From 43a10e3e77020c8f20f1fcf95aa366f1d4e5a779 Mon Sep 17 00:00:00 2001 From: "github-actions[bot]" Date: Thu, 5 Sep 2024 15:16:03 +0000 Subject: [PATCH] Deployed 88cd7a3 to 0.6.0 with MkDocs 1.6.1 and mike 1.2.0.dev0 --- 0.6.0/404.html | 539 + 0.6.0/assets/images/favicon.png | Bin 0 -> 1870 bytes 0.6.0/assets/images/hero.png | Bin 0 -> 381111 bytes 0.6.0/assets/images/hero.svg | 220 + 0.6.0/assets/images/illustration.png | Bin 0 -> 197865 bytes .../assets/javascripts/bundle.af256bd8.min.js | 29 + .../javascripts/bundle.af256bd8.min.js.map | 7 + .../javascripts/lunr/min/lunr.ar.min.js | 1 + .../javascripts/lunr/min/lunr.da.min.js | 18 + .../javascripts/lunr/min/lunr.de.min.js | 18 + .../javascripts/lunr/min/lunr.du.min.js | 18 + .../javascripts/lunr/min/lunr.el.min.js | 1 + .../javascripts/lunr/min/lunr.es.min.js | 18 + .../javascripts/lunr/min/lunr.fi.min.js | 18 + .../javascripts/lunr/min/lunr.fr.min.js | 18 + .../javascripts/lunr/min/lunr.he.min.js | 1 + .../javascripts/lunr/min/lunr.hi.min.js | 1 + .../javascripts/lunr/min/lunr.hu.min.js | 18 + .../javascripts/lunr/min/lunr.hy.min.js | 1 + .../javascripts/lunr/min/lunr.it.min.js | 18 + .../javascripts/lunr/min/lunr.ja.min.js | 1 + .../javascripts/lunr/min/lunr.jp.min.js | 1 + .../javascripts/lunr/min/lunr.kn.min.js | 1 + .../javascripts/lunr/min/lunr.ko.min.js | 1 + .../javascripts/lunr/min/lunr.multi.min.js | 1 + .../javascripts/lunr/min/lunr.nl.min.js | 18 + .../javascripts/lunr/min/lunr.no.min.js | 18 + .../javascripts/lunr/min/lunr.pt.min.js | 18 + .../javascripts/lunr/min/lunr.ro.min.js | 18 + .../javascripts/lunr/min/lunr.ru.min.js | 18 + .../javascripts/lunr/min/lunr.sa.min.js | 1 + .../lunr/min/lunr.stemmer.support.min.js | 1 + .../javascripts/lunr/min/lunr.sv.min.js | 18 + .../javascripts/lunr/min/lunr.ta.min.js | 1 + .../javascripts/lunr/min/lunr.te.min.js | 1 + .../javascripts/lunr/min/lunr.th.min.js | 1 + .../javascripts/lunr/min/lunr.tr.min.js | 18 + .../javascripts/lunr/min/lunr.vi.min.js | 1 + .../javascripts/lunr/min/lunr.zh.min.js | 1 + 0.6.0/assets/javascripts/lunr/tinyseg.js | 206 + 0.6.0/assets/javascripts/lunr/wordcut.js | 6708 + .../workers/search.b8dbb3d2.min.js | 42 + .../workers/search.b8dbb3d2.min.js.map | 7 + .../assets/stylesheets/main.3cba04c6.min.css | 1 + .../stylesheets/main.3cba04c6.min.css.map | 1 + .../stylesheets/palette.06af60db.min.css | 1 + .../stylesheets/palette.06af60db.min.css.map | 1 + .../generate-report/index.html | 738 + .../nixos-configuration/index.html | 742 + 0.6.0/index.html | 264 + 0.6.0/js/mermaid/Tableau10-31042135.js | 10 + 0.6.0/js/mermaid/Tableau10-558cc280.js | 9 + 0.6.0/js/mermaid/arc-c0f908ab.js | 148 + 0.6.0/js/mermaid/arc-d1f6357e.js | 86 + 0.6.0/js/mermaid/array-2ff2c7a6.js | 6 + 0.6.0/js/mermaid/array-b7dcf730.js | 6 + 0.6.0/js/mermaid/blockDiagram-5dc23a45.js | 1230 + 0.6.0/js/mermaid/blockDiagram-9f4a6865.js | 1822 + 0.6.0/js/mermaid/blockDiagram-efe38566.js | 1818 + 0.6.0/js/mermaid/c4Diagram-1e775db3.js | 1579 + 0.6.0/js/mermaid/c4Diagram-ae766693.js | 2473 + 0.6.0/js/mermaid/c4Diagram-af207393.js | 2463 + 0.6.0/js/mermaid/channel-ebbc4130.js | 5 + 0.6.0/js/mermaid/channel-f9001828.js | 8 + 0.6.0/js/mermaid/classDiagram-72b9c71d.js | 356 + 0.6.0/js/mermaid/classDiagram-f52caa06.js | 220 + 0.6.0/js/mermaid/classDiagram-fb54d2a0.js | 363 + 0.6.0/js/mermaid/classDiagram-v2-640c694e.js | 206 + 0.6.0/js/mermaid/classDiagram-v2-a2b738ad.js | 298 + 0.6.0/js/mermaid/classDiagram-v2-fedb80f6.js | 290 + 0.6.0/js/mermaid/clone-9ea6bfeb.js | 8 + 0.6.0/js/mermaid/clone-afc2f047.js | 8 + 0.6.0/js/mermaid/createText-03b82060.js | 2966 + 0.6.0/js/mermaid/createText-b70fe78a.js | 4929 + 0.6.0/js/mermaid/createText-ca0c5216.js | 251 + 0.6.0/js/mermaid/edges-066a5561.js | 1840 + 0.6.0/js/mermaid/edges-16357fde.js | 1083 + 0.6.0/js/mermaid/edges-ce5cfb7c.js | 1840 + 0.6.0/js/mermaid/erDiagram-09d1c15f.js | 1176 + 0.6.0/js/mermaid/erDiagram-543717f2.js | 1321 + 0.6.0/js/mermaid/erDiagram-c7ff1bec.js | 931 + 0.6.0/js/mermaid/flowDb-9a89ea33.js | 1126 + 0.6.0/js/mermaid/flowDb-ba9bd7fa.js | 1713 + 0.6.0/js/mermaid/flowDb-c1833063.js | 1714 + 0.6.0/js/mermaid/flowDiagram-aadb13b0.js | 797 + 0.6.0/js/mermaid/flowDiagram-b222e15a.js | 614 + 0.6.0/js/mermaid/flowDiagram-b5e7ba30.js | 1278 + 0.6.0/js/mermaid/flowDiagram-v2-13329dc7.js | 40 + 0.6.0/js/mermaid/flowDiagram-v2-54711e03.js | 32 + 0.6.0/js/mermaid/flowDiagram-v2-f2119625.js | 25 + .../flowchart-elk-definition-2d49707c.js | 93397 +++++++ .../flowchart-elk-definition-ae0efee6.js | 814 + .../flowchart-elk-definition-cf813a97.js | 48407 ++++ 0.6.0/js/mermaid/ganttDiagram-12cf43db.js | 3445 + 0.6.0/js/mermaid/ganttDiagram-3c2fde2b.js | 2501 + 0.6.0/js/mermaid/ganttDiagram-b62c793e.js | 2061 + 0.6.0/js/mermaid/gitGraphDiagram-942e62fe.js | 1800 + 0.6.0/js/mermaid/gitGraphDiagram-b9392a12.js | 1790 + 0.6.0/js/mermaid/gitGraphDiagram-c3a0619c.js | 1264 + 0.6.0/js/mermaid/graph-0ee63739.js | 881 + 0.6.0/js/mermaid/graph-fe24fab6.js | 1285 + 0.6.0/js/mermaid/index-01f381cb.js | 622 + 0.6.0/js/mermaid/index-bb6d8841.js | 373 + 0.6.0/js/mermaid/index-fc479858.js | 663 + 0.6.0/js/mermaid/infoDiagram-2f5c50c0.js | 319 + 0.6.0/js/mermaid/infoDiagram-94cd232f.js | 520 + 0.6.0/js/mermaid/infoDiagram-d0d5c9bd.js | 510 + 0.6.0/js/mermaid/init-cc95ec8e.js | 16 + 0.6.0/js/mermaid/init-f9637058.js | 16 + 0.6.0/js/mermaid/journeyDiagram-14fe341a.js | 804 + 0.6.0/js/mermaid/journeyDiagram-6625b456.js | 1191 + 0.6.0/js/mermaid/journeyDiagram-b56e6921.js | 1183 + 0.6.0/js/mermaid/katex-d90b6d29.js | 11624 + 0.6.0/js/mermaid/katex-ffb0e8f1.js | 14432 ++ 0.6.0/js/mermaid/layout-163b9689.js | 2314 + 0.6.0/js/mermaid/layout-fd473db2.js | 1536 + 0.6.0/js/mermaid/line-24d93f1b.js | 34 + 0.6.0/js/mermaid/line-87f517ef.js | 50 + 0.6.0/js/mermaid/linear-0ad15847.js | 595 + 0.6.0/js/mermaid/linear-9bcf74c4.js | 447 + 0.6.0/js/mermaid/mermaid-6dc72991.js | 6461 + 0.6.0/js/mermaid/mermaid-9f2aa176.js | 8112 + 0.6.0/js/mermaid/mermaid-dcacb631.js | 12793 + 0.6.0/js/mermaid/mermaid.core.mjs | 14 + 0.6.0/js/mermaid/mermaid.esm.min.mjs | 4 + 0.6.0/js/mermaid/mermaid.esm.mjs | 4 + 0.6.0/js/mermaid/mermaid.js | 195755 +++++++++++++++ 0.6.0/js/mermaid/mermaid.min.js | 2029 + .../js/mermaid/mindmap-definition-307c710a.js | 1177 + .../js/mermaid/mindmap-definition-696ddea4.js | 32342 +++ .../js/mermaid/mindmap-definition-9399c7e6.js | 18760 ++ 0.6.0/js/mermaid/ordinal-475e0c0c.js | 82 + 0.6.0/js/mermaid/ordinal-5695958c.js | 65 + 0.6.0/js/mermaid/path-39bad7e2.js | 118 + 0.6.0/js/mermaid/path-428ebac9.js | 91 + 0.6.0/js/mermaid/pieDiagram-828dae43.js | 502 + 0.6.0/js/mermaid/pieDiagram-bb1d19e5.js | 722 + 0.6.0/js/mermaid/pieDiagram-e854eaf0.js | 772 + 0.6.0/js/mermaid/quadrantDiagram-25a9848b.js | 1199 + 0.6.0/js/mermaid/quadrantDiagram-5fa00455.js | 904 + 0.6.0/js/mermaid/quadrantDiagram-c759a472.js | 1207 + .../js/mermaid/requirementDiagram-03163dc4.js | 769 + .../js/mermaid/requirementDiagram-87253d64.js | 1098 + .../js/mermaid/requirementDiagram-a721e157.js | 1091 + 0.6.0/js/mermaid/sankeyDiagram-33525efb.js | 1198 + 0.6.0/js/mermaid/sankeyDiagram-52ec8976.js | 818 + 0.6.0/js/mermaid/sankeyDiagram-707fac0f.js | 660 + 0.6.0/js/mermaid/sequenceDiagram-6894f283.js | 3346 + 0.6.0/js/mermaid/sequenceDiagram-9813c129.js | 3336 + 0.6.0/js/mermaid/sequenceDiagram-b517d154.js | 2234 + 0.6.0/js/mermaid/stateDiagram-5dee940d.js | 474 + 0.6.0/js/mermaid/stateDiagram-5ec31577.js | 467 + 0.6.0/js/mermaid/stateDiagram-fca82b5b.js | 275 + 0.6.0/js/mermaid/stateDiagram-v2-1992cada.js | 333 + 0.6.0/js/mermaid/stateDiagram-v2-992e82a1.js | 325 + 0.6.0/js/mermaid/stateDiagram-v2-ed04200a.js | 190 + 0.6.0/js/mermaid/styles-0784dbeb.js | 1363 + 0.6.0/js/mermaid/styles-11e81fdd.js | 1089 + 0.6.0/js/mermaid/styles-36a1a2e8.js | 1483 + 0.6.0/js/mermaid/styles-483fbfea.js | 509 + 0.6.0/js/mermaid/styles-727cdd61.js | 571 + 0.6.0/js/mermaid/styles-b83b31c9.js | 1484 + 0.6.0/js/mermaid/styles-cacbff60.js | 960 + 0.6.0/js/mermaid/styles-e75131e4.js | 433 + 0.6.0/js/mermaid/styles-f80da881.js | 1363 + 0.6.0/js/mermaid/svgDrawCommon-5e1cfd1d.js | 101 + 0.6.0/js/mermaid/svgDrawCommon-d6ab583c.js | 100 + 0.6.0/js/mermaid/svgDrawCommon-ecc5f780.js | 64 + .../mermaid/timeline-definition-23ce0e2e.js | 1211 + .../mermaid/timeline-definition-4ee9bff4.js | 795 + .../mermaid/timeline-definition-bf702344.js | 1219 + 0.6.0/js/mermaid/xychartDiagram-de2e5521.js | 1800 + 0.6.0/js/mermaid/xychartDiagram-e5e6b652.js | 1284 + 0.6.0/js/mermaid/xychartDiagram-f11f50a6.js | 1745 + 0.6.0/search/search_index.json | 1 + 0.6.0/sitemap.xml | 15 + 0.6.0/sitemap.xml.gz | Bin 0 -> 245 bytes 0.6.0/stylesheets/extra.css | 0 latest | 2 +- versions.json | 11 +- 180 files changed, 559101 insertions(+), 4 deletions(-) create mode 100644 0.6.0/404.html create mode 100644 0.6.0/assets/images/favicon.png create mode 100644 0.6.0/assets/images/hero.png create mode 100644 0.6.0/assets/images/hero.svg create mode 100644 0.6.0/assets/images/illustration.png create mode 100644 0.6.0/assets/javascripts/bundle.af256bd8.min.js create mode 100644 0.6.0/assets/javascripts/bundle.af256bd8.min.js.map create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.ar.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.da.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.de.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.du.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.el.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.es.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.fi.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.fr.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.he.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.hi.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.hu.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.hy.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.it.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.ja.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.jp.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.kn.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.ko.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.multi.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.nl.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.no.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.pt.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.ro.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.ru.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.sa.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.stemmer.support.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.sv.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.ta.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.te.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.th.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.tr.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.vi.min.js create mode 100644 0.6.0/assets/javascripts/lunr/min/lunr.zh.min.js create mode 100644 0.6.0/assets/javascripts/lunr/tinyseg.js create mode 100644 0.6.0/assets/javascripts/lunr/wordcut.js create mode 100644 0.6.0/assets/javascripts/workers/search.b8dbb3d2.min.js create mode 100644 0.6.0/assets/javascripts/workers/search.b8dbb3d2.min.js.map create mode 100644 0.6.0/assets/stylesheets/main.3cba04c6.min.css create mode 100644 0.6.0/assets/stylesheets/main.3cba04c6.min.css.map create mode 100644 0.6.0/assets/stylesheets/palette.06af60db.min.css create mode 100644 0.6.0/assets/stylesheets/palette.06af60db.min.css.map create mode 100644 0.6.0/getting-started/generate-report/index.html create mode 100644 0.6.0/getting-started/nixos-configuration/index.html create mode 100644 0.6.0/index.html create mode 100644 0.6.0/js/mermaid/Tableau10-31042135.js create mode 100644 0.6.0/js/mermaid/Tableau10-558cc280.js create mode 100644 0.6.0/js/mermaid/arc-c0f908ab.js create mode 100644 0.6.0/js/mermaid/arc-d1f6357e.js create mode 100644 0.6.0/js/mermaid/array-2ff2c7a6.js create mode 100644 0.6.0/js/mermaid/array-b7dcf730.js create mode 100644 0.6.0/js/mermaid/blockDiagram-5dc23a45.js create mode 100644 0.6.0/js/mermaid/blockDiagram-9f4a6865.js create mode 100644 0.6.0/js/mermaid/blockDiagram-efe38566.js create mode 100644 0.6.0/js/mermaid/c4Diagram-1e775db3.js create mode 100644 0.6.0/js/mermaid/c4Diagram-ae766693.js create mode 100644 0.6.0/js/mermaid/c4Diagram-af207393.js create mode 100644 0.6.0/js/mermaid/channel-ebbc4130.js create mode 100644 0.6.0/js/mermaid/channel-f9001828.js create mode 100644 0.6.0/js/mermaid/classDiagram-72b9c71d.js create mode 100644 0.6.0/js/mermaid/classDiagram-f52caa06.js create mode 100644 0.6.0/js/mermaid/classDiagram-fb54d2a0.js create mode 100644 0.6.0/js/mermaid/classDiagram-v2-640c694e.js create mode 100644 0.6.0/js/mermaid/classDiagram-v2-a2b738ad.js create mode 100644 0.6.0/js/mermaid/classDiagram-v2-fedb80f6.js create mode 100644 0.6.0/js/mermaid/clone-9ea6bfeb.js create mode 100644 0.6.0/js/mermaid/clone-afc2f047.js create mode 100644 0.6.0/js/mermaid/createText-03b82060.js create mode 100644 0.6.0/js/mermaid/createText-b70fe78a.js create mode 100644 0.6.0/js/mermaid/createText-ca0c5216.js create mode 100644 0.6.0/js/mermaid/edges-066a5561.js create mode 100644 0.6.0/js/mermaid/edges-16357fde.js create mode 100644 0.6.0/js/mermaid/edges-ce5cfb7c.js create mode 100644 0.6.0/js/mermaid/erDiagram-09d1c15f.js create mode 100644 0.6.0/js/mermaid/erDiagram-543717f2.js create mode 100644 0.6.0/js/mermaid/erDiagram-c7ff1bec.js create mode 100644 0.6.0/js/mermaid/flowDb-9a89ea33.js create mode 100644 0.6.0/js/mermaid/flowDb-ba9bd7fa.js create mode 100644 0.6.0/js/mermaid/flowDb-c1833063.js create mode 100644 0.6.0/js/mermaid/flowDiagram-aadb13b0.js create mode 100644 0.6.0/js/mermaid/flowDiagram-b222e15a.js create mode 100644 0.6.0/js/mermaid/flowDiagram-b5e7ba30.js create mode 100644 0.6.0/js/mermaid/flowDiagram-v2-13329dc7.js create mode 100644 0.6.0/js/mermaid/flowDiagram-v2-54711e03.js create mode 100644 0.6.0/js/mermaid/flowDiagram-v2-f2119625.js create mode 100644 0.6.0/js/mermaid/flowchart-elk-definition-2d49707c.js create mode 100644 0.6.0/js/mermaid/flowchart-elk-definition-ae0efee6.js create mode 100644 0.6.0/js/mermaid/flowchart-elk-definition-cf813a97.js create mode 100644 0.6.0/js/mermaid/ganttDiagram-12cf43db.js create mode 100644 0.6.0/js/mermaid/ganttDiagram-3c2fde2b.js create mode 100644 0.6.0/js/mermaid/ganttDiagram-b62c793e.js create mode 100644 0.6.0/js/mermaid/gitGraphDiagram-942e62fe.js create mode 100644 0.6.0/js/mermaid/gitGraphDiagram-b9392a12.js create mode 100644 0.6.0/js/mermaid/gitGraphDiagram-c3a0619c.js create mode 100644 0.6.0/js/mermaid/graph-0ee63739.js create mode 100644 0.6.0/js/mermaid/graph-fe24fab6.js create mode 100644 0.6.0/js/mermaid/index-01f381cb.js create mode 100644 0.6.0/js/mermaid/index-bb6d8841.js create mode 100644 0.6.0/js/mermaid/index-fc479858.js create mode 100644 0.6.0/js/mermaid/infoDiagram-2f5c50c0.js create mode 100644 0.6.0/js/mermaid/infoDiagram-94cd232f.js create mode 100644 0.6.0/js/mermaid/infoDiagram-d0d5c9bd.js create mode 100644 0.6.0/js/mermaid/init-cc95ec8e.js create mode 100644 0.6.0/js/mermaid/init-f9637058.js create mode 100644 0.6.0/js/mermaid/journeyDiagram-14fe341a.js create mode 100644 0.6.0/js/mermaid/journeyDiagram-6625b456.js create mode 100644 0.6.0/js/mermaid/journeyDiagram-b56e6921.js create mode 100644 0.6.0/js/mermaid/katex-d90b6d29.js create mode 100644 0.6.0/js/mermaid/katex-ffb0e8f1.js create mode 100644 0.6.0/js/mermaid/layout-163b9689.js create mode 100644 0.6.0/js/mermaid/layout-fd473db2.js create mode 100644 0.6.0/js/mermaid/line-24d93f1b.js create mode 100644 0.6.0/js/mermaid/line-87f517ef.js create mode 100644 0.6.0/js/mermaid/linear-0ad15847.js create mode 100644 0.6.0/js/mermaid/linear-9bcf74c4.js create mode 100644 0.6.0/js/mermaid/mermaid-6dc72991.js create mode 100644 0.6.0/js/mermaid/mermaid-9f2aa176.js create mode 100644 0.6.0/js/mermaid/mermaid-dcacb631.js create mode 100644 0.6.0/js/mermaid/mermaid.core.mjs create mode 100644 0.6.0/js/mermaid/mermaid.esm.min.mjs create mode 100644 0.6.0/js/mermaid/mermaid.esm.mjs create mode 100644 0.6.0/js/mermaid/mermaid.js create mode 100644 0.6.0/js/mermaid/mermaid.min.js create mode 100644 0.6.0/js/mermaid/mindmap-definition-307c710a.js create mode 100644 0.6.0/js/mermaid/mindmap-definition-696ddea4.js create mode 100644 0.6.0/js/mermaid/mindmap-definition-9399c7e6.js create mode 100644 0.6.0/js/mermaid/ordinal-475e0c0c.js create mode 100644 0.6.0/js/mermaid/ordinal-5695958c.js create mode 100644 0.6.0/js/mermaid/path-39bad7e2.js create mode 100644 0.6.0/js/mermaid/path-428ebac9.js create mode 100644 0.6.0/js/mermaid/pieDiagram-828dae43.js create mode 100644 0.6.0/js/mermaid/pieDiagram-bb1d19e5.js create mode 100644 0.6.0/js/mermaid/pieDiagram-e854eaf0.js create mode 100644 0.6.0/js/mermaid/quadrantDiagram-25a9848b.js create mode 100644 0.6.0/js/mermaid/quadrantDiagram-5fa00455.js create mode 100644 0.6.0/js/mermaid/quadrantDiagram-c759a472.js create mode 100644 0.6.0/js/mermaid/requirementDiagram-03163dc4.js create mode 100644 0.6.0/js/mermaid/requirementDiagram-87253d64.js create mode 100644 0.6.0/js/mermaid/requirementDiagram-a721e157.js create mode 100644 0.6.0/js/mermaid/sankeyDiagram-33525efb.js create mode 100644 0.6.0/js/mermaid/sankeyDiagram-52ec8976.js create mode 100644 0.6.0/js/mermaid/sankeyDiagram-707fac0f.js create mode 100644 0.6.0/js/mermaid/sequenceDiagram-6894f283.js create mode 100644 0.6.0/js/mermaid/sequenceDiagram-9813c129.js create mode 100644 0.6.0/js/mermaid/sequenceDiagram-b517d154.js create mode 100644 0.6.0/js/mermaid/stateDiagram-5dee940d.js create mode 100644 0.6.0/js/mermaid/stateDiagram-5ec31577.js create mode 100644 0.6.0/js/mermaid/stateDiagram-fca82b5b.js create mode 100644 0.6.0/js/mermaid/stateDiagram-v2-1992cada.js create mode 100644 0.6.0/js/mermaid/stateDiagram-v2-992e82a1.js create mode 100644 0.6.0/js/mermaid/stateDiagram-v2-ed04200a.js create mode 100644 0.6.0/js/mermaid/styles-0784dbeb.js create mode 100644 0.6.0/js/mermaid/styles-11e81fdd.js create mode 100644 0.6.0/js/mermaid/styles-36a1a2e8.js create mode 100644 0.6.0/js/mermaid/styles-483fbfea.js create mode 100644 0.6.0/js/mermaid/styles-727cdd61.js create mode 100644 0.6.0/js/mermaid/styles-b83b31c9.js create mode 100644 0.6.0/js/mermaid/styles-cacbff60.js create mode 100644 0.6.0/js/mermaid/styles-e75131e4.js create mode 100644 0.6.0/js/mermaid/styles-f80da881.js create mode 100644 0.6.0/js/mermaid/svgDrawCommon-5e1cfd1d.js create mode 100644 0.6.0/js/mermaid/svgDrawCommon-d6ab583c.js create mode 100644 0.6.0/js/mermaid/svgDrawCommon-ecc5f780.js create mode 100644 0.6.0/js/mermaid/timeline-definition-23ce0e2e.js create mode 100644 0.6.0/js/mermaid/timeline-definition-4ee9bff4.js create mode 100644 0.6.0/js/mermaid/timeline-definition-bf702344.js create mode 100644 0.6.0/js/mermaid/xychartDiagram-de2e5521.js create mode 100644 0.6.0/js/mermaid/xychartDiagram-e5e6b652.js create mode 100644 0.6.0/js/mermaid/xychartDiagram-f11f50a6.js create mode 100644 0.6.0/search/search_index.json create mode 100644 0.6.0/sitemap.xml create mode 100644 0.6.0/sitemap.xml.gz create mode 100644 0.6.0/stylesheets/extra.css diff --git a/0.6.0/404.html b/0.6.0/404.html new file mode 100644 index 0000000..629a58d --- /dev/null +++ b/0.6.0/404.html @@ -0,0 +1,539 @@ + + + + + + + + + + + + + + + + + + + + + NixOS Facter + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+
+ +
+ + + + + + +
+ + +
+ +
+ + + + + + + + + +
+
+ + + +
+
+
+ + + + + + + +
+
+
+ + + +
+
+
+ + + +
+
+
+ + + +
+
+ +

404 - Not found

+ +
+
+ + + +
+ +
+ + + +
+
+
+
+ + + + + + + + + + \ No newline at end of file diff --git a/0.6.0/assets/images/favicon.png b/0.6.0/assets/images/favicon.png new file mode 100644 index 0000000000000000000000000000000000000000..1cf13b9f9d978896599290a74f77d5dbe7d1655c GIT binary patch literal 1870 zcmV-U2eJ5xP)Gc)JR9QMau)O=X#!i9;T z37kk-upj^(fsR36MHs_+1RCI)NNu9}lD0S{B^g8PN?Ww(5|~L#Ng*g{WsqleV}|#l zz8@ri&cTzw_h33bHI+12+kK6WN$h#n5cD8OQt`5kw6p~9H3()bUQ8OS4Q4HTQ=1Ol z_JAocz`fLbT2^{`8n~UAo=#AUOf=SOq4pYkt;XbC&f#7lb$*7=$na!mWCQ`dBQsO0 zLFBSPj*N?#u5&pf2t4XjEGH|=pPQ8xh7tpx;US5Cx_Ju;!O`ya-yF`)b%TEt5>eP1ZX~}sjjA%FJF?h7cX8=b!DZl<6%Cv z*G0uvvU+vmnpLZ2paivG-(cd*y3$hCIcsZcYOGh{$&)A6*XX&kXZd3G8m)G$Zz-LV z^GF3VAW^Mdv!)4OM8EgqRiz~*Cji;uzl2uC9^=8I84vNp;ltJ|q-*uQwGp2ma6cY7 z;`%`!9UXO@fr&Ebapfs34OmS9^u6$)bJxrucutf>`dKPKT%%*d3XlFVKunp9 zasduxjrjs>f8V=D|J=XNZp;_Zy^WgQ$9WDjgY=z@stwiEBm9u5*|34&1Na8BMjjgf3+SHcr`5~>oz1Y?SW^=K z^bTyO6>Gar#P_W2gEMwq)ot3; zREHn~U&Dp0l6YT0&k-wLwYjb?5zGK`W6S2v+K>AM(95m2C20L|3m~rN8dprPr@t)5lsk9Hu*W z?pS990s;Ez=+Rj{x7p``4>+c0G5^pYnB1^!TL=(?HLHZ+HicG{~4F1d^5Awl_2!1jICM-!9eoLhbbT^;yHcefyTAaqRcY zmuctDopPT!%k+}x%lZRKnzykr2}}XfG_ne?nRQO~?%hkzo;@RN{P6o`&mMUWBYMTe z6i8ChtjX&gXl`nvrU>jah)2iNM%JdjqoaeaU%yVn!^70x-flljp6Q5tK}5}&X8&&G zX3fpb3E(!rH=zVI_9Gjl45w@{(ITqngWFe7@9{mX;tO25Z_8 zQHEpI+FkTU#4xu>RkN>b3Tnc3UpWzPXWm#o55GKF09j^Mh~)K7{QqbO_~(@CVq! zS<8954|P8mXN2MRs86xZ&Q4EfM@JB94b=(YGuk)s&^jiSF=t3*oNK3`rD{H`yQ?d; ztE=laAUoZx5?RC8*WKOj`%LXEkgDd>&^Q4M^z`%u0rg-It=hLCVsq!Z%^6eB-OvOT zFZ28TN&cRmgU}Elrnk43)!>Z1FCPL2K$7}gwzIc48NX}#!A1BpJP?#v5wkNprhV** z?Cpalt1oH&{r!o3eSKc&ap)iz2BTn_VV`4>9M^b3;(YY}4>#ML6{~(4mH+?%07*qo IM6N<$f(jP3KmY&$ literal 0 HcmV?d00001 diff --git a/0.6.0/assets/images/hero.png b/0.6.0/assets/images/hero.png new file mode 100644 index 0000000000000000000000000000000000000000..3c310914f0320da3a552558ea54b2b964add41c1 GIT binary patch literal 381111 zcmZs@2{@JO_dfojIGsdFQIt{{N~VM&bP7c%C8Uj#B$+d1*gBoaoJ^UUP!u8av^%Dd zB(Y-~woJ*e4YAGpx1M+Fe7^td`oGupxz4H2_U`9d&sz7o?|VH?z*$|*4S#O`6T`3# zr%#>K$1raA*FPNoV26J^EN^gvf2?yjW$cV$T$Sj5EVcG8ufbn#yRB|?`@H@2+iq8! zEHO7XH%V(d8)u6v4wjPkPFC^b%G)t)7k2vO@eA$=qh0OJd&yDMVQ23UtdMp_BqH{- zep$%OyT-?j42FtDoBW|;ZG@m%{a1T$#$f-H_?I-XU1&AfboV26sIO*idD9sw)zlKg8Ofa0q+?V5~@!;cB0{mpk z?J~K2DW!gR@L1&7_<(h*G$CSm%U9 zg9`kWrhd2He#|tWYh1YPuv>L+hpT{rLAU<_40AYB>9Eb_F85N(&Qw->T`F45E|!vS z1pR^@h|!$k?-VnglIPt@g5V1U1JJ5&R0vrlrFCxOfE|!+Vdog>v`Mu0nU;qTZ}EKv z4E#k7`f;ftsl!fIg0~1U{Ivw;5!h1H2?fm6exo%g39TXZa$;=C(j(imDTKjKg%Rbd zVUbHeSTSG9sH@?*?-v=F6b&tLv@Lj+1jr2s8a#=|IAc&m@k8|{Ml1E|W?He;_v)c;^zrUn|Q!^=sLq zaETAS$M<|IopS0`XGXHdGQz8q7iDuE70=))>Y6%kB9x?Y=CZ_5ahu4r2H&j}_ z9*M&Bkm#XDRm0e{_u zbX0NG%7XKn0*nnK1w}4>7RuQa)`Yx*Y zeJ-s@*n`S}Ui3toOe<(mx>M9+R-N+^k7WPMvd76tw^U1hNee;@ytwr0K-qm(>aI$M zEe-nJ_q+%N&2r3Cv~H2BQr5#E#U)%}FTOIh)d;_D%j-;ehN{D*i`OG_HKd%FsSFzl zqkqehkO?&`IyAnk`nq$H5~PG~=k`9M!Q+V|L(5b0DR}y;ojgggd!Ame!~O~8Zr$e|4k=um8HUaSRg*xitl2jO9X^*Xz$o~xbwwKEbkG~4pFh*`7}a6QkK$Zr>bF5U ze;WXdtmA+^!9z7W;LZah2#Z-(qCwilwv=kQl`a>qBKh<~yalww94YE3`z+pYT2Z$IxuKPk;s z$CeI@O0tYUbrig6JP4?fF(T5D-+-5hZBp7dTJ8Tu5_l=;zB|E+ z(vsx>Pd$bxLmomc7rN(#v6VQKBG(CI{@RAlZEj!amUilEF<*=Aeoo2s^Hcj#o5Oq; zQy^bbraqONX_3UY28Y#sJvU@iQ(;)2H4slwlyj0K;a_Q>FzwhGD zD+$GRfu$@^%J7)(P2nZDMJx5`Y7vgYt7|V9SSEQINAIhd+z+MGgW%fpn(?fR&IxEE zr<&;$0C5OKn~V7DE?vO+2_{^dYLI8n8MpwXH%{{|EyG+WR3)t{`z_6lQ}}g9osPWLXNhX3eTDA*!asy9m^ zd6tQXC^p_6CW;y9p?I4{@A7^ADt&)PewACFO>m#(I9iqmd8mg1*|XYw*nE}XWoHXr z2v-HOoUA%e_rw&jK-fdALZI=vRV5-s#n*)?7DHRvKe3%^z5QxZgUKm$qHXk{bJRUV zPQYh8Ei5qpCk_x(o`GWz3T%a32+Wo*uTx?aeFWmO+TPIGFj8|$WFR3>mD7%e9rNXT zm439tHG-MIigyM%#6loF{%%B2{SiTR`c>5*upNnj z$uZNAjB}1X#(j#s9@|(*CoXpD31BPLc5XOg*a?WIFl!uM)8>M}K%e_Cp0T8i3qPHf zt`r92+ypQM(G7cNtIqeAMmbqYCoExiXItI{Ats|}WYF52AJ2T#pogSWrB9KN9dlzD z24q_~9cD3BDURdazRrfClAd0=Z+=?2+D8@Yle!O5LhLh;6HbJSFKA7b0~L_|C61*J z9!%LW#)@-K)s2YYZ+!6J+pSN+&r0vfLYHp%zSSI>3?Z;w70=*_G@}NkxHS{Ij)bo} z`^2#{(B&X)pJ&VMW;wiND_Sou8}&ywrl&u*RY0i%5B1uM3;52Uo9qGFhp0kAX{z;e z>tZ}L_N7__4fBmLhYd@UxhYUk@n2N!4@0lCJH#1Nv>7dTPn25#v(QT~5()y+_tRbu z`l!|@#}vH9Vf*W$Lw)YX{VCTlZXFN%C~RlpmBI%ujReQS{4NbG7d)}8QIC;D(fn_{ zusp@%;>F|2kbJ;jdCpOf?}NX3mY)91wg6gBKJd;H9()lj%5vX+^hv|2G0Wpjh)t0euCJ;?|P;qi@VMeNceNG`@Q)OtJfOh$@rUtH*Z&?dJ*-Si?h z@i3C!vX=V(5~I{0SJ}HFBvSwPBDd|cYeo=mkchws9^Ff?8sz+YW!v&fo1`G1kM*_g zt4wFfa9Vy6!<2c^%4Bp(gbPN#x@@*BSp|+Hy1L!xtn~fGcJaSo(>=2-P6Z01%_YRK z^dpl4*)F~unTq~FqvJc{#O%;9U=2A{2-gcEWEHltU?j&eS4+DuqmU%xzjr7MwF=wG zZgdn3EG>jZhQ6USIg0{MyIfT~n2Av-k#v!DRF>_v4Myv|o|SiB{fb(pZ-hLP^VYo2 zwBP>&MFt)<8U6HUBl3`$<_BG4#SxW4JYXO(4FDWk@%jdATnP|Y)GmoGqXP#30PbSP zfNny0BLgY2XT1N8#VZOC&k*WH+mcn{gu0iuawR}YZC-n%N9uLKtgATdSXzs}jb9S- zoI+gm5il621;*KVoxk48v0Kjjt4qXc&;ld$c}p%3`6aI&r15Wtl^Og;L0m$vIINc@ zy^@Jt>+tXF;%?Nw`pgXsG|9G1mS6(iC%YO(=>#YRVoGVU2*#~ZByd}+OCLd>Tqqx22L-4#F{!aw2Xsk5_CE7I z_bnMVzAPAZt^P0XSgW7@y?RBPu{lHF?Fla(JF9ad3y!5(cif;%$w#tcB$@wF5QAnH z98_R!XG_y>J{ws;6-hqq_w?hwG{mkzyC4dTva1WmoWM6YGz^yThqsCb84@j9_qBOp^A7(sM4LelE$zvBK# zAZr@5GMkD{%SNDpPah*uP=c@y9tZmukNq~_nK>qtb zGTU^YIa%n`t<|{04iIW5Miz$yI>4iA{AxWtt4VPK{!KUueF0k)sLe2n-si?nx@QHi zs)Eik{*Tfy!on~l<{A}EYl@@kS4*Kt(nSz%!P9wSxQUHrpnXho&(%h}h7P7ckwG)z zY6H~)Cpx}4;u0o$EzVV@X%W68BVD98lc_jt|C5W6&uC4n$xkY4l>-DvT6m-wFFRBw zWIE+#`cWv>R1mY`_T?;86_67S!fh@GXYbE3j~>^q!1-+MYEP7mOXyGixyoVEK%`xu zPR66dm%z7NmGWcJ7SswX+es8tzM*T+n()A}G#KF9(jDdGfbA|s&N^tdNNd!*Pfrib z$C(yv+1Hb{kmwb_#$prv{4V_2Jv?>zc_sz+7C!{45;zj|y(}z_H5$;a0})v*9)epE zPMtc6HAY=yP|x{FVFvKYNf0)X^-66=bSx$RLSH(vnA^F|O_r07CmS%r{b9Z5`85vQ zW3GJJTj!KJ^C>U)t7-x4$s^Tx6vyv(t0Dm{Mp|F1nZB=^RS@t{@&tNcIwG)5hzo?lf^1GM7tlCaCYmMAFmi;AcI$Yvuk+7X)>R zWa-OLOK$5})rRXA16UlwUfWcGH!#~Ua>aL*VJVtc7iTiH*#F>r=ZnVFkNXlq$Bz^< zNkcS~;5l+YcM0IzjYT$M(rOye>|GApuh%6gH0Q5MpcK1eJ*44LUc*DWXF%5Z|7rHn zD?IiP7MC~T(stqrv=&xsQlU>TVURsRzaSV@{f0{QlacO=G~*ZjQOwQuziUrWKUoiZ zwJr{{6sP?KI0+_)@Iv{=L-S;-XPDyFv?DCC+x!}g$on8AI$Sp!wEiaF`3?V{9{*nZ zRbY9~;3vgz#iq$YAh7IkJrEB`JzW}xk^&A20O^{;@@FO74tn*0dn+7jVH*;dJZ?Gd z37Y$9vdkV|7*lMw*}wpf`WtHUVa%!}^srv;zLI#QaQ~F7obM(8q7P5L9*jZRw1n6i zCAd#A+VT_PSOtN&#v?5ojOVO$jqew3V{)gT#i99QtB!{zh-1Nf;*!35;!^>;Q5;a) zZ&*@;MIe`yzOAQwULk&hTZCfkvq$v*GGT= zQXk;75v60X9nO~k5x)$22m$$yAI(xd>97cV0G@<&1e(COfU#uYCA!YGHIjSuP0;}DO{pqQ=fYjAeH_tc}qJUyx~UV=>QGy(7qy~bZJ$bJLonYMqSUhyASeWk!Gbkd3Q24IND*r=86wh9w+@L(FRbpDVc8mV$VXZ$!R?_L=hmQd#G36Jk03L6OI( zyKUlR`MjbRW1&$C8j_COn^CO6c_KD^CMGF;*L5uk5}V*U>>FXw zO%d|_3n$Ut5jJGoz|O6Rcgcl<#hCyw;L>%n;(* z3&ME-eZHQRXt!^B!cg`ix{a$}Q}h3s3HJTE_^U9}aL~S&f2ksd;*VGP6a-qo9;iR+ zZ^-!VT#vST?~0f+KZF@J#z04>d3*WqJ4lh`k3G+9P+9}4g{O0`dQb9DXkkRxxGbDj zDTE;O6ut6*7I5EE-DXJ~L2_M+{jUZq_fZ!yNwA@{#GHTLE{&sQqKeT$Nw=zvk-1 z_Q>KjxA`+UVWp(?tD>s&{q{xJt`LO^}|F%i;Q4En}0XNFlpaeqtjRz>pF3MpFY7Lqt}Fawc;`Kr{vB~t&X0ALH%z3uQ- zeo0WOr+bq98&*lT&j`?_SEYNN{_a9R3nf=W2~sStRH+Tq)$p+Q#B{$h#j%$6Jd8JL z<-k+GM^Y^OezHvjkRLLKbp&ipx{o}uG`?C<0S?DmiOptM7D;aGs&PH# zq%pWrV>mqn=NCG@8?sBPp~46C@ZC}!0D04IqGCYuVV}=dNcGxQ7t5rz+x-ZyGg;UR zH$%bqG$X{Zw0qHh>(ic;P9T5|9eyCXToC+bjyzBQ54(AyiUn^AW--s<0=RsJ-D{cL z4d{#5BS19TkA(qek4j9Z1$WaSXfFu%2|}<038qa2D}YBaXO-(hM?n_0HjFl?kBfoI z?Y9Tpmq{S8YH^y93TYiKg-ZFF#MN)f`$3DMs%v#Ax6@(d0TIDpcMZ%Oo^#zpYgUO8 zLabEB(tNCrVB5RMiz7Km>sjWG(|F=Ox`|?>+ zbS@Ym>tu16w?z(ZI1o0h6gMP3yEwH|CChB01UXf91vQGM{ZL21ecr6#%Ohp9AW}Oe z`3Go;%b$_1arM@Csf@7OW4crU7$hH=BGMqp{sREKP8xow^SYoL@}+|B<=OtvY{hc4 zasSROheE)`Cg$66@i#GQkgZiTg)|cTSNifv4|*9}g75OmekLzK(QfekzyY1;5;!|g zOJhEYtKaT29_LgvwxwwFz_83qL40TbLt;z9tj(zEQZHR5S3+ng+tK-<#$G= zwYuaSTQ0Q~TMOIG-6W6|ByX3kbQI7QGJoz*k1xMyaIUpyB`;F{>r6opSB(CQq1obK zOvQtqrG4HGxoHeN_d#Jf3UFZ;F#nV?-mnKSF1gTJAk@Y#T)yJQ5buUf zcW&!EQL!)>Gg-jstAJoUIa{#7aREw~K(nHd_kHde;EY%wVArMWdUrZA>v1U!EVaGcJn za4j%%Yf;rCw1$sQ&@)ErdtJuwXO4WI95SoY^ZB*hDXzv+P8V8s8s*wo#Kwpza1K$QvsDmrk7 z=Nau0#_vNH48!Du2bR|H<( z&XJHgJ+1Ivbt#Q;cz;0@tLV>WtFS&k#;;s{*OE?g(z-=zWf&)8N~?_VUURaILaPz- zVNg27&qih{1ugqXj4!t;a)Dzgz-I{1z{3L;mxODH>Hyb~Z;&-sR`y_(DvFO3FExx+ z@bKvRu?kY}@IQIY*UQ7>U2zy03{uiMCy*Nfx;lOlWUNEZ&SNXe`DijXUIc6Fs|-^C zr>XN0A0IIg6-u*QW5G)8gw#V5gVxDk?c}0EzMC%^7TOveJKUoKsAfVi#0;+6}ckA>28rJ21o9Y{pg0qI|6|q9(Epe-fi0_2di1*xaW(?jN5P$y0dnsq4XV`4 zvdB*F*}ZP;^luSqP0wx11n!@Baba9d?UnXrO!z%KGM?!CoGbMl>|4paaZ zzuceYN)>4;UozcGe&~2j++ebQ*bp+n^SW{L+$1*ijoPl?f$!kL)9z$j%%I$+gi9U@axh z%nT3cu-zsIA)Saio&0aWFfe!}HPWl7vh<_RedJAnv(-Sq{@p0(xcdtl1fmqDngP4unZdLC=Z+^2D}+t?;T6vkFg;1&L=u5ZZ(% z6LW6Fp76RhSv4e6YI63^@rYcgGY7tN$XYTU0?l}5@abHW=`W2zbVt0YEJVoC!Zrl(!pMZ#SY;IqChBwt5c&l zBbP>NK9sw~Z|ZzOQ<(hG3>CAHhX?XPYKqMOA~IL28f@v>!sAff?a8QgUrYob#$vrz zs;6&IK-zGB2H#6h)e}6@z?OV4X%i7Vv9YYq%aI^~iv}FM(NKt***$vMJv}Q)NJ$hF z?qn~VU-)$%X~ut$PfV3Zc8u+T7TpUJJI;vr2a{A7`_nrP=;@xIxK7STq~XcC-G6Ra z&j-GadaQ|`Q{#|y24fjZPpTR z?)!f)qpJqH^>|CUu~z{sZL%+)zlb1~992ZJIEZb`pxullKG4vXC>S1H@gRb#`Og+`Z z2u`@dq4I1~hk?-|U4pQ?19fMpQ{#68*o9r*F{Pj|RS$3^3#~FGrEu1O!lNZ#ojYWA z<)6jZV+(Vm*_84l$MllDx496y8#Nvp29_&;>w?k$8&IHO=@; zyn^zA+cOM6Zday13x0u27fq`naiKT&%4&74bR)mmU#u5(qy75(X_ewTQ&X+`CWrI@ zOXwecD#D0!b=(N!eh%km9V@6j_Nyk|z7}#8O2h8gkI9H1i#jNCUkyF1nf#&#K`B); zINY4?4I~AoHho6j)!Z1-n!uQs7`XyLshUyvjBEzM*R~4kcHL`0ToiXNso({T+h2gV zZato=-5z9}tC0gOO*?C^k6d@7wl1V4GbALXq!3xTftT|FC=u!wIH+l<3Ydx785kHS zd#?aH6w@ULph{kR4R@9?W=>yPe`ZeutbyCKs1k!Q6VgnjAHbBBKKV+jvzK3A zYjSiRs2CNleffvoHMAp;=bE`!Q0IG-r65xS&{fh_T+YIMl9@-hSJ2oPuSKtWOIJ%{o*9MJ1&$W-SH6jVsWup)uohi%~jQs-WJj#nriz_ZqJYB>OBVy0Ht6*0l^Z=K}*5tDjL* zi)}CgC2Szxk=q+@-Jlm(U_UzN#@CyHURdaR1$JtCKdc?TiDB_Fah~sbavk^Tn09 z@g6nj8#QfPypd<}m_XomHTe(be?@*Ip| z@DdmLkTmGLk$WsiPskh2Nl{HpJc&3DJaHlsx?{UDL&@(1fqM;jo6PG10Wl|l0Xn*L z8HcYIsC9gRm^{{b6B!vj-p7qSdQw=*pTi=S%S-WOr4``gjjA`*l1syjvIRdXWx!K1 zQ(lC7OQlYTiVh$#g>F*K_0k!@gGg_7s(Ng-MfYP(zoaD}3vHa0aAWtfvagu7E2VdH zfXq_#CT-9I2fgWg}xp2g=SM zTO=-3wm_*3t`UIY?He(J(9l!inzJe-gy-a^5f|@@tT|J!@RNDTB6I^uai7EW!DqIwtP5^gH@ci%VRRl9m1<3EYizQv^ zCtqjv)2HM&yPvIT#%&+Nk>c{45NqV|4B(ERzV^{eq0l8ohRq z4je+dA#2?GA5<_#NZrfA==iegS*10ocHy=#Tz^SPxUCMHmm=G#@56#br74PB!?Mcla$C>h-H=%lvCm}%yu#d*F=k9VK? z1()&8!p*to*7csmJPBuDg*cdbcoR+gOP=UUg<#`p=+@Pc;ezLOjD6=nFy7paUx9)N zGBhDY4>&R2LYgRkkL(y*k4OryUd3$zes0YcIiSu~|I>XHh*ez#dOFZl3I?*t+w zEL-Wq#ApT1pn>dy)f5O>j?M;{WNL5RiWa6>e7lEq95UPEU}Vx8#xAi+(FWG1aL;!g}s_s88nLtXCl zGK8q~kJZ&eeeq^sU4igTFAfkjQwC;#@+8^*d-HQqsF@qU$7FvNe@bLgFDm~^m4G@J zb;VCb9fkw=?O%L2fFP0ktMuj4{FF|>5Kmiv$sj@Ymo}9EuoJ?tPQ~)15bG?%SMjpF zit_Qc%6AYQ{O}V;^eoz4!;xCmC7+ME@u9vgGtIThH3Igfpj&p9f;bLMpB>`a8JbD! z%dIto4FCRaEcL@(-~Tg?k1GB(AaR?Mq_2QAHC~o^ZQP<_{?3nI1*|Nmt7A| zgxDgmv5WML2Nvb>qTWV(XFfnBkW=WU4ox89RhR3+5dDI26f!TMP(OFyS?oe)BM^n= zV|SK3el0`C=1u!LtpiGvc|+1V#qh276(UDd{H^O00t*wqKYL^D*kMGbmi9Q@{x$>!^sf6ae z(csFxfv{xd5PP5b>Bp(?%M=b_OG{RajR@*)6(pVRJv*)3Q~1x#B)Wo+ZETE@ox2Z= z5ZVNiT;?x zmB9)|0df$DJO6M`ROl?_g3G;%FXnzvqVEv~>k~2|vi|5EEYdp8&(JA< zSYG6#ucvhqJ-de+S|FM?xJ>|XnqK3Vd{%W|mEblwAltbsg%|H=HHk}98bhRfen85} z${`5Qy0)(=8OE2V5O(l2^>Gjx3PtDPsxBc0jH4CFm1W{WQ_=akTo;19V1MaK$4ZS^ zNl(vGo(FN7HDK8%G=4?-a8J&yYu!@WH5<(0hm2wb*v-lNqUR~ZF57#rc}9{=D#plf zvO6be*9m=V8Qpd(ZqAg4_5nW28D`bQ6)A=%kX7%=(Tuq$tMzwrR6~v7!Y@AXDu%LB3I+o9j-fc-g&$T zLU{*%kxz6aLQnO;)RRde#++wm#o9R_X<}e(fkw$G=O!-ISxp8Z5h1w}skF9G(`P!~ zteWPt81D{Q=9DHl3R>p`&}_!^#m^o|R|$+e)PADR7=@S&9jD0JXeOWKn`MAY(Xa^l z2n;t|DG#Meb%_hpxj%6^G_WhaQ6BjZOQUJ3pAuQQ;fl)STwN~Q=AJ@>g=!kn%6$5( z*HYc{xv3E%y8VVk*9wiXKsVY z5>2}q=LgdZWaO+Zto7@i5^J~*a}N3^F!%5gm(QgjrIS-lAn{K1sKjI3rmr|c$Sxs5 z-VBWXlfUN4lZ@pG#$l+KrX}RCF$Rc>s=`}leed}A zY$Z!qdknig!{)gO<$9~_wbI2 zlww_XyQjyEZ5Q^>GdyFi?JLhZaPeM}&(BP`oejy=ai_8KmX}9bde{)$Vx*?(NwvU# zy9Xtp{?u5PNV+Y9>V5Ge+8%fAd=0&8cH7x_f}ppJ887I0T#1#YU9c8#j~?|gC6^hHR|^I(q%p! zS_?DBGf{iDoigsY8NrMH`W7~~#nSlHBhEaF3xkTnd2x+FQY1z6l@=}C>V3jZ{f~oc z25$%3-Lf0=-c;MGC`6(h9o}&|F115uzX^dNU2vM~v#ZY?3CCNs#a}-cM3UXiIXgUw z0TypxEsTyD`LV?hP>F$QwH!rdMPEYC#nL!(%38jJvOM0rCcLghudlO>4OVM(F{AOO zCjYt=Rjm6&^u9+!eV*h`A-l2j&&B>c-EtQq#E;)(@o99J6W+>w?cNi~&_3&0OeDHB zs7AE**y&AiSKoN}+<8ce*B;}KYQ5>w-g)yzEhcT5BN5Tk7YZ*BtPP)CG3$`Q&Idkw zXj*IPu_4)wx_pp$If`4m0XC!k-RP6R$o^;&)Z(g z;H{O?kDl#TMI+w6evk4wpBFox%Vw+>#m;2r@CNj)7%|SE0Ea00Yz?x?K7Q5$Xg2)j zRDg2R-iFb`Z%Z-{TrnbtvYe5~;0y7uyql1mc%zo|;7;O+h?p?9_=D^I@|3#3awfka z==?A}84g5VwL&bzW(2L-&OWn$vNs;~F*w9$Y3ZV)#4a5rSQ~ZG(@d%6RIx?{c{$*_ zV)S&21+4o>=$^5%CipRD<))ZjZ{2(hqEo75Oa@@#zR4bhJJ++Q$3i*uqwl+NV&{c* zIP`h@yi?&Kh57z|NEZ3>nPK~C$JKyWJ1BP7yert`=MoXGbJx*9&@gUHuR})T%dw-> zfrnQd1smpL%NlAkhZ^j1Q+BYCBE=iX$u?WZ@>K$c&SkE<(0oK$x~Tni`^w(T+E#Yz z8(Rg}l#2xguO^3wkK5Tx=2<-XJGUjND!WWaDM%>V(t7?mR6&AR98YaFy~HH0MxQrQ z8%0s|yJF_a@alFBEh1JLk|SY|A4pNMX7Ob_l^EklTDA0*bIl2!C#4J3(^guH5~q0M=B-H49{-oH}hu^ z9zz*IItg$6?*3$l#olvr89P`W8y(+RKdY;aD&9D*>(K+ouRHT|r{IsFeWz?_x#-kh zdj6{JKeFihT>RX%$*V`6q>+zADi_c_>_^}2?Vsi;ld5iRFT3I8;V81a0t+k+ zheGu5^7HRiuTl*&=UU+nF)bnf5_Jk@pOu9{$9=#WBk72p?j`#uzsIw@6QE_1MAuK zNA)x-B!3wfZ6BmQe~Pg%34UXy#nhi=G_jcd__e7RQ?$bbD1W&;qq)9QysddBu+27h zcBU7}qXfB6ITv)pl;F#1iv5Z4$|g6*yk(2j*OIO&9UInq^sVIA+ni#_^+7@qx7370 z!3KwkXOJ|lc^hKQj6TCo1{Fi!(HUO=l>7QZ>v{|(%odidipr0Y0rf`ab12Vlv%mc5 zvWwI`;dPGpk>%DN9UMq3UAA2kq^nnT?_j}-zsN;D`|x$e3t;5&Ob1E!Yp4us?Wj~K zES#iR?bvgz;SPTre?63v6=s)~_7*4@LfA4|f94dm!kWzM z`#tPjGfX`hxph5K*g-)0EYBB^X9ym6Fu1BAf6dOv6f&#webD8EMC)3Tfa3U0t>|Gw zq(D?_6W5bB7c+t$l+kWFD$5yf2g!*AM-0txS`!XgRG;&3Z?@t+Ry93w$JZvW8z9)Z zrWC``fM>;uTw!MLS*m7^M3h8sL35?!<$MOK>f7S{-Rsu}!3qUROFs;(*w&R$UlDSi(nj+cQ~0$IOj`GxoQ0F5Fd!c9EXd~1 zJhf~y)7GAPm#~fDayomP#`69x25A0(cpo-lkDsIesQrS$2-CT=4p(e2sN4ZH08uCE+>l%MB zV&7kMH?x72l?*70r$M>rw{hK8xE_4f$LHKda$6o0VJX*|Z=Uv#QnTwytYHNt#Ur86 zC|W{g{>D*()t5y*T>H@vRVfhO=4ZuEU!_?-d~k{v8YWt>i0Pv$5tFUQn)rGO$k(`o zwVyXXlFp%j9~vJC@hYik3BBuv_h;p=P>Vl1{602H;f*mVd1wFZpgsf?(B_k!Hd=lK zLqdVf2Z3J?c(=U-HJ+O@+uA#C-Kc%}T4MdMV7r9qdwP_mxF*6t{yMvn&HH%O)B%?G zKi#P1KP^ZpO-48ze17BCYL~H)R7+zCkEEN>hkHdVT^qa4ZzTyyo%R#)XYo?q2+Mtm zFemuDamT@>SFK`8EajrXH*@lAX@C0|Z~Zdj)f{?PMlA3zXpsN6shxRhH*|KYv-`-> zpzDdBhvcQA*)E|T8sC^NpcBBkm6PRC$6|7oj62Wt_s+poqovM*MWv#Oiq_C`#=Pn| zT{mDoAJ$&guZ7-Lc8`^N3LLV;S$>WbVU0ule&jhd{r+QZ{1Y8Fw&CY z{Bh;#dVIl;N>3R_qcHsqZ$TaX^=!A5<1tUoaH}*?S$-pBf0Ee$>DYW*2m0#c5NwMC zSR7Frv#x#l(Ge0$1sKek(=8`;pB^9c{e2f8Y|OixK#pS4!GBT)!gAidLqH>^)Bl1D zb?)}{$da(-IXID98QI$F)}D>+@;r}t-)LC@x>Z|KM?W#C>`70ZQjU-df&6-WDy7QN zOsT4(y~Krs8g_l=Z0pU4eeg+XUG?zOaa=g_3q8qWQsYZAHZqC~JCFfe({4HWNw>H| zM*2FGScE$7n=(BS|50Ek(=D3=EIcccrHGfqVRa}+J~iFi+VeW|O#?tZw1Sh)f`%QQ zKwyHae)>5r757rrB_(yy*A!>UQ6fKK2J=3<%7t#$z8rNizF$VGfwhnd%c55l;d_Jn z_{6n6*IHuThN$@$xds#aG&W*~rj(;3;)7>~4HQH7{4Ui)mAygy2}O^jUkCL$RIx5? zuH|W8{1xLG9A0WFmy~eta9{G)_L>P8#@}oh0#9fcIbjz=ZIF^H_E%*oMMrnAZ=9G&u(0l zSos;fmrb10PJ#mu`?S|O*7y|F)2MYa^nr0rUfVL{q_oACCn8U!EKn@27Y3LBFq@5| zPbHi_M1UfDNGS_W*-COdqxm%#(Ow~Lli#fAOV-D?{)c=svBvG+ zI@_SvOwG({ly~(&BHeOD?Moh-(q{2L{%W_*$HD6Mu9WIjwF?*fV+H9)5nJnE+=4p; zpRdsqwZu!U?gd%&dvr<&{zEHG3AXxs$1RS zJU6Ymi$u+*@W!5d@dzdLfVVoDs)E7|uD8p~!Z|HxaPv&-ePz{SkP)|BU3J?OU=!Hj zKUWBXwcUBGWRri2Y+a8&&JEI8?+NXN!7&Ls{56H;RUT+fGl^sFUl8ehjj4-e)VDp+vX<{wkre& zLCs5xP-58QziPYo)a9Ik0~it55Sy6T0_ow@c`Q;Q*R9SvBYV%e3-C8*f)PLodaAdk zr4delucKu8(&@kEb`>a);my;_YTHX9&te8^kMB*gvfs6<>CovGBPE37(#?XJFD~X@ zT4>=5Uzf1NCcQP{@*3b(z5(*DMp}sXTl2NxQ|1ZZ=hW*@zdo}VARS!gGDgs4sYxkg z1O(Mc(?-Vfl$ASChesXnA{nh&);g|!*wGNy9J=RA$8&y`m%V7K<$CdzUZ2H)90&nbb4J(O-@n{S2hEty@$}>F%Fr zh~0G6^=9ppqBe4uHfhXu8>o7f#FS(y0MxU5(!H~(c9wl)tExo9mz=V{l-1%}@A{su z;6;7<3@dqN-yfqz_dnu!jonX@YU^t9h26;8D#v@wW*iBOii4Ch@L29OPTmk9C&K>V@u zf@!%XO=vYc96umDryMr?-MYL!38Cr}yOoa&AY6cd3j$cDWo0uaJuB-<&?r!DS$+x~|4CRL-LWdmCg2o%a zB6PToC&?>`^*|)pE`X4edV=*yD=A5VD969>jP4!H4jFSb!~(x{@^*DEzSzM+;yrq7 z{8U^A2(kQf@#*RHC{IF5G(}WtCKM(8EQBl;y^6wbkoBQ)b!OW=IvFZrrWH5@GT0Ia zlaRGQW^Gf0R72FKh8gvBLyrkL@`AHETO(QK4jXUPPJ&SQtb^OoBK0E+w>>$Y1Ht8W z41i5SvGz`=OMvjzJAPK7U1MFaHfSrwP}jhpy1`sh$7{RD0`soKGzfUnyt=V*7cRn# zB%5!HQ3M~dzPo08-AO5}ukg#Q^Z)#MY<(Epyhq1E z{7=uZH<=?^8{gvpb&a`LMW41%=|^I5PbWC$xK`}~nMZa*>!qyEwl`>-WoC`qzC^wZ zu2as$=I|alstiE4DUiqaCThvy%}tBY^d!3Xv-vdJ+35XE>Yk0vDj-jdt>`MTa~3M9 zhWC=X&AXQVeFoeWh1r8ZGN-u}>)r^!>d7Z^pViP1j2A)&ee6 z!LQz&P$!RAhIs;LcI5)M`QAK771Xv~k7=BL_Mv-y++s!f#vH-|j4G=AJ=>R0zL^;NCo^<@wvsl3roL@zJF_T zUHfCf)js#1e}A@bdvfrPo8J{@{f2VE3D5?D1FVrIPM-hJ!rwBF`$f>KS=n z7+EI1$8pmp8L3GZf|ivp&z#SVoF}d0N+@RL34(wc+TUJ(D#P5PQnPv0q2c3 zInZ!R{%PT=8x5a5qnyE!e8q^5Jn(JJoG5^uCqoLd>Ij~;N*}7P6))a7&@)a$h@hk( zb%32?4uqhvRDYoxGLzmcH~l5WIx+G;tKFYP;!N0^n$WtCXL@1WPM*%-4ErSt3Z0It zf-`x3o1I_hjl9KF$)!h}FC@lnR|OQEZF2c6g64ClqT3Htt=)x-s37QfC!0ATGvuN+ z)yk98{Chd$^UvgYIsRbvQwTWyloZWNs z#|#w-(xEQE8|6HkII@87t<|XfEYri_ZH!yW6s!eyzt#BQ=+yElWhrxv-#2M*KnlXS zD32tmA0kG&F4#8>}O^5)p2H*%UZj010na82dWRnAYXZ;8`r@XE}R?4KV#r^KF0 zf|gfTp$+N#+=KAhoEB(%Tbhh;P_dTi^$es1CF>KES4`{zYn#Ai{0_o?NHjm zBE1DRy*Invm0x|8En5^!h;HmjgW5~#>WT)6()3}hF-lp*3+yFvm(F94z4k9fJ1LuxL_Q0fo>ev!Mc2m*%8^ezYR(LEhW$@@bWMPfAm0e79AxAALt#3s^( z2Yq}ICYUKXZTc@1-#H%2ebqx9JiY-28LdD-pTcQB6MI2E0z)|QXvXaoS(yJhbCg3~+bUl`_Rt|T^QZ|I%b73Q#$|T0s(Vou7Gj=YO0#J{u$+DL z!XHbwIFD;r;O0qd%hQaZ&tg?|&uCfC@OH$3fG&kMxxF%nU>IveZZfYtJ z%IWt&YK{$P0JIRm6l)rBE4mKE&8oK6O0-rah$lK)wcbAk_mM(92@&zf6!Q5=fA2tU zLd#&==TE(S5$bmzdoc%1hlKtUQZ$b5i@=4E4XwBnP6!?mQ{F~vP5yw^_kU6K!uMwL z-Y?s9ylJ|c{+uyK2lG_=B3LicDUfiB$s;Yu+gQr&{d~PwkGFN34{Ld!i$FIF2sOZY zlquT4F5lJT9R*DsK92j)GvGrbK?R(2=S`?pPsZk+4ZeQ{Do6C0A}Pyh{{B(ob(6oP z7v@zJuZ)k|4N%I;Xs6!xjlK|d#NF5L{+7m^prc+Nt#>ql5&%n2%Xp&=REBEb+~g*}hW6(fLSgARmcxV9AkS z=v9%5Y$O4b4Y9F#1=~i3Ct%bA7O%pp)J z*c}bi(-9C$IJ(>!fz7m;p)Y7;3ZXR}3UcKzGDaC@3>DD;tVSf1LquT1F)8VGF~kGG?+rwTWX-8( zH$GjnQI_T^7dmB;mI76pBa!0#tH70W=`OpJcTuq-80|=n*-qqgnNPWdas5B8-a8QM z_5UBgr5&kADpE*_P#hylOA?Y(MlbKjlozFyb$9FOsQY4eK$!eN6-SMg!5(}Xm$n<#jk{M-HKc=ztv zG76=y%}W2oCOw1rZM(j4$)1yqix7;gOsci;lO|iYKd^0|K)q4Rfl$Qj;24R`ng_ia zGKC0eGg>%R#CRWvcAnNT|}G71bsSd^2i!*xgni8Vq1pbq(7u zemm8ua#KFl{h?#lOVQNdYI%EUbiJJHpB>)^j^cdevP$>60RJ*AY0Fp496LiASpx0| zFy8!YXgGPoS<98GqY+Zo_JUa8a;qqENM5@`fS|;lIdg5D7QEOicat=0cCQ}s`L-Mxo@tDB*YYL4B9*>}Yc4K+ABvnu!lX#kc>kq)T|dcI2{Ng;EvFl|ZdUflMSJNoi1hi7!A5tTn|>kuhZm7O zH0PTcR97V&AScI=2g{um$FKe&Zv1QbDzfr>H44G9cSn1FpT;L?i6$#cdxT831Zt5u zUMhUJBmZX38U}EzW!6Kp7s`77hZ&{}5BZLuRomm_EE??fe=-;YZdlG$y`y6LSJP^_0RsQBmpmjn%PNM$^Ynv7(Amxc^&YrHHty6zm zE5X!KQ9#>hvnAwF5&6oP--yphzVF3i1sZDu)q!n{P57a?=p&LM{_s{hm>V{=TOBkN zgwVjMp))P3_lsZgwf3<6Jk7oBlau;5FLKF)Nol#$#6PHUg@DC|J(aDmNUMDn>X8iS zRiZW*E(WHDQVTyIIY$N%V`*`DO|Uz^MdKa<4ohxXt|9T1V?2nuqwWe4t$X<~4h^7`A^RnHOkj|BZVspFy%I9oL%1M^|MNldHkdEF8=8Ls4pz;EWdk&+( z3g(;xP%1wioY5G*mGo3U7^N)f(*AJidUdUr)*6_Ypkz^NY;4SqORz_8B~|J2&6U7K z!U*@;2AfWW2Ib1kzz5IXP2tjavJ<5S?GMQ(RJ zL8hVroT12BH1T6yU$^f&e|y!6YoWV?asoQ&{H1yK(}&bRm0X)~#&C=+(fRpUQu8LV zXZvJt?Aa{EBU^aYlWJ;faE^G@e;s=zrecE$t_CkC+AFxGN;s(MEC1h&1k^V=<|uri zG%-^e)S8lVOrT{4;KY^U#F0xU@jG>n1UA2Ko!7?km+nr@Af>zs)@rl7Nx|6@M|}cv zrxxLRq|NCu{@PH_M9vjtSgc%V(%$;UWYf7HnMnDBkiJp}y-*41e!32W7vt)!A*Z0AvGtNBCvGpNKx?KDN)kqc%q*trqCYXfA9<)n!1A{&Gt!M=<2H^4Yzrs*i`VH>Lsu+ zE+1`5K`^`MU1rY1)1O_-x6PsHNb)^Qi|bDhB~(FSQ{66#=uc6zy!n*~s4foEiQ%XsXnk782?~Xeg!T z?(EM#*(IR;io@fe%@)~Fn)lYZlMqJYJB<6!Ld3q=UJ@w&u|qaJhVI*nCvAkb0{j?) zS8?f*+P=OX6I6qUxcc|+1pT@Oc$JOIZ`vaJ@sCnK&OiG`8(Y)<_Vc5&k_@-Vsi>@@U{adPn^OfASB$~_v+Bw6!F+s*0z$mRYt|k5EJ!^B z8zgI-?|zoM`kZXLmH#8zhJ8nf&JG_&tsGu(vuj9t&5^A$0n=xF2$4-m7y9y}hbyk8t48CM)SNAz-aB)LSVCz4rtwhxn0#HB_)g?iQN4I^08%)ix72~B zJaprFK$xOsU4U;92)D0Lu_s%7VEAhQUuMqne|riNK7Ox>xZ|g0(DlBP7Ftst_u{pa zAeEXR+Ub4x*aj-4k!O@xaT7w}zh`;o>{&F^6~tLy76O1l=yabEKF!I9zVPZ=7#?F95YK#;!{}XRel*tN^H_-|T z>6Tzm@o;2F@tloAJ)VU6y*(4!I{eLuivEIx%p1+T(v~aGm_-iF)taXfa;cO|17&8+ z9ziu*4S`~o-DZqoWJFvxkGSm+^>o_+CmG&2a*$7b{}&$F3;g`IEk@g(MRzM_APl!EixFeVzS2fs0tP8iB}> z;5g*wRux=p`mO9zG#b0#h}xubSsHMx=1(((UDHlk{legPaMyAS2XNd_TGcH(!IDn; z!Y@T{KD6)V5pR0Mp9=}yt0mtgt=bA|Un{FFJn;V{UG!%CP!R|*$m-;}XSWDJ%vaLZ zb{>zw$_j9bIl>eA5Tqf|5;S078vM>=44t#azOx2sRrd54D1 z1dXb*ncjZFoWC5d*rGZ6Z^Onn9NKeZ?>}69*(WQ5UcG~sw-*1JZzz0@H z8!z>)Tm8K3V}i*x4_iKgVA)*kUjCHr!0Kfq>nO@^Xb%qLf5HXR`K}A66h>W`-)C!V zFa1G#m=oVj@J1qP)V`9VJ5^}$tfKB&IfqZnF~|e79bP2VSX;P6u)b{n$4trG*<%~( zRDbPhYT880x4Zltp(BqEO0RklKdlvBthD4}Ui!pg*vM#k52Y4F$&3g>euf3-ttK5D z;e*bq$$AzoxLR7_(9nLPgcPG&w*fh39)hNG-}#O+DmoFBi)q2}Q{&V65pd*b?f_G0 z2jd(jB99T7j4ddt#***hQc^zTlmbHbIfL$F#GWW-qUBVwyq5eMgu0Qh5IrO~$vqT1 zLv5Ulzm;}qcl5XS?cS=}jRc3^wY-dk-r?x*aG^T^g_1t!@A1-oPssGGh+)VxyS?lM zQ|iJ9F62#ZC*;llm7FwY<0+*Z0fPiDhPHIT(z?4NzOkA6l>+ zU{ibS6~i6f>a6cZt`df1%}@o&%tXt2Gk$D*ykkk@_&Iz}AS?Q%lby>Zg1O1=&poE- zsVk+!TReCO7i0J6)a}Fd2V=|qi%?QxSUF?vKFuW&JntpKH+g=5ONl11F1EZiur18a zZDxU`r>8nVDZ&)2TG%oEb2t8f4nTQ=+3C43sFR7(m3Hte{?qL9s7eTI5;1PP;QhxR z^^L!Cnodx`%~Ts=vzix*swPCNzYyWXal`-V)+Fw6JRg|Y4qA%kFfGBS&PKVDN!Ko^ zGeRdG|C}>&hv3KEIa&kR+s{t*REQ#zA20|n5I6`l55ta&%db@nj9R7 zAER0s+{CXg@ieAxQVN~g%Ho<1wl)Wc?A_=yt~oNubP>1!w`%@EkE(2T!gWC(J=qEC zXjykwjjwV6RsCf`ISfqdgrxzrvnu(#o@354nA2Z4p#mC#s6My~e|6%q$%V5o4gaYK+CH3v zn(uN+nK=Y>=l}}TTFbObPW`2G=RP7KhiKfwZmMQSMrLG5l)mY9vyHtl0~%4+wOl}- z_m~bx66uZXegN`E&RPmlGXK!iw6^2FrT5S*|dxX@eC z8#&VqY984r3Fl;^JR@j%L>V*!ZdwnrN{~s3rk5i-0{A2Fx>!6HqUk6|z)8O=@jL*k zHEG+_3`&W;E;c~axp+fJ$o;(q#i=IB9kS*>;5yw0Vrw!ZVqt9tAKb7jN{(*^@2>(4kc9D67?Zz1&P4KM61(jHS)6BW74x_HUl^1u z-Ffq^$(QSd9aNC9W9tTDZC7G>rAgY9fSdj@;L_4NR$deH7 zct>z(hP>-S9_@vult-a|)sm?)e9Weo@Gt4+E)q+go|OGs`fl_JHvQ;l0(=b4dJpI) zBOxcL?EgkYjW_R^LQtcm(Kx3l+sY7gF7*wyHAmX8Q$a zjAFnoeIvU$Q>o&6+`_(9CYM@KQ0`fx?lNHV`6uZU4u%@3n<)C#WqqZP>EN2qQ_~j( zZi=K=Rs%~~AQzzy1nnCQDPs&Dr-U>#9 zEGeftME21QfvIQPgNKTzEjX{23u8ZudlX1+W@aUd+PpEwEQY;^hBh zU@`t*^AvHbl?V-7Z^iZo$`KaR80JlJ( z#Sfw8)eh4i3odqvg&=l$cCFN$IX;C{sB9Qpwe63V1wzrH&YkmO-AAwx^u|JO7GN9n z`PjmZ2hXW??LKE=kh_d<%QZPPOTTGL7eA}9OH0QWXl)@eyGXgS$1;(-$L=#nuC>>b z^+B(>54j(6>;Pip#o$4n9_mGxylC&%cwjvg%VWkJXlDEN^x5Cu<+RKF+^gixL5io4l`| zDs3+~oV~HoDZ1`A;hibkE^U5mrR6U#4+Jlz*f8Adyy;t(sLTBanEv&CShQc2f~*LPSC^G>+R1Ih z`DJO#Xj8_h68#&QmEQ{-w9c)jG(KFHIHyHbKVDUxWML)R!1zV4^EBgnDky?ACrsx9 zJ6kV}?{Y+Sw{;sSJINEoUpD`Iv|NM{_p_RwtzI;Heb#MY4WKRGfhR_q8rui@#b-#7J1V;pfhc??M?Mw~|K!`3Z_+22 zL=IVH9_93qA)YgHmRH8*BIYFIya}8${<-R6RB3c3r&;k2h9#SlF{`%MndiZCrBz{4 z83QO))C3yt7hVyjPrW<2>p|Bnb8k9nh7=&D@a|b8`mDz4?ePUFvI{}n5Q3^;?-rP? z20qOgc^DB3?`l$dkZphdO)1}_P}`W6P*g5Z=c|wFn2MRpm%Jwqu0MJqN^2u))iW_= z?p!@q?4*lat+%?538!BN+rCKoNti@-0WGe$Z{QOfDFU*Q=Pw@4ngazP@n=QNd^{aTp$Xe8Qe0BgFE+F++CQ14~tVP8$L!;{otZ`UC4&Xg_d`n9J%v<6nTD39-a6 z3Ohp83daZzGN@W-Ps!;=a?7)<4MO*Yi%*9*2p~X8xXW2;e&dNb92$MoawxZQ3$Y%p z9J>!U7u`4cH_g@fbGwWM7R|^YJ)M^Kjsv`(e<7jpO6nXO9V+kSZzA^D#YBmzaH$F9 zA=zmc!q(Rj9*;0bW5J}a%Sud##EmE;>*_oWjGKW`xThsIgvgRdI@H&*pTbCKyorQR ztVCc)OUqsBGB~6V%o#4IA?9xv`a%3k`87?l7A18(;tiN<%Z7zWU-ikzTlD)9Y)lx+$Bn3Wk> z37V4CO89y^mRAMfO#cHAyJ`4Fj8{|>4!y2H?9#D=5S7^460#J%4M-L=m^(q-I{!}q ziN;5^kf@p1LQ}1qP=jIFG~S9{p%kSUob3+R7fmLkIi$qdLe(vc76*|4AGd9LA-hz6 zVWrd^@Y*YBDzEQS+kzHriV#<26XFyFNYhqU`KEdNRIRlIDMLN8xE zhxvzOJv@VAOQD5=L`9-O1+}}!I<~5$A|5)Bj%deZLBaQ@sKn;A%)VFx}?Yyrha@;L>@q=P2 z?dN6PvYW+;-S_e9q&2fzhP|}|#5^|{m@b_ebkdIoyjCpm*kk#O`2^-y_2QPI4%n^e zqEjaZX|n!SI%#p7hDlO#c$t9HQ3x*y#|lN;`s=eVHSzPS6;Yr!D4-9w^K^2%YHiZi z&V>z?zFdFKGULy|`Vk@_HejslrgX1oDa`rCp@Uv!vtr(~t6>=-?P$S|o=OM4UUtZ4 zg_d5Q3+Y8i78BVDz{p!m)ulC$yV!2%lOZ}Gn6)4)lnB?;VbEmzE_r#=3rM2hEAV|A zc~=H)0bxwd>|;KhEHPuYKoFnj)Mq1Qz&r z2g&K^c-QF;x5L@4JNzh4h_qz=<7VH`AF*I6fs$I8!<=b=Mkn!hvL?J+Y>$}frP@c@$bb}V9 zgfnKW$9qJ*Sd=(5rRF5};+Kj)*9Be@S9~&KiocL^(~-`B#2sd@HfG4vI9W#pd7xC{ zmFKeMn@>S|dVCi?6#E8(>lE2%%8x7sJ${b>@3-y=OXt`b4?4Okt)ajtTF-d>+tka%ww!0;nQdX%_VrHVFk6M~CD`sW zc0(!q(bwcXjVs&SfIs3az25r^S$>QpY>|qb7tP)>gj<9?#+_t%c!uVWf4_DyF5VGs zo%XlkT&>84hR)>VhRp`sxlPkZKZ5){?e=#h&urDI-uA+LVwzY{KFh$kEu!#M(@^Ay z4>@cN5t5W2n@a@q4Aq9wx{ zW=skG@6_x(xm}BxW=|&8l@pmGi*)0cDk}F|j2veTc=T7_l#=m9VG*`@vh(HVk1raS za+#V7&C5II7#KHTUNZ!F6uw#*wiJobd){=&mzh9!0F7E`&NOOrn_cEM|CkwbTLTTaQ zbcQWAD*x;k!{xj)A9fQ>yy?z1>r`S0&^@zc<+v41-rLYHG~B^4!9 z|5%e3$L60S%dznniLg$M`hYiE;)yixqgq2>{e0OapMRy8k2{j9dZR{oXvd-}UF8)N zjTEL6{r2U%D>iNC+yf4N^urIjb9WVbRH9)yJ(NpzPO!>6DHKM~G8)N{xStn?=P!E+ z(L!A2rn`H?l8fN_7+0lA+uyb;UPm_$JoZq_tAvy-3ci(RG@7G}7LWk7G6HVDYVO%; z9i$tWEqfbbHo-RWqeAJDi{#GH^1i?V^A6Akkvf4OgOlfT4$h-Z z?foN4qFjCPl&(QG;HHJxf9$a8{3gG2H^_+3zt+W#+_=#r1;RgR??pZDb;V*1^>Wif?^zjO?hC9I&x5P?>FFhf!I4#r%9I+@Z?Ff70PPJIo22Sff^I<3LT&@6TTB9?|=!?-wi z{zatvdWp#~l3g^En{x?@E)uDSE?t0v39w4G_s z@=k?cDtC&2uup30mQ@bok-B-gY`lJ*hg??vnL$L%5|yM{xmKrV;{u!>T1>H1Ep~|7JpXhy9JeU{X6Z)?iL3Hjy5w`!gF*{tc`96-q#$t8j6?u*zOq z7OAvqU$OrwtfuAmqav#b!*Fqs>9bppGjEA6tGf(rviy!9^CT;D24iI5u*W$OPG7oOygO1hW#>jMy2I2FxoRzV0u|`N+0{EcVkSuITFQ<* z!~R{k9xz~Oi2*QV+<;?5vuY1C;klkxHHG*OqostFg%Uq_l2A`~D<+S%3P|mTw^CE^ zIwAq<+#gu2!1cVsg2d@N9AHFOZw=eX2-^sB0KUa+CiFVlb=k=eIZ!di?H`EfV4ohX z)>;$2tRfG?S8bh5caQYD zVm%^rGzaPYS8Bg6QILT$blEU_8e*-nD9^gSQCsq%}4vqth?gL8uoB&h48A}JBxlf#vjgTWGH zctB<<(MoqbZoVb2Lt2!VnWCv%+#e-dp$13J#qr`kX3{>;3Wn0uzsnQcS54riAm#@@ zK2P*z9*5Bm$;R1`x*+Pqb`_GaWCtHTT`xl9M8qU_Q*OrBfHuF&wMHh(p*yfx^RM?G zEx_G6p$ctI*}jEu`*k;EjKexEouHD%K2xOJA%%vy2vS*0Y>}LD?|%W+&cS#_3Svnq zn=a<(=kF*jc}{ZK)8+{W=jsoi_G>*VI&P-?K(x|DdDB>V{^}5eR=B)VhEmM6AA9{w z58)5sq^TRJ*v}L7I=|umDto+^q0_G>JWW-1ZRy`^dQdz0)qC)Z|CHVCS2*c)-VmZr z**M$6k+m!6e##Il6`xnhs$N1)8*uK2#oxS%WpNhbf_vBR?>l`a&!RA^Ykjg704(XA zqTPW$NtnhC>Kwfuy8s-7{E8Cfee4nt`6d$Y86j{vF6Z(gO`OfBT(hd2#S?OWSdHI% zhxYgo$1zR&85x9<8jni@$LK1e5@&8KTs&`A#4d+;X|ftx%zEOL8%m?CD}LX;{b-AK8z9S>+$@BeMOq?UzZ3=+M zn~cP%W{#b74(RH5_pI1&8AJ8umal0N^NTm9k%UXjJ8rh}>(twmQ;WK_s)Hz3Pg4IU zR^2fZ&3A&bg;gIrXI}5;lt-6>50_;F1G-x!bn!1I<3KUm#!B7m&hB1Bcx;%nW@W^X zLJ}?fchfG&aFzRuOi;z7V)zWd`QTl(eFl%%tKL)W*&0#V zm>g`reBs80^Jo5)@-e)L?1d0YkuM};T;3c1i4WpUZbXu*)>)!hhO9cwlFIT@rAvbU zn(-o@Y8$(%^(@STxNFiFchUbrBF1_8tP(*-S`M>^#^jVZ9fgLEcZr`T1ovTrE7Ed6 zcDzXchl4_#RzZu-MIhjugcIy)%wd)yMl zZYaJND*p2By?QU!9C@^yJvk_z#hrwBiB z9ubX%INV+m0p`QzR$c3w^Q*`0rE<5+(gv7EgQlGi2)Nf+0 zEp)O>pZJILOie7Lnu}*S!apgdN7u3a@x(3^iCoy{d*#tZrNA7oM0uf?O9_E9!rjdC zZg3}#B;~Pld^y(+`(1S!0Q!u;XX*-M@h8SP8@_XX>E~b4e53O6u$sTqhD^iY;jjRTn{&HdZ++@uqnMie|_?k2}@9^AMG^ zo;xzw>am)C>M4Mqqo1n-`%jW}7k&TI=piCKGj_UF_n}A%90`Y-IYhjVP9ioebAYFD}=y@2%X=ADU?H zf{fKOt+2dP&e{iGI+rcJ`LKFnn4C@c|0aMiKCutXqC$lygVX?q#1W1#cS1`IjvCF*@i^cGYC~ef!56H|zWEb7_v!)GQfNC193JYF*&MLrxf+q;?@*vw675 z)~{b7^C~%gmJ+6^g`%o?<4+ADIxdoGxGThk-Iw zL;QQYCy#M;0~jw3b(G{<8;5WMHBN>- zdvFYKEc;x|ECJ2q$(`)ha9aNZ@v(?!g|Y|}{-v8@yHI(9A(T!+Z3Yk>r|ihxg02_y z$ZhwyAfM_f(Df=|#K#z6rTMEn&*P$=r6b+FX=}NbZ=dz#+PEUaqc^0; ze99AfCTczIEY@)lQAT{-2S*kg&2q7|v}f0HPwhx1uEVrAMo7PV$6?Z!P{_pC^4ZxM zlr1Qm7jSIte1Z&&hd1Rei`CMQ%_4%hDwBKE004j%ywut?H)BjpNc{et)WvxQG1)sW zK5tp&9zhRB;vGviN7%}Ylu_A;EVKcLlqE2OoYvBkS7*mFNL4TRU1-%_8`c?h1bF#b zGnT%M3c9<}F6<}D;Yq&FgO=&AvY3lB<>%?}ALa;8bFW{b4$aD~t!i6K%75L$`CCec z%$#3l4&;rD}I5p;*yD&gkoU|5Y9Z)v_Gxs z9?P~E2IVk-1P8T(N=@pojW!BuCkn$|3?7vfwu-N#pB;bKcvQvjfc zzrqks+puC8Uqj=3{=%V)n0ZR0Rr9Os1eeO9q}&(4>$J&bPn2Krmy$L=W4DGAJ>qlv zWH6m*yUN?$kDl&$P4LFPl@x|zTg2-Gfv71NN$3_1&^T+DqmMfE-sCV6KQ;K#+{RlR2|`)CJV_jRZzNE7V@|DGVbo)qfB0yW;e zqCP9dWIRRee%^b&x!DK|RdTO(q~;9QSm@Qo8I0q752dhY9SQ|G7x|uRE-WY_UdPCE z!XR{p5F11NJ9UW+qZtY{$H~;(JiUV{PWE@-**}WDx`#{Ptwq&o2}_$qzeYBiT%cCa zv&i(w&Dy&eU1JXku1Ik8Fi$7D#F3-B#r#*a9udAXJKJ3CzHkS7v>X)L5p1w2&`X1j zfWl-e=8q>!E4z~<_1McIdHsu;hwB$TZ5x3NK(0F&7k2`QV zS`3g-&8SQYIWOIgXnu3)Y6#rwhZy~bGJG?Hq9f8KlZZWh(ICd zm#-ZEh@l3EJ$dE3RD>_x-v@&)Z?u1ALTm|6q8|k;Izt<4)nq^r?`y zq@J~%{}TeO29iezd~YG2GR*9^wESnAH0om9R97B*g`@i{qxr_oNMp5hmkSQ*(1keol^`JZ;k2>5$+$o>X!}Tf#w7x{nwB6V~qJsK_hloFNGJ%(% zBu;xzre0YmKAq3-b!QI{rn&zI8I(y(D{z3rPl*TSw=6~z2&)gg5U4YeWEIjIISc`@ z-V_+`1X6s1N0=W!BDsOdOS}pMcv`P}U5y-@k1M$i8fr;r0OpkCgAS{u98*pe($8Jn z!@1aOKH2&{NxhGJ0f#?n4v65qZ(Cfw3}cW=0xs{?Gf()gNglv@txehU;?~&BAV=OO zo)Yf7dlD$O?fpzyHQ=p2kRXtsNpNA3950Qj1h2dp4jkS9lOM4Aa5@3^vfpB8&|tb~ z{(&6?*RC7y{MJ1cEtDT(<+1})+^}$kNoh4w9aqM1*a9cdvN2?} z*WcxPFf{Lna~Z8H0?a^g#6>nP0QDuQGP6RWbKGxGBVU+3+`eVA(}$MdYr z+?!obG;lCBo;?~;c}ySM{-JKl%6UQIHz(cW=Z&6o=#<_+Ox1EQ2*?LfkT=cu0GcRK zG*QR2BbQStiVupc{Guv(g}R7;ZC*Brncy}tLl6IbXMq3)KcGDl5lLMU!N6~&H$y*? zBt?dM5>?WW`0^PZ_lOs9#(n)RNd)a#`M3R!8s9}(0}`*U-iG2B5H{N_`-l>)e>GoP z6z4xbU(I0$R^HDY5nb+>Mb_Td3jfxvcl~=SDz77)#3%(y##c~9jccA(-g8i!9DVeAMcR%&w@xDQmhHlWn931b|vT z;RjZNKUOA~jJaJ{cjNuUD>k&r>#ti3p#C61T|LOot_Qe;wsJ3~W5iHJB{Rsdsgr*x zEjgANKt*cktbDiA5BxC$jq08B3=YK>cYaE9yLty5aCaIGy!K%@GT<`mAqRnmLapwq5@B3qY7! z6&)J$+5hZ)wx`3%{g5@b*#Ze4VxE=jab@~RfCj-v7>QiJWDg1|`f|!Y%+_)5i_O8< za)#g;XkW*&R$?PC=EkUj4a!EAmj@6aDStG=VoD#x+LGnt;%D*6EF&*9Uz$#6v+t`* zQ(7fSWKh+7f|jKWJBa*Ua^kH%6|>#rhRUxlTYB;dLu&ao6A*yH{;Qt`{HV8m>&v}@ z4yo^|N07V;UeYneq8W)-*TvK|P8!A5sbPkG%lafR?Lk3I=FBhutS`T{^vUON>Z+Apvk_#HI zN?lz9UhSZo@uriW$h8Z3-H3(Cyro>Ww2CoW_DHQ`}of&fn`_gXdo0S z_(4;cdkkR$t0tID_}xBXA~>bSQ*xr93o!j7v}$Wo-KqD?De*Fq znSGyHKkTj0)y3l>h{%>>1?R92ER$1ybKXCuSfjo zgbZirZi7&00iW3H{xD~LFMb5Q8JdfvG83m~m(A0*b1*F6)b)YYykIxniC6O1%<4Ny z>RC2f8D7o<`4h}!48bibJz6(w8&3bUywLM?`%+Sa+9ob8C4~UOqc280!)CYSWo6}r78cII0rnnwvHF<4KH1gNJb79+ zeQPb#bJh{c7tl7K1|L=y*)1WVr=3Hc`yyBQLZoY#J#o`q(3r@U*nd3u1-acqA!b28sDqw)XnBD)oEdw1zpQoH@`3N$i46` zB~}|H9vVMLW?0loes?j}ee(h!2K^=zk?{4b_@Tqpcums+h?YtzD+tkiWZ~ig#U>6H zwXFz{SFx|ID8z$xxZ^8u8uo3+xXu4RjHHdf$;}9Y3f^z4CheV<)9C4KuX3Rl>e=0P zuFntm1Z8f4velSP>&O$gnG!EwWpAD<(w{wg%%r%7M>apsVa9@UuQH@(rIKAu42cfA z2LY}Ej|4~dwbw0AFmQsfhz;Bsuzqi1c=`_#1@0@c$Dj z9ePd{9_SbY(XhgPw(9Q&i#Fv4HrDRCGtQU0{MR1QmoK`=4ac4ly^h_3nouu7=(Qqu z54si8k~rx^J}0KmMoDr4N(Mi+^X&iZS~rt4tl2w5xxpD52afry-mwVO#e?n)cQH>u zYftT5ybeElO61I;wnIY96)e`e*tKCg8T87deYj{Hsx{n^b|s>m6!eb*llGFu~NmS4HZ zOqy>2AO@~uCWu}`{}r%d;2m>BBO0#Mdo>H_&uuAR>m+5pZYX?)P~oi#Chi!0JtoSa zF&gVMFfhIinyh|P3<$m3#qN2@2P1qdXgcVLI;yLnriWsPt>&g#1vY)j0)IUn>r!zY zMTROiws}a9foTlk!MndJ=7kC9Z|}uv-2>G0;7CyM=#|07CRnw6fLBJa32bM2L2t8iasVl*to- zaiesd{p})TT>XuGS85Nq)h0>%fOlg%s(@cJfaKUHkcN8PTtXTKdxK_3*35wE2 zbcfv)2imCN>X13a#gSon+PL`}EzKO?u=d*mFC!&v1)sWf4n_PzieZTw_H`3xyOJRe zPrLKqJUVOODcr2uX2l@*4o2fbvbz+h3mK}!e4%*PN7e(%AxP0^R!0CEwmvbuc~zS* zOF%35)Los7$qZqlfRZhe1VcgT)fr5!w{q;L}CgUe2rICqQn>ey&wPCf4 zpGr&A`J0CUEBd+39AD!!emsdONy6W-;>^g|rluEbn`Y``n3@wQbI13i^rI!#*zFgZ zBP*1Dds*hIl=RnPf67#CW#w&~l^LhZT^iaiO3;!M-A|hi96xKFE=rA^Dih%H32&?y zK<{tgU>D-GF?Q-2Kpz&y&d)a8ADir$l)*x$O{E-~>2`rn@0_}8T5!0jsq6UPTZOYU zT0Mt)t-7U^-zM^@i`%SVBgT-)qYh!(aL9r?Rd_Y8?3ToFUUqSaVS$vgp=@|p@TKdt zm>&p%23Djk_9|?Tk=U*k*#!)dh)Z!aU5V*L_L7OoY-d++oKc$z$B~K(5L#w;ivekO zbR-EZ=XeL@+|1mNt}fKu^!38q{^QiMZ@;hCMis^!1o;N|ii%bpr#-MpIJ2GNRn*6$%&p7XwVzUL*1z##MP85M6lQSuVfJ zlc~~3N`cb~+z_dis+m)yCHrQhd$X3=M5ApbTG-U|p0n9YuXYJx9et7{q@nfNkZd@1 zc}g1oLl-Zjd&ZxaHm57g|JX?GB3)_K3f#rZtV_7cFCkT|-x?y{DNj)1cjY<-mR`$?l*PPVpnag{n?IAk7F-n&Z{^;qNK=Z^~ zl_x8CCo!T4U#^#4j6oi&S(%Ob%!8a^a&Aw|l&0z@iR8KEZ~<>(&(dEgT+K#&*2Qo< zB|}eE8Q9Nn^!3&)|yQPCHJxRR$?S$Q|S$YhA<_pRyRSrWO{=@SNf=%q{N8hGv=Ms(Rumd zZdd1pkO9UPt!mNF%J(=_E_gePt$U7R6LM{j%yAdqBX8N@&r&E2)mubF%xc48-yEP- z_XE_K)`G|{W6v9=K%J5|CTj-w$BORg%ayqZr$mwzx1+{Xfj18ce$#{!K||x>5OX+p*fB4)^ zN>S{#`%|cv2>?M#zYVws{TEddwq5t~^vEEp8PZJ-QTTK3hi3FUhW9Y3eT;i5Yhy$? z9lJ8nXXCjUrfy1swn^I(r6}zP9s?thkfn8YC)&N66O?>5 zDL=T`af{&P{-jR)_sUg8zkcEn0e~X!)$-Ri(-g&j1Q~V$xm=WHf_fFj{#eS!36{j> zxFh3BL1&u$3I)6usVuGcVR_G2bdtg4r|F?z2<3^R!0z}RYzjv-PX4-RXJ?1-MqX7> z1o-}Q%Q^VB>Hfzyc!LEAnS|CO?{Gln+xf2lefwMa=Igcec`d>!-_W_&OZH(jf9RR> z=glF%!$>%vX;-tYBN>UWEWaX`jC;bcq~z$JW#-R(={v_;_+ip?Jc`dMdWq ziUAk*a&CK&>nR}Dp>LMKb0xzx0(-pIafba9SiF%TB7%Y?B-)LD$EIlp##Lsn!QEa~ z?m;@cpo(t}QhUuTpDQ~DJr|jb7Y0IpQ6x2)G;ygqkX|tR99b7;(yX*XEuBxksQp0r z!#tAtGIL+uxUWWVANRzsCURvqIR3Hvf~2%eSZ66SEc zfJ|bFyGaMI*d3sztq>|D1RQ51E4E6L=_^Qg_?GM-bOMa~#2`d;%Vk$e1LQoH*Ltmz z_MM!rYl(grd=CLcnnp`fj({eubV)X9j#H?o8A?~!Ik--M1E6NC9>N=?x_d}l2|3$C zVnD{Me{&a&73DD~gV_m1dG--&})a0BF0#$Vx)t7oRNsZAvWPSsK}NiM1k~#2m0HpI=lJZ&?XN+cL)C= z$U;nD-w>-9o|OBNjMEZ)^(rM(XaaQ=681{By$h!`Im@*ZW8~U<#Sw{VMY8C`kqe6DeEC-yY41s|gNE<>j7x7qO(^z@;TwjHaeQLy@s@)q{q7|d?EFVV}? znG}k;=jZ{VG{@2bx1R(&ygs(NB^4h=PKCPK!qRn@N%a?E1nJvuADqryjr} zxtjFbl<1RI_L9u&GrWT?L2eg0E#VM5L89m&KJDnAoI}x7Mkeb;;4GefZqf!Z=3odl z6G`|~VB0hqIxF^e?X)$BR`v`NghFON(duh$CtP}J!^CUMfgtuF%~ zr}=;lpys+?`AD)dt+V#Th{&>K{1G!a*;uAFk?-9U!yXwm*WTO{JiLbHnCSkKFb=Cj z%HxHuoaDMV%fxnM^9^XCa4o66Ke?%|*-rY8baA@OGTm=I6(MlcVSU$=LI5`D&uA~+ zeb;}1_uZ6s-($nF?FfmHIct6q)^i|N%@)J^+{4JZ#`tV_nHeMJLEoG1Xeujb{ zsmb$##mHOn=4YLMAf8~0_czguptB5~GYR!=)d`B5Lb*r^C~7)*9hnYJSLQ1eRaR3Y z7R(=Kz;uy$V}ArV)T{N>@O!V%z zp^#5DYM*E7)9xv~ZXy9!0r2i8GTwn2_BJ{?PT*t01E!2ao{LuE%<<%T-GjIPVONk8 z6tFdIq`YmP?VgpBd2w+KcC!VqwPP{_sak%#N@_^+oP>TIgF207(-_iOMz7~<9*p=E zjMXwyGSJ2xAg!T6eb4Q1jXw};!9dBeC~*7d`o(3vcsHI~Jzbd3j|wV(R)aasg0llMJl9gE9Q zLo3i|mL1K{`;l4I+YLqHUW~l;KWDZ5fqzd^8cYS& z_XV^3_9ks|5|o$KKyy*olP8rp{?`Trx*9wX|paPTrII)AMC`_wbLFv1AQBWxGt|M`i@fk}I!*4zF-Hm1oHoIhaa zGgxMrKQ-iLwDWv9{kj_Jsop&#{``l_hTb2gbth*njSEq-Vq>t9)GXm2ZPc~1YWt>o zrEN{AWEVmIgsoi9%$Oz^lFy!6s;=TvFr zA9b-h7|L|xekFm4v(4M$O@|`ylqnx@4za*48=VEtv!$^!6ao6h))+k;>h!adNyHiqwf$pXBDzpfWX`ur&UKVu zaY6%+mu7WWG}Z7R!~}?U0;;R-FMz}1^EUq@CZj9H=X3aKuh)D-)!e2g|5YCvaK&@1 zp^wT^-8!)bli{cVF*tqI)XN~}CF7MyRd$%GgSh-F>k?7C?X`!$A?mfeSf63kmw=-y z#yhEucRJ6LUu|RYfOSAQ{TZgF6OJ2S^P5*n{(1+eG#7_7p5#0Sag{@=?!|g zpUJ=*_|fDV-Ian>RT78CHD>h6yl(J0M zc}L_m)5T-0rNCSjui>F}-fDW7M{E?eS=J#~Ids&dNDDx3rt>d?ym#l+3WzC^T9I_n!9aLWR=CbG_BtZ^At z^w)j6f{wBG#l^T9tudZW6#Zl2W{RAujXV!1m8(o ztXfI_UE(5EAU3+9?i8y_<+(v8yb(<+tEqy0lW~-4BHG5ngKSTFd^S3d-?rs7JZ+U=3af0Z8F|+$=H=+Yos?Zoy*J~~a zJJ}`gC2e|GjKs;X>hiqLfbkI1Z?qYj@h!?;YrP=IxY`DQv;q0Pn?uT-G`|MZw3}EqYYM0mud4t_AIC& zc*r+QAAeNzeJrSCravn zpU(A+Q{dzW=qDP^;rG1$;40ZZ{fhm%7D_3einJE*%a2|aKfI+sM~1@iEK&_Nm;PP6 z*{gJEe9>T8_rSggot{_S-u;|%W#7ZkklCvepRoHhpLLph#G6OGF)AoI9q-p1d$00a znsoI~uXZkb5Uv#1(b`QU1L&nI93ZYh^K{lT2&FzY*fWwW^eM4Sn6VcI;1uPK~jRD#xq0w zYF>2rMC(Q5G@7LSxIc#@>T@{HtGDI9ST8ap{SSpmZ76-yK6I>baq_ZB8uQY$Me1tF z2_KH)VvoPuYggmfIEk$Nt1G#pn-@M`wA& zW5jp!pDK+BC>kvYfzh}ff+5S@LQUiYNj)s4a~#hh-qB7os^3~c3pE<3H=$uv^3UrV znL$sj5;Ist$&-+Xl*5RvISHM`+TsKIKC#v7eCj$*T)h(kZHrlBj#7cg$W_NgLTe9x zG*8)n(A;hEFq6bQ-j?76x^HV%n z9fhslCXES{U9ba#?t)B&@(BJv{;@I%s7J?0*LrQ`2rq;81Snle zK|}+nX-u_?`!p*wy66wR&sJBY&pPrLub;^L*AlUAyA-IebFZLjSMf90iH+t7iH6%# z_4Eo|T~KN~Saw(prsW3$PZeLHu8qBBL;1CK^BdVOORQpfD=L3+w@zPcCP0DJ5GHFG z@F7GrFm1F1>LjJ+q^NG4oK`E;pzQOFa*PCjl$3N5m3^VVBhza+ZG2tq|HsvP$JPA5|Klf7M#^3( zq=hI-Lm^U>ie7{i4NWbHhBVA5MMZmZKhT!h?A-cdj`+&= z^J9h5mh{}SB3Wv!HmD$@s{=vx9zwcPf|OK{bzMoDj2FMas-Tm(q`L zmQv;f$)M>T(?z5|@^7l&HY`I(>737kbwISfPC2OlUkKDmZ>jkmU>Qe|$>185DN)d*}r*)Cq<^R$%Gg50%#H!wbzyy&1 z(F}A0eV|QHuPk$*D2?`W2l?m9GxeXAo0qB`V-ym)^FO-HR5ZQJ&PfyHil9%dY#R^C z1O`Q!jUf{l5-O*UBBxkK#v2@*CH+bMH5-1Z_|uKMmd?^ zV0PA+X1}(w*?&=14XF?yJ+^pDyL#rwQwW0;)k+w_q@^NU`avIsxsZ$L+KC%KRVGX* zGKnNeYARKPqK$vP;faAAP7|viF83;F6>+1F*dZINxGeiK`m{-Q4@@~A2}0ylUdKY* zGn*?wOrK^h@lrtPIIrVR7~BkV^Unkm6Ea2f(0x_(Y8Umh$ZOnkb_9(%jqzSc$#qM6 zQgF#1p4Zj}cpTLVXgUp!D(vz)uqAs@yh71`!ai$i=5IoCT>ag4My%v=&fH9-IL7WZ zE(1`swjd<)N9o|-j5FU%Fn(oxJ5uaI@fU1Ntqn=@Afbcq_qAmZKSl1*59E!gKc;ea zeWjjZzj~~7_5%J*(f&!|2akX*taI(z7V>dbdP_xtF4xzgxQ#ZJB&vf%VAKAq+C}9P zDe98BkZ4s+FP0|7eg{8IXuv|>sw1_2*;lh2qs}>w$kn5bgQT(9_PkZ1_BzZbR3v#+ zYAOHZ)AS45bY|xqH^l8_kMlmZpdsUo#;0#xmS4in73%zUFnP8-X3QwLWc@-f^3Eq%q?2J@YB8MIzL6kvC?d|@SLs=eXlhU%#Y zM9icTkU2>+8tmH^obEG9xwhqAMv=^&UAs8sS8*CLj=gC2>!DRiYOP#&C-SCff-t4< zrHE3img8~BH=-p&dg;bP4Qwyh4>$(r#-1mJngP zDf5W^d|b7cCw_`kSZdFxsv>eVn@gDPC(E``P*nvI6u{qZ%b7H{z}HC4-(PA?2Xh9P z&1B0q_w*|GE5{38RiEyczbqhtzxf`SN=1Lx_4OI*&nwNTR}CooZ#%!W+;Kd-SkE+l zC}}R}UF%veX9jZ#mc_r<$;L!RTEz>8me$OgT^Hh~{MH*;xi^DDL2YR@`4D z>v;H6%;UfaZY4F^oHaTEsaB;5pn2sI8M`^oi&+d>4Z*Na>q5qktEk@&`RhUYDdvJ| ztg$&MXUNx=Nh^_~r`K0%I(B@(OF$s)cQK{#efU3QBi;7DJ(s%qZLq^O|1 zFZyz~+&;hP>Yti!bkZ4WY&NhRXewcTbxcJd!Z;{w`K_%pQRbVO7GCYTk$GappPGQ{ zx2}UVeHbU#kjI^uc40c)JM@ah$I@cF17%ZhUz4=mvRQ$E6RI)PIkEP@s%pk*s_&+~MDM;F0QV<0KBes`SH(0%zrL<s!~kD=W`eZ*Wa+Vl{;$g#QI1#-O1TV+*Fq9jR@VHbpE+S@Bn_dUnnwPy2F;}X>5Qu4Zc~eOC;)&@|G+uKJb(+K4!wm_`oSY3t+MBv=oqx@bohlSRc*rv#z!=x- za>lLg=JmU02j>DDW45|(>9J=cji~!~NT0DDa`dYWh)t^TDs1TOru3i683+XYYjD9f zSV47dHG#9G-|)z*-#+}a`2FsZGdl`2BxNqCzJOQ!XDO~d25gW@~! z?#u4}?1(>v?=={;PWp`}&hg9V|neQjHK*%#o+DG_& zxR`JrNV?CMl~sSD%p*@-?=`>o)<@7pfCO?=)rTN;2{{&n1yMUG{eiU{4lzkbENyRI zTE)6(!I(F6U@t4VkBpiXlI%E1{nNn)u}N2G?XOXoUNHC8Bl_2^Gc8DRxWz2lDg zOx==asX>$E+vj&7J?;8ssZ*&sqZX76>8)zqW5z zbT>H}6nDMK8gmV4X)Pf4ePgjIj`U}-uY&bZgw+D4jV&5HGgNP@+_TVskJ<-jmnKKg z)ZGE|S7teSdc1jRsXSRDS{djRTKur6zW2EE)V@v2aWh`-MOO1?qX>t*YE{i<63}43 zrdY~uOh;Bssp^gVj58PwHFE7a_;^vUw8~q8!fSl`Jn}CWK+ZISc5-vlU#TbZmY*HD{(Mb;d&6<*--q%KC z2NR4W4E++3b9r@m9osi$zJlDQ!1RJ$&EhNT+2VzRmqRzt-4mWF;Bs%5y}$e|+1+|e z*ip^JNf#q07#iwPveFv%C0lSva9zuc^HaKh>)pL~JmchnI;ABGF558J*v#~r^NKBq zjI!o-@2z89YA7Lj(6bxR+Y`TB*z7|kL%LUn*m|FQ=owA|QEWNWBB$@(+@@YhpV#9` zd9KGp8+OR56trwpitss5q3ZphW#Sm!DJbOJlax%K<~~@6L1)Kf)h@ z>;=)(y91bKqyBW7TW(nK-pI&S_M)j>z|_NRb%{fQo`;?=*E%C!So`I#}&4^#dZF?4=(mk8!K}L&X|wnc@A&N{nxLw6HC;uvXQHtD(+}~!4*{z zcwyQ)?|>B>;~df^Yh=UW9<%Vowu4*q$-=enDE>#ly+1fLF>|?Y8xjuy@ zg2XD|gQ}`L_o!^pPD1dw9&_0xiA$W9_pYiHr{DXv^=yhC$0DwZR!*sjdW6%>sZ2nU ze8~cGd&o?Y`yal+Kyx}iCl{_BC8*A_$NEA|=GSM?*&#)|m>ZV}}l7o&r#b)AP&Hmex8@R}{^gS=K{i9iLc2 z*$>YvZ_Ly7kZ6i6sS&kNu%24cd$8UwVI;%yMP7~LL0Vt^wvJC@N*p!|Z4Y_G#*Z!g zGA8qw>#yU|ZdRlTO{;&iR1^+-s>~fxv1{se(#s6dC-+5&&wA`eQRanbW3KR+aA_h! ze9(*&C!_Ak9UGq(j!jol<#9f@<;N^16#QqZpaY1K0!n<>Kb0)+qMUXn2RJ&q{eXe> z1`#Z;|12yFw~?{IZ&Bm!nLJ%?E@hk+|5aC-aP9eJ%uWM6bxNl`O%%K=zq)KnhHPJ^ zfo)OAHxWv5rt6S!O1usKHHRbX4&R3Fq}XZdxVpV3eT6#B5+1y-VZJh~%7syBwB`yjI&+}EytM$H3t%dx-1Nshj0@I2$|OuG`35|a7%?Qqff z8}nc$@S`~Vp+Hfxc?-IkyKt35T@T&%%6_f?INiK6i?JX!Ca*|GWzESI-{!4W^SjP( zaHKrwwm<861}-=>;@#8a`bure8^CBJIa3SIAM`8lv{A(GNo#}FdFVB8G3z?+a7mvu z?@rCb9opMr-!8QEbXmT_ah-dNk{_d^ThJ~a3sW4F^5FKXge~)Deb7qRK9zkHQ=)=A zF}E!H9N|D!FF7OcnP|g#{Pg~T&StfU@P7txzb4n{G0H(SKjQ$h&V+|6xadR%?OjyT za}R|`BAjk59oIC;DY)qAxyjs-=8&8*^%A>v`?6Yd;z`O=9czQFXoWO50e5zAu-q74 z-IISkL&eW28J=-xh%dq&<&AHUU6SzV-BJ$~n-wqgM2U50;^!@-X5U63v2tqEtYjuh zD&z!lS`&zs|HjE|x|xz2C+hbnaD1JtDe1;Zk2=#t()Xvd8R%@HD4JXU^pX<8!P~0B zf54@YBi5}3_OrJyu>ip(Ev1Rq8^H$y_I1FOBx5L!J)l{ii0#Z^5N4wMP_Wl&H z)^S5kxomcFwNaM|6;xjyYri9LHOx zYffjG`cOD?I`cegYc+`EAI^k(e;77Ozr|L6Q1WSL^Bb9z{o_L`e-3wzu-i_Vso*qT z^XpoFih?Q^{xZh+_%$(r1?=5)3w|ALk@cQVvvhOwr_$bT*kdqplVnS{SSihF*Ohhm z#f-^l9^;m8OQC1S#&`31<(-z)*$LRy$+53P>lA2}natGx1*;b_^4x0nFi0`A2M#Bh z%xY-ROcYk!r)wU&)P0^+iicPWwdgw}CXPg|j)-kh2X8EfW_4hEq9 zkx(Ui)#hpi=is#Z2Dw!aW8ld8wg-BB86|GQ4N>tmi+`gGY>&_ScA}4no@S<7A~Um( zEyFDr{tB<@CET^_6a}V(0rj@Q)qToOvz?@sLcGuEI?O)6<%4N(XB~qc(*o{+?y(j& zF(~vB+YFEtK2n#Z$AW$IQX;XNc6f)HYM|9l*E*UHiRq;=4juUx6id~^|6b) zL;1*CW;R1WIE)Mw@1R_;|JfeFlGgTj=`wdP?Q9So6X|AgOeXM)n0_}=1Q6^jmg>$q zA=|QF?X9XtC2F-7SUWJ_eqPPGiE=J)#o6E$&@oU=t(zG4q?w`?YZ;2+XK`iZ!4GEd zbkT6(BJMc??4r?InG^T6L^%i!NNIY0YijJT%3;uwk~BK7ZzAik%PKOan|_s~3XC0C zohVt^U8Yr1Ymz@_?9l#UxwRo9_sy%#TdGo9i7#=vmmX3R-Z%I!Mk9E@B7*2v(%=*JOvQDq>`JS0*wsZCr z%=sgm>W$-U9G2o|$OnE&Cd>IZn; zbz_-OwR6j1iXz{3o{-euX;Hhbr1>eyqW4Rx>07#3ZZ3&|AwM1~`N@|5TIY~Ud^_Z` z7G>;omz%DXmP5e^zu$LzMQG}Pvkm8&oI6w1onxfp^og9sN6#bmZ6(suWw}0cdV|*e zvsCvd->={szP9rF1eqL_PWZd$q$tcEo=8OZi~#%o>*=&W$f~VFQJ34#IQP078&Qn+ ziH%RHDjT!^&zOh7Vl8zwo|S(6{vFXA5&TQ5I5r$y^Jm^Wx{)l1PH?y^*0jSvBF>xB z-Qc*g)hQX1cy)CQ znOTHdfNdmLTk^8CU+XDj^qeP&qld}iqkbQO+csUqc+d3^qf$!bJmVFq>&!<6$(c9c zn77HQkl0e}J^!!baaq;1p6ws#5^phOeh<-Q$x(mzcj5llQByQbwA0>z4Z%M*>!h}% zq&z;BD@$ZVMHsWLSSr8GG#xsv1qV29xvGXFbi36h|#K+H=c8r zC%bw|d*4RaN9m7aEo#kbgEt*IDaFJ}xzYwFRZX;_*!M19ly{Lc$qZ(lxnA7nUq5ur zQ&$<%6YNI!)+_+C;cPD-a=2JQcbaBa81#QG80iaLc;r0^;(Lda-U;+7na(B0a}5m% zLMnvOW3^>)@TjCrd2g>9N?Wl9q1=B%r>mC5@{R>Of=}6$~dN?F3IS4k1@;FR!#J`vabS(Jw`c+gG@QqYj!a% zosm=Jw|)^DK<-60XqTVXsC+4z3h`E#=qdHl&3io9(lTN z0eptq3tA`xes%EHn5{8^geoF`1rEmWLhvEn{~A$_2rqy8dLMCpxFk{udAb75&UR2S z548Dr8DAngtL_VQ)<>KpQSM1ONO(_KNb$Q8=&Y^`nnuumMz z1T}#avf;N>^|ndQ1CkYYx6%Q*tCk-<1p=U&@z2ep9q8(B0DLT~iCfvc-u94pcOcznEoh5hy86)c*5?Vu zq4X$KnMp2l=y!R28$_V8>mnVze&0LTq~UP6ddh*B5?2J=u+rT(Uw0qc3fd_WKh^nJ zsAy%j{J#3+gThvVv3|z229Gn5EGi5PkCixh%Q-=P2E9M%KwmEPSX_$5EE<*$8Yg{g# zJ(4mXqXGr-Ee#G3o6z`@qHwFGo@}5amy3=U=^IB~I8qK{!9NfY!^Osx z3f?p$a4*;1d)y9sppYa~ELX|WfpvVIvPrOj#8~uwEJL)Zs)|+WkA!kc7vLnb8SRoT z$*IgcF|hxzzBQfn>lJ)MG?T8P5*;2v{{+=LTPkBsP_>p25+!Pn1&|A`n4%iwHYHB1 z3P_@absFkd5)sV`u_*4FEjVYaEZLZ80VpoyJfajX9ooi5OR||56aH2}7&nBZc3$qu{%jldZMmCy47);!=OSe*J8d+b>;^I_5gqRzz+iwyiEG11>;=`NAVZ zW=)^j+I!6Y5VtNATIxf%03xH6^snk2c?Eik^9bc4Y#qdVdxnK(og%&LjBSR$3^ zf#1{jhyDJbHB-9j4wtF}zgeUbTg&$wCDlNY)KRHF5Gs;IbN)S2#V>h)=N9kBqE8=3 zY${=A@R39&^^spbS=Vn1#0pe?ud8q8{~$YkCR;H%;MiXH1xx=bSeR@7YKbZ)-bwAha@pR*NW@bUB&C^jGaM7_j}uguy%*V_Yz5?vObq8U3G zEJTvJJo5hge;0R+F_#QIVKu$GnAvIX_R`;7!}pJ&0)|nL9LfjuVeGV2c}_|%(b1s( zTCu$ORKUN=)TVG*ZDskXfTTa(BOD3wWs858bvo=t zv@QKYO2;6v-oFj#ys)XXuYBNaa1uoe!h-^)lfgkr!kKn#1j@N}~ zW~(0LbS^oBR4~>zc3Sn_zi2eKyh%m_lT&*~+oS@rlW=;B6RKl}(TfaWQ|63}hMswH z;lGJKp?jm&Q>Zzj57?8Hb86jmo~~w!P~m60Kg2qC77DwOL2Bd6+mB&q zSC?HFVsyG>XJ_vfkbn5LhUa?0b;PG8+TsY2Qsh7AQkunb9m4%rm9eAdLW9z0Ot7w` zn-Ti{%DRq@FNsPK6EHagw_v81))ZJ&laG#YncRM>OB$AyNu7e<&hZS7rp!tbbi!^* z^O%&pr$p}~O?Y6k+5^)UhYp=o1m-Wat00$m%eb?)fcA#JHo^z)WHGg%oaEm~^qKWM zJk~SlOCr%{DMXFd07mPtuZ{{^TG*}cKGUPqnqE@(}T^v*2%wj zmvZJ}uY}sgi+I%{M4i3n`TiIU^k6>K+WuKX(yP!F3E?}DwTd!2IB##KoBF1X zz!yapf}X07TER-mek;P^9~is>c&3ycTRgty6y~kB-GXWT%sEXR5XHi%-rxw-xkXR! zS#UKuV{!)>F|#otp}h^AFJg(6d;abN5Ps+sR0~(6Y7zkoj2j60PQX=yVt1K2tSm`N z;_2xJoF`+ZvCyeX$J%C4S7#_u1kaOhsqa>^yBKA=(x`N+37^;FqIOk_!iHKk9h#9~ zaC&Oz5Akdn zR7cHHH7?cDF(4!Z;JM0|J;v{t*Jt>Mnb$+G^ffdu{HA zjt^oIB~@9I7|+FDh5n0hL^$SS>;wWK8qspAw=QNMtJ_v`#>;LAKE{8w!r-yvLkMwh z-|&5IBiHu*Myp8q#ZN_}18ZE%p3{?V(Nz?olauMYG4zma@ccOlpVSZLzFk3zE!T)` zAOW}@3Ba|OR8@CCObM!RBeVYy>w9f*j7ZvG_AH5q{*WLUh}vg%%>?04pvs=FKPBy5 zOSyI!;LN(raJ{Ny;SWC|?4dXvMqFS*oekg?j9=~0NYLVOwOgycgPUNZ)uZ@u$GI>* z)KRMZ{>zAo=Klv>nTeTVgNDdr$uB+2I%-Xim8H?_7e{=?3K~j}oDBNE=$QrkSW`Hu zXhWi*IRh;ebx=%@^o4;a5H1C$h~J}vdZK%#$7hMa#}j?DdgQ}MJHUd@c;zHJ}0 z*L?jRx!*;6YWhQ8iB6L`bco5!eUamsnqQOrghjN(XntG0T5KetMnOhM3s{Sgrc{hlp14-HpAWnDchT6)l$g8fB zg)gI(TdbUEaql#N97!Ng2_>weZVr-#ar-Dip^SX9P$&Lbt5nHbfsKl=Z%%Egl9qbr zbMM-1J-LfEZ8+=wjt(KJuReTIiUrjf1143$!CAb-6gF6w-VmVs;_DvnB@(Rtm()ZO zh^2Kc;D~%D@H@2@z|SZN#)sO1$So6@#}658v^V7EUpx=P{buK~Dh`ou$y4T2sd?!P zPN5^k4@nfIQd89#GjE|O!C7^3Hv-mwxR9PqG(rh{e^ARxR0G5X_zNED48;YKP{;Yp zVO8JL1o(^#W!br-&qJ@)lKp*7Xb(MgA3JQhqSld>-vq1ay1hNYgT8*< zWt%yEgt#+*H4?If4z04BPRC=)>b+m{Lv*I%|HEtuqCnTmq{Z;6ApQM+#E(7aY_PwD9$C0Z>lwQ(_}uib1#zI87PAkiRTVwi*h`cRWCNiEx@+9Pjz z?+DDDV#NMvIA&jPkmo zHo=xuw}Bk&x)u{UiKSBpvcpm7QXY6r?9C4x&5n(A5%u>VE;0=U;sH^j9HbK~fZA zpL`()Y#0n99o`d^vNZd|SD^~}og)Frlj^TR-a@+3Spsk*HW3f~_LuKR@C8bPL!@$u zYja|rI=)}lJ?3yit=jHqW^Ad4xDipX7wR5yK717!c@uh|a4QlviNoehL2`g=h^4|Z zX)~v5YM&dxe2l8jQk_)MV&~SFD?GEwntCPH%K+}55I?sk-Jr-az!`dsB2*Cgi{1F3 zyr(T3huY;cG1d-601@vG8OOOZW*No{1o+<8TJ_KakOQv@S)y?iu;19J%f&opx6_g4 zU|!IY#Uot?mlL&K)aQttBo0d=WTo&ABEj)C3O3e~OHF^^8qxjwssPC)>|`ol^BdJt zDpT+Mo=+r;^~HV5CVN_tlHbvrSrl-LyrGDPWpRgp2+7j~f)x2b{^q*N8H9z0KBjd4 zHUZpG1Hx!<0-^(A1@Ec|=QotyQ>in2Tkd0?98VbE@l%sy3nSwWw0xEDpjJS5DbkGJ zEDBn9M~Ld`UCxSRNLJ5>@X`*q1c&BPO~N3fLo`#M-J~}vynl))jQSV< zh%M|IPPuS*E3p*(AO4awL&5)g9YpcHe*HGTm{{dJ$RtP2u#YBIOeuG}gw)TJjl&^} z?@Cu32q1fT>fquWiSOVDEDdrK73ed?24d(r4UAn zR63?^rhNVk)6|!R$H_&phq=48FWbBh3kber3+H|Y0K3j-%Ki?**J zgX9i-hDq-5T*PjePx`%&70|2f_!89DcD{FE7E61r7t7HP`A4moYM#!HG3aBjN~=Ci zNScOa?nb{6#J8Jx<=a4h^bFnZMO%#L3b989rzm*Z8dW?}Q0QTm>3_0vaQE{1`~ zdaG3j1UF2*`ep&H3O)-}^(XL9yKM%yd|YS=0|k{8N#N8Hw=0mF9$RDHTE`4#JCZ0z zop$1zurcLn!+6JOGjrr_uG+=)D?kkqUayS{`ZY+}BLXN{!k`p#DEi0rG;&SVxo(N_^pu!>>{bQEPKS4c}eIE=SM@4e;HI_Vd@ASFK z&+w!5f7TVf1lScCOP#=P183G}xpnyM&MgK*Wh6SANk2Ye%ow+mq&<;`Bxz4Kbqs!S z+~Ho+w7+}PCp#2cgy&Nmq_OHhH?7<9n`TeaG{q`Jk0VCVTUQcotD!r@Le}f4x8193 zHDO>H{u}H@W-MF|z5J}E3@KX-l^(TX!dntvW1SKSankEDbUTq=Pkb73sGxTGF1h?S z?Cp8l4fyam5XK53y2<6D^BRlaOeff>*DLm+_i~iA7`F={#{Xw-DKEc3Ld6r4@6>fQ z694JK3%x5|G8Ijr*O^y1RiLY=_bE>+0LxN`SSfGzhKE0wN=mwuKXj}qSV8kF1a)3H?`|%a3#lhpy3|AC+W%i0cI{Nzk?u?Qx zJorw7b*zc*^+}C2JgXLtUKT~>iO`yE9mZQASFjURJvi~e;LRv&CnW*^KRm2y>xun( zDH0@AUG(y4-WX%2iO^<-My`SE zPN?Wu260{1MRXU72d^$MF7?}m$bDqA-WI(io~@X>;5ECjapNu*#d)UX&~157eWlk} zEye$R_)-WIJrXAvjv+FcLEv4&G!fqA^z>bTpl`8-IwNi2BYi#()6Xsv+BG`LIjjFO ztiNyOU+z|}4C_&e+IlZE3TfLZU4R_UU{^Ui}_4l|Q5~QGyPWwy3*)7}ZN;!& zUGtA|f8gP#sZY1*NJo+WNNzPS3zBBm)UEo_(h$tAKsqh5@HbI}&eDl`X)`{Zg!-IC zlio-8b!K9OU^qKjta6*MQlgOv}0`En@RQhZxVpa zYc3kde0{cjb(Z~%*Aafgd*8f8>e@=78qc>pAwHE*z(7_BHi?!YpNI&?C8bLMfm5B& zFTPCaVf7#2miNEe2F6w15Q&q4t9X72Yfp(ATfR}42SrX|jK@@5=a+i0W#UiIaEefi zl?X-pAPJPs=wQ*9UV1hNMeg^~Ip7crGSd;IWrFnEQ&Yn(A#78ixkffNwi+j2IL>zu z>CgI{h6;+bDsc(#q(@!i`|b?a1(7%)t05R~uw2d(2O8IhqW`Fz-S{v2*I}<8i_)Pt zi3heWVRLn4eEBbMn+UW(bju!MvQFi}vn`~)dc>;?2jCCMTFmn;|HmjG%IPmE{+Au< zw6UC~A?LDe3_y@C*!$(5uSn4&6G}$_e~tumXv*@^nAMYOz%s_kp+|@pZ2QXV)w41k`ZMl^k9}yMrQAw zj$~D45U~yZk?TX$7+?W!spg-nDGl5Ha8yhAJvsKRpg)Ck1dlir%1WX)N%Md={0?A1Na1-2xRqzntO(^yiu#E1alUq;MAuf z016yPnsdOAANghiTWy4|eqTG1_{%Ry_)bFPhjf2#piq_0tOr#5y-5S4kAQNT4Dt6K zE-)A!)tu)wja{)Wswek_k~%5Jw&>$cQR0me)*rY4!JA3Q6Mu2gmf+lgFh6?U`4w_I9#bK~GW~D@iH+2MMuOtqy-#+C&%>7JalcHfllr)NTD64B0nvWhIW* z2Hw^Hm4if?bh*ZXgKvlap^1{~Wx>It(*?3tvEvnf6u_fM&N4nbw*g`2Vfn!n_s9nKo*s6|C zx2~9ifIb9;*=4rdj20JvfU@MNtK;^5UAom2KlsJxe;H#^8TTEJv!&L_z)j-J{?(ZA zrM@xBd4h=y_>2U#=}|$QZS@*4;Nd(op}a zG5E# zfeMc;3Z#har!+Fht1a~T{CM&L^Oi*5<5_0{2;*MoA|coZ?8o&Nk_@!OWk>pKZG;#b z!$magXqoH^gB&bd7Tq$_#7x%vp8tAPJ-m04-oLTIol=YY%raRsH#N7%<>;u@Ef-m* zgXm=%mihr%I0u^ZJmJZP7qBlV=(-qbwc89&x4DQEkiZ^xnpvc2DRq^>AQ$^e4?qB$ zMpRz!6{kGm^8oqnMLP2=NgL(Ry+G+^qAon>%z}(>dsoACe%jsD{y^h$Fs@-maDW$_ zW!#QX5V8Vl3zMibTn<^gwo}+>bU4~h=B{Q2xb{?G;?m7WiECDR1l=jB$;8}=UB;zX zk$(GaW%swLf#PKFt;?a9+>j_Repr!nsYbWSi4B8yv66pj%fNoT zZ_lP78LP!4(f&4R<`R6Rpydy@Q*I6?WfWYq*+nWtb~x=IbZtzP%{>cFk=~#hGbKwj z!tTJ(ZGqw{$@_Sw)A#nk6aLrRy0(eW=aLDqRpWRk^DFyFDbhIfcEgtc%fbi_12%Q} z998KN(uFWh-*lxsv+o^*Yyszfu|I&_gJJhQs(0SVKt50q;>T+-U7AUIR^V!h&(Ix@ zjgW&%tZ|cg7)UnZ!{o? zg@_`WQbPum7NRByt3yM(`UyP8sgoSkTx=5Js&1 zmNP&|C)6ke-w>NajaYtPv2^Sc#yKEdR)RKuC`jxdIe=$z%KN)N>B}^6rHOT)XsVmo zZ|C`THwkNAHu{f*Ef>z|ir-fF2o-LN^r_Nh~1oo2MzEO{@Z#V8Bb*$#j|! zg~B~g{(6%bzLTc}0V*D7=#-l9Dt(OCTC5^5Uf98-ef5WMq#5Wjh5v}!Yd^AmUZLBe z6A-j>{S7OuLBqJw#BD?!mH+_!Kh9E}pd!bjtEi2C0Y)PfZ2Ek~EkZcoBdTgYieH97 z*%Y^JiM$8)6z}2%YU(sPQ+Y%wFoMYR3XHt=TkmRjFwW!~?F^PT-JN^Uj$OzL1dM2j zDM1oatP_k)nG(1&Wmp^{Uie&u5E21eU+`!Ro8SfQ$r({LAT?XEN?4 zELG^9Bt_ODHJTZ{N(LxH-oPs~2Zt1mHs#z+o9kD>O%U3Ct}=C1&gf{U#@~B{?DA|< zYE7&Tq%x4ywy}}GyFnXmxApw+Wve76^9su-0rr5+pH|Dppwnp(!**;TbGwG#XydoK zW8!3mjwLh3lYs}37uoTX;#37P(4LR6V+(Y^;d=dO{faDmw})Z??nv&?lN-*G65UxM z0Rx>GRwu{;!Jod;YemXY;RKR`NbjQhM*P;iF{jSyt6d%RBsX{3viLFKB4635lp2GB z&$D!GuOuj(y|wx?!PQ@LbBR$=sRfad z;YW4kw)?MaFi%VGFYGw0d(5T%s{~EFzGRQ^_P`L2EcU*Q7y+d;>ua?~`5O7~wE5N)K>TWw#zb(}B~v|PNsglK_UL0Wo? z1ab3|mxb|t|EI;z>PaqUW$1py{82)+NdcvnEN1b7PBzl>)>nn^xZt~wS9>?OnfCT5 zBo+8^QMC5Co-7#DwZI(DE8r1MRMFet&Ys(Bt+cMhM{gTCzEH^uy&}3Vg3p>;oj9VQ zmL6iY$FOc}RWHT~_5C)~1vKqh=ok2j5ZY>!1X9y~*_xXLJ$-P5FFz_s9E>?H z-5u!FNHr%tu&8MVd;*N^?%lwMqt=0DjHN~$i?>_LNW>W|PGbED$8ij(retkxU$BuS z1g+J6bPl|NiASRmr_9#CI_;k(B#mx!VQ@NEcSg@Y(X_)|%ucYbv+(gFy!(|7n{Poo zTs(d!q^~EIeX}**9{-}wSH3{5XZHi5oZ_pdtj$}d#xUp1ZMT%#^Bf*Kbyv!6Y9(;U zmuR_rZw9e2>sE$ZK)qM;;?QU%*W3GiYaV?HkJH`&b;;78xJus}H*fBs)uV|S$e^cW zRk%Q!hESw26jS3!`*i<^@KTc*J3QFI{Nc(yWO^A?V)*eNZVL^epiN$b8pHld+=mtspt!-EYP3XBw+mys2B+a?lh z&_osw%6jf5R#9#D%QLjM`a*ZQk5py_hVO~kzvW<%Qwe$?x%aY+Ic?GX@(NWT^rnD-?!4;BP&65FS~=60abFv+u{Wa92q5*^g|Cn#h-(~Jz!|Wd&|s2-EM{=z zZ(>lt;9ipuV>cijD}S*{A&GZou?Y(Ux36#ew)qFlR>6=GuoP?4aMD zgG-)md1L%&*XL6AUw=mXq?>#h?6OSjG&BoRlcE!@hyG5Uh)A6 zAD@Ow4MqPhp+f4JJs0^3K7MQPOZ#SVKJdydx|1d>Yq9<2C2}KORz2ogYQaDe)qUfU zW_uG;e`5Gubi*>~QwfI0Pv^&CqyJ#U6Igl6cT%cpT~qHg(#TwFd`{2UfXp@gc|Ch( zj;pxgdH&E4T|Th^o7mS^pc9m$u1KuJb9O9oPA$0Jck|-I)C)BqCkvp*j`i&S#3NtX zB6&2Pd3n}25Bhz8M+LpI2P01=JekS9pMp$U+Q}Y*<~2$s=zPC$yTNx5PN@k|m~a?P z#vx$B(>e?YLigF2t&86tt|j9)ICkq+y|6Jy*+ON@t39w_5#gZau*P2zX$$;uZ7zlM#}$h%*1KVe z+3GQ9?PQzQkB+yvCu>sj8W$H!Z0w^SwKYQYzN|J%Q1-p`|C}E!23RpZCxHgI+5WLT z3Ib*#zz?!C3u2AEMttN;J+>O2DtI;4OnWD5RK2>ovOl7FsAjQcekp7RU^#avFT9C# zw;Lae!Tg?z=z%hy73ykj-a6I#4kE%SD3Fi7h*%#BEqyab#!p5jEQHn+x+1mr}qyu;{tqXWlf7J!08o?BfE=3-EvEE4D~Ih02#~}Z4qa~f z)A5oEUWJ0^pUAaE`vQuV<4NNlo-R*ZJ0u_=3RVL z-qXr-Pb!DG)e&OqbMyCkh3|yipr^+%m2i$`W;H9=06grZ=h?eX!Z&M|+nEQvGD~}S zhzwXUuzF3d)wRsDs!mIzYA;cO!D#&hyZZKH4~JGyA1k-~hFpf)3c&qoc2h*#TLk{7 zup%w?H{QH4o(kbhow@T(KGj7Bj7syyJWqk$QAB^D#g*hiw7jHb1)VJWC~gpa_ExQs zj=7c?9(PQD?S@fJZneeSMfAGb+uos>T^BoccG*oeD;};<*1EFzU3b3BN89!VvFu)} z%U<()2w}7lR>~JE;8hu|41KrmzDLh6@dHB9#Y92nPrz(iLi($6#>hmMpo?Sv(daf~*9L`ALP(R|#!Bgq1pDH=6{ZfbwW$9Ob~=GGKnr{6iltSPuB zmxGS8GqvzZ4>)p$|w{W=nix|%zS5bKG67#>nk6rBx{E~gCz!RiE~Y637tu+ zcl)$&_cHEygIlajj*0jtm<+z;Yw;paZVvKFia9w`N!KTOBcL?ewg{qh8rsEaBh^mg zfXyqqd(z${p1DwHk$HV!L3z0~_O9sg*o>Dqh@bPe}A8`1jBEN7~^ zV^kB_CClscg5RU8$X-8GW&tgJ>A15X+VSar8dJRc?EFvYkC{PvxF%?e9dnuH5qYSN zv>Iiy6}*1i&{F)U;}8246e;d>YMRug8gj!gRbDq44uXdDI#DJOWAjmCjTo=b81_O+ z3>gkr^uqH0X6*r~3%RS9$tW11O{yX1r4UY32~_4`XBKIf(? zo03n?Z3=~vnm((#7AQx>Ps#Rqa$)V=F)9Xetn^S03*%s*IN4d;#`MMu-=Psa-(GT- zl@6$@)yS(6izXWAufqmE{kyZ^x5@;Ze4;gz=UXBVPCL}?Kl46akA9ej0tNeQZ#rN$ zAAZj#RMd5_V4n{ee2Cp>5VVbBRIg5)sWh9rxK;kE--=LYEbDpeGLJZM9m2{f^Vvif~(f$L!Lm;&j zqv9;)HtqKJ<#hPmzh!OC3FNdlO%l)UU!z%mlSg(h#y>L{jB2f;ILW6UI{ZQ)&bsch z{pUSHLr+O3JB-c%MGVV;w=&!BhXWDrLJtdMX}^uVD8K2YzKwyB6qhdf>~}-rSb@1_ zYj%zuxl8X+;PRTk!u^+TU7S6POjWDBX{ zRn;~&`7JR?;Sv8RKkcn!e*6fYyQ^iO`hu)T`BDgEAHv2$J3-tYa%L~hYJ0S3YP(CK zmCSr_8GKdW{7QKAXIGY@r&&bto?JIX<#P+l8h@ePgS3iOl|` zBww+cD&bk&`{Gi%-IQF0rUSl3ar(S)j&-;fVY|`wuf}VP?ro3Md9)`Y=JYb_e*zo4?ZC-k# z)57t|*0|enI$$O(Ef3nx&)8%cq!#@8LL+?_xAa)TAs22L`1%^Xldx@(0w*OTC7@O) z(#CH)1M`kpk=w6I-w)2TUq8BXtApb^MUy`oBS#`*7RbG%#?j)iAthIHliSB{TFYN? z%b&mNw8fZQ6$6(hxvpyJE3Gv-t7IRO+kN)ZrAzrxyL8QQRy2_`r3aBHV}&MOVN(s! zsj_$!A#+6!HZ}!82Aae@dV|Qk$t;d*%DTyO8t9Q*to-yX|574&@eeJPOMmNp$$$l@ zGJ)|C+U26dee)7|6Sol`HT^ip-AbLB*)xrN%jZG`EI;hD6PylO#w}l+@Q`#gF?{p+ zBTtE`vf>pqF{NDLJI>6@H*HR1;g*N@MG=-0t3*)}y6j^a-o15X8NyvH9q;m{UKaIo zbXrLiETnW-R3yEtv?JjnT7cV5Ra4_&!pqiu{{U(y{)l0K{PQ-H&2#K>?32lY)YGaD z$j~iNk-6pH+kcrsN7%#tmvu!xllXAp!FyS|4w5MM&L1)!z(hoz$3@xaVP0PGU#F`j z5)tSM)e^zG?r_WG`pHU+NV?H3V0N0}rxoV#(t`kUh3mcu6HTJILKcpRGtT?^?cvgv z6ufs?``a?3^Q*s^wx$$a)WjdUb4PrLKCBj-&MhErtPa<3bYsRZ%9AZ?a@=gp&2_BM zJmGuqMH%AM#jB{k;N@eGZ0DB$cYUdkvyG4g~MRX6256~y6#R|0cv|uFm zmEuLEVZWAVJx@Cz=^?-l2{*CTQwHO<*~E0`8zLtccd=YS zYn;mQ&mXxL-XI$7SErZJAYz4>1|E+2D+4*p^nu%2t> zUdcPeLrylQyKbS=e0hQ5-?s}OQp=x$BhtHnk;@~NQS^54eYmu?0)c8vR~LeR0zDYs zU=&*WukwL2p3Js@;@Z}Bi$0I%&0daU=wde@z}bRJK0eSPff zv%41%33)|C&<1DgjNy>+80}QAv4`8X0|q^ZZqUgg?nYCn>jSe9Dcn7W@P2NbbSKz-8P@?XX3-e5LOAgHRcY%)?{FZty??Ut0y0xzjH7F1J?l zl$fl1`7lIky7}l?cnBtG4}<69L=;pKBa*#^8Zow-EleSZ`e;lM#?%B zrIM7925Bz`5sgENq(P#cv^9xHDoR7sDu*<*cMqu~4JGZNQluU2@m}BO>HOaJef~P1 zBc5;HagXc1@9R>?bT6FU#Xi(d9tJg1YVatBGJbOaT-|K@v9{HD6KF_dN|gF(cdcow zJ7_LH&!_)`epcDPKe24~n6VBYKf7q!;z!B_T{hHqX6>%LMUF)j_5&#pyfoZd z4Np_c^Q9)z^3oxEnWsNxzRBJeCCunfX_1egI8f=sJRVITtXU>BrhU!GKOnIf7US4b zUt2M7*Dq;~Cp~B;xpIZ;h6Y+MZ&%rMpgMZ`_)xLQw*7PF)kheI8AFXFJKYF8FtT|X z*Z_XK`dXJtAu*>nc<=N7Bn-ne6ybYMQ(JOjaNUbhr*H5R)O$I*z7ysZm=5VpH9s&9 z__~dWK!|AaAO@}QGmk=$sD;LZZcDv9mu;b;?ZnR;hSW`;8Zs|Sf#Nv6YhNsU)GC*W zGcXu|4r?-Y-sOC0?lNZ%|BgbW*f8}oW!4i2m$TK--(O1T-c;95Swb*wyUJ;H8v}DZHn=6Vo(s2p@=Df&Laj2D7C~-^f$aDrURrp~2?{ zC&OxT{V1O}>;G+XxonyK5?<M>H6wb;uOVy97GOXe{Onu@n8XIk&WM= zQX5T*e5$fCvwC@N*QL$9Ex5UrNf5cq%=BRew>$!HIwlI5bLtXD|8Li`P=O&Y2M3xM z0bZ#hQkREENHi)gk&_)FnN)?ilp?w>@cHfohDo1t;KEUV!eTvb+WHNH)n5o&hL@hx ziUr{-*}x?#>#;nR2M!dIWS6aG&2*ENFgn}R4Q1qG+nJqDEt|Ih`Cf+OZN<6XzE|OW zL+)C2nsc)`uVTmRek&A?pRBK)aW!yx`D&+oK~n6ixQRI)kNMxDzD_&Kf4Y10y>wrA zF}IKu`fArucj{faP*(P#i+^4w_~ihG7_U@9s+;zVa*2zl;9+sGu}#UUb&fL!(Y4y^ z>+&EaFQPEB@NY#gYZY(PHkTIRgR!%2!}^2$+=ipfj*dKgoxO9X6o{Mw@|BB5wlgdz zTVr_dfvQPF#A6|*=>(C+l@Q_ zSmSMq`p8wqoi!5QLjqcWKkkqt=r=g7iT&X|rKPB(Epmw5rF~OKCMc7SauQ>Az}g6a zrS?(S^4UkW*I@&WzbG1F@@&j}lfDPIKnUPX*;R(`OzgHL8N`$k(B;^+6B{GSnJKjy z({_4o1=68Ip`m1*2bu?lR3dk*iJw|#px_Z$6{AQVyJ63Jn_Y(=JZk<|7h&vS0h^Z3 z{&)?B{&)Z_`V}{9yW;93(0*&Sn z$*WiYd@j(AbPsVT{j#vItesum@fJf8%U!BSR2dl+eKfk4*u6pmwagI{LG}6?^{XuB z&7M)duCtGeyxM7ZE4AtCAsbzSN?rJdf88@hu8?hrc$dQ`GL8R)B4nH2-yvL0nWdg_ zdmQle)Vuq)>hN>aD%$f%nrzSZgtIre({;wdfeByOp}%KO(#Ll}+X+^6(+53xmoMSl>I2VB(|MGVY`><5esua)@D_N0MaugC-FHskJtWfIuM@M9BrxqR&l3=l7?r zUqfX*L_@cQ4_Th0N2?De+J3wjr$YoLv2TZU;sy3Cp}IA1NnWG)h$@&(*i{182wfEDMyCza92Y?%H4C)DBIxFvFLVxfhGpNqJ*b2;dSEQ^LNIOMZ&Gkd(;_%5iLN`dwjEG1VjaG`T7%8l#uS2blz;Db z9dek)i>Adev5Eci>}coPxb*sObcv8HxzlwBAO#6quwQu-WJ{bxBR8n5cR7e@td#!T zE6w%GvWoj+#wC>G*#|LyD(ta>^n=LiEEMTm;UWSO>Ki z&p3__{36m)$lSY@uXeFdu-7}T(*}VMc+l;rpl0XC`dV`Rqq*_Xso>)I^rHw^+!VMG zuw0IuNXMTlQ`S8Yx2(TKMjTAyKmTazPHW@;dDm7hWQj*c!J9p{`GhmyWLYn&tkAll zs3Hl1ZV8D`TCM}yxA8X}qloSa=wZM3znT&mQY0%n6QzDy$ZC0c$^$3gTR1a{W{7dU zz)%o^B7`e%9Y}F7;^1YOEoOhJtxlb-%KH4{>>(ljJ2L2UBwiZ@uaA3S>&d<@z5ZSd z?Kg_6i;lv3;2a)nA!)b>gqegauU>UOyoB4j67XADi8v*hN~{hHkN~PU{LYtbNjF6* z?+QMGnJOE#kUbPJ};v?+1* zI{aJJ%54j_KLX@YC}C@$ELdH3j(w+4I# ze01K%Fe*s=`y&n%riYn1{St|a7r2q7-Ni}58iSIslL3J+?p`32C(Em4OkZq+3?$jC zV3N1clug0B({T$y0(A@SHr-|##w|V1pF4+8egl%Mo%WVP=O{`p11#egtrsAREFFGz{mr%lz3$pjv+H$?4WCj~QLY0*mjw?)f6Ad4iQydMm z79vm{%Kn02hL&R^RK95Z=cSO4(ELb@ELLqbv_oKt#oec8p6>Vz=x`#P^puj&?k)jk ztP#ZWt2JwR=xmfcSs!i%GUvhxy?Qi32_LHTv6C6dS&OSju{3tP&=i^F z;lGY)_;y{oy|cJt5|*P1iVqK>zibE!^Ecfa#~7%p9LzBzR?8^vZ-a`r2Ni8ZJJ?w5 zHdu>GV3DigQJBeGaCdRxHElX^bZJ9Kocx=~e?xk)g7J_w_@dcYBs$2)Yb6mWK)g`e z?Yt|elXg0Jjmb+|m4tTnln@^OqJ_s){@zIF6B8}>7o|-2l~F!TtM3^fG?18H{>?yg zIpbs%GASwGonf9pz@%M46=8@LF%^0%3rfzW^;Cgec!BuMFRwR0W^nQ*zSDH**23i9 z7e~GmZ+)e`pPP!zV4axMI7e7Y!axDPYAusziT8{}A!B%!(}KEip&Pk~S&XuC@;+T> za71CLBwrki#5N=*C3d$qOX7upy3em>Y@WN2xiIswPt!Rs*(t!sv++K^o=v5`io=PE z0!;VuC{%ZqCmwpQUuza#ncnA~`s&y-zc2pt`@_COx4X}-A3Ci33^IBfOq&fi>>&W|T&+vm{e&Loba-$~rY4wgeF_+{rvt|baK>c*d}xIgI3a14q# zg-tWe5;;E^Be`Wje#Y;ci_$^Z6HS*QWjN4JJ!`Mx&c)s3la!uCM-8#hC9JO{P71D^ zGf(ybz3&N>O*k2voahINbPv@z;x+vY!YPxExn42sjesS%n}<9v0ojEKu_lq!Ahl^a zRga?Dnt;#ueK@sjO|Qpr~d3 zk+GEN-@S(=kTRE!%RbHyddB!N{wxl#gB^oF4KBn?ss8w5QE(gGN9z9ih|xq364bqL zPQH84(4g~XF}IQ?YEx%4L-c$n@+1+?q?Y&96q8h{S)8La;@rh;d^JCRzn31^NWEx6 ziDn?h4_%9;CW{C7;?*v~|JP!Vy9o8@;nUtORmCI9>nQG<$bO-Adb(GT=AjI~l|2pzrYK|}h1qK8gRm1fTO7KuL8^B!XGqeYiV&TXhlM!Eo!6piR_ z`z1xfm^(ZdAJr-M-Ncb&C=Q5^CE2nzKGVyd~(Hl9q-#l<2cWb7^@60?TJHBBYVX$RJDGz3e=% z7y3=_`5@mEcNV5R&ZlM4DqS8`h&~3RR^I-v7htYk)#@aZxHNm3m1eW0lSp81J=t~2 z;1{Q#7Zy|JK!3Q>GXn;`U5Qfl(aL6q>+K9TYll1nc_|G+gcHnfA*&vYn3(4gQR`RH z1jDKa6w`Hc^rC$jIuh56$LzbZ)}*6zjt*ARLh80ns$V`aP*Sa6RaKf2`O2Cn#|PqF zXNUF4X4asez}EJ1r^mwQStA{{9QWHkD440pBs6_>(8cJW)_3|k@3l^sN8d@i%u$>5 zpsCG`Z_YgIuTzH}eJ7=)gQ^!@X^(SwpR@b6Hr>du5L&;3=U1PnXEGc~9Bn8-z>kKD zGh3?PfBv>QsEU)~$pe1HTrb2Nl*5utJC9 zsqC?(avRl&P(wfRU?D397_-TJ@yFSVL<6O)>N~1Ff4H>GKG3c>dtCe^W6)EEhJXKO zyx`*g)nn(w);;z^dH89v)bG;40|KI!xn3YEtQbM~3e)vo1)7VZU1&veh1Dgmlm%$W zeO!F}0+072u~oHdahVto1`i7DrLsi}eXJSn6Y)^z5=7hN_* z^nU*HzEG2Jq#U_^6m=Aq>1P==tLQ!7Q2X=u zp_|K(bW{QIE(rw#ai9Q5PdTkJ z4OW~J8_OyOhbt8wX;!eIIfcdKc&&7h*Nri`ecAhA;E=u*ch(e(58SmKFdc)rzWc6I zIweSa!0a|<@RZB^-VQbb+$&S!MS$G_ghm{>hhW&WFuc;|_igc~3{FnV?v!pgNqrmv;uN9Ot$SO;&vs6>jjkK6lBJ0e~-;JDyZ!0B>HP`Fs z{#>2;=6 zHHYITu2(LzSSVJ-VXhd;zt{*U15u>BY3*XbA(Sg2{aw*tmX-iMw!a}77)7i5IowN*R7eTJu~<+&fs;a!vz8J4gU}{^v@Kmb(=C*w!Z0H8-^dTZP^*d%UuD zzVXZXfVv86yn}BTfTnkRB9A$2c{bAzbUr zp(%!oOGJlV8hgAxEF-G5;Jr$Oe&rHsQA%oaD8C9G$0g9od@Rl-aT!8!de}`|t4r!c zf1zrAqvdA(sF;rxeig>RYoJD=#l{{QH*bG#?T10nC;OB%wSSrZf}!e&M$()Xh1jww z4W;~HFYr(#B0%#?PkOL9OBTl~YPA$u1d3Ex8-)t$VSqu_7FOX7YHZpJwIL2N7ST&7 z#^`%OI6=a2^wHxw6rDrSkh5QrUB8jyv_e}u=400_gaMn&Q&q7pU0rI%gJq3%_Hi!0OGOH-O)8I``ZfABI}eX1h{q)*@*>u&h+FT z1)c}B>u`m=(or0Xxu7$A1BJJXF?F%STR#TKq4xy^O4zboFL`vk>Qg=?B6vqbYtut| z`8ia`O`ck`Y=6xvopC)x_7o~BxC}u2OfZ-M-5jaSdcK+UNA{@HSZZzCFS=&- zW@ZBx*OvC0w1_&tWWwTR@6n(o=y|E5@7rO;<6tyfmd#=&0_7vcP5tsgyxsOvS9Ez4 z&wZ#Di6H?uQvM!)yBvwt1n=A5LzCAadDTEI)R{vdIPsL#$9&flKYy?2EDUKntNK9mq^wX8VFy} ztWcbvS53MucIDeCPJX?$M>$l-#tyEGo18ko_U`JIFA9obSLaO^W;6A|9WL6MpRUvh zNGBDEyjeXqHnySP`=U0a`yEoec<151J3*o~^AY|0C+8LJ?fc=u^TmVv?1;;^v-b}y z%!tM#4`^`_#vs^iA%XNOKauXYx)*q*@ucwv`4!F%5Lai*?>61GlD=Ad=ZW!jSCo17 zGa35AGnG~N<-g@cvyI%fhj;D_wxi*~li)JPY1n$pt61N*fT0ngW3|yc6xTCO+|c|I zlG41Q`T=i8DY;;ikB~d;=vOPT$4ExX{^gUqBXl8Evju-UDu%l}w2B9gUsQO-jh_;t zx1TH>tXC+Mm@N3KS{!ww&wdqN`V`iK7>_YnXkOU*)=h%NMNFqXFDp$*gDuo~oKbWG z`TYQ7lpIpm2p~gfKma~KuU1aq>FJh(hf4fDEX*y;D}HB7Rc4qyNNZtv7@IJ|NUJdR zEywS&R|L#wLi<#j?0Hb08=*BdDh|E4e%n*Mf-R+W1+~wPyc3Dn1+K?xrT^^gRN^eQ z;cJ!!)V-P0&#JrP7wt=xfM(QdS|sloP#b`?tqtzQTuJm%k1P)lgD=Co(Y?HH%40rB zqx0tnieU?y`{k~QCm|sJT#=sV{O1@gBO!3HOOx1q^{n8G36h1z{iDeb(#qS=%+Ki)s zMFeGM14-k3d-SDD0Tx#MVQv;`R8!lgqv2@%nKg7wruBYMRDp?fHgtAwu}(XI6!X&! zo7z4COn1fl4m8b20J3GeEwHl4WH`Axp>Z#15NvL~bbewxLDva>adW$hhH6p{L)`Ov z7yfv2PHgbZ^q*AMX>@WDt4|T=A+|^)-6-r$zU=d@jGm^lZV`UQF^X;vMQF7t(StSO z!4(O50~`wicQ2%RZKgn4cxdBctEjP6>p?MvkU(Q(+;)@;6X1-dB#vytyi(?{caFCecC ziwPXsaga&?x9z9(u1#U!g)FVb2l0Mqe!l6#X7o5+Oq3*u+Gfsvc}bmy2~1nvv$9~* zTw?NKs&sWq$}~`u_N$d;SBA)J0BK&pJT30IwO^_ZBfiz*W6JJ<6##Z>il2V?&jaIH zA}AT$vWB`x%xY;CK>;yqf?js={f6%*zX#=C_#!?)t}cKx6o*>pp{rej6e=}{Kz8_C zxeTHCZgdq7a0o~VrerRVxh8Qi9PRS;9rqso>#*?U7bJiBw03tzdY8a=dx9owo7;@d zdOtz=v_l_tNG&ZIX5Exw_n8C`XX=029e#c|>I+r=2}9QQ*XmF1@NFg==h+O(2yjD? zWnM?48vyQOoVvOgQ_9>jGuwYA<(>*HKfYAn`11kgpiKX4{@*wPCF`%=C5>AexXxX< zYR5~^9C(!fHE3HIXJv|Q)Mg8C!(q*}vN1Ar zrQ9c_&d=QZ1rY?#W=~zJ*)}C~D8`ACjESPyi;gyyIh9&z0=NvJ114dBbW@HB1z}=? zxH?#YDDeLxFG@2C6XQ_0T)mI7A;ZBTwmJQD#ONFuh4BEwMrB_4?x@4e!2ym;Ho=z` zU<@^)^w`NrRQ38^;K!ZfBdbF(kc>N-2&vR)=lf0+gb3x*k5T1<^$Dgcr%fo@y%kmq zXrKWhtS>oN1P<78@Vl0yAa+~KOL;poshvc#5>+)Rv*eFyw6 z@H`4#okIugMHWI8;rjaA|_d6%se_#AT{ zV!#u(`EpL-=$4@>b>fW0S$n+M%@&dcms2MyclqZg;QbDAuAzP$MV=+&*7BdxzMMB9 zAQolIrQ2Eih=RRr_cgQe<7-V6Z#l!+TmssB{H)+BLiIwkyFT+P!Cj8B1x-Od{9szE$RKS|x-u=6!3!b@h}sHA~HY^1qITumb>x*m__4g$if9umlMJ z5eQQ@(!SkIaeOK7p~B5eifI)-r%~})mqBBURt)N`r?=QFCeup0*N|4&@o1j_7X4&< zVjroWa%ac26wc)pE{IqRiJd?;PfDy%p*}t~hKHL&+QU%2>c$8P;>AnJ6T0ztOCrvk zI~zi4xA7E1!9*{j)5=^tN1`zj=CmnZXf-`2C!>Fv@uvIB3(Vm$!ZYF@Y_6tSdp<=H zrQ^hT_~p&5^t7Pr%YVJcf~GRG;tPSc$NHvv3t<(Wwai}x~LO8Od@?@dcZ&)Zw- zaVzQ*GpTr`vdpl(r{n{fY{1~uOG=YD%5G)0J|6oUT&%7}?0j5i7GOaCXv`6w}>WAfPpD>)M zm<)K4ukOkJQ`8R$KPBrHQWdEB&{7qZchx){Nq~a_(fE(A)i0C@LI8jhBR_dMsZxW# zyg|l}^MCz=WLBEiI|7|{KGcO&*+?q?r^52luRm!^lhAP03@iiVGVWFYl$UN?8$W8XxY%=luwsZ z^)Nv2eM2=H@;r6Sw>*PbefR8ddeaxBB{wJWJGy2anD@~kkOPd>naw;<(KEN3A~m&X z5RnpGb+ORZ@(BH{n0dhB)WNr4%a%!LZuyF^zG>Tk$SSA=%zj=VWgrR8mq9ntf1&u9 z;yRSqsO*WBAii;Z+yeq0?XXhizI6D6#nl_4S9ly8rUh2BRsjtHNhZyCJnlpTJAHg( zLnnVQ(kE;H>$w-Qf}EVq@LpqRl>UZBY09Ut*0)f>u&|UltM9xE5hSiFByM;?U~dx; ziuQZr^6z2P<>OUaBUe*>TDbA)3sataEz_BJZ-by^R{u;f@ z`aXSkIXlG>j!@A2S45Lo+=Z-(h%(DK&p4?;phb;*j=IJ=v?)Z`!2{Y6+O>9xT2-=I z#$)cEvXy8piY9-#SXZnWE5PK6s9^Z^HS(%(z`_t!xg~A5Lpp?`3W~fx};Tw;> z*d-M#`kdw)7E^J-P{sNI-+Rzm#I2V-(re|rc!Q;_mvdgJ+&Z~w>Gje6= zti;FG9_pMSY-NyD3DG$h30rJ;Dv)1WB%x9zNH`(Rl#j6KeCe5avXmi){rZB>YAU+g zua=DwH9ldQClAVXnY?KILt|rwkFBfRQunyRF=g2&8Lx7hX|)VWR#5LFE*=nhe+v8V zXG;k;wKUR%s;usSm6iL4;!?2D1CJeZ{W(71CUPQlXeOn#nNZi5rpsIyd3H9u?HHj( zz%``AhiXSiypDafOQjYH94}FcxO|gp)NylS+nXGjC||OX)Qb>^eENYR#%8$<6jSx?lczUF7xTq7F1Y$lCnu{-7E%<@z$}{NHPDro5?x z1fOV^OjVDuGbYa=eDByem@amYceY)=OQ73EyJ2MBW>50N=V)cD3z!> ziC*&Cj*h1Ggq;gSOouD3SvyRC?Co%$l+`}oRg=qvDT>Mbn;u2}{q`{VYQw##j)gb5 zOhWb~zWBX($K}`RjT$9Jq)V9CCn!8~4tj`6e^4tz+WD!%9%u3?d45nfh-t<@z&ntC zynvljeXc6HqC7rWYk>K$*7?Mx*YnkeJ>x|06_53=VctQbc$AOkDV%W3C z{8Q(zu3E-U&dak5r3Rf48ha6RlAt_h@;tjT50y(oIy5(TOu+-BwPbOW4P=kv#-o3l zoN+DS7YQLULSbT%waZ*k2H!@}+{8&X=5LHwJVH+Em*>5`zGC9%pXoR|nJR3v<_%tp zFSmj)db871hISZhY#dGhXyflWGU|len(r@H#voj@&XoHO!l+8|D_z#X1fm@@RPEeY ziNk-bPJl20G4AHbFt)=3g0hFXCI$276U%&Vc+DxMZ6GV8-h-bug!e7FH(#l1w)vf{N4RFi+_a=omQHOpFa4h}3mVRZZ8cF{Onh=^#|n#V`37JlPM&aJa{V4goS;Jliy{x7@n71=3P-gsXbk$-2ISp{A0!9xj%N?d5yPxn4Yf z{)B!(isagFVipz_$8#$j!I>`Ma%`5lk2_1jFqhCH1 zvIOr$L3OQaTDiN5IcrAL%;uMW>qogl|E%uqi>@3JevW&C}5>z2ROHp&_IPWRf>G5tKJF~YydOHny=;FJ@j zE5oijZrx7!dWDXw)Dl4`iW9$<@l=~u>heVXvZEhUh%(IzJ}~w9%1|s@rt<`KLc-5Q z4H9iQ*gR~M=;OV)bD4GF8_)xwSl{eses#xJ!y$PlR_ zLTi*XG7GnzHyJW)@6`yUmG^MU5ZP+%8^mr`OHR+NdA!r#GJ5rgln1A@!1IoF+XEqf z;5~=J-HkJ@icpoPZCxAu2EXQDTk4X3eFga^o(77iJFk0es!4d3JmZelzV9v)gtEYj zezoak+(qv?SL>X;Mg$MYch2<@LREY|JrpreD9cQWN#Cb>rz_;OwFTa^=+jzff!*<( za2$}nD|)+VU2?6j^4{>)c2NiO4>8PH=^WtPOh`uL+r@PW4P6GdtjJXa>-I>Ng3 z{mKVzQshHT%qySuq}Hn2m-?e>AK+*Yy~+3bPT@ANo=A{#@%_;a!KuJE6>7UE;V)YU zKfnSwc<+p8miM`^d<&!fnfy}^dS7BBg0_eMgtzs{c`T?w;q%K(yj&H3l_uD!UbDnA zgx^?AErg(&%6ebc*)8-*+?B2Jt|^kg1(|g_ouR{8eROxc`DlM*9xft)w7r`fxsH+r zQq;)Ia^ug>T?>X@>|LN+)c1gzlTuOsS^ePRVnXf}tHMXhKcMJV^_cLJ^4+j*BZ#r# zfncE3A(17hYAjc<&dc!zUglD;FbZ|m^bLV|(K>Bg+|>#0;Hvl3v@FVOM2S&EeC@Lx zR$n%fs=(uyB<@O;{9P(7Xww4ExVa40t*=S;c_ayjuMQImMGAM#=eJ5J;-3++*NvJJ znt@76^*>;1tp5?4;Ps7Z=iR>%Dlj|0`F%3F5bxnUiDd* zT!jcEKR!iZ?tQy)v542AiVIT~mgmOTM!^%VB;%7*qf{AViMvgmTs%{rF^vuV z$1upcDSgWpX8tN7PlQjH>ERO}zP(iG|O_0QM)t>2@;B)$fZJo4V z)wDx@`26M}>Fdyl-lmrGdhbi|{NPu+h}EOYe;hk?mk;{n38tai@vj2;H$iJGwyw`a zkkVtb+0`uL^oubi@`aO^9a&@g^)e7)y}OSDx$3=*&@W`Qo6`N1B~jgk6(h^icvoDy zZ^{NNg+(_jQ=N76ouLc<_PDgg_ z{xyd(T;IU8&suB!85$@YZ?RmkWQq4W`A(FLrrj}?MUmScA73k9W&Pjzy*hSLuAmNb z>RgUDAL0I6P7nj(!nLwN$CU! zA&|+UqY{}eO`G*|ye0bqrTrSNU z^l<1)NbjS?^u+yOU_+kcUx)XMi+8g?WtJMe*OY9vR^E{X5V#<~s>o-5l_Rsg#dG;Byz}&FNVPg5MnVpdi#TGVb<1OuZyi&>6)}e~!#ZFyM z21+toYavSD^%WM`AAx83t3lzDx?j@veDt(GM@cl5E7+eSQOWg9>s- z%2e@|;cCbqT6vr%`PGN-KdwN7g{(`X2{dT@KKYjqZw}EHE+1n*P8PQG0B;1QOz*v9 z9#;tCTD9tNw*H=^51pM5L3kuyn7jir;^6S#i3VSyYY*pvke!HaP&AXTnWn=-KIl=s z`VrTWo($e3ttHDvHM1z^4$@)-?H97WDumsYEMdcI1=qVzrETu5V{$j6=Zn3a&x#n! zPP){Jl0_OqdwOTl9L=>lwvF6d<@A(b4&LL!A+A%P2XUJN*|VWHMCe=RK^Xt&YqRt2 z0v^Jx``)IsTYHp$6PZ6o+W**FPD8aVcXUqa1~0^8f?Ch-Q11+brEu$7GJI1gN!_|> z(c)rBqj}K%mS&CdL>ca=ghVcW&+T1r=*L8seW-iv#p)^dKWZ=|AQ8^fZ^lUve`rF_ zzu7QG?1Ha~8h&8(oJlXpw!FII<#x#beRUvu^oYe)9`sF83vNus9E+ScF--&+?ZrzYn$Npfn0QnbZj%*x z>ZC7xD^%mo_?%of5Ye(^mEkq*OplmouCgB?tG81IH8z$C+zvdOmhooifI}+F4@Nci z!-Rm$s7oh=fMwVr!zC&g#@g!O-IZj!G|-F~5{us(?6CeYqg2(D2^IANU^k63!rc(J zTzsOYG7?k6J6G_H%pE1UAvOceXe2iTxlW9t9-V`dGG7GoYgajlcZzOZ@poej(XDdg zKQ0pbead$`+;fUha97b2LVj91kS`|vFl|S_+mSv%POX5PJa>kOT)bB**|ZYYh^Han z@jJhNFWr0~Tvs|7&v==#dNN}Fb^dIc+b}c#?<8Nn63?Eimo{xF5`3)k+KPMAV1B(i z*)7WK`)^kaQiN*ZG5<7q)00p+(O$Wqe;~IJx0lOR)cM;QCEJQB5gNUgvZYSQ$Avk? zg&62Njy%srwLZ+rgsT2H2VyDD zM|F{>UwWrZKN+z)$xhF%Rqm0b{F^362Ji#5bxhnvH8s0~B8~`)D17|$hbZFUL)GYZ z7AU<97zjoDn&$J{I7NR+NMy#=WjIQFN7gfCHv)Q2Dl@D`)eng#ueZ^&lQw%u9dM`S z&!N1(s(Lwu{<&S3T8!g8hb&p+ZEJo!(QN3I^LZ+ucQ!#)IAz^B0+U_QU@}~;p)mi} z$@LjzqM#PH_#_ao$Yo0Xeqo9y(S!0t#@mW*Xo7ru1$UY(ad9mIPm?iIOc z`V;a}o=oeD-&j~cT`3OE&idsp;Q&gOVtG8UFB;2wL$r)1o46=zC<4E3YxZ?I#FQYHdF55;5<^eux~ZuR+4vOgR2nM zTj)n-UdupdaN{Y6X3e&`O0JES4(wJIa$mjH+YtvP!!a}DlW*xw9x)Bv z(?vkghAgZmwlfd72`g|6s^~Ou(t~A+o*@Lnq2BV;0t9o%Y7ye( zyPQ7H0rKG98nYAK7%Gd_XO>gji0Gi}- zKdO-lWMwllh&D+@1#9-KQzG3H{(D}IyX@!41HdoQJoMOwDzBrX7j$`S42R)Yx=mXC zn>{CWu5Y~kPVfHS>dEIAedbqjcUKsNN~%J1jNH}Fb3gFddSCljFo;X}@I@4r)_&>n zmILiQJdnps_S3RRTR&auUhZ}iLDlVdn_QPOa<63f^gtA(s{UqmQAQclT^u&jcFyU2 zHI-pEf_7Z^!8+`CP1gGTrpS}>EenVjnP>%p;rCm3Shw$YqN;e+t@fhKf21KE^mkU& z{m(y?igX|!h|d6xf-@K7vXkW=Jy){O!DF3!$t7`{`7d2!yd0Z{`q%J^+1vDKSJc$fek>75GvzNcx^m9Qtly8wNF~6!Q=VUne^5H6_R6k?o?~`lzhpbZTtbV(Z`5g z(xBt2?~CG%3V$|n5Vv-C+o+&vpa8dK23iG(U?gRg$25<_~$Hb=tk26m}g z(ywrCGc=3EOws%?R3IiDHs9ZU#>(2#9b~VMFfNr~MZ_F( zudndCqNiDJPbR7(b{V=l?NE(wRx3<_!)lMC&720u;~*umX0n-x+X zaJgxdz<~@(A8ieo|UtGYyi{ZQVjRTApQqoPEm1P48EsEudv#5rJlo z7V%u`wntp&7))#`5zJ=Z`S;cP{N$!oUN?4t?}$JtFrG#tbpBt`Tuss`qjeVm4*DunU?l1&JrTP z4akn3Z(yrRb$l&XwXeVtjPDNsF41L=nY)zr&gQ!;1QL~ddlP2S)%|WKT_~tjhHOVw z?aKPYwoT-1d#-f2J^#LQrowr0sW=#BQVOiB&8wa4cJoxxc<%8d6Oh=Gmf=#EXO+nM z0vVdd!2trbS5KFOr1kbksbyzphxi7(AXiq^x;LRLA?5aMkTU#a360OM%4fnQ4QdW& z*i+fKMLn8d@qLF4Fa%Zj)0!`B;|9Gzb#!IB6i;2sT*x?UdtvnWO2g$>7|zV+V^Tq| zaEIA`v;UH_M-fQPA}^1xmgo>8iR;ujwwP3kVDMS&$<55N|;@HNK9;i}NH2l=;*xNU(Dc|mkNSpF3df9fbRtBel|l+z%11k@&kmx!Cv zmwm2l7H&@}AS~`%E1hcwAn6>2DUJM7T2s0n%38rG3vUq`)SE}_t$&2- ziz*4MY*KXt?{UByP#Md{R8xc?VvnqH<&6*&)?U5Zn|)ZPyM1UKgNbt|yXS6|_2nYb z;|hkvG9gbt2_jb37>;Si*{DG{@0(4p`UW4P{}ute0~iu@3fzo`Yx!lO0A{?AY+3EJ zD_TBv$}vso*d`G0p%@hQ$8V2mRRu9yw9?z`&*=HrBA6)noa-#mXD!m{_33`698u0};<@BfeT?E;XS z`lD|2E@obF%N<5W=w(r|R0?;)JnEpwTy8swpJ^3dCAVy@bzyII?98MSJsJ}|h@O>- zfkZqnEv?p>e`>zXGX?eTVP_-Om=rmVaaBEX6$wK{ZjeW}6lMYnBb~#O6 zQKQQx!0J+$9;|shP^M2we1#H1o9~M|_+Rum%SXuQ2dk)g$=$R4^S1;2NjRX8Q?EGo#%{*C z7~vxLt9m0rm0Quv_m0gF-PI?crpJ#wU(=*5KYnCV`PH%9rv*FAd~G$x`?gkdXpCEb zgR@2FhJ2A|&jA8vh%%HP^f;S9Go}}j37_5LqPZ-yF?~_-Cc|FEQKL4}cE8=UH6so$* zt0?wR3y!`#ly~*SMWRyyOTBNa+L4o+^3t2qCd3eJfgKA{Fwug5t|PfceWSaVbv*rm z$xFA!k90qJRpsh#^s_zI;E?$BZ9_Fba@(Ge{Gv@NdqYw+BQ}iC-cRjL-*YUi+&wkL zuVJ?nKbLz`g_@cM={O;L{w@Or17ftqkl}Sk0%RE=(aE^z?Q*>EZ}YdArc!yDO1?^X zUG_ZN&mzJTVEw)`5TJMXa|C!P4{%E=rG1|EYPpVTie+5gb6#qCr}ZT;m-)P>TwFe@Zuqy?Yo$G!oVN4uc)QFJplw0v~7IM8AF zaCiDyOC5uD6lW7&9rB(TqCKSV!CE?JT%ozz{9|03#C$)hCTD;CUEn@9`dG1Rt5mN_ z(gJF-qQw&jQAsE|Ps?616SyGEq!P#}mNh$JFp;=e%+$I?+^pf48?R`5bcN!G0 z8HBt-3)mKX1o(aGd`v5@5l7%+r4DX;n5h{X3IWgCHVATE`t4|8)xda3 zg&^itZ6}@vEaqd#3rFNMGF$**Xm09X*jl$O5>wwbRoT|4(0=rd4JBSnTe5IFsvv<| zE8qzr2vs(Q^e`i?HJAARFKukb>ku}5_NNT<^vkC&tU(z)u%TtX*{pGvLJW~y2B}67 zQBlB72(>M;)gN~2{ z7xhh}_}vK6NcJ*1b+SOd=2F||fdn8giXW?Ttmj%CJ6nQeWLD3zA%kHCE}{7^znUdW z024*&ba8&X3sDdC3VON&e~crWy)F1><2IEN0RuTN0NslPImUkX>$PU~hn^qMi1A!b zKym#%WE=$-M0`Cd~I!oql7?rb9eHkc*br9N;Ms`?QK-cb=2CJ zeX$XusS+?9pOGDUE_^FHM-eVR2?EkSyWT^cVeA^%JHz#+GN?V{?9H19j)6rC6havp zwJd3l#p*0&Gp`yDMj0TCTTxp*vX{a3wzjo>C>_%z`y1EnvAe+9y7n`& zoqNgwE($3-R!Pe>xO|CmHps}BUcaejlo_EGDxwg7;tS-Lxcve2%@C|rSwE=P$`n6z z;HgPvcL%%SSNTWq0iy>Aua~Grsthe1Py#;0kD+XzMv;%6rO7!NTWxK}=lvt2xx!u5 z2!;j4sy`EIP9q{2rI z2FJMBxC@|Se#(7(XxLRFhaPK--cw^an$=toN|Fu3ze$&m&N*t0*_V7M+tM$koXCBm zYzxdMD2ozF>lt9z0QSKbhdEu8mpKBgfg>G=$$g@z(fMrCKM{2aiaH@FjewhgY_J>a zd_WI|Y|+x*LrBGtqzfA5W^NaYHzs~P80DXZ_<$gRXL+wOkVP+w+!?Sc}x~{ zD|!ECG@yZLpXCgE`4gx>jCPg(4eG?T$9vBeWh^wcJQd<2nr-OpQ`%55yL0SSO0JAN zN^04U7CcB)INXfEX*mtt0ozKk-%OLYDiR=efL5f4@dJeBf}*s~ZQgEYdx1M@K<7uM zRy!k;mSqfcj;hQf!=bcVKJ$bkE!rj}E(;8PJhcb_9*-?%WiPKLt(3ouvynX1o^@5y@s4JjnzwjgKo89G9Ox{^=r!WB?&W7i-h zqXD<0Bmod_*fL#v9vQ48c?k*D1bcC@-4n`wc`M7u08?kf(RQRPAZ1tiZW_?YbP z1RJ}-hnjL@*xv%zf``@yg^P*z=D{C^2DoMt%hu>N>jj0{c*dbTM)w8M9C@Kn4Q)9+ zXKKyTjV&?pM|!V}rA)rwYDV92cJ>slm1}8AYic&b=4#0HjWDy=R;HY~d!wog_~{FA zHI%C5&B65PS}0xR@4J|Z+agOt*92vfXVl@7fl*6XwnGln7VG^n0=3-C9`568tr*rZuRX+-L>D*v;c&-*==`a z$My^)n$J~IE01Ugf9NRkfUq*OOZ0krNrS~f#9|dsdL21g2BP-WZ~ckM2YN361EzaU zX>EtP8H2BFO_s}P?aUpeBazTy-6uBuea>M1$}ZabX@2E z4hhjm^c}))1pdh{m6I=rlyC1RWpL8KCAyt?+sGWreN%+^%lj>R8L`CYKNCJL6S5qU zGXN03h|kk-7!KI=Fsf>scm)oEk6xQvdC+BpHrc>6#2PEOU_5^xOay22P?>gS5+c~> z-m6!|7Xw|6lUjTSg;UgSmUB?&ni}19M_UhV`cpbauZhw@WDh_zC8xY+c%BO#L-&xq zsFTRy6L`HeurWRfmQ?dKi=xK*h)_89EDgtlV*Psz5oA35Hz8`|#j97UBFRe)z48U8 z7yd=NLXJ%Swn|eF`cjBQ=pziAKT&jlMhnKW8-t`WBsqT3Z>c%jNMOk7>oSv&oWuf( z8yoW-HG71W4xJ^ts4omV7Sfx|wWXgVUt&r1lE#U(@Pq@XC%evn>0gtp68NDE{BsbQ zo0IIEK|$ZpyDkBw7{E94{snWd+ok|(RbfN4McJ&$aSDzD@ly|r$+Rr7WVd0K1jKFG zJ!|dw!5LG$Z^hq)#+LrtUadz`bkO7J9UoI_yHDpC3}GV`e;6Zpz;z1JVdQ>@4kBZG zS$3d4z}n4L7gKa^uPU8hyOh@Hh%}r^QJ_r3%S#F-)l1-jcHjM*h1DA|1g%!+o<1Re z*H(R6mX`0nOST;4vin~e6tIg_#M#)B(Y=Zr6a$HgnH7iwt!&Dy(**$l2No5 z$YPmVD599}ze1~U;m|D78d#n3n8PZ;I!y zTj#eUtzej9n3GN?by)`L!%s1PV^9fAGTpJcfBha;_(4M2fIU^3 z0Cli31due?u7V(OP2=1`(Of)XEn&2{*Cc~p?m~a!6I$cdFY?$!*?VcJ=d+Ak#q24+ zuOeonGB-4|1UlpV>+-<8_LFR}%uEtY@m7E+tw!8LM0ZxL#{1u+oFnV& z4v}7veQpl0gk|fxw8!vG?qO*fyi8GjDV=mf^H{BJQ0>4C-at_N(5vpWPGjx(B7yZC z);G`Zh-e;^R^GO*4Ts6wrH~;&D0NeC+<< zw_&e`xAG5MBrB$HqK5p;>j_>PmZhDEXBu{u^e5}-!*zWnF^-WYSu~oqQ42b-1j-Lr zU1ViBcQUzngta_O$L8w`<-<+>AEv%MpvLrl|4oZAT5OX_WN1SvN{gZlA#ECKB3asK zQPIAfhRISg6|Fi&WJ%gf`!Q*g3PsviHPWWEY5QHzd-D1I&VMta=e+Op+|PYq_jO(O z8h`AJ-UP=^J{? z;Egot{ICYhZzRf#cP~$Rb@Ld@AyZ5BC&)+wSj*Ybc}X9B`%b9RvU5jFJZrJv(&~Tz z0V^-@=r(bCd6z_XweB(xu)=g6rgfuZ6AY>}@U7e8!sTDS5c+8TK)Dkk_b_(kH91Qb z1gnVlYcm_v#3l>^_(vtmd#77IFu#JMhg8`V=v%+#9>RS4&9D0)5xJ+x+_as&w4|gW zEA5=S-;lzl@jxNgtm)9aq|eK%kj?LM86nrx3_RVSFqVqbGNgf<;i)1WQmJFJmHXYI znbPbg!}W2Dqk)^eHsG7(I!e)7s0hMC2Q3&=R*%$n)=lLCW&0?;5VDlF!5Ojl%&-g=pp(^v2jJglobBd;2gAE2E0Mz`-h6oPgL zqzx{T^K00BF}kSJ_8voDj9RPSf+%-{O_!Gx_+rr0F%drXA|E9~#W3fW(O%CgZp#}T z0cAHGLA-F)UkQom#Y{#~Go?bB`D{2DE%UJf!&lnz9{|~0FnDtUVCd`r{2mRqlbS|X z8tv)-k<$D0lDJoue@)j5|N3dt+QZF5{QAqAgj`Bd4aKp>s%mN<5wNz^2G&Aq#SU0F zRXNxObaF-pmoqpbjkjHI?-CV>uIV;dPE%d|=N~$Bhj(;_41yi%0V5Hp8LA&w=9N>% zBuyYu6|cEKLfe|etbl8Z7Ju!d2u$G3HDq@>Djw&5Am36^{edV3RE z`>ILq*p3Rp7A?hd8b5fX|5)wuRR^yA)q7q{8$U&vEyjTSE}?R*=(`dZPLFv0BmY!eLyETt}~ zG=>s1iTn&@a1h|LN+Z}O1g#;2U@8u8IS5-D|8x;yE{<*-<#18Yi&B=H&kguQdovhf z>JbDK4_!jAexoKZj^4b;VVt&Km=w0sM1a!7u3Z}UK20b7aLdA1C~D#aITVU&4m|(% zspr=pg6yo23zM-F)5izP`j;R6*$v0+db%4v?lPy*acSQuSNZwJj~oQk_(bIg)tGgT zXevKt>OeIUy~GRXp<;YUr}T6DZ#Zc0#gWKz_WAF*12*|eUNoZL_YLgDv__;ZAjnju zD(|1Rwf|5Jn-nUHk4P!f#-2%`nw{>-EvZb|HCM`bEGRsR3vio)BZmq$sg8SfGZ+i2 zTS+1VgKx$3t=}K96%02&^c5`b4tM4H_UQ7<`A^pO5w0v|gCD`J8*2ugqxJ4yyh_qG zh!A&hupam~yc?|=(kHVNniF>Del~q!;jp@JU@M|=!wUD7#q)Pa8)FtT{t}Lkei*{Q z14t)vWs!^*Zd2SchBg1AwmT1G9W`C>Mr7$DyZEP@bGJ^1CruG=v2hDmruH0jN_$zd z88xov96TCI64{~8!Nf0wT`o|I7h^J5kU?lS0)mW8K2p6=rWO?e-GGF4uZ@y1>6!hl zgViO@>qegCV*`WLCknZG&JW1@-|bgR{J3Q z;I&n|c0a>~@7Tt`xV3nuoQPQGY6Q)wu}7+j{}lWa2j^z)9pXD!eo|QdU=@Hq_uwck zppVEH6Tdt6>eVCX;pY*X+q>g_ZLL}OuvE2?aTlyTq4Fu2 zMnml#;m5sapGV!ZMfv{v-{zpOiNCdsOxng4$v??ixE;b4bl+@au_5)$N1P8;^IQQh z?etK%OQX58qH-`#1t*tz63wD~QlbS}GjW+yu>)Kwjrznx~Vf8Og&LnUR9}f_i z&rY|fshYBP_W;LE%Ot2?P3-wZ7}c9{1skw|Dz0y;+kVv&Wz!lY}Zgn^W==WU(YGXCUHZMOr^PtqE$1@of%u$k-`;>|MEgIm-?5 z_mfpYuhz2H?1D;9)7$7`ue-T9cQL1|$xq`esjyoE)fKwjulFo zUOuh{SULBY5faQkoTUjgYUU2zb$?sC&mDEwu_qvPGOKG%{Z+G??lg?@-^xE`LPTrW z@~hr~zgCtIk2d;H)GIk&uvkr=yF+PgB2(9}o6j;i`$E}}urtN#1zw}|s@c6;#rEU8 z5NJ84c;C}&)OR%5Gz+%&-GF7_c6qT0&59<6rYGBiw-H0)v<-}|9@OO)y>d_$Zf^8O zq#_SfQx@_k)TBJUR{xDQgV{&!sJV>{p$*gE+!4x!m+%e_6W+|zCBnVmqFyE9dv$_W zgT#!qpj>kYxFmnmvTR&-;OgAH4Qc}O8gC~8ia$ZP^j6@Z-_yNn02(|+8 z_RAT-NM%yTboRc&y|9(;m+XSz=V`B}@Dk*nWH`FwN6<~SLwkep@JWDVd z)a^GXYf1K~sE>+1ZY{KiD%a1DN~}Z`fHJlq4Yk0Oi7p>0UBF^t3&ocnYxxxP;sfFH z3HKL-zHVJm3Klw!%|lHpIP&Wo%zh$#8doL;v=N-dEHH9AR9$teyy^}z6pex*KY7i0L^=rh_(&h09H%0? zWk#Sd!b`Bp@ZwChwm@(7(FwzrcWs(L)!Q6omy1=+T_(ueHx8)zTvwHP4w}=q z;?81CFw5?Umn8t+k4T%&d^(fIde4-ccIO&Y5xL0mf^gNibsvD~b?v1T&HY=8(G)4x zM9}OQfa_O|Ylr2K<_W^!b9)@+GaH?!W_<2^gW#5?AJP)LPRU=ASkUWQskggRD}R== zv*P-j(#S0~nl;5Q{uO#)*v)-j)o~!*`h4k88^!U0`C(J{!VcHDpC{j#(K0mBMcmyJ zqE7u=PDBeXP@si5Y*vxaT43gQzNC}&2UTD`GUDOlEj6&Q5}JF}tsZBF9GajIflvf_ zlsVT9@q94^A*e)=8>J3VR8G)YGQ=Li-KtZt5<{k^jN zwWg*v)55_CZO+FPss>K()+f1`B2~i=GcAT&MqB?&I4EeBvOZ_hX~RI`#xw=Vl(8PU zX6JcZ(vGbRZfF7CQ{61r5N2>%lKmTYJpR{+#hT7?_ZOm z`>vv{%)M|H2bN*NWLwrVhK)Y=+GcgTvM2)Vb0cmIj`FFOr??Me49v(pVx~RD0 z%;+*pl+=a|<)43ZO@4vn-MZMuc3>~WrcM3TkJw|1cvAyzkxSJkHaa|cVueTy6av8( z3Lpi!`TRnezO%dte-EC8T824>h4w+6&7EwqIiz;fuOjvwE{fU9{p9`-*zlk05UHEJ zD*6RhC4BTRTbIg8`#yGZOV7f3`;}t(NIl4>)i5dw)Ba@mo0<7d&H1p2B>CH+JEFqV z+Y?}#t=0MjAtoau2j3cbWXT>oAV2^h^bG>Y^Q;E9y3gO5?R1i$n_h}f~{_2~1wg}WGWRnglc z8cph$;ej~QcpSH48r;nsj7mNih4T*d*%;bI#Fr~%733iJ$)d{Y>jT(nuF?(OGqb|$ zQz;n5(ZS*^X-g%Sltk^8HPwcn^=%veeH?=-HM1keo{QVrt2Dsuzs%XKQcFq{NG^l} z-rx>w&iIhM5E&&z4PHD^P!N=;j8Lo#NXwjp*DS5(TvZ7%{l z2SS1`-ypEie!M=gFq8DH&R(+F+11qrXik9;7gCi6U-tZgoyupV6m&o71w(>XQszUB zL@VJcAR#G4Ag8pRDj!Xi*)*}H)0M-3#{9!}$GRu0Y?9?Qmh?V2FAng$&ekX+JmHO% z`fwUizD*X4SyC%k<}SWGHXK)}YT@ugIL3-Td=lkE{{qr8@i5NkUg4gN5^iDH;T-Pt)WL^3~4sw~gx-(8?Eq2Vg; zd2TsFEQ8TxH9gVt{#?aiC%HZRU-n!%KsxWx1Z$v#@9iDMc0dV_5tnRak{XZg@3;Lt z{o!xCYdOKtv-aN}lE;aj@L8j{D8m)T1splgYz;ndtBc;GLd3^!dK=j-ZpvKI#<=wb zA>FJbB|9@raV2f}k^VQGkZC)}p{i=aNw)u3(hCiXVX<4IbED5FNK!nHdT;EDpaMK z@<0Tmwm|invn_Jg=@x(UwU-@%H$x?_-;KuQEs2^~XAu|4H}o2WRGy0qN8}!drF0w; z1)Tp`_&$nerYq#9ZhcUgb(K4WiW%B)*hny_TPa$-BWx}tVN0Z>IhVd2b7{aIk$jZui#@e_u(O$LstbYf#1%Kc-WzzsF_D89tdg-7nND2rEpUO zqf(q<_~gS|n4wZjK(X(S)nku&F8;O9DfTceGeod;@_uWICbeVU%!c6To45F9LteLs z(%n;d@efVu_74n@lk;U%!XLy6`junHYPy%A$1xAox=GBZ7}6cdxzyE zp@*q|Bzgl;~+DjL9J5O>PI0@o&Y90L>=pR)Pf4WCLsTq7TKPX8 zu9$OAmowt`omI?^?uzzMv~PU&+jp#2^8n;`M&|aDi4Y6GmPH}Y(|!Jur%zA6-%fUH zYhCul>EY8?eA7qx!lR;4wqS7exbf5X&GK)f`k7aLFVysrGo(A+d=Bk!xM%lm!<2%dOeQr+LP#aE(gtnN%zQL zQ94m~;XN$(pI#)|b(7xMiE;kBcV^`hIVK6_Us6U^Sg!AW)$3am{L(o1>h}bZo4yYA zwgZ>;cDBvhw{&M(nI5Md3f5R{z5TkKLxf^H1vu|~@k;tnE`YYoMw5$t?iJ7dw+9Fq z-`2v!gw|Pwbbt*+b=o-3eC+aCELa}tsW$TwPMB&peLxw-L+W53q4cf?f($kjzAE_~ zyh&D=T#chyjxE5%@<LkvowQZesy7?94kGGI+>|2(JS4%n$GUanScfYg4=6@8^m0uX_v>UkNGE)=q zC)EW3kyHsVym}csA#P?0JjvW^n|=GiWVkT6Tdl)rz2Be6R7e((p0}Y-Y3EZPd!wc+ zp=LXutj{Rqq>2e$A}gf9Yw;*Yia@@wrJ0FpZ1(z4>5_q~tE@Isj=a38;HKsc2r#_l z{&C+KPah^U=_#Q=ap%()2JY{A=Z`41VOg=F_?xfSga&h5KAg5PfBNb{9=mTUZ=TR)xQ>ugcTNq=4S>c39KISwg#~EL@HvG@NNS|HFl!$#{~e2nDI@u! zz*C}^YM8YDB`ieW;xL;Si-F1bDjnF09$Z!A^ZMFgXZ zmkQssw!O$j>FP*mpLRTN6aOKw%j0(HluG5bGP!CF-6FA>kE|iVB+0yA$a$|g6!H@V z)W@J;?1y7^Rn4a&5o5=%X;0!OP!34_JT!$@Fj_D?`Xn%LL^Ka*5fPX&8v3-!mCZ`c zNK2FP(;3Z(3BZw5f$Ef{5hW_NFQm@+aJ8+1|GdX*e>weaS`#6ikZur^DTXgW6`j}b zSVR*+T8unJJvIJW-I}wG(iq(%hepKy*C|uM-tD(AbMdd$Y>ud|&`n?1zw25pORqR# z%@t?$NT?Su*;B-qV4sTLlXIGwyB1p<_Oai_>z+AgB&#>z+Jwh} zha;|cm2B>@#Dw$;(-He+uAlDnQX0c08>vvUQ{T&iWlgaH)(a#A_xB>i5_g0oI36g5 zd?-{hGkpD}jNMy-^;P-%U6oYgcQ>;!qM+SP&U;&fEw&Rx^mHC zq9?4a9Ix!}Ks#U|;*esaSPpeJZp^z!V|tGkIO(-_*_-ys)7SlzGb;VR_^C0(8a~wr zIW;s(Or)mzKuR-*G8L<7Yzu7rXJ<*re>i<(syiwFc6BKe z8k>*VUqrXkRg^=qRxAtj(Qy2!6%$czje9j0*||v56(?e^kXvw6^5wkhC0st%1K-JY z8oX;GoHW@jANhO8S%jf(lm8vb)#mXN3u3b&(ynP2{E`W)Wa z4cawyi@Ivf18ns^ns z3?9DmZ}WbV1H&#EsDNy=hWC5YM04L$Z{s(=oMR;k5UeiqHzu>`E~|_Se60Sv*mV|9 z5l0A0gWgWOnt}@+7guWqf?V?P%bPOd(E?_NP=;Q-Cd2y)dEsZs1u{%Lnjr{N0{cOeDeQBkM4gq=DKBqlw@>Nbw z&K-f;fuGOU;=*|5LBS(yb;BK*7bg?3#SYlo*>x6<+`%qDmK@ojMnc12(wCa%lz`xu z_wXJIKUe92q?lwkEt8UMy^tC_+Pl%j<0$LBf0YCFkw_DY zHF37mfRec7#_@tU2)3P>k$NO~BVu?BslOGCNZ6wj2xp`qX(9lmSX}XVB58Fr_m?r`O8ME|kNZ&MyzKdNGaMP`akY zkKiqQ{T?Rk)X_6AUF7Vq$p@C*=LvEV0r$sq!+A?VpU$?Ws~|bHut0e4xxGMK$*J2! zZn*F$XctLNvqMhXSF);!lk%!6Y}azPkdF#RUY@L`TS#U+ucd^BEtfMeNI)??le@RA zEHz;zIbLD^n30UWkU?bh$RYp#68w&Xy2>1}k(Gvh_&uzuw!^aO4ebzw#S{(VweJ&f|ZATCY6burlUzo9?x| zTEW2Ay^FjkRwubeP4AI*$V9zx%fl~kJ3EAslC9c9DXG_Ux4yHKhF_<8$BT+!De|xc zBZIqlp$-nXCL}uct8Q6OeaOYFsR+|2?nb}1v>bLNr7%j3EH~$kW6qgq|MiZJiu3Ly z)ek7R7tT7CYT8Bn9bujE>o^LNXT)vH!_?=oOIMJ;7kgQmn0M{AafF+3ZVG9uFV<3M zZ;V~(7ahSCkw9g3`?eXt7rSrwf%VqU7^A@!p6BCOnYDXc0M+Yq+hD6v$Uegdx4uP3 zK`qe8*Kf+@w%+||9^rmW z9V23cQLh>&eH=<`jM%>3i=>G3uSXB{p>)_4IxlCPnIIU37m&D9|NiL8cyn>QdGX_p z|5{;4;6DGjGk7)|=IJRaXRa>aFuL)Bh0$xx_foB}vakRn%|?^&bZf_N`LOyXSMxW+5hE&Kv1H0o7IjD#T>L|xkfs}}nFC-1 zygduk4Bh8D{+lGr9BUABXGm>8x}TgCi`_XmqyN15r&Y#aCog}?KBL?9!Z(R%zWF36 zE1g?xKNn7Jz*lQm2_e4yyexIJvBzxkomL6(>#o{Z;(Z8aeJe@fT-x<90Chk9+G73t zrCmvJSM_{HD?ubJK5%GFY+yx^U&S%jpWzr~HD+ zKaS+{pt$T^5+B@cj*-*LSNK?kM;ZSE5eEL%e2*Dv%;%mH__UU7Ra?0?=)!+4qSMm_ zmLUx_X(8wk+b*j%L1WYx(oeXk~8x(c?jLtW1Dl=beHYBXeuG zsPQboIEbtXH$fQv*ZI()h{l<(cbmo}sfaV}C+|b3E~B$5)olIUVUdi#NZY~kIbp;( zU|Ih&fA~6(_g)|5;8hs}i@<@@cm$2l_N`$*TGCz8;{byccY(}h`nss@N!jn5v_^4| zFg2~5Go>(ndTGbiug*gwU4BkHtLiSOU@i{&7uUa!n)r1mkMjs!?VdnNla+MvYLTBF z#@Fgpy9ZzXyZuGeyr1XXz>$sV?9U&xAm*L2277j;mPDx2}D*bKvm_<>0> zF8$5W>+Clba>%)zM*4x^SZ|jjp_(!+y9y>v)`a?p0;`cDQ%%n+bo3Z#gq^)$=~#Nw zdti%203+fVe>nuqJbRG1j_=eDm>(2Jt`b;XBGlp5R#;W(XW*f0qQ`6ytr4Kct7ro2 zSaY?i)TvK*Pl>>nhS_l3RG6l*8L)OmTc=nPzINf?aKYr7L-O_p1(uaLlEMeSMe_{E zh?wey-vUoE0>0AMFvH>uDqCK!Z7P@G`Ji9h>@3TOgFU-}XDRE;}@I zsQVmGl3||AJ7?4(|Nh46lE2Z{1osaMQ=e}tsf8V4z9Yjvq7-vpeAO5GMyr}diVX{8 z`aC6h-m0fZYoqoP7oNEuqOmc+;^B_O9e7rnX8_%}g3DRZBzA#eRo7U*#Z|ub`*>;R zE?x30sb|?alah2JL-#1=;?-rj;?ysT-^r6b?fK1x3wx)Qx?&A50;C&g}!bNUPfu|+V!;OWP^8~)%$sZc&3rV*rACZ%f@Ngberqe685e8{C=r; zRi7RcB@R1W9c|Lzq~dYjL5SUw{Agw*X(0vRWGT>@vzP&b2MBL(O=Q0R_$2h5uu50G z$~E-{?H%@I-Q<-QNT-+b63)(<4kP`40B)SlD|kiDL)hCiS>Fz}Ix^f7wxHF#wCKB`km6?zIR|Ti5)1>n`io8#?=+@~Qgxx#&q_OWjoEh5GDi*!3lH977#<;POtMyWo=(hO6RXC<^i#h&>*u zZb+T8PEA-8V(1kCO=yh3|DHThG9)fN;EnRXg`blVE~xznh_VY!+yyGo(DJIMX0wLc z?0YTuP%fv7XB3B%xMik;WxZb&3ML`kU@4}509o)>|5^HqB-FMnKYy7e#@{f7Vv;PD zm0D~T_6^Ln6~?%VL2T}}U_;4$z`%6AU6aBv=jPqk9Z zm{}&&HRN#FKv_k=d@>lFG|3rB0^UBSUAu@wbnot=z+$eS|(%8Ac>lFE|u9cfM z@s0m|v%eHl$hnJg-_U5_El$uo(;e%k{AX=cG?_B!XPrf*wS@!!w^uP$(!f6SC z^@gF-_S$%+?*>ii&=J!+`t_#A3on|p53F~#u(JpQi`h+@-8KRiZsUETRK&)rrR#om zH*O%H%r!JgbPmKXlqn?XEHea)^$HU?JFsw6K5gQ6B1nEKFVb}VTHe^Sq2k)g>7g@x zgVx+TRvRNxrMZfJ!*h~)YOn>|N*&@yB#CCJ<6_Ror(C?{jtp$XbH(6$r);FQno)BF zrKH0}2>Ic~t;tDTj0`{JSjwxZNo|P#iWedbv{}Zs3wNqXA{Fy)y>`$&r&qgHnXHH; z+F7z%61ZI4yxjiGCq{mL8qFvW=lbBCuIC(v?&5m(1vfk9ol~|u6gR$SR*E&Ko3fAB zfg^%hcX_ctb?L(Urk{}JN~y~`!Fwt=f_dmV?&gq}>`%|iTifSE1Zb#fU{QzM%JQ0w zUT5#w7}R36-Y5TJ-2Bc`SydVFsiE@7At$*I4wmCT;yZD?3gKXRzH+iuJWDy7wOO!b z3T{$IAiU*SJ1;rLBW3gd=!v}=<`lh{B z`39mnh&3p*yX?OEk`sQs@_ScMB9Gxt0R!J+F4&Yf@4jwQg*-o^EnOvNepnV3*WA1zSmW5LmARW#%h)o$ZcNS=^Y9WQmg#w9 zXn-#0z`>J~Fs!O4iWmA~($vZhyF66vU~o^XiNhYU4;mUGPlC!%SCf6cj>B) zJ&N7`R*&PIo8(Y2R;vV)K21JX3}|RSj(Y)kWb(MmZs@^+i%)Grqu1^7g}rMB7O!*8eNXS#m(YH;6T(H5-sluLIHO&hwx&9gkvB*NKHTgG3qZkJ_Q*gCo7)i%le2Q#rq?3 zA?wf~k*1li;sG{Zi%6;$mmqDe|9^?Wv*$K@Er4bcDS?78zpR%S`-}~v_Pv{|YA1tk zSZ7f?Y#>Zuzk5ln(|77RXL}NdBF?ZIKY{1ReKT`qTTI*T*n7wCMx6snhnAj4v`;-t z#Y5xv>ZGye1et}}2fU2uQ|S96VyuwqB<&9D1oOJLor6(V#}*T4QQc)%`B!i?1#IOviQ7X zzJ+S8&i3e&8_y*M)Qn11YEGNih4JD}28V775Ro8)h#13JD7_jx{mr!wqu|KNIpz+< zQaCK!d`vAqYVZWD{%&^kd*N+s$iw(DE=LG#s0cH;->8-dlBv6_&^lmZbD;w+=>{~+DK-U9+0Xk<0Uy&E_{?Eo0{=Q$`2EpKZJ7L$L zHNn2zOm`X8dnV?jr=#O!an8pc?dTn*-&#mZVYpqGQs*Yt2x-dKeusbaWQ9>~nE06F z{9{S1C9JgRP}mckc3t?XKvsdor9r#i8EO&nxL0xdEi6bS05m6Jh}t$CMPqU7?Yi{G z_ix9xd;fS0umJezzr-NsP3iD)fFEP3k*&4?Z7^} z&>QqL@nhH*+3VbWxrN1k?O~kMN8qp8n*q0iDFB0ud&`NzCK7K|^g3F@C%n#&w(Zos zSGRdFgk8LSdP`|EQM~MJ=c}~2j$h0>0;f#iV&DrvujvroPen&cd2qr@9hSS5aQZ?{ z`x8BWY|~a0B(pIe-(coiGqa*)ZDp1IS;aI}Y2j@C=9$7y_a@Y_xq=*L94aTf_q(}2 z+lW0?4hqTQ%)xjg%TnT(C@uxI)>qWs$64JRRK=J*3=A ztv+_D#$4~}>ZXZ^^zBo(hkMf8NI{v?aGddD0}bc8#gWDN9HBybpcXDbquMSGz}<&fBWs@>nUX z8*kjZ4UQ=g^ik?N!5NR>*VC8A&F!JVPE2(79*AFB4gMl%{ckPvX3oPuNk*)ZE&!?7 z{_o@a!Q{J_VC4vm$JL77^Q~f4DL@41eQs9SN_&EsenP)2 zrKVZy)?xSEb9E~&DjZkR-3A2?39-CL-SJ$Zk|-WolV@+3W;W?t*Srs#zl5dG4!?CH zrT6{V34yTZ-LVkQDGV^Wc=@0B{zw~d93yB}!n5aPjZ=T&I2;+M{M_F^XXXyyRPZIi zhr#Vi@LC|qBv7>uCLDa2r^DBf!wys~%i`fcrKX0wsv*-3*Yl5k*ry&bP$n$^neTX-{7ja8C3nt zeXTjjBP>3k9rP(my#yz}1hiLN_E;^-KhWluvls@gC)|v)8AXMn|&RoXw4-WQ` zNqnxetnNpjDL7WoH&)T_=U4gUsHSZT*1E6Qm6+IER-1?|?y`m?H3x#_=<+=aqmK@Cc=+x;1^0qYMYM}OT7I>p*V~UC{x};hr%Zf+fS~Fdpd7Ckjx!=1o!JeC>Lli zYVv*Hz>}WZaOdk-C_!6(HT?tnBlw_BCeA)`+9!)~>0>9$G5Qu6!7|e|KleRm3O&3l z3W{gz^@-8G!_N~pnqBfdp!P5WecmDO>BQOKo1a)h_a9GJotn(p==RwaS}D>!T}KT* zfbb0>6yC1F{eFZDKtqXR+oTuDa47m@8K(&tvwG)3+=DN9ZDo#<-M?`hNNs3X+G1D9 zo)}C~H637xu{+VtCr`Z2Y)C{oS0M*N%IDwucum(#BO3DBZr!T3VlNTw4RWm%;FrK; zTmO3Vtt*WbTJsY-dgk|Gn6?(2X=Rpftl1WTr@ zy*&k+zswTw_9MLZ`-Fo9ZixSNd<6;KI^JLX34|PZQLOS;h+V0{vqzhbeRXAW?SR`} z4rr7}4(=Du)1mZE^%$FFFv#@|LR$ZW%_=ntH_TNi&Z$2V3*`7j-m-yL#sWehnk59H z&!mEyf<;Yi#^HF`NK$~ah*gpD50Nb@Zgg+FbwLgi+MFCaJV8`KYE1;P=Z!D?8r*5J z-fzAy72{)Vm+;}a%l<~wKix+Lzigl^gJg7cZ4>y=Y>!cG*+w*VrZVU5ZvK}0|b+tzZI!8z2amd)MFNhVV_K;uAYx`A2O*II==Y{BKR5Y{ng5|(p z5Qn9t;zGfL(igvBj=MWZ+*wjtZXQE2zADO4u{tIp-AVafNpeN42W4Pe?(lGA08$X@iZN9hX}u6u`|rsy8^T}Cl5iZE+i6Pwyw z>`d}%L2_0($j&+tTc9;p6y%F%;Ub8|{3BO>OH#?&ubS0oFN}G4X6F2+7cPtU5BH6N zv|B*9a_BK-Wg+GA=yuKj?r(cvW2?)CJ4L^paM=v%25Eqj>-Dabd!h+pN2eXLLGE`- zR(p4@{yf&vr{2t$X)vNy?3#Q9s)=?#+H`Oo5endp2^Vp98$Y#Bh;8a)-wD|T-T9{< zSOuy!AU$*WDHRr^Z=nwg339XpJbUIt`>#|EhJ^Tyi72iLQoGuhH_zU}aB4-@Z%YiS z+Fq`B@|p;}|6Z;$CAh%9YHWr@0nTM%NK*hEUxviwG?cFIymDumu)vLFMRBCa= z{PTeORinF0t!4&Ce@Kl z*CnMV7!^*N!OWWR18_QC+I6_6FAB;|@N(quS%oGPA6f<%puFF?sli7yd-WTyd8+T9 zov!O$iI%6!HUG-*1D81zjXO3{^LNP5!yNG2CH;4gowh%H3|9H7?i#*Sby|AU9qAiC zA6?8VOxEz+$UX1U@t<`3bCGoC4@@TY1Jil6^$V7&3XASzb|an@B>y-DYw_>?+r_Br z?wPFK*UWdNUFN%~@!+7&$b&r5A{~I8&f`srXVvP5?G<%?utQ)iHMNH?hw7#2ZCDXw z0qI3a;h3VoWcX^*tJUIXcb0xyl(g|N%m-y#Ebf_a_h7S&Lne^(77Lg4ap!5$Kjx5} z%lX;nVTif8$i9F6c;NHUPf`d$+*!?<1E8*I`{F#k6%uH8CyRTL4Ce74K-Eq&-vqe= zX(6@SpG-vs4yg8BzwZ=FE}@#f0l#kLp0#T1)!hb_Z(RSk$8G)n zho865(Sq#!e&lsJDTT;xXN7tj+1r7bc2z~tx;i2Iu{4+Mqs(MpVQI2Nf z&nxJEtVrC99kHB%d?PKCGMyy?CRTD+C#P2v2k5N9!Vz~g8A1A-dSBK`3OJ>#QQbXC zN|4o3O9A^4|9{+zm>kf?N3A*#A!(lZ@dw7@luMN5UHcUIcA2jX9IE!5*+^v`Q+R)S z0kL1z3_f%Sr~>#=zbvh0*rREB9&7~ii8)2%v5*Xy?#9;kqSZ%G@s0v|YZbm`3|4AA z?IwU$tsBmuKis8Z4~w**)V8*Z0fx=8^rEa{(GoG73Z-sz3aackoU{LV6_$8kT1rV?CBtTyvzK+S-jIVyKb)R35HVK(b-8 z_i7U!TC{y-$JL8uwLlT!Mx8-7(r9%hK}pa(o30hzRV1c>Au@A>^I$gTkU_|?Gy=TT zh_pIYd6si_{8D&SU5?akJs)u{PtYE}D`aZY64L*F)Cn^zq3P^d&H#Xo+JTFX{K)k6 zdHI~CF2j592kzz;4Ngeu< zLcX`Zp|5tu#D!_NIaoH@OkTR!e^dDrG=;#r~ed@9qYXyl;)O-s+%oTEK+%E#;g zNI^okdbmxy)!8%4&%B;fA@sF*YJ`gTL}Q>#hBG9b?4?+$#2c^R(A#r$K4!Dx$jKaH z#inNK&5VBR=iaB;*_QrTy4PmUS9GI6VInVyi2Rcg(dl#6@Yez=n4XY@yS`#<8kmJ% z(7iH_B|8?;Hn-IN$R1pYw#t_C=z&US>Fo6txJkmNF#g*yCvW>n_ViZDRECu2uE&4n zD!%0H3;|swj;XtlXdN<`r8K1xXgqjG`*`Ntr7194f*xMK%j6|=@CGDoyaf7w#=KRQ za*vGt;h?;aAG%(bkdCA;0sfu)BKS$_aP%xEO9rHMFu4|`rOjaE00n;rNy!51%&lzz z=11T71DgeSLVsA-=xU~c`KK4zJp)*%UC!*Z`UG*`OXI=1e>*kvdcWJ2Rco2ze-TKe%CD!zu^ z&`0SR!{8JhGB2>a)nU}f74z+fyZ7}DPRtn~pL3t;zpzIT2pffzg}gqJ0=mM~7NU(SeB@*#IJi1K-%PoL5aDWW*PCBjma-I#Zq?rzd6 zqvVS*|AE%G#X&e+HrU+E`hfh)q`0-!_NVJ#_n1488etj{4B{ zp2X8#T-hmTx;T)gu~kZOu+ZV@5q^X58}-d4vvH6nWKU%GZgl7AxOs9jC6C-}y18kqD!3`ou*u>qf@#yHDaG;P5j!~VwqgOk=SH}^z6ljdCt zGP1Je?e7UOfCkT_@l0;nUKl_8It54G1_NT?*h4lI8I+KjDIG842(Z}VHu(2wMNUk8 zq{Bd%huGIipDU+`H(Y@k2?9y7mC4+M_a#(fc~MUA(fQqmn3wq)#ZLIgkC|u9n>W6z1hn3IHV^#U@c0P>+Mzl(?i`Sf(e(yw*n0D-L6{l&-!IONX33bk3 z*nqrAa~dI`QyfTd$irIjm!?y;=bX@i5>i&nTn$nW+3pch6-hq(+NLDctyfrAek_LJp@fwi5xn1$EVpL9^l({u zo%Bq>_u-5nqv|?xmQka6Bl89e1?811GzcFt?BF4R16yR_Ei{-RHlEcNMf=OLpA|z2 z(#j%9r5Im;<;U~XXoc9$y5>_!;>9p7?7iqtYUmGzTAr=zFuE1|b)5E;^wjeXNmR_s zo~#KX^;k&KV9>G6uZk#I1$#i)W;W_utI{n3#t~~Ete)F6KG>hU8k$dS=0+&17##N2 zk}!jmpkX0@1{iYg0zFvBJj?A^_ImbId`a^{S zz86soyG^5zWe_XAW$9Snel~-eWtZyCqd;zs)7Q~&VcWDr+!~jyu#}n!d$KKZlPY-# zLXd$%?;sg>T?KYUPF!zYnr2XY{fwTi->iwSSK;+IKRC*)ll z3var%!nHZFdr3ucX8zyHM|wC}2Fm*{l#{PGC~9v#Qk=GqKZ4RoPD@#@kUH?cZR*=6 z)HME!W!9wIhD@RjUVmO+ubjTa&y`*}VRgyc_R7F2kIh;47LMmY=219<8S4;UZ(Xu` zMEFmRo@eipvaSzWT{b6|>77^KGriQTV-n=>5wh@4R|Wi*Tp7vQBt*^RiC_Ob+C>1^qQ!gEeJ2?wPn&l|?cy_D zp2Lk1ipDFyT+*<5M45|@B{klGm5TQ*6_0+hxBsI-QGcAY_ds!f_n9Zv9 z^G)7o+6kaDu(5o@`TBKt`aGrthN5Q&W-T2U!sB;lY~reF-(@Vq{Mjcs`bb(6;}M(*=bE&)e=9QqU}9pM$_t%xr+SPV$sULF0%H}=d` z5!85cip)c2)+rr`4F4`NWBZ9Q2G;8Y&d!{iRp4AmG3tSj&fJHjUpr+JU-$0o{Md1 z3KdwW)4n2S(CXZ|V}}nb)3_n`<2-r)nNN?;pVySd$bpoj9?|9I95n}UGoVKC-=vbh z^>VmbGN6Klf#+Yf7k$cpwU~P9a_1}Gzw%3J(?>eU5sWcYbX(@99LK#QxM~{zy`?+* zd7ATfl3|_9R?#pYUry~mZxvBmmYnxeyu|)NYAR_!fh&1>DD_L@q-*#rhJ0{n1$69n zukAYTRghyhbU}6S800{)GvFH^&1g_t!ZlKNe11)6lZ5f%DrJr^Ui&G!>OLsw%V*z| zZJi*iN6*hwj4QHF+d#FBbQl zthYy@Hq>0idwgYlAI1y$XG6kj`?EO2=VpK9kWwT^1Q4DOgP0j zZiO(zgVA;IDyt$I_RFn-y4hvb@^_R=gUM8xosj-FO%fbj;#5{yO8HCNz}`pG$k}jN zS+O~g8*1jg;Vca{q2c_9oImJ3&d5YH-D*#ondg!*nPZ$a;eg?l7-xDr{U%=@uk?j& zSWZs8@R=|D-a#p6{ZPU?xlEFi`) z{l}tiwYxI$FgEL;$*Uq{n0;&G$5(ar zw%Q;ku6FUf1X0FGBv|#?1qHz!1pLSILsAu~al`YLyVs zGTd9>j$K=0QZQN8`FA^gKBODSu|Vt6!{ z_#lLxvpCr0%Ct@w`jzXc%GO?;AaQIq(yxB==9v?ZSKw$RQ{{Qyy?ep2`LDh~8umC( zCE#=C3*-tRPTjGzYg`QzM?_1n&p-L-2{)?M=6c6H(2W)zfEP$@LY2isz;Wl@gp`Wx zVX}v{mM+ySS!_!q-OMM_ziJ=wQ?63==tszwH+B8HFrVs)ms$8l47EHm59_OWoODwq z1x=NFDeAXnu98<_&cJ?=m3Wa}K3QYKL$rr~3YJC>_>u4E{BOVSEpX=UaKi{NfiUg= zSfqGv3)kpzNWdc;?#-ugSoa1U^;qd3ext{cM*)L#mW^g)yEEl>yanLNIN7De!?+x? z?)lfeR~qD%y9~FxtmX-w-M4H@(H0j!73^AZbTl&RdbwkYVXAUgCCz0W3Mm703xi|9 zP)CT^>pq4#bgbL)uw)(`1Z}%6Cu0nf-`N=P?+Vgz%Hzn-cuuw2slf!l1hc(k zQ=A97&YlXqr`ei?PEY^K0dm}Xdz0U^@sZ;1$vXGTe+WPy?0JdU3#BBz5FhA*J>$WU zSIKuphk1W-dHzV&7pAgi*waCuL`6AG8>$5zAPqZF8!Z2+7XRo*n+1RECr}U` zaF3k;rO|Y^HCK~7-ocM|(E3wbCOKr6d2@)40F@#Y>x_(B$PX9P4D{3xGbw;IA+-tmq5C!a`cqIAn4C z{c$@Jh8oUiM|#r^wet|qE@y;v+i*xbU|Ks5C76xCxT@A3~`I4K29-Za&&$f7Cy zMnYRaL5A*H{$b0sj27n5RdyXV{`a32=jMpM(EuGBg}A2_B)>2hg%;>@P;AXfFJWofqRO5vBahz4au3!!C5=J zY>OWM7BizYu1s9tVZS_txI%swDj66{&_@@ZfA|B&jpX?ZO!KK7IhjIl+tl{)cbz-B zS6g1|{>I({q9u1K$tkC%9>$k1%qo~fY@}FzEBM4d_o89R&SK4_7d>tte=Mb~j{4Br z%1qDP+yZa@k9xI&>m4cx0xL(|Aur<(<%~Gihf8JDmr4ZBqoMFJ)*5!kDalGPB};n= zLson9ZCJ7hpIo$S%ht8bol3~6XtA~bnH8n9w!`y zwe*5Buc5213lnj(_z#%Z$tbw!P^0X+8nf8C*AMCPPo6+9Pjj}h4dO~We!`@*a5@T0 zBbU>Qvv&XR&R*_#kw_u5G}|25wA^hV?^Sj9Sft>dV^0q{peIE?vZAC}mZ@Ngp|#TO^|-`0Hfdao~} z6F+RIUInZ(j5s{jr8%1n^nXogZ1zC=PZ!xraCjYjlwR*H+@q?divQQl3$yxP{=olY z@|2U#Omhr@@J{1@^eDNHTr|9#_j}LkYbr}QOxq8wq5|$)Jt^a+`wR(p9`3~+Q7B%b zrNG_+S!6B8Oi0m>kmVJkUd3K4aMLkX*M8GTlxaa%C*8BMbAgS?+*o7OfNnHP=&#kc zD{xEgHZvHwS%5Y{9N3W!AjuXV&7O?@^kYG8lKkDL6~(3NgTzDbw}#6zLbr&JScM!A zejM7pe1>WP8w?ep5Tbh4^HJ_5tMly!cK?nis<{)vO}clw^z-DsaW8f{5N$co8?HXZ zVY*qpv88O}P98}cibuXTI|JD;0^KyZ4wtX)moaOTi>X;3Lgdd`TEyHx>|WBT#fLm> zNF~X2uh?6dhpgQJ%>JO0ySr>=CVA}<$fO>|y9@d#HpnBGkTNNw;v;32Zb@A{1 zGu#DpB)&pl75&e7p?KK`UH%_a*Byv;`@J6&4H;3{Wh9jqLS|)$5E*4AGc!9og^;pC zBr=K!Wp5&TXOFVC?Cp2%N4?))|Gi$G=l0yGb3}NfCgQE^iVU?#MZaL2+CsP&G|heXwuMl>}gV7da?g?@Yk%e z0I-U1;4RS*f8(wmmL~5sTDw$#5{T-I`t+GwB)*)c^(2TH=igk9$+sv&UnDCp}qm8H0fkZPfy zPzVZ(z(AP>zIqZ&L32zKsv*~x&%*!Z2J7Y4HC|o0HgC!7bL&DQS}Kakm3l@-uCq5O zz@b(i7iImiy?Ge66h&B-V51kuVcHbxE2N@I{v4W3EL3Br69C|ybk1N59O;-QG(<=7 zG5m!P2MKn9TO4ofRSb=UJlzi3(PnaJTJtRP0RHb)q|ndI^dVmsL9{I_6O0|rauqyt z#-nAffSgwO5RY(_Ge9musRz(1EBj~2tP}h_2KubUUJ7@z=7}A7Ve1DV_dy|Bn#+Om z(ipP$K*`{=PLJQltiERAZPxYv70Ta~UHw&COQV-2{*M^ z&U;`8_KOiIz!Lb7ZU7lxmPVJ|qtz$0HM|@Tj#Nr(c7Z!V>y*i4i8@W{)rF7NS^9Q> zpzFXOl{(lg16D(vJJSZWi<*w!%VWK1A|f?f7vHS_|G&M_!6LGAWjfW3HuA5t^Ii2nU==2Tk*W(>`jfOd;@=Kz0fi?&grFJgL zlVLkKa&@gTK{YlZCMB_y218Wo4VJI(pydhgSs~#Q`vvKrD~;gsLs0(7bk5i)z+k_9 z|3X6RWb^*DW}6^2im09Sx;t*QpIe-iq&JTf^*|c}>hvomuS$0_mz65j1|;5wcU6mR`X=(FBSANKtZbUh~_bRpo%GHg%JeW)9XCqjoXJXF3k=E9<()KELp49QGH%Zu)#-cYw}2hqk+_b zpY2rHKbm+YMw;W2UlI!CN{Fa5Nr=_~k1$e+rE$L5!59T-Cg6=bG3fq!llb^!=Vb}O z!;mdMKII@c-`NdZs%^0z#Kb)WR>ve&=aSk<)?!_rt~(D!bu2q1E}JB+t#$v-k!A4 zRs4GUDzs>Tfv<9hFgurqwEpxN%N^yr0MCJG)?2Us%JTcb$OAiFTZe{QqeyIFI2*qG zmXT5O=y*hen;L2$4CG1<&_0#1jm^~x?-WX$(+-t6^t01P!{k#@vaje%%Vxi`Zbb(ot6S&tg}wKIniO>DCMl2l8<1#+JwJcBkY-; z^+OFk$Q~7ThMz--ZyF^=5QVSIo7)S9$St`P=zE>?4EWJbxt(xAw5@E2mkCB&Cp={qq??vuPI3{EJJCx z4x#+`1dL)-Ib8!$FeTic8lKp}PnyL0PG9d=h`tJ`cX4Gh(Pv1ZnR zf;ei4XVPflDJv#}QRV@NflAq6{t5yMJGIj!cI5JrMJ>1(w{N047inv*ZcCt3z0nD2 zCzx=NkTZalkTTa+|IDcs%S9}NofBdquzm_nY)!-7N2IUOZPHt~4jCrJ;ibB$h6d=P z4n;p%Dqw42-PZyy_nAjW1ZiAd-}7p4S4S8;PzoBuqu#k(>u%a2tgHZN*H&VG!Zleu zlg5sLV!AdScz8uTK!+gh=e}e^^Rbh%f#)TpMdqBK?=JGK%sbaGG~V*o(^>AQAw)_( zKb^G6B3B)Y=>bRFcvz2#IvQR&cR9O~D6Nkt; zL1z?M!(byWDiMf=auD5u4w~Gd`i##&citIAR>gaSzm0cm-C`A&S~r-7svS}zGQm<8 z+31RJ7vp2KVJ>~{;x3@vv#=xcu`QF1-lHblSGU-LmnD0-F$wK6(PiMR-SSy*!7vnft8mvqwuS* zFjGq$s;p=k;74zGxUo44K!h4WMvuF5b887(9yqltmlgu@!yXS+jqo;Z0rKu?7xFF} zbYCqjOMc8Xo`F{b7z|rs`6mesGxdG*gSR!f2TYj9MSvnn<)sd!L0--KoY&-V<>Hf1 z_^sjNwAr#qlxG|2-T}YF>ek^KZ)ncmc**Z(TgPvMV}Z};``mHjj&-ez{UtnWrz-*a zFhRJ9bwJ`qUE|k>f9a{UF#*bIP{&564scRkx7W_8p;9Y&C zv=fb{iS30^Jq@b!Th0OW<#y5n2+Y-Q@R*-NC7C7iPdm#MWAC9^;s;S4;goqw14V`Q>7I{dq5p;`43W8ORnuOA(l*09E8KO_ZwEbWrR7 zLrg+6yzo2|ekHt(d5ik3<;8Lw#HdfUOQUJD!L0;7A$a$J^%!g%vbvJsWy=D7ja+YP zo^>_KDR}?$DZt_o>hNWl*5ro5GJ_{isz-;MmB`x!H$Vdz7tdnqhxn^7L>*aJ9w8|k zQu>dDk=5c&pK!W_iiB0h`P0RP?jQ1~)AT>Ph9K_=nI+?;I2#H{=CezP+Bk`f7IdIQ z48;Wq)4Yy*gwLtofBHov*GsgkbL@Hl5aeBea4>{sq*&~p(g3+!2h_Gi8F(!a2zXQd z{K;ov>UZ2w=bp2X0y&g;C# zA85;sG}J24*b7nce|+vpG6GMl8~lY2%?fbz7HXE;OPS+`QL<3%4?hvj{5BAbq*s>; zi#HjdBRPt~u=Hmir1{c*9G_YT%@+Kn4G}S-vSI}}*gw|+nG8o0G)$5GZ>RYKzuKE= ztE#FU_m^Ed;F2nTU59SW=!s58gd12`AXkbga-{h$d*dQXK9o^!)w>Mcy-n)Ae5d$WUhynw_A|{qTkN_G57u0gTJz4WhA7SK}t5os_ z1J;olrbEQN9H71zBfZ;!_AVVE&l))}n4&y}=FyhP^VGBn)T}scXC`W}{vpN8%}r^r z88p#FM}fdjHMfZ?DBRb$^>YcQ87QFt&_*zze>vP?_akD_(WgQV{26Ak4)KK!{=gTa zQ^WAU!S`O(e9{w43Z8Sa94yvDhZTZ&G|&$K@cAQD=sICGUgWfTmSwl=Q=Ty2%R6HH z#(Dq7xM;T^|5+F^B5be>Rxx7?@I#5P5S%n#VeZSa*s^6x$l!55d7)~w&WN|qp{xJs zK9#()PmCqlkFGurWFx5Wvq3At(sohAs&s<6^C+!d7DAIp5jT21&TM5QgCZP;s z`pi$$?Tj&cQ|x^6GFIp0I_#1^0X=Z715!OlCjd=jrp@Pfi(J&z;T#~tJH3vM2BO=5 z7Ohr?3zzt#rwFX!BVbPowt+kfNbKx6)tp+hMppK;FeCS|jSciTN6E5OH1{j%|9hhJ z)^fY+vg8ub-57p{(tV+<4-z>cXYxLnuu7Dlemo4lcu^i~*p%Yu#MN&sk3+;dAge)s z70zNA4?e1F@;K`|^1jxmzT~VQnlOX**E89(3|s<$!~@RWgYwZ#G}l#O_=+B25?%5Q zv3orC>(^~4L<3uY90ixXXa|dT6`+v}dpBs8rAZbG+w*!QIpm-sB)qj{T%y(^TorKa z(DwJuNEhck2(A}z($riPFusem5tyQv0qf>RY)%YB*PfBu?HH8+QN2!;Z z5-e_*#?Q`a>7U$#=&}o>UY5! zI}^YWETmX`TDLR=Bg4rg+8OS=nk$8FwZ6Rvo*C+sYA~oSd+|)HMc7vd{d*)l->qkb zs{p&bfmsc220}Xr_EE1S8?HDobo!5#f1+L4UPBCDS=B$H6uHryK0xdkWkjNc0Arrj z2@~RCW1-Dga`tvK|7~HS05$7w!PnT9!q|f~ZwW#3HGx@(OsJW07P$j?sMgrupCW~^ zxn55(B^>fTFdK)xczIV5&9x>8N~WJ?%FL%1_DlLcto8ttLVIv97Je)@jJ^y8`ivsW z98OByJmip>32-wqn#T6#QvnQAcXWJBLnF;qu%m#pfZ_AdnHx>vu*MSkde$<7&F+x? zX<$K|v@mQrjns!?$lmAyzxS!31i17RGtLd>h%*<^;eqZQT-;EUtki?@#mQ^D?RbuK z&Bv?O=XOuuCC`UU8koJ~EPfTULpJ2{CXh&lCqWJP3`#7QU5{XRz2{|_@!D$D13nmyuTmS`DUqG!5nf<`V6A>Qa z_5R9GWO)O&`d?H`!H5Tyw$J#eMCvG`!H+B2*g4T-lj2Cl1bwlP5?K;3(ZIeI#4HMD zXst(QjgV{zo6FNl=YVopG~3!B^&2BpvSs%)Mm)+#87-XQu>ADPC6<3!l`dNEq|o9F zTS9R?I@lmfL2#qUqWVwS=<_2bI`8OBF^wZ`=>4S?H#1AYI{Uuy#pBS_aqo5s8fBpJ6B6lAb|{$e z6D9xnKwEeT=B|KML`ObKxjn1EaN%TV7VC$hkp;qCPbys{Nx&AxKc_fK_<#CDJV*FLGU;sWze3s|h$P6lB6rHgLM^{)SJ3pt*YN z{4NBCjrx9HoAGTFJ^-y}Vc7$mrbkZs@C_&_#_FDQcyk4@Hg5jHfz$`#5hx-``D_nX zEh(XWgz?1)3Zd%SRc)Qc?2>DwxLh7)Gjm>y#m}4-&NxkaKx9?FPI@uw1P~Yd&Q~|n zAFW4=68PNg=A*samYFny9z;_uOA_;^X50fB|;xFYgY- z8wi59MEB8o=aC=XNCEC`_{{OA-nHLxRdaQ4L(*8^g?~|3N#=f|nj0s2LJ4`n#c@sy z761d9xD(!csuR-Mnh~$oU~lbCO9Z7^T7Xed4QC*D=Z-j369*B$iJra{Tl>eXuU_$5 zo+Q8wv)w`r+T4i;*8&;mVuTR`2x)gF88E{=|3bf%Q#GVLJ-aB()ppQ<#zogHEyGgL@a|4wZ#M zc2PeSTIv7<7yZE66Ms}LOR{p@u$n(7Uy1w;kM)l6W2>uvQNIgT^BM|S9%o0;b(r{4 zVFsz(kh>_Wk`3-26?@RU{CyqhAUGL29%JVGQoC3^2<)+m!ChcV(S750d|mI4?E|%V z1_Gt}xw)5M)L%*}2P{jD{L=#b$8H9i@^*NED441yu{J~Y878ZGW?-^$v1Yt zBvWqj6BtWU1szyAXDfV*vwm;;XGAHdWRHbijf`}K_6=CaWCYvXJoY5rjCx?j_RGGE zIv9%U#j8Xjk^LPx#RK8k3Jh*Ky7|%RB^YOy#bOGrnR4vCKN;HG`}uQD>&a^vA$Cwp zZ)iC25VFefOAO5$pkGLaeD6#zHT{n)@vH#JUgrw`Q}3@yNr8Ozk7N ziYby<6DdZ42M3D`9d}J;ECsb80^yMZN&*x554$ zO+B-M!oP#U=f4zELe|U1pW?(j4)&scBON1Uj;Cs*gdzLm14;rwjUbSKPn7a;-5bQ& z5e$6xE7ZP9JrjIH7kfXL8qA(&Mcgh&a?T|76 zI#Kb5{}VPucYE#wvAYCy3b2n*Ibn362AOGDsJIf`2B9qaSu*NuhcRV_Zly&?E0dh9 zoeA*X{SHbPBKa#;mnE+sa^`90BXow@v38gF*UDNb5P(w5#b+F+b2dcF-d|bG> zm2`NX*H6tg#Uh4AsRzjMs?1{9On`VQP?w@qip)TJQW0QjjPmWkEoRYFj*PTOnt*LV zB#Q`aG>_YzHv%pVZE!jm==yO90)(JZfx8ElA4BSWkF$wi9fyxQCj53ZUMiG;R%`_@ zoXyua^t@OHKzDsp*dGkpMQo@DQ=(X06eG|5bAu~YnmJzPq8r$={DpA~H8L`>DN@rQ(nW&mRE0*0AJ! zG!DzmLLYQV1As3Pr4ATTQVCEeuT>vyCU<-k>-}fWd^8aFAMI_#TN=PISkzy2 z?1F?F#_c^1EwqIwyaJs|z;5RrgQFmK5;)jweVab{jQZ>66u$!&lap@-vTqIa+3D;Y z@YXS?I@3HLUK)@M0yGfc$wF^R>4Ev#+f`-z_RdnEKT2Xu?Hk3B2PH|B^&IUtVHgim zhC~M<$SARTP4{TW zK-r|jsueE&UUIS#H0OlA@>$U5DrE>87GYy;R=^?QNgrv>uE8@>V2O6;GkH)otPu{b zjBLhaJ45(ob*L|#KL!S9!Cu>S1xXztdWA(|X^1j$$cl#KCi>_-T+)Lg*fJ(aQ0C1JVa|6QG z)7IKW!H^h-^mXN!$7v)phNd=%B`-lkt8mJW05>A$9MR|JTlEK$RNOc-kp33RT_31G z%28=SF>!H75s+MkqTS&xeGF3GkTL$r}Qz_Ig}y}V>G52fO|lAzvu+z*92Kv?xyls0Uq2@#ccJ+xB>MHAo+EG0c9=4N^pXL1RNacuU?#jd-%K8= z)lIXABr&igXWW4LM56$~{puYozHw0t3lCm(EXziD z5Nvh{Kz`;4vNG@mBeSk*{v-77Y&>*WWF!w_Ge~4~eXcPWM6yC4$f}3Gfb2FD3m-jR z{0D_+wy-5e=&HqM>n~%r|Ij1b`agpJx+)N9Vh_Rb!UFyXA0KBhHc83m+Hr@F^m3~h z*%EbE?Ikt1Z0G%eD+(KM$q(;CBWFA=_RZ1$*?mIjt77eHcMv~eD8>q6Yq@V3XuQ!n zhNHf`vTkT;)oBg*E6Kk4UGQk@==Z~V6fdxHJkFqlQ+tR7Qj{W-<~&gk{@BZ7ae3ZX z)5i&o?bnA9@<)7r4_2xGc{_3mpd%nzuMW{!A67Z8YNRIAJg9ggZVbru{(%9o6}-aB z_V|01EWs}uq1&2)0^TS#@<~dDnh@;Oi)Z;TGyoV{R}ol6;-MEBBFqhy!lm%Xj(+u)P7Xt|@ zz_KTC|;~j)^mry z$yqHxArE`GCYZT#^5$~S2`a*pT6A9|4PZPW5+96M!nm!F@8_MP1KN3lMk+znr(5@* zAV%Y_zz464niSQ@6#FY+rMJ0v$-X?`p+fq5!sKscd!YuIwdP~k+6O^09E{~rtP^u= zmrRh#bVTfqyoemuFz9u>UVV9xdU$w_B*nO}n6YF50t9w@{iL-d{T zv=L*vs{~$d?2Ci$(wD{R@o=6fUV=T^1Ce{R`qqGJ$o@XAv9*@ky%=P)!R^TgodH8S zNGL`1a*MFx?jN2wsHmyab2ue|CT43)IoWp$Tdq5kujvq`}$Krw#Th zpZ>LEw%tJD%$f|ls{uItALjZOH>3P5aFQs03le^gt_ZYr3PkG6aPh3Wz~$SqAndr0 zWgxDEgIrfa#abv7O>4e{_$jQ?_=VAeEs_8%%0ZX+6nej;D(j6Dh}sm57RJZNDl39v zQAjC<#S4kWV7ydkkP9$DT2oj#xSM&VO3e3g;HmWo;NQEUs4k4sIxh(ix=} zGn-ihS=aLV5i3`_CODk`PrnovmiVK5VhAix5m3K2Bl^LFi7efIL`9Irg+|lc(Z`;8 zBUb9#=h3f*o{c*QGoRbIE zCK}kmlb5JPh@d71tCre%&;{LF9UK5hYS=)vP8VPS6aoFK_=wR`7Gt{K#|929dI1o} z=m9MUY60{*t$U%NkrNG&;26gQ1PzS=MZFJY%5=~pQk1eMP}71?lQ12m$Dk^0A%}E1 z4N8}vBg6o>89s5Te(9AD^IFGLIT@_C#L~b{84d;nAkHo{Kfc4v5ioZ%1#QzHZ$m6t zq`U$^q7(=nGdHg2BC?4D85Sf<=<9?2Ty@woH!x`<8dNWn(lRU&c|rc1hKiPi;A>HI zG{|hu!*6A=hG3-|9(?SC(ZAIT%EyQm{2B8|&TJF{tLK%f*PYV%NDZcMB_XGZxXF7( zhj1~2%vij>IF7nBf&dwcu=s}|d9G*#y*g17^DE&f@3(o4vL&k|pG~O);R+a#4#`7U zB?faIt|knObNKUWY~h|q_+a@0bLoU7RKG2|%mutNU2q|<`R4F-9#NZSmSSh(zFUh6 z6gnfCb@r@u6jwj~upQ7CfV$v|_zjP9E;=AIWN2gc?RH=NJMWaa%qKX9FhzIQV(%b0 zDXItpyD3FMeZqqbBf5iqld7NKemr(xNA1uV0~r1hJkM7Okx#&QWK|A&Vkd9*)J-2G zVKIh;XU{@=8p!g)lsK#wc;h{mohTpVZTYX7;`{W(E0ADlQn(Ofblcl+;z94ytmMzp z5CZ9{()7`2z64EdeZMITfdyH7!m^MK)Dxbs#Vm#&gl~N30|_21X4xDCHWS~H6l>=i zKVH<(=!0!cV>vcO%Sm!XrFDKbN~i@}Zz-Ur$EJ1-HxMwzN@gW<%kaKj_M6oTKezPta2~2xE_(|JdpF32 zUw0AhXd)qn5mDy@*`U}fJ9-Fbm`%R|b`@hOiK@HM!9cYX)(6#HcJ^*$$?RQ+)vTb) z9wMeO4QQ+uh*RLW!3r6@yhPx<+r5pUt2H)Wc<>tbFYAl3BSVP_R2Hcz6~DI+e=0V*#c=yG zzFJ7t_~AqUh)56ja%_@d(Dx3+nGj7w$p~pCpEMj1P8pCg)NXGQ!)HS)cchSoE^z>7 ziyzswx0j4M0hR@QT0E;PHerVqO=HD`4g8`|5F+JV8sxh1MZM4nHLLxZQ*0imkgdG&bit{1x3I$QemOHysru1^r%6fW<|JfLuR7 zLea08GHZRlAvGT210kIE6tGO(jC5PihB~ljNcAL!-HnXFk|w%~|5D*`hA3N)&9;T1 zq+?$XL!q;PU}@*{>O}tSKw<-a8o;)1 z6hS3RLwLD9S^h1?ZQjJHbI|Ans09gUmbXBIdQo=HZ@S`(QZ!;9L=Q0hc$k67+6{A* zHh{$rUqG|ddeX4a!pi+Zmm0WK4@wk+LnB&!)&U5@?+MAkZ)$5f>}S_DAC10mepHOT z`B3c4{LIT*&;9WZTXSA3-ej1W`I(OG?%%2=!0pe!C-$13a}Q)XsItP*tsE>=J;er$R`am9liA(aX^nCk{4)Kss3zloH-GpnLDX>^NkY4k1z`iku zRJ7}to$>3XKSYZ0@byJ%x@31x*}D=!kwW_TJ5=D)5{&OnKaRi_Q>?L@{SneR=svrH z!J;2da~>++?|qaBDSAt%tr5iJ;uic{q=BL~RQsuW3#6$uU4shDaOtpwKGFlB2-qEP z0?1<929exV?iw#_a6t~ea(nxw{hp*;PgGjTiX3zWp!v@T%>&f{2_txqJ7lS{#J@L` z>e>dcaSwk>{McB2cZe7;kTv}cRNEs4$c~3fV5kNM(`>ZBgYqnkKB#bfj`o3-mYPc` zDCJ)N8G&BBBMq}kvygR$Q?T4*Z0Tv#tSnjjOgOSIS_0`W@Q2UDuN4y0)jb z_@tzy7c)z80=5RzZ6yu0w1oM4M44i4eDEIk+@B6@uz3^IYE3S?g|BYUZlV8ZrpOjQ z=u+4;4{LpJ(+@Kn{S$?S5g)jHefMbVvwrb!I?eR)I7zCIeSa|{Ix&6mp+9Wj@V*jfmj z7hv6v&Rji_UXV`E-cYj~&-8-CTYf5_fv{4sur$bgX!KBV-)#_FoVkb6|4K$}VdgJ2h1&Z?0W z1A{4T>3uR-c#wce)VU)o!j8CvkR=f=@Wf9 zS45P;ntrg#D>pP+wWB}&W@xdNR#$&js+xJ&>F^XG!&Q6sX_^fVa#;#G%18AXciA1@ zyIbY4mHxcp7f&L49A1j}CqhD^5p}f)*o8((+SJRk*oBYrKkqjiZeZ}cDNf3ver{=3 zILs^6srNda1kP{%(54>^Jo5avl?1$eebY$^JYM+v`byIdWu*3-j`PRX`3#~Bmy&s} zSoPya9(=G#lB73o_Ni?HJJQTUZr;_yLT_=mkSL=^8;%)BE6Iat7}2z?O9huuAPr*4bG3uzSJy1 z(%SlfV%y7+%7oU1Nr2@Z!7urC?-9o~m~_fBFtnE%G!gcGQR)FhJfr{L<9v%o>WG+* z03&xLXNSllGps}4)}{7jy*FEQ(dp@|?|WJ{9|uX_%v7l!UQB^!kfG6g&&zmlLfAMO z8IP>cE(-OCdc?+Rqm7Pg^sZ|R%5mMOd~#vir)9uqN74OdWlKs|W=;XR8Ff|SrvOPC zJ+!xWKHk@N23^GT7v_auSY0E`nPr}Gnn@dx9F_UC?c7Gnc9HxRX6Z^kmA5=-Ok#o} z%>}=hyS@v0;Ty>1dZ7n4+jmlW*)>M&M6B8!Cx3o;^Q}s4Hbum)t{3259k0arFJDEw zcu84+PneChLxpIDgp^dNq{=#Av-jFmK)6bhf{ox&CH#Bt-V`)c68SE(iY04%lGcfR z*Nx7K)m^m{?@Ci-)pHadI&1|m&wl(0d|bTTvFE{c?>e8xm7CAlG9C7O#nj557xnHq zK^qSQB0}}1Wy^JKq~hYC|Bl2<&K1&{_po{42Iba5@DcE@;8-Q6VvGPAyt>VN$|`GQ zz$AxWxUH!Tc3B%_Y%$!+dJ@ zS$=D1R)pJpnWnBwMDG3>UTbS-S-2cwAE(+mJVB)5j+?@R;)lmNcuI zM19hdywUNANB%BRI#o4s&i=U9Lf2jGmeB$_x%OZC%v3mGU(z&ZgoA^MHp?h~dhfemzDyA1+Yh^EJvruWZB^69oSLksvB}RF`+cd6 z0p^f{o1ya7ix;rtzh6b%x6@Dfn;-3>>5K7luAx%anCl&5@SsR_tr3qm!>8JoelssZ_pil+`PVynRH$nb&?1p{)TK|VDRHj3VeJixP-F5 z4}HtmfZe>yoZ9|{^*-3VZ=D9SbJp7!bc_Ny7c+}^IN)x>2yeb^Qkjp9v0^7Lz|*}{ zkgKp8nAxI=Dm7}jT%6)5?KhG~@h(N$=<7p^HP$;X$*zfu?+4;EUzU~n`k^OHY-E!s z{?RE30RlC)`llnBL(R_!E=Z6}_V3+iA;%fj_l@%P%^Eq_T=Lb#8oB}l_hk0WE{n^MWf!5-Js;^3H>yKpFQ zJ@$3exjU8X(dru7ufZXFHIq|G%9wd{;7-| zk{=_7oJxMudb#pZCnso&1^?9Sv)nPl!o{#{huz37U)~~`Jt_0)_B-$QR=w`;dHp#% z9H<3hyQhNThCRv#2=ejvyE~iLUP;%r-8oTGas2xhfwxs!YHH$shDpzxH)(WMO3n?9 zLe=JR;*_DU?7&&7!;53O&8dUMA_9uBYN}2+89#rC#9ufmA>eMgKnztxl$aImle!ch zGvR2XCI$YTkIRJ7z9Z7G+X!#PV(}ZP)^n4nH)*lKO~$qTvl>j+3}F7MYxn4F*J&ca z&M9T+yP9htzv>(43kTT>*)zuM2blrCf{+ac^H*L`RO0E5HKOfp`wkDXaBDi(2Q6&$ zX(QO@z=?dk6C;wa^x$=3A{FlQ2yPNmt(PWIR&V2NC6C`Z*yVq_fHGpn@)D%*;yji&I(NxUO9m|_B_iL7hO(a&(=ROj@mb1 zX|jTSc~)-9$j0sJ?O(*2md6KZM9mz~Nb^~Jvb+4ZMRLkXOupoocn=H!!ico9TOWS7 ze?4hm0YJjyml9dryc3};g?pa#whrrH{*WKY`pN?C)|N#x_ef<6-zO4pEc7@hz*(ZB zwpnyR!7J68hThKwi~gR?Obe0$dK0}plx&LJjKImKae+LYxt$IFAz3&tznthKB`<(= zkX6>T7*9h0`JT^iF1y*M{xT^zPz9Yc&gwe%0aZ2Rmf@^ILiFY7)W z?R9Iy!s`+;A5Ggum(mwuVF(Z2m8`jJC9D9iEylmEyWq=3w81Gf$#IW^Zqi8IYECEJ zb#64o^C+1sg;?OkZ@o#zz*Vj82O7LIQbR@$!Fy-9?0l9+OJ8AhaVP#*GI2Zq$=}QP zvva^JWET(Ku7uLF#OK%0_kAVW&R}JWZ#9O42`Gj1lmtE46R?lmgu13%q38u56Yle- zruwo~ajNB0E<(J{kL~7{1k}Iv*hv2tN9XG1d*7heEAXD%$e}xGfAwwg(7W#y!*3hE zSm1kYDpV%9;;KY`E)WlXV~s#+iPq4s>iJmhxBNXE z2&oKjt82IMEn41VX1=VfwmU@lGT^<+Pd?);XA^=mO_u2XacKx225*AX-#dMBZH-+P zKJ43bgC2lz_gUHjDRsb?-wRIiSeV(_opIXS)L=hit9@vgpN_R2x#@VkDjZ#OgzHW; z631%ti4wl+LlmJu&QQgNPjW^PDWy4?U^!AJE3%mQ(Lz?1v9sBSyszVe+ z_o}%nIa^%QgnhW(#!B7DhqmVPb9U}Y1G551SL`*@@So%8R=BYI_T2U7mAVo0JhI8dkE;FYh^co0MPH*(~+aE8E^% zn9$95A-em0|F|A^-qLeNzA3?Xdkpa&`$Vsv#`xdw9u#>sI2h7) zG1Bolu4Hv}=2yj#+w^znWllCUHx4(1xZM;upItj`;xZGhvz@u`63=zGrWLNEtNE!2 zj)hwX!QiD^93J;m8W{-1kX^{(A|y+{f1PBKDoIv3t|u))eKz;^nK<+fNw2Xq2=Vn>!d0U3n()4ymQf#P){s!fOir#Vwu9^R_3ZsbU4?a{C>K zOLhp{FU7oXYS*#mn|E8NMDfxcOTLn=_X@X+6r%woR{k+sEB{eDbid2g*6bwpqsvG5 z({9_!H(93Z8#|H@2-hSkb4^XpOYWDQ_EPy!Ol!SqyJ;L5k=Upbj3c^{=bAm7Zr1pxEr4kCe#P zP|H6W8W_tTNa79PO^c7iEA?Vjqwth(I7I%KEjMOnhWHEN@5u0xxwU;b<+}J`y_^T0 zwp9sSeB#pL#L{ovzxez4P14HBE$`hBrW@uKssdiU!v-8raANJ+l|OL1HE7ic@)W2~pyRRvV@0D7j|;+FF;aks>u4d&4K1 zTQg^AZmK!tA|K=Id~kDrG^`2*1VWpit=lUjj+XDNl!le}XbY!xx!tvJ* z{$Id%(x4A4TR4~$83rij5%8Kky17S(fr`&qwVT@bYF=e(Xpkr?P&G4!Opy>4pZLot zy!}a_kbeKE-XbH!HKa=#Cm^Pk+02FO7cD$ttD& z)N#7Kk-qtero8y_J&~f-5;a*P+cX~eKao1SByCJVw`*Ts7}})?7+7JNB0P0lwZ^Kw zej&VR+;6J;*l346vrWchA27NQqhT$JSY?es+lEXO^o_vEabP|q)qql6qmY2 zzB~0I{q9E~2wHp*K@c3r>wFsyH_I6zg$eJvb1BO<)MNL^5C0DXZsvX9kyk!+Lkq0p zwpfR_c*n<;m}m6pjt8EUD5)b*NHQt6K8B(`L|A$2eG=Z$P<}EQE`6){kM_#i6!qHr zF0*Plum>q82G`0SaSF9?#Qe#lbE~|}DZq0srZw~D+33pL{hA?Jqfu`?ioETKvv-_K z#0m#CC!=+HH@7FM+kI-~?aQPiZLOj6#0FAii$rPT{y<|D< z5B5*1f3RY04GSHTZch~r>w`}b;qYK&z)C9PCu=({uCUDHeRL|{Dt zJ$G;-|Idw(Itqwv^sgsVQ`41IS~}+2R^L4(bf$DMkRXv;p!ba1_N!kDQ~fkn6!^E* z7CRz}Agt-K$lFy_v2csBtsbG`*D6=mc@k}l|4k+;=}okg9BleuHuT&bcn;E+-X#tW ziH|h|=(Bm`m7;|&!)>jr-NQM6;tlJrtQ?KVd5`(coW83)NpeUe_}Q6_JA2Rc@MPi_ zTti0kzOYIO;9*_^hHC-v-oV+Qc|r-E`PcA4xb@=Cu6LbJd``?e0tM_Fg_PL?vj=yO zPvjQbkqQ0Y^5aci&4d2V z|GBMXdjDD=Uj^G#Uq=^F&cyFEDLChjH*<@3Pb}66Y1*q8@6P_tqm!($-7}MBqL)9w zjQl56)lMsA%=EWNFqQMj%c&~JfH^v#X!DOS#8*CyLNuk#dzHEHyVIJ8fQ*7Sz&Tv7 z=~UWfHjmSiyW6#FtDOSWMvv7&@GEZYy7-Xd`uj35bM$CV5a&HL=z*(go|f^zVLcex zi<~)Kvm%C=APw06k)&kCUq6ioea{px!moABy1ptooK)N8<1_Z?>^^zUY1KsT#|a&M zUPhuDx26I#3s(1>Tev&mbU(XQJm5HAnGp_%;S)L(Gkwh50=%9#gPK=gq;~>StJyyo z+%##dME=0U6Txx{+Gy}EaFqLi4OotzLH8+t6c`il^RO85=O_gBn)Go&M|HiZ+U|J1 z(^=C05u4pPCCxv8T+kBPt7bxXlhJ6OSKO5^$;5R71);W~|1UKBOHlw^aG2yekQ}P=g|h(QHZv>h9HIyyVw6MH^-i>~KP;I}!T)(LVZ8Lvug44*V<+?; zn%xB4uZ@usx3!Ck;M~}w+pvyYIv2?J>^+uYc(YjKVuqujoH8&w=TuWRRtn@S-hqux znZw3*M_YO1^DIQ@gpf0B9Z9|Y&h!1EeAn*^A>d>t9x`0~e&?u{*cN`^Z~p2E7obpj zhgUiFP5L>tg20FrTe@Rv>I8@fO|0f+b!uisU6chF`Q-Yl=N5_})=-;w9F?~M_fvh9 zo9(#6evJ>9ub1JcA063A0=s$PHqkIR5p-Zyx9E6(s(s)VxZ`ShX6Dh3k!9@7%M`)l8&sF}DDKUjPS-=O}nZr@gk z`$@-t)Zi{{qb-2sA(3vb#0&WuLX;I;1T^O!OjvgZS`kCTn;UwGQI^ctgt?|NbDu7%Yj-f49$ZFHR+o9_?#4kEwL=DcXP z9w(4)S($VC%y`6~m!jL$a5D3kTYYqUrM5f2nM69aI-gZ_%0GDyVlQdtzu@8 zHiCdvK*Oyuc0hdy`H}*0d6g(*Y$Kx$@fUxoJ8!)>0XsyI`Y&T&F==IU-iox@6?vIl~I;2$NWw%IPBL-|eP*iZ&AURBF=KUQDhAeU0n zt$sK?dBLNs>ASg^c}xVNqd4XMTDQQ;J*f&?1Hz2LiR47?bbtN6jpq&`EHSOEB`e$R zPq)_20|Me#qWmtu-hV!ZemW^)==q*9(2Hy{wA2;cI;q>vXAQXdmMQK$zs!08(YQpZ zWLl}6Vdr_M1%~FvOj`c4ESwLuufAE_L*QMC1rmFbz z@i8g>)Wr4)D0hadJmSbHe;<4XNeyX*;?Q$8Z@r3TKkSnlZi!sP^0xO%h7_GzdLZ6X z{dXb5oUmaCq7~c8|0c<}1VlU^C=L0~VdIsOb1^r}7fT#U58D%%aTU*O<_`zf{|K%9#f!OuMRO{I)YjkG+#b!W%&<4m) z(&k(+&E=8jzYGucDL_Hx7ZezwxTe3OPwBGT)0FFKvZEP68Z{OnGNo_+QIxRarmdBt!rZMXIlx zHcH5E#Mx|T%!K1uZF4}-@t2kmuvH>w@Y@*1#{5LFdYG__F$B41Ou3JUx$+$+leuP} zcKiYXJ{(qmlw<5)u_Z6se3^0Gz(rkPq)d1#obR{etG&h#PTzJu*DQ8V>?>iNMU~cq zlcGSv=XsYE`Zu&+P5LHs|g z@1XKgMd9O)P<~dCucX!l=TTB6?d}{bB>@-b(2bVRrZ~p3bvw78EaXevdDG}p0z8R? zES$L%;#{BEHbsjg(^B_QWo~Wg=KE(wLXPOa<1bUw(23={$N~9MTwD(nAuu&}61iL@ z$9^>0izhZY zKM%e=O?#+vtM?NYnxY_5_V84In9WeCwqLt41Y)!^ZCi(T+H3Z1Avgb|*^3jhT_cJ; zvHpE$^K}G9TKfN_Z~qDh3)jK?kFH?MzM1*#SE~}Dui{xM+A7}KdS9ZRN$nme#)=vA zAaIwHMF7D&J8*G=a4U8Owms~f*aH4F3ce+w!7_bwo?3Iy@=r; zb;oeyFJ~eal63Lu^$D-WoAmz?XpoIN$UZMeQ+N0DAVX036&ywqczFb^LfiLf7p6q5 z@wC_C&qy25Tgr2Y!miPGIo=K_<{y2P zbw!?R!Fi>TlTb`xtVMW2gYVb#<~e^}akR@lo5d52;y}J4` z_}0ki&Dc7BMPJ{gMvsZ9LUP=eLcP$X%kpF!kU@Zy?vM6&BjBESS9|u2x;Gc%AWWS8 zi{X42WF9KkLp^wDdi9 z#6&>^63x7&E0fW`1i-e}Y;~3H9y`6?3FmsM<@S_6#=YS7v%ze<{nzl%=!ur{=+SUX>vK_G%nZsFGka>E!ZYLAQj!uUWe<_ zIoi!R@7(E+f@7n>eLa*~3ZhmhoVdO6E-Dm!N&;VO`3VP+`vM8(w@VidRV-bjP;C5{ z`i1Bfyhby6fr_l*S9rMK!;CX?+`)(cZyf*-#w~`c~)wZK- zN1qDhR9e6f@0*v$E=KJm|7=--};$J_iX;A=hL>u4sIJ5@FKfF0OtPqU+>(3zpxeQ-0B{$CXg^k=d?_16(4bb zh^W50hpJ@vV>2Qr>(Yq>fF@XY6Bph)VP zmGowt*|c*tE+$q@Qd?wjj(BvY&{lcov@N8YX#UzAys)I}*%}c|#xk*gqp7f$feLYo zz>Yo4fgHgEA8ZPi<~WsjzkB=mX4!F4kio+F4aeP$fWTQ)hk2Ik+1fc^HCvEiLvfF|Et8`*rAG;#mR|Sus3k3&Zy*Yn z4n}FqK6~Uw`W1pH^twY4CC%U6 zBLC@V_4ITjH_E5PXZ7esM564q&ZK56Q0gFVQJ&xZ{4(%NO=1)cP0exL3}=Z%xA%8Z z#ssGY5wSwc5o1FjL&W*^Mma~b^~%a2c*_Ch`xLm9;G+2*a-Kk_*3)O1Q8;@E^ZZo# ze1Vvt@_6;lR=XSXE?=S0rDXEab(-%Hh7iNl>e9(%{`XlfJZw2-v87d& z!J9Ex=l`pxy68Yq%*sNdFW9>zQ$C#bA@BoEoIF=T|Igs)E;H0Yh{pg1o0fJA{ubCf zN_rbmC=I;U$|Ok-CWo#Px6nV=BtKf5@zWs#G6OFsm2r57pU13>g>?wf8Fj;&c}H_Jv=7C-AfJZ7Y%Pg&cu0-T35PW?(5xMd zU35ShpSTOjSrwF!(lST*{1&OE)E2Y@-J zB=U_(!}Z`shF|;Cc+2`4{b?(L90#p4p20z_ws0li)xk6AElOH`2l6Yw)7B<=IEtfP z;QwMR(I~FN)<+0{uSb~eO-_yp9M8)Ew?F1Eqf#8B66k*(7mcaC89Ja+xi0HunhJ59 ze2muJZps>TcB{{=``hAg>$VAQP==>fZk{A_Sq`-lqk~v;snnJ4_P<_$ZgmsT5d+%E zTjL!UlTo}mC;m7(E)2q)^|pUwYl_IJ?8i5BUf3z~({31APQJCsCU58Z53IlU(D6?3 zfOJFL9z0=>v<=`m_@OVL<;uxK1`)Cu$048~jmoZI^hJ?z9KGtz{SDs#+1XMPg+H`` zw6HvxPS06~e~~L#IukjNl?>{`{cDYh7-Pze!0t2;vZcI(EbcRQqH1@R8h}Aqan*F; zlyEx}6vc2O7uO!_7DDYvmg-YBxbikCL9ox-9D)y=%0^qEJ<-1(jX?quOF>lYz78oJ!0n+b&7(Z~h>#W1`bU=IJ)mh3aAEuII#}37B<0S1oFsi!_L;+2A6$ zrdT#Tu&*wrmQ?HHKv?TqZKG;&-c(H8KGQzNXwT@ z3`iYn0(dvhM7?{BC2j~{{xQU`yI8_ChLN7^{917C&gqbWf}aNe*wotoOh9Q1zNW}I z3h*I|Aj!J$eS!QJi9qjkT2LQ*x_KEQYBn~KX&KVii$z}U?!n@gElZmAh3`94|JEoz zQ9Jws42!pg_HSZpteen^0NQx%uPS`Bm)^_S{LVO@84JX8gs$iG#&`+p>$6axgRG3y zT0?U^O4m)FD)2etcXC3-G4#=5#q;99vPxXTjIBQ6#j~mii_4d&rv0-@0jd6Rktm5N ziuegf*h!7w{X}zXj3_`V87nIzif@Va?&Bgo`gYIozMUIN(Ub*4gGTzl(wuQ0{N9)$ zjfNHi*8Hn9jU)|>H5k$*kwLj6CX_%MlOl}ktSkC=RsCsV$U|j2Uyq$f!I)ukH71r8 z)x!NRfH1Jrjr!?@F@}pvwk`>+t|RR2?5&Xs(bi!luadC}8gG-pGwF5s8&(|K1H+yd=AAh5@)mq!Jisu&?}06|2tFb9mH zA$c}TbnP4*WZ~ukRRmZKxwuDszw$mmR@&MEw<1HHF=-Jvz0h)@#Eqw+Bp4cUuXm)@ zEDrskACGLGhdBeN@(pKyZ|~nhho0xIch8k3jo-wofTXI+1^`YW7C*>8Nf|6E&x&mA zNk7cKgu9)o97?sXp%HoipPQa1hFgXA?01`NTVXBrZPjN4cRf|4P}(?{5GUqd)oiqV z9P6}U$-cizFRi~Tz*Dg+hj-fm*Z>|-I`m!E+&eCXl1RRLl8|cYu4O$VV?t1PjxtrT zM0y-1L~;Wt9Y5ww!?=g-J~ht=>ic`7d6Yw`gYjzd^XPB8U>ih9=*ts`D0nlRMdXw$ zZeU2zb!Lo99-K)aLA{N@Zv?rt;eCeBfeQChe}TDxKg=ooWtE{C;oxz+ z$oRnZoMr(O7;T-MOz_~7D!mHBu217N`dpJ-Y^qv6wYz^n3pH*Q8^q98ezz&|S{n7Ap0l5QQXJ^sZj`XYKTMXhLVwxkyTkJUqCiiP8e3M&LGUT!-;$Nh# zeBiGNB9?@jo8&*sm=9mHs7R>3{pEW<=sXsBQfMVK&JOjIyh)M&r*&};g_ngF6ltex z^U#r&@Np_XgZM=nt`6k|Y>C#f00Wfz?Rh|R$6RcK+jVl+zH#1EPL%_JFPYmmur_ve zVK;Zdi7;;aFSJ}(Bn_9?E%Yr!AVy=e{lGJ(5ZWC2$uLss^1W$1tZFETfj=#SbtP3+ zxaYcTvckH&)_L@2b_BVERN+N$a74UP7es^uH^8v{NA2CU$hgju@6i&CzwA!NrkS$M zf+C>7TXhv}Vo$ZTG#j2XEwLJ@S=-m%gWE)?LhNHbw0O^jn2)_;ON z-I#DNSuFI%p%#SLfQZ4hWI}Rj2%8S}{|Y}DAwReQ-$)rW5#0Hz;?3Q^HFcluru65l4}Mni_$}kgqp|!}@Y+%EDyLTA^Ooh7Iy` zF<>_=Jz;cWDX4;%F-ud4-j!D=dGoCZm#x`pR~5H5wejZfaJ^ddRn2!mdgrg+)e_E_@1dCy z_T`_V;cE=7GM#nL)&NaQPdsm>k+jcxr*K@^VVL=jX=kg54 z{%LThM;lz4|DP2Y<0-9{4H8jB`UCyvXJEnR4NSfz;dZe9o^|Bq(5?y+-P#=~OdW^0 zP<4!3wb$@M3mRmC$OR(*y_N~^}4%phe13}XIZ_k0Ls}h=T+TS&< z8j#@x^}lr)w;wq zNr2BqdH_N4^N>d`8$uf&Sbbq>U3tdj;H<{@t%W?5$M}VSxwzWNIa0dKLW#5P^(vz? z6u#K`2YA6C|FMV`KZ-fhh2X>W6eguYxmc>Cc|< zyy6C9N0A;F7686}sCqegEH4V~NUAz*{H566?TiZnwAxU#G*~PQwxjm_tyZCc=3Y^> zzZh1^#a7)VyU%srg;!MT&L(!B^vlgj;jNd`c#7%Vj*rIkn(IVPqJAi%!oSZBuu2^R zfx}aSqEfyz15!!dpYv#X?>|PfHFPXD%0q$Cc8Q+6phLDTb}f-XzT{GPPR!5i%tdoG z`O8bYw9ut?$cs-^L_^Q&^4*~{b#yijnV=_4&~6NR((ayv|4&Rx&ME`O;}l{%5>NZB z!2JQ?FJP7;5ZeFTqy-@M^zKa#Z85CRfH>K|nb8;PJ~_B+1+gbg!c0Y*fNiRuDscWdZrvmw3sHh!a+6&anaB}I z^@T0yN}KJMXbGuL$~A|*WyrHQ9}Q(AF(nzs3I0No=sZ0Q7whd>v3w>O&u*5@_CP`SKq`|M`lO`0^3Md3HgN z4TDwREiTd*&eyDq?zT|xX8_DDUkLWn>2u<;e>_pOe)EUZIM}&L6sCkcC-;A35zNh! zW2$2!Ja?}mmnRcUL)Cv(wjAH86|?28OnwA1kz$s=ANQ0uK`pcq2?q6f<)mV`aZF5~ z>ADma7aT!K+V*1c94k15^Q(C84T){@1`>Ogze*)J=>}^PjeIT?p7&xP-bj_(s1M_B zAKwg*K~a@TrJ(m!z52=9x$(>2Xb|71z`@Juud6u#2%Kxi`eW{NpN!}=gM5b@JYLxO zkF}z_7I;!_Nqi!7*=1Ew*8qQ8fKs=4`9um3o&Z_P5AOF@ZqvptWyXmebZsU$&3%|J z!M^`s^k*xzMB?eV9ek67)L9ZyVsJpf0qLvip8=j*fexi%CrHB^h6Vb;sXoZ4@*g)} zaMZ^GSjX#%u)1`?l5>oE;_BwRYhp*NhDI?1%=$b<9%`-iOOe4W7$4lK!iOzd?H4?B zUh)34O^P>&%A0fgS86OUhC|bdQA?ctSqFSLruYU?&lsGi6=!NDXI?UK*r{yzm`NjgmM}FTa^KX&1XWH~SD7Sa`A=4@S)bas=GsXMay_e#TfX=z zXK4G#oc`=T+rCJTQ9cJg*lQ$}1m+OW>ahYR7sw4CsfUv*gTMRvzyv940oMOI<|a>Y zd6ojn=%hUvPphd~Py)u~2vmSvXWk(XUDIs)!+Y|mgP8KDgLqZ9!|EWxM-13=xmeVe z15P8b#@4{=Z~T80u^5exLePVU>v;?SED`_{>TBby*!JiB4!l_pI$>)qk{0ZE2DgY# z(Gzy62yIGgRGK02m@dwm7F;*}&`a0q+Ef8@74=k4*GCL~ooWT5<9_n=e!Xk}G_LW< zOWwd}8GBHfl%#Gs5(kI2FP%B>yIsUQKR^G(QdbiR!35ARiu@bb6Vu(UjR^S45gpmX zj9g!VZxSos);%AXNI@1Tq7&T{7D#TQ zTQG$>M$p*aEUq$WPe0%?9VsAn#Wt9=9qoO632H) z_iwm4Wy>vrs>}ewO9!Cpq0$nlAK|^Z7y;~x!@aQSTP3~2p(-z>ii1fc&2JMX>4qS_ z!NB)7p4Xm_H-C&yq}jl0NH7LxH!EAlDOXK9&cEQc-gjIr=Xm9``#0Uz-9lmfqW+pO!&dDGB2IfqBjqA zyN7^u@-$Z6d=RwjZv}py^@B~vkNdOm-zKYp_#^Lg?b~5R0z-ROWK1@96T%jvzg6uw z15{1N?uND+*;UP0c7CBVpgrV82L^`h9Vyd=48DNw=#eUx!jCUKqW=e4EdR~}=?D0Y z+bo(!Mrr6D5n#w^oImJJ4}odZAk*}WAL_UT1J0{K{Kiy+8gq=Po*=ODK>>=LR_Pc| zplx2g_3g;iN>V@cMR7^(A<092gBj21&=Z=$A;fob@>S8zA`(K^4juc01!p``TY$+H zV?~p@*R;%LZym85KXRSPGU^LYd;PIDb-CH-+yE_d(Is<8e*1mw!gK`P8KISZ!ljK% zl)ldk+`_^jg961_Cj$MX?o+-pogj^YfC6w;^-V%0B0EY;9nA7wL7piAeq?!cr?+e)$~A$ zJL*W2G{$u8&;2+wi+GAd#2FiTz%L^ZVY8%8y^o}%-86A3&ula4(2Gn%E_g$GeXK}) zQ@=54Z)$Jcbl}=#Zq_HTAW%)S_r)NJpbt3+uK+UyEht0-w|i_yu-bKi`mY}MoXIlm zngt^TMui9MF%=vupP%VerY>8;$0{^&P0Fa0mJYclcAg7v@W~zN$E&iYlLop)uyX`P zeaPdMNC3SjG02C)K>fGocdMmfKh73EQ(bhu`*lsk^B*G@u(=F?5qIULYb-!x_JNN;-doi!On!K-Vx;# zzo5@GWO_xG1nSi*NY1X@kOc>r^@_Q<^1G@2cs#O_-gu~?w5ViO0TI+Di6RX6O7dx9&qBjq^P7ab2$%M{%hITRWU99zyI=4?I#y)&h%9JusW^5?v}I#@d5P? z)8CIKu!1}6kxhAr|s(YYe#VSKhHAMzq&=EE~Tn+_;S8$Rsr zUBLeK%sgu#?PKQ9mWuNbp=Qy{SZ8-;re({)K@-CF3Vx%k z8Y;~rRCCt?6aEriY>;dn!hNVcTa-P4gAMEu4hyCk%FxoB;;Z$;es+AbXc%yU0@&@> zqkm3HX-!4N+^k(eQwH?XORKL2x-EZ>QW}@gytN|zWpCvGfcs_7gs}=9O^``C0tZ&G z8i)44j%#RzzdkY@QT2!T;I?ef((9orvG1+<0T!c!3kg<3gm97Y!=#l?*UIzLvOnbc zC*fy%kFa-33wFn)jENnpiOEKYEmDkfRBowRwtdqbqZEb@xky8R6WY%=K2-{*@Y+RB zq1Uf^SUP`fy!577YtfEO4T-wSe0TT;-(A%n*8Qwn4PU z(AyS?0KeF65y6Ar2e5etwgbE7B6qLBGa#+lw{0{3vJ-vK5~8&)h^N8Zo}9Sq_Zn-% z$-6UI(sQyDLxM=ibXxh7(!ug&FL}DLSMF1_`zMm)5lK$Z^Szm$2jJUG|+b2v>53cTSN1;#HFazB(OL0C$W_I z?P0@-qLCu5&3h6x;|$XzPsgSW+K$-_+dr)P*SW27i?p&Dd-7h$HZ09{o^FR#8_?9)%RI%WtE@%C%DLn7*lxd&qt*W=KL%e zH-G_cu+YB++LhSCd(dJgX6TPkIJ}l?57nCV&V=?pSLO#0aWa-RNj3eyHpDn{jGAg3 zT>eu^$XUWrVe|9BSY?na%!m1{ab7f%5k#4EY4dx{txd@+4d0))^X9Z;oM&pWDsu;GjAT2NZoRo4NP9i) z!0_^uz8PmRXiHo(>jnclvBHPty{LC({g*w@G+CgF44exE$9rZ^F|icP{Z5%4LpNl4 zZnnWK2SB&aL#7KDJxBfnl;8_H)!ERXY+61SkSn^70Qz+H;3f*(G+CL_D6n z{Q6%FxtyC!TRU$gd?5}|f`HVO!ujpnKA=3C(wy4-{Ekc3-Xr#g1bZ(Y=9JOK$dfjF z$ChZgv8k4Q{7yxyQFvJF8ITpae%lqHzRPs{x%tS{37={iI@TC8;zJ}Tp3Pk3JFcd* zpJn>rbbGgOiPt%^WK7Y{7EgbNr3NicJdpBO*qfT%{LM2T0@qQ4+pk#L6?%B2cfJle zUwElh04rn%EMoW9bg#Z@N58dd+HlI#Ax@86Z;8HPaV6IUTJon~xNM>PYEdt4E7ml`s<6$!i`_9^PR= z-APxlAm9kT`4--Sl_zkQ@3aO)5@7zI-A;{~6f-cS@M=%?4f~`5J-#;UH5O(x?W8ay z$9-UmuZ!tv?cCdcy#O)6kBK%T;}D;!*tj^wOCer?+m|MnGqPG=3hZOiVf@J&N%&Q^|F{dY#A<)e@RYe4?N6!;}+WpnJjyG@sXv^41t_y@3^0 z-KzTRTebZIB8uYu9&7My_b~F=-@i~Wbif$sx)PUiOEIaS_!Oz;ngAO!ZfnJe)O57+ z){@Hn*N#@OntD?`FA~iDV->UimH5vJB^=qB?d?Pr+>Q*~OPh^T!ftJo6ZC}k^%q#b;SQQ}m5QHAR#L1T$QUMf z-M<80tb%1{Ld#ov@U)Z%IsG~w@W}WFK9JB)*0SF|k;n!RL{ZFCTbRI#GPFhFM|O7} zuP_vFA|huM?9ZA}tgK|e;SC(#xuIp+@uY8>tma(9r~HtQe9*)19TmXDfMUyU39@Y| zIj&A??4p>XHWy1aS&}4OI4`B4X@N{7k_5q_E!dj8{e8gvM=m%Xo>cy<7%6<$T~ca< zUxe-Y$b*~BPVI^DRph;1aG9WnovgJo65I-lfDhYPY`RCTEN2R#dCtJVoT}T`fyc*& z@~>EH0*rbxysN8w@>kK#m|(*`^$)z(7N8SJTq;e_EoWnlQHbbRHNT#=1arJ7FbN~Z z&mR&-gU`k}8&d5oTese#g0?j)=Bvx)neT9a-E5L;J^^%|A@#J~2By`U&RZdCPC~rv z`pvQyIH1JsgJKQzPgG|#r}#^Xe4AzEG_LV$N2Mn4n!8zvX+CcRU;@2tFCJ*`rsa-( zje{~oBH(Lf?UxDbT~E}`NhSG*1ZrozkJ`!-@NaDTA}njUErNg zyE1~gI2k(R)|>WM21J%(;PR7B>gls&tiJC6UyAGdQ9p5>EWrV49`zsR8_c>LydlIRXY zYdvE9BEH_(DJMM+RlI=o4Xq0eciy9Wl`dE2M+=5}j&4#H**72Dc!TLLk0a}9cJVZdkqUt~z{dV4 zG8FQz!8R}H!*}PXc6-^KwqAmkB@tj$|8=2i3;G+w*E?Nz=`Ol9;wwyPQyxqR>uy(` z0#?68y~OI?_g4EPT>vE}E>b~*ZaF3t{6FxOTCU^W|Irc(e+O`%;BieJSgblApOzN5 zcr-MMk(quwudDB)X;8*rH@XFXLSe}XJ?~g|h&E3j2OBY<*E0|oe#Q^dV;sj)KdhOg z2C;Ni3GnV$;9{tbxj$_qS`>f5_%8u-^O;*f^@j?<=wtjJ8jp~dO}~B%!bm`?!TpW6 zAy299Fj!E;!Mf$*Y}NW>Ski?C_W8}RAeum$>GM)<45!Uny`WsUB9*Mx`*nG=9FlaY z&Ql|&dtg{hGq_{E3{%x+nw#ZnH#WDTrkt!Pl`VDMt}L?isAEc%@eF~FiI4h@#SiYe z8TyRaXUZMOHqG)svU$2T&#r8$1g2X+%uK7_{uPmXaHk|F+DUw$zzB2+hEZ zW(V|D{sAR=5ZLM_o=Yz}uca=mt`jB}th}xK`qr9_k|kMMdo6s0UE_LC zg3e<$*)?uSsEL1mWg15a<7UfBSN}k3k!2gFiw08ur3zpQ(6f9{1?!56xy>z%QS4## z_@2~uUc-q;SjBS^UDI=AYf9SHH5@}(RLh$UGNUOGf?)bi8L(`kA9zp;eQ=d?UNJbzmn9x?H$z!K)e zeQIf8p_r!xG5cgdAgPXOw2&3chqRtgpIoF+z)m&Lc_z~waI&$pq2w2&{`D}ONYu_v z%N|DhI8`(Ik(=-R#}t6=uQF${$QLu8^3(xuJiuM)hB7`BnYrG~X4>CtHD7LvD&FEj zU+GSek5*p3*E7>d(_)0O2jl%t&hvC#(Nf$>{B8_?lIazDg!|Ww1s7}Mr1X=;TuliF zt;Vy!mGT>vDBKg_AYN3DJ_sBkwRM7_aZ?IDy78PT6VD%Hx>V8ey*DCocLyky0k6@{ zuOjhI_P;>)L=~MY0AHgR@CAtGO2hY*=OfR~#ZJQPM!1ycJdeGuhMOwWga6Cs5$Ze? zJ?5lcp_^{NpLPH(vNzHECc5(tSo$hwQ0MDw<#z3UUty zulN|78jt=#O+oER>y;mbU%$oebshiRrhOMdz1v+P3mQS4wW^ z%63o@H&336A&e+u?=xo;AN)T&tI3`y{T#^oZ%p7EI=Q#$W*9y!B9@V<<8hOa=0GHV)0QHHM|QP z!3vyoAA{fX^FHXHg=#_4WXqV~Y%6(huo>$h0F7!O$s9Mqtoj-t%9Ip1DN+-f_7icQE``NUylRmVc!urKCyuhT< zfblLP%~NIV1C~I|cE7G}*!>HoZLlI;prF`y4}6ds%?6MGmbj3usqtP9fU7$2DG}Mh z^ZL4>iIFcO4b(8)G}iDARgHW_Pg2e-TeFpnJS^#u&`G@br}RQPgt<(5S%g-9OPUU0 z@e2UMckNO3{1XFnEffxt#zY^7184kert#e2Ih^}&utHiq_Crn-N@T6wUHy?u4_qJ~ zOP9@J7hgTwtu843-9GHb{NAEIq?h%F*^j=BzIGVev(jv^TY^^f6b$~>xB~FzxmIEH z%?Grncj<&^gMSlH&et9mbtO4|9`-Ej^fZa}9iOda6=Z9yZHcmMcb+uX9avDOI&>_T z2Iy9=bP0L}hIqYp{PX`F*Vp6EnoJcp{Rs6_WN+$4plX-}U|HPB0-DWybDv~q)| z-M(qUf{ctJyhVZ;aaW-b=hnNor)77ijX{c*2-_&%b0EWEwd8KhSU&EuX=@9nF%qX0 zR$;%GwN3~&J0?0gc&$pN`9DSmg)n1l<$dw-2xudqd88{vbwftwh5%TGjXDa5GamF< z!?o>y^)%J$_*EVjsM_iBn8`hZ10^#hMHEg9fw7OF**Xg|*Ml8;?Z_}ed?O3k9if6t zo+mq%7Zz^APP1rTLKX=__QKzRR`)cG1WpC0r=m!a^81(Fv7+ojkDRr&5Z(%N6phmTgsA(BxsK%`>@iTRDvU5BF%u%ttYHorh9$MY@4;ckLEu4$>pL9?+ zW1<=P_hpsuPKZ zY+-f}#2r8w`CaM~_uzhY$wAHkFQ<3dqm#jp{GU(CsxU?Vmt zyZ^XLUC_9%x65d8w)BD?J;Q7%#-X;la75KKd5@G{nD#FHJI@~xNOCx@!{*y}-1zC4 z7&&BzEKHn$NeE}6QgzGiM1UFsVnb?B;*M42eCbBnmkl>+6w_P3vhqPXc^kKXw6?%WVAQjFcD~n$ z--JNo>3_TwSO1QX8PoB>k84b(c5_Yg6yu?FVm>veZ3ljQ@64uKbv}&pR}6h`^?i7( z4x=C>e&ieZ2ZF4^AbR#2trQFAi&T#-)vnBbtUv&Gz+1rGLxGR2?yn5A&p`wW1rE@d zixkJ=tQkj+qZp=M7gwv~&lLDatl0y2jIQl3n1LhdC*kI`W=ZLH-E{}(p^I{`fkoVnDVMJ!#D6TH!|AXV^1vncen-YCSHsq| z6Ik?_H>fc%YRJ!L#(YIwC?KE{Lj}Ip7shUNsSg3q$L|5^U3haM^e;N+RTKs82rYq- zlbE`!L5gcRa}%$NQ?vJ*>StGFt>hk=@s7}UJX0i+)3em~#3x}0MO|h$C0tXChS1kJ z%sZpWbMh6?VOJpP7V-v;lx7m>NH)!Kcur>U?eTNG22&x__=;>Ic6&9HB7b z(k1>#I#x&S#)*y_l{*=^68ddIo7-L{UfScINezYla51S=>}m9_l>7ap=o5RVAg$oM_!Z04Ld?!|4b_Z_o$^#+#nAnSA3fYx*Q8w zTiegQ%bf6*Yw&HCK5!kOHaC*0Fz^iEP$m01tF@0Hn9Web0YM)VJ?Kpek2k-w@9qXJ zz@78)P9z$ihCpe}cs_^$y1uDycYbE$;0AA}10qe&h)7*R@lF74b#`uC-E;ticla<> zqrCR%n-7~;45e6Fj64~9hj(UfzWvDw3=cRH7Tahn*SMc_awflc%>k&p*Brw{2iG_a ziJtd>9|a8!O^T-UsLegm=3T38VlEPsKQZ{TDS-xjMNtY7G!#=19X=}deg$tKpcrp9 z|3zUTvn=4<%g1C@hM%aUS&20*zoe?%Cyf@&&gAtqn~ZbvC+SSjj^Quy&2H|5U!;cu zTL75iUJc0h@;Xmx{CpJtsiF`GhWXZgcpixw&XfV@Uvx&ie zCF3b@m|ZoYwtOd`(%Kp^!uX|tE%^LE8@m>!B)5l>oI^pq>|jT@UUS0*hzl+PE1Ths z9Qzo=%WkPud2CVdDe}9|EDlG^*Dtez^Ub?X_5r2J^7Fy=Pc+PaxOe*`xg+i$ymI)E z&!t4>8OdmQ_lm-~Ot~;^lp_=|=iY&=uO;>Qh~Bx%g{yeZkm}AHr@lKZsedhX7KfRM z7W|c`?{ftuq)unNM{=(f%Z&33WLO#+tXGo{F+*aWhKIT3e8B8C6iHr=JLd7TAWl9t z$@T;p4e^8i{uiGJOn>3K;-f_0W9EQ-D-!(&<>N_vGj^K_I0l2l=`3@6n@ased zD9(AhWyVS3P(GTw*JJHZ+8vFf79|wOa28#q5#CF9_!-6WEP*sXLV?BcR@AZ4xfHkA zuY!m=w9FV zax~8?gL1C>%P|TC4wSUbP}07Y!uTe^VWAHai;yzq8*t$|K?aaGIb<7FUTH*j5ls<* z_pG?ces48G@a8aBuN-lyXEVEPh#ERBeDAd(h^h~YN6Rtb=1_Z;G|bu7+)4gexDZi5 zp*3~HK;#d#!*f)~$}9=tRiH)D?c47RM5=B+sM>$I*{r``iq712ob%;*0$0MUVP*Sc z!kc}$5Pnm97j`1!n9zYaBua3&B2%Zyl&pfaZka;{dgkdV9^5<*flR>iIr(94AqWx- zA>XCxyS`a7A!K@AnL^xGE~i^@rBrEyEOW;eRE*yt4z}wU;=AO^B9SL1BY_n1ABLl# zcTdncndVl1$A0?@s$TdBtw!2LP|kL0{Z<419UKMlQ9SJ54F=&VxzW+2l%OaqaQaks zI@IC|{b*1eKcTJjFt^B6QVHTcacSHYDH8_E_$>07|9AWO{}=OlDaJWK@`ql7vk{FVsQpZSbAr&b@w(#GMu6abl&?HyD9q~$<;H8(Y#Sn zADj$aRl@@mL`kQ)q$#jFm3Dtfhl(WFodE2%Q~$e><1kS`X{}Bdf*n5?U|y*$dcJUy zD*~ww;M_$p+juhh7M7qD-a`$MoUi5`=6F!pwU8EPqtCDC4K!=ROpFyYy`&mIo`l@g z&X>-Q&w2Xzk7i^m2?eW(cVHl5PFtdT>%SLXfWx0xSvxRwyQ}kU9OVh(8~D-dqz&vv zEu1!EMKMzFw#D0j<^!oVty8QYG&XwLrV~u)Rkz!PeG5{ z6DHgfDMEprqkfk=Ymh5Rya`gk@UYr18y2n}ER7BScMWak`E8tQ+@ertuGimcK=;qr zI}s_eIhJJtspChT6coy_IQ;6do^h{F-V(`#_TT^XftZaNPQ?(Nsm;ZMZC5j^r!xE= zYIpR-sfve|g_CcEZfNiC>@1DvI`4f9iutnP7+JY+S7tYjo~y){>N|Ga?pf}LM-Z?S zO&w-c$PgLVr)P;RVF>ci+4af*o%T66P0S-zzIu9429W~Nn>ys ztr=x4FEc2dL!8(BS^yK!K>U6gj+JiKrYviym8->|#On!ndjA%DumF zcP+J@q|kjfXOr^07|w>%u6pr4{ta?JL9 zkv*fUKQ#M&V+sk>R}60LpUi(1IpC6WV~jkKm~$iEY`)xa#(Jq-s>yXeaEvTg1yO;W zuVm;bLtc*YzMjpr#j~Zi%G$DpPkwqBV;f5B!aYu^Lk8z3b(RjH6?E`KCf_!Xv$JtR z!~bInQHBVlV}@Gfm7N+G@Pemh`H~CN0+{dM9zd`*mMN``hM+m-$&f7USG-(zDle*V zcNAXkrMuYPTc_|wVCdjec$Gp(I`O0M2(yVF(C_(_GDdT14#GmbxQ?9_-g_uTN9D2t z)|7rd7RDe(5U3Io6d=wavTi#PF=_44;KQ}>zE6_^rZK%p9}sPU*bTtRBlQxD560?w zXqoT@#OyUIiu-W39FFSz%x}K)kws;*(W#Oun1EVx-d8-HaWlbK$K_(7;Y;mTbiW?} zSr|WMm1i-{o5%n>CeDs~aRqVF>&_{k-`{a#_wY2F+LhLwcE7R?dW>t!@qF^$PdZg) zM;h+>RTw+b0baAR92(^pSdT0Igsj}{p=h|CuH7>rxx1m|&EPPzqDwVBGjOi797?*D zz{B-?n)~>!=gI9>xbJIEJ~0NqyB*$luMZ7c=_-20~bM- zl1&;oFZ_hAR%3;18;_q|6ephFC6S8@Q|uf3T0y=4626;aY-~K*_5ESyqZoMm`4ucl zk-N&UA4Uyd7a2%{GhdYRe*e}N1T17MO6+acd8cmQMrQ-}IQ5DpXeh7;&MC9gs-NG> z;Pn_c%kpX1p1KiRY84Hyeh+aRB*0oDNHm^|H_+gQY37Dw0+&#QFZInl`Om7hY+ua2 zG&+XUDF*!TSd(wfD6+_2#p~|7<|W~4phk8{$@K0Wl!FnD{R+e-b>&e^3^^QKRUZ~qx2biEjcs%Mc#rU!9%&Wpi=g@(AA@6Uj|aB~u;ci6!J z?AZ(iNi#-s11pLziFnGb84jf=&xIWfGT&**$E2e@1n=VqLwhWH_gobhRy=da4~bl$ zXlfeXPRf9C>U=0wg(?=RoxCw0`CRqV^#@vq1%JW_yz+F$_;-Fqg%7A~@S~+JG09;1 zvg^RgDc?JCFZIzzCaExCkn0a<@FKo$*0~ljX7*qsHfU(?>x1gt!k_rB4Qw;ZUs3N5 zfT7^#%e)0Pt^K~%V4&d52QFjAF`Wa=+#?Y{OJUY%U3-^|nN$`Ot~G3^+YcrfpSIXS z2jf3q0OT5?8-(rh)@t*;83NtBQ0+@J*oyaLOVD>+5Bct{T?OIq!qJ^N3w;b%%wVrk z>7PB}BaMQ&&A-^r2Sx@hcY$q|Cgsm^3}%Lc1T#V~U_g|2AGf@OYDy646z*+lTr{oP zU%pK}q{ip5;4;$$QLxNppDd9L#?PptSh6_yA*bPMj@i6IRAActK-s6&5DLd zu)|~vGt=!{%ARZnd%TBxJ3#4JaUX5jy~3!dvKBtMaDi~d4y5$knV&;y5aicV|GBxF zXkjukR1YmwX199JAu1pq$8qIhuGm6CMVj|H1&5056xM1I>avaG??A|$G|G-PdaAIq zJ$`#5X|);#F{u4iinF__wOg(~@p;{k6-lb@>zg@V&qK$vd9#m*n7)*~)zgcgo&MFZiiQp!RHC_VaE*@^ENU? zk#Q3J{=-ROduKyP|CY$pHb2*IS`>t#D`3|!iI?wpzz8S~N99`8Xm$PX+&<-x|etX)Sbog7VBfuEq zIrjsL+HSysE>$Hfd&O4+y99bNUe9$~3od4`LhtxTClgE8hm-4=p~a#Si~*_BU^`hw-s zrL!M-_=dbR7Wfc_Kc&1^Fr;Y~7pM!c>$CPD$;)s(k>T}17Vn;lbaRd+iuYDFo;pv; z<7YVAbfrw*-M{wD2H5^g+gewO1_oI$^TgwTa_zcU#IszFn|QH(sL!28(|$TOD3^+L zjNbKN4fZVv3KjFshii0^>7(_tEDa;E1+1xCN#wbAh0-SQ%R)6utd1j-z%_1OPG1cc zuwNdCiR+URY!HAKC<@tOCtu$I(s!1>-Vg9FRH|89`_Rd}`l7c8TT{hUDIRh0hB01e zj}z*o5B^cBWz$ie{x#gQp?N(`c!BCZNV&jQ4ILJ$3Q}L@37)QT$G98ohYIpZ!Wz5e zJjHSIjMrGKjAOML>iN^$&Ru8M0>NE5Bjp<(0CEI-BldoNvzsAdg%0#YXRE!iToIjT zW~~iX`}%R7Wwk>KI|lpWRduWjmD>DCdKVhR7PnQZp0zd*Zdi?ZW@&fU(Y*V!Lj`;U za0c+iJbZvOUo|~Xe}o_zQCNBM>@yZ13n*2fa5bO#0|GDjn27KLlO~?aLfXod=?ob2 za_A0;?GcBYxJ70`q6X^L?V~Vx98<*fS%de2mmm$^Ux82vUC6h#MVO9{VdK9U#EVE; zS=l5M=fb27_Mr_nVQBw|$7$l_9^48CA>8{#oGON(UyBV=kux3Xquz5O@l#VjFShxc z+V%V=UjfM*qqlh~h$m=`QZ3eIwE{;Y9fm%o3*lN8q(6dS?nC)^{;uuD)oHxrZQv;a z9~cz&MgQg1Mzd% zHJc0=XkN`eLQz%hsR2JG!~`6Mn7VIf1C$^bJ>%drJ1k$U$XTh}aT9^NpGHLmItwgU2G<+q^Qh6G2_7GznI@i6u*$?s}1~54IxfFmLpdbX#%8nV|eP?yQ!A=L} zRspyadyk-(VkGbJ0r`cEoyO(kHv|yI5fK^fxHZmosVAGpx1%DD+n2^J*5QNQF^OiP zi`GF2;Zf)kcAcJyIRnoF^vc-D)crrdddWP`bXvi#z@I6KQUaT?Hl4ML>RXkqu#acf z)((v@N0^~TR3|%U!Hg%TYV;xe#;!XHCDWz1(^AEByvu|aedtIFV}Gv`R65U2Li`NZ zi`uL$*0dZv*uNFGeoez-Nfe(skyBN;(6bXY>-gy9^WhPgs}&{(w;wk`qNO2_T)zgv z=m=m1VjZv57jQIvx^kM0=N7OEz|fyX>hZ(fSfX0%&I-1!l^dwLpO(Ghd+PK1rmaer z?(>|Ks0`UcDPv(5t8-}UE*#TVm`I$fz}M_!5U}joQ;Fx% zJ|c3^>^NjjnSZIWs?ZOF*z2Y=RFteW`CI&9!-(??02WQ{JWk|Ipwp0DVe?&6fc z&;1^IKHqdoE1N${fjpWelVjv7O`H2ePT4-9*<*nRD+;JZqCJ0b?PpICZCuuDRmFaz ziq5k<(>Ond?B`8}a;$%;$wb7x9B}KEfA;oz)K>WJo4n}Yd#{%5`^}>S<4Hzt)FTRm zTEzm{)Dp!CKH^yo0D5D_!v<=Ze{ARsCRJ=$qf`O4A98?+ATw{IP9#`9F!id~C?zRc z*FEU>Q0}*G0plp=|EN)i77rl&wz{wvcp_w(6^9^Q5Q1y@J?yH(-*y_Ut;EUhy&-)Ha#y>t!kxz= z1{Y5VVLDu(3iX608?YAM-x?c8mVO1omA9^m$z7|;`uc9cA;+0NM??n%{YP|36GQ~9 zS*g$6gLvf@lt;z$1@=_5C>j>ap*2)fc~1bA6?*>AO>kz>nNVj+5@~E!SJI0w#x{H!PwBd3S+{_huM?K7|bpv*72rmbapDq(Wb% z9y^q>86#4OJYj|$*RSqeN4|P-93UJesxg>!`?dbU)+WY-P^BcSTqtykXV2~^j-uTBTsCDAaUlX*N)bFM0Erv4uLo4+J8y8 z>&fj?gu~gUc7C4IkAy3}G4;m@q*Q5}Pp2&1A_0kDOw}k*vU-j|U2Hs@}KAm?Kb*4YtJo>Hon4-i>) zmA1jI_RDon2Zx`5LLe#Ilo;mr8tuSn>bPuILQ#ZS;)~$KSNQVraK~*4p-Mm}_#YL0 zvQp1{&YtLb`Xs))2!AiY92|sbLtpUi*f(xVd{#=DpreLOzbhLzmu2rC=v~Lwg;amV zOr%ju;d^5A#Q8Y1afrnz@u5)Mq|;Y?X-3HC4FqjgEw3@d8B*{?0NJw*uITca3D5TCS1dl7rh+BJXYkn8b;>sf3VS7WW(jhn_Jc(`vCCLs|N6~>3+PA z7%q_+IuBWw^Fc`gw)P}(N0fy}%L?;e{v}N=Uw$GWM{oL>JR%5Dy%hqZ!FQn=v8KIq z9T757C};*}QlF6)cy0-T$E@4qSr6iROgZj0s$_=|0Cfb~EC+vNiLF`r`6RDhi2>P@ zyg=D=DIp}=bqbXaGmdr$?A@tYJKlfx?P5EcQh(ZA#;=)xR; zbW)_9x9^^D@?d6BtDL*auL#pp7vs)`Q!{*{%pP#PImxkDN|7(Rsd46AXA9iawh^HR zzPnHCuC>+^Hv?;vgfN5IRkV3w9Q_0DPG*g*h+B&E&&@waAf#Cr^w{)|c zo2)Pj-}7HNWNI!nubP2z(h3Y}aHSa>KZwl^0T_3UjaRB*;pzd)In@ke61c@L^uj_8 zX3hSq%@^jyjESv^w+mpmgC6ney7miDiH|s}TE4ln-ui{NaYFCe&HEk;H}L@nKUu!v znGfE!>QX2N}eZ-T(7*Y)coa|6VK>Z6SC)O5rti)?nWymMkrpQkc}NZ@2?i6^rB!&-?G==Dx$V z(Q$j9{N+z0A<4$-&xp*U!JrIGgZ>LyV`-T18k+-4sN6;Wo-%&8#~yLe!Mm%VLygV& z&CM+}U1!cw^NoF-H{oL3v_O0RbGXK~5ekQ}h&O}h)FKSHMkJX&+ZW98Nm{kr_kgae zslz>|WJx94W0vGkLVc>hw}4L(EKv{b7`=aW+f*&#g{{HqD&!n-00&3KWW+k5nq$i|cf|dLTJHj7>w_H|T z70)bwJgbXXMK7Dh!VEL(BD%=+^hX9tBx*Y?EXq-Xg^=O3L>>Ol>cEz&e)hr-FlXL4 z9AM^AH+V{|Rz7zRwlu*DQ#pScnI8nyx-PoIZKmZm`s`=5A=97Y(QR;2gmB&zdC{b| z^*u>6I}5uB_Z*V66%-xEWE$8Ss3MQL>!$9|juY2HCZ}x>4Uf=^uoZB;K_8;9?zRM> z8odNV6$8d)HG+1~2%2`k?AOff{17u}5+*}0c7X{~CqXA+#~VGnF!5qQFcM29?Lro0N1%X$YNAUDJ0vK2D9Ec@rRbs168mys*~ zTs9NY!N9dydau(*Hasu+GgO*Bvc!^BuI5(Nu3EWxi|L?+ah7W1n|uf7b?>!Atabw9 zp~JkPyN=9q1ar91iyYvbe1$}LFuU64EA|L&XbZA(*Z$5kM~B(e6w1kMZ*Mz z8KiqdOJtr3k7K>X=c1O5q6QuRY%+^Dx7F8NyF<(4h_<0!8j0yJF*teYe*A&nqnEe) z+GkK+oTN4(*-v&@;c_jq{e0p_M`Q(bFSU=cV8Bl#BJaJh-_N%}A?h2)wA+8CKm-KR z@N+L>mzQjJSb$#8r7VmZE{d7mu~Hhr;v(>Ejm4jFXP&zX6Qjl(5vBv2q{s`W-$>H_ z?E`ou;~n$Ox$7HlcNPCNcZO3k2V4_)Vq|MT-s2ly#&zZaOxYtOdp|h%;dTPUhqtJN z*WW%{%#TLigmS_enN^gIKA_objKW2)FE8!2h>joUaA$X6z8|3-BDWRoUHm&ObRxoY z3)9KcSUNfW?$5mOe8t7Y^GL%tVLn<+F=*UfZX`Ctfpm>Yw%=X_1j;?g;I}34*xcKp zsiaPzG#OZ2(?b_QD_j%aVm0AG6K)et_8C9EI`fL{56pENFBxBAl0q^?_~(^=n&LBwrK516`Zz{Qy+Kn zyAGcxZRlQu>(R!}+4E|Zq@r7|t@RC~mCgp{fu`$%g?HTiMrZ)w36KeHxc~eJGbZFF zCx61w%%%l9VoA8MYQM{PftvQVNQ{3(ao61Bz^y`FyuEn>nu1R=u5aJW-Q?$fF_n0) zJI#!Jn$e6Gsp#hs4({p~xHsT7)9UXk!3DW273;L(Cr|XLfu}&ls-~kJT2Kmr-8n0H z0^tN6O#Fqd?uBKB;o*W?_VwIxt9z2Q@Kh>;%`r zuAz+k4)JHVUZrq2gg#Gx30POq>TOmX+(q9Lur8mcyyi!a$h%pkYgadSM@Qf5$pt4U zr5pz@`?9&b#|7?%`3Q-m9`K99n9p~d`)pA6E!i`8RZH2`Awz)m*nCZ1+lK92OC)f z1=5P?Wj&dxJQTyc@z1@&zUfz=Bz^f!-_U}TR|ys2H}i5R!eLRix77SeW?<9JOU&A1 zVw^|B`LBpc-l4Ua_j;~>|8>J+i1Gz3ae1?XgbTPz4z$tj-;S7&#O)=CZ4cej0hLkJ zqHYye(Y95J8YV3117nPYa(b1^Ny7o>=xlBOf(#T&=p|V-3WbWuP-aD!vo{yQE%p4nkOUCStfY6HH?{ow80(52qV<_>!ikC{vcOnYL0l22Rar-XMgIBqf> zm$xTy!`4ybetVX#>l;`-!>DEZFu!ck?S-P>+Ytxy%u5Ux!+N-`YijbRwJy?QgYM?_ zi@EQKhf|AMM19iSBdpO@s_+V%eIa!flN3ncNWQklGWw&A2qh>zSh;65Sfs}+Pg^8M z5c#LwsPj=r#q%q*<7wd$IH4B@qb&^uCE9^P)~lFJi_t*@|ad`L+zS6qGD&@Xle=N0Gb{wChuPn$yTqPf`Oc{MK}87TUlYtf7Ox@h?>l(9@7uug8FMy6nrut@&6lye%!s8(uP`l)IIl%T4T{ku|%HBDm_`EpQGiL<&= z>esaQGRqE5c9!ot|8(5+Hw>0yC(rx%{ljfu6l&Laeg*ci?@EE@y&kh#y!a8^lsk4T z1=Iffi?VjgQB?KO0!`V#GZGnGsN}DOiwY9Pp|GD>RyJaGRR^s!XQ%CY&!Y<8iax`= zZ;YO4f44GFTDkG1jl1~Ta5OY3L8BE-0O#O~Gwf{)D!Pt6QL7iJSSU@;;A+2UpWmga z=VYC`5M5yjXK@tGsIoCXoLph)CQIMiIQxW7OY>_hDzYOlU4<@c7(Pco&C}-Y?UU-T z;-5x@N1wZ5rYHCnOSEOy4wPB1GBab~uCl!Tr@QBao3OryIC6M(cjT?}`<5uwn5guO z4){Y*Ge6{F(9F3Jr&1(bC6YJhP4mIKS$#gg>u7M(6D(=<`REzbXWcEPT7hQ_(|U%q z{GLCKUMrTEz1QYm>OkaW`S@vyJO*CkG~>Q2aj=$+-VV$qI+v*Bfnyh*@KMt+P8hhZ z>lPOM=d*b4c?xU`ru>fho=oY$@p1l6$GxjqscpJs9sBwc>nYnFOuslS_0KQr+< z6P_+<0PUkRelI$Xh?X>K{XRHNQtUI+kGmC3brh7-SJmoSgL@0V8k;{m$R+R6g~(GL z68tbfpJ2{+;7^Fk=_%HvK%sJuw??DYmhPpkNp_{$iw$gf-1n{_hF_1exu08{1&uYV zkp-USK+gcgP~Y5~Z^*fsOs+vSjVRvX7Czm0cUPyF)m(nxr@*x<(bkh? zNo6xvOUJX|KuOZ@q6i^1-?5!vOtmkeB{}Eivc9%{ z9m%#R6u+U}_?y7jlPJ|)8C62@_}=q0w{ALqey<@|eLbsKCcu;X^<{!Sw=ylK*^nY_ z*OB@ekF{8jZ4Ml7&b8s)jO-@s2M0`QB;fgAbto*-Fz%iT3l&ia72Q#UMM@g%-ew-< zpdck@`T45%e9~trCj*7dwA6;<$Pzs2Fd!^Kc1!S?c_7aC8VQ@127y9t6>JxK%pMeI zt{ZsDp6yX)FXJoeU3Gh9faWz)OQ%#xe*)p%xyEw@b@Ba>D~=e2`fw|;Gdz%l@5M!B zrkb~=V#0Qy;#S^4@XVA)nM+r{b6m526*vi~Q=O|r~CsEJYLMZG@;ckK= zxPIe(#l{nk?g@H_eQ~12t)@X04Gtbyqz`+=-5Pn%IEVXbYq+Pg@3Y;*9PVHC{If_y ziQe3&XvoaYG&S((g@hm)*i${$I&lkVgJ^g!6t^*N+%@@0U9^P|w0frL^Ktk=2Ko7ER-XI!|XzMC72% z;AmGOjotxG?|G9Cso#rPgMHzgM(GfLO?N1A@Ohgwea^uF2S2X~aT0IO1&iVO?xrj3 zzNm9R;B}w+g21&=V_Bky*%yyZ?JVk0rNP~1%B{jtg{t=Uc9}~%jYeI$`^|wPa>ZNQ*$O##S@!<`T-PEV1!A(5LlidOr_cWcBRFPx~52IC`A06M*gM6ft z&wcX7)!`jKUP0kh#Z(j6&EB3|d26_>?g6TBBwKi2!DV);4ZSph8{WUl#-L-NuTWaB z?tpE`F8K}wWAui30EQ%Hl^g3v<~-<-tzhkx3`H{*DyESc{J_n&Rc;}>pXiz&?LWV) z(#t&0XR4zIOFpt%9|`i@5;9aPV~lm@^AQmwQEa)rbNKEP)MV~Ep{HX#ySO%bF7a2q zA#FWt=?2fc{dBX=&NEEh0T`wG-!Ho3+8HCgCbZz zWi1hhI|#CY^Yd$NodIQ%P`Q6;%1!_Y(J&d++hZdIJJ)=b*|QHiJ=2w?U@!0AqX}&x zf=yhuPgh3c>gK+Zym%N!3P}WIbIAe)yVU2!A0m~g0uS~wie3A(hjr_{9wzk#2l zBOfM?k6aS)qHGfsRB5~yc;>ZAdQS%AReJl5H@e#|W}s;G-7XcxVc9U1+vNeGHn^%( zo6$Y88&XBu_JPsvT`G`FbPpOsf5&y)#`;N2`Zh&>nGsre0Ou7x`2EWVibNJK59kCcqO-J|@g?26)^&#gnVIw`CHOa2HTU{kE$v~oPPS9rmL7-E` z!5QDQMV*LYR{3YOQ*)KijCE@U^2=0~T)KLC&qs_?jO-ab33JS2yb*&=JyRb5zw?~W z7Z(@e46X~~VgT^MBQm)Z7k&@<^{VP<$5Qm!tZ!4G)PMh;S2e%>`YYl3ijW?lRQS%u zud_2Apv%a+0MC_ZUmKOLFNl0(tMlodUJaA8OdbI$mOWztGL9r%HVW_nV$^v=Jb9lW zMM7`%!*@<=n11r&f~Oo+EcLtWS^>Gwchus)dMSz)wWLp+qxc`*a_~hRzI`&qTK^}Sv4lw1KUMX5coaML;!%S7C;86e<&MMv3mmRC+o2KUM)Sp0+24* z!y8%VR#pRe49UY^Ucu~7LHhn$1Z3bVm};(zNhc=Klv&@q-mbRI(mfzRNoQudc8_#G zAH-kV^W|bFK5SCoLQkSl#(x+09FN%_gB}g(b_!Y! zfT=%kZ=Dxmhn6GYT3RaSH|~cQA(I>7Gx?QsJ!#?5kOagC%V+08(~HWw(1g|GI4Bp2 zy!MNPWbcyOe$z1Q3=&Z#4w6_^>fRPHj_TlCa>qpkw^(IkomymNw}*?WI$(9Tgn3f! z`YVnLFVGDSR2XMF)PSt%H+1waYS%*-@1@Ms0ZcHbWGcj;EiKPZ};+(K#1&RNG% zn<@}akV*WxUo07)J>ra@nZ&%TYiV%SLmG}W8acH($e>WXH5;XjkY;jfeQQ;)FAtLp zREds#$8)8G&{LK4n+E&dL(*~$BbC6`d8ou=lT1giT{QhR5gGU2<<%z|_s`I2oZ*t_EKJmcShW;)P@(&f9pGjpBHLUpjdlklim{WOd% ze*XD=iCMHw`)B*lja_%kq_?@mlx6(UB%HVG+FKyQd>|^}RJI-swzR3*j?45FI0jEO0+iTke9lZ!N>o%ls{$t#EfdRSz>Yh@3 zklz)El)a52ClhNVb^q|Kb)bui$c0VYZ5_;3lC}?o3@iD`s$}*;!GfjmjG+QgXH?Nh zFH#-0*R#79v-Wz=Yq2&@t?ew8e?uEKJ&R7pjo1a=Iv-*;e*|gG^79@+wp!bE+@SHMw7soGnJ8mLHyQ;dr2?c$5&l&KGrtv+hZ+~w1Ieo!-KwG{8GAFD35~tk2D(V|B_}D^kuvZt+mVAk zWBWO?HeXcP3j0*C6+ZfK^tl|?k8S<8c#X?&Q#RB-!XLI7usQgmV4@r*(~CA#dKR7i z?Uy(7hvy_dGSNk;ld1o4*Ar*l)h6(gXv8_k5M814X<6yyjCRyoIqTEXd+Jlde<3yF z+&I;_3;?v6XK=y{sR!q-2lqy4|Bh_&88jjw%IUckmO-K|eeYx#_40HFPmMhajldc)LU_J;t&!CZ{zof>$dPQP~6 zw_nIL~GFmZ1YLhsGrATwijL_6{qY)XmHy-E@vo_iVXnJ8SffPZ}B;y`AGP z(CD%ZrPIe>L~aui@d*6dPil`I@!;X%K{~Jb<{)3J6@3t?y8ff9D2wO~e>pZ<%dVA` z2iUXK$D^Gb1I==a&7$%a5=`wf%e*c6V#!g}_j74rBgg)UOG&bG9!47y3cb37Zzm|o zS&pe+JAo1t9_Lpz*v&ysd_Kt}Kzg{pLH*V7%26j@(Y<$7d2%SPA95{hbAq0$PlWeM z)zp&{Ud%X`?h0FXGmmUb_%hoW)3n)H0eP|v-VbNOsIp$|F{6ZFaubcecnshDg;>);@%!L7m6y((#FID; z5OiT>i;0fE-56i_pbIR>vl~D-40!p2J<0Y}QxB{A=IN1VDNvF{*25c4XnQ|XF^bvB zXLkdfJMuFikj^l;=4QG5vd`qYFjv6g`i0$j?GkiIVyViVL-RpUlcQ(M^?%1Y)G^v^ z*k8y$Loa7A{>F@l7iKCh(2D$?1Yjna9}=Q7H$MjugLa%H#yZ!(PqmY)gxArL4clK8 zXu1giWsK=>v*%}45GR#rfsBr9HBLF!T{)u9MH--crEO;76biNe#!N+)vJTHv%$uo5 z7#G18=rOy;)pZoA}krXx=90=np5Q$;iI(@#fAkXaK&QZ~~yb>Z`(9A~1E0Q~)Vo{}Lb2%Nonbo`bf~ zNs?UO^x5QxKpMWkB@=0AyQk{)_QR(=+W|c#|=4p zt;;u^5v+)`Nx!BIwD3j3*%-)-Hq-aY)UFS0X|;?|a$q&DVH8~5JAvZ9b8@m<8&HTY9piV-AJra+aGlkljS zBP-5(e#ArIYgyT|0Mn2t+3>eo7|F*VPK*K-xZ4&OD%8Uwe*g901Dv5RUF3^gm1viR zrtaREji*i1NlbgaTG<7yoa?St&J~(Yxex7_`3t|sb~QnRaN69=N)_{57wdO-KoA|Z z8`&%QKep{YlwZe!MW}mTmJ4Fmf59Tkc(XFwqObv7V`|KdNiw7}$}MJXs2~h~5&NLB zE#xW+MbEO&a}-#D*ZlrbLN{eUtvH|i2XePad;0XbO8BZNm>-)4wKr*4ycVOweK<$<*FrIoLwzTYd~p*+F!`l_StB?}k!a_C zyPr;sXoB|dk@pK{>O-H-O#(*&NMmxbYBQ+O+=_m&n3CONq>KCM>{Wy#X&=nQW|ekA z8=2+09$aej6dG8voYK;`#9C)aCfcPVBarOdzrlIp=2CiCqKs$fMENr=QbBU6_Rq1_ zE88es07fnHmviNJPPzznoij&dSIYeye6FM_Yv#-Kec-eRnaR~Tj`C`$UIb+4b#TSk z44AC4)CFgHs(G&?L_R}dlJMtnv4;vmVk2jBb#9g}2W*P|jIwe_Gx9LGUT;fCc=}%3 z(5IOVH@%XOBsS+oy`YB2XSuCgvCVrs-rJoqyI>!n8Y*zK(-__ULA5qiR3^OT$c6CB z+v$7D?BVT0dGOr2`6K{Xz7fnVw zbe0*)$vf-oWjKM%kBy0O_$C%*%*|8qTTH$R;$Z$-4dd%I?c(}+R^%3OCyV)}>OWTZ?hbkwclyAJI!<_ETCXO|8Jq4|(}YdyM8 z;j$|olU%rOg$+_RVOZ?CswSc*y7@h-m&L)gPANKeMik2eU_l}M-gft>JMh(Fv;8H=lmCjPv0Em1*km<^e&?!M1oznGWso1Bb zs%lK);8}qG{?j2eAZme)#KV$)WOdo4HpJs$gfMz}$M!16kq6 zZDNVDM-bu1Plo9sZ$y5p%^jvdg_8*r<|?d|QIU@HN50%T?{OcP*swknMA;t(ps<36 zv}7(lFz9;}1*9ZU9|Z+SbO7>IdS$DUj%+EOZ=U=Bv$(_f)BxUaB}FA#7x>o69|h%|2tuJ^F~^V)FxS zD2^wTI*VvcpRHXcCvvB@z41PvWXp*>XACF=x`=La6xi;W2RI0%k9o^}B~-c| z1A@6qIyA~OV>kDxP+n{wDz7iXLA}oki~_v+BPw4*?lihus?622e^ zr+l`4R((96a$IB1^?N)}qZ5GP6tP!nKbXd~H{$sxOlDVCH^ zPyPb~L_te%E>O%iT=Xcf$06sap1OoRa1lGbN62`>?hDlV|H`Tu-3vFl(24~!h?){? z@1SyeaS`>2_p9pxZmQw$Fl@ zGa{K(rfLwoxWNB^XZDeaM8@SG?PWh;i+i&iv3}jxhMcPED!1IRqzT%#PgHOoYn~8H zjU=8}qOJZl9cEX6f-Hds$7{s*XS1w-S2FB^48y`HEU-8^-R$3LwP0q+V+j~sxPmZ= z%(SSoGVPEkc3k+2IEheWRHWn#K{Lx5r&H8UzHEH_4?LM=grh=}`==>O0o@JHy5Az! zf)~Nv)rGap^sreI!N8YmNA3?cAGL^;V`CfgBSu|(i|DqAaR{RN^-+99(e~D}TU=a6 zgSR}0BXf$9m7t}^z-eYo>sbrNxkD24-~2^Y8CT1w1i7H27n2Ek4UjZ?E1gX-iOC|% zxk#?R5xj29P!6pwi$bOFUyVSqiMA^_hdqWu6&9?~VM$P^b}_u# z(Sy)IZP!3toueIl@vB1|Sy-%GqN0L*zJ)*PQ(wMQ%)kajv83OUQ#D&#)t1W>`^eaX z4@({!F%FN+fK%~*WA<^;<)Gf7W#`~0`YKPfLzl|-G9AurVKUFbcf~-iYSkYLk726D zbFU~oO7Cl{m@k;9Q?OzI2uGQGrE{QE0>=0?HMKciEh9%80_yef)7Bg#Jy2@BZK+MEDhs*1E zE$R||VP$n{9yeKYpnGB2y{vzmn5dwbKU=EganwKjmjWADkKIvWb!!t^E0FY7G;L`h z3~!YSp8mrIkLfgx7wkUyxpZaCBLBV*kaqob%!!-7Iz2VRMOWZOtawh3y9#WG#$)T4 z)`R4nUpsU*^<#ky$>MF!AYPbdLAK%e)GMd= zT-YuZ_Xma~h~J;*rsEGJs%Yzhyn}ywSx`BNP*Kv7ovP7{r$8JU8_V&h-4Am(G3Li< zp<1A+K)W=*bJsM?hxQ&1Gv8y^=wwa{gzV8D#Ook^AniHaQ!u2WvGB3rO_pIoYW&#F zUozX`XXp3wxJ@IBNif_kI?3%hF zsT1{|ZymkTG2E3rJ$(*}&87$O&@W?m9S@Sgo1PsQ5m18f247+M*9*{^psex!) zw+A~LPU^{5P6I!^O~frM(2;|g2g0YfcbLpom5^xD>vhs2%@$u5P+3C*Q z#P)PJh><`;uOVOw$Ku-!iIU zx#F?H*8ebi+1;7l;u=nPYkyiKc_s>mS}lwzuJsMkD1!Vk!W82&X6&{V;URY0sOvyv zE1E+zzrSr(XUyw`I#5&*+u_xYR7aj~6Z;^E)Npx^oPY8`wo5Mh{&09{Uhp{zslJ8_r?NbtGkQblvm1zvVgV{e8jFglVRtbHUb$)}99v z+cRZVrcm;)`!RHk6uL)vRG6f%Z;+YU?x#p4W>)cqA{`NT=~VVa9^Uov0ztr%shXK^ zDcSM&v~EETQkOxYH(C3zzehY;0M302VlY8 zU~>u|YyQeNvKng7bU_;!J<}UUUM2gBMD3suXgR!3> zw4J#H-X@7~M*l(`=aaqxf--($(IHmX~P1j`WJXqZi&@{d{h37b<6s)VXFqQ737$98W zHuiv`-2%AYA=t2Urv|uKdrRQ+g)&}k#m~(z_GIZ~LW~|7Fraz^%4U8x(tkXwcHGxN zs^*n}k{LP1&f$bTb)iXMn>{fY9db(y?*d$-eFzmZGXz>`5DTCT$wd)rb8-un&Ia<+ z7+4vVUQ&WK4E5(HH(yaodRaZdap+cN8z4cV97^ZuFe#=1S|n^mo$^&HWU>ci$-U=o zv=h~Pg&DT}0CAO%O=Br1Y05NOaqfG+*!UU^gU8z3w@LJR2@L`B@#`Cv#@dwtXQS>a z5$d?qUzV7C%Ex(qjof0^yx7WN-S016M2R)l+Gc$3^G4cG&Zq4S1(&^oFaBf+?ALgG z4d461#W2!|4$RD)#`yvulpx1Kkm&EmD&5G^WVVoG$NYG7Emp2f6PHpEKM3ovOHJqx zdjRVI0>!`tD3zEFqa-HfRAshu`Nl#nCeq1-WbbK% zVhmWiYgqi~RB5%;;B%=WMJh5T>OmlbH)K2%cBef-c;#ao-vhg)Xv}?3$~*t;yoWGf zIV4*!uoc`V)GDAf_$#KKrMw4f;}4)+UtFY1ZY5x+rWbx3m2)ZZ6_orT!5$#J^ppEX zM^Y;+cVK(9^z?c%YIji2Qz4lOI9dG&7(8{_4+yyKe;FIp{p^rA zCv(mWnPwVxo9H2PW>Xv5{y6Ah=3I*=B-a3KC^)zaaCX7huW9kC)geMoKzcz-TynLo zV(P-zOSrzyxR6kJ-sxKCX9^!ui^io)j~LH@Md8&YYz9y#9;&xbY8rFj4fn_fj{L&L zbDJ|qZwI=?Jix*tPp88MR{Ni-&y~80lamQV{9|$XST9X2CoSVEjz&*3q~DPsWe`=2 z!n5a(fQLI{C~=l+?zqi&L)|qQGNIX<0BCGoeic``?}UQX+HymP{|kfr7Dz{_rzY)P zHnj9GA22Ss_m~uSJuPwFrlS%}N$dR_!v;|V#FTa9TFe$dA@pvA%_l*Q1Po-ms{il- z*?A!lL7ABSE%r!260}TIW;L^NY&_Jpgv{`aM8u@?hLUZOrpV}{sEZHqRsbn@RzMeN zXEh+IKizA@G^k$>EDdG-Vw6-^iw}YYNvn_J1zM|-A7Ru^_POAqtCs5;6paN2{WW)# zkgayI96c~Y4_{k+?y?_Uc0n*WXyK`irLOP3eDJ{SPA#xzW&zn5ieban=kmw-q;D?7Coi z5!ah%db)rO{-_S@9nb7^%Pn|xQAQ@ul*9a7V>TT_Z#pNdx>{hK!My*px_I@m0J zM8z@x?fmFgv*_H9ZUtyVejjq^g_9*QxaQ>F0`fZrY|d6x@KV;jeq!tVR<8-|;l5eC z#BbGTzfM7lcIGr;EGbo>MWGVvJIBja3?UMfQ6!SgygZ#FzJ zdFKnX9bvNwS?J*Mjm=v5gE3)~IB4B^J-dXo;jc2muT;9@xnBSUKxjz^!-^>{!6bQG zs2;5A@L9~+moEN?#jAN?6ngeCFq+0{C2jhtC?3 zpNYDS0Xl<_QUfPmF*T*6pXD(31Dy`1SBA0<9sr!lZi6ulefm50vTitmQpUY&>jAs( z9f%y?FzOv-)m5#F!xowJ7pcj+)->_03uJ?RlWZMl1?!ss4?I`%p1Q|_XCwPQeEH?Q zQvQCFgoak+8V8K{b+Y&yBIyOXa4*a8<}ga|F(UNkF}pbiY6Q=NuI+M!p+}LK4a*t- zuk2LbZ4pZZ34NRu0<5pMaq53mJ1-5;s|ax~?r&9h&5uDr*?vh`0y%$4@#$KbWk|{_ zEOoj6jwByW{Tx6$U^!`!o@gWha6GfTma#tZ7NWcS5%Up@Qc{@A5D`aN; z@qn{s5sj#vtJh!UU703Z)K?H5Q;Pe%rLgm;&LtYp}uq`Tn<_rqrL&+q&#PPYX}; z{X}5?_Q=dWu$F?&%MBXt2i8l-AIqHlU9wbcq!f*H8numbEXZl!zBF2KkX$+uZ4G6R z#%_Jj^I+`Fi;I$L2hXCph32Ne#lAlc>UTKe76MPROrmz@d~*V#e#{8EMls}kYT{{F z9U3+J6yoq1^rT>^egu=R1~(y`B~UU$o@#J_ZRn>~!XFWnCgi?LNv2jd;TGIdXdL2&Xxx|_wOG$#CdUc35o3Emk%^e_ifjwo zCbkXEd5UUJ_hS(EU~LZ6^a58#ovaON;I2%-C*-yNIL2-K5)uA2#etl$6wRJt&t*WC z^ERTp<2vD<)h(}@wZ6C)%ZF;0na;4deOxNKU0C~lFVM3A_U zsmbI+ovK1l{T~h9w`oifzv{atfE$AT3|if(fz0qjpnNIdK=}gN-C+Dc2kD{YJF0e)8}A9H7rxf^ZT6B<;8B%E2x?fEcJ-pL z~IoU4M5*?=!TfmroC4RQCXgIXRFk=GEGlVfl|h`=j+gqkw!ryAWPBh<&qJ(%)#B~V9y5ghvsqq^ z$=YWY25S;euN*rzqR1V#`NI{&azJ0cGYZ5lW0h-Yv~5lL={->}{qmsOXGaWJwWfal z_$soK2y||aIAXR~u0gOqx81|a7=fjUns_P!sLJs_miymB#zwu*DJ)ET<%}b@YXb8a z68L!Us0@Kbm0g_riWYit@2EZ^|`pY4^Z~Su6?(&XEf>|*3g-K)}vp=@GVd5{Lj&65d zjNt*BW~$}rJ`q*P69bR?>FEe>3|!SM6>6md&0M&E9eZg1L$&@9(lhw%|F)FM&he2g zY~Z2@{`OYKUGoaqPsAOoG*e*(vI@II{sYp9O)mESC+S{aNePX66fPX7JI*D(MiKvXFJAS9YX<8VC(V=yLXJY=P$KJ$Yt4IC4p_(%k-luMr2w z@$jQifi+X0N{TT@Pv8 z&ZiiGNg6sccXt&;ZbPh9w=Pg$*h@T^UU|uzeLI^=SRhNPwxV_lcFkR4CaIvX5IHsA zH5e$0A>8)bMw~vmB^z#twLGw(^&zcvZQMI=iv&)KkC+sSJQOO{3h&+;ypyS_lBk#m z7xArjdK!>Q20s6CikZ)_nIWoYAkCGp9KUHvN#`7JYXHtv(|fp8sG*QNOrELQK_8Ws zsdM{@Z>U9g!yJfg5RgUbBNQJX4(vT~`iUkW^Om=iX+7GLUU)nVVZgPWGWq z`mhKH|DH7d3M72vR340epx1Qla@k!*x*%c1E8f7u%e{aXdZsSA6>4p=O)LsU?-jrA z+JgMvo->0dn6%n!<1IQ}e|FRwZvS40DQc}ISHn~8R*;=);$L5Ru;*af52Ms zDEONkn5dMP0|3xL3QbLhnHXSSsgvyc93;=Ap$d3K7zYMJKTLs#cAd zMF*{dt=-30H8uE+q6oCx!C{xg@0-EZJbaK?#&eKwZ+&HGxKx^NbaNYVOU8JN8ESF> zsf0o#H=uDK4FmCF0ux}v#4ediiVHuMuSTJrzax2HY{C#0xabavpIVu{{)cp|F5 zaA4;SdrWW|At=AjM@EiT;ViU;sP13Kv!6XjlanJO0FB>oy3cSOfTg+n$+FFD(d~NI z3@({qOz%3VS{vm7RXZ(e>6X^!V7yx>!yPC)4Xv_aNyR>$t?&HNX8;KaUPdzhC+Ia? zxW+^R@d*#~Q^NRmxPNPjlX~Kz$OSv4nY18sg;XoZClc?g!+VwR(e@mM9U^IvwBgm& zI2Cu9n3?0qZE%GqOZ>AANt95W7%}oag3*%0Y>%JR>xN&@_g@7C3Nn+;rB@cbGLpf9 zqn;70_i*RL4Q5Jbykk^N9a_*e&4{R~Dj$iSF=X_1ciBtV?Hr3+OY6D32RD2+JKRnH z+n$J^g#>=^YOv&h7rxF~SahU~-KrKCrW_0GQYasCjN%X_vQiT%N3!)u^QH31732Lk zsry1w=h{z%v)2j)^`T8Dxmz1WsND|ckR&FY+<773%Kw^;;cOm-b?$kKLxHIUxxvZa zmn!Fs@D5wH3KvlHR&%bR9p1Ph(88|dInI5pTvqcmjxreUo_~P|sjWMkFq5RvFO&5A z-t5MIAQ4p+$7!pspbV@5Q!2Ou!ou<0>*iG$RqF~o10Urao&2lg9h`#XBe!*&cLQ{V+~(0F}nczctXDinI8 z1#1HjIpfw0;Ie!FDp+_4TfT9|@^$Qy+n+xVxv$xj1Yz^L9Qgjx%SP? zXYq{EpJSO>Sth2oBS`3v!Ru1--pM*2Qc^l)AM7)+;k^FHTVd6c1;UV|dBe&#JXKjU zuj7YiH1@aPKt9IXCnA+uGZ9vonzw2783|E$d}5*soenXSJH!WaxZ`4UKKCgEoYU6V zCW~2T!oCw<)IszwGST&AsG$nl8a)sYqktJ0Z*8r9e-gZQJ4k7GmPp?lFZOQ*AsDP~cR4k@Z7F zNdlwRj>gg3hE>LHqt=_|(ek;)Oov{%==vY_&@p^Nn7%QP0;8h$Nn%A7=ydS*_xq31 z(_!j35|4+fkAme6Z#<@fOCG-`Fjt=nt=xYyU?1BBnA@MqXdUjr2UfZ7EVJ?SI=t@p z9oXktvohuo^ZlyGKHm2i9)Zll{tvqmbXx-W6;b2A=6m_CuM^OeBI`LGKKn)S#LoHo zJ#Pi1H+mmkN8?i_lSF=CT%f7aW7dFYYJ;0>bzmGa6wl`ICu-|D+13OY|;NlOo(wPgF zj@12~jBs0gI~-8)OgS5D^-vboa+P~y-2d=mNiTlHn?+5b(Ky~BClAUgFajV$SUMUh zPT3&@f*M68amKS~Ob%IMm<+f9KumvkkB_*2(oS}zGshdsMfZDrVmc2cUr_@}K1#lX zw#yU7?l#EKCFduAewX909=#U>zjyH7e_9r;MEH%r9=WEGEuy2cVC^vbpK%Bkkyc)q zmF+nRCroSnnSmSE~W zg?|tUTzroAl@xBO2u-cBY3*KEPgVByjY|VG@OR3p6nx~4=*33Jv&JwIXlI*abSTpp zP^ZCT2W0lwt}1&S*$F(I+N{bU*5~$Lx_bC}q+TaMqUz6i2P6
  • UGAfz&EWY z5B?IcLjnz8kN~x+rG=VH3FZm^>J?tSy)chvWBmgWyjoK4--S+ra zWPLy!6&Ve2Q+O9z>{U-U?c8_FYSHz-vfXFO&y;C}uWm;b>5L-L+(qFggRTAKK$K&U z-=)NwW#9gAATv_8H}@*jdq}QMvM?bDmdgK6nerB0ZCh{#KgLrFT{c90m=O`;Xu%_6 z(ArTb8oYmW%u5~N^ndsO2lq++&++c~0*3&^ThDd+dg$j*@N;ATz^EX%%TM6WnV5lU zhpGvf>Qkt&9x=TzVrw#I4qeZbcY`C|r}20P%A zt33cSrkqidXxmcvln=FfHr#}qs{+jgQRmUuMLlcA^V;9oAfgmCy-WG!O6=)vYzc#dmDV&@HPMI%FSu^-uC}67cL%hrT28s5Ia9gfw zNjW%bE*bo+)r-~5vZ~{UM`I{$Q3rb>DTs{Ywx=LC*N@J~@c7u9nez1lv;HD5Tl0X0 z0VBUZ1&mSbCDn8CzXyvBD!_Z6=eY8<(s^);+3_IMsp5fwKOqOh{|Gl!L=tD~j6b(8 zxaZ}O#$Zc9q z(!O@SMd1CuUjL3?)JwnV4ErU`hSKZI=1~zp>W-fzs^{&idoFhIWdmbfU7b;#S7wNm zz4>pef`ky|i4okZ=V!$7zNSmBXG^T_Wz>@3RMp&vlM>Sg+76ucuZA`MTutLk`Xp!F zn)+QKSPJ;pqgcP6VC7>~8U6x+`A~}#p_EHQ+BgJD#x8!8yngN-EJN;1?ISq~Ls(Ai zzJsH~_1UrN#`)&2=cWP8z$oYN@PbQgL|Z{?3XK8voPSl-ZG)5Q$ta%HcIK+styB%H zpYQO_7p-7DO?R%={Qsls%j2QmzyGHcrRbJOB=;7{Udg_-D$2g^ge!aYWvmrlBp0DD zmhAh!uO%ee8M{%Iv5sZP&hNZO-Ou;;Uyqt*-tX7zyv})^=XsvY(OI=W-l}qeM)4B*Nz+Za z{i6aIiG@wghOghxBx>pCkPdL2NY~73>WlM5ZU4Y^1wquOkQa)N)L)a^%zx)7HR7_` zvTnB0c^P~DmTdUS(UI-;QVmlT=whp=|4v`0*+Oh|bYgU-HeJQ^lS{?R>x0J)iJU(-=G#13Wf|M=79=r81ul*ZWyDKmD zOgnp7VoncW`bLYU{6}oO#yK6OyqtpqXZu3t-|fM$dnnCX20-D*Ki?2u>e)JffbKQYVOPu&ymP`OR=XP6%?CaUh!Q?zxCv#+Bk+_)gxXr3A)|Ryw&vlMOsQ z$1|H=8Wig3v1Fy&lLhF?*V{F@E@DW(Vq)r|g08y)WAEpUe<*!P3KbMK-^eu6X~DV> zHYKjz!tM!hsCDEU%Vl~$U!Bu1?FqLT-O$8{Afmr_<#QF$XWx#T@84=>I`woOEvdOS z_-28-VkNW`*_7Qi$(=wMR_DF#!-`Cp3wzbBLbj--L9%QZql39tuq?d^)I;JI^2 zN<*K&*VZ*!;=WH`lj2EjUcOEuh_mX6NwGEcungy$FDjPnKupX##Otzc(KA?%6G^m= ziHYgFTal6U2$M?})`^NAxCA$C#yfjWrY$KE0bV)bZvx{8z@6W8aH z&qFDFs~n|_WAW_a=7@|8rTPg4Nluz5=w6=JRWq%QFTea@>*RVw;1e-v)Kl=)b-zL~ z%ENxw;iI!7HDpZY*1(pX9{BO8>P;&s(&6Y&>58stFS@^Ql+rEVCKJrm;etn;BJ6fp zedUfRXw&Gs8@KbEE=66^u%I^eu8qe?IdbmH-EZ&XURlF4m_ON@INpj8vc`1grCez$ zu9}#V0>Kta@iq0SbQKOw(|aYjPV_101Sf_+PPx2$5f{uJk~TjvX5KOx!CLOTWpm?w z2>v<;blRzXl!w+`1$CH{lkhK?&NpI`N(M4Vrm<#sL2mR9&3BR@ar>LZapb*m5zCRI zaQ==5e9g^UyK7)=aGcGYiKNbB?;{Dm@$hp#27(M)qvr{h(kII3+}}^wjoN zs>MT`uoE@RLrZE2Rw!A-pbBc`ys^nMH%84g?*xr5_6d&ol#(|ZDZ9xADH!1kdm>prH&CGfR- zAV3*0KF58VPaiwq@y@X^im-{-R?%tBbz2yYtWn_IYc+*~;>m;&PGPj( zj&UScP%aNQfeFcZZBK;~>+f>VjcDso!@{N~(u{x2=F)~OAsx?Apq7L_D{~a*`}Ewq zl&VZ0mWV+m!2`pJe>uKOG&`M1)^o z7k5-imAn2LY*=COhOF$Mb38~H3gUIT`oH`OJR#MRyMAuj)+N`h_)WMihL9P>bOA&a zvohkR8s+z!?om@LRzWP5 zM2Dz0ib4jYAUHg7J=_0iTphW|4XAbHL3O;qt~@KhGmDga3dE-_o@B!%2EC!qRJaO8 z)bE{IJIgAv#0W}X$ID<)r-qjnA(rSexK6xca38D0p08y&d3eNiM3%DtS?^qA^={BC zK}cadV{2`JdFP&f^*Tt^>+Y57U?D1k=lVh|UNg1+H@MVnOTuScOpK^CJf{ez)5mEY zTZ@WNO8;Bh0$2ZtrE6tZW8pdW4?iDD-xx=!qg8Rc=OHp?`yDcX_c#~OPzB5xID>qR z$Non|Qw}lq4tafn*q9%}#fCID3K{ef1d2-t1>l1twL3fg5e*yTzm{L8=Q+U%D5?{- zzbt6I2ZbMy5+fv$8D`Ih)I(6;j46VJHb*lvGaodw%r$xk!H!tu6t8;JTFdRX;v;GO zeBfD|jWc-2)4-_K4vgy7^!!Y1^F-L948_=f|3JkfQAF@`FG5=r+bMnEwJ`Y2S%NL` zUfcJNhuF@YK?O}WL}F5{DxI}VdxDGxY(4f*z#mbL3lpD&r|uF~7R?gvvL?nBv-o)W9G3u{&6m0imPPngA50(H3S*;zn~ z!H>OTWNyvS0RMdtTjE?>Qd|Uo+vf5k3HOb6caVmSEcJDO=le{Gfh48OQ)-AQ`5>lb zz;Wy=$Jybkbc{@SY2JlAyD@`TQBhIg_M#|2-up-4Vbx;7q{D z{*FCIFIV%PefpF9c$hs9bj-ch6WNNoDFY;!zq4~~x`_+U-uFeF4QA^Z9Wa78M^jHv zMnZ1=-h@~Q0A+xcQ{Koubv1*ST}QrJJ1soBn{BEMrlgb*kIvag`rqF&d(6ynS8 zgu2a^e45JDEVqTAT=()=*QxKwMqD1aKC9Zj4&aH&a8?F)3r{2?BL4 zH*b0AdF7U$OoQDe?GVFY0Mg7V&8ytcYswt7 zsvOxhV`;IV@-)6df>)WT^2aIU9|8wwO2UbUT3flzhY-Pe0ie5O#BqU>9k;FCsa`As zi^5e*21dn2A;PsY0sR28+et{+Pzm^is_%F zQ|oeJ3bCRD)Mff_$YHd4pn04W1a*(!HG2vpoTTnopii;WjbA%%koaRc>5PApQu>v- zv(icl|0@4cw(hEMDMW=Ug5+tVUz5!0^9WNnIJ0~shP>;tvaN%q`|;obpx0sC2oM#R zYrpsCUj2&L`e z3%mHroJ!l)Id#1iwE5787IL4Et6Z_5EX$tbi~4RGKqL z&P8m8tAp^+(??z6jFgq7leH$cf4(3Z(qE0!&nLkR;{u5TlX^ljsjGBEP^TQgdDb)Y z@5n7x9|zA727 zwC=ftjoM?{fpTd6MuBkw8XYp}_GW|$Om0D)3 zC0=5^0rSGG$~9E3tEbHpDJBajTgo#e{-!^|!KJ!yj~Py9P5P7)4 zE{z8w) zJ$X(C&lNK7qr>oR=P1A8Gq*(y_)nxp2rf8I?^o=NSIjY&_;) zpG9$7xZ}$bpb9`|x-EFSs0+->4`Akq3`@;oW@f5BS+KY{=CHvF2#g?)5U5%e({E;B z1nARowJe$fg)+}k&`_f%hYe*t!@eoO8|NJa)uxf^SFi$~uEDo@Gm40yV}_;oKQC)S zWH!Y3Fid;y@vRQ-<2e9?nSc7TL$`1A3;OSP%8NB?l55}kYE(q2=SO<*<@@7toh!`^ zs=3umo9$gK`a3(a9-fvu9Pd>)-Vd+h2fon+?ax+6&g|KEz%1mcQ#b0dUFr8>kb&7^ z4H=fbmsTd@<6|OVPs+_%>n`wxd9<>xgP$($y^z6>^eFH zo=AQXv8Nct5ahI1F;vwZd8P&6C2Y~kD8KBCKgrFc{Y4J7z+1AD#7B0^|Ng7OQUAuQ zj-2(3bg}bKK*w}`K2opFlj7-Z=f%G^uY=Ek#W6E60UDiusfwtVE?&(9sI2#Fgt`On zfi=P>zHK77KCC~rZ_s^lzirN1EwAx#)Xv6T)nShhagJ2)1~fc@zmk=^hT!6{=Mf8{MX6S~;Qtz)+@|6B*XG#F!Vvff z9JB|j^zI7oRLU_)nnA)YOu_?7YZM>-YBqIEn0H1q`kX9nI?+6yk9y;1{!N-nDcYL| zIDxErnB}vx&7UBXV}|)KaGIaVIX$ftNw_p34nO|`Tr5`MYSvYUC6?%Wmy$KOK;{i6 zfaIGMXbi7T5=rU(6_R_nX=9-{q_^&Loty3i12fZsq)i0Cj139Qyf&s#)f+!6Vad(w zy1pr6gM*^DO6%~(+Zy6bE`SW}uKfA3ntfl<%&m8~*}-VsTcY}K&J9Ng^Q)6H+K=xz z+iZ+P&S=(tpR#beM+3WA@F0sX1};$XqhKc0OrCY6H@L!KK)~Namfp@@@NWjRFd0h2 z!S*hvd^1bx{$W(dKO`!JUy&;Z@r2VCg4y0aWPz|@y84qT0uSRJLV`}7f+&o1d;(%Y zuQPR&M8I6U5boa*&D=oV=2h%w6o^ews*Zidg6X7uR~zfWT&~MW3{*u|*?3L0h(s{y zuMH}nTAQxwi%~AdA66T8jorh?>HLK=6_&XyWb3X*WW#6i&5o}2C}KoZs~3^-R?y$Z z8~=ncT3)nV1SJV9;u7b|CabW^My^u&$+%K*L-8(0;d27Ie;fhCHGG{r{Ku-kLE_J% zg}$Fm(2jOVTMHuZ&3b?{sI|7>hTh&03phCQW8;*%I?~=>JnannVV*%+NW#Y^ms%nV z$Tu3LASZ_3kmH;nM$t2pVxPO?+674GmvC=e{zod_cn_2Z^f;GQg7*~AO~{*{2--Kk z!HR>)WT4CP0N?2W>_{^;wa}(G=wIVIA)~z-@)+pFL`r%qXKPkYwA?LBfp zk0jr6)Xq0PyzO)IQ{O`PnVEE$kh%MO@c`b}6|E z^CO%sEm0yOz>eq!S)X`~;DrebqA@(1c0ZI3S2iI-GDal1rgJbm6VwO_<-?(l_wIMi z{F<`ZCD~roK}(F6$Y6UFk`CtEYHG zvYRMA431PNtLwPHct>+%OP0(h`A;#YWvQ^TcxXd#2<=mbNALXu=)_ZS+R`4{;Lfjz zk*}jHeDCPpRw#j#jqcIaiwHT3Lfs`Xy0YQzyy<^yKUG(}F~HJ3o_r?nbh?VnFHipb z)@4mnx}?)Fu=2uG_KtKC7izXjss_=MMJT zpKoo4aVGa7%*?xhqJjOr3w=GlpP(Rwgr+$V>KS~iriFK{JD;qiH)#je$Qua%^K6kt zxlRULdBc>4f-!cKl6YVRHzC|n>J!2H{&n)yXbgrU6hNnKCAqI zt*FT1D^PadTA8|=%g0Iktlb8r=$-Yp4+`q?acBHrf>GwJY?}B|dlDbAbRGCmR2@B8 z9lS=^%ddF#tjipsa)K?yEKZalXa+iBOThX=CW)@HZ}<)fkpEof$x}><3R8fofEudO z^?&>okZII=pVPZbf$QKgsb(f7USBNVZ3*#|SKyc#JvCAR$tt?N!TbmQEQwurTegvC zf#`-f$yemyYVIIp;YE^b?hlQKkTd(+4JKF?01fsghg9S^dRw#M3G}zz0H#gG1j)*8 zF_BUu%K&%J`v+EaQJ#a&sPw+UW#mEkp@v9%o=M^Zq*IHCt~6+>?jtonzaYX8{mw8I z$SC4G{n~ag=MG$^qhLOyjnf~aB{G$prUZ7@PK~U@MKQ){tqt18?x|F7m2L_jMfd4A zmj3|$o!s1DZz4u624qx*gz3*^cAOA(;Fq+q(@XzC9TiUP_Nk)Ga#t9E-SNz>oK>2D z*^8DjnQ(o*4Ie{LLEV*O^|yTQKn3AOdsx@Z6@=ckLa$qBKMI8Z9T-TA!W?+1I*}jC zF9$`@0Bz8KW}6^JlEp60(W>jSv=g(Gy)!luf_b%45_}qimZ5NJuGdBhmB+%$aMi`F z&v^CfsqLCkuQijMm^-@Di!&WVqf5Z}*eQd{R%RR42ls5z<8)qxQcXNs(j^nVS31~p zQ$kk4&3GiY5+7%yXy|IvYk{wxqIKI+KBX#3mDb-I8JCO25Uj5HPurE#0&ia0c5Qst z%mIEVM_5ESW%w(cQDaf367#+sapc?{1GJ}60G@B&lXRmyw0hKiBnGF9nvnD`T7VEbuyf1 zVp2;O8{PfXU0hX^cF=-@^7exxQE=DV8inij(ui$3<7rSx8^}o+J3%aVqlKDMaAm19 zv?KM4RiWW^Rl{4#%Z;>dybo!LFst)R>ORjT)^7%s8^Xvf9mrA<)-Nw?v9nRCfP-!Y z@%HERcBHI^s$oK6T2#Y(nk{VhKESiF+V^gj4<+{oK}rUW&UtS<$b$NqJ`4^WEX;J| zBYFqK?E9(DzJ?JqCwp!w@bFLIm+!tHqr5u@vC+Hny7P}Rxi+R!@a~wl>09VmP|5}d zD(%i+zze^}OQ)+K!~IZcd>kXd9>;4xim&^D}%O$@}(0OwGB z^P}Cr61$dcuDR)nGUUkNKUTZ#Y3rLH3qR6_%lbjdNRL{ZBFssqe_HvPySpV{<5b(| zwbY+cn_4;U&ErDk6a=ez$Tc;$tFDWz{Cn8i^oIL$ucL&2*NWiR804I$|G7iqY&bJN zt9mH}vi*`QcTZ`<=^rz-=QllJ;snsM=hxL1fYGQp>zA;ysjvUf#B+qiKlH5e4JMm3 zR`7Cxj`jTqY$Sdx%{dmISqbxu6E6*r_`N?XkkVZPQpJfkzv8)3cCm6Brl_GZHDaUt zUI^|t@$PD|>vzCy_dQXyc(0w#NtqRUO2_#uyu@96j0e=z&Hse*$}4CaO!NQqss#Xg zWKD0~)zZ}Kdix^UzVXR*$2HLBqO@UBx>El1s9$6(o-_O_IA!QZ`AjnUfIEf*&Ax5R zE;9KV5apje$4isWIL8fyvx4vpYf&dMC|dcp?IwgjCp*H+sVS%y$CFpYZr@~**xp2- z&db~JqPf+b&B{vNQp?%ewQ1$~>H0gw7lK}Lf!$4NyMvK6ORgf@S$Hf5oLGGwSAQjG z1nLByAc_cxT7i(`N>kI@c7U14(qsFdsx>@;2Ka*NZR)3p^CQojoUnU@Jq|Uxs0mln z9O<+Jtk6w$hXIU92{a2EIS_HVt4iiT-i_e!owrqVQ-0%C^r@(ob_Fq#a)@26`$ zOAlZC0rdER7NEl$RhS&cOI?fg}iK8`q z07|%%HNJ5kgMLw@Xv%uVG6J?sjpTfUtRTzP5o2Kq|N3R!2%%ShESHH?z&MjjCk|LC z_$Uev@A|(_kd%-KL*KVj5H0F|Im)zl#<>TJLr#FKq3iv1ula6>I|2q{bEi1BJ5D*Y zOM2XC&@t@IEnni!Rg^bH2eo*A)wTVuUF0ke9@hNNUsX$^?vthzrK{esV&0r7saHrS z;&Q?7e2zTtKH!4LY`_IF{Eq<4!@7!)f|eP3cmPMZn*KADb|}u1aCA)PKyT)65C0O% zeZTg>YDlZdbPuVLA2@p|?49V-j# z4BOMsw)FNZd3%Ymt|`c3|Ek-oU^21$;yuYP`>_mc!r1H4y}NSMMz4eaJ|GnlTQ8~J?k(_m z1S$FfAB@;$mCb$!ogmv+kfI6r&(h?c5gy~m_j(ye(mLSDBt!Ztd`GAd$bUN~=C8xj}w!=0-*w7mP zL&EZUt;br!%J{I{N389{-s08mv32;UiVxn^ZNE2?PwaTA_yYT`+ekSt%)|;Zrl7!z zwGOkwOpQmePhp?(XeaE2W#wK2q62hOfgY*SKdiwCrb%}K4je)ek4X@YKnG61 zS;`j5dW2a%1?D2zLyan*XD^o)`GNf}Xs1@*Ni)UUa)Ck_@>`{N$baJPoo*l3)L07_MwAoZxBDM47P%)<=7`qDYwZWR+@OT|3w*-+7uGl%RA(2CA z8E8p|%#}w7s?Qj!8x^lu-4TRPs=DSAJYtUVX0WqOG?b1))EfWA9Tkq`7Yn+u1V?Wl z6yNI3L&|vIi$WeYua9U)!l{|RhA4mpxK1YPw6)%Uo~}|T)?RV=*3CNb7f5Z?5BL39g_hZXn{jG4&m0rMf~c2W?ku}>Ay5q-XF^!$x}=C$65J$2gJ?b(T5EPGdV7YSU=;t- zM^4pch0D189o;B5OSm{m$O@!aZ5B34^kvRx4twjbSDD79+v{&>BPMXN;GwN> zW8u0qH#?&&w)a{30ne^_Tr5LhR~Ni6*ilwuvdOE#pKv3|KUx2_TRegJsPG^XwJhf( zWgaHqSP_$Q0VH&@3cM$Z@yrn)%A@Dx_t)Oa@M}Ln$sNC-`^UU!85)$Qw-WuE#$n7# zX`2u?G=1wu*5QyoGq%GX9myHJ}_sKSibYZL|vDjaDl zc8mWWgKmq*P}hXR{(^Ma8I`VP36+oWzkl4kexCBkhcDC@ZC4i2>gvIv(sJ8ydeTgp zbgN}p&VVz?F5Um*g&@_F9g5(YWpphP{IlM1PLH1Qg6tcP&YB~BmVFlv9~`ONtmz8G zLVXx!XC%4K;bfrdn6BYKY81YeXa-k7adSg!)+NzmpynkFsePKSYEiK@2 zisp9dm)a9p=XDBewd?9oHR4zqYmMvvv5E+fRP(A$qH`+d5kf^(*Qotq>6qsLaC z*AAn2a&2j&DvG1CZzKWk;tWTYa(973BIo&wXoU|qC`2pX!h|K*U)!B`Q*sB*?gvuB zB4?;LAUP~jwE%gWf`*gbiwMsGO=J6$Ci5H{Q~F_~wQOt5=e}byo6iZG9aaz%{enF4O>R4}Hb`MC zr|O>U`?o+c@9ag0V3_(d_MlwEanUH`&yqJb5-T1f#5$x{69Vq@H*D{C==7UB=yv|n z{Jp||`7|wMrp*||SY&t$D{UZQ*8^rGHXDP+32@yTq%ND6a_6tqKd&AT?V!H|5Q_Ir zc+2EqZ~Mr3(Xc_|EW`(eb6}||BHeKN5WATC?3|=AnBV3M&?h_F(AkH=(!M1daU2P< z(DV9eADd&}Ch;hA^|!w&mLXH{QQy($?HDi>Z$dI?CH4-So)_?U=4q9sxaRh`V7b>8 zq~Z-M(OiE`qH3iRlAlDhPu>)kfZ~GC`Aq-xSjcP{MU-MfJhhT=0++w zUPU++in;Q@hUbk^0E*zp@~GRx+_q0?o2syg-W;3wc){COi9Od2X5Il~()9LW67s1! zx;g|{YpC*+W>u8cUsSvl60%rX8YraDu2VhJffRHDPAS4c<$~0d{UQJ_%ZkyO`l@qQ zfAEpjZ*@l2fJQKjy|gTeLSk=*KezV4lZn@^T2R2m3RWBR?v=BM*p3L3iRs@8I(Luyu9Z!EQ*r?kR1pqmN3K&`_Bn>V*to+G{ zRE#HkKcaQOcqK@wOfGxmBaZNu-+0kbGJbHSJO-c&93L2>MJfTnN>Cvz-cN$XYoBlx zk?a>t7{pi+!it0r>N0AU^S!!B6;dmkfs{-h^mayHPT7(eQ-6!u)GhG=;L8_1ks=Np z)bR(_oz0uQUUG(W|8vEp;>dw40fjw{=;;nb5( zu)5r4yu2m=p>Xq1{PGHU|4ABP#?Mm1>nxZJS!%Rm!ch2(NDb#<*#9 zhSw8jO7j0``T?D^z(hQBdUor7J`ssm!{8HRMKY9A`{|GO|8wo6%2gO34vvl;gNQ02 z2RcRr9M)Lm*+AFu7Q(_iy1<6;he=4foQc3s7X*G*@4lMk@0x(~dW)(5cWmfUfpFm5 z4p~~y7tp3kvq=TR3)W8LoElCt2x?z*s}xy%BUn2t?X{n&Z(9<(pM~pxeG_$>lt%29 z^TO%Qn9be)uCKyz6xqQx9znr}kVpQX>d2MuEHVm!(3dzPTNoHy;p^MJ;3HYeOK&TK zVdEQ+@LfkoD!6R;UONee3*>l&gM{0lu=Q8!BxOvJu^=72kQ*6p)Z`LI8!x=HLIUql zDMF<@SCU@e>4wC}Tc3VotNyFR>I?o{efwV4fTmdYk0A#MP|JF`$1#l+F?k@I&wHKA zPj;V-wVD0C2s!|Ob)d0!$wR~$e;&IT>S%vi1z?3#HzJb@8f*H+^?B1E+OCG@2N?MM zHxduT?N{jstACEtm)17{U75>vhP~klLP`Av8CDhzN7qPqt_BxLxZCjuwUYxoU~SWP zGYg`Y0C|P&_MLC8j;#YH%tqcN=>oM-{jE>SRw3DMC9XSxOJvKx3Z*oUSVhyvW>J5 zq^j~9nzG2K2->BdiuOjCwd%o5Pqs4G_0G&JkFFC=6lcG0A3~jIl{Kqg3_!$ps*d$m z`w7d5e8~T264frYaE^xc+;rCq8&5m{DX;LZv$hU2ZIJVXQP`vC0vckT$Agp9bw)&TG%FA)>WrLfrx21iNc&Q$|;C#h+;*#6bt(hr>I2pre4AD>E} zF2<@M$2G-Nemb$#9g7@SS34(qBNp`M=53flOR9#*!Ce{LXh@VnQd!Rvj)5rv~D-wBUg= z_SRonW4r7i8{{uo{Eyj#L90fE-M;`Ks9qmLqT?!GL5_)#d1J2;LbJPIeEBV~B*@nH ze?UN2{C8hquMVnONQ&+42jMpbdJlZH|5rD@Fh+Q zD=6{P1}2E#QVyn?>CE*s0!`Nbo@h@&b^#5=ndP#*m9K%EvH%8Z%T~@LheBc;Z(g%L zZM5}+Ngu8u3i>>5>*%xwa2D>kDtG}=4;I~ktio*z1bpCKqN70V9~x~z^wv7@{8qyU z^js%PFw%Thmx9Q%yvf!7NBw~6o$l@-HBi4Ga?aNQt3NS+wHp!P3%$+ZF3kflKO2DG zo+Zo_!cV*J6P?Xw^TA8rgb3o;gu}&O)7WKsdAAxPve=7{!P-~N-*4{&0JC0nk*uyU zW^LGXI;OB4d~?Q?V~2Ma9GTVW{jlt5A*7xI0+kW4Lo+=;U_3GWCiednL*NQl2?1nq zKLTk2nORxF%ziQDmWD|3*inbb-SaG=&aV=n{1#==^tb6vNl8R0o{|nTR>2p-H(H(t znXm2$98gCyWUSXf1*tX&`o5he#`AW!TgA2}w{LDv4>H>85=S4=2FLAL)$K1oh~zvS z9QSh^rJ?zQ(=Ob14k++@6Oi>6+WrW$W+J3Or^=Q~_@crKoP_{^p?32d`d1 zFabBi1_j{XjYfD9$vHzZA0H5r$niXuWl;)f&~Q1{^8(T6I_u5P+7fR9yWs8C(>ai6 ze8UW*SgND@?&UOz&#%QJtM2{DPELP+$;v`cay^;1C(x5Ppz4}Kctch()|#8~)##AM z$fk`;a@+JGuBG0MCbfNLfq?&`n6DTXdO3(c#KMQ4Y8*Y9f zj5_f@0YD(}6!A(kpSeTU&aPk!O)stku*ak#f21BMU7l0Jm z5o#ddXkK1Bsd^RE$SN$DsXrMZkzgd*xHkmY|9Ga0&Wm?-4Kg`NQX?Q;z9HU)iBwd1 zhW%Y6sy_}?3Q2FA76QIJhEzK=2&_O_R8%x}-_DF=i>~FI7_DM&-;U^uO-z;SZS7X` zcI(A;CzRF@bV#0(u*IlywZeJ-c(`!?X!>JixERkEbUO||j^y@%&z{wVSco=-QTb4a zed@3Qm7)VrNfmX*zsOyZ6yF(+Aoc&7@2`nbawC%R>anvEcwTPTOhT5~k6j zN!~qX-1P}x_&-SMq)a2~Blw(Dv2}pbc1e8aqF9E{_C-zNR$MLq62G8T+mvg~B9z|8+ueML;J6B2V?ZcJeI~L&tl0 zbcCafvH0#QenIC?%_A(ZAX)Q6xP+-GNKNG+Z3K9^Hhrqr6!V;615&?fVH>drOzmzN zj+7<;#Gjo8s!EHv)g9ZF+lSc>m9=td>yFD%uim-8m0L-`_23UNd=xf~OFp-sf{shH zig=Qql>UBP)#DpfdVl24Qfs7kv$N6+r)tQipPk;XCO~~BErHGN`mna$O-F}=R2tql z@6D7I$ek;BInNnbytu$03oiG3STbt7l}dW6RDRLbs{KP%vra#syf#lU1K|W z*JFWsPnEZ7I%sg7Oxei)<(Zj@DGC21W96`_{;9o|jr_7uSu^RbpVjCI`x{fd?u(K& zDFYvSaiwmtsTMgEk85f-z4W~HUPVsF+DLqu4BttSJeQ{mQE;~*JQ8Vv^D5uu13f<+ z@plieoRLXYhP83wN|}n=70af>trusPo3+kymRI>nHD+$br0KV|T2mYSR^lKla|kHJ zNvod}nb8KuE((aahV0p$bQOhi9q5JphBPF_?41Bh2t?9;hKCZh^ApD-p$V>rnbd?( zKX4fdBjt?Obw|Vj;3wZnFu;JB!Zp|6!tZQNe7_UNpKMZEdgxFADL`$ME}^V0$z?^xI9p( z<4dE|$nbqHPy`QR3xKhP)F@|dwcNE!xf)9D%9q{){+R9R)?Yir?{PtI{xN2g^L`V33nz#CBokc{Y7{yX*Z`O#~!2({6JfBqDE z3}wL?F2leKS>Qp-1~mz<^knN+uBR14x384R?7X-RLQy&gL#53*RQ5b(mjHvNXTR$9 zjbz22h2{#RZZKh$n`_%iqqjT6i#-v$dov7AuCq3uDt;d^Ecmok`Gsklz3+)9Ck|2D zI?|8-R%pXQdOId5u`^jNBArgZTY!;_6tg3C72%D+wZKB&MtHlrh;t$pMp2$6Mq0ZV zE|@?Vv&(nX++=pT44?ooP*^AuLIsM%Q>Td{+JvU>G{SR>*~!3ckmwR<#jBbQ6*LHFBvSXZr&jX+GhjH1$6|kOMGw#vKQKDbaIpcTx-w1} za!421o_qC}nj~vdY{R&8!}xKy)PlxONuoCCfZ4-Cv+>Dfq_{+C+GsI7gyiGAq!36W zSd!UHOscsn50%+jDT^jg@x^sL0BC|TzQ9VRYGbSRhQBU2KK-o)Fcnj+-7YwX&71BM zUsDJk-I-N?CxFUv8RyhbF^zTY2Oq%272CBYI1K&9e?BLS*1v($>wz*G-fZrv*+7Cg zGLZXH3!VsieOTF;koHQ~X&H{*&yAk&U}rN2525-$eY&QQFg8W~B3;FUhl`iaOG1H( zBhK_AYRUM2BwtP}qWH|ygzgg&;)=XaMYd4P%M?DJezYsG-WMCIM)9&&yvAB|qr z2C#Ca(GMZ+5PFZ;1CmNuN~u@DX*yG=;|7=i2WFVnFNKik8Y&XET9T(@Ev*DXPfd>S zki|Y6&yQLW1znCw%#H$O8dR1p%f&{F03;^0Zy+oyG+)pLHo%Ky#n#+iF>+T4Zp3as zH%(jgZHG!XV_+fM>KL0u?bI4kk4P!LoBqmNqo@Q)5Kr;Cf=of74^rCFG%M#!@UHY1 zF7_?xZv-IiKtPC8dsxRBNQ5#OA2bd9X8Qk+V(!9eqzP#i=OA*q*^^HW?5kfx_2qtC zwPjJqWOz`_i>Z zc;Hrx{SkLzJ4Ud8HLh?Sa%5B;xoY|mQW>pRj5k>)2QK^6tf@^BdgD1>dq}7nnw@sL zm9ghlA0;cnZN#u;&@k24(UFENae}UE?l|7GLbzp*>{{4YV~6FT92g7sHrETJ(*b)0 z!M%OGGu(nYn&Th%&?C&XDwX7JknY}_T`=#9tJ*pRBd{h%7AsW^=`p+K4nKTZf?*o$ zD(e+VG!JB>yD2FMGHY-%g%6YYW*3-2B?s3`GcbR50BphkN+I`i zY9WTMpSMb!Ak6eC53|V!gft*?8-N&c*?yJMpd<-+Sz)YBWwBxjBi3cQmbhrx)0Ib^DEKnaKJtALT_DwpeVNfnj z<&JNH4Mvf_{SkX4O#OwA?F69XV!%0qs!kCZ^{oPzbdf}AT$lAa{bv8X%JGJifBMic zzd%)=h@t8hx!+qk`wy3a*wF$0>$%@>Lzt5qr~&~OlpoCyE!&5VPD2&LfblORs8Zd`gqGE$+y z6sy+3nndJWKp)?BYAU2XrWbe= z-goP{*QQ++*=`&~ZjDc7ID3eor6H8^f>;PU2)BX)Eko)9Nqg@uk=w>2kfrgozl(IT zPa2GXRP0>!t_Yi8cvd8Zf!CNOeNdJ zZB|Sh44oxG7%^&2sD=06a`#fSwbWItcCXY&o>P7dv@ae=VUDyCyhb?c5t{cp@?+sZLXQv}~-FPlB*LJ8A(7?;oQNl9#d<2U}9$H?J zl@xdCG~te<%mhP_LifI57X48FY6?M{pKZBtP`%X%Pojpa-cixoD^7!O^i_}7gZ)>x zra})`xy}v2-p#$xq**7GNEvJEPvqvw^V?Ce3{b9!!YB6#*8KpraNaV%wN=*}ER>04 z!35JYL8?inAy~d8qU$gYMOA;hMYN4NtHxf%D7KN?t-Dygr)+vy$7$xo>IB>Jd4}k2 z8t1h+RbGz}IMHxFf^+SnK!eUrikMC)dTsfUgJa>oAenNP0#C}IpV7g65F^!OU=)Ey zz(*lNFkai0!`-+r6D-$3gye^p7?F{9b>x3Er3z$Luth$a@;6gF%W-T+b*Coaxxu9J z3!m1ff1BT_SsY!LZuzMOk~5NOUPF*a-fi$H3=URNkNj3&;BCJ)Z^7Fgu`mQiW3+?b zPx$`I(`B#;x3!fS6U`DOlf2qiI{YU|J068@(zaF*Y31Hfme}Q8pJuD=2asmq3%8L} zFp0gs`o<`TS`rGEu*kI2GfWBsbKqae3cIy*fPjJPNCPe%y$zR)(^h@XF@YAKF#;S_ z##{7swD*Ce&wvsCCWXS_TjAa_oPsV7FZ-KB{;Wd+5#To@W~V;Y!oG7EAV*7WsEyjn z%)ugTKx)#JeU0jxI1Qt`y>lgx%Nq3f_@DL-A$Tk@rFyuh)oMrXcLrK$6ghcrSFugA zp3?{UW=~HtuX~B-dMVst_VD%i2{wloN#v@uTeNQ56qw=H*PRWd*yOklD(zgevkcHj zjrcDpvI$Fou1~0b{oLf(lK!NfqfBzY7UUNb|h8yjc^?mNH4C!k%uSJggrs zlQ)ZFZp!~^a&G^z_n8EWY&H?JcVWn^RM=?5n#eCCvC5-FcU7dM$em<+1| zeFS`L%9VYR2|EEnz2w;=J=jujkQLtq zzuOEKK5vo7#5@O&^6W~r$L`ljJM8%lUUKqvq4GZ|HQMSHB{W~0lYoJ{*CXCs=)23j zId8^XyHQ@7iQgmG^yNKWSg^F}oYN;ZLF|(qUW#hz=>^?;2>s=8<%(^hKFI@vpOW+Z z`7VZDQQ;>kFh8Sf4|$?Ib+eSrIz^tSQu>lhANb*D3S_|Q zGYtfQz%0*JWeJ#`n4g7A2@AlEy?+85cCN@LYPP$%`oQNw1P$g^VOLpUsdXc3~ZwYcMSw?ukqd`e=Xz+v8E`)0w$X-|gr8e88Pi z4c_7g{ac#Sao9=hXlF9wSCFmb@02Xk*5h!E>wKmpkMoAP$;jB{SkKL5^O*&hPx`vN zdVDLG7w0wDlv}f7!Z1BRub=DAlUnOC&JXI0imgRK-Nda5V2qy(6YHE;vlsV3rv;8! zPsW3+GK=)gxj$UEsn_60*SXD3&#EQlj6$e+5PSjKc^N7BfF}ma*(Bo)8Ogj-dVUvdKr6c zQMM+i5VH85k;61WX!3+d%;*&qocUz&?)Byzp>mS?e)yzdW|5^u7vtVUI6se;zSk1^ z-0VR6h82u2)fHRVVVh;;b$onr<*Vkf1l%09f=*sGVwO zydUyBzG$lbgeA+iX^M)D-J+>hcgf%UrIw^Pufb2vZ~Fk6?`9bp0Enw@RtwfhZIa7% zNKT$x_td75+!+9bvK^G$9YM9R=GN5O#~${*ghe0%)Gy9en{KYsRby5YC6%>l`RT9_ zC^d-M>6xGfN;J2uxzgH?G|l8~Nf#t9Vro6AALAg$8~2TZgg zCZPuAE0~|&!(@r|%ltn8>-3h1$1WMOkH>AQKy%Z+Tfus3T{w7mY!9ct zTYl_L61YHrTZ6s4z2%&CsG+9a*{|bC?gpkNBOm6xpz5gB)~E&tU_=<=esA($2R2%0 ze4^sfddmJ3(ec7O1x#W6C<6nNF3>cEd^K6W^3^R?I1pLo97y(X73U1kZ&@N2 z8~IuJvqhn>bG6`kGRBYn(-IB&Xi1#g_Evc7B*_hCbae{?D6qizaIBqLh``%wGFuCg zV3ybwqu7FL&KkJt?MJB|JBY={F8AOv3>6pnt*m-v)oY=bMuWztf*`Z-)C_JUdCk1L z8o9M1j)T`y@ZC!ghkIq{|K@{u>rGa&`1F_C;^yX_t(yn=^4LouiQHe4nR5mu>ihs&@>W`e0iES{rnQk2!pgzKK4pHtv$03wqRR|5GX2V8fD zBQg4Q0lmF_nbnC<&x46WJ?V*sL!brC)bYUZRD?9Yt0lm7jPIU*sGT?Rb(gd8s*md_ z`_gE^gZBS5)(vF6z3pjbQLU`sl+uF}H(1gHanXdjH zXtgDIv72`hy-^gb@72o*F;1=ilIZW0>Eu{U6_LA-Gtwkvj6H6DcGqnc4`~Q0OMwHU zqz^Mg8Z%zcZ?i@tBg`&9k6h**-DOH`ZM8!DB?FCpcM6e;w_l9M}=jzo;=Z?vevBq1Xm zdXPQqnoAB z>Q*}%3;C>newj)SdVdDNBpDqeBe^;?FcYL0z^=niKO#Ga6MSDF8kkXF$6?fE*TyvP z)No@EkRDDpTQ&mG>Kx&ux>y=lRR~*+kN0@QGweXD) z2fcVe1!f!o_SWn9pbIK%CIVN|Z-U8pYuW{c*J4$`1+AooRy4L~K7Zm5)_H#W0 zz0jFnd^O|gYm%##n`Wd}5?KIOJCiO=8k|^n961h42P?edx}FjSPVFJdw2s&4JFI*z zdVB>Cy%8p#tA(n!MqlNu>Nh>+hZRB*jZ&bU%#wjTIl0UI8@PpLxU@R4qC#ZuWY!^= z!g{R?M1>nvWVPGIRC*gXVS+#0GqslOwe`)6d4GWz8y~6Tu1FOanwV;zngekiQIzSe zXGB7?TMIz3#w+V{Iqe?32p-M z;OUN!K$c{bi`<4dVd*|#DW{7>Y>m4?+R;Uc#Zar=2v@n17>IL1R#(hr&a}v7W4a(1 z956WBE!pa^>6A?U^b)34#4VFzdaf(nF!rHpE<&63Wklb=Ar+%J>=i5A_fh<-f<+5A z5FEn_qd2c!D{5-C&>c^#&rqSCKxKVyc8rACTfJQ~MFj(-+r{cg=fnFYargc~=1!8r zdfvUz(bA43~(7}k3_A@uUKJ4(f? zAfRJu{O*6=W1nx|ZLmq-w)q5H_p^{=sJPMtX)S~d(5)EUAN3rcD@sm)2IcDnz$I>D zqLN5C@(!pIy`F+tGvjseg3*D~bt)>cfOmuSH|YH~hk&z-%&>?5 zT>Jm1dh39w_vd?fO$-nP3qere(LwwE+D5 z*w<}lwBiz5w+ydRyt7Acx7eT9qE)|$@B!vuA%=;O$^E5Qc%j2+a={7sdP?ly0#;FbAcx>*sc1GNOY|Vt~p?=nNU| z7Vmlq-h}%|=26u3#8v|xh2s6NceJ3NXw?U~XxrL>7~S&sMq6k9P+D(}3<6JA3jgj9 zH$p}nHMSUT`Ao}PP+tDA#b2SL{jqvFxK7#3t{;o11}+mqDz*w3Aaf^)z4rivAE5B; zs2Sf4zD9X1UqN9_XtQiK+Sn;Khd^J|5cq2R@Jp{`tVk0|Z@wYIl!^bAUsmK{pM!STVz&OCof-fV+~jEj$7Q5OhV~)Js+W~^2zgn zVP|I^XXT0~e%FmF$U&}KOUzA|HG4tmNaU>^CBmNl8k*hia+;ecnZX1m@P`8pPZs|; z+E{k}Y88k`ZJ%q-+O7!;#CHVuJ6c!_L5-~pkaIN)%jg!pyL0(&7)71FNq-KxM&hrJ zFdldbQ>7W-y7EO+u3j{_)3=HMbhjvV5ai{#{#l^7ykXP4{(^%833Td)Oo4jplOGKq zVu*aeTAFhMI0=`ka}Lws&#MxoL`fTpro$g~@@ptZkXh z^}&*xmwr@Y0%IJwEh3jFopzmppKqBWBOGS;APl44Uxx8LE!;wwFHP`dAuovL37$;y ziPFh9En{K!VvYEDm?{^__dmL;(0&FPNP6k%h8Z;umt2YejLEeNfhq>hB{`iv0KWCp z`(@~wCvgHAz&%c<*HQIH;+A6&j|qmXt)=TkPpF>kwRTW{7YuU#;aW2nsghU>gOG3 zYn%nV3uvwp_wOac@Hd5!>|$e~!-`yu71t5Zn1q{geZ@;kOJIB;c}pL9 zF^MuCKxCMe+k)jz0CQdAIvP_aGkYCK!7@$HzP7$`WU}g`_xwYS3q#C+9BJ-M@%H0) z>+l~LY%vp0bU&F|4(3^O3?nWwQYtzs{x72kqu~DXe8QD-;ZnBfkVBGWM{7gJ*%s}^ z2h9nSBy>9nd4^Yv;TJEUUwmFyZ=U@*1JKwEM##F=8OPZ?eWv;}^~+1SiN~N+kE_lY zA-GWeYwzGubLZhcYe}VsVkwq$Ox@06+k0QR;aB~v5vVs=Q$nIf<9_4;G$@8iX0-9{ z%LYS5?jYxU-oAXbN3K?VRKMMSQEhZ{Fh55z#I-0Y5VxO}4c1e#TW8EI?&m2MGQru? zI#oI%xTqM+Td$6V8NCtz`~L$`{6 zu7`LXsI6*_nmSG3mv{KE7Y`vvjNO8JNp8Gii9VKJ+wkWoggl+9rj%hS6JA0%b?1RZ ze`2c)TjfHOOD9J>$cJTCUZx95vU%V>A@pFTYA^o44?sUkDG{bjzOIB>v{_e093T3T z{-KK}SdegW4}$Bgi%o^%eu&5-cCx#&O(zoJkZe?0;nk@kh*|VLOqyr9tp+iU@c8xo zM#bo-HxYht@mC%DjiihzB{tn>6(=oNjR(iFEIMu@?n0Lwc#?w$uFy1zUAR;(ymgUY zS|)aOHRb28p9)$vt^o&=5dq^aCEY-Ah(F)oAE)l^ed}46HD0B}@-spMqdk4ItY*4{ zhaq(G;w|%(9>#+%5!ae(TJ7K5Ygp<7PNEB_Gc7QuZG{4oqUu!A$zLB|0eoqF&&sOK zwgP(V^v%s1Iy`>{k%0Bfs-??9v+E-?@Y*Ozow~pW|A*uwMm1DpTlB+QXxEeSFjYJX z=)O=;ZbG0moxF!24qa=~010U4Q8_#~mUvs^3OsjAga5Isu?Ygx`K#_a9E#*zOzHyh zkxvqQdM-@_DCOcnej zX6fXE6^mF6Hu9cNy8}kGknQ?-s^-9_RevPLp0mnRDj6CR*`Myjb zH2y+$THB1Kg7Da3O|Y~HZeWm~6EC=D(eq+VkpXad0h(A91jCaeV<2t=PaZI>T8o() zKlah_OlQ|3!7(alXXm3kw`39jU*HW$esiPfnE_p+FSTOz%ka}ZiqmWESXo}Hf2TU& z^&~1#d&39~BW+s0I(aCZ2B_U*hmho>w!?2cSS>DExgRK-jx~B;%*f3R(%6Wg)YbzB zfT^5)8VoF~!Tt24+J^)l~}J8^mp=9$@o` zQlBsacT0#smcG=;Jp*?kI&1r*<(Nl>rZxx*`SmCYrBcO~{!>1ESVv)IjPs;0zuP}8 zfbqu&aX&1-bGN<~{v&}+gDd@!;9~)klUaGJcm-37lqTr_`O_#d8heVJykv) zUE2w%U0ue&0RcVo-Lhi)oUZM2r9*x&^Z-Sx4SZ6GxfOI#g{A_%?Hf?E0nj`GXe#hm zfCvex57pBI$Uz`MM`CV4p9I?qc)AARZFyE7gJ$q z6*wQ(Z)w{+?lzIk6tU0cDvZ|JS(Dy)mFNNUjL3Z4M=O685x_dckok301Q-HFOA+c? z;hDXG>hw57 zeJD%zW*Ui;)4v~7LZEWgtjz2Dz<;+I#g#H)+K#dr=GRmABk8hG>RrOc3*NeEcI;DB zG?n6DKJIMZkI9-h(+(%pjcVL|S`C2$8@L|t*`wUbL%Yt-dzxHiJL=lrt`l_NG@3uN zNRzNV6)l|J*1Z@uwmP>2Lm?&i`w*5+7KXJoHVLmA1j)c3QL0ecnG5cQkhZFnD-576 zg^$f06}LQUYCHgyuqFS%5|joaQa8?%fHc~Ofo!*9%Fd0?Pi zf9_0sj?Ir$UQG6mSO^;+ud)1(WrO$+)p;|tB_qA7 zW~tqVB`E065b>XtZIHuKdgF5dXWQ6#To;-qH>|l|l6xF_>a~kxOAL+@xXF8)p|S6o z-Y^BnXA$*w;$UEH+$8Ga&2+8L=*9A$=EEjfKe*wBcnJHWukMl1)M^Cys zG&nh@f1DO7EnI#K=Z8j4MRYTY>`nBc4@7(?GBTUm#}s%XVq2j@Xy*oU5UB; z;A3(8L7ExD)eBKqD$-vZtr|OS{6BC6q*X}!s10JH1 zfH>@VMfD>XlJ{2d?OS~a3r6hi9kS(Btl->EpKh|Z#?|u)Nt_Mi;=5DIeUEF#87A*S zAu{i;ed&bs&UHta4<&B$Oo4QCE6Tw=D1T(ns}?(*kh^47o>G-8gVtWXi!2bWxhipG zVG*JG6NI>v*xZ(vkl+#qQKr}r)ksS08I1^z057lmDKpzj-c z6E-vUrA;$0z6559=_*cK1(E6TDPCLK-TZmU9k;ueBK&~PlmZI>%<~=L)7QN?_}sQX z22%+mK{aR;VB`v7ZR?*6ngeGK*vkJ>Q(>boHm}8QIl<8`#O0q6^YXFXbf{ctWCnXP z3xzl8(h`^YH@P5WtQvQUN&4@>q-@2ioOWt3w@2_Z3k$2UG@ktyr0U1yotQ602LTwos;Ar< zgq%;tNn{$e?nfo{_W|^22A?3s_ulEv3o5e*R_{p&-aw4|Bd{}A0G>x*fFz@+f8wEoTr#iYiOrK3|M+>S@NnD{GExXmFYzFi%@3E`Ou3IIMCT&|Fck#C|c2gJG z-526=&J9)M#pJh`Rea2QhaSdlK-y(M7q?H6uL$HaL^5uRkzG4*s>%!0Ll$ub zOyqhrvaGBSoeY>qYm{bJ82n9yLH9^lZ}5L{Fr*04dQb^Mbq-2bSrxhwi3R~b^X2=W z)HaAkfn;W9A@Kc6FnXp~7Dbj@UYs#_&;vJK8WH*EnNmY(xwiX*I|Uo80>>4`hJ{FWlJwrbYKn;19sHbFG*@S@7}?(AEtZieM~@p z|JOF{eL=0?Ve}A$`tV{-K5*Hg-j9d%v9N}3#FLH#PWX5V_|)EkKboU})6oL#gt?Cd z%J%s2Q9)}%`+<%lGlxzCcSi64iu`eZREiYHsmbf*S%p)Renwq$O8@9#F+L$L@J->cq=0htCn-sweWW=2Q&&6dgtZg=j zW8yzTG^uv+du$Ol=B@FDz}x-}F4C)fS)}7TgVD8y?+HBBjtkTuREeJ~`|Y&IT~c}!m8pzFn(<7{rx za0CyZ!I;|L)3@@W9|Z0bkb^PRj%0UAE|__nbid`{vlDf4+tne2{g5na@p1pZcn>ZY zZ-6;>`pOs-Mj&ajAOF&13aoiz?S@M;&L&7K=oL-KD0A7`KCu7^fbt(aDi&kLw9=x8 z9oZK++S}?q$atF-)cG0e(+H*agOISMf(ChgBIRxTUr*{KyIv3rcW}iKj)>>53dcpAv zLn7tUnVi%=z$8XF{Pmr*V_#PF`0cGdv~*~QAIQiA<}I1!5P|Sgq!@A`C$~1**p#KM z(vkOal`qW?v;ETKs}QN11gY?vUXL&B;8?Yc)pn?gx>3D?=kAb7mW2d_QqKkV4ljM(ZXXY4mPNWN`nb>a@4YFm=%qu< zsohBqU$SOw0TMuq0T2++jR+*c^&}EgNV#rpW1F3>nfIChxf%krr^XoV%|2rzl~mBs zGk~_gFj>NWVWJx1x)Rw;DPbLXBNdnh+L)sV>Y)3xYt9Z1Sj4D+iZJ&_BKxPk^xpol zOkdyIT+THm-2(%FkK>{f1a#wGzRI++?0$`|hE9(PwKy!bigOD{ZNMXB*IEycLr!#p zL9%l0jY#)=t!;uhy-|+h#Jl*;xXP_Jk%)V|EbfBdgDE_)10dZp9bD;mu#$w~TL4DD zcPmDhaxGQUi*)eoeFL!;gZi*fRWgJ6x=-OW!&8Hf1iNJcI>t9sT%Kc_+tGO%Mg|t7 z=(kgwFFISJMU1G#vL2d=s9q0ddegt{EQfPfUz*q4>y%1O;vLiUIo8=X0r7fynWe3p zDxvaO_5?iV<{C_-J%6$}HzC5-eTi_Oyt>&zu3p+EJ<(Ob0s2Vvh__mJ)GN595kJs%0sgGa?7;5<{|c_;TOlWR z5js<>B7I{E(>?isNI5g-;HGl<5<-uWF2?Aw&Kk;!%tqir`x z*U#wxu0wxg+^SOC%4NPP7xogrnr0T>1s0KPS}$R*Xe;UqriqMx%wI@ksw5*0i z*UlkVa{GI=U1&Lh?{)=2k15>F1-dQU-UOQ+xIwgPJ1d z5(bV}Ri)6)^N*;-h0ey#1VQ7Yg0C%agK;_LosTFd4%7C}G?Whw4Iz19#jK*_5-mam zB+DF3qs+AA$#I?7$H6lw+WbRsa`fXe)wkrC`0P-f{LO<;Z)Zg3X;EfA*7EYhutzS;)78tknagchBfTYFYaaW}q zipOk@FWO6C+}1ZCCR+2vPqN;QwO$`PRzP8Jmtu2+1VF`YL|2x-QXs7hf*61;4wyX{ z?ZWJLrgLc_k7zk9(mB2ZKrEU|padP1SodUQvt$qn&HIXHd77+63Ns=gBaM2j z9Uoa8G$cy)FkF6mnr5hEPqLqp@(tXtmK=ND``^#3;?cg{?)@>l?5&{ny3TBk1? z{~KH4T7c%KJ9m7q(xJ~Fa-p-!ZIJ)iNyphXwjc2~%5Xv2aw6jbSzVr+ko<%wZ;?`o zI|e}g5afMiSr9Fntj#8}?9(<>CT_@_5NqFTAM>>x{`oT#a8*>zsAkVVJ4Sy%zAziC zF$?me{U_T%h;qyupu}Yxsurx4U^r<;+|H3tAUZ{=`nI`{pT()xv*88liXMWf+xp8u zbFD+dQ_ovHq1-)wU45W>Brx@d9{f-4xc2*M0@~k4B8LOaQ^?q6?J$Cz=9cp0*Gt8h zh-rKOsvv>Wfq{-L*xO}UPYPYTj(+5K*d#Hi zKQ-x3q4QVKXA5IOEdNsie;}kGmKv~;v9U@qKqbo3L-ZP&{=EXrr6qSy-qyC2Q=S=8 z4CaVh5;cKte=L_(-q7(vH?`7rHynxP$S?yxX!zZX$BGl5Wb#(kyXzX4Ao+f9|uLztdVnx)4H* zhi0Eh{?xI>?svy7Ji$;R+CveD^lj(h49e>@wBB?vMWp2qfBo7Rzn`d0h6w@mN>Fa{ z|96vzzRx8-a$vCz@t$OmK$OpU($aC-UNo2G|FURavSWb>(G!M(1y2yd4k`E`V+&3# z4AH0By^G{?E(U|xA~!Kn0Yc|o4&9H0B>gTKqQb@>P%AFf8-~|;;4PSlApQAV6IXNz z7(zf`k3J;gEVXb&kbZm=_`C(}Dr^t^i@cbM&7t@aX&0{y4f24FN9009?h=1xi7*gg z^~W=1CgR7ar%9Syaa8Q@K~~T*1I#y!f%Qf_S&q+>OomJJeRH-B{zA$F*eEh5{&1;} z?E0VSt#6U*?UnBwL7lW-GZgfzL@`5TCyfwpG^=OYWzB3>UpX}92cDtVtOP5lIUiiQu{pXEv*6jwFMX>QoaS=s%i0tZVIC%fp08(boHwIJsP9)>ck z#aduL%yWCdsKnC}G6jFcY6n$+Bp>-xyhs#hv$p3BLN*ve%kqEe)mOa1%1HC#r>XLf z2$j32(<7@#QMy4OMGKc&OMkVm0_oF1^EijbBBrdK+>TLeU|+E7*+tE1Xz&&7)R z0J8rjAp-&(pw}&9g4~}2W+ucLB*(mCLQQ)XbM8jP!r6kDPjP`|o8T_A$((GDoIHz= zxqc<{{_|?-(0YNx(<^3Glxs+!vhRDrH@Lo1-{_VTpaZw+(?Kkk5LezZX11^7j&z z{Se_7d+E90ScIr?9~=&&a@5D`-*uZ{Bi5+~5aMZ5yjCu$UEQXQD|_ z%!*96TfePW*j4a5YeUC3psf{NIKf=OD>hC~a?|f8BGEdMTh~=@lKN&tJ8mRJZhebr zp0wZ)3Cc7FN?F{@6M*yye0(c;WeoE8^nt;@WH!7NI21#Hy3ZqrmhbX*Z7?jex4!$w zbf=|@mf84jx?J`PxFveZfSsx=D`W}-m@E2QJY7eb`zk&GJOkCeiLo&uGfW_sW(dSm zSYzX@W#hl@Tv1VP&AmV55c4@-17#*es{u7AMQUj<@&dK5LO7+Ma{f&2$Tsl1bD3Yv z4Rf{6h7l-T(In8FH-0fjWh7>{+(AaLfPUy7P3Q0QYvJ5gKDTE6=|G6@3(xV8iY`zO z(1D^ITBD0>kDxirtiJGn?fv|N@n9hVQ`pH%FS6glw$Zl-MNW?b?+d4wjc54@H~L0#$gAFFMTT{!;}Qwn7Kp;#J04rDEPbe#`UaV;ii(xH30CiXsQtm<_g_Wu zq3V%5*{n@Lxe84f!3!k_PHX2YX?3SLtquQIUljwj%e_E&A}jdkEFV=v0-Apfh9175 z;^+OVAP=ewh>&g#oMM%VhNz_({OZd0O6b*9&5}0sgNIdOG;L#%sLDww$ImN*REt7^L3kT$ zUe!ie7mun0cqH13PBn*6yb|{&=2C_bl`%lBLY8qh2nMObr2^ionjealC2*?<*FZV+ z2Oiu*HXrIBGZ0p-@n`SvWC<|f(U)^aPv?09;TtV5F~*tm?|t+(A9&*LghxvCQ*d2~ zXsg6ypafS{@ehNpiwJ$+AA{5-r3#tGg&e}$ILst7n_rbr(2%bv}%h#ow} zt+o>})=(rkRPjj>qN{#JRKcV*$F+=LsAoafwejn1nr{EFeNGTC-p~Xhai~@={Vqir zYfG7vy_uz>IFce%Ea<#AcV=l)pzh=R=!;YbsSZI~Y~8{DE{KaSWhQd7jJj4DKaYo$ zxYYCNgGThCP94r7PE`|kWu^X;hlXoBcH@f5q55gDXJWHc)0luj!F?JT-0yjDv5XR= zxCw?eAaqfReWNAi9`R0mVPa0CZHKy0@@#x(Nw=F4eUgk zCM(k$fNM}R!k5|up@G4UaHts?v`-K=gI=&m_7E9CtGwJp?zzNB*aPTIV`5?hbB(RV zB~*C)-sgzgm?#i!Rq;rwynhLV$4mwUa!@q)Z9T<1adfvOS)^F@9*G-vg>4Dp+9Sqf zm%<#%*gaLpE0(1DDVC;~vBDpjb#Tw2Bo*3hzCUq$IC`VeOgk5U;5{7a?uPH$S|r8K zQ!1l-Rj2Qwcx%?4D2(sTsK7*q2av4~lda-egbJM}NI&x<)~)s5uQ`uY9Yg7g0a_)D zE3T)YM{7Z8Pj=)yofQGxytfuR2d0#t>scR+`9#W0DBAd)PiYPE>m9Liy3Zxg>_>XF zH-w-F)qQaCt0+jPV0$@=24jKLgsuhb+?8@RzgE1FvNa{9N~p9nQ~VR8d^`>UqZ&`F z0(86IZY07yb#AFya$yD~#n?eDsA-F>YpPe2*_1uy&_!po>ls ziY+0TGlInU{dA5uf3@T@_CGnhouvei=Q>O#*y67VIf{C3=ms6=>-R`?QwefBh!V*# z&65uZ`tC+Pz(C0~u1FN;X&ni3ZEn3!bV(jRAYFF-O$6s=I!FI@aUPEYQElb!pdQWc zRGkM5YrTVrIM!s)v0JOu?znNTGOHwCF_g7S(^l8wUIH!}Y3>P0C*qYt5O1xno)bF* z{5#?RYQ43P=IWUZPOw@xjv$K`Mjskw1O4(?WyMAXxhC^KEC zz_oaJz*!$nae3%=*R;~or$G^+)F(F6ZiZA>$L43|zUIYy%-XUv3=ju*wl9WM;lJ_g zY5lD?1&Km$Ln4jD=A?iKq5;EqX;{f~hpKHA`cv;Ky>*`sxpE0iPRIVt9igot4AOo7 zpBe?E-n|`NoL=F7scLZMu{KCtz|RXL953+i^yzq)c;J|jdy3+v@fYv{p)Ryr&wOHI z^~B;I`Tn#*llF)#5>%liAKp`%>1}kF+mm(+^5%f?EPvX(O%(gUltqtUNaif?YOcl5 zP%+d#t$tw#3xmupX1aK(#M2N_VlLVb4U(M77%RhUCk1y{=7>4YrY2q6_LGC5uDue7 zA~9wJ!S3#(S6!B=bwE{$shK@# zvWxbC&IR?;e@H;Y-enfkw$zxN1mN;l*XPAS(BNE(U?xLBfV4 zBi!P=Ir!KG{^U17tAy0xRU#8S#laPWD0wMRIdhZjCFERRKa-zU(egy<$qr+2o+Zn_ z^psa8G|7El;5E8Gk zUy!VF*2JC|y_`;$;W{MnoU;nDfh)*ByvB#a#Ia}STMpO%l#vUz%Q!9nIxk*$cHMGp zV9Rt{{aY&C)emu*lg$0H2xxP%o7}JeZn<={x0$UDcNIF-f_>yds#k0Ai}}#BrhMKT zvp^^`54lXT>EN=ysR9PX53~O=n3`Ah>rE7|^Y6wo+@c}@>Lre@Jz2Spjsmek)RKs( zGE(oJJ^SrEi25DZDt8E11}R{B2Kf;e=XloyBzR<5T{#JLdvB5+!H5wV3y2S9qc&mDVj?q;PO|A<)sLrz#nZO1vDUxL%Mp&UcTzw-twUQDN?{88w(yb zV<@8WR!J#Tfr$oD$%v>4Zg+OW4IJ5oVOBpv3(hTvl z+i#MfX(wF$e;U4eK0;{!+716oQ`0H73r)Ax!09BHXeKYLlOE=i{)q^I-q48gQE_32 z`Ua36x=zH5e~*zDjgD*{!Wl-2)@Q=9#@zL+2VoU;Pilag;#1p*(md; zr`P>9o9RJB<$VQOK^^gNMHmDiY?Dr*JG>z*Ls~E(GL?FYe?=`&TLs!fg81e=Khhxk z`r^oN2}n)6kt)kdr!Trp;j+I{hORU4f!_uR%dODR8OBJnf=;z?;7wXSkNy%3g8oK` z5ZDOiMGjJ;zjeVzoZQ?d63n5BUAKa1WCE9AxP^bHh{QbPxg*-<`}%s2=Ge}^OS={t zKEvzDCW9*2s#&N&dRPuDw!_8;SH&iDTTiEF607^?PjY+PEsJP#+rtI8+SSCW3+LUD zGlazdPs)+1vSRD~4`({<4u~?uo#g7)c3uLjf$F?WIhsE3t%b_V8_9DyVulQ$Y~ybN z)|w3Q0le7*gOVj6K$m+g0Lw#aeFbON@%S&qDr{0>3IICqowL3bNt=lGsFK$$PIC?_*u(#-aud`na@3S{@zq;Lcqa`M$ zUb0gN8|%6@<~n9)_wvZe7Lv0u9kgd73SN1sytJs-wI=@X16skEGX|I-hMHyq;37S$&0M-;*Tb??m0}c0&|i=ibwXFx*|`;Ixa(1y?k4hzK^eJdoiOtz^~^Mbw2;dF6TOFtnR} zgx&sB99!w~ek8sFyYAe)Yx`2yrzNWX%zIN7#o0T{#Hi+y*E?#1szw1+)~TT3N-4>e z5um{)F@!~BN-hWbp7MFq-XUvZq;EJJ9OnDh3_fM;`fIkfjk4PGxR92)wJb0S^u-*u zvotWbDlj+(yO*Y2$^W*Qr0zgtSlFX$eDqd~xy*5SiL$!&r;_CB!p!$9c8UBN96BhO zs>-d!`=6@7>XPAS2P|7lLpM>Cn=<6bJ5dxzKUaQu(UvfO;ajP55cpzwW^G9zp?suc zOnHhqOy7?doZ;-8t45T@v8msj)ih?s zbx;FRR84n<`10ZoUHaP5iAD!%9U?QSYcA=yA*N*luI^uTMe770nbSmB#j|7g8 zyi3a*!F6f`4Lx=58h2M>Vm2G1s32?d-~XmlCkN-LjTK-EiPyWTA^cQLEi}IxKTX1V zxIjnHcF+Cp`m#hZ$M@?p9Ua|$quFsGYEOcoo5_8FBkWSc-afYQOB~^~H1cxr(1gpZ z=p4>_NF_nml;|jK7-3-LJWdCPnn#5k>VS8q#uF{{r6wCzJSo$OuMW$vqF-o#Qtj_& zi*xhbYg%I=?ijHo;gpI_yL-n`O5g~})&#`tK(Tb90`IWPlXb1b;aIu5%S2r4GB(P1 zl;!_8qJt`jUC{PEi*(iDpaNd?2tVBBndLy{B3^z*{LY|235P8V-xZ{F@|Zoe95}+T z8^8Y}CVzBm)yjP;pop`vUmsP)eC9#Lo|Q-vG?Be>MVK+dn=Ly1RvX!CZ^z@h#BD|T z#xp5|75$S|!HuI!B`Cl7OAs#q>+JZz}OHoyX%pN~mifaYE)>bX+qqp*ovjxna| z*Mn*NZ?30(A1u9{r!lf+(^m9tz0^~%?n$Ondo}wB&eoqli&$>68XKWR^UN)C+V-Q= zmWk^xe|sKkkKHgax|}G;&2+qTVu(vRV7;iaC5n3CM`A2^Itjof|TihVY=?Qoqioflua%y(3u$jodxjSWrQM7fS0p+2Z)>0&d1 zn}3FS@!f-EzY>nS+2)qbQ56*Ms~MUqT~bO)WMJn}dXK}K=z{g&t0&S}cde;ZP95`w zcD*P;bt)uLNg2uA7wt5^DjQ>3@_N$O@xF{(-Dc5npk|q*xj=$OByexyWKDBdTaRBc z$#PTAQeJ0GIwD&0IPk4hWrEzoA&PKcx&I92*M-#MV+E=h+S)D^bM(pt#@$_W`Xy?j zdg}E{$KzK%78TvXuae?Z;((~ItdmQ-wx8!Ho+s1M+2$vV<692Ybl#K6CvO_u#Vlo7 zc}U2P9&8>5Kb_6Zn$vthy&VQWqoK&0f{H&cP9anp?Rh!lux94{#Ont>Uxxs~T-MWb zSH5`ZGB2^FKc@^yEv86J00IzQxrt6NQl)2`5*rGgHQ3FE2W=E{(-=;rsB>AFPNy>3 zuNdI@+Q?Q9=8m6VuDz~0j@BskYCHK-bj~mx48ZkEopD<411@!%8Nsu7k)d^lnlCFZ z#MR_|GrUnpan_vN+}6Qw$Cd-zHPPX5vM;3GP6uYfF{2yur?=mErQP{dc4uB*8aM zw8wpLtdJ?W0v6}GD!Mbno9^3GxLhLhc|jYh{9vKY5L*9-=Xj_N2}H%khh5Kri|due zDWebP3&z0LK<&vD;l#LSuLh$SGnHP*tv#6a?|G8@6t39P%5v!Q&?uk6cQVnmwtE6r zEwdyNItSnDTG#g9JNlmE=H{85!`iCuHXY!WJSB$I%W5x{S6V;4w!L6ol$n)oAkvW|yntBxn)hPu0lZe5Mj0=EuK{HGoR#OC@p}p&a#TUOHDP(=M=76AHE^OWTB|cl6<+FUJ+Aiq zz8-BBe;;d%(~?m*Z#^w!O+l`gJaU;tSBFV1cFy7OyL%xfp zIB)LUq+vC%wTf|H)Q)obT}8rjxZo0PU)IP$8FhcB=n)cX5tEtuhl;Z{Py<1D6@yQ% zfcXJZ;m#L!{RwvK*WF6A#2tbxn7!N2Cp4Y|!Kuk?OoT$cyVPgOqM$z(adx=$+xi;c zo!j6(^vKh{^G#KLi-y#uB`LQ}vgO$vNxSuX%f#2q`q6AxpDYUY=R*HZl24VDEYbm| zk$Vvx9g~_}r2;2OK25AL*i!Kc#;bpE=IixP6`%`!uJ{SOOUuZwFvn9@CMc=*cyAYK4G(rM}t8q;!xgFJAYTVrY2G2ZXkw8Jts_uMDG*|)+ zEv*Rret&A==Xt#IuImy_oSmm2k4ElUS;jhxXHd-KBF(dFt5uBGo4OP=Dv z@NEeXD>oe0$4!Sj^YDUvr8G~k@;mMAAcd4H`Bf0Kl~YMiSL;;Q5j7pB`a zi45Qnk0%&qZPiPLEmiRK?HJkUHHHl?DsoeRn6h;`*|x6>|I$W8@xbRnQE~Bg z1>>=gT>7C6{z#lPTV{phDDm|Zwo7jpxtq6jfPKjkU^IJB<}Nj6JK8tISg{%$qfL($ z`u*;ehWR~Bs<<%Zdj%)Ibty0$(T#3xjUMq_qA!8n44!TlZE3goIGrwcNB&rI{ifR@ z_2u5b)=!{hNry+0O!B=xx{eja`F@(W%HwM3wXei1Z5NFq{oboZ&~34f<8{^6bXGDS z^(b{FXbkmX4*gO#i6%swrn-`a14&nr_eF2h#E(MVBop(dm4rwmYWjSG!#Z3-;v>^% z>R``K#q$PNoz`g~8@CGS=m^)^Ru59nG=F54O@GsHRQC+0)cMzUx%h633b{w&gqj$8 z4<>vqG#sLQ&*y2N$zd*W?A7REq0M_f&OG?i!X1W&XOO7`1lu1UIcr2W8$=r7)HSwx`$MS>+}~ zunw6=Kl?g9gkVQ(?ZqPw8O4)dWx$Oi#x}-jc?rM@Y*d3yxtY$VbKRUF*9S)W<_`~; zb+*g4MGcxP6JG#ZJl%_b>7H0X`Sr5n)3=PBA}v{8mF5$6uZi3ds?dhOr+3f6Z+hUl zT9rWIED&0V`5#bi)IOP&3| zTcO#c);PUrHXe&&k%fI1ehmAj$x&j{tu6$ld)g`u~P|2ad4mIAfah4+MuB zoF34fm}SGSd|ea4?_*08ZKoTT@*}$3R!oO>utV(Mb~5>P zw$d%p;1UR^?l=PUz%x;NKdRq7^v}rC^?mR*hX8|5CASeS76B31eq~k2 zOT2(Z+G8t=-qfg9A7nI1->XS49l8wygC{K9CPp*bmyh1%;YbCy%NwlkSjmz)Nj}6F zr5Zt(8WOtpyR0rT?&Wb+HC}qG=kK1iz;So6ueI~9qnvjdoA5Qy#;ruQe?_i@sNm-E zTSN0)VjZPeIeEBRFm*VmnJ!#{lhw|)Pr|;F^L{}5?W;6%SGNv-zg#xHe@JrRW~mhc z`}H~%XbD03MbeIt@DD5r{a#HRfuDkyHock{P zhgIr5`2CWb5!)WZRxEPwvmS;x$HcPABn}_U_m*1NjJn~}mRSG{uD`qqkfZy@Af1H; z5$t@n68CKTNFV}N(3>gwbt&+$)&LFi9Ss?T$bL{&2i@8HtNtHYyE2nay;~fcz~57V z!KT(#ijf^BT82Pw)^mSzk5;ms@|Ox5n=|gy?CRT57t{kXdL&}Aus(-UeC#p(EUFx@ zfdo3-4|K5N&#r&s2t_O;f3QP~_YoolP9PtK1?>upTw{52IP)nDJP`BYbLdUr0AS&q zXHZ8_TP5tAm^rm`=f=kmWJ;>&PV@&2J2F2RXS9z;(?%GKwdFCK3aZXHffCgokiBrU2 zSR%@`n#L9PcMp^u)<&TcFOzK~H7l&ytx{hhr>Q`VX{qMvuj4?y~^sll+ zq4u5v(}>w{Aqh3J9XlA_N0)Ivt&-xuatnpjx$bT*q? zSSWY0-iF9sd~um)-6cO0O^zH&DEmkl?Hwy!>BI^D>2f5HM!8-?F#Dbo(>>jvTjSNT zkD&wWopnBohV%UB+ixr`{oED$nW!E__lAiOcc%~ZvW$*G3?2n1F|CK-pk&y@5l80h z9{MIW+D}!08wrF?$4r^tJYE}{;SKBSeC@avt618@i%n|(kql>frgsApwpr{a&1jjYS8w@zd#Hcq#&{3+J z6F~$DEZmZE`B7+B3WSq<1^$c!PuA+D~C|y_AH-Jvo2uJ*_g_Ppb6mc`;p? zU!EDy+5M~xin;H!__5IWrEX}9C<@hVY&=u0TIw9B)!8m1ZD98RIWmd)JABp?A05S4 z==%OdeT4LSSrxg~oAdc!lC0qFAMkCuY{FqoY}*&mV{LhTc*(x*pUO_hmThM;oFCXGF-*BY(=O3YG4tKR;uT105UL$%8=S z4H6+gplSMc*ShD&ul5wcYCMrg)LEocINk088c{UJ!yX0}RO{>qzTe$gjfSFjS291)C{B?egTShiEBE@vXIgc-;Z^v!c zbN6eAekt~lddP`mb}9kT&dBdQGqDl@4n$2pvw5Vw7(7)N$f*ASX>%a-E?$}gg8^Zv z4@1_Y64SBziwOO>OE5%xrwDIVDz%99IBV90F0;<%hGHp$2TCh9J;Ma^B`ucT&0nCb zb$-FqV8hVIGz>_8AQ(sj5!G(suNww3Qf}4C9}gpVW^fuq!B_S#8ao)MfgR-Didi9t zRW)p9IEu?iJ!tx71KS-qzB8!>Q-HriShu=5gX)LUbA5x`%j0+hA&-a(=NM5eL$7frt2+)M}s=QEYTw!{YOZ||8(Bd*B zLJq|;ceV0};9g5WZ6UBrV|K%=7oIWad$gRMojHNm($1WIaIp4fe7nSgx^7RX47hO9 zBLOI5*X?y|^FFo-0V1O{?%gBiV;!B$ZI@<72I&y&ekApojh2c4&8JV&r;DnQh#D3m z0Q?FKk$qJjTdBpE5X{R(rA-44)75#@Lv5MG^%hh1Uw6{b)hJvnx7%i)9K(4x8qyPV zk}L{JKOnVq-AP@2I3@X$H2l<*=ts^kW5T?d4gNZ0_CImD?RMtaEqYn$Co&NHEG<*N zOS{EEq<5nVzwP(7WvF7v53+kp>G}?nzgRC$HeKZ(xMk(B+*ZO7xW1R~8BWDNP&%s@ z9?peW;~&6_s(%T3!1NWw>Y#pI zmm~vlj;Z?ufqw}Nd}WJ{5ZAnB7z*ReH8s+I%257<;l&Vz#$7DmrmfxYt?qmJ>#rt# zL+D4M8`Cy}c7&{dyl;K(`w!>O+ddBn=P=or1|QaJc%rJvS{5P594k(UtdNdd2T=*uk6Wl+75sk7%6YkOSQs}! zUwd6zZ|=b3_`6XRk&Q(Ou7$&fi_}yh_is=q+%YI*7h$GcA~rr;#6aOv}(GxrkU9SMAG|S1NLQ*WC&&B;fts)15o6+GW-{YWLGwMqKvo znXjVn8>&gZ!wujbE==X*%mHF~wNQaT-0245yr0A)j=DJ9m~-eGL?iy87d&R^Oo zcV$L1Uj2e?VZ+Ue7`iOqS^tim?H$$0*6YI=szp>Eq@n$%e=9u8J#|b2dS-173kz>{ zV44?%bgXpGd5KpoSqV3MeB-YFV&>I{?QRDcJDb#89n*H`cIomXlZA4yUdV$eX`L^F z<8ls9yBXeE311Xs6Oo1zX4Dpqa32xsmkB~Kod-(KQ0=KDeVTH%GB^)Q<3bhnB)h@(=rF1vW_MR=YG=na$cC@&5?k|*oixHPy^-mFNr>5iG5l8*e2+2m zR&la{O@Pqf%+m6XZNL@NPu8aQaqFL)w10@iD3R|>>C}!lAF@w-0nPFla|IJPw3)$e9t+S2UkGIvk>mM9JSt%IVZ? zi>>Ej^YU0A?k7Y5@D_u4g7%4X<*mOt2>po(f{>U%Xu124*t+HUjcUWf95)=7#ZSAR zdpqv3T4jxNc{=aK;8ax1()4jSc0@-$Qn2U@K3VdGPVDu9l%4vwdwiyK&sca*@4D(IK%tMa3VHB5u64(Tq48WyE*lwF6IZepi)V~YfAM?_lY~yAa4WetzJWT5|yYZza{F)%uXZ z|52oBi4#&fo|149Par3Ve}QRo#2GzB&oW~U=8s=kma}r}XiKg7^guwbYXQS|3$1;S z1l|LGBq6Nt^(Wv(<*nYj0ZDowcSe2r5+s(V_ICD1Ea@+GCWJz6!~`G+BMIQR%P(r2 zaDh3wS{~oYV8I(eu!J0m)%V#h5Jyw_H+$Aqcl#Q?Kg=0M)bF;4PrD*TE2DdomkKhWJ zOxNekbZ*5-3?6Uv?A&i;j%)BKAmKH)g)J!pJ;M(?|g69vfXazn{N@C z*KoD50M9tV*}>qT%WY(gBr(p{kv3m{GNaI$i>;%BN~$_G$A4kG< zhHSDg@j=yvK>#VW+xS|mHVdNpTSl{=<=hk!P4U~Il=+vCpmi&DF71}{Fs2r=5_Q;b z`OT0MN7vs(ZLXEPb$j}B;Af2$aYQg>#o_|+3`*P`R6kD}mvf?4QozQ*2A7XP(Dlyl zSvl*?ISc$IJUEu%Xjt0Jq5M`rlCsga$b2t=TVPr0-WnIYyUBOqj@hX=Fus4BMej(^ zFkrHz>?%2E*b5(fctACBhvO4sZ3sGo_Ti0`XQo9g3YU$ICWz(?(+uo-s{C3#m!{=p8 zweou=NT7vUXsSl!yKn0t0Zy(3QEKu!ImzIEJptPcpb={7G z;3@|0QTah`lf?Yarm#3bkeWAy6HI?Hc$S<#t-?})g*id7!AJLNGf95!IBjWM*Sx(z znrvr4(i?;pyfrO$(y&KUvgcu1D+C~> zcR6jlo3RZU9akZ=Jh~(@^q6ONmPmgpo0Re5vIT^sm={YVLlmyj25M_tKq^NVSnO<1 z8LJ@%n7jN`y=5ijwr@`QI{Q48k4X$!_T&Hmn7ZzGtlRc|m!hYPL`ESYB&#HwWbYA4 zvXU)(Bs)*`NcPSiWn^!PkiA049tqv{9>4Q@)ARoN<9(l}kH>vq-|ITh^Ei*=IIr*Y z4`2uH5ivS;}+#4)#*4 zS|GTbB1f7FItJHrUyVpPcIOG$fNtj6`2slIAvmCw`c}5eREMQ(NVClwY$u~J3_5>X z|G>a=D_w+JX{pnZ;_n3NV{yN{(0XE@=LEk2!F%E_0b<*6OB9yAsEg_vJPC7GOUoZOj9_h}P*1aDa85fRoaejjFa~i1CWd(_Om6}s z#jIULJ=X~!r0yPlqXK#PKSnzFbh&fL*8{LNH$5`_(Rrz)^V^$w$E7%dh2WttV0alD&(5{Sqx=gPsugLWc+13_Mpy+!lu+CDA3Qt;uMPWYr4Vw zpL-VPRAcDxs0-%6sY1C^rW(`eK1TS50#Rq7M1O>P-Q>XF(g5hI-Zh*Q2d>0elPT`E zCf^~=R7tf9Jv$gj6*@A7;}K5$xrC}4z3aSxTb$}#Tx@j2`)8xx{_YVVip)S02ND=k zAi3+$uA15CiIB`1A~`1hH7+hb;wgA%qI$UGwqK3WE*@?cK_TSq={K1zrYE8l7-6m5 z`;D+1o{8J9nFHlG^Uu|#*!|AU`_|_lZ0^jV;n3L&x>&%*~6zR-Yv7PC%`ainEZI9D$R zi2!Q+z(#}B)1?3wV9e>HplZQid@TXFukuSDOI`ZmBA{Bz;gYnwX0sl3-&T#Y9_=`h zmnkDvm((AuK5+evtb#lw&-3t-5RQkl2kIa!h}1(pL`}gzq08p&o?R{b-ezl_MD4ad zYg+2!yn2Fg0I*ldQKrq8`G&3%| z{NYC1&t^PS-6ObKtYNF2?_ya+!Cy&}e=KtJ5JXQ}Sp_+=a#j1<7$FYR>5|zJESwo5 z3Gg536pd|vH*Chx^^G;~+FpJ!*OhN-FZQ;PhP**{5K@IYB>Rv(^BpkrT$!%>Y|rDI zDgx!7{oHeVuNUv{lfdQr%4T=a95cnms_IXkGs4!~PY_e0mU?zVN4z@D{@6&P(0Jjs zoz%l6zeWDMsNtKF!ui)}W(Be!+eZ|aYK=zi9^DMWN>>1)`^?x@T4`q$mIsDr05-Oc z(KBsol6%KFID#QIcHxc?S4zAGE_4P6?i829_73u2iUOjk*)w7`dB6K=>DYb$#+Q2< z+6-^L^w&1AcCfS{gd!ZZ=PTFH2ZsOjbHNEkMcjaRK^UYN-`iP_J|Ly@=|E_W$2<6) zEqWProGXpUCD|^t2cKOcXIBnL2zB=mPEE^d4m=S?Ruobcv86XY7nrRaIGfw&Jks+$ zu}*wlYa4EJaGW*g#D8sfdxe?@6jgJ}<~A%3{|koCU)ZT4Y^dq5@cb`~py&Ikcf`!( z{fs~9G$dR&=rDwS?E0gvUg2bm)T8t+=Gd$bQBHh%kUR$)bWrO0;1Oxt-U03+2AU*w zjwB&s-S0o45fP6dSRbiH&MaO+q6eyqG9xhriUuf(;o)E(KvDoTASVp z8ce50A|eGBFSdL>t2=@%ArgaB-;2+zD1qP4oPU0S%@>XS>Y;uA0C(N~TXEht-V*M9 z9cV+UJ+7HATAPxk86B$UO2CCwcFAGH`2*c2$GrHrnn{XpYdnz5gY5GlroV`YxCi2W z3be(=Pr|?X_MSkCcXXG$5TZ8Ux)PzTQ9@q;|GIzr!v2;n3vlBsLe@G%B7pqy-2`c> z6B2uWDkB_H9~~~&4}5GC`#XL0M#$a?ac>!)pThwwB$UNr4=hLnkW!(Dsy z?G%bS(wrY(goEq*uImT;FZY!7*hHgWao@XuaDJ~Yi5a+*?bXkF)r@@vXTyE^_$Dx= zwZjI*#u`xlIbFmZM2nS12+5$Wv%R^|D;iC{Li_NcKF`pP8wt8NSi$zT-}a+CxT<+i?Cp(!|twkHqDcG3SK+-i%ttv1_-E`t%?q4G%jVzD;}{mDmtCZ!UaZ?B{jg zT(s}hJVi3!X4G}ZFaC)stJP~pQ(yd?H;-PG(tRKD=Ge`Vd#1h-&0wxh<7#@4yD)rK zqALAa`_bVRdiOVLKXqqJj7I8*z3zjor_hRv%KtudVr3=v_>zGd@b2(lDPsZJfojz z!^gw}#v$U)wXX%MJB9F;NCj&O32ba=(~s3MlTlON`!W`8-^x7SUYX>67d>BKk8Lju z2F`4L`X&XzM|?L5fr(n}Dy3pyeRZ*m@jo~@_JTXmEAqdm2~}ZEHTO zI{9nnr=eGZLsCRsz{k)v;(8z7-mbY+(5}+{{9Dtsq^W1*W%#zQOx{6G#V&bql@DcZ zJz0blErc8#mcDVWjpF^n9t+L0QKx5+kq$BiX+bQ^Ori6=fr|wp!rZ$1SuAuP>fUP| zAT$eQI*q~ARv*P{$0jGnbeV(89@1*Y;b)*)ezvO@msuXhJ*~1tu%4GTv$O&mj%aSf z`g8+<7ojfOV@MRm-w}leVHKwyN7`e*H65s0~eiAzj?!0e!(CCugaoL$D*x>E62`s}09I!~~IeO^JC?dmvu45XXmj56!R>dLZ+g zjPy!JRv%wEjOT2xnhP1ntSt{qGA0q z5&Es;U5KC=)}$a4LywdS=UPUAYRC}LX<3qvahOKH5m<;288uN+zpu`$$os_V`ZouB zK{{DsrKExQM$pPr1WA7Q{&;e*DzK&G#q7NiiO!LnCMf=?v+*22IB~#vD5o4M2rd6% z{9|Mgfpu2nI+YZHJ%~}zcje)`)d#Mf>R<{21{prSJeL6;F1VW_4}ZxGNSa=V6cVOzk*ygZ;A5LlvHraSFUkI^qN4f$ISM>TFxIUmLNo$-kFzJmBVUInEh zZA_-`+!E-~Z(g$n>5Yn&A;OC)^4|>hPt;4K9V`>Vp*pda1CBf?zxC(lI^)AJ*3b9y z2qX8s4oew)2|az!XLXq0Yf(8^KXzRh0QBf_YrS!x>S+ZZxu`N5sGidxguMo(Y%qwn z({+IpP9FH)84j>+z{dys z%oi0EnShz%q`~muJ%3_w1y(@=TiW0-9w3u!t(j)1;nmr?-g?B0&EJm(;Yl7^EiH7elKZ-yt*odd9tl)-))h1!W3$jj%4 zOOQtfsGbN}g0YEtNUr&sm)H#{)fOV?BH{ZE3jc=~8@4ox5GiVz5%J2tHB};(F1~U+ z?oyVU2O~5lobR~rp~ur+3{O_jgT`=4dsT|n07m%ctusk^@J+}f*miH5I%gxsRPLr$2ip!~r z>}W3qn+%%Ms7=2Py`Mey5|5SZ5FtPJsV4Hq?o%+6=F~DRLkHyjuU)axus8L_shOUoFvV%^R`JvB&OGtU=2t zJuL81P(8ifc3^%A_P)d%_T$+{Pt7uPW}BPe@CgeC*7@Dp%k!D+W(g%~xIy7Wsv zjnq4kVrDB6xa9>2^u(2@kNM~apD}s6ne!omB+lpb)GWuNcq~-g9Cr|Im^kc)GL;Yu z^rQ%~b5MY~$7On)q9$30_sC+AnYkJ4NF%!=>Z#+iw&u=d zi1vXH7Gv5!M+sP;9NR?WPNc7KfUBMf?=ZF^TcfY$4V! z7GP%T`VwVO?(>kxCLL$-$kY++l&AsNDPW=^VVxiXsCjlS4wl&1*=mBOKfD}#dehfE zJ-vr!mP6pA-xqnhwn{3URjbB_Rk^6Injh<~!8L3-;Dd9w#hN)(vQ(*Ht^JY;8e3S%KU5NdA~aVRo?RJ5VY zZYh#>lj?9^zFfk!eJ&U)ED%eip(xlB{0pOe&I`LW1@w*K7TXi<@MNp!v#CrOwKBsJ~77ZLm z6jAYjt-lY39RBj_H8o5!NS-cW#DgPPC(MKyda6i1CN}@o6$4Du*#*vSiY734!O~c7 zqs`S&bqS z!~YQdY;)q_>H*&$FjL~?l}jb8c&V8fqU?14a_G;Wfwf~`(mkTT{~pf}3>Scd;YzCt z`~%YY@JaSIG%wXg*v(@cXp59_nWs?G(!^)Q%_*(pULR*@?t3;V1&A)PGm;r+5%E&X zAI!$Al!tTaB&hobh=x_qfM^1$RG|n(iPEE3`W1$S^TWXYMp-$9#*dK`-6T5NxeII1 z7tq<9+cNg27lQr63;0FFEgBXt!y#tu=PHF5mA+Oj%xtU{cDkk83I)~jecFoRC7WIB zsrtyQ4M+<3*HtoT=uupp>JjYIoNx*1{RCAe7{91C%hezr#=H0$Zf8060^GCk004?A zX@Z8`eWdK}?e>wS+MTc~`*9`tIUmFUc)oe<$W?MePXlM83qJ9lk!Pdt12#4|)uR%7 zkt{uYlBK0mEUt4`7B#oe4EC>2mxa_bV1_vZm!bzX5b(^RCh+H9gv9$zdJw~J@LUoU z$S0coY}!Z7hS0p#7rb!nkQ=z-XnB569yyu<2T*T79)vkuBsBk{L!wphaZO`=U)4TXm~$GCKtilNemWwU&pKAY?M0fb2cV^`&80n>KDz( zb~rAenrk6@|0Ug0o{hIYzb|Jo_8vUaP{RZH?L+8PqvN=L)}hb!0ukFAN(A2wVPa`v zSKT#xNBZd8mc7(W4c~iEG(`v>cF4h61`^B1oTc}+wp6g0_FvJOTj%GwdjPLtJ55eqyH&f{s_?yIun;rc z_6L)#TP<9R%j9b8v6nL`{}-O;PV;c^fu2E@mRC!cFbDX>9;R2yq02u>*kYHZ-XXF# z!WPBwAn%Js@gW8yYSPy_Kbvz5fP}S|&+x$k9XZrfpp$gi9y-T=Wrz+|ch<^7x$)DU zaH46LP}H@cHKwgS&Vv*x^)5f2sM+Yf?NbWxEuu&wY>zg11rx(MlrfVs6&N8i|EVR& zC&k^gYvp8fOR~of+y53g07?i}^u}s6o2!@s)ou;!PLUl|g!aqt(5bphd@W$UiI>;~ zXdLeTQu&~Yhz%IAYZF!kt#v@~UxB|(vw{Zj^3&&#CEO)CtB9_HcOm0RAYG6MlrLx- zI$P%&ie#>aw+~N0SKs-WX-3~Vc)>|HpOpq%9!TnGW#j38A4k}W*%$VPn$4ZLqcb%Z z9?KkTWy6y@h&0517LhVxcBV;dIVjfrVy9g($NSXEwalkmEn|JKB~Y-3j}TkmnwL?3 z>qD&r8Xn8Gs`jip0=ThQT1Msr{MR3DwIW9VdMRn+?XnQ8w9d8;NsJX1dHf(#&_*Kt zYEXUgb65pN5k=`|sW2@J5rRyQNN7@*Y`B=X{Pid2<0xz(J^MQy&pYWrUOA*#;-<$T zC;?bWa^`Y$Eb?dowMB%9w;^*krlud@!@*tV1;K-0pQIJIZw`oRd+8JblE{92D3R)B3(f?P&}*H%1u^jipxci2%6H(Rls`z zHbtj*K(f>Ep{Tjch9f>F0Y3neNSpy5!&_mb%oS61b+A8hTqMpb3{eLP(9i&q z)g6wVV$>#Asp4B9r{RTSj<;B1W1%3M0g2dZ>4kNJ0md&SIN-m^iCob*tzCw2I;niXJ@MSM(1`LSz2nzb14{+_!BAX4W* zXU~Ev4FVsQKoWZ+?`pW*9Jc{gt~}6g?y+bTs(4|6jl6ur;@Bw(g|0ClguXEDafcfn ztnJ6`8!jgYkiB;;#s|BD^f1~QE_JABo@+?ht`jVVi0x$u$F!81fIMXAAsDYiMm_;@ zw%CkqKKW#3PV3GC!)h~+BOTo==)XTsr~d&&NB8%iw^&$mV25(@@>(XpoP@p3@1Dyr zK)n@-s*%#LS1WqdiwJu7Fx}w2Ijx45B=|_R<%j@Sio~uW^ zOmMt(LcK))Ku@{opq{Jn9-6{~6sCY5|u4%De=&99%MUW8Gu7{T)+d zV@z|3JMOo?#Z@c*M5FAH*U|4!3|`YWI^9YD2&e|ql+Ov2!b50btDRS!T&p~X&23#I z0yHN_vX9t^g`R?EC<{O&a-+dFdwFVq zq^#jO2M!wvUu?zPR3MplaK(vj?E)!RM=5EG+Fi6!PVy z&PTaup;H$7MTOtnGYSZszlDMq9P1VivmL{bG($i~K>V&OLsyUf6xFa@7b zgz2oBgoG;xkCx8B67QaKXgY>J)pk|qIjuJBd zr2%_<>CD2j@f~}V`{~w8N!iK|)*gj4x%fqPWjCC-~NTad*XLpDWLodz^PdCqW|k1v%}p1D6t zAg~k8_IC3SCZlyUj)}%mL)rf~0gijkEg&Q>)DTX`nOPSv0>u7!2H7}gD~brDM_439 zTn~3uVzhXh4QW7EsB+DHoE7EBz1kx_6DOGEq;fJ75*_`jnG)6Y5_qneBSW-&3T;S$WR3ls+Pt+uxiPb`NE<48-joZ-qF_S* zSrVzqlH&FJ6?eEFoEV%T7~)nUKyyxHztgRX~d<@zFK{-d83Z#$@Y8HPKO^J*F6LmpE!MUh<#@1RyrtDa)VFQItXA=zeU z8WkJ=u7jF}h9>!is1j;yU~91()GwL)KJX_~kODmkR4g=a8%4j1{Qo%JJ;L z==zQMxW0Ur3vOGZrBa4>i_k8UHkMqsddRb^79Beqy3mIaw%FY%z{_Ti*cP#Kc}lC# ziG35jB+KDBncvZAnYQxK=YeaUl&Gj^m_hNA%kDMkUxh#TBXchj5)v+P9Iub4={CQ@ z7`8$^ih?12ShwUJ(*l1$k=+H#Yob!@?YLlb?2u#*(knAp<@NOOQU2&=NmdfyA)`@J zXl+0a0|&@HK8|<;3h6xV2;QyW``cn{}$xsG;^gj{|EBYd0_SmJx*f}8cxgXTFW=_Sgw0b<%gDPH6dKwgxw!blE{>;tD-V_{YCO9~ z^`#5`w(YLmpuHCI)qQ+6$!fD`VN0hf^uvewUhon0%FeM&3M+~bzv&_O{b5fM9Z)k7 zCqBt7$7FGO-Gx*)6FtBWPpZcGAyGwzQyRx5|0$TT&q(F)Q6XpiO|dySGorXs^|3?olokRL>Z-3jOFQ8j33LplR8`hp*}qfsTrc&cNb zjP)q^H*=Ly1>AbYUG#OYg@`m-A0Ngye)YTrZXF%6DNkm+oRTkuTbO(aVRflLykuZV zKjFA*&dQ)E&&Huje_qM}Yffz8L&I>9l~aZ+PZ$ zX;iWOB|^TXuD$!S#LU{JYhxpFvdD=&)o>ZLJLFd*!XbbmSZPijpIoI6^Av+JYY{2~ zIn+UV^8pP#RZ5Pv-wY_jk66ESNnEsi>*3>bD5BxS@I+%cmE+Qy3qfJ;4dkPW@b}Q1 z139|p_R_qbo4!4RjKqQo_m8MceM76}g!af^j-n5OY{g9)tO5wMtXPs6dFRGzonvcD zuT^jL3?!xGsPd-h#_t|>vLB}GrEw_JIxM3S4ocLd4Z8#lW9a=v>U+rTZUzQt@5={E zO5506;3c?*gweUvvI;>E3b0q*_a?bt&wWqj_^m@7c}r3P`MZ#dnElILb0GzS%8)MN z+vEHt*gq1n7%rx{RE}Q*>w;t>L#Ny7?}&;PZ5%$c{FP}dt|>j0anWnnoP_>e&uEg( z;I+DhT054�SLI_x(1-%d33T#9W3!nSB5^DcE8!>6PeDSR4(*6H%V&w{RteLG~`a z!vk+|hK_Q|m$giHXI5%tv~R_Ccm1hYeI>fzwrQ&1HY3x;Gr|@xy!Tk!jZj@;%t7{+ zVZ^7B3YvJ~R4-jJvMc4HyeX_uFrmRb*|$%{wqj!rMo&mxFzf9AQxwEf0a>m_NKht7 zt*BI+LY16HZyF~gn!eSuZ*S7dVK%u#cxy>Cq<@&q*T*OWt_Y+~?36L20}p4=Oxju4 zJx<*EhWko$`9kgj2S(*q_LPS5Y)d~CB+uw%-wmSfa@ZLT$rU6%kCVz_l=y1F^avNI zU`UxtxqZtMrt)!HiF?aU7Ig;db8E9dmt%xn2ov^Senp2U|7n|Mc0HW2fKc=@j($0z zZxPY)-lfIL`qw<=TO4nhjzh zKfoW!iwu@NK1OQg=BhJ+#t}2rp`TJYI&Plh|2K&tK4h?8T;GMO5RDV`&^@F>ed|TJ z`DLY4^u`+>AN!zqyRKobzh&zxrfg;8Y0u;zY57l)5luO}BvsGtQ5mF5L)s$8R-_Pw z478`{v~ay@p*;`2S9q}Y(OKqrEdjJpX+cR)u(n$(74f`I3_TLHx<<}r84Uu7`}|C% zSK-0j-VPZ1(u@|;giuJDTvm!AcWKfv$jDI4d6dTC)5p$nQqh!SxZiO1J9uy*r`I*v zAw-TS@d*Bz5WLPc*RRvia3(YUJ7>JFJnTM|x~AhuVd{EO^{xE-CiqQGQY2h)fPV(Qo*CB0qF-vz?eSL#8jY9==|0a5EZOP{Sk-H|UE{WYw z@QahHQy#+ii>`I))KD_&*=9CykZorjZ)h*oS{8DfoYlB}TcFfmtb+gGTX2(%_OjW0 zfS2kp;}lNfWY><{=9jJ7v*g3bex~l|To~fRhZ6-A0umf7QH7k0nI^U!5@rdMv=6ro zkN3~$Y7H80eucau%Yij)f3m4$IPP#R2aG7&Y~uK3IpRI(YP7{L^&`zO<<1MMxVVhb@A0%;CPWi~E}w<=_xVn$r{_5spMsg771<6Yf-f)|n- z*NPYf@Y&o}){w{)QKR&p)81aA6gsy&@j+qnS%{$9T0&{k%}!7E%9%OsLz0N5bojxP z;=BvB2fvRX5cmE?0uj!FQe;oV&3}_>(Ca>_)2nj7{``SLh@9Vu#*?LKyo!{awmys6 z?N~>4u)AXt6P$k3%M*JEP-VPy;ekjQ#yun!8_ATdY-E=$)`%%K{|bO;m)y%^(x;<7 z@!`W8FB9OsprXo{s+_99EAnPOORA>kZQ1v5j>j6`OE(xJTT?34#)NHpn(oRuj~B?O zYJDluaD9nBC|lUuqCf2XY1OH)e2_R=dqIrXj?%m-EpN{TcJA^U!ar4$ujT_(96QqT zgp-z#yoKc*ygq(^O&B)h9v7G8D`O>IPs#A4kQ8=Vm!?7Rl`G{eS4tyb?(SOE6;M{8 z_!ks3KR1J%0e_@VxhTl{`bc^}0*VOAZ0$!q=Oq|-)H-WL0f!-CHn3$q)@)d*Tpe!B z*si%1FDxqRl(}X}8grTI@ZnC*BRk|3A7xm{v7SksA>5_a`Z| zj@3@|ZMo6Mhg|uQ&Y!RrG$08m7~XeDM#d~{*p~*Se#Yq;%}wto!(Br|*W*K?&`vPK z3lIU>HKc?r{MM*=My6QVhRH$pF!v3|vuUTspYc54mDcCXgZ8`xugvkde-BTG!6I$V zpIoD;Fh6V6hLtEPy5|x7iCvK*q$9JnVNmMOQ7r7fgdr(@iRFjEH&JoiUk6B~15Jtp zc6eM!wVvN0FGk;%^iFrCLc7gfMGon%hIvz#?=D+D*{$~RS&iCqPqB)bIA*YARjc!+ zB>i;!`p>^LY_K>5mz@h;8)drid~^=5>hlYsx;|@_xxnpY4{1jdubv(5f%Ao025$z1 zTGkvoV{Dn&Y7IlkN z%v-?bw&u|RcmUL?_w7##EaYGUT-@Iy9i=rTui<1OfHf-Jck-h5KdcQuHdNzys+j?W zUo}XlAHPNMme)D;YI{3Q8b_uurq~x&1MJ~^)ZcHlVaKJt9&Gcqm`nGCiyn^O6?jSD zHpTv*-UPb%?)-iO(v?CDZrj6i^>QjWU{>LE>*7fFSdEB>s?e1Fyr9U>&1_ z43y)vN#e&n1K=jJ! zcq($Q0SBYjtq(plE_p(tqP7#(JM^{=TT+H}Bu%&B4YHWeT41ADSoU99^VM74c%yt1 zK_I^=oEd{CLgn9Mt1K=w#%dkF#ltE)NKtGw*hzMa+bF!cJ&2EciR&G~(@p&6clOV} zEOkEGW?{_xC>-u6p4+x8?B#ut`X(L55qL-2!`E}G1Ufys7Qdvs-&J zK2bNyGOh}aNsL?VMZ)ekprB>LY~lVQF4N^haxvQ^3I=buVF8*B5>f*tRtqR0@x7B@ zn3?olGXG!AHDo*TR-hkm}N4utRTTtylL-7UkYbk<)%Rjn)AJ z+q({<$69HAPJ%m*$n!|qswTH*g*!$N4gp1={l!d7k<=WJpj+gs7yS5k<{NEPRPnBk{? zIrSkY@CN{V*z4CKIWLS}ECJGJ+Y$gKQxZzz9d27<`qKV*H8QWLgz1F~X=)T$Fxd*A zQJLb3Fnwr9$9wFRFG4Tr6ZSriLER7J4zk(_Z*o|VHoPcWwx6v4OC2~jdep)7e&@b0 zU{(RkVTb(X{0_OT%A_4hoP?D~wov#Tx@6d1;z3e|efrOwiIp0X_9yXylHQ(f(`!s2vCJQTHM~%r zinUh(UEA~|2lxKOi!-94>ruG%b<52+02oIz1=5~d|H&*%mj=a{mzO}sFq2(?=hWC1 zL_&$3y~|}lbVyFNqkxe*parm?2R@qmX@Rs;8nru`BTh%2e1}tq%cFZ%TLkFgm1}Ar zNAF4g1)BI7ufzdO!p}+I(+jxyqp$J}0b@`Kk-nE~~EZ6j|D*Py}tj z#Uv9tt=A!G!0g(r;SRqS>>FcyGUJ1bDiEYPmV0bSRu!O^pMw|^TRX^Z@r;YmuP-R* zA)h1m@@P3FUe7+kJr5vYqkC7!%G6zJOfCp^)2Jj~>_|rmFh5+^HhxV)l=Ke<6$>)P zCw+m5{FVzTMsC)ooNev0u#*Nc!{- z6@Trq;%nMhTkouFp(|C8@?kf#v1~em+V)|no-Y68c{br+8q-rl>*dPDPRRQ>F% z7t$N28$Yu&dJJC$_ztGdlhTn}nYGII3TZ63`=OMJiq17U_(76XN@jdLXIy=o<>#;) zXUj|s3bwz<^A7n17$(6aPJV?sG%XFyt{f)Bnc>kv^EMxnu>1Ts zE2M4R-SxMOi-VMid^%4dR4rs-!{^VfCAvA1R1# z=VfmXux;cy>*3Gdw?)kq`bkH97h7z8pCUtQ2G28LZk5EGhGypc8v|RaKY*K<{b*$6 zmzNooE@63!4XV2)a3^vH-M;M#yaVGWcHGIlA6GnC;Qutc{(7#IwR9gb*s$+JEa{du1XGnRtxt!P*q@Hs&> zQuu)E0@-oL_jXH4$-F$w?&S<~JuAy?3~ag28aWDhzzSDnfyMLHwZ%(>-4RKIIo?7t zmOn9@S?)|!QMs224M$X>SX$dwS!(a<H`tk`k`<6XRzBNURu?|Wz9VA z__-ND+X?76rWE0xARs?Y$YB%_iA`ef;4f{z__9mbh5W4@p}RqrR5G#0ODgs_0d!tT*o|IFhi``@{}$v*kmJeSMs zuNPpfFx6v{o!P%r;MbR`-}-C~4-+h90sg$E{xYNHVxr*I!RTiR6-KpYbTMM9=76pH z$0!qkAJ?5gwCD#9*|xVifOe54a0?2iIZunQ1kf}l73XLoP02T_Z9t*Iwn~`3 z!BGjwS0IKh-ZR4CBaT^pdBmp;AeCug%$iTUY3uNH+#c1-b7Q-If;ac)IoUQ69yI)3A5#J>~e$1KryXU4SwEC_7A0vSw(q|;q*kaDN!~Uo;=>uc;w-nEOlNG!K=b_OyqQFkujZQy{&xZ;zFl5y6?j zgP=72&9`4(#_owp0g`yF1>M8iVI7LPb~Ct-)H(nKE@i@HuHhm?IWLyD`-WKKg>P;+ zpk4Tw--yUo&U_A?+U^;EoLwh0_VPl6d>%rs_a>}!S1kr70Ed@a!G?HlcIstxtNw1^SmVHN@)|a8*eh4ashKm*#pH@6THk34ItOU+9jRuzOuDNXC5_Drx zv^vhmNXVF{&#z=t9`@-qHN3<8Unr+cSYq+sLR(J|ac0im$^`BL&@H&j3Z(_QdL|*F z-aoIpZ4%#rA}|j;6=BnD*4kBWXzb;M%a!YeoF}mnoF3~?dsfcTg>>I|CA4$IYvYYR zfFf>Zvx^F@Ki1MX7~gn#1xqpX=_BOeIV3ilxh{8sObtnh_zj~R!ssC=Z>_7s_N&$T z@c~?9fnjHmKKj?|H@YYUm0seIBl=;c#XEHy-t|>YkZk032N&yy*()v+3vUhh!Jbxj z_vFd?#F{+x15%osa&l)W=6{F4Cc2tGnTb$IzK~=Wt1PH}A1t4?*l9j5)VI;-SN^u* z*&~}d=!wz2YhfMR#cn%|4$E~SRfC99b8q?fb`Dhdc!G|g6&J#($>C^@qW$m z&QeeZt)`LSOGV(%tsRME{0mR&NmkW;V{?Nm<~hIzBFh-I#DpBpxz?611uv!UARBrE z?qr~$sn98o>G)i3b}w;=jYJ?X#!rq+>PLyEEIojCV~gj7__7bj@;unr3D4vr=ODg5 zrpHgmClr$Dil`1pOohkw;I&Y^o^qiMd2C|*2f3QT>9A5slAjpi=54$FU+Xrjj2%(j=L4C}n zD@p_9fJ*`Z0Em!#=MR-0Acd5-8?LB?<2Y9l6+f{?hV0#4kYy6oAWycjqnaje7-M!2 zZmmalaN8B{e_VPTV4$y7X9m7I*yQVyIbRe*;TCJWH!VJoO6a*xBTdv=&;>V{!uj)E z38kQ;mVRHILgYZ!tz)@Z%#q zxQxiie6UhtDD^0^F5X3<+g|K_rBcvjK>%54#v9g}@#R@hU;^_Sh9ZbpqiC|!bm2-r zCAs0A+<(0xC$Po&g0Q>(k9=kq9J>-Pv|UX)At7frB(QLebqMXoA(LINt3Ev~?6SBd zz)h+Q4zcE1Fuu#AdgA>v*mfg1s|$eTm&4hg7Q#t4<0A>AqY^Y4d^^YJ<5!{%x0>=K z(taaJMke8C@8u>(B0X$hgt*LhX`a=ueZqA8iJhY*xgK)5wr?|Cy#tUqAk2VDf?hmT z+Cp0hUS$m{y?S+lySj?{FMtKTDi2Mb2-i9rY*b6oBYSE)zK##)E^7uYAdn=@7)zrx7}w5Q?AbEe=UBS z6!NL#=euK7rWE(-_=@;7-KK-~?F41&atY}Jcx zgl&W@iD4U0)DU9K@qE#0*V7g@;Ww>4B`xgb-nNk<9H^HNbghOATXhtl*OU}t0IS^S?R2^Pq4xsR zl5W94|BUKYG3fo8aIwg)@Enuo7{o-aJXPmmU`rtg+x(aqJBsN9!Bu><{OM;as!5T7 za*vd{1gTW%U|r4x`sRdxPD2L<)zpB@z_0YE(NZ(#YWRg7!Z2ko-8!onplgyhKC=@l z(Sn}tC&KGZ|8hH&F&YcB?Cvb|a>lJTDTFn2HBae~?P6a|r`i@PafgGA3S~#=J zt-|zr$6zkR8Y8qeU97ij?IE=LHUkXn)!rf``n-qDj5IWA#n%Ns;vTEb7YUbS0IFG9 z^B_VLFp%i^P-Mh;CMDaq$O4^k%5Sh^4>n0}}+1>Lu2w z^U{WJ2d#X*l`BT}+eyAsL+fac?duI%PsHJ|UMcjoLBSPB@GJfd4C4db&x^Iecz{7> z5NYDZW-5pvP%lx@?YxXg<;5mvk6SH>wW2`A^AnDs&!yUh;2~wu7)G;cXm}YqZ3xA7 zOJelzkTAD~z)P1P`btVFSA~h=wOKQ4WQrCZso>8N5gN~OxWWd0B#T{u6Mqbn zj`mKMY7^nVyR3>MQUrnW<1*U4e4=|HrsjyK$}#+N*{ODoxN4ao;U<)Z zjxYnOqZ|iGL!Z4Lq_sgaE5`G9VLZDx$zxXiiHiq25_G>l(Amf{pldEI5 z5%3@UbpBtHfP5eL(?`wS4pd$6q$6*s?obI3>yj;se|8o6q&05Le)n@G(3jTc$;$E15`npWh)di;bis zg1_nR=-xUL0SvNg&LgFAJE#)%>^(b8G3ZKoK_N8htp%9v{H9;X6J;O{e}R;Ws_%(D zMqHGFJ%L#8QX_KT@7b5zIxzyWG6iq?s=$Pnf6BSgG$729`(V?Eq`7Wi_7;EpZF$3@ zmb>zk@2y~vUOvsWgkKSKZvSUKfN}!ol%TVn-oC?+o9I_-rj}(Xh`ZxpA+pA!muSzT z%+lEQQf=7*D{^kVbe|b*M`3g-`7HjY@^oo4inoS__>hw2LcsA5ahJfKA#p%uKeOTI ztjk~9o<{NwXOykHG*~=*sF#s)C;lwm_)AG|xs~mLunK5p_}CQQ1j(6NUM(zjb^S|+ z?q4)6`uGqxBT68c)iPV*{V#9_0L1^)-x{wH6(2oWLY~}|f9!!k>dy%(=%T9F>9?4i z_yp?{*zmntDwwKX!H$iNrnMIaL)`35#KT+1`^z3LDd3 zoJKX=9*5?al287W*L6)R^8_`qkCtiH_ZBQQNHvLDt$_w{iXs;~#SgS0HI0cRyouph z6$Je~zvPuThBileNd!q7W{&?=>Xmcux=PRFD_V@XwmkU zZq>-~>NUCi%APv+z}(rnA@OMC!g3$OZ;D^tI;*4FI{V&7OyDlZbQ>Fa1Yp;p`n1Hn zi{p=)I8XKvaMsrpO%ZftPXp0cf z^Nl|TY;)@tpj0K|&s!hhmx5Mq76D*q()cG$wVmhmA$O6CXp!3L&S|*W7n20e5g{?&TOTKSafmi8Kq-CW9XY4{i@den+}55E3AOCt+x*?GA!8j?D(|TweSEa0=Lu zJT}JWa+`^Tx(_svpydxfoz#ulc5KTg2?gpQoLC&JfqDnQO>#KCB3NH_!y`ReS=-(} z9SwuCR9|3*v0Q*#@!ok?JWMSyFMgsv<5Ysc)X&|=r`gdtQc6_R2b!!5tG&FC-={qsjzEj_{+WnF`cGo9ZZdfl8P81RcrfW)NQbptzKX8+Uq0L_h*J*v9+t$h_Cs9& z`BL-Y?X#-*&W;HmtZ(rWDqSfqwi{P8h06WxFTzQchPU3g)F)o*A9$qdiqG)wq8Onx z(G+3^!w;fLx;K9q~5?!AV!(o*8Y^f?+S|q zF>*}E^#aoe!!!>2_Qsy`uGYOT0Iqub(Ke~nY{Av2-slBBBm-fDf?cnJ6vi(q#sCx`NAc0DpD}F~q#qDm^Js!LSj_U7 z|8oZ>W5Z1fG|4Uu8(JnsV(h4AbiXv#w1K~y$Q5k9zdqa z!NAthYq3^a_32ZotS$$)6c-mFU{wSouNWfaIY+y87TM${Cn{Z`r*>+%yP<`GTlBM6 z1?WSPXq;PHFbX9lLRIMkupODTcUd(YiJ^dnfkkO z#NKxJdy$O_*D=IAQXajaY6!|S8-TH)<|`ReNK!9g7MVkqkYTfD!5WG4wxeBHgCKd` z#nDKe2YP+YG`o6RVzFfx7m)+7_p)=}eJ$GvQk9vb@hQX3TrgEa`lCm?6QBUXD)MWO%|utuh;_P< zB&@YTSAX|oR-%AUH~J9LP!rsVr}=pMdl@9*kdIUEGb{j|eBusbM|3b?7(o4N(LE|O z9I%>QfA<%+{zqsz=*(Kkn zx$mvZ;1Dq3?D_i8QF3<$bku7?EWFY6`SuUhA)Rz`Wd=bxzmP)Thrc<`r*HY#-5St< z;J|ZiGJ^`PcG>@Gm>-qcHj0655QAR351m-=fF=oVhcQJOMUSm&tVdpvl7Av9b1P1H zWT4+K93@t&e-=or0-NrpqLtAZX!oHI^=3Y@)e4iP`)qZr$%DnDZaXXVcwM$sxf8`}; z;sZmq{fU($PcFflWfhq3Ey#8Ub5W&!+?5aBiR#i&hctEqdq1h4L{&%zK_(KWpGK}`o#7P zS(Ma=S%Q&=#|xl?`nTJ5vJkGrEX$U@F4%xYhcOQ3@+RlV2N1zvF5$Rkmh~K zM_P_#;n$$rzF0iYk$r0H8OCu`j+H;CKL(TQB700GII(Mno`PGGq@C13B8MGugfWUq z)d~tCV3FZL{*{-}#*8GT(iIy}Z6_-oM(>#F-h2nv>$XbV$)3M{@_g_kr(8a&cKZ9F zs5+XS2>y2202A&waIk+@9wR$L55(gdGf~vp05-%$0pxKw`CR4M4IJ3_&R9r1m?X&$ z!~rLA?>k7?4+>fUmwrUXrGRmzF<&tLz~qiXZ#JTrJ5nMU zB)KXG-D@X+&l$Xwxkx%Je>7gJuq3OLQ|mK?Am!m+xbO$~^fRvvNEI{9w~=ZeU~<)R zaX0))a9>w0%o+A*pxluNEe(TizayV0^O1ZYyYT6Rv)bv z=o#&Sxq62SI!X&u=BPKrOMY)PR+4;4Uak7me&lk)jiOup_dyRQS(o|KRbC|Aq7Huy z95S3>41od;7XPVt8n)A!ol1*6PpSd;#Q~-2A_bIc_;xMkUVj~fmoszM3rpu4jc!+m zFhl#p52E)3A=>v$_uCKJ3!Q<}TwS205k7v=W#tb&gM2!+kF!UVw!v9U8)eYHc@ouC zf4${^Rk@@3Q_E3=%`a@0QB_t_DgmR)o$U_BjTCF3$|py<#+OhlUuV5?szphhPWs%* z6Uo8_`kQf#;JAxd6OK9!Co}=bL7fNk7^C{v=^*hGHFvOEM?joU(SMPF{~8ZdFRF{G z!r%X*xP#&AE-mRjp5QCBUKwX0evl%sg~NZFiSx-%m4op?;+1p|pw(>c<4LTWsmf>H zup#1Pj*%|26ld>YwacOvVE4W6KmUx2W8AzW!!oKKQ{#Ue(?!|**A*{J?Rba4xMd=o zN(~NADC1*kFUe&m&(xjjXn5IKaW(|du5M&G%|H4Mi6AZRK$L2?G03IK8(>&MgO0&b zd%}JnXYr;jI!Bodb4F^mA>}yyXYWBd>91azFo$0OcxPQtnnzhtc5(^A%IHe=OZmIj z^`Jk5Sgg)F^g*T5r>P2;dSAkB^x5Uf6Liys85(dVEzDtsS`{II+spljDn{e38~0K zSAJ3v(q#UPr_>S+l10c&?htokSChRprn@n~F1uY({pCBRyUBUeU`CS4TB+mD;JQIn zY`yl4WDC&J%!Vd2%DDiyfYwHUGi`XUW8Z8cxPf*4uHOq*J|hxYB}VcJ9&w9v`cukUby`sE^l|13tu919%0R=LHzc zZLjoCouO-OS&TialrKwHsi-xAtGj4rF!)1}N8oSMOyw9C`)#}QSsuY;34P@Ccty_9 zoPEDH-woUeNpd&q=Zq_wM<7|)bxl=uh@FrJUQR!;sCVxdk$B{)E1#@%@31iz#^lt? zQxS2^zK#`LI^CNJ4ZwjXm+L}hkPaIpYwVhRq;L7ILt=O*bujC9ev!z$Wm4!UMzCz%VyH9c+VpQq0* zEV&{h#3+GPLn)sPSTjwG&wX`4z!VNiMvQ0Q*RA3)4`9V1{}<>EV17Wt!y;(nz>*`A z$ui^+0kD*PKAaWR;I4kuW^D0iI) zE}tNHfXDg<%8PhdgLIX5pgG_ZnCU=3mud%g09Uwv!IL$Bs=5X;NR`W+T{Pq&tJuKr zpU%rY(CrtJQTiu#!_A4@&j0{f3UAJV2jB(5>Yq^fz1%FzJ*WHE588gpcZBkq{MOEKLv14c%uyBKKxo>gVE+~jPp z9c-4(7+t>f@lCl1qtMY{1Xj5{nL8TZOU$jdBhK6ywm#49)g2qCfBVEpg;h7^z+}o&O8FCZ?vAAI)l9C+Me4uCrT-P&t0kGt)r(> zn2-|ytOKC28u(Ndl&b$y@K_2?4D9x(WkOD~?DAEbFZijPo1aqfi}i#HZOSE;xq`px z>3})H9K+|qIPwCnhX^z<>b?&5Hqbvc>dR4p-KZ6-thK4TwP;m`?6d;`18a7q3|L=H z80HE3O`myPe1rEuyz+0kd*TmHzg^#*`t8S8qWl#p?U{&>1fc zb%CG^4=(RsRj{@4CjFuGHl(`Rb^k%B2G}YhahyX`!)KzD4fX@ay1QYfaPicU0i#rrA0p!97qtT`MGx@ojsQ7NAZiuS9l z&3kI#p2rU^#qZ;P{S&iq2aP}AFBiB5S(&~1o@o+FuG-*yFcp<3|G9fxOswGhS+r%~ z{FED0SA!7&wC+7O_fs&vzik4fW#P%P^^+rXE{Mjwn2CgD{PZJ}(!N8Dh&%v^WU9`g zb2fv>SuJMGHYm4F#x&mr(b7NP_1Ex1aa*Y-dh*@t>7;hrhm zrwALP5$MGbG`79SF$eF*e(r2?J}XTPj-joIE)E zvJ_6xS1LXGN?i#(U#VBvPyg&R@GtK+ReW}1Yry*s&ij_@zkcB#sBx~F!TTAsRyC5B zcY#^y+<^kiAdP3qf52lPCM64O&+|{=S)32p z2}n#Htf$9M%@Qsd;ZM(bbe`E|_j<;^n=vHR)Goeb*Vr_0MvRT_wM<-dtuM27bk8;} zB|6G+6;v-0ZjnHwpVyPTO!HQvvxNqoHusv^MhfXzZ{_UI z(|$elVYYF#+yCDFI;MmbiTt-fTk&3omZ;(w0kn3&JBc40Y1DMvrpFqv*h=utnBn1v z)snn=5L)m;`I{Fwyybmyk%IvFVMpyc+1(NXc2px|9GwsI0@+ra(NOo{#zp z+Y^};wf(FC_iZK9?NjX8X#kHcdF9>Q4q~II29y6O(3VEUWyETGjgvS1Cn+Rv)lPkL zdUdXOksn$fuSUO<=bEFZGl7jIA830|_;Yg~9tfH~#k{OW%eyr7zwn)RVXjA*+Yd5^ zJ$cUbi>K>PJ-H8>0s#>~lT*Ii%}n;S*ZD_~59Zqk@voq&gpFg(2PO?e3mxY!(@vcr+s5RN+bZ`zLpxeW;b zP`$Gui}NwC%ybJGIWY zclr1eV@~}@fAvq14cupK$6B+>12fRd;wrNWy_XRVC?K=*Y+;coL^?=yK;=`K2DPHF zbY8u-viB|(+;g&!V`*Wz=JpS-xzn|q9j*TPaJZw4Epo+&RKCso#l{MCmF*aH5sW?P zXLBs!F3rd=25jdWr|Uo%phtYWOZir<^Thy@8x%KZDg$D6_TMAx>{15Ue~r?flVr`T ze710Xv@7}SCS0gC?qTy4s<&@koKwqNO?Z-bG?4!f#dfYX z{lk48>&2gDHErt-z@bR zXhH(UlSZyY(5f=IRFiTOm?jw!! zSJq!O_$OEOrr>WXKCT%5%?l0kv$LT3=I;kq6Rulu;nRms&|Sfo=U@4s>}+pqFr`4;=(D}nH2HaO z1{QD>to(yu6Mq6Ng`?sUUiWJoKf*eB-tl!x>LO|)FJobf#g_lQI z4kKH3-+}{r?8oOY0EF{&P*)?nHgexU1^~3UH+KyA^INmOjVB59c5L`Uz#4JSC$&RS zr$NxvWe^)-<x(o2Y*!+zB4QYi=*l%Thybqk zd~^galCI=fhJhvqHDpb{`tiE1+PloF|2g@ z_xk#t!^tWAN^avU{vYxF`|jiq&E7Js%*qv0%RZp@;1KFJe#;m8*CH^7oB%4X2w%R=XP{N;v4gi9l2tlFIF7C1CG<#rA)79qz7lz zJlN6WH~OQ4ZTF`6a_5p#>4=UvF6^*Z_kR*B9;Lxq&gP;0XIR?}p!C7{E%?L9PNIUL zfqV|?v#Xk3!~|o(NOJ)zYe(HXjLB1PkM9=}llJ9Py*7JY4YzaG65hs{%`%qHDW@9_ zmQ;stj2OC8w!kE%kTp0u+UKw?W079%pnk$YR z*I$%NT1t)=i(G4PtC=-`LwgQx{YTHx!N%g^<;c|EZg1CqCbo90Is5*w8MXb1&tSBa zInf!_>tD8DshyZ+e*OAoboN#0$q24=GuH-E)jwbl#2)shWO)p`t@MeX5z=oxgsI`! z=(024lxFa7)Y}&q?`^l?SX($6XHn=}AeEn%BYx*Df`6u##DT0aD~pwj|INW!<~Ftm zn=-doZgXTOgk@XpSJN_siPEg89gUTUgPY-NC&}c2zLksc%N_0eOh;^ejxQy!!o^ro8>>bvvWp}MW4-5# zS3<a;pl2}FXjq1!K*nM zY^(gkkg4C*+-9l1l}o8t?gsnm zQ03?AM~F)iGvc-MB2%4mT9^BM?YnzK4e`=7n#ds~e6^OtMTocr!jnj9YmH=M(nGsXhvabJyT+@4VCJ z0cY!>#}=f+(fG-@I;aOH!{b8i_DDc0&!c?N2aXLbjpe>)U81}q5XSat!mtz9<2`zl zcyG9k@LEn*F0!QK3Y@j~cydU`@u_F|X+rIq{rTqKjYMC#6Fih*er+*vx!Iuc$=rMZ z9NK%<*P?D9^}yH|$F@@pyi_`CV4c80MU1eS497wPj- z+Y9Uo6Eq|5ew@~nO%bo&wXJd+HvThphK!ugP0z_+dW&AFbw4HtxW zthU2Lc9KYNjNSE3CcH;q+Mx}V`VjKz?}kfvWJ1rzRWznxaInHfggors?MRBf(= zhiUAYGTKWKX1vNK4jF$OnKEJLm!9Zm8S1nf#?hFS#Yc7hzQ}yHZO7(!Y?8*6R6>LjS&>|gmDG9>!J5DtRWwvr zbyH*xz`26$`=0FaI8dU}olT{GqDx~MPw=Nl!N=Dv9Xn9$@PNk=y}hv6horOam{2Z& z%D97~9j_|qbHN?(Vx#yB{m8pb&#X@;TmB{MIkbJTQ=0M5Fp734melj2ILqli7^B;0v#EWey ziR+{)waXf=^CW1?nhKUp5Y>$y(OBM3J`;KQ2U;x<9thpW6XdZ8+p=G2y;0X(@)(l_ ze=jO-@h8B5@F|?D8SlJ}J+I~Hw+HHtUOyT#1Vc|d-OPtkjc)E*$&43`EGtWRe!olu z1qrfh?59V=^Lx476GTq##7;rOJrR@Hgj0d{pi7X;noF{VkY_$$j?b4}+`6LY;^Xac zHnQr`FdT}9TM3?<3q{wsYPHpe9W5?@2S>-MTe%Tq*>}p}e@69A%?V%F*V$dO)K>Fy z)!X+ht8#8``;P{Qb86vh4RD0JZhMyqpK&AXJca?hYFi^t|xp6Dcf+|}^1``d8tfw_X=f@%<2oec|r_-Ces*E1%6c*vOS zcY2N_y7su5@dG_+6xX9+EfJfWUz!QAMlZ7Y*ohn(OOH-gnQZufNQXt;zH>yk!a}>5 z`I*5Mm;1>mK76VVvnhUuhnx)kQ&@6_Zw(L>%C1#tzW33^8|HEbAA#NasHmj$F0T8d&`}$^Eo)S`io8W1?xQwvB?A@$<{qYk z$O^C;n!b{jtJ{hNceGJ%TXBH3Dah%vy)vz63x+OmYxL*yaGIvdT4x^pEEN+98kK#> zQhiE5jc~>AHuvtvyuuM?cdLY9wVg`vRBhfNv{RSiCLy-CZkUJM*6wh@IyjN=m_cJy z0c3_xx}F`rFN|U@MBW{rFKk&`Bc_xrU1G0>)8xPW?CyBNs|s5&F3zHd3$7cryOw-t zM{phd*+CECWr7?^KMjz6=olo~xj3Rr{peAitC_u+`-NojE42SC^KtADOFv>2DIEqm zRJV&^-=^@Qtn~P4ZF9Xdj~>7ucYf;0c!{PRqMFh;y_9a(3`38duD;$A6=%5QEBAfR zxrTFL@K>~dbZ~5|ghZ5!g|V`xhKF^*&c#cPusZc#9v5)l5e!qlPdTB6BuoPbVfRdo z*#7jo{Ih#PH5RS|^xO9rC#B@V`Q*NZl#?6}KM~(gpMUUEvt|Crz8G;>^F0ctaHoLv zk;Y@H+QCw3GP{*wts8r;aMzMFU05YGI2&+quuu^!Xzz)oC%Me`P3>aMm;9;Qv>R@`rD_PuAF-tw| zO^D(}5N>@BO$AO<+tJoV)8!xb^aP?2Y%0M#sf!cuvNqi+d#}<{psbbmwxc@nk@9PrT){)C zw!%{PlDA=JPWFW5xcym*VA=H6=VQik0eX>A4|XTJs^F=oA}{L$E$8Z2SDZbq}JUxUVBm1|xnA+2dz zIIdisi4oem-yjyw0{4?bWk*K*g+BKT4zWm;lyd(}s}qm#jqu&GtBPIaB|uF-W^L@a`@=yWSr3vYG!rX9KQ4hxOW<_4cC~&^cP)^Is+>Lr%(xpMSoXkXH4Y>ZvXeHCO#WgOsOphL}a9L zP({x!I-5G=2qBCyCiRQD$1W!R%HuHYL|A~>u>Nph5H#x5&EYgsF z%x46aW&k521cG`1=;yzolT-Jpve)&#hpW<{WIJ1u_X1@w>!fe1Jm~1zi>_Yo+>DGg zFx(F=kNFD<3Zu$~`R;Fm>|d;A$;~tWc3nm5+d%3sw8XPT;dZd&5SMuGm%Y9oda&8@ z`@*Mu-hHv`nNXJ+w32%16ys1G6%JqNDsmKe_3l`4^N78r#e-C0-laOYsm5^0hx_IK z%L(TJ+X1RTsJAVrn2PhO)6Ja2j<#gy6Ic=nWQ-7(B_^RfnFeJe>@{^LPWA*l%rVaY zdBo~PgvdRWV5YYL)8Az+`cS~yVhTV@zy0@3b~* zJy0J8vNcOY;tLBmbNbQ4lWjXlFuvJEGN>D@Dn^(MTC&E?KG{$g5bJd~2o$XQfAr$x4Z6Yr`FTPpYQR zgoe)l-FYj8d9UV`nrI`U;4VNM?z{;Kay$^^;Dp!|@m7~ZbYrp^`=L&qsK2PjdhTBT zl+AwD*8ZK|-ck|k`T|f>)7-?(?Nx!o-3Zp}D?w$~w{{F9oIW3)er}GX!{=j-&TZX! zc_S}~d52QpOT~@F(@%RFL;ULRTT!>S&w|}zb1vV^5ejDrSNzc!#@B}Dl%ty*_&or1 zsA#2&A+`z7{2fv@!j7lz*=BX(adOVWm!aibi{)i%j}Q^iZIZhcXMIf~S7vHYKz%!j zC&B!MSxnV4>+_INUFDPPArH2`9(J8cH`BA8`DZI`?(LhUO9qXk)40Rcv@@a^>#!To zolq&1pCnJ5LFu7U(u?);NX;`?N^ltOs3#mHEt*O!GoNuPE_hpSHw6gHD{HvclK_{1 z3(Be_7UP7V-nh>L;G!E%pMvyTxCWZy1wc~?LkyKuDsRmhta7@a9EtsGif252ZL^;g zzsBhc%rWp~3B#@Kngx%g-^yI%P!4Jsyutn7h5e=f+H+8(YBoDqeqxGze|&FZCD$OGcL4tF~&m!PC6XuJhh za^}cQVr=Kln>UL@93flczC^D`AIfu{g_W&Wri1`d*&C0c3%o&mAK$o3qkBBv`OtW3 zX)!R&mQ(%P!0a%2T^ekX_^e#R+p*;HW)MhdY>GIBu=mHr~+3VR3ya{ z)#V$h^Z{)=X?Y9l$6OBzdo|g92gnVcD(eovZW3>>QfKr)d{#L{AUCDSYt#+5$)E%= zbzA;i+lqJM$2aVgWH{ygI)FmM6qc27^5mJ=w2e{43Z#TKd}9>%){Q}}LW3G)O1N@c zNhvu)uj6D(GCyx!0KA_}=s^={I1Id0PwTscOecc($`FGpG5}a^Itfvw~-1K=(lg_WT^=b4& zW&cx#=2~Zng@6{KXL>82e`yeb>5nvj!9HFVuW`OCUPvGq;Zm2BC}o^}R<^JP!-~{? z4XBtfU?y_a#8H_~KLSRltGkQBqFfCa_Q)koqP$c%8})cEu>wja_tSmu{N`3WbgAseL zV;;qyd*3HK2#|ExyCwgoq}^I6d9LtK-Gzw<3fCpP9`^UcHIucldRpeP5Vj*ObPe>* z70kUwWh?}QHEswFugjhR??{@Dbfvypt6y^TBr8hS9*)AW4K}g|l=G@E;ihli(V>8l z5d?rp^C2%xcNXA{;ibN1m(^=cGny`HbP27r>bZa3JFqL z2GTlMu<=jr2R>-9zghqu4mPxtr_=NJ>1vMgxkDNg^v6YnUw=k5C*(4S$u;3+w|rY? z&AWd2?F62(7~X`kwAx1AVE7q#T_R3MPu~b4)$*j$j_;q7+iB~P(Y|mBsF=WGxR)r96&6lsplA_Cl*N?_x6VEPwwehe z;{&L>lQheoR5b?}&6dGw!q(yb`@tCE6Z06@JFq$sQ7lyswQ<@wc}|^SrBO(*W?f8JA4ur%Z0C<0Qr*(N%k(}^oCOj7-_H>( z-0Tblei0f2&K|{NpPETc7j5=x*cl{_YR5z3(t_HNJdU=r{%*MJgAaK0^z1hH?ZQG- z;U#Ars5?3a!>~tLcr_lfkw~VXvZspiH;fZlEMj#Reo3<)5uq(ETS!^ITVB%KN@>yz zWnhHgKgM4DWHO+Bhu0t3?n8~v*tFvhXqZMc+M;Us4i@4nUiK-m;7XI5EV<2J7-|`^ zO4<;%{+!e-IBKHX{mi=O^$sYs?d6PH6CiL5ctDwyl-3?E(&sTR%p#*88(va^k**D& zSRCaDjpC;Rmv>jslZcmG2+l%LEW_~d#~~W%>!DgH2S3$4Vjt^e4+rdrMa}DTZWY{) zjj7tvm(7;vVC5jjm}NM9Bl!N!uoC-)DD_cGo2b8=>sbKQyZ=OQRTqxA$2}gU^4!<~Vd7 z6l(iA?$NPEL{8O!vN| zL!2Q4zrK==g^ayxp7ep`fy3>2OGUCUNW2JM#vz9;HvpW#`W3IZ-$*SEN%NRkI(P6-MJhMlsbS;!_I*fs zD{k#o!5saze+Vr54E_>#5XL-p0Nk7ZL(%MB#y=YZvTc$)32(S8eO%~R;xGyUGk7VP zDG{FLwv{7WEI?{>cYC$gK*H#WiOD{6IqSM!m+fGD zWzVz;XtS93xTqH|tRN>M(L+Wa(F!-@bWU_(^W*jw$p9#mK}ZYaW1$DS^W;u|aquq_ z)t)S7P#te`wDt^f*D|9>r&(h^JTvyYlW!+kITamf)UFYKdl*M<`2>ue0l{G`ER4ZS zB7f;Aoh4`-FD3~2>FkpWhg5e@(7Cu3BE1fQaKvKmA@~pb@x6?CiqcJHf;B?a+;s{$w8TrD%ykzgIEEit7;!7OvS<5AC5UgPx3WADi;|41OZVVU9 z&QdeG!99gl)WS&m`0zL3JTZrOLPQ_KO|hxYT%Ea{Ci*~K_$C_NH3<~alppV|-s_;w zWF^6;^c;$Ny~r~O9UYv59_2u;Rqm@GFl~C~o>0~sfWWcsS_73Rko>6>1kttjcEAG_ z=P0g8*{+o?0R5vi(7vx=SM@=e6YT(9zRcqF92{Uvrj4VR*Fjjl0u-9cx1lOskaaJa zFxS*tU%^(FS>b{q6sP8|yGp@7u28QEqygBlT3Q zh!`>ZjR{e_se9robql3hom@Ns@5#~vHt0iX-gzSqf>?duRHm~V?R!Uqyr^?9ikDs9 z#X-`P7M2Z1=tXTlap-YBL8g^+`W~YlCn& z9uP$Uis|<@~JD|V^^b*@0Df=%B74vKV9B)B75;|&&w6E2=*SHNWR=$-Ouh@x1dK^T*E(1Y(k@zL8s z9aYdBeaRW+r&@46^^Q;V9h7{7S{Ns(@aM;%BC7A`SeYrBcDjN%5-cYi{VyjxXdhd! zwLfF;MhqI8b`+m7h+?te6H&B6)Q`s{SdxBjcJ?M(e20->F3H*nav4IY0p#V}ACuM= z56p*`71VuvLFk=I0Npu=2a%%y(@TL0hbPY1bIz8kf=dEOd!|n_MH9IR#N9LaC?p;o zA+Tp&UlzG~iB*MYP-W=hijjRGuD9CBVx%xt5|D` z@1(AY*H07U;c50NhYM!ELeXU$5PsFMX`3;_ZPX09RJf$~NGo@M$4f0Nt5W3FeD6u9 z9B^K!Dz2{!g{LA#e`3d}oN|N0yrc9GmB=pr}^&DvJh4K2P6rST}%P50iyxDVhXdAm;SP~T4WfvzQ~(a zHfV*MHV%9plIkIYoO9F0H$n{xk4MK<mBI?rINL9*U+wZ61{Z zm2|8Z=Vn~R?&@75wqD44VU&1FF)8Rtfs2*ogdv{bMmYHYYo@&{ZD(Gyw81muT&_9* zLu}1kccCU15!+C828}LP_4R8OfWg4zXOAN9)E3~aw9K4~6hilXq7sbzW9HnikJ)_? z-5>Mx>7%w{Wti+{iSX63a@PQlvI!vpdXnIe$)D`{wE4hifo_Bx8ObWAB6Tnmko&j2 zk(VJ9qN1j&E97aS*v_qZ9pog?&@m}g53pTkBpoQqW)t3^)|>cyympADBX8C@I{o)4_;Kb`Rz;T^#}17 z(I_4X05B2j=pON-9Xx?>N3A)$65S^1JzmjI9~Ccch9QAyU)Hs;!w!bhUWjbp)1s`U zZ4jk}GFp$DyY&`7vB&0U4`~)ONTr$U33`BV`V_HL;jlhguFqMN3GPtc9bD)|O^zbd z=33vF4ZioeVFA^(amtGK2XAEp8&>1L$>qtvR={@&*rvg0&$|&G@gZL#6oKMPO{BYf zz_zC6oO~!4PLunuYOA0_77vIOrh>}^S-x(>l9V3)Uz+Fhp*%FU&Zzn{b?;2GBtLgX z_6gv4L;!1^nz;9d!UJS~9DPfc;E3(iXDrnL;V&Z27(}=Mid>6aJ|9HC!)EJSd7QYw zaswbu<+HMdDk$7AhZRt&3B$QW3uph!Zk0n{fxdHTX#Gq1)(m(v(fr&`{$m->GW-Oz`} zeupiCbh+|Km_Sey#7c@e-5oG(sOUN3@|l~vm$Cr6G($|Y!eUx7zgb~*T6z=&l<|4n z@<>o10IIC`81SxkQL=`c?4Ck zg)m%)+l|sa{9|gq`4KYO#XZ%GJl7nS9atr;3Bm4qdmr&0q!cDh?YnSBdaRO&E5!Ca z-r^{YrW>2_+G)GQwge~loTHAm(;f_8zfA((Qh(pLT=(uBK8mYV2WGqgSq2@*)H@W_ zz-!a7rUp|!(ZB+{A`vD%g9)mDt~W9}e_~R`HM=q)6IQ?)uHG&J3Rxl;#ZJ-15x;6B zF-j>xGXPK=3JnAtthmQ2_Dp0dC4HXM><)Q?D4-01(8}x!J*$qqbao8uVJfHIEPC!J zW%)bl|K*{pwcpdNz}T7|ueDEsoZUaISXO57))j?gNd8}nO3K3Pf{(#le*ogA03&|V zgy8B5=MN-{FPKqw<{uQAn=ET*W@2I411fL;!2w}0VmL1&pNQr5+W|$w-G@<%YYgW- zB~W)8)%#hw%&L!W!PF#Y9C9(_)nSIzO%bP2;Y^1+dz+iNaR+3ayg#u!N@@SCCQHhM zDE`+<@OHBq1G$mgy57*ZeAImd$)X%zJ9+})2;c~z?qje-5B$By8T@CTOy-J1B= zM29#4$k4h!rkid(2w?nMj}AOagK4h?DV{%*%!2?=(m8MyNN@z*LtC-&N!lra?F8Bx z#0WD2hiN5|yEJH$(zH7~_S_{J_dQx>4yXJ-_y2GSW*hV?v^Re(1V6clN#hL@c3CtM zLV{UmU(TI`7+bPYg}O_D?eUTM3mCq-qc+X9PB&=Wv!pp|n!?NKN3+IMtA7n1$Kfn( zFh_;mi4&M@)(D2(6l`r@zI;LSaoYWHG7wLH^$7V)9idapNs+dq4jl6za>}y{h$!p(taH&!^-;Wx zr7#N~33ViUB%7zoG(D_l26xz&n0b8j1czqL`z?xfs3=6%*Nc*3O^@zY z9YSbWJvz?#A;rDHCXdJDY*bm%=Dwp;#ssz6Tws-8!9Yml1@Y;FZ#Uz|g;N-kuDFvZ z^amw+pM#;VNzs?PUq40_0BiwNSlI*9lo7*id9VLx2`e`RUD3F=B16lN6!3@R6Cfh~ zEa9d7`hA4LC5@9O&OVy@k~9c_8e}r~GdAbcKY!@UMM9MCvPeYWM5}CE-}3z14jSB4 zEMVWc1{BIYWhE1}a6%K40X4(@!Lv-@SOtj@^3UPN<_A=-O$)xnDkgXfoH~EqOnT!g zVhfm%t>QcybHnq97+6e2zEcXLB+WoPLA7$UdY6@ipgq;z`~A0WxbFCxms7;cC9jUE zP*hYkfo<_>?U!Laj0n(bvy^z8QVA-rTXy%d{Y=Fw#jW?uLa}ajm9iEt&KLE*Ld>Y* z>({ReFc$iWAvnataKGPW{PhBi9o=xed=YsClXZFEe;hBsC@y(xv8wdFo8NmBz0ZEm z#`*PyVV|^UTu+pbkMr%#Au4K0qs4k)MynAgbo8MD;p(!8Um|or0G_^a3fQ%@dC6QF zhg+zAep|d$HOjp|sS25i$|*h=jOZ;TR0iI9%FYEZ3pR>ZuUt?a>`Lf(G+YczPOZ*H zT<_ej zsP4W(Q~>fDiYk?Uf7k6(_7aEnbBpq!ss+<$ZimI}4ozj?vfh!f!hx%BJz1V&(6+Vp z`F8FF@H|!ywzcc)#C78d=86ZEt8$?DJh~2cs|zT!#U!i=wzeAVrNLDYmlhq7#~ZYB zaj8On5P{a`6Z_vK6iwDK*8h<|ZS3a=LW#Oj5Ch^`%m5~1tp~`32a*uHUG&sq=lYo5 z(elkyeu?g#7i?_rrrc8ks9l&$fxODU0zRwBz)Uzrf<=0S!mz4C~_{0(agkAPhaQ?OQHJt z#@h6e#u@)-iamO@xv08bN?dPUe;t28&u#YQ%A#@Wg-ANkfP0WQR1O8S&;#k`^rbF{ znDlT2Y>8sTlfTHB35);+=wj=sKR)Z7>oYp9sr|$}68@7}b-U}i9q|$#iy~W-_k#g7 zgRL6S)L6;=Re`W5W1PDc6!m7FLwT@4K>2)+luuy0VjmYTq2dtc#2-xaTYNsuTpyZD ztFIHm0qKp5_Gclxf^{`AQU_)0jJr#B4=srcrFS%U$;VF{vJ`G9SrcSsd%v#o*R3OFbx zJVU{;DYjK8wK03ehJ%DEdU`R|3qBJA($!lMqFxnSJWCFmd`>%vn|o{?!#+NTf&3}9 z%Z*dWAkl~BT(QzQaXH4C+RxXsRObCql68t!_sKkjGIqn<8MN-{E|f~50bdPl&O*0} zy3vVeewzVS*6MF4oY9@~;9N4)`GL7w-@LP%Dcc8fgO?Xn_%SHdUgzJL@nQ7xJY?Rb zDU%Bb*z7?~L6L|L=!u$lwJUGLrWu)VgE1_i^WovKC^Ul3_y&DBa&aPJi_@h!WAVS( zDf;QO8iwr;g{Bx%RfxaLKBy`VtW3c%KdE%!R3P9B6=Lca(lVo=cL~H*$SMC?HKx=F zCElt`1X_i?dv!220-D*7ab*Gf{?kB&qOsC!>RRCotrMfe%}IE2=W6}Q-tqDlOc)Eo3)bobw zK2IMt=7Ea}>gLQB=f8=A2!!^~3$W1Cs5QZ6Cq+~ri<%dnTmZ@nGCqtfPCesKXCst) zpP>_ZFL5|1`MRBh`q8@F<`Cw&UQ8p!mF@zazjY)XTwEyL;T%5n&mW8PKetRMdBlsD z=(8m@&K(QTLqit`19S1Ft0(Wmf*XKe4Pen?8uJik0j?`l1eprPhluof&XbsEaH0&T z;Gfn&&p0wVW8h<8Oi3BrTpJC}{$-~wL@Eys`Jyte?Y?L@ruFn&-jj1YHyqva)hC zrVhF>W~n#8pkuon( z8|SW7&IJZc9c&<{uAWypNa*f{?NxgCa-%_zbb)-`c9`k!s#*i4@r@QZ){2ry^Me@F z@Kyle4;7n0DDAZ=o)gfmCb^T!eOE|8eLdr4hrOFeuX&dpgxR-vYYc4zhjesU5Z3rl z%zwWD?0OtVCv0O@Y)#9$!nvVC0e4I#s z-hVq2R|2|@MQJ!1HW&cWf@>6mPR&X?^3F1OWxCgdjqMx^&IjJ(Pvz9 zC={{Ujnn}tA~%=9IgIq>iDhES%_%~f7V$gT4kX1AWIlxM3}+x9IjW!V_kB48&p5>n z+l1r4G)$Zhy$OU2hitiAXyrpvDk@ zy96G0xGOWVqd&#lgY~CZ0!_Yd*Sxo*4^N?#LjJL-Kuk~`=b%FrAS2hfUE`K~X7DwX z0MGK~rX=xxWuOE2>oZE;lcjNUF1~IDF$NPJ%l(1?G&hldv4uqH;&*I@pOn7MW!@L^ z$+*^>EFli^1V!p(9g_|PNCGt$6adLNQgDhnq|+p5ZU}*t3I3SZQN9cGv{Rh0d&5U! z8et!&0-I0pM&tUjqdYkIp^pQYeSI~7C2Q>l(Demt`9oB&4D?togWcyrt-Mz>miJ)* z*E0UPZ?RxhmKqPwwn6L4ArqOKD(WIh0+HU=<^T&MN>XaIPysmG1A6aBpOZ6wR|n{i z6Y>Ay{IOp{aZ~4%wDLY(>GTz<+YOyFfHHa=ACA0)N(dtjp!4kNS&P}1HFn(_y6cv; zoY_34;$zax(hvaT8yk=(5(v*Sj<~?Z4$SjHzE6c)+=rN_Rj||Gh!DhVXPjY4`YnLZ z6b0!S=b_zbm=ln2wMKgNq>L#DHzg&>Z#}SRHT@ICjimr@#|daJ|WWD_oye-{?tI>J2?SptM2&0FG%_HRFZ-_y&~{4lak+Fuo7w zky--cG!3i8R0W)SBXE_!w$-{GiatWb%WP_2Z43p;4p3 zK=7FP*Jv8juzhtXceiF*i%&NzUt(kH52+%-%{WmJ@FZO6hK%KRnuGHuX1IViT?q+v zmPW*KXn*c13!0l`d}G3(w*reFRVgsB53!DXRQQQ}ZE(NH-W^vex?A~M-}kx8$NhAK zg06$EI2+btN3M8oYik!w?kMT;_4XD}aPS34mj=RS&F=?gcHQv*pIcJPLc%lBI@W~2 zeO(e(Feii>t3bsMHH~2Fg4po-2MbCAK6RIEPU9P4FZdBbaUERzMX}lvMfcAseU?b!mn=xyRgx5viKJ$NRx&@z`+-~4>j-UPTYV8XTB}Akrte(SS#Xo zRZAXD+x-5q^f|-ydr`jUlJnA=qIU;(NKut?f+cB($D@y+7E0DqMcnYZ$)D0Yt3DR{ z92QY!kGYCs-KWcHls=7>ap=?Vv9`GSk7poz(Jg84i;7C4 z<%6q^Ncw1Fdqt)GAuP_OxcqIQ37n2=H35BXIP1pIw;w9~y;UQ?4afv=_K1Qn3Gp(r zvWIsBtDz)4v1&*uSL%n}Zla?7gu_V|B^Q z96AJH90`xmQ|6t5dY~#IUS&%idH_-vZYl~uUrJ>t1#ulf;#FheX4?y>TV>DvAtP zOL)u^#}t;0H$nST|FatZhH|d^!z~K}o)Wpmb7FMqRgR+`FZNe-{ILA;`RY_QFq$q?$MP@>#jMb+k zQjsAtREA0qnz&GNaWWv3Pc^Z7?^qr%QA(4m`DPPg3X zq_hwrJbh4p9VC6bTcPd#Mb~ffd&U(nMPqM|uWguS4RpIEc&xIv<5984uoB`D??w-@ zBh^*oUQ_1zRr4H@eLD;U1T)_X1(Ufb^{~XZ(w-Lbhl38YMr8A(JZx}s3PVYE2LS!^ zC`{FkJ33K9DJ<&*QbJX}x@kdU*XiXC{Mrw#VKZ~xok^h?`2ENe2@b+9aC7rD2ZQ#RS-?jt!Q4#Omny{tho93N~{8e+hS%$ zhA>{ZCA#}T+vagsp|FAqC)!Ats3hoFfxpghq|IPyF~F?T>tAfN$%}TVLd%V|5D>;`FS$7)PvDh)=%zsV_qOZ z^hHmBix7R$G(%q`wo!paH9&MMJDlW-Cqy|b7b$;HtLJJ(9A*RB14EAfQswRr_xnMM zn7O{;Wk2Vi9KSg*rm7;MC9u*D?9v-Ey7R8IN8Ap|CHq3zTAfWYBj1C8?LJJHE2$&Xjw;q&8nth4$3 zxMRU!55Iz$wIXac2%Vk(tj)n_s8w&7l4tLbHEZtTg1)cUA#LXyJtyd{Ao-(DVd4Yt zfbPE+O|;Z&cB7Tqg@igZGyNDD|HeUGOjak0pF9;oiwdmH?BPn zt>^xiRA6|K6I+W_)5&z0`x*`}v%YDum2#&9xX4LGTZ`5x^Y^5y#bG7~HA>W*8l`?X zviv#y=4)aC(XXS00k97V1j6^9ldQtg#x5pco~THf%}+aUTKS3Dbq~c}((kWrjiR#p zdeR+?+8<}P{Gk7Pa?ING68*XZ5%^`3sSxY0bN2G5E6 zOW*e|oe$@BL9l>tx9BY6b^7zKIjYHt7GS|aXl-gr9jc7I3&~ig`9xM_PxZzsMo9yz3Vu^c{evl5o@vNy~L>K$MN#YM7Z(!OR zQV|qP3?DuxDqUqIM-%nQT;bd@|MbcN=KlZQ94>!*TascTW&8c3j`}KHI?9>)l$N=c zL))a^oaYJ|70q5*$s?dz+rSAezxL9Zl^cML}S-NKD{CZ)ame=6j-QIbnMmAgiS{Z~SB-D3NC zKN{8jnY}gy-ILY{W{(mQNXqpk;eWUMxhM<$)X~+-)pm;gd50GlBkXhIfp7QbwG<}S zcHCQ?%g;dcJW+UPNkOm`G~|`~ByCy_!l1zj)F(_uVL?-rgv6$%Q?!7 zG2}jS`zE0aW2};x1SxQ`b%Lx9W#GoIOu1+y)m|8{kAC-tC;|N?< zWuMoccNi=nPTG46)Z))^pStrbR*hWCZ=BlezUYVD=;q=+9pCVEQgJ$nJQkVRbNcVJr?s@^VtOgrdXn%;%Tv!rVDs|hvQCs+>efRU`zOKECn zrmgogMs1N_C5}hhfBgno(2!Hri+^H*ed}CUO;}i3LaavE`6rCIoBY*%+qaO_6gb}gSQ790(Zv-pr$)!PJ+_fHKKGQj{Iut+;gH38cjJ`Qs&8Ze*5E~+VQ973){!#l)!)&Dq{+2Q zGc)m@CFPLT4X@F0k172+|KPT;?!x>_1c5VuRwnq|pE1ntPR$08U^gycq8@TC+(N_TF)+RryxBhx_)& zt4N6Ok*ZBvDz?lL^T>%`u!;t^T%(6pe(N660_b z;YN!MNmt4C8w?CkVMWIvZ;6A@y}{m~MLig8P(tq9=kEu}!0{7dIZU144;6d$SD8Sl zqHmf$pYT+d_M5#}k8T^&WG?f6o+_liw5~bD8G% zwGQKw7IfdKzRA6sXU?Jl3Oi0t0rhVP|Kj1Z>Ex_-Sb&1G`TP-T@eN|fF`6yb2@@}B ztb*})da|!;9!RFx@8&?FAe3It^yL3d9tcPaCkUUONlK%!<-YO&%<(sghcu zhifpeueysS?I9E#KQj8KK$vJjFIr}ro`Hv(edk%;~z0J^C1LH5jJfYwbXqDU-fq3)%Va7DM-{bv<-Zkoa>rZwOf|@Kozz^hsdmmOHJlGp~Ss?dJ;W~nkE{w zktR_+FP06Xg`gQHe zJ@)pg)T{()h>#T4_S$6wZIe300zWQi5+q(9w5V2=f-+;(G=U%OZw9P#I+PU|4p;YGf4*QdjJ zwVjea5~(==k)pD4OsySO_VkYyBqL!E*|5n~Elh#qtUtvrnM;y79_k2H`cqohjelqU zL3iDW#@Fxxo$D`L>C!?aGycNQ9S6HT6tzd1R42te;pg#O7~0SD%*RX)QcsQK51Z^e z-e$?~SyHn`Zv~irrE~ABxiwO9YBQx5-IhLkAv`R_-gCMeenGlAMux5aCUloQd!t;F z(nKI%qMvn7_iR7oyqoT z-}Y!>t0Gm;gq6g7PdG2xSNs#_4Gxeo1DDF?9Anu^mDk(I4EJiUtafVj18pYpd@E~! zDWUr!O-{uyL;M$M@q!1xGQv>lXyrT3CBh{9ApqIHdCvim!aHJb^Bl;jpm)?!CFfs% zwE*QooL<^uOs)2Edr}bUO2DE2+gGD`z0EDd<{~%pGN*%WlAwK>%UDW#7Jl; zPho@`Ks1ek!3Yr|S3jMSnJ7>xKALisS&K9nPA3o+qX$q;lTVc{jD!072q1W7{q+{3 zFSp-sI)Z=C{kUH^;Z=doHsv4l#5NHzL5Q|VUIJBVl-Ehs_Rjgu(YE$k$ck?EnXF$f zYrdZQ3O|N{APsxIG1fE$+0E~G*_Wbc+n?{Mt&bK|mI9%6XWu7v`vK?1WPD%Iw zXLo4W@5q)M(xKzcJ5T)~)=N=YsoQpqXA#l>pJNpg{>=wLE+E-1fgvCM6yhwRL|`Nw zoE?tpvBLwlSr1rfvvR>ckrai`01D)8gQ|Oc7{iNSHbQcy-KKY0-!P3-(m{rj zAzkvjX|z@A(I%Ajhn6r)d?e@2aW%H3X$@8E}gtk9(lda-W^85qDC_LIWN3NsuMTZn9k- z8y6ZWQ>Ej@aBw6Tb81!r(+TQ1-1nGB{wT(LHU9bErWE)6{zPy8_n_3|tQlZifa;>^ zoG)7xM3>%0M9LRSk9w7UJksH%Q1Asm4%(C;a0~F5DmvT^&MvG1Pg-*Pk}64SguLl_ z@t49P%MU&Ew+^ci33y2FwzM?31mv!(#;Ij+p1!|f;*ugD=$1m7tsgYFJXaWb3Mn)q zE2nswYO5z~c*yB~u!fsc3&Y=GmFd;Pv2eTu~Q!2kI16IcY8pbc6=1(|$T1b-3)2uMqIEX@h! zMnZxG;48=&{oOcJ^|=rIo`tcoI?FTmoP(l;#rDpEl4P=4!TGAIM(XE{uKK@$WA{aK zEbh!wvS?b|W1rgG-xHO@x3MkXdic|Yg1;$42Y%GQrrGKGDuWhP9iP)un z>cf5BWh$cDB^W^_CVhC8HA~aH7wE9Et_N;-=p%ByJ_Yv??}Q3-jK8lAe^0;9IE^IG zWTa*R$y)(ZgR-15&0AoX`fqVb=LFggvE>Gt93;LL#_@H|{BdAGE|92>w5;#P9YSGmrNkcPATy?Nz~vk=x6;qIIf|O!hFL`z4|nhZ$km>by%Yew~!;l8spmXqL4sKGsd)M9tvit`xQqM8u%WT%CF z=t=m`#$#d*Y z^#q?!UQKK6simwg48c70Ou0*X)?Xo>E^N8;W4+8!KvNYvex~$%a?(}#0MqkOBI0~y z@glTb+2Qn@oEcEci;?!lG}|Gu+k8Y8{(V-JzWFcaX9YCBN{0cVs{ck=e&J5a|HE7wAWP-#rd^E^`eIe{Xbs~f-B$y zP2uTD@pQ6GXrk{|v?_F?A_Qi=du?4~{OVh$%zT*L7xUZ_sC8=gZhx{$E=xw5Nekp@ zGm77f!XYK=7hMMkV_8)%e+tB%o;R^~%Yx4vZAR5_He;3J6G%n!y8;TknPn9N3@W6I z7)cwb>4Ga5n$)bH4C4yQOdQqD<*77M^7@o?2v3z8iP=u8v$LDk$%Ac^dqBBo_*c6q znp0MfJQ_rZO6nl+tjSWJ#C=%n7vb>ZU0-BmL~l8|Y(CHllA3-e{IbzOvV!Mt!wl3$ z(p$lBIbR`yklyi2d#*EUDWAAXHBXGyYF*Pbo$22j3srjVfBc@u*%KjDaF+SYMEG9w z+^9)C66EZ)s*_Ww+x>o^yfT?em?vv4SB^3wD|Lb*XY1Fa z*y+hx(Dzzm?TC&(No9mm_l@3NDqENF53RNO7;y<|)5- z#jQ#hKq&ZTpW$YiM}hi&E7R5=(Vr~dgV@>#P_Sq!hRkdDN(QutWtF^iaJrLu|Hc6E zKm_+@I!Wb*{(I~E=rW9l8>FMTr1A@k-gSQwz1gh{%L{V)>3uM&3at42z;-*0`T5O6 z=RXx6pYF4KAwovm+xYh#d3syn3T;q|*dG#2Ir^K5s%F_`daC;-F_C7C$7s$8_bVe7 zfey@=;!3_ad|fvtOAsAW%bw;GxmQEt2aVW{t6D|(1PJj?FcY&<`br94|B;cv3rPWzSJyZLe ze|#DtoInp+BE4hugiQ**0DP&B9ve*Gpsy!Ol#C_nfDnkua637XW8g~iFe+|AK(-xl zCA0CQ)TrHTy;)Ja6(;HzU0jrBEKtsrD~?mIFtMu9)I4Bmlu*yK))FJ!&xM!PDKj%U z`&Idcnfb+2+qWwlNG9yszjQYs3B_ge5%4;X!;6}lPV}?s35Sk`IX~7FOa1QR@@z|Y zcZ~09?&nNKpNG$~?{gaJY;dblevyR?L)AOfGv~C9XA=-k?2^kx#jXR+$da!bn*5|w zZ4=gf)w5bsDL}kwJ1Yp&^TM>3A{Tb&CnI9&>zvdpyrV(Z8K4?ak5*`Y! znSim6ayLvoX#4KrpRIHvr$(8{gs6c4K*R6Gk&>wTU+RsWdObTnYZBAy|0p=@L8m_% zdnBMhDRQe=3cpY1JNpgmv{O;WGfA=jBbtdFO1peInA1~Tz%?$6~ zCjf3J-#rq&*|WM}WIX`B)&=uP50jNTGe_Ran%j=fijB*CEEqpAWHsYw$8zq`rC!B2 znP>aE1|zm9T(ERlIT%iI&^n3{5Kf{KFNRa~P8s!!lDXjbt$ zvvmA&1n2pUCM@{UY`LD#=Ww~V9g*(o{i{-|qi0O#1V*{(_(ez>1FxQi1=4Mtw*JwZ z$PmG^on=ctqTI!j`*R=p;`*JpVC)0^L9XsPb{1>vMmS|Ens$dsvg<0eI({j0+wJ(m z8Q3EF5Yo|;rm3Mzp!eG-SO5InhtPLW`|f$x$lYjCjWUWlX}>fM-s3auR<@4Y84S7r z$O48D55vNOd{68=C@v#VTqvVt6^-o_&7bW6S@-zI85lLk6_tkH+eT}R`U5h<(DLiQ z00j*=V_wbkv#M>{leYhDd5~}Q2m&W_o=uCut2cZ~-rptFih!{R{p_8&AjQ|* z7uj*0NnbG^hfM@y29|wa&GgV|U++kXcLEQPIK|f3@?7|3&m$05@8rTPu(8Z$?~nSa zU#=IQZQdACJ{Y3@?VEu~eKSWxs*D8#a&%B9FOXgr9Jl_LbhaNYY%2@^dTf)$O)Sq_ zDKwY4{6%SUjIE51U%J$c!^6(H%J2JSoE|~T3S5AN6R5~1OI()xB_00qTq1W61Clv{+z z!J9g=p@kXPa&A)Z7{itx-urVYP7J%tXlSxY!L;A`pHldj;-eSXJD&Ka8fj1X_^G|p zV3KG8lp>lOdgf_Vq;yPS0c^D*4j;;hGCD zJF$A?xM%G#4ryY3S2qi{1t)RwBF+SchH+X|~0#!*@w>E47~#*hk@le>3YzG#0SC zZk;muqR~-b(##PWd<4?{k_CFSl?Eei%IH_xt46jY!5(q^X_e8Jh4%YtdP5%ub6kZI zKJ;u@t_N0XKL#TzGh<>5VZQ?LW&T^c?BFS3tFKKIN94|BTP5`nX3S$U;ar?`$2d+` z)d3sAICJWTh59ZGlTtjv)_N0{sz8amaJxan>_8c>L! zvu_XH*gU8KJxU(xpZqhx%~#CN-1D*0`P`YEjtZ8Nt3THjg0>xO!#=h!B#;hA-U2pd zF4{wi{>nFPc>U^?#pmDNC1tI65{TjC=$E=XhCe*TK~6Sh7i8zmNJndLe@YTOC}v>Y zO2Spl(T+>xfN;Xp>+V3LC_O$Nf#|x189r6Ir!kmnU(&do4DH4^FY&!3AS%?3XpHBm zB1-982lmLFDZaM|QH$s5pOy(qzqh9yq$@atu zd@}G9C#vcJiJa8bJTS%1)LQfZ7DQ9DAmUZew!AHGUa^}Dg+Q)^D+(n-d^tkY84Sv9 z`~db;1Urwwd}EE%#O`{r(`&a}{)bUVCnq5_%*P(tnnX(8lQyR7v{%TDy4GfACpxZK z@n=0Mgw<19kER5J-gGu(l2#*Rv6(5X9~wOz$0cWh5|K5fO?~LTY4FHJ2D6fNkh8H( z?B27E$q(JjR4Nf#Npeq;&E?v8zWizRf&g*8A-c!pI6tlR69fX9mn;?IZlCHENtSz{ z7+l}r{sRND<%EQkZm`h8BQ& z`OHD@4$dlrILEGAa{VNbF0#0UKwCQQJ-RI})ROxv^}rGNNQZH_SyJ8rin;TFOy;?# zB8`QqN*(8_@La0_kgX6^7(^N4ZsW7vs2~_2p~*xNQtOGsx=RqqszHbLYc=IubkCby=ITT zNl{w_x9pL*X8d`U{KaDo&Y7%j?k0SN8u<1nxFT48wun(eZlsKd=!DMA?!yw5bo4t| zx-GdxzKva4=dMAy7C8ml;4cL!a_g-kg~}&jL=tr}KFYI&Q_J zk&1*BBMx9JVH@C|ZP*xz5WV}v3*uyGK_#)t)UmUFI%c-$E>gG1DBmJ;Ew;Q{?*`h7Rj|ui7cfBUe6q^`^OqDPmj^9h z?xZci)SA2mll=0Zq*M1rEei5}mdEU;eT0w=aj2|K$Y>AIL#pJ;2dp(dofta%49zi68<#!^po*;^;5Y6|Ii$k z6HQG+!+`1-BWcw-on3zfgF2aNYiO;G=ts$TIRpJ*i%5xoE!x@D1#31qKSU;*+q7>B z3+xnegnle#!#uaE4*Sz7PW7sMKtTWcDQ1Zg_IlrF4CeMHr{tIjQfuihvrAj*f)%@- z6P*Jk;(rjS6rbzn6eB<6@YNT>jUi8}PLSoK-of%v6XP2@;* zXFc&~!|5Z$yqHXI)Pn^HtZ3z0XT!^AjM;=5Y8!pU;NG?s_a6C&ry_~DYyDiEwJPUL z@}_J$!SMAp1w5Ku`n~I&_7Ei;k}UOrnU2HZoE>>+C%lWW`e>Pz5uOpw)!Mn_=TkP1 zs)!6s<@ehK0Vw(g`-tNRV;(i;+sev2eB$Hp(&LLqb!lQBdVYUp3~ED&`Ru!_&pi&J z$H*F1L-V=4`6b!I8ha2l2&i=P?FX1y0t*o@i z&v3P}S9{f%u@w%ok^)FYa64 zafL{wpMdTWPI7!vh(V}%Xlva?2$RRV0+7z3qwWgmMfddsL4Nbf+)SbBIo-)N(;MxD z!AzwgR;SH@zu*YiFj;eqO=sO8+5G?Tk+Seqm~H|1ax(2*2O~b{U&t#4rG)C~q z&L0hvL(}b3f{eox6iZHVZ<{FYJfiAB@`SX^z3a45<&3(nlz|F~G%vFK|Hxe$n!4RC z$uNQo`=1GRyKq9sJTZ5}mDI7WD>mUOl&#w$dZqFT9CC-PMkwL8STq63;YP72J~xum zU0UkTRL%>GZ@!NP`q3jta%?k@S7?DuUJEN4(`SjZEn3y6pCP&0fgd;RJ#b-D$!k!8 z_c?fBiAg=EgE%T@*!QB1c-4{Gd(qT#xU3=xX1pN-y|_HfZ|y<_+ME3OmsUnV5d17yrbT$v^Y%%E)e5F7}2H zih*al1Prfeml|i@JpcoOe~FGZ)OR#M6)P51(|eS-Rhhg_p7tM0ryf-4s7-e)I;Lky zq0>5kH(akNVC;v2=)TzMEV{mh(i;J4Tyu=lIPDkKdX)|EA{9RGWFp4uf)?pf02kgn zwjxBEEia*&w5P^Tjp{o%!sl>p0H5HXC?|39Ft{s0idoc*qHd>`Y&XYrhPB%mr5nx4 z*#@G<>(5=0kg`+m0eqs74Rxp$_Omc{mDm~z0h}Tc4(O!=sv06lHrR5>BmaoXh=?Bk zq+D%Wp9Er0&WliR-l<0A&Bm^@WXS0lRuP1C0(=bTTuS*$ESxE*xh!|U=IWMbD!Nkh zp2rd3J|hONxuk?Tzprua+_hgsv3PWQHpoI&3cV{elDzNdN7xg18{B$-ywg1zuQ_ef z5l5I48>M5TwHhE_mGq;X@t-^L5Cw2u;a*M0A#)(-21!~cmKV6}cxR|`UGEsTVWylH z$*v8r&LsfNvNDn0DT3zDDmJm&`~d{>obz|5rgwuoxMX>sMQn><43-YJJrT4xv97Va zGLka%~n!Rjyy06gI-auXaSGakhd>~WsMB#Y7_2Bgcx_d39g^ym63 z_}0ochYb|-!+GmL;rl6k10cX9t~2uGRhA-0z9Sv9oMf0Ht&kJvQ^lo(23vgj)p<2S zxIWToZe_$0Zh{?Gjgk>~rGHs?Z0zl~QMOPQv9ABz@VfA8VS$wal-Z=4YGCVM&rj>= zpiU|$?VsHToFCpB4kt^zuOCKg7)pyHBA!r)c*xVj#@4h~d&R9$*Wm*{-ap%OpaoL-J1iTgtLI-Gf1`zJ2vJzCd`UjI`;!-?$PvC1cfTu~bqej5I8_X=on z#vK7<%nlJC5gi$yCqAPLCRKl_*x+*@Kor82_{g5o^J->l|E8ID0VGkd z0mBxZ7-bZfutcoP_{X_foONw<=Wi*8G1JS+ui(!uU^Fg zmW<|J&-2;HXjrV7-#j_{cDLi-WnYXA0~3`#MRudv;(co!u1nknC2n41hjTW!c`r9! zjqD*`HYHbi_Uk`1IYsIx)tO~QAV%?$fOH^UyXD3yD`~MbwX^|}+#GQX7e3>V8HLxT ztU0Ediy|!P(^+uDctbcH%X*Xkpv*>KhT`LNmgh-C>bKYly0+b^o5duBSik;N2NDp| zFT|6IjOQVBV{`*XYtg{F$J)jQhw|!^$9!wKC2OI$xSb^~i7zscxL_>J_i;`U2pnXg znFw|sy24Py{(A1g6@^$zOqW5e*xfE^wiQ!xjKw z0*PiT@iYay6?Wn-jnvDZ#_|m77}d=JN_ErV#>**kpsZSl@GH-!h6^jhgkFw)l;F{z zxi2`s`cdOV7(~vGvJS4xjl_8s5L--mf9@mt-GuJ(evv#}(s5}VglnWRkgCjM9;`Zq zobE=R>THr?QKhLt&l?5wKz5G;!4i7C=0p#dT+W^GtsApJcth->kW=Pv+NuE*M3RS6 zy3I;cveZ@$;ul*+nit$2ce!VLra5VPGtH9X+sQ!b9Nm5|apLLeF>(s8;7*b`j8U~W zl1z((9)ikWm6rAMGk|HTDP;Z!zcyfug`XsAm@GoEL4mBN9!pCNBC)6{9X&ln1K`06j= zNg9vhIZ-s`8gUm|*>MDh`z`)8kIw4-oP3`oszoX| zKXT#%92>N!#TF_N^2Z7SsprBlZ*MU&F>LiDLY%eIS8QP3Aww>Cao702%In*xhLsLp z{t16fp|8iPnOH)pAiSMq0P@k3|NnH^l=v4@F`$PWB~A0nUGSAwjlS(J*8F$E+{*dF z`DoG)EE9`3GC`JEYC8Gec?!+2`2ov5}eup1QA`-hlR$IL;9%zP%lldEnb_()rW zOnP@q^RsU{7>8!$#6*y}b>P;Ty)#g06Bh{;%_^hMMfK@qjmccmGziOn^W>Dx3mKEq z;NNS_EW7|+R@E5083yedoDbT?xoh`8DdX|W6OW_tlzY<0ox@f@)L(`DD0W+eOxT?A8_gkzu@d>~I zsS!AOi;uy&bXnTn%^$X;nz3`w{(2*z+!u3x)TuS9e0E;YJ2W*4UFXGdA!WM?>4NgH zP2mBB8EWh?vAyV1R%tfQ6TalOY@Pr#y4#}OFOtPfUNMLw5Un2}Jstn;sDg)t9-Y85 zwC2YEYRI)_;BbcZ$*>FBM@Sbbfk;*JP*1v2+2x}!`9P57RMyW3__X86ztvroT|2l6 zZXM%NcElGdo5~(~*Q>>wMboHqd`4aKj<@{oaOr18@;y^7@zq>WSm9l+dQ7yH|IAU&ggW22-5d3FNXn? zmK14-#Wo&4!k80??^RqaFFH1++b0S;u?o`T&?A!QtOSM4e^yb|rEX9*Y&!jJ9_@-W zn@2+T`JKY7U#?MAA`A)`hiE)}I$Cw{UW=q|1b+Wpa4|b15qb*%G6jF6U9|bZ6k$My z)fDhgqu@FpVt8h*h<@5LDcY#mg;c_Y5S0KA|Kih4Gv=?%sP=#TPz4H9ELRdVo zd-F)1(Y2(m0vr@1Z#|Y+1e7-Os%l9q&@%am73kQoI-;bGBD~0b1Q=GNu4PKDX`Cs# zc95(zFs`AZV5Ji^>Afn!Bra4q`!Gy0;#Jwrf4jM7qu=&~thgmAb&$~tZTq%In_<4$R2sI57?)R_1C7OQ zH#RMM-JL#29y$gIPN3`s3z*`8V%@S%B)FVa1uifL=v#9OSow&H$-28NACTJ|;yxs7 zj5oE+(_||M;r;=aMYCGa%q% zKG3`F_@ZY-jU@jUT;7j3`XBn~o=#vY^}eNi{bTgbwmt%0?~es1_Sn;mk=~eNyWa_> zNf$RSQlg1&FTPN?RGEuHZn9Z1+%sp;qC;HSP&Gy<_gQ$S?u%p&dI)(fFeEPF%1ZG> zv%#+graQ*YpF2?MMovIahWdx8RTl=wN3w|3I0jRalF7wEi05w|-{=as@%#a*#kn1K zvbu5Rf;H})oy~a2sj-e}C1(M%->ftNHp%dRm-Kh3wNkP^jzlJm!T%t5d>Mr*!z;{Dl7py$sRa-yKVbwDgMe0}Fdj4a& zk@eB+TViTU4y2iPpzlmX%Vyn12jb#h*eccnl$(E8ZhoDgyHEPJ_Y<=@QMdkGF}iNS z@{KF#??tEaxn{#;(s%o#SBVDfEn%j>=SBD-C*w{0#H@AuA^E*lucEh6C6hMf6r zF>xaSE2P6J(r;w$Vfbj~5ccBBzWvg9VgVa2kDYW2i&0e@P1)*kUZR}$7|s3XWtsBN zVZup!_i_e3O!7OFmI0-hkuck#y1qUm!%RugjyuIK(!1Z^>)kd!I)X8oT;`WAA0DI= zpXz;5ZdM8$MjMXf9lm`XTHg5I>@K$v6J^f80KrKQ3cqZnl?_KGnOiP1)~QL9sm0l) z^f^)c(Vvf5g3AiT+Z?&eSn=$xG4b09cV;XR7W6y;ujGR1yvk zX}$-1bY`3u(BAd9zEr`Dm~YbKH{*hUFDwF2;^juOr{a(dqd2zh+%u*n)&6N=-qCM+ zQs0WNjWvCcr4z!n+Zavog-)-o3ZKOGNcvq z5mWI}EFS8q#(3XF;vb*cE@j+mkLf{zL9ZR2&h2m{Wr6IW;ARC}W4-3CoQk5e%;O*7 zWOje{qD1;iua%WB>nSUH*2Dw`ORh z4O)yHSf=8xPo8ysW;oXHU!shE)M&jl^Ke#EnQF~w^Lg8J-n2+oiIZynznz@w*OYoa zg?d|Ru0Byxg21k>4zCW5Kl&w@r%UFo@1izKCGe*OQ%~&Pd^i;5$nmSEYrAB5FnSNv(l`YqCY>CD#yc@@`gv(?I%OO(w1iG=%>R}h%r$-I< za$-%7hTV&N*|$E3?fS{5pPQKdfV>Xfr%$f9#kptqJlffIN4~g#5>d&D-|CXO?9zQd z24!#Aj|wEnsR;Lm0Ofy?Jm{*>T#9>)jm#u7{V^yE1Y#+UF^@?I)AQl$P`W$tx4VFa zTRk2b`kvqaPS>HF>!vE-> zxF(^|=KtUhW2*y}H6%!&ZRX=!Y%(>?VUHCwy@~(M3zLhzCDhgYJJL#89=Iz!?>%}_PwZ;|G8J7~pCA3U-h#t;LQo^HrDM`RYnF%kokop6+f`k3ixqX_`a|~m zvY1J+hCfE><#SG#)Ya8%<_;SNPHmQ)mKUZEW||EV0skQgKln?AofjhOIk-?wO#yZc zzeU>=Vt2)ANi}t#078?dN`l6-`v8?U=lFn95v};XgUuH0BA! zq)w)u_Ro61$FjM!_`@Xp@Lntz^n4X(Nmjll`M2a1<{| z=Rx--Ki!>7ez>ED@-BhWx&Oq9`BO8Kt5Wt!3CwOk;lqI&a3nJq<<7>Xj-^(y=vtfG z+QXaxE5=r=og;Tx|KEErpcJu*6@Mf{A=~bY2Bmf3Oo82`hKctZL=Ej;eRJE;>zmsc zyoPIxkTn^lC#i9>!f&oK^-|Y3S`}(t9f05R=-b97b~~;p7?{bLN9#+PO1gwwOs#-X z39dKKs`KKP3%tsWwEr}Qy% zyGcvmFSomYa!dnn9ptNXaY)e;ZyWk3k)iExZecK=R(rv=!C8}2brlTzT3@|obZt=$j*xfR2>OX;Iy^c;-P)Yc{K1g6}_8f?wyHv`QcT*M8^Q?|*@#}C5t81ww zn~3(O<*87>$Wo_6zhOX&6AIDQ7}U_|q#VK0A?q)tOJd)evQJNCft)^OLk zoCjmXbcA}|sRt#>H66D~P&S+fJ`$Z9Y4E5-Znr|k?!7cd!A4H=0c=NWx2~qU6yJJo zbpuD4M*X53J^NT|-!FHV*ZpLoi5^}pzv7mK(jk+ls2Jd+$I|*XOLW%UdSwGPkR!Qs z_`EWX!s>C-aLo)D?)amtM!R>}+Ihn>*twshb8>d}Pe~yzA5PDNp(@6@rc_V!AIv>? zm^`Wb@%~3^G$#^ps@0Z-n2uj1hM1DCg{&c_Q(erZnbOOKCA9n-||)zqK!@#4Sh294xYaAV*JsXRyUlsyyB zI8bYP@#kt6!*30fPeW;|^_;%n*~Xx)1J%^Fkb~a)y&u1^>5(Z`<?**3PpdTA3KErxd-zF!d=*>Ubmw-~f&i<=6)pCr*EVyx zU*po3SbGOc+VIo-?AW%S;Pvv`B&`N;JhgTnU6JaREfXoEx}_Ke>1B15Rf#Rs;7XTz zL5IBdQtT%I8AWd10mWdbe`rdwIb(7?_03WVC8a5cRY+s3g7kV9Ih4O;EGlW5xQdcz zJpzY_i>|e3%dUuaT3OjQvjsSD|0fmbt*nbx3DwyHR?WcyuNP9L?ul=tttmz zy(;|Touz13;K9nqw}5A3vDtP^AO$cc4A2bSkG4m4K`DLsV`b@|S(2mXRV6oh7-Ca( zHzy6dMgELieO3rAnVZ6j-QFN(H{My{r|SbJ630@m)Z9Zo=>g3HEdqN)w{I7*+0n)& zeIhbrSOF0_-5meW0Hfe~*V$RfSd4&Y{Hyp7>BfadJ#?3V^hA5T%M~dyGhFolD3GUg zN#4obyEBm4Ivw*jsJ1SD`BK8M`NOcZV5&R$!uDg8QZKeT8ID}v;47x|R(xhTiGvMg z9=CYI-XLQk+dNHpr?&T@kToe&T04!C&CXeTPJB{W48`tL=J-YiarJY++4}0j2hkib zWX7S1C=DT7`TTIsJz75e&A8dX-lB*T3^fnQm8o3)! z!lk^{{a|G7GvH!e@gIMAJMbJCz~j2NpgO^c@Rj$$q?}iLTjfG1I1WhfFA$wy?Hiqn zsSYdK&HF)!0zp9~c#W6i#mi%fW)SX5_RmBd!l7K-*T>DZY3AVSTZwPb@0Op@si|n0 zhEQ1+HgHd<6Wpi|*@{YQa4OAd353<anFe09jz7fvGZ>L9#Kk@$U?e7_(#Mm7LYW>aGA%jeWG={M@SLXb&&%Xq!!ZV{Fql^9d&E zjpQQih{$-k38&p2v@7-p?i3um+FJfH@%}Uh0B;R{5c3@=!6YCFTH5S$Y&z+d<_F(g zEo(aDPwDygXz5F&6VaCMm&LDpspTa#VPkWvMcFXFLVf+39DTa^BKIR1ZVu6mw`bKi z(DR#|8+}>cLz!-txE3#01PlguLr8$h_>!%9s>(iQ7Uw!Hd~`D@`%(l@6gfyu^Ye@z zWN7Y*y>tz0N8Bv(?2TPRR}$CPD^{*sWh^b;B7b2vI4S8hwjKHW;XpB4oB=A(JAZqQ z&gU`WIF{?E&icyZJpcLCD0A@<@Rm=-Ci84x^GiDQb#1y1YwNwp7bQy|U1)V%xs}+UmM%2#WD?J zj$B7lp)Lh#--^tSMvgpd$N15gFOko`j4^xijRl^;=uMESqs8#fqUk*Gazufezi&5Y zOiB1i+BuORj>0=In|ZbNuEnQTvt@c080iS)72pTI?OdDmXPT~m$xl*&O%1o>qD1%=Z1y+cP@}_ zjc2n$BM-~aec=r8@$dfxJ(O5q`0G0nHK#X7t(Y%5eBonJPx{+>afG^#TaK@#Zohdb z%U~wiPUvk>6R*TQb@?J{8z-(F@r{f^l6kLp0^4Zs zPO5I@3z@vRjr$D)b9uQHRZWB2{u3y0ZFc*f5X^n}qPM7{=So?In{nIAbWVjzT>J3m zOxDo_G>1pH4|VUmr}3uHCg^1E_H^8OWl%XFJnf*5ovFAaK!TKZxv+K)3jUcbi< zV2LhQVLo$e%8|4rA*sVd7T+P#*TZFOvOojrVSXto<*>vUTSM4rn%Md_{s;caOA%6V zLBa7yt?`}HWLN}|ddQQ{=>`=tON}Q^^=M^0O%pQl?B32fbLg)YpiYx5Z-Jg(k+-}( zOv`_+ku(40V$T~Ux5M}4Rur;HZ+&@a?rs_3ktUW7a!7P;x-@~Pms@|X$qGtKPdRVB zav;1G=nJ`A7w8LjQGY)Mqi8-ad$q1+kj@u{f~PsNEVG(gp(_~qJja8}KC6$-;RUTX z>wBCZ0%6OnJv5OK9u-gY1y;$0a=ZD)v~$^bG|2%c5HD;)uG}CkP3Sqj@e`6e<|{pz z^e`mlCNQriPh+Hk#+hEn+2)xgsGYLuirlH#yeH>Sn2agAjc8&?!6B`iVn0(+8WdDl zr;+&kJjr8Eg*xy|mN>m2@v zy^cA!UZ}hlAYWSM6sTuO(PBniDQ-v+<-Ts5Q(zTtfE`&{ zGt=YYVKI_9*`Gsx?kZa5AyC#l|Dce{Lljo|C1QHVIvlqe6y^=TP*XzdGfb)wueBkG!?BKHX4- zg4W2xjgJq@Q_ek)_e@eK=ilA-@x$b1$LX#(q#dvUL&M!rX|-mS|4=^Mx3tsiX@EoX z6*n%@_e$S<`4WQ1rPIsbIPDHaKep<5Z+)NK${OA;By1!J z3%eyO5HN82inBjeB%|7-m`oJsC;f8KO-biPY*bv#;B~*{!)`VstTmCqM;#xuXtt{v zL}h(zI3*qVgrsA9^onqQqBe_1BQ$laH*leQF7ZTB0Z`aBs;Q1Io`!`ZWA@Td-o~lPX)}Ov%`-OV<3( zAsQB!B-E0jIhL>EEFVqH_764Obk0c!8lk7889){4M!2T+rv>1Dni8of#?Zeq;7lO4 zNn&^Ab?{u!^ealO|08jmR! zPqLZUx-RJ$!RYGbqrn)J^4^T579r%YGn;qydNY-fX`OjN4+-sL1sj-WJ4o$sZlgHx z`lAA0Y;Op*eYNdo<{MmpXz#wmy@ye!lY>JzQ0P9=Gi zR*MTS3%{Q-4#sR87}eHHXNgVbSoD(`pz$Kf^e>@TyL1^)Xa({ZTYr)e)$j%Rgc#6EY>8^cNX)Pz@dM znSU@Mw0w1-BW=nP9b?WU=@>)%@3paxx*lP9+sLtW9F~>Yi>6Cquy`fiYz_6O()WNF z`E>`6PU=Q(B^e6&Mlo3Htp28GMhWhBdesZGI5y>TnP+C9;D5BdqMazbQ};CuJ9}QV z7mP-aqj~9eM#9jp zHS!|yhz)dgX>Bis6lJZVZ@{bgx`sw}qx7j!wfJ}dhWX;}b)~vnL_Rl+-z=QIMi$wf z>j^~fRB^sGWBgZM$K)Xl5}66vn$w>;ulhu0aY=~lxpzL1NvdDu=Dj4>T{F3E$>z9k zuatg&R6V3=Cz$+xm;RWxf4_O(JX-6Hr$Rf@9wiDd!5PS`?XIx)_b5LuyZ6qo7Z*=N zh6(*ufYPSar$of^Mss{2a#dqe%Pb#NOr)T}wIT;pG!D8D=P@bc2C49m!+#c2rNZD9 zDyyik|9!wzkX9P|^4L&gn;h*#TM(76axd!F9er8UTo)|n&Ck{!9{0V$DfhXs;_(C0 zH*)(uVyYGQ#ap6rY%K%4wOddO=-lngx!ev%RXVK2ejuu0ZrL#PDfUy8!J`l-v<Sm-*(ojO<4{HvoOpE`T>)ElbXbyq;N1T;|_t1%27y4OpmTVk`eJfhJg&f6|N zrK90%KwxrX!x#^1d(5$w2aR}XxGoFsr}rmjapYF++qe2?aQ$Sc`OmyNg$LQ)qsch{ zoxt}@U|ol;h{rZQVx_}}_ccK(bQe$t)}CxB0`8-&Rq&;*RwHxl`om#r+=8dXe|z9f zA0%i@gw3jCf;oD#g36;1enNyTXMF<>?nZCkVIJRTdsVe4{CBU?IqRl}QW2wIstg8_ zOT0AJg=h=xS*`o`jHE>?si_V1_om@H>fd(1T}e9yNx+SR1ckxUcHxq4s{PVy#HC+f zzSK9Q*f=}rS?g^O(;Ug+jIXUUncMu{iEsD)F7T5~aqOB3CwVIRu}1e`rY`7(HSv)2CU^|=P|=y=$$4Wn)6|SUhe9Q*h<5X!;LN-9pfiozN`RB zapwZL`HY$7?n#cS91ZFJ!7y4tS#Y~_;K$eJN^n0)qMiIEl90wn!=jF`G7Aha14|Dz zUv&K>p5Qf?p|uNDYM-j%o6agjcmjJ#Z*XHYt2FQW+MZ*pKH+cg9~)D0)m@;ZiZ;N& z9(03(FF-+ri92rT4xV!E1FBwrW$E-A`-+tg@5w0zQ@OS15>qhge7eS8|IsJr4qSo! zii|}smR9gx1Eoddi4Tc;zAOlOD6QB@FyS2maRZn&xa)P1K=F)T4^vLCaG8(OZ zEbMxQkZS}1tG&bS-8(Vq?>u?+2|_om1^_c56G`mm29b7rTQ44bDL`hRJ;0~V1vDw> zG)PS@lk+55n*_P!>p2AOj8>fH@<(C)IeZX7e|c`YBXggN`q}2kVTjclxZUSlDLUU+ z2kOLOvC6~S^oDmvV>uL+hlNs>!hwXL%(p*C>75iC`b#@Zu%d1z5`WJ@dJ>hhY6#RA zsC#aI>tIBg`ju9WrB`($U;deHv)?VnyLUBJQ5)&UPO3=X=ne+M6OviAP)U`*g_!06 ztgGNVM|F8mK9Lz6(7efDhNSm8S)Os{+FItJss=*l{EvaW;h7aap8{2~`4uS3d9|^X z!F_M`E#eA#m>#chIcAAY0yoDO_w@nF)73g>mGdjSaq3;bYp!nKq|sm7Dp(z-C+^~x z8t=QXZQtO0(gkp@H!+kH1rbO2ypsi9y@PQc12F3w8j58U7LWI=T?!-hM;?+EA>1qk zpH+?{i}6{{4?!0 z@4AH)>R~p3GLL%l;O4bDp#!7fYJqs7eR#8B;byje9XlLjd-)4r!M^(5F2@58Nt;89 z8L>yPFxD{=lA4HuL8_hC+`?RO6~O4bq2ZyQ%R<&sA#MI_lhplxcxB>B>?!RhPmBFmwnLv@)|~R?+bSOd^`^ zu0Y)jM7cJWjtVZCmwIbsvf-tUydqqdNkAKPv5+3DGD)saOiuxak0!Iv)=F3=FXd@(A?M?r8j^rdNbUPp_g zrbd9|iM-08;^+L2%6*W3_J)no3y+Ti(gmfrpf&#GOZ~5)2zCU(INLZCbS)nr!a}8M zsRe{Za71wi9;vrD%W+bi^;D%j2oq`=~d%G*anOnHmfY zrb;2AZlh4C6cGxEGNlX&r|Xs?b&(-sgEWweOqoszNt{ZOS*DXR%RIg7w~wCtzOR3t z&vP^Ev-kdehqcyseZ$M!u!Pwj$5S@~^)9>TD@vP~{|M&$AeaT-Gh@LxaW=vFyX7bt z)$XlY1mE7%&Kg8?1D+IXgsB>67tW^IY6uVVonFQjZIlZl-`f6ePps|fb5g$T9=x0y zH|EI`u^HUx9Y)+uhvd13{9$E}aW@*O`X7A*aRJEK3!0xxU7c$rc|@_UG)RD@s3SSO z#>2HP_u4zsV~=lc{OaFvj3T0wzk@Qj?h+5Q+@Pt%6ZB%VCHMY@botTR*Y3AsO!wIu z9IbXZA?PSrQUA30M{fl7Bd>gs^-`Wj5f_Wp)fQFGz-?uR+=qad9}uJP<$%+tou}Hz z>tRt*L4(>7_>-gPOaL;XLM~0te0yRClnsjrk7D*oR$v@baI58on2lg=(bwNiqk4@a zc}_|%%l7~`B~$2(dKhruT|qJx^2>pU+)=Q$S(!lx?uACbBqi!uliY1YX<)ROHlCb}ccE}$^gS_u6sJ+1!tDg4(E zQjxs?NZfoYd!^HpfolngwhzZDIi*4iYeMirA*#t!efO79X|~SJlD_Z<_z#F}$ba~F zH*dBAT|fjNbW9aHNtXuwdPhpIb*6ymzS%5W55>AKoU%6;xa+oXgk#SbPBl>ChQ z#g+q&cwxg}w>_n+3RSVgvHr_;=y-nuVl8z7K}&1xJ&XfqnnrR3;mT)^xT7L5tZ&~H zspI_mS9`pw;n=gaA2s_{F4!*b!^f!}oCkt07??oZkdU~lZ4eKgAY?uLY&z3!Wc1Gm8|^?Q{O-l5QiNttY_xld{vf z+s?X3k61aUY2K>2l2czFq|U-CsdJ~aR3=Da;>Ps>OQjdXmb1)`dJQHcoLm}xiIC;V zIc8%SnD?|!>#(hc+-O%wPqu9L>T^f6!ubhjtUg7U;Z!|3h)fCo5RI~grdHjsQ5=GsCQTP1|2vqZ>LT$c`9OngQPD4=B^^{Qi z-mzQ1s@iUv&VIvIq@Gj@_h<#j_iC$fp$%)GB2qghd+e)Fy}*lg($^y_8OxK}OPhcE zTCtn#qrJw5QgM3#!a97Yp_3v#OIcuZuzKI7Oe@H1f^vnqgOn7{&oe*ad`Ls~sm9M3 zII{=5X=w2)wioUl{{f8}b3xLGaaKk~h+p42V*XuB0Gm;A+;~hk?(q3QURx^s6d_pX zT&=9E38ftoIso@5BZ2AtR0a9Z-Dj%53I{#30z=(czI!(^h>%cS0_`NIYGg0$ntj`P z&{y)-dbeZ9ilLbBJa)3j+r)NY)_Sx3oeIZ)k>QTY%77K;qpuEWeS+OXiPf-`<^$B1 zB*!6-ReH#O`BXiQ56aBNo>pl5tzOgv+m!u}FxA=YGJ4OIS75`O0lGcMTnCz#C9No_ zeCN~mp2;98DV69o!y1h%(Xu&g4zJsN^weRcP)S>WOD$ke-qjU9B;C6?`GL5<0$=EO ze$AZRFNcZQNM}$PG!MR*(4DE#R%%s1iH9y`#(We%bM~1+-ZyOjVJ`S_y842A^#3Zd zN%FF*EE!utbJz5gBqdG<2cl{C__YGtBzl^TplCdD^zaDuOgC!Yb<*$)`5kpt|t_%ZGBc8U);ERKlRe9L6 zUl;vw^3zsYVM8~>-8x{02_r=WnijdlG7lxf&ix`a7J{VxLCJv2ChZT*bFG59Sbyi% z9Q%ykXF+*Nt)Ez;X)J^Z1W^2Fut18G!1$C0S|*C4N!Q3pZC zW2|JCh8^1=tO-tfp{zHTQLVn$VzjAjla)-H*@qzYCYR03?b)>o(gK_JR2_0DY_@VB z?=7>-!@wj62s)0im;^@YEF1%-DXQZ9>lusggXVCxBeEjV-xZ z@}yJnPu)XagZ4p!e{iMCK^^?H3cB-I)!VrS#oAG^I(5uuKS@Z`j<d8{0AHPM~Nc`K0$qLfL&7!fj0FjNn6@kOs0wXSZk?ZAEsjMv3Ppl5}~SW2DM> zx2&%*S&vC%fit$6?BJrhBT4e^L8Vj-(DYC84y$hb8v5-+9pnBA-$~aa6GQ@XF#>bR zoa4e=P*qbEvceZXk(o8Ns{UyXKH`u+p-P@Tp!w7LnZNnd?rkJn5a}OXveD+E4e3YF zkrBv1A?djbFR@mGE!0~b{_!65n2y{@pd_2O7z#-%JUWk#rhOoCR{OI4N*TjNdvc8p^{RP;(HHcbL7f zdp@zPuI=#0qi+QkIyQ!ZHTv1lIQvo}%4A{Bzjbx>(!yt{AXrjy0OYyb=3j;*D!vOI zx>Z?LmgjoPoX|qvW`Zim^LCLC!Jr43YxlpjRN)>z%S{!#tH7W~-*2S>er1nYVX=t) z(#kUDqZO(p3ahVwshyCFeq~h!rF7C+9AC4U=hA>hHT;v(bdP6IUFBHPAFfwH-`j_3 zkKXuLJKX%sg;OrpM?|u%KqiXmEE%zo00d&!IiFJO4WNpEN1SM{Ic#)JhsC}+L# z^Yw+=@#|O1E9@%*XN{^L@=90VT9D9MFDKWo09cm5!TNX{s!qDf$Q1gZR>Xb`Nzd-| z3MD`*F4c7xMdm?SN|1xl7hLHjeHSW!cw$9T@$Ixzs12xqx;m?%pguMYda@q%9|f{R8evR$koqZU|Yf^lbqY)PgsW z@cI6Jt>`=w2yhc}9r;7<(Y15_p(q2Zb8Byw&&Xm*c68AjcF@hmN}7G7JN#N4j_3=4ttUe;XkY?k`->-a7Vbz&{dh~~gCMBe z5klP}wmJsBts235WpF-ovcy4{nU2&}^le?xiF4+pXQi?%zyQskY*m{@@EbayF|FZp z3pd1# z)#nXIfQfts7#Az8Gm)l|lC4IY6eib2MA=@wd-AXCd)e*3w&54zvl_=wV}28X#k-|_UB?{&mV_#UlIx3+Qm?h5tHC?WC~^{8uT zk;gUnLjuVzRbq+{3Dw~jdJqEZ(8CWZCSMxZ?v2kU=j#PnLC4cQ-p6g7*9t3YVc_7n zhz{9AN+9ywEt@>z>X zW&P~|d;H+c2!(rpGeY&yd@u0@7&efTC0}gp`?`*?$SjcTY-#`8dUFuDe{#q$A$h#0 zjkWaiW|a9HUx1SWstfTH_mg+E0Ayq5*nMCi-s2Z77UdRmmBkW;<*RA&M%APmX^?{K zL&{HkfLGha0bmx0IE}3ZHLj7J4N3NYLZ9R<3O=wSv#cZ<#;L zT<}56K7kcbPjh2EE>Cg`ao>-ds=hov^x*bw5OS$~3q^16{h+T93H%N^gfx3j9v_OG zuVY6A!{D&gLXzSdlo_^Hn?|jI*uzQXm3s1vS#_OOK{2&dy4-Z`%9bnn3io% z*+#`J*i|Df;4y8>l8DKdzcN#g^##5uFF#C|rMRh8Uu!~E>>=4_!gFP4s3~rjdJq7A zLVZ9uHF&=)MYV>`sByQ*Cmnx?r=)-A%(Hq@#w#zbg@3Trb*uNbQUq60x@jp-7R_UT zCg+W#HtJq-y+z|c&bs3Ut82|qlZgXWSM+Fs)@yR8j9W(UYzxTN#z>Y{c-7cleu9Hf zDSNdgU_0{qE>ZeFpq2j4;LQ=F2>6kZ$jSfn7=>!6Y(94H!Jqn{Y?<6(=44XROZkq} zYO8{YqHo7w&(yeRli3-x)sI)<(~`EDNGb3YdAI_64upS==YMu}D^F7w#LLi>E|t^O z`QvQ-ft3j+s{kQOJ>QtHoOOUKhD4?!Tkcgfp~Nfp8rPhBI*rq}oVmbk5vEwj-Pu8| zIoTCeC{76`Q!GT?Ad?gX29Z9SHo10~Bj$7Am6VT%hCz*6C9yqPm-Hl7$tIJXz#8 z9B2dm(1ZOniiz|BfibR%vu( zFh~uIm5VM6{vth8%^m$=T&kSN_I?8<0CLW(y7a#wrFa?BQr_MWneM>Yq^HCm(ru&V z_l-SAG36di-mjm;NCx!~86Rxu%#0_K6D>=Yb^i@3Ffy_=8??_Z=$AOPW|j&e=u!vW z5)xN0`ZWkxs<8aB0{460E3fhv;{uugVA6}Gt_wEB_W*lvU8Zm8bnYcPBX^^R(#!Q3 zE2XYiHyUQCq7Qk4QK@Bq5{jgeHf`n#`dmLMtFLckrGqeVA32xgmGhioOcY;GA@FYE zU&gIaThw#0rnYBMhl@$>tx%w(oV3z?mw*7jJ7KsZxI###BF8!qRDX#V%BltAHK!=v z&jbM%sTUaEa)89Yw|EC$}+)$2Y z1u$d5CmTmvaN&AQR^*oGh~VXbf0l0bDtM*b#uR*ZUaP#n#QB_u*Ym2oNX`TN54b7D z3TrvQwJ=IDu=T+1zwEXxHkJCzO z;`oTE`?c&e>2IrzPCF=m4N8*5qkLdl8TB7>!I4}Mt=cv8ieD#2`H+prmi`Pqc+})} zARD---+`6KXK<6QR&h>(XVF1Uh6K9?O=6b^6qPece!ZW~vZHE*rd>RJj&LEC_Jhd> z?`QKIqN4ZO5Bh!nlXa<{#-CqsFix|_QdktUZR* ze*hQEdl92dMprQ;j`9TnxM=2R=Z~cXn1S94Z+qdj%PydoVv%a0vns3QWF*ETOxv97 zW!lCf??8!fieVK$wj+IcLs0}LSjz!-R8D+n#WV;CcJp;AJURkt=}7j7W{m)USDp{;2+ZQxr1p%Eb+we9iCtIpsXe$$V5AE zWrrX(*c9zYO;o-@S!Vbc^!=b;G0hW@pihPE=9IO8sEYs<6uI!ep*WP6;>d(zCpksJNC!Ok6-l7-gCcO>N;JrH7t5@WF0V$JgaB{GLMCJ zATLu*RaN72sbbsjaS+7esHnY-i$tHHr{lnfl*(gS?MjJXdC19S=f9@C~83(NDPRtC_yGTN>t?3f$t^NF4&ptj)y{Y zFoaE|3Zr7gidiwr$gdF~u0hK0)hie&Qd<6!W{16hni2795{rzaz3<-t!IGTWJmb_HhrfseZ~J+#Vu zFTa#@bSDIh>&)mPIp(ru#K6{u{37-P=s#PJsO1swLwc_s#0^-B1d)(hH!)YE#aPs} zbf|mkbE1*W6nu{x)_DW|Lb-?_?n-QyR(y#|hA zwOi@h{SDF;-qb)T_Z!FKXSmexDHUx&BSzl=<*DsmH3=X5+>@NKBlL1sl`u|d-9uS^;-Wtw?W6#h3CU*y#+;$g@1NjyZURR z>F_w$?GO{It&cy|U2e7R3O+x1Oz()T$xOP)>AG^)KtmSu~qyVHwNRg+sWi zWS3hsOnzH_;<}hG{0n)WyGlxFwHk~#`7ES(ZQdn4$3|?u1=@4pR4vlf*AIqXC?<9D&br)or^Y+ReJ4-24E(VqKN&7u0|=_^jWp;lZ6ZpQK48YxIs zn_K7v&jM4@5O^X+(Q1qhI6&m6ue)TwZ}Xf|{lK_^%Lg}gjoi@+vaEdDym@!vi%QgE zOddhV(E_p+;!0J47di8Oa2@ZATd*C2K)Xth)}NU{x!8J6JkN5=gj0l(zW%45SmjJ9 z+E``E7;eO*e3li<^lhK80@@gIk76^13lX?*BC8VR6%2OF9Q#WzmZ(XrM?B4Xvq-Q| zv@JbqI%cjH_`djanl?*?mvM1%LDL+wvMJ2s z_DA5#9iC8&1@H?vTPO};4$_SGNurmKx5N_*dn@hzmj|&zY1Qhs!3~H|21h5ojgFBE zGvkgw^|LiPQz z;c2Gaw_cU0M%dN@F?edXw18-CN;zWdmiwDnjmvT!J`%0r4hz_7%&9{*gyM0r944W; zr=$qv+Wpza1m|1o5x@RvlwuHGJiC>;w&L&=%-CUHpuibMc<4_qj$jg4e!0UIt}}WT z@G82eD)Xs!Xm7{09hIFfG=4;_D;V?`PEUfrV1VafJTf`5cKCzL;q8&|3-KRxblct- zX4Omnu!9KRz@%4fJAM7<*A@)@5${c*P_!vQfsQYft@|S5VfzIoInkr62?|&HbGp*5 z=m*jQzm5t#lCD~$yt^#G`SrH1c+V)=+}pd$E;{6hrdQ%lfCfV_c@67MZ#tB(JK59Z zE2#wsjnvhiJE`=o-k5_Th{H!$C^e5RCMSR@8}K})Rpm5LXWnTCAJdLG8@S7q#05Z< z7JJ6e`hxFaSWk`YKP>5ks4msH;QeuG;m{xK$k?{cYUazdKDF~@z|re*lCpu=b~=PG zu3VYA*Pl7Q0^4PoN{*RLDJCx7Mr~A0hNN}T>(@K+LPt7%>bQUbM@93IT3rp7y4OFI zyPA8NWH|Zd!^vX{-}&6P#5X1>1!vcSF}?i}dhol?l&2%Izggo=J_6JBTHywEMPoW@ z{jeV%-zJlo3KlqyTi7dhFWz*mkvwU~@1S_>2F%tY^CuoUWum?}^KQ;hRz@%m=SfIu zJNKBXZ7r{CyBZl2h4>t{W%a3;e1Y~&(Ha|Tg6PhYI-wJ7m6TbFt_!1B7MA0XMUcO) zRQ0Jhe4CyV>)N-KbXkvL3gAL&qa8=Sym zMO*Jz!L-nh@(*E~2YFLl=7y{9r7tvQ)T#7cw4|Fw?=mUvu;V;-|HkpGaUHgA@;O)x z{rz4b`>&Rd;aEBQe1WTCc^Q1SJX~;|yFd|w?l@$n zjp;Cl3Fv{ij8dwrti;odIccS%j|Z1s4%0eC@46hLo5RC95lH+m^QeBUCRl6}+0s`% ze9O7OB5vrry075yvvl?B+_~iD&35hmm7(s{1Ap|?vLN$}tRa{?DIE#%*CF8q&G{1Y zUEQluRFL$Fn-qYzORZ^(8IH(OE9be5BR*D6J_q5Mgqey1yCFWrNIqVilh0K4ycz7M z-8>Z$xs*&?oVFTUcIA)6;wY@twwuo9koH>fCfUS|WcyO2<}YruRWG9y#86&TzI{(#ru5u^ZT{Du3AGh46RYG~KKRY-!*>R?7GmrY+8@Y|gUlcTqFT2A}bEZDVm*>jPp$`F8Q&9 z!5*%`U=}XTHwcMpr;g-x_M1L+2raz1%o?-MEkN`Y zX)Y0E{RJ;h)K93<0o?2y_~E`GJt!>fSbz`+*)}cm<0U!fSs1&%&CiGAJsX;;k#!mk zvo{wOAKqXOKuO0rUk#Pexkwqe{BuX^MBbx{bg&;qP%;7upj8Ohc z;VoMjWP}_4&M0syrIB>$K*_$>pJLjMKb|wh*VMDQo&V8>K_4r^{0#8MduaZv(n^5d zeWs$UTgJ;^mT^-mBK4wao1N!8cDskmSa5ArPHY=d{9J>|?a(1jm=MKQRQ`)2#GJ`I z?NF+f*0&vX_x+ajSML&uI=^ck-`bpMj_O=P3p( znGR18QTM%G3}|uac26&YnD&(99P2#)tSTB=;>kPIE*aopB%f#O0`ueP%oAs=5|&-^ z3z?#>Gz3D4MK7MEOKQbevJyR;N6RmXN)Vqq*9Q5VsA7a2)FhXVt$v8s){46b>OrJc982C4`0 znobbgKK;tf?eepiU%iVvgEJtsT`ou=jf_XJdG|FOP8}7)fQxplXIyB*9IS`=IU&*G(;noV023d!9aH!5yVlW> zpHgkc^u%jTLH}5I_I*v_*#HbdT#{T{QD4A8UV#tOwqP>a+Ny?0^kB=SUlX#oLH@;& zzN#65aP27af6Y|FwwLO0>}yfOay7i-?Q;$hOx3I_RRd-e>Raa0qX#Ku&S?Xw6T7<2 zOku(UF`y7T@~j%^yWig~+#CHazQP{iJ^tNasUu>jK8IwC#-l9^<4{ZOjaCm1eOia- zk1u96%tSR36VUY>3g(oro9~e!6>IysOakNal7qxBO?EG8#7)K8YqK@fH9iGhpB+92 zBRtN%EPrJ~rr^Uj8Nk`)bjHN#V_n+z(Kp^?0J1-+glkf^6<}eVOqj%R-Vf@iC4W@G zG5)He1>fzfi2_>5kqsLTebKlo(LEwaE~ov7fpH*dGC!xLln1G^Geo-Am0qpf!jQZr z%&H3@FP_;CILlym+1QR~3I^o2hD&8}6?#w6IH=U)%L(P8XHun&%HdGR0>quvHrmA z^W+UrbMrEKZdcZZeQ94>o+KN)qTTlNFBoz>tn@C&?};O0c6>|Y#_C@4#%VGtUYHHS{Co-Ix9!XXTB zxt`t0%c^CF7z=P4s29ImLN3U`s6x2+Yo^5-_-C+|otVSJbbZ#VzFzhH+-b0Wx*O$q zPiZ_cN)dcwC@)JNr?m{cQH0-)f~Jcq?krKpqj!BesiRnNaipMWUiAQ1jUS0+jVClS zM*`5cp7C@h`^%JH!lgQ>3B^wVY)3*4L$5;qc*CBO63q~0dtn6POx*V}!JJ}lWvHoC zycJrSRMuonr?J1(pV~qlM?Zgab7pC<7URZkR=p=uwyn|CWLvn}{cyH9;eqa@{tu;5 z%zMoVk2dj-_xD~vKdn?ZQI`r&=#FbfKW#lNt2G#E710r)gJdgc3fjKpq9@_h>F+MN z;TL!{ZJ(Ot2FvV?;dC<0C_}@e%5KlMgd(2!(=(iSoP}tI@BtVznx02FU7B1$a_YiO zw%ijd8@8aY0ZHUtdTb$Wi>KKViNp)@F(%Y(71!}o0?d9Zes}xUmO~6_#(0XX5RJ6&vx^XxKZOYI;SiJ>Iv@ zIf1sv-`a4)TGfRZCmHgjhke8uL|b?qKN9JL)rG>@RN1+n4joJxr>wJUjtnv>EV#Xv zGBU}!AjLAx!qz<)avc4O2rqW9!socpI$&yK)~X` zjU@6B<^XT^=T`8Jc-KfoQHpj7#*bHf89i|ekyD^ePJ>D0!xd*LD+yB-wq=%|w#BZTd(x02 zcoK3;rRQJ1L;E{_4zaw|-U-wdsW|ERL4BvtnUhmoIqB>^xDvkHAj?8eQmZ|REBstS zRsqj(7qf4qqF0Xl^HRwxn|c9B-y`IeZs790n+n`jl6h) z9Q2boj46rQ^yKpTX0_=KJnU5BRXiL^KONORDpK@`%w{} zAIXQ{bd;Z|8*EaD^h4}jJdwKel+w#jdmhQ@^39*NCgvVPJ9B608)~(jtrrQk9Ns&r5gjF3TwZ?v_&hUh3`6#_Ch-Vo zPV}?cr@9Zgi-*0t)bb{^9@|qBnUjkFWI)w}A$(r^@c)bA> zLajtCwpAB@=P{w4tuU2UIOt)NHe93Zt?JrwrEVFF> zw2yn0x$*YsY+YD@0pyW8#V?8eLZVMfV(1e3LRC%8AU4bN`~u4 z=ppWT&1;qG+@#a4PenEYc!0XL#3Q4@*z)YNs#9YG194q=thfopT`57b)@qf|4(O6 zpXpwHU9e|-w00&EuY(At(iT)!2mXv)mw9J)Slma4C8O@uj{&!S>au&dfeO>LugeK7 z+}mFJLJ7dK{mwzFbyQ7CcC9Ve{axp!z5oLbB1<=@b%0Boe>IZ^psuj{inS*KajUxMlvF(M2DO*)v{mo;VgZEFVYG>kX1UTW8;fDEE4h%Wp z`EuVS@^r*VJ^GLcQ@khA;)88rQrg93T#V`DmM=4;iH_!znFxz8k@ zZ1DMcv3fT_%`rehF}>+FwV%YvWcBHDr{?cJxWZ6^rW6{U|0<+-8EcY%zlM$Jm4_b) zL*H@7#k)NAf+nrw!$nS%^baJ!$v*WbpU{AYFn5{r*>r`_P~iiU?xQs1kul974GdnE zDO}PB2!<$wT08wP{x^tEi;ME=QQv#0f*8)kA#h6-yY87og{PiB8Weh#D%(#SO!GyO zHeEI66xr3!Hs*#%+V-dyXh&T4`YX)PO#>jM%Li4`LP^)(ZbWNW_v?#I$&ABjkr^j? zQFdofYqd($6gk5b9SZJj4SmFKKATP`uRc#`Py&TNMkFxhEWTQzz3ZJ>HSo#nt= z^Ju)4X@7pA@jeX}@hIK{qen6&Zr}RFbDFyuU3ZzfpUy53a!CdLe!-i@<`~wPvA|5i zaoMS7n*K-5tz*)(>w=T{kupBbB-!;F4aBtPZlmia&GNDBikd()3^yQ$FShR<-+i5b z@WH^Ku6x5mW?pyu@T?&3>DvQ}OX;cgxa0Bl0qSXkXJA9cLKl6N{ru~~^e51UWV|FU z9SpulX&J9Zr#JBa2Gt-Bq_N-6?fh4(n32NU-w9n%R5} z->^a_)$lw;wWhFJTRKJsAQfGNdhT2feZ%@X#&k+qz#JL8PHV-hMG5$^{h#~Wa8&?5 zV5xxd^oMe@mt#9esL-Z^5Tv$}5mY-z^Keu*?eS$#`Qkgqk0T=^r}D+4KAI?iu(Roe zm-N^gAglIzvlVUKqU%Q$cjzDb)MZ=uv!1Kr7>B%aFW!AQ@1m%9J9+aDigk9qmN>HSB-J3*tDt4qNg8B01R_(@wCasdANOh z!uhwosq4sfRF{dasF~ai-$6IKE@24ocKDpc=h_;KxZ@>1cI)mgECWC_+QUESVxf}$ zGELJ9g~Y8QA73gQBl(8LN6JgXc3CxP=Bv81W^y&SsL0eX_^5SDe3uy>NgY-d{eb8L z17{KFi2V2k1`IS%jH${PZupEJ3;b$C4^5wZrj{FWrOT=4uGGMuU>@aX8_zayJZqbF z0I!ja4%P`&#bF~A(`{Z>`>gfx0_zyoXZFM<_q3Qyv@3}f*VTQ=9;>9pQ(MZ<5%1-D zsc2L<_$alC#zESMKD|LX+kFy9L*;9MnnU4nNx7M@d#BbtT{Ww+j?{4eL@HXm^4>!! zH02(6!r-!|h?W$h13TS!t#>QZ@`)>?8`!B6TOJ-N&3Y)rY4AQfZ!#eHiK0FWp$gB* z4z(dssoMQEmrgZ@5~&-G0lBwJ|B%ZBo7?qkD_f!%90NKhg!qx#IfyU&%0d3c4_%l} zh2Sp&lSY?yz&X`D@ID#(3A3&?qFuvyh$jG6D~-Fn>AR3z{0^@bqwS2BNtn4nsBG06 zT;h)K>#@X!wTcYzVg0&YgQTuc)ja5%@%ozT;3>!bWUU>*(1UIP^F{wlk^LbqgJJ{N z42%w;vz^7m$Td7VdAj%2WT&&~e*OzQt_`Gd?r`K0rwj&vRnBr77{dsq*$zS(IwQfE zow(ohoYPqQZx9#23#Qfwjn)MTavyb!z#6eD5)}-A&M9&sKnq63W6)UaI{~TVD@Do@ zCU8dL1Pz}iq)zP5O*_^ryGT)v2&_Tz zr(jh3*jJ96YcY$^9DUbL2Ranp)yFB8Ha3m2vo}9NWTM<1*J55ySR)U{47;f4TAm@XXHj%rpRcC&rtKh9b}jmC*4sw z4DbY9%Rfs)Wsl@jitjmQg#+h*r(t?s*>O@#+jo-MifQX+(xE=Thrrh^L(5b)gu$* zzDw6r>E_v`mz}vkoUHIm>X^elZOfY_;2_7W8X1jCKmJ*K~im5|lJy~!y`}T9v_zv)L zVKl5f9O7Dh=`6hAbG-Zd_GI?IJ;J<FZA}X>?V(IbK`qzJj~^!;?ffhc!$B3cT!1Gi;#?ydq)ip&DI=-|dzS|Tlg2K6@nmQ{ zyrV6d-P_o53il4u8A7S^P>Y{b)Hd^~6RR6_L&H&kDq%@!$x_zuoNTBeF(4CxJ;@7( z9!(9dlSUX`zBDT4&yL(hCcmY@4qv_UAnIa0V$6G>B#=iO3)@A^>oi+x`cr-ht@n5a zNnwM_o1QF#vH8(Zj>c49w63n~{Ic=N5GR**J)h3p+U$1RIm|4R)C6hPe^PNPwGUKQ zW33yxYyU|O)}gcUblHk)e-Dt#IW0q1EL|)7$R>MLnP{snI=>-%l2R(|q$)>`#pA-@ zG7CEht;VhVYOm}9d!6FG02Qk);R9uK`t>|KcN)lwoGWTxWQFeOp(Z!n?6CfL&EP^6rSXcj0j{W`OKZR&G%30Au!VdA}ycNIJP{z7+KY z7@J_v6BHpM*&xf@t%?}dFxx>bb>`jAK0eN5)CX7SFV;qM9X67~1O78>-rri*8$ay9 z^Tpg8K&=>5&~p9~3F!9IXThO5<08uYplTMwT1{0Wt9%O$Bk|jMD)4?V#@KvgAz|VG z3cpb;cuh5IkgaD}byX`;H8F64>C(J_*G~r&MoZ>$>a&ulFV?#0)&CNnf@966(sVu4S~=Y|BXl@9+M{0oy;0E0`Ko}T zZIu6HR*$=(UUO1%dCc*744+1Tl*GAKuNnft3u=&aV~TRm^&8ENL{&`DWs9S^@V-1V z2dP4zQF0h|rzKm{G1+?KS^}{?{|A2AkwXulam46-_6M%rZQe4N*7wXZH7I<+S} zYfZ<9a1iimzpaY+<{rQrivoUbg@#ie;b|30nxS*Er2 z0f)R%6t9jn)ea=(9J^wl1P@bD3VStHxht3>h7j_}?(8N5+pZU^{=5~QYaodBc|(TF zPbA8U*vL@Qr~B0c*^?U0YNGro#Eo`SHQ6b9Cy$XlTN(ndUjYLyM(V4EOi{5;ck@$Y+_-zoi!V>Tgemm!c+8njEI6-n@*p#?%sh*J?ekb) zL!cpFn{t z>>J2e3E6rc$`~VI&S{2Od}EP8vdQP`&X{bQEe=r~Zl7%N>1d}pd0(4b{u)}3_w6qd zVa@T<5CYD60O~*zYX<#R!jFoZ^K^^Jkf>j^TZi2ap12}anc5PC#>gPRVimO?_HZkD zYskuL2Yww@cRY6vd=m%(N>OlN&^f()26ci7;;Bddx)+sp?)({9;rddPF1G^+dDe#m zb234Fude(9veIK}vSRU5*bVlP6_Z@s*G3m*N*7Ktva%Teqnq3kpkkEb zy2$ugd$-DKuUvLg4icmbo+Of{Fo?s#)Ujb_&{}=*yH_w+=KWw$s;YIs-J1eNCB&8^ zb!hdj0}*|vrT{&Mz2R!NrjI?M-#nu~Jcu*&Ku0c?uDHp05M||X4^V~%nB)2%MX|5O zrFaLZ6!2%7*UTC*#NJTv$^W{MSX|v3hq^46?C@EK4ICiL`0K zZ@#Iz|KC};VYrPG(!{`ez~qbJxcW>KvoKIX@yl4$H&k@Mt)KWu0atr_2=EH2GoNO@ zT569hEAZEFIyTiH%a;G7nIG!IbUfq^c^~e$+hj-+_TtmjleP27ZEHId7`H(o^=eb9 ztFE|Np1nD>5XzY4C=j-=Ikd<%k^7HIUj0D)GiU>j-OWnKd6qe$^N!02Z*CD%`q4=& z{9R^bbQC&T;JM7d0ax+4tKo?<>VLI%xV!!Oj$}l~kyXQ#@~UMO>kO? z>E^!WrH140vEt#VeZ5?m==6m*E~DE5MNh4>b&p?-ZnKsP^>K*s1a$<50c$)mHj7c6 z?>>Hup3Pg2X1idOuMR-3b%IlsEq?RnCRH{br^fOZ=P%Cv0o|y7u;p?`-oq#`m*q&D zq-ozO(WH|p9KP~)+emUC7J?cfdf4gmP|UlEvn{RNba97jOP-RDgNu2xVkQT^N1$zz z+1t_*UqQG3q(TEjh~afvi_Cfma~2n?20)7r)+jO!+E2=Exvmcy8Vtvi=1LKJ#_t6X zVhJQRNmy?jlhb4j#GYLt5C#3_!GscmXW;XK&qrQE$#*Iwq(aiSebbPprdn_xnYW`{ z=YsD@?Ett~Gi6S%>!#AoUhmgEnN{6DW)$JEu4%nuL3J%wzWMUW+ z$bLlLrH~2rCFD{P_^CIvF3SEWDt^f74dfaf%-YGaJow8Takn$6 z%btY(Gr}ntB?WR}!z+i*kuT>chOJh-RF@_!ny5JZi%wlH7nQr5G+b$Dow2A#pLj1` zo8cNLIR!QZSn^=($N0k!w_`e&y*{0cBp5=6*u>!YzDAXgrRg90%~G;Wb+kUg$^>gD z0iqDUN#O?|jC@vLCir>MK*mSEpPnbYTy_>Lk0|EmVm>bRa{>)Pn4+<`{QG}iHMbk% zwmYRH`tI8+q6pW~&&^z_Z-|?OH)3nhtiPt_3vg=~1*?5OH@B>ZKYJiX6%@DMamKlc zjD3_3R2|mU+rr(iBt4!PRPl-SH&Ku#@eAfPu&&-8MLO&QSC?swa#0Qy$b)jMnA{H> zo~-T%{uWq(*GF7$Qs5;GInT3c}kQ`U2p?!2nf)TVM*Pv?djQ(nY$ zLbGE5^BO8~w65_J!^h?mrFn?*gq3=aWIB7YR(7JE-}NC99L6&N6Q4{Vb@)0??oqMh z)Zx4a(WVi=9G-sb?D_nsf1suLqsI}ZyOi|ESY=6Fw7Ph8*2+tyy{G!6iXvzG5LWSi z+rHO|Yuwb9Qj~6sTh0aJVOaGAc)A=QCf5MoR*K!Qw0GGF%e9mPHoX?uI2k(GGkMad z!F1@NLJoVi@;{BMHJv_)`}SVgd%-mA)!?T77Va%`uPDFDz2PSjT4MXzYrHiIt^eDG z(O~D9W`7awQh9K23ae^m%F&}HZzqSmCNrV$$?U4Xzh!RSPc`44^;-r9*`tCJ*E63e z&TiIVb?c0%jSP6@cs=#Xkr-+m9UNl2=M2579UtZ!tvSzMBdN=`?0C;WeTMtEAt`j; z`znduiZq>-x9jz@%Dz+S?s)6hM8@mb?d{I`=_9RsqK8*yUcizDVJHunl7BB58`Wio zsG#Ea@shuYL*w!-@6%4=BQ!cW0pOBs@TD5IRM&PEK^`V`-FDLhFNAf`PR&q1Kc|ib zW8RMwVgr9vOuiaD_{?Bh?gLq;;ilZN!{E$O8Km@UHs?;(Px|1)7fjS$&vHv!;^dSX zeIS>}e>Zt8t%v38flhr#RxYb+6szaH?pyGvsO2V2E*v>R;>k$|98(cUiZy_|DwXAEDhh0jAXuS_0O2?!*>r;>%Qa7qSarY2Yx3mUbD+idq$#QfPNK2pnZ#` zBUiNQm{=@dhE}i75SK=!|B=~u3gfXs>}_H2dSV$0(buBciOoX}FuzYFLSdg9$PX)P zOXdXeOkUvSrp(Sj_Gd{~hy-OI9S^Q=S6LS%M?i{jP(6G0ivO6JlC`0yWDx}e%1^a5 zrI*n0Myk#1IjK+cP~2;IOwu-J`m#bgCUrO|ADa&ZKTi|HEm zT%q@-Z`|kF47G>A)yO;ylyW8FvCq!SWkZ9uomLz=z#pB?a0H=5K6bW*>rz91giG(x ze_EPO@;p6n*HUmYW`T*}>cBh{ua3d}g!97>w_+7Lzru^!xUh!Mgy@}f z@>=m!Cm>s0PYZ3~fYqQS$~v{PW(BK|Hk-4hhfLF~j$Qq&1)wXVb%ntF?_yvq^{4-- z0sj549cydq^?ma^o4p!UAxZV99v!?v9%4!aMHOTjH`xj%$h~1}2;q1Re<~@d^!T*f z*Yn237R}B=MXUtMN;mVM7hG?> zajti$Y~> zO+t9ec2?)cgIxVhj0ep}-PP8L&L&SQ%>m1xLWS$mah_t86leb7uDzC0GDW9fv~{b* zVGXUh-F8ChPl!f`Xqxnl-0k+zg%20C`JQFvhi13p|3uSrJF1VDas9_~hj1a2x}b4^cp^ z;kwZmg6GPVQ?VN44wt+o$TDvitQb<}IuOcH&gdC&oOlZS+b53O^!b5FG+ULW8Cvyq z9RcJUW{^gK2{rUlV1K9p(#+44t)kQ|@?HgtihmVxhI5#ZW+HjtwxGkmX-URb8bA5I znE}W7wDo`(z2F~9L|QQ3A_5l14orL$Nm&uNYDff^2APt?qA1f@w5OTUbU~M}RqRNM zTjfj3PYCQb$o{j0HdKq+!L`lg&+?dPp*@hO1)|rDBp@WHE;{k<+vv+ z(D(fU>=4GeXHTIMA*#x-E9HKk4qi~197I_Z`6}32@8+(#O77<2wbfp1vRVKiLtH36 z<`r3@g3UM3-e3&5_*1Vhf$<|ub?Xu-YA*V7=hRF(RB!+gYTZeD7o#1^-TAH(fhcsC z7$kYWf}rfOp1i#lZvGd&&_;sh<>QbrcpSx^_*-W0l1^JVdzQdAZ?@8G9%fkh<5f^c z+5Xk9p4*c)*@}%4kUM!Utjh90^k!~EKje$kAxIce;d+3^km7xjoK6}ERgIgZSeZ>R z?Z4L71|YV%ynqI-82U1l^zRo=3G#I;+=BC`Zx-|6b6+cJ3_@XGY?#ClG_*)Q|Nie) z`aK;0@zE5!j+3w#vJN$#IY58oPN<7ty^`HAL+jK0r>`pRsal;AiK-aloCBdk5QwGY zw|=%LXVAY^aq|1~EYDFBygrW~$JS%PDI$q9B%~X1F%)5Ot|OV2t(g@N=q(MNf7hzS zHQknR4D{YRfa|k%YVg9DFB(L3Q6q)dij3m@-=KrL_O@AYK;B zTlj#`w)}G}*?vdzd0-AQqKT*n_MOdM`M!15U-1HX!s(~te|m+fr)MVDA|4Vry1NTq zS5X?;GHBKgX$xtP4k&C3;r_eqLg`4-iAX{klTE5v8~&s=nj`TCMY-z#1+-AFP`7&$ z*%j?a*ESJ9L`3H~;BGpjoGJu#Wp@X5xJyKXJu&}A;nPpTsdab+tBWVwy22~sW0N^JLCEcsm>@;viF!HQk~-c`r5gN zD@SL)c#$Qow}8CUx9Z?X;(-2vX!^J#R{WbLMJDrAb9wWHKQr;pCp;HdD8ctEZl?ODf@H3Lz+h zgJ0eEIQDgHc>VWAk)@r%PQdoF(ZEF$Y4<$kRlX?cKm?Wy@+98pBj7wSsusk3YWJ)_ z)*dv>e%{?n6Pq{()F4=gV0CSht)K@}_Z&moWnQCC^m%+-kb=eWvOB0BU+aEg-;-Ke z&p_?n_pEAT{+SqmoN{`%A)EKEkc}iD<{qtzx7xi)D-hM*7U03@hY#7e5Cc@?w)Bg5 zp@4M7=coL_P1Y?V^hvgWHGvU{Z8jD573>iFEGNJSBq{ zkK{NqdS&C@Kk`J~ZA1r8^&V(zqUr$Nux#}yQjDsLmR`M9IG_>ZcSUl>6d3n5>9<_E zt?$%HNR}P#X#s3nM=hD4Q|-7W(tRITUQTsIbrP zs$_x$CIkkE41ka{HTP(qv$l>kvh#NtO@|mTDWpt6jioLOI6Wo&cpr!z>1%LUcm6lrnDm_N3GUy@5>AR$l46FqE3N?AENUrdvG=_Vv+#)d@rVT?KN5W7OV$-77x%x2>lz2cZX%N|6wiM(J!i0* zYA_+H+26BhTUFJ`#&k+Y?`iT=jvgnh3*)_VPzq(0MIYPk! zO!cigv%NHutq}9HhAa2Y_wMqmgVo*Z#z6AigDf8zM}lTuWv|`$FrR=1rJBsp;0qwq4`|V>p zjfqB|Si4Bux@!m=-~r=`vQoyHa~eI<&Bg5>rYIMEcC4w|yZ71ofBz3vUmi&1_Pzh2 z=$2@Zl&K^XMJ1H6Ta-*mDajO)h~%25(?m)X86whP=oS?r^C=`#D#?@~q=b$kQ>Ndu zkGh}l@6YZ%$Jy_G_g?E+&wAEcFGhC`hE<<_Ks`tP^$0cJ?C`~ zPHMLYmS{etXkX7vb)Wa1a77ep^iWxvKc)$x)NyU2h%;w?nxX{o{8W}$z+BcNDn5Ck z6BCY&E5bKOZLBDd*-GwPoO-CX_Kz%1))8Z121@UGVj#M{57}ANzkNg7LEd1XWz5o= zyUA-^FcKv~F6rI2;63*&2HryMjRK%^@fK&w4@WczXwRYOtwtusktHRl{w)txK!3EQ z_yM(roZK@v-nV`0Yi=RpS%ObLwfJ6dijl@bGMa|cG7FGSjM}W^ofIn*KHYMb30@|1 zLF@&W;v?IF`2^p?lu>z)(s;sb9_^amZh5eE$Szr$yvh6ByGR$(~GC*;@Bsfm2= z>7V+F_tI9)yPvKI#!u$Fe zFV!16bLWsziylD%y**r3Z;Te#gce9c8I3-*x5|JwK_J`l_p~!*ulIEbg2`vM~*q! zMv9{Ngb0La4|eJA%ya_-5RMikrMvxzu{|lKg9d}DxFb05-Hdz~Mw#;%c_XR=AXc8K znET#-^PH9L|0)E38AMx}dz-9e@DYZ}}m9PCiBm?dAt zE0!#Bz8dA=p6Aw}(mHtTj+7RVfBx98lG!<$?Gt<<{iTZ!3e#%*E7EQ#2od1M zJVwvs@^@$5RxvFbo$z9wLz7#vJbsGgi70F6j3$~*_(!SaK~OpGIuBH zjFYPfE}C9duvZ%H%!ls%8I5^M}$NEY#zsmoM+;8JX0* zNtUVxKz{0W2`zLt19pUUjLsSs;~uxYl>M*MF01baa9|$|TOMI{&t;OF(&u6J@6o^6 zp|H8$i=>R`VMan+CZkvE@k_LvDD7TlgXN0@@A{WbWhF0fF|<61a>R&++&dp#a6S@U zUvXPEkfXX|ZYwuh{1Lor{!t-#jm3$f5=#NUI$c1*GJ)Mzj5hARpa-{N1vI1UV<3=r z-zIN{QK2x-8rD~jYh`AV#2M4pc>hdteRY7{YvQHp+O}>LGrwz&tv_%)W8}BTb5i}= z*Onb7RC==1JduGs)FWe^$@#Ledq{_d@a$B{0yD;t-IKEj?)Dlr#>VX%J-+}El|Tq{ zi$5QM_LQ~)J>s9I5;GTP6KXA>!AjLX$*#R_=!J+WZD4Fi>c(nvrPw(`T97orpY0oA zUvdGe0NM)Y(P2Xe$AS|!2R@#xu0XpG>|%L;zh0PKJWS4WA>#@p0}OdC-hYrk6(Qmp zaGI=7`hk=du{gW#o(Mi0?ar%|P;#KRWgq{nl!vF(GECa{T>QG!3bS?ibb7@m#eVC} zD}Y_M%291Dm;$&RUh>s}VD8o!?>Nlq^tku#y!Yhk2eJA$0dnkqewC$pDym>SR$`ii zpPo`RE=1+n^pq(!557a{^2)UQ8iFy}0@}xRNU6ke6|qk+v&Z6lLZ6m>{Z=4+nH0}O zE%x@>g3L>OE0-f_SCA0oY$MrIP<#Vf+)D5F1=)`7^MOWm* z)b+Il0t#{3DAV)cUpr15IuI$kblrTfn1@*D&h*;Qt10NDUH<1@P?TkwRQOOjrpV&T z?(v)9#&z8CZSrS*r}>4H*kD;>dvn&f^?{b?cS;sDe6)LHgwS4N{9g)3j2mlCJX0@j z({jTPwp}b4IM1h4AhzS}qp9(&^)CaJ58##~?GWJmj&dyUn>tr0r%*?0jhDdKjn1}$;KpigHNS@m7geY}Vy4nDV z>aTT2>%wK8Jul^TdBtLW0DTV~lNT0ww(c{II5r}~T8BAFRGx}O{iESuziuBE%wYpC zmvsDS1xtskA*<6l3054<%>G4_SQSt75hacm781nd_r9XqY$YXc7^2GWqbt<3Fw5@D zvz}i}YOrqlh*u;P-{P)#RlFi?7m9X|d(;h!&RYqQ z+l|DfVKv{pRhJOAhMn$zDNuS{B5m6pso+xu^Vq3MG3L;NxR0eik4DnF2IZg3 zuypyHg-#}3(&A|MAR9|;{VEX=#n@EY=#j)JzZqZY+p0c#p8fGr{m#(D-wuW+gX!^U zjgl4bzrh8g83V^WxziM%-jdQaVKqy=RUb_)%+TB{H-1d~a&&u6UOm?6UbS*zjI=~Y zeb-6>C@o(~gvK_!0iNzX0z#L5bCi}XR^7@8D|Ul6xd}qLz_$E+X(t2_e_}z zC5HtBcx6xj+=0U&bJ;4FX;t#hgq5AYRPUuCsJ_tYyLTADSo@X|=c~7O(TADImA&nh zjPJiv3lQeYTW!;wN)kVu?^Ee?^sk*_P2{|}#(llQ00<6O_APz7Z8aAqqxh&LdZ@c2 z{FC1Va`05t>Ll@b=WZ zsBe2}fap*vRq0|fF!jftgxEY<(igN&VTr$-^oO$x0Za8t2KGqlYA-nVt92iLDR<*v z27z}oFUefx!c&M`)zFekU0Cyv2(zY`GJP;Uu5M(~1f%-s^_FddLIkrM*S>CZ#`6p~ z-tg&Z;ZH4WZ4E|(K~FMju4|;Xu;rZHu357Sb^kbz&L)RE$wXF)E_op0nCok2o~pk> zNR1@zwwIEnHDmG!pInK{w!49?0jefrcS^he8Zq6NlPYO(m=S1e6cKf+>$^t*X`D+= zT=Z#yLoYEGZYGWArnY^-Dt4;AOCgwZWajOgD6|9&6rIKNITJqz_M%f*u7$6IgX!#; zl*%ZPYP42vF`rZFWc6f}#^$Q|H?(bg3Rf0*93b>DI%P;rZKAU&tp29&&716e*am2w{%1f<5Y zDkL4PJiZ{5GuJTUJ#*}zg|hWC=NXFV3~CT@QM7EAqUHQx*_EgINHjsG?MI1vywYMs zYFFk}m-TxAp3X?TC{?!Y zz86)IcH^EHkEw42y~pqAG>>-)glMbW<~sMfbJZ#QZd=0Ivf|DalC9jhT>$y%04-x2 z37`2-_9!dA7?jPC>10v}lgh0js62puV8)=&RXC`_&zgW95bcLI`{d8YK(uvzBYC(V zd$S6~chL8#w>{7eZq>Tp)butty(#>7O_#Y8H9Xw+!_cAND8T$j`-~OmSP#f5d5R~z z&=dJ(DZ@C$O1*lEC`niADzOmP zrQKa5a(NOS12`l91*ibp3am)l+Jce2Z0A1ONsW6P<3C9c9>i1DNi`&9u2jff-tes0 zsW)Gd13zinXtfzC@}dC(2&@%^Oxcsh`~86RHIKP?{+*xnuqjsK>&NNzxwtbb$ac-^ zZ9a(+C+`?)XpqD{;diN{-b=vC#c3lj6~S`w22xTRrx<=MpBk?l#*`J(4PtLETpKKo zMW*B#g(aYY07)fnUQzMo3uNNf=v!lx1$PmJNIjI)L#%K5(Yu#tE3w*J*6Ua@CxLFR z8`dt6XRh}MAuo8V57)vn9>0<=XfxJ_o;&^p5+^_UdY-Gb{f8KxmQIi&w8-WDI$>c! zVWJUtUlWVJ1aDCANqAZe`bsU-}s`%I6;IShshU2)nd7R zDnCoCa4B1IR(cI+A!I|-s``ST9pT);61QH*V4EsNFCOU1iTgQ96dBZ(2RG37q;>P< z#+Sa#yx~`LIUmoEvA>x&hjJZAS~vsl3#d?n7gLmP+ zvJOp`H|WYqR;g&SQXgVEp1&8aR~oY!9$BqsfKc>v>nGog=g&kc*g06JBTQ`X1_ji5 zJB<8$nhlYY`70g|v81A%IP2tb3aS`?(;^5X64ER9k7s($M$~=dy3tlFEwvA8_*isau{#jDJ&W*edgT z(zLHGgfS_cK@Xt@L{w6n=FD|ZOOwLx6GJvuz(%?2BKQb}P&pAY_!e>iDCrcb1>pVN zIsGGn!6qNeUPa}HP_BJ|7v#^{-;0kqG;*4$5T0z{Ot1jXHP&kfPw zieBN<5{r`Cy1LRowX~2Z28A&QP(hKIYiKjsEEX4@ttBpf3(Ii=DbpjNK{{NlT<7*F zh3ufadk9eemy`-*g5WA%9r*6Mv#-Ny{*~J)MNB)YT{U`21#?QlKD7T5r1tI3e^G$B zm7h<-SiWZBE!w&TS1Qs5kM||bd~$H3SH-K%6)#$Y`QX1#X5+B0-&}g!grnQwmmzTi zh^jK}9Z36-M9z?D*=&~g-<=mxYWbLpXcU3f6Gp;<$UsR9h-T0_&!H((IVNCepq_O&k@r~&}Rr7M96OEYuwwwD?RFdYoiTgVlfqO z+SO&>;%(4*kuxL&_rm~T?30-h&6!6`^X2QjSVj>9;ZO~dAI#I*QZsEz(bfYqCA{ua z&T8!I!+A(HS6W#X@NfY>10}d_7OWs8voUx#fQCn&eMwt|6MlL>+A+zT+(qiE8@y zI^}TtCy6U8Q6G+riuigH;iT<9sXd#Ru%xgOvG+ND*dA-6y#me)WT>_}IR4uT?BW); zZgZ~<>{FJUBYVo;^?q}l*Pv=)_QAf}9HzMySGKGO>GRobeDuimFX8e`uO*<@IXH;j z-;5b%S*443;xDI%S!&jRT1o4RHL;azaAc*Tbfa~d+PHGms1N}r7EEiL#p+w6OPw&_ zy6<91ZyP0JwfX5b<<*?HZGBdQ@nGRfnP!3hctMe2UtOP{xQ;mbK$&i2qrO}CSZZ}G zM=AMwt@gm9rni8k61AP9N}P86!c{}T4DXrk-Wb{&{$g5q)`VS2zatu$zxu<$fJExC zNkqaKUlcZiCpy}_kZHZxjfCERIstNwxjad&>t$9@-i1q?9D2k3?^w-fxwR4EFh|dG z%-AcAFFNsQ85>*N@=J^W=4Fdoj5v^|)~jz??-3V3{kK63E1p938=a#I!bA|hQU*Cw z*!cLt!mQ`dq$C{;{dO*vi7D_dh-hl!$NL5GYk$fOpR0^Q$NGODan@e}C-z|L zH^@xB^*tlMmRzu(Pxa@es`^}GjDjT!->`8*#b7y^pBR)Th3?(4xZXmAj1Qic+*G^< zDho(Zqy55y$%XgNAvO)O{u19a_ZzD`4qkH1cgivOYRA(C+kbuoD-_?PA?!PNSGzJHX(AU#C^{ZBvJRwgl zg}CQVKbSoR@LKChaA)R-EH>zu3~NhgBEB)-MeO5EvnA>}A2adt=}U_TUU$Z~mR2|_ zSkCqF9`a7O{PO$H3%`T~+;3@HIIfKC_%Or7113l%E&AYft-AGTP5}q??Hi+TS!u@T z>*0>yku0U{k)9)_RUuh8*>ie}#J;NT{ypzyv3`4Ue7lx2-}S_V;SH%$o^3lV7F@cYha~yqyLclFt*osN;-*SzLC%D9v`h&u z!|>?sFLj=IE1u0r74r74v@#O=%I@c|EqKlO{48?i-9tG#R8W4=vd}QNAp#@i%6My0Ui=Cuq0U-)WXr z(?a_9RvS0Pw*K;>(yji3`AD=lVsH*xO$iD&D)H2}qEEC%&;0%aOq1J{jz3jpXe=j3 z>_4@2aVbd*#@g{^9?oT^!>)<0>AUdY!fG5+J@2JHYtaweV`oaoC8AL22tXy6=uH^4 zS4bM z(TcRgv+1u{WI>=GLj8!n(T!eyUloEcSmZ;7IgB$P36`iBY1maKKKOe69jb&z&KH?Z z{w=TiDNNiwxn8G~r0J1zZD{=EUv^&6Nuc7(IA(>KU+x)CYx26;wB4jS(!p;=-B;S2 z_Yc~Cz&X-#+0rR=9_ySkhR z=$WQYwSDAbS%;&pq5818{uMX3QLcn?W@y{y~#q-nW!IyPg>7GfgrwlK=CM=vHBkacD%lqS=0Uqjc}W zNhf8q9A&P#tOsw!ajwfh6C47o#cazTnDcgS)mPXesIXl6O<>3{GhIQFP)djwXB`&bIaZ~Egs$35 zPS?Q18)G;m+Bu|1HG5MG1b5$mmprOYtg4zIn)zvNhAet7Plo!1orYw^)zAN=S(J74 zl1IhLWv}YAMBuiK&DyMe!unQ27rU(nSIx30wiX|*_4TFVW`Nrnc&CVWdF#dWS%n`J zg?n#8lU$oIynM!o<>3zoqw`nI?*D_35eBNGes4G4IXssSb~)Vpm;1Wb!dBQB7zYup z3P*C!q@{v|(fgpH776%{dj1oHddzz!xFt`93TNNYw!iyOxwhrG7bsU;zl>d>|Y3Vme+)1$#Ac-;ndh?kY|3N9kh*1J=RoI zJUm(G=XlzDkioB3(cPb4_9BHDHrmz>lKt6Ligmv`v-I35 zp6Z9A@MB8X-?tq!v)~Kt+02XqhL@7-meo-D{lj*O{twDYbR0CQ)3o2{Lb!xbr8NBP z;KG0O@d54+k19nS_^Ke{^QDMZvt4mpsH_fIERuikPkdL^>-*=| z5_RofOqT4w2Y!VYVnspzw=^tMoMe`p>{65 zWjWlIuSxVPWTd4A&)<=@mRURR?}k1A_FcP*|D=Sr zzf{k4(#q$MUJ=$8vI`T?it;<~~inGxeMs8ep9j3wZO~0;;~DPJqJBu^=rKuUE zG_$z|!e>Tp(nJCFI1|JHcNa3bELTqv&0~(L6MhQvOF9aMki)7*i)X^^abnWrq6leVS$rxKqtbFC2xn3^DWh=qzf zP7;TUa0gt6z8qm@Q>nyfObZKVI0Ii-t4nEvF|;{DX=FJ%SFyymY^>J%&A}l9AOJTe zE;*>J8xX*>5PSSWKn2TOA#QX9%6eXG+WriMI+VK+$^0509lEk>FKfdNF@yO6oTmrolrx%0Y`08w;0Mj3(HKX;IiQ)?!l>PLVA}ZSOcdqsqo{5 z(#8OIY^22mEph}-N&cEVGTKTXCkd&(<-U{_=nAamZgNU&|IU!xDfwkQ!9#UbWn-UEWHy?f$h@nR9Fl22gGm8gl+C`PeC+ov=X9woL2$J*mF3C;nVm$Ijm* zOA1c3wjf7;9vn%iBa?iKfhm@M*aPUhf@!C3gD3Lvo_;BZj%&-v@q^fo@Uuk8gC8fU z#4V5t+D+%&He;LS($lp;cKyE8&A5I=BHSXm`O49lc7@?-d-8CFuvDAeKkjXJw;#-9 zquLnxMkbMjMGY!{FB*ZUo(T=I-}hit`{X`8_1Ro?CDJ!Zkxatl2Rk&jgYv3>@1>u@Eq66+$rbGIwz&~!I)3MR_BsX=oXI%6xWJb zC@zyw)2+o<>o=91-W2v)O?=<-L(9Kz7HXIXhGQbE0Mi%zcPi2(PRf7=98>hhp+|E=q2@B}`<4=*a(73m*Db}PfNZjdn?uo?r zzv;*;4R zCXSq;D+UuT-=#0A7)!_ulK%nkz;3SV$50~($UO}=%;+#W!cmpav&W@ole%`Y(P{aX zmI^EsA>YXH!Cn5U`P*#y%H5dFg%>>C;Osm^&cwReKw!hq9d8%?k7|MLVQV2HfSK2l z*~&%nABqTpK>XjCpBIok>Pnmfb(Jv7Gu z_@?{Sqk@#o1E%hxNL-3Lfyuw_C;oNBVa7$^y2d@oc_)`(t&xc!ze%FDdI7VGgYe$a z`c51EId|NJ!ia)IMiRT6=~{fC-Cb0KFfVjF`NAg>c0K%fIm z7&X@R5JYhib)7+h06F?RB56~m?6VjLHt`MW9bVGi}U89;SbeN2>C`(%%Qno?gV!wa z*G?n{-u|hK+BZi1)Ejo{aU=|;j3;0JPb&${P(u0IJGg+sta%f4#P9T~)UVk1KD6ogQ1f0geCr|Q;l`E`fliP9EH z2oJ#(hi|^AbYi#mTF#jEC*Mjr+o&h{h<2i1G0n8W1pmn^FS~3e6mH&axlK3^nUvCD z2lOgfkCti|<*7V5a$V}`kR~4ZtQdBll|`p{I&RJmj5n^xbaP#M**-OlWub8Dn=hX~ zW16uw3EVT^T#cmS>agVO>3`6}#)wBfEh8OrF~}`dFn>TkIW4`3IerPM((5>#T3)I) z-l~gQzkVf|nf@)dD`WEJlmHB}wj@|WsZcNRkpK0)#O_;d{ zpQ}|+f=Cg`(&R3J70_q?z{v23h6ADgfED1E>py*b=;fZ?k+oLy=J#6x9}hCeXw^4A7#K{Egz3roX;Rwo zYR50;$JShvy$Td}O32Mb57;tBB3)|Jc*EwKKwEluj?xunGJg%U##WW;t{76Ek;bD-&~xp<3<8y4PK z;P<(vrqMWuOvlnv2yVVpgN4$yJdX|;e;RrnEu4;0l~+jCU%t!42t|#K@AbfWC*)TN z0pQF^Zt|ie(#B7}`Yx+PMY+J6T9d55hP7?<>xMGOQDsV8Ou8B5cJa=pyOB6Jt}SMn zoufd6NBEx$$zq2f7f1RVSTI4}{b4K>1!?oWS!r{_d4e| z%u&BzM6S9-{W??1PQasU25{XaxpdLd9$nsK7H% z$tYUvjFT@a4sP}k@C&^${UNMJSqxp^s}nQNLK9BUL4yI&%Z-hT>5i6;Nk1iTBtC`C zEz%yH07x~y>J4kC?DMaV@~Rk<{dV*6*0&qFqa&a?Z@D}xEiQXpJuIth8D?)Fr4G;Z zTkq4M{-2V89>f?WI2uEutamIbcOXgz^H*q{|22su;h`3E@H4};BLbmzcTyigO` zquVE^_!PCWX+0M1#Myqu!0F)s%0e zIB8!GMqIqbnIbgbTawEFA?(E9c-W`rW*k{L`9cXOuW*U_ziW#jHnhFm@#G+hVaIO5 z{P6AHCCX`xZ5y^3FY;yhazQ!dv3O>f;ohr{2vxp2V_^!N9h z^mlZ3|Iq@Zs$#m!0bY&k_N3|nXXA#o?TFZuoY|>kA6|4sw|1$EA(-6dzT3ay5W^t) z@nNFXA(#O;gOpkLN+9&DnU&wJz5IQufq;P{P^!p08)vQizQCD!l1O-VSIkrdNr*1)7yC%^(AeCeQ(fP>+JmhG!TD`1)3Z|8#`*eeTo09ATNI8cLo`PjbkG( z`OH_2xaQ@v+OC8~7#D5acU6JeO!r?q%!hbQuBeg$dbG$+1(B=%Rm-!TCRd5DyG60l z79$OtmUoOHV@`7aWawv9yF%(ub^-S(H-Zz0L>V9ppw;`=3C1g}|FJPf5#=QfAR!^b zI=qy1nThGGGIx6htq%DKNWF;Rt-Rd95wAk}YHo9|DV@tS3O^XFRAb^1kJZjU; zF|Y1@H(>I~2Ms67x;`QrG1rJrJmb5askzt%?tlqj)1>-@=70JMnychL977b35PIVO zo4>lTq;$lee(93z$_-DS%cBz)<*sSHZu8B#cGz`HR)KRbPmtPlf*lAey^FA~&CD&;l66ZMW3a4mv)OCRXgj zM+e7Mgj<9;Gl?s+vS%nZw!cq%lxGC|C1VM)@pWI-asnJqk=)I~kd~Wy&)Wtj;$yEY zpyGdo&Pwgp4-w@&VQC26MKW5vb&~~iSnPcBR0OEh>!8I!gYV)lickp7SKVt-&r_FC z7n``0G`nNE7>MSg^P1Pps{c^8=U-by19{E7^+;(8$g51|m&a-q$8D?7g5b;JkBnVFe(fb9+=$|P76hKo?sr7|hL+Utm?4`!} zt*WNtUP;2p#I6;S_sAto7DKFgH?ntHipSQ61dvv9)a24qr^~x|c5gT#Yi*ZwkAQ=q-()z^WF{0L zO&gjXwiC4l=eymuo7l>p`oYFZ+m16>_5$E|(-?6E?yMDdzI7QeQvCt|21^a)-FNF7 zOEDgJdVgDrs0pcKE2G)|Y9FF&BlAc&o7TcXGuvA4XE!L*R?-kyJb=n^8IpwK<>kfT zywd`^J-sGKzP>a-&M~hSVIC(i4z;DLw{s87lljnp<_TpUpsvaV>cWYpmyObvoFBtj zw}Cr=$*_dh<_Ct@`Nj>jBfoiiVetT583`r83;TEl*v!P#3bTfl?b+3P3Y-&eTWIa_ z{1AhY`S>jvJC{>f4wzOHrTkGbVbD(g^jTN`b;uT_J)6|Psx6g#uMut_2nwn&huds3 zRNSEm>odM5`}f6n>#y8fRGu>{!h^ci!k7&|ETade9(Zh?O@u( z zCVGk;4N5KZk2AXcLbabSBhG&;P~zm}s^RIwm(T4qr}iC8s)>|2iDNO+*A(kLK1qV- z1mae8cPkd%Kc2oJ##oVblR zRTj7FF~-Ww_aeoD2#J0-xoRbm-j6+ak1oBB##y+ihiH2IUKZgwqR79B8lvOcnDvfV z??m{`W5!%1F8O|fteFABD%61*+=pB+Ao@l|mj&{(vd;>={m`ly^krsMycl?ji22uKpDz{0b&NO?Uij~7bMa=9y*cILZsR8O#4uDyQnT>beTfMl8+PA zz8#L{Lo)HTZ0a;L^dlLF#8``HbaHJX$%^AQ5?;UijHKm*pTOE4BOmvml4lI5&4rfD z(?Z0*zk&vP>@y+7aNleC;4f)^5mt|gTHE&Ad-pLIze$~ZEHPg*6tYmB!$WL-PqQXG zG$71TzYfSnPUee8x_YN)-*%Ky@P#{70Xss9?)5gK@KXAeldVz9qeex}D5iu4KahwD zLTHyUZ`;E1;hMgYTW~+Gpdf`RGy|v!3LV`5G+2tOBcz*FOaQCfY*iU4K6?O?of+RY ze&U!zNv{juEyj_1!NTgyDhVvJ|2>jBU&43LqlL$i4?1|`IJdn9GH}NkBdwUiYjvj4 zaaR96yOBE<{fSoIcnVX#FF~4G&}){)#GGK!iD?oz;s3JtZ+`MN;K!)P_mHC;RoadI0axsN z+h&eY?v((9qAO06@||6yf1r+Q6Yp$5yJ;erjZ)9ah7ht>4+UQSNrRDav6* zG`Fm}!M2f0GWhn<(cI zz9U`+in(6)``On&FUY%A%HYNp*~zNB{=O3K$+WI0%PTt~vi44B*zRVHK zE#7dAjg}QE%0|@pD1JaRKj1;43$W8l6Y<_X_D$qF=*?q| zNhvkr)k2NdCVZF{czoDXm06K^C4p*7>Gk;~9d=45NqqNaz9+>ClaF~=AMENEcPpTkm)E-VM1hhHH2NTcim&HFLxLcId=9y(s z@%Ja&$R=+5_;_?-oHPgRkc|tUOrYg9-=6*itaGdPZ-`z9xYUQsXa**__K6#RW^)miNp32Fy zpd~A-KN;57AZ9cQT(lH7o2w!RA_CsItkH5=Zfh@}#MWrl>{9&OI(W_d#)(H{H|wTO z4%$q-5`!5vZPkA)X?yIk(K&d{XjGVXCgTW_lvLFe7tL)Wc~4iW9|>UUPBrQ_@S6~S z4}NOjTBtQ4-M=qI(wA=l_o|vBvkIB~V3Eicu=ZQb> zED#BF{5TcGcXHc#>KoIut>(W4izYHP&5aX^)KnP}zG1S<(o(&~#Tt;4I0*zZA-SqS zgox9pI$ZrDr!=JEI_A8(sMs!V$dg?rW(W=Y<@(c-BJDZIgWShEx+@{7X|M8xT<%vT z=nAmYt8T*DDB9;R2U^Txy`LIu@o+{F@3)N^;FjyAPZ@#W4c2e?Qj$IC?tSCOi{*V1 zYiu)BosyR%xBVR3BumV!->|iAuUiYQsrqZx5&PwL<=TgGUd0|N5i1&=X?V8ek zIHf5Nz?ML@+?Ew2MU6PtO0AvaI#`VPr%K2dl-Vd=3_@s`Xz5V&;D}H{iiDOT1 ztmCv%_%x)tOTW3ZXa?UzXgzz?M!aV%2Rv0Hl)icj(eNh1?Mh}-bXwpcQlY1&_-fDHOECXywcQJt z%@+*t!^})EESElHNfQ6skwb8ibR4AG=0fMm_XZx~uMKpnh5um@O+Bv6iLnpc4W;J$ z7Mx;B(bC<5nl&>M4)Jy4C(k%lym2r9Z4}HB<>ckOq4fvjndJe)$MRN|&c=%DP@qnI zHg#}J#ikqHwtd~Wedk%VWz9v>`&ZgWG@SaOxo8ft8}{w)s}f#_#jLti?Baum0Toc} zrLz0PKy=~pv^f-?JUguwG9AtUIS%Q2$*ZL@rdquVH>TP#IFMTj{Thg~hu3uXqJ`BU z)4-)2R%EAwE|L|aU-+v%!NJ=@MU`%|{Cn8A^%{4&Gu|%0((sq|-psOvecmLuE+1+)ys}^- zsaJO;=9i_xvn)p8h+L!s(>dK>R*!61SFL{a=nz}sIhHp0&_p(5llZ56kfF1=H`D4Q zuxX;mT0!7a$tm=2py*@x`og|NYdlOx5M*aYyYH+(UXL<`6zwj`IxUnoQ-3XBawEDm=cm14%ub(exmc^W$a*St1}YX zyG?0K#M<`p@cg&WET07q{unv(gW)hUGJ{qrp3UbsiU0D!ar0uNlP$mZ^b9Wy5e@#@+FZZ+G`->Lnm10{O<(_e5C$j37EMxqnnfCRv zNKD;?=H?rB&7X79e>U3wxGBJ%SC|{_IO?a$Ij@aTYqK(~AUg$?3Zszg#(&lLb^ZFj zU#L(uXx+P>o4D2qUvRBSgjC+`bO?SrcuiW?j3&7S23Yqf7cK$F7TM7eCW14Gs|XPe z!75{Bp06T#sZCVd)f@gX^yAOgko{cxSV}9sWVPYfG-?AURhXt!EvnOZ>WPa$z*XDA z*WVKZzY70=H^e7tfsi%MIa}g&58Yw97I=g1@kw0W!w=j;pdA^t4D@lNPp_TNyT;A+ zjMVuT71D z^h2!FiT3UZMV1x;q;FgqSA9{kNZHb&r;Y?9R^4dGwPZ>LisUJ`ynp zJWH-dz%!N&v9RI17xB(Bvy7LhOL4OU916lrDpo1OP|k1vyzh;k9$Wz$Q})V^0+!Jq zz8?D2Iq`ReRy6ar&2}CkQ1Q9g6~42YbjaKTJI!Na^AwaEtzx2p79J=^1gF_>zWK^?;8Q` z)>ZGCjz9p{(6EhM(4rS%w{AD_(@@0gO2Vpgvf4*nbAM!#i+M}HZLMan;NK?3t)Utn z=iyt%PHDbhzSt{(t?0CdK){+RvX9l_n*~NPb_R)F{@(u9^sk@`xnBBy@DJ%O$s|`Mm1xmF#m` z(hVoV+~bmPR>59*OiugU_sf!)k711kXYOX9ECBI~9nkQ$?=BF)ZZXC_2 zv1ObAddHkBk1YC7;?yhnZ?vrbhecPkBtkD3%HZQ|Ypb=wdQJM1y6K(gRj9E@pyN)N zw&5=qy=SK5abLa^1sEBbngEg+LGJ!xDxa-Sz7D+vJ~v6OU3t5q!NbV(>8K6+iFJe8 z!JZ}r&-Bf_5Obv-U%sQ(Hbo*L;gCND@rsrtjF!2T)8u_Y3sJ*rbCUGw0Bc%|5h?`K z4DM}nlc6SKP}L=so|Vx==%XChpa*R^sTfSyT7k@gru}q3F)puAq7^7|rEbF2te=fO zWZr*k| zveC+pdq|unq7tUQoC!i-?K$FgyVyx#KLm5E*eeLUZs;C(=$+y_qo4YCqv;pBs|L^qJ4t=D>hTKabVd2iMUwd&dGLD$YWs(E0wid`yip@zNnvP}A%&rsY zQnF=T@P*Yl7L4|)V#hr-cX-qj5uK1ye#AA2<<62(CBl0Xil0`kcEz{My#>NH&_$|? z)`^T{PP4cd8XDGFyN>v9W6>8$1xh1{0RYg~RkYU@m_Bx11s+ttV?-hJl8RwIu4_nS+>p6i7zQ#H?fe`JcHK826!uV^3Blqy)t zc`m0+y%I~HKUc1vs?Y5TxtsHR5MGQ*P-b*<5- zIpjbEg)nxDJs!Ox5+)jmt)NR=@GWvTb9Id&qD&CD1qf@0|B^ND}WoCT0? zOMF*-N=<9D|6v(R6iV41)Or-oYjYXiE~mOQ%guPnoU;HlL4cLLKlkA0QomL>kXV}X zEpuKPl|OoxbdPI1`jX(RAcKe!#Ej*VCUqUr!tQGk)k$cwi*XMl@eo&9k(_lbBU&YR zVt=DCJ9D`Q(cxfCkf>(d{myg3G?v_|h<6tBi9^Eda}rHb3?r+m1Oe~S*$vj&aWF$q zFW6ea-81a*R0Q6K6c)%n_0jo9?fqpcG!mE$mnkL~P08yaHiI-g5EeNkQfKO#V45SS9g5h-2in^GkX zM-OZ`!nVJ9$MYZNJ4Z0j$l9`fNHoCf)HbX)-`}8Uv4!PPW`e(k4z#bqn}#288L4I+ z;h((1T)jRpiNjr8$UM)hQH{Ko)FDB4=7Ud-S;t7%5h0-; ztv~DB7o2ev~RH~86AuDt>- z+@cjN1v&{{{Ux2O?~nI{xeG1WbJono*=Kd@LM}QuEUQyKh_`9$oP9i2hlI2O#mdb% z?cj~%BR5mPw>DTN)No?U#RZhuegSUMw}lVMWl`h>OR;djU5C*qbrq$#YsUdftmSk) z9I13jkxaYM{Qh!2Dz*5>*=}$H^-*#v`UjSmJ{|1~2RS(2Bz%m-QBn)eX*Xjp=1rsw5}o_i z6<-oltsS?3dIqZCT1*dFrFurRy~8OiljdgtRbpT*s&6YI$i@wnJIB~e36yR+@`P1e zu4UJOYobqi)Ki%jumrgsK1NV8$3fzo@M&v#9{=g5R6ZP@&%)QrZDp5~Ajn3) z@pL=S;fJ->mSF?}I($__qsxYeDX|e3EC@$C?WcJx{k7QT@3Lpfj~CLvAJyY~^F(&B zJDc~Rsk=&bXjz_aCJqb zpz(gikjyHXg|5aE?Gqz$ku68f%8QDo4*L|MW z=FO*d-?+@vjHa|doq}aHdd)TYFBCXG?*qTUTUce4fXpgG0v#EGA%uH-`O=gKap{h6 z96B3=TusdWjtggXM0{*^LsW17N~PN6Xapw2U-Rt4NjYxS!_B3$v9uD$mLb{N*l5vGCX;?M0I>kCK5y8}7ndX~ncNR1`eet)@DwO@{pnx2bUuc+Sa?^Oui^)ARY$PJhTU=qk^swsnAH~0b}1i^UOVERVvHN8~w2&ypwyWZ)8@P8`;gImzBWi znPlwjM$)JH+gBa0nREr-89K{a8}ZW3eD%4z5j9H8MvdAxYdYe}?$9CJpEcR${#|Ja zt)Fqh51(UIGx{Id8u?#z#>mclZ<@V((S>#o@Dq*~vHvmxDuFKs&45l6xcrJ6PiCxm z`n*IW*mf?th^9;Yw}>%v-~WSxJ+c|W8KW~Y+XND~an3uOk(VY$THtL$KK70$TXSjFg(}+Wc_?ml?l=S%jp|p6i-wp1)F4GBDsg-x#X9tmBJiyMuC$CDjE2Ujh2$s~h z8mPW|L&5j`Y)~glT4ii7WnAGT*o$g;5MJwYGbRQupg|On>f`St9d!L4?!vv-d!+aD z3QVs{c(E`62c4jBO!@du_e)VBMhE9d`zA~Wh9B>MV|N}BwkA^|aP+?RUwJnXTixy{ zkj*CJ>l#BBaWXOcjRXCQ3d#n{S0!KR8GJOyUCTRQYM0UF2A0>b?Jt&uKUn6!HB9yG zd)Y*0Qr3M3GhXxOC$RPk*#aA6ua8fJA#s5fY8T^plmRx~O$HoGW3&o)j&$u+^uKh8 zGcK-ku$=^|5EOpY)xxSS*PfkeKCXqr7ZS?1Tbn`F(xCwCiHFF zOG(Pr=oIUMq7~qp*O4O%u6bsAsZI4zwq~Q`*{oNw!>S-s(JuFuYz0Skk_kEMXYms! zW)Jjnm&IYtUSUUQv1oYw12?e6275&M5!eR*7t z>-Y7OC_~D0jFCeslu~I>DaTAH!$C@AXp~ZD9v(V`5{gF3Se#0lH9tv`CWIyp8by<$ zd3e{pAI|spdHw0saozWQUHjU5?X}k`*sZMmm0EE&`sPW!_@Qv&zO{h9_(u1aDKzD@ z-J+}{yev_9*0cC3`IP?2Z_rh|60ORexr(ctn9Z=Lu`ZBZNr9!*_u?B}KdZu0e++ z!ww6S1^-ZZ@(-5^V>Ig;fAqg<94UsUH|cTbv1FQ}6wfNpVy+tXpZayH-w>Ez)aWdAN>D+d!8^zWY;1lL*j1c1m;b}l(SpOBt~1Kw?J3axu?eA%*?61z z|4qwC@x_!H4qj1lQ9e1RW8eHM5v6cedB!I0g)SYdZ!mAu8T3HYo-ZgLyGD}U85>-m z9FN!SRdcekNUE6ZFRI|#fK9}^}$ZoisKT0mOb0wxe>ffUK?2gR}g6zw5&R3P8F-__ZkgBqP_GBP9?B&(ZV-+O}?P8H;<`X%}-zo=72J)_OY!p@r4JTUQMkvZZWHD-S|pti|Y?G_WX7HxD8~(>y zLnI%z?^SLBV=yAQTXAJmwvn)`n4^&X9j)SnT%4C5mJO4wc`s<$`2tT7&tnzgc zx93##spjUzWfCldT}UkACgsfI*5q?;nzY#7d-SJZ^-WH>O~gn5$*c3zA->h(DfTpv zrfDOijbgExs1HH|5=Pd$_ArAJ9aoU~1ILPbQn7$f^0NMKG#H%7qg`6Ht>3Q;@FhKQ zkCXI6vlQz=PpJB%IEC#kTMm(Y9mzm`lT}oVq13eXjG$=ADQuS$Clr?nw5y4aPk3Oy zM0|@H{t9g+COc&9SyFJsuV9*fS-@hWd6d6(`6?~is$01-<_8#lVWzj)d(<4s)XN;+130U4bJaZ_sWMQ48@>~Wd_^c8_2UzI(TPi5ujJVz!1AgV zdLt1$J@50?H>omFAuj!4=toUH$fjc%cIjSfKEEL#!q5n$0&}4>Dqp2gb;ap|Cl8O5 zo=V#87-VsKd;9wrm+cRzTc`RvAg%?=!iNip0?_lyn*@@n4N(n zP)9p)OqV`bdl4mu1P|WNo-vDce`Ue*V?!|ws>x%tN%~X3tSFd)jfAo1T`$(C-)XJZ zz8Y?B*{u`yq4~hDHG`X|EZ*;L=h;H5{*DH6+o4Xci%9L3?`WUJlB}#T-!`k_xQ096 zB*n5MPoA?jQ=V^4N(x~<&u*|65{{-5sE$UQ*L+ln^+O5ISy`{Yo&ocg+aJR%TBDzz zlaqlDW@6f6>}br?7A;*MxvzU*GHEh<*Hll+bxuj+R#9^4z)D!^`-5+1Ij)LH*zYt^ z)6ZUwrSG4luCZF}+#Rd#Kg&<8JOCsBKNe_~DRQZ0fEEKl_%w<+_Uc`G{feT2h2B(C z{HB$M0&Hh=uehIQa15aW-_z{8_pcUK%^#?sYX|V0|j;R>sq&ALIPoFHt_J+@e?#Qag|x<+Q+7ikD^_=gLt=3`$Ah% z(q(aTr8{>H7X9TbplNkkfI!Ql{?ZpV8!gs^2t5z={L=0!LQmQ-YtvLHU`&wS7OJW6 zn&(YvWxQkHz}Id~H_d!3epP&YPh6ZuOg1U?eqCgi=kT{Ub&L06PcH~j*&SKsvP#hG zV#5I(J8BLnVV{N3ogxb^K}zOYq~(}$6bmrn3HC|#gsMe{eNs|NEf3fxW{I!Dcg|#Z zRFFG0#Ap@6hQ?;OWO8O^O;64i zufAfIJW?Cjo&Aef3KaOh0kw~)yfYPek)itCbYSY5F)5de3A^3S*0S4(`0_ zJR^@lCaG1?uky}sq8m(;z)ZSrES)2k9o|dl^SbflTf#qoJ)hnXov7>K8=y^7wx*<0 zJ>?0#NP`(*G8L?Jh0Jyj4$n1vRhDp`>+1diWXp5PT$9}`_r&ar^vZ3YTM})=mvxt( zVfEykd43C?a+OK((oUkm*w+dU#!_T^+k;==AKC-rld+xMPP}i11+xJ(k{0g?yaMPikzOZt`cu`Ikc=8u4HA75DW@{s} z-Oq752ovZGA9Rt}w_Ug|aRZ)!CV5K(5l1TO9;+uJY0-nik6nm@p7&aQ_wB@PsX?`b z$_JlzTjaVqvG|Jfd@PV1oe>}?SFHjL?tr{C-B}VK!elgeXz}}gg6!fy+onCCb z?H7Y@y^i95kz|48s(0gL76CTxwbJ7@cq{(wYB%Vx ziXmJA42b#Y&Mdp_AuSej*e>|Qq;Y~5c^%X!R`&c&_keR4n!n+nYO90OBSOpz8JTne z*35s2Xyja=xe;`rO2(2a;24Az(JG~iq|*KDq@E5wHf@ZjiVwa(8z?hl!{3jJZ7kO< zh9=|ZE;KFhz%p-zTO3=jZc1SB_KT+#srh*b+b1iE3Hgi*Ch`e1&>21u+V;4U4p2d? zTYmgX>|p%(H}C$-S6tL((vi=__{+fD$+<1X!k{}vaLGN&cryD<{hOD zuk5R9ezg^5Urv>X7v^Hjhh}_vHbn&SC;kiLBTTRYvAacFTPOi>| z6*NtKU)0aGWm!L7CwDY1F;;R)>zNZt8+n2&NkO>MIr^lV(~_LCMfSXZPxa(gR#yl4 zDX2-oQDet{XA+8m^REbDX_`SDcZ*DZ>~qFYXiW-Bqo58{i5A>;PrU|MLn_ zA1FdXhhwJ?mwUAZxFrHapscpGYf7pr-JX!^NXdw#bNa|$!ra1o^~lSQN$*W1+%aVO z@P&;bnxFM4p|a5T0R}DKhuOgaS>s7$&ec5)DgB z<>kcfmyYr^vs6j2^y(BZydczRZRp8s{+h5su5Qqx5m#uip}A9nI(fYpLQ(!v+i{s` zghD`Yp}YPy@)1ICEZo)i=9t{zN4q`uUe%xaOJfTN__oKsyXD<9ISzb;J?Xk=>{~IJ zFfpdTI7d}_IClTPTO60kq|_9#x=xz)@XDjVs?^zhb<$Y2)ylx4q!W14Mz@}yeAzf+ zK)_b7;GS^~hX5=_p6GdVggWh?YCf;fD5W>@wO3)Jcj&6E>zTU?H{@c@XSn}6^)?2s zdc{38iZP%6X1D+OAF0UNy^*3+G^(v;=idx}EZmohr-p949ePhI;EZ!KA~T~|GqT_Z zEBy&wJ#A99Gay>$IBq_;WOOSW8|GR`DWmT*_=zg`|Mr-8yX~E3&s!ivK#89VAsF@rPGB6mH z_Aw_e^21kj`p{ECdZ@0ly23j%E>(<_Hvn)#b-4I0z^DxM7qR8zS#=-4ygzaU%&Hz$ zd=XsxFXEk^6k7yM>N3zAu{YHnja*l~D6&1q;m|(!Yhp0YS|36HEy&7-{(9AW(b)QD zmni6iSOsVw$@w{dv%{-DhQbUAZ;}DSfWBV%mlzh#r~YGDBqN-LpB6f?O0^tbzjH6p z37lR~gfxO^ROqV}Fv0QlS2;PdkU}Pe`$Tlx5lV!l*I4}u&<4SR4<%&rce+xm#@Ebr z-gEvBLZYbh3*yR%2xzj>qKzI_v@fGa1BL2>f?=S#bXA-^N0`%jJZW8!zQIXM++VHD z!j%98HxuJCMK#%t_aq)vDZlqwJssr`!SS6*%O*N(88`fI_8!Ak#o7qg%}$wZNxjU; zLy+t)GLmy@$cd7Sd4h1DiS8<-!GfMve_Yh3!ckd61k$ubnW*?jq~YiQ;g%VBym(`e zKhTb--YdikAZ0g(8GDhCVFAr+M0RUm7*#|LEFZWzyL_#X=)|@)i(oO=9lC(iNu;7b zJotURRM7#ZuHr2~)_&51JAG1pU+70%y!ayL?yay;-0X#Yt`+7Tv@|9asB{*Ok4s%8 zVq(fX!0jA$Ert8Zm0>S_y8K6g&`YnKgpLE=JtvUdQkee@&3t(^F)!0$S-u9wBkqyd zch7;ne443`7qNUAGT#clNzFg3oxThTn-(j}g;w`l!P1*GH&P}cW&8>sez65jEbo_q zbvsAyQaXhya)vWi_DmUxWMZ@NHuN3i(M6fr)L7nZT30#fFF#)dJH`aUsd*Vxg-RM8 z9T%wY5g`tv6$*Kjp2ssGukq1w+exoqHv1G7maFoQzmpm_Ynw0X)uoq~aBmv2oHDnF z87X6u*Ou95`%EnO*<=xNg+8m&la13Cly+r-+Ma10^GDmjkqb$b(A1eS{WAyY0|51% z9VQvcM;>1wR#gGYUw-cn4L>-KSyovZw&TlV=wR*-sV2u&ThyGTzWm4Tg*(#}^md<82k*yz^1N2`2}b}FcGDN1~7#b(FQ zHiaq%@agw!nW3?%Dox671AnbZM-!TpDla#t{(l^c0w!YYe&F1{36}&F5RSsKJY7zZ zX!pAxitnIbMhyNh-SzJqXWU@=hq$|V>aH;JZ?UR5*AHF^x23nY%rP`rf8!Sn@BG=G z#r~sr=j^d_jFg8f+X-+4=cW9x98D^j_Ws8DM}iD zn3%xGD{S5E>2ojhwunnfiNxQ<&1w}c7j|0U87E1kbcV>kE=2zZubE@N$*FmNf&7qS z+}R=ojL^+aGUseY)Axdvk=*Rn=t9#n3Di}Wm#~-5$y4x>drpcT+o-zllEY*qm^??l z|LNY&@n5dGde?lbu@e_3irnc>kx2m77S443xb+)XC4Tja0vcLE7q#xn`)^aBibAYw zOlX;%E}#15ea(>M6VuLthNj$0`7a}EoLs2ixDsESL7G2(M1}C~o6DMkohHX4%;U~3 z;xw+HOx1H-)lir+n;#?8lrXkSt$$o1e+&r>?n%Y&;ZaF6o8cJttLwK|i(jlZPc>kF zuj z4CoUGC=S&}GwNZbQe&{=^Zw;iocmOM!FX7@QSz$`-1~hQX6StdsBUXkoza!4^?`MA zSECEN{?J6ydZJ@aJ?(^Zl#i$%J(CmK1aFMdiu!se(jNGoG8M`!);SN%z+3n9d$k+T zGCUeMEpLOeiVA)ph^Qu(6zG-LeT5+g69vW4r(vRCHLQ(MB}cpZwTxp)?F+cmpDC@9 z2L56x4DetTToS2YCN~huT+)h>#`8+zw@NPIjSBjg$EaXIseV9!!XvTEmPzMwZ43nr zTChge(Vyv}uWL-&67OBf?@zfV_$g+#nUOgj2K@7nD}}^pL(gngu1_{h7Q_7VmWv<#1AXYnb5xWYq0*g zxTM29p~4(>=*|pQ{<(Q~=mT4=~&Oohio zReD;j5LF@YNn6f6fhE*0+e<~aZsnok33cvOP*WZB&ftfB`F(xEL%4=D2}JfzinJ3P zlTXpr-E(~os2NPzfxcaZl< zm0XSFz2@Is0Obzd^xEki_Uz@pq8qqlE$gSfRgvOq^P^qhD>; zUd4efbuCXZ{yt`rgfo^HEHES~KWt;x<{zJPqN1XnQ2qF7N~;~1&gi1`jZVw6!D{WC zoJ2vnv=e~G`@+fI7HcZXE14kJE*$709-or9^yj?!k67u83O1aL9w|A}6}M2Qr+;Mq zudxB*3yJlqu>U65br~}A_=A5jqyRkz^~|sa<<2Dx!CTgOkH^@b;6^bN6gUk%IUciV zg5N7RbvgF`>Emv;1rLa-zo%QmIbtZPCWd#KdFNO_J~%yoPefN2@UvGy-kqTsF&3!k zs)J8xbVlMNAv>>jSk&!b#?WBbDZ+{cOc^E!ey+OxskRnxJnC)#Vp0=99#2W7P*aCI zXuAk6vk@@BKe=c2@)!@dz%|yLD;0CvY-~a}yEV-&?aE(v{0ggsq6BZWKql_npID{L zPKaM{u@ktBZP2cB)jL#mts({d)tk9U`k;A^vuPu||6n_Mi%VnICak>#*VcGHWK}l_ z+%5tl&t7gSzGcP&egC*;36{3H6WIA5)s(KmjsO!dRh2VK;_X+l-pmm41p5K8pXeG9 z75FfB?x8)hE~XpvFV0)B7NbvSVZ&-Hd@f_)hXH94$No*A zpxZGLbF5+g&wBtL8%WHlYjPdM zK7D(uCozqmKO5lx{WIu7l(i)Sw~VpRRcaO&-@<^;){NqynRWY{9Ibx1ZF!JE$T-_@ zR^Eo?Qxz&mJmNPvrEl)^S!l|>v#mz9z)CiO?T8HR-Yb(GD=i&Hhm1S!lUCKqE5Z*M%&Fr z`0)qJRX5{OUrce(J~$MXYtyc_A{_#4XzWpn!4Qdc>DIb#DyA1AiDGPZ#lBKYcXV9) zsW*Gft@^L_cm8rcI~* z>iWPw^wLqUDejFir!Mrqp1?D#cFMksGMEFytTSd~xd&9$Z^f6@V3w7*vE2NSM#rm; ztFE~G=}U%c*E%2}Hy9)YvtBF2xAay9v$Qbs0(uXwCgGo{zM|*~KK?lNT>>8kkGmB9*SJH6mOG*GR_Yo!uSqU$F<#FJ-(}?a4JjPon5IH1WVTZyP5|YVZj0}J2Uiy z-(iUv%yOOPWja*vVAOq9LZ+Q|cPO}z+!-BGtT}TC%@Nu-OmhNHVSl$w`I>48g%ORA@YH_Ta$}%Wr=3CQ{ELRk2Za~+FKmv44wQ4%s+7w7h0u-u%cWt`K zElU=7NH3tfX7vhgtK_KYF8TWlc{nTO*063d!&O(zX;`gN_|-pJnIb`-$`Ai^7RK7= zikF?q?USlGiV|F#fN9SwMGJ$><+0e_AMXR;$3uaUNV!0uUTy{D6Wn*R|wK3&PHIhwxC6y&h^h+y0+f4-@*sC+H+pSq51Oq+&E_Xh;uS#Mc%1u`gmX zPJGB1zb&3iaxyjW_B1#v=t{**1Zi&L||G{K&vA?egCj zP_x!Ok=up~BGJx0%z57dB<^9M=0g)*GW)ppl!$AnY8^Z&dHF^2z{Ep<6c)}=QuaCC zJ7MHxd6^HZPMT)2wbmyq68%4fPAxNdlY}>A;;2*;FQS2qP&O+H3@O2 zfCW|;neXvUB~8n(sFx+SA2#wX@A29(;quPXouL)Fo>_ji7DxvZaCa0S;Ii#wBy9aU zQ*gv2?oFcpJ*bhDw~QTEO>4}UBonQ9t3P(Fz!x;M3@~ER8Az>_*$W=E3yx64K|4;N zN(~h>afVnmi3AVr_=d4vrcFi0UppWgN!T(-oX^TW_K|Bj(+RwSjiQsCe zzB8A;^*MbkO#EnBx%*pYr2qbp#x|{FSqb9{k|&{t-m`aAL-(K|eRz!B=kYo;bWzjb zR}!-WRrr+ieh7dx^*@p}4~7t2QXG^afpyPgH6zOY5VACw+}7?oJ+JK3u74o~A6e1i|$CwY-f3v04wO6q3A!9i|We;a9q)1ESQE&zpGh)JiXH zg(A#D_x`^DAR4`Kq`5uesias6P(6*&4}#y2tdkQINi7c_-iFUd!d5|t$3kxK@t2V( z_W0i739N%iX-j81*V?O=G~m5+z8dL~^WcCBmd+Y3hS|Na9tj~^xUQMTS^4OvVM;r{ z#L`k7=@LD5`-uI#JkoEK)~0(zcXCenGpp#V`msG+n!`L!$n?$lpr06HtR1Z)!_lN4 z+uH7h4*k5FhYSzB9;w!D7Z_GFjmVQ-L^{HHx`+I7bC;3IVB9Qp$-=R@tgN{zqcU3{ z9CRz}HUxCw*lpQPLbH2{clwC>v`-B;MDBhb?P7ttB2W@xlbSZ2t9nm)r;am8vK_;} ziAr%j2XjqQkJ?-7n3F}ZSX=VgUZF&BtS*X7xC#$@R zzwmj@=p37j%1puG0QCMFzrU?fSgWyTsQO$~RAtqL12EL%=dYaCZ-{exxVHHrr)Jbp zz;eQhXShZ}L}=5T2hLvw4MoU){&pv;##?F8 zrQF&$#ytJ0C{|Ke_S)U0IawSYmfCkYRXPPT-EpRG1&Vc#S?f;tx?Dg{Oh|>cIy9c} z(m#{I9 zlhv52VAyuEspk~k=$x2M*Ndb$HmbgH35v=KpFX$QnCh&ccn<4crnQIu-J2iQ=;}Mg zkV3UAsxmy{@bfwh43$_`*O-1+O{!)||Di1=7M6#GctoErBE~H=_X6_r__2<4E(iSk zMAn%j2p|@@)mF53yYly!iusAd&1mEGqD_C&8YDq1L=oipumM7Ek}>0Jd@B#3zehfh z|G1O;Rqpn5HCP*BrlMP&04~8{x*)UQP653I(ojN%Brw7=dL!}Y3G?JyXa*@PxInHPhm6}Z;~QwsJrwrE}cUKakB1ery~3>t0#?<$-ray zG>ETO(%JR=X*TaHF;(rMrzwB5Io`XM4Q(OR#v4jzW*qN3GnO1GwCiLmzr%@4kykq- z7+>_ywPK1fRA;JSIQPQYPb2Bv&5d#0&u5PXWq8DZH1o^vM76|Ni8;eK3C~>>Suw4j zM|ZlpB=_kiR#?KQ${)e(H7sP1`Yim}yL10v5Ce2)SAS02^?vsB%(=7?vLIB6|LfsL zPrk*a&v5XtIJ2buEAM+72ln&Xlx~m1gM#{x&Vw9&nthPiH*e|>hjoi=aA&25-`=Tx zj#Hz;7O9PCYH25*d;bWqMc(qzcRV;X70du-f zx?^+crj6{Rkq3&M>&GJVv(G@S4!wW-acqB@SaX0xdJq~H?W7-dN*p$J{$%v`Yg1!I z8bvovlE*F_-XSb@cbxUkE2~&luIzQzdzyGA1GG%apY)|fdVj?zr5eNAag&`r@~13X`caOLX+QGVK+bPml48_Vw#NPk8~#Rq-Ql6y*S zvrI;ziImot+xWhuv|;JIs{%MwweM)D8b!~Ij z6^xF1s?cmP^uvL}wlezRL4FNqMYl1syf2dyDo-#Mg5)tJCAffZw;w}kz>0xz!PIfn zrjy$U-I#1$i12rrjwU_DHVLt?p)1y+N5}Afw$QStD-j9iiYNX3sa6qPjMh*w46gckDv;=lyBqG-Gup9Y^^`A^J@E4Gay|~oB5Bi9>shsnBwT-K#4=^2>(FW zcRxBcV_g~oZq?U!+8e4~Z4cx8*nX)&94!dhwAhBB! zb&9RXu6&>L)%q;&E!wt@HveKLQLnNJVy~LYYRbO(-0kK1glo@tn00w-00^mF&K?~;()6+j8^EM*&!WX931 zeve&kjfter7p$+}5F#@T4RKd|G)scU3#>q8n#@j`buavh250_fHaiIn37zs9btxrMsc2?>fcC=O3X|jaimuU8+iIU!M*1_t{q1p$p=!#FWcNXKH$a4_TM8kbbX`g)i?#dtdm#_B&$@Y<hjXZ8Q#te?W`J4 z{5LoxvrM4ihMAv#@&AW@&Qo`idXMiLkoH?JwPfd2QJ;BV6}49t?>wgJ27Ac1hKN6O z^%*&M*)Jj&bHk3=J?rADyP5kPUOZQEHhR#3S?f$Y4*fcK-l){##{Csh<=R%=Jt=zG zQjmvINfYSq{W4lIJ@r>fEVER+jK8}3XjD3ca531GCOD^>Na26Uz za6Q83omrocm*c~DAnadT4dYGrJOJkQCC#;kPsg;nZ}mC!eCcSpGMqj_*+=9Df39!T zjr-YX%i)khP~AVFatc%N!KYImPX;F4i?+T=8avQ{$a>W?Z!vj7GnUJs6xj=-c`Xov zpC_43EwQDs&s<TU=95gYKH#1LQLu!*nj{4C3_vkU>I-(!%!R&%sBzN&g= zZA;#%x`))2U+P@-Y2lV*)?rhup=br|1y$8gWY70w^gb>!(r12KjjC7XX2a*ZjNR({ zgSzX&j1w<%ug}i^NwfRBbyj1I-Uu>e6%+E&%quUT8|E`GXS{-Rs;Mq_Bjafkx!N)T z9t6WsT-FpK`Lt_xpO(oM1s`BxJDcge+Z3zEar$PEK<*hfGkeH`f0Cv zt(bBftkTU(ojr8t1gv|Nr@fM1eqmi*q}}tqsm_KkZ1&sByr`lOuMogJ)UAvyOY<+lSr*0Yw>Ow4Qhhoj^+!()mV*3S+? z<(EI_9~4<2x8v0#l0fb+0^1_~gFh&D?E-f`+NFg78=cyjMme}Af4e{-=ld>0z(J-- zm~u5wnmcYv`d+a06`ejuCnJSetk3%S^Y=}FzNZ%BjKXLpSG0Ff28`NwyWksE78EPE zb|-cvy|mrqVI}~)nDR0tEAZW8t&uC8nPnavs2cSxmC4L`3NaOfL?(RvY(VNJ-*YAL zdq`wp!CI02$>_|Zxpxkq>`Knx;HGk$nU&#v^pL0-x`)WXvgDNV{N6-4nWbo4#%7PX ztN5(EU1Lf$Nm`hqt@F?!oPK!S6t#0JJ+m$?Z0}x9_0Ik0uEoo6vf>g;(J-^G>ut_U z98S-`J!T<|QmFQ>=iwJRgecc3zK)Z3E{3(~l(dyR!`5=?K-hc_xUv;C{Ua_>yI7h=Z*GAGbVhiQRq0(u$pCAo{kpRTA zxel1GPM$>YeP7elsYQE{5MxT0u`Mch_>u`qtuzrPj+(7wj~zFmgl5U6!`AiYG%PsG z@=neJA!>uOpJqXvj7l_9bU)mj^Yu;G_53*r>dZI2@tl>Iv0^mu+*0JluY6>yHdsh@v%Oty?<=9tT zV?VV{``eGqi!BvZPaW-?Bpariny_n;)PQ?$v_wF!UPS_yZZeNDB)zoseV)UenX3yBx{^d`I5o1QgJSft zzJHhG=*ESREf#jpdBrMxscF?q5m#xo)WqQWR8@`dcHmC!dQW+YugqK0H}AjQ^7w48 z!YwYGwr`I{4j^$&v0lC&sa3Amv zYGO3vk*>F-2v6nb=4Ze=*YB#q7B6 z4w59nNjl|=Rnioat#}W@p96CvWN2kSWe3d=QTp>kXw?5*-R0{YHKu%xyh{LX|Jg}; z-YcAudeR)Qz@1*`O|W&jH7k>Fek2zx$9IeuEhKJ4c+BVpnlyFd?){A#OrN`M!dVIPM5!n?^d4_0nb&o)^=6)QE^%jKm zUJ&Am$?tJNprwG(6;kw>mm^7pG+9{g7TRotk0)1=+1cCzzyg(us1Dh|L-!T+OXZ=+ z$TRssi(@A0}VkfNyR1`F``zRmYuHK(Yt z;(z9?BL1k2rM>G~_E@W<@12YjOKnvB<0Ro>flzi36m~MFcoZcei!lN4FQ+!V-AXi8 zAg*f2j{t=kHIoNzNpn-q;V}&g1{zn8wiO^2V`uN^R1Z%7N62ixup1PWQ7;l%aq5L) z)EO}FYQ27%Ae1Z}7iwlZ4(7>nU?yh&>3TGh4K70Uag~ocU;0$^II&DRucoI+ zGH}}9=`GK%@k?~Y{BwANzK6O4No;3-q^?KZeul=A{QVJ4Gtj<=A-%8=5N_0WW4Y_a z)8_#%>$Tc~D$&CuYhK}5_pe~hS-I&WXZvWG1SN8&f@*YFd?|Z}M412nrV-Dpv}<1V z>?>wsa^7{U8{aS7zsCIrlPtmsZ>F+JqN2-$z(k-ucAbQG4hYvIYZl*i^ys|OINxc5kX$im7TM> z*g@c>orG*-bGHq4{{?f)1Ua3f9y!)x>hbNTdqpRXBhX`s^f9HU_Mf#jJ|JAh{s@wy zk-^;^oo>`qdHPHg&x0KjM6Llt3ep)u+$s$D7QUiV(z92a$z_Ras6Y&4E9<(e-%@8> z&_Y&pA${;f8TGP#%SH`{@|cmp7xH!X=N8WZZ>4-WVkuNU=?Z+5*b?A1+jI1WNrdva zc<>!Oa$@lQW1W`IcvOG;Z9xaL&`yG*&bvl2$QzSQz4r#b-k97!bfa(NqWx#A zfMX4d4008g>EhS;J7zd3Q$Ec&9{0h-nYYgdn8`~TOq>>^xfw%)d4DtS9?{>Y0UOre zSb^V{XMTrU&FiA8$MO0Z-WqH_y0)C@8`=>(kW@+nY{NiHzTDh2fChyZA?bjpk(Jcij6f_ z)ll%!7ZJBL1B(?`(S z6T0YxfkV90^obf7Q-?@4In%@XguSSM@(zyy<1<}(ADV(x*P*asC7S+Jyf0&U5z1)q zr(n&6zSYiu3WDgP+4KQX@nO@?R^j>M|8*Koi%q`L==g5OU2gRr%n02GuB*7+ELdou z8U!P|SSA779+8H7K7B0=H%o^AEZ#&o@#CFvr)BW#^TxwJANJvr&ojpEo)tN#MnS>; z!H0U5AiKYXA_lk}F zbNB^Egtf;paSAmJ-qpQISZsEY`b=zP(!^1KsK3s3UsZF4p_W)?mXI5(*t5m=n51$3 z8u|yn1_opqeE7JttkEPoEiBmWF5pKJE9w6Zvc?u;L*34I! zL(FbeEG_%^M}f+q#~^cizw$$!St)>t0=!CQmO8MfZ^lhKbE;y=_r)#hLA+>gtZsii6jmjrs| z|J@-9wfc~d2&4sZ^`bqyt5H@dp>N?Q+_)Wbvv_)%O1uBf|7`2`eJk`P={nlM4Qh`H zxp^)VA(Yd2-S0ihRi4Az<9u@pXJ1*wmR)`b=++os46dC1e^MCPl+Th{M;S*Mna{ri zA2Qy`xXkPcl7*hgp!_!U;%aSbZN;T>VX9!(w(E1S?siHpZ5PjBFthSxCMf28v}VP$ z<@K%nWt7TvI`?6b`#=A>slwl>53evb?^Ky3vjf9EzU8VjKbj@LR)Z-}fZlzo;e@qp z5+2TkQqWkhwEsRu^VBCRGp()trt2vF!trmSqh)(a8NVa5gG-4S>`{#p;Or0(9Q8+o z>XUUuJmdV$8uMqicLdo$GZgZ79dUVRO?jAWYEv_57mQdRaW_ zsoB~4{c5vSGNcg{H?duT5YAZBc6$zrf~Cod>Qut*@V%bzZtAgk1{`Nb3CaruUcp5I z9T)ZI0Qf5%O0Fpmco=v)aQ3Fof10v5-!3i*nK>~mnN{W7%AD=pb2p16&uE5w+)LW_ zBvuHTE;n9>OgSJ!c~*z(TL8#!>omx2M(2G=Yrc-JC=x$QV1ftRCs3g~diU*JIm;2g zE^7K~x$$4Ux0R$VzFgll5il2^xLZXNZfeSInnM!}vhO-j6300-@qW(QhX9DKF zIqf{d&ZE&&IOc0HUYWeEnpD7%&K!rDAc~fM-jf-eXlo3r1YuS!Lm}2}jjr+?`eX_6rSXqeK^{>EmodAsMA$bOB}Ht;Ztcx zm*DtT)pTs1TcI+CH9Q8e3j$sj4uys-EHL}=fNI-gvNJs7JVjwlt2Fj;wEpDL9$o%EF&S#URxn z;r^MMq--$k{)+X!X*DvvTGEWEOV)O|%~QUZ3` z$yTxh{sxS@kiQ}4R^ZpY ze-Xg({dn@QjZeeVbqo7F&fPiOeQu=3^Z9Rks+Q%AvkkZVTk`N3Jc7yCd>6PZZ@2FB z%C|>P=wNhGRJ1jHg<0nXh7`i4Kg#lCT2FX^z*=5&?ZDuvcF8+56njGNfWEIb7(@(b zrEyn{Dk znc&h=w)#t(7hSXK#HTOkA|wZ=>U0cb2|ES|{iw?HB8sKe%3FH#65M1e1V?LBHWp%4|p$1hil0-kfCu54MFq6!@Jf5*r@AC0sh>&UCM ze9XdDZe^P?9Ba*;(DbX3lBC|CfMDi!U9!_W(J6D94>Is-YOjz|;k?4dr&(dcbRBD0 zE|UJM9BEPTdDc=0k56sOwh^9`^SgXT_oHpZ$LOc!Lbg-nX&xo?kLM2m`H}JHTCj}= z<1)=J+esGwR|Va!dwcgQ1nwrE3rtgTvoWf#xM$Dsd4~7sRV}b6k&Dx*^;?6mu5zj0|!Mp#PmYh~wn^ zY5~9gI)8&HEB#;e+Z~u3m%a^wn(h|Vpu|`e5Stljp2%WdfU;@Qh*$DZnPSRb%1r_j z^BcDz9>L8n?{PxJOqM}ouC_nW>*>yVko+;X4PI(g-ScCHb3kXoyN-VtKED6GM^a0A zSCs?pdhLq`*Z~jGSEZ%*@!s0)r*J`^VWHbKbHMlRd@Lb#>N2^Rl*` z>09UZ?fd<8UAxhq`u?WoqxJObtLQ1>xIO!kof+wI#X95P`!rlU-Ir;GjrK)kGkVOSR^h+D?Zkv4Fwi}5 z9XZ^mj9}>JLpC&^N>B0&hr2 z3^7qI2!ELXNN-20+-W}6#*K}?k@ZJWBUbCdeM8bQeLBrq!GILN1_||zGkGjI+Z{_gO1%;4Rzhk#tm=%^lyR4R(E9wb>BVl ziD;sPP$bTc-&HWv=FWXHj};Sz0Dpte@ZgzLflV4}Z3GUq-QGoPCK5XPg>LD8nKoX5 z|0`2JGLSV>CIPapqzmkmv@`%NbK4`q6NPl{>;&^fi7&uLUHe*W-#eOb2wYZs^+k^h z!ocMviUaTFzL7yC-}b&{lLqGPsERwQ*yi}{TG0-+$EaeB*WKA@oG$ZecQv7*nF$^N zV?0_pqx#>Sk^s)V>KGXKh*|v4b_dZ%#U? zUK8Dhi+iZwd=t~pIIC!3nrv$O?M>0uPFrBoD!kLKx7?M=86|k@bYGU4I4k_c@9xHG zgz>PG@=7;|db5J&^w6YP#p(g0Ws|T+X{)w(raiBTluuZ~%Fxt2*&SlS@MC(okf+Xl(uNReIj(ew4V}xtWn9_;2{ey-V_(li znhMtQgs9NBIblzuD=Z3t*J7VQHhe@cZ+Otnby=UiIw5xlxY-@H2^t#t(X|4%dAi`0 zj9Fr$E4qclx8$ zn8L>h-k+GQz*J%mgqnk0#F&kLtWPDS+G8pE!f3WTVqs!wh2P?d336SV(YcirSx005 zNv)X-lYuq%z7&mhLok8CJHBpd*^Vt34#-$0FREO^joutYnwcF{_e!U z$3@W#&6C;=#Zk8g%nkxj0z{Acbv{60R?={rJj%LOGL`0nbK*;8Y&tRh^TN68ihgw> zIEeb3Sf`QmH2OBHF5s5C%bVD|ulr8pH$X_bv)t$CnJ?P-T!CFs0jrH!MNkMgWC^76 zl<0Xf>ByTgF+`#`*&3hEb#EHo?^mfDnsgtyn$hKI?ruo6vUYB zh;LD&b^usys>e>r6YGiN-s7UalvzA-5g%69%i*iZ0t|2WR-nn5NQti5hzr77((a{- z&LaaaE@;BUZ0m-%J+mAc9Qiligl7P;7ai%?#S@DR2EkMI%-=D=!5Q=iW7VWSm5<%8 zQzchXu@WvoNE#)1-$JV1S@fi>VVB7*0&f$_stj+_|83`%r}uH^?E9#Iw_Sj1_39ux zW9>~`-U=g*0M88uGs$3bkgQ#vz`O&p?O7(@-1S*Wsq54xF2Qa7CtlgK@(?F%KoE6u zjOn?f*33ums<|4Hg85SpFx@gL3=1DyVUTa?{`~cwzpjdIi~5gtE)rl3jrNQ?Nj2GQ@$lGn3!h2|gowFcgpv4vEaajyYLmt}mllN~ z&SA$869vrZ2~hytFHEZckm3A`Wqk7wN3ks)xNh(G5>per61>mO8mU*^mor+%-)U|8 zap2`r=i0YG=&y0<9D&q*zm$FAF3`P*v566A^nR{?T3@y0{Mv&7U9Q$i@c zv3}MX(>|BkyzVTsfs!d4yRwMn7dD@2$Arc`y4g}NbOP+P8)FUz6i531h^#Hcnn4+7 zPoiR~B|2lufnE3i1huttUZ7mY$e5{ZdG+_VIuO4#(z)aAu=rs{Si*zSYQ>c0!lZd4 za7FOnFYRN--72fugQ*a>dHbrS^F7ddWAj!IJHBRb;*3_L>({6c>uvWkG-1yJwHMYx z#%zfrJ=EdsQn67rsS{%DZM=N(7&9DnGV;TfzgVG|x+OzsAlr|R&EsE+lgl=ATr^mU zUhV5+BoKTj_v_tUD#E6B{_%Y+$g9T=+w9_k#o*aj&g1Oe4ASr!M=&Hv=P0q7x@su{ zHd4uap2hONi54 z5VF|puiYxFp67o!hTbvSb^mSimT?@VNI#*5{`|%Zw1_!GDY|NL16 z3^)|Li|(FYPwbiYUKLV_E#}<1_zR;a%!T3QYqbCIpC9*=3b~V54M!4P@9D99nPZOM zZ)f1InmrffE%p0W>I%lf6l~bx5QedC-+!0!AAaIi z>1c`45W_qPaz>wepA>ni*{fSOHaDlC(O`{}=i^D8CM54W;l%~cvxB^E!6~l|rY;q& zO!fFx#3f#N*4?zceH+s+<7b|Q!h*Mg>EZ(3Mf-AQNLCTjOJRiyESr@D^Rr_?xo6dx zl#`dUpyi-`SO=Wt`DT`~9S@%wcf{9QYxEgu0~h)d)5XF(_26$VK<}!}XywkX4PwoQ zBx%Eax_48D+-+p0>;ah+S|InS0qzgn6j^xsWz;Kvo?ilfmGW5o+c(W`f?!_ZnEVv^ zy^)W19>jX>s0RB*%VgWoP*i#xF*SbyRD|5qL{Hejp|U?}t$!tZeW=<)Wh_x$F4)Xx zl=%!{WWxGA!k#}{Iq4@4X=65c?~ORgu~M)q&0|3eV_l4UV(k6S~6=WT4#|;$@z@VmrpP?js%sx?o@=Ie%Ttw zU2q)Sw5zo7*bNe6Nts69XZUh;XZJ%`ZmW!wxhuJeZ?ocMJ14jh3oO{U2A$wnc~=W? z0X{Ux#42K5-QU&2&-}xZ74dh8Rj4jsPMdsZa^wcnD65s@b)XrF0ztB3bc!Nh*!0 zN*ptZ0D+;FdWR$3X|dEuqD2aY@2nvyn`wCe{TnDy{6r2^K=Mt9QTSs~JorY$S^6H& zRHX2<5$?w^<&~7x3eO8fBTH;w*a61HjmQGbh}2!3dv!Ay!xZSSHFNP+eVJ}fPR*Mj ziOa{19>tj$2e0pZ_SmCiruN$B-qbk8c9wy_hM5)yYTBk-SvC4?NXzEXg<)Dm z*6vy7k5zC9LGdl0ScT$y=CJPrFBqQ4DwK=#n=U?c6%A3avX0t+(H1j*O+Y&{y2McN zm7cWOsUJ7xu;51FoE%B*vF!b;l@82vh~=__rB;SD*Rql#k7DGXSUP9}ch$Ga`o61QV6Ks!|6K$3 z+`|E|e7Z+-wt$zRACWAcDFXbym%7m%RzUvMae*nT{iX<~qCwAI?w5a{xY!5Z5L0Pu zGt?;83wH;v?(RgD+pgbTi&>xhoM`&INZ5Kv8w{y!M~bhpvSy;Cg(;j}UMG676pl4? z7@>LT5JOaXfu8X?(wl3ptp$8gb8YkeWwVoA^S&Rz5Zu*B`e8|~GV>R0Qf5BN?Tmpv zeTQ3s2!DE>_1-GW@57o9JX6}!`jIY7MZBb-mEwRmPr@um6Z18w<>L_tL zdV@nG--xw>r_Sj$?pWvEiM}uthM4)Ay}jQ{C~W_M+VEgL92bfPeZjA8gh!&A_t${i3&5Y&iFCI2`RZH!0iLPKWecS1SiQjcEB67 zST!vCUC3pJVa>Ru>P~i|+WL#EC$R>=xO;+3b)xuTKTBYaPlGFO{(lbI#ti@ofG7pV z@E`j<0+rK0;XD+6suo@sa@^Y80~rw+x|AT2!`E3GdIa~^lKQMYq!L+#|wpz|Uqs>zrfhXw#acHQClakii+^?mYr@!#5MUB+Ed^`AsINjv~i;1s$Y%tMKs z`VMkac_{msiWb?d1#d$}3>x{E=OGLrUfw9AZ-E8+2Q$vVx z#6n>rQ$z8xBMvSF&J@Lh)bBNxG@_%^<1)ulSF#IctQrlNAOhDy3B)vh+r50-NDRh@ z!BpxHAMKTB<%iCr)2z2Qv&f@h{}dpgIPvDfj5H>D`C60|oDC*hVhd3n_nSC@^Y;Zw z6?VC9G78@R4ReE+@)KNGqHU^PYmnIc&1r#{%pft|5pC zPOtoH0yXqf!Uzy^k5xfU)sj!(P4YbhRxQue+rgP?URk)stSOp$%-T2gK?$gy*750A?NHO6~{Pky2vaghYdZzcClGr8>iRh2B|7hNRdn29dsTFucKn*fz zg88G{>#XR#=I!0t&<$3Rd9KNO0v$iUNzYq8qx;cAo`aG|Ocay;`P)aNc1_=P)W<_c zL0eC&{<|@SNeLo$ycNW*a`diT2D|}^)9)K^8Pz3O6pa-V@~Di4r9jOJD#WIZn))>; zIEYLLm}>#3BHq4aif{ST^qZgG8~##*E(M>BS40o!oQKHSH#aX^(%oSQd+XaOsHNJD zE%{XO%Sx*`_j7IUAj9|g9)VWa)Qn>~B?8rnPmVWlrW(ze-0k{N?4jjD^#V!ED@?N{ z)pg5CnTJFsKzZYukQLX_Kx<(L-@uVE-?rv0G9%h1gYK@`i%%3;9HMf?Rc*}J)Y;)ygA<@s%}AU`uUK# z)7fq}sTWx7m)z8W!S70OLzEz!x&^4_ok;4}oVW^7OI6I9GFpmB)lW2N{VX(qNmiVU z)rxE`+Ocjk-!rwwe4|r)9 zmBRuHAODH{`LHKyU)tAklfuV0(NZ&sr=ibjXY*#Q6&E?PuoUiFAFTT0ufErnkDU{8 z`6zm~zc0*esA`Z7LhhN8qPuni{sr5(wsmWG@$L4BXtPfEAAF+6C}|3t{>ZR-ZLHQB zs#FT?4`8*co<9YNfCmxP*#0C2*uk_-MP5TCKZ>V=t{!u$|GCeD1ZRl}9E^5KF!cgi zL_=FD5zPvoWt+9_=&j2`727SGxR=q!BQ_8%tD@RU?7|DOB?R9X;?t-`mZst{n zmu<#wBs%6=^|LvzuP{?x+~IgzF-}3CJ}_4)@KgrXsJ)gA-P7bF>R^ZPBB7-LgN;|E zpJhzR?uiqE2a5oj#w|3#B&D}r+C5&d2d|6EByYa(Nkq8kDfD$ljQmNv@=SQ+0 zqQ%#!4^Xgi>d>h_^CdS2FQCa>sy*61cNd2AzokVYKZvxa?kOO&x4o#?v!$shoWmyj zPicQ%kfow0)Dr+m9{=7g%Jt$=<`2>^@G51x>JvFfrt5)X%NX$%DOK|ZFKhnjwZpEW zphhG=J)KRXAb(7MWuK8VK&QT2!+CtDYibJc7@6x2E?{0kBes2_{sYm+(MlR5^>0b) zKcr;2vUb2j4m%|XN4Nq21V3O_3oi?*5u|ZL{|l8)#O^VW(023d0MnC~>+mv73*{Wo z!>j4OQ0`_>9(4Ycjf%4PeZ#g}+wtmJq3{-~RhOddsezxGib7_8*Y^Y_{LoxGw!6v4 z+I5)LcZ!SLw%>C>rzDzk2~?%OhweI43xRvSm4|9zD=F_<)6vG9tn4{WB{tsTa<2_u zQ9aRa?NsV&Jo3@s*Ztr}HTl(!sK_o&PElk#Q|x*7@#Ep1}_(NeOMsEb*Us7)H$ zM-y%Kp1+s>fw7R_G%@*-DCwxM#Gty*;x>`atmA{pF!|k0HRug!lXx^jyC84MkjoM0 zu5D8Ju-aS!Ewsb>^yG+2KKz{|`u-hfAR8^eAaq4n-wmyHu7mZpk#nqH)TU%lo>;Ol z@V>^_butg>o4bQ>k&-byfNfEcy!5mD1?DsRhX8|;CA^f3bsHzvinPoPvho+e!$J^E>)Z53*+jyZ>} z{d8%Gn_%7#*F+R@HwL!v5Kvbx}kX$q?LFnYP` zKfk~G!;40+s;0P&43tBNpq05le+7p|qkNW)^HYYRIIJcRtYzYDw=}i3G}QLiD2hiN zBN-56OqA&9FYS~-*aTEi{s0qRt|*>0{i8e9A!xAiORnCK0Xnv2Ibe9D;n z6MyxsZjADcT7p&CFGhBOe)^8?kqL9?#$&h|y4*o~sjyS{T9u4GKq*L3-prn8pL%dR z-S~EZ&Bq#`G%?a`eiqb4M5FU_kPRHeJUA(!9Qb?cF08M(c*RItZ!}t91LprceOZ1lMf*<%QIq{M=oG??-j+3a-Sgwxc%sx18^_qEHHE&np4CG z%V|Ti5Xdvdyy5)-FD56}>WYE&RV3T%a*2<0{)FSo@%E+jT8A?7GFS6HUw6yisR>MZ z)2Nz9Bm3C8TWwl4@(WKD0KmXr1^CWwU9^G6?j6rGAK$FG;-J_u(p_YsYddAgZom*2 z`iLq`8JDdU_f9|FuT4F28o?=Q_Fdv^?Fs>M)^NC_I>h=sbPj2|myq<*VKbgU)m|L^ zBDg*vInrMpMO)$arJ=bwc|vddCL;TPRR(E8dq7yN4(Zs=(L{*VY3CHDJ&A&9kZp{G zK9TQyGxP*`oe}|3=t;rBIiE>J_0SWD3_%wi=vBWub6{C({p?j20MF9$92rB@;x$pn z?>TjKcBY_(2KQpB9{Kp4qE}B1OrNZOnSQLV@GCB3jO;lcny2A3mN6;MIk1Fxzqp6v z=R-U^|{Beo9{ozovWKbfp}Gthm= zyjP4a9p4Z3<9BamLZ#5E1NBz@A(gE|oPsKwhCq)oyH4uoXYW})6ZPeYImXB5I`rl+ zNOoavKua_nBQ+o9F2g3|tBMr&J6=qv&w8)qXuFD7+vx+Pp~VDL@J z$BXi2X-f{D<-Sv__#IgUjSU{NV+A1Dnx{W%&-(!BHAZy?p>mNCyj1f`qtmhN6l&d- z#-{Gk(g)VI|4=8Ao}aKymRthv{gjS zAO#y3_91e|));(y$O=jLT`202o^bP_-j~E46ub*v$&&R*jm`|N=^?3el{arzs7Q?+ z`Y@#l#Cd@_!)dLIFv4()@yVI=Yowr9$2r_FQYie@pJ&kG zg16-KA-#;gx%y96W0C93#8&u_JM8WNiY3oB-l@DmE}uyN&>dEr_w~A4aHMnfkE2J5 z!BiwH#dNZ>2uxzN=$?Fi0$K7jSCsbwzC%xwv!>bh!2KDT45#oP!j420^PY7U zF;gW$%pzHLd}QYE+HIT>ZaOhkcpHkPL{X5W?G`u)Nq|r_#1u@4Lf-dV%bD%3=6!h9 zdrY*STq{Y)KT{NR_Dk+WjFE~*p@i+lq35*z_XX-P_RT-c)tWp-g|2{p#7W*I*q`_5 zQ+Z$yQy`C?`SzpJrbDDsL_-%z$eCS=yZcQ<7yx9@F2l0lBq#4&RKzwD5u=MkUjzfT z9o_xyG4}C0c(Ow)z;>&67fTq0LiE7JDWDqoXpPssnS}a{9;B&bN^JSuj~S&wxRa!| z{Ph%I{btJY#7L!2D)x2dL1zY}j@Cw1#=gcnFBAeQPC{P7voh75?S36YW*-Zu z&Usfgc8>W@>WDl(xiAncl33b(-g|InD4|1vdvbD9q4n;tsC|RfAdjqR6IK4Lkw3n# zG!KVxx$_rwc{?@rQQ_pT1u3=GlGJDyq1pnwefASiNZsc)9C|vK3YkCojWGusFe|m3 ziCM^DO2t6})p|Pdr~32WnIRF3mbHsi$X}5pveH-@du0&mnUwst_rQVjNo}~9$x-WP z)pVDu-0!NUll8QA`&2Hk@(lZ{AB@`2SIPl_>>wX?%*GQ|A1SMG_~L@+#g)~CI4=C}TWFve5@!3dq6 zO}VP>WUUyYP|M45G*1&EzPj&pFt$q^`{Eugr!8a~X_ttUJZE6gzA~GKRIl?B>~=nf zDZR3G!VXF(=OV!yK@PKb-@w$=&xDsv7UpvP7JfRLF;mZ{-;QpO%&h$87c}+5Ar<>` z9TrH@+iTnCw29I(TBL#}X~(3Xa$uC&T*c~Ca{u$i&;?_!>jQTgV6}PZB0L5;dzpk* z6py8KQ}5U63j|u>t{X3666Qbhr4pDsMJp}X3Ucn%a^M9Oo}eDf2%RTK-!<$VwN?xh z`K^3~U5eR4XPX|JA3|xZ4#B{Y$eWy{ z0u$>Nf)}P+0V-QX-V2G4#KMHxJov)6i`Q(l`kEW=1kw7Mwz7X1U9-N8in3nk(Bz%* z{pY|iwkuqiSVB8jl$BB){owoj>I2b}mO)Whs$Ip9?SWfqaVR3}%aQe5{VXU8+IC=K z01;%3>q3-NkVWjQi2}|G^Blc3O1*rYDw$B^)^oPtMi1~$zyo&npJk;t|Ag0Fbe)=j zQXa2zbr}Y3>;?j(GBkyjChd&si71AL#mKwdt=VXd9{VgpoRt4|NU6Zp3oVtX1|J1C z%UlQJ>pg#}@y=@pXbcwaJlmD+{pUJxgs0Rq+gpU|I zM3lIVWiKKN=1|AOZm$EKJP11ZUAa2AhozIX*@os9hq7HFFK(!SMa4{#c5TKUKUasq zoVJxb9&9b_@~i5XQvM!yhtUQEWSECg+ybrTom{L|%Q(9PrJmie|E`dWinq!a6R2)SCcxLH!EGnUZ6=7i* z$2q#ZZX;yt8z@$rdFC-g(%C)hd*%%DFY(e&DfGPadJwh&7AEN`-rnrGQMahS1?*;X zZfHUh%HsVkq?{PY&B;WCa`vfV2qv)EG}nd;lqnNYOy4BsTk0t_FCM zYnIBbVPyl;6i6rO{14uCvt2n*#`yL4%%<3YOa_D6683W}3gngKJTjibPgMgngsk@$ zJODreHm(J2oVh4tV5rht73x$d7TUm3QuQG#K%rtWB}tHocYtF?kcqyVK|b7|J@NKC z&A(iLz*xucD$c9T=R8P?cILCP{^9RwO6*H;(hH{Qj5|7`(`=ImF&l zFoySydhBknxLO12P17{#!<-{M0r2FLCzx=$P{R3F^n%ZeWJN&Aj3?!rz0-{K-F_D8 zKmyd(I~+}+pmRlO?*P>T*LXpbx&NQ4ML33erq)l{>vtk7++JBw?3+=^neVTPr5E%r zS2zv{!tVN7L;r8rj-jpE8Pa7^Sj&LWAhTe{5-il+mW@`c_}ix=YyK+cEc%KurmHWz z@+NB@#H&tjoVxn*oSy(0I`p)%KMW#`_$ci}*QsBirL@hk3!3__r-jLFe||PN6pU6Q zYMWgrz0!}L3cXMWCVoHjHY)D#Y;|HPyQ_q)<3%cpHJn}%eI}&*nwd_P{j046Y!{jY z!|8rUl^n*_1K~)hoy{2hUKRx+2)KO1tc8Q>#QO?^bFKS@o!3LYmrheO*y|HCCN3S5H=J%_>jYFI9N!03b z$pQY4k{*>LmoOI0*QOlI@l8g4nc# z!{lpi=Oz#jdDR=rfsmts;+W9xy*NDWISc0vFrAPdVKBVlQOSFC8$qDY4 zhm@V;ync=L+A5ofupJgSY^0z?m;WLM{Bx%VZWj>bXjq^XL9QOny#Jk^#>OmkMG(SH^C$&vdz+B)zgijB6# zBfC@_cMoCD?Ub4#h86i0>e_DruVb!O5jw%yyoE8z`a7$gAg8FzS`+kui7}7Q4PPsP z@bPhd^(6v1L_<&dbT9uKPabzcZ^G&yq_?jMlfT6f?f{#s7zixBx zH;9w{H)zx&y*)Gg3CnQX&Uhl7vJ5l0oJsu=^E}*d1)mt2aP~Ww?HcVYmy_I%ZE;>N zl##hCSKnG<`HX!QJF&UR$6>^LDXc`E7iVX8O)QwaR}kzBb@l%S$HTlAY%K)l4>THL zfsoe@sgO-`i2~t+u^L5SDO`udtrfr38fwNkt(cs{^3!}SVG7!iV*|ipuE#GPm;jte zrw4+?i*a;N4<8)Gu5>c3i|^;%L6B;q^I<&lC(t6B zeCBiyF`r-lz87M6Q#zOhHlCNs_KpiRqXCBAcpu$Yx<<9ys;wG;2q=K^V|%qu4(;y| zsWyyVOUo_icJtySrCgRWt#}{-6J`<-ln5oQ z?Znmi@KISla$BLxXy}i*!5FkJd!l1LeD+eUpd|#QSB(5F19Ck$n`9Y}gSN=iO@tnR z!LgLD?$BeCDr!~hcOAB#fF*|tU=u#X+RQl~vP13BW74u2UL9y-GBk}swNR2q{pK#} zV2omcj~De6y(dxHkO7hQ`BE_J!@h@lt!%R3+&gCDSvY+U=$>`&u)B6PS+EwMF4WuG zvc~&J@NHinv=NYs)+h!LEm`_<(nzPgy`|4~{~nKt)c}y|ZY)Mg{RDF=p6Y@mz%Q{i4sLrTh^}w*nW9wc8g#sR2!V`Nj~H)0UXa}2C!hV)@y*8 zmOf~VXUmuOAx#}A?jdu53Aji)+3n`Vx7|f02T)z5jc9Y4bK&g(ld69wA#^`Dz9xcg zXy3bn`1cIVJauedCp_W&^Bo2L+}Nogkr>>Vn?Le!a$D_eREuO2DidrGb@nB%-;QUZ z!ig!YbN-R~pMJ$^-T=>GiT-f5HFg2^8EQSBDt~oC2WDp>FD1I}SxORCs~0MtXC;e_ zB1TD1>jBLMO<-m192oEIn3HOhCbn#Vq*7X2x%Z98;QTO3dEeo-b+^uJVtYh83ejQz z_yQOM9sQ3sBNH`!0Z-e<(gu?G_M5_8EXCr1V}4> z2D_C%^d1rDK69E&76O;ptP+~N@tdq-z=MdZSjriFx1iWZ^ zvzi%!yLMXWxgM|X$+Ubk}cjp)g&Hg`8;llA1(e~7N=p;hh z1YtcM`a#4TRMQhEVy}%kd!X7=F0_{&K6z+G78M2iyv1q#FViGr_PPdITS7}r@D#&U zt_k2Nh}i|7)?jI0?v(5j)7WVnY3jZj<2V%g_{7?!a@v*EsDTBOzt*qGczd<$PN7R@ zG5LYPU+Vh1<(^!)K6BB`zn~^81^Y8S)uvwJJrB`5mIxhe1yp?SawP1SR}rWNGq(6f zb_J}+l2;{eAF@oI-)HG5@h{eX^t6cWWtRv(%p`TS^2#=lkj4jYSMy@Rpq7L*mA4qV zJm8ct1{m)-U!4aex@Z*4h#~*oR$%&KhR+~d7co>mxQ5w$eRw#aQ#fkq4aQLqg^!3j z-rRRGNOm~l*?KNVo{N0XSmw_%$++z0Z_~GSOQ6kUDkPc`urjw_cm!za6(vJp9)Fnx zkPIrNtY*a;!z12@j|`~nPD@r~6QwPKiUbR6$?t|j6+{alV+NO0qbl2q_8~#t*+YQ< z@E$Vf8xDypZIo(zD>I;z`_gube=S8a+*Iaik7eeR<8pXJ!}u(UR--$ZXHkuv8iAnr zv~AIf*Z`#itw!j#d+%9!XU_wuT75);*sT^{MOyNm#eA;ud!CaxgkRwHv1MLL99uEo zTzVcUBo=}vWG*1tV!>Usz5Aklf+p{oyl0~%CTp?^mf*~vLvM>7GhU0(4(@CQKUFlic7GREtB(O4pwbz`r4ZrB=evnO3;>)FCT z?QZg{6m_8O)rWi@hXH93;9<);Z7i@d$mDopZ^m67`4c~!zRfvz-K{3sqYS4@;xHtb za(z7r0NWI*i;tW}0idsY-<2VYVM#M<5Y5Mv2FsVM3d(aw6poZmC|YNGn7<^J+KOWr zPvn}($~_60aUO$mGV0G1*9*ugms`}mWKh-@pA7|O=b?!VZA%2oXCDuyeEQwiOXU|N z0Y!>EooFK_ZKtj$?E=*##QIbYr5qd!M=jT&PaI}_JpJ=2C9wZ#NlysK0okq;nm z?pxv1OvJ-B6iwNup6ej2tp^@T>J>cxVrI2+;*Vq)`pt<1uVHJHKAB33CaF~yNUKB!qA zPo1kAxNnb>7c0!A#aa*Ebc1Ws=Tg@DT! z(vRdU51&h!uWzm<0qnGJ0sG#UpoQgY8ti*<&2*PLyt)Cu5%O)~`E6$UcPjam32Ow^ zio>L1)og9dYaE=YoilsLq&>0PUBiPnVQ(l^P`{F%|I488fo2`)>!o(o6X9D z5dNM2$eddfG=%DvWc}pih})k~#Y5ygfDGR3*rlmN0&|DINOk`1HCTywox|Ft!Cep6 zAjzO9!t~{GrcQ{2tK_p?0-w?;yC?1A@36X&pB<=C8KJqQ2|&_3+m*EO-}NW+I>XFJ z_>SNkRd9Rt*@1s!MRxG&V$!c3bOf^uD8Ff=x+xEWC)=szZs)MLj#zebw*6sB`A>Pw z@a7JGQEfLcnozC^U9=vRkdE_2FDxj?Altj=)Dn|-_VOWR*PLFtOYjKTuSp zk*QvQ+BE@(fVP*XP$x2B`qu)uhthe^lS=E6>L##~Tsz3yloS=Gp_tEc-l$gOHi{qQ z#yOBp$9fEj9RC0_!VUB^J1=+*CRaeu6J%c>@aU28h6=x{oEYSKn}Ei-_Ohsk*o)6d z{E$yfsJHyN->dAVhia%?7eUc^Js|9%IQxSZc`5STeCfjELO|g~J|%KCpzDukdq^_~ zB;M8No_eKa^6c6xrq}xJ#6Mg8CFV~~{X$`R>pse#@$C7Co_Y7d$$O%O&JB&tdZpZj zI?cacr{{c$9?2TfJBCHiVwW%WW;W562vDoNwl`E$1Lh6m@ONT0EH!tml zGT6mzON5=c0k|k%5QlWqFl614i`no-T{56OA zs1Sl-dIN&SkbRK3u_J*9!9vX8-Lz%JUfG}+K88QlWOX*QUF-2oj*4tE!+2b0 zyHLz?(6M!1U#a|IHoL~*-j@z1J#++b$t8MAQg)L!zHNUxYs-C@*g9kzW$@P4%+7da z;_UwBUt{Ufd%t^hZ?o-vsnpfjx=gX7QBZ2Qe>ui%2T0ke6;%_M=XO>{Kn1tBm8r5E z=H>jjFeWO>8d|7#+=ibwJhZ(X#p=s3Uikmak3D8Nhdp=sC)wN25|zc#7j!0vIHRHx z5S)5j2QWCslN>$ro7F<l)eah(hjs_jH zW%#v=$7=uFc2k?7=kbpo#iGE51!VZQM}5snjc4D!9oQdr=wu36WBp-sEQ5cjLTukp zsKhy-J)|iDfac}JlW=F7Zm2B&U3}QMIAV|3JyMW}C2T)nTgU10@F!1C20+7Dwf_+g zopb^X1E!9Kh0C^W>NtrD%-NgjtRJ0XEeTKq1_%!y3I36B2yq%vksF71;gi4BO;sKn zm(eX4$B~x+IfNR`U3krkBJgNR!NzrU#(mfXk)?xZuK1O)6Gg((%Zmjgil3slM;peo z@SBH>S5l^IWT6WfFXjU<{Aa!$zK}HWk>MV)zUBtp8ILu%Kl++eV?6(N{SK%(7;Dv^ zflvu?GK zY4A6Gy`lm#E>5)0ynfRbeZVB@?+shGA9O8HBuGR9q=}}C#@Yao=E?vt442k^_}geeaSzyXDrl!i_W@FDMO6o3ypEV%z_m7XPFvpet+MNr5M zj^yGv4!~wyHj>}aGthFtOg|pyV=NAcr5#ui4eOGv=Aqi4gFb|^#oKhbtr{qw$1=E) zAZh`mEvR|+o5`*6lZXOKTLoqlak5ZWLAiYV?^xtrr$XIUJ_9C%R3!Z^5Tu6AWsvn(3aRTiDbt6jHC?MP87mG9um-Jqljl2tDv;`6htwJ0 zv|=c3x;1Z_)Bk32s27aZ;zi?J@#fdjg@23aSrnjOAn%h?U`W93J|>uB`Ag7F0lFK8 z2BPgmWtc@#$%3lG-;qN1)|eEgA!toQSEHWQIEeQ($~PpX#vxaex7mT2_oCh1wXVWX z#1GJx)c$ixJK53lkVm1os9-acsR`od4*A~SQ4J5RfJTU_(bwznA99Y#qWIsZ4wf3p z2SOKt&{Y_bS+ol?2~cibw>}ZjHKSTEp{ysC>!DaRsY3xAYRzd z2@DF!k-*dkL+x8?0*D92XvNJPkj$KY2VrZT!n$=Yi8hOofptVp*-i(#dVMgSGT;No z-9yi~3wLM7>Q12nQ@9YRU_Fp0h}=Ah1TvhngZ#D%lEn{n}&3qA*#~rvevlNGNuvmW*(B9{4~uDkVvgSD0x6kMb3Gzw+YMF z)yewUcYyY9YN;WrJ*e_-?Z0$UG#*A<2812pB<@*YMNupZeW>@L<3di6G65qZo0VqB zDmoo=`tJd0Oe5-8B3NRlwMY%o#VnM-o!y8xvDWr1`lQSNLiCkj!Qzv`cKD;^8$`>u ziwSDP}^_hP7uh!+OR=HjrIaCLQ0y*@VVSH|?w$z|&t=}Yf zofd(tf);KSfUt{oKg(@stb7cP(o?7v#6_wY`V3u6C17(TuR=Qk_1&n|8{spAIVZt1 zvh2$`jU=#)`$M@{#`Xu2G!{g2g0UT0cC-(5vlGPgVCnz$8pG1BRLf2Rosx%@y7(G2 z#=lOby8SsFtRC5oLP`f2^qlQbO<W333JQ4N-OeXYI_PQCUArv*0 zr1fk#gn&KP1rhJZ^Ix6Dx3We9Pvcun5=GcHYU^U61jCV+q;MAfZ-IA_rbvZYfJ>f} z>+et*QdO>wBi@g{#Ur$bwsS9weKyujk@XN*g*6ah(c-oN=?-Yfh^~D`AA!fHhB3(} z=2UDSsoC7X(E8V;G#o_00OS&)3cr0=-F!JByQ-(DU?3mH5yb}Z#gBibQF@098~%-j^ohbH7q#B9ZN zr$XhO1kgPO5*o$tT%N;J|Km@g!7%VYUs;Z;7HHxBg_)*$k*wh23Bb$ro zvTS$S(gE;>ZvsELVtYHHPqVT)d^q@rv-VP!bipwTv?2ycM4JtVKC#?o0Cm|4EJFt@ zGIo@OxMv2JYc2N@JOp==few1)iyZQ-I8VCa^xrXGB_->!>^!15BH}mha`7rL5aJZG zv)3+;YK>U3biNga-s?~;7zTYa>T{TqeQorHDP7tAue~FS;ll~OV@`0G!1U~YcK%g- znq53#XDDrHS1Cio(wc6a38@(@g;Hu0-H9Eu^COsJyej}D-#jZ(@Si?#M7lkQot8}A znTz3S3SV{Jr1{mRbTyDtz!+&ORG$1%23aJ}4d++``1nm2rBZIhRXUL(YkKw5y$&_%XgG-ILW*D}$E z8T$`bxh8MT0ja@3G7Jh!>a8eR2AKk)jGe94W%QmxH;HIdGaw3poMmopmphFR~t<2@X&p_nLZw z17H3+Dzu+j%dc_d;2Ah-@t+3>;;w6A$q?(A(N9R$eu1bX6t?FGhocM|*$&nfjjVr4DT>KAH_-7;+}~6@CiPum^jC zME_a~7&qP+oEqz_mHjZtgeWG`;rEuL3>*6paiWFk%g`QK0`(}@m1ucB?P-2kqHr6|0^~ehk)hW74aXS z&Lz)d<)OBrhXS*UTka*UNnl21|9MI!CT_TO6|I|$Jz^Yq<@MeBzYzuYXUW~D`u5rQ zFS!aKNPnjcNeytpOg3O9*HC1#+l8VT2wiHZQ1%0=)kQrR*gWLR6_L|cLjl^ry^&*` zt$~j*EO{U%z~$d!)F*^ca+9Eip%0O`unhAWh!$IhsmB1lj&ZWpz-b@8xs?UwY}X!C zvFcFxC>R!3(U(0!tkyn%3Xe$xzl{!q2Mv4)OGy?Te$9??AgsO`tf=vi>)@Kv*Vv^s z_Q3g4&X%Hor5hjZ)MvRIIcru*!lL-u;N=#XN-d2xDOh!Y)!!d%%d5j80yR zIYhbcG%6O8HTyTKFMc$&USD6cv8jkl?Xeylnivv>K@m~@Tx0@b zGqaKgki+FDl)8&D3{9|DcJ%k1%eSH5|5n@zR%eFDMHIfhO@A*UB~4lm zB4cUJyv0?11}uw_JQVa-V8aWRNJ*;QqBz@l1aGmF7LH0O0y_ml!==ETlvc%uqAfTM zIR^4oWG;Jnet3EC;M~wy6SsOm@6DMtg~Ekd|5R};ouO><7GAb=Nj^B1c<&>rbJ4yL zJ)-Yj?2)TF=|I=yKThIod(y!*>TMfMps95(kvY)w-o@Yc+&LSHLI3)GPY3)?=^oL$ z&q~Yo&6Jc6=H}v?hLP3!6dW@h;@#idN{H5z2pE&+vdZ(|Ck>mg8HEbmTZ;|1nqcfx z>{4Nk_tjHnb#`^hURF5=VGk`x%cWq<1M9I{12fJ0J6>PlwTOZH;b-;elg9SOr2e`4T#8ZitA|bVF^*wvVzm}W*>||n zVV4VkUISQ%;jz#zNl)+lrNMOyk6*a6?AxqC&aqc^v7D`we`;Xu1d@U$@Ao?W8ET|1 zX)MP|R+si-t;hVWe~wz$_K#ChuRXw1q5(Sa<_Z|HJzCE{|=i zQo;B!lUf`_C#a=DXUk-c)vCluFJY2g2)so^<9Y* z`Z8S1ynn{;yHj&(^AG!1ccr?6NGTU=iTBQZoUc`zp1Kj6szJMOF*LsJsF%dh`qOBI zXnI<<_hGK)IuZ#O9{CNc1jA|zz&2HT_+8*--DKQo$6vvKrLm2)jB)GdzkY3!7)YLT}j=&L|#ZC;@k1B(iV1gy>NePT2i|)9)IqyX^l_r|Fbx^ zUZ*(dw9?QzD1-S(#0$BWyoN^~94i-r*Sx=Sp;$(`!t!2Lu`o^lyFyZQ1B+JJ*~B$v zyradhL3+uFxkJW39C6W&|1cd7drZ2&8alLmRW5xeGd3wpDjJ`D21_Y0=<4y{{`~pA z*4#RUwR&Xy*?P4fxevPiaY}E6emcwm&7W@6*ipNeUt6gJY+j&r7;8PFxxRX&VSk4d zb>3qMMn0~IR(oi?_MEV$htuK$B_e4u(b0SCLSd~oJr^W46$H6V=4h=JtoHmiwAz`r zRlBw49GF8hlDVm@$%l<1Z5)iIJ3PA4ibNYOTB~mV`gjv#8%o0{2GhJAe9kU-qzUE_ zR;_j9C9LD@!MW&l%b3BG*5?&RZ%7E9wj-q{EWv1&@uc+W88>Rl@gumh!(gRf`(q}Q zORr2n-GMZ$aKgj!MvU7-OQeN@7j2d^qxdRzcNdi2xsiJOl^sbs5r%nj!=bwl_DJcm z3TvJ)4!QI-T4y`h5nauIQMAsOa!&f_uDNKVlM>r|8ev+>WLS8$1GVV^x+Fbv-k|Jb zOMHn=IvM@>@kzQ%`0}8W1*j8TYR4r6Q#by~B02>G3O@%$J)71z+55Y<3hmlM*zW6C zkrJjxli>&$)k0G6$gojW4Q`|fKLQg6Td$DXaJdGzIJElazw1r)*#}cSUf9y`eG;v| z#F|XvT+14asVarB&8{1r-5@bOSyh)iK3xI+Pr$+Ge35r0$y5vJ1}klvKb(5JqMl@C zERJ+5WpBIZpa(S;c4m0nT=c4COeu+@CQ>&Xf0?EKuL4q}Q)PdhTA+3>M-NBtIbCJ* zwYk+J#N)gLe-BIWa|gHNOiY^3Dd_C3Ln0yYVVOBu&??e3jBmCgvm!SYHz7Z3Mi*_^ zjn?+7*{t!Hiu@Jp^XNJ5@3#j2EQQ5dogQ$1>TKVCG;xkjV-P@ft~oLq_=;6A>)yIp;7Q*qLv)oIa* z#2bdH-h(`_4%ub4uGuX~WxHwgiOo5`SWjsxCB6Q0Yb423t;qWV4t0=+p1&Xe!`R<0 zB?Uh~OAi_OyuVFKvGj;$8ksPA#AlA+6Bn%8`J**~l)AprE|ye?6!z`~e~6im$6BOIk_6-PH;hW*p)eC403e$!hH`k+XKRA%}yyw@8+dGPhv07v>!mjehp4EYh~3_khu&*6-05jLbevdieC7Jm z739`;Xdic#cYW#UUKsx)kdvE+Bp_7RpJHZg^P`;093Mm=HTcOtTLsjS&(16rg3pH4 zp?EzA~Dd<`Q`^$>W=T0^fcCTbrpjtyVh&dnwQ_A39^GOpZhmjE$M&g yVLB4!S&OFdD*y3U{Wkp%mBy5YSCd + + + diff --git a/0.6.0/assets/images/illustration.png b/0.6.0/assets/images/illustration.png new file mode 100644 index 0000000000000000000000000000000000000000..69f739c0573c2bd8847dd3e3eca2eb46ae054433 GIT binary patch literal 197865 zcmZs?WmH?w7d9F+w1q&6OM({H;*tP`5@>O!Knta~yM!POULbgJFH&fWOOZmMSaEj? z?(S_azyG}--gm8gKFrLXb5>Sn?=#PSX77C>HPzuH59uBP000sdWkqcOfDi!y;8zgg z-Ou3nliC3QcmPdR-4}2d)$#d_wXMC~qqCjE>%-HV^UK@w%bT-{%YXl{*Vi}aSAQ=q zZ}yIF?pt2%29}pKcYps~TwXtx{(N z3_1tr*u7IM9uXBj8Q<*sEdeF$`0PSC;&15J%dw@Kof9k(i&g*J4Hq;Ns#`7q`|yCn z!!GUo_r#^V!=SA0_ol%M3H3r=Dc`crtHYD?iKb)9~QB^xtm`-_j72ad0?fs z>!_k*d2)H*H*Rcbc4uqR2Ygn7V-y!%pp&vI?|@=KTTs^3fBel3f8otCvN zm$WPu{#Xh~nq1ht%B^2o-NzO*?m}%Q1so6lo$s+}e37!8aG7+31muh7)9FNJgW%$D1qXUlD({%c)(fNx%hnA_dmm#_{ ztOhe=(%IOBw5zoa8qHa3gU3ng)7$Y(a*ajoMEv|VmP~biVsaY$D-iqDer5|hwSj#k znmM+Hb%_`mUd6r-8i~vv60sPAXpORJ^-!r#^BWJDAV!(=W(<7B_A(+4Ec6-l7j-?y zj(=3Cxs5x9jqq4)sk)9Uy3CuJBY36kNxhL(Jn*-nP-)ztT30345c}=O@wRCMsh++3G4(Y0F*kmQ^A0NXqL-F6{~)aw!mW=Ks39{x9kO5LW+>@&7x_yzh=_#M-z26NjXYg}*M59+j|yojit@TXID7L1Pw0h+L(K)? z0-Sm+SUu@Q2@&u^(BB**YM)+hoO`AH|6Jw6=cYJ-WsV#3%neHmtJ#CDR)0zWU?HFq z{%6Io6(0~ZX6|*n^enrN8UPs9Sea~S6!okJV<`Xt*q+EWpSS-)Q+;XCP%94r;6GYX z3*_@ZNXh(x3ux2x#ly&rmwsL8N%`qmxd$U;WX6_Ry0AMDl zlGh(0#U}pKQp5gW_u1vTDFEPM{JHRyBCm&N;n(K;!j5j)spcXcpzR=2I00J4FRGxho^~E!aZy2Q;Ox^51^X1Iq0GbO8UZ(ZMv1mWE)TNE-ANtyeybVHw z0f0A^Q{38IT&x9+bG>(79mQ3CUrxi$Z~%7}hcZ4Gr3Ar;@PV2&MV)zO${v!WA)~>E zgU4>ISggS}2u$Q*?q@Jjb=#ok`46KB`p052)JCRK!uBdjDwhbNQkSUS_u3Rj5|X}n z&wo6*c<@2aq`?Ixf@W$+8$fyVI6;87SD}n7%v170b{s?>K7JDa{_U%QUTv%EdEdD! zHcI4brT%K(qQ76#^SNvZ2T32KUqLxlsqfgz{=%2hiwvJRo1|J@C-`Jy_t@P)>CfcF z;Kji&j7PuB(~HN=p7i4~56Ru!4prTQJeN#CF`?uB#JDV9p*rJGLwepSVx~+p<@xf0*(L`spkRlzRTSi zk0znL!@5}khl7j{&wo5N`=yZCfFypTo)9DUZd#r!vp&bmpL(}PnomWf&WQE)sjZ7M z0v@r?NL7ZgN(Iigw6sWHYHW!PQ`!0HxI9^5Adx2eusmvI@Sq$c((J`*Of!L{_y8nj zTw$=jJ!U!Rtya|e3B1+lw`MW9nF5T9eWZmqd?+$98!FR|q?JRsj=%=%E+uGbvL}&?k1h@Faf5#a znxHhCDPfKy42<8-*;q58Z~Ev-9Knc~+L##SM@PVW)%;NP<#7mZT5C#ghu zw{Iam8WH{;xFz#1YLGy+L?KyhImw|ia1zt)@WI4XNJ02-LirYoWu0EMX`r0KKMUWBC zu@VH8o%GQm)M5S<>K$;QBtAZNi7y?AYE^!-ubON~hRr8vk2r|0)2s#mqNRey1bl+3 zVN9KUyMjR!vKEa_be==Dj==h%(M_>}J(cRkpO>5u=)H2kz$>Q+U+f7peO8Rtl9m?) z@tf}dP#E1#_bH?J-sxV1wP-!haIstxCGJV|HGgN(UB7i}$=i$;M%8l*;Q zgYPonmd%)HzqxmP=ymk$gAWrM8|R`6ETXq@HPcG!RgbTX#j?`bWp4)jh^N#F4vb3n z<&aKKaR_P^_9bpLst}zaS&|i^y;+1hmblF-Tmfm-v-rnp#r6YIrW}8#X-BS}Wh#wG zlNi?7C;SeR$=@x~x{Sy}2BaNkn_MRe&$~=o&T|BS1DBCPSq2k4@n0!ot`RbY{tkz`9Rm(;E0 z)xG2iSP+>%4Y2dSk|^FcTV$|ry{>sSR4TX!I6NYjgVHD;9Ou>~+ym5Asmm94PQM6n zdq8+k_KMA%XF+aw+}pbNJ>F9?gZ*C`M-N6MepAH4avJyBHXDvg&cJdIkJ8_v zGIME>xw-qjaO%q)by-{wo|kSpke9U#4g{$?xx2U8P0Js?MYO$bD!t)4j#cKB?JCJ) zG9=+QF*5k9^H?gK*hH2n0$7ETAZa48`;HoaFGnT%$7Uz_2La82%KBQy+@?i>|LCo7 zE%-`CT$HRGJ&PZ z?*UCH^W8FKTmbchCFK_hAo->@S-V9m5dD{nUd#U167~CS3wYHmpIOc~vLsiT{Rhmk zDx?PtmTBR`tPIY6I!whhwdDAJu5?!7h&6bYbg3N41xbFH(;7YJO&H+}EM{qh!&8_S zwlwVn0~bUZS~?HfVSnrMkpCpJAc1$ubtw7+$na8;GLRcVvFU%JwHWyASN9~@1Lay$ z=@zYLg*lcy_crVbt@B02ew8oh)z^-x`UJ&oA?_Vr*>d+J^7?kZp|&by<>{PNk!I$d z(Qfl+H~We6-N!n-&4uwT?6KuR4PGPsAJ@y9`HgM(hPhEy1NQI@@wt1aSQYYYHs%G> zTuGMYh#y&J!*CO~r(0fP#=IM|t`VCY6=_3Y^N88eWDFpx@byh)cWy(QC(sncT!7iFr zdY$f6f5GIBn$V9vSIb?^Yd-30B#66t^yy-MbK)P!pHS{GP%G5trNR@I z?bRi{Ge+@Qza1;lNxvmw9J$P$UvfE4H~lffL$0DB^eL~Ayvu9mKqI4WG5(q!pNcpu z&=GzFzZr%g&YeBGf$NDsH?D+AUM)^{EWx(~2>?-n8J&gH(tZ)O3gze&8%GM%@046) z=8dWS%l#i!cxN$FZ{OO=LFT|Y_HEgQmILP9ESJ8%uF*2v&+Wu117s*dq`HqH#Cdqo zkN!q00ENrsrnN@o$7zYAQcol^8pzjFmdR@!<$&7{G8P;kSD(|TJYsnuHI(!BhoN!a zojAunQlr?-GPo50HK<3+QyM(uSp7V_yDOpvgiPf_IHQG)4fE_|B#=S zvE$&`Rr$HmNZ@!ENv~9jUOXp)m2*~I03L|lZDb6a>$c85wwv}@;UJ`EvXpxQ&}Pb7 zdR_SOoU$*;B&V?1+S9()*uX0&WpPXFb7*=M3LCI+F3b8PCvr(s`4P!k2Th>EwES!9 z{j~?@54X<1G6|4h&`RoPBO@b?pCyXjVn#!m2@HAN#LSRny{ULWW#Ne@DSK2ow9V$& zsk`|GkxQm7UPrHA%6}$VyjNO0w3L(EY+X~^(t@;TeVKDD&YlA1JbaAQ7k!n)_jq4i z7v3DXe{*7hD;*S0zPhN@EBd#nE+TIzk*+o|Ioa~NuWA^0#5yG?W9^8!fr-wx5JY%X z5t@T9j~n|TLL!~*OW)3;{Fn$-#Q|#})%IN#5Xq58`ofvR;+s76g@e;K;_d)xQ58JjEuf|!jj4yHnOLItE`hC%%;>6IR ztbMH}oqt3@U45W$Q=h;Q(9w-T4yPj}*YfF;Ve8g}n-I3vBi4%s(%RS?0t>tdy<*6uYn-He_1aSu2*NtRXE4OZ&pP*ZX zNhTbJh$8*qp;+5frGnR?E~iZsRe0mtGdMS&#CeWjQEIOqDU%N8L_{7Or}Be7b?76TtdB5z z;(sM7r8=o{|Jvx-}58izzDZua9*YSJ&5vP=CpVivJPClo8@!5?(z`V8j5GBr_wLKk4<0UwL3vm!IC(R(8% z0?`LdYqS+(M@5`bLqdpLjn{5S+>J&f>n$7l3mX3vYJR;pL@}ShCXrPr((bL(qG>$; zy?OQB`CPTsV?77j{kWJ}m7My|jp%V#o_}%pwT$+@uk`f;286w@Pb_oYXBZnEuLuS+ z#U+mGcAtM}g;0A=k`W~Ow}x*M%v$~^Pz`4Sgpdb%$m}v}+k~%&d5yUbWLpR{s-I;0 z+8?@-)DuIyvZcKzspcl&&e9f^K)%|H9geAlG2lsa_+w;Y2+Ykk)VPJlOS1#qW-+HP zp56RF`djRNxBg;6a&mX*plK{F9`Q*~jy2Cwd>@CCgbG=dYIk`iqiEu)MBJ+MYvXw^glmSqJ>Su+(fb-{^f?_$Ihaj5_P5tq;gxHtK#^gNWMvcJqdmZ#=rzhBNx%2MP zjxH%6&}H@JzUa!$#TEog#S*x^slMd7g^yhPe#lF5(D`s@d}Nc6do6NUWaxmvT}oxa zvuNmTN%@^#!_b?H`7qWp$JOkf#|4^`kIM9>!$Ro9*d3pe1Vc)6LRy(g!ii{-wK?Y- z_%h!OApm4Um?2?AY~`BNwbS;)y~>O12``|i*f(j!IZb_^?{9eb;9l9rtO_H_DLW3U*5e6hAiu4Xc! zk67glr&~uSMy%ZFJW7BQkU_%{bws&S_=)XOsIg$-thr)y*51H{BY#cGQp4bAW~TB2 zGXBP-$@=xrpG{58G#ZNuw!m8MifW3p#w<4IZIa$)V z5@{zPS&s6Ej&)qn^mIEdlHx~Mn>Bm$mvYLc$V~XwW26l6Ms6AaZ7qdtIc|5$%HD|V zku)1Rz$+L+p~nhW42w)Uvfqy^7W~U@*L>mpsG=Kt3-RDN%G)!0+s@G2QD4x&ry9iZ z8J(Gn`t5%<0vFrM)zt)Y9UcBDosMC}J%%0*$+$OUKI7pDq*TX+2GbjXn{JrL)kxjTfcxNtN_1pNB z^yV8$=tRA`ZtaH3lJ!YA9@RY%e6B&J9Nz8d)n9e>V_UKZ;q~aoBtw<)<+mI*1YMs8 zVQ%=p>{|ML&<<#lQNkaFjMD|%%(lZu6U9{o0$TO3%Y15nY|QW@p|nb8dpt;8MFECo zPv2PW)*)#-G1*fPdfo^p1hYQuN>kwMZ|Ja)FpT*gCKk*@Nk_&sjEOI72L9koeT=}B zGF-ZOjrLQm1kn;dLWK%+YAtL`22OT}Ra2dt$1VJ)uaGDFh5Tz3f*~g?g%0{4!@PV}`~tP4Re*1Q?VFYxOq>{qX^v=5^fp z^(!Mg@((Ky&#vs-8eG(~At7ggc1ZppU76-lsp{j2KM;6a$8Y4>g^P>wW11+M#RiUN z#g&9sAAf(BXFlCib}MpaVEN#4Fxh=h0<*FahtBzux}EJU{?r(mJ5Dy?@I?notM5Z~ z7Ggwi5C@Ab-rh`1eEhQbF#6;`&LZ&M#~j6a`?nXIaitt++C=!qn>U%_FG}U}<43}U zrrx|?FaU|f*dB`SG2Q>eM;d|p=$TINM6Efl49(x9fKCoSKO%mYr-TxIeH+UUP*&s= zpL61L;zhf37%7`71qz=|)`ieVW(a5%JBLNX1p;_&pv(~jsZ%OO?FdFZeGborPMW!=)e zvMleG4o^<_o%lR?-ue^L7?q~Z=5#7c*%1QYouuFEOC(@?{-(4%VY9R9J9neUYtMbKw*H3y$Cl2iPaMZjqh!A{(k-f8ET6 zRsV(Ze&T@b?(Q0(t@}K+HWl()`u|XUo6gDq=}v|}NfqA1+~#7Qu~q?MB31`PEkg7f z%;U2gg44}n9S2oMb-5wiEZa~twvg6I`*S|u>d|vjkTIK7Fsm?wdC7OLvFfgDaR^f| z@Fe$qq1RnW&kecu7h1qKtq>#X?5pYQa`=z`$oDE&YAS}3xvQq}?F`OK#+DcH#*J|% zX7EGbHOfynCsSjaj!x@&8hDFWN{(|f`fKpy3v0`D*Ss8)RstKc#i>jX%e59$SA!me z?bvL8&iek_NTFIL?(0?!|OGU3>J{5*_j4SIH2?kFOnceZ$dC;I7EDw4_)$jF!u zd(Gb8>InqE!^r(Me}+vo=Cex9bumfD)IEb#<%k_3W(`k=jBNw|$7wx)AIIb+ers7R zQ@tqA07PJ{WFCxS>U>U7t68K%Q@S8|>rW^a1()tJ?q!m3zJLD(#@%KaXIO!Bcrs;~O6Ak97K6zaZk1HE@ScW^r zU#*8QKIbQ-eW$D0!<+F5=H)ozVTMi|1{l`kL`RorzXu!^gTsH_R z{K8jLSIIalwDOy~=`X1OjZ{M??UvIPt=cufQPP_E`NNwUunbkj$G#Ss zy=4=gpBq9aCDE_XghDMJNmBtJv9t`3@H>uc&IUroh=`*PqhOqpa$)5r)fG}g_&1DG z^WZ>cd7OeKatc!tAEgO~Av33_m%%W;^nf0O92zG=mU567F+A$c_@&R!TYHh!R3<86 z_x-o_yNk&>TfLzfeebjVhIxmoc?3 z7eW~Qy&qohW)saal^i=14N2-jsQs=}s=$pAW+e4J-fhvD0dB(dc%Eje>mwNlKA+`y zml$wEG(>c+J-FUHj&85$fAuc|cce(<1ZkryK~~_J54jYQxI(3W6$|9fq`k=HAuX8A zg&j)XB<$Aw+_V~5s#Zae((SiF?8-k;&wJpdJC6OU zPOjaB)wB#Ykcvt*S2(o5(Vv;5YJhUL{J0GohWWXLlacYuZ+L1bBsOR3M5{L=a&2>_ zc<>1#cgVgFnrKH7TeBwRyEN9?`1SB|K2zYeN_fqsrp5l-LwU1xvyX6RdIM5;&LKQ4 z!(VEeiOY=~`CPWGxf#c?tI`5KH!*f9CWS1K814~o5*=KqK$YL6!%N!3wDRbwVq`tX z-q&k;rHS$k^i@%owhcTbBJjB4BHZo?4Hq+%iPso?Y$Jicsw(4A_VB7gi*ad+VR!4+ zb&@QjexZuP3Hf|gAN#v_kPIsA|=Dr9yT`2G6#U%q|ruWB8Y z+a9CYaE+k0XE{g(_laEPX>GRJa3D;}O#dKSY2u81He{V)6b&Lupv{)7sth@b-cC z`M!knVPq`iV_-x^1zos+wC1F6=`54)9{Z7*Bhr^FdGe``#FPD^7YKB^D!6Q8HVw9^ zX!I|Alj^r4!xSH+nE-(gQMRDYj8ljfMMYRcb#>5%AD=-c2?9pwvr8nGf9bb9m@R1w z((4Nl>VPPylfes_AD-y)10u-FM?Me9Z=@T>TFT#ZGv*6TH{?=M)u!OnDFKNV zz_Cp_-C4xJ0aDsY@~=NS|L-4C&|9yHA!-Ux(xuIKY$6;z=g>=l)U|}JFFGxrc6|38 zSD%~-95|I(;|jVDl6@pmrD-J6+YNh+Vw*7F`PJF|O2Gw=ERqMm*!HfDl(5?g7R0Pi za)vcNezmIE!}#sDqSk^8aeKO494Eg2Ju`c?7YsXhCy8zS??9w5G2TM*gz0HL*) zyoXf#P*Uo#FLkqf#rC!#?;e3nyp9TdjxE0MRIB%qjF!W*E$70)oW~E2%-HAxq@D(D zo!OF;A7ibJjI4c3Yo8xyYS=d-ez(oun)(!lW)V=6+rZ2{d0yBQ}Kwx4cFK-#bXpnZ;`Tw#_l8hjfJ!uS4s~b&bWt$i8agu?1DhFN5XLk7>E(`e}4mMo#wG~oru|lPs9?yt^3cBRS{_&%Pj6Gwx&r8;c zpKUdy4_N)Vu+H{f;jJuw1Apsgdbux=8az9>Sg z`%QWlEGye+`VRiYN6;)B{F0XKVausbZE_!b{ujQ zE)&OFk@Ko#GA8G&FeY~>uYaJ?qWA%#L^5~TES-Moll1ML~9i|wu0Aq zDfE0!4mK9*B(V8@*Z!9#7%}pvlMa>Lf$oD$kJuLaHKtlm(yV-wYmM}maCsYClgBHi zLFm`dQtpPG{Q9O(cU+JU0)45k5`f0*aY&8+x~{JQxP;QPxqH4lXK}yM{~=njQ>}OQb+gqpf*5GGeWtxyruUXWIf1 z{dC!=8F95YIzl9# z5q(ui2D_;KyyDER@2z;h(~dfqJG*YL4`@uKGI~`e1&za#VFrciGdhd!Z)iyyS${^K zjeLa*681$%)0979WQpavd4){eO~t2w=O6ueeN}xt-j)98MN@;oAvzURq*3k849kH>4D7{$P71hUxYHJx54tAZ z;Kg3VhitSS|z49PbNYTJ=-fqj(P5EtLr&CR!|7v zj@A8Z#sGinr1i$s_T06nWG^VsDPV#D&+~lip)b+#YOLLY_CQbHT&xC1vtl%B8(EY* z@7!2G>9b=03$aOUZmw;u&-6y5u_S)|VnWDj#TuOKhZngBwW-x^6G(>k&E5Ii(WQ<{ z^0RBmEJ723iS>KM$S*)=&c1OURMi{CTs4l2p@9O@K~fGaSEc%m%)CV@l5Ve$x-Y(q zg@A2qYgmS5oc;G2?ZV%kv_4)1@g+NeH*2kkM$&#`nql>a!@Qa@fZzopubsJX(w z?5k6pkuS$f0!K*oA#*iu=G7>^7?73B4_ga9d?4XuFd&7b%a47E+z~l<)Pi`$dH(1Q zWx4wB+m^LhlPkI2HG=J6UiVyoO{VTe4vjri$GL zj{h#>CyeyXd&pQP5JLY8d>`LZzDxZNenzKcu&|U93EMk-KMDZYh{5K#C-Aqih*-}6 ze+11+oS=m_Zxks<-1!z19k9Z`R){NEjT<|RnXXg|N$|}-{@XzIlL%VnHT@jTO-f{Q zCiH{MCtYDH_xKmyshYUg<r<+T} zB>%O5&grA${RWk>c}{m8*$;jeXqa)?zR(3j;a=`@#`6sBrFhav8SRtK7(V3nlzjG4 z>x&%1adVzcdHk3Q>(hIdH&#Rq^WGg{-HgV!srUeT#5&Mhq%og#8luP~rc{>{ffB{w zJkC%SUJ$ejW%?`=f9S&ow5+&kXU0?k9-FZ_T<3QgO#W~8tEEWbp)h8wy4tq-@-_|6p4k|D2Cb4jsucz=@j1d>KWQFyBEO^udE z$GG<6C|E}8Xcg*rq$Q9AJ*lzkN*~LV^vrtiR~IY27unfk@7&lWla6n83!ORIF<$?B zgU-e|mcwEcX+a+pPB;mT>`zhrxxcfFLOyCLcz&57rPomw_RIxUHgt4FNJTsskM1N; zFfvx52M7E{(b1|*g~(QLXm(N>#6BhvqhTmkdBr7brsqK7+&q}>KxCg!awJj#FbM?rcWXKPeW-s6kOUZ;?RnceoZBR>=YcGD0O&Mrlzy)>9o#Y!JpkmWC4)P+ zMtd!RaU4gdiF5IXoGy4a&nb^m1y^Xi0IqEB%!@sSfmdvM=Hu%Bt;6rkfLkao>2HL% z(-^M3*b^iGl$}AR77C7j!YK2Qus4`a4ElMVt@bX6AzF^2LjLXxO~IuU#EpkPnHvw? z9Vu+8^Y&|>oq;gMos7@H_OaPW;cNCrl!cIQ-Wkq-XMH{m9G)zzli65 zwl8syKF%({3r&l!7uh0HBQhwD0qThf3t>N{yQ)ZHN3CqRnRXr^m*2
    \n * import { animationFrameScheduler } from 'rxjs';\n *\n * const div = document.querySelector('div');\n *\n * animationFrameScheduler.schedule(function(height) {\n * div.style.height = height + \"px\";\n *\n * this.schedule(height + 1); // `this` references currently executing Action,\n * // which we reschedule with new state\n * }, 0, 0);\n *\n * // You will see a div element growing in height\n * ```\n */\n\nexport const animationFrameScheduler = new AnimationFrameScheduler(AnimationFrameAction);\n\n/**\n * @deprecated Renamed to {@link animationFrameScheduler}. Will be removed in v8.\n */\nexport const animationFrame = animationFrameScheduler;\n", "import { Observable } from '../Observable';\nimport { SchedulerLike } from '../types';\n\n/**\n * A simple Observable that emits no items to the Observer and immediately\n * emits a complete notification.\n *\n * Just emits 'complete', and nothing else.\n *\n * ![](empty.png)\n *\n * A simple Observable that only emits the complete notification. It can be used\n * for composing with other Observables, such as in a {@link mergeMap}.\n *\n * ## Examples\n *\n * Log complete notification\n *\n * ```ts\n * import { EMPTY } from 'rxjs';\n *\n * EMPTY.subscribe({\n * next: () => console.log('Next'),\n * complete: () => console.log('Complete!')\n * });\n *\n * // Outputs\n * // Complete!\n * ```\n *\n * Emit the number 7, then complete\n *\n * ```ts\n * import { EMPTY, startWith } from 'rxjs';\n *\n * const result = EMPTY.pipe(startWith(7));\n * result.subscribe(x => console.log(x));\n *\n * // Outputs\n * // 7\n * ```\n *\n * Map and flatten only odd numbers to the sequence `'a'`, `'b'`, `'c'`\n *\n * ```ts\n * import { interval, mergeMap, of, EMPTY } from 'rxjs';\n *\n * const interval$ = interval(1000);\n * const result = interval$.pipe(\n * mergeMap(x => x % 2 === 1 ? of('a', 'b', 'c') : EMPTY),\n * );\n * result.subscribe(x => console.log(x));\n *\n * // Results in the following to the console:\n * // x is equal to the count on the interval, e.g. (0, 1, 2, 3, ...)\n * // x will occur every 1000ms\n * // if x % 2 is equal to 1, print a, b, c (each on its own)\n * // if x % 2 is not equal to 1, nothing will be output\n * ```\n *\n * @see {@link Observable}\n * @see {@link NEVER}\n * @see {@link of}\n * @see {@link throwError}\n */\nexport const EMPTY = new Observable((subscriber) => subscriber.complete());\n\n/**\n * @param scheduler A {@link SchedulerLike} to use for scheduling\n * the emission of the complete notification.\n * @deprecated Replaced with the {@link EMPTY} constant or {@link scheduled} (e.g. `scheduled([], scheduler)`). Will be removed in v8.\n */\nexport function empty(scheduler?: SchedulerLike) {\n return scheduler ? emptyScheduled(scheduler) : EMPTY;\n}\n\nfunction emptyScheduled(scheduler: SchedulerLike) {\n return new Observable((subscriber) => scheduler.schedule(() => subscriber.complete()));\n}\n", "import { SchedulerLike } from '../types';\nimport { isFunction } from './isFunction';\n\nexport function isScheduler(value: any): value is SchedulerLike {\n return value && isFunction(value.schedule);\n}\n", "import { SchedulerLike } from '../types';\nimport { isFunction } from './isFunction';\nimport { isScheduler } from './isScheduler';\n\nfunction last(arr: T[]): T | undefined {\n return arr[arr.length - 1];\n}\n\nexport function popResultSelector(args: any[]): ((...args: unknown[]) => unknown) | undefined {\n return isFunction(last(args)) ? args.pop() : undefined;\n}\n\nexport function popScheduler(args: any[]): SchedulerLike | undefined {\n return isScheduler(last(args)) ? args.pop() : undefined;\n}\n\nexport function popNumber(args: any[], defaultValue: number): number {\n return typeof last(args) === 'number' ? args.pop()! : defaultValue;\n}\n", "export const isArrayLike = ((x: any): x is ArrayLike => x && typeof x.length === 'number' && typeof x !== 'function');", "import { isFunction } from \"./isFunction\";\n\n/**\n * Tests to see if the object is \"thennable\".\n * @param value the object to test\n */\nexport function isPromise(value: any): value is PromiseLike {\n return isFunction(value?.then);\n}\n", "import { InteropObservable } from '../types';\nimport { observable as Symbol_observable } from '../symbol/observable';\nimport { isFunction } from './isFunction';\n\n/** Identifies an input as being Observable (but not necessary an Rx Observable) */\nexport function isInteropObservable(input: any): input is InteropObservable {\n return isFunction(input[Symbol_observable]);\n}\n", "import { isFunction } from './isFunction';\n\nexport function isAsyncIterable(obj: any): obj is AsyncIterable {\n return Symbol.asyncIterator && isFunction(obj?.[Symbol.asyncIterator]);\n}\n", "/**\n * Creates the TypeError to throw if an invalid object is passed to `from` or `scheduled`.\n * @param input The object that was passed.\n */\nexport function createInvalidObservableTypeError(input: any) {\n // TODO: We should create error codes that can be looked up, so this can be less verbose.\n return new TypeError(\n `You provided ${\n input !== null && typeof input === 'object' ? 'an invalid object' : `'${input}'`\n } where a stream was expected. You can provide an Observable, Promise, ReadableStream, Array, AsyncIterable, or Iterable.`\n );\n}\n", "export function getSymbolIterator(): symbol {\n if (typeof Symbol !== 'function' || !Symbol.iterator) {\n return '@@iterator' as any;\n }\n\n return Symbol.iterator;\n}\n\nexport const iterator = getSymbolIterator();\n", "import { iterator as Symbol_iterator } from '../symbol/iterator';\nimport { isFunction } from './isFunction';\n\n/** Identifies an input as being an Iterable */\nexport function isIterable(input: any): input is Iterable {\n return isFunction(input?.[Symbol_iterator]);\n}\n", "import { ReadableStreamLike } from '../types';\nimport { isFunction } from './isFunction';\n\nexport async function* readableStreamLikeToAsyncGenerator(readableStream: ReadableStreamLike): AsyncGenerator {\n const reader = readableStream.getReader();\n try {\n while (true) {\n const { value, done } = await reader.read();\n if (done) {\n return;\n }\n yield value!;\n }\n } finally {\n reader.releaseLock();\n }\n}\n\nexport function isReadableStreamLike(obj: any): obj is ReadableStreamLike {\n // We don't want to use instanceof checks because they would return\n // false for instances from another Realm, like an `; +}; +const appendDivSvgG = (parentRoot, id2, enclosingDivId, divStyle, svgXlink) => { + const enclosingDiv = parentRoot.append("div"); + enclosingDiv.attr("id", enclosingDivId); + if (divStyle) { + enclosingDiv.attr("style", divStyle); + } + const svgNode = enclosingDiv.append("svg").attr("id", id2).attr("width", "100%").attr("xmlns", XMLNS_SVG_STD); + if (svgXlink) { + svgNode.attr("xmlns:xlink", svgXlink); + } + svgNode.append("g"); + return parentRoot; +}; +function sandboxedIframe(parentNode, iFrameId) { + return parentNode.append("iframe").attr("id", iFrameId).attr("style", "width: 100%; height: 100%;").attr("sandbox", ""); +} +const removeExistingElements = (doc, id2, divId, iFrameId) => { + var _a, _b, _c; + (_a = doc.getElementById(id2)) == null ? void 0 : _a.remove(); + (_b = doc.getElementById(divId)) == null ? void 0 : _b.remove(); + (_c = doc.getElementById(iFrameId)) == null ? void 0 : _c.remove(); +}; +const render$1 = async function(id2, text, svgContainingElement) { + var _a, _b, _c, _d, _e, _f; + addDiagrams(); + const processed = processAndSetConfigs(text); + text = processed.code; + const config2 = getConfig$1(); + log$1.debug(config2); + if (text.length > ((config2 == null ? void 0 : config2.maxTextSize) ?? MAX_TEXTLENGTH)) { + text = MAX_TEXTLENGTH_EXCEEDED_MSG; + } + const idSelector = "#" + id2; + const iFrameID = "i" + id2; + const iFrameID_selector = "#" + iFrameID; + const enclosingDivID = "d" + id2; + const enclosingDivID_selector = "#" + enclosingDivID; + let root = select("body"); + const isSandboxed = config2.securityLevel === SECURITY_LVL_SANDBOX; + const isLooseSecurityLevel = config2.securityLevel === SECURITY_LVL_LOOSE; + const fontFamily = config2.fontFamily; + if (svgContainingElement !== void 0) { + if (svgContainingElement) { + svgContainingElement.innerHTML = ""; + } + if (isSandboxed) { + const iframe = sandboxedIframe(select(svgContainingElement), iFrameID); + root = select(iframe.nodes()[0].contentDocument.body); + root.node().style.margin = 0; + } else { + root = select(svgContainingElement); + } + appendDivSvgG(root, id2, enclosingDivID, `font-family: ${fontFamily}`, XMLNS_XLINK_STD); + } else { + removeExistingElements(document, id2, enclosingDivID, iFrameID); + if (isSandboxed) { + const iframe = sandboxedIframe(select("body"), iFrameID); + root = select(iframe.nodes()[0].contentDocument.body); + root.node().style.margin = 0; + } else { + root = select("body"); + } + appendDivSvgG(root, id2, enclosingDivID); + } + let diag; + let parseEncounteredException; + try { + diag = await getDiagramFromText(text, { title: processed.title }); + } catch (error) { + diag = new Diagram("error"); + parseEncounteredException = error; + } + const element = root.select(enclosingDivID_selector).node(); + const diagramType = diag.type; + const svg = element.firstChild; + const firstChild = svg.firstChild; + const diagramClassDefs = (_b = (_a = diag.renderer).getClasses) == null ? void 0 : _b.call(_a, text, diag); + const rules = createUserStyles(config2, diagramType, diagramClassDefs, idSelector); + const style1 = document.createElement("style"); + style1.innerHTML = rules; + svg.insertBefore(style1, firstChild); + try { + await diag.renderer.draw(text, id2, version, diag); + } catch (e) { + errorRenderer.draw(text, id2, version); + throw e; + } + const svgNode = root.select(`${enclosingDivID_selector} svg`); + const a11yTitle = (_d = (_c = diag.db).getAccTitle) == null ? void 0 : _d.call(_c); + const a11yDescr = (_f = (_e = diag.db).getAccDescription) == null ? void 0 : _f.call(_e); + addA11yInfo(diagramType, svgNode, a11yTitle, a11yDescr); + root.select(`[id="${id2}"]`).selectAll("foreignobject > *").attr("xmlns", XMLNS_XHTML_STD); + let svgCode = root.select(enclosingDivID_selector).node().innerHTML; + log$1.debug("config.arrowMarkerAbsolute", config2.arrowMarkerAbsolute); + svgCode = cleanUpSvgCode(svgCode, isSandboxed, evaluate(config2.arrowMarkerAbsolute)); + if (isSandboxed) { + const svgEl = root.select(enclosingDivID_selector + " svg").node(); + svgCode = putIntoIFrame(svgCode, svgEl); + } else if (!isLooseSecurityLevel) { + svgCode = DOMPurify.sanitize(svgCode, { + ADD_TAGS: DOMPURIFY_TAGS, + ADD_ATTR: DOMPURIFY_ATTR + }); + } + attachFunctions(); + if (parseEncounteredException) { + throw parseEncounteredException; + } + const tmpElementSelector = isSandboxed ? iFrameID_selector : enclosingDivID_selector; + const node = select(tmpElementSelector).node(); + if (node && "remove" in node) { + node.remove(); + } + return { + svg: svgCode, + bindFunctions: diag.db.bindFunctions + }; +}; +function initialize$1(options = {}) { + var _a; + if ((options == null ? void 0 : options.fontFamily) && !((_a = options.themeVariables) == null ? void 0 : _a.fontFamily)) { + if (!options.themeVariables) { + options.themeVariables = {}; + } + options.themeVariables.fontFamily = options.fontFamily; + } + saveConfigFromInitialize(options); + if ((options == null ? void 0 : options.theme) && options.theme in theme) { + options.themeVariables = theme[options.theme].getThemeVariables( + options.themeVariables + ); + } else if (options) { + options.themeVariables = theme.default.getThemeVariables(options.themeVariables); + } + const config2 = typeof options === "object" ? setSiteConfig(options) : getSiteConfig(); + setLogLevel$1(config2.logLevel); + addDiagrams(); +} +const getDiagramFromText = (text, metadata = {}) => { + const { code } = preprocessDiagram(text); + return getDiagramFromText$1(code, metadata); +}; +function addA11yInfo(diagramType, svgNode, a11yTitle, a11yDescr) { + setA11yDiagramInfo(svgNode, diagramType); + addSVGa11yTitleDescription(svgNode, a11yTitle, a11yDescr, svgNode.attr("id")); +} +const mermaidAPI = Object.freeze({ + render: render$1, + parse: parse$1, + getDiagramFromText, + initialize: initialize$1, + getConfig: getConfig$1, + setConfig: setConfig$1, + getSiteConfig, + updateSiteConfig, + reset: () => { + reset(); + }, + globalReset: () => { + reset(defaultConfig$1); + }, + defaultConfig: defaultConfig$1 +}); +setLogLevel$1(getConfig$1().logLevel); +reset(getConfig$1()); +const loadRegisteredDiagrams = async () => { + log$1.debug(`Loading registered diagrams`); + const results = await Promise.allSettled( + Object.entries(detectors).map(async ([key, { detector: detector2, loader: loader2 }]) => { + if (loader2) { + try { + getDiagram(key); + } catch (error) { + try { + const { diagram: diagram2, id: id2 } = await loader2(); + registerDiagram(id2, diagram2, detector2); + } catch (err) { + log$1.error(`Failed to load external diagram with key ${key}. Removing from detectors.`); + delete detectors[key]; + throw err; + } + } + } + }) + ); + const failed = results.filter((result) => result.status === "rejected"); + if (failed.length > 0) { + log$1.error(`Failed to load ${failed.length} external diagrams`); + for (const res of failed) { + log$1.error(res); + } + throw new Error(`Failed to load ${failed.length} external diagrams`); + } +}; +const handleError = (error, errors, parseError) => { + log$1.warn(error); + if (isDetailedError(error)) { + if (parseError) { + parseError(error.str, error.hash); + } + errors.push({ ...error, message: error.str, error }); + } else { + if (parseError) { + parseError(error); + } + if (error instanceof Error) { + errors.push({ + str: error.message, + message: error.message, + hash: error.name, + error + }); + } + } +}; +const run = async function(options = { + querySelector: ".mermaid" +}) { + try { + await runThrowsErrors(options); + } catch (e) { + if (isDetailedError(e)) { + log$1.error(e.str); + } + if (mermaid.parseError) { + mermaid.parseError(e); + } + if (!options.suppressErrors) { + log$1.error("Use the suppressErrors option to suppress these errors"); + throw e; + } + } +}; +const runThrowsErrors = async function({ postRenderCallback, querySelector, nodes } = { + querySelector: ".mermaid" +}) { + const conf = mermaidAPI.getConfig(); + log$1.debug(`${!postRenderCallback ? "No " : ""}Callback function found`); + let nodesToProcess; + if (nodes) { + nodesToProcess = nodes; + } else if (querySelector) { + nodesToProcess = document.querySelectorAll(querySelector); + } else { + throw new Error("Nodes and querySelector are both undefined"); + } + log$1.debug(`Found ${nodesToProcess.length} diagrams`); + if ((conf == null ? void 0 : conf.startOnLoad) !== void 0) { + log$1.debug("Start On Load: " + (conf == null ? void 0 : conf.startOnLoad)); + mermaidAPI.updateSiteConfig({ startOnLoad: conf == null ? void 0 : conf.startOnLoad }); + } + const idGenerator = new utils.InitIDGenerator(conf.deterministicIds, conf.deterministicIDSeed); + let txt; + const errors = []; + for (const element of Array.from(nodesToProcess)) { + log$1.info("Rendering diagram: " + element.id); + /*! Check if previously processed */ + if (element.getAttribute("data-processed")) { + continue; + } + element.setAttribute("data-processed", "true"); + const id2 = `mermaid-${idGenerator.next()}`; + txt = element.innerHTML; + txt = dedent(utils.entityDecode(txt)).trim().replace(//gi, "
    "); + const init2 = utils.detectInit(txt); + if (init2) { + log$1.debug("Detected early reinit: ", init2); + } + try { + const { svg, bindFunctions } = await render(id2, txt, element); + element.innerHTML = svg; + if (postRenderCallback) { + await postRenderCallback(id2); + } + if (bindFunctions) { + bindFunctions(element); + } + } catch (error) { + handleError(error, errors, mermaid.parseError); + } + } + if (errors.length > 0) { + throw errors[0]; + } +}; +const initialize = function(config2) { + mermaidAPI.initialize(config2); +}; +const init = async function(config2, nodes, callback) { + log$1.warn("mermaid.init is deprecated. Please use run instead."); + if (config2) { + initialize(config2); + } + const runOptions = { postRenderCallback: callback, querySelector: ".mermaid" }; + if (typeof nodes === "string") { + runOptions.querySelector = nodes; + } else if (nodes) { + if (nodes instanceof HTMLElement) { + runOptions.nodes = [nodes]; + } else { + runOptions.nodes = nodes; + } + } + await run(runOptions); +}; +const registerExternalDiagrams = async (diagrams2, { + lazyLoad = true +} = {}) => { + registerLazyLoadedDiagrams(...diagrams2); + if (lazyLoad === false) { + await loadRegisteredDiagrams(); + } +}; +const contentLoaded = function() { + if (mermaid.startOnLoad) { + const { startOnLoad } = mermaidAPI.getConfig(); + if (startOnLoad) { + mermaid.run().catch((err) => log$1.error("Mermaid failed to initialize", err)); + } + } +}; +if (typeof document !== "undefined") { + /*! + * Wait for document loaded before starting the execution + */ + window.addEventListener("load", contentLoaded, false); +} +const setParseErrorHandler = function(parseErrorHandler) { + mermaid.parseError = parseErrorHandler; +}; +const executionQueue = []; +let executionQueueRunning = false; +const executeQueue = async () => { + if (executionQueueRunning) { + return; + } + executionQueueRunning = true; + while (executionQueue.length > 0) { + const f = executionQueue.shift(); + if (f) { + try { + await f(); + } catch (e) { + log$1.error("Error executing queue", e); + } + } + } + executionQueueRunning = false; +}; +const parse = async (text, parseOptions) => { + return new Promise((resolve, reject) => { + const performCall = () => new Promise((res, rej) => { + mermaidAPI.parse(text, parseOptions).then( + (r) => { + res(r); + resolve(r); + }, + (e) => { + var _a; + log$1.error("Error parsing", e); + (_a = mermaid.parseError) == null ? void 0 : _a.call(mermaid, e); + rej(e); + reject(e); + } + ); + }); + executionQueue.push(performCall); + executeQueue().catch(reject); + }); +}; +const render = (id2, text, container) => { + return new Promise((resolve, reject) => { + const performCall = () => new Promise((res, rej) => { + mermaidAPI.render(id2, text, container).then( + (r) => { + res(r); + resolve(r); + }, + (e) => { + var _a; + log$1.error("Error parsing", e); + (_a = mermaid.parseError) == null ? void 0 : _a.call(mermaid, e); + rej(e); + reject(e); + } + ); + }); + executionQueue.push(performCall); + executeQueue().catch(reject); + }); +}; +const mermaid = { + startOnLoad: true, + mermaidAPI, + parse, + render, + init, + run, + registerExternalDiagrams, + initialize, + parseError: void 0, + contentLoaded, + setParseErrorHandler, + detectType +}; +export { + selectSvgElement as A, + defaultConfig$2 as B, + cleanAndMerge as C, + parseFontSize as D, + getThemeVariables$2 as E, + getConfig$1 as F, + hasKatex as G, + calculateMathMLDimensions as H, + generateId as I, + lineBreakRegex as J, + defaultConfig as K, + commonDb as L, + decodeEntities as M, + mermaid as N, + ZERO_WIDTH_SPACE as Z, + getAccDescription as a, + setAccDescription as b, + getConfig as c, + sanitizeText$2 as d, + common$1 as e, + assignWithDepth$1 as f, + getAccTitle as g, + calculateTextWidth as h, + configureSvgSize as i, + calculateTextHeight as j, + getStylesFromArray as k, + log$1 as l, + evaluate as m, + interpolateToCurve as n, + setupGraphViewbox$1 as o, + setConfig as p, + setDiagramTitle as q, + renderKatex as r, + setAccTitle as s, + getDiagramTitle as t, + utils as u, + clear as v, + wrapLabel as w, + parseGenericTypes as x, + random as y, + setupGraphViewbox as z +}; diff --git a/0.6.0/js/mermaid/mermaid-9f2aa176.js b/0.6.0/js/mermaid/mermaid-9f2aa176.js new file mode 100644 index 0000000..7d41da3 --- /dev/null +++ b/0.6.0/js/mermaid/mermaid-9f2aa176.js @@ -0,0 +1,8112 @@ +function mh(t) { + for (var e = [], i = 1; i < arguments.length; i++) + e[i - 1] = arguments[i]; + var r = Array.from(typeof t == "string" ? [t] : t); + r[r.length - 1] = r[r.length - 1].replace(/\r?\n([\t ]*)$/, ""); + var n = r.reduce(function(a, l) { + var h = l.match(/\n([\t ]+|(?!\s).)/g); + return h ? a.concat(h.map(function(u) { + var f, c; + return (c = (f = u.match(/[\t ]/g)) === null || f === void 0 ? void 0 : f.length) !== null && c !== void 0 ? c : 0; + })) : a; + }, []); + if (n.length) { + var o = new RegExp(` +[ ]{` + Math.min.apply(Math, n) + "}", "g"); + r = r.map(function(a) { + return a.replace(o, ` +`); + }); + } + r[0] = r[0].replace(/^\r?\n/, ""); + var s = r[0]; + return e.forEach(function(a, l) { + var h = s.match(/(?:^|\n)( *)$/), u = h ? h[1] : "", f = a; + typeof a == "string" && a.includes(` +`) && (f = String(a).split(` +`).map(function(c, d) { + return d === 0 ? c : "" + u + c; + }).join(` +`)), s += f + r[l + 1]; + }), s; +} +var yh = typeof globalThis < "u" ? globalThis : typeof window < "u" ? window : typeof global < "u" ? global : typeof self < "u" ? self : {}; +function _h(t) { + return t && t.__esModule && Object.prototype.hasOwnProperty.call(t, "default") ? t.default : t; +} +var Ns = { exports: {} }; +(function(t, e) { + (function(i, r) { + t.exports = r(); + })(yh, function() { + var i = 1e3, r = 6e4, n = 36e5, o = "millisecond", s = "second", a = "minute", l = "hour", h = "day", u = "week", f = "month", c = "quarter", d = "year", m = "date", S = "Invalid Date", O = /^(\d{4})[-/]?(\d{1,2})?[-/]?(\d{0,2})[Tt\s]*(\d{1,2})?:?(\d{1,2})?:?(\d{1,2})?[.:]?(\d+)?$/, z = /\[([^\]]+)]|Y{1,4}|M{1,4}|D{1,2}|d{1,4}|H{1,2}|h{1,2}|a|A|m{1,2}|s{1,2}|Z{1,2}|SSS/g, T = { name: "en", weekdays: "Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday".split("_"), months: "January_February_March_April_May_June_July_August_September_October_November_December".split("_"), ordinal: function(M) { + var k = ["th", "st", "nd", "rd"], C = M % 100; + return "[" + M + (k[(C - 20) % 10] || k[C] || k[0]) + "]"; + } }, R = function(M, k, C) { + var w = String(M); + return !w || w.length >= k ? M : "" + Array(k + 1 - w.length).join(C) + M; + }, X = { s: R, z: function(M) { + var k = -M.utcOffset(), C = Math.abs(k), w = Math.floor(C / 60), x = C % 60; + return (k <= 0 ? "+" : "-") + R(w, 2, "0") + ":" + R(x, 2, "0"); + }, m: function M(k, C) { + if (k.date() < C.date()) + return -M(C, k); + var w = 12 * (C.year() - k.year()) + (C.month() - k.month()), x = k.clone().add(w, f), b = C - x < 0, D = k.clone().add(w + (b ? -1 : 1), f); + return +(-(w + (C - x) / (b ? x - D : D - x)) || 0); + }, a: function(M) { + return M < 0 ? Math.ceil(M) || 0 : Math.floor(M); + }, p: function(M) { + return { M: f, y: d, w: u, d: h, D: m, h: l, m: a, s, ms: o, Q: c }[M] || String(M || "").toLowerCase().replace(/s$/, ""); + }, u: function(M) { + return M === void 0; + } }, G = "en", V = {}; + V[G] = T; + var H = "$isDayjsObject", oe = function(M) { + return M instanceof Ct || !(!M || !M[H]); + }, Kt = function M(k, C, w) { + var x; + if (!k) + return G; + if (typeof k == "string") { + var b = k.toLowerCase(); + V[b] && (x = b), C && (V[b] = C, x = b); + var D = k.split("-"); + if (!x && D.length > 1) + return M(D[0]); + } else { + var I = k.name; + V[I] = k, x = I; + } + return !w && x && (G = x), x || !w && G; + }, P = function(M, k) { + if (oe(M)) + return M.clone(); + var C = typeof k == "object" ? k : {}; + return C.date = M, C.args = arguments, new Ct(C); + }, W = X; + W.l = Kt, W.i = oe, W.w = function(M, k) { + return P(M, { locale: k.$L, utc: k.$u, x: k.$x, $offset: k.$offset }); + }; + var Ct = function() { + function M(C) { + this.$L = Kt(C.locale, null, !0), this.parse(C), this.$x = this.$x || C.x || {}, this[H] = !0; + } + var k = M.prototype; + return k.parse = function(C) { + this.$d = function(w) { + var x = w.date, b = w.utc; + if (x === null) + return /* @__PURE__ */ new Date(NaN); + if (W.u(x)) + return /* @__PURE__ */ new Date(); + if (x instanceof Date) + return new Date(x); + if (typeof x == "string" && !/Z$/i.test(x)) { + var D = x.match(O); + if (D) { + var I = D[2] - 1 || 0, Y = (D[7] || "0").substring(0, 3); + return b ? new Date(Date.UTC(D[1], I, D[3] || 1, D[4] || 0, D[5] || 0, D[6] || 0, Y)) : new Date(D[1], I, D[3] || 1, D[4] || 0, D[5] || 0, D[6] || 0, Y); + } + } + return new Date(x); + }(C), this.init(); + }, k.init = function() { + var C = this.$d; + this.$y = C.getFullYear(), this.$M = C.getMonth(), this.$D = C.getDate(), this.$W = C.getDay(), this.$H = C.getHours(), this.$m = C.getMinutes(), this.$s = C.getSeconds(), this.$ms = C.getMilliseconds(); + }, k.$utils = function() { + return W; + }, k.isValid = function() { + return this.$d.toString() !== S; + }, k.isSame = function(C, w) { + var x = P(C); + return this.startOf(w) <= x && x <= this.endOf(w); + }, k.isAfter = function(C, w) { + return P(C) < this.startOf(w); + }, k.isBefore = function(C, w) { + return this.endOf(w) < P(C); + }, k.$g = function(C, w, x) { + return W.u(C) ? this[w] : this.set(x, C); + }, k.unix = function() { + return Math.floor(this.valueOf() / 1e3); + }, k.valueOf = function() { + return this.$d.getTime(); + }, k.startOf = function(C, w) { + var x = this, b = !!W.u(w) || w, D = W.p(C), I = function(Lt, Z) { + var it = W.w(x.$u ? Date.UTC(x.$y, Z, Lt) : new Date(x.$y, Z, Lt), x); + return b ? it : it.endOf(h); + }, Y = function(Lt, Z) { + return W.w(x.toDate()[Lt].apply(x.toDate("s"), (b ? [0, 0, 0, 0] : [23, 59, 59, 999]).slice(Z)), x); + }, N = this.$W, K = this.$M, et = this.$D, Rt = "set" + (this.$u ? "UTC" : ""); + switch (D) { + case d: + return b ? I(1, 0) : I(31, 11); + case f: + return b ? I(1, K) : I(0, K + 1); + case u: + var St = this.$locale().weekStart || 0, Zt = (N < St ? N + 7 : N) - St; + return I(b ? et - Zt : et + (6 - Zt), K); + case h: + case m: + return Y(Rt + "Hours", 0); + case l: + return Y(Rt + "Minutes", 1); + case a: + return Y(Rt + "Seconds", 2); + case s: + return Y(Rt + "Milliseconds", 3); + default: + return this.clone(); + } + }, k.endOf = function(C) { + return this.startOf(C, !1); + }, k.$set = function(C, w) { + var x, b = W.p(C), D = "set" + (this.$u ? "UTC" : ""), I = (x = {}, x[h] = D + "Date", x[m] = D + "Date", x[f] = D + "Month", x[d] = D + "FullYear", x[l] = D + "Hours", x[a] = D + "Minutes", x[s] = D + "Seconds", x[o] = D + "Milliseconds", x)[b], Y = b === h ? this.$D + (w - this.$W) : w; + if (b === f || b === d) { + var N = this.clone().set(m, 1); + N.$d[I](Y), N.init(), this.$d = N.set(m, Math.min(this.$D, N.daysInMonth())).$d; + } else + I && this.$d[I](Y); + return this.init(), this; + }, k.set = function(C, w) { + return this.clone().$set(C, w); + }, k.get = function(C) { + return this[W.p(C)](); + }, k.add = function(C, w) { + var x, b = this; + C = Number(C); + var D = W.p(w), I = function(K) { + var et = P(b); + return W.w(et.date(et.date() + Math.round(K * C)), b); + }; + if (D === f) + return this.set(f, this.$M + C); + if (D === d) + return this.set(d, this.$y + C); + if (D === h) + return I(1); + if (D === u) + return I(7); + var Y = (x = {}, x[a] = r, x[l] = n, x[s] = i, x)[D] || 1, N = this.$d.getTime() + C * Y; + return W.w(N, this); + }, k.subtract = function(C, w) { + return this.add(-1 * C, w); + }, k.format = function(C) { + var w = this, x = this.$locale(); + if (!this.isValid()) + return x.invalidDate || S; + var b = C || "YYYY-MM-DDTHH:mm:ssZ", D = W.z(this), I = this.$H, Y = this.$m, N = this.$M, K = x.weekdays, et = x.months, Rt = x.meridiem, St = function(Z, it, Pt, Jt) { + return Z && (Z[it] || Z(w, b)) || Pt[it].slice(0, Jt); + }, Zt = function(Z) { + return W.s(I % 12 || 12, Z, "0"); + }, Lt = Rt || function(Z, it, Pt) { + var Jt = Z < 12 ? "AM" : "PM"; + return Pt ? Jt.toLowerCase() : Jt; + }; + return b.replace(z, function(Z, it) { + return it || function(Pt) { + switch (Pt) { + case "YY": + return String(w.$y).slice(-2); + case "YYYY": + return W.s(w.$y, 4, "0"); + case "M": + return N + 1; + case "MM": + return W.s(N + 1, 2, "0"); + case "MMM": + return St(x.monthsShort, N, et, 3); + case "MMMM": + return St(et, N); + case "D": + return w.$D; + case "DD": + return W.s(w.$D, 2, "0"); + case "d": + return String(w.$W); + case "dd": + return St(x.weekdaysMin, w.$W, K, 2); + case "ddd": + return St(x.weekdaysShort, w.$W, K, 3); + case "dddd": + return K[w.$W]; + case "H": + return String(I); + case "HH": + return W.s(I, 2, "0"); + case "h": + return Zt(1); + case "hh": + return Zt(2); + case "a": + return Lt(I, Y, !0); + case "A": + return Lt(I, Y, !1); + case "m": + return String(Y); + case "mm": + return W.s(Y, 2, "0"); + case "s": + return String(w.$s); + case "ss": + return W.s(w.$s, 2, "0"); + case "SSS": + return W.s(w.$ms, 3, "0"); + case "Z": + return D; + } + return null; + }(Z) || D.replace(":", ""); + }); + }, k.utcOffset = function() { + return 15 * -Math.round(this.$d.getTimezoneOffset() / 15); + }, k.diff = function(C, w, x) { + var b, D = this, I = W.p(w), Y = P(C), N = (Y.utcOffset() - this.utcOffset()) * r, K = this - Y, et = function() { + return W.m(D, Y); + }; + switch (I) { + case d: + b = et() / 12; + break; + case f: + b = et(); + break; + case c: + b = et() / 3; + break; + case u: + b = (K - N) / 6048e5; + break; + case h: + b = (K - N) / 864e5; + break; + case l: + b = K / n; + break; + case a: + b = K / r; + break; + case s: + b = K / i; + break; + default: + b = K; + } + return x ? b : W.a(b); + }, k.daysInMonth = function() { + return this.endOf(f).$D; + }, k.$locale = function() { + return V[this.$L]; + }, k.locale = function(C, w) { + if (!C) + return this.$L; + var x = this.clone(), b = Kt(C, w, !0); + return b && (x.$L = b), x; + }, k.clone = function() { + return W.w(this.$d, this); + }, k.toDate = function() { + return new Date(this.valueOf()); + }, k.toJSON = function() { + return this.isValid() ? this.toISOString() : null; + }, k.toISOString = function() { + return this.$d.toISOString(); + }, k.toString = function() { + return this.$d.toUTCString(); + }, M; + }(), Nt = Ct.prototype; + return P.prototype = Nt, [["$ms", o], ["$s", s], ["$m", a], ["$H", l], ["$W", h], ["$M", f], ["$y", d], ["$D", m]].forEach(function(M) { + Nt[M[1]] = function(k) { + return this.$g(k, M[0], M[1]); + }; + }), P.extend = function(M, k) { + return M.$i || (M(k, Ct, P), M.$i = !0), P; + }, P.locale = Kt, P.isDayjs = oe, P.unix = function(M) { + return P(1e3 * M); + }, P.en = V[G], P.Ls = V, P.p = {}, P; + }); +})(Ns); +var Ch = Ns.exports; +const xh = /* @__PURE__ */ _h(Ch), Wt = { + trace: 0, + debug: 1, + info: 2, + warn: 3, + error: 4, + fatal: 5 +}, L = { + trace: (...t) => { + }, + debug: (...t) => { + }, + info: (...t) => { + }, + warn: (...t) => { + }, + error: (...t) => { + }, + fatal: (...t) => { + } +}, bn = function(t = "fatal") { + let e = Wt.fatal; + typeof t == "string" ? (t = t.toLowerCase(), t in Wt && (e = Wt[t])) : typeof t == "number" && (e = t), L.trace = () => { + }, L.debug = () => { + }, L.info = () => { + }, L.warn = () => { + }, L.error = () => { + }, L.fatal = () => { + }, e <= Wt.fatal && (L.fatal = console.error ? console.error.bind(console, xt("FATAL"), "color: orange") : console.log.bind(console, "\x1B[35m", xt("FATAL"))), e <= Wt.error && (L.error = console.error ? console.error.bind(console, xt("ERROR"), "color: orange") : console.log.bind(console, "\x1B[31m", xt("ERROR"))), e <= Wt.warn && (L.warn = console.warn ? console.warn.bind(console, xt("WARN"), "color: orange") : console.log.bind(console, "\x1B[33m", xt("WARN"))), e <= Wt.info && (L.info = console.info ? console.info.bind(console, xt("INFO"), "color: lightblue") : console.log.bind(console, "\x1B[34m", xt("INFO"))), e <= Wt.debug && (L.debug = console.debug ? console.debug.bind(console, xt("DEBUG"), "color: lightgreen") : console.log.bind(console, "\x1B[32m", xt("DEBUG"))), e <= Wt.trace && (L.trace = console.debug ? console.debug.bind(console, xt("TRACE"), "color: lightgreen") : console.log.bind(console, "\x1B[32m", xt("TRACE"))); +}, xt = (t) => `%c${xh().format("ss.SSS")} : ${t} : `; +var Rs = {}; +(function(t) { + Object.defineProperty(t, "__esModule", { value: !0 }), t.sanitizeUrl = t.BLANK_URL = void 0; + var e = /^([^\w]*)(javascript|data|vbscript)/im, i = /&#(\w+)(^\w|;)?/g, r = /&(newline|tab);/gi, n = /[\u0000-\u001F\u007F-\u009F\u2000-\u200D\uFEFF]/gim, o = /^.+(:|:)/gim, s = [".", "/"]; + t.BLANK_URL = "about:blank"; + function a(u) { + return s.indexOf(u[0]) > -1; + } + function l(u) { + var f = u.replace(n, ""); + return f.replace(i, function(c, d) { + return String.fromCharCode(d); + }); + } + function h(u) { + if (!u) + return t.BLANK_URL; + var f = l(u).replace(r, "").replace(n, "").trim(); + if (!f) + return t.BLANK_URL; + if (a(f)) + return f; + var c = f.match(o); + if (!c) + return f; + var d = c[0]; + return e.test(d) ? t.BLANK_URL : f; + } + t.sanitizeUrl = h; +})(Rs); +var bh = { value: () => { +} }; +function Ps() { + for (var t = 0, e = arguments.length, i = {}, r; t < e; ++t) { + if (!(r = arguments[t] + "") || r in i || /[\s.]/.test(r)) + throw new Error("illegal type: " + r); + i[r] = []; + } + return new Oi(i); +} +function Oi(t) { + this._ = t; +} +function Th(t, e) { + return t.trim().split(/^|\s+/).map(function(i) { + var r = "", n = i.indexOf("."); + if (n >= 0 && (r = i.slice(n + 1), i = i.slice(0, n)), i && !e.hasOwnProperty(i)) + throw new Error("unknown type: " + i); + return { type: i, name: r }; + }); +} +Oi.prototype = Ps.prototype = { + constructor: Oi, + on: function(t, e) { + var i = this._, r = Th(t + "", i), n, o = -1, s = r.length; + if (arguments.length < 2) { + for (; ++o < s; ) + if ((n = (t = r[o]).type) && (n = kh(i[n], t.name))) + return n; + return; + } + if (e != null && typeof e != "function") + throw new Error("invalid callback: " + e); + for (; ++o < s; ) + if (n = (t = r[o]).type) + i[n] = To(i[n], t.name, e); + else if (e == null) + for (n in i) + i[n] = To(i[n], t.name, null); + return this; + }, + copy: function() { + var t = {}, e = this._; + for (var i in e) + t[i] = e[i].slice(); + return new Oi(t); + }, + call: function(t, e) { + if ((n = arguments.length - 2) > 0) + for (var i = new Array(n), r = 0, n, o; r < n; ++r) + i[r] = arguments[r + 2]; + if (!this._.hasOwnProperty(t)) + throw new Error("unknown type: " + t); + for (o = this._[t], r = 0, n = o.length; r < n; ++r) + o[r].value.apply(e, i); + }, + apply: function(t, e, i) { + if (!this._.hasOwnProperty(t)) + throw new Error("unknown type: " + t); + for (var r = this._[t], n = 0, o = r.length; n < o; ++n) + r[n].value.apply(e, i); + } +}; +function kh(t, e) { + for (var i = 0, r = t.length, n; i < r; ++i) + if ((n = t[i]).name === e) + return n.value; +} +function To(t, e, i) { + for (var r = 0, n = t.length; r < n; ++r) + if (t[r].name === e) { + t[r] = bh, t = t.slice(0, r).concat(t.slice(r + 1)); + break; + } + return i != null && t.push({ name: e, value: i }), t; +} +var Jr = "http://www.w3.org/1999/xhtml"; +const ko = { + svg: "http://www.w3.org/2000/svg", + xhtml: Jr, + xlink: "http://www.w3.org/1999/xlink", + xml: "http://www.w3.org/XML/1998/namespace", + xmlns: "http://www.w3.org/2000/xmlns/" +}; +function fr(t) { + var e = t += "", i = e.indexOf(":"); + return i >= 0 && (e = t.slice(0, i)) !== "xmlns" && (t = t.slice(i + 1)), ko.hasOwnProperty(e) ? { space: ko[e], local: t } : t; +} +function Sh(t) { + return function() { + var e = this.ownerDocument, i = this.namespaceURI; + return i === Jr && e.documentElement.namespaceURI === Jr ? e.createElement(t) : e.createElementNS(i, t); + }; +} +function vh(t) { + return function() { + return this.ownerDocument.createElementNS(t.space, t.local); + }; +} +function qs(t) { + var e = fr(t); + return (e.local ? vh : Sh)(e); +} +function wh() { +} +function Tn(t) { + return t == null ? wh : function() { + return this.querySelector(t); + }; +} +function Bh(t) { + typeof t != "function" && (t = Tn(t)); + for (var e = this._groups, i = e.length, r = new Array(i), n = 0; n < i; ++n) + for (var o = e[n], s = o.length, a = r[n] = new Array(s), l, h, u = 0; u < s; ++u) + (l = o[u]) && (h = t.call(l, l.__data__, u, o)) && ("__data__" in l && (h.__data__ = l.__data__), a[u] = h); + return new yt(r, this._parents); +} +function Fh(t) { + return t == null ? [] : Array.isArray(t) ? t : Array.from(t); +} +function Ah() { + return []; +} +function zs(t) { + return t == null ? Ah : function() { + return this.querySelectorAll(t); + }; +} +function Lh(t) { + return function() { + return Fh(t.apply(this, arguments)); + }; +} +function Eh(t) { + typeof t == "function" ? t = Lh(t) : t = zs(t); + for (var e = this._groups, i = e.length, r = [], n = [], o = 0; o < i; ++o) + for (var s = e[o], a = s.length, l, h = 0; h < a; ++h) + (l = s[h]) && (r.push(t.call(l, l.__data__, h, s)), n.push(l)); + return new yt(r, n); +} +function Ws(t) { + return function() { + return this.matches(t); + }; +} +function Hs(t) { + return function(e) { + return e.matches(t); + }; +} +var Mh = Array.prototype.find; +function Oh(t) { + return function() { + return Mh.call(this.children, t); + }; +} +function $h() { + return this.firstElementChild; +} +function Ih(t) { + return this.select(t == null ? $h : Oh(typeof t == "function" ? t : Hs(t))); +} +var Dh = Array.prototype.filter; +function Nh() { + return Array.from(this.children); +} +function Rh(t) { + return function() { + return Dh.call(this.children, t); + }; +} +function Ph(t) { + return this.selectAll(t == null ? Nh : Rh(typeof t == "function" ? t : Hs(t))); +} +function qh(t) { + typeof t != "function" && (t = Ws(t)); + for (var e = this._groups, i = e.length, r = new Array(i), n = 0; n < i; ++n) + for (var o = e[n], s = o.length, a = r[n] = [], l, h = 0; h < s; ++h) + (l = o[h]) && t.call(l, l.__data__, h, o) && a.push(l); + return new yt(r, this._parents); +} +function js(t) { + return new Array(t.length); +} +function zh() { + return new yt(this._enter || this._groups.map(js), this._parents); +} +function ji(t, e) { + this.ownerDocument = t.ownerDocument, this.namespaceURI = t.namespaceURI, this._next = null, this._parent = t, this.__data__ = e; +} +ji.prototype = { + constructor: ji, + appendChild: function(t) { + return this._parent.insertBefore(t, this._next); + }, + insertBefore: function(t, e) { + return this._parent.insertBefore(t, e); + }, + querySelector: function(t) { + return this._parent.querySelector(t); + }, + querySelectorAll: function(t) { + return this._parent.querySelectorAll(t); + } +}; +function Wh(t) { + return function() { + return t; + }; +} +function Hh(t, e, i, r, n, o) { + for (var s = 0, a, l = e.length, h = o.length; s < h; ++s) + (a = e[s]) ? (a.__data__ = o[s], r[s] = a) : i[s] = new ji(t, o[s]); + for (; s < l; ++s) + (a = e[s]) && (n[s] = a); +} +function jh(t, e, i, r, n, o, s) { + var a, l, h = /* @__PURE__ */ new Map(), u = e.length, f = o.length, c = new Array(u), d; + for (a = 0; a < u; ++a) + (l = e[a]) && (c[a] = d = s.call(l, l.__data__, a, e) + "", h.has(d) ? n[a] = l : h.set(d, l)); + for (a = 0; a < f; ++a) + d = s.call(t, o[a], a, o) + "", (l = h.get(d)) ? (r[a] = l, l.__data__ = o[a], h.delete(d)) : i[a] = new ji(t, o[a]); + for (a = 0; a < u; ++a) + (l = e[a]) && h.get(c[a]) === l && (n[a] = l); +} +function Uh(t) { + return t.__data__; +} +function Yh(t, e) { + if (!arguments.length) + return Array.from(this, Uh); + var i = e ? jh : Hh, r = this._parents, n = this._groups; + typeof t != "function" && (t = Wh(t)); + for (var o = n.length, s = new Array(o), a = new Array(o), l = new Array(o), h = 0; h < o; ++h) { + var u = r[h], f = n[h], c = f.length, d = Gh(t.call(u, u && u.__data__, h, r)), m = d.length, S = a[h] = new Array(m), O = s[h] = new Array(m), z = l[h] = new Array(c); + i(u, f, S, O, z, d, e); + for (var T = 0, R = 0, X, G; T < m; ++T) + if (X = S[T]) { + for (T >= R && (R = T + 1); !(G = O[R]) && ++R < m; ) + ; + X._next = G || null; + } + } + return s = new yt(s, r), s._enter = a, s._exit = l, s; +} +function Gh(t) { + return typeof t == "object" && "length" in t ? t : Array.from(t); +} +function Vh() { + return new yt(this._exit || this._groups.map(js), this._parents); +} +function Xh(t, e, i) { + var r = this.enter(), n = this, o = this.exit(); + return typeof t == "function" ? (r = t(r), r && (r = r.selection())) : r = r.append(t + ""), e != null && (n = e(n), n && (n = n.selection())), i == null ? o.remove() : i(o), r && n ? r.merge(n).order() : n; +} +function Kh(t) { + for (var e = t.selection ? t.selection() : t, i = this._groups, r = e._groups, n = i.length, o = r.length, s = Math.min(n, o), a = new Array(n), l = 0; l < s; ++l) + for (var h = i[l], u = r[l], f = h.length, c = a[l] = new Array(f), d, m = 0; m < f; ++m) + (d = h[m] || u[m]) && (c[m] = d); + for (; l < n; ++l) + a[l] = i[l]; + return new yt(a, this._parents); +} +function Zh() { + for (var t = this._groups, e = -1, i = t.length; ++e < i; ) + for (var r = t[e], n = r.length - 1, o = r[n], s; --n >= 0; ) + (s = r[n]) && (o && s.compareDocumentPosition(o) ^ 4 && o.parentNode.insertBefore(s, o), o = s); + return this; +} +function Jh(t) { + t || (t = Qh); + function e(f, c) { + return f && c ? t(f.__data__, c.__data__) : !f - !c; + } + for (var i = this._groups, r = i.length, n = new Array(r), o = 0; o < r; ++o) { + for (var s = i[o], a = s.length, l = n[o] = new Array(a), h, u = 0; u < a; ++u) + (h = s[u]) && (l[u] = h); + l.sort(e); + } + return new yt(n, this._parents).order(); +} +function Qh(t, e) { + return t < e ? -1 : t > e ? 1 : t >= e ? 0 : NaN; +} +function tc() { + var t = arguments[0]; + return arguments[0] = this, t.apply(null, arguments), this; +} +function ec() { + return Array.from(this); +} +function ic() { + for (var t = this._groups, e = 0, i = t.length; e < i; ++e) + for (var r = t[e], n = 0, o = r.length; n < o; ++n) { + var s = r[n]; + if (s) + return s; + } + return null; +} +function rc() { + let t = 0; + for (const e of this) + ++t; + return t; +} +function nc() { + return !this.node(); +} +function oc(t) { + for (var e = this._groups, i = 0, r = e.length; i < r; ++i) + for (var n = e[i], o = 0, s = n.length, a; o < s; ++o) + (a = n[o]) && t.call(a, a.__data__, o, n); + return this; +} +function sc(t) { + return function() { + this.removeAttribute(t); + }; +} +function ac(t) { + return function() { + this.removeAttributeNS(t.space, t.local); + }; +} +function lc(t, e) { + return function() { + this.setAttribute(t, e); + }; +} +function hc(t, e) { + return function() { + this.setAttributeNS(t.space, t.local, e); + }; +} +function cc(t, e) { + return function() { + var i = e.apply(this, arguments); + i == null ? this.removeAttribute(t) : this.setAttribute(t, i); + }; +} +function uc(t, e) { + return function() { + var i = e.apply(this, arguments); + i == null ? this.removeAttributeNS(t.space, t.local) : this.setAttributeNS(t.space, t.local, i); + }; +} +function fc(t, e) { + var i = fr(t); + if (arguments.length < 2) { + var r = this.node(); + return i.local ? r.getAttributeNS(i.space, i.local) : r.getAttribute(i); + } + return this.each((e == null ? i.local ? ac : sc : typeof e == "function" ? i.local ? uc : cc : i.local ? hc : lc)(i, e)); +} +function Us(t) { + return t.ownerDocument && t.ownerDocument.defaultView || t.document && t || t.defaultView; +} +function dc(t) { + return function() { + this.style.removeProperty(t); + }; +} +function pc(t, e, i) { + return function() { + this.style.setProperty(t, e, i); + }; +} +function gc(t, e, i) { + return function() { + var r = e.apply(this, arguments); + r == null ? this.style.removeProperty(t) : this.style.setProperty(t, r, i); + }; +} +function mc(t, e, i) { + return arguments.length > 1 ? this.each((e == null ? dc : typeof e == "function" ? gc : pc)(t, e, i ?? "")) : Ae(this.node(), t); +} +function Ae(t, e) { + return t.style.getPropertyValue(e) || Us(t).getComputedStyle(t, null).getPropertyValue(e); +} +function yc(t) { + return function() { + delete this[t]; + }; +} +function _c(t, e) { + return function() { + this[t] = e; + }; +} +function Cc(t, e) { + return function() { + var i = e.apply(this, arguments); + i == null ? delete this[t] : this[t] = i; + }; +} +function xc(t, e) { + return arguments.length > 1 ? this.each((e == null ? yc : typeof e == "function" ? Cc : _c)(t, e)) : this.node()[t]; +} +function Ys(t) { + return t.trim().split(/^|\s+/); +} +function kn(t) { + return t.classList || new Gs(t); +} +function Gs(t) { + this._node = t, this._names = Ys(t.getAttribute("class") || ""); +} +Gs.prototype = { + add: function(t) { + var e = this._names.indexOf(t); + e < 0 && (this._names.push(t), this._node.setAttribute("class", this._names.join(" "))); + }, + remove: function(t) { + var e = this._names.indexOf(t); + e >= 0 && (this._names.splice(e, 1), this._node.setAttribute("class", this._names.join(" "))); + }, + contains: function(t) { + return this._names.indexOf(t) >= 0; + } +}; +function Vs(t, e) { + for (var i = kn(t), r = -1, n = e.length; ++r < n; ) + i.add(e[r]); +} +function Xs(t, e) { + for (var i = kn(t), r = -1, n = e.length; ++r < n; ) + i.remove(e[r]); +} +function bc(t) { + return function() { + Vs(this, t); + }; +} +function Tc(t) { + return function() { + Xs(this, t); + }; +} +function kc(t, e) { + return function() { + (e.apply(this, arguments) ? Vs : Xs)(this, t); + }; +} +function Sc(t, e) { + var i = Ys(t + ""); + if (arguments.length < 2) { + for (var r = kn(this.node()), n = -1, o = i.length; ++n < o; ) + if (!r.contains(i[n])) + return !1; + return !0; + } + return this.each((typeof e == "function" ? kc : e ? bc : Tc)(i, e)); +} +function vc() { + this.textContent = ""; +} +function wc(t) { + return function() { + this.textContent = t; + }; +} +function Bc(t) { + return function() { + var e = t.apply(this, arguments); + this.textContent = e ?? ""; + }; +} +function Fc(t) { + return arguments.length ? this.each(t == null ? vc : (typeof t == "function" ? Bc : wc)(t)) : this.node().textContent; +} +function Ac() { + this.innerHTML = ""; +} +function Lc(t) { + return function() { + this.innerHTML = t; + }; +} +function Ec(t) { + return function() { + var e = t.apply(this, arguments); + this.innerHTML = e ?? ""; + }; +} +function Mc(t) { + return arguments.length ? this.each(t == null ? Ac : (typeof t == "function" ? Ec : Lc)(t)) : this.node().innerHTML; +} +function Oc() { + this.nextSibling && this.parentNode.appendChild(this); +} +function $c() { + return this.each(Oc); +} +function Ic() { + this.previousSibling && this.parentNode.insertBefore(this, this.parentNode.firstChild); +} +function Dc() { + return this.each(Ic); +} +function Nc(t) { + var e = typeof t == "function" ? t : qs(t); + return this.select(function() { + return this.appendChild(e.apply(this, arguments)); + }); +} +function Rc() { + return null; +} +function Pc(t, e) { + var i = typeof t == "function" ? t : qs(t), r = e == null ? Rc : typeof e == "function" ? e : Tn(e); + return this.select(function() { + return this.insertBefore(i.apply(this, arguments), r.apply(this, arguments) || null); + }); +} +function qc() { + var t = this.parentNode; + t && t.removeChild(this); +} +function zc() { + return this.each(qc); +} +function Wc() { + var t = this.cloneNode(!1), e = this.parentNode; + return e ? e.insertBefore(t, this.nextSibling) : t; +} +function Hc() { + var t = this.cloneNode(!0), e = this.parentNode; + return e ? e.insertBefore(t, this.nextSibling) : t; +} +function jc(t) { + return this.select(t ? Hc : Wc); +} +function Uc(t) { + return arguments.length ? this.property("__data__", t) : this.node().__data__; +} +function Yc(t) { + return function(e) { + t.call(this, e, this.__data__); + }; +} +function Gc(t) { + return t.trim().split(/^|\s+/).map(function(e) { + var i = "", r = e.indexOf("."); + return r >= 0 && (i = e.slice(r + 1), e = e.slice(0, r)), { type: e, name: i }; + }); +} +function Vc(t) { + return function() { + var e = this.__on; + if (e) { + for (var i = 0, r = -1, n = e.length, o; i < n; ++i) + o = e[i], (!t.type || o.type === t.type) && o.name === t.name ? this.removeEventListener(o.type, o.listener, o.options) : e[++r] = o; + ++r ? e.length = r : delete this.__on; + } + }; +} +function Xc(t, e, i) { + return function() { + var r = this.__on, n, o = Yc(e); + if (r) { + for (var s = 0, a = r.length; s < a; ++s) + if ((n = r[s]).type === t.type && n.name === t.name) { + this.removeEventListener(n.type, n.listener, n.options), this.addEventListener(n.type, n.listener = o, n.options = i), n.value = e; + return; + } + } + this.addEventListener(t.type, o, i), n = { type: t.type, name: t.name, value: e, listener: o, options: i }, r ? r.push(n) : this.__on = [n]; + }; +} +function Kc(t, e, i) { + var r = Gc(t + ""), n, o = r.length, s; + if (arguments.length < 2) { + var a = this.node().__on; + if (a) { + for (var l = 0, h = a.length, u; l < h; ++l) + for (n = 0, u = a[l]; n < o; ++n) + if ((s = r[n]).type === u.type && s.name === u.name) + return u.value; + } + return; + } + for (a = e ? Xc : Vc, n = 0; n < o; ++n) + this.each(a(r[n], e, i)); + return this; +} +function Ks(t, e, i) { + var r = Us(t), n = r.CustomEvent; + typeof n == "function" ? n = new n(e, i) : (n = r.document.createEvent("Event"), i ? (n.initEvent(e, i.bubbles, i.cancelable), n.detail = i.detail) : n.initEvent(e, !1, !1)), t.dispatchEvent(n); +} +function Zc(t, e) { + return function() { + return Ks(this, t, e); + }; +} +function Jc(t, e) { + return function() { + return Ks(this, t, e.apply(this, arguments)); + }; +} +function Qc(t, e) { + return this.each((typeof e == "function" ? Jc : Zc)(t, e)); +} +function* tu() { + for (var t = this._groups, e = 0, i = t.length; e < i; ++e) + for (var r = t[e], n = 0, o = r.length, s; n < o; ++n) + (s = r[n]) && (yield s); +} +var Zs = [null]; +function yt(t, e) { + this._groups = t, this._parents = e; +} +function di() { + return new yt([[document.documentElement]], Zs); +} +function eu() { + return this; +} +yt.prototype = di.prototype = { + constructor: yt, + select: Bh, + selectAll: Eh, + selectChild: Ih, + selectChildren: Ph, + filter: qh, + data: Yh, + enter: zh, + exit: Vh, + join: Xh, + merge: Kh, + selection: eu, + order: Zh, + sort: Jh, + call: tc, + nodes: ec, + node: ic, + size: rc, + empty: nc, + each: oc, + attr: fc, + style: mc, + property: xc, + classed: Sc, + text: Fc, + html: Mc, + raise: $c, + lower: Dc, + append: Nc, + insert: Pc, + remove: zc, + clone: jc, + datum: Uc, + on: Kc, + dispatch: Qc, + [Symbol.iterator]: tu +}; +function bt(t) { + return typeof t == "string" ? new yt([[document.querySelector(t)]], [document.documentElement]) : new yt([[t]], Zs); +} +function Sn(t, e, i) { + t.prototype = e.prototype = i, i.constructor = t; +} +function Js(t, e) { + var i = Object.create(t.prototype); + for (var r in e) + i[r] = e[r]; + return i; +} +function pi() { +} +var ri = 0.7, Ui = 1 / ri, Fe = "\\s*([+-]?\\d+)\\s*", ni = "\\s*([+-]?(?:\\d*\\.)?\\d+(?:[eE][+-]?\\d+)?)\\s*", Et = "\\s*([+-]?(?:\\d*\\.)?\\d+(?:[eE][+-]?\\d+)?)%\\s*", iu = /^#([0-9a-f]{3,8})$/, ru = new RegExp(`^rgb\\(${Fe},${Fe},${Fe}\\)$`), nu = new RegExp(`^rgb\\(${Et},${Et},${Et}\\)$`), ou = new RegExp(`^rgba\\(${Fe},${Fe},${Fe},${ni}\\)$`), su = new RegExp(`^rgba\\(${Et},${Et},${Et},${ni}\\)$`), au = new RegExp(`^hsl\\(${ni},${Et},${Et}\\)$`), lu = new RegExp(`^hsla\\(${ni},${Et},${Et},${ni}\\)$`), So = { + aliceblue: 15792383, + antiquewhite: 16444375, + aqua: 65535, + aquamarine: 8388564, + azure: 15794175, + beige: 16119260, + bisque: 16770244, + black: 0, + blanchedalmond: 16772045, + blue: 255, + blueviolet: 9055202, + brown: 10824234, + burlywood: 14596231, + cadetblue: 6266528, + chartreuse: 8388352, + chocolate: 13789470, + coral: 16744272, + cornflowerblue: 6591981, + cornsilk: 16775388, + crimson: 14423100, + cyan: 65535, + darkblue: 139, + darkcyan: 35723, + darkgoldenrod: 12092939, + darkgray: 11119017, + darkgreen: 25600, + darkgrey: 11119017, + darkkhaki: 12433259, + darkmagenta: 9109643, + darkolivegreen: 5597999, + darkorange: 16747520, + darkorchid: 10040012, + darkred: 9109504, + darksalmon: 15308410, + darkseagreen: 9419919, + darkslateblue: 4734347, + darkslategray: 3100495, + darkslategrey: 3100495, + darkturquoise: 52945, + darkviolet: 9699539, + deeppink: 16716947, + deepskyblue: 49151, + dimgray: 6908265, + dimgrey: 6908265, + dodgerblue: 2003199, + firebrick: 11674146, + floralwhite: 16775920, + forestgreen: 2263842, + fuchsia: 16711935, + gainsboro: 14474460, + ghostwhite: 16316671, + gold: 16766720, + goldenrod: 14329120, + gray: 8421504, + green: 32768, + greenyellow: 11403055, + grey: 8421504, + honeydew: 15794160, + hotpink: 16738740, + indianred: 13458524, + indigo: 4915330, + ivory: 16777200, + khaki: 15787660, + lavender: 15132410, + lavenderblush: 16773365, + lawngreen: 8190976, + lemonchiffon: 16775885, + lightblue: 11393254, + lightcoral: 15761536, + lightcyan: 14745599, + lightgoldenrodyellow: 16448210, + lightgray: 13882323, + lightgreen: 9498256, + lightgrey: 13882323, + lightpink: 16758465, + lightsalmon: 16752762, + lightseagreen: 2142890, + lightskyblue: 8900346, + lightslategray: 7833753, + lightslategrey: 7833753, + lightsteelblue: 11584734, + lightyellow: 16777184, + lime: 65280, + limegreen: 3329330, + linen: 16445670, + magenta: 16711935, + maroon: 8388608, + mediumaquamarine: 6737322, + mediumblue: 205, + mediumorchid: 12211667, + mediumpurple: 9662683, + mediumseagreen: 3978097, + mediumslateblue: 8087790, + mediumspringgreen: 64154, + mediumturquoise: 4772300, + mediumvioletred: 13047173, + midnightblue: 1644912, + mintcream: 16121850, + mistyrose: 16770273, + moccasin: 16770229, + navajowhite: 16768685, + navy: 128, + oldlace: 16643558, + olive: 8421376, + olivedrab: 7048739, + orange: 16753920, + orangered: 16729344, + orchid: 14315734, + palegoldenrod: 15657130, + palegreen: 10025880, + paleturquoise: 11529966, + palevioletred: 14381203, + papayawhip: 16773077, + peachpuff: 16767673, + peru: 13468991, + pink: 16761035, + plum: 14524637, + powderblue: 11591910, + purple: 8388736, + rebeccapurple: 6697881, + red: 16711680, + rosybrown: 12357519, + royalblue: 4286945, + saddlebrown: 9127187, + salmon: 16416882, + sandybrown: 16032864, + seagreen: 3050327, + seashell: 16774638, + sienna: 10506797, + silver: 12632256, + skyblue: 8900331, + slateblue: 6970061, + slategray: 7372944, + slategrey: 7372944, + snow: 16775930, + springgreen: 65407, + steelblue: 4620980, + tan: 13808780, + teal: 32896, + thistle: 14204888, + tomato: 16737095, + turquoise: 4251856, + violet: 15631086, + wheat: 16113331, + white: 16777215, + whitesmoke: 16119285, + yellow: 16776960, + yellowgreen: 10145074 +}; +Sn(pi, oi, { + copy(t) { + return Object.assign(new this.constructor(), this, t); + }, + displayable() { + return this.rgb().displayable(); + }, + hex: vo, + // Deprecated! Use color.formatHex. + formatHex: vo, + formatHex8: hu, + formatHsl: cu, + formatRgb: wo, + toString: wo +}); +function vo() { + return this.rgb().formatHex(); +} +function hu() { + return this.rgb().formatHex8(); +} +function cu() { + return Qs(this).formatHsl(); +} +function wo() { + return this.rgb().formatRgb(); +} +function oi(t) { + var e, i; + return t = (t + "").trim().toLowerCase(), (e = iu.exec(t)) ? (i = e[1].length, e = parseInt(e[1], 16), i === 6 ? Bo(e) : i === 3 ? new pt(e >> 8 & 15 | e >> 4 & 240, e >> 4 & 15 | e & 240, (e & 15) << 4 | e & 15, 1) : i === 8 ? ki(e >> 24 & 255, e >> 16 & 255, e >> 8 & 255, (e & 255) / 255) : i === 4 ? ki(e >> 12 & 15 | e >> 8 & 240, e >> 8 & 15 | e >> 4 & 240, e >> 4 & 15 | e & 240, ((e & 15) << 4 | e & 15) / 255) : null) : (e = ru.exec(t)) ? new pt(e[1], e[2], e[3], 1) : (e = nu.exec(t)) ? new pt(e[1] * 255 / 100, e[2] * 255 / 100, e[3] * 255 / 100, 1) : (e = ou.exec(t)) ? ki(e[1], e[2], e[3], e[4]) : (e = su.exec(t)) ? ki(e[1] * 255 / 100, e[2] * 255 / 100, e[3] * 255 / 100, e[4]) : (e = au.exec(t)) ? Lo(e[1], e[2] / 100, e[3] / 100, 1) : (e = lu.exec(t)) ? Lo(e[1], e[2] / 100, e[3] / 100, e[4]) : So.hasOwnProperty(t) ? Bo(So[t]) : t === "transparent" ? new pt(NaN, NaN, NaN, 0) : null; +} +function Bo(t) { + return new pt(t >> 16 & 255, t >> 8 & 255, t & 255, 1); +} +function ki(t, e, i, r) { + return r <= 0 && (t = e = i = NaN), new pt(t, e, i, r); +} +function uu(t) { + return t instanceof pi || (t = oi(t)), t ? (t = t.rgb(), new pt(t.r, t.g, t.b, t.opacity)) : new pt(); +} +function Qr(t, e, i, r) { + return arguments.length === 1 ? uu(t) : new pt(t, e, i, r ?? 1); +} +function pt(t, e, i, r) { + this.r = +t, this.g = +e, this.b = +i, this.opacity = +r; +} +Sn(pt, Qr, Js(pi, { + brighter(t) { + return t = t == null ? Ui : Math.pow(Ui, t), new pt(this.r * t, this.g * t, this.b * t, this.opacity); + }, + darker(t) { + return t = t == null ? ri : Math.pow(ri, t), new pt(this.r * t, this.g * t, this.b * t, this.opacity); + }, + rgb() { + return this; + }, + clamp() { + return new pt(ue(this.r), ue(this.g), ue(this.b), Yi(this.opacity)); + }, + displayable() { + return -0.5 <= this.r && this.r < 255.5 && -0.5 <= this.g && this.g < 255.5 && -0.5 <= this.b && this.b < 255.5 && 0 <= this.opacity && this.opacity <= 1; + }, + hex: Fo, + // Deprecated! Use color.formatHex. + formatHex: Fo, + formatHex8: fu, + formatRgb: Ao, + toString: Ao +})); +function Fo() { + return `#${ce(this.r)}${ce(this.g)}${ce(this.b)}`; +} +function fu() { + return `#${ce(this.r)}${ce(this.g)}${ce(this.b)}${ce((isNaN(this.opacity) ? 1 : this.opacity) * 255)}`; +} +function Ao() { + const t = Yi(this.opacity); + return `${t === 1 ? "rgb(" : "rgba("}${ue(this.r)}, ${ue(this.g)}, ${ue(this.b)}${t === 1 ? ")" : `, ${t})`}`; +} +function Yi(t) { + return isNaN(t) ? 1 : Math.max(0, Math.min(1, t)); +} +function ue(t) { + return Math.max(0, Math.min(255, Math.round(t) || 0)); +} +function ce(t) { + return t = ue(t), (t < 16 ? "0" : "") + t.toString(16); +} +function Lo(t, e, i, r) { + return r <= 0 ? t = e = i = NaN : i <= 0 || i >= 1 ? t = e = NaN : e <= 0 && (t = NaN), new wt(t, e, i, r); +} +function Qs(t) { + if (t instanceof wt) + return new wt(t.h, t.s, t.l, t.opacity); + if (t instanceof pi || (t = oi(t)), !t) + return new wt(); + if (t instanceof wt) + return t; + t = t.rgb(); + var e = t.r / 255, i = t.g / 255, r = t.b / 255, n = Math.min(e, i, r), o = Math.max(e, i, r), s = NaN, a = o - n, l = (o + n) / 2; + return a ? (e === o ? s = (i - r) / a + (i < r) * 6 : i === o ? s = (r - e) / a + 2 : s = (e - i) / a + 4, a /= l < 0.5 ? o + n : 2 - o - n, s *= 60) : a = l > 0 && l < 1 ? 0 : s, new wt(s, a, l, t.opacity); +} +function du(t, e, i, r) { + return arguments.length === 1 ? Qs(t) : new wt(t, e, i, r ?? 1); +} +function wt(t, e, i, r) { + this.h = +t, this.s = +e, this.l = +i, this.opacity = +r; +} +Sn(wt, du, Js(pi, { + brighter(t) { + return t = t == null ? Ui : Math.pow(Ui, t), new wt(this.h, this.s, this.l * t, this.opacity); + }, + darker(t) { + return t = t == null ? ri : Math.pow(ri, t), new wt(this.h, this.s, this.l * t, this.opacity); + }, + rgb() { + var t = this.h % 360 + (this.h < 0) * 360, e = isNaN(t) || isNaN(this.s) ? 0 : this.s, i = this.l, r = i + (i < 0.5 ? i : 1 - i) * e, n = 2 * i - r; + return new pt( + Dr(t >= 240 ? t - 240 : t + 120, n, r), + Dr(t, n, r), + Dr(t < 120 ? t + 240 : t - 120, n, r), + this.opacity + ); + }, + clamp() { + return new wt(Eo(this.h), Si(this.s), Si(this.l), Yi(this.opacity)); + }, + displayable() { + return (0 <= this.s && this.s <= 1 || isNaN(this.s)) && 0 <= this.l && this.l <= 1 && 0 <= this.opacity && this.opacity <= 1; + }, + formatHsl() { + const t = Yi(this.opacity); + return `${t === 1 ? "hsl(" : "hsla("}${Eo(this.h)}, ${Si(this.s) * 100}%, ${Si(this.l) * 100}%${t === 1 ? ")" : `, ${t})`}`; + } +})); +function Eo(t) { + return t = (t || 0) % 360, t < 0 ? t + 360 : t; +} +function Si(t) { + return Math.max(0, Math.min(1, t || 0)); +} +function Dr(t, e, i) { + return (t < 60 ? e + (i - e) * t / 60 : t < 180 ? i : t < 240 ? e + (i - e) * (240 - t) / 60 : e) * 255; +} +const vn = (t) => () => t; +function ta(t, e) { + return function(i) { + return t + i * e; + }; +} +function pu(t, e, i) { + return t = Math.pow(t, i), e = Math.pow(e, i) - t, i = 1 / i, function(r) { + return Math.pow(t + r * e, i); + }; +} +function l1(t, e) { + var i = e - t; + return i ? ta(t, i > 180 || i < -180 ? i - 360 * Math.round(i / 360) : i) : vn(isNaN(t) ? e : t); +} +function gu(t) { + return (t = +t) == 1 ? ea : function(e, i) { + return i - e ? pu(e, i, t) : vn(isNaN(e) ? i : e); + }; +} +function ea(t, e) { + var i = e - t; + return i ? ta(t, i) : vn(isNaN(t) ? e : t); +} +const Mo = function t(e) { + var i = gu(e); + function r(n, o) { + var s = i((n = Qr(n)).r, (o = Qr(o)).r), a = i(n.g, o.g), l = i(n.b, o.b), h = ea(n.opacity, o.opacity); + return function(u) { + return n.r = s(u), n.g = a(u), n.b = l(u), n.opacity = h(u), n + ""; + }; + } + return r.gamma = t, r; +}(1); +function te(t, e) { + return t = +t, e = +e, function(i) { + return t * (1 - i) + e * i; + }; +} +var tn = /[-+]?(?:\d+\.?\d*|\.?\d+)(?:[eE][-+]?\d+)?/g, Nr = new RegExp(tn.source, "g"); +function mu(t) { + return function() { + return t; + }; +} +function yu(t) { + return function(e) { + return t(e) + ""; + }; +} +function _u(t, e) { + var i = tn.lastIndex = Nr.lastIndex = 0, r, n, o, s = -1, a = [], l = []; + for (t = t + "", e = e + ""; (r = tn.exec(t)) && (n = Nr.exec(e)); ) + (o = n.index) > i && (o = e.slice(i, o), a[s] ? a[s] += o : a[++s] = o), (r = r[0]) === (n = n[0]) ? a[s] ? a[s] += n : a[++s] = n : (a[++s] = null, l.push({ i: s, x: te(r, n) })), i = Nr.lastIndex; + return i < e.length && (o = e.slice(i), a[s] ? a[s] += o : a[++s] = o), a.length < 2 ? l[0] ? yu(l[0].x) : mu(e) : (e = l.length, function(h) { + for (var u = 0, f; u < e; ++u) + a[(f = l[u]).i] = f.x(h); + return a.join(""); + }); +} +var Oo = 180 / Math.PI, en = { + translateX: 0, + translateY: 0, + rotate: 0, + skewX: 0, + scaleX: 1, + scaleY: 1 +}; +function ia(t, e, i, r, n, o) { + var s, a, l; + return (s = Math.sqrt(t * t + e * e)) && (t /= s, e /= s), (l = t * i + e * r) && (i -= t * l, r -= e * l), (a = Math.sqrt(i * i + r * r)) && (i /= a, r /= a, l /= a), t * r < e * i && (t = -t, e = -e, l = -l, s = -s), { + translateX: n, + translateY: o, + rotate: Math.atan2(e, t) * Oo, + skewX: Math.atan(l) * Oo, + scaleX: s, + scaleY: a + }; +} +var vi; +function Cu(t) { + const e = new (typeof DOMMatrix == "function" ? DOMMatrix : WebKitCSSMatrix)(t + ""); + return e.isIdentity ? en : ia(e.a, e.b, e.c, e.d, e.e, e.f); +} +function xu(t) { + return t == null || (vi || (vi = document.createElementNS("http://www.w3.org/2000/svg", "g")), vi.setAttribute("transform", t), !(t = vi.transform.baseVal.consolidate())) ? en : (t = t.matrix, ia(t.a, t.b, t.c, t.d, t.e, t.f)); +} +function ra(t, e, i, r) { + function n(h) { + return h.length ? h.pop() + " " : ""; + } + function o(h, u, f, c, d, m) { + if (h !== f || u !== c) { + var S = d.push("translate(", null, e, null, i); + m.push({ i: S - 4, x: te(h, f) }, { i: S - 2, x: te(u, c) }); + } else + (f || c) && d.push("translate(" + f + e + c + i); + } + function s(h, u, f, c) { + h !== u ? (h - u > 180 ? u += 360 : u - h > 180 && (h += 360), c.push({ i: f.push(n(f) + "rotate(", null, r) - 2, x: te(h, u) })) : u && f.push(n(f) + "rotate(" + u + r); + } + function a(h, u, f, c) { + h !== u ? c.push({ i: f.push(n(f) + "skewX(", null, r) - 2, x: te(h, u) }) : u && f.push(n(f) + "skewX(" + u + r); + } + function l(h, u, f, c, d, m) { + if (h !== f || u !== c) { + var S = d.push(n(d) + "scale(", null, ",", null, ")"); + m.push({ i: S - 4, x: te(h, f) }, { i: S - 2, x: te(u, c) }); + } else + (f !== 1 || c !== 1) && d.push(n(d) + "scale(" + f + "," + c + ")"); + } + return function(h, u) { + var f = [], c = []; + return h = t(h), u = t(u), o(h.translateX, h.translateY, u.translateX, u.translateY, f, c), s(h.rotate, u.rotate, f, c), a(h.skewX, u.skewX, f, c), l(h.scaleX, h.scaleY, u.scaleX, u.scaleY, f, c), h = u = null, function(d) { + for (var m = -1, S = c.length, O; ++m < S; ) + f[(O = c[m]).i] = O.x(d); + return f.join(""); + }; + }; +} +var bu = ra(Cu, "px, ", "px)", "deg)"), Tu = ra(xu, ", ", ")", ")"), Le = 0, Ve = 0, He = 0, na = 1e3, Gi, Xe, Vi = 0, pe = 0, dr = 0, si = typeof performance == "object" && performance.now ? performance : Date, oa = typeof window == "object" && window.requestAnimationFrame ? window.requestAnimationFrame.bind(window) : function(t) { + setTimeout(t, 17); +}; +function wn() { + return pe || (oa(ku), pe = si.now() + dr); +} +function ku() { + pe = 0; +} +function Xi() { + this._call = this._time = this._next = null; +} +Xi.prototype = sa.prototype = { + constructor: Xi, + restart: function(t, e, i) { + if (typeof t != "function") + throw new TypeError("callback is not a function"); + i = (i == null ? wn() : +i) + (e == null ? 0 : +e), !this._next && Xe !== this && (Xe ? Xe._next = this : Gi = this, Xe = this), this._call = t, this._time = i, rn(); + }, + stop: function() { + this._call && (this._call = null, this._time = 1 / 0, rn()); + } +}; +function sa(t, e, i) { + var r = new Xi(); + return r.restart(t, e, i), r; +} +function Su() { + wn(), ++Le; + for (var t = Gi, e; t; ) + (e = pe - t._time) >= 0 && t._call.call(void 0, e), t = t._next; + --Le; +} +function $o() { + pe = (Vi = si.now()) + dr, Le = Ve = 0; + try { + Su(); + } finally { + Le = 0, wu(), pe = 0; + } +} +function vu() { + var t = si.now(), e = t - Vi; + e > na && (dr -= e, Vi = t); +} +function wu() { + for (var t, e = Gi, i, r = 1 / 0; e; ) + e._call ? (r > e._time && (r = e._time), t = e, e = e._next) : (i = e._next, e._next = null, e = t ? t._next = i : Gi = i); + Xe = t, rn(r); +} +function rn(t) { + if (!Le) { + Ve && (Ve = clearTimeout(Ve)); + var e = t - pe; + e > 24 ? (t < 1 / 0 && (Ve = setTimeout($o, t - si.now() - dr)), He && (He = clearInterval(He))) : (He || (Vi = si.now(), He = setInterval(vu, na)), Le = 1, oa($o)); + } +} +function Io(t, e, i) { + var r = new Xi(); + return e = e == null ? 0 : +e, r.restart((n) => { + r.stop(), t(n + e); + }, e, i), r; +} +var Bu = Ps("start", "end", "cancel", "interrupt"), Fu = [], aa = 0, Do = 1, nn = 2, $i = 3, No = 4, on = 5, Ii = 6; +function pr(t, e, i, r, n, o) { + var s = t.__transition; + if (!s) + t.__transition = {}; + else if (i in s) + return; + Au(t, i, { + name: e, + index: r, + // For context during callback. + group: n, + // For context during callback. + on: Bu, + tween: Fu, + time: o.time, + delay: o.delay, + duration: o.duration, + ease: o.ease, + timer: null, + state: aa + }); +} +function Bn(t, e) { + var i = At(t, e); + if (i.state > aa) + throw new Error("too late; already scheduled"); + return i; +} +function It(t, e) { + var i = At(t, e); + if (i.state > $i) + throw new Error("too late; already running"); + return i; +} +function At(t, e) { + var i = t.__transition; + if (!i || !(i = i[e])) + throw new Error("transition not found"); + return i; +} +function Au(t, e, i) { + var r = t.__transition, n; + r[e] = i, i.timer = sa(o, 0, i.time); + function o(h) { + i.state = Do, i.timer.restart(s, i.delay, i.time), i.delay <= h && s(h - i.delay); + } + function s(h) { + var u, f, c, d; + if (i.state !== Do) + return l(); + for (u in r) + if (d = r[u], d.name === i.name) { + if (d.state === $i) + return Io(s); + d.state === No ? (d.state = Ii, d.timer.stop(), d.on.call("interrupt", t, t.__data__, d.index, d.group), delete r[u]) : +u < e && (d.state = Ii, d.timer.stop(), d.on.call("cancel", t, t.__data__, d.index, d.group), delete r[u]); + } + if (Io(function() { + i.state === $i && (i.state = No, i.timer.restart(a, i.delay, i.time), a(h)); + }), i.state = nn, i.on.call("start", t, t.__data__, i.index, i.group), i.state === nn) { + for (i.state = $i, n = new Array(c = i.tween.length), u = 0, f = -1; u < c; ++u) + (d = i.tween[u].value.call(t, t.__data__, i.index, i.group)) && (n[++f] = d); + n.length = f + 1; + } + } + function a(h) { + for (var u = h < i.duration ? i.ease.call(null, h / i.duration) : (i.timer.restart(l), i.state = on, 1), f = -1, c = n.length; ++f < c; ) + n[f].call(t, u); + i.state === on && (i.on.call("end", t, t.__data__, i.index, i.group), l()); + } + function l() { + i.state = Ii, i.timer.stop(), delete r[e]; + for (var h in r) + return; + delete t.__transition; + } +} +function Lu(t, e) { + var i = t.__transition, r, n, o = !0, s; + if (i) { + e = e == null ? null : e + ""; + for (s in i) { + if ((r = i[s]).name !== e) { + o = !1; + continue; + } + n = r.state > nn && r.state < on, r.state = Ii, r.timer.stop(), r.on.call(n ? "interrupt" : "cancel", t, t.__data__, r.index, r.group), delete i[s]; + } + o && delete t.__transition; + } +} +function Eu(t) { + return this.each(function() { + Lu(this, t); + }); +} +function Mu(t, e) { + var i, r; + return function() { + var n = It(this, t), o = n.tween; + if (o !== i) { + r = i = o; + for (var s = 0, a = r.length; s < a; ++s) + if (r[s].name === e) { + r = r.slice(), r.splice(s, 1); + break; + } + } + n.tween = r; + }; +} +function Ou(t, e, i) { + var r, n; + if (typeof i != "function") + throw new Error(); + return function() { + var o = It(this, t), s = o.tween; + if (s !== r) { + n = (r = s).slice(); + for (var a = { name: e, value: i }, l = 0, h = n.length; l < h; ++l) + if (n[l].name === e) { + n[l] = a; + break; + } + l === h && n.push(a); + } + o.tween = n; + }; +} +function $u(t, e) { + var i = this._id; + if (t += "", arguments.length < 2) { + for (var r = At(this.node(), i).tween, n = 0, o = r.length, s; n < o; ++n) + if ((s = r[n]).name === t) + return s.value; + return null; + } + return this.each((e == null ? Mu : Ou)(i, t, e)); +} +function Fn(t, e, i) { + var r = t._id; + return t.each(function() { + var n = It(this, r); + (n.value || (n.value = {}))[e] = i.apply(this, arguments); + }), function(n) { + return At(n, r).value[e]; + }; +} +function la(t, e) { + var i; + return (typeof e == "number" ? te : e instanceof oi ? Mo : (i = oi(e)) ? (e = i, Mo) : _u)(t, e); +} +function Iu(t) { + return function() { + this.removeAttribute(t); + }; +} +function Du(t) { + return function() { + this.removeAttributeNS(t.space, t.local); + }; +} +function Nu(t, e, i) { + var r, n = i + "", o; + return function() { + var s = this.getAttribute(t); + return s === n ? null : s === r ? o : o = e(r = s, i); + }; +} +function Ru(t, e, i) { + var r, n = i + "", o; + return function() { + var s = this.getAttributeNS(t.space, t.local); + return s === n ? null : s === r ? o : o = e(r = s, i); + }; +} +function Pu(t, e, i) { + var r, n, o; + return function() { + var s, a = i(this), l; + return a == null ? void this.removeAttribute(t) : (s = this.getAttribute(t), l = a + "", s === l ? null : s === r && l === n ? o : (n = l, o = e(r = s, a))); + }; +} +function qu(t, e, i) { + var r, n, o; + return function() { + var s, a = i(this), l; + return a == null ? void this.removeAttributeNS(t.space, t.local) : (s = this.getAttributeNS(t.space, t.local), l = a + "", s === l ? null : s === r && l === n ? o : (n = l, o = e(r = s, a))); + }; +} +function zu(t, e) { + var i = fr(t), r = i === "transform" ? Tu : la; + return this.attrTween(t, typeof e == "function" ? (i.local ? qu : Pu)(i, r, Fn(this, "attr." + t, e)) : e == null ? (i.local ? Du : Iu)(i) : (i.local ? Ru : Nu)(i, r, e)); +} +function Wu(t, e) { + return function(i) { + this.setAttribute(t, e.call(this, i)); + }; +} +function Hu(t, e) { + return function(i) { + this.setAttributeNS(t.space, t.local, e.call(this, i)); + }; +} +function ju(t, e) { + var i, r; + function n() { + var o = e.apply(this, arguments); + return o !== r && (i = (r = o) && Hu(t, o)), i; + } + return n._value = e, n; +} +function Uu(t, e) { + var i, r; + function n() { + var o = e.apply(this, arguments); + return o !== r && (i = (r = o) && Wu(t, o)), i; + } + return n._value = e, n; +} +function Yu(t, e) { + var i = "attr." + t; + if (arguments.length < 2) + return (i = this.tween(i)) && i._value; + if (e == null) + return this.tween(i, null); + if (typeof e != "function") + throw new Error(); + var r = fr(t); + return this.tween(i, (r.local ? ju : Uu)(r, e)); +} +function Gu(t, e) { + return function() { + Bn(this, t).delay = +e.apply(this, arguments); + }; +} +function Vu(t, e) { + return e = +e, function() { + Bn(this, t).delay = e; + }; +} +function Xu(t) { + var e = this._id; + return arguments.length ? this.each((typeof t == "function" ? Gu : Vu)(e, t)) : At(this.node(), e).delay; +} +function Ku(t, e) { + return function() { + It(this, t).duration = +e.apply(this, arguments); + }; +} +function Zu(t, e) { + return e = +e, function() { + It(this, t).duration = e; + }; +} +function Ju(t) { + var e = this._id; + return arguments.length ? this.each((typeof t == "function" ? Ku : Zu)(e, t)) : At(this.node(), e).duration; +} +function Qu(t, e) { + if (typeof e != "function") + throw new Error(); + return function() { + It(this, t).ease = e; + }; +} +function tf(t) { + var e = this._id; + return arguments.length ? this.each(Qu(e, t)) : At(this.node(), e).ease; +} +function ef(t, e) { + return function() { + var i = e.apply(this, arguments); + if (typeof i != "function") + throw new Error(); + It(this, t).ease = i; + }; +} +function rf(t) { + if (typeof t != "function") + throw new Error(); + return this.each(ef(this._id, t)); +} +function nf(t) { + typeof t != "function" && (t = Ws(t)); + for (var e = this._groups, i = e.length, r = new Array(i), n = 0; n < i; ++n) + for (var o = e[n], s = o.length, a = r[n] = [], l, h = 0; h < s; ++h) + (l = o[h]) && t.call(l, l.__data__, h, o) && a.push(l); + return new Vt(r, this._parents, this._name, this._id); +} +function of(t) { + if (t._id !== this._id) + throw new Error(); + for (var e = this._groups, i = t._groups, r = e.length, n = i.length, o = Math.min(r, n), s = new Array(r), a = 0; a < o; ++a) + for (var l = e[a], h = i[a], u = l.length, f = s[a] = new Array(u), c, d = 0; d < u; ++d) + (c = l[d] || h[d]) && (f[d] = c); + for (; a < r; ++a) + s[a] = e[a]; + return new Vt(s, this._parents, this._name, this._id); +} +function sf(t) { + return (t + "").trim().split(/^|\s+/).every(function(e) { + var i = e.indexOf("."); + return i >= 0 && (e = e.slice(0, i)), !e || e === "start"; + }); +} +function af(t, e, i) { + var r, n, o = sf(e) ? Bn : It; + return function() { + var s = o(this, t), a = s.on; + a !== r && (n = (r = a).copy()).on(e, i), s.on = n; + }; +} +function lf(t, e) { + var i = this._id; + return arguments.length < 2 ? At(this.node(), i).on.on(t) : this.each(af(i, t, e)); +} +function hf(t) { + return function() { + var e = this.parentNode; + for (var i in this.__transition) + if (+i !== t) + return; + e && e.removeChild(this); + }; +} +function cf() { + return this.on("end.remove", hf(this._id)); +} +function uf(t) { + var e = this._name, i = this._id; + typeof t != "function" && (t = Tn(t)); + for (var r = this._groups, n = r.length, o = new Array(n), s = 0; s < n; ++s) + for (var a = r[s], l = a.length, h = o[s] = new Array(l), u, f, c = 0; c < l; ++c) + (u = a[c]) && (f = t.call(u, u.__data__, c, a)) && ("__data__" in u && (f.__data__ = u.__data__), h[c] = f, pr(h[c], e, i, c, h, At(u, i))); + return new Vt(o, this._parents, e, i); +} +function ff(t) { + var e = this._name, i = this._id; + typeof t != "function" && (t = zs(t)); + for (var r = this._groups, n = r.length, o = [], s = [], a = 0; a < n; ++a) + for (var l = r[a], h = l.length, u, f = 0; f < h; ++f) + if (u = l[f]) { + for (var c = t.call(u, u.__data__, f, l), d, m = At(u, i), S = 0, O = c.length; S < O; ++S) + (d = c[S]) && pr(d, e, i, S, c, m); + o.push(c), s.push(u); + } + return new Vt(o, s, e, i); +} +var df = di.prototype.constructor; +function pf() { + return new df(this._groups, this._parents); +} +function gf(t, e) { + var i, r, n; + return function() { + var o = Ae(this, t), s = (this.style.removeProperty(t), Ae(this, t)); + return o === s ? null : o === i && s === r ? n : n = e(i = o, r = s); + }; +} +function ha(t) { + return function() { + this.style.removeProperty(t); + }; +} +function mf(t, e, i) { + var r, n = i + "", o; + return function() { + var s = Ae(this, t); + return s === n ? null : s === r ? o : o = e(r = s, i); + }; +} +function yf(t, e, i) { + var r, n, o; + return function() { + var s = Ae(this, t), a = i(this), l = a + ""; + return a == null && (l = a = (this.style.removeProperty(t), Ae(this, t))), s === l ? null : s === r && l === n ? o : (n = l, o = e(r = s, a)); + }; +} +function _f(t, e) { + var i, r, n, o = "style." + e, s = "end." + o, a; + return function() { + var l = It(this, t), h = l.on, u = l.value[o] == null ? a || (a = ha(e)) : void 0; + (h !== i || n !== u) && (r = (i = h).copy()).on(s, n = u), l.on = r; + }; +} +function Cf(t, e, i) { + var r = (t += "") == "transform" ? bu : la; + return e == null ? this.styleTween(t, gf(t, r)).on("end.style." + t, ha(t)) : typeof e == "function" ? this.styleTween(t, yf(t, r, Fn(this, "style." + t, e))).each(_f(this._id, t)) : this.styleTween(t, mf(t, r, e), i).on("end.style." + t, null); +} +function xf(t, e, i) { + return function(r) { + this.style.setProperty(t, e.call(this, r), i); + }; +} +function bf(t, e, i) { + var r, n; + function o() { + var s = e.apply(this, arguments); + return s !== n && (r = (n = s) && xf(t, s, i)), r; + } + return o._value = e, o; +} +function Tf(t, e, i) { + var r = "style." + (t += ""); + if (arguments.length < 2) + return (r = this.tween(r)) && r._value; + if (e == null) + return this.tween(r, null); + if (typeof e != "function") + throw new Error(); + return this.tween(r, bf(t, e, i ?? "")); +} +function kf(t) { + return function() { + this.textContent = t; + }; +} +function Sf(t) { + return function() { + var e = t(this); + this.textContent = e ?? ""; + }; +} +function vf(t) { + return this.tween("text", typeof t == "function" ? Sf(Fn(this, "text", t)) : kf(t == null ? "" : t + "")); +} +function wf(t) { + return function(e) { + this.textContent = t.call(this, e); + }; +} +function Bf(t) { + var e, i; + function r() { + var n = t.apply(this, arguments); + return n !== i && (e = (i = n) && wf(n)), e; + } + return r._value = t, r; +} +function Ff(t) { + var e = "text"; + if (arguments.length < 1) + return (e = this.tween(e)) && e._value; + if (t == null) + return this.tween(e, null); + if (typeof t != "function") + throw new Error(); + return this.tween(e, Bf(t)); +} +function Af() { + for (var t = this._name, e = this._id, i = ca(), r = this._groups, n = r.length, o = 0; o < n; ++o) + for (var s = r[o], a = s.length, l, h = 0; h < a; ++h) + if (l = s[h]) { + var u = At(l, e); + pr(l, t, i, h, s, { + time: u.time + u.delay + u.duration, + delay: 0, + duration: u.duration, + ease: u.ease + }); + } + return new Vt(r, this._parents, t, i); +} +function Lf() { + var t, e, i = this, r = i._id, n = i.size(); + return new Promise(function(o, s) { + var a = { value: s }, l = { value: function() { + --n === 0 && o(); + } }; + i.each(function() { + var h = It(this, r), u = h.on; + u !== t && (e = (t = u).copy(), e._.cancel.push(a), e._.interrupt.push(a), e._.end.push(l)), h.on = e; + }), n === 0 && o(); + }); +} +var Ef = 0; +function Vt(t, e, i, r) { + this._groups = t, this._parents = e, this._name = i, this._id = r; +} +function ca() { + return ++Ef; +} +var Ht = di.prototype; +Vt.prototype = { + constructor: Vt, + select: uf, + selectAll: ff, + selectChild: Ht.selectChild, + selectChildren: Ht.selectChildren, + filter: nf, + merge: of, + selection: pf, + transition: Af, + call: Ht.call, + nodes: Ht.nodes, + node: Ht.node, + size: Ht.size, + empty: Ht.empty, + each: Ht.each, + on: lf, + attr: zu, + attrTween: Yu, + style: Cf, + styleTween: Tf, + text: vf, + textTween: Ff, + remove: cf, + tween: $u, + delay: Xu, + duration: Ju, + ease: tf, + easeVarying: rf, + end: Lf, + [Symbol.iterator]: Ht[Symbol.iterator] +}; +function Mf(t) { + return ((t *= 2) <= 1 ? t * t * t : (t -= 2) * t * t + 2) / 2; +} +var Of = { + time: null, + // Set on use. + delay: 0, + duration: 250, + ease: Mf +}; +function $f(t, e) { + for (var i; !(i = t.__transition) || !(i = i[e]); ) + if (!(t = t.parentNode)) + throw new Error(`transition ${e} not found`); + return i; +} +function If(t) { + var e, i; + t instanceof Vt ? (e = t._id, t = t._name) : (e = ca(), (i = Of).time = wn(), t = t == null ? null : t + ""); + for (var r = this._groups, n = r.length, o = 0; o < n; ++o) + for (var s = r[o], a = s.length, l, h = 0; h < a; ++h) + (l = s[h]) && pr(l, t, e, h, s, i || $f(l, e)); + return new Vt(r, this._parents, t, e); +} +di.prototype.interrupt = Eu; +di.prototype.transition = If; +const h1 = Math.abs, c1 = Math.atan2, u1 = Math.cos, f1 = Math.max, d1 = Math.min, p1 = Math.sin, g1 = Math.sqrt, Ro = 1e-12, An = Math.PI, Po = An / 2, m1 = 2 * An; +function y1(t) { + return t > 1 ? 0 : t < -1 ? An : Math.acos(t); +} +function _1(t) { + return t >= 1 ? Po : t <= -1 ? -Po : Math.asin(t); +} +function ua(t) { + this._context = t; +} +ua.prototype = { + areaStart: function() { + this._line = 0; + }, + areaEnd: function() { + this._line = NaN; + }, + lineStart: function() { + this._point = 0; + }, + lineEnd: function() { + (this._line || this._line !== 0 && this._point === 1) && this._context.closePath(), this._line = 1 - this._line; + }, + point: function(t, e) { + switch (t = +t, e = +e, this._point) { + case 0: + this._point = 1, this._line ? this._context.lineTo(t, e) : this._context.moveTo(t, e); + break; + case 1: + this._point = 2; + default: + this._context.lineTo(t, e); + break; + } + } +}; +function Df(t) { + return new ua(t); +} +class fa { + constructor(e, i) { + this._context = e, this._x = i; + } + areaStart() { + this._line = 0; + } + areaEnd() { + this._line = NaN; + } + lineStart() { + this._point = 0; + } + lineEnd() { + (this._line || this._line !== 0 && this._point === 1) && this._context.closePath(), this._line = 1 - this._line; + } + point(e, i) { + switch (e = +e, i = +i, this._point) { + case 0: { + this._point = 1, this._line ? this._context.lineTo(e, i) : this._context.moveTo(e, i); + break; + } + case 1: + this._point = 2; + default: { + this._x ? this._context.bezierCurveTo(this._x0 = (this._x0 + e) / 2, this._y0, this._x0, i, e, i) : this._context.bezierCurveTo(this._x0, this._y0 = (this._y0 + i) / 2, e, this._y0, e, i); + break; + } + } + this._x0 = e, this._y0 = i; + } +} +function Nf(t) { + return new fa(t, !0); +} +function Rf(t) { + return new fa(t, !1); +} +function ie() { +} +function Ki(t, e, i) { + t._context.bezierCurveTo( + (2 * t._x0 + t._x1) / 3, + (2 * t._y0 + t._y1) / 3, + (t._x0 + 2 * t._x1) / 3, + (t._y0 + 2 * t._y1) / 3, + (t._x0 + 4 * t._x1 + e) / 6, + (t._y0 + 4 * t._y1 + i) / 6 + ); +} +function gr(t) { + this._context = t; +} +gr.prototype = { + areaStart: function() { + this._line = 0; + }, + areaEnd: function() { + this._line = NaN; + }, + lineStart: function() { + this._x0 = this._x1 = this._y0 = this._y1 = NaN, this._point = 0; + }, + lineEnd: function() { + switch (this._point) { + case 3: + Ki(this, this._x1, this._y1); + case 2: + this._context.lineTo(this._x1, this._y1); + break; + } + (this._line || this._line !== 0 && this._point === 1) && this._context.closePath(), this._line = 1 - this._line; + }, + point: function(t, e) { + switch (t = +t, e = +e, this._point) { + case 0: + this._point = 1, this._line ? this._context.lineTo(t, e) : this._context.moveTo(t, e); + break; + case 1: + this._point = 2; + break; + case 2: + this._point = 3, this._context.lineTo((5 * this._x0 + this._x1) / 6, (5 * this._y0 + this._y1) / 6); + default: + Ki(this, t, e); + break; + } + this._x0 = this._x1, this._x1 = t, this._y0 = this._y1, this._y1 = e; + } +}; +function Pf(t) { + return new gr(t); +} +function da(t) { + this._context = t; +} +da.prototype = { + areaStart: ie, + areaEnd: ie, + lineStart: function() { + this._x0 = this._x1 = this._x2 = this._x3 = this._x4 = this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = NaN, this._point = 0; + }, + lineEnd: function() { + switch (this._point) { + case 1: { + this._context.moveTo(this._x2, this._y2), this._context.closePath(); + break; + } + case 2: { + this._context.moveTo((this._x2 + 2 * this._x3) / 3, (this._y2 + 2 * this._y3) / 3), this._context.lineTo((this._x3 + 2 * this._x2) / 3, (this._y3 + 2 * this._y2) / 3), this._context.closePath(); + break; + } + case 3: { + this.point(this._x2, this._y2), this.point(this._x3, this._y3), this.point(this._x4, this._y4); + break; + } + } + }, + point: function(t, e) { + switch (t = +t, e = +e, this._point) { + case 0: + this._point = 1, this._x2 = t, this._y2 = e; + break; + case 1: + this._point = 2, this._x3 = t, this._y3 = e; + break; + case 2: + this._point = 3, this._x4 = t, this._y4 = e, this._context.moveTo((this._x0 + 4 * this._x1 + t) / 6, (this._y0 + 4 * this._y1 + e) / 6); + break; + default: + Ki(this, t, e); + break; + } + this._x0 = this._x1, this._x1 = t, this._y0 = this._y1, this._y1 = e; + } +}; +function qf(t) { + return new da(t); +} +function pa(t) { + this._context = t; +} +pa.prototype = { + areaStart: function() { + this._line = 0; + }, + areaEnd: function() { + this._line = NaN; + }, + lineStart: function() { + this._x0 = this._x1 = this._y0 = this._y1 = NaN, this._point = 0; + }, + lineEnd: function() { + (this._line || this._line !== 0 && this._point === 3) && this._context.closePath(), this._line = 1 - this._line; + }, + point: function(t, e) { + switch (t = +t, e = +e, this._point) { + case 0: + this._point = 1; + break; + case 1: + this._point = 2; + break; + case 2: + this._point = 3; + var i = (this._x0 + 4 * this._x1 + t) / 6, r = (this._y0 + 4 * this._y1 + e) / 6; + this._line ? this._context.lineTo(i, r) : this._context.moveTo(i, r); + break; + case 3: + this._point = 4; + default: + Ki(this, t, e); + break; + } + this._x0 = this._x1, this._x1 = t, this._y0 = this._y1, this._y1 = e; + } +}; +function zf(t) { + return new pa(t); +} +function ga(t, e) { + this._basis = new gr(t), this._beta = e; +} +ga.prototype = { + lineStart: function() { + this._x = [], this._y = [], this._basis.lineStart(); + }, + lineEnd: function() { + var t = this._x, e = this._y, i = t.length - 1; + if (i > 0) + for (var r = t[0], n = e[0], o = t[i] - r, s = e[i] - n, a = -1, l; ++a <= i; ) + l = a / i, this._basis.point( + this._beta * t[a] + (1 - this._beta) * (r + l * o), + this._beta * e[a] + (1 - this._beta) * (n + l * s) + ); + this._x = this._y = null, this._basis.lineEnd(); + }, + point: function(t, e) { + this._x.push(+t), this._y.push(+e); + } +}; +const Wf = function t(e) { + function i(r) { + return e === 1 ? new gr(r) : new ga(r, e); + } + return i.beta = function(r) { + return t(+r); + }, i; +}(0.85); +function Zi(t, e, i) { + t._context.bezierCurveTo( + t._x1 + t._k * (t._x2 - t._x0), + t._y1 + t._k * (t._y2 - t._y0), + t._x2 + t._k * (t._x1 - e), + t._y2 + t._k * (t._y1 - i), + t._x2, + t._y2 + ); +} +function Ln(t, e) { + this._context = t, this._k = (1 - e) / 6; +} +Ln.prototype = { + areaStart: function() { + this._line = 0; + }, + areaEnd: function() { + this._line = NaN; + }, + lineStart: function() { + this._x0 = this._x1 = this._x2 = this._y0 = this._y1 = this._y2 = NaN, this._point = 0; + }, + lineEnd: function() { + switch (this._point) { + case 2: + this._context.lineTo(this._x2, this._y2); + break; + case 3: + Zi(this, this._x1, this._y1); + break; + } + (this._line || this._line !== 0 && this._point === 1) && this._context.closePath(), this._line = 1 - this._line; + }, + point: function(t, e) { + switch (t = +t, e = +e, this._point) { + case 0: + this._point = 1, this._line ? this._context.lineTo(t, e) : this._context.moveTo(t, e); + break; + case 1: + this._point = 2, this._x1 = t, this._y1 = e; + break; + case 2: + this._point = 3; + default: + Zi(this, t, e); + break; + } + this._x0 = this._x1, this._x1 = this._x2, this._x2 = t, this._y0 = this._y1, this._y1 = this._y2, this._y2 = e; + } +}; +const Hf = function t(e) { + function i(r) { + return new Ln(r, e); + } + return i.tension = function(r) { + return t(+r); + }, i; +}(0); +function En(t, e) { + this._context = t, this._k = (1 - e) / 6; +} +En.prototype = { + areaStart: ie, + areaEnd: ie, + lineStart: function() { + this._x0 = this._x1 = this._x2 = this._x3 = this._x4 = this._x5 = this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = this._y5 = NaN, this._point = 0; + }, + lineEnd: function() { + switch (this._point) { + case 1: { + this._context.moveTo(this._x3, this._y3), this._context.closePath(); + break; + } + case 2: { + this._context.lineTo(this._x3, this._y3), this._context.closePath(); + break; + } + case 3: { + this.point(this._x3, this._y3), this.point(this._x4, this._y4), this.point(this._x5, this._y5); + break; + } + } + }, + point: function(t, e) { + switch (t = +t, e = +e, this._point) { + case 0: + this._point = 1, this._x3 = t, this._y3 = e; + break; + case 1: + this._point = 2, this._context.moveTo(this._x4 = t, this._y4 = e); + break; + case 2: + this._point = 3, this._x5 = t, this._y5 = e; + break; + default: + Zi(this, t, e); + break; + } + this._x0 = this._x1, this._x1 = this._x2, this._x2 = t, this._y0 = this._y1, this._y1 = this._y2, this._y2 = e; + } +}; +const jf = function t(e) { + function i(r) { + return new En(r, e); + } + return i.tension = function(r) { + return t(+r); + }, i; +}(0); +function Mn(t, e) { + this._context = t, this._k = (1 - e) / 6; +} +Mn.prototype = { + areaStart: function() { + this._line = 0; + }, + areaEnd: function() { + this._line = NaN; + }, + lineStart: function() { + this._x0 = this._x1 = this._x2 = this._y0 = this._y1 = this._y2 = NaN, this._point = 0; + }, + lineEnd: function() { + (this._line || this._line !== 0 && this._point === 3) && this._context.closePath(), this._line = 1 - this._line; + }, + point: function(t, e) { + switch (t = +t, e = +e, this._point) { + case 0: + this._point = 1; + break; + case 1: + this._point = 2; + break; + case 2: + this._point = 3, this._line ? this._context.lineTo(this._x2, this._y2) : this._context.moveTo(this._x2, this._y2); + break; + case 3: + this._point = 4; + default: + Zi(this, t, e); + break; + } + this._x0 = this._x1, this._x1 = this._x2, this._x2 = t, this._y0 = this._y1, this._y1 = this._y2, this._y2 = e; + } +}; +const Uf = function t(e) { + function i(r) { + return new Mn(r, e); + } + return i.tension = function(r) { + return t(+r); + }, i; +}(0); +function On(t, e, i) { + var r = t._x1, n = t._y1, o = t._x2, s = t._y2; + if (t._l01_a > Ro) { + var a = 2 * t._l01_2a + 3 * t._l01_a * t._l12_a + t._l12_2a, l = 3 * t._l01_a * (t._l01_a + t._l12_a); + r = (r * a - t._x0 * t._l12_2a + t._x2 * t._l01_2a) / l, n = (n * a - t._y0 * t._l12_2a + t._y2 * t._l01_2a) / l; + } + if (t._l23_a > Ro) { + var h = 2 * t._l23_2a + 3 * t._l23_a * t._l12_a + t._l12_2a, u = 3 * t._l23_a * (t._l23_a + t._l12_a); + o = (o * h + t._x1 * t._l23_2a - e * t._l12_2a) / u, s = (s * h + t._y1 * t._l23_2a - i * t._l12_2a) / u; + } + t._context.bezierCurveTo(r, n, o, s, t._x2, t._y2); +} +function ma(t, e) { + this._context = t, this._alpha = e; +} +ma.prototype = { + areaStart: function() { + this._line = 0; + }, + areaEnd: function() { + this._line = NaN; + }, + lineStart: function() { + this._x0 = this._x1 = this._x2 = this._y0 = this._y1 = this._y2 = NaN, this._l01_a = this._l12_a = this._l23_a = this._l01_2a = this._l12_2a = this._l23_2a = this._point = 0; + }, + lineEnd: function() { + switch (this._point) { + case 2: + this._context.lineTo(this._x2, this._y2); + break; + case 3: + this.point(this._x2, this._y2); + break; + } + (this._line || this._line !== 0 && this._point === 1) && this._context.closePath(), this._line = 1 - this._line; + }, + point: function(t, e) { + if (t = +t, e = +e, this._point) { + var i = this._x2 - t, r = this._y2 - e; + this._l23_a = Math.sqrt(this._l23_2a = Math.pow(i * i + r * r, this._alpha)); + } + switch (this._point) { + case 0: + this._point = 1, this._line ? this._context.lineTo(t, e) : this._context.moveTo(t, e); + break; + case 1: + this._point = 2; + break; + case 2: + this._point = 3; + default: + On(this, t, e); + break; + } + this._l01_a = this._l12_a, this._l12_a = this._l23_a, this._l01_2a = this._l12_2a, this._l12_2a = this._l23_2a, this._x0 = this._x1, this._x1 = this._x2, this._x2 = t, this._y0 = this._y1, this._y1 = this._y2, this._y2 = e; + } +}; +const Yf = function t(e) { + function i(r) { + return e ? new ma(r, e) : new Ln(r, 0); + } + return i.alpha = function(r) { + return t(+r); + }, i; +}(0.5); +function ya(t, e) { + this._context = t, this._alpha = e; +} +ya.prototype = { + areaStart: ie, + areaEnd: ie, + lineStart: function() { + this._x0 = this._x1 = this._x2 = this._x3 = this._x4 = this._x5 = this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = this._y5 = NaN, this._l01_a = this._l12_a = this._l23_a = this._l01_2a = this._l12_2a = this._l23_2a = this._point = 0; + }, + lineEnd: function() { + switch (this._point) { + case 1: { + this._context.moveTo(this._x3, this._y3), this._context.closePath(); + break; + } + case 2: { + this._context.lineTo(this._x3, this._y3), this._context.closePath(); + break; + } + case 3: { + this.point(this._x3, this._y3), this.point(this._x4, this._y4), this.point(this._x5, this._y5); + break; + } + } + }, + point: function(t, e) { + if (t = +t, e = +e, this._point) { + var i = this._x2 - t, r = this._y2 - e; + this._l23_a = Math.sqrt(this._l23_2a = Math.pow(i * i + r * r, this._alpha)); + } + switch (this._point) { + case 0: + this._point = 1, this._x3 = t, this._y3 = e; + break; + case 1: + this._point = 2, this._context.moveTo(this._x4 = t, this._y4 = e); + break; + case 2: + this._point = 3, this._x5 = t, this._y5 = e; + break; + default: + On(this, t, e); + break; + } + this._l01_a = this._l12_a, this._l12_a = this._l23_a, this._l01_2a = this._l12_2a, this._l12_2a = this._l23_2a, this._x0 = this._x1, this._x1 = this._x2, this._x2 = t, this._y0 = this._y1, this._y1 = this._y2, this._y2 = e; + } +}; +const Gf = function t(e) { + function i(r) { + return e ? new ya(r, e) : new En(r, 0); + } + return i.alpha = function(r) { + return t(+r); + }, i; +}(0.5); +function _a(t, e) { + this._context = t, this._alpha = e; +} +_a.prototype = { + areaStart: function() { + this._line = 0; + }, + areaEnd: function() { + this._line = NaN; + }, + lineStart: function() { + this._x0 = this._x1 = this._x2 = this._y0 = this._y1 = this._y2 = NaN, this._l01_a = this._l12_a = this._l23_a = this._l01_2a = this._l12_2a = this._l23_2a = this._point = 0; + }, + lineEnd: function() { + (this._line || this._line !== 0 && this._point === 3) && this._context.closePath(), this._line = 1 - this._line; + }, + point: function(t, e) { + if (t = +t, e = +e, this._point) { + var i = this._x2 - t, r = this._y2 - e; + this._l23_a = Math.sqrt(this._l23_2a = Math.pow(i * i + r * r, this._alpha)); + } + switch (this._point) { + case 0: + this._point = 1; + break; + case 1: + this._point = 2; + break; + case 2: + this._point = 3, this._line ? this._context.lineTo(this._x2, this._y2) : this._context.moveTo(this._x2, this._y2); + break; + case 3: + this._point = 4; + default: + On(this, t, e); + break; + } + this._l01_a = this._l12_a, this._l12_a = this._l23_a, this._l01_2a = this._l12_2a, this._l12_2a = this._l23_2a, this._x0 = this._x1, this._x1 = this._x2, this._x2 = t, this._y0 = this._y1, this._y1 = this._y2, this._y2 = e; + } +}; +const Vf = function t(e) { + function i(r) { + return e ? new _a(r, e) : new Mn(r, 0); + } + return i.alpha = function(r) { + return t(+r); + }, i; +}(0.5); +function Ca(t) { + this._context = t; +} +Ca.prototype = { + areaStart: ie, + areaEnd: ie, + lineStart: function() { + this._point = 0; + }, + lineEnd: function() { + this._point && this._context.closePath(); + }, + point: function(t, e) { + t = +t, e = +e, this._point ? this._context.lineTo(t, e) : (this._point = 1, this._context.moveTo(t, e)); + } +}; +function Xf(t) { + return new Ca(t); +} +function qo(t) { + return t < 0 ? -1 : 1; +} +function zo(t, e, i) { + var r = t._x1 - t._x0, n = e - t._x1, o = (t._y1 - t._y0) / (r || n < 0 && -0), s = (i - t._y1) / (n || r < 0 && -0), a = (o * n + s * r) / (r + n); + return (qo(o) + qo(s)) * Math.min(Math.abs(o), Math.abs(s), 0.5 * Math.abs(a)) || 0; +} +function Wo(t, e) { + var i = t._x1 - t._x0; + return i ? (3 * (t._y1 - t._y0) / i - e) / 2 : e; +} +function Rr(t, e, i) { + var r = t._x0, n = t._y0, o = t._x1, s = t._y1, a = (o - r) / 3; + t._context.bezierCurveTo(r + a, n + a * e, o - a, s - a * i, o, s); +} +function Ji(t) { + this._context = t; +} +Ji.prototype = { + areaStart: function() { + this._line = 0; + }, + areaEnd: function() { + this._line = NaN; + }, + lineStart: function() { + this._x0 = this._x1 = this._y0 = this._y1 = this._t0 = NaN, this._point = 0; + }, + lineEnd: function() { + switch (this._point) { + case 2: + this._context.lineTo(this._x1, this._y1); + break; + case 3: + Rr(this, this._t0, Wo(this, this._t0)); + break; + } + (this._line || this._line !== 0 && this._point === 1) && this._context.closePath(), this._line = 1 - this._line; + }, + point: function(t, e) { + var i = NaN; + if (t = +t, e = +e, !(t === this._x1 && e === this._y1)) { + switch (this._point) { + case 0: + this._point = 1, this._line ? this._context.lineTo(t, e) : this._context.moveTo(t, e); + break; + case 1: + this._point = 2; + break; + case 2: + this._point = 3, Rr(this, Wo(this, i = zo(this, t, e)), i); + break; + default: + Rr(this, this._t0, i = zo(this, t, e)); + break; + } + this._x0 = this._x1, this._x1 = t, this._y0 = this._y1, this._y1 = e, this._t0 = i; + } + } +}; +function xa(t) { + this._context = new ba(t); +} +(xa.prototype = Object.create(Ji.prototype)).point = function(t, e) { + Ji.prototype.point.call(this, e, t); +}; +function ba(t) { + this._context = t; +} +ba.prototype = { + moveTo: function(t, e) { + this._context.moveTo(e, t); + }, + closePath: function() { + this._context.closePath(); + }, + lineTo: function(t, e) { + this._context.lineTo(e, t); + }, + bezierCurveTo: function(t, e, i, r, n, o) { + this._context.bezierCurveTo(e, t, r, i, o, n); + } +}; +function Kf(t) { + return new Ji(t); +} +function Zf(t) { + return new xa(t); +} +function Ta(t) { + this._context = t; +} +Ta.prototype = { + areaStart: function() { + this._line = 0; + }, + areaEnd: function() { + this._line = NaN; + }, + lineStart: function() { + this._x = [], this._y = []; + }, + lineEnd: function() { + var t = this._x, e = this._y, i = t.length; + if (i) + if (this._line ? this._context.lineTo(t[0], e[0]) : this._context.moveTo(t[0], e[0]), i === 2) + this._context.lineTo(t[1], e[1]); + else + for (var r = Ho(t), n = Ho(e), o = 0, s = 1; s < i; ++o, ++s) + this._context.bezierCurveTo(r[0][o], n[0][o], r[1][o], n[1][o], t[s], e[s]); + (this._line || this._line !== 0 && i === 1) && this._context.closePath(), this._line = 1 - this._line, this._x = this._y = null; + }, + point: function(t, e) { + this._x.push(+t), this._y.push(+e); + } +}; +function Ho(t) { + var e, i = t.length - 1, r, n = new Array(i), o = new Array(i), s = new Array(i); + for (n[0] = 0, o[0] = 2, s[0] = t[0] + 2 * t[1], e = 1; e < i - 1; ++e) + n[e] = 1, o[e] = 4, s[e] = 4 * t[e] + 2 * t[e + 1]; + for (n[i - 1] = 2, o[i - 1] = 7, s[i - 1] = 8 * t[i - 1] + t[i], e = 1; e < i; ++e) + r = n[e] / o[e - 1], o[e] -= r, s[e] -= r * s[e - 1]; + for (n[i - 1] = s[i - 1] / o[i - 1], e = i - 2; e >= 0; --e) + n[e] = (s[e] - n[e + 1]) / o[e]; + for (o[i - 1] = (t[i] + n[i - 1]) / 2, e = 0; e < i - 1; ++e) + o[e] = 2 * t[e + 1] - n[e + 1]; + return [n, o]; +} +function Jf(t) { + return new Ta(t); +} +function mr(t, e) { + this._context = t, this._t = e; +} +mr.prototype = { + areaStart: function() { + this._line = 0; + }, + areaEnd: function() { + this._line = NaN; + }, + lineStart: function() { + this._x = this._y = NaN, this._point = 0; + }, + lineEnd: function() { + 0 < this._t && this._t < 1 && this._point === 2 && this._context.lineTo(this._x, this._y), (this._line || this._line !== 0 && this._point === 1) && this._context.closePath(), this._line >= 0 && (this._t = 1 - this._t, this._line = 1 - this._line); + }, + point: function(t, e) { + switch (t = +t, e = +e, this._point) { + case 0: + this._point = 1, this._line ? this._context.lineTo(t, e) : this._context.moveTo(t, e); + break; + case 1: + this._point = 2; + default: { + if (this._t <= 0) + this._context.lineTo(this._x, e), this._context.lineTo(t, e); + else { + var i = this._x * (1 - this._t) + t * this._t; + this._context.lineTo(i, this._y), this._context.lineTo(i, e); + } + break; + } + } + this._x = t, this._y = e; + } +}; +function Qf(t) { + return new mr(t, 0.5); +} +function td(t) { + return new mr(t, 0); +} +function ed(t) { + return new mr(t, 1); +} +function Ke(t, e, i) { + this.k = t, this.x = e, this.y = i; +} +Ke.prototype = { + constructor: Ke, + scale: function(t) { + return t === 1 ? this : new Ke(this.k * t, this.x, this.y); + }, + translate: function(t, e) { + return t === 0 & e === 0 ? this : new Ke(this.k, this.x + this.k * t, this.y + this.k * e); + }, + apply: function(t) { + return [t[0] * this.k + this.x, t[1] * this.k + this.y]; + }, + applyX: function(t) { + return t * this.k + this.x; + }, + applyY: function(t) { + return t * this.k + this.y; + }, + invert: function(t) { + return [(t[0] - this.x) / this.k, (t[1] - this.y) / this.k]; + }, + invertX: function(t) { + return (t - this.x) / this.k; + }, + invertY: function(t) { + return (t - this.y) / this.k; + }, + rescaleX: function(t) { + return t.copy().domain(t.range().map(this.invertX, this).map(t.invert, t)); + }, + rescaleY: function(t) { + return t.copy().domain(t.range().map(this.invertY, this).map(t.invert, t)); + }, + toString: function() { + return "translate(" + this.x + "," + this.y + ") scale(" + this.k + ")"; + } +}; +Ke.prototype; +/*! @license DOMPurify 3.0.9 | (c) Cure53 and other contributors | Released under the Apache license 2.0 and Mozilla Public License 2.0 | github.com/cure53/DOMPurify/blob/3.0.9/LICENSE */ +const { + entries: ka, + setPrototypeOf: jo, + isFrozen: id, + getPrototypeOf: rd, + getOwnPropertyDescriptor: nd +} = Object; +let { + freeze: ct, + seal: Ft, + create: Sa +} = Object, { + apply: sn, + construct: an +} = typeof Reflect < "u" && Reflect; +ct || (ct = function(e) { + return e; +}); +Ft || (Ft = function(e) { + return e; +}); +sn || (sn = function(e, i, r) { + return e.apply(i, r); +}); +an || (an = function(e, i) { + return new e(...i); +}); +const wi = _t(Array.prototype.forEach), Uo = _t(Array.prototype.pop), je = _t(Array.prototype.push), Di = _t(String.prototype.toLowerCase), Pr = _t(String.prototype.toString), od = _t(String.prototype.match), Ue = _t(String.prototype.replace), sd = _t(String.prototype.indexOf), ad = _t(String.prototype.trim), vt = _t(Object.prototype.hasOwnProperty), mt = _t(RegExp.prototype.test), Ye = ld(TypeError); +function _t(t) { + return function(e) { + for (var i = arguments.length, r = new Array(i > 1 ? i - 1 : 0), n = 1; n < i; n++) + r[n - 1] = arguments[n]; + return sn(t, e, r); + }; +} +function ld(t) { + return function() { + for (var e = arguments.length, i = new Array(e), r = 0; r < e; r++) + i[r] = arguments[r]; + return an(t, i); + }; +} +function q(t, e) { + let i = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : Di; + jo && jo(t, null); + let r = e.length; + for (; r--; ) { + let n = e[r]; + if (typeof n == "string") { + const o = i(n); + o !== n && (id(e) || (e[r] = o), n = o); + } + t[n] = !0; + } + return t; +} +function hd(t) { + for (let e = 0; e < t.length; e++) + vt(t, e) || (t[e] = null); + return t; +} +function le(t) { + const e = Sa(null); + for (const [i, r] of ka(t)) + vt(t, i) && (Array.isArray(r) ? e[i] = hd(r) : r && typeof r == "object" && r.constructor === Object ? e[i] = le(r) : e[i] = r); + return e; +} +function Bi(t, e) { + for (; t !== null; ) { + const r = nd(t, e); + if (r) { + if (r.get) + return _t(r.get); + if (typeof r.value == "function") + return _t(r.value); + } + t = rd(t); + } + function i() { + return null; + } + return i; +} +const Yo = ct(["a", "abbr", "acronym", "address", "area", "article", "aside", "audio", "b", "bdi", "bdo", "big", "blink", "blockquote", "body", "br", "button", "canvas", "caption", "center", "cite", "code", "col", "colgroup", "content", "data", "datalist", "dd", "decorator", "del", "details", "dfn", "dialog", "dir", "div", "dl", "dt", "element", "em", "fieldset", "figcaption", "figure", "font", "footer", "form", "h1", "h2", "h3", "h4", "h5", "h6", "head", "header", "hgroup", "hr", "html", "i", "img", "input", "ins", "kbd", "label", "legend", "li", "main", "map", "mark", "marquee", "menu", "menuitem", "meter", "nav", "nobr", "ol", "optgroup", "option", "output", "p", "picture", "pre", "progress", "q", "rp", "rt", "ruby", "s", "samp", "section", "select", "shadow", "small", "source", "spacer", "span", "strike", "strong", "style", "sub", "summary", "sup", "table", "tbody", "td", "template", "textarea", "tfoot", "th", "thead", "time", "tr", "track", "tt", "u", "ul", "var", "video", "wbr"]), qr = ct(["svg", "a", "altglyph", "altglyphdef", "altglyphitem", "animatecolor", "animatemotion", "animatetransform", "circle", "clippath", "defs", "desc", "ellipse", "filter", "font", "g", "glyph", "glyphref", "hkern", "image", "line", "lineargradient", "marker", "mask", "metadata", "mpath", "path", "pattern", "polygon", "polyline", "radialgradient", "rect", "stop", "style", "switch", "symbol", "text", "textpath", "title", "tref", "tspan", "view", "vkern"]), zr = ct(["feBlend", "feColorMatrix", "feComponentTransfer", "feComposite", "feConvolveMatrix", "feDiffuseLighting", "feDisplacementMap", "feDistantLight", "feDropShadow", "feFlood", "feFuncA", "feFuncB", "feFuncG", "feFuncR", "feGaussianBlur", "feImage", "feMerge", "feMergeNode", "feMorphology", "feOffset", "fePointLight", "feSpecularLighting", "feSpotLight", "feTile", "feTurbulence"]), cd = ct(["animate", "color-profile", "cursor", "discard", "font-face", "font-face-format", "font-face-name", "font-face-src", "font-face-uri", "foreignobject", "hatch", "hatchpath", "mesh", "meshgradient", "meshpatch", "meshrow", "missing-glyph", "script", "set", "solidcolor", "unknown", "use"]), Wr = ct(["math", "menclose", "merror", "mfenced", "mfrac", "mglyph", "mi", "mlabeledtr", "mmultiscripts", "mn", "mo", "mover", "mpadded", "mphantom", "mroot", "mrow", "ms", "mspace", "msqrt", "mstyle", "msub", "msup", "msubsup", "mtable", "mtd", "mtext", "mtr", "munder", "munderover", "mprescripts"]), ud = ct(["maction", "maligngroup", "malignmark", "mlongdiv", "mscarries", "mscarry", "msgroup", "mstack", "msline", "msrow", "semantics", "annotation", "annotation-xml", "mprescripts", "none"]), Go = ct(["#text"]), Vo = ct(["accept", "action", "align", "alt", "autocapitalize", "autocomplete", "autopictureinpicture", "autoplay", "background", "bgcolor", "border", "capture", "cellpadding", "cellspacing", "checked", "cite", "class", "clear", "color", "cols", "colspan", "controls", "controlslist", "coords", "crossorigin", "datetime", "decoding", "default", "dir", "disabled", "disablepictureinpicture", "disableremoteplayback", "download", "draggable", "enctype", "enterkeyhint", "face", "for", "headers", "height", "hidden", "high", "href", "hreflang", "id", "inputmode", "integrity", "ismap", "kind", "label", "lang", "list", "loading", "loop", "low", "max", "maxlength", "media", "method", "min", "minlength", "multiple", "muted", "name", "nonce", "noshade", "novalidate", "nowrap", "open", "optimum", "pattern", "placeholder", "playsinline", "poster", "preload", "pubdate", "radiogroup", "readonly", "rel", "required", "rev", "reversed", "role", "rows", "rowspan", "spellcheck", "scope", "selected", "shape", "size", "sizes", "span", "srclang", "start", "src", "srcset", "step", "style", "summary", "tabindex", "title", "translate", "type", "usemap", "valign", "value", "width", "xmlns", "slot"]), Hr = ct(["accent-height", "accumulate", "additive", "alignment-baseline", "ascent", "attributename", "attributetype", "azimuth", "basefrequency", "baseline-shift", "begin", "bias", "by", "class", "clip", "clippathunits", "clip-path", "clip-rule", "color", "color-interpolation", "color-interpolation-filters", "color-profile", "color-rendering", "cx", "cy", "d", "dx", "dy", "diffuseconstant", "direction", "display", "divisor", "dur", "edgemode", "elevation", "end", "fill", "fill-opacity", "fill-rule", "filter", "filterunits", "flood-color", "flood-opacity", "font-family", "font-size", "font-size-adjust", "font-stretch", "font-style", "font-variant", "font-weight", "fx", "fy", "g1", "g2", "glyph-name", "glyphref", "gradientunits", "gradienttransform", "height", "href", "id", "image-rendering", "in", "in2", "k", "k1", "k2", "k3", "k4", "kerning", "keypoints", "keysplines", "keytimes", "lang", "lengthadjust", "letter-spacing", "kernelmatrix", "kernelunitlength", "lighting-color", "local", "marker-end", "marker-mid", "marker-start", "markerheight", "markerunits", "markerwidth", "maskcontentunits", "maskunits", "max", "mask", "media", "method", "mode", "min", "name", "numoctaves", "offset", "operator", "opacity", "order", "orient", "orientation", "origin", "overflow", "paint-order", "path", "pathlength", "patterncontentunits", "patterntransform", "patternunits", "points", "preservealpha", "preserveaspectratio", "primitiveunits", "r", "rx", "ry", "radius", "refx", "refy", "repeatcount", "repeatdur", "restart", "result", "rotate", "scale", "seed", "shape-rendering", "specularconstant", "specularexponent", "spreadmethod", "startoffset", "stddeviation", "stitchtiles", "stop-color", "stop-opacity", "stroke-dasharray", "stroke-dashoffset", "stroke-linecap", "stroke-linejoin", "stroke-miterlimit", "stroke-opacity", "stroke", "stroke-width", "style", "surfacescale", "systemlanguage", "tabindex", "targetx", "targety", "transform", "transform-origin", "text-anchor", "text-decoration", "text-rendering", "textlength", "type", "u1", "u2", "unicode", "values", "viewbox", "visibility", "version", "vert-adv-y", "vert-origin-x", "vert-origin-y", "width", "word-spacing", "wrap", "writing-mode", "xchannelselector", "ychannelselector", "x", "x1", "x2", "xmlns", "y", "y1", "y2", "z", "zoomandpan"]), Xo = ct(["accent", "accentunder", "align", "bevelled", "close", "columnsalign", "columnlines", "columnspan", "denomalign", "depth", "dir", "display", "displaystyle", "encoding", "fence", "frame", "height", "href", "id", "largeop", "length", "linethickness", "lspace", "lquote", "mathbackground", "mathcolor", "mathsize", "mathvariant", "maxsize", "minsize", "movablelimits", "notation", "numalign", "open", "rowalign", "rowlines", "rowspacing", "rowspan", "rspace", "rquote", "scriptlevel", "scriptminsize", "scriptsizemultiplier", "selection", "separator", "separators", "stretchy", "subscriptshift", "supscriptshift", "symmetric", "voffset", "width", "xmlns"]), Fi = ct(["xlink:href", "xml:id", "xlink:title", "xml:space", "xmlns:xlink"]), fd = Ft(/\{\{[\w\W]*|[\w\W]*\}\}/gm), dd = Ft(/<%[\w\W]*|[\w\W]*%>/gm), pd = Ft(/\${[\w\W]*}/gm), gd = Ft(/^data-[\-\w.\u00B7-\uFFFF]/), md = Ft(/^aria-[\-\w]+$/), va = Ft( + /^(?:(?:(?:f|ht)tps?|mailto|tel|callto|sms|cid|xmpp):|[^a-z]|[a-z+.\-]+(?:[^a-z+.\-:]|$))/i + // eslint-disable-line no-useless-escape +), yd = Ft(/^(?:\w+script|data):/i), _d = Ft( + /[\u0000-\u0020\u00A0\u1680\u180E\u2000-\u2029\u205F\u3000]/g + // eslint-disable-line no-control-regex +), wa = Ft(/^html$/i); +var Ko = /* @__PURE__ */ Object.freeze({ + __proto__: null, + MUSTACHE_EXPR: fd, + ERB_EXPR: dd, + TMPLIT_EXPR: pd, + DATA_ATTR: gd, + ARIA_ATTR: md, + IS_ALLOWED_URI: va, + IS_SCRIPT_OR_DATA: yd, + ATTR_WHITESPACE: _d, + DOCTYPE_NAME: wa +}); +const Cd = function() { + return typeof window > "u" ? null : window; +}, xd = function(e, i) { + if (typeof e != "object" || typeof e.createPolicy != "function") + return null; + let r = null; + const n = "data-tt-policy-suffix"; + i && i.hasAttribute(n) && (r = i.getAttribute(n)); + const o = "dompurify" + (r ? "#" + r : ""); + try { + return e.createPolicy(o, { + createHTML(s) { + return s; + }, + createScriptURL(s) { + return s; + } + }); + } catch { + return console.warn("TrustedTypes policy " + o + " could not be created."), null; + } +}; +function Ba() { + let t = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : Cd(); + const e = (B) => Ba(B); + if (e.version = "3.0.9", e.removed = [], !t || !t.document || t.document.nodeType !== 9) + return e.isSupported = !1, e; + let { + document: i + } = t; + const r = i, n = r.currentScript, { + DocumentFragment: o, + HTMLTemplateElement: s, + Node: a, + Element: l, + NodeFilter: h, + NamedNodeMap: u = t.NamedNodeMap || t.MozNamedAttrMap, + HTMLFormElement: f, + DOMParser: c, + trustedTypes: d + } = t, m = l.prototype, S = Bi(m, "cloneNode"), O = Bi(m, "nextSibling"), z = Bi(m, "childNodes"), T = Bi(m, "parentNode"); + if (typeof s == "function") { + const B = i.createElement("template"); + B.content && B.content.ownerDocument && (i = B.content.ownerDocument); + } + let R, X = ""; + const { + implementation: G, + createNodeIterator: V, + createDocumentFragment: H, + getElementsByTagName: oe + } = i, { + importNode: Kt + } = r; + let P = {}; + e.isSupported = typeof ka == "function" && typeof T == "function" && G && G.createHTMLDocument !== void 0; + const { + MUSTACHE_EXPR: W, + ERB_EXPR: Ct, + TMPLIT_EXPR: Nt, + DATA_ATTR: M, + ARIA_ATTR: k, + IS_SCRIPT_OR_DATA: C, + ATTR_WHITESPACE: w + } = Ko; + let { + IS_ALLOWED_URI: x + } = Ko, b = null; + const D = q({}, [...Yo, ...qr, ...zr, ...Wr, ...Go]); + let I = null; + const Y = q({}, [...Vo, ...Hr, ...Xo, ...Fi]); + let N = Object.seal(Sa(null, { + tagNameCheck: { + writable: !0, + configurable: !1, + enumerable: !0, + value: null + }, + attributeNameCheck: { + writable: !0, + configurable: !1, + enumerable: !0, + value: null + }, + allowCustomizedBuiltInElements: { + writable: !0, + configurable: !1, + enumerable: !0, + value: !1 + } + })), K = null, et = null, Rt = !0, St = !0, Zt = !1, Lt = !0, Z = !1, it = !1, Pt = !1, Jt = !1, xe = !1, Ci = !1, xi = !1, eo = !0, io = !1; + const ah = "user-content-"; + let Lr = !0, qe = !1, be = {}, Te = null; + const ro = q({}, ["annotation-xml", "audio", "colgroup", "desc", "foreignobject", "head", "iframe", "math", "mi", "mn", "mo", "ms", "mtext", "noembed", "noframes", "noscript", "plaintext", "script", "style", "svg", "template", "thead", "title", "video", "xmp"]); + let no = null; + const oo = q({}, ["audio", "video", "img", "source", "image", "track"]); + let Er = null; + const so = q({}, ["alt", "class", "for", "id", "label", "name", "pattern", "placeholder", "role", "summary", "title", "value", "style", "xmlns"]), bi = "http://www.w3.org/1998/Math/MathML", Ti = "http://www.w3.org/2000/svg", qt = "http://www.w3.org/1999/xhtml"; + let ke = qt, Mr = !1, Or = null; + const lh = q({}, [bi, Ti, qt], Pr); + let ze = null; + const hh = ["application/xhtml+xml", "text/html"], ch = "text/html"; + let tt = null, Se = null; + const uh = i.createElement("form"), ao = function(p) { + return p instanceof RegExp || p instanceof Function; + }, $r = function() { + let p = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}; + if (!(Se && Se === p)) { + if ((!p || typeof p != "object") && (p = {}), p = le(p), ze = // eslint-disable-next-line unicorn/prefer-includes + hh.indexOf(p.PARSER_MEDIA_TYPE) === -1 ? ch : p.PARSER_MEDIA_TYPE, tt = ze === "application/xhtml+xml" ? Pr : Di, b = vt(p, "ALLOWED_TAGS") ? q({}, p.ALLOWED_TAGS, tt) : D, I = vt(p, "ALLOWED_ATTR") ? q({}, p.ALLOWED_ATTR, tt) : Y, Or = vt(p, "ALLOWED_NAMESPACES") ? q({}, p.ALLOWED_NAMESPACES, Pr) : lh, Er = vt(p, "ADD_URI_SAFE_ATTR") ? q( + le(so), + // eslint-disable-line indent + p.ADD_URI_SAFE_ATTR, + // eslint-disable-line indent + tt + // eslint-disable-line indent + ) : so, no = vt(p, "ADD_DATA_URI_TAGS") ? q( + le(oo), + // eslint-disable-line indent + p.ADD_DATA_URI_TAGS, + // eslint-disable-line indent + tt + // eslint-disable-line indent + ) : oo, Te = vt(p, "FORBID_CONTENTS") ? q({}, p.FORBID_CONTENTS, tt) : ro, K = vt(p, "FORBID_TAGS") ? q({}, p.FORBID_TAGS, tt) : {}, et = vt(p, "FORBID_ATTR") ? q({}, p.FORBID_ATTR, tt) : {}, be = vt(p, "USE_PROFILES") ? p.USE_PROFILES : !1, Rt = p.ALLOW_ARIA_ATTR !== !1, St = p.ALLOW_DATA_ATTR !== !1, Zt = p.ALLOW_UNKNOWN_PROTOCOLS || !1, Lt = p.ALLOW_SELF_CLOSE_IN_ATTR !== !1, Z = p.SAFE_FOR_TEMPLATES || !1, it = p.WHOLE_DOCUMENT || !1, xe = p.RETURN_DOM || !1, Ci = p.RETURN_DOM_FRAGMENT || !1, xi = p.RETURN_TRUSTED_TYPE || !1, Jt = p.FORCE_BODY || !1, eo = p.SANITIZE_DOM !== !1, io = p.SANITIZE_NAMED_PROPS || !1, Lr = p.KEEP_CONTENT !== !1, qe = p.IN_PLACE || !1, x = p.ALLOWED_URI_REGEXP || va, ke = p.NAMESPACE || qt, N = p.CUSTOM_ELEMENT_HANDLING || {}, p.CUSTOM_ELEMENT_HANDLING && ao(p.CUSTOM_ELEMENT_HANDLING.tagNameCheck) && (N.tagNameCheck = p.CUSTOM_ELEMENT_HANDLING.tagNameCheck), p.CUSTOM_ELEMENT_HANDLING && ao(p.CUSTOM_ELEMENT_HANDLING.attributeNameCheck) && (N.attributeNameCheck = p.CUSTOM_ELEMENT_HANDLING.attributeNameCheck), p.CUSTOM_ELEMENT_HANDLING && typeof p.CUSTOM_ELEMENT_HANDLING.allowCustomizedBuiltInElements == "boolean" && (N.allowCustomizedBuiltInElements = p.CUSTOM_ELEMENT_HANDLING.allowCustomizedBuiltInElements), Z && (St = !1), Ci && (xe = !0), be && (b = q({}, Go), I = [], be.html === !0 && (q(b, Yo), q(I, Vo)), be.svg === !0 && (q(b, qr), q(I, Hr), q(I, Fi)), be.svgFilters === !0 && (q(b, zr), q(I, Hr), q(I, Fi)), be.mathMl === !0 && (q(b, Wr), q(I, Xo), q(I, Fi))), p.ADD_TAGS && (b === D && (b = le(b)), q(b, p.ADD_TAGS, tt)), p.ADD_ATTR && (I === Y && (I = le(I)), q(I, p.ADD_ATTR, tt)), p.ADD_URI_SAFE_ATTR && q(Er, p.ADD_URI_SAFE_ATTR, tt), p.FORBID_CONTENTS && (Te === ro && (Te = le(Te)), q(Te, p.FORBID_CONTENTS, tt)), Lr && (b["#text"] = !0), it && q(b, ["html", "head", "body"]), b.table && (q(b, ["tbody"]), delete K.tbody), p.TRUSTED_TYPES_POLICY) { + if (typeof p.TRUSTED_TYPES_POLICY.createHTML != "function") + throw Ye('TRUSTED_TYPES_POLICY configuration option must provide a "createHTML" hook.'); + if (typeof p.TRUSTED_TYPES_POLICY.createScriptURL != "function") + throw Ye('TRUSTED_TYPES_POLICY configuration option must provide a "createScriptURL" hook.'); + R = p.TRUSTED_TYPES_POLICY, X = R.createHTML(""); + } else + R === void 0 && (R = xd(d, n)), R !== null && typeof X == "string" && (X = R.createHTML("")); + ct && ct(p), Se = p; + } + }, lo = q({}, ["mi", "mo", "mn", "ms", "mtext"]), ho = q({}, ["foreignobject", "desc", "title", "annotation-xml"]), fh = q({}, ["title", "style", "font", "a", "script"]), co = q({}, [...qr, ...zr, ...cd]), uo = q({}, [...Wr, ...ud]), dh = function(p) { + let y = T(p); + (!y || !y.tagName) && (y = { + namespaceURI: ke, + tagName: "template" + }); + const v = Di(p.tagName), j = Di(y.tagName); + return Or[p.namespaceURI] ? p.namespaceURI === Ti ? y.namespaceURI === qt ? v === "svg" : y.namespaceURI === bi ? v === "svg" && (j === "annotation-xml" || lo[j]) : !!co[v] : p.namespaceURI === bi ? y.namespaceURI === qt ? v === "math" : y.namespaceURI === Ti ? v === "math" && ho[j] : !!uo[v] : p.namespaceURI === qt ? y.namespaceURI === Ti && !ho[j] || y.namespaceURI === bi && !lo[j] ? !1 : !uo[v] && (fh[v] || !co[v]) : !!(ze === "application/xhtml+xml" && Or[p.namespaceURI]) : !1; + }, se = function(p) { + je(e.removed, { + element: p + }); + try { + p.parentNode.removeChild(p); + } catch { + p.remove(); + } + }, Ir = function(p, y) { + try { + je(e.removed, { + attribute: y.getAttributeNode(p), + from: y + }); + } catch { + je(e.removed, { + attribute: null, + from: y + }); + } + if (y.removeAttribute(p), p === "is" && !I[p]) + if (xe || Ci) + try { + se(y); + } catch { + } + else + try { + y.setAttribute(p, ""); + } catch { + } + }, fo = function(p) { + let y = null, v = null; + if (Jt) + p = "" + p; + else { + const nt = od(p, /^[\r\n\t ]+/); + v = nt && nt[0]; + } + ze === "application/xhtml+xml" && ke === qt && (p = '' + p + ""); + const j = R ? R.createHTML(p) : p; + if (ke === qt) + try { + y = new c().parseFromString(j, ze); + } catch { + } + if (!y || !y.documentElement) { + y = G.createDocument(ke, "template", null); + try { + y.documentElement.innerHTML = Mr ? X : j; + } catch { + } + } + const rt = y.body || y.documentElement; + return p && v && rt.insertBefore(i.createTextNode(v), rt.childNodes[0] || null), ke === qt ? oe.call(y, it ? "html" : "body")[0] : it ? y.documentElement : rt; + }, po = function(p) { + return V.call( + p.ownerDocument || p, + p, + // eslint-disable-next-line no-bitwise + h.SHOW_ELEMENT | h.SHOW_COMMENT | h.SHOW_TEXT, + null + ); + }, ph = function(p) { + return p instanceof f && (typeof p.nodeName != "string" || typeof p.textContent != "string" || typeof p.removeChild != "function" || !(p.attributes instanceof u) || typeof p.removeAttribute != "function" || typeof p.setAttribute != "function" || typeof p.namespaceURI != "string" || typeof p.insertBefore != "function" || typeof p.hasChildNodes != "function"); + }, go = function(p) { + return typeof a == "function" && p instanceof a; + }, zt = function(p, y, v) { + P[p] && wi(P[p], (j) => { + j.call(e, y, v, Se); + }); + }, mo = function(p) { + let y = null; + if (zt("beforeSanitizeElements", p, null), ph(p)) + return se(p), !0; + const v = tt(p.nodeName); + if (zt("uponSanitizeElement", p, { + tagName: v, + allowedTags: b + }), p.hasChildNodes() && !go(p.firstElementChild) && mt(/<[/\w]/g, p.innerHTML) && mt(/<[/\w]/g, p.textContent)) + return se(p), !0; + if (!b[v] || K[v]) { + if (!K[v] && _o(v) && (N.tagNameCheck instanceof RegExp && mt(N.tagNameCheck, v) || N.tagNameCheck instanceof Function && N.tagNameCheck(v))) + return !1; + if (Lr && !Te[v]) { + const j = T(p) || p.parentNode, rt = z(p) || p.childNodes; + if (rt && j) { + const nt = rt.length; + for (let ut = nt - 1; ut >= 0; --ut) + j.insertBefore(S(rt[ut], !0), O(p)); + } + } + return se(p), !0; + } + return p instanceof l && !dh(p) || (v === "noscript" || v === "noembed" || v === "noframes") && mt(/<\/no(script|embed|frames)/i, p.innerHTML) ? (se(p), !0) : (Z && p.nodeType === 3 && (y = p.textContent, wi([W, Ct, Nt], (j) => { + y = Ue(y, j, " "); + }), p.textContent !== y && (je(e.removed, { + element: p.cloneNode() + }), p.textContent = y)), zt("afterSanitizeElements", p, null), !1); + }, yo = function(p, y, v) { + if (eo && (y === "id" || y === "name") && (v in i || v in uh)) + return !1; + if (!(St && !et[y] && mt(M, y))) { + if (!(Rt && mt(k, y))) { + if (!I[y] || et[y]) { + if ( + // First condition does a very basic check if a) it's basically a valid custom element tagname AND + // b) if the tagName passes whatever the user has configured for CUSTOM_ELEMENT_HANDLING.tagNameCheck + // and c) if the attribute name passes whatever the user has configured for CUSTOM_ELEMENT_HANDLING.attributeNameCheck + !(_o(p) && (N.tagNameCheck instanceof RegExp && mt(N.tagNameCheck, p) || N.tagNameCheck instanceof Function && N.tagNameCheck(p)) && (N.attributeNameCheck instanceof RegExp && mt(N.attributeNameCheck, y) || N.attributeNameCheck instanceof Function && N.attributeNameCheck(y)) || // Alternative, second condition checks if it's an `is`-attribute, AND + // the value passes whatever the user has configured for CUSTOM_ELEMENT_HANDLING.tagNameCheck + y === "is" && N.allowCustomizedBuiltInElements && (N.tagNameCheck instanceof RegExp && mt(N.tagNameCheck, v) || N.tagNameCheck instanceof Function && N.tagNameCheck(v))) + ) + return !1; + } else if (!Er[y]) { + if (!mt(x, Ue(v, w, ""))) { + if (!((y === "src" || y === "xlink:href" || y === "href") && p !== "script" && sd(v, "data:") === 0 && no[p])) { + if (!(Zt && !mt(C, Ue(v, w, "")))) { + if (v) + return !1; + } + } + } + } + } + } + return !0; + }, _o = function(p) { + return p !== "annotation-xml" && p.indexOf("-") > 0; + }, Co = function(p) { + zt("beforeSanitizeAttributes", p, null); + const { + attributes: y + } = p; + if (!y) + return; + const v = { + attrName: "", + attrValue: "", + keepAttr: !0, + allowedAttributes: I + }; + let j = y.length; + for (; j--; ) { + const rt = y[j], { + name: nt, + namespaceURI: ut, + value: ae + } = rt, We = tt(nt); + let ft = nt === "value" ? ae : ad(ae); + if (v.attrName = We, v.attrValue = ft, v.keepAttr = !0, v.forceKeepAttr = void 0, zt("uponSanitizeAttribute", p, v), ft = v.attrValue, v.forceKeepAttr || (Ir(nt, p), !v.keepAttr)) + continue; + if (!Lt && mt(/\/>/i, ft)) { + Ir(nt, p); + continue; + } + Z && wi([W, Ct, Nt], (bo) => { + ft = Ue(ft, bo, " "); + }); + const xo = tt(p.nodeName); + if (yo(xo, We, ft)) { + if (io && (We === "id" || We === "name") && (Ir(nt, p), ft = ah + ft), R && typeof d == "object" && typeof d.getAttributeType == "function" && !ut) + switch (d.getAttributeType(xo, We)) { + case "TrustedHTML": { + ft = R.createHTML(ft); + break; + } + case "TrustedScriptURL": { + ft = R.createScriptURL(ft); + break; + } + } + try { + ut ? p.setAttributeNS(ut, nt, ft) : p.setAttribute(nt, ft), Uo(e.removed); + } catch { + } + } + } + zt("afterSanitizeAttributes", p, null); + }, gh = function B(p) { + let y = null; + const v = po(p); + for (zt("beforeSanitizeShadowDOM", p, null); y = v.nextNode(); ) + zt("uponSanitizeShadowNode", y, null), !mo(y) && (y.content instanceof o && B(y.content), Co(y)); + zt("afterSanitizeShadowDOM", p, null); + }; + return e.sanitize = function(B) { + let p = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}, y = null, v = null, j = null, rt = null; + if (Mr = !B, Mr && (B = ""), typeof B != "string" && !go(B)) + if (typeof B.toString == "function") { + if (B = B.toString(), typeof B != "string") + throw Ye("dirty is not a string, aborting"); + } else + throw Ye("toString is not a function"); + if (!e.isSupported) + return B; + if (Pt || $r(p), e.removed = [], typeof B == "string" && (qe = !1), qe) { + if (B.nodeName) { + const ae = tt(B.nodeName); + if (!b[ae] || K[ae]) + throw Ye("root node is forbidden and cannot be sanitized in-place"); + } + } else if (B instanceof a) + y = fo(""), v = y.ownerDocument.importNode(B, !0), v.nodeType === 1 && v.nodeName === "BODY" || v.nodeName === "HTML" ? y = v : y.appendChild(v); + else { + if (!xe && !Z && !it && // eslint-disable-next-line unicorn/prefer-includes + B.indexOf("<") === -1) + return R && xi ? R.createHTML(B) : B; + if (y = fo(B), !y) + return xe ? null : xi ? X : ""; + } + y && Jt && se(y.firstChild); + const nt = po(qe ? B : y); + for (; j = nt.nextNode(); ) + mo(j) || (j.content instanceof o && gh(j.content), Co(j)); + if (qe) + return B; + if (xe) { + if (Ci) + for (rt = H.call(y.ownerDocument); y.firstChild; ) + rt.appendChild(y.firstChild); + else + rt = y; + return (I.shadowroot || I.shadowrootmode) && (rt = Kt.call(r, rt, !0)), rt; + } + let ut = it ? y.outerHTML : y.innerHTML; + return it && b["!doctype"] && y.ownerDocument && y.ownerDocument.doctype && y.ownerDocument.doctype.name && mt(wa, y.ownerDocument.doctype.name) && (ut = " +` + ut), Z && wi([W, Ct, Nt], (ae) => { + ut = Ue(ut, ae, " "); + }), R && xi ? R.createHTML(ut) : ut; + }, e.setConfig = function() { + let B = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}; + $r(B), Pt = !0; + }, e.clearConfig = function() { + Se = null, Pt = !1; + }, e.isValidAttribute = function(B, p, y) { + Se || $r({}); + const v = tt(B), j = tt(p); + return yo(v, j, y); + }, e.addHook = function(B, p) { + typeof p == "function" && (P[B] = P[B] || [], je(P[B], p)); + }, e.removeHook = function(B) { + if (P[B]) + return Uo(P[B]); + }, e.removeHooks = function(B) { + P[B] && (P[B] = []); + }, e.removeAllHooks = function() { + P = {}; + }, e; +} +var Ee = Ba(); +const gi = //gi, bd = (t) => t ? Aa(t).replace(/\\n/g, "#br#").split("#br#") : [""], Td = (() => { + let t = !1; + return () => { + t || (kd(), t = !0); + }; +})(); +function kd() { + const t = "data-temp-href-target"; + Ee.addHook("beforeSanitizeAttributes", (e) => { + e.tagName === "A" && e.hasAttribute("target") && e.setAttribute(t, e.getAttribute("target") || ""); + }), Ee.addHook("afterSanitizeAttributes", (e) => { + e.tagName === "A" && e.hasAttribute(t) && (e.setAttribute("target", e.getAttribute(t) || ""), e.removeAttribute(t), e.getAttribute("target") === "_blank" && e.setAttribute("rel", "noopener")); + }); +} +const Fa = (t) => (Td(), Ee.sanitize(t)), Zo = (t, e) => { + var i; + if (((i = e.flowchart) == null ? void 0 : i.htmlLabels) !== !1) { + const r = e.securityLevel; + r === "antiscript" || r === "strict" ? t = Fa(t) : r !== "loose" && (t = Aa(t), t = t.replace(//g, ">"), t = t.replace(/=/g, "="), t = Bd(t)); + } + return t; +}, ai = (t, e) => t && (e.dompurifyConfig ? t = Ee.sanitize(Zo(t, e), e.dompurifyConfig).toString() : t = Ee.sanitize(Zo(t, e), { + FORBID_TAGS: ["style"] +}).toString(), t), Sd = (t, e) => typeof t == "string" ? ai(t, e) : t.flat().map((i) => ai(i, e)), vd = (t) => gi.test(t), wd = (t) => t.split(gi), Bd = (t) => t.replace(/#br#/g, "
    "), Aa = (t) => t.replace(gi, "#br#"), Fd = (t) => { + let e = ""; + return t && (e = window.location.protocol + "//" + window.location.host + window.location.pathname + window.location.search, e = e.replaceAll(/\(/g, "\\("), e = e.replaceAll(/\)/g, "\\)")), e; +}, La = (t) => !(t === !1 || ["false", "null", "0"].includes(String(t).trim().toLowerCase())), Ad = function(...t) { + const e = t.filter((i) => !isNaN(i)); + return Math.max(...e); +}, Ld = function(...t) { + const e = t.filter((i) => !isNaN(i)); + return Math.min(...e); +}, C1 = function(t) { + const e = t.split(/(,)/), i = []; + for (let r = 0; r < e.length; r++) { + let n = e[r]; + if (n === "," && r > 0 && r + 1 < e.length) { + const o = e[r - 1], s = e[r + 1]; + Ed(o, s) && (n = o + "," + s, r++, i.pop()); + } + i.push(Md(n)); + } + return i.join(""); +}, ln = (t, e) => Math.max(0, t.split(e).length - 1), Ed = (t, e) => { + const i = ln(t, "~"), r = ln(e, "~"); + return i === 1 && r === 1; +}, Md = (t) => { + const e = ln(t, "~"); + let i = !1; + if (e <= 1) + return t; + e % 2 !== 0 && t.startsWith("~") && (t = t.substring(1), i = !0); + const r = [...t]; + let n = r.indexOf("~"), o = r.lastIndexOf("~"); + for (; n !== -1 && o !== -1 && n !== o; ) + r[n] = "<", r[o] = ">", n = r.indexOf("~"), o = r.lastIndexOf("~"); + return i && r.unshift("~"), r.join(""); +}, Jo = () => window.MathMLElement !== void 0, hn = /\$\$(.*)\$\$/g, Qo = (t) => { + var e; + return (((e = t.match(hn)) == null ? void 0 : e.length) ?? 0) > 0; +}, x1 = async (t, e) => { + t = await Od(t, e); + const i = document.createElement("div"); + i.innerHTML = t, i.id = "katex-temp", i.style.visibility = "hidden", i.style.position = "absolute", i.style.top = "0"; + const r = document.querySelector("body"); + r == null || r.insertAdjacentElement("beforeend", i); + const n = { width: i.clientWidth, height: i.clientHeight }; + return i.remove(), n; +}, Od = async (t, e) => { + if (!Qo(t)) + return t; + if (!Jo() && !e.legacyMathML) + return t.replace(hn, "MathML is unsupported in this environment."); + const { default: i } = await import("./katex-d90b6d29.js"); + return t.split(gi).map( + (r) => Qo(r) ? ` +
    + ${r} +
    + ` : `
    ${r}
    ` + ).join("").replace( + hn, + (r, n) => i.renderToString(n, { + throwOnError: !0, + displayMode: !0, + output: Jo() ? "mathml" : "htmlAndMathml" + }).replace(/\n/g, " ").replace(//g, "") + ); +}, $n = { + getRows: bd, + sanitizeText: ai, + sanitizeTextOrArray: Sd, + hasBreaks: vd, + splitBreaks: wd, + lineBreakRegex: gi, + removeScript: Fa, + getUrl: Fd, + evaluate: La, + getMax: Ad, + getMin: Ld +}, Ni = { + /* CLAMP */ + min: { + r: 0, + g: 0, + b: 0, + s: 0, + l: 0, + a: 0 + }, + max: { + r: 255, + g: 255, + b: 255, + h: 360, + s: 100, + l: 100, + a: 1 + }, + clamp: { + r: (t) => t >= 255 ? 255 : t < 0 ? 0 : t, + g: (t) => t >= 255 ? 255 : t < 0 ? 0 : t, + b: (t) => t >= 255 ? 255 : t < 0 ? 0 : t, + h: (t) => t % 360, + s: (t) => t >= 100 ? 100 : t < 0 ? 0 : t, + l: (t) => t >= 100 ? 100 : t < 0 ? 0 : t, + a: (t) => t >= 1 ? 1 : t < 0 ? 0 : t + }, + /* CONVERSION */ + //SOURCE: https://planetcalc.com/7779 + toLinear: (t) => { + const e = t / 255; + return t > 0.03928 ? Math.pow((e + 0.055) / 1.055, 2.4) : e / 12.92; + }, + //SOURCE: https://gist.github.com/mjackson/5311256 + hue2rgb: (t, e, i) => (i < 0 && (i += 1), i > 1 && (i -= 1), i < 1 / 6 ? t + (e - t) * 6 * i : i < 1 / 2 ? e : i < 2 / 3 ? t + (e - t) * (2 / 3 - i) * 6 : t), + hsl2rgb: ({ h: t, s: e, l: i }, r) => { + if (!e) + return i * 2.55; + t /= 360, e /= 100, i /= 100; + const n = i < 0.5 ? i * (1 + e) : i + e - i * e, o = 2 * i - n; + switch (r) { + case "r": + return Ni.hue2rgb(o, n, t + 1 / 3) * 255; + case "g": + return Ni.hue2rgb(o, n, t) * 255; + case "b": + return Ni.hue2rgb(o, n, t - 1 / 3) * 255; + } + }, + rgb2hsl: ({ r: t, g: e, b: i }, r) => { + t /= 255, e /= 255, i /= 255; + const n = Math.max(t, e, i), o = Math.min(t, e, i), s = (n + o) / 2; + if (r === "l") + return s * 100; + if (n === o) + return 0; + const a = n - o, l = s > 0.5 ? a / (2 - n - o) : a / (n + o); + if (r === "s") + return l * 100; + switch (n) { + case t: + return ((e - i) / a + (e < i ? 6 : 0)) * 60; + case e: + return ((i - t) / a + 2) * 60; + case i: + return ((t - e) / a + 4) * 60; + default: + return -1; + } + } +}, $d = Ni, Id = { + /* API */ + clamp: (t, e, i) => e > i ? Math.min(e, Math.max(i, t)) : Math.min(i, Math.max(e, t)), + round: (t) => Math.round(t * 1e10) / 1e10 +}, Dd = Id, Nd = { + /* API */ + dec2hex: (t) => { + const e = Math.round(t).toString(16); + return e.length > 1 ? e : `0${e}`; + } +}, Rd = Nd, Pd = { + channel: $d, + lang: Dd, + unit: Rd +}, $ = Pd, Qt = {}; +for (let t = 0; t <= 255; t++) + Qt[t] = $.unit.dec2hex(t); +const ot = { + ALL: 0, + RGB: 1, + HSL: 2 +}; +class qd { + constructor() { + this.type = ot.ALL; + } + /* API */ + get() { + return this.type; + } + set(e) { + if (this.type && this.type !== e) + throw new Error("Cannot change both RGB and HSL channels at the same time"); + this.type = e; + } + reset() { + this.type = ot.ALL; + } + is(e) { + return this.type === e; + } +} +const zd = qd; +class Wd { + /* CONSTRUCTOR */ + constructor(e, i) { + this.color = i, this.changed = !1, this.data = e, this.type = new zd(); + } + /* API */ + set(e, i) { + return this.color = i, this.changed = !1, this.data = e, this.type.type = ot.ALL, this; + } + /* HELPERS */ + _ensureHSL() { + const e = this.data, { h: i, s: r, l: n } = e; + i === void 0 && (e.h = $.channel.rgb2hsl(e, "h")), r === void 0 && (e.s = $.channel.rgb2hsl(e, "s")), n === void 0 && (e.l = $.channel.rgb2hsl(e, "l")); + } + _ensureRGB() { + const e = this.data, { r: i, g: r, b: n } = e; + i === void 0 && (e.r = $.channel.hsl2rgb(e, "r")), r === void 0 && (e.g = $.channel.hsl2rgb(e, "g")), n === void 0 && (e.b = $.channel.hsl2rgb(e, "b")); + } + /* GETTERS */ + get r() { + const e = this.data, i = e.r; + return !this.type.is(ot.HSL) && i !== void 0 ? i : (this._ensureHSL(), $.channel.hsl2rgb(e, "r")); + } + get g() { + const e = this.data, i = e.g; + return !this.type.is(ot.HSL) && i !== void 0 ? i : (this._ensureHSL(), $.channel.hsl2rgb(e, "g")); + } + get b() { + const e = this.data, i = e.b; + return !this.type.is(ot.HSL) && i !== void 0 ? i : (this._ensureHSL(), $.channel.hsl2rgb(e, "b")); + } + get h() { + const e = this.data, i = e.h; + return !this.type.is(ot.RGB) && i !== void 0 ? i : (this._ensureRGB(), $.channel.rgb2hsl(e, "h")); + } + get s() { + const e = this.data, i = e.s; + return !this.type.is(ot.RGB) && i !== void 0 ? i : (this._ensureRGB(), $.channel.rgb2hsl(e, "s")); + } + get l() { + const e = this.data, i = e.l; + return !this.type.is(ot.RGB) && i !== void 0 ? i : (this._ensureRGB(), $.channel.rgb2hsl(e, "l")); + } + get a() { + return this.data.a; + } + /* SETTERS */ + set r(e) { + this.type.set(ot.RGB), this.changed = !0, this.data.r = e; + } + set g(e) { + this.type.set(ot.RGB), this.changed = !0, this.data.g = e; + } + set b(e) { + this.type.set(ot.RGB), this.changed = !0, this.data.b = e; + } + set h(e) { + this.type.set(ot.HSL), this.changed = !0, this.data.h = e; + } + set s(e) { + this.type.set(ot.HSL), this.changed = !0, this.data.s = e; + } + set l(e) { + this.type.set(ot.HSL), this.changed = !0, this.data.l = e; + } + set a(e) { + this.changed = !0, this.data.a = e; + } +} +const Hd = Wd, jd = new Hd({ r: 0, g: 0, b: 0, a: 0 }, "transparent"), yr = jd, Ea = { + /* VARIABLES */ + re: /^#((?:[a-f0-9]{2}){2,4}|[a-f0-9]{3})$/i, + /* API */ + parse: (t) => { + if (t.charCodeAt(0) !== 35) + return; + const e = t.match(Ea.re); + if (!e) + return; + const i = e[1], r = parseInt(i, 16), n = i.length, o = n % 4 === 0, s = n > 4, a = s ? 1 : 17, l = s ? 8 : 4, h = o ? 0 : -1, u = s ? 255 : 15; + return yr.set({ + r: (r >> l * (h + 3) & u) * a, + g: (r >> l * (h + 2) & u) * a, + b: (r >> l * (h + 1) & u) * a, + a: o ? (r & u) * a / 255 : 1 + }, t); + }, + stringify: (t) => { + const { r: e, g: i, b: r, a: n } = t; + return n < 1 ? `#${Qt[Math.round(e)]}${Qt[Math.round(i)]}${Qt[Math.round(r)]}${Qt[Math.round(n * 255)]}` : `#${Qt[Math.round(e)]}${Qt[Math.round(i)]}${Qt[Math.round(r)]}`; + } +}, Ze = Ea, Ri = { + /* VARIABLES */ + re: /^hsla?\(\s*?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e-?\d+)?(?:deg|grad|rad|turn)?)\s*?(?:,|\s)\s*?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e-?\d+)?%)\s*?(?:,|\s)\s*?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e-?\d+)?%)(?:\s*?(?:,|\/)\s*?\+?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e-?\d+)?(%)?))?\s*?\)$/i, + hueRe: /^(.+?)(deg|grad|rad|turn)$/i, + /* HELPERS */ + _hue2deg: (t) => { + const e = t.match(Ri.hueRe); + if (e) { + const [, i, r] = e; + switch (r) { + case "grad": + return $.channel.clamp.h(parseFloat(i) * 0.9); + case "rad": + return $.channel.clamp.h(parseFloat(i) * 180 / Math.PI); + case "turn": + return $.channel.clamp.h(parseFloat(i) * 360); + } + } + return $.channel.clamp.h(parseFloat(t)); + }, + /* API */ + parse: (t) => { + const e = t.charCodeAt(0); + if (e !== 104 && e !== 72) + return; + const i = t.match(Ri.re); + if (!i) + return; + const [, r, n, o, s, a] = i; + return yr.set({ + h: Ri._hue2deg(r), + s: $.channel.clamp.s(parseFloat(n)), + l: $.channel.clamp.l(parseFloat(o)), + a: s ? $.channel.clamp.a(a ? parseFloat(s) / 100 : parseFloat(s)) : 1 + }, t); + }, + stringify: (t) => { + const { h: e, s: i, l: r, a: n } = t; + return n < 1 ? `hsla(${$.lang.round(e)}, ${$.lang.round(i)}%, ${$.lang.round(r)}%, ${n})` : `hsl(${$.lang.round(e)}, ${$.lang.round(i)}%, ${$.lang.round(r)}%)`; + } +}, Ai = Ri, Pi = { + /* VARIABLES */ + colors: { + aliceblue: "#f0f8ff", + antiquewhite: "#faebd7", + aqua: "#00ffff", + aquamarine: "#7fffd4", + azure: "#f0ffff", + beige: "#f5f5dc", + bisque: "#ffe4c4", + black: "#000000", + blanchedalmond: "#ffebcd", + blue: "#0000ff", + blueviolet: "#8a2be2", + brown: "#a52a2a", + burlywood: "#deb887", + cadetblue: "#5f9ea0", + chartreuse: "#7fff00", + chocolate: "#d2691e", + coral: "#ff7f50", + cornflowerblue: "#6495ed", + cornsilk: "#fff8dc", + crimson: "#dc143c", + cyanaqua: "#00ffff", + darkblue: "#00008b", + darkcyan: "#008b8b", + darkgoldenrod: "#b8860b", + darkgray: "#a9a9a9", + darkgreen: "#006400", + darkgrey: "#a9a9a9", + darkkhaki: "#bdb76b", + darkmagenta: "#8b008b", + darkolivegreen: "#556b2f", + darkorange: "#ff8c00", + darkorchid: "#9932cc", + darkred: "#8b0000", + darksalmon: "#e9967a", + darkseagreen: "#8fbc8f", + darkslateblue: "#483d8b", + darkslategray: "#2f4f4f", + darkslategrey: "#2f4f4f", + darkturquoise: "#00ced1", + darkviolet: "#9400d3", + deeppink: "#ff1493", + deepskyblue: "#00bfff", + dimgray: "#696969", + dimgrey: "#696969", + dodgerblue: "#1e90ff", + firebrick: "#b22222", + floralwhite: "#fffaf0", + forestgreen: "#228b22", + fuchsia: "#ff00ff", + gainsboro: "#dcdcdc", + ghostwhite: "#f8f8ff", + gold: "#ffd700", + goldenrod: "#daa520", + gray: "#808080", + green: "#008000", + greenyellow: "#adff2f", + grey: "#808080", + honeydew: "#f0fff0", + hotpink: "#ff69b4", + indianred: "#cd5c5c", + indigo: "#4b0082", + ivory: "#fffff0", + khaki: "#f0e68c", + lavender: "#e6e6fa", + lavenderblush: "#fff0f5", + lawngreen: "#7cfc00", + lemonchiffon: "#fffacd", + lightblue: "#add8e6", + lightcoral: "#f08080", + lightcyan: "#e0ffff", + lightgoldenrodyellow: "#fafad2", + lightgray: "#d3d3d3", + lightgreen: "#90ee90", + lightgrey: "#d3d3d3", + lightpink: "#ffb6c1", + lightsalmon: "#ffa07a", + lightseagreen: "#20b2aa", + lightskyblue: "#87cefa", + lightslategray: "#778899", + lightslategrey: "#778899", + lightsteelblue: "#b0c4de", + lightyellow: "#ffffe0", + lime: "#00ff00", + limegreen: "#32cd32", + linen: "#faf0e6", + magenta: "#ff00ff", + maroon: "#800000", + mediumaquamarine: "#66cdaa", + mediumblue: "#0000cd", + mediumorchid: "#ba55d3", + mediumpurple: "#9370db", + mediumseagreen: "#3cb371", + mediumslateblue: "#7b68ee", + mediumspringgreen: "#00fa9a", + mediumturquoise: "#48d1cc", + mediumvioletred: "#c71585", + midnightblue: "#191970", + mintcream: "#f5fffa", + mistyrose: "#ffe4e1", + moccasin: "#ffe4b5", + navajowhite: "#ffdead", + navy: "#000080", + oldlace: "#fdf5e6", + olive: "#808000", + olivedrab: "#6b8e23", + orange: "#ffa500", + orangered: "#ff4500", + orchid: "#da70d6", + palegoldenrod: "#eee8aa", + palegreen: "#98fb98", + paleturquoise: "#afeeee", + palevioletred: "#db7093", + papayawhip: "#ffefd5", + peachpuff: "#ffdab9", + peru: "#cd853f", + pink: "#ffc0cb", + plum: "#dda0dd", + powderblue: "#b0e0e6", + purple: "#800080", + rebeccapurple: "#663399", + red: "#ff0000", + rosybrown: "#bc8f8f", + royalblue: "#4169e1", + saddlebrown: "#8b4513", + salmon: "#fa8072", + sandybrown: "#f4a460", + seagreen: "#2e8b57", + seashell: "#fff5ee", + sienna: "#a0522d", + silver: "#c0c0c0", + skyblue: "#87ceeb", + slateblue: "#6a5acd", + slategray: "#708090", + slategrey: "#708090", + snow: "#fffafa", + springgreen: "#00ff7f", + tan: "#d2b48c", + teal: "#008080", + thistle: "#d8bfd8", + transparent: "#00000000", + turquoise: "#40e0d0", + violet: "#ee82ee", + wheat: "#f5deb3", + white: "#ffffff", + whitesmoke: "#f5f5f5", + yellow: "#ffff00", + yellowgreen: "#9acd32" + }, + /* API */ + parse: (t) => { + t = t.toLowerCase(); + const e = Pi.colors[t]; + if (e) + return Ze.parse(e); + }, + stringify: (t) => { + const e = Ze.stringify(t); + for (const i in Pi.colors) + if (Pi.colors[i] === e) + return i; + } +}, ts = Pi, Ma = { + /* VARIABLES */ + re: /^rgba?\(\s*?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e\d+)?(%?))\s*?(?:,|\s)\s*?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e\d+)?(%?))\s*?(?:,|\s)\s*?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e\d+)?(%?))(?:\s*?(?:,|\/)\s*?\+?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e\d+)?(%?)))?\s*?\)$/i, + /* API */ + parse: (t) => { + const e = t.charCodeAt(0); + if (e !== 114 && e !== 82) + return; + const i = t.match(Ma.re); + if (!i) + return; + const [, r, n, o, s, a, l, h, u] = i; + return yr.set({ + r: $.channel.clamp.r(n ? parseFloat(r) * 2.55 : parseFloat(r)), + g: $.channel.clamp.g(s ? parseFloat(o) * 2.55 : parseFloat(o)), + b: $.channel.clamp.b(l ? parseFloat(a) * 2.55 : parseFloat(a)), + a: h ? $.channel.clamp.a(u ? parseFloat(h) / 100 : parseFloat(h)) : 1 + }, t); + }, + stringify: (t) => { + const { r: e, g: i, b: r, a: n } = t; + return n < 1 ? `rgba(${$.lang.round(e)}, ${$.lang.round(i)}, ${$.lang.round(r)}, ${$.lang.round(n)})` : `rgb(${$.lang.round(e)}, ${$.lang.round(i)}, ${$.lang.round(r)})`; + } +}, Li = Ma, Ud = { + /* VARIABLES */ + format: { + keyword: ts, + hex: Ze, + rgb: Li, + rgba: Li, + hsl: Ai, + hsla: Ai + }, + /* API */ + parse: (t) => { + if (typeof t != "string") + return t; + const e = Ze.parse(t) || Li.parse(t) || Ai.parse(t) || ts.parse(t); + if (e) + return e; + throw new Error(`Unsupported color format: "${t}"`); + }, + stringify: (t) => !t.changed && t.color ? t.color : t.type.is(ot.HSL) || t.data.r === void 0 ? Ai.stringify(t) : t.a < 1 || !Number.isInteger(t.r) || !Number.isInteger(t.g) || !Number.isInteger(t.b) ? Li.stringify(t) : Ze.stringify(t) +}, Ot = Ud, Yd = (t, e) => { + const i = Ot.parse(t); + for (const r in e) + i[r] = $.channel.clamp[r](e[r]); + return Ot.stringify(i); +}, Oa = Yd, Gd = (t, e, i = 0, r = 1) => { + if (typeof t != "number") + return Oa(t, { a: e }); + const n = yr.set({ + r: $.channel.clamp.r(t), + g: $.channel.clamp.g(e), + b: $.channel.clamp.b(i), + a: $.channel.clamp.a(r) + }); + return Ot.stringify(n); +}, Je = Gd, Vd = (t) => { + const { r: e, g: i, b: r } = Ot.parse(t), n = 0.2126 * $.channel.toLinear(e) + 0.7152 * $.channel.toLinear(i) + 0.0722 * $.channel.toLinear(r); + return $.lang.round(n); +}, Xd = Vd, Kd = (t) => Xd(t) >= 0.5, Zd = Kd, Jd = (t) => !Zd(t), mi = Jd, Qd = (t, e, i) => { + const r = Ot.parse(t), n = r[e], o = $.channel.clamp[e](n + i); + return n !== o && (r[e] = o), Ot.stringify(r); +}, $a = Qd, tp = (t, e) => $a(t, "l", e), F = tp, ep = (t, e) => $a(t, "l", -e), E = ep, ip = (t, e) => { + const i = Ot.parse(t), r = {}; + for (const n in e) + e[n] && (r[n] = i[n] + e[n]); + return Oa(t, r); +}, g = ip, rp = (t, e, i = 50) => { + const { r, g: n, b: o, a: s } = Ot.parse(t), { r: a, g: l, b: h, a: u } = Ot.parse(e), f = i / 100, c = f * 2 - 1, d = s - u, S = ((c * d === -1 ? c : (c + d) / (1 + c * d)) + 1) / 2, O = 1 - S, z = r * S + a * O, T = n * S + l * O, R = o * S + h * O, X = s * f + u * (1 - f); + return Je(z, T, R, X); +}, np = rp, op = (t, e = 100) => { + const i = Ot.parse(t); + return i.r = 255 - i.r, i.g = 255 - i.g, i.b = 255 - i.b, np(i, t, e); +}, _ = op, ht = (t, e) => e ? g(t, { s: -40, l: 10 }) : g(t, { s: -40, l: -10 }), _r = "#ffffff", Cr = "#f2f2f2"; +let sp = class { + constructor() { + this.background = "#f4f4f4", this.primaryColor = "#fff4dd", this.noteBkgColor = "#fff5ad", this.noteTextColor = "#333", this.THEME_COLOR_LIMIT = 12, this.fontFamily = '"trebuchet ms", verdana, arial, sans-serif', this.fontSize = "16px"; + } + updateColors() { + var i, r, n, o, s, a, l, h, u, f, c; + if (this.primaryTextColor = this.primaryTextColor || (this.darkMode ? "#eee" : "#333"), this.secondaryColor = this.secondaryColor || g(this.primaryColor, { h: -120 }), this.tertiaryColor = this.tertiaryColor || g(this.primaryColor, { h: 180, l: 5 }), this.primaryBorderColor = this.primaryBorderColor || ht(this.primaryColor, this.darkMode), this.secondaryBorderColor = this.secondaryBorderColor || ht(this.secondaryColor, this.darkMode), this.tertiaryBorderColor = this.tertiaryBorderColor || ht(this.tertiaryColor, this.darkMode), this.noteBorderColor = this.noteBorderColor || ht(this.noteBkgColor, this.darkMode), this.noteBkgColor = this.noteBkgColor || "#fff5ad", this.noteTextColor = this.noteTextColor || "#333", this.secondaryTextColor = this.secondaryTextColor || _(this.secondaryColor), this.tertiaryTextColor = this.tertiaryTextColor || _(this.tertiaryColor), this.lineColor = this.lineColor || _(this.background), this.arrowheadColor = this.arrowheadColor || _(this.background), this.textColor = this.textColor || this.primaryTextColor, this.border2 = this.border2 || this.tertiaryBorderColor, this.nodeBkg = this.nodeBkg || this.primaryColor, this.mainBkg = this.mainBkg || this.primaryColor, this.nodeBorder = this.nodeBorder || this.primaryBorderColor, this.clusterBkg = this.clusterBkg || this.tertiaryColor, this.clusterBorder = this.clusterBorder || this.tertiaryBorderColor, this.defaultLinkColor = this.defaultLinkColor || this.lineColor, this.titleColor = this.titleColor || this.tertiaryTextColor, this.edgeLabelBackground = this.edgeLabelBackground || (this.darkMode ? E(this.secondaryColor, 30) : this.secondaryColor), this.nodeTextColor = this.nodeTextColor || this.primaryTextColor, this.actorBorder = this.actorBorder || this.primaryBorderColor, this.actorBkg = this.actorBkg || this.mainBkg, this.actorTextColor = this.actorTextColor || this.primaryTextColor, this.actorLineColor = this.actorLineColor || "grey", this.labelBoxBkgColor = this.labelBoxBkgColor || this.actorBkg, this.signalColor = this.signalColor || this.textColor, this.signalTextColor = this.signalTextColor || this.textColor, this.labelBoxBorderColor = this.labelBoxBorderColor || this.actorBorder, this.labelTextColor = this.labelTextColor || this.actorTextColor, this.loopTextColor = this.loopTextColor || this.actorTextColor, this.activationBorderColor = this.activationBorderColor || E(this.secondaryColor, 10), this.activationBkgColor = this.activationBkgColor || this.secondaryColor, this.sequenceNumberColor = this.sequenceNumberColor || _(this.lineColor), this.sectionBkgColor = this.sectionBkgColor || this.tertiaryColor, this.altSectionBkgColor = this.altSectionBkgColor || "white", this.sectionBkgColor = this.sectionBkgColor || this.secondaryColor, this.sectionBkgColor2 = this.sectionBkgColor2 || this.primaryColor, this.excludeBkgColor = this.excludeBkgColor || "#eeeeee", this.taskBorderColor = this.taskBorderColor || this.primaryBorderColor, this.taskBkgColor = this.taskBkgColor || this.primaryColor, this.activeTaskBorderColor = this.activeTaskBorderColor || this.primaryColor, this.activeTaskBkgColor = this.activeTaskBkgColor || F(this.primaryColor, 23), this.gridColor = this.gridColor || "lightgrey", this.doneTaskBkgColor = this.doneTaskBkgColor || "lightgrey", this.doneTaskBorderColor = this.doneTaskBorderColor || "grey", this.critBorderColor = this.critBorderColor || "#ff8888", this.critBkgColor = this.critBkgColor || "red", this.todayLineColor = this.todayLineColor || "red", this.taskTextColor = this.taskTextColor || this.textColor, this.taskTextOutsideColor = this.taskTextOutsideColor || this.textColor, this.taskTextLightColor = this.taskTextLightColor || this.textColor, this.taskTextColor = this.taskTextColor || this.primaryTextColor, this.taskTextDarkColor = this.taskTextDarkColor || this.textColor, this.taskTextClickableColor = this.taskTextClickableColor || "#003163", this.personBorder = this.personBorder || this.primaryBorderColor, this.personBkg = this.personBkg || this.mainBkg, this.transitionColor = this.transitionColor || this.lineColor, this.transitionLabelColor = this.transitionLabelColor || this.textColor, this.stateLabelColor = this.stateLabelColor || this.stateBkg || this.primaryTextColor, this.stateBkg = this.stateBkg || this.mainBkg, this.labelBackgroundColor = this.labelBackgroundColor || this.stateBkg, this.compositeBackground = this.compositeBackground || this.background || this.tertiaryColor, this.altBackground = this.altBackground || this.tertiaryColor, this.compositeTitleBackground = this.compositeTitleBackground || this.mainBkg, this.compositeBorder = this.compositeBorder || this.nodeBorder, this.innerEndBackground = this.nodeBorder, this.errorBkgColor = this.errorBkgColor || this.tertiaryColor, this.errorTextColor = this.errorTextColor || this.tertiaryTextColor, this.transitionColor = this.transitionColor || this.lineColor, this.specialStateColor = this.lineColor, this.cScale0 = this.cScale0 || this.primaryColor, this.cScale1 = this.cScale1 || this.secondaryColor, this.cScale2 = this.cScale2 || this.tertiaryColor, this.cScale3 = this.cScale3 || g(this.primaryColor, { h: 30 }), this.cScale4 = this.cScale4 || g(this.primaryColor, { h: 60 }), this.cScale5 = this.cScale5 || g(this.primaryColor, { h: 90 }), this.cScale6 = this.cScale6 || g(this.primaryColor, { h: 120 }), this.cScale7 = this.cScale7 || g(this.primaryColor, { h: 150 }), this.cScale8 = this.cScale8 || g(this.primaryColor, { h: 210, l: 150 }), this.cScale9 = this.cScale9 || g(this.primaryColor, { h: 270 }), this.cScale10 = this.cScale10 || g(this.primaryColor, { h: 300 }), this.cScale11 = this.cScale11 || g(this.primaryColor, { h: 330 }), this.darkMode) + for (let d = 0; d < this.THEME_COLOR_LIMIT; d++) + this["cScale" + d] = E(this["cScale" + d], 75); + else + for (let d = 0; d < this.THEME_COLOR_LIMIT; d++) + this["cScale" + d] = E(this["cScale" + d], 25); + for (let d = 0; d < this.THEME_COLOR_LIMIT; d++) + this["cScaleInv" + d] = this["cScaleInv" + d] || _(this["cScale" + d]); + for (let d = 0; d < this.THEME_COLOR_LIMIT; d++) + this.darkMode ? this["cScalePeer" + d] = this["cScalePeer" + d] || F(this["cScale" + d], 10) : this["cScalePeer" + d] = this["cScalePeer" + d] || E(this["cScale" + d], 10); + this.scaleLabelColor = this.scaleLabelColor || this.labelTextColor; + for (let d = 0; d < this.THEME_COLOR_LIMIT; d++) + this["cScaleLabel" + d] = this["cScaleLabel" + d] || this.scaleLabelColor; + const e = this.darkMode ? -4 : -1; + for (let d = 0; d < 5; d++) + this["surface" + d] = this["surface" + d] || g(this.mainBkg, { h: 180, s: -15, l: e * (5 + d * 3) }), this["surfacePeer" + d] = this["surfacePeer" + d] || g(this.mainBkg, { h: 180, s: -15, l: e * (8 + d * 3) }); + this.classText = this.classText || this.textColor, this.fillType0 = this.fillType0 || this.primaryColor, this.fillType1 = this.fillType1 || this.secondaryColor, this.fillType2 = this.fillType2 || g(this.primaryColor, { h: 64 }), this.fillType3 = this.fillType3 || g(this.secondaryColor, { h: 64 }), this.fillType4 = this.fillType4 || g(this.primaryColor, { h: -64 }), this.fillType5 = this.fillType5 || g(this.secondaryColor, { h: -64 }), this.fillType6 = this.fillType6 || g(this.primaryColor, { h: 128 }), this.fillType7 = this.fillType7 || g(this.secondaryColor, { h: 128 }), this.pie1 = this.pie1 || this.primaryColor, this.pie2 = this.pie2 || this.secondaryColor, this.pie3 = this.pie3 || this.tertiaryColor, this.pie4 = this.pie4 || g(this.primaryColor, { l: -10 }), this.pie5 = this.pie5 || g(this.secondaryColor, { l: -10 }), this.pie6 = this.pie6 || g(this.tertiaryColor, { l: -10 }), this.pie7 = this.pie7 || g(this.primaryColor, { h: 60, l: -10 }), this.pie8 = this.pie8 || g(this.primaryColor, { h: -60, l: -10 }), this.pie9 = this.pie9 || g(this.primaryColor, { h: 120, l: 0 }), this.pie10 = this.pie10 || g(this.primaryColor, { h: 60, l: -20 }), this.pie11 = this.pie11 || g(this.primaryColor, { h: -60, l: -20 }), this.pie12 = this.pie12 || g(this.primaryColor, { h: 120, l: -10 }), this.pieTitleTextSize = this.pieTitleTextSize || "25px", this.pieTitleTextColor = this.pieTitleTextColor || this.taskTextDarkColor, this.pieSectionTextSize = this.pieSectionTextSize || "17px", this.pieSectionTextColor = this.pieSectionTextColor || this.textColor, this.pieLegendTextSize = this.pieLegendTextSize || "17px", this.pieLegendTextColor = this.pieLegendTextColor || this.taskTextDarkColor, this.pieStrokeColor = this.pieStrokeColor || "black", this.pieStrokeWidth = this.pieStrokeWidth || "2px", this.pieOuterStrokeWidth = this.pieOuterStrokeWidth || "2px", this.pieOuterStrokeColor = this.pieOuterStrokeColor || "black", this.pieOpacity = this.pieOpacity || "0.7", this.quadrant1Fill = this.quadrant1Fill || this.primaryColor, this.quadrant2Fill = this.quadrant2Fill || g(this.primaryColor, { r: 5, g: 5, b: 5 }), this.quadrant3Fill = this.quadrant3Fill || g(this.primaryColor, { r: 10, g: 10, b: 10 }), this.quadrant4Fill = this.quadrant4Fill || g(this.primaryColor, { r: 15, g: 15, b: 15 }), this.quadrant1TextFill = this.quadrant1TextFill || this.primaryTextColor, this.quadrant2TextFill = this.quadrant2TextFill || g(this.primaryTextColor, { r: -5, g: -5, b: -5 }), this.quadrant3TextFill = this.quadrant3TextFill || g(this.primaryTextColor, { r: -10, g: -10, b: -10 }), this.quadrant4TextFill = this.quadrant4TextFill || g(this.primaryTextColor, { r: -15, g: -15, b: -15 }), this.quadrantPointFill = this.quadrantPointFill || mi(this.quadrant1Fill) ? F(this.quadrant1Fill) : E(this.quadrant1Fill), this.quadrantPointTextFill = this.quadrantPointTextFill || this.primaryTextColor, this.quadrantXAxisTextFill = this.quadrantXAxisTextFill || this.primaryTextColor, this.quadrantYAxisTextFill = this.quadrantYAxisTextFill || this.primaryTextColor, this.quadrantInternalBorderStrokeFill = this.quadrantInternalBorderStrokeFill || this.primaryBorderColor, this.quadrantExternalBorderStrokeFill = this.quadrantExternalBorderStrokeFill || this.primaryBorderColor, this.quadrantTitleFill = this.quadrantTitleFill || this.primaryTextColor, this.xyChart = { + backgroundColor: ((i = this.xyChart) == null ? void 0 : i.backgroundColor) || this.background, + titleColor: ((r = this.xyChart) == null ? void 0 : r.titleColor) || this.primaryTextColor, + xAxisTitleColor: ((n = this.xyChart) == null ? void 0 : n.xAxisTitleColor) || this.primaryTextColor, + xAxisLabelColor: ((o = this.xyChart) == null ? void 0 : o.xAxisLabelColor) || this.primaryTextColor, + xAxisTickColor: ((s = this.xyChart) == null ? void 0 : s.xAxisTickColor) || this.primaryTextColor, + xAxisLineColor: ((a = this.xyChart) == null ? void 0 : a.xAxisLineColor) || this.primaryTextColor, + yAxisTitleColor: ((l = this.xyChart) == null ? void 0 : l.yAxisTitleColor) || this.primaryTextColor, + yAxisLabelColor: ((h = this.xyChart) == null ? void 0 : h.yAxisLabelColor) || this.primaryTextColor, + yAxisTickColor: ((u = this.xyChart) == null ? void 0 : u.yAxisTickColor) || this.primaryTextColor, + yAxisLineColor: ((f = this.xyChart) == null ? void 0 : f.yAxisLineColor) || this.primaryTextColor, + plotColorPalette: ((c = this.xyChart) == null ? void 0 : c.plotColorPalette) || "#FFF4DD,#FFD8B1,#FFA07A,#ECEFF1,#D6DBDF,#C3E0A8,#FFB6A4,#FFD74D,#738FA7,#FFFFF0" + }, this.requirementBackground = this.requirementBackground || this.primaryColor, this.requirementBorderColor = this.requirementBorderColor || this.primaryBorderColor, this.requirementBorderSize = this.requirementBorderSize || "1", this.requirementTextColor = this.requirementTextColor || this.primaryTextColor, this.relationColor = this.relationColor || this.lineColor, this.relationLabelBackground = this.relationLabelBackground || (this.darkMode ? E(this.secondaryColor, 30) : this.secondaryColor), this.relationLabelColor = this.relationLabelColor || this.actorTextColor, this.git0 = this.git0 || this.primaryColor, this.git1 = this.git1 || this.secondaryColor, this.git2 = this.git2 || this.tertiaryColor, this.git3 = this.git3 || g(this.primaryColor, { h: -30 }), this.git4 = this.git4 || g(this.primaryColor, { h: -60 }), this.git5 = this.git5 || g(this.primaryColor, { h: -90 }), this.git6 = this.git6 || g(this.primaryColor, { h: 60 }), this.git7 = this.git7 || g(this.primaryColor, { h: 120 }), this.darkMode ? (this.git0 = F(this.git0, 25), this.git1 = F(this.git1, 25), this.git2 = F(this.git2, 25), this.git3 = F(this.git3, 25), this.git4 = F(this.git4, 25), this.git5 = F(this.git5, 25), this.git6 = F(this.git6, 25), this.git7 = F(this.git7, 25)) : (this.git0 = E(this.git0, 25), this.git1 = E(this.git1, 25), this.git2 = E(this.git2, 25), this.git3 = E(this.git3, 25), this.git4 = E(this.git4, 25), this.git5 = E(this.git5, 25), this.git6 = E(this.git6, 25), this.git7 = E(this.git7, 25)), this.gitInv0 = this.gitInv0 || _(this.git0), this.gitInv1 = this.gitInv1 || _(this.git1), this.gitInv2 = this.gitInv2 || _(this.git2), this.gitInv3 = this.gitInv3 || _(this.git3), this.gitInv4 = this.gitInv4 || _(this.git4), this.gitInv5 = this.gitInv5 || _(this.git5), this.gitInv6 = this.gitInv6 || _(this.git6), this.gitInv7 = this.gitInv7 || _(this.git7), this.branchLabelColor = this.branchLabelColor || (this.darkMode ? "black" : this.labelTextColor), this.gitBranchLabel0 = this.gitBranchLabel0 || this.branchLabelColor, this.gitBranchLabel1 = this.gitBranchLabel1 || this.branchLabelColor, this.gitBranchLabel2 = this.gitBranchLabel2 || this.branchLabelColor, this.gitBranchLabel3 = this.gitBranchLabel3 || this.branchLabelColor, this.gitBranchLabel4 = this.gitBranchLabel4 || this.branchLabelColor, this.gitBranchLabel5 = this.gitBranchLabel5 || this.branchLabelColor, this.gitBranchLabel6 = this.gitBranchLabel6 || this.branchLabelColor, this.gitBranchLabel7 = this.gitBranchLabel7 || this.branchLabelColor, this.tagLabelColor = this.tagLabelColor || this.primaryTextColor, this.tagLabelBackground = this.tagLabelBackground || this.primaryColor, this.tagLabelBorder = this.tagBorder || this.primaryBorderColor, this.tagLabelFontSize = this.tagLabelFontSize || "10px", this.commitLabelColor = this.commitLabelColor || this.secondaryTextColor, this.commitLabelBackground = this.commitLabelBackground || this.secondaryColor, this.commitLabelFontSize = this.commitLabelFontSize || "10px", this.attributeBackgroundColorOdd = this.attributeBackgroundColorOdd || _r, this.attributeBackgroundColorEven = this.attributeBackgroundColorEven || Cr; + } + calculate(e) { + if (typeof e != "object") { + this.updateColors(); + return; + } + const i = Object.keys(e); + i.forEach((r) => { + this[r] = e[r]; + }), this.updateColors(), i.forEach((r) => { + this[r] = e[r]; + }); + } +}; +const ap = (t) => { + const e = new sp(); + return e.calculate(t), e; +}; +let lp = class { + constructor() { + this.background = "#333", this.primaryColor = "#1f2020", this.secondaryColor = F(this.primaryColor, 16), this.tertiaryColor = g(this.primaryColor, { h: -160 }), this.primaryBorderColor = _(this.background), this.secondaryBorderColor = ht(this.secondaryColor, this.darkMode), this.tertiaryBorderColor = ht(this.tertiaryColor, this.darkMode), this.primaryTextColor = _(this.primaryColor), this.secondaryTextColor = _(this.secondaryColor), this.tertiaryTextColor = _(this.tertiaryColor), this.lineColor = _(this.background), this.textColor = _(this.background), this.mainBkg = "#1f2020", this.secondBkg = "calculated", this.mainContrastColor = "lightgrey", this.darkTextColor = F(_("#323D47"), 10), this.lineColor = "calculated", this.border1 = "#81B1DB", this.border2 = Je(255, 255, 255, 0.25), this.arrowheadColor = "calculated", this.fontFamily = '"trebuchet ms", verdana, arial, sans-serif', this.fontSize = "16px", this.labelBackground = "#181818", this.textColor = "#ccc", this.THEME_COLOR_LIMIT = 12, this.nodeBkg = "calculated", this.nodeBorder = "calculated", this.clusterBkg = "calculated", this.clusterBorder = "calculated", this.defaultLinkColor = "calculated", this.titleColor = "#F9FFFE", this.edgeLabelBackground = "calculated", this.actorBorder = "calculated", this.actorBkg = "calculated", this.actorTextColor = "calculated", this.actorLineColor = "calculated", this.signalColor = "calculated", this.signalTextColor = "calculated", this.labelBoxBkgColor = "calculated", this.labelBoxBorderColor = "calculated", this.labelTextColor = "calculated", this.loopTextColor = "calculated", this.noteBorderColor = "calculated", this.noteBkgColor = "#fff5ad", this.noteTextColor = "calculated", this.activationBorderColor = "calculated", this.activationBkgColor = "calculated", this.sequenceNumberColor = "black", this.sectionBkgColor = E("#EAE8D9", 30), this.altSectionBkgColor = "calculated", this.sectionBkgColor2 = "#EAE8D9", this.excludeBkgColor = E(this.sectionBkgColor, 10), this.taskBorderColor = Je(255, 255, 255, 70), this.taskBkgColor = "calculated", this.taskTextColor = "calculated", this.taskTextLightColor = "calculated", this.taskTextOutsideColor = "calculated", this.taskTextClickableColor = "#003163", this.activeTaskBorderColor = Je(255, 255, 255, 50), this.activeTaskBkgColor = "#81B1DB", this.gridColor = "calculated", this.doneTaskBkgColor = "calculated", this.doneTaskBorderColor = "grey", this.critBorderColor = "#E83737", this.critBkgColor = "#E83737", this.taskTextDarkColor = "calculated", this.todayLineColor = "#DB5757", this.personBorder = this.primaryBorderColor, this.personBkg = this.mainBkg, this.labelColor = "calculated", this.errorBkgColor = "#a44141", this.errorTextColor = "#ddd"; + } + updateColors() { + var e, i, r, n, o, s, a, l, h, u, f; + this.secondBkg = F(this.mainBkg, 16), this.lineColor = this.mainContrastColor, this.arrowheadColor = this.mainContrastColor, this.nodeBkg = this.mainBkg, this.nodeBorder = this.border1, this.clusterBkg = this.secondBkg, this.clusterBorder = this.border2, this.defaultLinkColor = this.lineColor, this.edgeLabelBackground = F(this.labelBackground, 25), this.actorBorder = this.border1, this.actorBkg = this.mainBkg, this.actorTextColor = this.mainContrastColor, this.actorLineColor = this.mainContrastColor, this.signalColor = this.mainContrastColor, this.signalTextColor = this.mainContrastColor, this.labelBoxBkgColor = this.actorBkg, this.labelBoxBorderColor = this.actorBorder, this.labelTextColor = this.mainContrastColor, this.loopTextColor = this.mainContrastColor, this.noteBorderColor = this.secondaryBorderColor, this.noteBkgColor = this.secondBkg, this.noteTextColor = this.secondaryTextColor, this.activationBorderColor = this.border1, this.activationBkgColor = this.secondBkg, this.altSectionBkgColor = this.background, this.taskBkgColor = F(this.mainBkg, 23), this.taskTextColor = this.darkTextColor, this.taskTextLightColor = this.mainContrastColor, this.taskTextOutsideColor = this.taskTextLightColor, this.gridColor = this.mainContrastColor, this.doneTaskBkgColor = this.mainContrastColor, this.taskTextDarkColor = this.darkTextColor, this.transitionColor = this.transitionColor || this.lineColor, this.transitionLabelColor = this.transitionLabelColor || this.textColor, this.stateLabelColor = this.stateLabelColor || this.stateBkg || this.primaryTextColor, this.stateBkg = this.stateBkg || this.mainBkg, this.labelBackgroundColor = this.labelBackgroundColor || this.stateBkg, this.compositeBackground = this.compositeBackground || this.background || this.tertiaryColor, this.altBackground = this.altBackground || "#555", this.compositeTitleBackground = this.compositeTitleBackground || this.mainBkg, this.compositeBorder = this.compositeBorder || this.nodeBorder, this.innerEndBackground = this.primaryBorderColor, this.specialStateColor = "#f4f4f4", this.errorBkgColor = this.errorBkgColor || this.tertiaryColor, this.errorTextColor = this.errorTextColor || this.tertiaryTextColor, this.fillType0 = this.primaryColor, this.fillType1 = this.secondaryColor, this.fillType2 = g(this.primaryColor, { h: 64 }), this.fillType3 = g(this.secondaryColor, { h: 64 }), this.fillType4 = g(this.primaryColor, { h: -64 }), this.fillType5 = g(this.secondaryColor, { h: -64 }), this.fillType6 = g(this.primaryColor, { h: 128 }), this.fillType7 = g(this.secondaryColor, { h: 128 }), this.cScale1 = this.cScale1 || "#0b0000", this.cScale2 = this.cScale2 || "#4d1037", this.cScale3 = this.cScale3 || "#3f5258", this.cScale4 = this.cScale4 || "#4f2f1b", this.cScale5 = this.cScale5 || "#6e0a0a", this.cScale6 = this.cScale6 || "#3b0048", this.cScale7 = this.cScale7 || "#995a01", this.cScale8 = this.cScale8 || "#154706", this.cScale9 = this.cScale9 || "#161722", this.cScale10 = this.cScale10 || "#00296f", this.cScale11 = this.cScale11 || "#01629c", this.cScale12 = this.cScale12 || "#010029", this.cScale0 = this.cScale0 || this.primaryColor, this.cScale1 = this.cScale1 || this.secondaryColor, this.cScale2 = this.cScale2 || this.tertiaryColor, this.cScale3 = this.cScale3 || g(this.primaryColor, { h: 30 }), this.cScale4 = this.cScale4 || g(this.primaryColor, { h: 60 }), this.cScale5 = this.cScale5 || g(this.primaryColor, { h: 90 }), this.cScale6 = this.cScale6 || g(this.primaryColor, { h: 120 }), this.cScale7 = this.cScale7 || g(this.primaryColor, { h: 150 }), this.cScale8 = this.cScale8 || g(this.primaryColor, { h: 210 }), this.cScale9 = this.cScale9 || g(this.primaryColor, { h: 270 }), this.cScale10 = this.cScale10 || g(this.primaryColor, { h: 300 }), this.cScale11 = this.cScale11 || g(this.primaryColor, { h: 330 }); + for (let c = 0; c < this.THEME_COLOR_LIMIT; c++) + this["cScaleInv" + c] = this["cScaleInv" + c] || _(this["cScale" + c]); + for (let c = 0; c < this.THEME_COLOR_LIMIT; c++) + this["cScalePeer" + c] = this["cScalePeer" + c] || F(this["cScale" + c], 10); + for (let c = 0; c < 5; c++) + this["surface" + c] = this["surface" + c] || g(this.mainBkg, { h: 30, s: -30, l: -(-10 + c * 4) }), this["surfacePeer" + c] = this["surfacePeer" + c] || g(this.mainBkg, { h: 30, s: -30, l: -(-7 + c * 4) }); + this.scaleLabelColor = this.scaleLabelColor || (this.darkMode ? "black" : this.labelTextColor); + for (let c = 0; c < this.THEME_COLOR_LIMIT; c++) + this["cScaleLabel" + c] = this["cScaleLabel" + c] || this.scaleLabelColor; + for (let c = 0; c < this.THEME_COLOR_LIMIT; c++) + this["pie" + c] = this["cScale" + c]; + this.pieTitleTextSize = this.pieTitleTextSize || "25px", this.pieTitleTextColor = this.pieTitleTextColor || this.taskTextDarkColor, this.pieSectionTextSize = this.pieSectionTextSize || "17px", this.pieSectionTextColor = this.pieSectionTextColor || this.textColor, this.pieLegendTextSize = this.pieLegendTextSize || "17px", this.pieLegendTextColor = this.pieLegendTextColor || this.taskTextDarkColor, this.pieStrokeColor = this.pieStrokeColor || "black", this.pieStrokeWidth = this.pieStrokeWidth || "2px", this.pieOuterStrokeWidth = this.pieOuterStrokeWidth || "2px", this.pieOuterStrokeColor = this.pieOuterStrokeColor || "black", this.pieOpacity = this.pieOpacity || "0.7", this.quadrant1Fill = this.quadrant1Fill || this.primaryColor, this.quadrant2Fill = this.quadrant2Fill || g(this.primaryColor, { r: 5, g: 5, b: 5 }), this.quadrant3Fill = this.quadrant3Fill || g(this.primaryColor, { r: 10, g: 10, b: 10 }), this.quadrant4Fill = this.quadrant4Fill || g(this.primaryColor, { r: 15, g: 15, b: 15 }), this.quadrant1TextFill = this.quadrant1TextFill || this.primaryTextColor, this.quadrant2TextFill = this.quadrant2TextFill || g(this.primaryTextColor, { r: -5, g: -5, b: -5 }), this.quadrant3TextFill = this.quadrant3TextFill || g(this.primaryTextColor, { r: -10, g: -10, b: -10 }), this.quadrant4TextFill = this.quadrant4TextFill || g(this.primaryTextColor, { r: -15, g: -15, b: -15 }), this.quadrantPointFill = this.quadrantPointFill || mi(this.quadrant1Fill) ? F(this.quadrant1Fill) : E(this.quadrant1Fill), this.quadrantPointTextFill = this.quadrantPointTextFill || this.primaryTextColor, this.quadrantXAxisTextFill = this.quadrantXAxisTextFill || this.primaryTextColor, this.quadrantYAxisTextFill = this.quadrantYAxisTextFill || this.primaryTextColor, this.quadrantInternalBorderStrokeFill = this.quadrantInternalBorderStrokeFill || this.primaryBorderColor, this.quadrantExternalBorderStrokeFill = this.quadrantExternalBorderStrokeFill || this.primaryBorderColor, this.quadrantTitleFill = this.quadrantTitleFill || this.primaryTextColor, this.xyChart = { + backgroundColor: ((e = this.xyChart) == null ? void 0 : e.backgroundColor) || this.background, + titleColor: ((i = this.xyChart) == null ? void 0 : i.titleColor) || this.primaryTextColor, + xAxisTitleColor: ((r = this.xyChart) == null ? void 0 : r.xAxisTitleColor) || this.primaryTextColor, + xAxisLabelColor: ((n = this.xyChart) == null ? void 0 : n.xAxisLabelColor) || this.primaryTextColor, + xAxisTickColor: ((o = this.xyChart) == null ? void 0 : o.xAxisTickColor) || this.primaryTextColor, + xAxisLineColor: ((s = this.xyChart) == null ? void 0 : s.xAxisLineColor) || this.primaryTextColor, + yAxisTitleColor: ((a = this.xyChart) == null ? void 0 : a.yAxisTitleColor) || this.primaryTextColor, + yAxisLabelColor: ((l = this.xyChart) == null ? void 0 : l.yAxisLabelColor) || this.primaryTextColor, + yAxisTickColor: ((h = this.xyChart) == null ? void 0 : h.yAxisTickColor) || this.primaryTextColor, + yAxisLineColor: ((u = this.xyChart) == null ? void 0 : u.yAxisLineColor) || this.primaryTextColor, + plotColorPalette: ((f = this.xyChart) == null ? void 0 : f.plotColorPalette) || "#3498db,#2ecc71,#e74c3c,#f1c40f,#bdc3c7,#ffffff,#34495e,#9b59b6,#1abc9c,#e67e22" + }, this.classText = this.primaryTextColor, this.requirementBackground = this.requirementBackground || this.primaryColor, this.requirementBorderColor = this.requirementBorderColor || this.primaryBorderColor, this.requirementBorderSize = this.requirementBorderSize || "1", this.requirementTextColor = this.requirementTextColor || this.primaryTextColor, this.relationColor = this.relationColor || this.lineColor, this.relationLabelBackground = this.relationLabelBackground || (this.darkMode ? E(this.secondaryColor, 30) : this.secondaryColor), this.relationLabelColor = this.relationLabelColor || this.actorTextColor, this.git0 = F(this.secondaryColor, 20), this.git1 = F(this.pie2 || this.secondaryColor, 20), this.git2 = F(this.pie3 || this.tertiaryColor, 20), this.git3 = F(this.pie4 || g(this.primaryColor, { h: -30 }), 20), this.git4 = F(this.pie5 || g(this.primaryColor, { h: -60 }), 20), this.git5 = F(this.pie6 || g(this.primaryColor, { h: -90 }), 10), this.git6 = F(this.pie7 || g(this.primaryColor, { h: 60 }), 10), this.git7 = F(this.pie8 || g(this.primaryColor, { h: 120 }), 20), this.gitInv0 = this.gitInv0 || _(this.git0), this.gitInv1 = this.gitInv1 || _(this.git1), this.gitInv2 = this.gitInv2 || _(this.git2), this.gitInv3 = this.gitInv3 || _(this.git3), this.gitInv4 = this.gitInv4 || _(this.git4), this.gitInv5 = this.gitInv5 || _(this.git5), this.gitInv6 = this.gitInv6 || _(this.git6), this.gitInv7 = this.gitInv7 || _(this.git7), this.gitBranchLabel0 = this.gitBranchLabel0 || _(this.labelTextColor), this.gitBranchLabel1 = this.gitBranchLabel1 || this.labelTextColor, this.gitBranchLabel2 = this.gitBranchLabel2 || this.labelTextColor, this.gitBranchLabel3 = this.gitBranchLabel3 || _(this.labelTextColor), this.gitBranchLabel4 = this.gitBranchLabel4 || this.labelTextColor, this.gitBranchLabel5 = this.gitBranchLabel5 || this.labelTextColor, this.gitBranchLabel6 = this.gitBranchLabel6 || this.labelTextColor, this.gitBranchLabel7 = this.gitBranchLabel7 || this.labelTextColor, this.tagLabelColor = this.tagLabelColor || this.primaryTextColor, this.tagLabelBackground = this.tagLabelBackground || this.primaryColor, this.tagLabelBorder = this.tagBorder || this.primaryBorderColor, this.tagLabelFontSize = this.tagLabelFontSize || "10px", this.commitLabelColor = this.commitLabelColor || this.secondaryTextColor, this.commitLabelBackground = this.commitLabelBackground || this.secondaryColor, this.commitLabelFontSize = this.commitLabelFontSize || "10px", this.attributeBackgroundColorOdd = this.attributeBackgroundColorOdd || F(this.background, 12), this.attributeBackgroundColorEven = this.attributeBackgroundColorEven || F(this.background, 2); + } + calculate(e) { + if (typeof e != "object") { + this.updateColors(); + return; + } + const i = Object.keys(e); + i.forEach((r) => { + this[r] = e[r]; + }), this.updateColors(), i.forEach((r) => { + this[r] = e[r]; + }); + } +}; +const hp = (t) => { + const e = new lp(); + return e.calculate(t), e; +}; +let cp = class { + constructor() { + this.background = "#f4f4f4", this.primaryColor = "#ECECFF", this.secondaryColor = g(this.primaryColor, { h: 120 }), this.secondaryColor = "#ffffde", this.tertiaryColor = g(this.primaryColor, { h: -160 }), this.primaryBorderColor = ht(this.primaryColor, this.darkMode), this.secondaryBorderColor = ht(this.secondaryColor, this.darkMode), this.tertiaryBorderColor = ht(this.tertiaryColor, this.darkMode), this.primaryTextColor = _(this.primaryColor), this.secondaryTextColor = _(this.secondaryColor), this.tertiaryTextColor = _(this.tertiaryColor), this.lineColor = _(this.background), this.textColor = _(this.background), this.background = "white", this.mainBkg = "#ECECFF", this.secondBkg = "#ffffde", this.lineColor = "#333333", this.border1 = "#9370DB", this.border2 = "#aaaa33", this.arrowheadColor = "#333333", this.fontFamily = '"trebuchet ms", verdana, arial, sans-serif', this.fontSize = "16px", this.labelBackground = "#e8e8e8", this.textColor = "#333", this.THEME_COLOR_LIMIT = 12, this.nodeBkg = "calculated", this.nodeBorder = "calculated", this.clusterBkg = "calculated", this.clusterBorder = "calculated", this.defaultLinkColor = "calculated", this.titleColor = "calculated", this.edgeLabelBackground = "calculated", this.actorBorder = "calculated", this.actorBkg = "calculated", this.actorTextColor = "black", this.actorLineColor = "grey", this.signalColor = "calculated", this.signalTextColor = "calculated", this.labelBoxBkgColor = "calculated", this.labelBoxBorderColor = "calculated", this.labelTextColor = "calculated", this.loopTextColor = "calculated", this.noteBorderColor = "calculated", this.noteBkgColor = "#fff5ad", this.noteTextColor = "calculated", this.activationBorderColor = "#666", this.activationBkgColor = "#f4f4f4", this.sequenceNumberColor = "white", this.sectionBkgColor = "calculated", this.altSectionBkgColor = "calculated", this.sectionBkgColor2 = "calculated", this.excludeBkgColor = "#eeeeee", this.taskBorderColor = "calculated", this.taskBkgColor = "calculated", this.taskTextLightColor = "calculated", this.taskTextColor = this.taskTextLightColor, this.taskTextDarkColor = "calculated", this.taskTextOutsideColor = this.taskTextDarkColor, this.taskTextClickableColor = "calculated", this.activeTaskBorderColor = "calculated", this.activeTaskBkgColor = "calculated", this.gridColor = "calculated", this.doneTaskBkgColor = "calculated", this.doneTaskBorderColor = "calculated", this.critBorderColor = "calculated", this.critBkgColor = "calculated", this.todayLineColor = "calculated", this.sectionBkgColor = Je(102, 102, 255, 0.49), this.altSectionBkgColor = "white", this.sectionBkgColor2 = "#fff400", this.taskBorderColor = "#534fbc", this.taskBkgColor = "#8a90dd", this.taskTextLightColor = "white", this.taskTextColor = "calculated", this.taskTextDarkColor = "black", this.taskTextOutsideColor = "calculated", this.taskTextClickableColor = "#003163", this.activeTaskBorderColor = "#534fbc", this.activeTaskBkgColor = "#bfc7ff", this.gridColor = "lightgrey", this.doneTaskBkgColor = "lightgrey", this.doneTaskBorderColor = "grey", this.critBorderColor = "#ff8888", this.critBkgColor = "red", this.todayLineColor = "red", this.personBorder = this.primaryBorderColor, this.personBkg = this.mainBkg, this.labelColor = "black", this.errorBkgColor = "#552222", this.errorTextColor = "#552222", this.updateColors(); + } + updateColors() { + var e, i, r, n, o, s, a, l, h, u, f; + this.cScale0 = this.cScale0 || this.primaryColor, this.cScale1 = this.cScale1 || this.secondaryColor, this.cScale2 = this.cScale2 || this.tertiaryColor, this.cScale3 = this.cScale3 || g(this.primaryColor, { h: 30 }), this.cScale4 = this.cScale4 || g(this.primaryColor, { h: 60 }), this.cScale5 = this.cScale5 || g(this.primaryColor, { h: 90 }), this.cScale6 = this.cScale6 || g(this.primaryColor, { h: 120 }), this.cScale7 = this.cScale7 || g(this.primaryColor, { h: 150 }), this.cScale8 = this.cScale8 || g(this.primaryColor, { h: 210 }), this.cScale9 = this.cScale9 || g(this.primaryColor, { h: 270 }), this.cScale10 = this.cScale10 || g(this.primaryColor, { h: 300 }), this.cScale11 = this.cScale11 || g(this.primaryColor, { h: 330 }), this["cScalePeer1"] = this["cScalePeer1"] || E(this.secondaryColor, 45), this["cScalePeer2"] = this["cScalePeer2"] || E(this.tertiaryColor, 40); + for (let c = 0; c < this.THEME_COLOR_LIMIT; c++) + this["cScale" + c] = E(this["cScale" + c], 10), this["cScalePeer" + c] = this["cScalePeer" + c] || E(this["cScale" + c], 25); + for (let c = 0; c < this.THEME_COLOR_LIMIT; c++) + this["cScaleInv" + c] = this["cScaleInv" + c] || g(this["cScale" + c], { h: 180 }); + for (let c = 0; c < 5; c++) + this["surface" + c] = this["surface" + c] || g(this.mainBkg, { h: 30, l: -(5 + c * 5) }), this["surfacePeer" + c] = this["surfacePeer" + c] || g(this.mainBkg, { h: 30, l: -(7 + c * 5) }); + if (this.scaleLabelColor = this.scaleLabelColor !== "calculated" && this.scaleLabelColor ? this.scaleLabelColor : this.labelTextColor, this.labelTextColor !== "calculated") { + this.cScaleLabel0 = this.cScaleLabel0 || _(this.labelTextColor), this.cScaleLabel3 = this.cScaleLabel3 || _(this.labelTextColor); + for (let c = 0; c < this.THEME_COLOR_LIMIT; c++) + this["cScaleLabel" + c] = this["cScaleLabel" + c] || this.labelTextColor; + } + this.nodeBkg = this.mainBkg, this.nodeBorder = this.border1, this.clusterBkg = this.secondBkg, this.clusterBorder = this.border2, this.defaultLinkColor = this.lineColor, this.titleColor = this.textColor, this.edgeLabelBackground = this.labelBackground, this.actorBorder = F(this.border1, 23), this.actorBkg = this.mainBkg, this.labelBoxBkgColor = this.actorBkg, this.signalColor = this.textColor, this.signalTextColor = this.textColor, this.labelBoxBorderColor = this.actorBorder, this.labelTextColor = this.actorTextColor, this.loopTextColor = this.actorTextColor, this.noteBorderColor = this.border2, this.noteTextColor = this.actorTextColor, this.taskTextColor = this.taskTextLightColor, this.taskTextOutsideColor = this.taskTextDarkColor, this.transitionColor = this.transitionColor || this.lineColor, this.transitionLabelColor = this.transitionLabelColor || this.textColor, this.stateLabelColor = this.stateLabelColor || this.stateBkg || this.primaryTextColor, this.stateBkg = this.stateBkg || this.mainBkg, this.labelBackgroundColor = this.labelBackgroundColor || this.stateBkg, this.compositeBackground = this.compositeBackground || this.background || this.tertiaryColor, this.altBackground = this.altBackground || "#f0f0f0", this.compositeTitleBackground = this.compositeTitleBackground || this.mainBkg, this.compositeBorder = this.compositeBorder || this.nodeBorder, this.innerEndBackground = this.nodeBorder, this.specialStateColor = this.lineColor, this.errorBkgColor = this.errorBkgColor || this.tertiaryColor, this.errorTextColor = this.errorTextColor || this.tertiaryTextColor, this.transitionColor = this.transitionColor || this.lineColor, this.classText = this.primaryTextColor, this.fillType0 = this.primaryColor, this.fillType1 = this.secondaryColor, this.fillType2 = g(this.primaryColor, { h: 64 }), this.fillType3 = g(this.secondaryColor, { h: 64 }), this.fillType4 = g(this.primaryColor, { h: -64 }), this.fillType5 = g(this.secondaryColor, { h: -64 }), this.fillType6 = g(this.primaryColor, { h: 128 }), this.fillType7 = g(this.secondaryColor, { h: 128 }), this.pie1 = this.pie1 || this.primaryColor, this.pie2 = this.pie2 || this.secondaryColor, this.pie3 = this.pie3 || g(this.tertiaryColor, { l: -40 }), this.pie4 = this.pie4 || g(this.primaryColor, { l: -10 }), this.pie5 = this.pie5 || g(this.secondaryColor, { l: -30 }), this.pie6 = this.pie6 || g(this.tertiaryColor, { l: -20 }), this.pie7 = this.pie7 || g(this.primaryColor, { h: 60, l: -20 }), this.pie8 = this.pie8 || g(this.primaryColor, { h: -60, l: -40 }), this.pie9 = this.pie9 || g(this.primaryColor, { h: 120, l: -40 }), this.pie10 = this.pie10 || g(this.primaryColor, { h: 60, l: -40 }), this.pie11 = this.pie11 || g(this.primaryColor, { h: -90, l: -40 }), this.pie12 = this.pie12 || g(this.primaryColor, { h: 120, l: -30 }), this.pieTitleTextSize = this.pieTitleTextSize || "25px", this.pieTitleTextColor = this.pieTitleTextColor || this.taskTextDarkColor, this.pieSectionTextSize = this.pieSectionTextSize || "17px", this.pieSectionTextColor = this.pieSectionTextColor || this.textColor, this.pieLegendTextSize = this.pieLegendTextSize || "17px", this.pieLegendTextColor = this.pieLegendTextColor || this.taskTextDarkColor, this.pieStrokeColor = this.pieStrokeColor || "black", this.pieStrokeWidth = this.pieStrokeWidth || "2px", this.pieOuterStrokeWidth = this.pieOuterStrokeWidth || "2px", this.pieOuterStrokeColor = this.pieOuterStrokeColor || "black", this.pieOpacity = this.pieOpacity || "0.7", this.quadrant1Fill = this.quadrant1Fill || this.primaryColor, this.quadrant2Fill = this.quadrant2Fill || g(this.primaryColor, { r: 5, g: 5, b: 5 }), this.quadrant3Fill = this.quadrant3Fill || g(this.primaryColor, { r: 10, g: 10, b: 10 }), this.quadrant4Fill = this.quadrant4Fill || g(this.primaryColor, { r: 15, g: 15, b: 15 }), this.quadrant1TextFill = this.quadrant1TextFill || this.primaryTextColor, this.quadrant2TextFill = this.quadrant2TextFill || g(this.primaryTextColor, { r: -5, g: -5, b: -5 }), this.quadrant3TextFill = this.quadrant3TextFill || g(this.primaryTextColor, { r: -10, g: -10, b: -10 }), this.quadrant4TextFill = this.quadrant4TextFill || g(this.primaryTextColor, { r: -15, g: -15, b: -15 }), this.quadrantPointFill = this.quadrantPointFill || mi(this.quadrant1Fill) ? F(this.quadrant1Fill) : E(this.quadrant1Fill), this.quadrantPointTextFill = this.quadrantPointTextFill || this.primaryTextColor, this.quadrantXAxisTextFill = this.quadrantXAxisTextFill || this.primaryTextColor, this.quadrantYAxisTextFill = this.quadrantYAxisTextFill || this.primaryTextColor, this.quadrantInternalBorderStrokeFill = this.quadrantInternalBorderStrokeFill || this.primaryBorderColor, this.quadrantExternalBorderStrokeFill = this.quadrantExternalBorderStrokeFill || this.primaryBorderColor, this.quadrantTitleFill = this.quadrantTitleFill || this.primaryTextColor, this.xyChart = { + backgroundColor: ((e = this.xyChart) == null ? void 0 : e.backgroundColor) || this.background, + titleColor: ((i = this.xyChart) == null ? void 0 : i.titleColor) || this.primaryTextColor, + xAxisTitleColor: ((r = this.xyChart) == null ? void 0 : r.xAxisTitleColor) || this.primaryTextColor, + xAxisLabelColor: ((n = this.xyChart) == null ? void 0 : n.xAxisLabelColor) || this.primaryTextColor, + xAxisTickColor: ((o = this.xyChart) == null ? void 0 : o.xAxisTickColor) || this.primaryTextColor, + xAxisLineColor: ((s = this.xyChart) == null ? void 0 : s.xAxisLineColor) || this.primaryTextColor, + yAxisTitleColor: ((a = this.xyChart) == null ? void 0 : a.yAxisTitleColor) || this.primaryTextColor, + yAxisLabelColor: ((l = this.xyChart) == null ? void 0 : l.yAxisLabelColor) || this.primaryTextColor, + yAxisTickColor: ((h = this.xyChart) == null ? void 0 : h.yAxisTickColor) || this.primaryTextColor, + yAxisLineColor: ((u = this.xyChart) == null ? void 0 : u.yAxisLineColor) || this.primaryTextColor, + plotColorPalette: ((f = this.xyChart) == null ? void 0 : f.plotColorPalette) || "#ECECFF,#8493A6,#FFC3A0,#DCDDE1,#B8E994,#D1A36F,#C3CDE6,#FFB6C1,#496078,#F8F3E3" + }, this.requirementBackground = this.requirementBackground || this.primaryColor, this.requirementBorderColor = this.requirementBorderColor || this.primaryBorderColor, this.requirementBorderSize = this.requirementBorderSize || "1", this.requirementTextColor = this.requirementTextColor || this.primaryTextColor, this.relationColor = this.relationColor || this.lineColor, this.relationLabelBackground = this.relationLabelBackground || this.labelBackground, this.relationLabelColor = this.relationLabelColor || this.actorTextColor, this.git0 = this.git0 || this.primaryColor, this.git1 = this.git1 || this.secondaryColor, this.git2 = this.git2 || this.tertiaryColor, this.git3 = this.git3 || g(this.primaryColor, { h: -30 }), this.git4 = this.git4 || g(this.primaryColor, { h: -60 }), this.git5 = this.git5 || g(this.primaryColor, { h: -90 }), this.git6 = this.git6 || g(this.primaryColor, { h: 60 }), this.git7 = this.git7 || g(this.primaryColor, { h: 120 }), this.darkMode ? (this.git0 = F(this.git0, 25), this.git1 = F(this.git1, 25), this.git2 = F(this.git2, 25), this.git3 = F(this.git3, 25), this.git4 = F(this.git4, 25), this.git5 = F(this.git5, 25), this.git6 = F(this.git6, 25), this.git7 = F(this.git7, 25)) : (this.git0 = E(this.git0, 25), this.git1 = E(this.git1, 25), this.git2 = E(this.git2, 25), this.git3 = E(this.git3, 25), this.git4 = E(this.git4, 25), this.git5 = E(this.git5, 25), this.git6 = E(this.git6, 25), this.git7 = E(this.git7, 25)), this.gitInv0 = this.gitInv0 || E(_(this.git0), 25), this.gitInv1 = this.gitInv1 || _(this.git1), this.gitInv2 = this.gitInv2 || _(this.git2), this.gitInv3 = this.gitInv3 || _(this.git3), this.gitInv4 = this.gitInv4 || _(this.git4), this.gitInv5 = this.gitInv5 || _(this.git5), this.gitInv6 = this.gitInv6 || _(this.git6), this.gitInv7 = this.gitInv7 || _(this.git7), this.gitBranchLabel0 = this.gitBranchLabel0 || _(this.labelTextColor), this.gitBranchLabel1 = this.gitBranchLabel1 || this.labelTextColor, this.gitBranchLabel2 = this.gitBranchLabel2 || this.labelTextColor, this.gitBranchLabel3 = this.gitBranchLabel3 || _(this.labelTextColor), this.gitBranchLabel4 = this.gitBranchLabel4 || this.labelTextColor, this.gitBranchLabel5 = this.gitBranchLabel5 || this.labelTextColor, this.gitBranchLabel6 = this.gitBranchLabel6 || this.labelTextColor, this.gitBranchLabel7 = this.gitBranchLabel7 || this.labelTextColor, this.tagLabelColor = this.tagLabelColor || this.primaryTextColor, this.tagLabelBackground = this.tagLabelBackground || this.primaryColor, this.tagLabelBorder = this.tagBorder || this.primaryBorderColor, this.tagLabelFontSize = this.tagLabelFontSize || "10px", this.commitLabelColor = this.commitLabelColor || this.secondaryTextColor, this.commitLabelBackground = this.commitLabelBackground || this.secondaryColor, this.commitLabelFontSize = this.commitLabelFontSize || "10px", this.attributeBackgroundColorOdd = this.attributeBackgroundColorOdd || _r, this.attributeBackgroundColorEven = this.attributeBackgroundColorEven || Cr; + } + calculate(e) { + if (typeof e != "object") { + this.updateColors(); + return; + } + const i = Object.keys(e); + i.forEach((r) => { + this[r] = e[r]; + }), this.updateColors(), i.forEach((r) => { + this[r] = e[r]; + }); + } +}; +const up = (t) => { + const e = new cp(); + return e.calculate(t), e; +}; +let fp = class { + constructor() { + this.background = "#f4f4f4", this.primaryColor = "#cde498", this.secondaryColor = "#cdffb2", this.background = "white", this.mainBkg = "#cde498", this.secondBkg = "#cdffb2", this.lineColor = "green", this.border1 = "#13540c", this.border2 = "#6eaa49", this.arrowheadColor = "green", this.fontFamily = '"trebuchet ms", verdana, arial, sans-serif', this.fontSize = "16px", this.tertiaryColor = F("#cde498", 10), this.primaryBorderColor = ht(this.primaryColor, this.darkMode), this.secondaryBorderColor = ht(this.secondaryColor, this.darkMode), this.tertiaryBorderColor = ht(this.tertiaryColor, this.darkMode), this.primaryTextColor = _(this.primaryColor), this.secondaryTextColor = _(this.secondaryColor), this.tertiaryTextColor = _(this.primaryColor), this.lineColor = _(this.background), this.textColor = _(this.background), this.THEME_COLOR_LIMIT = 12, this.nodeBkg = "calculated", this.nodeBorder = "calculated", this.clusterBkg = "calculated", this.clusterBorder = "calculated", this.defaultLinkColor = "calculated", this.titleColor = "#333", this.edgeLabelBackground = "#e8e8e8", this.actorBorder = "calculated", this.actorBkg = "calculated", this.actorTextColor = "black", this.actorLineColor = "grey", this.signalColor = "#333", this.signalTextColor = "#333", this.labelBoxBkgColor = "calculated", this.labelBoxBorderColor = "#326932", this.labelTextColor = "calculated", this.loopTextColor = "calculated", this.noteBorderColor = "calculated", this.noteBkgColor = "#fff5ad", this.noteTextColor = "calculated", this.activationBorderColor = "#666", this.activationBkgColor = "#f4f4f4", this.sequenceNumberColor = "white", this.sectionBkgColor = "#6eaa49", this.altSectionBkgColor = "white", this.sectionBkgColor2 = "#6eaa49", this.excludeBkgColor = "#eeeeee", this.taskBorderColor = "calculated", this.taskBkgColor = "#487e3a", this.taskTextLightColor = "white", this.taskTextColor = "calculated", this.taskTextDarkColor = "black", this.taskTextOutsideColor = "calculated", this.taskTextClickableColor = "#003163", this.activeTaskBorderColor = "calculated", this.activeTaskBkgColor = "calculated", this.gridColor = "lightgrey", this.doneTaskBkgColor = "lightgrey", this.doneTaskBorderColor = "grey", this.critBorderColor = "#ff8888", this.critBkgColor = "red", this.todayLineColor = "red", this.personBorder = this.primaryBorderColor, this.personBkg = this.mainBkg, this.labelColor = "black", this.errorBkgColor = "#552222", this.errorTextColor = "#552222"; + } + updateColors() { + var e, i, r, n, o, s, a, l, h, u, f; + this.actorBorder = E(this.mainBkg, 20), this.actorBkg = this.mainBkg, this.labelBoxBkgColor = this.actorBkg, this.labelTextColor = this.actorTextColor, this.loopTextColor = this.actorTextColor, this.noteBorderColor = this.border2, this.noteTextColor = this.actorTextColor, this.cScale0 = this.cScale0 || this.primaryColor, this.cScale1 = this.cScale1 || this.secondaryColor, this.cScale2 = this.cScale2 || this.tertiaryColor, this.cScale3 = this.cScale3 || g(this.primaryColor, { h: 30 }), this.cScale4 = this.cScale4 || g(this.primaryColor, { h: 60 }), this.cScale5 = this.cScale5 || g(this.primaryColor, { h: 90 }), this.cScale6 = this.cScale6 || g(this.primaryColor, { h: 120 }), this.cScale7 = this.cScale7 || g(this.primaryColor, { h: 150 }), this.cScale8 = this.cScale8 || g(this.primaryColor, { h: 210 }), this.cScale9 = this.cScale9 || g(this.primaryColor, { h: 270 }), this.cScale10 = this.cScale10 || g(this.primaryColor, { h: 300 }), this.cScale11 = this.cScale11 || g(this.primaryColor, { h: 330 }), this["cScalePeer1"] = this["cScalePeer1"] || E(this.secondaryColor, 45), this["cScalePeer2"] = this["cScalePeer2"] || E(this.tertiaryColor, 40); + for (let c = 0; c < this.THEME_COLOR_LIMIT; c++) + this["cScale" + c] = E(this["cScale" + c], 10), this["cScalePeer" + c] = this["cScalePeer" + c] || E(this["cScale" + c], 25); + for (let c = 0; c < this.THEME_COLOR_LIMIT; c++) + this["cScaleInv" + c] = this["cScaleInv" + c] || g(this["cScale" + c], { h: 180 }); + this.scaleLabelColor = this.scaleLabelColor !== "calculated" && this.scaleLabelColor ? this.scaleLabelColor : this.labelTextColor; + for (let c = 0; c < this.THEME_COLOR_LIMIT; c++) + this["cScaleLabel" + c] = this["cScaleLabel" + c] || this.scaleLabelColor; + for (let c = 0; c < 5; c++) + this["surface" + c] = this["surface" + c] || g(this.mainBkg, { h: 30, s: -30, l: -(5 + c * 5) }), this["surfacePeer" + c] = this["surfacePeer" + c] || g(this.mainBkg, { h: 30, s: -30, l: -(8 + c * 5) }); + this.nodeBkg = this.mainBkg, this.nodeBorder = this.border1, this.clusterBkg = this.secondBkg, this.clusterBorder = this.border2, this.defaultLinkColor = this.lineColor, this.taskBorderColor = this.border1, this.taskTextColor = this.taskTextLightColor, this.taskTextOutsideColor = this.taskTextDarkColor, this.activeTaskBorderColor = this.taskBorderColor, this.activeTaskBkgColor = this.mainBkg, this.transitionColor = this.transitionColor || this.lineColor, this.transitionLabelColor = this.transitionLabelColor || this.textColor, this.stateLabelColor = this.stateLabelColor || this.stateBkg || this.primaryTextColor, this.stateBkg = this.stateBkg || this.mainBkg, this.labelBackgroundColor = this.labelBackgroundColor || this.stateBkg, this.compositeBackground = this.compositeBackground || this.background || this.tertiaryColor, this.altBackground = this.altBackground || "#f0f0f0", this.compositeTitleBackground = this.compositeTitleBackground || this.mainBkg, this.compositeBorder = this.compositeBorder || this.nodeBorder, this.innerEndBackground = this.primaryBorderColor, this.specialStateColor = this.lineColor, this.errorBkgColor = this.errorBkgColor || this.tertiaryColor, this.errorTextColor = this.errorTextColor || this.tertiaryTextColor, this.transitionColor = this.transitionColor || this.lineColor, this.classText = this.primaryTextColor, this.fillType0 = this.primaryColor, this.fillType1 = this.secondaryColor, this.fillType2 = g(this.primaryColor, { h: 64 }), this.fillType3 = g(this.secondaryColor, { h: 64 }), this.fillType4 = g(this.primaryColor, { h: -64 }), this.fillType5 = g(this.secondaryColor, { h: -64 }), this.fillType6 = g(this.primaryColor, { h: 128 }), this.fillType7 = g(this.secondaryColor, { h: 128 }), this.pie1 = this.pie1 || this.primaryColor, this.pie2 = this.pie2 || this.secondaryColor, this.pie3 = this.pie3 || this.tertiaryColor, this.pie4 = this.pie4 || g(this.primaryColor, { l: -30 }), this.pie5 = this.pie5 || g(this.secondaryColor, { l: -30 }), this.pie6 = this.pie6 || g(this.tertiaryColor, { h: 40, l: -40 }), this.pie7 = this.pie7 || g(this.primaryColor, { h: 60, l: -10 }), this.pie8 = this.pie8 || g(this.primaryColor, { h: -60, l: -10 }), this.pie9 = this.pie9 || g(this.primaryColor, { h: 120, l: 0 }), this.pie10 = this.pie10 || g(this.primaryColor, { h: 60, l: -50 }), this.pie11 = this.pie11 || g(this.primaryColor, { h: -60, l: -50 }), this.pie12 = this.pie12 || g(this.primaryColor, { h: 120, l: -50 }), this.pieTitleTextSize = this.pieTitleTextSize || "25px", this.pieTitleTextColor = this.pieTitleTextColor || this.taskTextDarkColor, this.pieSectionTextSize = this.pieSectionTextSize || "17px", this.pieSectionTextColor = this.pieSectionTextColor || this.textColor, this.pieLegendTextSize = this.pieLegendTextSize || "17px", this.pieLegendTextColor = this.pieLegendTextColor || this.taskTextDarkColor, this.pieStrokeColor = this.pieStrokeColor || "black", this.pieStrokeWidth = this.pieStrokeWidth || "2px", this.pieOuterStrokeWidth = this.pieOuterStrokeWidth || "2px", this.pieOuterStrokeColor = this.pieOuterStrokeColor || "black", this.pieOpacity = this.pieOpacity || "0.7", this.quadrant1Fill = this.quadrant1Fill || this.primaryColor, this.quadrant2Fill = this.quadrant2Fill || g(this.primaryColor, { r: 5, g: 5, b: 5 }), this.quadrant3Fill = this.quadrant3Fill || g(this.primaryColor, { r: 10, g: 10, b: 10 }), this.quadrant4Fill = this.quadrant4Fill || g(this.primaryColor, { r: 15, g: 15, b: 15 }), this.quadrant1TextFill = this.quadrant1TextFill || this.primaryTextColor, this.quadrant2TextFill = this.quadrant2TextFill || g(this.primaryTextColor, { r: -5, g: -5, b: -5 }), this.quadrant3TextFill = this.quadrant3TextFill || g(this.primaryTextColor, { r: -10, g: -10, b: -10 }), this.quadrant4TextFill = this.quadrant4TextFill || g(this.primaryTextColor, { r: -15, g: -15, b: -15 }), this.quadrantPointFill = this.quadrantPointFill || mi(this.quadrant1Fill) ? F(this.quadrant1Fill) : E(this.quadrant1Fill), this.quadrantPointTextFill = this.quadrantPointTextFill || this.primaryTextColor, this.quadrantXAxisTextFill = this.quadrantXAxisTextFill || this.primaryTextColor, this.quadrantYAxisTextFill = this.quadrantYAxisTextFill || this.primaryTextColor, this.quadrantInternalBorderStrokeFill = this.quadrantInternalBorderStrokeFill || this.primaryBorderColor, this.quadrantExternalBorderStrokeFill = this.quadrantExternalBorderStrokeFill || this.primaryBorderColor, this.quadrantTitleFill = this.quadrantTitleFill || this.primaryTextColor, this.xyChart = { + backgroundColor: ((e = this.xyChart) == null ? void 0 : e.backgroundColor) || this.background, + titleColor: ((i = this.xyChart) == null ? void 0 : i.titleColor) || this.primaryTextColor, + xAxisTitleColor: ((r = this.xyChart) == null ? void 0 : r.xAxisTitleColor) || this.primaryTextColor, + xAxisLabelColor: ((n = this.xyChart) == null ? void 0 : n.xAxisLabelColor) || this.primaryTextColor, + xAxisTickColor: ((o = this.xyChart) == null ? void 0 : o.xAxisTickColor) || this.primaryTextColor, + xAxisLineColor: ((s = this.xyChart) == null ? void 0 : s.xAxisLineColor) || this.primaryTextColor, + yAxisTitleColor: ((a = this.xyChart) == null ? void 0 : a.yAxisTitleColor) || this.primaryTextColor, + yAxisLabelColor: ((l = this.xyChart) == null ? void 0 : l.yAxisLabelColor) || this.primaryTextColor, + yAxisTickColor: ((h = this.xyChart) == null ? void 0 : h.yAxisTickColor) || this.primaryTextColor, + yAxisLineColor: ((u = this.xyChart) == null ? void 0 : u.yAxisLineColor) || this.primaryTextColor, + plotColorPalette: ((f = this.xyChart) == null ? void 0 : f.plotColorPalette) || "#CDE498,#FF6B6B,#A0D2DB,#D7BDE2,#F0F0F0,#FFC3A0,#7FD8BE,#FF9A8B,#FAF3E0,#FFF176" + }, this.requirementBackground = this.requirementBackground || this.primaryColor, this.requirementBorderColor = this.requirementBorderColor || this.primaryBorderColor, this.requirementBorderSize = this.requirementBorderSize || "1", this.requirementTextColor = this.requirementTextColor || this.primaryTextColor, this.relationColor = this.relationColor || this.lineColor, this.relationLabelBackground = this.relationLabelBackground || this.edgeLabelBackground, this.relationLabelColor = this.relationLabelColor || this.actorTextColor, this.git0 = this.git0 || this.primaryColor, this.git1 = this.git1 || this.secondaryColor, this.git2 = this.git2 || this.tertiaryColor, this.git3 = this.git3 || g(this.primaryColor, { h: -30 }), this.git4 = this.git4 || g(this.primaryColor, { h: -60 }), this.git5 = this.git5 || g(this.primaryColor, { h: -90 }), this.git6 = this.git6 || g(this.primaryColor, { h: 60 }), this.git7 = this.git7 || g(this.primaryColor, { h: 120 }), this.darkMode ? (this.git0 = F(this.git0, 25), this.git1 = F(this.git1, 25), this.git2 = F(this.git2, 25), this.git3 = F(this.git3, 25), this.git4 = F(this.git4, 25), this.git5 = F(this.git5, 25), this.git6 = F(this.git6, 25), this.git7 = F(this.git7, 25)) : (this.git0 = E(this.git0, 25), this.git1 = E(this.git1, 25), this.git2 = E(this.git2, 25), this.git3 = E(this.git3, 25), this.git4 = E(this.git4, 25), this.git5 = E(this.git5, 25), this.git6 = E(this.git6, 25), this.git7 = E(this.git7, 25)), this.gitInv0 = this.gitInv0 || _(this.git0), this.gitInv1 = this.gitInv1 || _(this.git1), this.gitInv2 = this.gitInv2 || _(this.git2), this.gitInv3 = this.gitInv3 || _(this.git3), this.gitInv4 = this.gitInv4 || _(this.git4), this.gitInv5 = this.gitInv5 || _(this.git5), this.gitInv6 = this.gitInv6 || _(this.git6), this.gitInv7 = this.gitInv7 || _(this.git7), this.gitBranchLabel0 = this.gitBranchLabel0 || _(this.labelTextColor), this.gitBranchLabel1 = this.gitBranchLabel1 || this.labelTextColor, this.gitBranchLabel2 = this.gitBranchLabel2 || this.labelTextColor, this.gitBranchLabel3 = this.gitBranchLabel3 || _(this.labelTextColor), this.gitBranchLabel4 = this.gitBranchLabel4 || this.labelTextColor, this.gitBranchLabel5 = this.gitBranchLabel5 || this.labelTextColor, this.gitBranchLabel6 = this.gitBranchLabel6 || this.labelTextColor, this.gitBranchLabel7 = this.gitBranchLabel7 || this.labelTextColor, this.tagLabelColor = this.tagLabelColor || this.primaryTextColor, this.tagLabelBackground = this.tagLabelBackground || this.primaryColor, this.tagLabelBorder = this.tagBorder || this.primaryBorderColor, this.tagLabelFontSize = this.tagLabelFontSize || "10px", this.commitLabelColor = this.commitLabelColor || this.secondaryTextColor, this.commitLabelBackground = this.commitLabelBackground || this.secondaryColor, this.commitLabelFontSize = this.commitLabelFontSize || "10px", this.attributeBackgroundColorOdd = this.attributeBackgroundColorOdd || _r, this.attributeBackgroundColorEven = this.attributeBackgroundColorEven || Cr; + } + calculate(e) { + if (typeof e != "object") { + this.updateColors(); + return; + } + const i = Object.keys(e); + i.forEach((r) => { + this[r] = e[r]; + }), this.updateColors(), i.forEach((r) => { + this[r] = e[r]; + }); + } +}; +const dp = (t) => { + const e = new fp(); + return e.calculate(t), e; +}; +class pp { + constructor() { + this.primaryColor = "#eee", this.contrast = "#707070", this.secondaryColor = F(this.contrast, 55), this.background = "#ffffff", this.tertiaryColor = g(this.primaryColor, { h: -160 }), this.primaryBorderColor = ht(this.primaryColor, this.darkMode), this.secondaryBorderColor = ht(this.secondaryColor, this.darkMode), this.tertiaryBorderColor = ht(this.tertiaryColor, this.darkMode), this.primaryTextColor = _(this.primaryColor), this.secondaryTextColor = _(this.secondaryColor), this.tertiaryTextColor = _(this.tertiaryColor), this.lineColor = _(this.background), this.textColor = _(this.background), this.mainBkg = "#eee", this.secondBkg = "calculated", this.lineColor = "#666", this.border1 = "#999", this.border2 = "calculated", this.note = "#ffa", this.text = "#333", this.critical = "#d42", this.done = "#bbb", this.arrowheadColor = "#333333", this.fontFamily = '"trebuchet ms", verdana, arial, sans-serif', this.fontSize = "16px", this.THEME_COLOR_LIMIT = 12, this.nodeBkg = "calculated", this.nodeBorder = "calculated", this.clusterBkg = "calculated", this.clusterBorder = "calculated", this.defaultLinkColor = "calculated", this.titleColor = "calculated", this.edgeLabelBackground = "white", this.actorBorder = "calculated", this.actorBkg = "calculated", this.actorTextColor = "calculated", this.actorLineColor = "calculated", this.signalColor = "calculated", this.signalTextColor = "calculated", this.labelBoxBkgColor = "calculated", this.labelBoxBorderColor = "calculated", this.labelTextColor = "calculated", this.loopTextColor = "calculated", this.noteBorderColor = "calculated", this.noteBkgColor = "calculated", this.noteTextColor = "calculated", this.activationBorderColor = "#666", this.activationBkgColor = "#f4f4f4", this.sequenceNumberColor = "white", this.sectionBkgColor = "calculated", this.altSectionBkgColor = "white", this.sectionBkgColor2 = "calculated", this.excludeBkgColor = "#eeeeee", this.taskBorderColor = "calculated", this.taskBkgColor = "calculated", this.taskTextLightColor = "white", this.taskTextColor = "calculated", this.taskTextDarkColor = "calculated", this.taskTextOutsideColor = "calculated", this.taskTextClickableColor = "#003163", this.activeTaskBorderColor = "calculated", this.activeTaskBkgColor = "calculated", this.gridColor = "calculated", this.doneTaskBkgColor = "calculated", this.doneTaskBorderColor = "calculated", this.critBkgColor = "calculated", this.critBorderColor = "calculated", this.todayLineColor = "calculated", this.personBorder = this.primaryBorderColor, this.personBkg = this.mainBkg, this.labelColor = "black", this.errorBkgColor = "#552222", this.errorTextColor = "#552222"; + } + updateColors() { + var e, i, r, n, o, s, a, l, h, u, f; + this.secondBkg = F(this.contrast, 55), this.border2 = this.contrast, this.actorBorder = F(this.border1, 23), this.actorBkg = this.mainBkg, this.actorTextColor = this.text, this.actorLineColor = this.lineColor, this.signalColor = this.text, this.signalTextColor = this.text, this.labelBoxBkgColor = this.actorBkg, this.labelBoxBorderColor = this.actorBorder, this.labelTextColor = this.text, this.loopTextColor = this.text, this.noteBorderColor = "#999", this.noteBkgColor = "#666", this.noteTextColor = "#fff", this.cScale0 = this.cScale0 || "#555", this.cScale1 = this.cScale1 || "#F4F4F4", this.cScale2 = this.cScale2 || "#555", this.cScale3 = this.cScale3 || "#BBB", this.cScale4 = this.cScale4 || "#777", this.cScale5 = this.cScale5 || "#999", this.cScale6 = this.cScale6 || "#DDD", this.cScale7 = this.cScale7 || "#FFF", this.cScale8 = this.cScale8 || "#DDD", this.cScale9 = this.cScale9 || "#BBB", this.cScale10 = this.cScale10 || "#999", this.cScale11 = this.cScale11 || "#777"; + for (let c = 0; c < this.THEME_COLOR_LIMIT; c++) + this["cScaleInv" + c] = this["cScaleInv" + c] || _(this["cScale" + c]); + for (let c = 0; c < this.THEME_COLOR_LIMIT; c++) + this.darkMode ? this["cScalePeer" + c] = this["cScalePeer" + c] || F(this["cScale" + c], 10) : this["cScalePeer" + c] = this["cScalePeer" + c] || E(this["cScale" + c], 10); + this.scaleLabelColor = this.scaleLabelColor || (this.darkMode ? "black" : this.labelTextColor), this.cScaleLabel0 = this.cScaleLabel0 || this.cScale1, this.cScaleLabel2 = this.cScaleLabel2 || this.cScale1; + for (let c = 0; c < this.THEME_COLOR_LIMIT; c++) + this["cScaleLabel" + c] = this["cScaleLabel" + c] || this.scaleLabelColor; + for (let c = 0; c < 5; c++) + this["surface" + c] = this["surface" + c] || g(this.mainBkg, { l: -(5 + c * 5) }), this["surfacePeer" + c] = this["surfacePeer" + c] || g(this.mainBkg, { l: -(8 + c * 5) }); + this.nodeBkg = this.mainBkg, this.nodeBorder = this.border1, this.clusterBkg = this.secondBkg, this.clusterBorder = this.border2, this.defaultLinkColor = this.lineColor, this.titleColor = this.text, this.sectionBkgColor = F(this.contrast, 30), this.sectionBkgColor2 = F(this.contrast, 30), this.taskBorderColor = E(this.contrast, 10), this.taskBkgColor = this.contrast, this.taskTextColor = this.taskTextLightColor, this.taskTextDarkColor = this.text, this.taskTextOutsideColor = this.taskTextDarkColor, this.activeTaskBorderColor = this.taskBorderColor, this.activeTaskBkgColor = this.mainBkg, this.gridColor = F(this.border1, 30), this.doneTaskBkgColor = this.done, this.doneTaskBorderColor = this.lineColor, this.critBkgColor = this.critical, this.critBorderColor = E(this.critBkgColor, 10), this.todayLineColor = this.critBkgColor, this.transitionColor = this.transitionColor || "#000", this.transitionLabelColor = this.transitionLabelColor || this.textColor, this.stateLabelColor = this.stateLabelColor || this.stateBkg || this.primaryTextColor, this.stateBkg = this.stateBkg || this.mainBkg, this.labelBackgroundColor = this.labelBackgroundColor || this.stateBkg, this.compositeBackground = this.compositeBackground || this.background || this.tertiaryColor, this.altBackground = this.altBackground || "#f4f4f4", this.compositeTitleBackground = this.compositeTitleBackground || this.mainBkg, this.stateBorder = this.stateBorder || "#000", this.innerEndBackground = this.primaryBorderColor, this.specialStateColor = "#222", this.errorBkgColor = this.errorBkgColor || this.tertiaryColor, this.errorTextColor = this.errorTextColor || this.tertiaryTextColor, this.classText = this.primaryTextColor, this.fillType0 = this.primaryColor, this.fillType1 = this.secondaryColor, this.fillType2 = g(this.primaryColor, { h: 64 }), this.fillType3 = g(this.secondaryColor, { h: 64 }), this.fillType4 = g(this.primaryColor, { h: -64 }), this.fillType5 = g(this.secondaryColor, { h: -64 }), this.fillType6 = g(this.primaryColor, { h: 128 }), this.fillType7 = g(this.secondaryColor, { h: 128 }); + for (let c = 0; c < this.THEME_COLOR_LIMIT; c++) + this["pie" + c] = this["cScale" + c]; + this.pie12 = this.pie0, this.pieTitleTextSize = this.pieTitleTextSize || "25px", this.pieTitleTextColor = this.pieTitleTextColor || this.taskTextDarkColor, this.pieSectionTextSize = this.pieSectionTextSize || "17px", this.pieSectionTextColor = this.pieSectionTextColor || this.textColor, this.pieLegendTextSize = this.pieLegendTextSize || "17px", this.pieLegendTextColor = this.pieLegendTextColor || this.taskTextDarkColor, this.pieStrokeColor = this.pieStrokeColor || "black", this.pieStrokeWidth = this.pieStrokeWidth || "2px", this.pieOuterStrokeWidth = this.pieOuterStrokeWidth || "2px", this.pieOuterStrokeColor = this.pieOuterStrokeColor || "black", this.pieOpacity = this.pieOpacity || "0.7", this.quadrant1Fill = this.quadrant1Fill || this.primaryColor, this.quadrant2Fill = this.quadrant2Fill || g(this.primaryColor, { r: 5, g: 5, b: 5 }), this.quadrant3Fill = this.quadrant3Fill || g(this.primaryColor, { r: 10, g: 10, b: 10 }), this.quadrant4Fill = this.quadrant4Fill || g(this.primaryColor, { r: 15, g: 15, b: 15 }), this.quadrant1TextFill = this.quadrant1TextFill || this.primaryTextColor, this.quadrant2TextFill = this.quadrant2TextFill || g(this.primaryTextColor, { r: -5, g: -5, b: -5 }), this.quadrant3TextFill = this.quadrant3TextFill || g(this.primaryTextColor, { r: -10, g: -10, b: -10 }), this.quadrant4TextFill = this.quadrant4TextFill || g(this.primaryTextColor, { r: -15, g: -15, b: -15 }), this.quadrantPointFill = this.quadrantPointFill || mi(this.quadrant1Fill) ? F(this.quadrant1Fill) : E(this.quadrant1Fill), this.quadrantPointTextFill = this.quadrantPointTextFill || this.primaryTextColor, this.quadrantXAxisTextFill = this.quadrantXAxisTextFill || this.primaryTextColor, this.quadrantYAxisTextFill = this.quadrantYAxisTextFill || this.primaryTextColor, this.quadrantInternalBorderStrokeFill = this.quadrantInternalBorderStrokeFill || this.primaryBorderColor, this.quadrantExternalBorderStrokeFill = this.quadrantExternalBorderStrokeFill || this.primaryBorderColor, this.quadrantTitleFill = this.quadrantTitleFill || this.primaryTextColor, this.xyChart = { + backgroundColor: ((e = this.xyChart) == null ? void 0 : e.backgroundColor) || this.background, + titleColor: ((i = this.xyChart) == null ? void 0 : i.titleColor) || this.primaryTextColor, + xAxisTitleColor: ((r = this.xyChart) == null ? void 0 : r.xAxisTitleColor) || this.primaryTextColor, + xAxisLabelColor: ((n = this.xyChart) == null ? void 0 : n.xAxisLabelColor) || this.primaryTextColor, + xAxisTickColor: ((o = this.xyChart) == null ? void 0 : o.xAxisTickColor) || this.primaryTextColor, + xAxisLineColor: ((s = this.xyChart) == null ? void 0 : s.xAxisLineColor) || this.primaryTextColor, + yAxisTitleColor: ((a = this.xyChart) == null ? void 0 : a.yAxisTitleColor) || this.primaryTextColor, + yAxisLabelColor: ((l = this.xyChart) == null ? void 0 : l.yAxisLabelColor) || this.primaryTextColor, + yAxisTickColor: ((h = this.xyChart) == null ? void 0 : h.yAxisTickColor) || this.primaryTextColor, + yAxisLineColor: ((u = this.xyChart) == null ? void 0 : u.yAxisLineColor) || this.primaryTextColor, + plotColorPalette: ((f = this.xyChart) == null ? void 0 : f.plotColorPalette) || "#EEE,#6BB8E4,#8ACB88,#C7ACD6,#E8DCC2,#FFB2A8,#FFF380,#7E8D91,#FFD8B1,#FAF3E0" + }, this.requirementBackground = this.requirementBackground || this.primaryColor, this.requirementBorderColor = this.requirementBorderColor || this.primaryBorderColor, this.requirementBorderSize = this.requirementBorderSize || "1", this.requirementTextColor = this.requirementTextColor || this.primaryTextColor, this.relationColor = this.relationColor || this.lineColor, this.relationLabelBackground = this.relationLabelBackground || this.edgeLabelBackground, this.relationLabelColor = this.relationLabelColor || this.actorTextColor, this.git0 = E(this.pie1, 25) || this.primaryColor, this.git1 = this.pie2 || this.secondaryColor, this.git2 = this.pie3 || this.tertiaryColor, this.git3 = this.pie4 || g(this.primaryColor, { h: -30 }), this.git4 = this.pie5 || g(this.primaryColor, { h: -60 }), this.git5 = this.pie6 || g(this.primaryColor, { h: -90 }), this.git6 = this.pie7 || g(this.primaryColor, { h: 60 }), this.git7 = this.pie8 || g(this.primaryColor, { h: 120 }), this.gitInv0 = this.gitInv0 || _(this.git0), this.gitInv1 = this.gitInv1 || _(this.git1), this.gitInv2 = this.gitInv2 || _(this.git2), this.gitInv3 = this.gitInv3 || _(this.git3), this.gitInv4 = this.gitInv4 || _(this.git4), this.gitInv5 = this.gitInv5 || _(this.git5), this.gitInv6 = this.gitInv6 || _(this.git6), this.gitInv7 = this.gitInv7 || _(this.git7), this.branchLabelColor = this.branchLabelColor || this.labelTextColor, this.gitBranchLabel0 = this.branchLabelColor, this.gitBranchLabel1 = "white", this.gitBranchLabel2 = this.branchLabelColor, this.gitBranchLabel3 = "white", this.gitBranchLabel4 = this.branchLabelColor, this.gitBranchLabel5 = this.branchLabelColor, this.gitBranchLabel6 = this.branchLabelColor, this.gitBranchLabel7 = this.branchLabelColor, this.tagLabelColor = this.tagLabelColor || this.primaryTextColor, this.tagLabelBackground = this.tagLabelBackground || this.primaryColor, this.tagLabelBorder = this.tagBorder || this.primaryBorderColor, this.tagLabelFontSize = this.tagLabelFontSize || "10px", this.commitLabelColor = this.commitLabelColor || this.secondaryTextColor, this.commitLabelBackground = this.commitLabelBackground || this.secondaryColor, this.commitLabelFontSize = this.commitLabelFontSize || "10px", this.attributeBackgroundColorOdd = this.attributeBackgroundColorOdd || _r, this.attributeBackgroundColorEven = this.attributeBackgroundColorEven || Cr; + } + calculate(e) { + if (typeof e != "object") { + this.updateColors(); + return; + } + const i = Object.keys(e); + i.forEach((r) => { + this[r] = e[r]; + }), this.updateColors(), i.forEach((r) => { + this[r] = e[r]; + }); + } +} +const gp = (t) => { + const e = new pp(); + return e.calculate(t), e; +}, Gt = { + base: { + getThemeVariables: ap + }, + dark: { + getThemeVariables: hp + }, + default: { + getThemeVariables: up + }, + forest: { + getThemeVariables: dp + }, + neutral: { + getThemeVariables: gp + } +}, jt = { + flowchart: { + useMaxWidth: !0, + titleTopMargin: 25, + subGraphTitleMargin: { + top: 0, + bottom: 0 + }, + diagramPadding: 8, + htmlLabels: !0, + nodeSpacing: 50, + rankSpacing: 50, + curve: "basis", + padding: 15, + defaultRenderer: "dagre-wrapper", + wrappingWidth: 200 + }, + sequence: { + useMaxWidth: !0, + hideUnusedParticipants: !1, + activationWidth: 10, + diagramMarginX: 50, + diagramMarginY: 10, + actorMargin: 50, + width: 150, + height: 65, + boxMargin: 10, + boxTextMargin: 5, + noteMargin: 10, + messageMargin: 35, + messageAlign: "center", + mirrorActors: !0, + forceMenus: !1, + bottomMarginAdj: 1, + rightAngles: !1, + showSequenceNumbers: !1, + actorFontSize: 14, + actorFontFamily: '"Open Sans", sans-serif', + actorFontWeight: 400, + noteFontSize: 14, + noteFontFamily: '"trebuchet ms", verdana, arial, sans-serif', + noteFontWeight: 400, + noteAlign: "center", + messageFontSize: 16, + messageFontFamily: '"trebuchet ms", verdana, arial, sans-serif', + messageFontWeight: 400, + wrap: !1, + wrapPadding: 10, + labelBoxWidth: 50, + labelBoxHeight: 20 + }, + gantt: { + useMaxWidth: !0, + titleTopMargin: 25, + barHeight: 20, + barGap: 4, + topPadding: 50, + rightPadding: 75, + leftPadding: 75, + gridLineStartPadding: 35, + fontSize: 11, + sectionFontSize: 11, + numberSectionStyles: 4, + axisFormat: "%Y-%m-%d", + topAxis: !1, + displayMode: "", + weekday: "sunday" + }, + journey: { + useMaxWidth: !0, + diagramMarginX: 50, + diagramMarginY: 10, + leftMargin: 150, + width: 150, + height: 50, + boxMargin: 10, + boxTextMargin: 5, + noteMargin: 10, + messageMargin: 35, + messageAlign: "center", + bottomMarginAdj: 1, + rightAngles: !1, + taskFontSize: 14, + taskFontFamily: '"Open Sans", sans-serif', + taskMargin: 50, + activationWidth: 10, + textPlacement: "fo", + actorColours: [ + "#8FBC8F", + "#7CFC00", + "#00FFFF", + "#20B2AA", + "#B0E0E6", + "#FFFFE0" + ], + sectionFills: [ + "#191970", + "#8B008B", + "#4B0082", + "#2F4F4F", + "#800000", + "#8B4513", + "#00008B" + ], + sectionColours: [ + "#fff" + ] + }, + class: { + useMaxWidth: !0, + titleTopMargin: 25, + arrowMarkerAbsolute: !1, + dividerMargin: 10, + padding: 5, + textHeight: 10, + defaultRenderer: "dagre-wrapper", + htmlLabels: !1 + }, + state: { + useMaxWidth: !0, + titleTopMargin: 25, + dividerMargin: 10, + sizeUnit: 5, + padding: 8, + textHeight: 10, + titleShift: -15, + noteMargin: 10, + forkWidth: 70, + forkHeight: 7, + miniPadding: 2, + fontSizeFactor: 5.02, + fontSize: 24, + labelHeight: 16, + edgeLengthFactor: "20", + compositTitleSize: 35, + radius: 5, + defaultRenderer: "dagre-wrapper" + }, + er: { + useMaxWidth: !0, + titleTopMargin: 25, + diagramPadding: 20, + layoutDirection: "TB", + minEntityWidth: 100, + minEntityHeight: 75, + entityPadding: 15, + stroke: "gray", + fill: "honeydew", + fontSize: 12 + }, + pie: { + useMaxWidth: !0, + textPosition: 0.75 + }, + quadrantChart: { + useMaxWidth: !0, + chartWidth: 500, + chartHeight: 500, + titleFontSize: 20, + titlePadding: 10, + quadrantPadding: 5, + xAxisLabelPadding: 5, + yAxisLabelPadding: 5, + xAxisLabelFontSize: 16, + yAxisLabelFontSize: 16, + quadrantLabelFontSize: 16, + quadrantTextTopPadding: 5, + pointTextPadding: 5, + pointLabelFontSize: 12, + pointRadius: 5, + xAxisPosition: "top", + yAxisPosition: "left", + quadrantInternalBorderStrokeWidth: 1, + quadrantExternalBorderStrokeWidth: 2 + }, + xyChart: { + useMaxWidth: !0, + width: 700, + height: 500, + titleFontSize: 20, + titlePadding: 10, + showTitle: !0, + xAxis: { + $ref: "#/$defs/XYChartAxisConfig", + showLabel: !0, + labelFontSize: 14, + labelPadding: 5, + showTitle: !0, + titleFontSize: 16, + titlePadding: 5, + showTick: !0, + tickLength: 5, + tickWidth: 2, + showAxisLine: !0, + axisLineWidth: 2 + }, + yAxis: { + $ref: "#/$defs/XYChartAxisConfig", + showLabel: !0, + labelFontSize: 14, + labelPadding: 5, + showTitle: !0, + titleFontSize: 16, + titlePadding: 5, + showTick: !0, + tickLength: 5, + tickWidth: 2, + showAxisLine: !0, + axisLineWidth: 2 + }, + chartOrientation: "vertical", + plotReservedSpacePercent: 50 + }, + requirement: { + useMaxWidth: !0, + rect_fill: "#f9f9f9", + text_color: "#333", + rect_border_size: "0.5px", + rect_border_color: "#bbb", + rect_min_width: 200, + rect_min_height: 200, + fontSize: 14, + rect_padding: 10, + line_height: 20 + }, + mindmap: { + useMaxWidth: !0, + padding: 10, + maxNodeWidth: 200 + }, + timeline: { + useMaxWidth: !0, + diagramMarginX: 50, + diagramMarginY: 10, + leftMargin: 150, + width: 150, + height: 50, + boxMargin: 10, + boxTextMargin: 5, + noteMargin: 10, + messageMargin: 35, + messageAlign: "center", + bottomMarginAdj: 1, + rightAngles: !1, + taskFontSize: 14, + taskFontFamily: '"Open Sans", sans-serif', + taskMargin: 50, + activationWidth: 10, + textPlacement: "fo", + actorColours: [ + "#8FBC8F", + "#7CFC00", + "#00FFFF", + "#20B2AA", + "#B0E0E6", + "#FFFFE0" + ], + sectionFills: [ + "#191970", + "#8B008B", + "#4B0082", + "#2F4F4F", + "#800000", + "#8B4513", + "#00008B" + ], + sectionColours: [ + "#fff" + ], + disableMulticolor: !1 + }, + gitGraph: { + useMaxWidth: !0, + titleTopMargin: 25, + diagramPadding: 8, + nodeLabel: { + width: 75, + height: 100, + x: -25, + y: 0 + }, + mainBranchName: "main", + mainBranchOrder: 0, + showCommitLabel: !0, + showBranches: !0, + rotateCommitLabel: !0, + parallelCommits: !1, + arrowMarkerAbsolute: !1 + }, + c4: { + useMaxWidth: !0, + diagramMarginX: 50, + diagramMarginY: 10, + c4ShapeMargin: 50, + c4ShapePadding: 20, + width: 216, + height: 60, + boxMargin: 10, + c4ShapeInRow: 4, + nextLinePaddingX: 0, + c4BoundaryInRow: 2, + personFontSize: 14, + personFontFamily: '"Open Sans", sans-serif', + personFontWeight: "normal", + external_personFontSize: 14, + external_personFontFamily: '"Open Sans", sans-serif', + external_personFontWeight: "normal", + systemFontSize: 14, + systemFontFamily: '"Open Sans", sans-serif', + systemFontWeight: "normal", + external_systemFontSize: 14, + external_systemFontFamily: '"Open Sans", sans-serif', + external_systemFontWeight: "normal", + system_dbFontSize: 14, + system_dbFontFamily: '"Open Sans", sans-serif', + system_dbFontWeight: "normal", + external_system_dbFontSize: 14, + external_system_dbFontFamily: '"Open Sans", sans-serif', + external_system_dbFontWeight: "normal", + system_queueFontSize: 14, + system_queueFontFamily: '"Open Sans", sans-serif', + system_queueFontWeight: "normal", + external_system_queueFontSize: 14, + external_system_queueFontFamily: '"Open Sans", sans-serif', + external_system_queueFontWeight: "normal", + boundaryFontSize: 14, + boundaryFontFamily: '"Open Sans", sans-serif', + boundaryFontWeight: "normal", + messageFontSize: 12, + messageFontFamily: '"Open Sans", sans-serif', + messageFontWeight: "normal", + containerFontSize: 14, + containerFontFamily: '"Open Sans", sans-serif', + containerFontWeight: "normal", + external_containerFontSize: 14, + external_containerFontFamily: '"Open Sans", sans-serif', + external_containerFontWeight: "normal", + container_dbFontSize: 14, + container_dbFontFamily: '"Open Sans", sans-serif', + container_dbFontWeight: "normal", + external_container_dbFontSize: 14, + external_container_dbFontFamily: '"Open Sans", sans-serif', + external_container_dbFontWeight: "normal", + container_queueFontSize: 14, + container_queueFontFamily: '"Open Sans", sans-serif', + container_queueFontWeight: "normal", + external_container_queueFontSize: 14, + external_container_queueFontFamily: '"Open Sans", sans-serif', + external_container_queueFontWeight: "normal", + componentFontSize: 14, + componentFontFamily: '"Open Sans", sans-serif', + componentFontWeight: "normal", + external_componentFontSize: 14, + external_componentFontFamily: '"Open Sans", sans-serif', + external_componentFontWeight: "normal", + component_dbFontSize: 14, + component_dbFontFamily: '"Open Sans", sans-serif', + component_dbFontWeight: "normal", + external_component_dbFontSize: 14, + external_component_dbFontFamily: '"Open Sans", sans-serif', + external_component_dbFontWeight: "normal", + component_queueFontSize: 14, + component_queueFontFamily: '"Open Sans", sans-serif', + component_queueFontWeight: "normal", + external_component_queueFontSize: 14, + external_component_queueFontFamily: '"Open Sans", sans-serif', + external_component_queueFontWeight: "normal", + wrap: !0, + wrapPadding: 10, + person_bg_color: "#08427B", + person_border_color: "#073B6F", + external_person_bg_color: "#686868", + external_person_border_color: "#8A8A8A", + system_bg_color: "#1168BD", + system_border_color: "#3C7FC0", + system_db_bg_color: "#1168BD", + system_db_border_color: "#3C7FC0", + system_queue_bg_color: "#1168BD", + system_queue_border_color: "#3C7FC0", + external_system_bg_color: "#999999", + external_system_border_color: "#8A8A8A", + external_system_db_bg_color: "#999999", + external_system_db_border_color: "#8A8A8A", + external_system_queue_bg_color: "#999999", + external_system_queue_border_color: "#8A8A8A", + container_bg_color: "#438DD5", + container_border_color: "#3C7FC0", + container_db_bg_color: "#438DD5", + container_db_border_color: "#3C7FC0", + container_queue_bg_color: "#438DD5", + container_queue_border_color: "#3C7FC0", + external_container_bg_color: "#B3B3B3", + external_container_border_color: "#A6A6A6", + external_container_db_bg_color: "#B3B3B3", + external_container_db_border_color: "#A6A6A6", + external_container_queue_bg_color: "#B3B3B3", + external_container_queue_border_color: "#A6A6A6", + component_bg_color: "#85BBF0", + component_border_color: "#78A8D8", + component_db_bg_color: "#85BBF0", + component_db_border_color: "#78A8D8", + component_queue_bg_color: "#85BBF0", + component_queue_border_color: "#78A8D8", + external_component_bg_color: "#CCCCCC", + external_component_border_color: "#BFBFBF", + external_component_db_bg_color: "#CCCCCC", + external_component_db_border_color: "#BFBFBF", + external_component_queue_bg_color: "#CCCCCC", + external_component_queue_border_color: "#BFBFBF" + }, + sankey: { + useMaxWidth: !0, + width: 600, + height: 400, + linkColor: "gradient", + nodeAlignment: "justify", + showValues: !0, + prefix: "", + suffix: "" + }, + block: { + useMaxWidth: !0, + padding: 8 + }, + theme: "default", + maxTextSize: 5e4, + maxEdges: 500, + darkMode: !1, + fontFamily: '"trebuchet ms", verdana, arial, sans-serif;', + logLevel: 5, + securityLevel: "strict", + startOnLoad: !0, + arrowMarkerAbsolute: !1, + secure: [ + "secure", + "securityLevel", + "startOnLoad", + "maxTextSize", + "maxEdges" + ], + legacyMathML: !1, + deterministicIds: !1, + fontSize: 16 +}, Ia = { + ...jt, + // Set, even though they're `undefined` so that `configKeys` finds these keys + // TODO: Should we replace these with `null` so that they can go in the JSON Schema? + deterministicIDSeed: void 0, + themeCSS: void 0, + // add non-JSON default config values + themeVariables: Gt.default.getThemeVariables(), + sequence: { + ...jt.sequence, + messageFont: function() { + return { + fontFamily: this.messageFontFamily, + fontSize: this.messageFontSize, + fontWeight: this.messageFontWeight + }; + }, + noteFont: function() { + return { + fontFamily: this.noteFontFamily, + fontSize: this.noteFontSize, + fontWeight: this.noteFontWeight + }; + }, + actorFont: function() { + return { + fontFamily: this.actorFontFamily, + fontSize: this.actorFontSize, + fontWeight: this.actorFontWeight + }; + } + }, + gantt: { + ...jt.gantt, + tickInterval: void 0, + useWidth: void 0 + // can probably be removed since `configKeys` already includes this + }, + c4: { + ...jt.c4, + useWidth: void 0, + personFont: function() { + return { + fontFamily: this.personFontFamily, + fontSize: this.personFontSize, + fontWeight: this.personFontWeight + }; + }, + external_personFont: function() { + return { + fontFamily: this.external_personFontFamily, + fontSize: this.external_personFontSize, + fontWeight: this.external_personFontWeight + }; + }, + systemFont: function() { + return { + fontFamily: this.systemFontFamily, + fontSize: this.systemFontSize, + fontWeight: this.systemFontWeight + }; + }, + external_systemFont: function() { + return { + fontFamily: this.external_systemFontFamily, + fontSize: this.external_systemFontSize, + fontWeight: this.external_systemFontWeight + }; + }, + system_dbFont: function() { + return { + fontFamily: this.system_dbFontFamily, + fontSize: this.system_dbFontSize, + fontWeight: this.system_dbFontWeight + }; + }, + external_system_dbFont: function() { + return { + fontFamily: this.external_system_dbFontFamily, + fontSize: this.external_system_dbFontSize, + fontWeight: this.external_system_dbFontWeight + }; + }, + system_queueFont: function() { + return { + fontFamily: this.system_queueFontFamily, + fontSize: this.system_queueFontSize, + fontWeight: this.system_queueFontWeight + }; + }, + external_system_queueFont: function() { + return { + fontFamily: this.external_system_queueFontFamily, + fontSize: this.external_system_queueFontSize, + fontWeight: this.external_system_queueFontWeight + }; + }, + containerFont: function() { + return { + fontFamily: this.containerFontFamily, + fontSize: this.containerFontSize, + fontWeight: this.containerFontWeight + }; + }, + external_containerFont: function() { + return { + fontFamily: this.external_containerFontFamily, + fontSize: this.external_containerFontSize, + fontWeight: this.external_containerFontWeight + }; + }, + container_dbFont: function() { + return { + fontFamily: this.container_dbFontFamily, + fontSize: this.container_dbFontSize, + fontWeight: this.container_dbFontWeight + }; + }, + external_container_dbFont: function() { + return { + fontFamily: this.external_container_dbFontFamily, + fontSize: this.external_container_dbFontSize, + fontWeight: this.external_container_dbFontWeight + }; + }, + container_queueFont: function() { + return { + fontFamily: this.container_queueFontFamily, + fontSize: this.container_queueFontSize, + fontWeight: this.container_queueFontWeight + }; + }, + external_container_queueFont: function() { + return { + fontFamily: this.external_container_queueFontFamily, + fontSize: this.external_container_queueFontSize, + fontWeight: this.external_container_queueFontWeight + }; + }, + componentFont: function() { + return { + fontFamily: this.componentFontFamily, + fontSize: this.componentFontSize, + fontWeight: this.componentFontWeight + }; + }, + external_componentFont: function() { + return { + fontFamily: this.external_componentFontFamily, + fontSize: this.external_componentFontSize, + fontWeight: this.external_componentFontWeight + }; + }, + component_dbFont: function() { + return { + fontFamily: this.component_dbFontFamily, + fontSize: this.component_dbFontSize, + fontWeight: this.component_dbFontWeight + }; + }, + external_component_dbFont: function() { + return { + fontFamily: this.external_component_dbFontFamily, + fontSize: this.external_component_dbFontSize, + fontWeight: this.external_component_dbFontWeight + }; + }, + component_queueFont: function() { + return { + fontFamily: this.component_queueFontFamily, + fontSize: this.component_queueFontSize, + fontWeight: this.component_queueFontWeight + }; + }, + external_component_queueFont: function() { + return { + fontFamily: this.external_component_queueFontFamily, + fontSize: this.external_component_queueFontSize, + fontWeight: this.external_component_queueFontWeight + }; + }, + boundaryFont: function() { + return { + fontFamily: this.boundaryFontFamily, + fontSize: this.boundaryFontSize, + fontWeight: this.boundaryFontWeight + }; + }, + messageFont: function() { + return { + fontFamily: this.messageFontFamily, + fontSize: this.messageFontSize, + fontWeight: this.messageFontWeight + }; + } + }, + pie: { + ...jt.pie, + useWidth: 984 + }, + xyChart: { + ...jt.xyChart, + useWidth: void 0 + }, + requirement: { + ...jt.requirement, + useWidth: void 0 + }, + gitGraph: { + ...jt.gitGraph, + // TODO: This is a temporary override for `gitGraph`, since every other + // diagram does have `useMaxWidth`, but instead sets it to `true`. + // Should we set this to `true` instead? + useMaxWidth: !1 + }, + sankey: { + ...jt.sankey, + // this is false, unlike every other diagram (other than gitGraph) + // TODO: can we make this default to `true` instead? + useMaxWidth: !1 + } +}, Da = (t, e = "") => Object.keys(t).reduce((i, r) => Array.isArray(t[r]) ? i : typeof t[r] == "object" && t[r] !== null ? [...i, e + r, ...Da(t[r], "")] : [...i, e + r], []), mp = new Set(Da(Ia, "")), yp = Ia, Qi = (t) => { + if (L.debug("sanitizeDirective called with", t), !(typeof t != "object" || t == null)) { + if (Array.isArray(t)) { + t.forEach((e) => Qi(e)); + return; + } + for (const e of Object.keys(t)) { + if (L.debug("Checking key", e), e.startsWith("__") || e.includes("proto") || e.includes("constr") || !mp.has(e) || t[e] == null) { + L.debug("sanitize deleting key: ", e), delete t[e]; + continue; + } + if (typeof t[e] == "object") { + L.debug("sanitizing object", e), Qi(t[e]); + continue; + } + const i = ["themeCSS", "fontFamily", "altFontFamily"]; + for (const r of i) + e.includes(r) && (L.debug("sanitizing css option", e), t[e] = _p(t[e])); + } + if (t.themeVariables) + for (const e of Object.keys(t.themeVariables)) { + const i = t.themeVariables[e]; + i != null && i.match && !i.match(/^[\d "#%(),.;A-Za-z]+$/) && (t.themeVariables[e] = ""); + } + L.debug("After sanitization", t); + } +}, _p = (t) => { + let e = 0, i = 0; + for (const r of t) { + if (e < i) + return "{ /* ERROR: Unbalanced CSS */ }"; + r === "{" ? e++ : r === "}" && i++; + } + return e !== i ? "{ /* ERROR: Unbalanced CSS */ }" : t; +}, Na = /^-{3}\s*[\n\r](.*?)[\n\r]-{3}\s*[\n\r]+/s, Qe = /%{2}{\s*(?:(\w+)\s*:|(\w+))\s*(?:(\w+)|((?:(?!}%{2}).|\r?\n)*))?\s*(?:}%{2})?/gi, Cp = /\s*%%.*\n/gm; +class Ra extends Error { + constructor(e) { + super(e), this.name = "UnknownDiagramError"; + } +} +const Me = {}, xr = function(t, e) { + t = t.replace(Na, "").replace(Qe, "").replace(Cp, ` +`); + for (const [i, { detector: r }] of Object.entries(Me)) + if (r(t, e)) + return i; + throw new Ra( + `No diagram type detected matching given configuration for text: ${t}` + ); +}, Pa = (...t) => { + for (const { id: e, detector: i, loader: r } of t) + qa(e, i, r); +}, qa = (t, e, i) => { + Me[t] ? L.error(`Detector with key ${t} already exists`) : Me[t] = { detector: e, loader: i }, L.debug(`Detector with key ${t} added${i ? " with loader" : ""}`); +}, xp = (t) => Me[t].loader, cn = (t, e, { depth: i = 2, clobber: r = !1 } = {}) => { + const n = { depth: i, clobber: r }; + return Array.isArray(e) && !Array.isArray(t) ? (e.forEach((o) => cn(t, o, n)), t) : Array.isArray(e) && Array.isArray(t) ? (e.forEach((o) => { + t.includes(o) || t.push(o); + }), t) : t === void 0 || i <= 0 ? t != null && typeof t == "object" && typeof e == "object" ? Object.assign(t, e) : e : (e !== void 0 && typeof t == "object" && typeof e == "object" && Object.keys(e).forEach((o) => { + typeof e[o] == "object" && (t[o] === void 0 || typeof t[o] == "object") ? (t[o] === void 0 && (t[o] = Array.isArray(e[o]) ? [] : {}), t[o] = cn(t[o], e[o], { depth: i - 1, clobber: r })) : (r || typeof t[o] != "object" && typeof e[o] != "object") && (t[o] = e[o]); + }), t); +}, st = cn; +var bp = typeof global == "object" && global && global.Object === Object && global; +const za = bp; +var Tp = typeof self == "object" && self && self.Object === Object && self, kp = za || Tp || Function("return this")(); +const Dt = kp; +var Sp = Dt.Symbol; +const tr = Sp; +var Wa = Object.prototype, vp = Wa.hasOwnProperty, wp = Wa.toString, Ge = tr ? tr.toStringTag : void 0; +function Bp(t) { + var e = vp.call(t, Ge), i = t[Ge]; + try { + t[Ge] = void 0; + var r = !0; + } catch { + } + var n = wp.call(t); + return r && (e ? t[Ge] = i : delete t[Ge]), n; +} +var Fp = Object.prototype, Ap = Fp.toString; +function Lp(t) { + return Ap.call(t); +} +var Ep = "[object Null]", Mp = "[object Undefined]", es = tr ? tr.toStringTag : void 0; +function Ne(t) { + return t == null ? t === void 0 ? Mp : Ep : es && es in Object(t) ? Bp(t) : Lp(t); +} +function ye(t) { + var e = typeof t; + return t != null && (e == "object" || e == "function"); +} +var Op = "[object AsyncFunction]", $p = "[object Function]", Ip = "[object GeneratorFunction]", Dp = "[object Proxy]"; +function In(t) { + if (!ye(t)) + return !1; + var e = Ne(t); + return e == $p || e == Ip || e == Op || e == Dp; +} +var Np = Dt["__core-js_shared__"]; +const jr = Np; +var is = function() { + var t = /[^.]+$/.exec(jr && jr.keys && jr.keys.IE_PROTO || ""); + return t ? "Symbol(src)_1." + t : ""; +}(); +function Rp(t) { + return !!is && is in t; +} +var Pp = Function.prototype, qp = Pp.toString; +function _e(t) { + if (t != null) { + try { + return qp.call(t); + } catch { + } + try { + return t + ""; + } catch { + } + } + return ""; +} +var zp = /[\\^$.*+?()[\]{}|]/g, Wp = /^\[object .+?Constructor\]$/, Hp = Function.prototype, jp = Object.prototype, Up = Hp.toString, Yp = jp.hasOwnProperty, Gp = RegExp( + "^" + Up.call(Yp).replace(zp, "\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g, "$1.*?") + "$" +); +function Vp(t) { + if (!ye(t) || Rp(t)) + return !1; + var e = In(t) ? Gp : Wp; + return e.test(_e(t)); +} +function Xp(t, e) { + return t == null ? void 0 : t[e]; +} +function Ce(t, e) { + var i = Xp(t, e); + return Vp(i) ? i : void 0; +} +var Kp = Ce(Object, "create"); +const li = Kp; +function Zp() { + this.__data__ = li ? li(null) : {}, this.size = 0; +} +function Jp(t) { + var e = this.has(t) && delete this.__data__[t]; + return this.size -= e ? 1 : 0, e; +} +var Qp = "__lodash_hash_undefined__", tg = Object.prototype, eg = tg.hasOwnProperty; +function ig(t) { + var e = this.__data__; + if (li) { + var i = e[t]; + return i === Qp ? void 0 : i; + } + return eg.call(e, t) ? e[t] : void 0; +} +var rg = Object.prototype, ng = rg.hasOwnProperty; +function og(t) { + var e = this.__data__; + return li ? e[t] !== void 0 : ng.call(e, t); +} +var sg = "__lodash_hash_undefined__"; +function ag(t, e) { + var i = this.__data__; + return this.size += this.has(t) ? 0 : 1, i[t] = li && e === void 0 ? sg : e, this; +} +function ge(t) { + var e = -1, i = t == null ? 0 : t.length; + for (this.clear(); ++e < i; ) { + var r = t[e]; + this.set(r[0], r[1]); + } +} +ge.prototype.clear = Zp; +ge.prototype.delete = Jp; +ge.prototype.get = ig; +ge.prototype.has = og; +ge.prototype.set = ag; +function lg() { + this.__data__ = [], this.size = 0; +} +function br(t, e) { + return t === e || t !== t && e !== e; +} +function Tr(t, e) { + for (var i = t.length; i--; ) + if (br(t[i][0], e)) + return i; + return -1; +} +var hg = Array.prototype, cg = hg.splice; +function ug(t) { + var e = this.__data__, i = Tr(e, t); + if (i < 0) + return !1; + var r = e.length - 1; + return i == r ? e.pop() : cg.call(e, i, 1), --this.size, !0; +} +function fg(t) { + var e = this.__data__, i = Tr(e, t); + return i < 0 ? void 0 : e[i][1]; +} +function dg(t) { + return Tr(this.__data__, t) > -1; +} +function pg(t, e) { + var i = this.__data__, r = Tr(i, t); + return r < 0 ? (++this.size, i.push([t, e])) : i[r][1] = e, this; +} +function Xt(t) { + var e = -1, i = t == null ? 0 : t.length; + for (this.clear(); ++e < i; ) { + var r = t[e]; + this.set(r[0], r[1]); + } +} +Xt.prototype.clear = lg; +Xt.prototype.delete = ug; +Xt.prototype.get = fg; +Xt.prototype.has = dg; +Xt.prototype.set = pg; +var gg = Ce(Dt, "Map"); +const hi = gg; +function mg() { + this.size = 0, this.__data__ = { + hash: new ge(), + map: new (hi || Xt)(), + string: new ge() + }; +} +function yg(t) { + var e = typeof t; + return e == "string" || e == "number" || e == "symbol" || e == "boolean" ? t !== "__proto__" : t === null; +} +function kr(t, e) { + var i = t.__data__; + return yg(e) ? i[typeof e == "string" ? "string" : "hash"] : i.map; +} +function _g(t) { + var e = kr(this, t).delete(t); + return this.size -= e ? 1 : 0, e; +} +function Cg(t) { + return kr(this, t).get(t); +} +function xg(t) { + return kr(this, t).has(t); +} +function bg(t, e) { + var i = kr(this, t), r = i.size; + return i.set(t, e), this.size += i.size == r ? 0 : 1, this; +} +function ne(t) { + var e = -1, i = t == null ? 0 : t.length; + for (this.clear(); ++e < i; ) { + var r = t[e]; + this.set(r[0], r[1]); + } +} +ne.prototype.clear = mg; +ne.prototype.delete = _g; +ne.prototype.get = Cg; +ne.prototype.has = xg; +ne.prototype.set = bg; +var Tg = "Expected a function"; +function yi(t, e) { + if (typeof t != "function" || e != null && typeof e != "function") + throw new TypeError(Tg); + var i = function() { + var r = arguments, n = e ? e.apply(this, r) : r[0], o = i.cache; + if (o.has(n)) + return o.get(n); + var s = t.apply(this, r); + return i.cache = o.set(n, s) || o, s; + }; + return i.cache = new (yi.Cache || ne)(), i; +} +yi.Cache = ne; +function kg() { + this.__data__ = new Xt(), this.size = 0; +} +function Sg(t) { + var e = this.__data__, i = e.delete(t); + return this.size = e.size, i; +} +function vg(t) { + return this.__data__.get(t); +} +function wg(t) { + return this.__data__.has(t); +} +var Bg = 200; +function Fg(t, e) { + var i = this.__data__; + if (i instanceof Xt) { + var r = i.__data__; + if (!hi || r.length < Bg - 1) + return r.push([t, e]), this.size = ++i.size, this; + i = this.__data__ = new ne(r); + } + return i.set(t, e), this.size = i.size, this; +} +function Re(t) { + var e = this.__data__ = new Xt(t); + this.size = e.size; +} +Re.prototype.clear = kg; +Re.prototype.delete = Sg; +Re.prototype.get = vg; +Re.prototype.has = wg; +Re.prototype.set = Fg; +var Ag = function() { + try { + var t = Ce(Object, "defineProperty"); + return t({}, "", {}), t; + } catch { + } +}(); +const er = Ag; +function Dn(t, e, i) { + e == "__proto__" && er ? er(t, e, { + configurable: !0, + enumerable: !0, + value: i, + writable: !0 + }) : t[e] = i; +} +function un(t, e, i) { + (i !== void 0 && !br(t[e], i) || i === void 0 && !(e in t)) && Dn(t, e, i); +} +function Lg(t) { + return function(e, i, r) { + for (var n = -1, o = Object(e), s = r(e), a = s.length; a--; ) { + var l = s[t ? a : ++n]; + if (i(o[l], l, o) === !1) + break; + } + return e; + }; +} +var Eg = Lg(); +const Mg = Eg; +var Ha = typeof exports == "object" && exports && !exports.nodeType && exports, rs = Ha && typeof module == "object" && module && !module.nodeType && module, Og = rs && rs.exports === Ha, ns = Og ? Dt.Buffer : void 0, os = ns ? ns.allocUnsafe : void 0; +function $g(t, e) { + if (e) + return t.slice(); + var i = t.length, r = os ? os(i) : new t.constructor(i); + return t.copy(r), r; +} +var Ig = Dt.Uint8Array; +const ss = Ig; +function Dg(t) { + var e = new t.constructor(t.byteLength); + return new ss(e).set(new ss(t)), e; +} +function Ng(t, e) { + var i = e ? Dg(t.buffer) : t.buffer; + return new t.constructor(i, t.byteOffset, t.length); +} +function Rg(t, e) { + var i = -1, r = t.length; + for (e || (e = Array(r)); ++i < r; ) + e[i] = t[i]; + return e; +} +var as = Object.create, Pg = function() { + function t() { + } + return function(e) { + if (!ye(e)) + return {}; + if (as) + return as(e); + t.prototype = e; + var i = new t(); + return t.prototype = void 0, i; + }; +}(); +const qg = Pg; +function ja(t, e) { + return function(i) { + return t(e(i)); + }; +} +var zg = ja(Object.getPrototypeOf, Object); +const Ua = zg; +var Wg = Object.prototype; +function Sr(t) { + var e = t && t.constructor, i = typeof e == "function" && e.prototype || Wg; + return t === i; +} +function Hg(t) { + return typeof t.constructor == "function" && !Sr(t) ? qg(Ua(t)) : {}; +} +function _i(t) { + return t != null && typeof t == "object"; +} +var jg = "[object Arguments]"; +function ls(t) { + return _i(t) && Ne(t) == jg; +} +var Ya = Object.prototype, Ug = Ya.hasOwnProperty, Yg = Ya.propertyIsEnumerable, Gg = ls(function() { + return arguments; +}()) ? ls : function(t) { + return _i(t) && Ug.call(t, "callee") && !Yg.call(t, "callee"); +}; +const ir = Gg; +var Vg = Array.isArray; +const rr = Vg; +var Xg = 9007199254740991; +function Ga(t) { + return typeof t == "number" && t > -1 && t % 1 == 0 && t <= Xg; +} +function vr(t) { + return t != null && Ga(t.length) && !In(t); +} +function Kg(t) { + return _i(t) && vr(t); +} +function Zg() { + return !1; +} +var Va = typeof exports == "object" && exports && !exports.nodeType && exports, hs = Va && typeof module == "object" && module && !module.nodeType && module, Jg = hs && hs.exports === Va, cs = Jg ? Dt.Buffer : void 0, Qg = cs ? cs.isBuffer : void 0, tm = Qg || Zg; +const Nn = tm; +var em = "[object Object]", im = Function.prototype, rm = Object.prototype, Xa = im.toString, nm = rm.hasOwnProperty, om = Xa.call(Object); +function sm(t) { + if (!_i(t) || Ne(t) != em) + return !1; + var e = Ua(t); + if (e === null) + return !0; + var i = nm.call(e, "constructor") && e.constructor; + return typeof i == "function" && i instanceof i && Xa.call(i) == om; +} +var am = "[object Arguments]", lm = "[object Array]", hm = "[object Boolean]", cm = "[object Date]", um = "[object Error]", fm = "[object Function]", dm = "[object Map]", pm = "[object Number]", gm = "[object Object]", mm = "[object RegExp]", ym = "[object Set]", _m = "[object String]", Cm = "[object WeakMap]", xm = "[object ArrayBuffer]", bm = "[object DataView]", Tm = "[object Float32Array]", km = "[object Float64Array]", Sm = "[object Int8Array]", vm = "[object Int16Array]", wm = "[object Int32Array]", Bm = "[object Uint8Array]", Fm = "[object Uint8ClampedArray]", Am = "[object Uint16Array]", Lm = "[object Uint32Array]", U = {}; +U[Tm] = U[km] = U[Sm] = U[vm] = U[wm] = U[Bm] = U[Fm] = U[Am] = U[Lm] = !0; +U[am] = U[lm] = U[xm] = U[hm] = U[bm] = U[cm] = U[um] = U[fm] = U[dm] = U[pm] = U[gm] = U[mm] = U[ym] = U[_m] = U[Cm] = !1; +function Em(t) { + return _i(t) && Ga(t.length) && !!U[Ne(t)]; +} +function Mm(t) { + return function(e) { + return t(e); + }; +} +var Ka = typeof exports == "object" && exports && !exports.nodeType && exports, ti = Ka && typeof module == "object" && module && !module.nodeType && module, Om = ti && ti.exports === Ka, Ur = Om && za.process, $m = function() { + try { + var t = ti && ti.require && ti.require("util").types; + return t || Ur && Ur.binding && Ur.binding("util"); + } catch { + } +}(); +const us = $m; +var fs = us && us.isTypedArray, Im = fs ? Mm(fs) : Em; +const Rn = Im; +function fn(t, e) { + if (!(e === "constructor" && typeof t[e] == "function") && e != "__proto__") + return t[e]; +} +var Dm = Object.prototype, Nm = Dm.hasOwnProperty; +function Rm(t, e, i) { + var r = t[e]; + (!(Nm.call(t, e) && br(r, i)) || i === void 0 && !(e in t)) && Dn(t, e, i); +} +function Pm(t, e, i, r) { + var n = !i; + i || (i = {}); + for (var o = -1, s = e.length; ++o < s; ) { + var a = e[o], l = r ? r(i[a], t[a], a, i, t) : void 0; + l === void 0 && (l = t[a]), n ? Dn(i, a, l) : Rm(i, a, l); + } + return i; +} +function qm(t, e) { + for (var i = -1, r = Array(t); ++i < t; ) + r[i] = e(i); + return r; +} +var zm = 9007199254740991, Wm = /^(?:0|[1-9]\d*)$/; +function Za(t, e) { + var i = typeof t; + return e = e ?? zm, !!e && (i == "number" || i != "symbol" && Wm.test(t)) && t > -1 && t % 1 == 0 && t < e; +} +var Hm = Object.prototype, jm = Hm.hasOwnProperty; +function Um(t, e) { + var i = rr(t), r = !i && ir(t), n = !i && !r && Nn(t), o = !i && !r && !n && Rn(t), s = i || r || n || o, a = s ? qm(t.length, String) : [], l = a.length; + for (var h in t) + (e || jm.call(t, h)) && !(s && // Safari 9 has enumerable `arguments.length` in strict mode. + (h == "length" || // Node.js 0.10 has enumerable non-index properties on buffers. + n && (h == "offset" || h == "parent") || // PhantomJS 2 has enumerable non-index properties on typed arrays. + o && (h == "buffer" || h == "byteLength" || h == "byteOffset") || // Skip index properties. + Za(h, l))) && a.push(h); + return a; +} +function Ym(t) { + var e = []; + if (t != null) + for (var i in Object(t)) + e.push(i); + return e; +} +var Gm = Object.prototype, Vm = Gm.hasOwnProperty; +function Xm(t) { + if (!ye(t)) + return Ym(t); + var e = Sr(t), i = []; + for (var r in t) + r == "constructor" && (e || !Vm.call(t, r)) || i.push(r); + return i; +} +function Ja(t) { + return vr(t) ? Um(t, !0) : Xm(t); +} +function Km(t) { + return Pm(t, Ja(t)); +} +function Zm(t, e, i, r, n, o, s) { + var a = fn(t, i), l = fn(e, i), h = s.get(l); + if (h) { + un(t, i, h); + return; + } + var u = o ? o(a, l, i + "", t, e, s) : void 0, f = u === void 0; + if (f) { + var c = rr(l), d = !c && Nn(l), m = !c && !d && Rn(l); + u = l, c || d || m ? rr(a) ? u = a : Kg(a) ? u = Rg(a) : d ? (f = !1, u = $g(l, !0)) : m ? (f = !1, u = Ng(l, !0)) : u = [] : sm(l) || ir(l) ? (u = a, ir(a) ? u = Km(a) : (!ye(a) || In(a)) && (u = Hg(l))) : f = !1; + } + f && (s.set(l, u), n(u, l, r, o, s), s.delete(l)), un(t, i, u); +} +function Qa(t, e, i, r, n) { + t !== e && Mg(e, function(o, s) { + if (n || (n = new Re()), ye(o)) + Zm(t, e, s, i, Qa, r, n); + else { + var a = r ? r(fn(t, s), o, s + "", t, e, n) : void 0; + a === void 0 && (a = o), un(t, s, a); + } + }, Ja); +} +function tl(t) { + return t; +} +function Jm(t, e, i) { + switch (i.length) { + case 0: + return t.call(e); + case 1: + return t.call(e, i[0]); + case 2: + return t.call(e, i[0], i[1]); + case 3: + return t.call(e, i[0], i[1], i[2]); + } + return t.apply(e, i); +} +var ds = Math.max; +function Qm(t, e, i) { + return e = ds(e === void 0 ? t.length - 1 : e, 0), function() { + for (var r = arguments, n = -1, o = ds(r.length - e, 0), s = Array(o); ++n < o; ) + s[n] = r[e + n]; + n = -1; + for (var a = Array(e + 1); ++n < e; ) + a[n] = r[n]; + return a[e] = i(s), Jm(t, this, a); + }; +} +function t0(t) { + return function() { + return t; + }; +} +var e0 = er ? function(t, e) { + return er(t, "toString", { + configurable: !0, + enumerable: !1, + value: t0(e), + writable: !0 + }); +} : tl; +const i0 = e0; +var r0 = 800, n0 = 16, o0 = Date.now; +function s0(t) { + var e = 0, i = 0; + return function() { + var r = o0(), n = n0 - (r - i); + if (i = r, n > 0) { + if (++e >= r0) + return arguments[0]; + } else + e = 0; + return t.apply(void 0, arguments); + }; +} +var a0 = s0(i0); +const l0 = a0; +function h0(t, e) { + return l0(Qm(t, e, tl), t + ""); +} +function c0(t, e, i) { + if (!ye(i)) + return !1; + var r = typeof e; + return (r == "number" ? vr(i) && Za(e, i.length) : r == "string" && e in i) ? br(i[e], t) : !1; +} +function u0(t) { + return h0(function(e, i) { + var r = -1, n = i.length, o = n > 1 ? i[n - 1] : void 0, s = n > 2 ? i[2] : void 0; + for (o = t.length > 3 && typeof o == "function" ? (n--, o) : void 0, s && c0(i[0], i[1], s) && (o = n < 3 ? void 0 : o, n = 1), e = Object(e); ++r < n; ) { + var a = i[r]; + a && t(e, a, r, o); + } + return e; + }); +} +var f0 = u0(function(t, e, i) { + Qa(t, e, i); +}); +const d0 = f0, p0 = "​", g0 = { + curveBasis: Pf, + curveBasisClosed: qf, + curveBasisOpen: zf, + curveBumpX: Nf, + curveBumpY: Rf, + curveBundle: Wf, + curveCardinalClosed: jf, + curveCardinalOpen: Uf, + curveCardinal: Hf, + curveCatmullRomClosed: Gf, + curveCatmullRomOpen: Vf, + curveCatmullRom: Yf, + curveLinear: Df, + curveLinearClosed: Xf, + curveMonotoneX: Kf, + curveMonotoneY: Zf, + curveNatural: Jf, + curveStep: Qf, + curveStepAfter: ed, + curveStepBefore: td +}, m0 = /\s*(?:(\w+)(?=:):|(\w+))\s*(?:(\w+)|((?:(?!}%{2}).|\r?\n)*))?\s*(?:}%{2})?/gi, y0 = function(t, e) { + const i = el(t, /(?:init\b)|(?:initialize\b)/); + let r = {}; + if (Array.isArray(i)) { + const s = i.map((a) => a.args); + Qi(s), r = st(r, [...s]); + } else + r = i.args; + if (!r) + return; + let n = xr(t, e); + const o = "config"; + return r[o] !== void 0 && (n === "flowchart-v2" && (n = "flowchart"), r[n] = r[o], delete r[o]), r; +}, el = function(t, e = null) { + try { + const i = new RegExp( + `[%]{2}(?![{]${m0.source})(?=[}][%]{2}).* +`, + "ig" + ); + t = t.trim().replace(i, "").replace(/'/gm, '"'), L.debug( + `Detecting diagram directive${e !== null ? " type:" + e : ""} based on the text:${t}` + ); + let r; + const n = []; + for (; (r = Qe.exec(t)) !== null; ) + if (r.index === Qe.lastIndex && Qe.lastIndex++, r && !e || e && r[1] && r[1].match(e) || e && r[2] && r[2].match(e)) { + const o = r[1] ? r[1] : r[2], s = r[3] ? r[3].trim() : r[4] ? JSON.parse(r[4].trim()) : null; + n.push({ type: o, args: s }); + } + return n.length === 0 ? { type: t, args: null } : n.length === 1 ? n[0] : n; + } catch (i) { + return L.error( + `ERROR: ${i.message} - Unable to parse directive type: '${e}' based on the text: '${t}'` + ), { type: void 0, args: null }; + } +}, _0 = function(t) { + return t.replace(Qe, ""); +}, C0 = function(t, e) { + for (const [i, r] of e.entries()) + if (r.match(t)) + return i; + return -1; +}; +function x0(t, e) { + if (!t) + return e; + const i = `curve${t.charAt(0).toUpperCase() + t.slice(1)}`; + return g0[i] ?? e; +} +function b0(t, e) { + const i = t.trim(); + if (i) + return e.securityLevel !== "loose" ? Rs.sanitizeUrl(i) : i; +} +const T0 = (t, ...e) => { + const i = t.split("."), r = i.length - 1, n = i[r]; + let o = window; + for (let s = 0; s < r; s++) + if (o = o[i[s]], !o) { + L.error(`Function name: ${t} not found in window`); + return; + } + o[n](...e); +}; +function il(t, e) { + return !t || !e ? 0 : Math.sqrt(Math.pow(e.x - t.x, 2) + Math.pow(e.y - t.y, 2)); +} +function k0(t) { + let e, i = 0; + t.forEach((n) => { + i += il(n, e), e = n; + }); + const r = i / 2; + return Pn(t, r); +} +function S0(t) { + return t.length === 1 ? t[0] : k0(t); +} +const ps = (t, e = 2) => { + const i = Math.pow(10, e); + return Math.round(t * i) / i; +}, Pn = (t, e) => { + let i, r = e; + for (const n of t) { + if (i) { + const o = il(n, i); + if (o < r) + r -= o; + else { + const s = r / o; + if (s <= 0) + return i; + if (s >= 1) + return { x: n.x, y: n.y }; + if (s > 0 && s < 1) + return { + x: ps((1 - s) * i.x + s * n.x, 5), + y: ps((1 - s) * i.y + s * n.y, 5) + }; + } + } + i = n; + } + throw new Error("Could not find a suitable point for the given distance"); +}, v0 = (t, e, i) => { + L.info(`our points ${JSON.stringify(e)}`), e[0] !== i && (e = e.reverse()); + const n = Pn(e, 25), o = t ? 10 : 5, s = Math.atan2(e[0].y - n.y, e[0].x - n.x), a = { x: 0, y: 0 }; + return a.x = Math.sin(s) * o + (e[0].x + n.x) / 2, a.y = -Math.cos(s) * o + (e[0].y + n.y) / 2, a; +}; +function w0(t, e, i) { + const r = structuredClone(i); + L.info("our points", r), e !== "start_left" && e !== "start_right" && r.reverse(); + const n = 25 + t, o = Pn(r, n), s = 10 + t * 0.5, a = Math.atan2(r[0].y - o.y, r[0].x - o.x), l = { x: 0, y: 0 }; + return e === "start_left" ? (l.x = Math.sin(a + Math.PI) * s + (r[0].x + o.x) / 2, l.y = -Math.cos(a + Math.PI) * s + (r[0].y + o.y) / 2) : e === "end_right" ? (l.x = Math.sin(a - Math.PI) * s + (r[0].x + o.x) / 2 - 5, l.y = -Math.cos(a - Math.PI) * s + (r[0].y + o.y) / 2 - 5) : e === "end_left" ? (l.x = Math.sin(a) * s + (r[0].x + o.x) / 2 - 5, l.y = -Math.cos(a) * s + (r[0].y + o.y) / 2 - 5) : (l.x = Math.sin(a) * s + (r[0].x + o.x) / 2, l.y = -Math.cos(a) * s + (r[0].y + o.y) / 2), l; +} +function B0(t) { + let e = "", i = ""; + for (const r of t) + r !== void 0 && (r.startsWith("color:") || r.startsWith("text-align:") ? i = i + r + ";" : e = e + r + ";"); + return { style: e, labelStyle: i }; +} +let gs = 0; +const F0 = () => (gs++, "id-" + Math.random().toString(36).substr(2, 12) + "-" + gs); +function A0(t) { + let e = ""; + const i = "0123456789abcdef", r = i.length; + for (let n = 0; n < t; n++) + e += i.charAt(Math.floor(Math.random() * r)); + return e; +} +const L0 = (t) => A0(t.length), E0 = function() { + return { + x: 0, + y: 0, + fill: void 0, + anchor: "start", + style: "#666", + width: 100, + height: 100, + textMargin: 0, + rx: 0, + ry: 0, + valign: void 0, + text: "" + }; +}, M0 = function(t, e) { + const i = e.text.replace($n.lineBreakRegex, " "), [, r] = zn(e.fontSize), n = t.append("text"); + n.attr("x", e.x), n.attr("y", e.y), n.style("text-anchor", e.anchor), n.style("font-family", e.fontFamily), n.style("font-size", r), n.style("font-weight", e.fontWeight), n.attr("fill", e.fill), e.class !== void 0 && n.attr("class", e.class); + const o = n.append("tspan"); + return o.attr("x", e.x + e.textMargin * 2), o.attr("fill", e.fill), o.text(i), n; +}, O0 = yi( + (t, e, i) => { + if (!t || (i = Object.assign( + { fontSize: 12, fontWeight: 400, fontFamily: "Arial", joinWith: "
    " }, + i + ), $n.lineBreakRegex.test(t))) + return t; + const r = t.split(" "), n = []; + let o = ""; + return r.forEach((s, a) => { + const l = nr(`${s} `, i), h = nr(o, i); + if (l > e) { + const { hyphenatedStrings: c, remainingWord: d } = $0(s, e, "-", i); + n.push(o, ...c), o = d; + } else + h + l >= e ? (n.push(o), o = s) : o = [o, s].filter(Boolean).join(" "); + a + 1 === r.length && n.push(o); + }), n.filter((s) => s !== "").join(i.joinWith); + }, + (t, e, i) => `${t}${e}${i.fontSize}${i.fontWeight}${i.fontFamily}${i.joinWith}` +), $0 = yi( + (t, e, i = "-", r) => { + r = Object.assign( + { fontSize: 12, fontWeight: 400, fontFamily: "Arial", margin: 0 }, + r + ); + const n = [...t], o = []; + let s = ""; + return n.forEach((a, l) => { + const h = `${s}${a}`; + if (nr(h, r) >= e) { + const f = l + 1, c = n.length === f, d = `${h}${i}`; + o.push(c ? h : d), s = ""; + } else + s = h; + }), { hyphenatedStrings: o, remainingWord: s }; + }, + (t, e, i = "-", r) => `${t}${e}${i}${r.fontSize}${r.fontWeight}${r.fontFamily}` +); +function I0(t, e) { + return qn(t, e).height; +} +function nr(t, e) { + return qn(t, e).width; +} +const qn = yi( + (t, e) => { + const { fontSize: i = 12, fontFamily: r = "Arial", fontWeight: n = 400 } = e; + if (!t) + return { width: 0, height: 0 }; + const [, o] = zn(i), s = ["sans-serif", r], a = t.split($n.lineBreakRegex), l = [], h = bt("body"); + if (!h.remove) + return { width: 0, height: 0, lineHeight: 0 }; + const u = h.append("svg"); + for (const c of s) { + let d = 0; + const m = { width: 0, height: 0, lineHeight: 0 }; + for (const S of a) { + const O = E0(); + O.text = S || p0; + const z = M0(u, O).style("font-size", o).style("font-weight", n).style("font-family", c), T = (z._groups || z)[0][0].getBBox(); + if (T.width === 0 && T.height === 0) + throw new Error("svg element not in render tree"); + m.width = Math.round(Math.max(m.width, T.width)), d = Math.round(T.height), m.height += d, m.lineHeight = Math.round(Math.max(m.lineHeight, d)); + } + l.push(m); + } + u.remove(); + const f = isNaN(l[1].height) || isNaN(l[1].width) || isNaN(l[1].lineHeight) || l[0].height > l[1].height && l[0].width > l[1].width && l[0].lineHeight > l[1].lineHeight ? 0 : 1; + return l[f]; + }, + (t, e) => `${t}${e.fontSize}${e.fontWeight}${e.fontFamily}` +); +class D0 { + constructor(e = !1, i) { + this.count = 0, this.count = i ? i.length : 0, this.next = e ? () => this.count++ : () => Date.now(); + } +} +let Ei; +const N0 = function(t) { + return Ei = Ei || document.createElement("div"), t = escape(t).replace(/%26/g, "&").replace(/%23/g, "#").replace(/%3B/g, ";"), Ei.innerHTML = t, unescape(Ei.textContent); +}; +function rl(t) { + return "str" in t; +} +const R0 = (t, e, i, r) => { + var o; + if (!r) + return; + const n = (o = t.node()) == null ? void 0 : o.getBBox(); + n && t.append("text").text(r).attr("x", n.x + n.width / 2).attr("y", -i).attr("class", e); +}, zn = (t) => { + if (typeof t == "number") + return [t, t + "px"]; + const e = parseInt(t ?? "", 10); + return Number.isNaN(e) ? [void 0, void 0] : t === String(e) ? [e, t + "px"] : [e, t]; +}; +function nl(t, e) { + return d0({}, t, e); +} +const ei = { + assignWithDepth: st, + wrapLabel: O0, + calculateTextHeight: I0, + calculateTextWidth: nr, + calculateTextDimensions: qn, + cleanAndMerge: nl, + detectInit: y0, + detectDirective: el, + isSubstringInArray: C0, + interpolateToCurve: x0, + calcLabelPosition: S0, + calcCardinalityPosition: v0, + calcTerminalLabelPosition: w0, + formatUrl: b0, + getStylesFromArray: B0, + generateId: F0, + random: L0, + runFunc: T0, + entityDecode: N0, + insertTitle: R0, + parseFontSize: zn, + InitIDGenerator: D0 +}, P0 = function(t) { + let e = t; + return e = e.replace(/style.*:\S*#.*;/g, function(i) { + return i.substring(0, i.length - 1); + }), e = e.replace(/classDef.*:\S*#.*;/g, function(i) { + return i.substring(0, i.length - 1); + }), e = e.replace(/#\w+;/g, function(i) { + const r = i.substring(1, i.length - 1); + return /^\+?\d+$/.test(r) ? "fl°°" + r + "¶ß" : "fl°" + r + "¶ß"; + }), e; +}, q0 = function(t) { + return t.replace(/fl°°/g, "&#").replace(/fl°/g, "&").replace(/¶ß/g, ";"); +}; +var ol = "comm", sl = "rule", al = "decl", z0 = "@import", W0 = "@keyframes", H0 = "@layer", ll = Math.abs, Wn = String.fromCharCode; +function hl(t) { + return t.trim(); +} +function qi(t, e, i) { + return t.replace(e, i); +} +function j0(t, e, i) { + return t.indexOf(e, i); +} +function ci(t, e) { + return t.charCodeAt(e) | 0; +} +function ui(t, e, i) { + return t.slice(e, i); +} +function Ut(t) { + return t.length; +} +function U0(t) { + return t.length; +} +function Mi(t, e) { + return e.push(t), t; +} +var wr = 1, Oe = 1, cl = 0, kt = 0, J = 0, Pe = ""; +function Hn(t, e, i, r, n, o, s, a) { + return { value: t, root: e, parent: i, type: r, props: n, children: o, line: wr, column: Oe, length: s, return: "", siblings: a }; +} +function Y0() { + return J; +} +function G0() { + return J = kt > 0 ? ci(Pe, --kt) : 0, Oe--, J === 10 && (Oe = 1, wr--), J; +} +function Bt() { + return J = kt < cl ? ci(Pe, kt++) : 0, Oe++, J === 10 && (Oe = 1, wr++), J; +} +function fe() { + return ci(Pe, kt); +} +function zi() { + return kt; +} +function Br(t, e) { + return ui(Pe, t, e); +} +function dn(t) { + switch (t) { + case 0: + case 9: + case 10: + case 13: + case 32: + return 5; + case 33: + case 43: + case 44: + case 47: + case 62: + case 64: + case 126: + case 59: + case 123: + case 125: + return 4; + case 58: + return 3; + case 34: + case 39: + case 40: + case 91: + return 2; + case 41: + case 93: + return 1; + } + return 0; +} +function V0(t) { + return wr = Oe = 1, cl = Ut(Pe = t), kt = 0, []; +} +function X0(t) { + return Pe = "", t; +} +function Yr(t) { + return hl(Br(kt - 1, pn(t === 91 ? t + 2 : t === 40 ? t + 1 : t))); +} +function K0(t) { + for (; (J = fe()) && J < 33; ) + Bt(); + return dn(t) > 2 || dn(J) > 3 ? "" : " "; +} +function Z0(t, e) { + for (; --e && Bt() && !(J < 48 || J > 102 || J > 57 && J < 65 || J > 70 && J < 97); ) + ; + return Br(t, zi() + (e < 6 && fe() == 32 && Bt() == 32)); +} +function pn(t) { + for (; Bt(); ) + switch (J) { + case t: + return kt; + case 34: + case 39: + t !== 34 && t !== 39 && pn(J); + break; + case 40: + t === 41 && pn(t); + break; + case 92: + Bt(); + break; + } + return kt; +} +function J0(t, e) { + for (; Bt() && t + J !== 47 + 10; ) + if (t + J === 42 + 42 && fe() === 47) + break; + return "/*" + Br(e, kt - 1) + "*" + Wn(t === 47 ? t : Bt()); +} +function Q0(t) { + for (; !dn(fe()); ) + Bt(); + return Br(t, kt); +} +function ty(t) { + return X0(Wi("", null, null, null, [""], t = V0(t), 0, [0], t)); +} +function Wi(t, e, i, r, n, o, s, a, l) { + for (var h = 0, u = 0, f = s, c = 0, d = 0, m = 0, S = 1, O = 1, z = 1, T = 0, R = "", X = n, G = o, V = r, H = R; O; ) + switch (m = T, T = Bt()) { + case 40: + if (m != 108 && ci(H, f - 1) == 58) { + j0(H += qi(Yr(T), "&", "&\f"), "&\f", ll(h ? a[h - 1] : 0)) != -1 && (z = -1); + break; + } + case 34: + case 39: + case 91: + H += Yr(T); + break; + case 9: + case 10: + case 13: + case 32: + H += K0(m); + break; + case 92: + H += Z0(zi() - 1, 7); + continue; + case 47: + switch (fe()) { + case 42: + case 47: + Mi(ey(J0(Bt(), zi()), e, i, l), l); + break; + default: + H += "/"; + } + break; + case 123 * S: + a[h++] = Ut(H) * z; + case 125 * S: + case 59: + case 0: + switch (T) { + case 0: + case 125: + O = 0; + case 59 + u: + z == -1 && (H = qi(H, /\f/g, "")), d > 0 && Ut(H) - f && Mi(d > 32 ? ys(H + ";", r, i, f - 1, l) : ys(qi(H, " ", "") + ";", r, i, f - 2, l), l); + break; + case 59: + H += ";"; + default: + if (Mi(V = ms(H, e, i, h, u, n, a, R, X = [], G = [], f, o), o), T === 123) + if (u === 0) + Wi(H, e, V, V, X, o, f, a, G); + else + switch (c === 99 && ci(H, 3) === 110 ? 100 : c) { + case 100: + case 108: + case 109: + case 115: + Wi(t, V, V, r && Mi(ms(t, V, V, 0, 0, n, a, R, n, X = [], f, G), G), n, G, f, a, r ? X : G); + break; + default: + Wi(H, V, V, V, [""], G, 0, a, G); + } + } + h = u = d = 0, S = z = 1, R = H = "", f = s; + break; + case 58: + f = 1 + Ut(H), d = m; + default: + if (S < 1) { + if (T == 123) + --S; + else if (T == 125 && S++ == 0 && G0() == 125) + continue; + } + switch (H += Wn(T), T * S) { + case 38: + z = u > 0 ? 1 : (H += "\f", -1); + break; + case 44: + a[h++] = (Ut(H) - 1) * z, z = 1; + break; + case 64: + fe() === 45 && (H += Yr(Bt())), c = fe(), u = f = Ut(R = H += Q0(zi())), T++; + break; + case 45: + m === 45 && Ut(H) == 2 && (S = 0); + } + } + return o; +} +function ms(t, e, i, r, n, o, s, a, l, h, u, f) { + for (var c = n - 1, d = n === 0 ? o : [""], m = U0(d), S = 0, O = 0, z = 0; S < r; ++S) + for (var T = 0, R = ui(t, c + 1, c = ll(O = s[S])), X = t; T < m; ++T) + (X = hl(O > 0 ? d[T] + " " + R : qi(R, /&\f/g, d[T]))) && (l[z++] = X); + return Hn(t, e, i, n === 0 ? sl : a, l, h, u, f); +} +function ey(t, e, i, r) { + return Hn(t, e, i, ol, Wn(Y0()), ui(t, 2, -2), 0, r); +} +function ys(t, e, i, r, n) { + return Hn(t, e, i, al, ui(t, 0, r), ui(t, r + 1, -1), r, n); +} +function gn(t, e) { + for (var i = "", r = 0; r < t.length; r++) + i += e(t[r], r, t, e) || ""; + return i; +} +function iy(t, e, i, r) { + switch (t.type) { + case H0: + if (t.children.length) + break; + case z0: + case al: + return t.return = t.return || t.value; + case ol: + return ""; + case W0: + return t.return = t.value + "{" + gn(t.children, r) + "}"; + case sl: + if (!Ut(t.value = t.props.join(","))) + return ""; + } + return Ut(i = gn(t.children, r)) ? t.return = t.value + "{" + i + "}" : ""; +} +const _s = "10.9.1", $e = Object.freeze(yp); +let dt = st({}, $e), ul, Ie = [], ii = st({}, $e); +const Fr = (t, e) => { + let i = st({}, t), r = {}; + for (const n of e) + pl(n), r = st(r, n); + if (i = st(i, r), r.theme && r.theme in Gt) { + const n = st({}, ul), o = st( + n.themeVariables || {}, + r.themeVariables + ); + i.theme && i.theme in Gt && (i.themeVariables = Gt[i.theme].getThemeVariables(o)); + } + return ii = i, gl(ii), ii; +}, ry = (t) => (dt = st({}, $e), dt = st(dt, t), t.theme && Gt[t.theme] && (dt.themeVariables = Gt[t.theme].getThemeVariables(t.themeVariables)), Fr(dt, Ie), dt), ny = (t) => { + ul = st({}, t); +}, oy = (t) => (dt = st(dt, t), Fr(dt, Ie), dt), fl = () => st({}, dt), dl = (t) => (gl(t), st(ii, t), $t()), $t = () => st({}, ii), pl = (t) => { + t && (["secure", ...dt.secure ?? []].forEach((e) => { + Object.hasOwn(t, e) && (L.debug(`Denied attempt to modify a secure key ${e}`, t[e]), delete t[e]); + }), Object.keys(t).forEach((e) => { + e.startsWith("__") && delete t[e]; + }), Object.keys(t).forEach((e) => { + typeof t[e] == "string" && (t[e].includes("<") || t[e].includes(">") || t[e].includes("url(data:")) && delete t[e], typeof t[e] == "object" && pl(t[e]); + })); +}, sy = (t) => { + Qi(t), t.fontFamily && (!t.themeVariables || !t.themeVariables.fontFamily) && (t.themeVariables = { fontFamily: t.fontFamily }), Ie.push(t), Fr(dt, Ie); +}, or = (t = dt) => { + Ie = [], Fr(t, Ie); +}, ay = { + LAZY_LOAD_DEPRECATED: "The configuration options lazyLoadedDiagrams and loadExternalDiagramsAtStartup are deprecated. Please use registerExternalDiagrams instead." +}, Cs = {}, ly = (t) => { + Cs[t] || (L.warn(ay[t]), Cs[t] = !0); +}, gl = (t) => { + t && (t.lazyLoadedDiagrams || t.loadExternalDiagramsAtStartup) && ly("LAZY_LOAD_DEPRECATED"); +}, ml = "c4", hy = (t) => /^\s*C4Context|C4Container|C4Component|C4Dynamic|C4Deployment/.test(t), cy = async () => { + const { diagram: t } = await import("./c4Diagram-1e775db3.js"); + return { id: ml, diagram: t }; +}, uy = { + id: ml, + detector: hy, + loader: cy +}, fy = uy, yl = "flowchart", dy = (t, e) => { + var i, r; + return ((i = e == null ? void 0 : e.flowchart) == null ? void 0 : i.defaultRenderer) === "dagre-wrapper" || ((r = e == null ? void 0 : e.flowchart) == null ? void 0 : r.defaultRenderer) === "elk" ? !1 : /^\s*graph/.test(t); +}, py = async () => { + const { diagram: t } = await import("./flowDiagram-aadb13b0.js"); + return { id: yl, diagram: t }; +}, gy = { + id: yl, + detector: dy, + loader: py +}, my = gy, _l = "flowchart-v2", yy = (t, e) => { + var i, r, n; + return ((i = e == null ? void 0 : e.flowchart) == null ? void 0 : i.defaultRenderer) === "dagre-d3" || ((r = e == null ? void 0 : e.flowchart) == null ? void 0 : r.defaultRenderer) === "elk" ? !1 : /^\s*graph/.test(t) && ((n = e == null ? void 0 : e.flowchart) == null ? void 0 : n.defaultRenderer) === "dagre-wrapper" ? !0 : /^\s*flowchart/.test(t); +}, _y = async () => { + const { diagram: t } = await import("./flowDiagram-v2-f2119625.js"); + return { id: _l, diagram: t }; +}, Cy = { + id: _l, + detector: yy, + loader: _y +}, xy = Cy, Cl = "er", by = (t) => /^\s*erDiagram/.test(t), Ty = async () => { + const { diagram: t } = await import("./erDiagram-c7ff1bec.js"); + return { id: Cl, diagram: t }; +}, ky = { + id: Cl, + detector: by, + loader: Ty +}, Sy = ky, xl = "gitGraph", vy = (t) => /^\s*gitGraph/.test(t), wy = async () => { + const { diagram: t } = await import("./gitGraphDiagram-c3a0619c.js"); + return { id: xl, diagram: t }; +}, By = { + id: xl, + detector: vy, + loader: wy +}, Fy = By, bl = "gantt", Ay = (t) => /^\s*gantt/.test(t), Ly = async () => { + const { diagram: t } = await import("./ganttDiagram-3c2fde2b.js"); + return { id: bl, diagram: t }; +}, Ey = { + id: bl, + detector: Ay, + loader: Ly +}, My = Ey, Tl = "info", Oy = (t) => /^\s*info/.test(t), $y = async () => { + const { diagram: t } = await import("./infoDiagram-2f5c50c0.js"); + return { id: Tl, diagram: t }; +}, Iy = { + id: Tl, + detector: Oy, + loader: $y +}, kl = "pie", Dy = (t) => /^\s*pie/.test(t), Ny = async () => { + const { diagram: t } = await import("./pieDiagram-828dae43.js"); + return { id: kl, diagram: t }; +}, Ry = { + id: kl, + detector: Dy, + loader: Ny +}, Sl = "quadrantChart", Py = (t) => /^\s*quadrantChart/.test(t), qy = async () => { + const { diagram: t } = await import("./quadrantDiagram-5fa00455.js"); + return { id: Sl, diagram: t }; +}, zy = { + id: Sl, + detector: Py, + loader: qy +}, Wy = zy, vl = "xychart", Hy = (t) => /^\s*xychart-beta/.test(t), jy = async () => { + const { diagram: t } = await import("./xychartDiagram-e5e6b652.js"); + return { id: vl, diagram: t }; +}, Uy = { + id: vl, + detector: Hy, + loader: jy +}, Yy = Uy, wl = "requirement", Gy = (t) => /^\s*requirement(Diagram)?/.test(t), Vy = async () => { + const { diagram: t } = await import("./requirementDiagram-03163dc4.js"); + return { id: wl, diagram: t }; +}, Xy = { + id: wl, + detector: Gy, + loader: Vy +}, Ky = Xy, Bl = "sequence", Zy = (t) => /^\s*sequenceDiagram/.test(t), Jy = async () => { + const { diagram: t } = await import("./sequenceDiagram-b517d154.js"); + return { id: Bl, diagram: t }; +}, Qy = { + id: Bl, + detector: Zy, + loader: Jy +}, t_ = Qy, Fl = "class", e_ = (t, e) => { + var i; + return ((i = e == null ? void 0 : e.class) == null ? void 0 : i.defaultRenderer) === "dagre-wrapper" ? !1 : /^\s*classDiagram/.test(t); +}, i_ = async () => { + const { diagram: t } = await import("./classDiagram-f52caa06.js"); + return { id: Fl, diagram: t }; +}, r_ = { + id: Fl, + detector: e_, + loader: i_ +}, n_ = r_, Al = "classDiagram", o_ = (t, e) => { + var i; + return /^\s*classDiagram/.test(t) && ((i = e == null ? void 0 : e.class) == null ? void 0 : i.defaultRenderer) === "dagre-wrapper" ? !0 : /^\s*classDiagram-v2/.test(t); +}, s_ = async () => { + const { diagram: t } = await import("./classDiagram-v2-640c694e.js"); + return { id: Al, diagram: t }; +}, a_ = { + id: Al, + detector: o_, + loader: s_ +}, l_ = a_, Ll = "state", h_ = (t, e) => { + var i; + return ((i = e == null ? void 0 : e.state) == null ? void 0 : i.defaultRenderer) === "dagre-wrapper" ? !1 : /^\s*stateDiagram/.test(t); +}, c_ = async () => { + const { diagram: t } = await import("./stateDiagram-fca82b5b.js"); + return { id: Ll, diagram: t }; +}, u_ = { + id: Ll, + detector: h_, + loader: c_ +}, f_ = u_, El = "stateDiagram", d_ = (t, e) => { + var i; + return !!(/^\s*stateDiagram-v2/.test(t) || /^\s*stateDiagram/.test(t) && ((i = e == null ? void 0 : e.state) == null ? void 0 : i.defaultRenderer) === "dagre-wrapper"); +}, p_ = async () => { + const { diagram: t } = await import("./stateDiagram-v2-ed04200a.js"); + return { id: El, diagram: t }; +}, g_ = { + id: El, + detector: d_, + loader: p_ +}, m_ = g_, Ml = "journey", y_ = (t) => /^\s*journey/.test(t), __ = async () => { + const { diagram: t } = await import("./journeyDiagram-14fe341a.js"); + return { id: Ml, diagram: t }; +}, C_ = { + id: Ml, + detector: y_, + loader: __ +}, x_ = C_, b_ = function(t, e) { + for (let i of e) + t.attr(i[0], i[1]); +}, T_ = function(t, e, i) { + let r = /* @__PURE__ */ new Map(); + return i ? (r.set("width", "100%"), r.set("style", `max-width: ${e}px;`)) : (r.set("height", t), r.set("width", e)), r; +}, Ol = function(t, e, i, r) { + const n = T_(e, i, r); + b_(t, n); +}, k_ = function(t, e, i, r) { + const n = e.node().getBBox(), o = n.width, s = n.height; + L.info(`SVG bounds: ${o}x${s}`, n); + let a = 0, l = 0; + L.info(`Graph bounds: ${a}x${l}`, t), a = o + i * 2, l = s + i * 2, L.info(`Calculated bounds: ${a}x${l}`), Ol(e, l, a, r); + const h = `${n.x - i} ${n.y - i} ${n.width + 2 * i} ${n.height + 2 * i}`; + e.attr("viewBox", h); +}, Hi = {}, S_ = (t, e, i) => { + let r = ""; + return t in Hi && Hi[t] ? r = Hi[t](i) : L.warn(`No theme found for ${t}`), ` & { + font-family: ${i.fontFamily}; + font-size: ${i.fontSize}; + fill: ${i.textColor} + } + + /* Classes common for multiple diagrams */ + + & .error-icon { + fill: ${i.errorBkgColor}; + } + & .error-text { + fill: ${i.errorTextColor}; + stroke: ${i.errorTextColor}; + } + + & .edge-thickness-normal { + stroke-width: 2px; + } + & .edge-thickness-thick { + stroke-width: 3.5px + } + & .edge-pattern-solid { + stroke-dasharray: 0; + } + + & .edge-pattern-dashed{ + stroke-dasharray: 3; + } + .edge-pattern-dotted { + stroke-dasharray: 2; + } + + & .marker { + fill: ${i.lineColor}; + stroke: ${i.lineColor}; + } + & .marker.cross { + stroke: ${i.lineColor}; + } + + & svg { + font-family: ${i.fontFamily}; + font-size: ${i.fontSize}; + } + + ${r} + + ${e} +`; +}, v_ = (t, e) => { + e !== void 0 && (Hi[t] = e); +}, w_ = S_; +let jn = "", Un = "", Yn = ""; +const Gn = (t) => ai(t, $t()), B_ = () => { + jn = "", Yn = "", Un = ""; +}, F_ = (t) => { + jn = Gn(t).replace(/^\s+/g, ""); +}, A_ = () => jn, L_ = (t) => { + Yn = Gn(t).replace(/\n\s+/g, ` +`); +}, E_ = () => Yn, M_ = (t) => { + Un = Gn(t); +}, O_ = () => Un, $_ = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + clear: B_, + getAccDescription: E_, + getAccTitle: A_, + getDiagramTitle: O_, + setAccDescription: L_, + setAccTitle: F_, + setDiagramTitle: M_ +}, Symbol.toStringTag, { value: "Module" })), I_ = L, D_ = bn, Vn = $t, v1 = dl, w1 = $e, N_ = (t) => ai(t, Vn()), R_ = k_, P_ = () => $_, sr = {}, ar = (t, e, i) => { + var r; + if (sr[t]) + throw new Error(`Diagram ${t} already registered.`); + sr[t] = e, i && qa(t, i), v_(t, e.styles), (r = e.injectUtils) == null || r.call( + e, + I_, + D_, + Vn, + N_, + R_, + P_(), + () => { + } + ); +}, Xn = (t) => { + if (t in sr) + return sr[t]; + throw new q_(t); +}; +class q_ extends Error { + constructor(e) { + super(`Diagram ${e} not found.`); + } +} +const z_ = (t) => { + var n; + const { securityLevel: e } = Vn(); + let i = bt("body"); + if (e === "sandbox") { + const s = ((n = bt(`#i${t}`).node()) == null ? void 0 : n.contentDocument) ?? document; + i = bt(s.body); + } + return i.select(`#${t}`); +}, W_ = (t, e, i) => { + L.debug(`rendering svg for syntax error +`); + const r = z_(e), n = r.append("g"); + r.attr("viewBox", "0 0 2412 512"), Ol(r, 100, 512, !0), n.append("path").attr("class", "error-icon").attr( + "d", + "m411.313,123.313c6.25-6.25 6.25-16.375 0-22.625s-16.375-6.25-22.625,0l-32,32-9.375,9.375-20.688-20.688c-12.484-12.5-32.766-12.5-45.25,0l-16,16c-1.261,1.261-2.304,2.648-3.31,4.051-21.739-8.561-45.324-13.426-70.065-13.426-105.867,0-192,86.133-192,192s86.133,192 192,192 192-86.133 192-192c0-24.741-4.864-48.327-13.426-70.065 1.402-1.007 2.79-2.049 4.051-3.31l16-16c12.5-12.492 12.5-32.758 0-45.25l-20.688-20.688 9.375-9.375 32.001-31.999zm-219.313,100.687c-52.938,0-96,43.063-96,96 0,8.836-7.164,16-16,16s-16-7.164-16-16c0-70.578 57.422-128 128-128 8.836,0 16,7.164 16,16s-7.164,16-16,16z" + ), n.append("path").attr("class", "error-icon").attr( + "d", + "m459.02,148.98c-6.25-6.25-16.375-6.25-22.625,0s-6.25,16.375 0,22.625l16,16c3.125,3.125 7.219,4.688 11.313,4.688 4.094,0 8.188-1.563 11.313-4.688 6.25-6.25 6.25-16.375 0-22.625l-16.001-16z" + ), n.append("path").attr("class", "error-icon").attr( + "d", + "m340.395,75.605c3.125,3.125 7.219,4.688 11.313,4.688 4.094,0 8.188-1.563 11.313-4.688 6.25-6.25 6.25-16.375 0-22.625l-16-16c-6.25-6.25-16.375-6.25-22.625,0s-6.25,16.375 0,22.625l15.999,16z" + ), n.append("path").attr("class", "error-icon").attr( + "d", + "m400,64c8.844,0 16-7.164 16-16v-32c0-8.836-7.156-16-16-16-8.844,0-16,7.164-16,16v32c0,8.836 7.156,16 16,16z" + ), n.append("path").attr("class", "error-icon").attr( + "d", + "m496,96.586h-32c-8.844,0-16,7.164-16,16 0,8.836 7.156,16 16,16h32c8.844,0 16-7.164 16-16 0-8.836-7.156-16-16-16z" + ), n.append("path").attr("class", "error-icon").attr( + "d", + "m436.98,75.605c3.125,3.125 7.219,4.688 11.313,4.688 4.094,0 8.188-1.563 11.313-4.688l32-32c6.25-6.25 6.25-16.375 0-22.625s-16.375-6.25-22.625,0l-32,32c-6.251,6.25-6.251,16.375-0.001,22.625z" + ), n.append("text").attr("class", "error-text").attr("x", 1440).attr("y", 250).attr("font-size", "150px").style("text-anchor", "middle").text("Syntax error in text"), n.append("text").attr("class", "error-text").attr("x", 1250).attr("y", 400).attr("font-size", "100px").style("text-anchor", "middle").text(`mermaid version ${i}`); +}, $l = { draw: W_ }, H_ = $l, j_ = { + db: {}, + renderer: $l, + parser: { + parser: { yy: {} }, + parse: () => { + } + } +}, U_ = j_, Il = "flowchart-elk", Y_ = (t, e) => { + var i; + return ( + // If diagram explicitly states flowchart-elk + !!(/^\s*flowchart-elk/.test(t) || // If a flowchart/graph diagram has their default renderer set to elk + /^\s*flowchart|graph/.test(t) && ((i = e == null ? void 0 : e.flowchart) == null ? void 0 : i.defaultRenderer) === "elk") + ); +}, G_ = async () => { + const { diagram: t } = await import("./flowchart-elk-definition-cf813a97.js"); + return { id: Il, diagram: t }; +}, V_ = { + id: Il, + detector: Y_, + loader: G_ +}, X_ = V_, Dl = "timeline", K_ = (t) => /^\s*timeline/.test(t), Z_ = async () => { + const { diagram: t } = await import("./timeline-definition-4ee9bff4.js"); + return { id: Dl, diagram: t }; +}, J_ = { + id: Dl, + detector: K_, + loader: Z_ +}, Q_ = J_, Nl = "mindmap", tC = (t) => /^\s*mindmap/.test(t), eC = async () => { + const { diagram: t } = await import("./mindmap-definition-9399c7e6.js"); + return { id: Nl, diagram: t }; +}, iC = { + id: Nl, + detector: tC, + loader: eC +}, rC = iC, Rl = "sankey", nC = (t) => /^\s*sankey-beta/.test(t), oC = async () => { + const { diagram: t } = await import("./sankeyDiagram-52ec8976.js"); + return { id: Rl, diagram: t }; +}, sC = { + id: Rl, + detector: nC, + loader: oC +}, aC = sC, Pl = "block", lC = (t) => /^\s*block-beta/.test(t), hC = async () => { + const { diagram: t } = await import("./blockDiagram-5dc23a45.js"); + return { id: Pl, diagram: t }; +}, cC = { + id: Pl, + detector: lC, + loader: hC +}, uC = cC; +let xs = !1; +const Kn = () => { + xs || (xs = !0, ar("error", U_, (t) => t.toLowerCase().trim() === "error"), ar( + "---", + // --- diagram type may appear if YAML front-matter is not parsed correctly + { + db: { + clear: () => { + } + }, + styles: {}, + // should never be used + renderer: { + draw: () => { + } + }, + parser: { + parser: { yy: {} }, + parse: () => { + throw new Error( + "Diagrams beginning with --- are not valid. If you were trying to use a YAML front-matter, please ensure that you've correctly opened and closed the YAML front-matter with un-indented `---` blocks" + ); + } + }, + init: () => null + // no op + }, + (t) => t.toLowerCase().trimStart().startsWith("---") + ), Pa( + fy, + l_, + n_, + Sy, + My, + Iy, + Ry, + Ky, + t_, + X_, + xy, + my, + rC, + Q_, + Fy, + m_, + f_, + x_, + Wy, + aC, + Yy, + uC + )); +}; +class ql { + constructor(e, i = {}) { + this.text = e, this.metadata = i, this.type = "graph", this.text = P0(e), this.text += ` +`; + const r = $t(); + try { + this.type = xr(e, r); + } catch (o) { + this.type = "error", this.detectError = o; + } + const n = Xn(this.type); + L.debug("Type " + this.type), this.db = n.db, this.renderer = n.renderer, this.parser = n.parser, this.parser.parser.yy = this.db, this.init = n.init, this.parse(); + } + parse() { + var i, r, n, o, s; + if (this.detectError) + throw this.detectError; + (r = (i = this.db).clear) == null || r.call(i); + const e = $t(); + (n = this.init) == null || n.call(this, e), this.metadata.title && ((s = (o = this.db).setDiagramTitle) == null || s.call(o, this.metadata.title)), this.parser.parse(this.text); + } + async render(e, i) { + await this.renderer.draw(this.text, e, i, this); + } + getParser() { + return this.parser; + } + getType() { + return this.type; + } +} +const fC = async (t, e = {}) => { + const i = xr(t, $t()); + try { + Xn(i); + } catch { + const n = xp(i); + if (!n) + throw new Ra(`Diagram ${i} not found.`); + const { id: o, diagram: s } = await n(); + ar(o, s); + } + return new ql(t, e); +}; +let bs = []; +const dC = () => { + bs.forEach((t) => { + t(); + }), bs = []; +}; +var pC = ja(Object.keys, Object); +const gC = pC; +var mC = Object.prototype, yC = mC.hasOwnProperty; +function _C(t) { + if (!Sr(t)) + return gC(t); + var e = []; + for (var i in Object(t)) + yC.call(t, i) && i != "constructor" && e.push(i); + return e; +} +var CC = Ce(Dt, "DataView"); +const mn = CC; +var xC = Ce(Dt, "Promise"); +const yn = xC; +var bC = Ce(Dt, "Set"); +const _n = bC; +var TC = Ce(Dt, "WeakMap"); +const Cn = TC; +var Ts = "[object Map]", kC = "[object Object]", ks = "[object Promise]", Ss = "[object Set]", vs = "[object WeakMap]", ws = "[object DataView]", SC = _e(mn), vC = _e(hi), wC = _e(yn), BC = _e(_n), FC = _e(Cn), he = Ne; +(mn && he(new mn(new ArrayBuffer(1))) != ws || hi && he(new hi()) != Ts || yn && he(yn.resolve()) != ks || _n && he(new _n()) != Ss || Cn && he(new Cn()) != vs) && (he = function(t) { + var e = Ne(t), i = e == kC ? t.constructor : void 0, r = i ? _e(i) : ""; + if (r) + switch (r) { + case SC: + return ws; + case vC: + return Ts; + case wC: + return ks; + case BC: + return Ss; + case FC: + return vs; + } + return e; +}); +const AC = he; +var LC = "[object Map]", EC = "[object Set]", MC = Object.prototype, OC = MC.hasOwnProperty; +function Gr(t) { + if (t == null) + return !0; + if (vr(t) && (rr(t) || typeof t == "string" || typeof t.splice == "function" || Nn(t) || Rn(t) || ir(t))) + return !t.length; + var e = AC(t); + if (e == LC || e == EC) + return !t.size; + if (Sr(t)) + return !_C(t).length; + for (var i in t) + if (OC.call(t, i)) + return !1; + return !0; +} +const $C = "graphics-document document"; +function IC(t, e) { + t.attr("role", $C), e !== "" && t.attr("aria-roledescription", e); +} +function DC(t, e, i, r) { + if (t.insert !== void 0) { + if (i) { + const n = `chart-desc-${r}`; + t.attr("aria-describedby", n), t.insert("desc", ":first-child").attr("id", n).text(i); + } + if (e) { + const n = `chart-title-${r}`; + t.attr("aria-labelledby", n), t.insert("title", ":first-child").attr("id", n).text(e); + } + } +} +const NC = (t) => t.replace(/^\s*%%(?!{)[^\n]+\n?/gm, "").trimStart(); +/*! js-yaml 4.1.0 https://github.com/nodeca/js-yaml @license MIT */ +function zl(t) { + return typeof t > "u" || t === null; +} +function RC(t) { + return typeof t == "object" && t !== null; +} +function PC(t) { + return Array.isArray(t) ? t : zl(t) ? [] : [t]; +} +function qC(t, e) { + var i, r, n, o; + if (e) + for (o = Object.keys(e), i = 0, r = o.length; i < r; i += 1) + n = o[i], t[n] = e[n]; + return t; +} +function zC(t, e) { + var i = "", r; + for (r = 0; r < e; r += 1) + i += t; + return i; +} +function WC(t) { + return t === 0 && Number.NEGATIVE_INFINITY === 1 / t; +} +var HC = zl, jC = RC, UC = PC, YC = zC, GC = WC, VC = qC, lt = { + isNothing: HC, + isObject: jC, + toArray: UC, + repeat: YC, + isNegativeZero: GC, + extend: VC +}; +function Wl(t, e) { + var i = "", r = t.reason || "(unknown reason)"; + return t.mark ? (t.mark.name && (i += 'in "' + t.mark.name + '" '), i += "(" + (t.mark.line + 1) + ":" + (t.mark.column + 1) + ")", !e && t.mark.snippet && (i += ` + +` + t.mark.snippet), r + " " + i) : r; +} +function fi(t, e) { + Error.call(this), this.name = "YAMLException", this.reason = t, this.mark = e, this.message = Wl(this, !1), Error.captureStackTrace ? Error.captureStackTrace(this, this.constructor) : this.stack = new Error().stack || ""; +} +fi.prototype = Object.create(Error.prototype); +fi.prototype.constructor = fi; +fi.prototype.toString = function(e) { + return this.name + ": " + Wl(this, e); +}; +var Yt = fi; +function Vr(t, e, i, r, n) { + var o = "", s = "", a = Math.floor(n / 2) - 1; + return r - e > a && (o = " ... ", e = r - a + o.length), i - r > a && (s = " ...", i = r + a - s.length), { + str: o + t.slice(e, i).replace(/\t/g, "→") + s, + pos: r - e + o.length + // relative position + }; +} +function Xr(t, e) { + return lt.repeat(" ", e - t.length) + t; +} +function XC(t, e) { + if (e = Object.create(e || null), !t.buffer) + return null; + e.maxLength || (e.maxLength = 79), typeof e.indent != "number" && (e.indent = 1), typeof e.linesBefore != "number" && (e.linesBefore = 3), typeof e.linesAfter != "number" && (e.linesAfter = 2); + for (var i = /\r?\n|\r|\0/g, r = [0], n = [], o, s = -1; o = i.exec(t.buffer); ) + n.push(o.index), r.push(o.index + o[0].length), t.position <= o.index && s < 0 && (s = r.length - 2); + s < 0 && (s = r.length - 1); + var a = "", l, h, u = Math.min(t.line + e.linesAfter, n.length).toString().length, f = e.maxLength - (e.indent + u + 3); + for (l = 1; l <= e.linesBefore && !(s - l < 0); l++) + h = Vr( + t.buffer, + r[s - l], + n[s - l], + t.position - (r[s] - r[s - l]), + f + ), a = lt.repeat(" ", e.indent) + Xr((t.line - l + 1).toString(), u) + " | " + h.str + ` +` + a; + for (h = Vr(t.buffer, r[s], n[s], t.position, f), a += lt.repeat(" ", e.indent) + Xr((t.line + 1).toString(), u) + " | " + h.str + ` +`, a += lt.repeat("-", e.indent + u + 3 + h.pos) + `^ +`, l = 1; l <= e.linesAfter && !(s + l >= n.length); l++) + h = Vr( + t.buffer, + r[s + l], + n[s + l], + t.position - (r[s] - r[s + l]), + f + ), a += lt.repeat(" ", e.indent) + Xr((t.line + l + 1).toString(), u) + " | " + h.str + ` +`; + return a.replace(/\n$/, ""); +} +var KC = XC, ZC = [ + "kind", + "multi", + "resolve", + "construct", + "instanceOf", + "predicate", + "represent", + "representName", + "defaultStyle", + "styleAliases" +], JC = [ + "scalar", + "sequence", + "mapping" +]; +function QC(t) { + var e = {}; + return t !== null && Object.keys(t).forEach(function(i) { + t[i].forEach(function(r) { + e[String(r)] = i; + }); + }), e; +} +function tx(t, e) { + if (e = e || {}, Object.keys(e).forEach(function(i) { + if (ZC.indexOf(i) === -1) + throw new Yt('Unknown option "' + i + '" is met in definition of "' + t + '" YAML type.'); + }), this.options = e, this.tag = t, this.kind = e.kind || null, this.resolve = e.resolve || function() { + return !0; + }, this.construct = e.construct || function(i) { + return i; + }, this.instanceOf = e.instanceOf || null, this.predicate = e.predicate || null, this.represent = e.represent || null, this.representName = e.representName || null, this.defaultStyle = e.defaultStyle || null, this.multi = e.multi || !1, this.styleAliases = QC(e.styleAliases || null), JC.indexOf(this.kind) === -1) + throw new Yt('Unknown kind "' + this.kind + '" is specified for "' + t + '" YAML type.'); +} +var at = tx; +function Bs(t, e) { + var i = []; + return t[e].forEach(function(r) { + var n = i.length; + i.forEach(function(o, s) { + o.tag === r.tag && o.kind === r.kind && o.multi === r.multi && (n = s); + }), i[n] = r; + }), i; +} +function ex() { + var t = { + scalar: {}, + sequence: {}, + mapping: {}, + fallback: {}, + multi: { + scalar: [], + sequence: [], + mapping: [], + fallback: [] + } + }, e, i; + function r(n) { + n.multi ? (t.multi[n.kind].push(n), t.multi.fallback.push(n)) : t[n.kind][n.tag] = t.fallback[n.tag] = n; + } + for (e = 0, i = arguments.length; e < i; e += 1) + arguments[e].forEach(r); + return t; +} +function xn(t) { + return this.extend(t); +} +xn.prototype.extend = function(e) { + var i = [], r = []; + if (e instanceof at) + r.push(e); + else if (Array.isArray(e)) + r = r.concat(e); + else if (e && (Array.isArray(e.implicit) || Array.isArray(e.explicit))) + e.implicit && (i = i.concat(e.implicit)), e.explicit && (r = r.concat(e.explicit)); + else + throw new Yt("Schema.extend argument should be a Type, [ Type ], or a schema definition ({ implicit: [...], explicit: [...] })"); + i.forEach(function(o) { + if (!(o instanceof at)) + throw new Yt("Specified list of YAML types (or a single Type object) contains a non-Type object."); + if (o.loadKind && o.loadKind !== "scalar") + throw new Yt("There is a non-scalar type in the implicit list of a schema. Implicit resolving of such types is not supported."); + if (o.multi) + throw new Yt("There is a multi type in the implicit list of a schema. Multi tags can only be listed as explicit."); + }), r.forEach(function(o) { + if (!(o instanceof at)) + throw new Yt("Specified list of YAML types (or a single Type object) contains a non-Type object."); + }); + var n = Object.create(xn.prototype); + return n.implicit = (this.implicit || []).concat(i), n.explicit = (this.explicit || []).concat(r), n.compiledImplicit = Bs(n, "implicit"), n.compiledExplicit = Bs(n, "explicit"), n.compiledTypeMap = ex(n.compiledImplicit, n.compiledExplicit), n; +}; +var ix = xn, rx = new at("tag:yaml.org,2002:str", { + kind: "scalar", + construct: function(t) { + return t !== null ? t : ""; + } +}), nx = new at("tag:yaml.org,2002:seq", { + kind: "sequence", + construct: function(t) { + return t !== null ? t : []; + } +}), ox = new at("tag:yaml.org,2002:map", { + kind: "mapping", + construct: function(t) { + return t !== null ? t : {}; + } +}), sx = new ix({ + explicit: [ + rx, + nx, + ox + ] +}); +function ax(t) { + if (t === null) + return !0; + var e = t.length; + return e === 1 && t === "~" || e === 4 && (t === "null" || t === "Null" || t === "NULL"); +} +function lx() { + return null; +} +function hx(t) { + return t === null; +} +var cx = new at("tag:yaml.org,2002:null", { + kind: "scalar", + resolve: ax, + construct: lx, + predicate: hx, + represent: { + canonical: function() { + return "~"; + }, + lowercase: function() { + return "null"; + }, + uppercase: function() { + return "NULL"; + }, + camelcase: function() { + return "Null"; + }, + empty: function() { + return ""; + } + }, + defaultStyle: "lowercase" +}); +function ux(t) { + if (t === null) + return !1; + var e = t.length; + return e === 4 && (t === "true" || t === "True" || t === "TRUE") || e === 5 && (t === "false" || t === "False" || t === "FALSE"); +} +function fx(t) { + return t === "true" || t === "True" || t === "TRUE"; +} +function dx(t) { + return Object.prototype.toString.call(t) === "[object Boolean]"; +} +var px = new at("tag:yaml.org,2002:bool", { + kind: "scalar", + resolve: ux, + construct: fx, + predicate: dx, + represent: { + lowercase: function(t) { + return t ? "true" : "false"; + }, + uppercase: function(t) { + return t ? "TRUE" : "FALSE"; + }, + camelcase: function(t) { + return t ? "True" : "False"; + } + }, + defaultStyle: "lowercase" +}); +function gx(t) { + return 48 <= t && t <= 57 || 65 <= t && t <= 70 || 97 <= t && t <= 102; +} +function mx(t) { + return 48 <= t && t <= 55; +} +function yx(t) { + return 48 <= t && t <= 57; +} +function _x(t) { + if (t === null) + return !1; + var e = t.length, i = 0, r = !1, n; + if (!e) + return !1; + if (n = t[i], (n === "-" || n === "+") && (n = t[++i]), n === "0") { + if (i + 1 === e) + return !0; + if (n = t[++i], n === "b") { + for (i++; i < e; i++) + if (n = t[i], n !== "_") { + if (n !== "0" && n !== "1") + return !1; + r = !0; + } + return r && n !== "_"; + } + if (n === "x") { + for (i++; i < e; i++) + if (n = t[i], n !== "_") { + if (!gx(t.charCodeAt(i))) + return !1; + r = !0; + } + return r && n !== "_"; + } + if (n === "o") { + for (i++; i < e; i++) + if (n = t[i], n !== "_") { + if (!mx(t.charCodeAt(i))) + return !1; + r = !0; + } + return r && n !== "_"; + } + } + if (n === "_") + return !1; + for (; i < e; i++) + if (n = t[i], n !== "_") { + if (!yx(t.charCodeAt(i))) + return !1; + r = !0; + } + return !(!r || n === "_"); +} +function Cx(t) { + var e = t, i = 1, r; + if (e.indexOf("_") !== -1 && (e = e.replace(/_/g, "")), r = e[0], (r === "-" || r === "+") && (r === "-" && (i = -1), e = e.slice(1), r = e[0]), e === "0") + return 0; + if (r === "0") { + if (e[1] === "b") + return i * parseInt(e.slice(2), 2); + if (e[1] === "x") + return i * parseInt(e.slice(2), 16); + if (e[1] === "o") + return i * parseInt(e.slice(2), 8); + } + return i * parseInt(e, 10); +} +function xx(t) { + return Object.prototype.toString.call(t) === "[object Number]" && t % 1 === 0 && !lt.isNegativeZero(t); +} +var bx = new at("tag:yaml.org,2002:int", { + kind: "scalar", + resolve: _x, + construct: Cx, + predicate: xx, + represent: { + binary: function(t) { + return t >= 0 ? "0b" + t.toString(2) : "-0b" + t.toString(2).slice(1); + }, + octal: function(t) { + return t >= 0 ? "0o" + t.toString(8) : "-0o" + t.toString(8).slice(1); + }, + decimal: function(t) { + return t.toString(10); + }, + /* eslint-disable max-len */ + hexadecimal: function(t) { + return t >= 0 ? "0x" + t.toString(16).toUpperCase() : "-0x" + t.toString(16).toUpperCase().slice(1); + } + }, + defaultStyle: "decimal", + styleAliases: { + binary: [2, "bin"], + octal: [8, "oct"], + decimal: [10, "dec"], + hexadecimal: [16, "hex"] + } +}), Tx = new RegExp( + // 2.5e4, 2.5 and integers + "^(?:[-+]?(?:[0-9][0-9_]*)(?:\\.[0-9_]*)?(?:[eE][-+]?[0-9]+)?|\\.[0-9_]+(?:[eE][-+]?[0-9]+)?|[-+]?\\.(?:inf|Inf|INF)|\\.(?:nan|NaN|NAN))$" +); +function kx(t) { + return !(t === null || !Tx.test(t) || // Quick hack to not allow integers end with `_` + // Probably should update regexp & check speed + t[t.length - 1] === "_"); +} +function Sx(t) { + var e, i; + return e = t.replace(/_/g, "").toLowerCase(), i = e[0] === "-" ? -1 : 1, "+-".indexOf(e[0]) >= 0 && (e = e.slice(1)), e === ".inf" ? i === 1 ? Number.POSITIVE_INFINITY : Number.NEGATIVE_INFINITY : e === ".nan" ? NaN : i * parseFloat(e, 10); +} +var vx = /^[-+]?[0-9]+e/; +function wx(t, e) { + var i; + if (isNaN(t)) + switch (e) { + case "lowercase": + return ".nan"; + case "uppercase": + return ".NAN"; + case "camelcase": + return ".NaN"; + } + else if (Number.POSITIVE_INFINITY === t) + switch (e) { + case "lowercase": + return ".inf"; + case "uppercase": + return ".INF"; + case "camelcase": + return ".Inf"; + } + else if (Number.NEGATIVE_INFINITY === t) + switch (e) { + case "lowercase": + return "-.inf"; + case "uppercase": + return "-.INF"; + case "camelcase": + return "-.Inf"; + } + else if (lt.isNegativeZero(t)) + return "-0.0"; + return i = t.toString(10), vx.test(i) ? i.replace("e", ".e") : i; +} +function Bx(t) { + return Object.prototype.toString.call(t) === "[object Number]" && (t % 1 !== 0 || lt.isNegativeZero(t)); +} +var Fx = new at("tag:yaml.org,2002:float", { + kind: "scalar", + resolve: kx, + construct: Sx, + predicate: Bx, + represent: wx, + defaultStyle: "lowercase" +}), Hl = sx.extend({ + implicit: [ + cx, + px, + bx, + Fx + ] +}), Ax = Hl, jl = new RegExp( + "^([0-9][0-9][0-9][0-9])-([0-9][0-9])-([0-9][0-9])$" +), Ul = new RegExp( + "^([0-9][0-9][0-9][0-9])-([0-9][0-9]?)-([0-9][0-9]?)(?:[Tt]|[ \\t]+)([0-9][0-9]?):([0-9][0-9]):([0-9][0-9])(?:\\.([0-9]*))?(?:[ \\t]*(Z|([-+])([0-9][0-9]?)(?::([0-9][0-9]))?))?$" +); +function Lx(t) { + return t === null ? !1 : jl.exec(t) !== null || Ul.exec(t) !== null; +} +function Ex(t) { + var e, i, r, n, o, s, a, l = 0, h = null, u, f, c; + if (e = jl.exec(t), e === null && (e = Ul.exec(t)), e === null) + throw new Error("Date resolve error"); + if (i = +e[1], r = +e[2] - 1, n = +e[3], !e[4]) + return new Date(Date.UTC(i, r, n)); + if (o = +e[4], s = +e[5], a = +e[6], e[7]) { + for (l = e[7].slice(0, 3); l.length < 3; ) + l += "0"; + l = +l; + } + return e[9] && (u = +e[10], f = +(e[11] || 0), h = (u * 60 + f) * 6e4, e[9] === "-" && (h = -h)), c = new Date(Date.UTC(i, r, n, o, s, a, l)), h && c.setTime(c.getTime() - h), c; +} +function Mx(t) { + return t.toISOString(); +} +var Ox = new at("tag:yaml.org,2002:timestamp", { + kind: "scalar", + resolve: Lx, + construct: Ex, + instanceOf: Date, + represent: Mx +}); +function $x(t) { + return t === "<<" || t === null; +} +var Ix = new at("tag:yaml.org,2002:merge", { + kind: "scalar", + resolve: $x +}), Zn = `ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/= +\r`; +function Dx(t) { + if (t === null) + return !1; + var e, i, r = 0, n = t.length, o = Zn; + for (i = 0; i < n; i++) + if (e = o.indexOf(t.charAt(i)), !(e > 64)) { + if (e < 0) + return !1; + r += 6; + } + return r % 8 === 0; +} +function Nx(t) { + var e, i, r = t.replace(/[\r\n=]/g, ""), n = r.length, o = Zn, s = 0, a = []; + for (e = 0; e < n; e++) + e % 4 === 0 && e && (a.push(s >> 16 & 255), a.push(s >> 8 & 255), a.push(s & 255)), s = s << 6 | o.indexOf(r.charAt(e)); + return i = n % 4 * 6, i === 0 ? (a.push(s >> 16 & 255), a.push(s >> 8 & 255), a.push(s & 255)) : i === 18 ? (a.push(s >> 10 & 255), a.push(s >> 2 & 255)) : i === 12 && a.push(s >> 4 & 255), new Uint8Array(a); +} +function Rx(t) { + var e = "", i = 0, r, n, o = t.length, s = Zn; + for (r = 0; r < o; r++) + r % 3 === 0 && r && (e += s[i >> 18 & 63], e += s[i >> 12 & 63], e += s[i >> 6 & 63], e += s[i & 63]), i = (i << 8) + t[r]; + return n = o % 3, n === 0 ? (e += s[i >> 18 & 63], e += s[i >> 12 & 63], e += s[i >> 6 & 63], e += s[i & 63]) : n === 2 ? (e += s[i >> 10 & 63], e += s[i >> 4 & 63], e += s[i << 2 & 63], e += s[64]) : n === 1 && (e += s[i >> 2 & 63], e += s[i << 4 & 63], e += s[64], e += s[64]), e; +} +function Px(t) { + return Object.prototype.toString.call(t) === "[object Uint8Array]"; +} +var qx = new at("tag:yaml.org,2002:binary", { + kind: "scalar", + resolve: Dx, + construct: Nx, + predicate: Px, + represent: Rx +}), zx = Object.prototype.hasOwnProperty, Wx = Object.prototype.toString; +function Hx(t) { + if (t === null) + return !0; + var e = [], i, r, n, o, s, a = t; + for (i = 0, r = a.length; i < r; i += 1) { + if (n = a[i], s = !1, Wx.call(n) !== "[object Object]") + return !1; + for (o in n) + if (zx.call(n, o)) + if (!s) + s = !0; + else + return !1; + if (!s) + return !1; + if (e.indexOf(o) === -1) + e.push(o); + else + return !1; + } + return !0; +} +function jx(t) { + return t !== null ? t : []; +} +var Ux = new at("tag:yaml.org,2002:omap", { + kind: "sequence", + resolve: Hx, + construct: jx +}), Yx = Object.prototype.toString; +function Gx(t) { + if (t === null) + return !0; + var e, i, r, n, o, s = t; + for (o = new Array(s.length), e = 0, i = s.length; e < i; e += 1) { + if (r = s[e], Yx.call(r) !== "[object Object]" || (n = Object.keys(r), n.length !== 1)) + return !1; + o[e] = [n[0], r[n[0]]]; + } + return !0; +} +function Vx(t) { + if (t === null) + return []; + var e, i, r, n, o, s = t; + for (o = new Array(s.length), e = 0, i = s.length; e < i; e += 1) + r = s[e], n = Object.keys(r), o[e] = [n[0], r[n[0]]]; + return o; +} +var Xx = new at("tag:yaml.org,2002:pairs", { + kind: "sequence", + resolve: Gx, + construct: Vx +}), Kx = Object.prototype.hasOwnProperty; +function Zx(t) { + if (t === null) + return !0; + var e, i = t; + for (e in i) + if (Kx.call(i, e) && i[e] !== null) + return !1; + return !0; +} +function Jx(t) { + return t !== null ? t : {}; +} +var Qx = new at("tag:yaml.org,2002:set", { + kind: "mapping", + resolve: Zx, + construct: Jx +}), tb = Ax.extend({ + implicit: [ + Ox, + Ix + ], + explicit: [ + qx, + Ux, + Xx, + Qx + ] +}), re = Object.prototype.hasOwnProperty, lr = 1, Yl = 2, Gl = 3, hr = 4, Kr = 1, eb = 2, Fs = 3, ib = /[\x00-\x08\x0B\x0C\x0E-\x1F\x7F-\x84\x86-\x9F\uFFFE\uFFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF]/, rb = /[\x85\u2028\u2029]/, nb = /[,\[\]\{\}]/, Vl = /^(?:!|!!|![a-z\-]+!)$/i, Xl = /^(?:!|[^,\[\]\{\}])(?:%[0-9a-f]{2}|[0-9a-z\-#;\/\?:@&=\+\$,_\.!~\*'\(\)\[\]])*$/i; +function As(t) { + return Object.prototype.toString.call(t); +} +function Mt(t) { + return t === 10 || t === 13; +} +function de(t) { + return t === 9 || t === 32; +} +function gt(t) { + return t === 9 || t === 32 || t === 10 || t === 13; +} +function we(t) { + return t === 44 || t === 91 || t === 93 || t === 123 || t === 125; +} +function ob(t) { + var e; + return 48 <= t && t <= 57 ? t - 48 : (e = t | 32, 97 <= e && e <= 102 ? e - 97 + 10 : -1); +} +function sb(t) { + return t === 120 ? 2 : t === 117 ? 4 : t === 85 ? 8 : 0; +} +function ab(t) { + return 48 <= t && t <= 57 ? t - 48 : -1; +} +function Ls(t) { + return t === 48 ? "\0" : t === 97 ? "\x07" : t === 98 ? "\b" : t === 116 || t === 9 ? " " : t === 110 ? ` +` : t === 118 ? "\v" : t === 102 ? "\f" : t === 114 ? "\r" : t === 101 ? "\x1B" : t === 32 ? " " : t === 34 ? '"' : t === 47 ? "/" : t === 92 ? "\\" : t === 78 ? "…" : t === 95 ? " " : t === 76 ? "\u2028" : t === 80 ? "\u2029" : ""; +} +function lb(t) { + return t <= 65535 ? String.fromCharCode(t) : String.fromCharCode( + (t - 65536 >> 10) + 55296, + (t - 65536 & 1023) + 56320 + ); +} +var Kl = new Array(256), Zl = new Array(256); +for (var ve = 0; ve < 256; ve++) + Kl[ve] = Ls(ve) ? 1 : 0, Zl[ve] = Ls(ve); +function hb(t, e) { + this.input = t, this.filename = e.filename || null, this.schema = e.schema || tb, this.onWarning = e.onWarning || null, this.legacy = e.legacy || !1, this.json = e.json || !1, this.listener = e.listener || null, this.implicitTypes = this.schema.compiledImplicit, this.typeMap = this.schema.compiledTypeMap, this.length = t.length, this.position = 0, this.line = 0, this.lineStart = 0, this.lineIndent = 0, this.firstTabInLine = -1, this.documents = []; +} +function Jl(t, e) { + var i = { + name: t.filename, + buffer: t.input.slice(0, -1), + // omit trailing \0 + position: t.position, + line: t.line, + column: t.position - t.lineStart + }; + return i.snippet = KC(i), new Yt(e, i); +} +function A(t, e) { + throw Jl(t, e); +} +function cr(t, e) { + t.onWarning && t.onWarning.call(null, Jl(t, e)); +} +var Es = { + YAML: function(e, i, r) { + var n, o, s; + e.version !== null && A(e, "duplication of %YAML directive"), r.length !== 1 && A(e, "YAML directive accepts exactly one argument"), n = /^([0-9]+)\.([0-9]+)$/.exec(r[0]), n === null && A(e, "ill-formed argument of the YAML directive"), o = parseInt(n[1], 10), s = parseInt(n[2], 10), o !== 1 && A(e, "unacceptable YAML version of the document"), e.version = r[0], e.checkLineBreaks = s < 2, s !== 1 && s !== 2 && cr(e, "unsupported YAML version of the document"); + }, + TAG: function(e, i, r) { + var n, o; + r.length !== 2 && A(e, "TAG directive accepts exactly two arguments"), n = r[0], o = r[1], Vl.test(n) || A(e, "ill-formed tag handle (first argument) of the TAG directive"), re.call(e.tagMap, n) && A(e, 'there is a previously declared suffix for "' + n + '" tag handle'), Xl.test(o) || A(e, "ill-formed tag prefix (second argument) of the TAG directive"); + try { + o = decodeURIComponent(o); + } catch { + A(e, "tag prefix is malformed: " + o); + } + e.tagMap[n] = o; + } +}; +function ee(t, e, i, r) { + var n, o, s, a; + if (e < i) { + if (a = t.input.slice(e, i), r) + for (n = 0, o = a.length; n < o; n += 1) + s = a.charCodeAt(n), s === 9 || 32 <= s && s <= 1114111 || A(t, "expected valid JSON character"); + else + ib.test(a) && A(t, "the stream contains non-printable characters"); + t.result += a; + } +} +function Ms(t, e, i, r) { + var n, o, s, a; + for (lt.isObject(i) || A(t, "cannot merge mappings; the provided source object is unacceptable"), n = Object.keys(i), s = 0, a = n.length; s < a; s += 1) + o = n[s], re.call(e, o) || (e[o] = i[o], r[o] = !0); +} +function Be(t, e, i, r, n, o, s, a, l) { + var h, u; + if (Array.isArray(n)) + for (n = Array.prototype.slice.call(n), h = 0, u = n.length; h < u; h += 1) + Array.isArray(n[h]) && A(t, "nested arrays are not supported inside keys"), typeof n == "object" && As(n[h]) === "[object Object]" && (n[h] = "[object Object]"); + if (typeof n == "object" && As(n) === "[object Object]" && (n = "[object Object]"), n = String(n), e === null && (e = {}), r === "tag:yaml.org,2002:merge") + if (Array.isArray(o)) + for (h = 0, u = o.length; h < u; h += 1) + Ms(t, e, o[h], i); + else + Ms(t, e, o, i); + else + !t.json && !re.call(i, n) && re.call(e, n) && (t.line = s || t.line, t.lineStart = a || t.lineStart, t.position = l || t.position, A(t, "duplicated mapping key")), n === "__proto__" ? Object.defineProperty(e, n, { + configurable: !0, + enumerable: !0, + writable: !0, + value: o + }) : e[n] = o, delete i[n]; + return e; +} +function Jn(t) { + var e; + e = t.input.charCodeAt(t.position), e === 10 ? t.position++ : e === 13 ? (t.position++, t.input.charCodeAt(t.position) === 10 && t.position++) : A(t, "a line break is expected"), t.line += 1, t.lineStart = t.position, t.firstTabInLine = -1; +} +function Q(t, e, i) { + for (var r = 0, n = t.input.charCodeAt(t.position); n !== 0; ) { + for (; de(n); ) + n === 9 && t.firstTabInLine === -1 && (t.firstTabInLine = t.position), n = t.input.charCodeAt(++t.position); + if (e && n === 35) + do + n = t.input.charCodeAt(++t.position); + while (n !== 10 && n !== 13 && n !== 0); + if (Mt(n)) + for (Jn(t), n = t.input.charCodeAt(t.position), r++, t.lineIndent = 0; n === 32; ) + t.lineIndent++, n = t.input.charCodeAt(++t.position); + else + break; + } + return i !== -1 && r !== 0 && t.lineIndent < i && cr(t, "deficient indentation"), r; +} +function Ar(t) { + var e = t.position, i; + return i = t.input.charCodeAt(e), !!((i === 45 || i === 46) && i === t.input.charCodeAt(e + 1) && i === t.input.charCodeAt(e + 2) && (e += 3, i = t.input.charCodeAt(e), i === 0 || gt(i))); +} +function Qn(t, e) { + e === 1 ? t.result += " " : e > 1 && (t.result += lt.repeat(` +`, e - 1)); +} +function cb(t, e, i) { + var r, n, o, s, a, l, h, u, f = t.kind, c = t.result, d; + if (d = t.input.charCodeAt(t.position), gt(d) || we(d) || d === 35 || d === 38 || d === 42 || d === 33 || d === 124 || d === 62 || d === 39 || d === 34 || d === 37 || d === 64 || d === 96 || (d === 63 || d === 45) && (n = t.input.charCodeAt(t.position + 1), gt(n) || i && we(n))) + return !1; + for (t.kind = "scalar", t.result = "", o = s = t.position, a = !1; d !== 0; ) { + if (d === 58) { + if (n = t.input.charCodeAt(t.position + 1), gt(n) || i && we(n)) + break; + } else if (d === 35) { + if (r = t.input.charCodeAt(t.position - 1), gt(r)) + break; + } else { + if (t.position === t.lineStart && Ar(t) || i && we(d)) + break; + if (Mt(d)) + if (l = t.line, h = t.lineStart, u = t.lineIndent, Q(t, !1, -1), t.lineIndent >= e) { + a = !0, d = t.input.charCodeAt(t.position); + continue; + } else { + t.position = s, t.line = l, t.lineStart = h, t.lineIndent = u; + break; + } + } + a && (ee(t, o, s, !1), Qn(t, t.line - l), o = s = t.position, a = !1), de(d) || (s = t.position + 1), d = t.input.charCodeAt(++t.position); + } + return ee(t, o, s, !1), t.result ? !0 : (t.kind = f, t.result = c, !1); +} +function ub(t, e) { + var i, r, n; + if (i = t.input.charCodeAt(t.position), i !== 39) + return !1; + for (t.kind = "scalar", t.result = "", t.position++, r = n = t.position; (i = t.input.charCodeAt(t.position)) !== 0; ) + if (i === 39) + if (ee(t, r, t.position, !0), i = t.input.charCodeAt(++t.position), i === 39) + r = t.position, t.position++, n = t.position; + else + return !0; + else + Mt(i) ? (ee(t, r, n, !0), Qn(t, Q(t, !1, e)), r = n = t.position) : t.position === t.lineStart && Ar(t) ? A(t, "unexpected end of the document within a single quoted scalar") : (t.position++, n = t.position); + A(t, "unexpected end of the stream within a single quoted scalar"); +} +function fb(t, e) { + var i, r, n, o, s, a; + if (a = t.input.charCodeAt(t.position), a !== 34) + return !1; + for (t.kind = "scalar", t.result = "", t.position++, i = r = t.position; (a = t.input.charCodeAt(t.position)) !== 0; ) { + if (a === 34) + return ee(t, i, t.position, !0), t.position++, !0; + if (a === 92) { + if (ee(t, i, t.position, !0), a = t.input.charCodeAt(++t.position), Mt(a)) + Q(t, !1, e); + else if (a < 256 && Kl[a]) + t.result += Zl[a], t.position++; + else if ((s = sb(a)) > 0) { + for (n = s, o = 0; n > 0; n--) + a = t.input.charCodeAt(++t.position), (s = ob(a)) >= 0 ? o = (o << 4) + s : A(t, "expected hexadecimal character"); + t.result += lb(o), t.position++; + } else + A(t, "unknown escape sequence"); + i = r = t.position; + } else + Mt(a) ? (ee(t, i, r, !0), Qn(t, Q(t, !1, e)), i = r = t.position) : t.position === t.lineStart && Ar(t) ? A(t, "unexpected end of the document within a double quoted scalar") : (t.position++, r = t.position); + } + A(t, "unexpected end of the stream within a double quoted scalar"); +} +function db(t, e) { + var i = !0, r, n, o, s = t.tag, a, l = t.anchor, h, u, f, c, d, m = /* @__PURE__ */ Object.create(null), S, O, z, T; + if (T = t.input.charCodeAt(t.position), T === 91) + u = 93, d = !1, a = []; + else if (T === 123) + u = 125, d = !0, a = {}; + else + return !1; + for (t.anchor !== null && (t.anchorMap[t.anchor] = a), T = t.input.charCodeAt(++t.position); T !== 0; ) { + if (Q(t, !0, e), T = t.input.charCodeAt(t.position), T === u) + return t.position++, t.tag = s, t.anchor = l, t.kind = d ? "mapping" : "sequence", t.result = a, !0; + i ? T === 44 && A(t, "expected the node content, but found ','") : A(t, "missed comma between flow collection entries"), O = S = z = null, f = c = !1, T === 63 && (h = t.input.charCodeAt(t.position + 1), gt(h) && (f = c = !0, t.position++, Q(t, !0, e))), r = t.line, n = t.lineStart, o = t.position, De(t, e, lr, !1, !0), O = t.tag, S = t.result, Q(t, !0, e), T = t.input.charCodeAt(t.position), (c || t.line === r) && T === 58 && (f = !0, T = t.input.charCodeAt(++t.position), Q(t, !0, e), De(t, e, lr, !1, !0), z = t.result), d ? Be(t, a, m, O, S, z, r, n, o) : f ? a.push(Be(t, null, m, O, S, z, r, n, o)) : a.push(S), Q(t, !0, e), T = t.input.charCodeAt(t.position), T === 44 ? (i = !0, T = t.input.charCodeAt(++t.position)) : i = !1; + } + A(t, "unexpected end of the stream within a flow collection"); +} +function pb(t, e) { + var i, r, n = Kr, o = !1, s = !1, a = e, l = 0, h = !1, u, f; + if (f = t.input.charCodeAt(t.position), f === 124) + r = !1; + else if (f === 62) + r = !0; + else + return !1; + for (t.kind = "scalar", t.result = ""; f !== 0; ) + if (f = t.input.charCodeAt(++t.position), f === 43 || f === 45) + Kr === n ? n = f === 43 ? Fs : eb : A(t, "repeat of a chomping mode identifier"); + else if ((u = ab(f)) >= 0) + u === 0 ? A(t, "bad explicit indentation width of a block scalar; it cannot be less than one") : s ? A(t, "repeat of an indentation width identifier") : (a = e + u - 1, s = !0); + else + break; + if (de(f)) { + do + f = t.input.charCodeAt(++t.position); + while (de(f)); + if (f === 35) + do + f = t.input.charCodeAt(++t.position); + while (!Mt(f) && f !== 0); + } + for (; f !== 0; ) { + for (Jn(t), t.lineIndent = 0, f = t.input.charCodeAt(t.position); (!s || t.lineIndent < a) && f === 32; ) + t.lineIndent++, f = t.input.charCodeAt(++t.position); + if (!s && t.lineIndent > a && (a = t.lineIndent), Mt(f)) { + l++; + continue; + } + if (t.lineIndent < a) { + n === Fs ? t.result += lt.repeat(` +`, o ? 1 + l : l) : n === Kr && o && (t.result += ` +`); + break; + } + for (r ? de(f) ? (h = !0, t.result += lt.repeat(` +`, o ? 1 + l : l)) : h ? (h = !1, t.result += lt.repeat(` +`, l + 1)) : l === 0 ? o && (t.result += " ") : t.result += lt.repeat(` +`, l) : t.result += lt.repeat(` +`, o ? 1 + l : l), o = !0, s = !0, l = 0, i = t.position; !Mt(f) && f !== 0; ) + f = t.input.charCodeAt(++t.position); + ee(t, i, t.position, !1); + } + return !0; +} +function Os(t, e) { + var i, r = t.tag, n = t.anchor, o = [], s, a = !1, l; + if (t.firstTabInLine !== -1) + return !1; + for (t.anchor !== null && (t.anchorMap[t.anchor] = o), l = t.input.charCodeAt(t.position); l !== 0 && (t.firstTabInLine !== -1 && (t.position = t.firstTabInLine, A(t, "tab characters must not be used in indentation")), !(l !== 45 || (s = t.input.charCodeAt(t.position + 1), !gt(s)))); ) { + if (a = !0, t.position++, Q(t, !0, -1) && t.lineIndent <= e) { + o.push(null), l = t.input.charCodeAt(t.position); + continue; + } + if (i = t.line, De(t, e, Gl, !1, !0), o.push(t.result), Q(t, !0, -1), l = t.input.charCodeAt(t.position), (t.line === i || t.lineIndent > e) && l !== 0) + A(t, "bad indentation of a sequence entry"); + else if (t.lineIndent < e) + break; + } + return a ? (t.tag = r, t.anchor = n, t.kind = "sequence", t.result = o, !0) : !1; +} +function gb(t, e, i) { + var r, n, o, s, a, l, h = t.tag, u = t.anchor, f = {}, c = /* @__PURE__ */ Object.create(null), d = null, m = null, S = null, O = !1, z = !1, T; + if (t.firstTabInLine !== -1) + return !1; + for (t.anchor !== null && (t.anchorMap[t.anchor] = f), T = t.input.charCodeAt(t.position); T !== 0; ) { + if (!O && t.firstTabInLine !== -1 && (t.position = t.firstTabInLine, A(t, "tab characters must not be used in indentation")), r = t.input.charCodeAt(t.position + 1), o = t.line, (T === 63 || T === 58) && gt(r)) + T === 63 ? (O && (Be(t, f, c, d, m, null, s, a, l), d = m = S = null), z = !0, O = !0, n = !0) : O ? (O = !1, n = !0) : A(t, "incomplete explicit mapping pair; a key node is missed; or followed by a non-tabulated empty line"), t.position += 1, T = r; + else { + if (s = t.line, a = t.lineStart, l = t.position, !De(t, i, Yl, !1, !0)) + break; + if (t.line === o) { + for (T = t.input.charCodeAt(t.position); de(T); ) + T = t.input.charCodeAt(++t.position); + if (T === 58) + T = t.input.charCodeAt(++t.position), gt(T) || A(t, "a whitespace character is expected after the key-value separator within a block mapping"), O && (Be(t, f, c, d, m, null, s, a, l), d = m = S = null), z = !0, O = !1, n = !1, d = t.tag, m = t.result; + else if (z) + A(t, "can not read an implicit mapping pair; a colon is missed"); + else + return t.tag = h, t.anchor = u, !0; + } else if (z) + A(t, "can not read a block mapping entry; a multiline key may not be an implicit key"); + else + return t.tag = h, t.anchor = u, !0; + } + if ((t.line === o || t.lineIndent > e) && (O && (s = t.line, a = t.lineStart, l = t.position), De(t, e, hr, !0, n) && (O ? m = t.result : S = t.result), O || (Be(t, f, c, d, m, S, s, a, l), d = m = S = null), Q(t, !0, -1), T = t.input.charCodeAt(t.position)), (t.line === o || t.lineIndent > e) && T !== 0) + A(t, "bad indentation of a mapping entry"); + else if (t.lineIndent < e) + break; + } + return O && Be(t, f, c, d, m, null, s, a, l), z && (t.tag = h, t.anchor = u, t.kind = "mapping", t.result = f), z; +} +function mb(t) { + var e, i = !1, r = !1, n, o, s; + if (s = t.input.charCodeAt(t.position), s !== 33) + return !1; + if (t.tag !== null && A(t, "duplication of a tag property"), s = t.input.charCodeAt(++t.position), s === 60 ? (i = !0, s = t.input.charCodeAt(++t.position)) : s === 33 ? (r = !0, n = "!!", s = t.input.charCodeAt(++t.position)) : n = "!", e = t.position, i) { + do + s = t.input.charCodeAt(++t.position); + while (s !== 0 && s !== 62); + t.position < t.length ? (o = t.input.slice(e, t.position), s = t.input.charCodeAt(++t.position)) : A(t, "unexpected end of the stream within a verbatim tag"); + } else { + for (; s !== 0 && !gt(s); ) + s === 33 && (r ? A(t, "tag suffix cannot contain exclamation marks") : (n = t.input.slice(e - 1, t.position + 1), Vl.test(n) || A(t, "named tag handle cannot contain such characters"), r = !0, e = t.position + 1)), s = t.input.charCodeAt(++t.position); + o = t.input.slice(e, t.position), nb.test(o) && A(t, "tag suffix cannot contain flow indicator characters"); + } + o && !Xl.test(o) && A(t, "tag name cannot contain such characters: " + o); + try { + o = decodeURIComponent(o); + } catch { + A(t, "tag name is malformed: " + o); + } + return i ? t.tag = o : re.call(t.tagMap, n) ? t.tag = t.tagMap[n] + o : n === "!" ? t.tag = "!" + o : n === "!!" ? t.tag = "tag:yaml.org,2002:" + o : A(t, 'undeclared tag handle "' + n + '"'), !0; +} +function yb(t) { + var e, i; + if (i = t.input.charCodeAt(t.position), i !== 38) + return !1; + for (t.anchor !== null && A(t, "duplication of an anchor property"), i = t.input.charCodeAt(++t.position), e = t.position; i !== 0 && !gt(i) && !we(i); ) + i = t.input.charCodeAt(++t.position); + return t.position === e && A(t, "name of an anchor node must contain at least one character"), t.anchor = t.input.slice(e, t.position), !0; +} +function _b(t) { + var e, i, r; + if (r = t.input.charCodeAt(t.position), r !== 42) + return !1; + for (r = t.input.charCodeAt(++t.position), e = t.position; r !== 0 && !gt(r) && !we(r); ) + r = t.input.charCodeAt(++t.position); + return t.position === e && A(t, "name of an alias node must contain at least one character"), i = t.input.slice(e, t.position), re.call(t.anchorMap, i) || A(t, 'unidentified alias "' + i + '"'), t.result = t.anchorMap[i], Q(t, !0, -1), !0; +} +function De(t, e, i, r, n) { + var o, s, a, l = 1, h = !1, u = !1, f, c, d, m, S, O; + if (t.listener !== null && t.listener("open", t), t.tag = null, t.anchor = null, t.kind = null, t.result = null, o = s = a = hr === i || Gl === i, r && Q(t, !0, -1) && (h = !0, t.lineIndent > e ? l = 1 : t.lineIndent === e ? l = 0 : t.lineIndent < e && (l = -1)), l === 1) + for (; mb(t) || yb(t); ) + Q(t, !0, -1) ? (h = !0, a = o, t.lineIndent > e ? l = 1 : t.lineIndent === e ? l = 0 : t.lineIndent < e && (l = -1)) : a = !1; + if (a && (a = h || n), (l === 1 || hr === i) && (lr === i || Yl === i ? S = e : S = e + 1, O = t.position - t.lineStart, l === 1 ? a && (Os(t, O) || gb(t, O, S)) || db(t, S) ? u = !0 : (s && pb(t, S) || ub(t, S) || fb(t, S) ? u = !0 : _b(t) ? (u = !0, (t.tag !== null || t.anchor !== null) && A(t, "alias node should not have any properties")) : cb(t, S, lr === i) && (u = !0, t.tag === null && (t.tag = "?")), t.anchor !== null && (t.anchorMap[t.anchor] = t.result)) : l === 0 && (u = a && Os(t, O))), t.tag === null) + t.anchor !== null && (t.anchorMap[t.anchor] = t.result); + else if (t.tag === "?") { + for (t.result !== null && t.kind !== "scalar" && A(t, 'unacceptable node kind for ! tag; it should be "scalar", not "' + t.kind + '"'), f = 0, c = t.implicitTypes.length; f < c; f += 1) + if (m = t.implicitTypes[f], m.resolve(t.result)) { + t.result = m.construct(t.result), t.tag = m.tag, t.anchor !== null && (t.anchorMap[t.anchor] = t.result); + break; + } + } else if (t.tag !== "!") { + if (re.call(t.typeMap[t.kind || "fallback"], t.tag)) + m = t.typeMap[t.kind || "fallback"][t.tag]; + else + for (m = null, d = t.typeMap.multi[t.kind || "fallback"], f = 0, c = d.length; f < c; f += 1) + if (t.tag.slice(0, d[f].tag.length) === d[f].tag) { + m = d[f]; + break; + } + m || A(t, "unknown tag !<" + t.tag + ">"), t.result !== null && m.kind !== t.kind && A(t, "unacceptable node kind for !<" + t.tag + '> tag; it should be "' + m.kind + '", not "' + t.kind + '"'), m.resolve(t.result, t.tag) ? (t.result = m.construct(t.result, t.tag), t.anchor !== null && (t.anchorMap[t.anchor] = t.result)) : A(t, "cannot resolve a node with !<" + t.tag + "> explicit tag"); + } + return t.listener !== null && t.listener("close", t), t.tag !== null || t.anchor !== null || u; +} +function Cb(t) { + var e = t.position, i, r, n, o = !1, s; + for (t.version = null, t.checkLineBreaks = t.legacy, t.tagMap = /* @__PURE__ */ Object.create(null), t.anchorMap = /* @__PURE__ */ Object.create(null); (s = t.input.charCodeAt(t.position)) !== 0 && (Q(t, !0, -1), s = t.input.charCodeAt(t.position), !(t.lineIndent > 0 || s !== 37)); ) { + for (o = !0, s = t.input.charCodeAt(++t.position), i = t.position; s !== 0 && !gt(s); ) + s = t.input.charCodeAt(++t.position); + for (r = t.input.slice(i, t.position), n = [], r.length < 1 && A(t, "directive name must not be less than one character in length"); s !== 0; ) { + for (; de(s); ) + s = t.input.charCodeAt(++t.position); + if (s === 35) { + do + s = t.input.charCodeAt(++t.position); + while (s !== 0 && !Mt(s)); + break; + } + if (Mt(s)) + break; + for (i = t.position; s !== 0 && !gt(s); ) + s = t.input.charCodeAt(++t.position); + n.push(t.input.slice(i, t.position)); + } + s !== 0 && Jn(t), re.call(Es, r) ? Es[r](t, r, n) : cr(t, 'unknown document directive "' + r + '"'); + } + if (Q(t, !0, -1), t.lineIndent === 0 && t.input.charCodeAt(t.position) === 45 && t.input.charCodeAt(t.position + 1) === 45 && t.input.charCodeAt(t.position + 2) === 45 ? (t.position += 3, Q(t, !0, -1)) : o && A(t, "directives end mark is expected"), De(t, t.lineIndent - 1, hr, !1, !0), Q(t, !0, -1), t.checkLineBreaks && rb.test(t.input.slice(e, t.position)) && cr(t, "non-ASCII line breaks are interpreted as content"), t.documents.push(t.result), t.position === t.lineStart && Ar(t)) { + t.input.charCodeAt(t.position) === 46 && (t.position += 3, Q(t, !0, -1)); + return; + } + if (t.position < t.length - 1) + A(t, "end of the stream or a document separator is expected"); + else + return; +} +function Ql(t, e) { + t = String(t), e = e || {}, t.length !== 0 && (t.charCodeAt(t.length - 1) !== 10 && t.charCodeAt(t.length - 1) !== 13 && (t += ` +`), t.charCodeAt(0) === 65279 && (t = t.slice(1))); + var i = new hb(t, e), r = t.indexOf("\0"); + for (r !== -1 && (i.position = r, A(i, "null byte is not allowed in input")), i.input += "\0"; i.input.charCodeAt(i.position) === 32; ) + i.lineIndent += 1, i.position += 1; + for (; i.position < i.length - 1; ) + Cb(i); + return i.documents; +} +function xb(t, e, i) { + e !== null && typeof e == "object" && typeof i > "u" && (i = e, e = null); + var r = Ql(t, i); + if (typeof e != "function") + return r; + for (var n = 0, o = r.length; n < o; n += 1) + e(r[n]); +} +function bb(t, e) { + var i = Ql(t, e); + if (i.length !== 0) { + if (i.length === 1) + return i[0]; + throw new Yt("expected a single document in the stream, but found more"); + } +} +var Tb = xb, kb = bb, Sb = { + loadAll: Tb, + load: kb +}, vb = Hl, wb = Sb.load; +function Bb(t) { + const e = t.match(Na); + if (!e) + return { + text: t, + metadata: {} + }; + let i = wb(e[1], { + // To support config, we need JSON schema. + // https://www.yaml.org/spec/1.2/spec.html#id2803231 + schema: vb + }) ?? {}; + i = typeof i == "object" && !Array.isArray(i) ? i : {}; + const r = {}; + return i.displayMode && (r.displayMode = i.displayMode.toString()), i.title && (r.title = i.title.toString()), i.config && (r.config = i.config), { + text: t.slice(e[0].length), + metadata: r + }; +} +const Fb = (t) => t.replace(/\r\n?/g, ` +`).replace( + /<(\w+)([^>]*)>/g, + (e, i, r) => "<" + i + r.replace(/="([^"]*)"/g, "='$1'") + ">" +), Ab = (t) => { + const { text: e, metadata: i } = Bb(t), { displayMode: r, title: n, config: o = {} } = i; + return r && (o.gantt || (o.gantt = {}), o.gantt.displayMode = r), { title: n, config: o, text: e }; +}, Lb = (t) => { + const e = ei.detectInit(t) ?? {}, i = ei.detectDirective(t, "wrap"); + return Array.isArray(i) ? e.wrap = i.some(({ type: r }) => { + }) : (i == null ? void 0 : i.type) === "wrap" && (e.wrap = !0), { + text: _0(t), + directive: e + }; +}; +function th(t) { + const e = Fb(t), i = Ab(e), r = Lb(i.text), n = nl(i.config, r.directive); + return t = NC(r.text), { + code: t, + title: i.title, + config: n + }; +} +const Eb = 5e4, Mb = "graph TB;a[Maximum text size in diagram exceeded];style a fill:#faa", Ob = "sandbox", $b = "loose", Ib = "http://www.w3.org/2000/svg", Db = "http://www.w3.org/1999/xlink", Nb = "http://www.w3.org/1999/xhtml", Rb = "100%", Pb = "100%", qb = "border:0;margin:0;", zb = "margin:0", Wb = "allow-top-navigation-by-user-activation allow-popups", Hb = 'The "iframe" tag is not supported by your browser.', jb = ["foreignobject"], Ub = ["dominant-baseline"]; +function eh(t) { + const e = th(t); + return or(), sy(e.config ?? {}), e; +} +async function Yb(t, e) { + Kn(), t = eh(t).code; + try { + await to(t); + } catch (i) { + if (e != null && e.suppressErrors) + return !1; + throw i; + } + return !0; +} +const $s = (t, e, i = []) => ` +.${t} ${e} { ${i.join(" !important; ")} !important; }`, Gb = (t, e = {}) => { + var r; + let i = ""; + if (t.themeCSS !== void 0 && (i += ` +${t.themeCSS}`), t.fontFamily !== void 0 && (i += ` +:root { --mermaid-font-family: ${t.fontFamily}}`), t.altFontFamily !== void 0 && (i += ` +:root { --mermaid-alt-font-family: ${t.altFontFamily}}`), !Gr(e)) { + const a = t.htmlLabels || ((r = t.flowchart) == null ? void 0 : r.htmlLabels) ? ["> *", "span"] : ["rect", "polygon", "ellipse", "circle", "path"]; + for (const l in e) { + const h = e[l]; + Gr(h.styles) || a.forEach((u) => { + i += $s(h.id, u, h.styles); + }), Gr(h.textStyles) || (i += $s(h.id, "tspan", h.textStyles)); + } + } + return i; +}, Vb = (t, e, i, r) => { + const n = Gb(t, i), o = w_(e, n, t.themeVariables); + return gn(ty(`${r}{${o}}`), iy); +}, Xb = (t = "", e, i) => { + let r = t; + return !i && !e && (r = r.replace( + /marker-end="url\([\d+./:=?A-Za-z-]*?#/g, + 'marker-end="url(#' + )), r = q0(r), r = r.replace(/
    /g, "
    "), r; +}, Kb = (t = "", e) => { + var n, o; + const i = (o = (n = e == null ? void 0 : e.viewBox) == null ? void 0 : n.baseVal) != null && o.height ? e.viewBox.baseVal.height + "px" : Pb, r = btoa('' + t + ""); + return ``; +}, Is = (t, e, i, r, n) => { + const o = t.append("div"); + o.attr("id", i), r && o.attr("style", r); + const s = o.append("svg").attr("id", e).attr("width", "100%").attr("xmlns", Ib); + return n && s.attr("xmlns:xlink", n), s.append("g"), t; +}; +function Ds(t, e) { + return t.append("iframe").attr("id", e).attr("style", "width: 100%; height: 100%;").attr("sandbox", ""); +} +const Zb = (t, e, i, r) => { + var n, o, s; + (n = t.getElementById(e)) == null || n.remove(), (o = t.getElementById(i)) == null || o.remove(), (s = t.getElementById(r)) == null || s.remove(); +}, Jb = async function(t, e, i) { + var Nt, M, k, C, w, x; + Kn(); + const r = eh(e); + e = r.code; + const n = $t(); + L.debug(n), e.length > ((n == null ? void 0 : n.maxTextSize) ?? Eb) && (e = Mb); + const o = "#" + t, s = "i" + t, a = "#" + s, l = "d" + t, h = "#" + l; + let u = bt("body"); + const f = n.securityLevel === Ob, c = n.securityLevel === $b, d = n.fontFamily; + if (i !== void 0) { + if (i && (i.innerHTML = ""), f) { + const b = Ds(bt(i), s); + u = bt(b.nodes()[0].contentDocument.body), u.node().style.margin = 0; + } else + u = bt(i); + Is(u, t, l, `font-family: ${d}`, Db); + } else { + if (Zb(document, t, l, s), f) { + const b = Ds(bt("body"), s); + u = bt(b.nodes()[0].contentDocument.body), u.node().style.margin = 0; + } else + u = bt("body"); + Is(u, t, l); + } + let m, S; + try { + m = await to(e, { title: r.title }); + } catch (b) { + m = new ql("error"), S = b; + } + const O = u.select(h).node(), z = m.type, T = O.firstChild, R = T.firstChild, X = (M = (Nt = m.renderer).getClasses) == null ? void 0 : M.call(Nt, e, m), G = Vb(n, z, X, o), V = document.createElement("style"); + V.innerHTML = G, T.insertBefore(V, R); + try { + await m.renderer.draw(e, t, _s, m); + } catch (b) { + throw H_.draw(e, t, _s), b; + } + const H = u.select(`${h} svg`), oe = (C = (k = m.db).getAccTitle) == null ? void 0 : C.call(k), Kt = (x = (w = m.db).getAccDescription) == null ? void 0 : x.call(w); + t1(z, H, oe, Kt), u.select(`[id="${t}"]`).selectAll("foreignobject > *").attr("xmlns", Nb); + let P = u.select(h).node().innerHTML; + if (L.debug("config.arrowMarkerAbsolute", n.arrowMarkerAbsolute), P = Xb(P, f, La(n.arrowMarkerAbsolute)), f) { + const b = u.select(h + " svg").node(); + P = Kb(P, b); + } else + c || (P = Ee.sanitize(P, { + ADD_TAGS: jb, + ADD_ATTR: Ub + })); + if (dC(), S) + throw S; + const Ct = bt(f ? a : h).node(); + return Ct && "remove" in Ct && Ct.remove(), { + svg: P, + bindFunctions: m.db.bindFunctions + }; +}; +function Qb(t = {}) { + var i; + t != null && t.fontFamily && !((i = t.themeVariables) != null && i.fontFamily) && (t.themeVariables || (t.themeVariables = {}), t.themeVariables.fontFamily = t.fontFamily), ny(t), t != null && t.theme && t.theme in Gt ? t.themeVariables = Gt[t.theme].getThemeVariables( + t.themeVariables + ) : t && (t.themeVariables = Gt.default.getThemeVariables(t.themeVariables)); + const e = typeof t == "object" ? ry(t) : fl(); + bn(e.logLevel), Kn(); +} +const to = (t, e = {}) => { + const { code: i } = th(t); + return fC(i, e); +}; +function t1(t, e, i, r) { + IC(e, t), DC(e, i, r, e.attr("id")); +} +const me = Object.freeze({ + render: Jb, + parse: Yb, + getDiagramFromText: to, + initialize: Qb, + getConfig: $t, + setConfig: dl, + getSiteConfig: fl, + updateSiteConfig: oy, + reset: () => { + or(); + }, + globalReset: () => { + or($e); + }, + defaultConfig: $e +}); +bn($t().logLevel); +or($t()); +const e1 = async () => { + L.debug("Loading registered diagrams"); + const e = (await Promise.allSettled( + Object.entries(Me).map(async ([i, { detector: r, loader: n }]) => { + if (n) + try { + Xn(i); + } catch { + try { + const { diagram: s, id: a } = await n(); + ar(a, s, r); + } catch (s) { + throw L.error(`Failed to load external diagram with key ${i}. Removing from detectors.`), delete Me[i], s; + } + } + }) + )).filter((i) => i.status === "rejected"); + if (e.length > 0) { + L.error(`Failed to load ${e.length} external diagrams`); + for (const i of e) + L.error(i); + throw new Error(`Failed to load ${e.length} external diagrams`); + } +}, i1 = (t, e, i) => { + L.warn(t), rl(t) ? (i && i(t.str, t.hash), e.push({ ...t, message: t.str, error: t })) : (i && i(t), t instanceof Error && e.push({ + str: t.message, + message: t.message, + hash: t.name, + error: t + })); +}, ih = async function(t = { + querySelector: ".mermaid" +}) { + try { + await r1(t); + } catch (e) { + if (rl(e) && L.error(e.str), Tt.parseError && Tt.parseError(e), !t.suppressErrors) + throw L.error("Use the suppressErrors option to suppress these errors"), e; + } +}, r1 = async function({ postRenderCallback: t, querySelector: e, nodes: i } = { + querySelector: ".mermaid" +}) { + const r = me.getConfig(); + L.debug(`${t ? "" : "No "}Callback function found`); + let n; + if (i) + n = i; + else if (e) + n = document.querySelectorAll(e); + else + throw new Error("Nodes and querySelector are both undefined"); + L.debug(`Found ${n.length} diagrams`), (r == null ? void 0 : r.startOnLoad) !== void 0 && (L.debug("Start On Load: " + (r == null ? void 0 : r.startOnLoad)), me.updateSiteConfig({ startOnLoad: r == null ? void 0 : r.startOnLoad })); + const o = new ei.InitIDGenerator(r.deterministicIds, r.deterministicIDSeed); + let s; + const a = []; + for (const l of Array.from(n)) { + L.info("Rendering diagram: " + l.id); + /*! Check if previously processed */ + if (l.getAttribute("data-processed")) + continue; + l.setAttribute("data-processed", "true"); + const h = `mermaid-${o.next()}`; + s = l.innerHTML, s = mh(ei.entityDecode(s)).trim().replace(//gi, "
    "); + const u = ei.detectInit(s); + u && L.debug("Detected early reinit: ", u); + try { + const { svg: f, bindFunctions: c } = await sh(h, s, l); + l.innerHTML = f, t && await t(h), c && c(l); + } catch (f) { + i1(f, a, Tt.parseError); + } + } + if (a.length > 0) + throw a[0]; +}, rh = function(t) { + me.initialize(t); +}, n1 = async function(t, e, i) { + L.warn("mermaid.init is deprecated. Please use run instead."), t && rh(t); + const r = { postRenderCallback: i, querySelector: ".mermaid" }; + typeof e == "string" ? r.querySelector = e : e && (e instanceof HTMLElement ? r.nodes = [e] : r.nodes = e), await ih(r); +}, o1 = async (t, { + lazyLoad: e = !0 +} = {}) => { + Pa(...t), e === !1 && await e1(); +}, nh = function() { + if (Tt.startOnLoad) { + const { startOnLoad: t } = me.getConfig(); + t && Tt.run().catch((e) => L.error("Mermaid failed to initialize", e)); + } +}; +if (typeof document < "u") { + /*! + * Wait for document loaded before starting the execution + */ + window.addEventListener("load", nh, !1); +} +const s1 = function(t) { + Tt.parseError = t; +}, ur = []; +let Zr = !1; +const oh = async () => { + if (!Zr) { + for (Zr = !0; ur.length > 0; ) { + const t = ur.shift(); + if (t) + try { + await t(); + } catch (e) { + L.error("Error executing queue", e); + } + } + Zr = !1; + } +}, a1 = async (t, e) => new Promise((i, r) => { + const n = () => new Promise((o, s) => { + me.parse(t, e).then( + (a) => { + o(a), i(a); + }, + (a) => { + var l; + L.error("Error parsing", a), (l = Tt.parseError) == null || l.call(Tt, a), s(a), r(a); + } + ); + }); + ur.push(n), oh().catch(r); +}), sh = (t, e, i) => new Promise((r, n) => { + const o = () => new Promise((s, a) => { + me.render(t, e, i).then( + (l) => { + s(l), r(l); + }, + (l) => { + var h; + L.error("Error parsing", l), (h = Tt.parseError) == null || h.call(Tt, l), a(l), n(l); + } + ); + }); + ur.push(o), oh().catch(n); +}), Tt = { + startOnLoad: !0, + mermaidAPI: me, + parse: a1, + render: sh, + init: n1, + run: ih, + registerExternalDiagrams: o1, + initialize: rh, + parseError: void 0, + contentLoaded: nh, + setParseErrorHandler: s1, + detectType: xr +}; +export { + vn as $, + ei as A, + Je as B, + M_ as C, + O_ as D, + B_ as E, + Pf as F, + C1 as G, + L0 as H, + R_ as I, + Sn as J, + Js as K, + pi as L, + uu as M, + ea as N, + l1 as O, + yh as P, + _h as Q, + pt as R, + yt as S, + xh as T, + z_ as U, + m1 as V, + yp as W, + nl as X, + zn as Y, + up as Z, + $t as _, + E_ as a, + Re as a$, + te as a0, + oi as a1, + Mo as a2, + _u as a3, + Qo as a4, + p0 as a5, + x1 as a6, + F0 as a7, + ye as a8, + l0 as a9, + Ro as aA, + g1 as aB, + d1 as aC, + h1 as aD, + c1 as aE, + _1 as aF, + y1 as aG, + f1 as aH, + $ as aI, + Ot as aJ, + _i as aK, + Ne as aL, + tr as aM, + Um as aN, + _C as aO, + yi as aP, + ir as aQ, + Pm as aR, + Ua as aS, + Dg as aT, + Ng as aU, + AC as aV, + us as aW, + Rg as aX, + Nn as aY, + $g as aZ, + Hg as a_, + Qm as aa, + Dt as ab, + h0 as ac, + c0 as ad, + Ja as ae, + br as af, + vr as ag, + rr as ah, + Mg as ai, + Dn as aj, + tl as ak, + Za as al, + Rm as am, + Mm as an, + t0 as ao, + d0 as ap, + gi as aq, + w1 as ar, + $_ as as, + mi as at, + F as au, + E as av, + An as aw, + u1 as ax, + p1 as ay, + Po as az, + L_ as b, + ne as b0, + ss as b1, + Rn as b2, + Ga as b3, + _n as b4, + Kg as b5, + Gr as b6, + q0 as b7, + mh as b8, + Tt as b9, + Vn as c, + ai as d, + Rs as e, + $n as f, + A_ as g, + st as h, + nr as i, + bt as j, + Ol as k, + L as l, + I0 as m, + Df as n, + B0 as o, + La as p, + x0 as q, + Od as r, + F_ as s, + k_ as t, + v1 as u, + Zs as v, + O0 as w, + Fh as x, + sm as y, + In as z +}; diff --git a/0.6.0/js/mermaid/mermaid-dcacb631.js b/0.6.0/js/mermaid/mermaid-dcacb631.js new file mode 100644 index 0000000..d10cc9a --- /dev/null +++ b/0.6.0/js/mermaid/mermaid-dcacb631.js @@ -0,0 +1,12793 @@ +function dedent(templ) { + var values = []; + for (var _i = 1; _i < arguments.length; _i++) { + values[_i - 1] = arguments[_i]; + } + var strings = Array.from(typeof templ === "string" ? [templ] : templ); + strings[strings.length - 1] = strings[strings.length - 1].replace(/\r?\n([\t ]*)$/, ""); + var indentLengths = strings.reduce(function(arr, str2) { + var matches = str2.match(/\n([\t ]+|(?!\s).)/g); + if (matches) { + return arr.concat(matches.map(function(match) { + var _a, _b; + return (_b = (_a = match.match(/[\t ]/g)) === null || _a === void 0 ? void 0 : _a.length) !== null && _b !== void 0 ? _b : 0; + })); + } + return arr; + }, []); + if (indentLengths.length) { + var pattern_1 = new RegExp("\n[ ]{" + Math.min.apply(Math, indentLengths) + "}", "g"); + strings = strings.map(function(str2) { + return str2.replace(pattern_1, "\n"); + }); + } + strings[0] = strings[0].replace(/^\r?\n/, ""); + var string = strings[0]; + values.forEach(function(value, i) { + var endentations = string.match(/(?:^|\n)( *)$/); + var endentation = endentations ? endentations[1] : ""; + var indentedValue = value; + if (typeof value === "string" && value.includes("\n")) { + indentedValue = String(value).split("\n").map(function(str2, i2) { + return i2 === 0 ? str2 : "" + endentation + str2; + }).join("\n"); + } + string += indentedValue + strings[i + 1]; + }); + return string; +} +var commonjsGlobal = typeof globalThis !== "undefined" ? globalThis : typeof window !== "undefined" ? window : typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : {}; +function getDefaultExportFromCjs(x) { + return x && x.__esModule && Object.prototype.hasOwnProperty.call(x, "default") ? x["default"] : x; +} +var dayjs_min = { exports: {} }; +(function(module2, exports2) { + !function(t, e) { + module2.exports = e(); + }(commonjsGlobal, function() { + var t = 1e3, e = 6e4, n = 36e5, r = "millisecond", i = "second", s = "minute", u = "hour", a = "day", o = "week", c = "month", f = "quarter", h = "year", d = "date", l = "Invalid Date", $ = /^(\d{4})[-/]?(\d{1,2})?[-/]?(\d{0,2})[Tt\s]*(\d{1,2})?:?(\d{1,2})?:?(\d{1,2})?[.:]?(\d+)?$/, y = /\[([^\]]+)]|Y{1,4}|M{1,4}|D{1,2}|d{1,4}|H{1,2}|h{1,2}|a|A|m{1,2}|s{1,2}|Z{1,2}|SSS/g, M = { name: "en", weekdays: "Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday".split("_"), months: "January_February_March_April_May_June_July_August_September_October_November_December".split("_"), ordinal: function(t2) { + var e2 = ["th", "st", "nd", "rd"], n2 = t2 % 100; + return "[" + t2 + (e2[(n2 - 20) % 10] || e2[n2] || e2[0]) + "]"; + } }, m = function(t2, e2, n2) { + var r2 = String(t2); + return !r2 || r2.length >= e2 ? t2 : "" + Array(e2 + 1 - r2.length).join(n2) + t2; + }, v = { s: m, z: function(t2) { + var e2 = -t2.utcOffset(), n2 = Math.abs(e2), r2 = Math.floor(n2 / 60), i2 = n2 % 60; + return (e2 <= 0 ? "+" : "-") + m(r2, 2, "0") + ":" + m(i2, 2, "0"); + }, m: function t2(e2, n2) { + if (e2.date() < n2.date()) + return -t2(n2, e2); + var r2 = 12 * (n2.year() - e2.year()) + (n2.month() - e2.month()), i2 = e2.clone().add(r2, c), s2 = n2 - i2 < 0, u2 = e2.clone().add(r2 + (s2 ? -1 : 1), c); + return +(-(r2 + (n2 - i2) / (s2 ? i2 - u2 : u2 - i2)) || 0); + }, a: function(t2) { + return t2 < 0 ? Math.ceil(t2) || 0 : Math.floor(t2); + }, p: function(t2) { + return { M: c, y: h, w: o, d: a, D: d, h: u, m: s, s: i, ms: r, Q: f }[t2] || String(t2 || "").toLowerCase().replace(/s$/, ""); + }, u: function(t2) { + return void 0 === t2; + } }, g = "en", D = {}; + D[g] = M; + var p = "$isDayjsObject", S = function(t2) { + return t2 instanceof _2 || !(!t2 || !t2[p]); + }, w = function t2(e2, n2, r2) { + var i2; + if (!e2) + return g; + if ("string" == typeof e2) { + var s2 = e2.toLowerCase(); + D[s2] && (i2 = s2), n2 && (D[s2] = n2, i2 = s2); + var u2 = e2.split("-"); + if (!i2 && u2.length > 1) + return t2(u2[0]); + } else { + var a2 = e2.name; + D[a2] = e2, i2 = a2; + } + return !r2 && i2 && (g = i2), i2 || !r2 && g; + }, O = function(t2, e2) { + if (S(t2)) + return t2.clone(); + var n2 = "object" == typeof e2 ? e2 : {}; + return n2.date = t2, n2.args = arguments, new _2(n2); + }, b = v; + b.l = w, b.i = S, b.w = function(t2, e2) { + return O(t2, { locale: e2.$L, utc: e2.$u, x: e2.$x, $offset: e2.$offset }); + }; + var _2 = function() { + function M2(t2) { + this.$L = w(t2.locale, null, true), this.parse(t2), this.$x = this.$x || t2.x || {}, this[p] = true; + } + var m2 = M2.prototype; + return m2.parse = function(t2) { + this.$d = function(t3) { + var e2 = t3.date, n2 = t3.utc; + if (null === e2) + return /* @__PURE__ */ new Date(NaN); + if (b.u(e2)) + return /* @__PURE__ */ new Date(); + if (e2 instanceof Date) + return new Date(e2); + if ("string" == typeof e2 && !/Z$/i.test(e2)) { + var r2 = e2.match($); + if (r2) { + var i2 = r2[2] - 1 || 0, s2 = (r2[7] || "0").substring(0, 3); + return n2 ? new Date(Date.UTC(r2[1], i2, r2[3] || 1, r2[4] || 0, r2[5] || 0, r2[6] || 0, s2)) : new Date(r2[1], i2, r2[3] || 1, r2[4] || 0, r2[5] || 0, r2[6] || 0, s2); + } + } + return new Date(e2); + }(t2), this.init(); + }, m2.init = function() { + var t2 = this.$d; + this.$y = t2.getFullYear(), this.$M = t2.getMonth(), this.$D = t2.getDate(), this.$W = t2.getDay(), this.$H = t2.getHours(), this.$m = t2.getMinutes(), this.$s = t2.getSeconds(), this.$ms = t2.getMilliseconds(); + }, m2.$utils = function() { + return b; + }, m2.isValid = function() { + return !(this.$d.toString() === l); + }, m2.isSame = function(t2, e2) { + var n2 = O(t2); + return this.startOf(e2) <= n2 && n2 <= this.endOf(e2); + }, m2.isAfter = function(t2, e2) { + return O(t2) < this.startOf(e2); + }, m2.isBefore = function(t2, e2) { + return this.endOf(e2) < O(t2); + }, m2.$g = function(t2, e2, n2) { + return b.u(t2) ? this[e2] : this.set(n2, t2); + }, m2.unix = function() { + return Math.floor(this.valueOf() / 1e3); + }, m2.valueOf = function() { + return this.$d.getTime(); + }, m2.startOf = function(t2, e2) { + var n2 = this, r2 = !!b.u(e2) || e2, f2 = b.p(t2), l2 = function(t3, e3) { + var i2 = b.w(n2.$u ? Date.UTC(n2.$y, e3, t3) : new Date(n2.$y, e3, t3), n2); + return r2 ? i2 : i2.endOf(a); + }, $2 = function(t3, e3) { + return b.w(n2.toDate()[t3].apply(n2.toDate("s"), (r2 ? [0, 0, 0, 0] : [23, 59, 59, 999]).slice(e3)), n2); + }, y2 = this.$W, M3 = this.$M, m3 = this.$D, v2 = "set" + (this.$u ? "UTC" : ""); + switch (f2) { + case h: + return r2 ? l2(1, 0) : l2(31, 11); + case c: + return r2 ? l2(1, M3) : l2(0, M3 + 1); + case o: + var g2 = this.$locale().weekStart || 0, D2 = (y2 < g2 ? y2 + 7 : y2) - g2; + return l2(r2 ? m3 - D2 : m3 + (6 - D2), M3); + case a: + case d: + return $2(v2 + "Hours", 0); + case u: + return $2(v2 + "Minutes", 1); + case s: + return $2(v2 + "Seconds", 2); + case i: + return $2(v2 + "Milliseconds", 3); + default: + return this.clone(); + } + }, m2.endOf = function(t2) { + return this.startOf(t2, false); + }, m2.$set = function(t2, e2) { + var n2, o2 = b.p(t2), f2 = "set" + (this.$u ? "UTC" : ""), l2 = (n2 = {}, n2[a] = f2 + "Date", n2[d] = f2 + "Date", n2[c] = f2 + "Month", n2[h] = f2 + "FullYear", n2[u] = f2 + "Hours", n2[s] = f2 + "Minutes", n2[i] = f2 + "Seconds", n2[r] = f2 + "Milliseconds", n2)[o2], $2 = o2 === a ? this.$D + (e2 - this.$W) : e2; + if (o2 === c || o2 === h) { + var y2 = this.clone().set(d, 1); + y2.$d[l2]($2), y2.init(), this.$d = y2.set(d, Math.min(this.$D, y2.daysInMonth())).$d; + } else + l2 && this.$d[l2]($2); + return this.init(), this; + }, m2.set = function(t2, e2) { + return this.clone().$set(t2, e2); + }, m2.get = function(t2) { + return this[b.p(t2)](); + }, m2.add = function(r2, f2) { + var d2, l2 = this; + r2 = Number(r2); + var $2 = b.p(f2), y2 = function(t2) { + var e2 = O(l2); + return b.w(e2.date(e2.date() + Math.round(t2 * r2)), l2); + }; + if ($2 === c) + return this.set(c, this.$M + r2); + if ($2 === h) + return this.set(h, this.$y + r2); + if ($2 === a) + return y2(1); + if ($2 === o) + return y2(7); + var M3 = (d2 = {}, d2[s] = e, d2[u] = n, d2[i] = t, d2)[$2] || 1, m3 = this.$d.getTime() + r2 * M3; + return b.w(m3, this); + }, m2.subtract = function(t2, e2) { + return this.add(-1 * t2, e2); + }, m2.format = function(t2) { + var e2 = this, n2 = this.$locale(); + if (!this.isValid()) + return n2.invalidDate || l; + var r2 = t2 || "YYYY-MM-DDTHH:mm:ssZ", i2 = b.z(this), s2 = this.$H, u2 = this.$m, a2 = this.$M, o2 = n2.weekdays, c2 = n2.months, f2 = n2.meridiem, h2 = function(t3, n3, i3, s3) { + return t3 && (t3[n3] || t3(e2, r2)) || i3[n3].slice(0, s3); + }, d2 = function(t3) { + return b.s(s2 % 12 || 12, t3, "0"); + }, $2 = f2 || function(t3, e3, n3) { + var r3 = t3 < 12 ? "AM" : "PM"; + return n3 ? r3.toLowerCase() : r3; + }; + return r2.replace(y, function(t3, r3) { + return r3 || function(t4) { + switch (t4) { + case "YY": + return String(e2.$y).slice(-2); + case "YYYY": + return b.s(e2.$y, 4, "0"); + case "M": + return a2 + 1; + case "MM": + return b.s(a2 + 1, 2, "0"); + case "MMM": + return h2(n2.monthsShort, a2, c2, 3); + case "MMMM": + return h2(c2, a2); + case "D": + return e2.$D; + case "DD": + return b.s(e2.$D, 2, "0"); + case "d": + return String(e2.$W); + case "dd": + return h2(n2.weekdaysMin, e2.$W, o2, 2); + case "ddd": + return h2(n2.weekdaysShort, e2.$W, o2, 3); + case "dddd": + return o2[e2.$W]; + case "H": + return String(s2); + case "HH": + return b.s(s2, 2, "0"); + case "h": + return d2(1); + case "hh": + return d2(2); + case "a": + return $2(s2, u2, true); + case "A": + return $2(s2, u2, false); + case "m": + return String(u2); + case "mm": + return b.s(u2, 2, "0"); + case "s": + return String(e2.$s); + case "ss": + return b.s(e2.$s, 2, "0"); + case "SSS": + return b.s(e2.$ms, 3, "0"); + case "Z": + return i2; + } + return null; + }(t3) || i2.replace(":", ""); + }); + }, m2.utcOffset = function() { + return 15 * -Math.round(this.$d.getTimezoneOffset() / 15); + }, m2.diff = function(r2, d2, l2) { + var $2, y2 = this, M3 = b.p(d2), m3 = O(r2), v2 = (m3.utcOffset() - this.utcOffset()) * e, g2 = this - m3, D2 = function() { + return b.m(y2, m3); + }; + switch (M3) { + case h: + $2 = D2() / 12; + break; + case c: + $2 = D2(); + break; + case f: + $2 = D2() / 3; + break; + case o: + $2 = (g2 - v2) / 6048e5; + break; + case a: + $2 = (g2 - v2) / 864e5; + break; + case u: + $2 = g2 / n; + break; + case s: + $2 = g2 / e; + break; + case i: + $2 = g2 / t; + break; + default: + $2 = g2; + } + return l2 ? $2 : b.a($2); + }, m2.daysInMonth = function() { + return this.endOf(c).$D; + }, m2.$locale = function() { + return D[this.$L]; + }, m2.locale = function(t2, e2) { + if (!t2) + return this.$L; + var n2 = this.clone(), r2 = w(t2, e2, true); + return r2 && (n2.$L = r2), n2; + }, m2.clone = function() { + return b.w(this.$d, this); + }, m2.toDate = function() { + return new Date(this.valueOf()); + }, m2.toJSON = function() { + return this.isValid() ? this.toISOString() : null; + }, m2.toISOString = function() { + return this.$d.toISOString(); + }, m2.toString = function() { + return this.$d.toUTCString(); + }, M2; + }(), k = _2.prototype; + return O.prototype = k, [["$ms", r], ["$s", i], ["$m", s], ["$H", u], ["$W", a], ["$M", c], ["$y", h], ["$D", d]].forEach(function(t2) { + k[t2[1]] = function(e2) { + return this.$g(e2, t2[0], t2[1]); + }; + }), O.extend = function(t2, e2) { + return t2.$i || (t2(e2, _2, O), t2.$i = true), O; + }, O.locale = w, O.isDayjs = S, O.unix = function(t2) { + return O(1e3 * t2); + }, O.en = D[g], O.Ls = D, O.p = {}, O; + }); +})(dayjs_min); +var dayjs_minExports = dayjs_min.exports; +const dayjs = /* @__PURE__ */ getDefaultExportFromCjs(dayjs_minExports); +const LEVELS = { + trace: 0, + debug: 1, + info: 2, + warn: 3, + error: 4, + fatal: 5 +}; +const log$1 = { + trace: (..._args) => { + }, + debug: (..._args) => { + }, + info: (..._args) => { + }, + warn: (..._args) => { + }, + error: (..._args) => { + }, + fatal: (..._args) => { + } +}; +const setLogLevel$1 = function(level = "fatal") { + let numericLevel = LEVELS.fatal; + if (typeof level === "string") { + level = level.toLowerCase(); + if (level in LEVELS) { + numericLevel = LEVELS[level]; + } + } else if (typeof level === "number") { + numericLevel = level; + } + log$1.trace = () => { + }; + log$1.debug = () => { + }; + log$1.info = () => { + }; + log$1.warn = () => { + }; + log$1.error = () => { + }; + log$1.fatal = () => { + }; + if (numericLevel <= LEVELS.fatal) { + log$1.fatal = console.error ? console.error.bind(console, format("FATAL"), "color: orange") : console.log.bind(console, "\x1B[35m", format("FATAL")); + } + if (numericLevel <= LEVELS.error) { + log$1.error = console.error ? console.error.bind(console, format("ERROR"), "color: orange") : console.log.bind(console, "\x1B[31m", format("ERROR")); + } + if (numericLevel <= LEVELS.warn) { + log$1.warn = console.warn ? console.warn.bind(console, format("WARN"), "color: orange") : console.log.bind(console, `\x1B[33m`, format("WARN")); + } + if (numericLevel <= LEVELS.info) { + log$1.info = console.info ? console.info.bind(console, format("INFO"), "color: lightblue") : console.log.bind(console, "\x1B[34m", format("INFO")); + } + if (numericLevel <= LEVELS.debug) { + log$1.debug = console.debug ? console.debug.bind(console, format("DEBUG"), "color: lightgreen") : console.log.bind(console, "\x1B[32m", format("DEBUG")); + } + if (numericLevel <= LEVELS.trace) { + log$1.trace = console.debug ? console.debug.bind(console, format("TRACE"), "color: lightgreen") : console.log.bind(console, "\x1B[32m", format("TRACE")); + } +}; +const format = (level) => { + const time = dayjs().format("ss.SSS"); + return `%c${time} : ${level} : `; +}; +var dist = {}; +(function(exports2) { + Object.defineProperty(exports2, "__esModule", { value: true }); + exports2.sanitizeUrl = exports2.BLANK_URL = void 0; + var invalidProtocolRegex = /^([^\w]*)(javascript|data|vbscript)/im; + var htmlEntitiesRegex = /&#(\w+)(^\w|;)?/g; + var htmlCtrlEntityRegex = /&(newline|tab);/gi; + var ctrlCharactersRegex = /[\u0000-\u001F\u007F-\u009F\u2000-\u200D\uFEFF]/gim; + var urlSchemeRegex = /^.+(:|:)/gim; + var relativeFirstCharacters = [".", "/"]; + exports2.BLANK_URL = "about:blank"; + function isRelativeUrlWithoutProtocol(url) { + return relativeFirstCharacters.indexOf(url[0]) > -1; + } + function decodeHtmlCharacters(str2) { + var removedNullByte = str2.replace(ctrlCharactersRegex, ""); + return removedNullByte.replace(htmlEntitiesRegex, function(match, dec) { + return String.fromCharCode(dec); + }); + } + function sanitizeUrl(url) { + if (!url) { + return exports2.BLANK_URL; + } + var sanitizedUrl = decodeHtmlCharacters(url).replace(htmlCtrlEntityRegex, "").replace(ctrlCharactersRegex, "").trim(); + if (!sanitizedUrl) { + return exports2.BLANK_URL; + } + if (isRelativeUrlWithoutProtocol(sanitizedUrl)) { + return sanitizedUrl; + } + var urlSchemeParseResults = sanitizedUrl.match(urlSchemeRegex); + if (!urlSchemeParseResults) { + return sanitizedUrl; + } + var urlScheme = urlSchemeParseResults[0]; + if (invalidProtocolRegex.test(urlScheme)) { + return exports2.BLANK_URL; + } + return sanitizedUrl; + } + exports2.sanitizeUrl = sanitizeUrl; +})(dist); +var noop$1 = { value: () => { +} }; +function dispatch() { + for (var i = 0, n = arguments.length, _2 = {}, t; i < n; ++i) { + if (!(t = arguments[i] + "") || t in _2 || /[\s.]/.test(t)) + throw new Error("illegal type: " + t); + _2[t] = []; + } + return new Dispatch(_2); +} +function Dispatch(_2) { + this._ = _2; +} +function parseTypenames$1(typenames, types) { + return typenames.trim().split(/^|\s+/).map(function(t) { + var name = "", i = t.indexOf("."); + if (i >= 0) + name = t.slice(i + 1), t = t.slice(0, i); + if (t && !types.hasOwnProperty(t)) + throw new Error("unknown type: " + t); + return { type: t, name }; + }); +} +Dispatch.prototype = dispatch.prototype = { + constructor: Dispatch, + on: function(typename, callback) { + var _2 = this._, T = parseTypenames$1(typename + "", _2), t, i = -1, n = T.length; + if (arguments.length < 2) { + while (++i < n) + if ((t = (typename = T[i]).type) && (t = get$1(_2[t], typename.name))) + return t; + return; + } + if (callback != null && typeof callback !== "function") + throw new Error("invalid callback: " + callback); + while (++i < n) { + if (t = (typename = T[i]).type) + _2[t] = set$2(_2[t], typename.name, callback); + else if (callback == null) + for (t in _2) + _2[t] = set$2(_2[t], typename.name, null); + } + return this; + }, + copy: function() { + var copy = {}, _2 = this._; + for (var t in _2) + copy[t] = _2[t].slice(); + return new Dispatch(copy); + }, + call: function(type2, that) { + if ((n = arguments.length - 2) > 0) + for (var args = new Array(n), i = 0, n, t; i < n; ++i) + args[i] = arguments[i + 2]; + if (!this._.hasOwnProperty(type2)) + throw new Error("unknown type: " + type2); + for (t = this._[type2], i = 0, n = t.length; i < n; ++i) + t[i].value.apply(that, args); + }, + apply: function(type2, that, args) { + if (!this._.hasOwnProperty(type2)) + throw new Error("unknown type: " + type2); + for (var t = this._[type2], i = 0, n = t.length; i < n; ++i) + t[i].value.apply(that, args); + } +}; +function get$1(type2, name) { + for (var i = 0, n = type2.length, c; i < n; ++i) { + if ((c = type2[i]).name === name) { + return c.value; + } + } +} +function set$2(type2, name, callback) { + for (var i = 0, n = type2.length; i < n; ++i) { + if (type2[i].name === name) { + type2[i] = noop$1, type2 = type2.slice(0, i).concat(type2.slice(i + 1)); + break; + } + } + if (callback != null) + type2.push({ name, value: callback }); + return type2; +} +var xhtml = "http://www.w3.org/1999/xhtml"; +const namespaces = { + svg: "http://www.w3.org/2000/svg", + xhtml, + xlink: "http://www.w3.org/1999/xlink", + xml: "http://www.w3.org/XML/1998/namespace", + xmlns: "http://www.w3.org/2000/xmlns/" +}; +function namespace(name) { + var prefix = name += "", i = prefix.indexOf(":"); + if (i >= 0 && (prefix = name.slice(0, i)) !== "xmlns") + name = name.slice(i + 1); + return namespaces.hasOwnProperty(prefix) ? { space: namespaces[prefix], local: name } : name; +} +function creatorInherit(name) { + return function() { + var document2 = this.ownerDocument, uri = this.namespaceURI; + return uri === xhtml && document2.documentElement.namespaceURI === xhtml ? document2.createElement(name) : document2.createElementNS(uri, name); + }; +} +function creatorFixed(fullname) { + return function() { + return this.ownerDocument.createElementNS(fullname.space, fullname.local); + }; +} +function creator(name) { + var fullname = namespace(name); + return (fullname.local ? creatorFixed : creatorInherit)(fullname); +} +function none() { +} +function selector(selector2) { + return selector2 == null ? none : function() { + return this.querySelector(selector2); + }; +} +function selection_select(select) { + if (typeof select !== "function") + select = selector(select); + for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) { + for (var group = groups[j], n = group.length, subgroup = subgroups[j] = new Array(n), node2, subnode, i = 0; i < n; ++i) { + if ((node2 = group[i]) && (subnode = select.call(node2, node2.__data__, i, group))) { + if ("__data__" in node2) + subnode.__data__ = node2.__data__; + subgroup[i] = subnode; + } + } + } + return new Selection$1(subgroups, this._parents); +} +function array(x) { + return x == null ? [] : Array.isArray(x) ? x : Array.from(x); +} +function empty() { + return []; +} +function selectorAll(selector2) { + return selector2 == null ? empty : function() { + return this.querySelectorAll(selector2); + }; +} +function arrayAll(select) { + return function() { + return array(select.apply(this, arguments)); + }; +} +function selection_selectAll(select) { + if (typeof select === "function") + select = arrayAll(select); + else + select = selectorAll(select); + for (var groups = this._groups, m = groups.length, subgroups = [], parents = [], j = 0; j < m; ++j) { + for (var group = groups[j], n = group.length, node2, i = 0; i < n; ++i) { + if (node2 = group[i]) { + subgroups.push(select.call(node2, node2.__data__, i, group)); + parents.push(node2); + } + } + } + return new Selection$1(subgroups, parents); +} +function matcher(selector2) { + return function() { + return this.matches(selector2); + }; +} +function childMatcher(selector2) { + return function(node2) { + return node2.matches(selector2); + }; +} +var find = Array.prototype.find; +function childFind(match) { + return function() { + return find.call(this.children, match); + }; +} +function childFirst() { + return this.firstElementChild; +} +function selection_selectChild(match) { + return this.select(match == null ? childFirst : childFind(typeof match === "function" ? match : childMatcher(match))); +} +var filter = Array.prototype.filter; +function children() { + return Array.from(this.children); +} +function childrenFilter(match) { + return function() { + return filter.call(this.children, match); + }; +} +function selection_selectChildren(match) { + return this.selectAll(match == null ? children : childrenFilter(typeof match === "function" ? match : childMatcher(match))); +} +function selection_filter(match) { + if (typeof match !== "function") + match = matcher(match); + for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) { + for (var group = groups[j], n = group.length, subgroup = subgroups[j] = [], node2, i = 0; i < n; ++i) { + if ((node2 = group[i]) && match.call(node2, node2.__data__, i, group)) { + subgroup.push(node2); + } + } + } + return new Selection$1(subgroups, this._parents); +} +function sparse(update) { + return new Array(update.length); +} +function selection_enter() { + return new Selection$1(this._enter || this._groups.map(sparse), this._parents); +} +function EnterNode(parent, datum2) { + this.ownerDocument = parent.ownerDocument; + this.namespaceURI = parent.namespaceURI; + this._next = null; + this._parent = parent; + this.__data__ = datum2; +} +EnterNode.prototype = { + constructor: EnterNode, + appendChild: function(child) { + return this._parent.insertBefore(child, this._next); + }, + insertBefore: function(child, next2) { + return this._parent.insertBefore(child, next2); + }, + querySelector: function(selector2) { + return this._parent.querySelector(selector2); + }, + querySelectorAll: function(selector2) { + return this._parent.querySelectorAll(selector2); + } +}; +function constant$2(x) { + return function() { + return x; + }; +} +function bindIndex(parent, group, enter, update, exit, data) { + var i = 0, node2, groupLength = group.length, dataLength = data.length; + for (; i < dataLength; ++i) { + if (node2 = group[i]) { + node2.__data__ = data[i]; + update[i] = node2; + } else { + enter[i] = new EnterNode(parent, data[i]); + } + } + for (; i < groupLength; ++i) { + if (node2 = group[i]) { + exit[i] = node2; + } + } +} +function bindKey(parent, group, enter, update, exit, data, key) { + var i, node2, nodeByKeyValue = /* @__PURE__ */ new Map(), groupLength = group.length, dataLength = data.length, keyValues = new Array(groupLength), keyValue; + for (i = 0; i < groupLength; ++i) { + if (node2 = group[i]) { + keyValues[i] = keyValue = key.call(node2, node2.__data__, i, group) + ""; + if (nodeByKeyValue.has(keyValue)) { + exit[i] = node2; + } else { + nodeByKeyValue.set(keyValue, node2); + } + } + } + for (i = 0; i < dataLength; ++i) { + keyValue = key.call(parent, data[i], i, data) + ""; + if (node2 = nodeByKeyValue.get(keyValue)) { + update[i] = node2; + node2.__data__ = data[i]; + nodeByKeyValue.delete(keyValue); + } else { + enter[i] = new EnterNode(parent, data[i]); + } + } + for (i = 0; i < groupLength; ++i) { + if ((node2 = group[i]) && nodeByKeyValue.get(keyValues[i]) === node2) { + exit[i] = node2; + } + } +} +function datum(node2) { + return node2.__data__; +} +function selection_data(value, key) { + if (!arguments.length) + return Array.from(this, datum); + var bind = key ? bindKey : bindIndex, parents = this._parents, groups = this._groups; + if (typeof value !== "function") + value = constant$2(value); + for (var m = groups.length, update = new Array(m), enter = new Array(m), exit = new Array(m), j = 0; j < m; ++j) { + var parent = parents[j], group = groups[j], groupLength = group.length, data = arraylike(value.call(parent, parent && parent.__data__, j, parents)), dataLength = data.length, enterGroup = enter[j] = new Array(dataLength), updateGroup = update[j] = new Array(dataLength), exitGroup = exit[j] = new Array(groupLength); + bind(parent, group, enterGroup, updateGroup, exitGroup, data, key); + for (var i0 = 0, i1 = 0, previous, next2; i0 < dataLength; ++i0) { + if (previous = enterGroup[i0]) { + if (i0 >= i1) + i1 = i0 + 1; + while (!(next2 = updateGroup[i1]) && ++i1 < dataLength) + ; + previous._next = next2 || null; + } + } + } + update = new Selection$1(update, parents); + update._enter = enter; + update._exit = exit; + return update; +} +function arraylike(data) { + return typeof data === "object" && "length" in data ? data : Array.from(data); +} +function selection_exit() { + return new Selection$1(this._exit || this._groups.map(sparse), this._parents); +} +function selection_join(onenter, onupdate, onexit) { + var enter = this.enter(), update = this, exit = this.exit(); + if (typeof onenter === "function") { + enter = onenter(enter); + if (enter) + enter = enter.selection(); + } else { + enter = enter.append(onenter + ""); + } + if (onupdate != null) { + update = onupdate(update); + if (update) + update = update.selection(); + } + if (onexit == null) + exit.remove(); + else + onexit(exit); + return enter && update ? enter.merge(update).order() : update; +} +function selection_merge(context) { + var selection2 = context.selection ? context.selection() : context; + for (var groups0 = this._groups, groups1 = selection2._groups, m0 = groups0.length, m1 = groups1.length, m = Math.min(m0, m1), merges = new Array(m0), j = 0; j < m; ++j) { + for (var group0 = groups0[j], group1 = groups1[j], n = group0.length, merge2 = merges[j] = new Array(n), node2, i = 0; i < n; ++i) { + if (node2 = group0[i] || group1[i]) { + merge2[i] = node2; + } + } + } + for (; j < m0; ++j) { + merges[j] = groups0[j]; + } + return new Selection$1(merges, this._parents); +} +function selection_order() { + for (var groups = this._groups, j = -1, m = groups.length; ++j < m; ) { + for (var group = groups[j], i = group.length - 1, next2 = group[i], node2; --i >= 0; ) { + if (node2 = group[i]) { + if (next2 && node2.compareDocumentPosition(next2) ^ 4) + next2.parentNode.insertBefore(node2, next2); + next2 = node2; + } + } + } + return this; +} +function selection_sort(compare) { + if (!compare) + compare = ascending; + function compareNode(a, b) { + return a && b ? compare(a.__data__, b.__data__) : !a - !b; + } + for (var groups = this._groups, m = groups.length, sortgroups = new Array(m), j = 0; j < m; ++j) { + for (var group = groups[j], n = group.length, sortgroup = sortgroups[j] = new Array(n), node2, i = 0; i < n; ++i) { + if (node2 = group[i]) { + sortgroup[i] = node2; + } + } + sortgroup.sort(compareNode); + } + return new Selection$1(sortgroups, this._parents).order(); +} +function ascending(a, b) { + return a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN; +} +function selection_call() { + var callback = arguments[0]; + arguments[0] = this; + callback.apply(null, arguments); + return this; +} +function selection_nodes() { + return Array.from(this); +} +function selection_node() { + for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) { + for (var group = groups[j], i = 0, n = group.length; i < n; ++i) { + var node2 = group[i]; + if (node2) + return node2; + } + } + return null; +} +function selection_size() { + let size = 0; + for (const node2 of this) + ++size; + return size; +} +function selection_empty() { + return !this.node(); +} +function selection_each(callback) { + for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) { + for (var group = groups[j], i = 0, n = group.length, node2; i < n; ++i) { + if (node2 = group[i]) + callback.call(node2, node2.__data__, i, group); + } + } + return this; +} +function attrRemove$1(name) { + return function() { + this.removeAttribute(name); + }; +} +function attrRemoveNS$1(fullname) { + return function() { + this.removeAttributeNS(fullname.space, fullname.local); + }; +} +function attrConstant$1(name, value) { + return function() { + this.setAttribute(name, value); + }; +} +function attrConstantNS$1(fullname, value) { + return function() { + this.setAttributeNS(fullname.space, fullname.local, value); + }; +} +function attrFunction$1(name, value) { + return function() { + var v = value.apply(this, arguments); + if (v == null) + this.removeAttribute(name); + else + this.setAttribute(name, v); + }; +} +function attrFunctionNS$1(fullname, value) { + return function() { + var v = value.apply(this, arguments); + if (v == null) + this.removeAttributeNS(fullname.space, fullname.local); + else + this.setAttributeNS(fullname.space, fullname.local, v); + }; +} +function selection_attr(name, value) { + var fullname = namespace(name); + if (arguments.length < 2) { + var node2 = this.node(); + return fullname.local ? node2.getAttributeNS(fullname.space, fullname.local) : node2.getAttribute(fullname); + } + return this.each((value == null ? fullname.local ? attrRemoveNS$1 : attrRemove$1 : typeof value === "function" ? fullname.local ? attrFunctionNS$1 : attrFunction$1 : fullname.local ? attrConstantNS$1 : attrConstant$1)(fullname, value)); +} +function defaultView(node2) { + return node2.ownerDocument && node2.ownerDocument.defaultView || node2.document && node2 || node2.defaultView; +} +function styleRemove$1(name) { + return function() { + this.style.removeProperty(name); + }; +} +function styleConstant$1(name, value, priority) { + return function() { + this.style.setProperty(name, value, priority); + }; +} +function styleFunction$1(name, value, priority) { + return function() { + var v = value.apply(this, arguments); + if (v == null) + this.style.removeProperty(name); + else + this.style.setProperty(name, v, priority); + }; +} +function selection_style(name, value, priority) { + return arguments.length > 1 ? this.each((value == null ? styleRemove$1 : typeof value === "function" ? styleFunction$1 : styleConstant$1)(name, value, priority == null ? "" : priority)) : styleValue(this.node(), name); +} +function styleValue(node2, name) { + return node2.style.getPropertyValue(name) || defaultView(node2).getComputedStyle(node2, null).getPropertyValue(name); +} +function propertyRemove(name) { + return function() { + delete this[name]; + }; +} +function propertyConstant(name, value) { + return function() { + this[name] = value; + }; +} +function propertyFunction(name, value) { + return function() { + var v = value.apply(this, arguments); + if (v == null) + delete this[name]; + else + this[name] = v; + }; +} +function selection_property(name, value) { + return arguments.length > 1 ? this.each((value == null ? propertyRemove : typeof value === "function" ? propertyFunction : propertyConstant)(name, value)) : this.node()[name]; +} +function classArray(string) { + return string.trim().split(/^|\s+/); +} +function classList(node2) { + return node2.classList || new ClassList(node2); +} +function ClassList(node2) { + this._node = node2; + this._names = classArray(node2.getAttribute("class") || ""); +} +ClassList.prototype = { + add: function(name) { + var i = this._names.indexOf(name); + if (i < 0) { + this._names.push(name); + this._node.setAttribute("class", this._names.join(" ")); + } + }, + remove: function(name) { + var i = this._names.indexOf(name); + if (i >= 0) { + this._names.splice(i, 1); + this._node.setAttribute("class", this._names.join(" ")); + } + }, + contains: function(name) { + return this._names.indexOf(name) >= 0; + } +}; +function classedAdd(node2, names) { + var list = classList(node2), i = -1, n = names.length; + while (++i < n) + list.add(names[i]); +} +function classedRemove(node2, names) { + var list = classList(node2), i = -1, n = names.length; + while (++i < n) + list.remove(names[i]); +} +function classedTrue(names) { + return function() { + classedAdd(this, names); + }; +} +function classedFalse(names) { + return function() { + classedRemove(this, names); + }; +} +function classedFunction(names, value) { + return function() { + (value.apply(this, arguments) ? classedAdd : classedRemove)(this, names); + }; +} +function selection_classed(name, value) { + var names = classArray(name + ""); + if (arguments.length < 2) { + var list = classList(this.node()), i = -1, n = names.length; + while (++i < n) + if (!list.contains(names[i])) + return false; + return true; + } + return this.each((typeof value === "function" ? classedFunction : value ? classedTrue : classedFalse)(names, value)); +} +function textRemove() { + this.textContent = ""; +} +function textConstant$1(value) { + return function() { + this.textContent = value; + }; +} +function textFunction$1(value) { + return function() { + var v = value.apply(this, arguments); + this.textContent = v == null ? "" : v; + }; +} +function selection_text(value) { + return arguments.length ? this.each(value == null ? textRemove : (typeof value === "function" ? textFunction$1 : textConstant$1)(value)) : this.node().textContent; +} +function htmlRemove() { + this.innerHTML = ""; +} +function htmlConstant(value) { + return function() { + this.innerHTML = value; + }; +} +function htmlFunction(value) { + return function() { + var v = value.apply(this, arguments); + this.innerHTML = v == null ? "" : v; + }; +} +function selection_html(value) { + return arguments.length ? this.each(value == null ? htmlRemove : (typeof value === "function" ? htmlFunction : htmlConstant)(value)) : this.node().innerHTML; +} +function raise() { + if (this.nextSibling) + this.parentNode.appendChild(this); +} +function selection_raise() { + return this.each(raise); +} +function lower() { + if (this.previousSibling) + this.parentNode.insertBefore(this, this.parentNode.firstChild); +} +function selection_lower() { + return this.each(lower); +} +function selection_append(name) { + var create2 = typeof name === "function" ? name : creator(name); + return this.select(function() { + return this.appendChild(create2.apply(this, arguments)); + }); +} +function constantNull() { + return null; +} +function selection_insert(name, before) { + var create2 = typeof name === "function" ? name : creator(name), select = before == null ? constantNull : typeof before === "function" ? before : selector(before); + return this.select(function() { + return this.insertBefore(create2.apply(this, arguments), select.apply(this, arguments) || null); + }); +} +function remove() { + var parent = this.parentNode; + if (parent) + parent.removeChild(this); +} +function selection_remove() { + return this.each(remove); +} +function selection_cloneShallow() { + var clone2 = this.cloneNode(false), parent = this.parentNode; + return parent ? parent.insertBefore(clone2, this.nextSibling) : clone2; +} +function selection_cloneDeep() { + var clone2 = this.cloneNode(true), parent = this.parentNode; + return parent ? parent.insertBefore(clone2, this.nextSibling) : clone2; +} +function selection_clone(deep) { + return this.select(deep ? selection_cloneDeep : selection_cloneShallow); +} +function selection_datum(value) { + return arguments.length ? this.property("__data__", value) : this.node().__data__; +} +function contextListener(listener) { + return function(event) { + listener.call(this, event, this.__data__); + }; +} +function parseTypenames(typenames) { + return typenames.trim().split(/^|\s+/).map(function(t) { + var name = "", i = t.indexOf("."); + if (i >= 0) + name = t.slice(i + 1), t = t.slice(0, i); + return { type: t, name }; + }); +} +function onRemove(typename) { + return function() { + var on = this.__on; + if (!on) + return; + for (var j = 0, i = -1, m = on.length, o; j < m; ++j) { + if (o = on[j], (!typename.type || o.type === typename.type) && o.name === typename.name) { + this.removeEventListener(o.type, o.listener, o.options); + } else { + on[++i] = o; + } + } + if (++i) + on.length = i; + else + delete this.__on; + }; +} +function onAdd(typename, value, options) { + return function() { + var on = this.__on, o, listener = contextListener(value); + if (on) + for (var j = 0, m = on.length; j < m; ++j) { + if ((o = on[j]).type === typename.type && o.name === typename.name) { + this.removeEventListener(o.type, o.listener, o.options); + this.addEventListener(o.type, o.listener = listener, o.options = options); + o.value = value; + return; + } + } + this.addEventListener(typename.type, listener, options); + o = { type: typename.type, name: typename.name, value, listener, options }; + if (!on) + this.__on = [o]; + else + on.push(o); + }; +} +function selection_on(typename, value, options) { + var typenames = parseTypenames(typename + ""), i, n = typenames.length, t; + if (arguments.length < 2) { + var on = this.node().__on; + if (on) + for (var j = 0, m = on.length, o; j < m; ++j) { + for (i = 0, o = on[j]; i < n; ++i) { + if ((t = typenames[i]).type === o.type && t.name === o.name) { + return o.value; + } + } + } + return; + } + on = value ? onAdd : onRemove; + for (i = 0; i < n; ++i) + this.each(on(typenames[i], value, options)); + return this; +} +function dispatchEvent(node2, type2, params) { + var window2 = defaultView(node2), event = window2.CustomEvent; + if (typeof event === "function") { + event = new event(type2, params); + } else { + event = window2.document.createEvent("Event"); + if (params) + event.initEvent(type2, params.bubbles, params.cancelable), event.detail = params.detail; + else + event.initEvent(type2, false, false); + } + node2.dispatchEvent(event); +} +function dispatchConstant(type2, params) { + return function() { + return dispatchEvent(this, type2, params); + }; +} +function dispatchFunction(type2, params) { + return function() { + return dispatchEvent(this, type2, params.apply(this, arguments)); + }; +} +function selection_dispatch(type2, params) { + return this.each((typeof params === "function" ? dispatchFunction : dispatchConstant)(type2, params)); +} +function* selection_iterator() { + for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) { + for (var group = groups[j], i = 0, n = group.length, node2; i < n; ++i) { + if (node2 = group[i]) + yield node2; + } + } +} +var root$2 = [null]; +function Selection$1(groups, parents) { + this._groups = groups; + this._parents = parents; +} +function selection() { + return new Selection$1([[document.documentElement]], root$2); +} +function selection_selection() { + return this; +} +Selection$1.prototype = selection.prototype = { + constructor: Selection$1, + select: selection_select, + selectAll: selection_selectAll, + selectChild: selection_selectChild, + selectChildren: selection_selectChildren, + filter: selection_filter, + data: selection_data, + enter: selection_enter, + exit: selection_exit, + join: selection_join, + merge: selection_merge, + selection: selection_selection, + order: selection_order, + sort: selection_sort, + call: selection_call, + nodes: selection_nodes, + node: selection_node, + size: selection_size, + empty: selection_empty, + each: selection_each, + attr: selection_attr, + style: selection_style, + property: selection_property, + classed: selection_classed, + text: selection_text, + html: selection_html, + raise: selection_raise, + lower: selection_lower, + append: selection_append, + insert: selection_insert, + remove: selection_remove, + clone: selection_clone, + datum: selection_datum, + on: selection_on, + dispatch: selection_dispatch, + [Symbol.iterator]: selection_iterator +}; +function d3select(selector2) { + return typeof selector2 === "string" ? new Selection$1([[document.querySelector(selector2)]], [document.documentElement]) : new Selection$1([[selector2]], root$2); +} +function define(constructor, factory, prototype) { + constructor.prototype = factory.prototype = prototype; + prototype.constructor = constructor; +} +function extend$1(parent, definition) { + var prototype = Object.create(parent.prototype); + for (var key in definition) + prototype[key] = definition[key]; + return prototype; +} +function Color$2() { +} +var darker = 0.7; +var brighter = 1 / darker; +var reI = "\\s*([+-]?\\d+)\\s*", reN = "\\s*([+-]?(?:\\d*\\.)?\\d+(?:[eE][+-]?\\d+)?)\\s*", reP = "\\s*([+-]?(?:\\d*\\.)?\\d+(?:[eE][+-]?\\d+)?)%\\s*", reHex = /^#([0-9a-f]{3,8})$/, reRgbInteger = new RegExp(`^rgb\\(${reI},${reI},${reI}\\)$`), reRgbPercent = new RegExp(`^rgb\\(${reP},${reP},${reP}\\)$`), reRgbaInteger = new RegExp(`^rgba\\(${reI},${reI},${reI},${reN}\\)$`), reRgbaPercent = new RegExp(`^rgba\\(${reP},${reP},${reP},${reN}\\)$`), reHslPercent = new RegExp(`^hsl\\(${reN},${reP},${reP}\\)$`), reHslaPercent = new RegExp(`^hsla\\(${reN},${reP},${reP},${reN}\\)$`); +var named = { + aliceblue: 15792383, + antiquewhite: 16444375, + aqua: 65535, + aquamarine: 8388564, + azure: 15794175, + beige: 16119260, + bisque: 16770244, + black: 0, + blanchedalmond: 16772045, + blue: 255, + blueviolet: 9055202, + brown: 10824234, + burlywood: 14596231, + cadetblue: 6266528, + chartreuse: 8388352, + chocolate: 13789470, + coral: 16744272, + cornflowerblue: 6591981, + cornsilk: 16775388, + crimson: 14423100, + cyan: 65535, + darkblue: 139, + darkcyan: 35723, + darkgoldenrod: 12092939, + darkgray: 11119017, + darkgreen: 25600, + darkgrey: 11119017, + darkkhaki: 12433259, + darkmagenta: 9109643, + darkolivegreen: 5597999, + darkorange: 16747520, + darkorchid: 10040012, + darkred: 9109504, + darksalmon: 15308410, + darkseagreen: 9419919, + darkslateblue: 4734347, + darkslategray: 3100495, + darkslategrey: 3100495, + darkturquoise: 52945, + darkviolet: 9699539, + deeppink: 16716947, + deepskyblue: 49151, + dimgray: 6908265, + dimgrey: 6908265, + dodgerblue: 2003199, + firebrick: 11674146, + floralwhite: 16775920, + forestgreen: 2263842, + fuchsia: 16711935, + gainsboro: 14474460, + ghostwhite: 16316671, + gold: 16766720, + goldenrod: 14329120, + gray: 8421504, + green: 32768, + greenyellow: 11403055, + grey: 8421504, + honeydew: 15794160, + hotpink: 16738740, + indianred: 13458524, + indigo: 4915330, + ivory: 16777200, + khaki: 15787660, + lavender: 15132410, + lavenderblush: 16773365, + lawngreen: 8190976, + lemonchiffon: 16775885, + lightblue: 11393254, + lightcoral: 15761536, + lightcyan: 14745599, + lightgoldenrodyellow: 16448210, + lightgray: 13882323, + lightgreen: 9498256, + lightgrey: 13882323, + lightpink: 16758465, + lightsalmon: 16752762, + lightseagreen: 2142890, + lightskyblue: 8900346, + lightslategray: 7833753, + lightslategrey: 7833753, + lightsteelblue: 11584734, + lightyellow: 16777184, + lime: 65280, + limegreen: 3329330, + linen: 16445670, + magenta: 16711935, + maroon: 8388608, + mediumaquamarine: 6737322, + mediumblue: 205, + mediumorchid: 12211667, + mediumpurple: 9662683, + mediumseagreen: 3978097, + mediumslateblue: 8087790, + mediumspringgreen: 64154, + mediumturquoise: 4772300, + mediumvioletred: 13047173, + midnightblue: 1644912, + mintcream: 16121850, + mistyrose: 16770273, + moccasin: 16770229, + navajowhite: 16768685, + navy: 128, + oldlace: 16643558, + olive: 8421376, + olivedrab: 7048739, + orange: 16753920, + orangered: 16729344, + orchid: 14315734, + palegoldenrod: 15657130, + palegreen: 10025880, + paleturquoise: 11529966, + palevioletred: 14381203, + papayawhip: 16773077, + peachpuff: 16767673, + peru: 13468991, + pink: 16761035, + plum: 14524637, + powderblue: 11591910, + purple: 8388736, + rebeccapurple: 6697881, + red: 16711680, + rosybrown: 12357519, + royalblue: 4286945, + saddlebrown: 9127187, + salmon: 16416882, + sandybrown: 16032864, + seagreen: 3050327, + seashell: 16774638, + sienna: 10506797, + silver: 12632256, + skyblue: 8900331, + slateblue: 6970061, + slategray: 7372944, + slategrey: 7372944, + snow: 16775930, + springgreen: 65407, + steelblue: 4620980, + tan: 13808780, + teal: 32896, + thistle: 14204888, + tomato: 16737095, + turquoise: 4251856, + violet: 15631086, + wheat: 16113331, + white: 16777215, + whitesmoke: 16119285, + yellow: 16776960, + yellowgreen: 10145074 +}; +define(Color$2, color, { + copy(channels2) { + return Object.assign(new this.constructor(), this, channels2); + }, + displayable() { + return this.rgb().displayable(); + }, + hex: color_formatHex, + // Deprecated! Use color.formatHex. + formatHex: color_formatHex, + formatHex8: color_formatHex8, + formatHsl: color_formatHsl, + formatRgb: color_formatRgb, + toString: color_formatRgb +}); +function color_formatHex() { + return this.rgb().formatHex(); +} +function color_formatHex8() { + return this.rgb().formatHex8(); +} +function color_formatHsl() { + return hslConvert(this).formatHsl(); +} +function color_formatRgb() { + return this.rgb().formatRgb(); +} +function color(format2) { + var m, l; + format2 = (format2 + "").trim().toLowerCase(); + return (m = reHex.exec(format2)) ? (l = m[1].length, m = parseInt(m[1], 16), l === 6 ? rgbn(m) : l === 3 ? new Rgb(m >> 8 & 15 | m >> 4 & 240, m >> 4 & 15 | m & 240, (m & 15) << 4 | m & 15, 1) : l === 8 ? rgba$2(m >> 24 & 255, m >> 16 & 255, m >> 8 & 255, (m & 255) / 255) : l === 4 ? rgba$2(m >> 12 & 15 | m >> 8 & 240, m >> 8 & 15 | m >> 4 & 240, m >> 4 & 15 | m & 240, ((m & 15) << 4 | m & 15) / 255) : null) : (m = reRgbInteger.exec(format2)) ? new Rgb(m[1], m[2], m[3], 1) : (m = reRgbPercent.exec(format2)) ? new Rgb(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, 1) : (m = reRgbaInteger.exec(format2)) ? rgba$2(m[1], m[2], m[3], m[4]) : (m = reRgbaPercent.exec(format2)) ? rgba$2(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, m[4]) : (m = reHslPercent.exec(format2)) ? hsla(m[1], m[2] / 100, m[3] / 100, 1) : (m = reHslaPercent.exec(format2)) ? hsla(m[1], m[2] / 100, m[3] / 100, m[4]) : named.hasOwnProperty(format2) ? rgbn(named[format2]) : format2 === "transparent" ? new Rgb(NaN, NaN, NaN, 0) : null; +} +function rgbn(n) { + return new Rgb(n >> 16 & 255, n >> 8 & 255, n & 255, 1); +} +function rgba$2(r, g, b, a) { + if (a <= 0) + r = g = b = NaN; + return new Rgb(r, g, b, a); +} +function rgbConvert(o) { + if (!(o instanceof Color$2)) + o = color(o); + if (!o) + return new Rgb(); + o = o.rgb(); + return new Rgb(o.r, o.g, o.b, o.opacity); +} +function rgb(r, g, b, opacity) { + return arguments.length === 1 ? rgbConvert(r) : new Rgb(r, g, b, opacity == null ? 1 : opacity); +} +function Rgb(r, g, b, opacity) { + this.r = +r; + this.g = +g; + this.b = +b; + this.opacity = +opacity; +} +define(Rgb, rgb, extend$1(Color$2, { + brighter(k) { + k = k == null ? brighter : Math.pow(brighter, k); + return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity); + }, + darker(k) { + k = k == null ? darker : Math.pow(darker, k); + return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity); + }, + rgb() { + return this; + }, + clamp() { + return new Rgb(clampi(this.r), clampi(this.g), clampi(this.b), clampa(this.opacity)); + }, + displayable() { + return -0.5 <= this.r && this.r < 255.5 && (-0.5 <= this.g && this.g < 255.5) && (-0.5 <= this.b && this.b < 255.5) && (0 <= this.opacity && this.opacity <= 1); + }, + hex: rgb_formatHex, + // Deprecated! Use color.formatHex. + formatHex: rgb_formatHex, + formatHex8: rgb_formatHex8, + formatRgb: rgb_formatRgb, + toString: rgb_formatRgb +})); +function rgb_formatHex() { + return `#${hex(this.r)}${hex(this.g)}${hex(this.b)}`; +} +function rgb_formatHex8() { + return `#${hex(this.r)}${hex(this.g)}${hex(this.b)}${hex((isNaN(this.opacity) ? 1 : this.opacity) * 255)}`; +} +function rgb_formatRgb() { + const a = clampa(this.opacity); + return `${a === 1 ? "rgb(" : "rgba("}${clampi(this.r)}, ${clampi(this.g)}, ${clampi(this.b)}${a === 1 ? ")" : `, ${a})`}`; +} +function clampa(opacity) { + return isNaN(opacity) ? 1 : Math.max(0, Math.min(1, opacity)); +} +function clampi(value) { + return Math.max(0, Math.min(255, Math.round(value) || 0)); +} +function hex(value) { + value = clampi(value); + return (value < 16 ? "0" : "") + value.toString(16); +} +function hsla(h, s, l, a) { + if (a <= 0) + h = s = l = NaN; + else if (l <= 0 || l >= 1) + h = s = NaN; + else if (s <= 0) + h = NaN; + return new Hsl(h, s, l, a); +} +function hslConvert(o) { + if (o instanceof Hsl) + return new Hsl(o.h, o.s, o.l, o.opacity); + if (!(o instanceof Color$2)) + o = color(o); + if (!o) + return new Hsl(); + if (o instanceof Hsl) + return o; + o = o.rgb(); + var r = o.r / 255, g = o.g / 255, b = o.b / 255, min2 = Math.min(r, g, b), max2 = Math.max(r, g, b), h = NaN, s = max2 - min2, l = (max2 + min2) / 2; + if (s) { + if (r === max2) + h = (g - b) / s + (g < b) * 6; + else if (g === max2) + h = (b - r) / s + 2; + else + h = (r - g) / s + 4; + s /= l < 0.5 ? max2 + min2 : 2 - max2 - min2; + h *= 60; + } else { + s = l > 0 && l < 1 ? 0 : h; + } + return new Hsl(h, s, l, o.opacity); +} +function hsl(h, s, l, opacity) { + return arguments.length === 1 ? hslConvert(h) : new Hsl(h, s, l, opacity == null ? 1 : opacity); +} +function Hsl(h, s, l, opacity) { + this.h = +h; + this.s = +s; + this.l = +l; + this.opacity = +opacity; +} +define(Hsl, hsl, extend$1(Color$2, { + brighter(k) { + k = k == null ? brighter : Math.pow(brighter, k); + return new Hsl(this.h, this.s, this.l * k, this.opacity); + }, + darker(k) { + k = k == null ? darker : Math.pow(darker, k); + return new Hsl(this.h, this.s, this.l * k, this.opacity); + }, + rgb() { + var h = this.h % 360 + (this.h < 0) * 360, s = isNaN(h) || isNaN(this.s) ? 0 : this.s, l = this.l, m2 = l + (l < 0.5 ? l : 1 - l) * s, m1 = 2 * l - m2; + return new Rgb( + hsl2rgb(h >= 240 ? h - 240 : h + 120, m1, m2), + hsl2rgb(h, m1, m2), + hsl2rgb(h < 120 ? h + 240 : h - 120, m1, m2), + this.opacity + ); + }, + clamp() { + return new Hsl(clamph(this.h), clampt(this.s), clampt(this.l), clampa(this.opacity)); + }, + displayable() { + return (0 <= this.s && this.s <= 1 || isNaN(this.s)) && (0 <= this.l && this.l <= 1) && (0 <= this.opacity && this.opacity <= 1); + }, + formatHsl() { + const a = clampa(this.opacity); + return `${a === 1 ? "hsl(" : "hsla("}${clamph(this.h)}, ${clampt(this.s) * 100}%, ${clampt(this.l) * 100}%${a === 1 ? ")" : `, ${a})`}`; + } +})); +function clamph(value) { + value = (value || 0) % 360; + return value < 0 ? value + 360 : value; +} +function clampt(value) { + return Math.max(0, Math.min(1, value || 0)); +} +function hsl2rgb(h, m1, m2) { + return (h < 60 ? m1 + (m2 - m1) * h / 60 : h < 180 ? m2 : h < 240 ? m1 + (m2 - m1) * (240 - h) / 60 : m1) * 255; +} +const constant$1 = (x) => () => x; +function linear(a, d) { + return function(t) { + return a + t * d; + }; +} +function exponential(a, b, y) { + return a = Math.pow(a, y), b = Math.pow(b, y) - a, y = 1 / y, function(t) { + return Math.pow(a + t * b, y); + }; +} +function hue(a, b) { + var d = b - a; + return d ? linear(a, d > 180 || d < -180 ? d - 360 * Math.round(d / 360) : d) : constant$1(isNaN(a) ? b : a); +} +function gamma(y) { + return (y = +y) === 1 ? nogamma : function(a, b) { + return b - a ? exponential(a, b, y) : constant$1(isNaN(a) ? b : a); + }; +} +function nogamma(a, b) { + var d = b - a; + return d ? linear(a, d) : constant$1(isNaN(a) ? b : a); +} +const interpolateRgb = function rgbGamma(y) { + var color2 = gamma(y); + function rgb$1(start2, end) { + var r = color2((start2 = rgb(start2)).r, (end = rgb(end)).r), g = color2(start2.g, end.g), b = color2(start2.b, end.b), opacity = nogamma(start2.opacity, end.opacity); + return function(t) { + start2.r = r(t); + start2.g = g(t); + start2.b = b(t); + start2.opacity = opacity(t); + return start2 + ""; + }; + } + rgb$1.gamma = rgbGamma; + return rgb$1; +}(1); +function interpolateNumber(a, b) { + return a = +a, b = +b, function(t) { + return a * (1 - t) + b * t; + }; +} +var reA = /[-+]?(?:\d+\.?\d*|\.?\d+)(?:[eE][-+]?\d+)?/g, reB = new RegExp(reA.source, "g"); +function zero(b) { + return function() { + return b; + }; +} +function one(b) { + return function(t) { + return b(t) + ""; + }; +} +function interpolateString(a, b) { + var bi = reA.lastIndex = reB.lastIndex = 0, am, bm, bs, i = -1, s = [], q = []; + a = a + "", b = b + ""; + while ((am = reA.exec(a)) && (bm = reB.exec(b))) { + if ((bs = bm.index) > bi) { + bs = b.slice(bi, bs); + if (s[i]) + s[i] += bs; + else + s[++i] = bs; + } + if ((am = am[0]) === (bm = bm[0])) { + if (s[i]) + s[i] += bm; + else + s[++i] = bm; + } else { + s[++i] = null; + q.push({ i, x: interpolateNumber(am, bm) }); + } + bi = reB.lastIndex; + } + if (bi < b.length) { + bs = b.slice(bi); + if (s[i]) + s[i] += bs; + else + s[++i] = bs; + } + return s.length < 2 ? q[0] ? one(q[0].x) : zero(b) : (b = q.length, function(t) { + for (var i2 = 0, o; i2 < b; ++i2) + s[(o = q[i2]).i] = o.x(t); + return s.join(""); + }); +} +var degrees = 180 / Math.PI; +var identity$1 = { + translateX: 0, + translateY: 0, + rotate: 0, + skewX: 0, + scaleX: 1, + scaleY: 1 +}; +function decompose(a, b, c, d, e, f) { + var scaleX, scaleY, skewX; + if (scaleX = Math.sqrt(a * a + b * b)) + a /= scaleX, b /= scaleX; + if (skewX = a * c + b * d) + c -= a * skewX, d -= b * skewX; + if (scaleY = Math.sqrt(c * c + d * d)) + c /= scaleY, d /= scaleY, skewX /= scaleY; + if (a * d < b * c) + a = -a, b = -b, skewX = -skewX, scaleX = -scaleX; + return { + translateX: e, + translateY: f, + rotate: Math.atan2(b, a) * degrees, + skewX: Math.atan(skewX) * degrees, + scaleX, + scaleY + }; +} +var svgNode; +function parseCss(value) { + const m = new (typeof DOMMatrix === "function" ? DOMMatrix : WebKitCSSMatrix)(value + ""); + return m.isIdentity ? identity$1 : decompose(m.a, m.b, m.c, m.d, m.e, m.f); +} +function parseSvg(value) { + if (value == null) + return identity$1; + if (!svgNode) + svgNode = document.createElementNS("http://www.w3.org/2000/svg", "g"); + svgNode.setAttribute("transform", value); + if (!(value = svgNode.transform.baseVal.consolidate())) + return identity$1; + value = value.matrix; + return decompose(value.a, value.b, value.c, value.d, value.e, value.f); +} +function interpolateTransform(parse2, pxComma, pxParen, degParen) { + function pop(s) { + return s.length ? s.pop() + " " : ""; + } + function translate(xa, ya, xb, yb, s, q) { + if (xa !== xb || ya !== yb) { + var i = s.push("translate(", null, pxComma, null, pxParen); + q.push({ i: i - 4, x: interpolateNumber(xa, xb) }, { i: i - 2, x: interpolateNumber(ya, yb) }); + } else if (xb || yb) { + s.push("translate(" + xb + pxComma + yb + pxParen); + } + } + function rotate(a, b, s, q) { + if (a !== b) { + if (a - b > 180) + b += 360; + else if (b - a > 180) + a += 360; + q.push({ i: s.push(pop(s) + "rotate(", null, degParen) - 2, x: interpolateNumber(a, b) }); + } else if (b) { + s.push(pop(s) + "rotate(" + b + degParen); + } + } + function skewX(a, b, s, q) { + if (a !== b) { + q.push({ i: s.push(pop(s) + "skewX(", null, degParen) - 2, x: interpolateNumber(a, b) }); + } else if (b) { + s.push(pop(s) + "skewX(" + b + degParen); + } + } + function scale(xa, ya, xb, yb, s, q) { + if (xa !== xb || ya !== yb) { + var i = s.push(pop(s) + "scale(", null, ",", null, ")"); + q.push({ i: i - 4, x: interpolateNumber(xa, xb) }, { i: i - 2, x: interpolateNumber(ya, yb) }); + } else if (xb !== 1 || yb !== 1) { + s.push(pop(s) + "scale(" + xb + "," + yb + ")"); + } + } + return function(a, b) { + var s = [], q = []; + a = parse2(a), b = parse2(b); + translate(a.translateX, a.translateY, b.translateX, b.translateY, s, q); + rotate(a.rotate, b.rotate, s, q); + skewX(a.skewX, b.skewX, s, q); + scale(a.scaleX, a.scaleY, b.scaleX, b.scaleY, s, q); + a = b = null; + return function(t) { + var i = -1, n = q.length, o; + while (++i < n) + s[(o = q[i]).i] = o.x(t); + return s.join(""); + }; + }; +} +var interpolateTransformCss = interpolateTransform(parseCss, "px, ", "px)", "deg)"); +var interpolateTransformSvg = interpolateTransform(parseSvg, ", ", ")", ")"); +var frame = 0, timeout$1 = 0, interval = 0, pokeDelay = 1e3, taskHead, taskTail, clockLast = 0, clockNow = 0, clockSkew = 0, clock = typeof performance === "object" && performance.now ? performance : Date, setFrame = typeof window === "object" && window.requestAnimationFrame ? window.requestAnimationFrame.bind(window) : function(f) { + setTimeout(f, 17); +}; +function now() { + return clockNow || (setFrame(clearNow), clockNow = clock.now() + clockSkew); +} +function clearNow() { + clockNow = 0; +} +function Timer() { + this._call = this._time = this._next = null; +} +Timer.prototype = timer.prototype = { + constructor: Timer, + restart: function(callback, delay, time) { + if (typeof callback !== "function") + throw new TypeError("callback is not a function"); + time = (time == null ? now() : +time) + (delay == null ? 0 : +delay); + if (!this._next && taskTail !== this) { + if (taskTail) + taskTail._next = this; + else + taskHead = this; + taskTail = this; + } + this._call = callback; + this._time = time; + sleep(); + }, + stop: function() { + if (this._call) { + this._call = null; + this._time = Infinity; + sleep(); + } + } +}; +function timer(callback, delay, time) { + var t = new Timer(); + t.restart(callback, delay, time); + return t; +} +function timerFlush() { + now(); + ++frame; + var t = taskHead, e; + while (t) { + if ((e = clockNow - t._time) >= 0) + t._call.call(void 0, e); + t = t._next; + } + --frame; +} +function wake() { + clockNow = (clockLast = clock.now()) + clockSkew; + frame = timeout$1 = 0; + try { + timerFlush(); + } finally { + frame = 0; + nap(); + clockNow = 0; + } +} +function poke() { + var now2 = clock.now(), delay = now2 - clockLast; + if (delay > pokeDelay) + clockSkew -= delay, clockLast = now2; +} +function nap() { + var t0, t1 = taskHead, t2, time = Infinity; + while (t1) { + if (t1._call) { + if (time > t1._time) + time = t1._time; + t0 = t1, t1 = t1._next; + } else { + t2 = t1._next, t1._next = null; + t1 = t0 ? t0._next = t2 : taskHead = t2; + } + } + taskTail = t0; + sleep(time); +} +function sleep(time) { + if (frame) + return; + if (timeout$1) + timeout$1 = clearTimeout(timeout$1); + var delay = time - clockNow; + if (delay > 24) { + if (time < Infinity) + timeout$1 = setTimeout(wake, time - clock.now() - clockSkew); + if (interval) + interval = clearInterval(interval); + } else { + if (!interval) + clockLast = clock.now(), interval = setInterval(poke, pokeDelay); + frame = 1, setFrame(wake); + } +} +function timeout(callback, delay, time) { + var t = new Timer(); + delay = delay == null ? 0 : +delay; + t.restart((elapsed) => { + t.stop(); + callback(elapsed + delay); + }, delay, time); + return t; +} +var emptyOn = dispatch("start", "end", "cancel", "interrupt"); +var emptyTween = []; +var CREATED = 0; +var SCHEDULED = 1; +var STARTING = 2; +var STARTED = 3; +var RUNNING = 4; +var ENDING = 5; +var ENDED = 6; +function schedule(node2, name, id2, index, group, timing) { + var schedules = node2.__transition; + if (!schedules) + node2.__transition = {}; + else if (id2 in schedules) + return; + create$1(node2, id2, { + name, + index, + // For context during callback. + group, + // For context during callback. + on: emptyOn, + tween: emptyTween, + time: timing.time, + delay: timing.delay, + duration: timing.duration, + ease: timing.ease, + timer: null, + state: CREATED + }); +} +function init$1(node2, id2) { + var schedule2 = get(node2, id2); + if (schedule2.state > CREATED) + throw new Error("too late; already scheduled"); + return schedule2; +} +function set$1(node2, id2) { + var schedule2 = get(node2, id2); + if (schedule2.state > STARTED) + throw new Error("too late; already running"); + return schedule2; +} +function get(node2, id2) { + var schedule2 = node2.__transition; + if (!schedule2 || !(schedule2 = schedule2[id2])) + throw new Error("transition not found"); + return schedule2; +} +function create$1(node2, id2, self2) { + var schedules = node2.__transition, tween; + schedules[id2] = self2; + self2.timer = timer(schedule2, 0, self2.time); + function schedule2(elapsed) { + self2.state = SCHEDULED; + self2.timer.restart(start2, self2.delay, self2.time); + if (self2.delay <= elapsed) + start2(elapsed - self2.delay); + } + function start2(elapsed) { + var i, j, n, o; + if (self2.state !== SCHEDULED) + return stop(); + for (i in schedules) { + o = schedules[i]; + if (o.name !== self2.name) + continue; + if (o.state === STARTED) + return timeout(start2); + if (o.state === RUNNING) { + o.state = ENDED; + o.timer.stop(); + o.on.call("interrupt", node2, node2.__data__, o.index, o.group); + delete schedules[i]; + } else if (+i < id2) { + o.state = ENDED; + o.timer.stop(); + o.on.call("cancel", node2, node2.__data__, o.index, o.group); + delete schedules[i]; + } + } + timeout(function() { + if (self2.state === STARTED) { + self2.state = RUNNING; + self2.timer.restart(tick, self2.delay, self2.time); + tick(elapsed); + } + }); + self2.state = STARTING; + self2.on.call("start", node2, node2.__data__, self2.index, self2.group); + if (self2.state !== STARTING) + return; + self2.state = STARTED; + tween = new Array(n = self2.tween.length); + for (i = 0, j = -1; i < n; ++i) { + if (o = self2.tween[i].value.call(node2, node2.__data__, self2.index, self2.group)) { + tween[++j] = o; + } + } + tween.length = j + 1; + } + function tick(elapsed) { + var t = elapsed < self2.duration ? self2.ease.call(null, elapsed / self2.duration) : (self2.timer.restart(stop), self2.state = ENDING, 1), i = -1, n = tween.length; + while (++i < n) { + tween[i].call(node2, t); + } + if (self2.state === ENDING) { + self2.on.call("end", node2, node2.__data__, self2.index, self2.group); + stop(); + } + } + function stop() { + self2.state = ENDED; + self2.timer.stop(); + delete schedules[id2]; + for (var i in schedules) + return; + delete node2.__transition; + } +} +function interrupt(node2, name) { + var schedules = node2.__transition, schedule2, active, empty2 = true, i; + if (!schedules) + return; + name = name == null ? null : name + ""; + for (i in schedules) { + if ((schedule2 = schedules[i]).name !== name) { + empty2 = false; + continue; + } + active = schedule2.state > STARTING && schedule2.state < ENDING; + schedule2.state = ENDED; + schedule2.timer.stop(); + schedule2.on.call(active ? "interrupt" : "cancel", node2, node2.__data__, schedule2.index, schedule2.group); + delete schedules[i]; + } + if (empty2) + delete node2.__transition; +} +function selection_interrupt(name) { + return this.each(function() { + interrupt(this, name); + }); +} +function tweenRemove(id2, name) { + var tween0, tween1; + return function() { + var schedule2 = set$1(this, id2), tween = schedule2.tween; + if (tween !== tween0) { + tween1 = tween0 = tween; + for (var i = 0, n = tween1.length; i < n; ++i) { + if (tween1[i].name === name) { + tween1 = tween1.slice(); + tween1.splice(i, 1); + break; + } + } + } + schedule2.tween = tween1; + }; +} +function tweenFunction(id2, name, value) { + var tween0, tween1; + if (typeof value !== "function") + throw new Error(); + return function() { + var schedule2 = set$1(this, id2), tween = schedule2.tween; + if (tween !== tween0) { + tween1 = (tween0 = tween).slice(); + for (var t = { name, value }, i = 0, n = tween1.length; i < n; ++i) { + if (tween1[i].name === name) { + tween1[i] = t; + break; + } + } + if (i === n) + tween1.push(t); + } + schedule2.tween = tween1; + }; +} +function transition_tween(name, value) { + var id2 = this._id; + name += ""; + if (arguments.length < 2) { + var tween = get(this.node(), id2).tween; + for (var i = 0, n = tween.length, t; i < n; ++i) { + if ((t = tween[i]).name === name) { + return t.value; + } + } + return null; + } + return this.each((value == null ? tweenRemove : tweenFunction)(id2, name, value)); +} +function tweenValue(transition, name, value) { + var id2 = transition._id; + transition.each(function() { + var schedule2 = set$1(this, id2); + (schedule2.value || (schedule2.value = {}))[name] = value.apply(this, arguments); + }); + return function(node2) { + return get(node2, id2).value[name]; + }; +} +function interpolate(a, b) { + var c; + return (typeof b === "number" ? interpolateNumber : b instanceof color ? interpolateRgb : (c = color(b)) ? (b = c, interpolateRgb) : interpolateString)(a, b); +} +function attrRemove(name) { + return function() { + this.removeAttribute(name); + }; +} +function attrRemoveNS(fullname) { + return function() { + this.removeAttributeNS(fullname.space, fullname.local); + }; +} +function attrConstant(name, interpolate2, value1) { + var string00, string1 = value1 + "", interpolate0; + return function() { + var string0 = this.getAttribute(name); + return string0 === string1 ? null : string0 === string00 ? interpolate0 : interpolate0 = interpolate2(string00 = string0, value1); + }; +} +function attrConstantNS(fullname, interpolate2, value1) { + var string00, string1 = value1 + "", interpolate0; + return function() { + var string0 = this.getAttributeNS(fullname.space, fullname.local); + return string0 === string1 ? null : string0 === string00 ? interpolate0 : interpolate0 = interpolate2(string00 = string0, value1); + }; +} +function attrFunction(name, interpolate2, value) { + var string00, string10, interpolate0; + return function() { + var string0, value1 = value(this), string1; + if (value1 == null) + return void this.removeAttribute(name); + string0 = this.getAttribute(name); + string1 = value1 + ""; + return string0 === string1 ? null : string0 === string00 && string1 === string10 ? interpolate0 : (string10 = string1, interpolate0 = interpolate2(string00 = string0, value1)); + }; +} +function attrFunctionNS(fullname, interpolate2, value) { + var string00, string10, interpolate0; + return function() { + var string0, value1 = value(this), string1; + if (value1 == null) + return void this.removeAttributeNS(fullname.space, fullname.local); + string0 = this.getAttributeNS(fullname.space, fullname.local); + string1 = value1 + ""; + return string0 === string1 ? null : string0 === string00 && string1 === string10 ? interpolate0 : (string10 = string1, interpolate0 = interpolate2(string00 = string0, value1)); + }; +} +function transition_attr(name, value) { + var fullname = namespace(name), i = fullname === "transform" ? interpolateTransformSvg : interpolate; + return this.attrTween(name, typeof value === "function" ? (fullname.local ? attrFunctionNS : attrFunction)(fullname, i, tweenValue(this, "attr." + name, value)) : value == null ? (fullname.local ? attrRemoveNS : attrRemove)(fullname) : (fullname.local ? attrConstantNS : attrConstant)(fullname, i, value)); +} +function attrInterpolate(name, i) { + return function(t) { + this.setAttribute(name, i.call(this, t)); + }; +} +function attrInterpolateNS(fullname, i) { + return function(t) { + this.setAttributeNS(fullname.space, fullname.local, i.call(this, t)); + }; +} +function attrTweenNS(fullname, value) { + var t0, i0; + function tween() { + var i = value.apply(this, arguments); + if (i !== i0) + t0 = (i0 = i) && attrInterpolateNS(fullname, i); + return t0; + } + tween._value = value; + return tween; +} +function attrTween(name, value) { + var t0, i0; + function tween() { + var i = value.apply(this, arguments); + if (i !== i0) + t0 = (i0 = i) && attrInterpolate(name, i); + return t0; + } + tween._value = value; + return tween; +} +function transition_attrTween(name, value) { + var key = "attr." + name; + if (arguments.length < 2) + return (key = this.tween(key)) && key._value; + if (value == null) + return this.tween(key, null); + if (typeof value !== "function") + throw new Error(); + var fullname = namespace(name); + return this.tween(key, (fullname.local ? attrTweenNS : attrTween)(fullname, value)); +} +function delayFunction(id2, value) { + return function() { + init$1(this, id2).delay = +value.apply(this, arguments); + }; +} +function delayConstant(id2, value) { + return value = +value, function() { + init$1(this, id2).delay = value; + }; +} +function transition_delay(value) { + var id2 = this._id; + return arguments.length ? this.each((typeof value === "function" ? delayFunction : delayConstant)(id2, value)) : get(this.node(), id2).delay; +} +function durationFunction(id2, value) { + return function() { + set$1(this, id2).duration = +value.apply(this, arguments); + }; +} +function durationConstant(id2, value) { + return value = +value, function() { + set$1(this, id2).duration = value; + }; +} +function transition_duration(value) { + var id2 = this._id; + return arguments.length ? this.each((typeof value === "function" ? durationFunction : durationConstant)(id2, value)) : get(this.node(), id2).duration; +} +function easeConstant(id2, value) { + if (typeof value !== "function") + throw new Error(); + return function() { + set$1(this, id2).ease = value; + }; +} +function transition_ease(value) { + var id2 = this._id; + return arguments.length ? this.each(easeConstant(id2, value)) : get(this.node(), id2).ease; +} +function easeVarying(id2, value) { + return function() { + var v = value.apply(this, arguments); + if (typeof v !== "function") + throw new Error(); + set$1(this, id2).ease = v; + }; +} +function transition_easeVarying(value) { + if (typeof value !== "function") + throw new Error(); + return this.each(easeVarying(this._id, value)); +} +function transition_filter(match) { + if (typeof match !== "function") + match = matcher(match); + for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) { + for (var group = groups[j], n = group.length, subgroup = subgroups[j] = [], node2, i = 0; i < n; ++i) { + if ((node2 = group[i]) && match.call(node2, node2.__data__, i, group)) { + subgroup.push(node2); + } + } + } + return new Transition(subgroups, this._parents, this._name, this._id); +} +function transition_merge(transition) { + if (transition._id !== this._id) + throw new Error(); + for (var groups0 = this._groups, groups1 = transition._groups, m0 = groups0.length, m1 = groups1.length, m = Math.min(m0, m1), merges = new Array(m0), j = 0; j < m; ++j) { + for (var group0 = groups0[j], group1 = groups1[j], n = group0.length, merge2 = merges[j] = new Array(n), node2, i = 0; i < n; ++i) { + if (node2 = group0[i] || group1[i]) { + merge2[i] = node2; + } + } + } + for (; j < m0; ++j) { + merges[j] = groups0[j]; + } + return new Transition(merges, this._parents, this._name, this._id); +} +function start(name) { + return (name + "").trim().split(/^|\s+/).every(function(t) { + var i = t.indexOf("."); + if (i >= 0) + t = t.slice(0, i); + return !t || t === "start"; + }); +} +function onFunction(id2, name, listener) { + var on0, on1, sit = start(name) ? init$1 : set$1; + return function() { + var schedule2 = sit(this, id2), on = schedule2.on; + if (on !== on0) + (on1 = (on0 = on).copy()).on(name, listener); + schedule2.on = on1; + }; +} +function transition_on(name, listener) { + var id2 = this._id; + return arguments.length < 2 ? get(this.node(), id2).on.on(name) : this.each(onFunction(id2, name, listener)); +} +function removeFunction(id2) { + return function() { + var parent = this.parentNode; + for (var i in this.__transition) + if (+i !== id2) + return; + if (parent) + parent.removeChild(this); + }; +} +function transition_remove() { + return this.on("end.remove", removeFunction(this._id)); +} +function transition_select(select) { + var name = this._name, id2 = this._id; + if (typeof select !== "function") + select = selector(select); + for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) { + for (var group = groups[j], n = group.length, subgroup = subgroups[j] = new Array(n), node2, subnode, i = 0; i < n; ++i) { + if ((node2 = group[i]) && (subnode = select.call(node2, node2.__data__, i, group))) { + if ("__data__" in node2) + subnode.__data__ = node2.__data__; + subgroup[i] = subnode; + schedule(subgroup[i], name, id2, i, subgroup, get(node2, id2)); + } + } + } + return new Transition(subgroups, this._parents, name, id2); +} +function transition_selectAll(select) { + var name = this._name, id2 = this._id; + if (typeof select !== "function") + select = selectorAll(select); + for (var groups = this._groups, m = groups.length, subgroups = [], parents = [], j = 0; j < m; ++j) { + for (var group = groups[j], n = group.length, node2, i = 0; i < n; ++i) { + if (node2 = group[i]) { + for (var children2 = select.call(node2, node2.__data__, i, group), child, inherit2 = get(node2, id2), k = 0, l = children2.length; k < l; ++k) { + if (child = children2[k]) { + schedule(child, name, id2, k, children2, inherit2); + } + } + subgroups.push(children2); + parents.push(node2); + } + } + } + return new Transition(subgroups, parents, name, id2); +} +var Selection = selection.prototype.constructor; +function transition_selection() { + return new Selection(this._groups, this._parents); +} +function styleNull(name, interpolate2) { + var string00, string10, interpolate0; + return function() { + var string0 = styleValue(this, name), string1 = (this.style.removeProperty(name), styleValue(this, name)); + return string0 === string1 ? null : string0 === string00 && string1 === string10 ? interpolate0 : interpolate0 = interpolate2(string00 = string0, string10 = string1); + }; +} +function styleRemove(name) { + return function() { + this.style.removeProperty(name); + }; +} +function styleConstant(name, interpolate2, value1) { + var string00, string1 = value1 + "", interpolate0; + return function() { + var string0 = styleValue(this, name); + return string0 === string1 ? null : string0 === string00 ? interpolate0 : interpolate0 = interpolate2(string00 = string0, value1); + }; +} +function styleFunction(name, interpolate2, value) { + var string00, string10, interpolate0; + return function() { + var string0 = styleValue(this, name), value1 = value(this), string1 = value1 + ""; + if (value1 == null) + string1 = value1 = (this.style.removeProperty(name), styleValue(this, name)); + return string0 === string1 ? null : string0 === string00 && string1 === string10 ? interpolate0 : (string10 = string1, interpolate0 = interpolate2(string00 = string0, value1)); + }; +} +function styleMaybeRemove(id2, name) { + var on0, on1, listener0, key = "style." + name, event = "end." + key, remove2; + return function() { + var schedule2 = set$1(this, id2), on = schedule2.on, listener = schedule2.value[key] == null ? remove2 || (remove2 = styleRemove(name)) : void 0; + if (on !== on0 || listener0 !== listener) + (on1 = (on0 = on).copy()).on(event, listener0 = listener); + schedule2.on = on1; + }; +} +function transition_style(name, value, priority) { + var i = (name += "") === "transform" ? interpolateTransformCss : interpolate; + return value == null ? this.styleTween(name, styleNull(name, i)).on("end.style." + name, styleRemove(name)) : typeof value === "function" ? this.styleTween(name, styleFunction(name, i, tweenValue(this, "style." + name, value))).each(styleMaybeRemove(this._id, name)) : this.styleTween(name, styleConstant(name, i, value), priority).on("end.style." + name, null); +} +function styleInterpolate(name, i, priority) { + return function(t) { + this.style.setProperty(name, i.call(this, t), priority); + }; +} +function styleTween(name, value, priority) { + var t, i0; + function tween() { + var i = value.apply(this, arguments); + if (i !== i0) + t = (i0 = i) && styleInterpolate(name, i, priority); + return t; + } + tween._value = value; + return tween; +} +function transition_styleTween(name, value, priority) { + var key = "style." + (name += ""); + if (arguments.length < 2) + return (key = this.tween(key)) && key._value; + if (value == null) + return this.tween(key, null); + if (typeof value !== "function") + throw new Error(); + return this.tween(key, styleTween(name, value, priority == null ? "" : priority)); +} +function textConstant(value) { + return function() { + this.textContent = value; + }; +} +function textFunction(value) { + return function() { + var value1 = value(this); + this.textContent = value1 == null ? "" : value1; + }; +} +function transition_text(value) { + return this.tween("text", typeof value === "function" ? textFunction(tweenValue(this, "text", value)) : textConstant(value == null ? "" : value + "")); +} +function textInterpolate(i) { + return function(t) { + this.textContent = i.call(this, t); + }; +} +function textTween(value) { + var t0, i0; + function tween() { + var i = value.apply(this, arguments); + if (i !== i0) + t0 = (i0 = i) && textInterpolate(i); + return t0; + } + tween._value = value; + return tween; +} +function transition_textTween(value) { + var key = "text"; + if (arguments.length < 1) + return (key = this.tween(key)) && key._value; + if (value == null) + return this.tween(key, null); + if (typeof value !== "function") + throw new Error(); + return this.tween(key, textTween(value)); +} +function transition_transition() { + var name = this._name, id0 = this._id, id1 = newId(); + for (var groups = this._groups, m = groups.length, j = 0; j < m; ++j) { + for (var group = groups[j], n = group.length, node2, i = 0; i < n; ++i) { + if (node2 = group[i]) { + var inherit2 = get(node2, id0); + schedule(node2, name, id1, i, group, { + time: inherit2.time + inherit2.delay + inherit2.duration, + delay: 0, + duration: inherit2.duration, + ease: inherit2.ease + }); + } + } + } + return new Transition(groups, this._parents, name, id1); +} +function transition_end() { + var on0, on1, that = this, id2 = that._id, size = that.size(); + return new Promise(function(resolve, reject) { + var cancel = { value: reject }, end = { value: function() { + if (--size === 0) + resolve(); + } }; + that.each(function() { + var schedule2 = set$1(this, id2), on = schedule2.on; + if (on !== on0) { + on1 = (on0 = on).copy(); + on1._.cancel.push(cancel); + on1._.interrupt.push(cancel); + on1._.end.push(end); + } + schedule2.on = on1; + }); + if (size === 0) + resolve(); + }); +} +var id$m = 0; +function Transition(groups, parents, name, id2) { + this._groups = groups; + this._parents = parents; + this._name = name; + this._id = id2; +} +function newId() { + return ++id$m; +} +var selection_prototype = selection.prototype; +Transition.prototype = { + constructor: Transition, + select: transition_select, + selectAll: transition_selectAll, + selectChild: selection_prototype.selectChild, + selectChildren: selection_prototype.selectChildren, + filter: transition_filter, + merge: transition_merge, + selection: transition_selection, + transition: transition_transition, + call: selection_prototype.call, + nodes: selection_prototype.nodes, + node: selection_prototype.node, + size: selection_prototype.size, + empty: selection_prototype.empty, + each: selection_prototype.each, + on: transition_on, + attr: transition_attr, + attrTween: transition_attrTween, + style: transition_style, + styleTween: transition_styleTween, + text: transition_text, + textTween: transition_textTween, + remove: transition_remove, + tween: transition_tween, + delay: transition_delay, + duration: transition_duration, + ease: transition_ease, + easeVarying: transition_easeVarying, + end: transition_end, + [Symbol.iterator]: selection_prototype[Symbol.iterator] +}; +function cubicInOut(t) { + return ((t *= 2) <= 1 ? t * t * t : (t -= 2) * t * t + 2) / 2; +} +var defaultTiming = { + time: null, + // Set on use. + delay: 0, + duration: 250, + ease: cubicInOut +}; +function inherit(node2, id2) { + var timing; + while (!(timing = node2.__transition) || !(timing = timing[id2])) { + if (!(node2 = node2.parentNode)) { + throw new Error(`transition ${id2} not found`); + } + } + return timing; +} +function selection_transition(name) { + var id2, timing; + if (name instanceof Transition) { + id2 = name._id, name = name._name; + } else { + id2 = newId(), (timing = defaultTiming).time = now(), name = name == null ? null : name + ""; + } + for (var groups = this._groups, m = groups.length, j = 0; j < m; ++j) { + for (var group = groups[j], n = group.length, node2, i = 0; i < n; ++i) { + if (node2 = group[i]) { + schedule(node2, name, id2, i, group, timing || inherit(node2, id2)); + } + } + } + return new Transition(groups, this._parents, name, id2); +} +selection.prototype.interrupt = selection_interrupt; +selection.prototype.transition = selection_transition; +const abs$1 = Math.abs; +const atan2 = Math.atan2; +const cos = Math.cos; +const max = Math.max; +const min = Math.min; +const sin = Math.sin; +const sqrt = Math.sqrt; +const epsilon = 1e-12; +const pi = Math.PI; +const halfPi = pi / 2; +const tau = 2 * pi; +function acos(x) { + return x > 1 ? 0 : x < -1 ? pi : Math.acos(x); +} +function asin(x) { + return x >= 1 ? halfPi : x <= -1 ? -halfPi : Math.asin(x); +} +function Linear(context) { + this._context = context; +} +Linear.prototype = { + areaStart: function() { + this._line = 0; + }, + areaEnd: function() { + this._line = NaN; + }, + lineStart: function() { + this._point = 0; + }, + lineEnd: function() { + if (this._line || this._line !== 0 && this._point === 1) + this._context.closePath(); + this._line = 1 - this._line; + }, + point: function(x, y) { + x = +x, y = +y; + switch (this._point) { + case 0: + this._point = 1; + this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); + break; + case 1: + this._point = 2; + default: + this._context.lineTo(x, y); + break; + } + } +}; +function curveLinear(context) { + return new Linear(context); +} +class Bump { + constructor(context, x) { + this._context = context; + this._x = x; + } + areaStart() { + this._line = 0; + } + areaEnd() { + this._line = NaN; + } + lineStart() { + this._point = 0; + } + lineEnd() { + if (this._line || this._line !== 0 && this._point === 1) + this._context.closePath(); + this._line = 1 - this._line; + } + point(x, y) { + x = +x, y = +y; + switch (this._point) { + case 0: { + this._point = 1; + if (this._line) + this._context.lineTo(x, y); + else + this._context.moveTo(x, y); + break; + } + case 1: + this._point = 2; + default: { + if (this._x) + this._context.bezierCurveTo(this._x0 = (this._x0 + x) / 2, this._y0, this._x0, y, x, y); + else + this._context.bezierCurveTo(this._x0, this._y0 = (this._y0 + y) / 2, x, this._y0, x, y); + break; + } + } + this._x0 = x, this._y0 = y; + } +} +function bumpX(context) { + return new Bump(context, true); +} +function bumpY(context) { + return new Bump(context, false); +} +function noop() { +} +function point$3(that, x, y) { + that._context.bezierCurveTo( + (2 * that._x0 + that._x1) / 3, + (2 * that._y0 + that._y1) / 3, + (that._x0 + 2 * that._x1) / 3, + (that._y0 + 2 * that._y1) / 3, + (that._x0 + 4 * that._x1 + x) / 6, + (that._y0 + 4 * that._y1 + y) / 6 + ); +} +function Basis(context) { + this._context = context; +} +Basis.prototype = { + areaStart: function() { + this._line = 0; + }, + areaEnd: function() { + this._line = NaN; + }, + lineStart: function() { + this._x0 = this._x1 = this._y0 = this._y1 = NaN; + this._point = 0; + }, + lineEnd: function() { + switch (this._point) { + case 3: + point$3(this, this._x1, this._y1); + case 2: + this._context.lineTo(this._x1, this._y1); + break; + } + if (this._line || this._line !== 0 && this._point === 1) + this._context.closePath(); + this._line = 1 - this._line; + }, + point: function(x, y) { + x = +x, y = +y; + switch (this._point) { + case 0: + this._point = 1; + this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); + break; + case 1: + this._point = 2; + break; + case 2: + this._point = 3; + this._context.lineTo((5 * this._x0 + this._x1) / 6, (5 * this._y0 + this._y1) / 6); + default: + point$3(this, x, y); + break; + } + this._x0 = this._x1, this._x1 = x; + this._y0 = this._y1, this._y1 = y; + } +}; +function curveBasis(context) { + return new Basis(context); +} +function BasisClosed(context) { + this._context = context; +} +BasisClosed.prototype = { + areaStart: noop, + areaEnd: noop, + lineStart: function() { + this._x0 = this._x1 = this._x2 = this._x3 = this._x4 = this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = NaN; + this._point = 0; + }, + lineEnd: function() { + switch (this._point) { + case 1: { + this._context.moveTo(this._x2, this._y2); + this._context.closePath(); + break; + } + case 2: { + this._context.moveTo((this._x2 + 2 * this._x3) / 3, (this._y2 + 2 * this._y3) / 3); + this._context.lineTo((this._x3 + 2 * this._x2) / 3, (this._y3 + 2 * this._y2) / 3); + this._context.closePath(); + break; + } + case 3: { + this.point(this._x2, this._y2); + this.point(this._x3, this._y3); + this.point(this._x4, this._y4); + break; + } + } + }, + point: function(x, y) { + x = +x, y = +y; + switch (this._point) { + case 0: + this._point = 1; + this._x2 = x, this._y2 = y; + break; + case 1: + this._point = 2; + this._x3 = x, this._y3 = y; + break; + case 2: + this._point = 3; + this._x4 = x, this._y4 = y; + this._context.moveTo((this._x0 + 4 * this._x1 + x) / 6, (this._y0 + 4 * this._y1 + y) / 6); + break; + default: + point$3(this, x, y); + break; + } + this._x0 = this._x1, this._x1 = x; + this._y0 = this._y1, this._y1 = y; + } +}; +function curveBasisClosed(context) { + return new BasisClosed(context); +} +function BasisOpen(context) { + this._context = context; +} +BasisOpen.prototype = { + areaStart: function() { + this._line = 0; + }, + areaEnd: function() { + this._line = NaN; + }, + lineStart: function() { + this._x0 = this._x1 = this._y0 = this._y1 = NaN; + this._point = 0; + }, + lineEnd: function() { + if (this._line || this._line !== 0 && this._point === 3) + this._context.closePath(); + this._line = 1 - this._line; + }, + point: function(x, y) { + x = +x, y = +y; + switch (this._point) { + case 0: + this._point = 1; + break; + case 1: + this._point = 2; + break; + case 2: + this._point = 3; + var x0 = (this._x0 + 4 * this._x1 + x) / 6, y0 = (this._y0 + 4 * this._y1 + y) / 6; + this._line ? this._context.lineTo(x0, y0) : this._context.moveTo(x0, y0); + break; + case 3: + this._point = 4; + default: + point$3(this, x, y); + break; + } + this._x0 = this._x1, this._x1 = x; + this._y0 = this._y1, this._y1 = y; + } +}; +function curveBasisOpen(context) { + return new BasisOpen(context); +} +function Bundle(context, beta) { + this._basis = new Basis(context); + this._beta = beta; +} +Bundle.prototype = { + lineStart: function() { + this._x = []; + this._y = []; + this._basis.lineStart(); + }, + lineEnd: function() { + var x = this._x, y = this._y, j = x.length - 1; + if (j > 0) { + var x0 = x[0], y0 = y[0], dx = x[j] - x0, dy = y[j] - y0, i = -1, t; + while (++i <= j) { + t = i / j; + this._basis.point( + this._beta * x[i] + (1 - this._beta) * (x0 + t * dx), + this._beta * y[i] + (1 - this._beta) * (y0 + t * dy) + ); + } + } + this._x = this._y = null; + this._basis.lineEnd(); + }, + point: function(x, y) { + this._x.push(+x); + this._y.push(+y); + } +}; +const curveBundle = function custom(beta) { + function bundle(context) { + return beta === 1 ? new Basis(context) : new Bundle(context, beta); + } + bundle.beta = function(beta2) { + return custom(+beta2); + }; + return bundle; +}(0.85); +function point$2(that, x, y) { + that._context.bezierCurveTo( + that._x1 + that._k * (that._x2 - that._x0), + that._y1 + that._k * (that._y2 - that._y0), + that._x2 + that._k * (that._x1 - x), + that._y2 + that._k * (that._y1 - y), + that._x2, + that._y2 + ); +} +function Cardinal(context, tension) { + this._context = context; + this._k = (1 - tension) / 6; +} +Cardinal.prototype = { + areaStart: function() { + this._line = 0; + }, + areaEnd: function() { + this._line = NaN; + }, + lineStart: function() { + this._x0 = this._x1 = this._x2 = this._y0 = this._y1 = this._y2 = NaN; + this._point = 0; + }, + lineEnd: function() { + switch (this._point) { + case 2: + this._context.lineTo(this._x2, this._y2); + break; + case 3: + point$2(this, this._x1, this._y1); + break; + } + if (this._line || this._line !== 0 && this._point === 1) + this._context.closePath(); + this._line = 1 - this._line; + }, + point: function(x, y) { + x = +x, y = +y; + switch (this._point) { + case 0: + this._point = 1; + this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); + break; + case 1: + this._point = 2; + this._x1 = x, this._y1 = y; + break; + case 2: + this._point = 3; + default: + point$2(this, x, y); + break; + } + this._x0 = this._x1, this._x1 = this._x2, this._x2 = x; + this._y0 = this._y1, this._y1 = this._y2, this._y2 = y; + } +}; +const curveCardinal = function custom2(tension) { + function cardinal(context) { + return new Cardinal(context, tension); + } + cardinal.tension = function(tension2) { + return custom2(+tension2); + }; + return cardinal; +}(0); +function CardinalClosed(context, tension) { + this._context = context; + this._k = (1 - tension) / 6; +} +CardinalClosed.prototype = { + areaStart: noop, + areaEnd: noop, + lineStart: function() { + this._x0 = this._x1 = this._x2 = this._x3 = this._x4 = this._x5 = this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = this._y5 = NaN; + this._point = 0; + }, + lineEnd: function() { + switch (this._point) { + case 1: { + this._context.moveTo(this._x3, this._y3); + this._context.closePath(); + break; + } + case 2: { + this._context.lineTo(this._x3, this._y3); + this._context.closePath(); + break; + } + case 3: { + this.point(this._x3, this._y3); + this.point(this._x4, this._y4); + this.point(this._x5, this._y5); + break; + } + } + }, + point: function(x, y) { + x = +x, y = +y; + switch (this._point) { + case 0: + this._point = 1; + this._x3 = x, this._y3 = y; + break; + case 1: + this._point = 2; + this._context.moveTo(this._x4 = x, this._y4 = y); + break; + case 2: + this._point = 3; + this._x5 = x, this._y5 = y; + break; + default: + point$2(this, x, y); + break; + } + this._x0 = this._x1, this._x1 = this._x2, this._x2 = x; + this._y0 = this._y1, this._y1 = this._y2, this._y2 = y; + } +}; +const curveCardinalClosed = function custom3(tension) { + function cardinal(context) { + return new CardinalClosed(context, tension); + } + cardinal.tension = function(tension2) { + return custom3(+tension2); + }; + return cardinal; +}(0); +function CardinalOpen(context, tension) { + this._context = context; + this._k = (1 - tension) / 6; +} +CardinalOpen.prototype = { + areaStart: function() { + this._line = 0; + }, + areaEnd: function() { + this._line = NaN; + }, + lineStart: function() { + this._x0 = this._x1 = this._x2 = this._y0 = this._y1 = this._y2 = NaN; + this._point = 0; + }, + lineEnd: function() { + if (this._line || this._line !== 0 && this._point === 3) + this._context.closePath(); + this._line = 1 - this._line; + }, + point: function(x, y) { + x = +x, y = +y; + switch (this._point) { + case 0: + this._point = 1; + break; + case 1: + this._point = 2; + break; + case 2: + this._point = 3; + this._line ? this._context.lineTo(this._x2, this._y2) : this._context.moveTo(this._x2, this._y2); + break; + case 3: + this._point = 4; + default: + point$2(this, x, y); + break; + } + this._x0 = this._x1, this._x1 = this._x2, this._x2 = x; + this._y0 = this._y1, this._y1 = this._y2, this._y2 = y; + } +}; +const curveCardinalOpen = function custom4(tension) { + function cardinal(context) { + return new CardinalOpen(context, tension); + } + cardinal.tension = function(tension2) { + return custom4(+tension2); + }; + return cardinal; +}(0); +function point$1(that, x, y) { + var x1 = that._x1, y1 = that._y1, x2 = that._x2, y2 = that._y2; + if (that._l01_a > epsilon) { + var a = 2 * that._l01_2a + 3 * that._l01_a * that._l12_a + that._l12_2a, n = 3 * that._l01_a * (that._l01_a + that._l12_a); + x1 = (x1 * a - that._x0 * that._l12_2a + that._x2 * that._l01_2a) / n; + y1 = (y1 * a - that._y0 * that._l12_2a + that._y2 * that._l01_2a) / n; + } + if (that._l23_a > epsilon) { + var b = 2 * that._l23_2a + 3 * that._l23_a * that._l12_a + that._l12_2a, m = 3 * that._l23_a * (that._l23_a + that._l12_a); + x2 = (x2 * b + that._x1 * that._l23_2a - x * that._l12_2a) / m; + y2 = (y2 * b + that._y1 * that._l23_2a - y * that._l12_2a) / m; + } + that._context.bezierCurveTo(x1, y1, x2, y2, that._x2, that._y2); +} +function CatmullRom(context, alpha) { + this._context = context; + this._alpha = alpha; +} +CatmullRom.prototype = { + areaStart: function() { + this._line = 0; + }, + areaEnd: function() { + this._line = NaN; + }, + lineStart: function() { + this._x0 = this._x1 = this._x2 = this._y0 = this._y1 = this._y2 = NaN; + this._l01_a = this._l12_a = this._l23_a = this._l01_2a = this._l12_2a = this._l23_2a = this._point = 0; + }, + lineEnd: function() { + switch (this._point) { + case 2: + this._context.lineTo(this._x2, this._y2); + break; + case 3: + this.point(this._x2, this._y2); + break; + } + if (this._line || this._line !== 0 && this._point === 1) + this._context.closePath(); + this._line = 1 - this._line; + }, + point: function(x, y) { + x = +x, y = +y; + if (this._point) { + var x23 = this._x2 - x, y23 = this._y2 - y; + this._l23_a = Math.sqrt(this._l23_2a = Math.pow(x23 * x23 + y23 * y23, this._alpha)); + } + switch (this._point) { + case 0: + this._point = 1; + this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); + break; + case 1: + this._point = 2; + break; + case 2: + this._point = 3; + default: + point$1(this, x, y); + break; + } + this._l01_a = this._l12_a, this._l12_a = this._l23_a; + this._l01_2a = this._l12_2a, this._l12_2a = this._l23_2a; + this._x0 = this._x1, this._x1 = this._x2, this._x2 = x; + this._y0 = this._y1, this._y1 = this._y2, this._y2 = y; + } +}; +const curveCatmullRom = function custom5(alpha) { + function catmullRom(context) { + return alpha ? new CatmullRom(context, alpha) : new Cardinal(context, 0); + } + catmullRom.alpha = function(alpha2) { + return custom5(+alpha2); + }; + return catmullRom; +}(0.5); +function CatmullRomClosed(context, alpha) { + this._context = context; + this._alpha = alpha; +} +CatmullRomClosed.prototype = { + areaStart: noop, + areaEnd: noop, + lineStart: function() { + this._x0 = this._x1 = this._x2 = this._x3 = this._x4 = this._x5 = this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = this._y5 = NaN; + this._l01_a = this._l12_a = this._l23_a = this._l01_2a = this._l12_2a = this._l23_2a = this._point = 0; + }, + lineEnd: function() { + switch (this._point) { + case 1: { + this._context.moveTo(this._x3, this._y3); + this._context.closePath(); + break; + } + case 2: { + this._context.lineTo(this._x3, this._y3); + this._context.closePath(); + break; + } + case 3: { + this.point(this._x3, this._y3); + this.point(this._x4, this._y4); + this.point(this._x5, this._y5); + break; + } + } + }, + point: function(x, y) { + x = +x, y = +y; + if (this._point) { + var x23 = this._x2 - x, y23 = this._y2 - y; + this._l23_a = Math.sqrt(this._l23_2a = Math.pow(x23 * x23 + y23 * y23, this._alpha)); + } + switch (this._point) { + case 0: + this._point = 1; + this._x3 = x, this._y3 = y; + break; + case 1: + this._point = 2; + this._context.moveTo(this._x4 = x, this._y4 = y); + break; + case 2: + this._point = 3; + this._x5 = x, this._y5 = y; + break; + default: + point$1(this, x, y); + break; + } + this._l01_a = this._l12_a, this._l12_a = this._l23_a; + this._l01_2a = this._l12_2a, this._l12_2a = this._l23_2a; + this._x0 = this._x1, this._x1 = this._x2, this._x2 = x; + this._y0 = this._y1, this._y1 = this._y2, this._y2 = y; + } +}; +const curveCatmullRomClosed = function custom6(alpha) { + function catmullRom(context) { + return alpha ? new CatmullRomClosed(context, alpha) : new CardinalClosed(context, 0); + } + catmullRom.alpha = function(alpha2) { + return custom6(+alpha2); + }; + return catmullRom; +}(0.5); +function CatmullRomOpen(context, alpha) { + this._context = context; + this._alpha = alpha; +} +CatmullRomOpen.prototype = { + areaStart: function() { + this._line = 0; + }, + areaEnd: function() { + this._line = NaN; + }, + lineStart: function() { + this._x0 = this._x1 = this._x2 = this._y0 = this._y1 = this._y2 = NaN; + this._l01_a = this._l12_a = this._l23_a = this._l01_2a = this._l12_2a = this._l23_2a = this._point = 0; + }, + lineEnd: function() { + if (this._line || this._line !== 0 && this._point === 3) + this._context.closePath(); + this._line = 1 - this._line; + }, + point: function(x, y) { + x = +x, y = +y; + if (this._point) { + var x23 = this._x2 - x, y23 = this._y2 - y; + this._l23_a = Math.sqrt(this._l23_2a = Math.pow(x23 * x23 + y23 * y23, this._alpha)); + } + switch (this._point) { + case 0: + this._point = 1; + break; + case 1: + this._point = 2; + break; + case 2: + this._point = 3; + this._line ? this._context.lineTo(this._x2, this._y2) : this._context.moveTo(this._x2, this._y2); + break; + case 3: + this._point = 4; + default: + point$1(this, x, y); + break; + } + this._l01_a = this._l12_a, this._l12_a = this._l23_a; + this._l01_2a = this._l12_2a, this._l12_2a = this._l23_2a; + this._x0 = this._x1, this._x1 = this._x2, this._x2 = x; + this._y0 = this._y1, this._y1 = this._y2, this._y2 = y; + } +}; +const curveCatmullRomOpen = function custom7(alpha) { + function catmullRom(context) { + return alpha ? new CatmullRomOpen(context, alpha) : new CardinalOpen(context, 0); + } + catmullRom.alpha = function(alpha2) { + return custom7(+alpha2); + }; + return catmullRom; +}(0.5); +function LinearClosed(context) { + this._context = context; +} +LinearClosed.prototype = { + areaStart: noop, + areaEnd: noop, + lineStart: function() { + this._point = 0; + }, + lineEnd: function() { + if (this._point) + this._context.closePath(); + }, + point: function(x, y) { + x = +x, y = +y; + if (this._point) + this._context.lineTo(x, y); + else + this._point = 1, this._context.moveTo(x, y); + } +}; +function curveLinearClosed(context) { + return new LinearClosed(context); +} +function sign(x) { + return x < 0 ? -1 : 1; +} +function slope3(that, x2, y2) { + var h0 = that._x1 - that._x0, h1 = x2 - that._x1, s0 = (that._y1 - that._y0) / (h0 || h1 < 0 && -0), s1 = (y2 - that._y1) / (h1 || h0 < 0 && -0), p = (s0 * h1 + s1 * h0) / (h0 + h1); + return (sign(s0) + sign(s1)) * Math.min(Math.abs(s0), Math.abs(s1), 0.5 * Math.abs(p)) || 0; +} +function slope2(that, t) { + var h = that._x1 - that._x0; + return h ? (3 * (that._y1 - that._y0) / h - t) / 2 : t; +} +function point(that, t0, t1) { + var x0 = that._x0, y0 = that._y0, x1 = that._x1, y1 = that._y1, dx = (x1 - x0) / 3; + that._context.bezierCurveTo(x0 + dx, y0 + dx * t0, x1 - dx, y1 - dx * t1, x1, y1); +} +function MonotoneX(context) { + this._context = context; +} +MonotoneX.prototype = { + areaStart: function() { + this._line = 0; + }, + areaEnd: function() { + this._line = NaN; + }, + lineStart: function() { + this._x0 = this._x1 = this._y0 = this._y1 = this._t0 = NaN; + this._point = 0; + }, + lineEnd: function() { + switch (this._point) { + case 2: + this._context.lineTo(this._x1, this._y1); + break; + case 3: + point(this, this._t0, slope2(this, this._t0)); + break; + } + if (this._line || this._line !== 0 && this._point === 1) + this._context.closePath(); + this._line = 1 - this._line; + }, + point: function(x, y) { + var t1 = NaN; + x = +x, y = +y; + if (x === this._x1 && y === this._y1) + return; + switch (this._point) { + case 0: + this._point = 1; + this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); + break; + case 1: + this._point = 2; + break; + case 2: + this._point = 3; + point(this, slope2(this, t1 = slope3(this, x, y)), t1); + break; + default: + point(this, this._t0, t1 = slope3(this, x, y)); + break; + } + this._x0 = this._x1, this._x1 = x; + this._y0 = this._y1, this._y1 = y; + this._t0 = t1; + } +}; +function MonotoneY(context) { + this._context = new ReflectContext(context); +} +(MonotoneY.prototype = Object.create(MonotoneX.prototype)).point = function(x, y) { + MonotoneX.prototype.point.call(this, y, x); +}; +function ReflectContext(context) { + this._context = context; +} +ReflectContext.prototype = { + moveTo: function(x, y) { + this._context.moveTo(y, x); + }, + closePath: function() { + this._context.closePath(); + }, + lineTo: function(x, y) { + this._context.lineTo(y, x); + }, + bezierCurveTo: function(x1, y1, x2, y2, x, y) { + this._context.bezierCurveTo(y1, x1, y2, x2, y, x); + } +}; +function monotoneX(context) { + return new MonotoneX(context); +} +function monotoneY(context) { + return new MonotoneY(context); +} +function Natural(context) { + this._context = context; +} +Natural.prototype = { + areaStart: function() { + this._line = 0; + }, + areaEnd: function() { + this._line = NaN; + }, + lineStart: function() { + this._x = []; + this._y = []; + }, + lineEnd: function() { + var x = this._x, y = this._y, n = x.length; + if (n) { + this._line ? this._context.lineTo(x[0], y[0]) : this._context.moveTo(x[0], y[0]); + if (n === 2) { + this._context.lineTo(x[1], y[1]); + } else { + var px = controlPoints(x), py = controlPoints(y); + for (var i0 = 0, i1 = 1; i1 < n; ++i0, ++i1) { + this._context.bezierCurveTo(px[0][i0], py[0][i0], px[1][i0], py[1][i0], x[i1], y[i1]); + } + } + } + if (this._line || this._line !== 0 && n === 1) + this._context.closePath(); + this._line = 1 - this._line; + this._x = this._y = null; + }, + point: function(x, y) { + this._x.push(+x); + this._y.push(+y); + } +}; +function controlPoints(x) { + var i, n = x.length - 1, m, a = new Array(n), b = new Array(n), r = new Array(n); + a[0] = 0, b[0] = 2, r[0] = x[0] + 2 * x[1]; + for (i = 1; i < n - 1; ++i) + a[i] = 1, b[i] = 4, r[i] = 4 * x[i] + 2 * x[i + 1]; + a[n - 1] = 2, b[n - 1] = 7, r[n - 1] = 8 * x[n - 1] + x[n]; + for (i = 1; i < n; ++i) + m = a[i] / b[i - 1], b[i] -= m, r[i] -= m * r[i - 1]; + a[n - 1] = r[n - 1] / b[n - 1]; + for (i = n - 2; i >= 0; --i) + a[i] = (r[i] - a[i + 1]) / b[i]; + b[n - 1] = (x[n] + a[n - 1]) / 2; + for (i = 0; i < n - 1; ++i) + b[i] = 2 * x[i + 1] - a[i + 1]; + return [a, b]; +} +function curveNatural(context) { + return new Natural(context); +} +function Step(context, t) { + this._context = context; + this._t = t; +} +Step.prototype = { + areaStart: function() { + this._line = 0; + }, + areaEnd: function() { + this._line = NaN; + }, + lineStart: function() { + this._x = this._y = NaN; + this._point = 0; + }, + lineEnd: function() { + if (0 < this._t && this._t < 1 && this._point === 2) + this._context.lineTo(this._x, this._y); + if (this._line || this._line !== 0 && this._point === 1) + this._context.closePath(); + if (this._line >= 0) + this._t = 1 - this._t, this._line = 1 - this._line; + }, + point: function(x, y) { + x = +x, y = +y; + switch (this._point) { + case 0: + this._point = 1; + this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); + break; + case 1: + this._point = 2; + default: { + if (this._t <= 0) { + this._context.lineTo(this._x, y); + this._context.lineTo(x, y); + } else { + var x1 = this._x * (1 - this._t) + x * this._t; + this._context.lineTo(x1, this._y); + this._context.lineTo(x1, y); + } + break; + } + } + this._x = x, this._y = y; + } +}; +function curveStep(context) { + return new Step(context, 0.5); +} +function stepBefore(context) { + return new Step(context, 0); +} +function stepAfter(context) { + return new Step(context, 1); +} +function Transform(k, x, y) { + this.k = k; + this.x = x; + this.y = y; +} +Transform.prototype = { + constructor: Transform, + scale: function(k) { + return k === 1 ? this : new Transform(this.k * k, this.x, this.y); + }, + translate: function(x, y) { + return x === 0 & y === 0 ? this : new Transform(this.k, this.x + this.k * x, this.y + this.k * y); + }, + apply: function(point2) { + return [point2[0] * this.k + this.x, point2[1] * this.k + this.y]; + }, + applyX: function(x) { + return x * this.k + this.x; + }, + applyY: function(y) { + return y * this.k + this.y; + }, + invert: function(location) { + return [(location[0] - this.x) / this.k, (location[1] - this.y) / this.k]; + }, + invertX: function(x) { + return (x - this.x) / this.k; + }, + invertY: function(y) { + return (y - this.y) / this.k; + }, + rescaleX: function(x) { + return x.copy().domain(x.range().map(this.invertX, this).map(x.invert, x)); + }, + rescaleY: function(y) { + return y.copy().domain(y.range().map(this.invertY, this).map(y.invert, y)); + }, + toString: function() { + return "translate(" + this.x + "," + this.y + ") scale(" + this.k + ")"; + } +}; +Transform.prototype; +/*! @license DOMPurify 3.0.9 | (c) Cure53 and other contributors | Released under the Apache license 2.0 and Mozilla Public License 2.0 | github.com/cure53/DOMPurify/blob/3.0.9/LICENSE */ +const { + entries, + setPrototypeOf, + isFrozen, + getPrototypeOf, + getOwnPropertyDescriptor +} = Object; +let { + freeze, + seal, + create +} = Object; +let { + apply: apply$1, + construct +} = typeof Reflect !== "undefined" && Reflect; +if (!freeze) { + freeze = function freeze2(x) { + return x; + }; +} +if (!seal) { + seal = function seal2(x) { + return x; + }; +} +if (!apply$1) { + apply$1 = function apply2(fun, thisValue, args) { + return fun.apply(thisValue, args); + }; +} +if (!construct) { + construct = function construct2(Func, args) { + return new Func(...args); + }; +} +const arrayForEach = unapply(Array.prototype.forEach); +const arrayPop = unapply(Array.prototype.pop); +const arrayPush = unapply(Array.prototype.push); +const stringToLowerCase = unapply(String.prototype.toLowerCase); +const stringToString = unapply(String.prototype.toString); +const stringMatch = unapply(String.prototype.match); +const stringReplace = unapply(String.prototype.replace); +const stringIndexOf = unapply(String.prototype.indexOf); +const stringTrim = unapply(String.prototype.trim); +const objectHasOwnProperty = unapply(Object.prototype.hasOwnProperty); +const regExpTest = unapply(RegExp.prototype.test); +const typeErrorCreate = unconstruct(TypeError); +function unapply(func) { + return function(thisArg) { + for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + args[_key - 1] = arguments[_key]; + } + return apply$1(func, thisArg, args); + }; +} +function unconstruct(func) { + return function() { + for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) { + args[_key2] = arguments[_key2]; + } + return construct(func, args); + }; +} +function addToSet(set2, array2) { + let transformCaseFunc = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : stringToLowerCase; + if (setPrototypeOf) { + setPrototypeOf(set2, null); + } + let l = array2.length; + while (l--) { + let element = array2[l]; + if (typeof element === "string") { + const lcElement = transformCaseFunc(element); + if (lcElement !== element) { + if (!isFrozen(array2)) { + array2[l] = lcElement; + } + element = lcElement; + } + } + set2[element] = true; + } + return set2; +} +function cleanArray(array2) { + for (let index = 0; index < array2.length; index++) { + const isPropertyExist = objectHasOwnProperty(array2, index); + if (!isPropertyExist) { + array2[index] = null; + } + } + return array2; +} +function clone(object) { + const newObject = create(null); + for (const [property, value] of entries(object)) { + const isPropertyExist = objectHasOwnProperty(object, property); + if (isPropertyExist) { + if (Array.isArray(value)) { + newObject[property] = cleanArray(value); + } else if (value && typeof value === "object" && value.constructor === Object) { + newObject[property] = clone(value); + } else { + newObject[property] = value; + } + } + } + return newObject; +} +function lookupGetter(object, prop) { + while (object !== null) { + const desc = getOwnPropertyDescriptor(object, prop); + if (desc) { + if (desc.get) { + return unapply(desc.get); + } + if (typeof desc.value === "function") { + return unapply(desc.value); + } + } + object = getPrototypeOf(object); + } + function fallbackValue() { + return null; + } + return fallbackValue; +} +const html$1 = freeze(["a", "abbr", "acronym", "address", "area", "article", "aside", "audio", "b", "bdi", "bdo", "big", "blink", "blockquote", "body", "br", "button", "canvas", "caption", "center", "cite", "code", "col", "colgroup", "content", "data", "datalist", "dd", "decorator", "del", "details", "dfn", "dialog", "dir", "div", "dl", "dt", "element", "em", "fieldset", "figcaption", "figure", "font", "footer", "form", "h1", "h2", "h3", "h4", "h5", "h6", "head", "header", "hgroup", "hr", "html", "i", "img", "input", "ins", "kbd", "label", "legend", "li", "main", "map", "mark", "marquee", "menu", "menuitem", "meter", "nav", "nobr", "ol", "optgroup", "option", "output", "p", "picture", "pre", "progress", "q", "rp", "rt", "ruby", "s", "samp", "section", "select", "shadow", "small", "source", "spacer", "span", "strike", "strong", "style", "sub", "summary", "sup", "table", "tbody", "td", "template", "textarea", "tfoot", "th", "thead", "time", "tr", "track", "tt", "u", "ul", "var", "video", "wbr"]); +const svg$1 = freeze(["svg", "a", "altglyph", "altglyphdef", "altglyphitem", "animatecolor", "animatemotion", "animatetransform", "circle", "clippath", "defs", "desc", "ellipse", "filter", "font", "g", "glyph", "glyphref", "hkern", "image", "line", "lineargradient", "marker", "mask", "metadata", "mpath", "path", "pattern", "polygon", "polyline", "radialgradient", "rect", "stop", "style", "switch", "symbol", "text", "textpath", "title", "tref", "tspan", "view", "vkern"]); +const svgFilters = freeze(["feBlend", "feColorMatrix", "feComponentTransfer", "feComposite", "feConvolveMatrix", "feDiffuseLighting", "feDisplacementMap", "feDistantLight", "feDropShadow", "feFlood", "feFuncA", "feFuncB", "feFuncG", "feFuncR", "feGaussianBlur", "feImage", "feMerge", "feMergeNode", "feMorphology", "feOffset", "fePointLight", "feSpecularLighting", "feSpotLight", "feTile", "feTurbulence"]); +const svgDisallowed = freeze(["animate", "color-profile", "cursor", "discard", "font-face", "font-face-format", "font-face-name", "font-face-src", "font-face-uri", "foreignobject", "hatch", "hatchpath", "mesh", "meshgradient", "meshpatch", "meshrow", "missing-glyph", "script", "set", "solidcolor", "unknown", "use"]); +const mathMl$1 = freeze(["math", "menclose", "merror", "mfenced", "mfrac", "mglyph", "mi", "mlabeledtr", "mmultiscripts", "mn", "mo", "mover", "mpadded", "mphantom", "mroot", "mrow", "ms", "mspace", "msqrt", "mstyle", "msub", "msup", "msubsup", "mtable", "mtd", "mtext", "mtr", "munder", "munderover", "mprescripts"]); +const mathMlDisallowed = freeze(["maction", "maligngroup", "malignmark", "mlongdiv", "mscarries", "mscarry", "msgroup", "mstack", "msline", "msrow", "semantics", "annotation", "annotation-xml", "mprescripts", "none"]); +const text = freeze(["#text"]); +const html = freeze(["accept", "action", "align", "alt", "autocapitalize", "autocomplete", "autopictureinpicture", "autoplay", "background", "bgcolor", "border", "capture", "cellpadding", "cellspacing", "checked", "cite", "class", "clear", "color", "cols", "colspan", "controls", "controlslist", "coords", "crossorigin", "datetime", "decoding", "default", "dir", "disabled", "disablepictureinpicture", "disableremoteplayback", "download", "draggable", "enctype", "enterkeyhint", "face", "for", "headers", "height", "hidden", "high", "href", "hreflang", "id", "inputmode", "integrity", "ismap", "kind", "label", "lang", "list", "loading", "loop", "low", "max", "maxlength", "media", "method", "min", "minlength", "multiple", "muted", "name", "nonce", "noshade", "novalidate", "nowrap", "open", "optimum", "pattern", "placeholder", "playsinline", "poster", "preload", "pubdate", "radiogroup", "readonly", "rel", "required", "rev", "reversed", "role", "rows", "rowspan", "spellcheck", "scope", "selected", "shape", "size", "sizes", "span", "srclang", "start", "src", "srcset", "step", "style", "summary", "tabindex", "title", "translate", "type", "usemap", "valign", "value", "width", "xmlns", "slot"]); +const svg = freeze(["accent-height", "accumulate", "additive", "alignment-baseline", "ascent", "attributename", "attributetype", "azimuth", "basefrequency", "baseline-shift", "begin", "bias", "by", "class", "clip", "clippathunits", "clip-path", "clip-rule", "color", "color-interpolation", "color-interpolation-filters", "color-profile", "color-rendering", "cx", "cy", "d", "dx", "dy", "diffuseconstant", "direction", "display", "divisor", "dur", "edgemode", "elevation", "end", "fill", "fill-opacity", "fill-rule", "filter", "filterunits", "flood-color", "flood-opacity", "font-family", "font-size", "font-size-adjust", "font-stretch", "font-style", "font-variant", "font-weight", "fx", "fy", "g1", "g2", "glyph-name", "glyphref", "gradientunits", "gradienttransform", "height", "href", "id", "image-rendering", "in", "in2", "k", "k1", "k2", "k3", "k4", "kerning", "keypoints", "keysplines", "keytimes", "lang", "lengthadjust", "letter-spacing", "kernelmatrix", "kernelunitlength", "lighting-color", "local", "marker-end", "marker-mid", "marker-start", "markerheight", "markerunits", "markerwidth", "maskcontentunits", "maskunits", "max", "mask", "media", "method", "mode", "min", "name", "numoctaves", "offset", "operator", "opacity", "order", "orient", "orientation", "origin", "overflow", "paint-order", "path", "pathlength", "patterncontentunits", "patterntransform", "patternunits", "points", "preservealpha", "preserveaspectratio", "primitiveunits", "r", "rx", "ry", "radius", "refx", "refy", "repeatcount", "repeatdur", "restart", "result", "rotate", "scale", "seed", "shape-rendering", "specularconstant", "specularexponent", "spreadmethod", "startoffset", "stddeviation", "stitchtiles", "stop-color", "stop-opacity", "stroke-dasharray", "stroke-dashoffset", "stroke-linecap", "stroke-linejoin", "stroke-miterlimit", "stroke-opacity", "stroke", "stroke-width", "style", "surfacescale", "systemlanguage", "tabindex", "targetx", "targety", "transform", "transform-origin", "text-anchor", "text-decoration", "text-rendering", "textlength", "type", "u1", "u2", "unicode", "values", "viewbox", "visibility", "version", "vert-adv-y", "vert-origin-x", "vert-origin-y", "width", "word-spacing", "wrap", "writing-mode", "xchannelselector", "ychannelselector", "x", "x1", "x2", "xmlns", "y", "y1", "y2", "z", "zoomandpan"]); +const mathMl = freeze(["accent", "accentunder", "align", "bevelled", "close", "columnsalign", "columnlines", "columnspan", "denomalign", "depth", "dir", "display", "displaystyle", "encoding", "fence", "frame", "height", "href", "id", "largeop", "length", "linethickness", "lspace", "lquote", "mathbackground", "mathcolor", "mathsize", "mathvariant", "maxsize", "minsize", "movablelimits", "notation", "numalign", "open", "rowalign", "rowlines", "rowspacing", "rowspan", "rspace", "rquote", "scriptlevel", "scriptminsize", "scriptsizemultiplier", "selection", "separator", "separators", "stretchy", "subscriptshift", "supscriptshift", "symmetric", "voffset", "width", "xmlns"]); +const xml = freeze(["xlink:href", "xml:id", "xlink:title", "xml:space", "xmlns:xlink"]); +const MUSTACHE_EXPR = seal(/\{\{[\w\W]*|[\w\W]*\}\}/gm); +const ERB_EXPR = seal(/<%[\w\W]*|[\w\W]*%>/gm); +const TMPLIT_EXPR = seal(/\${[\w\W]*}/gm); +const DATA_ATTR = seal(/^data-[\-\w.\u00B7-\uFFFF]/); +const ARIA_ATTR = seal(/^aria-[\-\w]+$/); +const IS_ALLOWED_URI = seal( + /^(?:(?:(?:f|ht)tps?|mailto|tel|callto|sms|cid|xmpp):|[^a-z]|[a-z+.\-]+(?:[^a-z+.\-:]|$))/i + // eslint-disable-line no-useless-escape +); +const IS_SCRIPT_OR_DATA = seal(/^(?:\w+script|data):/i); +const ATTR_WHITESPACE = seal( + /[\u0000-\u0020\u00A0\u1680\u180E\u2000-\u2029\u205F\u3000]/g + // eslint-disable-line no-control-regex +); +const DOCTYPE_NAME = seal(/^html$/i); +var EXPRESSIONS = /* @__PURE__ */ Object.freeze({ + __proto__: null, + MUSTACHE_EXPR, + ERB_EXPR, + TMPLIT_EXPR, + DATA_ATTR, + ARIA_ATTR, + IS_ALLOWED_URI, + IS_SCRIPT_OR_DATA, + ATTR_WHITESPACE, + DOCTYPE_NAME +}); +const getGlobal = function getGlobal2() { + return typeof window === "undefined" ? null : window; +}; +const _createTrustedTypesPolicy = function _createTrustedTypesPolicy2(trustedTypes, purifyHostElement) { + if (typeof trustedTypes !== "object" || typeof trustedTypes.createPolicy !== "function") { + return null; + } + let suffix = null; + const ATTR_NAME = "data-tt-policy-suffix"; + if (purifyHostElement && purifyHostElement.hasAttribute(ATTR_NAME)) { + suffix = purifyHostElement.getAttribute(ATTR_NAME); + } + const policyName = "dompurify" + (suffix ? "#" + suffix : ""); + try { + return trustedTypes.createPolicy(policyName, { + createHTML(html2) { + return html2; + }, + createScriptURL(scriptUrl) { + return scriptUrl; + } + }); + } catch (_2) { + console.warn("TrustedTypes policy " + policyName + " could not be created."); + return null; + } +}; +function createDOMPurify() { + let window2 = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : getGlobal(); + const DOMPurify = (root2) => createDOMPurify(root2); + DOMPurify.version = "3.0.9"; + DOMPurify.removed = []; + if (!window2 || !window2.document || window2.document.nodeType !== 9) { + DOMPurify.isSupported = false; + return DOMPurify; + } + let { + document: document2 + } = window2; + const originalDocument = document2; + const currentScript = originalDocument.currentScript; + const { + DocumentFragment, + HTMLTemplateElement, + Node, + Element, + NodeFilter, + NamedNodeMap = window2.NamedNodeMap || window2.MozNamedAttrMap, + HTMLFormElement, + DOMParser, + trustedTypes + } = window2; + const ElementPrototype = Element.prototype; + const cloneNode = lookupGetter(ElementPrototype, "cloneNode"); + const getNextSibling = lookupGetter(ElementPrototype, "nextSibling"); + const getChildNodes = lookupGetter(ElementPrototype, "childNodes"); + const getParentNode = lookupGetter(ElementPrototype, "parentNode"); + if (typeof HTMLTemplateElement === "function") { + const template = document2.createElement("template"); + if (template.content && template.content.ownerDocument) { + document2 = template.content.ownerDocument; + } + } + let trustedTypesPolicy; + let emptyHTML = ""; + const { + implementation, + createNodeIterator, + createDocumentFragment, + getElementsByTagName + } = document2; + const { + importNode + } = originalDocument; + let hooks = {}; + DOMPurify.isSupported = typeof entries === "function" && typeof getParentNode === "function" && implementation && implementation.createHTMLDocument !== void 0; + const { + MUSTACHE_EXPR: MUSTACHE_EXPR2, + ERB_EXPR: ERB_EXPR2, + TMPLIT_EXPR: TMPLIT_EXPR2, + DATA_ATTR: DATA_ATTR2, + ARIA_ATTR: ARIA_ATTR2, + IS_SCRIPT_OR_DATA: IS_SCRIPT_OR_DATA2, + ATTR_WHITESPACE: ATTR_WHITESPACE2 + } = EXPRESSIONS; + let { + IS_ALLOWED_URI: IS_ALLOWED_URI$1 + } = EXPRESSIONS; + let ALLOWED_TAGS = null; + const DEFAULT_ALLOWED_TAGS = addToSet({}, [...html$1, ...svg$1, ...svgFilters, ...mathMl$1, ...text]); + let ALLOWED_ATTR = null; + const DEFAULT_ALLOWED_ATTR = addToSet({}, [...html, ...svg, ...mathMl, ...xml]); + let CUSTOM_ELEMENT_HANDLING = Object.seal(create(null, { + tagNameCheck: { + writable: true, + configurable: false, + enumerable: true, + value: null + }, + attributeNameCheck: { + writable: true, + configurable: false, + enumerable: true, + value: null + }, + allowCustomizedBuiltInElements: { + writable: true, + configurable: false, + enumerable: true, + value: false + } + })); + let FORBID_TAGS = null; + let FORBID_ATTR = null; + let ALLOW_ARIA_ATTR = true; + let ALLOW_DATA_ATTR = true; + let ALLOW_UNKNOWN_PROTOCOLS = false; + let ALLOW_SELF_CLOSE_IN_ATTR = true; + let SAFE_FOR_TEMPLATES = false; + let WHOLE_DOCUMENT = false; + let SET_CONFIG = false; + let FORCE_BODY = false; + let RETURN_DOM = false; + let RETURN_DOM_FRAGMENT = false; + let RETURN_TRUSTED_TYPE = false; + let SANITIZE_DOM = true; + let SANITIZE_NAMED_PROPS = false; + const SANITIZE_NAMED_PROPS_PREFIX = "user-content-"; + let KEEP_CONTENT = true; + let IN_PLACE = false; + let USE_PROFILES = {}; + let FORBID_CONTENTS = null; + const DEFAULT_FORBID_CONTENTS = addToSet({}, ["annotation-xml", "audio", "colgroup", "desc", "foreignobject", "head", "iframe", "math", "mi", "mn", "mo", "ms", "mtext", "noembed", "noframes", "noscript", "plaintext", "script", "style", "svg", "template", "thead", "title", "video", "xmp"]); + let DATA_URI_TAGS = null; + const DEFAULT_DATA_URI_TAGS = addToSet({}, ["audio", "video", "img", "source", "image", "track"]); + let URI_SAFE_ATTRIBUTES = null; + const DEFAULT_URI_SAFE_ATTRIBUTES = addToSet({}, ["alt", "class", "for", "id", "label", "name", "pattern", "placeholder", "role", "summary", "title", "value", "style", "xmlns"]); + const MATHML_NAMESPACE = "http://www.w3.org/1998/Math/MathML"; + const SVG_NAMESPACE = "http://www.w3.org/2000/svg"; + const HTML_NAMESPACE = "http://www.w3.org/1999/xhtml"; + let NAMESPACE = HTML_NAMESPACE; + let IS_EMPTY_INPUT = false; + let ALLOWED_NAMESPACES = null; + const DEFAULT_ALLOWED_NAMESPACES = addToSet({}, [MATHML_NAMESPACE, SVG_NAMESPACE, HTML_NAMESPACE], stringToString); + let PARSER_MEDIA_TYPE = null; + const SUPPORTED_PARSER_MEDIA_TYPES = ["application/xhtml+xml", "text/html"]; + const DEFAULT_PARSER_MEDIA_TYPE = "text/html"; + let transformCaseFunc = null; + let CONFIG = null; + const formElement = document2.createElement("form"); + const isRegexOrFunction = function isRegexOrFunction2(testValue) { + return testValue instanceof RegExp || testValue instanceof Function; + }; + const _parseConfig = function _parseConfig2() { + let cfg = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}; + if (CONFIG && CONFIG === cfg) { + return; + } + if (!cfg || typeof cfg !== "object") { + cfg = {}; + } + cfg = clone(cfg); + PARSER_MEDIA_TYPE = // eslint-disable-next-line unicorn/prefer-includes + SUPPORTED_PARSER_MEDIA_TYPES.indexOf(cfg.PARSER_MEDIA_TYPE) === -1 ? DEFAULT_PARSER_MEDIA_TYPE : cfg.PARSER_MEDIA_TYPE; + transformCaseFunc = PARSER_MEDIA_TYPE === "application/xhtml+xml" ? stringToString : stringToLowerCase; + ALLOWED_TAGS = objectHasOwnProperty(cfg, "ALLOWED_TAGS") ? addToSet({}, cfg.ALLOWED_TAGS, transformCaseFunc) : DEFAULT_ALLOWED_TAGS; + ALLOWED_ATTR = objectHasOwnProperty(cfg, "ALLOWED_ATTR") ? addToSet({}, cfg.ALLOWED_ATTR, transformCaseFunc) : DEFAULT_ALLOWED_ATTR; + ALLOWED_NAMESPACES = objectHasOwnProperty(cfg, "ALLOWED_NAMESPACES") ? addToSet({}, cfg.ALLOWED_NAMESPACES, stringToString) : DEFAULT_ALLOWED_NAMESPACES; + URI_SAFE_ATTRIBUTES = objectHasOwnProperty(cfg, "ADD_URI_SAFE_ATTR") ? addToSet( + clone(DEFAULT_URI_SAFE_ATTRIBUTES), + // eslint-disable-line indent + cfg.ADD_URI_SAFE_ATTR, + // eslint-disable-line indent + transformCaseFunc + // eslint-disable-line indent + ) : DEFAULT_URI_SAFE_ATTRIBUTES; + DATA_URI_TAGS = objectHasOwnProperty(cfg, "ADD_DATA_URI_TAGS") ? addToSet( + clone(DEFAULT_DATA_URI_TAGS), + // eslint-disable-line indent + cfg.ADD_DATA_URI_TAGS, + // eslint-disable-line indent + transformCaseFunc + // eslint-disable-line indent + ) : DEFAULT_DATA_URI_TAGS; + FORBID_CONTENTS = objectHasOwnProperty(cfg, "FORBID_CONTENTS") ? addToSet({}, cfg.FORBID_CONTENTS, transformCaseFunc) : DEFAULT_FORBID_CONTENTS; + FORBID_TAGS = objectHasOwnProperty(cfg, "FORBID_TAGS") ? addToSet({}, cfg.FORBID_TAGS, transformCaseFunc) : {}; + FORBID_ATTR = objectHasOwnProperty(cfg, "FORBID_ATTR") ? addToSet({}, cfg.FORBID_ATTR, transformCaseFunc) : {}; + USE_PROFILES = objectHasOwnProperty(cfg, "USE_PROFILES") ? cfg.USE_PROFILES : false; + ALLOW_ARIA_ATTR = cfg.ALLOW_ARIA_ATTR !== false; + ALLOW_DATA_ATTR = cfg.ALLOW_DATA_ATTR !== false; + ALLOW_UNKNOWN_PROTOCOLS = cfg.ALLOW_UNKNOWN_PROTOCOLS || false; + ALLOW_SELF_CLOSE_IN_ATTR = cfg.ALLOW_SELF_CLOSE_IN_ATTR !== false; + SAFE_FOR_TEMPLATES = cfg.SAFE_FOR_TEMPLATES || false; + WHOLE_DOCUMENT = cfg.WHOLE_DOCUMENT || false; + RETURN_DOM = cfg.RETURN_DOM || false; + RETURN_DOM_FRAGMENT = cfg.RETURN_DOM_FRAGMENT || false; + RETURN_TRUSTED_TYPE = cfg.RETURN_TRUSTED_TYPE || false; + FORCE_BODY = cfg.FORCE_BODY || false; + SANITIZE_DOM = cfg.SANITIZE_DOM !== false; + SANITIZE_NAMED_PROPS = cfg.SANITIZE_NAMED_PROPS || false; + KEEP_CONTENT = cfg.KEEP_CONTENT !== false; + IN_PLACE = cfg.IN_PLACE || false; + IS_ALLOWED_URI$1 = cfg.ALLOWED_URI_REGEXP || IS_ALLOWED_URI; + NAMESPACE = cfg.NAMESPACE || HTML_NAMESPACE; + CUSTOM_ELEMENT_HANDLING = cfg.CUSTOM_ELEMENT_HANDLING || {}; + if (cfg.CUSTOM_ELEMENT_HANDLING && isRegexOrFunction(cfg.CUSTOM_ELEMENT_HANDLING.tagNameCheck)) { + CUSTOM_ELEMENT_HANDLING.tagNameCheck = cfg.CUSTOM_ELEMENT_HANDLING.tagNameCheck; + } + if (cfg.CUSTOM_ELEMENT_HANDLING && isRegexOrFunction(cfg.CUSTOM_ELEMENT_HANDLING.attributeNameCheck)) { + CUSTOM_ELEMENT_HANDLING.attributeNameCheck = cfg.CUSTOM_ELEMENT_HANDLING.attributeNameCheck; + } + if (cfg.CUSTOM_ELEMENT_HANDLING && typeof cfg.CUSTOM_ELEMENT_HANDLING.allowCustomizedBuiltInElements === "boolean") { + CUSTOM_ELEMENT_HANDLING.allowCustomizedBuiltInElements = cfg.CUSTOM_ELEMENT_HANDLING.allowCustomizedBuiltInElements; + } + if (SAFE_FOR_TEMPLATES) { + ALLOW_DATA_ATTR = false; + } + if (RETURN_DOM_FRAGMENT) { + RETURN_DOM = true; + } + if (USE_PROFILES) { + ALLOWED_TAGS = addToSet({}, text); + ALLOWED_ATTR = []; + if (USE_PROFILES.html === true) { + addToSet(ALLOWED_TAGS, html$1); + addToSet(ALLOWED_ATTR, html); + } + if (USE_PROFILES.svg === true) { + addToSet(ALLOWED_TAGS, svg$1); + addToSet(ALLOWED_ATTR, svg); + addToSet(ALLOWED_ATTR, xml); + } + if (USE_PROFILES.svgFilters === true) { + addToSet(ALLOWED_TAGS, svgFilters); + addToSet(ALLOWED_ATTR, svg); + addToSet(ALLOWED_ATTR, xml); + } + if (USE_PROFILES.mathMl === true) { + addToSet(ALLOWED_TAGS, mathMl$1); + addToSet(ALLOWED_ATTR, mathMl); + addToSet(ALLOWED_ATTR, xml); + } + } + if (cfg.ADD_TAGS) { + if (ALLOWED_TAGS === DEFAULT_ALLOWED_TAGS) { + ALLOWED_TAGS = clone(ALLOWED_TAGS); + } + addToSet(ALLOWED_TAGS, cfg.ADD_TAGS, transformCaseFunc); + } + if (cfg.ADD_ATTR) { + if (ALLOWED_ATTR === DEFAULT_ALLOWED_ATTR) { + ALLOWED_ATTR = clone(ALLOWED_ATTR); + } + addToSet(ALLOWED_ATTR, cfg.ADD_ATTR, transformCaseFunc); + } + if (cfg.ADD_URI_SAFE_ATTR) { + addToSet(URI_SAFE_ATTRIBUTES, cfg.ADD_URI_SAFE_ATTR, transformCaseFunc); + } + if (cfg.FORBID_CONTENTS) { + if (FORBID_CONTENTS === DEFAULT_FORBID_CONTENTS) { + FORBID_CONTENTS = clone(FORBID_CONTENTS); + } + addToSet(FORBID_CONTENTS, cfg.FORBID_CONTENTS, transformCaseFunc); + } + if (KEEP_CONTENT) { + ALLOWED_TAGS["#text"] = true; + } + if (WHOLE_DOCUMENT) { + addToSet(ALLOWED_TAGS, ["html", "head", "body"]); + } + if (ALLOWED_TAGS.table) { + addToSet(ALLOWED_TAGS, ["tbody"]); + delete FORBID_TAGS.tbody; + } + if (cfg.TRUSTED_TYPES_POLICY) { + if (typeof cfg.TRUSTED_TYPES_POLICY.createHTML !== "function") { + throw typeErrorCreate('TRUSTED_TYPES_POLICY configuration option must provide a "createHTML" hook.'); + } + if (typeof cfg.TRUSTED_TYPES_POLICY.createScriptURL !== "function") { + throw typeErrorCreate('TRUSTED_TYPES_POLICY configuration option must provide a "createScriptURL" hook.'); + } + trustedTypesPolicy = cfg.TRUSTED_TYPES_POLICY; + emptyHTML = trustedTypesPolicy.createHTML(""); + } else { + if (trustedTypesPolicy === void 0) { + trustedTypesPolicy = _createTrustedTypesPolicy(trustedTypes, currentScript); + } + if (trustedTypesPolicy !== null && typeof emptyHTML === "string") { + emptyHTML = trustedTypesPolicy.createHTML(""); + } + } + if (freeze) { + freeze(cfg); + } + CONFIG = cfg; + }; + const MATHML_TEXT_INTEGRATION_POINTS = addToSet({}, ["mi", "mo", "mn", "ms", "mtext"]); + const HTML_INTEGRATION_POINTS = addToSet({}, ["foreignobject", "desc", "title", "annotation-xml"]); + const COMMON_SVG_AND_HTML_ELEMENTS = addToSet({}, ["title", "style", "font", "a", "script"]); + const ALL_SVG_TAGS = addToSet({}, [...svg$1, ...svgFilters, ...svgDisallowed]); + const ALL_MATHML_TAGS = addToSet({}, [...mathMl$1, ...mathMlDisallowed]); + const _checkValidNamespace = function _checkValidNamespace2(element) { + let parent = getParentNode(element); + if (!parent || !parent.tagName) { + parent = { + namespaceURI: NAMESPACE, + tagName: "template" + }; + } + const tagName = stringToLowerCase(element.tagName); + const parentTagName = stringToLowerCase(parent.tagName); + if (!ALLOWED_NAMESPACES[element.namespaceURI]) { + return false; + } + if (element.namespaceURI === SVG_NAMESPACE) { + if (parent.namespaceURI === HTML_NAMESPACE) { + return tagName === "svg"; + } + if (parent.namespaceURI === MATHML_NAMESPACE) { + return tagName === "svg" && (parentTagName === "annotation-xml" || MATHML_TEXT_INTEGRATION_POINTS[parentTagName]); + } + return Boolean(ALL_SVG_TAGS[tagName]); + } + if (element.namespaceURI === MATHML_NAMESPACE) { + if (parent.namespaceURI === HTML_NAMESPACE) { + return tagName === "math"; + } + if (parent.namespaceURI === SVG_NAMESPACE) { + return tagName === "math" && HTML_INTEGRATION_POINTS[parentTagName]; + } + return Boolean(ALL_MATHML_TAGS[tagName]); + } + if (element.namespaceURI === HTML_NAMESPACE) { + if (parent.namespaceURI === SVG_NAMESPACE && !HTML_INTEGRATION_POINTS[parentTagName]) { + return false; + } + if (parent.namespaceURI === MATHML_NAMESPACE && !MATHML_TEXT_INTEGRATION_POINTS[parentTagName]) { + return false; + } + return !ALL_MATHML_TAGS[tagName] && (COMMON_SVG_AND_HTML_ELEMENTS[tagName] || !ALL_SVG_TAGS[tagName]); + } + if (PARSER_MEDIA_TYPE === "application/xhtml+xml" && ALLOWED_NAMESPACES[element.namespaceURI]) { + return true; + } + return false; + }; + const _forceRemove = function _forceRemove2(node2) { + arrayPush(DOMPurify.removed, { + element: node2 + }); + try { + node2.parentNode.removeChild(node2); + } catch (_2) { + node2.remove(); + } + }; + const _removeAttribute = function _removeAttribute2(name, node2) { + try { + arrayPush(DOMPurify.removed, { + attribute: node2.getAttributeNode(name), + from: node2 + }); + } catch (_2) { + arrayPush(DOMPurify.removed, { + attribute: null, + from: node2 + }); + } + node2.removeAttribute(name); + if (name === "is" && !ALLOWED_ATTR[name]) { + if (RETURN_DOM || RETURN_DOM_FRAGMENT) { + try { + _forceRemove(node2); + } catch (_2) { + } + } else { + try { + node2.setAttribute(name, ""); + } catch (_2) { + } + } + } + }; + const _initDocument = function _initDocument2(dirty) { + let doc = null; + let leadingWhitespace = null; + if (FORCE_BODY) { + dirty = "" + dirty; + } else { + const matches = stringMatch(dirty, /^[\r\n\t ]+/); + leadingWhitespace = matches && matches[0]; + } + if (PARSER_MEDIA_TYPE === "application/xhtml+xml" && NAMESPACE === HTML_NAMESPACE) { + dirty = '' + dirty + ""; + } + const dirtyPayload = trustedTypesPolicy ? trustedTypesPolicy.createHTML(dirty) : dirty; + if (NAMESPACE === HTML_NAMESPACE) { + try { + doc = new DOMParser().parseFromString(dirtyPayload, PARSER_MEDIA_TYPE); + } catch (_2) { + } + } + if (!doc || !doc.documentElement) { + doc = implementation.createDocument(NAMESPACE, "template", null); + try { + doc.documentElement.innerHTML = IS_EMPTY_INPUT ? emptyHTML : dirtyPayload; + } catch (_2) { + } + } + const body = doc.body || doc.documentElement; + if (dirty && leadingWhitespace) { + body.insertBefore(document2.createTextNode(leadingWhitespace), body.childNodes[0] || null); + } + if (NAMESPACE === HTML_NAMESPACE) { + return getElementsByTagName.call(doc, WHOLE_DOCUMENT ? "html" : "body")[0]; + } + return WHOLE_DOCUMENT ? doc.documentElement : body; + }; + const _createNodeIterator = function _createNodeIterator2(root2) { + return createNodeIterator.call( + root2.ownerDocument || root2, + root2, + // eslint-disable-next-line no-bitwise + NodeFilter.SHOW_ELEMENT | NodeFilter.SHOW_COMMENT | NodeFilter.SHOW_TEXT, + null + ); + }; + const _isClobbered = function _isClobbered2(elm) { + return elm instanceof HTMLFormElement && (typeof elm.nodeName !== "string" || typeof elm.textContent !== "string" || typeof elm.removeChild !== "function" || !(elm.attributes instanceof NamedNodeMap) || typeof elm.removeAttribute !== "function" || typeof elm.setAttribute !== "function" || typeof elm.namespaceURI !== "string" || typeof elm.insertBefore !== "function" || typeof elm.hasChildNodes !== "function"); + }; + const _isNode = function _isNode2(object) { + return typeof Node === "function" && object instanceof Node; + }; + const _executeHook = function _executeHook2(entryPoint, currentNode, data) { + if (!hooks[entryPoint]) { + return; + } + arrayForEach(hooks[entryPoint], (hook) => { + hook.call(DOMPurify, currentNode, data, CONFIG); + }); + }; + const _sanitizeElements = function _sanitizeElements2(currentNode) { + let content = null; + _executeHook("beforeSanitizeElements", currentNode, null); + if (_isClobbered(currentNode)) { + _forceRemove(currentNode); + return true; + } + const tagName = transformCaseFunc(currentNode.nodeName); + _executeHook("uponSanitizeElement", currentNode, { + tagName, + allowedTags: ALLOWED_TAGS + }); + if (currentNode.hasChildNodes() && !_isNode(currentNode.firstElementChild) && regExpTest(/<[/\w]/g, currentNode.innerHTML) && regExpTest(/<[/\w]/g, currentNode.textContent)) { + _forceRemove(currentNode); + return true; + } + if (!ALLOWED_TAGS[tagName] || FORBID_TAGS[tagName]) { + if (!FORBID_TAGS[tagName] && _isBasicCustomElement(tagName)) { + if (CUSTOM_ELEMENT_HANDLING.tagNameCheck instanceof RegExp && regExpTest(CUSTOM_ELEMENT_HANDLING.tagNameCheck, tagName)) { + return false; + } + if (CUSTOM_ELEMENT_HANDLING.tagNameCheck instanceof Function && CUSTOM_ELEMENT_HANDLING.tagNameCheck(tagName)) { + return false; + } + } + if (KEEP_CONTENT && !FORBID_CONTENTS[tagName]) { + const parentNode = getParentNode(currentNode) || currentNode.parentNode; + const childNodes = getChildNodes(currentNode) || currentNode.childNodes; + if (childNodes && parentNode) { + const childCount = childNodes.length; + for (let i = childCount - 1; i >= 0; --i) { + parentNode.insertBefore(cloneNode(childNodes[i], true), getNextSibling(currentNode)); + } + } + } + _forceRemove(currentNode); + return true; + } + if (currentNode instanceof Element && !_checkValidNamespace(currentNode)) { + _forceRemove(currentNode); + return true; + } + if ((tagName === "noscript" || tagName === "noembed" || tagName === "noframes") && regExpTest(/<\/no(script|embed|frames)/i, currentNode.innerHTML)) { + _forceRemove(currentNode); + return true; + } + if (SAFE_FOR_TEMPLATES && currentNode.nodeType === 3) { + content = currentNode.textContent; + arrayForEach([MUSTACHE_EXPR2, ERB_EXPR2, TMPLIT_EXPR2], (expr) => { + content = stringReplace(content, expr, " "); + }); + if (currentNode.textContent !== content) { + arrayPush(DOMPurify.removed, { + element: currentNode.cloneNode() + }); + currentNode.textContent = content; + } + } + _executeHook("afterSanitizeElements", currentNode, null); + return false; + }; + const _isValidAttribute = function _isValidAttribute2(lcTag, lcName, value) { + if (SANITIZE_DOM && (lcName === "id" || lcName === "name") && (value in document2 || value in formElement)) { + return false; + } + if (ALLOW_DATA_ATTR && !FORBID_ATTR[lcName] && regExpTest(DATA_ATTR2, lcName)) + ; + else if (ALLOW_ARIA_ATTR && regExpTest(ARIA_ATTR2, lcName)) + ; + else if (!ALLOWED_ATTR[lcName] || FORBID_ATTR[lcName]) { + if ( + // First condition does a very basic check if a) it's basically a valid custom element tagname AND + // b) if the tagName passes whatever the user has configured for CUSTOM_ELEMENT_HANDLING.tagNameCheck + // and c) if the attribute name passes whatever the user has configured for CUSTOM_ELEMENT_HANDLING.attributeNameCheck + _isBasicCustomElement(lcTag) && (CUSTOM_ELEMENT_HANDLING.tagNameCheck instanceof RegExp && regExpTest(CUSTOM_ELEMENT_HANDLING.tagNameCheck, lcTag) || CUSTOM_ELEMENT_HANDLING.tagNameCheck instanceof Function && CUSTOM_ELEMENT_HANDLING.tagNameCheck(lcTag)) && (CUSTOM_ELEMENT_HANDLING.attributeNameCheck instanceof RegExp && regExpTest(CUSTOM_ELEMENT_HANDLING.attributeNameCheck, lcName) || CUSTOM_ELEMENT_HANDLING.attributeNameCheck instanceof Function && CUSTOM_ELEMENT_HANDLING.attributeNameCheck(lcName)) || // Alternative, second condition checks if it's an `is`-attribute, AND + // the value passes whatever the user has configured for CUSTOM_ELEMENT_HANDLING.tagNameCheck + lcName === "is" && CUSTOM_ELEMENT_HANDLING.allowCustomizedBuiltInElements && (CUSTOM_ELEMENT_HANDLING.tagNameCheck instanceof RegExp && regExpTest(CUSTOM_ELEMENT_HANDLING.tagNameCheck, value) || CUSTOM_ELEMENT_HANDLING.tagNameCheck instanceof Function && CUSTOM_ELEMENT_HANDLING.tagNameCheck(value)) + ) + ; + else { + return false; + } + } else if (URI_SAFE_ATTRIBUTES[lcName]) + ; + else if (regExpTest(IS_ALLOWED_URI$1, stringReplace(value, ATTR_WHITESPACE2, ""))) + ; + else if ((lcName === "src" || lcName === "xlink:href" || lcName === "href") && lcTag !== "script" && stringIndexOf(value, "data:") === 0 && DATA_URI_TAGS[lcTag]) + ; + else if (ALLOW_UNKNOWN_PROTOCOLS && !regExpTest(IS_SCRIPT_OR_DATA2, stringReplace(value, ATTR_WHITESPACE2, ""))) + ; + else if (value) { + return false; + } else + ; + return true; + }; + const _isBasicCustomElement = function _isBasicCustomElement2(tagName) { + return tagName !== "annotation-xml" && tagName.indexOf("-") > 0; + }; + const _sanitizeAttributes = function _sanitizeAttributes2(currentNode) { + _executeHook("beforeSanitizeAttributes", currentNode, null); + const { + attributes + } = currentNode; + if (!attributes) { + return; + } + const hookEvent = { + attrName: "", + attrValue: "", + keepAttr: true, + allowedAttributes: ALLOWED_ATTR + }; + let l = attributes.length; + while (l--) { + const attr = attributes[l]; + const { + name, + namespaceURI, + value: attrValue + } = attr; + const lcName = transformCaseFunc(name); + let value = name === "value" ? attrValue : stringTrim(attrValue); + hookEvent.attrName = lcName; + hookEvent.attrValue = value; + hookEvent.keepAttr = true; + hookEvent.forceKeepAttr = void 0; + _executeHook("uponSanitizeAttribute", currentNode, hookEvent); + value = hookEvent.attrValue; + if (hookEvent.forceKeepAttr) { + continue; + } + _removeAttribute(name, currentNode); + if (!hookEvent.keepAttr) { + continue; + } + if (!ALLOW_SELF_CLOSE_IN_ATTR && regExpTest(/\/>/i, value)) { + _removeAttribute(name, currentNode); + continue; + } + if (SAFE_FOR_TEMPLATES) { + arrayForEach([MUSTACHE_EXPR2, ERB_EXPR2, TMPLIT_EXPR2], (expr) => { + value = stringReplace(value, expr, " "); + }); + } + const lcTag = transformCaseFunc(currentNode.nodeName); + if (!_isValidAttribute(lcTag, lcName, value)) { + continue; + } + if (SANITIZE_NAMED_PROPS && (lcName === "id" || lcName === "name")) { + _removeAttribute(name, currentNode); + value = SANITIZE_NAMED_PROPS_PREFIX + value; + } + if (trustedTypesPolicy && typeof trustedTypes === "object" && typeof trustedTypes.getAttributeType === "function") { + if (namespaceURI) + ; + else { + switch (trustedTypes.getAttributeType(lcTag, lcName)) { + case "TrustedHTML": { + value = trustedTypesPolicy.createHTML(value); + break; + } + case "TrustedScriptURL": { + value = trustedTypesPolicy.createScriptURL(value); + break; + } + } + } + } + try { + if (namespaceURI) { + currentNode.setAttributeNS(namespaceURI, name, value); + } else { + currentNode.setAttribute(name, value); + } + arrayPop(DOMPurify.removed); + } catch (_2) { + } + } + _executeHook("afterSanitizeAttributes", currentNode, null); + }; + const _sanitizeShadowDOM = function _sanitizeShadowDOM2(fragment) { + let shadowNode = null; + const shadowIterator = _createNodeIterator(fragment); + _executeHook("beforeSanitizeShadowDOM", fragment, null); + while (shadowNode = shadowIterator.nextNode()) { + _executeHook("uponSanitizeShadowNode", shadowNode, null); + if (_sanitizeElements(shadowNode)) { + continue; + } + if (shadowNode.content instanceof DocumentFragment) { + _sanitizeShadowDOM2(shadowNode.content); + } + _sanitizeAttributes(shadowNode); + } + _executeHook("afterSanitizeShadowDOM", fragment, null); + }; + DOMPurify.sanitize = function(dirty) { + let cfg = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}; + let body = null; + let importedNode = null; + let currentNode = null; + let returnNode = null; + IS_EMPTY_INPUT = !dirty; + if (IS_EMPTY_INPUT) { + dirty = ""; + } + if (typeof dirty !== "string" && !_isNode(dirty)) { + if (typeof dirty.toString === "function") { + dirty = dirty.toString(); + if (typeof dirty !== "string") { + throw typeErrorCreate("dirty is not a string, aborting"); + } + } else { + throw typeErrorCreate("toString is not a function"); + } + } + if (!DOMPurify.isSupported) { + return dirty; + } + if (!SET_CONFIG) { + _parseConfig(cfg); + } + DOMPurify.removed = []; + if (typeof dirty === "string") { + IN_PLACE = false; + } + if (IN_PLACE) { + if (dirty.nodeName) { + const tagName = transformCaseFunc(dirty.nodeName); + if (!ALLOWED_TAGS[tagName] || FORBID_TAGS[tagName]) { + throw typeErrorCreate("root node is forbidden and cannot be sanitized in-place"); + } + } + } else if (dirty instanceof Node) { + body = _initDocument(""); + importedNode = body.ownerDocument.importNode(dirty, true); + if (importedNode.nodeType === 1 && importedNode.nodeName === "BODY") { + body = importedNode; + } else if (importedNode.nodeName === "HTML") { + body = importedNode; + } else { + body.appendChild(importedNode); + } + } else { + if (!RETURN_DOM && !SAFE_FOR_TEMPLATES && !WHOLE_DOCUMENT && // eslint-disable-next-line unicorn/prefer-includes + dirty.indexOf("<") === -1) { + return trustedTypesPolicy && RETURN_TRUSTED_TYPE ? trustedTypesPolicy.createHTML(dirty) : dirty; + } + body = _initDocument(dirty); + if (!body) { + return RETURN_DOM ? null : RETURN_TRUSTED_TYPE ? emptyHTML : ""; + } + } + if (body && FORCE_BODY) { + _forceRemove(body.firstChild); + } + const nodeIterator = _createNodeIterator(IN_PLACE ? dirty : body); + while (currentNode = nodeIterator.nextNode()) { + if (_sanitizeElements(currentNode)) { + continue; + } + if (currentNode.content instanceof DocumentFragment) { + _sanitizeShadowDOM(currentNode.content); + } + _sanitizeAttributes(currentNode); + } + if (IN_PLACE) { + return dirty; + } + if (RETURN_DOM) { + if (RETURN_DOM_FRAGMENT) { + returnNode = createDocumentFragment.call(body.ownerDocument); + while (body.firstChild) { + returnNode.appendChild(body.firstChild); + } + } else { + returnNode = body; + } + if (ALLOWED_ATTR.shadowroot || ALLOWED_ATTR.shadowrootmode) { + returnNode = importNode.call(originalDocument, returnNode, true); + } + return returnNode; + } + let serializedHTML = WHOLE_DOCUMENT ? body.outerHTML : body.innerHTML; + if (WHOLE_DOCUMENT && ALLOWED_TAGS["!doctype"] && body.ownerDocument && body.ownerDocument.doctype && body.ownerDocument.doctype.name && regExpTest(DOCTYPE_NAME, body.ownerDocument.doctype.name)) { + serializedHTML = "\n" + serializedHTML; + } + if (SAFE_FOR_TEMPLATES) { + arrayForEach([MUSTACHE_EXPR2, ERB_EXPR2, TMPLIT_EXPR2], (expr) => { + serializedHTML = stringReplace(serializedHTML, expr, " "); + }); + } + return trustedTypesPolicy && RETURN_TRUSTED_TYPE ? trustedTypesPolicy.createHTML(serializedHTML) : serializedHTML; + }; + DOMPurify.setConfig = function() { + let cfg = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}; + _parseConfig(cfg); + SET_CONFIG = true; + }; + DOMPurify.clearConfig = function() { + CONFIG = null; + SET_CONFIG = false; + }; + DOMPurify.isValidAttribute = function(tag, attr, value) { + if (!CONFIG) { + _parseConfig({}); + } + const lcTag = transformCaseFunc(tag); + const lcName = transformCaseFunc(attr); + return _isValidAttribute(lcTag, lcName, value); + }; + DOMPurify.addHook = function(entryPoint, hookFunction) { + if (typeof hookFunction !== "function") { + return; + } + hooks[entryPoint] = hooks[entryPoint] || []; + arrayPush(hooks[entryPoint], hookFunction); + }; + DOMPurify.removeHook = function(entryPoint) { + if (hooks[entryPoint]) { + return arrayPop(hooks[entryPoint]); + } + }; + DOMPurify.removeHooks = function(entryPoint) { + if (hooks[entryPoint]) { + hooks[entryPoint] = []; + } + }; + DOMPurify.removeAllHooks = function() { + hooks = {}; + }; + return DOMPurify; +} +var purify = createDOMPurify(); +const lineBreakRegex = //gi; +const getRows = (s) => { + if (!s) { + return [""]; + } + const str2 = breakToPlaceholder(s).replace(/\\n/g, "#br#"); + return str2.split("#br#"); +}; +const setupDompurifyHooksIfNotSetup = (() => { + let setup = false; + return () => { + if (!setup) { + setupDompurifyHooks(); + setup = true; + } + }; +})(); +function setupDompurifyHooks() { + const TEMPORARY_ATTRIBUTE = "data-temp-href-target"; + purify.addHook("beforeSanitizeAttributes", (node2) => { + if (node2.tagName === "A" && node2.hasAttribute("target")) { + node2.setAttribute(TEMPORARY_ATTRIBUTE, node2.getAttribute("target") || ""); + } + }); + purify.addHook("afterSanitizeAttributes", (node2) => { + if (node2.tagName === "A" && node2.hasAttribute(TEMPORARY_ATTRIBUTE)) { + node2.setAttribute("target", node2.getAttribute(TEMPORARY_ATTRIBUTE) || ""); + node2.removeAttribute(TEMPORARY_ATTRIBUTE); + if (node2.getAttribute("target") === "_blank") { + node2.setAttribute("rel", "noopener"); + } + } + }); +} +const removeScript = (txt) => { + setupDompurifyHooksIfNotSetup(); + const sanitizedText = purify.sanitize(txt); + return sanitizedText; +}; +const sanitizeMore = (text2, config2) => { + var _a; + if (((_a = config2.flowchart) == null ? void 0 : _a.htmlLabels) !== false) { + const level = config2.securityLevel; + if (level === "antiscript" || level === "strict") { + text2 = removeScript(text2); + } else if (level !== "loose") { + text2 = breakToPlaceholder(text2); + text2 = text2.replace(//g, ">"); + text2 = text2.replace(/=/g, "="); + text2 = placeholderToBreak(text2); + } + } + return text2; +}; +const sanitizeText$2 = (text2, config2) => { + if (!text2) { + return text2; + } + if (config2.dompurifyConfig) { + text2 = purify.sanitize(sanitizeMore(text2, config2), config2.dompurifyConfig).toString(); + } else { + text2 = purify.sanitize(sanitizeMore(text2, config2), { + FORBID_TAGS: ["style"] + }).toString(); + } + return text2; +}; +const sanitizeTextOrArray = (a, config2) => { + if (typeof a === "string") { + return sanitizeText$2(a, config2); + } + return a.flat().map((x) => sanitizeText$2(x, config2)); +}; +const hasBreaks = (text2) => { + return lineBreakRegex.test(text2); +}; +const splitBreaks = (text2) => { + return text2.split(lineBreakRegex); +}; +const placeholderToBreak = (s) => { + return s.replace(/#br#/g, "
    "); +}; +const breakToPlaceholder = (s) => { + return s.replace(lineBreakRegex, "#br#"); +}; +const getUrl = (useAbsolute) => { + let url = ""; + if (useAbsolute) { + url = window.location.protocol + "//" + window.location.host + window.location.pathname + window.location.search; + url = url.replaceAll(/\(/g, "\\("); + url = url.replaceAll(/\)/g, "\\)"); + } + return url; +}; +const evaluate = (val) => val === false || ["false", "null", "0"].includes(String(val).trim().toLowerCase()) ? false : true; +const getMax = function(...values) { + const newValues = values.filter((value) => { + return !isNaN(value); + }); + return Math.max(...newValues); +}; +const getMin = function(...values) { + const newValues = values.filter((value) => { + return !isNaN(value); + }); + return Math.min(...newValues); +}; +const parseGenericTypes = function(input) { + const inputSets = input.split(/(,)/); + const output = []; + for (let i = 0; i < inputSets.length; i++) { + let thisSet = inputSets[i]; + if (thisSet === "," && i > 0 && i + 1 < inputSets.length) { + const previousSet = inputSets[i - 1]; + const nextSet = inputSets[i + 1]; + if (shouldCombineSets(previousSet, nextSet)) { + thisSet = previousSet + "," + nextSet; + i++; + output.pop(); + } + } + output.push(processSet(thisSet)); + } + return output.join(""); +}; +const countOccurrence = (string, substring) => { + return Math.max(0, string.split(substring).length - 1); +}; +const shouldCombineSets = (previousSet, nextSet) => { + const prevCount = countOccurrence(previousSet, "~"); + const nextCount = countOccurrence(nextSet, "~"); + return prevCount === 1 && nextCount === 1; +}; +const processSet = (input) => { + const tildeCount = countOccurrence(input, "~"); + let hasStartingTilde = false; + if (tildeCount <= 1) { + return input; + } + if (tildeCount % 2 !== 0 && input.startsWith("~")) { + input = input.substring(1); + hasStartingTilde = true; + } + const chars = [...input]; + let first = chars.indexOf("~"); + let last = chars.lastIndexOf("~"); + while (first !== -1 && last !== -1 && first !== last) { + chars[first] = "<"; + chars[last] = ">"; + first = chars.indexOf("~"); + last = chars.lastIndexOf("~"); + } + if (hasStartingTilde) { + chars.unshift("~"); + } + return chars.join(""); +}; +const isMathMLSupported = () => window.MathMLElement !== void 0; +const katexRegex = /\$\$(.*)\$\$/g; +const hasKatex = (text2) => { + var _a; + return (((_a = text2.match(katexRegex)) == null ? void 0 : _a.length) ?? 0) > 0; +}; +const calculateMathMLDimensions = async (text2, config2) => { + text2 = await renderKatex(text2, config2); + const divElem = document.createElement("div"); + divElem.innerHTML = text2; + divElem.id = "katex-temp"; + divElem.style.visibility = "hidden"; + divElem.style.position = "absolute"; + divElem.style.top = "0"; + const body = document.querySelector("body"); + body == null ? void 0 : body.insertAdjacentElement("beforeend", divElem); + const dim = { width: divElem.clientWidth, height: divElem.clientHeight }; + divElem.remove(); + return dim; +}; +const renderKatex = async (text2, config2) => { + if (!hasKatex(text2)) { + return text2; + } + if (!isMathMLSupported() && !config2.legacyMathML) { + return text2.replace(katexRegex, "MathML is unsupported in this environment."); + } + const { default: katex } = await import("./katex-ffb0e8f1.js"); + return text2.split(lineBreakRegex).map( + (line2) => hasKatex(line2) ? ` +
    + ${line2} +
    + ` : `
    ${line2}
    ` + ).join("").replace( + katexRegex, + (_2, c) => katex.renderToString(c, { + throwOnError: true, + displayMode: true, + output: isMathMLSupported() ? "mathml" : "htmlAndMathml" + }).replace(/\n/g, " ").replace(//g, "") + ); +}; +const common$1 = { + getRows, + sanitizeText: sanitizeText$2, + sanitizeTextOrArray, + hasBreaks, + splitBreaks, + lineBreakRegex, + removeScript, + getUrl, + evaluate, + getMax, + getMin +}; +const Channel = { + /* CLAMP */ + min: { + r: 0, + g: 0, + b: 0, + s: 0, + l: 0, + a: 0 + }, + max: { + r: 255, + g: 255, + b: 255, + h: 360, + s: 100, + l: 100, + a: 1 + }, + clamp: { + r: (r) => r >= 255 ? 255 : r < 0 ? 0 : r, + g: (g) => g >= 255 ? 255 : g < 0 ? 0 : g, + b: (b) => b >= 255 ? 255 : b < 0 ? 0 : b, + h: (h) => h % 360, + s: (s) => s >= 100 ? 100 : s < 0 ? 0 : s, + l: (l) => l >= 100 ? 100 : l < 0 ? 0 : l, + a: (a) => a >= 1 ? 1 : a < 0 ? 0 : a + }, + /* CONVERSION */ + //SOURCE: https://planetcalc.com/7779 + toLinear: (c) => { + const n = c / 255; + return c > 0.03928 ? Math.pow((n + 0.055) / 1.055, 2.4) : n / 12.92; + }, + //SOURCE: https://gist.github.com/mjackson/5311256 + hue2rgb: (p, q, t) => { + if (t < 0) + t += 1; + if (t > 1) + t -= 1; + if (t < 1 / 6) + return p + (q - p) * 6 * t; + if (t < 1 / 2) + return q; + if (t < 2 / 3) + return p + (q - p) * (2 / 3 - t) * 6; + return p; + }, + hsl2rgb: ({ h, s, l }, channel2) => { + if (!s) + return l * 2.55; + h /= 360; + s /= 100; + l /= 100; + const q = l < 0.5 ? l * (1 + s) : l + s - l * s; + const p = 2 * l - q; + switch (channel2) { + case "r": + return Channel.hue2rgb(p, q, h + 1 / 3) * 255; + case "g": + return Channel.hue2rgb(p, q, h) * 255; + case "b": + return Channel.hue2rgb(p, q, h - 1 / 3) * 255; + } + }, + rgb2hsl: ({ r, g, b }, channel2) => { + r /= 255; + g /= 255; + b /= 255; + const max2 = Math.max(r, g, b); + const min2 = Math.min(r, g, b); + const l = (max2 + min2) / 2; + if (channel2 === "l") + return l * 100; + if (max2 === min2) + return 0; + const d = max2 - min2; + const s = l > 0.5 ? d / (2 - max2 - min2) : d / (max2 + min2); + if (channel2 === "s") + return s * 100; + switch (max2) { + case r: + return ((g - b) / d + (g < b ? 6 : 0)) * 60; + case g: + return ((b - r) / d + 2) * 60; + case b: + return ((r - g) / d + 4) * 60; + default: + return -1; + } + } +}; +const channel = Channel; +const Lang = { + /* API */ + clamp: (number, lower2, upper) => { + if (lower2 > upper) + return Math.min(lower2, Math.max(upper, number)); + return Math.min(upper, Math.max(lower2, number)); + }, + round: (number) => { + return Math.round(number * 1e10) / 1e10; + } +}; +const lang = Lang; +const Unit = { + /* API */ + dec2hex: (dec) => { + const hex2 = Math.round(dec).toString(16); + return hex2.length > 1 ? hex2 : `0${hex2}`; + } +}; +const unit = Unit; +const Utils = { + channel, + lang, + unit +}; +const _ = Utils; +const DEC2HEX = {}; +for (let i = 0; i <= 255; i++) + DEC2HEX[i] = _.unit.dec2hex(i); +const TYPE = { + ALL: 0, + RGB: 1, + HSL: 2 +}; +class Type { + constructor() { + this.type = TYPE.ALL; + } + /* API */ + get() { + return this.type; + } + set(type2) { + if (this.type && this.type !== type2) + throw new Error("Cannot change both RGB and HSL channels at the same time"); + this.type = type2; + } + reset() { + this.type = TYPE.ALL; + } + is(type2) { + return this.type === type2; + } +} +const Type$2 = Type; +class Channels { + /* CONSTRUCTOR */ + constructor(data, color2) { + this.color = color2; + this.changed = false; + this.data = data; + this.type = new Type$2(); + } + /* API */ + set(data, color2) { + this.color = color2; + this.changed = false; + this.data = data; + this.type.type = TYPE.ALL; + return this; + } + /* HELPERS */ + _ensureHSL() { + const data = this.data; + const { h, s, l } = data; + if (h === void 0) + data.h = _.channel.rgb2hsl(data, "h"); + if (s === void 0) + data.s = _.channel.rgb2hsl(data, "s"); + if (l === void 0) + data.l = _.channel.rgb2hsl(data, "l"); + } + _ensureRGB() { + const data = this.data; + const { r, g, b } = data; + if (r === void 0) + data.r = _.channel.hsl2rgb(data, "r"); + if (g === void 0) + data.g = _.channel.hsl2rgb(data, "g"); + if (b === void 0) + data.b = _.channel.hsl2rgb(data, "b"); + } + /* GETTERS */ + get r() { + const data = this.data; + const r = data.r; + if (!this.type.is(TYPE.HSL) && r !== void 0) + return r; + this._ensureHSL(); + return _.channel.hsl2rgb(data, "r"); + } + get g() { + const data = this.data; + const g = data.g; + if (!this.type.is(TYPE.HSL) && g !== void 0) + return g; + this._ensureHSL(); + return _.channel.hsl2rgb(data, "g"); + } + get b() { + const data = this.data; + const b = data.b; + if (!this.type.is(TYPE.HSL) && b !== void 0) + return b; + this._ensureHSL(); + return _.channel.hsl2rgb(data, "b"); + } + get h() { + const data = this.data; + const h = data.h; + if (!this.type.is(TYPE.RGB) && h !== void 0) + return h; + this._ensureRGB(); + return _.channel.rgb2hsl(data, "h"); + } + get s() { + const data = this.data; + const s = data.s; + if (!this.type.is(TYPE.RGB) && s !== void 0) + return s; + this._ensureRGB(); + return _.channel.rgb2hsl(data, "s"); + } + get l() { + const data = this.data; + const l = data.l; + if (!this.type.is(TYPE.RGB) && l !== void 0) + return l; + this._ensureRGB(); + return _.channel.rgb2hsl(data, "l"); + } + get a() { + return this.data.a; + } + /* SETTERS */ + set r(r) { + this.type.set(TYPE.RGB); + this.changed = true; + this.data.r = r; + } + set g(g) { + this.type.set(TYPE.RGB); + this.changed = true; + this.data.g = g; + } + set b(b) { + this.type.set(TYPE.RGB); + this.changed = true; + this.data.b = b; + } + set h(h) { + this.type.set(TYPE.HSL); + this.changed = true; + this.data.h = h; + } + set s(s) { + this.type.set(TYPE.HSL); + this.changed = true; + this.data.s = s; + } + set l(l) { + this.type.set(TYPE.HSL); + this.changed = true; + this.data.l = l; + } + set a(a) { + this.changed = true; + this.data.a = a; + } +} +const Channels$1 = Channels; +const channels = new Channels$1({ r: 0, g: 0, b: 0, a: 0 }, "transparent"); +const ChannelsReusable = channels; +const Hex = { + /* VARIABLES */ + re: /^#((?:[a-f0-9]{2}){2,4}|[a-f0-9]{3})$/i, + /* API */ + parse: (color2) => { + if (color2.charCodeAt(0) !== 35) + return; + const match = color2.match(Hex.re); + if (!match) + return; + const hex2 = match[1]; + const dec = parseInt(hex2, 16); + const length2 = hex2.length; + const hasAlpha = length2 % 4 === 0; + const isFullLength = length2 > 4; + const multiplier = isFullLength ? 1 : 17; + const bits = isFullLength ? 8 : 4; + const bitsOffset = hasAlpha ? 0 : -1; + const mask = isFullLength ? 255 : 15; + return ChannelsReusable.set({ + r: (dec >> bits * (bitsOffset + 3) & mask) * multiplier, + g: (dec >> bits * (bitsOffset + 2) & mask) * multiplier, + b: (dec >> bits * (bitsOffset + 1) & mask) * multiplier, + a: hasAlpha ? (dec & mask) * multiplier / 255 : 1 + }, color2); + }, + stringify: (channels2) => { + const { r, g, b, a } = channels2; + if (a < 1) { + return `#${DEC2HEX[Math.round(r)]}${DEC2HEX[Math.round(g)]}${DEC2HEX[Math.round(b)]}${DEC2HEX[Math.round(a * 255)]}`; + } else { + return `#${DEC2HEX[Math.round(r)]}${DEC2HEX[Math.round(g)]}${DEC2HEX[Math.round(b)]}`; + } + } +}; +const Hex$1 = Hex; +const HSL = { + /* VARIABLES */ + re: /^hsla?\(\s*?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e-?\d+)?(?:deg|grad|rad|turn)?)\s*?(?:,|\s)\s*?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e-?\d+)?%)\s*?(?:,|\s)\s*?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e-?\d+)?%)(?:\s*?(?:,|\/)\s*?\+?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e-?\d+)?(%)?))?\s*?\)$/i, + hueRe: /^(.+?)(deg|grad|rad|turn)$/i, + /* HELPERS */ + _hue2deg: (hue2) => { + const match = hue2.match(HSL.hueRe); + if (match) { + const [, number, unit2] = match; + switch (unit2) { + case "grad": + return _.channel.clamp.h(parseFloat(number) * 0.9); + case "rad": + return _.channel.clamp.h(parseFloat(number) * 180 / Math.PI); + case "turn": + return _.channel.clamp.h(parseFloat(number) * 360); + } + } + return _.channel.clamp.h(parseFloat(hue2)); + }, + /* API */ + parse: (color2) => { + const charCode = color2.charCodeAt(0); + if (charCode !== 104 && charCode !== 72) + return; + const match = color2.match(HSL.re); + if (!match) + return; + const [, h, s, l, a, isAlphaPercentage] = match; + return ChannelsReusable.set({ + h: HSL._hue2deg(h), + s: _.channel.clamp.s(parseFloat(s)), + l: _.channel.clamp.l(parseFloat(l)), + a: a ? _.channel.clamp.a(isAlphaPercentage ? parseFloat(a) / 100 : parseFloat(a)) : 1 + }, color2); + }, + stringify: (channels2) => { + const { h, s, l, a } = channels2; + if (a < 1) { + return `hsla(${_.lang.round(h)}, ${_.lang.round(s)}%, ${_.lang.round(l)}%, ${a})`; + } else { + return `hsl(${_.lang.round(h)}, ${_.lang.round(s)}%, ${_.lang.round(l)}%)`; + } + } +}; +const HSL$1 = HSL; +const Keyword = { + /* VARIABLES */ + colors: { + aliceblue: "#f0f8ff", + antiquewhite: "#faebd7", + aqua: "#00ffff", + aquamarine: "#7fffd4", + azure: "#f0ffff", + beige: "#f5f5dc", + bisque: "#ffe4c4", + black: "#000000", + blanchedalmond: "#ffebcd", + blue: "#0000ff", + blueviolet: "#8a2be2", + brown: "#a52a2a", + burlywood: "#deb887", + cadetblue: "#5f9ea0", + chartreuse: "#7fff00", + chocolate: "#d2691e", + coral: "#ff7f50", + cornflowerblue: "#6495ed", + cornsilk: "#fff8dc", + crimson: "#dc143c", + cyanaqua: "#00ffff", + darkblue: "#00008b", + darkcyan: "#008b8b", + darkgoldenrod: "#b8860b", + darkgray: "#a9a9a9", + darkgreen: "#006400", + darkgrey: "#a9a9a9", + darkkhaki: "#bdb76b", + darkmagenta: "#8b008b", + darkolivegreen: "#556b2f", + darkorange: "#ff8c00", + darkorchid: "#9932cc", + darkred: "#8b0000", + darksalmon: "#e9967a", + darkseagreen: "#8fbc8f", + darkslateblue: "#483d8b", + darkslategray: "#2f4f4f", + darkslategrey: "#2f4f4f", + darkturquoise: "#00ced1", + darkviolet: "#9400d3", + deeppink: "#ff1493", + deepskyblue: "#00bfff", + dimgray: "#696969", + dimgrey: "#696969", + dodgerblue: "#1e90ff", + firebrick: "#b22222", + floralwhite: "#fffaf0", + forestgreen: "#228b22", + fuchsia: "#ff00ff", + gainsboro: "#dcdcdc", + ghostwhite: "#f8f8ff", + gold: "#ffd700", + goldenrod: "#daa520", + gray: "#808080", + green: "#008000", + greenyellow: "#adff2f", + grey: "#808080", + honeydew: "#f0fff0", + hotpink: "#ff69b4", + indianred: "#cd5c5c", + indigo: "#4b0082", + ivory: "#fffff0", + khaki: "#f0e68c", + lavender: "#e6e6fa", + lavenderblush: "#fff0f5", + lawngreen: "#7cfc00", + lemonchiffon: "#fffacd", + lightblue: "#add8e6", + lightcoral: "#f08080", + lightcyan: "#e0ffff", + lightgoldenrodyellow: "#fafad2", + lightgray: "#d3d3d3", + lightgreen: "#90ee90", + lightgrey: "#d3d3d3", + lightpink: "#ffb6c1", + lightsalmon: "#ffa07a", + lightseagreen: "#20b2aa", + lightskyblue: "#87cefa", + lightslategray: "#778899", + lightslategrey: "#778899", + lightsteelblue: "#b0c4de", + lightyellow: "#ffffe0", + lime: "#00ff00", + limegreen: "#32cd32", + linen: "#faf0e6", + magenta: "#ff00ff", + maroon: "#800000", + mediumaquamarine: "#66cdaa", + mediumblue: "#0000cd", + mediumorchid: "#ba55d3", + mediumpurple: "#9370db", + mediumseagreen: "#3cb371", + mediumslateblue: "#7b68ee", + mediumspringgreen: "#00fa9a", + mediumturquoise: "#48d1cc", + mediumvioletred: "#c71585", + midnightblue: "#191970", + mintcream: "#f5fffa", + mistyrose: "#ffe4e1", + moccasin: "#ffe4b5", + navajowhite: "#ffdead", + navy: "#000080", + oldlace: "#fdf5e6", + olive: "#808000", + olivedrab: "#6b8e23", + orange: "#ffa500", + orangered: "#ff4500", + orchid: "#da70d6", + palegoldenrod: "#eee8aa", + palegreen: "#98fb98", + paleturquoise: "#afeeee", + palevioletred: "#db7093", + papayawhip: "#ffefd5", + peachpuff: "#ffdab9", + peru: "#cd853f", + pink: "#ffc0cb", + plum: "#dda0dd", + powderblue: "#b0e0e6", + purple: "#800080", + rebeccapurple: "#663399", + red: "#ff0000", + rosybrown: "#bc8f8f", + royalblue: "#4169e1", + saddlebrown: "#8b4513", + salmon: "#fa8072", + sandybrown: "#f4a460", + seagreen: "#2e8b57", + seashell: "#fff5ee", + sienna: "#a0522d", + silver: "#c0c0c0", + skyblue: "#87ceeb", + slateblue: "#6a5acd", + slategray: "#708090", + slategrey: "#708090", + snow: "#fffafa", + springgreen: "#00ff7f", + tan: "#d2b48c", + teal: "#008080", + thistle: "#d8bfd8", + transparent: "#00000000", + turquoise: "#40e0d0", + violet: "#ee82ee", + wheat: "#f5deb3", + white: "#ffffff", + whitesmoke: "#f5f5f5", + yellow: "#ffff00", + yellowgreen: "#9acd32" + }, + /* API */ + parse: (color2) => { + color2 = color2.toLowerCase(); + const hex2 = Keyword.colors[color2]; + if (!hex2) + return; + return Hex$1.parse(hex2); + }, + stringify: (channels2) => { + const hex2 = Hex$1.stringify(channels2); + for (const name in Keyword.colors) { + if (Keyword.colors[name] === hex2) + return name; + } + return; + } +}; +const Keyword$1 = Keyword; +const RGB = { + /* VARIABLES */ + re: /^rgba?\(\s*?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e\d+)?(%?))\s*?(?:,|\s)\s*?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e\d+)?(%?))\s*?(?:,|\s)\s*?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e\d+)?(%?))(?:\s*?(?:,|\/)\s*?\+?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e\d+)?(%?)))?\s*?\)$/i, + /* API */ + parse: (color2) => { + const charCode = color2.charCodeAt(0); + if (charCode !== 114 && charCode !== 82) + return; + const match = color2.match(RGB.re); + if (!match) + return; + const [, r, isRedPercentage, g, isGreenPercentage, b, isBluePercentage, a, isAlphaPercentage] = match; + return ChannelsReusable.set({ + r: _.channel.clamp.r(isRedPercentage ? parseFloat(r) * 2.55 : parseFloat(r)), + g: _.channel.clamp.g(isGreenPercentage ? parseFloat(g) * 2.55 : parseFloat(g)), + b: _.channel.clamp.b(isBluePercentage ? parseFloat(b) * 2.55 : parseFloat(b)), + a: a ? _.channel.clamp.a(isAlphaPercentage ? parseFloat(a) / 100 : parseFloat(a)) : 1 + }, color2); + }, + stringify: (channels2) => { + const { r, g, b, a } = channels2; + if (a < 1) { + return `rgba(${_.lang.round(r)}, ${_.lang.round(g)}, ${_.lang.round(b)}, ${_.lang.round(a)})`; + } else { + return `rgb(${_.lang.round(r)}, ${_.lang.round(g)}, ${_.lang.round(b)})`; + } + } +}; +const RGB$1 = RGB; +const Color = { + /* VARIABLES */ + format: { + keyword: Keyword$1, + hex: Hex$1, + rgb: RGB$1, + rgba: RGB$1, + hsl: HSL$1, + hsla: HSL$1 + }, + /* API */ + parse: (color2) => { + if (typeof color2 !== "string") + return color2; + const channels2 = Hex$1.parse(color2) || RGB$1.parse(color2) || HSL$1.parse(color2) || Keyword$1.parse(color2); + if (channels2) + return channels2; + throw new Error(`Unsupported color format: "${color2}"`); + }, + stringify: (channels2) => { + if (!channels2.changed && channels2.color) + return channels2.color; + if (channels2.type.is(TYPE.HSL) || channels2.data.r === void 0) { + return HSL$1.stringify(channels2); + } else if (channels2.a < 1 || !Number.isInteger(channels2.r) || !Number.isInteger(channels2.g) || !Number.isInteger(channels2.b)) { + return RGB$1.stringify(channels2); + } else { + return Hex$1.stringify(channels2); + } + } +}; +const Color$1 = Color; +const change = (color2, channels2) => { + const ch = Color$1.parse(color2); + for (const c in channels2) { + ch[c] = _.channel.clamp[c](channels2[c]); + } + return Color$1.stringify(ch); +}; +const change$1 = change; +const rgba = (r, g, b = 0, a = 1) => { + if (typeof r !== "number") + return change$1(r, { a: g }); + const channels2 = ChannelsReusable.set({ + r: _.channel.clamp.r(r), + g: _.channel.clamp.g(g), + b: _.channel.clamp.b(b), + a: _.channel.clamp.a(a) + }); + return Color$1.stringify(channels2); +}; +const rgba$1 = rgba; +const luminance = (color2) => { + const { r, g, b } = Color$1.parse(color2); + const luminance2 = 0.2126 * _.channel.toLinear(r) + 0.7152 * _.channel.toLinear(g) + 0.0722 * _.channel.toLinear(b); + return _.lang.round(luminance2); +}; +const luminance$1 = luminance; +const isLight = (color2) => { + return luminance$1(color2) >= 0.5; +}; +const isLight$1 = isLight; +const isDark = (color2) => { + return !isLight$1(color2); +}; +const isDark$1 = isDark; +const adjustChannel = (color2, channel2, amount) => { + const channels2 = Color$1.parse(color2); + const amountCurrent = channels2[channel2]; + const amountNext = _.channel.clamp[channel2](amountCurrent + amount); + if (amountCurrent !== amountNext) + channels2[channel2] = amountNext; + return Color$1.stringify(channels2); +}; +const adjustChannel$1 = adjustChannel; +const lighten = (color2, amount) => { + return adjustChannel$1(color2, "l", amount); +}; +const lighten$1 = lighten; +const darken = (color2, amount) => { + return adjustChannel$1(color2, "l", -amount); +}; +const darken$1 = darken; +const adjust = (color2, channels2) => { + const ch = Color$1.parse(color2); + const changes = {}; + for (const c in channels2) { + if (!channels2[c]) + continue; + changes[c] = ch[c] + channels2[c]; + } + return change$1(color2, changes); +}; +const adjust$1 = adjust; +const mix = (color1, color2, weight = 50) => { + const { r: r1, g: g1, b: b1, a: a1 } = Color$1.parse(color1); + const { r: r2, g: g2, b: b2, a: a2 } = Color$1.parse(color2); + const weightScale = weight / 100; + const weightNormalized = weightScale * 2 - 1; + const alphaDelta = a1 - a2; + const weight1combined = weightNormalized * alphaDelta === -1 ? weightNormalized : (weightNormalized + alphaDelta) / (1 + weightNormalized * alphaDelta); + const weight1 = (weight1combined + 1) / 2; + const weight2 = 1 - weight1; + const r = r1 * weight1 + r2 * weight2; + const g = g1 * weight1 + g2 * weight2; + const b = b1 * weight1 + b2 * weight2; + const a = a1 * weightScale + a2 * (1 - weightScale); + return rgba$1(r, g, b, a); +}; +const mix$1 = mix; +const invert = (color2, weight = 100) => { + const inverse = Color$1.parse(color2); + inverse.r = 255 - inverse.r; + inverse.g = 255 - inverse.g; + inverse.b = 255 - inverse.b; + return mix$1(inverse, color2, weight); +}; +const invert$1 = invert; +const mkBorder = (col, darkMode) => darkMode ? adjust$1(col, { s: -40, l: 10 }) : adjust$1(col, { s: -40, l: -10 }); +const oldAttributeBackgroundColorOdd = "#ffffff"; +const oldAttributeBackgroundColorEven = "#f2f2f2"; +let Theme$4 = class Theme { + constructor() { + this.background = "#f4f4f4"; + this.primaryColor = "#fff4dd"; + this.noteBkgColor = "#fff5ad"; + this.noteTextColor = "#333"; + this.THEME_COLOR_LIMIT = 12; + this.fontFamily = '"trebuchet ms", verdana, arial, sans-serif'; + this.fontSize = "16px"; + } + updateColors() { + var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k; + this.primaryTextColor = this.primaryTextColor || (this.darkMode ? "#eee" : "#333"); + this.secondaryColor = this.secondaryColor || adjust$1(this.primaryColor, { h: -120 }); + this.tertiaryColor = this.tertiaryColor || adjust$1(this.primaryColor, { h: 180, l: 5 }); + this.primaryBorderColor = this.primaryBorderColor || mkBorder(this.primaryColor, this.darkMode); + this.secondaryBorderColor = this.secondaryBorderColor || mkBorder(this.secondaryColor, this.darkMode); + this.tertiaryBorderColor = this.tertiaryBorderColor || mkBorder(this.tertiaryColor, this.darkMode); + this.noteBorderColor = this.noteBorderColor || mkBorder(this.noteBkgColor, this.darkMode); + this.noteBkgColor = this.noteBkgColor || "#fff5ad"; + this.noteTextColor = this.noteTextColor || "#333"; + this.secondaryTextColor = this.secondaryTextColor || invert$1(this.secondaryColor); + this.tertiaryTextColor = this.tertiaryTextColor || invert$1(this.tertiaryColor); + this.lineColor = this.lineColor || invert$1(this.background); + this.arrowheadColor = this.arrowheadColor || invert$1(this.background); + this.textColor = this.textColor || this.primaryTextColor; + this.border2 = this.border2 || this.tertiaryBorderColor; + this.nodeBkg = this.nodeBkg || this.primaryColor; + this.mainBkg = this.mainBkg || this.primaryColor; + this.nodeBorder = this.nodeBorder || this.primaryBorderColor; + this.clusterBkg = this.clusterBkg || this.tertiaryColor; + this.clusterBorder = this.clusterBorder || this.tertiaryBorderColor; + this.defaultLinkColor = this.defaultLinkColor || this.lineColor; + this.titleColor = this.titleColor || this.tertiaryTextColor; + this.edgeLabelBackground = this.edgeLabelBackground || (this.darkMode ? darken$1(this.secondaryColor, 30) : this.secondaryColor); + this.nodeTextColor = this.nodeTextColor || this.primaryTextColor; + this.actorBorder = this.actorBorder || this.primaryBorderColor; + this.actorBkg = this.actorBkg || this.mainBkg; + this.actorTextColor = this.actorTextColor || this.primaryTextColor; + this.actorLineColor = this.actorLineColor || "grey"; + this.labelBoxBkgColor = this.labelBoxBkgColor || this.actorBkg; + this.signalColor = this.signalColor || this.textColor; + this.signalTextColor = this.signalTextColor || this.textColor; + this.labelBoxBorderColor = this.labelBoxBorderColor || this.actorBorder; + this.labelTextColor = this.labelTextColor || this.actorTextColor; + this.loopTextColor = this.loopTextColor || this.actorTextColor; + this.activationBorderColor = this.activationBorderColor || darken$1(this.secondaryColor, 10); + this.activationBkgColor = this.activationBkgColor || this.secondaryColor; + this.sequenceNumberColor = this.sequenceNumberColor || invert$1(this.lineColor); + this.sectionBkgColor = this.sectionBkgColor || this.tertiaryColor; + this.altSectionBkgColor = this.altSectionBkgColor || "white"; + this.sectionBkgColor = this.sectionBkgColor || this.secondaryColor; + this.sectionBkgColor2 = this.sectionBkgColor2 || this.primaryColor; + this.excludeBkgColor = this.excludeBkgColor || "#eeeeee"; + this.taskBorderColor = this.taskBorderColor || this.primaryBorderColor; + this.taskBkgColor = this.taskBkgColor || this.primaryColor; + this.activeTaskBorderColor = this.activeTaskBorderColor || this.primaryColor; + this.activeTaskBkgColor = this.activeTaskBkgColor || lighten$1(this.primaryColor, 23); + this.gridColor = this.gridColor || "lightgrey"; + this.doneTaskBkgColor = this.doneTaskBkgColor || "lightgrey"; + this.doneTaskBorderColor = this.doneTaskBorderColor || "grey"; + this.critBorderColor = this.critBorderColor || "#ff8888"; + this.critBkgColor = this.critBkgColor || "red"; + this.todayLineColor = this.todayLineColor || "red"; + this.taskTextColor = this.taskTextColor || this.textColor; + this.taskTextOutsideColor = this.taskTextOutsideColor || this.textColor; + this.taskTextLightColor = this.taskTextLightColor || this.textColor; + this.taskTextColor = this.taskTextColor || this.primaryTextColor; + this.taskTextDarkColor = this.taskTextDarkColor || this.textColor; + this.taskTextClickableColor = this.taskTextClickableColor || "#003163"; + this.personBorder = this.personBorder || this.primaryBorderColor; + this.personBkg = this.personBkg || this.mainBkg; + this.transitionColor = this.transitionColor || this.lineColor; + this.transitionLabelColor = this.transitionLabelColor || this.textColor; + this.stateLabelColor = this.stateLabelColor || this.stateBkg || this.primaryTextColor; + this.stateBkg = this.stateBkg || this.mainBkg; + this.labelBackgroundColor = this.labelBackgroundColor || this.stateBkg; + this.compositeBackground = this.compositeBackground || this.background || this.tertiaryColor; + this.altBackground = this.altBackground || this.tertiaryColor; + this.compositeTitleBackground = this.compositeTitleBackground || this.mainBkg; + this.compositeBorder = this.compositeBorder || this.nodeBorder; + this.innerEndBackground = this.nodeBorder; + this.errorBkgColor = this.errorBkgColor || this.tertiaryColor; + this.errorTextColor = this.errorTextColor || this.tertiaryTextColor; + this.transitionColor = this.transitionColor || this.lineColor; + this.specialStateColor = this.lineColor; + this.cScale0 = this.cScale0 || this.primaryColor; + this.cScale1 = this.cScale1 || this.secondaryColor; + this.cScale2 = this.cScale2 || this.tertiaryColor; + this.cScale3 = this.cScale3 || adjust$1(this.primaryColor, { h: 30 }); + this.cScale4 = this.cScale4 || adjust$1(this.primaryColor, { h: 60 }); + this.cScale5 = this.cScale5 || adjust$1(this.primaryColor, { h: 90 }); + this.cScale6 = this.cScale6 || adjust$1(this.primaryColor, { h: 120 }); + this.cScale7 = this.cScale7 || adjust$1(this.primaryColor, { h: 150 }); + this.cScale8 = this.cScale8 || adjust$1(this.primaryColor, { h: 210, l: 150 }); + this.cScale9 = this.cScale9 || adjust$1(this.primaryColor, { h: 270 }); + this.cScale10 = this.cScale10 || adjust$1(this.primaryColor, { h: 300 }); + this.cScale11 = this.cScale11 || adjust$1(this.primaryColor, { h: 330 }); + if (this.darkMode) { + for (let i = 0; i < this.THEME_COLOR_LIMIT; i++) { + this["cScale" + i] = darken$1(this["cScale" + i], 75); + } + } else { + for (let i = 0; i < this.THEME_COLOR_LIMIT; i++) { + this["cScale" + i] = darken$1(this["cScale" + i], 25); + } + } + for (let i = 0; i < this.THEME_COLOR_LIMIT; i++) { + this["cScaleInv" + i] = this["cScaleInv" + i] || invert$1(this["cScale" + i]); + } + for (let i = 0; i < this.THEME_COLOR_LIMIT; i++) { + if (this.darkMode) { + this["cScalePeer" + i] = this["cScalePeer" + i] || lighten$1(this["cScale" + i], 10); + } else { + this["cScalePeer" + i] = this["cScalePeer" + i] || darken$1(this["cScale" + i], 10); + } + } + this.scaleLabelColor = this.scaleLabelColor || this.labelTextColor; + for (let i = 0; i < this.THEME_COLOR_LIMIT; i++) { + this["cScaleLabel" + i] = this["cScaleLabel" + i] || this.scaleLabelColor; + } + const multiplier = this.darkMode ? -4 : -1; + for (let i = 0; i < 5; i++) { + this["surface" + i] = this["surface" + i] || adjust$1(this.mainBkg, { h: 180, s: -15, l: multiplier * (5 + i * 3) }); + this["surfacePeer" + i] = this["surfacePeer" + i] || adjust$1(this.mainBkg, { h: 180, s: -15, l: multiplier * (8 + i * 3) }); + } + this.classText = this.classText || this.textColor; + this.fillType0 = this.fillType0 || this.primaryColor; + this.fillType1 = this.fillType1 || this.secondaryColor; + this.fillType2 = this.fillType2 || adjust$1(this.primaryColor, { h: 64 }); + this.fillType3 = this.fillType3 || adjust$1(this.secondaryColor, { h: 64 }); + this.fillType4 = this.fillType4 || adjust$1(this.primaryColor, { h: -64 }); + this.fillType5 = this.fillType5 || adjust$1(this.secondaryColor, { h: -64 }); + this.fillType6 = this.fillType6 || adjust$1(this.primaryColor, { h: 128 }); + this.fillType7 = this.fillType7 || adjust$1(this.secondaryColor, { h: 128 }); + this.pie1 = this.pie1 || this.primaryColor; + this.pie2 = this.pie2 || this.secondaryColor; + this.pie3 = this.pie3 || this.tertiaryColor; + this.pie4 = this.pie4 || adjust$1(this.primaryColor, { l: -10 }); + this.pie5 = this.pie5 || adjust$1(this.secondaryColor, { l: -10 }); + this.pie6 = this.pie6 || adjust$1(this.tertiaryColor, { l: -10 }); + this.pie7 = this.pie7 || adjust$1(this.primaryColor, { h: 60, l: -10 }); + this.pie8 = this.pie8 || adjust$1(this.primaryColor, { h: -60, l: -10 }); + this.pie9 = this.pie9 || adjust$1(this.primaryColor, { h: 120, l: 0 }); + this.pie10 = this.pie10 || adjust$1(this.primaryColor, { h: 60, l: -20 }); + this.pie11 = this.pie11 || adjust$1(this.primaryColor, { h: -60, l: -20 }); + this.pie12 = this.pie12 || adjust$1(this.primaryColor, { h: 120, l: -10 }); + this.pieTitleTextSize = this.pieTitleTextSize || "25px"; + this.pieTitleTextColor = this.pieTitleTextColor || this.taskTextDarkColor; + this.pieSectionTextSize = this.pieSectionTextSize || "17px"; + this.pieSectionTextColor = this.pieSectionTextColor || this.textColor; + this.pieLegendTextSize = this.pieLegendTextSize || "17px"; + this.pieLegendTextColor = this.pieLegendTextColor || this.taskTextDarkColor; + this.pieStrokeColor = this.pieStrokeColor || "black"; + this.pieStrokeWidth = this.pieStrokeWidth || "2px"; + this.pieOuterStrokeWidth = this.pieOuterStrokeWidth || "2px"; + this.pieOuterStrokeColor = this.pieOuterStrokeColor || "black"; + this.pieOpacity = this.pieOpacity || "0.7"; + this.quadrant1Fill = this.quadrant1Fill || this.primaryColor; + this.quadrant2Fill = this.quadrant2Fill || adjust$1(this.primaryColor, { r: 5, g: 5, b: 5 }); + this.quadrant3Fill = this.quadrant3Fill || adjust$1(this.primaryColor, { r: 10, g: 10, b: 10 }); + this.quadrant4Fill = this.quadrant4Fill || adjust$1(this.primaryColor, { r: 15, g: 15, b: 15 }); + this.quadrant1TextFill = this.quadrant1TextFill || this.primaryTextColor; + this.quadrant2TextFill = this.quadrant2TextFill || adjust$1(this.primaryTextColor, { r: -5, g: -5, b: -5 }); + this.quadrant3TextFill = this.quadrant3TextFill || adjust$1(this.primaryTextColor, { r: -10, g: -10, b: -10 }); + this.quadrant4TextFill = this.quadrant4TextFill || adjust$1(this.primaryTextColor, { r: -15, g: -15, b: -15 }); + this.quadrantPointFill = this.quadrantPointFill || isDark$1(this.quadrant1Fill) ? lighten$1(this.quadrant1Fill) : darken$1(this.quadrant1Fill); + this.quadrantPointTextFill = this.quadrantPointTextFill || this.primaryTextColor; + this.quadrantXAxisTextFill = this.quadrantXAxisTextFill || this.primaryTextColor; + this.quadrantYAxisTextFill = this.quadrantYAxisTextFill || this.primaryTextColor; + this.quadrantInternalBorderStrokeFill = this.quadrantInternalBorderStrokeFill || this.primaryBorderColor; + this.quadrantExternalBorderStrokeFill = this.quadrantExternalBorderStrokeFill || this.primaryBorderColor; + this.quadrantTitleFill = this.quadrantTitleFill || this.primaryTextColor; + this.xyChart = { + backgroundColor: ((_a = this.xyChart) == null ? void 0 : _a.backgroundColor) || this.background, + titleColor: ((_b = this.xyChart) == null ? void 0 : _b.titleColor) || this.primaryTextColor, + xAxisTitleColor: ((_c = this.xyChart) == null ? void 0 : _c.xAxisTitleColor) || this.primaryTextColor, + xAxisLabelColor: ((_d = this.xyChart) == null ? void 0 : _d.xAxisLabelColor) || this.primaryTextColor, + xAxisTickColor: ((_e = this.xyChart) == null ? void 0 : _e.xAxisTickColor) || this.primaryTextColor, + xAxisLineColor: ((_f = this.xyChart) == null ? void 0 : _f.xAxisLineColor) || this.primaryTextColor, + yAxisTitleColor: ((_g = this.xyChart) == null ? void 0 : _g.yAxisTitleColor) || this.primaryTextColor, + yAxisLabelColor: ((_h = this.xyChart) == null ? void 0 : _h.yAxisLabelColor) || this.primaryTextColor, + yAxisTickColor: ((_i = this.xyChart) == null ? void 0 : _i.yAxisTickColor) || this.primaryTextColor, + yAxisLineColor: ((_j = this.xyChart) == null ? void 0 : _j.yAxisLineColor) || this.primaryTextColor, + plotColorPalette: ((_k = this.xyChart) == null ? void 0 : _k.plotColorPalette) || "#FFF4DD,#FFD8B1,#FFA07A,#ECEFF1,#D6DBDF,#C3E0A8,#FFB6A4,#FFD74D,#738FA7,#FFFFF0" + }; + this.requirementBackground = this.requirementBackground || this.primaryColor; + this.requirementBorderColor = this.requirementBorderColor || this.primaryBorderColor; + this.requirementBorderSize = this.requirementBorderSize || "1"; + this.requirementTextColor = this.requirementTextColor || this.primaryTextColor; + this.relationColor = this.relationColor || this.lineColor; + this.relationLabelBackground = this.relationLabelBackground || (this.darkMode ? darken$1(this.secondaryColor, 30) : this.secondaryColor); + this.relationLabelColor = this.relationLabelColor || this.actorTextColor; + this.git0 = this.git0 || this.primaryColor; + this.git1 = this.git1 || this.secondaryColor; + this.git2 = this.git2 || this.tertiaryColor; + this.git3 = this.git3 || adjust$1(this.primaryColor, { h: -30 }); + this.git4 = this.git4 || adjust$1(this.primaryColor, { h: -60 }); + this.git5 = this.git5 || adjust$1(this.primaryColor, { h: -90 }); + this.git6 = this.git6 || adjust$1(this.primaryColor, { h: 60 }); + this.git7 = this.git7 || adjust$1(this.primaryColor, { h: 120 }); + if (this.darkMode) { + this.git0 = lighten$1(this.git0, 25); + this.git1 = lighten$1(this.git1, 25); + this.git2 = lighten$1(this.git2, 25); + this.git3 = lighten$1(this.git3, 25); + this.git4 = lighten$1(this.git4, 25); + this.git5 = lighten$1(this.git5, 25); + this.git6 = lighten$1(this.git6, 25); + this.git7 = lighten$1(this.git7, 25); + } else { + this.git0 = darken$1(this.git0, 25); + this.git1 = darken$1(this.git1, 25); + this.git2 = darken$1(this.git2, 25); + this.git3 = darken$1(this.git3, 25); + this.git4 = darken$1(this.git4, 25); + this.git5 = darken$1(this.git5, 25); + this.git6 = darken$1(this.git6, 25); + this.git7 = darken$1(this.git7, 25); + } + this.gitInv0 = this.gitInv0 || invert$1(this.git0); + this.gitInv1 = this.gitInv1 || invert$1(this.git1); + this.gitInv2 = this.gitInv2 || invert$1(this.git2); + this.gitInv3 = this.gitInv3 || invert$1(this.git3); + this.gitInv4 = this.gitInv4 || invert$1(this.git4); + this.gitInv5 = this.gitInv5 || invert$1(this.git5); + this.gitInv6 = this.gitInv6 || invert$1(this.git6); + this.gitInv7 = this.gitInv7 || invert$1(this.git7); + this.branchLabelColor = this.branchLabelColor || (this.darkMode ? "black" : this.labelTextColor); + this.gitBranchLabel0 = this.gitBranchLabel0 || this.branchLabelColor; + this.gitBranchLabel1 = this.gitBranchLabel1 || this.branchLabelColor; + this.gitBranchLabel2 = this.gitBranchLabel2 || this.branchLabelColor; + this.gitBranchLabel3 = this.gitBranchLabel3 || this.branchLabelColor; + this.gitBranchLabel4 = this.gitBranchLabel4 || this.branchLabelColor; + this.gitBranchLabel5 = this.gitBranchLabel5 || this.branchLabelColor; + this.gitBranchLabel6 = this.gitBranchLabel6 || this.branchLabelColor; + this.gitBranchLabel7 = this.gitBranchLabel7 || this.branchLabelColor; + this.tagLabelColor = this.tagLabelColor || this.primaryTextColor; + this.tagLabelBackground = this.tagLabelBackground || this.primaryColor; + this.tagLabelBorder = this.tagBorder || this.primaryBorderColor; + this.tagLabelFontSize = this.tagLabelFontSize || "10px"; + this.commitLabelColor = this.commitLabelColor || this.secondaryTextColor; + this.commitLabelBackground = this.commitLabelBackground || this.secondaryColor; + this.commitLabelFontSize = this.commitLabelFontSize || "10px"; + this.attributeBackgroundColorOdd = this.attributeBackgroundColorOdd || oldAttributeBackgroundColorOdd; + this.attributeBackgroundColorEven = this.attributeBackgroundColorEven || oldAttributeBackgroundColorEven; + } + calculate(overrides) { + if (typeof overrides !== "object") { + this.updateColors(); + return; + } + const keys = Object.keys(overrides); + keys.forEach((k) => { + this[k] = overrides[k]; + }); + this.updateColors(); + keys.forEach((k) => { + this[k] = overrides[k]; + }); + } +}; +const getThemeVariables$4 = (userOverrides) => { + const theme2 = new Theme$4(); + theme2.calculate(userOverrides); + return theme2; +}; +let Theme$3 = class Theme2 { + constructor() { + this.background = "#333"; + this.primaryColor = "#1f2020"; + this.secondaryColor = lighten$1(this.primaryColor, 16); + this.tertiaryColor = adjust$1(this.primaryColor, { h: -160 }); + this.primaryBorderColor = invert$1(this.background); + this.secondaryBorderColor = mkBorder(this.secondaryColor, this.darkMode); + this.tertiaryBorderColor = mkBorder(this.tertiaryColor, this.darkMode); + this.primaryTextColor = invert$1(this.primaryColor); + this.secondaryTextColor = invert$1(this.secondaryColor); + this.tertiaryTextColor = invert$1(this.tertiaryColor); + this.lineColor = invert$1(this.background); + this.textColor = invert$1(this.background); + this.mainBkg = "#1f2020"; + this.secondBkg = "calculated"; + this.mainContrastColor = "lightgrey"; + this.darkTextColor = lighten$1(invert$1("#323D47"), 10); + this.lineColor = "calculated"; + this.border1 = "#81B1DB"; + this.border2 = rgba$1(255, 255, 255, 0.25); + this.arrowheadColor = "calculated"; + this.fontFamily = '"trebuchet ms", verdana, arial, sans-serif'; + this.fontSize = "16px"; + this.labelBackground = "#181818"; + this.textColor = "#ccc"; + this.THEME_COLOR_LIMIT = 12; + this.nodeBkg = "calculated"; + this.nodeBorder = "calculated"; + this.clusterBkg = "calculated"; + this.clusterBorder = "calculated"; + this.defaultLinkColor = "calculated"; + this.titleColor = "#F9FFFE"; + this.edgeLabelBackground = "calculated"; + this.actorBorder = "calculated"; + this.actorBkg = "calculated"; + this.actorTextColor = "calculated"; + this.actorLineColor = "calculated"; + this.signalColor = "calculated"; + this.signalTextColor = "calculated"; + this.labelBoxBkgColor = "calculated"; + this.labelBoxBorderColor = "calculated"; + this.labelTextColor = "calculated"; + this.loopTextColor = "calculated"; + this.noteBorderColor = "calculated"; + this.noteBkgColor = "#fff5ad"; + this.noteTextColor = "calculated"; + this.activationBorderColor = "calculated"; + this.activationBkgColor = "calculated"; + this.sequenceNumberColor = "black"; + this.sectionBkgColor = darken$1("#EAE8D9", 30); + this.altSectionBkgColor = "calculated"; + this.sectionBkgColor2 = "#EAE8D9"; + this.excludeBkgColor = darken$1(this.sectionBkgColor, 10); + this.taskBorderColor = rgba$1(255, 255, 255, 70); + this.taskBkgColor = "calculated"; + this.taskTextColor = "calculated"; + this.taskTextLightColor = "calculated"; + this.taskTextOutsideColor = "calculated"; + this.taskTextClickableColor = "#003163"; + this.activeTaskBorderColor = rgba$1(255, 255, 255, 50); + this.activeTaskBkgColor = "#81B1DB"; + this.gridColor = "calculated"; + this.doneTaskBkgColor = "calculated"; + this.doneTaskBorderColor = "grey"; + this.critBorderColor = "#E83737"; + this.critBkgColor = "#E83737"; + this.taskTextDarkColor = "calculated"; + this.todayLineColor = "#DB5757"; + this.personBorder = this.primaryBorderColor; + this.personBkg = this.mainBkg; + this.labelColor = "calculated"; + this.errorBkgColor = "#a44141"; + this.errorTextColor = "#ddd"; + } + updateColors() { + var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k; + this.secondBkg = lighten$1(this.mainBkg, 16); + this.lineColor = this.mainContrastColor; + this.arrowheadColor = this.mainContrastColor; + this.nodeBkg = this.mainBkg; + this.nodeBorder = this.border1; + this.clusterBkg = this.secondBkg; + this.clusterBorder = this.border2; + this.defaultLinkColor = this.lineColor; + this.edgeLabelBackground = lighten$1(this.labelBackground, 25); + this.actorBorder = this.border1; + this.actorBkg = this.mainBkg; + this.actorTextColor = this.mainContrastColor; + this.actorLineColor = this.mainContrastColor; + this.signalColor = this.mainContrastColor; + this.signalTextColor = this.mainContrastColor; + this.labelBoxBkgColor = this.actorBkg; + this.labelBoxBorderColor = this.actorBorder; + this.labelTextColor = this.mainContrastColor; + this.loopTextColor = this.mainContrastColor; + this.noteBorderColor = this.secondaryBorderColor; + this.noteBkgColor = this.secondBkg; + this.noteTextColor = this.secondaryTextColor; + this.activationBorderColor = this.border1; + this.activationBkgColor = this.secondBkg; + this.altSectionBkgColor = this.background; + this.taskBkgColor = lighten$1(this.mainBkg, 23); + this.taskTextColor = this.darkTextColor; + this.taskTextLightColor = this.mainContrastColor; + this.taskTextOutsideColor = this.taskTextLightColor; + this.gridColor = this.mainContrastColor; + this.doneTaskBkgColor = this.mainContrastColor; + this.taskTextDarkColor = this.darkTextColor; + this.transitionColor = this.transitionColor || this.lineColor; + this.transitionLabelColor = this.transitionLabelColor || this.textColor; + this.stateLabelColor = this.stateLabelColor || this.stateBkg || this.primaryTextColor; + this.stateBkg = this.stateBkg || this.mainBkg; + this.labelBackgroundColor = this.labelBackgroundColor || this.stateBkg; + this.compositeBackground = this.compositeBackground || this.background || this.tertiaryColor; + this.altBackground = this.altBackground || "#555"; + this.compositeTitleBackground = this.compositeTitleBackground || this.mainBkg; + this.compositeBorder = this.compositeBorder || this.nodeBorder; + this.innerEndBackground = this.primaryBorderColor; + this.specialStateColor = "#f4f4f4"; + this.errorBkgColor = this.errorBkgColor || this.tertiaryColor; + this.errorTextColor = this.errorTextColor || this.tertiaryTextColor; + this.fillType0 = this.primaryColor; + this.fillType1 = this.secondaryColor; + this.fillType2 = adjust$1(this.primaryColor, { h: 64 }); + this.fillType3 = adjust$1(this.secondaryColor, { h: 64 }); + this.fillType4 = adjust$1(this.primaryColor, { h: -64 }); + this.fillType5 = adjust$1(this.secondaryColor, { h: -64 }); + this.fillType6 = adjust$1(this.primaryColor, { h: 128 }); + this.fillType7 = adjust$1(this.secondaryColor, { h: 128 }); + this.cScale1 = this.cScale1 || "#0b0000"; + this.cScale2 = this.cScale2 || "#4d1037"; + this.cScale3 = this.cScale3 || "#3f5258"; + this.cScale4 = this.cScale4 || "#4f2f1b"; + this.cScale5 = this.cScale5 || "#6e0a0a"; + this.cScale6 = this.cScale6 || "#3b0048"; + this.cScale7 = this.cScale7 || "#995a01"; + this.cScale8 = this.cScale8 || "#154706"; + this.cScale9 = this.cScale9 || "#161722"; + this.cScale10 = this.cScale10 || "#00296f"; + this.cScale11 = this.cScale11 || "#01629c"; + this.cScale12 = this.cScale12 || "#010029"; + this.cScale0 = this.cScale0 || this.primaryColor; + this.cScale1 = this.cScale1 || this.secondaryColor; + this.cScale2 = this.cScale2 || this.tertiaryColor; + this.cScale3 = this.cScale3 || adjust$1(this.primaryColor, { h: 30 }); + this.cScale4 = this.cScale4 || adjust$1(this.primaryColor, { h: 60 }); + this.cScale5 = this.cScale5 || adjust$1(this.primaryColor, { h: 90 }); + this.cScale6 = this.cScale6 || adjust$1(this.primaryColor, { h: 120 }); + this.cScale7 = this.cScale7 || adjust$1(this.primaryColor, { h: 150 }); + this.cScale8 = this.cScale8 || adjust$1(this.primaryColor, { h: 210 }); + this.cScale9 = this.cScale9 || adjust$1(this.primaryColor, { h: 270 }); + this.cScale10 = this.cScale10 || adjust$1(this.primaryColor, { h: 300 }); + this.cScale11 = this.cScale11 || adjust$1(this.primaryColor, { h: 330 }); + for (let i = 0; i < this.THEME_COLOR_LIMIT; i++) { + this["cScaleInv" + i] = this["cScaleInv" + i] || invert$1(this["cScale" + i]); + } + for (let i = 0; i < this.THEME_COLOR_LIMIT; i++) { + this["cScalePeer" + i] = this["cScalePeer" + i] || lighten$1(this["cScale" + i], 10); + } + for (let i = 0; i < 5; i++) { + this["surface" + i] = this["surface" + i] || adjust$1(this.mainBkg, { h: 30, s: -30, l: -(-10 + i * 4) }); + this["surfacePeer" + i] = this["surfacePeer" + i] || adjust$1(this.mainBkg, { h: 30, s: -30, l: -(-7 + i * 4) }); + } + this.scaleLabelColor = this.scaleLabelColor || (this.darkMode ? "black" : this.labelTextColor); + for (let i = 0; i < this.THEME_COLOR_LIMIT; i++) { + this["cScaleLabel" + i] = this["cScaleLabel" + i] || this.scaleLabelColor; + } + for (let i = 0; i < this.THEME_COLOR_LIMIT; i++) { + this["pie" + i] = this["cScale" + i]; + } + this.pieTitleTextSize = this.pieTitleTextSize || "25px"; + this.pieTitleTextColor = this.pieTitleTextColor || this.taskTextDarkColor; + this.pieSectionTextSize = this.pieSectionTextSize || "17px"; + this.pieSectionTextColor = this.pieSectionTextColor || this.textColor; + this.pieLegendTextSize = this.pieLegendTextSize || "17px"; + this.pieLegendTextColor = this.pieLegendTextColor || this.taskTextDarkColor; + this.pieStrokeColor = this.pieStrokeColor || "black"; + this.pieStrokeWidth = this.pieStrokeWidth || "2px"; + this.pieOuterStrokeWidth = this.pieOuterStrokeWidth || "2px"; + this.pieOuterStrokeColor = this.pieOuterStrokeColor || "black"; + this.pieOpacity = this.pieOpacity || "0.7"; + this.quadrant1Fill = this.quadrant1Fill || this.primaryColor; + this.quadrant2Fill = this.quadrant2Fill || adjust$1(this.primaryColor, { r: 5, g: 5, b: 5 }); + this.quadrant3Fill = this.quadrant3Fill || adjust$1(this.primaryColor, { r: 10, g: 10, b: 10 }); + this.quadrant4Fill = this.quadrant4Fill || adjust$1(this.primaryColor, { r: 15, g: 15, b: 15 }); + this.quadrant1TextFill = this.quadrant1TextFill || this.primaryTextColor; + this.quadrant2TextFill = this.quadrant2TextFill || adjust$1(this.primaryTextColor, { r: -5, g: -5, b: -5 }); + this.quadrant3TextFill = this.quadrant3TextFill || adjust$1(this.primaryTextColor, { r: -10, g: -10, b: -10 }); + this.quadrant4TextFill = this.quadrant4TextFill || adjust$1(this.primaryTextColor, { r: -15, g: -15, b: -15 }); + this.quadrantPointFill = this.quadrantPointFill || isDark$1(this.quadrant1Fill) ? lighten$1(this.quadrant1Fill) : darken$1(this.quadrant1Fill); + this.quadrantPointTextFill = this.quadrantPointTextFill || this.primaryTextColor; + this.quadrantXAxisTextFill = this.quadrantXAxisTextFill || this.primaryTextColor; + this.quadrantYAxisTextFill = this.quadrantYAxisTextFill || this.primaryTextColor; + this.quadrantInternalBorderStrokeFill = this.quadrantInternalBorderStrokeFill || this.primaryBorderColor; + this.quadrantExternalBorderStrokeFill = this.quadrantExternalBorderStrokeFill || this.primaryBorderColor; + this.quadrantTitleFill = this.quadrantTitleFill || this.primaryTextColor; + this.xyChart = { + backgroundColor: ((_a = this.xyChart) == null ? void 0 : _a.backgroundColor) || this.background, + titleColor: ((_b = this.xyChart) == null ? void 0 : _b.titleColor) || this.primaryTextColor, + xAxisTitleColor: ((_c = this.xyChart) == null ? void 0 : _c.xAxisTitleColor) || this.primaryTextColor, + xAxisLabelColor: ((_d = this.xyChart) == null ? void 0 : _d.xAxisLabelColor) || this.primaryTextColor, + xAxisTickColor: ((_e = this.xyChart) == null ? void 0 : _e.xAxisTickColor) || this.primaryTextColor, + xAxisLineColor: ((_f = this.xyChart) == null ? void 0 : _f.xAxisLineColor) || this.primaryTextColor, + yAxisTitleColor: ((_g = this.xyChart) == null ? void 0 : _g.yAxisTitleColor) || this.primaryTextColor, + yAxisLabelColor: ((_h = this.xyChart) == null ? void 0 : _h.yAxisLabelColor) || this.primaryTextColor, + yAxisTickColor: ((_i = this.xyChart) == null ? void 0 : _i.yAxisTickColor) || this.primaryTextColor, + yAxisLineColor: ((_j = this.xyChart) == null ? void 0 : _j.yAxisLineColor) || this.primaryTextColor, + plotColorPalette: ((_k = this.xyChart) == null ? void 0 : _k.plotColorPalette) || "#3498db,#2ecc71,#e74c3c,#f1c40f,#bdc3c7,#ffffff,#34495e,#9b59b6,#1abc9c,#e67e22" + }; + this.classText = this.primaryTextColor; + this.requirementBackground = this.requirementBackground || this.primaryColor; + this.requirementBorderColor = this.requirementBorderColor || this.primaryBorderColor; + this.requirementBorderSize = this.requirementBorderSize || "1"; + this.requirementTextColor = this.requirementTextColor || this.primaryTextColor; + this.relationColor = this.relationColor || this.lineColor; + this.relationLabelBackground = this.relationLabelBackground || (this.darkMode ? darken$1(this.secondaryColor, 30) : this.secondaryColor); + this.relationLabelColor = this.relationLabelColor || this.actorTextColor; + this.git0 = lighten$1(this.secondaryColor, 20); + this.git1 = lighten$1(this.pie2 || this.secondaryColor, 20); + this.git2 = lighten$1(this.pie3 || this.tertiaryColor, 20); + this.git3 = lighten$1(this.pie4 || adjust$1(this.primaryColor, { h: -30 }), 20); + this.git4 = lighten$1(this.pie5 || adjust$1(this.primaryColor, { h: -60 }), 20); + this.git5 = lighten$1(this.pie6 || adjust$1(this.primaryColor, { h: -90 }), 10); + this.git6 = lighten$1(this.pie7 || adjust$1(this.primaryColor, { h: 60 }), 10); + this.git7 = lighten$1(this.pie8 || adjust$1(this.primaryColor, { h: 120 }), 20); + this.gitInv0 = this.gitInv0 || invert$1(this.git0); + this.gitInv1 = this.gitInv1 || invert$1(this.git1); + this.gitInv2 = this.gitInv2 || invert$1(this.git2); + this.gitInv3 = this.gitInv3 || invert$1(this.git3); + this.gitInv4 = this.gitInv4 || invert$1(this.git4); + this.gitInv5 = this.gitInv5 || invert$1(this.git5); + this.gitInv6 = this.gitInv6 || invert$1(this.git6); + this.gitInv7 = this.gitInv7 || invert$1(this.git7); + this.gitBranchLabel0 = this.gitBranchLabel0 || invert$1(this.labelTextColor); + this.gitBranchLabel1 = this.gitBranchLabel1 || this.labelTextColor; + this.gitBranchLabel2 = this.gitBranchLabel2 || this.labelTextColor; + this.gitBranchLabel3 = this.gitBranchLabel3 || invert$1(this.labelTextColor); + this.gitBranchLabel4 = this.gitBranchLabel4 || this.labelTextColor; + this.gitBranchLabel5 = this.gitBranchLabel5 || this.labelTextColor; + this.gitBranchLabel6 = this.gitBranchLabel6 || this.labelTextColor; + this.gitBranchLabel7 = this.gitBranchLabel7 || this.labelTextColor; + this.tagLabelColor = this.tagLabelColor || this.primaryTextColor; + this.tagLabelBackground = this.tagLabelBackground || this.primaryColor; + this.tagLabelBorder = this.tagBorder || this.primaryBorderColor; + this.tagLabelFontSize = this.tagLabelFontSize || "10px"; + this.commitLabelColor = this.commitLabelColor || this.secondaryTextColor; + this.commitLabelBackground = this.commitLabelBackground || this.secondaryColor; + this.commitLabelFontSize = this.commitLabelFontSize || "10px"; + this.attributeBackgroundColorOdd = this.attributeBackgroundColorOdd || lighten$1(this.background, 12); + this.attributeBackgroundColorEven = this.attributeBackgroundColorEven || lighten$1(this.background, 2); + } + calculate(overrides) { + if (typeof overrides !== "object") { + this.updateColors(); + return; + } + const keys = Object.keys(overrides); + keys.forEach((k) => { + this[k] = overrides[k]; + }); + this.updateColors(); + keys.forEach((k) => { + this[k] = overrides[k]; + }); + } +}; +const getThemeVariables$3 = (userOverrides) => { + const theme2 = new Theme$3(); + theme2.calculate(userOverrides); + return theme2; +}; +let Theme$2 = class Theme3 { + constructor() { + this.background = "#f4f4f4"; + this.primaryColor = "#ECECFF"; + this.secondaryColor = adjust$1(this.primaryColor, { h: 120 }); + this.secondaryColor = "#ffffde"; + this.tertiaryColor = adjust$1(this.primaryColor, { h: -160 }); + this.primaryBorderColor = mkBorder(this.primaryColor, this.darkMode); + this.secondaryBorderColor = mkBorder(this.secondaryColor, this.darkMode); + this.tertiaryBorderColor = mkBorder(this.tertiaryColor, this.darkMode); + this.primaryTextColor = invert$1(this.primaryColor); + this.secondaryTextColor = invert$1(this.secondaryColor); + this.tertiaryTextColor = invert$1(this.tertiaryColor); + this.lineColor = invert$1(this.background); + this.textColor = invert$1(this.background); + this.background = "white"; + this.mainBkg = "#ECECFF"; + this.secondBkg = "#ffffde"; + this.lineColor = "#333333"; + this.border1 = "#9370DB"; + this.border2 = "#aaaa33"; + this.arrowheadColor = "#333333"; + this.fontFamily = '"trebuchet ms", verdana, arial, sans-serif'; + this.fontSize = "16px"; + this.labelBackground = "#e8e8e8"; + this.textColor = "#333"; + this.THEME_COLOR_LIMIT = 12; + this.nodeBkg = "calculated"; + this.nodeBorder = "calculated"; + this.clusterBkg = "calculated"; + this.clusterBorder = "calculated"; + this.defaultLinkColor = "calculated"; + this.titleColor = "calculated"; + this.edgeLabelBackground = "calculated"; + this.actorBorder = "calculated"; + this.actorBkg = "calculated"; + this.actorTextColor = "black"; + this.actorLineColor = "grey"; + this.signalColor = "calculated"; + this.signalTextColor = "calculated"; + this.labelBoxBkgColor = "calculated"; + this.labelBoxBorderColor = "calculated"; + this.labelTextColor = "calculated"; + this.loopTextColor = "calculated"; + this.noteBorderColor = "calculated"; + this.noteBkgColor = "#fff5ad"; + this.noteTextColor = "calculated"; + this.activationBorderColor = "#666"; + this.activationBkgColor = "#f4f4f4"; + this.sequenceNumberColor = "white"; + this.sectionBkgColor = "calculated"; + this.altSectionBkgColor = "calculated"; + this.sectionBkgColor2 = "calculated"; + this.excludeBkgColor = "#eeeeee"; + this.taskBorderColor = "calculated"; + this.taskBkgColor = "calculated"; + this.taskTextLightColor = "calculated"; + this.taskTextColor = this.taskTextLightColor; + this.taskTextDarkColor = "calculated"; + this.taskTextOutsideColor = this.taskTextDarkColor; + this.taskTextClickableColor = "calculated"; + this.activeTaskBorderColor = "calculated"; + this.activeTaskBkgColor = "calculated"; + this.gridColor = "calculated"; + this.doneTaskBkgColor = "calculated"; + this.doneTaskBorderColor = "calculated"; + this.critBorderColor = "calculated"; + this.critBkgColor = "calculated"; + this.todayLineColor = "calculated"; + this.sectionBkgColor = rgba$1(102, 102, 255, 0.49); + this.altSectionBkgColor = "white"; + this.sectionBkgColor2 = "#fff400"; + this.taskBorderColor = "#534fbc"; + this.taskBkgColor = "#8a90dd"; + this.taskTextLightColor = "white"; + this.taskTextColor = "calculated"; + this.taskTextDarkColor = "black"; + this.taskTextOutsideColor = "calculated"; + this.taskTextClickableColor = "#003163"; + this.activeTaskBorderColor = "#534fbc"; + this.activeTaskBkgColor = "#bfc7ff"; + this.gridColor = "lightgrey"; + this.doneTaskBkgColor = "lightgrey"; + this.doneTaskBorderColor = "grey"; + this.critBorderColor = "#ff8888"; + this.critBkgColor = "red"; + this.todayLineColor = "red"; + this.personBorder = this.primaryBorderColor; + this.personBkg = this.mainBkg; + this.labelColor = "black"; + this.errorBkgColor = "#552222"; + this.errorTextColor = "#552222"; + this.updateColors(); + } + updateColors() { + var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k; + this.cScale0 = this.cScale0 || this.primaryColor; + this.cScale1 = this.cScale1 || this.secondaryColor; + this.cScale2 = this.cScale2 || this.tertiaryColor; + this.cScale3 = this.cScale3 || adjust$1(this.primaryColor, { h: 30 }); + this.cScale4 = this.cScale4 || adjust$1(this.primaryColor, { h: 60 }); + this.cScale5 = this.cScale5 || adjust$1(this.primaryColor, { h: 90 }); + this.cScale6 = this.cScale6 || adjust$1(this.primaryColor, { h: 120 }); + this.cScale7 = this.cScale7 || adjust$1(this.primaryColor, { h: 150 }); + this.cScale8 = this.cScale8 || adjust$1(this.primaryColor, { h: 210 }); + this.cScale9 = this.cScale9 || adjust$1(this.primaryColor, { h: 270 }); + this.cScale10 = this.cScale10 || adjust$1(this.primaryColor, { h: 300 }); + this.cScale11 = this.cScale11 || adjust$1(this.primaryColor, { h: 330 }); + this["cScalePeer1"] = this["cScalePeer1"] || darken$1(this.secondaryColor, 45); + this["cScalePeer2"] = this["cScalePeer2"] || darken$1(this.tertiaryColor, 40); + for (let i = 0; i < this.THEME_COLOR_LIMIT; i++) { + this["cScale" + i] = darken$1(this["cScale" + i], 10); + this["cScalePeer" + i] = this["cScalePeer" + i] || darken$1(this["cScale" + i], 25); + } + for (let i = 0; i < this.THEME_COLOR_LIMIT; i++) { + this["cScaleInv" + i] = this["cScaleInv" + i] || adjust$1(this["cScale" + i], { h: 180 }); + } + for (let i = 0; i < 5; i++) { + this["surface" + i] = this["surface" + i] || adjust$1(this.mainBkg, { h: 30, l: -(5 + i * 5) }); + this["surfacePeer" + i] = this["surfacePeer" + i] || adjust$1(this.mainBkg, { h: 30, l: -(7 + i * 5) }); + } + this.scaleLabelColor = this.scaleLabelColor !== "calculated" && this.scaleLabelColor ? this.scaleLabelColor : this.labelTextColor; + if (this.labelTextColor !== "calculated") { + this.cScaleLabel0 = this.cScaleLabel0 || invert$1(this.labelTextColor); + this.cScaleLabel3 = this.cScaleLabel3 || invert$1(this.labelTextColor); + for (let i = 0; i < this.THEME_COLOR_LIMIT; i++) { + this["cScaleLabel" + i] = this["cScaleLabel" + i] || this.labelTextColor; + } + } + this.nodeBkg = this.mainBkg; + this.nodeBorder = this.border1; + this.clusterBkg = this.secondBkg; + this.clusterBorder = this.border2; + this.defaultLinkColor = this.lineColor; + this.titleColor = this.textColor; + this.edgeLabelBackground = this.labelBackground; + this.actorBorder = lighten$1(this.border1, 23); + this.actorBkg = this.mainBkg; + this.labelBoxBkgColor = this.actorBkg; + this.signalColor = this.textColor; + this.signalTextColor = this.textColor; + this.labelBoxBorderColor = this.actorBorder; + this.labelTextColor = this.actorTextColor; + this.loopTextColor = this.actorTextColor; + this.noteBorderColor = this.border2; + this.noteTextColor = this.actorTextColor; + this.taskTextColor = this.taskTextLightColor; + this.taskTextOutsideColor = this.taskTextDarkColor; + this.transitionColor = this.transitionColor || this.lineColor; + this.transitionLabelColor = this.transitionLabelColor || this.textColor; + this.stateLabelColor = this.stateLabelColor || this.stateBkg || this.primaryTextColor; + this.stateBkg = this.stateBkg || this.mainBkg; + this.labelBackgroundColor = this.labelBackgroundColor || this.stateBkg; + this.compositeBackground = this.compositeBackground || this.background || this.tertiaryColor; + this.altBackground = this.altBackground || "#f0f0f0"; + this.compositeTitleBackground = this.compositeTitleBackground || this.mainBkg; + this.compositeBorder = this.compositeBorder || this.nodeBorder; + this.innerEndBackground = this.nodeBorder; + this.specialStateColor = this.lineColor; + this.errorBkgColor = this.errorBkgColor || this.tertiaryColor; + this.errorTextColor = this.errorTextColor || this.tertiaryTextColor; + this.transitionColor = this.transitionColor || this.lineColor; + this.classText = this.primaryTextColor; + this.fillType0 = this.primaryColor; + this.fillType1 = this.secondaryColor; + this.fillType2 = adjust$1(this.primaryColor, { h: 64 }); + this.fillType3 = adjust$1(this.secondaryColor, { h: 64 }); + this.fillType4 = adjust$1(this.primaryColor, { h: -64 }); + this.fillType5 = adjust$1(this.secondaryColor, { h: -64 }); + this.fillType6 = adjust$1(this.primaryColor, { h: 128 }); + this.fillType7 = adjust$1(this.secondaryColor, { h: 128 }); + this.pie1 = this.pie1 || this.primaryColor; + this.pie2 = this.pie2 || this.secondaryColor; + this.pie3 = this.pie3 || adjust$1(this.tertiaryColor, { l: -40 }); + this.pie4 = this.pie4 || adjust$1(this.primaryColor, { l: -10 }); + this.pie5 = this.pie5 || adjust$1(this.secondaryColor, { l: -30 }); + this.pie6 = this.pie6 || adjust$1(this.tertiaryColor, { l: -20 }); + this.pie7 = this.pie7 || adjust$1(this.primaryColor, { h: 60, l: -20 }); + this.pie8 = this.pie8 || adjust$1(this.primaryColor, { h: -60, l: -40 }); + this.pie9 = this.pie9 || adjust$1(this.primaryColor, { h: 120, l: -40 }); + this.pie10 = this.pie10 || adjust$1(this.primaryColor, { h: 60, l: -40 }); + this.pie11 = this.pie11 || adjust$1(this.primaryColor, { h: -90, l: -40 }); + this.pie12 = this.pie12 || adjust$1(this.primaryColor, { h: 120, l: -30 }); + this.pieTitleTextSize = this.pieTitleTextSize || "25px"; + this.pieTitleTextColor = this.pieTitleTextColor || this.taskTextDarkColor; + this.pieSectionTextSize = this.pieSectionTextSize || "17px"; + this.pieSectionTextColor = this.pieSectionTextColor || this.textColor; + this.pieLegendTextSize = this.pieLegendTextSize || "17px"; + this.pieLegendTextColor = this.pieLegendTextColor || this.taskTextDarkColor; + this.pieStrokeColor = this.pieStrokeColor || "black"; + this.pieStrokeWidth = this.pieStrokeWidth || "2px"; + this.pieOuterStrokeWidth = this.pieOuterStrokeWidth || "2px"; + this.pieOuterStrokeColor = this.pieOuterStrokeColor || "black"; + this.pieOpacity = this.pieOpacity || "0.7"; + this.quadrant1Fill = this.quadrant1Fill || this.primaryColor; + this.quadrant2Fill = this.quadrant2Fill || adjust$1(this.primaryColor, { r: 5, g: 5, b: 5 }); + this.quadrant3Fill = this.quadrant3Fill || adjust$1(this.primaryColor, { r: 10, g: 10, b: 10 }); + this.quadrant4Fill = this.quadrant4Fill || adjust$1(this.primaryColor, { r: 15, g: 15, b: 15 }); + this.quadrant1TextFill = this.quadrant1TextFill || this.primaryTextColor; + this.quadrant2TextFill = this.quadrant2TextFill || adjust$1(this.primaryTextColor, { r: -5, g: -5, b: -5 }); + this.quadrant3TextFill = this.quadrant3TextFill || adjust$1(this.primaryTextColor, { r: -10, g: -10, b: -10 }); + this.quadrant4TextFill = this.quadrant4TextFill || adjust$1(this.primaryTextColor, { r: -15, g: -15, b: -15 }); + this.quadrantPointFill = this.quadrantPointFill || isDark$1(this.quadrant1Fill) ? lighten$1(this.quadrant1Fill) : darken$1(this.quadrant1Fill); + this.quadrantPointTextFill = this.quadrantPointTextFill || this.primaryTextColor; + this.quadrantXAxisTextFill = this.quadrantXAxisTextFill || this.primaryTextColor; + this.quadrantYAxisTextFill = this.quadrantYAxisTextFill || this.primaryTextColor; + this.quadrantInternalBorderStrokeFill = this.quadrantInternalBorderStrokeFill || this.primaryBorderColor; + this.quadrantExternalBorderStrokeFill = this.quadrantExternalBorderStrokeFill || this.primaryBorderColor; + this.quadrantTitleFill = this.quadrantTitleFill || this.primaryTextColor; + this.xyChart = { + backgroundColor: ((_a = this.xyChart) == null ? void 0 : _a.backgroundColor) || this.background, + titleColor: ((_b = this.xyChart) == null ? void 0 : _b.titleColor) || this.primaryTextColor, + xAxisTitleColor: ((_c = this.xyChart) == null ? void 0 : _c.xAxisTitleColor) || this.primaryTextColor, + xAxisLabelColor: ((_d = this.xyChart) == null ? void 0 : _d.xAxisLabelColor) || this.primaryTextColor, + xAxisTickColor: ((_e = this.xyChart) == null ? void 0 : _e.xAxisTickColor) || this.primaryTextColor, + xAxisLineColor: ((_f = this.xyChart) == null ? void 0 : _f.xAxisLineColor) || this.primaryTextColor, + yAxisTitleColor: ((_g = this.xyChart) == null ? void 0 : _g.yAxisTitleColor) || this.primaryTextColor, + yAxisLabelColor: ((_h = this.xyChart) == null ? void 0 : _h.yAxisLabelColor) || this.primaryTextColor, + yAxisTickColor: ((_i = this.xyChart) == null ? void 0 : _i.yAxisTickColor) || this.primaryTextColor, + yAxisLineColor: ((_j = this.xyChart) == null ? void 0 : _j.yAxisLineColor) || this.primaryTextColor, + plotColorPalette: ((_k = this.xyChart) == null ? void 0 : _k.plotColorPalette) || "#ECECFF,#8493A6,#FFC3A0,#DCDDE1,#B8E994,#D1A36F,#C3CDE6,#FFB6C1,#496078,#F8F3E3" + }; + this.requirementBackground = this.requirementBackground || this.primaryColor; + this.requirementBorderColor = this.requirementBorderColor || this.primaryBorderColor; + this.requirementBorderSize = this.requirementBorderSize || "1"; + this.requirementTextColor = this.requirementTextColor || this.primaryTextColor; + this.relationColor = this.relationColor || this.lineColor; + this.relationLabelBackground = this.relationLabelBackground || this.labelBackground; + this.relationLabelColor = this.relationLabelColor || this.actorTextColor; + this.git0 = this.git0 || this.primaryColor; + this.git1 = this.git1 || this.secondaryColor; + this.git2 = this.git2 || this.tertiaryColor; + this.git3 = this.git3 || adjust$1(this.primaryColor, { h: -30 }); + this.git4 = this.git4 || adjust$1(this.primaryColor, { h: -60 }); + this.git5 = this.git5 || adjust$1(this.primaryColor, { h: -90 }); + this.git6 = this.git6 || adjust$1(this.primaryColor, { h: 60 }); + this.git7 = this.git7 || adjust$1(this.primaryColor, { h: 120 }); + if (this.darkMode) { + this.git0 = lighten$1(this.git0, 25); + this.git1 = lighten$1(this.git1, 25); + this.git2 = lighten$1(this.git2, 25); + this.git3 = lighten$1(this.git3, 25); + this.git4 = lighten$1(this.git4, 25); + this.git5 = lighten$1(this.git5, 25); + this.git6 = lighten$1(this.git6, 25); + this.git7 = lighten$1(this.git7, 25); + } else { + this.git0 = darken$1(this.git0, 25); + this.git1 = darken$1(this.git1, 25); + this.git2 = darken$1(this.git2, 25); + this.git3 = darken$1(this.git3, 25); + this.git4 = darken$1(this.git4, 25); + this.git5 = darken$1(this.git5, 25); + this.git6 = darken$1(this.git6, 25); + this.git7 = darken$1(this.git7, 25); + } + this.gitInv0 = this.gitInv0 || darken$1(invert$1(this.git0), 25); + this.gitInv1 = this.gitInv1 || invert$1(this.git1); + this.gitInv2 = this.gitInv2 || invert$1(this.git2); + this.gitInv3 = this.gitInv3 || invert$1(this.git3); + this.gitInv4 = this.gitInv4 || invert$1(this.git4); + this.gitInv5 = this.gitInv5 || invert$1(this.git5); + this.gitInv6 = this.gitInv6 || invert$1(this.git6); + this.gitInv7 = this.gitInv7 || invert$1(this.git7); + this.gitBranchLabel0 = this.gitBranchLabel0 || invert$1(this.labelTextColor); + this.gitBranchLabel1 = this.gitBranchLabel1 || this.labelTextColor; + this.gitBranchLabel2 = this.gitBranchLabel2 || this.labelTextColor; + this.gitBranchLabel3 = this.gitBranchLabel3 || invert$1(this.labelTextColor); + this.gitBranchLabel4 = this.gitBranchLabel4 || this.labelTextColor; + this.gitBranchLabel5 = this.gitBranchLabel5 || this.labelTextColor; + this.gitBranchLabel6 = this.gitBranchLabel6 || this.labelTextColor; + this.gitBranchLabel7 = this.gitBranchLabel7 || this.labelTextColor; + this.tagLabelColor = this.tagLabelColor || this.primaryTextColor; + this.tagLabelBackground = this.tagLabelBackground || this.primaryColor; + this.tagLabelBorder = this.tagBorder || this.primaryBorderColor; + this.tagLabelFontSize = this.tagLabelFontSize || "10px"; + this.commitLabelColor = this.commitLabelColor || this.secondaryTextColor; + this.commitLabelBackground = this.commitLabelBackground || this.secondaryColor; + this.commitLabelFontSize = this.commitLabelFontSize || "10px"; + this.attributeBackgroundColorOdd = this.attributeBackgroundColorOdd || oldAttributeBackgroundColorOdd; + this.attributeBackgroundColorEven = this.attributeBackgroundColorEven || oldAttributeBackgroundColorEven; + } + calculate(overrides) { + if (typeof overrides !== "object") { + this.updateColors(); + return; + } + const keys = Object.keys(overrides); + keys.forEach((k) => { + this[k] = overrides[k]; + }); + this.updateColors(); + keys.forEach((k) => { + this[k] = overrides[k]; + }); + } +}; +const getThemeVariables$2 = (userOverrides) => { + const theme2 = new Theme$2(); + theme2.calculate(userOverrides); + return theme2; +}; +let Theme$1 = class Theme4 { + constructor() { + this.background = "#f4f4f4"; + this.primaryColor = "#cde498"; + this.secondaryColor = "#cdffb2"; + this.background = "white"; + this.mainBkg = "#cde498"; + this.secondBkg = "#cdffb2"; + this.lineColor = "green"; + this.border1 = "#13540c"; + this.border2 = "#6eaa49"; + this.arrowheadColor = "green"; + this.fontFamily = '"trebuchet ms", verdana, arial, sans-serif'; + this.fontSize = "16px"; + this.tertiaryColor = lighten$1("#cde498", 10); + this.primaryBorderColor = mkBorder(this.primaryColor, this.darkMode); + this.secondaryBorderColor = mkBorder(this.secondaryColor, this.darkMode); + this.tertiaryBorderColor = mkBorder(this.tertiaryColor, this.darkMode); + this.primaryTextColor = invert$1(this.primaryColor); + this.secondaryTextColor = invert$1(this.secondaryColor); + this.tertiaryTextColor = invert$1(this.primaryColor); + this.lineColor = invert$1(this.background); + this.textColor = invert$1(this.background); + this.THEME_COLOR_LIMIT = 12; + this.nodeBkg = "calculated"; + this.nodeBorder = "calculated"; + this.clusterBkg = "calculated"; + this.clusterBorder = "calculated"; + this.defaultLinkColor = "calculated"; + this.titleColor = "#333"; + this.edgeLabelBackground = "#e8e8e8"; + this.actorBorder = "calculated"; + this.actorBkg = "calculated"; + this.actorTextColor = "black"; + this.actorLineColor = "grey"; + this.signalColor = "#333"; + this.signalTextColor = "#333"; + this.labelBoxBkgColor = "calculated"; + this.labelBoxBorderColor = "#326932"; + this.labelTextColor = "calculated"; + this.loopTextColor = "calculated"; + this.noteBorderColor = "calculated"; + this.noteBkgColor = "#fff5ad"; + this.noteTextColor = "calculated"; + this.activationBorderColor = "#666"; + this.activationBkgColor = "#f4f4f4"; + this.sequenceNumberColor = "white"; + this.sectionBkgColor = "#6eaa49"; + this.altSectionBkgColor = "white"; + this.sectionBkgColor2 = "#6eaa49"; + this.excludeBkgColor = "#eeeeee"; + this.taskBorderColor = "calculated"; + this.taskBkgColor = "#487e3a"; + this.taskTextLightColor = "white"; + this.taskTextColor = "calculated"; + this.taskTextDarkColor = "black"; + this.taskTextOutsideColor = "calculated"; + this.taskTextClickableColor = "#003163"; + this.activeTaskBorderColor = "calculated"; + this.activeTaskBkgColor = "calculated"; + this.gridColor = "lightgrey"; + this.doneTaskBkgColor = "lightgrey"; + this.doneTaskBorderColor = "grey"; + this.critBorderColor = "#ff8888"; + this.critBkgColor = "red"; + this.todayLineColor = "red"; + this.personBorder = this.primaryBorderColor; + this.personBkg = this.mainBkg; + this.labelColor = "black"; + this.errorBkgColor = "#552222"; + this.errorTextColor = "#552222"; + } + updateColors() { + var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k; + this.actorBorder = darken$1(this.mainBkg, 20); + this.actorBkg = this.mainBkg; + this.labelBoxBkgColor = this.actorBkg; + this.labelTextColor = this.actorTextColor; + this.loopTextColor = this.actorTextColor; + this.noteBorderColor = this.border2; + this.noteTextColor = this.actorTextColor; + this.cScale0 = this.cScale0 || this.primaryColor; + this.cScale1 = this.cScale1 || this.secondaryColor; + this.cScale2 = this.cScale2 || this.tertiaryColor; + this.cScale3 = this.cScale3 || adjust$1(this.primaryColor, { h: 30 }); + this.cScale4 = this.cScale4 || adjust$1(this.primaryColor, { h: 60 }); + this.cScale5 = this.cScale5 || adjust$1(this.primaryColor, { h: 90 }); + this.cScale6 = this.cScale6 || adjust$1(this.primaryColor, { h: 120 }); + this.cScale7 = this.cScale7 || adjust$1(this.primaryColor, { h: 150 }); + this.cScale8 = this.cScale8 || adjust$1(this.primaryColor, { h: 210 }); + this.cScale9 = this.cScale9 || adjust$1(this.primaryColor, { h: 270 }); + this.cScale10 = this.cScale10 || adjust$1(this.primaryColor, { h: 300 }); + this.cScale11 = this.cScale11 || adjust$1(this.primaryColor, { h: 330 }); + this["cScalePeer1"] = this["cScalePeer1"] || darken$1(this.secondaryColor, 45); + this["cScalePeer2"] = this["cScalePeer2"] || darken$1(this.tertiaryColor, 40); + for (let i = 0; i < this.THEME_COLOR_LIMIT; i++) { + this["cScale" + i] = darken$1(this["cScale" + i], 10); + this["cScalePeer" + i] = this["cScalePeer" + i] || darken$1(this["cScale" + i], 25); + } + for (let i = 0; i < this.THEME_COLOR_LIMIT; i++) { + this["cScaleInv" + i] = this["cScaleInv" + i] || adjust$1(this["cScale" + i], { h: 180 }); + } + this.scaleLabelColor = this.scaleLabelColor !== "calculated" && this.scaleLabelColor ? this.scaleLabelColor : this.labelTextColor; + for (let i = 0; i < this.THEME_COLOR_LIMIT; i++) { + this["cScaleLabel" + i] = this["cScaleLabel" + i] || this.scaleLabelColor; + } + for (let i = 0; i < 5; i++) { + this["surface" + i] = this["surface" + i] || adjust$1(this.mainBkg, { h: 30, s: -30, l: -(5 + i * 5) }); + this["surfacePeer" + i] = this["surfacePeer" + i] || adjust$1(this.mainBkg, { h: 30, s: -30, l: -(8 + i * 5) }); + } + this.nodeBkg = this.mainBkg; + this.nodeBorder = this.border1; + this.clusterBkg = this.secondBkg; + this.clusterBorder = this.border2; + this.defaultLinkColor = this.lineColor; + this.taskBorderColor = this.border1; + this.taskTextColor = this.taskTextLightColor; + this.taskTextOutsideColor = this.taskTextDarkColor; + this.activeTaskBorderColor = this.taskBorderColor; + this.activeTaskBkgColor = this.mainBkg; + this.transitionColor = this.transitionColor || this.lineColor; + this.transitionLabelColor = this.transitionLabelColor || this.textColor; + this.stateLabelColor = this.stateLabelColor || this.stateBkg || this.primaryTextColor; + this.stateBkg = this.stateBkg || this.mainBkg; + this.labelBackgroundColor = this.labelBackgroundColor || this.stateBkg; + this.compositeBackground = this.compositeBackground || this.background || this.tertiaryColor; + this.altBackground = this.altBackground || "#f0f0f0"; + this.compositeTitleBackground = this.compositeTitleBackground || this.mainBkg; + this.compositeBorder = this.compositeBorder || this.nodeBorder; + this.innerEndBackground = this.primaryBorderColor; + this.specialStateColor = this.lineColor; + this.errorBkgColor = this.errorBkgColor || this.tertiaryColor; + this.errorTextColor = this.errorTextColor || this.tertiaryTextColor; + this.transitionColor = this.transitionColor || this.lineColor; + this.classText = this.primaryTextColor; + this.fillType0 = this.primaryColor; + this.fillType1 = this.secondaryColor; + this.fillType2 = adjust$1(this.primaryColor, { h: 64 }); + this.fillType3 = adjust$1(this.secondaryColor, { h: 64 }); + this.fillType4 = adjust$1(this.primaryColor, { h: -64 }); + this.fillType5 = adjust$1(this.secondaryColor, { h: -64 }); + this.fillType6 = adjust$1(this.primaryColor, { h: 128 }); + this.fillType7 = adjust$1(this.secondaryColor, { h: 128 }); + this.pie1 = this.pie1 || this.primaryColor; + this.pie2 = this.pie2 || this.secondaryColor; + this.pie3 = this.pie3 || this.tertiaryColor; + this.pie4 = this.pie4 || adjust$1(this.primaryColor, { l: -30 }); + this.pie5 = this.pie5 || adjust$1(this.secondaryColor, { l: -30 }); + this.pie6 = this.pie6 || adjust$1(this.tertiaryColor, { h: 40, l: -40 }); + this.pie7 = this.pie7 || adjust$1(this.primaryColor, { h: 60, l: -10 }); + this.pie8 = this.pie8 || adjust$1(this.primaryColor, { h: -60, l: -10 }); + this.pie9 = this.pie9 || adjust$1(this.primaryColor, { h: 120, l: 0 }); + this.pie10 = this.pie10 || adjust$1(this.primaryColor, { h: 60, l: -50 }); + this.pie11 = this.pie11 || adjust$1(this.primaryColor, { h: -60, l: -50 }); + this.pie12 = this.pie12 || adjust$1(this.primaryColor, { h: 120, l: -50 }); + this.pieTitleTextSize = this.pieTitleTextSize || "25px"; + this.pieTitleTextColor = this.pieTitleTextColor || this.taskTextDarkColor; + this.pieSectionTextSize = this.pieSectionTextSize || "17px"; + this.pieSectionTextColor = this.pieSectionTextColor || this.textColor; + this.pieLegendTextSize = this.pieLegendTextSize || "17px"; + this.pieLegendTextColor = this.pieLegendTextColor || this.taskTextDarkColor; + this.pieStrokeColor = this.pieStrokeColor || "black"; + this.pieStrokeWidth = this.pieStrokeWidth || "2px"; + this.pieOuterStrokeWidth = this.pieOuterStrokeWidth || "2px"; + this.pieOuterStrokeColor = this.pieOuterStrokeColor || "black"; + this.pieOpacity = this.pieOpacity || "0.7"; + this.quadrant1Fill = this.quadrant1Fill || this.primaryColor; + this.quadrant2Fill = this.quadrant2Fill || adjust$1(this.primaryColor, { r: 5, g: 5, b: 5 }); + this.quadrant3Fill = this.quadrant3Fill || adjust$1(this.primaryColor, { r: 10, g: 10, b: 10 }); + this.quadrant4Fill = this.quadrant4Fill || adjust$1(this.primaryColor, { r: 15, g: 15, b: 15 }); + this.quadrant1TextFill = this.quadrant1TextFill || this.primaryTextColor; + this.quadrant2TextFill = this.quadrant2TextFill || adjust$1(this.primaryTextColor, { r: -5, g: -5, b: -5 }); + this.quadrant3TextFill = this.quadrant3TextFill || adjust$1(this.primaryTextColor, { r: -10, g: -10, b: -10 }); + this.quadrant4TextFill = this.quadrant4TextFill || adjust$1(this.primaryTextColor, { r: -15, g: -15, b: -15 }); + this.quadrantPointFill = this.quadrantPointFill || isDark$1(this.quadrant1Fill) ? lighten$1(this.quadrant1Fill) : darken$1(this.quadrant1Fill); + this.quadrantPointTextFill = this.quadrantPointTextFill || this.primaryTextColor; + this.quadrantXAxisTextFill = this.quadrantXAxisTextFill || this.primaryTextColor; + this.quadrantYAxisTextFill = this.quadrantYAxisTextFill || this.primaryTextColor; + this.quadrantInternalBorderStrokeFill = this.quadrantInternalBorderStrokeFill || this.primaryBorderColor; + this.quadrantExternalBorderStrokeFill = this.quadrantExternalBorderStrokeFill || this.primaryBorderColor; + this.quadrantTitleFill = this.quadrantTitleFill || this.primaryTextColor; + this.xyChart = { + backgroundColor: ((_a = this.xyChart) == null ? void 0 : _a.backgroundColor) || this.background, + titleColor: ((_b = this.xyChart) == null ? void 0 : _b.titleColor) || this.primaryTextColor, + xAxisTitleColor: ((_c = this.xyChart) == null ? void 0 : _c.xAxisTitleColor) || this.primaryTextColor, + xAxisLabelColor: ((_d = this.xyChart) == null ? void 0 : _d.xAxisLabelColor) || this.primaryTextColor, + xAxisTickColor: ((_e = this.xyChart) == null ? void 0 : _e.xAxisTickColor) || this.primaryTextColor, + xAxisLineColor: ((_f = this.xyChart) == null ? void 0 : _f.xAxisLineColor) || this.primaryTextColor, + yAxisTitleColor: ((_g = this.xyChart) == null ? void 0 : _g.yAxisTitleColor) || this.primaryTextColor, + yAxisLabelColor: ((_h = this.xyChart) == null ? void 0 : _h.yAxisLabelColor) || this.primaryTextColor, + yAxisTickColor: ((_i = this.xyChart) == null ? void 0 : _i.yAxisTickColor) || this.primaryTextColor, + yAxisLineColor: ((_j = this.xyChart) == null ? void 0 : _j.yAxisLineColor) || this.primaryTextColor, + plotColorPalette: ((_k = this.xyChart) == null ? void 0 : _k.plotColorPalette) || "#CDE498,#FF6B6B,#A0D2DB,#D7BDE2,#F0F0F0,#FFC3A0,#7FD8BE,#FF9A8B,#FAF3E0,#FFF176" + }; + this.requirementBackground = this.requirementBackground || this.primaryColor; + this.requirementBorderColor = this.requirementBorderColor || this.primaryBorderColor; + this.requirementBorderSize = this.requirementBorderSize || "1"; + this.requirementTextColor = this.requirementTextColor || this.primaryTextColor; + this.relationColor = this.relationColor || this.lineColor; + this.relationLabelBackground = this.relationLabelBackground || this.edgeLabelBackground; + this.relationLabelColor = this.relationLabelColor || this.actorTextColor; + this.git0 = this.git0 || this.primaryColor; + this.git1 = this.git1 || this.secondaryColor; + this.git2 = this.git2 || this.tertiaryColor; + this.git3 = this.git3 || adjust$1(this.primaryColor, { h: -30 }); + this.git4 = this.git4 || adjust$1(this.primaryColor, { h: -60 }); + this.git5 = this.git5 || adjust$1(this.primaryColor, { h: -90 }); + this.git6 = this.git6 || adjust$1(this.primaryColor, { h: 60 }); + this.git7 = this.git7 || adjust$1(this.primaryColor, { h: 120 }); + if (this.darkMode) { + this.git0 = lighten$1(this.git0, 25); + this.git1 = lighten$1(this.git1, 25); + this.git2 = lighten$1(this.git2, 25); + this.git3 = lighten$1(this.git3, 25); + this.git4 = lighten$1(this.git4, 25); + this.git5 = lighten$1(this.git5, 25); + this.git6 = lighten$1(this.git6, 25); + this.git7 = lighten$1(this.git7, 25); + } else { + this.git0 = darken$1(this.git0, 25); + this.git1 = darken$1(this.git1, 25); + this.git2 = darken$1(this.git2, 25); + this.git3 = darken$1(this.git3, 25); + this.git4 = darken$1(this.git4, 25); + this.git5 = darken$1(this.git5, 25); + this.git6 = darken$1(this.git6, 25); + this.git7 = darken$1(this.git7, 25); + } + this.gitInv0 = this.gitInv0 || invert$1(this.git0); + this.gitInv1 = this.gitInv1 || invert$1(this.git1); + this.gitInv2 = this.gitInv2 || invert$1(this.git2); + this.gitInv3 = this.gitInv3 || invert$1(this.git3); + this.gitInv4 = this.gitInv4 || invert$1(this.git4); + this.gitInv5 = this.gitInv5 || invert$1(this.git5); + this.gitInv6 = this.gitInv6 || invert$1(this.git6); + this.gitInv7 = this.gitInv7 || invert$1(this.git7); + this.gitBranchLabel0 = this.gitBranchLabel0 || invert$1(this.labelTextColor); + this.gitBranchLabel1 = this.gitBranchLabel1 || this.labelTextColor; + this.gitBranchLabel2 = this.gitBranchLabel2 || this.labelTextColor; + this.gitBranchLabel3 = this.gitBranchLabel3 || invert$1(this.labelTextColor); + this.gitBranchLabel4 = this.gitBranchLabel4 || this.labelTextColor; + this.gitBranchLabel5 = this.gitBranchLabel5 || this.labelTextColor; + this.gitBranchLabel6 = this.gitBranchLabel6 || this.labelTextColor; + this.gitBranchLabel7 = this.gitBranchLabel7 || this.labelTextColor; + this.tagLabelColor = this.tagLabelColor || this.primaryTextColor; + this.tagLabelBackground = this.tagLabelBackground || this.primaryColor; + this.tagLabelBorder = this.tagBorder || this.primaryBorderColor; + this.tagLabelFontSize = this.tagLabelFontSize || "10px"; + this.commitLabelColor = this.commitLabelColor || this.secondaryTextColor; + this.commitLabelBackground = this.commitLabelBackground || this.secondaryColor; + this.commitLabelFontSize = this.commitLabelFontSize || "10px"; + this.attributeBackgroundColorOdd = this.attributeBackgroundColorOdd || oldAttributeBackgroundColorOdd; + this.attributeBackgroundColorEven = this.attributeBackgroundColorEven || oldAttributeBackgroundColorEven; + } + calculate(overrides) { + if (typeof overrides !== "object") { + this.updateColors(); + return; + } + const keys = Object.keys(overrides); + keys.forEach((k) => { + this[k] = overrides[k]; + }); + this.updateColors(); + keys.forEach((k) => { + this[k] = overrides[k]; + }); + } +}; +const getThemeVariables$1 = (userOverrides) => { + const theme2 = new Theme$1(); + theme2.calculate(userOverrides); + return theme2; +}; +class Theme5 { + constructor() { + this.primaryColor = "#eee"; + this.contrast = "#707070"; + this.secondaryColor = lighten$1(this.contrast, 55); + this.background = "#ffffff"; + this.tertiaryColor = adjust$1(this.primaryColor, { h: -160 }); + this.primaryBorderColor = mkBorder(this.primaryColor, this.darkMode); + this.secondaryBorderColor = mkBorder(this.secondaryColor, this.darkMode); + this.tertiaryBorderColor = mkBorder(this.tertiaryColor, this.darkMode); + this.primaryTextColor = invert$1(this.primaryColor); + this.secondaryTextColor = invert$1(this.secondaryColor); + this.tertiaryTextColor = invert$1(this.tertiaryColor); + this.lineColor = invert$1(this.background); + this.textColor = invert$1(this.background); + this.mainBkg = "#eee"; + this.secondBkg = "calculated"; + this.lineColor = "#666"; + this.border1 = "#999"; + this.border2 = "calculated"; + this.note = "#ffa"; + this.text = "#333"; + this.critical = "#d42"; + this.done = "#bbb"; + this.arrowheadColor = "#333333"; + this.fontFamily = '"trebuchet ms", verdana, arial, sans-serif'; + this.fontSize = "16px"; + this.THEME_COLOR_LIMIT = 12; + this.nodeBkg = "calculated"; + this.nodeBorder = "calculated"; + this.clusterBkg = "calculated"; + this.clusterBorder = "calculated"; + this.defaultLinkColor = "calculated"; + this.titleColor = "calculated"; + this.edgeLabelBackground = "white"; + this.actorBorder = "calculated"; + this.actorBkg = "calculated"; + this.actorTextColor = "calculated"; + this.actorLineColor = "calculated"; + this.signalColor = "calculated"; + this.signalTextColor = "calculated"; + this.labelBoxBkgColor = "calculated"; + this.labelBoxBorderColor = "calculated"; + this.labelTextColor = "calculated"; + this.loopTextColor = "calculated"; + this.noteBorderColor = "calculated"; + this.noteBkgColor = "calculated"; + this.noteTextColor = "calculated"; + this.activationBorderColor = "#666"; + this.activationBkgColor = "#f4f4f4"; + this.sequenceNumberColor = "white"; + this.sectionBkgColor = "calculated"; + this.altSectionBkgColor = "white"; + this.sectionBkgColor2 = "calculated"; + this.excludeBkgColor = "#eeeeee"; + this.taskBorderColor = "calculated"; + this.taskBkgColor = "calculated"; + this.taskTextLightColor = "white"; + this.taskTextColor = "calculated"; + this.taskTextDarkColor = "calculated"; + this.taskTextOutsideColor = "calculated"; + this.taskTextClickableColor = "#003163"; + this.activeTaskBorderColor = "calculated"; + this.activeTaskBkgColor = "calculated"; + this.gridColor = "calculated"; + this.doneTaskBkgColor = "calculated"; + this.doneTaskBorderColor = "calculated"; + this.critBkgColor = "calculated"; + this.critBorderColor = "calculated"; + this.todayLineColor = "calculated"; + this.personBorder = this.primaryBorderColor; + this.personBkg = this.mainBkg; + this.labelColor = "black"; + this.errorBkgColor = "#552222"; + this.errorTextColor = "#552222"; + } + updateColors() { + var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k; + this.secondBkg = lighten$1(this.contrast, 55); + this.border2 = this.contrast; + this.actorBorder = lighten$1(this.border1, 23); + this.actorBkg = this.mainBkg; + this.actorTextColor = this.text; + this.actorLineColor = this.lineColor; + this.signalColor = this.text; + this.signalTextColor = this.text; + this.labelBoxBkgColor = this.actorBkg; + this.labelBoxBorderColor = this.actorBorder; + this.labelTextColor = this.text; + this.loopTextColor = this.text; + this.noteBorderColor = "#999"; + this.noteBkgColor = "#666"; + this.noteTextColor = "#fff"; + this.cScale0 = this.cScale0 || "#555"; + this.cScale1 = this.cScale1 || "#F4F4F4"; + this.cScale2 = this.cScale2 || "#555"; + this.cScale3 = this.cScale3 || "#BBB"; + this.cScale4 = this.cScale4 || "#777"; + this.cScale5 = this.cScale5 || "#999"; + this.cScale6 = this.cScale6 || "#DDD"; + this.cScale7 = this.cScale7 || "#FFF"; + this.cScale8 = this.cScale8 || "#DDD"; + this.cScale9 = this.cScale9 || "#BBB"; + this.cScale10 = this.cScale10 || "#999"; + this.cScale11 = this.cScale11 || "#777"; + for (let i = 0; i < this.THEME_COLOR_LIMIT; i++) { + this["cScaleInv" + i] = this["cScaleInv" + i] || invert$1(this["cScale" + i]); + } + for (let i = 0; i < this.THEME_COLOR_LIMIT; i++) { + if (this.darkMode) { + this["cScalePeer" + i] = this["cScalePeer" + i] || lighten$1(this["cScale" + i], 10); + } else { + this["cScalePeer" + i] = this["cScalePeer" + i] || darken$1(this["cScale" + i], 10); + } + } + this.scaleLabelColor = this.scaleLabelColor || (this.darkMode ? "black" : this.labelTextColor); + this["cScaleLabel0"] = this["cScaleLabel0"] || this.cScale1; + this["cScaleLabel2"] = this["cScaleLabel2"] || this.cScale1; + for (let i = 0; i < this.THEME_COLOR_LIMIT; i++) { + this["cScaleLabel" + i] = this["cScaleLabel" + i] || this.scaleLabelColor; + } + for (let i = 0; i < 5; i++) { + this["surface" + i] = this["surface" + i] || adjust$1(this.mainBkg, { l: -(5 + i * 5) }); + this["surfacePeer" + i] = this["surfacePeer" + i] || adjust$1(this.mainBkg, { l: -(8 + i * 5) }); + } + this.nodeBkg = this.mainBkg; + this.nodeBorder = this.border1; + this.clusterBkg = this.secondBkg; + this.clusterBorder = this.border2; + this.defaultLinkColor = this.lineColor; + this.titleColor = this.text; + this.sectionBkgColor = lighten$1(this.contrast, 30); + this.sectionBkgColor2 = lighten$1(this.contrast, 30); + this.taskBorderColor = darken$1(this.contrast, 10); + this.taskBkgColor = this.contrast; + this.taskTextColor = this.taskTextLightColor; + this.taskTextDarkColor = this.text; + this.taskTextOutsideColor = this.taskTextDarkColor; + this.activeTaskBorderColor = this.taskBorderColor; + this.activeTaskBkgColor = this.mainBkg; + this.gridColor = lighten$1(this.border1, 30); + this.doneTaskBkgColor = this.done; + this.doneTaskBorderColor = this.lineColor; + this.critBkgColor = this.critical; + this.critBorderColor = darken$1(this.critBkgColor, 10); + this.todayLineColor = this.critBkgColor; + this.transitionColor = this.transitionColor || "#000"; + this.transitionLabelColor = this.transitionLabelColor || this.textColor; + this.stateLabelColor = this.stateLabelColor || this.stateBkg || this.primaryTextColor; + this.stateBkg = this.stateBkg || this.mainBkg; + this.labelBackgroundColor = this.labelBackgroundColor || this.stateBkg; + this.compositeBackground = this.compositeBackground || this.background || this.tertiaryColor; + this.altBackground = this.altBackground || "#f4f4f4"; + this.compositeTitleBackground = this.compositeTitleBackground || this.mainBkg; + this.stateBorder = this.stateBorder || "#000"; + this.innerEndBackground = this.primaryBorderColor; + this.specialStateColor = "#222"; + this.errorBkgColor = this.errorBkgColor || this.tertiaryColor; + this.errorTextColor = this.errorTextColor || this.tertiaryTextColor; + this.classText = this.primaryTextColor; + this.fillType0 = this.primaryColor; + this.fillType1 = this.secondaryColor; + this.fillType2 = adjust$1(this.primaryColor, { h: 64 }); + this.fillType3 = adjust$1(this.secondaryColor, { h: 64 }); + this.fillType4 = adjust$1(this.primaryColor, { h: -64 }); + this.fillType5 = adjust$1(this.secondaryColor, { h: -64 }); + this.fillType6 = adjust$1(this.primaryColor, { h: 128 }); + this.fillType7 = adjust$1(this.secondaryColor, { h: 128 }); + for (let i = 0; i < this.THEME_COLOR_LIMIT; i++) { + this["pie" + i] = this["cScale" + i]; + } + this.pie12 = this.pie0; + this.pieTitleTextSize = this.pieTitleTextSize || "25px"; + this.pieTitleTextColor = this.pieTitleTextColor || this.taskTextDarkColor; + this.pieSectionTextSize = this.pieSectionTextSize || "17px"; + this.pieSectionTextColor = this.pieSectionTextColor || this.textColor; + this.pieLegendTextSize = this.pieLegendTextSize || "17px"; + this.pieLegendTextColor = this.pieLegendTextColor || this.taskTextDarkColor; + this.pieStrokeColor = this.pieStrokeColor || "black"; + this.pieStrokeWidth = this.pieStrokeWidth || "2px"; + this.pieOuterStrokeWidth = this.pieOuterStrokeWidth || "2px"; + this.pieOuterStrokeColor = this.pieOuterStrokeColor || "black"; + this.pieOpacity = this.pieOpacity || "0.7"; + this.quadrant1Fill = this.quadrant1Fill || this.primaryColor; + this.quadrant2Fill = this.quadrant2Fill || adjust$1(this.primaryColor, { r: 5, g: 5, b: 5 }); + this.quadrant3Fill = this.quadrant3Fill || adjust$1(this.primaryColor, { r: 10, g: 10, b: 10 }); + this.quadrant4Fill = this.quadrant4Fill || adjust$1(this.primaryColor, { r: 15, g: 15, b: 15 }); + this.quadrant1TextFill = this.quadrant1TextFill || this.primaryTextColor; + this.quadrant2TextFill = this.quadrant2TextFill || adjust$1(this.primaryTextColor, { r: -5, g: -5, b: -5 }); + this.quadrant3TextFill = this.quadrant3TextFill || adjust$1(this.primaryTextColor, { r: -10, g: -10, b: -10 }); + this.quadrant4TextFill = this.quadrant4TextFill || adjust$1(this.primaryTextColor, { r: -15, g: -15, b: -15 }); + this.quadrantPointFill = this.quadrantPointFill || isDark$1(this.quadrant1Fill) ? lighten$1(this.quadrant1Fill) : darken$1(this.quadrant1Fill); + this.quadrantPointTextFill = this.quadrantPointTextFill || this.primaryTextColor; + this.quadrantXAxisTextFill = this.quadrantXAxisTextFill || this.primaryTextColor; + this.quadrantYAxisTextFill = this.quadrantYAxisTextFill || this.primaryTextColor; + this.quadrantInternalBorderStrokeFill = this.quadrantInternalBorderStrokeFill || this.primaryBorderColor; + this.quadrantExternalBorderStrokeFill = this.quadrantExternalBorderStrokeFill || this.primaryBorderColor; + this.quadrantTitleFill = this.quadrantTitleFill || this.primaryTextColor; + this.xyChart = { + backgroundColor: ((_a = this.xyChart) == null ? void 0 : _a.backgroundColor) || this.background, + titleColor: ((_b = this.xyChart) == null ? void 0 : _b.titleColor) || this.primaryTextColor, + xAxisTitleColor: ((_c = this.xyChart) == null ? void 0 : _c.xAxisTitleColor) || this.primaryTextColor, + xAxisLabelColor: ((_d = this.xyChart) == null ? void 0 : _d.xAxisLabelColor) || this.primaryTextColor, + xAxisTickColor: ((_e = this.xyChart) == null ? void 0 : _e.xAxisTickColor) || this.primaryTextColor, + xAxisLineColor: ((_f = this.xyChart) == null ? void 0 : _f.xAxisLineColor) || this.primaryTextColor, + yAxisTitleColor: ((_g = this.xyChart) == null ? void 0 : _g.yAxisTitleColor) || this.primaryTextColor, + yAxisLabelColor: ((_h = this.xyChart) == null ? void 0 : _h.yAxisLabelColor) || this.primaryTextColor, + yAxisTickColor: ((_i = this.xyChart) == null ? void 0 : _i.yAxisTickColor) || this.primaryTextColor, + yAxisLineColor: ((_j = this.xyChart) == null ? void 0 : _j.yAxisLineColor) || this.primaryTextColor, + plotColorPalette: ((_k = this.xyChart) == null ? void 0 : _k.plotColorPalette) || "#EEE,#6BB8E4,#8ACB88,#C7ACD6,#E8DCC2,#FFB2A8,#FFF380,#7E8D91,#FFD8B1,#FAF3E0" + }; + this.requirementBackground = this.requirementBackground || this.primaryColor; + this.requirementBorderColor = this.requirementBorderColor || this.primaryBorderColor; + this.requirementBorderSize = this.requirementBorderSize || "1"; + this.requirementTextColor = this.requirementTextColor || this.primaryTextColor; + this.relationColor = this.relationColor || this.lineColor; + this.relationLabelBackground = this.relationLabelBackground || this.edgeLabelBackground; + this.relationLabelColor = this.relationLabelColor || this.actorTextColor; + this.git0 = darken$1(this.pie1, 25) || this.primaryColor; + this.git1 = this.pie2 || this.secondaryColor; + this.git2 = this.pie3 || this.tertiaryColor; + this.git3 = this.pie4 || adjust$1(this.primaryColor, { h: -30 }); + this.git4 = this.pie5 || adjust$1(this.primaryColor, { h: -60 }); + this.git5 = this.pie6 || adjust$1(this.primaryColor, { h: -90 }); + this.git6 = this.pie7 || adjust$1(this.primaryColor, { h: 60 }); + this.git7 = this.pie8 || adjust$1(this.primaryColor, { h: 120 }); + this.gitInv0 = this.gitInv0 || invert$1(this.git0); + this.gitInv1 = this.gitInv1 || invert$1(this.git1); + this.gitInv2 = this.gitInv2 || invert$1(this.git2); + this.gitInv3 = this.gitInv3 || invert$1(this.git3); + this.gitInv4 = this.gitInv4 || invert$1(this.git4); + this.gitInv5 = this.gitInv5 || invert$1(this.git5); + this.gitInv6 = this.gitInv6 || invert$1(this.git6); + this.gitInv7 = this.gitInv7 || invert$1(this.git7); + this.branchLabelColor = this.branchLabelColor || this.labelTextColor; + this.gitBranchLabel0 = this.branchLabelColor; + this.gitBranchLabel1 = "white"; + this.gitBranchLabel2 = this.branchLabelColor; + this.gitBranchLabel3 = "white"; + this.gitBranchLabel4 = this.branchLabelColor; + this.gitBranchLabel5 = this.branchLabelColor; + this.gitBranchLabel6 = this.branchLabelColor; + this.gitBranchLabel7 = this.branchLabelColor; + this.tagLabelColor = this.tagLabelColor || this.primaryTextColor; + this.tagLabelBackground = this.tagLabelBackground || this.primaryColor; + this.tagLabelBorder = this.tagBorder || this.primaryBorderColor; + this.tagLabelFontSize = this.tagLabelFontSize || "10px"; + this.commitLabelColor = this.commitLabelColor || this.secondaryTextColor; + this.commitLabelBackground = this.commitLabelBackground || this.secondaryColor; + this.commitLabelFontSize = this.commitLabelFontSize || "10px"; + this.attributeBackgroundColorOdd = this.attributeBackgroundColorOdd || oldAttributeBackgroundColorOdd; + this.attributeBackgroundColorEven = this.attributeBackgroundColorEven || oldAttributeBackgroundColorEven; + } + calculate(overrides) { + if (typeof overrides !== "object") { + this.updateColors(); + return; + } + const keys = Object.keys(overrides); + keys.forEach((k) => { + this[k] = overrides[k]; + }); + this.updateColors(); + keys.forEach((k) => { + this[k] = overrides[k]; + }); + } +} +const getThemeVariables = (userOverrides) => { + const theme2 = new Theme5(); + theme2.calculate(userOverrides); + return theme2; +}; +const theme = { + base: { + getThemeVariables: getThemeVariables$4 + }, + dark: { + getThemeVariables: getThemeVariables$3 + }, + default: { + getThemeVariables: getThemeVariables$2 + }, + forest: { + getThemeVariables: getThemeVariables$1 + }, + neutral: { + getThemeVariables + } +}; +const defaultConfigJson = { + "flowchart": { + "useMaxWidth": true, + "titleTopMargin": 25, + "subGraphTitleMargin": { + "top": 0, + "bottom": 0 + }, + "diagramPadding": 8, + "htmlLabels": true, + "nodeSpacing": 50, + "rankSpacing": 50, + "curve": "basis", + "padding": 15, + "defaultRenderer": "dagre-wrapper", + "wrappingWidth": 200 + }, + "sequence": { + "useMaxWidth": true, + "hideUnusedParticipants": false, + "activationWidth": 10, + "diagramMarginX": 50, + "diagramMarginY": 10, + "actorMargin": 50, + "width": 150, + "height": 65, + "boxMargin": 10, + "boxTextMargin": 5, + "noteMargin": 10, + "messageMargin": 35, + "messageAlign": "center", + "mirrorActors": true, + "forceMenus": false, + "bottomMarginAdj": 1, + "rightAngles": false, + "showSequenceNumbers": false, + "actorFontSize": 14, + "actorFontFamily": '"Open Sans", sans-serif', + "actorFontWeight": 400, + "noteFontSize": 14, + "noteFontFamily": '"trebuchet ms", verdana, arial, sans-serif', + "noteFontWeight": 400, + "noteAlign": "center", + "messageFontSize": 16, + "messageFontFamily": '"trebuchet ms", verdana, arial, sans-serif', + "messageFontWeight": 400, + "wrap": false, + "wrapPadding": 10, + "labelBoxWidth": 50, + "labelBoxHeight": 20 + }, + "gantt": { + "useMaxWidth": true, + "titleTopMargin": 25, + "barHeight": 20, + "barGap": 4, + "topPadding": 50, + "rightPadding": 75, + "leftPadding": 75, + "gridLineStartPadding": 35, + "fontSize": 11, + "sectionFontSize": 11, + "numberSectionStyles": 4, + "axisFormat": "%Y-%m-%d", + "topAxis": false, + "displayMode": "", + "weekday": "sunday" + }, + "journey": { + "useMaxWidth": true, + "diagramMarginX": 50, + "diagramMarginY": 10, + "leftMargin": 150, + "width": 150, + "height": 50, + "boxMargin": 10, + "boxTextMargin": 5, + "noteMargin": 10, + "messageMargin": 35, + "messageAlign": "center", + "bottomMarginAdj": 1, + "rightAngles": false, + "taskFontSize": 14, + "taskFontFamily": '"Open Sans", sans-serif', + "taskMargin": 50, + "activationWidth": 10, + "textPlacement": "fo", + "actorColours": [ + "#8FBC8F", + "#7CFC00", + "#00FFFF", + "#20B2AA", + "#B0E0E6", + "#FFFFE0" + ], + "sectionFills": [ + "#191970", + "#8B008B", + "#4B0082", + "#2F4F4F", + "#800000", + "#8B4513", + "#00008B" + ], + "sectionColours": [ + "#fff" + ] + }, + "class": { + "useMaxWidth": true, + "titleTopMargin": 25, + "arrowMarkerAbsolute": false, + "dividerMargin": 10, + "padding": 5, + "textHeight": 10, + "defaultRenderer": "dagre-wrapper", + "htmlLabels": false + }, + "state": { + "useMaxWidth": true, + "titleTopMargin": 25, + "dividerMargin": 10, + "sizeUnit": 5, + "padding": 8, + "textHeight": 10, + "titleShift": -15, + "noteMargin": 10, + "forkWidth": 70, + "forkHeight": 7, + "miniPadding": 2, + "fontSizeFactor": 5.02, + "fontSize": 24, + "labelHeight": 16, + "edgeLengthFactor": "20", + "compositTitleSize": 35, + "radius": 5, + "defaultRenderer": "dagre-wrapper" + }, + "er": { + "useMaxWidth": true, + "titleTopMargin": 25, + "diagramPadding": 20, + "layoutDirection": "TB", + "minEntityWidth": 100, + "minEntityHeight": 75, + "entityPadding": 15, + "stroke": "gray", + "fill": "honeydew", + "fontSize": 12 + }, + "pie": { + "useMaxWidth": true, + "textPosition": 0.75 + }, + "quadrantChart": { + "useMaxWidth": true, + "chartWidth": 500, + "chartHeight": 500, + "titleFontSize": 20, + "titlePadding": 10, + "quadrantPadding": 5, + "xAxisLabelPadding": 5, + "yAxisLabelPadding": 5, + "xAxisLabelFontSize": 16, + "yAxisLabelFontSize": 16, + "quadrantLabelFontSize": 16, + "quadrantTextTopPadding": 5, + "pointTextPadding": 5, + "pointLabelFontSize": 12, + "pointRadius": 5, + "xAxisPosition": "top", + "yAxisPosition": "left", + "quadrantInternalBorderStrokeWidth": 1, + "quadrantExternalBorderStrokeWidth": 2 + }, + "xyChart": { + "useMaxWidth": true, + "width": 700, + "height": 500, + "titleFontSize": 20, + "titlePadding": 10, + "showTitle": true, + "xAxis": { + "$ref": "#/$defs/XYChartAxisConfig", + "showLabel": true, + "labelFontSize": 14, + "labelPadding": 5, + "showTitle": true, + "titleFontSize": 16, + "titlePadding": 5, + "showTick": true, + "tickLength": 5, + "tickWidth": 2, + "showAxisLine": true, + "axisLineWidth": 2 + }, + "yAxis": { + "$ref": "#/$defs/XYChartAxisConfig", + "showLabel": true, + "labelFontSize": 14, + "labelPadding": 5, + "showTitle": true, + "titleFontSize": 16, + "titlePadding": 5, + "showTick": true, + "tickLength": 5, + "tickWidth": 2, + "showAxisLine": true, + "axisLineWidth": 2 + }, + "chartOrientation": "vertical", + "plotReservedSpacePercent": 50 + }, + "requirement": { + "useMaxWidth": true, + "rect_fill": "#f9f9f9", + "text_color": "#333", + "rect_border_size": "0.5px", + "rect_border_color": "#bbb", + "rect_min_width": 200, + "rect_min_height": 200, + "fontSize": 14, + "rect_padding": 10, + "line_height": 20 + }, + "mindmap": { + "useMaxWidth": true, + "padding": 10, + "maxNodeWidth": 200 + }, + "timeline": { + "useMaxWidth": true, + "diagramMarginX": 50, + "diagramMarginY": 10, + "leftMargin": 150, + "width": 150, + "height": 50, + "boxMargin": 10, + "boxTextMargin": 5, + "noteMargin": 10, + "messageMargin": 35, + "messageAlign": "center", + "bottomMarginAdj": 1, + "rightAngles": false, + "taskFontSize": 14, + "taskFontFamily": '"Open Sans", sans-serif', + "taskMargin": 50, + "activationWidth": 10, + "textPlacement": "fo", + "actorColours": [ + "#8FBC8F", + "#7CFC00", + "#00FFFF", + "#20B2AA", + "#B0E0E6", + "#FFFFE0" + ], + "sectionFills": [ + "#191970", + "#8B008B", + "#4B0082", + "#2F4F4F", + "#800000", + "#8B4513", + "#00008B" + ], + "sectionColours": [ + "#fff" + ], + "disableMulticolor": false + }, + "gitGraph": { + "useMaxWidth": true, + "titleTopMargin": 25, + "diagramPadding": 8, + "nodeLabel": { + "width": 75, + "height": 100, + "x": -25, + "y": 0 + }, + "mainBranchName": "main", + "mainBranchOrder": 0, + "showCommitLabel": true, + "showBranches": true, + "rotateCommitLabel": true, + "parallelCommits": false, + "arrowMarkerAbsolute": false + }, + "c4": { + "useMaxWidth": true, + "diagramMarginX": 50, + "diagramMarginY": 10, + "c4ShapeMargin": 50, + "c4ShapePadding": 20, + "width": 216, + "height": 60, + "boxMargin": 10, + "c4ShapeInRow": 4, + "nextLinePaddingX": 0, + "c4BoundaryInRow": 2, + "personFontSize": 14, + "personFontFamily": '"Open Sans", sans-serif', + "personFontWeight": "normal", + "external_personFontSize": 14, + "external_personFontFamily": '"Open Sans", sans-serif', + "external_personFontWeight": "normal", + "systemFontSize": 14, + "systemFontFamily": '"Open Sans", sans-serif', + "systemFontWeight": "normal", + "external_systemFontSize": 14, + "external_systemFontFamily": '"Open Sans", sans-serif', + "external_systemFontWeight": "normal", + "system_dbFontSize": 14, + "system_dbFontFamily": '"Open Sans", sans-serif', + "system_dbFontWeight": "normal", + "external_system_dbFontSize": 14, + "external_system_dbFontFamily": '"Open Sans", sans-serif', + "external_system_dbFontWeight": "normal", + "system_queueFontSize": 14, + "system_queueFontFamily": '"Open Sans", sans-serif', + "system_queueFontWeight": "normal", + "external_system_queueFontSize": 14, + "external_system_queueFontFamily": '"Open Sans", sans-serif', + "external_system_queueFontWeight": "normal", + "boundaryFontSize": 14, + "boundaryFontFamily": '"Open Sans", sans-serif', + "boundaryFontWeight": "normal", + "messageFontSize": 12, + "messageFontFamily": '"Open Sans", sans-serif', + "messageFontWeight": "normal", + "containerFontSize": 14, + "containerFontFamily": '"Open Sans", sans-serif', + "containerFontWeight": "normal", + "external_containerFontSize": 14, + "external_containerFontFamily": '"Open Sans", sans-serif', + "external_containerFontWeight": "normal", + "container_dbFontSize": 14, + "container_dbFontFamily": '"Open Sans", sans-serif', + "container_dbFontWeight": "normal", + "external_container_dbFontSize": 14, + "external_container_dbFontFamily": '"Open Sans", sans-serif', + "external_container_dbFontWeight": "normal", + "container_queueFontSize": 14, + "container_queueFontFamily": '"Open Sans", sans-serif', + "container_queueFontWeight": "normal", + "external_container_queueFontSize": 14, + "external_container_queueFontFamily": '"Open Sans", sans-serif', + "external_container_queueFontWeight": "normal", + "componentFontSize": 14, + "componentFontFamily": '"Open Sans", sans-serif', + "componentFontWeight": "normal", + "external_componentFontSize": 14, + "external_componentFontFamily": '"Open Sans", sans-serif', + "external_componentFontWeight": "normal", + "component_dbFontSize": 14, + "component_dbFontFamily": '"Open Sans", sans-serif', + "component_dbFontWeight": "normal", + "external_component_dbFontSize": 14, + "external_component_dbFontFamily": '"Open Sans", sans-serif', + "external_component_dbFontWeight": "normal", + "component_queueFontSize": 14, + "component_queueFontFamily": '"Open Sans", sans-serif', + "component_queueFontWeight": "normal", + "external_component_queueFontSize": 14, + "external_component_queueFontFamily": '"Open Sans", sans-serif', + "external_component_queueFontWeight": "normal", + "wrap": true, + "wrapPadding": 10, + "person_bg_color": "#08427B", + "person_border_color": "#073B6F", + "external_person_bg_color": "#686868", + "external_person_border_color": "#8A8A8A", + "system_bg_color": "#1168BD", + "system_border_color": "#3C7FC0", + "system_db_bg_color": "#1168BD", + "system_db_border_color": "#3C7FC0", + "system_queue_bg_color": "#1168BD", + "system_queue_border_color": "#3C7FC0", + "external_system_bg_color": "#999999", + "external_system_border_color": "#8A8A8A", + "external_system_db_bg_color": "#999999", + "external_system_db_border_color": "#8A8A8A", + "external_system_queue_bg_color": "#999999", + "external_system_queue_border_color": "#8A8A8A", + "container_bg_color": "#438DD5", + "container_border_color": "#3C7FC0", + "container_db_bg_color": "#438DD5", + "container_db_border_color": "#3C7FC0", + "container_queue_bg_color": "#438DD5", + "container_queue_border_color": "#3C7FC0", + "external_container_bg_color": "#B3B3B3", + "external_container_border_color": "#A6A6A6", + "external_container_db_bg_color": "#B3B3B3", + "external_container_db_border_color": "#A6A6A6", + "external_container_queue_bg_color": "#B3B3B3", + "external_container_queue_border_color": "#A6A6A6", + "component_bg_color": "#85BBF0", + "component_border_color": "#78A8D8", + "component_db_bg_color": "#85BBF0", + "component_db_border_color": "#78A8D8", + "component_queue_bg_color": "#85BBF0", + "component_queue_border_color": "#78A8D8", + "external_component_bg_color": "#CCCCCC", + "external_component_border_color": "#BFBFBF", + "external_component_db_bg_color": "#CCCCCC", + "external_component_db_border_color": "#BFBFBF", + "external_component_queue_bg_color": "#CCCCCC", + "external_component_queue_border_color": "#BFBFBF" + }, + "sankey": { + "useMaxWidth": true, + "width": 600, + "height": 400, + "linkColor": "gradient", + "nodeAlignment": "justify", + "showValues": true, + "prefix": "", + "suffix": "" + }, + "block": { + "useMaxWidth": true, + "padding": 8 + }, + "theme": "default", + "maxTextSize": 5e4, + "maxEdges": 500, + "darkMode": false, + "fontFamily": '"trebuchet ms", verdana, arial, sans-serif;', + "logLevel": 5, + "securityLevel": "strict", + "startOnLoad": true, + "arrowMarkerAbsolute": false, + "secure": [ + "secure", + "securityLevel", + "startOnLoad", + "maxTextSize", + "maxEdges" + ], + "legacyMathML": false, + "deterministicIds": false, + "fontSize": 16 +}; +const config = { + ...defaultConfigJson, + // Set, even though they're `undefined` so that `configKeys` finds these keys + // TODO: Should we replace these with `null` so that they can go in the JSON Schema? + deterministicIDSeed: void 0, + themeCSS: void 0, + // add non-JSON default config values + themeVariables: theme["default"].getThemeVariables(), + sequence: { + ...defaultConfigJson.sequence, + messageFont: function() { + return { + fontFamily: this.messageFontFamily, + fontSize: this.messageFontSize, + fontWeight: this.messageFontWeight + }; + }, + noteFont: function() { + return { + fontFamily: this.noteFontFamily, + fontSize: this.noteFontSize, + fontWeight: this.noteFontWeight + }; + }, + actorFont: function() { + return { + fontFamily: this.actorFontFamily, + fontSize: this.actorFontSize, + fontWeight: this.actorFontWeight + }; + } + }, + gantt: { + ...defaultConfigJson.gantt, + tickInterval: void 0, + useWidth: void 0 + // can probably be removed since `configKeys` already includes this + }, + c4: { + ...defaultConfigJson.c4, + useWidth: void 0, + personFont: function() { + return { + fontFamily: this.personFontFamily, + fontSize: this.personFontSize, + fontWeight: this.personFontWeight + }; + }, + external_personFont: function() { + return { + fontFamily: this.external_personFontFamily, + fontSize: this.external_personFontSize, + fontWeight: this.external_personFontWeight + }; + }, + systemFont: function() { + return { + fontFamily: this.systemFontFamily, + fontSize: this.systemFontSize, + fontWeight: this.systemFontWeight + }; + }, + external_systemFont: function() { + return { + fontFamily: this.external_systemFontFamily, + fontSize: this.external_systemFontSize, + fontWeight: this.external_systemFontWeight + }; + }, + system_dbFont: function() { + return { + fontFamily: this.system_dbFontFamily, + fontSize: this.system_dbFontSize, + fontWeight: this.system_dbFontWeight + }; + }, + external_system_dbFont: function() { + return { + fontFamily: this.external_system_dbFontFamily, + fontSize: this.external_system_dbFontSize, + fontWeight: this.external_system_dbFontWeight + }; + }, + system_queueFont: function() { + return { + fontFamily: this.system_queueFontFamily, + fontSize: this.system_queueFontSize, + fontWeight: this.system_queueFontWeight + }; + }, + external_system_queueFont: function() { + return { + fontFamily: this.external_system_queueFontFamily, + fontSize: this.external_system_queueFontSize, + fontWeight: this.external_system_queueFontWeight + }; + }, + containerFont: function() { + return { + fontFamily: this.containerFontFamily, + fontSize: this.containerFontSize, + fontWeight: this.containerFontWeight + }; + }, + external_containerFont: function() { + return { + fontFamily: this.external_containerFontFamily, + fontSize: this.external_containerFontSize, + fontWeight: this.external_containerFontWeight + }; + }, + container_dbFont: function() { + return { + fontFamily: this.container_dbFontFamily, + fontSize: this.container_dbFontSize, + fontWeight: this.container_dbFontWeight + }; + }, + external_container_dbFont: function() { + return { + fontFamily: this.external_container_dbFontFamily, + fontSize: this.external_container_dbFontSize, + fontWeight: this.external_container_dbFontWeight + }; + }, + container_queueFont: function() { + return { + fontFamily: this.container_queueFontFamily, + fontSize: this.container_queueFontSize, + fontWeight: this.container_queueFontWeight + }; + }, + external_container_queueFont: function() { + return { + fontFamily: this.external_container_queueFontFamily, + fontSize: this.external_container_queueFontSize, + fontWeight: this.external_container_queueFontWeight + }; + }, + componentFont: function() { + return { + fontFamily: this.componentFontFamily, + fontSize: this.componentFontSize, + fontWeight: this.componentFontWeight + }; + }, + external_componentFont: function() { + return { + fontFamily: this.external_componentFontFamily, + fontSize: this.external_componentFontSize, + fontWeight: this.external_componentFontWeight + }; + }, + component_dbFont: function() { + return { + fontFamily: this.component_dbFontFamily, + fontSize: this.component_dbFontSize, + fontWeight: this.component_dbFontWeight + }; + }, + external_component_dbFont: function() { + return { + fontFamily: this.external_component_dbFontFamily, + fontSize: this.external_component_dbFontSize, + fontWeight: this.external_component_dbFontWeight + }; + }, + component_queueFont: function() { + return { + fontFamily: this.component_queueFontFamily, + fontSize: this.component_queueFontSize, + fontWeight: this.component_queueFontWeight + }; + }, + external_component_queueFont: function() { + return { + fontFamily: this.external_component_queueFontFamily, + fontSize: this.external_component_queueFontSize, + fontWeight: this.external_component_queueFontWeight + }; + }, + boundaryFont: function() { + return { + fontFamily: this.boundaryFontFamily, + fontSize: this.boundaryFontSize, + fontWeight: this.boundaryFontWeight + }; + }, + messageFont: function() { + return { + fontFamily: this.messageFontFamily, + fontSize: this.messageFontSize, + fontWeight: this.messageFontWeight + }; + } + }, + pie: { + ...defaultConfigJson.pie, + useWidth: 984 + }, + xyChart: { + ...defaultConfigJson.xyChart, + useWidth: void 0 + }, + requirement: { + ...defaultConfigJson.requirement, + useWidth: void 0 + }, + gitGraph: { + ...defaultConfigJson.gitGraph, + // TODO: This is a temporary override for `gitGraph`, since every other + // diagram does have `useMaxWidth`, but instead sets it to `true`. + // Should we set this to `true` instead? + useMaxWidth: false + }, + sankey: { + ...defaultConfigJson.sankey, + // this is false, unlike every other diagram (other than gitGraph) + // TODO: can we make this default to `true` instead? + useMaxWidth: false + } +}; +const keyify = (obj, prefix = "") => Object.keys(obj).reduce((res, el) => { + if (Array.isArray(obj[el])) { + return res; + } else if (typeof obj[el] === "object" && obj[el] !== null) { + return [...res, prefix + el, ...keyify(obj[el], "")]; + } + return [...res, prefix + el]; +}, []); +const configKeys = new Set(keyify(config, "")); +const defaultConfig$2 = config; +const sanitizeDirective = (args) => { + log$1.debug("sanitizeDirective called with", args); + if (typeof args !== "object" || args == null) { + return; + } + if (Array.isArray(args)) { + args.forEach((arg) => sanitizeDirective(arg)); + return; + } + for (const key of Object.keys(args)) { + log$1.debug("Checking key", key); + if (key.startsWith("__") || key.includes("proto") || key.includes("constr") || !configKeys.has(key) || args[key] == null) { + log$1.debug("sanitize deleting key: ", key); + delete args[key]; + continue; + } + if (typeof args[key] === "object") { + log$1.debug("sanitizing object", key); + sanitizeDirective(args[key]); + continue; + } + const cssMatchers = ["themeCSS", "fontFamily", "altFontFamily"]; + for (const cssKey of cssMatchers) { + if (key.includes(cssKey)) { + log$1.debug("sanitizing css option", key); + args[key] = sanitizeCss(args[key]); + } + } + } + if (args.themeVariables) { + for (const k of Object.keys(args.themeVariables)) { + const val = args.themeVariables[k]; + if ((val == null ? void 0 : val.match) && !val.match(/^[\d "#%(),.;A-Za-z]+$/)) { + args.themeVariables[k] = ""; + } + } + } + log$1.debug("After sanitization", args); +}; +const sanitizeCss = (str2) => { + let startCnt = 0; + let endCnt = 0; + for (const element of str2) { + if (startCnt < endCnt) { + return "{ /* ERROR: Unbalanced CSS */ }"; + } + if (element === "{") { + startCnt++; + } else if (element === "}") { + endCnt++; + } + } + if (startCnt !== endCnt) { + return "{ /* ERROR: Unbalanced CSS */ }"; + } + return str2; +}; +const frontMatterRegex = /^-{3}\s*[\n\r](.*?)[\n\r]-{3}\s*[\n\r]+/s; +const directiveRegex = /%{2}{\s*(?:(\w+)\s*:|(\w+))\s*(?:(\w+)|((?:(?!}%{2}).|\r?\n)*))?\s*(?:}%{2})?/gi; +const anyCommentRegex = /\s*%%.*\n/gm; +class UnknownDiagramError extends Error { + constructor(message) { + super(message); + this.name = "UnknownDiagramError"; + } +} +const detectors = {}; +const detectType = function(text2, config2) { + text2 = text2.replace(frontMatterRegex, "").replace(directiveRegex, "").replace(anyCommentRegex, "\n"); + for (const [key, { detector: detector2 }] of Object.entries(detectors)) { + const diagram2 = detector2(text2, config2); + if (diagram2) { + return key; + } + } + throw new UnknownDiagramError( + `No diagram type detected matching given configuration for text: ${text2}` + ); +}; +const registerLazyLoadedDiagrams = (...diagrams2) => { + for (const { id: id2, detector: detector2, loader: loader2 } of diagrams2) { + addDetector(id2, detector2, loader2); + } +}; +const addDetector = (key, detector2, loader2) => { + if (detectors[key]) { + log$1.error(`Detector with key ${key} already exists`); + } else { + detectors[key] = { detector: detector2, loader: loader2 }; + } + log$1.debug(`Detector with key ${key} added${loader2 ? " with loader" : ""}`); +}; +const getDiagramLoader = (key) => { + return detectors[key].loader; +}; +const assignWithDepth = (dst, src, { depth = 2, clobber = false } = {}) => { + const config2 = { depth, clobber }; + if (Array.isArray(src) && !Array.isArray(dst)) { + src.forEach((s) => assignWithDepth(dst, s, config2)); + return dst; + } else if (Array.isArray(src) && Array.isArray(dst)) { + src.forEach((s) => { + if (!dst.includes(s)) { + dst.push(s); + } + }); + return dst; + } + if (dst === void 0 || depth <= 0) { + if (dst !== void 0 && dst !== null && typeof dst === "object" && typeof src === "object") { + return Object.assign(dst, src); + } else { + return src; + } + } + if (src !== void 0 && typeof dst === "object" && typeof src === "object") { + Object.keys(src).forEach((key) => { + if (typeof src[key] === "object" && (dst[key] === void 0 || typeof dst[key] === "object")) { + if (dst[key] === void 0) { + dst[key] = Array.isArray(src[key]) ? [] : {}; + } + dst[key] = assignWithDepth(dst[key], src[key], { depth: depth - 1, clobber }); + } else if (clobber || typeof dst[key] !== "object" && typeof src[key] !== "object") { + dst[key] = src[key]; + } + }); + } + return dst; +}; +const assignWithDepth$1 = assignWithDepth; +var freeGlobal = typeof global == "object" && global && global.Object === Object && global; +const freeGlobal$1 = freeGlobal; +var freeSelf = typeof self == "object" && self && self.Object === Object && self; +var root = freeGlobal$1 || freeSelf || Function("return this")(); +const root$1 = root; +var Symbol$1 = root$1.Symbol; +const Symbol$2 = Symbol$1; +var objectProto$c = Object.prototype; +var hasOwnProperty$a = objectProto$c.hasOwnProperty; +var nativeObjectToString$1 = objectProto$c.toString; +var symToStringTag$1 = Symbol$2 ? Symbol$2.toStringTag : void 0; +function getRawTag(value) { + var isOwn = hasOwnProperty$a.call(value, symToStringTag$1), tag = value[symToStringTag$1]; + try { + value[symToStringTag$1] = void 0; + var unmasked = true; + } catch (e) { + } + var result = nativeObjectToString$1.call(value); + if (unmasked) { + if (isOwn) { + value[symToStringTag$1] = tag; + } else { + delete value[symToStringTag$1]; + } + } + return result; +} +var objectProto$b = Object.prototype; +var nativeObjectToString = objectProto$b.toString; +function objectToString(value) { + return nativeObjectToString.call(value); +} +var nullTag = "[object Null]", undefinedTag = "[object Undefined]"; +var symToStringTag = Symbol$2 ? Symbol$2.toStringTag : void 0; +function baseGetTag(value) { + if (value == null) { + return value === void 0 ? undefinedTag : nullTag; + } + return symToStringTag && symToStringTag in Object(value) ? getRawTag(value) : objectToString(value); +} +function isObject$1(value) { + var type2 = typeof value; + return value != null && (type2 == "object" || type2 == "function"); +} +var asyncTag = "[object AsyncFunction]", funcTag$1 = "[object Function]", genTag = "[object GeneratorFunction]", proxyTag = "[object Proxy]"; +function isFunction(value) { + if (!isObject$1(value)) { + return false; + } + var tag = baseGetTag(value); + return tag == funcTag$1 || tag == genTag || tag == asyncTag || tag == proxyTag; +} +var coreJsData = root$1["__core-js_shared__"]; +const coreJsData$1 = coreJsData; +var maskSrcKey = function() { + var uid = /[^.]+$/.exec(coreJsData$1 && coreJsData$1.keys && coreJsData$1.keys.IE_PROTO || ""); + return uid ? "Symbol(src)_1." + uid : ""; +}(); +function isMasked(func) { + return !!maskSrcKey && maskSrcKey in func; +} +var funcProto$2 = Function.prototype; +var funcToString$2 = funcProto$2.toString; +function toSource(func) { + if (func != null) { + try { + return funcToString$2.call(func); + } catch (e) { + } + try { + return func + ""; + } catch (e) { + } + } + return ""; +} +var reRegExpChar = /[\\^$.*+?()[\]{}|]/g; +var reIsHostCtor = /^\[object .+?Constructor\]$/; +var funcProto$1 = Function.prototype, objectProto$a = Object.prototype; +var funcToString$1 = funcProto$1.toString; +var hasOwnProperty$9 = objectProto$a.hasOwnProperty; +var reIsNative = RegExp( + "^" + funcToString$1.call(hasOwnProperty$9).replace(reRegExpChar, "\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g, "$1.*?") + "$" +); +function baseIsNative(value) { + if (!isObject$1(value) || isMasked(value)) { + return false; + } + var pattern = isFunction(value) ? reIsNative : reIsHostCtor; + return pattern.test(toSource(value)); +} +function getValue(object, key) { + return object == null ? void 0 : object[key]; +} +function getNative(object, key) { + var value = getValue(object, key); + return baseIsNative(value) ? value : void 0; +} +var nativeCreate = getNative(Object, "create"); +const nativeCreate$1 = nativeCreate; +function hashClear() { + this.__data__ = nativeCreate$1 ? nativeCreate$1(null) : {}; + this.size = 0; +} +function hashDelete(key) { + var result = this.has(key) && delete this.__data__[key]; + this.size -= result ? 1 : 0; + return result; +} +var HASH_UNDEFINED$1 = "__lodash_hash_undefined__"; +var objectProto$9 = Object.prototype; +var hasOwnProperty$8 = objectProto$9.hasOwnProperty; +function hashGet(key) { + var data = this.__data__; + if (nativeCreate$1) { + var result = data[key]; + return result === HASH_UNDEFINED$1 ? void 0 : result; + } + return hasOwnProperty$8.call(data, key) ? data[key] : void 0; +} +var objectProto$8 = Object.prototype; +var hasOwnProperty$7 = objectProto$8.hasOwnProperty; +function hashHas(key) { + var data = this.__data__; + return nativeCreate$1 ? data[key] !== void 0 : hasOwnProperty$7.call(data, key); +} +var HASH_UNDEFINED = "__lodash_hash_undefined__"; +function hashSet(key, value) { + var data = this.__data__; + this.size += this.has(key) ? 0 : 1; + data[key] = nativeCreate$1 && value === void 0 ? HASH_UNDEFINED : value; + return this; +} +function Hash(entries2) { + var index = -1, length2 = entries2 == null ? 0 : entries2.length; + this.clear(); + while (++index < length2) { + var entry = entries2[index]; + this.set(entry[0], entry[1]); + } +} +Hash.prototype.clear = hashClear; +Hash.prototype["delete"] = hashDelete; +Hash.prototype.get = hashGet; +Hash.prototype.has = hashHas; +Hash.prototype.set = hashSet; +function listCacheClear() { + this.__data__ = []; + this.size = 0; +} +function eq(value, other) { + return value === other || value !== value && other !== other; +} +function assocIndexOf(array2, key) { + var length2 = array2.length; + while (length2--) { + if (eq(array2[length2][0], key)) { + return length2; + } + } + return -1; +} +var arrayProto = Array.prototype; +var splice = arrayProto.splice; +function listCacheDelete(key) { + var data = this.__data__, index = assocIndexOf(data, key); + if (index < 0) { + return false; + } + var lastIndex = data.length - 1; + if (index == lastIndex) { + data.pop(); + } else { + splice.call(data, index, 1); + } + --this.size; + return true; +} +function listCacheGet(key) { + var data = this.__data__, index = assocIndexOf(data, key); + return index < 0 ? void 0 : data[index][1]; +} +function listCacheHas(key) { + return assocIndexOf(this.__data__, key) > -1; +} +function listCacheSet(key, value) { + var data = this.__data__, index = assocIndexOf(data, key); + if (index < 0) { + ++this.size; + data.push([key, value]); + } else { + data[index][1] = value; + } + return this; +} +function ListCache(entries2) { + var index = -1, length2 = entries2 == null ? 0 : entries2.length; + this.clear(); + while (++index < length2) { + var entry = entries2[index]; + this.set(entry[0], entry[1]); + } +} +ListCache.prototype.clear = listCacheClear; +ListCache.prototype["delete"] = listCacheDelete; +ListCache.prototype.get = listCacheGet; +ListCache.prototype.has = listCacheHas; +ListCache.prototype.set = listCacheSet; +var Map$1 = getNative(root$1, "Map"); +const Map$2 = Map$1; +function mapCacheClear() { + this.size = 0; + this.__data__ = { + "hash": new Hash(), + "map": new (Map$2 || ListCache)(), + "string": new Hash() + }; +} +function isKeyable(value) { + var type2 = typeof value; + return type2 == "string" || type2 == "number" || type2 == "symbol" || type2 == "boolean" ? value !== "__proto__" : value === null; +} +function getMapData(map2, key) { + var data = map2.__data__; + return isKeyable(key) ? data[typeof key == "string" ? "string" : "hash"] : data.map; +} +function mapCacheDelete(key) { + var result = getMapData(this, key)["delete"](key); + this.size -= result ? 1 : 0; + return result; +} +function mapCacheGet(key) { + return getMapData(this, key).get(key); +} +function mapCacheHas(key) { + return getMapData(this, key).has(key); +} +function mapCacheSet(key, value) { + var data = getMapData(this, key), size = data.size; + data.set(key, value); + this.size += data.size == size ? 0 : 1; + return this; +} +function MapCache(entries2) { + var index = -1, length2 = entries2 == null ? 0 : entries2.length; + this.clear(); + while (++index < length2) { + var entry = entries2[index]; + this.set(entry[0], entry[1]); + } +} +MapCache.prototype.clear = mapCacheClear; +MapCache.prototype["delete"] = mapCacheDelete; +MapCache.prototype.get = mapCacheGet; +MapCache.prototype.has = mapCacheHas; +MapCache.prototype.set = mapCacheSet; +var FUNC_ERROR_TEXT = "Expected a function"; +function memoize(func, resolver) { + if (typeof func != "function" || resolver != null && typeof resolver != "function") { + throw new TypeError(FUNC_ERROR_TEXT); + } + var memoized = function() { + var args = arguments, key = resolver ? resolver.apply(this, args) : args[0], cache = memoized.cache; + if (cache.has(key)) { + return cache.get(key); + } + var result = func.apply(this, args); + memoized.cache = cache.set(key, result) || cache; + return result; + }; + memoized.cache = new (memoize.Cache || MapCache)(); + return memoized; +} +memoize.Cache = MapCache; +function stackClear() { + this.__data__ = new ListCache(); + this.size = 0; +} +function stackDelete(key) { + var data = this.__data__, result = data["delete"](key); + this.size = data.size; + return result; +} +function stackGet(key) { + return this.__data__.get(key); +} +function stackHas(key) { + return this.__data__.has(key); +} +var LARGE_ARRAY_SIZE = 200; +function stackSet(key, value) { + var data = this.__data__; + if (data instanceof ListCache) { + var pairs2 = data.__data__; + if (!Map$2 || pairs2.length < LARGE_ARRAY_SIZE - 1) { + pairs2.push([key, value]); + this.size = ++data.size; + return this; + } + data = this.__data__ = new MapCache(pairs2); + } + data.set(key, value); + this.size = data.size; + return this; +} +function Stack(entries2) { + var data = this.__data__ = new ListCache(entries2); + this.size = data.size; +} +Stack.prototype.clear = stackClear; +Stack.prototype["delete"] = stackDelete; +Stack.prototype.get = stackGet; +Stack.prototype.has = stackHas; +Stack.prototype.set = stackSet; +var defineProperty = function() { + try { + var func = getNative(Object, "defineProperty"); + func({}, "", {}); + return func; + } catch (e) { + } +}(); +const defineProperty$1 = defineProperty; +function baseAssignValue(object, key, value) { + if (key == "__proto__" && defineProperty$1) { + defineProperty$1(object, key, { + "configurable": true, + "enumerable": true, + "value": value, + "writable": true + }); + } else { + object[key] = value; + } +} +function assignMergeValue(object, key, value) { + if (value !== void 0 && !eq(object[key], value) || value === void 0 && !(key in object)) { + baseAssignValue(object, key, value); + } +} +function createBaseFor(fromRight) { + return function(object, iteratee, keysFunc) { + var index = -1, iterable = Object(object), props = keysFunc(object), length2 = props.length; + while (length2--) { + var key = props[fromRight ? length2 : ++index]; + if (iteratee(iterable[key], key, iterable) === false) { + break; + } + } + return object; + }; +} +var baseFor = createBaseFor(); +const baseFor$1 = baseFor; +var freeExports$2 = typeof exports == "object" && exports && !exports.nodeType && exports; +var freeModule$2 = freeExports$2 && typeof module == "object" && module && !module.nodeType && module; +var moduleExports$2 = freeModule$2 && freeModule$2.exports === freeExports$2; +var Buffer$1 = moduleExports$2 ? root$1.Buffer : void 0, allocUnsafe = Buffer$1 ? Buffer$1.allocUnsafe : void 0; +function cloneBuffer(buffer, isDeep) { + if (isDeep) { + return buffer.slice(); + } + var length2 = buffer.length, result = allocUnsafe ? allocUnsafe(length2) : new buffer.constructor(length2); + buffer.copy(result); + return result; +} +var Uint8Array$1 = root$1.Uint8Array; +const Uint8Array$2 = Uint8Array$1; +function cloneArrayBuffer(arrayBuffer) { + var result = new arrayBuffer.constructor(arrayBuffer.byteLength); + new Uint8Array$2(result).set(new Uint8Array$2(arrayBuffer)); + return result; +} +function cloneTypedArray(typedArray, isDeep) { + var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer; + return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length); +} +function copyArray(source, array2) { + var index = -1, length2 = source.length; + array2 || (array2 = Array(length2)); + while (++index < length2) { + array2[index] = source[index]; + } + return array2; +} +var objectCreate = Object.create; +var baseCreate = function() { + function object() { + } + return function(proto) { + if (!isObject$1(proto)) { + return {}; + } + if (objectCreate) { + return objectCreate(proto); + } + object.prototype = proto; + var result = new object(); + object.prototype = void 0; + return result; + }; +}(); +const baseCreate$1 = baseCreate; +function overArg(func, transform) { + return function(arg) { + return func(transform(arg)); + }; +} +var getPrototype = overArg(Object.getPrototypeOf, Object); +const getPrototype$1 = getPrototype; +var objectProto$7 = Object.prototype; +function isPrototype(value) { + var Ctor = value && value.constructor, proto = typeof Ctor == "function" && Ctor.prototype || objectProto$7; + return value === proto; +} +function initCloneObject(object) { + return typeof object.constructor == "function" && !isPrototype(object) ? baseCreate$1(getPrototype$1(object)) : {}; +} +function isObjectLike(value) { + return value != null && typeof value == "object"; +} +var argsTag$1 = "[object Arguments]"; +function baseIsArguments(value) { + return isObjectLike(value) && baseGetTag(value) == argsTag$1; +} +var objectProto$6 = Object.prototype; +var hasOwnProperty$6 = objectProto$6.hasOwnProperty; +var propertyIsEnumerable = objectProto$6.propertyIsEnumerable; +var isArguments = baseIsArguments(function() { + return arguments; +}()) ? baseIsArguments : function(value) { + return isObjectLike(value) && hasOwnProperty$6.call(value, "callee") && !propertyIsEnumerable.call(value, "callee"); +}; +const isArguments$1 = isArguments; +var isArray = Array.isArray; +const isArray$1 = isArray; +var MAX_SAFE_INTEGER$1 = 9007199254740991; +function isLength(value) { + return typeof value == "number" && value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER$1; +} +function isArrayLike(value) { + return value != null && isLength(value.length) && !isFunction(value); +} +function isArrayLikeObject(value) { + return isObjectLike(value) && isArrayLike(value); +} +function stubFalse() { + return false; +} +var freeExports$1 = typeof exports == "object" && exports && !exports.nodeType && exports; +var freeModule$1 = freeExports$1 && typeof module == "object" && module && !module.nodeType && module; +var moduleExports$1 = freeModule$1 && freeModule$1.exports === freeExports$1; +var Buffer = moduleExports$1 ? root$1.Buffer : void 0; +var nativeIsBuffer = Buffer ? Buffer.isBuffer : void 0; +var isBuffer = nativeIsBuffer || stubFalse; +const isBuffer$1 = isBuffer; +var objectTag$2 = "[object Object]"; +var funcProto = Function.prototype, objectProto$5 = Object.prototype; +var funcToString = funcProto.toString; +var hasOwnProperty$5 = objectProto$5.hasOwnProperty; +var objectCtorString = funcToString.call(Object); +function isPlainObject(value) { + if (!isObjectLike(value) || baseGetTag(value) != objectTag$2) { + return false; + } + var proto = getPrototype$1(value); + if (proto === null) { + return true; + } + var Ctor = hasOwnProperty$5.call(proto, "constructor") && proto.constructor; + return typeof Ctor == "function" && Ctor instanceof Ctor && funcToString.call(Ctor) == objectCtorString; +} +var argsTag = "[object Arguments]", arrayTag = "[object Array]", boolTag = "[object Boolean]", dateTag = "[object Date]", errorTag = "[object Error]", funcTag = "[object Function]", mapTag$2 = "[object Map]", numberTag = "[object Number]", objectTag$1 = "[object Object]", regexpTag = "[object RegExp]", setTag$2 = "[object Set]", stringTag = "[object String]", weakMapTag$1 = "[object WeakMap]"; +var arrayBufferTag = "[object ArrayBuffer]", dataViewTag$1 = "[object DataView]", float32Tag = "[object Float32Array]", float64Tag = "[object Float64Array]", int8Tag = "[object Int8Array]", int16Tag = "[object Int16Array]", int32Tag = "[object Int32Array]", uint8Tag = "[object Uint8Array]", uint8ClampedTag = "[object Uint8ClampedArray]", uint16Tag = "[object Uint16Array]", uint32Tag = "[object Uint32Array]"; +var typedArrayTags = {}; +typedArrayTags[float32Tag] = typedArrayTags[float64Tag] = typedArrayTags[int8Tag] = typedArrayTags[int16Tag] = typedArrayTags[int32Tag] = typedArrayTags[uint8Tag] = typedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] = typedArrayTags[uint32Tag] = true; +typedArrayTags[argsTag] = typedArrayTags[arrayTag] = typedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] = typedArrayTags[dataViewTag$1] = typedArrayTags[dateTag] = typedArrayTags[errorTag] = typedArrayTags[funcTag] = typedArrayTags[mapTag$2] = typedArrayTags[numberTag] = typedArrayTags[objectTag$1] = typedArrayTags[regexpTag] = typedArrayTags[setTag$2] = typedArrayTags[stringTag] = typedArrayTags[weakMapTag$1] = false; +function baseIsTypedArray(value) { + return isObjectLike(value) && isLength(value.length) && !!typedArrayTags[baseGetTag(value)]; +} +function baseUnary(func) { + return function(value) { + return func(value); + }; +} +var freeExports = typeof exports == "object" && exports && !exports.nodeType && exports; +var freeModule = freeExports && typeof module == "object" && module && !module.nodeType && module; +var moduleExports = freeModule && freeModule.exports === freeExports; +var freeProcess = moduleExports && freeGlobal$1.process; +var nodeUtil = function() { + try { + var types = freeModule && freeModule.require && freeModule.require("util").types; + if (types) { + return types; + } + return freeProcess && freeProcess.binding && freeProcess.binding("util"); + } catch (e) { + } +}(); +const nodeUtil$1 = nodeUtil; +var nodeIsTypedArray = nodeUtil$1 && nodeUtil$1.isTypedArray; +var isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray; +const isTypedArray$1 = isTypedArray; +function safeGet(object, key) { + if (key === "constructor" && typeof object[key] === "function") { + return; + } + if (key == "__proto__") { + return; + } + return object[key]; +} +var objectProto$4 = Object.prototype; +var hasOwnProperty$4 = objectProto$4.hasOwnProperty; +function assignValue(object, key, value) { + var objValue = object[key]; + if (!(hasOwnProperty$4.call(object, key) && eq(objValue, value)) || value === void 0 && !(key in object)) { + baseAssignValue(object, key, value); + } +} +function copyObject(source, props, object, customizer) { + var isNew = !object; + object || (object = {}); + var index = -1, length2 = props.length; + while (++index < length2) { + var key = props[index]; + var newValue = customizer ? customizer(object[key], source[key], key, object, source) : void 0; + if (newValue === void 0) { + newValue = source[key]; + } + if (isNew) { + baseAssignValue(object, key, newValue); + } else { + assignValue(object, key, newValue); + } + } + return object; +} +function baseTimes(n, iteratee) { + var index = -1, result = Array(n); + while (++index < n) { + result[index] = iteratee(index); + } + return result; +} +var MAX_SAFE_INTEGER = 9007199254740991; +var reIsUint = /^(?:0|[1-9]\d*)$/; +function isIndex(value, length2) { + var type2 = typeof value; + length2 = length2 == null ? MAX_SAFE_INTEGER : length2; + return !!length2 && (type2 == "number" || type2 != "symbol" && reIsUint.test(value)) && (value > -1 && value % 1 == 0 && value < length2); +} +var objectProto$3 = Object.prototype; +var hasOwnProperty$3 = objectProto$3.hasOwnProperty; +function arrayLikeKeys(value, inherited) { + var isArr = isArray$1(value), isArg = !isArr && isArguments$1(value), isBuff = !isArr && !isArg && isBuffer$1(value), isType = !isArr && !isArg && !isBuff && isTypedArray$1(value), skipIndexes = isArr || isArg || isBuff || isType, result = skipIndexes ? baseTimes(value.length, String) : [], length2 = result.length; + for (var key in value) { + if ((inherited || hasOwnProperty$3.call(value, key)) && !(skipIndexes && // Safari 9 has enumerable `arguments.length` in strict mode. + (key == "length" || // Node.js 0.10 has enumerable non-index properties on buffers. + isBuff && (key == "offset" || key == "parent") || // PhantomJS 2 has enumerable non-index properties on typed arrays. + isType && (key == "buffer" || key == "byteLength" || key == "byteOffset") || // Skip index properties. + isIndex(key, length2)))) { + result.push(key); + } + } + return result; +} +function nativeKeysIn(object) { + var result = []; + if (object != null) { + for (var key in Object(object)) { + result.push(key); + } + } + return result; +} +var objectProto$2 = Object.prototype; +var hasOwnProperty$2 = objectProto$2.hasOwnProperty; +function baseKeysIn(object) { + if (!isObject$1(object)) { + return nativeKeysIn(object); + } + var isProto = isPrototype(object), result = []; + for (var key in object) { + if (!(key == "constructor" && (isProto || !hasOwnProperty$2.call(object, key)))) { + result.push(key); + } + } + return result; +} +function keysIn(object) { + return isArrayLike(object) ? arrayLikeKeys(object, true) : baseKeysIn(object); +} +function toPlainObject(value) { + return copyObject(value, keysIn(value)); +} +function baseMergeDeep(object, source, key, srcIndex, mergeFunc, customizer, stack) { + var objValue = safeGet(object, key), srcValue = safeGet(source, key), stacked = stack.get(srcValue); + if (stacked) { + assignMergeValue(object, key, stacked); + return; + } + var newValue = customizer ? customizer(objValue, srcValue, key + "", object, source, stack) : void 0; + var isCommon = newValue === void 0; + if (isCommon) { + var isArr = isArray$1(srcValue), isBuff = !isArr && isBuffer$1(srcValue), isTyped = !isArr && !isBuff && isTypedArray$1(srcValue); + newValue = srcValue; + if (isArr || isBuff || isTyped) { + if (isArray$1(objValue)) { + newValue = objValue; + } else if (isArrayLikeObject(objValue)) { + newValue = copyArray(objValue); + } else if (isBuff) { + isCommon = false; + newValue = cloneBuffer(srcValue, true); + } else if (isTyped) { + isCommon = false; + newValue = cloneTypedArray(srcValue, true); + } else { + newValue = []; + } + } else if (isPlainObject(srcValue) || isArguments$1(srcValue)) { + newValue = objValue; + if (isArguments$1(objValue)) { + newValue = toPlainObject(objValue); + } else if (!isObject$1(objValue) || isFunction(objValue)) { + newValue = initCloneObject(srcValue); + } + } else { + isCommon = false; + } + } + if (isCommon) { + stack.set(srcValue, newValue); + mergeFunc(newValue, srcValue, srcIndex, customizer, stack); + stack["delete"](srcValue); + } + assignMergeValue(object, key, newValue); +} +function baseMerge(object, source, srcIndex, customizer, stack) { + if (object === source) { + return; + } + baseFor$1(source, function(srcValue, key) { + stack || (stack = new Stack()); + if (isObject$1(srcValue)) { + baseMergeDeep(object, source, key, srcIndex, baseMerge, customizer, stack); + } else { + var newValue = customizer ? customizer(safeGet(object, key), srcValue, key + "", object, source, stack) : void 0; + if (newValue === void 0) { + newValue = srcValue; + } + assignMergeValue(object, key, newValue); + } + }, keysIn); +} +function identity(value) { + return value; +} +function apply(func, thisArg, args) { + switch (args.length) { + case 0: + return func.call(thisArg); + case 1: + return func.call(thisArg, args[0]); + case 2: + return func.call(thisArg, args[0], args[1]); + case 3: + return func.call(thisArg, args[0], args[1], args[2]); + } + return func.apply(thisArg, args); +} +var nativeMax = Math.max; +function overRest(func, start2, transform) { + start2 = nativeMax(start2 === void 0 ? func.length - 1 : start2, 0); + return function() { + var args = arguments, index = -1, length2 = nativeMax(args.length - start2, 0), array2 = Array(length2); + while (++index < length2) { + array2[index] = args[start2 + index]; + } + index = -1; + var otherArgs = Array(start2 + 1); + while (++index < start2) { + otherArgs[index] = args[index]; + } + otherArgs[start2] = transform(array2); + return apply(func, this, otherArgs); + }; +} +function constant(value) { + return function() { + return value; + }; +} +var baseSetToString = !defineProperty$1 ? identity : function(func, string) { + return defineProperty$1(func, "toString", { + "configurable": true, + "enumerable": false, + "value": constant(string), + "writable": true + }); +}; +const baseSetToString$1 = baseSetToString; +var HOT_COUNT = 800, HOT_SPAN = 16; +var nativeNow = Date.now; +function shortOut(func) { + var count = 0, lastCalled = 0; + return function() { + var stamp = nativeNow(), remaining = HOT_SPAN - (stamp - lastCalled); + lastCalled = stamp; + if (remaining > 0) { + if (++count >= HOT_COUNT) { + return arguments[0]; + } + } else { + count = 0; + } + return func.apply(void 0, arguments); + }; +} +var setToString = shortOut(baseSetToString$1); +const setToString$1 = setToString; +function baseRest(func, start2) { + return setToString$1(overRest(func, start2, identity), func + ""); +} +function isIterateeCall(value, index, object) { + if (!isObject$1(object)) { + return false; + } + var type2 = typeof index; + if (type2 == "number" ? isArrayLike(object) && isIndex(index, object.length) : type2 == "string" && index in object) { + return eq(object[index], value); + } + return false; +} +function createAssigner(assigner) { + return baseRest(function(object, sources) { + var index = -1, length2 = sources.length, customizer = length2 > 1 ? sources[length2 - 1] : void 0, guard = length2 > 2 ? sources[2] : void 0; + customizer = assigner.length > 3 && typeof customizer == "function" ? (length2--, customizer) : void 0; + if (guard && isIterateeCall(sources[0], sources[1], guard)) { + customizer = length2 < 3 ? void 0 : customizer; + length2 = 1; + } + object = Object(object); + while (++index < length2) { + var source = sources[index]; + if (source) { + assigner(object, source, index, customizer); + } + } + return object; + }); +} +var merge$1 = createAssigner(function(object, source, srcIndex) { + baseMerge(object, source, srcIndex); +}); +const merge$2 = merge$1; +const ZERO_WIDTH_SPACE = "​"; +const d3CurveTypes = { + curveBasis, + curveBasisClosed, + curveBasisOpen, + curveBumpX: bumpX, + curveBumpY: bumpY, + curveBundle, + curveCardinalClosed, + curveCardinalOpen, + curveCardinal, + curveCatmullRomClosed, + curveCatmullRomOpen, + curveCatmullRom, + curveLinear, + curveLinearClosed, + curveMonotoneX: monotoneX, + curveMonotoneY: monotoneY, + curveNatural, + curveStep, + curveStepAfter: stepAfter, + curveStepBefore: stepBefore +}; +const directiveWithoutOpen = /\s*(?:(\w+)(?=:):|(\w+))\s*(?:(\w+)|((?:(?!}%{2}).|\r?\n)*))?\s*(?:}%{2})?/gi; +const detectInit = function(text2, config2) { + const inits = detectDirective(text2, /(?:init\b)|(?:initialize\b)/); + let results = {}; + if (Array.isArray(inits)) { + const args = inits.map((init2) => init2.args); + sanitizeDirective(args); + results = assignWithDepth$1(results, [...args]); + } else { + results = inits.args; + } + if (!results) { + return; + } + let type2 = detectType(text2, config2); + const prop = "config"; + if (results[prop] !== void 0) { + if (type2 === "flowchart-v2") { + type2 = "flowchart"; + } + results[type2] = results[prop]; + delete results[prop]; + } + return results; +}; +const detectDirective = function(text2, type2 = null) { + try { + const commentWithoutDirectives = new RegExp( + `[%]{2}(?![{]${directiveWithoutOpen.source})(?=[}][%]{2}).* +`, + "ig" + ); + text2 = text2.trim().replace(commentWithoutDirectives, "").replace(/'/gm, '"'); + log$1.debug( + `Detecting diagram directive${type2 !== null ? " type:" + type2 : ""} based on the text:${text2}` + ); + let match; + const result = []; + while ((match = directiveRegex.exec(text2)) !== null) { + if (match.index === directiveRegex.lastIndex) { + directiveRegex.lastIndex++; + } + if (match && !type2 || type2 && match[1] && match[1].match(type2) || type2 && match[2] && match[2].match(type2)) { + const type22 = match[1] ? match[1] : match[2]; + const args = match[3] ? match[3].trim() : match[4] ? JSON.parse(match[4].trim()) : null; + result.push({ type: type22, args }); + } + } + if (result.length === 0) { + return { type: text2, args: null }; + } + return result.length === 1 ? result[0] : result; + } catch (error) { + log$1.error( + `ERROR: ${error.message} - Unable to parse directive type: '${type2}' based on the text: '${text2}'` + ); + return { type: void 0, args: null }; + } +}; +const removeDirectives = function(text2) { + return text2.replace(directiveRegex, ""); +}; +const isSubstringInArray = function(str2, arr) { + for (const [i, element] of arr.entries()) { + if (element.match(str2)) { + return i; + } + } + return -1; +}; +function interpolateToCurve(interpolate2, defaultCurve) { + if (!interpolate2) { + return defaultCurve; + } + const curveName = `curve${interpolate2.charAt(0).toUpperCase() + interpolate2.slice(1)}`; + return d3CurveTypes[curveName] ?? defaultCurve; +} +function formatUrl(linkStr, config2) { + const url = linkStr.trim(); + if (!url) { + return void 0; + } + if (config2.securityLevel !== "loose") { + return dist.sanitizeUrl(url); + } + return url; +} +const runFunc = (functionName, ...params) => { + const arrPaths = functionName.split("."); + const len = arrPaths.length - 1; + const fnName = arrPaths[len]; + let obj = window; + for (let i = 0; i < len; i++) { + obj = obj[arrPaths[i]]; + if (!obj) { + log$1.error(`Function name: ${functionName} not found in window`); + return; + } + } + obj[fnName](...params); +}; +function distance(p1, p2) { + if (!p1 || !p2) { + return 0; + } + return Math.sqrt(Math.pow(p2.x - p1.x, 2) + Math.pow(p2.y - p1.y, 2)); +} +function traverseEdge(points) { + let prevPoint; + let totalDistance = 0; + points.forEach((point2) => { + totalDistance += distance(point2, prevPoint); + prevPoint = point2; + }); + const remainingDistance = totalDistance / 2; + return calculatePoint(points, remainingDistance); +} +function calcLabelPosition(points) { + if (points.length === 1) { + return points[0]; + } + return traverseEdge(points); +} +const roundNumber = (num, precision = 2) => { + const factor = Math.pow(10, precision); + return Math.round(num * factor) / factor; +}; +const calculatePoint = (points, distanceToTraverse) => { + let prevPoint = void 0; + let remainingDistance = distanceToTraverse; + for (const point2 of points) { + if (prevPoint) { + const vectorDistance = distance(point2, prevPoint); + if (vectorDistance < remainingDistance) { + remainingDistance -= vectorDistance; + } else { + const distanceRatio = remainingDistance / vectorDistance; + if (distanceRatio <= 0) { + return prevPoint; + } + if (distanceRatio >= 1) { + return { x: point2.x, y: point2.y }; + } + if (distanceRatio > 0 && distanceRatio < 1) { + return { + x: roundNumber((1 - distanceRatio) * prevPoint.x + distanceRatio * point2.x, 5), + y: roundNumber((1 - distanceRatio) * prevPoint.y + distanceRatio * point2.y, 5) + }; + } + } + } + prevPoint = point2; + } + throw new Error("Could not find a suitable point for the given distance"); +}; +const calcCardinalityPosition = (isRelationTypePresent, points, initialPosition) => { + log$1.info(`our points ${JSON.stringify(points)}`); + if (points[0] !== initialPosition) { + points = points.reverse(); + } + const distanceToCardinalityPoint = 25; + const center = calculatePoint(points, distanceToCardinalityPoint); + const d = isRelationTypePresent ? 10 : 5; + const angle = Math.atan2(points[0].y - center.y, points[0].x - center.x); + const cardinalityPosition = { x: 0, y: 0 }; + cardinalityPosition.x = Math.sin(angle) * d + (points[0].x + center.x) / 2; + cardinalityPosition.y = -Math.cos(angle) * d + (points[0].y + center.y) / 2; + return cardinalityPosition; +}; +function calcTerminalLabelPosition(terminalMarkerSize, position2, _points) { + const points = structuredClone(_points); + log$1.info("our points", points); + if (position2 !== "start_left" && position2 !== "start_right") { + points.reverse(); + } + const distanceToCardinalityPoint = 25 + terminalMarkerSize; + const center = calculatePoint(points, distanceToCardinalityPoint); + const d = 10 + terminalMarkerSize * 0.5; + const angle = Math.atan2(points[0].y - center.y, points[0].x - center.x); + const cardinalityPosition = { x: 0, y: 0 }; + if (position2 === "start_left") { + cardinalityPosition.x = Math.sin(angle + Math.PI) * d + (points[0].x + center.x) / 2; + cardinalityPosition.y = -Math.cos(angle + Math.PI) * d + (points[0].y + center.y) / 2; + } else if (position2 === "end_right") { + cardinalityPosition.x = Math.sin(angle - Math.PI) * d + (points[0].x + center.x) / 2 - 5; + cardinalityPosition.y = -Math.cos(angle - Math.PI) * d + (points[0].y + center.y) / 2 - 5; + } else if (position2 === "end_left") { + cardinalityPosition.x = Math.sin(angle) * d + (points[0].x + center.x) / 2 - 5; + cardinalityPosition.y = -Math.cos(angle) * d + (points[0].y + center.y) / 2 - 5; + } else { + cardinalityPosition.x = Math.sin(angle) * d + (points[0].x + center.x) / 2; + cardinalityPosition.y = -Math.cos(angle) * d + (points[0].y + center.y) / 2; + } + return cardinalityPosition; +} +function getStylesFromArray(arr) { + let style = ""; + let labelStyle = ""; + for (const element of arr) { + if (element !== void 0) { + if (element.startsWith("color:") || element.startsWith("text-align:")) { + labelStyle = labelStyle + element + ";"; + } else { + style = style + element + ";"; + } + } + } + return { style, labelStyle }; +} +let cnt = 0; +const generateId = () => { + cnt++; + return "id-" + Math.random().toString(36).substr(2, 12) + "-" + cnt; +}; +function makeRandomHex(length2) { + let result = ""; + const characters2 = "0123456789abcdef"; + const charactersLength = characters2.length; + for (let i = 0; i < length2; i++) { + result += characters2.charAt(Math.floor(Math.random() * charactersLength)); + } + return result; +} +const random = (options) => { + return makeRandomHex(options.length); +}; +const getTextObj = function() { + return { + x: 0, + y: 0, + fill: void 0, + anchor: "start", + style: "#666", + width: 100, + height: 100, + textMargin: 0, + rx: 0, + ry: 0, + valign: void 0, + text: "" + }; +}; +const drawSimpleText = function(elem, textData) { + const nText = textData.text.replace(common$1.lineBreakRegex, " "); + const [, _fontSizePx] = parseFontSize(textData.fontSize); + const textElem = elem.append("text"); + textElem.attr("x", textData.x); + textElem.attr("y", textData.y); + textElem.style("text-anchor", textData.anchor); + textElem.style("font-family", textData.fontFamily); + textElem.style("font-size", _fontSizePx); + textElem.style("font-weight", textData.fontWeight); + textElem.attr("fill", textData.fill); + if (textData.class !== void 0) { + textElem.attr("class", textData.class); + } + const span = textElem.append("tspan"); + span.attr("x", textData.x + textData.textMargin * 2); + span.attr("fill", textData.fill); + span.text(nText); + return textElem; +}; +const wrapLabel = memoize( + (label, maxWidth, config2) => { + if (!label) { + return label; + } + config2 = Object.assign( + { fontSize: 12, fontWeight: 400, fontFamily: "Arial", joinWith: "
    " }, + config2 + ); + if (common$1.lineBreakRegex.test(label)) { + return label; + } + const words = label.split(" "); + const completedLines = []; + let nextLine = ""; + words.forEach((word, index) => { + const wordLength = calculateTextWidth(`${word} `, config2); + const nextLineLength = calculateTextWidth(nextLine, config2); + if (wordLength > maxWidth) { + const { hyphenatedStrings, remainingWord } = breakString(word, maxWidth, "-", config2); + completedLines.push(nextLine, ...hyphenatedStrings); + nextLine = remainingWord; + } else if (nextLineLength + wordLength >= maxWidth) { + completedLines.push(nextLine); + nextLine = word; + } else { + nextLine = [nextLine, word].filter(Boolean).join(" "); + } + const currentWord = index + 1; + const isLastWord = currentWord === words.length; + if (isLastWord) { + completedLines.push(nextLine); + } + }); + return completedLines.filter((line2) => line2 !== "").join(config2.joinWith); + }, + (label, maxWidth, config2) => `${label}${maxWidth}${config2.fontSize}${config2.fontWeight}${config2.fontFamily}${config2.joinWith}` +); +const breakString = memoize( + (word, maxWidth, hyphenCharacter = "-", config2) => { + config2 = Object.assign( + { fontSize: 12, fontWeight: 400, fontFamily: "Arial", margin: 0 }, + config2 + ); + const characters2 = [...word]; + const lines = []; + let currentLine = ""; + characters2.forEach((character2, index) => { + const nextLine = `${currentLine}${character2}`; + const lineWidth = calculateTextWidth(nextLine, config2); + if (lineWidth >= maxWidth) { + const currentCharacter = index + 1; + const isLastLine = characters2.length === currentCharacter; + const hyphenatedNextLine = `${nextLine}${hyphenCharacter}`; + lines.push(isLastLine ? nextLine : hyphenatedNextLine); + currentLine = ""; + } else { + currentLine = nextLine; + } + }); + return { hyphenatedStrings: lines, remainingWord: currentLine }; + }, + (word, maxWidth, hyphenCharacter = "-", config2) => `${word}${maxWidth}${hyphenCharacter}${config2.fontSize}${config2.fontWeight}${config2.fontFamily}` +); +function calculateTextHeight(text2, config2) { + return calculateTextDimensions(text2, config2).height; +} +function calculateTextWidth(text2, config2) { + return calculateTextDimensions(text2, config2).width; +} +const calculateTextDimensions = memoize( + (text2, config2) => { + const { fontSize = 12, fontFamily = "Arial", fontWeight = 400 } = config2; + if (!text2) { + return { width: 0, height: 0 }; + } + const [, _fontSizePx] = parseFontSize(fontSize); + const fontFamilies = ["sans-serif", fontFamily]; + const lines = text2.split(common$1.lineBreakRegex); + const dims = []; + const body = d3select("body"); + if (!body.remove) { + return { width: 0, height: 0, lineHeight: 0 }; + } + const g = body.append("svg"); + for (const fontFamily2 of fontFamilies) { + let cHeight = 0; + const dim = { width: 0, height: 0, lineHeight: 0 }; + for (const line2 of lines) { + const textObj = getTextObj(); + textObj.text = line2 || ZERO_WIDTH_SPACE; + const textElem = drawSimpleText(g, textObj).style("font-size", _fontSizePx).style("font-weight", fontWeight).style("font-family", fontFamily2); + const bBox = (textElem._groups || textElem)[0][0].getBBox(); + if (bBox.width === 0 && bBox.height === 0) { + throw new Error("svg element not in render tree"); + } + dim.width = Math.round(Math.max(dim.width, bBox.width)); + cHeight = Math.round(bBox.height); + dim.height += cHeight; + dim.lineHeight = Math.round(Math.max(dim.lineHeight, cHeight)); + } + dims.push(dim); + } + g.remove(); + const index = isNaN(dims[1].height) || isNaN(dims[1].width) || isNaN(dims[1].lineHeight) || dims[0].height > dims[1].height && dims[0].width > dims[1].width && dims[0].lineHeight > dims[1].lineHeight ? 0 : 1; + return dims[index]; + }, + (text2, config2) => `${text2}${config2.fontSize}${config2.fontWeight}${config2.fontFamily}` +); +class InitIDGenerator { + constructor(deterministic = false, seed) { + this.count = 0; + this.count = seed ? seed.length : 0; + this.next = deterministic ? () => this.count++ : () => Date.now(); + } +} +let decoder; +const entityDecode = function(html2) { + decoder = decoder || document.createElement("div"); + html2 = escape(html2).replace(/%26/g, "&").replace(/%23/g, "#").replace(/%3B/g, ";"); + decoder.innerHTML = html2; + return unescape(decoder.textContent); +}; +function isDetailedError(error) { + return "str" in error; +} +const insertTitle = (parent, cssClass, titleTopMargin, title) => { + var _a; + if (!title) { + return; + } + const bounds = (_a = parent.node()) == null ? void 0 : _a.getBBox(); + if (!bounds) { + return; + } + parent.append("text").text(title).attr("x", bounds.x + bounds.width / 2).attr("y", -titleTopMargin).attr("class", cssClass); +}; +const parseFontSize = (fontSize) => { + if (typeof fontSize === "number") { + return [fontSize, fontSize + "px"]; + } + const fontSizeNumber = parseInt(fontSize ?? "", 10); + if (Number.isNaN(fontSizeNumber)) { + return [void 0, void 0]; + } else if (fontSize === String(fontSizeNumber)) { + return [fontSizeNumber, fontSize + "px"]; + } else { + return [fontSizeNumber, fontSize]; + } +}; +function cleanAndMerge(defaultData, data) { + return merge$2({}, defaultData, data); +} +const utils = { + assignWithDepth: assignWithDepth$1, + wrapLabel, + calculateTextHeight, + calculateTextWidth, + calculateTextDimensions, + cleanAndMerge, + detectInit, + detectDirective, + isSubstringInArray, + interpolateToCurve, + calcLabelPosition, + calcCardinalityPosition, + calcTerminalLabelPosition, + formatUrl, + getStylesFromArray, + generateId, + random, + runFunc, + entityDecode, + insertTitle, + parseFontSize, + InitIDGenerator +}; +const encodeEntities = function(text2) { + let txt = text2; + txt = txt.replace(/style.*:\S*#.*;/g, function(s) { + return s.substring(0, s.length - 1); + }); + txt = txt.replace(/classDef.*:\S*#.*;/g, function(s) { + return s.substring(0, s.length - 1); + }); + txt = txt.replace(/#\w+;/g, function(s) { + const innerTxt = s.substring(1, s.length - 1); + const isInt = /^\+?\d+$/.test(innerTxt); + if (isInt) { + return "fl°°" + innerTxt + "¶ß"; + } else { + return "fl°" + innerTxt + "¶ß"; + } + }); + return txt; +}; +const decodeEntities = function(text2) { + return text2.replace(/fl°°/g, "&#").replace(/fl°/g, "&").replace(/¶ß/g, ";"); +}; +var COMMENT = "comm"; +var RULESET = "rule"; +var DECLARATION = "decl"; +var IMPORT = "@import"; +var KEYFRAMES = "@keyframes"; +var LAYER = "@layer"; +var abs = Math.abs; +var from = String.fromCharCode; +function trim(value) { + return value.trim(); +} +function replace(value, pattern, replacement) { + return value.replace(pattern, replacement); +} +function indexof(value, search, position2) { + return value.indexOf(search, position2); +} +function charat(value, index) { + return value.charCodeAt(index) | 0; +} +function substr(value, begin, end) { + return value.slice(begin, end); +} +function strlen(value) { + return value.length; +} +function sizeof(value) { + return value.length; +} +function append(value, array2) { + return array2.push(value), value; +} +var line = 1; +var column = 1; +var length = 0; +var position = 0; +var character = 0; +var characters = ""; +function node(value, root2, parent, type2, props, children2, length2, siblings) { + return { value, root: root2, parent, type: type2, props, children: children2, line, column, length: length2, return: "", siblings }; +} +function char() { + return character; +} +function prev() { + character = position > 0 ? charat(characters, --position) : 0; + if (column--, character === 10) + column = 1, line--; + return character; +} +function next() { + character = position < length ? charat(characters, position++) : 0; + if (column++, character === 10) + column = 1, line++; + return character; +} +function peek() { + return charat(characters, position); +} +function caret() { + return position; +} +function slice(begin, end) { + return substr(characters, begin, end); +} +function token(type2) { + switch (type2) { + case 0: + case 9: + case 10: + case 13: + case 32: + return 5; + case 33: + case 43: + case 44: + case 47: + case 62: + case 64: + case 126: + case 59: + case 123: + case 125: + return 4; + case 58: + return 3; + case 34: + case 39: + case 40: + case 91: + return 2; + case 41: + case 93: + return 1; + } + return 0; +} +function alloc(value) { + return line = column = 1, length = strlen(characters = value), position = 0, []; +} +function dealloc(value) { + return characters = "", value; +} +function delimit(type2) { + return trim(slice(position - 1, delimiter(type2 === 91 ? type2 + 2 : type2 === 40 ? type2 + 1 : type2))); +} +function whitespace(type2) { + while (character = peek()) + if (character < 33) + next(); + else + break; + return token(type2) > 2 || token(character) > 3 ? "" : " "; +} +function escaping(index, count) { + while (--count && next()) + if (character < 48 || character > 102 || character > 57 && character < 65 || character > 70 && character < 97) + break; + return slice(index, caret() + (count < 6 && peek() == 32 && next() == 32)); +} +function delimiter(type2) { + while (next()) + switch (character) { + case type2: + return position; + case 34: + case 39: + if (type2 !== 34 && type2 !== 39) + delimiter(character); + break; + case 40: + if (type2 === 41) + delimiter(type2); + break; + case 92: + next(); + break; + } + return position; +} +function commenter(type2, index) { + while (next()) + if (type2 + character === 47 + 10) + break; + else if (type2 + character === 42 + 42 && peek() === 47) + break; + return "/*" + slice(index, position - 1) + "*" + from(type2 === 47 ? type2 : next()); +} +function identifier(index) { + while (!token(peek())) + next(); + return slice(index, position); +} +function compile(value) { + return dealloc(parse$2("", null, null, null, [""], value = alloc(value), 0, [0], value)); +} +function parse$2(value, root2, parent, rule, rules, rulesets, pseudo, points, declarations) { + var index = 0; + var offset = 0; + var length2 = pseudo; + var atrule = 0; + var property = 0; + var previous = 0; + var variable = 1; + var scanning = 1; + var ampersand = 1; + var character2 = 0; + var type2 = ""; + var props = rules; + var children2 = rulesets; + var reference = rule; + var characters2 = type2; + while (scanning) + switch (previous = character2, character2 = next()) { + case 40: + if (previous != 108 && charat(characters2, length2 - 1) == 58) { + if (indexof(characters2 += replace(delimit(character2), "&", "&\f"), "&\f", abs(index ? points[index - 1] : 0)) != -1) + ampersand = -1; + break; + } + case 34: + case 39: + case 91: + characters2 += delimit(character2); + break; + case 9: + case 10: + case 13: + case 32: + characters2 += whitespace(previous); + break; + case 92: + characters2 += escaping(caret() - 1, 7); + continue; + case 47: + switch (peek()) { + case 42: + case 47: + append(comment(commenter(next(), caret()), root2, parent, declarations), declarations); + break; + default: + characters2 += "/"; + } + break; + case 123 * variable: + points[index++] = strlen(characters2) * ampersand; + case 125 * variable: + case 59: + case 0: + switch (character2) { + case 0: + case 125: + scanning = 0; + case 59 + offset: + if (ampersand == -1) + characters2 = replace(characters2, /\f/g, ""); + if (property > 0 && strlen(characters2) - length2) + append(property > 32 ? declaration(characters2 + ";", rule, parent, length2 - 1, declarations) : declaration(replace(characters2, " ", "") + ";", rule, parent, length2 - 2, declarations), declarations); + break; + case 59: + characters2 += ";"; + default: + append(reference = ruleset(characters2, root2, parent, index, offset, rules, points, type2, props = [], children2 = [], length2, rulesets), rulesets); + if (character2 === 123) + if (offset === 0) + parse$2(characters2, root2, reference, reference, props, rulesets, length2, points, children2); + else + switch (atrule === 99 && charat(characters2, 3) === 110 ? 100 : atrule) { + case 100: + case 108: + case 109: + case 115: + parse$2(value, reference, reference, rule && append(ruleset(value, reference, reference, 0, 0, rules, points, type2, rules, props = [], length2, children2), children2), rules, children2, length2, points, rule ? props : children2); + break; + default: + parse$2(characters2, reference, reference, reference, [""], children2, 0, points, children2); + } + } + index = offset = property = 0, variable = ampersand = 1, type2 = characters2 = "", length2 = pseudo; + break; + case 58: + length2 = 1 + strlen(characters2), property = previous; + default: + if (variable < 1) { + if (character2 == 123) + --variable; + else if (character2 == 125 && variable++ == 0 && prev() == 125) + continue; + } + switch (characters2 += from(character2), character2 * variable) { + case 38: + ampersand = offset > 0 ? 1 : (characters2 += "\f", -1); + break; + case 44: + points[index++] = (strlen(characters2) - 1) * ampersand, ampersand = 1; + break; + case 64: + if (peek() === 45) + characters2 += delimit(next()); + atrule = peek(), offset = length2 = strlen(type2 = characters2 += identifier(caret())), character2++; + break; + case 45: + if (previous === 45 && strlen(characters2) == 2) + variable = 0; + } + } + return rulesets; +} +function ruleset(value, root2, parent, index, offset, rules, points, type2, props, children2, length2, siblings) { + var post = offset - 1; + var rule = offset === 0 ? rules : [""]; + var size = sizeof(rule); + for (var i = 0, j = 0, k = 0; i < index; ++i) + for (var x = 0, y = substr(value, post + 1, post = abs(j = points[i])), z = value; x < size; ++x) + if (z = trim(j > 0 ? rule[x] + " " + y : replace(y, /&\f/g, rule[x]))) + props[k++] = z; + return node(value, root2, parent, offset === 0 ? RULESET : type2, props, children2, length2, siblings); +} +function comment(value, root2, parent, siblings) { + return node(value, root2, parent, COMMENT, from(char()), substr(value, 2, -2), 0, siblings); +} +function declaration(value, root2, parent, length2, siblings) { + return node(value, root2, parent, DECLARATION, substr(value, 0, length2), substr(value, length2 + 1, -1), length2, siblings); +} +function serialize(children2, callback) { + var output = ""; + for (var i = 0; i < children2.length; i++) + output += callback(children2[i], i, children2, callback) || ""; + return output; +} +function stringify(element, index, children2, callback) { + switch (element.type) { + case LAYER: + if (element.children.length) + break; + case IMPORT: + case DECLARATION: + return element.return = element.return || element.value; + case COMMENT: + return ""; + case KEYFRAMES: + return element.return = element.value + "{" + serialize(element.children, callback) + "}"; + case RULESET: + if (!strlen(element.value = element.props.join(","))) + return ""; + } + return strlen(children2 = serialize(element.children, callback)) ? element.return = element.value + "{" + children2 + "}" : ""; +} +const version = "10.9.1"; +const defaultConfig$1 = Object.freeze(defaultConfig$2); +let siteConfig = assignWithDepth$1({}, defaultConfig$1); +let configFromInitialize; +let directives = []; +let currentConfig = assignWithDepth$1({}, defaultConfig$1); +const updateCurrentConfig = (siteCfg, _directives) => { + let cfg = assignWithDepth$1({}, siteCfg); + let sumOfDirectives = {}; + for (const d of _directives) { + sanitize(d); + sumOfDirectives = assignWithDepth$1(sumOfDirectives, d); + } + cfg = assignWithDepth$1(cfg, sumOfDirectives); + if (sumOfDirectives.theme && sumOfDirectives.theme in theme) { + const tmpConfigFromInitialize = assignWithDepth$1({}, configFromInitialize); + const themeVariables = assignWithDepth$1( + tmpConfigFromInitialize.themeVariables || {}, + sumOfDirectives.themeVariables + ); + if (cfg.theme && cfg.theme in theme) { + cfg.themeVariables = theme[cfg.theme].getThemeVariables(themeVariables); + } + } + currentConfig = cfg; + checkConfig(currentConfig); + return currentConfig; +}; +const setSiteConfig = (conf) => { + siteConfig = assignWithDepth$1({}, defaultConfig$1); + siteConfig = assignWithDepth$1(siteConfig, conf); + if (conf.theme && theme[conf.theme]) { + siteConfig.themeVariables = theme[conf.theme].getThemeVariables(conf.themeVariables); + } + updateCurrentConfig(siteConfig, directives); + return siteConfig; +}; +const saveConfigFromInitialize = (conf) => { + configFromInitialize = assignWithDepth$1({}, conf); +}; +const updateSiteConfig = (conf) => { + siteConfig = assignWithDepth$1(siteConfig, conf); + updateCurrentConfig(siteConfig, directives); + return siteConfig; +}; +const getSiteConfig = () => { + return assignWithDepth$1({}, siteConfig); +}; +const setConfig$1 = (conf) => { + checkConfig(conf); + assignWithDepth$1(currentConfig, conf); + return getConfig$1(); +}; +const getConfig$1 = () => { + return assignWithDepth$1({}, currentConfig); +}; +const sanitize = (options) => { + if (!options) { + return; + } + ["secure", ...siteConfig.secure ?? []].forEach((key) => { + if (Object.hasOwn(options, key)) { + log$1.debug(`Denied attempt to modify a secure key ${key}`, options[key]); + delete options[key]; + } + }); + Object.keys(options).forEach((key) => { + if (key.startsWith("__")) { + delete options[key]; + } + }); + Object.keys(options).forEach((key) => { + if (typeof options[key] === "string" && (options[key].includes("<") || options[key].includes(">") || options[key].includes("url(data:"))) { + delete options[key]; + } + if (typeof options[key] === "object") { + sanitize(options[key]); + } + }); +}; +const addDirective = (directive) => { + sanitizeDirective(directive); + if (directive.fontFamily && (!directive.themeVariables || !directive.themeVariables.fontFamily)) { + directive.themeVariables = { fontFamily: directive.fontFamily }; + } + directives.push(directive); + updateCurrentConfig(siteConfig, directives); +}; +const reset = (config2 = siteConfig) => { + directives = []; + updateCurrentConfig(config2, directives); +}; +const ConfigWarning = { + LAZY_LOAD_DEPRECATED: "The configuration options lazyLoadedDiagrams and loadExternalDiagramsAtStartup are deprecated. Please use registerExternalDiagrams instead." +}; +const issuedWarnings = {}; +const issueWarning = (warning) => { + if (issuedWarnings[warning]) { + return; + } + log$1.warn(ConfigWarning[warning]); + issuedWarnings[warning] = true; +}; +const checkConfig = (config2) => { + if (!config2) { + return; + } + if (config2.lazyLoadedDiagrams || config2.loadExternalDiagramsAtStartup) { + issueWarning("LAZY_LOAD_DEPRECATED"); + } +}; +const id$l = "c4"; +const detector$l = (txt) => { + return /^\s*C4Context|C4Container|C4Component|C4Dynamic|C4Deployment/.test(txt); +}; +const loader$m = async () => { + const { diagram: diagram2 } = await import("./c4Diagram-af207393.js"); + return { id: id$l, diagram: diagram2 }; +}; +const plugin$j = { + id: id$l, + detector: detector$l, + loader: loader$m +}; +const c4 = plugin$j; +const id$k = "flowchart"; +const detector$k = (txt, config2) => { + var _a, _b; + if (((_a = config2 == null ? void 0 : config2.flowchart) == null ? void 0 : _a.defaultRenderer) === "dagre-wrapper" || ((_b = config2 == null ? void 0 : config2.flowchart) == null ? void 0 : _b.defaultRenderer) === "elk") { + return false; + } + return /^\s*graph/.test(txt); +}; +const loader$l = async () => { + const { diagram: diagram2 } = await import("./flowDiagram-b5e7ba30.js"); + return { id: id$k, diagram: diagram2 }; +}; +const plugin$i = { + id: id$k, + detector: detector$k, + loader: loader$l +}; +const flowchart = plugin$i; +const id$j = "flowchart-v2"; +const detector$j = (txt, config2) => { + var _a, _b, _c; + if (((_a = config2 == null ? void 0 : config2.flowchart) == null ? void 0 : _a.defaultRenderer) === "dagre-d3" || ((_b = config2 == null ? void 0 : config2.flowchart) == null ? void 0 : _b.defaultRenderer) === "elk") { + return false; + } + if (/^\s*graph/.test(txt) && ((_c = config2 == null ? void 0 : config2.flowchart) == null ? void 0 : _c.defaultRenderer) === "dagre-wrapper") { + return true; + } + return /^\s*flowchart/.test(txt); +}; +const loader$k = async () => { + const { diagram: diagram2 } = await import("./flowDiagram-v2-54711e03.js"); + return { id: id$j, diagram: diagram2 }; +}; +const plugin$h = { + id: id$j, + detector: detector$j, + loader: loader$k +}; +const flowchartV2 = plugin$h; +const id$i = "er"; +const detector$i = (txt) => { + return /^\s*erDiagram/.test(txt); +}; +const loader$j = async () => { + const { diagram: diagram2 } = await import("./erDiagram-543717f2.js"); + return { id: id$i, diagram: diagram2 }; +}; +const plugin$g = { + id: id$i, + detector: detector$i, + loader: loader$j +}; +const er = plugin$g; +const id$h = "gitGraph"; +const detector$h = (txt) => { + return /^\s*gitGraph/.test(txt); +}; +const loader$i = async () => { + const { diagram: diagram2 } = await import("./gitGraphDiagram-b9392a12.js"); + return { id: id$h, diagram: diagram2 }; +}; +const plugin$f = { + id: id$h, + detector: detector$h, + loader: loader$i +}; +const git = plugin$f; +const id$g = "gantt"; +const detector$g = (txt) => { + return /^\s*gantt/.test(txt); +}; +const loader$h = async () => { + const { diagram: diagram2 } = await import("./ganttDiagram-12cf43db.js"); + return { id: id$g, diagram: diagram2 }; +}; +const plugin$e = { + id: id$g, + detector: detector$g, + loader: loader$h +}; +const gantt = plugin$e; +const id$f = "info"; +const detector$f = (txt) => { + return /^\s*info/.test(txt); +}; +const loader$g = async () => { + const { diagram: diagram2 } = await import("./infoDiagram-d0d5c9bd.js"); + return { id: id$f, diagram: diagram2 }; +}; +const info = { + id: id$f, + detector: detector$f, + loader: loader$g +}; +const id$e = "pie"; +const detector$e = (txt) => { + return /^\s*pie/.test(txt); +}; +const loader$f = async () => { + const { diagram: diagram2 } = await import("./pieDiagram-e854eaf0.js"); + return { id: id$e, diagram: diagram2 }; +}; +const pie = { + id: id$e, + detector: detector$e, + loader: loader$f +}; +const id$d = "quadrantChart"; +const detector$d = (txt) => { + return /^\s*quadrantChart/.test(txt); +}; +const loader$e = async () => { + const { diagram: diagram2 } = await import("./quadrantDiagram-25a9848b.js"); + return { id: id$d, diagram: diagram2 }; +}; +const plugin$d = { + id: id$d, + detector: detector$d, + loader: loader$e +}; +const quadrantChart = plugin$d; +const id$c = "xychart"; +const detector$c = (txt) => { + return /^\s*xychart-beta/.test(txt); +}; +const loader$d = async () => { + const { diagram: diagram2 } = await import("./xychartDiagram-de2e5521.js"); + return { id: id$c, diagram: diagram2 }; +}; +const plugin$c = { + id: id$c, + detector: detector$c, + loader: loader$d +}; +const xychart = plugin$c; +const id$b = "requirement"; +const detector$b = (txt) => { + return /^\s*requirement(Diagram)?/.test(txt); +}; +const loader$c = async () => { + const { diagram: diagram2 } = await import("./requirementDiagram-a721e157.js"); + return { id: id$b, diagram: diagram2 }; +}; +const plugin$b = { + id: id$b, + detector: detector$b, + loader: loader$c +}; +const requirement = plugin$b; +const id$a = "sequence"; +const detector$a = (txt) => { + return /^\s*sequenceDiagram/.test(txt); +}; +const loader$b = async () => { + const { diagram: diagram2 } = await import("./sequenceDiagram-9813c129.js"); + return { id: id$a, diagram: diagram2 }; +}; +const plugin$a = { + id: id$a, + detector: detector$a, + loader: loader$b +}; +const sequence = plugin$a; +const id$9 = "class"; +const detector$9 = (txt, config2) => { + var _a; + if (((_a = config2 == null ? void 0 : config2.class) == null ? void 0 : _a.defaultRenderer) === "dagre-wrapper") { + return false; + } + return /^\s*classDiagram/.test(txt); +}; +const loader$a = async () => { + const { diagram: diagram2 } = await import("./classDiagram-72b9c71d.js"); + return { id: id$9, diagram: diagram2 }; +}; +const plugin$9 = { + id: id$9, + detector: detector$9, + loader: loader$a +}; +const classDiagram = plugin$9; +const id$8 = "classDiagram"; +const detector$8 = (txt, config2) => { + var _a; + if (/^\s*classDiagram/.test(txt) && ((_a = config2 == null ? void 0 : config2.class) == null ? void 0 : _a.defaultRenderer) === "dagre-wrapper") { + return true; + } + return /^\s*classDiagram-v2/.test(txt); +}; +const loader$9 = async () => { + const { diagram: diagram2 } = await import("./classDiagram-v2-fedb80f6.js"); + return { id: id$8, diagram: diagram2 }; +}; +const plugin$8 = { + id: id$8, + detector: detector$8, + loader: loader$9 +}; +const classDiagramV2 = plugin$8; +const id$7 = "state"; +const detector$7 = (txt, config2) => { + var _a; + if (((_a = config2 == null ? void 0 : config2.state) == null ? void 0 : _a.defaultRenderer) === "dagre-wrapper") { + return false; + } + return /^\s*stateDiagram/.test(txt); +}; +const loader$8 = async () => { + const { diagram: diagram2 } = await import("./stateDiagram-5ec31577.js"); + return { id: id$7, diagram: diagram2 }; +}; +const plugin$7 = { + id: id$7, + detector: detector$7, + loader: loader$8 +}; +const state = plugin$7; +const id$6 = "stateDiagram"; +const detector$6 = (txt, config2) => { + var _a; + if (/^\s*stateDiagram-v2/.test(txt)) { + return true; + } + if (/^\s*stateDiagram/.test(txt) && ((_a = config2 == null ? void 0 : config2.state) == null ? void 0 : _a.defaultRenderer) === "dagre-wrapper") { + return true; + } + return false; +}; +const loader$7 = async () => { + const { diagram: diagram2 } = await import("./stateDiagram-v2-992e82a1.js"); + return { id: id$6, diagram: diagram2 }; +}; +const plugin$6 = { + id: id$6, + detector: detector$6, + loader: loader$7 +}; +const stateV2 = plugin$6; +const id$5 = "journey"; +const detector$5 = (txt) => { + return /^\s*journey/.test(txt); +}; +const loader$6 = async () => { + const { diagram: diagram2 } = await import("./journeyDiagram-b56e6921.js"); + return { id: id$5, diagram: diagram2 }; +}; +const plugin$5 = { + id: id$5, + detector: detector$5, + loader: loader$6 +}; +const journey = plugin$5; +const d3Attrs = function(d3Elem, attrs) { + for (let attr of attrs) { + d3Elem.attr(attr[0], attr[1]); + } +}; +const calculateSvgSizeAttrs = function(height, width, useMaxWidth) { + let attrs = /* @__PURE__ */ new Map(); + if (useMaxWidth) { + attrs.set("width", "100%"); + attrs.set("style", `max-width: ${width}px;`); + } else { + attrs.set("height", height); + attrs.set("width", width); + } + return attrs; +}; +const configureSvgSize = function(svgElem, height, width, useMaxWidth) { + const attrs = calculateSvgSizeAttrs(height, width, useMaxWidth); + d3Attrs(svgElem, attrs); +}; +const setupGraphViewbox$1 = function(graph, svgElem, padding, useMaxWidth) { + const svgBounds = svgElem.node().getBBox(); + const sWidth = svgBounds.width; + const sHeight = svgBounds.height; + log$1.info(`SVG bounds: ${sWidth}x${sHeight}`, svgBounds); + let width = 0; + let height = 0; + log$1.info(`Graph bounds: ${width}x${height}`, graph); + width = sWidth + padding * 2; + height = sHeight + padding * 2; + log$1.info(`Calculated bounds: ${width}x${height}`); + configureSvgSize(svgElem, height, width, useMaxWidth); + const vBox = `${svgBounds.x - padding} ${svgBounds.y - padding} ${svgBounds.width + 2 * padding} ${svgBounds.height + 2 * padding}`; + svgElem.attr("viewBox", vBox); +}; +const themes = {}; +const getStyles = (type2, userStyles, options) => { + let diagramStyles = ""; + if (type2 in themes && themes[type2]) { + diagramStyles = themes[type2](options); + } else { + log$1.warn(`No theme found for ${type2}`); + } + return ` & { + font-family: ${options.fontFamily}; + font-size: ${options.fontSize}; + fill: ${options.textColor} + } + + /* Classes common for multiple diagrams */ + + & .error-icon { + fill: ${options.errorBkgColor}; + } + & .error-text { + fill: ${options.errorTextColor}; + stroke: ${options.errorTextColor}; + } + + & .edge-thickness-normal { + stroke-width: 2px; + } + & .edge-thickness-thick { + stroke-width: 3.5px + } + & .edge-pattern-solid { + stroke-dasharray: 0; + } + + & .edge-pattern-dashed{ + stroke-dasharray: 3; + } + .edge-pattern-dotted { + stroke-dasharray: 2; + } + + & .marker { + fill: ${options.lineColor}; + stroke: ${options.lineColor}; + } + & .marker.cross { + stroke: ${options.lineColor}; + } + + & svg { + font-family: ${options.fontFamily}; + font-size: ${options.fontSize}; + } + + ${diagramStyles} + + ${userStyles} +`; +}; +const addStylesForDiagram = (type2, diagramTheme) => { + if (diagramTheme !== void 0) { + themes[type2] = diagramTheme; + } +}; +const getStyles$1 = getStyles; +let accTitle = ""; +let diagramTitle = ""; +let accDescription = ""; +const sanitizeText$1 = (txt) => sanitizeText$2(txt, getConfig$1()); +const clear = () => { + accTitle = ""; + accDescription = ""; + diagramTitle = ""; +}; +const setAccTitle = (txt) => { + accTitle = sanitizeText$1(txt).replace(/^\s+/g, ""); +}; +const getAccTitle = () => accTitle; +const setAccDescription = (txt) => { + accDescription = sanitizeText$1(txt).replace(/\n\s+/g, "\n"); +}; +const getAccDescription = () => accDescription; +const setDiagramTitle = (txt) => { + diagramTitle = sanitizeText$1(txt); +}; +const getDiagramTitle = () => diagramTitle; +const commonDb = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + clear, + getAccDescription, + getAccTitle, + getDiagramTitle, + setAccDescription, + setAccTitle, + setDiagramTitle +}, Symbol.toStringTag, { value: "Module" })); +const log = log$1; +const setLogLevel = setLogLevel$1; +const getConfig = getConfig$1; +const setConfig = setConfig$1; +const defaultConfig = defaultConfig$1; +const sanitizeText = (text2) => sanitizeText$2(text2, getConfig()); +const setupGraphViewbox = setupGraphViewbox$1; +const getCommonDb = () => { + return commonDb; +}; +const diagrams = {}; +const registerDiagram = (id2, diagram2, detector2) => { + var _a; + if (diagrams[id2]) { + throw new Error(`Diagram ${id2} already registered.`); + } + diagrams[id2] = diagram2; + if (detector2) { + addDetector(id2, detector2); + } + addStylesForDiagram(id2, diagram2.styles); + (_a = diagram2.injectUtils) == null ? void 0 : _a.call( + diagram2, + log, + setLogLevel, + getConfig, + sanitizeText, + setupGraphViewbox, + getCommonDb(), + () => { + } + ); +}; +const getDiagram = (name) => { + if (name in diagrams) { + return diagrams[name]; + } + throw new DiagramNotFoundError(name); +}; +class DiagramNotFoundError extends Error { + constructor(name) { + super(`Diagram ${name} not found.`); + } +} +const selectSvgElement = (id2) => { + var _a; + const { securityLevel } = getConfig(); + let root2 = d3select("body"); + if (securityLevel === "sandbox") { + const sandboxElement = d3select(`#i${id2}`); + const doc = ((_a = sandboxElement.node()) == null ? void 0 : _a.contentDocument) ?? document; + root2 = d3select(doc.body); + } + const svg2 = root2.select(`#${id2}`); + return svg2; +}; +const draw = (_text, id2, version2) => { + log$1.debug("rendering svg for syntax error\n"); + const svg2 = selectSvgElement(id2); + const g = svg2.append("g"); + svg2.attr("viewBox", "0 0 2412 512"); + configureSvgSize(svg2, 100, 512, true); + g.append("path").attr("class", "error-icon").attr( + "d", + "m411.313,123.313c6.25-6.25 6.25-16.375 0-22.625s-16.375-6.25-22.625,0l-32,32-9.375,9.375-20.688-20.688c-12.484-12.5-32.766-12.5-45.25,0l-16,16c-1.261,1.261-2.304,2.648-3.31,4.051-21.739-8.561-45.324-13.426-70.065-13.426-105.867,0-192,86.133-192,192s86.133,192 192,192 192-86.133 192-192c0-24.741-4.864-48.327-13.426-70.065 1.402-1.007 2.79-2.049 4.051-3.31l16-16c12.5-12.492 12.5-32.758 0-45.25l-20.688-20.688 9.375-9.375 32.001-31.999zm-219.313,100.687c-52.938,0-96,43.063-96,96 0,8.836-7.164,16-16,16s-16-7.164-16-16c0-70.578 57.422-128 128-128 8.836,0 16,7.164 16,16s-7.164,16-16,16z" + ); + g.append("path").attr("class", "error-icon").attr( + "d", + "m459.02,148.98c-6.25-6.25-16.375-6.25-22.625,0s-6.25,16.375 0,22.625l16,16c3.125,3.125 7.219,4.688 11.313,4.688 4.094,0 8.188-1.563 11.313-4.688 6.25-6.25 6.25-16.375 0-22.625l-16.001-16z" + ); + g.append("path").attr("class", "error-icon").attr( + "d", + "m340.395,75.605c3.125,3.125 7.219,4.688 11.313,4.688 4.094,0 8.188-1.563 11.313-4.688 6.25-6.25 6.25-16.375 0-22.625l-16-16c-6.25-6.25-16.375-6.25-22.625,0s-6.25,16.375 0,22.625l15.999,16z" + ); + g.append("path").attr("class", "error-icon").attr( + "d", + "m400,64c8.844,0 16-7.164 16-16v-32c0-8.836-7.156-16-16-16-8.844,0-16,7.164-16,16v32c0,8.836 7.156,16 16,16z" + ); + g.append("path").attr("class", "error-icon").attr( + "d", + "m496,96.586h-32c-8.844,0-16,7.164-16,16 0,8.836 7.156,16 16,16h32c8.844,0 16-7.164 16-16 0-8.836-7.156-16-16-16z" + ); + g.append("path").attr("class", "error-icon").attr( + "d", + "m436.98,75.605c3.125,3.125 7.219,4.688 11.313,4.688 4.094,0 8.188-1.563 11.313-4.688l32-32c6.25-6.25 6.25-16.375 0-22.625s-16.375-6.25-22.625,0l-32,32c-6.251,6.25-6.251,16.375-0.001,22.625z" + ); + g.append("text").attr("class", "error-text").attr("x", 1440).attr("y", 250).attr("font-size", "150px").style("text-anchor", "middle").text("Syntax error in text"); + g.append("text").attr("class", "error-text").attr("x", 1250).attr("y", 400).attr("font-size", "100px").style("text-anchor", "middle").text(`mermaid version ${version2}`); +}; +const renderer = { draw }; +const errorRenderer = renderer; +const diagram = { + db: {}, + renderer, + parser: { + parser: { yy: {} }, + parse: () => { + return; + } + } +}; +const errorDiagram = diagram; +const id$4 = "flowchart-elk"; +const detector$4 = (txt, config2) => { + var _a; + if ( + // If diagram explicitly states flowchart-elk + /^\s*flowchart-elk/.test(txt) || // If a flowchart/graph diagram has their default renderer set to elk + /^\s*flowchart|graph/.test(txt) && ((_a = config2 == null ? void 0 : config2.flowchart) == null ? void 0 : _a.defaultRenderer) === "elk" + ) { + return true; + } + return false; +}; +const loader$5 = async () => { + const { diagram: diagram2 } = await import("./flowchart-elk-definition-2d49707c.js"); + return { id: id$4, diagram: diagram2 }; +}; +const plugin$4 = { + id: id$4, + detector: detector$4, + loader: loader$5 +}; +const flowchartElk = plugin$4; +const id$3 = "timeline"; +const detector$3 = (txt) => { + return /^\s*timeline/.test(txt); +}; +const loader$4 = async () => { + const { diagram: diagram2 } = await import("./timeline-definition-23ce0e2e.js"); + return { id: id$3, diagram: diagram2 }; +}; +const plugin$3 = { + id: id$3, + detector: detector$3, + loader: loader$4 +}; +const timeline = plugin$3; +const id$2 = "mindmap"; +const detector$2 = (txt) => { + return /^\s*mindmap/.test(txt); +}; +const loader$3 = async () => { + const { diagram: diagram2 } = await import("./mindmap-definition-696ddea4.js"); + return { id: id$2, diagram: diagram2 }; +}; +const plugin$2 = { + id: id$2, + detector: detector$2, + loader: loader$3 +}; +const mindmap = plugin$2; +const id$1 = "sankey"; +const detector$1 = (txt) => { + return /^\s*sankey-beta/.test(txt); +}; +const loader$2 = async () => { + const { diagram: diagram2 } = await import("./sankeyDiagram-33525efb.js"); + return { id: id$1, diagram: diagram2 }; +}; +const plugin$1 = { + id: id$1, + detector: detector$1, + loader: loader$2 +}; +const sankey = plugin$1; +const id = "block"; +const detector = (txt) => { + return /^\s*block-beta/.test(txt); +}; +const loader$1 = async () => { + const { diagram: diagram2 } = await import("./blockDiagram-efe38566.js"); + return { id, diagram: diagram2 }; +}; +const plugin = { + id, + detector, + loader: loader$1 +}; +const block = plugin; +let hasLoadedDiagrams = false; +const addDiagrams = () => { + if (hasLoadedDiagrams) { + return; + } + hasLoadedDiagrams = true; + registerDiagram("error", errorDiagram, (text2) => { + return text2.toLowerCase().trim() === "error"; + }); + registerDiagram( + "---", + // --- diagram type may appear if YAML front-matter is not parsed correctly + { + db: { + clear: () => { + } + }, + styles: {}, + // should never be used + renderer: { + draw: () => { + } + }, + parser: { + parser: { yy: {} }, + parse: () => { + throw new Error( + "Diagrams beginning with --- are not valid. If you were trying to use a YAML front-matter, please ensure that you've correctly opened and closed the YAML front-matter with un-indented `---` blocks" + ); + } + }, + init: () => null + // no op + }, + (text2) => { + return text2.toLowerCase().trimStart().startsWith("---"); + } + ); + registerLazyLoadedDiagrams( + c4, + classDiagramV2, + classDiagram, + er, + gantt, + info, + pie, + requirement, + sequence, + flowchartElk, + flowchartV2, + flowchart, + mindmap, + timeline, + git, + stateV2, + state, + journey, + quadrantChart, + sankey, + xychart, + block + ); +}; +class Diagram { + constructor(text2, metadata = {}) { + this.text = text2; + this.metadata = metadata; + this.type = "graph"; + this.text = encodeEntities(text2); + this.text += "\n"; + const cnf = getConfig$1(); + try { + this.type = detectType(text2, cnf); + } catch (e) { + this.type = "error"; + this.detectError = e; + } + const diagram2 = getDiagram(this.type); + log$1.debug("Type " + this.type); + this.db = diagram2.db; + this.renderer = diagram2.renderer; + this.parser = diagram2.parser; + this.parser.parser.yy = this.db; + this.init = diagram2.init; + this.parse(); + } + parse() { + var _a, _b, _c, _d, _e; + if (this.detectError) { + throw this.detectError; + } + (_b = (_a = this.db).clear) == null ? void 0 : _b.call(_a); + const config2 = getConfig$1(); + (_c = this.init) == null ? void 0 : _c.call(this, config2); + if (this.metadata.title) { + (_e = (_d = this.db).setDiagramTitle) == null ? void 0 : _e.call(_d, this.metadata.title); + } + this.parser.parse(this.text); + } + async render(id2, version2) { + await this.renderer.draw(this.text, id2, version2, this); + } + getParser() { + return this.parser; + } + getType() { + return this.type; + } +} +const getDiagramFromText$1 = async (text2, metadata = {}) => { + const type2 = detectType(text2, getConfig$1()); + try { + getDiagram(type2); + } catch (error) { + const loader2 = getDiagramLoader(type2); + if (!loader2) { + throw new UnknownDiagramError(`Diagram ${type2} not found.`); + } + const { id: id2, diagram: diagram2 } = await loader2(); + registerDiagram(id2, diagram2); + } + return new Diagram(text2, metadata); +}; +let interactionFunctions = []; +const attachFunctions = () => { + interactionFunctions.forEach((f) => { + f(); + }); + interactionFunctions = []; +}; +var nativeKeys = overArg(Object.keys, Object); +const nativeKeys$1 = nativeKeys; +var objectProto$1 = Object.prototype; +var hasOwnProperty$1 = objectProto$1.hasOwnProperty; +function baseKeys(object) { + if (!isPrototype(object)) { + return nativeKeys$1(object); + } + var result = []; + for (var key in Object(object)) { + if (hasOwnProperty$1.call(object, key) && key != "constructor") { + result.push(key); + } + } + return result; +} +var DataView = getNative(root$1, "DataView"); +const DataView$1 = DataView; +var Promise$1 = getNative(root$1, "Promise"); +const Promise$2 = Promise$1; +var Set$1 = getNative(root$1, "Set"); +const Set$2 = Set$1; +var WeakMap = getNative(root$1, "WeakMap"); +const WeakMap$1 = WeakMap; +var mapTag$1 = "[object Map]", objectTag = "[object Object]", promiseTag = "[object Promise]", setTag$1 = "[object Set]", weakMapTag = "[object WeakMap]"; +var dataViewTag = "[object DataView]"; +var dataViewCtorString = toSource(DataView$1), mapCtorString = toSource(Map$2), promiseCtorString = toSource(Promise$2), setCtorString = toSource(Set$2), weakMapCtorString = toSource(WeakMap$1); +var getTag = baseGetTag; +if (DataView$1 && getTag(new DataView$1(new ArrayBuffer(1))) != dataViewTag || Map$2 && getTag(new Map$2()) != mapTag$1 || Promise$2 && getTag(Promise$2.resolve()) != promiseTag || Set$2 && getTag(new Set$2()) != setTag$1 || WeakMap$1 && getTag(new WeakMap$1()) != weakMapTag) { + getTag = function(value) { + var result = baseGetTag(value), Ctor = result == objectTag ? value.constructor : void 0, ctorString = Ctor ? toSource(Ctor) : ""; + if (ctorString) { + switch (ctorString) { + case dataViewCtorString: + return dataViewTag; + case mapCtorString: + return mapTag$1; + case promiseCtorString: + return promiseTag; + case setCtorString: + return setTag$1; + case weakMapCtorString: + return weakMapTag; + } + } + return result; + }; +} +const getTag$1 = getTag; +var mapTag = "[object Map]", setTag = "[object Set]"; +var objectProto = Object.prototype; +var hasOwnProperty = objectProto.hasOwnProperty; +function isEmpty(value) { + if (value == null) { + return true; + } + if (isArrayLike(value) && (isArray$1(value) || typeof value == "string" || typeof value.splice == "function" || isBuffer$1(value) || isTypedArray$1(value) || isArguments$1(value))) { + return !value.length; + } + var tag = getTag$1(value); + if (tag == mapTag || tag == setTag) { + return !value.size; + } + if (isPrototype(value)) { + return !baseKeys(value).length; + } + for (var key in value) { + if (hasOwnProperty.call(value, key)) { + return false; + } + } + return true; +} +const SVG_ROLE = "graphics-document document"; +function setA11yDiagramInfo(svg2, diagramType) { + svg2.attr("role", SVG_ROLE); + if (diagramType !== "") { + svg2.attr("aria-roledescription", diagramType); + } +} +function addSVGa11yTitleDescription(svg2, a11yTitle, a11yDesc, baseId) { + if (svg2.insert === void 0) { + return; + } + if (a11yDesc) { + const descId = `chart-desc-${baseId}`; + svg2.attr("aria-describedby", descId); + svg2.insert("desc", ":first-child").attr("id", descId).text(a11yDesc); + } + if (a11yTitle) { + const titleId = `chart-title-${baseId}`; + svg2.attr("aria-labelledby", titleId); + svg2.insert("title", ":first-child").attr("id", titleId).text(a11yTitle); + } +} +const cleanupComments = (text2) => { + return text2.replace(/^\s*%%(?!{)[^\n]+\n?/gm, "").trimStart(); +}; +/*! js-yaml 4.1.0 https://github.com/nodeca/js-yaml @license MIT */ +function isNothing(subject) { + return typeof subject === "undefined" || subject === null; +} +function isObject(subject) { + return typeof subject === "object" && subject !== null; +} +function toArray(sequence2) { + if (Array.isArray(sequence2)) + return sequence2; + else if (isNothing(sequence2)) + return []; + return [sequence2]; +} +function extend(target, source) { + var index, length2, key, sourceKeys; + if (source) { + sourceKeys = Object.keys(source); + for (index = 0, length2 = sourceKeys.length; index < length2; index += 1) { + key = sourceKeys[index]; + target[key] = source[key]; + } + } + return target; +} +function repeat(string, count) { + var result = "", cycle; + for (cycle = 0; cycle < count; cycle += 1) { + result += string; + } + return result; +} +function isNegativeZero(number) { + return number === 0 && Number.NEGATIVE_INFINITY === 1 / number; +} +var isNothing_1 = isNothing; +var isObject_1 = isObject; +var toArray_1 = toArray; +var repeat_1 = repeat; +var isNegativeZero_1 = isNegativeZero; +var extend_1 = extend; +var common = { + isNothing: isNothing_1, + isObject: isObject_1, + toArray: toArray_1, + repeat: repeat_1, + isNegativeZero: isNegativeZero_1, + extend: extend_1 +}; +function formatError(exception2, compact) { + var where = "", message = exception2.reason || "(unknown reason)"; + if (!exception2.mark) + return message; + if (exception2.mark.name) { + where += 'in "' + exception2.mark.name + '" '; + } + where += "(" + (exception2.mark.line + 1) + ":" + (exception2.mark.column + 1) + ")"; + if (!compact && exception2.mark.snippet) { + where += "\n\n" + exception2.mark.snippet; + } + return message + " " + where; +} +function YAMLException$1(reason, mark) { + Error.call(this); + this.name = "YAMLException"; + this.reason = reason; + this.mark = mark; + this.message = formatError(this, false); + if (Error.captureStackTrace) { + Error.captureStackTrace(this, this.constructor); + } else { + this.stack = new Error().stack || ""; + } +} +YAMLException$1.prototype = Object.create(Error.prototype); +YAMLException$1.prototype.constructor = YAMLException$1; +YAMLException$1.prototype.toString = function toString(compact) { + return this.name + ": " + formatError(this, compact); +}; +var exception = YAMLException$1; +function getLine(buffer, lineStart, lineEnd, position2, maxLineLength) { + var head = ""; + var tail = ""; + var maxHalfLength = Math.floor(maxLineLength / 2) - 1; + if (position2 - lineStart > maxHalfLength) { + head = " ... "; + lineStart = position2 - maxHalfLength + head.length; + } + if (lineEnd - position2 > maxHalfLength) { + tail = " ..."; + lineEnd = position2 + maxHalfLength - tail.length; + } + return { + str: head + buffer.slice(lineStart, lineEnd).replace(/\t/g, "→") + tail, + pos: position2 - lineStart + head.length + // relative position + }; +} +function padStart(string, max2) { + return common.repeat(" ", max2 - string.length) + string; +} +function makeSnippet(mark, options) { + options = Object.create(options || null); + if (!mark.buffer) + return null; + if (!options.maxLength) + options.maxLength = 79; + if (typeof options.indent !== "number") + options.indent = 1; + if (typeof options.linesBefore !== "number") + options.linesBefore = 3; + if (typeof options.linesAfter !== "number") + options.linesAfter = 2; + var re = /\r?\n|\r|\0/g; + var lineStarts = [0]; + var lineEnds = []; + var match; + var foundLineNo = -1; + while (match = re.exec(mark.buffer)) { + lineEnds.push(match.index); + lineStarts.push(match.index + match[0].length); + if (mark.position <= match.index && foundLineNo < 0) { + foundLineNo = lineStarts.length - 2; + } + } + if (foundLineNo < 0) + foundLineNo = lineStarts.length - 1; + var result = "", i, line2; + var lineNoLength = Math.min(mark.line + options.linesAfter, lineEnds.length).toString().length; + var maxLineLength = options.maxLength - (options.indent + lineNoLength + 3); + for (i = 1; i <= options.linesBefore; i++) { + if (foundLineNo - i < 0) + break; + line2 = getLine( + mark.buffer, + lineStarts[foundLineNo - i], + lineEnds[foundLineNo - i], + mark.position - (lineStarts[foundLineNo] - lineStarts[foundLineNo - i]), + maxLineLength + ); + result = common.repeat(" ", options.indent) + padStart((mark.line - i + 1).toString(), lineNoLength) + " | " + line2.str + "\n" + result; + } + line2 = getLine(mark.buffer, lineStarts[foundLineNo], lineEnds[foundLineNo], mark.position, maxLineLength); + result += common.repeat(" ", options.indent) + padStart((mark.line + 1).toString(), lineNoLength) + " | " + line2.str + "\n"; + result += common.repeat("-", options.indent + lineNoLength + 3 + line2.pos) + "^\n"; + for (i = 1; i <= options.linesAfter; i++) { + if (foundLineNo + i >= lineEnds.length) + break; + line2 = getLine( + mark.buffer, + lineStarts[foundLineNo + i], + lineEnds[foundLineNo + i], + mark.position - (lineStarts[foundLineNo] - lineStarts[foundLineNo + i]), + maxLineLength + ); + result += common.repeat(" ", options.indent) + padStart((mark.line + i + 1).toString(), lineNoLength) + " | " + line2.str + "\n"; + } + return result.replace(/\n$/, ""); +} +var snippet = makeSnippet; +var TYPE_CONSTRUCTOR_OPTIONS = [ + "kind", + "multi", + "resolve", + "construct", + "instanceOf", + "predicate", + "represent", + "representName", + "defaultStyle", + "styleAliases" +]; +var YAML_NODE_KINDS = [ + "scalar", + "sequence", + "mapping" +]; +function compileStyleAliases(map2) { + var result = {}; + if (map2 !== null) { + Object.keys(map2).forEach(function(style) { + map2[style].forEach(function(alias) { + result[String(alias)] = style; + }); + }); + } + return result; +} +function Type$1(tag, options) { + options = options || {}; + Object.keys(options).forEach(function(name) { + if (TYPE_CONSTRUCTOR_OPTIONS.indexOf(name) === -1) { + throw new exception('Unknown option "' + name + '" is met in definition of "' + tag + '" YAML type.'); + } + }); + this.options = options; + this.tag = tag; + this.kind = options["kind"] || null; + this.resolve = options["resolve"] || function() { + return true; + }; + this.construct = options["construct"] || function(data) { + return data; + }; + this.instanceOf = options["instanceOf"] || null; + this.predicate = options["predicate"] || null; + this.represent = options["represent"] || null; + this.representName = options["representName"] || null; + this.defaultStyle = options["defaultStyle"] || null; + this.multi = options["multi"] || false; + this.styleAliases = compileStyleAliases(options["styleAliases"] || null); + if (YAML_NODE_KINDS.indexOf(this.kind) === -1) { + throw new exception('Unknown kind "' + this.kind + '" is specified for "' + tag + '" YAML type.'); + } +} +var type = Type$1; +function compileList(schema2, name) { + var result = []; + schema2[name].forEach(function(currentType) { + var newIndex = result.length; + result.forEach(function(previousType, previousIndex) { + if (previousType.tag === currentType.tag && previousType.kind === currentType.kind && previousType.multi === currentType.multi) { + newIndex = previousIndex; + } + }); + result[newIndex] = currentType; + }); + return result; +} +function compileMap() { + var result = { + scalar: {}, + sequence: {}, + mapping: {}, + fallback: {}, + multi: { + scalar: [], + sequence: [], + mapping: [], + fallback: [] + } + }, index, length2; + function collectType(type2) { + if (type2.multi) { + result.multi[type2.kind].push(type2); + result.multi["fallback"].push(type2); + } else { + result[type2.kind][type2.tag] = result["fallback"][type2.tag] = type2; + } + } + for (index = 0, length2 = arguments.length; index < length2; index += 1) { + arguments[index].forEach(collectType); + } + return result; +} +function Schema$1(definition) { + return this.extend(definition); +} +Schema$1.prototype.extend = function extend2(definition) { + var implicit = []; + var explicit = []; + if (definition instanceof type) { + explicit.push(definition); + } else if (Array.isArray(definition)) { + explicit = explicit.concat(definition); + } else if (definition && (Array.isArray(definition.implicit) || Array.isArray(definition.explicit))) { + if (definition.implicit) + implicit = implicit.concat(definition.implicit); + if (definition.explicit) + explicit = explicit.concat(definition.explicit); + } else { + throw new exception("Schema.extend argument should be a Type, [ Type ], or a schema definition ({ implicit: [...], explicit: [...] })"); + } + implicit.forEach(function(type$1) { + if (!(type$1 instanceof type)) { + throw new exception("Specified list of YAML types (or a single Type object) contains a non-Type object."); + } + if (type$1.loadKind && type$1.loadKind !== "scalar") { + throw new exception("There is a non-scalar type in the implicit list of a schema. Implicit resolving of such types is not supported."); + } + if (type$1.multi) { + throw new exception("There is a multi type in the implicit list of a schema. Multi tags can only be listed as explicit."); + } + }); + explicit.forEach(function(type$1) { + if (!(type$1 instanceof type)) { + throw new exception("Specified list of YAML types (or a single Type object) contains a non-Type object."); + } + }); + var result = Object.create(Schema$1.prototype); + result.implicit = (this.implicit || []).concat(implicit); + result.explicit = (this.explicit || []).concat(explicit); + result.compiledImplicit = compileList(result, "implicit"); + result.compiledExplicit = compileList(result, "explicit"); + result.compiledTypeMap = compileMap(result.compiledImplicit, result.compiledExplicit); + return result; +}; +var schema = Schema$1; +var str = new type("tag:yaml.org,2002:str", { + kind: "scalar", + construct: function(data) { + return data !== null ? data : ""; + } +}); +var seq = new type("tag:yaml.org,2002:seq", { + kind: "sequence", + construct: function(data) { + return data !== null ? data : []; + } +}); +var map = new type("tag:yaml.org,2002:map", { + kind: "mapping", + construct: function(data) { + return data !== null ? data : {}; + } +}); +var failsafe = new schema({ + explicit: [ + str, + seq, + map + ] +}); +function resolveYamlNull(data) { + if (data === null) + return true; + var max2 = data.length; + return max2 === 1 && data === "~" || max2 === 4 && (data === "null" || data === "Null" || data === "NULL"); +} +function constructYamlNull() { + return null; +} +function isNull(object) { + return object === null; +} +var _null = new type("tag:yaml.org,2002:null", { + kind: "scalar", + resolve: resolveYamlNull, + construct: constructYamlNull, + predicate: isNull, + represent: { + canonical: function() { + return "~"; + }, + lowercase: function() { + return "null"; + }, + uppercase: function() { + return "NULL"; + }, + camelcase: function() { + return "Null"; + }, + empty: function() { + return ""; + } + }, + defaultStyle: "lowercase" +}); +function resolveYamlBoolean(data) { + if (data === null) + return false; + var max2 = data.length; + return max2 === 4 && (data === "true" || data === "True" || data === "TRUE") || max2 === 5 && (data === "false" || data === "False" || data === "FALSE"); +} +function constructYamlBoolean(data) { + return data === "true" || data === "True" || data === "TRUE"; +} +function isBoolean(object) { + return Object.prototype.toString.call(object) === "[object Boolean]"; +} +var bool = new type("tag:yaml.org,2002:bool", { + kind: "scalar", + resolve: resolveYamlBoolean, + construct: constructYamlBoolean, + predicate: isBoolean, + represent: { + lowercase: function(object) { + return object ? "true" : "false"; + }, + uppercase: function(object) { + return object ? "TRUE" : "FALSE"; + }, + camelcase: function(object) { + return object ? "True" : "False"; + } + }, + defaultStyle: "lowercase" +}); +function isHexCode(c) { + return 48 <= c && c <= 57 || 65 <= c && c <= 70 || 97 <= c && c <= 102; +} +function isOctCode(c) { + return 48 <= c && c <= 55; +} +function isDecCode(c) { + return 48 <= c && c <= 57; +} +function resolveYamlInteger(data) { + if (data === null) + return false; + var max2 = data.length, index = 0, hasDigits = false, ch; + if (!max2) + return false; + ch = data[index]; + if (ch === "-" || ch === "+") { + ch = data[++index]; + } + if (ch === "0") { + if (index + 1 === max2) + return true; + ch = data[++index]; + if (ch === "b") { + index++; + for (; index < max2; index++) { + ch = data[index]; + if (ch === "_") + continue; + if (ch !== "0" && ch !== "1") + return false; + hasDigits = true; + } + return hasDigits && ch !== "_"; + } + if (ch === "x") { + index++; + for (; index < max2; index++) { + ch = data[index]; + if (ch === "_") + continue; + if (!isHexCode(data.charCodeAt(index))) + return false; + hasDigits = true; + } + return hasDigits && ch !== "_"; + } + if (ch === "o") { + index++; + for (; index < max2; index++) { + ch = data[index]; + if (ch === "_") + continue; + if (!isOctCode(data.charCodeAt(index))) + return false; + hasDigits = true; + } + return hasDigits && ch !== "_"; + } + } + if (ch === "_") + return false; + for (; index < max2; index++) { + ch = data[index]; + if (ch === "_") + continue; + if (!isDecCode(data.charCodeAt(index))) { + return false; + } + hasDigits = true; + } + if (!hasDigits || ch === "_") + return false; + return true; +} +function constructYamlInteger(data) { + var value = data, sign2 = 1, ch; + if (value.indexOf("_") !== -1) { + value = value.replace(/_/g, ""); + } + ch = value[0]; + if (ch === "-" || ch === "+") { + if (ch === "-") + sign2 = -1; + value = value.slice(1); + ch = value[0]; + } + if (value === "0") + return 0; + if (ch === "0") { + if (value[1] === "b") + return sign2 * parseInt(value.slice(2), 2); + if (value[1] === "x") + return sign2 * parseInt(value.slice(2), 16); + if (value[1] === "o") + return sign2 * parseInt(value.slice(2), 8); + } + return sign2 * parseInt(value, 10); +} +function isInteger(object) { + return Object.prototype.toString.call(object) === "[object Number]" && (object % 1 === 0 && !common.isNegativeZero(object)); +} +var int = new type("tag:yaml.org,2002:int", { + kind: "scalar", + resolve: resolveYamlInteger, + construct: constructYamlInteger, + predicate: isInteger, + represent: { + binary: function(obj) { + return obj >= 0 ? "0b" + obj.toString(2) : "-0b" + obj.toString(2).slice(1); + }, + octal: function(obj) { + return obj >= 0 ? "0o" + obj.toString(8) : "-0o" + obj.toString(8).slice(1); + }, + decimal: function(obj) { + return obj.toString(10); + }, + /* eslint-disable max-len */ + hexadecimal: function(obj) { + return obj >= 0 ? "0x" + obj.toString(16).toUpperCase() : "-0x" + obj.toString(16).toUpperCase().slice(1); + } + }, + defaultStyle: "decimal", + styleAliases: { + binary: [2, "bin"], + octal: [8, "oct"], + decimal: [10, "dec"], + hexadecimal: [16, "hex"] + } +}); +var YAML_FLOAT_PATTERN = new RegExp( + // 2.5e4, 2.5 and integers + "^(?:[-+]?(?:[0-9][0-9_]*)(?:\\.[0-9_]*)?(?:[eE][-+]?[0-9]+)?|\\.[0-9_]+(?:[eE][-+]?[0-9]+)?|[-+]?\\.(?:inf|Inf|INF)|\\.(?:nan|NaN|NAN))$" +); +function resolveYamlFloat(data) { + if (data === null) + return false; + if (!YAML_FLOAT_PATTERN.test(data) || // Quick hack to not allow integers end with `_` + // Probably should update regexp & check speed + data[data.length - 1] === "_") { + return false; + } + return true; +} +function constructYamlFloat(data) { + var value, sign2; + value = data.replace(/_/g, "").toLowerCase(); + sign2 = value[0] === "-" ? -1 : 1; + if ("+-".indexOf(value[0]) >= 0) { + value = value.slice(1); + } + if (value === ".inf") { + return sign2 === 1 ? Number.POSITIVE_INFINITY : Number.NEGATIVE_INFINITY; + } else if (value === ".nan") { + return NaN; + } + return sign2 * parseFloat(value, 10); +} +var SCIENTIFIC_WITHOUT_DOT = /^[-+]?[0-9]+e/; +function representYamlFloat(object, style) { + var res; + if (isNaN(object)) { + switch (style) { + case "lowercase": + return ".nan"; + case "uppercase": + return ".NAN"; + case "camelcase": + return ".NaN"; + } + } else if (Number.POSITIVE_INFINITY === object) { + switch (style) { + case "lowercase": + return ".inf"; + case "uppercase": + return ".INF"; + case "camelcase": + return ".Inf"; + } + } else if (Number.NEGATIVE_INFINITY === object) { + switch (style) { + case "lowercase": + return "-.inf"; + case "uppercase": + return "-.INF"; + case "camelcase": + return "-.Inf"; + } + } else if (common.isNegativeZero(object)) { + return "-0.0"; + } + res = object.toString(10); + return SCIENTIFIC_WITHOUT_DOT.test(res) ? res.replace("e", ".e") : res; +} +function isFloat(object) { + return Object.prototype.toString.call(object) === "[object Number]" && (object % 1 !== 0 || common.isNegativeZero(object)); +} +var float = new type("tag:yaml.org,2002:float", { + kind: "scalar", + resolve: resolveYamlFloat, + construct: constructYamlFloat, + predicate: isFloat, + represent: representYamlFloat, + defaultStyle: "lowercase" +}); +var json = failsafe.extend({ + implicit: [ + _null, + bool, + int, + float + ] +}); +var core = json; +var YAML_DATE_REGEXP = new RegExp( + "^([0-9][0-9][0-9][0-9])-([0-9][0-9])-([0-9][0-9])$" +); +var YAML_TIMESTAMP_REGEXP = new RegExp( + "^([0-9][0-9][0-9][0-9])-([0-9][0-9]?)-([0-9][0-9]?)(?:[Tt]|[ \\t]+)([0-9][0-9]?):([0-9][0-9]):([0-9][0-9])(?:\\.([0-9]*))?(?:[ \\t]*(Z|([-+])([0-9][0-9]?)(?::([0-9][0-9]))?))?$" +); +function resolveYamlTimestamp(data) { + if (data === null) + return false; + if (YAML_DATE_REGEXP.exec(data) !== null) + return true; + if (YAML_TIMESTAMP_REGEXP.exec(data) !== null) + return true; + return false; +} +function constructYamlTimestamp(data) { + var match, year, month, day, hour, minute, second, fraction = 0, delta = null, tz_hour, tz_minute, date; + match = YAML_DATE_REGEXP.exec(data); + if (match === null) + match = YAML_TIMESTAMP_REGEXP.exec(data); + if (match === null) + throw new Error("Date resolve error"); + year = +match[1]; + month = +match[2] - 1; + day = +match[3]; + if (!match[4]) { + return new Date(Date.UTC(year, month, day)); + } + hour = +match[4]; + minute = +match[5]; + second = +match[6]; + if (match[7]) { + fraction = match[7].slice(0, 3); + while (fraction.length < 3) { + fraction += "0"; + } + fraction = +fraction; + } + if (match[9]) { + tz_hour = +match[10]; + tz_minute = +(match[11] || 0); + delta = (tz_hour * 60 + tz_minute) * 6e4; + if (match[9] === "-") + delta = -delta; + } + date = new Date(Date.UTC(year, month, day, hour, minute, second, fraction)); + if (delta) + date.setTime(date.getTime() - delta); + return date; +} +function representYamlTimestamp(object) { + return object.toISOString(); +} +var timestamp = new type("tag:yaml.org,2002:timestamp", { + kind: "scalar", + resolve: resolveYamlTimestamp, + construct: constructYamlTimestamp, + instanceOf: Date, + represent: representYamlTimestamp +}); +function resolveYamlMerge(data) { + return data === "<<" || data === null; +} +var merge = new type("tag:yaml.org,2002:merge", { + kind: "scalar", + resolve: resolveYamlMerge +}); +var BASE64_MAP = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=\n\r"; +function resolveYamlBinary(data) { + if (data === null) + return false; + var code, idx, bitlen = 0, max2 = data.length, map2 = BASE64_MAP; + for (idx = 0; idx < max2; idx++) { + code = map2.indexOf(data.charAt(idx)); + if (code > 64) + continue; + if (code < 0) + return false; + bitlen += 6; + } + return bitlen % 8 === 0; +} +function constructYamlBinary(data) { + var idx, tailbits, input = data.replace(/[\r\n=]/g, ""), max2 = input.length, map2 = BASE64_MAP, bits = 0, result = []; + for (idx = 0; idx < max2; idx++) { + if (idx % 4 === 0 && idx) { + result.push(bits >> 16 & 255); + result.push(bits >> 8 & 255); + result.push(bits & 255); + } + bits = bits << 6 | map2.indexOf(input.charAt(idx)); + } + tailbits = max2 % 4 * 6; + if (tailbits === 0) { + result.push(bits >> 16 & 255); + result.push(bits >> 8 & 255); + result.push(bits & 255); + } else if (tailbits === 18) { + result.push(bits >> 10 & 255); + result.push(bits >> 2 & 255); + } else if (tailbits === 12) { + result.push(bits >> 4 & 255); + } + return new Uint8Array(result); +} +function representYamlBinary(object) { + var result = "", bits = 0, idx, tail, max2 = object.length, map2 = BASE64_MAP; + for (idx = 0; idx < max2; idx++) { + if (idx % 3 === 0 && idx) { + result += map2[bits >> 18 & 63]; + result += map2[bits >> 12 & 63]; + result += map2[bits >> 6 & 63]; + result += map2[bits & 63]; + } + bits = (bits << 8) + object[idx]; + } + tail = max2 % 3; + if (tail === 0) { + result += map2[bits >> 18 & 63]; + result += map2[bits >> 12 & 63]; + result += map2[bits >> 6 & 63]; + result += map2[bits & 63]; + } else if (tail === 2) { + result += map2[bits >> 10 & 63]; + result += map2[bits >> 4 & 63]; + result += map2[bits << 2 & 63]; + result += map2[64]; + } else if (tail === 1) { + result += map2[bits >> 2 & 63]; + result += map2[bits << 4 & 63]; + result += map2[64]; + result += map2[64]; + } + return result; +} +function isBinary(obj) { + return Object.prototype.toString.call(obj) === "[object Uint8Array]"; +} +var binary = new type("tag:yaml.org,2002:binary", { + kind: "scalar", + resolve: resolveYamlBinary, + construct: constructYamlBinary, + predicate: isBinary, + represent: representYamlBinary +}); +var _hasOwnProperty$3 = Object.prototype.hasOwnProperty; +var _toString$2 = Object.prototype.toString; +function resolveYamlOmap(data) { + if (data === null) + return true; + var objectKeys = [], index, length2, pair, pairKey, pairHasKey, object = data; + for (index = 0, length2 = object.length; index < length2; index += 1) { + pair = object[index]; + pairHasKey = false; + if (_toString$2.call(pair) !== "[object Object]") + return false; + for (pairKey in pair) { + if (_hasOwnProperty$3.call(pair, pairKey)) { + if (!pairHasKey) + pairHasKey = true; + else + return false; + } + } + if (!pairHasKey) + return false; + if (objectKeys.indexOf(pairKey) === -1) + objectKeys.push(pairKey); + else + return false; + } + return true; +} +function constructYamlOmap(data) { + return data !== null ? data : []; +} +var omap = new type("tag:yaml.org,2002:omap", { + kind: "sequence", + resolve: resolveYamlOmap, + construct: constructYamlOmap +}); +var _toString$1 = Object.prototype.toString; +function resolveYamlPairs(data) { + if (data === null) + return true; + var index, length2, pair, keys, result, object = data; + result = new Array(object.length); + for (index = 0, length2 = object.length; index < length2; index += 1) { + pair = object[index]; + if (_toString$1.call(pair) !== "[object Object]") + return false; + keys = Object.keys(pair); + if (keys.length !== 1) + return false; + result[index] = [keys[0], pair[keys[0]]]; + } + return true; +} +function constructYamlPairs(data) { + if (data === null) + return []; + var index, length2, pair, keys, result, object = data; + result = new Array(object.length); + for (index = 0, length2 = object.length; index < length2; index += 1) { + pair = object[index]; + keys = Object.keys(pair); + result[index] = [keys[0], pair[keys[0]]]; + } + return result; +} +var pairs = new type("tag:yaml.org,2002:pairs", { + kind: "sequence", + resolve: resolveYamlPairs, + construct: constructYamlPairs +}); +var _hasOwnProperty$2 = Object.prototype.hasOwnProperty; +function resolveYamlSet(data) { + if (data === null) + return true; + var key, object = data; + for (key in object) { + if (_hasOwnProperty$2.call(object, key)) { + if (object[key] !== null) + return false; + } + } + return true; +} +function constructYamlSet(data) { + return data !== null ? data : {}; +} +var set = new type("tag:yaml.org,2002:set", { + kind: "mapping", + resolve: resolveYamlSet, + construct: constructYamlSet +}); +var _default = core.extend({ + implicit: [ + timestamp, + merge + ], + explicit: [ + binary, + omap, + pairs, + set + ] +}); +var _hasOwnProperty$1 = Object.prototype.hasOwnProperty; +var CONTEXT_FLOW_IN = 1; +var CONTEXT_FLOW_OUT = 2; +var CONTEXT_BLOCK_IN = 3; +var CONTEXT_BLOCK_OUT = 4; +var CHOMPING_CLIP = 1; +var CHOMPING_STRIP = 2; +var CHOMPING_KEEP = 3; +var PATTERN_NON_PRINTABLE = /[\x00-\x08\x0B\x0C\x0E-\x1F\x7F-\x84\x86-\x9F\uFFFE\uFFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF]/; +var PATTERN_NON_ASCII_LINE_BREAKS = /[\x85\u2028\u2029]/; +var PATTERN_FLOW_INDICATORS = /[,\[\]\{\}]/; +var PATTERN_TAG_HANDLE = /^(?:!|!!|![a-z\-]+!)$/i; +var PATTERN_TAG_URI = /^(?:!|[^,\[\]\{\}])(?:%[0-9a-f]{2}|[0-9a-z\-#;\/\?:@&=\+\$,_\.!~\*'\(\)\[\]])*$/i; +function _class(obj) { + return Object.prototype.toString.call(obj); +} +function is_EOL(c) { + return c === 10 || c === 13; +} +function is_WHITE_SPACE(c) { + return c === 9 || c === 32; +} +function is_WS_OR_EOL(c) { + return c === 9 || c === 32 || c === 10 || c === 13; +} +function is_FLOW_INDICATOR(c) { + return c === 44 || c === 91 || c === 93 || c === 123 || c === 125; +} +function fromHexCode(c) { + var lc; + if (48 <= c && c <= 57) { + return c - 48; + } + lc = c | 32; + if (97 <= lc && lc <= 102) { + return lc - 97 + 10; + } + return -1; +} +function escapedHexLen(c) { + if (c === 120) { + return 2; + } + if (c === 117) { + return 4; + } + if (c === 85) { + return 8; + } + return 0; +} +function fromDecimalCode(c) { + if (48 <= c && c <= 57) { + return c - 48; + } + return -1; +} +function simpleEscapeSequence(c) { + return c === 48 ? "\0" : c === 97 ? "\x07" : c === 98 ? "\b" : c === 116 ? " " : c === 9 ? " " : c === 110 ? "\n" : c === 118 ? "\v" : c === 102 ? "\f" : c === 114 ? "\r" : c === 101 ? "\x1B" : c === 32 ? " " : c === 34 ? '"' : c === 47 ? "/" : c === 92 ? "\\" : c === 78 ? "…" : c === 95 ? " " : c === 76 ? "\u2028" : c === 80 ? "\u2029" : ""; +} +function charFromCodepoint(c) { + if (c <= 65535) { + return String.fromCharCode(c); + } + return String.fromCharCode( + (c - 65536 >> 10) + 55296, + (c - 65536 & 1023) + 56320 + ); +} +var simpleEscapeCheck = new Array(256); +var simpleEscapeMap = new Array(256); +for (var i = 0; i < 256; i++) { + simpleEscapeCheck[i] = simpleEscapeSequence(i) ? 1 : 0; + simpleEscapeMap[i] = simpleEscapeSequence(i); +} +function State$1(input, options) { + this.input = input; + this.filename = options["filename"] || null; + this.schema = options["schema"] || _default; + this.onWarning = options["onWarning"] || null; + this.legacy = options["legacy"] || false; + this.json = options["json"] || false; + this.listener = options["listener"] || null; + this.implicitTypes = this.schema.compiledImplicit; + this.typeMap = this.schema.compiledTypeMap; + this.length = input.length; + this.position = 0; + this.line = 0; + this.lineStart = 0; + this.lineIndent = 0; + this.firstTabInLine = -1; + this.documents = []; +} +function generateError(state2, message) { + var mark = { + name: state2.filename, + buffer: state2.input.slice(0, -1), + // omit trailing \0 + position: state2.position, + line: state2.line, + column: state2.position - state2.lineStart + }; + mark.snippet = snippet(mark); + return new exception(message, mark); +} +function throwError(state2, message) { + throw generateError(state2, message); +} +function throwWarning(state2, message) { + if (state2.onWarning) { + state2.onWarning.call(null, generateError(state2, message)); + } +} +var directiveHandlers = { + YAML: function handleYamlDirective(state2, name, args) { + var match, major, minor; + if (state2.version !== null) { + throwError(state2, "duplication of %YAML directive"); + } + if (args.length !== 1) { + throwError(state2, "YAML directive accepts exactly one argument"); + } + match = /^([0-9]+)\.([0-9]+)$/.exec(args[0]); + if (match === null) { + throwError(state2, "ill-formed argument of the YAML directive"); + } + major = parseInt(match[1], 10); + minor = parseInt(match[2], 10); + if (major !== 1) { + throwError(state2, "unacceptable YAML version of the document"); + } + state2.version = args[0]; + state2.checkLineBreaks = minor < 2; + if (minor !== 1 && minor !== 2) { + throwWarning(state2, "unsupported YAML version of the document"); + } + }, + TAG: function handleTagDirective(state2, name, args) { + var handle, prefix; + if (args.length !== 2) { + throwError(state2, "TAG directive accepts exactly two arguments"); + } + handle = args[0]; + prefix = args[1]; + if (!PATTERN_TAG_HANDLE.test(handle)) { + throwError(state2, "ill-formed tag handle (first argument) of the TAG directive"); + } + if (_hasOwnProperty$1.call(state2.tagMap, handle)) { + throwError(state2, 'there is a previously declared suffix for "' + handle + '" tag handle'); + } + if (!PATTERN_TAG_URI.test(prefix)) { + throwError(state2, "ill-formed tag prefix (second argument) of the TAG directive"); + } + try { + prefix = decodeURIComponent(prefix); + } catch (err) { + throwError(state2, "tag prefix is malformed: " + prefix); + } + state2.tagMap[handle] = prefix; + } +}; +function captureSegment(state2, start2, end, checkJson) { + var _position, _length, _character, _result; + if (start2 < end) { + _result = state2.input.slice(start2, end); + if (checkJson) { + for (_position = 0, _length = _result.length; _position < _length; _position += 1) { + _character = _result.charCodeAt(_position); + if (!(_character === 9 || 32 <= _character && _character <= 1114111)) { + throwError(state2, "expected valid JSON character"); + } + } + } else if (PATTERN_NON_PRINTABLE.test(_result)) { + throwError(state2, "the stream contains non-printable characters"); + } + state2.result += _result; + } +} +function mergeMappings(state2, destination, source, overridableKeys) { + var sourceKeys, key, index, quantity; + if (!common.isObject(source)) { + throwError(state2, "cannot merge mappings; the provided source object is unacceptable"); + } + sourceKeys = Object.keys(source); + for (index = 0, quantity = sourceKeys.length; index < quantity; index += 1) { + key = sourceKeys[index]; + if (!_hasOwnProperty$1.call(destination, key)) { + destination[key] = source[key]; + overridableKeys[key] = true; + } + } +} +function storeMappingPair(state2, _result, overridableKeys, keyTag, keyNode, valueNode, startLine, startLineStart, startPos) { + var index, quantity; + if (Array.isArray(keyNode)) { + keyNode = Array.prototype.slice.call(keyNode); + for (index = 0, quantity = keyNode.length; index < quantity; index += 1) { + if (Array.isArray(keyNode[index])) { + throwError(state2, "nested arrays are not supported inside keys"); + } + if (typeof keyNode === "object" && _class(keyNode[index]) === "[object Object]") { + keyNode[index] = "[object Object]"; + } + } + } + if (typeof keyNode === "object" && _class(keyNode) === "[object Object]") { + keyNode = "[object Object]"; + } + keyNode = String(keyNode); + if (_result === null) { + _result = {}; + } + if (keyTag === "tag:yaml.org,2002:merge") { + if (Array.isArray(valueNode)) { + for (index = 0, quantity = valueNode.length; index < quantity; index += 1) { + mergeMappings(state2, _result, valueNode[index], overridableKeys); + } + } else { + mergeMappings(state2, _result, valueNode, overridableKeys); + } + } else { + if (!state2.json && !_hasOwnProperty$1.call(overridableKeys, keyNode) && _hasOwnProperty$1.call(_result, keyNode)) { + state2.line = startLine || state2.line; + state2.lineStart = startLineStart || state2.lineStart; + state2.position = startPos || state2.position; + throwError(state2, "duplicated mapping key"); + } + if (keyNode === "__proto__") { + Object.defineProperty(_result, keyNode, { + configurable: true, + enumerable: true, + writable: true, + value: valueNode + }); + } else { + _result[keyNode] = valueNode; + } + delete overridableKeys[keyNode]; + } + return _result; +} +function readLineBreak(state2) { + var ch; + ch = state2.input.charCodeAt(state2.position); + if (ch === 10) { + state2.position++; + } else if (ch === 13) { + state2.position++; + if (state2.input.charCodeAt(state2.position) === 10) { + state2.position++; + } + } else { + throwError(state2, "a line break is expected"); + } + state2.line += 1; + state2.lineStart = state2.position; + state2.firstTabInLine = -1; +} +function skipSeparationSpace(state2, allowComments, checkIndent) { + var lineBreaks = 0, ch = state2.input.charCodeAt(state2.position); + while (ch !== 0) { + while (is_WHITE_SPACE(ch)) { + if (ch === 9 && state2.firstTabInLine === -1) { + state2.firstTabInLine = state2.position; + } + ch = state2.input.charCodeAt(++state2.position); + } + if (allowComments && ch === 35) { + do { + ch = state2.input.charCodeAt(++state2.position); + } while (ch !== 10 && ch !== 13 && ch !== 0); + } + if (is_EOL(ch)) { + readLineBreak(state2); + ch = state2.input.charCodeAt(state2.position); + lineBreaks++; + state2.lineIndent = 0; + while (ch === 32) { + state2.lineIndent++; + ch = state2.input.charCodeAt(++state2.position); + } + } else { + break; + } + } + if (checkIndent !== -1 && lineBreaks !== 0 && state2.lineIndent < checkIndent) { + throwWarning(state2, "deficient indentation"); + } + return lineBreaks; +} +function testDocumentSeparator(state2) { + var _position = state2.position, ch; + ch = state2.input.charCodeAt(_position); + if ((ch === 45 || ch === 46) && ch === state2.input.charCodeAt(_position + 1) && ch === state2.input.charCodeAt(_position + 2)) { + _position += 3; + ch = state2.input.charCodeAt(_position); + if (ch === 0 || is_WS_OR_EOL(ch)) { + return true; + } + } + return false; +} +function writeFoldedLines(state2, count) { + if (count === 1) { + state2.result += " "; + } else if (count > 1) { + state2.result += common.repeat("\n", count - 1); + } +} +function readPlainScalar(state2, nodeIndent, withinFlowCollection) { + var preceding, following, captureStart, captureEnd, hasPendingContent, _line, _lineStart, _lineIndent, _kind = state2.kind, _result = state2.result, ch; + ch = state2.input.charCodeAt(state2.position); + if (is_WS_OR_EOL(ch) || is_FLOW_INDICATOR(ch) || ch === 35 || ch === 38 || ch === 42 || ch === 33 || ch === 124 || ch === 62 || ch === 39 || ch === 34 || ch === 37 || ch === 64 || ch === 96) { + return false; + } + if (ch === 63 || ch === 45) { + following = state2.input.charCodeAt(state2.position + 1); + if (is_WS_OR_EOL(following) || withinFlowCollection && is_FLOW_INDICATOR(following)) { + return false; + } + } + state2.kind = "scalar"; + state2.result = ""; + captureStart = captureEnd = state2.position; + hasPendingContent = false; + while (ch !== 0) { + if (ch === 58) { + following = state2.input.charCodeAt(state2.position + 1); + if (is_WS_OR_EOL(following) || withinFlowCollection && is_FLOW_INDICATOR(following)) { + break; + } + } else if (ch === 35) { + preceding = state2.input.charCodeAt(state2.position - 1); + if (is_WS_OR_EOL(preceding)) { + break; + } + } else if (state2.position === state2.lineStart && testDocumentSeparator(state2) || withinFlowCollection && is_FLOW_INDICATOR(ch)) { + break; + } else if (is_EOL(ch)) { + _line = state2.line; + _lineStart = state2.lineStart; + _lineIndent = state2.lineIndent; + skipSeparationSpace(state2, false, -1); + if (state2.lineIndent >= nodeIndent) { + hasPendingContent = true; + ch = state2.input.charCodeAt(state2.position); + continue; + } else { + state2.position = captureEnd; + state2.line = _line; + state2.lineStart = _lineStart; + state2.lineIndent = _lineIndent; + break; + } + } + if (hasPendingContent) { + captureSegment(state2, captureStart, captureEnd, false); + writeFoldedLines(state2, state2.line - _line); + captureStart = captureEnd = state2.position; + hasPendingContent = false; + } + if (!is_WHITE_SPACE(ch)) { + captureEnd = state2.position + 1; + } + ch = state2.input.charCodeAt(++state2.position); + } + captureSegment(state2, captureStart, captureEnd, false); + if (state2.result) { + return true; + } + state2.kind = _kind; + state2.result = _result; + return false; +} +function readSingleQuotedScalar(state2, nodeIndent) { + var ch, captureStart, captureEnd; + ch = state2.input.charCodeAt(state2.position); + if (ch !== 39) { + return false; + } + state2.kind = "scalar"; + state2.result = ""; + state2.position++; + captureStart = captureEnd = state2.position; + while ((ch = state2.input.charCodeAt(state2.position)) !== 0) { + if (ch === 39) { + captureSegment(state2, captureStart, state2.position, true); + ch = state2.input.charCodeAt(++state2.position); + if (ch === 39) { + captureStart = state2.position; + state2.position++; + captureEnd = state2.position; + } else { + return true; + } + } else if (is_EOL(ch)) { + captureSegment(state2, captureStart, captureEnd, true); + writeFoldedLines(state2, skipSeparationSpace(state2, false, nodeIndent)); + captureStart = captureEnd = state2.position; + } else if (state2.position === state2.lineStart && testDocumentSeparator(state2)) { + throwError(state2, "unexpected end of the document within a single quoted scalar"); + } else { + state2.position++; + captureEnd = state2.position; + } + } + throwError(state2, "unexpected end of the stream within a single quoted scalar"); +} +function readDoubleQuotedScalar(state2, nodeIndent) { + var captureStart, captureEnd, hexLength, hexResult, tmp, ch; + ch = state2.input.charCodeAt(state2.position); + if (ch !== 34) { + return false; + } + state2.kind = "scalar"; + state2.result = ""; + state2.position++; + captureStart = captureEnd = state2.position; + while ((ch = state2.input.charCodeAt(state2.position)) !== 0) { + if (ch === 34) { + captureSegment(state2, captureStart, state2.position, true); + state2.position++; + return true; + } else if (ch === 92) { + captureSegment(state2, captureStart, state2.position, true); + ch = state2.input.charCodeAt(++state2.position); + if (is_EOL(ch)) { + skipSeparationSpace(state2, false, nodeIndent); + } else if (ch < 256 && simpleEscapeCheck[ch]) { + state2.result += simpleEscapeMap[ch]; + state2.position++; + } else if ((tmp = escapedHexLen(ch)) > 0) { + hexLength = tmp; + hexResult = 0; + for (; hexLength > 0; hexLength--) { + ch = state2.input.charCodeAt(++state2.position); + if ((tmp = fromHexCode(ch)) >= 0) { + hexResult = (hexResult << 4) + tmp; + } else { + throwError(state2, "expected hexadecimal character"); + } + } + state2.result += charFromCodepoint(hexResult); + state2.position++; + } else { + throwError(state2, "unknown escape sequence"); + } + captureStart = captureEnd = state2.position; + } else if (is_EOL(ch)) { + captureSegment(state2, captureStart, captureEnd, true); + writeFoldedLines(state2, skipSeparationSpace(state2, false, nodeIndent)); + captureStart = captureEnd = state2.position; + } else if (state2.position === state2.lineStart && testDocumentSeparator(state2)) { + throwError(state2, "unexpected end of the document within a double quoted scalar"); + } else { + state2.position++; + captureEnd = state2.position; + } + } + throwError(state2, "unexpected end of the stream within a double quoted scalar"); +} +function readFlowCollection(state2, nodeIndent) { + var readNext = true, _line, _lineStart, _pos, _tag = state2.tag, _result, _anchor = state2.anchor, following, terminator, isPair, isExplicitPair, isMapping, overridableKeys = /* @__PURE__ */ Object.create(null), keyNode, keyTag, valueNode, ch; + ch = state2.input.charCodeAt(state2.position); + if (ch === 91) { + terminator = 93; + isMapping = false; + _result = []; + } else if (ch === 123) { + terminator = 125; + isMapping = true; + _result = {}; + } else { + return false; + } + if (state2.anchor !== null) { + state2.anchorMap[state2.anchor] = _result; + } + ch = state2.input.charCodeAt(++state2.position); + while (ch !== 0) { + skipSeparationSpace(state2, true, nodeIndent); + ch = state2.input.charCodeAt(state2.position); + if (ch === terminator) { + state2.position++; + state2.tag = _tag; + state2.anchor = _anchor; + state2.kind = isMapping ? "mapping" : "sequence"; + state2.result = _result; + return true; + } else if (!readNext) { + throwError(state2, "missed comma between flow collection entries"); + } else if (ch === 44) { + throwError(state2, "expected the node content, but found ','"); + } + keyTag = keyNode = valueNode = null; + isPair = isExplicitPair = false; + if (ch === 63) { + following = state2.input.charCodeAt(state2.position + 1); + if (is_WS_OR_EOL(following)) { + isPair = isExplicitPair = true; + state2.position++; + skipSeparationSpace(state2, true, nodeIndent); + } + } + _line = state2.line; + _lineStart = state2.lineStart; + _pos = state2.position; + composeNode(state2, nodeIndent, CONTEXT_FLOW_IN, false, true); + keyTag = state2.tag; + keyNode = state2.result; + skipSeparationSpace(state2, true, nodeIndent); + ch = state2.input.charCodeAt(state2.position); + if ((isExplicitPair || state2.line === _line) && ch === 58) { + isPair = true; + ch = state2.input.charCodeAt(++state2.position); + skipSeparationSpace(state2, true, nodeIndent); + composeNode(state2, nodeIndent, CONTEXT_FLOW_IN, false, true); + valueNode = state2.result; + } + if (isMapping) { + storeMappingPair(state2, _result, overridableKeys, keyTag, keyNode, valueNode, _line, _lineStart, _pos); + } else if (isPair) { + _result.push(storeMappingPair(state2, null, overridableKeys, keyTag, keyNode, valueNode, _line, _lineStart, _pos)); + } else { + _result.push(keyNode); + } + skipSeparationSpace(state2, true, nodeIndent); + ch = state2.input.charCodeAt(state2.position); + if (ch === 44) { + readNext = true; + ch = state2.input.charCodeAt(++state2.position); + } else { + readNext = false; + } + } + throwError(state2, "unexpected end of the stream within a flow collection"); +} +function readBlockScalar(state2, nodeIndent) { + var captureStart, folding, chomping = CHOMPING_CLIP, didReadContent = false, detectedIndent = false, textIndent = nodeIndent, emptyLines = 0, atMoreIndented = false, tmp, ch; + ch = state2.input.charCodeAt(state2.position); + if (ch === 124) { + folding = false; + } else if (ch === 62) { + folding = true; + } else { + return false; + } + state2.kind = "scalar"; + state2.result = ""; + while (ch !== 0) { + ch = state2.input.charCodeAt(++state2.position); + if (ch === 43 || ch === 45) { + if (CHOMPING_CLIP === chomping) { + chomping = ch === 43 ? CHOMPING_KEEP : CHOMPING_STRIP; + } else { + throwError(state2, "repeat of a chomping mode identifier"); + } + } else if ((tmp = fromDecimalCode(ch)) >= 0) { + if (tmp === 0) { + throwError(state2, "bad explicit indentation width of a block scalar; it cannot be less than one"); + } else if (!detectedIndent) { + textIndent = nodeIndent + tmp - 1; + detectedIndent = true; + } else { + throwError(state2, "repeat of an indentation width identifier"); + } + } else { + break; + } + } + if (is_WHITE_SPACE(ch)) { + do { + ch = state2.input.charCodeAt(++state2.position); + } while (is_WHITE_SPACE(ch)); + if (ch === 35) { + do { + ch = state2.input.charCodeAt(++state2.position); + } while (!is_EOL(ch) && ch !== 0); + } + } + while (ch !== 0) { + readLineBreak(state2); + state2.lineIndent = 0; + ch = state2.input.charCodeAt(state2.position); + while ((!detectedIndent || state2.lineIndent < textIndent) && ch === 32) { + state2.lineIndent++; + ch = state2.input.charCodeAt(++state2.position); + } + if (!detectedIndent && state2.lineIndent > textIndent) { + textIndent = state2.lineIndent; + } + if (is_EOL(ch)) { + emptyLines++; + continue; + } + if (state2.lineIndent < textIndent) { + if (chomping === CHOMPING_KEEP) { + state2.result += common.repeat("\n", didReadContent ? 1 + emptyLines : emptyLines); + } else if (chomping === CHOMPING_CLIP) { + if (didReadContent) { + state2.result += "\n"; + } + } + break; + } + if (folding) { + if (is_WHITE_SPACE(ch)) { + atMoreIndented = true; + state2.result += common.repeat("\n", didReadContent ? 1 + emptyLines : emptyLines); + } else if (atMoreIndented) { + atMoreIndented = false; + state2.result += common.repeat("\n", emptyLines + 1); + } else if (emptyLines === 0) { + if (didReadContent) { + state2.result += " "; + } + } else { + state2.result += common.repeat("\n", emptyLines); + } + } else { + state2.result += common.repeat("\n", didReadContent ? 1 + emptyLines : emptyLines); + } + didReadContent = true; + detectedIndent = true; + emptyLines = 0; + captureStart = state2.position; + while (!is_EOL(ch) && ch !== 0) { + ch = state2.input.charCodeAt(++state2.position); + } + captureSegment(state2, captureStart, state2.position, false); + } + return true; +} +function readBlockSequence(state2, nodeIndent) { + var _line, _tag = state2.tag, _anchor = state2.anchor, _result = [], following, detected = false, ch; + if (state2.firstTabInLine !== -1) + return false; + if (state2.anchor !== null) { + state2.anchorMap[state2.anchor] = _result; + } + ch = state2.input.charCodeAt(state2.position); + while (ch !== 0) { + if (state2.firstTabInLine !== -1) { + state2.position = state2.firstTabInLine; + throwError(state2, "tab characters must not be used in indentation"); + } + if (ch !== 45) { + break; + } + following = state2.input.charCodeAt(state2.position + 1); + if (!is_WS_OR_EOL(following)) { + break; + } + detected = true; + state2.position++; + if (skipSeparationSpace(state2, true, -1)) { + if (state2.lineIndent <= nodeIndent) { + _result.push(null); + ch = state2.input.charCodeAt(state2.position); + continue; + } + } + _line = state2.line; + composeNode(state2, nodeIndent, CONTEXT_BLOCK_IN, false, true); + _result.push(state2.result); + skipSeparationSpace(state2, true, -1); + ch = state2.input.charCodeAt(state2.position); + if ((state2.line === _line || state2.lineIndent > nodeIndent) && ch !== 0) { + throwError(state2, "bad indentation of a sequence entry"); + } else if (state2.lineIndent < nodeIndent) { + break; + } + } + if (detected) { + state2.tag = _tag; + state2.anchor = _anchor; + state2.kind = "sequence"; + state2.result = _result; + return true; + } + return false; +} +function readBlockMapping(state2, nodeIndent, flowIndent) { + var following, allowCompact, _line, _keyLine, _keyLineStart, _keyPos, _tag = state2.tag, _anchor = state2.anchor, _result = {}, overridableKeys = /* @__PURE__ */ Object.create(null), keyTag = null, keyNode = null, valueNode = null, atExplicitKey = false, detected = false, ch; + if (state2.firstTabInLine !== -1) + return false; + if (state2.anchor !== null) { + state2.anchorMap[state2.anchor] = _result; + } + ch = state2.input.charCodeAt(state2.position); + while (ch !== 0) { + if (!atExplicitKey && state2.firstTabInLine !== -1) { + state2.position = state2.firstTabInLine; + throwError(state2, "tab characters must not be used in indentation"); + } + following = state2.input.charCodeAt(state2.position + 1); + _line = state2.line; + if ((ch === 63 || ch === 58) && is_WS_OR_EOL(following)) { + if (ch === 63) { + if (atExplicitKey) { + storeMappingPair(state2, _result, overridableKeys, keyTag, keyNode, null, _keyLine, _keyLineStart, _keyPos); + keyTag = keyNode = valueNode = null; + } + detected = true; + atExplicitKey = true; + allowCompact = true; + } else if (atExplicitKey) { + atExplicitKey = false; + allowCompact = true; + } else { + throwError(state2, "incomplete explicit mapping pair; a key node is missed; or followed by a non-tabulated empty line"); + } + state2.position += 1; + ch = following; + } else { + _keyLine = state2.line; + _keyLineStart = state2.lineStart; + _keyPos = state2.position; + if (!composeNode(state2, flowIndent, CONTEXT_FLOW_OUT, false, true)) { + break; + } + if (state2.line === _line) { + ch = state2.input.charCodeAt(state2.position); + while (is_WHITE_SPACE(ch)) { + ch = state2.input.charCodeAt(++state2.position); + } + if (ch === 58) { + ch = state2.input.charCodeAt(++state2.position); + if (!is_WS_OR_EOL(ch)) { + throwError(state2, "a whitespace character is expected after the key-value separator within a block mapping"); + } + if (atExplicitKey) { + storeMappingPair(state2, _result, overridableKeys, keyTag, keyNode, null, _keyLine, _keyLineStart, _keyPos); + keyTag = keyNode = valueNode = null; + } + detected = true; + atExplicitKey = false; + allowCompact = false; + keyTag = state2.tag; + keyNode = state2.result; + } else if (detected) { + throwError(state2, "can not read an implicit mapping pair; a colon is missed"); + } else { + state2.tag = _tag; + state2.anchor = _anchor; + return true; + } + } else if (detected) { + throwError(state2, "can not read a block mapping entry; a multiline key may not be an implicit key"); + } else { + state2.tag = _tag; + state2.anchor = _anchor; + return true; + } + } + if (state2.line === _line || state2.lineIndent > nodeIndent) { + if (atExplicitKey) { + _keyLine = state2.line; + _keyLineStart = state2.lineStart; + _keyPos = state2.position; + } + if (composeNode(state2, nodeIndent, CONTEXT_BLOCK_OUT, true, allowCompact)) { + if (atExplicitKey) { + keyNode = state2.result; + } else { + valueNode = state2.result; + } + } + if (!atExplicitKey) { + storeMappingPair(state2, _result, overridableKeys, keyTag, keyNode, valueNode, _keyLine, _keyLineStart, _keyPos); + keyTag = keyNode = valueNode = null; + } + skipSeparationSpace(state2, true, -1); + ch = state2.input.charCodeAt(state2.position); + } + if ((state2.line === _line || state2.lineIndent > nodeIndent) && ch !== 0) { + throwError(state2, "bad indentation of a mapping entry"); + } else if (state2.lineIndent < nodeIndent) { + break; + } + } + if (atExplicitKey) { + storeMappingPair(state2, _result, overridableKeys, keyTag, keyNode, null, _keyLine, _keyLineStart, _keyPos); + } + if (detected) { + state2.tag = _tag; + state2.anchor = _anchor; + state2.kind = "mapping"; + state2.result = _result; + } + return detected; +} +function readTagProperty(state2) { + var _position, isVerbatim = false, isNamed = false, tagHandle, tagName, ch; + ch = state2.input.charCodeAt(state2.position); + if (ch !== 33) + return false; + if (state2.tag !== null) { + throwError(state2, "duplication of a tag property"); + } + ch = state2.input.charCodeAt(++state2.position); + if (ch === 60) { + isVerbatim = true; + ch = state2.input.charCodeAt(++state2.position); + } else if (ch === 33) { + isNamed = true; + tagHandle = "!!"; + ch = state2.input.charCodeAt(++state2.position); + } else { + tagHandle = "!"; + } + _position = state2.position; + if (isVerbatim) { + do { + ch = state2.input.charCodeAt(++state2.position); + } while (ch !== 0 && ch !== 62); + if (state2.position < state2.length) { + tagName = state2.input.slice(_position, state2.position); + ch = state2.input.charCodeAt(++state2.position); + } else { + throwError(state2, "unexpected end of the stream within a verbatim tag"); + } + } else { + while (ch !== 0 && !is_WS_OR_EOL(ch)) { + if (ch === 33) { + if (!isNamed) { + tagHandle = state2.input.slice(_position - 1, state2.position + 1); + if (!PATTERN_TAG_HANDLE.test(tagHandle)) { + throwError(state2, "named tag handle cannot contain such characters"); + } + isNamed = true; + _position = state2.position + 1; + } else { + throwError(state2, "tag suffix cannot contain exclamation marks"); + } + } + ch = state2.input.charCodeAt(++state2.position); + } + tagName = state2.input.slice(_position, state2.position); + if (PATTERN_FLOW_INDICATORS.test(tagName)) { + throwError(state2, "tag suffix cannot contain flow indicator characters"); + } + } + if (tagName && !PATTERN_TAG_URI.test(tagName)) { + throwError(state2, "tag name cannot contain such characters: " + tagName); + } + try { + tagName = decodeURIComponent(tagName); + } catch (err) { + throwError(state2, "tag name is malformed: " + tagName); + } + if (isVerbatim) { + state2.tag = tagName; + } else if (_hasOwnProperty$1.call(state2.tagMap, tagHandle)) { + state2.tag = state2.tagMap[tagHandle] + tagName; + } else if (tagHandle === "!") { + state2.tag = "!" + tagName; + } else if (tagHandle === "!!") { + state2.tag = "tag:yaml.org,2002:" + tagName; + } else { + throwError(state2, 'undeclared tag handle "' + tagHandle + '"'); + } + return true; +} +function readAnchorProperty(state2) { + var _position, ch; + ch = state2.input.charCodeAt(state2.position); + if (ch !== 38) + return false; + if (state2.anchor !== null) { + throwError(state2, "duplication of an anchor property"); + } + ch = state2.input.charCodeAt(++state2.position); + _position = state2.position; + while (ch !== 0 && !is_WS_OR_EOL(ch) && !is_FLOW_INDICATOR(ch)) { + ch = state2.input.charCodeAt(++state2.position); + } + if (state2.position === _position) { + throwError(state2, "name of an anchor node must contain at least one character"); + } + state2.anchor = state2.input.slice(_position, state2.position); + return true; +} +function readAlias(state2) { + var _position, alias, ch; + ch = state2.input.charCodeAt(state2.position); + if (ch !== 42) + return false; + ch = state2.input.charCodeAt(++state2.position); + _position = state2.position; + while (ch !== 0 && !is_WS_OR_EOL(ch) && !is_FLOW_INDICATOR(ch)) { + ch = state2.input.charCodeAt(++state2.position); + } + if (state2.position === _position) { + throwError(state2, "name of an alias node must contain at least one character"); + } + alias = state2.input.slice(_position, state2.position); + if (!_hasOwnProperty$1.call(state2.anchorMap, alias)) { + throwError(state2, 'unidentified alias "' + alias + '"'); + } + state2.result = state2.anchorMap[alias]; + skipSeparationSpace(state2, true, -1); + return true; +} +function composeNode(state2, parentIndent, nodeContext, allowToSeek, allowCompact) { + var allowBlockStyles, allowBlockScalars, allowBlockCollections, indentStatus = 1, atNewLine = false, hasContent = false, typeIndex, typeQuantity, typeList, type2, flowIndent, blockIndent; + if (state2.listener !== null) { + state2.listener("open", state2); + } + state2.tag = null; + state2.anchor = null; + state2.kind = null; + state2.result = null; + allowBlockStyles = allowBlockScalars = allowBlockCollections = CONTEXT_BLOCK_OUT === nodeContext || CONTEXT_BLOCK_IN === nodeContext; + if (allowToSeek) { + if (skipSeparationSpace(state2, true, -1)) { + atNewLine = true; + if (state2.lineIndent > parentIndent) { + indentStatus = 1; + } else if (state2.lineIndent === parentIndent) { + indentStatus = 0; + } else if (state2.lineIndent < parentIndent) { + indentStatus = -1; + } + } + } + if (indentStatus === 1) { + while (readTagProperty(state2) || readAnchorProperty(state2)) { + if (skipSeparationSpace(state2, true, -1)) { + atNewLine = true; + allowBlockCollections = allowBlockStyles; + if (state2.lineIndent > parentIndent) { + indentStatus = 1; + } else if (state2.lineIndent === parentIndent) { + indentStatus = 0; + } else if (state2.lineIndent < parentIndent) { + indentStatus = -1; + } + } else { + allowBlockCollections = false; + } + } + } + if (allowBlockCollections) { + allowBlockCollections = atNewLine || allowCompact; + } + if (indentStatus === 1 || CONTEXT_BLOCK_OUT === nodeContext) { + if (CONTEXT_FLOW_IN === nodeContext || CONTEXT_FLOW_OUT === nodeContext) { + flowIndent = parentIndent; + } else { + flowIndent = parentIndent + 1; + } + blockIndent = state2.position - state2.lineStart; + if (indentStatus === 1) { + if (allowBlockCollections && (readBlockSequence(state2, blockIndent) || readBlockMapping(state2, blockIndent, flowIndent)) || readFlowCollection(state2, flowIndent)) { + hasContent = true; + } else { + if (allowBlockScalars && readBlockScalar(state2, flowIndent) || readSingleQuotedScalar(state2, flowIndent) || readDoubleQuotedScalar(state2, flowIndent)) { + hasContent = true; + } else if (readAlias(state2)) { + hasContent = true; + if (state2.tag !== null || state2.anchor !== null) { + throwError(state2, "alias node should not have any properties"); + } + } else if (readPlainScalar(state2, flowIndent, CONTEXT_FLOW_IN === nodeContext)) { + hasContent = true; + if (state2.tag === null) { + state2.tag = "?"; + } + } + if (state2.anchor !== null) { + state2.anchorMap[state2.anchor] = state2.result; + } + } + } else if (indentStatus === 0) { + hasContent = allowBlockCollections && readBlockSequence(state2, blockIndent); + } + } + if (state2.tag === null) { + if (state2.anchor !== null) { + state2.anchorMap[state2.anchor] = state2.result; + } + } else if (state2.tag === "?") { + if (state2.result !== null && state2.kind !== "scalar") { + throwError(state2, 'unacceptable node kind for ! tag; it should be "scalar", not "' + state2.kind + '"'); + } + for (typeIndex = 0, typeQuantity = state2.implicitTypes.length; typeIndex < typeQuantity; typeIndex += 1) { + type2 = state2.implicitTypes[typeIndex]; + if (type2.resolve(state2.result)) { + state2.result = type2.construct(state2.result); + state2.tag = type2.tag; + if (state2.anchor !== null) { + state2.anchorMap[state2.anchor] = state2.result; + } + break; + } + } + } else if (state2.tag !== "!") { + if (_hasOwnProperty$1.call(state2.typeMap[state2.kind || "fallback"], state2.tag)) { + type2 = state2.typeMap[state2.kind || "fallback"][state2.tag]; + } else { + type2 = null; + typeList = state2.typeMap.multi[state2.kind || "fallback"]; + for (typeIndex = 0, typeQuantity = typeList.length; typeIndex < typeQuantity; typeIndex += 1) { + if (state2.tag.slice(0, typeList[typeIndex].tag.length) === typeList[typeIndex].tag) { + type2 = typeList[typeIndex]; + break; + } + } + } + if (!type2) { + throwError(state2, "unknown tag !<" + state2.tag + ">"); + } + if (state2.result !== null && type2.kind !== state2.kind) { + throwError(state2, "unacceptable node kind for !<" + state2.tag + '> tag; it should be "' + type2.kind + '", not "' + state2.kind + '"'); + } + if (!type2.resolve(state2.result, state2.tag)) { + throwError(state2, "cannot resolve a node with !<" + state2.tag + "> explicit tag"); + } else { + state2.result = type2.construct(state2.result, state2.tag); + if (state2.anchor !== null) { + state2.anchorMap[state2.anchor] = state2.result; + } + } + } + if (state2.listener !== null) { + state2.listener("close", state2); + } + return state2.tag !== null || state2.anchor !== null || hasContent; +} +function readDocument(state2) { + var documentStart = state2.position, _position, directiveName, directiveArgs, hasDirectives = false, ch; + state2.version = null; + state2.checkLineBreaks = state2.legacy; + state2.tagMap = /* @__PURE__ */ Object.create(null); + state2.anchorMap = /* @__PURE__ */ Object.create(null); + while ((ch = state2.input.charCodeAt(state2.position)) !== 0) { + skipSeparationSpace(state2, true, -1); + ch = state2.input.charCodeAt(state2.position); + if (state2.lineIndent > 0 || ch !== 37) { + break; + } + hasDirectives = true; + ch = state2.input.charCodeAt(++state2.position); + _position = state2.position; + while (ch !== 0 && !is_WS_OR_EOL(ch)) { + ch = state2.input.charCodeAt(++state2.position); + } + directiveName = state2.input.slice(_position, state2.position); + directiveArgs = []; + if (directiveName.length < 1) { + throwError(state2, "directive name must not be less than one character in length"); + } + while (ch !== 0) { + while (is_WHITE_SPACE(ch)) { + ch = state2.input.charCodeAt(++state2.position); + } + if (ch === 35) { + do { + ch = state2.input.charCodeAt(++state2.position); + } while (ch !== 0 && !is_EOL(ch)); + break; + } + if (is_EOL(ch)) + break; + _position = state2.position; + while (ch !== 0 && !is_WS_OR_EOL(ch)) { + ch = state2.input.charCodeAt(++state2.position); + } + directiveArgs.push(state2.input.slice(_position, state2.position)); + } + if (ch !== 0) + readLineBreak(state2); + if (_hasOwnProperty$1.call(directiveHandlers, directiveName)) { + directiveHandlers[directiveName](state2, directiveName, directiveArgs); + } else { + throwWarning(state2, 'unknown document directive "' + directiveName + '"'); + } + } + skipSeparationSpace(state2, true, -1); + if (state2.lineIndent === 0 && state2.input.charCodeAt(state2.position) === 45 && state2.input.charCodeAt(state2.position + 1) === 45 && state2.input.charCodeAt(state2.position + 2) === 45) { + state2.position += 3; + skipSeparationSpace(state2, true, -1); + } else if (hasDirectives) { + throwError(state2, "directives end mark is expected"); + } + composeNode(state2, state2.lineIndent - 1, CONTEXT_BLOCK_OUT, false, true); + skipSeparationSpace(state2, true, -1); + if (state2.checkLineBreaks && PATTERN_NON_ASCII_LINE_BREAKS.test(state2.input.slice(documentStart, state2.position))) { + throwWarning(state2, "non-ASCII line breaks are interpreted as content"); + } + state2.documents.push(state2.result); + if (state2.position === state2.lineStart && testDocumentSeparator(state2)) { + if (state2.input.charCodeAt(state2.position) === 46) { + state2.position += 3; + skipSeparationSpace(state2, true, -1); + } + return; + } + if (state2.position < state2.length - 1) { + throwError(state2, "end of the stream or a document separator is expected"); + } else { + return; + } +} +function loadDocuments(input, options) { + input = String(input); + options = options || {}; + if (input.length !== 0) { + if (input.charCodeAt(input.length - 1) !== 10 && input.charCodeAt(input.length - 1) !== 13) { + input += "\n"; + } + if (input.charCodeAt(0) === 65279) { + input = input.slice(1); + } + } + var state2 = new State$1(input, options); + var nullpos = input.indexOf("\0"); + if (nullpos !== -1) { + state2.position = nullpos; + throwError(state2, "null byte is not allowed in input"); + } + state2.input += "\0"; + while (state2.input.charCodeAt(state2.position) === 32) { + state2.lineIndent += 1; + state2.position += 1; + } + while (state2.position < state2.length - 1) { + readDocument(state2); + } + return state2.documents; +} +function loadAll$1(input, iterator, options) { + if (iterator !== null && typeof iterator === "object" && typeof options === "undefined") { + options = iterator; + iterator = null; + } + var documents = loadDocuments(input, options); + if (typeof iterator !== "function") { + return documents; + } + for (var index = 0, length2 = documents.length; index < length2; index += 1) { + iterator(documents[index]); + } +} +function load$1(input, options) { + var documents = loadDocuments(input, options); + if (documents.length === 0) { + return void 0; + } else if (documents.length === 1) { + return documents[0]; + } + throw new exception("expected a single document in the stream, but found more"); +} +var loadAll_1 = loadAll$1; +var load_1 = load$1; +var loader = { + loadAll: loadAll_1, + load: load_1 +}; +var JSON_SCHEMA = json; +var load = loader.load; +function extractFrontMatter(text2) { + const matches = text2.match(frontMatterRegex); + if (!matches) { + return { + text: text2, + metadata: {} + }; + } + let parsed = load(matches[1], { + // To support config, we need JSON schema. + // https://www.yaml.org/spec/1.2/spec.html#id2803231 + schema: JSON_SCHEMA + }) ?? {}; + parsed = typeof parsed === "object" && !Array.isArray(parsed) ? parsed : {}; + const metadata = {}; + if (parsed.displayMode) { + metadata.displayMode = parsed.displayMode.toString(); + } + if (parsed.title) { + metadata.title = parsed.title.toString(); + } + if (parsed.config) { + metadata.config = parsed.config; + } + return { + text: text2.slice(matches[0].length), + metadata + }; +} +const cleanupText = (code) => { + return code.replace(/\r\n?/g, "\n").replace( + /<(\w+)([^>]*)>/g, + (match, tag, attributes) => "<" + tag + attributes.replace(/="([^"]*)"/g, "='$1'") + ">" + ); +}; +const processFrontmatter = (code) => { + const { text: text2, metadata } = extractFrontMatter(code); + const { displayMode, title, config: config2 = {} } = metadata; + if (displayMode) { + if (!config2.gantt) { + config2.gantt = {}; + } + config2.gantt.displayMode = displayMode; + } + return { title, config: config2, text: text2 }; +}; +const processDirectives = (code) => { + const initDirective = utils.detectInit(code) ?? {}; + const wrapDirectives = utils.detectDirective(code, "wrap"); + if (Array.isArray(wrapDirectives)) { + initDirective.wrap = wrapDirectives.some(({ type: type2 }) => { + }); + } else if ((wrapDirectives == null ? void 0 : wrapDirectives.type) === "wrap") { + initDirective.wrap = true; + } + return { + text: removeDirectives(code), + directive: initDirective + }; +}; +function preprocessDiagram(code) { + const cleanedCode = cleanupText(code); + const frontMatterResult = processFrontmatter(cleanedCode); + const directiveResult = processDirectives(frontMatterResult.text); + const config2 = cleanAndMerge(frontMatterResult.config, directiveResult.directive); + code = cleanupComments(directiveResult.text); + return { + code, + title: frontMatterResult.title, + config: config2 + }; +} +const MAX_TEXTLENGTH = 5e4; +const MAX_TEXTLENGTH_EXCEEDED_MSG = "graph TB;a[Maximum text size in diagram exceeded];style a fill:#faa"; +const SECURITY_LVL_SANDBOX = "sandbox"; +const SECURITY_LVL_LOOSE = "loose"; +const XMLNS_SVG_STD = "http://www.w3.org/2000/svg"; +const XMLNS_XLINK_STD = "http://www.w3.org/1999/xlink"; +const XMLNS_XHTML_STD = "http://www.w3.org/1999/xhtml"; +const IFRAME_WIDTH = "100%"; +const IFRAME_HEIGHT = "100%"; +const IFRAME_STYLES = "border:0;margin:0;"; +const IFRAME_BODY_STYLE = "margin:0"; +const IFRAME_SANDBOX_OPTS = "allow-top-navigation-by-user-activation allow-popups"; +const IFRAME_NOT_SUPPORTED_MSG = 'The "iframe" tag is not supported by your browser.'; +const DOMPURIFY_TAGS = ["foreignobject"]; +const DOMPURIFY_ATTR = ["dominant-baseline"]; +function processAndSetConfigs(text2) { + const processed = preprocessDiagram(text2); + reset(); + addDirective(processed.config ?? {}); + return processed; +} +async function parse$1(text2, parseOptions) { + addDiagrams(); + text2 = processAndSetConfigs(text2).code; + try { + await getDiagramFromText(text2); + } catch (error) { + if (parseOptions == null ? void 0 : parseOptions.suppressErrors) { + return false; + } + throw error; + } + return true; +} +const cssImportantStyles = (cssClass, element, cssClasses = []) => { + return ` +.${cssClass} ${element} { ${cssClasses.join(" !important; ")} !important; }`; +}; +const createCssStyles = (config2, classDefs = {}) => { + var _a; + let cssStyles = ""; + if (config2.themeCSS !== void 0) { + cssStyles += ` +${config2.themeCSS}`; + } + if (config2.fontFamily !== void 0) { + cssStyles += ` +:root { --mermaid-font-family: ${config2.fontFamily}}`; + } + if (config2.altFontFamily !== void 0) { + cssStyles += ` +:root { --mermaid-alt-font-family: ${config2.altFontFamily}}`; + } + if (!isEmpty(classDefs)) { + const htmlLabels = config2.htmlLabels || ((_a = config2.flowchart) == null ? void 0 : _a.htmlLabels); + const cssHtmlElements = ["> *", "span"]; + const cssShapeElements = ["rect", "polygon", "ellipse", "circle", "path"]; + const cssElements = htmlLabels ? cssHtmlElements : cssShapeElements; + for (const classId in classDefs) { + const styleClassDef = classDefs[classId]; + if (!isEmpty(styleClassDef.styles)) { + cssElements.forEach((cssElement) => { + cssStyles += cssImportantStyles(styleClassDef.id, cssElement, styleClassDef.styles); + }); + } + if (!isEmpty(styleClassDef.textStyles)) { + cssStyles += cssImportantStyles(styleClassDef.id, "tspan", styleClassDef.textStyles); + } + } + } + return cssStyles; +}; +const createUserStyles = (config2, graphType, classDefs, svgId) => { + const userCSSstyles = createCssStyles(config2, classDefs); + const allStyles = getStyles$1(graphType, userCSSstyles, config2.themeVariables); + return serialize(compile(`${svgId}{${allStyles}}`), stringify); +}; +const cleanUpSvgCode = (svgCode = "", inSandboxMode, useArrowMarkerUrls) => { + let cleanedUpSvg = svgCode; + if (!useArrowMarkerUrls && !inSandboxMode) { + cleanedUpSvg = cleanedUpSvg.replace( + /marker-end="url\([\d+./:=?A-Za-z-]*?#/g, + 'marker-end="url(#' + ); + } + cleanedUpSvg = decodeEntities(cleanedUpSvg); + cleanedUpSvg = cleanedUpSvg.replace(/
    /g, "
    "); + return cleanedUpSvg; +}; +const putIntoIFrame = (svgCode = "", svgElement) => { + var _a, _b; + const height = ((_b = (_a = svgElement == null ? void 0 : svgElement.viewBox) == null ? void 0 : _a.baseVal) == null ? void 0 : _b.height) ? svgElement.viewBox.baseVal.height + "px" : IFRAME_HEIGHT; + const base64encodedSrc = btoa('' + svgCode + ""); + return ``; +}; +const appendDivSvgG = (parentRoot, id2, enclosingDivId, divStyle, svgXlink) => { + const enclosingDiv = parentRoot.append("div"); + enclosingDiv.attr("id", enclosingDivId); + if (divStyle) { + enclosingDiv.attr("style", divStyle); + } + const svgNode2 = enclosingDiv.append("svg").attr("id", id2).attr("width", "100%").attr("xmlns", XMLNS_SVG_STD); + if (svgXlink) { + svgNode2.attr("xmlns:xlink", svgXlink); + } + svgNode2.append("g"); + return parentRoot; +}; +function sandboxedIframe(parentNode, iFrameId) { + return parentNode.append("iframe").attr("id", iFrameId).attr("style", "width: 100%; height: 100%;").attr("sandbox", ""); +} +const removeExistingElements = (doc, id2, divId, iFrameId) => { + var _a, _b, _c; + (_a = doc.getElementById(id2)) == null ? void 0 : _a.remove(); + (_b = doc.getElementById(divId)) == null ? void 0 : _b.remove(); + (_c = doc.getElementById(iFrameId)) == null ? void 0 : _c.remove(); +}; +const render$1 = async function(id2, text2, svgContainingElement) { + var _a, _b, _c, _d, _e, _f; + addDiagrams(); + const processed = processAndSetConfigs(text2); + text2 = processed.code; + const config2 = getConfig$1(); + log$1.debug(config2); + if (text2.length > ((config2 == null ? void 0 : config2.maxTextSize) ?? MAX_TEXTLENGTH)) { + text2 = MAX_TEXTLENGTH_EXCEEDED_MSG; + } + const idSelector = "#" + id2; + const iFrameID = "i" + id2; + const iFrameID_selector = "#" + iFrameID; + const enclosingDivID = "d" + id2; + const enclosingDivID_selector = "#" + enclosingDivID; + let root2 = d3select("body"); + const isSandboxed = config2.securityLevel === SECURITY_LVL_SANDBOX; + const isLooseSecurityLevel = config2.securityLevel === SECURITY_LVL_LOOSE; + const fontFamily = config2.fontFamily; + if (svgContainingElement !== void 0) { + if (svgContainingElement) { + svgContainingElement.innerHTML = ""; + } + if (isSandboxed) { + const iframe = sandboxedIframe(d3select(svgContainingElement), iFrameID); + root2 = d3select(iframe.nodes()[0].contentDocument.body); + root2.node().style.margin = 0; + } else { + root2 = d3select(svgContainingElement); + } + appendDivSvgG(root2, id2, enclosingDivID, `font-family: ${fontFamily}`, XMLNS_XLINK_STD); + } else { + removeExistingElements(document, id2, enclosingDivID, iFrameID); + if (isSandboxed) { + const iframe = sandboxedIframe(d3select("body"), iFrameID); + root2 = d3select(iframe.nodes()[0].contentDocument.body); + root2.node().style.margin = 0; + } else { + root2 = d3select("body"); + } + appendDivSvgG(root2, id2, enclosingDivID); + } + let diag; + let parseEncounteredException; + try { + diag = await getDiagramFromText(text2, { title: processed.title }); + } catch (error) { + diag = new Diagram("error"); + parseEncounteredException = error; + } + const element = root2.select(enclosingDivID_selector).node(); + const diagramType = diag.type; + const svg2 = element.firstChild; + const firstChild = svg2.firstChild; + const diagramClassDefs = (_b = (_a = diag.renderer).getClasses) == null ? void 0 : _b.call(_a, text2, diag); + const rules = createUserStyles(config2, diagramType, diagramClassDefs, idSelector); + const style1 = document.createElement("style"); + style1.innerHTML = rules; + svg2.insertBefore(style1, firstChild); + try { + await diag.renderer.draw(text2, id2, version, diag); + } catch (e) { + errorRenderer.draw(text2, id2, version); + throw e; + } + const svgNode2 = root2.select(`${enclosingDivID_selector} svg`); + const a11yTitle = (_d = (_c = diag.db).getAccTitle) == null ? void 0 : _d.call(_c); + const a11yDescr = (_f = (_e = diag.db).getAccDescription) == null ? void 0 : _f.call(_e); + addA11yInfo(diagramType, svgNode2, a11yTitle, a11yDescr); + root2.select(`[id="${id2}"]`).selectAll("foreignobject > *").attr("xmlns", XMLNS_XHTML_STD); + let svgCode = root2.select(enclosingDivID_selector).node().innerHTML; + log$1.debug("config.arrowMarkerAbsolute", config2.arrowMarkerAbsolute); + svgCode = cleanUpSvgCode(svgCode, isSandboxed, evaluate(config2.arrowMarkerAbsolute)); + if (isSandboxed) { + const svgEl = root2.select(enclosingDivID_selector + " svg").node(); + svgCode = putIntoIFrame(svgCode, svgEl); + } else if (!isLooseSecurityLevel) { + svgCode = purify.sanitize(svgCode, { + ADD_TAGS: DOMPURIFY_TAGS, + ADD_ATTR: DOMPURIFY_ATTR + }); + } + attachFunctions(); + if (parseEncounteredException) { + throw parseEncounteredException; + } + const tmpElementSelector = isSandboxed ? iFrameID_selector : enclosingDivID_selector; + const node2 = d3select(tmpElementSelector).node(); + if (node2 && "remove" in node2) { + node2.remove(); + } + return { + svg: svgCode, + bindFunctions: diag.db.bindFunctions + }; +}; +function initialize$1(options = {}) { + var _a; + if ((options == null ? void 0 : options.fontFamily) && !((_a = options.themeVariables) == null ? void 0 : _a.fontFamily)) { + if (!options.themeVariables) { + options.themeVariables = {}; + } + options.themeVariables.fontFamily = options.fontFamily; + } + saveConfigFromInitialize(options); + if ((options == null ? void 0 : options.theme) && options.theme in theme) { + options.themeVariables = theme[options.theme].getThemeVariables( + options.themeVariables + ); + } else if (options) { + options.themeVariables = theme.default.getThemeVariables(options.themeVariables); + } + const config2 = typeof options === "object" ? setSiteConfig(options) : getSiteConfig(); + setLogLevel$1(config2.logLevel); + addDiagrams(); +} +const getDiagramFromText = (text2, metadata = {}) => { + const { code } = preprocessDiagram(text2); + return getDiagramFromText$1(code, metadata); +}; +function addA11yInfo(diagramType, svgNode2, a11yTitle, a11yDescr) { + setA11yDiagramInfo(svgNode2, diagramType); + addSVGa11yTitleDescription(svgNode2, a11yTitle, a11yDescr, svgNode2.attr("id")); +} +const mermaidAPI = Object.freeze({ + render: render$1, + parse: parse$1, + getDiagramFromText, + initialize: initialize$1, + getConfig: getConfig$1, + setConfig: setConfig$1, + getSiteConfig, + updateSiteConfig, + reset: () => { + reset(); + }, + globalReset: () => { + reset(defaultConfig$1); + }, + defaultConfig: defaultConfig$1 +}); +setLogLevel$1(getConfig$1().logLevel); +reset(getConfig$1()); +const loadRegisteredDiagrams = async () => { + log$1.debug(`Loading registered diagrams`); + const results = await Promise.allSettled( + Object.entries(detectors).map(async ([key, { detector: detector2, loader: loader2 }]) => { + if (loader2) { + try { + getDiagram(key); + } catch (error) { + try { + const { diagram: diagram2, id: id2 } = await loader2(); + registerDiagram(id2, diagram2, detector2); + } catch (err) { + log$1.error(`Failed to load external diagram with key ${key}. Removing from detectors.`); + delete detectors[key]; + throw err; + } + } + } + }) + ); + const failed = results.filter((result) => result.status === "rejected"); + if (failed.length > 0) { + log$1.error(`Failed to load ${failed.length} external diagrams`); + for (const res of failed) { + log$1.error(res); + } + throw new Error(`Failed to load ${failed.length} external diagrams`); + } +}; +const handleError = (error, errors, parseError) => { + log$1.warn(error); + if (isDetailedError(error)) { + if (parseError) { + parseError(error.str, error.hash); + } + errors.push({ ...error, message: error.str, error }); + } else { + if (parseError) { + parseError(error); + } + if (error instanceof Error) { + errors.push({ + str: error.message, + message: error.message, + hash: error.name, + error + }); + } + } +}; +const run = async function(options = { + querySelector: ".mermaid" +}) { + try { + await runThrowsErrors(options); + } catch (e) { + if (isDetailedError(e)) { + log$1.error(e.str); + } + if (mermaid.parseError) { + mermaid.parseError(e); + } + if (!options.suppressErrors) { + log$1.error("Use the suppressErrors option to suppress these errors"); + throw e; + } + } +}; +const runThrowsErrors = async function({ postRenderCallback, querySelector, nodes } = { + querySelector: ".mermaid" +}) { + const conf = mermaidAPI.getConfig(); + log$1.debug(`${!postRenderCallback ? "No " : ""}Callback function found`); + let nodesToProcess; + if (nodes) { + nodesToProcess = nodes; + } else if (querySelector) { + nodesToProcess = document.querySelectorAll(querySelector); + } else { + throw new Error("Nodes and querySelector are both undefined"); + } + log$1.debug(`Found ${nodesToProcess.length} diagrams`); + if ((conf == null ? void 0 : conf.startOnLoad) !== void 0) { + log$1.debug("Start On Load: " + (conf == null ? void 0 : conf.startOnLoad)); + mermaidAPI.updateSiteConfig({ startOnLoad: conf == null ? void 0 : conf.startOnLoad }); + } + const idGenerator = new utils.InitIDGenerator(conf.deterministicIds, conf.deterministicIDSeed); + let txt; + const errors = []; + for (const element of Array.from(nodesToProcess)) { + log$1.info("Rendering diagram: " + element.id); + /*! Check if previously processed */ + if (element.getAttribute("data-processed")) { + continue; + } + element.setAttribute("data-processed", "true"); + const id2 = `mermaid-${idGenerator.next()}`; + txt = element.innerHTML; + txt = dedent(utils.entityDecode(txt)).trim().replace(//gi, "
    "); + const init2 = utils.detectInit(txt); + if (init2) { + log$1.debug("Detected early reinit: ", init2); + } + try { + const { svg: svg2, bindFunctions } = await render(id2, txt, element); + element.innerHTML = svg2; + if (postRenderCallback) { + await postRenderCallback(id2); + } + if (bindFunctions) { + bindFunctions(element); + } + } catch (error) { + handleError(error, errors, mermaid.parseError); + } + } + if (errors.length > 0) { + throw errors[0]; + } +}; +const initialize = function(config2) { + mermaidAPI.initialize(config2); +}; +const init = async function(config2, nodes, callback) { + log$1.warn("mermaid.init is deprecated. Please use run instead."); + if (config2) { + initialize(config2); + } + const runOptions = { postRenderCallback: callback, querySelector: ".mermaid" }; + if (typeof nodes === "string") { + runOptions.querySelector = nodes; + } else if (nodes) { + if (nodes instanceof HTMLElement) { + runOptions.nodes = [nodes]; + } else { + runOptions.nodes = nodes; + } + } + await run(runOptions); +}; +const registerExternalDiagrams = async (diagrams2, { + lazyLoad = true +} = {}) => { + registerLazyLoadedDiagrams(...diagrams2); + if (lazyLoad === false) { + await loadRegisteredDiagrams(); + } +}; +const contentLoaded = function() { + if (mermaid.startOnLoad) { + const { startOnLoad } = mermaidAPI.getConfig(); + if (startOnLoad) { + mermaid.run().catch((err) => log$1.error("Mermaid failed to initialize", err)); + } + } +}; +if (typeof document !== "undefined") { + /*! + * Wait for document loaded before starting the execution + */ + window.addEventListener("load", contentLoaded, false); +} +const setParseErrorHandler = function(parseErrorHandler) { + mermaid.parseError = parseErrorHandler; +}; +const executionQueue = []; +let executionQueueRunning = false; +const executeQueue = async () => { + if (executionQueueRunning) { + return; + } + executionQueueRunning = true; + while (executionQueue.length > 0) { + const f = executionQueue.shift(); + if (f) { + try { + await f(); + } catch (e) { + log$1.error("Error executing queue", e); + } + } + } + executionQueueRunning = false; +}; +const parse = async (text2, parseOptions) => { + return new Promise((resolve, reject) => { + const performCall = () => new Promise((res, rej) => { + mermaidAPI.parse(text2, parseOptions).then( + (r) => { + res(r); + resolve(r); + }, + (e) => { + var _a; + log$1.error("Error parsing", e); + (_a = mermaid.parseError) == null ? void 0 : _a.call(mermaid, e); + rej(e); + reject(e); + } + ); + }); + executionQueue.push(performCall); + executeQueue().catch(reject); + }); +}; +const render = (id2, text2, container) => { + return new Promise((resolve, reject) => { + const performCall = () => new Promise((res, rej) => { + mermaidAPI.render(id2, text2, container).then( + (r) => { + res(r); + resolve(r); + }, + (e) => { + var _a; + log$1.error("Error parsing", e); + (_a = mermaid.parseError) == null ? void 0 : _a.call(mermaid, e); + rej(e); + reject(e); + } + ); + }); + executionQueue.push(performCall); + executeQueue().catch(reject); + }); +}; +const mermaid = { + startOnLoad: true, + mermaidAPI, + parse, + render, + init, + run, + registerExternalDiagrams, + initialize, + parseError: void 0, + contentLoaded, + setParseErrorHandler, + detectType +}; +export { + constant$1 as $, + utils as A, + rgba$1 as B, + setDiagramTitle as C, + getDiagramTitle as D, + clear as E, + curveBasis as F, + parseGenericTypes as G, + random as H, + setupGraphViewbox as I, + define as J, + extend$1 as K, + Color$2 as L, + rgbConvert as M, + nogamma as N, + hue as O, + commonjsGlobal as P, + getDefaultExportFromCjs as Q, + Rgb as R, + Selection$1 as S, + dayjs as T, + selectSvgElement as U, + tau as V, + defaultConfig$2 as W, + cleanAndMerge as X, + parseFontSize as Y, + getThemeVariables$2 as Z, + getConfig$1 as _, + getAccDescription as a, + Stack as a$, + interpolateNumber as a0, + color as a1, + interpolateRgb as a2, + interpolateString as a3, + hasKatex as a4, + ZERO_WIDTH_SPACE as a5, + calculateMathMLDimensions as a6, + generateId as a7, + isObject$1 as a8, + setToString$1 as a9, + epsilon as aA, + sqrt as aB, + min as aC, + abs$1 as aD, + atan2 as aE, + asin as aF, + acos as aG, + max as aH, + _ as aI, + Color$1 as aJ, + isObjectLike as aK, + baseGetTag as aL, + Symbol$2 as aM, + arrayLikeKeys as aN, + baseKeys as aO, + memoize as aP, + isArguments$1 as aQ, + copyObject as aR, + getPrototype$1 as aS, + cloneArrayBuffer as aT, + cloneTypedArray as aU, + getTag$1 as aV, + nodeUtil$1 as aW, + copyArray as aX, + isBuffer$1 as aY, + cloneBuffer as aZ, + initCloneObject as a_, + overRest as aa, + root$1 as ab, + baseRest as ac, + isIterateeCall as ad, + keysIn as ae, + eq as af, + isArrayLike as ag, + isArray$1 as ah, + baseFor$1 as ai, + baseAssignValue as aj, + identity as ak, + isIndex as al, + assignValue as am, + baseUnary as an, + constant as ao, + merge$2 as ap, + lineBreakRegex as aq, + defaultConfig as ar, + commonDb as as, + isDark$1 as at, + lighten$1 as au, + darken$1 as av, + pi as aw, + cos as ax, + sin as ay, + halfPi as az, + setAccDescription as b, + MapCache as b0, + Uint8Array$2 as b1, + isTypedArray$1 as b2, + isLength as b3, + Set$2 as b4, + isArrayLikeObject as b5, + isEmpty as b6, + decodeEntities as b7, + dedent as b8, + mermaid as b9, + getConfig as c, + sanitizeText$2 as d, + dist as e, + common$1 as f, + getAccTitle as g, + assignWithDepth$1 as h, + calculateTextWidth as i, + d3select as j, + configureSvgSize as k, + log$1 as l, + calculateTextHeight as m, + curveLinear as n, + getStylesFromArray as o, + evaluate as p, + interpolateToCurve as q, + renderKatex as r, + setAccTitle as s, + setupGraphViewbox$1 as t, + setConfig as u, + root$2 as v, + wrapLabel as w, + array as x, + isPlainObject as y, + isFunction as z +}; diff --git a/0.6.0/js/mermaid/mermaid.core.mjs b/0.6.0/js/mermaid/mermaid.core.mjs new file mode 100644 index 0000000..ba36250 --- /dev/null +++ b/0.6.0/js/mermaid/mermaid.core.mjs @@ -0,0 +1,14 @@ +import "ts-dedent"; +import { N } from "./mermaid-6dc72991.js"; +import "dayjs"; +import "@braintree/sanitize-url"; +import "d3"; +import "dompurify"; +import "khroma"; +import "lodash-es/memoize.js"; +import "lodash-es/merge.js"; +import "stylis"; +import "lodash-es/isEmpty.js"; +export { + N as default +}; diff --git a/0.6.0/js/mermaid/mermaid.esm.min.mjs b/0.6.0/js/mermaid/mermaid.esm.min.mjs new file mode 100644 index 0000000..0eb454a --- /dev/null +++ b/0.6.0/js/mermaid/mermaid.esm.min.mjs @@ -0,0 +1,4 @@ +import { b9 as f } from "./mermaid-9f2aa176.js"; +export { + f as default +}; diff --git a/0.6.0/js/mermaid/mermaid.esm.mjs b/0.6.0/js/mermaid/mermaid.esm.mjs new file mode 100644 index 0000000..1638bb6 --- /dev/null +++ b/0.6.0/js/mermaid/mermaid.esm.mjs @@ -0,0 +1,4 @@ +import { b9 } from "./mermaid-dcacb631.js"; +export { + b9 as default +}; diff --git a/0.6.0/js/mermaid/mermaid.js b/0.6.0/js/mermaid/mermaid.js new file mode 100644 index 0000000..97b1ac2 --- /dev/null +++ b/0.6.0/js/mermaid/mermaid.js @@ -0,0 +1,195755 @@ +(function(global2, factory) { + typeof exports === "object" && typeof module !== "undefined" ? module.exports = factory() : typeof define === "function" && define.amd ? define(factory) : (global2 = typeof globalThis !== "undefined" ? globalThis : global2 || self, global2.mermaid = factory()); +})(this, function() { + var _a, _b; + "use strict"; + function dedent(templ) { + var values2 = []; + for (var _i6 = 1; _i6 < arguments.length; _i6++) { + values2[_i6 - 1] = arguments[_i6]; + } + var strings = Array.from(typeof templ === "string" ? [templ] : templ); + strings[strings.length - 1] = strings[strings.length - 1].replace(/\r?\n([\t ]*)$/, ""); + var indentLengths = strings.reduce(function(arr, str2) { + var matches = str2.match(/\n([\t ]+|(?!\s).)/g); + if (matches) { + return arr.concat(matches.map(function(match) { + var _a2, _b2; + return (_b2 = (_a2 = match.match(/[\t ]/g)) === null || _a2 === void 0 ? void 0 : _a2.length) !== null && _b2 !== void 0 ? _b2 : 0; + })); + } + return arr; + }, []); + if (indentLengths.length) { + var pattern_1 = new RegExp("\n[ ]{" + Math.min.apply(Math, indentLengths) + "}", "g"); + strings = strings.map(function(str2) { + return str2.replace(pattern_1, "\n"); + }); + } + strings[0] = strings[0].replace(/^\r?\n/, ""); + var string2 = strings[0]; + values2.forEach(function(value2, i2) { + var endentations = string2.match(/(?:^|\n)( *)$/); + var endentation = endentations ? endentations[1] : ""; + var indentedValue = value2; + if (typeof value2 === "string" && value2.includes("\n")) { + indentedValue = String(value2).split("\n").map(function(str2, i3) { + return i3 === 0 ? str2 : "" + endentation + str2; + }).join("\n"); + } + string2 += indentedValue + strings[i2 + 1]; + }); + return string2; + } + var commonjsGlobal = typeof globalThis !== "undefined" ? globalThis : typeof window !== "undefined" ? window : typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : {}; + function getDefaultExportFromCjs(x2) { + return x2 && x2.__esModule && Object.prototype.hasOwnProperty.call(x2, "default") ? x2["default"] : x2; + } + var dayjs_min = { exports: {} }; + (function(module2, exports2) { + !function(t, e) { + module2.exports = e(); + }(commonjsGlobal, function() { + var t = 1e3, e = 6e4, n = 36e5, r = "millisecond", i2 = "second", s = "minute", u = "hour", a = "day", o = "week", c2 = "month", f2 = "quarter", h = "year", d = "date", l = "Invalid Date", $ = /^(\d{4})[-/]?(\d{1,2})?[-/]?(\d{0,2})[Tt\s]*(\d{1,2})?:?(\d{1,2})?:?(\d{1,2})?[.:]?(\d+)?$/, y2 = /\[([^\]]+)]|Y{1,4}|M{1,4}|D{1,2}|d{1,4}|H{1,2}|h{1,2}|a|A|m{1,2}|s{1,2}|Z{1,2}|SSS/g, M = { name: "en", weekdays: "Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday".split("_"), months: "January_February_March_April_May_June_July_August_September_October_November_December".split("_"), ordinal: function(t4) { + var e3 = ["th", "st", "nd", "rd"], n2 = t4 % 100; + return "[" + t4 + (e3[(n2 - 20) % 10] || e3[n2] || e3[0]) + "]"; + } }, m = function(t4, e3, n2) { + var r2 = String(t4); + return !r2 || r2.length >= e3 ? t4 : "" + Array(e3 + 1 - r2.length).join(n2) + t4; + }, v = { s: m, z: function(t4) { + var e3 = -t4.utcOffset(), n2 = Math.abs(e3), r2 = Math.floor(n2 / 60), i3 = n2 % 60; + return (e3 <= 0 ? "+" : "-") + m(r2, 2, "0") + ":" + m(i3, 2, "0"); + }, m: function t4(e3, n2) { + if (e3.date() < n2.date()) + return -t4(n2, e3); + var r2 = 12 * (n2.year() - e3.year()) + (n2.month() - e3.month()), i3 = e3.clone().add(r2, c2), s2 = n2 - i3 < 0, u2 = e3.clone().add(r2 + (s2 ? -1 : 1), c2); + return +(-(r2 + (n2 - i3) / (s2 ? i3 - u2 : u2 - i3)) || 0); + }, a: function(t4) { + return t4 < 0 ? Math.ceil(t4) || 0 : Math.floor(t4); + }, p: function(t4) { + return { M: c2, y: h, w: o, d: a, D: d, h: u, m: s, s: i2, ms: r, Q: f2 }[t4] || String(t4 || "").toLowerCase().replace(/s$/, ""); + }, u: function(t4) { + return void 0 === t4; + } }, g = "en", D2 = {}; + D2[g] = M; + var p = "$isDayjsObject", S2 = function(t4) { + return t4 instanceof _2 || !(!t4 || !t4[p]); + }, w2 = function t4(e3, n2, r2) { + var i3; + if (!e3) + return g; + if ("string" == typeof e3) { + var s2 = e3.toLowerCase(); + D2[s2] && (i3 = s2), n2 && (D2[s2] = n2, i3 = s2); + var u2 = e3.split("-"); + if (!i3 && u2.length > 1) + return t4(u2[0]); + } else { + var a2 = e3.name; + D2[a2] = e3, i3 = a2; + } + return !r2 && i3 && (g = i3), i3 || !r2 && g; + }, O = function(t4, e3) { + if (S2(t4)) + return t4.clone(); + var n2 = "object" == typeof e3 ? e3 : {}; + return n2.date = t4, n2.args = arguments, new _2(n2); + }, b = v; + b.l = w2, b.i = S2, b.w = function(t4, e3) { + return O(t4, { locale: e3.$L, utc: e3.$u, x: e3.$x, $offset: e3.$offset }); + }; + var _2 = function() { + function M2(t4) { + this.$L = w2(t4.locale, null, true), this.parse(t4), this.$x = this.$x || t4.x || {}, this[p] = true; + } + var m2 = M2.prototype; + return m2.parse = function(t4) { + this.$d = function(t5) { + var e3 = t5.date, n2 = t5.utc; + if (null === e3) + return /* @__PURE__ */ new Date(NaN); + if (b.u(e3)) + return /* @__PURE__ */ new Date(); + if (e3 instanceof Date) + return new Date(e3); + if ("string" == typeof e3 && !/Z$/i.test(e3)) { + var r2 = e3.match($); + if (r2) { + var i3 = r2[2] - 1 || 0, s2 = (r2[7] || "0").substring(0, 3); + return n2 ? new Date(Date.UTC(r2[1], i3, r2[3] || 1, r2[4] || 0, r2[5] || 0, r2[6] || 0, s2)) : new Date(r2[1], i3, r2[3] || 1, r2[4] || 0, r2[5] || 0, r2[6] || 0, s2); + } + } + return new Date(e3); + }(t4), this.init(); + }, m2.init = function() { + var t4 = this.$d; + this.$y = t4.getFullYear(), this.$M = t4.getMonth(), this.$D = t4.getDate(), this.$W = t4.getDay(), this.$H = t4.getHours(), this.$m = t4.getMinutes(), this.$s = t4.getSeconds(), this.$ms = t4.getMilliseconds(); + }, m2.$utils = function() { + return b; + }, m2.isValid = function() { + return !(this.$d.toString() === l); + }, m2.isSame = function(t4, e3) { + var n2 = O(t4); + return this.startOf(e3) <= n2 && n2 <= this.endOf(e3); + }, m2.isAfter = function(t4, e3) { + return O(t4) < this.startOf(e3); + }, m2.isBefore = function(t4, e3) { + return this.endOf(e3) < O(t4); + }, m2.$g = function(t4, e3, n2) { + return b.u(t4) ? this[e3] : this.set(n2, t4); + }, m2.unix = function() { + return Math.floor(this.valueOf() / 1e3); + }, m2.valueOf = function() { + return this.$d.getTime(); + }, m2.startOf = function(t4, e3) { + var n2 = this, r2 = !!b.u(e3) || e3, f3 = b.p(t4), l2 = function(t5, e4) { + var i3 = b.w(n2.$u ? Date.UTC(n2.$y, e4, t5) : new Date(n2.$y, e4, t5), n2); + return r2 ? i3 : i3.endOf(a); + }, $2 = function(t5, e4) { + return b.w(n2.toDate()[t5].apply(n2.toDate("s"), (r2 ? [0, 0, 0, 0] : [23, 59, 59, 999]).slice(e4)), n2); + }, y3 = this.$W, M3 = this.$M, m3 = this.$D, v2 = "set" + (this.$u ? "UTC" : ""); + switch (f3) { + case h: + return r2 ? l2(1, 0) : l2(31, 11); + case c2: + return r2 ? l2(1, M3) : l2(0, M3 + 1); + case o: + var g2 = this.$locale().weekStart || 0, D3 = (y3 < g2 ? y3 + 7 : y3) - g2; + return l2(r2 ? m3 - D3 : m3 + (6 - D3), M3); + case a: + case d: + return $2(v2 + "Hours", 0); + case u: + return $2(v2 + "Minutes", 1); + case s: + return $2(v2 + "Seconds", 2); + case i2: + return $2(v2 + "Milliseconds", 3); + default: + return this.clone(); + } + }, m2.endOf = function(t4) { + return this.startOf(t4, false); + }, m2.$set = function(t4, e3) { + var n2, o2 = b.p(t4), f3 = "set" + (this.$u ? "UTC" : ""), l2 = (n2 = {}, n2[a] = f3 + "Date", n2[d] = f3 + "Date", n2[c2] = f3 + "Month", n2[h] = f3 + "FullYear", n2[u] = f3 + "Hours", n2[s] = f3 + "Minutes", n2[i2] = f3 + "Seconds", n2[r] = f3 + "Milliseconds", n2)[o2], $2 = o2 === a ? this.$D + (e3 - this.$W) : e3; + if (o2 === c2 || o2 === h) { + var y3 = this.clone().set(d, 1); + y3.$d[l2]($2), y3.init(), this.$d = y3.set(d, Math.min(this.$D, y3.daysInMonth())).$d; + } else + l2 && this.$d[l2]($2); + return this.init(), this; + }, m2.set = function(t4, e3) { + return this.clone().$set(t4, e3); + }, m2.get = function(t4) { + return this[b.p(t4)](); + }, m2.add = function(r2, f3) { + var d2, l2 = this; + r2 = Number(r2); + var $2 = b.p(f3), y3 = function(t4) { + var e3 = O(l2); + return b.w(e3.date(e3.date() + Math.round(t4 * r2)), l2); + }; + if ($2 === c2) + return this.set(c2, this.$M + r2); + if ($2 === h) + return this.set(h, this.$y + r2); + if ($2 === a) + return y3(1); + if ($2 === o) + return y3(7); + var M3 = (d2 = {}, d2[s] = e, d2[u] = n, d2[i2] = t, d2)[$2] || 1, m3 = this.$d.getTime() + r2 * M3; + return b.w(m3, this); + }, m2.subtract = function(t4, e3) { + return this.add(-1 * t4, e3); + }, m2.format = function(t4) { + var e3 = this, n2 = this.$locale(); + if (!this.isValid()) + return n2.invalidDate || l; + var r2 = t4 || "YYYY-MM-DDTHH:mm:ssZ", i3 = b.z(this), s2 = this.$H, u2 = this.$m, a2 = this.$M, o2 = n2.weekdays, c3 = n2.months, f3 = n2.meridiem, h2 = function(t5, n3, i4, s3) { + return t5 && (t5[n3] || t5(e3, r2)) || i4[n3].slice(0, s3); + }, d2 = function(t5) { + return b.s(s2 % 12 || 12, t5, "0"); + }, $2 = f3 || function(t5, e4, n3) { + var r3 = t5 < 12 ? "AM" : "PM"; + return n3 ? r3.toLowerCase() : r3; + }; + return r2.replace(y2, function(t5, r3) { + return r3 || function(t6) { + switch (t6) { + case "YY": + return String(e3.$y).slice(-2); + case "YYYY": + return b.s(e3.$y, 4, "0"); + case "M": + return a2 + 1; + case "MM": + return b.s(a2 + 1, 2, "0"); + case "MMM": + return h2(n2.monthsShort, a2, c3, 3); + case "MMMM": + return h2(c3, a2); + case "D": + return e3.$D; + case "DD": + return b.s(e3.$D, 2, "0"); + case "d": + return String(e3.$W); + case "dd": + return h2(n2.weekdaysMin, e3.$W, o2, 2); + case "ddd": + return h2(n2.weekdaysShort, e3.$W, o2, 3); + case "dddd": + return o2[e3.$W]; + case "H": + return String(s2); + case "HH": + return b.s(s2, 2, "0"); + case "h": + return d2(1); + case "hh": + return d2(2); + case "a": + return $2(s2, u2, true); + case "A": + return $2(s2, u2, false); + case "m": + return String(u2); + case "mm": + return b.s(u2, 2, "0"); + case "s": + return String(e3.$s); + case "ss": + return b.s(e3.$s, 2, "0"); + case "SSS": + return b.s(e3.$ms, 3, "0"); + case "Z": + return i3; + } + return null; + }(t5) || i3.replace(":", ""); + }); + }, m2.utcOffset = function() { + return 15 * -Math.round(this.$d.getTimezoneOffset() / 15); + }, m2.diff = function(r2, d2, l2) { + var $2, y3 = this, M3 = b.p(d2), m3 = O(r2), v2 = (m3.utcOffset() - this.utcOffset()) * e, g2 = this - m3, D3 = function() { + return b.m(y3, m3); + }; + switch (M3) { + case h: + $2 = D3() / 12; + break; + case c2: + $2 = D3(); + break; + case f2: + $2 = D3() / 3; + break; + case o: + $2 = (g2 - v2) / 6048e5; + break; + case a: + $2 = (g2 - v2) / 864e5; + break; + case u: + $2 = g2 / n; + break; + case s: + $2 = g2 / e; + break; + case i2: + $2 = g2 / t; + break; + default: + $2 = g2; + } + return l2 ? $2 : b.a($2); + }, m2.daysInMonth = function() { + return this.endOf(c2).$D; + }, m2.$locale = function() { + return D2[this.$L]; + }, m2.locale = function(t4, e3) { + if (!t4) + return this.$L; + var n2 = this.clone(), r2 = w2(t4, e3, true); + return r2 && (n2.$L = r2), n2; + }, m2.clone = function() { + return b.w(this.$d, this); + }, m2.toDate = function() { + return new Date(this.valueOf()); + }, m2.toJSON = function() { + return this.isValid() ? this.toISOString() : null; + }, m2.toISOString = function() { + return this.$d.toISOString(); + }, m2.toString = function() { + return this.$d.toUTCString(); + }, M2; + }(), k = _2.prototype; + return O.prototype = k, [["$ms", r], ["$s", i2], ["$m", s], ["$H", u], ["$W", a], ["$M", c2], ["$y", h], ["$D", d]].forEach(function(t4) { + k[t4[1]] = function(e3) { + return this.$g(e3, t4[0], t4[1]); + }; + }), O.extend = function(t4, e3) { + return t4.$i || (t4(e3, _2, O), t4.$i = true), O; + }, O.locale = w2, O.isDayjs = S2, O.unix = function(t4) { + return O(1e3 * t4); + }, O.en = D2[g], O.Ls = D2, O.p = {}, O; + }); + })(dayjs_min); + var dayjs_minExports = dayjs_min.exports; + const dayjs = /* @__PURE__ */ getDefaultExportFromCjs(dayjs_minExports); + const LEVELS = { + trace: 0, + debug: 1, + info: 2, + warn: 3, + error: 4, + fatal: 5 + }; + const log$1 = { + trace: (..._args) => { + }, + debug: (..._args) => { + }, + info: (..._args) => { + }, + warn: (..._args) => { + }, + error: (..._args) => { + }, + fatal: (..._args) => { + } + }; + const setLogLevel$1 = function(level = "fatal") { + let numericLevel = LEVELS.fatal; + if (typeof level === "string") { + level = level.toLowerCase(); + if (level in LEVELS) { + numericLevel = LEVELS[level]; + } + } else if (typeof level === "number") { + numericLevel = level; + } + log$1.trace = () => { + }; + log$1.debug = () => { + }; + log$1.info = () => { + }; + log$1.warn = () => { + }; + log$1.error = () => { + }; + log$1.fatal = () => { + }; + if (numericLevel <= LEVELS.fatal) { + log$1.fatal = console.error ? console.error.bind(console, format$1("FATAL"), "color: orange") : console.log.bind(console, "\x1B[35m", format$1("FATAL")); + } + if (numericLevel <= LEVELS.error) { + log$1.error = console.error ? console.error.bind(console, format$1("ERROR"), "color: orange") : console.log.bind(console, "\x1B[31m", format$1("ERROR")); + } + if (numericLevel <= LEVELS.warn) { + log$1.warn = console.warn ? console.warn.bind(console, format$1("WARN"), "color: orange") : console.log.bind(console, `\x1B[33m`, format$1("WARN")); + } + if (numericLevel <= LEVELS.info) { + log$1.info = console.info ? console.info.bind(console, format$1("INFO"), "color: lightblue") : console.log.bind(console, "\x1B[34m", format$1("INFO")); + } + if (numericLevel <= LEVELS.debug) { + log$1.debug = console.debug ? console.debug.bind(console, format$1("DEBUG"), "color: lightgreen") : console.log.bind(console, "\x1B[32m", format$1("DEBUG")); + } + if (numericLevel <= LEVELS.trace) { + log$1.trace = console.debug ? console.debug.bind(console, format$1("TRACE"), "color: lightgreen") : console.log.bind(console, "\x1B[32m", format$1("TRACE")); + } + }; + const format$1 = (level) => { + const time2 = dayjs().format("ss.SSS"); + return `%c${time2} : ${level} : `; + }; + var dist = {}; + (function(exports2) { + Object.defineProperty(exports2, "__esModule", { value: true }); + exports2.sanitizeUrl = exports2.BLANK_URL = void 0; + var invalidProtocolRegex = /^([^\w]*)(javascript|data|vbscript)/im; + var htmlEntitiesRegex = /&#(\w+)(^\w|;)?/g; + var htmlCtrlEntityRegex = /&(newline|tab);/gi; + var ctrlCharactersRegex = /[\u0000-\u001F\u007F-\u009F\u2000-\u200D\uFEFF]/gim; + var urlSchemeRegex = /^.+(:|:)/gim; + var relativeFirstCharacters = [".", "/"]; + exports2.BLANK_URL = "about:blank"; + function isRelativeUrlWithoutProtocol(url) { + return relativeFirstCharacters.indexOf(url[0]) > -1; + } + function decodeHtmlCharacters(str2) { + var removedNullByte = str2.replace(ctrlCharactersRegex, ""); + return removedNullByte.replace(htmlEntitiesRegex, function(match, dec) { + return String.fromCharCode(dec); + }); + } + function sanitizeUrl(url) { + if (!url) { + return exports2.BLANK_URL; + } + var sanitizedUrl = decodeHtmlCharacters(url).replace(htmlCtrlEntityRegex, "").replace(ctrlCharactersRegex, "").trim(); + if (!sanitizedUrl) { + return exports2.BLANK_URL; + } + if (isRelativeUrlWithoutProtocol(sanitizedUrl)) { + return sanitizedUrl; + } + var urlSchemeParseResults = sanitizedUrl.match(urlSchemeRegex); + if (!urlSchemeParseResults) { + return sanitizedUrl; + } + var urlScheme = urlSchemeParseResults[0]; + if (invalidProtocolRegex.test(urlScheme)) { + return exports2.BLANK_URL; + } + return sanitizedUrl; + } + exports2.sanitizeUrl = sanitizeUrl; + })(dist); + function ascending$1(a, b) { + return a == null || b == null ? NaN : a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN; + } + function descending$1(a, b) { + return a == null || b == null ? NaN : b < a ? -1 : b > a ? 1 : b >= a ? 0 : NaN; + } + function bisector(f2) { + let compare1, compare2, delta; + if (f2.length !== 2) { + compare1 = ascending$1; + compare2 = (d, x2) => ascending$1(f2(d), x2); + delta = (d, x2) => f2(d) - x2; + } else { + compare1 = f2 === ascending$1 || f2 === descending$1 ? f2 : zero$1; + compare2 = f2; + delta = f2; + } + function left2(a, x2, lo = 0, hi = a.length) { + if (lo < hi) { + if (compare1(x2, x2) !== 0) + return hi; + do { + const mid = lo + hi >>> 1; + if (compare2(a[mid], x2) < 0) + lo = mid + 1; + else + hi = mid; + } while (lo < hi); + } + return lo; + } + function right2(a, x2, lo = 0, hi = a.length) { + if (lo < hi) { + if (compare1(x2, x2) !== 0) + return hi; + do { + const mid = lo + hi >>> 1; + if (compare2(a[mid], x2) <= 0) + lo = mid + 1; + else + hi = mid; + } while (lo < hi); + } + return lo; + } + function center2(a, x2, lo = 0, hi = a.length) { + const i2 = left2(a, x2, lo, hi - 1); + return i2 > lo && delta(a[i2 - 1], x2) > -delta(a[i2], x2) ? i2 - 1 : i2; + } + return { left: left2, center: center2, right: right2 }; + } + function zero$1() { + return 0; + } + function number$3(x2) { + return x2 === null ? NaN : +x2; + } + const ascendingBisect = bisector(ascending$1); + const bisectRight = ascendingBisect.right; + bisector(number$3).center; + const bisect = bisectRight; + class InternMap extends Map { + constructor(entries2, key = keyof) { + super(); + Object.defineProperties(this, { _intern: { value: /* @__PURE__ */ new Map() }, _key: { value: key } }); + if (entries2 != null) + for (const [key2, value2] of entries2) + this.set(key2, value2); + } + get(key) { + return super.get(intern_get(this, key)); + } + has(key) { + return super.has(intern_get(this, key)); + } + set(key, value2) { + return super.set(intern_set(this, key), value2); + } + delete(key) { + return super.delete(intern_delete(this, key)); + } + } + function intern_get({ _intern, _key }, value2) { + const key = _key(value2); + return _intern.has(key) ? _intern.get(key) : value2; + } + function intern_set({ _intern, _key }, value2) { + const key = _key(value2); + if (_intern.has(key)) + return _intern.get(key); + _intern.set(key, value2); + return value2; + } + function intern_delete({ _intern, _key }, value2) { + const key = _key(value2); + if (_intern.has(key)) { + value2 = _intern.get(key); + _intern.delete(key); + } + return value2; + } + function keyof(value2) { + return value2 !== null && typeof value2 === "object" ? value2.valueOf() : value2; + } + const e10 = Math.sqrt(50), e5 = Math.sqrt(10), e2 = Math.sqrt(2); + function tickSpec(start2, stop, count) { + const step = (stop - start2) / Math.max(0, count), power = Math.floor(Math.log10(step)), error = step / Math.pow(10, power), factor = error >= e10 ? 10 : error >= e5 ? 5 : error >= e2 ? 2 : 1; + let i1, i2, inc; + if (power < 0) { + inc = Math.pow(10, -power) / factor; + i1 = Math.round(start2 * inc); + i2 = Math.round(stop * inc); + if (i1 / inc < start2) + ++i1; + if (i2 / inc > stop) + --i2; + inc = -inc; + } else { + inc = Math.pow(10, power) * factor; + i1 = Math.round(start2 / inc); + i2 = Math.round(stop / inc); + if (i1 * inc < start2) + ++i1; + if (i2 * inc > stop) + --i2; + } + if (i2 < i1 && 0.5 <= count && count < 2) + return tickSpec(start2, stop, count * 2); + return [i1, i2, inc]; + } + function ticks(start2, stop, count) { + stop = +stop, start2 = +start2, count = +count; + if (!(count > 0)) + return []; + if (start2 === stop) + return [start2]; + const reverse = stop < start2, [i1, i2, inc] = reverse ? tickSpec(stop, start2, count) : tickSpec(start2, stop, count); + if (!(i2 >= i1)) + return []; + const n = i2 - i1 + 1, ticks2 = new Array(n); + if (reverse) { + if (inc < 0) + for (let i3 = 0; i3 < n; ++i3) + ticks2[i3] = (i2 - i3) / -inc; + else + for (let i3 = 0; i3 < n; ++i3) + ticks2[i3] = (i2 - i3) * inc; + } else { + if (inc < 0) + for (let i3 = 0; i3 < n; ++i3) + ticks2[i3] = (i1 + i3) / -inc; + else + for (let i3 = 0; i3 < n; ++i3) + ticks2[i3] = (i1 + i3) * inc; + } + return ticks2; + } + function tickIncrement(start2, stop, count) { + stop = +stop, start2 = +start2, count = +count; + return tickSpec(start2, stop, count)[2]; + } + function tickStep(start2, stop, count) { + stop = +stop, start2 = +start2, count = +count; + const reverse = stop < start2, inc = reverse ? tickIncrement(stop, start2, count) : tickIncrement(start2, stop, count); + return (reverse ? -1 : 1) * (inc < 0 ? 1 / -inc : inc); + } + function max$3(values2, valueof) { + let max2; + if (valueof === void 0) { + for (const value2 of values2) { + if (value2 != null && (max2 < value2 || max2 === void 0 && value2 >= value2)) { + max2 = value2; + } + } + } else { + let index2 = -1; + for (let value2 of values2) { + if ((value2 = valueof(value2, ++index2, values2)) != null && (max2 < value2 || max2 === void 0 && value2 >= value2)) { + max2 = value2; + } + } + } + return max2; + } + function min$3(values2, valueof) { + let min2; + if (valueof === void 0) { + for (const value2 of values2) { + if (value2 != null && (min2 > value2 || min2 === void 0 && value2 >= value2)) { + min2 = value2; + } + } + } else { + let index2 = -1; + for (let value2 of values2) { + if ((value2 = valueof(value2, ++index2, values2)) != null && (min2 > value2 || min2 === void 0 && value2 >= value2)) { + min2 = value2; + } + } + } + return min2; + } + function range$2(start2, stop, step) { + start2 = +start2, stop = +stop, step = (n = arguments.length) < 2 ? (stop = start2, start2 = 0, 1) : n < 3 ? 1 : +step; + var i2 = -1, n = Math.max(0, Math.ceil((stop - start2) / step)) | 0, range2 = new Array(n); + while (++i2 < n) { + range2[i2] = start2 + i2 * step; + } + return range2; + } + function identity$5(x2) { + return x2; + } + var top = 1, right$1 = 2, bottom = 3, left$1 = 4, epsilon$3 = 1e-6; + function translateX(x2) { + return "translate(" + x2 + ",0)"; + } + function translateY(y2) { + return "translate(0," + y2 + ")"; + } + function number$2(scale) { + return (d) => +scale(d); + } + function center$1(scale, offset) { + offset = Math.max(0, scale.bandwidth() - offset * 2) / 2; + if (scale.round()) + offset = Math.round(offset); + return (d) => +scale(d) + offset; + } + function entering() { + return !this.__axis; + } + function axis(orient, scale) { + var tickArguments = [], tickValues = null, tickFormat2 = null, tickSizeInner = 6, tickSizeOuter = 6, tickPadding = 3, offset = typeof window !== "undefined" && window.devicePixelRatio > 1 ? 0 : 0.5, k = orient === top || orient === left$1 ? -1 : 1, x2 = orient === left$1 || orient === right$1 ? "x" : "y", transform = orient === top || orient === bottom ? translateX : translateY; + function axis2(context) { + var values2 = tickValues == null ? scale.ticks ? scale.ticks.apply(scale, tickArguments) : scale.domain() : tickValues, format2 = tickFormat2 == null ? scale.tickFormat ? scale.tickFormat.apply(scale, tickArguments) : identity$5 : tickFormat2, spacing2 = Math.max(tickSizeInner, 0) + tickPadding, range2 = scale.range(), range0 = +range2[0] + offset, range1 = +range2[range2.length - 1] + offset, position2 = (scale.bandwidth ? center$1 : number$2)(scale.copy(), offset), selection2 = context.selection ? context.selection() : context, path2 = selection2.selectAll(".domain").data([null]), tick = selection2.selectAll(".tick").data(values2, scale).order(), tickExit = tick.exit(), tickEnter = tick.enter().append("g").attr("class", "tick"), line2 = tick.select("line"), text2 = tick.select("text"); + path2 = path2.merge(path2.enter().insert("path", ".tick").attr("class", "domain").attr("stroke", "currentColor")); + tick = tick.merge(tickEnter); + line2 = line2.merge(tickEnter.append("line").attr("stroke", "currentColor").attr(x2 + "2", k * tickSizeInner)); + text2 = text2.merge(tickEnter.append("text").attr("fill", "currentColor").attr(x2, k * spacing2).attr("dy", orient === top ? "0em" : orient === bottom ? "0.71em" : "0.32em")); + if (context !== selection2) { + path2 = path2.transition(context); + tick = tick.transition(context); + line2 = line2.transition(context); + text2 = text2.transition(context); + tickExit = tickExit.transition(context).attr("opacity", epsilon$3).attr("transform", function(d) { + return isFinite(d = position2(d)) ? transform(d + offset) : this.getAttribute("transform"); + }); + tickEnter.attr("opacity", epsilon$3).attr("transform", function(d) { + var p = this.parentNode.__axis; + return transform((p && isFinite(p = p(d)) ? p : position2(d)) + offset); + }); + } + tickExit.remove(); + path2.attr("d", orient === left$1 || orient === right$1 ? tickSizeOuter ? "M" + k * tickSizeOuter + "," + range0 + "H" + offset + "V" + range1 + "H" + k * tickSizeOuter : "M" + offset + "," + range0 + "V" + range1 : tickSizeOuter ? "M" + range0 + "," + k * tickSizeOuter + "V" + offset + "H" + range1 + "V" + k * tickSizeOuter : "M" + range0 + "," + offset + "H" + range1); + tick.attr("opacity", 1).attr("transform", function(d) { + return transform(position2(d) + offset); + }); + line2.attr(x2 + "2", k * tickSizeInner); + text2.attr(x2, k * spacing2).text(format2); + selection2.filter(entering).attr("fill", "none").attr("font-size", 10).attr("font-family", "sans-serif").attr("text-anchor", orient === right$1 ? "start" : orient === left$1 ? "end" : "middle"); + selection2.each(function() { + this.__axis = position2; + }); + } + axis2.scale = function(_2) { + return arguments.length ? (scale = _2, axis2) : scale; + }; + axis2.ticks = function() { + return tickArguments = Array.from(arguments), axis2; + }; + axis2.tickArguments = function(_2) { + return arguments.length ? (tickArguments = _2 == null ? [] : Array.from(_2), axis2) : tickArguments.slice(); + }; + axis2.tickValues = function(_2) { + return arguments.length ? (tickValues = _2 == null ? null : Array.from(_2), axis2) : tickValues && tickValues.slice(); + }; + axis2.tickFormat = function(_2) { + return arguments.length ? (tickFormat2 = _2, axis2) : tickFormat2; + }; + axis2.tickSize = function(_2) { + return arguments.length ? (tickSizeInner = tickSizeOuter = +_2, axis2) : tickSizeInner; + }; + axis2.tickSizeInner = function(_2) { + return arguments.length ? (tickSizeInner = +_2, axis2) : tickSizeInner; + }; + axis2.tickSizeOuter = function(_2) { + return arguments.length ? (tickSizeOuter = +_2, axis2) : tickSizeOuter; + }; + axis2.tickPadding = function(_2) { + return arguments.length ? (tickPadding = +_2, axis2) : tickPadding; + }; + axis2.offset = function(_2) { + return arguments.length ? (offset = +_2, axis2) : offset; + }; + return axis2; + } + function axisTop(scale) { + return axis(top, scale); + } + function axisBottom(scale) { + return axis(bottom, scale); + } + var noop$2 = { value: () => { + } }; + function dispatch() { + for (var i2 = 0, n = arguments.length, _2 = {}, t; i2 < n; ++i2) { + if (!(t = arguments[i2] + "") || t in _2 || /[\s.]/.test(t)) + throw new Error("illegal type: " + t); + _2[t] = []; + } + return new Dispatch(_2); + } + function Dispatch(_2) { + this._ = _2; + } + function parseTypenames$1(typenames, types) { + return typenames.trim().split(/^|\s+/).map(function(t) { + var name = "", i2 = t.indexOf("."); + if (i2 >= 0) + name = t.slice(i2 + 1), t = t.slice(0, i2); + if (t && !types.hasOwnProperty(t)) + throw new Error("unknown type: " + t); + return { type: t, name }; + }); + } + Dispatch.prototype = dispatch.prototype = { + constructor: Dispatch, + on: function(typename, callback) { + var _2 = this._, T2 = parseTypenames$1(typename + "", _2), t, i2 = -1, n = T2.length; + if (arguments.length < 2) { + while (++i2 < n) + if ((t = (typename = T2[i2]).type) && (t = get$3(_2[t], typename.name))) + return t; + return; + } + if (callback != null && typeof callback !== "function") + throw new Error("invalid callback: " + callback); + while (++i2 < n) { + if (t = (typename = T2[i2]).type) + _2[t] = set$3(_2[t], typename.name, callback); + else if (callback == null) + for (t in _2) + _2[t] = set$3(_2[t], typename.name, null); + } + return this; + }, + copy: function() { + var copy2 = {}, _2 = this._; + for (var t in _2) + copy2[t] = _2[t].slice(); + return new Dispatch(copy2); + }, + call: function(type2, that) { + if ((n = arguments.length - 2) > 0) + for (var args = new Array(n), i2 = 0, n, t; i2 < n; ++i2) + args[i2] = arguments[i2 + 2]; + if (!this._.hasOwnProperty(type2)) + throw new Error("unknown type: " + type2); + for (t = this._[type2], i2 = 0, n = t.length; i2 < n; ++i2) + t[i2].value.apply(that, args); + }, + apply: function(type2, that, args) { + if (!this._.hasOwnProperty(type2)) + throw new Error("unknown type: " + type2); + for (var t = this._[type2], i2 = 0, n = t.length; i2 < n; ++i2) + t[i2].value.apply(that, args); + } + }; + function get$3(type2, name) { + for (var i2 = 0, n = type2.length, c2; i2 < n; ++i2) { + if ((c2 = type2[i2]).name === name) { + return c2.value; + } + } + } + function set$3(type2, name, callback) { + for (var i2 = 0, n = type2.length; i2 < n; ++i2) { + if (type2[i2].name === name) { + type2[i2] = noop$2, type2 = type2.slice(0, i2).concat(type2.slice(i2 + 1)); + break; + } + } + if (callback != null) + type2.push({ name, value: callback }); + return type2; + } + var xhtml = "http://www.w3.org/1999/xhtml"; + const namespaces$1 = { + svg: "http://www.w3.org/2000/svg", + xhtml, + xlink: "http://www.w3.org/1999/xlink", + xml: "http://www.w3.org/XML/1998/namespace", + xmlns: "http://www.w3.org/2000/xmlns/" + }; + function namespace(name) { + var prefix = name += "", i2 = prefix.indexOf(":"); + if (i2 >= 0 && (prefix = name.slice(0, i2)) !== "xmlns") + name = name.slice(i2 + 1); + return namespaces$1.hasOwnProperty(prefix) ? { space: namespaces$1[prefix], local: name } : name; + } + function creatorInherit(name) { + return function() { + var document2 = this.ownerDocument, uri = this.namespaceURI; + return uri === xhtml && document2.documentElement.namespaceURI === xhtml ? document2.createElement(name) : document2.createElementNS(uri, name); + }; + } + function creatorFixed(fullname) { + return function() { + return this.ownerDocument.createElementNS(fullname.space, fullname.local); + }; + } + function creator(name) { + var fullname = namespace(name); + return (fullname.local ? creatorFixed : creatorInherit)(fullname); + } + function none() { + } + function selector(selector2) { + return selector2 == null ? none : function() { + return this.querySelector(selector2); + }; + } + function selection_select(select) { + if (typeof select !== "function") + select = selector(select); + for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) { + for (var group = groups[j], n = group.length, subgroup = subgroups[j] = new Array(n), node2, subnode, i2 = 0; i2 < n; ++i2) { + if ((node2 = group[i2]) && (subnode = select.call(node2, node2.__data__, i2, group))) { + if ("__data__" in node2) + subnode.__data__ = node2.__data__; + subgroup[i2] = subnode; + } + } + } + return new Selection$1(subgroups, this._parents); + } + function array$1(x2) { + return x2 == null ? [] : Array.isArray(x2) ? x2 : Array.from(x2); + } + function empty() { + return []; + } + function selectorAll(selector2) { + return selector2 == null ? empty : function() { + return this.querySelectorAll(selector2); + }; + } + function arrayAll(select) { + return function() { + return array$1(select.apply(this, arguments)); + }; + } + function selection_selectAll(select) { + if (typeof select === "function") + select = arrayAll(select); + else + select = selectorAll(select); + for (var groups = this._groups, m = groups.length, subgroups = [], parents2 = [], j = 0; j < m; ++j) { + for (var group = groups[j], n = group.length, node2, i2 = 0; i2 < n; ++i2) { + if (node2 = group[i2]) { + subgroups.push(select.call(node2, node2.__data__, i2, group)); + parents2.push(node2); + } + } + } + return new Selection$1(subgroups, parents2); + } + function matcher(selector2) { + return function() { + return this.matches(selector2); + }; + } + function childMatcher(selector2) { + return function(node2) { + return node2.matches(selector2); + }; + } + var find$3 = Array.prototype.find; + function childFind(match) { + return function() { + return find$3.call(this.children, match); + }; + } + function childFirst() { + return this.firstElementChild; + } + function selection_selectChild(match) { + return this.select(match == null ? childFirst : childFind(typeof match === "function" ? match : childMatcher(match))); + } + var filter$1 = Array.prototype.filter; + function children() { + return Array.from(this.children); + } + function childrenFilter(match) { + return function() { + return filter$1.call(this.children, match); + }; + } + function selection_selectChildren(match) { + return this.selectAll(match == null ? children : childrenFilter(typeof match === "function" ? match : childMatcher(match))); + } + function selection_filter(match) { + if (typeof match !== "function") + match = matcher(match); + for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) { + for (var group = groups[j], n = group.length, subgroup = subgroups[j] = [], node2, i2 = 0; i2 < n; ++i2) { + if ((node2 = group[i2]) && match.call(node2, node2.__data__, i2, group)) { + subgroup.push(node2); + } + } + } + return new Selection$1(subgroups, this._parents); + } + function sparse(update2) { + return new Array(update2.length); + } + function selection_enter() { + return new Selection$1(this._enter || this._groups.map(sparse), this._parents); + } + function EnterNode(parent, datum2) { + this.ownerDocument = parent.ownerDocument; + this.namespaceURI = parent.namespaceURI; + this._next = null; + this._parent = parent; + this.__data__ = datum2; + } + EnterNode.prototype = { + constructor: EnterNode, + appendChild: function(child) { + return this._parent.insertBefore(child, this._next); + }, + insertBefore: function(child, next2) { + return this._parent.insertBefore(child, next2); + }, + querySelector: function(selector2) { + return this._parent.querySelector(selector2); + }, + querySelectorAll: function(selector2) { + return this._parent.querySelectorAll(selector2); + } + }; + function constant$5(x2) { + return function() { + return x2; + }; + } + function bindIndex(parent, group, enter2, update2, exit2, data) { + var i2 = 0, node2, groupLength2 = group.length, dataLength = data.length; + for (; i2 < dataLength; ++i2) { + if (node2 = group[i2]) { + node2.__data__ = data[i2]; + update2[i2] = node2; + } else { + enter2[i2] = new EnterNode(parent, data[i2]); + } + } + for (; i2 < groupLength2; ++i2) { + if (node2 = group[i2]) { + exit2[i2] = node2; + } + } + } + function bindKey(parent, group, enter2, update2, exit2, data, key) { + var i2, node2, nodeByKeyValue = /* @__PURE__ */ new Map(), groupLength2 = group.length, dataLength = data.length, keyValues = new Array(groupLength2), keyValue; + for (i2 = 0; i2 < groupLength2; ++i2) { + if (node2 = group[i2]) { + keyValues[i2] = keyValue = key.call(node2, node2.__data__, i2, group) + ""; + if (nodeByKeyValue.has(keyValue)) { + exit2[i2] = node2; + } else { + nodeByKeyValue.set(keyValue, node2); + } + } + } + for (i2 = 0; i2 < dataLength; ++i2) { + keyValue = key.call(parent, data[i2], i2, data) + ""; + if (node2 = nodeByKeyValue.get(keyValue)) { + update2[i2] = node2; + node2.__data__ = data[i2]; + nodeByKeyValue.delete(keyValue); + } else { + enter2[i2] = new EnterNode(parent, data[i2]); + } + } + for (i2 = 0; i2 < groupLength2; ++i2) { + if ((node2 = group[i2]) && nodeByKeyValue.get(keyValues[i2]) === node2) { + exit2[i2] = node2; + } + } + } + function datum(node2) { + return node2.__data__; + } + function selection_data(value2, key) { + if (!arguments.length) + return Array.from(this, datum); + var bind = key ? bindKey : bindIndex, parents2 = this._parents, groups = this._groups; + if (typeof value2 !== "function") + value2 = constant$5(value2); + for (var m = groups.length, update2 = new Array(m), enter2 = new Array(m), exit2 = new Array(m), j = 0; j < m; ++j) { + var parent = parents2[j], group = groups[j], groupLength2 = group.length, data = arraylike(value2.call(parent, parent && parent.__data__, j, parents2)), dataLength = data.length, enterGroup = enter2[j] = new Array(dataLength), updateGroup = update2[j] = new Array(dataLength), exitGroup = exit2[j] = new Array(groupLength2); + bind(parent, group, enterGroup, updateGroup, exitGroup, data, key); + for (var i0 = 0, i1 = 0, previous2, next2; i0 < dataLength; ++i0) { + if (previous2 = enterGroup[i0]) { + if (i0 >= i1) + i1 = i0 + 1; + while (!(next2 = updateGroup[i1]) && ++i1 < dataLength) + ; + previous2._next = next2 || null; + } + } + } + update2 = new Selection$1(update2, parents2); + update2._enter = enter2; + update2._exit = exit2; + return update2; + } + function arraylike(data) { + return typeof data === "object" && "length" in data ? data : Array.from(data); + } + function selection_exit() { + return new Selection$1(this._exit || this._groups.map(sparse), this._parents); + } + function selection_join(onenter, onupdate, onexit) { + var enter2 = this.enter(), update2 = this, exit2 = this.exit(); + if (typeof onenter === "function") { + enter2 = onenter(enter2); + if (enter2) + enter2 = enter2.selection(); + } else { + enter2 = enter2.append(onenter + ""); + } + if (onupdate != null) { + update2 = onupdate(update2); + if (update2) + update2 = update2.selection(); + } + if (onexit == null) + exit2.remove(); + else + onexit(exit2); + return enter2 && update2 ? enter2.merge(update2).order() : update2; + } + function selection_merge(context) { + var selection2 = context.selection ? context.selection() : context; + for (var groups0 = this._groups, groups1 = selection2._groups, m0 = groups0.length, m1 = groups1.length, m = Math.min(m0, m1), merges = new Array(m0), j = 0; j < m; ++j) { + for (var group0 = groups0[j], group1 = groups1[j], n = group0.length, merge2 = merges[j] = new Array(n), node2, i2 = 0; i2 < n; ++i2) { + if (node2 = group0[i2] || group1[i2]) { + merge2[i2] = node2; + } + } + } + for (; j < m0; ++j) { + merges[j] = groups0[j]; + } + return new Selection$1(merges, this._parents); + } + function selection_order() { + for (var groups = this._groups, j = -1, m = groups.length; ++j < m; ) { + for (var group = groups[j], i2 = group.length - 1, next2 = group[i2], node2; --i2 >= 0; ) { + if (node2 = group[i2]) { + if (next2 && node2.compareDocumentPosition(next2) ^ 4) + next2.parentNode.insertBefore(node2, next2); + next2 = node2; + } + } + } + return this; + } + function selection_sort(compare) { + if (!compare) + compare = ascending; + function compareNode(a, b) { + return a && b ? compare(a.__data__, b.__data__) : !a - !b; + } + for (var groups = this._groups, m = groups.length, sortgroups = new Array(m), j = 0; j < m; ++j) { + for (var group = groups[j], n = group.length, sortgroup = sortgroups[j] = new Array(n), node2, i2 = 0; i2 < n; ++i2) { + if (node2 = group[i2]) { + sortgroup[i2] = node2; + } + } + sortgroup.sort(compareNode); + } + return new Selection$1(sortgroups, this._parents).order(); + } + function ascending(a, b) { + return a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN; + } + function selection_call() { + var callback = arguments[0]; + arguments[0] = this; + callback.apply(null, arguments); + return this; + } + function selection_nodes() { + return Array.from(this); + } + function selection_node() { + for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) { + for (var group = groups[j], i2 = 0, n = group.length; i2 < n; ++i2) { + var node2 = group[i2]; + if (node2) + return node2; + } + } + return null; + } + function selection_size() { + let size2 = 0; + for (const node2 of this) + ++size2; + return size2; + } + function selection_empty() { + return !this.node(); + } + function selection_each(callback) { + for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) { + for (var group = groups[j], i2 = 0, n = group.length, node2; i2 < n; ++i2) { + if (node2 = group[i2]) + callback.call(node2, node2.__data__, i2, group); + } + } + return this; + } + function attrRemove$1(name) { + return function() { + this.removeAttribute(name); + }; + } + function attrRemoveNS$1(fullname) { + return function() { + this.removeAttributeNS(fullname.space, fullname.local); + }; + } + function attrConstant$1(name, value2) { + return function() { + this.setAttribute(name, value2); + }; + } + function attrConstantNS$1(fullname, value2) { + return function() { + this.setAttributeNS(fullname.space, fullname.local, value2); + }; + } + function attrFunction$1(name, value2) { + return function() { + var v = value2.apply(this, arguments); + if (v == null) + this.removeAttribute(name); + else + this.setAttribute(name, v); + }; + } + function attrFunctionNS$1(fullname, value2) { + return function() { + var v = value2.apply(this, arguments); + if (v == null) + this.removeAttributeNS(fullname.space, fullname.local); + else + this.setAttributeNS(fullname.space, fullname.local, v); + }; + } + function selection_attr(name, value2) { + var fullname = namespace(name); + if (arguments.length < 2) { + var node2 = this.node(); + return fullname.local ? node2.getAttributeNS(fullname.space, fullname.local) : node2.getAttribute(fullname); + } + return this.each((value2 == null ? fullname.local ? attrRemoveNS$1 : attrRemove$1 : typeof value2 === "function" ? fullname.local ? attrFunctionNS$1 : attrFunction$1 : fullname.local ? attrConstantNS$1 : attrConstant$1)(fullname, value2)); + } + function defaultView(node2) { + return node2.ownerDocument && node2.ownerDocument.defaultView || node2.document && node2 || node2.defaultView; + } + function styleRemove$1(name) { + return function() { + this.style.removeProperty(name); + }; + } + function styleConstant$1(name, value2, priority) { + return function() { + this.style.setProperty(name, value2, priority); + }; + } + function styleFunction$1(name, value2, priority) { + return function() { + var v = value2.apply(this, arguments); + if (v == null) + this.style.removeProperty(name); + else + this.style.setProperty(name, v, priority); + }; + } + function selection_style(name, value2, priority) { + return arguments.length > 1 ? this.each((value2 == null ? styleRemove$1 : typeof value2 === "function" ? styleFunction$1 : styleConstant$1)(name, value2, priority == null ? "" : priority)) : styleValue(this.node(), name); + } + function styleValue(node2, name) { + return node2.style.getPropertyValue(name) || defaultView(node2).getComputedStyle(node2, null).getPropertyValue(name); + } + function propertyRemove(name) { + return function() { + delete this[name]; + }; + } + function propertyConstant(name, value2) { + return function() { + this[name] = value2; + }; + } + function propertyFunction(name, value2) { + return function() { + var v = value2.apply(this, arguments); + if (v == null) + delete this[name]; + else + this[name] = v; + }; + } + function selection_property(name, value2) { + return arguments.length > 1 ? this.each((value2 == null ? propertyRemove : typeof value2 === "function" ? propertyFunction : propertyConstant)(name, value2)) : this.node()[name]; + } + function classArray(string2) { + return string2.trim().split(/^|\s+/); + } + function classList(node2) { + return node2.classList || new ClassList(node2); + } + function ClassList(node2) { + this._node = node2; + this._names = classArray(node2.getAttribute("class") || ""); + } + ClassList.prototype = { + add: function(name) { + var i2 = this._names.indexOf(name); + if (i2 < 0) { + this._names.push(name); + this._node.setAttribute("class", this._names.join(" ")); + } + }, + remove: function(name) { + var i2 = this._names.indexOf(name); + if (i2 >= 0) { + this._names.splice(i2, 1); + this._node.setAttribute("class", this._names.join(" ")); + } + }, + contains: function(name) { + return this._names.indexOf(name) >= 0; + } + }; + function classedAdd(node2, names) { + var list2 = classList(node2), i2 = -1, n = names.length; + while (++i2 < n) + list2.add(names[i2]); + } + function classedRemove(node2, names) { + var list2 = classList(node2), i2 = -1, n = names.length; + while (++i2 < n) + list2.remove(names[i2]); + } + function classedTrue(names) { + return function() { + classedAdd(this, names); + }; + } + function classedFalse(names) { + return function() { + classedRemove(this, names); + }; + } + function classedFunction(names, value2) { + return function() { + (value2.apply(this, arguments) ? classedAdd : classedRemove)(this, names); + }; + } + function selection_classed(name, value2) { + var names = classArray(name + ""); + if (arguments.length < 2) { + var list2 = classList(this.node()), i2 = -1, n = names.length; + while (++i2 < n) + if (!list2.contains(names[i2])) + return false; + return true; + } + return this.each((typeof value2 === "function" ? classedFunction : value2 ? classedTrue : classedFalse)(names, value2)); + } + function textRemove() { + this.textContent = ""; + } + function textConstant$1(value2) { + return function() { + this.textContent = value2; + }; + } + function textFunction$1(value2) { + return function() { + var v = value2.apply(this, arguments); + this.textContent = v == null ? "" : v; + }; + } + function selection_text(value2) { + return arguments.length ? this.each(value2 == null ? textRemove : (typeof value2 === "function" ? textFunction$1 : textConstant$1)(value2)) : this.node().textContent; + } + function htmlRemove() { + this.innerHTML = ""; + } + function htmlConstant(value2) { + return function() { + this.innerHTML = value2; + }; + } + function htmlFunction(value2) { + return function() { + var v = value2.apply(this, arguments); + this.innerHTML = v == null ? "" : v; + }; + } + function selection_html(value2) { + return arguments.length ? this.each(value2 == null ? htmlRemove : (typeof value2 === "function" ? htmlFunction : htmlConstant)(value2)) : this.node().innerHTML; + } + function raise() { + if (this.nextSibling) + this.parentNode.appendChild(this); + } + function selection_raise() { + return this.each(raise); + } + function lower() { + if (this.previousSibling) + this.parentNode.insertBefore(this, this.parentNode.firstChild); + } + function selection_lower() { + return this.each(lower); + } + function selection_append(name) { + var create2 = typeof name === "function" ? name : creator(name); + return this.select(function() { + return this.appendChild(create2.apply(this, arguments)); + }); + } + function constantNull() { + return null; + } + function selection_insert(name, before) { + var create2 = typeof name === "function" ? name : creator(name), select = before == null ? constantNull : typeof before === "function" ? before : selector(before); + return this.select(function() { + return this.insertBefore(create2.apply(this, arguments), select.apply(this, arguments) || null); + }); + } + function remove() { + var parent = this.parentNode; + if (parent) + parent.removeChild(this); + } + function selection_remove() { + return this.each(remove); + } + function selection_cloneShallow() { + var clone2 = this.cloneNode(false), parent = this.parentNode; + return parent ? parent.insertBefore(clone2, this.nextSibling) : clone2; + } + function selection_cloneDeep() { + var clone2 = this.cloneNode(true), parent = this.parentNode; + return parent ? parent.insertBefore(clone2, this.nextSibling) : clone2; + } + function selection_clone(deep) { + return this.select(deep ? selection_cloneDeep : selection_cloneShallow); + } + function selection_datum(value2) { + return arguments.length ? this.property("__data__", value2) : this.node().__data__; + } + function contextListener(listener) { + return function(event) { + listener.call(this, event, this.__data__); + }; + } + function parseTypenames(typenames) { + return typenames.trim().split(/^|\s+/).map(function(t) { + var name = "", i2 = t.indexOf("."); + if (i2 >= 0) + name = t.slice(i2 + 1), t = t.slice(0, i2); + return { type: t, name }; + }); + } + function onRemove(typename) { + return function() { + var on = this.__on; + if (!on) + return; + for (var j = 0, i2 = -1, m = on.length, o; j < m; ++j) { + if (o = on[j], (!typename.type || o.type === typename.type) && o.name === typename.name) { + this.removeEventListener(o.type, o.listener, o.options); + } else { + on[++i2] = o; + } + } + if (++i2) + on.length = i2; + else + delete this.__on; + }; + } + function onAdd(typename, value2, options2) { + return function() { + var on = this.__on, o, listener = contextListener(value2); + if (on) + for (var j = 0, m = on.length; j < m; ++j) { + if ((o = on[j]).type === typename.type && o.name === typename.name) { + this.removeEventListener(o.type, o.listener, o.options); + this.addEventListener(o.type, o.listener = listener, o.options = options2); + o.value = value2; + return; + } + } + this.addEventListener(typename.type, listener, options2); + o = { type: typename.type, name: typename.name, value: value2, listener, options: options2 }; + if (!on) + this.__on = [o]; + else + on.push(o); + }; + } + function selection_on(typename, value2, options2) { + var typenames = parseTypenames(typename + ""), i2, n = typenames.length, t; + if (arguments.length < 2) { + var on = this.node().__on; + if (on) + for (var j = 0, m = on.length, o; j < m; ++j) { + for (i2 = 0, o = on[j]; i2 < n; ++i2) { + if ((t = typenames[i2]).type === o.type && t.name === o.name) { + return o.value; + } + } + } + return; + } + on = value2 ? onAdd : onRemove; + for (i2 = 0; i2 < n; ++i2) + this.each(on(typenames[i2], value2, options2)); + return this; + } + function dispatchEvent(node2, type2, params) { + var window2 = defaultView(node2), event = window2.CustomEvent; + if (typeof event === "function") { + event = new event(type2, params); + } else { + event = window2.document.createEvent("Event"); + if (params) + event.initEvent(type2, params.bubbles, params.cancelable), event.detail = params.detail; + else + event.initEvent(type2, false, false); + } + node2.dispatchEvent(event); + } + function dispatchConstant(type2, params) { + return function() { + return dispatchEvent(this, type2, params); + }; + } + function dispatchFunction(type2, params) { + return function() { + return dispatchEvent(this, type2, params.apply(this, arguments)); + }; + } + function selection_dispatch(type2, params) { + return this.each((typeof params === "function" ? dispatchFunction : dispatchConstant)(type2, params)); + } + function* selection_iterator() { + for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) { + for (var group = groups[j], i2 = 0, n = group.length, node2; i2 < n; ++i2) { + if (node2 = group[i2]) + yield node2; + } + } + } + var root$2 = [null]; + function Selection$1(groups, parents2) { + this._groups = groups; + this._parents = parents2; + } + function selection() { + return new Selection$1([[document.documentElement]], root$2); + } + function selection_selection() { + return this; + } + Selection$1.prototype = selection.prototype = { + constructor: Selection$1, + select: selection_select, + selectAll: selection_selectAll, + selectChild: selection_selectChild, + selectChildren: selection_selectChildren, + filter: selection_filter, + data: selection_data, + enter: selection_enter, + exit: selection_exit, + join: selection_join, + merge: selection_merge, + selection: selection_selection, + order: selection_order, + sort: selection_sort, + call: selection_call, + nodes: selection_nodes, + node: selection_node, + size: selection_size, + empty: selection_empty, + each: selection_each, + attr: selection_attr, + style: selection_style, + property: selection_property, + classed: selection_classed, + text: selection_text, + html: selection_html, + raise: selection_raise, + lower: selection_lower, + append: selection_append, + insert: selection_insert, + remove: selection_remove, + clone: selection_clone, + datum: selection_datum, + on: selection_on, + dispatch: selection_dispatch, + [Symbol.iterator]: selection_iterator + }; + function d3select(selector2) { + return typeof selector2 === "string" ? new Selection$1([[document.querySelector(selector2)]], [document.documentElement]) : new Selection$1([[selector2]], root$2); + } + function selectAll(selector2) { + return typeof selector2 === "string" ? new Selection$1([document.querySelectorAll(selector2)], [document.documentElement]) : new Selection$1([array$1(selector2)], root$2); + } + function define2(constructor, factory, prototype) { + constructor.prototype = factory.prototype = prototype; + prototype.constructor = constructor; + } + function extend$1(parent, definition2) { + var prototype = Object.create(parent.prototype); + for (var key in definition2) + prototype[key] = definition2[key]; + return prototype; + } + function Color$2() { + } + var darker = 0.7; + var brighter = 1 / darker; + var reI = "\\s*([+-]?\\d+)\\s*", reN = "\\s*([+-]?(?:\\d*\\.)?\\d+(?:[eE][+-]?\\d+)?)\\s*", reP = "\\s*([+-]?(?:\\d*\\.)?\\d+(?:[eE][+-]?\\d+)?)%\\s*", reHex = /^#([0-9a-f]{3,8})$/, reRgbInteger = new RegExp(`^rgb\\(${reI},${reI},${reI}\\)$`), reRgbPercent = new RegExp(`^rgb\\(${reP},${reP},${reP}\\)$`), reRgbaInteger = new RegExp(`^rgba\\(${reI},${reI},${reI},${reN}\\)$`), reRgbaPercent = new RegExp(`^rgba\\(${reP},${reP},${reP},${reN}\\)$`), reHslPercent = new RegExp(`^hsl\\(${reN},${reP},${reP}\\)$`), reHslaPercent = new RegExp(`^hsla\\(${reN},${reP},${reP},${reN}\\)$`); + var named = { + aliceblue: 15792383, + antiquewhite: 16444375, + aqua: 65535, + aquamarine: 8388564, + azure: 15794175, + beige: 16119260, + bisque: 16770244, + black: 0, + blanchedalmond: 16772045, + blue: 255, + blueviolet: 9055202, + brown: 10824234, + burlywood: 14596231, + cadetblue: 6266528, + chartreuse: 8388352, + chocolate: 13789470, + coral: 16744272, + cornflowerblue: 6591981, + cornsilk: 16775388, + crimson: 14423100, + cyan: 65535, + darkblue: 139, + darkcyan: 35723, + darkgoldenrod: 12092939, + darkgray: 11119017, + darkgreen: 25600, + darkgrey: 11119017, + darkkhaki: 12433259, + darkmagenta: 9109643, + darkolivegreen: 5597999, + darkorange: 16747520, + darkorchid: 10040012, + darkred: 9109504, + darksalmon: 15308410, + darkseagreen: 9419919, + darkslateblue: 4734347, + darkslategray: 3100495, + darkslategrey: 3100495, + darkturquoise: 52945, + darkviolet: 9699539, + deeppink: 16716947, + deepskyblue: 49151, + dimgray: 6908265, + dimgrey: 6908265, + dodgerblue: 2003199, + firebrick: 11674146, + floralwhite: 16775920, + forestgreen: 2263842, + fuchsia: 16711935, + gainsboro: 14474460, + ghostwhite: 16316671, + gold: 16766720, + goldenrod: 14329120, + gray: 8421504, + green: 32768, + greenyellow: 11403055, + grey: 8421504, + honeydew: 15794160, + hotpink: 16738740, + indianred: 13458524, + indigo: 4915330, + ivory: 16777200, + khaki: 15787660, + lavender: 15132410, + lavenderblush: 16773365, + lawngreen: 8190976, + lemonchiffon: 16775885, + lightblue: 11393254, + lightcoral: 15761536, + lightcyan: 14745599, + lightgoldenrodyellow: 16448210, + lightgray: 13882323, + lightgreen: 9498256, + lightgrey: 13882323, + lightpink: 16758465, + lightsalmon: 16752762, + lightseagreen: 2142890, + lightskyblue: 8900346, + lightslategray: 7833753, + lightslategrey: 7833753, + lightsteelblue: 11584734, + lightyellow: 16777184, + lime: 65280, + limegreen: 3329330, + linen: 16445670, + magenta: 16711935, + maroon: 8388608, + mediumaquamarine: 6737322, + mediumblue: 205, + mediumorchid: 12211667, + mediumpurple: 9662683, + mediumseagreen: 3978097, + mediumslateblue: 8087790, + mediumspringgreen: 64154, + mediumturquoise: 4772300, + mediumvioletred: 13047173, + midnightblue: 1644912, + mintcream: 16121850, + mistyrose: 16770273, + moccasin: 16770229, + navajowhite: 16768685, + navy: 128, + oldlace: 16643558, + olive: 8421376, + olivedrab: 7048739, + orange: 16753920, + orangered: 16729344, + orchid: 14315734, + palegoldenrod: 15657130, + palegreen: 10025880, + paleturquoise: 11529966, + palevioletred: 14381203, + papayawhip: 16773077, + peachpuff: 16767673, + peru: 13468991, + pink: 16761035, + plum: 14524637, + powderblue: 11591910, + purple: 8388736, + rebeccapurple: 6697881, + red: 16711680, + rosybrown: 12357519, + royalblue: 4286945, + saddlebrown: 9127187, + salmon: 16416882, + sandybrown: 16032864, + seagreen: 3050327, + seashell: 16774638, + sienna: 10506797, + silver: 12632256, + skyblue: 8900331, + slateblue: 6970061, + slategray: 7372944, + slategrey: 7372944, + snow: 16775930, + springgreen: 65407, + steelblue: 4620980, + tan: 13808780, + teal: 32896, + thistle: 14204888, + tomato: 16737095, + turquoise: 4251856, + violet: 15631086, + wheat: 16113331, + white: 16777215, + whitesmoke: 16119285, + yellow: 16776960, + yellowgreen: 10145074 + }; + define2(Color$2, color, { + copy(channels2) { + return Object.assign(new this.constructor(), this, channels2); + }, + displayable() { + return this.rgb().displayable(); + }, + hex: color_formatHex, + // Deprecated! Use color.formatHex. + formatHex: color_formatHex, + formatHex8: color_formatHex8, + formatHsl: color_formatHsl, + formatRgb: color_formatRgb, + toString: color_formatRgb + }); + function color_formatHex() { + return this.rgb().formatHex(); + } + function color_formatHex8() { + return this.rgb().formatHex8(); + } + function color_formatHsl() { + return hslConvert(this).formatHsl(); + } + function color_formatRgb() { + return this.rgb().formatRgb(); + } + function color(format2) { + var m, l; + format2 = (format2 + "").trim().toLowerCase(); + return (m = reHex.exec(format2)) ? (l = m[1].length, m = parseInt(m[1], 16), l === 6 ? rgbn(m) : l === 3 ? new Rgb(m >> 8 & 15 | m >> 4 & 240, m >> 4 & 15 | m & 240, (m & 15) << 4 | m & 15, 1) : l === 8 ? rgba$2(m >> 24 & 255, m >> 16 & 255, m >> 8 & 255, (m & 255) / 255) : l === 4 ? rgba$2(m >> 12 & 15 | m >> 8 & 240, m >> 8 & 15 | m >> 4 & 240, m >> 4 & 15 | m & 240, ((m & 15) << 4 | m & 15) / 255) : null) : (m = reRgbInteger.exec(format2)) ? new Rgb(m[1], m[2], m[3], 1) : (m = reRgbPercent.exec(format2)) ? new Rgb(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, 1) : (m = reRgbaInteger.exec(format2)) ? rgba$2(m[1], m[2], m[3], m[4]) : (m = reRgbaPercent.exec(format2)) ? rgba$2(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, m[4]) : (m = reHslPercent.exec(format2)) ? hsla(m[1], m[2] / 100, m[3] / 100, 1) : (m = reHslaPercent.exec(format2)) ? hsla(m[1], m[2] / 100, m[3] / 100, m[4]) : named.hasOwnProperty(format2) ? rgbn(named[format2]) : format2 === "transparent" ? new Rgb(NaN, NaN, NaN, 0) : null; + } + function rgbn(n) { + return new Rgb(n >> 16 & 255, n >> 8 & 255, n & 255, 1); + } + function rgba$2(r, g, b, a) { + if (a <= 0) + r = g = b = NaN; + return new Rgb(r, g, b, a); + } + function rgbConvert(o) { + if (!(o instanceof Color$2)) + o = color(o); + if (!o) + return new Rgb(); + o = o.rgb(); + return new Rgb(o.r, o.g, o.b, o.opacity); + } + function rgb(r, g, b, opacity) { + return arguments.length === 1 ? rgbConvert(r) : new Rgb(r, g, b, opacity == null ? 1 : opacity); + } + function Rgb(r, g, b, opacity) { + this.r = +r; + this.g = +g; + this.b = +b; + this.opacity = +opacity; + } + define2(Rgb, rgb, extend$1(Color$2, { + brighter(k) { + k = k == null ? brighter : Math.pow(brighter, k); + return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity); + }, + darker(k) { + k = k == null ? darker : Math.pow(darker, k); + return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity); + }, + rgb() { + return this; + }, + clamp() { + return new Rgb(clampi(this.r), clampi(this.g), clampi(this.b), clampa(this.opacity)); + }, + displayable() { + return -0.5 <= this.r && this.r < 255.5 && (-0.5 <= this.g && this.g < 255.5) && (-0.5 <= this.b && this.b < 255.5) && (0 <= this.opacity && this.opacity <= 1); + }, + hex: rgb_formatHex, + // Deprecated! Use color.formatHex. + formatHex: rgb_formatHex, + formatHex8: rgb_formatHex8, + formatRgb: rgb_formatRgb, + toString: rgb_formatRgb + })); + function rgb_formatHex() { + return `#${hex(this.r)}${hex(this.g)}${hex(this.b)}`; + } + function rgb_formatHex8() { + return `#${hex(this.r)}${hex(this.g)}${hex(this.b)}${hex((isNaN(this.opacity) ? 1 : this.opacity) * 255)}`; + } + function rgb_formatRgb() { + const a = clampa(this.opacity); + return `${a === 1 ? "rgb(" : "rgba("}${clampi(this.r)}, ${clampi(this.g)}, ${clampi(this.b)}${a === 1 ? ")" : `, ${a})`}`; + } + function clampa(opacity) { + return isNaN(opacity) ? 1 : Math.max(0, Math.min(1, opacity)); + } + function clampi(value2) { + return Math.max(0, Math.min(255, Math.round(value2) || 0)); + } + function hex(value2) { + value2 = clampi(value2); + return (value2 < 16 ? "0" : "") + value2.toString(16); + } + function hsla(h, s, l, a) { + if (a <= 0) + h = s = l = NaN; + else if (l <= 0 || l >= 1) + h = s = NaN; + else if (s <= 0) + h = NaN; + return new Hsl(h, s, l, a); + } + function hslConvert(o) { + if (o instanceof Hsl) + return new Hsl(o.h, o.s, o.l, o.opacity); + if (!(o instanceof Color$2)) + o = color(o); + if (!o) + return new Hsl(); + if (o instanceof Hsl) + return o; + o = o.rgb(); + var r = o.r / 255, g = o.g / 255, b = o.b / 255, min2 = Math.min(r, g, b), max2 = Math.max(r, g, b), h = NaN, s = max2 - min2, l = (max2 + min2) / 2; + if (s) { + if (r === max2) + h = (g - b) / s + (g < b) * 6; + else if (g === max2) + h = (b - r) / s + 2; + else + h = (r - g) / s + 4; + s /= l < 0.5 ? max2 + min2 : 2 - max2 - min2; + h *= 60; + } else { + s = l > 0 && l < 1 ? 0 : h; + } + return new Hsl(h, s, l, o.opacity); + } + function hsl(h, s, l, opacity) { + return arguments.length === 1 ? hslConvert(h) : new Hsl(h, s, l, opacity == null ? 1 : opacity); + } + function Hsl(h, s, l, opacity) { + this.h = +h; + this.s = +s; + this.l = +l; + this.opacity = +opacity; + } + define2(Hsl, hsl, extend$1(Color$2, { + brighter(k) { + k = k == null ? brighter : Math.pow(brighter, k); + return new Hsl(this.h, this.s, this.l * k, this.opacity); + }, + darker(k) { + k = k == null ? darker : Math.pow(darker, k); + return new Hsl(this.h, this.s, this.l * k, this.opacity); + }, + rgb() { + var h = this.h % 360 + (this.h < 0) * 360, s = isNaN(h) || isNaN(this.s) ? 0 : this.s, l = this.l, m2 = l + (l < 0.5 ? l : 1 - l) * s, m1 = 2 * l - m2; + return new Rgb( + hsl2rgb(h >= 240 ? h - 240 : h + 120, m1, m2), + hsl2rgb(h, m1, m2), + hsl2rgb(h < 120 ? h + 240 : h - 120, m1, m2), + this.opacity + ); + }, + clamp() { + return new Hsl(clamph(this.h), clampt(this.s), clampt(this.l), clampa(this.opacity)); + }, + displayable() { + return (0 <= this.s && this.s <= 1 || isNaN(this.s)) && (0 <= this.l && this.l <= 1) && (0 <= this.opacity && this.opacity <= 1); + }, + formatHsl() { + const a = clampa(this.opacity); + return `${a === 1 ? "hsl(" : "hsla("}${clamph(this.h)}, ${clampt(this.s) * 100}%, ${clampt(this.l) * 100}%${a === 1 ? ")" : `, ${a})`}`; + } + })); + function clamph(value2) { + value2 = (value2 || 0) % 360; + return value2 < 0 ? value2 + 360 : value2; + } + function clampt(value2) { + return Math.max(0, Math.min(1, value2 || 0)); + } + function hsl2rgb(h, m1, m2) { + return (h < 60 ? m1 + (m2 - m1) * h / 60 : h < 180 ? m2 : h < 240 ? m1 + (m2 - m1) * (240 - h) / 60 : m1) * 255; + } + const radians = Math.PI / 180; + const degrees$1 = 180 / Math.PI; + const K = 18, Xn = 0.96422, Yn = 1, Zn = 0.82521, t0$1 = 4 / 29, t1$1 = 6 / 29, t2 = 3 * t1$1 * t1$1, t3 = t1$1 * t1$1 * t1$1; + function labConvert(o) { + if (o instanceof Lab) + return new Lab(o.l, o.a, o.b, o.opacity); + if (o instanceof Hcl) + return hcl2lab(o); + if (!(o instanceof Rgb)) + o = rgbConvert(o); + var r = rgb2lrgb(o.r), g = rgb2lrgb(o.g), b = rgb2lrgb(o.b), y2 = xyz2lab((0.2225045 * r + 0.7168786 * g + 0.0606169 * b) / Yn), x2, z; + if (r === g && g === b) + x2 = z = y2; + else { + x2 = xyz2lab((0.4360747 * r + 0.3850649 * g + 0.1430804 * b) / Xn); + z = xyz2lab((0.0139322 * r + 0.0971045 * g + 0.7141733 * b) / Zn); + } + return new Lab(116 * y2 - 16, 500 * (x2 - y2), 200 * (y2 - z), o.opacity); + } + function lab(l, a, b, opacity) { + return arguments.length === 1 ? labConvert(l) : new Lab(l, a, b, opacity == null ? 1 : opacity); + } + function Lab(l, a, b, opacity) { + this.l = +l; + this.a = +a; + this.b = +b; + this.opacity = +opacity; + } + define2(Lab, lab, extend$1(Color$2, { + brighter(k) { + return new Lab(this.l + K * (k == null ? 1 : k), this.a, this.b, this.opacity); + }, + darker(k) { + return new Lab(this.l - K * (k == null ? 1 : k), this.a, this.b, this.opacity); + }, + rgb() { + var y2 = (this.l + 16) / 116, x2 = isNaN(this.a) ? y2 : y2 + this.a / 500, z = isNaN(this.b) ? y2 : y2 - this.b / 200; + x2 = Xn * lab2xyz(x2); + y2 = Yn * lab2xyz(y2); + z = Zn * lab2xyz(z); + return new Rgb( + lrgb2rgb(3.1338561 * x2 - 1.6168667 * y2 - 0.4906146 * z), + lrgb2rgb(-0.9787684 * x2 + 1.9161415 * y2 + 0.033454 * z), + lrgb2rgb(0.0719453 * x2 - 0.2289914 * y2 + 1.4052427 * z), + this.opacity + ); + } + })); + function xyz2lab(t) { + return t > t3 ? Math.pow(t, 1 / 3) : t / t2 + t0$1; + } + function lab2xyz(t) { + return t > t1$1 ? t * t * t : t2 * (t - t0$1); + } + function lrgb2rgb(x2) { + return 255 * (x2 <= 31308e-7 ? 12.92 * x2 : 1.055 * Math.pow(x2, 1 / 2.4) - 0.055); + } + function rgb2lrgb(x2) { + return (x2 /= 255) <= 0.04045 ? x2 / 12.92 : Math.pow((x2 + 0.055) / 1.055, 2.4); + } + function hclConvert(o) { + if (o instanceof Hcl) + return new Hcl(o.h, o.c, o.l, o.opacity); + if (!(o instanceof Lab)) + o = labConvert(o); + if (o.a === 0 && o.b === 0) + return new Hcl(NaN, 0 < o.l && o.l < 100 ? 0 : NaN, o.l, o.opacity); + var h = Math.atan2(o.b, o.a) * degrees$1; + return new Hcl(h < 0 ? h + 360 : h, Math.sqrt(o.a * o.a + o.b * o.b), o.l, o.opacity); + } + function hcl$1(h, c2, l, opacity) { + return arguments.length === 1 ? hclConvert(h) : new Hcl(h, c2, l, opacity == null ? 1 : opacity); + } + function Hcl(h, c2, l, opacity) { + this.h = +h; + this.c = +c2; + this.l = +l; + this.opacity = +opacity; + } + function hcl2lab(o) { + if (isNaN(o.h)) + return new Lab(o.l, 0, 0, o.opacity); + var h = o.h * radians; + return new Lab(o.l, Math.cos(h) * o.c, Math.sin(h) * o.c, o.opacity); + } + define2(Hcl, hcl$1, extend$1(Color$2, { + brighter(k) { + return new Hcl(this.h, this.c, this.l + K * (k == null ? 1 : k), this.opacity); + }, + darker(k) { + return new Hcl(this.h, this.c, this.l - K * (k == null ? 1 : k), this.opacity); + }, + rgb() { + return hcl2lab(this).rgb(); + } + })); + const constant$4 = (x2) => () => x2; + function linear$1(a, d) { + return function(t) { + return a + t * d; + }; + } + function exponential(a, b, y2) { + return a = Math.pow(a, y2), b = Math.pow(b, y2) - a, y2 = 1 / y2, function(t) { + return Math.pow(a + t * b, y2); + }; + } + function hue(a, b) { + var d = b - a; + return d ? linear$1(a, d > 180 || d < -180 ? d - 360 * Math.round(d / 360) : d) : constant$4(isNaN(a) ? b : a); + } + function gamma(y2) { + return (y2 = +y2) === 1 ? nogamma : function(a, b) { + return b - a ? exponential(a, b, y2) : constant$4(isNaN(a) ? b : a); + }; + } + function nogamma(a, b) { + var d = b - a; + return d ? linear$1(a, d) : constant$4(isNaN(a) ? b : a); + } + const interpolateRgb = function rgbGamma(y2) { + var color2 = gamma(y2); + function rgb$1(start2, end2) { + var r = color2((start2 = rgb(start2)).r, (end2 = rgb(end2)).r), g = color2(start2.g, end2.g), b = color2(start2.b, end2.b), opacity = nogamma(start2.opacity, end2.opacity); + return function(t) { + start2.r = r(t); + start2.g = g(t); + start2.b = b(t); + start2.opacity = opacity(t); + return start2 + ""; + }; + } + rgb$1.gamma = rgbGamma; + return rgb$1; + }(1); + function numberArray(a, b) { + if (!b) + b = []; + var n = a ? Math.min(b.length, a.length) : 0, c2 = b.slice(), i2; + return function(t) { + for (i2 = 0; i2 < n; ++i2) + c2[i2] = a[i2] * (1 - t) + b[i2] * t; + return c2; + }; + } + function isNumberArray(x2) { + return ArrayBuffer.isView(x2) && !(x2 instanceof DataView); + } + function genericArray(a, b) { + var nb = b ? b.length : 0, na = a ? Math.min(nb, a.length) : 0, x2 = new Array(na), c2 = new Array(nb), i2; + for (i2 = 0; i2 < na; ++i2) + x2[i2] = interpolate$1(a[i2], b[i2]); + for (; i2 < nb; ++i2) + c2[i2] = b[i2]; + return function(t) { + for (i2 = 0; i2 < na; ++i2) + c2[i2] = x2[i2](t); + return c2; + }; + } + function date$1(a, b) { + var d = /* @__PURE__ */ new Date(); + return a = +a, b = +b, function(t) { + return d.setTime(a * (1 - t) + b * t), d; + }; + } + function interpolateNumber(a, b) { + return a = +a, b = +b, function(t) { + return a * (1 - t) + b * t; + }; + } + function object(a, b) { + var i2 = {}, c2 = {}, k; + if (a === null || typeof a !== "object") + a = {}; + if (b === null || typeof b !== "object") + b = {}; + for (k in b) { + if (k in a) { + i2[k] = interpolate$1(a[k], b[k]); + } else { + c2[k] = b[k]; + } + } + return function(t) { + for (k in i2) + c2[k] = i2[k](t); + return c2; + }; + } + var reA = /[-+]?(?:\d+\.?\d*|\.?\d+)(?:[eE][-+]?\d+)?/g, reB = new RegExp(reA.source, "g"); + function zero(b) { + return function() { + return b; + }; + } + function one$1(b) { + return function(t) { + return b(t) + ""; + }; + } + function interpolateString(a, b) { + var bi = reA.lastIndex = reB.lastIndex = 0, am, bm, bs, i2 = -1, s = [], q = []; + a = a + "", b = b + ""; + while ((am = reA.exec(a)) && (bm = reB.exec(b))) { + if ((bs = bm.index) > bi) { + bs = b.slice(bi, bs); + if (s[i2]) + s[i2] += bs; + else + s[++i2] = bs; + } + if ((am = am[0]) === (bm = bm[0])) { + if (s[i2]) + s[i2] += bm; + else + s[++i2] = bm; + } else { + s[++i2] = null; + q.push({ i: i2, x: interpolateNumber(am, bm) }); + } + bi = reB.lastIndex; + } + if (bi < b.length) { + bs = b.slice(bi); + if (s[i2]) + s[i2] += bs; + else + s[++i2] = bs; + } + return s.length < 2 ? q[0] ? one$1(q[0].x) : zero(b) : (b = q.length, function(t) { + for (var i3 = 0, o; i3 < b; ++i3) + s[(o = q[i3]).i] = o.x(t); + return s.join(""); + }); + } + function interpolate$1(a, b) { + var t = typeof b, c2; + return b == null || t === "boolean" ? constant$4(b) : (t === "number" ? interpolateNumber : t === "string" ? (c2 = color(b)) ? (b = c2, interpolateRgb) : interpolateString : b instanceof color ? interpolateRgb : b instanceof Date ? date$1 : isNumberArray(b) ? numberArray : Array.isArray(b) ? genericArray : typeof b.valueOf !== "function" && typeof b.toString !== "function" || isNaN(b) ? object : interpolateNumber)(a, b); + } + function interpolateRound(a, b) { + return a = +a, b = +b, function(t) { + return Math.round(a * (1 - t) + b * t); + }; + } + var degrees = 180 / Math.PI; + var identity$4 = { + translateX: 0, + translateY: 0, + rotate: 0, + skewX: 0, + scaleX: 1, + scaleY: 1 + }; + function decompose(a, b, c2, d, e, f2) { + var scaleX, scaleY, skewX; + if (scaleX = Math.sqrt(a * a + b * b)) + a /= scaleX, b /= scaleX; + if (skewX = a * c2 + b * d) + c2 -= a * skewX, d -= b * skewX; + if (scaleY = Math.sqrt(c2 * c2 + d * d)) + c2 /= scaleY, d /= scaleY, skewX /= scaleY; + if (a * d < b * c2) + a = -a, b = -b, skewX = -skewX, scaleX = -scaleX; + return { + translateX: e, + translateY: f2, + rotate: Math.atan2(b, a) * degrees, + skewX: Math.atan(skewX) * degrees, + scaleX, + scaleY + }; + } + var svgNode; + function parseCss(value2) { + const m = new (typeof DOMMatrix === "function" ? DOMMatrix : WebKitCSSMatrix)(value2 + ""); + return m.isIdentity ? identity$4 : decompose(m.a, m.b, m.c, m.d, m.e, m.f); + } + function parseSvg(value2) { + if (value2 == null) + return identity$4; + if (!svgNode) + svgNode = document.createElementNS("http://www.w3.org/2000/svg", "g"); + svgNode.setAttribute("transform", value2); + if (!(value2 = svgNode.transform.baseVal.consolidate())) + return identity$4; + value2 = value2.matrix; + return decompose(value2.a, value2.b, value2.c, value2.d, value2.e, value2.f); + } + function interpolateTransform(parse2, pxComma, pxParen, degParen) { + function pop(s) { + return s.length ? s.pop() + " " : ""; + } + function translate(xa, ya, xb, yb, s, q) { + if (xa !== xb || ya !== yb) { + var i2 = s.push("translate(", null, pxComma, null, pxParen); + q.push({ i: i2 - 4, x: interpolateNumber(xa, xb) }, { i: i2 - 2, x: interpolateNumber(ya, yb) }); + } else if (xb || yb) { + s.push("translate(" + xb + pxComma + yb + pxParen); + } + } + function rotate(a, b, s, q) { + if (a !== b) { + if (a - b > 180) + b += 360; + else if (b - a > 180) + a += 360; + q.push({ i: s.push(pop(s) + "rotate(", null, degParen) - 2, x: interpolateNumber(a, b) }); + } else if (b) { + s.push(pop(s) + "rotate(" + b + degParen); + } + } + function skewX(a, b, s, q) { + if (a !== b) { + q.push({ i: s.push(pop(s) + "skewX(", null, degParen) - 2, x: interpolateNumber(a, b) }); + } else if (b) { + s.push(pop(s) + "skewX(" + b + degParen); + } + } + function scale(xa, ya, xb, yb, s, q) { + if (xa !== xb || ya !== yb) { + var i2 = s.push(pop(s) + "scale(", null, ",", null, ")"); + q.push({ i: i2 - 4, x: interpolateNumber(xa, xb) }, { i: i2 - 2, x: interpolateNumber(ya, yb) }); + } else if (xb !== 1 || yb !== 1) { + s.push(pop(s) + "scale(" + xb + "," + yb + ")"); + } + } + return function(a, b) { + var s = [], q = []; + a = parse2(a), b = parse2(b); + translate(a.translateX, a.translateY, b.translateX, b.translateY, s, q); + rotate(a.rotate, b.rotate, s, q); + skewX(a.skewX, b.skewX, s, q); + scale(a.scaleX, a.scaleY, b.scaleX, b.scaleY, s, q); + a = b = null; + return function(t) { + var i2 = -1, n = q.length, o; + while (++i2 < n) + s[(o = q[i2]).i] = o.x(t); + return s.join(""); + }; + }; + } + var interpolateTransformCss = interpolateTransform(parseCss, "px, ", "px)", "deg)"); + var interpolateTransformSvg = interpolateTransform(parseSvg, ", ", ")", ")"); + function hcl(hue2) { + return function(start2, end2) { + var h = hue2((start2 = hcl$1(start2)).h, (end2 = hcl$1(end2)).h), c2 = nogamma(start2.c, end2.c), l = nogamma(start2.l, end2.l), opacity = nogamma(start2.opacity, end2.opacity); + return function(t) { + start2.h = h(t); + start2.c = c2(t); + start2.l = l(t); + start2.opacity = opacity(t); + return start2 + ""; + }; + }; + } + const interpolateHcl = hcl(hue); + var frame = 0, timeout$1 = 0, interval = 0, pokeDelay = 1e3, taskHead, taskTail, clockLast = 0, clockNow = 0, clockSkew = 0, clock = typeof performance === "object" && performance.now ? performance : Date, setFrame = typeof window === "object" && window.requestAnimationFrame ? window.requestAnimationFrame.bind(window) : function(f2) { + setTimeout(f2, 17); + }; + function now$2() { + return clockNow || (setFrame(clearNow), clockNow = clock.now() + clockSkew); + } + function clearNow() { + clockNow = 0; + } + function Timer() { + this._call = this._time = this._next = null; + } + Timer.prototype = timer.prototype = { + constructor: Timer, + restart: function(callback, delay, time2) { + if (typeof callback !== "function") + throw new TypeError("callback is not a function"); + time2 = (time2 == null ? now$2() : +time2) + (delay == null ? 0 : +delay); + if (!this._next && taskTail !== this) { + if (taskTail) + taskTail._next = this; + else + taskHead = this; + taskTail = this; + } + this._call = callback; + this._time = time2; + sleep(); + }, + stop: function() { + if (this._call) { + this._call = null; + this._time = Infinity; + sleep(); + } + } + }; + function timer(callback, delay, time2) { + var t = new Timer(); + t.restart(callback, delay, time2); + return t; + } + function timerFlush() { + now$2(); + ++frame; + var t = taskHead, e; + while (t) { + if ((e = clockNow - t._time) >= 0) + t._call.call(void 0, e); + t = t._next; + } + --frame; + } + function wake() { + clockNow = (clockLast = clock.now()) + clockSkew; + frame = timeout$1 = 0; + try { + timerFlush(); + } finally { + frame = 0; + nap(); + clockNow = 0; + } + } + function poke() { + var now2 = clock.now(), delay = now2 - clockLast; + if (delay > pokeDelay) + clockSkew -= delay, clockLast = now2; + } + function nap() { + var t02, t12 = taskHead, t22, time2 = Infinity; + while (t12) { + if (t12._call) { + if (time2 > t12._time) + time2 = t12._time; + t02 = t12, t12 = t12._next; + } else { + t22 = t12._next, t12._next = null; + t12 = t02 ? t02._next = t22 : taskHead = t22; + } + } + taskTail = t02; + sleep(time2); + } + function sleep(time2) { + if (frame) + return; + if (timeout$1) + timeout$1 = clearTimeout(timeout$1); + var delay = time2 - clockNow; + if (delay > 24) { + if (time2 < Infinity) + timeout$1 = setTimeout(wake, time2 - clock.now() - clockSkew); + if (interval) + interval = clearInterval(interval); + } else { + if (!interval) + clockLast = clock.now(), interval = setInterval(poke, pokeDelay); + frame = 1, setFrame(wake); + } + } + function timeout(callback, delay, time2) { + var t = new Timer(); + delay = delay == null ? 0 : +delay; + t.restart((elapsed) => { + t.stop(); + callback(elapsed + delay); + }, delay, time2); + return t; + } + var emptyOn = dispatch("start", "end", "cancel", "interrupt"); + var emptyTween = []; + var CREATED = 0; + var SCHEDULED = 1; + var STARTING = 2; + var STARTED = 3; + var RUNNING = 4; + var ENDING = 5; + var ENDED = 6; + function schedule(node2, name, id2, index2, group, timing) { + var schedules = node2.__transition; + if (!schedules) + node2.__transition = {}; + else if (id2 in schedules) + return; + create$1(node2, id2, { + name, + index: index2, + // For context during callback. + group, + // For context during callback. + on: emptyOn, + tween: emptyTween, + time: timing.time, + delay: timing.delay, + duration: timing.duration, + ease: timing.ease, + timer: null, + state: CREATED + }); + } + function init$1(node2, id2) { + var schedule2 = get$2(node2, id2); + if (schedule2.state > CREATED) + throw new Error("too late; already scheduled"); + return schedule2; + } + function set$2(node2, id2) { + var schedule2 = get$2(node2, id2); + if (schedule2.state > STARTED) + throw new Error("too late; already running"); + return schedule2; + } + function get$2(node2, id2) { + var schedule2 = node2.__transition; + if (!schedule2 || !(schedule2 = schedule2[id2])) + throw new Error("transition not found"); + return schedule2; + } + function create$1(node2, id2, self2) { + var schedules = node2.__transition, tween; + schedules[id2] = self2; + self2.timer = timer(schedule2, 0, self2.time); + function schedule2(elapsed) { + self2.state = SCHEDULED; + self2.timer.restart(start2, self2.delay, self2.time); + if (self2.delay <= elapsed) + start2(elapsed - self2.delay); + } + function start2(elapsed) { + var i2, j, n, o; + if (self2.state !== SCHEDULED) + return stop(); + for (i2 in schedules) { + o = schedules[i2]; + if (o.name !== self2.name) + continue; + if (o.state === STARTED) + return timeout(start2); + if (o.state === RUNNING) { + o.state = ENDED; + o.timer.stop(); + o.on.call("interrupt", node2, node2.__data__, o.index, o.group); + delete schedules[i2]; + } else if (+i2 < id2) { + o.state = ENDED; + o.timer.stop(); + o.on.call("cancel", node2, node2.__data__, o.index, o.group); + delete schedules[i2]; + } + } + timeout(function() { + if (self2.state === STARTED) { + self2.state = RUNNING; + self2.timer.restart(tick, self2.delay, self2.time); + tick(elapsed); + } + }); + self2.state = STARTING; + self2.on.call("start", node2, node2.__data__, self2.index, self2.group); + if (self2.state !== STARTING) + return; + self2.state = STARTED; + tween = new Array(n = self2.tween.length); + for (i2 = 0, j = -1; i2 < n; ++i2) { + if (o = self2.tween[i2].value.call(node2, node2.__data__, self2.index, self2.group)) { + tween[++j] = o; + } + } + tween.length = j + 1; + } + function tick(elapsed) { + var t = elapsed < self2.duration ? self2.ease.call(null, elapsed / self2.duration) : (self2.timer.restart(stop), self2.state = ENDING, 1), i2 = -1, n = tween.length; + while (++i2 < n) { + tween[i2].call(node2, t); + } + if (self2.state === ENDING) { + self2.on.call("end", node2, node2.__data__, self2.index, self2.group); + stop(); + } + } + function stop() { + self2.state = ENDED; + self2.timer.stop(); + delete schedules[id2]; + for (var i2 in schedules) + return; + delete node2.__transition; + } + } + function interrupt(node2, name) { + var schedules = node2.__transition, schedule2, active, empty2 = true, i2; + if (!schedules) + return; + name = name == null ? null : name + ""; + for (i2 in schedules) { + if ((schedule2 = schedules[i2]).name !== name) { + empty2 = false; + continue; + } + active = schedule2.state > STARTING && schedule2.state < ENDING; + schedule2.state = ENDED; + schedule2.timer.stop(); + schedule2.on.call(active ? "interrupt" : "cancel", node2, node2.__data__, schedule2.index, schedule2.group); + delete schedules[i2]; + } + if (empty2) + delete node2.__transition; + } + function selection_interrupt(name) { + return this.each(function() { + interrupt(this, name); + }); + } + function tweenRemove(id2, name) { + var tween0, tween1; + return function() { + var schedule2 = set$2(this, id2), tween = schedule2.tween; + if (tween !== tween0) { + tween1 = tween0 = tween; + for (var i2 = 0, n = tween1.length; i2 < n; ++i2) { + if (tween1[i2].name === name) { + tween1 = tween1.slice(); + tween1.splice(i2, 1); + break; + } + } + } + schedule2.tween = tween1; + }; + } + function tweenFunction(id2, name, value2) { + var tween0, tween1; + if (typeof value2 !== "function") + throw new Error(); + return function() { + var schedule2 = set$2(this, id2), tween = schedule2.tween; + if (tween !== tween0) { + tween1 = (tween0 = tween).slice(); + for (var t = { name, value: value2 }, i2 = 0, n = tween1.length; i2 < n; ++i2) { + if (tween1[i2].name === name) { + tween1[i2] = t; + break; + } + } + if (i2 === n) + tween1.push(t); + } + schedule2.tween = tween1; + }; + } + function transition_tween(name, value2) { + var id2 = this._id; + name += ""; + if (arguments.length < 2) { + var tween = get$2(this.node(), id2).tween; + for (var i2 = 0, n = tween.length, t; i2 < n; ++i2) { + if ((t = tween[i2]).name === name) { + return t.value; + } + } + return null; + } + return this.each((value2 == null ? tweenRemove : tweenFunction)(id2, name, value2)); + } + function tweenValue(transition, name, value2) { + var id2 = transition._id; + transition.each(function() { + var schedule2 = set$2(this, id2); + (schedule2.value || (schedule2.value = {}))[name] = value2.apply(this, arguments); + }); + return function(node2) { + return get$2(node2, id2).value[name]; + }; + } + function interpolate(a, b) { + var c2; + return (typeof b === "number" ? interpolateNumber : b instanceof color ? interpolateRgb : (c2 = color(b)) ? (b = c2, interpolateRgb) : interpolateString)(a, b); + } + function attrRemove(name) { + return function() { + this.removeAttribute(name); + }; + } + function attrRemoveNS(fullname) { + return function() { + this.removeAttributeNS(fullname.space, fullname.local); + }; + } + function attrConstant(name, interpolate2, value1) { + var string00, string1 = value1 + "", interpolate0; + return function() { + var string0 = this.getAttribute(name); + return string0 === string1 ? null : string0 === string00 ? interpolate0 : interpolate0 = interpolate2(string00 = string0, value1); + }; + } + function attrConstantNS(fullname, interpolate2, value1) { + var string00, string1 = value1 + "", interpolate0; + return function() { + var string0 = this.getAttributeNS(fullname.space, fullname.local); + return string0 === string1 ? null : string0 === string00 ? interpolate0 : interpolate0 = interpolate2(string00 = string0, value1); + }; + } + function attrFunction(name, interpolate2, value2) { + var string00, string10, interpolate0; + return function() { + var string0, value1 = value2(this), string1; + if (value1 == null) + return void this.removeAttribute(name); + string0 = this.getAttribute(name); + string1 = value1 + ""; + return string0 === string1 ? null : string0 === string00 && string1 === string10 ? interpolate0 : (string10 = string1, interpolate0 = interpolate2(string00 = string0, value1)); + }; + } + function attrFunctionNS(fullname, interpolate2, value2) { + var string00, string10, interpolate0; + return function() { + var string0, value1 = value2(this), string1; + if (value1 == null) + return void this.removeAttributeNS(fullname.space, fullname.local); + string0 = this.getAttributeNS(fullname.space, fullname.local); + string1 = value1 + ""; + return string0 === string1 ? null : string0 === string00 && string1 === string10 ? interpolate0 : (string10 = string1, interpolate0 = interpolate2(string00 = string0, value1)); + }; + } + function transition_attr(name, value2) { + var fullname = namespace(name), i2 = fullname === "transform" ? interpolateTransformSvg : interpolate; + return this.attrTween(name, typeof value2 === "function" ? (fullname.local ? attrFunctionNS : attrFunction)(fullname, i2, tweenValue(this, "attr." + name, value2)) : value2 == null ? (fullname.local ? attrRemoveNS : attrRemove)(fullname) : (fullname.local ? attrConstantNS : attrConstant)(fullname, i2, value2)); + } + function attrInterpolate(name, i2) { + return function(t) { + this.setAttribute(name, i2.call(this, t)); + }; + } + function attrInterpolateNS(fullname, i2) { + return function(t) { + this.setAttributeNS(fullname.space, fullname.local, i2.call(this, t)); + }; + } + function attrTweenNS(fullname, value2) { + var t02, i0; + function tween() { + var i2 = value2.apply(this, arguments); + if (i2 !== i0) + t02 = (i0 = i2) && attrInterpolateNS(fullname, i2); + return t02; + } + tween._value = value2; + return tween; + } + function attrTween(name, value2) { + var t02, i0; + function tween() { + var i2 = value2.apply(this, arguments); + if (i2 !== i0) + t02 = (i0 = i2) && attrInterpolate(name, i2); + return t02; + } + tween._value = value2; + return tween; + } + function transition_attrTween(name, value2) { + var key = "attr." + name; + if (arguments.length < 2) + return (key = this.tween(key)) && key._value; + if (value2 == null) + return this.tween(key, null); + if (typeof value2 !== "function") + throw new Error(); + var fullname = namespace(name); + return this.tween(key, (fullname.local ? attrTweenNS : attrTween)(fullname, value2)); + } + function delayFunction(id2, value2) { + return function() { + init$1(this, id2).delay = +value2.apply(this, arguments); + }; + } + function delayConstant(id2, value2) { + return value2 = +value2, function() { + init$1(this, id2).delay = value2; + }; + } + function transition_delay(value2) { + var id2 = this._id; + return arguments.length ? this.each((typeof value2 === "function" ? delayFunction : delayConstant)(id2, value2)) : get$2(this.node(), id2).delay; + } + function durationFunction(id2, value2) { + return function() { + set$2(this, id2).duration = +value2.apply(this, arguments); + }; + } + function durationConstant(id2, value2) { + return value2 = +value2, function() { + set$2(this, id2).duration = value2; + }; + } + function transition_duration(value2) { + var id2 = this._id; + return arguments.length ? this.each((typeof value2 === "function" ? durationFunction : durationConstant)(id2, value2)) : get$2(this.node(), id2).duration; + } + function easeConstant(id2, value2) { + if (typeof value2 !== "function") + throw new Error(); + return function() { + set$2(this, id2).ease = value2; + }; + } + function transition_ease(value2) { + var id2 = this._id; + return arguments.length ? this.each(easeConstant(id2, value2)) : get$2(this.node(), id2).ease; + } + function easeVarying(id2, value2) { + return function() { + var v = value2.apply(this, arguments); + if (typeof v !== "function") + throw new Error(); + set$2(this, id2).ease = v; + }; + } + function transition_easeVarying(value2) { + if (typeof value2 !== "function") + throw new Error(); + return this.each(easeVarying(this._id, value2)); + } + function transition_filter(match) { + if (typeof match !== "function") + match = matcher(match); + for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) { + for (var group = groups[j], n = group.length, subgroup = subgroups[j] = [], node2, i2 = 0; i2 < n; ++i2) { + if ((node2 = group[i2]) && match.call(node2, node2.__data__, i2, group)) { + subgroup.push(node2); + } + } + } + return new Transition(subgroups, this._parents, this._name, this._id); + } + function transition_merge(transition) { + if (transition._id !== this._id) + throw new Error(); + for (var groups0 = this._groups, groups1 = transition._groups, m0 = groups0.length, m1 = groups1.length, m = Math.min(m0, m1), merges = new Array(m0), j = 0; j < m; ++j) { + for (var group0 = groups0[j], group1 = groups1[j], n = group0.length, merge2 = merges[j] = new Array(n), node2, i2 = 0; i2 < n; ++i2) { + if (node2 = group0[i2] || group1[i2]) { + merge2[i2] = node2; + } + } + } + for (; j < m0; ++j) { + merges[j] = groups0[j]; + } + return new Transition(merges, this._parents, this._name, this._id); + } + function start$1(name) { + return (name + "").trim().split(/^|\s+/).every(function(t) { + var i2 = t.indexOf("."); + if (i2 >= 0) + t = t.slice(0, i2); + return !t || t === "start"; + }); + } + function onFunction(id2, name, listener) { + var on0, on1, sit = start$1(name) ? init$1 : set$2; + return function() { + var schedule2 = sit(this, id2), on = schedule2.on; + if (on !== on0) + (on1 = (on0 = on).copy()).on(name, listener); + schedule2.on = on1; + }; + } + function transition_on(name, listener) { + var id2 = this._id; + return arguments.length < 2 ? get$2(this.node(), id2).on.on(name) : this.each(onFunction(id2, name, listener)); + } + function removeFunction(id2) { + return function() { + var parent = this.parentNode; + for (var i2 in this.__transition) + if (+i2 !== id2) + return; + if (parent) + parent.removeChild(this); + }; + } + function transition_remove() { + return this.on("end.remove", removeFunction(this._id)); + } + function transition_select(select) { + var name = this._name, id2 = this._id; + if (typeof select !== "function") + select = selector(select); + for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) { + for (var group = groups[j], n = group.length, subgroup = subgroups[j] = new Array(n), node2, subnode, i2 = 0; i2 < n; ++i2) { + if ((node2 = group[i2]) && (subnode = select.call(node2, node2.__data__, i2, group))) { + if ("__data__" in node2) + subnode.__data__ = node2.__data__; + subgroup[i2] = subnode; + schedule(subgroup[i2], name, id2, i2, subgroup, get$2(node2, id2)); + } + } + } + return new Transition(subgroups, this._parents, name, id2); + } + function transition_selectAll(select) { + var name = this._name, id2 = this._id; + if (typeof select !== "function") + select = selectorAll(select); + for (var groups = this._groups, m = groups.length, subgroups = [], parents2 = [], j = 0; j < m; ++j) { + for (var group = groups[j], n = group.length, node2, i2 = 0; i2 < n; ++i2) { + if (node2 = group[i2]) { + for (var children2 = select.call(node2, node2.__data__, i2, group), child, inherit2 = get$2(node2, id2), k = 0, l = children2.length; k < l; ++k) { + if (child = children2[k]) { + schedule(child, name, id2, k, children2, inherit2); + } + } + subgroups.push(children2); + parents2.push(node2); + } + } + } + return new Transition(subgroups, parents2, name, id2); + } + var Selection = selection.prototype.constructor; + function transition_selection() { + return new Selection(this._groups, this._parents); + } + function styleNull(name, interpolate2) { + var string00, string10, interpolate0; + return function() { + var string0 = styleValue(this, name), string1 = (this.style.removeProperty(name), styleValue(this, name)); + return string0 === string1 ? null : string0 === string00 && string1 === string10 ? interpolate0 : interpolate0 = interpolate2(string00 = string0, string10 = string1); + }; + } + function styleRemove(name) { + return function() { + this.style.removeProperty(name); + }; + } + function styleConstant(name, interpolate2, value1) { + var string00, string1 = value1 + "", interpolate0; + return function() { + var string0 = styleValue(this, name); + return string0 === string1 ? null : string0 === string00 ? interpolate0 : interpolate0 = interpolate2(string00 = string0, value1); + }; + } + function styleFunction(name, interpolate2, value2) { + var string00, string10, interpolate0; + return function() { + var string0 = styleValue(this, name), value1 = value2(this), string1 = value1 + ""; + if (value1 == null) + string1 = value1 = (this.style.removeProperty(name), styleValue(this, name)); + return string0 === string1 ? null : string0 === string00 && string1 === string10 ? interpolate0 : (string10 = string1, interpolate0 = interpolate2(string00 = string0, value1)); + }; + } + function styleMaybeRemove(id2, name) { + var on0, on1, listener0, key = "style." + name, event = "end." + key, remove2; + return function() { + var schedule2 = set$2(this, id2), on = schedule2.on, listener = schedule2.value[key] == null ? remove2 || (remove2 = styleRemove(name)) : void 0; + if (on !== on0 || listener0 !== listener) + (on1 = (on0 = on).copy()).on(event, listener0 = listener); + schedule2.on = on1; + }; + } + function transition_style(name, value2, priority) { + var i2 = (name += "") === "transform" ? interpolateTransformCss : interpolate; + return value2 == null ? this.styleTween(name, styleNull(name, i2)).on("end.style." + name, styleRemove(name)) : typeof value2 === "function" ? this.styleTween(name, styleFunction(name, i2, tweenValue(this, "style." + name, value2))).each(styleMaybeRemove(this._id, name)) : this.styleTween(name, styleConstant(name, i2, value2), priority).on("end.style." + name, null); + } + function styleInterpolate(name, i2, priority) { + return function(t) { + this.style.setProperty(name, i2.call(this, t), priority); + }; + } + function styleTween(name, value2, priority) { + var t, i0; + function tween() { + var i2 = value2.apply(this, arguments); + if (i2 !== i0) + t = (i0 = i2) && styleInterpolate(name, i2, priority); + return t; + } + tween._value = value2; + return tween; + } + function transition_styleTween(name, value2, priority) { + var key = "style." + (name += ""); + if (arguments.length < 2) + return (key = this.tween(key)) && key._value; + if (value2 == null) + return this.tween(key, null); + if (typeof value2 !== "function") + throw new Error(); + return this.tween(key, styleTween(name, value2, priority == null ? "" : priority)); + } + function textConstant(value2) { + return function() { + this.textContent = value2; + }; + } + function textFunction(value2) { + return function() { + var value1 = value2(this); + this.textContent = value1 == null ? "" : value1; + }; + } + function transition_text(value2) { + return this.tween("text", typeof value2 === "function" ? textFunction(tweenValue(this, "text", value2)) : textConstant(value2 == null ? "" : value2 + "")); + } + function textInterpolate(i2) { + return function(t) { + this.textContent = i2.call(this, t); + }; + } + function textTween(value2) { + var t02, i0; + function tween() { + var i2 = value2.apply(this, arguments); + if (i2 !== i0) + t02 = (i0 = i2) && textInterpolate(i2); + return t02; + } + tween._value = value2; + return tween; + } + function transition_textTween(value2) { + var key = "text"; + if (arguments.length < 1) + return (key = this.tween(key)) && key._value; + if (value2 == null) + return this.tween(key, null); + if (typeof value2 !== "function") + throw new Error(); + return this.tween(key, textTween(value2)); + } + function transition_transition() { + var name = this._name, id0 = this._id, id1 = newId(); + for (var groups = this._groups, m = groups.length, j = 0; j < m; ++j) { + for (var group = groups[j], n = group.length, node2, i2 = 0; i2 < n; ++i2) { + if (node2 = group[i2]) { + var inherit2 = get$2(node2, id0); + schedule(node2, name, id1, i2, group, { + time: inherit2.time + inherit2.delay + inherit2.duration, + delay: 0, + duration: inherit2.duration, + ease: inherit2.ease + }); + } + } + } + return new Transition(groups, this._parents, name, id1); + } + function transition_end() { + var on0, on1, that = this, id2 = that._id, size2 = that.size(); + return new Promise(function(resolve, reject) { + var cancel = { value: reject }, end2 = { value: function() { + if (--size2 === 0) + resolve(); + } }; + that.each(function() { + var schedule2 = set$2(this, id2), on = schedule2.on; + if (on !== on0) { + on1 = (on0 = on).copy(); + on1._.cancel.push(cancel); + on1._.interrupt.push(cancel); + on1._.end.push(end2); + } + schedule2.on = on1; + }); + if (size2 === 0) + resolve(); + }); + } + var id$m = 0; + function Transition(groups, parents2, name, id2) { + this._groups = groups; + this._parents = parents2; + this._name = name; + this._id = id2; + } + function newId() { + return ++id$m; + } + var selection_prototype = selection.prototype; + Transition.prototype = { + constructor: Transition, + select: transition_select, + selectAll: transition_selectAll, + selectChild: selection_prototype.selectChild, + selectChildren: selection_prototype.selectChildren, + filter: transition_filter, + merge: transition_merge, + selection: transition_selection, + transition: transition_transition, + call: selection_prototype.call, + nodes: selection_prototype.nodes, + node: selection_prototype.node, + size: selection_prototype.size, + empty: selection_prototype.empty, + each: selection_prototype.each, + on: transition_on, + attr: transition_attr, + attrTween: transition_attrTween, + style: transition_style, + styleTween: transition_styleTween, + text: transition_text, + textTween: transition_textTween, + remove: transition_remove, + tween: transition_tween, + delay: transition_delay, + duration: transition_duration, + ease: transition_ease, + easeVarying: transition_easeVarying, + end: transition_end, + [Symbol.iterator]: selection_prototype[Symbol.iterator] + }; + function cubicInOut(t) { + return ((t *= 2) <= 1 ? t * t * t : (t -= 2) * t * t + 2) / 2; + } + var defaultTiming = { + time: null, + // Set on use. + delay: 0, + duration: 250, + ease: cubicInOut + }; + function inherit(node2, id2) { + var timing; + while (!(timing = node2.__transition) || !(timing = timing[id2])) { + if (!(node2 = node2.parentNode)) { + throw new Error(`transition ${id2} not found`); + } + } + return timing; + } + function selection_transition(name) { + var id2, timing; + if (name instanceof Transition) { + id2 = name._id, name = name._name; + } else { + id2 = newId(), (timing = defaultTiming).time = now$2(), name = name == null ? null : name + ""; + } + for (var groups = this._groups, m = groups.length, j = 0; j < m; ++j) { + for (var group = groups[j], n = group.length, node2, i2 = 0; i2 < n; ++i2) { + if (node2 = group[i2]) { + schedule(node2, name, id2, i2, group, timing || inherit(node2, id2)); + } + } + } + return new Transition(groups, this._parents, name, id2); + } + selection.prototype.interrupt = selection_interrupt; + selection.prototype.transition = selection_transition; + const pi$2 = Math.PI, tau$2 = 2 * pi$2, epsilon$2 = 1e-6, tauEpsilon$1 = tau$2 - epsilon$2; + function append$1(strings) { + this._ += strings[0]; + for (let i2 = 1, n = strings.length; i2 < n; ++i2) { + this._ += arguments[i2] + strings[i2]; + } + } + function appendRound(digits) { + let d = Math.floor(digits); + if (!(d >= 0)) + throw new Error(`invalid digits: ${digits}`); + if (d > 15) + return append$1; + const k = 10 ** d; + return function(strings) { + this._ += strings[0]; + for (let i2 = 1, n = strings.length; i2 < n; ++i2) { + this._ += Math.round(arguments[i2] * k) / k + strings[i2]; + } + }; + } + let Path$1 = class Path { + constructor(digits) { + this._x0 = this._y0 = // start of current subpath + this._x1 = this._y1 = null; + this._ = ""; + this._append = digits == null ? append$1 : appendRound(digits); + } + moveTo(x2, y2) { + this._append`M${this._x0 = this._x1 = +x2},${this._y0 = this._y1 = +y2}`; + } + closePath() { + if (this._x1 !== null) { + this._x1 = this._x0, this._y1 = this._y0; + this._append`Z`; + } + } + lineTo(x2, y2) { + this._append`L${this._x1 = +x2},${this._y1 = +y2}`; + } + quadraticCurveTo(x1, y1, x2, y2) { + this._append`Q${+x1},${+y1},${this._x1 = +x2},${this._y1 = +y2}`; + } + bezierCurveTo(x1, y1, x2, y2, x3, y3) { + this._append`C${+x1},${+y1},${+x2},${+y2},${this._x1 = +x3},${this._y1 = +y3}`; + } + arcTo(x1, y1, x2, y2, r) { + x1 = +x1, y1 = +y1, x2 = +x2, y2 = +y2, r = +r; + if (r < 0) + throw new Error(`negative radius: ${r}`); + let x0 = this._x1, y0 = this._y1, x21 = x2 - x1, y21 = y2 - y1, x01 = x0 - x1, y01 = y0 - y1, l01_2 = x01 * x01 + y01 * y01; + if (this._x1 === null) { + this._append`M${this._x1 = x1},${this._y1 = y1}`; + } else if (!(l01_2 > epsilon$2)) + ; + else if (!(Math.abs(y01 * x21 - y21 * x01) > epsilon$2) || !r) { + this._append`L${this._x1 = x1},${this._y1 = y1}`; + } else { + let x20 = x2 - x0, y20 = y2 - y0, l21_2 = x21 * x21 + y21 * y21, l20_2 = x20 * x20 + y20 * y20, l21 = Math.sqrt(l21_2), l01 = Math.sqrt(l01_2), l = r * Math.tan((pi$2 - Math.acos((l21_2 + l01_2 - l20_2) / (2 * l21 * l01))) / 2), t01 = l / l01, t21 = l / l21; + if (Math.abs(t01 - 1) > epsilon$2) { + this._append`L${x1 + t01 * x01},${y1 + t01 * y01}`; + } + this._append`A${r},${r},0,0,${+(y01 * x20 > x01 * y20)},${this._x1 = x1 + t21 * x21},${this._y1 = y1 + t21 * y21}`; + } + } + arc(x2, y2, r, a0, a1, ccw) { + x2 = +x2, y2 = +y2, r = +r, ccw = !!ccw; + if (r < 0) + throw new Error(`negative radius: ${r}`); + let dx = r * Math.cos(a0), dy = r * Math.sin(a0), x0 = x2 + dx, y0 = y2 + dy, cw = 1 ^ ccw, da = ccw ? a0 - a1 : a1 - a0; + if (this._x1 === null) { + this._append`M${x0},${y0}`; + } else if (Math.abs(this._x1 - x0) > epsilon$2 || Math.abs(this._y1 - y0) > epsilon$2) { + this._append`L${x0},${y0}`; + } + if (!r) + return; + if (da < 0) + da = da % tau$2 + tau$2; + if (da > tauEpsilon$1) { + this._append`A${r},${r},0,1,${cw},${x2 - dx},${y2 - dy}A${r},${r},0,1,${cw},${this._x1 = x0},${this._y1 = y0}`; + } else if (da > epsilon$2) { + this._append`A${r},${r},0,${+(da >= pi$2)},${cw},${this._x1 = x2 + r * Math.cos(a1)},${this._y1 = y2 + r * Math.sin(a1)}`; + } + } + rect(x2, y2, w2, h) { + this._append`M${this._x0 = this._x1 = +x2},${this._y0 = this._y1 = +y2}h${w2 = +w2}v${+h}h${-w2}Z`; + } + toString() { + return this._; + } + }; + function responseText(response) { + if (!response.ok) + throw new Error(response.status + " " + response.statusText); + return response.text(); + } + function text$4(input, init2) { + return fetch(input, init2).then(responseText); + } + function parser$x(type2) { + return (input, init2) => text$4(input, init2).then((text2) => new DOMParser().parseFromString(text2, type2)); + } + var svg$2 = parser$x("image/svg+xml"); + function formatDecimal(x2) { + return Math.abs(x2 = Math.round(x2)) >= 1e21 ? x2.toLocaleString("en").replace(/,/g, "") : x2.toString(10); + } + function formatDecimalParts(x2, p) { + if ((i2 = (x2 = p ? x2.toExponential(p - 1) : x2.toExponential()).indexOf("e")) < 0) + return null; + var i2, coefficient = x2.slice(0, i2); + return [ + coefficient.length > 1 ? coefficient[0] + coefficient.slice(2) : coefficient, + +x2.slice(i2 + 1) + ]; + } + function exponent(x2) { + return x2 = formatDecimalParts(Math.abs(x2)), x2 ? x2[1] : NaN; + } + function formatGroup(grouping, thousands) { + return function(value2, width2) { + var i2 = value2.length, t = [], j = 0, g = grouping[0], length2 = 0; + while (i2 > 0 && g > 0) { + if (length2 + g + 1 > width2) + g = Math.max(1, width2 - length2); + t.push(value2.substring(i2 -= g, i2 + g)); + if ((length2 += g + 1) > width2) + break; + g = grouping[j = (j + 1) % grouping.length]; + } + return t.reverse().join(thousands); + }; + } + function formatNumerals(numerals) { + return function(value2) { + return value2.replace(/[0-9]/g, function(i2) { + return numerals[+i2]; + }); + }; + } + var re = /^(?:(.)?([<>=^]))?([+\-( ])?([$#])?(0)?(\d+)?(,)?(\.\d+)?(~)?([a-z%])?$/i; + function formatSpecifier(specifier) { + if (!(match = re.exec(specifier))) + throw new Error("invalid format: " + specifier); + var match; + return new FormatSpecifier({ + fill: match[1], + align: match[2], + sign: match[3], + symbol: match[4], + zero: match[5], + width: match[6], + comma: match[7], + precision: match[8] && match[8].slice(1), + trim: match[9], + type: match[10] + }); + } + formatSpecifier.prototype = FormatSpecifier.prototype; + function FormatSpecifier(specifier) { + this.fill = specifier.fill === void 0 ? " " : specifier.fill + ""; + this.align = specifier.align === void 0 ? ">" : specifier.align + ""; + this.sign = specifier.sign === void 0 ? "-" : specifier.sign + ""; + this.symbol = specifier.symbol === void 0 ? "" : specifier.symbol + ""; + this.zero = !!specifier.zero; + this.width = specifier.width === void 0 ? void 0 : +specifier.width; + this.comma = !!specifier.comma; + this.precision = specifier.precision === void 0 ? void 0 : +specifier.precision; + this.trim = !!specifier.trim; + this.type = specifier.type === void 0 ? "" : specifier.type + ""; + } + FormatSpecifier.prototype.toString = function() { + return this.fill + this.align + this.sign + this.symbol + (this.zero ? "0" : "") + (this.width === void 0 ? "" : Math.max(1, this.width | 0)) + (this.comma ? "," : "") + (this.precision === void 0 ? "" : "." + Math.max(0, this.precision | 0)) + (this.trim ? "~" : "") + this.type; + }; + function formatTrim(s) { + out: + for (var n = s.length, i2 = 1, i0 = -1, i1; i2 < n; ++i2) { + switch (s[i2]) { + case ".": + i0 = i1 = i2; + break; + case "0": + if (i0 === 0) + i0 = i2; + i1 = i2; + break; + default: + if (!+s[i2]) + break out; + if (i0 > 0) + i0 = 0; + break; + } + } + return i0 > 0 ? s.slice(0, i0) + s.slice(i1 + 1) : s; + } + var prefixExponent; + function formatPrefixAuto(x2, p) { + var d = formatDecimalParts(x2, p); + if (!d) + return x2 + ""; + var coefficient = d[0], exponent2 = d[1], i2 = exponent2 - (prefixExponent = Math.max(-8, Math.min(8, Math.floor(exponent2 / 3))) * 3) + 1, n = coefficient.length; + return i2 === n ? coefficient : i2 > n ? coefficient + new Array(i2 - n + 1).join("0") : i2 > 0 ? coefficient.slice(0, i2) + "." + coefficient.slice(i2) : "0." + new Array(1 - i2).join("0") + formatDecimalParts(x2, Math.max(0, p + i2 - 1))[0]; + } + function formatRounded(x2, p) { + var d = formatDecimalParts(x2, p); + if (!d) + return x2 + ""; + var coefficient = d[0], exponent2 = d[1]; + return exponent2 < 0 ? "0." + new Array(-exponent2).join("0") + coefficient : coefficient.length > exponent2 + 1 ? coefficient.slice(0, exponent2 + 1) + "." + coefficient.slice(exponent2 + 1) : coefficient + new Array(exponent2 - coefficient.length + 2).join("0"); + } + const formatTypes = { + "%": (x2, p) => (x2 * 100).toFixed(p), + "b": (x2) => Math.round(x2).toString(2), + "c": (x2) => x2 + "", + "d": formatDecimal, + "e": (x2, p) => x2.toExponential(p), + "f": (x2, p) => x2.toFixed(p), + "g": (x2, p) => x2.toPrecision(p), + "o": (x2) => Math.round(x2).toString(8), + "p": (x2, p) => formatRounded(x2 * 100, p), + "r": formatRounded, + "s": formatPrefixAuto, + "X": (x2) => Math.round(x2).toString(16).toUpperCase(), + "x": (x2) => Math.round(x2).toString(16) + }; + function identity$3(x2) { + return x2; + } + var map$2 = Array.prototype.map, prefixes = ["y", "z", "a", "f", "p", "n", "µ", "m", "", "k", "M", "G", "T", "P", "E", "Z", "Y"]; + function formatLocale$1(locale2) { + var group = locale2.grouping === void 0 || locale2.thousands === void 0 ? identity$3 : formatGroup(map$2.call(locale2.grouping, Number), locale2.thousands + ""), currencyPrefix = locale2.currency === void 0 ? "" : locale2.currency[0] + "", currencySuffix = locale2.currency === void 0 ? "" : locale2.currency[1] + "", decimal = locale2.decimal === void 0 ? "." : locale2.decimal + "", numerals = locale2.numerals === void 0 ? identity$3 : formatNumerals(map$2.call(locale2.numerals, String)), percent = locale2.percent === void 0 ? "%" : locale2.percent + "", minus = locale2.minus === void 0 ? "−" : locale2.minus + "", nan = locale2.nan === void 0 ? "NaN" : locale2.nan + ""; + function newFormat(specifier) { + specifier = formatSpecifier(specifier); + var fill = specifier.fill, align = specifier.align, sign2 = specifier.sign, symbol = specifier.symbol, zero2 = specifier.zero, width2 = specifier.width, comma = specifier.comma, precision = specifier.precision, trim2 = specifier.trim, type2 = specifier.type; + if (type2 === "n") + comma = true, type2 = "g"; + else if (!formatTypes[type2]) + precision === void 0 && (precision = 12), trim2 = true, type2 = "g"; + if (zero2 || fill === "0" && align === "=") + zero2 = true, fill = "0", align = "="; + var prefix = symbol === "$" ? currencyPrefix : symbol === "#" && /[boxX]/.test(type2) ? "0" + type2.toLowerCase() : "", suffix = symbol === "$" ? currencySuffix : /[%p]/.test(type2) ? percent : ""; + var formatType = formatTypes[type2], maybeSuffix = /[defgprs%]/.test(type2); + precision = precision === void 0 ? 6 : /[gprs]/.test(type2) ? Math.max(1, Math.min(21, precision)) : Math.max(0, Math.min(20, precision)); + function format2(value2) { + var valuePrefix = prefix, valueSuffix = suffix, i2, n, c2; + if (type2 === "c") { + valueSuffix = formatType(value2) + valueSuffix; + value2 = ""; + } else { + value2 = +value2; + var valueNegative = value2 < 0 || 1 / value2 < 0; + value2 = isNaN(value2) ? nan : formatType(Math.abs(value2), precision); + if (trim2) + value2 = formatTrim(value2); + if (valueNegative && +value2 === 0 && sign2 !== "+") + valueNegative = false; + valuePrefix = (valueNegative ? sign2 === "(" ? sign2 : minus : sign2 === "-" || sign2 === "(" ? "" : sign2) + valuePrefix; + valueSuffix = (type2 === "s" ? prefixes[8 + prefixExponent / 3] : "") + valueSuffix + (valueNegative && sign2 === "(" ? ")" : ""); + if (maybeSuffix) { + i2 = -1, n = value2.length; + while (++i2 < n) { + if (c2 = value2.charCodeAt(i2), 48 > c2 || c2 > 57) { + valueSuffix = (c2 === 46 ? decimal + value2.slice(i2 + 1) : value2.slice(i2)) + valueSuffix; + value2 = value2.slice(0, i2); + break; + } + } + } + } + if (comma && !zero2) + value2 = group(value2, Infinity); + var length2 = valuePrefix.length + value2.length + valueSuffix.length, padding2 = length2 < width2 ? new Array(width2 - length2 + 1).join(fill) : ""; + if (comma && zero2) + value2 = group(padding2 + value2, padding2.length ? width2 - valueSuffix.length : Infinity), padding2 = ""; + switch (align) { + case "<": + value2 = valuePrefix + value2 + valueSuffix + padding2; + break; + case "=": + value2 = valuePrefix + padding2 + value2 + valueSuffix; + break; + case "^": + value2 = padding2.slice(0, length2 = padding2.length >> 1) + valuePrefix + value2 + valueSuffix + padding2.slice(length2); + break; + default: + value2 = padding2 + valuePrefix + value2 + valueSuffix; + break; + } + return numerals(value2); + } + format2.toString = function() { + return specifier + ""; + }; + return format2; + } + function formatPrefix2(specifier, value2) { + var f2 = newFormat((specifier = formatSpecifier(specifier), specifier.type = "f", specifier)), e = Math.max(-8, Math.min(8, Math.floor(exponent(value2) / 3))) * 3, k = Math.pow(10, -e), prefix = prefixes[8 + e / 3]; + return function(value3) { + return f2(k * value3) + prefix; + }; + } + return { + format: newFormat, + formatPrefix: formatPrefix2 + }; + } + var locale$1; + var format; + var formatPrefix; + defaultLocale$1({ + thousands: ",", + grouping: [3], + currency: ["$", ""] + }); + function defaultLocale$1(definition2) { + locale$1 = formatLocale$1(definition2); + format = locale$1.format; + formatPrefix = locale$1.formatPrefix; + return locale$1; + } + function precisionFixed(step) { + return Math.max(0, -exponent(Math.abs(step))); + } + function precisionPrefix(step, value2) { + return Math.max(0, Math.max(-8, Math.min(8, Math.floor(exponent(value2) / 3))) * 3 - exponent(Math.abs(step))); + } + function precisionRound(step, max2) { + step = Math.abs(step), max2 = Math.abs(max2) - step; + return Math.max(0, exponent(max2) - exponent(step)) + 1; + } + function initRange(domain, range2) { + switch (arguments.length) { + case 0: + break; + case 1: + this.range(domain); + break; + default: + this.range(range2).domain(domain); + break; + } + return this; + } + const implicit = Symbol("implicit"); + function ordinal() { + var index2 = new InternMap(), domain = [], range2 = [], unknown = implicit; + function scale(d) { + let i2 = index2.get(d); + if (i2 === void 0) { + if (unknown !== implicit) + return unknown; + index2.set(d, i2 = domain.push(d) - 1); + } + return range2[i2 % range2.length]; + } + scale.domain = function(_2) { + if (!arguments.length) + return domain.slice(); + domain = [], index2 = new InternMap(); + for (const value2 of _2) { + if (index2.has(value2)) + continue; + index2.set(value2, domain.push(value2) - 1); + } + return scale; + }; + scale.range = function(_2) { + return arguments.length ? (range2 = Array.from(_2), scale) : range2.slice(); + }; + scale.unknown = function(_2) { + return arguments.length ? (unknown = _2, scale) : unknown; + }; + scale.copy = function() { + return ordinal(domain, range2).unknown(unknown); + }; + initRange.apply(scale, arguments); + return scale; + } + function band() { + var scale = ordinal().unknown(void 0), domain = scale.domain, ordinalRange = scale.range, r0 = 0, r1 = 1, step, bandwidth, round = false, paddingInner = 0, paddingOuter = 0, align = 0.5; + delete scale.unknown; + function rescale() { + var n = domain().length, reverse = r1 < r0, start2 = reverse ? r1 : r0, stop = reverse ? r0 : r1; + step = (stop - start2) / Math.max(1, n - paddingInner + paddingOuter * 2); + if (round) + step = Math.floor(step); + start2 += (stop - start2 - step * (n - paddingInner)) * align; + bandwidth = step * (1 - paddingInner); + if (round) + start2 = Math.round(start2), bandwidth = Math.round(bandwidth); + var values2 = range$2(n).map(function(i2) { + return start2 + step * i2; + }); + return ordinalRange(reverse ? values2.reverse() : values2); + } + scale.domain = function(_2) { + return arguments.length ? (domain(_2), rescale()) : domain(); + }; + scale.range = function(_2) { + return arguments.length ? ([r0, r1] = _2, r0 = +r0, r1 = +r1, rescale()) : [r0, r1]; + }; + scale.rangeRound = function(_2) { + return [r0, r1] = _2, r0 = +r0, r1 = +r1, round = true, rescale(); + }; + scale.bandwidth = function() { + return bandwidth; + }; + scale.step = function() { + return step; + }; + scale.round = function(_2) { + return arguments.length ? (round = !!_2, rescale()) : round; + }; + scale.padding = function(_2) { + return arguments.length ? (paddingInner = Math.min(1, paddingOuter = +_2), rescale()) : paddingInner; + }; + scale.paddingInner = function(_2) { + return arguments.length ? (paddingInner = Math.min(1, _2), rescale()) : paddingInner; + }; + scale.paddingOuter = function(_2) { + return arguments.length ? (paddingOuter = +_2, rescale()) : paddingOuter; + }; + scale.align = function(_2) { + return arguments.length ? (align = Math.max(0, Math.min(1, _2)), rescale()) : align; + }; + scale.copy = function() { + return band(domain(), [r0, r1]).round(round).paddingInner(paddingInner).paddingOuter(paddingOuter).align(align); + }; + return initRange.apply(rescale(), arguments); + } + function constants(x2) { + return function() { + return x2; + }; + } + function number$1(x2) { + return +x2; + } + var unit$1 = [0, 1]; + function identity$2(x2) { + return x2; + } + function normalize(a, b) { + return (b -= a = +a) ? function(x2) { + return (x2 - a) / b; + } : constants(isNaN(b) ? NaN : 0.5); + } + function clamper(a, b) { + var t; + if (a > b) + t = a, a = b, b = t; + return function(x2) { + return Math.max(a, Math.min(b, x2)); + }; + } + function bimap(domain, range2, interpolate2) { + var d0 = domain[0], d1 = domain[1], r0 = range2[0], r1 = range2[1]; + if (d1 < d0) + d0 = normalize(d1, d0), r0 = interpolate2(r1, r0); + else + d0 = normalize(d0, d1), r0 = interpolate2(r0, r1); + return function(x2) { + return r0(d0(x2)); + }; + } + function polymap(domain, range2, interpolate2) { + var j = Math.min(domain.length, range2.length) - 1, d = new Array(j), r = new Array(j), i2 = -1; + if (domain[j] < domain[0]) { + domain = domain.slice().reverse(); + range2 = range2.slice().reverse(); + } + while (++i2 < j) { + d[i2] = normalize(domain[i2], domain[i2 + 1]); + r[i2] = interpolate2(range2[i2], range2[i2 + 1]); + } + return function(x2) { + var i3 = bisect(domain, x2, 1, j) - 1; + return r[i3](d[i3](x2)); + }; + } + function copy$1(source, target) { + return target.domain(source.domain()).range(source.range()).interpolate(source.interpolate()).clamp(source.clamp()).unknown(source.unknown()); + } + function transformer() { + var domain = unit$1, range2 = unit$1, interpolate2 = interpolate$1, transform, untransform, unknown, clamp = identity$2, piecewise, output, input; + function rescale() { + var n = Math.min(domain.length, range2.length); + if (clamp !== identity$2) + clamp = clamper(domain[0], domain[n - 1]); + piecewise = n > 2 ? polymap : bimap; + output = input = null; + return scale; + } + function scale(x2) { + return x2 == null || isNaN(x2 = +x2) ? unknown : (output || (output = piecewise(domain.map(transform), range2, interpolate2)))(transform(clamp(x2))); + } + scale.invert = function(y2) { + return clamp(untransform((input || (input = piecewise(range2, domain.map(transform), interpolateNumber)))(y2))); + }; + scale.domain = function(_2) { + return arguments.length ? (domain = Array.from(_2, number$1), rescale()) : domain.slice(); + }; + scale.range = function(_2) { + return arguments.length ? (range2 = Array.from(_2), rescale()) : range2.slice(); + }; + scale.rangeRound = function(_2) { + return range2 = Array.from(_2), interpolate2 = interpolateRound, rescale(); + }; + scale.clamp = function(_2) { + return arguments.length ? (clamp = _2 ? true : identity$2, rescale()) : clamp !== identity$2; + }; + scale.interpolate = function(_2) { + return arguments.length ? (interpolate2 = _2, rescale()) : interpolate2; + }; + scale.unknown = function(_2) { + return arguments.length ? (unknown = _2, scale) : unknown; + }; + return function(t, u) { + transform = t, untransform = u; + return rescale(); + }; + } + function continuous() { + return transformer()(identity$2, identity$2); + } + function tickFormat(start2, stop, count, specifier) { + var step = tickStep(start2, stop, count), precision; + specifier = formatSpecifier(specifier == null ? ",f" : specifier); + switch (specifier.type) { + case "s": { + var value2 = Math.max(Math.abs(start2), Math.abs(stop)); + if (specifier.precision == null && !isNaN(precision = precisionPrefix(step, value2))) + specifier.precision = precision; + return formatPrefix(specifier, value2); + } + case "": + case "e": + case "g": + case "p": + case "r": { + if (specifier.precision == null && !isNaN(precision = precisionRound(step, Math.max(Math.abs(start2), Math.abs(stop))))) + specifier.precision = precision - (specifier.type === "e"); + break; + } + case "f": + case "%": { + if (specifier.precision == null && !isNaN(precision = precisionFixed(step))) + specifier.precision = precision - (specifier.type === "%") * 2; + break; + } + } + return format(specifier); + } + function linearish(scale) { + var domain = scale.domain; + scale.ticks = function(count) { + var d = domain(); + return ticks(d[0], d[d.length - 1], count == null ? 10 : count); + }; + scale.tickFormat = function(count, specifier) { + var d = domain(); + return tickFormat(d[0], d[d.length - 1], count == null ? 10 : count, specifier); + }; + scale.nice = function(count) { + if (count == null) + count = 10; + var d = domain(); + var i0 = 0; + var i1 = d.length - 1; + var start2 = d[i0]; + var stop = d[i1]; + var prestep; + var step; + var maxIter = 10; + if (stop < start2) { + step = start2, start2 = stop, stop = step; + step = i0, i0 = i1, i1 = step; + } + while (maxIter-- > 0) { + step = tickIncrement(start2, stop, count); + if (step === prestep) { + d[i0] = start2; + d[i1] = stop; + return domain(d); + } else if (step > 0) { + start2 = Math.floor(start2 / step) * step; + stop = Math.ceil(stop / step) * step; + } else if (step < 0) { + start2 = Math.ceil(start2 * step) / step; + stop = Math.floor(stop * step) / step; + } else { + break; + } + prestep = step; + } + return scale; + }; + return scale; + } + function linear() { + var scale = continuous(); + scale.copy = function() { + return copy$1(scale, linear()); + }; + initRange.apply(scale, arguments); + return linearish(scale); + } + function nice(domain, interval2) { + domain = domain.slice(); + var i0 = 0, i1 = domain.length - 1, x0 = domain[i0], x1 = domain[i1], t; + if (x1 < x0) { + t = i0, i0 = i1, i1 = t; + t = x0, x0 = x1, x1 = t; + } + domain[i0] = interval2.floor(x0); + domain[i1] = interval2.ceil(x1); + return domain; + } + const t0 = /* @__PURE__ */ new Date(), t1 = /* @__PURE__ */ new Date(); + function timeInterval(floori, offseti, count, field) { + function interval2(date2) { + return floori(date2 = arguments.length === 0 ? /* @__PURE__ */ new Date() : /* @__PURE__ */ new Date(+date2)), date2; + } + interval2.floor = (date2) => { + return floori(date2 = /* @__PURE__ */ new Date(+date2)), date2; + }; + interval2.ceil = (date2) => { + return floori(date2 = new Date(date2 - 1)), offseti(date2, 1), floori(date2), date2; + }; + interval2.round = (date2) => { + const d0 = interval2(date2), d1 = interval2.ceil(date2); + return date2 - d0 < d1 - date2 ? d0 : d1; + }; + interval2.offset = (date2, step) => { + return offseti(date2 = /* @__PURE__ */ new Date(+date2), step == null ? 1 : Math.floor(step)), date2; + }; + interval2.range = (start2, stop, step) => { + const range2 = []; + start2 = interval2.ceil(start2); + step = step == null ? 1 : Math.floor(step); + if (!(start2 < stop) || !(step > 0)) + return range2; + let previous2; + do + range2.push(previous2 = /* @__PURE__ */ new Date(+start2)), offseti(start2, step), floori(start2); + while (previous2 < start2 && start2 < stop); + return range2; + }; + interval2.filter = (test) => { + return timeInterval((date2) => { + if (date2 >= date2) + while (floori(date2), !test(date2)) + date2.setTime(date2 - 1); + }, (date2, step) => { + if (date2 >= date2) { + if (step < 0) + while (++step <= 0) { + while (offseti(date2, -1), !test(date2)) { + } + } + else + while (--step >= 0) { + while (offseti(date2, 1), !test(date2)) { + } + } + } + }); + }; + if (count) { + interval2.count = (start2, end2) => { + t0.setTime(+start2), t1.setTime(+end2); + floori(t0), floori(t1); + return Math.floor(count(t0, t1)); + }; + interval2.every = (step) => { + step = Math.floor(step); + return !isFinite(step) || !(step > 0) ? null : !(step > 1) ? interval2 : interval2.filter(field ? (d) => field(d) % step === 0 : (d) => interval2.count(0, d) % step === 0); + }; + } + return interval2; + } + const millisecond = timeInterval(() => { + }, (date2, step) => { + date2.setTime(+date2 + step); + }, (start2, end2) => { + return end2 - start2; + }); + millisecond.every = (k) => { + k = Math.floor(k); + if (!isFinite(k) || !(k > 0)) + return null; + if (!(k > 1)) + return millisecond; + return timeInterval((date2) => { + date2.setTime(Math.floor(date2 / k) * k); + }, (date2, step) => { + date2.setTime(+date2 + step * k); + }, (start2, end2) => { + return (end2 - start2) / k; + }); + }; + millisecond.range; + const durationSecond = 1e3; + const durationMinute = durationSecond * 60; + const durationHour = durationMinute * 60; + const durationDay = durationHour * 24; + const durationWeek = durationDay * 7; + const durationMonth = durationDay * 30; + const durationYear = durationDay * 365; + const second = timeInterval((date2) => { + date2.setTime(date2 - date2.getMilliseconds()); + }, (date2, step) => { + date2.setTime(+date2 + step * durationSecond); + }, (start2, end2) => { + return (end2 - start2) / durationSecond; + }, (date2) => { + return date2.getUTCSeconds(); + }); + second.range; + const timeMinute = timeInterval((date2) => { + date2.setTime(date2 - date2.getMilliseconds() - date2.getSeconds() * durationSecond); + }, (date2, step) => { + date2.setTime(+date2 + step * durationMinute); + }, (start2, end2) => { + return (end2 - start2) / durationMinute; + }, (date2) => { + return date2.getMinutes(); + }); + timeMinute.range; + const utcMinute = timeInterval((date2) => { + date2.setUTCSeconds(0, 0); + }, (date2, step) => { + date2.setTime(+date2 + step * durationMinute); + }, (start2, end2) => { + return (end2 - start2) / durationMinute; + }, (date2) => { + return date2.getUTCMinutes(); + }); + utcMinute.range; + const timeHour = timeInterval((date2) => { + date2.setTime(date2 - date2.getMilliseconds() - date2.getSeconds() * durationSecond - date2.getMinutes() * durationMinute); + }, (date2, step) => { + date2.setTime(+date2 + step * durationHour); + }, (start2, end2) => { + return (end2 - start2) / durationHour; + }, (date2) => { + return date2.getHours(); + }); + timeHour.range; + const utcHour = timeInterval((date2) => { + date2.setUTCMinutes(0, 0, 0); + }, (date2, step) => { + date2.setTime(+date2 + step * durationHour); + }, (start2, end2) => { + return (end2 - start2) / durationHour; + }, (date2) => { + return date2.getUTCHours(); + }); + utcHour.range; + const timeDay = timeInterval( + (date2) => date2.setHours(0, 0, 0, 0), + (date2, step) => date2.setDate(date2.getDate() + step), + (start2, end2) => (end2 - start2 - (end2.getTimezoneOffset() - start2.getTimezoneOffset()) * durationMinute) / durationDay, + (date2) => date2.getDate() - 1 + ); + timeDay.range; + const utcDay = timeInterval((date2) => { + date2.setUTCHours(0, 0, 0, 0); + }, (date2, step) => { + date2.setUTCDate(date2.getUTCDate() + step); + }, (start2, end2) => { + return (end2 - start2) / durationDay; + }, (date2) => { + return date2.getUTCDate() - 1; + }); + utcDay.range; + const unixDay = timeInterval((date2) => { + date2.setUTCHours(0, 0, 0, 0); + }, (date2, step) => { + date2.setUTCDate(date2.getUTCDate() + step); + }, (start2, end2) => { + return (end2 - start2) / durationDay; + }, (date2) => { + return Math.floor(date2 / durationDay); + }); + unixDay.range; + function timeWeekday(i2) { + return timeInterval((date2) => { + date2.setDate(date2.getDate() - (date2.getDay() + 7 - i2) % 7); + date2.setHours(0, 0, 0, 0); + }, (date2, step) => { + date2.setDate(date2.getDate() + step * 7); + }, (start2, end2) => { + return (end2 - start2 - (end2.getTimezoneOffset() - start2.getTimezoneOffset()) * durationMinute) / durationWeek; + }); + } + const timeSunday = timeWeekday(0); + const timeMonday = timeWeekday(1); + const timeTuesday = timeWeekday(2); + const timeWednesday = timeWeekday(3); + const timeThursday = timeWeekday(4); + const timeFriday = timeWeekday(5); + const timeSaturday = timeWeekday(6); + timeSunday.range; + timeMonday.range; + timeTuesday.range; + timeWednesday.range; + timeThursday.range; + timeFriday.range; + timeSaturday.range; + function utcWeekday(i2) { + return timeInterval((date2) => { + date2.setUTCDate(date2.getUTCDate() - (date2.getUTCDay() + 7 - i2) % 7); + date2.setUTCHours(0, 0, 0, 0); + }, (date2, step) => { + date2.setUTCDate(date2.getUTCDate() + step * 7); + }, (start2, end2) => { + return (end2 - start2) / durationWeek; + }); + } + const utcSunday = utcWeekday(0); + const utcMonday = utcWeekday(1); + const utcTuesday = utcWeekday(2); + const utcWednesday = utcWeekday(3); + const utcThursday = utcWeekday(4); + const utcFriday = utcWeekday(5); + const utcSaturday = utcWeekday(6); + utcSunday.range; + utcMonday.range; + utcTuesday.range; + utcWednesday.range; + utcThursday.range; + utcFriday.range; + utcSaturday.range; + const timeMonth = timeInterval((date2) => { + date2.setDate(1); + date2.setHours(0, 0, 0, 0); + }, (date2, step) => { + date2.setMonth(date2.getMonth() + step); + }, (start2, end2) => { + return end2.getMonth() - start2.getMonth() + (end2.getFullYear() - start2.getFullYear()) * 12; + }, (date2) => { + return date2.getMonth(); + }); + timeMonth.range; + const utcMonth = timeInterval((date2) => { + date2.setUTCDate(1); + date2.setUTCHours(0, 0, 0, 0); + }, (date2, step) => { + date2.setUTCMonth(date2.getUTCMonth() + step); + }, (start2, end2) => { + return end2.getUTCMonth() - start2.getUTCMonth() + (end2.getUTCFullYear() - start2.getUTCFullYear()) * 12; + }, (date2) => { + return date2.getUTCMonth(); + }); + utcMonth.range; + const timeYear = timeInterval((date2) => { + date2.setMonth(0, 1); + date2.setHours(0, 0, 0, 0); + }, (date2, step) => { + date2.setFullYear(date2.getFullYear() + step); + }, (start2, end2) => { + return end2.getFullYear() - start2.getFullYear(); + }, (date2) => { + return date2.getFullYear(); + }); + timeYear.every = (k) => { + return !isFinite(k = Math.floor(k)) || !(k > 0) ? null : timeInterval((date2) => { + date2.setFullYear(Math.floor(date2.getFullYear() / k) * k); + date2.setMonth(0, 1); + date2.setHours(0, 0, 0, 0); + }, (date2, step) => { + date2.setFullYear(date2.getFullYear() + step * k); + }); + }; + timeYear.range; + const utcYear = timeInterval((date2) => { + date2.setUTCMonth(0, 1); + date2.setUTCHours(0, 0, 0, 0); + }, (date2, step) => { + date2.setUTCFullYear(date2.getUTCFullYear() + step); + }, (start2, end2) => { + return end2.getUTCFullYear() - start2.getUTCFullYear(); + }, (date2) => { + return date2.getUTCFullYear(); + }); + utcYear.every = (k) => { + return !isFinite(k = Math.floor(k)) || !(k > 0) ? null : timeInterval((date2) => { + date2.setUTCFullYear(Math.floor(date2.getUTCFullYear() / k) * k); + date2.setUTCMonth(0, 1); + date2.setUTCHours(0, 0, 0, 0); + }, (date2, step) => { + date2.setUTCFullYear(date2.getUTCFullYear() + step * k); + }); + }; + utcYear.range; + function ticker(year, month, week, day, hour, minute) { + const tickIntervals = [ + [second, 1, durationSecond], + [second, 5, 5 * durationSecond], + [second, 15, 15 * durationSecond], + [second, 30, 30 * durationSecond], + [minute, 1, durationMinute], + [minute, 5, 5 * durationMinute], + [minute, 15, 15 * durationMinute], + [minute, 30, 30 * durationMinute], + [hour, 1, durationHour], + [hour, 3, 3 * durationHour], + [hour, 6, 6 * durationHour], + [hour, 12, 12 * durationHour], + [day, 1, durationDay], + [day, 2, 2 * durationDay], + [week, 1, durationWeek], + [month, 1, durationMonth], + [month, 3, 3 * durationMonth], + [year, 1, durationYear] + ]; + function ticks2(start2, stop, count) { + const reverse = stop < start2; + if (reverse) + [start2, stop] = [stop, start2]; + const interval2 = count && typeof count.range === "function" ? count : tickInterval2(start2, stop, count); + const ticks3 = interval2 ? interval2.range(start2, +stop + 1) : []; + return reverse ? ticks3.reverse() : ticks3; + } + function tickInterval2(start2, stop, count) { + const target = Math.abs(stop - start2) / count; + const i2 = bisector(([, , step2]) => step2).right(tickIntervals, target); + if (i2 === tickIntervals.length) + return year.every(tickStep(start2 / durationYear, stop / durationYear, count)); + if (i2 === 0) + return millisecond.every(Math.max(tickStep(start2, stop, count), 1)); + const [t, step] = tickIntervals[target / tickIntervals[i2 - 1][2] < tickIntervals[i2][2] / target ? i2 - 1 : i2]; + return t.every(step); + } + return [ticks2, tickInterval2]; + } + const [timeTicks, timeTickInterval] = ticker(timeYear, timeMonth, timeSunday, timeDay, timeHour, timeMinute); + function localDate(d) { + if (0 <= d.y && d.y < 100) { + var date2 = new Date(-1, d.m, d.d, d.H, d.M, d.S, d.L); + date2.setFullYear(d.y); + return date2; + } + return new Date(d.y, d.m, d.d, d.H, d.M, d.S, d.L); + } + function utcDate(d) { + if (0 <= d.y && d.y < 100) { + var date2 = new Date(Date.UTC(-1, d.m, d.d, d.H, d.M, d.S, d.L)); + date2.setUTCFullYear(d.y); + return date2; + } + return new Date(Date.UTC(d.y, d.m, d.d, d.H, d.M, d.S, d.L)); + } + function newDate(y2, m, d) { + return { y: y2, m, d, H: 0, M: 0, S: 0, L: 0 }; + } + function formatLocale(locale2) { + var locale_dateTime = locale2.dateTime, locale_date = locale2.date, locale_time = locale2.time, locale_periods = locale2.periods, locale_weekdays = locale2.days, locale_shortWeekdays = locale2.shortDays, locale_months = locale2.months, locale_shortMonths = locale2.shortMonths; + var periodRe = formatRe(locale_periods), periodLookup = formatLookup(locale_periods), weekdayRe = formatRe(locale_weekdays), weekdayLookup = formatLookup(locale_weekdays), shortWeekdayRe = formatRe(locale_shortWeekdays), shortWeekdayLookup = formatLookup(locale_shortWeekdays), monthRe = formatRe(locale_months), monthLookup = formatLookup(locale_months), shortMonthRe = formatRe(locale_shortMonths), shortMonthLookup = formatLookup(locale_shortMonths); + var formats = { + "a": formatShortWeekday, + "A": formatWeekday, + "b": formatShortMonth, + "B": formatMonth, + "c": null, + "d": formatDayOfMonth, + "e": formatDayOfMonth, + "f": formatMicroseconds, + "g": formatYearISO, + "G": formatFullYearISO, + "H": formatHour24, + "I": formatHour12, + "j": formatDayOfYear, + "L": formatMilliseconds, + "m": formatMonthNumber, + "M": formatMinutes, + "p": formatPeriod, + "q": formatQuarter, + "Q": formatUnixTimestamp, + "s": formatUnixTimestampSeconds, + "S": formatSeconds, + "u": formatWeekdayNumberMonday, + "U": formatWeekNumberSunday, + "V": formatWeekNumberISO, + "w": formatWeekdayNumberSunday, + "W": formatWeekNumberMonday, + "x": null, + "X": null, + "y": formatYear, + "Y": formatFullYear, + "Z": formatZone, + "%": formatLiteralPercent + }; + var utcFormats = { + "a": formatUTCShortWeekday, + "A": formatUTCWeekday, + "b": formatUTCShortMonth, + "B": formatUTCMonth, + "c": null, + "d": formatUTCDayOfMonth, + "e": formatUTCDayOfMonth, + "f": formatUTCMicroseconds, + "g": formatUTCYearISO, + "G": formatUTCFullYearISO, + "H": formatUTCHour24, + "I": formatUTCHour12, + "j": formatUTCDayOfYear, + "L": formatUTCMilliseconds, + "m": formatUTCMonthNumber, + "M": formatUTCMinutes, + "p": formatUTCPeriod, + "q": formatUTCQuarter, + "Q": formatUnixTimestamp, + "s": formatUnixTimestampSeconds, + "S": formatUTCSeconds, + "u": formatUTCWeekdayNumberMonday, + "U": formatUTCWeekNumberSunday, + "V": formatUTCWeekNumberISO, + "w": formatUTCWeekdayNumberSunday, + "W": formatUTCWeekNumberMonday, + "x": null, + "X": null, + "y": formatUTCYear, + "Y": formatUTCFullYear, + "Z": formatUTCZone, + "%": formatLiteralPercent + }; + var parses = { + "a": parseShortWeekday, + "A": parseWeekday, + "b": parseShortMonth, + "B": parseMonth, + "c": parseLocaleDateTime, + "d": parseDayOfMonth, + "e": parseDayOfMonth, + "f": parseMicroseconds, + "g": parseYear, + "G": parseFullYear, + "H": parseHour24, + "I": parseHour24, + "j": parseDayOfYear, + "L": parseMilliseconds, + "m": parseMonthNumber, + "M": parseMinutes, + "p": parsePeriod, + "q": parseQuarter, + "Q": parseUnixTimestamp, + "s": parseUnixTimestampSeconds, + "S": parseSeconds, + "u": parseWeekdayNumberMonday, + "U": parseWeekNumberSunday, + "V": parseWeekNumberISO, + "w": parseWeekdayNumberSunday, + "W": parseWeekNumberMonday, + "x": parseLocaleDate, + "X": parseLocaleTime, + "y": parseYear, + "Y": parseFullYear, + "Z": parseZone, + "%": parseLiteralPercent + }; + formats.x = newFormat(locale_date, formats); + formats.X = newFormat(locale_time, formats); + formats.c = newFormat(locale_dateTime, formats); + utcFormats.x = newFormat(locale_date, utcFormats); + utcFormats.X = newFormat(locale_time, utcFormats); + utcFormats.c = newFormat(locale_dateTime, utcFormats); + function newFormat(specifier, formats2) { + return function(date2) { + var string2 = [], i2 = -1, j = 0, n = specifier.length, c2, pad2, format2; + if (!(date2 instanceof Date)) + date2 = /* @__PURE__ */ new Date(+date2); + while (++i2 < n) { + if (specifier.charCodeAt(i2) === 37) { + string2.push(specifier.slice(j, i2)); + if ((pad2 = pads[c2 = specifier.charAt(++i2)]) != null) + c2 = specifier.charAt(++i2); + else + pad2 = c2 === "e" ? " " : "0"; + if (format2 = formats2[c2]) + c2 = format2(date2, pad2); + string2.push(c2); + j = i2 + 1; + } + } + string2.push(specifier.slice(j, i2)); + return string2.join(""); + }; + } + function newParse(specifier, Z) { + return function(string2) { + var d = newDate(1900, void 0, 1), i2 = parseSpecifier(d, specifier, string2 += "", 0), week, day; + if (i2 != string2.length) + return null; + if ("Q" in d) + return new Date(d.Q); + if ("s" in d) + return new Date(d.s * 1e3 + ("L" in d ? d.L : 0)); + if (Z && !("Z" in d)) + d.Z = 0; + if ("p" in d) + d.H = d.H % 12 + d.p * 12; + if (d.m === void 0) + d.m = "q" in d ? d.q : 0; + if ("V" in d) { + if (d.V < 1 || d.V > 53) + return null; + if (!("w" in d)) + d.w = 1; + if ("Z" in d) { + week = utcDate(newDate(d.y, 0, 1)), day = week.getUTCDay(); + week = day > 4 || day === 0 ? utcMonday.ceil(week) : utcMonday(week); + week = utcDay.offset(week, (d.V - 1) * 7); + d.y = week.getUTCFullYear(); + d.m = week.getUTCMonth(); + d.d = week.getUTCDate() + (d.w + 6) % 7; + } else { + week = localDate(newDate(d.y, 0, 1)), day = week.getDay(); + week = day > 4 || day === 0 ? timeMonday.ceil(week) : timeMonday(week); + week = timeDay.offset(week, (d.V - 1) * 7); + d.y = week.getFullYear(); + d.m = week.getMonth(); + d.d = week.getDate() + (d.w + 6) % 7; + } + } else if ("W" in d || "U" in d) { + if (!("w" in d)) + d.w = "u" in d ? d.u % 7 : "W" in d ? 1 : 0; + day = "Z" in d ? utcDate(newDate(d.y, 0, 1)).getUTCDay() : localDate(newDate(d.y, 0, 1)).getDay(); + d.m = 0; + d.d = "W" in d ? (d.w + 6) % 7 + d.W * 7 - (day + 5) % 7 : d.w + d.U * 7 - (day + 6) % 7; + } + if ("Z" in d) { + d.H += d.Z / 100 | 0; + d.M += d.Z % 100; + return utcDate(d); + } + return localDate(d); + }; + } + function parseSpecifier(d, specifier, string2, j) { + var i2 = 0, n = specifier.length, m = string2.length, c2, parse2; + while (i2 < n) { + if (j >= m) + return -1; + c2 = specifier.charCodeAt(i2++); + if (c2 === 37) { + c2 = specifier.charAt(i2++); + parse2 = parses[c2 in pads ? specifier.charAt(i2++) : c2]; + if (!parse2 || (j = parse2(d, string2, j)) < 0) + return -1; + } else if (c2 != string2.charCodeAt(j++)) { + return -1; + } + } + return j; + } + function parsePeriod(d, string2, i2) { + var n = periodRe.exec(string2.slice(i2)); + return n ? (d.p = periodLookup.get(n[0].toLowerCase()), i2 + n[0].length) : -1; + } + function parseShortWeekday(d, string2, i2) { + var n = shortWeekdayRe.exec(string2.slice(i2)); + return n ? (d.w = shortWeekdayLookup.get(n[0].toLowerCase()), i2 + n[0].length) : -1; + } + function parseWeekday(d, string2, i2) { + var n = weekdayRe.exec(string2.slice(i2)); + return n ? (d.w = weekdayLookup.get(n[0].toLowerCase()), i2 + n[0].length) : -1; + } + function parseShortMonth(d, string2, i2) { + var n = shortMonthRe.exec(string2.slice(i2)); + return n ? (d.m = shortMonthLookup.get(n[0].toLowerCase()), i2 + n[0].length) : -1; + } + function parseMonth(d, string2, i2) { + var n = monthRe.exec(string2.slice(i2)); + return n ? (d.m = monthLookup.get(n[0].toLowerCase()), i2 + n[0].length) : -1; + } + function parseLocaleDateTime(d, string2, i2) { + return parseSpecifier(d, locale_dateTime, string2, i2); + } + function parseLocaleDate(d, string2, i2) { + return parseSpecifier(d, locale_date, string2, i2); + } + function parseLocaleTime(d, string2, i2) { + return parseSpecifier(d, locale_time, string2, i2); + } + function formatShortWeekday(d) { + return locale_shortWeekdays[d.getDay()]; + } + function formatWeekday(d) { + return locale_weekdays[d.getDay()]; + } + function formatShortMonth(d) { + return locale_shortMonths[d.getMonth()]; + } + function formatMonth(d) { + return locale_months[d.getMonth()]; + } + function formatPeriod(d) { + return locale_periods[+(d.getHours() >= 12)]; + } + function formatQuarter(d) { + return 1 + ~~(d.getMonth() / 3); + } + function formatUTCShortWeekday(d) { + return locale_shortWeekdays[d.getUTCDay()]; + } + function formatUTCWeekday(d) { + return locale_weekdays[d.getUTCDay()]; + } + function formatUTCShortMonth(d) { + return locale_shortMonths[d.getUTCMonth()]; + } + function formatUTCMonth(d) { + return locale_months[d.getUTCMonth()]; + } + function formatUTCPeriod(d) { + return locale_periods[+(d.getUTCHours() >= 12)]; + } + function formatUTCQuarter(d) { + return 1 + ~~(d.getUTCMonth() / 3); + } + return { + format: function(specifier) { + var f2 = newFormat(specifier += "", formats); + f2.toString = function() { + return specifier; + }; + return f2; + }, + parse: function(specifier) { + var p = newParse(specifier += "", false); + p.toString = function() { + return specifier; + }; + return p; + }, + utcFormat: function(specifier) { + var f2 = newFormat(specifier += "", utcFormats); + f2.toString = function() { + return specifier; + }; + return f2; + }, + utcParse: function(specifier) { + var p = newParse(specifier += "", true); + p.toString = function() { + return specifier; + }; + return p; + } + }; + } + var pads = { "-": "", "_": " ", "0": "0" }, numberRe = /^\s*\d+/, percentRe = /^%/, requoteRe = /[\\^$*+?|[\]().{}]/g; + function pad$1(value2, fill, width2) { + var sign2 = value2 < 0 ? "-" : "", string2 = (sign2 ? -value2 : value2) + "", length2 = string2.length; + return sign2 + (length2 < width2 ? new Array(width2 - length2 + 1).join(fill) + string2 : string2); + } + function requote(s) { + return s.replace(requoteRe, "\\$&"); + } + function formatRe(names) { + return new RegExp("^(?:" + names.map(requote).join("|") + ")", "i"); + } + function formatLookup(names) { + return new Map(names.map((name, i2) => [name.toLowerCase(), i2])); + } + function parseWeekdayNumberSunday(d, string2, i2) { + var n = numberRe.exec(string2.slice(i2, i2 + 1)); + return n ? (d.w = +n[0], i2 + n[0].length) : -1; + } + function parseWeekdayNumberMonday(d, string2, i2) { + var n = numberRe.exec(string2.slice(i2, i2 + 1)); + return n ? (d.u = +n[0], i2 + n[0].length) : -1; + } + function parseWeekNumberSunday(d, string2, i2) { + var n = numberRe.exec(string2.slice(i2, i2 + 2)); + return n ? (d.U = +n[0], i2 + n[0].length) : -1; + } + function parseWeekNumberISO(d, string2, i2) { + var n = numberRe.exec(string2.slice(i2, i2 + 2)); + return n ? (d.V = +n[0], i2 + n[0].length) : -1; + } + function parseWeekNumberMonday(d, string2, i2) { + var n = numberRe.exec(string2.slice(i2, i2 + 2)); + return n ? (d.W = +n[0], i2 + n[0].length) : -1; + } + function parseFullYear(d, string2, i2) { + var n = numberRe.exec(string2.slice(i2, i2 + 4)); + return n ? (d.y = +n[0], i2 + n[0].length) : -1; + } + function parseYear(d, string2, i2) { + var n = numberRe.exec(string2.slice(i2, i2 + 2)); + return n ? (d.y = +n[0] + (+n[0] > 68 ? 1900 : 2e3), i2 + n[0].length) : -1; + } + function parseZone(d, string2, i2) { + var n = /^(Z)|([+-]\d\d)(?::?(\d\d))?/.exec(string2.slice(i2, i2 + 6)); + return n ? (d.Z = n[1] ? 0 : -(n[2] + (n[3] || "00")), i2 + n[0].length) : -1; + } + function parseQuarter(d, string2, i2) { + var n = numberRe.exec(string2.slice(i2, i2 + 1)); + return n ? (d.q = n[0] * 3 - 3, i2 + n[0].length) : -1; + } + function parseMonthNumber(d, string2, i2) { + var n = numberRe.exec(string2.slice(i2, i2 + 2)); + return n ? (d.m = n[0] - 1, i2 + n[0].length) : -1; + } + function parseDayOfMonth(d, string2, i2) { + var n = numberRe.exec(string2.slice(i2, i2 + 2)); + return n ? (d.d = +n[0], i2 + n[0].length) : -1; + } + function parseDayOfYear(d, string2, i2) { + var n = numberRe.exec(string2.slice(i2, i2 + 3)); + return n ? (d.m = 0, d.d = +n[0], i2 + n[0].length) : -1; + } + function parseHour24(d, string2, i2) { + var n = numberRe.exec(string2.slice(i2, i2 + 2)); + return n ? (d.H = +n[0], i2 + n[0].length) : -1; + } + function parseMinutes(d, string2, i2) { + var n = numberRe.exec(string2.slice(i2, i2 + 2)); + return n ? (d.M = +n[0], i2 + n[0].length) : -1; + } + function parseSeconds(d, string2, i2) { + var n = numberRe.exec(string2.slice(i2, i2 + 2)); + return n ? (d.S = +n[0], i2 + n[0].length) : -1; + } + function parseMilliseconds(d, string2, i2) { + var n = numberRe.exec(string2.slice(i2, i2 + 3)); + return n ? (d.L = +n[0], i2 + n[0].length) : -1; + } + function parseMicroseconds(d, string2, i2) { + var n = numberRe.exec(string2.slice(i2, i2 + 6)); + return n ? (d.L = Math.floor(n[0] / 1e3), i2 + n[0].length) : -1; + } + function parseLiteralPercent(d, string2, i2) { + var n = percentRe.exec(string2.slice(i2, i2 + 1)); + return n ? i2 + n[0].length : -1; + } + function parseUnixTimestamp(d, string2, i2) { + var n = numberRe.exec(string2.slice(i2)); + return n ? (d.Q = +n[0], i2 + n[0].length) : -1; + } + function parseUnixTimestampSeconds(d, string2, i2) { + var n = numberRe.exec(string2.slice(i2)); + return n ? (d.s = +n[0], i2 + n[0].length) : -1; + } + function formatDayOfMonth(d, p) { + return pad$1(d.getDate(), p, 2); + } + function formatHour24(d, p) { + return pad$1(d.getHours(), p, 2); + } + function formatHour12(d, p) { + return pad$1(d.getHours() % 12 || 12, p, 2); + } + function formatDayOfYear(d, p) { + return pad$1(1 + timeDay.count(timeYear(d), d), p, 3); + } + function formatMilliseconds(d, p) { + return pad$1(d.getMilliseconds(), p, 3); + } + function formatMicroseconds(d, p) { + return formatMilliseconds(d, p) + "000"; + } + function formatMonthNumber(d, p) { + return pad$1(d.getMonth() + 1, p, 2); + } + function formatMinutes(d, p) { + return pad$1(d.getMinutes(), p, 2); + } + function formatSeconds(d, p) { + return pad$1(d.getSeconds(), p, 2); + } + function formatWeekdayNumberMonday(d) { + var day = d.getDay(); + return day === 0 ? 7 : day; + } + function formatWeekNumberSunday(d, p) { + return pad$1(timeSunday.count(timeYear(d) - 1, d), p, 2); + } + function dISO(d) { + var day = d.getDay(); + return day >= 4 || day === 0 ? timeThursday(d) : timeThursday.ceil(d); + } + function formatWeekNumberISO(d, p) { + d = dISO(d); + return pad$1(timeThursday.count(timeYear(d), d) + (timeYear(d).getDay() === 4), p, 2); + } + function formatWeekdayNumberSunday(d) { + return d.getDay(); + } + function formatWeekNumberMonday(d, p) { + return pad$1(timeMonday.count(timeYear(d) - 1, d), p, 2); + } + function formatYear(d, p) { + return pad$1(d.getFullYear() % 100, p, 2); + } + function formatYearISO(d, p) { + d = dISO(d); + return pad$1(d.getFullYear() % 100, p, 2); + } + function formatFullYear(d, p) { + return pad$1(d.getFullYear() % 1e4, p, 4); + } + function formatFullYearISO(d, p) { + var day = d.getDay(); + d = day >= 4 || day === 0 ? timeThursday(d) : timeThursday.ceil(d); + return pad$1(d.getFullYear() % 1e4, p, 4); + } + function formatZone(d) { + var z = d.getTimezoneOffset(); + return (z > 0 ? "-" : (z *= -1, "+")) + pad$1(z / 60 | 0, "0", 2) + pad$1(z % 60, "0", 2); + } + function formatUTCDayOfMonth(d, p) { + return pad$1(d.getUTCDate(), p, 2); + } + function formatUTCHour24(d, p) { + return pad$1(d.getUTCHours(), p, 2); + } + function formatUTCHour12(d, p) { + return pad$1(d.getUTCHours() % 12 || 12, p, 2); + } + function formatUTCDayOfYear(d, p) { + return pad$1(1 + utcDay.count(utcYear(d), d), p, 3); + } + function formatUTCMilliseconds(d, p) { + return pad$1(d.getUTCMilliseconds(), p, 3); + } + function formatUTCMicroseconds(d, p) { + return formatUTCMilliseconds(d, p) + "000"; + } + function formatUTCMonthNumber(d, p) { + return pad$1(d.getUTCMonth() + 1, p, 2); + } + function formatUTCMinutes(d, p) { + return pad$1(d.getUTCMinutes(), p, 2); + } + function formatUTCSeconds(d, p) { + return pad$1(d.getUTCSeconds(), p, 2); + } + function formatUTCWeekdayNumberMonday(d) { + var dow = d.getUTCDay(); + return dow === 0 ? 7 : dow; + } + function formatUTCWeekNumberSunday(d, p) { + return pad$1(utcSunday.count(utcYear(d) - 1, d), p, 2); + } + function UTCdISO(d) { + var day = d.getUTCDay(); + return day >= 4 || day === 0 ? utcThursday(d) : utcThursday.ceil(d); + } + function formatUTCWeekNumberISO(d, p) { + d = UTCdISO(d); + return pad$1(utcThursday.count(utcYear(d), d) + (utcYear(d).getUTCDay() === 4), p, 2); + } + function formatUTCWeekdayNumberSunday(d) { + return d.getUTCDay(); + } + function formatUTCWeekNumberMonday(d, p) { + return pad$1(utcMonday.count(utcYear(d) - 1, d), p, 2); + } + function formatUTCYear(d, p) { + return pad$1(d.getUTCFullYear() % 100, p, 2); + } + function formatUTCYearISO(d, p) { + d = UTCdISO(d); + return pad$1(d.getUTCFullYear() % 100, p, 2); + } + function formatUTCFullYear(d, p) { + return pad$1(d.getUTCFullYear() % 1e4, p, 4); + } + function formatUTCFullYearISO(d, p) { + var day = d.getUTCDay(); + d = day >= 4 || day === 0 ? utcThursday(d) : utcThursday.ceil(d); + return pad$1(d.getUTCFullYear() % 1e4, p, 4); + } + function formatUTCZone() { + return "+0000"; + } + function formatLiteralPercent() { + return "%"; + } + function formatUnixTimestamp(d) { + return +d; + } + function formatUnixTimestampSeconds(d) { + return Math.floor(+d / 1e3); + } + var locale; + var timeFormat; + defaultLocale({ + dateTime: "%x, %X", + date: "%-m/%-d/%Y", + time: "%-I:%M:%S %p", + periods: ["AM", "PM"], + days: ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"], + shortDays: ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"], + months: ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"], + shortMonths: ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"] + }); + function defaultLocale(definition2) { + locale = formatLocale(definition2); + timeFormat = locale.format; + locale.parse; + locale.utcFormat; + locale.utcParse; + return locale; + } + function date(t) { + return new Date(t); + } + function number(t) { + return t instanceof Date ? +t : +/* @__PURE__ */ new Date(+t); + } + function calendar(ticks2, tickInterval2, year, month, week, day, hour, minute, second2, format2) { + var scale = continuous(), invert2 = scale.invert, domain = scale.domain; + var formatMillisecond = format2(".%L"), formatSecond = format2(":%S"), formatMinute = format2("%I:%M"), formatHour = format2("%I %p"), formatDay = format2("%a %d"), formatWeek = format2("%b %d"), formatMonth = format2("%B"), formatYear2 = format2("%Y"); + function tickFormat2(date2) { + return (second2(date2) < date2 ? formatMillisecond : minute(date2) < date2 ? formatSecond : hour(date2) < date2 ? formatMinute : day(date2) < date2 ? formatHour : month(date2) < date2 ? week(date2) < date2 ? formatDay : formatWeek : year(date2) < date2 ? formatMonth : formatYear2)(date2); + } + scale.invert = function(y2) { + return new Date(invert2(y2)); + }; + scale.domain = function(_2) { + return arguments.length ? domain(Array.from(_2, number)) : domain().map(date); + }; + scale.ticks = function(interval2) { + var d = domain(); + return ticks2(d[0], d[d.length - 1], interval2 == null ? 10 : interval2); + }; + scale.tickFormat = function(count, specifier) { + return specifier == null ? tickFormat2 : format2(specifier); + }; + scale.nice = function(interval2) { + var d = domain(); + if (!interval2 || typeof interval2.range !== "function") + interval2 = tickInterval2(d[0], d[d.length - 1], interval2 == null ? 10 : interval2); + return interval2 ? domain(nice(d, interval2)) : scale; + }; + scale.copy = function() { + return copy$1(scale, calendar(ticks2, tickInterval2, year, month, week, day, hour, minute, second2, format2)); + }; + return scale; + } + function time$1() { + return initRange.apply(calendar(timeTicks, timeTickInterval, timeYear, timeMonth, timeSunday, timeDay, timeHour, timeMinute, second, timeFormat).domain([new Date(2e3, 0, 1), new Date(2e3, 0, 2)]), arguments); + } + function colors(specifier) { + var n = specifier.length / 6 | 0, colors2 = new Array(n), i2 = 0; + while (i2 < n) + colors2[i2] = "#" + specifier.slice(i2 * 6, ++i2 * 6); + return colors2; + } + const d3schemeTableau10 = colors("4e79a7f28e2ce1575976b7b259a14fedc949af7aa1ff9da79c755fbab0ab"); + function constant$3(x2) { + return function constant2() { + return x2; + }; + } + const abs$1 = Math.abs; + const atan2 = Math.atan2; + const cos = Math.cos; + const max$2 = Math.max; + const min$2 = Math.min; + const sin = Math.sin; + const sqrt = Math.sqrt; + const epsilon$1 = 1e-12; + const pi$1 = Math.PI; + const halfPi = pi$1 / 2; + const tau$1 = 2 * pi$1; + function acos(x2) { + return x2 > 1 ? 0 : x2 < -1 ? pi$1 : Math.acos(x2); + } + function asin(x2) { + return x2 >= 1 ? halfPi : x2 <= -1 ? -halfPi : Math.asin(x2); + } + function withPath(shape) { + let digits = 3; + shape.digits = function(_2) { + if (!arguments.length) + return digits; + if (_2 == null) { + digits = null; + } else { + const d = Math.floor(_2); + if (!(d >= 0)) + throw new RangeError(`invalid digits: ${_2}`); + digits = d; + } + return shape; + }; + return () => new Path$1(digits); + } + function arcInnerRadius(d) { + return d.innerRadius; + } + function arcOuterRadius(d) { + return d.outerRadius; + } + function arcStartAngle(d) { + return d.startAngle; + } + function arcEndAngle(d) { + return d.endAngle; + } + function arcPadAngle(d) { + return d && d.padAngle; + } + function intersect$1(x0, y0, x1, y1, x2, y2, x3, y3) { + var x10 = x1 - x0, y10 = y1 - y0, x32 = x3 - x2, y32 = y3 - y2, t = y32 * x10 - x32 * y10; + if (t * t < epsilon$1) + return; + t = (x32 * (y0 - y2) - y32 * (x0 - x2)) / t; + return [x0 + t * x10, y0 + t * y10]; + } + function cornerTangents(x0, y0, x1, y1, r1, rc, cw) { + var x01 = x0 - x1, y01 = y0 - y1, lo = (cw ? rc : -rc) / sqrt(x01 * x01 + y01 * y01), ox = lo * y01, oy = -lo * x01, x11 = x0 + ox, y11 = y0 + oy, x10 = x1 + ox, y10 = y1 + oy, x00 = (x11 + x10) / 2, y00 = (y11 + y10) / 2, dx = x10 - x11, dy = y10 - y11, d2 = dx * dx + dy * dy, r = r1 - rc, D2 = x11 * y10 - x10 * y11, d = (dy < 0 ? -1 : 1) * sqrt(max$2(0, r * r * d2 - D2 * D2)), cx0 = (D2 * dy - dx * d) / d2, cy0 = (-D2 * dx - dy * d) / d2, cx1 = (D2 * dy + dx * d) / d2, cy1 = (-D2 * dx + dy * d) / d2, dx0 = cx0 - x00, dy0 = cy0 - y00, dx1 = cx1 - x00, dy1 = cy1 - y00; + if (dx0 * dx0 + dy0 * dy0 > dx1 * dx1 + dy1 * dy1) + cx0 = cx1, cy0 = cy1; + return { + cx: cx0, + cy: cy0, + x01: -ox, + y01: -oy, + x11: cx0 * (r1 / r - 1), + y11: cy0 * (r1 / r - 1) + }; + } + function d3arc() { + var innerRadius = arcInnerRadius, outerRadius = arcOuterRadius, cornerRadius = constant$3(0), padRadius = null, startAngle = arcStartAngle, endAngle = arcEndAngle, padAngle = arcPadAngle, context = null, path2 = withPath(arc); + function arc() { + var buffer, r, r0 = +innerRadius.apply(this, arguments), r1 = +outerRadius.apply(this, arguments), a0 = startAngle.apply(this, arguments) - halfPi, a1 = endAngle.apply(this, arguments) - halfPi, da = abs$1(a1 - a0), cw = a1 > a0; + if (!context) + context = buffer = path2(); + if (r1 < r0) + r = r1, r1 = r0, r0 = r; + if (!(r1 > epsilon$1)) + context.moveTo(0, 0); + else if (da > tau$1 - epsilon$1) { + context.moveTo(r1 * cos(a0), r1 * sin(a0)); + context.arc(0, 0, r1, a0, a1, !cw); + if (r0 > epsilon$1) { + context.moveTo(r0 * cos(a1), r0 * sin(a1)); + context.arc(0, 0, r0, a1, a0, cw); + } + } else { + var a01 = a0, a11 = a1, a00 = a0, a10 = a1, da0 = da, da1 = da, ap = padAngle.apply(this, arguments) / 2, rp = ap > epsilon$1 && (padRadius ? +padRadius.apply(this, arguments) : sqrt(r0 * r0 + r1 * r1)), rc = min$2(abs$1(r1 - r0) / 2, +cornerRadius.apply(this, arguments)), rc0 = rc, rc1 = rc, t02, t12; + if (rp > epsilon$1) { + var p0 = asin(rp / r0 * sin(ap)), p1 = asin(rp / r1 * sin(ap)); + if ((da0 -= p0 * 2) > epsilon$1) + p0 *= cw ? 1 : -1, a00 += p0, a10 -= p0; + else + da0 = 0, a00 = a10 = (a0 + a1) / 2; + if ((da1 -= p1 * 2) > epsilon$1) + p1 *= cw ? 1 : -1, a01 += p1, a11 -= p1; + else + da1 = 0, a01 = a11 = (a0 + a1) / 2; + } + var x01 = r1 * cos(a01), y01 = r1 * sin(a01), x10 = r0 * cos(a10), y10 = r0 * sin(a10); + if (rc > epsilon$1) { + var x11 = r1 * cos(a11), y11 = r1 * sin(a11), x00 = r0 * cos(a00), y00 = r0 * sin(a00), oc; + if (da < pi$1) { + if (oc = intersect$1(x01, y01, x00, y00, x11, y11, x10, y10)) { + var ax = x01 - oc[0], ay = y01 - oc[1], bx = x11 - oc[0], by = y11 - oc[1], kc = 1 / sin(acos((ax * bx + ay * by) / (sqrt(ax * ax + ay * ay) * sqrt(bx * bx + by * by))) / 2), lc = sqrt(oc[0] * oc[0] + oc[1] * oc[1]); + rc0 = min$2(rc, (r0 - lc) / (kc - 1)); + rc1 = min$2(rc, (r1 - lc) / (kc + 1)); + } else { + rc0 = rc1 = 0; + } + } + } + if (!(da1 > epsilon$1)) + context.moveTo(x01, y01); + else if (rc1 > epsilon$1) { + t02 = cornerTangents(x00, y00, x01, y01, r1, rc1, cw); + t12 = cornerTangents(x11, y11, x10, y10, r1, rc1, cw); + context.moveTo(t02.cx + t02.x01, t02.cy + t02.y01); + if (rc1 < rc) + context.arc(t02.cx, t02.cy, rc1, atan2(t02.y01, t02.x01), atan2(t12.y01, t12.x01), !cw); + else { + context.arc(t02.cx, t02.cy, rc1, atan2(t02.y01, t02.x01), atan2(t02.y11, t02.x11), !cw); + context.arc(0, 0, r1, atan2(t02.cy + t02.y11, t02.cx + t02.x11), atan2(t12.cy + t12.y11, t12.cx + t12.x11), !cw); + context.arc(t12.cx, t12.cy, rc1, atan2(t12.y11, t12.x11), atan2(t12.y01, t12.x01), !cw); + } + } else + context.moveTo(x01, y01), context.arc(0, 0, r1, a01, a11, !cw); + if (!(r0 > epsilon$1) || !(da0 > epsilon$1)) + context.lineTo(x10, y10); + else if (rc0 > epsilon$1) { + t02 = cornerTangents(x10, y10, x11, y11, r0, -rc0, cw); + t12 = cornerTangents(x01, y01, x00, y00, r0, -rc0, cw); + context.lineTo(t02.cx + t02.x01, t02.cy + t02.y01); + if (rc0 < rc) + context.arc(t02.cx, t02.cy, rc0, atan2(t02.y01, t02.x01), atan2(t12.y01, t12.x01), !cw); + else { + context.arc(t02.cx, t02.cy, rc0, atan2(t02.y01, t02.x01), atan2(t02.y11, t02.x11), !cw); + context.arc(0, 0, r0, atan2(t02.cy + t02.y11, t02.cx + t02.x11), atan2(t12.cy + t12.y11, t12.cx + t12.x11), cw); + context.arc(t12.cx, t12.cy, rc0, atan2(t12.y11, t12.x11), atan2(t12.y01, t12.x01), !cw); + } + } else + context.arc(0, 0, r0, a10, a00, cw); + } + context.closePath(); + if (buffer) + return context = null, buffer + "" || null; + } + arc.centroid = function() { + var r = (+innerRadius.apply(this, arguments) + +outerRadius.apply(this, arguments)) / 2, a = (+startAngle.apply(this, arguments) + +endAngle.apply(this, arguments)) / 2 - pi$1 / 2; + return [cos(a) * r, sin(a) * r]; + }; + arc.innerRadius = function(_2) { + return arguments.length ? (innerRadius = typeof _2 === "function" ? _2 : constant$3(+_2), arc) : innerRadius; + }; + arc.outerRadius = function(_2) { + return arguments.length ? (outerRadius = typeof _2 === "function" ? _2 : constant$3(+_2), arc) : outerRadius; + }; + arc.cornerRadius = function(_2) { + return arguments.length ? (cornerRadius = typeof _2 === "function" ? _2 : constant$3(+_2), arc) : cornerRadius; + }; + arc.padRadius = function(_2) { + return arguments.length ? (padRadius = _2 == null ? null : typeof _2 === "function" ? _2 : constant$3(+_2), arc) : padRadius; + }; + arc.startAngle = function(_2) { + return arguments.length ? (startAngle = typeof _2 === "function" ? _2 : constant$3(+_2), arc) : startAngle; + }; + arc.endAngle = function(_2) { + return arguments.length ? (endAngle = typeof _2 === "function" ? _2 : constant$3(+_2), arc) : endAngle; + }; + arc.padAngle = function(_2) { + return arguments.length ? (padAngle = typeof _2 === "function" ? _2 : constant$3(+_2), arc) : padAngle; + }; + arc.context = function(_2) { + return arguments.length ? (context = _2 == null ? null : _2, arc) : context; + }; + return arc; + } + function array(x2) { + return typeof x2 === "object" && "length" in x2 ? x2 : Array.from(x2); + } + function Linear(context) { + this._context = context; + } + Linear.prototype = { + areaStart: function() { + this._line = 0; + }, + areaEnd: function() { + this._line = NaN; + }, + lineStart: function() { + this._point = 0; + }, + lineEnd: function() { + if (this._line || this._line !== 0 && this._point === 1) + this._context.closePath(); + this._line = 1 - this._line; + }, + point: function(x2, y2) { + x2 = +x2, y2 = +y2; + switch (this._point) { + case 0: + this._point = 1; + this._line ? this._context.lineTo(x2, y2) : this._context.moveTo(x2, y2); + break; + case 1: + this._point = 2; + default: + this._context.lineTo(x2, y2); + break; + } + } + }; + function curveLinear(context) { + return new Linear(context); + } + function x$1(p) { + return p[0]; + } + function y$1(p) { + return p[1]; + } + function line$1(x2, y2) { + var defined = constant$3(true), context = null, curve = curveLinear, output = null, path2 = withPath(line2); + x2 = typeof x2 === "function" ? x2 : x2 === void 0 ? x$1 : constant$3(x2); + y2 = typeof y2 === "function" ? y2 : y2 === void 0 ? y$1 : constant$3(y2); + function line2(data) { + var i2, n = (data = array(data)).length, d, defined0 = false, buffer; + if (context == null) + output = curve(buffer = path2()); + for (i2 = 0; i2 <= n; ++i2) { + if (!(i2 < n && defined(d = data[i2], i2, data)) === defined0) { + if (defined0 = !defined0) + output.lineStart(); + else + output.lineEnd(); + } + if (defined0) + output.point(+x2(d, i2, data), +y2(d, i2, data)); + } + if (buffer) + return output = null, buffer + "" || null; + } + line2.x = function(_2) { + return arguments.length ? (x2 = typeof _2 === "function" ? _2 : constant$3(+_2), line2) : x2; + }; + line2.y = function(_2) { + return arguments.length ? (y2 = typeof _2 === "function" ? _2 : constant$3(+_2), line2) : y2; + }; + line2.defined = function(_2) { + return arguments.length ? (defined = typeof _2 === "function" ? _2 : constant$3(!!_2), line2) : defined; + }; + line2.curve = function(_2) { + return arguments.length ? (curve = _2, context != null && (output = curve(context)), line2) : curve; + }; + line2.context = function(_2) { + return arguments.length ? (_2 == null ? context = output = null : output = curve(context = _2), line2) : context; + }; + return line2; + } + function descending(a, b) { + return b < a ? -1 : b > a ? 1 : b >= a ? 0 : NaN; + } + function identity$1(d) { + return d; + } + function d3pie() { + var value2 = identity$1, sortValues = descending, sort2 = null, startAngle = constant$3(0), endAngle = constant$3(tau$1), padAngle = constant$3(0); + function pie2(data) { + var i2, n = (data = array(data)).length, j, k, sum2 = 0, index2 = new Array(n), arcs = new Array(n), a0 = +startAngle.apply(this, arguments), da = Math.min(tau$1, Math.max(-tau$1, endAngle.apply(this, arguments) - a0)), a1, p = Math.min(Math.abs(da) / n, padAngle.apply(this, arguments)), pa = p * (da < 0 ? -1 : 1), v; + for (i2 = 0; i2 < n; ++i2) { + if ((v = arcs[index2[i2] = i2] = +value2(data[i2], i2, data)) > 0) { + sum2 += v; + } + } + if (sortValues != null) + index2.sort(function(i3, j2) { + return sortValues(arcs[i3], arcs[j2]); + }); + else if (sort2 != null) + index2.sort(function(i3, j2) { + return sort2(data[i3], data[j2]); + }); + for (i2 = 0, k = sum2 ? (da - n * pa) / sum2 : 0; i2 < n; ++i2, a0 = a1) { + j = index2[i2], v = arcs[j], a1 = a0 + (v > 0 ? v * k : 0) + pa, arcs[j] = { + data: data[j], + index: i2, + value: v, + startAngle: a0, + endAngle: a1, + padAngle: p + }; + } + return arcs; + } + pie2.value = function(_2) { + return arguments.length ? (value2 = typeof _2 === "function" ? _2 : constant$3(+_2), pie2) : value2; + }; + pie2.sortValues = function(_2) { + return arguments.length ? (sortValues = _2, sort2 = null, pie2) : sortValues; + }; + pie2.sort = function(_2) { + return arguments.length ? (sort2 = _2, sortValues = null, pie2) : sort2; + }; + pie2.startAngle = function(_2) { + return arguments.length ? (startAngle = typeof _2 === "function" ? _2 : constant$3(+_2), pie2) : startAngle; + }; + pie2.endAngle = function(_2) { + return arguments.length ? (endAngle = typeof _2 === "function" ? _2 : constant$3(+_2), pie2) : endAngle; + }; + pie2.padAngle = function(_2) { + return arguments.length ? (padAngle = typeof _2 === "function" ? _2 : constant$3(+_2), pie2) : padAngle; + }; + return pie2; + } + class Bump { + constructor(context, x2) { + this._context = context; + this._x = x2; + } + areaStart() { + this._line = 0; + } + areaEnd() { + this._line = NaN; + } + lineStart() { + this._point = 0; + } + lineEnd() { + if (this._line || this._line !== 0 && this._point === 1) + this._context.closePath(); + this._line = 1 - this._line; + } + point(x2, y2) { + x2 = +x2, y2 = +y2; + switch (this._point) { + case 0: { + this._point = 1; + if (this._line) + this._context.lineTo(x2, y2); + else + this._context.moveTo(x2, y2); + break; + } + case 1: + this._point = 2; + default: { + if (this._x) + this._context.bezierCurveTo(this._x0 = (this._x0 + x2) / 2, this._y0, this._x0, y2, x2, y2); + else + this._context.bezierCurveTo(this._x0, this._y0 = (this._y0 + y2) / 2, x2, this._y0, x2, y2); + break; + } + } + this._x0 = x2, this._y0 = y2; + } + } + function bumpX(context) { + return new Bump(context, true); + } + function bumpY(context) { + return new Bump(context, false); + } + function noop$1() { + } + function point$6(that, x2, y2) { + that._context.bezierCurveTo( + (2 * that._x0 + that._x1) / 3, + (2 * that._y0 + that._y1) / 3, + (that._x0 + 2 * that._x1) / 3, + (that._y0 + 2 * that._y1) / 3, + (that._x0 + 4 * that._x1 + x2) / 6, + (that._y0 + 4 * that._y1 + y2) / 6 + ); + } + function Basis(context) { + this._context = context; + } + Basis.prototype = { + areaStart: function() { + this._line = 0; + }, + areaEnd: function() { + this._line = NaN; + }, + lineStart: function() { + this._x0 = this._x1 = this._y0 = this._y1 = NaN; + this._point = 0; + }, + lineEnd: function() { + switch (this._point) { + case 3: + point$6(this, this._x1, this._y1); + case 2: + this._context.lineTo(this._x1, this._y1); + break; + } + if (this._line || this._line !== 0 && this._point === 1) + this._context.closePath(); + this._line = 1 - this._line; + }, + point: function(x2, y2) { + x2 = +x2, y2 = +y2; + switch (this._point) { + case 0: + this._point = 1; + this._line ? this._context.lineTo(x2, y2) : this._context.moveTo(x2, y2); + break; + case 1: + this._point = 2; + break; + case 2: + this._point = 3; + this._context.lineTo((5 * this._x0 + this._x1) / 6, (5 * this._y0 + this._y1) / 6); + default: + point$6(this, x2, y2); + break; + } + this._x0 = this._x1, this._x1 = x2; + this._y0 = this._y1, this._y1 = y2; + } + }; + function curveBasis(context) { + return new Basis(context); + } + function BasisClosed(context) { + this._context = context; + } + BasisClosed.prototype = { + areaStart: noop$1, + areaEnd: noop$1, + lineStart: function() { + this._x0 = this._x1 = this._x2 = this._x3 = this._x4 = this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = NaN; + this._point = 0; + }, + lineEnd: function() { + switch (this._point) { + case 1: { + this._context.moveTo(this._x2, this._y2); + this._context.closePath(); + break; + } + case 2: { + this._context.moveTo((this._x2 + 2 * this._x3) / 3, (this._y2 + 2 * this._y3) / 3); + this._context.lineTo((this._x3 + 2 * this._x2) / 3, (this._y3 + 2 * this._y2) / 3); + this._context.closePath(); + break; + } + case 3: { + this.point(this._x2, this._y2); + this.point(this._x3, this._y3); + this.point(this._x4, this._y4); + break; + } + } + }, + point: function(x2, y2) { + x2 = +x2, y2 = +y2; + switch (this._point) { + case 0: + this._point = 1; + this._x2 = x2, this._y2 = y2; + break; + case 1: + this._point = 2; + this._x3 = x2, this._y3 = y2; + break; + case 2: + this._point = 3; + this._x4 = x2, this._y4 = y2; + this._context.moveTo((this._x0 + 4 * this._x1 + x2) / 6, (this._y0 + 4 * this._y1 + y2) / 6); + break; + default: + point$6(this, x2, y2); + break; + } + this._x0 = this._x1, this._x1 = x2; + this._y0 = this._y1, this._y1 = y2; + } + }; + function curveBasisClosed(context) { + return new BasisClosed(context); + } + function BasisOpen(context) { + this._context = context; + } + BasisOpen.prototype = { + areaStart: function() { + this._line = 0; + }, + areaEnd: function() { + this._line = NaN; + }, + lineStart: function() { + this._x0 = this._x1 = this._y0 = this._y1 = NaN; + this._point = 0; + }, + lineEnd: function() { + if (this._line || this._line !== 0 && this._point === 3) + this._context.closePath(); + this._line = 1 - this._line; + }, + point: function(x2, y2) { + x2 = +x2, y2 = +y2; + switch (this._point) { + case 0: + this._point = 1; + break; + case 1: + this._point = 2; + break; + case 2: + this._point = 3; + var x0 = (this._x0 + 4 * this._x1 + x2) / 6, y0 = (this._y0 + 4 * this._y1 + y2) / 6; + this._line ? this._context.lineTo(x0, y0) : this._context.moveTo(x0, y0); + break; + case 3: + this._point = 4; + default: + point$6(this, x2, y2); + break; + } + this._x0 = this._x1, this._x1 = x2; + this._y0 = this._y1, this._y1 = y2; + } + }; + function curveBasisOpen(context) { + return new BasisOpen(context); + } + function Bundle(context, beta) { + this._basis = new Basis(context); + this._beta = beta; + } + Bundle.prototype = { + lineStart: function() { + this._x = []; + this._y = []; + this._basis.lineStart(); + }, + lineEnd: function() { + var x2 = this._x, y2 = this._y, j = x2.length - 1; + if (j > 0) { + var x0 = x2[0], y0 = y2[0], dx = x2[j] - x0, dy = y2[j] - y0, i2 = -1, t; + while (++i2 <= j) { + t = i2 / j; + this._basis.point( + this._beta * x2[i2] + (1 - this._beta) * (x0 + t * dx), + this._beta * y2[i2] + (1 - this._beta) * (y0 + t * dy) + ); + } + } + this._x = this._y = null; + this._basis.lineEnd(); + }, + point: function(x2, y2) { + this._x.push(+x2); + this._y.push(+y2); + } + }; + const curveBundle = function custom(beta) { + function bundle(context) { + return beta === 1 ? new Basis(context) : new Bundle(context, beta); + } + bundle.beta = function(beta2) { + return custom(+beta2); + }; + return bundle; + }(0.85); + function point$5(that, x2, y2) { + that._context.bezierCurveTo( + that._x1 + that._k * (that._x2 - that._x0), + that._y1 + that._k * (that._y2 - that._y0), + that._x2 + that._k * (that._x1 - x2), + that._y2 + that._k * (that._y1 - y2), + that._x2, + that._y2 + ); + } + function Cardinal(context, tension) { + this._context = context; + this._k = (1 - tension) / 6; + } + Cardinal.prototype = { + areaStart: function() { + this._line = 0; + }, + areaEnd: function() { + this._line = NaN; + }, + lineStart: function() { + this._x0 = this._x1 = this._x2 = this._y0 = this._y1 = this._y2 = NaN; + this._point = 0; + }, + lineEnd: function() { + switch (this._point) { + case 2: + this._context.lineTo(this._x2, this._y2); + break; + case 3: + point$5(this, this._x1, this._y1); + break; + } + if (this._line || this._line !== 0 && this._point === 1) + this._context.closePath(); + this._line = 1 - this._line; + }, + point: function(x2, y2) { + x2 = +x2, y2 = +y2; + switch (this._point) { + case 0: + this._point = 1; + this._line ? this._context.lineTo(x2, y2) : this._context.moveTo(x2, y2); + break; + case 1: + this._point = 2; + this._x1 = x2, this._y1 = y2; + break; + case 2: + this._point = 3; + default: + point$5(this, x2, y2); + break; + } + this._x0 = this._x1, this._x1 = this._x2, this._x2 = x2; + this._y0 = this._y1, this._y1 = this._y2, this._y2 = y2; + } + }; + const curveCardinal = function custom(tension) { + function cardinal(context) { + return new Cardinal(context, tension); + } + cardinal.tension = function(tension2) { + return custom(+tension2); + }; + return cardinal; + }(0); + function CardinalClosed(context, tension) { + this._context = context; + this._k = (1 - tension) / 6; + } + CardinalClosed.prototype = { + areaStart: noop$1, + areaEnd: noop$1, + lineStart: function() { + this._x0 = this._x1 = this._x2 = this._x3 = this._x4 = this._x5 = this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = this._y5 = NaN; + this._point = 0; + }, + lineEnd: function() { + switch (this._point) { + case 1: { + this._context.moveTo(this._x3, this._y3); + this._context.closePath(); + break; + } + case 2: { + this._context.lineTo(this._x3, this._y3); + this._context.closePath(); + break; + } + case 3: { + this.point(this._x3, this._y3); + this.point(this._x4, this._y4); + this.point(this._x5, this._y5); + break; + } + } + }, + point: function(x2, y2) { + x2 = +x2, y2 = +y2; + switch (this._point) { + case 0: + this._point = 1; + this._x3 = x2, this._y3 = y2; + break; + case 1: + this._point = 2; + this._context.moveTo(this._x4 = x2, this._y4 = y2); + break; + case 2: + this._point = 3; + this._x5 = x2, this._y5 = y2; + break; + default: + point$5(this, x2, y2); + break; + } + this._x0 = this._x1, this._x1 = this._x2, this._x2 = x2; + this._y0 = this._y1, this._y1 = this._y2, this._y2 = y2; + } + }; + const curveCardinalClosed = function custom(tension) { + function cardinal(context) { + return new CardinalClosed(context, tension); + } + cardinal.tension = function(tension2) { + return custom(+tension2); + }; + return cardinal; + }(0); + function CardinalOpen(context, tension) { + this._context = context; + this._k = (1 - tension) / 6; + } + CardinalOpen.prototype = { + areaStart: function() { + this._line = 0; + }, + areaEnd: function() { + this._line = NaN; + }, + lineStart: function() { + this._x0 = this._x1 = this._x2 = this._y0 = this._y1 = this._y2 = NaN; + this._point = 0; + }, + lineEnd: function() { + if (this._line || this._line !== 0 && this._point === 3) + this._context.closePath(); + this._line = 1 - this._line; + }, + point: function(x2, y2) { + x2 = +x2, y2 = +y2; + switch (this._point) { + case 0: + this._point = 1; + break; + case 1: + this._point = 2; + break; + case 2: + this._point = 3; + this._line ? this._context.lineTo(this._x2, this._y2) : this._context.moveTo(this._x2, this._y2); + break; + case 3: + this._point = 4; + default: + point$5(this, x2, y2); + break; + } + this._x0 = this._x1, this._x1 = this._x2, this._x2 = x2; + this._y0 = this._y1, this._y1 = this._y2, this._y2 = y2; + } + }; + const curveCardinalOpen = function custom(tension) { + function cardinal(context) { + return new CardinalOpen(context, tension); + } + cardinal.tension = function(tension2) { + return custom(+tension2); + }; + return cardinal; + }(0); + function point$4(that, x2, y2) { + var x1 = that._x1, y1 = that._y1, x22 = that._x2, y22 = that._y2; + if (that._l01_a > epsilon$1) { + var a = 2 * that._l01_2a + 3 * that._l01_a * that._l12_a + that._l12_2a, n = 3 * that._l01_a * (that._l01_a + that._l12_a); + x1 = (x1 * a - that._x0 * that._l12_2a + that._x2 * that._l01_2a) / n; + y1 = (y1 * a - that._y0 * that._l12_2a + that._y2 * that._l01_2a) / n; + } + if (that._l23_a > epsilon$1) { + var b = 2 * that._l23_2a + 3 * that._l23_a * that._l12_a + that._l12_2a, m = 3 * that._l23_a * (that._l23_a + that._l12_a); + x22 = (x22 * b + that._x1 * that._l23_2a - x2 * that._l12_2a) / m; + y22 = (y22 * b + that._y1 * that._l23_2a - y2 * that._l12_2a) / m; + } + that._context.bezierCurveTo(x1, y1, x22, y22, that._x2, that._y2); + } + function CatmullRom(context, alpha) { + this._context = context; + this._alpha = alpha; + } + CatmullRom.prototype = { + areaStart: function() { + this._line = 0; + }, + areaEnd: function() { + this._line = NaN; + }, + lineStart: function() { + this._x0 = this._x1 = this._x2 = this._y0 = this._y1 = this._y2 = NaN; + this._l01_a = this._l12_a = this._l23_a = this._l01_2a = this._l12_2a = this._l23_2a = this._point = 0; + }, + lineEnd: function() { + switch (this._point) { + case 2: + this._context.lineTo(this._x2, this._y2); + break; + case 3: + this.point(this._x2, this._y2); + break; + } + if (this._line || this._line !== 0 && this._point === 1) + this._context.closePath(); + this._line = 1 - this._line; + }, + point: function(x2, y2) { + x2 = +x2, y2 = +y2; + if (this._point) { + var x23 = this._x2 - x2, y23 = this._y2 - y2; + this._l23_a = Math.sqrt(this._l23_2a = Math.pow(x23 * x23 + y23 * y23, this._alpha)); + } + switch (this._point) { + case 0: + this._point = 1; + this._line ? this._context.lineTo(x2, y2) : this._context.moveTo(x2, y2); + break; + case 1: + this._point = 2; + break; + case 2: + this._point = 3; + default: + point$4(this, x2, y2); + break; + } + this._l01_a = this._l12_a, this._l12_a = this._l23_a; + this._l01_2a = this._l12_2a, this._l12_2a = this._l23_2a; + this._x0 = this._x1, this._x1 = this._x2, this._x2 = x2; + this._y0 = this._y1, this._y1 = this._y2, this._y2 = y2; + } + }; + const curveCatmullRom = function custom(alpha) { + function catmullRom(context) { + return alpha ? new CatmullRom(context, alpha) : new Cardinal(context, 0); + } + catmullRom.alpha = function(alpha2) { + return custom(+alpha2); + }; + return catmullRom; + }(0.5); + function CatmullRomClosed(context, alpha) { + this._context = context; + this._alpha = alpha; + } + CatmullRomClosed.prototype = { + areaStart: noop$1, + areaEnd: noop$1, + lineStart: function() { + this._x0 = this._x1 = this._x2 = this._x3 = this._x4 = this._x5 = this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = this._y5 = NaN; + this._l01_a = this._l12_a = this._l23_a = this._l01_2a = this._l12_2a = this._l23_2a = this._point = 0; + }, + lineEnd: function() { + switch (this._point) { + case 1: { + this._context.moveTo(this._x3, this._y3); + this._context.closePath(); + break; + } + case 2: { + this._context.lineTo(this._x3, this._y3); + this._context.closePath(); + break; + } + case 3: { + this.point(this._x3, this._y3); + this.point(this._x4, this._y4); + this.point(this._x5, this._y5); + break; + } + } + }, + point: function(x2, y2) { + x2 = +x2, y2 = +y2; + if (this._point) { + var x23 = this._x2 - x2, y23 = this._y2 - y2; + this._l23_a = Math.sqrt(this._l23_2a = Math.pow(x23 * x23 + y23 * y23, this._alpha)); + } + switch (this._point) { + case 0: + this._point = 1; + this._x3 = x2, this._y3 = y2; + break; + case 1: + this._point = 2; + this._context.moveTo(this._x4 = x2, this._y4 = y2); + break; + case 2: + this._point = 3; + this._x5 = x2, this._y5 = y2; + break; + default: + point$4(this, x2, y2); + break; + } + this._l01_a = this._l12_a, this._l12_a = this._l23_a; + this._l01_2a = this._l12_2a, this._l12_2a = this._l23_2a; + this._x0 = this._x1, this._x1 = this._x2, this._x2 = x2; + this._y0 = this._y1, this._y1 = this._y2, this._y2 = y2; + } + }; + const curveCatmullRomClosed = function custom(alpha) { + function catmullRom(context) { + return alpha ? new CatmullRomClosed(context, alpha) : new CardinalClosed(context, 0); + } + catmullRom.alpha = function(alpha2) { + return custom(+alpha2); + }; + return catmullRom; + }(0.5); + function CatmullRomOpen(context, alpha) { + this._context = context; + this._alpha = alpha; + } + CatmullRomOpen.prototype = { + areaStart: function() { + this._line = 0; + }, + areaEnd: function() { + this._line = NaN; + }, + lineStart: function() { + this._x0 = this._x1 = this._x2 = this._y0 = this._y1 = this._y2 = NaN; + this._l01_a = this._l12_a = this._l23_a = this._l01_2a = this._l12_2a = this._l23_2a = this._point = 0; + }, + lineEnd: function() { + if (this._line || this._line !== 0 && this._point === 3) + this._context.closePath(); + this._line = 1 - this._line; + }, + point: function(x2, y2) { + x2 = +x2, y2 = +y2; + if (this._point) { + var x23 = this._x2 - x2, y23 = this._y2 - y2; + this._l23_a = Math.sqrt(this._l23_2a = Math.pow(x23 * x23 + y23 * y23, this._alpha)); + } + switch (this._point) { + case 0: + this._point = 1; + break; + case 1: + this._point = 2; + break; + case 2: + this._point = 3; + this._line ? this._context.lineTo(this._x2, this._y2) : this._context.moveTo(this._x2, this._y2); + break; + case 3: + this._point = 4; + default: + point$4(this, x2, y2); + break; + } + this._l01_a = this._l12_a, this._l12_a = this._l23_a; + this._l01_2a = this._l12_2a, this._l12_2a = this._l23_2a; + this._x0 = this._x1, this._x1 = this._x2, this._x2 = x2; + this._y0 = this._y1, this._y1 = this._y2, this._y2 = y2; + } + }; + const curveCatmullRomOpen = function custom(alpha) { + function catmullRom(context) { + return alpha ? new CatmullRomOpen(context, alpha) : new CardinalOpen(context, 0); + } + catmullRom.alpha = function(alpha2) { + return custom(+alpha2); + }; + return catmullRom; + }(0.5); + function LinearClosed(context) { + this._context = context; + } + LinearClosed.prototype = { + areaStart: noop$1, + areaEnd: noop$1, + lineStart: function() { + this._point = 0; + }, + lineEnd: function() { + if (this._point) + this._context.closePath(); + }, + point: function(x2, y2) { + x2 = +x2, y2 = +y2; + if (this._point) + this._context.lineTo(x2, y2); + else + this._point = 1, this._context.moveTo(x2, y2); + } + }; + function curveLinearClosed(context) { + return new LinearClosed(context); + } + function sign(x2) { + return x2 < 0 ? -1 : 1; + } + function slope3(that, x2, y2) { + var h0 = that._x1 - that._x0, h1 = x2 - that._x1, s0 = (that._y1 - that._y0) / (h0 || h1 < 0 && -0), s1 = (y2 - that._y1) / (h1 || h0 < 0 && -0), p = (s0 * h1 + s1 * h0) / (h0 + h1); + return (sign(s0) + sign(s1)) * Math.min(Math.abs(s0), Math.abs(s1), 0.5 * Math.abs(p)) || 0; + } + function slope2(that, t) { + var h = that._x1 - that._x0; + return h ? (3 * (that._y1 - that._y0) / h - t) / 2 : t; + } + function point$3(that, t02, t12) { + var x0 = that._x0, y0 = that._y0, x1 = that._x1, y1 = that._y1, dx = (x1 - x0) / 3; + that._context.bezierCurveTo(x0 + dx, y0 + dx * t02, x1 - dx, y1 - dx * t12, x1, y1); + } + function MonotoneX(context) { + this._context = context; + } + MonotoneX.prototype = { + areaStart: function() { + this._line = 0; + }, + areaEnd: function() { + this._line = NaN; + }, + lineStart: function() { + this._x0 = this._x1 = this._y0 = this._y1 = this._t0 = NaN; + this._point = 0; + }, + lineEnd: function() { + switch (this._point) { + case 2: + this._context.lineTo(this._x1, this._y1); + break; + case 3: + point$3(this, this._t0, slope2(this, this._t0)); + break; + } + if (this._line || this._line !== 0 && this._point === 1) + this._context.closePath(); + this._line = 1 - this._line; + }, + point: function(x2, y2) { + var t12 = NaN; + x2 = +x2, y2 = +y2; + if (x2 === this._x1 && y2 === this._y1) + return; + switch (this._point) { + case 0: + this._point = 1; + this._line ? this._context.lineTo(x2, y2) : this._context.moveTo(x2, y2); + break; + case 1: + this._point = 2; + break; + case 2: + this._point = 3; + point$3(this, slope2(this, t12 = slope3(this, x2, y2)), t12); + break; + default: + point$3(this, this._t0, t12 = slope3(this, x2, y2)); + break; + } + this._x0 = this._x1, this._x1 = x2; + this._y0 = this._y1, this._y1 = y2; + this._t0 = t12; + } + }; + function MonotoneY(context) { + this._context = new ReflectContext(context); + } + (MonotoneY.prototype = Object.create(MonotoneX.prototype)).point = function(x2, y2) { + MonotoneX.prototype.point.call(this, y2, x2); + }; + function ReflectContext(context) { + this._context = context; + } + ReflectContext.prototype = { + moveTo: function(x2, y2) { + this._context.moveTo(y2, x2); + }, + closePath: function() { + this._context.closePath(); + }, + lineTo: function(x2, y2) { + this._context.lineTo(y2, x2); + }, + bezierCurveTo: function(x1, y1, x2, y2, x3, y3) { + this._context.bezierCurveTo(y1, x1, y2, x2, y3, x3); + } + }; + function monotoneX(context) { + return new MonotoneX(context); + } + function monotoneY(context) { + return new MonotoneY(context); + } + function Natural(context) { + this._context = context; + } + Natural.prototype = { + areaStart: function() { + this._line = 0; + }, + areaEnd: function() { + this._line = NaN; + }, + lineStart: function() { + this._x = []; + this._y = []; + }, + lineEnd: function() { + var x2 = this._x, y2 = this._y, n = x2.length; + if (n) { + this._line ? this._context.lineTo(x2[0], y2[0]) : this._context.moveTo(x2[0], y2[0]); + if (n === 2) { + this._context.lineTo(x2[1], y2[1]); + } else { + var px = controlPoints(x2), py = controlPoints(y2); + for (var i0 = 0, i1 = 1; i1 < n; ++i0, ++i1) { + this._context.bezierCurveTo(px[0][i0], py[0][i0], px[1][i0], py[1][i0], x2[i1], y2[i1]); + } + } + } + if (this._line || this._line !== 0 && n === 1) + this._context.closePath(); + this._line = 1 - this._line; + this._x = this._y = null; + }, + point: function(x2, y2) { + this._x.push(+x2); + this._y.push(+y2); + } + }; + function controlPoints(x2) { + var i2, n = x2.length - 1, m, a = new Array(n), b = new Array(n), r = new Array(n); + a[0] = 0, b[0] = 2, r[0] = x2[0] + 2 * x2[1]; + for (i2 = 1; i2 < n - 1; ++i2) + a[i2] = 1, b[i2] = 4, r[i2] = 4 * x2[i2] + 2 * x2[i2 + 1]; + a[n - 1] = 2, b[n - 1] = 7, r[n - 1] = 8 * x2[n - 1] + x2[n]; + for (i2 = 1; i2 < n; ++i2) + m = a[i2] / b[i2 - 1], b[i2] -= m, r[i2] -= m * r[i2 - 1]; + a[n - 1] = r[n - 1] / b[n - 1]; + for (i2 = n - 2; i2 >= 0; --i2) + a[i2] = (r[i2] - a[i2 + 1]) / b[i2]; + b[n - 1] = (x2[n] + a[n - 1]) / 2; + for (i2 = 0; i2 < n - 1; ++i2) + b[i2] = 2 * x2[i2 + 1] - a[i2 + 1]; + return [a, b]; + } + function curveNatural(context) { + return new Natural(context); + } + function Step(context, t) { + this._context = context; + this._t = t; + } + Step.prototype = { + areaStart: function() { + this._line = 0; + }, + areaEnd: function() { + this._line = NaN; + }, + lineStart: function() { + this._x = this._y = NaN; + this._point = 0; + }, + lineEnd: function() { + if (0 < this._t && this._t < 1 && this._point === 2) + this._context.lineTo(this._x, this._y); + if (this._line || this._line !== 0 && this._point === 1) + this._context.closePath(); + if (this._line >= 0) + this._t = 1 - this._t, this._line = 1 - this._line; + }, + point: function(x2, y2) { + x2 = +x2, y2 = +y2; + switch (this._point) { + case 0: + this._point = 1; + this._line ? this._context.lineTo(x2, y2) : this._context.moveTo(x2, y2); + break; + case 1: + this._point = 2; + default: { + if (this._t <= 0) { + this._context.lineTo(this._x, y2); + this._context.lineTo(x2, y2); + } else { + var x1 = this._x * (1 - this._t) + x2 * this._t; + this._context.lineTo(x1, this._y); + this._context.lineTo(x1, y2); + } + break; + } + } + this._x = x2, this._y = y2; + } + }; + function curveStep(context) { + return new Step(context, 0.5); + } + function stepBefore(context) { + return new Step(context, 0); + } + function stepAfter(context) { + return new Step(context, 1); + } + function Transform(k, x2, y2) { + this.k = k; + this.x = x2; + this.y = y2; + } + Transform.prototype = { + constructor: Transform, + scale: function(k) { + return k === 1 ? this : new Transform(this.k * k, this.x, this.y); + }, + translate: function(x2, y2) { + return x2 === 0 & y2 === 0 ? this : new Transform(this.k, this.x + this.k * x2, this.y + this.k * y2); + }, + apply: function(point2) { + return [point2[0] * this.k + this.x, point2[1] * this.k + this.y]; + }, + applyX: function(x2) { + return x2 * this.k + this.x; + }, + applyY: function(y2) { + return y2 * this.k + this.y; + }, + invert: function(location2) { + return [(location2[0] - this.x) / this.k, (location2[1] - this.y) / this.k]; + }, + invertX: function(x2) { + return (x2 - this.x) / this.k; + }, + invertY: function(y2) { + return (y2 - this.y) / this.k; + }, + rescaleX: function(x2) { + return x2.copy().domain(x2.range().map(this.invertX, this).map(x2.invert, x2)); + }, + rescaleY: function(y2) { + return y2.copy().domain(y2.range().map(this.invertY, this).map(y2.invert, y2)); + }, + toString: function() { + return "translate(" + this.x + "," + this.y + ") scale(" + this.k + ")"; + } + }; + Transform.prototype; + /*! @license DOMPurify 3.0.9 | (c) Cure53 and other contributors | Released under the Apache license 2.0 and Mozilla Public License 2.0 | github.com/cure53/DOMPurify/blob/3.0.9/LICENSE */ + const { + entries, + setPrototypeOf, + isFrozen, + getPrototypeOf, + getOwnPropertyDescriptor + } = Object; + let { + freeze, + seal, + create + } = Object; + let { + apply: apply$2, + construct + } = typeof Reflect !== "undefined" && Reflect; + if (!freeze) { + freeze = function freeze2(x2) { + return x2; + }; + } + if (!seal) { + seal = function seal2(x2) { + return x2; + }; + } + if (!apply$2) { + apply$2 = function apply2(fun, thisValue, args) { + return fun.apply(thisValue, args); + }; + } + if (!construct) { + construct = function construct2(Func, args) { + return new Func(...args); + }; + } + const arrayForEach = unapply(Array.prototype.forEach); + const arrayPop = unapply(Array.prototype.pop); + const arrayPush$1 = unapply(Array.prototype.push); + const stringToLowerCase = unapply(String.prototype.toLowerCase); + const stringToString = unapply(String.prototype.toString); + const stringMatch = unapply(String.prototype.match); + const stringReplace = unapply(String.prototype.replace); + const stringIndexOf = unapply(String.prototype.indexOf); + const stringTrim = unapply(String.prototype.trim); + const objectHasOwnProperty = unapply(Object.prototype.hasOwnProperty); + const regExpTest = unapply(RegExp.prototype.test); + const typeErrorCreate = unconstruct(TypeError); + function unapply(func) { + return function(thisArg) { + for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + args[_key - 1] = arguments[_key]; + } + return apply$2(func, thisArg, args); + }; + } + function unconstruct(func) { + return function() { + for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) { + args[_key2] = arguments[_key2]; + } + return construct(func, args); + }; + } + function addToSet(set2, array2) { + let transformCaseFunc = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : stringToLowerCase; + if (setPrototypeOf) { + setPrototypeOf(set2, null); + } + let l = array2.length; + while (l--) { + let element2 = array2[l]; + if (typeof element2 === "string") { + const lcElement = transformCaseFunc(element2); + if (lcElement !== element2) { + if (!isFrozen(array2)) { + array2[l] = lcElement; + } + element2 = lcElement; + } + } + set2[element2] = true; + } + return set2; + } + function cleanArray(array2) { + for (let index2 = 0; index2 < array2.length; index2++) { + const isPropertyExist = objectHasOwnProperty(array2, index2); + if (!isPropertyExist) { + array2[index2] = null; + } + } + return array2; + } + function clone$2(object2) { + const newObject = create(null); + for (const [property2, value2] of entries(object2)) { + const isPropertyExist = objectHasOwnProperty(object2, property2); + if (isPropertyExist) { + if (Array.isArray(value2)) { + newObject[property2] = cleanArray(value2); + } else if (value2 && typeof value2 === "object" && value2.constructor === Object) { + newObject[property2] = clone$2(value2); + } else { + newObject[property2] = value2; + } + } + } + return newObject; + } + function lookupGetter(object2, prop) { + while (object2 !== null) { + const desc = getOwnPropertyDescriptor(object2, prop); + if (desc) { + if (desc.get) { + return unapply(desc.get); + } + if (typeof desc.value === "function") { + return unapply(desc.value); + } + } + object2 = getPrototypeOf(object2); + } + function fallbackValue() { + return null; + } + return fallbackValue; + } + const html$1 = freeze(["a", "abbr", "acronym", "address", "area", "article", "aside", "audio", "b", "bdi", "bdo", "big", "blink", "blockquote", "body", "br", "button", "canvas", "caption", "center", "cite", "code", "col", "colgroup", "content", "data", "datalist", "dd", "decorator", "del", "details", "dfn", "dialog", "dir", "div", "dl", "dt", "element", "em", "fieldset", "figcaption", "figure", "font", "footer", "form", "h1", "h2", "h3", "h4", "h5", "h6", "head", "header", "hgroup", "hr", "html", "i", "img", "input", "ins", "kbd", "label", "legend", "li", "main", "map", "mark", "marquee", "menu", "menuitem", "meter", "nav", "nobr", "ol", "optgroup", "option", "output", "p", "picture", "pre", "progress", "q", "rp", "rt", "ruby", "s", "samp", "section", "select", "shadow", "small", "source", "spacer", "span", "strike", "strong", "style", "sub", "summary", "sup", "table", "tbody", "td", "template", "textarea", "tfoot", "th", "thead", "time", "tr", "track", "tt", "u", "ul", "var", "video", "wbr"]); + const svg$1 = freeze(["svg", "a", "altglyph", "altglyphdef", "altglyphitem", "animatecolor", "animatemotion", "animatetransform", "circle", "clippath", "defs", "desc", "ellipse", "filter", "font", "g", "glyph", "glyphref", "hkern", "image", "line", "lineargradient", "marker", "mask", "metadata", "mpath", "path", "pattern", "polygon", "polyline", "radialgradient", "rect", "stop", "style", "switch", "symbol", "text", "textpath", "title", "tref", "tspan", "view", "vkern"]); + const svgFilters = freeze(["feBlend", "feColorMatrix", "feComponentTransfer", "feComposite", "feConvolveMatrix", "feDiffuseLighting", "feDisplacementMap", "feDistantLight", "feDropShadow", "feFlood", "feFuncA", "feFuncB", "feFuncG", "feFuncR", "feGaussianBlur", "feImage", "feMerge", "feMergeNode", "feMorphology", "feOffset", "fePointLight", "feSpecularLighting", "feSpotLight", "feTile", "feTurbulence"]); + const svgDisallowed = freeze(["animate", "color-profile", "cursor", "discard", "font-face", "font-face-format", "font-face-name", "font-face-src", "font-face-uri", "foreignobject", "hatch", "hatchpath", "mesh", "meshgradient", "meshpatch", "meshrow", "missing-glyph", "script", "set", "solidcolor", "unknown", "use"]); + const mathMl$1 = freeze(["math", "menclose", "merror", "mfenced", "mfrac", "mglyph", "mi", "mlabeledtr", "mmultiscripts", "mn", "mo", "mover", "mpadded", "mphantom", "mroot", "mrow", "ms", "mspace", "msqrt", "mstyle", "msub", "msup", "msubsup", "mtable", "mtd", "mtext", "mtr", "munder", "munderover", "mprescripts"]); + const mathMlDisallowed = freeze(["maction", "maligngroup", "malignmark", "mlongdiv", "mscarries", "mscarry", "msgroup", "mstack", "msline", "msrow", "semantics", "annotation", "annotation-xml", "mprescripts", "none"]); + const text$3 = freeze(["#text"]); + const html = freeze(["accept", "action", "align", "alt", "autocapitalize", "autocomplete", "autopictureinpicture", "autoplay", "background", "bgcolor", "border", "capture", "cellpadding", "cellspacing", "checked", "cite", "class", "clear", "color", "cols", "colspan", "controls", "controlslist", "coords", "crossorigin", "datetime", "decoding", "default", "dir", "disabled", "disablepictureinpicture", "disableremoteplayback", "download", "draggable", "enctype", "enterkeyhint", "face", "for", "headers", "height", "hidden", "high", "href", "hreflang", "id", "inputmode", "integrity", "ismap", "kind", "label", "lang", "list", "loading", "loop", "low", "max", "maxlength", "media", "method", "min", "minlength", "multiple", "muted", "name", "nonce", "noshade", "novalidate", "nowrap", "open", "optimum", "pattern", "placeholder", "playsinline", "poster", "preload", "pubdate", "radiogroup", "readonly", "rel", "required", "rev", "reversed", "role", "rows", "rowspan", "spellcheck", "scope", "selected", "shape", "size", "sizes", "span", "srclang", "start", "src", "srcset", "step", "style", "summary", "tabindex", "title", "translate", "type", "usemap", "valign", "value", "width", "xmlns", "slot"]); + const svg = freeze(["accent-height", "accumulate", "additive", "alignment-baseline", "ascent", "attributename", "attributetype", "azimuth", "basefrequency", "baseline-shift", "begin", "bias", "by", "class", "clip", "clippathunits", "clip-path", "clip-rule", "color", "color-interpolation", "color-interpolation-filters", "color-profile", "color-rendering", "cx", "cy", "d", "dx", "dy", "diffuseconstant", "direction", "display", "divisor", "dur", "edgemode", "elevation", "end", "fill", "fill-opacity", "fill-rule", "filter", "filterunits", "flood-color", "flood-opacity", "font-family", "font-size", "font-size-adjust", "font-stretch", "font-style", "font-variant", "font-weight", "fx", "fy", "g1", "g2", "glyph-name", "glyphref", "gradientunits", "gradienttransform", "height", "href", "id", "image-rendering", "in", "in2", "k", "k1", "k2", "k3", "k4", "kerning", "keypoints", "keysplines", "keytimes", "lang", "lengthadjust", "letter-spacing", "kernelmatrix", "kernelunitlength", "lighting-color", "local", "marker-end", "marker-mid", "marker-start", "markerheight", "markerunits", "markerwidth", "maskcontentunits", "maskunits", "max", "mask", "media", "method", "mode", "min", "name", "numoctaves", "offset", "operator", "opacity", "order", "orient", "orientation", "origin", "overflow", "paint-order", "path", "pathlength", "patterncontentunits", "patterntransform", "patternunits", "points", "preservealpha", "preserveaspectratio", "primitiveunits", "r", "rx", "ry", "radius", "refx", "refy", "repeatcount", "repeatdur", "restart", "result", "rotate", "scale", "seed", "shape-rendering", "specularconstant", "specularexponent", "spreadmethod", "startoffset", "stddeviation", "stitchtiles", "stop-color", "stop-opacity", "stroke-dasharray", "stroke-dashoffset", "stroke-linecap", "stroke-linejoin", "stroke-miterlimit", "stroke-opacity", "stroke", "stroke-width", "style", "surfacescale", "systemlanguage", "tabindex", "targetx", "targety", "transform", "transform-origin", "text-anchor", "text-decoration", "text-rendering", "textlength", "type", "u1", "u2", "unicode", "values", "viewbox", "visibility", "version", "vert-adv-y", "vert-origin-x", "vert-origin-y", "width", "word-spacing", "wrap", "writing-mode", "xchannelselector", "ychannelselector", "x", "x1", "x2", "xmlns", "y", "y1", "y2", "z", "zoomandpan"]); + const mathMl = freeze(["accent", "accentunder", "align", "bevelled", "close", "columnsalign", "columnlines", "columnspan", "denomalign", "depth", "dir", "display", "displaystyle", "encoding", "fence", "frame", "height", "href", "id", "largeop", "length", "linethickness", "lspace", "lquote", "mathbackground", "mathcolor", "mathsize", "mathvariant", "maxsize", "minsize", "movablelimits", "notation", "numalign", "open", "rowalign", "rowlines", "rowspacing", "rowspan", "rspace", "rquote", "scriptlevel", "scriptminsize", "scriptsizemultiplier", "selection", "separator", "separators", "stretchy", "subscriptshift", "supscriptshift", "symmetric", "voffset", "width", "xmlns"]); + const xml = freeze(["xlink:href", "xml:id", "xlink:title", "xml:space", "xmlns:xlink"]); + const MUSTACHE_EXPR = seal(/\{\{[\w\W]*|[\w\W]*\}\}/gm); + const ERB_EXPR = seal(/<%[\w\W]*|[\w\W]*%>/gm); + const TMPLIT_EXPR = seal(/\${[\w\W]*}/gm); + const DATA_ATTR = seal(/^data-[\-\w.\u00B7-\uFFFF]/); + const ARIA_ATTR = seal(/^aria-[\-\w]+$/); + const IS_ALLOWED_URI = seal( + /^(?:(?:(?:f|ht)tps?|mailto|tel|callto|sms|cid|xmpp):|[^a-z]|[a-z+.\-]+(?:[^a-z+.\-:]|$))/i + // eslint-disable-line no-useless-escape + ); + const IS_SCRIPT_OR_DATA = seal(/^(?:\w+script|data):/i); + const ATTR_WHITESPACE = seal( + /[\u0000-\u0020\u00A0\u1680\u180E\u2000-\u2029\u205F\u3000]/g + // eslint-disable-line no-control-regex + ); + const DOCTYPE_NAME = seal(/^html$/i); + var EXPRESSIONS = /* @__PURE__ */ Object.freeze({ + __proto__: null, + MUSTACHE_EXPR, + ERB_EXPR, + TMPLIT_EXPR, + DATA_ATTR, + ARIA_ATTR, + IS_ALLOWED_URI, + IS_SCRIPT_OR_DATA, + ATTR_WHITESPACE, + DOCTYPE_NAME + }); + const getGlobal = function getGlobal2() { + return typeof window === "undefined" ? null : window; + }; + const _createTrustedTypesPolicy = function _createTrustedTypesPolicy2(trustedTypes, purifyHostElement) { + if (typeof trustedTypes !== "object" || typeof trustedTypes.createPolicy !== "function") { + return null; + } + let suffix = null; + const ATTR_NAME = "data-tt-policy-suffix"; + if (purifyHostElement && purifyHostElement.hasAttribute(ATTR_NAME)) { + suffix = purifyHostElement.getAttribute(ATTR_NAME); + } + const policyName = "dompurify" + (suffix ? "#" + suffix : ""); + try { + return trustedTypes.createPolicy(policyName, { + createHTML(html2) { + return html2; + }, + createScriptURL(scriptUrl) { + return scriptUrl; + } + }); + } catch (_2) { + console.warn("TrustedTypes policy " + policyName + " could not be created."); + return null; + } + }; + function createDOMPurify() { + let window2 = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : getGlobal(); + const DOMPurify = (root2) => createDOMPurify(root2); + DOMPurify.version = "3.0.9"; + DOMPurify.removed = []; + if (!window2 || !window2.document || window2.document.nodeType !== 9) { + DOMPurify.isSupported = false; + return DOMPurify; + } + let { + document: document2 + } = window2; + const originalDocument = document2; + const currentScript = originalDocument.currentScript; + const { + DocumentFragment: DocumentFragment2, + HTMLTemplateElement, + Node, + Element, + NodeFilter, + NamedNodeMap = window2.NamedNodeMap || window2.MozNamedAttrMap, + HTMLFormElement, + DOMParser: DOMParser2, + trustedTypes + } = window2; + const ElementPrototype = Element.prototype; + const cloneNode = lookupGetter(ElementPrototype, "cloneNode"); + const getNextSibling = lookupGetter(ElementPrototype, "nextSibling"); + const getChildNodes = lookupGetter(ElementPrototype, "childNodes"); + const getParentNode = lookupGetter(ElementPrototype, "parentNode"); + if (typeof HTMLTemplateElement === "function") { + const template = document2.createElement("template"); + if (template.content && template.content.ownerDocument) { + document2 = template.content.ownerDocument; + } + } + let trustedTypesPolicy; + let emptyHTML = ""; + const { + implementation, + createNodeIterator, + createDocumentFragment, + getElementsByTagName + } = document2; + const { + importNode + } = originalDocument; + let hooks = {}; + DOMPurify.isSupported = typeof entries === "function" && typeof getParentNode === "function" && implementation && implementation.createHTMLDocument !== void 0; + const { + MUSTACHE_EXPR: MUSTACHE_EXPR2, + ERB_EXPR: ERB_EXPR2, + TMPLIT_EXPR: TMPLIT_EXPR2, + DATA_ATTR: DATA_ATTR2, + ARIA_ATTR: ARIA_ATTR2, + IS_SCRIPT_OR_DATA: IS_SCRIPT_OR_DATA2, + ATTR_WHITESPACE: ATTR_WHITESPACE2 + } = EXPRESSIONS; + let { + IS_ALLOWED_URI: IS_ALLOWED_URI$1 + } = EXPRESSIONS; + let ALLOWED_TAGS = null; + const DEFAULT_ALLOWED_TAGS = addToSet({}, [...html$1, ...svg$1, ...svgFilters, ...mathMl$1, ...text$3]); + let ALLOWED_ATTR = null; + const DEFAULT_ALLOWED_ATTR = addToSet({}, [...html, ...svg, ...mathMl, ...xml]); + let CUSTOM_ELEMENT_HANDLING = Object.seal(create(null, { + tagNameCheck: { + writable: true, + configurable: false, + enumerable: true, + value: null + }, + attributeNameCheck: { + writable: true, + configurable: false, + enumerable: true, + value: null + }, + allowCustomizedBuiltInElements: { + writable: true, + configurable: false, + enumerable: true, + value: false + } + })); + let FORBID_TAGS = null; + let FORBID_ATTR = null; + let ALLOW_ARIA_ATTR = true; + let ALLOW_DATA_ATTR = true; + let ALLOW_UNKNOWN_PROTOCOLS = false; + let ALLOW_SELF_CLOSE_IN_ATTR = true; + let SAFE_FOR_TEMPLATES = false; + let WHOLE_DOCUMENT = false; + let SET_CONFIG = false; + let FORCE_BODY = false; + let RETURN_DOM = false; + let RETURN_DOM_FRAGMENT = false; + let RETURN_TRUSTED_TYPE = false; + let SANITIZE_DOM = true; + let SANITIZE_NAMED_PROPS = false; + const SANITIZE_NAMED_PROPS_PREFIX = "user-content-"; + let KEEP_CONTENT = true; + let IN_PLACE = false; + let USE_PROFILES = {}; + let FORBID_CONTENTS = null; + const DEFAULT_FORBID_CONTENTS = addToSet({}, ["annotation-xml", "audio", "colgroup", "desc", "foreignobject", "head", "iframe", "math", "mi", "mn", "mo", "ms", "mtext", "noembed", "noframes", "noscript", "plaintext", "script", "style", "svg", "template", "thead", "title", "video", "xmp"]); + let DATA_URI_TAGS = null; + const DEFAULT_DATA_URI_TAGS = addToSet({}, ["audio", "video", "img", "source", "image", "track"]); + let URI_SAFE_ATTRIBUTES = null; + const DEFAULT_URI_SAFE_ATTRIBUTES = addToSet({}, ["alt", "class", "for", "id", "label", "name", "pattern", "placeholder", "role", "summary", "title", "value", "style", "xmlns"]); + const MATHML_NAMESPACE = "http://www.w3.org/1998/Math/MathML"; + const SVG_NAMESPACE = "http://www.w3.org/2000/svg"; + const HTML_NAMESPACE = "http://www.w3.org/1999/xhtml"; + let NAMESPACE = HTML_NAMESPACE; + let IS_EMPTY_INPUT = false; + let ALLOWED_NAMESPACES = null; + const DEFAULT_ALLOWED_NAMESPACES = addToSet({}, [MATHML_NAMESPACE, SVG_NAMESPACE, HTML_NAMESPACE], stringToString); + let PARSER_MEDIA_TYPE = null; + const SUPPORTED_PARSER_MEDIA_TYPES = ["application/xhtml+xml", "text/html"]; + const DEFAULT_PARSER_MEDIA_TYPE = "text/html"; + let transformCaseFunc = null; + let CONFIG = null; + const formElement = document2.createElement("form"); + const isRegexOrFunction = function isRegexOrFunction2(testValue) { + return testValue instanceof RegExp || testValue instanceof Function; + }; + const _parseConfig = function _parseConfig2() { + let cfg = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}; + if (CONFIG && CONFIG === cfg) { + return; + } + if (!cfg || typeof cfg !== "object") { + cfg = {}; + } + cfg = clone$2(cfg); + PARSER_MEDIA_TYPE = // eslint-disable-next-line unicorn/prefer-includes + SUPPORTED_PARSER_MEDIA_TYPES.indexOf(cfg.PARSER_MEDIA_TYPE) === -1 ? DEFAULT_PARSER_MEDIA_TYPE : cfg.PARSER_MEDIA_TYPE; + transformCaseFunc = PARSER_MEDIA_TYPE === "application/xhtml+xml" ? stringToString : stringToLowerCase; + ALLOWED_TAGS = objectHasOwnProperty(cfg, "ALLOWED_TAGS") ? addToSet({}, cfg.ALLOWED_TAGS, transformCaseFunc) : DEFAULT_ALLOWED_TAGS; + ALLOWED_ATTR = objectHasOwnProperty(cfg, "ALLOWED_ATTR") ? addToSet({}, cfg.ALLOWED_ATTR, transformCaseFunc) : DEFAULT_ALLOWED_ATTR; + ALLOWED_NAMESPACES = objectHasOwnProperty(cfg, "ALLOWED_NAMESPACES") ? addToSet({}, cfg.ALLOWED_NAMESPACES, stringToString) : DEFAULT_ALLOWED_NAMESPACES; + URI_SAFE_ATTRIBUTES = objectHasOwnProperty(cfg, "ADD_URI_SAFE_ATTR") ? addToSet( + clone$2(DEFAULT_URI_SAFE_ATTRIBUTES), + // eslint-disable-line indent + cfg.ADD_URI_SAFE_ATTR, + // eslint-disable-line indent + transformCaseFunc + // eslint-disable-line indent + ) : DEFAULT_URI_SAFE_ATTRIBUTES; + DATA_URI_TAGS = objectHasOwnProperty(cfg, "ADD_DATA_URI_TAGS") ? addToSet( + clone$2(DEFAULT_DATA_URI_TAGS), + // eslint-disable-line indent + cfg.ADD_DATA_URI_TAGS, + // eslint-disable-line indent + transformCaseFunc + // eslint-disable-line indent + ) : DEFAULT_DATA_URI_TAGS; + FORBID_CONTENTS = objectHasOwnProperty(cfg, "FORBID_CONTENTS") ? addToSet({}, cfg.FORBID_CONTENTS, transformCaseFunc) : DEFAULT_FORBID_CONTENTS; + FORBID_TAGS = objectHasOwnProperty(cfg, "FORBID_TAGS") ? addToSet({}, cfg.FORBID_TAGS, transformCaseFunc) : {}; + FORBID_ATTR = objectHasOwnProperty(cfg, "FORBID_ATTR") ? addToSet({}, cfg.FORBID_ATTR, transformCaseFunc) : {}; + USE_PROFILES = objectHasOwnProperty(cfg, "USE_PROFILES") ? cfg.USE_PROFILES : false; + ALLOW_ARIA_ATTR = cfg.ALLOW_ARIA_ATTR !== false; + ALLOW_DATA_ATTR = cfg.ALLOW_DATA_ATTR !== false; + ALLOW_UNKNOWN_PROTOCOLS = cfg.ALLOW_UNKNOWN_PROTOCOLS || false; + ALLOW_SELF_CLOSE_IN_ATTR = cfg.ALLOW_SELF_CLOSE_IN_ATTR !== false; + SAFE_FOR_TEMPLATES = cfg.SAFE_FOR_TEMPLATES || false; + WHOLE_DOCUMENT = cfg.WHOLE_DOCUMENT || false; + RETURN_DOM = cfg.RETURN_DOM || false; + RETURN_DOM_FRAGMENT = cfg.RETURN_DOM_FRAGMENT || false; + RETURN_TRUSTED_TYPE = cfg.RETURN_TRUSTED_TYPE || false; + FORCE_BODY = cfg.FORCE_BODY || false; + SANITIZE_DOM = cfg.SANITIZE_DOM !== false; + SANITIZE_NAMED_PROPS = cfg.SANITIZE_NAMED_PROPS || false; + KEEP_CONTENT = cfg.KEEP_CONTENT !== false; + IN_PLACE = cfg.IN_PLACE || false; + IS_ALLOWED_URI$1 = cfg.ALLOWED_URI_REGEXP || IS_ALLOWED_URI; + NAMESPACE = cfg.NAMESPACE || HTML_NAMESPACE; + CUSTOM_ELEMENT_HANDLING = cfg.CUSTOM_ELEMENT_HANDLING || {}; + if (cfg.CUSTOM_ELEMENT_HANDLING && isRegexOrFunction(cfg.CUSTOM_ELEMENT_HANDLING.tagNameCheck)) { + CUSTOM_ELEMENT_HANDLING.tagNameCheck = cfg.CUSTOM_ELEMENT_HANDLING.tagNameCheck; + } + if (cfg.CUSTOM_ELEMENT_HANDLING && isRegexOrFunction(cfg.CUSTOM_ELEMENT_HANDLING.attributeNameCheck)) { + CUSTOM_ELEMENT_HANDLING.attributeNameCheck = cfg.CUSTOM_ELEMENT_HANDLING.attributeNameCheck; + } + if (cfg.CUSTOM_ELEMENT_HANDLING && typeof cfg.CUSTOM_ELEMENT_HANDLING.allowCustomizedBuiltInElements === "boolean") { + CUSTOM_ELEMENT_HANDLING.allowCustomizedBuiltInElements = cfg.CUSTOM_ELEMENT_HANDLING.allowCustomizedBuiltInElements; + } + if (SAFE_FOR_TEMPLATES) { + ALLOW_DATA_ATTR = false; + } + if (RETURN_DOM_FRAGMENT) { + RETURN_DOM = true; + } + if (USE_PROFILES) { + ALLOWED_TAGS = addToSet({}, text$3); + ALLOWED_ATTR = []; + if (USE_PROFILES.html === true) { + addToSet(ALLOWED_TAGS, html$1); + addToSet(ALLOWED_ATTR, html); + } + if (USE_PROFILES.svg === true) { + addToSet(ALLOWED_TAGS, svg$1); + addToSet(ALLOWED_ATTR, svg); + addToSet(ALLOWED_ATTR, xml); + } + if (USE_PROFILES.svgFilters === true) { + addToSet(ALLOWED_TAGS, svgFilters); + addToSet(ALLOWED_ATTR, svg); + addToSet(ALLOWED_ATTR, xml); + } + if (USE_PROFILES.mathMl === true) { + addToSet(ALLOWED_TAGS, mathMl$1); + addToSet(ALLOWED_ATTR, mathMl); + addToSet(ALLOWED_ATTR, xml); + } + } + if (cfg.ADD_TAGS) { + if (ALLOWED_TAGS === DEFAULT_ALLOWED_TAGS) { + ALLOWED_TAGS = clone$2(ALLOWED_TAGS); + } + addToSet(ALLOWED_TAGS, cfg.ADD_TAGS, transformCaseFunc); + } + if (cfg.ADD_ATTR) { + if (ALLOWED_ATTR === DEFAULT_ALLOWED_ATTR) { + ALLOWED_ATTR = clone$2(ALLOWED_ATTR); + } + addToSet(ALLOWED_ATTR, cfg.ADD_ATTR, transformCaseFunc); + } + if (cfg.ADD_URI_SAFE_ATTR) { + addToSet(URI_SAFE_ATTRIBUTES, cfg.ADD_URI_SAFE_ATTR, transformCaseFunc); + } + if (cfg.FORBID_CONTENTS) { + if (FORBID_CONTENTS === DEFAULT_FORBID_CONTENTS) { + FORBID_CONTENTS = clone$2(FORBID_CONTENTS); + } + addToSet(FORBID_CONTENTS, cfg.FORBID_CONTENTS, transformCaseFunc); + } + if (KEEP_CONTENT) { + ALLOWED_TAGS["#text"] = true; + } + if (WHOLE_DOCUMENT) { + addToSet(ALLOWED_TAGS, ["html", "head", "body"]); + } + if (ALLOWED_TAGS.table) { + addToSet(ALLOWED_TAGS, ["tbody"]); + delete FORBID_TAGS.tbody; + } + if (cfg.TRUSTED_TYPES_POLICY) { + if (typeof cfg.TRUSTED_TYPES_POLICY.createHTML !== "function") { + throw typeErrorCreate('TRUSTED_TYPES_POLICY configuration option must provide a "createHTML" hook.'); + } + if (typeof cfg.TRUSTED_TYPES_POLICY.createScriptURL !== "function") { + throw typeErrorCreate('TRUSTED_TYPES_POLICY configuration option must provide a "createScriptURL" hook.'); + } + trustedTypesPolicy = cfg.TRUSTED_TYPES_POLICY; + emptyHTML = trustedTypesPolicy.createHTML(""); + } else { + if (trustedTypesPolicy === void 0) { + trustedTypesPolicy = _createTrustedTypesPolicy(trustedTypes, currentScript); + } + if (trustedTypesPolicy !== null && typeof emptyHTML === "string") { + emptyHTML = trustedTypesPolicy.createHTML(""); + } + } + if (freeze) { + freeze(cfg); + } + CONFIG = cfg; + }; + const MATHML_TEXT_INTEGRATION_POINTS = addToSet({}, ["mi", "mo", "mn", "ms", "mtext"]); + const HTML_INTEGRATION_POINTS = addToSet({}, ["foreignobject", "desc", "title", "annotation-xml"]); + const COMMON_SVG_AND_HTML_ELEMENTS = addToSet({}, ["title", "style", "font", "a", "script"]); + const ALL_SVG_TAGS = addToSet({}, [...svg$1, ...svgFilters, ...svgDisallowed]); + const ALL_MATHML_TAGS = addToSet({}, [...mathMl$1, ...mathMlDisallowed]); + const _checkValidNamespace = function _checkValidNamespace2(element2) { + let parent = getParentNode(element2); + if (!parent || !parent.tagName) { + parent = { + namespaceURI: NAMESPACE, + tagName: "template" + }; + } + const tagName = stringToLowerCase(element2.tagName); + const parentTagName = stringToLowerCase(parent.tagName); + if (!ALLOWED_NAMESPACES[element2.namespaceURI]) { + return false; + } + if (element2.namespaceURI === SVG_NAMESPACE) { + if (parent.namespaceURI === HTML_NAMESPACE) { + return tagName === "svg"; + } + if (parent.namespaceURI === MATHML_NAMESPACE) { + return tagName === "svg" && (parentTagName === "annotation-xml" || MATHML_TEXT_INTEGRATION_POINTS[parentTagName]); + } + return Boolean(ALL_SVG_TAGS[tagName]); + } + if (element2.namespaceURI === MATHML_NAMESPACE) { + if (parent.namespaceURI === HTML_NAMESPACE) { + return tagName === "math"; + } + if (parent.namespaceURI === SVG_NAMESPACE) { + return tagName === "math" && HTML_INTEGRATION_POINTS[parentTagName]; + } + return Boolean(ALL_MATHML_TAGS[tagName]); + } + if (element2.namespaceURI === HTML_NAMESPACE) { + if (parent.namespaceURI === SVG_NAMESPACE && !HTML_INTEGRATION_POINTS[parentTagName]) { + return false; + } + if (parent.namespaceURI === MATHML_NAMESPACE && !MATHML_TEXT_INTEGRATION_POINTS[parentTagName]) { + return false; + } + return !ALL_MATHML_TAGS[tagName] && (COMMON_SVG_AND_HTML_ELEMENTS[tagName] || !ALL_SVG_TAGS[tagName]); + } + if (PARSER_MEDIA_TYPE === "application/xhtml+xml" && ALLOWED_NAMESPACES[element2.namespaceURI]) { + return true; + } + return false; + }; + const _forceRemove = function _forceRemove2(node2) { + arrayPush$1(DOMPurify.removed, { + element: node2 + }); + try { + node2.parentNode.removeChild(node2); + } catch (_2) { + node2.remove(); + } + }; + const _removeAttribute = function _removeAttribute2(name, node2) { + try { + arrayPush$1(DOMPurify.removed, { + attribute: node2.getAttributeNode(name), + from: node2 + }); + } catch (_2) { + arrayPush$1(DOMPurify.removed, { + attribute: null, + from: node2 + }); + } + node2.removeAttribute(name); + if (name === "is" && !ALLOWED_ATTR[name]) { + if (RETURN_DOM || RETURN_DOM_FRAGMENT) { + try { + _forceRemove(node2); + } catch (_2) { + } + } else { + try { + node2.setAttribute(name, ""); + } catch (_2) { + } + } + } + }; + const _initDocument = function _initDocument2(dirty) { + let doc = null; + let leadingWhitespace = null; + if (FORCE_BODY) { + dirty = "" + dirty; + } else { + const matches = stringMatch(dirty, /^[\r\n\t ]+/); + leadingWhitespace = matches && matches[0]; + } + if (PARSER_MEDIA_TYPE === "application/xhtml+xml" && NAMESPACE === HTML_NAMESPACE) { + dirty = '' + dirty + ""; + } + const dirtyPayload = trustedTypesPolicy ? trustedTypesPolicy.createHTML(dirty) : dirty; + if (NAMESPACE === HTML_NAMESPACE) { + try { + doc = new DOMParser2().parseFromString(dirtyPayload, PARSER_MEDIA_TYPE); + } catch (_2) { + } + } + if (!doc || !doc.documentElement) { + doc = implementation.createDocument(NAMESPACE, "template", null); + try { + doc.documentElement.innerHTML = IS_EMPTY_INPUT ? emptyHTML : dirtyPayload; + } catch (_2) { + } + } + const body = doc.body || doc.documentElement; + if (dirty && leadingWhitespace) { + body.insertBefore(document2.createTextNode(leadingWhitespace), body.childNodes[0] || null); + } + if (NAMESPACE === HTML_NAMESPACE) { + return getElementsByTagName.call(doc, WHOLE_DOCUMENT ? "html" : "body")[0]; + } + return WHOLE_DOCUMENT ? doc.documentElement : body; + }; + const _createNodeIterator = function _createNodeIterator2(root2) { + return createNodeIterator.call( + root2.ownerDocument || root2, + root2, + // eslint-disable-next-line no-bitwise + NodeFilter.SHOW_ELEMENT | NodeFilter.SHOW_COMMENT | NodeFilter.SHOW_TEXT, + null + ); + }; + const _isClobbered = function _isClobbered2(elm) { + return elm instanceof HTMLFormElement && (typeof elm.nodeName !== "string" || typeof elm.textContent !== "string" || typeof elm.removeChild !== "function" || !(elm.attributes instanceof NamedNodeMap) || typeof elm.removeAttribute !== "function" || typeof elm.setAttribute !== "function" || typeof elm.namespaceURI !== "string" || typeof elm.insertBefore !== "function" || typeof elm.hasChildNodes !== "function"); + }; + const _isNode = function _isNode2(object2) { + return typeof Node === "function" && object2 instanceof Node; + }; + const _executeHook = function _executeHook2(entryPoint, currentNode, data) { + if (!hooks[entryPoint]) { + return; + } + arrayForEach(hooks[entryPoint], (hook) => { + hook.call(DOMPurify, currentNode, data, CONFIG); + }); + }; + const _sanitizeElements = function _sanitizeElements2(currentNode) { + let content2 = null; + _executeHook("beforeSanitizeElements", currentNode, null); + if (_isClobbered(currentNode)) { + _forceRemove(currentNode); + return true; + } + const tagName = transformCaseFunc(currentNode.nodeName); + _executeHook("uponSanitizeElement", currentNode, { + tagName, + allowedTags: ALLOWED_TAGS + }); + if (currentNode.hasChildNodes() && !_isNode(currentNode.firstElementChild) && regExpTest(/<[/\w]/g, currentNode.innerHTML) && regExpTest(/<[/\w]/g, currentNode.textContent)) { + _forceRemove(currentNode); + return true; + } + if (!ALLOWED_TAGS[tagName] || FORBID_TAGS[tagName]) { + if (!FORBID_TAGS[tagName] && _isBasicCustomElement(tagName)) { + if (CUSTOM_ELEMENT_HANDLING.tagNameCheck instanceof RegExp && regExpTest(CUSTOM_ELEMENT_HANDLING.tagNameCheck, tagName)) { + return false; + } + if (CUSTOM_ELEMENT_HANDLING.tagNameCheck instanceof Function && CUSTOM_ELEMENT_HANDLING.tagNameCheck(tagName)) { + return false; + } + } + if (KEEP_CONTENT && !FORBID_CONTENTS[tagName]) { + const parentNode = getParentNode(currentNode) || currentNode.parentNode; + const childNodes = getChildNodes(currentNode) || currentNode.childNodes; + if (childNodes && parentNode) { + const childCount = childNodes.length; + for (let i2 = childCount - 1; i2 >= 0; --i2) { + parentNode.insertBefore(cloneNode(childNodes[i2], true), getNextSibling(currentNode)); + } + } + } + _forceRemove(currentNode); + return true; + } + if (currentNode instanceof Element && !_checkValidNamespace(currentNode)) { + _forceRemove(currentNode); + return true; + } + if ((tagName === "noscript" || tagName === "noembed" || tagName === "noframes") && regExpTest(/<\/no(script|embed|frames)/i, currentNode.innerHTML)) { + _forceRemove(currentNode); + return true; + } + if (SAFE_FOR_TEMPLATES && currentNode.nodeType === 3) { + content2 = currentNode.textContent; + arrayForEach([MUSTACHE_EXPR2, ERB_EXPR2, TMPLIT_EXPR2], (expr) => { + content2 = stringReplace(content2, expr, " "); + }); + if (currentNode.textContent !== content2) { + arrayPush$1(DOMPurify.removed, { + element: currentNode.cloneNode() + }); + currentNode.textContent = content2; + } + } + _executeHook("afterSanitizeElements", currentNode, null); + return false; + }; + const _isValidAttribute = function _isValidAttribute2(lcTag, lcName, value2) { + if (SANITIZE_DOM && (lcName === "id" || lcName === "name") && (value2 in document2 || value2 in formElement)) { + return false; + } + if (ALLOW_DATA_ATTR && !FORBID_ATTR[lcName] && regExpTest(DATA_ATTR2, lcName)) + ; + else if (ALLOW_ARIA_ATTR && regExpTest(ARIA_ATTR2, lcName)) + ; + else if (!ALLOWED_ATTR[lcName] || FORBID_ATTR[lcName]) { + if ( + // First condition does a very basic check if a) it's basically a valid custom element tagname AND + // b) if the tagName passes whatever the user has configured for CUSTOM_ELEMENT_HANDLING.tagNameCheck + // and c) if the attribute name passes whatever the user has configured for CUSTOM_ELEMENT_HANDLING.attributeNameCheck + _isBasicCustomElement(lcTag) && (CUSTOM_ELEMENT_HANDLING.tagNameCheck instanceof RegExp && regExpTest(CUSTOM_ELEMENT_HANDLING.tagNameCheck, lcTag) || CUSTOM_ELEMENT_HANDLING.tagNameCheck instanceof Function && CUSTOM_ELEMENT_HANDLING.tagNameCheck(lcTag)) && (CUSTOM_ELEMENT_HANDLING.attributeNameCheck instanceof RegExp && regExpTest(CUSTOM_ELEMENT_HANDLING.attributeNameCheck, lcName) || CUSTOM_ELEMENT_HANDLING.attributeNameCheck instanceof Function && CUSTOM_ELEMENT_HANDLING.attributeNameCheck(lcName)) || // Alternative, second condition checks if it's an `is`-attribute, AND + // the value passes whatever the user has configured for CUSTOM_ELEMENT_HANDLING.tagNameCheck + lcName === "is" && CUSTOM_ELEMENT_HANDLING.allowCustomizedBuiltInElements && (CUSTOM_ELEMENT_HANDLING.tagNameCheck instanceof RegExp && regExpTest(CUSTOM_ELEMENT_HANDLING.tagNameCheck, value2) || CUSTOM_ELEMENT_HANDLING.tagNameCheck instanceof Function && CUSTOM_ELEMENT_HANDLING.tagNameCheck(value2)) + ) + ; + else { + return false; + } + } else if (URI_SAFE_ATTRIBUTES[lcName]) + ; + else if (regExpTest(IS_ALLOWED_URI$1, stringReplace(value2, ATTR_WHITESPACE2, ""))) + ; + else if ((lcName === "src" || lcName === "xlink:href" || lcName === "href") && lcTag !== "script" && stringIndexOf(value2, "data:") === 0 && DATA_URI_TAGS[lcTag]) + ; + else if (ALLOW_UNKNOWN_PROTOCOLS && !regExpTest(IS_SCRIPT_OR_DATA2, stringReplace(value2, ATTR_WHITESPACE2, ""))) + ; + else if (value2) { + return false; + } else + ; + return true; + }; + const _isBasicCustomElement = function _isBasicCustomElement2(tagName) { + return tagName !== "annotation-xml" && tagName.indexOf("-") > 0; + }; + const _sanitizeAttributes = function _sanitizeAttributes2(currentNode) { + _executeHook("beforeSanitizeAttributes", currentNode, null); + const { + attributes + } = currentNode; + if (!attributes) { + return; + } + const hookEvent = { + attrName: "", + attrValue: "", + keepAttr: true, + allowedAttributes: ALLOWED_ATTR + }; + let l = attributes.length; + while (l--) { + const attr = attributes[l]; + const { + name, + namespaceURI, + value: attrValue + } = attr; + const lcName = transformCaseFunc(name); + let value2 = name === "value" ? attrValue : stringTrim(attrValue); + hookEvent.attrName = lcName; + hookEvent.attrValue = value2; + hookEvent.keepAttr = true; + hookEvent.forceKeepAttr = void 0; + _executeHook("uponSanitizeAttribute", currentNode, hookEvent); + value2 = hookEvent.attrValue; + if (hookEvent.forceKeepAttr) { + continue; + } + _removeAttribute(name, currentNode); + if (!hookEvent.keepAttr) { + continue; + } + if (!ALLOW_SELF_CLOSE_IN_ATTR && regExpTest(/\/>/i, value2)) { + _removeAttribute(name, currentNode); + continue; + } + if (SAFE_FOR_TEMPLATES) { + arrayForEach([MUSTACHE_EXPR2, ERB_EXPR2, TMPLIT_EXPR2], (expr) => { + value2 = stringReplace(value2, expr, " "); + }); + } + const lcTag = transformCaseFunc(currentNode.nodeName); + if (!_isValidAttribute(lcTag, lcName, value2)) { + continue; + } + if (SANITIZE_NAMED_PROPS && (lcName === "id" || lcName === "name")) { + _removeAttribute(name, currentNode); + value2 = SANITIZE_NAMED_PROPS_PREFIX + value2; + } + if (trustedTypesPolicy && typeof trustedTypes === "object" && typeof trustedTypes.getAttributeType === "function") { + if (namespaceURI) + ; + else { + switch (trustedTypes.getAttributeType(lcTag, lcName)) { + case "TrustedHTML": { + value2 = trustedTypesPolicy.createHTML(value2); + break; + } + case "TrustedScriptURL": { + value2 = trustedTypesPolicy.createScriptURL(value2); + break; + } + } + } + } + try { + if (namespaceURI) { + currentNode.setAttributeNS(namespaceURI, name, value2); + } else { + currentNode.setAttribute(name, value2); + } + arrayPop(DOMPurify.removed); + } catch (_2) { + } + } + _executeHook("afterSanitizeAttributes", currentNode, null); + }; + const _sanitizeShadowDOM = function _sanitizeShadowDOM2(fragment) { + let shadowNode = null; + const shadowIterator = _createNodeIterator(fragment); + _executeHook("beforeSanitizeShadowDOM", fragment, null); + while (shadowNode = shadowIterator.nextNode()) { + _executeHook("uponSanitizeShadowNode", shadowNode, null); + if (_sanitizeElements(shadowNode)) { + continue; + } + if (shadowNode.content instanceof DocumentFragment2) { + _sanitizeShadowDOM2(shadowNode.content); + } + _sanitizeAttributes(shadowNode); + } + _executeHook("afterSanitizeShadowDOM", fragment, null); + }; + DOMPurify.sanitize = function(dirty) { + let cfg = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}; + let body = null; + let importedNode = null; + let currentNode = null; + let returnNode = null; + IS_EMPTY_INPUT = !dirty; + if (IS_EMPTY_INPUT) { + dirty = ""; + } + if (typeof dirty !== "string" && !_isNode(dirty)) { + if (typeof dirty.toString === "function") { + dirty = dirty.toString(); + if (typeof dirty !== "string") { + throw typeErrorCreate("dirty is not a string, aborting"); + } + } else { + throw typeErrorCreate("toString is not a function"); + } + } + if (!DOMPurify.isSupported) { + return dirty; + } + if (!SET_CONFIG) { + _parseConfig(cfg); + } + DOMPurify.removed = []; + if (typeof dirty === "string") { + IN_PLACE = false; + } + if (IN_PLACE) { + if (dirty.nodeName) { + const tagName = transformCaseFunc(dirty.nodeName); + if (!ALLOWED_TAGS[tagName] || FORBID_TAGS[tagName]) { + throw typeErrorCreate("root node is forbidden and cannot be sanitized in-place"); + } + } + } else if (dirty instanceof Node) { + body = _initDocument(""); + importedNode = body.ownerDocument.importNode(dirty, true); + if (importedNode.nodeType === 1 && importedNode.nodeName === "BODY") { + body = importedNode; + } else if (importedNode.nodeName === "HTML") { + body = importedNode; + } else { + body.appendChild(importedNode); + } + } else { + if (!RETURN_DOM && !SAFE_FOR_TEMPLATES && !WHOLE_DOCUMENT && // eslint-disable-next-line unicorn/prefer-includes + dirty.indexOf("<") === -1) { + return trustedTypesPolicy && RETURN_TRUSTED_TYPE ? trustedTypesPolicy.createHTML(dirty) : dirty; + } + body = _initDocument(dirty); + if (!body) { + return RETURN_DOM ? null : RETURN_TRUSTED_TYPE ? emptyHTML : ""; + } + } + if (body && FORCE_BODY) { + _forceRemove(body.firstChild); + } + const nodeIterator = _createNodeIterator(IN_PLACE ? dirty : body); + while (currentNode = nodeIterator.nextNode()) { + if (_sanitizeElements(currentNode)) { + continue; + } + if (currentNode.content instanceof DocumentFragment2) { + _sanitizeShadowDOM(currentNode.content); + } + _sanitizeAttributes(currentNode); + } + if (IN_PLACE) { + return dirty; + } + if (RETURN_DOM) { + if (RETURN_DOM_FRAGMENT) { + returnNode = createDocumentFragment.call(body.ownerDocument); + while (body.firstChild) { + returnNode.appendChild(body.firstChild); + } + } else { + returnNode = body; + } + if (ALLOWED_ATTR.shadowroot || ALLOWED_ATTR.shadowrootmode) { + returnNode = importNode.call(originalDocument, returnNode, true); + } + return returnNode; + } + let serializedHTML = WHOLE_DOCUMENT ? body.outerHTML : body.innerHTML; + if (WHOLE_DOCUMENT && ALLOWED_TAGS["!doctype"] && body.ownerDocument && body.ownerDocument.doctype && body.ownerDocument.doctype.name && regExpTest(DOCTYPE_NAME, body.ownerDocument.doctype.name)) { + serializedHTML = "\n" + serializedHTML; + } + if (SAFE_FOR_TEMPLATES) { + arrayForEach([MUSTACHE_EXPR2, ERB_EXPR2, TMPLIT_EXPR2], (expr) => { + serializedHTML = stringReplace(serializedHTML, expr, " "); + }); + } + return trustedTypesPolicy && RETURN_TRUSTED_TYPE ? trustedTypesPolicy.createHTML(serializedHTML) : serializedHTML; + }; + DOMPurify.setConfig = function() { + let cfg = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}; + _parseConfig(cfg); + SET_CONFIG = true; + }; + DOMPurify.clearConfig = function() { + CONFIG = null; + SET_CONFIG = false; + }; + DOMPurify.isValidAttribute = function(tag, attr, value2) { + if (!CONFIG) { + _parseConfig({}); + } + const lcTag = transformCaseFunc(tag); + const lcName = transformCaseFunc(attr); + return _isValidAttribute(lcTag, lcName, value2); + }; + DOMPurify.addHook = function(entryPoint, hookFunction) { + if (typeof hookFunction !== "function") { + return; + } + hooks[entryPoint] = hooks[entryPoint] || []; + arrayPush$1(hooks[entryPoint], hookFunction); + }; + DOMPurify.removeHook = function(entryPoint) { + if (hooks[entryPoint]) { + return arrayPop(hooks[entryPoint]); + } + }; + DOMPurify.removeHooks = function(entryPoint) { + if (hooks[entryPoint]) { + hooks[entryPoint] = []; + } + }; + DOMPurify.removeAllHooks = function() { + hooks = {}; + }; + return DOMPurify; + } + var purify = createDOMPurify(); + const lineBreakRegex = //gi; + const getRows = (s) => { + if (!s) { + return [""]; + } + const str2 = breakToPlaceholder(s).replace(/\\n/g, "#br#"); + return str2.split("#br#"); + }; + const setupDompurifyHooksIfNotSetup = (() => { + let setup = false; + return () => { + if (!setup) { + setupDompurifyHooks(); + setup = true; + } + }; + })(); + function setupDompurifyHooks() { + const TEMPORARY_ATTRIBUTE = "data-temp-href-target"; + purify.addHook("beforeSanitizeAttributes", (node2) => { + if (node2.tagName === "A" && node2.hasAttribute("target")) { + node2.setAttribute(TEMPORARY_ATTRIBUTE, node2.getAttribute("target") || ""); + } + }); + purify.addHook("afterSanitizeAttributes", (node2) => { + if (node2.tagName === "A" && node2.hasAttribute(TEMPORARY_ATTRIBUTE)) { + node2.setAttribute("target", node2.getAttribute(TEMPORARY_ATTRIBUTE) || ""); + node2.removeAttribute(TEMPORARY_ATTRIBUTE); + if (node2.getAttribute("target") === "_blank") { + node2.setAttribute("rel", "noopener"); + } + } + }); + } + const removeScript = (txt) => { + setupDompurifyHooksIfNotSetup(); + const sanitizedText = purify.sanitize(txt); + return sanitizedText; + }; + const sanitizeMore = (text2, config2) => { + var _a2; + if (((_a2 = config2.flowchart) == null ? void 0 : _a2.htmlLabels) !== false) { + const level = config2.securityLevel; + if (level === "antiscript" || level === "strict") { + text2 = removeScript(text2); + } else if (level !== "loose") { + text2 = breakToPlaceholder(text2); + text2 = text2.replace(//g, ">"); + text2 = text2.replace(/=/g, "="); + text2 = placeholderToBreak(text2); + } + } + return text2; + }; + const sanitizeText$6 = (text2, config2) => { + if (!text2) { + return text2; + } + if (config2.dompurifyConfig) { + text2 = purify.sanitize(sanitizeMore(text2, config2), config2.dompurifyConfig).toString(); + } else { + text2 = purify.sanitize(sanitizeMore(text2, config2), { + FORBID_TAGS: ["style"] + }).toString(); + } + return text2; + }; + const sanitizeTextOrArray = (a, config2) => { + if (typeof a === "string") { + return sanitizeText$6(a, config2); + } + return a.flat().map((x2) => sanitizeText$6(x2, config2)); + }; + const hasBreaks = (text2) => { + return lineBreakRegex.test(text2); + }; + const splitBreaks = (text2) => { + return text2.split(lineBreakRegex); + }; + const placeholderToBreak = (s) => { + return s.replace(/#br#/g, "
    "); + }; + const breakToPlaceholder = (s) => { + return s.replace(lineBreakRegex, "#br#"); + }; + const getUrl = (useAbsolute) => { + let url = ""; + if (useAbsolute) { + url = window.location.protocol + "//" + window.location.host + window.location.pathname + window.location.search; + url = url.replaceAll(/\(/g, "\\("); + url = url.replaceAll(/\)/g, "\\)"); + } + return url; + }; + const evaluate = (val) => val === false || ["false", "null", "0"].includes(String(val).trim().toLowerCase()) ? false : true; + const getMax = function(...values2) { + const newValues = values2.filter((value2) => { + return !isNaN(value2); + }); + return Math.max(...newValues); + }; + const getMin = function(...values2) { + const newValues = values2.filter((value2) => { + return !isNaN(value2); + }); + return Math.min(...newValues); + }; + const parseGenericTypes = function(input) { + const inputSets = input.split(/(,)/); + const output = []; + for (let i2 = 0; i2 < inputSets.length; i2++) { + let thisSet = inputSets[i2]; + if (thisSet === "," && i2 > 0 && i2 + 1 < inputSets.length) { + const previousSet = inputSets[i2 - 1]; + const nextSet = inputSets[i2 + 1]; + if (shouldCombineSets(previousSet, nextSet)) { + thisSet = previousSet + "," + nextSet; + i2++; + output.pop(); + } + } + output.push(processSet(thisSet)); + } + return output.join(""); + }; + const countOccurrence = (string2, substring) => { + return Math.max(0, string2.split(substring).length - 1); + }; + const shouldCombineSets = (previousSet, nextSet) => { + const prevCount = countOccurrence(previousSet, "~"); + const nextCount = countOccurrence(nextSet, "~"); + return prevCount === 1 && nextCount === 1; + }; + const processSet = (input) => { + const tildeCount = countOccurrence(input, "~"); + let hasStartingTilde = false; + if (tildeCount <= 1) { + return input; + } + if (tildeCount % 2 !== 0 && input.startsWith("~")) { + input = input.substring(1); + hasStartingTilde = true; + } + const chars = [...input]; + let first = chars.indexOf("~"); + let last2 = chars.lastIndexOf("~"); + while (first !== -1 && last2 !== -1 && first !== last2) { + chars[first] = "<"; + chars[last2] = ">"; + first = chars.indexOf("~"); + last2 = chars.lastIndexOf("~"); + } + if (hasStartingTilde) { + chars.unshift("~"); + } + return chars.join(""); + }; + const isMathMLSupported = () => window.MathMLElement !== void 0; + const katexRegex = /\$\$(.*)\$\$/g; + const hasKatex = (text2) => { + var _a2; + return (((_a2 = text2.match(katexRegex)) == null ? void 0 : _a2.length) ?? 0) > 0; + }; + const calculateMathMLDimensions = async (text2, config2) => { + text2 = await renderKatex(text2, config2); + const divElem = document.createElement("div"); + divElem.innerHTML = text2; + divElem.id = "katex-temp"; + divElem.style.visibility = "hidden"; + divElem.style.position = "absolute"; + divElem.style.top = "0"; + const body = document.querySelector("body"); + body == null ? void 0 : body.insertAdjacentElement("beforeend", divElem); + const dim = { width: divElem.clientWidth, height: divElem.clientHeight }; + divElem.remove(); + return dim; + }; + const renderKatex = async (text2, config2) => { + if (!hasKatex(text2)) { + return text2; + } + if (!isMathMLSupported() && !config2.legacyMathML) { + return text2.replace(katexRegex, "MathML is unsupported in this environment."); + } + const { default: katex2 } = await Promise.resolve().then(() => katex$1); + return text2.split(lineBreakRegex).map( + (line2) => hasKatex(line2) ? ` +
    + ${line2} +
    + ` : `
    ${line2}
    ` + ).join("").replace( + katexRegex, + (_2, c2) => katex2.renderToString(c2, { + throwOnError: true, + displayMode: true, + output: isMathMLSupported() ? "mathml" : "htmlAndMathml" + }).replace(/\n/g, " ").replace(//g, "") + ); + }; + const common$1 = { + getRows, + sanitizeText: sanitizeText$6, + sanitizeTextOrArray, + hasBreaks, + splitBreaks, + lineBreakRegex, + removeScript, + getUrl, + evaluate, + getMax, + getMin + }; + const Channel = { + /* CLAMP */ + min: { + r: 0, + g: 0, + b: 0, + s: 0, + l: 0, + a: 0 + }, + max: { + r: 255, + g: 255, + b: 255, + h: 360, + s: 100, + l: 100, + a: 1 + }, + clamp: { + r: (r) => r >= 255 ? 255 : r < 0 ? 0 : r, + g: (g) => g >= 255 ? 255 : g < 0 ? 0 : g, + b: (b) => b >= 255 ? 255 : b < 0 ? 0 : b, + h: (h) => h % 360, + s: (s) => s >= 100 ? 100 : s < 0 ? 0 : s, + l: (l) => l >= 100 ? 100 : l < 0 ? 0 : l, + a: (a) => a >= 1 ? 1 : a < 0 ? 0 : a + }, + /* CONVERSION */ + //SOURCE: https://planetcalc.com/7779 + toLinear: (c2) => { + const n = c2 / 255; + return c2 > 0.03928 ? Math.pow((n + 0.055) / 1.055, 2.4) : n / 12.92; + }, + //SOURCE: https://gist.github.com/mjackson/5311256 + hue2rgb: (p, q, t) => { + if (t < 0) + t += 1; + if (t > 1) + t -= 1; + if (t < 1 / 6) + return p + (q - p) * 6 * t; + if (t < 1 / 2) + return q; + if (t < 2 / 3) + return p + (q - p) * (2 / 3 - t) * 6; + return p; + }, + hsl2rgb: ({ h, s, l }, channel2) => { + if (!s) + return l * 2.55; + h /= 360; + s /= 100; + l /= 100; + const q = l < 0.5 ? l * (1 + s) : l + s - l * s; + const p = 2 * l - q; + switch (channel2) { + case "r": + return Channel.hue2rgb(p, q, h + 1 / 3) * 255; + case "g": + return Channel.hue2rgb(p, q, h) * 255; + case "b": + return Channel.hue2rgb(p, q, h - 1 / 3) * 255; + } + }, + rgb2hsl: ({ r, g, b }, channel2) => { + r /= 255; + g /= 255; + b /= 255; + const max2 = Math.max(r, g, b); + const min2 = Math.min(r, g, b); + const l = (max2 + min2) / 2; + if (channel2 === "l") + return l * 100; + if (max2 === min2) + return 0; + const d = max2 - min2; + const s = l > 0.5 ? d / (2 - max2 - min2) : d / (max2 + min2); + if (channel2 === "s") + return s * 100; + switch (max2) { + case r: + return ((g - b) / d + (g < b ? 6 : 0)) * 60; + case g: + return ((b - r) / d + 2) * 60; + case b: + return ((r - g) / d + 4) * 60; + default: + return -1; + } + } + }; + const channel$2 = Channel; + const Lang = { + /* API */ + clamp: (number2, lower2, upper) => { + if (lower2 > upper) + return Math.min(lower2, Math.max(upper, number2)); + return Math.min(upper, Math.max(lower2, number2)); + }, + round: (number2) => { + return Math.round(number2 * 1e10) / 1e10; + } + }; + const lang = Lang; + const Unit = { + /* API */ + dec2hex: (dec) => { + const hex2 = Math.round(dec).toString(16); + return hex2.length > 1 ? hex2 : `0${hex2}`; + } + }; + const unit = Unit; + const Utils = { + channel: channel$2, + lang, + unit + }; + const _ = Utils; + const DEC2HEX = {}; + for (let i2 = 0; i2 <= 255; i2++) + DEC2HEX[i2] = _.unit.dec2hex(i2); + const TYPE = { + ALL: 0, + RGB: 1, + HSL: 2 + }; + class Type { + constructor() { + this.type = TYPE.ALL; + } + /* API */ + get() { + return this.type; + } + set(type2) { + if (this.type && this.type !== type2) + throw new Error("Cannot change both RGB and HSL channels at the same time"); + this.type = type2; + } + reset() { + this.type = TYPE.ALL; + } + is(type2) { + return this.type === type2; + } + } + const Type$2 = Type; + class Channels { + /* CONSTRUCTOR */ + constructor(data, color2) { + this.color = color2; + this.changed = false; + this.data = data; + this.type = new Type$2(); + } + /* API */ + set(data, color2) { + this.color = color2; + this.changed = false; + this.data = data; + this.type.type = TYPE.ALL; + return this; + } + /* HELPERS */ + _ensureHSL() { + const data = this.data; + const { h, s, l } = data; + if (h === void 0) + data.h = _.channel.rgb2hsl(data, "h"); + if (s === void 0) + data.s = _.channel.rgb2hsl(data, "s"); + if (l === void 0) + data.l = _.channel.rgb2hsl(data, "l"); + } + _ensureRGB() { + const data = this.data; + const { r, g, b } = data; + if (r === void 0) + data.r = _.channel.hsl2rgb(data, "r"); + if (g === void 0) + data.g = _.channel.hsl2rgb(data, "g"); + if (b === void 0) + data.b = _.channel.hsl2rgb(data, "b"); + } + /* GETTERS */ + get r() { + const data = this.data; + const r = data.r; + if (!this.type.is(TYPE.HSL) && r !== void 0) + return r; + this._ensureHSL(); + return _.channel.hsl2rgb(data, "r"); + } + get g() { + const data = this.data; + const g = data.g; + if (!this.type.is(TYPE.HSL) && g !== void 0) + return g; + this._ensureHSL(); + return _.channel.hsl2rgb(data, "g"); + } + get b() { + const data = this.data; + const b = data.b; + if (!this.type.is(TYPE.HSL) && b !== void 0) + return b; + this._ensureHSL(); + return _.channel.hsl2rgb(data, "b"); + } + get h() { + const data = this.data; + const h = data.h; + if (!this.type.is(TYPE.RGB) && h !== void 0) + return h; + this._ensureRGB(); + return _.channel.rgb2hsl(data, "h"); + } + get s() { + const data = this.data; + const s = data.s; + if (!this.type.is(TYPE.RGB) && s !== void 0) + return s; + this._ensureRGB(); + return _.channel.rgb2hsl(data, "s"); + } + get l() { + const data = this.data; + const l = data.l; + if (!this.type.is(TYPE.RGB) && l !== void 0) + return l; + this._ensureRGB(); + return _.channel.rgb2hsl(data, "l"); + } + get a() { + return this.data.a; + } + /* SETTERS */ + set r(r) { + this.type.set(TYPE.RGB); + this.changed = true; + this.data.r = r; + } + set g(g) { + this.type.set(TYPE.RGB); + this.changed = true; + this.data.g = g; + } + set b(b) { + this.type.set(TYPE.RGB); + this.changed = true; + this.data.b = b; + } + set h(h) { + this.type.set(TYPE.HSL); + this.changed = true; + this.data.h = h; + } + set s(s) { + this.type.set(TYPE.HSL); + this.changed = true; + this.data.s = s; + } + set l(l) { + this.type.set(TYPE.HSL); + this.changed = true; + this.data.l = l; + } + set a(a) { + this.changed = true; + this.data.a = a; + } + } + const Channels$1 = Channels; + const channels = new Channels$1({ r: 0, g: 0, b: 0, a: 0 }, "transparent"); + const ChannelsReusable = channels; + const Hex = { + /* VARIABLES */ + re: /^#((?:[a-f0-9]{2}){2,4}|[a-f0-9]{3})$/i, + /* API */ + parse: (color2) => { + if (color2.charCodeAt(0) !== 35) + return; + const match = color2.match(Hex.re); + if (!match) + return; + const hex2 = match[1]; + const dec = parseInt(hex2, 16); + const length2 = hex2.length; + const hasAlpha = length2 % 4 === 0; + const isFullLength = length2 > 4; + const multiplier = isFullLength ? 1 : 17; + const bits = isFullLength ? 8 : 4; + const bitsOffset = hasAlpha ? 0 : -1; + const mask = isFullLength ? 255 : 15; + return ChannelsReusable.set({ + r: (dec >> bits * (bitsOffset + 3) & mask) * multiplier, + g: (dec >> bits * (bitsOffset + 2) & mask) * multiplier, + b: (dec >> bits * (bitsOffset + 1) & mask) * multiplier, + a: hasAlpha ? (dec & mask) * multiplier / 255 : 1 + }, color2); + }, + stringify: (channels2) => { + const { r, g, b, a } = channels2; + if (a < 1) { + return `#${DEC2HEX[Math.round(r)]}${DEC2HEX[Math.round(g)]}${DEC2HEX[Math.round(b)]}${DEC2HEX[Math.round(a * 255)]}`; + } else { + return `#${DEC2HEX[Math.round(r)]}${DEC2HEX[Math.round(g)]}${DEC2HEX[Math.round(b)]}`; + } + } + }; + const Hex$1 = Hex; + const HSL = { + /* VARIABLES */ + re: /^hsla?\(\s*?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e-?\d+)?(?:deg|grad|rad|turn)?)\s*?(?:,|\s)\s*?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e-?\d+)?%)\s*?(?:,|\s)\s*?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e-?\d+)?%)(?:\s*?(?:,|\/)\s*?\+?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e-?\d+)?(%)?))?\s*?\)$/i, + hueRe: /^(.+?)(deg|grad|rad|turn)$/i, + /* HELPERS */ + _hue2deg: (hue2) => { + const match = hue2.match(HSL.hueRe); + if (match) { + const [, number2, unit2] = match; + switch (unit2) { + case "grad": + return _.channel.clamp.h(parseFloat(number2) * 0.9); + case "rad": + return _.channel.clamp.h(parseFloat(number2) * 180 / Math.PI); + case "turn": + return _.channel.clamp.h(parseFloat(number2) * 360); + } + } + return _.channel.clamp.h(parseFloat(hue2)); + }, + /* API */ + parse: (color2) => { + const charCode = color2.charCodeAt(0); + if (charCode !== 104 && charCode !== 72) + return; + const match = color2.match(HSL.re); + if (!match) + return; + const [, h, s, l, a, isAlphaPercentage] = match; + return ChannelsReusable.set({ + h: HSL._hue2deg(h), + s: _.channel.clamp.s(parseFloat(s)), + l: _.channel.clamp.l(parseFloat(l)), + a: a ? _.channel.clamp.a(isAlphaPercentage ? parseFloat(a) / 100 : parseFloat(a)) : 1 + }, color2); + }, + stringify: (channels2) => { + const { h, s, l, a } = channels2; + if (a < 1) { + return `hsla(${_.lang.round(h)}, ${_.lang.round(s)}%, ${_.lang.round(l)}%, ${a})`; + } else { + return `hsl(${_.lang.round(h)}, ${_.lang.round(s)}%, ${_.lang.round(l)}%)`; + } + } + }; + const HSL$1 = HSL; + const Keyword = { + /* VARIABLES */ + colors: { + aliceblue: "#f0f8ff", + antiquewhite: "#faebd7", + aqua: "#00ffff", + aquamarine: "#7fffd4", + azure: "#f0ffff", + beige: "#f5f5dc", + bisque: "#ffe4c4", + black: "#000000", + blanchedalmond: "#ffebcd", + blue: "#0000ff", + blueviolet: "#8a2be2", + brown: "#a52a2a", + burlywood: "#deb887", + cadetblue: "#5f9ea0", + chartreuse: "#7fff00", + chocolate: "#d2691e", + coral: "#ff7f50", + cornflowerblue: "#6495ed", + cornsilk: "#fff8dc", + crimson: "#dc143c", + cyanaqua: "#00ffff", + darkblue: "#00008b", + darkcyan: "#008b8b", + darkgoldenrod: "#b8860b", + darkgray: "#a9a9a9", + darkgreen: "#006400", + darkgrey: "#a9a9a9", + darkkhaki: "#bdb76b", + darkmagenta: "#8b008b", + darkolivegreen: "#556b2f", + darkorange: "#ff8c00", + darkorchid: "#9932cc", + darkred: "#8b0000", + darksalmon: "#e9967a", + darkseagreen: "#8fbc8f", + darkslateblue: "#483d8b", + darkslategray: "#2f4f4f", + darkslategrey: "#2f4f4f", + darkturquoise: "#00ced1", + darkviolet: "#9400d3", + deeppink: "#ff1493", + deepskyblue: "#00bfff", + dimgray: "#696969", + dimgrey: "#696969", + dodgerblue: "#1e90ff", + firebrick: "#b22222", + floralwhite: "#fffaf0", + forestgreen: "#228b22", + fuchsia: "#ff00ff", + gainsboro: "#dcdcdc", + ghostwhite: "#f8f8ff", + gold: "#ffd700", + goldenrod: "#daa520", + gray: "#808080", + green: "#008000", + greenyellow: "#adff2f", + grey: "#808080", + honeydew: "#f0fff0", + hotpink: "#ff69b4", + indianred: "#cd5c5c", + indigo: "#4b0082", + ivory: "#fffff0", + khaki: "#f0e68c", + lavender: "#e6e6fa", + lavenderblush: "#fff0f5", + lawngreen: "#7cfc00", + lemonchiffon: "#fffacd", + lightblue: "#add8e6", + lightcoral: "#f08080", + lightcyan: "#e0ffff", + lightgoldenrodyellow: "#fafad2", + lightgray: "#d3d3d3", + lightgreen: "#90ee90", + lightgrey: "#d3d3d3", + lightpink: "#ffb6c1", + lightsalmon: "#ffa07a", + lightseagreen: "#20b2aa", + lightskyblue: "#87cefa", + lightslategray: "#778899", + lightslategrey: "#778899", + lightsteelblue: "#b0c4de", + lightyellow: "#ffffe0", + lime: "#00ff00", + limegreen: "#32cd32", + linen: "#faf0e6", + magenta: "#ff00ff", + maroon: "#800000", + mediumaquamarine: "#66cdaa", + mediumblue: "#0000cd", + mediumorchid: "#ba55d3", + mediumpurple: "#9370db", + mediumseagreen: "#3cb371", + mediumslateblue: "#7b68ee", + mediumspringgreen: "#00fa9a", + mediumturquoise: "#48d1cc", + mediumvioletred: "#c71585", + midnightblue: "#191970", + mintcream: "#f5fffa", + mistyrose: "#ffe4e1", + moccasin: "#ffe4b5", + navajowhite: "#ffdead", + navy: "#000080", + oldlace: "#fdf5e6", + olive: "#808000", + olivedrab: "#6b8e23", + orange: "#ffa500", + orangered: "#ff4500", + orchid: "#da70d6", + palegoldenrod: "#eee8aa", + palegreen: "#98fb98", + paleturquoise: "#afeeee", + palevioletred: "#db7093", + papayawhip: "#ffefd5", + peachpuff: "#ffdab9", + peru: "#cd853f", + pink: "#ffc0cb", + plum: "#dda0dd", + powderblue: "#b0e0e6", + purple: "#800080", + rebeccapurple: "#663399", + red: "#ff0000", + rosybrown: "#bc8f8f", + royalblue: "#4169e1", + saddlebrown: "#8b4513", + salmon: "#fa8072", + sandybrown: "#f4a460", + seagreen: "#2e8b57", + seashell: "#fff5ee", + sienna: "#a0522d", + silver: "#c0c0c0", + skyblue: "#87ceeb", + slateblue: "#6a5acd", + slategray: "#708090", + slategrey: "#708090", + snow: "#fffafa", + springgreen: "#00ff7f", + tan: "#d2b48c", + teal: "#008080", + thistle: "#d8bfd8", + transparent: "#00000000", + turquoise: "#40e0d0", + violet: "#ee82ee", + wheat: "#f5deb3", + white: "#ffffff", + whitesmoke: "#f5f5f5", + yellow: "#ffff00", + yellowgreen: "#9acd32" + }, + /* API */ + parse: (color2) => { + color2 = color2.toLowerCase(); + const hex2 = Keyword.colors[color2]; + if (!hex2) + return; + return Hex$1.parse(hex2); + }, + stringify: (channels2) => { + const hex2 = Hex$1.stringify(channels2); + for (const name in Keyword.colors) { + if (Keyword.colors[name] === hex2) + return name; + } + return; + } + }; + const Keyword$1 = Keyword; + const RGB = { + /* VARIABLES */ + re: /^rgba?\(\s*?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e\d+)?(%?))\s*?(?:,|\s)\s*?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e\d+)?(%?))\s*?(?:,|\s)\s*?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e\d+)?(%?))(?:\s*?(?:,|\/)\s*?\+?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e\d+)?(%?)))?\s*?\)$/i, + /* API */ + parse: (color2) => { + const charCode = color2.charCodeAt(0); + if (charCode !== 114 && charCode !== 82) + return; + const match = color2.match(RGB.re); + if (!match) + return; + const [, r, isRedPercentage, g, isGreenPercentage, b, isBluePercentage, a, isAlphaPercentage] = match; + return ChannelsReusable.set({ + r: _.channel.clamp.r(isRedPercentage ? parseFloat(r) * 2.55 : parseFloat(r)), + g: _.channel.clamp.g(isGreenPercentage ? parseFloat(g) * 2.55 : parseFloat(g)), + b: _.channel.clamp.b(isBluePercentage ? parseFloat(b) * 2.55 : parseFloat(b)), + a: a ? _.channel.clamp.a(isAlphaPercentage ? parseFloat(a) / 100 : parseFloat(a)) : 1 + }, color2); + }, + stringify: (channels2) => { + const { r, g, b, a } = channels2; + if (a < 1) { + return `rgba(${_.lang.round(r)}, ${_.lang.round(g)}, ${_.lang.round(b)}, ${_.lang.round(a)})`; + } else { + return `rgb(${_.lang.round(r)}, ${_.lang.round(g)}, ${_.lang.round(b)})`; + } + } + }; + const RGB$1 = RGB; + const Color = { + /* VARIABLES */ + format: { + keyword: Keyword$1, + hex: Hex$1, + rgb: RGB$1, + rgba: RGB$1, + hsl: HSL$1, + hsla: HSL$1 + }, + /* API */ + parse: (color2) => { + if (typeof color2 !== "string") + return color2; + const channels2 = Hex$1.parse(color2) || RGB$1.parse(color2) || HSL$1.parse(color2) || Keyword$1.parse(color2); + if (channels2) + return channels2; + throw new Error(`Unsupported color format: "${color2}"`); + }, + stringify: (channels2) => { + if (!channels2.changed && channels2.color) + return channels2.color; + if (channels2.type.is(TYPE.HSL) || channels2.data.r === void 0) { + return HSL$1.stringify(channels2); + } else if (channels2.a < 1 || !Number.isInteger(channels2.r) || !Number.isInteger(channels2.g) || !Number.isInteger(channels2.b)) { + return RGB$1.stringify(channels2); + } else { + return Hex$1.stringify(channels2); + } + } + }; + const Color$1 = Color; + const change = (color2, channels2) => { + const ch2 = Color$1.parse(color2); + for (const c2 in channels2) { + ch2[c2] = _.channel.clamp[c2](channels2[c2]); + } + return Color$1.stringify(ch2); + }; + const change$1 = change; + const rgba = (r, g, b = 0, a = 1) => { + if (typeof r !== "number") + return change$1(r, { a: g }); + const channels2 = ChannelsReusable.set({ + r: _.channel.clamp.r(r), + g: _.channel.clamp.g(g), + b: _.channel.clamp.b(b), + a: _.channel.clamp.a(a) + }); + return Color$1.stringify(channels2); + }; + const rgba$1 = rgba; + const channel = (color2, channel2) => { + return _.lang.round(Color$1.parse(color2)[channel2]); + }; + const channel$1 = channel; + const luminance = (color2) => { + const { r, g, b } = Color$1.parse(color2); + const luminance2 = 0.2126 * _.channel.toLinear(r) + 0.7152 * _.channel.toLinear(g) + 0.0722 * _.channel.toLinear(b); + return _.lang.round(luminance2); + }; + const luminance$1 = luminance; + const isLight = (color2) => { + return luminance$1(color2) >= 0.5; + }; + const isLight$1 = isLight; + const isDark = (color2) => { + return !isLight$1(color2); + }; + const isDark$1 = isDark; + const adjustChannel = (color2, channel2, amount) => { + const channels2 = Color$1.parse(color2); + const amountCurrent = channels2[channel2]; + const amountNext = _.channel.clamp[channel2](amountCurrent + amount); + if (amountCurrent !== amountNext) + channels2[channel2] = amountNext; + return Color$1.stringify(channels2); + }; + const adjustChannel$1 = adjustChannel; + const lighten = (color2, amount) => { + return adjustChannel$1(color2, "l", amount); + }; + const lighten$1 = lighten; + const darken = (color2, amount) => { + return adjustChannel$1(color2, "l", -amount); + }; + const darken$1 = darken; + const adjust$1 = (color2, channels2) => { + const ch2 = Color$1.parse(color2); + const changes = {}; + for (const c2 in channels2) { + if (!channels2[c2]) + continue; + changes[c2] = ch2[c2] + channels2[c2]; + } + return change$1(color2, changes); + }; + const adjust$2 = adjust$1; + const mix = (color1, color2, weight = 50) => { + const { r: r1, g: g1, b: b1, a: a1 } = Color$1.parse(color1); + const { r: r2, g: g2, b: b2, a: a2 } = Color$1.parse(color2); + const weightScale = weight / 100; + const weightNormalized = weightScale * 2 - 1; + const alphaDelta = a1 - a2; + const weight1combined = weightNormalized * alphaDelta === -1 ? weightNormalized : (weightNormalized + alphaDelta) / (1 + weightNormalized * alphaDelta); + const weight1 = (weight1combined + 1) / 2; + const weight2 = 1 - weight1; + const r = r1 * weight1 + r2 * weight2; + const g = g1 * weight1 + g2 * weight2; + const b = b1 * weight1 + b2 * weight2; + const a = a1 * weightScale + a2 * (1 - weightScale); + return rgba$1(r, g, b, a); + }; + const mix$1 = mix; + const invert = (color2, weight = 100) => { + const inverse = Color$1.parse(color2); + inverse.r = 255 - inverse.r; + inverse.g = 255 - inverse.g; + inverse.b = 255 - inverse.b; + return mix$1(inverse, color2, weight); + }; + const invert$1 = invert; + const mkBorder = (col, darkMode) => darkMode ? adjust$2(col, { s: -40, l: 10 }) : adjust$2(col, { s: -40, l: -10 }); + const oldAttributeBackgroundColorOdd = "#ffffff"; + const oldAttributeBackgroundColorEven = "#f2f2f2"; + let Theme$4 = class Theme { + constructor() { + this.background = "#f4f4f4"; + this.primaryColor = "#fff4dd"; + this.noteBkgColor = "#fff5ad"; + this.noteTextColor = "#333"; + this.THEME_COLOR_LIMIT = 12; + this.fontFamily = '"trebuchet ms", verdana, arial, sans-serif'; + this.fontSize = "16px"; + } + updateColors() { + var _a2, _b2, _c, _d, _e, _f, _g, _h, _i6, _j, _k; + this.primaryTextColor = this.primaryTextColor || (this.darkMode ? "#eee" : "#333"); + this.secondaryColor = this.secondaryColor || adjust$2(this.primaryColor, { h: -120 }); + this.tertiaryColor = this.tertiaryColor || adjust$2(this.primaryColor, { h: 180, l: 5 }); + this.primaryBorderColor = this.primaryBorderColor || mkBorder(this.primaryColor, this.darkMode); + this.secondaryBorderColor = this.secondaryBorderColor || mkBorder(this.secondaryColor, this.darkMode); + this.tertiaryBorderColor = this.tertiaryBorderColor || mkBorder(this.tertiaryColor, this.darkMode); + this.noteBorderColor = this.noteBorderColor || mkBorder(this.noteBkgColor, this.darkMode); + this.noteBkgColor = this.noteBkgColor || "#fff5ad"; + this.noteTextColor = this.noteTextColor || "#333"; + this.secondaryTextColor = this.secondaryTextColor || invert$1(this.secondaryColor); + this.tertiaryTextColor = this.tertiaryTextColor || invert$1(this.tertiaryColor); + this.lineColor = this.lineColor || invert$1(this.background); + this.arrowheadColor = this.arrowheadColor || invert$1(this.background); + this.textColor = this.textColor || this.primaryTextColor; + this.border2 = this.border2 || this.tertiaryBorderColor; + this.nodeBkg = this.nodeBkg || this.primaryColor; + this.mainBkg = this.mainBkg || this.primaryColor; + this.nodeBorder = this.nodeBorder || this.primaryBorderColor; + this.clusterBkg = this.clusterBkg || this.tertiaryColor; + this.clusterBorder = this.clusterBorder || this.tertiaryBorderColor; + this.defaultLinkColor = this.defaultLinkColor || this.lineColor; + this.titleColor = this.titleColor || this.tertiaryTextColor; + this.edgeLabelBackground = this.edgeLabelBackground || (this.darkMode ? darken$1(this.secondaryColor, 30) : this.secondaryColor); + this.nodeTextColor = this.nodeTextColor || this.primaryTextColor; + this.actorBorder = this.actorBorder || this.primaryBorderColor; + this.actorBkg = this.actorBkg || this.mainBkg; + this.actorTextColor = this.actorTextColor || this.primaryTextColor; + this.actorLineColor = this.actorLineColor || "grey"; + this.labelBoxBkgColor = this.labelBoxBkgColor || this.actorBkg; + this.signalColor = this.signalColor || this.textColor; + this.signalTextColor = this.signalTextColor || this.textColor; + this.labelBoxBorderColor = this.labelBoxBorderColor || this.actorBorder; + this.labelTextColor = this.labelTextColor || this.actorTextColor; + this.loopTextColor = this.loopTextColor || this.actorTextColor; + this.activationBorderColor = this.activationBorderColor || darken$1(this.secondaryColor, 10); + this.activationBkgColor = this.activationBkgColor || this.secondaryColor; + this.sequenceNumberColor = this.sequenceNumberColor || invert$1(this.lineColor); + this.sectionBkgColor = this.sectionBkgColor || this.tertiaryColor; + this.altSectionBkgColor = this.altSectionBkgColor || "white"; + this.sectionBkgColor = this.sectionBkgColor || this.secondaryColor; + this.sectionBkgColor2 = this.sectionBkgColor2 || this.primaryColor; + this.excludeBkgColor = this.excludeBkgColor || "#eeeeee"; + this.taskBorderColor = this.taskBorderColor || this.primaryBorderColor; + this.taskBkgColor = this.taskBkgColor || this.primaryColor; + this.activeTaskBorderColor = this.activeTaskBorderColor || this.primaryColor; + this.activeTaskBkgColor = this.activeTaskBkgColor || lighten$1(this.primaryColor, 23); + this.gridColor = this.gridColor || "lightgrey"; + this.doneTaskBkgColor = this.doneTaskBkgColor || "lightgrey"; + this.doneTaskBorderColor = this.doneTaskBorderColor || "grey"; + this.critBorderColor = this.critBorderColor || "#ff8888"; + this.critBkgColor = this.critBkgColor || "red"; + this.todayLineColor = this.todayLineColor || "red"; + this.taskTextColor = this.taskTextColor || this.textColor; + this.taskTextOutsideColor = this.taskTextOutsideColor || this.textColor; + this.taskTextLightColor = this.taskTextLightColor || this.textColor; + this.taskTextColor = this.taskTextColor || this.primaryTextColor; + this.taskTextDarkColor = this.taskTextDarkColor || this.textColor; + this.taskTextClickableColor = this.taskTextClickableColor || "#003163"; + this.personBorder = this.personBorder || this.primaryBorderColor; + this.personBkg = this.personBkg || this.mainBkg; + this.transitionColor = this.transitionColor || this.lineColor; + this.transitionLabelColor = this.transitionLabelColor || this.textColor; + this.stateLabelColor = this.stateLabelColor || this.stateBkg || this.primaryTextColor; + this.stateBkg = this.stateBkg || this.mainBkg; + this.labelBackgroundColor = this.labelBackgroundColor || this.stateBkg; + this.compositeBackground = this.compositeBackground || this.background || this.tertiaryColor; + this.altBackground = this.altBackground || this.tertiaryColor; + this.compositeTitleBackground = this.compositeTitleBackground || this.mainBkg; + this.compositeBorder = this.compositeBorder || this.nodeBorder; + this.innerEndBackground = this.nodeBorder; + this.errorBkgColor = this.errorBkgColor || this.tertiaryColor; + this.errorTextColor = this.errorTextColor || this.tertiaryTextColor; + this.transitionColor = this.transitionColor || this.lineColor; + this.specialStateColor = this.lineColor; + this.cScale0 = this.cScale0 || this.primaryColor; + this.cScale1 = this.cScale1 || this.secondaryColor; + this.cScale2 = this.cScale2 || this.tertiaryColor; + this.cScale3 = this.cScale3 || adjust$2(this.primaryColor, { h: 30 }); + this.cScale4 = this.cScale4 || adjust$2(this.primaryColor, { h: 60 }); + this.cScale5 = this.cScale5 || adjust$2(this.primaryColor, { h: 90 }); + this.cScale6 = this.cScale6 || adjust$2(this.primaryColor, { h: 120 }); + this.cScale7 = this.cScale7 || adjust$2(this.primaryColor, { h: 150 }); + this.cScale8 = this.cScale8 || adjust$2(this.primaryColor, { h: 210, l: 150 }); + this.cScale9 = this.cScale9 || adjust$2(this.primaryColor, { h: 270 }); + this.cScale10 = this.cScale10 || adjust$2(this.primaryColor, { h: 300 }); + this.cScale11 = this.cScale11 || adjust$2(this.primaryColor, { h: 330 }); + if (this.darkMode) { + for (let i2 = 0; i2 < this.THEME_COLOR_LIMIT; i2++) { + this["cScale" + i2] = darken$1(this["cScale" + i2], 75); + } + } else { + for (let i2 = 0; i2 < this.THEME_COLOR_LIMIT; i2++) { + this["cScale" + i2] = darken$1(this["cScale" + i2], 25); + } + } + for (let i2 = 0; i2 < this.THEME_COLOR_LIMIT; i2++) { + this["cScaleInv" + i2] = this["cScaleInv" + i2] || invert$1(this["cScale" + i2]); + } + for (let i2 = 0; i2 < this.THEME_COLOR_LIMIT; i2++) { + if (this.darkMode) { + this["cScalePeer" + i2] = this["cScalePeer" + i2] || lighten$1(this["cScale" + i2], 10); + } else { + this["cScalePeer" + i2] = this["cScalePeer" + i2] || darken$1(this["cScale" + i2], 10); + } + } + this.scaleLabelColor = this.scaleLabelColor || this.labelTextColor; + for (let i2 = 0; i2 < this.THEME_COLOR_LIMIT; i2++) { + this["cScaleLabel" + i2] = this["cScaleLabel" + i2] || this.scaleLabelColor; + } + const multiplier = this.darkMode ? -4 : -1; + for (let i2 = 0; i2 < 5; i2++) { + this["surface" + i2] = this["surface" + i2] || adjust$2(this.mainBkg, { h: 180, s: -15, l: multiplier * (5 + i2 * 3) }); + this["surfacePeer" + i2] = this["surfacePeer" + i2] || adjust$2(this.mainBkg, { h: 180, s: -15, l: multiplier * (8 + i2 * 3) }); + } + this.classText = this.classText || this.textColor; + this.fillType0 = this.fillType0 || this.primaryColor; + this.fillType1 = this.fillType1 || this.secondaryColor; + this.fillType2 = this.fillType2 || adjust$2(this.primaryColor, { h: 64 }); + this.fillType3 = this.fillType3 || adjust$2(this.secondaryColor, { h: 64 }); + this.fillType4 = this.fillType4 || adjust$2(this.primaryColor, { h: -64 }); + this.fillType5 = this.fillType5 || adjust$2(this.secondaryColor, { h: -64 }); + this.fillType6 = this.fillType6 || adjust$2(this.primaryColor, { h: 128 }); + this.fillType7 = this.fillType7 || adjust$2(this.secondaryColor, { h: 128 }); + this.pie1 = this.pie1 || this.primaryColor; + this.pie2 = this.pie2 || this.secondaryColor; + this.pie3 = this.pie3 || this.tertiaryColor; + this.pie4 = this.pie4 || adjust$2(this.primaryColor, { l: -10 }); + this.pie5 = this.pie5 || adjust$2(this.secondaryColor, { l: -10 }); + this.pie6 = this.pie6 || adjust$2(this.tertiaryColor, { l: -10 }); + this.pie7 = this.pie7 || adjust$2(this.primaryColor, { h: 60, l: -10 }); + this.pie8 = this.pie8 || adjust$2(this.primaryColor, { h: -60, l: -10 }); + this.pie9 = this.pie9 || adjust$2(this.primaryColor, { h: 120, l: 0 }); + this.pie10 = this.pie10 || adjust$2(this.primaryColor, { h: 60, l: -20 }); + this.pie11 = this.pie11 || adjust$2(this.primaryColor, { h: -60, l: -20 }); + this.pie12 = this.pie12 || adjust$2(this.primaryColor, { h: 120, l: -10 }); + this.pieTitleTextSize = this.pieTitleTextSize || "25px"; + this.pieTitleTextColor = this.pieTitleTextColor || this.taskTextDarkColor; + this.pieSectionTextSize = this.pieSectionTextSize || "17px"; + this.pieSectionTextColor = this.pieSectionTextColor || this.textColor; + this.pieLegendTextSize = this.pieLegendTextSize || "17px"; + this.pieLegendTextColor = this.pieLegendTextColor || this.taskTextDarkColor; + this.pieStrokeColor = this.pieStrokeColor || "black"; + this.pieStrokeWidth = this.pieStrokeWidth || "2px"; + this.pieOuterStrokeWidth = this.pieOuterStrokeWidth || "2px"; + this.pieOuterStrokeColor = this.pieOuterStrokeColor || "black"; + this.pieOpacity = this.pieOpacity || "0.7"; + this.quadrant1Fill = this.quadrant1Fill || this.primaryColor; + this.quadrant2Fill = this.quadrant2Fill || adjust$2(this.primaryColor, { r: 5, g: 5, b: 5 }); + this.quadrant3Fill = this.quadrant3Fill || adjust$2(this.primaryColor, { r: 10, g: 10, b: 10 }); + this.quadrant4Fill = this.quadrant4Fill || adjust$2(this.primaryColor, { r: 15, g: 15, b: 15 }); + this.quadrant1TextFill = this.quadrant1TextFill || this.primaryTextColor; + this.quadrant2TextFill = this.quadrant2TextFill || adjust$2(this.primaryTextColor, { r: -5, g: -5, b: -5 }); + this.quadrant3TextFill = this.quadrant3TextFill || adjust$2(this.primaryTextColor, { r: -10, g: -10, b: -10 }); + this.quadrant4TextFill = this.quadrant4TextFill || adjust$2(this.primaryTextColor, { r: -15, g: -15, b: -15 }); + this.quadrantPointFill = this.quadrantPointFill || isDark$1(this.quadrant1Fill) ? lighten$1(this.quadrant1Fill) : darken$1(this.quadrant1Fill); + this.quadrantPointTextFill = this.quadrantPointTextFill || this.primaryTextColor; + this.quadrantXAxisTextFill = this.quadrantXAxisTextFill || this.primaryTextColor; + this.quadrantYAxisTextFill = this.quadrantYAxisTextFill || this.primaryTextColor; + this.quadrantInternalBorderStrokeFill = this.quadrantInternalBorderStrokeFill || this.primaryBorderColor; + this.quadrantExternalBorderStrokeFill = this.quadrantExternalBorderStrokeFill || this.primaryBorderColor; + this.quadrantTitleFill = this.quadrantTitleFill || this.primaryTextColor; + this.xyChart = { + backgroundColor: ((_a2 = this.xyChart) == null ? void 0 : _a2.backgroundColor) || this.background, + titleColor: ((_b2 = this.xyChart) == null ? void 0 : _b2.titleColor) || this.primaryTextColor, + xAxisTitleColor: ((_c = this.xyChart) == null ? void 0 : _c.xAxisTitleColor) || this.primaryTextColor, + xAxisLabelColor: ((_d = this.xyChart) == null ? void 0 : _d.xAxisLabelColor) || this.primaryTextColor, + xAxisTickColor: ((_e = this.xyChart) == null ? void 0 : _e.xAxisTickColor) || this.primaryTextColor, + xAxisLineColor: ((_f = this.xyChart) == null ? void 0 : _f.xAxisLineColor) || this.primaryTextColor, + yAxisTitleColor: ((_g = this.xyChart) == null ? void 0 : _g.yAxisTitleColor) || this.primaryTextColor, + yAxisLabelColor: ((_h = this.xyChart) == null ? void 0 : _h.yAxisLabelColor) || this.primaryTextColor, + yAxisTickColor: ((_i6 = this.xyChart) == null ? void 0 : _i6.yAxisTickColor) || this.primaryTextColor, + yAxisLineColor: ((_j = this.xyChart) == null ? void 0 : _j.yAxisLineColor) || this.primaryTextColor, + plotColorPalette: ((_k = this.xyChart) == null ? void 0 : _k.plotColorPalette) || "#FFF4DD,#FFD8B1,#FFA07A,#ECEFF1,#D6DBDF,#C3E0A8,#FFB6A4,#FFD74D,#738FA7,#FFFFF0" + }; + this.requirementBackground = this.requirementBackground || this.primaryColor; + this.requirementBorderColor = this.requirementBorderColor || this.primaryBorderColor; + this.requirementBorderSize = this.requirementBorderSize || "1"; + this.requirementTextColor = this.requirementTextColor || this.primaryTextColor; + this.relationColor = this.relationColor || this.lineColor; + this.relationLabelBackground = this.relationLabelBackground || (this.darkMode ? darken$1(this.secondaryColor, 30) : this.secondaryColor); + this.relationLabelColor = this.relationLabelColor || this.actorTextColor; + this.git0 = this.git0 || this.primaryColor; + this.git1 = this.git1 || this.secondaryColor; + this.git2 = this.git2 || this.tertiaryColor; + this.git3 = this.git3 || adjust$2(this.primaryColor, { h: -30 }); + this.git4 = this.git4 || adjust$2(this.primaryColor, { h: -60 }); + this.git5 = this.git5 || adjust$2(this.primaryColor, { h: -90 }); + this.git6 = this.git6 || adjust$2(this.primaryColor, { h: 60 }); + this.git7 = this.git7 || adjust$2(this.primaryColor, { h: 120 }); + if (this.darkMode) { + this.git0 = lighten$1(this.git0, 25); + this.git1 = lighten$1(this.git1, 25); + this.git2 = lighten$1(this.git2, 25); + this.git3 = lighten$1(this.git3, 25); + this.git4 = lighten$1(this.git4, 25); + this.git5 = lighten$1(this.git5, 25); + this.git6 = lighten$1(this.git6, 25); + this.git7 = lighten$1(this.git7, 25); + } else { + this.git0 = darken$1(this.git0, 25); + this.git1 = darken$1(this.git1, 25); + this.git2 = darken$1(this.git2, 25); + this.git3 = darken$1(this.git3, 25); + this.git4 = darken$1(this.git4, 25); + this.git5 = darken$1(this.git5, 25); + this.git6 = darken$1(this.git6, 25); + this.git7 = darken$1(this.git7, 25); + } + this.gitInv0 = this.gitInv0 || invert$1(this.git0); + this.gitInv1 = this.gitInv1 || invert$1(this.git1); + this.gitInv2 = this.gitInv2 || invert$1(this.git2); + this.gitInv3 = this.gitInv3 || invert$1(this.git3); + this.gitInv4 = this.gitInv4 || invert$1(this.git4); + this.gitInv5 = this.gitInv5 || invert$1(this.git5); + this.gitInv6 = this.gitInv6 || invert$1(this.git6); + this.gitInv7 = this.gitInv7 || invert$1(this.git7); + this.branchLabelColor = this.branchLabelColor || (this.darkMode ? "black" : this.labelTextColor); + this.gitBranchLabel0 = this.gitBranchLabel0 || this.branchLabelColor; + this.gitBranchLabel1 = this.gitBranchLabel1 || this.branchLabelColor; + this.gitBranchLabel2 = this.gitBranchLabel2 || this.branchLabelColor; + this.gitBranchLabel3 = this.gitBranchLabel3 || this.branchLabelColor; + this.gitBranchLabel4 = this.gitBranchLabel4 || this.branchLabelColor; + this.gitBranchLabel5 = this.gitBranchLabel5 || this.branchLabelColor; + this.gitBranchLabel6 = this.gitBranchLabel6 || this.branchLabelColor; + this.gitBranchLabel7 = this.gitBranchLabel7 || this.branchLabelColor; + this.tagLabelColor = this.tagLabelColor || this.primaryTextColor; + this.tagLabelBackground = this.tagLabelBackground || this.primaryColor; + this.tagLabelBorder = this.tagBorder || this.primaryBorderColor; + this.tagLabelFontSize = this.tagLabelFontSize || "10px"; + this.commitLabelColor = this.commitLabelColor || this.secondaryTextColor; + this.commitLabelBackground = this.commitLabelBackground || this.secondaryColor; + this.commitLabelFontSize = this.commitLabelFontSize || "10px"; + this.attributeBackgroundColorOdd = this.attributeBackgroundColorOdd || oldAttributeBackgroundColorOdd; + this.attributeBackgroundColorEven = this.attributeBackgroundColorEven || oldAttributeBackgroundColorEven; + } + calculate(overrides) { + if (typeof overrides !== "object") { + this.updateColors(); + return; + } + const keys2 = Object.keys(overrides); + keys2.forEach((k) => { + this[k] = overrides[k]; + }); + this.updateColors(); + keys2.forEach((k) => { + this[k] = overrides[k]; + }); + } + }; + const getThemeVariables$4 = (userOverrides) => { + const theme2 = new Theme$4(); + theme2.calculate(userOverrides); + return theme2; + }; + let Theme$3 = class Theme { + constructor() { + this.background = "#333"; + this.primaryColor = "#1f2020"; + this.secondaryColor = lighten$1(this.primaryColor, 16); + this.tertiaryColor = adjust$2(this.primaryColor, { h: -160 }); + this.primaryBorderColor = invert$1(this.background); + this.secondaryBorderColor = mkBorder(this.secondaryColor, this.darkMode); + this.tertiaryBorderColor = mkBorder(this.tertiaryColor, this.darkMode); + this.primaryTextColor = invert$1(this.primaryColor); + this.secondaryTextColor = invert$1(this.secondaryColor); + this.tertiaryTextColor = invert$1(this.tertiaryColor); + this.lineColor = invert$1(this.background); + this.textColor = invert$1(this.background); + this.mainBkg = "#1f2020"; + this.secondBkg = "calculated"; + this.mainContrastColor = "lightgrey"; + this.darkTextColor = lighten$1(invert$1("#323D47"), 10); + this.lineColor = "calculated"; + this.border1 = "#81B1DB"; + this.border2 = rgba$1(255, 255, 255, 0.25); + this.arrowheadColor = "calculated"; + this.fontFamily = '"trebuchet ms", verdana, arial, sans-serif'; + this.fontSize = "16px"; + this.labelBackground = "#181818"; + this.textColor = "#ccc"; + this.THEME_COLOR_LIMIT = 12; + this.nodeBkg = "calculated"; + this.nodeBorder = "calculated"; + this.clusterBkg = "calculated"; + this.clusterBorder = "calculated"; + this.defaultLinkColor = "calculated"; + this.titleColor = "#F9FFFE"; + this.edgeLabelBackground = "calculated"; + this.actorBorder = "calculated"; + this.actorBkg = "calculated"; + this.actorTextColor = "calculated"; + this.actorLineColor = "calculated"; + this.signalColor = "calculated"; + this.signalTextColor = "calculated"; + this.labelBoxBkgColor = "calculated"; + this.labelBoxBorderColor = "calculated"; + this.labelTextColor = "calculated"; + this.loopTextColor = "calculated"; + this.noteBorderColor = "calculated"; + this.noteBkgColor = "#fff5ad"; + this.noteTextColor = "calculated"; + this.activationBorderColor = "calculated"; + this.activationBkgColor = "calculated"; + this.sequenceNumberColor = "black"; + this.sectionBkgColor = darken$1("#EAE8D9", 30); + this.altSectionBkgColor = "calculated"; + this.sectionBkgColor2 = "#EAE8D9"; + this.excludeBkgColor = darken$1(this.sectionBkgColor, 10); + this.taskBorderColor = rgba$1(255, 255, 255, 70); + this.taskBkgColor = "calculated"; + this.taskTextColor = "calculated"; + this.taskTextLightColor = "calculated"; + this.taskTextOutsideColor = "calculated"; + this.taskTextClickableColor = "#003163"; + this.activeTaskBorderColor = rgba$1(255, 255, 255, 50); + this.activeTaskBkgColor = "#81B1DB"; + this.gridColor = "calculated"; + this.doneTaskBkgColor = "calculated"; + this.doneTaskBorderColor = "grey"; + this.critBorderColor = "#E83737"; + this.critBkgColor = "#E83737"; + this.taskTextDarkColor = "calculated"; + this.todayLineColor = "#DB5757"; + this.personBorder = this.primaryBorderColor; + this.personBkg = this.mainBkg; + this.labelColor = "calculated"; + this.errorBkgColor = "#a44141"; + this.errorTextColor = "#ddd"; + } + updateColors() { + var _a2, _b2, _c, _d, _e, _f, _g, _h, _i6, _j, _k; + this.secondBkg = lighten$1(this.mainBkg, 16); + this.lineColor = this.mainContrastColor; + this.arrowheadColor = this.mainContrastColor; + this.nodeBkg = this.mainBkg; + this.nodeBorder = this.border1; + this.clusterBkg = this.secondBkg; + this.clusterBorder = this.border2; + this.defaultLinkColor = this.lineColor; + this.edgeLabelBackground = lighten$1(this.labelBackground, 25); + this.actorBorder = this.border1; + this.actorBkg = this.mainBkg; + this.actorTextColor = this.mainContrastColor; + this.actorLineColor = this.mainContrastColor; + this.signalColor = this.mainContrastColor; + this.signalTextColor = this.mainContrastColor; + this.labelBoxBkgColor = this.actorBkg; + this.labelBoxBorderColor = this.actorBorder; + this.labelTextColor = this.mainContrastColor; + this.loopTextColor = this.mainContrastColor; + this.noteBorderColor = this.secondaryBorderColor; + this.noteBkgColor = this.secondBkg; + this.noteTextColor = this.secondaryTextColor; + this.activationBorderColor = this.border1; + this.activationBkgColor = this.secondBkg; + this.altSectionBkgColor = this.background; + this.taskBkgColor = lighten$1(this.mainBkg, 23); + this.taskTextColor = this.darkTextColor; + this.taskTextLightColor = this.mainContrastColor; + this.taskTextOutsideColor = this.taskTextLightColor; + this.gridColor = this.mainContrastColor; + this.doneTaskBkgColor = this.mainContrastColor; + this.taskTextDarkColor = this.darkTextColor; + this.transitionColor = this.transitionColor || this.lineColor; + this.transitionLabelColor = this.transitionLabelColor || this.textColor; + this.stateLabelColor = this.stateLabelColor || this.stateBkg || this.primaryTextColor; + this.stateBkg = this.stateBkg || this.mainBkg; + this.labelBackgroundColor = this.labelBackgroundColor || this.stateBkg; + this.compositeBackground = this.compositeBackground || this.background || this.tertiaryColor; + this.altBackground = this.altBackground || "#555"; + this.compositeTitleBackground = this.compositeTitleBackground || this.mainBkg; + this.compositeBorder = this.compositeBorder || this.nodeBorder; + this.innerEndBackground = this.primaryBorderColor; + this.specialStateColor = "#f4f4f4"; + this.errorBkgColor = this.errorBkgColor || this.tertiaryColor; + this.errorTextColor = this.errorTextColor || this.tertiaryTextColor; + this.fillType0 = this.primaryColor; + this.fillType1 = this.secondaryColor; + this.fillType2 = adjust$2(this.primaryColor, { h: 64 }); + this.fillType3 = adjust$2(this.secondaryColor, { h: 64 }); + this.fillType4 = adjust$2(this.primaryColor, { h: -64 }); + this.fillType5 = adjust$2(this.secondaryColor, { h: -64 }); + this.fillType6 = adjust$2(this.primaryColor, { h: 128 }); + this.fillType7 = adjust$2(this.secondaryColor, { h: 128 }); + this.cScale1 = this.cScale1 || "#0b0000"; + this.cScale2 = this.cScale2 || "#4d1037"; + this.cScale3 = this.cScale3 || "#3f5258"; + this.cScale4 = this.cScale4 || "#4f2f1b"; + this.cScale5 = this.cScale5 || "#6e0a0a"; + this.cScale6 = this.cScale6 || "#3b0048"; + this.cScale7 = this.cScale7 || "#995a01"; + this.cScale8 = this.cScale8 || "#154706"; + this.cScale9 = this.cScale9 || "#161722"; + this.cScale10 = this.cScale10 || "#00296f"; + this.cScale11 = this.cScale11 || "#01629c"; + this.cScale12 = this.cScale12 || "#010029"; + this.cScale0 = this.cScale0 || this.primaryColor; + this.cScale1 = this.cScale1 || this.secondaryColor; + this.cScale2 = this.cScale2 || this.tertiaryColor; + this.cScale3 = this.cScale3 || adjust$2(this.primaryColor, { h: 30 }); + this.cScale4 = this.cScale4 || adjust$2(this.primaryColor, { h: 60 }); + this.cScale5 = this.cScale5 || adjust$2(this.primaryColor, { h: 90 }); + this.cScale6 = this.cScale6 || adjust$2(this.primaryColor, { h: 120 }); + this.cScale7 = this.cScale7 || adjust$2(this.primaryColor, { h: 150 }); + this.cScale8 = this.cScale8 || adjust$2(this.primaryColor, { h: 210 }); + this.cScale9 = this.cScale9 || adjust$2(this.primaryColor, { h: 270 }); + this.cScale10 = this.cScale10 || adjust$2(this.primaryColor, { h: 300 }); + this.cScale11 = this.cScale11 || adjust$2(this.primaryColor, { h: 330 }); + for (let i2 = 0; i2 < this.THEME_COLOR_LIMIT; i2++) { + this["cScaleInv" + i2] = this["cScaleInv" + i2] || invert$1(this["cScale" + i2]); + } + for (let i2 = 0; i2 < this.THEME_COLOR_LIMIT; i2++) { + this["cScalePeer" + i2] = this["cScalePeer" + i2] || lighten$1(this["cScale" + i2], 10); + } + for (let i2 = 0; i2 < 5; i2++) { + this["surface" + i2] = this["surface" + i2] || adjust$2(this.mainBkg, { h: 30, s: -30, l: -(-10 + i2 * 4) }); + this["surfacePeer" + i2] = this["surfacePeer" + i2] || adjust$2(this.mainBkg, { h: 30, s: -30, l: -(-7 + i2 * 4) }); + } + this.scaleLabelColor = this.scaleLabelColor || (this.darkMode ? "black" : this.labelTextColor); + for (let i2 = 0; i2 < this.THEME_COLOR_LIMIT; i2++) { + this["cScaleLabel" + i2] = this["cScaleLabel" + i2] || this.scaleLabelColor; + } + for (let i2 = 0; i2 < this.THEME_COLOR_LIMIT; i2++) { + this["pie" + i2] = this["cScale" + i2]; + } + this.pieTitleTextSize = this.pieTitleTextSize || "25px"; + this.pieTitleTextColor = this.pieTitleTextColor || this.taskTextDarkColor; + this.pieSectionTextSize = this.pieSectionTextSize || "17px"; + this.pieSectionTextColor = this.pieSectionTextColor || this.textColor; + this.pieLegendTextSize = this.pieLegendTextSize || "17px"; + this.pieLegendTextColor = this.pieLegendTextColor || this.taskTextDarkColor; + this.pieStrokeColor = this.pieStrokeColor || "black"; + this.pieStrokeWidth = this.pieStrokeWidth || "2px"; + this.pieOuterStrokeWidth = this.pieOuterStrokeWidth || "2px"; + this.pieOuterStrokeColor = this.pieOuterStrokeColor || "black"; + this.pieOpacity = this.pieOpacity || "0.7"; + this.quadrant1Fill = this.quadrant1Fill || this.primaryColor; + this.quadrant2Fill = this.quadrant2Fill || adjust$2(this.primaryColor, { r: 5, g: 5, b: 5 }); + this.quadrant3Fill = this.quadrant3Fill || adjust$2(this.primaryColor, { r: 10, g: 10, b: 10 }); + this.quadrant4Fill = this.quadrant4Fill || adjust$2(this.primaryColor, { r: 15, g: 15, b: 15 }); + this.quadrant1TextFill = this.quadrant1TextFill || this.primaryTextColor; + this.quadrant2TextFill = this.quadrant2TextFill || adjust$2(this.primaryTextColor, { r: -5, g: -5, b: -5 }); + this.quadrant3TextFill = this.quadrant3TextFill || adjust$2(this.primaryTextColor, { r: -10, g: -10, b: -10 }); + this.quadrant4TextFill = this.quadrant4TextFill || adjust$2(this.primaryTextColor, { r: -15, g: -15, b: -15 }); + this.quadrantPointFill = this.quadrantPointFill || isDark$1(this.quadrant1Fill) ? lighten$1(this.quadrant1Fill) : darken$1(this.quadrant1Fill); + this.quadrantPointTextFill = this.quadrantPointTextFill || this.primaryTextColor; + this.quadrantXAxisTextFill = this.quadrantXAxisTextFill || this.primaryTextColor; + this.quadrantYAxisTextFill = this.quadrantYAxisTextFill || this.primaryTextColor; + this.quadrantInternalBorderStrokeFill = this.quadrantInternalBorderStrokeFill || this.primaryBorderColor; + this.quadrantExternalBorderStrokeFill = this.quadrantExternalBorderStrokeFill || this.primaryBorderColor; + this.quadrantTitleFill = this.quadrantTitleFill || this.primaryTextColor; + this.xyChart = { + backgroundColor: ((_a2 = this.xyChart) == null ? void 0 : _a2.backgroundColor) || this.background, + titleColor: ((_b2 = this.xyChart) == null ? void 0 : _b2.titleColor) || this.primaryTextColor, + xAxisTitleColor: ((_c = this.xyChart) == null ? void 0 : _c.xAxisTitleColor) || this.primaryTextColor, + xAxisLabelColor: ((_d = this.xyChart) == null ? void 0 : _d.xAxisLabelColor) || this.primaryTextColor, + xAxisTickColor: ((_e = this.xyChart) == null ? void 0 : _e.xAxisTickColor) || this.primaryTextColor, + xAxisLineColor: ((_f = this.xyChart) == null ? void 0 : _f.xAxisLineColor) || this.primaryTextColor, + yAxisTitleColor: ((_g = this.xyChart) == null ? void 0 : _g.yAxisTitleColor) || this.primaryTextColor, + yAxisLabelColor: ((_h = this.xyChart) == null ? void 0 : _h.yAxisLabelColor) || this.primaryTextColor, + yAxisTickColor: ((_i6 = this.xyChart) == null ? void 0 : _i6.yAxisTickColor) || this.primaryTextColor, + yAxisLineColor: ((_j = this.xyChart) == null ? void 0 : _j.yAxisLineColor) || this.primaryTextColor, + plotColorPalette: ((_k = this.xyChart) == null ? void 0 : _k.plotColorPalette) || "#3498db,#2ecc71,#e74c3c,#f1c40f,#bdc3c7,#ffffff,#34495e,#9b59b6,#1abc9c,#e67e22" + }; + this.classText = this.primaryTextColor; + this.requirementBackground = this.requirementBackground || this.primaryColor; + this.requirementBorderColor = this.requirementBorderColor || this.primaryBorderColor; + this.requirementBorderSize = this.requirementBorderSize || "1"; + this.requirementTextColor = this.requirementTextColor || this.primaryTextColor; + this.relationColor = this.relationColor || this.lineColor; + this.relationLabelBackground = this.relationLabelBackground || (this.darkMode ? darken$1(this.secondaryColor, 30) : this.secondaryColor); + this.relationLabelColor = this.relationLabelColor || this.actorTextColor; + this.git0 = lighten$1(this.secondaryColor, 20); + this.git1 = lighten$1(this.pie2 || this.secondaryColor, 20); + this.git2 = lighten$1(this.pie3 || this.tertiaryColor, 20); + this.git3 = lighten$1(this.pie4 || adjust$2(this.primaryColor, { h: -30 }), 20); + this.git4 = lighten$1(this.pie5 || adjust$2(this.primaryColor, { h: -60 }), 20); + this.git5 = lighten$1(this.pie6 || adjust$2(this.primaryColor, { h: -90 }), 10); + this.git6 = lighten$1(this.pie7 || adjust$2(this.primaryColor, { h: 60 }), 10); + this.git7 = lighten$1(this.pie8 || adjust$2(this.primaryColor, { h: 120 }), 20); + this.gitInv0 = this.gitInv0 || invert$1(this.git0); + this.gitInv1 = this.gitInv1 || invert$1(this.git1); + this.gitInv2 = this.gitInv2 || invert$1(this.git2); + this.gitInv3 = this.gitInv3 || invert$1(this.git3); + this.gitInv4 = this.gitInv4 || invert$1(this.git4); + this.gitInv5 = this.gitInv5 || invert$1(this.git5); + this.gitInv6 = this.gitInv6 || invert$1(this.git6); + this.gitInv7 = this.gitInv7 || invert$1(this.git7); + this.gitBranchLabel0 = this.gitBranchLabel0 || invert$1(this.labelTextColor); + this.gitBranchLabel1 = this.gitBranchLabel1 || this.labelTextColor; + this.gitBranchLabel2 = this.gitBranchLabel2 || this.labelTextColor; + this.gitBranchLabel3 = this.gitBranchLabel3 || invert$1(this.labelTextColor); + this.gitBranchLabel4 = this.gitBranchLabel4 || this.labelTextColor; + this.gitBranchLabel5 = this.gitBranchLabel5 || this.labelTextColor; + this.gitBranchLabel6 = this.gitBranchLabel6 || this.labelTextColor; + this.gitBranchLabel7 = this.gitBranchLabel7 || this.labelTextColor; + this.tagLabelColor = this.tagLabelColor || this.primaryTextColor; + this.tagLabelBackground = this.tagLabelBackground || this.primaryColor; + this.tagLabelBorder = this.tagBorder || this.primaryBorderColor; + this.tagLabelFontSize = this.tagLabelFontSize || "10px"; + this.commitLabelColor = this.commitLabelColor || this.secondaryTextColor; + this.commitLabelBackground = this.commitLabelBackground || this.secondaryColor; + this.commitLabelFontSize = this.commitLabelFontSize || "10px"; + this.attributeBackgroundColorOdd = this.attributeBackgroundColorOdd || lighten$1(this.background, 12); + this.attributeBackgroundColorEven = this.attributeBackgroundColorEven || lighten$1(this.background, 2); + } + calculate(overrides) { + if (typeof overrides !== "object") { + this.updateColors(); + return; + } + const keys2 = Object.keys(overrides); + keys2.forEach((k) => { + this[k] = overrides[k]; + }); + this.updateColors(); + keys2.forEach((k) => { + this[k] = overrides[k]; + }); + } + }; + const getThemeVariables$3 = (userOverrides) => { + const theme2 = new Theme$3(); + theme2.calculate(userOverrides); + return theme2; + }; + let Theme$2 = class Theme { + constructor() { + this.background = "#f4f4f4"; + this.primaryColor = "#ECECFF"; + this.secondaryColor = adjust$2(this.primaryColor, { h: 120 }); + this.secondaryColor = "#ffffde"; + this.tertiaryColor = adjust$2(this.primaryColor, { h: -160 }); + this.primaryBorderColor = mkBorder(this.primaryColor, this.darkMode); + this.secondaryBorderColor = mkBorder(this.secondaryColor, this.darkMode); + this.tertiaryBorderColor = mkBorder(this.tertiaryColor, this.darkMode); + this.primaryTextColor = invert$1(this.primaryColor); + this.secondaryTextColor = invert$1(this.secondaryColor); + this.tertiaryTextColor = invert$1(this.tertiaryColor); + this.lineColor = invert$1(this.background); + this.textColor = invert$1(this.background); + this.background = "white"; + this.mainBkg = "#ECECFF"; + this.secondBkg = "#ffffde"; + this.lineColor = "#333333"; + this.border1 = "#9370DB"; + this.border2 = "#aaaa33"; + this.arrowheadColor = "#333333"; + this.fontFamily = '"trebuchet ms", verdana, arial, sans-serif'; + this.fontSize = "16px"; + this.labelBackground = "#e8e8e8"; + this.textColor = "#333"; + this.THEME_COLOR_LIMIT = 12; + this.nodeBkg = "calculated"; + this.nodeBorder = "calculated"; + this.clusterBkg = "calculated"; + this.clusterBorder = "calculated"; + this.defaultLinkColor = "calculated"; + this.titleColor = "calculated"; + this.edgeLabelBackground = "calculated"; + this.actorBorder = "calculated"; + this.actorBkg = "calculated"; + this.actorTextColor = "black"; + this.actorLineColor = "grey"; + this.signalColor = "calculated"; + this.signalTextColor = "calculated"; + this.labelBoxBkgColor = "calculated"; + this.labelBoxBorderColor = "calculated"; + this.labelTextColor = "calculated"; + this.loopTextColor = "calculated"; + this.noteBorderColor = "calculated"; + this.noteBkgColor = "#fff5ad"; + this.noteTextColor = "calculated"; + this.activationBorderColor = "#666"; + this.activationBkgColor = "#f4f4f4"; + this.sequenceNumberColor = "white"; + this.sectionBkgColor = "calculated"; + this.altSectionBkgColor = "calculated"; + this.sectionBkgColor2 = "calculated"; + this.excludeBkgColor = "#eeeeee"; + this.taskBorderColor = "calculated"; + this.taskBkgColor = "calculated"; + this.taskTextLightColor = "calculated"; + this.taskTextColor = this.taskTextLightColor; + this.taskTextDarkColor = "calculated"; + this.taskTextOutsideColor = this.taskTextDarkColor; + this.taskTextClickableColor = "calculated"; + this.activeTaskBorderColor = "calculated"; + this.activeTaskBkgColor = "calculated"; + this.gridColor = "calculated"; + this.doneTaskBkgColor = "calculated"; + this.doneTaskBorderColor = "calculated"; + this.critBorderColor = "calculated"; + this.critBkgColor = "calculated"; + this.todayLineColor = "calculated"; + this.sectionBkgColor = rgba$1(102, 102, 255, 0.49); + this.altSectionBkgColor = "white"; + this.sectionBkgColor2 = "#fff400"; + this.taskBorderColor = "#534fbc"; + this.taskBkgColor = "#8a90dd"; + this.taskTextLightColor = "white"; + this.taskTextColor = "calculated"; + this.taskTextDarkColor = "black"; + this.taskTextOutsideColor = "calculated"; + this.taskTextClickableColor = "#003163"; + this.activeTaskBorderColor = "#534fbc"; + this.activeTaskBkgColor = "#bfc7ff"; + this.gridColor = "lightgrey"; + this.doneTaskBkgColor = "lightgrey"; + this.doneTaskBorderColor = "grey"; + this.critBorderColor = "#ff8888"; + this.critBkgColor = "red"; + this.todayLineColor = "red"; + this.personBorder = this.primaryBorderColor; + this.personBkg = this.mainBkg; + this.labelColor = "black"; + this.errorBkgColor = "#552222"; + this.errorTextColor = "#552222"; + this.updateColors(); + } + updateColors() { + var _a2, _b2, _c, _d, _e, _f, _g, _h, _i6, _j, _k; + this.cScale0 = this.cScale0 || this.primaryColor; + this.cScale1 = this.cScale1 || this.secondaryColor; + this.cScale2 = this.cScale2 || this.tertiaryColor; + this.cScale3 = this.cScale3 || adjust$2(this.primaryColor, { h: 30 }); + this.cScale4 = this.cScale4 || adjust$2(this.primaryColor, { h: 60 }); + this.cScale5 = this.cScale5 || adjust$2(this.primaryColor, { h: 90 }); + this.cScale6 = this.cScale6 || adjust$2(this.primaryColor, { h: 120 }); + this.cScale7 = this.cScale7 || adjust$2(this.primaryColor, { h: 150 }); + this.cScale8 = this.cScale8 || adjust$2(this.primaryColor, { h: 210 }); + this.cScale9 = this.cScale9 || adjust$2(this.primaryColor, { h: 270 }); + this.cScale10 = this.cScale10 || adjust$2(this.primaryColor, { h: 300 }); + this.cScale11 = this.cScale11 || adjust$2(this.primaryColor, { h: 330 }); + this["cScalePeer1"] = this["cScalePeer1"] || darken$1(this.secondaryColor, 45); + this["cScalePeer2"] = this["cScalePeer2"] || darken$1(this.tertiaryColor, 40); + for (let i2 = 0; i2 < this.THEME_COLOR_LIMIT; i2++) { + this["cScale" + i2] = darken$1(this["cScale" + i2], 10); + this["cScalePeer" + i2] = this["cScalePeer" + i2] || darken$1(this["cScale" + i2], 25); + } + for (let i2 = 0; i2 < this.THEME_COLOR_LIMIT; i2++) { + this["cScaleInv" + i2] = this["cScaleInv" + i2] || adjust$2(this["cScale" + i2], { h: 180 }); + } + for (let i2 = 0; i2 < 5; i2++) { + this["surface" + i2] = this["surface" + i2] || adjust$2(this.mainBkg, { h: 30, l: -(5 + i2 * 5) }); + this["surfacePeer" + i2] = this["surfacePeer" + i2] || adjust$2(this.mainBkg, { h: 30, l: -(7 + i2 * 5) }); + } + this.scaleLabelColor = this.scaleLabelColor !== "calculated" && this.scaleLabelColor ? this.scaleLabelColor : this.labelTextColor; + if (this.labelTextColor !== "calculated") { + this.cScaleLabel0 = this.cScaleLabel0 || invert$1(this.labelTextColor); + this.cScaleLabel3 = this.cScaleLabel3 || invert$1(this.labelTextColor); + for (let i2 = 0; i2 < this.THEME_COLOR_LIMIT; i2++) { + this["cScaleLabel" + i2] = this["cScaleLabel" + i2] || this.labelTextColor; + } + } + this.nodeBkg = this.mainBkg; + this.nodeBorder = this.border1; + this.clusterBkg = this.secondBkg; + this.clusterBorder = this.border2; + this.defaultLinkColor = this.lineColor; + this.titleColor = this.textColor; + this.edgeLabelBackground = this.labelBackground; + this.actorBorder = lighten$1(this.border1, 23); + this.actorBkg = this.mainBkg; + this.labelBoxBkgColor = this.actorBkg; + this.signalColor = this.textColor; + this.signalTextColor = this.textColor; + this.labelBoxBorderColor = this.actorBorder; + this.labelTextColor = this.actorTextColor; + this.loopTextColor = this.actorTextColor; + this.noteBorderColor = this.border2; + this.noteTextColor = this.actorTextColor; + this.taskTextColor = this.taskTextLightColor; + this.taskTextOutsideColor = this.taskTextDarkColor; + this.transitionColor = this.transitionColor || this.lineColor; + this.transitionLabelColor = this.transitionLabelColor || this.textColor; + this.stateLabelColor = this.stateLabelColor || this.stateBkg || this.primaryTextColor; + this.stateBkg = this.stateBkg || this.mainBkg; + this.labelBackgroundColor = this.labelBackgroundColor || this.stateBkg; + this.compositeBackground = this.compositeBackground || this.background || this.tertiaryColor; + this.altBackground = this.altBackground || "#f0f0f0"; + this.compositeTitleBackground = this.compositeTitleBackground || this.mainBkg; + this.compositeBorder = this.compositeBorder || this.nodeBorder; + this.innerEndBackground = this.nodeBorder; + this.specialStateColor = this.lineColor; + this.errorBkgColor = this.errorBkgColor || this.tertiaryColor; + this.errorTextColor = this.errorTextColor || this.tertiaryTextColor; + this.transitionColor = this.transitionColor || this.lineColor; + this.classText = this.primaryTextColor; + this.fillType0 = this.primaryColor; + this.fillType1 = this.secondaryColor; + this.fillType2 = adjust$2(this.primaryColor, { h: 64 }); + this.fillType3 = adjust$2(this.secondaryColor, { h: 64 }); + this.fillType4 = adjust$2(this.primaryColor, { h: -64 }); + this.fillType5 = adjust$2(this.secondaryColor, { h: -64 }); + this.fillType6 = adjust$2(this.primaryColor, { h: 128 }); + this.fillType7 = adjust$2(this.secondaryColor, { h: 128 }); + this.pie1 = this.pie1 || this.primaryColor; + this.pie2 = this.pie2 || this.secondaryColor; + this.pie3 = this.pie3 || adjust$2(this.tertiaryColor, { l: -40 }); + this.pie4 = this.pie4 || adjust$2(this.primaryColor, { l: -10 }); + this.pie5 = this.pie5 || adjust$2(this.secondaryColor, { l: -30 }); + this.pie6 = this.pie6 || adjust$2(this.tertiaryColor, { l: -20 }); + this.pie7 = this.pie7 || adjust$2(this.primaryColor, { h: 60, l: -20 }); + this.pie8 = this.pie8 || adjust$2(this.primaryColor, { h: -60, l: -40 }); + this.pie9 = this.pie9 || adjust$2(this.primaryColor, { h: 120, l: -40 }); + this.pie10 = this.pie10 || adjust$2(this.primaryColor, { h: 60, l: -40 }); + this.pie11 = this.pie11 || adjust$2(this.primaryColor, { h: -90, l: -40 }); + this.pie12 = this.pie12 || adjust$2(this.primaryColor, { h: 120, l: -30 }); + this.pieTitleTextSize = this.pieTitleTextSize || "25px"; + this.pieTitleTextColor = this.pieTitleTextColor || this.taskTextDarkColor; + this.pieSectionTextSize = this.pieSectionTextSize || "17px"; + this.pieSectionTextColor = this.pieSectionTextColor || this.textColor; + this.pieLegendTextSize = this.pieLegendTextSize || "17px"; + this.pieLegendTextColor = this.pieLegendTextColor || this.taskTextDarkColor; + this.pieStrokeColor = this.pieStrokeColor || "black"; + this.pieStrokeWidth = this.pieStrokeWidth || "2px"; + this.pieOuterStrokeWidth = this.pieOuterStrokeWidth || "2px"; + this.pieOuterStrokeColor = this.pieOuterStrokeColor || "black"; + this.pieOpacity = this.pieOpacity || "0.7"; + this.quadrant1Fill = this.quadrant1Fill || this.primaryColor; + this.quadrant2Fill = this.quadrant2Fill || adjust$2(this.primaryColor, { r: 5, g: 5, b: 5 }); + this.quadrant3Fill = this.quadrant3Fill || adjust$2(this.primaryColor, { r: 10, g: 10, b: 10 }); + this.quadrant4Fill = this.quadrant4Fill || adjust$2(this.primaryColor, { r: 15, g: 15, b: 15 }); + this.quadrant1TextFill = this.quadrant1TextFill || this.primaryTextColor; + this.quadrant2TextFill = this.quadrant2TextFill || adjust$2(this.primaryTextColor, { r: -5, g: -5, b: -5 }); + this.quadrant3TextFill = this.quadrant3TextFill || adjust$2(this.primaryTextColor, { r: -10, g: -10, b: -10 }); + this.quadrant4TextFill = this.quadrant4TextFill || adjust$2(this.primaryTextColor, { r: -15, g: -15, b: -15 }); + this.quadrantPointFill = this.quadrantPointFill || isDark$1(this.quadrant1Fill) ? lighten$1(this.quadrant1Fill) : darken$1(this.quadrant1Fill); + this.quadrantPointTextFill = this.quadrantPointTextFill || this.primaryTextColor; + this.quadrantXAxisTextFill = this.quadrantXAxisTextFill || this.primaryTextColor; + this.quadrantYAxisTextFill = this.quadrantYAxisTextFill || this.primaryTextColor; + this.quadrantInternalBorderStrokeFill = this.quadrantInternalBorderStrokeFill || this.primaryBorderColor; + this.quadrantExternalBorderStrokeFill = this.quadrantExternalBorderStrokeFill || this.primaryBorderColor; + this.quadrantTitleFill = this.quadrantTitleFill || this.primaryTextColor; + this.xyChart = { + backgroundColor: ((_a2 = this.xyChart) == null ? void 0 : _a2.backgroundColor) || this.background, + titleColor: ((_b2 = this.xyChart) == null ? void 0 : _b2.titleColor) || this.primaryTextColor, + xAxisTitleColor: ((_c = this.xyChart) == null ? void 0 : _c.xAxisTitleColor) || this.primaryTextColor, + xAxisLabelColor: ((_d = this.xyChart) == null ? void 0 : _d.xAxisLabelColor) || this.primaryTextColor, + xAxisTickColor: ((_e = this.xyChart) == null ? void 0 : _e.xAxisTickColor) || this.primaryTextColor, + xAxisLineColor: ((_f = this.xyChart) == null ? void 0 : _f.xAxisLineColor) || this.primaryTextColor, + yAxisTitleColor: ((_g = this.xyChart) == null ? void 0 : _g.yAxisTitleColor) || this.primaryTextColor, + yAxisLabelColor: ((_h = this.xyChart) == null ? void 0 : _h.yAxisLabelColor) || this.primaryTextColor, + yAxisTickColor: ((_i6 = this.xyChart) == null ? void 0 : _i6.yAxisTickColor) || this.primaryTextColor, + yAxisLineColor: ((_j = this.xyChart) == null ? void 0 : _j.yAxisLineColor) || this.primaryTextColor, + plotColorPalette: ((_k = this.xyChart) == null ? void 0 : _k.plotColorPalette) || "#ECECFF,#8493A6,#FFC3A0,#DCDDE1,#B8E994,#D1A36F,#C3CDE6,#FFB6C1,#496078,#F8F3E3" + }; + this.requirementBackground = this.requirementBackground || this.primaryColor; + this.requirementBorderColor = this.requirementBorderColor || this.primaryBorderColor; + this.requirementBorderSize = this.requirementBorderSize || "1"; + this.requirementTextColor = this.requirementTextColor || this.primaryTextColor; + this.relationColor = this.relationColor || this.lineColor; + this.relationLabelBackground = this.relationLabelBackground || this.labelBackground; + this.relationLabelColor = this.relationLabelColor || this.actorTextColor; + this.git0 = this.git0 || this.primaryColor; + this.git1 = this.git1 || this.secondaryColor; + this.git2 = this.git2 || this.tertiaryColor; + this.git3 = this.git3 || adjust$2(this.primaryColor, { h: -30 }); + this.git4 = this.git4 || adjust$2(this.primaryColor, { h: -60 }); + this.git5 = this.git5 || adjust$2(this.primaryColor, { h: -90 }); + this.git6 = this.git6 || adjust$2(this.primaryColor, { h: 60 }); + this.git7 = this.git7 || adjust$2(this.primaryColor, { h: 120 }); + if (this.darkMode) { + this.git0 = lighten$1(this.git0, 25); + this.git1 = lighten$1(this.git1, 25); + this.git2 = lighten$1(this.git2, 25); + this.git3 = lighten$1(this.git3, 25); + this.git4 = lighten$1(this.git4, 25); + this.git5 = lighten$1(this.git5, 25); + this.git6 = lighten$1(this.git6, 25); + this.git7 = lighten$1(this.git7, 25); + } else { + this.git0 = darken$1(this.git0, 25); + this.git1 = darken$1(this.git1, 25); + this.git2 = darken$1(this.git2, 25); + this.git3 = darken$1(this.git3, 25); + this.git4 = darken$1(this.git4, 25); + this.git5 = darken$1(this.git5, 25); + this.git6 = darken$1(this.git6, 25); + this.git7 = darken$1(this.git7, 25); + } + this.gitInv0 = this.gitInv0 || darken$1(invert$1(this.git0), 25); + this.gitInv1 = this.gitInv1 || invert$1(this.git1); + this.gitInv2 = this.gitInv2 || invert$1(this.git2); + this.gitInv3 = this.gitInv3 || invert$1(this.git3); + this.gitInv4 = this.gitInv4 || invert$1(this.git4); + this.gitInv5 = this.gitInv5 || invert$1(this.git5); + this.gitInv6 = this.gitInv6 || invert$1(this.git6); + this.gitInv7 = this.gitInv7 || invert$1(this.git7); + this.gitBranchLabel0 = this.gitBranchLabel0 || invert$1(this.labelTextColor); + this.gitBranchLabel1 = this.gitBranchLabel1 || this.labelTextColor; + this.gitBranchLabel2 = this.gitBranchLabel2 || this.labelTextColor; + this.gitBranchLabel3 = this.gitBranchLabel3 || invert$1(this.labelTextColor); + this.gitBranchLabel4 = this.gitBranchLabel4 || this.labelTextColor; + this.gitBranchLabel5 = this.gitBranchLabel5 || this.labelTextColor; + this.gitBranchLabel6 = this.gitBranchLabel6 || this.labelTextColor; + this.gitBranchLabel7 = this.gitBranchLabel7 || this.labelTextColor; + this.tagLabelColor = this.tagLabelColor || this.primaryTextColor; + this.tagLabelBackground = this.tagLabelBackground || this.primaryColor; + this.tagLabelBorder = this.tagBorder || this.primaryBorderColor; + this.tagLabelFontSize = this.tagLabelFontSize || "10px"; + this.commitLabelColor = this.commitLabelColor || this.secondaryTextColor; + this.commitLabelBackground = this.commitLabelBackground || this.secondaryColor; + this.commitLabelFontSize = this.commitLabelFontSize || "10px"; + this.attributeBackgroundColorOdd = this.attributeBackgroundColorOdd || oldAttributeBackgroundColorOdd; + this.attributeBackgroundColorEven = this.attributeBackgroundColorEven || oldAttributeBackgroundColorEven; + } + calculate(overrides) { + if (typeof overrides !== "object") { + this.updateColors(); + return; + } + const keys2 = Object.keys(overrides); + keys2.forEach((k) => { + this[k] = overrides[k]; + }); + this.updateColors(); + keys2.forEach((k) => { + this[k] = overrides[k]; + }); + } + }; + const getThemeVariables$2 = (userOverrides) => { + const theme2 = new Theme$2(); + theme2.calculate(userOverrides); + return theme2; + }; + let Theme$1 = class Theme { + constructor() { + this.background = "#f4f4f4"; + this.primaryColor = "#cde498"; + this.secondaryColor = "#cdffb2"; + this.background = "white"; + this.mainBkg = "#cde498"; + this.secondBkg = "#cdffb2"; + this.lineColor = "green"; + this.border1 = "#13540c"; + this.border2 = "#6eaa49"; + this.arrowheadColor = "green"; + this.fontFamily = '"trebuchet ms", verdana, arial, sans-serif'; + this.fontSize = "16px"; + this.tertiaryColor = lighten$1("#cde498", 10); + this.primaryBorderColor = mkBorder(this.primaryColor, this.darkMode); + this.secondaryBorderColor = mkBorder(this.secondaryColor, this.darkMode); + this.tertiaryBorderColor = mkBorder(this.tertiaryColor, this.darkMode); + this.primaryTextColor = invert$1(this.primaryColor); + this.secondaryTextColor = invert$1(this.secondaryColor); + this.tertiaryTextColor = invert$1(this.primaryColor); + this.lineColor = invert$1(this.background); + this.textColor = invert$1(this.background); + this.THEME_COLOR_LIMIT = 12; + this.nodeBkg = "calculated"; + this.nodeBorder = "calculated"; + this.clusterBkg = "calculated"; + this.clusterBorder = "calculated"; + this.defaultLinkColor = "calculated"; + this.titleColor = "#333"; + this.edgeLabelBackground = "#e8e8e8"; + this.actorBorder = "calculated"; + this.actorBkg = "calculated"; + this.actorTextColor = "black"; + this.actorLineColor = "grey"; + this.signalColor = "#333"; + this.signalTextColor = "#333"; + this.labelBoxBkgColor = "calculated"; + this.labelBoxBorderColor = "#326932"; + this.labelTextColor = "calculated"; + this.loopTextColor = "calculated"; + this.noteBorderColor = "calculated"; + this.noteBkgColor = "#fff5ad"; + this.noteTextColor = "calculated"; + this.activationBorderColor = "#666"; + this.activationBkgColor = "#f4f4f4"; + this.sequenceNumberColor = "white"; + this.sectionBkgColor = "#6eaa49"; + this.altSectionBkgColor = "white"; + this.sectionBkgColor2 = "#6eaa49"; + this.excludeBkgColor = "#eeeeee"; + this.taskBorderColor = "calculated"; + this.taskBkgColor = "#487e3a"; + this.taskTextLightColor = "white"; + this.taskTextColor = "calculated"; + this.taskTextDarkColor = "black"; + this.taskTextOutsideColor = "calculated"; + this.taskTextClickableColor = "#003163"; + this.activeTaskBorderColor = "calculated"; + this.activeTaskBkgColor = "calculated"; + this.gridColor = "lightgrey"; + this.doneTaskBkgColor = "lightgrey"; + this.doneTaskBorderColor = "grey"; + this.critBorderColor = "#ff8888"; + this.critBkgColor = "red"; + this.todayLineColor = "red"; + this.personBorder = this.primaryBorderColor; + this.personBkg = this.mainBkg; + this.labelColor = "black"; + this.errorBkgColor = "#552222"; + this.errorTextColor = "#552222"; + } + updateColors() { + var _a2, _b2, _c, _d, _e, _f, _g, _h, _i6, _j, _k; + this.actorBorder = darken$1(this.mainBkg, 20); + this.actorBkg = this.mainBkg; + this.labelBoxBkgColor = this.actorBkg; + this.labelTextColor = this.actorTextColor; + this.loopTextColor = this.actorTextColor; + this.noteBorderColor = this.border2; + this.noteTextColor = this.actorTextColor; + this.cScale0 = this.cScale0 || this.primaryColor; + this.cScale1 = this.cScale1 || this.secondaryColor; + this.cScale2 = this.cScale2 || this.tertiaryColor; + this.cScale3 = this.cScale3 || adjust$2(this.primaryColor, { h: 30 }); + this.cScale4 = this.cScale4 || adjust$2(this.primaryColor, { h: 60 }); + this.cScale5 = this.cScale5 || adjust$2(this.primaryColor, { h: 90 }); + this.cScale6 = this.cScale6 || adjust$2(this.primaryColor, { h: 120 }); + this.cScale7 = this.cScale7 || adjust$2(this.primaryColor, { h: 150 }); + this.cScale8 = this.cScale8 || adjust$2(this.primaryColor, { h: 210 }); + this.cScale9 = this.cScale9 || adjust$2(this.primaryColor, { h: 270 }); + this.cScale10 = this.cScale10 || adjust$2(this.primaryColor, { h: 300 }); + this.cScale11 = this.cScale11 || adjust$2(this.primaryColor, { h: 330 }); + this["cScalePeer1"] = this["cScalePeer1"] || darken$1(this.secondaryColor, 45); + this["cScalePeer2"] = this["cScalePeer2"] || darken$1(this.tertiaryColor, 40); + for (let i2 = 0; i2 < this.THEME_COLOR_LIMIT; i2++) { + this["cScale" + i2] = darken$1(this["cScale" + i2], 10); + this["cScalePeer" + i2] = this["cScalePeer" + i2] || darken$1(this["cScale" + i2], 25); + } + for (let i2 = 0; i2 < this.THEME_COLOR_LIMIT; i2++) { + this["cScaleInv" + i2] = this["cScaleInv" + i2] || adjust$2(this["cScale" + i2], { h: 180 }); + } + this.scaleLabelColor = this.scaleLabelColor !== "calculated" && this.scaleLabelColor ? this.scaleLabelColor : this.labelTextColor; + for (let i2 = 0; i2 < this.THEME_COLOR_LIMIT; i2++) { + this["cScaleLabel" + i2] = this["cScaleLabel" + i2] || this.scaleLabelColor; + } + for (let i2 = 0; i2 < 5; i2++) { + this["surface" + i2] = this["surface" + i2] || adjust$2(this.mainBkg, { h: 30, s: -30, l: -(5 + i2 * 5) }); + this["surfacePeer" + i2] = this["surfacePeer" + i2] || adjust$2(this.mainBkg, { h: 30, s: -30, l: -(8 + i2 * 5) }); + } + this.nodeBkg = this.mainBkg; + this.nodeBorder = this.border1; + this.clusterBkg = this.secondBkg; + this.clusterBorder = this.border2; + this.defaultLinkColor = this.lineColor; + this.taskBorderColor = this.border1; + this.taskTextColor = this.taskTextLightColor; + this.taskTextOutsideColor = this.taskTextDarkColor; + this.activeTaskBorderColor = this.taskBorderColor; + this.activeTaskBkgColor = this.mainBkg; + this.transitionColor = this.transitionColor || this.lineColor; + this.transitionLabelColor = this.transitionLabelColor || this.textColor; + this.stateLabelColor = this.stateLabelColor || this.stateBkg || this.primaryTextColor; + this.stateBkg = this.stateBkg || this.mainBkg; + this.labelBackgroundColor = this.labelBackgroundColor || this.stateBkg; + this.compositeBackground = this.compositeBackground || this.background || this.tertiaryColor; + this.altBackground = this.altBackground || "#f0f0f0"; + this.compositeTitleBackground = this.compositeTitleBackground || this.mainBkg; + this.compositeBorder = this.compositeBorder || this.nodeBorder; + this.innerEndBackground = this.primaryBorderColor; + this.specialStateColor = this.lineColor; + this.errorBkgColor = this.errorBkgColor || this.tertiaryColor; + this.errorTextColor = this.errorTextColor || this.tertiaryTextColor; + this.transitionColor = this.transitionColor || this.lineColor; + this.classText = this.primaryTextColor; + this.fillType0 = this.primaryColor; + this.fillType1 = this.secondaryColor; + this.fillType2 = adjust$2(this.primaryColor, { h: 64 }); + this.fillType3 = adjust$2(this.secondaryColor, { h: 64 }); + this.fillType4 = adjust$2(this.primaryColor, { h: -64 }); + this.fillType5 = adjust$2(this.secondaryColor, { h: -64 }); + this.fillType6 = adjust$2(this.primaryColor, { h: 128 }); + this.fillType7 = adjust$2(this.secondaryColor, { h: 128 }); + this.pie1 = this.pie1 || this.primaryColor; + this.pie2 = this.pie2 || this.secondaryColor; + this.pie3 = this.pie3 || this.tertiaryColor; + this.pie4 = this.pie4 || adjust$2(this.primaryColor, { l: -30 }); + this.pie5 = this.pie5 || adjust$2(this.secondaryColor, { l: -30 }); + this.pie6 = this.pie6 || adjust$2(this.tertiaryColor, { h: 40, l: -40 }); + this.pie7 = this.pie7 || adjust$2(this.primaryColor, { h: 60, l: -10 }); + this.pie8 = this.pie8 || adjust$2(this.primaryColor, { h: -60, l: -10 }); + this.pie9 = this.pie9 || adjust$2(this.primaryColor, { h: 120, l: 0 }); + this.pie10 = this.pie10 || adjust$2(this.primaryColor, { h: 60, l: -50 }); + this.pie11 = this.pie11 || adjust$2(this.primaryColor, { h: -60, l: -50 }); + this.pie12 = this.pie12 || adjust$2(this.primaryColor, { h: 120, l: -50 }); + this.pieTitleTextSize = this.pieTitleTextSize || "25px"; + this.pieTitleTextColor = this.pieTitleTextColor || this.taskTextDarkColor; + this.pieSectionTextSize = this.pieSectionTextSize || "17px"; + this.pieSectionTextColor = this.pieSectionTextColor || this.textColor; + this.pieLegendTextSize = this.pieLegendTextSize || "17px"; + this.pieLegendTextColor = this.pieLegendTextColor || this.taskTextDarkColor; + this.pieStrokeColor = this.pieStrokeColor || "black"; + this.pieStrokeWidth = this.pieStrokeWidth || "2px"; + this.pieOuterStrokeWidth = this.pieOuterStrokeWidth || "2px"; + this.pieOuterStrokeColor = this.pieOuterStrokeColor || "black"; + this.pieOpacity = this.pieOpacity || "0.7"; + this.quadrant1Fill = this.quadrant1Fill || this.primaryColor; + this.quadrant2Fill = this.quadrant2Fill || adjust$2(this.primaryColor, { r: 5, g: 5, b: 5 }); + this.quadrant3Fill = this.quadrant3Fill || adjust$2(this.primaryColor, { r: 10, g: 10, b: 10 }); + this.quadrant4Fill = this.quadrant4Fill || adjust$2(this.primaryColor, { r: 15, g: 15, b: 15 }); + this.quadrant1TextFill = this.quadrant1TextFill || this.primaryTextColor; + this.quadrant2TextFill = this.quadrant2TextFill || adjust$2(this.primaryTextColor, { r: -5, g: -5, b: -5 }); + this.quadrant3TextFill = this.quadrant3TextFill || adjust$2(this.primaryTextColor, { r: -10, g: -10, b: -10 }); + this.quadrant4TextFill = this.quadrant4TextFill || adjust$2(this.primaryTextColor, { r: -15, g: -15, b: -15 }); + this.quadrantPointFill = this.quadrantPointFill || isDark$1(this.quadrant1Fill) ? lighten$1(this.quadrant1Fill) : darken$1(this.quadrant1Fill); + this.quadrantPointTextFill = this.quadrantPointTextFill || this.primaryTextColor; + this.quadrantXAxisTextFill = this.quadrantXAxisTextFill || this.primaryTextColor; + this.quadrantYAxisTextFill = this.quadrantYAxisTextFill || this.primaryTextColor; + this.quadrantInternalBorderStrokeFill = this.quadrantInternalBorderStrokeFill || this.primaryBorderColor; + this.quadrantExternalBorderStrokeFill = this.quadrantExternalBorderStrokeFill || this.primaryBorderColor; + this.quadrantTitleFill = this.quadrantTitleFill || this.primaryTextColor; + this.xyChart = { + backgroundColor: ((_a2 = this.xyChart) == null ? void 0 : _a2.backgroundColor) || this.background, + titleColor: ((_b2 = this.xyChart) == null ? void 0 : _b2.titleColor) || this.primaryTextColor, + xAxisTitleColor: ((_c = this.xyChart) == null ? void 0 : _c.xAxisTitleColor) || this.primaryTextColor, + xAxisLabelColor: ((_d = this.xyChart) == null ? void 0 : _d.xAxisLabelColor) || this.primaryTextColor, + xAxisTickColor: ((_e = this.xyChart) == null ? void 0 : _e.xAxisTickColor) || this.primaryTextColor, + xAxisLineColor: ((_f = this.xyChart) == null ? void 0 : _f.xAxisLineColor) || this.primaryTextColor, + yAxisTitleColor: ((_g = this.xyChart) == null ? void 0 : _g.yAxisTitleColor) || this.primaryTextColor, + yAxisLabelColor: ((_h = this.xyChart) == null ? void 0 : _h.yAxisLabelColor) || this.primaryTextColor, + yAxisTickColor: ((_i6 = this.xyChart) == null ? void 0 : _i6.yAxisTickColor) || this.primaryTextColor, + yAxisLineColor: ((_j = this.xyChart) == null ? void 0 : _j.yAxisLineColor) || this.primaryTextColor, + plotColorPalette: ((_k = this.xyChart) == null ? void 0 : _k.plotColorPalette) || "#CDE498,#FF6B6B,#A0D2DB,#D7BDE2,#F0F0F0,#FFC3A0,#7FD8BE,#FF9A8B,#FAF3E0,#FFF176" + }; + this.requirementBackground = this.requirementBackground || this.primaryColor; + this.requirementBorderColor = this.requirementBorderColor || this.primaryBorderColor; + this.requirementBorderSize = this.requirementBorderSize || "1"; + this.requirementTextColor = this.requirementTextColor || this.primaryTextColor; + this.relationColor = this.relationColor || this.lineColor; + this.relationLabelBackground = this.relationLabelBackground || this.edgeLabelBackground; + this.relationLabelColor = this.relationLabelColor || this.actorTextColor; + this.git0 = this.git0 || this.primaryColor; + this.git1 = this.git1 || this.secondaryColor; + this.git2 = this.git2 || this.tertiaryColor; + this.git3 = this.git3 || adjust$2(this.primaryColor, { h: -30 }); + this.git4 = this.git4 || adjust$2(this.primaryColor, { h: -60 }); + this.git5 = this.git5 || adjust$2(this.primaryColor, { h: -90 }); + this.git6 = this.git6 || adjust$2(this.primaryColor, { h: 60 }); + this.git7 = this.git7 || adjust$2(this.primaryColor, { h: 120 }); + if (this.darkMode) { + this.git0 = lighten$1(this.git0, 25); + this.git1 = lighten$1(this.git1, 25); + this.git2 = lighten$1(this.git2, 25); + this.git3 = lighten$1(this.git3, 25); + this.git4 = lighten$1(this.git4, 25); + this.git5 = lighten$1(this.git5, 25); + this.git6 = lighten$1(this.git6, 25); + this.git7 = lighten$1(this.git7, 25); + } else { + this.git0 = darken$1(this.git0, 25); + this.git1 = darken$1(this.git1, 25); + this.git2 = darken$1(this.git2, 25); + this.git3 = darken$1(this.git3, 25); + this.git4 = darken$1(this.git4, 25); + this.git5 = darken$1(this.git5, 25); + this.git6 = darken$1(this.git6, 25); + this.git7 = darken$1(this.git7, 25); + } + this.gitInv0 = this.gitInv0 || invert$1(this.git0); + this.gitInv1 = this.gitInv1 || invert$1(this.git1); + this.gitInv2 = this.gitInv2 || invert$1(this.git2); + this.gitInv3 = this.gitInv3 || invert$1(this.git3); + this.gitInv4 = this.gitInv4 || invert$1(this.git4); + this.gitInv5 = this.gitInv5 || invert$1(this.git5); + this.gitInv6 = this.gitInv6 || invert$1(this.git6); + this.gitInv7 = this.gitInv7 || invert$1(this.git7); + this.gitBranchLabel0 = this.gitBranchLabel0 || invert$1(this.labelTextColor); + this.gitBranchLabel1 = this.gitBranchLabel1 || this.labelTextColor; + this.gitBranchLabel2 = this.gitBranchLabel2 || this.labelTextColor; + this.gitBranchLabel3 = this.gitBranchLabel3 || invert$1(this.labelTextColor); + this.gitBranchLabel4 = this.gitBranchLabel4 || this.labelTextColor; + this.gitBranchLabel5 = this.gitBranchLabel5 || this.labelTextColor; + this.gitBranchLabel6 = this.gitBranchLabel6 || this.labelTextColor; + this.gitBranchLabel7 = this.gitBranchLabel7 || this.labelTextColor; + this.tagLabelColor = this.tagLabelColor || this.primaryTextColor; + this.tagLabelBackground = this.tagLabelBackground || this.primaryColor; + this.tagLabelBorder = this.tagBorder || this.primaryBorderColor; + this.tagLabelFontSize = this.tagLabelFontSize || "10px"; + this.commitLabelColor = this.commitLabelColor || this.secondaryTextColor; + this.commitLabelBackground = this.commitLabelBackground || this.secondaryColor; + this.commitLabelFontSize = this.commitLabelFontSize || "10px"; + this.attributeBackgroundColorOdd = this.attributeBackgroundColorOdd || oldAttributeBackgroundColorOdd; + this.attributeBackgroundColorEven = this.attributeBackgroundColorEven || oldAttributeBackgroundColorEven; + } + calculate(overrides) { + if (typeof overrides !== "object") { + this.updateColors(); + return; + } + const keys2 = Object.keys(overrides); + keys2.forEach((k) => { + this[k] = overrides[k]; + }); + this.updateColors(); + keys2.forEach((k) => { + this[k] = overrides[k]; + }); + } + }; + const getThemeVariables$1 = (userOverrides) => { + const theme2 = new Theme$1(); + theme2.calculate(userOverrides); + return theme2; + }; + class Theme { + constructor() { + this.primaryColor = "#eee"; + this.contrast = "#707070"; + this.secondaryColor = lighten$1(this.contrast, 55); + this.background = "#ffffff"; + this.tertiaryColor = adjust$2(this.primaryColor, { h: -160 }); + this.primaryBorderColor = mkBorder(this.primaryColor, this.darkMode); + this.secondaryBorderColor = mkBorder(this.secondaryColor, this.darkMode); + this.tertiaryBorderColor = mkBorder(this.tertiaryColor, this.darkMode); + this.primaryTextColor = invert$1(this.primaryColor); + this.secondaryTextColor = invert$1(this.secondaryColor); + this.tertiaryTextColor = invert$1(this.tertiaryColor); + this.lineColor = invert$1(this.background); + this.textColor = invert$1(this.background); + this.mainBkg = "#eee"; + this.secondBkg = "calculated"; + this.lineColor = "#666"; + this.border1 = "#999"; + this.border2 = "calculated"; + this.note = "#ffa"; + this.text = "#333"; + this.critical = "#d42"; + this.done = "#bbb"; + this.arrowheadColor = "#333333"; + this.fontFamily = '"trebuchet ms", verdana, arial, sans-serif'; + this.fontSize = "16px"; + this.THEME_COLOR_LIMIT = 12; + this.nodeBkg = "calculated"; + this.nodeBorder = "calculated"; + this.clusterBkg = "calculated"; + this.clusterBorder = "calculated"; + this.defaultLinkColor = "calculated"; + this.titleColor = "calculated"; + this.edgeLabelBackground = "white"; + this.actorBorder = "calculated"; + this.actorBkg = "calculated"; + this.actorTextColor = "calculated"; + this.actorLineColor = "calculated"; + this.signalColor = "calculated"; + this.signalTextColor = "calculated"; + this.labelBoxBkgColor = "calculated"; + this.labelBoxBorderColor = "calculated"; + this.labelTextColor = "calculated"; + this.loopTextColor = "calculated"; + this.noteBorderColor = "calculated"; + this.noteBkgColor = "calculated"; + this.noteTextColor = "calculated"; + this.activationBorderColor = "#666"; + this.activationBkgColor = "#f4f4f4"; + this.sequenceNumberColor = "white"; + this.sectionBkgColor = "calculated"; + this.altSectionBkgColor = "white"; + this.sectionBkgColor2 = "calculated"; + this.excludeBkgColor = "#eeeeee"; + this.taskBorderColor = "calculated"; + this.taskBkgColor = "calculated"; + this.taskTextLightColor = "white"; + this.taskTextColor = "calculated"; + this.taskTextDarkColor = "calculated"; + this.taskTextOutsideColor = "calculated"; + this.taskTextClickableColor = "#003163"; + this.activeTaskBorderColor = "calculated"; + this.activeTaskBkgColor = "calculated"; + this.gridColor = "calculated"; + this.doneTaskBkgColor = "calculated"; + this.doneTaskBorderColor = "calculated"; + this.critBkgColor = "calculated"; + this.critBorderColor = "calculated"; + this.todayLineColor = "calculated"; + this.personBorder = this.primaryBorderColor; + this.personBkg = this.mainBkg; + this.labelColor = "black"; + this.errorBkgColor = "#552222"; + this.errorTextColor = "#552222"; + } + updateColors() { + var _a2, _b2, _c, _d, _e, _f, _g, _h, _i6, _j, _k; + this.secondBkg = lighten$1(this.contrast, 55); + this.border2 = this.contrast; + this.actorBorder = lighten$1(this.border1, 23); + this.actorBkg = this.mainBkg; + this.actorTextColor = this.text; + this.actorLineColor = this.lineColor; + this.signalColor = this.text; + this.signalTextColor = this.text; + this.labelBoxBkgColor = this.actorBkg; + this.labelBoxBorderColor = this.actorBorder; + this.labelTextColor = this.text; + this.loopTextColor = this.text; + this.noteBorderColor = "#999"; + this.noteBkgColor = "#666"; + this.noteTextColor = "#fff"; + this.cScale0 = this.cScale0 || "#555"; + this.cScale1 = this.cScale1 || "#F4F4F4"; + this.cScale2 = this.cScale2 || "#555"; + this.cScale3 = this.cScale3 || "#BBB"; + this.cScale4 = this.cScale4 || "#777"; + this.cScale5 = this.cScale5 || "#999"; + this.cScale6 = this.cScale6 || "#DDD"; + this.cScale7 = this.cScale7 || "#FFF"; + this.cScale8 = this.cScale8 || "#DDD"; + this.cScale9 = this.cScale9 || "#BBB"; + this.cScale10 = this.cScale10 || "#999"; + this.cScale11 = this.cScale11 || "#777"; + for (let i2 = 0; i2 < this.THEME_COLOR_LIMIT; i2++) { + this["cScaleInv" + i2] = this["cScaleInv" + i2] || invert$1(this["cScale" + i2]); + } + for (let i2 = 0; i2 < this.THEME_COLOR_LIMIT; i2++) { + if (this.darkMode) { + this["cScalePeer" + i2] = this["cScalePeer" + i2] || lighten$1(this["cScale" + i2], 10); + } else { + this["cScalePeer" + i2] = this["cScalePeer" + i2] || darken$1(this["cScale" + i2], 10); + } + } + this.scaleLabelColor = this.scaleLabelColor || (this.darkMode ? "black" : this.labelTextColor); + this["cScaleLabel0"] = this["cScaleLabel0"] || this.cScale1; + this["cScaleLabel2"] = this["cScaleLabel2"] || this.cScale1; + for (let i2 = 0; i2 < this.THEME_COLOR_LIMIT; i2++) { + this["cScaleLabel" + i2] = this["cScaleLabel" + i2] || this.scaleLabelColor; + } + for (let i2 = 0; i2 < 5; i2++) { + this["surface" + i2] = this["surface" + i2] || adjust$2(this.mainBkg, { l: -(5 + i2 * 5) }); + this["surfacePeer" + i2] = this["surfacePeer" + i2] || adjust$2(this.mainBkg, { l: -(8 + i2 * 5) }); + } + this.nodeBkg = this.mainBkg; + this.nodeBorder = this.border1; + this.clusterBkg = this.secondBkg; + this.clusterBorder = this.border2; + this.defaultLinkColor = this.lineColor; + this.titleColor = this.text; + this.sectionBkgColor = lighten$1(this.contrast, 30); + this.sectionBkgColor2 = lighten$1(this.contrast, 30); + this.taskBorderColor = darken$1(this.contrast, 10); + this.taskBkgColor = this.contrast; + this.taskTextColor = this.taskTextLightColor; + this.taskTextDarkColor = this.text; + this.taskTextOutsideColor = this.taskTextDarkColor; + this.activeTaskBorderColor = this.taskBorderColor; + this.activeTaskBkgColor = this.mainBkg; + this.gridColor = lighten$1(this.border1, 30); + this.doneTaskBkgColor = this.done; + this.doneTaskBorderColor = this.lineColor; + this.critBkgColor = this.critical; + this.critBorderColor = darken$1(this.critBkgColor, 10); + this.todayLineColor = this.critBkgColor; + this.transitionColor = this.transitionColor || "#000"; + this.transitionLabelColor = this.transitionLabelColor || this.textColor; + this.stateLabelColor = this.stateLabelColor || this.stateBkg || this.primaryTextColor; + this.stateBkg = this.stateBkg || this.mainBkg; + this.labelBackgroundColor = this.labelBackgroundColor || this.stateBkg; + this.compositeBackground = this.compositeBackground || this.background || this.tertiaryColor; + this.altBackground = this.altBackground || "#f4f4f4"; + this.compositeTitleBackground = this.compositeTitleBackground || this.mainBkg; + this.stateBorder = this.stateBorder || "#000"; + this.innerEndBackground = this.primaryBorderColor; + this.specialStateColor = "#222"; + this.errorBkgColor = this.errorBkgColor || this.tertiaryColor; + this.errorTextColor = this.errorTextColor || this.tertiaryTextColor; + this.classText = this.primaryTextColor; + this.fillType0 = this.primaryColor; + this.fillType1 = this.secondaryColor; + this.fillType2 = adjust$2(this.primaryColor, { h: 64 }); + this.fillType3 = adjust$2(this.secondaryColor, { h: 64 }); + this.fillType4 = adjust$2(this.primaryColor, { h: -64 }); + this.fillType5 = adjust$2(this.secondaryColor, { h: -64 }); + this.fillType6 = adjust$2(this.primaryColor, { h: 128 }); + this.fillType7 = adjust$2(this.secondaryColor, { h: 128 }); + for (let i2 = 0; i2 < this.THEME_COLOR_LIMIT; i2++) { + this["pie" + i2] = this["cScale" + i2]; + } + this.pie12 = this.pie0; + this.pieTitleTextSize = this.pieTitleTextSize || "25px"; + this.pieTitleTextColor = this.pieTitleTextColor || this.taskTextDarkColor; + this.pieSectionTextSize = this.pieSectionTextSize || "17px"; + this.pieSectionTextColor = this.pieSectionTextColor || this.textColor; + this.pieLegendTextSize = this.pieLegendTextSize || "17px"; + this.pieLegendTextColor = this.pieLegendTextColor || this.taskTextDarkColor; + this.pieStrokeColor = this.pieStrokeColor || "black"; + this.pieStrokeWidth = this.pieStrokeWidth || "2px"; + this.pieOuterStrokeWidth = this.pieOuterStrokeWidth || "2px"; + this.pieOuterStrokeColor = this.pieOuterStrokeColor || "black"; + this.pieOpacity = this.pieOpacity || "0.7"; + this.quadrant1Fill = this.quadrant1Fill || this.primaryColor; + this.quadrant2Fill = this.quadrant2Fill || adjust$2(this.primaryColor, { r: 5, g: 5, b: 5 }); + this.quadrant3Fill = this.quadrant3Fill || adjust$2(this.primaryColor, { r: 10, g: 10, b: 10 }); + this.quadrant4Fill = this.quadrant4Fill || adjust$2(this.primaryColor, { r: 15, g: 15, b: 15 }); + this.quadrant1TextFill = this.quadrant1TextFill || this.primaryTextColor; + this.quadrant2TextFill = this.quadrant2TextFill || adjust$2(this.primaryTextColor, { r: -5, g: -5, b: -5 }); + this.quadrant3TextFill = this.quadrant3TextFill || adjust$2(this.primaryTextColor, { r: -10, g: -10, b: -10 }); + this.quadrant4TextFill = this.quadrant4TextFill || adjust$2(this.primaryTextColor, { r: -15, g: -15, b: -15 }); + this.quadrantPointFill = this.quadrantPointFill || isDark$1(this.quadrant1Fill) ? lighten$1(this.quadrant1Fill) : darken$1(this.quadrant1Fill); + this.quadrantPointTextFill = this.quadrantPointTextFill || this.primaryTextColor; + this.quadrantXAxisTextFill = this.quadrantXAxisTextFill || this.primaryTextColor; + this.quadrantYAxisTextFill = this.quadrantYAxisTextFill || this.primaryTextColor; + this.quadrantInternalBorderStrokeFill = this.quadrantInternalBorderStrokeFill || this.primaryBorderColor; + this.quadrantExternalBorderStrokeFill = this.quadrantExternalBorderStrokeFill || this.primaryBorderColor; + this.quadrantTitleFill = this.quadrantTitleFill || this.primaryTextColor; + this.xyChart = { + backgroundColor: ((_a2 = this.xyChart) == null ? void 0 : _a2.backgroundColor) || this.background, + titleColor: ((_b2 = this.xyChart) == null ? void 0 : _b2.titleColor) || this.primaryTextColor, + xAxisTitleColor: ((_c = this.xyChart) == null ? void 0 : _c.xAxisTitleColor) || this.primaryTextColor, + xAxisLabelColor: ((_d = this.xyChart) == null ? void 0 : _d.xAxisLabelColor) || this.primaryTextColor, + xAxisTickColor: ((_e = this.xyChart) == null ? void 0 : _e.xAxisTickColor) || this.primaryTextColor, + xAxisLineColor: ((_f = this.xyChart) == null ? void 0 : _f.xAxisLineColor) || this.primaryTextColor, + yAxisTitleColor: ((_g = this.xyChart) == null ? void 0 : _g.yAxisTitleColor) || this.primaryTextColor, + yAxisLabelColor: ((_h = this.xyChart) == null ? void 0 : _h.yAxisLabelColor) || this.primaryTextColor, + yAxisTickColor: ((_i6 = this.xyChart) == null ? void 0 : _i6.yAxisTickColor) || this.primaryTextColor, + yAxisLineColor: ((_j = this.xyChart) == null ? void 0 : _j.yAxisLineColor) || this.primaryTextColor, + plotColorPalette: ((_k = this.xyChart) == null ? void 0 : _k.plotColorPalette) || "#EEE,#6BB8E4,#8ACB88,#C7ACD6,#E8DCC2,#FFB2A8,#FFF380,#7E8D91,#FFD8B1,#FAF3E0" + }; + this.requirementBackground = this.requirementBackground || this.primaryColor; + this.requirementBorderColor = this.requirementBorderColor || this.primaryBorderColor; + this.requirementBorderSize = this.requirementBorderSize || "1"; + this.requirementTextColor = this.requirementTextColor || this.primaryTextColor; + this.relationColor = this.relationColor || this.lineColor; + this.relationLabelBackground = this.relationLabelBackground || this.edgeLabelBackground; + this.relationLabelColor = this.relationLabelColor || this.actorTextColor; + this.git0 = darken$1(this.pie1, 25) || this.primaryColor; + this.git1 = this.pie2 || this.secondaryColor; + this.git2 = this.pie3 || this.tertiaryColor; + this.git3 = this.pie4 || adjust$2(this.primaryColor, { h: -30 }); + this.git4 = this.pie5 || adjust$2(this.primaryColor, { h: -60 }); + this.git5 = this.pie6 || adjust$2(this.primaryColor, { h: -90 }); + this.git6 = this.pie7 || adjust$2(this.primaryColor, { h: 60 }); + this.git7 = this.pie8 || adjust$2(this.primaryColor, { h: 120 }); + this.gitInv0 = this.gitInv0 || invert$1(this.git0); + this.gitInv1 = this.gitInv1 || invert$1(this.git1); + this.gitInv2 = this.gitInv2 || invert$1(this.git2); + this.gitInv3 = this.gitInv3 || invert$1(this.git3); + this.gitInv4 = this.gitInv4 || invert$1(this.git4); + this.gitInv5 = this.gitInv5 || invert$1(this.git5); + this.gitInv6 = this.gitInv6 || invert$1(this.git6); + this.gitInv7 = this.gitInv7 || invert$1(this.git7); + this.branchLabelColor = this.branchLabelColor || this.labelTextColor; + this.gitBranchLabel0 = this.branchLabelColor; + this.gitBranchLabel1 = "white"; + this.gitBranchLabel2 = this.branchLabelColor; + this.gitBranchLabel3 = "white"; + this.gitBranchLabel4 = this.branchLabelColor; + this.gitBranchLabel5 = this.branchLabelColor; + this.gitBranchLabel6 = this.branchLabelColor; + this.gitBranchLabel7 = this.branchLabelColor; + this.tagLabelColor = this.tagLabelColor || this.primaryTextColor; + this.tagLabelBackground = this.tagLabelBackground || this.primaryColor; + this.tagLabelBorder = this.tagBorder || this.primaryBorderColor; + this.tagLabelFontSize = this.tagLabelFontSize || "10px"; + this.commitLabelColor = this.commitLabelColor || this.secondaryTextColor; + this.commitLabelBackground = this.commitLabelBackground || this.secondaryColor; + this.commitLabelFontSize = this.commitLabelFontSize || "10px"; + this.attributeBackgroundColorOdd = this.attributeBackgroundColorOdd || oldAttributeBackgroundColorOdd; + this.attributeBackgroundColorEven = this.attributeBackgroundColorEven || oldAttributeBackgroundColorEven; + } + calculate(overrides) { + if (typeof overrides !== "object") { + this.updateColors(); + return; + } + const keys2 = Object.keys(overrides); + keys2.forEach((k) => { + this[k] = overrides[k]; + }); + this.updateColors(); + keys2.forEach((k) => { + this[k] = overrides[k]; + }); + } + } + const getThemeVariables = (userOverrides) => { + const theme2 = new Theme(); + theme2.calculate(userOverrides); + return theme2; + }; + const theme = { + base: { + getThemeVariables: getThemeVariables$4 + }, + dark: { + getThemeVariables: getThemeVariables$3 + }, + default: { + getThemeVariables: getThemeVariables$2 + }, + forest: { + getThemeVariables: getThemeVariables$1 + }, + neutral: { + getThemeVariables + } + }; + const defaultConfigJson = { + "flowchart": { + "useMaxWidth": true, + "titleTopMargin": 25, + "subGraphTitleMargin": { + "top": 0, + "bottom": 0 + }, + "diagramPadding": 8, + "htmlLabels": true, + "nodeSpacing": 50, + "rankSpacing": 50, + "curve": "basis", + "padding": 15, + "defaultRenderer": "dagre-wrapper", + "wrappingWidth": 200 + }, + "sequence": { + "useMaxWidth": true, + "hideUnusedParticipants": false, + "activationWidth": 10, + "diagramMarginX": 50, + "diagramMarginY": 10, + "actorMargin": 50, + "width": 150, + "height": 65, + "boxMargin": 10, + "boxTextMargin": 5, + "noteMargin": 10, + "messageMargin": 35, + "messageAlign": "center", + "mirrorActors": true, + "forceMenus": false, + "bottomMarginAdj": 1, + "rightAngles": false, + "showSequenceNumbers": false, + "actorFontSize": 14, + "actorFontFamily": '"Open Sans", sans-serif', + "actorFontWeight": 400, + "noteFontSize": 14, + "noteFontFamily": '"trebuchet ms", verdana, arial, sans-serif', + "noteFontWeight": 400, + "noteAlign": "center", + "messageFontSize": 16, + "messageFontFamily": '"trebuchet ms", verdana, arial, sans-serif', + "messageFontWeight": 400, + "wrap": false, + "wrapPadding": 10, + "labelBoxWidth": 50, + "labelBoxHeight": 20 + }, + "gantt": { + "useMaxWidth": true, + "titleTopMargin": 25, + "barHeight": 20, + "barGap": 4, + "topPadding": 50, + "rightPadding": 75, + "leftPadding": 75, + "gridLineStartPadding": 35, + "fontSize": 11, + "sectionFontSize": 11, + "numberSectionStyles": 4, + "axisFormat": "%Y-%m-%d", + "topAxis": false, + "displayMode": "", + "weekday": "sunday" + }, + "journey": { + "useMaxWidth": true, + "diagramMarginX": 50, + "diagramMarginY": 10, + "leftMargin": 150, + "width": 150, + "height": 50, + "boxMargin": 10, + "boxTextMargin": 5, + "noteMargin": 10, + "messageMargin": 35, + "messageAlign": "center", + "bottomMarginAdj": 1, + "rightAngles": false, + "taskFontSize": 14, + "taskFontFamily": '"Open Sans", sans-serif', + "taskMargin": 50, + "activationWidth": 10, + "textPlacement": "fo", + "actorColours": [ + "#8FBC8F", + "#7CFC00", + "#00FFFF", + "#20B2AA", + "#B0E0E6", + "#FFFFE0" + ], + "sectionFills": [ + "#191970", + "#8B008B", + "#4B0082", + "#2F4F4F", + "#800000", + "#8B4513", + "#00008B" + ], + "sectionColours": [ + "#fff" + ] + }, + "class": { + "useMaxWidth": true, + "titleTopMargin": 25, + "arrowMarkerAbsolute": false, + "dividerMargin": 10, + "padding": 5, + "textHeight": 10, + "defaultRenderer": "dagre-wrapper", + "htmlLabels": false + }, + "state": { + "useMaxWidth": true, + "titleTopMargin": 25, + "dividerMargin": 10, + "sizeUnit": 5, + "padding": 8, + "textHeight": 10, + "titleShift": -15, + "noteMargin": 10, + "forkWidth": 70, + "forkHeight": 7, + "miniPadding": 2, + "fontSizeFactor": 5.02, + "fontSize": 24, + "labelHeight": 16, + "edgeLengthFactor": "20", + "compositTitleSize": 35, + "radius": 5, + "defaultRenderer": "dagre-wrapper" + }, + "er": { + "useMaxWidth": true, + "titleTopMargin": 25, + "diagramPadding": 20, + "layoutDirection": "TB", + "minEntityWidth": 100, + "minEntityHeight": 75, + "entityPadding": 15, + "stroke": "gray", + "fill": "honeydew", + "fontSize": 12 + }, + "pie": { + "useMaxWidth": true, + "textPosition": 0.75 + }, + "quadrantChart": { + "useMaxWidth": true, + "chartWidth": 500, + "chartHeight": 500, + "titleFontSize": 20, + "titlePadding": 10, + "quadrantPadding": 5, + "xAxisLabelPadding": 5, + "yAxisLabelPadding": 5, + "xAxisLabelFontSize": 16, + "yAxisLabelFontSize": 16, + "quadrantLabelFontSize": 16, + "quadrantTextTopPadding": 5, + "pointTextPadding": 5, + "pointLabelFontSize": 12, + "pointRadius": 5, + "xAxisPosition": "top", + "yAxisPosition": "left", + "quadrantInternalBorderStrokeWidth": 1, + "quadrantExternalBorderStrokeWidth": 2 + }, + "xyChart": { + "useMaxWidth": true, + "width": 700, + "height": 500, + "titleFontSize": 20, + "titlePadding": 10, + "showTitle": true, + "xAxis": { + "$ref": "#/$defs/XYChartAxisConfig", + "showLabel": true, + "labelFontSize": 14, + "labelPadding": 5, + "showTitle": true, + "titleFontSize": 16, + "titlePadding": 5, + "showTick": true, + "tickLength": 5, + "tickWidth": 2, + "showAxisLine": true, + "axisLineWidth": 2 + }, + "yAxis": { + "$ref": "#/$defs/XYChartAxisConfig", + "showLabel": true, + "labelFontSize": 14, + "labelPadding": 5, + "showTitle": true, + "titleFontSize": 16, + "titlePadding": 5, + "showTick": true, + "tickLength": 5, + "tickWidth": 2, + "showAxisLine": true, + "axisLineWidth": 2 + }, + "chartOrientation": "vertical", + "plotReservedSpacePercent": 50 + }, + "requirement": { + "useMaxWidth": true, + "rect_fill": "#f9f9f9", + "text_color": "#333", + "rect_border_size": "0.5px", + "rect_border_color": "#bbb", + "rect_min_width": 200, + "rect_min_height": 200, + "fontSize": 14, + "rect_padding": 10, + "line_height": 20 + }, + "mindmap": { + "useMaxWidth": true, + "padding": 10, + "maxNodeWidth": 200 + }, + "timeline": { + "useMaxWidth": true, + "diagramMarginX": 50, + "diagramMarginY": 10, + "leftMargin": 150, + "width": 150, + "height": 50, + "boxMargin": 10, + "boxTextMargin": 5, + "noteMargin": 10, + "messageMargin": 35, + "messageAlign": "center", + "bottomMarginAdj": 1, + "rightAngles": false, + "taskFontSize": 14, + "taskFontFamily": '"Open Sans", sans-serif', + "taskMargin": 50, + "activationWidth": 10, + "textPlacement": "fo", + "actorColours": [ + "#8FBC8F", + "#7CFC00", + "#00FFFF", + "#20B2AA", + "#B0E0E6", + "#FFFFE0" + ], + "sectionFills": [ + "#191970", + "#8B008B", + "#4B0082", + "#2F4F4F", + "#800000", + "#8B4513", + "#00008B" + ], + "sectionColours": [ + "#fff" + ], + "disableMulticolor": false + }, + "gitGraph": { + "useMaxWidth": true, + "titleTopMargin": 25, + "diagramPadding": 8, + "nodeLabel": { + "width": 75, + "height": 100, + "x": -25, + "y": 0 + }, + "mainBranchName": "main", + "mainBranchOrder": 0, + "showCommitLabel": true, + "showBranches": true, + "rotateCommitLabel": true, + "parallelCommits": false, + "arrowMarkerAbsolute": false + }, + "c4": { + "useMaxWidth": true, + "diagramMarginX": 50, + "diagramMarginY": 10, + "c4ShapeMargin": 50, + "c4ShapePadding": 20, + "width": 216, + "height": 60, + "boxMargin": 10, + "c4ShapeInRow": 4, + "nextLinePaddingX": 0, + "c4BoundaryInRow": 2, + "personFontSize": 14, + "personFontFamily": '"Open Sans", sans-serif', + "personFontWeight": "normal", + "external_personFontSize": 14, + "external_personFontFamily": '"Open Sans", sans-serif', + "external_personFontWeight": "normal", + "systemFontSize": 14, + "systemFontFamily": '"Open Sans", sans-serif', + "systemFontWeight": "normal", + "external_systemFontSize": 14, + "external_systemFontFamily": '"Open Sans", sans-serif', + "external_systemFontWeight": "normal", + "system_dbFontSize": 14, + "system_dbFontFamily": '"Open Sans", sans-serif', + "system_dbFontWeight": "normal", + "external_system_dbFontSize": 14, + "external_system_dbFontFamily": '"Open Sans", sans-serif', + "external_system_dbFontWeight": "normal", + "system_queueFontSize": 14, + "system_queueFontFamily": '"Open Sans", sans-serif', + "system_queueFontWeight": "normal", + "external_system_queueFontSize": 14, + "external_system_queueFontFamily": '"Open Sans", sans-serif', + "external_system_queueFontWeight": "normal", + "boundaryFontSize": 14, + "boundaryFontFamily": '"Open Sans", sans-serif', + "boundaryFontWeight": "normal", + "messageFontSize": 12, + "messageFontFamily": '"Open Sans", sans-serif', + "messageFontWeight": "normal", + "containerFontSize": 14, + "containerFontFamily": '"Open Sans", sans-serif', + "containerFontWeight": "normal", + "external_containerFontSize": 14, + "external_containerFontFamily": '"Open Sans", sans-serif', + "external_containerFontWeight": "normal", + "container_dbFontSize": 14, + "container_dbFontFamily": '"Open Sans", sans-serif', + "container_dbFontWeight": "normal", + "external_container_dbFontSize": 14, + "external_container_dbFontFamily": '"Open Sans", sans-serif', + "external_container_dbFontWeight": "normal", + "container_queueFontSize": 14, + "container_queueFontFamily": '"Open Sans", sans-serif', + "container_queueFontWeight": "normal", + "external_container_queueFontSize": 14, + "external_container_queueFontFamily": '"Open Sans", sans-serif', + "external_container_queueFontWeight": "normal", + "componentFontSize": 14, + "componentFontFamily": '"Open Sans", sans-serif', + "componentFontWeight": "normal", + "external_componentFontSize": 14, + "external_componentFontFamily": '"Open Sans", sans-serif', + "external_componentFontWeight": "normal", + "component_dbFontSize": 14, + "component_dbFontFamily": '"Open Sans", sans-serif', + "component_dbFontWeight": "normal", + "external_component_dbFontSize": 14, + "external_component_dbFontFamily": '"Open Sans", sans-serif', + "external_component_dbFontWeight": "normal", + "component_queueFontSize": 14, + "component_queueFontFamily": '"Open Sans", sans-serif', + "component_queueFontWeight": "normal", + "external_component_queueFontSize": 14, + "external_component_queueFontFamily": '"Open Sans", sans-serif', + "external_component_queueFontWeight": "normal", + "wrap": true, + "wrapPadding": 10, + "person_bg_color": "#08427B", + "person_border_color": "#073B6F", + "external_person_bg_color": "#686868", + "external_person_border_color": "#8A8A8A", + "system_bg_color": "#1168BD", + "system_border_color": "#3C7FC0", + "system_db_bg_color": "#1168BD", + "system_db_border_color": "#3C7FC0", + "system_queue_bg_color": "#1168BD", + "system_queue_border_color": "#3C7FC0", + "external_system_bg_color": "#999999", + "external_system_border_color": "#8A8A8A", + "external_system_db_bg_color": "#999999", + "external_system_db_border_color": "#8A8A8A", + "external_system_queue_bg_color": "#999999", + "external_system_queue_border_color": "#8A8A8A", + "container_bg_color": "#438DD5", + "container_border_color": "#3C7FC0", + "container_db_bg_color": "#438DD5", + "container_db_border_color": "#3C7FC0", + "container_queue_bg_color": "#438DD5", + "container_queue_border_color": "#3C7FC0", + "external_container_bg_color": "#B3B3B3", + "external_container_border_color": "#A6A6A6", + "external_container_db_bg_color": "#B3B3B3", + "external_container_db_border_color": "#A6A6A6", + "external_container_queue_bg_color": "#B3B3B3", + "external_container_queue_border_color": "#A6A6A6", + "component_bg_color": "#85BBF0", + "component_border_color": "#78A8D8", + "component_db_bg_color": "#85BBF0", + "component_db_border_color": "#78A8D8", + "component_queue_bg_color": "#85BBF0", + "component_queue_border_color": "#78A8D8", + "external_component_bg_color": "#CCCCCC", + "external_component_border_color": "#BFBFBF", + "external_component_db_bg_color": "#CCCCCC", + "external_component_db_border_color": "#BFBFBF", + "external_component_queue_bg_color": "#CCCCCC", + "external_component_queue_border_color": "#BFBFBF" + }, + "sankey": { + "useMaxWidth": true, + "width": 600, + "height": 400, + "linkColor": "gradient", + "nodeAlignment": "justify", + "showValues": true, + "prefix": "", + "suffix": "" + }, + "block": { + "useMaxWidth": true, + "padding": 8 + }, + "theme": "default", + "maxTextSize": 5e4, + "maxEdges": 500, + "darkMode": false, + "fontFamily": '"trebuchet ms", verdana, arial, sans-serif;', + "logLevel": 5, + "securityLevel": "strict", + "startOnLoad": true, + "arrowMarkerAbsolute": false, + "secure": [ + "secure", + "securityLevel", + "startOnLoad", + "maxTextSize", + "maxEdges" + ], + "legacyMathML": false, + "deterministicIds": false, + "fontSize": 16 + }; + const config$4 = { + ...defaultConfigJson, + // Set, even though they're `undefined` so that `configKeys` finds these keys + // TODO: Should we replace these with `null` so that they can go in the JSON Schema? + deterministicIDSeed: void 0, + themeCSS: void 0, + // add non-JSON default config values + themeVariables: theme["default"].getThemeVariables(), + sequence: { + ...defaultConfigJson.sequence, + messageFont: function() { + return { + fontFamily: this.messageFontFamily, + fontSize: this.messageFontSize, + fontWeight: this.messageFontWeight + }; + }, + noteFont: function() { + return { + fontFamily: this.noteFontFamily, + fontSize: this.noteFontSize, + fontWeight: this.noteFontWeight + }; + }, + actorFont: function() { + return { + fontFamily: this.actorFontFamily, + fontSize: this.actorFontSize, + fontWeight: this.actorFontWeight + }; + } + }, + gantt: { + ...defaultConfigJson.gantt, + tickInterval: void 0, + useWidth: void 0 + // can probably be removed since `configKeys` already includes this + }, + c4: { + ...defaultConfigJson.c4, + useWidth: void 0, + personFont: function() { + return { + fontFamily: this.personFontFamily, + fontSize: this.personFontSize, + fontWeight: this.personFontWeight + }; + }, + external_personFont: function() { + return { + fontFamily: this.external_personFontFamily, + fontSize: this.external_personFontSize, + fontWeight: this.external_personFontWeight + }; + }, + systemFont: function() { + return { + fontFamily: this.systemFontFamily, + fontSize: this.systemFontSize, + fontWeight: this.systemFontWeight + }; + }, + external_systemFont: function() { + return { + fontFamily: this.external_systemFontFamily, + fontSize: this.external_systemFontSize, + fontWeight: this.external_systemFontWeight + }; + }, + system_dbFont: function() { + return { + fontFamily: this.system_dbFontFamily, + fontSize: this.system_dbFontSize, + fontWeight: this.system_dbFontWeight + }; + }, + external_system_dbFont: function() { + return { + fontFamily: this.external_system_dbFontFamily, + fontSize: this.external_system_dbFontSize, + fontWeight: this.external_system_dbFontWeight + }; + }, + system_queueFont: function() { + return { + fontFamily: this.system_queueFontFamily, + fontSize: this.system_queueFontSize, + fontWeight: this.system_queueFontWeight + }; + }, + external_system_queueFont: function() { + return { + fontFamily: this.external_system_queueFontFamily, + fontSize: this.external_system_queueFontSize, + fontWeight: this.external_system_queueFontWeight + }; + }, + containerFont: function() { + return { + fontFamily: this.containerFontFamily, + fontSize: this.containerFontSize, + fontWeight: this.containerFontWeight + }; + }, + external_containerFont: function() { + return { + fontFamily: this.external_containerFontFamily, + fontSize: this.external_containerFontSize, + fontWeight: this.external_containerFontWeight + }; + }, + container_dbFont: function() { + return { + fontFamily: this.container_dbFontFamily, + fontSize: this.container_dbFontSize, + fontWeight: this.container_dbFontWeight + }; + }, + external_container_dbFont: function() { + return { + fontFamily: this.external_container_dbFontFamily, + fontSize: this.external_container_dbFontSize, + fontWeight: this.external_container_dbFontWeight + }; + }, + container_queueFont: function() { + return { + fontFamily: this.container_queueFontFamily, + fontSize: this.container_queueFontSize, + fontWeight: this.container_queueFontWeight + }; + }, + external_container_queueFont: function() { + return { + fontFamily: this.external_container_queueFontFamily, + fontSize: this.external_container_queueFontSize, + fontWeight: this.external_container_queueFontWeight + }; + }, + componentFont: function() { + return { + fontFamily: this.componentFontFamily, + fontSize: this.componentFontSize, + fontWeight: this.componentFontWeight + }; + }, + external_componentFont: function() { + return { + fontFamily: this.external_componentFontFamily, + fontSize: this.external_componentFontSize, + fontWeight: this.external_componentFontWeight + }; + }, + component_dbFont: function() { + return { + fontFamily: this.component_dbFontFamily, + fontSize: this.component_dbFontSize, + fontWeight: this.component_dbFontWeight + }; + }, + external_component_dbFont: function() { + return { + fontFamily: this.external_component_dbFontFamily, + fontSize: this.external_component_dbFontSize, + fontWeight: this.external_component_dbFontWeight + }; + }, + component_queueFont: function() { + return { + fontFamily: this.component_queueFontFamily, + fontSize: this.component_queueFontSize, + fontWeight: this.component_queueFontWeight + }; + }, + external_component_queueFont: function() { + return { + fontFamily: this.external_component_queueFontFamily, + fontSize: this.external_component_queueFontSize, + fontWeight: this.external_component_queueFontWeight + }; + }, + boundaryFont: function() { + return { + fontFamily: this.boundaryFontFamily, + fontSize: this.boundaryFontSize, + fontWeight: this.boundaryFontWeight + }; + }, + messageFont: function() { + return { + fontFamily: this.messageFontFamily, + fontSize: this.messageFontSize, + fontWeight: this.messageFontWeight + }; + } + }, + pie: { + ...defaultConfigJson.pie, + useWidth: 984 + }, + xyChart: { + ...defaultConfigJson.xyChart, + useWidth: void 0 + }, + requirement: { + ...defaultConfigJson.requirement, + useWidth: void 0 + }, + gitGraph: { + ...defaultConfigJson.gitGraph, + // TODO: This is a temporary override for `gitGraph`, since every other + // diagram does have `useMaxWidth`, but instead sets it to `true`. + // Should we set this to `true` instead? + useMaxWidth: false + }, + sankey: { + ...defaultConfigJson.sankey, + // this is false, unlike every other diagram (other than gitGraph) + // TODO: can we make this default to `true` instead? + useMaxWidth: false + } + }; + const keyify = (obj, prefix = "") => Object.keys(obj).reduce((res, el) => { + if (Array.isArray(obj[el])) { + return res; + } else if (typeof obj[el] === "object" && obj[el] !== null) { + return [...res, prefix + el, ...keyify(obj[el], "")]; + } + return [...res, prefix + el]; + }, []); + const configKeys = new Set(keyify(config$4, "")); + const defaultConfig$2 = config$4; + const sanitizeDirective = (args) => { + log$1.debug("sanitizeDirective called with", args); + if (typeof args !== "object" || args == null) { + return; + } + if (Array.isArray(args)) { + args.forEach((arg) => sanitizeDirective(arg)); + return; + } + for (const key of Object.keys(args)) { + log$1.debug("Checking key", key); + if (key.startsWith("__") || key.includes("proto") || key.includes("constr") || !configKeys.has(key) || args[key] == null) { + log$1.debug("sanitize deleting key: ", key); + delete args[key]; + continue; + } + if (typeof args[key] === "object") { + log$1.debug("sanitizing object", key); + sanitizeDirective(args[key]); + continue; + } + const cssMatchers = ["themeCSS", "fontFamily", "altFontFamily"]; + for (const cssKey of cssMatchers) { + if (key.includes(cssKey)) { + log$1.debug("sanitizing css option", key); + args[key] = sanitizeCss(args[key]); + } + } + } + if (args.themeVariables) { + for (const k of Object.keys(args.themeVariables)) { + const val = args.themeVariables[k]; + if ((val == null ? void 0 : val.match) && !val.match(/^[\d "#%(),.;A-Za-z]+$/)) { + args.themeVariables[k] = ""; + } + } + } + log$1.debug("After sanitization", args); + }; + const sanitizeCss = (str2) => { + let startCnt = 0; + let endCnt = 0; + for (const element2 of str2) { + if (startCnt < endCnt) { + return "{ /* ERROR: Unbalanced CSS */ }"; + } + if (element2 === "{") { + startCnt++; + } else if (element2 === "}") { + endCnt++; + } + } + if (startCnt !== endCnt) { + return "{ /* ERROR: Unbalanced CSS */ }"; + } + return str2; + }; + const frontMatterRegex = /^-{3}\s*[\n\r](.*?)[\n\r]-{3}\s*[\n\r]+/s; + const directiveRegex = /%{2}{\s*(?:(\w+)\s*:|(\w+))\s*(?:(\w+)|((?:(?!}%{2}).|\r?\n)*))?\s*(?:}%{2})?/gi; + const anyCommentRegex = /\s*%%.*\n/gm; + class UnknownDiagramError extends Error { + constructor(message) { + super(message); + this.name = "UnknownDiagramError"; + } + } + const detectors = {}; + const detectType = function(text2, config2) { + text2 = text2.replace(frontMatterRegex, "").replace(directiveRegex, "").replace(anyCommentRegex, "\n"); + for (const [key, { detector: detector2 }] of Object.entries(detectors)) { + const diagram2 = detector2(text2, config2); + if (diagram2) { + return key; + } + } + throw new UnknownDiagramError( + `No diagram type detected matching given configuration for text: ${text2}` + ); + }; + const registerLazyLoadedDiagrams = (...diagrams2) => { + for (const { id: id2, detector: detector2, loader: loader2 } of diagrams2) { + addDetector(id2, detector2, loader2); + } + }; + const addDetector = (key, detector2, loader2) => { + if (detectors[key]) { + log$1.error(`Detector with key ${key} already exists`); + } else { + detectors[key] = { detector: detector2, loader: loader2 }; + } + log$1.debug(`Detector with key ${key} added${loader2 ? " with loader" : ""}`); + }; + const getDiagramLoader = (key) => { + return detectors[key].loader; + }; + const assignWithDepth = (dst, src, { depth = 2, clobber = false } = {}) => { + const config2 = { depth, clobber }; + if (Array.isArray(src) && !Array.isArray(dst)) { + src.forEach((s) => assignWithDepth(dst, s, config2)); + return dst; + } else if (Array.isArray(src) && Array.isArray(dst)) { + src.forEach((s) => { + if (!dst.includes(s)) { + dst.push(s); + } + }); + return dst; + } + if (dst === void 0 || depth <= 0) { + if (dst !== void 0 && dst !== null && typeof dst === "object" && typeof src === "object") { + return Object.assign(dst, src); + } else { + return src; + } + } + if (src !== void 0 && typeof dst === "object" && typeof src === "object") { + Object.keys(src).forEach((key) => { + if (typeof src[key] === "object" && (dst[key] === void 0 || typeof dst[key] === "object")) { + if (dst[key] === void 0) { + dst[key] = Array.isArray(src[key]) ? [] : {}; + } + dst[key] = assignWithDepth(dst[key], src[key], { depth: depth - 1, clobber }); + } else if (clobber || typeof dst[key] !== "object" && typeof src[key] !== "object") { + dst[key] = src[key]; + } + }); + } + return dst; + }; + const assignWithDepth$1 = assignWithDepth; + var freeGlobal = typeof global == "object" && global && global.Object === Object && global; + const freeGlobal$1 = freeGlobal; + var freeSelf = typeof self == "object" && self && self.Object === Object && self; + var root = freeGlobal$1 || freeSelf || Function("return this")(); + const root$1 = root; + var Symbol$1 = root$1.Symbol; + const Symbol$2 = Symbol$1; + var objectProto$i = Object.prototype; + var hasOwnProperty$g = objectProto$i.hasOwnProperty; + var nativeObjectToString$1 = objectProto$i.toString; + var symToStringTag$1 = Symbol$2 ? Symbol$2.toStringTag : void 0; + function getRawTag(value2) { + var isOwn = hasOwnProperty$g.call(value2, symToStringTag$1), tag = value2[symToStringTag$1]; + try { + value2[symToStringTag$1] = void 0; + var unmasked = true; + } catch (e) { + } + var result = nativeObjectToString$1.call(value2); + if (unmasked) { + if (isOwn) { + value2[symToStringTag$1] = tag; + } else { + delete value2[symToStringTag$1]; + } + } + return result; + } + var objectProto$h = Object.prototype; + var nativeObjectToString = objectProto$h.toString; + function objectToString(value2) { + return nativeObjectToString.call(value2); + } + var nullTag = "[object Null]", undefinedTag = "[object Undefined]"; + var symToStringTag = Symbol$2 ? Symbol$2.toStringTag : void 0; + function baseGetTag(value2) { + if (value2 == null) { + return value2 === void 0 ? undefinedTag : nullTag; + } + return symToStringTag && symToStringTag in Object(value2) ? getRawTag(value2) : objectToString(value2); + } + function isObject$1(value2) { + var type2 = typeof value2; + return value2 != null && (type2 == "object" || type2 == "function"); + } + var asyncTag = "[object AsyncFunction]", funcTag$2 = "[object Function]", genTag$1 = "[object GeneratorFunction]", proxyTag = "[object Proxy]"; + function isFunction(value2) { + if (!isObject$1(value2)) { + return false; + } + var tag = baseGetTag(value2); + return tag == funcTag$2 || tag == genTag$1 || tag == asyncTag || tag == proxyTag; + } + var coreJsData = root$1["__core-js_shared__"]; + const coreJsData$1 = coreJsData; + var maskSrcKey = function() { + var uid = /[^.]+$/.exec(coreJsData$1 && coreJsData$1.keys && coreJsData$1.keys.IE_PROTO || ""); + return uid ? "Symbol(src)_1." + uid : ""; + }(); + function isMasked(func) { + return !!maskSrcKey && maskSrcKey in func; + } + var funcProto$2 = Function.prototype; + var funcToString$2 = funcProto$2.toString; + function toSource(func) { + if (func != null) { + try { + return funcToString$2.call(func); + } catch (e) { + } + try { + return func + ""; + } catch (e) { + } + } + return ""; + } + var reRegExpChar = /[\\^$.*+?()[\]{}|]/g; + var reIsHostCtor = /^\[object .+?Constructor\]$/; + var funcProto$1 = Function.prototype, objectProto$g = Object.prototype; + var funcToString$1 = funcProto$1.toString; + var hasOwnProperty$f = objectProto$g.hasOwnProperty; + var reIsNative = RegExp( + "^" + funcToString$1.call(hasOwnProperty$f).replace(reRegExpChar, "\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g, "$1.*?") + "$" + ); + function baseIsNative(value2) { + if (!isObject$1(value2) || isMasked(value2)) { + return false; + } + var pattern = isFunction(value2) ? reIsNative : reIsHostCtor; + return pattern.test(toSource(value2)); + } + function getValue(object2, key) { + return object2 == null ? void 0 : object2[key]; + } + function getNative(object2, key) { + var value2 = getValue(object2, key); + return baseIsNative(value2) ? value2 : void 0; + } + var nativeCreate = getNative(Object, "create"); + const nativeCreate$1 = nativeCreate; + function hashClear() { + this.__data__ = nativeCreate$1 ? nativeCreate$1(null) : {}; + this.size = 0; + } + function hashDelete(key) { + var result = this.has(key) && delete this.__data__[key]; + this.size -= result ? 1 : 0; + return result; + } + var HASH_UNDEFINED$2 = "__lodash_hash_undefined__"; + var objectProto$f = Object.prototype; + var hasOwnProperty$e = objectProto$f.hasOwnProperty; + function hashGet(key) { + var data = this.__data__; + if (nativeCreate$1) { + var result = data[key]; + return result === HASH_UNDEFINED$2 ? void 0 : result; + } + return hasOwnProperty$e.call(data, key) ? data[key] : void 0; + } + var objectProto$e = Object.prototype; + var hasOwnProperty$d = objectProto$e.hasOwnProperty; + function hashHas(key) { + var data = this.__data__; + return nativeCreate$1 ? data[key] !== void 0 : hasOwnProperty$d.call(data, key); + } + var HASH_UNDEFINED$1 = "__lodash_hash_undefined__"; + function hashSet(key, value2) { + var data = this.__data__; + this.size += this.has(key) ? 0 : 1; + data[key] = nativeCreate$1 && value2 === void 0 ? HASH_UNDEFINED$1 : value2; + return this; + } + function Hash(entries2) { + var index2 = -1, length2 = entries2 == null ? 0 : entries2.length; + this.clear(); + while (++index2 < length2) { + var entry = entries2[index2]; + this.set(entry[0], entry[1]); + } + } + Hash.prototype.clear = hashClear; + Hash.prototype["delete"] = hashDelete; + Hash.prototype.get = hashGet; + Hash.prototype.has = hashHas; + Hash.prototype.set = hashSet; + function listCacheClear() { + this.__data__ = []; + this.size = 0; + } + function eq(value2, other) { + return value2 === other || value2 !== value2 && other !== other; + } + function assocIndexOf(array2, key) { + var length2 = array2.length; + while (length2--) { + if (eq(array2[length2][0], key)) { + return length2; + } + } + return -1; + } + var arrayProto = Array.prototype; + var splice$1 = arrayProto.splice; + function listCacheDelete(key) { + var data = this.__data__, index2 = assocIndexOf(data, key); + if (index2 < 0) { + return false; + } + var lastIndex = data.length - 1; + if (index2 == lastIndex) { + data.pop(); + } else { + splice$1.call(data, index2, 1); + } + --this.size; + return true; + } + function listCacheGet(key) { + var data = this.__data__, index2 = assocIndexOf(data, key); + return index2 < 0 ? void 0 : data[index2][1]; + } + function listCacheHas(key) { + return assocIndexOf(this.__data__, key) > -1; + } + function listCacheSet(key, value2) { + var data = this.__data__, index2 = assocIndexOf(data, key); + if (index2 < 0) { + ++this.size; + data.push([key, value2]); + } else { + data[index2][1] = value2; + } + return this; + } + function ListCache(entries2) { + var index2 = -1, length2 = entries2 == null ? 0 : entries2.length; + this.clear(); + while (++index2 < length2) { + var entry = entries2[index2]; + this.set(entry[0], entry[1]); + } + } + ListCache.prototype.clear = listCacheClear; + ListCache.prototype["delete"] = listCacheDelete; + ListCache.prototype.get = listCacheGet; + ListCache.prototype.has = listCacheHas; + ListCache.prototype.set = listCacheSet; + var Map$1 = getNative(root$1, "Map"); + const Map$2 = Map$1; + function mapCacheClear() { + this.size = 0; + this.__data__ = { + "hash": new Hash(), + "map": new (Map$2 || ListCache)(), + "string": new Hash() + }; + } + function isKeyable(value2) { + var type2 = typeof value2; + return type2 == "string" || type2 == "number" || type2 == "symbol" || type2 == "boolean" ? value2 !== "__proto__" : value2 === null; + } + function getMapData(map2, key) { + var data = map2.__data__; + return isKeyable(key) ? data[typeof key == "string" ? "string" : "hash"] : data.map; + } + function mapCacheDelete(key) { + var result = getMapData(this, key)["delete"](key); + this.size -= result ? 1 : 0; + return result; + } + function mapCacheGet(key) { + return getMapData(this, key).get(key); + } + function mapCacheHas(key) { + return getMapData(this, key).has(key); + } + function mapCacheSet(key, value2) { + var data = getMapData(this, key), size2 = data.size; + data.set(key, value2); + this.size += data.size == size2 ? 0 : 1; + return this; + } + function MapCache(entries2) { + var index2 = -1, length2 = entries2 == null ? 0 : entries2.length; + this.clear(); + while (++index2 < length2) { + var entry = entries2[index2]; + this.set(entry[0], entry[1]); + } + } + MapCache.prototype.clear = mapCacheClear; + MapCache.prototype["delete"] = mapCacheDelete; + MapCache.prototype.get = mapCacheGet; + MapCache.prototype.has = mapCacheHas; + MapCache.prototype.set = mapCacheSet; + var FUNC_ERROR_TEXT = "Expected a function"; + function memoize(func, resolver2) { + if (typeof func != "function" || resolver2 != null && typeof resolver2 != "function") { + throw new TypeError(FUNC_ERROR_TEXT); + } + var memoized = function() { + var args = arguments, key = resolver2 ? resolver2.apply(this, args) : args[0], cache = memoized.cache; + if (cache.has(key)) { + return cache.get(key); + } + var result = func.apply(this, args); + memoized.cache = cache.set(key, result) || cache; + return result; + }; + memoized.cache = new (memoize.Cache || MapCache)(); + return memoized; + } + memoize.Cache = MapCache; + function stackClear() { + this.__data__ = new ListCache(); + this.size = 0; + } + function stackDelete(key) { + var data = this.__data__, result = data["delete"](key); + this.size = data.size; + return result; + } + function stackGet(key) { + return this.__data__.get(key); + } + function stackHas(key) { + return this.__data__.has(key); + } + var LARGE_ARRAY_SIZE$1 = 200; + function stackSet(key, value2) { + var data = this.__data__; + if (data instanceof ListCache) { + var pairs2 = data.__data__; + if (!Map$2 || pairs2.length < LARGE_ARRAY_SIZE$1 - 1) { + pairs2.push([key, value2]); + this.size = ++data.size; + return this; + } + data = this.__data__ = new MapCache(pairs2); + } + data.set(key, value2); + this.size = data.size; + return this; + } + function Stack(entries2) { + var data = this.__data__ = new ListCache(entries2); + this.size = data.size; + } + Stack.prototype.clear = stackClear; + Stack.prototype["delete"] = stackDelete; + Stack.prototype.get = stackGet; + Stack.prototype.has = stackHas; + Stack.prototype.set = stackSet; + var defineProperty = function() { + try { + var func = getNative(Object, "defineProperty"); + func({}, "", {}); + return func; + } catch (e) { + } + }(); + const defineProperty$1 = defineProperty; + function baseAssignValue(object2, key, value2) { + if (key == "__proto__" && defineProperty$1) { + defineProperty$1(object2, key, { + "configurable": true, + "enumerable": true, + "value": value2, + "writable": true + }); + } else { + object2[key] = value2; + } + } + function assignMergeValue(object2, key, value2) { + if (value2 !== void 0 && !eq(object2[key], value2) || value2 === void 0 && !(key in object2)) { + baseAssignValue(object2, key, value2); + } + } + function createBaseFor(fromRight) { + return function(object2, iteratee, keysFunc) { + var index2 = -1, iterable = Object(object2), props = keysFunc(object2), length2 = props.length; + while (length2--) { + var key = props[fromRight ? length2 : ++index2]; + if (iteratee(iterable[key], key, iterable) === false) { + break; + } + } + return object2; + }; + } + var baseFor = createBaseFor(); + const baseFor$1 = baseFor; + var freeExports$2 = typeof exports == "object" && exports && !exports.nodeType && exports; + var freeModule$2 = freeExports$2 && typeof module == "object" && module && !module.nodeType && module; + var moduleExports$2 = freeModule$2 && freeModule$2.exports === freeExports$2; + var Buffer$1 = moduleExports$2 ? root$1.Buffer : void 0, allocUnsafe = Buffer$1 ? Buffer$1.allocUnsafe : void 0; + function cloneBuffer(buffer, isDeep) { + if (isDeep) { + return buffer.slice(); + } + var length2 = buffer.length, result = allocUnsafe ? allocUnsafe(length2) : new buffer.constructor(length2); + buffer.copy(result); + return result; + } + var Uint8Array$1 = root$1.Uint8Array; + const Uint8Array$2 = Uint8Array$1; + function cloneArrayBuffer(arrayBuffer) { + var result = new arrayBuffer.constructor(arrayBuffer.byteLength); + new Uint8Array$2(result).set(new Uint8Array$2(arrayBuffer)); + return result; + } + function cloneTypedArray(typedArray, isDeep) { + var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer; + return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length); + } + function copyArray(source, array2) { + var index2 = -1, length2 = source.length; + array2 || (array2 = Array(length2)); + while (++index2 < length2) { + array2[index2] = source[index2]; + } + return array2; + } + var objectCreate = Object.create; + var baseCreate = function() { + function object2() { + } + return function(proto) { + if (!isObject$1(proto)) { + return {}; + } + if (objectCreate) { + return objectCreate(proto); + } + object2.prototype = proto; + var result = new object2(); + object2.prototype = void 0; + return result; + }; + }(); + const baseCreate$1 = baseCreate; + function overArg(func, transform) { + return function(arg) { + return func(transform(arg)); + }; + } + var getPrototype = overArg(Object.getPrototypeOf, Object); + const getPrototype$1 = getPrototype; + var objectProto$d = Object.prototype; + function isPrototype(value2) { + var Ctor = value2 && value2.constructor, proto = typeof Ctor == "function" && Ctor.prototype || objectProto$d; + return value2 === proto; + } + function initCloneObject(object2) { + return typeof object2.constructor == "function" && !isPrototype(object2) ? baseCreate$1(getPrototype$1(object2)) : {}; + } + function isObjectLike(value2) { + return value2 != null && typeof value2 == "object"; + } + var argsTag$3 = "[object Arguments]"; + function baseIsArguments(value2) { + return isObjectLike(value2) && baseGetTag(value2) == argsTag$3; + } + var objectProto$c = Object.prototype; + var hasOwnProperty$c = objectProto$c.hasOwnProperty; + var propertyIsEnumerable$1 = objectProto$c.propertyIsEnumerable; + var isArguments = baseIsArguments(function() { + return arguments; + }()) ? baseIsArguments : function(value2) { + return isObjectLike(value2) && hasOwnProperty$c.call(value2, "callee") && !propertyIsEnumerable$1.call(value2, "callee"); + }; + const isArguments$1 = isArguments; + var isArray = Array.isArray; + const isArray$1 = isArray; + var MAX_SAFE_INTEGER$1 = 9007199254740991; + function isLength(value2) { + return typeof value2 == "number" && value2 > -1 && value2 % 1 == 0 && value2 <= MAX_SAFE_INTEGER$1; + } + function isArrayLike(value2) { + return value2 != null && isLength(value2.length) && !isFunction(value2); + } + function isArrayLikeObject(value2) { + return isObjectLike(value2) && isArrayLike(value2); + } + function stubFalse() { + return false; + } + var freeExports$1 = typeof exports == "object" && exports && !exports.nodeType && exports; + var freeModule$1 = freeExports$1 && typeof module == "object" && module && !module.nodeType && module; + var moduleExports$1 = freeModule$1 && freeModule$1.exports === freeExports$1; + var Buffer = moduleExports$1 ? root$1.Buffer : void 0; + var nativeIsBuffer = Buffer ? Buffer.isBuffer : void 0; + var isBuffer = nativeIsBuffer || stubFalse; + const isBuffer$1 = isBuffer; + var objectTag$4 = "[object Object]"; + var funcProto = Function.prototype, objectProto$b = Object.prototype; + var funcToString = funcProto.toString; + var hasOwnProperty$b = objectProto$b.hasOwnProperty; + var objectCtorString = funcToString.call(Object); + function isPlainObject(value2) { + if (!isObjectLike(value2) || baseGetTag(value2) != objectTag$4) { + return false; + } + var proto = getPrototype$1(value2); + if (proto === null) { + return true; + } + var Ctor = hasOwnProperty$b.call(proto, "constructor") && proto.constructor; + return typeof Ctor == "function" && Ctor instanceof Ctor && funcToString.call(Ctor) == objectCtorString; + } + var argsTag$2 = "[object Arguments]", arrayTag$2 = "[object Array]", boolTag$3 = "[object Boolean]", dateTag$3 = "[object Date]", errorTag$2 = "[object Error]", funcTag$1 = "[object Function]", mapTag$6 = "[object Map]", numberTag$3 = "[object Number]", objectTag$3 = "[object Object]", regexpTag$3 = "[object RegExp]", setTag$6 = "[object Set]", stringTag$3 = "[object String]", weakMapTag$2 = "[object WeakMap]"; + var arrayBufferTag$3 = "[object ArrayBuffer]", dataViewTag$4 = "[object DataView]", float32Tag$2 = "[object Float32Array]", float64Tag$2 = "[object Float64Array]", int8Tag$2 = "[object Int8Array]", int16Tag$2 = "[object Int16Array]", int32Tag$2 = "[object Int32Array]", uint8Tag$2 = "[object Uint8Array]", uint8ClampedTag$2 = "[object Uint8ClampedArray]", uint16Tag$2 = "[object Uint16Array]", uint32Tag$2 = "[object Uint32Array]"; + var typedArrayTags = {}; + typedArrayTags[float32Tag$2] = typedArrayTags[float64Tag$2] = typedArrayTags[int8Tag$2] = typedArrayTags[int16Tag$2] = typedArrayTags[int32Tag$2] = typedArrayTags[uint8Tag$2] = typedArrayTags[uint8ClampedTag$2] = typedArrayTags[uint16Tag$2] = typedArrayTags[uint32Tag$2] = true; + typedArrayTags[argsTag$2] = typedArrayTags[arrayTag$2] = typedArrayTags[arrayBufferTag$3] = typedArrayTags[boolTag$3] = typedArrayTags[dataViewTag$4] = typedArrayTags[dateTag$3] = typedArrayTags[errorTag$2] = typedArrayTags[funcTag$1] = typedArrayTags[mapTag$6] = typedArrayTags[numberTag$3] = typedArrayTags[objectTag$3] = typedArrayTags[regexpTag$3] = typedArrayTags[setTag$6] = typedArrayTags[stringTag$3] = typedArrayTags[weakMapTag$2] = false; + function baseIsTypedArray(value2) { + return isObjectLike(value2) && isLength(value2.length) && !!typedArrayTags[baseGetTag(value2)]; + } + function baseUnary(func) { + return function(value2) { + return func(value2); + }; + } + var freeExports = typeof exports == "object" && exports && !exports.nodeType && exports; + var freeModule = freeExports && typeof module == "object" && module && !module.nodeType && module; + var moduleExports = freeModule && freeModule.exports === freeExports; + var freeProcess = moduleExports && freeGlobal$1.process; + var nodeUtil = function() { + try { + var types = freeModule && freeModule.require && freeModule.require("util").types; + if (types) { + return types; + } + return freeProcess && freeProcess.binding && freeProcess.binding("util"); + } catch (e) { + } + }(); + const nodeUtil$1 = nodeUtil; + var nodeIsTypedArray = nodeUtil$1 && nodeUtil$1.isTypedArray; + var isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray; + const isTypedArray$1 = isTypedArray; + function safeGet(object2, key) { + if (key === "constructor" && typeof object2[key] === "function") { + return; + } + if (key == "__proto__") { + return; + } + return object2[key]; + } + var objectProto$a = Object.prototype; + var hasOwnProperty$a = objectProto$a.hasOwnProperty; + function assignValue(object2, key, value2) { + var objValue = object2[key]; + if (!(hasOwnProperty$a.call(object2, key) && eq(objValue, value2)) || value2 === void 0 && !(key in object2)) { + baseAssignValue(object2, key, value2); + } + } + function copyObject(source, props, object2, customizer) { + var isNew = !object2; + object2 || (object2 = {}); + var index2 = -1, length2 = props.length; + while (++index2 < length2) { + var key = props[index2]; + var newValue = customizer ? customizer(object2[key], source[key], key, object2, source) : void 0; + if (newValue === void 0) { + newValue = source[key]; + } + if (isNew) { + baseAssignValue(object2, key, newValue); + } else { + assignValue(object2, key, newValue); + } + } + return object2; + } + function baseTimes(n, iteratee) { + var index2 = -1, result = Array(n); + while (++index2 < n) { + result[index2] = iteratee(index2); + } + return result; + } + var MAX_SAFE_INTEGER = 9007199254740991; + var reIsUint = /^(?:0|[1-9]\d*)$/; + function isIndex(value2, length2) { + var type2 = typeof value2; + length2 = length2 == null ? MAX_SAFE_INTEGER : length2; + return !!length2 && (type2 == "number" || type2 != "symbol" && reIsUint.test(value2)) && (value2 > -1 && value2 % 1 == 0 && value2 < length2); + } + var objectProto$9 = Object.prototype; + var hasOwnProperty$9 = objectProto$9.hasOwnProperty; + function arrayLikeKeys(value2, inherited) { + var isArr = isArray$1(value2), isArg = !isArr && isArguments$1(value2), isBuff = !isArr && !isArg && isBuffer$1(value2), isType = !isArr && !isArg && !isBuff && isTypedArray$1(value2), skipIndexes = isArr || isArg || isBuff || isType, result = skipIndexes ? baseTimes(value2.length, String) : [], length2 = result.length; + for (var key in value2) { + if ((inherited || hasOwnProperty$9.call(value2, key)) && !(skipIndexes && // Safari 9 has enumerable `arguments.length` in strict mode. + (key == "length" || // Node.js 0.10 has enumerable non-index properties on buffers. + isBuff && (key == "offset" || key == "parent") || // PhantomJS 2 has enumerable non-index properties on typed arrays. + isType && (key == "buffer" || key == "byteLength" || key == "byteOffset") || // Skip index properties. + isIndex(key, length2)))) { + result.push(key); + } + } + return result; + } + function nativeKeysIn(object2) { + var result = []; + if (object2 != null) { + for (var key in Object(object2)) { + result.push(key); + } + } + return result; + } + var objectProto$8 = Object.prototype; + var hasOwnProperty$8 = objectProto$8.hasOwnProperty; + function baseKeysIn(object2) { + if (!isObject$1(object2)) { + return nativeKeysIn(object2); + } + var isProto = isPrototype(object2), result = []; + for (var key in object2) { + if (!(key == "constructor" && (isProto || !hasOwnProperty$8.call(object2, key)))) { + result.push(key); + } + } + return result; + } + function keysIn(object2) { + return isArrayLike(object2) ? arrayLikeKeys(object2, true) : baseKeysIn(object2); + } + function toPlainObject(value2) { + return copyObject(value2, keysIn(value2)); + } + function baseMergeDeep(object2, source, key, srcIndex, mergeFunc, customizer, stack) { + var objValue = safeGet(object2, key), srcValue = safeGet(source, key), stacked = stack.get(srcValue); + if (stacked) { + assignMergeValue(object2, key, stacked); + return; + } + var newValue = customizer ? customizer(objValue, srcValue, key + "", object2, source, stack) : void 0; + var isCommon = newValue === void 0; + if (isCommon) { + var isArr = isArray$1(srcValue), isBuff = !isArr && isBuffer$1(srcValue), isTyped = !isArr && !isBuff && isTypedArray$1(srcValue); + newValue = srcValue; + if (isArr || isBuff || isTyped) { + if (isArray$1(objValue)) { + newValue = objValue; + } else if (isArrayLikeObject(objValue)) { + newValue = copyArray(objValue); + } else if (isBuff) { + isCommon = false; + newValue = cloneBuffer(srcValue, true); + } else if (isTyped) { + isCommon = false; + newValue = cloneTypedArray(srcValue, true); + } else { + newValue = []; + } + } else if (isPlainObject(srcValue) || isArguments$1(srcValue)) { + newValue = objValue; + if (isArguments$1(objValue)) { + newValue = toPlainObject(objValue); + } else if (!isObject$1(objValue) || isFunction(objValue)) { + newValue = initCloneObject(srcValue); + } + } else { + isCommon = false; + } + } + if (isCommon) { + stack.set(srcValue, newValue); + mergeFunc(newValue, srcValue, srcIndex, customizer, stack); + stack["delete"](srcValue); + } + assignMergeValue(object2, key, newValue); + } + function baseMerge(object2, source, srcIndex, customizer, stack) { + if (object2 === source) { + return; + } + baseFor$1(source, function(srcValue, key) { + stack || (stack = new Stack()); + if (isObject$1(srcValue)) { + baseMergeDeep(object2, source, key, srcIndex, baseMerge, customizer, stack); + } else { + var newValue = customizer ? customizer(safeGet(object2, key), srcValue, key + "", object2, source, stack) : void 0; + if (newValue === void 0) { + newValue = srcValue; + } + assignMergeValue(object2, key, newValue); + } + }, keysIn); + } + function identity(value2) { + return value2; + } + function apply$1(func, thisArg, args) { + switch (args.length) { + case 0: + return func.call(thisArg); + case 1: + return func.call(thisArg, args[0]); + case 2: + return func.call(thisArg, args[0], args[1]); + case 3: + return func.call(thisArg, args[0], args[1], args[2]); + } + return func.apply(thisArg, args); + } + var nativeMax$2 = Math.max; + function overRest(func, start2, transform) { + start2 = nativeMax$2(start2 === void 0 ? func.length - 1 : start2, 0); + return function() { + var args = arguments, index2 = -1, length2 = nativeMax$2(args.length - start2, 0), array2 = Array(length2); + while (++index2 < length2) { + array2[index2] = args[start2 + index2]; + } + index2 = -1; + var otherArgs = Array(start2 + 1); + while (++index2 < start2) { + otherArgs[index2] = args[index2]; + } + otherArgs[start2] = transform(array2); + return apply$1(func, this, otherArgs); + }; + } + function constant$2(value2) { + return function() { + return value2; + }; + } + var baseSetToString = !defineProperty$1 ? identity : function(func, string2) { + return defineProperty$1(func, "toString", { + "configurable": true, + "enumerable": false, + "value": constant$2(string2), + "writable": true + }); + }; + const baseSetToString$1 = baseSetToString; + var HOT_COUNT = 800, HOT_SPAN = 16; + var nativeNow = Date.now; + function shortOut(func) { + var count = 0, lastCalled = 0; + return function() { + var stamp = nativeNow(), remaining = HOT_SPAN - (stamp - lastCalled); + lastCalled = stamp; + if (remaining > 0) { + if (++count >= HOT_COUNT) { + return arguments[0]; + } + } else { + count = 0; + } + return func.apply(void 0, arguments); + }; + } + var setToString = shortOut(baseSetToString$1); + const setToString$1 = setToString; + function baseRest(func, start2) { + return setToString$1(overRest(func, start2, identity), func + ""); + } + function isIterateeCall(value2, index2, object2) { + if (!isObject$1(object2)) { + return false; + } + var type2 = typeof index2; + if (type2 == "number" ? isArrayLike(object2) && isIndex(index2, object2.length) : type2 == "string" && index2 in object2) { + return eq(object2[index2], value2); + } + return false; + } + function createAssigner(assigner) { + return baseRest(function(object2, sources) { + var index2 = -1, length2 = sources.length, customizer = length2 > 1 ? sources[length2 - 1] : void 0, guard = length2 > 2 ? sources[2] : void 0; + customizer = assigner.length > 3 && typeof customizer == "function" ? (length2--, customizer) : void 0; + if (guard && isIterateeCall(sources[0], sources[1], guard)) { + customizer = length2 < 3 ? void 0 : customizer; + length2 = 1; + } + object2 = Object(object2); + while (++index2 < length2) { + var source = sources[index2]; + if (source) { + assigner(object2, source, index2, customizer); + } + } + return object2; + }); + } + var merge$2 = createAssigner(function(object2, source, srcIndex) { + baseMerge(object2, source, srcIndex); + }); + const merge$3 = merge$2; + const ZERO_WIDTH_SPACE = "​"; + const d3CurveTypes = { + curveBasis, + curveBasisClosed, + curveBasisOpen, + curveBumpX: bumpX, + curveBumpY: bumpY, + curveBundle, + curveCardinalClosed, + curveCardinalOpen, + curveCardinal, + curveCatmullRomClosed, + curveCatmullRomOpen, + curveCatmullRom, + curveLinear, + curveLinearClosed, + curveMonotoneX: monotoneX, + curveMonotoneY: monotoneY, + curveNatural, + curveStep, + curveStepAfter: stepAfter, + curveStepBefore: stepBefore + }; + const directiveWithoutOpen = /\s*(?:(\w+)(?=:):|(\w+))\s*(?:(\w+)|((?:(?!}%{2}).|\r?\n)*))?\s*(?:}%{2})?/gi; + const detectInit = function(text2, config2) { + const inits = detectDirective(text2, /(?:init\b)|(?:initialize\b)/); + let results = {}; + if (Array.isArray(inits)) { + const args = inits.map((init2) => init2.args); + sanitizeDirective(args); + results = assignWithDepth$1(results, [...args]); + } else { + results = inits.args; + } + if (!results) { + return; + } + let type2 = detectType(text2, config2); + const prop = "config"; + if (results[prop] !== void 0) { + if (type2 === "flowchart-v2") { + type2 = "flowchart"; + } + results[type2] = results[prop]; + delete results[prop]; + } + return results; + }; + const detectDirective = function(text2, type2 = null) { + try { + const commentWithoutDirectives = new RegExp( + `[%]{2}(?![{]${directiveWithoutOpen.source})(?=[}][%]{2}).* +`, + "ig" + ); + text2 = text2.trim().replace(commentWithoutDirectives, "").replace(/'/gm, '"'); + log$1.debug( + `Detecting diagram directive${type2 !== null ? " type:" + type2 : ""} based on the text:${text2}` + ); + let match; + const result = []; + while ((match = directiveRegex.exec(text2)) !== null) { + if (match.index === directiveRegex.lastIndex) { + directiveRegex.lastIndex++; + } + if (match && !type2 || type2 && match[1] && match[1].match(type2) || type2 && match[2] && match[2].match(type2)) { + const type22 = match[1] ? match[1] : match[2]; + const args = match[3] ? match[3].trim() : match[4] ? JSON.parse(match[4].trim()) : null; + result.push({ type: type22, args }); + } + } + if (result.length === 0) { + return { type: text2, args: null }; + } + return result.length === 1 ? result[0] : result; + } catch (error) { + log$1.error( + `ERROR: ${error.message} - Unable to parse directive type: '${type2}' based on the text: '${text2}'` + ); + return { type: void 0, args: null }; + } + }; + const removeDirectives = function(text2) { + return text2.replace(directiveRegex, ""); + }; + const isSubstringInArray = function(str2, arr) { + for (const [i2, element2] of arr.entries()) { + if (element2.match(str2)) { + return i2; + } + } + return -1; + }; + function interpolateToCurve(interpolate2, defaultCurve) { + if (!interpolate2) { + return defaultCurve; + } + const curveName = `curve${interpolate2.charAt(0).toUpperCase() + interpolate2.slice(1)}`; + return d3CurveTypes[curveName] ?? defaultCurve; + } + function formatUrl(linkStr, config2) { + const url = linkStr.trim(); + if (!url) { + return void 0; + } + if (config2.securityLevel !== "loose") { + return dist.sanitizeUrl(url); + } + return url; + } + const runFunc = (functionName, ...params) => { + const arrPaths = functionName.split("."); + const len = arrPaths.length - 1; + const fnName = arrPaths[len]; + let obj = window; + for (let i2 = 0; i2 < len; i2++) { + obj = obj[arrPaths[i2]]; + if (!obj) { + log$1.error(`Function name: ${functionName} not found in window`); + return; + } + } + obj[fnName](...params); + }; + function distance(p1, p2) { + if (!p1 || !p2) { + return 0; + } + return Math.sqrt(Math.pow(p2.x - p1.x, 2) + Math.pow(p2.y - p1.y, 2)); + } + function traverseEdge(points) { + let prevPoint; + let totalDistance = 0; + points.forEach((point2) => { + totalDistance += distance(point2, prevPoint); + prevPoint = point2; + }); + const remainingDistance = totalDistance / 2; + return calculatePoint(points, remainingDistance); + } + function calcLabelPosition(points) { + if (points.length === 1) { + return points[0]; + } + return traverseEdge(points); + } + const roundNumber = (num, precision = 2) => { + const factor = Math.pow(10, precision); + return Math.round(num * factor) / factor; + }; + const calculatePoint = (points, distanceToTraverse) => { + let prevPoint = void 0; + let remainingDistance = distanceToTraverse; + for (const point2 of points) { + if (prevPoint) { + const vectorDistance = distance(point2, prevPoint); + if (vectorDistance < remainingDistance) { + remainingDistance -= vectorDistance; + } else { + const distanceRatio = remainingDistance / vectorDistance; + if (distanceRatio <= 0) { + return prevPoint; + } + if (distanceRatio >= 1) { + return { x: point2.x, y: point2.y }; + } + if (distanceRatio > 0 && distanceRatio < 1) { + return { + x: roundNumber((1 - distanceRatio) * prevPoint.x + distanceRatio * point2.x, 5), + y: roundNumber((1 - distanceRatio) * prevPoint.y + distanceRatio * point2.y, 5) + }; + } + } + } + prevPoint = point2; + } + throw new Error("Could not find a suitable point for the given distance"); + }; + const calcCardinalityPosition = (isRelationTypePresent, points, initialPosition) => { + log$1.info(`our points ${JSON.stringify(points)}`); + if (points[0] !== initialPosition) { + points = points.reverse(); + } + const distanceToCardinalityPoint = 25; + const center2 = calculatePoint(points, distanceToCardinalityPoint); + const d = isRelationTypePresent ? 10 : 5; + const angle = Math.atan2(points[0].y - center2.y, points[0].x - center2.x); + const cardinalityPosition = { x: 0, y: 0 }; + cardinalityPosition.x = Math.sin(angle) * d + (points[0].x + center2.x) / 2; + cardinalityPosition.y = -Math.cos(angle) * d + (points[0].y + center2.y) / 2; + return cardinalityPosition; + }; + function calcTerminalLabelPosition(terminalMarkerSize, position2, _points) { + const points = structuredClone(_points); + log$1.info("our points", points); + if (position2 !== "start_left" && position2 !== "start_right") { + points.reverse(); + } + const distanceToCardinalityPoint = 25 + terminalMarkerSize; + const center2 = calculatePoint(points, distanceToCardinalityPoint); + const d = 10 + terminalMarkerSize * 0.5; + const angle = Math.atan2(points[0].y - center2.y, points[0].x - center2.x); + const cardinalityPosition = { x: 0, y: 0 }; + if (position2 === "start_left") { + cardinalityPosition.x = Math.sin(angle + Math.PI) * d + (points[0].x + center2.x) / 2; + cardinalityPosition.y = -Math.cos(angle + Math.PI) * d + (points[0].y + center2.y) / 2; + } else if (position2 === "end_right") { + cardinalityPosition.x = Math.sin(angle - Math.PI) * d + (points[0].x + center2.x) / 2 - 5; + cardinalityPosition.y = -Math.cos(angle - Math.PI) * d + (points[0].y + center2.y) / 2 - 5; + } else if (position2 === "end_left") { + cardinalityPosition.x = Math.sin(angle) * d + (points[0].x + center2.x) / 2 - 5; + cardinalityPosition.y = -Math.cos(angle) * d + (points[0].y + center2.y) / 2 - 5; + } else { + cardinalityPosition.x = Math.sin(angle) * d + (points[0].x + center2.x) / 2; + cardinalityPosition.y = -Math.cos(angle) * d + (points[0].y + center2.y) / 2; + } + return cardinalityPosition; + } + function getStylesFromArray(arr) { + let style = ""; + let labelStyle = ""; + for (const element2 of arr) { + if (element2 !== void 0) { + if (element2.startsWith("color:") || element2.startsWith("text-align:")) { + labelStyle = labelStyle + element2 + ";"; + } else { + style = style + element2 + ";"; + } + } + } + return { style, labelStyle }; + } + let cnt$2 = 0; + const generateId$2 = () => { + cnt$2++; + return "id-" + Math.random().toString(36).substr(2, 12) + "-" + cnt$2; + }; + function makeRandomHex(length2) { + let result = ""; + const characters2 = "0123456789abcdef"; + const charactersLength = characters2.length; + for (let i2 = 0; i2 < length2; i2++) { + result += characters2.charAt(Math.floor(Math.random() * charactersLength)); + } + return result; + } + const random = (options2) => { + return makeRandomHex(options2.length); + }; + const getTextObj$3 = function() { + return { + x: 0, + y: 0, + fill: void 0, + anchor: "start", + style: "#666", + width: 100, + height: 100, + textMargin: 0, + rx: 0, + ry: 0, + valign: void 0, + text: "" + }; + }; + const drawSimpleText = function(elem, textData) { + const nText = textData.text.replace(common$1.lineBreakRegex, " "); + const [, _fontSizePx] = parseFontSize(textData.fontSize); + const textElem = elem.append("text"); + textElem.attr("x", textData.x); + textElem.attr("y", textData.y); + textElem.style("text-anchor", textData.anchor); + textElem.style("font-family", textData.fontFamily); + textElem.style("font-size", _fontSizePx); + textElem.style("font-weight", textData.fontWeight); + textElem.attr("fill", textData.fill); + if (textData.class !== void 0) { + textElem.attr("class", textData.class); + } + const span = textElem.append("tspan"); + span.attr("x", textData.x + textData.textMargin * 2); + span.attr("fill", textData.fill); + span.text(nText); + return textElem; + }; + const wrapLabel = memoize( + (label, maxWidth, config2) => { + if (!label) { + return label; + } + config2 = Object.assign( + { fontSize: 12, fontWeight: 400, fontFamily: "Arial", joinWith: "
    " }, + config2 + ); + if (common$1.lineBreakRegex.test(label)) { + return label; + } + const words = label.split(" "); + const completedLines = []; + let nextLine = ""; + words.forEach((word, index2) => { + const wordLength = calculateTextWidth(`${word} `, config2); + const nextLineLength = calculateTextWidth(nextLine, config2); + if (wordLength > maxWidth) { + const { hyphenatedStrings, remainingWord } = breakString(word, maxWidth, "-", config2); + completedLines.push(nextLine, ...hyphenatedStrings); + nextLine = remainingWord; + } else if (nextLineLength + wordLength >= maxWidth) { + completedLines.push(nextLine); + nextLine = word; + } else { + nextLine = [nextLine, word].filter(Boolean).join(" "); + } + const currentWord = index2 + 1; + const isLastWord = currentWord === words.length; + if (isLastWord) { + completedLines.push(nextLine); + } + }); + return completedLines.filter((line2) => line2 !== "").join(config2.joinWith); + }, + (label, maxWidth, config2) => `${label}${maxWidth}${config2.fontSize}${config2.fontWeight}${config2.fontFamily}${config2.joinWith}` + ); + const breakString = memoize( + (word, maxWidth, hyphenCharacter = "-", config2) => { + config2 = Object.assign( + { fontSize: 12, fontWeight: 400, fontFamily: "Arial", margin: 0 }, + config2 + ); + const characters2 = [...word]; + const lines = []; + let currentLine = ""; + characters2.forEach((character2, index2) => { + const nextLine = `${currentLine}${character2}`; + const lineWidth = calculateTextWidth(nextLine, config2); + if (lineWidth >= maxWidth) { + const currentCharacter = index2 + 1; + const isLastLine = characters2.length === currentCharacter; + const hyphenatedNextLine = `${nextLine}${hyphenCharacter}`; + lines.push(isLastLine ? nextLine : hyphenatedNextLine); + currentLine = ""; + } else { + currentLine = nextLine; + } + }); + return { hyphenatedStrings: lines, remainingWord: currentLine }; + }, + (word, maxWidth, hyphenCharacter = "-", config2) => `${word}${maxWidth}${hyphenCharacter}${config2.fontSize}${config2.fontWeight}${config2.fontFamily}` + ); + function calculateTextHeight(text2, config2) { + return calculateTextDimensions(text2, config2).height; + } + function calculateTextWidth(text2, config2) { + return calculateTextDimensions(text2, config2).width; + } + const calculateTextDimensions = memoize( + (text2, config2) => { + const { fontSize = 12, fontFamily = "Arial", fontWeight = 400 } = config2; + if (!text2) { + return { width: 0, height: 0 }; + } + const [, _fontSizePx] = parseFontSize(fontSize); + const fontFamilies = ["sans-serif", fontFamily]; + const lines = text2.split(common$1.lineBreakRegex); + const dims = []; + const body = d3select("body"); + if (!body.remove) { + return { width: 0, height: 0, lineHeight: 0 }; + } + const g = body.append("svg"); + for (const fontFamily2 of fontFamilies) { + let cHeight = 0; + const dim = { width: 0, height: 0, lineHeight: 0 }; + for (const line2 of lines) { + const textObj = getTextObj$3(); + textObj.text = line2 || ZERO_WIDTH_SPACE; + const textElem = drawSimpleText(g, textObj).style("font-size", _fontSizePx).style("font-weight", fontWeight).style("font-family", fontFamily2); + const bBox = (textElem._groups || textElem)[0][0].getBBox(); + if (bBox.width === 0 && bBox.height === 0) { + throw new Error("svg element not in render tree"); + } + dim.width = Math.round(Math.max(dim.width, bBox.width)); + cHeight = Math.round(bBox.height); + dim.height += cHeight; + dim.lineHeight = Math.round(Math.max(dim.lineHeight, cHeight)); + } + dims.push(dim); + } + g.remove(); + const index2 = isNaN(dims[1].height) || isNaN(dims[1].width) || isNaN(dims[1].lineHeight) || dims[0].height > dims[1].height && dims[0].width > dims[1].width && dims[0].lineHeight > dims[1].lineHeight ? 0 : 1; + return dims[index2]; + }, + (text2, config2) => `${text2}${config2.fontSize}${config2.fontWeight}${config2.fontFamily}` + ); + class InitIDGenerator { + constructor(deterministic = false, seed) { + this.count = 0; + this.count = seed ? seed.length : 0; + this.next = deterministic ? () => this.count++ : () => Date.now(); + } + } + let decoder; + const entityDecode = function(html2) { + decoder = decoder || document.createElement("div"); + html2 = escape(html2).replace(/%26/g, "&").replace(/%23/g, "#").replace(/%3B/g, ";"); + decoder.innerHTML = html2; + return unescape(decoder.textContent); + }; + function isDetailedError(error) { + return "str" in error; + } + const insertTitle = (parent, cssClass, titleTopMargin, title2) => { + var _a2; + if (!title2) { + return; + } + const bounds2 = (_a2 = parent.node()) == null ? void 0 : _a2.getBBox(); + if (!bounds2) { + return; + } + parent.append("text").text(title2).attr("x", bounds2.x + bounds2.width / 2).attr("y", -titleTopMargin).attr("class", cssClass); + }; + const parseFontSize = (fontSize) => { + if (typeof fontSize === "number") { + return [fontSize, fontSize + "px"]; + } + const fontSizeNumber = parseInt(fontSize ?? "", 10); + if (Number.isNaN(fontSizeNumber)) { + return [void 0, void 0]; + } else if (fontSize === String(fontSizeNumber)) { + return [fontSizeNumber, fontSize + "px"]; + } else { + return [fontSizeNumber, fontSize]; + } + }; + function cleanAndMerge(defaultData, data) { + return merge$3({}, defaultData, data); + } + const utils$1 = { + assignWithDepth: assignWithDepth$1, + wrapLabel, + calculateTextHeight, + calculateTextWidth, + calculateTextDimensions, + cleanAndMerge, + detectInit, + detectDirective, + isSubstringInArray, + interpolateToCurve, + calcLabelPosition, + calcCardinalityPosition, + calcTerminalLabelPosition, + formatUrl, + getStylesFromArray, + generateId: generateId$2, + random, + runFunc, + entityDecode, + insertTitle, + parseFontSize, + InitIDGenerator + }; + const encodeEntities = function(text2) { + let txt = text2; + txt = txt.replace(/style.*:\S*#.*;/g, function(s) { + return s.substring(0, s.length - 1); + }); + txt = txt.replace(/classDef.*:\S*#.*;/g, function(s) { + return s.substring(0, s.length - 1); + }); + txt = txt.replace(/#\w+;/g, function(s) { + const innerTxt = s.substring(1, s.length - 1); + const isInt = /^\+?\d+$/.test(innerTxt); + if (isInt) { + return "fl°°" + innerTxt + "¶ß"; + } else { + return "fl°" + innerTxt + "¶ß"; + } + }); + return txt; + }; + const decodeEntities = function(text2) { + return text2.replace(/fl°°/g, "&#").replace(/fl°/g, "&").replace(/¶ß/g, ";"); + }; + var COMMENT = "comm"; + var RULESET = "rule"; + var DECLARATION = "decl"; + var IMPORT = "@import"; + var KEYFRAMES = "@keyframes"; + var LAYER = "@layer"; + var abs = Math.abs; + var from = String.fromCharCode; + function trim(value2) { + return value2.trim(); + } + function replace(value2, pattern, replacement) { + return value2.replace(pattern, replacement); + } + function indexof(value2, search2, position2) { + return value2.indexOf(search2, position2); + } + function charat(value2, index2) { + return value2.charCodeAt(index2) | 0; + } + function substr(value2, begin, end2) { + return value2.slice(begin, end2); + } + function strlen(value2) { + return value2.length; + } + function sizeof(value2) { + return value2.length; + } + function append(value2, array2) { + return array2.push(value2), value2; + } + var line = 1; + var column = 1; + var length = 0; + var position$2 = 0; + var character = 0; + var characters = ""; + function node$1(value2, root2, parent, type2, props, children2, length2, siblings) { + return { value: value2, root: root2, parent, type: type2, props, children: children2, line, column, length: length2, return: "", siblings }; + } + function char() { + return character; + } + function prev() { + character = position$2 > 0 ? charat(characters, --position$2) : 0; + if (column--, character === 10) + column = 1, line--; + return character; + } + function next$1() { + character = position$2 < length ? charat(characters, position$2++) : 0; + if (column++, character === 10) + column = 1, line++; + return character; + } + function peek() { + return charat(characters, position$2); + } + function caret() { + return position$2; + } + function slice$1(begin, end2) { + return substr(characters, begin, end2); + } + function token(type2) { + switch (type2) { + case 0: + case 9: + case 10: + case 13: + case 32: + return 5; + case 33: + case 43: + case 44: + case 47: + case 62: + case 64: + case 126: + case 59: + case 123: + case 125: + return 4; + case 58: + return 3; + case 34: + case 39: + case 40: + case 91: + return 2; + case 41: + case 93: + return 1; + } + return 0; + } + function alloc(value2) { + return line = column = 1, length = strlen(characters = value2), position$2 = 0, []; + } + function dealloc(value2) { + return characters = "", value2; + } + function delimit(type2) { + return trim(slice$1(position$2 - 1, delimiter$1(type2 === 91 ? type2 + 2 : type2 === 40 ? type2 + 1 : type2))); + } + function whitespace(type2) { + while (character = peek()) + if (character < 33) + next$1(); + else + break; + return token(type2) > 2 || token(character) > 3 ? "" : " "; + } + function escaping(index2, count) { + while (--count && next$1()) + if (character < 48 || character > 102 || character > 57 && character < 65 || character > 70 && character < 97) + break; + return slice$1(index2, caret() + (count < 6 && peek() == 32 && next$1() == 32)); + } + function delimiter$1(type2) { + while (next$1()) + switch (character) { + case type2: + return position$2; + case 34: + case 39: + if (type2 !== 34 && type2 !== 39) + delimiter$1(character); + break; + case 40: + if (type2 === 41) + delimiter$1(type2); + break; + case 92: + next$1(); + break; + } + return position$2; + } + function commenter(type2, index2) { + while (next$1()) + if (type2 + character === 47 + 10) + break; + else if (type2 + character === 42 + 42 && peek() === 47) + break; + return "/*" + slice$1(index2, position$2 - 1) + "*" + from(type2 === 47 ? type2 : next$1()); + } + function identifier(index2) { + while (!token(peek())) + next$1(); + return slice$1(index2, position$2); + } + function compile(value2) { + return dealloc(parse$4("", null, null, null, [""], value2 = alloc(value2), 0, [0], value2)); + } + function parse$4(value2, root2, parent, rule, rules, rulesets, pseudo, points, declarations) { + var index2 = 0; + var offset = 0; + var length2 = pseudo; + var atrule = 0; + var property2 = 0; + var previous2 = 0; + var variable = 1; + var scanning = 1; + var ampersand = 1; + var character2 = 0; + var type2 = ""; + var props = rules; + var children2 = rulesets; + var reference = rule; + var characters2 = type2; + while (scanning) + switch (previous2 = character2, character2 = next$1()) { + case 40: + if (previous2 != 108 && charat(characters2, length2 - 1) == 58) { + if (indexof(characters2 += replace(delimit(character2), "&", "&\f"), "&\f", abs(index2 ? points[index2 - 1] : 0)) != -1) + ampersand = -1; + break; + } + case 34: + case 39: + case 91: + characters2 += delimit(character2); + break; + case 9: + case 10: + case 13: + case 32: + characters2 += whitespace(previous2); + break; + case 92: + characters2 += escaping(caret() - 1, 7); + continue; + case 47: + switch (peek()) { + case 42: + case 47: + append(comment(commenter(next$1(), caret()), root2, parent, declarations), declarations); + break; + default: + characters2 += "/"; + } + break; + case 123 * variable: + points[index2++] = strlen(characters2) * ampersand; + case 125 * variable: + case 59: + case 0: + switch (character2) { + case 0: + case 125: + scanning = 0; + case 59 + offset: + if (ampersand == -1) + characters2 = replace(characters2, /\f/g, ""); + if (property2 > 0 && strlen(characters2) - length2) + append(property2 > 32 ? declaration(characters2 + ";", rule, parent, length2 - 1, declarations) : declaration(replace(characters2, " ", "") + ";", rule, parent, length2 - 2, declarations), declarations); + break; + case 59: + characters2 += ";"; + default: + append(reference = ruleset(characters2, root2, parent, index2, offset, rules, points, type2, props = [], children2 = [], length2, rulesets), rulesets); + if (character2 === 123) + if (offset === 0) + parse$4(characters2, root2, reference, reference, props, rulesets, length2, points, children2); + else + switch (atrule === 99 && charat(characters2, 3) === 110 ? 100 : atrule) { + case 100: + case 108: + case 109: + case 115: + parse$4(value2, reference, reference, rule && append(ruleset(value2, reference, reference, 0, 0, rules, points, type2, rules, props = [], length2, children2), children2), rules, children2, length2, points, rule ? props : children2); + break; + default: + parse$4(characters2, reference, reference, reference, [""], children2, 0, points, children2); + } + } + index2 = offset = property2 = 0, variable = ampersand = 1, type2 = characters2 = "", length2 = pseudo; + break; + case 58: + length2 = 1 + strlen(characters2), property2 = previous2; + default: + if (variable < 1) { + if (character2 == 123) + --variable; + else if (character2 == 125 && variable++ == 0 && prev() == 125) + continue; + } + switch (characters2 += from(character2), character2 * variable) { + case 38: + ampersand = offset > 0 ? 1 : (characters2 += "\f", -1); + break; + case 44: + points[index2++] = (strlen(characters2) - 1) * ampersand, ampersand = 1; + break; + case 64: + if (peek() === 45) + characters2 += delimit(next$1()); + atrule = peek(), offset = length2 = strlen(type2 = characters2 += identifier(caret())), character2++; + break; + case 45: + if (previous2 === 45 && strlen(characters2) == 2) + variable = 0; + } + } + return rulesets; + } + function ruleset(value2, root2, parent, index2, offset, rules, points, type2, props, children2, length2, siblings) { + var post = offset - 1; + var rule = offset === 0 ? rules : [""]; + var size2 = sizeof(rule); + for (var i2 = 0, j = 0, k = 0; i2 < index2; ++i2) + for (var x2 = 0, y2 = substr(value2, post + 1, post = abs(j = points[i2])), z = value2; x2 < size2; ++x2) + if (z = trim(j > 0 ? rule[x2] + " " + y2 : replace(y2, /&\f/g, rule[x2]))) + props[k++] = z; + return node$1(value2, root2, parent, offset === 0 ? RULESET : type2, props, children2, length2, siblings); + } + function comment(value2, root2, parent, siblings) { + return node$1(value2, root2, parent, COMMENT, from(char()), substr(value2, 2, -2), 0, siblings); + } + function declaration(value2, root2, parent, length2, siblings) { + return node$1(value2, root2, parent, DECLARATION, substr(value2, 0, length2), substr(value2, length2 + 1, -1), length2, siblings); + } + function serialize(children2, callback) { + var output = ""; + for (var i2 = 0; i2 < children2.length; i2++) + output += callback(children2[i2], i2, children2, callback) || ""; + return output; + } + function stringify(element2, index2, children2, callback) { + switch (element2.type) { + case LAYER: + if (element2.children.length) + break; + case IMPORT: + case DECLARATION: + return element2.return = element2.return || element2.value; + case COMMENT: + return ""; + case KEYFRAMES: + return element2.return = element2.value + "{" + serialize(element2.children, callback) + "}"; + case RULESET: + if (!strlen(element2.value = element2.props.join(","))) + return ""; + } + return strlen(children2 = serialize(element2.children, callback)) ? element2.return = element2.value + "{" + children2 + "}" : ""; + } + const version$1 = "10.9.1"; + const defaultConfig$1 = Object.freeze(defaultConfig$2); + let siteConfig = assignWithDepth$1({}, defaultConfig$1); + let configFromInitialize; + let directives = []; + let currentConfig = assignWithDepth$1({}, defaultConfig$1); + const updateCurrentConfig = (siteCfg, _directives) => { + let cfg = assignWithDepth$1({}, siteCfg); + let sumOfDirectives = {}; + for (const d of _directives) { + sanitize(d); + sumOfDirectives = assignWithDepth$1(sumOfDirectives, d); + } + cfg = assignWithDepth$1(cfg, sumOfDirectives); + if (sumOfDirectives.theme && sumOfDirectives.theme in theme) { + const tmpConfigFromInitialize = assignWithDepth$1({}, configFromInitialize); + const themeVariables = assignWithDepth$1( + tmpConfigFromInitialize.themeVariables || {}, + sumOfDirectives.themeVariables + ); + if (cfg.theme && cfg.theme in theme) { + cfg.themeVariables = theme[cfg.theme].getThemeVariables(themeVariables); + } + } + currentConfig = cfg; + checkConfig(currentConfig); + return currentConfig; + }; + const setSiteConfig = (conf2) => { + siteConfig = assignWithDepth$1({}, defaultConfig$1); + siteConfig = assignWithDepth$1(siteConfig, conf2); + if (conf2.theme && theme[conf2.theme]) { + siteConfig.themeVariables = theme[conf2.theme].getThemeVariables(conf2.themeVariables); + } + updateCurrentConfig(siteConfig, directives); + return siteConfig; + }; + const saveConfigFromInitialize = (conf2) => { + configFromInitialize = assignWithDepth$1({}, conf2); + }; + const updateSiteConfig = (conf2) => { + siteConfig = assignWithDepth$1(siteConfig, conf2); + updateCurrentConfig(siteConfig, directives); + return siteConfig; + }; + const getSiteConfig = () => { + return assignWithDepth$1({}, siteConfig); + }; + const setConfig$1 = (conf2) => { + checkConfig(conf2); + assignWithDepth$1(currentConfig, conf2); + return getConfig$2(); + }; + const getConfig$2 = () => { + return assignWithDepth$1({}, currentConfig); + }; + const sanitize = (options2) => { + if (!options2) { + return; + } + ["secure", ...siteConfig.secure ?? []].forEach((key) => { + if (Object.hasOwn(options2, key)) { + log$1.debug(`Denied attempt to modify a secure key ${key}`, options2[key]); + delete options2[key]; + } + }); + Object.keys(options2).forEach((key) => { + if (key.startsWith("__")) { + delete options2[key]; + } + }); + Object.keys(options2).forEach((key) => { + if (typeof options2[key] === "string" && (options2[key].includes("<") || options2[key].includes(">") || options2[key].includes("url(data:"))) { + delete options2[key]; + } + if (typeof options2[key] === "object") { + sanitize(options2[key]); + } + }); + }; + const addDirective = (directive) => { + sanitizeDirective(directive); + if (directive.fontFamily && (!directive.themeVariables || !directive.themeVariables.fontFamily)) { + directive.themeVariables = { fontFamily: directive.fontFamily }; + } + directives.push(directive); + updateCurrentConfig(siteConfig, directives); + }; + const reset = (config2 = siteConfig) => { + directives = []; + updateCurrentConfig(config2, directives); + }; + const ConfigWarning = { + LAZY_LOAD_DEPRECATED: "The configuration options lazyLoadedDiagrams and loadExternalDiagramsAtStartup are deprecated. Please use registerExternalDiagrams instead." + }; + const issuedWarnings = {}; + const issueWarning = (warning) => { + if (issuedWarnings[warning]) { + return; + } + log$1.warn(ConfigWarning[warning]); + issuedWarnings[warning] = true; + }; + const checkConfig = (config2) => { + if (!config2) { + return; + } + if (config2.lazyLoadedDiagrams || config2.loadExternalDiagramsAtStartup) { + issueWarning("LAZY_LOAD_DEPRECATED"); + } + }; + const id$l = "c4"; + const detector$l = (txt) => { + return /^\s*C4Context|C4Container|C4Component|C4Dynamic|C4Deployment/.test(txt); + }; + const loader$m = async () => { + const { diagram: diagram2 } = await Promise.resolve().then(() => c4Diagram); + return { id: id$l, diagram: diagram2 }; + }; + const plugin$j = { + id: id$l, + detector: detector$l, + loader: loader$m + }; + const c4 = plugin$j; + const id$k = "flowchart"; + const detector$k = (txt, config2) => { + var _a2, _b2; + if (((_a2 = config2 == null ? void 0 : config2.flowchart) == null ? void 0 : _a2.defaultRenderer) === "dagre-wrapper" || ((_b2 = config2 == null ? void 0 : config2.flowchart) == null ? void 0 : _b2.defaultRenderer) === "elk") { + return false; + } + return /^\s*graph/.test(txt); + }; + const loader$l = async () => { + const { diagram: diagram2 } = await Promise.resolve().then(() => flowDiagram); + return { id: id$k, diagram: diagram2 }; + }; + const plugin$i = { + id: id$k, + detector: detector$k, + loader: loader$l + }; + const flowchart = plugin$i; + const id$j = "flowchart-v2"; + const detector$j = (txt, config2) => { + var _a2, _b2, _c; + if (((_a2 = config2 == null ? void 0 : config2.flowchart) == null ? void 0 : _a2.defaultRenderer) === "dagre-d3" || ((_b2 = config2 == null ? void 0 : config2.flowchart) == null ? void 0 : _b2.defaultRenderer) === "elk") { + return false; + } + if (/^\s*graph/.test(txt) && ((_c = config2 == null ? void 0 : config2.flowchart) == null ? void 0 : _c.defaultRenderer) === "dagre-wrapper") { + return true; + } + return /^\s*flowchart/.test(txt); + }; + const loader$k = async () => { + const { diagram: diagram2 } = await Promise.resolve().then(() => flowDiagramV2); + return { id: id$j, diagram: diagram2 }; + }; + const plugin$h = { + id: id$j, + detector: detector$j, + loader: loader$k + }; + const flowchartV2 = plugin$h; + const id$i = "er"; + const detector$i = (txt) => { + return /^\s*erDiagram/.test(txt); + }; + const loader$j = async () => { + const { diagram: diagram2 } = await Promise.resolve().then(() => erDiagram); + return { id: id$i, diagram: diagram2 }; + }; + const plugin$g = { + id: id$i, + detector: detector$i, + loader: loader$j + }; + const er = plugin$g; + const id$h = "gitGraph"; + const detector$h = (txt) => { + return /^\s*gitGraph/.test(txt); + }; + const loader$i = async () => { + const { diagram: diagram2 } = await Promise.resolve().then(() => gitGraphDiagram); + return { id: id$h, diagram: diagram2 }; + }; + const plugin$f = { + id: id$h, + detector: detector$h, + loader: loader$i + }; + const git = plugin$f; + const id$g = "gantt"; + const detector$g = (txt) => { + return /^\s*gantt/.test(txt); + }; + const loader$h = async () => { + const { diagram: diagram2 } = await Promise.resolve().then(() => ganttDiagram); + return { id: id$g, diagram: diagram2 }; + }; + const plugin$e = { + id: id$g, + detector: detector$g, + loader: loader$h + }; + const gantt = plugin$e; + const id$f = "info"; + const detector$f = (txt) => { + return /^\s*info/.test(txt); + }; + const loader$g = async () => { + const { diagram: diagram2 } = await Promise.resolve().then(() => infoDiagram); + return { id: id$f, diagram: diagram2 }; + }; + const info$1 = { + id: id$f, + detector: detector$f, + loader: loader$g + }; + const id$e = "pie"; + const detector$e = (txt) => { + return /^\s*pie/.test(txt); + }; + const loader$f = async () => { + const { diagram: diagram2 } = await Promise.resolve().then(() => pieDiagram); + return { id: id$e, diagram: diagram2 }; + }; + const pie = { + id: id$e, + detector: detector$e, + loader: loader$f + }; + const id$d = "quadrantChart"; + const detector$d = (txt) => { + return /^\s*quadrantChart/.test(txt); + }; + const loader$e = async () => { + const { diagram: diagram2 } = await Promise.resolve().then(() => quadrantDiagram); + return { id: id$d, diagram: diagram2 }; + }; + const plugin$d = { + id: id$d, + detector: detector$d, + loader: loader$e + }; + const quadrantChart = plugin$d; + const id$c = "xychart"; + const detector$c = (txt) => { + return /^\s*xychart-beta/.test(txt); + }; + const loader$d = async () => { + const { diagram: diagram2 } = await Promise.resolve().then(() => xychartDiagram); + return { id: id$c, diagram: diagram2 }; + }; + const plugin$c = { + id: id$c, + detector: detector$c, + loader: loader$d + }; + const xychart = plugin$c; + const id$b = "requirement"; + const detector$b = (txt) => { + return /^\s*requirement(Diagram)?/.test(txt); + }; + const loader$c = async () => { + const { diagram: diagram2 } = await Promise.resolve().then(() => requirementDiagram); + return { id: id$b, diagram: diagram2 }; + }; + const plugin$b = { + id: id$b, + detector: detector$b, + loader: loader$c + }; + const requirement = plugin$b; + const id$a = "sequence"; + const detector$a = (txt) => { + return /^\s*sequenceDiagram/.test(txt); + }; + const loader$b = async () => { + const { diagram: diagram2 } = await Promise.resolve().then(() => sequenceDiagram); + return { id: id$a, diagram: diagram2 }; + }; + const plugin$a = { + id: id$a, + detector: detector$a, + loader: loader$b + }; + const sequence = plugin$a; + const id$9 = "class"; + const detector$9 = (txt, config2) => { + var _a2; + if (((_a2 = config2 == null ? void 0 : config2.class) == null ? void 0 : _a2.defaultRenderer) === "dagre-wrapper") { + return false; + } + return /^\s*classDiagram/.test(txt); + }; + const loader$a = async () => { + const { diagram: diagram2 } = await Promise.resolve().then(() => classDiagram); + return { id: id$9, diagram: diagram2 }; + }; + const plugin$9 = { + id: id$9, + detector: detector$9, + loader: loader$a + }; + const classDiagram$1 = plugin$9; + const id$8 = "classDiagram"; + const detector$8 = (txt, config2) => { + var _a2; + if (/^\s*classDiagram/.test(txt) && ((_a2 = config2 == null ? void 0 : config2.class) == null ? void 0 : _a2.defaultRenderer) === "dagre-wrapper") { + return true; + } + return /^\s*classDiagram-v2/.test(txt); + }; + const loader$9 = async () => { + const { diagram: diagram2 } = await Promise.resolve().then(() => classDiagramV2); + return { id: id$8, diagram: diagram2 }; + }; + const plugin$8 = { + id: id$8, + detector: detector$8, + loader: loader$9 + }; + const classDiagramV2$1 = plugin$8; + const id$7 = "state"; + const detector$7 = (txt, config2) => { + var _a2; + if (((_a2 = config2 == null ? void 0 : config2.state) == null ? void 0 : _a2.defaultRenderer) === "dagre-wrapper") { + return false; + } + return /^\s*stateDiagram/.test(txt); + }; + const loader$8 = async () => { + const { diagram: diagram2 } = await Promise.resolve().then(() => stateDiagram); + return { id: id$7, diagram: diagram2 }; + }; + const plugin$7 = { + id: id$7, + detector: detector$7, + loader: loader$8 + }; + const state$1 = plugin$7; + const id$6 = "stateDiagram"; + const detector$6 = (txt, config2) => { + var _a2; + if (/^\s*stateDiagram-v2/.test(txt)) { + return true; + } + if (/^\s*stateDiagram/.test(txt) && ((_a2 = config2 == null ? void 0 : config2.state) == null ? void 0 : _a2.defaultRenderer) === "dagre-wrapper") { + return true; + } + return false; + }; + const loader$7 = async () => { + const { diagram: diagram2 } = await Promise.resolve().then(() => stateDiagramV2); + return { id: id$6, diagram: diagram2 }; + }; + const plugin$6 = { + id: id$6, + detector: detector$6, + loader: loader$7 + }; + const stateV2 = plugin$6; + const id$5 = "journey"; + const detector$5 = (txt) => { + return /^\s*journey/.test(txt); + }; + const loader$6 = async () => { + const { diagram: diagram2 } = await Promise.resolve().then(() => journeyDiagram); + return { id: id$5, diagram: diagram2 }; + }; + const plugin$5 = { + id: id$5, + detector: detector$5, + loader: loader$6 + }; + const journey = plugin$5; + const d3Attrs = function(d3Elem, attrs) { + for (let attr of attrs) { + d3Elem.attr(attr[0], attr[1]); + } + }; + const calculateSvgSizeAttrs = function(height, width2, useMaxWidth) { + let attrs = /* @__PURE__ */ new Map(); + if (useMaxWidth) { + attrs.set("width", "100%"); + attrs.set("style", `max-width: ${width2}px;`); + } else { + attrs.set("height", height); + attrs.set("width", width2); + } + return attrs; + }; + const configureSvgSize = function(svgElem, height, width2, useMaxWidth) { + const attrs = calculateSvgSizeAttrs(height, width2, useMaxWidth); + d3Attrs(svgElem, attrs); + }; + const setupGraphViewbox$1 = function(graph, svgElem, padding2, useMaxWidth) { + const svgBounds = svgElem.node().getBBox(); + const sWidth = svgBounds.width; + const sHeight = svgBounds.height; + log$1.info(`SVG bounds: ${sWidth}x${sHeight}`, svgBounds); + let width2 = 0; + let height = 0; + log$1.info(`Graph bounds: ${width2}x${height}`, graph); + width2 = sWidth + padding2 * 2; + height = sHeight + padding2 * 2; + log$1.info(`Calculated bounds: ${width2}x${height}`); + configureSvgSize(svgElem, height, width2, useMaxWidth); + const vBox = `${svgBounds.x - padding2} ${svgBounds.y - padding2} ${svgBounds.width + 2 * padding2} ${svgBounds.height + 2 * padding2}`; + svgElem.attr("viewBox", vBox); + }; + const themes = {}; + const getStyles$f = (type2, userStyles, options2) => { + let diagramStyles = ""; + if (type2 in themes && themes[type2]) { + diagramStyles = themes[type2](options2); + } else { + log$1.warn(`No theme found for ${type2}`); + } + return ` & { + font-family: ${options2.fontFamily}; + font-size: ${options2.fontSize}; + fill: ${options2.textColor} + } + + /* Classes common for multiple diagrams */ + + & .error-icon { + fill: ${options2.errorBkgColor}; + } + & .error-text { + fill: ${options2.errorTextColor}; + stroke: ${options2.errorTextColor}; + } + + & .edge-thickness-normal { + stroke-width: 2px; + } + & .edge-thickness-thick { + stroke-width: 3.5px + } + & .edge-pattern-solid { + stroke-dasharray: 0; + } + + & .edge-pattern-dashed{ + stroke-dasharray: 3; + } + .edge-pattern-dotted { + stroke-dasharray: 2; + } + + & .marker { + fill: ${options2.lineColor}; + stroke: ${options2.lineColor}; + } + & .marker.cross { + stroke: ${options2.lineColor}; + } + + & svg { + font-family: ${options2.fontFamily}; + font-size: ${options2.fontSize}; + } + + ${diagramStyles} + + ${userStyles} +`; + }; + const addStylesForDiagram = (type2, diagramTheme) => { + if (diagramTheme !== void 0) { + themes[type2] = diagramTheme; + } + }; + const getStyles$g = getStyles$f; + let accTitle = ""; + let diagramTitle = ""; + let accDescription = ""; + const sanitizeText$5 = (txt) => sanitizeText$6(txt, getConfig$2()); + const clear$n = () => { + accTitle = ""; + accDescription = ""; + diagramTitle = ""; + }; + const setAccTitle = (txt) => { + accTitle = sanitizeText$5(txt).replace(/^\s+/g, ""); + }; + const getAccTitle = () => accTitle; + const setAccDescription = (txt) => { + accDescription = sanitizeText$5(txt).replace(/\n\s+/g, "\n"); + }; + const getAccDescription = () => accDescription; + const setDiagramTitle = (txt) => { + diagramTitle = sanitizeText$5(txt); + }; + const getDiagramTitle = () => diagramTitle; + const commonDb = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + clear: clear$n, + getAccDescription, + getAccTitle, + getDiagramTitle, + setAccDescription, + setAccTitle, + setDiagramTitle + }, Symbol.toStringTag, { value: "Module" })); + const log = log$1; + const setLogLevel = setLogLevel$1; + const getConfig$1 = getConfig$2; + const setConfig = setConfig$1; + const defaultConfig = defaultConfig$1; + const sanitizeText$4 = (text2) => sanitizeText$6(text2, getConfig$1()); + const setupGraphViewbox = setupGraphViewbox$1; + const getCommonDb$1 = () => { + return commonDb; + }; + const diagrams = {}; + const registerDiagram = (id2, diagram2, detector2) => { + var _a2; + if (diagrams[id2]) { + throw new Error(`Diagram ${id2} already registered.`); + } + diagrams[id2] = diagram2; + if (detector2) { + addDetector(id2, detector2); + } + addStylesForDiagram(id2, diagram2.styles); + (_a2 = diagram2.injectUtils) == null ? void 0 : _a2.call( + diagram2, + log, + setLogLevel, + getConfig$1, + sanitizeText$4, + setupGraphViewbox, + getCommonDb$1(), + () => { + } + ); + }; + const getDiagram = (name) => { + if (name in diagrams) { + return diagrams[name]; + } + throw new DiagramNotFoundError(name); + }; + class DiagramNotFoundError extends Error { + constructor(name) { + super(`Diagram ${name} not found.`); + } + } + const selectSvgElement = (id2) => { + var _a2; + const { securityLevel } = getConfig$1(); + let root2 = d3select("body"); + if (securityLevel === "sandbox") { + const sandboxElement = d3select(`#i${id2}`); + const doc = ((_a2 = sandboxElement.node()) == null ? void 0 : _a2.contentDocument) ?? document; + root2 = d3select(doc.body); + } + const svg2 = root2.select(`#${id2}`); + return svg2; + }; + const draw$m = (_text, id2, version2) => { + log$1.debug("rendering svg for syntax error\n"); + const svg2 = selectSvgElement(id2); + const g = svg2.append("g"); + svg2.attr("viewBox", "0 0 2412 512"); + configureSvgSize(svg2, 100, 512, true); + g.append("path").attr("class", "error-icon").attr( + "d", + "m411.313,123.313c6.25-6.25 6.25-16.375 0-22.625s-16.375-6.25-22.625,0l-32,32-9.375,9.375-20.688-20.688c-12.484-12.5-32.766-12.5-45.25,0l-16,16c-1.261,1.261-2.304,2.648-3.31,4.051-21.739-8.561-45.324-13.426-70.065-13.426-105.867,0-192,86.133-192,192s86.133,192 192,192 192-86.133 192-192c0-24.741-4.864-48.327-13.426-70.065 1.402-1.007 2.79-2.049 4.051-3.31l16-16c12.5-12.492 12.5-32.758 0-45.25l-20.688-20.688 9.375-9.375 32.001-31.999zm-219.313,100.687c-52.938,0-96,43.063-96,96 0,8.836-7.164,16-16,16s-16-7.164-16-16c0-70.578 57.422-128 128-128 8.836,0 16,7.164 16,16s-7.164,16-16,16z" + ); + g.append("path").attr("class", "error-icon").attr( + "d", + "m459.02,148.98c-6.25-6.25-16.375-6.25-22.625,0s-6.25,16.375 0,22.625l16,16c3.125,3.125 7.219,4.688 11.313,4.688 4.094,0 8.188-1.563 11.313-4.688 6.25-6.25 6.25-16.375 0-22.625l-16.001-16z" + ); + g.append("path").attr("class", "error-icon").attr( + "d", + "m340.395,75.605c3.125,3.125 7.219,4.688 11.313,4.688 4.094,0 8.188-1.563 11.313-4.688 6.25-6.25 6.25-16.375 0-22.625l-16-16c-6.25-6.25-16.375-6.25-22.625,0s-6.25,16.375 0,22.625l15.999,16z" + ); + g.append("path").attr("class", "error-icon").attr( + "d", + "m400,64c8.844,0 16-7.164 16-16v-32c0-8.836-7.156-16-16-16-8.844,0-16,7.164-16,16v32c0,8.836 7.156,16 16,16z" + ); + g.append("path").attr("class", "error-icon").attr( + "d", + "m496,96.586h-32c-8.844,0-16,7.164-16,16 0,8.836 7.156,16 16,16h32c8.844,0 16-7.164 16-16 0-8.836-7.156-16-16-16z" + ); + g.append("path").attr("class", "error-icon").attr( + "d", + "m436.98,75.605c3.125,3.125 7.219,4.688 11.313,4.688 4.094,0 8.188-1.563 11.313-4.688l32-32c6.25-6.25 6.25-16.375 0-22.625s-16.375-6.25-22.625,0l-32,32c-6.251,6.25-6.251,16.375-0.001,22.625z" + ); + g.append("text").attr("class", "error-text").attr("x", 1440).attr("y", 250).attr("font-size", "150px").style("text-anchor", "middle").text("Syntax error in text"); + g.append("text").attr("class", "error-text").attr("x", 1250).attr("y", 400).attr("font-size", "100px").style("text-anchor", "middle").text(`mermaid version ${version2}`); + }; + const renderer$h = { draw: draw$m }; + const errorRenderer = renderer$h; + const diagram$m = { + db: {}, + renderer: renderer$h, + parser: { + parser: { yy: {} }, + parse: () => { + return; + } + } + }; + const errorDiagram = diagram$m; + const id$4 = "flowchart-elk"; + const detector$4 = (txt, config2) => { + var _a2; + if ( + // If diagram explicitly states flowchart-elk + /^\s*flowchart-elk/.test(txt) || // If a flowchart/graph diagram has their default renderer set to elk + /^\s*flowchart|graph/.test(txt) && ((_a2 = config2 == null ? void 0 : config2.flowchart) == null ? void 0 : _a2.defaultRenderer) === "elk" + ) { + return true; + } + return false; + }; + const loader$5 = async () => { + const { diagram: diagram2 } = await Promise.resolve().then(() => flowchartElkDefinition); + return { id: id$4, diagram: diagram2 }; + }; + const plugin$4 = { + id: id$4, + detector: detector$4, + loader: loader$5 + }; + const flowchartElk = plugin$4; + const id$3 = "timeline"; + const detector$3 = (txt) => { + return /^\s*timeline/.test(txt); + }; + const loader$4 = async () => { + const { diagram: diagram2 } = await Promise.resolve().then(() => timelineDefinition); + return { id: id$3, diagram: diagram2 }; + }; + const plugin$3 = { + id: id$3, + detector: detector$3, + loader: loader$4 + }; + const timeline = plugin$3; + const id$2 = "mindmap"; + const detector$2 = (txt) => { + return /^\s*mindmap/.test(txt); + }; + const loader$3 = async () => { + const { diagram: diagram2 } = await Promise.resolve().then(() => mindmapDefinition); + return { id: id$2, diagram: diagram2 }; + }; + const plugin$2 = { + id: id$2, + detector: detector$2, + loader: loader$3 + }; + const mindmap = plugin$2; + const id$1 = "sankey"; + const detector$1 = (txt) => { + return /^\s*sankey-beta/.test(txt); + }; + const loader$2 = async () => { + const { diagram: diagram2 } = await Promise.resolve().then(() => sankeyDiagram); + return { id: id$1, diagram: diagram2 }; + }; + const plugin$1 = { + id: id$1, + detector: detector$1, + loader: loader$2 + }; + const sankey = plugin$1; + const id = "block"; + const detector = (txt) => { + return /^\s*block-beta/.test(txt); + }; + const loader$1 = async () => { + const { diagram: diagram2 } = await Promise.resolve().then(() => blockDiagram); + return { id, diagram: diagram2 }; + }; + const plugin = { + id, + detector, + loader: loader$1 + }; + const block = plugin; + let hasLoadedDiagrams = false; + const addDiagrams = () => { + if (hasLoadedDiagrams) { + return; + } + hasLoadedDiagrams = true; + registerDiagram("error", errorDiagram, (text2) => { + return text2.toLowerCase().trim() === "error"; + }); + registerDiagram( + "---", + // --- diagram type may appear if YAML front-matter is not parsed correctly + { + db: { + clear: () => { + } + }, + styles: {}, + // should never be used + renderer: { + draw: () => { + } + }, + parser: { + parser: { yy: {} }, + parse: () => { + throw new Error( + "Diagrams beginning with --- are not valid. If you were trying to use a YAML front-matter, please ensure that you've correctly opened and closed the YAML front-matter with un-indented `---` blocks" + ); + } + }, + init: () => null + // no op + }, + (text2) => { + return text2.toLowerCase().trimStart().startsWith("---"); + } + ); + registerLazyLoadedDiagrams( + c4, + classDiagramV2$1, + classDiagram$1, + er, + gantt, + info$1, + pie, + requirement, + sequence, + flowchartElk, + flowchartV2, + flowchart, + mindmap, + timeline, + git, + stateV2, + state$1, + journey, + quadrantChart, + sankey, + xychart, + block + ); + }; + class Diagram { + constructor(text2, metadata = {}) { + this.text = text2; + this.metadata = metadata; + this.type = "graph"; + this.text = encodeEntities(text2); + this.text += "\n"; + const cnf = getConfig$2(); + try { + this.type = detectType(text2, cnf); + } catch (e) { + this.type = "error"; + this.detectError = e; + } + const diagram2 = getDiagram(this.type); + log$1.debug("Type " + this.type); + this.db = diagram2.db; + this.renderer = diagram2.renderer; + this.parser = diagram2.parser; + this.parser.parser.yy = this.db; + this.init = diagram2.init; + this.parse(); + } + parse() { + var _a2, _b2, _c, _d, _e; + if (this.detectError) { + throw this.detectError; + } + (_b2 = (_a2 = this.db).clear) == null ? void 0 : _b2.call(_a2); + const config2 = getConfig$2(); + (_c = this.init) == null ? void 0 : _c.call(this, config2); + if (this.metadata.title) { + (_e = (_d = this.db).setDiagramTitle) == null ? void 0 : _e.call(_d, this.metadata.title); + } + this.parser.parse(this.text); + } + async render(id2, version2) { + await this.renderer.draw(this.text, id2, version2, this); + } + getParser() { + return this.parser; + } + getType() { + return this.type; + } + } + const getDiagramFromText$1 = async (text2, metadata = {}) => { + const type2 = detectType(text2, getConfig$2()); + try { + getDiagram(type2); + } catch (error) { + const loader2 = getDiagramLoader(type2); + if (!loader2) { + throw new UnknownDiagramError(`Diagram ${type2} not found.`); + } + const { id: id2, diagram: diagram2 } = await loader2(); + registerDiagram(id2, diagram2); + } + return new Diagram(text2, metadata); + }; + let interactionFunctions = []; + const attachFunctions = () => { + interactionFunctions.forEach((f2) => { + f2(); + }); + interactionFunctions = []; + }; + var nativeKeys = overArg(Object.keys, Object); + const nativeKeys$1 = nativeKeys; + var objectProto$7 = Object.prototype; + var hasOwnProperty$7 = objectProto$7.hasOwnProperty; + function baseKeys(object2) { + if (!isPrototype(object2)) { + return nativeKeys$1(object2); + } + var result = []; + for (var key in Object(object2)) { + if (hasOwnProperty$7.call(object2, key) && key != "constructor") { + result.push(key); + } + } + return result; + } + var DataView$1 = getNative(root$1, "DataView"); + const DataView$2 = DataView$1; + var Promise$1 = getNative(root$1, "Promise"); + const Promise$2 = Promise$1; + var Set$1 = getNative(root$1, "Set"); + const Set$2 = Set$1; + var WeakMap = getNative(root$1, "WeakMap"); + const WeakMap$1 = WeakMap; + var mapTag$5 = "[object Map]", objectTag$2 = "[object Object]", promiseTag = "[object Promise]", setTag$5 = "[object Set]", weakMapTag$1 = "[object WeakMap]"; + var dataViewTag$3 = "[object DataView]"; + var dataViewCtorString = toSource(DataView$2), mapCtorString = toSource(Map$2), promiseCtorString = toSource(Promise$2), setCtorString = toSource(Set$2), weakMapCtorString = toSource(WeakMap$1); + var getTag = baseGetTag; + if (DataView$2 && getTag(new DataView$2(new ArrayBuffer(1))) != dataViewTag$3 || Map$2 && getTag(new Map$2()) != mapTag$5 || Promise$2 && getTag(Promise$2.resolve()) != promiseTag || Set$2 && getTag(new Set$2()) != setTag$5 || WeakMap$1 && getTag(new WeakMap$1()) != weakMapTag$1) { + getTag = function(value2) { + var result = baseGetTag(value2), Ctor = result == objectTag$2 ? value2.constructor : void 0, ctorString = Ctor ? toSource(Ctor) : ""; + if (ctorString) { + switch (ctorString) { + case dataViewCtorString: + return dataViewTag$3; + case mapCtorString: + return mapTag$5; + case promiseCtorString: + return promiseTag; + case setCtorString: + return setTag$5; + case weakMapCtorString: + return weakMapTag$1; + } + } + return result; + }; + } + const getTag$1 = getTag; + var mapTag$4 = "[object Map]", setTag$4 = "[object Set]"; + var objectProto$6 = Object.prototype; + var hasOwnProperty$6 = objectProto$6.hasOwnProperty; + function isEmpty(value2) { + if (value2 == null) { + return true; + } + if (isArrayLike(value2) && (isArray$1(value2) || typeof value2 == "string" || typeof value2.splice == "function" || isBuffer$1(value2) || isTypedArray$1(value2) || isArguments$1(value2))) { + return !value2.length; + } + var tag = getTag$1(value2); + if (tag == mapTag$4 || tag == setTag$4) { + return !value2.size; + } + if (isPrototype(value2)) { + return !baseKeys(value2).length; + } + for (var key in value2) { + if (hasOwnProperty$6.call(value2, key)) { + return false; + } + } + return true; + } + const SVG_ROLE = "graphics-document document"; + function setA11yDiagramInfo(svg2, diagramType) { + svg2.attr("role", SVG_ROLE); + if (diagramType !== "") { + svg2.attr("aria-roledescription", diagramType); + } + } + function addSVGa11yTitleDescription(svg2, a11yTitle, a11yDesc, baseId) { + if (svg2.insert === void 0) { + return; + } + if (a11yDesc) { + const descId = `chart-desc-${baseId}`; + svg2.attr("aria-describedby", descId); + svg2.insert("desc", ":first-child").attr("id", descId).text(a11yDesc); + } + if (a11yTitle) { + const titleId = `chart-title-${baseId}`; + svg2.attr("aria-labelledby", titleId); + svg2.insert("title", ":first-child").attr("id", titleId).text(a11yTitle); + } + } + const cleanupComments = (text2) => { + return text2.replace(/^\s*%%(?!{)[^\n]+\n?/gm, "").trimStart(); + }; + /*! js-yaml 4.1.0 https://github.com/nodeca/js-yaml @license MIT */ + function isNothing(subject) { + return typeof subject === "undefined" || subject === null; + } + function isObject(subject) { + return typeof subject === "object" && subject !== null; + } + function toArray(sequence2) { + if (Array.isArray(sequence2)) + return sequence2; + else if (isNothing(sequence2)) + return []; + return [sequence2]; + } + function extend(target, source) { + var index2, length2, key, sourceKeys; + if (source) { + sourceKeys = Object.keys(source); + for (index2 = 0, length2 = sourceKeys.length; index2 < length2; index2 += 1) { + key = sourceKeys[index2]; + target[key] = source[key]; + } + } + return target; + } + function repeat(string2, count) { + var result = "", cycle; + for (cycle = 0; cycle < count; cycle += 1) { + result += string2; + } + return result; + } + function isNegativeZero(number2) { + return number2 === 0 && Number.NEGATIVE_INFINITY === 1 / number2; + } + var isNothing_1 = isNothing; + var isObject_1 = isObject; + var toArray_1 = toArray; + var repeat_1 = repeat; + var isNegativeZero_1 = isNegativeZero; + var extend_1 = extend; + var common = { + isNothing: isNothing_1, + isObject: isObject_1, + toArray: toArray_1, + repeat: repeat_1, + isNegativeZero: isNegativeZero_1, + extend: extend_1 + }; + function formatError(exception2, compact) { + var where = "", message = exception2.reason || "(unknown reason)"; + if (!exception2.mark) + return message; + if (exception2.mark.name) { + where += 'in "' + exception2.mark.name + '" '; + } + where += "(" + (exception2.mark.line + 1) + ":" + (exception2.mark.column + 1) + ")"; + if (!compact && exception2.mark.snippet) { + where += "\n\n" + exception2.mark.snippet; + } + return message + " " + where; + } + function YAMLException$1(reason, mark) { + Error.call(this); + this.name = "YAMLException"; + this.reason = reason; + this.mark = mark; + this.message = formatError(this, false); + if (Error.captureStackTrace) { + Error.captureStackTrace(this, this.constructor); + } else { + this.stack = new Error().stack || ""; + } + } + YAMLException$1.prototype = Object.create(Error.prototype); + YAMLException$1.prototype.constructor = YAMLException$1; + YAMLException$1.prototype.toString = function toString2(compact) { + return this.name + ": " + formatError(this, compact); + }; + var exception = YAMLException$1; + function getLine(buffer, lineStart, lineEnd, position2, maxLineLength) { + var head2 = ""; + var tail = ""; + var maxHalfLength = Math.floor(maxLineLength / 2) - 1; + if (position2 - lineStart > maxHalfLength) { + head2 = " ... "; + lineStart = position2 - maxHalfLength + head2.length; + } + if (lineEnd - position2 > maxHalfLength) { + tail = " ..."; + lineEnd = position2 + maxHalfLength - tail.length; + } + return { + str: head2 + buffer.slice(lineStart, lineEnd).replace(/\t/g, "→") + tail, + pos: position2 - lineStart + head2.length + // relative position + }; + } + function padStart(string2, max2) { + return common.repeat(" ", max2 - string2.length) + string2; + } + function makeSnippet(mark, options2) { + options2 = Object.create(options2 || null); + if (!mark.buffer) + return null; + if (!options2.maxLength) + options2.maxLength = 79; + if (typeof options2.indent !== "number") + options2.indent = 1; + if (typeof options2.linesBefore !== "number") + options2.linesBefore = 3; + if (typeof options2.linesAfter !== "number") + options2.linesAfter = 2; + var re2 = /\r?\n|\r|\0/g; + var lineStarts = [0]; + var lineEnds = []; + var match; + var foundLineNo = -1; + while (match = re2.exec(mark.buffer)) { + lineEnds.push(match.index); + lineStarts.push(match.index + match[0].length); + if (mark.position <= match.index && foundLineNo < 0) { + foundLineNo = lineStarts.length - 2; + } + } + if (foundLineNo < 0) + foundLineNo = lineStarts.length - 1; + var result = "", i2, line2; + var lineNoLength = Math.min(mark.line + options2.linesAfter, lineEnds.length).toString().length; + var maxLineLength = options2.maxLength - (options2.indent + lineNoLength + 3); + for (i2 = 1; i2 <= options2.linesBefore; i2++) { + if (foundLineNo - i2 < 0) + break; + line2 = getLine( + mark.buffer, + lineStarts[foundLineNo - i2], + lineEnds[foundLineNo - i2], + mark.position - (lineStarts[foundLineNo] - lineStarts[foundLineNo - i2]), + maxLineLength + ); + result = common.repeat(" ", options2.indent) + padStart((mark.line - i2 + 1).toString(), lineNoLength) + " | " + line2.str + "\n" + result; + } + line2 = getLine(mark.buffer, lineStarts[foundLineNo], lineEnds[foundLineNo], mark.position, maxLineLength); + result += common.repeat(" ", options2.indent) + padStart((mark.line + 1).toString(), lineNoLength) + " | " + line2.str + "\n"; + result += common.repeat("-", options2.indent + lineNoLength + 3 + line2.pos) + "^\n"; + for (i2 = 1; i2 <= options2.linesAfter; i2++) { + if (foundLineNo + i2 >= lineEnds.length) + break; + line2 = getLine( + mark.buffer, + lineStarts[foundLineNo + i2], + lineEnds[foundLineNo + i2], + mark.position - (lineStarts[foundLineNo] - lineStarts[foundLineNo + i2]), + maxLineLength + ); + result += common.repeat(" ", options2.indent) + padStart((mark.line + i2 + 1).toString(), lineNoLength) + " | " + line2.str + "\n"; + } + return result.replace(/\n$/, ""); + } + var snippet = makeSnippet; + var TYPE_CONSTRUCTOR_OPTIONS = [ + "kind", + "multi", + "resolve", + "construct", + "instanceOf", + "predicate", + "represent", + "representName", + "defaultStyle", + "styleAliases" + ]; + var YAML_NODE_KINDS = [ + "scalar", + "sequence", + "mapping" + ]; + function compileStyleAliases(map2) { + var result = {}; + if (map2 !== null) { + Object.keys(map2).forEach(function(style) { + map2[style].forEach(function(alias) { + result[String(alias)] = style; + }); + }); + } + return result; + } + function Type$1(tag, options2) { + options2 = options2 || {}; + Object.keys(options2).forEach(function(name) { + if (TYPE_CONSTRUCTOR_OPTIONS.indexOf(name) === -1) { + throw new exception('Unknown option "' + name + '" is met in definition of "' + tag + '" YAML type.'); + } + }); + this.options = options2; + this.tag = tag; + this.kind = options2["kind"] || null; + this.resolve = options2["resolve"] || function() { + return true; + }; + this.construct = options2["construct"] || function(data) { + return data; + }; + this.instanceOf = options2["instanceOf"] || null; + this.predicate = options2["predicate"] || null; + this.represent = options2["represent"] || null; + this.representName = options2["representName"] || null; + this.defaultStyle = options2["defaultStyle"] || null; + this.multi = options2["multi"] || false; + this.styleAliases = compileStyleAliases(options2["styleAliases"] || null); + if (YAML_NODE_KINDS.indexOf(this.kind) === -1) { + throw new exception('Unknown kind "' + this.kind + '" is specified for "' + tag + '" YAML type.'); + } + } + var type = Type$1; + function compileList(schema2, name) { + var result = []; + schema2[name].forEach(function(currentType) { + var newIndex = result.length; + result.forEach(function(previousType, previousIndex) { + if (previousType.tag === currentType.tag && previousType.kind === currentType.kind && previousType.multi === currentType.multi) { + newIndex = previousIndex; + } + }); + result[newIndex] = currentType; + }); + return result; + } + function compileMap() { + var result = { + scalar: {}, + sequence: {}, + mapping: {}, + fallback: {}, + multi: { + scalar: [], + sequence: [], + mapping: [], + fallback: [] + } + }, index2, length2; + function collectType(type2) { + if (type2.multi) { + result.multi[type2.kind].push(type2); + result.multi["fallback"].push(type2); + } else { + result[type2.kind][type2.tag] = result["fallback"][type2.tag] = type2; + } + } + for (index2 = 0, length2 = arguments.length; index2 < length2; index2 += 1) { + arguments[index2].forEach(collectType); + } + return result; + } + function Schema$1(definition2) { + return this.extend(definition2); + } + Schema$1.prototype.extend = function extend2(definition2) { + var implicit2 = []; + var explicit = []; + if (definition2 instanceof type) { + explicit.push(definition2); + } else if (Array.isArray(definition2)) { + explicit = explicit.concat(definition2); + } else if (definition2 && (Array.isArray(definition2.implicit) || Array.isArray(definition2.explicit))) { + if (definition2.implicit) + implicit2 = implicit2.concat(definition2.implicit); + if (definition2.explicit) + explicit = explicit.concat(definition2.explicit); + } else { + throw new exception("Schema.extend argument should be a Type, [ Type ], or a schema definition ({ implicit: [...], explicit: [...] })"); + } + implicit2.forEach(function(type$1) { + if (!(type$1 instanceof type)) { + throw new exception("Specified list of YAML types (or a single Type object) contains a non-Type object."); + } + if (type$1.loadKind && type$1.loadKind !== "scalar") { + throw new exception("There is a non-scalar type in the implicit list of a schema. Implicit resolving of such types is not supported."); + } + if (type$1.multi) { + throw new exception("There is a multi type in the implicit list of a schema. Multi tags can only be listed as explicit."); + } + }); + explicit.forEach(function(type$1) { + if (!(type$1 instanceof type)) { + throw new exception("Specified list of YAML types (or a single Type object) contains a non-Type object."); + } + }); + var result = Object.create(Schema$1.prototype); + result.implicit = (this.implicit || []).concat(implicit2); + result.explicit = (this.explicit || []).concat(explicit); + result.compiledImplicit = compileList(result, "implicit"); + result.compiledExplicit = compileList(result, "explicit"); + result.compiledTypeMap = compileMap(result.compiledImplicit, result.compiledExplicit); + return result; + }; + var schema = Schema$1; + var str = new type("tag:yaml.org,2002:str", { + kind: "scalar", + construct: function(data) { + return data !== null ? data : ""; + } + }); + var seq$1 = new type("tag:yaml.org,2002:seq", { + kind: "sequence", + construct: function(data) { + return data !== null ? data : []; + } + }); + var map$1 = new type("tag:yaml.org,2002:map", { + kind: "mapping", + construct: function(data) { + return data !== null ? data : {}; + } + }); + var failsafe = new schema({ + explicit: [ + str, + seq$1, + map$1 + ] + }); + function resolveYamlNull(data) { + if (data === null) + return true; + var max2 = data.length; + return max2 === 1 && data === "~" || max2 === 4 && (data === "null" || data === "Null" || data === "NULL"); + } + function constructYamlNull() { + return null; + } + function isNull(object2) { + return object2 === null; + } + var _null = new type("tag:yaml.org,2002:null", { + kind: "scalar", + resolve: resolveYamlNull, + construct: constructYamlNull, + predicate: isNull, + represent: { + canonical: function() { + return "~"; + }, + lowercase: function() { + return "null"; + }, + uppercase: function() { + return "NULL"; + }, + camelcase: function() { + return "Null"; + }, + empty: function() { + return ""; + } + }, + defaultStyle: "lowercase" + }); + function resolveYamlBoolean(data) { + if (data === null) + return false; + var max2 = data.length; + return max2 === 4 && (data === "true" || data === "True" || data === "TRUE") || max2 === 5 && (data === "false" || data === "False" || data === "FALSE"); + } + function constructYamlBoolean(data) { + return data === "true" || data === "True" || data === "TRUE"; + } + function isBoolean(object2) { + return Object.prototype.toString.call(object2) === "[object Boolean]"; + } + var bool = new type("tag:yaml.org,2002:bool", { + kind: "scalar", + resolve: resolveYamlBoolean, + construct: constructYamlBoolean, + predicate: isBoolean, + represent: { + lowercase: function(object2) { + return object2 ? "true" : "false"; + }, + uppercase: function(object2) { + return object2 ? "TRUE" : "FALSE"; + }, + camelcase: function(object2) { + return object2 ? "True" : "False"; + } + }, + defaultStyle: "lowercase" + }); + function isHexCode(c2) { + return 48 <= c2 && c2 <= 57 || 65 <= c2 && c2 <= 70 || 97 <= c2 && c2 <= 102; + } + function isOctCode(c2) { + return 48 <= c2 && c2 <= 55; + } + function isDecCode(c2) { + return 48 <= c2 && c2 <= 57; + } + function resolveYamlInteger(data) { + if (data === null) + return false; + var max2 = data.length, index2 = 0, hasDigits = false, ch2; + if (!max2) + return false; + ch2 = data[index2]; + if (ch2 === "-" || ch2 === "+") { + ch2 = data[++index2]; + } + if (ch2 === "0") { + if (index2 + 1 === max2) + return true; + ch2 = data[++index2]; + if (ch2 === "b") { + index2++; + for (; index2 < max2; index2++) { + ch2 = data[index2]; + if (ch2 === "_") + continue; + if (ch2 !== "0" && ch2 !== "1") + return false; + hasDigits = true; + } + return hasDigits && ch2 !== "_"; + } + if (ch2 === "x") { + index2++; + for (; index2 < max2; index2++) { + ch2 = data[index2]; + if (ch2 === "_") + continue; + if (!isHexCode(data.charCodeAt(index2))) + return false; + hasDigits = true; + } + return hasDigits && ch2 !== "_"; + } + if (ch2 === "o") { + index2++; + for (; index2 < max2; index2++) { + ch2 = data[index2]; + if (ch2 === "_") + continue; + if (!isOctCode(data.charCodeAt(index2))) + return false; + hasDigits = true; + } + return hasDigits && ch2 !== "_"; + } + } + if (ch2 === "_") + return false; + for (; index2 < max2; index2++) { + ch2 = data[index2]; + if (ch2 === "_") + continue; + if (!isDecCode(data.charCodeAt(index2))) { + return false; + } + hasDigits = true; + } + if (!hasDigits || ch2 === "_") + return false; + return true; + } + function constructYamlInteger(data) { + var value2 = data, sign2 = 1, ch2; + if (value2.indexOf("_") !== -1) { + value2 = value2.replace(/_/g, ""); + } + ch2 = value2[0]; + if (ch2 === "-" || ch2 === "+") { + if (ch2 === "-") + sign2 = -1; + value2 = value2.slice(1); + ch2 = value2[0]; + } + if (value2 === "0") + return 0; + if (ch2 === "0") { + if (value2[1] === "b") + return sign2 * parseInt(value2.slice(2), 2); + if (value2[1] === "x") + return sign2 * parseInt(value2.slice(2), 16); + if (value2[1] === "o") + return sign2 * parseInt(value2.slice(2), 8); + } + return sign2 * parseInt(value2, 10); + } + function isInteger(object2) { + return Object.prototype.toString.call(object2) === "[object Number]" && (object2 % 1 === 0 && !common.isNegativeZero(object2)); + } + var int = new type("tag:yaml.org,2002:int", { + kind: "scalar", + resolve: resolveYamlInteger, + construct: constructYamlInteger, + predicate: isInteger, + represent: { + binary: function(obj) { + return obj >= 0 ? "0b" + obj.toString(2) : "-0b" + obj.toString(2).slice(1); + }, + octal: function(obj) { + return obj >= 0 ? "0o" + obj.toString(8) : "-0o" + obj.toString(8).slice(1); + }, + decimal: function(obj) { + return obj.toString(10); + }, + /* eslint-disable max-len */ + hexadecimal: function(obj) { + return obj >= 0 ? "0x" + obj.toString(16).toUpperCase() : "-0x" + obj.toString(16).toUpperCase().slice(1); + } + }, + defaultStyle: "decimal", + styleAliases: { + binary: [2, "bin"], + octal: [8, "oct"], + decimal: [10, "dec"], + hexadecimal: [16, "hex"] + } + }); + var YAML_FLOAT_PATTERN = new RegExp( + // 2.5e4, 2.5 and integers + "^(?:[-+]?(?:[0-9][0-9_]*)(?:\\.[0-9_]*)?(?:[eE][-+]?[0-9]+)?|\\.[0-9_]+(?:[eE][-+]?[0-9]+)?|[-+]?\\.(?:inf|Inf|INF)|\\.(?:nan|NaN|NAN))$" + ); + function resolveYamlFloat(data) { + if (data === null) + return false; + if (!YAML_FLOAT_PATTERN.test(data) || // Quick hack to not allow integers end with `_` + // Probably should update regexp & check speed + data[data.length - 1] === "_") { + return false; + } + return true; + } + function constructYamlFloat(data) { + var value2, sign2; + value2 = data.replace(/_/g, "").toLowerCase(); + sign2 = value2[0] === "-" ? -1 : 1; + if ("+-".indexOf(value2[0]) >= 0) { + value2 = value2.slice(1); + } + if (value2 === ".inf") { + return sign2 === 1 ? Number.POSITIVE_INFINITY : Number.NEGATIVE_INFINITY; + } else if (value2 === ".nan") { + return NaN; + } + return sign2 * parseFloat(value2, 10); + } + var SCIENTIFIC_WITHOUT_DOT = /^[-+]?[0-9]+e/; + function representYamlFloat(object2, style) { + var res; + if (isNaN(object2)) { + switch (style) { + case "lowercase": + return ".nan"; + case "uppercase": + return ".NAN"; + case "camelcase": + return ".NaN"; + } + } else if (Number.POSITIVE_INFINITY === object2) { + switch (style) { + case "lowercase": + return ".inf"; + case "uppercase": + return ".INF"; + case "camelcase": + return ".Inf"; + } + } else if (Number.NEGATIVE_INFINITY === object2) { + switch (style) { + case "lowercase": + return "-.inf"; + case "uppercase": + return "-.INF"; + case "camelcase": + return "-.Inf"; + } + } else if (common.isNegativeZero(object2)) { + return "-0.0"; + } + res = object2.toString(10); + return SCIENTIFIC_WITHOUT_DOT.test(res) ? res.replace("e", ".e") : res; + } + function isFloat(object2) { + return Object.prototype.toString.call(object2) === "[object Number]" && (object2 % 1 !== 0 || common.isNegativeZero(object2)); + } + var float = new type("tag:yaml.org,2002:float", { + kind: "scalar", + resolve: resolveYamlFloat, + construct: constructYamlFloat, + predicate: isFloat, + represent: representYamlFloat, + defaultStyle: "lowercase" + }); + var json = failsafe.extend({ + implicit: [ + _null, + bool, + int, + float + ] + }); + var core = json; + var YAML_DATE_REGEXP = new RegExp( + "^([0-9][0-9][0-9][0-9])-([0-9][0-9])-([0-9][0-9])$" + ); + var YAML_TIMESTAMP_REGEXP = new RegExp( + "^([0-9][0-9][0-9][0-9])-([0-9][0-9]?)-([0-9][0-9]?)(?:[Tt]|[ \\t]+)([0-9][0-9]?):([0-9][0-9]):([0-9][0-9])(?:\\.([0-9]*))?(?:[ \\t]*(Z|([-+])([0-9][0-9]?)(?::([0-9][0-9]))?))?$" + ); + function resolveYamlTimestamp(data) { + if (data === null) + return false; + if (YAML_DATE_REGEXP.exec(data) !== null) + return true; + if (YAML_TIMESTAMP_REGEXP.exec(data) !== null) + return true; + return false; + } + function constructYamlTimestamp(data) { + var match, year, month, day, hour, minute, second2, fraction = 0, delta = null, tz_hour, tz_minute, date2; + match = YAML_DATE_REGEXP.exec(data); + if (match === null) + match = YAML_TIMESTAMP_REGEXP.exec(data); + if (match === null) + throw new Error("Date resolve error"); + year = +match[1]; + month = +match[2] - 1; + day = +match[3]; + if (!match[4]) { + return new Date(Date.UTC(year, month, day)); + } + hour = +match[4]; + minute = +match[5]; + second2 = +match[6]; + if (match[7]) { + fraction = match[7].slice(0, 3); + while (fraction.length < 3) { + fraction += "0"; + } + fraction = +fraction; + } + if (match[9]) { + tz_hour = +match[10]; + tz_minute = +(match[11] || 0); + delta = (tz_hour * 60 + tz_minute) * 6e4; + if (match[9] === "-") + delta = -delta; + } + date2 = new Date(Date.UTC(year, month, day, hour, minute, second2, fraction)); + if (delta) + date2.setTime(date2.getTime() - delta); + return date2; + } + function representYamlTimestamp(object2) { + return object2.toISOString(); + } + var timestamp = new type("tag:yaml.org,2002:timestamp", { + kind: "scalar", + resolve: resolveYamlTimestamp, + construct: constructYamlTimestamp, + instanceOf: Date, + represent: representYamlTimestamp + }); + function resolveYamlMerge(data) { + return data === "<<" || data === null; + } + var merge$1 = new type("tag:yaml.org,2002:merge", { + kind: "scalar", + resolve: resolveYamlMerge + }); + var BASE64_MAP = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=\n\r"; + function resolveYamlBinary(data) { + if (data === null) + return false; + var code, idx, bitlen = 0, max2 = data.length, map2 = BASE64_MAP; + for (idx = 0; idx < max2; idx++) { + code = map2.indexOf(data.charAt(idx)); + if (code > 64) + continue; + if (code < 0) + return false; + bitlen += 6; + } + return bitlen % 8 === 0; + } + function constructYamlBinary(data) { + var idx, tailbits, input = data.replace(/[\r\n=]/g, ""), max2 = input.length, map2 = BASE64_MAP, bits = 0, result = []; + for (idx = 0; idx < max2; idx++) { + if (idx % 4 === 0 && idx) { + result.push(bits >> 16 & 255); + result.push(bits >> 8 & 255); + result.push(bits & 255); + } + bits = bits << 6 | map2.indexOf(input.charAt(idx)); + } + tailbits = max2 % 4 * 6; + if (tailbits === 0) { + result.push(bits >> 16 & 255); + result.push(bits >> 8 & 255); + result.push(bits & 255); + } else if (tailbits === 18) { + result.push(bits >> 10 & 255); + result.push(bits >> 2 & 255); + } else if (tailbits === 12) { + result.push(bits >> 4 & 255); + } + return new Uint8Array(result); + } + function representYamlBinary(object2) { + var result = "", bits = 0, idx, tail, max2 = object2.length, map2 = BASE64_MAP; + for (idx = 0; idx < max2; idx++) { + if (idx % 3 === 0 && idx) { + result += map2[bits >> 18 & 63]; + result += map2[bits >> 12 & 63]; + result += map2[bits >> 6 & 63]; + result += map2[bits & 63]; + } + bits = (bits << 8) + object2[idx]; + } + tail = max2 % 3; + if (tail === 0) { + result += map2[bits >> 18 & 63]; + result += map2[bits >> 12 & 63]; + result += map2[bits >> 6 & 63]; + result += map2[bits & 63]; + } else if (tail === 2) { + result += map2[bits >> 10 & 63]; + result += map2[bits >> 4 & 63]; + result += map2[bits << 2 & 63]; + result += map2[64]; + } else if (tail === 1) { + result += map2[bits >> 2 & 63]; + result += map2[bits << 4 & 63]; + result += map2[64]; + result += map2[64]; + } + return result; + } + function isBinary(obj) { + return Object.prototype.toString.call(obj) === "[object Uint8Array]"; + } + var binary = new type("tag:yaml.org,2002:binary", { + kind: "scalar", + resolve: resolveYamlBinary, + construct: constructYamlBinary, + predicate: isBinary, + represent: representYamlBinary + }); + var _hasOwnProperty$3 = Object.prototype.hasOwnProperty; + var _toString$2 = Object.prototype.toString; + function resolveYamlOmap(data) { + if (data === null) + return true; + var objectKeys = [], index2, length2, pair, pairKey, pairHasKey, object2 = data; + for (index2 = 0, length2 = object2.length; index2 < length2; index2 += 1) { + pair = object2[index2]; + pairHasKey = false; + if (_toString$2.call(pair) !== "[object Object]") + return false; + for (pairKey in pair) { + if (_hasOwnProperty$3.call(pair, pairKey)) { + if (!pairHasKey) + pairHasKey = true; + else + return false; + } + } + if (!pairHasKey) + return false; + if (objectKeys.indexOf(pairKey) === -1) + objectKeys.push(pairKey); + else + return false; + } + return true; + } + function constructYamlOmap(data) { + return data !== null ? data : []; + } + var omap = new type("tag:yaml.org,2002:omap", { + kind: "sequence", + resolve: resolveYamlOmap, + construct: constructYamlOmap + }); + var _toString$1 = Object.prototype.toString; + function resolveYamlPairs(data) { + if (data === null) + return true; + var index2, length2, pair, keys2, result, object2 = data; + result = new Array(object2.length); + for (index2 = 0, length2 = object2.length; index2 < length2; index2 += 1) { + pair = object2[index2]; + if (_toString$1.call(pair) !== "[object Object]") + return false; + keys2 = Object.keys(pair); + if (keys2.length !== 1) + return false; + result[index2] = [keys2[0], pair[keys2[0]]]; + } + return true; + } + function constructYamlPairs(data) { + if (data === null) + return []; + var index2, length2, pair, keys2, result, object2 = data; + result = new Array(object2.length); + for (index2 = 0, length2 = object2.length; index2 < length2; index2 += 1) { + pair = object2[index2]; + keys2 = Object.keys(pair); + result[index2] = [keys2[0], pair[keys2[0]]]; + } + return result; + } + var pairs = new type("tag:yaml.org,2002:pairs", { + kind: "sequence", + resolve: resolveYamlPairs, + construct: constructYamlPairs + }); + var _hasOwnProperty$2 = Object.prototype.hasOwnProperty; + function resolveYamlSet(data) { + if (data === null) + return true; + var key, object2 = data; + for (key in object2) { + if (_hasOwnProperty$2.call(object2, key)) { + if (object2[key] !== null) + return false; + } + } + return true; + } + function constructYamlSet(data) { + return data !== null ? data : {}; + } + var set$1 = new type("tag:yaml.org,2002:set", { + kind: "mapping", + resolve: resolveYamlSet, + construct: constructYamlSet + }); + var _default = core.extend({ + implicit: [ + timestamp, + merge$1 + ], + explicit: [ + binary, + omap, + pairs, + set$1 + ] + }); + var _hasOwnProperty$1 = Object.prototype.hasOwnProperty; + var CONTEXT_FLOW_IN = 1; + var CONTEXT_FLOW_OUT = 2; + var CONTEXT_BLOCK_IN = 3; + var CONTEXT_BLOCK_OUT = 4; + var CHOMPING_CLIP = 1; + var CHOMPING_STRIP = 2; + var CHOMPING_KEEP = 3; + var PATTERN_NON_PRINTABLE = /[\x00-\x08\x0B\x0C\x0E-\x1F\x7F-\x84\x86-\x9F\uFFFE\uFFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF]/; + var PATTERN_NON_ASCII_LINE_BREAKS = /[\x85\u2028\u2029]/; + var PATTERN_FLOW_INDICATORS = /[,\[\]\{\}]/; + var PATTERN_TAG_HANDLE = /^(?:!|!!|![a-z\-]+!)$/i; + var PATTERN_TAG_URI = /^(?:!|[^,\[\]\{\}])(?:%[0-9a-f]{2}|[0-9a-z\-#;\/\?:@&=\+\$,_\.!~\*'\(\)\[\]])*$/i; + function _class(obj) { + return Object.prototype.toString.call(obj); + } + function is_EOL(c2) { + return c2 === 10 || c2 === 13; + } + function is_WHITE_SPACE(c2) { + return c2 === 9 || c2 === 32; + } + function is_WS_OR_EOL(c2) { + return c2 === 9 || c2 === 32 || c2 === 10 || c2 === 13; + } + function is_FLOW_INDICATOR(c2) { + return c2 === 44 || c2 === 91 || c2 === 93 || c2 === 123 || c2 === 125; + } + function fromHexCode(c2) { + var lc; + if (48 <= c2 && c2 <= 57) { + return c2 - 48; + } + lc = c2 | 32; + if (97 <= lc && lc <= 102) { + return lc - 97 + 10; + } + return -1; + } + function escapedHexLen(c2) { + if (c2 === 120) { + return 2; + } + if (c2 === 117) { + return 4; + } + if (c2 === 85) { + return 8; + } + return 0; + } + function fromDecimalCode(c2) { + if (48 <= c2 && c2 <= 57) { + return c2 - 48; + } + return -1; + } + function simpleEscapeSequence(c2) { + return c2 === 48 ? "\0" : c2 === 97 ? "\x07" : c2 === 98 ? "\b" : c2 === 116 ? " " : c2 === 9 ? " " : c2 === 110 ? "\n" : c2 === 118 ? "\v" : c2 === 102 ? "\f" : c2 === 114 ? "\r" : c2 === 101 ? "\x1B" : c2 === 32 ? " " : c2 === 34 ? '"' : c2 === 47 ? "/" : c2 === 92 ? "\\" : c2 === 78 ? "…" : c2 === 95 ? " " : c2 === 76 ? "\u2028" : c2 === 80 ? "\u2029" : ""; + } + function charFromCodepoint(c2) { + if (c2 <= 65535) { + return String.fromCharCode(c2); + } + return String.fromCharCode( + (c2 - 65536 >> 10) + 55296, + (c2 - 65536 & 1023) + 56320 + ); + } + var simpleEscapeCheck = new Array(256); + var simpleEscapeMap = new Array(256); + for (var i$1 = 0; i$1 < 256; i$1++) { + simpleEscapeCheck[i$1] = simpleEscapeSequence(i$1) ? 1 : 0; + simpleEscapeMap[i$1] = simpleEscapeSequence(i$1); + } + function State$1(input, options2) { + this.input = input; + this.filename = options2["filename"] || null; + this.schema = options2["schema"] || _default; + this.onWarning = options2["onWarning"] || null; + this.legacy = options2["legacy"] || false; + this.json = options2["json"] || false; + this.listener = options2["listener"] || null; + this.implicitTypes = this.schema.compiledImplicit; + this.typeMap = this.schema.compiledTypeMap; + this.length = input.length; + this.position = 0; + this.line = 0; + this.lineStart = 0; + this.lineIndent = 0; + this.firstTabInLine = -1; + this.documents = []; + } + function generateError(state2, message) { + var mark = { + name: state2.filename, + buffer: state2.input.slice(0, -1), + // omit trailing \0 + position: state2.position, + line: state2.line, + column: state2.position - state2.lineStart + }; + mark.snippet = snippet(mark); + return new exception(message, mark); + } + function throwError(state2, message) { + throw generateError(state2, message); + } + function throwWarning(state2, message) { + if (state2.onWarning) { + state2.onWarning.call(null, generateError(state2, message)); + } + } + var directiveHandlers = { + YAML: function handleYamlDirective(state2, name, args) { + var match, major, minor; + if (state2.version !== null) { + throwError(state2, "duplication of %YAML directive"); + } + if (args.length !== 1) { + throwError(state2, "YAML directive accepts exactly one argument"); + } + match = /^([0-9]+)\.([0-9]+)$/.exec(args[0]); + if (match === null) { + throwError(state2, "ill-formed argument of the YAML directive"); + } + major = parseInt(match[1], 10); + minor = parseInt(match[2], 10); + if (major !== 1) { + throwError(state2, "unacceptable YAML version of the document"); + } + state2.version = args[0]; + state2.checkLineBreaks = minor < 2; + if (minor !== 1 && minor !== 2) { + throwWarning(state2, "unsupported YAML version of the document"); + } + }, + TAG: function handleTagDirective(state2, name, args) { + var handle, prefix; + if (args.length !== 2) { + throwError(state2, "TAG directive accepts exactly two arguments"); + } + handle = args[0]; + prefix = args[1]; + if (!PATTERN_TAG_HANDLE.test(handle)) { + throwError(state2, "ill-formed tag handle (first argument) of the TAG directive"); + } + if (_hasOwnProperty$1.call(state2.tagMap, handle)) { + throwError(state2, 'there is a previously declared suffix for "' + handle + '" tag handle'); + } + if (!PATTERN_TAG_URI.test(prefix)) { + throwError(state2, "ill-formed tag prefix (second argument) of the TAG directive"); + } + try { + prefix = decodeURIComponent(prefix); + } catch (err) { + throwError(state2, "tag prefix is malformed: " + prefix); + } + state2.tagMap[handle] = prefix; + } + }; + function captureSegment(state2, start2, end2, checkJson) { + var _position, _length, _character, _result; + if (start2 < end2) { + _result = state2.input.slice(start2, end2); + if (checkJson) { + for (_position = 0, _length = _result.length; _position < _length; _position += 1) { + _character = _result.charCodeAt(_position); + if (!(_character === 9 || 32 <= _character && _character <= 1114111)) { + throwError(state2, "expected valid JSON character"); + } + } + } else if (PATTERN_NON_PRINTABLE.test(_result)) { + throwError(state2, "the stream contains non-printable characters"); + } + state2.result += _result; + } + } + function mergeMappings(state2, destination, source, overridableKeys) { + var sourceKeys, key, index2, quantity; + if (!common.isObject(source)) { + throwError(state2, "cannot merge mappings; the provided source object is unacceptable"); + } + sourceKeys = Object.keys(source); + for (index2 = 0, quantity = sourceKeys.length; index2 < quantity; index2 += 1) { + key = sourceKeys[index2]; + if (!_hasOwnProperty$1.call(destination, key)) { + destination[key] = source[key]; + overridableKeys[key] = true; + } + } + } + function storeMappingPair(state2, _result, overridableKeys, keyTag, keyNode, valueNode, startLine, startLineStart, startPos) { + var index2, quantity; + if (Array.isArray(keyNode)) { + keyNode = Array.prototype.slice.call(keyNode); + for (index2 = 0, quantity = keyNode.length; index2 < quantity; index2 += 1) { + if (Array.isArray(keyNode[index2])) { + throwError(state2, "nested arrays are not supported inside keys"); + } + if (typeof keyNode === "object" && _class(keyNode[index2]) === "[object Object]") { + keyNode[index2] = "[object Object]"; + } + } + } + if (typeof keyNode === "object" && _class(keyNode) === "[object Object]") { + keyNode = "[object Object]"; + } + keyNode = String(keyNode); + if (_result === null) { + _result = {}; + } + if (keyTag === "tag:yaml.org,2002:merge") { + if (Array.isArray(valueNode)) { + for (index2 = 0, quantity = valueNode.length; index2 < quantity; index2 += 1) { + mergeMappings(state2, _result, valueNode[index2], overridableKeys); + } + } else { + mergeMappings(state2, _result, valueNode, overridableKeys); + } + } else { + if (!state2.json && !_hasOwnProperty$1.call(overridableKeys, keyNode) && _hasOwnProperty$1.call(_result, keyNode)) { + state2.line = startLine || state2.line; + state2.lineStart = startLineStart || state2.lineStart; + state2.position = startPos || state2.position; + throwError(state2, "duplicated mapping key"); + } + if (keyNode === "__proto__") { + Object.defineProperty(_result, keyNode, { + configurable: true, + enumerable: true, + writable: true, + value: valueNode + }); + } else { + _result[keyNode] = valueNode; + } + delete overridableKeys[keyNode]; + } + return _result; + } + function readLineBreak(state2) { + var ch2; + ch2 = state2.input.charCodeAt(state2.position); + if (ch2 === 10) { + state2.position++; + } else if (ch2 === 13) { + state2.position++; + if (state2.input.charCodeAt(state2.position) === 10) { + state2.position++; + } + } else { + throwError(state2, "a line break is expected"); + } + state2.line += 1; + state2.lineStart = state2.position; + state2.firstTabInLine = -1; + } + function skipSeparationSpace(state2, allowComments, checkIndent) { + var lineBreaks = 0, ch2 = state2.input.charCodeAt(state2.position); + while (ch2 !== 0) { + while (is_WHITE_SPACE(ch2)) { + if (ch2 === 9 && state2.firstTabInLine === -1) { + state2.firstTabInLine = state2.position; + } + ch2 = state2.input.charCodeAt(++state2.position); + } + if (allowComments && ch2 === 35) { + do { + ch2 = state2.input.charCodeAt(++state2.position); + } while (ch2 !== 10 && ch2 !== 13 && ch2 !== 0); + } + if (is_EOL(ch2)) { + readLineBreak(state2); + ch2 = state2.input.charCodeAt(state2.position); + lineBreaks++; + state2.lineIndent = 0; + while (ch2 === 32) { + state2.lineIndent++; + ch2 = state2.input.charCodeAt(++state2.position); + } + } else { + break; + } + } + if (checkIndent !== -1 && lineBreaks !== 0 && state2.lineIndent < checkIndent) { + throwWarning(state2, "deficient indentation"); + } + return lineBreaks; + } + function testDocumentSeparator(state2) { + var _position = state2.position, ch2; + ch2 = state2.input.charCodeAt(_position); + if ((ch2 === 45 || ch2 === 46) && ch2 === state2.input.charCodeAt(_position + 1) && ch2 === state2.input.charCodeAt(_position + 2)) { + _position += 3; + ch2 = state2.input.charCodeAt(_position); + if (ch2 === 0 || is_WS_OR_EOL(ch2)) { + return true; + } + } + return false; + } + function writeFoldedLines(state2, count) { + if (count === 1) { + state2.result += " "; + } else if (count > 1) { + state2.result += common.repeat("\n", count - 1); + } + } + function readPlainScalar(state2, nodeIndent, withinFlowCollection) { + var preceding, following, captureStart, captureEnd, hasPendingContent, _line, _lineStart, _lineIndent, _kind = state2.kind, _result = state2.result, ch2; + ch2 = state2.input.charCodeAt(state2.position); + if (is_WS_OR_EOL(ch2) || is_FLOW_INDICATOR(ch2) || ch2 === 35 || ch2 === 38 || ch2 === 42 || ch2 === 33 || ch2 === 124 || ch2 === 62 || ch2 === 39 || ch2 === 34 || ch2 === 37 || ch2 === 64 || ch2 === 96) { + return false; + } + if (ch2 === 63 || ch2 === 45) { + following = state2.input.charCodeAt(state2.position + 1); + if (is_WS_OR_EOL(following) || withinFlowCollection && is_FLOW_INDICATOR(following)) { + return false; + } + } + state2.kind = "scalar"; + state2.result = ""; + captureStart = captureEnd = state2.position; + hasPendingContent = false; + while (ch2 !== 0) { + if (ch2 === 58) { + following = state2.input.charCodeAt(state2.position + 1); + if (is_WS_OR_EOL(following) || withinFlowCollection && is_FLOW_INDICATOR(following)) { + break; + } + } else if (ch2 === 35) { + preceding = state2.input.charCodeAt(state2.position - 1); + if (is_WS_OR_EOL(preceding)) { + break; + } + } else if (state2.position === state2.lineStart && testDocumentSeparator(state2) || withinFlowCollection && is_FLOW_INDICATOR(ch2)) { + break; + } else if (is_EOL(ch2)) { + _line = state2.line; + _lineStart = state2.lineStart; + _lineIndent = state2.lineIndent; + skipSeparationSpace(state2, false, -1); + if (state2.lineIndent >= nodeIndent) { + hasPendingContent = true; + ch2 = state2.input.charCodeAt(state2.position); + continue; + } else { + state2.position = captureEnd; + state2.line = _line; + state2.lineStart = _lineStart; + state2.lineIndent = _lineIndent; + break; + } + } + if (hasPendingContent) { + captureSegment(state2, captureStart, captureEnd, false); + writeFoldedLines(state2, state2.line - _line); + captureStart = captureEnd = state2.position; + hasPendingContent = false; + } + if (!is_WHITE_SPACE(ch2)) { + captureEnd = state2.position + 1; + } + ch2 = state2.input.charCodeAt(++state2.position); + } + captureSegment(state2, captureStart, captureEnd, false); + if (state2.result) { + return true; + } + state2.kind = _kind; + state2.result = _result; + return false; + } + function readSingleQuotedScalar(state2, nodeIndent) { + var ch2, captureStart, captureEnd; + ch2 = state2.input.charCodeAt(state2.position); + if (ch2 !== 39) { + return false; + } + state2.kind = "scalar"; + state2.result = ""; + state2.position++; + captureStart = captureEnd = state2.position; + while ((ch2 = state2.input.charCodeAt(state2.position)) !== 0) { + if (ch2 === 39) { + captureSegment(state2, captureStart, state2.position, true); + ch2 = state2.input.charCodeAt(++state2.position); + if (ch2 === 39) { + captureStart = state2.position; + state2.position++; + captureEnd = state2.position; + } else { + return true; + } + } else if (is_EOL(ch2)) { + captureSegment(state2, captureStart, captureEnd, true); + writeFoldedLines(state2, skipSeparationSpace(state2, false, nodeIndent)); + captureStart = captureEnd = state2.position; + } else if (state2.position === state2.lineStart && testDocumentSeparator(state2)) { + throwError(state2, "unexpected end of the document within a single quoted scalar"); + } else { + state2.position++; + captureEnd = state2.position; + } + } + throwError(state2, "unexpected end of the stream within a single quoted scalar"); + } + function readDoubleQuotedScalar(state2, nodeIndent) { + var captureStart, captureEnd, hexLength, hexResult, tmp, ch2; + ch2 = state2.input.charCodeAt(state2.position); + if (ch2 !== 34) { + return false; + } + state2.kind = "scalar"; + state2.result = ""; + state2.position++; + captureStart = captureEnd = state2.position; + while ((ch2 = state2.input.charCodeAt(state2.position)) !== 0) { + if (ch2 === 34) { + captureSegment(state2, captureStart, state2.position, true); + state2.position++; + return true; + } else if (ch2 === 92) { + captureSegment(state2, captureStart, state2.position, true); + ch2 = state2.input.charCodeAt(++state2.position); + if (is_EOL(ch2)) { + skipSeparationSpace(state2, false, nodeIndent); + } else if (ch2 < 256 && simpleEscapeCheck[ch2]) { + state2.result += simpleEscapeMap[ch2]; + state2.position++; + } else if ((tmp = escapedHexLen(ch2)) > 0) { + hexLength = tmp; + hexResult = 0; + for (; hexLength > 0; hexLength--) { + ch2 = state2.input.charCodeAt(++state2.position); + if ((tmp = fromHexCode(ch2)) >= 0) { + hexResult = (hexResult << 4) + tmp; + } else { + throwError(state2, "expected hexadecimal character"); + } + } + state2.result += charFromCodepoint(hexResult); + state2.position++; + } else { + throwError(state2, "unknown escape sequence"); + } + captureStart = captureEnd = state2.position; + } else if (is_EOL(ch2)) { + captureSegment(state2, captureStart, captureEnd, true); + writeFoldedLines(state2, skipSeparationSpace(state2, false, nodeIndent)); + captureStart = captureEnd = state2.position; + } else if (state2.position === state2.lineStart && testDocumentSeparator(state2)) { + throwError(state2, "unexpected end of the document within a double quoted scalar"); + } else { + state2.position++; + captureEnd = state2.position; + } + } + throwError(state2, "unexpected end of the stream within a double quoted scalar"); + } + function readFlowCollection(state2, nodeIndent) { + var readNext = true, _line, _lineStart, _pos, _tag = state2.tag, _result, _anchor = state2.anchor, following, terminator, isPair, isExplicitPair, isMapping, overridableKeys = /* @__PURE__ */ Object.create(null), keyNode, keyTag, valueNode, ch2; + ch2 = state2.input.charCodeAt(state2.position); + if (ch2 === 91) { + terminator = 93; + isMapping = false; + _result = []; + } else if (ch2 === 123) { + terminator = 125; + isMapping = true; + _result = {}; + } else { + return false; + } + if (state2.anchor !== null) { + state2.anchorMap[state2.anchor] = _result; + } + ch2 = state2.input.charCodeAt(++state2.position); + while (ch2 !== 0) { + skipSeparationSpace(state2, true, nodeIndent); + ch2 = state2.input.charCodeAt(state2.position); + if (ch2 === terminator) { + state2.position++; + state2.tag = _tag; + state2.anchor = _anchor; + state2.kind = isMapping ? "mapping" : "sequence"; + state2.result = _result; + return true; + } else if (!readNext) { + throwError(state2, "missed comma between flow collection entries"); + } else if (ch2 === 44) { + throwError(state2, "expected the node content, but found ','"); + } + keyTag = keyNode = valueNode = null; + isPair = isExplicitPair = false; + if (ch2 === 63) { + following = state2.input.charCodeAt(state2.position + 1); + if (is_WS_OR_EOL(following)) { + isPair = isExplicitPair = true; + state2.position++; + skipSeparationSpace(state2, true, nodeIndent); + } + } + _line = state2.line; + _lineStart = state2.lineStart; + _pos = state2.position; + composeNode(state2, nodeIndent, CONTEXT_FLOW_IN, false, true); + keyTag = state2.tag; + keyNode = state2.result; + skipSeparationSpace(state2, true, nodeIndent); + ch2 = state2.input.charCodeAt(state2.position); + if ((isExplicitPair || state2.line === _line) && ch2 === 58) { + isPair = true; + ch2 = state2.input.charCodeAt(++state2.position); + skipSeparationSpace(state2, true, nodeIndent); + composeNode(state2, nodeIndent, CONTEXT_FLOW_IN, false, true); + valueNode = state2.result; + } + if (isMapping) { + storeMappingPair(state2, _result, overridableKeys, keyTag, keyNode, valueNode, _line, _lineStart, _pos); + } else if (isPair) { + _result.push(storeMappingPair(state2, null, overridableKeys, keyTag, keyNode, valueNode, _line, _lineStart, _pos)); + } else { + _result.push(keyNode); + } + skipSeparationSpace(state2, true, nodeIndent); + ch2 = state2.input.charCodeAt(state2.position); + if (ch2 === 44) { + readNext = true; + ch2 = state2.input.charCodeAt(++state2.position); + } else { + readNext = false; + } + } + throwError(state2, "unexpected end of the stream within a flow collection"); + } + function readBlockScalar(state2, nodeIndent) { + var captureStart, folding, chomping = CHOMPING_CLIP, didReadContent = false, detectedIndent = false, textIndent = nodeIndent, emptyLines = 0, atMoreIndented = false, tmp, ch2; + ch2 = state2.input.charCodeAt(state2.position); + if (ch2 === 124) { + folding = false; + } else if (ch2 === 62) { + folding = true; + } else { + return false; + } + state2.kind = "scalar"; + state2.result = ""; + while (ch2 !== 0) { + ch2 = state2.input.charCodeAt(++state2.position); + if (ch2 === 43 || ch2 === 45) { + if (CHOMPING_CLIP === chomping) { + chomping = ch2 === 43 ? CHOMPING_KEEP : CHOMPING_STRIP; + } else { + throwError(state2, "repeat of a chomping mode identifier"); + } + } else if ((tmp = fromDecimalCode(ch2)) >= 0) { + if (tmp === 0) { + throwError(state2, "bad explicit indentation width of a block scalar; it cannot be less than one"); + } else if (!detectedIndent) { + textIndent = nodeIndent + tmp - 1; + detectedIndent = true; + } else { + throwError(state2, "repeat of an indentation width identifier"); + } + } else { + break; + } + } + if (is_WHITE_SPACE(ch2)) { + do { + ch2 = state2.input.charCodeAt(++state2.position); + } while (is_WHITE_SPACE(ch2)); + if (ch2 === 35) { + do { + ch2 = state2.input.charCodeAt(++state2.position); + } while (!is_EOL(ch2) && ch2 !== 0); + } + } + while (ch2 !== 0) { + readLineBreak(state2); + state2.lineIndent = 0; + ch2 = state2.input.charCodeAt(state2.position); + while ((!detectedIndent || state2.lineIndent < textIndent) && ch2 === 32) { + state2.lineIndent++; + ch2 = state2.input.charCodeAt(++state2.position); + } + if (!detectedIndent && state2.lineIndent > textIndent) { + textIndent = state2.lineIndent; + } + if (is_EOL(ch2)) { + emptyLines++; + continue; + } + if (state2.lineIndent < textIndent) { + if (chomping === CHOMPING_KEEP) { + state2.result += common.repeat("\n", didReadContent ? 1 + emptyLines : emptyLines); + } else if (chomping === CHOMPING_CLIP) { + if (didReadContent) { + state2.result += "\n"; + } + } + break; + } + if (folding) { + if (is_WHITE_SPACE(ch2)) { + atMoreIndented = true; + state2.result += common.repeat("\n", didReadContent ? 1 + emptyLines : emptyLines); + } else if (atMoreIndented) { + atMoreIndented = false; + state2.result += common.repeat("\n", emptyLines + 1); + } else if (emptyLines === 0) { + if (didReadContent) { + state2.result += " "; + } + } else { + state2.result += common.repeat("\n", emptyLines); + } + } else { + state2.result += common.repeat("\n", didReadContent ? 1 + emptyLines : emptyLines); + } + didReadContent = true; + detectedIndent = true; + emptyLines = 0; + captureStart = state2.position; + while (!is_EOL(ch2) && ch2 !== 0) { + ch2 = state2.input.charCodeAt(++state2.position); + } + captureSegment(state2, captureStart, state2.position, false); + } + return true; + } + function readBlockSequence(state2, nodeIndent) { + var _line, _tag = state2.tag, _anchor = state2.anchor, _result = [], following, detected = false, ch2; + if (state2.firstTabInLine !== -1) + return false; + if (state2.anchor !== null) { + state2.anchorMap[state2.anchor] = _result; + } + ch2 = state2.input.charCodeAt(state2.position); + while (ch2 !== 0) { + if (state2.firstTabInLine !== -1) { + state2.position = state2.firstTabInLine; + throwError(state2, "tab characters must not be used in indentation"); + } + if (ch2 !== 45) { + break; + } + following = state2.input.charCodeAt(state2.position + 1); + if (!is_WS_OR_EOL(following)) { + break; + } + detected = true; + state2.position++; + if (skipSeparationSpace(state2, true, -1)) { + if (state2.lineIndent <= nodeIndent) { + _result.push(null); + ch2 = state2.input.charCodeAt(state2.position); + continue; + } + } + _line = state2.line; + composeNode(state2, nodeIndent, CONTEXT_BLOCK_IN, false, true); + _result.push(state2.result); + skipSeparationSpace(state2, true, -1); + ch2 = state2.input.charCodeAt(state2.position); + if ((state2.line === _line || state2.lineIndent > nodeIndent) && ch2 !== 0) { + throwError(state2, "bad indentation of a sequence entry"); + } else if (state2.lineIndent < nodeIndent) { + break; + } + } + if (detected) { + state2.tag = _tag; + state2.anchor = _anchor; + state2.kind = "sequence"; + state2.result = _result; + return true; + } + return false; + } + function readBlockMapping(state2, nodeIndent, flowIndent) { + var following, allowCompact, _line, _keyLine, _keyLineStart, _keyPos, _tag = state2.tag, _anchor = state2.anchor, _result = {}, overridableKeys = /* @__PURE__ */ Object.create(null), keyTag = null, keyNode = null, valueNode = null, atExplicitKey = false, detected = false, ch2; + if (state2.firstTabInLine !== -1) + return false; + if (state2.anchor !== null) { + state2.anchorMap[state2.anchor] = _result; + } + ch2 = state2.input.charCodeAt(state2.position); + while (ch2 !== 0) { + if (!atExplicitKey && state2.firstTabInLine !== -1) { + state2.position = state2.firstTabInLine; + throwError(state2, "tab characters must not be used in indentation"); + } + following = state2.input.charCodeAt(state2.position + 1); + _line = state2.line; + if ((ch2 === 63 || ch2 === 58) && is_WS_OR_EOL(following)) { + if (ch2 === 63) { + if (atExplicitKey) { + storeMappingPair(state2, _result, overridableKeys, keyTag, keyNode, null, _keyLine, _keyLineStart, _keyPos); + keyTag = keyNode = valueNode = null; + } + detected = true; + atExplicitKey = true; + allowCompact = true; + } else if (atExplicitKey) { + atExplicitKey = false; + allowCompact = true; + } else { + throwError(state2, "incomplete explicit mapping pair; a key node is missed; or followed by a non-tabulated empty line"); + } + state2.position += 1; + ch2 = following; + } else { + _keyLine = state2.line; + _keyLineStart = state2.lineStart; + _keyPos = state2.position; + if (!composeNode(state2, flowIndent, CONTEXT_FLOW_OUT, false, true)) { + break; + } + if (state2.line === _line) { + ch2 = state2.input.charCodeAt(state2.position); + while (is_WHITE_SPACE(ch2)) { + ch2 = state2.input.charCodeAt(++state2.position); + } + if (ch2 === 58) { + ch2 = state2.input.charCodeAt(++state2.position); + if (!is_WS_OR_EOL(ch2)) { + throwError(state2, "a whitespace character is expected after the key-value separator within a block mapping"); + } + if (atExplicitKey) { + storeMappingPair(state2, _result, overridableKeys, keyTag, keyNode, null, _keyLine, _keyLineStart, _keyPos); + keyTag = keyNode = valueNode = null; + } + detected = true; + atExplicitKey = false; + allowCompact = false; + keyTag = state2.tag; + keyNode = state2.result; + } else if (detected) { + throwError(state2, "can not read an implicit mapping pair; a colon is missed"); + } else { + state2.tag = _tag; + state2.anchor = _anchor; + return true; + } + } else if (detected) { + throwError(state2, "can not read a block mapping entry; a multiline key may not be an implicit key"); + } else { + state2.tag = _tag; + state2.anchor = _anchor; + return true; + } + } + if (state2.line === _line || state2.lineIndent > nodeIndent) { + if (atExplicitKey) { + _keyLine = state2.line; + _keyLineStart = state2.lineStart; + _keyPos = state2.position; + } + if (composeNode(state2, nodeIndent, CONTEXT_BLOCK_OUT, true, allowCompact)) { + if (atExplicitKey) { + keyNode = state2.result; + } else { + valueNode = state2.result; + } + } + if (!atExplicitKey) { + storeMappingPair(state2, _result, overridableKeys, keyTag, keyNode, valueNode, _keyLine, _keyLineStart, _keyPos); + keyTag = keyNode = valueNode = null; + } + skipSeparationSpace(state2, true, -1); + ch2 = state2.input.charCodeAt(state2.position); + } + if ((state2.line === _line || state2.lineIndent > nodeIndent) && ch2 !== 0) { + throwError(state2, "bad indentation of a mapping entry"); + } else if (state2.lineIndent < nodeIndent) { + break; + } + } + if (atExplicitKey) { + storeMappingPair(state2, _result, overridableKeys, keyTag, keyNode, null, _keyLine, _keyLineStart, _keyPos); + } + if (detected) { + state2.tag = _tag; + state2.anchor = _anchor; + state2.kind = "mapping"; + state2.result = _result; + } + return detected; + } + function readTagProperty(state2) { + var _position, isVerbatim = false, isNamed = false, tagHandle, tagName, ch2; + ch2 = state2.input.charCodeAt(state2.position); + if (ch2 !== 33) + return false; + if (state2.tag !== null) { + throwError(state2, "duplication of a tag property"); + } + ch2 = state2.input.charCodeAt(++state2.position); + if (ch2 === 60) { + isVerbatim = true; + ch2 = state2.input.charCodeAt(++state2.position); + } else if (ch2 === 33) { + isNamed = true; + tagHandle = "!!"; + ch2 = state2.input.charCodeAt(++state2.position); + } else { + tagHandle = "!"; + } + _position = state2.position; + if (isVerbatim) { + do { + ch2 = state2.input.charCodeAt(++state2.position); + } while (ch2 !== 0 && ch2 !== 62); + if (state2.position < state2.length) { + tagName = state2.input.slice(_position, state2.position); + ch2 = state2.input.charCodeAt(++state2.position); + } else { + throwError(state2, "unexpected end of the stream within a verbatim tag"); + } + } else { + while (ch2 !== 0 && !is_WS_OR_EOL(ch2)) { + if (ch2 === 33) { + if (!isNamed) { + tagHandle = state2.input.slice(_position - 1, state2.position + 1); + if (!PATTERN_TAG_HANDLE.test(tagHandle)) { + throwError(state2, "named tag handle cannot contain such characters"); + } + isNamed = true; + _position = state2.position + 1; + } else { + throwError(state2, "tag suffix cannot contain exclamation marks"); + } + } + ch2 = state2.input.charCodeAt(++state2.position); + } + tagName = state2.input.slice(_position, state2.position); + if (PATTERN_FLOW_INDICATORS.test(tagName)) { + throwError(state2, "tag suffix cannot contain flow indicator characters"); + } + } + if (tagName && !PATTERN_TAG_URI.test(tagName)) { + throwError(state2, "tag name cannot contain such characters: " + tagName); + } + try { + tagName = decodeURIComponent(tagName); + } catch (err) { + throwError(state2, "tag name is malformed: " + tagName); + } + if (isVerbatim) { + state2.tag = tagName; + } else if (_hasOwnProperty$1.call(state2.tagMap, tagHandle)) { + state2.tag = state2.tagMap[tagHandle] + tagName; + } else if (tagHandle === "!") { + state2.tag = "!" + tagName; + } else if (tagHandle === "!!") { + state2.tag = "tag:yaml.org,2002:" + tagName; + } else { + throwError(state2, 'undeclared tag handle "' + tagHandle + '"'); + } + return true; + } + function readAnchorProperty(state2) { + var _position, ch2; + ch2 = state2.input.charCodeAt(state2.position); + if (ch2 !== 38) + return false; + if (state2.anchor !== null) { + throwError(state2, "duplication of an anchor property"); + } + ch2 = state2.input.charCodeAt(++state2.position); + _position = state2.position; + while (ch2 !== 0 && !is_WS_OR_EOL(ch2) && !is_FLOW_INDICATOR(ch2)) { + ch2 = state2.input.charCodeAt(++state2.position); + } + if (state2.position === _position) { + throwError(state2, "name of an anchor node must contain at least one character"); + } + state2.anchor = state2.input.slice(_position, state2.position); + return true; + } + function readAlias(state2) { + var _position, alias, ch2; + ch2 = state2.input.charCodeAt(state2.position); + if (ch2 !== 42) + return false; + ch2 = state2.input.charCodeAt(++state2.position); + _position = state2.position; + while (ch2 !== 0 && !is_WS_OR_EOL(ch2) && !is_FLOW_INDICATOR(ch2)) { + ch2 = state2.input.charCodeAt(++state2.position); + } + if (state2.position === _position) { + throwError(state2, "name of an alias node must contain at least one character"); + } + alias = state2.input.slice(_position, state2.position); + if (!_hasOwnProperty$1.call(state2.anchorMap, alias)) { + throwError(state2, 'unidentified alias "' + alias + '"'); + } + state2.result = state2.anchorMap[alias]; + skipSeparationSpace(state2, true, -1); + return true; + } + function composeNode(state2, parentIndent, nodeContext, allowToSeek, allowCompact) { + var allowBlockStyles, allowBlockScalars, allowBlockCollections, indentStatus = 1, atNewLine = false, hasContent = false, typeIndex, typeQuantity, typeList, type2, flowIndent, blockIndent; + if (state2.listener !== null) { + state2.listener("open", state2); + } + state2.tag = null; + state2.anchor = null; + state2.kind = null; + state2.result = null; + allowBlockStyles = allowBlockScalars = allowBlockCollections = CONTEXT_BLOCK_OUT === nodeContext || CONTEXT_BLOCK_IN === nodeContext; + if (allowToSeek) { + if (skipSeparationSpace(state2, true, -1)) { + atNewLine = true; + if (state2.lineIndent > parentIndent) { + indentStatus = 1; + } else if (state2.lineIndent === parentIndent) { + indentStatus = 0; + } else if (state2.lineIndent < parentIndent) { + indentStatus = -1; + } + } + } + if (indentStatus === 1) { + while (readTagProperty(state2) || readAnchorProperty(state2)) { + if (skipSeparationSpace(state2, true, -1)) { + atNewLine = true; + allowBlockCollections = allowBlockStyles; + if (state2.lineIndent > parentIndent) { + indentStatus = 1; + } else if (state2.lineIndent === parentIndent) { + indentStatus = 0; + } else if (state2.lineIndent < parentIndent) { + indentStatus = -1; + } + } else { + allowBlockCollections = false; + } + } + } + if (allowBlockCollections) { + allowBlockCollections = atNewLine || allowCompact; + } + if (indentStatus === 1 || CONTEXT_BLOCK_OUT === nodeContext) { + if (CONTEXT_FLOW_IN === nodeContext || CONTEXT_FLOW_OUT === nodeContext) { + flowIndent = parentIndent; + } else { + flowIndent = parentIndent + 1; + } + blockIndent = state2.position - state2.lineStart; + if (indentStatus === 1) { + if (allowBlockCollections && (readBlockSequence(state2, blockIndent) || readBlockMapping(state2, blockIndent, flowIndent)) || readFlowCollection(state2, flowIndent)) { + hasContent = true; + } else { + if (allowBlockScalars && readBlockScalar(state2, flowIndent) || readSingleQuotedScalar(state2, flowIndent) || readDoubleQuotedScalar(state2, flowIndent)) { + hasContent = true; + } else if (readAlias(state2)) { + hasContent = true; + if (state2.tag !== null || state2.anchor !== null) { + throwError(state2, "alias node should not have any properties"); + } + } else if (readPlainScalar(state2, flowIndent, CONTEXT_FLOW_IN === nodeContext)) { + hasContent = true; + if (state2.tag === null) { + state2.tag = "?"; + } + } + if (state2.anchor !== null) { + state2.anchorMap[state2.anchor] = state2.result; + } + } + } else if (indentStatus === 0) { + hasContent = allowBlockCollections && readBlockSequence(state2, blockIndent); + } + } + if (state2.tag === null) { + if (state2.anchor !== null) { + state2.anchorMap[state2.anchor] = state2.result; + } + } else if (state2.tag === "?") { + if (state2.result !== null && state2.kind !== "scalar") { + throwError(state2, 'unacceptable node kind for ! tag; it should be "scalar", not "' + state2.kind + '"'); + } + for (typeIndex = 0, typeQuantity = state2.implicitTypes.length; typeIndex < typeQuantity; typeIndex += 1) { + type2 = state2.implicitTypes[typeIndex]; + if (type2.resolve(state2.result)) { + state2.result = type2.construct(state2.result); + state2.tag = type2.tag; + if (state2.anchor !== null) { + state2.anchorMap[state2.anchor] = state2.result; + } + break; + } + } + } else if (state2.tag !== "!") { + if (_hasOwnProperty$1.call(state2.typeMap[state2.kind || "fallback"], state2.tag)) { + type2 = state2.typeMap[state2.kind || "fallback"][state2.tag]; + } else { + type2 = null; + typeList = state2.typeMap.multi[state2.kind || "fallback"]; + for (typeIndex = 0, typeQuantity = typeList.length; typeIndex < typeQuantity; typeIndex += 1) { + if (state2.tag.slice(0, typeList[typeIndex].tag.length) === typeList[typeIndex].tag) { + type2 = typeList[typeIndex]; + break; + } + } + } + if (!type2) { + throwError(state2, "unknown tag !<" + state2.tag + ">"); + } + if (state2.result !== null && type2.kind !== state2.kind) { + throwError(state2, "unacceptable node kind for !<" + state2.tag + '> tag; it should be "' + type2.kind + '", not "' + state2.kind + '"'); + } + if (!type2.resolve(state2.result, state2.tag)) { + throwError(state2, "cannot resolve a node with !<" + state2.tag + "> explicit tag"); + } else { + state2.result = type2.construct(state2.result, state2.tag); + if (state2.anchor !== null) { + state2.anchorMap[state2.anchor] = state2.result; + } + } + } + if (state2.listener !== null) { + state2.listener("close", state2); + } + return state2.tag !== null || state2.anchor !== null || hasContent; + } + function readDocument(state2) { + var documentStart = state2.position, _position, directiveName, directiveArgs, hasDirectives = false, ch2; + state2.version = null; + state2.checkLineBreaks = state2.legacy; + state2.tagMap = /* @__PURE__ */ Object.create(null); + state2.anchorMap = /* @__PURE__ */ Object.create(null); + while ((ch2 = state2.input.charCodeAt(state2.position)) !== 0) { + skipSeparationSpace(state2, true, -1); + ch2 = state2.input.charCodeAt(state2.position); + if (state2.lineIndent > 0 || ch2 !== 37) { + break; + } + hasDirectives = true; + ch2 = state2.input.charCodeAt(++state2.position); + _position = state2.position; + while (ch2 !== 0 && !is_WS_OR_EOL(ch2)) { + ch2 = state2.input.charCodeAt(++state2.position); + } + directiveName = state2.input.slice(_position, state2.position); + directiveArgs = []; + if (directiveName.length < 1) { + throwError(state2, "directive name must not be less than one character in length"); + } + while (ch2 !== 0) { + while (is_WHITE_SPACE(ch2)) { + ch2 = state2.input.charCodeAt(++state2.position); + } + if (ch2 === 35) { + do { + ch2 = state2.input.charCodeAt(++state2.position); + } while (ch2 !== 0 && !is_EOL(ch2)); + break; + } + if (is_EOL(ch2)) + break; + _position = state2.position; + while (ch2 !== 0 && !is_WS_OR_EOL(ch2)) { + ch2 = state2.input.charCodeAt(++state2.position); + } + directiveArgs.push(state2.input.slice(_position, state2.position)); + } + if (ch2 !== 0) + readLineBreak(state2); + if (_hasOwnProperty$1.call(directiveHandlers, directiveName)) { + directiveHandlers[directiveName](state2, directiveName, directiveArgs); + } else { + throwWarning(state2, 'unknown document directive "' + directiveName + '"'); + } + } + skipSeparationSpace(state2, true, -1); + if (state2.lineIndent === 0 && state2.input.charCodeAt(state2.position) === 45 && state2.input.charCodeAt(state2.position + 1) === 45 && state2.input.charCodeAt(state2.position + 2) === 45) { + state2.position += 3; + skipSeparationSpace(state2, true, -1); + } else if (hasDirectives) { + throwError(state2, "directives end mark is expected"); + } + composeNode(state2, state2.lineIndent - 1, CONTEXT_BLOCK_OUT, false, true); + skipSeparationSpace(state2, true, -1); + if (state2.checkLineBreaks && PATTERN_NON_ASCII_LINE_BREAKS.test(state2.input.slice(documentStart, state2.position))) { + throwWarning(state2, "non-ASCII line breaks are interpreted as content"); + } + state2.documents.push(state2.result); + if (state2.position === state2.lineStart && testDocumentSeparator(state2)) { + if (state2.input.charCodeAt(state2.position) === 46) { + state2.position += 3; + skipSeparationSpace(state2, true, -1); + } + return; + } + if (state2.position < state2.length - 1) { + throwError(state2, "end of the stream or a document separator is expected"); + } else { + return; + } + } + function loadDocuments(input, options2) { + input = String(input); + options2 = options2 || {}; + if (input.length !== 0) { + if (input.charCodeAt(input.length - 1) !== 10 && input.charCodeAt(input.length - 1) !== 13) { + input += "\n"; + } + if (input.charCodeAt(0) === 65279) { + input = input.slice(1); + } + } + var state2 = new State$1(input, options2); + var nullpos = input.indexOf("\0"); + if (nullpos !== -1) { + state2.position = nullpos; + throwError(state2, "null byte is not allowed in input"); + } + state2.input += "\0"; + while (state2.input.charCodeAt(state2.position) === 32) { + state2.lineIndent += 1; + state2.position += 1; + } + while (state2.position < state2.length - 1) { + readDocument(state2); + } + return state2.documents; + } + function loadAll$1(input, iterator, options2) { + if (iterator !== null && typeof iterator === "object" && typeof options2 === "undefined") { + options2 = iterator; + iterator = null; + } + var documents2 = loadDocuments(input, options2); + if (typeof iterator !== "function") { + return documents2; + } + for (var index2 = 0, length2 = documents2.length; index2 < length2; index2 += 1) { + iterator(documents2[index2]); + } + } + function load$1(input, options2) { + var documents2 = loadDocuments(input, options2); + if (documents2.length === 0) { + return void 0; + } else if (documents2.length === 1) { + return documents2[0]; + } + throw new exception("expected a single document in the stream, but found more"); + } + var loadAll_1 = loadAll$1; + var load_1 = load$1; + var loader = { + loadAll: loadAll_1, + load: load_1 + }; + var JSON_SCHEMA = json; + var load = loader.load; + function extractFrontMatter(text2) { + const matches = text2.match(frontMatterRegex); + if (!matches) { + return { + text: text2, + metadata: {} + }; + } + let parsed = load(matches[1], { + // To support config, we need JSON schema. + // https://www.yaml.org/spec/1.2/spec.html#id2803231 + schema: JSON_SCHEMA + }) ?? {}; + parsed = typeof parsed === "object" && !Array.isArray(parsed) ? parsed : {}; + const metadata = {}; + if (parsed.displayMode) { + metadata.displayMode = parsed.displayMode.toString(); + } + if (parsed.title) { + metadata.title = parsed.title.toString(); + } + if (parsed.config) { + metadata.config = parsed.config; + } + return { + text: text2.slice(matches[0].length), + metadata + }; + } + const cleanupText = (code) => { + return code.replace(/\r\n?/g, "\n").replace( + /<(\w+)([^>]*)>/g, + (match, tag, attributes) => "<" + tag + attributes.replace(/="([^"]*)"/g, "='$1'") + ">" + ); + }; + const processFrontmatter = (code) => { + const { text: text2, metadata } = extractFrontMatter(code); + const { displayMode: displayMode2, title: title2, config: config2 = {} } = metadata; + if (displayMode2) { + if (!config2.gantt) { + config2.gantt = {}; + } + config2.gantt.displayMode = displayMode2; + } + return { title: title2, config: config2, text: text2 }; + }; + const processDirectives = (code) => { + const initDirective = utils$1.detectInit(code) ?? {}; + const wrapDirectives = utils$1.detectDirective(code, "wrap"); + if (Array.isArray(wrapDirectives)) { + initDirective.wrap = wrapDirectives.some(({ type: type2 }) => { + }); + } else if ((wrapDirectives == null ? void 0 : wrapDirectives.type) === "wrap") { + initDirective.wrap = true; + } + return { + text: removeDirectives(code), + directive: initDirective + }; + }; + function preprocessDiagram(code) { + const cleanedCode = cleanupText(code); + const frontMatterResult = processFrontmatter(cleanedCode); + const directiveResult = processDirectives(frontMatterResult.text); + const config2 = cleanAndMerge(frontMatterResult.config, directiveResult.directive); + code = cleanupComments(directiveResult.text); + return { + code, + title: frontMatterResult.title, + config: config2 + }; + } + const MAX_TEXTLENGTH = 5e4; + const MAX_TEXTLENGTH_EXCEEDED_MSG = "graph TB;a[Maximum text size in diagram exceeded];style a fill:#faa"; + const SECURITY_LVL_SANDBOX = "sandbox"; + const SECURITY_LVL_LOOSE = "loose"; + const XMLNS_SVG_STD = "http://www.w3.org/2000/svg"; + const XMLNS_XLINK_STD = "http://www.w3.org/1999/xlink"; + const XMLNS_XHTML_STD = "http://www.w3.org/1999/xhtml"; + const IFRAME_WIDTH = "100%"; + const IFRAME_HEIGHT = "100%"; + const IFRAME_STYLES = "border:0;margin:0;"; + const IFRAME_BODY_STYLE = "margin:0"; + const IFRAME_SANDBOX_OPTS = "allow-top-navigation-by-user-activation allow-popups"; + const IFRAME_NOT_SUPPORTED_MSG = 'The "iframe" tag is not supported by your browser.'; + const DOMPURIFY_TAGS = ["foreignobject"]; + const DOMPURIFY_ATTR = ["dominant-baseline"]; + function processAndSetConfigs(text2) { + const processed2 = preprocessDiagram(text2); + reset(); + addDirective(processed2.config ?? {}); + return processed2; + } + async function parse$3(text2, parseOptions) { + addDiagrams(); + text2 = processAndSetConfigs(text2).code; + try { + await getDiagramFromText(text2); + } catch (error) { + if (parseOptions == null ? void 0 : parseOptions.suppressErrors) { + return false; + } + throw error; + } + return true; + } + const cssImportantStyles = (cssClass, element2, cssClasses = []) => { + return ` +.${cssClass} ${element2} { ${cssClasses.join(" !important; ")} !important; }`; + }; + const createCssStyles = (config2, classDefs = {}) => { + var _a2; + let cssStyles = ""; + if (config2.themeCSS !== void 0) { + cssStyles += ` +${config2.themeCSS}`; + } + if (config2.fontFamily !== void 0) { + cssStyles += ` +:root { --mermaid-font-family: ${config2.fontFamily}}`; + } + if (config2.altFontFamily !== void 0) { + cssStyles += ` +:root { --mermaid-alt-font-family: ${config2.altFontFamily}}`; + } + if (!isEmpty(classDefs)) { + const htmlLabels = config2.htmlLabels || ((_a2 = config2.flowchart) == null ? void 0 : _a2.htmlLabels); + const cssHtmlElements = ["> *", "span"]; + const cssShapeElements = ["rect", "polygon", "ellipse", "circle", "path"]; + const cssElements = htmlLabels ? cssHtmlElements : cssShapeElements; + for (const classId in classDefs) { + const styleClassDef = classDefs[classId]; + if (!isEmpty(styleClassDef.styles)) { + cssElements.forEach((cssElement) => { + cssStyles += cssImportantStyles(styleClassDef.id, cssElement, styleClassDef.styles); + }); + } + if (!isEmpty(styleClassDef.textStyles)) { + cssStyles += cssImportantStyles(styleClassDef.id, "tspan", styleClassDef.textStyles); + } + } + } + return cssStyles; + }; + const createUserStyles = (config2, graphType, classDefs, svgId) => { + const userCSSstyles = createCssStyles(config2, classDefs); + const allStyles = getStyles$g(graphType, userCSSstyles, config2.themeVariables); + return serialize(compile(`${svgId}{${allStyles}}`), stringify); + }; + const cleanUpSvgCode = (svgCode = "", inSandboxMode, useArrowMarkerUrls) => { + let cleanedUpSvg = svgCode; + if (!useArrowMarkerUrls && !inSandboxMode) { + cleanedUpSvg = cleanedUpSvg.replace( + /marker-end="url\([\d+./:=?A-Za-z-]*?#/g, + 'marker-end="url(#' + ); + } + cleanedUpSvg = decodeEntities(cleanedUpSvg); + cleanedUpSvg = cleanedUpSvg.replace(/
    /g, "
    "); + return cleanedUpSvg; + }; + const putIntoIFrame = (svgCode = "", svgElement) => { + var _a2, _b2; + const height = ((_b2 = (_a2 = svgElement == null ? void 0 : svgElement.viewBox) == null ? void 0 : _a2.baseVal) == null ? void 0 : _b2.height) ? svgElement.viewBox.baseVal.height + "px" : IFRAME_HEIGHT; + const base64encodedSrc = btoa('' + svgCode + ""); + return ``; + }; + const appendDivSvgG = (parentRoot, id2, enclosingDivId, divStyle, svgXlink) => { + const enclosingDiv = parentRoot.append("div"); + enclosingDiv.attr("id", enclosingDivId); + if (divStyle) { + enclosingDiv.attr("style", divStyle); + } + const svgNode2 = enclosingDiv.append("svg").attr("id", id2).attr("width", "100%").attr("xmlns", XMLNS_SVG_STD); + if (svgXlink) { + svgNode2.attr("xmlns:xlink", svgXlink); + } + svgNode2.append("g"); + return parentRoot; + }; + function sandboxedIframe(parentNode, iFrameId) { + return parentNode.append("iframe").attr("id", iFrameId).attr("style", "width: 100%; height: 100%;").attr("sandbox", ""); + } + const removeExistingElements = (doc, id2, divId, iFrameId) => { + var _a2, _b2, _c; + (_a2 = doc.getElementById(id2)) == null ? void 0 : _a2.remove(); + (_b2 = doc.getElementById(divId)) == null ? void 0 : _b2.remove(); + (_c = doc.getElementById(iFrameId)) == null ? void 0 : _c.remove(); + }; + const render$4 = async function(id2, text2, svgContainingElement) { + var _a2, _b2, _c, _d, _e, _f; + addDiagrams(); + const processed2 = processAndSetConfigs(text2); + text2 = processed2.code; + const config2 = getConfig$2(); + log$1.debug(config2); + if (text2.length > ((config2 == null ? void 0 : config2.maxTextSize) ?? MAX_TEXTLENGTH)) { + text2 = MAX_TEXTLENGTH_EXCEEDED_MSG; + } + const idSelector = "#" + id2; + const iFrameID = "i" + id2; + const iFrameID_selector = "#" + iFrameID; + const enclosingDivID = "d" + id2; + const enclosingDivID_selector = "#" + enclosingDivID; + let root2 = d3select("body"); + const isSandboxed = config2.securityLevel === SECURITY_LVL_SANDBOX; + const isLooseSecurityLevel = config2.securityLevel === SECURITY_LVL_LOOSE; + const fontFamily = config2.fontFamily; + if (svgContainingElement !== void 0) { + if (svgContainingElement) { + svgContainingElement.innerHTML = ""; + } + if (isSandboxed) { + const iframe = sandboxedIframe(d3select(svgContainingElement), iFrameID); + root2 = d3select(iframe.nodes()[0].contentDocument.body); + root2.node().style.margin = 0; + } else { + root2 = d3select(svgContainingElement); + } + appendDivSvgG(root2, id2, enclosingDivID, `font-family: ${fontFamily}`, XMLNS_XLINK_STD); + } else { + removeExistingElements(document, id2, enclosingDivID, iFrameID); + if (isSandboxed) { + const iframe = sandboxedIframe(d3select("body"), iFrameID); + root2 = d3select(iframe.nodes()[0].contentDocument.body); + root2.node().style.margin = 0; + } else { + root2 = d3select("body"); + } + appendDivSvgG(root2, id2, enclosingDivID); + } + let diag; + let parseEncounteredException; + try { + diag = await getDiagramFromText(text2, { title: processed2.title }); + } catch (error) { + diag = new Diagram("error"); + parseEncounteredException = error; + } + const element2 = root2.select(enclosingDivID_selector).node(); + const diagramType = diag.type; + const svg2 = element2.firstChild; + const firstChild = svg2.firstChild; + const diagramClassDefs = (_b2 = (_a2 = diag.renderer).getClasses) == null ? void 0 : _b2.call(_a2, text2, diag); + const rules = createUserStyles(config2, diagramType, diagramClassDefs, idSelector); + const style1 = document.createElement("style"); + style1.innerHTML = rules; + svg2.insertBefore(style1, firstChild); + try { + await diag.renderer.draw(text2, id2, version$1, diag); + } catch (e) { + errorRenderer.draw(text2, id2, version$1); + throw e; + } + const svgNode2 = root2.select(`${enclosingDivID_selector} svg`); + const a11yTitle = (_d = (_c = diag.db).getAccTitle) == null ? void 0 : _d.call(_c); + const a11yDescr = (_f = (_e = diag.db).getAccDescription) == null ? void 0 : _f.call(_e); + addA11yInfo(diagramType, svgNode2, a11yTitle, a11yDescr); + root2.select(`[id="${id2}"]`).selectAll("foreignobject > *").attr("xmlns", XMLNS_XHTML_STD); + let svgCode = root2.select(enclosingDivID_selector).node().innerHTML; + log$1.debug("config.arrowMarkerAbsolute", config2.arrowMarkerAbsolute); + svgCode = cleanUpSvgCode(svgCode, isSandboxed, evaluate(config2.arrowMarkerAbsolute)); + if (isSandboxed) { + const svgEl = root2.select(enclosingDivID_selector + " svg").node(); + svgCode = putIntoIFrame(svgCode, svgEl); + } else if (!isLooseSecurityLevel) { + svgCode = purify.sanitize(svgCode, { + ADD_TAGS: DOMPURIFY_TAGS, + ADD_ATTR: DOMPURIFY_ATTR + }); + } + attachFunctions(); + if (parseEncounteredException) { + throw parseEncounteredException; + } + const tmpElementSelector = isSandboxed ? iFrameID_selector : enclosingDivID_selector; + const node2 = d3select(tmpElementSelector).node(); + if (node2 && "remove" in node2) { + node2.remove(); + } + return { + svg: svgCode, + bindFunctions: diag.db.bindFunctions + }; + }; + function initialize$1(options2 = {}) { + var _a2; + if ((options2 == null ? void 0 : options2.fontFamily) && !((_a2 = options2.themeVariables) == null ? void 0 : _a2.fontFamily)) { + if (!options2.themeVariables) { + options2.themeVariables = {}; + } + options2.themeVariables.fontFamily = options2.fontFamily; + } + saveConfigFromInitialize(options2); + if ((options2 == null ? void 0 : options2.theme) && options2.theme in theme) { + options2.themeVariables = theme[options2.theme].getThemeVariables( + options2.themeVariables + ); + } else if (options2) { + options2.themeVariables = theme.default.getThemeVariables(options2.themeVariables); + } + const config2 = typeof options2 === "object" ? setSiteConfig(options2) : getSiteConfig(); + setLogLevel$1(config2.logLevel); + addDiagrams(); + } + const getDiagramFromText = (text2, metadata = {}) => { + const { code } = preprocessDiagram(text2); + return getDiagramFromText$1(code, metadata); + }; + function addA11yInfo(diagramType, svgNode2, a11yTitle, a11yDescr) { + setA11yDiagramInfo(svgNode2, diagramType); + addSVGa11yTitleDescription(svgNode2, a11yTitle, a11yDescr, svgNode2.attr("id")); + } + const mermaidAPI = Object.freeze({ + render: render$4, + parse: parse$3, + getDiagramFromText, + initialize: initialize$1, + getConfig: getConfig$2, + setConfig: setConfig$1, + getSiteConfig, + updateSiteConfig, + reset: () => { + reset(); + }, + globalReset: () => { + reset(defaultConfig$1); + }, + defaultConfig: defaultConfig$1 + }); + setLogLevel$1(getConfig$2().logLevel); + reset(getConfig$2()); + const loadRegisteredDiagrams = async () => { + log$1.debug(`Loading registered diagrams`); + const results = await Promise.allSettled( + Object.entries(detectors).map(async ([key, { detector: detector2, loader: loader2 }]) => { + if (loader2) { + try { + getDiagram(key); + } catch (error) { + try { + const { diagram: diagram2, id: id2 } = await loader2(); + registerDiagram(id2, diagram2, detector2); + } catch (err) { + log$1.error(`Failed to load external diagram with key ${key}. Removing from detectors.`); + delete detectors[key]; + throw err; + } + } + } + }) + ); + const failed = results.filter((result) => result.status === "rejected"); + if (failed.length > 0) { + log$1.error(`Failed to load ${failed.length} external diagrams`); + for (const res of failed) { + log$1.error(res); + } + throw new Error(`Failed to load ${failed.length} external diagrams`); + } + }; + const handleError = (error, errors, parseError) => { + log$1.warn(error); + if (isDetailedError(error)) { + if (parseError) { + parseError(error.str, error.hash); + } + errors.push({ ...error, message: error.str, error }); + } else { + if (parseError) { + parseError(error); + } + if (error instanceof Error) { + errors.push({ + str: error.message, + message: error.message, + hash: error.name, + error + }); + } + } + }; + const run$3 = async function(options2 = { + querySelector: ".mermaid" + }) { + try { + await runThrowsErrors(options2); + } catch (e) { + if (isDetailedError(e)) { + log$1.error(e.str); + } + if (mermaid.parseError) { + mermaid.parseError(e); + } + if (!options2.suppressErrors) { + log$1.error("Use the suppressErrors option to suppress these errors"); + throw e; + } + } + }; + const runThrowsErrors = async function({ postRenderCallback, querySelector, nodes: nodes2 } = { + querySelector: ".mermaid" + }) { + const conf2 = mermaidAPI.getConfig(); + log$1.debug(`${!postRenderCallback ? "No " : ""}Callback function found`); + let nodesToProcess; + if (nodes2) { + nodesToProcess = nodes2; + } else if (querySelector) { + nodesToProcess = document.querySelectorAll(querySelector); + } else { + throw new Error("Nodes and querySelector are both undefined"); + } + log$1.debug(`Found ${nodesToProcess.length} diagrams`); + if ((conf2 == null ? void 0 : conf2.startOnLoad) !== void 0) { + log$1.debug("Start On Load: " + (conf2 == null ? void 0 : conf2.startOnLoad)); + mermaidAPI.updateSiteConfig({ startOnLoad: conf2 == null ? void 0 : conf2.startOnLoad }); + } + const idGenerator = new utils$1.InitIDGenerator(conf2.deterministicIds, conf2.deterministicIDSeed); + let txt; + const errors = []; + for (const element2 of Array.from(nodesToProcess)) { + log$1.info("Rendering diagram: " + element2.id); + /*! Check if previously processed */ + if (element2.getAttribute("data-processed")) { + continue; + } + element2.setAttribute("data-processed", "true"); + const id2 = `mermaid-${idGenerator.next()}`; + txt = element2.innerHTML; + txt = dedent(utils$1.entityDecode(txt)).trim().replace(//gi, "
    "); + const init2 = utils$1.detectInit(txt); + if (init2) { + log$1.debug("Detected early reinit: ", init2); + } + try { + const { svg: svg2, bindFunctions: bindFunctions2 } = await render$3(id2, txt, element2); + element2.innerHTML = svg2; + if (postRenderCallback) { + await postRenderCallback(id2); + } + if (bindFunctions2) { + bindFunctions2(element2); + } + } catch (error) { + handleError(error, errors, mermaid.parseError); + } + } + if (errors.length > 0) { + throw errors[0]; + } + }; + const initialize = function(config2) { + mermaidAPI.initialize(config2); + }; + const init = async function(config2, nodes2, callback) { + log$1.warn("mermaid.init is deprecated. Please use run instead."); + if (config2) { + initialize(config2); + } + const runOptions = { postRenderCallback: callback, querySelector: ".mermaid" }; + if (typeof nodes2 === "string") { + runOptions.querySelector = nodes2; + } else if (nodes2) { + if (nodes2 instanceof HTMLElement) { + runOptions.nodes = [nodes2]; + } else { + runOptions.nodes = nodes2; + } + } + await run$3(runOptions); + }; + const registerExternalDiagrams = async (diagrams2, { + lazyLoad = true + } = {}) => { + registerLazyLoadedDiagrams(...diagrams2); + if (lazyLoad === false) { + await loadRegisteredDiagrams(); + } + }; + const contentLoaded = function() { + if (mermaid.startOnLoad) { + const { startOnLoad } = mermaidAPI.getConfig(); + if (startOnLoad) { + mermaid.run().catch((err) => log$1.error("Mermaid failed to initialize", err)); + } + } + }; + if (typeof document !== "undefined") { + /*! + * Wait for document loaded before starting the execution + */ + window.addEventListener("load", contentLoaded, false); + } + const setParseErrorHandler = function(parseErrorHandler) { + mermaid.parseError = parseErrorHandler; + }; + const executionQueue = []; + let executionQueueRunning = false; + const executeQueue = async () => { + if (executionQueueRunning) { + return; + } + executionQueueRunning = true; + while (executionQueue.length > 0) { + const f2 = executionQueue.shift(); + if (f2) { + try { + await f2(); + } catch (e) { + log$1.error("Error executing queue", e); + } + } + } + executionQueueRunning = false; + }; + const parse$2 = async (text2, parseOptions) => { + return new Promise((resolve, reject) => { + const performCall = () => new Promise((res, rej) => { + mermaidAPI.parse(text2, parseOptions).then( + (r) => { + res(r); + resolve(r); + }, + (e) => { + var _a2; + log$1.error("Error parsing", e); + (_a2 = mermaid.parseError) == null ? void 0 : _a2.call(mermaid, e); + rej(e); + reject(e); + } + ); + }); + executionQueue.push(performCall); + executeQueue().catch(reject); + }); + }; + const render$3 = (id2, text2, container) => { + return new Promise((resolve, reject) => { + const performCall = () => new Promise((res, rej) => { + mermaidAPI.render(id2, text2, container).then( + (r) => { + res(r); + resolve(r); + }, + (e) => { + var _a2; + log$1.error("Error parsing", e); + (_a2 = mermaid.parseError) == null ? void 0 : _a2.call(mermaid, e); + rej(e); + reject(e); + } + ); + }); + executionQueue.push(performCall); + executeQueue().catch(reject); + }); + }; + const mermaid = { + startOnLoad: true, + mermaidAPI, + parse: parse$2, + render: render$3, + init, + run: run$3, + registerExternalDiagrams, + initialize, + parseError: void 0, + contentLoaded, + setParseErrorHandler, + detectType + }; + class SourceLocation { + // The + prefix indicates that these fields aren't writeable + // Lexer holding the input string. + // Start offset, zero-based inclusive. + // End offset, zero-based exclusive. + constructor(lexer, start2, end2) { + this.lexer = void 0; + this.start = void 0; + this.end = void 0; + this.lexer = lexer; + this.start = start2; + this.end = end2; + } + /** + * Merges two `SourceLocation`s from location providers, given they are + * provided in order of appearance. + * - Returns the first one's location if only the first is provided. + * - Returns a merged range of the first and the last if both are provided + * and their lexers match. + * - Otherwise, returns null. + */ + static range(first, second2) { + if (!second2) { + return first && first.loc; + } else if (!first || !first.loc || !second2.loc || first.loc.lexer !== second2.loc.lexer) { + return null; + } else { + return new SourceLocation(first.loc.lexer, first.loc.start, second2.loc.end); + } + } + } + class Token { + // don't expand the token + // used in \noexpand + constructor(text2, loc) { + this.text = void 0; + this.loc = void 0; + this.noexpand = void 0; + this.treatAsRelax = void 0; + this.text = text2; + this.loc = loc; + } + /** + * Given a pair of tokens (this and endToken), compute a `Token` encompassing + * the whole input range enclosed by these two. + */ + range(endToken, text2) { + return new Token(text2, SourceLocation.range(this, endToken)); + } + } + class ParseError { + // Error start position based on passed-in Token or ParseNode. + // Length of affected text based on passed-in Token or ParseNode. + // The underlying error message without any context added. + constructor(message, token2) { + this.name = void 0; + this.position = void 0; + this.length = void 0; + this.rawMessage = void 0; + var error = "KaTeX parse error: " + message; + var start2; + var end2; + var loc = token2 && token2.loc; + if (loc && loc.start <= loc.end) { + var input = loc.lexer.input; + start2 = loc.start; + end2 = loc.end; + if (start2 === input.length) { + error += " at end of input: "; + } else { + error += " at position " + (start2 + 1) + ": "; + } + var underlined = input.slice(start2, end2).replace(/[^]/g, "$&̲"); + var left2; + if (start2 > 15) { + left2 = "…" + input.slice(start2 - 15, start2); + } else { + left2 = input.slice(0, start2); + } + var right2; + if (end2 + 15 < input.length) { + right2 = input.slice(end2, end2 + 15) + "…"; + } else { + right2 = input.slice(end2); + } + error += left2 + underlined + right2; + } + var self2 = new Error(error); + self2.name = "ParseError"; + self2.__proto__ = ParseError.prototype; + self2.position = start2; + if (start2 != null && end2 != null) { + self2.length = end2 - start2; + } + self2.rawMessage = message; + return self2; + } + } + ParseError.prototype.__proto__ = Error.prototype; + var contains = function contains2(list2, elem) { + return list2.indexOf(elem) !== -1; + }; + var deflt = function deflt2(setting, defaultIfUndefined) { + return setting === void 0 ? defaultIfUndefined : setting; + }; + var uppercase = /([A-Z])/g; + var hyphenate = function hyphenate2(str2) { + return str2.replace(uppercase, "-$1").toLowerCase(); + }; + var ESCAPE_LOOKUP = { + "&": "&", + ">": ">", + "<": "<", + '"': """, + "'": "'" + }; + var ESCAPE_REGEX = /[&><"']/g; + function escape$1(text2) { + return String(text2).replace(ESCAPE_REGEX, (match) => ESCAPE_LOOKUP[match]); + } + var getBaseElem = function getBaseElem2(group) { + if (group.type === "ordgroup") { + if (group.body.length === 1) { + return getBaseElem2(group.body[0]); + } else { + return group; + } + } else if (group.type === "color") { + if (group.body.length === 1) { + return getBaseElem2(group.body[0]); + } else { + return group; + } + } else if (group.type === "font") { + return getBaseElem2(group.body); + } else { + return group; + } + }; + var isCharacterBox = function isCharacterBox2(group) { + var baseElem = getBaseElem(group); + return baseElem.type === "mathord" || baseElem.type === "textord" || baseElem.type === "atom"; + }; + var assert = function assert2(value2) { + if (!value2) { + throw new Error("Expected non-null, but got " + String(value2)); + } + return value2; + }; + var protocolFromUrl = function protocolFromUrl2(url) { + var protocol = /^\s*([^\\/#]*?)(?::|�*58|�*3a)/i.exec(url); + return protocol != null ? protocol[1] : "_relative"; + }; + var utils = { + contains, + deflt, + escape: escape$1, + hyphenate, + getBaseElem, + isCharacterBox, + protocolFromUrl + }; + var SETTINGS_SCHEMA = { + displayMode: { + type: "boolean", + description: "Render math in display mode, which puts the math in display style (so \\int and \\sum are large, for example), and centers the math on the page on its own line.", + cli: "-d, --display-mode" + }, + output: { + type: { + enum: ["htmlAndMathml", "html", "mathml"] + }, + description: "Determines the markup language of the output.", + cli: "-F, --format " + }, + leqno: { + type: "boolean", + description: "Render display math in leqno style (left-justified tags)." + }, + fleqn: { + type: "boolean", + description: "Render display math flush left." + }, + throwOnError: { + type: "boolean", + default: true, + cli: "-t, --no-throw-on-error", + cliDescription: "Render errors (in the color given by --error-color) instead of throwing a ParseError exception when encountering an error." + }, + errorColor: { + type: "string", + default: "#cc0000", + cli: "-c, --error-color ", + cliDescription: "A color string given in the format 'rgb' or 'rrggbb' (no #). This option determines the color of errors rendered by the -t option.", + cliProcessor: (color2) => "#" + color2 + }, + macros: { + type: "object", + cli: "-m, --macro ", + cliDescription: "Define custom macro of the form '\\foo:expansion' (use multiple -m arguments for multiple macros).", + cliDefault: [], + cliProcessor: (def, defs) => { + defs.push(def); + return defs; + } + }, + minRuleThickness: { + type: "number", + description: "Specifies a minimum thickness, in ems, for fraction lines, `\\sqrt` top lines, `{array}` vertical lines, `\\hline`, `\\hdashline`, `\\underline`, `\\overline`, and the borders of `\\fbox`, `\\boxed`, and `\\fcolorbox`.", + processor: (t) => Math.max(0, t), + cli: "--min-rule-thickness ", + cliProcessor: parseFloat + }, + colorIsTextColor: { + type: "boolean", + description: "Makes \\color behave like LaTeX's 2-argument \\textcolor, instead of LaTeX's one-argument \\color mode change.", + cli: "-b, --color-is-text-color" + }, + strict: { + type: [{ + enum: ["warn", "ignore", "error"] + }, "boolean", "function"], + description: "Turn on strict / LaTeX faithfulness mode, which throws an error if the input uses features that are not supported by LaTeX.", + cli: "-S, --strict", + cliDefault: false + }, + trust: { + type: ["boolean", "function"], + description: "Trust the input, enabling all HTML features such as \\url.", + cli: "-T, --trust" + }, + maxSize: { + type: "number", + default: Infinity, + description: "If non-zero, all user-specified sizes, e.g. in \\rule{500em}{500em}, will be capped to maxSize ems. Otherwise, elements and spaces can be arbitrarily large", + processor: (s) => Math.max(0, s), + cli: "-s, --max-size ", + cliProcessor: parseInt + }, + maxExpand: { + type: "number", + default: 1e3, + description: "Limit the number of macro expansions to the specified number, to prevent e.g. infinite macro loops. If set to Infinity, the macro expander will try to fully expand as in LaTeX.", + processor: (n) => Math.max(0, n), + cli: "-e, --max-expand ", + cliProcessor: (n) => n === "Infinity" ? Infinity : parseInt(n) + }, + globalGroup: { + type: "boolean", + cli: false + } + }; + function getDefaultValue(schema2) { + if (schema2.default) { + return schema2.default; + } + var type2 = schema2.type; + var defaultType = Array.isArray(type2) ? type2[0] : type2; + if (typeof defaultType !== "string") { + return defaultType.enum[0]; + } + switch (defaultType) { + case "boolean": + return false; + case "string": + return ""; + case "number": + return 0; + case "object": + return {}; + } + } + class Settings { + constructor(options2) { + this.displayMode = void 0; + this.output = void 0; + this.leqno = void 0; + this.fleqn = void 0; + this.throwOnError = void 0; + this.errorColor = void 0; + this.macros = void 0; + this.minRuleThickness = void 0; + this.colorIsTextColor = void 0; + this.strict = void 0; + this.trust = void 0; + this.maxSize = void 0; + this.maxExpand = void 0; + this.globalGroup = void 0; + options2 = options2 || {}; + for (var prop in SETTINGS_SCHEMA) { + if (SETTINGS_SCHEMA.hasOwnProperty(prop)) { + var schema2 = SETTINGS_SCHEMA[prop]; + this[prop] = options2[prop] !== void 0 ? schema2.processor ? schema2.processor(options2[prop]) : options2[prop] : getDefaultValue(schema2); + } + } + } + /** + * Report nonstrict (non-LaTeX-compatible) input. + * Can safely not be called if `this.strict` is false in JavaScript. + */ + reportNonstrict(errorCode, errorMsg, token2) { + var strict = this.strict; + if (typeof strict === "function") { + strict = strict(errorCode, errorMsg, token2); + } + if (!strict || strict === "ignore") { + return; + } else if (strict === true || strict === "error") { + throw new ParseError("LaTeX-incompatible input and strict mode is set to 'error': " + (errorMsg + " [" + errorCode + "]"), token2); + } else if (strict === "warn") { + typeof console !== "undefined" && console.warn("LaTeX-incompatible input and strict mode is set to 'warn': " + (errorMsg + " [" + errorCode + "]")); + } else { + typeof console !== "undefined" && console.warn("LaTeX-incompatible input and strict mode is set to " + ("unrecognized '" + strict + "': " + errorMsg + " [" + errorCode + "]")); + } + } + /** + * Check whether to apply strict (LaTeX-adhering) behavior for unusual + * input (like `\\`). Unlike `nonstrict`, will not throw an error; + * instead, "error" translates to a return value of `true`, while "ignore" + * translates to a return value of `false`. May still print a warning: + * "warn" prints a warning and returns `false`. + * This is for the second category of `errorCode`s listed in the README. + */ + useStrictBehavior(errorCode, errorMsg, token2) { + var strict = this.strict; + if (typeof strict === "function") { + try { + strict = strict(errorCode, errorMsg, token2); + } catch (error) { + strict = "error"; + } + } + if (!strict || strict === "ignore") { + return false; + } else if (strict === true || strict === "error") { + return true; + } else if (strict === "warn") { + typeof console !== "undefined" && console.warn("LaTeX-incompatible input and strict mode is set to 'warn': " + (errorMsg + " [" + errorCode + "]")); + return false; + } else { + typeof console !== "undefined" && console.warn("LaTeX-incompatible input and strict mode is set to " + ("unrecognized '" + strict + "': " + errorMsg + " [" + errorCode + "]")); + return false; + } + } + /** + * Check whether to test potentially dangerous input, and return + * `true` (trusted) or `false` (untrusted). The sole argument `context` + * should be an object with `command` field specifying the relevant LaTeX + * command (as a string starting with `\`), and any other arguments, etc. + * If `context` has a `url` field, a `protocol` field will automatically + * get added by this function (changing the specified object). + */ + isTrusted(context) { + if (context.url && !context.protocol) { + context.protocol = utils.protocolFromUrl(context.url); + } + var trust = typeof this.trust === "function" ? this.trust(context) : this.trust; + return Boolean(trust); + } + } + class Style { + constructor(id2, size2, cramped) { + this.id = void 0; + this.size = void 0; + this.cramped = void 0; + this.id = id2; + this.size = size2; + this.cramped = cramped; + } + /** + * Get the style of a superscript given a base in the current style. + */ + sup() { + return styles$a[sup[this.id]]; + } + /** + * Get the style of a subscript given a base in the current style. + */ + sub() { + return styles$a[sub[this.id]]; + } + /** + * Get the style of a fraction numerator given the fraction in the current + * style. + */ + fracNum() { + return styles$a[fracNum[this.id]]; + } + /** + * Get the style of a fraction denominator given the fraction in the current + * style. + */ + fracDen() { + return styles$a[fracDen[this.id]]; + } + /** + * Get the cramped version of a style (in particular, cramping a cramped style + * doesn't change the style). + */ + cramp() { + return styles$a[cramp[this.id]]; + } + /** + * Get a text or display version of this style. + */ + text() { + return styles$a[text$1$1[this.id]]; + } + /** + * Return true if this style is tightly spaced (scriptstyle/scriptscriptstyle) + */ + isTight() { + return this.size >= 2; + } + } + var D = 0; + var Dc = 1; + var T = 2; + var Tc = 3; + var S = 4; + var Sc = 5; + var SS = 6; + var SSc = 7; + var styles$a = [new Style(D, 0, false), new Style(Dc, 0, true), new Style(T, 1, false), new Style(Tc, 1, true), new Style(S, 2, false), new Style(Sc, 2, true), new Style(SS, 3, false), new Style(SSc, 3, true)]; + var sup = [S, Sc, S, Sc, SS, SSc, SS, SSc]; + var sub = [Sc, Sc, Sc, Sc, SSc, SSc, SSc, SSc]; + var fracNum = [T, Tc, S, Sc, SS, SSc, SS, SSc]; + var fracDen = [Tc, Tc, Sc, Sc, SSc, SSc, SSc, SSc]; + var cramp = [Dc, Dc, Tc, Tc, Sc, Sc, SSc, SSc]; + var text$1$1 = [D, Dc, T, Tc, T, Tc, T, Tc]; + var Style$1 = { + DISPLAY: styles$a[D], + TEXT: styles$a[T], + SCRIPT: styles$a[S], + SCRIPTSCRIPT: styles$a[SS] + }; + var scriptData = [{ + // Latin characters beyond the Latin-1 characters we have metrics for. + // Needed for Czech, Hungarian and Turkish text, for example. + name: "latin", + blocks: [ + [256, 591], + // Latin Extended-A and Latin Extended-B + [768, 879] + // Combining Diacritical marks + ] + }, { + // The Cyrillic script used by Russian and related languages. + // A Cyrillic subset used to be supported as explicitly defined + // symbols in symbols.js + name: "cyrillic", + blocks: [[1024, 1279]] + }, { + // Armenian + name: "armenian", + blocks: [[1328, 1423]] + }, { + // The Brahmic scripts of South and Southeast Asia + // Devanagari (0900–097F) + // Bengali (0980–09FF) + // Gurmukhi (0A00–0A7F) + // Gujarati (0A80–0AFF) + // Oriya (0B00–0B7F) + // Tamil (0B80–0BFF) + // Telugu (0C00–0C7F) + // Kannada (0C80–0CFF) + // Malayalam (0D00–0D7F) + // Sinhala (0D80–0DFF) + // Thai (0E00–0E7F) + // Lao (0E80–0EFF) + // Tibetan (0F00–0FFF) + // Myanmar (1000–109F) + name: "brahmic", + blocks: [[2304, 4255]] + }, { + name: "georgian", + blocks: [[4256, 4351]] + }, { + // Chinese and Japanese. + // The "k" in cjk is for Korean, but we've separated Korean out + name: "cjk", + blocks: [ + [12288, 12543], + // CJK symbols and punctuation, Hiragana, Katakana + [19968, 40879], + // CJK ideograms + [65280, 65376] + // Fullwidth punctuation + // TODO: add halfwidth Katakana and Romanji glyphs + ] + }, { + // Korean + name: "hangul", + blocks: [[44032, 55215]] + }]; + function scriptFromCodepoint(codepoint) { + for (var i2 = 0; i2 < scriptData.length; i2++) { + var script = scriptData[i2]; + for (var _i6 = 0; _i6 < script.blocks.length; _i6++) { + var block2 = script.blocks[_i6]; + if (codepoint >= block2[0] && codepoint <= block2[1]) { + return script.name; + } + } + } + return null; + } + var allBlocks = []; + scriptData.forEach((s) => s.blocks.forEach((b) => allBlocks.push(...b))); + function supportedCodepoint(codepoint) { + for (var i2 = 0; i2 < allBlocks.length; i2 += 2) { + if (codepoint >= allBlocks[i2] && codepoint <= allBlocks[i2 + 1]) { + return true; + } + } + return false; + } + var hLinePad = 80; + var sqrtMain = function sqrtMain2(extraVinculum, hLinePad2) { + return "M95," + (622 + extraVinculum + hLinePad2) + "\nc-2.7,0,-7.17,-2.7,-13.5,-8c-5.8,-5.3,-9.5,-10,-9.5,-14\nc0,-2,0.3,-3.3,1,-4c1.3,-2.7,23.83,-20.7,67.5,-54\nc44.2,-33.3,65.8,-50.3,66.5,-51c1.3,-1.3,3,-2,5,-2c4.7,0,8.7,3.3,12,10\ns173,378,173,378c0.7,0,35.3,-71,104,-213c68.7,-142,137.5,-285,206.5,-429\nc69,-144,104.5,-217.7,106.5,-221\nl" + extraVinculum / 2.075 + " -" + extraVinculum + "\nc5.3,-9.3,12,-14,20,-14\nH400000v" + (40 + extraVinculum) + "H845.2724\ns-225.272,467,-225.272,467s-235,486,-235,486c-2.7,4.7,-9,7,-19,7\nc-6,0,-10,-1,-12,-3s-194,-422,-194,-422s-65,47,-65,47z\nM" + (834 + extraVinculum) + " " + hLinePad2 + "h400000v" + (40 + extraVinculum) + "h-400000z"; + }; + var sqrtSize1 = function sqrtSize12(extraVinculum, hLinePad2) { + return "M263," + (601 + extraVinculum + hLinePad2) + "c0.7,0,18,39.7,52,119\nc34,79.3,68.167,158.7,102.5,238c34.3,79.3,51.8,119.3,52.5,120\nc340,-704.7,510.7,-1060.3,512,-1067\nl" + extraVinculum / 2.084 + " -" + extraVinculum + "\nc4.7,-7.3,11,-11,19,-11\nH40000v" + (40 + extraVinculum) + "H1012.3\ns-271.3,567,-271.3,567c-38.7,80.7,-84,175,-136,283c-52,108,-89.167,185.3,-111.5,232\nc-22.3,46.7,-33.8,70.3,-34.5,71c-4.7,4.7,-12.3,7,-23,7s-12,-1,-12,-1\ns-109,-253,-109,-253c-72.7,-168,-109.3,-252,-110,-252c-10.7,8,-22,16.7,-34,26\nc-22,17.3,-33.3,26,-34,26s-26,-26,-26,-26s76,-59,76,-59s76,-60,76,-60z\nM" + (1001 + extraVinculum) + " " + hLinePad2 + "h400000v" + (40 + extraVinculum) + "h-400000z"; + }; + var sqrtSize2 = function sqrtSize22(extraVinculum, hLinePad2) { + return "M983 " + (10 + extraVinculum + hLinePad2) + "\nl" + extraVinculum / 3.13 + " -" + extraVinculum + "\nc4,-6.7,10,-10,18,-10 H400000v" + (40 + extraVinculum) + "\nH1013.1s-83.4,268,-264.1,840c-180.7,572,-277,876.3,-289,913c-4.7,4.7,-12.7,7,-24,7\ns-12,0,-12,0c-1.3,-3.3,-3.7,-11.7,-7,-25c-35.3,-125.3,-106.7,-373.3,-214,-744\nc-10,12,-21,25,-33,39s-32,39,-32,39c-6,-5.3,-15,-14,-27,-26s25,-30,25,-30\nc26.7,-32.7,52,-63,76,-91s52,-60,52,-60s208,722,208,722\nc56,-175.3,126.3,-397.3,211,-666c84.7,-268.7,153.8,-488.2,207.5,-658.5\nc53.7,-170.3,84.5,-266.8,92.5,-289.5z\nM" + (1001 + extraVinculum) + " " + hLinePad2 + "h400000v" + (40 + extraVinculum) + "h-400000z"; + }; + var sqrtSize3 = function sqrtSize32(extraVinculum, hLinePad2) { + return "M424," + (2398 + extraVinculum + hLinePad2) + "\nc-1.3,-0.7,-38.5,-172,-111.5,-514c-73,-342,-109.8,-513.3,-110.5,-514\nc0,-2,-10.7,14.3,-32,49c-4.7,7.3,-9.8,15.7,-15.5,25c-5.7,9.3,-9.8,16,-12.5,20\ns-5,7,-5,7c-4,-3.3,-8.3,-7.7,-13,-13s-13,-13,-13,-13s76,-122,76,-122s77,-121,77,-121\ns209,968,209,968c0,-2,84.7,-361.7,254,-1079c169.3,-717.3,254.7,-1077.7,256,-1081\nl" + extraVinculum / 4.223 + " -" + extraVinculum + "c4,-6.7,10,-10,18,-10 H400000\nv" + (40 + extraVinculum) + "H1014.6\ns-87.3,378.7,-272.6,1166c-185.3,787.3,-279.3,1182.3,-282,1185\nc-2,6,-10,9,-24,9\nc-8,0,-12,-0.7,-12,-2z M" + (1001 + extraVinculum) + " " + hLinePad2 + "\nh400000v" + (40 + extraVinculum) + "h-400000z"; + }; + var sqrtSize4 = function sqrtSize42(extraVinculum, hLinePad2) { + return "M473," + (2713 + extraVinculum + hLinePad2) + "\nc339.3,-1799.3,509.3,-2700,510,-2702 l" + extraVinculum / 5.298 + " -" + extraVinculum + "\nc3.3,-7.3,9.3,-11,18,-11 H400000v" + (40 + extraVinculum) + "H1017.7\ns-90.5,478,-276.2,1466c-185.7,988,-279.5,1483,-281.5,1485c-2,6,-10,9,-24,9\nc-8,0,-12,-0.7,-12,-2c0,-1.3,-5.3,-32,-16,-92c-50.7,-293.3,-119.7,-693.3,-207,-1200\nc0,-1.3,-5.3,8.7,-16,30c-10.7,21.3,-21.3,42.7,-32,64s-16,33,-16,33s-26,-26,-26,-26\ns76,-153,76,-153s77,-151,77,-151c0.7,0.7,35.7,202,105,604c67.3,400.7,102,602.7,104,\n606zM" + (1001 + extraVinculum) + " " + hLinePad2 + "h400000v" + (40 + extraVinculum) + "H1017.7z"; + }; + var phasePath = function phasePath2(y2) { + var x2 = y2 / 2; + return "M400000 " + y2 + " H0 L" + x2 + " 0 l65 45 L145 " + (y2 - 80) + " H400000z"; + }; + var sqrtTall = function sqrtTall2(extraVinculum, hLinePad2, viewBoxHeight) { + var vertSegment = viewBoxHeight - 54 - hLinePad2 - extraVinculum; + return "M702 " + (extraVinculum + hLinePad2) + "H400000" + (40 + extraVinculum) + "\nH742v" + vertSegment + "l-4 4-4 4c-.667.7 -2 1.5-4 2.5s-4.167 1.833-6.5 2.5-5.5 1-9.5 1\nh-12l-28-84c-16.667-52-96.667 -294.333-240-727l-212 -643 -85 170\nc-4-3.333-8.333-7.667-13 -13l-13-13l77-155 77-156c66 199.333 139 419.667\n219 661 l218 661zM702 " + hLinePad2 + "H400000v" + (40 + extraVinculum) + "H742z"; + }; + var sqrtPath = function sqrtPath2(size2, extraVinculum, viewBoxHeight) { + extraVinculum = 1e3 * extraVinculum; + var path2 = ""; + switch (size2) { + case "sqrtMain": + path2 = sqrtMain(extraVinculum, hLinePad); + break; + case "sqrtSize1": + path2 = sqrtSize1(extraVinculum, hLinePad); + break; + case "sqrtSize2": + path2 = sqrtSize2(extraVinculum, hLinePad); + break; + case "sqrtSize3": + path2 = sqrtSize3(extraVinculum, hLinePad); + break; + case "sqrtSize4": + path2 = sqrtSize4(extraVinculum, hLinePad); + break; + case "sqrtTall": + path2 = sqrtTall(extraVinculum, hLinePad, viewBoxHeight); + } + return path2; + }; + var innerPath = function innerPath2(name, height) { + switch (name) { + case "⎜": + return "M291 0 H417 V" + height + " H291z M291 0 H417 V" + height + " H291z"; + case "∣": + return "M145 0 H188 V" + height + " H145z M145 0 H188 V" + height + " H145z"; + case "∥": + return "M145 0 H188 V" + height + " H145z M145 0 H188 V" + height + " H145z" + ("M367 0 H410 V" + height + " H367z M367 0 H410 V" + height + " H367z"); + case "⎟": + return "M457 0 H583 V" + height + " H457z M457 0 H583 V" + height + " H457z"; + case "⎢": + return "M319 0 H403 V" + height + " H319z M319 0 H403 V" + height + " H319z"; + case "⎥": + return "M263 0 H347 V" + height + " H263z M263 0 H347 V" + height + " H263z"; + case "⎪": + return "M384 0 H504 V" + height + " H384z M384 0 H504 V" + height + " H384z"; + case "⏐": + return "M312 0 H355 V" + height + " H312z M312 0 H355 V" + height + " H312z"; + case "‖": + return "M257 0 H300 V" + height + " H257z M257 0 H300 V" + height + " H257z" + ("M478 0 H521 V" + height + " H478z M478 0 H521 V" + height + " H478z"); + default: + return ""; + } + }; + var path$1 = { + // The doubleleftarrow geometry is from glyph U+21D0 in the font KaTeX Main + doubleleftarrow: "M262 157\nl10-10c34-36 62.7-77 86-123 3.3-8 5-13.3 5-16 0-5.3-6.7-8-20-8-7.3\n 0-12.2.5-14.5 1.5-2.3 1-4.8 4.5-7.5 10.5-49.3 97.3-121.7 169.3-217 216-28\n 14-57.3 25-88 33-6.7 2-11 3.8-13 5.5-2 1.7-3 4.2-3 7.5s1 5.8 3 7.5\nc2 1.7 6.3 3.5 13 5.5 68 17.3 128.2 47.8 180.5 91.5 52.3 43.7 93.8 96.2 124.5\n 157.5 9.3 8 15.3 12.3 18 13h6c12-.7 18-4 18-10 0-2-1.7-7-5-15-23.3-46-52-87\n-86-123l-10-10h399738v-40H218c328 0 0 0 0 0l-10-8c-26.7-20-65.7-43-117-69 2.7\n-2 6-3.7 10-5 36.7-16 72.3-37.3 107-64l10-8h399782v-40z\nm8 0v40h399730v-40zm0 194v40h399730v-40z", + // doublerightarrow is from glyph U+21D2 in font KaTeX Main + doublerightarrow: "M399738 392l\n-10 10c-34 36-62.7 77-86 123-3.3 8-5 13.3-5 16 0 5.3 6.7 8 20 8 7.3 0 12.2-.5\n 14.5-1.5 2.3-1 4.8-4.5 7.5-10.5 49.3-97.3 121.7-169.3 217-216 28-14 57.3-25 88\n-33 6.7-2 11-3.8 13-5.5 2-1.7 3-4.2 3-7.5s-1-5.8-3-7.5c-2-1.7-6.3-3.5-13-5.5-68\n-17.3-128.2-47.8-180.5-91.5-52.3-43.7-93.8-96.2-124.5-157.5-9.3-8-15.3-12.3-18\n-13h-6c-12 .7-18 4-18 10 0 2 1.7 7 5 15 23.3 46 52 87 86 123l10 10H0v40h399782\nc-328 0 0 0 0 0l10 8c26.7 20 65.7 43 117 69-2.7 2-6 3.7-10 5-36.7 16-72.3 37.3\n-107 64l-10 8H0v40zM0 157v40h399730v-40zm0 194v40h399730v-40z", + // leftarrow is from glyph U+2190 in font KaTeX Main + leftarrow: "M400000 241H110l3-3c68.7-52.7 113.7-120\n 135-202 4-14.7 6-23 6-25 0-7.3-7-11-21-11-8 0-13.2.8-15.5 2.5-2.3 1.7-4.2 5.8\n-5.5 12.5-1.3 4.7-2.7 10.3-4 17-12 48.7-34.8 92-68.5 130S65.3 228.3 18 247\nc-10 4-16 7.7-18 11 0 8.7 6 14.3 18 17 47.3 18.7 87.8 47 121.5 85S196 441.3 208\n 490c.7 2 1.3 5 2 9s1.2 6.7 1.5 8c.3 1.3 1 3.3 2 6s2.2 4.5 3.5 5.5c1.3 1 3.3\n 1.8 6 2.5s6 1 10 1c14 0 21-3.7 21-11 0-2-2-10.3-6-25-20-79.3-65-146.7-135-202\n l-3-3h399890zM100 241v40h399900v-40z", + // overbrace is from glyphs U+23A9/23A8/23A7 in font KaTeX_Size4-Regular + leftbrace: "M6 548l-6-6v-35l6-11c56-104 135.3-181.3 238-232 57.3-28.7 117\n-45 179-50h399577v120H403c-43.3 7-81 15-113 26-100.7 33-179.7 91-237 174-2.7\n 5-6 9-10 13-.7 1-7.3 1-20 1H6z", + leftbraceunder: "M0 6l6-6h17c12.688 0 19.313.3 20 1 4 4 7.313 8.3 10 13\n 35.313 51.3 80.813 93.8 136.5 127.5 55.688 33.7 117.188 55.8 184.5 66.5.688\n 0 2 .3 4 1 18.688 2.7 76 4.3 172 5h399450v120H429l-6-1c-124.688-8-235-61.7\n-331-161C60.687 138.7 32.312 99.3 7 54L0 41V6z", + // overgroup is from the MnSymbol package (public domain) + leftgroup: "M400000 80\nH435C64 80 168.3 229.4 21 260c-5.9 1.2-18 0-18 0-2 0-3-1-3-3v-38C76 61 257 0\n 435 0h399565z", + leftgroupunder: "M400000 262\nH435C64 262 168.3 112.6 21 82c-5.9-1.2-18 0-18 0-2 0-3 1-3 3v38c76 158 257 219\n 435 219h399565z", + // Harpoons are from glyph U+21BD in font KaTeX Main + leftharpoon: "M0 267c.7 5.3 3 10 7 14h399993v-40H93c3.3\n-3.3 10.2-9.5 20.5-18.5s17.8-15.8 22.5-20.5c50.7-52 88-110.3 112-175 4-11.3 5\n-18.3 3-21-1.3-4-7.3-6-18-6-8 0-13 .7-15 2s-4.7 6.7-8 16c-42 98.7-107.3 174.7\n-196 228-6.7 4.7-10.7 8-12 10-1.3 2-2 5.7-2 11zm100-26v40h399900v-40z", + leftharpoonplus: "M0 267c.7 5.3 3 10 7 14h399993v-40H93c3.3-3.3 10.2-9.5\n 20.5-18.5s17.8-15.8 22.5-20.5c50.7-52 88-110.3 112-175 4-11.3 5-18.3 3-21-1.3\n-4-7.3-6-18-6-8 0-13 .7-15 2s-4.7 6.7-8 16c-42 98.7-107.3 174.7-196 228-6.7 4.7\n-10.7 8-12 10-1.3 2-2 5.7-2 11zm100-26v40h399900v-40zM0 435v40h400000v-40z\nm0 0v40h400000v-40z", + leftharpoondown: "M7 241c-4 4-6.333 8.667-7 14 0 5.333.667 9 2 11s5.333\n 5.333 12 10c90.667 54 156 130 196 228 3.333 10.667 6.333 16.333 9 17 2 .667 5\n 1 9 1h5c10.667 0 16.667-2 18-6 2-2.667 1-9.667-3-21-32-87.333-82.667-157.667\n-152-211l-3-3h399907v-40zM93 281 H400000 v-40L7 241z", + leftharpoondownplus: "M7 435c-4 4-6.3 8.7-7 14 0 5.3.7 9 2 11s5.3 5.3 12\n 10c90.7 54 156 130 196 228 3.3 10.7 6.3 16.3 9 17 2 .7 5 1 9 1h5c10.7 0 16.7\n-2 18-6 2-2.7 1-9.7-3-21-32-87.3-82.7-157.7-152-211l-3-3h399907v-40H7zm93 0\nv40h399900v-40zM0 241v40h399900v-40zm0 0v40h399900v-40z", + // hook is from glyph U+21A9 in font KaTeX Main + lefthook: "M400000 281 H103s-33-11.2-61-33.5S0 197.3 0 164s14.2-61.2 42.5\n-83.5C70.8 58.2 104 47 142 47 c16.7 0 25 6.7 25 20 0 12-8.7 18.7-26 20-40 3.3\n-68.7 15.7-86 37-10 12-15 25.3-15 40 0 22.7 9.8 40.7 29.5 54 19.7 13.3 43.5 21\n 71.5 23h399859zM103 281v-40h399897v40z", + leftlinesegment: "M40 281 V428 H0 V94 H40 V241 H400000 v40z\nM40 281 V428 H0 V94 H40 V241 H400000 v40z", + leftmapsto: "M40 281 V448H0V74H40V241H400000v40z\nM40 281 V448H0V74H40V241H400000v40z", + // tofrom is from glyph U+21C4 in font KaTeX AMS Regular + leftToFrom: "M0 147h400000v40H0zm0 214c68 40 115.7 95.7 143 167h22c15.3 0 23\n-.3 23-1 0-1.3-5.3-13.7-16-37-18-35.3-41.3-69-70-101l-7-8h399905v-40H95l7-8\nc28.7-32 52-65.7 70-101 10.7-23.3 16-35.7 16-37 0-.7-7.7-1-23-1h-22C115.7 265.3\n 68 321 0 361zm0-174v-40h399900v40zm100 154v40h399900v-40z", + longequal: "M0 50 h400000 v40H0z m0 194h40000v40H0z\nM0 50 h400000 v40H0z m0 194h40000v40H0z", + midbrace: "M200428 334\nc-100.7-8.3-195.3-44-280-108-55.3-42-101.7-93-139-153l-9-14c-2.7 4-5.7 8.7-9 14\n-53.3 86.7-123.7 153-211 199-66.7 36-137.3 56.3-212 62H0V214h199568c178.3-11.7\n 311.7-78.3 403-201 6-8 9.7-12 11-12 .7-.7 6.7-1 18-1s17.3.3 18 1c1.3 0 5 4 11\n 12 44.7 59.3 101.3 106.3 170 141s145.3 54.3 229 60h199572v120z", + midbraceunder: "M199572 214\nc100.7 8.3 195.3 44 280 108 55.3 42 101.7 93 139 153l9 14c2.7-4 5.7-8.7 9-14\n 53.3-86.7 123.7-153 211-199 66.7-36 137.3-56.3 212-62h199568v120H200432c-178.3\n 11.7-311.7 78.3-403 201-6 8-9.7 12-11 12-.7.7-6.7 1-18 1s-17.3-.3-18-1c-1.3 0\n-5-4-11-12-44.7-59.3-101.3-106.3-170-141s-145.3-54.3-229-60H0V214z", + oiintSize1: "M512.6 71.6c272.6 0 320.3 106.8 320.3 178.2 0 70.8-47.7 177.6\n-320.3 177.6S193.1 320.6 193.1 249.8c0-71.4 46.9-178.2 319.5-178.2z\nm368.1 178.2c0-86.4-60.9-215.4-368.1-215.4-306.4 0-367.3 129-367.3 215.4 0 85.8\n60.9 214.8 367.3 214.8 307.2 0 368.1-129 368.1-214.8z", + oiintSize2: "M757.8 100.1c384.7 0 451.1 137.6 451.1 230 0 91.3-66.4 228.8\n-451.1 228.8-386.3 0-452.7-137.5-452.7-228.8 0-92.4 66.4-230 452.7-230z\nm502.4 230c0-111.2-82.4-277.2-502.4-277.2s-504 166-504 277.2\nc0 110 84 276 504 276s502.4-166 502.4-276z", + oiiintSize1: "M681.4 71.6c408.9 0 480.5 106.8 480.5 178.2 0 70.8-71.6 177.6\n-480.5 177.6S202.1 320.6 202.1 249.8c0-71.4 70.5-178.2 479.3-178.2z\nm525.8 178.2c0-86.4-86.8-215.4-525.7-215.4-437.9 0-524.7 129-524.7 215.4 0\n85.8 86.8 214.8 524.7 214.8 438.9 0 525.7-129 525.7-214.8z", + oiiintSize2: "M1021.2 53c603.6 0 707.8 165.8 707.8 277.2 0 110-104.2 275.8\n-707.8 275.8-606 0-710.2-165.8-710.2-275.8C311 218.8 415.2 53 1021.2 53z\nm770.4 277.1c0-131.2-126.4-327.6-770.5-327.6S248.4 198.9 248.4 330.1\nc0 130 128.8 326.4 772.7 326.4s770.5-196.4 770.5-326.4z", + rightarrow: "M0 241v40h399891c-47.3 35.3-84 78-110 128\n-16.7 32-27.7 63.7-33 95 0 1.3-.2 2.7-.5 4-.3 1.3-.5 2.3-.5 3 0 7.3 6.7 11 20\n 11 8 0 13.2-.8 15.5-2.5 2.3-1.7 4.2-5.5 5.5-11.5 2-13.3 5.7-27 11-41 14.7-44.7\n 39-84.5 73-119.5s73.7-60.2 119-75.5c6-2 9-5.7 9-11s-3-9-9-11c-45.3-15.3-85\n-40.5-119-75.5s-58.3-74.8-73-119.5c-4.7-14-8.3-27.3-11-40-1.3-6.7-3.2-10.8-5.5\n-12.5-2.3-1.7-7.5-2.5-15.5-2.5-14 0-21 3.7-21 11 0 2 2 10.3 6 25 20.7 83.3 67\n 151.7 139 205zm0 0v40h399900v-40z", + rightbrace: "M400000 542l\n-6 6h-17c-12.7 0-19.3-.3-20-1-4-4-7.3-8.3-10-13-35.3-51.3-80.8-93.8-136.5-127.5\ns-117.2-55.8-184.5-66.5c-.7 0-2-.3-4-1-18.7-2.7-76-4.3-172-5H0V214h399571l6 1\nc124.7 8 235 61.7 331 161 31.3 33.3 59.7 72.7 85 118l7 13v35z", + rightbraceunder: "M399994 0l6 6v35l-6 11c-56 104-135.3 181.3-238 232-57.3\n 28.7-117 45-179 50H-300V214h399897c43.3-7 81-15 113-26 100.7-33 179.7-91 237\n-174 2.7-5 6-9 10-13 .7-1 7.3-1 20-1h17z", + rightgroup: "M0 80h399565c371 0 266.7 149.4 414 180 5.9 1.2 18 0 18 0 2 0\n 3-1 3-3v-38c-76-158-257-219-435-219H0z", + rightgroupunder: "M0 262h399565c371 0 266.7-149.4 414-180 5.9-1.2 18 0 18\n 0 2 0 3 1 3 3v38c-76 158-257 219-435 219H0z", + rightharpoon: "M0 241v40h399993c4.7-4.7 7-9.3 7-14 0-9.3\n-3.7-15.3-11-18-92.7-56.7-159-133.7-199-231-3.3-9.3-6-14.7-8-16-2-1.3-7-2-15-2\n-10.7 0-16.7 2-18 6-2 2.7-1 9.7 3 21 15.3 42 36.7 81.8 64 119.5 27.3 37.7 58\n 69.2 92 94.5zm0 0v40h399900v-40z", + rightharpoonplus: "M0 241v40h399993c4.7-4.7 7-9.3 7-14 0-9.3-3.7-15.3-11\n-18-92.7-56.7-159-133.7-199-231-3.3-9.3-6-14.7-8-16-2-1.3-7-2-15-2-10.7 0-16.7\n 2-18 6-2 2.7-1 9.7 3 21 15.3 42 36.7 81.8 64 119.5 27.3 37.7 58 69.2 92 94.5z\nm0 0v40h399900v-40z m100 194v40h399900v-40zm0 0v40h399900v-40z", + rightharpoondown: "M399747 511c0 7.3 6.7 11 20 11 8 0 13-.8 15-2.5s4.7-6.8\n 8-15.5c40-94 99.3-166.3 178-217 13.3-8 20.3-12.3 21-13 5.3-3.3 8.5-5.8 9.5\n-7.5 1-1.7 1.5-5.2 1.5-10.5s-2.3-10.3-7-15H0v40h399908c-34 25.3-64.7 57-92 95\n-27.3 38-48.7 77.7-64 119-3.3 8.7-5 14-5 16zM0 241v40h399900v-40z", + rightharpoondownplus: "M399747 705c0 7.3 6.7 11 20 11 8 0 13-.8\n 15-2.5s4.7-6.8 8-15.5c40-94 99.3-166.3 178-217 13.3-8 20.3-12.3 21-13 5.3-3.3\n 8.5-5.8 9.5-7.5 1-1.7 1.5-5.2 1.5-10.5s-2.3-10.3-7-15H0v40h399908c-34 25.3\n-64.7 57-92 95-27.3 38-48.7 77.7-64 119-3.3 8.7-5 14-5 16zM0 435v40h399900v-40z\nm0-194v40h400000v-40zm0 0v40h400000v-40z", + righthook: "M399859 241c-764 0 0 0 0 0 40-3.3 68.7-15.7 86-37 10-12 15-25.3\n 15-40 0-22.7-9.8-40.7-29.5-54-19.7-13.3-43.5-21-71.5-23-17.3-1.3-26-8-26-20 0\n-13.3 8.7-20 26-20 38 0 71 11.2 99 33.5 0 0 7 5.6 21 16.7 14 11.2 21 33.5 21\n 66.8s-14 61.2-42 83.5c-28 22.3-61 33.5-99 33.5L0 241z M0 281v-40h399859v40z", + rightlinesegment: "M399960 241 V94 h40 V428 h-40 V281 H0 v-40z\nM399960 241 V94 h40 V428 h-40 V281 H0 v-40z", + rightToFrom: "M400000 167c-70.7-42-118-97.7-142-167h-23c-15.3 0-23 .3-23\n 1 0 1.3 5.3 13.7 16 37 18 35.3 41.3 69 70 101l7 8H0v40h399905l-7 8c-28.7 32\n-52 65.7-70 101-10.7 23.3-16 35.7-16 37 0 .7 7.7 1 23 1h23c24-69.3 71.3-125 142\n-167z M100 147v40h399900v-40zM0 341v40h399900v-40z", + // twoheadleftarrow is from glyph U+219E in font KaTeX AMS Regular + twoheadleftarrow: "M0 167c68 40\n 115.7 95.7 143 167h22c15.3 0 23-.3 23-1 0-1.3-5.3-13.7-16-37-18-35.3-41.3-69\n-70-101l-7-8h125l9 7c50.7 39.3 85 86 103 140h46c0-4.7-6.3-18.7-19-42-18-35.3\n-40-67.3-66-96l-9-9h399716v-40H284l9-9c26-28.7 48-60.7 66-96 12.7-23.333 19\n-37.333 19-42h-46c-18 54-52.3 100.7-103 140l-9 7H95l7-8c28.7-32 52-65.7 70-101\n 10.7-23.333 16-35.7 16-37 0-.7-7.7-1-23-1h-22C115.7 71.3 68 127 0 167z", + twoheadrightarrow: "M400000 167\nc-68-40-115.7-95.7-143-167h-22c-15.3 0-23 .3-23 1 0 1.3 5.3 13.7 16 37 18 35.3\n 41.3 69 70 101l7 8h-125l-9-7c-50.7-39.3-85-86-103-140h-46c0 4.7 6.3 18.7 19 42\n 18 35.3 40 67.3 66 96l9 9H0v40h399716l-9 9c-26 28.7-48 60.7-66 96-12.7 23.333\n-19 37.333-19 42h46c18-54 52.3-100.7 103-140l9-7h125l-7 8c-28.7 32-52 65.7-70\n 101-10.7 23.333-16 35.7-16 37 0 .7 7.7 1 23 1h22c27.3-71.3 75-127 143-167z", + // tilde1 is a modified version of a glyph from the MnSymbol package + tilde1: "M200 55.538c-77 0-168 73.953-177 73.953-3 0-7\n-2.175-9-5.437L2 97c-1-2-2-4-2-6 0-4 2-7 5-9l20-12C116 12 171 0 207 0c86 0\n 114 68 191 68 78 0 168-68 177-68 4 0 7 2 9 5l12 19c1 2.175 2 4.35 2 6.525 0\n 4.35-2 7.613-5 9.788l-19 13.05c-92 63.077-116.937 75.308-183 76.128\n-68.267.847-113-73.952-191-73.952z", + // ditto tilde2, tilde3, & tilde4 + tilde2: "M344 55.266c-142 0-300.638 81.316-311.5 86.418\n-8.01 3.762-22.5 10.91-23.5 5.562L1 120c-1-2-1-3-1-4 0-5 3-9 8-10l18.4-9C160.9\n 31.9 283 0 358 0c148 0 188 122 331 122s314-97 326-97c4 0 8 2 10 7l7 21.114\nc1 2.14 1 3.21 1 4.28 0 5.347-3 9.626-7 10.696l-22.3 12.622C852.6 158.372 751\n 181.476 676 181.476c-149 0-189-126.21-332-126.21z", + tilde3: "M786 59C457 59 32 175.242 13 175.242c-6 0-10-3.457\n-11-10.37L.15 138c-1-7 3-12 10-13l19.2-6.4C378.4 40.7 634.3 0 804.3 0c337 0\n 411.8 157 746.8 157 328 0 754-112 773-112 5 0 10 3 11 9l1 14.075c1 8.066-.697\n 16.595-6.697 17.492l-21.052 7.31c-367.9 98.146-609.15 122.696-778.15 122.696\n -338 0-409-156.573-744-156.573z", + tilde4: "M786 58C457 58 32 177.487 13 177.487c-6 0-10-3.345\n-11-10.035L.15 143c-1-7 3-12 10-13l22-6.7C381.2 35 637.15 0 807.15 0c337 0 409\n 177 744 177 328 0 754-127 773-127 5 0 10 3 11 9l1 14.794c1 7.805-3 13.38-9\n 14.495l-20.7 5.574c-366.85 99.79-607.3 139.372-776.3 139.372-338 0-409\n -175.236-744-175.236z", + // vec is from glyph U+20D7 in font KaTeX Main + vec: "M377 20c0-5.333 1.833-10 5.5-14S391 0 397 0c4.667 0 8.667 1.667 12 5\n3.333 2.667 6.667 9 10 19 6.667 24.667 20.333 43.667 41 57 7.333 4.667 11\n10.667 11 18 0 6-1 10-3 12s-6.667 5-14 9c-28.667 14.667-53.667 35.667-75 63\n-1.333 1.333-3.167 3.5-5.5 6.5s-4 4.833-5 5.5c-1 .667-2.5 1.333-4.5 2s-4.333 1\n-7 1c-4.667 0-9.167-1.833-13.5-5.5S337 184 337 178c0-12.667 15.667-32.333 47-59\nH213l-171-1c-8.667-6-13-12.333-13-19 0-4.667 4.333-11.333 13-20h359\nc-16-25.333-24-45-24-59z", + // widehat1 is a modified version of a glyph from the MnSymbol package + widehat1: "M529 0h5l519 115c5 1 9 5 9 10 0 1-1 2-1 3l-4 22\nc-1 5-5 9-11 9h-2L532 67 19 159h-2c-5 0-9-4-11-9l-5-22c-1-6 2-12 8-13z", + // ditto widehat2, widehat3, & widehat4 + widehat2: "M1181 0h2l1171 176c6 0 10 5 10 11l-2 23c-1 6-5 10\n-11 10h-1L1182 67 15 220h-1c-6 0-10-4-11-10l-2-23c-1-6 4-11 10-11z", + widehat3: "M1181 0h2l1171 236c6 0 10 5 10 11l-2 23c-1 6-5 10\n-11 10h-1L1182 67 15 280h-1c-6 0-10-4-11-10l-2-23c-1-6 4-11 10-11z", + widehat4: "M1181 0h2l1171 296c6 0 10 5 10 11l-2 23c-1 6-5 10\n-11 10h-1L1182 67 15 340h-1c-6 0-10-4-11-10l-2-23c-1-6 4-11 10-11z", + // widecheck paths are all inverted versions of widehat + widecheck1: "M529,159h5l519,-115c5,-1,9,-5,9,-10c0,-1,-1,-2,-1,-3l-4,-22c-1,\n-5,-5,-9,-11,-9h-2l-512,92l-513,-92h-2c-5,0,-9,4,-11,9l-5,22c-1,6,2,12,8,13z", + widecheck2: "M1181,220h2l1171,-176c6,0,10,-5,10,-11l-2,-23c-1,-6,-5,-10,\n-11,-10h-1l-1168,153l-1167,-153h-1c-6,0,-10,4,-11,10l-2,23c-1,6,4,11,10,11z", + widecheck3: "M1181,280h2l1171,-236c6,0,10,-5,10,-11l-2,-23c-1,-6,-5,-10,\n-11,-10h-1l-1168,213l-1167,-213h-1c-6,0,-10,4,-11,10l-2,23c-1,6,4,11,10,11z", + widecheck4: "M1181,340h2l1171,-296c6,0,10,-5,10,-11l-2,-23c-1,-6,-5,-10,\n-11,-10h-1l-1168,273l-1167,-273h-1c-6,0,-10,4,-11,10l-2,23c-1,6,4,11,10,11z", + // The next ten paths support reaction arrows from the mhchem package. + // Arrows for \ce{<-->} are offset from xAxis by 0.22ex, per mhchem in LaTeX + // baraboveleftarrow is mostly from glyph U+2190 in font KaTeX Main + baraboveleftarrow: "M400000 620h-399890l3 -3c68.7 -52.7 113.7 -120 135 -202\nc4 -14.7 6 -23 6 -25c0 -7.3 -7 -11 -21 -11c-8 0 -13.2 0.8 -15.5 2.5\nc-2.3 1.7 -4.2 5.8 -5.5 12.5c-1.3 4.7 -2.7 10.3 -4 17c-12 48.7 -34.8 92 -68.5 130\ns-74.2 66.3 -121.5 85c-10 4 -16 7.7 -18 11c0 8.7 6 14.3 18 17c47.3 18.7 87.8 47\n121.5 85s56.5 81.3 68.5 130c0.7 2 1.3 5 2 9s1.2 6.7 1.5 8c0.3 1.3 1 3.3 2 6\ns2.2 4.5 3.5 5.5c1.3 1 3.3 1.8 6 2.5s6 1 10 1c14 0 21 -3.7 21 -11\nc0 -2 -2 -10.3 -6 -25c-20 -79.3 -65 -146.7 -135 -202l-3 -3h399890z\nM100 620v40h399900v-40z M0 241v40h399900v-40zM0 241v40h399900v-40z", + // rightarrowabovebar is mostly from glyph U+2192, KaTeX Main + rightarrowabovebar: "M0 241v40h399891c-47.3 35.3-84 78-110 128-16.7 32\n-27.7 63.7-33 95 0 1.3-.2 2.7-.5 4-.3 1.3-.5 2.3-.5 3 0 7.3 6.7 11 20 11 8 0\n13.2-.8 15.5-2.5 2.3-1.7 4.2-5.5 5.5-11.5 2-13.3 5.7-27 11-41 14.7-44.7 39\n-84.5 73-119.5s73.7-60.2 119-75.5c6-2 9-5.7 9-11s-3-9-9-11c-45.3-15.3-85-40.5\n-119-75.5s-58.3-74.8-73-119.5c-4.7-14-8.3-27.3-11-40-1.3-6.7-3.2-10.8-5.5\n-12.5-2.3-1.7-7.5-2.5-15.5-2.5-14 0-21 3.7-21 11 0 2 2 10.3 6 25 20.7 83.3 67\n151.7 139 205zm96 379h399894v40H0zm0 0h399904v40H0z", + // The short left harpoon has 0.5em (i.e. 500 units) kern on the left end. + // Ref from mhchem.sty: \rlap{\raisebox{-.22ex}{$\kern0.5em + baraboveshortleftharpoon: "M507,435c-4,4,-6.3,8.7,-7,14c0,5.3,0.7,9,2,11\nc1.3,2,5.3,5.3,12,10c90.7,54,156,130,196,228c3.3,10.7,6.3,16.3,9,17\nc2,0.7,5,1,9,1c0,0,5,0,5,0c10.7,0,16.7,-2,18,-6c2,-2.7,1,-9.7,-3,-21\nc-32,-87.3,-82.7,-157.7,-152,-211c0,0,-3,-3,-3,-3l399351,0l0,-40\nc-398570,0,-399437,0,-399437,0z M593 435 v40 H399500 v-40z\nM0 281 v-40 H399908 v40z M0 281 v-40 H399908 v40z", + rightharpoonaboveshortbar: "M0,241 l0,40c399126,0,399993,0,399993,0\nc4.7,-4.7,7,-9.3,7,-14c0,-9.3,-3.7,-15.3,-11,-18c-92.7,-56.7,-159,-133.7,-199,\n-231c-3.3,-9.3,-6,-14.7,-8,-16c-2,-1.3,-7,-2,-15,-2c-10.7,0,-16.7,2,-18,6\nc-2,2.7,-1,9.7,3,21c15.3,42,36.7,81.8,64,119.5c27.3,37.7,58,69.2,92,94.5z\nM0 241 v40 H399908 v-40z M0 475 v-40 H399500 v40z M0 475 v-40 H399500 v40z", + shortbaraboveleftharpoon: "M7,435c-4,4,-6.3,8.7,-7,14c0,5.3,0.7,9,2,11\nc1.3,2,5.3,5.3,12,10c90.7,54,156,130,196,228c3.3,10.7,6.3,16.3,9,17c2,0.7,5,1,9,\n1c0,0,5,0,5,0c10.7,0,16.7,-2,18,-6c2,-2.7,1,-9.7,-3,-21c-32,-87.3,-82.7,-157.7,\n-152,-211c0,0,-3,-3,-3,-3l399907,0l0,-40c-399126,0,-399993,0,-399993,0z\nM93 435 v40 H400000 v-40z M500 241 v40 H400000 v-40z M500 241 v40 H400000 v-40z", + shortrightharpoonabovebar: "M53,241l0,40c398570,0,399437,0,399437,0\nc4.7,-4.7,7,-9.3,7,-14c0,-9.3,-3.7,-15.3,-11,-18c-92.7,-56.7,-159,-133.7,-199,\n-231c-3.3,-9.3,-6,-14.7,-8,-16c-2,-1.3,-7,-2,-15,-2c-10.7,0,-16.7,2,-18,6\nc-2,2.7,-1,9.7,3,21c15.3,42,36.7,81.8,64,119.5c27.3,37.7,58,69.2,92,94.5z\nM500 241 v40 H399408 v-40z M500 435 v40 H400000 v-40z" + }; + var tallDelim = function tallDelim2(label, midHeight) { + switch (label) { + case "lbrack": + return "M403 1759 V84 H666 V0 H319 V1759 v" + midHeight + " v1759 h347 v-84\nH403z M403 1759 V0 H319 V1759 v" + midHeight + " v1759 h84z"; + case "rbrack": + return "M347 1759 V0 H0 V84 H263 V1759 v" + midHeight + " v1759 H0 v84 H347z\nM347 1759 V0 H263 V1759 v" + midHeight + " v1759 h84z"; + case "vert": + return "M145 15 v585 v" + midHeight + " v585 c2.667,10,9.667,15,21,15\nc10,0,16.667,-5,20,-15 v-585 v" + -midHeight + " v-585 c-2.667,-10,-9.667,-15,-21,-15\nc-10,0,-16.667,5,-20,15z M188 15 H145 v585 v" + midHeight + " v585 h43z"; + case "doublevert": + return "M145 15 v585 v" + midHeight + " v585 c2.667,10,9.667,15,21,15\nc10,0,16.667,-5,20,-15 v-585 v" + -midHeight + " v-585 c-2.667,-10,-9.667,-15,-21,-15\nc-10,0,-16.667,5,-20,15z M188 15 H145 v585 v" + midHeight + " v585 h43z\nM367 15 v585 v" + midHeight + " v585 c2.667,10,9.667,15,21,15\nc10,0,16.667,-5,20,-15 v-585 v" + -midHeight + " v-585 c-2.667,-10,-9.667,-15,-21,-15\nc-10,0,-16.667,5,-20,15z M410 15 H367 v585 v" + midHeight + " v585 h43z"; + case "lfloor": + return "M319 602 V0 H403 V602 v" + midHeight + " v1715 h263 v84 H319z\nMM319 602 V0 H403 V602 v" + midHeight + " v1715 H319z"; + case "rfloor": + return "M319 602 V0 H403 V602 v" + midHeight + " v1799 H0 v-84 H319z\nMM319 602 V0 H403 V602 v" + midHeight + " v1715 H319z"; + case "lceil": + return "M403 1759 V84 H666 V0 H319 V1759 v" + midHeight + " v602 h84z\nM403 1759 V0 H319 V1759 v" + midHeight + " v602 h84z"; + case "rceil": + return "M347 1759 V0 H0 V84 H263 V1759 v" + midHeight + " v602 h84z\nM347 1759 V0 h-84 V1759 v" + midHeight + " v602 h84z"; + case "lparen": + return "M863,9c0,-2,-2,-5,-6,-9c0,0,-17,0,-17,0c-12.7,0,-19.3,0.3,-20,1\nc-5.3,5.3,-10.3,11,-15,17c-242.7,294.7,-395.3,682,-458,1162c-21.3,163.3,-33.3,349,\n-36,557 l0," + (midHeight + 84) + "c0.2,6,0,26,0,60c2,159.3,10,310.7,24,454c53.3,528,210,\n949.7,470,1265c4.7,6,9.7,11.7,15,17c0.7,0.7,7,1,19,1c0,0,18,0,18,0c4,-4,6,-7,6,-9\nc0,-2.7,-3.3,-8.7,-10,-18c-135.3,-192.7,-235.5,-414.3,-300.5,-665c-65,-250.7,-102.5,\n-544.7,-112.5,-882c-2,-104,-3,-167,-3,-189\nl0,-" + (midHeight + 92) + "c0,-162.7,5.7,-314,17,-454c20.7,-272,63.7,-513,129,-723c65.3,\n-210,155.3,-396.3,270,-559c6.7,-9.3,10,-15.3,10,-18z"; + case "rparen": + return "M76,0c-16.7,0,-25,3,-25,9c0,2,2,6.3,6,13c21.3,28.7,42.3,60.3,\n63,95c96.7,156.7,172.8,332.5,228.5,527.5c55.7,195,92.8,416.5,111.5,664.5\nc11.3,139.3,17,290.7,17,454c0,28,1.7,43,3.3,45l0," + (midHeight + 9) + "\nc-3,4,-3.3,16.7,-3.3,38c0,162,-5.7,313.7,-17,455c-18.7,248,-55.8,469.3,-111.5,664\nc-55.7,194.7,-131.8,370.3,-228.5,527c-20.7,34.7,-41.7,66.3,-63,95c-2,3.3,-4,7,-6,11\nc0,7.3,5.7,11,17,11c0,0,11,0,11,0c9.3,0,14.3,-0.3,15,-1c5.3,-5.3,10.3,-11,15,-17\nc242.7,-294.7,395.3,-681.7,458,-1161c21.3,-164.7,33.3,-350.7,36,-558\nl0,-" + (midHeight + 144) + "c-2,-159.3,-10,-310.7,-24,-454c-53.3,-528,-210,-949.7,\n-470,-1265c-4.7,-6,-9.7,-11.7,-15,-17c-0.7,-0.7,-6.7,-1,-18,-1z"; + default: + throw new Error("Unknown stretchy delimiter."); + } + }; + class DocumentFragment { + // HtmlDomNode + // Never used; needed for satisfying interface. + constructor(children2) { + this.children = void 0; + this.classes = void 0; + this.height = void 0; + this.depth = void 0; + this.maxFontSize = void 0; + this.style = void 0; + this.children = children2; + this.classes = []; + this.height = 0; + this.depth = 0; + this.maxFontSize = 0; + this.style = {}; + } + hasClass(className) { + return utils.contains(this.classes, className); + } + /** Convert the fragment into a node. */ + toNode() { + var frag = document.createDocumentFragment(); + for (var i2 = 0; i2 < this.children.length; i2++) { + frag.appendChild(this.children[i2].toNode()); + } + return frag; + } + /** Convert the fragment into HTML markup. */ + toMarkup() { + var markup = ""; + for (var i2 = 0; i2 < this.children.length; i2++) { + markup += this.children[i2].toMarkup(); + } + return markup; + } + /** + * Converts the math node into a string, similar to innerText. Applies to + * MathDomNode's only. + */ + toText() { + var toText = (child) => child.toText(); + return this.children.map(toText).join(""); + } + } + var fontMetricsData = { + "AMS-Regular": { + "32": [0, 0, 0, 0, 0.25], + "65": [0, 0.68889, 0, 0, 0.72222], + "66": [0, 0.68889, 0, 0, 0.66667], + "67": [0, 0.68889, 0, 0, 0.72222], + "68": [0, 0.68889, 0, 0, 0.72222], + "69": [0, 0.68889, 0, 0, 0.66667], + "70": [0, 0.68889, 0, 0, 0.61111], + "71": [0, 0.68889, 0, 0, 0.77778], + "72": [0, 0.68889, 0, 0, 0.77778], + "73": [0, 0.68889, 0, 0, 0.38889], + "74": [0.16667, 0.68889, 0, 0, 0.5], + "75": [0, 0.68889, 0, 0, 0.77778], + "76": [0, 0.68889, 0, 0, 0.66667], + "77": [0, 0.68889, 0, 0, 0.94445], + "78": [0, 0.68889, 0, 0, 0.72222], + "79": [0.16667, 0.68889, 0, 0, 0.77778], + "80": [0, 0.68889, 0, 0, 0.61111], + "81": [0.16667, 0.68889, 0, 0, 0.77778], + "82": [0, 0.68889, 0, 0, 0.72222], + "83": [0, 0.68889, 0, 0, 0.55556], + "84": [0, 0.68889, 0, 0, 0.66667], + "85": [0, 0.68889, 0, 0, 0.72222], + "86": [0, 0.68889, 0, 0, 0.72222], + "87": [0, 0.68889, 0, 0, 1], + "88": [0, 0.68889, 0, 0, 0.72222], + "89": [0, 0.68889, 0, 0, 0.72222], + "90": [0, 0.68889, 0, 0, 0.66667], + "107": [0, 0.68889, 0, 0, 0.55556], + "160": [0, 0, 0, 0, 0.25], + "165": [0, 0.675, 0.025, 0, 0.75], + "174": [0.15559, 0.69224, 0, 0, 0.94666], + "240": [0, 0.68889, 0, 0, 0.55556], + "295": [0, 0.68889, 0, 0, 0.54028], + "710": [0, 0.825, 0, 0, 2.33334], + "732": [0, 0.9, 0, 0, 2.33334], + "770": [0, 0.825, 0, 0, 2.33334], + "771": [0, 0.9, 0, 0, 2.33334], + "989": [0.08167, 0.58167, 0, 0, 0.77778], + "1008": [0, 0.43056, 0.04028, 0, 0.66667], + "8245": [0, 0.54986, 0, 0, 0.275], + "8463": [0, 0.68889, 0, 0, 0.54028], + "8487": [0, 0.68889, 0, 0, 0.72222], + "8498": [0, 0.68889, 0, 0, 0.55556], + "8502": [0, 0.68889, 0, 0, 0.66667], + "8503": [0, 0.68889, 0, 0, 0.44445], + "8504": [0, 0.68889, 0, 0, 0.66667], + "8513": [0, 0.68889, 0, 0, 0.63889], + "8592": [-0.03598, 0.46402, 0, 0, 0.5], + "8594": [-0.03598, 0.46402, 0, 0, 0.5], + "8602": [-0.13313, 0.36687, 0, 0, 1], + "8603": [-0.13313, 0.36687, 0, 0, 1], + "8606": [0.01354, 0.52239, 0, 0, 1], + "8608": [0.01354, 0.52239, 0, 0, 1], + "8610": [0.01354, 0.52239, 0, 0, 1.11111], + "8611": [0.01354, 0.52239, 0, 0, 1.11111], + "8619": [0, 0.54986, 0, 0, 1], + "8620": [0, 0.54986, 0, 0, 1], + "8621": [-0.13313, 0.37788, 0, 0, 1.38889], + "8622": [-0.13313, 0.36687, 0, 0, 1], + "8624": [0, 0.69224, 0, 0, 0.5], + "8625": [0, 0.69224, 0, 0, 0.5], + "8630": [0, 0.43056, 0, 0, 1], + "8631": [0, 0.43056, 0, 0, 1], + "8634": [0.08198, 0.58198, 0, 0, 0.77778], + "8635": [0.08198, 0.58198, 0, 0, 0.77778], + "8638": [0.19444, 0.69224, 0, 0, 0.41667], + "8639": [0.19444, 0.69224, 0, 0, 0.41667], + "8642": [0.19444, 0.69224, 0, 0, 0.41667], + "8643": [0.19444, 0.69224, 0, 0, 0.41667], + "8644": [0.1808, 0.675, 0, 0, 1], + "8646": [0.1808, 0.675, 0, 0, 1], + "8647": [0.1808, 0.675, 0, 0, 1], + "8648": [0.19444, 0.69224, 0, 0, 0.83334], + "8649": [0.1808, 0.675, 0, 0, 1], + "8650": [0.19444, 0.69224, 0, 0, 0.83334], + "8651": [0.01354, 0.52239, 0, 0, 1], + "8652": [0.01354, 0.52239, 0, 0, 1], + "8653": [-0.13313, 0.36687, 0, 0, 1], + "8654": [-0.13313, 0.36687, 0, 0, 1], + "8655": [-0.13313, 0.36687, 0, 0, 1], + "8666": [0.13667, 0.63667, 0, 0, 1], + "8667": [0.13667, 0.63667, 0, 0, 1], + "8669": [-0.13313, 0.37788, 0, 0, 1], + "8672": [-0.064, 0.437, 0, 0, 1.334], + "8674": [-0.064, 0.437, 0, 0, 1.334], + "8705": [0, 0.825, 0, 0, 0.5], + "8708": [0, 0.68889, 0, 0, 0.55556], + "8709": [0.08167, 0.58167, 0, 0, 0.77778], + "8717": [0, 0.43056, 0, 0, 0.42917], + "8722": [-0.03598, 0.46402, 0, 0, 0.5], + "8724": [0.08198, 0.69224, 0, 0, 0.77778], + "8726": [0.08167, 0.58167, 0, 0, 0.77778], + "8733": [0, 0.69224, 0, 0, 0.77778], + "8736": [0, 0.69224, 0, 0, 0.72222], + "8737": [0, 0.69224, 0, 0, 0.72222], + "8738": [0.03517, 0.52239, 0, 0, 0.72222], + "8739": [0.08167, 0.58167, 0, 0, 0.22222], + "8740": [0.25142, 0.74111, 0, 0, 0.27778], + "8741": [0.08167, 0.58167, 0, 0, 0.38889], + "8742": [0.25142, 0.74111, 0, 0, 0.5], + "8756": [0, 0.69224, 0, 0, 0.66667], + "8757": [0, 0.69224, 0, 0, 0.66667], + "8764": [-0.13313, 0.36687, 0, 0, 0.77778], + "8765": [-0.13313, 0.37788, 0, 0, 0.77778], + "8769": [-0.13313, 0.36687, 0, 0, 0.77778], + "8770": [-0.03625, 0.46375, 0, 0, 0.77778], + "8774": [0.30274, 0.79383, 0, 0, 0.77778], + "8776": [-0.01688, 0.48312, 0, 0, 0.77778], + "8778": [0.08167, 0.58167, 0, 0, 0.77778], + "8782": [0.06062, 0.54986, 0, 0, 0.77778], + "8783": [0.06062, 0.54986, 0, 0, 0.77778], + "8785": [0.08198, 0.58198, 0, 0, 0.77778], + "8786": [0.08198, 0.58198, 0, 0, 0.77778], + "8787": [0.08198, 0.58198, 0, 0, 0.77778], + "8790": [0, 0.69224, 0, 0, 0.77778], + "8791": [0.22958, 0.72958, 0, 0, 0.77778], + "8796": [0.08198, 0.91667, 0, 0, 0.77778], + "8806": [0.25583, 0.75583, 0, 0, 0.77778], + "8807": [0.25583, 0.75583, 0, 0, 0.77778], + "8808": [0.25142, 0.75726, 0, 0, 0.77778], + "8809": [0.25142, 0.75726, 0, 0, 0.77778], + "8812": [0.25583, 0.75583, 0, 0, 0.5], + "8814": [0.20576, 0.70576, 0, 0, 0.77778], + "8815": [0.20576, 0.70576, 0, 0, 0.77778], + "8816": [0.30274, 0.79383, 0, 0, 0.77778], + "8817": [0.30274, 0.79383, 0, 0, 0.77778], + "8818": [0.22958, 0.72958, 0, 0, 0.77778], + "8819": [0.22958, 0.72958, 0, 0, 0.77778], + "8822": [0.1808, 0.675, 0, 0, 0.77778], + "8823": [0.1808, 0.675, 0, 0, 0.77778], + "8828": [0.13667, 0.63667, 0, 0, 0.77778], + "8829": [0.13667, 0.63667, 0, 0, 0.77778], + "8830": [0.22958, 0.72958, 0, 0, 0.77778], + "8831": [0.22958, 0.72958, 0, 0, 0.77778], + "8832": [0.20576, 0.70576, 0, 0, 0.77778], + "8833": [0.20576, 0.70576, 0, 0, 0.77778], + "8840": [0.30274, 0.79383, 0, 0, 0.77778], + "8841": [0.30274, 0.79383, 0, 0, 0.77778], + "8842": [0.13597, 0.63597, 0, 0, 0.77778], + "8843": [0.13597, 0.63597, 0, 0, 0.77778], + "8847": [0.03517, 0.54986, 0, 0, 0.77778], + "8848": [0.03517, 0.54986, 0, 0, 0.77778], + "8858": [0.08198, 0.58198, 0, 0, 0.77778], + "8859": [0.08198, 0.58198, 0, 0, 0.77778], + "8861": [0.08198, 0.58198, 0, 0, 0.77778], + "8862": [0, 0.675, 0, 0, 0.77778], + "8863": [0, 0.675, 0, 0, 0.77778], + "8864": [0, 0.675, 0, 0, 0.77778], + "8865": [0, 0.675, 0, 0, 0.77778], + "8872": [0, 0.69224, 0, 0, 0.61111], + "8873": [0, 0.69224, 0, 0, 0.72222], + "8874": [0, 0.69224, 0, 0, 0.88889], + "8876": [0, 0.68889, 0, 0, 0.61111], + "8877": [0, 0.68889, 0, 0, 0.61111], + "8878": [0, 0.68889, 0, 0, 0.72222], + "8879": [0, 0.68889, 0, 0, 0.72222], + "8882": [0.03517, 0.54986, 0, 0, 0.77778], + "8883": [0.03517, 0.54986, 0, 0, 0.77778], + "8884": [0.13667, 0.63667, 0, 0, 0.77778], + "8885": [0.13667, 0.63667, 0, 0, 0.77778], + "8888": [0, 0.54986, 0, 0, 1.11111], + "8890": [0.19444, 0.43056, 0, 0, 0.55556], + "8891": [0.19444, 0.69224, 0, 0, 0.61111], + "8892": [0.19444, 0.69224, 0, 0, 0.61111], + "8901": [0, 0.54986, 0, 0, 0.27778], + "8903": [0.08167, 0.58167, 0, 0, 0.77778], + "8905": [0.08167, 0.58167, 0, 0, 0.77778], + "8906": [0.08167, 0.58167, 0, 0, 0.77778], + "8907": [0, 0.69224, 0, 0, 0.77778], + "8908": [0, 0.69224, 0, 0, 0.77778], + "8909": [-0.03598, 0.46402, 0, 0, 0.77778], + "8910": [0, 0.54986, 0, 0, 0.76042], + "8911": [0, 0.54986, 0, 0, 0.76042], + "8912": [0.03517, 0.54986, 0, 0, 0.77778], + "8913": [0.03517, 0.54986, 0, 0, 0.77778], + "8914": [0, 0.54986, 0, 0, 0.66667], + "8915": [0, 0.54986, 0, 0, 0.66667], + "8916": [0, 0.69224, 0, 0, 0.66667], + "8918": [0.0391, 0.5391, 0, 0, 0.77778], + "8919": [0.0391, 0.5391, 0, 0, 0.77778], + "8920": [0.03517, 0.54986, 0, 0, 1.33334], + "8921": [0.03517, 0.54986, 0, 0, 1.33334], + "8922": [0.38569, 0.88569, 0, 0, 0.77778], + "8923": [0.38569, 0.88569, 0, 0, 0.77778], + "8926": [0.13667, 0.63667, 0, 0, 0.77778], + "8927": [0.13667, 0.63667, 0, 0, 0.77778], + "8928": [0.30274, 0.79383, 0, 0, 0.77778], + "8929": [0.30274, 0.79383, 0, 0, 0.77778], + "8934": [0.23222, 0.74111, 0, 0, 0.77778], + "8935": [0.23222, 0.74111, 0, 0, 0.77778], + "8936": [0.23222, 0.74111, 0, 0, 0.77778], + "8937": [0.23222, 0.74111, 0, 0, 0.77778], + "8938": [0.20576, 0.70576, 0, 0, 0.77778], + "8939": [0.20576, 0.70576, 0, 0, 0.77778], + "8940": [0.30274, 0.79383, 0, 0, 0.77778], + "8941": [0.30274, 0.79383, 0, 0, 0.77778], + "8994": [0.19444, 0.69224, 0, 0, 0.77778], + "8995": [0.19444, 0.69224, 0, 0, 0.77778], + "9416": [0.15559, 0.69224, 0, 0, 0.90222], + "9484": [0, 0.69224, 0, 0, 0.5], + "9488": [0, 0.69224, 0, 0, 0.5], + "9492": [0, 0.37788, 0, 0, 0.5], + "9496": [0, 0.37788, 0, 0, 0.5], + "9585": [0.19444, 0.68889, 0, 0, 0.88889], + "9586": [0.19444, 0.74111, 0, 0, 0.88889], + "9632": [0, 0.675, 0, 0, 0.77778], + "9633": [0, 0.675, 0, 0, 0.77778], + "9650": [0, 0.54986, 0, 0, 0.72222], + "9651": [0, 0.54986, 0, 0, 0.72222], + "9654": [0.03517, 0.54986, 0, 0, 0.77778], + "9660": [0, 0.54986, 0, 0, 0.72222], + "9661": [0, 0.54986, 0, 0, 0.72222], + "9664": [0.03517, 0.54986, 0, 0, 0.77778], + "9674": [0.11111, 0.69224, 0, 0, 0.66667], + "9733": [0.19444, 0.69224, 0, 0, 0.94445], + "10003": [0, 0.69224, 0, 0, 0.83334], + "10016": [0, 0.69224, 0, 0, 0.83334], + "10731": [0.11111, 0.69224, 0, 0, 0.66667], + "10846": [0.19444, 0.75583, 0, 0, 0.61111], + "10877": [0.13667, 0.63667, 0, 0, 0.77778], + "10878": [0.13667, 0.63667, 0, 0, 0.77778], + "10885": [0.25583, 0.75583, 0, 0, 0.77778], + "10886": [0.25583, 0.75583, 0, 0, 0.77778], + "10887": [0.13597, 0.63597, 0, 0, 0.77778], + "10888": [0.13597, 0.63597, 0, 0, 0.77778], + "10889": [0.26167, 0.75726, 0, 0, 0.77778], + "10890": [0.26167, 0.75726, 0, 0, 0.77778], + "10891": [0.48256, 0.98256, 0, 0, 0.77778], + "10892": [0.48256, 0.98256, 0, 0, 0.77778], + "10901": [0.13667, 0.63667, 0, 0, 0.77778], + "10902": [0.13667, 0.63667, 0, 0, 0.77778], + "10933": [0.25142, 0.75726, 0, 0, 0.77778], + "10934": [0.25142, 0.75726, 0, 0, 0.77778], + "10935": [0.26167, 0.75726, 0, 0, 0.77778], + "10936": [0.26167, 0.75726, 0, 0, 0.77778], + "10937": [0.26167, 0.75726, 0, 0, 0.77778], + "10938": [0.26167, 0.75726, 0, 0, 0.77778], + "10949": [0.25583, 0.75583, 0, 0, 0.77778], + "10950": [0.25583, 0.75583, 0, 0, 0.77778], + "10955": [0.28481, 0.79383, 0, 0, 0.77778], + "10956": [0.28481, 0.79383, 0, 0, 0.77778], + "57350": [0.08167, 0.58167, 0, 0, 0.22222], + "57351": [0.08167, 0.58167, 0, 0, 0.38889], + "57352": [0.08167, 0.58167, 0, 0, 0.77778], + "57353": [0, 0.43056, 0.04028, 0, 0.66667], + "57356": [0.25142, 0.75726, 0, 0, 0.77778], + "57357": [0.25142, 0.75726, 0, 0, 0.77778], + "57358": [0.41951, 0.91951, 0, 0, 0.77778], + "57359": [0.30274, 0.79383, 0, 0, 0.77778], + "57360": [0.30274, 0.79383, 0, 0, 0.77778], + "57361": [0.41951, 0.91951, 0, 0, 0.77778], + "57366": [0.25142, 0.75726, 0, 0, 0.77778], + "57367": [0.25142, 0.75726, 0, 0, 0.77778], + "57368": [0.25142, 0.75726, 0, 0, 0.77778], + "57369": [0.25142, 0.75726, 0, 0, 0.77778], + "57370": [0.13597, 0.63597, 0, 0, 0.77778], + "57371": [0.13597, 0.63597, 0, 0, 0.77778] + }, + "Caligraphic-Regular": { + "32": [0, 0, 0, 0, 0.25], + "65": [0, 0.68333, 0, 0.19445, 0.79847], + "66": [0, 0.68333, 0.03041, 0.13889, 0.65681], + "67": [0, 0.68333, 0.05834, 0.13889, 0.52653], + "68": [0, 0.68333, 0.02778, 0.08334, 0.77139], + "69": [0, 0.68333, 0.08944, 0.11111, 0.52778], + "70": [0, 0.68333, 0.09931, 0.11111, 0.71875], + "71": [0.09722, 0.68333, 0.0593, 0.11111, 0.59487], + "72": [0, 0.68333, 965e-5, 0.11111, 0.84452], + "73": [0, 0.68333, 0.07382, 0, 0.54452], + "74": [0.09722, 0.68333, 0.18472, 0.16667, 0.67778], + "75": [0, 0.68333, 0.01445, 0.05556, 0.76195], + "76": [0, 0.68333, 0, 0.13889, 0.68972], + "77": [0, 0.68333, 0, 0.13889, 1.2009], + "78": [0, 0.68333, 0.14736, 0.08334, 0.82049], + "79": [0, 0.68333, 0.02778, 0.11111, 0.79611], + "80": [0, 0.68333, 0.08222, 0.08334, 0.69556], + "81": [0.09722, 0.68333, 0, 0.11111, 0.81667], + "82": [0, 0.68333, 0, 0.08334, 0.8475], + "83": [0, 0.68333, 0.075, 0.13889, 0.60556], + "84": [0, 0.68333, 0.25417, 0, 0.54464], + "85": [0, 0.68333, 0.09931, 0.08334, 0.62583], + "86": [0, 0.68333, 0.08222, 0, 0.61278], + "87": [0, 0.68333, 0.08222, 0.08334, 0.98778], + "88": [0, 0.68333, 0.14643, 0.13889, 0.7133], + "89": [0.09722, 0.68333, 0.08222, 0.08334, 0.66834], + "90": [0, 0.68333, 0.07944, 0.13889, 0.72473], + "160": [0, 0, 0, 0, 0.25] + }, + "Fraktur-Regular": { + "32": [0, 0, 0, 0, 0.25], + "33": [0, 0.69141, 0, 0, 0.29574], + "34": [0, 0.69141, 0, 0, 0.21471], + "38": [0, 0.69141, 0, 0, 0.73786], + "39": [0, 0.69141, 0, 0, 0.21201], + "40": [0.24982, 0.74947, 0, 0, 0.38865], + "41": [0.24982, 0.74947, 0, 0, 0.38865], + "42": [0, 0.62119, 0, 0, 0.27764], + "43": [0.08319, 0.58283, 0, 0, 0.75623], + "44": [0, 0.10803, 0, 0, 0.27764], + "45": [0.08319, 0.58283, 0, 0, 0.75623], + "46": [0, 0.10803, 0, 0, 0.27764], + "47": [0.24982, 0.74947, 0, 0, 0.50181], + "48": [0, 0.47534, 0, 0, 0.50181], + "49": [0, 0.47534, 0, 0, 0.50181], + "50": [0, 0.47534, 0, 0, 0.50181], + "51": [0.18906, 0.47534, 0, 0, 0.50181], + "52": [0.18906, 0.47534, 0, 0, 0.50181], + "53": [0.18906, 0.47534, 0, 0, 0.50181], + "54": [0, 0.69141, 0, 0, 0.50181], + "55": [0.18906, 0.47534, 0, 0, 0.50181], + "56": [0, 0.69141, 0, 0, 0.50181], + "57": [0.18906, 0.47534, 0, 0, 0.50181], + "58": [0, 0.47534, 0, 0, 0.21606], + "59": [0.12604, 0.47534, 0, 0, 0.21606], + "61": [-0.13099, 0.36866, 0, 0, 0.75623], + "63": [0, 0.69141, 0, 0, 0.36245], + "65": [0, 0.69141, 0, 0, 0.7176], + "66": [0, 0.69141, 0, 0, 0.88397], + "67": [0, 0.69141, 0, 0, 0.61254], + "68": [0, 0.69141, 0, 0, 0.83158], + "69": [0, 0.69141, 0, 0, 0.66278], + "70": [0.12604, 0.69141, 0, 0, 0.61119], + "71": [0, 0.69141, 0, 0, 0.78539], + "72": [0.06302, 0.69141, 0, 0, 0.7203], + "73": [0, 0.69141, 0, 0, 0.55448], + "74": [0.12604, 0.69141, 0, 0, 0.55231], + "75": [0, 0.69141, 0, 0, 0.66845], + "76": [0, 0.69141, 0, 0, 0.66602], + "77": [0, 0.69141, 0, 0, 1.04953], + "78": [0, 0.69141, 0, 0, 0.83212], + "79": [0, 0.69141, 0, 0, 0.82699], + "80": [0.18906, 0.69141, 0, 0, 0.82753], + "81": [0.03781, 0.69141, 0, 0, 0.82699], + "82": [0, 0.69141, 0, 0, 0.82807], + "83": [0, 0.69141, 0, 0, 0.82861], + "84": [0, 0.69141, 0, 0, 0.66899], + "85": [0, 0.69141, 0, 0, 0.64576], + "86": [0, 0.69141, 0, 0, 0.83131], + "87": [0, 0.69141, 0, 0, 1.04602], + "88": [0, 0.69141, 0, 0, 0.71922], + "89": [0.18906, 0.69141, 0, 0, 0.83293], + "90": [0.12604, 0.69141, 0, 0, 0.60201], + "91": [0.24982, 0.74947, 0, 0, 0.27764], + "93": [0.24982, 0.74947, 0, 0, 0.27764], + "94": [0, 0.69141, 0, 0, 0.49965], + "97": [0, 0.47534, 0, 0, 0.50046], + "98": [0, 0.69141, 0, 0, 0.51315], + "99": [0, 0.47534, 0, 0, 0.38946], + "100": [0, 0.62119, 0, 0, 0.49857], + "101": [0, 0.47534, 0, 0, 0.40053], + "102": [0.18906, 0.69141, 0, 0, 0.32626], + "103": [0.18906, 0.47534, 0, 0, 0.5037], + "104": [0.18906, 0.69141, 0, 0, 0.52126], + "105": [0, 0.69141, 0, 0, 0.27899], + "106": [0, 0.69141, 0, 0, 0.28088], + "107": [0, 0.69141, 0, 0, 0.38946], + "108": [0, 0.69141, 0, 0, 0.27953], + "109": [0, 0.47534, 0, 0, 0.76676], + "110": [0, 0.47534, 0, 0, 0.52666], + "111": [0, 0.47534, 0, 0, 0.48885], + "112": [0.18906, 0.52396, 0, 0, 0.50046], + "113": [0.18906, 0.47534, 0, 0, 0.48912], + "114": [0, 0.47534, 0, 0, 0.38919], + "115": [0, 0.47534, 0, 0, 0.44266], + "116": [0, 0.62119, 0, 0, 0.33301], + "117": [0, 0.47534, 0, 0, 0.5172], + "118": [0, 0.52396, 0, 0, 0.5118], + "119": [0, 0.52396, 0, 0, 0.77351], + "120": [0.18906, 0.47534, 0, 0, 0.38865], + "121": [0.18906, 0.47534, 0, 0, 0.49884], + "122": [0.18906, 0.47534, 0, 0, 0.39054], + "160": [0, 0, 0, 0, 0.25], + "8216": [0, 0.69141, 0, 0, 0.21471], + "8217": [0, 0.69141, 0, 0, 0.21471], + "58112": [0, 0.62119, 0, 0, 0.49749], + "58113": [0, 0.62119, 0, 0, 0.4983], + "58114": [0.18906, 0.69141, 0, 0, 0.33328], + "58115": [0.18906, 0.69141, 0, 0, 0.32923], + "58116": [0.18906, 0.47534, 0, 0, 0.50343], + "58117": [0, 0.69141, 0, 0, 0.33301], + "58118": [0, 0.62119, 0, 0, 0.33409], + "58119": [0, 0.47534, 0, 0, 0.50073] + }, + "Main-Bold": { + "32": [0, 0, 0, 0, 0.25], + "33": [0, 0.69444, 0, 0, 0.35], + "34": [0, 0.69444, 0, 0, 0.60278], + "35": [0.19444, 0.69444, 0, 0, 0.95833], + "36": [0.05556, 0.75, 0, 0, 0.575], + "37": [0.05556, 0.75, 0, 0, 0.95833], + "38": [0, 0.69444, 0, 0, 0.89444], + "39": [0, 0.69444, 0, 0, 0.31944], + "40": [0.25, 0.75, 0, 0, 0.44722], + "41": [0.25, 0.75, 0, 0, 0.44722], + "42": [0, 0.75, 0, 0, 0.575], + "43": [0.13333, 0.63333, 0, 0, 0.89444], + "44": [0.19444, 0.15556, 0, 0, 0.31944], + "45": [0, 0.44444, 0, 0, 0.38333], + "46": [0, 0.15556, 0, 0, 0.31944], + "47": [0.25, 0.75, 0, 0, 0.575], + "48": [0, 0.64444, 0, 0, 0.575], + "49": [0, 0.64444, 0, 0, 0.575], + "50": [0, 0.64444, 0, 0, 0.575], + "51": [0, 0.64444, 0, 0, 0.575], + "52": [0, 0.64444, 0, 0, 0.575], + "53": [0, 0.64444, 0, 0, 0.575], + "54": [0, 0.64444, 0, 0, 0.575], + "55": [0, 0.64444, 0, 0, 0.575], + "56": [0, 0.64444, 0, 0, 0.575], + "57": [0, 0.64444, 0, 0, 0.575], + "58": [0, 0.44444, 0, 0, 0.31944], + "59": [0.19444, 0.44444, 0, 0, 0.31944], + "60": [0.08556, 0.58556, 0, 0, 0.89444], + "61": [-0.10889, 0.39111, 0, 0, 0.89444], + "62": [0.08556, 0.58556, 0, 0, 0.89444], + "63": [0, 0.69444, 0, 0, 0.54305], + "64": [0, 0.69444, 0, 0, 0.89444], + "65": [0, 0.68611, 0, 0, 0.86944], + "66": [0, 0.68611, 0, 0, 0.81805], + "67": [0, 0.68611, 0, 0, 0.83055], + "68": [0, 0.68611, 0, 0, 0.88194], + "69": [0, 0.68611, 0, 0, 0.75555], + "70": [0, 0.68611, 0, 0, 0.72361], + "71": [0, 0.68611, 0, 0, 0.90416], + "72": [0, 0.68611, 0, 0, 0.9], + "73": [0, 0.68611, 0, 0, 0.43611], + "74": [0, 0.68611, 0, 0, 0.59444], + "75": [0, 0.68611, 0, 0, 0.90138], + "76": [0, 0.68611, 0, 0, 0.69166], + "77": [0, 0.68611, 0, 0, 1.09166], + "78": [0, 0.68611, 0, 0, 0.9], + "79": [0, 0.68611, 0, 0, 0.86388], + "80": [0, 0.68611, 0, 0, 0.78611], + "81": [0.19444, 0.68611, 0, 0, 0.86388], + "82": [0, 0.68611, 0, 0, 0.8625], + "83": [0, 0.68611, 0, 0, 0.63889], + "84": [0, 0.68611, 0, 0, 0.8], + "85": [0, 0.68611, 0, 0, 0.88472], + "86": [0, 0.68611, 0.01597, 0, 0.86944], + "87": [0, 0.68611, 0.01597, 0, 1.18888], + "88": [0, 0.68611, 0, 0, 0.86944], + "89": [0, 0.68611, 0.02875, 0, 0.86944], + "90": [0, 0.68611, 0, 0, 0.70277], + "91": [0.25, 0.75, 0, 0, 0.31944], + "92": [0.25, 0.75, 0, 0, 0.575], + "93": [0.25, 0.75, 0, 0, 0.31944], + "94": [0, 0.69444, 0, 0, 0.575], + "95": [0.31, 0.13444, 0.03194, 0, 0.575], + "97": [0, 0.44444, 0, 0, 0.55902], + "98": [0, 0.69444, 0, 0, 0.63889], + "99": [0, 0.44444, 0, 0, 0.51111], + "100": [0, 0.69444, 0, 0, 0.63889], + "101": [0, 0.44444, 0, 0, 0.52708], + "102": [0, 0.69444, 0.10903, 0, 0.35139], + "103": [0.19444, 0.44444, 0.01597, 0, 0.575], + "104": [0, 0.69444, 0, 0, 0.63889], + "105": [0, 0.69444, 0, 0, 0.31944], + "106": [0.19444, 0.69444, 0, 0, 0.35139], + "107": [0, 0.69444, 0, 0, 0.60694], + "108": [0, 0.69444, 0, 0, 0.31944], + "109": [0, 0.44444, 0, 0, 0.95833], + "110": [0, 0.44444, 0, 0, 0.63889], + "111": [0, 0.44444, 0, 0, 0.575], + "112": [0.19444, 0.44444, 0, 0, 0.63889], + "113": [0.19444, 0.44444, 0, 0, 0.60694], + "114": [0, 0.44444, 0, 0, 0.47361], + "115": [0, 0.44444, 0, 0, 0.45361], + "116": [0, 0.63492, 0, 0, 0.44722], + "117": [0, 0.44444, 0, 0, 0.63889], + "118": [0, 0.44444, 0.01597, 0, 0.60694], + "119": [0, 0.44444, 0.01597, 0, 0.83055], + "120": [0, 0.44444, 0, 0, 0.60694], + "121": [0.19444, 0.44444, 0.01597, 0, 0.60694], + "122": [0, 0.44444, 0, 0, 0.51111], + "123": [0.25, 0.75, 0, 0, 0.575], + "124": [0.25, 0.75, 0, 0, 0.31944], + "125": [0.25, 0.75, 0, 0, 0.575], + "126": [0.35, 0.34444, 0, 0, 0.575], + "160": [0, 0, 0, 0, 0.25], + "163": [0, 0.69444, 0, 0, 0.86853], + "168": [0, 0.69444, 0, 0, 0.575], + "172": [0, 0.44444, 0, 0, 0.76666], + "176": [0, 0.69444, 0, 0, 0.86944], + "177": [0.13333, 0.63333, 0, 0, 0.89444], + "184": [0.17014, 0, 0, 0, 0.51111], + "198": [0, 0.68611, 0, 0, 1.04166], + "215": [0.13333, 0.63333, 0, 0, 0.89444], + "216": [0.04861, 0.73472, 0, 0, 0.89444], + "223": [0, 0.69444, 0, 0, 0.59722], + "230": [0, 0.44444, 0, 0, 0.83055], + "247": [0.13333, 0.63333, 0, 0, 0.89444], + "248": [0.09722, 0.54167, 0, 0, 0.575], + "305": [0, 0.44444, 0, 0, 0.31944], + "338": [0, 0.68611, 0, 0, 1.16944], + "339": [0, 0.44444, 0, 0, 0.89444], + "567": [0.19444, 0.44444, 0, 0, 0.35139], + "710": [0, 0.69444, 0, 0, 0.575], + "711": [0, 0.63194, 0, 0, 0.575], + "713": [0, 0.59611, 0, 0, 0.575], + "714": [0, 0.69444, 0, 0, 0.575], + "715": [0, 0.69444, 0, 0, 0.575], + "728": [0, 0.69444, 0, 0, 0.575], + "729": [0, 0.69444, 0, 0, 0.31944], + "730": [0, 0.69444, 0, 0, 0.86944], + "732": [0, 0.69444, 0, 0, 0.575], + "733": [0, 0.69444, 0, 0, 0.575], + "915": [0, 0.68611, 0, 0, 0.69166], + "916": [0, 0.68611, 0, 0, 0.95833], + "920": [0, 0.68611, 0, 0, 0.89444], + "923": [0, 0.68611, 0, 0, 0.80555], + "926": [0, 0.68611, 0, 0, 0.76666], + "928": [0, 0.68611, 0, 0, 0.9], + "931": [0, 0.68611, 0, 0, 0.83055], + "933": [0, 0.68611, 0, 0, 0.89444], + "934": [0, 0.68611, 0, 0, 0.83055], + "936": [0, 0.68611, 0, 0, 0.89444], + "937": [0, 0.68611, 0, 0, 0.83055], + "8211": [0, 0.44444, 0.03194, 0, 0.575], + "8212": [0, 0.44444, 0.03194, 0, 1.14999], + "8216": [0, 0.69444, 0, 0, 0.31944], + "8217": [0, 0.69444, 0, 0, 0.31944], + "8220": [0, 0.69444, 0, 0, 0.60278], + "8221": [0, 0.69444, 0, 0, 0.60278], + "8224": [0.19444, 0.69444, 0, 0, 0.51111], + "8225": [0.19444, 0.69444, 0, 0, 0.51111], + "8242": [0, 0.55556, 0, 0, 0.34444], + "8407": [0, 0.72444, 0.15486, 0, 0.575], + "8463": [0, 0.69444, 0, 0, 0.66759], + "8465": [0, 0.69444, 0, 0, 0.83055], + "8467": [0, 0.69444, 0, 0, 0.47361], + "8472": [0.19444, 0.44444, 0, 0, 0.74027], + "8476": [0, 0.69444, 0, 0, 0.83055], + "8501": [0, 0.69444, 0, 0, 0.70277], + "8592": [-0.10889, 0.39111, 0, 0, 1.14999], + "8593": [0.19444, 0.69444, 0, 0, 0.575], + "8594": [-0.10889, 0.39111, 0, 0, 1.14999], + "8595": [0.19444, 0.69444, 0, 0, 0.575], + "8596": [-0.10889, 0.39111, 0, 0, 1.14999], + "8597": [0.25, 0.75, 0, 0, 0.575], + "8598": [0.19444, 0.69444, 0, 0, 1.14999], + "8599": [0.19444, 0.69444, 0, 0, 1.14999], + "8600": [0.19444, 0.69444, 0, 0, 1.14999], + "8601": [0.19444, 0.69444, 0, 0, 1.14999], + "8636": [-0.10889, 0.39111, 0, 0, 1.14999], + "8637": [-0.10889, 0.39111, 0, 0, 1.14999], + "8640": [-0.10889, 0.39111, 0, 0, 1.14999], + "8641": [-0.10889, 0.39111, 0, 0, 1.14999], + "8656": [-0.10889, 0.39111, 0, 0, 1.14999], + "8657": [0.19444, 0.69444, 0, 0, 0.70277], + "8658": [-0.10889, 0.39111, 0, 0, 1.14999], + "8659": [0.19444, 0.69444, 0, 0, 0.70277], + "8660": [-0.10889, 0.39111, 0, 0, 1.14999], + "8661": [0.25, 0.75, 0, 0, 0.70277], + "8704": [0, 0.69444, 0, 0, 0.63889], + "8706": [0, 0.69444, 0.06389, 0, 0.62847], + "8707": [0, 0.69444, 0, 0, 0.63889], + "8709": [0.05556, 0.75, 0, 0, 0.575], + "8711": [0, 0.68611, 0, 0, 0.95833], + "8712": [0.08556, 0.58556, 0, 0, 0.76666], + "8715": [0.08556, 0.58556, 0, 0, 0.76666], + "8722": [0.13333, 0.63333, 0, 0, 0.89444], + "8723": [0.13333, 0.63333, 0, 0, 0.89444], + "8725": [0.25, 0.75, 0, 0, 0.575], + "8726": [0.25, 0.75, 0, 0, 0.575], + "8727": [-0.02778, 0.47222, 0, 0, 0.575], + "8728": [-0.02639, 0.47361, 0, 0, 0.575], + "8729": [-0.02639, 0.47361, 0, 0, 0.575], + "8730": [0.18, 0.82, 0, 0, 0.95833], + "8733": [0, 0.44444, 0, 0, 0.89444], + "8734": [0, 0.44444, 0, 0, 1.14999], + "8736": [0, 0.69224, 0, 0, 0.72222], + "8739": [0.25, 0.75, 0, 0, 0.31944], + "8741": [0.25, 0.75, 0, 0, 0.575], + "8743": [0, 0.55556, 0, 0, 0.76666], + "8744": [0, 0.55556, 0, 0, 0.76666], + "8745": [0, 0.55556, 0, 0, 0.76666], + "8746": [0, 0.55556, 0, 0, 0.76666], + "8747": [0.19444, 0.69444, 0.12778, 0, 0.56875], + "8764": [-0.10889, 0.39111, 0, 0, 0.89444], + "8768": [0.19444, 0.69444, 0, 0, 0.31944], + "8771": [222e-5, 0.50222, 0, 0, 0.89444], + "8773": [0.027, 0.638, 0, 0, 0.894], + "8776": [0.02444, 0.52444, 0, 0, 0.89444], + "8781": [222e-5, 0.50222, 0, 0, 0.89444], + "8801": [222e-5, 0.50222, 0, 0, 0.89444], + "8804": [0.19667, 0.69667, 0, 0, 0.89444], + "8805": [0.19667, 0.69667, 0, 0, 0.89444], + "8810": [0.08556, 0.58556, 0, 0, 1.14999], + "8811": [0.08556, 0.58556, 0, 0, 1.14999], + "8826": [0.08556, 0.58556, 0, 0, 0.89444], + "8827": [0.08556, 0.58556, 0, 0, 0.89444], + "8834": [0.08556, 0.58556, 0, 0, 0.89444], + "8835": [0.08556, 0.58556, 0, 0, 0.89444], + "8838": [0.19667, 0.69667, 0, 0, 0.89444], + "8839": [0.19667, 0.69667, 0, 0, 0.89444], + "8846": [0, 0.55556, 0, 0, 0.76666], + "8849": [0.19667, 0.69667, 0, 0, 0.89444], + "8850": [0.19667, 0.69667, 0, 0, 0.89444], + "8851": [0, 0.55556, 0, 0, 0.76666], + "8852": [0, 0.55556, 0, 0, 0.76666], + "8853": [0.13333, 0.63333, 0, 0, 0.89444], + "8854": [0.13333, 0.63333, 0, 0, 0.89444], + "8855": [0.13333, 0.63333, 0, 0, 0.89444], + "8856": [0.13333, 0.63333, 0, 0, 0.89444], + "8857": [0.13333, 0.63333, 0, 0, 0.89444], + "8866": [0, 0.69444, 0, 0, 0.70277], + "8867": [0, 0.69444, 0, 0, 0.70277], + "8868": [0, 0.69444, 0, 0, 0.89444], + "8869": [0, 0.69444, 0, 0, 0.89444], + "8900": [-0.02639, 0.47361, 0, 0, 0.575], + "8901": [-0.02639, 0.47361, 0, 0, 0.31944], + "8902": [-0.02778, 0.47222, 0, 0, 0.575], + "8968": [0.25, 0.75, 0, 0, 0.51111], + "8969": [0.25, 0.75, 0, 0, 0.51111], + "8970": [0.25, 0.75, 0, 0, 0.51111], + "8971": [0.25, 0.75, 0, 0, 0.51111], + "8994": [-0.13889, 0.36111, 0, 0, 1.14999], + "8995": [-0.13889, 0.36111, 0, 0, 1.14999], + "9651": [0.19444, 0.69444, 0, 0, 1.02222], + "9657": [-0.02778, 0.47222, 0, 0, 0.575], + "9661": [0.19444, 0.69444, 0, 0, 1.02222], + "9667": [-0.02778, 0.47222, 0, 0, 0.575], + "9711": [0.19444, 0.69444, 0, 0, 1.14999], + "9824": [0.12963, 0.69444, 0, 0, 0.89444], + "9825": [0.12963, 0.69444, 0, 0, 0.89444], + "9826": [0.12963, 0.69444, 0, 0, 0.89444], + "9827": [0.12963, 0.69444, 0, 0, 0.89444], + "9837": [0, 0.75, 0, 0, 0.44722], + "9838": [0.19444, 0.69444, 0, 0, 0.44722], + "9839": [0.19444, 0.69444, 0, 0, 0.44722], + "10216": [0.25, 0.75, 0, 0, 0.44722], + "10217": [0.25, 0.75, 0, 0, 0.44722], + "10815": [0, 0.68611, 0, 0, 0.9], + "10927": [0.19667, 0.69667, 0, 0, 0.89444], + "10928": [0.19667, 0.69667, 0, 0, 0.89444], + "57376": [0.19444, 0.69444, 0, 0, 0] + }, + "Main-BoldItalic": { + "32": [0, 0, 0, 0, 0.25], + "33": [0, 0.69444, 0.11417, 0, 0.38611], + "34": [0, 0.69444, 0.07939, 0, 0.62055], + "35": [0.19444, 0.69444, 0.06833, 0, 0.94444], + "37": [0.05556, 0.75, 0.12861, 0, 0.94444], + "38": [0, 0.69444, 0.08528, 0, 0.88555], + "39": [0, 0.69444, 0.12945, 0, 0.35555], + "40": [0.25, 0.75, 0.15806, 0, 0.47333], + "41": [0.25, 0.75, 0.03306, 0, 0.47333], + "42": [0, 0.75, 0.14333, 0, 0.59111], + "43": [0.10333, 0.60333, 0.03306, 0, 0.88555], + "44": [0.19444, 0.14722, 0, 0, 0.35555], + "45": [0, 0.44444, 0.02611, 0, 0.41444], + "46": [0, 0.14722, 0, 0, 0.35555], + "47": [0.25, 0.75, 0.15806, 0, 0.59111], + "48": [0, 0.64444, 0.13167, 0, 0.59111], + "49": [0, 0.64444, 0.13167, 0, 0.59111], + "50": [0, 0.64444, 0.13167, 0, 0.59111], + "51": [0, 0.64444, 0.13167, 0, 0.59111], + "52": [0.19444, 0.64444, 0.13167, 0, 0.59111], + "53": [0, 0.64444, 0.13167, 0, 0.59111], + "54": [0, 0.64444, 0.13167, 0, 0.59111], + "55": [0.19444, 0.64444, 0.13167, 0, 0.59111], + "56": [0, 0.64444, 0.13167, 0, 0.59111], + "57": [0, 0.64444, 0.13167, 0, 0.59111], + "58": [0, 0.44444, 0.06695, 0, 0.35555], + "59": [0.19444, 0.44444, 0.06695, 0, 0.35555], + "61": [-0.10889, 0.39111, 0.06833, 0, 0.88555], + "63": [0, 0.69444, 0.11472, 0, 0.59111], + "64": [0, 0.69444, 0.09208, 0, 0.88555], + "65": [0, 0.68611, 0, 0, 0.86555], + "66": [0, 0.68611, 0.0992, 0, 0.81666], + "67": [0, 0.68611, 0.14208, 0, 0.82666], + "68": [0, 0.68611, 0.09062, 0, 0.87555], + "69": [0, 0.68611, 0.11431, 0, 0.75666], + "70": [0, 0.68611, 0.12903, 0, 0.72722], + "71": [0, 0.68611, 0.07347, 0, 0.89527], + "72": [0, 0.68611, 0.17208, 0, 0.8961], + "73": [0, 0.68611, 0.15681, 0, 0.47166], + "74": [0, 0.68611, 0.145, 0, 0.61055], + "75": [0, 0.68611, 0.14208, 0, 0.89499], + "76": [0, 0.68611, 0, 0, 0.69777], + "77": [0, 0.68611, 0.17208, 0, 1.07277], + "78": [0, 0.68611, 0.17208, 0, 0.8961], + "79": [0, 0.68611, 0.09062, 0, 0.85499], + "80": [0, 0.68611, 0.0992, 0, 0.78721], + "81": [0.19444, 0.68611, 0.09062, 0, 0.85499], + "82": [0, 0.68611, 0.02559, 0, 0.85944], + "83": [0, 0.68611, 0.11264, 0, 0.64999], + "84": [0, 0.68611, 0.12903, 0, 0.7961], + "85": [0, 0.68611, 0.17208, 0, 0.88083], + "86": [0, 0.68611, 0.18625, 0, 0.86555], + "87": [0, 0.68611, 0.18625, 0, 1.15999], + "88": [0, 0.68611, 0.15681, 0, 0.86555], + "89": [0, 0.68611, 0.19803, 0, 0.86555], + "90": [0, 0.68611, 0.14208, 0, 0.70888], + "91": [0.25, 0.75, 0.1875, 0, 0.35611], + "93": [0.25, 0.75, 0.09972, 0, 0.35611], + "94": [0, 0.69444, 0.06709, 0, 0.59111], + "95": [0.31, 0.13444, 0.09811, 0, 0.59111], + "97": [0, 0.44444, 0.09426, 0, 0.59111], + "98": [0, 0.69444, 0.07861, 0, 0.53222], + "99": [0, 0.44444, 0.05222, 0, 0.53222], + "100": [0, 0.69444, 0.10861, 0, 0.59111], + "101": [0, 0.44444, 0.085, 0, 0.53222], + "102": [0.19444, 0.69444, 0.21778, 0, 0.4], + "103": [0.19444, 0.44444, 0.105, 0, 0.53222], + "104": [0, 0.69444, 0.09426, 0, 0.59111], + "105": [0, 0.69326, 0.11387, 0, 0.35555], + "106": [0.19444, 0.69326, 0.1672, 0, 0.35555], + "107": [0, 0.69444, 0.11111, 0, 0.53222], + "108": [0, 0.69444, 0.10861, 0, 0.29666], + "109": [0, 0.44444, 0.09426, 0, 0.94444], + "110": [0, 0.44444, 0.09426, 0, 0.64999], + "111": [0, 0.44444, 0.07861, 0, 0.59111], + "112": [0.19444, 0.44444, 0.07861, 0, 0.59111], + "113": [0.19444, 0.44444, 0.105, 0, 0.53222], + "114": [0, 0.44444, 0.11111, 0, 0.50167], + "115": [0, 0.44444, 0.08167, 0, 0.48694], + "116": [0, 0.63492, 0.09639, 0, 0.385], + "117": [0, 0.44444, 0.09426, 0, 0.62055], + "118": [0, 0.44444, 0.11111, 0, 0.53222], + "119": [0, 0.44444, 0.11111, 0, 0.76777], + "120": [0, 0.44444, 0.12583, 0, 0.56055], + "121": [0.19444, 0.44444, 0.105, 0, 0.56166], + "122": [0, 0.44444, 0.13889, 0, 0.49055], + "126": [0.35, 0.34444, 0.11472, 0, 0.59111], + "160": [0, 0, 0, 0, 0.25], + "168": [0, 0.69444, 0.11473, 0, 0.59111], + "176": [0, 0.69444, 0, 0, 0.94888], + "184": [0.17014, 0, 0, 0, 0.53222], + "198": [0, 0.68611, 0.11431, 0, 1.02277], + "216": [0.04861, 0.73472, 0.09062, 0, 0.88555], + "223": [0.19444, 0.69444, 0.09736, 0, 0.665], + "230": [0, 0.44444, 0.085, 0, 0.82666], + "248": [0.09722, 0.54167, 0.09458, 0, 0.59111], + "305": [0, 0.44444, 0.09426, 0, 0.35555], + "338": [0, 0.68611, 0.11431, 0, 1.14054], + "339": [0, 0.44444, 0.085, 0, 0.82666], + "567": [0.19444, 0.44444, 0.04611, 0, 0.385], + "710": [0, 0.69444, 0.06709, 0, 0.59111], + "711": [0, 0.63194, 0.08271, 0, 0.59111], + "713": [0, 0.59444, 0.10444, 0, 0.59111], + "714": [0, 0.69444, 0.08528, 0, 0.59111], + "715": [0, 0.69444, 0, 0, 0.59111], + "728": [0, 0.69444, 0.10333, 0, 0.59111], + "729": [0, 0.69444, 0.12945, 0, 0.35555], + "730": [0, 0.69444, 0, 0, 0.94888], + "732": [0, 0.69444, 0.11472, 0, 0.59111], + "733": [0, 0.69444, 0.11472, 0, 0.59111], + "915": [0, 0.68611, 0.12903, 0, 0.69777], + "916": [0, 0.68611, 0, 0, 0.94444], + "920": [0, 0.68611, 0.09062, 0, 0.88555], + "923": [0, 0.68611, 0, 0, 0.80666], + "926": [0, 0.68611, 0.15092, 0, 0.76777], + "928": [0, 0.68611, 0.17208, 0, 0.8961], + "931": [0, 0.68611, 0.11431, 0, 0.82666], + "933": [0, 0.68611, 0.10778, 0, 0.88555], + "934": [0, 0.68611, 0.05632, 0, 0.82666], + "936": [0, 0.68611, 0.10778, 0, 0.88555], + "937": [0, 0.68611, 0.0992, 0, 0.82666], + "8211": [0, 0.44444, 0.09811, 0, 0.59111], + "8212": [0, 0.44444, 0.09811, 0, 1.18221], + "8216": [0, 0.69444, 0.12945, 0, 0.35555], + "8217": [0, 0.69444, 0.12945, 0, 0.35555], + "8220": [0, 0.69444, 0.16772, 0, 0.62055], + "8221": [0, 0.69444, 0.07939, 0, 0.62055] + }, + "Main-Italic": { + "32": [0, 0, 0, 0, 0.25], + "33": [0, 0.69444, 0.12417, 0, 0.30667], + "34": [0, 0.69444, 0.06961, 0, 0.51444], + "35": [0.19444, 0.69444, 0.06616, 0, 0.81777], + "37": [0.05556, 0.75, 0.13639, 0, 0.81777], + "38": [0, 0.69444, 0.09694, 0, 0.76666], + "39": [0, 0.69444, 0.12417, 0, 0.30667], + "40": [0.25, 0.75, 0.16194, 0, 0.40889], + "41": [0.25, 0.75, 0.03694, 0, 0.40889], + "42": [0, 0.75, 0.14917, 0, 0.51111], + "43": [0.05667, 0.56167, 0.03694, 0, 0.76666], + "44": [0.19444, 0.10556, 0, 0, 0.30667], + "45": [0, 0.43056, 0.02826, 0, 0.35778], + "46": [0, 0.10556, 0, 0, 0.30667], + "47": [0.25, 0.75, 0.16194, 0, 0.51111], + "48": [0, 0.64444, 0.13556, 0, 0.51111], + "49": [0, 0.64444, 0.13556, 0, 0.51111], + "50": [0, 0.64444, 0.13556, 0, 0.51111], + "51": [0, 0.64444, 0.13556, 0, 0.51111], + "52": [0.19444, 0.64444, 0.13556, 0, 0.51111], + "53": [0, 0.64444, 0.13556, 0, 0.51111], + "54": [0, 0.64444, 0.13556, 0, 0.51111], + "55": [0.19444, 0.64444, 0.13556, 0, 0.51111], + "56": [0, 0.64444, 0.13556, 0, 0.51111], + "57": [0, 0.64444, 0.13556, 0, 0.51111], + "58": [0, 0.43056, 0.0582, 0, 0.30667], + "59": [0.19444, 0.43056, 0.0582, 0, 0.30667], + "61": [-0.13313, 0.36687, 0.06616, 0, 0.76666], + "63": [0, 0.69444, 0.1225, 0, 0.51111], + "64": [0, 0.69444, 0.09597, 0, 0.76666], + "65": [0, 0.68333, 0, 0, 0.74333], + "66": [0, 0.68333, 0.10257, 0, 0.70389], + "67": [0, 0.68333, 0.14528, 0, 0.71555], + "68": [0, 0.68333, 0.09403, 0, 0.755], + "69": [0, 0.68333, 0.12028, 0, 0.67833], + "70": [0, 0.68333, 0.13305, 0, 0.65277], + "71": [0, 0.68333, 0.08722, 0, 0.77361], + "72": [0, 0.68333, 0.16389, 0, 0.74333], + "73": [0, 0.68333, 0.15806, 0, 0.38555], + "74": [0, 0.68333, 0.14028, 0, 0.525], + "75": [0, 0.68333, 0.14528, 0, 0.76888], + "76": [0, 0.68333, 0, 0, 0.62722], + "77": [0, 0.68333, 0.16389, 0, 0.89666], + "78": [0, 0.68333, 0.16389, 0, 0.74333], + "79": [0, 0.68333, 0.09403, 0, 0.76666], + "80": [0, 0.68333, 0.10257, 0, 0.67833], + "81": [0.19444, 0.68333, 0.09403, 0, 0.76666], + "82": [0, 0.68333, 0.03868, 0, 0.72944], + "83": [0, 0.68333, 0.11972, 0, 0.56222], + "84": [0, 0.68333, 0.13305, 0, 0.71555], + "85": [0, 0.68333, 0.16389, 0, 0.74333], + "86": [0, 0.68333, 0.18361, 0, 0.74333], + "87": [0, 0.68333, 0.18361, 0, 0.99888], + "88": [0, 0.68333, 0.15806, 0, 0.74333], + "89": [0, 0.68333, 0.19383, 0, 0.74333], + "90": [0, 0.68333, 0.14528, 0, 0.61333], + "91": [0.25, 0.75, 0.1875, 0, 0.30667], + "93": [0.25, 0.75, 0.10528, 0, 0.30667], + "94": [0, 0.69444, 0.06646, 0, 0.51111], + "95": [0.31, 0.12056, 0.09208, 0, 0.51111], + "97": [0, 0.43056, 0.07671, 0, 0.51111], + "98": [0, 0.69444, 0.06312, 0, 0.46], + "99": [0, 0.43056, 0.05653, 0, 0.46], + "100": [0, 0.69444, 0.10333, 0, 0.51111], + "101": [0, 0.43056, 0.07514, 0, 0.46], + "102": [0.19444, 0.69444, 0.21194, 0, 0.30667], + "103": [0.19444, 0.43056, 0.08847, 0, 0.46], + "104": [0, 0.69444, 0.07671, 0, 0.51111], + "105": [0, 0.65536, 0.1019, 0, 0.30667], + "106": [0.19444, 0.65536, 0.14467, 0, 0.30667], + "107": [0, 0.69444, 0.10764, 0, 0.46], + "108": [0, 0.69444, 0.10333, 0, 0.25555], + "109": [0, 0.43056, 0.07671, 0, 0.81777], + "110": [0, 0.43056, 0.07671, 0, 0.56222], + "111": [0, 0.43056, 0.06312, 0, 0.51111], + "112": [0.19444, 0.43056, 0.06312, 0, 0.51111], + "113": [0.19444, 0.43056, 0.08847, 0, 0.46], + "114": [0, 0.43056, 0.10764, 0, 0.42166], + "115": [0, 0.43056, 0.08208, 0, 0.40889], + "116": [0, 0.61508, 0.09486, 0, 0.33222], + "117": [0, 0.43056, 0.07671, 0, 0.53666], + "118": [0, 0.43056, 0.10764, 0, 0.46], + "119": [0, 0.43056, 0.10764, 0, 0.66444], + "120": [0, 0.43056, 0.12042, 0, 0.46389], + "121": [0.19444, 0.43056, 0.08847, 0, 0.48555], + "122": [0, 0.43056, 0.12292, 0, 0.40889], + "126": [0.35, 0.31786, 0.11585, 0, 0.51111], + "160": [0, 0, 0, 0, 0.25], + "168": [0, 0.66786, 0.10474, 0, 0.51111], + "176": [0, 0.69444, 0, 0, 0.83129], + "184": [0.17014, 0, 0, 0, 0.46], + "198": [0, 0.68333, 0.12028, 0, 0.88277], + "216": [0.04861, 0.73194, 0.09403, 0, 0.76666], + "223": [0.19444, 0.69444, 0.10514, 0, 0.53666], + "230": [0, 0.43056, 0.07514, 0, 0.71555], + "248": [0.09722, 0.52778, 0.09194, 0, 0.51111], + "338": [0, 0.68333, 0.12028, 0, 0.98499], + "339": [0, 0.43056, 0.07514, 0, 0.71555], + "710": [0, 0.69444, 0.06646, 0, 0.51111], + "711": [0, 0.62847, 0.08295, 0, 0.51111], + "713": [0, 0.56167, 0.10333, 0, 0.51111], + "714": [0, 0.69444, 0.09694, 0, 0.51111], + "715": [0, 0.69444, 0, 0, 0.51111], + "728": [0, 0.69444, 0.10806, 0, 0.51111], + "729": [0, 0.66786, 0.11752, 0, 0.30667], + "730": [0, 0.69444, 0, 0, 0.83129], + "732": [0, 0.66786, 0.11585, 0, 0.51111], + "733": [0, 0.69444, 0.1225, 0, 0.51111], + "915": [0, 0.68333, 0.13305, 0, 0.62722], + "916": [0, 0.68333, 0, 0, 0.81777], + "920": [0, 0.68333, 0.09403, 0, 0.76666], + "923": [0, 0.68333, 0, 0, 0.69222], + "926": [0, 0.68333, 0.15294, 0, 0.66444], + "928": [0, 0.68333, 0.16389, 0, 0.74333], + "931": [0, 0.68333, 0.12028, 0, 0.71555], + "933": [0, 0.68333, 0.11111, 0, 0.76666], + "934": [0, 0.68333, 0.05986, 0, 0.71555], + "936": [0, 0.68333, 0.11111, 0, 0.76666], + "937": [0, 0.68333, 0.10257, 0, 0.71555], + "8211": [0, 0.43056, 0.09208, 0, 0.51111], + "8212": [0, 0.43056, 0.09208, 0, 1.02222], + "8216": [0, 0.69444, 0.12417, 0, 0.30667], + "8217": [0, 0.69444, 0.12417, 0, 0.30667], + "8220": [0, 0.69444, 0.1685, 0, 0.51444], + "8221": [0, 0.69444, 0.06961, 0, 0.51444], + "8463": [0, 0.68889, 0, 0, 0.54028] + }, + "Main-Regular": { + "32": [0, 0, 0, 0, 0.25], + "33": [0, 0.69444, 0, 0, 0.27778], + "34": [0, 0.69444, 0, 0, 0.5], + "35": [0.19444, 0.69444, 0, 0, 0.83334], + "36": [0.05556, 0.75, 0, 0, 0.5], + "37": [0.05556, 0.75, 0, 0, 0.83334], + "38": [0, 0.69444, 0, 0, 0.77778], + "39": [0, 0.69444, 0, 0, 0.27778], + "40": [0.25, 0.75, 0, 0, 0.38889], + "41": [0.25, 0.75, 0, 0, 0.38889], + "42": [0, 0.75, 0, 0, 0.5], + "43": [0.08333, 0.58333, 0, 0, 0.77778], + "44": [0.19444, 0.10556, 0, 0, 0.27778], + "45": [0, 0.43056, 0, 0, 0.33333], + "46": [0, 0.10556, 0, 0, 0.27778], + "47": [0.25, 0.75, 0, 0, 0.5], + "48": [0, 0.64444, 0, 0, 0.5], + "49": [0, 0.64444, 0, 0, 0.5], + "50": [0, 0.64444, 0, 0, 0.5], + "51": [0, 0.64444, 0, 0, 0.5], + "52": [0, 0.64444, 0, 0, 0.5], + "53": [0, 0.64444, 0, 0, 0.5], + "54": [0, 0.64444, 0, 0, 0.5], + "55": [0, 0.64444, 0, 0, 0.5], + "56": [0, 0.64444, 0, 0, 0.5], + "57": [0, 0.64444, 0, 0, 0.5], + "58": [0, 0.43056, 0, 0, 0.27778], + "59": [0.19444, 0.43056, 0, 0, 0.27778], + "60": [0.0391, 0.5391, 0, 0, 0.77778], + "61": [-0.13313, 0.36687, 0, 0, 0.77778], + "62": [0.0391, 0.5391, 0, 0, 0.77778], + "63": [0, 0.69444, 0, 0, 0.47222], + "64": [0, 0.69444, 0, 0, 0.77778], + "65": [0, 0.68333, 0, 0, 0.75], + "66": [0, 0.68333, 0, 0, 0.70834], + "67": [0, 0.68333, 0, 0, 0.72222], + "68": [0, 0.68333, 0, 0, 0.76389], + "69": [0, 0.68333, 0, 0, 0.68056], + "70": [0, 0.68333, 0, 0, 0.65278], + "71": [0, 0.68333, 0, 0, 0.78472], + "72": [0, 0.68333, 0, 0, 0.75], + "73": [0, 0.68333, 0, 0, 0.36111], + "74": [0, 0.68333, 0, 0, 0.51389], + "75": [0, 0.68333, 0, 0, 0.77778], + "76": [0, 0.68333, 0, 0, 0.625], + "77": [0, 0.68333, 0, 0, 0.91667], + "78": [0, 0.68333, 0, 0, 0.75], + "79": [0, 0.68333, 0, 0, 0.77778], + "80": [0, 0.68333, 0, 0, 0.68056], + "81": [0.19444, 0.68333, 0, 0, 0.77778], + "82": [0, 0.68333, 0, 0, 0.73611], + "83": [0, 0.68333, 0, 0, 0.55556], + "84": [0, 0.68333, 0, 0, 0.72222], + "85": [0, 0.68333, 0, 0, 0.75], + "86": [0, 0.68333, 0.01389, 0, 0.75], + "87": [0, 0.68333, 0.01389, 0, 1.02778], + "88": [0, 0.68333, 0, 0, 0.75], + "89": [0, 0.68333, 0.025, 0, 0.75], + "90": [0, 0.68333, 0, 0, 0.61111], + "91": [0.25, 0.75, 0, 0, 0.27778], + "92": [0.25, 0.75, 0, 0, 0.5], + "93": [0.25, 0.75, 0, 0, 0.27778], + "94": [0, 0.69444, 0, 0, 0.5], + "95": [0.31, 0.12056, 0.02778, 0, 0.5], + "97": [0, 0.43056, 0, 0, 0.5], + "98": [0, 0.69444, 0, 0, 0.55556], + "99": [0, 0.43056, 0, 0, 0.44445], + "100": [0, 0.69444, 0, 0, 0.55556], + "101": [0, 0.43056, 0, 0, 0.44445], + "102": [0, 0.69444, 0.07778, 0, 0.30556], + "103": [0.19444, 0.43056, 0.01389, 0, 0.5], + "104": [0, 0.69444, 0, 0, 0.55556], + "105": [0, 0.66786, 0, 0, 0.27778], + "106": [0.19444, 0.66786, 0, 0, 0.30556], + "107": [0, 0.69444, 0, 0, 0.52778], + "108": [0, 0.69444, 0, 0, 0.27778], + "109": [0, 0.43056, 0, 0, 0.83334], + "110": [0, 0.43056, 0, 0, 0.55556], + "111": [0, 0.43056, 0, 0, 0.5], + "112": [0.19444, 0.43056, 0, 0, 0.55556], + "113": [0.19444, 0.43056, 0, 0, 0.52778], + "114": [0, 0.43056, 0, 0, 0.39167], + "115": [0, 0.43056, 0, 0, 0.39445], + "116": [0, 0.61508, 0, 0, 0.38889], + "117": [0, 0.43056, 0, 0, 0.55556], + "118": [0, 0.43056, 0.01389, 0, 0.52778], + "119": [0, 0.43056, 0.01389, 0, 0.72222], + "120": [0, 0.43056, 0, 0, 0.52778], + "121": [0.19444, 0.43056, 0.01389, 0, 0.52778], + "122": [0, 0.43056, 0, 0, 0.44445], + "123": [0.25, 0.75, 0, 0, 0.5], + "124": [0.25, 0.75, 0, 0, 0.27778], + "125": [0.25, 0.75, 0, 0, 0.5], + "126": [0.35, 0.31786, 0, 0, 0.5], + "160": [0, 0, 0, 0, 0.25], + "163": [0, 0.69444, 0, 0, 0.76909], + "167": [0.19444, 0.69444, 0, 0, 0.44445], + "168": [0, 0.66786, 0, 0, 0.5], + "172": [0, 0.43056, 0, 0, 0.66667], + "176": [0, 0.69444, 0, 0, 0.75], + "177": [0.08333, 0.58333, 0, 0, 0.77778], + "182": [0.19444, 0.69444, 0, 0, 0.61111], + "184": [0.17014, 0, 0, 0, 0.44445], + "198": [0, 0.68333, 0, 0, 0.90278], + "215": [0.08333, 0.58333, 0, 0, 0.77778], + "216": [0.04861, 0.73194, 0, 0, 0.77778], + "223": [0, 0.69444, 0, 0, 0.5], + "230": [0, 0.43056, 0, 0, 0.72222], + "247": [0.08333, 0.58333, 0, 0, 0.77778], + "248": [0.09722, 0.52778, 0, 0, 0.5], + "305": [0, 0.43056, 0, 0, 0.27778], + "338": [0, 0.68333, 0, 0, 1.01389], + "339": [0, 0.43056, 0, 0, 0.77778], + "567": [0.19444, 0.43056, 0, 0, 0.30556], + "710": [0, 0.69444, 0, 0, 0.5], + "711": [0, 0.62847, 0, 0, 0.5], + "713": [0, 0.56778, 0, 0, 0.5], + "714": [0, 0.69444, 0, 0, 0.5], + "715": [0, 0.69444, 0, 0, 0.5], + "728": [0, 0.69444, 0, 0, 0.5], + "729": [0, 0.66786, 0, 0, 0.27778], + "730": [0, 0.69444, 0, 0, 0.75], + "732": [0, 0.66786, 0, 0, 0.5], + "733": [0, 0.69444, 0, 0, 0.5], + "915": [0, 0.68333, 0, 0, 0.625], + "916": [0, 0.68333, 0, 0, 0.83334], + "920": [0, 0.68333, 0, 0, 0.77778], + "923": [0, 0.68333, 0, 0, 0.69445], + "926": [0, 0.68333, 0, 0, 0.66667], + "928": [0, 0.68333, 0, 0, 0.75], + "931": [0, 0.68333, 0, 0, 0.72222], + "933": [0, 0.68333, 0, 0, 0.77778], + "934": [0, 0.68333, 0, 0, 0.72222], + "936": [0, 0.68333, 0, 0, 0.77778], + "937": [0, 0.68333, 0, 0, 0.72222], + "8211": [0, 0.43056, 0.02778, 0, 0.5], + "8212": [0, 0.43056, 0.02778, 0, 1], + "8216": [0, 0.69444, 0, 0, 0.27778], + "8217": [0, 0.69444, 0, 0, 0.27778], + "8220": [0, 0.69444, 0, 0, 0.5], + "8221": [0, 0.69444, 0, 0, 0.5], + "8224": [0.19444, 0.69444, 0, 0, 0.44445], + "8225": [0.19444, 0.69444, 0, 0, 0.44445], + "8230": [0, 0.123, 0, 0, 1.172], + "8242": [0, 0.55556, 0, 0, 0.275], + "8407": [0, 0.71444, 0.15382, 0, 0.5], + "8463": [0, 0.68889, 0, 0, 0.54028], + "8465": [0, 0.69444, 0, 0, 0.72222], + "8467": [0, 0.69444, 0, 0.11111, 0.41667], + "8472": [0.19444, 0.43056, 0, 0.11111, 0.63646], + "8476": [0, 0.69444, 0, 0, 0.72222], + "8501": [0, 0.69444, 0, 0, 0.61111], + "8592": [-0.13313, 0.36687, 0, 0, 1], + "8593": [0.19444, 0.69444, 0, 0, 0.5], + "8594": [-0.13313, 0.36687, 0, 0, 1], + "8595": [0.19444, 0.69444, 0, 0, 0.5], + "8596": [-0.13313, 0.36687, 0, 0, 1], + "8597": [0.25, 0.75, 0, 0, 0.5], + "8598": [0.19444, 0.69444, 0, 0, 1], + "8599": [0.19444, 0.69444, 0, 0, 1], + "8600": [0.19444, 0.69444, 0, 0, 1], + "8601": [0.19444, 0.69444, 0, 0, 1], + "8614": [0.011, 0.511, 0, 0, 1], + "8617": [0.011, 0.511, 0, 0, 1.126], + "8618": [0.011, 0.511, 0, 0, 1.126], + "8636": [-0.13313, 0.36687, 0, 0, 1], + "8637": [-0.13313, 0.36687, 0, 0, 1], + "8640": [-0.13313, 0.36687, 0, 0, 1], + "8641": [-0.13313, 0.36687, 0, 0, 1], + "8652": [0.011, 0.671, 0, 0, 1], + "8656": [-0.13313, 0.36687, 0, 0, 1], + "8657": [0.19444, 0.69444, 0, 0, 0.61111], + "8658": [-0.13313, 0.36687, 0, 0, 1], + "8659": [0.19444, 0.69444, 0, 0, 0.61111], + "8660": [-0.13313, 0.36687, 0, 0, 1], + "8661": [0.25, 0.75, 0, 0, 0.61111], + "8704": [0, 0.69444, 0, 0, 0.55556], + "8706": [0, 0.69444, 0.05556, 0.08334, 0.5309], + "8707": [0, 0.69444, 0, 0, 0.55556], + "8709": [0.05556, 0.75, 0, 0, 0.5], + "8711": [0, 0.68333, 0, 0, 0.83334], + "8712": [0.0391, 0.5391, 0, 0, 0.66667], + "8715": [0.0391, 0.5391, 0, 0, 0.66667], + "8722": [0.08333, 0.58333, 0, 0, 0.77778], + "8723": [0.08333, 0.58333, 0, 0, 0.77778], + "8725": [0.25, 0.75, 0, 0, 0.5], + "8726": [0.25, 0.75, 0, 0, 0.5], + "8727": [-0.03472, 0.46528, 0, 0, 0.5], + "8728": [-0.05555, 0.44445, 0, 0, 0.5], + "8729": [-0.05555, 0.44445, 0, 0, 0.5], + "8730": [0.2, 0.8, 0, 0, 0.83334], + "8733": [0, 0.43056, 0, 0, 0.77778], + "8734": [0, 0.43056, 0, 0, 1], + "8736": [0, 0.69224, 0, 0, 0.72222], + "8739": [0.25, 0.75, 0, 0, 0.27778], + "8741": [0.25, 0.75, 0, 0, 0.5], + "8743": [0, 0.55556, 0, 0, 0.66667], + "8744": [0, 0.55556, 0, 0, 0.66667], + "8745": [0, 0.55556, 0, 0, 0.66667], + "8746": [0, 0.55556, 0, 0, 0.66667], + "8747": [0.19444, 0.69444, 0.11111, 0, 0.41667], + "8764": [-0.13313, 0.36687, 0, 0, 0.77778], + "8768": [0.19444, 0.69444, 0, 0, 0.27778], + "8771": [-0.03625, 0.46375, 0, 0, 0.77778], + "8773": [-0.022, 0.589, 0, 0, 0.778], + "8776": [-0.01688, 0.48312, 0, 0, 0.77778], + "8781": [-0.03625, 0.46375, 0, 0, 0.77778], + "8784": [-0.133, 0.673, 0, 0, 0.778], + "8801": [-0.03625, 0.46375, 0, 0, 0.77778], + "8804": [0.13597, 0.63597, 0, 0, 0.77778], + "8805": [0.13597, 0.63597, 0, 0, 0.77778], + "8810": [0.0391, 0.5391, 0, 0, 1], + "8811": [0.0391, 0.5391, 0, 0, 1], + "8826": [0.0391, 0.5391, 0, 0, 0.77778], + "8827": [0.0391, 0.5391, 0, 0, 0.77778], + "8834": [0.0391, 0.5391, 0, 0, 0.77778], + "8835": [0.0391, 0.5391, 0, 0, 0.77778], + "8838": [0.13597, 0.63597, 0, 0, 0.77778], + "8839": [0.13597, 0.63597, 0, 0, 0.77778], + "8846": [0, 0.55556, 0, 0, 0.66667], + "8849": [0.13597, 0.63597, 0, 0, 0.77778], + "8850": [0.13597, 0.63597, 0, 0, 0.77778], + "8851": [0, 0.55556, 0, 0, 0.66667], + "8852": [0, 0.55556, 0, 0, 0.66667], + "8853": [0.08333, 0.58333, 0, 0, 0.77778], + "8854": [0.08333, 0.58333, 0, 0, 0.77778], + "8855": [0.08333, 0.58333, 0, 0, 0.77778], + "8856": [0.08333, 0.58333, 0, 0, 0.77778], + "8857": [0.08333, 0.58333, 0, 0, 0.77778], + "8866": [0, 0.69444, 0, 0, 0.61111], + "8867": [0, 0.69444, 0, 0, 0.61111], + "8868": [0, 0.69444, 0, 0, 0.77778], + "8869": [0, 0.69444, 0, 0, 0.77778], + "8872": [0.249, 0.75, 0, 0, 0.867], + "8900": [-0.05555, 0.44445, 0, 0, 0.5], + "8901": [-0.05555, 0.44445, 0, 0, 0.27778], + "8902": [-0.03472, 0.46528, 0, 0, 0.5], + "8904": [5e-3, 0.505, 0, 0, 0.9], + "8942": [0.03, 0.903, 0, 0, 0.278], + "8943": [-0.19, 0.313, 0, 0, 1.172], + "8945": [-0.1, 0.823, 0, 0, 1.282], + "8968": [0.25, 0.75, 0, 0, 0.44445], + "8969": [0.25, 0.75, 0, 0, 0.44445], + "8970": [0.25, 0.75, 0, 0, 0.44445], + "8971": [0.25, 0.75, 0, 0, 0.44445], + "8994": [-0.14236, 0.35764, 0, 0, 1], + "8995": [-0.14236, 0.35764, 0, 0, 1], + "9136": [0.244, 0.744, 0, 0, 0.412], + "9137": [0.244, 0.745, 0, 0, 0.412], + "9651": [0.19444, 0.69444, 0, 0, 0.88889], + "9657": [-0.03472, 0.46528, 0, 0, 0.5], + "9661": [0.19444, 0.69444, 0, 0, 0.88889], + "9667": [-0.03472, 0.46528, 0, 0, 0.5], + "9711": [0.19444, 0.69444, 0, 0, 1], + "9824": [0.12963, 0.69444, 0, 0, 0.77778], + "9825": [0.12963, 0.69444, 0, 0, 0.77778], + "9826": [0.12963, 0.69444, 0, 0, 0.77778], + "9827": [0.12963, 0.69444, 0, 0, 0.77778], + "9837": [0, 0.75, 0, 0, 0.38889], + "9838": [0.19444, 0.69444, 0, 0, 0.38889], + "9839": [0.19444, 0.69444, 0, 0, 0.38889], + "10216": [0.25, 0.75, 0, 0, 0.38889], + "10217": [0.25, 0.75, 0, 0, 0.38889], + "10222": [0.244, 0.744, 0, 0, 0.412], + "10223": [0.244, 0.745, 0, 0, 0.412], + "10229": [0.011, 0.511, 0, 0, 1.609], + "10230": [0.011, 0.511, 0, 0, 1.638], + "10231": [0.011, 0.511, 0, 0, 1.859], + "10232": [0.024, 0.525, 0, 0, 1.609], + "10233": [0.024, 0.525, 0, 0, 1.638], + "10234": [0.024, 0.525, 0, 0, 1.858], + "10236": [0.011, 0.511, 0, 0, 1.638], + "10815": [0, 0.68333, 0, 0, 0.75], + "10927": [0.13597, 0.63597, 0, 0, 0.77778], + "10928": [0.13597, 0.63597, 0, 0, 0.77778], + "57376": [0.19444, 0.69444, 0, 0, 0] + }, + "Math-BoldItalic": { + "32": [0, 0, 0, 0, 0.25], + "48": [0, 0.44444, 0, 0, 0.575], + "49": [0, 0.44444, 0, 0, 0.575], + "50": [0, 0.44444, 0, 0, 0.575], + "51": [0.19444, 0.44444, 0, 0, 0.575], + "52": [0.19444, 0.44444, 0, 0, 0.575], + "53": [0.19444, 0.44444, 0, 0, 0.575], + "54": [0, 0.64444, 0, 0, 0.575], + "55": [0.19444, 0.44444, 0, 0, 0.575], + "56": [0, 0.64444, 0, 0, 0.575], + "57": [0.19444, 0.44444, 0, 0, 0.575], + "65": [0, 0.68611, 0, 0, 0.86944], + "66": [0, 0.68611, 0.04835, 0, 0.8664], + "67": [0, 0.68611, 0.06979, 0, 0.81694], + "68": [0, 0.68611, 0.03194, 0, 0.93812], + "69": [0, 0.68611, 0.05451, 0, 0.81007], + "70": [0, 0.68611, 0.15972, 0, 0.68889], + "71": [0, 0.68611, 0, 0, 0.88673], + "72": [0, 0.68611, 0.08229, 0, 0.98229], + "73": [0, 0.68611, 0.07778, 0, 0.51111], + "74": [0, 0.68611, 0.10069, 0, 0.63125], + "75": [0, 0.68611, 0.06979, 0, 0.97118], + "76": [0, 0.68611, 0, 0, 0.75555], + "77": [0, 0.68611, 0.11424, 0, 1.14201], + "78": [0, 0.68611, 0.11424, 0, 0.95034], + "79": [0, 0.68611, 0.03194, 0, 0.83666], + "80": [0, 0.68611, 0.15972, 0, 0.72309], + "81": [0.19444, 0.68611, 0, 0, 0.86861], + "82": [0, 0.68611, 421e-5, 0, 0.87235], + "83": [0, 0.68611, 0.05382, 0, 0.69271], + "84": [0, 0.68611, 0.15972, 0, 0.63663], + "85": [0, 0.68611, 0.11424, 0, 0.80027], + "86": [0, 0.68611, 0.25555, 0, 0.67778], + "87": [0, 0.68611, 0.15972, 0, 1.09305], + "88": [0, 0.68611, 0.07778, 0, 0.94722], + "89": [0, 0.68611, 0.25555, 0, 0.67458], + "90": [0, 0.68611, 0.06979, 0, 0.77257], + "97": [0, 0.44444, 0, 0, 0.63287], + "98": [0, 0.69444, 0, 0, 0.52083], + "99": [0, 0.44444, 0, 0, 0.51342], + "100": [0, 0.69444, 0, 0, 0.60972], + "101": [0, 0.44444, 0, 0, 0.55361], + "102": [0.19444, 0.69444, 0.11042, 0, 0.56806], + "103": [0.19444, 0.44444, 0.03704, 0, 0.5449], + "104": [0, 0.69444, 0, 0, 0.66759], + "105": [0, 0.69326, 0, 0, 0.4048], + "106": [0.19444, 0.69326, 0.0622, 0, 0.47083], + "107": [0, 0.69444, 0.01852, 0, 0.6037], + "108": [0, 0.69444, 88e-4, 0, 0.34815], + "109": [0, 0.44444, 0, 0, 1.0324], + "110": [0, 0.44444, 0, 0, 0.71296], + "111": [0, 0.44444, 0, 0, 0.58472], + "112": [0.19444, 0.44444, 0, 0, 0.60092], + "113": [0.19444, 0.44444, 0.03704, 0, 0.54213], + "114": [0, 0.44444, 0.03194, 0, 0.5287], + "115": [0, 0.44444, 0, 0, 0.53125], + "116": [0, 0.63492, 0, 0, 0.41528], + "117": [0, 0.44444, 0, 0, 0.68102], + "118": [0, 0.44444, 0.03704, 0, 0.56666], + "119": [0, 0.44444, 0.02778, 0, 0.83148], + "120": [0, 0.44444, 0, 0, 0.65903], + "121": [0.19444, 0.44444, 0.03704, 0, 0.59028], + "122": [0, 0.44444, 0.04213, 0, 0.55509], + "160": [0, 0, 0, 0, 0.25], + "915": [0, 0.68611, 0.15972, 0, 0.65694], + "916": [0, 0.68611, 0, 0, 0.95833], + "920": [0, 0.68611, 0.03194, 0, 0.86722], + "923": [0, 0.68611, 0, 0, 0.80555], + "926": [0, 0.68611, 0.07458, 0, 0.84125], + "928": [0, 0.68611, 0.08229, 0, 0.98229], + "931": [0, 0.68611, 0.05451, 0, 0.88507], + "933": [0, 0.68611, 0.15972, 0, 0.67083], + "934": [0, 0.68611, 0, 0, 0.76666], + "936": [0, 0.68611, 0.11653, 0, 0.71402], + "937": [0, 0.68611, 0.04835, 0, 0.8789], + "945": [0, 0.44444, 0, 0, 0.76064], + "946": [0.19444, 0.69444, 0.03403, 0, 0.65972], + "947": [0.19444, 0.44444, 0.06389, 0, 0.59003], + "948": [0, 0.69444, 0.03819, 0, 0.52222], + "949": [0, 0.44444, 0, 0, 0.52882], + "950": [0.19444, 0.69444, 0.06215, 0, 0.50833], + "951": [0.19444, 0.44444, 0.03704, 0, 0.6], + "952": [0, 0.69444, 0.03194, 0, 0.5618], + "953": [0, 0.44444, 0, 0, 0.41204], + "954": [0, 0.44444, 0, 0, 0.66759], + "955": [0, 0.69444, 0, 0, 0.67083], + "956": [0.19444, 0.44444, 0, 0, 0.70787], + "957": [0, 0.44444, 0.06898, 0, 0.57685], + "958": [0.19444, 0.69444, 0.03021, 0, 0.50833], + "959": [0, 0.44444, 0, 0, 0.58472], + "960": [0, 0.44444, 0.03704, 0, 0.68241], + "961": [0.19444, 0.44444, 0, 0, 0.6118], + "962": [0.09722, 0.44444, 0.07917, 0, 0.42361], + "963": [0, 0.44444, 0.03704, 0, 0.68588], + "964": [0, 0.44444, 0.13472, 0, 0.52083], + "965": [0, 0.44444, 0.03704, 0, 0.63055], + "966": [0.19444, 0.44444, 0, 0, 0.74722], + "967": [0.19444, 0.44444, 0, 0, 0.71805], + "968": [0.19444, 0.69444, 0.03704, 0, 0.75833], + "969": [0, 0.44444, 0.03704, 0, 0.71782], + "977": [0, 0.69444, 0, 0, 0.69155], + "981": [0.19444, 0.69444, 0, 0, 0.7125], + "982": [0, 0.44444, 0.03194, 0, 0.975], + "1009": [0.19444, 0.44444, 0, 0, 0.6118], + "1013": [0, 0.44444, 0, 0, 0.48333], + "57649": [0, 0.44444, 0, 0, 0.39352], + "57911": [0.19444, 0.44444, 0, 0, 0.43889] + }, + "Math-Italic": { + "32": [0, 0, 0, 0, 0.25], + "48": [0, 0.43056, 0, 0, 0.5], + "49": [0, 0.43056, 0, 0, 0.5], + "50": [0, 0.43056, 0, 0, 0.5], + "51": [0.19444, 0.43056, 0, 0, 0.5], + "52": [0.19444, 0.43056, 0, 0, 0.5], + "53": [0.19444, 0.43056, 0, 0, 0.5], + "54": [0, 0.64444, 0, 0, 0.5], + "55": [0.19444, 0.43056, 0, 0, 0.5], + "56": [0, 0.64444, 0, 0, 0.5], + "57": [0.19444, 0.43056, 0, 0, 0.5], + "65": [0, 0.68333, 0, 0.13889, 0.75], + "66": [0, 0.68333, 0.05017, 0.08334, 0.75851], + "67": [0, 0.68333, 0.07153, 0.08334, 0.71472], + "68": [0, 0.68333, 0.02778, 0.05556, 0.82792], + "69": [0, 0.68333, 0.05764, 0.08334, 0.7382], + "70": [0, 0.68333, 0.13889, 0.08334, 0.64306], + "71": [0, 0.68333, 0, 0.08334, 0.78625], + "72": [0, 0.68333, 0.08125, 0.05556, 0.83125], + "73": [0, 0.68333, 0.07847, 0.11111, 0.43958], + "74": [0, 0.68333, 0.09618, 0.16667, 0.55451], + "75": [0, 0.68333, 0.07153, 0.05556, 0.84931], + "76": [0, 0.68333, 0, 0.02778, 0.68056], + "77": [0, 0.68333, 0.10903, 0.08334, 0.97014], + "78": [0, 0.68333, 0.10903, 0.08334, 0.80347], + "79": [0, 0.68333, 0.02778, 0.08334, 0.76278], + "80": [0, 0.68333, 0.13889, 0.08334, 0.64201], + "81": [0.19444, 0.68333, 0, 0.08334, 0.79056], + "82": [0, 0.68333, 773e-5, 0.08334, 0.75929], + "83": [0, 0.68333, 0.05764, 0.08334, 0.6132], + "84": [0, 0.68333, 0.13889, 0.08334, 0.58438], + "85": [0, 0.68333, 0.10903, 0.02778, 0.68278], + "86": [0, 0.68333, 0.22222, 0, 0.58333], + "87": [0, 0.68333, 0.13889, 0, 0.94445], + "88": [0, 0.68333, 0.07847, 0.08334, 0.82847], + "89": [0, 0.68333, 0.22222, 0, 0.58056], + "90": [0, 0.68333, 0.07153, 0.08334, 0.68264], + "97": [0, 0.43056, 0, 0, 0.52859], + "98": [0, 0.69444, 0, 0, 0.42917], + "99": [0, 0.43056, 0, 0.05556, 0.43276], + "100": [0, 0.69444, 0, 0.16667, 0.52049], + "101": [0, 0.43056, 0, 0.05556, 0.46563], + "102": [0.19444, 0.69444, 0.10764, 0.16667, 0.48959], + "103": [0.19444, 0.43056, 0.03588, 0.02778, 0.47697], + "104": [0, 0.69444, 0, 0, 0.57616], + "105": [0, 0.65952, 0, 0, 0.34451], + "106": [0.19444, 0.65952, 0.05724, 0, 0.41181], + "107": [0, 0.69444, 0.03148, 0, 0.5206], + "108": [0, 0.69444, 0.01968, 0.08334, 0.29838], + "109": [0, 0.43056, 0, 0, 0.87801], + "110": [0, 0.43056, 0, 0, 0.60023], + "111": [0, 0.43056, 0, 0.05556, 0.48472], + "112": [0.19444, 0.43056, 0, 0.08334, 0.50313], + "113": [0.19444, 0.43056, 0.03588, 0.08334, 0.44641], + "114": [0, 0.43056, 0.02778, 0.05556, 0.45116], + "115": [0, 0.43056, 0, 0.05556, 0.46875], + "116": [0, 0.61508, 0, 0.08334, 0.36111], + "117": [0, 0.43056, 0, 0.02778, 0.57246], + "118": [0, 0.43056, 0.03588, 0.02778, 0.48472], + "119": [0, 0.43056, 0.02691, 0.08334, 0.71592], + "120": [0, 0.43056, 0, 0.02778, 0.57153], + "121": [0.19444, 0.43056, 0.03588, 0.05556, 0.49028], + "122": [0, 0.43056, 0.04398, 0.05556, 0.46505], + "160": [0, 0, 0, 0, 0.25], + "915": [0, 0.68333, 0.13889, 0.08334, 0.61528], + "916": [0, 0.68333, 0, 0.16667, 0.83334], + "920": [0, 0.68333, 0.02778, 0.08334, 0.76278], + "923": [0, 0.68333, 0, 0.16667, 0.69445], + "926": [0, 0.68333, 0.07569, 0.08334, 0.74236], + "928": [0, 0.68333, 0.08125, 0.05556, 0.83125], + "931": [0, 0.68333, 0.05764, 0.08334, 0.77986], + "933": [0, 0.68333, 0.13889, 0.05556, 0.58333], + "934": [0, 0.68333, 0, 0.08334, 0.66667], + "936": [0, 0.68333, 0.11, 0.05556, 0.61222], + "937": [0, 0.68333, 0.05017, 0.08334, 0.7724], + "945": [0, 0.43056, 37e-4, 0.02778, 0.6397], + "946": [0.19444, 0.69444, 0.05278, 0.08334, 0.56563], + "947": [0.19444, 0.43056, 0.05556, 0, 0.51773], + "948": [0, 0.69444, 0.03785, 0.05556, 0.44444], + "949": [0, 0.43056, 0, 0.08334, 0.46632], + "950": [0.19444, 0.69444, 0.07378, 0.08334, 0.4375], + "951": [0.19444, 0.43056, 0.03588, 0.05556, 0.49653], + "952": [0, 0.69444, 0.02778, 0.08334, 0.46944], + "953": [0, 0.43056, 0, 0.05556, 0.35394], + "954": [0, 0.43056, 0, 0, 0.57616], + "955": [0, 0.69444, 0, 0, 0.58334], + "956": [0.19444, 0.43056, 0, 0.02778, 0.60255], + "957": [0, 0.43056, 0.06366, 0.02778, 0.49398], + "958": [0.19444, 0.69444, 0.04601, 0.11111, 0.4375], + "959": [0, 0.43056, 0, 0.05556, 0.48472], + "960": [0, 0.43056, 0.03588, 0, 0.57003], + "961": [0.19444, 0.43056, 0, 0.08334, 0.51702], + "962": [0.09722, 0.43056, 0.07986, 0.08334, 0.36285], + "963": [0, 0.43056, 0.03588, 0, 0.57141], + "964": [0, 0.43056, 0.1132, 0.02778, 0.43715], + "965": [0, 0.43056, 0.03588, 0.02778, 0.54028], + "966": [0.19444, 0.43056, 0, 0.08334, 0.65417], + "967": [0.19444, 0.43056, 0, 0.05556, 0.62569], + "968": [0.19444, 0.69444, 0.03588, 0.11111, 0.65139], + "969": [0, 0.43056, 0.03588, 0, 0.62245], + "977": [0, 0.69444, 0, 0.08334, 0.59144], + "981": [0.19444, 0.69444, 0, 0.08334, 0.59583], + "982": [0, 0.43056, 0.02778, 0, 0.82813], + "1009": [0.19444, 0.43056, 0, 0.08334, 0.51702], + "1013": [0, 0.43056, 0, 0.05556, 0.4059], + "57649": [0, 0.43056, 0, 0.02778, 0.32246], + "57911": [0.19444, 0.43056, 0, 0.08334, 0.38403] + }, + "SansSerif-Bold": { + "32": [0, 0, 0, 0, 0.25], + "33": [0, 0.69444, 0, 0, 0.36667], + "34": [0, 0.69444, 0, 0, 0.55834], + "35": [0.19444, 0.69444, 0, 0, 0.91667], + "36": [0.05556, 0.75, 0, 0, 0.55], + "37": [0.05556, 0.75, 0, 0, 1.02912], + "38": [0, 0.69444, 0, 0, 0.83056], + "39": [0, 0.69444, 0, 0, 0.30556], + "40": [0.25, 0.75, 0, 0, 0.42778], + "41": [0.25, 0.75, 0, 0, 0.42778], + "42": [0, 0.75, 0, 0, 0.55], + "43": [0.11667, 0.61667, 0, 0, 0.85556], + "44": [0.10556, 0.13056, 0, 0, 0.30556], + "45": [0, 0.45833, 0, 0, 0.36667], + "46": [0, 0.13056, 0, 0, 0.30556], + "47": [0.25, 0.75, 0, 0, 0.55], + "48": [0, 0.69444, 0, 0, 0.55], + "49": [0, 0.69444, 0, 0, 0.55], + "50": [0, 0.69444, 0, 0, 0.55], + "51": [0, 0.69444, 0, 0, 0.55], + "52": [0, 0.69444, 0, 0, 0.55], + "53": [0, 0.69444, 0, 0, 0.55], + "54": [0, 0.69444, 0, 0, 0.55], + "55": [0, 0.69444, 0, 0, 0.55], + "56": [0, 0.69444, 0, 0, 0.55], + "57": [0, 0.69444, 0, 0, 0.55], + "58": [0, 0.45833, 0, 0, 0.30556], + "59": [0.10556, 0.45833, 0, 0, 0.30556], + "61": [-0.09375, 0.40625, 0, 0, 0.85556], + "63": [0, 0.69444, 0, 0, 0.51945], + "64": [0, 0.69444, 0, 0, 0.73334], + "65": [0, 0.69444, 0, 0, 0.73334], + "66": [0, 0.69444, 0, 0, 0.73334], + "67": [0, 0.69444, 0, 0, 0.70278], + "68": [0, 0.69444, 0, 0, 0.79445], + "69": [0, 0.69444, 0, 0, 0.64167], + "70": [0, 0.69444, 0, 0, 0.61111], + "71": [0, 0.69444, 0, 0, 0.73334], + "72": [0, 0.69444, 0, 0, 0.79445], + "73": [0, 0.69444, 0, 0, 0.33056], + "74": [0, 0.69444, 0, 0, 0.51945], + "75": [0, 0.69444, 0, 0, 0.76389], + "76": [0, 0.69444, 0, 0, 0.58056], + "77": [0, 0.69444, 0, 0, 0.97778], + "78": [0, 0.69444, 0, 0, 0.79445], + "79": [0, 0.69444, 0, 0, 0.79445], + "80": [0, 0.69444, 0, 0, 0.70278], + "81": [0.10556, 0.69444, 0, 0, 0.79445], + "82": [0, 0.69444, 0, 0, 0.70278], + "83": [0, 0.69444, 0, 0, 0.61111], + "84": [0, 0.69444, 0, 0, 0.73334], + "85": [0, 0.69444, 0, 0, 0.76389], + "86": [0, 0.69444, 0.01528, 0, 0.73334], + "87": [0, 0.69444, 0.01528, 0, 1.03889], + "88": [0, 0.69444, 0, 0, 0.73334], + "89": [0, 0.69444, 0.0275, 0, 0.73334], + "90": [0, 0.69444, 0, 0, 0.67223], + "91": [0.25, 0.75, 0, 0, 0.34306], + "93": [0.25, 0.75, 0, 0, 0.34306], + "94": [0, 0.69444, 0, 0, 0.55], + "95": [0.35, 0.10833, 0.03056, 0, 0.55], + "97": [0, 0.45833, 0, 0, 0.525], + "98": [0, 0.69444, 0, 0, 0.56111], + "99": [0, 0.45833, 0, 0, 0.48889], + "100": [0, 0.69444, 0, 0, 0.56111], + "101": [0, 0.45833, 0, 0, 0.51111], + "102": [0, 0.69444, 0.07639, 0, 0.33611], + "103": [0.19444, 0.45833, 0.01528, 0, 0.55], + "104": [0, 0.69444, 0, 0, 0.56111], + "105": [0, 0.69444, 0, 0, 0.25556], + "106": [0.19444, 0.69444, 0, 0, 0.28611], + "107": [0, 0.69444, 0, 0, 0.53056], + "108": [0, 0.69444, 0, 0, 0.25556], + "109": [0, 0.45833, 0, 0, 0.86667], + "110": [0, 0.45833, 0, 0, 0.56111], + "111": [0, 0.45833, 0, 0, 0.55], + "112": [0.19444, 0.45833, 0, 0, 0.56111], + "113": [0.19444, 0.45833, 0, 0, 0.56111], + "114": [0, 0.45833, 0.01528, 0, 0.37222], + "115": [0, 0.45833, 0, 0, 0.42167], + "116": [0, 0.58929, 0, 0, 0.40417], + "117": [0, 0.45833, 0, 0, 0.56111], + "118": [0, 0.45833, 0.01528, 0, 0.5], + "119": [0, 0.45833, 0.01528, 0, 0.74445], + "120": [0, 0.45833, 0, 0, 0.5], + "121": [0.19444, 0.45833, 0.01528, 0, 0.5], + "122": [0, 0.45833, 0, 0, 0.47639], + "126": [0.35, 0.34444, 0, 0, 0.55], + "160": [0, 0, 0, 0, 0.25], + "168": [0, 0.69444, 0, 0, 0.55], + "176": [0, 0.69444, 0, 0, 0.73334], + "180": [0, 0.69444, 0, 0, 0.55], + "184": [0.17014, 0, 0, 0, 0.48889], + "305": [0, 0.45833, 0, 0, 0.25556], + "567": [0.19444, 0.45833, 0, 0, 0.28611], + "710": [0, 0.69444, 0, 0, 0.55], + "711": [0, 0.63542, 0, 0, 0.55], + "713": [0, 0.63778, 0, 0, 0.55], + "728": [0, 0.69444, 0, 0, 0.55], + "729": [0, 0.69444, 0, 0, 0.30556], + "730": [0, 0.69444, 0, 0, 0.73334], + "732": [0, 0.69444, 0, 0, 0.55], + "733": [0, 0.69444, 0, 0, 0.55], + "915": [0, 0.69444, 0, 0, 0.58056], + "916": [0, 0.69444, 0, 0, 0.91667], + "920": [0, 0.69444, 0, 0, 0.85556], + "923": [0, 0.69444, 0, 0, 0.67223], + "926": [0, 0.69444, 0, 0, 0.73334], + "928": [0, 0.69444, 0, 0, 0.79445], + "931": [0, 0.69444, 0, 0, 0.79445], + "933": [0, 0.69444, 0, 0, 0.85556], + "934": [0, 0.69444, 0, 0, 0.79445], + "936": [0, 0.69444, 0, 0, 0.85556], + "937": [0, 0.69444, 0, 0, 0.79445], + "8211": [0, 0.45833, 0.03056, 0, 0.55], + "8212": [0, 0.45833, 0.03056, 0, 1.10001], + "8216": [0, 0.69444, 0, 0, 0.30556], + "8217": [0, 0.69444, 0, 0, 0.30556], + "8220": [0, 0.69444, 0, 0, 0.55834], + "8221": [0, 0.69444, 0, 0, 0.55834] + }, + "SansSerif-Italic": { + "32": [0, 0, 0, 0, 0.25], + "33": [0, 0.69444, 0.05733, 0, 0.31945], + "34": [0, 0.69444, 316e-5, 0, 0.5], + "35": [0.19444, 0.69444, 0.05087, 0, 0.83334], + "36": [0.05556, 0.75, 0.11156, 0, 0.5], + "37": [0.05556, 0.75, 0.03126, 0, 0.83334], + "38": [0, 0.69444, 0.03058, 0, 0.75834], + "39": [0, 0.69444, 0.07816, 0, 0.27778], + "40": [0.25, 0.75, 0.13164, 0, 0.38889], + "41": [0.25, 0.75, 0.02536, 0, 0.38889], + "42": [0, 0.75, 0.11775, 0, 0.5], + "43": [0.08333, 0.58333, 0.02536, 0, 0.77778], + "44": [0.125, 0.08333, 0, 0, 0.27778], + "45": [0, 0.44444, 0.01946, 0, 0.33333], + "46": [0, 0.08333, 0, 0, 0.27778], + "47": [0.25, 0.75, 0.13164, 0, 0.5], + "48": [0, 0.65556, 0.11156, 0, 0.5], + "49": [0, 0.65556, 0.11156, 0, 0.5], + "50": [0, 0.65556, 0.11156, 0, 0.5], + "51": [0, 0.65556, 0.11156, 0, 0.5], + "52": [0, 0.65556, 0.11156, 0, 0.5], + "53": [0, 0.65556, 0.11156, 0, 0.5], + "54": [0, 0.65556, 0.11156, 0, 0.5], + "55": [0, 0.65556, 0.11156, 0, 0.5], + "56": [0, 0.65556, 0.11156, 0, 0.5], + "57": [0, 0.65556, 0.11156, 0, 0.5], + "58": [0, 0.44444, 0.02502, 0, 0.27778], + "59": [0.125, 0.44444, 0.02502, 0, 0.27778], + "61": [-0.13, 0.37, 0.05087, 0, 0.77778], + "63": [0, 0.69444, 0.11809, 0, 0.47222], + "64": [0, 0.69444, 0.07555, 0, 0.66667], + "65": [0, 0.69444, 0, 0, 0.66667], + "66": [0, 0.69444, 0.08293, 0, 0.66667], + "67": [0, 0.69444, 0.11983, 0, 0.63889], + "68": [0, 0.69444, 0.07555, 0, 0.72223], + "69": [0, 0.69444, 0.11983, 0, 0.59722], + "70": [0, 0.69444, 0.13372, 0, 0.56945], + "71": [0, 0.69444, 0.11983, 0, 0.66667], + "72": [0, 0.69444, 0.08094, 0, 0.70834], + "73": [0, 0.69444, 0.13372, 0, 0.27778], + "74": [0, 0.69444, 0.08094, 0, 0.47222], + "75": [0, 0.69444, 0.11983, 0, 0.69445], + "76": [0, 0.69444, 0, 0, 0.54167], + "77": [0, 0.69444, 0.08094, 0, 0.875], + "78": [0, 0.69444, 0.08094, 0, 0.70834], + "79": [0, 0.69444, 0.07555, 0, 0.73611], + "80": [0, 0.69444, 0.08293, 0, 0.63889], + "81": [0.125, 0.69444, 0.07555, 0, 0.73611], + "82": [0, 0.69444, 0.08293, 0, 0.64584], + "83": [0, 0.69444, 0.09205, 0, 0.55556], + "84": [0, 0.69444, 0.13372, 0, 0.68056], + "85": [0, 0.69444, 0.08094, 0, 0.6875], + "86": [0, 0.69444, 0.1615, 0, 0.66667], + "87": [0, 0.69444, 0.1615, 0, 0.94445], + "88": [0, 0.69444, 0.13372, 0, 0.66667], + "89": [0, 0.69444, 0.17261, 0, 0.66667], + "90": [0, 0.69444, 0.11983, 0, 0.61111], + "91": [0.25, 0.75, 0.15942, 0, 0.28889], + "93": [0.25, 0.75, 0.08719, 0, 0.28889], + "94": [0, 0.69444, 0.0799, 0, 0.5], + "95": [0.35, 0.09444, 0.08616, 0, 0.5], + "97": [0, 0.44444, 981e-5, 0, 0.48056], + "98": [0, 0.69444, 0.03057, 0, 0.51667], + "99": [0, 0.44444, 0.08336, 0, 0.44445], + "100": [0, 0.69444, 0.09483, 0, 0.51667], + "101": [0, 0.44444, 0.06778, 0, 0.44445], + "102": [0, 0.69444, 0.21705, 0, 0.30556], + "103": [0.19444, 0.44444, 0.10836, 0, 0.5], + "104": [0, 0.69444, 0.01778, 0, 0.51667], + "105": [0, 0.67937, 0.09718, 0, 0.23889], + "106": [0.19444, 0.67937, 0.09162, 0, 0.26667], + "107": [0, 0.69444, 0.08336, 0, 0.48889], + "108": [0, 0.69444, 0.09483, 0, 0.23889], + "109": [0, 0.44444, 0.01778, 0, 0.79445], + "110": [0, 0.44444, 0.01778, 0, 0.51667], + "111": [0, 0.44444, 0.06613, 0, 0.5], + "112": [0.19444, 0.44444, 0.0389, 0, 0.51667], + "113": [0.19444, 0.44444, 0.04169, 0, 0.51667], + "114": [0, 0.44444, 0.10836, 0, 0.34167], + "115": [0, 0.44444, 0.0778, 0, 0.38333], + "116": [0, 0.57143, 0.07225, 0, 0.36111], + "117": [0, 0.44444, 0.04169, 0, 0.51667], + "118": [0, 0.44444, 0.10836, 0, 0.46111], + "119": [0, 0.44444, 0.10836, 0, 0.68334], + "120": [0, 0.44444, 0.09169, 0, 0.46111], + "121": [0.19444, 0.44444, 0.10836, 0, 0.46111], + "122": [0, 0.44444, 0.08752, 0, 0.43472], + "126": [0.35, 0.32659, 0.08826, 0, 0.5], + "160": [0, 0, 0, 0, 0.25], + "168": [0, 0.67937, 0.06385, 0, 0.5], + "176": [0, 0.69444, 0, 0, 0.73752], + "184": [0.17014, 0, 0, 0, 0.44445], + "305": [0, 0.44444, 0.04169, 0, 0.23889], + "567": [0.19444, 0.44444, 0.04169, 0, 0.26667], + "710": [0, 0.69444, 0.0799, 0, 0.5], + "711": [0, 0.63194, 0.08432, 0, 0.5], + "713": [0, 0.60889, 0.08776, 0, 0.5], + "714": [0, 0.69444, 0.09205, 0, 0.5], + "715": [0, 0.69444, 0, 0, 0.5], + "728": [0, 0.69444, 0.09483, 0, 0.5], + "729": [0, 0.67937, 0.07774, 0, 0.27778], + "730": [0, 0.69444, 0, 0, 0.73752], + "732": [0, 0.67659, 0.08826, 0, 0.5], + "733": [0, 0.69444, 0.09205, 0, 0.5], + "915": [0, 0.69444, 0.13372, 0, 0.54167], + "916": [0, 0.69444, 0, 0, 0.83334], + "920": [0, 0.69444, 0.07555, 0, 0.77778], + "923": [0, 0.69444, 0, 0, 0.61111], + "926": [0, 0.69444, 0.12816, 0, 0.66667], + "928": [0, 0.69444, 0.08094, 0, 0.70834], + "931": [0, 0.69444, 0.11983, 0, 0.72222], + "933": [0, 0.69444, 0.09031, 0, 0.77778], + "934": [0, 0.69444, 0.04603, 0, 0.72222], + "936": [0, 0.69444, 0.09031, 0, 0.77778], + "937": [0, 0.69444, 0.08293, 0, 0.72222], + "8211": [0, 0.44444, 0.08616, 0, 0.5], + "8212": [0, 0.44444, 0.08616, 0, 1], + "8216": [0, 0.69444, 0.07816, 0, 0.27778], + "8217": [0, 0.69444, 0.07816, 0, 0.27778], + "8220": [0, 0.69444, 0.14205, 0, 0.5], + "8221": [0, 0.69444, 316e-5, 0, 0.5] + }, + "SansSerif-Regular": { + "32": [0, 0, 0, 0, 0.25], + "33": [0, 0.69444, 0, 0, 0.31945], + "34": [0, 0.69444, 0, 0, 0.5], + "35": [0.19444, 0.69444, 0, 0, 0.83334], + "36": [0.05556, 0.75, 0, 0, 0.5], + "37": [0.05556, 0.75, 0, 0, 0.83334], + "38": [0, 0.69444, 0, 0, 0.75834], + "39": [0, 0.69444, 0, 0, 0.27778], + "40": [0.25, 0.75, 0, 0, 0.38889], + "41": [0.25, 0.75, 0, 0, 0.38889], + "42": [0, 0.75, 0, 0, 0.5], + "43": [0.08333, 0.58333, 0, 0, 0.77778], + "44": [0.125, 0.08333, 0, 0, 0.27778], + "45": [0, 0.44444, 0, 0, 0.33333], + "46": [0, 0.08333, 0, 0, 0.27778], + "47": [0.25, 0.75, 0, 0, 0.5], + "48": [0, 0.65556, 0, 0, 0.5], + "49": [0, 0.65556, 0, 0, 0.5], + "50": [0, 0.65556, 0, 0, 0.5], + "51": [0, 0.65556, 0, 0, 0.5], + "52": [0, 0.65556, 0, 0, 0.5], + "53": [0, 0.65556, 0, 0, 0.5], + "54": [0, 0.65556, 0, 0, 0.5], + "55": [0, 0.65556, 0, 0, 0.5], + "56": [0, 0.65556, 0, 0, 0.5], + "57": [0, 0.65556, 0, 0, 0.5], + "58": [0, 0.44444, 0, 0, 0.27778], + "59": [0.125, 0.44444, 0, 0, 0.27778], + "61": [-0.13, 0.37, 0, 0, 0.77778], + "63": [0, 0.69444, 0, 0, 0.47222], + "64": [0, 0.69444, 0, 0, 0.66667], + "65": [0, 0.69444, 0, 0, 0.66667], + "66": [0, 0.69444, 0, 0, 0.66667], + "67": [0, 0.69444, 0, 0, 0.63889], + "68": [0, 0.69444, 0, 0, 0.72223], + "69": [0, 0.69444, 0, 0, 0.59722], + "70": [0, 0.69444, 0, 0, 0.56945], + "71": [0, 0.69444, 0, 0, 0.66667], + "72": [0, 0.69444, 0, 0, 0.70834], + "73": [0, 0.69444, 0, 0, 0.27778], + "74": [0, 0.69444, 0, 0, 0.47222], + "75": [0, 0.69444, 0, 0, 0.69445], + "76": [0, 0.69444, 0, 0, 0.54167], + "77": [0, 0.69444, 0, 0, 0.875], + "78": [0, 0.69444, 0, 0, 0.70834], + "79": [0, 0.69444, 0, 0, 0.73611], + "80": [0, 0.69444, 0, 0, 0.63889], + "81": [0.125, 0.69444, 0, 0, 0.73611], + "82": [0, 0.69444, 0, 0, 0.64584], + "83": [0, 0.69444, 0, 0, 0.55556], + "84": [0, 0.69444, 0, 0, 0.68056], + "85": [0, 0.69444, 0, 0, 0.6875], + "86": [0, 0.69444, 0.01389, 0, 0.66667], + "87": [0, 0.69444, 0.01389, 0, 0.94445], + "88": [0, 0.69444, 0, 0, 0.66667], + "89": [0, 0.69444, 0.025, 0, 0.66667], + "90": [0, 0.69444, 0, 0, 0.61111], + "91": [0.25, 0.75, 0, 0, 0.28889], + "93": [0.25, 0.75, 0, 0, 0.28889], + "94": [0, 0.69444, 0, 0, 0.5], + "95": [0.35, 0.09444, 0.02778, 0, 0.5], + "97": [0, 0.44444, 0, 0, 0.48056], + "98": [0, 0.69444, 0, 0, 0.51667], + "99": [0, 0.44444, 0, 0, 0.44445], + "100": [0, 0.69444, 0, 0, 0.51667], + "101": [0, 0.44444, 0, 0, 0.44445], + "102": [0, 0.69444, 0.06944, 0, 0.30556], + "103": [0.19444, 0.44444, 0.01389, 0, 0.5], + "104": [0, 0.69444, 0, 0, 0.51667], + "105": [0, 0.67937, 0, 0, 0.23889], + "106": [0.19444, 0.67937, 0, 0, 0.26667], + "107": [0, 0.69444, 0, 0, 0.48889], + "108": [0, 0.69444, 0, 0, 0.23889], + "109": [0, 0.44444, 0, 0, 0.79445], + "110": [0, 0.44444, 0, 0, 0.51667], + "111": [0, 0.44444, 0, 0, 0.5], + "112": [0.19444, 0.44444, 0, 0, 0.51667], + "113": [0.19444, 0.44444, 0, 0, 0.51667], + "114": [0, 0.44444, 0.01389, 0, 0.34167], + "115": [0, 0.44444, 0, 0, 0.38333], + "116": [0, 0.57143, 0, 0, 0.36111], + "117": [0, 0.44444, 0, 0, 0.51667], + "118": [0, 0.44444, 0.01389, 0, 0.46111], + "119": [0, 0.44444, 0.01389, 0, 0.68334], + "120": [0, 0.44444, 0, 0, 0.46111], + "121": [0.19444, 0.44444, 0.01389, 0, 0.46111], + "122": [0, 0.44444, 0, 0, 0.43472], + "126": [0.35, 0.32659, 0, 0, 0.5], + "160": [0, 0, 0, 0, 0.25], + "168": [0, 0.67937, 0, 0, 0.5], + "176": [0, 0.69444, 0, 0, 0.66667], + "184": [0.17014, 0, 0, 0, 0.44445], + "305": [0, 0.44444, 0, 0, 0.23889], + "567": [0.19444, 0.44444, 0, 0, 0.26667], + "710": [0, 0.69444, 0, 0, 0.5], + "711": [0, 0.63194, 0, 0, 0.5], + "713": [0, 0.60889, 0, 0, 0.5], + "714": [0, 0.69444, 0, 0, 0.5], + "715": [0, 0.69444, 0, 0, 0.5], + "728": [0, 0.69444, 0, 0, 0.5], + "729": [0, 0.67937, 0, 0, 0.27778], + "730": [0, 0.69444, 0, 0, 0.66667], + "732": [0, 0.67659, 0, 0, 0.5], + "733": [0, 0.69444, 0, 0, 0.5], + "915": [0, 0.69444, 0, 0, 0.54167], + "916": [0, 0.69444, 0, 0, 0.83334], + "920": [0, 0.69444, 0, 0, 0.77778], + "923": [0, 0.69444, 0, 0, 0.61111], + "926": [0, 0.69444, 0, 0, 0.66667], + "928": [0, 0.69444, 0, 0, 0.70834], + "931": [0, 0.69444, 0, 0, 0.72222], + "933": [0, 0.69444, 0, 0, 0.77778], + "934": [0, 0.69444, 0, 0, 0.72222], + "936": [0, 0.69444, 0, 0, 0.77778], + "937": [0, 0.69444, 0, 0, 0.72222], + "8211": [0, 0.44444, 0.02778, 0, 0.5], + "8212": [0, 0.44444, 0.02778, 0, 1], + "8216": [0, 0.69444, 0, 0, 0.27778], + "8217": [0, 0.69444, 0, 0, 0.27778], + "8220": [0, 0.69444, 0, 0, 0.5], + "8221": [0, 0.69444, 0, 0, 0.5] + }, + "Script-Regular": { + "32": [0, 0, 0, 0, 0.25], + "65": [0, 0.7, 0.22925, 0, 0.80253], + "66": [0, 0.7, 0.04087, 0, 0.90757], + "67": [0, 0.7, 0.1689, 0, 0.66619], + "68": [0, 0.7, 0.09371, 0, 0.77443], + "69": [0, 0.7, 0.18583, 0, 0.56162], + "70": [0, 0.7, 0.13634, 0, 0.89544], + "71": [0, 0.7, 0.17322, 0, 0.60961], + "72": [0, 0.7, 0.29694, 0, 0.96919], + "73": [0, 0.7, 0.19189, 0, 0.80907], + "74": [0.27778, 0.7, 0.19189, 0, 1.05159], + "75": [0, 0.7, 0.31259, 0, 0.91364], + "76": [0, 0.7, 0.19189, 0, 0.87373], + "77": [0, 0.7, 0.15981, 0, 1.08031], + "78": [0, 0.7, 0.3525, 0, 0.9015], + "79": [0, 0.7, 0.08078, 0, 0.73787], + "80": [0, 0.7, 0.08078, 0, 1.01262], + "81": [0, 0.7, 0.03305, 0, 0.88282], + "82": [0, 0.7, 0.06259, 0, 0.85], + "83": [0, 0.7, 0.19189, 0, 0.86767], + "84": [0, 0.7, 0.29087, 0, 0.74697], + "85": [0, 0.7, 0.25815, 0, 0.79996], + "86": [0, 0.7, 0.27523, 0, 0.62204], + "87": [0, 0.7, 0.27523, 0, 0.80532], + "88": [0, 0.7, 0.26006, 0, 0.94445], + "89": [0, 0.7, 0.2939, 0, 0.70961], + "90": [0, 0.7, 0.24037, 0, 0.8212], + "160": [0, 0, 0, 0, 0.25] + }, + "Size1-Regular": { + "32": [0, 0, 0, 0, 0.25], + "40": [0.35001, 0.85, 0, 0, 0.45834], + "41": [0.35001, 0.85, 0, 0, 0.45834], + "47": [0.35001, 0.85, 0, 0, 0.57778], + "91": [0.35001, 0.85, 0, 0, 0.41667], + "92": [0.35001, 0.85, 0, 0, 0.57778], + "93": [0.35001, 0.85, 0, 0, 0.41667], + "123": [0.35001, 0.85, 0, 0, 0.58334], + "125": [0.35001, 0.85, 0, 0, 0.58334], + "160": [0, 0, 0, 0, 0.25], + "710": [0, 0.72222, 0, 0, 0.55556], + "732": [0, 0.72222, 0, 0, 0.55556], + "770": [0, 0.72222, 0, 0, 0.55556], + "771": [0, 0.72222, 0, 0, 0.55556], + "8214": [-99e-5, 0.601, 0, 0, 0.77778], + "8593": [1e-5, 0.6, 0, 0, 0.66667], + "8595": [1e-5, 0.6, 0, 0, 0.66667], + "8657": [1e-5, 0.6, 0, 0, 0.77778], + "8659": [1e-5, 0.6, 0, 0, 0.77778], + "8719": [0.25001, 0.75, 0, 0, 0.94445], + "8720": [0.25001, 0.75, 0, 0, 0.94445], + "8721": [0.25001, 0.75, 0, 0, 1.05556], + "8730": [0.35001, 0.85, 0, 0, 1], + "8739": [-599e-5, 0.606, 0, 0, 0.33333], + "8741": [-599e-5, 0.606, 0, 0, 0.55556], + "8747": [0.30612, 0.805, 0.19445, 0, 0.47222], + "8748": [0.306, 0.805, 0.19445, 0, 0.47222], + "8749": [0.306, 0.805, 0.19445, 0, 0.47222], + "8750": [0.30612, 0.805, 0.19445, 0, 0.47222], + "8896": [0.25001, 0.75, 0, 0, 0.83334], + "8897": [0.25001, 0.75, 0, 0, 0.83334], + "8898": [0.25001, 0.75, 0, 0, 0.83334], + "8899": [0.25001, 0.75, 0, 0, 0.83334], + "8968": [0.35001, 0.85, 0, 0, 0.47222], + "8969": [0.35001, 0.85, 0, 0, 0.47222], + "8970": [0.35001, 0.85, 0, 0, 0.47222], + "8971": [0.35001, 0.85, 0, 0, 0.47222], + "9168": [-99e-5, 0.601, 0, 0, 0.66667], + "10216": [0.35001, 0.85, 0, 0, 0.47222], + "10217": [0.35001, 0.85, 0, 0, 0.47222], + "10752": [0.25001, 0.75, 0, 0, 1.11111], + "10753": [0.25001, 0.75, 0, 0, 1.11111], + "10754": [0.25001, 0.75, 0, 0, 1.11111], + "10756": [0.25001, 0.75, 0, 0, 0.83334], + "10758": [0.25001, 0.75, 0, 0, 0.83334] + }, + "Size2-Regular": { + "32": [0, 0, 0, 0, 0.25], + "40": [0.65002, 1.15, 0, 0, 0.59722], + "41": [0.65002, 1.15, 0, 0, 0.59722], + "47": [0.65002, 1.15, 0, 0, 0.81111], + "91": [0.65002, 1.15, 0, 0, 0.47222], + "92": [0.65002, 1.15, 0, 0, 0.81111], + "93": [0.65002, 1.15, 0, 0, 0.47222], + "123": [0.65002, 1.15, 0, 0, 0.66667], + "125": [0.65002, 1.15, 0, 0, 0.66667], + "160": [0, 0, 0, 0, 0.25], + "710": [0, 0.75, 0, 0, 1], + "732": [0, 0.75, 0, 0, 1], + "770": [0, 0.75, 0, 0, 1], + "771": [0, 0.75, 0, 0, 1], + "8719": [0.55001, 1.05, 0, 0, 1.27778], + "8720": [0.55001, 1.05, 0, 0, 1.27778], + "8721": [0.55001, 1.05, 0, 0, 1.44445], + "8730": [0.65002, 1.15, 0, 0, 1], + "8747": [0.86225, 1.36, 0.44445, 0, 0.55556], + "8748": [0.862, 1.36, 0.44445, 0, 0.55556], + "8749": [0.862, 1.36, 0.44445, 0, 0.55556], + "8750": [0.86225, 1.36, 0.44445, 0, 0.55556], + "8896": [0.55001, 1.05, 0, 0, 1.11111], + "8897": [0.55001, 1.05, 0, 0, 1.11111], + "8898": [0.55001, 1.05, 0, 0, 1.11111], + "8899": [0.55001, 1.05, 0, 0, 1.11111], + "8968": [0.65002, 1.15, 0, 0, 0.52778], + "8969": [0.65002, 1.15, 0, 0, 0.52778], + "8970": [0.65002, 1.15, 0, 0, 0.52778], + "8971": [0.65002, 1.15, 0, 0, 0.52778], + "10216": [0.65002, 1.15, 0, 0, 0.61111], + "10217": [0.65002, 1.15, 0, 0, 0.61111], + "10752": [0.55001, 1.05, 0, 0, 1.51112], + "10753": [0.55001, 1.05, 0, 0, 1.51112], + "10754": [0.55001, 1.05, 0, 0, 1.51112], + "10756": [0.55001, 1.05, 0, 0, 1.11111], + "10758": [0.55001, 1.05, 0, 0, 1.11111] + }, + "Size3-Regular": { + "32": [0, 0, 0, 0, 0.25], + "40": [0.95003, 1.45, 0, 0, 0.73611], + "41": [0.95003, 1.45, 0, 0, 0.73611], + "47": [0.95003, 1.45, 0, 0, 1.04445], + "91": [0.95003, 1.45, 0, 0, 0.52778], + "92": [0.95003, 1.45, 0, 0, 1.04445], + "93": [0.95003, 1.45, 0, 0, 0.52778], + "123": [0.95003, 1.45, 0, 0, 0.75], + "125": [0.95003, 1.45, 0, 0, 0.75], + "160": [0, 0, 0, 0, 0.25], + "710": [0, 0.75, 0, 0, 1.44445], + "732": [0, 0.75, 0, 0, 1.44445], + "770": [0, 0.75, 0, 0, 1.44445], + "771": [0, 0.75, 0, 0, 1.44445], + "8730": [0.95003, 1.45, 0, 0, 1], + "8968": [0.95003, 1.45, 0, 0, 0.58334], + "8969": [0.95003, 1.45, 0, 0, 0.58334], + "8970": [0.95003, 1.45, 0, 0, 0.58334], + "8971": [0.95003, 1.45, 0, 0, 0.58334], + "10216": [0.95003, 1.45, 0, 0, 0.75], + "10217": [0.95003, 1.45, 0, 0, 0.75] + }, + "Size4-Regular": { + "32": [0, 0, 0, 0, 0.25], + "40": [1.25003, 1.75, 0, 0, 0.79167], + "41": [1.25003, 1.75, 0, 0, 0.79167], + "47": [1.25003, 1.75, 0, 0, 1.27778], + "91": [1.25003, 1.75, 0, 0, 0.58334], + "92": [1.25003, 1.75, 0, 0, 1.27778], + "93": [1.25003, 1.75, 0, 0, 0.58334], + "123": [1.25003, 1.75, 0, 0, 0.80556], + "125": [1.25003, 1.75, 0, 0, 0.80556], + "160": [0, 0, 0, 0, 0.25], + "710": [0, 0.825, 0, 0, 1.8889], + "732": [0, 0.825, 0, 0, 1.8889], + "770": [0, 0.825, 0, 0, 1.8889], + "771": [0, 0.825, 0, 0, 1.8889], + "8730": [1.25003, 1.75, 0, 0, 1], + "8968": [1.25003, 1.75, 0, 0, 0.63889], + "8969": [1.25003, 1.75, 0, 0, 0.63889], + "8970": [1.25003, 1.75, 0, 0, 0.63889], + "8971": [1.25003, 1.75, 0, 0, 0.63889], + "9115": [0.64502, 1.155, 0, 0, 0.875], + "9116": [1e-5, 0.6, 0, 0, 0.875], + "9117": [0.64502, 1.155, 0, 0, 0.875], + "9118": [0.64502, 1.155, 0, 0, 0.875], + "9119": [1e-5, 0.6, 0, 0, 0.875], + "9120": [0.64502, 1.155, 0, 0, 0.875], + "9121": [0.64502, 1.155, 0, 0, 0.66667], + "9122": [-99e-5, 0.601, 0, 0, 0.66667], + "9123": [0.64502, 1.155, 0, 0, 0.66667], + "9124": [0.64502, 1.155, 0, 0, 0.66667], + "9125": [-99e-5, 0.601, 0, 0, 0.66667], + "9126": [0.64502, 1.155, 0, 0, 0.66667], + "9127": [1e-5, 0.9, 0, 0, 0.88889], + "9128": [0.65002, 1.15, 0, 0, 0.88889], + "9129": [0.90001, 0, 0, 0, 0.88889], + "9130": [0, 0.3, 0, 0, 0.88889], + "9131": [1e-5, 0.9, 0, 0, 0.88889], + "9132": [0.65002, 1.15, 0, 0, 0.88889], + "9133": [0.90001, 0, 0, 0, 0.88889], + "9143": [0.88502, 0.915, 0, 0, 1.05556], + "10216": [1.25003, 1.75, 0, 0, 0.80556], + "10217": [1.25003, 1.75, 0, 0, 0.80556], + "57344": [-499e-5, 0.605, 0, 0, 1.05556], + "57345": [-499e-5, 0.605, 0, 0, 1.05556], + "57680": [0, 0.12, 0, 0, 0.45], + "57681": [0, 0.12, 0, 0, 0.45], + "57682": [0, 0.12, 0, 0, 0.45], + "57683": [0, 0.12, 0, 0, 0.45] + }, + "Typewriter-Regular": { + "32": [0, 0, 0, 0, 0.525], + "33": [0, 0.61111, 0, 0, 0.525], + "34": [0, 0.61111, 0, 0, 0.525], + "35": [0, 0.61111, 0, 0, 0.525], + "36": [0.08333, 0.69444, 0, 0, 0.525], + "37": [0.08333, 0.69444, 0, 0, 0.525], + "38": [0, 0.61111, 0, 0, 0.525], + "39": [0, 0.61111, 0, 0, 0.525], + "40": [0.08333, 0.69444, 0, 0, 0.525], + "41": [0.08333, 0.69444, 0, 0, 0.525], + "42": [0, 0.52083, 0, 0, 0.525], + "43": [-0.08056, 0.53055, 0, 0, 0.525], + "44": [0.13889, 0.125, 0, 0, 0.525], + "45": [-0.08056, 0.53055, 0, 0, 0.525], + "46": [0, 0.125, 0, 0, 0.525], + "47": [0.08333, 0.69444, 0, 0, 0.525], + "48": [0, 0.61111, 0, 0, 0.525], + "49": [0, 0.61111, 0, 0, 0.525], + "50": [0, 0.61111, 0, 0, 0.525], + "51": [0, 0.61111, 0, 0, 0.525], + "52": [0, 0.61111, 0, 0, 0.525], + "53": [0, 0.61111, 0, 0, 0.525], + "54": [0, 0.61111, 0, 0, 0.525], + "55": [0, 0.61111, 0, 0, 0.525], + "56": [0, 0.61111, 0, 0, 0.525], + "57": [0, 0.61111, 0, 0, 0.525], + "58": [0, 0.43056, 0, 0, 0.525], + "59": [0.13889, 0.43056, 0, 0, 0.525], + "60": [-0.05556, 0.55556, 0, 0, 0.525], + "61": [-0.19549, 0.41562, 0, 0, 0.525], + "62": [-0.05556, 0.55556, 0, 0, 0.525], + "63": [0, 0.61111, 0, 0, 0.525], + "64": [0, 0.61111, 0, 0, 0.525], + "65": [0, 0.61111, 0, 0, 0.525], + "66": [0, 0.61111, 0, 0, 0.525], + "67": [0, 0.61111, 0, 0, 0.525], + "68": [0, 0.61111, 0, 0, 0.525], + "69": [0, 0.61111, 0, 0, 0.525], + "70": [0, 0.61111, 0, 0, 0.525], + "71": [0, 0.61111, 0, 0, 0.525], + "72": [0, 0.61111, 0, 0, 0.525], + "73": [0, 0.61111, 0, 0, 0.525], + "74": [0, 0.61111, 0, 0, 0.525], + "75": [0, 0.61111, 0, 0, 0.525], + "76": [0, 0.61111, 0, 0, 0.525], + "77": [0, 0.61111, 0, 0, 0.525], + "78": [0, 0.61111, 0, 0, 0.525], + "79": [0, 0.61111, 0, 0, 0.525], + "80": [0, 0.61111, 0, 0, 0.525], + "81": [0.13889, 0.61111, 0, 0, 0.525], + "82": [0, 0.61111, 0, 0, 0.525], + "83": [0, 0.61111, 0, 0, 0.525], + "84": [0, 0.61111, 0, 0, 0.525], + "85": [0, 0.61111, 0, 0, 0.525], + "86": [0, 0.61111, 0, 0, 0.525], + "87": [0, 0.61111, 0, 0, 0.525], + "88": [0, 0.61111, 0, 0, 0.525], + "89": [0, 0.61111, 0, 0, 0.525], + "90": [0, 0.61111, 0, 0, 0.525], + "91": [0.08333, 0.69444, 0, 0, 0.525], + "92": [0.08333, 0.69444, 0, 0, 0.525], + "93": [0.08333, 0.69444, 0, 0, 0.525], + "94": [0, 0.61111, 0, 0, 0.525], + "95": [0.09514, 0, 0, 0, 0.525], + "96": [0, 0.61111, 0, 0, 0.525], + "97": [0, 0.43056, 0, 0, 0.525], + "98": [0, 0.61111, 0, 0, 0.525], + "99": [0, 0.43056, 0, 0, 0.525], + "100": [0, 0.61111, 0, 0, 0.525], + "101": [0, 0.43056, 0, 0, 0.525], + "102": [0, 0.61111, 0, 0, 0.525], + "103": [0.22222, 0.43056, 0, 0, 0.525], + "104": [0, 0.61111, 0, 0, 0.525], + "105": [0, 0.61111, 0, 0, 0.525], + "106": [0.22222, 0.61111, 0, 0, 0.525], + "107": [0, 0.61111, 0, 0, 0.525], + "108": [0, 0.61111, 0, 0, 0.525], + "109": [0, 0.43056, 0, 0, 0.525], + "110": [0, 0.43056, 0, 0, 0.525], + "111": [0, 0.43056, 0, 0, 0.525], + "112": [0.22222, 0.43056, 0, 0, 0.525], + "113": [0.22222, 0.43056, 0, 0, 0.525], + "114": [0, 0.43056, 0, 0, 0.525], + "115": [0, 0.43056, 0, 0, 0.525], + "116": [0, 0.55358, 0, 0, 0.525], + "117": [0, 0.43056, 0, 0, 0.525], + "118": [0, 0.43056, 0, 0, 0.525], + "119": [0, 0.43056, 0, 0, 0.525], + "120": [0, 0.43056, 0, 0, 0.525], + "121": [0.22222, 0.43056, 0, 0, 0.525], + "122": [0, 0.43056, 0, 0, 0.525], + "123": [0.08333, 0.69444, 0, 0, 0.525], + "124": [0.08333, 0.69444, 0, 0, 0.525], + "125": [0.08333, 0.69444, 0, 0, 0.525], + "126": [0, 0.61111, 0, 0, 0.525], + "127": [0, 0.61111, 0, 0, 0.525], + "160": [0, 0, 0, 0, 0.525], + "176": [0, 0.61111, 0, 0, 0.525], + "184": [0.19445, 0, 0, 0, 0.525], + "305": [0, 0.43056, 0, 0, 0.525], + "567": [0.22222, 0.43056, 0, 0, 0.525], + "711": [0, 0.56597, 0, 0, 0.525], + "713": [0, 0.56555, 0, 0, 0.525], + "714": [0, 0.61111, 0, 0, 0.525], + "715": [0, 0.61111, 0, 0, 0.525], + "728": [0, 0.61111, 0, 0, 0.525], + "730": [0, 0.61111, 0, 0, 0.525], + "770": [0, 0.61111, 0, 0, 0.525], + "771": [0, 0.61111, 0, 0, 0.525], + "776": [0, 0.61111, 0, 0, 0.525], + "915": [0, 0.61111, 0, 0, 0.525], + "916": [0, 0.61111, 0, 0, 0.525], + "920": [0, 0.61111, 0, 0, 0.525], + "923": [0, 0.61111, 0, 0, 0.525], + "926": [0, 0.61111, 0, 0, 0.525], + "928": [0, 0.61111, 0, 0, 0.525], + "931": [0, 0.61111, 0, 0, 0.525], + "933": [0, 0.61111, 0, 0, 0.525], + "934": [0, 0.61111, 0, 0, 0.525], + "936": [0, 0.61111, 0, 0, 0.525], + "937": [0, 0.61111, 0, 0, 0.525], + "8216": [0, 0.61111, 0, 0, 0.525], + "8217": [0, 0.61111, 0, 0, 0.525], + "8242": [0, 0.61111, 0, 0, 0.525], + "9251": [0.11111, 0.21944, 0, 0, 0.525] + } + }; + var sigmasAndXis = { + slant: [0.25, 0.25, 0.25], + // sigma1 + space: [0, 0, 0], + // sigma2 + stretch: [0, 0, 0], + // sigma3 + shrink: [0, 0, 0], + // sigma4 + xHeight: [0.431, 0.431, 0.431], + // sigma5 + quad: [1, 1.171, 1.472], + // sigma6 + extraSpace: [0, 0, 0], + // sigma7 + num1: [0.677, 0.732, 0.925], + // sigma8 + num2: [0.394, 0.384, 0.387], + // sigma9 + num3: [0.444, 0.471, 0.504], + // sigma10 + denom1: [0.686, 0.752, 1.025], + // sigma11 + denom2: [0.345, 0.344, 0.532], + // sigma12 + sup1: [0.413, 0.503, 0.504], + // sigma13 + sup2: [0.363, 0.431, 0.404], + // sigma14 + sup3: [0.289, 0.286, 0.294], + // sigma15 + sub1: [0.15, 0.143, 0.2], + // sigma16 + sub2: [0.247, 0.286, 0.4], + // sigma17 + supDrop: [0.386, 0.353, 0.494], + // sigma18 + subDrop: [0.05, 0.071, 0.1], + // sigma19 + delim1: [2.39, 1.7, 1.98], + // sigma20 + delim2: [1.01, 1.157, 1.42], + // sigma21 + axisHeight: [0.25, 0.25, 0.25], + // sigma22 + // These font metrics are extracted from TeX by using tftopl on cmex10.tfm; + // they correspond to the font parameters of the extension fonts (family 3). + // See the TeXbook, page 441. In AMSTeX, the extension fonts scale; to + // match cmex7, we'd use cmex7.tfm values for script and scriptscript + // values. + defaultRuleThickness: [0.04, 0.049, 0.049], + // xi8; cmex7: 0.049 + bigOpSpacing1: [0.111, 0.111, 0.111], + // xi9 + bigOpSpacing2: [0.166, 0.166, 0.166], + // xi10 + bigOpSpacing3: [0.2, 0.2, 0.2], + // xi11 + bigOpSpacing4: [0.6, 0.611, 0.611], + // xi12; cmex7: 0.611 + bigOpSpacing5: [0.1, 0.143, 0.143], + // xi13; cmex7: 0.143 + // The \sqrt rule width is taken from the height of the surd character. + // Since we use the same font at all sizes, this thickness doesn't scale. + sqrtRuleThickness: [0.04, 0.04, 0.04], + // This value determines how large a pt is, for metrics which are defined + // in terms of pts. + // This value is also used in katex.less; if you change it make sure the + // values match. + ptPerEm: [10, 10, 10], + // The space between adjacent `|` columns in an array definition. From + // `\showthe\doublerulesep` in LaTeX. Equals 2.0 / ptPerEm. + doubleRuleSep: [0.2, 0.2, 0.2], + // The width of separator lines in {array} environments. From + // `\showthe\arrayrulewidth` in LaTeX. Equals 0.4 / ptPerEm. + arrayRuleWidth: [0.04, 0.04, 0.04], + // Two values from LaTeX source2e: + fboxsep: [0.3, 0.3, 0.3], + // 3 pt / ptPerEm + fboxrule: [0.04, 0.04, 0.04] + // 0.4 pt / ptPerEm + }; + var extraCharacterMap = { + // Latin-1 + "Å": "A", + "Ð": "D", + "Þ": "o", + "å": "a", + "ð": "d", + "þ": "o", + // Cyrillic + "А": "A", + "Б": "B", + "В": "B", + "Г": "F", + "Д": "A", + "Е": "E", + "Ж": "K", + "З": "3", + "И": "N", + "Й": "N", + "К": "K", + "Л": "N", + "М": "M", + "Н": "H", + "О": "O", + "П": "N", + "Р": "P", + "С": "C", + "Т": "T", + "У": "y", + "Ф": "O", + "Х": "X", + "Ц": "U", + "Ч": "h", + "Ш": "W", + "Щ": "W", + "Ъ": "B", + "Ы": "X", + "Ь": "B", + "Э": "3", + "Ю": "X", + "Я": "R", + "а": "a", + "б": "b", + "в": "a", + "г": "r", + "д": "y", + "е": "e", + "ж": "m", + "з": "e", + "и": "n", + "й": "n", + "к": "n", + "л": "n", + "м": "m", + "н": "n", + "о": "o", + "п": "n", + "р": "p", + "с": "c", + "т": "o", + "у": "y", + "ф": "b", + "х": "x", + "ц": "n", + "ч": "n", + "ш": "w", + "щ": "w", + "ъ": "a", + "ы": "m", + "ь": "a", + "э": "e", + "ю": "m", + "я": "r" + }; + function setFontMetrics(fontName, metrics) { + fontMetricsData[fontName] = metrics; + } + function getCharacterMetrics(character2, font, mode) { + if (!fontMetricsData[font]) { + throw new Error("Font metrics not found for font: " + font + "."); + } + var ch2 = character2.charCodeAt(0); + var metrics = fontMetricsData[font][ch2]; + if (!metrics && character2[0] in extraCharacterMap) { + ch2 = extraCharacterMap[character2[0]].charCodeAt(0); + metrics = fontMetricsData[font][ch2]; + } + if (!metrics && mode === "text") { + if (supportedCodepoint(ch2)) { + metrics = fontMetricsData[font][77]; + } + } + if (metrics) { + return { + depth: metrics[0], + height: metrics[1], + italic: metrics[2], + skew: metrics[3], + width: metrics[4] + }; + } + } + var fontMetricsBySizeIndex = {}; + function getGlobalMetrics(size2) { + var sizeIndex; + if (size2 >= 5) { + sizeIndex = 0; + } else if (size2 >= 3) { + sizeIndex = 1; + } else { + sizeIndex = 2; + } + if (!fontMetricsBySizeIndex[sizeIndex]) { + var metrics = fontMetricsBySizeIndex[sizeIndex] = { + cssEmPerMu: sigmasAndXis.quad[sizeIndex] / 18 + }; + for (var key in sigmasAndXis) { + if (sigmasAndXis.hasOwnProperty(key)) { + metrics[key] = sigmasAndXis[key][sizeIndex]; + } + } + } + return fontMetricsBySizeIndex[sizeIndex]; + } + var sizeStyleMap = [ + // Each element contains [textsize, scriptsize, scriptscriptsize]. + // The size mappings are taken from TeX with \normalsize=10pt. + [1, 1, 1], + // size1: [5, 5, 5] \tiny + [2, 1, 1], + // size2: [6, 5, 5] + [3, 1, 1], + // size3: [7, 5, 5] \scriptsize + [4, 2, 1], + // size4: [8, 6, 5] \footnotesize + [5, 2, 1], + // size5: [9, 6, 5] \small + [6, 3, 1], + // size6: [10, 7, 5] \normalsize + [7, 4, 2], + // size7: [12, 8, 6] \large + [8, 6, 3], + // size8: [14.4, 10, 7] \Large + [9, 7, 6], + // size9: [17.28, 12, 10] \LARGE + [10, 8, 7], + // size10: [20.74, 14.4, 12] \huge + [11, 10, 9] + // size11: [24.88, 20.74, 17.28] \HUGE + ]; + var sizeMultipliers = [ + // fontMetrics.js:getGlobalMetrics also uses size indexes, so if + // you change size indexes, change that function. + 0.5, + 0.6, + 0.7, + 0.8, + 0.9, + 1, + 1.2, + 1.44, + 1.728, + 2.074, + 2.488 + ]; + var sizeAtStyle = function sizeAtStyle2(size2, style) { + return style.size < 2 ? size2 : sizeStyleMap[size2 - 1][style.size - 1]; + }; + class Options { + // A font family applies to a group of fonts (i.e. SansSerif), while a font + // represents a specific font (i.e. SansSerif Bold). + // See: https://tex.stackexchange.com/questions/22350/difference-between-textrm-and-mathrm + /** + * The base size index. + */ + constructor(data) { + this.style = void 0; + this.color = void 0; + this.size = void 0; + this.textSize = void 0; + this.phantom = void 0; + this.font = void 0; + this.fontFamily = void 0; + this.fontWeight = void 0; + this.fontShape = void 0; + this.sizeMultiplier = void 0; + this.maxSize = void 0; + this.minRuleThickness = void 0; + this._fontMetrics = void 0; + this.style = data.style; + this.color = data.color; + this.size = data.size || Options.BASESIZE; + this.textSize = data.textSize || this.size; + this.phantom = !!data.phantom; + this.font = data.font || ""; + this.fontFamily = data.fontFamily || ""; + this.fontWeight = data.fontWeight || ""; + this.fontShape = data.fontShape || ""; + this.sizeMultiplier = sizeMultipliers[this.size - 1]; + this.maxSize = data.maxSize; + this.minRuleThickness = data.minRuleThickness; + this._fontMetrics = void 0; + } + /** + * Returns a new options object with the same properties as "this". Properties + * from "extension" will be copied to the new options object. + */ + extend(extension2) { + var data = { + style: this.style, + size: this.size, + textSize: this.textSize, + color: this.color, + phantom: this.phantom, + font: this.font, + fontFamily: this.fontFamily, + fontWeight: this.fontWeight, + fontShape: this.fontShape, + maxSize: this.maxSize, + minRuleThickness: this.minRuleThickness + }; + for (var key in extension2) { + if (extension2.hasOwnProperty(key)) { + data[key] = extension2[key]; + } + } + return new Options(data); + } + /** + * Return an options object with the given style. If `this.style === style`, + * returns `this`. + */ + havingStyle(style) { + if (this.style === style) { + return this; + } else { + return this.extend({ + style, + size: sizeAtStyle(this.textSize, style) + }); + } + } + /** + * Return an options object with a cramped version of the current style. If + * the current style is cramped, returns `this`. + */ + havingCrampedStyle() { + return this.havingStyle(this.style.cramp()); + } + /** + * Return an options object with the given size and in at least `\textstyle`. + * Returns `this` if appropriate. + */ + havingSize(size2) { + if (this.size === size2 && this.textSize === size2) { + return this; + } else { + return this.extend({ + style: this.style.text(), + size: size2, + textSize: size2, + sizeMultiplier: sizeMultipliers[size2 - 1] + }); + } + } + /** + * Like `this.havingSize(BASESIZE).havingStyle(style)`. If `style` is omitted, + * changes to at least `\textstyle`. + */ + havingBaseStyle(style) { + style = style || this.style.text(); + var wantSize = sizeAtStyle(Options.BASESIZE, style); + if (this.size === wantSize && this.textSize === Options.BASESIZE && this.style === style) { + return this; + } else { + return this.extend({ + style, + size: wantSize + }); + } + } + /** + * Remove the effect of sizing changes such as \Huge. + * Keep the effect of the current style, such as \scriptstyle. + */ + havingBaseSizing() { + var size2; + switch (this.style.id) { + case 4: + case 5: + size2 = 3; + break; + case 6: + case 7: + size2 = 1; + break; + default: + size2 = 6; + } + return this.extend({ + style: this.style.text(), + size: size2 + }); + } + /** + * Create a new options object with the given color. + */ + withColor(color2) { + return this.extend({ + color: color2 + }); + } + /** + * Create a new options object with "phantom" set to true. + */ + withPhantom() { + return this.extend({ + phantom: true + }); + } + /** + * Creates a new options object with the given math font or old text font. + * @type {[type]} + */ + withFont(font) { + return this.extend({ + font + }); + } + /** + * Create a new options objects with the given fontFamily. + */ + withTextFontFamily(fontFamily) { + return this.extend({ + fontFamily, + font: "" + }); + } + /** + * Creates a new options object with the given font weight + */ + withTextFontWeight(fontWeight) { + return this.extend({ + fontWeight, + font: "" + }); + } + /** + * Creates a new options object with the given font weight + */ + withTextFontShape(fontShape) { + return this.extend({ + fontShape, + font: "" + }); + } + /** + * Return the CSS sizing classes required to switch from enclosing options + * `oldOptions` to `this`. Returns an array of classes. + */ + sizingClasses(oldOptions) { + if (oldOptions.size !== this.size) { + return ["sizing", "reset-size" + oldOptions.size, "size" + this.size]; + } else { + return []; + } + } + /** + * Return the CSS sizing classes required to switch to the base size. Like + * `this.havingSize(BASESIZE).sizingClasses(this)`. + */ + baseSizingClasses() { + if (this.size !== Options.BASESIZE) { + return ["sizing", "reset-size" + this.size, "size" + Options.BASESIZE]; + } else { + return []; + } + } + /** + * Return the font metrics for this size. + */ + fontMetrics() { + if (!this._fontMetrics) { + this._fontMetrics = getGlobalMetrics(this.size); + } + return this._fontMetrics; + } + /** + * Gets the CSS color of the current options object + */ + getColor() { + if (this.phantom) { + return "transparent"; + } else { + return this.color; + } + } + } + Options.BASESIZE = 6; + var ptPerUnit = { + // https://en.wikibooks.org/wiki/LaTeX/Lengths and + // https://tex.stackexchange.com/a/8263 + "pt": 1, + // TeX point + "mm": 7227 / 2540, + // millimeter + "cm": 7227 / 254, + // centimeter + "in": 72.27, + // inch + "bp": 803 / 800, + // big (PostScript) points + "pc": 12, + // pica + "dd": 1238 / 1157, + // didot + "cc": 14856 / 1157, + // cicero (12 didot) + "nd": 685 / 642, + // new didot + "nc": 1370 / 107, + // new cicero (12 new didot) + "sp": 1 / 65536, + // scaled point (TeX's internal smallest unit) + // https://tex.stackexchange.com/a/41371 + "px": 803 / 800 + // \pdfpxdimen defaults to 1 bp in pdfTeX and LuaTeX + }; + var relativeUnit = { + "ex": true, + "em": true, + "mu": true + }; + var validUnit = function validUnit2(unit2) { + if (typeof unit2 !== "string") { + unit2 = unit2.unit; + } + return unit2 in ptPerUnit || unit2 in relativeUnit || unit2 === "ex"; + }; + var calculateSize = function calculateSize2(sizeValue, options2) { + var scale; + if (sizeValue.unit in ptPerUnit) { + scale = ptPerUnit[sizeValue.unit] / options2.fontMetrics().ptPerEm / options2.sizeMultiplier; + } else if (sizeValue.unit === "mu") { + scale = options2.fontMetrics().cssEmPerMu; + } else { + var unitOptions; + if (options2.style.isTight()) { + unitOptions = options2.havingStyle(options2.style.text()); + } else { + unitOptions = options2; + } + if (sizeValue.unit === "ex") { + scale = unitOptions.fontMetrics().xHeight; + } else if (sizeValue.unit === "em") { + scale = unitOptions.fontMetrics().quad; + } else { + throw new ParseError("Invalid unit: '" + sizeValue.unit + "'"); + } + if (unitOptions !== options2) { + scale *= unitOptions.sizeMultiplier / options2.sizeMultiplier; + } + } + return Math.min(sizeValue.number * scale, options2.maxSize); + }; + var makeEm = function makeEm2(n) { + return +n.toFixed(4) + "em"; + }; + var createClass = function createClass2(classes2) { + return classes2.filter((cls) => cls).join(" "); + }; + var initNode = function initNode2(classes2, options2, style) { + this.classes = classes2 || []; + this.attributes = {}; + this.height = 0; + this.depth = 0; + this.maxFontSize = 0; + this.style = style || {}; + if (options2) { + if (options2.style.isTight()) { + this.classes.push("mtight"); + } + var color2 = options2.getColor(); + if (color2) { + this.style.color = color2; + } + } + }; + var toNode = function toNode2(tagName) { + var node2 = document.createElement(tagName); + node2.className = createClass(this.classes); + for (var style in this.style) { + if (this.style.hasOwnProperty(style)) { + node2.style[style] = this.style[style]; + } + } + for (var attr in this.attributes) { + if (this.attributes.hasOwnProperty(attr)) { + node2.setAttribute(attr, this.attributes[attr]); + } + } + for (var i2 = 0; i2 < this.children.length; i2++) { + node2.appendChild(this.children[i2].toNode()); + } + return node2; + }; + var toMarkup = function toMarkup2(tagName) { + var markup = "<" + tagName; + if (this.classes.length) { + markup += ' class="' + utils.escape(createClass(this.classes)) + '"'; + } + var styles2 = ""; + for (var style in this.style) { + if (this.style.hasOwnProperty(style)) { + styles2 += utils.hyphenate(style) + ":" + this.style[style] + ";"; + } + } + if (styles2) { + markup += ' style="' + utils.escape(styles2) + '"'; + } + for (var attr in this.attributes) { + if (this.attributes.hasOwnProperty(attr)) { + markup += " " + attr + '="' + utils.escape(this.attributes[attr]) + '"'; + } + } + markup += ">"; + for (var i2 = 0; i2 < this.children.length; i2++) { + markup += this.children[i2].toMarkup(); + } + markup += ""; + return markup; + }; + class Span { + constructor(classes2, children2, options2, style) { + this.children = void 0; + this.attributes = void 0; + this.classes = void 0; + this.height = void 0; + this.depth = void 0; + this.width = void 0; + this.maxFontSize = void 0; + this.style = void 0; + initNode.call(this, classes2, options2, style); + this.children = children2 || []; + } + /** + * Sets an arbitrary attribute on the span. Warning: use this wisely. Not + * all browsers support attributes the same, and having too many custom + * attributes is probably bad. + */ + setAttribute(attribute, value2) { + this.attributes[attribute] = value2; + } + hasClass(className) { + return utils.contains(this.classes, className); + } + toNode() { + return toNode.call(this, "span"); + } + toMarkup() { + return toMarkup.call(this, "span"); + } + } + class Anchor { + constructor(href, classes2, children2, options2) { + this.children = void 0; + this.attributes = void 0; + this.classes = void 0; + this.height = void 0; + this.depth = void 0; + this.maxFontSize = void 0; + this.style = void 0; + initNode.call(this, classes2, options2); + this.children = children2 || []; + this.setAttribute("href", href); + } + setAttribute(attribute, value2) { + this.attributes[attribute] = value2; + } + hasClass(className) { + return utils.contains(this.classes, className); + } + toNode() { + return toNode.call(this, "a"); + } + toMarkup() { + return toMarkup.call(this, "a"); + } + } + class Img { + constructor(src, alt, style) { + this.src = void 0; + this.alt = void 0; + this.classes = void 0; + this.height = void 0; + this.depth = void 0; + this.maxFontSize = void 0; + this.style = void 0; + this.alt = alt; + this.src = src; + this.classes = ["mord"]; + this.style = style; + } + hasClass(className) { + return utils.contains(this.classes, className); + } + toNode() { + var node2 = document.createElement("img"); + node2.src = this.src; + node2.alt = this.alt; + node2.className = "mord"; + for (var style in this.style) { + if (this.style.hasOwnProperty(style)) { + node2.style[style] = this.style[style]; + } + } + return node2; + } + toMarkup() { + var markup = "" + this.alt + " 0) { + span = document.createElement("span"); + span.style.marginRight = makeEm(this.italic); + } + if (this.classes.length > 0) { + span = span || document.createElement("span"); + span.className = createClass(this.classes); + } + for (var style in this.style) { + if (this.style.hasOwnProperty(style)) { + span = span || document.createElement("span"); + span.style[style] = this.style[style]; + } + } + if (span) { + span.appendChild(node2); + return span; + } else { + return node2; + } + } + /** + * Creates markup for a symbol node. + */ + toMarkup() { + var needsSpan = false; + var markup = " 0) { + styles2 += "margin-right:" + this.italic + "em;"; + } + for (var style in this.style) { + if (this.style.hasOwnProperty(style)) { + styles2 += utils.hyphenate(style) + ":" + this.style[style] + ";"; + } + } + if (styles2) { + needsSpan = true; + markup += ' style="' + utils.escape(styles2) + '"'; + } + var escaped = utils.escape(this.text); + if (needsSpan) { + markup += ">"; + markup += escaped; + markup += ""; + return markup; + } else { + return escaped; + } + } + } + class SvgNode { + constructor(children2, attributes) { + this.children = void 0; + this.attributes = void 0; + this.children = children2 || []; + this.attributes = attributes || {}; + } + toNode() { + var svgNS = "http://www.w3.org/2000/svg"; + var node2 = document.createElementNS(svgNS, "svg"); + for (var attr in this.attributes) { + if (Object.prototype.hasOwnProperty.call(this.attributes, attr)) { + node2.setAttribute(attr, this.attributes[attr]); + } + } + for (var i2 = 0; i2 < this.children.length; i2++) { + node2.appendChild(this.children[i2].toNode()); + } + return node2; + } + toMarkup() { + var markup = '"; + } else { + return ""; + } + } + } + class LineNode { + constructor(attributes) { + this.attributes = void 0; + this.attributes = attributes || {}; + } + toNode() { + var svgNS = "http://www.w3.org/2000/svg"; + var node2 = document.createElementNS(svgNS, "line"); + for (var attr in this.attributes) { + if (Object.prototype.hasOwnProperty.call(this.attributes, attr)) { + node2.setAttribute(attr, this.attributes[attr]); + } + } + return node2; + } + toMarkup() { + var markup = " but got " + String(group) + "."); + } + } + var ATOMS = { + "bin": 1, + "close": 1, + "inner": 1, + "open": 1, + "punct": 1, + "rel": 1 + }; + var NON_ATOMS = { + "accent-token": 1, + "mathord": 1, + "op-token": 1, + "spacing": 1, + "textord": 1 + }; + var symbols = { + "math": {}, + "text": {} + }; + function defineSymbol(mode, font, group, replace2, name, acceptUnicodeChar) { + symbols[mode][name] = { + font, + group, + replace: replace2 + }; + if (acceptUnicodeChar && replace2) { + symbols[mode][replace2] = symbols[mode][name]; + } + } + var math = "math"; + var text$2 = "text"; + var main = "main"; + var ams = "ams"; + var accent = "accent-token"; + var bin = "bin"; + var close = "close"; + var inner = "inner"; + var mathord = "mathord"; + var op = "op-token"; + var open = "open"; + var punct = "punct"; + var rel = "rel"; + var spacing = "spacing"; + var textord = "textord"; + defineSymbol(math, main, rel, "≡", "\\equiv", true); + defineSymbol(math, main, rel, "≺", "\\prec", true); + defineSymbol(math, main, rel, "≻", "\\succ", true); + defineSymbol(math, main, rel, "∼", "\\sim", true); + defineSymbol(math, main, rel, "⊥", "\\perp"); + defineSymbol(math, main, rel, "⪯", "\\preceq", true); + defineSymbol(math, main, rel, "⪰", "\\succeq", true); + defineSymbol(math, main, rel, "≃", "\\simeq", true); + defineSymbol(math, main, rel, "∣", "\\mid", true); + defineSymbol(math, main, rel, "≪", "\\ll", true); + defineSymbol(math, main, rel, "≫", "\\gg", true); + defineSymbol(math, main, rel, "≍", "\\asymp", true); + defineSymbol(math, main, rel, "∥", "\\parallel"); + defineSymbol(math, main, rel, "⋈", "\\bowtie", true); + defineSymbol(math, main, rel, "⌣", "\\smile", true); + defineSymbol(math, main, rel, "⊑", "\\sqsubseteq", true); + defineSymbol(math, main, rel, "⊒", "\\sqsupseteq", true); + defineSymbol(math, main, rel, "≐", "\\doteq", true); + defineSymbol(math, main, rel, "⌢", "\\frown", true); + defineSymbol(math, main, rel, "∋", "\\ni", true); + defineSymbol(math, main, rel, "∝", "\\propto", true); + defineSymbol(math, main, rel, "⊢", "\\vdash", true); + defineSymbol(math, main, rel, "⊣", "\\dashv", true); + defineSymbol(math, main, rel, "∋", "\\owns"); + defineSymbol(math, main, punct, ".", "\\ldotp"); + defineSymbol(math, main, punct, "⋅", "\\cdotp"); + defineSymbol(math, main, textord, "#", "\\#"); + defineSymbol(text$2, main, textord, "#", "\\#"); + defineSymbol(math, main, textord, "&", "\\&"); + defineSymbol(text$2, main, textord, "&", "\\&"); + defineSymbol(math, main, textord, "ℵ", "\\aleph", true); + defineSymbol(math, main, textord, "∀", "\\forall", true); + defineSymbol(math, main, textord, "ℏ", "\\hbar", true); + defineSymbol(math, main, textord, "∃", "\\exists", true); + defineSymbol(math, main, textord, "∇", "\\nabla", true); + defineSymbol(math, main, textord, "♭", "\\flat", true); + defineSymbol(math, main, textord, "ℓ", "\\ell", true); + defineSymbol(math, main, textord, "♮", "\\natural", true); + defineSymbol(math, main, textord, "♣", "\\clubsuit", true); + defineSymbol(math, main, textord, "℘", "\\wp", true); + defineSymbol(math, main, textord, "♯", "\\sharp", true); + defineSymbol(math, main, textord, "♢", "\\diamondsuit", true); + defineSymbol(math, main, textord, "ℜ", "\\Re", true); + defineSymbol(math, main, textord, "♡", "\\heartsuit", true); + defineSymbol(math, main, textord, "ℑ", "\\Im", true); + defineSymbol(math, main, textord, "♠", "\\spadesuit", true); + defineSymbol(math, main, textord, "§", "\\S", true); + defineSymbol(text$2, main, textord, "§", "\\S"); + defineSymbol(math, main, textord, "¶", "\\P", true); + defineSymbol(text$2, main, textord, "¶", "\\P"); + defineSymbol(math, main, textord, "†", "\\dag"); + defineSymbol(text$2, main, textord, "†", "\\dag"); + defineSymbol(text$2, main, textord, "†", "\\textdagger"); + defineSymbol(math, main, textord, "‡", "\\ddag"); + defineSymbol(text$2, main, textord, "‡", "\\ddag"); + defineSymbol(text$2, main, textord, "‡", "\\textdaggerdbl"); + defineSymbol(math, main, close, "⎱", "\\rmoustache", true); + defineSymbol(math, main, open, "⎰", "\\lmoustache", true); + defineSymbol(math, main, close, "⟯", "\\rgroup", true); + defineSymbol(math, main, open, "⟮", "\\lgroup", true); + defineSymbol(math, main, bin, "∓", "\\mp", true); + defineSymbol(math, main, bin, "⊖", "\\ominus", true); + defineSymbol(math, main, bin, "⊎", "\\uplus", true); + defineSymbol(math, main, bin, "⊓", "\\sqcap", true); + defineSymbol(math, main, bin, "∗", "\\ast"); + defineSymbol(math, main, bin, "⊔", "\\sqcup", true); + defineSymbol(math, main, bin, "◯", "\\bigcirc", true); + defineSymbol(math, main, bin, "∙", "\\bullet", true); + defineSymbol(math, main, bin, "‡", "\\ddagger"); + defineSymbol(math, main, bin, "≀", "\\wr", true); + defineSymbol(math, main, bin, "⨿", "\\amalg"); + defineSymbol(math, main, bin, "&", "\\And"); + defineSymbol(math, main, rel, "⟵", "\\longleftarrow", true); + defineSymbol(math, main, rel, "⇐", "\\Leftarrow", true); + defineSymbol(math, main, rel, "⟸", "\\Longleftarrow", true); + defineSymbol(math, main, rel, "⟶", "\\longrightarrow", true); + defineSymbol(math, main, rel, "⇒", "\\Rightarrow", true); + defineSymbol(math, main, rel, "⟹", "\\Longrightarrow", true); + defineSymbol(math, main, rel, "↔", "\\leftrightarrow", true); + defineSymbol(math, main, rel, "⟷", "\\longleftrightarrow", true); + defineSymbol(math, main, rel, "⇔", "\\Leftrightarrow", true); + defineSymbol(math, main, rel, "⟺", "\\Longleftrightarrow", true); + defineSymbol(math, main, rel, "↦", "\\mapsto", true); + defineSymbol(math, main, rel, "⟼", "\\longmapsto", true); + defineSymbol(math, main, rel, "↗", "\\nearrow", true); + defineSymbol(math, main, rel, "↩", "\\hookleftarrow", true); + defineSymbol(math, main, rel, "↪", "\\hookrightarrow", true); + defineSymbol(math, main, rel, "↘", "\\searrow", true); + defineSymbol(math, main, rel, "↼", "\\leftharpoonup", true); + defineSymbol(math, main, rel, "⇀", "\\rightharpoonup", true); + defineSymbol(math, main, rel, "↙", "\\swarrow", true); + defineSymbol(math, main, rel, "↽", "\\leftharpoondown", true); + defineSymbol(math, main, rel, "⇁", "\\rightharpoondown", true); + defineSymbol(math, main, rel, "↖", "\\nwarrow", true); + defineSymbol(math, main, rel, "⇌", "\\rightleftharpoons", true); + defineSymbol(math, ams, rel, "≮", "\\nless", true); + defineSymbol(math, ams, rel, "", "\\@nleqslant"); + defineSymbol(math, ams, rel, "", "\\@nleqq"); + defineSymbol(math, ams, rel, "⪇", "\\lneq", true); + defineSymbol(math, ams, rel, "≨", "\\lneqq", true); + defineSymbol(math, ams, rel, "", "\\@lvertneqq"); + defineSymbol(math, ams, rel, "⋦", "\\lnsim", true); + defineSymbol(math, ams, rel, "⪉", "\\lnapprox", true); + defineSymbol(math, ams, rel, "⊀", "\\nprec", true); + defineSymbol(math, ams, rel, "⋠", "\\npreceq", true); + defineSymbol(math, ams, rel, "⋨", "\\precnsim", true); + defineSymbol(math, ams, rel, "⪹", "\\precnapprox", true); + defineSymbol(math, ams, rel, "≁", "\\nsim", true); + defineSymbol(math, ams, rel, "", "\\@nshortmid"); + defineSymbol(math, ams, rel, "∤", "\\nmid", true); + defineSymbol(math, ams, rel, "⊬", "\\nvdash", true); + defineSymbol(math, ams, rel, "⊭", "\\nvDash", true); + defineSymbol(math, ams, rel, "⋪", "\\ntriangleleft"); + defineSymbol(math, ams, rel, "⋬", "\\ntrianglelefteq", true); + defineSymbol(math, ams, rel, "⊊", "\\subsetneq", true); + defineSymbol(math, ams, rel, "", "\\@varsubsetneq"); + defineSymbol(math, ams, rel, "⫋", "\\subsetneqq", true); + defineSymbol(math, ams, rel, "", "\\@varsubsetneqq"); + defineSymbol(math, ams, rel, "≯", "\\ngtr", true); + defineSymbol(math, ams, rel, "", "\\@ngeqslant"); + defineSymbol(math, ams, rel, "", "\\@ngeqq"); + defineSymbol(math, ams, rel, "⪈", "\\gneq", true); + defineSymbol(math, ams, rel, "≩", "\\gneqq", true); + defineSymbol(math, ams, rel, "", "\\@gvertneqq"); + defineSymbol(math, ams, rel, "⋧", "\\gnsim", true); + defineSymbol(math, ams, rel, "⪊", "\\gnapprox", true); + defineSymbol(math, ams, rel, "⊁", "\\nsucc", true); + defineSymbol(math, ams, rel, "⋡", "\\nsucceq", true); + defineSymbol(math, ams, rel, "⋩", "\\succnsim", true); + defineSymbol(math, ams, rel, "⪺", "\\succnapprox", true); + defineSymbol(math, ams, rel, "≆", "\\ncong", true); + defineSymbol(math, ams, rel, "", "\\@nshortparallel"); + defineSymbol(math, ams, rel, "∦", "\\nparallel", true); + defineSymbol(math, ams, rel, "⊯", "\\nVDash", true); + defineSymbol(math, ams, rel, "⋫", "\\ntriangleright"); + defineSymbol(math, ams, rel, "⋭", "\\ntrianglerighteq", true); + defineSymbol(math, ams, rel, "", "\\@nsupseteqq"); + defineSymbol(math, ams, rel, "⊋", "\\supsetneq", true); + defineSymbol(math, ams, rel, "", "\\@varsupsetneq"); + defineSymbol(math, ams, rel, "⫌", "\\supsetneqq", true); + defineSymbol(math, ams, rel, "", "\\@varsupsetneqq"); + defineSymbol(math, ams, rel, "⊮", "\\nVdash", true); + defineSymbol(math, ams, rel, "⪵", "\\precneqq", true); + defineSymbol(math, ams, rel, "⪶", "\\succneqq", true); + defineSymbol(math, ams, rel, "", "\\@nsubseteqq"); + defineSymbol(math, ams, bin, "⊴", "\\unlhd"); + defineSymbol(math, ams, bin, "⊵", "\\unrhd"); + defineSymbol(math, ams, rel, "↚", "\\nleftarrow", true); + defineSymbol(math, ams, rel, "↛", "\\nrightarrow", true); + defineSymbol(math, ams, rel, "⇍", "\\nLeftarrow", true); + defineSymbol(math, ams, rel, "⇏", "\\nRightarrow", true); + defineSymbol(math, ams, rel, "↮", "\\nleftrightarrow", true); + defineSymbol(math, ams, rel, "⇎", "\\nLeftrightarrow", true); + defineSymbol(math, ams, rel, "△", "\\vartriangle"); + defineSymbol(math, ams, textord, "ℏ", "\\hslash"); + defineSymbol(math, ams, textord, "▽", "\\triangledown"); + defineSymbol(math, ams, textord, "◊", "\\lozenge"); + defineSymbol(math, ams, textord, "Ⓢ", "\\circledS"); + defineSymbol(math, ams, textord, "®", "\\circledR"); + defineSymbol(text$2, ams, textord, "®", "\\circledR"); + defineSymbol(math, ams, textord, "∡", "\\measuredangle", true); + defineSymbol(math, ams, textord, "∄", "\\nexists"); + defineSymbol(math, ams, textord, "℧", "\\mho"); + defineSymbol(math, ams, textord, "Ⅎ", "\\Finv", true); + defineSymbol(math, ams, textord, "⅁", "\\Game", true); + defineSymbol(math, ams, textord, "‵", "\\backprime"); + defineSymbol(math, ams, textord, "▲", "\\blacktriangle"); + defineSymbol(math, ams, textord, "▼", "\\blacktriangledown"); + defineSymbol(math, ams, textord, "■", "\\blacksquare"); + defineSymbol(math, ams, textord, "⧫", "\\blacklozenge"); + defineSymbol(math, ams, textord, "★", "\\bigstar"); + defineSymbol(math, ams, textord, "∢", "\\sphericalangle", true); + defineSymbol(math, ams, textord, "∁", "\\complement", true); + defineSymbol(math, ams, textord, "ð", "\\eth", true); + defineSymbol(text$2, main, textord, "ð", "ð"); + defineSymbol(math, ams, textord, "╱", "\\diagup"); + defineSymbol(math, ams, textord, "╲", "\\diagdown"); + defineSymbol(math, ams, textord, "□", "\\square"); + defineSymbol(math, ams, textord, "□", "\\Box"); + defineSymbol(math, ams, textord, "◊", "\\Diamond"); + defineSymbol(math, ams, textord, "¥", "\\yen", true); + defineSymbol(text$2, ams, textord, "¥", "\\yen", true); + defineSymbol(math, ams, textord, "✓", "\\checkmark", true); + defineSymbol(text$2, ams, textord, "✓", "\\checkmark"); + defineSymbol(math, ams, textord, "ℶ", "\\beth", true); + defineSymbol(math, ams, textord, "ℸ", "\\daleth", true); + defineSymbol(math, ams, textord, "ℷ", "\\gimel", true); + defineSymbol(math, ams, textord, "ϝ", "\\digamma", true); + defineSymbol(math, ams, textord, "ϰ", "\\varkappa"); + defineSymbol(math, ams, open, "┌", "\\@ulcorner", true); + defineSymbol(math, ams, close, "┐", "\\@urcorner", true); + defineSymbol(math, ams, open, "└", "\\@llcorner", true); + defineSymbol(math, ams, close, "┘", "\\@lrcorner", true); + defineSymbol(math, ams, rel, "≦", "\\leqq", true); + defineSymbol(math, ams, rel, "⩽", "\\leqslant", true); + defineSymbol(math, ams, rel, "⪕", "\\eqslantless", true); + defineSymbol(math, ams, rel, "≲", "\\lesssim", true); + defineSymbol(math, ams, rel, "⪅", "\\lessapprox", true); + defineSymbol(math, ams, rel, "≊", "\\approxeq", true); + defineSymbol(math, ams, bin, "⋖", "\\lessdot"); + defineSymbol(math, ams, rel, "⋘", "\\lll", true); + defineSymbol(math, ams, rel, "≶", "\\lessgtr", true); + defineSymbol(math, ams, rel, "⋚", "\\lesseqgtr", true); + defineSymbol(math, ams, rel, "⪋", "\\lesseqqgtr", true); + defineSymbol(math, ams, rel, "≑", "\\doteqdot"); + defineSymbol(math, ams, rel, "≓", "\\risingdotseq", true); + defineSymbol(math, ams, rel, "≒", "\\fallingdotseq", true); + defineSymbol(math, ams, rel, "∽", "\\backsim", true); + defineSymbol(math, ams, rel, "⋍", "\\backsimeq", true); + defineSymbol(math, ams, rel, "⫅", "\\subseteqq", true); + defineSymbol(math, ams, rel, "⋐", "\\Subset", true); + defineSymbol(math, ams, rel, "⊏", "\\sqsubset", true); + defineSymbol(math, ams, rel, "≼", "\\preccurlyeq", true); + defineSymbol(math, ams, rel, "⋞", "\\curlyeqprec", true); + defineSymbol(math, ams, rel, "≾", "\\precsim", true); + defineSymbol(math, ams, rel, "⪷", "\\precapprox", true); + defineSymbol(math, ams, rel, "⊲", "\\vartriangleleft"); + defineSymbol(math, ams, rel, "⊴", "\\trianglelefteq"); + defineSymbol(math, ams, rel, "⊨", "\\vDash", true); + defineSymbol(math, ams, rel, "⊪", "\\Vvdash", true); + defineSymbol(math, ams, rel, "⌣", "\\smallsmile"); + defineSymbol(math, ams, rel, "⌢", "\\smallfrown"); + defineSymbol(math, ams, rel, "≏", "\\bumpeq", true); + defineSymbol(math, ams, rel, "≎", "\\Bumpeq", true); + defineSymbol(math, ams, rel, "≧", "\\geqq", true); + defineSymbol(math, ams, rel, "⩾", "\\geqslant", true); + defineSymbol(math, ams, rel, "⪖", "\\eqslantgtr", true); + defineSymbol(math, ams, rel, "≳", "\\gtrsim", true); + defineSymbol(math, ams, rel, "⪆", "\\gtrapprox", true); + defineSymbol(math, ams, bin, "⋗", "\\gtrdot"); + defineSymbol(math, ams, rel, "⋙", "\\ggg", true); + defineSymbol(math, ams, rel, "≷", "\\gtrless", true); + defineSymbol(math, ams, rel, "⋛", "\\gtreqless", true); + defineSymbol(math, ams, rel, "⪌", "\\gtreqqless", true); + defineSymbol(math, ams, rel, "≖", "\\eqcirc", true); + defineSymbol(math, ams, rel, "≗", "\\circeq", true); + defineSymbol(math, ams, rel, "≜", "\\triangleq", true); + defineSymbol(math, ams, rel, "∼", "\\thicksim"); + defineSymbol(math, ams, rel, "≈", "\\thickapprox"); + defineSymbol(math, ams, rel, "⫆", "\\supseteqq", true); + defineSymbol(math, ams, rel, "⋑", "\\Supset", true); + defineSymbol(math, ams, rel, "⊐", "\\sqsupset", true); + defineSymbol(math, ams, rel, "≽", "\\succcurlyeq", true); + defineSymbol(math, ams, rel, "⋟", "\\curlyeqsucc", true); + defineSymbol(math, ams, rel, "≿", "\\succsim", true); + defineSymbol(math, ams, rel, "⪸", "\\succapprox", true); + defineSymbol(math, ams, rel, "⊳", "\\vartriangleright"); + defineSymbol(math, ams, rel, "⊵", "\\trianglerighteq"); + defineSymbol(math, ams, rel, "⊩", "\\Vdash", true); + defineSymbol(math, ams, rel, "∣", "\\shortmid"); + defineSymbol(math, ams, rel, "∥", "\\shortparallel"); + defineSymbol(math, ams, rel, "≬", "\\between", true); + defineSymbol(math, ams, rel, "⋔", "\\pitchfork", true); + defineSymbol(math, ams, rel, "∝", "\\varpropto"); + defineSymbol(math, ams, rel, "◀", "\\blacktriangleleft"); + defineSymbol(math, ams, rel, "∴", "\\therefore", true); + defineSymbol(math, ams, rel, "∍", "\\backepsilon"); + defineSymbol(math, ams, rel, "▶", "\\blacktriangleright"); + defineSymbol(math, ams, rel, "∵", "\\because", true); + defineSymbol(math, ams, rel, "⋘", "\\llless"); + defineSymbol(math, ams, rel, "⋙", "\\gggtr"); + defineSymbol(math, ams, bin, "⊲", "\\lhd"); + defineSymbol(math, ams, bin, "⊳", "\\rhd"); + defineSymbol(math, ams, rel, "≂", "\\eqsim", true); + defineSymbol(math, main, rel, "⋈", "\\Join"); + defineSymbol(math, ams, rel, "≑", "\\Doteq", true); + defineSymbol(math, ams, bin, "∔", "\\dotplus", true); + defineSymbol(math, ams, bin, "∖", "\\smallsetminus"); + defineSymbol(math, ams, bin, "⋒", "\\Cap", true); + defineSymbol(math, ams, bin, "⋓", "\\Cup", true); + defineSymbol(math, ams, bin, "⩞", "\\doublebarwedge", true); + defineSymbol(math, ams, bin, "⊟", "\\boxminus", true); + defineSymbol(math, ams, bin, "⊞", "\\boxplus", true); + defineSymbol(math, ams, bin, "⋇", "\\divideontimes", true); + defineSymbol(math, ams, bin, "⋉", "\\ltimes", true); + defineSymbol(math, ams, bin, "⋊", "\\rtimes", true); + defineSymbol(math, ams, bin, "⋋", "\\leftthreetimes", true); + defineSymbol(math, ams, bin, "⋌", "\\rightthreetimes", true); + defineSymbol(math, ams, bin, "⋏", "\\curlywedge", true); + defineSymbol(math, ams, bin, "⋎", "\\curlyvee", true); + defineSymbol(math, ams, bin, "⊝", "\\circleddash", true); + defineSymbol(math, ams, bin, "⊛", "\\circledast", true); + defineSymbol(math, ams, bin, "⋅", "\\centerdot"); + defineSymbol(math, ams, bin, "⊺", "\\intercal", true); + defineSymbol(math, ams, bin, "⋒", "\\doublecap"); + defineSymbol(math, ams, bin, "⋓", "\\doublecup"); + defineSymbol(math, ams, bin, "⊠", "\\boxtimes", true); + defineSymbol(math, ams, rel, "⇢", "\\dashrightarrow", true); + defineSymbol(math, ams, rel, "⇠", "\\dashleftarrow", true); + defineSymbol(math, ams, rel, "⇇", "\\leftleftarrows", true); + defineSymbol(math, ams, rel, "⇆", "\\leftrightarrows", true); + defineSymbol(math, ams, rel, "⇚", "\\Lleftarrow", true); + defineSymbol(math, ams, rel, "↞", "\\twoheadleftarrow", true); + defineSymbol(math, ams, rel, "↢", "\\leftarrowtail", true); + defineSymbol(math, ams, rel, "↫", "\\looparrowleft", true); + defineSymbol(math, ams, rel, "⇋", "\\leftrightharpoons", true); + defineSymbol(math, ams, rel, "↶", "\\curvearrowleft", true); + defineSymbol(math, ams, rel, "↺", "\\circlearrowleft", true); + defineSymbol(math, ams, rel, "↰", "\\Lsh", true); + defineSymbol(math, ams, rel, "⇈", "\\upuparrows", true); + defineSymbol(math, ams, rel, "↿", "\\upharpoonleft", true); + defineSymbol(math, ams, rel, "⇃", "\\downharpoonleft", true); + defineSymbol(math, main, rel, "⊶", "\\origof", true); + defineSymbol(math, main, rel, "⊷", "\\imageof", true); + defineSymbol(math, ams, rel, "⊸", "\\multimap", true); + defineSymbol(math, ams, rel, "↭", "\\leftrightsquigarrow", true); + defineSymbol(math, ams, rel, "⇉", "\\rightrightarrows", true); + defineSymbol(math, ams, rel, "⇄", "\\rightleftarrows", true); + defineSymbol(math, ams, rel, "↠", "\\twoheadrightarrow", true); + defineSymbol(math, ams, rel, "↣", "\\rightarrowtail", true); + defineSymbol(math, ams, rel, "↬", "\\looparrowright", true); + defineSymbol(math, ams, rel, "↷", "\\curvearrowright", true); + defineSymbol(math, ams, rel, "↻", "\\circlearrowright", true); + defineSymbol(math, ams, rel, "↱", "\\Rsh", true); + defineSymbol(math, ams, rel, "⇊", "\\downdownarrows", true); + defineSymbol(math, ams, rel, "↾", "\\upharpoonright", true); + defineSymbol(math, ams, rel, "⇂", "\\downharpoonright", true); + defineSymbol(math, ams, rel, "⇝", "\\rightsquigarrow", true); + defineSymbol(math, ams, rel, "⇝", "\\leadsto"); + defineSymbol(math, ams, rel, "⇛", "\\Rrightarrow", true); + defineSymbol(math, ams, rel, "↾", "\\restriction"); + defineSymbol(math, main, textord, "‘", "`"); + defineSymbol(math, main, textord, "$", "\\$"); + defineSymbol(text$2, main, textord, "$", "\\$"); + defineSymbol(text$2, main, textord, "$", "\\textdollar"); + defineSymbol(math, main, textord, "%", "\\%"); + defineSymbol(text$2, main, textord, "%", "\\%"); + defineSymbol(math, main, textord, "_", "\\_"); + defineSymbol(text$2, main, textord, "_", "\\_"); + defineSymbol(text$2, main, textord, "_", "\\textunderscore"); + defineSymbol(math, main, textord, "∠", "\\angle", true); + defineSymbol(math, main, textord, "∞", "\\infty", true); + defineSymbol(math, main, textord, "′", "\\prime"); + defineSymbol(math, main, textord, "△", "\\triangle"); + defineSymbol(math, main, textord, "Γ", "\\Gamma", true); + defineSymbol(math, main, textord, "Δ", "\\Delta", true); + defineSymbol(math, main, textord, "Θ", "\\Theta", true); + defineSymbol(math, main, textord, "Λ", "\\Lambda", true); + defineSymbol(math, main, textord, "Ξ", "\\Xi", true); + defineSymbol(math, main, textord, "Π", "\\Pi", true); + defineSymbol(math, main, textord, "Σ", "\\Sigma", true); + defineSymbol(math, main, textord, "Υ", "\\Upsilon", true); + defineSymbol(math, main, textord, "Φ", "\\Phi", true); + defineSymbol(math, main, textord, "Ψ", "\\Psi", true); + defineSymbol(math, main, textord, "Ω", "\\Omega", true); + defineSymbol(math, main, textord, "A", "Α"); + defineSymbol(math, main, textord, "B", "Β"); + defineSymbol(math, main, textord, "E", "Ε"); + defineSymbol(math, main, textord, "Z", "Ζ"); + defineSymbol(math, main, textord, "H", "Η"); + defineSymbol(math, main, textord, "I", "Ι"); + defineSymbol(math, main, textord, "K", "Κ"); + defineSymbol(math, main, textord, "M", "Μ"); + defineSymbol(math, main, textord, "N", "Ν"); + defineSymbol(math, main, textord, "O", "Ο"); + defineSymbol(math, main, textord, "P", "Ρ"); + defineSymbol(math, main, textord, "T", "Τ"); + defineSymbol(math, main, textord, "X", "Χ"); + defineSymbol(math, main, textord, "¬", "\\neg", true); + defineSymbol(math, main, textord, "¬", "\\lnot"); + defineSymbol(math, main, textord, "⊤", "\\top"); + defineSymbol(math, main, textord, "⊥", "\\bot"); + defineSymbol(math, main, textord, "∅", "\\emptyset"); + defineSymbol(math, ams, textord, "∅", "\\varnothing"); + defineSymbol(math, main, mathord, "α", "\\alpha", true); + defineSymbol(math, main, mathord, "β", "\\beta", true); + defineSymbol(math, main, mathord, "γ", "\\gamma", true); + defineSymbol(math, main, mathord, "δ", "\\delta", true); + defineSymbol(math, main, mathord, "ϵ", "\\epsilon", true); + defineSymbol(math, main, mathord, "ζ", "\\zeta", true); + defineSymbol(math, main, mathord, "η", "\\eta", true); + defineSymbol(math, main, mathord, "θ", "\\theta", true); + defineSymbol(math, main, mathord, "ι", "\\iota", true); + defineSymbol(math, main, mathord, "κ", "\\kappa", true); + defineSymbol(math, main, mathord, "λ", "\\lambda", true); + defineSymbol(math, main, mathord, "μ", "\\mu", true); + defineSymbol(math, main, mathord, "ν", "\\nu", true); + defineSymbol(math, main, mathord, "ξ", "\\xi", true); + defineSymbol(math, main, mathord, "ο", "\\omicron", true); + defineSymbol(math, main, mathord, "π", "\\pi", true); + defineSymbol(math, main, mathord, "ρ", "\\rho", true); + defineSymbol(math, main, mathord, "σ", "\\sigma", true); + defineSymbol(math, main, mathord, "τ", "\\tau", true); + defineSymbol(math, main, mathord, "υ", "\\upsilon", true); + defineSymbol(math, main, mathord, "ϕ", "\\phi", true); + defineSymbol(math, main, mathord, "χ", "\\chi", true); + defineSymbol(math, main, mathord, "ψ", "\\psi", true); + defineSymbol(math, main, mathord, "ω", "\\omega", true); + defineSymbol(math, main, mathord, "ε", "\\varepsilon", true); + defineSymbol(math, main, mathord, "ϑ", "\\vartheta", true); + defineSymbol(math, main, mathord, "ϖ", "\\varpi", true); + defineSymbol(math, main, mathord, "ϱ", "\\varrho", true); + defineSymbol(math, main, mathord, "ς", "\\varsigma", true); + defineSymbol(math, main, mathord, "φ", "\\varphi", true); + defineSymbol(math, main, bin, "∗", "*", true); + defineSymbol(math, main, bin, "+", "+"); + defineSymbol(math, main, bin, "−", "-", true); + defineSymbol(math, main, bin, "⋅", "\\cdot", true); + defineSymbol(math, main, bin, "∘", "\\circ", true); + defineSymbol(math, main, bin, "÷", "\\div", true); + defineSymbol(math, main, bin, "±", "\\pm", true); + defineSymbol(math, main, bin, "×", "\\times", true); + defineSymbol(math, main, bin, "∩", "\\cap", true); + defineSymbol(math, main, bin, "∪", "\\cup", true); + defineSymbol(math, main, bin, "∖", "\\setminus", true); + defineSymbol(math, main, bin, "∧", "\\land"); + defineSymbol(math, main, bin, "∨", "\\lor"); + defineSymbol(math, main, bin, "∧", "\\wedge", true); + defineSymbol(math, main, bin, "∨", "\\vee", true); + defineSymbol(math, main, textord, "√", "\\surd"); + defineSymbol(math, main, open, "⟨", "\\langle", true); + defineSymbol(math, main, open, "∣", "\\lvert"); + defineSymbol(math, main, open, "∥", "\\lVert"); + defineSymbol(math, main, close, "?", "?"); + defineSymbol(math, main, close, "!", "!"); + defineSymbol(math, main, close, "⟩", "\\rangle", true); + defineSymbol(math, main, close, "∣", "\\rvert"); + defineSymbol(math, main, close, "∥", "\\rVert"); + defineSymbol(math, main, rel, "=", "="); + defineSymbol(math, main, rel, ":", ":"); + defineSymbol(math, main, rel, "≈", "\\approx", true); + defineSymbol(math, main, rel, "≅", "\\cong", true); + defineSymbol(math, main, rel, "≥", "\\ge"); + defineSymbol(math, main, rel, "≥", "\\geq", true); + defineSymbol(math, main, rel, "←", "\\gets"); + defineSymbol(math, main, rel, ">", "\\gt", true); + defineSymbol(math, main, rel, "∈", "\\in", true); + defineSymbol(math, main, rel, "", "\\@not"); + defineSymbol(math, main, rel, "⊂", "\\subset", true); + defineSymbol(math, main, rel, "⊃", "\\supset", true); + defineSymbol(math, main, rel, "⊆", "\\subseteq", true); + defineSymbol(math, main, rel, "⊇", "\\supseteq", true); + defineSymbol(math, ams, rel, "⊈", "\\nsubseteq", true); + defineSymbol(math, ams, rel, "⊉", "\\nsupseteq", true); + defineSymbol(math, main, rel, "⊨", "\\models"); + defineSymbol(math, main, rel, "←", "\\leftarrow", true); + defineSymbol(math, main, rel, "≤", "\\le"); + defineSymbol(math, main, rel, "≤", "\\leq", true); + defineSymbol(math, main, rel, "<", "\\lt", true); + defineSymbol(math, main, rel, "→", "\\rightarrow", true); + defineSymbol(math, main, rel, "→", "\\to"); + defineSymbol(math, ams, rel, "≱", "\\ngeq", true); + defineSymbol(math, ams, rel, "≰", "\\nleq", true); + defineSymbol(math, main, spacing, " ", "\\ "); + defineSymbol(math, main, spacing, " ", "\\space"); + defineSymbol(math, main, spacing, " ", "\\nobreakspace"); + defineSymbol(text$2, main, spacing, " ", "\\ "); + defineSymbol(text$2, main, spacing, " ", " "); + defineSymbol(text$2, main, spacing, " ", "\\space"); + defineSymbol(text$2, main, spacing, " ", "\\nobreakspace"); + defineSymbol(math, main, spacing, null, "\\nobreak"); + defineSymbol(math, main, spacing, null, "\\allowbreak"); + defineSymbol(math, main, punct, ",", ","); + defineSymbol(math, main, punct, ";", ";"); + defineSymbol(math, ams, bin, "⊼", "\\barwedge", true); + defineSymbol(math, ams, bin, "⊻", "\\veebar", true); + defineSymbol(math, main, bin, "⊙", "\\odot", true); + defineSymbol(math, main, bin, "⊕", "\\oplus", true); + defineSymbol(math, main, bin, "⊗", "\\otimes", true); + defineSymbol(math, main, textord, "∂", "\\partial", true); + defineSymbol(math, main, bin, "⊘", "\\oslash", true); + defineSymbol(math, ams, bin, "⊚", "\\circledcirc", true); + defineSymbol(math, ams, bin, "⊡", "\\boxdot", true); + defineSymbol(math, main, bin, "△", "\\bigtriangleup"); + defineSymbol(math, main, bin, "▽", "\\bigtriangledown"); + defineSymbol(math, main, bin, "†", "\\dagger"); + defineSymbol(math, main, bin, "⋄", "\\diamond"); + defineSymbol(math, main, bin, "⋆", "\\star"); + defineSymbol(math, main, bin, "◃", "\\triangleleft"); + defineSymbol(math, main, bin, "▹", "\\triangleright"); + defineSymbol(math, main, open, "{", "\\{"); + defineSymbol(text$2, main, textord, "{", "\\{"); + defineSymbol(text$2, main, textord, "{", "\\textbraceleft"); + defineSymbol(math, main, close, "}", "\\}"); + defineSymbol(text$2, main, textord, "}", "\\}"); + defineSymbol(text$2, main, textord, "}", "\\textbraceright"); + defineSymbol(math, main, open, "{", "\\lbrace"); + defineSymbol(math, main, close, "}", "\\rbrace"); + defineSymbol(math, main, open, "[", "\\lbrack", true); + defineSymbol(text$2, main, textord, "[", "\\lbrack", true); + defineSymbol(math, main, close, "]", "\\rbrack", true); + defineSymbol(text$2, main, textord, "]", "\\rbrack", true); + defineSymbol(math, main, open, "(", "\\lparen", true); + defineSymbol(math, main, close, ")", "\\rparen", true); + defineSymbol(text$2, main, textord, "<", "\\textless", true); + defineSymbol(text$2, main, textord, ">", "\\textgreater", true); + defineSymbol(math, main, open, "⌊", "\\lfloor", true); + defineSymbol(math, main, close, "⌋", "\\rfloor", true); + defineSymbol(math, main, open, "⌈", "\\lceil", true); + defineSymbol(math, main, close, "⌉", "\\rceil", true); + defineSymbol(math, main, textord, "\\", "\\backslash"); + defineSymbol(math, main, textord, "∣", "|"); + defineSymbol(math, main, textord, "∣", "\\vert"); + defineSymbol(text$2, main, textord, "|", "\\textbar", true); + defineSymbol(math, main, textord, "∥", "\\|"); + defineSymbol(math, main, textord, "∥", "\\Vert"); + defineSymbol(text$2, main, textord, "∥", "\\textbardbl"); + defineSymbol(text$2, main, textord, "~", "\\textasciitilde"); + defineSymbol(text$2, main, textord, "\\", "\\textbackslash"); + defineSymbol(text$2, main, textord, "^", "\\textasciicircum"); + defineSymbol(math, main, rel, "↑", "\\uparrow", true); + defineSymbol(math, main, rel, "⇑", "\\Uparrow", true); + defineSymbol(math, main, rel, "↓", "\\downarrow", true); + defineSymbol(math, main, rel, "⇓", "\\Downarrow", true); + defineSymbol(math, main, rel, "↕", "\\updownarrow", true); + defineSymbol(math, main, rel, "⇕", "\\Updownarrow", true); + defineSymbol(math, main, op, "∐", "\\coprod"); + defineSymbol(math, main, op, "⋁", "\\bigvee"); + defineSymbol(math, main, op, "⋀", "\\bigwedge"); + defineSymbol(math, main, op, "⨄", "\\biguplus"); + defineSymbol(math, main, op, "⋂", "\\bigcap"); + defineSymbol(math, main, op, "⋃", "\\bigcup"); + defineSymbol(math, main, op, "∫", "\\int"); + defineSymbol(math, main, op, "∫", "\\intop"); + defineSymbol(math, main, op, "∬", "\\iint"); + defineSymbol(math, main, op, "∭", "\\iiint"); + defineSymbol(math, main, op, "∏", "\\prod"); + defineSymbol(math, main, op, "∑", "\\sum"); + defineSymbol(math, main, op, "⨂", "\\bigotimes"); + defineSymbol(math, main, op, "⨁", "\\bigoplus"); + defineSymbol(math, main, op, "⨀", "\\bigodot"); + defineSymbol(math, main, op, "∮", "\\oint"); + defineSymbol(math, main, op, "∯", "\\oiint"); + defineSymbol(math, main, op, "∰", "\\oiiint"); + defineSymbol(math, main, op, "⨆", "\\bigsqcup"); + defineSymbol(math, main, op, "∫", "\\smallint"); + defineSymbol(text$2, main, inner, "…", "\\textellipsis"); + defineSymbol(math, main, inner, "…", "\\mathellipsis"); + defineSymbol(text$2, main, inner, "…", "\\ldots", true); + defineSymbol(math, main, inner, "…", "\\ldots", true); + defineSymbol(math, main, inner, "⋯", "\\@cdots", true); + defineSymbol(math, main, inner, "⋱", "\\ddots", true); + defineSymbol(math, main, textord, "⋮", "\\varvdots"); + defineSymbol(math, main, accent, "ˊ", "\\acute"); + defineSymbol(math, main, accent, "ˋ", "\\grave"); + defineSymbol(math, main, accent, "¨", "\\ddot"); + defineSymbol(math, main, accent, "~", "\\tilde"); + defineSymbol(math, main, accent, "ˉ", "\\bar"); + defineSymbol(math, main, accent, "˘", "\\breve"); + defineSymbol(math, main, accent, "ˇ", "\\check"); + defineSymbol(math, main, accent, "^", "\\hat"); + defineSymbol(math, main, accent, "⃗", "\\vec"); + defineSymbol(math, main, accent, "˙", "\\dot"); + defineSymbol(math, main, accent, "˚", "\\mathring"); + defineSymbol(math, main, mathord, "", "\\@imath"); + defineSymbol(math, main, mathord, "", "\\@jmath"); + defineSymbol(math, main, textord, "ı", "ı"); + defineSymbol(math, main, textord, "ȷ", "ȷ"); + defineSymbol(text$2, main, textord, "ı", "\\i", true); + defineSymbol(text$2, main, textord, "ȷ", "\\j", true); + defineSymbol(text$2, main, textord, "ß", "\\ss", true); + defineSymbol(text$2, main, textord, "æ", "\\ae", true); + defineSymbol(text$2, main, textord, "œ", "\\oe", true); + defineSymbol(text$2, main, textord, "ø", "\\o", true); + defineSymbol(text$2, main, textord, "Æ", "\\AE", true); + defineSymbol(text$2, main, textord, "Œ", "\\OE", true); + defineSymbol(text$2, main, textord, "Ø", "\\O", true); + defineSymbol(text$2, main, accent, "ˊ", "\\'"); + defineSymbol(text$2, main, accent, "ˋ", "\\`"); + defineSymbol(text$2, main, accent, "ˆ", "\\^"); + defineSymbol(text$2, main, accent, "˜", "\\~"); + defineSymbol(text$2, main, accent, "ˉ", "\\="); + defineSymbol(text$2, main, accent, "˘", "\\u"); + defineSymbol(text$2, main, accent, "˙", "\\."); + defineSymbol(text$2, main, accent, "¸", "\\c"); + defineSymbol(text$2, main, accent, "˚", "\\r"); + defineSymbol(text$2, main, accent, "ˇ", "\\v"); + defineSymbol(text$2, main, accent, "¨", '\\"'); + defineSymbol(text$2, main, accent, "˝", "\\H"); + defineSymbol(text$2, main, accent, "◯", "\\textcircled"); + var ligatures = { + "--": true, + "---": true, + "``": true, + "''": true + }; + defineSymbol(text$2, main, textord, "–", "--", true); + defineSymbol(text$2, main, textord, "–", "\\textendash"); + defineSymbol(text$2, main, textord, "—", "---", true); + defineSymbol(text$2, main, textord, "—", "\\textemdash"); + defineSymbol(text$2, main, textord, "‘", "`", true); + defineSymbol(text$2, main, textord, "‘", "\\textquoteleft"); + defineSymbol(text$2, main, textord, "’", "'", true); + defineSymbol(text$2, main, textord, "’", "\\textquoteright"); + defineSymbol(text$2, main, textord, "“", "``", true); + defineSymbol(text$2, main, textord, "“", "\\textquotedblleft"); + defineSymbol(text$2, main, textord, "”", "''", true); + defineSymbol(text$2, main, textord, "”", "\\textquotedblright"); + defineSymbol(math, main, textord, "°", "\\degree", true); + defineSymbol(text$2, main, textord, "°", "\\degree"); + defineSymbol(text$2, main, textord, "°", "\\textdegree", true); + defineSymbol(math, main, textord, "£", "\\pounds"); + defineSymbol(math, main, textord, "£", "\\mathsterling", true); + defineSymbol(text$2, main, textord, "£", "\\pounds"); + defineSymbol(text$2, main, textord, "£", "\\textsterling", true); + defineSymbol(math, ams, textord, "✠", "\\maltese"); + defineSymbol(text$2, ams, textord, "✠", "\\maltese"); + var mathTextSymbols = '0123456789/@."'; + for (var i = 0; i < mathTextSymbols.length; i++) { + var ch = mathTextSymbols.charAt(i); + defineSymbol(math, main, textord, ch, ch); + } + var textSymbols = '0123456789!@*()-=+";:?/.,'; + for (var _i = 0; _i < textSymbols.length; _i++) { + var _ch = textSymbols.charAt(_i); + defineSymbol(text$2, main, textord, _ch, _ch); + } + var letters = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"; + for (var _i2 = 0; _i2 < letters.length; _i2++) { + var _ch2 = letters.charAt(_i2); + defineSymbol(math, main, mathord, _ch2, _ch2); + defineSymbol(text$2, main, textord, _ch2, _ch2); + } + defineSymbol(math, ams, textord, "C", "ℂ"); + defineSymbol(text$2, ams, textord, "C", "ℂ"); + defineSymbol(math, ams, textord, "H", "ℍ"); + defineSymbol(text$2, ams, textord, "H", "ℍ"); + defineSymbol(math, ams, textord, "N", "ℕ"); + defineSymbol(text$2, ams, textord, "N", "ℕ"); + defineSymbol(math, ams, textord, "P", "ℙ"); + defineSymbol(text$2, ams, textord, "P", "ℙ"); + defineSymbol(math, ams, textord, "Q", "ℚ"); + defineSymbol(text$2, ams, textord, "Q", "ℚ"); + defineSymbol(math, ams, textord, "R", "ℝ"); + defineSymbol(text$2, ams, textord, "R", "ℝ"); + defineSymbol(math, ams, textord, "Z", "ℤ"); + defineSymbol(text$2, ams, textord, "Z", "ℤ"); + defineSymbol(math, main, mathord, "h", "ℎ"); + defineSymbol(text$2, main, mathord, "h", "ℎ"); + var wideChar = ""; + for (var _i3 = 0; _i3 < letters.length; _i3++) { + var _ch3 = letters.charAt(_i3); + wideChar = String.fromCharCode(55349, 56320 + _i3); + defineSymbol(math, main, mathord, _ch3, wideChar); + defineSymbol(text$2, main, textord, _ch3, wideChar); + wideChar = String.fromCharCode(55349, 56372 + _i3); + defineSymbol(math, main, mathord, _ch3, wideChar); + defineSymbol(text$2, main, textord, _ch3, wideChar); + wideChar = String.fromCharCode(55349, 56424 + _i3); + defineSymbol(math, main, mathord, _ch3, wideChar); + defineSymbol(text$2, main, textord, _ch3, wideChar); + wideChar = String.fromCharCode(55349, 56580 + _i3); + defineSymbol(math, main, mathord, _ch3, wideChar); + defineSymbol(text$2, main, textord, _ch3, wideChar); + wideChar = String.fromCharCode(55349, 56684 + _i3); + defineSymbol(math, main, mathord, _ch3, wideChar); + defineSymbol(text$2, main, textord, _ch3, wideChar); + wideChar = String.fromCharCode(55349, 56736 + _i3); + defineSymbol(math, main, mathord, _ch3, wideChar); + defineSymbol(text$2, main, textord, _ch3, wideChar); + wideChar = String.fromCharCode(55349, 56788 + _i3); + defineSymbol(math, main, mathord, _ch3, wideChar); + defineSymbol(text$2, main, textord, _ch3, wideChar); + wideChar = String.fromCharCode(55349, 56840 + _i3); + defineSymbol(math, main, mathord, _ch3, wideChar); + defineSymbol(text$2, main, textord, _ch3, wideChar); + wideChar = String.fromCharCode(55349, 56944 + _i3); + defineSymbol(math, main, mathord, _ch3, wideChar); + defineSymbol(text$2, main, textord, _ch3, wideChar); + if (_i3 < 26) { + wideChar = String.fromCharCode(55349, 56632 + _i3); + defineSymbol(math, main, mathord, _ch3, wideChar); + defineSymbol(text$2, main, textord, _ch3, wideChar); + wideChar = String.fromCharCode(55349, 56476 + _i3); + defineSymbol(math, main, mathord, _ch3, wideChar); + defineSymbol(text$2, main, textord, _ch3, wideChar); + } + } + wideChar = String.fromCharCode(55349, 56668); + defineSymbol(math, main, mathord, "k", wideChar); + defineSymbol(text$2, main, textord, "k", wideChar); + for (var _i4 = 0; _i4 < 10; _i4++) { + var _ch4 = _i4.toString(); + wideChar = String.fromCharCode(55349, 57294 + _i4); + defineSymbol(math, main, mathord, _ch4, wideChar); + defineSymbol(text$2, main, textord, _ch4, wideChar); + wideChar = String.fromCharCode(55349, 57314 + _i4); + defineSymbol(math, main, mathord, _ch4, wideChar); + defineSymbol(text$2, main, textord, _ch4, wideChar); + wideChar = String.fromCharCode(55349, 57324 + _i4); + defineSymbol(math, main, mathord, _ch4, wideChar); + defineSymbol(text$2, main, textord, _ch4, wideChar); + wideChar = String.fromCharCode(55349, 57334 + _i4); + defineSymbol(math, main, mathord, _ch4, wideChar); + defineSymbol(text$2, main, textord, _ch4, wideChar); + } + var extraLatin = "ÐÞþ"; + for (var _i5 = 0; _i5 < extraLatin.length; _i5++) { + var _ch5 = extraLatin.charAt(_i5); + defineSymbol(math, main, mathord, _ch5, _ch5); + defineSymbol(text$2, main, textord, _ch5, _ch5); + } + var wideLatinLetterData = [ + ["mathbf", "textbf", "Main-Bold"], + // A-Z bold upright + ["mathbf", "textbf", "Main-Bold"], + // a-z bold upright + ["mathnormal", "textit", "Math-Italic"], + // A-Z italic + ["mathnormal", "textit", "Math-Italic"], + // a-z italic + ["boldsymbol", "boldsymbol", "Main-BoldItalic"], + // A-Z bold italic + ["boldsymbol", "boldsymbol", "Main-BoldItalic"], + // a-z bold italic + // Map fancy A-Z letters to script, not calligraphic. + // This aligns with unicode-math and math fonts (except Cambria Math). + ["mathscr", "textscr", "Script-Regular"], + // A-Z script + ["", "", ""], + // a-z script. No font + ["", "", ""], + // A-Z bold script. No font + ["", "", ""], + // a-z bold script. No font + ["mathfrak", "textfrak", "Fraktur-Regular"], + // A-Z Fraktur + ["mathfrak", "textfrak", "Fraktur-Regular"], + // a-z Fraktur + ["mathbb", "textbb", "AMS-Regular"], + // A-Z double-struck + ["mathbb", "textbb", "AMS-Regular"], + // k double-struck + // Note that we are using a bold font, but font metrics for regular Fraktur. + ["mathboldfrak", "textboldfrak", "Fraktur-Regular"], + // A-Z bold Fraktur + ["mathboldfrak", "textboldfrak", "Fraktur-Regular"], + // a-z bold Fraktur + ["mathsf", "textsf", "SansSerif-Regular"], + // A-Z sans-serif + ["mathsf", "textsf", "SansSerif-Regular"], + // a-z sans-serif + ["mathboldsf", "textboldsf", "SansSerif-Bold"], + // A-Z bold sans-serif + ["mathboldsf", "textboldsf", "SansSerif-Bold"], + // a-z bold sans-serif + ["mathitsf", "textitsf", "SansSerif-Italic"], + // A-Z italic sans-serif + ["mathitsf", "textitsf", "SansSerif-Italic"], + // a-z italic sans-serif + ["", "", ""], + // A-Z bold italic sans. No font + ["", "", ""], + // a-z bold italic sans. No font + ["mathtt", "texttt", "Typewriter-Regular"], + // A-Z monospace + ["mathtt", "texttt", "Typewriter-Regular"] + // a-z monospace + ]; + var wideNumeralData = [ + ["mathbf", "textbf", "Main-Bold"], + // 0-9 bold + ["", "", ""], + // 0-9 double-struck. No KaTeX font. + ["mathsf", "textsf", "SansSerif-Regular"], + // 0-9 sans-serif + ["mathboldsf", "textboldsf", "SansSerif-Bold"], + // 0-9 bold sans-serif + ["mathtt", "texttt", "Typewriter-Regular"] + // 0-9 monospace + ]; + var wideCharacterFont = function wideCharacterFont2(wideChar2, mode) { + var H = wideChar2.charCodeAt(0); + var L = wideChar2.charCodeAt(1); + var codePoint = (H - 55296) * 1024 + (L - 56320) + 65536; + var j = mode === "math" ? 0 : 1; + if (119808 <= codePoint && codePoint < 120484) { + var i2 = Math.floor((codePoint - 119808) / 26); + return [wideLatinLetterData[i2][2], wideLatinLetterData[i2][j]]; + } else if (120782 <= codePoint && codePoint <= 120831) { + var _i6 = Math.floor((codePoint - 120782) / 10); + return [wideNumeralData[_i6][2], wideNumeralData[_i6][j]]; + } else if (codePoint === 120485 || codePoint === 120486) { + return [wideLatinLetterData[0][2], wideLatinLetterData[0][j]]; + } else if (120486 < codePoint && codePoint < 120782) { + return ["", ""]; + } else { + throw new ParseError("Unsupported character: " + wideChar2); + } + }; + var lookupSymbol = function lookupSymbol2(value2, fontName, mode) { + if (symbols[mode][value2] && symbols[mode][value2].replace) { + value2 = symbols[mode][value2].replace; + } + return { + value: value2, + metrics: getCharacterMetrics(value2, fontName, mode) + }; + }; + var makeSymbol = function makeSymbol2(value2, fontName, mode, options2, classes2) { + var lookup = lookupSymbol(value2, fontName, mode); + var metrics = lookup.metrics; + value2 = lookup.value; + var symbolNode; + if (metrics) { + var italic = metrics.italic; + if (mode === "text" || options2 && options2.font === "mathit") { + italic = 0; + } + symbolNode = new SymbolNode(value2, metrics.height, metrics.depth, italic, metrics.skew, metrics.width, classes2); + } else { + typeof console !== "undefined" && console.warn("No character metrics " + ("for '" + value2 + "' in style '" + fontName + "' and mode '" + mode + "'")); + symbolNode = new SymbolNode(value2, 0, 0, 0, 0, 0, classes2); + } + if (options2) { + symbolNode.maxFontSize = options2.sizeMultiplier; + if (options2.style.isTight()) { + symbolNode.classes.push("mtight"); + } + var color2 = options2.getColor(); + if (color2) { + symbolNode.style.color = color2; + } + } + return symbolNode; + }; + var mathsym = function mathsym2(value2, mode, options2, classes2) { + if (classes2 === void 0) { + classes2 = []; + } + if (options2.font === "boldsymbol" && lookupSymbol(value2, "Main-Bold", mode).metrics) { + return makeSymbol(value2, "Main-Bold", mode, options2, classes2.concat(["mathbf"])); + } else if (value2 === "\\" || symbols[mode][value2].font === "main") { + return makeSymbol(value2, "Main-Regular", mode, options2, classes2); + } else { + return makeSymbol(value2, "AMS-Regular", mode, options2, classes2.concat(["amsrm"])); + } + }; + var boldsymbol = function boldsymbol2(value2, mode, options2, classes2, type2) { + if (type2 !== "textord" && lookupSymbol(value2, "Math-BoldItalic", mode).metrics) { + return { + fontName: "Math-BoldItalic", + fontClass: "boldsymbol" + }; + } else { + return { + fontName: "Main-Bold", + fontClass: "mathbf" + }; + } + }; + var makeOrd = function makeOrd2(group, options2, type2) { + var mode = group.mode; + var text2 = group.text; + var classes2 = ["mord"]; + var isFont = mode === "math" || mode === "text" && options2.font; + var fontOrFamily = isFont ? options2.font : options2.fontFamily; + var wideFontName = ""; + var wideFontClass = ""; + if (text2.charCodeAt(0) === 55349) { + [wideFontName, wideFontClass] = wideCharacterFont(text2, mode); + } + if (wideFontName.length > 0) { + return makeSymbol(text2, wideFontName, mode, options2, classes2.concat(wideFontClass)); + } else if (fontOrFamily) { + var fontName; + var fontClasses; + if (fontOrFamily === "boldsymbol") { + var fontData = boldsymbol(text2, mode, options2, classes2, type2); + fontName = fontData.fontName; + fontClasses = [fontData.fontClass]; + } else if (isFont) { + fontName = fontMap[fontOrFamily].fontName; + fontClasses = [fontOrFamily]; + } else { + fontName = retrieveTextFontName(fontOrFamily, options2.fontWeight, options2.fontShape); + fontClasses = [fontOrFamily, options2.fontWeight, options2.fontShape]; + } + if (lookupSymbol(text2, fontName, mode).metrics) { + return makeSymbol(text2, fontName, mode, options2, classes2.concat(fontClasses)); + } else if (ligatures.hasOwnProperty(text2) && fontName.slice(0, 10) === "Typewriter") { + var parts = []; + for (var i2 = 0; i2 < text2.length; i2++) { + parts.push(makeSymbol(text2[i2], fontName, mode, options2, classes2.concat(fontClasses))); + } + return makeFragment(parts); + } + } + if (type2 === "mathord") { + return makeSymbol(text2, "Math-Italic", mode, options2, classes2.concat(["mathnormal"])); + } else if (type2 === "textord") { + var font = symbols[mode][text2] && symbols[mode][text2].font; + if (font === "ams") { + var _fontName = retrieveTextFontName("amsrm", options2.fontWeight, options2.fontShape); + return makeSymbol(text2, _fontName, mode, options2, classes2.concat("amsrm", options2.fontWeight, options2.fontShape)); + } else if (font === "main" || !font) { + var _fontName2 = retrieveTextFontName("textrm", options2.fontWeight, options2.fontShape); + return makeSymbol(text2, _fontName2, mode, options2, classes2.concat(options2.fontWeight, options2.fontShape)); + } else { + var _fontName3 = retrieveTextFontName(font, options2.fontWeight, options2.fontShape); + return makeSymbol(text2, _fontName3, mode, options2, classes2.concat(_fontName3, options2.fontWeight, options2.fontShape)); + } + } else { + throw new Error("unexpected type: " + type2 + " in makeOrd"); + } + }; + var canCombine = (prev2, next2) => { + if (createClass(prev2.classes) !== createClass(next2.classes) || prev2.skew !== next2.skew || prev2.maxFontSize !== next2.maxFontSize) { + return false; + } + if (prev2.classes.length === 1) { + var cls = prev2.classes[0]; + if (cls === "mbin" || cls === "mord") { + return false; + } + } + for (var style in prev2.style) { + if (prev2.style.hasOwnProperty(style) && prev2.style[style] !== next2.style[style]) { + return false; + } + } + for (var _style in next2.style) { + if (next2.style.hasOwnProperty(_style) && prev2.style[_style] !== next2.style[_style]) { + return false; + } + } + return true; + }; + var tryCombineChars = (chars) => { + for (var i2 = 0; i2 < chars.length - 1; i2++) { + var prev2 = chars[i2]; + var next2 = chars[i2 + 1]; + if (prev2 instanceof SymbolNode && next2 instanceof SymbolNode && canCombine(prev2, next2)) { + prev2.text += next2.text; + prev2.height = Math.max(prev2.height, next2.height); + prev2.depth = Math.max(prev2.depth, next2.depth); + prev2.italic = next2.italic; + chars.splice(i2 + 1, 1); + i2--; + } + } + return chars; + }; + var sizeElementFromChildren = function sizeElementFromChildren2(elem) { + var height = 0; + var depth = 0; + var maxFontSize = 0; + for (var i2 = 0; i2 < elem.children.length; i2++) { + var child = elem.children[i2]; + if (child.height > height) { + height = child.height; + } + if (child.depth > depth) { + depth = child.depth; + } + if (child.maxFontSize > maxFontSize) { + maxFontSize = child.maxFontSize; + } + } + elem.height = height; + elem.depth = depth; + elem.maxFontSize = maxFontSize; + }; + var makeSpan$2 = function makeSpan2(classes2, children2, options2, style) { + var span = new Span(classes2, children2, options2, style); + sizeElementFromChildren(span); + return span; + }; + var makeSvgSpan = (classes2, children2, options2, style) => new Span(classes2, children2, options2, style); + var makeLineSpan = function makeLineSpan2(className, options2, thickness) { + var line2 = makeSpan$2([className], [], options2); + line2.height = Math.max(thickness || options2.fontMetrics().defaultRuleThickness, options2.minRuleThickness); + line2.style.borderBottomWidth = makeEm(line2.height); + line2.maxFontSize = 1; + return line2; + }; + var makeAnchor = function makeAnchor2(href, classes2, children2, options2) { + var anchor = new Anchor(href, classes2, children2, options2); + sizeElementFromChildren(anchor); + return anchor; + }; + var makeFragment = function makeFragment2(children2) { + var fragment = new DocumentFragment(children2); + sizeElementFromChildren(fragment); + return fragment; + }; + var wrapFragment = function wrapFragment2(group, options2) { + if (group instanceof DocumentFragment) { + return makeSpan$2([], [group], options2); + } + return group; + }; + var getVListChildrenAndDepth = function getVListChildrenAndDepth2(params) { + if (params.positionType === "individualShift") { + var oldChildren = params.children; + var children2 = [oldChildren[0]]; + var _depth = -oldChildren[0].shift - oldChildren[0].elem.depth; + var currPos = _depth; + for (var i2 = 1; i2 < oldChildren.length; i2++) { + var diff = -oldChildren[i2].shift - currPos - oldChildren[i2].elem.depth; + var size2 = diff - (oldChildren[i2 - 1].elem.height + oldChildren[i2 - 1].elem.depth); + currPos = currPos + diff; + children2.push({ + type: "kern", + size: size2 + }); + children2.push(oldChildren[i2]); + } + return { + children: children2, + depth: _depth + }; + } + var depth; + if (params.positionType === "top") { + var bottom2 = params.positionData; + for (var _i6 = 0; _i6 < params.children.length; _i6++) { + var child = params.children[_i6]; + bottom2 -= child.type === "kern" ? child.size : child.elem.height + child.elem.depth; + } + depth = bottom2; + } else if (params.positionType === "bottom") { + depth = -params.positionData; + } else { + var firstChild = params.children[0]; + if (firstChild.type !== "elem") { + throw new Error('First child must have type "elem".'); + } + if (params.positionType === "shift") { + depth = -firstChild.elem.depth - params.positionData; + } else if (params.positionType === "firstBaseline") { + depth = -firstChild.elem.depth; + } else { + throw new Error("Invalid positionType " + params.positionType + "."); + } + } + return { + children: params.children, + depth + }; + }; + var makeVList = function makeVList2(params, options2) { + var { + children: children2, + depth + } = getVListChildrenAndDepth(params); + var pstrutSize = 0; + for (var i2 = 0; i2 < children2.length; i2++) { + var child = children2[i2]; + if (child.type === "elem") { + var elem = child.elem; + pstrutSize = Math.max(pstrutSize, elem.maxFontSize, elem.height); + } + } + pstrutSize += 2; + var pstrut = makeSpan$2(["pstrut"], []); + pstrut.style.height = makeEm(pstrutSize); + var realChildren = []; + var minPos = depth; + var maxPos2 = depth; + var currPos = depth; + for (var _i22 = 0; _i22 < children2.length; _i22++) { + var _child = children2[_i22]; + if (_child.type === "kern") { + currPos += _child.size; + } else { + var _elem = _child.elem; + var classes2 = _child.wrapperClasses || []; + var style = _child.wrapperStyle || {}; + var childWrap = makeSpan$2(classes2, [pstrut, _elem], void 0, style); + childWrap.style.top = makeEm(-pstrutSize - currPos - _elem.depth); + if (_child.marginLeft) { + childWrap.style.marginLeft = _child.marginLeft; + } + if (_child.marginRight) { + childWrap.style.marginRight = _child.marginRight; + } + realChildren.push(childWrap); + currPos += _elem.height + _elem.depth; + } + minPos = Math.min(minPos, currPos); + maxPos2 = Math.max(maxPos2, currPos); + } + var vlist = makeSpan$2(["vlist"], realChildren); + vlist.style.height = makeEm(maxPos2); + var rows; + if (minPos < 0) { + var emptySpan = makeSpan$2([], []); + var depthStrut = makeSpan$2(["vlist"], [emptySpan]); + depthStrut.style.height = makeEm(-minPos); + var topStrut = makeSpan$2(["vlist-s"], [new SymbolNode("​")]); + rows = [makeSpan$2(["vlist-r"], [vlist, topStrut]), makeSpan$2(["vlist-r"], [depthStrut])]; + } else { + rows = [makeSpan$2(["vlist-r"], [vlist])]; + } + var vtable = makeSpan$2(["vlist-t"], rows); + if (rows.length === 2) { + vtable.classes.push("vlist-t2"); + } + vtable.height = maxPos2; + vtable.depth = -minPos; + return vtable; + }; + var makeGlue = (measurement, options2) => { + var rule = makeSpan$2(["mspace"], [], options2); + var size2 = calculateSize(measurement, options2); + rule.style.marginRight = makeEm(size2); + return rule; + }; + var retrieveTextFontName = function retrieveTextFontName2(fontFamily, fontWeight, fontShape) { + var baseFontName = ""; + switch (fontFamily) { + case "amsrm": + baseFontName = "AMS"; + break; + case "textrm": + baseFontName = "Main"; + break; + case "textsf": + baseFontName = "SansSerif"; + break; + case "texttt": + baseFontName = "Typewriter"; + break; + default: + baseFontName = fontFamily; + } + var fontStylesName; + if (fontWeight === "textbf" && fontShape === "textit") { + fontStylesName = "BoldItalic"; + } else if (fontWeight === "textbf") { + fontStylesName = "Bold"; + } else if (fontWeight === "textit") { + fontStylesName = "Italic"; + } else { + fontStylesName = "Regular"; + } + return baseFontName + "-" + fontStylesName; + }; + var fontMap = { + // styles + "mathbf": { + variant: "bold", + fontName: "Main-Bold" + }, + "mathrm": { + variant: "normal", + fontName: "Main-Regular" + }, + "textit": { + variant: "italic", + fontName: "Main-Italic" + }, + "mathit": { + variant: "italic", + fontName: "Main-Italic" + }, + "mathnormal": { + variant: "italic", + fontName: "Math-Italic" + }, + // "boldsymbol" is missing because they require the use of multiple fonts: + // Math-BoldItalic and Main-Bold. This is handled by a special case in + // makeOrd which ends up calling boldsymbol. + // families + "mathbb": { + variant: "double-struck", + fontName: "AMS-Regular" + }, + "mathcal": { + variant: "script", + fontName: "Caligraphic-Regular" + }, + "mathfrak": { + variant: "fraktur", + fontName: "Fraktur-Regular" + }, + "mathscr": { + variant: "script", + fontName: "Script-Regular" + }, + "mathsf": { + variant: "sans-serif", + fontName: "SansSerif-Regular" + }, + "mathtt": { + variant: "monospace", + fontName: "Typewriter-Regular" + } + }; + var svgData = { + // path, width, height + vec: ["vec", 0.471, 0.714], + // values from the font glyph + oiintSize1: ["oiintSize1", 0.957, 0.499], + // oval to overlay the integrand + oiintSize2: ["oiintSize2", 1.472, 0.659], + oiiintSize1: ["oiiintSize1", 1.304, 0.499], + oiiintSize2: ["oiiintSize2", 1.98, 0.659] + }; + var staticSvg = function staticSvg2(value2, options2) { + var [pathName, width2, height] = svgData[value2]; + var path2 = new PathNode(pathName); + var svgNode2 = new SvgNode([path2], { + "width": makeEm(width2), + "height": makeEm(height), + // Override CSS rule `.katex svg { width: 100% }` + "style": "width:" + makeEm(width2), + "viewBox": "0 0 " + 1e3 * width2 + " " + 1e3 * height, + "preserveAspectRatio": "xMinYMin" + }); + var span = makeSvgSpan(["overlay"], [svgNode2], options2); + span.height = height; + span.style.height = makeEm(height); + span.style.width = makeEm(width2); + return span; + }; + var buildCommon = { + fontMap, + makeSymbol, + mathsym, + makeSpan: makeSpan$2, + makeSvgSpan, + makeLineSpan, + makeAnchor, + makeFragment, + wrapFragment, + makeVList, + makeOrd, + makeGlue, + staticSvg, + svgData, + tryCombineChars + }; + var thinspace = { + number: 3, + unit: "mu" + }; + var mediumspace = { + number: 4, + unit: "mu" + }; + var thickspace = { + number: 5, + unit: "mu" + }; + var spacings = { + mord: { + mop: thinspace, + mbin: mediumspace, + mrel: thickspace, + minner: thinspace + }, + mop: { + mord: thinspace, + mop: thinspace, + mrel: thickspace, + minner: thinspace + }, + mbin: { + mord: mediumspace, + mop: mediumspace, + mopen: mediumspace, + minner: mediumspace + }, + mrel: { + mord: thickspace, + mop: thickspace, + mopen: thickspace, + minner: thickspace + }, + mopen: {}, + mclose: { + mop: thinspace, + mbin: mediumspace, + mrel: thickspace, + minner: thinspace + }, + mpunct: { + mord: thinspace, + mop: thinspace, + mrel: thickspace, + mopen: thinspace, + mclose: thinspace, + mpunct: thinspace, + minner: thinspace + }, + minner: { + mord: thinspace, + mop: thinspace, + mbin: mediumspace, + mrel: thickspace, + mopen: thinspace, + mpunct: thinspace, + minner: thinspace + } + }; + var tightSpacings = { + mord: { + mop: thinspace + }, + mop: { + mord: thinspace, + mop: thinspace + }, + mbin: {}, + mrel: {}, + mopen: {}, + mclose: { + mop: thinspace + }, + mpunct: {}, + minner: { + mop: thinspace + } + }; + var _functions = {}; + var _htmlGroupBuilders = {}; + var _mathmlGroupBuilders = {}; + function defineFunction(_ref) { + var { + type: type2, + names, + props, + handler, + htmlBuilder: htmlBuilder2, + mathmlBuilder: mathmlBuilder2 + } = _ref; + var data = { + type: type2, + numArgs: props.numArgs, + argTypes: props.argTypes, + allowedInArgument: !!props.allowedInArgument, + allowedInText: !!props.allowedInText, + allowedInMath: props.allowedInMath === void 0 ? true : props.allowedInMath, + numOptionalArgs: props.numOptionalArgs || 0, + infix: !!props.infix, + primitive: !!props.primitive, + handler + }; + for (var i2 = 0; i2 < names.length; ++i2) { + _functions[names[i2]] = data; + } + if (type2) { + if (htmlBuilder2) { + _htmlGroupBuilders[type2] = htmlBuilder2; + } + if (mathmlBuilder2) { + _mathmlGroupBuilders[type2] = mathmlBuilder2; + } + } + } + function defineFunctionBuilders(_ref2) { + var { + type: type2, + htmlBuilder: htmlBuilder2, + mathmlBuilder: mathmlBuilder2 + } = _ref2; + defineFunction({ + type: type2, + names: [], + props: { + numArgs: 0 + }, + handler() { + throw new Error("Should never be called."); + }, + htmlBuilder: htmlBuilder2, + mathmlBuilder: mathmlBuilder2 + }); + } + var normalizeArgument = function normalizeArgument2(arg) { + return arg.type === "ordgroup" && arg.body.length === 1 ? arg.body[0] : arg; + }; + var ordargument = function ordargument2(arg) { + return arg.type === "ordgroup" ? arg.body : [arg]; + }; + var makeSpan$1 = buildCommon.makeSpan; + var binLeftCanceller = ["leftmost", "mbin", "mopen", "mrel", "mop", "mpunct"]; + var binRightCanceller = ["rightmost", "mrel", "mclose", "mpunct"]; + var styleMap$1 = { + "display": Style$1.DISPLAY, + "text": Style$1.TEXT, + "script": Style$1.SCRIPT, + "scriptscript": Style$1.SCRIPTSCRIPT + }; + var DomEnum = { + mord: "mord", + mop: "mop", + mbin: "mbin", + mrel: "mrel", + mopen: "mopen", + mclose: "mclose", + mpunct: "mpunct", + minner: "minner" + }; + var buildExpression$1 = function buildExpression2(expression, options2, isRealGroup, surrounding) { + if (surrounding === void 0) { + surrounding = [null, null]; + } + var groups = []; + for (var i2 = 0; i2 < expression.length; i2++) { + var output = buildGroup$1(expression[i2], options2); + if (output instanceof DocumentFragment) { + var children2 = output.children; + groups.push(...children2); + } else { + groups.push(output); + } + } + buildCommon.tryCombineChars(groups); + if (!isRealGroup) { + return groups; + } + var glueOptions = options2; + if (expression.length === 1) { + var node2 = expression[0]; + if (node2.type === "sizing") { + glueOptions = options2.havingSize(node2.size); + } else if (node2.type === "styling") { + glueOptions = options2.havingStyle(styleMap$1[node2.style]); + } + } + var dummyPrev = makeSpan$1([surrounding[0] || "leftmost"], [], options2); + var dummyNext = makeSpan$1([surrounding[1] || "rightmost"], [], options2); + var isRoot = isRealGroup === "root"; + traverseNonSpaceNodes(groups, (node3, prev2) => { + var prevType = prev2.classes[0]; + var type2 = node3.classes[0]; + if (prevType === "mbin" && utils.contains(binRightCanceller, type2)) { + prev2.classes[0] = "mord"; + } else if (type2 === "mbin" && utils.contains(binLeftCanceller, prevType)) { + node3.classes[0] = "mord"; + } + }, { + node: dummyPrev + }, dummyNext, isRoot); + traverseNonSpaceNodes(groups, (node3, prev2) => { + var prevType = getTypeOfDomTree(prev2); + var type2 = getTypeOfDomTree(node3); + var space = prevType && type2 ? node3.hasClass("mtight") ? tightSpacings[prevType][type2] : spacings[prevType][type2] : null; + if (space) { + return buildCommon.makeGlue(space, glueOptions); + } + }, { + node: dummyPrev + }, dummyNext, isRoot); + return groups; + }; + var traverseNonSpaceNodes = function traverseNonSpaceNodes2(nodes2, callback, prev2, next2, isRoot) { + if (next2) { + nodes2.push(next2); + } + var i2 = 0; + for (; i2 < nodes2.length; i2++) { + var node2 = nodes2[i2]; + var partialGroup = checkPartialGroup(node2); + if (partialGroup) { + traverseNonSpaceNodes2(partialGroup.children, callback, prev2, null, isRoot); + continue; + } + var nonspace = !node2.hasClass("mspace"); + if (nonspace) { + var result = callback(node2, prev2.node); + if (result) { + if (prev2.insertAfter) { + prev2.insertAfter(result); + } else { + nodes2.unshift(result); + i2++; + } + } + } + if (nonspace) { + prev2.node = node2; + } else if (isRoot && node2.hasClass("newline")) { + prev2.node = makeSpan$1(["leftmost"]); + } + prev2.insertAfter = ((index2) => (n) => { + nodes2.splice(index2 + 1, 0, n); + i2++; + })(i2); + } + if (next2) { + nodes2.pop(); + } + }; + var checkPartialGroup = function checkPartialGroup2(node2) { + if (node2 instanceof DocumentFragment || node2 instanceof Anchor || node2 instanceof Span && node2.hasClass("enclosing")) { + return node2; + } + return null; + }; + var getOutermostNode = function getOutermostNode2(node2, side) { + var partialGroup = checkPartialGroup(node2); + if (partialGroup) { + var children2 = partialGroup.children; + if (children2.length) { + if (side === "right") { + return getOutermostNode2(children2[children2.length - 1], "right"); + } else if (side === "left") { + return getOutermostNode2(children2[0], "left"); + } + } + } + return node2; + }; + var getTypeOfDomTree = function getTypeOfDomTree2(node2, side) { + if (!node2) { + return null; + } + if (side) { + node2 = getOutermostNode(node2, side); + } + return DomEnum[node2.classes[0]] || null; + }; + var makeNullDelimiter = function makeNullDelimiter2(options2, classes2) { + var moreClasses = ["nulldelimiter"].concat(options2.baseSizingClasses()); + return makeSpan$1(classes2.concat(moreClasses)); + }; + var buildGroup$1 = function buildGroup2(group, options2, baseOptions) { + if (!group) { + return makeSpan$1(); + } + if (_htmlGroupBuilders[group.type]) { + var groupNode = _htmlGroupBuilders[group.type](group, options2); + if (baseOptions && options2.size !== baseOptions.size) { + groupNode = makeSpan$1(options2.sizingClasses(baseOptions), [groupNode], options2); + var multiplier = options2.sizeMultiplier / baseOptions.sizeMultiplier; + groupNode.height *= multiplier; + groupNode.depth *= multiplier; + } + return groupNode; + } else { + throw new ParseError("Got group of unknown type: '" + group.type + "'"); + } + }; + function buildHTMLUnbreakable(children2, options2) { + var body = makeSpan$1(["base"], children2, options2); + var strut = makeSpan$1(["strut"]); + strut.style.height = makeEm(body.height + body.depth); + if (body.depth) { + strut.style.verticalAlign = makeEm(-body.depth); + } + body.children.unshift(strut); + return body; + } + function buildHTML(tree, options2) { + var tag = null; + if (tree.length === 1 && tree[0].type === "tag") { + tag = tree[0].tag; + tree = tree[0].body; + } + var expression = buildExpression$1(tree, options2, "root"); + var eqnNum; + if (expression.length === 2 && expression[1].hasClass("tag")) { + eqnNum = expression.pop(); + } + var children2 = []; + var parts = []; + for (var i2 = 0; i2 < expression.length; i2++) { + parts.push(expression[i2]); + if (expression[i2].hasClass("mbin") || expression[i2].hasClass("mrel") || expression[i2].hasClass("allowbreak")) { + var nobreak = false; + while (i2 < expression.length - 1 && expression[i2 + 1].hasClass("mspace") && !expression[i2 + 1].hasClass("newline")) { + i2++; + parts.push(expression[i2]); + if (expression[i2].hasClass("nobreak")) { + nobreak = true; + } + } + if (!nobreak) { + children2.push(buildHTMLUnbreakable(parts, options2)); + parts = []; + } + } else if (expression[i2].hasClass("newline")) { + parts.pop(); + if (parts.length > 0) { + children2.push(buildHTMLUnbreakable(parts, options2)); + parts = []; + } + children2.push(expression[i2]); + } + } + if (parts.length > 0) { + children2.push(buildHTMLUnbreakable(parts, options2)); + } + var tagChild; + if (tag) { + tagChild = buildHTMLUnbreakable(buildExpression$1(tag, options2, true)); + tagChild.classes = ["tag"]; + children2.push(tagChild); + } else if (eqnNum) { + children2.push(eqnNum); + } + var htmlNode = makeSpan$1(["katex-html"], children2); + htmlNode.setAttribute("aria-hidden", "true"); + if (tagChild) { + var strut = tagChild.children[0]; + strut.style.height = makeEm(htmlNode.height + htmlNode.depth); + if (htmlNode.depth) { + strut.style.verticalAlign = makeEm(-htmlNode.depth); + } + } + return htmlNode; + } + function newDocumentFragment(children2) { + return new DocumentFragment(children2); + } + class MathNode { + constructor(type2, children2, classes2) { + this.type = void 0; + this.attributes = void 0; + this.children = void 0; + this.classes = void 0; + this.type = type2; + this.attributes = {}; + this.children = children2 || []; + this.classes = classes2 || []; + } + /** + * Sets an attribute on a MathML node. MathML depends on attributes to convey a + * semantic content, so this is used heavily. + */ + setAttribute(name, value2) { + this.attributes[name] = value2; + } + /** + * Gets an attribute on a MathML node. + */ + getAttribute(name) { + return this.attributes[name]; + } + /** + * Converts the math node into a MathML-namespaced DOM element. + */ + toNode() { + var node2 = document.createElementNS("http://www.w3.org/1998/Math/MathML", this.type); + for (var attr in this.attributes) { + if (Object.prototype.hasOwnProperty.call(this.attributes, attr)) { + node2.setAttribute(attr, this.attributes[attr]); + } + } + if (this.classes.length > 0) { + node2.className = createClass(this.classes); + } + for (var i2 = 0; i2 < this.children.length; i2++) { + node2.appendChild(this.children[i2].toNode()); + } + return node2; + } + /** + * Converts the math node into an HTML markup string. + */ + toMarkup() { + var markup = "<" + this.type; + for (var attr in this.attributes) { + if (Object.prototype.hasOwnProperty.call(this.attributes, attr)) { + markup += " " + attr + '="'; + markup += utils.escape(this.attributes[attr]); + markup += '"'; + } + } + if (this.classes.length > 0) { + markup += ' class ="' + utils.escape(createClass(this.classes)) + '"'; + } + markup += ">"; + for (var i2 = 0; i2 < this.children.length; i2++) { + markup += this.children[i2].toMarkup(); + } + markup += ""; + return markup; + } + /** + * Converts the math node into a string, similar to innerText, but escaped. + */ + toText() { + return this.children.map((child) => child.toText()).join(""); + } + } + class TextNode { + constructor(text2) { + this.text = void 0; + this.text = text2; + } + /** + * Converts the text node into a DOM text node. + */ + toNode() { + return document.createTextNode(this.text); + } + /** + * Converts the text node into escaped HTML markup + * (representing the text itself). + */ + toMarkup() { + return utils.escape(this.toText()); + } + /** + * Converts the text node into a string + * (representing the text itself). + */ + toText() { + return this.text; + } + } + class SpaceNode { + /** + * Create a Space node with width given in CSS ems. + */ + constructor(width2) { + this.width = void 0; + this.character = void 0; + this.width = width2; + if (width2 >= 0.05555 && width2 <= 0.05556) { + this.character = " "; + } else if (width2 >= 0.1666 && width2 <= 0.1667) { + this.character = " "; + } else if (width2 >= 0.2222 && width2 <= 0.2223) { + this.character = " "; + } else if (width2 >= 0.2777 && width2 <= 0.2778) { + this.character = "  "; + } else if (width2 >= -0.05556 && width2 <= -0.05555) { + this.character = " ⁣"; + } else if (width2 >= -0.1667 && width2 <= -0.1666) { + this.character = " ⁣"; + } else if (width2 >= -0.2223 && width2 <= -0.2222) { + this.character = " ⁣"; + } else if (width2 >= -0.2778 && width2 <= -0.2777) { + this.character = " ⁣"; + } else { + this.character = null; + } + } + /** + * Converts the math node into a MathML-namespaced DOM element. + */ + toNode() { + if (this.character) { + return document.createTextNode(this.character); + } else { + var node2 = document.createElementNS("http://www.w3.org/1998/Math/MathML", "mspace"); + node2.setAttribute("width", makeEm(this.width)); + return node2; + } + } + /** + * Converts the math node into an HTML markup string. + */ + toMarkup() { + if (this.character) { + return "" + this.character + ""; + } else { + return ''; + } + } + /** + * Converts the math node into a string, similar to innerText. + */ + toText() { + if (this.character) { + return this.character; + } else { + return " "; + } + } + } + var mathMLTree = { + MathNode, + TextNode, + SpaceNode, + newDocumentFragment + }; + var makeText = function makeText2(text2, mode, options2) { + if (symbols[mode][text2] && symbols[mode][text2].replace && text2.charCodeAt(0) !== 55349 && !(ligatures.hasOwnProperty(text2) && options2 && (options2.fontFamily && options2.fontFamily.slice(4, 6) === "tt" || options2.font && options2.font.slice(4, 6) === "tt"))) { + text2 = symbols[mode][text2].replace; + } + return new mathMLTree.TextNode(text2); + }; + var makeRow = function makeRow2(body) { + if (body.length === 1) { + return body[0]; + } else { + return new mathMLTree.MathNode("mrow", body); + } + }; + var getVariant = function getVariant2(group, options2) { + if (options2.fontFamily === "texttt") { + return "monospace"; + } else if (options2.fontFamily === "textsf") { + if (options2.fontShape === "textit" && options2.fontWeight === "textbf") { + return "sans-serif-bold-italic"; + } else if (options2.fontShape === "textit") { + return "sans-serif-italic"; + } else if (options2.fontWeight === "textbf") { + return "bold-sans-serif"; + } else { + return "sans-serif"; + } + } else if (options2.fontShape === "textit" && options2.fontWeight === "textbf") { + return "bold-italic"; + } else if (options2.fontShape === "textit") { + return "italic"; + } else if (options2.fontWeight === "textbf") { + return "bold"; + } + var font = options2.font; + if (!font || font === "mathnormal") { + return null; + } + var mode = group.mode; + if (font === "mathit") { + return "italic"; + } else if (font === "boldsymbol") { + return group.type === "textord" ? "bold" : "bold-italic"; + } else if (font === "mathbf") { + return "bold"; + } else if (font === "mathbb") { + return "double-struck"; + } else if (font === "mathfrak") { + return "fraktur"; + } else if (font === "mathscr" || font === "mathcal") { + return "script"; + } else if (font === "mathsf") { + return "sans-serif"; + } else if (font === "mathtt") { + return "monospace"; + } + var text2 = group.text; + if (utils.contains(["\\imath", "\\jmath"], text2)) { + return null; + } + if (symbols[mode][text2] && symbols[mode][text2].replace) { + text2 = symbols[mode][text2].replace; + } + var fontName = buildCommon.fontMap[font].fontName; + if (getCharacterMetrics(text2, fontName, mode)) { + return buildCommon.fontMap[font].variant; + } + return null; + }; + var buildExpression = function buildExpression2(expression, options2, isOrdgroup) { + if (expression.length === 1) { + var group = buildGroup(expression[0], options2); + if (isOrdgroup && group instanceof MathNode && group.type === "mo") { + group.setAttribute("lspace", "0em"); + group.setAttribute("rspace", "0em"); + } + return [group]; + } + var groups = []; + var lastGroup; + for (var i2 = 0; i2 < expression.length; i2++) { + var _group = buildGroup(expression[i2], options2); + if (_group instanceof MathNode && lastGroup instanceof MathNode) { + if (_group.type === "mtext" && lastGroup.type === "mtext" && _group.getAttribute("mathvariant") === lastGroup.getAttribute("mathvariant")) { + lastGroup.children.push(..._group.children); + continue; + } else if (_group.type === "mn" && lastGroup.type === "mn") { + lastGroup.children.push(..._group.children); + continue; + } else if (_group.type === "mi" && _group.children.length === 1 && lastGroup.type === "mn") { + var child = _group.children[0]; + if (child instanceof TextNode && child.text === ".") { + lastGroup.children.push(..._group.children); + continue; + } + } else if (lastGroup.type === "mi" && lastGroup.children.length === 1) { + var lastChild = lastGroup.children[0]; + if (lastChild instanceof TextNode && lastChild.text === "̸" && (_group.type === "mo" || _group.type === "mi" || _group.type === "mn")) { + var _child = _group.children[0]; + if (_child instanceof TextNode && _child.text.length > 0) { + _child.text = _child.text.slice(0, 1) + "̸" + _child.text.slice(1); + groups.pop(); + } + } + } + } + groups.push(_group); + lastGroup = _group; + } + return groups; + }; + var buildExpressionRow = function buildExpressionRow2(expression, options2, isOrdgroup) { + return makeRow(buildExpression(expression, options2, isOrdgroup)); + }; + var buildGroup = function buildGroup2(group, options2) { + if (!group) { + return new mathMLTree.MathNode("mrow"); + } + if (_mathmlGroupBuilders[group.type]) { + var result = _mathmlGroupBuilders[group.type](group, options2); + return result; + } else { + throw new ParseError("Got group of unknown type: '" + group.type + "'"); + } + }; + function buildMathML(tree, texExpression, options2, isDisplayMode, forMathmlOnly) { + var expression = buildExpression(tree, options2); + var wrapper; + if (expression.length === 1 && expression[0] instanceof MathNode && utils.contains(["mrow", "mtable"], expression[0].type)) { + wrapper = expression[0]; + } else { + wrapper = new mathMLTree.MathNode("mrow", expression); + } + var annotation = new mathMLTree.MathNode("annotation", [new mathMLTree.TextNode(texExpression)]); + annotation.setAttribute("encoding", "application/x-tex"); + var semantics = new mathMLTree.MathNode("semantics", [wrapper, annotation]); + var math2 = new mathMLTree.MathNode("math", [semantics]); + math2.setAttribute("xmlns", "http://www.w3.org/1998/Math/MathML"); + if (isDisplayMode) { + math2.setAttribute("display", "block"); + } + var wrapperClass = forMathmlOnly ? "katex" : "katex-mathml"; + return buildCommon.makeSpan([wrapperClass], [math2]); + } + var optionsFromSettings = function optionsFromSettings2(settings) { + return new Options({ + style: settings.displayMode ? Style$1.DISPLAY : Style$1.TEXT, + maxSize: settings.maxSize, + minRuleThickness: settings.minRuleThickness + }); + }; + var displayWrap = function displayWrap2(node2, settings) { + if (settings.displayMode) { + var classes2 = ["katex-display"]; + if (settings.leqno) { + classes2.push("leqno"); + } + if (settings.fleqn) { + classes2.push("fleqn"); + } + node2 = buildCommon.makeSpan(classes2, [node2]); + } + return node2; + }; + var buildTree = function buildTree2(tree, expression, settings) { + var options2 = optionsFromSettings(settings); + var katexNode; + if (settings.output === "mathml") { + return buildMathML(tree, expression, options2, settings.displayMode, true); + } else if (settings.output === "html") { + var htmlNode = buildHTML(tree, options2); + katexNode = buildCommon.makeSpan(["katex"], [htmlNode]); + } else { + var mathMLNode = buildMathML(tree, expression, options2, settings.displayMode, false); + var _htmlNode = buildHTML(tree, options2); + katexNode = buildCommon.makeSpan(["katex"], [mathMLNode, _htmlNode]); + } + return displayWrap(katexNode, settings); + }; + var buildHTMLTree = function buildHTMLTree2(tree, expression, settings) { + var options2 = optionsFromSettings(settings); + var htmlNode = buildHTML(tree, options2); + var katexNode = buildCommon.makeSpan(["katex"], [htmlNode]); + return displayWrap(katexNode, settings); + }; + var stretchyCodePoint = { + widehat: "^", + widecheck: "ˇ", + widetilde: "~", + utilde: "~", + overleftarrow: "←", + underleftarrow: "←", + xleftarrow: "←", + overrightarrow: "→", + underrightarrow: "→", + xrightarrow: "→", + underbrace: "⏟", + overbrace: "⏞", + overgroup: "⏠", + undergroup: "⏡", + overleftrightarrow: "↔", + underleftrightarrow: "↔", + xleftrightarrow: "↔", + Overrightarrow: "⇒", + xRightarrow: "⇒", + overleftharpoon: "↼", + xleftharpoonup: "↼", + overrightharpoon: "⇀", + xrightharpoonup: "⇀", + xLeftarrow: "⇐", + xLeftrightarrow: "⇔", + xhookleftarrow: "↩", + xhookrightarrow: "↪", + xmapsto: "↦", + xrightharpoondown: "⇁", + xleftharpoondown: "↽", + xrightleftharpoons: "⇌", + xleftrightharpoons: "⇋", + xtwoheadleftarrow: "↞", + xtwoheadrightarrow: "↠", + xlongequal: "=", + xtofrom: "⇄", + xrightleftarrows: "⇄", + xrightequilibrium: "⇌", + // Not a perfect match. + xleftequilibrium: "⇋", + // None better available. + "\\cdrightarrow": "→", + "\\cdleftarrow": "←", + "\\cdlongequal": "=" + }; + var mathMLnode = function mathMLnode2(label) { + var node2 = new mathMLTree.MathNode("mo", [new mathMLTree.TextNode(stretchyCodePoint[label.replace(/^\\/, "")])]); + node2.setAttribute("stretchy", "true"); + return node2; + }; + var katexImagesData = { + // path(s), minWidth, height, align + overrightarrow: [["rightarrow"], 0.888, 522, "xMaxYMin"], + overleftarrow: [["leftarrow"], 0.888, 522, "xMinYMin"], + underrightarrow: [["rightarrow"], 0.888, 522, "xMaxYMin"], + underleftarrow: [["leftarrow"], 0.888, 522, "xMinYMin"], + xrightarrow: [["rightarrow"], 1.469, 522, "xMaxYMin"], + "\\cdrightarrow": [["rightarrow"], 3, 522, "xMaxYMin"], + // CD minwwidth2.5pc + xleftarrow: [["leftarrow"], 1.469, 522, "xMinYMin"], + "\\cdleftarrow": [["leftarrow"], 3, 522, "xMinYMin"], + Overrightarrow: [["doublerightarrow"], 0.888, 560, "xMaxYMin"], + xRightarrow: [["doublerightarrow"], 1.526, 560, "xMaxYMin"], + xLeftarrow: [["doubleleftarrow"], 1.526, 560, "xMinYMin"], + overleftharpoon: [["leftharpoon"], 0.888, 522, "xMinYMin"], + xleftharpoonup: [["leftharpoon"], 0.888, 522, "xMinYMin"], + xleftharpoondown: [["leftharpoondown"], 0.888, 522, "xMinYMin"], + overrightharpoon: [["rightharpoon"], 0.888, 522, "xMaxYMin"], + xrightharpoonup: [["rightharpoon"], 0.888, 522, "xMaxYMin"], + xrightharpoondown: [["rightharpoondown"], 0.888, 522, "xMaxYMin"], + xlongequal: [["longequal"], 0.888, 334, "xMinYMin"], + "\\cdlongequal": [["longequal"], 3, 334, "xMinYMin"], + xtwoheadleftarrow: [["twoheadleftarrow"], 0.888, 334, "xMinYMin"], + xtwoheadrightarrow: [["twoheadrightarrow"], 0.888, 334, "xMaxYMin"], + overleftrightarrow: [["leftarrow", "rightarrow"], 0.888, 522], + overbrace: [["leftbrace", "midbrace", "rightbrace"], 1.6, 548], + underbrace: [["leftbraceunder", "midbraceunder", "rightbraceunder"], 1.6, 548], + underleftrightarrow: [["leftarrow", "rightarrow"], 0.888, 522], + xleftrightarrow: [["leftarrow", "rightarrow"], 1.75, 522], + xLeftrightarrow: [["doubleleftarrow", "doublerightarrow"], 1.75, 560], + xrightleftharpoons: [["leftharpoondownplus", "rightharpoonplus"], 1.75, 716], + xleftrightharpoons: [["leftharpoonplus", "rightharpoondownplus"], 1.75, 716], + xhookleftarrow: [["leftarrow", "righthook"], 1.08, 522], + xhookrightarrow: [["lefthook", "rightarrow"], 1.08, 522], + overlinesegment: [["leftlinesegment", "rightlinesegment"], 0.888, 522], + underlinesegment: [["leftlinesegment", "rightlinesegment"], 0.888, 522], + overgroup: [["leftgroup", "rightgroup"], 0.888, 342], + undergroup: [["leftgroupunder", "rightgroupunder"], 0.888, 342], + xmapsto: [["leftmapsto", "rightarrow"], 1.5, 522], + xtofrom: [["leftToFrom", "rightToFrom"], 1.75, 528], + // The next three arrows are from the mhchem package. + // In mhchem.sty, min-length is 2.0em. But these arrows might appear in the + // document as \xrightarrow or \xrightleftharpoons. Those have + // min-length = 1.75em, so we set min-length on these next three to match. + xrightleftarrows: [["baraboveleftarrow", "rightarrowabovebar"], 1.75, 901], + xrightequilibrium: [["baraboveshortleftharpoon", "rightharpoonaboveshortbar"], 1.75, 716], + xleftequilibrium: [["shortbaraboveleftharpoon", "shortrightharpoonabovebar"], 1.75, 716] + }; + var groupLength = function groupLength2(arg) { + if (arg.type === "ordgroup") { + return arg.body.length; + } else { + return 1; + } + }; + var svgSpan = function svgSpan2(group, options2) { + function buildSvgSpan_() { + var viewBoxWidth = 4e5; + var label = group.label.slice(1); + if (utils.contains(["widehat", "widecheck", "widetilde", "utilde"], label)) { + var grp = group; + var numChars = groupLength(grp.base); + var viewBoxHeight; + var pathName; + var _height; + if (numChars > 5) { + if (label === "widehat" || label === "widecheck") { + viewBoxHeight = 420; + viewBoxWidth = 2364; + _height = 0.42; + pathName = label + "4"; + } else { + viewBoxHeight = 312; + viewBoxWidth = 2340; + _height = 0.34; + pathName = "tilde4"; + } + } else { + var imgIndex = [1, 1, 2, 2, 3, 3][numChars]; + if (label === "widehat" || label === "widecheck") { + viewBoxWidth = [0, 1062, 2364, 2364, 2364][imgIndex]; + viewBoxHeight = [0, 239, 300, 360, 420][imgIndex]; + _height = [0, 0.24, 0.3, 0.3, 0.36, 0.42][imgIndex]; + pathName = label + imgIndex; + } else { + viewBoxWidth = [0, 600, 1033, 2339, 2340][imgIndex]; + viewBoxHeight = [0, 260, 286, 306, 312][imgIndex]; + _height = [0, 0.26, 0.286, 0.3, 0.306, 0.34][imgIndex]; + pathName = "tilde" + imgIndex; + } + } + var path2 = new PathNode(pathName); + var svgNode2 = new SvgNode([path2], { + "width": "100%", + "height": makeEm(_height), + "viewBox": "0 0 " + viewBoxWidth + " " + viewBoxHeight, + "preserveAspectRatio": "none" + }); + return { + span: buildCommon.makeSvgSpan([], [svgNode2], options2), + minWidth: 0, + height: _height + }; + } else { + var spans = []; + var data = katexImagesData[label]; + var [paths, _minWidth, _viewBoxHeight] = data; + var _height2 = _viewBoxHeight / 1e3; + var numSvgChildren = paths.length; + var widthClasses; + var aligns; + if (numSvgChildren === 1) { + var align1 = data[3]; + widthClasses = ["hide-tail"]; + aligns = [align1]; + } else if (numSvgChildren === 2) { + widthClasses = ["halfarrow-left", "halfarrow-right"]; + aligns = ["xMinYMin", "xMaxYMin"]; + } else if (numSvgChildren === 3) { + widthClasses = ["brace-left", "brace-center", "brace-right"]; + aligns = ["xMinYMin", "xMidYMin", "xMaxYMin"]; + } else { + throw new Error("Correct katexImagesData or update code here to support\n " + numSvgChildren + " children."); + } + for (var i2 = 0; i2 < numSvgChildren; i2++) { + var _path = new PathNode(paths[i2]); + var _svgNode = new SvgNode([_path], { + "width": "400em", + "height": makeEm(_height2), + "viewBox": "0 0 " + viewBoxWidth + " " + _viewBoxHeight, + "preserveAspectRatio": aligns[i2] + " slice" + }); + var _span = buildCommon.makeSvgSpan([widthClasses[i2]], [_svgNode], options2); + if (numSvgChildren === 1) { + return { + span: _span, + minWidth: _minWidth, + height: _height2 + }; + } else { + _span.style.height = makeEm(_height2); + spans.push(_span); + } + } + return { + span: buildCommon.makeSpan(["stretchy"], spans, options2), + minWidth: _minWidth, + height: _height2 + }; + } + } + var { + span, + minWidth, + height + } = buildSvgSpan_(); + span.height = height; + span.style.height = makeEm(height); + if (minWidth > 0) { + span.style.minWidth = makeEm(minWidth); + } + return span; + }; + var encloseSpan = function encloseSpan2(inner2, label, topPad, bottomPad, options2) { + var img; + var totalHeight = inner2.height + inner2.depth + topPad + bottomPad; + if (/fbox|color|angl/.test(label)) { + img = buildCommon.makeSpan(["stretchy", label], [], options2); + if (label === "fbox") { + var color2 = options2.color && options2.getColor(); + if (color2) { + img.style.borderColor = color2; + } + } + } else { + var lines = []; + if (/^[bx]cancel$/.test(label)) { + lines.push(new LineNode({ + "x1": "0", + "y1": "0", + "x2": "100%", + "y2": "100%", + "stroke-width": "0.046em" + })); + } + if (/^x?cancel$/.test(label)) { + lines.push(new LineNode({ + "x1": "0", + "y1": "100%", + "x2": "100%", + "y2": "0", + "stroke-width": "0.046em" + })); + } + var svgNode2 = new SvgNode(lines, { + "width": "100%", + "height": makeEm(totalHeight) + }); + img = buildCommon.makeSvgSpan([], [svgNode2], options2); + } + img.height = totalHeight; + img.style.height = makeEm(totalHeight); + return img; + }; + var stretchy = { + encloseSpan, + mathMLnode, + svgSpan + }; + function assertNodeType(node2, type2) { + if (!node2 || node2.type !== type2) { + throw new Error("Expected node of type " + type2 + ", but got " + (node2 ? "node of type " + node2.type : String(node2))); + } + return node2; + } + function assertSymbolNodeType(node2) { + var typedNode = checkSymbolNodeType(node2); + if (!typedNode) { + throw new Error("Expected node of symbol group type, but got " + (node2 ? "node of type " + node2.type : String(node2))); + } + return typedNode; + } + function checkSymbolNodeType(node2) { + if (node2 && (node2.type === "atom" || NON_ATOMS.hasOwnProperty(node2.type))) { + return node2; + } + return null; + } + var htmlBuilder$a = (grp, options2) => { + var base; + var group; + var supSubGroup; + if (grp && grp.type === "supsub") { + group = assertNodeType(grp.base, "accent"); + base = group.base; + grp.base = base; + supSubGroup = assertSpan(buildGroup$1(grp, options2)); + grp.base = group; + } else { + group = assertNodeType(grp, "accent"); + base = group.base; + } + var body = buildGroup$1(base, options2.havingCrampedStyle()); + var mustShift = group.isShifty && utils.isCharacterBox(base); + var skew = 0; + if (mustShift) { + var baseChar = utils.getBaseElem(base); + var baseGroup = buildGroup$1(baseChar, options2.havingCrampedStyle()); + skew = assertSymbolDomNode(baseGroup).skew; + } + var accentBelow = group.label === "\\c"; + var clearance = accentBelow ? body.height + body.depth : Math.min(body.height, options2.fontMetrics().xHeight); + var accentBody; + if (!group.isStretchy) { + var accent2; + var width2; + if (group.label === "\\vec") { + accent2 = buildCommon.staticSvg("vec", options2); + width2 = buildCommon.svgData.vec[1]; + } else { + accent2 = buildCommon.makeOrd({ + mode: group.mode, + text: group.label + }, options2, "textord"); + accent2 = assertSymbolDomNode(accent2); + accent2.italic = 0; + width2 = accent2.width; + if (accentBelow) { + clearance += accent2.depth; + } + } + accentBody = buildCommon.makeSpan(["accent-body"], [accent2]); + var accentFull = group.label === "\\textcircled"; + if (accentFull) { + accentBody.classes.push("accent-full"); + clearance = body.height; + } + var left2 = skew; + if (!accentFull) { + left2 -= width2 / 2; + } + accentBody.style.left = makeEm(left2); + if (group.label === "\\textcircled") { + accentBody.style.top = ".2em"; + } + accentBody = buildCommon.makeVList({ + positionType: "firstBaseline", + children: [{ + type: "elem", + elem: body + }, { + type: "kern", + size: -clearance + }, { + type: "elem", + elem: accentBody + }] + }, options2); + } else { + accentBody = stretchy.svgSpan(group, options2); + accentBody = buildCommon.makeVList({ + positionType: "firstBaseline", + children: [{ + type: "elem", + elem: body + }, { + type: "elem", + elem: accentBody, + wrapperClasses: ["svg-align"], + wrapperStyle: skew > 0 ? { + width: "calc(100% - " + makeEm(2 * skew) + ")", + marginLeft: makeEm(2 * skew) + } : void 0 + }] + }, options2); + } + var accentWrap = buildCommon.makeSpan(["mord", "accent"], [accentBody], options2); + if (supSubGroup) { + supSubGroup.children[0] = accentWrap; + supSubGroup.height = Math.max(accentWrap.height, supSubGroup.height); + supSubGroup.classes[0] = "mord"; + return supSubGroup; + } else { + return accentWrap; + } + }; + var mathmlBuilder$9 = (group, options2) => { + var accentNode = group.isStretchy ? stretchy.mathMLnode(group.label) : new mathMLTree.MathNode("mo", [makeText(group.label, group.mode)]); + var node2 = new mathMLTree.MathNode("mover", [buildGroup(group.base, options2), accentNode]); + node2.setAttribute("accent", "true"); + return node2; + }; + var NON_STRETCHY_ACCENT_REGEX = new RegExp(["\\acute", "\\grave", "\\ddot", "\\tilde", "\\bar", "\\breve", "\\check", "\\hat", "\\vec", "\\dot", "\\mathring"].map((accent2) => "\\" + accent2).join("|")); + defineFunction({ + type: "accent", + names: ["\\acute", "\\grave", "\\ddot", "\\tilde", "\\bar", "\\breve", "\\check", "\\hat", "\\vec", "\\dot", "\\mathring", "\\widecheck", "\\widehat", "\\widetilde", "\\overrightarrow", "\\overleftarrow", "\\Overrightarrow", "\\overleftrightarrow", "\\overgroup", "\\overlinesegment", "\\overleftharpoon", "\\overrightharpoon"], + props: { + numArgs: 1 + }, + handler: (context, args) => { + var base = normalizeArgument(args[0]); + var isStretchy = !NON_STRETCHY_ACCENT_REGEX.test(context.funcName); + var isShifty = !isStretchy || context.funcName === "\\widehat" || context.funcName === "\\widetilde" || context.funcName === "\\widecheck"; + return { + type: "accent", + mode: context.parser.mode, + label: context.funcName, + isStretchy, + isShifty, + base + }; + }, + htmlBuilder: htmlBuilder$a, + mathmlBuilder: mathmlBuilder$9 + }); + defineFunction({ + type: "accent", + names: ["\\'", "\\`", "\\^", "\\~", "\\=", "\\u", "\\.", '\\"', "\\c", "\\r", "\\H", "\\v", "\\textcircled"], + props: { + numArgs: 1, + allowedInText: true, + allowedInMath: true, + // unless in strict mode + argTypes: ["primitive"] + }, + handler: (context, args) => { + var base = args[0]; + var mode = context.parser.mode; + if (mode === "math") { + context.parser.settings.reportNonstrict("mathVsTextAccents", "LaTeX's accent " + context.funcName + " works only in text mode"); + mode = "text"; + } + return { + type: "accent", + mode, + label: context.funcName, + isStretchy: false, + isShifty: true, + base + }; + }, + htmlBuilder: htmlBuilder$a, + mathmlBuilder: mathmlBuilder$9 + }); + defineFunction({ + type: "accentUnder", + names: ["\\underleftarrow", "\\underrightarrow", "\\underleftrightarrow", "\\undergroup", "\\underlinesegment", "\\utilde"], + props: { + numArgs: 1 + }, + handler: (_ref, args) => { + var { + parser: parser2, + funcName + } = _ref; + var base = args[0]; + return { + type: "accentUnder", + mode: parser2.mode, + label: funcName, + base + }; + }, + htmlBuilder: (group, options2) => { + var innerGroup = buildGroup$1(group.base, options2); + var accentBody = stretchy.svgSpan(group, options2); + var kern = group.label === "\\utilde" ? 0.12 : 0; + var vlist = buildCommon.makeVList({ + positionType: "top", + positionData: innerGroup.height, + children: [{ + type: "elem", + elem: accentBody, + wrapperClasses: ["svg-align"] + }, { + type: "kern", + size: kern + }, { + type: "elem", + elem: innerGroup + }] + }, options2); + return buildCommon.makeSpan(["mord", "accentunder"], [vlist], options2); + }, + mathmlBuilder: (group, options2) => { + var accentNode = stretchy.mathMLnode(group.label); + var node2 = new mathMLTree.MathNode("munder", [buildGroup(group.base, options2), accentNode]); + node2.setAttribute("accentunder", "true"); + return node2; + } + }); + var paddedNode = (group) => { + var node2 = new mathMLTree.MathNode("mpadded", group ? [group] : []); + node2.setAttribute("width", "+0.6em"); + node2.setAttribute("lspace", "0.3em"); + return node2; + }; + defineFunction({ + type: "xArrow", + names: [ + "\\xleftarrow", + "\\xrightarrow", + "\\xLeftarrow", + "\\xRightarrow", + "\\xleftrightarrow", + "\\xLeftrightarrow", + "\\xhookleftarrow", + "\\xhookrightarrow", + "\\xmapsto", + "\\xrightharpoondown", + "\\xrightharpoonup", + "\\xleftharpoondown", + "\\xleftharpoonup", + "\\xrightleftharpoons", + "\\xleftrightharpoons", + "\\xlongequal", + "\\xtwoheadrightarrow", + "\\xtwoheadleftarrow", + "\\xtofrom", + // The next 3 functions are here to support the mhchem extension. + // Direct use of these functions is discouraged and may break someday. + "\\xrightleftarrows", + "\\xrightequilibrium", + "\\xleftequilibrium", + // The next 3 functions are here only to support the {CD} environment. + "\\\\cdrightarrow", + "\\\\cdleftarrow", + "\\\\cdlongequal" + ], + props: { + numArgs: 1, + numOptionalArgs: 1 + }, + handler(_ref, args, optArgs) { + var { + parser: parser2, + funcName + } = _ref; + return { + type: "xArrow", + mode: parser2.mode, + label: funcName, + body: args[0], + below: optArgs[0] + }; + }, + // Flow is unable to correctly infer the type of `group`, even though it's + // unambiguously determined from the passed-in `type` above. + htmlBuilder(group, options2) { + var style = options2.style; + var newOptions = options2.havingStyle(style.sup()); + var upperGroup = buildCommon.wrapFragment(buildGroup$1(group.body, newOptions, options2), options2); + var arrowPrefix = group.label.slice(0, 2) === "\\x" ? "x" : "cd"; + upperGroup.classes.push(arrowPrefix + "-arrow-pad"); + var lowerGroup; + if (group.below) { + newOptions = options2.havingStyle(style.sub()); + lowerGroup = buildCommon.wrapFragment(buildGroup$1(group.below, newOptions, options2), options2); + lowerGroup.classes.push(arrowPrefix + "-arrow-pad"); + } + var arrowBody = stretchy.svgSpan(group, options2); + var arrowShift = -options2.fontMetrics().axisHeight + 0.5 * arrowBody.height; + var upperShift = -options2.fontMetrics().axisHeight - 0.5 * arrowBody.height - 0.111; + if (upperGroup.depth > 0.25 || group.label === "\\xleftequilibrium") { + upperShift -= upperGroup.depth; + } + var vlist; + if (lowerGroup) { + var lowerShift = -options2.fontMetrics().axisHeight + lowerGroup.height + 0.5 * arrowBody.height + 0.111; + vlist = buildCommon.makeVList({ + positionType: "individualShift", + children: [{ + type: "elem", + elem: upperGroup, + shift: upperShift + }, { + type: "elem", + elem: arrowBody, + shift: arrowShift + }, { + type: "elem", + elem: lowerGroup, + shift: lowerShift + }] + }, options2); + } else { + vlist = buildCommon.makeVList({ + positionType: "individualShift", + children: [{ + type: "elem", + elem: upperGroup, + shift: upperShift + }, { + type: "elem", + elem: arrowBody, + shift: arrowShift + }] + }, options2); + } + vlist.children[0].children[0].children[1].classes.push("svg-align"); + return buildCommon.makeSpan(["mrel", "x-arrow"], [vlist], options2); + }, + mathmlBuilder(group, options2) { + var arrowNode = stretchy.mathMLnode(group.label); + arrowNode.setAttribute("minsize", group.label.charAt(0) === "x" ? "1.75em" : "3.0em"); + var node2; + if (group.body) { + var upperNode = paddedNode(buildGroup(group.body, options2)); + if (group.below) { + var lowerNode = paddedNode(buildGroup(group.below, options2)); + node2 = new mathMLTree.MathNode("munderover", [arrowNode, lowerNode, upperNode]); + } else { + node2 = new mathMLTree.MathNode("mover", [arrowNode, upperNode]); + } + } else if (group.below) { + var _lowerNode = paddedNode(buildGroup(group.below, options2)); + node2 = new mathMLTree.MathNode("munder", [arrowNode, _lowerNode]); + } else { + node2 = paddedNode(); + node2 = new mathMLTree.MathNode("mover", [arrowNode, node2]); + } + return node2; + } + }); + var makeSpan = buildCommon.makeSpan; + function htmlBuilder$9(group, options2) { + var elements2 = buildExpression$1(group.body, options2, true); + return makeSpan([group.mclass], elements2, options2); + } + function mathmlBuilder$8(group, options2) { + var node2; + var inner2 = buildExpression(group.body, options2); + if (group.mclass === "minner") { + node2 = new mathMLTree.MathNode("mpadded", inner2); + } else if (group.mclass === "mord") { + if (group.isCharacterBox) { + node2 = inner2[0]; + node2.type = "mi"; + } else { + node2 = new mathMLTree.MathNode("mi", inner2); + } + } else { + if (group.isCharacterBox) { + node2 = inner2[0]; + node2.type = "mo"; + } else { + node2 = new mathMLTree.MathNode("mo", inner2); + } + if (group.mclass === "mbin") { + node2.attributes.lspace = "0.22em"; + node2.attributes.rspace = "0.22em"; + } else if (group.mclass === "mpunct") { + node2.attributes.lspace = "0em"; + node2.attributes.rspace = "0.17em"; + } else if (group.mclass === "mopen" || group.mclass === "mclose") { + node2.attributes.lspace = "0em"; + node2.attributes.rspace = "0em"; + } else if (group.mclass === "minner") { + node2.attributes.lspace = "0.0556em"; + node2.attributes.width = "+0.1111em"; + } + } + return node2; + } + defineFunction({ + type: "mclass", + names: ["\\mathord", "\\mathbin", "\\mathrel", "\\mathopen", "\\mathclose", "\\mathpunct", "\\mathinner"], + props: { + numArgs: 1, + primitive: true + }, + handler(_ref, args) { + var { + parser: parser2, + funcName + } = _ref; + var body = args[0]; + return { + type: "mclass", + mode: parser2.mode, + mclass: "m" + funcName.slice(5), + // TODO(kevinb): don't prefix with 'm' + body: ordargument(body), + isCharacterBox: utils.isCharacterBox(body) + }; + }, + htmlBuilder: htmlBuilder$9, + mathmlBuilder: mathmlBuilder$8 + }); + var binrelClass = (arg) => { + var atom = arg.type === "ordgroup" && arg.body.length ? arg.body[0] : arg; + if (atom.type === "atom" && (atom.family === "bin" || atom.family === "rel")) { + return "m" + atom.family; + } else { + return "mord"; + } + }; + defineFunction({ + type: "mclass", + names: ["\\@binrel"], + props: { + numArgs: 2 + }, + handler(_ref2, args) { + var { + parser: parser2 + } = _ref2; + return { + type: "mclass", + mode: parser2.mode, + mclass: binrelClass(args[0]), + body: ordargument(args[1]), + isCharacterBox: utils.isCharacterBox(args[1]) + }; + } + }); + defineFunction({ + type: "mclass", + names: ["\\stackrel", "\\overset", "\\underset"], + props: { + numArgs: 2 + }, + handler(_ref3, args) { + var { + parser: parser2, + funcName + } = _ref3; + var baseArg = args[1]; + var shiftedArg = args[0]; + var mclass; + if (funcName !== "\\stackrel") { + mclass = binrelClass(baseArg); + } else { + mclass = "mrel"; + } + var baseOp = { + type: "op", + mode: baseArg.mode, + limits: true, + alwaysHandleSupSub: true, + parentIsSupSub: false, + symbol: false, + suppressBaseShift: funcName !== "\\stackrel", + body: ordargument(baseArg) + }; + var supsub = { + type: "supsub", + mode: shiftedArg.mode, + base: baseOp, + sup: funcName === "\\underset" ? null : shiftedArg, + sub: funcName === "\\underset" ? shiftedArg : null + }; + return { + type: "mclass", + mode: parser2.mode, + mclass, + body: [supsub], + isCharacterBox: utils.isCharacterBox(supsub) + }; + }, + htmlBuilder: htmlBuilder$9, + mathmlBuilder: mathmlBuilder$8 + }); + defineFunction({ + type: "pmb", + names: ["\\pmb"], + props: { + numArgs: 1, + allowedInText: true + }, + handler(_ref, args) { + var { + parser: parser2 + } = _ref; + return { + type: "pmb", + mode: parser2.mode, + mclass: binrelClass(args[0]), + body: ordargument(args[0]) + }; + }, + htmlBuilder(group, options2) { + var elements2 = buildExpression$1(group.body, options2, true); + var node2 = buildCommon.makeSpan([group.mclass], elements2, options2); + node2.style.textShadow = "0.02em 0.01em 0.04px"; + return node2; + }, + mathmlBuilder(group, style) { + var inner2 = buildExpression(group.body, style); + var node2 = new mathMLTree.MathNode("mstyle", inner2); + node2.setAttribute("style", "text-shadow: 0.02em 0.01em 0.04px"); + return node2; + } + }); + var cdArrowFunctionName = { + ">": "\\\\cdrightarrow", + "<": "\\\\cdleftarrow", + "=": "\\\\cdlongequal", + "A": "\\uparrow", + "V": "\\downarrow", + "|": "\\Vert", + ".": "no arrow" + }; + var newCell = () => { + return { + type: "styling", + body: [], + mode: "math", + style: "display" + }; + }; + var isStartOfArrow = (node2) => { + return node2.type === "textord" && node2.text === "@"; + }; + var isLabelEnd = (node2, endChar) => { + return (node2.type === "mathord" || node2.type === "atom") && node2.text === endChar; + }; + function cdArrow(arrowChar, labels, parser2) { + var funcName = cdArrowFunctionName[arrowChar]; + switch (funcName) { + case "\\\\cdrightarrow": + case "\\\\cdleftarrow": + return parser2.callFunction(funcName, [labels[0]], [labels[1]]); + case "\\uparrow": + case "\\downarrow": { + var leftLabel = parser2.callFunction("\\\\cdleft", [labels[0]], []); + var bareArrow = { + type: "atom", + text: funcName, + mode: "math", + family: "rel" + }; + var sizedArrow = parser2.callFunction("\\Big", [bareArrow], []); + var rightLabel = parser2.callFunction("\\\\cdright", [labels[1]], []); + var arrowGroup = { + type: "ordgroup", + mode: "math", + body: [leftLabel, sizedArrow, rightLabel] + }; + return parser2.callFunction("\\\\cdparent", [arrowGroup], []); + } + case "\\\\cdlongequal": + return parser2.callFunction("\\\\cdlongequal", [], []); + case "\\Vert": { + var arrow = { + type: "textord", + text: "\\Vert", + mode: "math" + }; + return parser2.callFunction("\\Big", [arrow], []); + } + default: + return { + type: "textord", + text: " ", + mode: "math" + }; + } + } + function parseCD(parser2) { + var parsedRows = []; + parser2.gullet.beginGroup(); + parser2.gullet.macros.set("\\cr", "\\\\\\relax"); + parser2.gullet.beginGroup(); + while (true) { + parsedRows.push(parser2.parseExpression(false, "\\\\")); + parser2.gullet.endGroup(); + parser2.gullet.beginGroup(); + var next2 = parser2.fetch().text; + if (next2 === "&" || next2 === "\\\\") { + parser2.consume(); + } else if (next2 === "\\end") { + if (parsedRows[parsedRows.length - 1].length === 0) { + parsedRows.pop(); + } + break; + } else { + throw new ParseError("Expected \\\\ or \\cr or \\end", parser2.nextToken); + } + } + var row = []; + var body = [row]; + for (var i2 = 0; i2 < parsedRows.length; i2++) { + var rowNodes = parsedRows[i2]; + var cell = newCell(); + for (var j = 0; j < rowNodes.length; j++) { + if (!isStartOfArrow(rowNodes[j])) { + cell.body.push(rowNodes[j]); + } else { + row.push(cell); + j += 1; + var arrowChar = assertSymbolNodeType(rowNodes[j]).text; + var labels = new Array(2); + labels[0] = { + type: "ordgroup", + mode: "math", + body: [] + }; + labels[1] = { + type: "ordgroup", + mode: "math", + body: [] + }; + if ("=|.".indexOf(arrowChar) > -1) + ; + else if ("<>AV".indexOf(arrowChar) > -1) { + for (var labelNum = 0; labelNum < 2; labelNum++) { + var inLabel = true; + for (var k = j + 1; k < rowNodes.length; k++) { + if (isLabelEnd(rowNodes[k], arrowChar)) { + inLabel = false; + j = k; + break; + } + if (isStartOfArrow(rowNodes[k])) { + throw new ParseError("Missing a " + arrowChar + " character to complete a CD arrow.", rowNodes[k]); + } + labels[labelNum].body.push(rowNodes[k]); + } + if (inLabel) { + throw new ParseError("Missing a " + arrowChar + " character to complete a CD arrow.", rowNodes[j]); + } + } + } else { + throw new ParseError('Expected one of "<>AV=|." after @', rowNodes[j]); + } + var arrow = cdArrow(arrowChar, labels, parser2); + var wrappedArrow = { + type: "styling", + body: [arrow], + mode: "math", + style: "display" + // CD is always displaystyle. + }; + row.push(wrappedArrow); + cell = newCell(); + } + } + if (i2 % 2 === 0) { + row.push(cell); + } else { + row.shift(); + } + row = []; + body.push(row); + } + parser2.gullet.endGroup(); + parser2.gullet.endGroup(); + var cols = new Array(body[0].length).fill({ + type: "align", + align: "c", + pregap: 0.25, + // CD package sets \enskip between columns. + postgap: 0.25 + // So pre and post each get half an \enskip, i.e. 0.25em. + }); + return { + type: "array", + mode: "math", + body, + arraystretch: 1, + addJot: true, + rowGaps: [null], + cols, + colSeparationType: "CD", + hLinesBeforeRow: new Array(body.length + 1).fill([]) + }; + } + defineFunction({ + type: "cdlabel", + names: ["\\\\cdleft", "\\\\cdright"], + props: { + numArgs: 1 + }, + handler(_ref, args) { + var { + parser: parser2, + funcName + } = _ref; + return { + type: "cdlabel", + mode: parser2.mode, + side: funcName.slice(4), + label: args[0] + }; + }, + htmlBuilder(group, options2) { + var newOptions = options2.havingStyle(options2.style.sup()); + var label = buildCommon.wrapFragment(buildGroup$1(group.label, newOptions, options2), options2); + label.classes.push("cd-label-" + group.side); + label.style.bottom = makeEm(0.8 - label.depth); + label.height = 0; + label.depth = 0; + return label; + }, + mathmlBuilder(group, options2) { + var label = new mathMLTree.MathNode("mrow", [buildGroup(group.label, options2)]); + label = new mathMLTree.MathNode("mpadded", [label]); + label.setAttribute("width", "0"); + if (group.side === "left") { + label.setAttribute("lspace", "-1width"); + } + label.setAttribute("voffset", "0.7em"); + label = new mathMLTree.MathNode("mstyle", [label]); + label.setAttribute("displaystyle", "false"); + label.setAttribute("scriptlevel", "1"); + return label; + } + }); + defineFunction({ + type: "cdlabelparent", + names: ["\\\\cdparent"], + props: { + numArgs: 1 + }, + handler(_ref2, args) { + var { + parser: parser2 + } = _ref2; + return { + type: "cdlabelparent", + mode: parser2.mode, + fragment: args[0] + }; + }, + htmlBuilder(group, options2) { + var parent = buildCommon.wrapFragment(buildGroup$1(group.fragment, options2), options2); + parent.classes.push("cd-vert-arrow"); + return parent; + }, + mathmlBuilder(group, options2) { + return new mathMLTree.MathNode("mrow", [buildGroup(group.fragment, options2)]); + } + }); + defineFunction({ + type: "textord", + names: ["\\@char"], + props: { + numArgs: 1, + allowedInText: true + }, + handler(_ref, args) { + var { + parser: parser2 + } = _ref; + var arg = assertNodeType(args[0], "ordgroup"); + var group = arg.body; + var number2 = ""; + for (var i2 = 0; i2 < group.length; i2++) { + var node2 = assertNodeType(group[i2], "textord"); + number2 += node2.text; + } + var code = parseInt(number2); + var text2; + if (isNaN(code)) { + throw new ParseError("\\@char has non-numeric argument " + number2); + } else if (code < 0 || code >= 1114111) { + throw new ParseError("\\@char with invalid code point " + number2); + } else if (code <= 65535) { + text2 = String.fromCharCode(code); + } else { + code -= 65536; + text2 = String.fromCharCode((code >> 10) + 55296, (code & 1023) + 56320); + } + return { + type: "textord", + mode: parser2.mode, + text: text2 + }; + } + }); + var htmlBuilder$8 = (group, options2) => { + var elements2 = buildExpression$1(group.body, options2.withColor(group.color), false); + return buildCommon.makeFragment(elements2); + }; + var mathmlBuilder$7 = (group, options2) => { + var inner2 = buildExpression(group.body, options2.withColor(group.color)); + var node2 = new mathMLTree.MathNode("mstyle", inner2); + node2.setAttribute("mathcolor", group.color); + return node2; + }; + defineFunction({ + type: "color", + names: ["\\textcolor"], + props: { + numArgs: 2, + allowedInText: true, + argTypes: ["color", "original"] + }, + handler(_ref, args) { + var { + parser: parser2 + } = _ref; + var color2 = assertNodeType(args[0], "color-token").color; + var body = args[1]; + return { + type: "color", + mode: parser2.mode, + color: color2, + body: ordargument(body) + }; + }, + htmlBuilder: htmlBuilder$8, + mathmlBuilder: mathmlBuilder$7 + }); + defineFunction({ + type: "color", + names: ["\\color"], + props: { + numArgs: 1, + allowedInText: true, + argTypes: ["color"] + }, + handler(_ref2, args) { + var { + parser: parser2, + breakOnTokenText + } = _ref2; + var color2 = assertNodeType(args[0], "color-token").color; + parser2.gullet.macros.set("\\current@color", color2); + var body = parser2.parseExpression(true, breakOnTokenText); + return { + type: "color", + mode: parser2.mode, + color: color2, + body + }; + }, + htmlBuilder: htmlBuilder$8, + mathmlBuilder: mathmlBuilder$7 + }); + defineFunction({ + type: "cr", + names: ["\\\\"], + props: { + numArgs: 0, + numOptionalArgs: 0, + allowedInText: true + }, + handler(_ref, args, optArgs) { + var { + parser: parser2 + } = _ref; + var size2 = parser2.gullet.future().text === "[" ? parser2.parseSizeGroup(true) : null; + var newLine = !parser2.settings.displayMode || !parser2.settings.useStrictBehavior("newLineInDisplayMode", "In LaTeX, \\\\ or \\newline does nothing in display mode"); + return { + type: "cr", + mode: parser2.mode, + newLine, + size: size2 && assertNodeType(size2, "size").value + }; + }, + // The following builders are called only at the top level, + // not within tabular/array environments. + htmlBuilder(group, options2) { + var span = buildCommon.makeSpan(["mspace"], [], options2); + if (group.newLine) { + span.classes.push("newline"); + if (group.size) { + span.style.marginTop = makeEm(calculateSize(group.size, options2)); + } + } + return span; + }, + mathmlBuilder(group, options2) { + var node2 = new mathMLTree.MathNode("mspace"); + if (group.newLine) { + node2.setAttribute("linebreak", "newline"); + if (group.size) { + node2.setAttribute("height", makeEm(calculateSize(group.size, options2))); + } + } + return node2; + } + }); + var globalMap = { + "\\global": "\\global", + "\\long": "\\\\globallong", + "\\\\globallong": "\\\\globallong", + "\\def": "\\gdef", + "\\gdef": "\\gdef", + "\\edef": "\\xdef", + "\\xdef": "\\xdef", + "\\let": "\\\\globallet", + "\\futurelet": "\\\\globalfuture" + }; + var checkControlSequence = (tok) => { + var name = tok.text; + if (/^(?:[\\{}$&#^_]|EOF)$/.test(name)) { + throw new ParseError("Expected a control sequence", tok); + } + return name; + }; + var getRHS = (parser2) => { + var tok = parser2.gullet.popToken(); + if (tok.text === "=") { + tok = parser2.gullet.popToken(); + if (tok.text === " ") { + tok = parser2.gullet.popToken(); + } + } + return tok; + }; + var letCommand = (parser2, name, tok, global2) => { + var macro = parser2.gullet.macros.get(tok.text); + if (macro == null) { + tok.noexpand = true; + macro = { + tokens: [tok], + numArgs: 0, + // reproduce the same behavior in expansion + unexpandable: !parser2.gullet.isExpandable(tok.text) + }; + } + parser2.gullet.macros.set(name, macro, global2); + }; + defineFunction({ + type: "internal", + names: [ + "\\global", + "\\long", + "\\\\globallong" + // can’t be entered directly + ], + props: { + numArgs: 0, + allowedInText: true + }, + handler(_ref) { + var { + parser: parser2, + funcName + } = _ref; + parser2.consumeSpaces(); + var token2 = parser2.fetch(); + if (globalMap[token2.text]) { + if (funcName === "\\global" || funcName === "\\\\globallong") { + token2.text = globalMap[token2.text]; + } + return assertNodeType(parser2.parseFunction(), "internal"); + } + throw new ParseError("Invalid token after macro prefix", token2); + } + }); + defineFunction({ + type: "internal", + names: ["\\def", "\\gdef", "\\edef", "\\xdef"], + props: { + numArgs: 0, + allowedInText: true, + primitive: true + }, + handler(_ref2) { + var { + parser: parser2, + funcName + } = _ref2; + var tok = parser2.gullet.popToken(); + var name = tok.text; + if (/^(?:[\\{}$&#^_]|EOF)$/.test(name)) { + throw new ParseError("Expected a control sequence", tok); + } + var numArgs = 0; + var insert; + var delimiters2 = [[]]; + while (parser2.gullet.future().text !== "{") { + tok = parser2.gullet.popToken(); + if (tok.text === "#") { + if (parser2.gullet.future().text === "{") { + insert = parser2.gullet.future(); + delimiters2[numArgs].push("{"); + break; + } + tok = parser2.gullet.popToken(); + if (!/^[1-9]$/.test(tok.text)) { + throw new ParseError('Invalid argument number "' + tok.text + '"'); + } + if (parseInt(tok.text) !== numArgs + 1) { + throw new ParseError('Argument number "' + tok.text + '" out of order'); + } + numArgs++; + delimiters2.push([]); + } else if (tok.text === "EOF") { + throw new ParseError("Expected a macro definition"); + } else { + delimiters2[numArgs].push(tok.text); + } + } + var { + tokens + } = parser2.gullet.consumeArg(); + if (insert) { + tokens.unshift(insert); + } + if (funcName === "\\edef" || funcName === "\\xdef") { + tokens = parser2.gullet.expandTokens(tokens); + tokens.reverse(); + } + parser2.gullet.macros.set(name, { + tokens, + numArgs, + delimiters: delimiters2 + }, funcName === globalMap[funcName]); + return { + type: "internal", + mode: parser2.mode + }; + } + }); + defineFunction({ + type: "internal", + names: [ + "\\let", + "\\\\globallet" + // can’t be entered directly + ], + props: { + numArgs: 0, + allowedInText: true, + primitive: true + }, + handler(_ref3) { + var { + parser: parser2, + funcName + } = _ref3; + var name = checkControlSequence(parser2.gullet.popToken()); + parser2.gullet.consumeSpaces(); + var tok = getRHS(parser2); + letCommand(parser2, name, tok, funcName === "\\\\globallet"); + return { + type: "internal", + mode: parser2.mode + }; + } + }); + defineFunction({ + type: "internal", + names: [ + "\\futurelet", + "\\\\globalfuture" + // can’t be entered directly + ], + props: { + numArgs: 0, + allowedInText: true, + primitive: true + }, + handler(_ref4) { + var { + parser: parser2, + funcName + } = _ref4; + var name = checkControlSequence(parser2.gullet.popToken()); + var middle = parser2.gullet.popToken(); + var tok = parser2.gullet.popToken(); + letCommand(parser2, name, tok, funcName === "\\\\globalfuture"); + parser2.gullet.pushToken(tok); + parser2.gullet.pushToken(middle); + return { + type: "internal", + mode: parser2.mode + }; + } + }); + var getMetrics = function getMetrics2(symbol, font, mode) { + var replace2 = symbols.math[symbol] && symbols.math[symbol].replace; + var metrics = getCharacterMetrics(replace2 || symbol, font, mode); + if (!metrics) { + throw new Error("Unsupported symbol " + symbol + " and font size " + font + "."); + } + return metrics; + }; + var styleWrap = function styleWrap2(delim, toStyle, options2, classes2) { + var newOptions = options2.havingBaseStyle(toStyle); + var span = buildCommon.makeSpan(classes2.concat(newOptions.sizingClasses(options2)), [delim], options2); + var delimSizeMultiplier = newOptions.sizeMultiplier / options2.sizeMultiplier; + span.height *= delimSizeMultiplier; + span.depth *= delimSizeMultiplier; + span.maxFontSize = newOptions.sizeMultiplier; + return span; + }; + var centerSpan = function centerSpan2(span, options2, style) { + var newOptions = options2.havingBaseStyle(style); + var shift = (1 - options2.sizeMultiplier / newOptions.sizeMultiplier) * options2.fontMetrics().axisHeight; + span.classes.push("delimcenter"); + span.style.top = makeEm(shift); + span.height -= shift; + span.depth += shift; + }; + var makeSmallDelim = function makeSmallDelim2(delim, style, center2, options2, mode, classes2) { + var text2 = buildCommon.makeSymbol(delim, "Main-Regular", mode, options2); + var span = styleWrap(text2, style, options2, classes2); + if (center2) { + centerSpan(span, options2, style); + } + return span; + }; + var mathrmSize = function mathrmSize2(value2, size2, mode, options2) { + return buildCommon.makeSymbol(value2, "Size" + size2 + "-Regular", mode, options2); + }; + var makeLargeDelim = function makeLargeDelim2(delim, size2, center2, options2, mode, classes2) { + var inner2 = mathrmSize(delim, size2, mode, options2); + var span = styleWrap(buildCommon.makeSpan(["delimsizing", "size" + size2], [inner2], options2), Style$1.TEXT, options2, classes2); + if (center2) { + centerSpan(span, options2, Style$1.TEXT); + } + return span; + }; + var makeGlyphSpan = function makeGlyphSpan2(symbol, font, mode) { + var sizeClass; + if (font === "Size1-Regular") { + sizeClass = "delim-size1"; + } else { + sizeClass = "delim-size4"; + } + var corner = buildCommon.makeSpan(["delimsizinginner", sizeClass], [buildCommon.makeSpan([], [buildCommon.makeSymbol(symbol, font, mode)])]); + return { + type: "elem", + elem: corner + }; + }; + var makeInner = function makeInner2(ch2, height, options2) { + var width2 = fontMetricsData["Size4-Regular"][ch2.charCodeAt(0)] ? fontMetricsData["Size4-Regular"][ch2.charCodeAt(0)][4] : fontMetricsData["Size1-Regular"][ch2.charCodeAt(0)][4]; + var path2 = new PathNode("inner", innerPath(ch2, Math.round(1e3 * height))); + var svgNode2 = new SvgNode([path2], { + "width": makeEm(width2), + "height": makeEm(height), + // Override CSS rule `.katex svg { width: 100% }` + "style": "width:" + makeEm(width2), + "viewBox": "0 0 " + 1e3 * width2 + " " + Math.round(1e3 * height), + "preserveAspectRatio": "xMinYMin" + }); + var span = buildCommon.makeSvgSpan([], [svgNode2], options2); + span.height = height; + span.style.height = makeEm(height); + span.style.width = makeEm(width2); + return { + type: "elem", + elem: span + }; + }; + var lapInEms = 8e-3; + var lap = { + type: "kern", + size: -1 * lapInEms + }; + var verts = ["|", "\\lvert", "\\rvert", "\\vert"]; + var doubleVerts = ["\\|", "\\lVert", "\\rVert", "\\Vert"]; + var makeStackedDelim = function makeStackedDelim2(delim, heightTotal, center2, options2, mode, classes2) { + var top2; + var middle; + var repeat2; + var bottom2; + var svgLabel = ""; + var viewBoxWidth = 0; + top2 = repeat2 = bottom2 = delim; + middle = null; + var font = "Size1-Regular"; + if (delim === "\\uparrow") { + repeat2 = bottom2 = "⏐"; + } else if (delim === "\\Uparrow") { + repeat2 = bottom2 = "‖"; + } else if (delim === "\\downarrow") { + top2 = repeat2 = "⏐"; + } else if (delim === "\\Downarrow") { + top2 = repeat2 = "‖"; + } else if (delim === "\\updownarrow") { + top2 = "\\uparrow"; + repeat2 = "⏐"; + bottom2 = "\\downarrow"; + } else if (delim === "\\Updownarrow") { + top2 = "\\Uparrow"; + repeat2 = "‖"; + bottom2 = "\\Downarrow"; + } else if (utils.contains(verts, delim)) { + repeat2 = "∣"; + svgLabel = "vert"; + viewBoxWidth = 333; + } else if (utils.contains(doubleVerts, delim)) { + repeat2 = "∥"; + svgLabel = "doublevert"; + viewBoxWidth = 556; + } else if (delim === "[" || delim === "\\lbrack") { + top2 = "⎡"; + repeat2 = "⎢"; + bottom2 = "⎣"; + font = "Size4-Regular"; + svgLabel = "lbrack"; + viewBoxWidth = 667; + } else if (delim === "]" || delim === "\\rbrack") { + top2 = "⎤"; + repeat2 = "⎥"; + bottom2 = "⎦"; + font = "Size4-Regular"; + svgLabel = "rbrack"; + viewBoxWidth = 667; + } else if (delim === "\\lfloor" || delim === "⌊") { + repeat2 = top2 = "⎢"; + bottom2 = "⎣"; + font = "Size4-Regular"; + svgLabel = "lfloor"; + viewBoxWidth = 667; + } else if (delim === "\\lceil" || delim === "⌈") { + top2 = "⎡"; + repeat2 = bottom2 = "⎢"; + font = "Size4-Regular"; + svgLabel = "lceil"; + viewBoxWidth = 667; + } else if (delim === "\\rfloor" || delim === "⌋") { + repeat2 = top2 = "⎥"; + bottom2 = "⎦"; + font = "Size4-Regular"; + svgLabel = "rfloor"; + viewBoxWidth = 667; + } else if (delim === "\\rceil" || delim === "⌉") { + top2 = "⎤"; + repeat2 = bottom2 = "⎥"; + font = "Size4-Regular"; + svgLabel = "rceil"; + viewBoxWidth = 667; + } else if (delim === "(" || delim === "\\lparen") { + top2 = "⎛"; + repeat2 = "⎜"; + bottom2 = "⎝"; + font = "Size4-Regular"; + svgLabel = "lparen"; + viewBoxWidth = 875; + } else if (delim === ")" || delim === "\\rparen") { + top2 = "⎞"; + repeat2 = "⎟"; + bottom2 = "⎠"; + font = "Size4-Regular"; + svgLabel = "rparen"; + viewBoxWidth = 875; + } else if (delim === "\\{" || delim === "\\lbrace") { + top2 = "⎧"; + middle = "⎨"; + bottom2 = "⎩"; + repeat2 = "⎪"; + font = "Size4-Regular"; + } else if (delim === "\\}" || delim === "\\rbrace") { + top2 = "⎫"; + middle = "⎬"; + bottom2 = "⎭"; + repeat2 = "⎪"; + font = "Size4-Regular"; + } else if (delim === "\\lgroup" || delim === "⟮") { + top2 = "⎧"; + bottom2 = "⎩"; + repeat2 = "⎪"; + font = "Size4-Regular"; + } else if (delim === "\\rgroup" || delim === "⟯") { + top2 = "⎫"; + bottom2 = "⎭"; + repeat2 = "⎪"; + font = "Size4-Regular"; + } else if (delim === "\\lmoustache" || delim === "⎰") { + top2 = "⎧"; + bottom2 = "⎭"; + repeat2 = "⎪"; + font = "Size4-Regular"; + } else if (delim === "\\rmoustache" || delim === "⎱") { + top2 = "⎫"; + bottom2 = "⎩"; + repeat2 = "⎪"; + font = "Size4-Regular"; + } + var topMetrics = getMetrics(top2, font, mode); + var topHeightTotal = topMetrics.height + topMetrics.depth; + var repeatMetrics = getMetrics(repeat2, font, mode); + var repeatHeightTotal = repeatMetrics.height + repeatMetrics.depth; + var bottomMetrics = getMetrics(bottom2, font, mode); + var bottomHeightTotal = bottomMetrics.height + bottomMetrics.depth; + var middleHeightTotal = 0; + var middleFactor = 1; + if (middle !== null) { + var middleMetrics = getMetrics(middle, font, mode); + middleHeightTotal = middleMetrics.height + middleMetrics.depth; + middleFactor = 2; + } + var minHeight = topHeightTotal + bottomHeightTotal + middleHeightTotal; + var repeatCount = Math.max(0, Math.ceil((heightTotal - minHeight) / (middleFactor * repeatHeightTotal))); + var realHeightTotal = minHeight + repeatCount * middleFactor * repeatHeightTotal; + var axisHeight = options2.fontMetrics().axisHeight; + if (center2) { + axisHeight *= options2.sizeMultiplier; + } + var depth = realHeightTotal / 2 - axisHeight; + var stack = []; + if (svgLabel.length > 0) { + var midHeight = realHeightTotal - topHeightTotal - bottomHeightTotal; + var viewBoxHeight = Math.round(realHeightTotal * 1e3); + var pathStr = tallDelim(svgLabel, Math.round(midHeight * 1e3)); + var path2 = new PathNode(svgLabel, pathStr); + var width2 = (viewBoxWidth / 1e3).toFixed(3) + "em"; + var height = (viewBoxHeight / 1e3).toFixed(3) + "em"; + var svg2 = new SvgNode([path2], { + "width": width2, + "height": height, + "viewBox": "0 0 " + viewBoxWidth + " " + viewBoxHeight + }); + var wrapper = buildCommon.makeSvgSpan([], [svg2], options2); + wrapper.height = viewBoxHeight / 1e3; + wrapper.style.width = width2; + wrapper.style.height = height; + stack.push({ + type: "elem", + elem: wrapper + }); + } else { + stack.push(makeGlyphSpan(bottom2, font, mode)); + stack.push(lap); + if (middle === null) { + var innerHeight = realHeightTotal - topHeightTotal - bottomHeightTotal + 2 * lapInEms; + stack.push(makeInner(repeat2, innerHeight, options2)); + } else { + var _innerHeight = (realHeightTotal - topHeightTotal - bottomHeightTotal - middleHeightTotal) / 2 + 2 * lapInEms; + stack.push(makeInner(repeat2, _innerHeight, options2)); + stack.push(lap); + stack.push(makeGlyphSpan(middle, font, mode)); + stack.push(lap); + stack.push(makeInner(repeat2, _innerHeight, options2)); + } + stack.push(lap); + stack.push(makeGlyphSpan(top2, font, mode)); + } + var newOptions = options2.havingBaseStyle(Style$1.TEXT); + var inner2 = buildCommon.makeVList({ + positionType: "bottom", + positionData: depth, + children: stack + }, newOptions); + return styleWrap(buildCommon.makeSpan(["delimsizing", "mult"], [inner2], newOptions), Style$1.TEXT, options2, classes2); + }; + var vbPad = 80; + var emPad = 0.08; + var sqrtSvg = function sqrtSvg2(sqrtName, height, viewBoxHeight, extraVinculum, options2) { + var path2 = sqrtPath(sqrtName, extraVinculum, viewBoxHeight); + var pathNode = new PathNode(sqrtName, path2); + var svg2 = new SvgNode([pathNode], { + // Note: 1000:1 ratio of viewBox to document em width. + "width": "400em", + "height": makeEm(height), + "viewBox": "0 0 400000 " + viewBoxHeight, + "preserveAspectRatio": "xMinYMin slice" + }); + return buildCommon.makeSvgSpan(["hide-tail"], [svg2], options2); + }; + var makeSqrtImage = function makeSqrtImage2(height, options2) { + var newOptions = options2.havingBaseSizing(); + var delim = traverseSequence("\\surd", height * newOptions.sizeMultiplier, stackLargeDelimiterSequence, newOptions); + var sizeMultiplier = newOptions.sizeMultiplier; + var extraVinculum = Math.max(0, options2.minRuleThickness - options2.fontMetrics().sqrtRuleThickness); + var span; + var spanHeight = 0; + var texHeight = 0; + var viewBoxHeight = 0; + var advanceWidth; + if (delim.type === "small") { + viewBoxHeight = 1e3 + 1e3 * extraVinculum + vbPad; + if (height < 1) { + sizeMultiplier = 1; + } else if (height < 1.4) { + sizeMultiplier = 0.7; + } + spanHeight = (1 + extraVinculum + emPad) / sizeMultiplier; + texHeight = (1 + extraVinculum) / sizeMultiplier; + span = sqrtSvg("sqrtMain", spanHeight, viewBoxHeight, extraVinculum, options2); + span.style.minWidth = "0.853em"; + advanceWidth = 0.833 / sizeMultiplier; + } else if (delim.type === "large") { + viewBoxHeight = (1e3 + vbPad) * sizeToMaxHeight[delim.size]; + texHeight = (sizeToMaxHeight[delim.size] + extraVinculum) / sizeMultiplier; + spanHeight = (sizeToMaxHeight[delim.size] + extraVinculum + emPad) / sizeMultiplier; + span = sqrtSvg("sqrtSize" + delim.size, spanHeight, viewBoxHeight, extraVinculum, options2); + span.style.minWidth = "1.02em"; + advanceWidth = 1 / sizeMultiplier; + } else { + spanHeight = height + extraVinculum + emPad; + texHeight = height + extraVinculum; + viewBoxHeight = Math.floor(1e3 * height + extraVinculum) + vbPad; + span = sqrtSvg("sqrtTall", spanHeight, viewBoxHeight, extraVinculum, options2); + span.style.minWidth = "0.742em"; + advanceWidth = 1.056; + } + span.height = texHeight; + span.style.height = makeEm(spanHeight); + return { + span, + advanceWidth, + // Calculate the actual line width. + // This actually should depend on the chosen font -- e.g. \boldmath + // should use the thicker surd symbols from e.g. KaTeX_Main-Bold, and + // have thicker rules. + ruleWidth: (options2.fontMetrics().sqrtRuleThickness + extraVinculum) * sizeMultiplier + }; + }; + var stackLargeDelimiters = ["(", "\\lparen", ")", "\\rparen", "[", "\\lbrack", "]", "\\rbrack", "\\{", "\\lbrace", "\\}", "\\rbrace", "\\lfloor", "\\rfloor", "⌊", "⌋", "\\lceil", "\\rceil", "⌈", "⌉", "\\surd"]; + var stackAlwaysDelimiters = ["\\uparrow", "\\downarrow", "\\updownarrow", "\\Uparrow", "\\Downarrow", "\\Updownarrow", "|", "\\|", "\\vert", "\\Vert", "\\lvert", "\\rvert", "\\lVert", "\\rVert", "\\lgroup", "\\rgroup", "⟮", "⟯", "\\lmoustache", "\\rmoustache", "⎰", "⎱"]; + var stackNeverDelimiters = ["<", ">", "\\langle", "\\rangle", "/", "\\backslash", "\\lt", "\\gt"]; + var sizeToMaxHeight = [0, 1.2, 1.8, 2.4, 3]; + var makeSizedDelim = function makeSizedDelim2(delim, size2, options2, mode, classes2) { + if (delim === "<" || delim === "\\lt" || delim === "⟨") { + delim = "\\langle"; + } else if (delim === ">" || delim === "\\gt" || delim === "⟩") { + delim = "\\rangle"; + } + if (utils.contains(stackLargeDelimiters, delim) || utils.contains(stackNeverDelimiters, delim)) { + return makeLargeDelim(delim, size2, false, options2, mode, classes2); + } else if (utils.contains(stackAlwaysDelimiters, delim)) { + return makeStackedDelim(delim, sizeToMaxHeight[size2], false, options2, mode, classes2); + } else { + throw new ParseError("Illegal delimiter: '" + delim + "'"); + } + }; + var stackNeverDelimiterSequence = [{ + type: "small", + style: Style$1.SCRIPTSCRIPT + }, { + type: "small", + style: Style$1.SCRIPT + }, { + type: "small", + style: Style$1.TEXT + }, { + type: "large", + size: 1 + }, { + type: "large", + size: 2 + }, { + type: "large", + size: 3 + }, { + type: "large", + size: 4 + }]; + var stackAlwaysDelimiterSequence = [{ + type: "small", + style: Style$1.SCRIPTSCRIPT + }, { + type: "small", + style: Style$1.SCRIPT + }, { + type: "small", + style: Style$1.TEXT + }, { + type: "stack" + }]; + var stackLargeDelimiterSequence = [{ + type: "small", + style: Style$1.SCRIPTSCRIPT + }, { + type: "small", + style: Style$1.SCRIPT + }, { + type: "small", + style: Style$1.TEXT + }, { + type: "large", + size: 1 + }, { + type: "large", + size: 2 + }, { + type: "large", + size: 3 + }, { + type: "large", + size: 4 + }, { + type: "stack" + }]; + var delimTypeToFont = function delimTypeToFont2(type2) { + if (type2.type === "small") { + return "Main-Regular"; + } else if (type2.type === "large") { + return "Size" + type2.size + "-Regular"; + } else if (type2.type === "stack") { + return "Size4-Regular"; + } else { + throw new Error("Add support for delim type '" + type2.type + "' here."); + } + }; + var traverseSequence = function traverseSequence2(delim, height, sequence2, options2) { + var start2 = Math.min(2, 3 - options2.style.size); + for (var i2 = start2; i2 < sequence2.length; i2++) { + if (sequence2[i2].type === "stack") { + break; + } + var metrics = getMetrics(delim, delimTypeToFont(sequence2[i2]), "math"); + var heightDepth = metrics.height + metrics.depth; + if (sequence2[i2].type === "small") { + var newOptions = options2.havingBaseStyle(sequence2[i2].style); + heightDepth *= newOptions.sizeMultiplier; + } + if (heightDepth > height) { + return sequence2[i2]; + } + } + return sequence2[sequence2.length - 1]; + }; + var makeCustomSizedDelim = function makeCustomSizedDelim2(delim, height, center2, options2, mode, classes2) { + if (delim === "<" || delim === "\\lt" || delim === "⟨") { + delim = "\\langle"; + } else if (delim === ">" || delim === "\\gt" || delim === "⟩") { + delim = "\\rangle"; + } + var sequence2; + if (utils.contains(stackNeverDelimiters, delim)) { + sequence2 = stackNeverDelimiterSequence; + } else if (utils.contains(stackLargeDelimiters, delim)) { + sequence2 = stackLargeDelimiterSequence; + } else { + sequence2 = stackAlwaysDelimiterSequence; + } + var delimType = traverseSequence(delim, height, sequence2, options2); + if (delimType.type === "small") { + return makeSmallDelim(delim, delimType.style, center2, options2, mode, classes2); + } else if (delimType.type === "large") { + return makeLargeDelim(delim, delimType.size, center2, options2, mode, classes2); + } else { + return makeStackedDelim(delim, height, center2, options2, mode, classes2); + } + }; + var makeLeftRightDelim = function makeLeftRightDelim2(delim, height, depth, options2, mode, classes2) { + var axisHeight = options2.fontMetrics().axisHeight * options2.sizeMultiplier; + var delimiterFactor = 901; + var delimiterExtend = 5 / options2.fontMetrics().ptPerEm; + var maxDistFromAxis = Math.max(height - axisHeight, depth + axisHeight); + var totalHeight = Math.max( + // In real TeX, calculations are done using integral values which are + // 65536 per pt, or 655360 per em. So, the division here truncates in + // TeX but doesn't here, producing different results. If we wanted to + // exactly match TeX's calculation, we could do + // Math.floor(655360 * maxDistFromAxis / 500) * + // delimiterFactor / 655360 + // (To see the difference, compare + // x^{x^{\left(\rule{0.1em}{0.68em}\right)}} + // in TeX and KaTeX) + maxDistFromAxis / 500 * delimiterFactor, + 2 * maxDistFromAxis - delimiterExtend + ); + return makeCustomSizedDelim(delim, totalHeight, true, options2, mode, classes2); + }; + var delimiter = { + sqrtImage: makeSqrtImage, + sizedDelim: makeSizedDelim, + sizeToMaxHeight, + customSizedDelim: makeCustomSizedDelim, + leftRightDelim: makeLeftRightDelim + }; + var delimiterSizes = { + "\\bigl": { + mclass: "mopen", + size: 1 + }, + "\\Bigl": { + mclass: "mopen", + size: 2 + }, + "\\biggl": { + mclass: "mopen", + size: 3 + }, + "\\Biggl": { + mclass: "mopen", + size: 4 + }, + "\\bigr": { + mclass: "mclose", + size: 1 + }, + "\\Bigr": { + mclass: "mclose", + size: 2 + }, + "\\biggr": { + mclass: "mclose", + size: 3 + }, + "\\Biggr": { + mclass: "mclose", + size: 4 + }, + "\\bigm": { + mclass: "mrel", + size: 1 + }, + "\\Bigm": { + mclass: "mrel", + size: 2 + }, + "\\biggm": { + mclass: "mrel", + size: 3 + }, + "\\Biggm": { + mclass: "mrel", + size: 4 + }, + "\\big": { + mclass: "mord", + size: 1 + }, + "\\Big": { + mclass: "mord", + size: 2 + }, + "\\bigg": { + mclass: "mord", + size: 3 + }, + "\\Bigg": { + mclass: "mord", + size: 4 + } + }; + var delimiters = ["(", "\\lparen", ")", "\\rparen", "[", "\\lbrack", "]", "\\rbrack", "\\{", "\\lbrace", "\\}", "\\rbrace", "\\lfloor", "\\rfloor", "⌊", "⌋", "\\lceil", "\\rceil", "⌈", "⌉", "<", ">", "\\langle", "⟨", "\\rangle", "⟩", "\\lt", "\\gt", "\\lvert", "\\rvert", "\\lVert", "\\rVert", "\\lgroup", "\\rgroup", "⟮", "⟯", "\\lmoustache", "\\rmoustache", "⎰", "⎱", "/", "\\backslash", "|", "\\vert", "\\|", "\\Vert", "\\uparrow", "\\Uparrow", "\\downarrow", "\\Downarrow", "\\updownarrow", "\\Updownarrow", "."]; + function checkDelimiter(delim, context) { + var symDelim = checkSymbolNodeType(delim); + if (symDelim && utils.contains(delimiters, symDelim.text)) { + return symDelim; + } else if (symDelim) { + throw new ParseError("Invalid delimiter '" + symDelim.text + "' after '" + context.funcName + "'", delim); + } else { + throw new ParseError("Invalid delimiter type '" + delim.type + "'", delim); + } + } + defineFunction({ + type: "delimsizing", + names: ["\\bigl", "\\Bigl", "\\biggl", "\\Biggl", "\\bigr", "\\Bigr", "\\biggr", "\\Biggr", "\\bigm", "\\Bigm", "\\biggm", "\\Biggm", "\\big", "\\Big", "\\bigg", "\\Bigg"], + props: { + numArgs: 1, + argTypes: ["primitive"] + }, + handler: (context, args) => { + var delim = checkDelimiter(args[0], context); + return { + type: "delimsizing", + mode: context.parser.mode, + size: delimiterSizes[context.funcName].size, + mclass: delimiterSizes[context.funcName].mclass, + delim: delim.text + }; + }, + htmlBuilder: (group, options2) => { + if (group.delim === ".") { + return buildCommon.makeSpan([group.mclass]); + } + return delimiter.sizedDelim(group.delim, group.size, options2, group.mode, [group.mclass]); + }, + mathmlBuilder: (group) => { + var children2 = []; + if (group.delim !== ".") { + children2.push(makeText(group.delim, group.mode)); + } + var node2 = new mathMLTree.MathNode("mo", children2); + if (group.mclass === "mopen" || group.mclass === "mclose") { + node2.setAttribute("fence", "true"); + } else { + node2.setAttribute("fence", "false"); + } + node2.setAttribute("stretchy", "true"); + var size2 = makeEm(delimiter.sizeToMaxHeight[group.size]); + node2.setAttribute("minsize", size2); + node2.setAttribute("maxsize", size2); + return node2; + } + }); + function assertParsed(group) { + if (!group.body) { + throw new Error("Bug: The leftright ParseNode wasn't fully parsed."); + } + } + defineFunction({ + type: "leftright-right", + names: ["\\right"], + props: { + numArgs: 1, + primitive: true + }, + handler: (context, args) => { + var color2 = context.parser.gullet.macros.get("\\current@color"); + if (color2 && typeof color2 !== "string") { + throw new ParseError("\\current@color set to non-string in \\right"); + } + return { + type: "leftright-right", + mode: context.parser.mode, + delim: checkDelimiter(args[0], context).text, + color: color2 + // undefined if not set via \color + }; + } + }); + defineFunction({ + type: "leftright", + names: ["\\left"], + props: { + numArgs: 1, + primitive: true + }, + handler: (context, args) => { + var delim = checkDelimiter(args[0], context); + var parser2 = context.parser; + ++parser2.leftrightDepth; + var body = parser2.parseExpression(false); + --parser2.leftrightDepth; + parser2.expect("\\right", false); + var right2 = assertNodeType(parser2.parseFunction(), "leftright-right"); + return { + type: "leftright", + mode: parser2.mode, + body, + left: delim.text, + right: right2.delim, + rightColor: right2.color + }; + }, + htmlBuilder: (group, options2) => { + assertParsed(group); + var inner2 = buildExpression$1(group.body, options2, true, ["mopen", "mclose"]); + var innerHeight = 0; + var innerDepth = 0; + var hadMiddle = false; + for (var i2 = 0; i2 < inner2.length; i2++) { + if (inner2[i2].isMiddle) { + hadMiddle = true; + } else { + innerHeight = Math.max(inner2[i2].height, innerHeight); + innerDepth = Math.max(inner2[i2].depth, innerDepth); + } + } + innerHeight *= options2.sizeMultiplier; + innerDepth *= options2.sizeMultiplier; + var leftDelim; + if (group.left === ".") { + leftDelim = makeNullDelimiter(options2, ["mopen"]); + } else { + leftDelim = delimiter.leftRightDelim(group.left, innerHeight, innerDepth, options2, group.mode, ["mopen"]); + } + inner2.unshift(leftDelim); + if (hadMiddle) { + for (var _i6 = 1; _i6 < inner2.length; _i6++) { + var middleDelim = inner2[_i6]; + var isMiddle = middleDelim.isMiddle; + if (isMiddle) { + inner2[_i6] = delimiter.leftRightDelim(isMiddle.delim, innerHeight, innerDepth, isMiddle.options, group.mode, []); + } + } + } + var rightDelim; + if (group.right === ".") { + rightDelim = makeNullDelimiter(options2, ["mclose"]); + } else { + var colorOptions = group.rightColor ? options2.withColor(group.rightColor) : options2; + rightDelim = delimiter.leftRightDelim(group.right, innerHeight, innerDepth, colorOptions, group.mode, ["mclose"]); + } + inner2.push(rightDelim); + return buildCommon.makeSpan(["minner"], inner2, options2); + }, + mathmlBuilder: (group, options2) => { + assertParsed(group); + var inner2 = buildExpression(group.body, options2); + if (group.left !== ".") { + var leftNode = new mathMLTree.MathNode("mo", [makeText(group.left, group.mode)]); + leftNode.setAttribute("fence", "true"); + inner2.unshift(leftNode); + } + if (group.right !== ".") { + var rightNode = new mathMLTree.MathNode("mo", [makeText(group.right, group.mode)]); + rightNode.setAttribute("fence", "true"); + if (group.rightColor) { + rightNode.setAttribute("mathcolor", group.rightColor); + } + inner2.push(rightNode); + } + return makeRow(inner2); + } + }); + defineFunction({ + type: "middle", + names: ["\\middle"], + props: { + numArgs: 1, + primitive: true + }, + handler: (context, args) => { + var delim = checkDelimiter(args[0], context); + if (!context.parser.leftrightDepth) { + throw new ParseError("\\middle without preceding \\left", delim); + } + return { + type: "middle", + mode: context.parser.mode, + delim: delim.text + }; + }, + htmlBuilder: (group, options2) => { + var middleDelim; + if (group.delim === ".") { + middleDelim = makeNullDelimiter(options2, []); + } else { + middleDelim = delimiter.sizedDelim(group.delim, 1, options2, group.mode, []); + var isMiddle = { + delim: group.delim, + options: options2 + }; + middleDelim.isMiddle = isMiddle; + } + return middleDelim; + }, + mathmlBuilder: (group, options2) => { + var textNode = group.delim === "\\vert" || group.delim === "|" ? makeText("|", "text") : makeText(group.delim, group.mode); + var middleNode = new mathMLTree.MathNode("mo", [textNode]); + middleNode.setAttribute("fence", "true"); + middleNode.setAttribute("lspace", "0.05em"); + middleNode.setAttribute("rspace", "0.05em"); + return middleNode; + } + }); + var htmlBuilder$7 = (group, options2) => { + var inner2 = buildCommon.wrapFragment(buildGroup$1(group.body, options2), options2); + var label = group.label.slice(1); + var scale = options2.sizeMultiplier; + var img; + var imgShift = 0; + var isSingleChar = utils.isCharacterBox(group.body); + if (label === "sout") { + img = buildCommon.makeSpan(["stretchy", "sout"]); + img.height = options2.fontMetrics().defaultRuleThickness / scale; + imgShift = -0.5 * options2.fontMetrics().xHeight; + } else if (label === "phase") { + var lineWeight = calculateSize({ + number: 0.6, + unit: "pt" + }, options2); + var clearance = calculateSize({ + number: 0.35, + unit: "ex" + }, options2); + var newOptions = options2.havingBaseSizing(); + scale = scale / newOptions.sizeMultiplier; + var angleHeight = inner2.height + inner2.depth + lineWeight + clearance; + inner2.style.paddingLeft = makeEm(angleHeight / 2 + lineWeight); + var viewBoxHeight = Math.floor(1e3 * angleHeight * scale); + var path2 = phasePath(viewBoxHeight); + var svgNode2 = new SvgNode([new PathNode("phase", path2)], { + "width": "400em", + "height": makeEm(viewBoxHeight / 1e3), + "viewBox": "0 0 400000 " + viewBoxHeight, + "preserveAspectRatio": "xMinYMin slice" + }); + img = buildCommon.makeSvgSpan(["hide-tail"], [svgNode2], options2); + img.style.height = makeEm(angleHeight); + imgShift = inner2.depth + lineWeight + clearance; + } else { + if (/cancel/.test(label)) { + if (!isSingleChar) { + inner2.classes.push("cancel-pad"); + } + } else if (label === "angl") { + inner2.classes.push("anglpad"); + } else { + inner2.classes.push("boxpad"); + } + var topPad = 0; + var bottomPad = 0; + var ruleThickness = 0; + if (/box/.test(label)) { + ruleThickness = Math.max( + options2.fontMetrics().fboxrule, + // default + options2.minRuleThickness + // User override. + ); + topPad = options2.fontMetrics().fboxsep + (label === "colorbox" ? 0 : ruleThickness); + bottomPad = topPad; + } else if (label === "angl") { + ruleThickness = Math.max(options2.fontMetrics().defaultRuleThickness, options2.minRuleThickness); + topPad = 4 * ruleThickness; + bottomPad = Math.max(0, 0.25 - inner2.depth); + } else { + topPad = isSingleChar ? 0.2 : 0; + bottomPad = topPad; + } + img = stretchy.encloseSpan(inner2, label, topPad, bottomPad, options2); + if (/fbox|boxed|fcolorbox/.test(label)) { + img.style.borderStyle = "solid"; + img.style.borderWidth = makeEm(ruleThickness); + } else if (label === "angl" && ruleThickness !== 0.049) { + img.style.borderTopWidth = makeEm(ruleThickness); + img.style.borderRightWidth = makeEm(ruleThickness); + } + imgShift = inner2.depth + bottomPad; + if (group.backgroundColor) { + img.style.backgroundColor = group.backgroundColor; + if (group.borderColor) { + img.style.borderColor = group.borderColor; + } + } + } + var vlist; + if (group.backgroundColor) { + vlist = buildCommon.makeVList({ + positionType: "individualShift", + children: [ + // Put the color background behind inner; + { + type: "elem", + elem: img, + shift: imgShift + }, + { + type: "elem", + elem: inner2, + shift: 0 + } + ] + }, options2); + } else { + var classes2 = /cancel|phase/.test(label) ? ["svg-align"] : []; + vlist = buildCommon.makeVList({ + positionType: "individualShift", + children: [ + // Write the \cancel stroke on top of inner. + { + type: "elem", + elem: inner2, + shift: 0 + }, + { + type: "elem", + elem: img, + shift: imgShift, + wrapperClasses: classes2 + } + ] + }, options2); + } + if (/cancel/.test(label)) { + vlist.height = inner2.height; + vlist.depth = inner2.depth; + } + if (/cancel/.test(label) && !isSingleChar) { + return buildCommon.makeSpan(["mord", "cancel-lap"], [vlist], options2); + } else { + return buildCommon.makeSpan(["mord"], [vlist], options2); + } + }; + var mathmlBuilder$6 = (group, options2) => { + var fboxsep = 0; + var node2 = new mathMLTree.MathNode(group.label.indexOf("colorbox") > -1 ? "mpadded" : "menclose", [buildGroup(group.body, options2)]); + switch (group.label) { + case "\\cancel": + node2.setAttribute("notation", "updiagonalstrike"); + break; + case "\\bcancel": + node2.setAttribute("notation", "downdiagonalstrike"); + break; + case "\\phase": + node2.setAttribute("notation", "phasorangle"); + break; + case "\\sout": + node2.setAttribute("notation", "horizontalstrike"); + break; + case "\\fbox": + node2.setAttribute("notation", "box"); + break; + case "\\angl": + node2.setAttribute("notation", "actuarial"); + break; + case "\\fcolorbox": + case "\\colorbox": + fboxsep = options2.fontMetrics().fboxsep * options2.fontMetrics().ptPerEm; + node2.setAttribute("width", "+" + 2 * fboxsep + "pt"); + node2.setAttribute("height", "+" + 2 * fboxsep + "pt"); + node2.setAttribute("lspace", fboxsep + "pt"); + node2.setAttribute("voffset", fboxsep + "pt"); + if (group.label === "\\fcolorbox") { + var thk = Math.max( + options2.fontMetrics().fboxrule, + // default + options2.minRuleThickness + // user override + ); + node2.setAttribute("style", "border: " + thk + "em solid " + String(group.borderColor)); + } + break; + case "\\xcancel": + node2.setAttribute("notation", "updiagonalstrike downdiagonalstrike"); + break; + } + if (group.backgroundColor) { + node2.setAttribute("mathbackground", group.backgroundColor); + } + return node2; + }; + defineFunction({ + type: "enclose", + names: ["\\colorbox"], + props: { + numArgs: 2, + allowedInText: true, + argTypes: ["color", "text"] + }, + handler(_ref, args, optArgs) { + var { + parser: parser2, + funcName + } = _ref; + var color2 = assertNodeType(args[0], "color-token").color; + var body = args[1]; + return { + type: "enclose", + mode: parser2.mode, + label: funcName, + backgroundColor: color2, + body + }; + }, + htmlBuilder: htmlBuilder$7, + mathmlBuilder: mathmlBuilder$6 + }); + defineFunction({ + type: "enclose", + names: ["\\fcolorbox"], + props: { + numArgs: 3, + allowedInText: true, + argTypes: ["color", "color", "text"] + }, + handler(_ref2, args, optArgs) { + var { + parser: parser2, + funcName + } = _ref2; + var borderColor = assertNodeType(args[0], "color-token").color; + var backgroundColor = assertNodeType(args[1], "color-token").color; + var body = args[2]; + return { + type: "enclose", + mode: parser2.mode, + label: funcName, + backgroundColor, + borderColor, + body + }; + }, + htmlBuilder: htmlBuilder$7, + mathmlBuilder: mathmlBuilder$6 + }); + defineFunction({ + type: "enclose", + names: ["\\fbox"], + props: { + numArgs: 1, + argTypes: ["hbox"], + allowedInText: true + }, + handler(_ref3, args) { + var { + parser: parser2 + } = _ref3; + return { + type: "enclose", + mode: parser2.mode, + label: "\\fbox", + body: args[0] + }; + } + }); + defineFunction({ + type: "enclose", + names: ["\\cancel", "\\bcancel", "\\xcancel", "\\sout", "\\phase"], + props: { + numArgs: 1 + }, + handler(_ref4, args) { + var { + parser: parser2, + funcName + } = _ref4; + var body = args[0]; + return { + type: "enclose", + mode: parser2.mode, + label: funcName, + body + }; + }, + htmlBuilder: htmlBuilder$7, + mathmlBuilder: mathmlBuilder$6 + }); + defineFunction({ + type: "enclose", + names: ["\\angl"], + props: { + numArgs: 1, + argTypes: ["hbox"], + allowedInText: false + }, + handler(_ref5, args) { + var { + parser: parser2 + } = _ref5; + return { + type: "enclose", + mode: parser2.mode, + label: "\\angl", + body: args[0] + }; + } + }); + var _environments = {}; + function defineEnvironment(_ref) { + var { + type: type2, + names, + props, + handler, + htmlBuilder: htmlBuilder2, + mathmlBuilder: mathmlBuilder2 + } = _ref; + var data = { + type: type2, + numArgs: props.numArgs || 0, + allowedInText: false, + numOptionalArgs: 0, + handler + }; + for (var i2 = 0; i2 < names.length; ++i2) { + _environments[names[i2]] = data; + } + if (htmlBuilder2) { + _htmlGroupBuilders[type2] = htmlBuilder2; + } + if (mathmlBuilder2) { + _mathmlGroupBuilders[type2] = mathmlBuilder2; + } + } + var _macros = {}; + function defineMacro(name, body) { + _macros[name] = body; + } + function getHLines(parser2) { + var hlineInfo = []; + parser2.consumeSpaces(); + var nxt = parser2.fetch().text; + if (nxt === "\\relax") { + parser2.consume(); + parser2.consumeSpaces(); + nxt = parser2.fetch().text; + } + while (nxt === "\\hline" || nxt === "\\hdashline") { + parser2.consume(); + hlineInfo.push(nxt === "\\hdashline"); + parser2.consumeSpaces(); + nxt = parser2.fetch().text; + } + return hlineInfo; + } + var validateAmsEnvironmentContext = (context) => { + var settings = context.parser.settings; + if (!settings.displayMode) { + throw new ParseError("{" + context.envName + "} can be used only in display mode."); + } + }; + function getAutoTag(name) { + if (name.indexOf("ed") === -1) { + return name.indexOf("*") === -1; + } + } + function parseArray(parser2, _ref, style) { + var { + hskipBeforeAndAfter, + addJot, + cols, + arraystretch, + colSeparationType, + autoTag, + singleRow, + emptySingleRow, + maxNumCols, + leqno + } = _ref; + parser2.gullet.beginGroup(); + if (!singleRow) { + parser2.gullet.macros.set("\\cr", "\\\\\\relax"); + } + if (!arraystretch) { + var stretch = parser2.gullet.expandMacroAsText("\\arraystretch"); + if (stretch == null) { + arraystretch = 1; + } else { + arraystretch = parseFloat(stretch); + if (!arraystretch || arraystretch < 0) { + throw new ParseError("Invalid \\arraystretch: " + stretch); + } + } + } + parser2.gullet.beginGroup(); + var row = []; + var body = [row]; + var rowGaps = []; + var hLinesBeforeRow = []; + var tags2 = autoTag != null ? [] : void 0; + function beginRow() { + if (autoTag) { + parser2.gullet.macros.set("\\@eqnsw", "1", true); + } + } + function endRow() { + if (tags2) { + if (parser2.gullet.macros.get("\\df@tag")) { + tags2.push(parser2.subparse([new Token("\\df@tag")])); + parser2.gullet.macros.set("\\df@tag", void 0, true); + } else { + tags2.push(Boolean(autoTag) && parser2.gullet.macros.get("\\@eqnsw") === "1"); + } + } + } + beginRow(); + hLinesBeforeRow.push(getHLines(parser2)); + while (true) { + var cell = parser2.parseExpression(false, singleRow ? "\\end" : "\\\\"); + parser2.gullet.endGroup(); + parser2.gullet.beginGroup(); + cell = { + type: "ordgroup", + mode: parser2.mode, + body: cell + }; + if (style) { + cell = { + type: "styling", + mode: parser2.mode, + style, + body: [cell] + }; + } + row.push(cell); + var next2 = parser2.fetch().text; + if (next2 === "&") { + if (maxNumCols && row.length === maxNumCols) { + if (singleRow || colSeparationType) { + throw new ParseError("Too many tab characters: &", parser2.nextToken); + } else { + parser2.settings.reportNonstrict("textEnv", "Too few columns specified in the {array} column argument."); + } + } + parser2.consume(); + } else if (next2 === "\\end") { + endRow(); + if (row.length === 1 && cell.type === "styling" && cell.body[0].body.length === 0 && (body.length > 1 || !emptySingleRow)) { + body.pop(); + } + if (hLinesBeforeRow.length < body.length + 1) { + hLinesBeforeRow.push([]); + } + break; + } else if (next2 === "\\\\") { + parser2.consume(); + var size2 = void 0; + if (parser2.gullet.future().text !== " ") { + size2 = parser2.parseSizeGroup(true); + } + rowGaps.push(size2 ? size2.value : null); + endRow(); + hLinesBeforeRow.push(getHLines(parser2)); + row = []; + body.push(row); + beginRow(); + } else { + throw new ParseError("Expected & or \\\\ or \\cr or \\end", parser2.nextToken); + } + } + parser2.gullet.endGroup(); + parser2.gullet.endGroup(); + return { + type: "array", + mode: parser2.mode, + addJot, + arraystretch, + body, + cols, + rowGaps, + hskipBeforeAndAfter, + hLinesBeforeRow, + colSeparationType, + tags: tags2, + leqno + }; + } + function dCellStyle(envName) { + if (envName.slice(0, 1) === "d") { + return "display"; + } else { + return "text"; + } + } + var htmlBuilder$6 = function htmlBuilder2(group, options2) { + var r; + var c2; + var nr = group.body.length; + var hLinesBeforeRow = group.hLinesBeforeRow; + var nc = 0; + var body = new Array(nr); + var hlines = []; + var ruleThickness = Math.max( + // From LaTeX \showthe\arrayrulewidth. Equals 0.04 em. + options2.fontMetrics().arrayRuleWidth, + options2.minRuleThickness + // User override. + ); + var pt = 1 / options2.fontMetrics().ptPerEm; + var arraycolsep = 5 * pt; + if (group.colSeparationType && group.colSeparationType === "small") { + var localMultiplier = options2.havingStyle(Style$1.SCRIPT).sizeMultiplier; + arraycolsep = 0.2778 * (localMultiplier / options2.sizeMultiplier); + } + var baselineskip = group.colSeparationType === "CD" ? calculateSize({ + number: 3, + unit: "ex" + }, options2) : 12 * pt; + var jot = 3 * pt; + var arrayskip = group.arraystretch * baselineskip; + var arstrutHeight = 0.7 * arrayskip; + var arstrutDepth = 0.3 * arrayskip; + var totalHeight = 0; + function setHLinePos(hlinesInGap) { + for (var i2 = 0; i2 < hlinesInGap.length; ++i2) { + if (i2 > 0) { + totalHeight += 0.25; + } + hlines.push({ + pos: totalHeight, + isDashed: hlinesInGap[i2] + }); + } + } + setHLinePos(hLinesBeforeRow[0]); + for (r = 0; r < group.body.length; ++r) { + var inrow = group.body[r]; + var height = arstrutHeight; + var depth = arstrutDepth; + if (nc < inrow.length) { + nc = inrow.length; + } + var outrow = new Array(inrow.length); + for (c2 = 0; c2 < inrow.length; ++c2) { + var elt = buildGroup$1(inrow[c2], options2); + if (depth < elt.depth) { + depth = elt.depth; + } + if (height < elt.height) { + height = elt.height; + } + outrow[c2] = elt; + } + var rowGap = group.rowGaps[r]; + var gap = 0; + if (rowGap) { + gap = calculateSize(rowGap, options2); + if (gap > 0) { + gap += arstrutDepth; + if (depth < gap) { + depth = gap; + } + gap = 0; + } + } + if (group.addJot) { + depth += jot; + } + outrow.height = height; + outrow.depth = depth; + totalHeight += height; + outrow.pos = totalHeight; + totalHeight += depth + gap; + body[r] = outrow; + setHLinePos(hLinesBeforeRow[r + 1]); + } + var offset = totalHeight / 2 + options2.fontMetrics().axisHeight; + var colDescriptions = group.cols || []; + var cols = []; + var colSep; + var colDescrNum; + var tagSpans = []; + if (group.tags && group.tags.some((tag2) => tag2)) { + for (r = 0; r < nr; ++r) { + var rw = body[r]; + var shift = rw.pos - offset; + var tag = group.tags[r]; + var tagSpan = void 0; + if (tag === true) { + tagSpan = buildCommon.makeSpan(["eqn-num"], [], options2); + } else if (tag === false) { + tagSpan = buildCommon.makeSpan([], [], options2); + } else { + tagSpan = buildCommon.makeSpan([], buildExpression$1(tag, options2, true), options2); + } + tagSpan.depth = rw.depth; + tagSpan.height = rw.height; + tagSpans.push({ + type: "elem", + elem: tagSpan, + shift + }); + } + } + for ( + c2 = 0, colDescrNum = 0; + // Continue while either there are more columns or more column + // descriptions, so trailing separators don't get lost. + c2 < nc || colDescrNum < colDescriptions.length; + ++c2, ++colDescrNum + ) { + var colDescr = colDescriptions[colDescrNum] || {}; + var firstSeparator = true; + while (colDescr.type === "separator") { + if (!firstSeparator) { + colSep = buildCommon.makeSpan(["arraycolsep"], []); + colSep.style.width = makeEm(options2.fontMetrics().doubleRuleSep); + cols.push(colSep); + } + if (colDescr.separator === "|" || colDescr.separator === ":") { + var lineType2 = colDescr.separator === "|" ? "solid" : "dashed"; + var separator = buildCommon.makeSpan(["vertical-separator"], [], options2); + separator.style.height = makeEm(totalHeight); + separator.style.borderRightWidth = makeEm(ruleThickness); + separator.style.borderRightStyle = lineType2; + separator.style.margin = "0 " + makeEm(-ruleThickness / 2); + var _shift = totalHeight - offset; + if (_shift) { + separator.style.verticalAlign = makeEm(-_shift); + } + cols.push(separator); + } else { + throw new ParseError("Invalid separator type: " + colDescr.separator); + } + colDescrNum++; + colDescr = colDescriptions[colDescrNum] || {}; + firstSeparator = false; + } + if (c2 >= nc) { + continue; + } + var sepwidth = void 0; + if (c2 > 0 || group.hskipBeforeAndAfter) { + sepwidth = utils.deflt(colDescr.pregap, arraycolsep); + if (sepwidth !== 0) { + colSep = buildCommon.makeSpan(["arraycolsep"], []); + colSep.style.width = makeEm(sepwidth); + cols.push(colSep); + } + } + var col = []; + for (r = 0; r < nr; ++r) { + var row = body[r]; + var elem = row[c2]; + if (!elem) { + continue; + } + var _shift2 = row.pos - offset; + elem.depth = row.depth; + elem.height = row.height; + col.push({ + type: "elem", + elem, + shift: _shift2 + }); + } + col = buildCommon.makeVList({ + positionType: "individualShift", + children: col + }, options2); + col = buildCommon.makeSpan(["col-align-" + (colDescr.align || "c")], [col]); + cols.push(col); + if (c2 < nc - 1 || group.hskipBeforeAndAfter) { + sepwidth = utils.deflt(colDescr.postgap, arraycolsep); + if (sepwidth !== 0) { + colSep = buildCommon.makeSpan(["arraycolsep"], []); + colSep.style.width = makeEm(sepwidth); + cols.push(colSep); + } + } + } + body = buildCommon.makeSpan(["mtable"], cols); + if (hlines.length > 0) { + var line2 = buildCommon.makeLineSpan("hline", options2, ruleThickness); + var dashes = buildCommon.makeLineSpan("hdashline", options2, ruleThickness); + var vListElems = [{ + type: "elem", + elem: body, + shift: 0 + }]; + while (hlines.length > 0) { + var hline = hlines.pop(); + var lineShift = hline.pos - offset; + if (hline.isDashed) { + vListElems.push({ + type: "elem", + elem: dashes, + shift: lineShift + }); + } else { + vListElems.push({ + type: "elem", + elem: line2, + shift: lineShift + }); + } + } + body = buildCommon.makeVList({ + positionType: "individualShift", + children: vListElems + }, options2); + } + if (tagSpans.length === 0) { + return buildCommon.makeSpan(["mord"], [body], options2); + } else { + var eqnNumCol = buildCommon.makeVList({ + positionType: "individualShift", + children: tagSpans + }, options2); + eqnNumCol = buildCommon.makeSpan(["tag"], [eqnNumCol], options2); + return buildCommon.makeFragment([body, eqnNumCol]); + } + }; + var alignMap = { + c: "center ", + l: "left ", + r: "right " + }; + var mathmlBuilder$5 = function mathmlBuilder2(group, options2) { + var tbl = []; + var glue = new mathMLTree.MathNode("mtd", [], ["mtr-glue"]); + var tag = new mathMLTree.MathNode("mtd", [], ["mml-eqn-num"]); + for (var i2 = 0; i2 < group.body.length; i2++) { + var rw = group.body[i2]; + var row = []; + for (var j = 0; j < rw.length; j++) { + row.push(new mathMLTree.MathNode("mtd", [buildGroup(rw[j], options2)])); + } + if (group.tags && group.tags[i2]) { + row.unshift(glue); + row.push(glue); + if (group.leqno) { + row.unshift(tag); + } else { + row.push(tag); + } + } + tbl.push(new mathMLTree.MathNode("mtr", row)); + } + var table = new mathMLTree.MathNode("mtable", tbl); + var gap = group.arraystretch === 0.5 ? 0.1 : 0.16 + group.arraystretch - 1 + (group.addJot ? 0.09 : 0); + table.setAttribute("rowspacing", makeEm(gap)); + var menclose = ""; + var align = ""; + if (group.cols && group.cols.length > 0) { + var cols = group.cols; + var columnLines = ""; + var prevTypeWasAlign = false; + var iStart = 0; + var iEnd = cols.length; + if (cols[0].type === "separator") { + menclose += "top "; + iStart = 1; + } + if (cols[cols.length - 1].type === "separator") { + menclose += "bottom "; + iEnd -= 1; + } + for (var _i6 = iStart; _i6 < iEnd; _i6++) { + if (cols[_i6].type === "align") { + align += alignMap[cols[_i6].align]; + if (prevTypeWasAlign) { + columnLines += "none "; + } + prevTypeWasAlign = true; + } else if (cols[_i6].type === "separator") { + if (prevTypeWasAlign) { + columnLines += cols[_i6].separator === "|" ? "solid " : "dashed "; + prevTypeWasAlign = false; + } + } + } + table.setAttribute("columnalign", align.trim()); + if (/[sd]/.test(columnLines)) { + table.setAttribute("columnlines", columnLines.trim()); + } + } + if (group.colSeparationType === "align") { + var _cols = group.cols || []; + var spacing2 = ""; + for (var _i22 = 1; _i22 < _cols.length; _i22++) { + spacing2 += _i22 % 2 ? "0em " : "1em "; + } + table.setAttribute("columnspacing", spacing2.trim()); + } else if (group.colSeparationType === "alignat" || group.colSeparationType === "gather") { + table.setAttribute("columnspacing", "0em"); + } else if (group.colSeparationType === "small") { + table.setAttribute("columnspacing", "0.2778em"); + } else if (group.colSeparationType === "CD") { + table.setAttribute("columnspacing", "0.5em"); + } else { + table.setAttribute("columnspacing", "1em"); + } + var rowLines = ""; + var hlines = group.hLinesBeforeRow; + menclose += hlines[0].length > 0 ? "left " : ""; + menclose += hlines[hlines.length - 1].length > 0 ? "right " : ""; + for (var _i32 = 1; _i32 < hlines.length - 1; _i32++) { + rowLines += hlines[_i32].length === 0 ? "none " : hlines[_i32][0] ? "dashed " : "solid "; + } + if (/[sd]/.test(rowLines)) { + table.setAttribute("rowlines", rowLines.trim()); + } + if (menclose !== "") { + table = new mathMLTree.MathNode("menclose", [table]); + table.setAttribute("notation", menclose.trim()); + } + if (group.arraystretch && group.arraystretch < 1) { + table = new mathMLTree.MathNode("mstyle", [table]); + table.setAttribute("scriptlevel", "1"); + } + return table; + }; + var alignedHandler = function alignedHandler2(context, args) { + if (context.envName.indexOf("ed") === -1) { + validateAmsEnvironmentContext(context); + } + var cols = []; + var separationType = context.envName.indexOf("at") > -1 ? "alignat" : "align"; + var isSplit = context.envName === "split"; + var res = parseArray(context.parser, { + cols, + addJot: true, + autoTag: isSplit ? void 0 : getAutoTag(context.envName), + emptySingleRow: true, + colSeparationType: separationType, + maxNumCols: isSplit ? 2 : void 0, + leqno: context.parser.settings.leqno + }, "display"); + var numMaths; + var numCols = 0; + var emptyGroup = { + type: "ordgroup", + mode: context.mode, + body: [] + }; + if (args[0] && args[0].type === "ordgroup") { + var arg0 = ""; + for (var i2 = 0; i2 < args[0].body.length; i2++) { + var textord2 = assertNodeType(args[0].body[i2], "textord"); + arg0 += textord2.text; + } + numMaths = Number(arg0); + numCols = numMaths * 2; + } + var isAligned = !numCols; + res.body.forEach(function(row) { + for (var _i42 = 1; _i42 < row.length; _i42 += 2) { + var styling = assertNodeType(row[_i42], "styling"); + var ordgroup = assertNodeType(styling.body[0], "ordgroup"); + ordgroup.body.unshift(emptyGroup); + } + if (!isAligned) { + var curMaths = row.length / 2; + if (numMaths < curMaths) { + throw new ParseError("Too many math in a row: " + ("expected " + numMaths + ", but got " + curMaths), row[0]); + } + } else if (numCols < row.length) { + numCols = row.length; + } + }); + for (var _i52 = 0; _i52 < numCols; ++_i52) { + var align = "r"; + var pregap = 0; + if (_i52 % 2 === 1) { + align = "l"; + } else if (_i52 > 0 && isAligned) { + pregap = 1; + } + cols[_i52] = { + type: "align", + align, + pregap, + postgap: 0 + }; + } + res.colSeparationType = isAligned ? "align" : "alignat"; + return res; + }; + defineEnvironment({ + type: "array", + names: ["array", "darray"], + props: { + numArgs: 1 + }, + handler(context, args) { + var symNode = checkSymbolNodeType(args[0]); + var colalign = symNode ? [args[0]] : assertNodeType(args[0], "ordgroup").body; + var cols = colalign.map(function(nde) { + var node2 = assertSymbolNodeType(nde); + var ca = node2.text; + if ("lcr".indexOf(ca) !== -1) { + return { + type: "align", + align: ca + }; + } else if (ca === "|") { + return { + type: "separator", + separator: "|" + }; + } else if (ca === ":") { + return { + type: "separator", + separator: ":" + }; + } + throw new ParseError("Unknown column alignment: " + ca, nde); + }); + var res = { + cols, + hskipBeforeAndAfter: true, + // \@preamble in lttab.dtx + maxNumCols: cols.length + }; + return parseArray(context.parser, res, dCellStyle(context.envName)); + }, + htmlBuilder: htmlBuilder$6, + mathmlBuilder: mathmlBuilder$5 + }); + defineEnvironment({ + type: "array", + names: ["matrix", "pmatrix", "bmatrix", "Bmatrix", "vmatrix", "Vmatrix", "matrix*", "pmatrix*", "bmatrix*", "Bmatrix*", "vmatrix*", "Vmatrix*"], + props: { + numArgs: 0 + }, + handler(context) { + var delimiters2 = { + "matrix": null, + "pmatrix": ["(", ")"], + "bmatrix": ["[", "]"], + "Bmatrix": ["\\{", "\\}"], + "vmatrix": ["|", "|"], + "Vmatrix": ["\\Vert", "\\Vert"] + }[context.envName.replace("*", "")]; + var colAlign = "c"; + var payload = { + hskipBeforeAndAfter: false, + cols: [{ + type: "align", + align: colAlign + }] + }; + if (context.envName.charAt(context.envName.length - 1) === "*") { + var parser2 = context.parser; + parser2.consumeSpaces(); + if (parser2.fetch().text === "[") { + parser2.consume(); + parser2.consumeSpaces(); + colAlign = parser2.fetch().text; + if ("lcr".indexOf(colAlign) === -1) { + throw new ParseError("Expected l or c or r", parser2.nextToken); + } + parser2.consume(); + parser2.consumeSpaces(); + parser2.expect("]"); + parser2.consume(); + payload.cols = [{ + type: "align", + align: colAlign + }]; + } + } + var res = parseArray(context.parser, payload, dCellStyle(context.envName)); + var numCols = Math.max(0, ...res.body.map((row) => row.length)); + res.cols = new Array(numCols).fill({ + type: "align", + align: colAlign + }); + return delimiters2 ? { + type: "leftright", + mode: context.mode, + body: [res], + left: delimiters2[0], + right: delimiters2[1], + rightColor: void 0 + // \right uninfluenced by \color in array + } : res; + }, + htmlBuilder: htmlBuilder$6, + mathmlBuilder: mathmlBuilder$5 + }); + defineEnvironment({ + type: "array", + names: ["smallmatrix"], + props: { + numArgs: 0 + }, + handler(context) { + var payload = { + arraystretch: 0.5 + }; + var res = parseArray(context.parser, payload, "script"); + res.colSeparationType = "small"; + return res; + }, + htmlBuilder: htmlBuilder$6, + mathmlBuilder: mathmlBuilder$5 + }); + defineEnvironment({ + type: "array", + names: ["subarray"], + props: { + numArgs: 1 + }, + handler(context, args) { + var symNode = checkSymbolNodeType(args[0]); + var colalign = symNode ? [args[0]] : assertNodeType(args[0], "ordgroup").body; + var cols = colalign.map(function(nde) { + var node2 = assertSymbolNodeType(nde); + var ca = node2.text; + if ("lc".indexOf(ca) !== -1) { + return { + type: "align", + align: ca + }; + } + throw new ParseError("Unknown column alignment: " + ca, nde); + }); + if (cols.length > 1) { + throw new ParseError("{subarray} can contain only one column"); + } + var res = { + cols, + hskipBeforeAndAfter: false, + arraystretch: 0.5 + }; + res = parseArray(context.parser, res, "script"); + if (res.body.length > 0 && res.body[0].length > 1) { + throw new ParseError("{subarray} can contain only one column"); + } + return res; + }, + htmlBuilder: htmlBuilder$6, + mathmlBuilder: mathmlBuilder$5 + }); + defineEnvironment({ + type: "array", + names: ["cases", "dcases", "rcases", "drcases"], + props: { + numArgs: 0 + }, + handler(context) { + var payload = { + arraystretch: 1.2, + cols: [{ + type: "align", + align: "l", + pregap: 0, + // TODO(kevinb) get the current style. + // For now we use the metrics for TEXT style which is what we were + // doing before. Before attempting to get the current style we + // should look at TeX's behavior especially for \over and matrices. + postgap: 1 + /* 1em quad */ + }, { + type: "align", + align: "l", + pregap: 0, + postgap: 0 + }] + }; + var res = parseArray(context.parser, payload, dCellStyle(context.envName)); + return { + type: "leftright", + mode: context.mode, + body: [res], + left: context.envName.indexOf("r") > -1 ? "." : "\\{", + right: context.envName.indexOf("r") > -1 ? "\\}" : ".", + rightColor: void 0 + }; + }, + htmlBuilder: htmlBuilder$6, + mathmlBuilder: mathmlBuilder$5 + }); + defineEnvironment({ + type: "array", + names: ["align", "align*", "aligned", "split"], + props: { + numArgs: 0 + }, + handler: alignedHandler, + htmlBuilder: htmlBuilder$6, + mathmlBuilder: mathmlBuilder$5 + }); + defineEnvironment({ + type: "array", + names: ["gathered", "gather", "gather*"], + props: { + numArgs: 0 + }, + handler(context) { + if (utils.contains(["gather", "gather*"], context.envName)) { + validateAmsEnvironmentContext(context); + } + var res = { + cols: [{ + type: "align", + align: "c" + }], + addJot: true, + colSeparationType: "gather", + autoTag: getAutoTag(context.envName), + emptySingleRow: true, + leqno: context.parser.settings.leqno + }; + return parseArray(context.parser, res, "display"); + }, + htmlBuilder: htmlBuilder$6, + mathmlBuilder: mathmlBuilder$5 + }); + defineEnvironment({ + type: "array", + names: ["alignat", "alignat*", "alignedat"], + props: { + numArgs: 1 + }, + handler: alignedHandler, + htmlBuilder: htmlBuilder$6, + mathmlBuilder: mathmlBuilder$5 + }); + defineEnvironment({ + type: "array", + names: ["equation", "equation*"], + props: { + numArgs: 0 + }, + handler(context) { + validateAmsEnvironmentContext(context); + var res = { + autoTag: getAutoTag(context.envName), + emptySingleRow: true, + singleRow: true, + maxNumCols: 1, + leqno: context.parser.settings.leqno + }; + return parseArray(context.parser, res, "display"); + }, + htmlBuilder: htmlBuilder$6, + mathmlBuilder: mathmlBuilder$5 + }); + defineEnvironment({ + type: "array", + names: ["CD"], + props: { + numArgs: 0 + }, + handler(context) { + validateAmsEnvironmentContext(context); + return parseCD(context.parser); + }, + htmlBuilder: htmlBuilder$6, + mathmlBuilder: mathmlBuilder$5 + }); + defineMacro("\\nonumber", "\\gdef\\@eqnsw{0}"); + defineMacro("\\notag", "\\nonumber"); + defineFunction({ + type: "text", + // Doesn't matter what this is. + names: ["\\hline", "\\hdashline"], + props: { + numArgs: 0, + allowedInText: true, + allowedInMath: true + }, + handler(context, args) { + throw new ParseError(context.funcName + " valid only within array environment"); + } + }); + var environments = _environments; + defineFunction({ + type: "environment", + names: ["\\begin", "\\end"], + props: { + numArgs: 1, + argTypes: ["text"] + }, + handler(_ref, args) { + var { + parser: parser2, + funcName + } = _ref; + var nameGroup = args[0]; + if (nameGroup.type !== "ordgroup") { + throw new ParseError("Invalid environment name", nameGroup); + } + var envName = ""; + for (var i2 = 0; i2 < nameGroup.body.length; ++i2) { + envName += assertNodeType(nameGroup.body[i2], "textord").text; + } + if (funcName === "\\begin") { + if (!environments.hasOwnProperty(envName)) { + throw new ParseError("No such environment: " + envName, nameGroup); + } + var env = environments[envName]; + var { + args: _args, + optArgs + } = parser2.parseArguments("\\begin{" + envName + "}", env); + var context = { + mode: parser2.mode, + envName, + parser: parser2 + }; + var result = env.handler(context, _args, optArgs); + parser2.expect("\\end", false); + var endNameToken = parser2.nextToken; + var end2 = assertNodeType(parser2.parseFunction(), "environment"); + if (end2.name !== envName) { + throw new ParseError("Mismatch: \\begin{" + envName + "} matched by \\end{" + end2.name + "}", endNameToken); + } + return result; + } + return { + type: "environment", + mode: parser2.mode, + name: envName, + nameGroup + }; + } + }); + var htmlBuilder$5 = (group, options2) => { + var font = group.font; + var newOptions = options2.withFont(font); + return buildGroup$1(group.body, newOptions); + }; + var mathmlBuilder$4 = (group, options2) => { + var font = group.font; + var newOptions = options2.withFont(font); + return buildGroup(group.body, newOptions); + }; + var fontAliases = { + "\\Bbb": "\\mathbb", + "\\bold": "\\mathbf", + "\\frak": "\\mathfrak", + "\\bm": "\\boldsymbol" + }; + defineFunction({ + type: "font", + names: [ + // styles, except \boldsymbol defined below + "\\mathrm", + "\\mathit", + "\\mathbf", + "\\mathnormal", + // families + "\\mathbb", + "\\mathcal", + "\\mathfrak", + "\\mathscr", + "\\mathsf", + "\\mathtt", + // aliases, except \bm defined below + "\\Bbb", + "\\bold", + "\\frak" + ], + props: { + numArgs: 1, + allowedInArgument: true + }, + handler: (_ref, args) => { + var { + parser: parser2, + funcName + } = _ref; + var body = normalizeArgument(args[0]); + var func = funcName; + if (func in fontAliases) { + func = fontAliases[func]; + } + return { + type: "font", + mode: parser2.mode, + font: func.slice(1), + body + }; + }, + htmlBuilder: htmlBuilder$5, + mathmlBuilder: mathmlBuilder$4 + }); + defineFunction({ + type: "mclass", + names: ["\\boldsymbol", "\\bm"], + props: { + numArgs: 1 + }, + handler: (_ref2, args) => { + var { + parser: parser2 + } = _ref2; + var body = args[0]; + var isCharacterBox2 = utils.isCharacterBox(body); + return { + type: "mclass", + mode: parser2.mode, + mclass: binrelClass(body), + body: [{ + type: "font", + mode: parser2.mode, + font: "boldsymbol", + body + }], + isCharacterBox: isCharacterBox2 + }; + } + }); + defineFunction({ + type: "font", + names: ["\\rm", "\\sf", "\\tt", "\\bf", "\\it", "\\cal"], + props: { + numArgs: 0, + allowedInText: true + }, + handler: (_ref3, args) => { + var { + parser: parser2, + funcName, + breakOnTokenText + } = _ref3; + var { + mode + } = parser2; + var body = parser2.parseExpression(true, breakOnTokenText); + var style = "math" + funcName.slice(1); + return { + type: "font", + mode, + font: style, + body: { + type: "ordgroup", + mode: parser2.mode, + body + } + }; + }, + htmlBuilder: htmlBuilder$5, + mathmlBuilder: mathmlBuilder$4 + }); + var adjustStyle = (size2, originalStyle) => { + var style = originalStyle; + if (size2 === "display") { + style = style.id >= Style$1.SCRIPT.id ? style.text() : Style$1.DISPLAY; + } else if (size2 === "text" && style.size === Style$1.DISPLAY.size) { + style = Style$1.TEXT; + } else if (size2 === "script") { + style = Style$1.SCRIPT; + } else if (size2 === "scriptscript") { + style = Style$1.SCRIPTSCRIPT; + } + return style; + }; + var htmlBuilder$4 = (group, options2) => { + var style = adjustStyle(group.size, options2.style); + var nstyle = style.fracNum(); + var dstyle = style.fracDen(); + var newOptions; + newOptions = options2.havingStyle(nstyle); + var numerm = buildGroup$1(group.numer, newOptions, options2); + if (group.continued) { + var hStrut = 8.5 / options2.fontMetrics().ptPerEm; + var dStrut = 3.5 / options2.fontMetrics().ptPerEm; + numerm.height = numerm.height < hStrut ? hStrut : numerm.height; + numerm.depth = numerm.depth < dStrut ? dStrut : numerm.depth; + } + newOptions = options2.havingStyle(dstyle); + var denomm = buildGroup$1(group.denom, newOptions, options2); + var rule; + var ruleWidth; + var ruleSpacing; + if (group.hasBarLine) { + if (group.barSize) { + ruleWidth = calculateSize(group.barSize, options2); + rule = buildCommon.makeLineSpan("frac-line", options2, ruleWidth); + } else { + rule = buildCommon.makeLineSpan("frac-line", options2); + } + ruleWidth = rule.height; + ruleSpacing = rule.height; + } else { + rule = null; + ruleWidth = 0; + ruleSpacing = options2.fontMetrics().defaultRuleThickness; + } + var numShift; + var clearance; + var denomShift; + if (style.size === Style$1.DISPLAY.size || group.size === "display") { + numShift = options2.fontMetrics().num1; + if (ruleWidth > 0) { + clearance = 3 * ruleSpacing; + } else { + clearance = 7 * ruleSpacing; + } + denomShift = options2.fontMetrics().denom1; + } else { + if (ruleWidth > 0) { + numShift = options2.fontMetrics().num2; + clearance = ruleSpacing; + } else { + numShift = options2.fontMetrics().num3; + clearance = 3 * ruleSpacing; + } + denomShift = options2.fontMetrics().denom2; + } + var frac; + if (!rule) { + var candidateClearance = numShift - numerm.depth - (denomm.height - denomShift); + if (candidateClearance < clearance) { + numShift += 0.5 * (clearance - candidateClearance); + denomShift += 0.5 * (clearance - candidateClearance); + } + frac = buildCommon.makeVList({ + positionType: "individualShift", + children: [{ + type: "elem", + elem: denomm, + shift: denomShift + }, { + type: "elem", + elem: numerm, + shift: -numShift + }] + }, options2); + } else { + var axisHeight = options2.fontMetrics().axisHeight; + if (numShift - numerm.depth - (axisHeight + 0.5 * ruleWidth) < clearance) { + numShift += clearance - (numShift - numerm.depth - (axisHeight + 0.5 * ruleWidth)); + } + if (axisHeight - 0.5 * ruleWidth - (denomm.height - denomShift) < clearance) { + denomShift += clearance - (axisHeight - 0.5 * ruleWidth - (denomm.height - denomShift)); + } + var midShift = -(axisHeight - 0.5 * ruleWidth); + frac = buildCommon.makeVList({ + positionType: "individualShift", + children: [{ + type: "elem", + elem: denomm, + shift: denomShift + }, { + type: "elem", + elem: rule, + shift: midShift + }, { + type: "elem", + elem: numerm, + shift: -numShift + }] + }, options2); + } + newOptions = options2.havingStyle(style); + frac.height *= newOptions.sizeMultiplier / options2.sizeMultiplier; + frac.depth *= newOptions.sizeMultiplier / options2.sizeMultiplier; + var delimSize; + if (style.size === Style$1.DISPLAY.size) { + delimSize = options2.fontMetrics().delim1; + } else if (style.size === Style$1.SCRIPTSCRIPT.size) { + delimSize = options2.havingStyle(Style$1.SCRIPT).fontMetrics().delim2; + } else { + delimSize = options2.fontMetrics().delim2; + } + var leftDelim; + var rightDelim; + if (group.leftDelim == null) { + leftDelim = makeNullDelimiter(options2, ["mopen"]); + } else { + leftDelim = delimiter.customSizedDelim(group.leftDelim, delimSize, true, options2.havingStyle(style), group.mode, ["mopen"]); + } + if (group.continued) { + rightDelim = buildCommon.makeSpan([]); + } else if (group.rightDelim == null) { + rightDelim = makeNullDelimiter(options2, ["mclose"]); + } else { + rightDelim = delimiter.customSizedDelim(group.rightDelim, delimSize, true, options2.havingStyle(style), group.mode, ["mclose"]); + } + return buildCommon.makeSpan(["mord"].concat(newOptions.sizingClasses(options2)), [leftDelim, buildCommon.makeSpan(["mfrac"], [frac]), rightDelim], options2); + }; + var mathmlBuilder$3 = (group, options2) => { + var node2 = new mathMLTree.MathNode("mfrac", [buildGroup(group.numer, options2), buildGroup(group.denom, options2)]); + if (!group.hasBarLine) { + node2.setAttribute("linethickness", "0px"); + } else if (group.barSize) { + var ruleWidth = calculateSize(group.barSize, options2); + node2.setAttribute("linethickness", makeEm(ruleWidth)); + } + var style = adjustStyle(group.size, options2.style); + if (style.size !== options2.style.size) { + node2 = new mathMLTree.MathNode("mstyle", [node2]); + var isDisplay = style.size === Style$1.DISPLAY.size ? "true" : "false"; + node2.setAttribute("displaystyle", isDisplay); + node2.setAttribute("scriptlevel", "0"); + } + if (group.leftDelim != null || group.rightDelim != null) { + var withDelims = []; + if (group.leftDelim != null) { + var leftOp = new mathMLTree.MathNode("mo", [new mathMLTree.TextNode(group.leftDelim.replace("\\", ""))]); + leftOp.setAttribute("fence", "true"); + withDelims.push(leftOp); + } + withDelims.push(node2); + if (group.rightDelim != null) { + var rightOp = new mathMLTree.MathNode("mo", [new mathMLTree.TextNode(group.rightDelim.replace("\\", ""))]); + rightOp.setAttribute("fence", "true"); + withDelims.push(rightOp); + } + return makeRow(withDelims); + } + return node2; + }; + defineFunction({ + type: "genfrac", + names: [ + "\\dfrac", + "\\frac", + "\\tfrac", + "\\dbinom", + "\\binom", + "\\tbinom", + "\\\\atopfrac", + // can’t be entered directly + "\\\\bracefrac", + "\\\\brackfrac" + // ditto + ], + props: { + numArgs: 2, + allowedInArgument: true + }, + handler: (_ref, args) => { + var { + parser: parser2, + funcName + } = _ref; + var numer = args[0]; + var denom = args[1]; + var hasBarLine; + var leftDelim = null; + var rightDelim = null; + var size2 = "auto"; + switch (funcName) { + case "\\dfrac": + case "\\frac": + case "\\tfrac": + hasBarLine = true; + break; + case "\\\\atopfrac": + hasBarLine = false; + break; + case "\\dbinom": + case "\\binom": + case "\\tbinom": + hasBarLine = false; + leftDelim = "("; + rightDelim = ")"; + break; + case "\\\\bracefrac": + hasBarLine = false; + leftDelim = "\\{"; + rightDelim = "\\}"; + break; + case "\\\\brackfrac": + hasBarLine = false; + leftDelim = "["; + rightDelim = "]"; + break; + default: + throw new Error("Unrecognized genfrac command"); + } + switch (funcName) { + case "\\dfrac": + case "\\dbinom": + size2 = "display"; + break; + case "\\tfrac": + case "\\tbinom": + size2 = "text"; + break; + } + return { + type: "genfrac", + mode: parser2.mode, + continued: false, + numer, + denom, + hasBarLine, + leftDelim, + rightDelim, + size: size2, + barSize: null + }; + }, + htmlBuilder: htmlBuilder$4, + mathmlBuilder: mathmlBuilder$3 + }); + defineFunction({ + type: "genfrac", + names: ["\\cfrac"], + props: { + numArgs: 2 + }, + handler: (_ref2, args) => { + var { + parser: parser2, + funcName + } = _ref2; + var numer = args[0]; + var denom = args[1]; + return { + type: "genfrac", + mode: parser2.mode, + continued: true, + numer, + denom, + hasBarLine: true, + leftDelim: null, + rightDelim: null, + size: "display", + barSize: null + }; + } + }); + defineFunction({ + type: "infix", + names: ["\\over", "\\choose", "\\atop", "\\brace", "\\brack"], + props: { + numArgs: 0, + infix: true + }, + handler(_ref3) { + var { + parser: parser2, + funcName, + token: token2 + } = _ref3; + var replaceWith; + switch (funcName) { + case "\\over": + replaceWith = "\\frac"; + break; + case "\\choose": + replaceWith = "\\binom"; + break; + case "\\atop": + replaceWith = "\\\\atopfrac"; + break; + case "\\brace": + replaceWith = "\\\\bracefrac"; + break; + case "\\brack": + replaceWith = "\\\\brackfrac"; + break; + default: + throw new Error("Unrecognized infix genfrac command"); + } + return { + type: "infix", + mode: parser2.mode, + replaceWith, + token: token2 + }; + } + }); + var stylArray = ["display", "text", "script", "scriptscript"]; + var delimFromValue = function delimFromValue2(delimString) { + var delim = null; + if (delimString.length > 0) { + delim = delimString; + delim = delim === "." ? null : delim; + } + return delim; + }; + defineFunction({ + type: "genfrac", + names: ["\\genfrac"], + props: { + numArgs: 6, + allowedInArgument: true, + argTypes: ["math", "math", "size", "text", "math", "math"] + }, + handler(_ref4, args) { + var { + parser: parser2 + } = _ref4; + var numer = args[4]; + var denom = args[5]; + var leftNode = normalizeArgument(args[0]); + var leftDelim = leftNode.type === "atom" && leftNode.family === "open" ? delimFromValue(leftNode.text) : null; + var rightNode = normalizeArgument(args[1]); + var rightDelim = rightNode.type === "atom" && rightNode.family === "close" ? delimFromValue(rightNode.text) : null; + var barNode = assertNodeType(args[2], "size"); + var hasBarLine; + var barSize = null; + if (barNode.isBlank) { + hasBarLine = true; + } else { + barSize = barNode.value; + hasBarLine = barSize.number > 0; + } + var size2 = "auto"; + var styl = args[3]; + if (styl.type === "ordgroup") { + if (styl.body.length > 0) { + var textOrd = assertNodeType(styl.body[0], "textord"); + size2 = stylArray[Number(textOrd.text)]; + } + } else { + styl = assertNodeType(styl, "textord"); + size2 = stylArray[Number(styl.text)]; + } + return { + type: "genfrac", + mode: parser2.mode, + numer, + denom, + continued: false, + hasBarLine, + barSize, + leftDelim, + rightDelim, + size: size2 + }; + }, + htmlBuilder: htmlBuilder$4, + mathmlBuilder: mathmlBuilder$3 + }); + defineFunction({ + type: "infix", + names: ["\\above"], + props: { + numArgs: 1, + argTypes: ["size"], + infix: true + }, + handler(_ref5, args) { + var { + parser: parser2, + funcName, + token: token2 + } = _ref5; + return { + type: "infix", + mode: parser2.mode, + replaceWith: "\\\\abovefrac", + size: assertNodeType(args[0], "size").value, + token: token2 + }; + } + }); + defineFunction({ + type: "genfrac", + names: ["\\\\abovefrac"], + props: { + numArgs: 3, + argTypes: ["math", "size", "math"] + }, + handler: (_ref6, args) => { + var { + parser: parser2, + funcName + } = _ref6; + var numer = args[0]; + var barSize = assert(assertNodeType(args[1], "infix").size); + var denom = args[2]; + var hasBarLine = barSize.number > 0; + return { + type: "genfrac", + mode: parser2.mode, + numer, + denom, + continued: false, + hasBarLine, + barSize, + leftDelim: null, + rightDelim: null, + size: "auto" + }; + }, + htmlBuilder: htmlBuilder$4, + mathmlBuilder: mathmlBuilder$3 + }); + var htmlBuilder$3 = (grp, options2) => { + var style = options2.style; + var supSubGroup; + var group; + if (grp.type === "supsub") { + supSubGroup = grp.sup ? buildGroup$1(grp.sup, options2.havingStyle(style.sup()), options2) : buildGroup$1(grp.sub, options2.havingStyle(style.sub()), options2); + group = assertNodeType(grp.base, "horizBrace"); + } else { + group = assertNodeType(grp, "horizBrace"); + } + var body = buildGroup$1(group.base, options2.havingBaseStyle(Style$1.DISPLAY)); + var braceBody = stretchy.svgSpan(group, options2); + var vlist; + if (group.isOver) { + vlist = buildCommon.makeVList({ + positionType: "firstBaseline", + children: [{ + type: "elem", + elem: body + }, { + type: "kern", + size: 0.1 + }, { + type: "elem", + elem: braceBody + }] + }, options2); + vlist.children[0].children[0].children[1].classes.push("svg-align"); + } else { + vlist = buildCommon.makeVList({ + positionType: "bottom", + positionData: body.depth + 0.1 + braceBody.height, + children: [{ + type: "elem", + elem: braceBody + }, { + type: "kern", + size: 0.1 + }, { + type: "elem", + elem: body + }] + }, options2); + vlist.children[0].children[0].children[0].classes.push("svg-align"); + } + if (supSubGroup) { + var vSpan = buildCommon.makeSpan(["mord", group.isOver ? "mover" : "munder"], [vlist], options2); + if (group.isOver) { + vlist = buildCommon.makeVList({ + positionType: "firstBaseline", + children: [{ + type: "elem", + elem: vSpan + }, { + type: "kern", + size: 0.2 + }, { + type: "elem", + elem: supSubGroup + }] + }, options2); + } else { + vlist = buildCommon.makeVList({ + positionType: "bottom", + positionData: vSpan.depth + 0.2 + supSubGroup.height + supSubGroup.depth, + children: [{ + type: "elem", + elem: supSubGroup + }, { + type: "kern", + size: 0.2 + }, { + type: "elem", + elem: vSpan + }] + }, options2); + } + } + return buildCommon.makeSpan(["mord", group.isOver ? "mover" : "munder"], [vlist], options2); + }; + var mathmlBuilder$2 = (group, options2) => { + var accentNode = stretchy.mathMLnode(group.label); + return new mathMLTree.MathNode(group.isOver ? "mover" : "munder", [buildGroup(group.base, options2), accentNode]); + }; + defineFunction({ + type: "horizBrace", + names: ["\\overbrace", "\\underbrace"], + props: { + numArgs: 1 + }, + handler(_ref, args) { + var { + parser: parser2, + funcName + } = _ref; + return { + type: "horizBrace", + mode: parser2.mode, + label: funcName, + isOver: /^\\over/.test(funcName), + base: args[0] + }; + }, + htmlBuilder: htmlBuilder$3, + mathmlBuilder: mathmlBuilder$2 + }); + defineFunction({ + type: "href", + names: ["\\href"], + props: { + numArgs: 2, + argTypes: ["url", "original"], + allowedInText: true + }, + handler: (_ref, args) => { + var { + parser: parser2 + } = _ref; + var body = args[1]; + var href = assertNodeType(args[0], "url").url; + if (!parser2.settings.isTrusted({ + command: "\\href", + url: href + })) { + return parser2.formatUnsupportedCmd("\\href"); + } + return { + type: "href", + mode: parser2.mode, + href, + body: ordargument(body) + }; + }, + htmlBuilder: (group, options2) => { + var elements2 = buildExpression$1(group.body, options2, false); + return buildCommon.makeAnchor(group.href, [], elements2, options2); + }, + mathmlBuilder: (group, options2) => { + var math2 = buildExpressionRow(group.body, options2); + if (!(math2 instanceof MathNode)) { + math2 = new MathNode("mrow", [math2]); + } + math2.setAttribute("href", group.href); + return math2; + } + }); + defineFunction({ + type: "href", + names: ["\\url"], + props: { + numArgs: 1, + argTypes: ["url"], + allowedInText: true + }, + handler: (_ref2, args) => { + var { + parser: parser2 + } = _ref2; + var href = assertNodeType(args[0], "url").url; + if (!parser2.settings.isTrusted({ + command: "\\url", + url: href + })) { + return parser2.formatUnsupportedCmd("\\url"); + } + var chars = []; + for (var i2 = 0; i2 < href.length; i2++) { + var c2 = href[i2]; + if (c2 === "~") { + c2 = "\\textasciitilde"; + } + chars.push({ + type: "textord", + mode: "text", + text: c2 + }); + } + var body = { + type: "text", + mode: parser2.mode, + font: "\\texttt", + body: chars + }; + return { + type: "href", + mode: parser2.mode, + href, + body: ordargument(body) + }; + } + }); + defineFunction({ + type: "hbox", + names: ["\\hbox"], + props: { + numArgs: 1, + argTypes: ["text"], + allowedInText: true, + primitive: true + }, + handler(_ref, args) { + var { + parser: parser2 + } = _ref; + return { + type: "hbox", + mode: parser2.mode, + body: ordargument(args[0]) + }; + }, + htmlBuilder(group, options2) { + var elements2 = buildExpression$1(group.body, options2, false); + return buildCommon.makeFragment(elements2); + }, + mathmlBuilder(group, options2) { + return new mathMLTree.MathNode("mrow", buildExpression(group.body, options2)); + } + }); + defineFunction({ + type: "html", + names: ["\\htmlClass", "\\htmlId", "\\htmlStyle", "\\htmlData"], + props: { + numArgs: 2, + argTypes: ["raw", "original"], + allowedInText: true + }, + handler: (_ref, args) => { + var { + parser: parser2, + funcName, + token: token2 + } = _ref; + var value2 = assertNodeType(args[0], "raw").string; + var body = args[1]; + if (parser2.settings.strict) { + parser2.settings.reportNonstrict("htmlExtension", "HTML extension is disabled on strict mode"); + } + var trustContext; + var attributes = {}; + switch (funcName) { + case "\\htmlClass": + attributes.class = value2; + trustContext = { + command: "\\htmlClass", + class: value2 + }; + break; + case "\\htmlId": + attributes.id = value2; + trustContext = { + command: "\\htmlId", + id: value2 + }; + break; + case "\\htmlStyle": + attributes.style = value2; + trustContext = { + command: "\\htmlStyle", + style: value2 + }; + break; + case "\\htmlData": { + var data = value2.split(","); + for (var i2 = 0; i2 < data.length; i2++) { + var keyVal = data[i2].split("="); + if (keyVal.length !== 2) { + throw new ParseError("Error parsing key-value for \\htmlData"); + } + attributes["data-" + keyVal[0].trim()] = keyVal[1].trim(); + } + trustContext = { + command: "\\htmlData", + attributes + }; + break; + } + default: + throw new Error("Unrecognized html command"); + } + if (!parser2.settings.isTrusted(trustContext)) { + return parser2.formatUnsupportedCmd(funcName); + } + return { + type: "html", + mode: parser2.mode, + attributes, + body: ordargument(body) + }; + }, + htmlBuilder: (group, options2) => { + var elements2 = buildExpression$1(group.body, options2, false); + var classes2 = ["enclosing"]; + if (group.attributes.class) { + classes2.push(...group.attributes.class.trim().split(/\s+/)); + } + var span = buildCommon.makeSpan(classes2, elements2, options2); + for (var attr in group.attributes) { + if (attr !== "class" && group.attributes.hasOwnProperty(attr)) { + span.setAttribute(attr, group.attributes[attr]); + } + } + return span; + }, + mathmlBuilder: (group, options2) => { + return buildExpressionRow(group.body, options2); + } + }); + defineFunction({ + type: "htmlmathml", + names: ["\\html@mathml"], + props: { + numArgs: 2, + allowedInText: true + }, + handler: (_ref, args) => { + var { + parser: parser2 + } = _ref; + return { + type: "htmlmathml", + mode: parser2.mode, + html: ordargument(args[0]), + mathml: ordargument(args[1]) + }; + }, + htmlBuilder: (group, options2) => { + var elements2 = buildExpression$1(group.html, options2, false); + return buildCommon.makeFragment(elements2); + }, + mathmlBuilder: (group, options2) => { + return buildExpressionRow(group.mathml, options2); + } + }); + var sizeData = function sizeData2(str2) { + if (/^[-+]? *(\d+(\.\d*)?|\.\d+)$/.test(str2)) { + return { + number: +str2, + unit: "bp" + }; + } else { + var match = /([-+]?) *(\d+(?:\.\d*)?|\.\d+) *([a-z]{2})/.exec(str2); + if (!match) { + throw new ParseError("Invalid size: '" + str2 + "' in \\includegraphics"); + } + var data = { + number: +(match[1] + match[2]), + // sign + magnitude, cast to number + unit: match[3] + }; + if (!validUnit(data)) { + throw new ParseError("Invalid unit: '" + data.unit + "' in \\includegraphics."); + } + return data; + } + }; + defineFunction({ + type: "includegraphics", + names: ["\\includegraphics"], + props: { + numArgs: 1, + numOptionalArgs: 1, + argTypes: ["raw", "url"], + allowedInText: false + }, + handler: (_ref, args, optArgs) => { + var { + parser: parser2 + } = _ref; + var width2 = { + number: 0, + unit: "em" + }; + var height = { + number: 0.9, + unit: "em" + }; + var totalheight = { + number: 0, + unit: "em" + }; + var alt = ""; + if (optArgs[0]) { + var attributeStr = assertNodeType(optArgs[0], "raw").string; + var attributes = attributeStr.split(","); + for (var i2 = 0; i2 < attributes.length; i2++) { + var keyVal = attributes[i2].split("="); + if (keyVal.length === 2) { + var str2 = keyVal[1].trim(); + switch (keyVal[0].trim()) { + case "alt": + alt = str2; + break; + case "width": + width2 = sizeData(str2); + break; + case "height": + height = sizeData(str2); + break; + case "totalheight": + totalheight = sizeData(str2); + break; + default: + throw new ParseError("Invalid key: '" + keyVal[0] + "' in \\includegraphics."); + } + } + } + } + var src = assertNodeType(args[0], "url").url; + if (alt === "") { + alt = src; + alt = alt.replace(/^.*[\\/]/, ""); + alt = alt.substring(0, alt.lastIndexOf(".")); + } + if (!parser2.settings.isTrusted({ + command: "\\includegraphics", + url: src + })) { + return parser2.formatUnsupportedCmd("\\includegraphics"); + } + return { + type: "includegraphics", + mode: parser2.mode, + alt, + width: width2, + height, + totalheight, + src + }; + }, + htmlBuilder: (group, options2) => { + var height = calculateSize(group.height, options2); + var depth = 0; + if (group.totalheight.number > 0) { + depth = calculateSize(group.totalheight, options2) - height; + } + var width2 = 0; + if (group.width.number > 0) { + width2 = calculateSize(group.width, options2); + } + var style = { + height: makeEm(height + depth) + }; + if (width2 > 0) { + style.width = makeEm(width2); + } + if (depth > 0) { + style.verticalAlign = makeEm(-depth); + } + var node2 = new Img(group.src, group.alt, style); + node2.height = height; + node2.depth = depth; + return node2; + }, + mathmlBuilder: (group, options2) => { + var node2 = new mathMLTree.MathNode("mglyph", []); + node2.setAttribute("alt", group.alt); + var height = calculateSize(group.height, options2); + var depth = 0; + if (group.totalheight.number > 0) { + depth = calculateSize(group.totalheight, options2) - height; + node2.setAttribute("valign", makeEm(-depth)); + } + node2.setAttribute("height", makeEm(height + depth)); + if (group.width.number > 0) { + var width2 = calculateSize(group.width, options2); + node2.setAttribute("width", makeEm(width2)); + } + node2.setAttribute("src", group.src); + return node2; + } + }); + defineFunction({ + type: "kern", + names: ["\\kern", "\\mkern", "\\hskip", "\\mskip"], + props: { + numArgs: 1, + argTypes: ["size"], + primitive: true, + allowedInText: true + }, + handler(_ref, args) { + var { + parser: parser2, + funcName + } = _ref; + var size2 = assertNodeType(args[0], "size"); + if (parser2.settings.strict) { + var mathFunction = funcName[1] === "m"; + var muUnit = size2.value.unit === "mu"; + if (mathFunction) { + if (!muUnit) { + parser2.settings.reportNonstrict("mathVsTextUnits", "LaTeX's " + funcName + " supports only mu units, " + ("not " + size2.value.unit + " units")); + } + if (parser2.mode !== "math") { + parser2.settings.reportNonstrict("mathVsTextUnits", "LaTeX's " + funcName + " works only in math mode"); + } + } else { + if (muUnit) { + parser2.settings.reportNonstrict("mathVsTextUnits", "LaTeX's " + funcName + " doesn't support mu units"); + } + } + } + return { + type: "kern", + mode: parser2.mode, + dimension: size2.value + }; + }, + htmlBuilder(group, options2) { + return buildCommon.makeGlue(group.dimension, options2); + }, + mathmlBuilder(group, options2) { + var dimension = calculateSize(group.dimension, options2); + return new mathMLTree.SpaceNode(dimension); + } + }); + defineFunction({ + type: "lap", + names: ["\\mathllap", "\\mathrlap", "\\mathclap"], + props: { + numArgs: 1, + allowedInText: true + }, + handler: (_ref, args) => { + var { + parser: parser2, + funcName + } = _ref; + var body = args[0]; + return { + type: "lap", + mode: parser2.mode, + alignment: funcName.slice(5), + body + }; + }, + htmlBuilder: (group, options2) => { + var inner2; + if (group.alignment === "clap") { + inner2 = buildCommon.makeSpan([], [buildGroup$1(group.body, options2)]); + inner2 = buildCommon.makeSpan(["inner"], [inner2], options2); + } else { + inner2 = buildCommon.makeSpan(["inner"], [buildGroup$1(group.body, options2)]); + } + var fix = buildCommon.makeSpan(["fix"], []); + var node2 = buildCommon.makeSpan([group.alignment], [inner2, fix], options2); + var strut = buildCommon.makeSpan(["strut"]); + strut.style.height = makeEm(node2.height + node2.depth); + if (node2.depth) { + strut.style.verticalAlign = makeEm(-node2.depth); + } + node2.children.unshift(strut); + node2 = buildCommon.makeSpan(["thinbox"], [node2], options2); + return buildCommon.makeSpan(["mord", "vbox"], [node2], options2); + }, + mathmlBuilder: (group, options2) => { + var node2 = new mathMLTree.MathNode("mpadded", [buildGroup(group.body, options2)]); + if (group.alignment !== "rlap") { + var offset = group.alignment === "llap" ? "-1" : "-0.5"; + node2.setAttribute("lspace", offset + "width"); + } + node2.setAttribute("width", "0px"); + return node2; + } + }); + defineFunction({ + type: "styling", + names: ["\\(", "$"], + props: { + numArgs: 0, + allowedInText: true, + allowedInMath: false + }, + handler(_ref, args) { + var { + funcName, + parser: parser2 + } = _ref; + var outerMode = parser2.mode; + parser2.switchMode("math"); + var close2 = funcName === "\\(" ? "\\)" : "$"; + var body = parser2.parseExpression(false, close2); + parser2.expect(close2); + parser2.switchMode(outerMode); + return { + type: "styling", + mode: parser2.mode, + style: "text", + body + }; + } + }); + defineFunction({ + type: "text", + // Doesn't matter what this is. + names: ["\\)", "\\]"], + props: { + numArgs: 0, + allowedInText: true, + allowedInMath: false + }, + handler(context, args) { + throw new ParseError("Mismatched " + context.funcName); + } + }); + var chooseMathStyle = (group, options2) => { + switch (options2.style.size) { + case Style$1.DISPLAY.size: + return group.display; + case Style$1.TEXT.size: + return group.text; + case Style$1.SCRIPT.size: + return group.script; + case Style$1.SCRIPTSCRIPT.size: + return group.scriptscript; + default: + return group.text; + } + }; + defineFunction({ + type: "mathchoice", + names: ["\\mathchoice"], + props: { + numArgs: 4, + primitive: true + }, + handler: (_ref, args) => { + var { + parser: parser2 + } = _ref; + return { + type: "mathchoice", + mode: parser2.mode, + display: ordargument(args[0]), + text: ordargument(args[1]), + script: ordargument(args[2]), + scriptscript: ordargument(args[3]) + }; + }, + htmlBuilder: (group, options2) => { + var body = chooseMathStyle(group, options2); + var elements2 = buildExpression$1(body, options2, false); + return buildCommon.makeFragment(elements2); + }, + mathmlBuilder: (group, options2) => { + var body = chooseMathStyle(group, options2); + return buildExpressionRow(body, options2); + } + }); + var assembleSupSub = (base, supGroup, subGroup, options2, style, slant, baseShift) => { + base = buildCommon.makeSpan([], [base]); + var subIsSingleCharacter = subGroup && utils.isCharacterBox(subGroup); + var sub2; + var sup2; + if (supGroup) { + var elem = buildGroup$1(supGroup, options2.havingStyle(style.sup()), options2); + sup2 = { + elem, + kern: Math.max(options2.fontMetrics().bigOpSpacing1, options2.fontMetrics().bigOpSpacing3 - elem.depth) + }; + } + if (subGroup) { + var _elem = buildGroup$1(subGroup, options2.havingStyle(style.sub()), options2); + sub2 = { + elem: _elem, + kern: Math.max(options2.fontMetrics().bigOpSpacing2, options2.fontMetrics().bigOpSpacing4 - _elem.height) + }; + } + var finalGroup; + if (sup2 && sub2) { + var bottom2 = options2.fontMetrics().bigOpSpacing5 + sub2.elem.height + sub2.elem.depth + sub2.kern + base.depth + baseShift; + finalGroup = buildCommon.makeVList({ + positionType: "bottom", + positionData: bottom2, + children: [{ + type: "kern", + size: options2.fontMetrics().bigOpSpacing5 + }, { + type: "elem", + elem: sub2.elem, + marginLeft: makeEm(-slant) + }, { + type: "kern", + size: sub2.kern + }, { + type: "elem", + elem: base + }, { + type: "kern", + size: sup2.kern + }, { + type: "elem", + elem: sup2.elem, + marginLeft: makeEm(slant) + }, { + type: "kern", + size: options2.fontMetrics().bigOpSpacing5 + }] + }, options2); + } else if (sub2) { + var top2 = base.height - baseShift; + finalGroup = buildCommon.makeVList({ + positionType: "top", + positionData: top2, + children: [{ + type: "kern", + size: options2.fontMetrics().bigOpSpacing5 + }, { + type: "elem", + elem: sub2.elem, + marginLeft: makeEm(-slant) + }, { + type: "kern", + size: sub2.kern + }, { + type: "elem", + elem: base + }] + }, options2); + } else if (sup2) { + var _bottom = base.depth + baseShift; + finalGroup = buildCommon.makeVList({ + positionType: "bottom", + positionData: _bottom, + children: [{ + type: "elem", + elem: base + }, { + type: "kern", + size: sup2.kern + }, { + type: "elem", + elem: sup2.elem, + marginLeft: makeEm(slant) + }, { + type: "kern", + size: options2.fontMetrics().bigOpSpacing5 + }] + }, options2); + } else { + return base; + } + var parts = [finalGroup]; + if (sub2 && slant !== 0 && !subIsSingleCharacter) { + var spacer = buildCommon.makeSpan(["mspace"], [], options2); + spacer.style.marginRight = makeEm(slant); + parts.unshift(spacer); + } + return buildCommon.makeSpan(["mop", "op-limits"], parts, options2); + }; + var noSuccessor = ["\\smallint"]; + var htmlBuilder$2 = (grp, options2) => { + var supGroup; + var subGroup; + var hasLimits = false; + var group; + if (grp.type === "supsub") { + supGroup = grp.sup; + subGroup = grp.sub; + group = assertNodeType(grp.base, "op"); + hasLimits = true; + } else { + group = assertNodeType(grp, "op"); + } + var style = options2.style; + var large = false; + if (style.size === Style$1.DISPLAY.size && group.symbol && !utils.contains(noSuccessor, group.name)) { + large = true; + } + var base; + if (group.symbol) { + var fontName = large ? "Size2-Regular" : "Size1-Regular"; + var stash = ""; + if (group.name === "\\oiint" || group.name === "\\oiiint") { + stash = group.name.slice(1); + group.name = stash === "oiint" ? "\\iint" : "\\iiint"; + } + base = buildCommon.makeSymbol(group.name, fontName, "math", options2, ["mop", "op-symbol", large ? "large-op" : "small-op"]); + if (stash.length > 0) { + var italic = base.italic; + var oval = buildCommon.staticSvg(stash + "Size" + (large ? "2" : "1"), options2); + base = buildCommon.makeVList({ + positionType: "individualShift", + children: [{ + type: "elem", + elem: base, + shift: 0 + }, { + type: "elem", + elem: oval, + shift: large ? 0.08 : 0 + }] + }, options2); + group.name = "\\" + stash; + base.classes.unshift("mop"); + base.italic = italic; + } + } else if (group.body) { + var inner2 = buildExpression$1(group.body, options2, true); + if (inner2.length === 1 && inner2[0] instanceof SymbolNode) { + base = inner2[0]; + base.classes[0] = "mop"; + } else { + base = buildCommon.makeSpan(["mop"], inner2, options2); + } + } else { + var output = []; + for (var i2 = 1; i2 < group.name.length; i2++) { + output.push(buildCommon.mathsym(group.name[i2], group.mode, options2)); + } + base = buildCommon.makeSpan(["mop"], output, options2); + } + var baseShift = 0; + var slant = 0; + if ((base instanceof SymbolNode || group.name === "\\oiint" || group.name === "\\oiiint") && !group.suppressBaseShift) { + baseShift = (base.height - base.depth) / 2 - options2.fontMetrics().axisHeight; + slant = base.italic; + } + if (hasLimits) { + return assembleSupSub(base, supGroup, subGroup, options2, style, slant, baseShift); + } else { + if (baseShift) { + base.style.position = "relative"; + base.style.top = makeEm(baseShift); + } + return base; + } + }; + var mathmlBuilder$1 = (group, options2) => { + var node2; + if (group.symbol) { + node2 = new MathNode("mo", [makeText(group.name, group.mode)]); + if (utils.contains(noSuccessor, group.name)) { + node2.setAttribute("largeop", "false"); + } + } else if (group.body) { + node2 = new MathNode("mo", buildExpression(group.body, options2)); + } else { + node2 = new MathNode("mi", [new TextNode(group.name.slice(1))]); + var operator = new MathNode("mo", [makeText("⁡", "text")]); + if (group.parentIsSupSub) { + node2 = new MathNode("mrow", [node2, operator]); + } else { + node2 = newDocumentFragment([node2, operator]); + } + } + return node2; + }; + var singleCharBigOps = { + "∏": "\\prod", + "∐": "\\coprod", + "∑": "\\sum", + "⋀": "\\bigwedge", + "⋁": "\\bigvee", + "⋂": "\\bigcap", + "⋃": "\\bigcup", + "⨀": "\\bigodot", + "⨁": "\\bigoplus", + "⨂": "\\bigotimes", + "⨄": "\\biguplus", + "⨆": "\\bigsqcup" + }; + defineFunction({ + type: "op", + names: ["\\coprod", "\\bigvee", "\\bigwedge", "\\biguplus", "\\bigcap", "\\bigcup", "\\intop", "\\prod", "\\sum", "\\bigotimes", "\\bigoplus", "\\bigodot", "\\bigsqcup", "\\smallint", "∏", "∐", "∑", "⋀", "⋁", "⋂", "⋃", "⨀", "⨁", "⨂", "⨄", "⨆"], + props: { + numArgs: 0 + }, + handler: (_ref, args) => { + var { + parser: parser2, + funcName + } = _ref; + var fName = funcName; + if (fName.length === 1) { + fName = singleCharBigOps[fName]; + } + return { + type: "op", + mode: parser2.mode, + limits: true, + parentIsSupSub: false, + symbol: true, + name: fName + }; + }, + htmlBuilder: htmlBuilder$2, + mathmlBuilder: mathmlBuilder$1 + }); + defineFunction({ + type: "op", + names: ["\\mathop"], + props: { + numArgs: 1, + primitive: true + }, + handler: (_ref2, args) => { + var { + parser: parser2 + } = _ref2; + var body = args[0]; + return { + type: "op", + mode: parser2.mode, + limits: false, + parentIsSupSub: false, + symbol: false, + body: ordargument(body) + }; + }, + htmlBuilder: htmlBuilder$2, + mathmlBuilder: mathmlBuilder$1 + }); + var singleCharIntegrals = { + "∫": "\\int", + "∬": "\\iint", + "∭": "\\iiint", + "∮": "\\oint", + "∯": "\\oiint", + "∰": "\\oiiint" + }; + defineFunction({ + type: "op", + names: ["\\arcsin", "\\arccos", "\\arctan", "\\arctg", "\\arcctg", "\\arg", "\\ch", "\\cos", "\\cosec", "\\cosh", "\\cot", "\\cotg", "\\coth", "\\csc", "\\ctg", "\\cth", "\\deg", "\\dim", "\\exp", "\\hom", "\\ker", "\\lg", "\\ln", "\\log", "\\sec", "\\sin", "\\sinh", "\\sh", "\\tan", "\\tanh", "\\tg", "\\th"], + props: { + numArgs: 0 + }, + handler(_ref3) { + var { + parser: parser2, + funcName + } = _ref3; + return { + type: "op", + mode: parser2.mode, + limits: false, + parentIsSupSub: false, + symbol: false, + name: funcName + }; + }, + htmlBuilder: htmlBuilder$2, + mathmlBuilder: mathmlBuilder$1 + }); + defineFunction({ + type: "op", + names: ["\\det", "\\gcd", "\\inf", "\\lim", "\\max", "\\min", "\\Pr", "\\sup"], + props: { + numArgs: 0 + }, + handler(_ref4) { + var { + parser: parser2, + funcName + } = _ref4; + return { + type: "op", + mode: parser2.mode, + limits: true, + parentIsSupSub: false, + symbol: false, + name: funcName + }; + }, + htmlBuilder: htmlBuilder$2, + mathmlBuilder: mathmlBuilder$1 + }); + defineFunction({ + type: "op", + names: ["\\int", "\\iint", "\\iiint", "\\oint", "\\oiint", "\\oiiint", "∫", "∬", "∭", "∮", "∯", "∰"], + props: { + numArgs: 0 + }, + handler(_ref5) { + var { + parser: parser2, + funcName + } = _ref5; + var fName = funcName; + if (fName.length === 1) { + fName = singleCharIntegrals[fName]; + } + return { + type: "op", + mode: parser2.mode, + limits: false, + parentIsSupSub: false, + symbol: true, + name: fName + }; + }, + htmlBuilder: htmlBuilder$2, + mathmlBuilder: mathmlBuilder$1 + }); + var htmlBuilder$1 = (grp, options2) => { + var supGroup; + var subGroup; + var hasLimits = false; + var group; + if (grp.type === "supsub") { + supGroup = grp.sup; + subGroup = grp.sub; + group = assertNodeType(grp.base, "operatorname"); + hasLimits = true; + } else { + group = assertNodeType(grp, "operatorname"); + } + var base; + if (group.body.length > 0) { + var body = group.body.map((child2) => { + var childText = child2.text; + if (typeof childText === "string") { + return { + type: "textord", + mode: child2.mode, + text: childText + }; + } else { + return child2; + } + }); + var expression = buildExpression$1(body, options2.withFont("mathrm"), true); + for (var i2 = 0; i2 < expression.length; i2++) { + var child = expression[i2]; + if (child instanceof SymbolNode) { + child.text = child.text.replace(/\u2212/, "-").replace(/\u2217/, "*"); + } + } + base = buildCommon.makeSpan(["mop"], expression, options2); + } else { + base = buildCommon.makeSpan(["mop"], [], options2); + } + if (hasLimits) { + return assembleSupSub(base, supGroup, subGroup, options2, options2.style, 0, 0); + } else { + return base; + } + }; + var mathmlBuilder = (group, options2) => { + var expression = buildExpression(group.body, options2.withFont("mathrm")); + var isAllString = true; + for (var i2 = 0; i2 < expression.length; i2++) { + var node2 = expression[i2]; + if (node2 instanceof mathMLTree.SpaceNode) + ; + else if (node2 instanceof mathMLTree.MathNode) { + switch (node2.type) { + case "mi": + case "mn": + case "ms": + case "mspace": + case "mtext": + break; + case "mo": { + var child = node2.children[0]; + if (node2.children.length === 1 && child instanceof mathMLTree.TextNode) { + child.text = child.text.replace(/\u2212/, "-").replace(/\u2217/, "*"); + } else { + isAllString = false; + } + break; + } + default: + isAllString = false; + } + } else { + isAllString = false; + } + } + if (isAllString) { + var word = expression.map((node3) => node3.toText()).join(""); + expression = [new mathMLTree.TextNode(word)]; + } + var identifier2 = new mathMLTree.MathNode("mi", expression); + identifier2.setAttribute("mathvariant", "normal"); + var operator = new mathMLTree.MathNode("mo", [makeText("⁡", "text")]); + if (group.parentIsSupSub) { + return new mathMLTree.MathNode("mrow", [identifier2, operator]); + } else { + return mathMLTree.newDocumentFragment([identifier2, operator]); + } + }; + defineFunction({ + type: "operatorname", + names: ["\\operatorname@", "\\operatornamewithlimits"], + props: { + numArgs: 1 + }, + handler: (_ref, args) => { + var { + parser: parser2, + funcName + } = _ref; + var body = args[0]; + return { + type: "operatorname", + mode: parser2.mode, + body: ordargument(body), + alwaysHandleSupSub: funcName === "\\operatornamewithlimits", + limits: false, + parentIsSupSub: false + }; + }, + htmlBuilder: htmlBuilder$1, + mathmlBuilder + }); + defineMacro("\\operatorname", "\\@ifstar\\operatornamewithlimits\\operatorname@"); + defineFunctionBuilders({ + type: "ordgroup", + htmlBuilder(group, options2) { + if (group.semisimple) { + return buildCommon.makeFragment(buildExpression$1(group.body, options2, false)); + } + return buildCommon.makeSpan(["mord"], buildExpression$1(group.body, options2, true), options2); + }, + mathmlBuilder(group, options2) { + return buildExpressionRow(group.body, options2, true); + } + }); + defineFunction({ + type: "overline", + names: ["\\overline"], + props: { + numArgs: 1 + }, + handler(_ref, args) { + var { + parser: parser2 + } = _ref; + var body = args[0]; + return { + type: "overline", + mode: parser2.mode, + body + }; + }, + htmlBuilder(group, options2) { + var innerGroup = buildGroup$1(group.body, options2.havingCrampedStyle()); + var line2 = buildCommon.makeLineSpan("overline-line", options2); + var defaultRuleThickness = options2.fontMetrics().defaultRuleThickness; + var vlist = buildCommon.makeVList({ + positionType: "firstBaseline", + children: [{ + type: "elem", + elem: innerGroup + }, { + type: "kern", + size: 3 * defaultRuleThickness + }, { + type: "elem", + elem: line2 + }, { + type: "kern", + size: defaultRuleThickness + }] + }, options2); + return buildCommon.makeSpan(["mord", "overline"], [vlist], options2); + }, + mathmlBuilder(group, options2) { + var operator = new mathMLTree.MathNode("mo", [new mathMLTree.TextNode("‾")]); + operator.setAttribute("stretchy", "true"); + var node2 = new mathMLTree.MathNode("mover", [buildGroup(group.body, options2), operator]); + node2.setAttribute("accent", "true"); + return node2; + } + }); + defineFunction({ + type: "phantom", + names: ["\\phantom"], + props: { + numArgs: 1, + allowedInText: true + }, + handler: (_ref, args) => { + var { + parser: parser2 + } = _ref; + var body = args[0]; + return { + type: "phantom", + mode: parser2.mode, + body: ordargument(body) + }; + }, + htmlBuilder: (group, options2) => { + var elements2 = buildExpression$1(group.body, options2.withPhantom(), false); + return buildCommon.makeFragment(elements2); + }, + mathmlBuilder: (group, options2) => { + var inner2 = buildExpression(group.body, options2); + return new mathMLTree.MathNode("mphantom", inner2); + } + }); + defineFunction({ + type: "hphantom", + names: ["\\hphantom"], + props: { + numArgs: 1, + allowedInText: true + }, + handler: (_ref2, args) => { + var { + parser: parser2 + } = _ref2; + var body = args[0]; + return { + type: "hphantom", + mode: parser2.mode, + body + }; + }, + htmlBuilder: (group, options2) => { + var node2 = buildCommon.makeSpan([], [buildGroup$1(group.body, options2.withPhantom())]); + node2.height = 0; + node2.depth = 0; + if (node2.children) { + for (var i2 = 0; i2 < node2.children.length; i2++) { + node2.children[i2].height = 0; + node2.children[i2].depth = 0; + } + } + node2 = buildCommon.makeVList({ + positionType: "firstBaseline", + children: [{ + type: "elem", + elem: node2 + }] + }, options2); + return buildCommon.makeSpan(["mord"], [node2], options2); + }, + mathmlBuilder: (group, options2) => { + var inner2 = buildExpression(ordargument(group.body), options2); + var phantom = new mathMLTree.MathNode("mphantom", inner2); + var node2 = new mathMLTree.MathNode("mpadded", [phantom]); + node2.setAttribute("height", "0px"); + node2.setAttribute("depth", "0px"); + return node2; + } + }); + defineFunction({ + type: "vphantom", + names: ["\\vphantom"], + props: { + numArgs: 1, + allowedInText: true + }, + handler: (_ref3, args) => { + var { + parser: parser2 + } = _ref3; + var body = args[0]; + return { + type: "vphantom", + mode: parser2.mode, + body + }; + }, + htmlBuilder: (group, options2) => { + var inner2 = buildCommon.makeSpan(["inner"], [buildGroup$1(group.body, options2.withPhantom())]); + var fix = buildCommon.makeSpan(["fix"], []); + return buildCommon.makeSpan(["mord", "rlap"], [inner2, fix], options2); + }, + mathmlBuilder: (group, options2) => { + var inner2 = buildExpression(ordargument(group.body), options2); + var phantom = new mathMLTree.MathNode("mphantom", inner2); + var node2 = new mathMLTree.MathNode("mpadded", [phantom]); + node2.setAttribute("width", "0px"); + return node2; + } + }); + defineFunction({ + type: "raisebox", + names: ["\\raisebox"], + props: { + numArgs: 2, + argTypes: ["size", "hbox"], + allowedInText: true + }, + handler(_ref, args) { + var { + parser: parser2 + } = _ref; + var amount = assertNodeType(args[0], "size").value; + var body = args[1]; + return { + type: "raisebox", + mode: parser2.mode, + dy: amount, + body + }; + }, + htmlBuilder(group, options2) { + var body = buildGroup$1(group.body, options2); + var dy = calculateSize(group.dy, options2); + return buildCommon.makeVList({ + positionType: "shift", + positionData: -dy, + children: [{ + type: "elem", + elem: body + }] + }, options2); + }, + mathmlBuilder(group, options2) { + var node2 = new mathMLTree.MathNode("mpadded", [buildGroup(group.body, options2)]); + var dy = group.dy.number + group.dy.unit; + node2.setAttribute("voffset", dy); + return node2; + } + }); + defineFunction({ + type: "internal", + names: ["\\relax"], + props: { + numArgs: 0, + allowedInText: true + }, + handler(_ref) { + var { + parser: parser2 + } = _ref; + return { + type: "internal", + mode: parser2.mode + }; + } + }); + defineFunction({ + type: "rule", + names: ["\\rule"], + props: { + numArgs: 2, + numOptionalArgs: 1, + argTypes: ["size", "size", "size"] + }, + handler(_ref, args, optArgs) { + var { + parser: parser2 + } = _ref; + var shift = optArgs[0]; + var width2 = assertNodeType(args[0], "size"); + var height = assertNodeType(args[1], "size"); + return { + type: "rule", + mode: parser2.mode, + shift: shift && assertNodeType(shift, "size").value, + width: width2.value, + height: height.value + }; + }, + htmlBuilder(group, options2) { + var rule = buildCommon.makeSpan(["mord", "rule"], [], options2); + var width2 = calculateSize(group.width, options2); + var height = calculateSize(group.height, options2); + var shift = group.shift ? calculateSize(group.shift, options2) : 0; + rule.style.borderRightWidth = makeEm(width2); + rule.style.borderTopWidth = makeEm(height); + rule.style.bottom = makeEm(shift); + rule.width = width2; + rule.height = height + shift; + rule.depth = -shift; + rule.maxFontSize = height * 1.125 * options2.sizeMultiplier; + return rule; + }, + mathmlBuilder(group, options2) { + var width2 = calculateSize(group.width, options2); + var height = calculateSize(group.height, options2); + var shift = group.shift ? calculateSize(group.shift, options2) : 0; + var color2 = options2.color && options2.getColor() || "black"; + var rule = new mathMLTree.MathNode("mspace"); + rule.setAttribute("mathbackground", color2); + rule.setAttribute("width", makeEm(width2)); + rule.setAttribute("height", makeEm(height)); + var wrapper = new mathMLTree.MathNode("mpadded", [rule]); + if (shift >= 0) { + wrapper.setAttribute("height", makeEm(shift)); + } else { + wrapper.setAttribute("height", makeEm(shift)); + wrapper.setAttribute("depth", makeEm(-shift)); + } + wrapper.setAttribute("voffset", makeEm(shift)); + return wrapper; + } + }); + function sizingGroup(value2, options2, baseOptions) { + var inner2 = buildExpression$1(value2, options2, false); + var multiplier = options2.sizeMultiplier / baseOptions.sizeMultiplier; + for (var i2 = 0; i2 < inner2.length; i2++) { + var pos = inner2[i2].classes.indexOf("sizing"); + if (pos < 0) { + Array.prototype.push.apply(inner2[i2].classes, options2.sizingClasses(baseOptions)); + } else if (inner2[i2].classes[pos + 1] === "reset-size" + options2.size) { + inner2[i2].classes[pos + 1] = "reset-size" + baseOptions.size; + } + inner2[i2].height *= multiplier; + inner2[i2].depth *= multiplier; + } + return buildCommon.makeFragment(inner2); + } + var sizeFuncs = ["\\tiny", "\\sixptsize", "\\scriptsize", "\\footnotesize", "\\small", "\\normalsize", "\\large", "\\Large", "\\LARGE", "\\huge", "\\Huge"]; + var htmlBuilder = (group, options2) => { + var newOptions = options2.havingSize(group.size); + return sizingGroup(group.body, newOptions, options2); + }; + defineFunction({ + type: "sizing", + names: sizeFuncs, + props: { + numArgs: 0, + allowedInText: true + }, + handler: (_ref, args) => { + var { + breakOnTokenText, + funcName, + parser: parser2 + } = _ref; + var body = parser2.parseExpression(false, breakOnTokenText); + return { + type: "sizing", + mode: parser2.mode, + // Figure out what size to use based on the list of functions above + size: sizeFuncs.indexOf(funcName) + 1, + body + }; + }, + htmlBuilder, + mathmlBuilder: (group, options2) => { + var newOptions = options2.havingSize(group.size); + var inner2 = buildExpression(group.body, newOptions); + var node2 = new mathMLTree.MathNode("mstyle", inner2); + node2.setAttribute("mathsize", makeEm(newOptions.sizeMultiplier)); + return node2; + } + }); + defineFunction({ + type: "smash", + names: ["\\smash"], + props: { + numArgs: 1, + numOptionalArgs: 1, + allowedInText: true + }, + handler: (_ref, args, optArgs) => { + var { + parser: parser2 + } = _ref; + var smashHeight = false; + var smashDepth = false; + var tbArg = optArgs[0] && assertNodeType(optArgs[0], "ordgroup"); + if (tbArg) { + var letter = ""; + for (var i2 = 0; i2 < tbArg.body.length; ++i2) { + var node2 = tbArg.body[i2]; + letter = node2.text; + if (letter === "t") { + smashHeight = true; + } else if (letter === "b") { + smashDepth = true; + } else { + smashHeight = false; + smashDepth = false; + break; + } + } + } else { + smashHeight = true; + smashDepth = true; + } + var body = args[0]; + return { + type: "smash", + mode: parser2.mode, + body, + smashHeight, + smashDepth + }; + }, + htmlBuilder: (group, options2) => { + var node2 = buildCommon.makeSpan([], [buildGroup$1(group.body, options2)]); + if (!group.smashHeight && !group.smashDepth) { + return node2; + } + if (group.smashHeight) { + node2.height = 0; + if (node2.children) { + for (var i2 = 0; i2 < node2.children.length; i2++) { + node2.children[i2].height = 0; + } + } + } + if (group.smashDepth) { + node2.depth = 0; + if (node2.children) { + for (var _i6 = 0; _i6 < node2.children.length; _i6++) { + node2.children[_i6].depth = 0; + } + } + } + var smashedNode = buildCommon.makeVList({ + positionType: "firstBaseline", + children: [{ + type: "elem", + elem: node2 + }] + }, options2); + return buildCommon.makeSpan(["mord"], [smashedNode], options2); + }, + mathmlBuilder: (group, options2) => { + var node2 = new mathMLTree.MathNode("mpadded", [buildGroup(group.body, options2)]); + if (group.smashHeight) { + node2.setAttribute("height", "0px"); + } + if (group.smashDepth) { + node2.setAttribute("depth", "0px"); + } + return node2; + } + }); + defineFunction({ + type: "sqrt", + names: ["\\sqrt"], + props: { + numArgs: 1, + numOptionalArgs: 1 + }, + handler(_ref, args, optArgs) { + var { + parser: parser2 + } = _ref; + var index2 = optArgs[0]; + var body = args[0]; + return { + type: "sqrt", + mode: parser2.mode, + body, + index: index2 + }; + }, + htmlBuilder(group, options2) { + var inner2 = buildGroup$1(group.body, options2.havingCrampedStyle()); + if (inner2.height === 0) { + inner2.height = options2.fontMetrics().xHeight; + } + inner2 = buildCommon.wrapFragment(inner2, options2); + var metrics = options2.fontMetrics(); + var theta = metrics.defaultRuleThickness; + var phi = theta; + if (options2.style.id < Style$1.TEXT.id) { + phi = options2.fontMetrics().xHeight; + } + var lineClearance = theta + phi / 4; + var minDelimiterHeight = inner2.height + inner2.depth + lineClearance + theta; + var { + span: img, + ruleWidth, + advanceWidth + } = delimiter.sqrtImage(minDelimiterHeight, options2); + var delimDepth = img.height - ruleWidth; + if (delimDepth > inner2.height + inner2.depth + lineClearance) { + lineClearance = (lineClearance + delimDepth - inner2.height - inner2.depth) / 2; + } + var imgShift = img.height - inner2.height - lineClearance - ruleWidth; + inner2.style.paddingLeft = makeEm(advanceWidth); + var body = buildCommon.makeVList({ + positionType: "firstBaseline", + children: [{ + type: "elem", + elem: inner2, + wrapperClasses: ["svg-align"] + }, { + type: "kern", + size: -(inner2.height + imgShift) + }, { + type: "elem", + elem: img + }, { + type: "kern", + size: ruleWidth + }] + }, options2); + if (!group.index) { + return buildCommon.makeSpan(["mord", "sqrt"], [body], options2); + } else { + var newOptions = options2.havingStyle(Style$1.SCRIPTSCRIPT); + var rootm = buildGroup$1(group.index, newOptions, options2); + var toShift = 0.6 * (body.height - body.depth); + var rootVList = buildCommon.makeVList({ + positionType: "shift", + positionData: -toShift, + children: [{ + type: "elem", + elem: rootm + }] + }, options2); + var rootVListWrap = buildCommon.makeSpan(["root"], [rootVList]); + return buildCommon.makeSpan(["mord", "sqrt"], [rootVListWrap, body], options2); + } + }, + mathmlBuilder(group, options2) { + var { + body, + index: index2 + } = group; + return index2 ? new mathMLTree.MathNode("mroot", [buildGroup(body, options2), buildGroup(index2, options2)]) : new mathMLTree.MathNode("msqrt", [buildGroup(body, options2)]); + } + }); + var styleMap = { + "display": Style$1.DISPLAY, + "text": Style$1.TEXT, + "script": Style$1.SCRIPT, + "scriptscript": Style$1.SCRIPTSCRIPT + }; + defineFunction({ + type: "styling", + names: ["\\displaystyle", "\\textstyle", "\\scriptstyle", "\\scriptscriptstyle"], + props: { + numArgs: 0, + allowedInText: true, + primitive: true + }, + handler(_ref, args) { + var { + breakOnTokenText, + funcName, + parser: parser2 + } = _ref; + var body = parser2.parseExpression(true, breakOnTokenText); + var style = funcName.slice(1, funcName.length - 5); + return { + type: "styling", + mode: parser2.mode, + // Figure out what style to use by pulling out the style from + // the function name + style, + body + }; + }, + htmlBuilder(group, options2) { + var newStyle = styleMap[group.style]; + var newOptions = options2.havingStyle(newStyle).withFont(""); + return sizingGroup(group.body, newOptions, options2); + }, + mathmlBuilder(group, options2) { + var newStyle = styleMap[group.style]; + var newOptions = options2.havingStyle(newStyle); + var inner2 = buildExpression(group.body, newOptions); + var node2 = new mathMLTree.MathNode("mstyle", inner2); + var styleAttributes = { + "display": ["0", "true"], + "text": ["0", "false"], + "script": ["1", "false"], + "scriptscript": ["2", "false"] + }; + var attr = styleAttributes[group.style]; + node2.setAttribute("scriptlevel", attr[0]); + node2.setAttribute("displaystyle", attr[1]); + return node2; + } + }); + var htmlBuilderDelegate = function htmlBuilderDelegate2(group, options2) { + var base = group.base; + if (!base) { + return null; + } else if (base.type === "op") { + var delegate = base.limits && (options2.style.size === Style$1.DISPLAY.size || base.alwaysHandleSupSub); + return delegate ? htmlBuilder$2 : null; + } else if (base.type === "operatorname") { + var _delegate = base.alwaysHandleSupSub && (options2.style.size === Style$1.DISPLAY.size || base.limits); + return _delegate ? htmlBuilder$1 : null; + } else if (base.type === "accent") { + return utils.isCharacterBox(base.base) ? htmlBuilder$a : null; + } else if (base.type === "horizBrace") { + var isSup = !group.sub; + return isSup === base.isOver ? htmlBuilder$3 : null; + } else { + return null; + } + }; + defineFunctionBuilders({ + type: "supsub", + htmlBuilder(group, options2) { + var builderDelegate = htmlBuilderDelegate(group, options2); + if (builderDelegate) { + return builderDelegate(group, options2); + } + var { + base: valueBase, + sup: valueSup, + sub: valueSub + } = group; + var base = buildGroup$1(valueBase, options2); + var supm; + var subm; + var metrics = options2.fontMetrics(); + var supShift = 0; + var subShift = 0; + var isCharacterBox2 = valueBase && utils.isCharacterBox(valueBase); + if (valueSup) { + var newOptions = options2.havingStyle(options2.style.sup()); + supm = buildGroup$1(valueSup, newOptions, options2); + if (!isCharacterBox2) { + supShift = base.height - newOptions.fontMetrics().supDrop * newOptions.sizeMultiplier / options2.sizeMultiplier; + } + } + if (valueSub) { + var _newOptions = options2.havingStyle(options2.style.sub()); + subm = buildGroup$1(valueSub, _newOptions, options2); + if (!isCharacterBox2) { + subShift = base.depth + _newOptions.fontMetrics().subDrop * _newOptions.sizeMultiplier / options2.sizeMultiplier; + } + } + var minSupShift; + if (options2.style === Style$1.DISPLAY) { + minSupShift = metrics.sup1; + } else if (options2.style.cramped) { + minSupShift = metrics.sup3; + } else { + minSupShift = metrics.sup2; + } + var multiplier = options2.sizeMultiplier; + var marginRight = makeEm(0.5 / metrics.ptPerEm / multiplier); + var marginLeft = null; + if (subm) { + var isOiint = group.base && group.base.type === "op" && group.base.name && (group.base.name === "\\oiint" || group.base.name === "\\oiiint"); + if (base instanceof SymbolNode || isOiint) { + marginLeft = makeEm(-base.italic); + } + } + var supsub; + if (supm && subm) { + supShift = Math.max(supShift, minSupShift, supm.depth + 0.25 * metrics.xHeight); + subShift = Math.max(subShift, metrics.sub2); + var ruleWidth = metrics.defaultRuleThickness; + var maxWidth = 4 * ruleWidth; + if (supShift - supm.depth - (subm.height - subShift) < maxWidth) { + subShift = maxWidth - (supShift - supm.depth) + subm.height; + var psi = 0.8 * metrics.xHeight - (supShift - supm.depth); + if (psi > 0) { + supShift += psi; + subShift -= psi; + } + } + var vlistElem = [{ + type: "elem", + elem: subm, + shift: subShift, + marginRight, + marginLeft + }, { + type: "elem", + elem: supm, + shift: -supShift, + marginRight + }]; + supsub = buildCommon.makeVList({ + positionType: "individualShift", + children: vlistElem + }, options2); + } else if (subm) { + subShift = Math.max(subShift, metrics.sub1, subm.height - 0.8 * metrics.xHeight); + var _vlistElem = [{ + type: "elem", + elem: subm, + marginLeft, + marginRight + }]; + supsub = buildCommon.makeVList({ + positionType: "shift", + positionData: subShift, + children: _vlistElem + }, options2); + } else if (supm) { + supShift = Math.max(supShift, minSupShift, supm.depth + 0.25 * metrics.xHeight); + supsub = buildCommon.makeVList({ + positionType: "shift", + positionData: -supShift, + children: [{ + type: "elem", + elem: supm, + marginRight + }] + }, options2); + } else { + throw new Error("supsub must have either sup or sub."); + } + var mclass = getTypeOfDomTree(base, "right") || "mord"; + return buildCommon.makeSpan([mclass], [base, buildCommon.makeSpan(["msupsub"], [supsub])], options2); + }, + mathmlBuilder(group, options2) { + var isBrace = false; + var isOver; + var isSup; + if (group.base && group.base.type === "horizBrace") { + isSup = !!group.sup; + if (isSup === group.base.isOver) { + isBrace = true; + isOver = group.base.isOver; + } + } + if (group.base && (group.base.type === "op" || group.base.type === "operatorname")) { + group.base.parentIsSupSub = true; + } + var children2 = [buildGroup(group.base, options2)]; + if (group.sub) { + children2.push(buildGroup(group.sub, options2)); + } + if (group.sup) { + children2.push(buildGroup(group.sup, options2)); + } + var nodeType2; + if (isBrace) { + nodeType2 = isOver ? "mover" : "munder"; + } else if (!group.sub) { + var base = group.base; + if (base && base.type === "op" && base.limits && (options2.style === Style$1.DISPLAY || base.alwaysHandleSupSub)) { + nodeType2 = "mover"; + } else if (base && base.type === "operatorname" && base.alwaysHandleSupSub && (base.limits || options2.style === Style$1.DISPLAY)) { + nodeType2 = "mover"; + } else { + nodeType2 = "msup"; + } + } else if (!group.sup) { + var _base = group.base; + if (_base && _base.type === "op" && _base.limits && (options2.style === Style$1.DISPLAY || _base.alwaysHandleSupSub)) { + nodeType2 = "munder"; + } else if (_base && _base.type === "operatorname" && _base.alwaysHandleSupSub && (_base.limits || options2.style === Style$1.DISPLAY)) { + nodeType2 = "munder"; + } else { + nodeType2 = "msub"; + } + } else { + var _base2 = group.base; + if (_base2 && _base2.type === "op" && _base2.limits && options2.style === Style$1.DISPLAY) { + nodeType2 = "munderover"; + } else if (_base2 && _base2.type === "operatorname" && _base2.alwaysHandleSupSub && (options2.style === Style$1.DISPLAY || _base2.limits)) { + nodeType2 = "munderover"; + } else { + nodeType2 = "msubsup"; + } + } + return new mathMLTree.MathNode(nodeType2, children2); + } + }); + defineFunctionBuilders({ + type: "atom", + htmlBuilder(group, options2) { + return buildCommon.mathsym(group.text, group.mode, options2, ["m" + group.family]); + }, + mathmlBuilder(group, options2) { + var node2 = new mathMLTree.MathNode("mo", [makeText(group.text, group.mode)]); + if (group.family === "bin") { + var variant = getVariant(group, options2); + if (variant === "bold-italic") { + node2.setAttribute("mathvariant", variant); + } + } else if (group.family === "punct") { + node2.setAttribute("separator", "true"); + } else if (group.family === "open" || group.family === "close") { + node2.setAttribute("stretchy", "false"); + } + return node2; + } + }); + var defaultVariant = { + "mi": "italic", + "mn": "normal", + "mtext": "normal" + }; + defineFunctionBuilders({ + type: "mathord", + htmlBuilder(group, options2) { + return buildCommon.makeOrd(group, options2, "mathord"); + }, + mathmlBuilder(group, options2) { + var node2 = new mathMLTree.MathNode("mi", [makeText(group.text, group.mode, options2)]); + var variant = getVariant(group, options2) || "italic"; + if (variant !== defaultVariant[node2.type]) { + node2.setAttribute("mathvariant", variant); + } + return node2; + } + }); + defineFunctionBuilders({ + type: "textord", + htmlBuilder(group, options2) { + return buildCommon.makeOrd(group, options2, "textord"); + }, + mathmlBuilder(group, options2) { + var text2 = makeText(group.text, group.mode, options2); + var variant = getVariant(group, options2) || "normal"; + var node2; + if (group.mode === "text") { + node2 = new mathMLTree.MathNode("mtext", [text2]); + } else if (/[0-9]/.test(group.text)) { + node2 = new mathMLTree.MathNode("mn", [text2]); + } else if (group.text === "\\prime") { + node2 = new mathMLTree.MathNode("mo", [text2]); + } else { + node2 = new mathMLTree.MathNode("mi", [text2]); + } + if (variant !== defaultVariant[node2.type]) { + node2.setAttribute("mathvariant", variant); + } + return node2; + } + }); + var cssSpace = { + "\\nobreak": "nobreak", + "\\allowbreak": "allowbreak" + }; + var regularSpace = { + " ": {}, + "\\ ": {}, + "~": { + className: "nobreak" + }, + "\\space": {}, + "\\nobreakspace": { + className: "nobreak" + } + }; + defineFunctionBuilders({ + type: "spacing", + htmlBuilder(group, options2) { + if (regularSpace.hasOwnProperty(group.text)) { + var className = regularSpace[group.text].className || ""; + if (group.mode === "text") { + var ord = buildCommon.makeOrd(group, options2, "textord"); + ord.classes.push(className); + return ord; + } else { + return buildCommon.makeSpan(["mspace", className], [buildCommon.mathsym(group.text, group.mode, options2)], options2); + } + } else if (cssSpace.hasOwnProperty(group.text)) { + return buildCommon.makeSpan(["mspace", cssSpace[group.text]], [], options2); + } else { + throw new ParseError('Unknown type of space "' + group.text + '"'); + } + }, + mathmlBuilder(group, options2) { + var node2; + if (regularSpace.hasOwnProperty(group.text)) { + node2 = new mathMLTree.MathNode("mtext", [new mathMLTree.TextNode(" ")]); + } else if (cssSpace.hasOwnProperty(group.text)) { + return new mathMLTree.MathNode("mspace"); + } else { + throw new ParseError('Unknown type of space "' + group.text + '"'); + } + return node2; + } + }); + var pad = () => { + var padNode = new mathMLTree.MathNode("mtd", []); + padNode.setAttribute("width", "50%"); + return padNode; + }; + defineFunctionBuilders({ + type: "tag", + mathmlBuilder(group, options2) { + var table = new mathMLTree.MathNode("mtable", [new mathMLTree.MathNode("mtr", [pad(), new mathMLTree.MathNode("mtd", [buildExpressionRow(group.body, options2)]), pad(), new mathMLTree.MathNode("mtd", [buildExpressionRow(group.tag, options2)])])]); + table.setAttribute("width", "100%"); + return table; + } + }); + var textFontFamilies = { + "\\text": void 0, + "\\textrm": "textrm", + "\\textsf": "textsf", + "\\texttt": "texttt", + "\\textnormal": "textrm" + }; + var textFontWeights = { + "\\textbf": "textbf", + "\\textmd": "textmd" + }; + var textFontShapes = { + "\\textit": "textit", + "\\textup": "textup" + }; + var optionsWithFont = (group, options2) => { + var font = group.font; + if (!font) { + return options2; + } else if (textFontFamilies[font]) { + return options2.withTextFontFamily(textFontFamilies[font]); + } else if (textFontWeights[font]) { + return options2.withTextFontWeight(textFontWeights[font]); + } else { + return options2.withTextFontShape(textFontShapes[font]); + } + }; + defineFunction({ + type: "text", + names: [ + // Font families + "\\text", + "\\textrm", + "\\textsf", + "\\texttt", + "\\textnormal", + // Font weights + "\\textbf", + "\\textmd", + // Font Shapes + "\\textit", + "\\textup" + ], + props: { + numArgs: 1, + argTypes: ["text"], + allowedInArgument: true, + allowedInText: true + }, + handler(_ref, args) { + var { + parser: parser2, + funcName + } = _ref; + var body = args[0]; + return { + type: "text", + mode: parser2.mode, + body: ordargument(body), + font: funcName + }; + }, + htmlBuilder(group, options2) { + var newOptions = optionsWithFont(group, options2); + var inner2 = buildExpression$1(group.body, newOptions, true); + return buildCommon.makeSpan(["mord", "text"], inner2, newOptions); + }, + mathmlBuilder(group, options2) { + var newOptions = optionsWithFont(group, options2); + return buildExpressionRow(group.body, newOptions); + } + }); + defineFunction({ + type: "underline", + names: ["\\underline"], + props: { + numArgs: 1, + allowedInText: true + }, + handler(_ref, args) { + var { + parser: parser2 + } = _ref; + return { + type: "underline", + mode: parser2.mode, + body: args[0] + }; + }, + htmlBuilder(group, options2) { + var innerGroup = buildGroup$1(group.body, options2); + var line2 = buildCommon.makeLineSpan("underline-line", options2); + var defaultRuleThickness = options2.fontMetrics().defaultRuleThickness; + var vlist = buildCommon.makeVList({ + positionType: "top", + positionData: innerGroup.height, + children: [{ + type: "kern", + size: defaultRuleThickness + }, { + type: "elem", + elem: line2 + }, { + type: "kern", + size: 3 * defaultRuleThickness + }, { + type: "elem", + elem: innerGroup + }] + }, options2); + return buildCommon.makeSpan(["mord", "underline"], [vlist], options2); + }, + mathmlBuilder(group, options2) { + var operator = new mathMLTree.MathNode("mo", [new mathMLTree.TextNode("‾")]); + operator.setAttribute("stretchy", "true"); + var node2 = new mathMLTree.MathNode("munder", [buildGroup(group.body, options2), operator]); + node2.setAttribute("accentunder", "true"); + return node2; + } + }); + defineFunction({ + type: "vcenter", + names: ["\\vcenter"], + props: { + numArgs: 1, + argTypes: ["original"], + // In LaTeX, \vcenter can act only on a box. + allowedInText: false + }, + handler(_ref, args) { + var { + parser: parser2 + } = _ref; + return { + type: "vcenter", + mode: parser2.mode, + body: args[0] + }; + }, + htmlBuilder(group, options2) { + var body = buildGroup$1(group.body, options2); + var axisHeight = options2.fontMetrics().axisHeight; + var dy = 0.5 * (body.height - axisHeight - (body.depth + axisHeight)); + return buildCommon.makeVList({ + positionType: "shift", + positionData: dy, + children: [{ + type: "elem", + elem: body + }] + }, options2); + }, + mathmlBuilder(group, options2) { + return new mathMLTree.MathNode("mpadded", [buildGroup(group.body, options2)], ["vcenter"]); + } + }); + defineFunction({ + type: "verb", + names: ["\\verb"], + props: { + numArgs: 0, + allowedInText: true + }, + handler(context, args, optArgs) { + throw new ParseError("\\verb ended by end of line instead of matching delimiter"); + }, + htmlBuilder(group, options2) { + var text2 = makeVerb(group); + var body = []; + var newOptions = options2.havingStyle(options2.style.text()); + for (var i2 = 0; i2 < text2.length; i2++) { + var c2 = text2[i2]; + if (c2 === "~") { + c2 = "\\textasciitilde"; + } + body.push(buildCommon.makeSymbol(c2, "Typewriter-Regular", group.mode, newOptions, ["mord", "texttt"])); + } + return buildCommon.makeSpan(["mord", "text"].concat(newOptions.sizingClasses(options2)), buildCommon.tryCombineChars(body), newOptions); + }, + mathmlBuilder(group, options2) { + var text2 = new mathMLTree.TextNode(makeVerb(group)); + var node2 = new mathMLTree.MathNode("mtext", [text2]); + node2.setAttribute("mathvariant", "monospace"); + return node2; + } + }); + var makeVerb = (group) => group.body.replace(/ /g, group.star ? "␣" : " "); + var functions$1 = _functions; + var spaceRegexString = "[ \r\n ]"; + var controlWordRegexString = "\\\\[a-zA-Z@]+"; + var controlSymbolRegexString = "\\\\[^\uD800-\uDFFF]"; + var controlWordWhitespaceRegexString = "(" + controlWordRegexString + ")" + spaceRegexString + "*"; + var controlSpaceRegexString = "\\\\(\n|[ \r ]+\n?)[ \r ]*"; + var combiningDiacriticalMarkString = "[̀-ͯ]"; + var combiningDiacriticalMarksEndRegex = new RegExp(combiningDiacriticalMarkString + "+$"); + var tokenRegexString = "(" + spaceRegexString + "+)|" + // whitespace + (controlSpaceRegexString + "|") + // \whitespace + "([!-\\[\\]-‧‪-퟿豈-￿]" + // single codepoint + (combiningDiacriticalMarkString + "*") + // ...plus accents + "|[\uD800-\uDBFF][\uDC00-\uDFFF]" + // surrogate pair + (combiningDiacriticalMarkString + "*") + // ...plus accents + "|\\\\verb\\*([^]).*?\\4|\\\\verb([^*a-zA-Z]).*?\\5" + // \verb unstarred + ("|" + controlWordWhitespaceRegexString) + // \macroName + spaces + ("|" + controlSymbolRegexString + ")"); + class Lexer { + // Category codes. The lexer only supports comment characters (14) for now. + // MacroExpander additionally distinguishes active (13). + constructor(input, settings) { + this.input = void 0; + this.settings = void 0; + this.tokenRegex = void 0; + this.catcodes = void 0; + this.input = input; + this.settings = settings; + this.tokenRegex = new RegExp(tokenRegexString, "g"); + this.catcodes = { + "%": 14, + // comment character + "~": 13 + // active character + }; + } + setCatcode(char2, code) { + this.catcodes[char2] = code; + } + /** + * This function lexes a single token. + */ + lex() { + var input = this.input; + var pos = this.tokenRegex.lastIndex; + if (pos === input.length) { + return new Token("EOF", new SourceLocation(this, pos, pos)); + } + var match = this.tokenRegex.exec(input); + if (match === null || match.index !== pos) { + throw new ParseError("Unexpected character: '" + input[pos] + "'", new Token(input[pos], new SourceLocation(this, pos, pos + 1))); + } + var text2 = match[6] || match[3] || (match[2] ? "\\ " : " "); + if (this.catcodes[text2] === 14) { + var nlIndex = input.indexOf("\n", this.tokenRegex.lastIndex); + if (nlIndex === -1) { + this.tokenRegex.lastIndex = input.length; + this.settings.reportNonstrict("commentAtEnd", "% comment has no terminating newline; LaTeX would fail because of commenting the end of math mode (e.g. $)"); + } else { + this.tokenRegex.lastIndex = nlIndex + 1; + } + return this.lex(); + } + return new Token(text2, new SourceLocation(this, pos, this.tokenRegex.lastIndex)); + } + } + class Namespace { + /** + * Both arguments are optional. The first argument is an object of + * built-in mappings which never change. The second argument is an object + * of initial (global-level) mappings, which will constantly change + * according to any global/top-level `set`s done. + */ + constructor(builtins, globalMacros) { + if (builtins === void 0) { + builtins = {}; + } + if (globalMacros === void 0) { + globalMacros = {}; + } + this.current = void 0; + this.builtins = void 0; + this.undefStack = void 0; + this.current = globalMacros; + this.builtins = builtins; + this.undefStack = []; + } + /** + * Start a new nested group, affecting future local `set`s. + */ + beginGroup() { + this.undefStack.push({}); + } + /** + * End current nested group, restoring values before the group began. + */ + endGroup() { + if (this.undefStack.length === 0) { + throw new ParseError("Unbalanced namespace destruction: attempt to pop global namespace; please report this as a bug"); + } + var undefs = this.undefStack.pop(); + for (var undef in undefs) { + if (undefs.hasOwnProperty(undef)) { + if (undefs[undef] == null) { + delete this.current[undef]; + } else { + this.current[undef] = undefs[undef]; + } + } + } + } + /** + * Ends all currently nested groups (if any), restoring values before the + * groups began. Useful in case of an error in the middle of parsing. + */ + endGroups() { + while (this.undefStack.length > 0) { + this.endGroup(); + } + } + /** + * Detect whether `name` has a definition. Equivalent to + * `get(name) != null`. + */ + has(name) { + return this.current.hasOwnProperty(name) || this.builtins.hasOwnProperty(name); + } + /** + * Get the current value of a name, or `undefined` if there is no value. + * + * Note: Do not use `if (namespace.get(...))` to detect whether a macro + * is defined, as the definition may be the empty string which evaluates + * to `false` in JavaScript. Use `if (namespace.get(...) != null)` or + * `if (namespace.has(...))`. + */ + get(name) { + if (this.current.hasOwnProperty(name)) { + return this.current[name]; + } else { + return this.builtins[name]; + } + } + /** + * Set the current value of a name, and optionally set it globally too. + * Local set() sets the current value and (when appropriate) adds an undo + * operation to the undo stack. Global set() may change the undo + * operation at every level, so takes time linear in their number. + * A value of undefined means to delete existing definitions. + */ + set(name, value2, global2) { + if (global2 === void 0) { + global2 = false; + } + if (global2) { + for (var i2 = 0; i2 < this.undefStack.length; i2++) { + delete this.undefStack[i2][name]; + } + if (this.undefStack.length > 0) { + this.undefStack[this.undefStack.length - 1][name] = value2; + } + } else { + var top2 = this.undefStack[this.undefStack.length - 1]; + if (top2 && !top2.hasOwnProperty(name)) { + top2[name] = this.current[name]; + } + } + if (value2 == null) { + delete this.current[name]; + } else { + this.current[name] = value2; + } + } + } + var macros = _macros; + defineMacro("\\noexpand", function(context) { + var t = context.popToken(); + if (context.isExpandable(t.text)) { + t.noexpand = true; + t.treatAsRelax = true; + } + return { + tokens: [t], + numArgs: 0 + }; + }); + defineMacro("\\expandafter", function(context) { + var t = context.popToken(); + context.expandOnce(true); + return { + tokens: [t], + numArgs: 0 + }; + }); + defineMacro("\\@firstoftwo", function(context) { + var args = context.consumeArgs(2); + return { + tokens: args[0], + numArgs: 0 + }; + }); + defineMacro("\\@secondoftwo", function(context) { + var args = context.consumeArgs(2); + return { + tokens: args[1], + numArgs: 0 + }; + }); + defineMacro("\\@ifnextchar", function(context) { + var args = context.consumeArgs(3); + context.consumeSpaces(); + var nextToken = context.future(); + if (args[0].length === 1 && args[0][0].text === nextToken.text) { + return { + tokens: args[1], + numArgs: 0 + }; + } else { + return { + tokens: args[2], + numArgs: 0 + }; + } + }); + defineMacro("\\@ifstar", "\\@ifnextchar *{\\@firstoftwo{#1}}"); + defineMacro("\\TextOrMath", function(context) { + var args = context.consumeArgs(2); + if (context.mode === "text") { + return { + tokens: args[0], + numArgs: 0 + }; + } else { + return { + tokens: args[1], + numArgs: 0 + }; + } + }); + var digitToNumber = { + "0": 0, + "1": 1, + "2": 2, + "3": 3, + "4": 4, + "5": 5, + "6": 6, + "7": 7, + "8": 8, + "9": 9, + "a": 10, + "A": 10, + "b": 11, + "B": 11, + "c": 12, + "C": 12, + "d": 13, + "D": 13, + "e": 14, + "E": 14, + "f": 15, + "F": 15 + }; + defineMacro("\\char", function(context) { + var token2 = context.popToken(); + var base; + var number2 = ""; + if (token2.text === "'") { + base = 8; + token2 = context.popToken(); + } else if (token2.text === '"') { + base = 16; + token2 = context.popToken(); + } else if (token2.text === "`") { + token2 = context.popToken(); + if (token2.text[0] === "\\") { + number2 = token2.text.charCodeAt(1); + } else if (token2.text === "EOF") { + throw new ParseError("\\char` missing argument"); + } else { + number2 = token2.text.charCodeAt(0); + } + } else { + base = 10; + } + if (base) { + number2 = digitToNumber[token2.text]; + if (number2 == null || number2 >= base) { + throw new ParseError("Invalid base-" + base + " digit " + token2.text); + } + var digit; + while ((digit = digitToNumber[context.future().text]) != null && digit < base) { + number2 *= base; + number2 += digit; + context.popToken(); + } + } + return "\\@char{" + number2 + "}"; + }); + var newcommand = (context, existsOK, nonexistsOK) => { + var arg = context.consumeArg().tokens; + if (arg.length !== 1) { + throw new ParseError("\\newcommand's first argument must be a macro name"); + } + var name = arg[0].text; + var exists2 = context.isDefined(name); + if (exists2 && !existsOK) { + throw new ParseError("\\newcommand{" + name + "} attempting to redefine " + (name + "; use \\renewcommand")); + } + if (!exists2 && !nonexistsOK) { + throw new ParseError("\\renewcommand{" + name + "} when command " + name + " does not yet exist; use \\newcommand"); + } + var numArgs = 0; + arg = context.consumeArg().tokens; + if (arg.length === 1 && arg[0].text === "[") { + var argText = ""; + var token2 = context.expandNextToken(); + while (token2.text !== "]" && token2.text !== "EOF") { + argText += token2.text; + token2 = context.expandNextToken(); + } + if (!argText.match(/^\s*[0-9]+\s*$/)) { + throw new ParseError("Invalid number of arguments: " + argText); + } + numArgs = parseInt(argText); + arg = context.consumeArg().tokens; + } + context.macros.set(name, { + tokens: arg, + numArgs + }); + return ""; + }; + defineMacro("\\newcommand", (context) => newcommand(context, false, true)); + defineMacro("\\renewcommand", (context) => newcommand(context, true, false)); + defineMacro("\\providecommand", (context) => newcommand(context, true, true)); + defineMacro("\\message", (context) => { + var arg = context.consumeArgs(1)[0]; + console.log(arg.reverse().map((token2) => token2.text).join("")); + return ""; + }); + defineMacro("\\errmessage", (context) => { + var arg = context.consumeArgs(1)[0]; + console.error(arg.reverse().map((token2) => token2.text).join("")); + return ""; + }); + defineMacro("\\show", (context) => { + var tok = context.popToken(); + var name = tok.text; + console.log(tok, context.macros.get(name), functions$1[name], symbols.math[name], symbols.text[name]); + return ""; + }); + defineMacro("\\bgroup", "{"); + defineMacro("\\egroup", "}"); + defineMacro("~", "\\nobreakspace"); + defineMacro("\\lq", "`"); + defineMacro("\\rq", "'"); + defineMacro("\\aa", "\\r a"); + defineMacro("\\AA", "\\r A"); + defineMacro("\\textcopyright", "\\html@mathml{\\textcircled{c}}{\\char`©}"); + defineMacro("\\copyright", "\\TextOrMath{\\textcopyright}{\\text{\\textcopyright}}"); + defineMacro("\\textregistered", "\\html@mathml{\\textcircled{\\scriptsize R}}{\\char`®}"); + defineMacro("ℬ", "\\mathscr{B}"); + defineMacro("ℰ", "\\mathscr{E}"); + defineMacro("ℱ", "\\mathscr{F}"); + defineMacro("ℋ", "\\mathscr{H}"); + defineMacro("ℐ", "\\mathscr{I}"); + defineMacro("ℒ", "\\mathscr{L}"); + defineMacro("ℳ", "\\mathscr{M}"); + defineMacro("ℛ", "\\mathscr{R}"); + defineMacro("ℭ", "\\mathfrak{C}"); + defineMacro("ℌ", "\\mathfrak{H}"); + defineMacro("ℨ", "\\mathfrak{Z}"); + defineMacro("\\Bbbk", "\\Bbb{k}"); + defineMacro("·", "\\cdotp"); + defineMacro("\\llap", "\\mathllap{\\textrm{#1}}"); + defineMacro("\\rlap", "\\mathrlap{\\textrm{#1}}"); + defineMacro("\\clap", "\\mathclap{\\textrm{#1}}"); + defineMacro("\\mathstrut", "\\vphantom{(}"); + defineMacro("\\underbar", "\\underline{\\text{#1}}"); + defineMacro("\\not", '\\html@mathml{\\mathrel{\\mathrlap\\@not}}{\\char"338}'); + defineMacro("\\neq", "\\html@mathml{\\mathrel{\\not=}}{\\mathrel{\\char`≠}}"); + defineMacro("\\ne", "\\neq"); + defineMacro("≠", "\\neq"); + defineMacro("\\notin", "\\html@mathml{\\mathrel{{\\in}\\mathllap{/\\mskip1mu}}}{\\mathrel{\\char`∉}}"); + defineMacro("∉", "\\notin"); + defineMacro("≘", "\\html@mathml{\\mathrel{=\\kern{-1em}\\raisebox{0.4em}{$\\scriptsize\\frown$}}}{\\mathrel{\\char`≘}}"); + defineMacro("≙", "\\html@mathml{\\stackrel{\\tiny\\wedge}{=}}{\\mathrel{\\char`≘}}"); + defineMacro("≚", "\\html@mathml{\\stackrel{\\tiny\\vee}{=}}{\\mathrel{\\char`≚}}"); + defineMacro("≛", "\\html@mathml{\\stackrel{\\scriptsize\\star}{=}}{\\mathrel{\\char`≛}}"); + defineMacro("≝", "\\html@mathml{\\stackrel{\\tiny\\mathrm{def}}{=}}{\\mathrel{\\char`≝}}"); + defineMacro("≞", "\\html@mathml{\\stackrel{\\tiny\\mathrm{m}}{=}}{\\mathrel{\\char`≞}}"); + defineMacro("≟", "\\html@mathml{\\stackrel{\\tiny?}{=}}{\\mathrel{\\char`≟}}"); + defineMacro("⟂", "\\perp"); + defineMacro("‼", "\\mathclose{!\\mkern-0.8mu!}"); + defineMacro("∌", "\\notni"); + defineMacro("⌜", "\\ulcorner"); + defineMacro("⌝", "\\urcorner"); + defineMacro("⌞", "\\llcorner"); + defineMacro("⌟", "\\lrcorner"); + defineMacro("©", "\\copyright"); + defineMacro("®", "\\textregistered"); + defineMacro("️", "\\textregistered"); + defineMacro("\\ulcorner", '\\html@mathml{\\@ulcorner}{\\mathop{\\char"231c}}'); + defineMacro("\\urcorner", '\\html@mathml{\\@urcorner}{\\mathop{\\char"231d}}'); + defineMacro("\\llcorner", '\\html@mathml{\\@llcorner}{\\mathop{\\char"231e}}'); + defineMacro("\\lrcorner", '\\html@mathml{\\@lrcorner}{\\mathop{\\char"231f}}'); + defineMacro("\\vdots", "\\mathord{\\varvdots\\rule{0pt}{15pt}}"); + defineMacro("⋮", "\\vdots"); + defineMacro("\\varGamma", "\\mathit{\\Gamma}"); + defineMacro("\\varDelta", "\\mathit{\\Delta}"); + defineMacro("\\varTheta", "\\mathit{\\Theta}"); + defineMacro("\\varLambda", "\\mathit{\\Lambda}"); + defineMacro("\\varXi", "\\mathit{\\Xi}"); + defineMacro("\\varPi", "\\mathit{\\Pi}"); + defineMacro("\\varSigma", "\\mathit{\\Sigma}"); + defineMacro("\\varUpsilon", "\\mathit{\\Upsilon}"); + defineMacro("\\varPhi", "\\mathit{\\Phi}"); + defineMacro("\\varPsi", "\\mathit{\\Psi}"); + defineMacro("\\varOmega", "\\mathit{\\Omega}"); + defineMacro("\\substack", "\\begin{subarray}{c}#1\\end{subarray}"); + defineMacro("\\colon", "\\nobreak\\mskip2mu\\mathpunct{}\\mathchoice{\\mkern-3mu}{\\mkern-3mu}{}{}{:}\\mskip6mu\\relax"); + defineMacro("\\boxed", "\\fbox{$\\displaystyle{#1}$}"); + defineMacro("\\iff", "\\DOTSB\\;\\Longleftrightarrow\\;"); + defineMacro("\\implies", "\\DOTSB\\;\\Longrightarrow\\;"); + defineMacro("\\impliedby", "\\DOTSB\\;\\Longleftarrow\\;"); + var dotsByToken = { + ",": "\\dotsc", + "\\not": "\\dotsb", + // \keybin@ checks for the following: + "+": "\\dotsb", + "=": "\\dotsb", + "<": "\\dotsb", + ">": "\\dotsb", + "-": "\\dotsb", + "*": "\\dotsb", + ":": "\\dotsb", + // Symbols whose definition starts with \DOTSB: + "\\DOTSB": "\\dotsb", + "\\coprod": "\\dotsb", + "\\bigvee": "\\dotsb", + "\\bigwedge": "\\dotsb", + "\\biguplus": "\\dotsb", + "\\bigcap": "\\dotsb", + "\\bigcup": "\\dotsb", + "\\prod": "\\dotsb", + "\\sum": "\\dotsb", + "\\bigotimes": "\\dotsb", + "\\bigoplus": "\\dotsb", + "\\bigodot": "\\dotsb", + "\\bigsqcup": "\\dotsb", + "\\And": "\\dotsb", + "\\longrightarrow": "\\dotsb", + "\\Longrightarrow": "\\dotsb", + "\\longleftarrow": "\\dotsb", + "\\Longleftarrow": "\\dotsb", + "\\longleftrightarrow": "\\dotsb", + "\\Longleftrightarrow": "\\dotsb", + "\\mapsto": "\\dotsb", + "\\longmapsto": "\\dotsb", + "\\hookrightarrow": "\\dotsb", + "\\doteq": "\\dotsb", + // Symbols whose definition starts with \mathbin: + "\\mathbin": "\\dotsb", + // Symbols whose definition starts with \mathrel: + "\\mathrel": "\\dotsb", + "\\relbar": "\\dotsb", + "\\Relbar": "\\dotsb", + "\\xrightarrow": "\\dotsb", + "\\xleftarrow": "\\dotsb", + // Symbols whose definition starts with \DOTSI: + "\\DOTSI": "\\dotsi", + "\\int": "\\dotsi", + "\\oint": "\\dotsi", + "\\iint": "\\dotsi", + "\\iiint": "\\dotsi", + "\\iiiint": "\\dotsi", + "\\idotsint": "\\dotsi", + // Symbols whose definition starts with \DOTSX: + "\\DOTSX": "\\dotsx" + }; + defineMacro("\\dots", function(context) { + var thedots = "\\dotso"; + var next2 = context.expandAfterFuture().text; + if (next2 in dotsByToken) { + thedots = dotsByToken[next2]; + } else if (next2.slice(0, 4) === "\\not") { + thedots = "\\dotsb"; + } else if (next2 in symbols.math) { + if (utils.contains(["bin", "rel"], symbols.math[next2].group)) { + thedots = "\\dotsb"; + } + } + return thedots; + }); + var spaceAfterDots = { + // \rightdelim@ checks for the following: + ")": true, + "]": true, + "\\rbrack": true, + "\\}": true, + "\\rbrace": true, + "\\rangle": true, + "\\rceil": true, + "\\rfloor": true, + "\\rgroup": true, + "\\rmoustache": true, + "\\right": true, + "\\bigr": true, + "\\biggr": true, + "\\Bigr": true, + "\\Biggr": true, + // \extra@ also tests for the following: + "$": true, + // \extrap@ checks for the following: + ";": true, + ".": true, + ",": true + }; + defineMacro("\\dotso", function(context) { + var next2 = context.future().text; + if (next2 in spaceAfterDots) { + return "\\ldots\\,"; + } else { + return "\\ldots"; + } + }); + defineMacro("\\dotsc", function(context) { + var next2 = context.future().text; + if (next2 in spaceAfterDots && next2 !== ",") { + return "\\ldots\\,"; + } else { + return "\\ldots"; + } + }); + defineMacro("\\cdots", function(context) { + var next2 = context.future().text; + if (next2 in spaceAfterDots) { + return "\\@cdots\\,"; + } else { + return "\\@cdots"; + } + }); + defineMacro("\\dotsb", "\\cdots"); + defineMacro("\\dotsm", "\\cdots"); + defineMacro("\\dotsi", "\\!\\cdots"); + defineMacro("\\dotsx", "\\ldots\\,"); + defineMacro("\\DOTSI", "\\relax"); + defineMacro("\\DOTSB", "\\relax"); + defineMacro("\\DOTSX", "\\relax"); + defineMacro("\\tmspace", "\\TextOrMath{\\kern#1#3}{\\mskip#1#2}\\relax"); + defineMacro("\\,", "\\tmspace+{3mu}{.1667em}"); + defineMacro("\\thinspace", "\\,"); + defineMacro("\\>", "\\mskip{4mu}"); + defineMacro("\\:", "\\tmspace+{4mu}{.2222em}"); + defineMacro("\\medspace", "\\:"); + defineMacro("\\;", "\\tmspace+{5mu}{.2777em}"); + defineMacro("\\thickspace", "\\;"); + defineMacro("\\!", "\\tmspace-{3mu}{.1667em}"); + defineMacro("\\negthinspace", "\\!"); + defineMacro("\\negmedspace", "\\tmspace-{4mu}{.2222em}"); + defineMacro("\\negthickspace", "\\tmspace-{5mu}{.277em}"); + defineMacro("\\enspace", "\\kern.5em "); + defineMacro("\\enskip", "\\hskip.5em\\relax"); + defineMacro("\\quad", "\\hskip1em\\relax"); + defineMacro("\\qquad", "\\hskip2em\\relax"); + defineMacro("\\tag", "\\@ifstar\\tag@literal\\tag@paren"); + defineMacro("\\tag@paren", "\\tag@literal{({#1})}"); + defineMacro("\\tag@literal", (context) => { + if (context.macros.get("\\df@tag")) { + throw new ParseError("Multiple \\tag"); + } + return "\\gdef\\df@tag{\\text{#1}}"; + }); + defineMacro("\\bmod", "\\mathchoice{\\mskip1mu}{\\mskip1mu}{\\mskip5mu}{\\mskip5mu}\\mathbin{\\rm mod}\\mathchoice{\\mskip1mu}{\\mskip1mu}{\\mskip5mu}{\\mskip5mu}"); + defineMacro("\\pod", "\\allowbreak\\mathchoice{\\mkern18mu}{\\mkern8mu}{\\mkern8mu}{\\mkern8mu}(#1)"); + defineMacro("\\pmod", "\\pod{{\\rm mod}\\mkern6mu#1}"); + defineMacro("\\mod", "\\allowbreak\\mathchoice{\\mkern18mu}{\\mkern12mu}{\\mkern12mu}{\\mkern12mu}{\\rm mod}\\,\\,#1"); + defineMacro("\\newline", "\\\\\\relax"); + defineMacro("\\TeX", "\\textrm{\\html@mathml{T\\kern-.1667em\\raisebox{-.5ex}{E}\\kern-.125emX}{TeX}}"); + var latexRaiseA = makeEm(fontMetricsData["Main-Regular"]["T".charCodeAt(0)][1] - 0.7 * fontMetricsData["Main-Regular"]["A".charCodeAt(0)][1]); + defineMacro("\\LaTeX", "\\textrm{\\html@mathml{" + ("L\\kern-.36em\\raisebox{" + latexRaiseA + "}{\\scriptstyle A}") + "\\kern-.15em\\TeX}{LaTeX}}"); + defineMacro("\\KaTeX", "\\textrm{\\html@mathml{" + ("K\\kern-.17em\\raisebox{" + latexRaiseA + "}{\\scriptstyle A}") + "\\kern-.15em\\TeX}{KaTeX}}"); + defineMacro("\\hspace", "\\@ifstar\\@hspacer\\@hspace"); + defineMacro("\\@hspace", "\\hskip #1\\relax"); + defineMacro("\\@hspacer", "\\rule{0pt}{0pt}\\hskip #1\\relax"); + defineMacro("\\ordinarycolon", ":"); + defineMacro("\\vcentcolon", "\\mathrel{\\mathop\\ordinarycolon}"); + defineMacro("\\dblcolon", '\\html@mathml{\\mathrel{\\vcentcolon\\mathrel{\\mkern-.9mu}\\vcentcolon}}{\\mathop{\\char"2237}}'); + defineMacro("\\coloneqq", '\\html@mathml{\\mathrel{\\vcentcolon\\mathrel{\\mkern-1.2mu}=}}{\\mathop{\\char"2254}}'); + defineMacro("\\Coloneqq", '\\html@mathml{\\mathrel{\\dblcolon\\mathrel{\\mkern-1.2mu}=}}{\\mathop{\\char"2237\\char"3d}}'); + defineMacro("\\coloneq", '\\html@mathml{\\mathrel{\\vcentcolon\\mathrel{\\mkern-1.2mu}\\mathrel{-}}}{\\mathop{\\char"3a\\char"2212}}'); + defineMacro("\\Coloneq", '\\html@mathml{\\mathrel{\\dblcolon\\mathrel{\\mkern-1.2mu}\\mathrel{-}}}{\\mathop{\\char"2237\\char"2212}}'); + defineMacro("\\eqqcolon", '\\html@mathml{\\mathrel{=\\mathrel{\\mkern-1.2mu}\\vcentcolon}}{\\mathop{\\char"2255}}'); + defineMacro("\\Eqqcolon", '\\html@mathml{\\mathrel{=\\mathrel{\\mkern-1.2mu}\\dblcolon}}{\\mathop{\\char"3d\\char"2237}}'); + defineMacro("\\eqcolon", '\\html@mathml{\\mathrel{\\mathrel{-}\\mathrel{\\mkern-1.2mu}\\vcentcolon}}{\\mathop{\\char"2239}}'); + defineMacro("\\Eqcolon", '\\html@mathml{\\mathrel{\\mathrel{-}\\mathrel{\\mkern-1.2mu}\\dblcolon}}{\\mathop{\\char"2212\\char"2237}}'); + defineMacro("\\colonapprox", '\\html@mathml{\\mathrel{\\vcentcolon\\mathrel{\\mkern-1.2mu}\\approx}}{\\mathop{\\char"3a\\char"2248}}'); + defineMacro("\\Colonapprox", '\\html@mathml{\\mathrel{\\dblcolon\\mathrel{\\mkern-1.2mu}\\approx}}{\\mathop{\\char"2237\\char"2248}}'); + defineMacro("\\colonsim", '\\html@mathml{\\mathrel{\\vcentcolon\\mathrel{\\mkern-1.2mu}\\sim}}{\\mathop{\\char"3a\\char"223c}}'); + defineMacro("\\Colonsim", '\\html@mathml{\\mathrel{\\dblcolon\\mathrel{\\mkern-1.2mu}\\sim}}{\\mathop{\\char"2237\\char"223c}}'); + defineMacro("∷", "\\dblcolon"); + defineMacro("∹", "\\eqcolon"); + defineMacro("≔", "\\coloneqq"); + defineMacro("≕", "\\eqqcolon"); + defineMacro("⩴", "\\Coloneqq"); + defineMacro("\\ratio", "\\vcentcolon"); + defineMacro("\\coloncolon", "\\dblcolon"); + defineMacro("\\colonequals", "\\coloneqq"); + defineMacro("\\coloncolonequals", "\\Coloneqq"); + defineMacro("\\equalscolon", "\\eqqcolon"); + defineMacro("\\equalscoloncolon", "\\Eqqcolon"); + defineMacro("\\colonminus", "\\coloneq"); + defineMacro("\\coloncolonminus", "\\Coloneq"); + defineMacro("\\minuscolon", "\\eqcolon"); + defineMacro("\\minuscoloncolon", "\\Eqcolon"); + defineMacro("\\coloncolonapprox", "\\Colonapprox"); + defineMacro("\\coloncolonsim", "\\Colonsim"); + defineMacro("\\simcolon", "\\mathrel{\\sim\\mathrel{\\mkern-1.2mu}\\vcentcolon}"); + defineMacro("\\simcoloncolon", "\\mathrel{\\sim\\mathrel{\\mkern-1.2mu}\\dblcolon}"); + defineMacro("\\approxcolon", "\\mathrel{\\approx\\mathrel{\\mkern-1.2mu}\\vcentcolon}"); + defineMacro("\\approxcoloncolon", "\\mathrel{\\approx\\mathrel{\\mkern-1.2mu}\\dblcolon}"); + defineMacro("\\notni", "\\html@mathml{\\not\\ni}{\\mathrel{\\char`∌}}"); + defineMacro("\\limsup", "\\DOTSB\\operatorname*{lim\\,sup}"); + defineMacro("\\liminf", "\\DOTSB\\operatorname*{lim\\,inf}"); + defineMacro("\\injlim", "\\DOTSB\\operatorname*{inj\\,lim}"); + defineMacro("\\projlim", "\\DOTSB\\operatorname*{proj\\,lim}"); + defineMacro("\\varlimsup", "\\DOTSB\\operatorname*{\\overline{lim}}"); + defineMacro("\\varliminf", "\\DOTSB\\operatorname*{\\underline{lim}}"); + defineMacro("\\varinjlim", "\\DOTSB\\operatorname*{\\underrightarrow{lim}}"); + defineMacro("\\varprojlim", "\\DOTSB\\operatorname*{\\underleftarrow{lim}}"); + defineMacro("\\gvertneqq", "\\html@mathml{\\@gvertneqq}{≩}"); + defineMacro("\\lvertneqq", "\\html@mathml{\\@lvertneqq}{≨}"); + defineMacro("\\ngeqq", "\\html@mathml{\\@ngeqq}{≱}"); + defineMacro("\\ngeqslant", "\\html@mathml{\\@ngeqslant}{≱}"); + defineMacro("\\nleqq", "\\html@mathml{\\@nleqq}{≰}"); + defineMacro("\\nleqslant", "\\html@mathml{\\@nleqslant}{≰}"); + defineMacro("\\nshortmid", "\\html@mathml{\\@nshortmid}{∤}"); + defineMacro("\\nshortparallel", "\\html@mathml{\\@nshortparallel}{∦}"); + defineMacro("\\nsubseteqq", "\\html@mathml{\\@nsubseteqq}{⊈}"); + defineMacro("\\nsupseteqq", "\\html@mathml{\\@nsupseteqq}{⊉}"); + defineMacro("\\varsubsetneq", "\\html@mathml{\\@varsubsetneq}{⊊}"); + defineMacro("\\varsubsetneqq", "\\html@mathml{\\@varsubsetneqq}{⫋}"); + defineMacro("\\varsupsetneq", "\\html@mathml{\\@varsupsetneq}{⊋}"); + defineMacro("\\varsupsetneqq", "\\html@mathml{\\@varsupsetneqq}{⫌}"); + defineMacro("\\imath", "\\html@mathml{\\@imath}{ı}"); + defineMacro("\\jmath", "\\html@mathml{\\@jmath}{ȷ}"); + defineMacro("\\llbracket", "\\html@mathml{\\mathopen{[\\mkern-3.2mu[}}{\\mathopen{\\char`⟦}}"); + defineMacro("\\rrbracket", "\\html@mathml{\\mathclose{]\\mkern-3.2mu]}}{\\mathclose{\\char`⟧}}"); + defineMacro("⟦", "\\llbracket"); + defineMacro("⟧", "\\rrbracket"); + defineMacro("\\lBrace", "\\html@mathml{\\mathopen{\\{\\mkern-3.2mu[}}{\\mathopen{\\char`⦃}}"); + defineMacro("\\rBrace", "\\html@mathml{\\mathclose{]\\mkern-3.2mu\\}}}{\\mathclose{\\char`⦄}}"); + defineMacro("⦃", "\\lBrace"); + defineMacro("⦄", "\\rBrace"); + defineMacro("\\minuso", "\\mathbin{\\html@mathml{{\\mathrlap{\\mathchoice{\\kern{0.145em}}{\\kern{0.145em}}{\\kern{0.1015em}}{\\kern{0.0725em}}\\circ}{-}}}{\\char`⦵}}"); + defineMacro("⦵", "\\minuso"); + defineMacro("\\darr", "\\downarrow"); + defineMacro("\\dArr", "\\Downarrow"); + defineMacro("\\Darr", "\\Downarrow"); + defineMacro("\\lang", "\\langle"); + defineMacro("\\rang", "\\rangle"); + defineMacro("\\uarr", "\\uparrow"); + defineMacro("\\uArr", "\\Uparrow"); + defineMacro("\\Uarr", "\\Uparrow"); + defineMacro("\\N", "\\mathbb{N}"); + defineMacro("\\R", "\\mathbb{R}"); + defineMacro("\\Z", "\\mathbb{Z}"); + defineMacro("\\alef", "\\aleph"); + defineMacro("\\alefsym", "\\aleph"); + defineMacro("\\Alpha", "\\mathrm{A}"); + defineMacro("\\Beta", "\\mathrm{B}"); + defineMacro("\\bull", "\\bullet"); + defineMacro("\\Chi", "\\mathrm{X}"); + defineMacro("\\clubs", "\\clubsuit"); + defineMacro("\\cnums", "\\mathbb{C}"); + defineMacro("\\Complex", "\\mathbb{C}"); + defineMacro("\\Dagger", "\\ddagger"); + defineMacro("\\diamonds", "\\diamondsuit"); + defineMacro("\\empty", "\\emptyset"); + defineMacro("\\Epsilon", "\\mathrm{E}"); + defineMacro("\\Eta", "\\mathrm{H}"); + defineMacro("\\exist", "\\exists"); + defineMacro("\\harr", "\\leftrightarrow"); + defineMacro("\\hArr", "\\Leftrightarrow"); + defineMacro("\\Harr", "\\Leftrightarrow"); + defineMacro("\\hearts", "\\heartsuit"); + defineMacro("\\image", "\\Im"); + defineMacro("\\infin", "\\infty"); + defineMacro("\\Iota", "\\mathrm{I}"); + defineMacro("\\isin", "\\in"); + defineMacro("\\Kappa", "\\mathrm{K}"); + defineMacro("\\larr", "\\leftarrow"); + defineMacro("\\lArr", "\\Leftarrow"); + defineMacro("\\Larr", "\\Leftarrow"); + defineMacro("\\lrarr", "\\leftrightarrow"); + defineMacro("\\lrArr", "\\Leftrightarrow"); + defineMacro("\\Lrarr", "\\Leftrightarrow"); + defineMacro("\\Mu", "\\mathrm{M}"); + defineMacro("\\natnums", "\\mathbb{N}"); + defineMacro("\\Nu", "\\mathrm{N}"); + defineMacro("\\Omicron", "\\mathrm{O}"); + defineMacro("\\plusmn", "\\pm"); + defineMacro("\\rarr", "\\rightarrow"); + defineMacro("\\rArr", "\\Rightarrow"); + defineMacro("\\Rarr", "\\Rightarrow"); + defineMacro("\\real", "\\Re"); + defineMacro("\\reals", "\\mathbb{R}"); + defineMacro("\\Reals", "\\mathbb{R}"); + defineMacro("\\Rho", "\\mathrm{P}"); + defineMacro("\\sdot", "\\cdot"); + defineMacro("\\sect", "\\S"); + defineMacro("\\spades", "\\spadesuit"); + defineMacro("\\sub", "\\subset"); + defineMacro("\\sube", "\\subseteq"); + defineMacro("\\supe", "\\supseteq"); + defineMacro("\\Tau", "\\mathrm{T}"); + defineMacro("\\thetasym", "\\vartheta"); + defineMacro("\\weierp", "\\wp"); + defineMacro("\\Zeta", "\\mathrm{Z}"); + defineMacro("\\argmin", "\\DOTSB\\operatorname*{arg\\,min}"); + defineMacro("\\argmax", "\\DOTSB\\operatorname*{arg\\,max}"); + defineMacro("\\plim", "\\DOTSB\\mathop{\\operatorname{plim}}\\limits"); + defineMacro("\\bra", "\\mathinner{\\langle{#1}|}"); + defineMacro("\\ket", "\\mathinner{|{#1}\\rangle}"); + defineMacro("\\braket", "\\mathinner{\\langle{#1}\\rangle}"); + defineMacro("\\Bra", "\\left\\langle#1\\right|"); + defineMacro("\\Ket", "\\left|#1\\right\\rangle"); + var braketHelper = (one2) => (context) => { + var left2 = context.consumeArg().tokens; + var middle = context.consumeArg().tokens; + var middleDouble = context.consumeArg().tokens; + var right2 = context.consumeArg().tokens; + var oldMiddle = context.macros.get("|"); + var oldMiddleDouble = context.macros.get("\\|"); + context.macros.beginGroup(); + var midMacro = (double) => (context2) => { + if (one2) { + context2.macros.set("|", oldMiddle); + if (middleDouble.length) { + context2.macros.set("\\|", oldMiddleDouble); + } + } + var doubled = double; + if (!double && middleDouble.length) { + var nextToken = context2.future(); + if (nextToken.text === "|") { + context2.popToken(); + doubled = true; + } + } + return { + tokens: doubled ? middleDouble : middle, + numArgs: 0 + }; + }; + context.macros.set("|", midMacro(false)); + if (middleDouble.length) { + context.macros.set("\\|", midMacro(true)); + } + var arg = context.consumeArg().tokens; + var expanded = context.expandTokens([ + ...right2, + ...arg, + ...left2 + // reversed + ]); + context.macros.endGroup(); + return { + tokens: expanded.reverse(), + numArgs: 0 + }; + }; + defineMacro("\\bra@ket", braketHelper(false)); + defineMacro("\\bra@set", braketHelper(true)); + defineMacro("\\Braket", "\\bra@ket{\\left\\langle}{\\,\\middle\\vert\\,}{\\,\\middle\\vert\\,}{\\right\\rangle}"); + defineMacro("\\Set", "\\bra@set{\\left\\{\\:}{\\;\\middle\\vert\\;}{\\;\\middle\\Vert\\;}{\\:\\right\\}}"); + defineMacro("\\set", "\\bra@set{\\{\\,}{\\mid}{}{\\,\\}}"); + defineMacro("\\angln", "{\\angl n}"); + defineMacro("\\blue", "\\textcolor{##6495ed}{#1}"); + defineMacro("\\orange", "\\textcolor{##ffa500}{#1}"); + defineMacro("\\pink", "\\textcolor{##ff00af}{#1}"); + defineMacro("\\red", "\\textcolor{##df0030}{#1}"); + defineMacro("\\green", "\\textcolor{##28ae7b}{#1}"); + defineMacro("\\gray", "\\textcolor{gray}{#1}"); + defineMacro("\\purple", "\\textcolor{##9d38bd}{#1}"); + defineMacro("\\blueA", "\\textcolor{##ccfaff}{#1}"); + defineMacro("\\blueB", "\\textcolor{##80f6ff}{#1}"); + defineMacro("\\blueC", "\\textcolor{##63d9ea}{#1}"); + defineMacro("\\blueD", "\\textcolor{##11accd}{#1}"); + defineMacro("\\blueE", "\\textcolor{##0c7f99}{#1}"); + defineMacro("\\tealA", "\\textcolor{##94fff5}{#1}"); + defineMacro("\\tealB", "\\textcolor{##26edd5}{#1}"); + defineMacro("\\tealC", "\\textcolor{##01d1c1}{#1}"); + defineMacro("\\tealD", "\\textcolor{##01a995}{#1}"); + defineMacro("\\tealE", "\\textcolor{##208170}{#1}"); + defineMacro("\\greenA", "\\textcolor{##b6ffb0}{#1}"); + defineMacro("\\greenB", "\\textcolor{##8af281}{#1}"); + defineMacro("\\greenC", "\\textcolor{##74cf70}{#1}"); + defineMacro("\\greenD", "\\textcolor{##1fab54}{#1}"); + defineMacro("\\greenE", "\\textcolor{##0d923f}{#1}"); + defineMacro("\\goldA", "\\textcolor{##ffd0a9}{#1}"); + defineMacro("\\goldB", "\\textcolor{##ffbb71}{#1}"); + defineMacro("\\goldC", "\\textcolor{##ff9c39}{#1}"); + defineMacro("\\goldD", "\\textcolor{##e07d10}{#1}"); + defineMacro("\\goldE", "\\textcolor{##a75a05}{#1}"); + defineMacro("\\redA", "\\textcolor{##fca9a9}{#1}"); + defineMacro("\\redB", "\\textcolor{##ff8482}{#1}"); + defineMacro("\\redC", "\\textcolor{##f9685d}{#1}"); + defineMacro("\\redD", "\\textcolor{##e84d39}{#1}"); + defineMacro("\\redE", "\\textcolor{##bc2612}{#1}"); + defineMacro("\\maroonA", "\\textcolor{##ffbde0}{#1}"); + defineMacro("\\maroonB", "\\textcolor{##ff92c6}{#1}"); + defineMacro("\\maroonC", "\\textcolor{##ed5fa6}{#1}"); + defineMacro("\\maroonD", "\\textcolor{##ca337c}{#1}"); + defineMacro("\\maroonE", "\\textcolor{##9e034e}{#1}"); + defineMacro("\\purpleA", "\\textcolor{##ddd7ff}{#1}"); + defineMacro("\\purpleB", "\\textcolor{##c6b9fc}{#1}"); + defineMacro("\\purpleC", "\\textcolor{##aa87ff}{#1}"); + defineMacro("\\purpleD", "\\textcolor{##7854ab}{#1}"); + defineMacro("\\purpleE", "\\textcolor{##543b78}{#1}"); + defineMacro("\\mintA", "\\textcolor{##f5f9e8}{#1}"); + defineMacro("\\mintB", "\\textcolor{##edf2df}{#1}"); + defineMacro("\\mintC", "\\textcolor{##e0e5cc}{#1}"); + defineMacro("\\grayA", "\\textcolor{##f6f7f7}{#1}"); + defineMacro("\\grayB", "\\textcolor{##f0f1f2}{#1}"); + defineMacro("\\grayC", "\\textcolor{##e3e5e6}{#1}"); + defineMacro("\\grayD", "\\textcolor{##d6d8da}{#1}"); + defineMacro("\\grayE", "\\textcolor{##babec2}{#1}"); + defineMacro("\\grayF", "\\textcolor{##888d93}{#1}"); + defineMacro("\\grayG", "\\textcolor{##626569}{#1}"); + defineMacro("\\grayH", "\\textcolor{##3b3e40}{#1}"); + defineMacro("\\grayI", "\\textcolor{##21242c}{#1}"); + defineMacro("\\kaBlue", "\\textcolor{##314453}{#1}"); + defineMacro("\\kaGreen", "\\textcolor{##71B307}{#1}"); + var implicitCommands = { + "^": true, + // Parser.js + "_": true, + // Parser.js + "\\limits": true, + // Parser.js + "\\nolimits": true + // Parser.js + }; + class MacroExpander { + constructor(input, settings, mode) { + this.settings = void 0; + this.expansionCount = void 0; + this.lexer = void 0; + this.macros = void 0; + this.stack = void 0; + this.mode = void 0; + this.settings = settings; + this.expansionCount = 0; + this.feed(input); + this.macros = new Namespace(macros, settings.macros); + this.mode = mode; + this.stack = []; + } + /** + * Feed a new input string to the same MacroExpander + * (with existing macros etc.). + */ + feed(input) { + this.lexer = new Lexer(input, this.settings); + } + /** + * Switches between "text" and "math" modes. + */ + switchMode(newMode) { + this.mode = newMode; + } + /** + * Start a new group nesting within all namespaces. + */ + beginGroup() { + this.macros.beginGroup(); + } + /** + * End current group nesting within all namespaces. + */ + endGroup() { + this.macros.endGroup(); + } + /** + * Ends all currently nested groups (if any), restoring values before the + * groups began. Useful in case of an error in the middle of parsing. + */ + endGroups() { + this.macros.endGroups(); + } + /** + * Returns the topmost token on the stack, without expanding it. + * Similar in behavior to TeX's `\futurelet`. + */ + future() { + if (this.stack.length === 0) { + this.pushToken(this.lexer.lex()); + } + return this.stack[this.stack.length - 1]; + } + /** + * Remove and return the next unexpanded token. + */ + popToken() { + this.future(); + return this.stack.pop(); + } + /** + * Add a given token to the token stack. In particular, this get be used + * to put back a token returned from one of the other methods. + */ + pushToken(token2) { + this.stack.push(token2); + } + /** + * Append an array of tokens to the token stack. + */ + pushTokens(tokens) { + this.stack.push(...tokens); + } + /** + * Find an macro argument without expanding tokens and append the array of + * tokens to the token stack. Uses Token as a container for the result. + */ + scanArgument(isOptional) { + var start2; + var end2; + var tokens; + if (isOptional) { + this.consumeSpaces(); + if (this.future().text !== "[") { + return null; + } + start2 = this.popToken(); + ({ + tokens, + end: end2 + } = this.consumeArg(["]"])); + } else { + ({ + tokens, + start: start2, + end: end2 + } = this.consumeArg()); + } + this.pushToken(new Token("EOF", end2.loc)); + this.pushTokens(tokens); + return start2.range(end2, ""); + } + /** + * Consume all following space tokens, without expansion. + */ + consumeSpaces() { + for (; ; ) { + var token2 = this.future(); + if (token2.text === " ") { + this.stack.pop(); + } else { + break; + } + } + } + /** + * Consume an argument from the token stream, and return the resulting array + * of tokens and start/end token. + */ + consumeArg(delims) { + var tokens = []; + var isDelimited = delims && delims.length > 0; + if (!isDelimited) { + this.consumeSpaces(); + } + var start2 = this.future(); + var tok; + var depth = 0; + var match = 0; + do { + tok = this.popToken(); + tokens.push(tok); + if (tok.text === "{") { + ++depth; + } else if (tok.text === "}") { + --depth; + if (depth === -1) { + throw new ParseError("Extra }", tok); + } + } else if (tok.text === "EOF") { + throw new ParseError("Unexpected end of input in a macro argument, expected '" + (delims && isDelimited ? delims[match] : "}") + "'", tok); + } + if (delims && isDelimited) { + if ((depth === 0 || depth === 1 && delims[match] === "{") && tok.text === delims[match]) { + ++match; + if (match === delims.length) { + tokens.splice(-match, match); + break; + } + } else { + match = 0; + } + } + } while (depth !== 0 || isDelimited); + if (start2.text === "{" && tokens[tokens.length - 1].text === "}") { + tokens.pop(); + tokens.shift(); + } + tokens.reverse(); + return { + tokens, + start: start2, + end: tok + }; + } + /** + * Consume the specified number of (delimited) arguments from the token + * stream and return the resulting array of arguments. + */ + consumeArgs(numArgs, delimiters2) { + if (delimiters2) { + if (delimiters2.length !== numArgs + 1) { + throw new ParseError("The length of delimiters doesn't match the number of args!"); + } + var delims = delimiters2[0]; + for (var i2 = 0; i2 < delims.length; i2++) { + var tok = this.popToken(); + if (delims[i2] !== tok.text) { + throw new ParseError("Use of the macro doesn't match its definition", tok); + } + } + } + var args = []; + for (var _i6 = 0; _i6 < numArgs; _i6++) { + args.push(this.consumeArg(delimiters2 && delimiters2[_i6 + 1]).tokens); + } + return args; + } + /** + * Expand the next token only once if possible. + * + * If the token is expanded, the resulting tokens will be pushed onto + * the stack in reverse order, and the number of such tokens will be + * returned. This number might be zero or positive. + * + * If not, the return value is `false`, and the next token remains at the + * top of the stack. + * + * In either case, the next token will be on the top of the stack, + * or the stack will be empty (in case of empty expansion + * and no other tokens). + * + * Used to implement `expandAfterFuture` and `expandNextToken`. + * + * If expandableOnly, only expandable tokens are expanded and + * an undefined control sequence results in an error. + */ + expandOnce(expandableOnly) { + var topToken = this.popToken(); + var name = topToken.text; + var expansion = !topToken.noexpand ? this._getExpansion(name) : null; + if (expansion == null || expandableOnly && expansion.unexpandable) { + if (expandableOnly && expansion == null && name[0] === "\\" && !this.isDefined(name)) { + throw new ParseError("Undefined control sequence: " + name); + } + this.pushToken(topToken); + return false; + } + this.expansionCount++; + if (this.expansionCount > this.settings.maxExpand) { + throw new ParseError("Too many expansions: infinite loop or need to increase maxExpand setting"); + } + var tokens = expansion.tokens; + var args = this.consumeArgs(expansion.numArgs, expansion.delimiters); + if (expansion.numArgs) { + tokens = tokens.slice(); + for (var i2 = tokens.length - 1; i2 >= 0; --i2) { + var tok = tokens[i2]; + if (tok.text === "#") { + if (i2 === 0) { + throw new ParseError("Incomplete placeholder at end of macro body", tok); + } + tok = tokens[--i2]; + if (tok.text === "#") { + tokens.splice(i2 + 1, 1); + } else if (/^[1-9]$/.test(tok.text)) { + tokens.splice(i2, 2, ...args[+tok.text - 1]); + } else { + throw new ParseError("Not a valid argument number", tok); + } + } + } + } + this.pushTokens(tokens); + return tokens.length; + } + /** + * Expand the next token only once (if possible), and return the resulting + * top token on the stack (without removing anything from the stack). + * Similar in behavior to TeX's `\expandafter\futurelet`. + * Equivalent to expandOnce() followed by future(). + */ + expandAfterFuture() { + this.expandOnce(); + return this.future(); + } + /** + * Recursively expand first token, then return first non-expandable token. + */ + expandNextToken() { + for (; ; ) { + if (this.expandOnce() === false) { + var token2 = this.stack.pop(); + if (token2.treatAsRelax) { + token2.text = "\\relax"; + } + return token2; + } + } + throw new Error(); + } + /** + * Fully expand the given macro name and return the resulting list of + * tokens, or return `undefined` if no such macro is defined. + */ + expandMacro(name) { + return this.macros.has(name) ? this.expandTokens([new Token(name)]) : void 0; + } + /** + * Fully expand the given token stream and return the resulting list of + * tokens. Note that the input tokens are in reverse order, but the + * output tokens are in forward order. + */ + expandTokens(tokens) { + var output = []; + var oldStackLength = this.stack.length; + this.pushTokens(tokens); + while (this.stack.length > oldStackLength) { + if (this.expandOnce(true) === false) { + var token2 = this.stack.pop(); + if (token2.treatAsRelax) { + token2.noexpand = false; + token2.treatAsRelax = false; + } + output.push(token2); + } + } + return output; + } + /** + * Fully expand the given macro name and return the result as a string, + * or return `undefined` if no such macro is defined. + */ + expandMacroAsText(name) { + var tokens = this.expandMacro(name); + if (tokens) { + return tokens.map((token2) => token2.text).join(""); + } else { + return tokens; + } + } + /** + * Returns the expanded macro as a reversed array of tokens and a macro + * argument count. Or returns `null` if no such macro. + */ + _getExpansion(name) { + var definition2 = this.macros.get(name); + if (definition2 == null) { + return definition2; + } + if (name.length === 1) { + var catcode = this.lexer.catcodes[name]; + if (catcode != null && catcode !== 13) { + return; + } + } + var expansion = typeof definition2 === "function" ? definition2(this) : definition2; + if (typeof expansion === "string") { + var numArgs = 0; + if (expansion.indexOf("#") !== -1) { + var stripped = expansion.replace(/##/g, ""); + while (stripped.indexOf("#" + (numArgs + 1)) !== -1) { + ++numArgs; + } + } + var bodyLexer = new Lexer(expansion, this.settings); + var tokens = []; + var tok = bodyLexer.lex(); + while (tok.text !== "EOF") { + tokens.push(tok); + tok = bodyLexer.lex(); + } + tokens.reverse(); + var expanded = { + tokens, + numArgs + }; + return expanded; + } + return expansion; + } + /** + * Determine whether a command is currently "defined" (has some + * functionality), meaning that it's a macro (in the current group), + * a function, a symbol, or one of the special commands listed in + * `implicitCommands`. + */ + isDefined(name) { + return this.macros.has(name) || functions$1.hasOwnProperty(name) || symbols.math.hasOwnProperty(name) || symbols.text.hasOwnProperty(name) || implicitCommands.hasOwnProperty(name); + } + /** + * Determine whether a command is expandable. + */ + isExpandable(name) { + var macro = this.macros.get(name); + return macro != null ? typeof macro === "string" || typeof macro === "function" || !macro.unexpandable : functions$1.hasOwnProperty(name) && !functions$1[name].primitive; + } + } + var unicodeSubRegEx = /^[₊₋₌₍₎₀₁₂₃₄₅₆₇₈₉ₐₑₕᵢⱼₖₗₘₙₒₚᵣₛₜᵤᵥₓᵦᵧᵨᵩᵪ]/; + var uSubsAndSups = Object.freeze({ + "₊": "+", + "₋": "-", + "₌": "=", + "₍": "(", + "₎": ")", + "₀": "0", + "₁": "1", + "₂": "2", + "₃": "3", + "₄": "4", + "₅": "5", + "₆": "6", + "₇": "7", + "₈": "8", + "₉": "9", + "ₐ": "a", + "ₑ": "e", + "ₕ": "h", + "ᵢ": "i", + "ⱼ": "j", + "ₖ": "k", + "ₗ": "l", + "ₘ": "m", + "ₙ": "n", + "ₒ": "o", + "ₚ": "p", + "ᵣ": "r", + "ₛ": "s", + "ₜ": "t", + "ᵤ": "u", + "ᵥ": "v", + "ₓ": "x", + "ᵦ": "β", + "ᵧ": "γ", + "ᵨ": "ρ", + "ᵩ": "ϕ", + "ᵪ": "χ", + "⁺": "+", + "⁻": "-", + "⁼": "=", + "⁽": "(", + "⁾": ")", + "⁰": "0", + "¹": "1", + "²": "2", + "³": "3", + "⁴": "4", + "⁵": "5", + "⁶": "6", + "⁷": "7", + "⁸": "8", + "⁹": "9", + "ᴬ": "A", + "ᴮ": "B", + "ᴰ": "D", + "ᴱ": "E", + "ᴳ": "G", + "ᴴ": "H", + "ᴵ": "I", + "ᴶ": "J", + "ᴷ": "K", + "ᴸ": "L", + "ᴹ": "M", + "ᴺ": "N", + "ᴼ": "O", + "ᴾ": "P", + "ᴿ": "R", + "ᵀ": "T", + "ᵁ": "U", + "ⱽ": "V", + "ᵂ": "W", + "ᵃ": "a", + "ᵇ": "b", + "ᶜ": "c", + "ᵈ": "d", + "ᵉ": "e", + "ᶠ": "f", + "ᵍ": "g", + "ʰ": "h", + "ⁱ": "i", + "ʲ": "j", + "ᵏ": "k", + "ˡ": "l", + "ᵐ": "m", + "ⁿ": "n", + "ᵒ": "o", + "ᵖ": "p", + "ʳ": "r", + "ˢ": "s", + "ᵗ": "t", + "ᵘ": "u", + "ᵛ": "v", + "ʷ": "w", + "ˣ": "x", + "ʸ": "y", + "ᶻ": "z", + "ᵝ": "β", + "ᵞ": "γ", + "ᵟ": "δ", + "ᵠ": "ϕ", + "ᵡ": "χ", + "ᶿ": "θ" + }); + var unicodeAccents = { + "́": { + "text": "\\'", + "math": "\\acute" + }, + "̀": { + "text": "\\`", + "math": "\\grave" + }, + "̈": { + "text": '\\"', + "math": "\\ddot" + }, + "̃": { + "text": "\\~", + "math": "\\tilde" + }, + "̄": { + "text": "\\=", + "math": "\\bar" + }, + "̆": { + "text": "\\u", + "math": "\\breve" + }, + "̌": { + "text": "\\v", + "math": "\\check" + }, + "̂": { + "text": "\\^", + "math": "\\hat" + }, + "̇": { + "text": "\\.", + "math": "\\dot" + }, + "̊": { + "text": "\\r", + "math": "\\mathring" + }, + "̋": { + "text": "\\H" + }, + "̧": { + "text": "\\c" + } + }; + var unicodeSymbols = { + "á": "á", + "à": "à", + "ä": "ä", + "ǟ": "ǟ", + "ã": "ã", + "ā": "ā", + "ă": "ă", + "ắ": "ắ", + "ằ": "ằ", + "ẵ": "ẵ", + "ǎ": "ǎ", + "â": "â", + "ấ": "ấ", + "ầ": "ầ", + "ẫ": "ẫ", + "ȧ": "ȧ", + "ǡ": "ǡ", + "å": "å", + "ǻ": "ǻ", + "ḃ": "ḃ", + "ć": "ć", + "ḉ": "ḉ", + "č": "č", + "ĉ": "ĉ", + "ċ": "ċ", + "ç": "ç", + "ď": "ď", + "ḋ": "ḋ", + "ḑ": "ḑ", + "é": "é", + "è": "è", + "ë": "ë", + "ẽ": "ẽ", + "ē": "ē", + "ḗ": "ḗ", + "ḕ": "ḕ", + "ĕ": "ĕ", + "ḝ": "ḝ", + "ě": "ě", + "ê": "ê", + "ế": "ế", + "ề": "ề", + "ễ": "ễ", + "ė": "ė", + "ȩ": "ȩ", + "ḟ": "ḟ", + "ǵ": "ǵ", + "ḡ": "ḡ", + "ğ": "ğ", + "ǧ": "ǧ", + "ĝ": "ĝ", + "ġ": "ġ", + "ģ": "ģ", + "ḧ": "ḧ", + "ȟ": "ȟ", + "ĥ": "ĥ", + "ḣ": "ḣ", + "ḩ": "ḩ", + "í": "í", + "ì": "ì", + "ï": "ï", + "ḯ": "ḯ", + "ĩ": "ĩ", + "ī": "ī", + "ĭ": "ĭ", + "ǐ": "ǐ", + "î": "î", + "ǰ": "ǰ", + "ĵ": "ĵ", + "ḱ": "ḱ", + "ǩ": "ǩ", + "ķ": "ķ", + "ĺ": "ĺ", + "ľ": "ľ", + "ļ": "ļ", + "ḿ": "ḿ", + "ṁ": "ṁ", + "ń": "ń", + "ǹ": "ǹ", + "ñ": "ñ", + "ň": "ň", + "ṅ": "ṅ", + "ņ": "ņ", + "ó": "ó", + "ò": "ò", + "ö": "ö", + "ȫ": "ȫ", + "õ": "õ", + "ṍ": "ṍ", + "ṏ": "ṏ", + "ȭ": "ȭ", + "ō": "ō", + "ṓ": "ṓ", + "ṑ": "ṑ", + "ŏ": "ŏ", + "ǒ": "ǒ", + "ô": "ô", + "ố": "ố", + "ồ": "ồ", + "ỗ": "ỗ", + "ȯ": "ȯ", + "ȱ": "ȱ", + "ő": "ő", + "ṕ": "ṕ", + "ṗ": "ṗ", + "ŕ": "ŕ", + "ř": "ř", + "ṙ": "ṙ", + "ŗ": "ŗ", + "ś": "ś", + "ṥ": "ṥ", + "š": "š", + "ṧ": "ṧ", + "ŝ": "ŝ", + "ṡ": "ṡ", + "ş": "ş", + "ẗ": "ẗ", + "ť": "ť", + "ṫ": "ṫ", + "ţ": "ţ", + "ú": "ú", + "ù": "ù", + "ü": "ü", + "ǘ": "ǘ", + "ǜ": "ǜ", + "ǖ": "ǖ", + "ǚ": "ǚ", + "ũ": "ũ", + "ṹ": "ṹ", + "ū": "ū", + "ṻ": "ṻ", + "ŭ": "ŭ", + "ǔ": "ǔ", + "û": "û", + "ů": "ů", + "ű": "ű", + "ṽ": "ṽ", + "ẃ": "ẃ", + "ẁ": "ẁ", + "ẅ": "ẅ", + "ŵ": "ŵ", + "ẇ": "ẇ", + "ẘ": "ẘ", + "ẍ": "ẍ", + "ẋ": "ẋ", + "ý": "ý", + "ỳ": "ỳ", + "ÿ": "ÿ", + "ỹ": "ỹ", + "ȳ": "ȳ", + "ŷ": "ŷ", + "ẏ": "ẏ", + "ẙ": "ẙ", + "ź": "ź", + "ž": "ž", + "ẑ": "ẑ", + "ż": "ż", + "Á": "Á", + "À": "À", + "Ä": "Ä", + "Ǟ": "Ǟ", + "Ã": "Ã", + "Ā": "Ā", + "Ă": "Ă", + "Ắ": "Ắ", + "Ằ": "Ằ", + "Ẵ": "Ẵ", + "Ǎ": "Ǎ", + "Â": "Â", + "Ấ": "Ấ", + "Ầ": "Ầ", + "Ẫ": "Ẫ", + "Ȧ": "Ȧ", + "Ǡ": "Ǡ", + "Å": "Å", + "Ǻ": "Ǻ", + "Ḃ": "Ḃ", + "Ć": "Ć", + "Ḉ": "Ḉ", + "Č": "Č", + "Ĉ": "Ĉ", + "Ċ": "Ċ", + "Ç": "Ç", + "Ď": "Ď", + "Ḋ": "Ḋ", + "Ḑ": "Ḑ", + "É": "É", + "È": "È", + "Ë": "Ë", + "Ẽ": "Ẽ", + "Ē": "Ē", + "Ḗ": "Ḗ", + "Ḕ": "Ḕ", + "Ĕ": "Ĕ", + "Ḝ": "Ḝ", + "Ě": "Ě", + "Ê": "Ê", + "Ế": "Ế", + "Ề": "Ề", + "Ễ": "Ễ", + "Ė": "Ė", + "Ȩ": "Ȩ", + "Ḟ": "Ḟ", + "Ǵ": "Ǵ", + "Ḡ": "Ḡ", + "Ğ": "Ğ", + "Ǧ": "Ǧ", + "Ĝ": "Ĝ", + "Ġ": "Ġ", + "Ģ": "Ģ", + "Ḧ": "Ḧ", + "Ȟ": "Ȟ", + "Ĥ": "Ĥ", + "Ḣ": "Ḣ", + "Ḩ": "Ḩ", + "Í": "Í", + "Ì": "Ì", + "Ï": "Ï", + "Ḯ": "Ḯ", + "Ĩ": "Ĩ", + "Ī": "Ī", + "Ĭ": "Ĭ", + "Ǐ": "Ǐ", + "Î": "Î", + "İ": "İ", + "Ĵ": "Ĵ", + "Ḱ": "Ḱ", + "Ǩ": "Ǩ", + "Ķ": "Ķ", + "Ĺ": "Ĺ", + "Ľ": "Ľ", + "Ļ": "Ļ", + "Ḿ": "Ḿ", + "Ṁ": "Ṁ", + "Ń": "Ń", + "Ǹ": "Ǹ", + "Ñ": "Ñ", + "Ň": "Ň", + "Ṅ": "Ṅ", + "Ņ": "Ņ", + "Ó": "Ó", + "Ò": "Ò", + "Ö": "Ö", + "Ȫ": "Ȫ", + "Õ": "Õ", + "Ṍ": "Ṍ", + "Ṏ": "Ṏ", + "Ȭ": "Ȭ", + "Ō": "Ō", + "Ṓ": "Ṓ", + "Ṑ": "Ṑ", + "Ŏ": "Ŏ", + "Ǒ": "Ǒ", + "Ô": "Ô", + "Ố": "Ố", + "Ồ": "Ồ", + "Ỗ": "Ỗ", + "Ȯ": "Ȯ", + "Ȱ": "Ȱ", + "Ő": "Ő", + "Ṕ": "Ṕ", + "Ṗ": "Ṗ", + "Ŕ": "Ŕ", + "Ř": "Ř", + "Ṙ": "Ṙ", + "Ŗ": "Ŗ", + "Ś": "Ś", + "Ṥ": "Ṥ", + "Š": "Š", + "Ṧ": "Ṧ", + "Ŝ": "Ŝ", + "Ṡ": "Ṡ", + "Ş": "Ş", + "Ť": "Ť", + "Ṫ": "Ṫ", + "Ţ": "Ţ", + "Ú": "Ú", + "Ù": "Ù", + "Ü": "Ü", + "Ǘ": "Ǘ", + "Ǜ": "Ǜ", + "Ǖ": "Ǖ", + "Ǚ": "Ǚ", + "Ũ": "Ũ", + "Ṹ": "Ṹ", + "Ū": "Ū", + "Ṻ": "Ṻ", + "Ŭ": "Ŭ", + "Ǔ": "Ǔ", + "Û": "Û", + "Ů": "Ů", + "Ű": "Ű", + "Ṽ": "Ṽ", + "Ẃ": "Ẃ", + "Ẁ": "Ẁ", + "Ẅ": "Ẅ", + "Ŵ": "Ŵ", + "Ẇ": "Ẇ", + "Ẍ": "Ẍ", + "Ẋ": "Ẋ", + "Ý": "Ý", + "Ỳ": "Ỳ", + "Ÿ": "Ÿ", + "Ỹ": "Ỹ", + "Ȳ": "Ȳ", + "Ŷ": "Ŷ", + "Ẏ": "Ẏ", + "Ź": "Ź", + "Ž": "Ž", + "Ẑ": "Ẑ", + "Ż": "Ż", + "ά": "ά", + "ὰ": "ὰ", + "ᾱ": "ᾱ", + "ᾰ": "ᾰ", + "έ": "έ", + "ὲ": "ὲ", + "ή": "ή", + "ὴ": "ὴ", + "ί": "ί", + "ὶ": "ὶ", + "ϊ": "ϊ", + "ΐ": "ΐ", + "ῒ": "ῒ", + "ῑ": "ῑ", + "ῐ": "ῐ", + "ό": "ό", + "ὸ": "ὸ", + "ύ": "ύ", + "ὺ": "ὺ", + "ϋ": "ϋ", + "ΰ": "ΰ", + "ῢ": "ῢ", + "ῡ": "ῡ", + "ῠ": "ῠ", + "ώ": "ώ", + "ὼ": "ὼ", + "Ύ": "Ύ", + "Ὺ": "Ὺ", + "Ϋ": "Ϋ", + "Ῡ": "Ῡ", + "Ῠ": "Ῠ", + "Ώ": "Ώ", + "Ὼ": "Ὼ" + }; + class Parser { + constructor(input, settings) { + this.mode = void 0; + this.gullet = void 0; + this.settings = void 0; + this.leftrightDepth = void 0; + this.nextToken = void 0; + this.mode = "math"; + this.gullet = new MacroExpander(input, settings, this.mode); + this.settings = settings; + this.leftrightDepth = 0; + } + /** + * Checks a result to make sure it has the right type, and throws an + * appropriate error otherwise. + */ + expect(text2, consume) { + if (consume === void 0) { + consume = true; + } + if (this.fetch().text !== text2) { + throw new ParseError("Expected '" + text2 + "', got '" + this.fetch().text + "'", this.fetch()); + } + if (consume) { + this.consume(); + } + } + /** + * Discards the current lookahead token, considering it consumed. + */ + consume() { + this.nextToken = null; + } + /** + * Return the current lookahead token, or if there isn't one (at the + * beginning, or if the previous lookahead token was consume()d), + * fetch the next token as the new lookahead token and return it. + */ + fetch() { + if (this.nextToken == null) { + this.nextToken = this.gullet.expandNextToken(); + } + return this.nextToken; + } + /** + * Switches between "text" and "math" modes. + */ + switchMode(newMode) { + this.mode = newMode; + this.gullet.switchMode(newMode); + } + /** + * Main parsing function, which parses an entire input. + */ + parse() { + if (!this.settings.globalGroup) { + this.gullet.beginGroup(); + } + if (this.settings.colorIsTextColor) { + this.gullet.macros.set("\\color", "\\textcolor"); + } + try { + var parse2 = this.parseExpression(false); + this.expect("EOF"); + if (!this.settings.globalGroup) { + this.gullet.endGroup(); + } + return parse2; + } finally { + this.gullet.endGroups(); + } + } + /** + * Fully parse a separate sequence of tokens as a separate job. + * Tokens should be specified in reverse order, as in a MacroDefinition. + */ + subparse(tokens) { + var oldToken = this.nextToken; + this.consume(); + this.gullet.pushToken(new Token("}")); + this.gullet.pushTokens(tokens); + var parse2 = this.parseExpression(false); + this.expect("}"); + this.nextToken = oldToken; + return parse2; + } + /** + * Parses an "expression", which is a list of atoms. + * + * `breakOnInfix`: Should the parsing stop when we hit infix nodes? This + * happens when functions have higher precedence han infix + * nodes in implicit parses. + * + * `breakOnTokenText`: The text of the token that the expression should end + * with, or `null` if something else should end the + * expression. + */ + parseExpression(breakOnInfix, breakOnTokenText) { + var body = []; + while (true) { + if (this.mode === "math") { + this.consumeSpaces(); + } + var lex2 = this.fetch(); + if (Parser.endOfExpression.indexOf(lex2.text) !== -1) { + break; + } + if (breakOnTokenText && lex2.text === breakOnTokenText) { + break; + } + if (breakOnInfix && functions$1[lex2.text] && functions$1[lex2.text].infix) { + break; + } + var atom = this.parseAtom(breakOnTokenText); + if (!atom) { + break; + } else if (atom.type === "internal") { + continue; + } + body.push(atom); + } + if (this.mode === "text") { + this.formLigatures(body); + } + return this.handleInfixNodes(body); + } + /** + * Rewrites infix operators such as \over with corresponding commands such + * as \frac. + * + * There can only be one infix operator per group. If there's more than one + * then the expression is ambiguous. This can be resolved by adding {}. + */ + handleInfixNodes(body) { + var overIndex = -1; + var funcName; + for (var i2 = 0; i2 < body.length; i2++) { + if (body[i2].type === "infix") { + if (overIndex !== -1) { + throw new ParseError("only one infix operator per group", body[i2].token); + } + overIndex = i2; + funcName = body[i2].replaceWith; + } + } + if (overIndex !== -1 && funcName) { + var numerNode; + var denomNode; + var numerBody = body.slice(0, overIndex); + var denomBody = body.slice(overIndex + 1); + if (numerBody.length === 1 && numerBody[0].type === "ordgroup") { + numerNode = numerBody[0]; + } else { + numerNode = { + type: "ordgroup", + mode: this.mode, + body: numerBody + }; + } + if (denomBody.length === 1 && denomBody[0].type === "ordgroup") { + denomNode = denomBody[0]; + } else { + denomNode = { + type: "ordgroup", + mode: this.mode, + body: denomBody + }; + } + var node2; + if (funcName === "\\\\abovefrac") { + node2 = this.callFunction(funcName, [numerNode, body[overIndex], denomNode], []); + } else { + node2 = this.callFunction(funcName, [numerNode, denomNode], []); + } + return [node2]; + } else { + return body; + } + } + /** + * Handle a subscript or superscript with nice errors. + */ + handleSupSubscript(name) { + var symbolToken = this.fetch(); + var symbol = symbolToken.text; + this.consume(); + this.consumeSpaces(); + var group = this.parseGroup(name); + if (!group) { + throw new ParseError("Expected group after '" + symbol + "'", symbolToken); + } + return group; + } + /** + * Converts the textual input of an unsupported command into a text node + * contained within a color node whose color is determined by errorColor + */ + formatUnsupportedCmd(text2) { + var textordArray = []; + for (var i2 = 0; i2 < text2.length; i2++) { + textordArray.push({ + type: "textord", + mode: "text", + text: text2[i2] + }); + } + var textNode = { + type: "text", + mode: this.mode, + body: textordArray + }; + var colorNode = { + type: "color", + mode: this.mode, + color: this.settings.errorColor, + body: [textNode] + }; + return colorNode; + } + /** + * Parses a group with optional super/subscripts. + */ + parseAtom(breakOnTokenText) { + var base = this.parseGroup("atom", breakOnTokenText); + if (this.mode === "text") { + return base; + } + var superscript; + var subscript; + while (true) { + this.consumeSpaces(); + var lex2 = this.fetch(); + if (lex2.text === "\\limits" || lex2.text === "\\nolimits") { + if (base && base.type === "op") { + var limits = lex2.text === "\\limits"; + base.limits = limits; + base.alwaysHandleSupSub = true; + } else if (base && base.type === "operatorname") { + if (base.alwaysHandleSupSub) { + base.limits = lex2.text === "\\limits"; + } + } else { + throw new ParseError("Limit controls must follow a math operator", lex2); + } + this.consume(); + } else if (lex2.text === "^") { + if (superscript) { + throw new ParseError("Double superscript", lex2); + } + superscript = this.handleSupSubscript("superscript"); + } else if (lex2.text === "_") { + if (subscript) { + throw new ParseError("Double subscript", lex2); + } + subscript = this.handleSupSubscript("subscript"); + } else if (lex2.text === "'") { + if (superscript) { + throw new ParseError("Double superscript", lex2); + } + var prime = { + type: "textord", + mode: this.mode, + text: "\\prime" + }; + var primes = [prime]; + this.consume(); + while (this.fetch().text === "'") { + primes.push(prime); + this.consume(); + } + if (this.fetch().text === "^") { + primes.push(this.handleSupSubscript("superscript")); + } + superscript = { + type: "ordgroup", + mode: this.mode, + body: primes + }; + } else if (uSubsAndSups[lex2.text]) { + var str2 = uSubsAndSups[lex2.text]; + var isSub = unicodeSubRegEx.test(lex2.text); + this.consume(); + while (true) { + var token2 = this.fetch().text; + if (!uSubsAndSups[token2]) { + break; + } + if (unicodeSubRegEx.test(token2) !== isSub) { + break; + } + this.consume(); + str2 += uSubsAndSups[token2]; + } + var body = new Parser(str2, this.settings).parse(); + if (isSub) { + subscript = { + type: "ordgroup", + mode: "math", + body + }; + } else { + superscript = { + type: "ordgroup", + mode: "math", + body + }; + } + } else { + break; + } + } + if (superscript || subscript) { + return { + type: "supsub", + mode: this.mode, + base, + sup: superscript, + sub: subscript + }; + } else { + return base; + } + } + /** + * Parses an entire function, including its base and all of its arguments. + */ + parseFunction(breakOnTokenText, name) { + var token2 = this.fetch(); + var func = token2.text; + var funcData = functions$1[func]; + if (!funcData) { + return null; + } + this.consume(); + if (name && name !== "atom" && !funcData.allowedInArgument) { + throw new ParseError("Got function '" + func + "' with no arguments" + (name ? " as " + name : ""), token2); + } else if (this.mode === "text" && !funcData.allowedInText) { + throw new ParseError("Can't use function '" + func + "' in text mode", token2); + } else if (this.mode === "math" && funcData.allowedInMath === false) { + throw new ParseError("Can't use function '" + func + "' in math mode", token2); + } + var { + args, + optArgs + } = this.parseArguments(func, funcData); + return this.callFunction(func, args, optArgs, token2, breakOnTokenText); + } + /** + * Call a function handler with a suitable context and arguments. + */ + callFunction(name, args, optArgs, token2, breakOnTokenText) { + var context = { + funcName: name, + parser: this, + token: token2, + breakOnTokenText + }; + var func = functions$1[name]; + if (func && func.handler) { + return func.handler(context, args, optArgs); + } else { + throw new ParseError("No function handler for " + name); + } + } + /** + * Parses the arguments of a function or environment + */ + parseArguments(func, funcData) { + var totalArgs = funcData.numArgs + funcData.numOptionalArgs; + if (totalArgs === 0) { + return { + args: [], + optArgs: [] + }; + } + var args = []; + var optArgs = []; + for (var i2 = 0; i2 < totalArgs; i2++) { + var argType = funcData.argTypes && funcData.argTypes[i2]; + var isOptional = i2 < funcData.numOptionalArgs; + if (funcData.primitive && argType == null || // \sqrt expands into primitive if optional argument doesn't exist + funcData.type === "sqrt" && i2 === 1 && optArgs[0] == null) { + argType = "primitive"; + } + var arg = this.parseGroupOfType("argument to '" + func + "'", argType, isOptional); + if (isOptional) { + optArgs.push(arg); + } else if (arg != null) { + args.push(arg); + } else { + throw new ParseError("Null argument, please report this as a bug"); + } + } + return { + args, + optArgs + }; + } + /** + * Parses a group when the mode is changing. + */ + parseGroupOfType(name, type2, optional) { + switch (type2) { + case "color": + return this.parseColorGroup(optional); + case "size": + return this.parseSizeGroup(optional); + case "url": + return this.parseUrlGroup(optional); + case "math": + case "text": + return this.parseArgumentGroup(optional, type2); + case "hbox": { + var group = this.parseArgumentGroup(optional, "text"); + return group != null ? { + type: "styling", + mode: group.mode, + body: [group], + style: "text" + // simulate \textstyle + } : null; + } + case "raw": { + var token2 = this.parseStringGroup("raw", optional); + return token2 != null ? { + type: "raw", + mode: "text", + string: token2.text + } : null; + } + case "primitive": { + if (optional) { + throw new ParseError("A primitive argument cannot be optional"); + } + var _group = this.parseGroup(name); + if (_group == null) { + throw new ParseError("Expected group as " + name, this.fetch()); + } + return _group; + } + case "original": + case null: + case void 0: + return this.parseArgumentGroup(optional); + default: + throw new ParseError("Unknown group type as " + name, this.fetch()); + } + } + /** + * Discard any space tokens, fetching the next non-space token. + */ + consumeSpaces() { + while (this.fetch().text === " ") { + this.consume(); + } + } + /** + * Parses a group, essentially returning the string formed by the + * brace-enclosed tokens plus some position information. + */ + parseStringGroup(modeName, optional) { + var argToken = this.gullet.scanArgument(optional); + if (argToken == null) { + return null; + } + var str2 = ""; + var nextToken; + while ((nextToken = this.fetch()).text !== "EOF") { + str2 += nextToken.text; + this.consume(); + } + this.consume(); + argToken.text = str2; + return argToken; + } + /** + * Parses a regex-delimited group: the largest sequence of tokens + * whose concatenated strings match `regex`. Returns the string + * formed by the tokens plus some position information. + */ + parseRegexGroup(regex, modeName) { + var firstToken = this.fetch(); + var lastToken = firstToken; + var str2 = ""; + var nextToken; + while ((nextToken = this.fetch()).text !== "EOF" && regex.test(str2 + nextToken.text)) { + lastToken = nextToken; + str2 += lastToken.text; + this.consume(); + } + if (str2 === "") { + throw new ParseError("Invalid " + modeName + ": '" + firstToken.text + "'", firstToken); + } + return firstToken.range(lastToken, str2); + } + /** + * Parses a color description. + */ + parseColorGroup(optional) { + var res = this.parseStringGroup("color", optional); + if (res == null) { + return null; + } + var match = /^(#[a-f0-9]{3}|#?[a-f0-9]{6}|[a-z]+)$/i.exec(res.text); + if (!match) { + throw new ParseError("Invalid color: '" + res.text + "'", res); + } + var color2 = match[0]; + if (/^[0-9a-f]{6}$/i.test(color2)) { + color2 = "#" + color2; + } + return { + type: "color-token", + mode: this.mode, + color: color2 + }; + } + /** + * Parses a size specification, consisting of magnitude and unit. + */ + parseSizeGroup(optional) { + var res; + var isBlank = false; + this.gullet.consumeSpaces(); + if (!optional && this.gullet.future().text !== "{") { + res = this.parseRegexGroup(/^[-+]? *(?:$|\d+|\d+\.\d*|\.\d*) *[a-z]{0,2} *$/, "size"); + } else { + res = this.parseStringGroup("size", optional); + } + if (!res) { + return null; + } + if (!optional && res.text.length === 0) { + res.text = "0pt"; + isBlank = true; + } + var match = /([-+]?) *(\d+(?:\.\d*)?|\.\d+) *([a-z]{2})/.exec(res.text); + if (!match) { + throw new ParseError("Invalid size: '" + res.text + "'", res); + } + var data = { + number: +(match[1] + match[2]), + // sign + magnitude, cast to number + unit: match[3] + }; + if (!validUnit(data)) { + throw new ParseError("Invalid unit: '" + data.unit + "'", res); + } + return { + type: "size", + mode: this.mode, + value: data, + isBlank + }; + } + /** + * Parses an URL, checking escaped letters and allowed protocols, + * and setting the catcode of % as an active character (as in \hyperref). + */ + parseUrlGroup(optional) { + this.gullet.lexer.setCatcode("%", 13); + this.gullet.lexer.setCatcode("~", 12); + var res = this.parseStringGroup("url", optional); + this.gullet.lexer.setCatcode("%", 14); + this.gullet.lexer.setCatcode("~", 13); + if (res == null) { + return null; + } + var url = res.text.replace(/\\([#$%&~_^{}])/g, "$1"); + return { + type: "url", + mode: this.mode, + url + }; + } + /** + * Parses an argument with the mode specified. + */ + parseArgumentGroup(optional, mode) { + var argToken = this.gullet.scanArgument(optional); + if (argToken == null) { + return null; + } + var outerMode = this.mode; + if (mode) { + this.switchMode(mode); + } + this.gullet.beginGroup(); + var expression = this.parseExpression(false, "EOF"); + this.expect("EOF"); + this.gullet.endGroup(); + var result = { + type: "ordgroup", + mode: this.mode, + loc: argToken.loc, + body: expression + }; + if (mode) { + this.switchMode(outerMode); + } + return result; + } + /** + * Parses an ordinary group, which is either a single nucleus (like "x") + * or an expression in braces (like "{x+y}") or an implicit group, a group + * that starts at the current position, and ends right before a higher explicit + * group ends, or at EOF. + */ + parseGroup(name, breakOnTokenText) { + var firstToken = this.fetch(); + var text2 = firstToken.text; + var result; + if (text2 === "{" || text2 === "\\begingroup") { + this.consume(); + var groupEnd = text2 === "{" ? "}" : "\\endgroup"; + this.gullet.beginGroup(); + var expression = this.parseExpression(false, groupEnd); + var lastToken = this.fetch(); + this.expect(groupEnd); + this.gullet.endGroup(); + result = { + type: "ordgroup", + mode: this.mode, + loc: SourceLocation.range(firstToken, lastToken), + body: expression, + // A group formed by \begingroup...\endgroup is a semi-simple group + // which doesn't affect spacing in math mode, i.e., is transparent. + // https://tex.stackexchange.com/questions/1930/when-should-one- + // use-begingroup-instead-of-bgroup + semisimple: text2 === "\\begingroup" || void 0 + }; + } else { + result = this.parseFunction(breakOnTokenText, name) || this.parseSymbol(); + if (result == null && text2[0] === "\\" && !implicitCommands.hasOwnProperty(text2)) { + if (this.settings.throwOnError) { + throw new ParseError("Undefined control sequence: " + text2, firstToken); + } + result = this.formatUnsupportedCmd(text2); + this.consume(); + } + } + return result; + } + /** + * Form ligature-like combinations of characters for text mode. + * This includes inputs like "--", "---", "``" and "''". + * The result will simply replace multiple textord nodes with a single + * character in each value by a single textord node having multiple + * characters in its value. The representation is still ASCII source. + * The group will be modified in place. + */ + formLigatures(group) { + var n = group.length - 1; + for (var i2 = 0; i2 < n; ++i2) { + var a = group[i2]; + var v = a.text; + if (v === "-" && group[i2 + 1].text === "-") { + if (i2 + 1 < n && group[i2 + 2].text === "-") { + group.splice(i2, 3, { + type: "textord", + mode: "text", + loc: SourceLocation.range(a, group[i2 + 2]), + text: "---" + }); + n -= 2; + } else { + group.splice(i2, 2, { + type: "textord", + mode: "text", + loc: SourceLocation.range(a, group[i2 + 1]), + text: "--" + }); + n -= 1; + } + } + if ((v === "'" || v === "`") && group[i2 + 1].text === v) { + group.splice(i2, 2, { + type: "textord", + mode: "text", + loc: SourceLocation.range(a, group[i2 + 1]), + text: v + v + }); + n -= 1; + } + } + } + /** + * Parse a single symbol out of the string. Here, we handle single character + * symbols and special functions like \verb. + */ + parseSymbol() { + var nucleus = this.fetch(); + var text2 = nucleus.text; + if (/^\\verb[^a-zA-Z]/.test(text2)) { + this.consume(); + var arg = text2.slice(5); + var star = arg.charAt(0) === "*"; + if (star) { + arg = arg.slice(1); + } + if (arg.length < 2 || arg.charAt(0) !== arg.slice(-1)) { + throw new ParseError("\\verb assertion failed --\n please report what input caused this bug"); + } + arg = arg.slice(1, -1); + return { + type: "verb", + mode: "text", + body: arg, + star + }; + } + if (unicodeSymbols.hasOwnProperty(text2[0]) && !symbols[this.mode][text2[0]]) { + if (this.settings.strict && this.mode === "math") { + this.settings.reportNonstrict("unicodeTextInMathMode", 'Accented Unicode text character "' + text2[0] + '" used in math mode', nucleus); + } + text2 = unicodeSymbols[text2[0]] + text2.slice(1); + } + var match = combiningDiacriticalMarksEndRegex.exec(text2); + if (match) { + text2 = text2.substring(0, match.index); + if (text2 === "i") { + text2 = "ı"; + } else if (text2 === "j") { + text2 = "ȷ"; + } + } + var symbol; + if (symbols[this.mode][text2]) { + if (this.settings.strict && this.mode === "math" && extraLatin.indexOf(text2) >= 0) { + this.settings.reportNonstrict("unicodeTextInMathMode", 'Latin-1/Unicode text character "' + text2[0] + '" used in math mode', nucleus); + } + var group = symbols[this.mode][text2].group; + var loc = SourceLocation.range(nucleus); + var s; + if (ATOMS.hasOwnProperty(group)) { + var family = group; + s = { + type: "atom", + mode: this.mode, + family, + loc, + text: text2 + }; + } else { + s = { + type: group, + mode: this.mode, + loc, + text: text2 + }; + } + symbol = s; + } else if (text2.charCodeAt(0) >= 128) { + if (this.settings.strict) { + if (!supportedCodepoint(text2.charCodeAt(0))) { + this.settings.reportNonstrict("unknownSymbol", 'Unrecognized Unicode character "' + text2[0] + '"' + (" (" + text2.charCodeAt(0) + ")"), nucleus); + } else if (this.mode === "math") { + this.settings.reportNonstrict("unicodeTextInMathMode", 'Unicode text character "' + text2[0] + '" used in math mode', nucleus); + } + } + symbol = { + type: "textord", + mode: "text", + loc: SourceLocation.range(nucleus), + text: text2 + }; + } else { + return null; + } + this.consume(); + if (match) { + for (var i2 = 0; i2 < match[0].length; i2++) { + var accent2 = match[0][i2]; + if (!unicodeAccents[accent2]) { + throw new ParseError("Unknown accent ' " + accent2 + "'", nucleus); + } + var command = unicodeAccents[accent2][this.mode] || unicodeAccents[accent2].text; + if (!command) { + throw new ParseError("Accent " + accent2 + " unsupported in " + this.mode + " mode", nucleus); + } + symbol = { + type: "accent", + mode: this.mode, + loc: SourceLocation.range(nucleus), + label: command, + isStretchy: false, + isShifty: true, + // $FlowFixMe + base: symbol + }; + } + } + return symbol; + } + } + Parser.endOfExpression = ["}", "\\endgroup", "\\end", "\\right", "&"]; + var parseTree = function parseTree2(toParse, settings) { + if (!(typeof toParse === "string" || toParse instanceof String)) { + throw new TypeError("KaTeX can only parse string typed expression"); + } + var parser2 = new Parser(toParse, settings); + delete parser2.gullet.macros.current["\\df@tag"]; + var tree = parser2.parse(); + delete parser2.gullet.macros.current["\\current@color"]; + delete parser2.gullet.macros.current["\\color"]; + if (parser2.gullet.macros.get("\\df@tag")) { + if (!settings.displayMode) { + throw new ParseError("\\tag works only in display equations"); + } + tree = [{ + type: "tag", + mode: "text", + body: tree, + tag: parser2.subparse([new Token("\\df@tag")]) + }]; + } + return tree; + }; + var render$2 = function render2(expression, baseNode, options2) { + baseNode.textContent = ""; + var node2 = renderToDomTree(expression, options2).toNode(); + baseNode.appendChild(node2); + }; + if (typeof document !== "undefined") { + if (document.compatMode !== "CSS1Compat") { + typeof console !== "undefined" && console.warn("Warning: KaTeX doesn't work in quirks mode. Make sure your website has a suitable doctype."); + render$2 = function render2() { + throw new ParseError("KaTeX doesn't work in quirks mode."); + }; + } + } + var renderToString = function renderToString2(expression, options2) { + var markup = renderToDomTree(expression, options2).toMarkup(); + return markup; + }; + var generateParseTree = function generateParseTree2(expression, options2) { + var settings = new Settings(options2); + return parseTree(expression, settings); + }; + var renderError = function renderError2(error, expression, options2) { + if (options2.throwOnError || !(error instanceof ParseError)) { + throw error; + } + var node2 = buildCommon.makeSpan(["katex-error"], [new SymbolNode(expression)]); + node2.setAttribute("title", error.toString()); + node2.setAttribute("style", "color:" + options2.errorColor); + return node2; + }; + var renderToDomTree = function renderToDomTree2(expression, options2) { + var settings = new Settings(options2); + try { + var tree = parseTree(expression, settings); + return buildTree(tree, expression, settings); + } catch (error) { + return renderError(error, expression, settings); + } + }; + var renderToHTMLTree = function renderToHTMLTree2(expression, options2) { + var settings = new Settings(options2); + try { + var tree = parseTree(expression, settings); + return buildHTMLTree(tree, expression, settings); + } catch (error) { + return renderError(error, expression, settings); + } + }; + var katex = { + /** + * Current KaTeX version + */ + version: "0.16.9", + /** + * Renders the given LaTeX into an HTML+MathML combination, and adds + * it as a child to the specified DOM node. + */ + render: render$2, + /** + * Renders the given LaTeX into an HTML+MathML combination string, + * for sending to the client. + */ + renderToString, + /** + * KaTeX error, usually during parsing. + */ + ParseError, + /** + * The shema of Settings + */ + SETTINGS_SCHEMA, + /** + * Parses the given LaTeX into KaTeX's internal parse tree structure, + * without rendering to HTML or MathML. + * + * NOTE: This method is not currently recommended for public use. + * The internal tree representation is unstable and is very likely + * to change. Use at your own risk. + */ + __parse: generateParseTree, + /** + * Renders the given LaTeX into an HTML+MathML internal DOM tree + * representation, without flattening that representation to a string. + * + * NOTE: This method is not currently recommended for public use. + * The internal tree representation is unstable and is very likely + * to change. Use at your own risk. + */ + __renderToDomTree: renderToDomTree, + /** + * Renders the given LaTeX into an HTML internal DOM tree representation, + * without MathML and without flattening that representation to a string. + * + * NOTE: This method is not currently recommended for public use. + * The internal tree representation is unstable and is very likely + * to change. Use at your own risk. + */ + __renderToHTMLTree: renderToHTMLTree, + /** + * extends internal font metrics object with a new object + * each key in the new object represents a font name + */ + __setFontMetrics: setFontMetrics, + /** + * adds a new symbol to builtin symbols table + */ + __defineSymbol: defineSymbol, + /** + * adds a new function to builtin function list, + * which directly produce parse tree elements + * and have their own html/mathml builders + */ + __defineFunction: defineFunction, + /** + * adds a new macro to builtin macro list + */ + __defineMacro: defineMacro, + /** + * Expose the dom tree node types, which can be useful for type checking nodes. + * + * NOTE: This method is not currently recommended for public use. + * The internal tree representation is unstable and is very likely + * to change. Use at your own risk. + */ + __domTree: { + Span, + Anchor, + SymbolNode, + SvgNode, + PathNode, + LineNode + } + }; + const katex$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + default: katex + }, Symbol.toStringTag, { value: "Module" })); + var parser$v = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 24], $V1 = [1, 25], $V2 = [1, 26], $V3 = [1, 27], $V4 = [1, 28], $V5 = [1, 63], $V6 = [1, 64], $V7 = [1, 65], $V8 = [1, 66], $V9 = [1, 67], $Va = [1, 68], $Vb = [1, 69], $Vc = [1, 29], $Vd = [1, 30], $Ve = [1, 31], $Vf = [1, 32], $Vg = [1, 33], $Vh = [1, 34], $Vi = [1, 35], $Vj = [1, 36], $Vk = [1, 37], $Vl = [1, 38], $Vm = [1, 39], $Vn = [1, 40], $Vo = [1, 41], $Vp = [1, 42], $Vq = [1, 43], $Vr = [1, 44], $Vs = [1, 45], $Vt = [1, 46], $Vu = [1, 47], $Vv = [1, 48], $Vw = [1, 50], $Vx = [1, 51], $Vy = [1, 52], $Vz = [1, 53], $VA = [1, 54], $VB = [1, 55], $VC = [1, 56], $VD = [1, 57], $VE = [1, 58], $VF = [1, 59], $VG = [1, 60], $VH = [14, 42], $VI = [14, 34, 36, 37, 38, 39, 40, 41, 42, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74], $VJ = [12, 14, 34, 36, 37, 38, 39, 40, 41, 42, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74], $VK = [1, 82], $VL = [1, 83], $VM = [1, 84], $VN = [1, 85], $VO = [12, 14, 42], $VP = [12, 14, 33, 42], $VQ = [12, 14, 33, 42, 76, 77, 79, 80], $VR = [12, 33], $VS = [34, 36, 37, 38, 39, 40, 41, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "mermaidDoc": 4, "direction": 5, "direction_tb": 6, "direction_bt": 7, "direction_rl": 8, "direction_lr": 9, "graphConfig": 10, "C4_CONTEXT": 11, "NEWLINE": 12, "statements": 13, "EOF": 14, "C4_CONTAINER": 15, "C4_COMPONENT": 16, "C4_DYNAMIC": 17, "C4_DEPLOYMENT": 18, "otherStatements": 19, "diagramStatements": 20, "otherStatement": 21, "title": 22, "accDescription": 23, "acc_title": 24, "acc_title_value": 25, "acc_descr": 26, "acc_descr_value": 27, "acc_descr_multiline_value": 28, "boundaryStatement": 29, "boundaryStartStatement": 30, "boundaryStopStatement": 31, "boundaryStart": 32, "LBRACE": 33, "ENTERPRISE_BOUNDARY": 34, "attributes": 35, "SYSTEM_BOUNDARY": 36, "BOUNDARY": 37, "CONTAINER_BOUNDARY": 38, "NODE": 39, "NODE_L": 40, "NODE_R": 41, "RBRACE": 42, "diagramStatement": 43, "PERSON": 44, "PERSON_EXT": 45, "SYSTEM": 46, "SYSTEM_DB": 47, "SYSTEM_QUEUE": 48, "SYSTEM_EXT": 49, "SYSTEM_EXT_DB": 50, "SYSTEM_EXT_QUEUE": 51, "CONTAINER": 52, "CONTAINER_DB": 53, "CONTAINER_QUEUE": 54, "CONTAINER_EXT": 55, "CONTAINER_EXT_DB": 56, "CONTAINER_EXT_QUEUE": 57, "COMPONENT": 58, "COMPONENT_DB": 59, "COMPONENT_QUEUE": 60, "COMPONENT_EXT": 61, "COMPONENT_EXT_DB": 62, "COMPONENT_EXT_QUEUE": 63, "REL": 64, "BIREL": 65, "REL_U": 66, "REL_D": 67, "REL_L": 68, "REL_R": 69, "REL_B": 70, "REL_INDEX": 71, "UPDATE_EL_STYLE": 72, "UPDATE_REL_STYLE": 73, "UPDATE_LAYOUT_CONFIG": 74, "attribute": 75, "STR": 76, "STR_KEY": 77, "STR_VALUE": 78, "ATTRIBUTE": 79, "ATTRIBUTE_EMPTY": 80, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 6: "direction_tb", 7: "direction_bt", 8: "direction_rl", 9: "direction_lr", 11: "C4_CONTEXT", 12: "NEWLINE", 14: "EOF", 15: "C4_CONTAINER", 16: "C4_COMPONENT", 17: "C4_DYNAMIC", 18: "C4_DEPLOYMENT", 22: "title", 23: "accDescription", 24: "acc_title", 25: "acc_title_value", 26: "acc_descr", 27: "acc_descr_value", 28: "acc_descr_multiline_value", 33: "LBRACE", 34: "ENTERPRISE_BOUNDARY", 36: "SYSTEM_BOUNDARY", 37: "BOUNDARY", 38: "CONTAINER_BOUNDARY", 39: "NODE", 40: "NODE_L", 41: "NODE_R", 42: "RBRACE", 44: "PERSON", 45: "PERSON_EXT", 46: "SYSTEM", 47: "SYSTEM_DB", 48: "SYSTEM_QUEUE", 49: "SYSTEM_EXT", 50: "SYSTEM_EXT_DB", 51: "SYSTEM_EXT_QUEUE", 52: "CONTAINER", 53: "CONTAINER_DB", 54: "CONTAINER_QUEUE", 55: "CONTAINER_EXT", 56: "CONTAINER_EXT_DB", 57: "CONTAINER_EXT_QUEUE", 58: "COMPONENT", 59: "COMPONENT_DB", 60: "COMPONENT_QUEUE", 61: "COMPONENT_EXT", 62: "COMPONENT_EXT_DB", 63: "COMPONENT_EXT_QUEUE", 64: "REL", 65: "BIREL", 66: "REL_U", 67: "REL_D", 68: "REL_L", 69: "REL_R", 70: "REL_B", 71: "REL_INDEX", 72: "UPDATE_EL_STYLE", 73: "UPDATE_REL_STYLE", 74: "UPDATE_LAYOUT_CONFIG", 76: "STR", 77: "STR_KEY", 78: "STR_VALUE", 79: "ATTRIBUTE", 80: "ATTRIBUTE_EMPTY" }, + productions_: [0, [3, 1], [3, 1], [5, 1], [5, 1], [5, 1], [5, 1], [4, 1], [10, 4], [10, 4], [10, 4], [10, 4], [10, 4], [13, 1], [13, 1], [13, 2], [19, 1], [19, 2], [19, 3], [21, 1], [21, 1], [21, 2], [21, 2], [21, 1], [29, 3], [30, 3], [30, 3], [30, 4], [32, 2], [32, 2], [32, 2], [32, 2], [32, 2], [32, 2], [32, 2], [31, 1], [20, 1], [20, 2], [20, 3], [43, 2], [43, 2], [43, 2], [43, 2], [43, 2], [43, 2], [43, 2], [43, 2], [43, 2], [43, 2], [43, 2], [43, 2], [43, 2], [43, 2], [43, 2], [43, 2], [43, 2], [43, 2], [43, 2], [43, 2], [43, 1], [43, 2], [43, 2], [43, 2], [43, 2], [43, 2], [43, 2], [43, 2], [43, 2], [43, 2], [43, 2], [43, 2], [35, 1], [35, 2], [75, 1], [75, 2], [75, 1], [75, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 3: + yy.setDirection("TB"); + break; + case 4: + yy.setDirection("BT"); + break; + case 5: + yy.setDirection("RL"); + break; + case 6: + yy.setDirection("LR"); + break; + case 8: + case 9: + case 10: + case 11: + case 12: + yy.setC4Type($$[$0 - 3]); + break; + case 19: + yy.setTitle($$[$0].substring(6)); + this.$ = $$[$0].substring(6); + break; + case 20: + yy.setAccDescription($$[$0].substring(15)); + this.$ = $$[$0].substring(15); + break; + case 21: + this.$ = $$[$0].trim(); + yy.setTitle(this.$); + break; + case 22: + case 23: + this.$ = $$[$0].trim(); + yy.setAccDescription(this.$); + break; + case 28: + case 29: + $$[$0].splice(2, 0, "ENTERPRISE"); + yy.addPersonOrSystemBoundary(...$$[$0]); + this.$ = $$[$0]; + break; + case 30: + yy.addPersonOrSystemBoundary(...$$[$0]); + this.$ = $$[$0]; + break; + case 31: + $$[$0].splice(2, 0, "CONTAINER"); + yy.addContainerBoundary(...$$[$0]); + this.$ = $$[$0]; + break; + case 32: + yy.addDeploymentNode("node", ...$$[$0]); + this.$ = $$[$0]; + break; + case 33: + yy.addDeploymentNode("nodeL", ...$$[$0]); + this.$ = $$[$0]; + break; + case 34: + yy.addDeploymentNode("nodeR", ...$$[$0]); + this.$ = $$[$0]; + break; + case 35: + yy.popBoundaryParseStack(); + break; + case 39: + yy.addPersonOrSystem("person", ...$$[$0]); + this.$ = $$[$0]; + break; + case 40: + yy.addPersonOrSystem("external_person", ...$$[$0]); + this.$ = $$[$0]; + break; + case 41: + yy.addPersonOrSystem("system", ...$$[$0]); + this.$ = $$[$0]; + break; + case 42: + yy.addPersonOrSystem("system_db", ...$$[$0]); + this.$ = $$[$0]; + break; + case 43: + yy.addPersonOrSystem("system_queue", ...$$[$0]); + this.$ = $$[$0]; + break; + case 44: + yy.addPersonOrSystem("external_system", ...$$[$0]); + this.$ = $$[$0]; + break; + case 45: + yy.addPersonOrSystem("external_system_db", ...$$[$0]); + this.$ = $$[$0]; + break; + case 46: + yy.addPersonOrSystem("external_system_queue", ...$$[$0]); + this.$ = $$[$0]; + break; + case 47: + yy.addContainer("container", ...$$[$0]); + this.$ = $$[$0]; + break; + case 48: + yy.addContainer("container_db", ...$$[$0]); + this.$ = $$[$0]; + break; + case 49: + yy.addContainer("container_queue", ...$$[$0]); + this.$ = $$[$0]; + break; + case 50: + yy.addContainer("external_container", ...$$[$0]); + this.$ = $$[$0]; + break; + case 51: + yy.addContainer("external_container_db", ...$$[$0]); + this.$ = $$[$0]; + break; + case 52: + yy.addContainer("external_container_queue", ...$$[$0]); + this.$ = $$[$0]; + break; + case 53: + yy.addComponent("component", ...$$[$0]); + this.$ = $$[$0]; + break; + case 54: + yy.addComponent("component_db", ...$$[$0]); + this.$ = $$[$0]; + break; + case 55: + yy.addComponent("component_queue", ...$$[$0]); + this.$ = $$[$0]; + break; + case 56: + yy.addComponent("external_component", ...$$[$0]); + this.$ = $$[$0]; + break; + case 57: + yy.addComponent("external_component_db", ...$$[$0]); + this.$ = $$[$0]; + break; + case 58: + yy.addComponent("external_component_queue", ...$$[$0]); + this.$ = $$[$0]; + break; + case 60: + yy.addRel("rel", ...$$[$0]); + this.$ = $$[$0]; + break; + case 61: + yy.addRel("birel", ...$$[$0]); + this.$ = $$[$0]; + break; + case 62: + yy.addRel("rel_u", ...$$[$0]); + this.$ = $$[$0]; + break; + case 63: + yy.addRel("rel_d", ...$$[$0]); + this.$ = $$[$0]; + break; + case 64: + yy.addRel("rel_l", ...$$[$0]); + this.$ = $$[$0]; + break; + case 65: + yy.addRel("rel_r", ...$$[$0]); + this.$ = $$[$0]; + break; + case 66: + yy.addRel("rel_b", ...$$[$0]); + this.$ = $$[$0]; + break; + case 67: + $$[$0].splice(0, 1); + yy.addRel("rel", ...$$[$0]); + this.$ = $$[$0]; + break; + case 68: + yy.updateElStyle("update_el_style", ...$$[$0]); + this.$ = $$[$0]; + break; + case 69: + yy.updateRelStyle("update_rel_style", ...$$[$0]); + this.$ = $$[$0]; + break; + case 70: + yy.updateLayoutConfig("update_layout_config", ...$$[$0]); + this.$ = $$[$0]; + break; + case 71: + this.$ = [$$[$0]]; + break; + case 72: + $$[$0].unshift($$[$0 - 1]); + this.$ = $$[$0]; + break; + case 73: + case 75: + this.$ = $$[$0].trim(); + break; + case 74: + let kv = {}; + kv[$$[$0 - 1].trim()] = $$[$0].trim(); + this.$ = kv; + break; + case 76: + this.$ = ""; + break; + } + }, + table: [{ 3: 1, 4: 2, 5: 3, 6: [1, 5], 7: [1, 6], 8: [1, 7], 9: [1, 8], 10: 4, 11: [1, 9], 15: [1, 10], 16: [1, 11], 17: [1, 12], 18: [1, 13] }, { 1: [3] }, { 1: [2, 1] }, { 1: [2, 2] }, { 1: [2, 7] }, { 1: [2, 3] }, { 1: [2, 4] }, { 1: [2, 5] }, { 1: [2, 6] }, { 12: [1, 14] }, { 12: [1, 15] }, { 12: [1, 16] }, { 12: [1, 17] }, { 12: [1, 18] }, { 13: 19, 19: 20, 20: 21, 21: 22, 22: $V0, 23: $V1, 24: $V2, 26: $V3, 28: $V4, 29: 49, 30: 61, 32: 62, 34: $V5, 36: $V6, 37: $V7, 38: $V8, 39: $V9, 40: $Va, 41: $Vb, 43: 23, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi, 51: $Vj, 52: $Vk, 53: $Vl, 54: $Vm, 55: $Vn, 56: $Vo, 57: $Vp, 58: $Vq, 59: $Vr, 60: $Vs, 61: $Vt, 62: $Vu, 63: $Vv, 64: $Vw, 65: $Vx, 66: $Vy, 67: $Vz, 68: $VA, 69: $VB, 70: $VC, 71: $VD, 72: $VE, 73: $VF, 74: $VG }, { 13: 70, 19: 20, 20: 21, 21: 22, 22: $V0, 23: $V1, 24: $V2, 26: $V3, 28: $V4, 29: 49, 30: 61, 32: 62, 34: $V5, 36: $V6, 37: $V7, 38: $V8, 39: $V9, 40: $Va, 41: $Vb, 43: 23, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi, 51: $Vj, 52: $Vk, 53: $Vl, 54: $Vm, 55: $Vn, 56: $Vo, 57: $Vp, 58: $Vq, 59: $Vr, 60: $Vs, 61: $Vt, 62: $Vu, 63: $Vv, 64: $Vw, 65: $Vx, 66: $Vy, 67: $Vz, 68: $VA, 69: $VB, 70: $VC, 71: $VD, 72: $VE, 73: $VF, 74: $VG }, { 13: 71, 19: 20, 20: 21, 21: 22, 22: $V0, 23: $V1, 24: $V2, 26: $V3, 28: $V4, 29: 49, 30: 61, 32: 62, 34: $V5, 36: $V6, 37: $V7, 38: $V8, 39: $V9, 40: $Va, 41: $Vb, 43: 23, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi, 51: $Vj, 52: $Vk, 53: $Vl, 54: $Vm, 55: $Vn, 56: $Vo, 57: $Vp, 58: $Vq, 59: $Vr, 60: $Vs, 61: $Vt, 62: $Vu, 63: $Vv, 64: $Vw, 65: $Vx, 66: $Vy, 67: $Vz, 68: $VA, 69: $VB, 70: $VC, 71: $VD, 72: $VE, 73: $VF, 74: $VG }, { 13: 72, 19: 20, 20: 21, 21: 22, 22: $V0, 23: $V1, 24: $V2, 26: $V3, 28: $V4, 29: 49, 30: 61, 32: 62, 34: $V5, 36: $V6, 37: $V7, 38: $V8, 39: $V9, 40: $Va, 41: $Vb, 43: 23, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi, 51: $Vj, 52: $Vk, 53: $Vl, 54: $Vm, 55: $Vn, 56: $Vo, 57: $Vp, 58: $Vq, 59: $Vr, 60: $Vs, 61: $Vt, 62: $Vu, 63: $Vv, 64: $Vw, 65: $Vx, 66: $Vy, 67: $Vz, 68: $VA, 69: $VB, 70: $VC, 71: $VD, 72: $VE, 73: $VF, 74: $VG }, { 13: 73, 19: 20, 20: 21, 21: 22, 22: $V0, 23: $V1, 24: $V2, 26: $V3, 28: $V4, 29: 49, 30: 61, 32: 62, 34: $V5, 36: $V6, 37: $V7, 38: $V8, 39: $V9, 40: $Va, 41: $Vb, 43: 23, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi, 51: $Vj, 52: $Vk, 53: $Vl, 54: $Vm, 55: $Vn, 56: $Vo, 57: $Vp, 58: $Vq, 59: $Vr, 60: $Vs, 61: $Vt, 62: $Vu, 63: $Vv, 64: $Vw, 65: $Vx, 66: $Vy, 67: $Vz, 68: $VA, 69: $VB, 70: $VC, 71: $VD, 72: $VE, 73: $VF, 74: $VG }, { 14: [1, 74] }, o($VH, [2, 13], { 43: 23, 29: 49, 30: 61, 32: 62, 20: 75, 34: $V5, 36: $V6, 37: $V7, 38: $V8, 39: $V9, 40: $Va, 41: $Vb, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi, 51: $Vj, 52: $Vk, 53: $Vl, 54: $Vm, 55: $Vn, 56: $Vo, 57: $Vp, 58: $Vq, 59: $Vr, 60: $Vs, 61: $Vt, 62: $Vu, 63: $Vv, 64: $Vw, 65: $Vx, 66: $Vy, 67: $Vz, 68: $VA, 69: $VB, 70: $VC, 71: $VD, 72: $VE, 73: $VF, 74: $VG }), o($VH, [2, 14]), o($VI, [2, 16], { 12: [1, 76] }), o($VH, [2, 36], { 12: [1, 77] }), o($VJ, [2, 19]), o($VJ, [2, 20]), { 25: [1, 78] }, { 27: [1, 79] }, o($VJ, [2, 23]), { 35: 80, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 86, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 87, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 88, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 89, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 90, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 91, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 92, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 93, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 94, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 95, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 96, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 97, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 98, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 99, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 100, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 101, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 102, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 103, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 104, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, o($VO, [2, 59]), { 35: 105, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 106, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 107, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 108, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 109, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 110, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 111, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 112, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 113, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 114, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 115, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 20: 116, 29: 49, 30: 61, 32: 62, 34: $V5, 36: $V6, 37: $V7, 38: $V8, 39: $V9, 40: $Va, 41: $Vb, 43: 23, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi, 51: $Vj, 52: $Vk, 53: $Vl, 54: $Vm, 55: $Vn, 56: $Vo, 57: $Vp, 58: $Vq, 59: $Vr, 60: $Vs, 61: $Vt, 62: $Vu, 63: $Vv, 64: $Vw, 65: $Vx, 66: $Vy, 67: $Vz, 68: $VA, 69: $VB, 70: $VC, 71: $VD, 72: $VE, 73: $VF, 74: $VG }, { 12: [1, 118], 33: [1, 117] }, { 35: 119, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 120, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 121, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 122, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 123, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 124, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 35: 125, 75: 81, 76: $VK, 77: $VL, 79: $VM, 80: $VN }, { 14: [1, 126] }, { 14: [1, 127] }, { 14: [1, 128] }, { 14: [1, 129] }, { 1: [2, 8] }, o($VH, [2, 15]), o($VI, [2, 17], { 21: 22, 19: 130, 22: $V0, 23: $V1, 24: $V2, 26: $V3, 28: $V4 }), o($VH, [2, 37], { 19: 20, 20: 21, 21: 22, 43: 23, 29: 49, 30: 61, 32: 62, 13: 131, 22: $V0, 23: $V1, 24: $V2, 26: $V3, 28: $V4, 34: $V5, 36: $V6, 37: $V7, 38: $V8, 39: $V9, 40: $Va, 41: $Vb, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi, 51: $Vj, 52: $Vk, 53: $Vl, 54: $Vm, 55: $Vn, 56: $Vo, 57: $Vp, 58: $Vq, 59: $Vr, 60: $Vs, 61: $Vt, 62: $Vu, 63: $Vv, 64: $Vw, 65: $Vx, 66: $Vy, 67: $Vz, 68: $VA, 69: $VB, 70: $VC, 71: $VD, 72: $VE, 73: $VF, 74: $VG }), o($VJ, [2, 21]), o($VJ, [2, 22]), o($VO, [2, 39]), o($VP, [2, 71], { 75: 81, 35: 132, 76: $VK, 77: $VL, 79: $VM, 80: $VN }), o($VQ, [2, 73]), { 78: [1, 133] }, o($VQ, [2, 75]), o($VQ, [2, 76]), o($VO, [2, 40]), o($VO, [2, 41]), o($VO, [2, 42]), o($VO, [2, 43]), o($VO, [2, 44]), o($VO, [2, 45]), o($VO, [2, 46]), o($VO, [2, 47]), o($VO, [2, 48]), o($VO, [2, 49]), o($VO, [2, 50]), o($VO, [2, 51]), o($VO, [2, 52]), o($VO, [2, 53]), o($VO, [2, 54]), o($VO, [2, 55]), o($VO, [2, 56]), o($VO, [2, 57]), o($VO, [2, 58]), o($VO, [2, 60]), o($VO, [2, 61]), o($VO, [2, 62]), o($VO, [2, 63]), o($VO, [2, 64]), o($VO, [2, 65]), o($VO, [2, 66]), o($VO, [2, 67]), o($VO, [2, 68]), o($VO, [2, 69]), o($VO, [2, 70]), { 31: 134, 42: [1, 135] }, { 12: [1, 136] }, { 33: [1, 137] }, o($VR, [2, 28]), o($VR, [2, 29]), o($VR, [2, 30]), o($VR, [2, 31]), o($VR, [2, 32]), o($VR, [2, 33]), o($VR, [2, 34]), { 1: [2, 9] }, { 1: [2, 10] }, { 1: [2, 11] }, { 1: [2, 12] }, o($VI, [2, 18]), o($VH, [2, 38]), o($VP, [2, 72]), o($VQ, [2, 74]), o($VO, [2, 24]), o($VO, [2, 35]), o($VS, [2, 25]), o($VS, [2, 26], { 12: [1, 138] }), o($VS, [2, 27])], + defaultActions: { 2: [2, 1], 3: [2, 2], 4: [2, 7], 5: [2, 3], 6: [2, 4], 7: [2, 5], 8: [2, 6], 74: [2, 8], 126: [2, 9], 127: [2, 10], 128: [2, 11], 129: [2, 12] }, + parseError: function parseError(str2, hash) { + if (hash.recoverable) { + this.trace(str2); + } else { + var error = new Error(str2); + error.hash = hash; + throw error; + } + }, + parse: function parse2(input) { + var self2 = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex2() { + var token2; + token2 = tstack.pop() || lexer2.lex() || EOF; + if (typeof token2 !== "number") { + if (token2 instanceof Array) { + tstack = token2; + token2 = tstack.pop(); + } + token2 = self2.symbols_[token2] || token2; + } + return token2; + } + var symbol, state2, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state2 = stack[stack.length - 1]; + if (this.defaultActions[state2]) { + action = this.defaultActions[state2]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex2(); + } + action = table[state2] && table[state2][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state2]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state2 + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str2, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str2, hash); + } else { + throw new Error(str2); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch2 = this._input[0]; + this.yytext += ch2; + this.yyleng++; + this.offset++; + this.match += ch2; + this.matched += ch2; + var lines = ch2.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch2; + }, + // unshifts one char (or a string) into the input + unput: function(ch2) { + var len = ch2.length; + var lines = ch2.split(/(?:\r\n?|\n)/g); + this._input = ch2 + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next2 = this.match; + if (next2.length < 20) { + next2 += this._input.substr(0, 20 - next2.length); + } + return (next2.substr(0, 20) + (next2.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c2 = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c2 + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token2, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token2 = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token2) { + return token2; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token2, match, tempMatch, index2; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i2 = 0; i2 < rules.length; i2++) { + tempMatch = this._input.match(this.rules[rules[i2]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index2 = i2; + if (this.options.backtrack_lexer) { + token2 = this.test_match(tempMatch, rules[i2]); + if (token2 !== false) { + return token2; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token2 = this.test_match(match, rules[index2]); + if (token2 !== false) { + return token2; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex2() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: {}, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + return 6; + case 1: + return 7; + case 2: + return 8; + case 3: + return 9; + case 4: + return 22; + case 5: + return 23; + case 6: + this.begin("acc_title"); + return 24; + case 7: + this.popState(); + return "acc_title_value"; + case 8: + this.begin("acc_descr"); + return 26; + case 9: + this.popState(); + return "acc_descr_value"; + case 10: + this.begin("acc_descr_multiline"); + break; + case 11: + this.popState(); + break; + case 12: + return "acc_descr_multiline_value"; + case 13: + break; + case 14: + c; + break; + case 15: + return 12; + case 16: + break; + case 17: + return 11; + case 18: + return 15; + case 19: + return 16; + case 20: + return 17; + case 21: + return 18; + case 22: + this.begin("person_ext"); + return 45; + case 23: + this.begin("person"); + return 44; + case 24: + this.begin("system_ext_queue"); + return 51; + case 25: + this.begin("system_ext_db"); + return 50; + case 26: + this.begin("system_ext"); + return 49; + case 27: + this.begin("system_queue"); + return 48; + case 28: + this.begin("system_db"); + return 47; + case 29: + this.begin("system"); + return 46; + case 30: + this.begin("boundary"); + return 37; + case 31: + this.begin("enterprise_boundary"); + return 34; + case 32: + this.begin("system_boundary"); + return 36; + case 33: + this.begin("container_ext_queue"); + return 57; + case 34: + this.begin("container_ext_db"); + return 56; + case 35: + this.begin("container_ext"); + return 55; + case 36: + this.begin("container_queue"); + return 54; + case 37: + this.begin("container_db"); + return 53; + case 38: + this.begin("container"); + return 52; + case 39: + this.begin("container_boundary"); + return 38; + case 40: + this.begin("component_ext_queue"); + return 63; + case 41: + this.begin("component_ext_db"); + return 62; + case 42: + this.begin("component_ext"); + return 61; + case 43: + this.begin("component_queue"); + return 60; + case 44: + this.begin("component_db"); + return 59; + case 45: + this.begin("component"); + return 58; + case 46: + this.begin("node"); + return 39; + case 47: + this.begin("node"); + return 39; + case 48: + this.begin("node_l"); + return 40; + case 49: + this.begin("node_r"); + return 41; + case 50: + this.begin("rel"); + return 64; + case 51: + this.begin("birel"); + return 65; + case 52: + this.begin("rel_u"); + return 66; + case 53: + this.begin("rel_u"); + return 66; + case 54: + this.begin("rel_d"); + return 67; + case 55: + this.begin("rel_d"); + return 67; + case 56: + this.begin("rel_l"); + return 68; + case 57: + this.begin("rel_l"); + return 68; + case 58: + this.begin("rel_r"); + return 69; + case 59: + this.begin("rel_r"); + return 69; + case 60: + this.begin("rel_b"); + return 70; + case 61: + this.begin("rel_index"); + return 71; + case 62: + this.begin("update_el_style"); + return 72; + case 63: + this.begin("update_rel_style"); + return 73; + case 64: + this.begin("update_layout_config"); + return 74; + case 65: + return "EOF_IN_STRUCT"; + case 66: + this.begin("attribute"); + return "ATTRIBUTE_EMPTY"; + case 67: + this.begin("attribute"); + break; + case 68: + this.popState(); + this.popState(); + break; + case 69: + return 80; + case 70: + break; + case 71: + return 80; + case 72: + this.begin("string"); + break; + case 73: + this.popState(); + break; + case 74: + return "STR"; + case 75: + this.begin("string_kv"); + break; + case 76: + this.begin("string_kv_key"); + return "STR_KEY"; + case 77: + this.popState(); + this.begin("string_kv_value"); + break; + case 78: + return "STR_VALUE"; + case 79: + this.popState(); + this.popState(); + break; + case 80: + return "STR"; + case 81: + return "LBRACE"; + case 82: + return "RBRACE"; + case 83: + return "SPACE"; + case 84: + return "EOL"; + case 85: + return 14; + } + }, + rules: [/^(?:.*direction\s+TB[^\n]*)/, /^(?:.*direction\s+BT[^\n]*)/, /^(?:.*direction\s+RL[^\n]*)/, /^(?:.*direction\s+LR[^\n]*)/, /^(?:title\s[^#\n;]+)/, /^(?:accDescription\s[^#\n;]+)/, /^(?:accTitle\s*:\s*)/, /^(?:(?!\n||)*[^\n]*)/, /^(?:accDescr\s*:\s*)/, /^(?:(?!\n||)*[^\n]*)/, /^(?:accDescr\s*\{\s*)/, /^(?:[\}])/, /^(?:[^\}]*)/, /^(?:%%(?!\{)*[^\n]*(\r?\n?)+)/, /^(?:%%[^\n]*(\r?\n)*)/, /^(?:\s*(\r?\n)+)/, /^(?:\s+)/, /^(?:C4Context\b)/, /^(?:C4Container\b)/, /^(?:C4Component\b)/, /^(?:C4Dynamic\b)/, /^(?:C4Deployment\b)/, /^(?:Person_Ext\b)/, /^(?:Person\b)/, /^(?:SystemQueue_Ext\b)/, /^(?:SystemDb_Ext\b)/, /^(?:System_Ext\b)/, /^(?:SystemQueue\b)/, /^(?:SystemDb\b)/, /^(?:System\b)/, /^(?:Boundary\b)/, /^(?:Enterprise_Boundary\b)/, /^(?:System_Boundary\b)/, /^(?:ContainerQueue_Ext\b)/, /^(?:ContainerDb_Ext\b)/, /^(?:Container_Ext\b)/, /^(?:ContainerQueue\b)/, /^(?:ContainerDb\b)/, /^(?:Container\b)/, /^(?:Container_Boundary\b)/, /^(?:ComponentQueue_Ext\b)/, /^(?:ComponentDb_Ext\b)/, /^(?:Component_Ext\b)/, /^(?:ComponentQueue\b)/, /^(?:ComponentDb\b)/, /^(?:Component\b)/, /^(?:Deployment_Node\b)/, /^(?:Node\b)/, /^(?:Node_L\b)/, /^(?:Node_R\b)/, /^(?:Rel\b)/, /^(?:BiRel\b)/, /^(?:Rel_Up\b)/, /^(?:Rel_U\b)/, /^(?:Rel_Down\b)/, /^(?:Rel_D\b)/, /^(?:Rel_Left\b)/, /^(?:Rel_L\b)/, /^(?:Rel_Right\b)/, /^(?:Rel_R\b)/, /^(?:Rel_Back\b)/, /^(?:RelIndex\b)/, /^(?:UpdateElementStyle\b)/, /^(?:UpdateRelStyle\b)/, /^(?:UpdateLayoutConfig\b)/, /^(?:$)/, /^(?:[(][ ]*[,])/, /^(?:[(])/, /^(?:[)])/, /^(?:,,)/, /^(?:,)/, /^(?:[ ]*["]["])/, /^(?:[ ]*["])/, /^(?:["])/, /^(?:[^"]*)/, /^(?:[ ]*[\$])/, /^(?:[^=]*)/, /^(?:[=][ ]*["])/, /^(?:[^"]+)/, /^(?:["])/, /^(?:[^,]+)/, /^(?:\{)/, /^(?:\})/, /^(?:[\s]+)/, /^(?:[\n\r]+)/, /^(?:$)/], + conditions: { "acc_descr_multiline": { "rules": [11, 12], "inclusive": false }, "acc_descr": { "rules": [9], "inclusive": false }, "acc_title": { "rules": [7], "inclusive": false }, "string_kv_value": { "rules": [78, 79], "inclusive": false }, "string_kv_key": { "rules": [77], "inclusive": false }, "string_kv": { "rules": [76], "inclusive": false }, "string": { "rules": [73, 74], "inclusive": false }, "attribute": { "rules": [68, 69, 70, 71, 72, 75, 80], "inclusive": false }, "update_layout_config": { "rules": [65, 66, 67, 68], "inclusive": false }, "update_rel_style": { "rules": [65, 66, 67, 68], "inclusive": false }, "update_el_style": { "rules": [65, 66, 67, 68], "inclusive": false }, "rel_b": { "rules": [65, 66, 67, 68], "inclusive": false }, "rel_r": { "rules": [65, 66, 67, 68], "inclusive": false }, "rel_l": { "rules": [65, 66, 67, 68], "inclusive": false }, "rel_d": { "rules": [65, 66, 67, 68], "inclusive": false }, "rel_u": { "rules": [65, 66, 67, 68], "inclusive": false }, "rel_bi": { "rules": [], "inclusive": false }, "rel": { "rules": [65, 66, 67, 68], "inclusive": false }, "node_r": { "rules": [65, 66, 67, 68], "inclusive": false }, "node_l": { "rules": [65, 66, 67, 68], "inclusive": false }, "node": { "rules": [65, 66, 67, 68], "inclusive": false }, "index": { "rules": [], "inclusive": false }, "rel_index": { "rules": [65, 66, 67, 68], "inclusive": false }, "component_ext_queue": { "rules": [], "inclusive": false }, "component_ext_db": { "rules": [65, 66, 67, 68], "inclusive": false }, "component_ext": { "rules": [65, 66, 67, 68], "inclusive": false }, "component_queue": { "rules": [65, 66, 67, 68], "inclusive": false }, "component_db": { "rules": [65, 66, 67, 68], "inclusive": false }, "component": { "rules": [65, 66, 67, 68], "inclusive": false }, "container_boundary": { "rules": [65, 66, 67, 68], "inclusive": false }, "container_ext_queue": { "rules": [65, 66, 67, 68], "inclusive": false }, "container_ext_db": { "rules": [65, 66, 67, 68], "inclusive": false }, "container_ext": { "rules": [65, 66, 67, 68], "inclusive": false }, "container_queue": { "rules": [65, 66, 67, 68], "inclusive": false }, "container_db": { "rules": [65, 66, 67, 68], "inclusive": false }, "container": { "rules": [65, 66, 67, 68], "inclusive": false }, "birel": { "rules": [65, 66, 67, 68], "inclusive": false }, "system_boundary": { "rules": [65, 66, 67, 68], "inclusive": false }, "enterprise_boundary": { "rules": [65, 66, 67, 68], "inclusive": false }, "boundary": { "rules": [65, 66, 67, 68], "inclusive": false }, "system_ext_queue": { "rules": [65, 66, 67, 68], "inclusive": false }, "system_ext_db": { "rules": [65, 66, 67, 68], "inclusive": false }, "system_ext": { "rules": [65, 66, 67, 68], "inclusive": false }, "system_queue": { "rules": [65, 66, 67, 68], "inclusive": false }, "system_db": { "rules": [65, 66, 67, 68], "inclusive": false }, "system": { "rules": [65, 66, 67, 68], "inclusive": false }, "person_ext": { "rules": [65, 66, 67, 68], "inclusive": false }, "person": { "rules": [65, 66, 67, 68], "inclusive": false }, "INITIAL": { "rules": [0, 1, 2, 3, 4, 5, 6, 8, 10, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 81, 82, 83, 84, 85], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser2() { + this.yy = {}; + } + Parser2.prototype = parser2; + parser2.Parser = Parser2; + return new Parser2(); + }(); + parser$v.parser = parser$v; + const parser$w = parser$v; + let c4ShapeArray = []; + let boundaryParseStack = [""]; + let currentBoundaryParse = "global"; + let parentBoundaryParse = ""; + let boundaries = [ + { + alias: "global", + label: { text: "global" }, + type: { text: "global" }, + tags: null, + link: null, + parentBoundary: "" + } + ]; + let rels = []; + let title = ""; + let wrapEnabled = false; + let c4ShapeInRow$1 = 4; + let c4BoundaryInRow$1 = 2; + var c4Type; + const getC4Type = function() { + return c4Type; + }; + const setC4Type = function(c4TypeParam) { + let sanitizedText = sanitizeText$6(c4TypeParam, getConfig$1()); + c4Type = sanitizedText; + }; + const addRel = function(type2, from2, to, label, techn, descr, sprite, tags2, link2) { + if (type2 === void 0 || type2 === null || from2 === void 0 || from2 === null || to === void 0 || to === null || label === void 0 || label === null) { + return; + } + let rel2 = {}; + const old = rels.find((rel3) => rel3.from === from2 && rel3.to === to); + if (old) { + rel2 = old; + } else { + rels.push(rel2); + } + rel2.type = type2; + rel2.from = from2; + rel2.to = to; + rel2.label = { text: label }; + if (techn === void 0 || techn === null) { + rel2.techn = { text: "" }; + } else { + if (typeof techn === "object") { + let [key, value2] = Object.entries(techn)[0]; + rel2[key] = { text: value2 }; + } else { + rel2.techn = { text: techn }; + } + } + if (descr === void 0 || descr === null) { + rel2.descr = { text: "" }; + } else { + if (typeof descr === "object") { + let [key, value2] = Object.entries(descr)[0]; + rel2[key] = { text: value2 }; + } else { + rel2.descr = { text: descr }; + } + } + if (typeof sprite === "object") { + let [key, value2] = Object.entries(sprite)[0]; + rel2[key] = value2; + } else { + rel2.sprite = sprite; + } + if (typeof tags2 === "object") { + let [key, value2] = Object.entries(tags2)[0]; + rel2[key] = value2; + } else { + rel2.tags = tags2; + } + if (typeof link2 === "object") { + let [key, value2] = Object.entries(link2)[0]; + rel2[key] = value2; + } else { + rel2.link = link2; + } + rel2.wrap = autoWrap$1(); + }; + const addPersonOrSystem = function(typeC4Shape, alias, label, descr, sprite, tags2, link2) { + if (alias === null || label === null) { + return; + } + let personOrSystem = {}; + const old = c4ShapeArray.find((personOrSystem2) => personOrSystem2.alias === alias); + if (old && alias === old.alias) { + personOrSystem = old; + } else { + personOrSystem.alias = alias; + c4ShapeArray.push(personOrSystem); + } + if (label === void 0 || label === null) { + personOrSystem.label = { text: "" }; + } else { + personOrSystem.label = { text: label }; + } + if (descr === void 0 || descr === null) { + personOrSystem.descr = { text: "" }; + } else { + if (typeof descr === "object") { + let [key, value2] = Object.entries(descr)[0]; + personOrSystem[key] = { text: value2 }; + } else { + personOrSystem.descr = { text: descr }; + } + } + if (typeof sprite === "object") { + let [key, value2] = Object.entries(sprite)[0]; + personOrSystem[key] = value2; + } else { + personOrSystem.sprite = sprite; + } + if (typeof tags2 === "object") { + let [key, value2] = Object.entries(tags2)[0]; + personOrSystem[key] = value2; + } else { + personOrSystem.tags = tags2; + } + if (typeof link2 === "object") { + let [key, value2] = Object.entries(link2)[0]; + personOrSystem[key] = value2; + } else { + personOrSystem.link = link2; + } + personOrSystem.typeC4Shape = { text: typeC4Shape }; + personOrSystem.parentBoundary = currentBoundaryParse; + personOrSystem.wrap = autoWrap$1(); + }; + const addContainer = function(typeC4Shape, alias, label, techn, descr, sprite, tags2, link2) { + if (alias === null || label === null) { + return; + } + let container = {}; + const old = c4ShapeArray.find((container2) => container2.alias === alias); + if (old && alias === old.alias) { + container = old; + } else { + container.alias = alias; + c4ShapeArray.push(container); + } + if (label === void 0 || label === null) { + container.label = { text: "" }; + } else { + container.label = { text: label }; + } + if (techn === void 0 || techn === null) { + container.techn = { text: "" }; + } else { + if (typeof techn === "object") { + let [key, value2] = Object.entries(techn)[0]; + container[key] = { text: value2 }; + } else { + container.techn = { text: techn }; + } + } + if (descr === void 0 || descr === null) { + container.descr = { text: "" }; + } else { + if (typeof descr === "object") { + let [key, value2] = Object.entries(descr)[0]; + container[key] = { text: value2 }; + } else { + container.descr = { text: descr }; + } + } + if (typeof sprite === "object") { + let [key, value2] = Object.entries(sprite)[0]; + container[key] = value2; + } else { + container.sprite = sprite; + } + if (typeof tags2 === "object") { + let [key, value2] = Object.entries(tags2)[0]; + container[key] = value2; + } else { + container.tags = tags2; + } + if (typeof link2 === "object") { + let [key, value2] = Object.entries(link2)[0]; + container[key] = value2; + } else { + container.link = link2; + } + container.wrap = autoWrap$1(); + container.typeC4Shape = { text: typeC4Shape }; + container.parentBoundary = currentBoundaryParse; + }; + const addComponent = function(typeC4Shape, alias, label, techn, descr, sprite, tags2, link2) { + if (alias === null || label === null) { + return; + } + let component = {}; + const old = c4ShapeArray.find((component2) => component2.alias === alias); + if (old && alias === old.alias) { + component = old; + } else { + component.alias = alias; + c4ShapeArray.push(component); + } + if (label === void 0 || label === null) { + component.label = { text: "" }; + } else { + component.label = { text: label }; + } + if (techn === void 0 || techn === null) { + component.techn = { text: "" }; + } else { + if (typeof techn === "object") { + let [key, value2] = Object.entries(techn)[0]; + component[key] = { text: value2 }; + } else { + component.techn = { text: techn }; + } + } + if (descr === void 0 || descr === null) { + component.descr = { text: "" }; + } else { + if (typeof descr === "object") { + let [key, value2] = Object.entries(descr)[0]; + component[key] = { text: value2 }; + } else { + component.descr = { text: descr }; + } + } + if (typeof sprite === "object") { + let [key, value2] = Object.entries(sprite)[0]; + component[key] = value2; + } else { + component.sprite = sprite; + } + if (typeof tags2 === "object") { + let [key, value2] = Object.entries(tags2)[0]; + component[key] = value2; + } else { + component.tags = tags2; + } + if (typeof link2 === "object") { + let [key, value2] = Object.entries(link2)[0]; + component[key] = value2; + } else { + component.link = link2; + } + component.wrap = autoWrap$1(); + component.typeC4Shape = { text: typeC4Shape }; + component.parentBoundary = currentBoundaryParse; + }; + const addPersonOrSystemBoundary = function(alias, label, type2, tags2, link2) { + if (alias === null || label === null) { + return; + } + let boundary = {}; + const old = boundaries.find((boundary2) => boundary2.alias === alias); + if (old && alias === old.alias) { + boundary = old; + } else { + boundary.alias = alias; + boundaries.push(boundary); + } + if (label === void 0 || label === null) { + boundary.label = { text: "" }; + } else { + boundary.label = { text: label }; + } + if (type2 === void 0 || type2 === null) { + boundary.type = { text: "system" }; + } else { + if (typeof type2 === "object") { + let [key, value2] = Object.entries(type2)[0]; + boundary[key] = { text: value2 }; + } else { + boundary.type = { text: type2 }; + } + } + if (typeof tags2 === "object") { + let [key, value2] = Object.entries(tags2)[0]; + boundary[key] = value2; + } else { + boundary.tags = tags2; + } + if (typeof link2 === "object") { + let [key, value2] = Object.entries(link2)[0]; + boundary[key] = value2; + } else { + boundary.link = link2; + } + boundary.parentBoundary = currentBoundaryParse; + boundary.wrap = autoWrap$1(); + parentBoundaryParse = currentBoundaryParse; + currentBoundaryParse = alias; + boundaryParseStack.push(parentBoundaryParse); + }; + const addContainerBoundary = function(alias, label, type2, tags2, link2) { + if (alias === null || label === null) { + return; + } + let boundary = {}; + const old = boundaries.find((boundary2) => boundary2.alias === alias); + if (old && alias === old.alias) { + boundary = old; + } else { + boundary.alias = alias; + boundaries.push(boundary); + } + if (label === void 0 || label === null) { + boundary.label = { text: "" }; + } else { + boundary.label = { text: label }; + } + if (type2 === void 0 || type2 === null) { + boundary.type = { text: "container" }; + } else { + if (typeof type2 === "object") { + let [key, value2] = Object.entries(type2)[0]; + boundary[key] = { text: value2 }; + } else { + boundary.type = { text: type2 }; + } + } + if (typeof tags2 === "object") { + let [key, value2] = Object.entries(tags2)[0]; + boundary[key] = value2; + } else { + boundary.tags = tags2; + } + if (typeof link2 === "object") { + let [key, value2] = Object.entries(link2)[0]; + boundary[key] = value2; + } else { + boundary.link = link2; + } + boundary.parentBoundary = currentBoundaryParse; + boundary.wrap = autoWrap$1(); + parentBoundaryParse = currentBoundaryParse; + currentBoundaryParse = alias; + boundaryParseStack.push(parentBoundaryParse); + }; + const addDeploymentNode = function(nodeType2, alias, label, type2, descr, sprite, tags2, link2) { + if (alias === null || label === null) { + return; + } + let boundary = {}; + const old = boundaries.find((boundary2) => boundary2.alias === alias); + if (old && alias === old.alias) { + boundary = old; + } else { + boundary.alias = alias; + boundaries.push(boundary); + } + if (label === void 0 || label === null) { + boundary.label = { text: "" }; + } else { + boundary.label = { text: label }; + } + if (type2 === void 0 || type2 === null) { + boundary.type = { text: "node" }; + } else { + if (typeof type2 === "object") { + let [key, value2] = Object.entries(type2)[0]; + boundary[key] = { text: value2 }; + } else { + boundary.type = { text: type2 }; + } + } + if (descr === void 0 || descr === null) { + boundary.descr = { text: "" }; + } else { + if (typeof descr === "object") { + let [key, value2] = Object.entries(descr)[0]; + boundary[key] = { text: value2 }; + } else { + boundary.descr = { text: descr }; + } + } + if (typeof tags2 === "object") { + let [key, value2] = Object.entries(tags2)[0]; + boundary[key] = value2; + } else { + boundary.tags = tags2; + } + if (typeof link2 === "object") { + let [key, value2] = Object.entries(link2)[0]; + boundary[key] = value2; + } else { + boundary.link = link2; + } + boundary.nodeType = nodeType2; + boundary.parentBoundary = currentBoundaryParse; + boundary.wrap = autoWrap$1(); + parentBoundaryParse = currentBoundaryParse; + currentBoundaryParse = alias; + boundaryParseStack.push(parentBoundaryParse); + }; + const popBoundaryParseStack = function() { + currentBoundaryParse = parentBoundaryParse; + boundaryParseStack.pop(); + parentBoundaryParse = boundaryParseStack.pop(); + boundaryParseStack.push(parentBoundaryParse); + }; + const updateElStyle = function(typeC4Shape, elementName, bgColor, fontColor, borderColor, shadowing, shape, sprite, techn, legendText, legendSprite) { + let old = c4ShapeArray.find((element2) => element2.alias === elementName); + if (old === void 0) { + old = boundaries.find((element2) => element2.alias === elementName); + if (old === void 0) { + return; + } + } + if (bgColor !== void 0 && bgColor !== null) { + if (typeof bgColor === "object") { + let [key, value2] = Object.entries(bgColor)[0]; + old[key] = value2; + } else { + old.bgColor = bgColor; + } + } + if (fontColor !== void 0 && fontColor !== null) { + if (typeof fontColor === "object") { + let [key, value2] = Object.entries(fontColor)[0]; + old[key] = value2; + } else { + old.fontColor = fontColor; + } + } + if (borderColor !== void 0 && borderColor !== null) { + if (typeof borderColor === "object") { + let [key, value2] = Object.entries(borderColor)[0]; + old[key] = value2; + } else { + old.borderColor = borderColor; + } + } + if (shadowing !== void 0 && shadowing !== null) { + if (typeof shadowing === "object") { + let [key, value2] = Object.entries(shadowing)[0]; + old[key] = value2; + } else { + old.shadowing = shadowing; + } + } + if (shape !== void 0 && shape !== null) { + if (typeof shape === "object") { + let [key, value2] = Object.entries(shape)[0]; + old[key] = value2; + } else { + old.shape = shape; + } + } + if (sprite !== void 0 && sprite !== null) { + if (typeof sprite === "object") { + let [key, value2] = Object.entries(sprite)[0]; + old[key] = value2; + } else { + old.sprite = sprite; + } + } + if (techn !== void 0 && techn !== null) { + if (typeof techn === "object") { + let [key, value2] = Object.entries(techn)[0]; + old[key] = value2; + } else { + old.techn = techn; + } + } + if (legendText !== void 0 && legendText !== null) { + if (typeof legendText === "object") { + let [key, value2] = Object.entries(legendText)[0]; + old[key] = value2; + } else { + old.legendText = legendText; + } + } + if (legendSprite !== void 0 && legendSprite !== null) { + if (typeof legendSprite === "object") { + let [key, value2] = Object.entries(legendSprite)[0]; + old[key] = value2; + } else { + old.legendSprite = legendSprite; + } + } + }; + const updateRelStyle = function(typeC4Shape, from2, to, textColor, lineColor, offsetX, offsetY) { + const old = rels.find((rel2) => rel2.from === from2 && rel2.to === to); + if (old === void 0) { + return; + } + if (textColor !== void 0 && textColor !== null) { + if (typeof textColor === "object") { + let [key, value2] = Object.entries(textColor)[0]; + old[key] = value2; + } else { + old.textColor = textColor; + } + } + if (lineColor !== void 0 && lineColor !== null) { + if (typeof lineColor === "object") { + let [key, value2] = Object.entries(lineColor)[0]; + old[key] = value2; + } else { + old.lineColor = lineColor; + } + } + if (offsetX !== void 0 && offsetX !== null) { + if (typeof offsetX === "object") { + let [key, value2] = Object.entries(offsetX)[0]; + old[key] = parseInt(value2); + } else { + old.offsetX = parseInt(offsetX); + } + } + if (offsetY !== void 0 && offsetY !== null) { + if (typeof offsetY === "object") { + let [key, value2] = Object.entries(offsetY)[0]; + old[key] = parseInt(value2); + } else { + old.offsetY = parseInt(offsetY); + } + } + }; + const updateLayoutConfig = function(typeC4Shape, c4ShapeInRowParam, c4BoundaryInRowParam) { + let c4ShapeInRowValue = c4ShapeInRow$1; + let c4BoundaryInRowValue = c4BoundaryInRow$1; + if (typeof c4ShapeInRowParam === "object") { + const value2 = Object.values(c4ShapeInRowParam)[0]; + c4ShapeInRowValue = parseInt(value2); + } else { + c4ShapeInRowValue = parseInt(c4ShapeInRowParam); + } + if (typeof c4BoundaryInRowParam === "object") { + const value2 = Object.values(c4BoundaryInRowParam)[0]; + c4BoundaryInRowValue = parseInt(value2); + } else { + c4BoundaryInRowValue = parseInt(c4BoundaryInRowParam); + } + if (c4ShapeInRowValue >= 1) { + c4ShapeInRow$1 = c4ShapeInRowValue; + } + if (c4BoundaryInRowValue >= 1) { + c4BoundaryInRow$1 = c4BoundaryInRowValue; + } + }; + const getC4ShapeInRow = function() { + return c4ShapeInRow$1; + }; + const getC4BoundaryInRow = function() { + return c4BoundaryInRow$1; + }; + const getCurrentBoundaryParse = function() { + return currentBoundaryParse; + }; + const getParentBoundaryParse = function() { + return parentBoundaryParse; + }; + const getC4ShapeArray = function(parentBoundary) { + if (parentBoundary === void 0 || parentBoundary === null) { + return c4ShapeArray; + } else { + return c4ShapeArray.filter((personOrSystem) => { + return personOrSystem.parentBoundary === parentBoundary; + }); + } + }; + const getC4Shape = function(alias) { + return c4ShapeArray.find((personOrSystem) => personOrSystem.alias === alias); + }; + const getC4ShapeKeys = function(parentBoundary) { + return Object.keys(getC4ShapeArray(parentBoundary)); + }; + const getBoundaries = function(parentBoundary) { + if (parentBoundary === void 0 || parentBoundary === null) { + return boundaries; + } else { + return boundaries.filter((boundary) => boundary.parentBoundary === parentBoundary); + } + }; + const getBoundarys = getBoundaries; + const getRels = function() { + return rels; + }; + const getTitle = function() { + return title; + }; + const setWrap$1 = function(wrapSetting) { + wrapEnabled = wrapSetting; + }; + const autoWrap$1 = function() { + return wrapEnabled; + }; + const clear$m = function() { + c4ShapeArray = []; + boundaries = [ + { + alias: "global", + label: { text: "global" }, + type: { text: "global" }, + tags: null, + link: null, + parentBoundary: "" + } + ]; + parentBoundaryParse = ""; + currentBoundaryParse = "global"; + boundaryParseStack = [""]; + rels = []; + boundaryParseStack = [""]; + title = ""; + wrapEnabled = false; + c4ShapeInRow$1 = 4; + c4BoundaryInRow$1 = 2; + }; + const LINETYPE$1 = { + 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 + }; + const ARROWTYPE$1 = { + FILLED: 0, + OPEN: 1 + }; + const PLACEMENT$1 = { + LEFTOF: 0, + RIGHTOF: 1, + OVER: 2 + }; + const setTitle = function(txt) { + let sanitizedText = sanitizeText$6(txt, getConfig$1()); + title = sanitizedText; + }; + const db$g = { + addPersonOrSystem, + addPersonOrSystemBoundary, + addContainer, + addContainerBoundary, + addComponent, + addDeploymentNode, + popBoundaryParseStack, + addRel, + updateElStyle, + updateRelStyle, + updateLayoutConfig, + autoWrap: autoWrap$1, + setWrap: setWrap$1, + getC4ShapeArray, + getC4Shape, + getC4ShapeKeys, + getBoundaries, + getBoundarys, + getCurrentBoundaryParse, + getParentBoundaryParse, + getRels, + getTitle, + getC4Type, + getC4ShapeInRow, + getC4BoundaryInRow, + setAccTitle, + getAccTitle, + getAccDescription, + setAccDescription, + getConfig: () => getConfig$1().c4, + clear: clear$m, + LINETYPE: LINETYPE$1, + ARROWTYPE: ARROWTYPE$1, + PLACEMENT: PLACEMENT$1, + setTitle, + setC4Type + // apply, + }; + const drawRect$4 = (element2, rectData) => { + const rectElement = element2.append("rect"); + rectElement.attr("x", rectData.x); + rectElement.attr("y", rectData.y); + rectElement.attr("fill", rectData.fill); + rectElement.attr("stroke", rectData.stroke); + rectElement.attr("width", rectData.width); + rectElement.attr("height", rectData.height); + if (rectData.name) { + rectElement.attr("name", rectData.name); + } + rectData.rx !== void 0 && rectElement.attr("rx", rectData.rx); + rectData.ry !== void 0 && rectElement.attr("ry", rectData.ry); + if (rectData.attrs !== void 0) { + for (const attrKey in rectData.attrs) { + rectElement.attr(attrKey, rectData.attrs[attrKey]); + } + } + rectData.class !== void 0 && rectElement.attr("class", rectData.class); + return rectElement; + }; + const drawBackgroundRect$3 = (element2, bounds2) => { + const rectData = { + x: bounds2.startx, + y: bounds2.starty, + width: bounds2.stopx - bounds2.startx, + height: bounds2.stopy - bounds2.starty, + fill: bounds2.fill, + stroke: bounds2.stroke, + class: "rect" + }; + const rectElement = drawRect$4(element2, rectData); + rectElement.lower(); + }; + const drawText$4 = (element2, textData) => { + const nText = textData.text.replace(lineBreakRegex, " "); + const textElem = element2.append("text"); + textElem.attr("x", textData.x); + textElem.attr("y", textData.y); + textElem.attr("class", "legend"); + textElem.style("text-anchor", textData.anchor); + textData.class !== void 0 && textElem.attr("class", textData.class); + const tspan = textElem.append("tspan"); + tspan.attr("x", textData.x + textData.textMargin * 2); + tspan.text(nText); + return textElem; + }; + const drawImage$1 = (elem, x2, y2, link2) => { + const imageElement = elem.append("image"); + imageElement.attr("x", x2); + imageElement.attr("y", y2); + const sanitizedLink = dist.sanitizeUrl(link2); + imageElement.attr("xlink:href", sanitizedLink); + }; + const drawEmbeddedImage = (element2, x2, y2, link2) => { + const imageElement = element2.append("use"); + imageElement.attr("x", x2); + imageElement.attr("y", y2); + const sanitizedLink = dist.sanitizeUrl(link2); + imageElement.attr("xlink:href", `#${sanitizedLink}`); + }; + const getNoteRect$2 = () => { + const noteRectData = { + x: 0, + y: 0, + width: 100, + height: 100, + fill: "#EDF2AE", + stroke: "#666", + anchor: "start", + rx: 0, + ry: 0 + }; + return noteRectData; + }; + const getTextObj$2 = () => { + const testObject = { + x: 0, + y: 0, + width: 100, + height: 100, + "text-anchor": "start", + style: "#666", + textMargin: 0, + rx: 0, + ry: 0, + tspan: true + }; + return testObject; + }; + const drawRect$3 = function(elem, rectData) { + return drawRect$4(elem, rectData); + }; + const drawImage = function(elem, width2, height, x2, y2, link2) { + const imageElem = elem.append("image"); + imageElem.attr("width", width2); + imageElem.attr("height", height); + imageElem.attr("x", x2); + imageElem.attr("y", y2); + let sanitizedLink = link2.startsWith("data:image/png;base64") ? link2 : dist.sanitizeUrl(link2); + imageElem.attr("xlink:href", sanitizedLink); + }; + const drawRels$1 = (elem, rels2, conf2) => { + const relsElem = elem.append("g"); + let i2 = 0; + for (let rel2 of rels2) { + let textColor = rel2.textColor ? rel2.textColor : "#444444"; + let strokeColor = rel2.lineColor ? rel2.lineColor : "#444444"; + let offsetX = rel2.offsetX ? parseInt(rel2.offsetX) : 0; + let offsetY = rel2.offsetY ? parseInt(rel2.offsetY) : 0; + let url = ""; + if (i2 === 0) { + let line2 = relsElem.append("line"); + line2.attr("x1", rel2.startPoint.x); + line2.attr("y1", rel2.startPoint.y); + line2.attr("x2", rel2.endPoint.x); + line2.attr("y2", rel2.endPoint.y); + line2.attr("stroke-width", "1"); + line2.attr("stroke", strokeColor); + line2.style("fill", "none"); + if (rel2.type !== "rel_b") { + line2.attr("marker-end", "url(" + url + "#arrowhead)"); + } + if (rel2.type === "birel" || rel2.type === "rel_b") { + line2.attr("marker-start", "url(" + url + "#arrowend)"); + } + i2 = -1; + } else { + let line2 = relsElem.append("path"); + line2.attr("fill", "none").attr("stroke-width", "1").attr("stroke", strokeColor).attr( + "d", + "Mstartx,starty Qcontrolx,controly stopx,stopy ".replaceAll("startx", rel2.startPoint.x).replaceAll("starty", rel2.startPoint.y).replaceAll( + "controlx", + rel2.startPoint.x + (rel2.endPoint.x - rel2.startPoint.x) / 2 - (rel2.endPoint.x - rel2.startPoint.x) / 4 + ).replaceAll("controly", rel2.startPoint.y + (rel2.endPoint.y - rel2.startPoint.y) / 2).replaceAll("stopx", rel2.endPoint.x).replaceAll("stopy", rel2.endPoint.y) + ); + if (rel2.type !== "rel_b") { + line2.attr("marker-end", "url(" + url + "#arrowhead)"); + } + if (rel2.type === "birel" || rel2.type === "rel_b") { + line2.attr("marker-start", "url(" + url + "#arrowend)"); + } + } + let messageConf = conf2.messageFont(); + _drawTextCandidateFunc$3(conf2)( + rel2.label.text, + relsElem, + Math.min(rel2.startPoint.x, rel2.endPoint.x) + Math.abs(rel2.endPoint.x - rel2.startPoint.x) / 2 + offsetX, + Math.min(rel2.startPoint.y, rel2.endPoint.y) + Math.abs(rel2.endPoint.y - rel2.startPoint.y) / 2 + offsetY, + rel2.label.width, + rel2.label.height, + { fill: textColor }, + messageConf + ); + if (rel2.techn && rel2.techn.text !== "") { + messageConf = conf2.messageFont(); + _drawTextCandidateFunc$3(conf2)( + "[" + rel2.techn.text + "]", + relsElem, + Math.min(rel2.startPoint.x, rel2.endPoint.x) + Math.abs(rel2.endPoint.x - rel2.startPoint.x) / 2 + offsetX, + Math.min(rel2.startPoint.y, rel2.endPoint.y) + Math.abs(rel2.endPoint.y - rel2.startPoint.y) / 2 + conf2.messageFontSize + 5 + offsetY, + Math.max(rel2.label.width, rel2.techn.width), + rel2.techn.height, + { fill: textColor, "font-style": "italic" }, + messageConf + ); + } + } + }; + const drawBoundary$1 = function(elem, boundary, conf2) { + const boundaryElem = elem.append("g"); + let fillColor = boundary.bgColor ? boundary.bgColor : "none"; + let strokeColor = boundary.borderColor ? boundary.borderColor : "#444444"; + let fontColor = boundary.fontColor ? boundary.fontColor : "black"; + let attrsValue = { "stroke-width": 1, "stroke-dasharray": "7.0,7.0" }; + if (boundary.nodeType) { + attrsValue = { "stroke-width": 1 }; + } + let rectData = { + x: boundary.x, + y: boundary.y, + fill: fillColor, + stroke: strokeColor, + width: boundary.width, + height: boundary.height, + rx: 2.5, + ry: 2.5, + attrs: attrsValue + }; + drawRect$3(boundaryElem, rectData); + let boundaryConf = conf2.boundaryFont(); + boundaryConf.fontWeight = "bold"; + boundaryConf.fontSize = boundaryConf.fontSize + 2; + boundaryConf.fontColor = fontColor; + _drawTextCandidateFunc$3(conf2)( + boundary.label.text, + boundaryElem, + boundary.x, + boundary.y + boundary.label.Y, + boundary.width, + boundary.height, + { fill: "#444444" }, + boundaryConf + ); + if (boundary.type && boundary.type.text !== "") { + boundaryConf = conf2.boundaryFont(); + boundaryConf.fontColor = fontColor; + _drawTextCandidateFunc$3(conf2)( + boundary.type.text, + boundaryElem, + boundary.x, + boundary.y + boundary.type.Y, + boundary.width, + boundary.height, + { fill: "#444444" }, + boundaryConf + ); + } + if (boundary.descr && boundary.descr.text !== "") { + boundaryConf = conf2.boundaryFont(); + boundaryConf.fontSize = boundaryConf.fontSize - 2; + boundaryConf.fontColor = fontColor; + _drawTextCandidateFunc$3(conf2)( + boundary.descr.text, + boundaryElem, + boundary.x, + boundary.y + boundary.descr.Y, + boundary.width, + boundary.height, + { fill: "#444444" }, + boundaryConf + ); + } + }; + const drawC4Shape = function(elem, c4Shape, conf2) { + var _a2; + let fillColor = c4Shape.bgColor ? c4Shape.bgColor : conf2[c4Shape.typeC4Shape.text + "_bg_color"]; + let strokeColor = c4Shape.borderColor ? c4Shape.borderColor : conf2[c4Shape.typeC4Shape.text + "_border_color"]; + let fontColor = c4Shape.fontColor ? c4Shape.fontColor : "#FFFFFF"; + let personImg = ""; + switch (c4Shape.typeC4Shape.text) { + case "person": + personImg = ""; + break; + case "external_person": + personImg = ""; + break; + } + const c4ShapeElem = elem.append("g"); + c4ShapeElem.attr("class", "person-man"); + const rect2 = getNoteRect$2(); + switch (c4Shape.typeC4Shape.text) { + case "person": + case "external_person": + case "system": + case "external_system": + case "container": + case "external_container": + case "component": + case "external_component": + rect2.x = c4Shape.x; + rect2.y = c4Shape.y; + rect2.fill = fillColor; + rect2.width = c4Shape.width; + rect2.height = c4Shape.height; + rect2.stroke = strokeColor; + rect2.rx = 2.5; + rect2.ry = 2.5; + rect2.attrs = { "stroke-width": 0.5 }; + drawRect$3(c4ShapeElem, rect2); + break; + case "system_db": + case "external_system_db": + case "container_db": + case "external_container_db": + case "component_db": + case "external_component_db": + c4ShapeElem.append("path").attr("fill", fillColor).attr("stroke-width", "0.5").attr("stroke", strokeColor).attr( + "d", + "Mstartx,startyc0,-10 half,-10 half,-10c0,0 half,0 half,10l0,heightc0,10 -half,10 -half,10c0,0 -half,0 -half,-10l0,-height".replaceAll("startx", c4Shape.x).replaceAll("starty", c4Shape.y).replaceAll("half", c4Shape.width / 2).replaceAll("height", c4Shape.height) + ); + c4ShapeElem.append("path").attr("fill", "none").attr("stroke-width", "0.5").attr("stroke", strokeColor).attr( + "d", + "Mstartx,startyc0,10 half,10 half,10c0,0 half,0 half,-10".replaceAll("startx", c4Shape.x).replaceAll("starty", c4Shape.y).replaceAll("half", c4Shape.width / 2) + ); + break; + case "system_queue": + case "external_system_queue": + case "container_queue": + case "external_container_queue": + case "component_queue": + case "external_component_queue": + c4ShapeElem.append("path").attr("fill", fillColor).attr("stroke-width", "0.5").attr("stroke", strokeColor).attr( + "d", + "Mstartx,startylwidth,0c5,0 5,half 5,halfc0,0 0,half -5,halfl-width,0c-5,0 -5,-half -5,-halfc0,0 0,-half 5,-half".replaceAll("startx", c4Shape.x).replaceAll("starty", c4Shape.y).replaceAll("width", c4Shape.width).replaceAll("half", c4Shape.height / 2) + ); + c4ShapeElem.append("path").attr("fill", "none").attr("stroke-width", "0.5").attr("stroke", strokeColor).attr( + "d", + "Mstartx,startyc-5,0 -5,half -5,halfc0,half 5,half 5,half".replaceAll("startx", c4Shape.x + c4Shape.width).replaceAll("starty", c4Shape.y).replaceAll("half", c4Shape.height / 2) + ); + break; + } + let c4ShapeFontConf = getC4ShapeFont(conf2, c4Shape.typeC4Shape.text); + c4ShapeElem.append("text").attr("fill", fontColor).attr("font-family", c4ShapeFontConf.fontFamily).attr("font-size", c4ShapeFontConf.fontSize - 2).attr("font-style", "italic").attr("lengthAdjust", "spacing").attr("textLength", c4Shape.typeC4Shape.width).attr("x", c4Shape.x + c4Shape.width / 2 - c4Shape.typeC4Shape.width / 2).attr("y", c4Shape.y + c4Shape.typeC4Shape.Y).text("<<" + c4Shape.typeC4Shape.text + ">>"); + switch (c4Shape.typeC4Shape.text) { + case "person": + case "external_person": + drawImage( + c4ShapeElem, + 48, + 48, + c4Shape.x + c4Shape.width / 2 - 24, + c4Shape.y + c4Shape.image.Y, + personImg + ); + break; + } + let textFontConf = conf2[c4Shape.typeC4Shape.text + "Font"](); + textFontConf.fontWeight = "bold"; + textFontConf.fontSize = textFontConf.fontSize + 2; + textFontConf.fontColor = fontColor; + _drawTextCandidateFunc$3(conf2)( + c4Shape.label.text, + c4ShapeElem, + c4Shape.x, + c4Shape.y + c4Shape.label.Y, + c4Shape.width, + c4Shape.height, + { fill: fontColor }, + textFontConf + ); + textFontConf = conf2[c4Shape.typeC4Shape.text + "Font"](); + textFontConf.fontColor = fontColor; + if (c4Shape.techn && ((_a2 = c4Shape.techn) == null ? void 0 : _a2.text) !== "") { + _drawTextCandidateFunc$3(conf2)( + c4Shape.techn.text, + c4ShapeElem, + c4Shape.x, + c4Shape.y + c4Shape.techn.Y, + c4Shape.width, + c4Shape.height, + { fill: fontColor, "font-style": "italic" }, + textFontConf + ); + } else if (c4Shape.type && c4Shape.type.text !== "") { + _drawTextCandidateFunc$3(conf2)( + c4Shape.type.text, + c4ShapeElem, + c4Shape.x, + c4Shape.y + c4Shape.type.Y, + c4Shape.width, + c4Shape.height, + { fill: fontColor, "font-style": "italic" }, + textFontConf + ); + } + if (c4Shape.descr && c4Shape.descr.text !== "") { + textFontConf = conf2.personFont(); + textFontConf.fontColor = fontColor; + _drawTextCandidateFunc$3(conf2)( + c4Shape.descr.text, + c4ShapeElem, + c4Shape.x, + c4Shape.y + c4Shape.descr.Y, + c4Shape.width, + c4Shape.height, + { fill: fontColor }, + textFontConf + ); + } + return c4Shape.height; + }; + const insertDatabaseIcon$1 = function(elem) { + elem.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-.047.148-.048.143-.049.139-.049.136-.05.131-.05.126-.05.123-.051.118-.052.114-.051.11-.052.106-.052.101-.052.096-.052.092-.052.088-.053.083-.051.079-.052.074-.052.07-.051.065-.051.06-.051.056-.05.051-.05.023-.024.023-.025.021-.024.02-.024.019-.024.018-.024.017-.024.015-.023.014-.024.013-.023.012-.023.01-.023.01-.022.008-.022.006-.022.006-.022.004-.022.004-.021.001-.021.001-.021v-4.127l-.077.055-.08.053-.083.054-.085.053-.087.052-.09.052-.093.051-.095.05-.097.05-.1.049-.102.049-.105.048-.106.047-.109.047-.111.046-.114.045-.115.045-.118.044-.12.043-.122.042-.124.042-.126.041-.128.04-.13.04-.132.038-.134.038-.135.037-.138.037-.139.035-.142.035-.143.034-.144.033-.147.032-.148.031-.15.03-.151.03-.153.029-.154.027-.156.027-.158.026-.159.025-.161.024-.162.023-.163.022-.165.021-.166.02-.167.019-.169.018-.169.017-.171.016-.173.015-.173.014-.175.013-.175.012-.177.011-.178.01-.179.008-.179.008-.181.006-.182.005-.182.004-.184.003-.184.002h-.37l-.184-.002-.184-.003-.182-.004-.182-.005-.181-.006-.179-.008-.179-.008-.178-.01-.176-.011-.176-.012-.175-.013-.173-.014-.172-.015-.171-.016-.17-.017-.169-.018-.167-.019-.166-.02-.165-.021-.163-.022-.162-.023-.161-.024-.159-.025-.157-.026-.156-.027-.155-.027-.153-.029-.151-.03-.15-.03-.148-.031-.146-.032-.145-.033-.143-.034-.141-.035-.14-.035-.137-.037-.136-.037-.134-.038-.132-.038-.13-.04-.128-.04-.126-.041-.124-.042-.122-.042-.12-.044-.117-.043-.116-.045-.113-.045-.112-.046-.109-.047-.106-.047-.105-.048-.102-.049-.1-.049-.097-.05-.095-.05-.093-.052-.09-.051-.087-.052-.085-.053-.083-.054-.08-.054-.077-.054v4.127zm0-5.654v.011l.001.021.003.021.004.021.005.022.006.022.007.022.009.022.01.022.011.023.012.023.013.023.015.024.016.023.017.024.018.024.019.024.021.024.022.024.023.025.024.024.052.05.056.05.061.05.066.051.07.051.075.052.079.051.084.052.088.052.092.052.097.052.102.052.105.052.11.051.114.051.119.052.123.05.127.051.131.05.135.049.139.049.144.048.147.048.152.047.155.046.16.045.163.045.167.044.171.042.176.042.178.04.183.04.187.038.19.037.194.036.197.034.202.033.204.032.209.03.212.028.216.027.219.025.222.024.226.022.23.02.233.018.236.016.24.014.243.012.246.01.249.008.253.006.256.003.259.001.26-.001.257-.003.254-.006.25-.008.247-.01.244-.012.241-.015.237-.016.233-.018.231-.02.226-.022.224-.024.22-.025.216-.027.212-.029.21-.03.205-.032.202-.033.198-.035.194-.036.191-.037.187-.039.183-.039.179-.041.175-.042.172-.043.168-.044.163-.045.16-.045.155-.047.152-.047.148-.048.143-.048.139-.05.136-.049.131-.05.126-.051.123-.051.118-.051.114-.052.11-.052.106-.052.101-.052.096-.052.092-.052.088-.052.083-.052.079-.052.074-.051.07-.052.065-.051.06-.05.056-.051.051-.049.023-.025.023-.024.021-.025.02-.024.019-.024.018-.024.017-.024.015-.023.014-.023.013-.024.012-.022.01-.023.01-.023.008-.022.006-.022.006-.022.004-.021.004-.022.001-.021.001-.021v-4.139l-.077.054-.08.054-.083.054-.085.052-.087.053-.09.051-.093.051-.095.051-.097.05-.1.049-.102.049-.105.048-.106.047-.109.047-.111.046-.114.045-.115.044-.118.044-.12.044-.122.042-.124.042-.126.041-.128.04-.13.039-.132.039-.134.038-.135.037-.138.036-.139.036-.142.035-.143.033-.144.033-.147.033-.148.031-.15.03-.151.03-.153.028-.154.028-.156.027-.158.026-.159.025-.161.024-.162.023-.163.022-.165.021-.166.02-.167.019-.169.018-.169.017-.171.016-.173.015-.173.014-.175.013-.175.012-.177.011-.178.009-.179.009-.179.007-.181.007-.182.005-.182.004-.184.003-.184.002h-.37l-.184-.002-.184-.003-.182-.004-.182-.005-.181-.007-.179-.007-.179-.009-.178-.009-.176-.011-.176-.012-.175-.013-.173-.014-.172-.015-.171-.016-.17-.017-.169-.018-.167-.019-.166-.02-.165-.021-.163-.022-.162-.023-.161-.024-.159-.025-.157-.026-.156-.027-.155-.028-.153-.028-.151-.03-.15-.03-.148-.031-.146-.033-.145-.033-.143-.033-.141-.035-.14-.036-.137-.036-.136-.037-.134-.038-.132-.039-.13-.039-.128-.04-.126-.041-.124-.042-.122-.043-.12-.043-.117-.044-.116-.044-.113-.046-.112-.046-.109-.046-.106-.047-.105-.048-.102-.049-.1-.049-.097-.05-.095-.051-.093-.051-.09-.051-.087-.053-.085-.052-.083-.054-.08-.054-.077-.054v4.139zm0-5.666v.011l.001.02.003.022.004.021.005.022.006.021.007.022.009.023.01.022.011.023.012.023.013.023.015.023.016.024.017.024.018.023.019.024.021.025.022.024.023.024.024.025.052.05.056.05.061.05.066.051.07.051.075.052.079.051.084.052.088.052.092.052.097.052.102.052.105.051.11.052.114.051.119.051.123.051.127.05.131.05.135.05.139.049.144.048.147.048.152.047.155.046.16.045.163.045.167.043.171.043.176.042.178.04.183.04.187.038.19.037.194.036.197.034.202.033.204.032.209.03.212.028.216.027.219.025.222.024.226.021.23.02.233.018.236.017.24.014.243.012.246.01.249.008.253.006.256.003.259.001.26-.001.257-.003.254-.006.25-.008.247-.01.244-.013.241-.014.237-.016.233-.018.231-.02.226-.022.224-.024.22-.025.216-.027.212-.029.21-.03.205-.032.202-.033.198-.035.194-.036.191-.037.187-.039.183-.039.179-.041.175-.042.172-.043.168-.044.163-.045.16-.045.155-.047.152-.047.148-.048.143-.049.139-.049.136-.049.131-.051.126-.05.123-.051.118-.052.114-.051.11-.052.106-.052.101-.052.096-.052.092-.052.088-.052.083-.052.079-.052.074-.052.07-.051.065-.051.06-.051.056-.05.051-.049.023-.025.023-.025.021-.024.02-.024.019-.024.018-.024.017-.024.015-.023.014-.024.013-.023.012-.023.01-.022.01-.023.008-.022.006-.022.006-.022.004-.022.004-.021.001-.021.001-.021v-4.153l-.077.054-.08.054-.083.053-.085.053-.087.053-.09.051-.093.051-.095.051-.097.05-.1.049-.102.048-.105.048-.106.048-.109.046-.111.046-.114.046-.115.044-.118.044-.12.043-.122.043-.124.042-.126.041-.128.04-.13.039-.132.039-.134.038-.135.037-.138.036-.139.036-.142.034-.143.034-.144.033-.147.032-.148.032-.15.03-.151.03-.153.028-.154.028-.156.027-.158.026-.159.024-.161.024-.162.023-.163.023-.165.021-.166.02-.167.019-.169.018-.169.017-.171.016-.173.015-.173.014-.175.013-.175.012-.177.01-.178.01-.179.009-.179.007-.181.006-.182.006-.182.004-.184.003-.184.001-.185.001-.185-.001-.184-.001-.184-.003-.182-.004-.182-.006-.181-.006-.179-.007-.179-.009-.178-.01-.176-.01-.176-.012-.175-.013-.173-.014-.172-.015-.171-.016-.17-.017-.169-.018-.167-.019-.166-.02-.165-.021-.163-.023-.162-.023-.161-.024-.159-.024-.157-.026-.156-.027-.155-.028-.153-.028-.151-.03-.15-.03-.148-.032-.146-.032-.145-.033-.143-.034-.141-.034-.14-.036-.137-.036-.136-.037-.134-.038-.132-.039-.13-.039-.128-.041-.126-.041-.124-.041-.122-.043-.12-.043-.117-.044-.116-.044-.113-.046-.112-.046-.109-.046-.106-.048-.105-.048-.102-.048-.1-.05-.097-.049-.095-.051-.093-.051-.09-.052-.087-.052-.085-.053-.083-.053-.08-.054-.077-.054v4.153zm8.74-8.179l-.257.004-.254.005-.25.008-.247.011-.244.012-.241.014-.237.016-.233.018-.231.021-.226.022-.224.023-.22.026-.216.027-.212.028-.21.031-.205.032-.202.033-.198.034-.194.036-.191.038-.187.038-.183.04-.179.041-.175.042-.172.043-.168.043-.163.045-.16.046-.155.046-.152.048-.148.048-.143.048-.139.049-.136.05-.131.05-.126.051-.123.051-.118.051-.114.052-.11.052-.106.052-.101.052-.096.052-.092.052-.088.052-.083.052-.079.052-.074.051-.07.052-.065.051-.06.05-.056.05-.051.05-.023.025-.023.024-.021.024-.02.025-.019.024-.018.024-.017.023-.015.024-.014.023-.013.023-.012.023-.01.023-.01.022-.008.022-.006.023-.006.021-.004.022-.004.021-.001.021-.001.021.001.021.001.021.004.021.004.022.006.021.006.023.008.022.01.022.01.023.012.023.013.023.014.023.015.024.017.023.018.024.019.024.02.025.021.024.023.024.023.025.051.05.056.05.06.05.065.051.07.052.074.051.079.052.083.052.088.052.092.052.096.052.101.052.106.052.11.052.114.052.118.051.123.051.126.051.131.05.136.05.139.049.143.048.148.048.152.048.155.046.16.046.163.045.168.043.172.043.175.042.179.041.183.04.187.038.191.038.194.036.198.034.202.033.205.032.21.031.212.028.216.027.22.026.224.023.226.022.231.021.233.018.237.016.241.014.244.012.247.011.25.008.254.005.257.004.26.001.26-.001.257-.004.254-.005.25-.008.247-.011.244-.012.241-.014.237-.016.233-.018.231-.021.226-.022.224-.023.22-.026.216-.027.212-.028.21-.031.205-.032.202-.033.198-.034.194-.036.191-.038.187-.038.183-.04.179-.041.175-.042.172-.043.168-.043.163-.045.16-.046.155-.046.152-.048.148-.048.143-.048.139-.049.136-.05.131-.05.126-.051.123-.051.118-.051.114-.052.11-.052.106-.052.101-.052.096-.052.092-.052.088-.052.083-.052.079-.052.074-.051.07-.052.065-.051.06-.05.056-.05.051-.05.023-.025.023-.024.021-.024.02-.025.019-.024.018-.024.017-.023.015-.024.014-.023.013-.023.012-.023.01-.023.01-.022.008-.022.006-.023.006-.021.004-.022.004-.021.001-.021.001-.021-.001-.021-.001-.021-.004-.021-.004-.022-.006-.021-.006-.023-.008-.022-.01-.022-.01-.023-.012-.023-.013-.023-.014-.023-.015-.024-.017-.023-.018-.024-.019-.024-.02-.025-.021-.024-.023-.024-.023-.025-.051-.05-.056-.05-.06-.05-.065-.051-.07-.052-.074-.051-.079-.052-.083-.052-.088-.052-.092-.052-.096-.052-.101-.052-.106-.052-.11-.052-.114-.052-.118-.051-.123-.051-.126-.051-.131-.05-.136-.05-.139-.049-.143-.048-.148-.048-.152-.048-.155-.046-.16-.046-.163-.045-.168-.043-.172-.043-.175-.042-.179-.041-.183-.04-.187-.038-.191-.038-.194-.036-.198-.034-.202-.033-.205-.032-.21-.031-.212-.028-.216-.027-.22-.026-.224-.023-.226-.022-.231-.021-.233-.018-.237-.016-.241-.014-.244-.012-.247-.011-.25-.008-.254-.005-.257-.004-.26-.001-.26.001z" + ); + }; + const insertComputerIcon$1 = function(elem) { + elem.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" + ); + }; + const insertClockIcon$1 = function(elem) { + elem.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" + ); + }; + const insertArrowHead$1 = function(elem) { + elem.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"); + }; + const insertArrowEnd = function(elem) { + elem.append("defs").append("marker").attr("id", "arrowend").attr("refX", 1).attr("refY", 5).attr("markerUnits", "userSpaceOnUse").attr("markerWidth", 12).attr("markerHeight", 12).attr("orient", "auto").append("path").attr("d", "M 10 0 L 0 5 L 10 10 z"); + }; + const insertArrowFilledHead$1 = function(elem) { + elem.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"); + }; + const insertDynamicNumber = function(elem) { + elem.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); + }; + const insertArrowCrossHead$1 = function(elem) { + const defs = elem.append("defs"); + const marker = defs.append("marker").attr("id", "crosshead").attr("markerWidth", 15).attr("markerHeight", 8).attr("orient", "auto").attr("refX", 16).attr("refY", 4); + marker.append("path").attr("fill", "black").attr("stroke", "#000000").style("stroke-dasharray", "0, 0").attr("stroke-width", "1px").attr("d", "M 9,2 V 6 L16,4 Z"); + marker.append("path").attr("fill", "none").attr("stroke", "#000000").style("stroke-dasharray", "0, 0").attr("stroke-width", "1px").attr("d", "M 0,1 L 6,7 M 6,1 L 0,7"); + }; + const getC4ShapeFont = (cnf, typeC4Shape) => { + return { + fontFamily: cnf[typeC4Shape + "FontFamily"], + fontSize: cnf[typeC4Shape + "FontSize"], + fontWeight: cnf[typeC4Shape + "FontWeight"] + }; + }; + const _drawTextCandidateFunc$3 = function() { + function byText(content2, g, x2, y2, width2, height, textAttrs) { + const text2 = g.append("text").attr("x", x2 + width2 / 2).attr("y", y2 + height / 2 + 5).style("text-anchor", "middle").text(content2); + _setTextAttrs(text2, textAttrs); + } + function byTspan(content2, g, x2, y2, width2, height, textAttrs, conf2) { + const { fontSize, fontFamily, fontWeight } = conf2; + const lines = content2.split(common$1.lineBreakRegex); + for (let i2 = 0; i2 < lines.length; i2++) { + const dy = i2 * fontSize - fontSize * (lines.length - 1) / 2; + const text2 = g.append("text").attr("x", x2 + width2 / 2).attr("y", y2).style("text-anchor", "middle").attr("dominant-baseline", "middle").style("font-size", fontSize).style("font-weight", fontWeight).style("font-family", fontFamily); + text2.append("tspan").attr("dy", dy).text(lines[i2]).attr("alignment-baseline", "mathematical"); + _setTextAttrs(text2, textAttrs); + } + } + function byFo(content2, g, x2, y2, width2, height, textAttrs, conf2) { + const s = g.append("switch"); + const f2 = s.append("foreignObject").attr("x", x2).attr("y", y2).attr("width", width2).attr("height", height); + const text2 = f2.append("xhtml:div").style("display", "table").style("height", "100%").style("width", "100%"); + text2.append("div").style("display", "table-cell").style("text-align", "center").style("vertical-align", "middle").text(content2); + byTspan(content2, s, x2, y2, width2, height, textAttrs, conf2); + _setTextAttrs(text2, textAttrs); + } + function _setTextAttrs(toText, fromTextAttrsDict) { + for (const key in fromTextAttrsDict) { + if (fromTextAttrsDict.hasOwnProperty(key)) { + toText.attr(key, fromTextAttrsDict[key]); + } + } + } + return function(conf2) { + return conf2.textPlacement === "fo" ? byFo : conf2.textPlacement === "old" ? byText : byTspan; + }; + }(); + const svgDraw$4 = { + drawRect: drawRect$3, + drawBoundary: drawBoundary$1, + drawC4Shape, + drawRels: drawRels$1, + drawImage, + insertArrowHead: insertArrowHead$1, + insertArrowEnd, + insertArrowFilledHead: insertArrowFilledHead$1, + insertDynamicNumber, + insertArrowCrossHead: insertArrowCrossHead$1, + insertDatabaseIcon: insertDatabaseIcon$1, + insertComputerIcon: insertComputerIcon$1, + insertClockIcon: insertClockIcon$1 + }; + let globalBoundaryMaxX = 0, globalBoundaryMaxY = 0; + let c4ShapeInRow = 4; + let c4BoundaryInRow = 2; + parser$v.yy = db$g; + let conf$9 = {}; + class Bounds { + constructor(diagObj) { + this.name = ""; + this.data = {}; + this.data.startx = void 0; + this.data.stopx = void 0; + this.data.starty = void 0; + this.data.stopy = void 0; + this.data.widthLimit = void 0; + this.nextData = {}; + this.nextData.startx = void 0; + this.nextData.stopx = void 0; + this.nextData.starty = void 0; + this.nextData.stopy = void 0; + this.nextData.cnt = 0; + setConf$9(diagObj.db.getConfig()); + } + setData(startx, stopx, starty, stopy) { + this.nextData.startx = this.data.startx = startx; + this.nextData.stopx = this.data.stopx = stopx; + this.nextData.starty = this.data.starty = starty; + this.nextData.stopy = this.data.stopy = stopy; + } + updateVal(obj, key, val, fun) { + if (obj[key] === void 0) { + obj[key] = val; + } else { + obj[key] = fun(val, obj[key]); + } + } + insert(c4Shape) { + this.nextData.cnt = this.nextData.cnt + 1; + let _startx = this.nextData.startx === this.nextData.stopx ? this.nextData.stopx + c4Shape.margin : this.nextData.stopx + c4Shape.margin * 2; + let _stopx = _startx + c4Shape.width; + let _starty = this.nextData.starty + c4Shape.margin * 2; + let _stopy = _starty + c4Shape.height; + if (_startx >= this.data.widthLimit || _stopx >= this.data.widthLimit || this.nextData.cnt > c4ShapeInRow) { + _startx = this.nextData.startx + c4Shape.margin + conf$9.nextLinePaddingX; + _starty = this.nextData.stopy + c4Shape.margin * 2; + this.nextData.stopx = _stopx = _startx + c4Shape.width; + this.nextData.starty = this.nextData.stopy; + this.nextData.stopy = _stopy = _starty + c4Shape.height; + this.nextData.cnt = 1; + } + c4Shape.x = _startx; + c4Shape.y = _starty; + this.updateVal(this.data, "startx", _startx, Math.min); + this.updateVal(this.data, "starty", _starty, Math.min); + this.updateVal(this.data, "stopx", _stopx, Math.max); + this.updateVal(this.data, "stopy", _stopy, Math.max); + this.updateVal(this.nextData, "startx", _startx, Math.min); + this.updateVal(this.nextData, "starty", _starty, Math.min); + this.updateVal(this.nextData, "stopx", _stopx, Math.max); + this.updateVal(this.nextData, "stopy", _stopy, Math.max); + } + init(diagObj) { + this.name = ""; + this.data = { + startx: void 0, + stopx: void 0, + starty: void 0, + stopy: void 0, + widthLimit: void 0 + }; + this.nextData = { + startx: void 0, + stopx: void 0, + starty: void 0, + stopy: void 0, + cnt: 0 + }; + setConf$9(diagObj.db.getConfig()); + } + bumpLastMargin(margin) { + this.data.stopx += margin; + this.data.stopy += margin; + } + } + const setConf$9 = function(cnf) { + assignWithDepth$1(conf$9, cnf); + if (cnf.fontFamily) { + conf$9.personFontFamily = conf$9.systemFontFamily = conf$9.messageFontFamily = cnf.fontFamily; + } + if (cnf.fontSize) { + conf$9.personFontSize = conf$9.systemFontSize = conf$9.messageFontSize = cnf.fontSize; + } + if (cnf.fontWeight) { + conf$9.personFontWeight = conf$9.systemFontWeight = conf$9.messageFontWeight = cnf.fontWeight; + } + }; + const c4ShapeFont = (cnf, typeC4Shape) => { + return { + fontFamily: cnf[typeC4Shape + "FontFamily"], + fontSize: cnf[typeC4Shape + "FontSize"], + fontWeight: cnf[typeC4Shape + "FontWeight"] + }; + }; + const boundaryFont = (cnf) => { + return { + fontFamily: cnf.boundaryFontFamily, + fontSize: cnf.boundaryFontSize, + fontWeight: cnf.boundaryFontWeight + }; + }; + const messageFont$1 = (cnf) => { + return { + fontFamily: cnf.messageFontFamily, + fontSize: cnf.messageFontSize, + fontWeight: cnf.messageFontWeight + }; + }; + function calcC4ShapeTextWH(textType, c4Shape, c4ShapeTextWrap, textConf, textLimitWidth) { + if (!c4Shape[textType].width) { + if (c4ShapeTextWrap) { + c4Shape[textType].text = wrapLabel(c4Shape[textType].text, textLimitWidth, textConf); + c4Shape[textType].textLines = c4Shape[textType].text.split(common$1.lineBreakRegex).length; + c4Shape[textType].width = textLimitWidth; + c4Shape[textType].height = calculateTextHeight(c4Shape[textType].text, textConf); + } else { + let lines = c4Shape[textType].text.split(common$1.lineBreakRegex); + c4Shape[textType].textLines = lines.length; + let lineHeight = 0; + c4Shape[textType].height = 0; + c4Shape[textType].width = 0; + for (const line2 of lines) { + c4Shape[textType].width = Math.max( + calculateTextWidth(line2, textConf), + c4Shape[textType].width + ); + lineHeight = calculateTextHeight(line2, textConf); + c4Shape[textType].height = c4Shape[textType].height + lineHeight; + } + } + } + } + const drawBoundary = function(diagram2, boundary, bounds2) { + boundary.x = bounds2.data.startx; + boundary.y = bounds2.data.starty; + boundary.width = bounds2.data.stopx - bounds2.data.startx; + boundary.height = bounds2.data.stopy - bounds2.data.starty; + boundary.label.y = conf$9.c4ShapeMargin - 35; + let boundaryTextWrap = boundary.wrap && conf$9.wrap; + let boundaryLabelConf = boundaryFont(conf$9); + boundaryLabelConf.fontSize = boundaryLabelConf.fontSize + 2; + boundaryLabelConf.fontWeight = "bold"; + let textLimitWidth = calculateTextWidth(boundary.label.text, boundaryLabelConf); + calcC4ShapeTextWH("label", boundary, boundaryTextWrap, boundaryLabelConf, textLimitWidth); + svgDraw$4.drawBoundary(diagram2, boundary, conf$9); + }; + const drawC4ShapeArray = function(currentBounds, diagram2, c4ShapeArray2, c4ShapeKeys) { + let Y = 0; + for (const c4ShapeKey of c4ShapeKeys) { + Y = 0; + const c4Shape = c4ShapeArray2[c4ShapeKey]; + let c4ShapeTypeConf = c4ShapeFont(conf$9, c4Shape.typeC4Shape.text); + c4ShapeTypeConf.fontSize = c4ShapeTypeConf.fontSize - 2; + c4Shape.typeC4Shape.width = calculateTextWidth( + "«" + c4Shape.typeC4Shape.text + "»", + c4ShapeTypeConf + ); + c4Shape.typeC4Shape.height = c4ShapeTypeConf.fontSize + 2; + c4Shape.typeC4Shape.Y = conf$9.c4ShapePadding; + Y = c4Shape.typeC4Shape.Y + c4Shape.typeC4Shape.height - 4; + c4Shape.image = { width: 0, height: 0, Y: 0 }; + switch (c4Shape.typeC4Shape.text) { + case "person": + case "external_person": + c4Shape.image.width = 48; + c4Shape.image.height = 48; + c4Shape.image.Y = Y; + Y = c4Shape.image.Y + c4Shape.image.height; + break; + } + if (c4Shape.sprite) { + c4Shape.image.width = 48; + c4Shape.image.height = 48; + c4Shape.image.Y = Y; + Y = c4Shape.image.Y + c4Shape.image.height; + } + let c4ShapeTextWrap = c4Shape.wrap && conf$9.wrap; + let textLimitWidth = conf$9.width - conf$9.c4ShapePadding * 2; + let c4ShapeLabelConf = c4ShapeFont(conf$9, c4Shape.typeC4Shape.text); + c4ShapeLabelConf.fontSize = c4ShapeLabelConf.fontSize + 2; + c4ShapeLabelConf.fontWeight = "bold"; + calcC4ShapeTextWH("label", c4Shape, c4ShapeTextWrap, c4ShapeLabelConf, textLimitWidth); + c4Shape["label"].Y = Y + 8; + Y = c4Shape["label"].Y + c4Shape["label"].height; + if (c4Shape.type && c4Shape.type.text !== "") { + c4Shape.type.text = "[" + c4Shape.type.text + "]"; + let c4ShapeTypeConf2 = c4ShapeFont(conf$9, c4Shape.typeC4Shape.text); + calcC4ShapeTextWH("type", c4Shape, c4ShapeTextWrap, c4ShapeTypeConf2, textLimitWidth); + c4Shape["type"].Y = Y + 5; + Y = c4Shape["type"].Y + c4Shape["type"].height; + } else if (c4Shape.techn && c4Shape.techn.text !== "") { + c4Shape.techn.text = "[" + c4Shape.techn.text + "]"; + let c4ShapeTechnConf = c4ShapeFont(conf$9, c4Shape.techn.text); + calcC4ShapeTextWH("techn", c4Shape, c4ShapeTextWrap, c4ShapeTechnConf, textLimitWidth); + c4Shape["techn"].Y = Y + 5; + Y = c4Shape["techn"].Y + c4Shape["techn"].height; + } + let rectHeight = Y; + let rectWidth = c4Shape.label.width; + if (c4Shape.descr && c4Shape.descr.text !== "") { + let c4ShapeDescrConf = c4ShapeFont(conf$9, c4Shape.typeC4Shape.text); + calcC4ShapeTextWH("descr", c4Shape, c4ShapeTextWrap, c4ShapeDescrConf, textLimitWidth); + c4Shape["descr"].Y = Y + 20; + Y = c4Shape["descr"].Y + c4Shape["descr"].height; + rectWidth = Math.max(c4Shape.label.width, c4Shape.descr.width); + rectHeight = Y - c4Shape["descr"].textLines * 5; + } + rectWidth = rectWidth + conf$9.c4ShapePadding; + c4Shape.width = Math.max(c4Shape.width || conf$9.width, rectWidth, conf$9.width); + c4Shape.height = Math.max(c4Shape.height || conf$9.height, rectHeight, conf$9.height); + c4Shape.margin = c4Shape.margin || conf$9.c4ShapeMargin; + currentBounds.insert(c4Shape); + svgDraw$4.drawC4Shape(diagram2, c4Shape, conf$9); + } + currentBounds.bumpLastMargin(conf$9.c4ShapeMargin); + }; + let Point$1 = class Point { + constructor(x2, y2) { + this.x = x2; + this.y = y2; + } + }; + let getIntersectPoint = function(fromNode, endPoint) { + let x1 = fromNode.x; + let y1 = fromNode.y; + let x2 = endPoint.x; + let y2 = endPoint.y; + let fromCenterX = x1 + fromNode.width / 2; + let fromCenterY = y1 + fromNode.height / 2; + let dx = Math.abs(x1 - x2); + let dy = Math.abs(y1 - y2); + let tanDYX = dy / dx; + let fromDYX = fromNode.height / fromNode.width; + let returnPoint = null; + if (y1 == y2 && x1 < x2) { + returnPoint = new Point$1(x1 + fromNode.width, fromCenterY); + } else if (y1 == y2 && x1 > x2) { + returnPoint = new Point$1(x1, fromCenterY); + } else if (x1 == x2 && y1 < y2) { + returnPoint = new Point$1(fromCenterX, y1 + fromNode.height); + } else if (x1 == x2 && y1 > y2) { + returnPoint = new Point$1(fromCenterX, y1); + } + if (x1 > x2 && y1 < y2) { + if (fromDYX >= tanDYX) { + returnPoint = new Point$1(x1, fromCenterY + tanDYX * fromNode.width / 2); + } else { + returnPoint = new Point$1( + fromCenterX - dx / dy * fromNode.height / 2, + y1 + fromNode.height + ); + } + } else if (x1 < x2 && y1 < y2) { + if (fromDYX >= tanDYX) { + returnPoint = new Point$1(x1 + fromNode.width, fromCenterY + tanDYX * fromNode.width / 2); + } else { + returnPoint = new Point$1( + fromCenterX + dx / dy * fromNode.height / 2, + y1 + fromNode.height + ); + } + } else if (x1 < x2 && y1 > y2) { + if (fromDYX >= tanDYX) { + returnPoint = new Point$1(x1 + fromNode.width, fromCenterY - tanDYX * fromNode.width / 2); + } else { + returnPoint = new Point$1(fromCenterX + fromNode.height / 2 * dx / dy, y1); + } + } else if (x1 > x2 && y1 > y2) { + if (fromDYX >= tanDYX) { + returnPoint = new Point$1(x1, fromCenterY - fromNode.width / 2 * tanDYX); + } else { + returnPoint = new Point$1(fromCenterX - fromNode.height / 2 * dx / dy, y1); + } + } + return returnPoint; + }; + let getIntersectPoints = function(fromNode, endNode) { + let endIntersectPoint = { x: 0, y: 0 }; + endIntersectPoint.x = endNode.x + endNode.width / 2; + endIntersectPoint.y = endNode.y + endNode.height / 2; + let startPoint = getIntersectPoint(fromNode, endIntersectPoint); + endIntersectPoint.x = fromNode.x + fromNode.width / 2; + endIntersectPoint.y = fromNode.y + fromNode.height / 2; + let endPoint = getIntersectPoint(endNode, endIntersectPoint); + return { startPoint, endPoint }; + }; + const drawRels = function(diagram2, rels2, getC4ShapeObj, diagObj) { + let i2 = 0; + for (let rel2 of rels2) { + i2 = i2 + 1; + let relTextWrap = rel2.wrap && conf$9.wrap; + let relConf = messageFont$1(conf$9); + let diagramType = diagObj.db.getC4Type(); + if (diagramType === "C4Dynamic") { + rel2.label.text = i2 + ": " + rel2.label.text; + } + let textLimitWidth = calculateTextWidth(rel2.label.text, relConf); + calcC4ShapeTextWH("label", rel2, relTextWrap, relConf, textLimitWidth); + if (rel2.techn && rel2.techn.text !== "") { + textLimitWidth = calculateTextWidth(rel2.techn.text, relConf); + calcC4ShapeTextWH("techn", rel2, relTextWrap, relConf, textLimitWidth); + } + if (rel2.descr && rel2.descr.text !== "") { + textLimitWidth = calculateTextWidth(rel2.descr.text, relConf); + calcC4ShapeTextWH("descr", rel2, relTextWrap, relConf, textLimitWidth); + } + let fromNode = getC4ShapeObj(rel2.from); + let endNode = getC4ShapeObj(rel2.to); + let points = getIntersectPoints(fromNode, endNode); + rel2.startPoint = points.startPoint; + rel2.endPoint = points.endPoint; + } + svgDraw$4.drawRels(diagram2, rels2, conf$9); + }; + function drawInsideBoundary(diagram2, parentBoundaryAlias, parentBounds, currentBoundaries, diagObj) { + let currentBounds = new Bounds(diagObj); + currentBounds.data.widthLimit = parentBounds.data.widthLimit / Math.min(c4BoundaryInRow, currentBoundaries.length); + for (let [i2, currentBoundary] of currentBoundaries.entries()) { + let Y = 0; + currentBoundary.image = { width: 0, height: 0, Y: 0 }; + if (currentBoundary.sprite) { + currentBoundary.image.width = 48; + currentBoundary.image.height = 48; + currentBoundary.image.Y = Y; + Y = currentBoundary.image.Y + currentBoundary.image.height; + } + let currentBoundaryTextWrap = currentBoundary.wrap && conf$9.wrap; + let currentBoundaryLabelConf = boundaryFont(conf$9); + currentBoundaryLabelConf.fontSize = currentBoundaryLabelConf.fontSize + 2; + currentBoundaryLabelConf.fontWeight = "bold"; + calcC4ShapeTextWH( + "label", + currentBoundary, + currentBoundaryTextWrap, + currentBoundaryLabelConf, + currentBounds.data.widthLimit + ); + currentBoundary["label"].Y = Y + 8; + Y = currentBoundary["label"].Y + currentBoundary["label"].height; + if (currentBoundary.type && currentBoundary.type.text !== "") { + currentBoundary.type.text = "[" + currentBoundary.type.text + "]"; + let currentBoundaryTypeConf = boundaryFont(conf$9); + calcC4ShapeTextWH( + "type", + currentBoundary, + currentBoundaryTextWrap, + currentBoundaryTypeConf, + currentBounds.data.widthLimit + ); + currentBoundary["type"].Y = Y + 5; + Y = currentBoundary["type"].Y + currentBoundary["type"].height; + } + if (currentBoundary.descr && currentBoundary.descr.text !== "") { + let currentBoundaryDescrConf = boundaryFont(conf$9); + currentBoundaryDescrConf.fontSize = currentBoundaryDescrConf.fontSize - 2; + calcC4ShapeTextWH( + "descr", + currentBoundary, + currentBoundaryTextWrap, + currentBoundaryDescrConf, + currentBounds.data.widthLimit + ); + currentBoundary["descr"].Y = Y + 20; + Y = currentBoundary["descr"].Y + currentBoundary["descr"].height; + } + if (i2 == 0 || i2 % c4BoundaryInRow === 0) { + let _x = parentBounds.data.startx + conf$9.diagramMarginX; + let _y = parentBounds.data.stopy + conf$9.diagramMarginY + Y; + currentBounds.setData(_x, _x, _y, _y); + } else { + let _x = currentBounds.data.stopx !== currentBounds.data.startx ? currentBounds.data.stopx + conf$9.diagramMarginX : currentBounds.data.startx; + let _y = currentBounds.data.starty; + currentBounds.setData(_x, _x, _y, _y); + } + currentBounds.name = currentBoundary.alias; + let currentPersonOrSystemArray = diagObj.db.getC4ShapeArray(currentBoundary.alias); + let currentPersonOrSystemKeys = diagObj.db.getC4ShapeKeys(currentBoundary.alias); + if (currentPersonOrSystemKeys.length > 0) { + drawC4ShapeArray( + currentBounds, + diagram2, + currentPersonOrSystemArray, + currentPersonOrSystemKeys + ); + } + parentBoundaryAlias = currentBoundary.alias; + let nextCurrentBoundaries = diagObj.db.getBoundarys(parentBoundaryAlias); + if (nextCurrentBoundaries.length > 0) { + drawInsideBoundary( + diagram2, + parentBoundaryAlias, + currentBounds, + nextCurrentBoundaries, + diagObj + ); + } + if (currentBoundary.alias !== "global") { + drawBoundary(diagram2, currentBoundary, currentBounds); + } + parentBounds.data.stopy = Math.max( + currentBounds.data.stopy + conf$9.c4ShapeMargin, + parentBounds.data.stopy + ); + parentBounds.data.stopx = Math.max( + currentBounds.data.stopx + conf$9.c4ShapeMargin, + parentBounds.data.stopx + ); + globalBoundaryMaxX = Math.max(globalBoundaryMaxX, parentBounds.data.stopx); + globalBoundaryMaxY = Math.max(globalBoundaryMaxY, parentBounds.data.stopy); + } + } + const draw$l = function(_text, id2, _version, diagObj) { + conf$9 = getConfig$1().c4; + const securityLevel = getConfig$1().securityLevel; + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = d3select("#i" + id2); + } + const root2 = securityLevel === "sandbox" ? d3select(sandboxElement.nodes()[0].contentDocument.body) : d3select("body"); + let db2 = diagObj.db; + diagObj.db.setWrap(conf$9.wrap); + c4ShapeInRow = db2.getC4ShapeInRow(); + c4BoundaryInRow = db2.getC4BoundaryInRow(); + log$1.debug(`C:${JSON.stringify(conf$9, null, 2)}`); + const diagram2 = securityLevel === "sandbox" ? root2.select(`[id="${id2}"]`) : d3select(`[id="${id2}"]`); + svgDraw$4.insertComputerIcon(diagram2); + svgDraw$4.insertDatabaseIcon(diagram2); + svgDraw$4.insertClockIcon(diagram2); + let screenBounds = new Bounds(diagObj); + screenBounds.setData( + conf$9.diagramMarginX, + conf$9.diagramMarginX, + conf$9.diagramMarginY, + conf$9.diagramMarginY + ); + screenBounds.data.widthLimit = screen.availWidth; + globalBoundaryMaxX = conf$9.diagramMarginX; + globalBoundaryMaxY = conf$9.diagramMarginY; + const title2 = diagObj.db.getTitle(); + let currentBoundaries = diagObj.db.getBoundarys(""); + drawInsideBoundary(diagram2, "", screenBounds, currentBoundaries, diagObj); + svgDraw$4.insertArrowHead(diagram2); + svgDraw$4.insertArrowEnd(diagram2); + svgDraw$4.insertArrowCrossHead(diagram2); + svgDraw$4.insertArrowFilledHead(diagram2); + drawRels(diagram2, diagObj.db.getRels(), diagObj.db.getC4Shape, diagObj); + screenBounds.data.stopx = globalBoundaryMaxX; + screenBounds.data.stopy = globalBoundaryMaxY; + const box = screenBounds.data; + let boxHeight = box.stopy - box.starty; + let height = boxHeight + 2 * conf$9.diagramMarginY; + let boxWidth = box.stopx - box.startx; + const width2 = boxWidth + 2 * conf$9.diagramMarginX; + if (title2) { + diagram2.append("text").text(title2).attr("x", (box.stopx - box.startx) / 2 - 4 * conf$9.diagramMarginX).attr("y", box.starty + conf$9.diagramMarginY); + } + configureSvgSize(diagram2, height, width2, conf$9.useMaxWidth); + const extraVertForTitle = title2 ? 60 : 0; + diagram2.attr( + "viewBox", + box.startx - conf$9.diagramMarginX + " -" + (conf$9.diagramMarginY + extraVertForTitle) + " " + width2 + " " + (height + extraVertForTitle) + ); + log$1.debug(`models:`, box); + }; + const renderer$g = { + drawPersonOrSystemArray: drawC4ShapeArray, + drawBoundary, + setConf: setConf$9, + draw: draw$l + }; + const getStyles$e = (options2) => `.person { + stroke: ${options2.personBorder}; + fill: ${options2.personBkg}; + } +`; + const styles$9 = getStyles$e; + const diagram$l = { + parser: parser$w, + db: db$g, + renderer: renderer$g, + styles: styles$9, + init: ({ c4: c42, wrap: wrap2 }) => { + renderer$g.setConf(c42); + db$g.setWrap(wrap2); + } + }; + const c4Diagram = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + diagram: diagram$l + }, Symbol.toStringTag, { value: "Module" })); + var parser$t = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 4], $V1 = [1, 3], $V2 = [1, 5], $V3 = [1, 8, 9, 10, 11, 27, 34, 36, 38, 42, 58, 81, 82, 83, 84, 85, 86, 99, 102, 103, 106, 108, 111, 112, 113, 118, 119, 120, 121], $V4 = [2, 2], $V5 = [1, 13], $V6 = [1, 14], $V7 = [1, 15], $V8 = [1, 16], $V9 = [1, 23], $Va = [1, 25], $Vb = [1, 26], $Vc = [1, 27], $Vd = [1, 49], $Ve = [1, 48], $Vf = [1, 29], $Vg = [1, 30], $Vh = [1, 31], $Vi = [1, 32], $Vj = [1, 33], $Vk = [1, 44], $Vl = [1, 46], $Vm = [1, 42], $Vn = [1, 47], $Vo = [1, 43], $Vp = [1, 50], $Vq = [1, 45], $Vr = [1, 51], $Vs = [1, 52], $Vt = [1, 34], $Vu = [1, 35], $Vv = [1, 36], $Vw = [1, 37], $Vx = [1, 57], $Vy = [1, 8, 9, 10, 11, 27, 32, 34, 36, 38, 42, 58, 81, 82, 83, 84, 85, 86, 99, 102, 103, 106, 108, 111, 112, 113, 118, 119, 120, 121], $Vz = [1, 61], $VA = [1, 60], $VB = [1, 62], $VC = [8, 9, 11, 73, 75], $VD = [1, 88], $VE = [1, 93], $VF = [1, 92], $VG = [1, 89], $VH = [1, 85], $VI = [1, 91], $VJ = [1, 87], $VK = [1, 94], $VL = [1, 90], $VM = [1, 95], $VN = [1, 86], $VO = [8, 9, 10, 11, 73, 75], $VP = [8, 9, 10, 11, 44, 73, 75], $VQ = [8, 9, 10, 11, 29, 42, 44, 46, 48, 50, 52, 54, 56, 58, 61, 63, 65, 66, 68, 73, 75, 86, 99, 102, 103, 106, 108, 111, 112, 113], $VR = [8, 9, 11, 42, 58, 73, 75, 86, 99, 102, 103, 106, 108, 111, 112, 113], $VS = [42, 58, 86, 99, 102, 103, 106, 108, 111, 112, 113], $VT = [1, 121], $VU = [1, 120], $VV = [1, 128], $VW = [1, 142], $VX = [1, 143], $VY = [1, 144], $VZ = [1, 145], $V_ = [1, 130], $V$ = [1, 132], $V01 = [1, 136], $V11 = [1, 137], $V21 = [1, 138], $V31 = [1, 139], $V41 = [1, 140], $V51 = [1, 141], $V61 = [1, 146], $V71 = [1, 147], $V81 = [1, 126], $V91 = [1, 127], $Va1 = [1, 134], $Vb1 = [1, 129], $Vc1 = [1, 133], $Vd1 = [1, 131], $Ve1 = [8, 9, 10, 11, 27, 32, 34, 36, 38, 42, 58, 81, 82, 83, 84, 85, 86, 99, 102, 103, 106, 108, 111, 112, 113, 118, 119, 120, 121], $Vf1 = [1, 149], $Vg1 = [8, 9, 11], $Vh1 = [8, 9, 10, 11, 14, 42, 58, 86, 102, 103, 106, 108, 111, 112, 113], $Vi1 = [1, 169], $Vj1 = [1, 165], $Vk1 = [1, 166], $Vl1 = [1, 170], $Vm1 = [1, 167], $Vn1 = [1, 168], $Vo1 = [75, 113, 116], $Vp1 = [8, 9, 10, 11, 12, 14, 27, 29, 32, 42, 58, 73, 81, 82, 83, 84, 85, 86, 87, 102, 106, 108, 111, 112, 113], $Vq1 = [10, 103], $Vr1 = [31, 47, 49, 51, 53, 55, 60, 62, 64, 65, 67, 69, 113, 114, 115], $Vs1 = [1, 235], $Vt1 = [1, 233], $Vu1 = [1, 237], $Vv1 = [1, 231], $Vw1 = [1, 232], $Vx1 = [1, 234], $Vy1 = [1, 236], $Vz1 = [1, 238], $VA1 = [1, 255], $VB1 = [8, 9, 11, 103], $VC1 = [8, 9, 10, 11, 58, 81, 102, 103, 106, 107, 108, 109]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "graphConfig": 4, "document": 5, "line": 6, "statement": 7, "SEMI": 8, "NEWLINE": 9, "SPACE": 10, "EOF": 11, "GRAPH": 12, "NODIR": 13, "DIR": 14, "FirstStmtSeparator": 15, "ending": 16, "endToken": 17, "spaceList": 18, "spaceListNewline": 19, "vertexStatement": 20, "separator": 21, "styleStatement": 22, "linkStyleStatement": 23, "classDefStatement": 24, "classStatement": 25, "clickStatement": 26, "subgraph": 27, "textNoTags": 28, "SQS": 29, "text": 30, "SQE": 31, "end": 32, "direction": 33, "acc_title": 34, "acc_title_value": 35, "acc_descr": 36, "acc_descr_value": 37, "acc_descr_multiline_value": 38, "link": 39, "node": 40, "styledVertex": 41, "AMP": 42, "vertex": 43, "STYLE_SEPARATOR": 44, "idString": 45, "DOUBLECIRCLESTART": 46, "DOUBLECIRCLEEND": 47, "PS": 48, "PE": 49, "(-": 50, "-)": 51, "STADIUMSTART": 52, "STADIUMEND": 53, "SUBROUTINESTART": 54, "SUBROUTINEEND": 55, "VERTEX_WITH_PROPS_START": 56, "NODE_STRING[field]": 57, "COLON": 58, "NODE_STRING[value]": 59, "PIPE": 60, "CYLINDERSTART": 61, "CYLINDEREND": 62, "DIAMOND_START": 63, "DIAMOND_STOP": 64, "TAGEND": 65, "TRAPSTART": 66, "TRAPEND": 67, "INVTRAPSTART": 68, "INVTRAPEND": 69, "linkStatement": 70, "arrowText": 71, "TESTSTR": 72, "START_LINK": 73, "edgeText": 74, "LINK": 75, "edgeTextToken": 76, "STR": 77, "MD_STR": 78, "textToken": 79, "keywords": 80, "STYLE": 81, "LINKSTYLE": 82, "CLASSDEF": 83, "CLASS": 84, "CLICK": 85, "DOWN": 86, "UP": 87, "textNoTagsToken": 88, "stylesOpt": 89, "idString[vertex]": 90, "idString[class]": 91, "CALLBACKNAME": 92, "CALLBACKARGS": 93, "HREF": 94, "LINK_TARGET": 95, "STR[link]": 96, "STR[tooltip]": 97, "alphaNum": 98, "DEFAULT": 99, "numList": 100, "INTERPOLATE": 101, "NUM": 102, "COMMA": 103, "style": 104, "styleComponent": 105, "NODE_STRING": 106, "UNIT": 107, "BRKT": 108, "PCT": 109, "idStringToken": 110, "MINUS": 111, "MULT": 112, "UNICODE_TEXT": 113, "TEXT": 114, "TAGSTART": 115, "EDGE_TEXT": 116, "alphaNumToken": 117, "direction_tb": 118, "direction_bt": 119, "direction_rl": 120, "direction_lr": 121, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 8: "SEMI", 9: "NEWLINE", 10: "SPACE", 11: "EOF", 12: "GRAPH", 13: "NODIR", 14: "DIR", 27: "subgraph", 29: "SQS", 31: "SQE", 32: "end", 34: "acc_title", 35: "acc_title_value", 36: "acc_descr", 37: "acc_descr_value", 38: "acc_descr_multiline_value", 42: "AMP", 44: "STYLE_SEPARATOR", 46: "DOUBLECIRCLESTART", 47: "DOUBLECIRCLEEND", 48: "PS", 49: "PE", 50: "(-", 51: "-)", 52: "STADIUMSTART", 53: "STADIUMEND", 54: "SUBROUTINESTART", 55: "SUBROUTINEEND", 56: "VERTEX_WITH_PROPS_START", 57: "NODE_STRING[field]", 58: "COLON", 59: "NODE_STRING[value]", 60: "PIPE", 61: "CYLINDERSTART", 62: "CYLINDEREND", 63: "DIAMOND_START", 64: "DIAMOND_STOP", 65: "TAGEND", 66: "TRAPSTART", 67: "TRAPEND", 68: "INVTRAPSTART", 69: "INVTRAPEND", 72: "TESTSTR", 73: "START_LINK", 75: "LINK", 77: "STR", 78: "MD_STR", 81: "STYLE", 82: "LINKSTYLE", 83: "CLASSDEF", 84: "CLASS", 85: "CLICK", 86: "DOWN", 87: "UP", 90: "idString[vertex]", 91: "idString[class]", 92: "CALLBACKNAME", 93: "CALLBACKARGS", 94: "HREF", 95: "LINK_TARGET", 96: "STR[link]", 97: "STR[tooltip]", 99: "DEFAULT", 101: "INTERPOLATE", 102: "NUM", 103: "COMMA", 106: "NODE_STRING", 107: "UNIT", 108: "BRKT", 109: "PCT", 111: "MINUS", 112: "MULT", 113: "UNICODE_TEXT", 114: "TEXT", 115: "TAGSTART", 116: "EDGE_TEXT", 118: "direction_tb", 119: "direction_bt", 120: "direction_rl", 121: "direction_lr" }, + productions_: [0, [3, 2], [5, 0], [5, 2], [6, 1], [6, 1], [6, 1], [6, 1], [6, 1], [4, 2], [4, 2], [4, 2], [4, 3], [16, 2], [16, 1], [17, 1], [17, 1], [17, 1], [15, 1], [15, 1], [15, 2], [19, 2], [19, 2], [19, 1], [19, 1], [18, 2], [18, 1], [7, 2], [7, 2], [7, 2], [7, 2], [7, 2], [7, 2], [7, 9], [7, 6], [7, 4], [7, 1], [7, 2], [7, 2], [7, 1], [21, 1], [21, 1], [21, 1], [20, 3], [20, 4], [20, 2], [20, 1], [40, 1], [40, 5], [41, 1], [41, 3], [43, 4], [43, 4], [43, 6], [43, 4], [43, 4], [43, 4], [43, 8], [43, 4], [43, 4], [43, 4], [43, 6], [43, 4], [43, 4], [43, 4], [43, 4], [43, 4], [43, 1], [39, 2], [39, 3], [39, 3], [39, 1], [39, 3], [74, 1], [74, 2], [74, 1], [74, 1], [70, 1], [71, 3], [30, 1], [30, 2], [30, 1], [30, 1], [80, 1], [80, 1], [80, 1], [80, 1], [80, 1], [80, 1], [80, 1], [80, 1], [80, 1], [80, 1], [80, 1], [28, 1], [28, 2], [28, 1], [28, 1], [24, 5], [25, 5], [26, 2], [26, 4], [26, 3], [26, 5], [26, 3], [26, 5], [26, 5], [26, 7], [26, 2], [26, 4], [26, 2], [26, 4], [26, 4], [26, 6], [22, 5], [23, 5], [23, 5], [23, 9], [23, 9], [23, 7], [23, 7], [100, 1], [100, 3], [89, 1], [89, 3], [104, 1], [104, 2], [105, 1], [105, 1], [105, 1], [105, 1], [105, 1], [105, 1], [105, 1], [105, 1], [110, 1], [110, 1], [110, 1], [110, 1], [110, 1], [110, 1], [110, 1], [110, 1], [110, 1], [110, 1], [110, 1], [79, 1], [79, 1], [79, 1], [79, 1], [88, 1], [88, 1], [88, 1], [88, 1], [88, 1], [88, 1], [88, 1], [88, 1], [88, 1], [88, 1], [88, 1], [76, 1], [76, 1], [117, 1], [117, 1], [117, 1], [117, 1], [117, 1], [117, 1], [117, 1], [117, 1], [117, 1], [117, 1], [117, 1], [45, 1], [45, 2], [98, 1], [98, 2], [33, 1], [33, 1], [33, 1], [33, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 2: + this.$ = []; + break; + case 3: + if (!Array.isArray($$[$0]) || $$[$0].length > 0) { + $$[$0 - 1].push($$[$0]); + } + this.$ = $$[$0 - 1]; + break; + case 4: + case 176: + this.$ = $$[$0]; + break; + case 11: + yy.setDirection("TB"); + this.$ = "TB"; + break; + case 12: + yy.setDirection($$[$0 - 1]); + this.$ = $$[$0 - 1]; + break; + case 27: + this.$ = $$[$0 - 1].nodes; + break; + case 28: + case 29: + case 30: + case 31: + case 32: + this.$ = []; + break; + case 33: + this.$ = yy.addSubGraph($$[$0 - 6], $$[$0 - 1], $$[$0 - 4]); + break; + case 34: + this.$ = yy.addSubGraph($$[$0 - 3], $$[$0 - 1], $$[$0 - 3]); + break; + case 35: + this.$ = yy.addSubGraph(void 0, $$[$0 - 1], void 0); + break; + case 37: + this.$ = $$[$0].trim(); + yy.setAccTitle(this.$); + break; + case 38: + case 39: + this.$ = $$[$0].trim(); + yy.setAccDescription(this.$); + break; + case 43: + yy.addLink($$[$0 - 2].stmt, $$[$0], $$[$0 - 1]); + this.$ = { stmt: $$[$0], nodes: $$[$0].concat($$[$0 - 2].nodes) }; + break; + case 44: + yy.addLink($$[$0 - 3].stmt, $$[$0 - 1], $$[$0 - 2]); + this.$ = { stmt: $$[$0 - 1], nodes: $$[$0 - 1].concat($$[$0 - 3].nodes) }; + break; + case 45: + this.$ = { stmt: $$[$0 - 1], nodes: $$[$0 - 1] }; + break; + case 46: + this.$ = { stmt: $$[$0], nodes: $$[$0] }; + break; + case 47: + this.$ = [$$[$0]]; + break; + case 48: + this.$ = $$[$0 - 4].concat($$[$0]); + break; + case 49: + this.$ = $$[$0]; + break; + case 50: + this.$ = $$[$0 - 2]; + yy.setClass($$[$0 - 2], $$[$0]); + break; + case 51: + this.$ = $$[$0 - 3]; + yy.addVertex($$[$0 - 3], $$[$0 - 1], "square"); + break; + case 52: + this.$ = $$[$0 - 3]; + yy.addVertex($$[$0 - 3], $$[$0 - 1], "doublecircle"); + break; + case 53: + this.$ = $$[$0 - 5]; + yy.addVertex($$[$0 - 5], $$[$0 - 2], "circle"); + break; + case 54: + this.$ = $$[$0 - 3]; + yy.addVertex($$[$0 - 3], $$[$0 - 1], "ellipse"); + break; + case 55: + this.$ = $$[$0 - 3]; + yy.addVertex($$[$0 - 3], $$[$0 - 1], "stadium"); + break; + case 56: + this.$ = $$[$0 - 3]; + yy.addVertex($$[$0 - 3], $$[$0 - 1], "subroutine"); + break; + case 57: + this.$ = $$[$0 - 7]; + yy.addVertex($$[$0 - 7], $$[$0 - 1], "rect", void 0, void 0, void 0, Object.fromEntries([[$$[$0 - 5], $$[$0 - 3]]])); + break; + case 58: + this.$ = $$[$0 - 3]; + yy.addVertex($$[$0 - 3], $$[$0 - 1], "cylinder"); + break; + case 59: + this.$ = $$[$0 - 3]; + yy.addVertex($$[$0 - 3], $$[$0 - 1], "round"); + break; + case 60: + this.$ = $$[$0 - 3]; + yy.addVertex($$[$0 - 3], $$[$0 - 1], "diamond"); + break; + case 61: + this.$ = $$[$0 - 5]; + yy.addVertex($$[$0 - 5], $$[$0 - 2], "hexagon"); + break; + case 62: + this.$ = $$[$0 - 3]; + yy.addVertex($$[$0 - 3], $$[$0 - 1], "odd"); + break; + case 63: + this.$ = $$[$0 - 3]; + yy.addVertex($$[$0 - 3], $$[$0 - 1], "trapezoid"); + break; + case 64: + this.$ = $$[$0 - 3]; + yy.addVertex($$[$0 - 3], $$[$0 - 1], "inv_trapezoid"); + break; + case 65: + this.$ = $$[$0 - 3]; + yy.addVertex($$[$0 - 3], $$[$0 - 1], "lean_right"); + break; + case 66: + this.$ = $$[$0 - 3]; + yy.addVertex($$[$0 - 3], $$[$0 - 1], "lean_left"); + break; + case 67: + this.$ = $$[$0]; + yy.addVertex($$[$0]); + break; + case 68: + $$[$0 - 1].text = $$[$0]; + this.$ = $$[$0 - 1]; + break; + case 69: + case 70: + $$[$0 - 2].text = $$[$0 - 1]; + this.$ = $$[$0 - 2]; + break; + case 71: + this.$ = $$[$0]; + break; + case 72: + var inf = yy.destructLink($$[$0], $$[$0 - 2]); + this.$ = { "type": inf.type, "stroke": inf.stroke, "length": inf.length, "text": $$[$0 - 1] }; + break; + case 73: + this.$ = { text: $$[$0], type: "text" }; + break; + case 74: + this.$ = { text: $$[$0 - 1].text + "" + $$[$0], type: $$[$0 - 1].type }; + break; + case 75: + this.$ = { text: $$[$0], type: "string" }; + break; + case 76: + this.$ = { text: $$[$0], type: "markdown" }; + break; + case 77: + var inf = yy.destructLink($$[$0]); + this.$ = { "type": inf.type, "stroke": inf.stroke, "length": inf.length }; + break; + case 78: + this.$ = $$[$0 - 1]; + break; + case 79: + this.$ = { text: $$[$0], type: "text" }; + break; + case 80: + this.$ = { text: $$[$0 - 1].text + "" + $$[$0], type: $$[$0 - 1].type }; + break; + case 81: + this.$ = { text: $$[$0], type: "string" }; + break; + case 82: + case 97: + this.$ = { text: $$[$0], type: "markdown" }; + break; + case 94: + this.$ = { text: $$[$0], type: "text" }; + break; + case 95: + this.$ = { text: $$[$0 - 1].text + "" + $$[$0], type: $$[$0 - 1].type }; + break; + case 96: + this.$ = { text: $$[$0], type: "text" }; + break; + case 98: + this.$ = $$[$0 - 4]; + yy.addClass($$[$0 - 2], $$[$0]); + break; + case 99: + this.$ = $$[$0 - 4]; + yy.setClass($$[$0 - 2], $$[$0]); + break; + case 100: + case 108: + this.$ = $$[$0 - 1]; + yy.setClickEvent($$[$0 - 1], $$[$0]); + break; + case 101: + case 109: + this.$ = $$[$0 - 3]; + yy.setClickEvent($$[$0 - 3], $$[$0 - 2]); + yy.setTooltip($$[$0 - 3], $$[$0]); + break; + case 102: + this.$ = $$[$0 - 2]; + yy.setClickEvent($$[$0 - 2], $$[$0 - 1], $$[$0]); + break; + case 103: + this.$ = $$[$0 - 4]; + yy.setClickEvent($$[$0 - 4], $$[$0 - 3], $$[$0 - 2]); + yy.setTooltip($$[$0 - 4], $$[$0]); + break; + case 104: + this.$ = $$[$0 - 2]; + yy.setLink($$[$0 - 2], $$[$0]); + break; + case 105: + this.$ = $$[$0 - 4]; + yy.setLink($$[$0 - 4], $$[$0 - 2]); + yy.setTooltip($$[$0 - 4], $$[$0]); + break; + case 106: + this.$ = $$[$0 - 4]; + yy.setLink($$[$0 - 4], $$[$0 - 2], $$[$0]); + break; + case 107: + this.$ = $$[$0 - 6]; + yy.setLink($$[$0 - 6], $$[$0 - 4], $$[$0]); + yy.setTooltip($$[$0 - 6], $$[$0 - 2]); + break; + case 110: + this.$ = $$[$0 - 1]; + yy.setLink($$[$0 - 1], $$[$0]); + break; + case 111: + this.$ = $$[$0 - 3]; + yy.setLink($$[$0 - 3], $$[$0 - 2]); + yy.setTooltip($$[$0 - 3], $$[$0]); + break; + case 112: + this.$ = $$[$0 - 3]; + yy.setLink($$[$0 - 3], $$[$0 - 2], $$[$0]); + break; + case 113: + this.$ = $$[$0 - 5]; + yy.setLink($$[$0 - 5], $$[$0 - 4], $$[$0]); + yy.setTooltip($$[$0 - 5], $$[$0 - 2]); + break; + case 114: + this.$ = $$[$0 - 4]; + yy.addVertex($$[$0 - 2], void 0, void 0, $$[$0]); + break; + case 115: + this.$ = $$[$0 - 4]; + yy.updateLink([$$[$0 - 2]], $$[$0]); + break; + case 116: + this.$ = $$[$0 - 4]; + yy.updateLink($$[$0 - 2], $$[$0]); + break; + case 117: + this.$ = $$[$0 - 8]; + yy.updateLinkInterpolate([$$[$0 - 6]], $$[$0 - 2]); + yy.updateLink([$$[$0 - 6]], $$[$0]); + break; + case 118: + this.$ = $$[$0 - 8]; + yy.updateLinkInterpolate($$[$0 - 6], $$[$0 - 2]); + yy.updateLink($$[$0 - 6], $$[$0]); + break; + case 119: + this.$ = $$[$0 - 6]; + yy.updateLinkInterpolate([$$[$0 - 4]], $$[$0]); + break; + case 120: + this.$ = $$[$0 - 6]; + yy.updateLinkInterpolate($$[$0 - 4], $$[$0]); + break; + case 121: + case 123: + this.$ = [$$[$0]]; + break; + case 122: + case 124: + $$[$0 - 2].push($$[$0]); + this.$ = $$[$0 - 2]; + break; + case 126: + this.$ = $$[$0 - 1] + $$[$0]; + break; + case 174: + this.$ = $$[$0]; + break; + case 175: + this.$ = $$[$0 - 1] + "" + $$[$0]; + break; + case 177: + this.$ = $$[$0 - 1] + "" + $$[$0]; + break; + case 178: + this.$ = { stmt: "dir", value: "TB" }; + break; + case 179: + this.$ = { stmt: "dir", value: "BT" }; + break; + case 180: + this.$ = { stmt: "dir", value: "RL" }; + break; + case 181: + this.$ = { stmt: "dir", value: "LR" }; + break; + } + }, + table: [{ 3: 1, 4: 2, 9: $V0, 10: $V1, 12: $V2 }, { 1: [3] }, o($V3, $V4, { 5: 6 }), { 4: 7, 9: $V0, 10: $V1, 12: $V2 }, { 4: 8, 9: $V0, 10: $V1, 12: $V2 }, { 13: [1, 9], 14: [1, 10] }, { 1: [2, 1], 6: 11, 7: 12, 8: $V5, 9: $V6, 10: $V7, 11: $V8, 20: 17, 22: 18, 23: 19, 24: 20, 25: 21, 26: 22, 27: $V9, 33: 24, 34: $Va, 36: $Vb, 38: $Vc, 40: 28, 41: 38, 42: $Vd, 43: 39, 45: 40, 58: $Ve, 81: $Vf, 82: $Vg, 83: $Vh, 84: $Vi, 85: $Vj, 86: $Vk, 99: $Vl, 102: $Vm, 103: $Vn, 106: $Vo, 108: $Vp, 110: 41, 111: $Vq, 112: $Vr, 113: $Vs, 118: $Vt, 119: $Vu, 120: $Vv, 121: $Vw }, o($V3, [2, 9]), o($V3, [2, 10]), o($V3, [2, 11]), { 8: [1, 54], 9: [1, 55], 10: $Vx, 15: 53, 18: 56 }, o($Vy, [2, 3]), o($Vy, [2, 4]), o($Vy, [2, 5]), o($Vy, [2, 6]), o($Vy, [2, 7]), o($Vy, [2, 8]), { 8: $Vz, 9: $VA, 11: $VB, 21: 58, 39: 59, 70: 63, 73: [1, 64], 75: [1, 65] }, { 8: $Vz, 9: $VA, 11: $VB, 21: 66 }, { 8: $Vz, 9: $VA, 11: $VB, 21: 67 }, { 8: $Vz, 9: $VA, 11: $VB, 21: 68 }, { 8: $Vz, 9: $VA, 11: $VB, 21: 69 }, { 8: $Vz, 9: $VA, 11: $VB, 21: 70 }, { 8: $Vz, 9: $VA, 10: [1, 71], 11: $VB, 21: 72 }, o($Vy, [2, 36]), { 35: [1, 73] }, { 37: [1, 74] }, o($Vy, [2, 39]), o($VC, [2, 46], { 18: 75, 10: $Vx }), { 10: [1, 76] }, { 10: [1, 77] }, { 10: [1, 78] }, { 10: [1, 79] }, { 14: $VD, 42: $VE, 58: $VF, 77: [1, 83], 86: $VG, 92: [1, 80], 94: [1, 81], 98: 82, 102: $VH, 103: $VI, 106: $VJ, 108: $VK, 111: $VL, 112: $VM, 113: $VN, 117: 84 }, o($Vy, [2, 178]), o($Vy, [2, 179]), o($Vy, [2, 180]), o($Vy, [2, 181]), o($VO, [2, 47]), o($VO, [2, 49], { 44: [1, 96] }), o($VP, [2, 67], { 110: 109, 29: [1, 97], 42: $Vd, 46: [1, 98], 48: [1, 99], 50: [1, 100], 52: [1, 101], 54: [1, 102], 56: [1, 103], 58: $Ve, 61: [1, 104], 63: [1, 105], 65: [1, 106], 66: [1, 107], 68: [1, 108], 86: $Vk, 99: $Vl, 102: $Vm, 103: $Vn, 106: $Vo, 108: $Vp, 111: $Vq, 112: $Vr, 113: $Vs }), o($VQ, [2, 174]), o($VQ, [2, 135]), o($VQ, [2, 136]), o($VQ, [2, 137]), o($VQ, [2, 138]), o($VQ, [2, 139]), o($VQ, [2, 140]), o($VQ, [2, 141]), o($VQ, [2, 142]), o($VQ, [2, 143]), o($VQ, [2, 144]), o($VQ, [2, 145]), o($V3, [2, 12]), o($V3, [2, 18]), o($V3, [2, 19]), { 9: [1, 110] }, o($VR, [2, 26], { 18: 111, 10: $Vx }), o($Vy, [2, 27]), { 40: 112, 41: 38, 42: $Vd, 43: 39, 45: 40, 58: $Ve, 86: $Vk, 99: $Vl, 102: $Vm, 103: $Vn, 106: $Vo, 108: $Vp, 110: 41, 111: $Vq, 112: $Vr, 113: $Vs }, o($Vy, [2, 40]), o($Vy, [2, 41]), o($Vy, [2, 42]), o($VS, [2, 71], { 71: 113, 60: [1, 115], 72: [1, 114] }), { 74: 116, 76: 117, 77: [1, 118], 78: [1, 119], 113: $VT, 116: $VU }, o([42, 58, 60, 72, 86, 99, 102, 103, 106, 108, 111, 112, 113], [2, 77]), o($Vy, [2, 28]), o($Vy, [2, 29]), o($Vy, [2, 30]), o($Vy, [2, 31]), o($Vy, [2, 32]), { 10: $VV, 12: $VW, 14: $VX, 27: $VY, 28: 122, 32: $VZ, 42: $V_, 58: $V$, 73: $V01, 77: [1, 124], 78: [1, 125], 80: 135, 81: $V11, 82: $V21, 83: $V31, 84: $V41, 85: $V51, 86: $V61, 87: $V71, 88: 123, 102: $V81, 106: $V91, 108: $Va1, 111: $Vb1, 112: $Vc1, 113: $Vd1 }, o($Ve1, $V4, { 5: 148 }), o($Vy, [2, 37]), o($Vy, [2, 38]), o($VC, [2, 45], { 42: $Vf1 }), { 42: $Vd, 45: 150, 58: $Ve, 86: $Vk, 99: $Vl, 102: $Vm, 103: $Vn, 106: $Vo, 108: $Vp, 110: 41, 111: $Vq, 112: $Vr, 113: $Vs }, { 99: [1, 151], 100: 152, 102: [1, 153] }, { 42: $Vd, 45: 154, 58: $Ve, 86: $Vk, 99: $Vl, 102: $Vm, 103: $Vn, 106: $Vo, 108: $Vp, 110: 41, 111: $Vq, 112: $Vr, 113: $Vs }, { 42: $Vd, 45: 155, 58: $Ve, 86: $Vk, 99: $Vl, 102: $Vm, 103: $Vn, 106: $Vo, 108: $Vp, 110: 41, 111: $Vq, 112: $Vr, 113: $Vs }, o($Vg1, [2, 100], { 10: [1, 156], 93: [1, 157] }), { 77: [1, 158] }, o($Vg1, [2, 108], { 117: 160, 10: [1, 159], 14: $VD, 42: $VE, 58: $VF, 86: $VG, 102: $VH, 103: $VI, 106: $VJ, 108: $VK, 111: $VL, 112: $VM, 113: $VN }), o($Vg1, [2, 110], { 10: [1, 161] }), o($Vh1, [2, 176]), o($Vh1, [2, 163]), o($Vh1, [2, 164]), o($Vh1, [2, 165]), o($Vh1, [2, 166]), o($Vh1, [2, 167]), o($Vh1, [2, 168]), o($Vh1, [2, 169]), o($Vh1, [2, 170]), o($Vh1, [2, 171]), o($Vh1, [2, 172]), o($Vh1, [2, 173]), { 42: $Vd, 45: 162, 58: $Ve, 86: $Vk, 99: $Vl, 102: $Vm, 103: $Vn, 106: $Vo, 108: $Vp, 110: 41, 111: $Vq, 112: $Vr, 113: $Vs }, { 30: 163, 65: $Vi1, 77: $Vj1, 78: $Vk1, 79: 164, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, { 30: 171, 65: $Vi1, 77: $Vj1, 78: $Vk1, 79: 164, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, { 30: 173, 48: [1, 172], 65: $Vi1, 77: $Vj1, 78: $Vk1, 79: 164, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, { 30: 174, 65: $Vi1, 77: $Vj1, 78: $Vk1, 79: 164, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, { 30: 175, 65: $Vi1, 77: $Vj1, 78: $Vk1, 79: 164, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, { 30: 176, 65: $Vi1, 77: $Vj1, 78: $Vk1, 79: 164, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, { 106: [1, 177] }, { 30: 178, 65: $Vi1, 77: $Vj1, 78: $Vk1, 79: 164, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, { 30: 179, 63: [1, 180], 65: $Vi1, 77: $Vj1, 78: $Vk1, 79: 164, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, { 30: 181, 65: $Vi1, 77: $Vj1, 78: $Vk1, 79: 164, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, { 30: 182, 65: $Vi1, 77: $Vj1, 78: $Vk1, 79: 164, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, { 30: 183, 65: $Vi1, 77: $Vj1, 78: $Vk1, 79: 164, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, o($VQ, [2, 175]), o($V3, [2, 20]), o($VR, [2, 25]), o($VC, [2, 43], { 18: 184, 10: $Vx }), o($VS, [2, 68], { 10: [1, 185] }), { 10: [1, 186] }, { 30: 187, 65: $Vi1, 77: $Vj1, 78: $Vk1, 79: 164, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, { 75: [1, 188], 76: 189, 113: $VT, 116: $VU }, o($Vo1, [2, 73]), o($Vo1, [2, 75]), o($Vo1, [2, 76]), o($Vo1, [2, 161]), o($Vo1, [2, 162]), { 8: $Vz, 9: $VA, 10: $VV, 11: $VB, 12: $VW, 14: $VX, 21: 191, 27: $VY, 29: [1, 190], 32: $VZ, 42: $V_, 58: $V$, 73: $V01, 80: 135, 81: $V11, 82: $V21, 83: $V31, 84: $V41, 85: $V51, 86: $V61, 87: $V71, 88: 192, 102: $V81, 106: $V91, 108: $Va1, 111: $Vb1, 112: $Vc1, 113: $Vd1 }, o($Vp1, [2, 94]), o($Vp1, [2, 96]), o($Vp1, [2, 97]), o($Vp1, [2, 150]), o($Vp1, [2, 151]), o($Vp1, [2, 152]), o($Vp1, [2, 153]), o($Vp1, [2, 154]), o($Vp1, [2, 155]), o($Vp1, [2, 156]), o($Vp1, [2, 157]), o($Vp1, [2, 158]), o($Vp1, [2, 159]), o($Vp1, [2, 160]), o($Vp1, [2, 83]), o($Vp1, [2, 84]), o($Vp1, [2, 85]), o($Vp1, [2, 86]), o($Vp1, [2, 87]), o($Vp1, [2, 88]), o($Vp1, [2, 89]), o($Vp1, [2, 90]), o($Vp1, [2, 91]), o($Vp1, [2, 92]), o($Vp1, [2, 93]), { 6: 11, 7: 12, 8: $V5, 9: $V6, 10: $V7, 11: $V8, 20: 17, 22: 18, 23: 19, 24: 20, 25: 21, 26: 22, 27: $V9, 32: [1, 193], 33: 24, 34: $Va, 36: $Vb, 38: $Vc, 40: 28, 41: 38, 42: $Vd, 43: 39, 45: 40, 58: $Ve, 81: $Vf, 82: $Vg, 83: $Vh, 84: $Vi, 85: $Vj, 86: $Vk, 99: $Vl, 102: $Vm, 103: $Vn, 106: $Vo, 108: $Vp, 110: 41, 111: $Vq, 112: $Vr, 113: $Vs, 118: $Vt, 119: $Vu, 120: $Vv, 121: $Vw }, { 10: $Vx, 18: 194 }, { 10: [1, 195], 42: $Vd, 58: $Ve, 86: $Vk, 99: $Vl, 102: $Vm, 103: $Vn, 106: $Vo, 108: $Vp, 110: 109, 111: $Vq, 112: $Vr, 113: $Vs }, { 10: [1, 196] }, { 10: [1, 197], 103: [1, 198] }, o($Vq1, [2, 121]), { 10: [1, 199], 42: $Vd, 58: $Ve, 86: $Vk, 99: $Vl, 102: $Vm, 103: $Vn, 106: $Vo, 108: $Vp, 110: 109, 111: $Vq, 112: $Vr, 113: $Vs }, { 10: [1, 200], 42: $Vd, 58: $Ve, 86: $Vk, 99: $Vl, 102: $Vm, 103: $Vn, 106: $Vo, 108: $Vp, 110: 109, 111: $Vq, 112: $Vr, 113: $Vs }, { 77: [1, 201] }, o($Vg1, [2, 102], { 10: [1, 202] }), o($Vg1, [2, 104], { 10: [1, 203] }), { 77: [1, 204] }, o($Vh1, [2, 177]), { 77: [1, 205], 95: [1, 206] }, o($VO, [2, 50], { 110: 109, 42: $Vd, 58: $Ve, 86: $Vk, 99: $Vl, 102: $Vm, 103: $Vn, 106: $Vo, 108: $Vp, 111: $Vq, 112: $Vr, 113: $Vs }), { 31: [1, 207], 65: $Vi1, 79: 208, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, o($Vr1, [2, 79]), o($Vr1, [2, 81]), o($Vr1, [2, 82]), o($Vr1, [2, 146]), o($Vr1, [2, 147]), o($Vr1, [2, 148]), o($Vr1, [2, 149]), { 47: [1, 209], 65: $Vi1, 79: 208, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, { 30: 210, 65: $Vi1, 77: $Vj1, 78: $Vk1, 79: 164, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, { 49: [1, 211], 65: $Vi1, 79: 208, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, { 51: [1, 212], 65: $Vi1, 79: 208, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, { 53: [1, 213], 65: $Vi1, 79: 208, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, { 55: [1, 214], 65: $Vi1, 79: 208, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, { 58: [1, 215] }, { 62: [1, 216], 65: $Vi1, 79: 208, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, { 64: [1, 217], 65: $Vi1, 79: 208, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, { 30: 218, 65: $Vi1, 77: $Vj1, 78: $Vk1, 79: 164, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, { 31: [1, 219], 65: $Vi1, 79: 208, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, { 65: $Vi1, 67: [1, 220], 69: [1, 221], 79: 208, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, { 65: $Vi1, 67: [1, 223], 69: [1, 222], 79: 208, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, o($VC, [2, 44], { 42: $Vf1 }), o($VS, [2, 70]), o($VS, [2, 69]), { 60: [1, 224], 65: $Vi1, 79: 208, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, o($VS, [2, 72]), o($Vo1, [2, 74]), { 30: 225, 65: $Vi1, 77: $Vj1, 78: $Vk1, 79: 164, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, o($Ve1, $V4, { 5: 226 }), o($Vp1, [2, 95]), o($Vy, [2, 35]), { 41: 227, 42: $Vd, 43: 39, 45: 40, 58: $Ve, 86: $Vk, 99: $Vl, 102: $Vm, 103: $Vn, 106: $Vo, 108: $Vp, 110: 41, 111: $Vq, 112: $Vr, 113: $Vs }, { 10: $Vs1, 58: $Vt1, 81: $Vu1, 89: 228, 102: $Vv1, 104: 229, 105: 230, 106: $Vw1, 107: $Vx1, 108: $Vy1, 109: $Vz1 }, { 10: $Vs1, 58: $Vt1, 81: $Vu1, 89: 239, 101: [1, 240], 102: $Vv1, 104: 229, 105: 230, 106: $Vw1, 107: $Vx1, 108: $Vy1, 109: $Vz1 }, { 10: $Vs1, 58: $Vt1, 81: $Vu1, 89: 241, 101: [1, 242], 102: $Vv1, 104: 229, 105: 230, 106: $Vw1, 107: $Vx1, 108: $Vy1, 109: $Vz1 }, { 102: [1, 243] }, { 10: $Vs1, 58: $Vt1, 81: $Vu1, 89: 244, 102: $Vv1, 104: 229, 105: 230, 106: $Vw1, 107: $Vx1, 108: $Vy1, 109: $Vz1 }, { 42: $Vd, 45: 245, 58: $Ve, 86: $Vk, 99: $Vl, 102: $Vm, 103: $Vn, 106: $Vo, 108: $Vp, 110: 41, 111: $Vq, 112: $Vr, 113: $Vs }, o($Vg1, [2, 101]), { 77: [1, 246] }, { 77: [1, 247], 95: [1, 248] }, o($Vg1, [2, 109]), o($Vg1, [2, 111], { 10: [1, 249] }), o($Vg1, [2, 112]), o($VP, [2, 51]), o($Vr1, [2, 80]), o($VP, [2, 52]), { 49: [1, 250], 65: $Vi1, 79: 208, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, o($VP, [2, 59]), o($VP, [2, 54]), o($VP, [2, 55]), o($VP, [2, 56]), { 106: [1, 251] }, o($VP, [2, 58]), o($VP, [2, 60]), { 64: [1, 252], 65: $Vi1, 79: 208, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, o($VP, [2, 62]), o($VP, [2, 63]), o($VP, [2, 65]), o($VP, [2, 64]), o($VP, [2, 66]), o([10, 42, 58, 86, 99, 102, 103, 106, 108, 111, 112, 113], [2, 78]), { 31: [1, 253], 65: $Vi1, 79: 208, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, { 6: 11, 7: 12, 8: $V5, 9: $V6, 10: $V7, 11: $V8, 20: 17, 22: 18, 23: 19, 24: 20, 25: 21, 26: 22, 27: $V9, 32: [1, 254], 33: 24, 34: $Va, 36: $Vb, 38: $Vc, 40: 28, 41: 38, 42: $Vd, 43: 39, 45: 40, 58: $Ve, 81: $Vf, 82: $Vg, 83: $Vh, 84: $Vi, 85: $Vj, 86: $Vk, 99: $Vl, 102: $Vm, 103: $Vn, 106: $Vo, 108: $Vp, 110: 41, 111: $Vq, 112: $Vr, 113: $Vs, 118: $Vt, 119: $Vu, 120: $Vv, 121: $Vw }, o($VO, [2, 48]), o($Vg1, [2, 114], { 103: $VA1 }), o($VB1, [2, 123], { 105: 256, 10: $Vs1, 58: $Vt1, 81: $Vu1, 102: $Vv1, 106: $Vw1, 107: $Vx1, 108: $Vy1, 109: $Vz1 }), o($VC1, [2, 125]), o($VC1, [2, 127]), o($VC1, [2, 128]), o($VC1, [2, 129]), o($VC1, [2, 130]), o($VC1, [2, 131]), o($VC1, [2, 132]), o($VC1, [2, 133]), o($VC1, [2, 134]), o($Vg1, [2, 115], { 103: $VA1 }), { 10: [1, 257] }, o($Vg1, [2, 116], { 103: $VA1 }), { 10: [1, 258] }, o($Vq1, [2, 122]), o($Vg1, [2, 98], { 103: $VA1 }), o($Vg1, [2, 99], { 110: 109, 42: $Vd, 58: $Ve, 86: $Vk, 99: $Vl, 102: $Vm, 103: $Vn, 106: $Vo, 108: $Vp, 111: $Vq, 112: $Vr, 113: $Vs }), o($Vg1, [2, 103]), o($Vg1, [2, 105], { 10: [1, 259] }), o($Vg1, [2, 106]), { 95: [1, 260] }, { 49: [1, 261] }, { 60: [1, 262] }, { 64: [1, 263] }, { 8: $Vz, 9: $VA, 11: $VB, 21: 264 }, o($Vy, [2, 34]), { 10: $Vs1, 58: $Vt1, 81: $Vu1, 102: $Vv1, 104: 265, 105: 230, 106: $Vw1, 107: $Vx1, 108: $Vy1, 109: $Vz1 }, o($VC1, [2, 126]), { 14: $VD, 42: $VE, 58: $VF, 86: $VG, 98: 266, 102: $VH, 103: $VI, 106: $VJ, 108: $VK, 111: $VL, 112: $VM, 113: $VN, 117: 84 }, { 14: $VD, 42: $VE, 58: $VF, 86: $VG, 98: 267, 102: $VH, 103: $VI, 106: $VJ, 108: $VK, 111: $VL, 112: $VM, 113: $VN, 117: 84 }, { 95: [1, 268] }, o($Vg1, [2, 113]), o($VP, [2, 53]), { 30: 269, 65: $Vi1, 77: $Vj1, 78: $Vk1, 79: 164, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, o($VP, [2, 61]), o($Ve1, $V4, { 5: 270 }), o($VB1, [2, 124], { 105: 256, 10: $Vs1, 58: $Vt1, 81: $Vu1, 102: $Vv1, 106: $Vw1, 107: $Vx1, 108: $Vy1, 109: $Vz1 }), o($Vg1, [2, 119], { 117: 160, 10: [1, 271], 14: $VD, 42: $VE, 58: $VF, 86: $VG, 102: $VH, 103: $VI, 106: $VJ, 108: $VK, 111: $VL, 112: $VM, 113: $VN }), o($Vg1, [2, 120], { 117: 160, 10: [1, 272], 14: $VD, 42: $VE, 58: $VF, 86: $VG, 102: $VH, 103: $VI, 106: $VJ, 108: $VK, 111: $VL, 112: $VM, 113: $VN }), o($Vg1, [2, 107]), { 31: [1, 273], 65: $Vi1, 79: 208, 113: $Vl1, 114: $Vm1, 115: $Vn1 }, { 6: 11, 7: 12, 8: $V5, 9: $V6, 10: $V7, 11: $V8, 20: 17, 22: 18, 23: 19, 24: 20, 25: 21, 26: 22, 27: $V9, 32: [1, 274], 33: 24, 34: $Va, 36: $Vb, 38: $Vc, 40: 28, 41: 38, 42: $Vd, 43: 39, 45: 40, 58: $Ve, 81: $Vf, 82: $Vg, 83: $Vh, 84: $Vi, 85: $Vj, 86: $Vk, 99: $Vl, 102: $Vm, 103: $Vn, 106: $Vo, 108: $Vp, 110: 41, 111: $Vq, 112: $Vr, 113: $Vs, 118: $Vt, 119: $Vu, 120: $Vv, 121: $Vw }, { 10: $Vs1, 58: $Vt1, 81: $Vu1, 89: 275, 102: $Vv1, 104: 229, 105: 230, 106: $Vw1, 107: $Vx1, 108: $Vy1, 109: $Vz1 }, { 10: $Vs1, 58: $Vt1, 81: $Vu1, 89: 276, 102: $Vv1, 104: 229, 105: 230, 106: $Vw1, 107: $Vx1, 108: $Vy1, 109: $Vz1 }, o($VP, [2, 57]), o($Vy, [2, 33]), o($Vg1, [2, 117], { 103: $VA1 }), o($Vg1, [2, 118], { 103: $VA1 })], + defaultActions: {}, + parseError: function parseError(str2, hash) { + if (hash.recoverable) { + this.trace(str2); + } else { + var error = new Error(str2); + error.hash = hash; + throw error; + } + }, + parse: function parse2(input) { + var self2 = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex2() { + var token2; + token2 = tstack.pop() || lexer2.lex() || EOF; + if (typeof token2 !== "number") { + if (token2 instanceof Array) { + tstack = token2; + token2 = tstack.pop(); + } + token2 = self2.symbols_[token2] || token2; + } + return token2; + } + var symbol, state2, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state2 = stack[stack.length - 1]; + if (this.defaultActions[state2]) { + action = this.defaultActions[state2]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex2(); + } + action = table[state2] && table[state2][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state2]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state2 + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str2, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str2, hash); + } else { + throw new Error(str2); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch2 = this._input[0]; + this.yytext += ch2; + this.yyleng++; + this.offset++; + this.match += ch2; + this.matched += ch2; + var lines = ch2.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch2; + }, + // unshifts one char (or a string) into the input + unput: function(ch2) { + var len = ch2.length; + var lines = ch2.split(/(?:\r\n?|\n)/g); + this._input = ch2 + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next2 = this.match; + if (next2.length < 20) { + next2 += this._input.substr(0, 20 - next2.length); + } + return (next2.substr(0, 20) + (next2.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c2 = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c2 + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token2, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token2 = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token2) { + return token2; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token2, match, tempMatch, index2; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i2 = 0; i2 < rules.length; i2++) { + tempMatch = this._input.match(this.rules[rules[i2]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index2 = i2; + if (this.options.backtrack_lexer) { + token2 = this.test_match(tempMatch, rules[i2]); + if (token2 !== false) { + return token2; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token2 = this.test_match(match, rules[index2]); + if (token2 !== false) { + return token2; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex2() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: {}, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + this.begin("acc_title"); + return 34; + case 1: + this.popState(); + return "acc_title_value"; + case 2: + this.begin("acc_descr"); + return 36; + case 3: + this.popState(); + return "acc_descr_value"; + case 4: + this.begin("acc_descr_multiline"); + break; + case 5: + this.popState(); + break; + case 6: + return "acc_descr_multiline_value"; + case 7: + this.begin("callbackname"); + break; + case 8: + this.popState(); + break; + case 9: + this.popState(); + this.begin("callbackargs"); + break; + case 10: + return 92; + case 11: + this.popState(); + break; + case 12: + return 93; + case 13: + return "MD_STR"; + case 14: + this.popState(); + break; + case 15: + this.begin("md_string"); + break; + case 16: + return "STR"; + case 17: + this.popState(); + break; + case 18: + this.pushState("string"); + break; + case 19: + return 81; + case 20: + return 99; + case 21: + return 82; + case 22: + return 101; + case 23: + return 83; + case 24: + return 84; + case 25: + return 94; + case 26: + this.begin("click"); + break; + case 27: + this.popState(); + break; + case 28: + return 85; + case 29: + if (yy.lex.firstGraph()) { + this.begin("dir"); + } + return 12; + case 30: + if (yy.lex.firstGraph()) { + this.begin("dir"); + } + return 12; + case 31: + if (yy.lex.firstGraph()) { + this.begin("dir"); + } + return 12; + case 32: + return 27; + case 33: + return 32; + case 34: + return 95; + case 35: + return 95; + case 36: + return 95; + case 37: + return 95; + case 38: + this.popState(); + return 13; + case 39: + this.popState(); + return 14; + case 40: + this.popState(); + return 14; + case 41: + this.popState(); + return 14; + case 42: + this.popState(); + return 14; + case 43: + this.popState(); + return 14; + case 44: + this.popState(); + return 14; + case 45: + this.popState(); + return 14; + case 46: + this.popState(); + return 14; + case 47: + this.popState(); + return 14; + case 48: + this.popState(); + return 14; + case 49: + return 118; + case 50: + return 119; + case 51: + return 120; + case 52: + return 121; + case 53: + return 102; + case 54: + return 108; + case 55: + return 44; + case 56: + return 58; + case 57: + return 42; + case 58: + return 8; + case 59: + return 103; + case 60: + return 112; + case 61: + this.popState(); + return 75; + case 62: + this.pushState("edgeText"); + return 73; + case 63: + return 116; + case 64: + this.popState(); + return 75; + case 65: + this.pushState("thickEdgeText"); + return 73; + case 66: + return 116; + case 67: + this.popState(); + return 75; + case 68: + this.pushState("dottedEdgeText"); + return 73; + case 69: + return 116; + case 70: + return 75; + case 71: + this.popState(); + return 51; + case 72: + return "TEXT"; + case 73: + this.pushState("ellipseText"); + return 50; + case 74: + this.popState(); + return 53; + case 75: + this.pushState("text"); + return 52; + case 76: + this.popState(); + return 55; + case 77: + this.pushState("text"); + return 54; + case 78: + return 56; + case 79: + this.pushState("text"); + return 65; + case 80: + this.popState(); + return 62; + case 81: + this.pushState("text"); + return 61; + case 82: + this.popState(); + return 47; + case 83: + this.pushState("text"); + return 46; + case 84: + this.popState(); + return 67; + case 85: + this.popState(); + return 69; + case 86: + return 114; + case 87: + this.pushState("trapText"); + return 66; + case 88: + this.pushState("trapText"); + return 68; + case 89: + return 115; + case 90: + return 65; + case 91: + return 87; + case 92: + return "SEP"; + case 93: + return 86; + case 94: + return 112; + case 95: + return 108; + case 96: + return 42; + case 97: + return 106; + case 98: + return 111; + case 99: + return 113; + case 100: + this.popState(); + return 60; + case 101: + this.pushState("text"); + return 60; + case 102: + this.popState(); + return 49; + case 103: + this.pushState("text"); + return 48; + case 104: + this.popState(); + return 31; + case 105: + this.pushState("text"); + return 29; + case 106: + this.popState(); + return 64; + case 107: + this.pushState("text"); + return 63; + case 108: + return "TEXT"; + case 109: + return "QUOTE"; + case 110: + return 9; + case 111: + return 10; + case 112: + return 11; + } + }, + rules: [/^(?:accTitle\s*:\s*)/, /^(?:(?!\n||)*[^\n]*)/, /^(?:accDescr\s*:\s*)/, /^(?:(?!\n||)*[^\n]*)/, /^(?:accDescr\s*\{\s*)/, /^(?:[\}])/, /^(?:[^\}]*)/, /^(?:call[\s]+)/, /^(?:\([\s]*\))/, /^(?:\()/, /^(?:[^(]*)/, /^(?:\))/, /^(?:[^)]*)/, /^(?:[^`"]+)/, /^(?:[`]["])/, /^(?:["][`])/, /^(?:[^"]+)/, /^(?:["])/, /^(?:["])/, /^(?:style\b)/, /^(?:default\b)/, /^(?:linkStyle\b)/, /^(?:interpolate\b)/, /^(?:classDef\b)/, /^(?:class\b)/, /^(?:href[\s])/, /^(?:click[\s]+)/, /^(?:[\s\n])/, /^(?:[^\s\n]*)/, /^(?:flowchart-elk\b)/, /^(?:graph\b)/, /^(?:flowchart\b)/, /^(?:subgraph\b)/, /^(?:end\b\s*)/, /^(?:_self\b)/, /^(?:_blank\b)/, /^(?:_parent\b)/, /^(?:_top\b)/, /^(?:(\r?\n)*\s*\n)/, /^(?:\s*LR\b)/, /^(?:\s*RL\b)/, /^(?:\s*TB\b)/, /^(?:\s*BT\b)/, /^(?:\s*TD\b)/, /^(?:\s*BR\b)/, /^(?:\s*<)/, /^(?:\s*>)/, /^(?:\s*\^)/, /^(?:\s*v\b)/, /^(?:.*direction\s+TB[^\n]*)/, /^(?:.*direction\s+BT[^\n]*)/, /^(?:.*direction\s+RL[^\n]*)/, /^(?:.*direction\s+LR[^\n]*)/, /^(?:[0-9]+)/, /^(?:#)/, /^(?::::)/, /^(?::)/, /^(?:&)/, /^(?:;)/, /^(?:,)/, /^(?:\*)/, /^(?:\s*[xo<]?--+[-xo>]\s*)/, /^(?:\s*[xo<]?--\s*)/, /^(?:[^-]|-(?!-)+)/, /^(?:\s*[xo<]?==+[=xo>]\s*)/, /^(?:\s*[xo<]?==\s*)/, /^(?:[^=]|=(?!))/, /^(?:\s*[xo<]?-?\.+-[xo>]?\s*)/, /^(?:\s*[xo<]?-\.\s*)/, /^(?:[^\.]|\.(?!))/, /^(?:\s*~~[\~]+\s*)/, /^(?:[-/\)][\)])/, /^(?:[^\(\)\[\]\{\}]|!\)+)/, /^(?:\(-)/, /^(?:\]\))/, /^(?:\(\[)/, /^(?:\]\])/, /^(?:\[\[)/, /^(?:\[\|)/, /^(?:>)/, /^(?:\)\])/, /^(?:\[\()/, /^(?:\)\)\))/, /^(?:\(\(\()/, /^(?:[\\(?=\])][\]])/, /^(?:\/(?=\])\])/, /^(?:\/(?!\])|\\(?!\])|[^\\\[\]\(\)\{\}\/]+)/, /^(?:\[\/)/, /^(?:\[\\)/, /^(?:<)/, /^(?:>)/, /^(?:\^)/, /^(?:\\\|)/, /^(?:v\b)/, /^(?:\*)/, /^(?:#)/, /^(?:&)/, /^(?:([A-Za-z0-9!"\#$%&'*+\.`?\\_\/]|-(?=[^\>\-\.])|(?!))+)/, /^(?:-)/, /^(?:[\u00AA\u00B5\u00BA\u00C0-\u00D6\u00D8-\u00F6]|[\u00F8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377]|[\u037A-\u037D\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5]|[\u03F7-\u0481\u048A-\u0527\u0531-\u0556\u0559\u0561-\u0587\u05D0-\u05EA]|[\u05F0-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE]|[\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA]|[\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u08A0]|[\u08A2-\u08AC\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0977]|[\u0979-\u097F\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2]|[\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u0A05-\u0A0A]|[\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39]|[\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8]|[\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0B05-\u0B0C]|[\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C]|[\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99]|[\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0]|[\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C33\u0C35-\u0C39\u0C3D]|[\u0C58\u0C59\u0C60\u0C61\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3]|[\u0CB5-\u0CB9\u0CBD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D05-\u0D0C\u0D0E-\u0D10]|[\u0D12-\u0D3A\u0D3D\u0D4E\u0D60\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1]|[\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81]|[\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3]|[\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6]|[\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A]|[\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081]|[\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D]|[\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0]|[\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310]|[\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F4\u1401-\u166C]|[\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u1700-\u170C\u170E-\u1711]|[\u1720-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7]|[\u17DC\u1820-\u1877\u1880-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191C]|[\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19C1-\u19C7\u1A00-\u1A16]|[\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4B\u1B83-\u1BA0\u1BAE\u1BAF]|[\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1CE9-\u1CEC]|[\u1CEE-\u1CF1\u1CF5\u1CF6\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D]|[\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D]|[\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3]|[\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F]|[\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128]|[\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2183\u2184]|[\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3]|[\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6]|[\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE]|[\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005\u3006\u3031-\u3035\u303B\u303C]|[\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312D]|[\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FCC]|[\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B]|[\uA640-\uA66E\uA67F-\uA697\uA6A0-\uA6E5\uA717-\uA71F\uA722-\uA788]|[\uA78B-\uA78E\uA790-\uA793\uA7A0-\uA7AA\uA7F8-\uA801\uA803-\uA805]|[\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB]|[\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uAA00-\uAA28]|[\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA80-\uAAAF\uAAB1\uAAB5]|[\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4]|[\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E]|[\uABC0-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D]|[\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36]|[\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D]|[\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC]|[\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF]|[\uFFD2-\uFFD7\uFFDA-\uFFDC])/, /^(?:\|)/, /^(?:\|)/, /^(?:\))/, /^(?:\()/, /^(?:\])/, /^(?:\[)/, /^(?:(\}))/, /^(?:\{)/, /^(?:[^\[\]\(\)\{\}\|\"]+)/, /^(?:")/, /^(?:(\r?\n)+)/, /^(?:\s)/, /^(?:$)/], + conditions: { "callbackargs": { "rules": [11, 12, 15, 18, 70, 73, 75, 77, 81, 83, 87, 88, 101, 103, 105, 107], "inclusive": false }, "callbackname": { "rules": [8, 9, 10, 15, 18, 70, 73, 75, 77, 81, 83, 87, 88, 101, 103, 105, 107], "inclusive": false }, "href": { "rules": [15, 18, 70, 73, 75, 77, 81, 83, 87, 88, 101, 103, 105, 107], "inclusive": false }, "click": { "rules": [15, 18, 27, 28, 70, 73, 75, 77, 81, 83, 87, 88, 101, 103, 105, 107], "inclusive": false }, "dottedEdgeText": { "rules": [15, 18, 67, 69, 70, 73, 75, 77, 81, 83, 87, 88, 101, 103, 105, 107], "inclusive": false }, "thickEdgeText": { "rules": [15, 18, 64, 66, 70, 73, 75, 77, 81, 83, 87, 88, 101, 103, 105, 107], "inclusive": false }, "edgeText": { "rules": [15, 18, 61, 63, 70, 73, 75, 77, 81, 83, 87, 88, 101, 103, 105, 107], "inclusive": false }, "trapText": { "rules": [15, 18, 70, 73, 75, 77, 81, 83, 84, 85, 86, 87, 88, 101, 103, 105, 107], "inclusive": false }, "ellipseText": { "rules": [15, 18, 70, 71, 72, 73, 75, 77, 81, 83, 87, 88, 101, 103, 105, 107], "inclusive": false }, "text": { "rules": [15, 18, 70, 73, 74, 75, 76, 77, 80, 81, 82, 83, 87, 88, 100, 101, 102, 103, 104, 105, 106, 107, 108], "inclusive": false }, "vertex": { "rules": [15, 18, 70, 73, 75, 77, 81, 83, 87, 88, 101, 103, 105, 107], "inclusive": false }, "dir": { "rules": [15, 18, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 70, 73, 75, 77, 81, 83, 87, 88, 101, 103, 105, 107], "inclusive": false }, "acc_descr_multiline": { "rules": [5, 6, 15, 18, 70, 73, 75, 77, 81, 83, 87, 88, 101, 103, 105, 107], "inclusive": false }, "acc_descr": { "rules": [3, 15, 18, 70, 73, 75, 77, 81, 83, 87, 88, 101, 103, 105, 107], "inclusive": false }, "acc_title": { "rules": [1, 15, 18, 70, 73, 75, 77, 81, 83, 87, 88, 101, 103, 105, 107], "inclusive": false }, "md_string": { "rules": [13, 14, 15, 18, 70, 73, 75, 77, 81, 83, 87, 88, 101, 103, 105, 107], "inclusive": false }, "string": { "rules": [15, 16, 17, 18, 70, 73, 75, 77, 81, 83, 87, 88, 101, 103, 105, 107], "inclusive": false }, "INITIAL": { "rules": [0, 2, 4, 7, 15, 18, 19, 20, 21, 22, 23, 24, 25, 26, 29, 30, 31, 32, 33, 34, 35, 36, 37, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 64, 65, 67, 68, 70, 73, 75, 77, 78, 79, 81, 83, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 101, 103, 105, 107, 109, 110, 111, 112], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser2() { + this.yy = {}; + } + Parser2.prototype = parser2; + parser2.Parser = Parser2; + return new Parser2(); + }(); + parser$t.parser = parser$t; + const parser$u = parser$t; + const MERMAID_DOM_ID_PREFIX$1 = "flowchart-"; + let vertexCounter = 0; + let config$3 = getConfig$1(); + let vertices = {}; + let edges = []; + let classes$3 = {}; + let subGraphs = []; + let subGraphLookup = {}; + let tooltips = {}; + let subCount = 0; + let firstGraphFlag = true; + let direction$3; + let version; + let funs$1 = []; + const sanitizeText$3 = (txt) => common$1.sanitizeText(txt, config$3); + const lookUpDomId$1 = function(id2) { + const vertexKeys = Object.keys(vertices); + for (const vertexKey of vertexKeys) { + if (vertices[vertexKey].id === id2) { + return vertices[vertexKey].domId; + } + } + return id2; + }; + const addVertex = function(_id, textObj, type2, style, classes2, dir2, props = {}) { + let txt; + let id2 = _id; + if (id2 === void 0) { + return; + } + if (id2.trim().length === 0) { + return; + } + if (vertices[id2] === void 0) { + vertices[id2] = { + id: id2, + labelType: "text", + domId: MERMAID_DOM_ID_PREFIX$1 + id2 + "-" + vertexCounter, + styles: [], + classes: [] + }; + } + vertexCounter++; + if (textObj !== void 0) { + config$3 = getConfig$1(); + txt = sanitizeText$3(textObj.text.trim()); + vertices[id2].labelType = textObj.type; + if (txt[0] === '"' && txt[txt.length - 1] === '"') { + txt = txt.substring(1, txt.length - 1); + } + vertices[id2].text = txt; + } else { + if (vertices[id2].text === void 0) { + vertices[id2].text = _id; + } + } + if (type2 !== void 0) { + vertices[id2].type = type2; + } + if (style !== void 0 && style !== null) { + style.forEach(function(s) { + vertices[id2].styles.push(s); + }); + } + if (classes2 !== void 0 && classes2 !== null) { + classes2.forEach(function(s) { + vertices[id2].classes.push(s); + }); + } + if (dir2 !== void 0) { + vertices[id2].dir = dir2; + } + if (vertices[id2].props === void 0) { + vertices[id2].props = props; + } else if (props !== void 0) { + Object.assign(vertices[id2].props, props); + } + }; + const addSingleLink = function(_start, _end, type2) { + let start2 = _start; + let end2 = _end; + const edge = { start: start2, end: end2, type: void 0, text: "", labelType: "text" }; + log$1.info("abc78 Got edge...", edge); + const linkTextObj = type2.text; + if (linkTextObj !== void 0) { + edge.text = sanitizeText$3(linkTextObj.text.trim()); + if (edge.text[0] === '"' && edge.text[edge.text.length - 1] === '"') { + edge.text = edge.text.substring(1, edge.text.length - 1); + } + edge.labelType = linkTextObj.type; + } + if (type2 !== void 0) { + edge.type = type2.type; + edge.stroke = type2.stroke; + edge.length = type2.length; + } + if ((edge == null ? void 0 : edge.length) > 10) { + edge.length = 10; + } + if (edges.length < (config$3.maxEdges ?? 500)) { + log$1.info("abc78 pushing edge..."); + edges.push(edge); + } else { + throw new Error( + `Edge limit exceeded. ${edges.length} edges found, but the limit is ${config$3.maxEdges}. + +Initialize mermaid with maxEdges set to a higher number to allow more edges. +You cannot set this config via configuration inside the diagram as it is a secure config. +You have to call mermaid.initialize.` + ); + } + }; + const addLink$1 = function(_start, _end, type2) { + log$1.info("addLink (abc78)", _start, _end, type2); + let i2, j; + for (i2 = 0; i2 < _start.length; i2++) { + for (j = 0; j < _end.length; j++) { + addSingleLink(_start[i2], _end[j], type2); + } + } + }; + const updateLinkInterpolate = function(positions, interp) { + positions.forEach(function(pos) { + if (pos === "default") { + edges.defaultInterpolate = interp; + } else { + edges[pos].interpolate = interp; + } + }); + }; + const updateLink = function(positions, style) { + positions.forEach(function(pos) { + if (pos >= edges.length) { + throw new Error( + `The index ${pos} for linkStyle is out of bounds. Valid indices for linkStyle are between 0 and ${edges.length - 1}. (Help: Ensure that the index is within the range of existing edges.)` + ); + } + if (pos === "default") { + edges.defaultStyle = style; + } else { + if (utils$1.isSubstringInArray("fill", style) === -1) { + style.push("fill:none"); + } + edges[pos].style = style; + } + }); + }; + const addClass$1 = function(ids, style) { + ids.split(",").forEach(function(id2) { + if (classes$3[id2] === void 0) { + classes$3[id2] = { id: id2, styles: [], textStyles: [] }; + } + if (style !== void 0 && style !== null) { + style.forEach(function(s) { + if (s.match("color")) { + const newStyle = s.replace("fill", "bgFill").replace("color", "fill"); + classes$3[id2].textStyles.push(newStyle); + } + classes$3[id2].styles.push(s); + }); + } + }); + }; + const setDirection$3 = function(dir2) { + direction$3 = dir2; + if (direction$3.match(/.*/)) { + direction$3 = "LR"; + } + if (direction$3.match(/.*v/)) { + direction$3 = "TB"; + } + if (direction$3 === "TD") { + direction$3 = "TB"; + } + }; + const setClass$1 = function(ids, className) { + ids.split(",").forEach(function(_id) { + let id2 = _id; + if (vertices[id2] !== void 0) { + vertices[id2].classes.push(className); + } + if (subGraphLookup[id2] !== void 0) { + subGraphLookup[id2].classes.push(className); + } + }); + }; + const setTooltip$1 = function(ids, tooltip) { + ids.split(",").forEach(function(id2) { + if (tooltip !== void 0) { + tooltips[version === "gen-1" ? lookUpDomId$1(id2) : id2] = sanitizeText$3(tooltip); + } + }); + }; + const setClickFun$1 = function(id2, functionName, functionArgs) { + let domId = lookUpDomId$1(id2); + if (getConfig$1().securityLevel !== "loose") { + return; + } + if (functionName === void 0) { + return; + } + let argList = []; + if (typeof functionArgs === "string") { + argList = functionArgs.split(/,(?=(?:(?:[^"]*"){2})*[^"]*$)/); + for (let i2 = 0; i2 < argList.length; i2++) { + let item = argList[i2].trim(); + if (item.charAt(0) === '"' && item.charAt(item.length - 1) === '"') { + item = item.substr(1, item.length - 2); + } + argList[i2] = item; + } + } + if (argList.length === 0) { + argList.push(id2); + } + if (vertices[id2] !== void 0) { + vertices[id2].haveCallback = true; + funs$1.push(function() { + const elem = document.querySelector(`[id="${domId}"]`); + if (elem !== null) { + elem.addEventListener( + "click", + function() { + utils$1.runFunc(functionName, ...argList); + }, + false + ); + } + }); + } + }; + const setLink$2 = function(ids, linkStr, target) { + ids.split(",").forEach(function(id2) { + if (vertices[id2] !== void 0) { + vertices[id2].link = utils$1.formatUrl(linkStr, config$3); + vertices[id2].linkTarget = target; + } + }); + setClass$1(ids, "clickable"); + }; + const getTooltip$1 = function(id2) { + if (tooltips.hasOwnProperty(id2)) { + return tooltips[id2]; + } + return void 0; + }; + const setClickEvent$2 = function(ids, functionName, functionArgs) { + ids.split(",").forEach(function(id2) { + setClickFun$1(id2, functionName, functionArgs); + }); + setClass$1(ids, "clickable"); + }; + const bindFunctions$2 = function(element2) { + funs$1.forEach(function(fun) { + fun(element2); + }); + }; + const getDirection$3 = function() { + return direction$3.trim(); + }; + const getVertices = function() { + return vertices; + }; + const getEdges$1 = function() { + return edges; + }; + const getClasses$8 = function() { + return classes$3; + }; + const setupToolTips$1 = function(element2) { + let tooltipElem = d3select(".mermaidTooltip"); + if ((tooltipElem._groups || tooltipElem)[0][0] === null) { + tooltipElem = d3select("body").append("div").attr("class", "mermaidTooltip").style("opacity", 0); + } + const svg2 = d3select(element2).select("svg"); + const nodes2 = svg2.selectAll("g.node"); + nodes2.on("mouseover", function() { + const el = d3select(this); + const title2 = el.attr("title"); + if (title2 === null) { + return; + } + const rect2 = this.getBoundingClientRect(); + tooltipElem.transition().duration(200).style("opacity", ".9"); + tooltipElem.text(el.attr("title")).style("left", window.scrollX + rect2.left + (rect2.right - rect2.left) / 2 + "px").style("top", window.scrollY + rect2.bottom + "px"); + tooltipElem.html(tooltipElem.html().replace(/<br\/>/g, "
    ")); + el.classed("hover", true); + }).on("mouseout", function() { + tooltipElem.transition().duration(500).style("opacity", 0); + const el = d3select(this); + el.classed("hover", false); + }); + }; + funs$1.push(setupToolTips$1); + const clear$l = function(ver = "gen-1") { + vertices = {}; + classes$3 = {}; + edges = []; + funs$1 = [setupToolTips$1]; + subGraphs = []; + subGraphLookup = {}; + subCount = 0; + tooltips = {}; + firstGraphFlag = true; + version = ver; + config$3 = getConfig$1(); + clear$n(); + }; + const setGen = (ver) => { + version = ver || "gen-2"; + }; + const defaultStyle = function() { + return "fill:#ffa;stroke: #f66; stroke-width: 3px; stroke-dasharray: 5, 5;fill:#ffa;stroke: #666;"; + }; + const addSubGraph = function(_id, list2, _title) { + let id2 = _id.text.trim(); + let title2 = _title.text; + if (_id === _title && _title.text.match(/\s/)) { + id2 = void 0; + } + function uniq(a) { + const prims = { boolean: {}, number: {}, string: {} }; + const objs = []; + let dir3; + const nodeList2 = a.filter(function(item) { + const type2 = typeof item; + if (item.stmt && item.stmt === "dir") { + dir3 = item.value; + return false; + } + if (item.trim() === "") { + return false; + } + if (type2 in prims) { + return prims[type2].hasOwnProperty(item) ? false : prims[type2][item] = true; + } else { + return objs.includes(item) ? false : objs.push(item); + } + }); + return { nodeList: nodeList2, dir: dir3 }; + } + let nodeList = []; + const { nodeList: nl, dir: dir2 } = uniq(nodeList.concat.apply(nodeList, list2)); + nodeList = nl; + if (version === "gen-1") { + for (let i2 = 0; i2 < nodeList.length; i2++) { + nodeList[i2] = lookUpDomId$1(nodeList[i2]); + } + } + id2 = id2 || "subGraph" + subCount; + title2 = title2 || ""; + title2 = sanitizeText$3(title2); + subCount = subCount + 1; + const subGraph = { + id: id2, + nodes: nodeList, + title: title2.trim(), + classes: [], + dir: dir2, + labelType: _title.type + }; + log$1.info("Adding", subGraph.id, subGraph.nodes, subGraph.dir); + subGraph.nodes = makeUniq(subGraph, subGraphs).nodes; + subGraphs.push(subGraph); + subGraphLookup[id2] = subGraph; + return id2; + }; + const getPosForId = function(id2) { + for (const [i2, subGraph] of subGraphs.entries()) { + if (subGraph.id === id2) { + return i2; + } + } + return -1; + }; + let secCount = -1; + const posCrossRef = []; + const indexNodes2 = function(id2, pos) { + const nodes2 = subGraphs[pos].nodes; + secCount = secCount + 1; + if (secCount > 2e3) { + return; + } + posCrossRef[secCount] = pos; + if (subGraphs[pos].id === id2) { + return { + result: true, + count: 0 + }; + } + let count = 0; + let posCount = 1; + while (count < nodes2.length) { + const childPos = getPosForId(nodes2[count]); + if (childPos >= 0) { + const res = indexNodes2(id2, childPos); + if (res.result) { + return { + result: true, + count: posCount + res.count + }; + } else { + posCount = posCount + res.count; + } + } + count = count + 1; + } + return { + result: false, + count: posCount + }; + }; + const getDepthFirstPos = function(pos) { + return posCrossRef[pos]; + }; + const indexNodes = function() { + secCount = -1; + if (subGraphs.length > 0) { + indexNodes2("none", subGraphs.length - 1); + } + }; + const getSubGraphs = function() { + return subGraphs; + }; + const firstGraph = () => { + if (firstGraphFlag) { + firstGraphFlag = false; + return true; + } + return false; + }; + const destructStartLink = (_str) => { + let str2 = _str.trim(); + let type2 = "arrow_open"; + switch (str2[0]) { + case "<": + type2 = "arrow_point"; + str2 = str2.slice(1); + break; + case "x": + type2 = "arrow_cross"; + str2 = str2.slice(1); + break; + case "o": + type2 = "arrow_circle"; + str2 = str2.slice(1); + break; + } + let stroke = "normal"; + if (str2.includes("=")) { + stroke = "thick"; + } + if (str2.includes(".")) { + stroke = "dotted"; + } + return { type: type2, stroke }; + }; + const countChar = (char2, str2) => { + const length2 = str2.length; + let count = 0; + for (let i2 = 0; i2 < length2; ++i2) { + if (str2[i2] === char2) { + ++count; + } + } + return count; + }; + const destructEndLink = (_str) => { + const str2 = _str.trim(); + let line2 = str2.slice(0, -1); + let type2 = "arrow_open"; + switch (str2.slice(-1)) { + case "x": + type2 = "arrow_cross"; + if (str2[0] === "x") { + type2 = "double_" + type2; + line2 = line2.slice(1); + } + break; + case ">": + type2 = "arrow_point"; + if (str2[0] === "<") { + type2 = "double_" + type2; + line2 = line2.slice(1); + } + break; + case "o": + type2 = "arrow_circle"; + if (str2[0] === "o") { + type2 = "double_" + type2; + line2 = line2.slice(1); + } + break; + } + let stroke = "normal"; + let length2 = line2.length - 1; + if (line2[0] === "=") { + stroke = "thick"; + } + if (line2[0] === "~") { + stroke = "invisible"; + } + let dots = countChar(".", line2); + if (dots) { + stroke = "dotted"; + length2 = dots; + } + return { type: type2, stroke, length: length2 }; + }; + const destructLink = (_str, _startStr) => { + const info2 = destructEndLink(_str); + let startInfo; + if (_startStr) { + startInfo = destructStartLink(_startStr); + if (startInfo.stroke !== info2.stroke) { + return { type: "INVALID", stroke: "INVALID" }; + } + if (startInfo.type === "arrow_open") { + startInfo.type = info2.type; + } else { + if (startInfo.type !== info2.type) { + return { type: "INVALID", stroke: "INVALID" }; + } + startInfo.type = "double_" + startInfo.type; + } + if (startInfo.type === "double_arrow") { + startInfo.type = "double_arrow_point"; + } + startInfo.length = info2.length; + return startInfo; + } + return info2; + }; + const exists = (allSgs, _id) => { + let res = false; + allSgs.forEach((sg) => { + const pos = sg.nodes.indexOf(_id); + if (pos >= 0) { + res = true; + } + }); + return res; + }; + const makeUniq = (sg, allSubgraphs) => { + const res = []; + sg.nodes.forEach((_id, pos) => { + if (!exists(allSubgraphs, _id)) { + res.push(sg.nodes[pos]); + } + }); + return { nodes: res }; + }; + const lex = { + firstGraph + }; + const flowDb = { + defaultConfig: () => defaultConfig.flowchart, + setAccTitle, + getAccTitle, + getAccDescription, + setAccDescription, + addVertex, + lookUpDomId: lookUpDomId$1, + addLink: addLink$1, + updateLinkInterpolate, + updateLink, + addClass: addClass$1, + setDirection: setDirection$3, + setClass: setClass$1, + setTooltip: setTooltip$1, + getTooltip: getTooltip$1, + setClickEvent: setClickEvent$2, + setLink: setLink$2, + bindFunctions: bindFunctions$2, + getDirection: getDirection$3, + getVertices, + getEdges: getEdges$1, + getClasses: getClasses$8, + clear: clear$l, + setGen, + defaultStyle, + addSubGraph, + getDepthFirstPos, + indexNodes, + getSubGraphs, + destructLink, + lex, + exists, + makeUniq, + setDiagramTitle, + getDiagramTitle + }; + const db$f = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + addClass: addClass$1, + addLink: addLink$1, + addSingleLink, + addSubGraph, + addVertex, + bindFunctions: bindFunctions$2, + clear: clear$l, + default: flowDb, + defaultStyle, + destructLink, + firstGraph, + getClasses: getClasses$8, + getDepthFirstPos, + getDirection: getDirection$3, + getEdges: getEdges$1, + getSubGraphs, + getTooltip: getTooltip$1, + getVertices, + indexNodes, + lex, + lookUpDomId: lookUpDomId$1, + setClass: setClass$1, + setClickEvent: setClickEvent$2, + setDirection: setDirection$3, + setGen, + setLink: setLink$2, + updateLink, + updateLinkInterpolate + }, Symbol.toStringTag, { value: "Module" })); + var symbolTag$3 = "[object Symbol]"; + function isSymbol(value2) { + return typeof value2 == "symbol" || isObjectLike(value2) && baseGetTag(value2) == symbolTag$3; + } + function arrayMap(array2, iteratee) { + var index2 = -1, length2 = array2 == null ? 0 : array2.length, result = Array(length2); + while (++index2 < length2) { + result[index2] = iteratee(array2[index2], index2, array2); + } + return result; + } + var INFINITY$3 = 1 / 0; + var symbolProto$2 = Symbol$2 ? Symbol$2.prototype : void 0, symbolToString = symbolProto$2 ? symbolProto$2.toString : void 0; + function baseToString(value2) { + if (typeof value2 == "string") { + return value2; + } + if (isArray$1(value2)) { + return arrayMap(value2, baseToString) + ""; + } + if (isSymbol(value2)) { + return symbolToString ? symbolToString.call(value2) : ""; + } + var result = value2 + ""; + return result == "0" && 1 / value2 == -INFINITY$3 ? "-0" : result; + } + var reWhitespace = /\s/; + function trimmedEndIndex(string2) { + var index2 = string2.length; + while (index2-- && reWhitespace.test(string2.charAt(index2))) { + } + return index2; + } + var reTrimStart = /^\s+/; + function baseTrim(string2) { + return string2 ? string2.slice(0, trimmedEndIndex(string2) + 1).replace(reTrimStart, "") : string2; + } + var NAN = 0 / 0; + var reIsBadHex = /^[-+]0x[0-9a-f]+$/i; + var reIsBinary = /^0b[01]+$/i; + var reIsOctal = /^0o[0-7]+$/i; + var freeParseInt = parseInt; + function toNumber(value2) { + if (typeof value2 == "number") { + return value2; + } + if (isSymbol(value2)) { + return NAN; + } + if (isObject$1(value2)) { + var other = typeof value2.valueOf == "function" ? value2.valueOf() : value2; + value2 = isObject$1(other) ? other + "" : other; + } + if (typeof value2 != "string") { + return value2 === 0 ? value2 : +value2; + } + value2 = baseTrim(value2); + var isBinary2 = reIsBinary.test(value2); + return isBinary2 || reIsOctal.test(value2) ? freeParseInt(value2.slice(2), isBinary2 ? 2 : 8) : reIsBadHex.test(value2) ? NAN : +value2; + } + var INFINITY$2 = 1 / 0, MAX_INTEGER = 17976931348623157e292; + function toFinite(value2) { + if (!value2) { + return value2 === 0 ? value2 : 0; + } + value2 = toNumber(value2); + if (value2 === INFINITY$2 || value2 === -INFINITY$2) { + var sign2 = value2 < 0 ? -1 : 1; + return sign2 * MAX_INTEGER; + } + return value2 === value2 ? value2 : 0; + } + function toInteger(value2) { + var result = toFinite(value2), remainder = result % 1; + return result === result ? remainder ? result - remainder : result : 0; + } + function noop() { + } + function arrayEach(array2, iteratee) { + var index2 = -1, length2 = array2 == null ? 0 : array2.length; + while (++index2 < length2) { + if (iteratee(array2[index2], index2, array2) === false) { + break; + } + } + return array2; + } + function baseFindIndex(array2, predicate, fromIndex, fromRight) { + var length2 = array2.length, index2 = fromIndex + (fromRight ? 1 : -1); + while (fromRight ? index2-- : ++index2 < length2) { + if (predicate(array2[index2], index2, array2)) { + return index2; + } + } + return -1; + } + function baseIsNaN(value2) { + return value2 !== value2; + } + function strictIndexOf(array2, value2, fromIndex) { + var index2 = fromIndex - 1, length2 = array2.length; + while (++index2 < length2) { + if (array2[index2] === value2) { + return index2; + } + } + return -1; + } + function baseIndexOf(array2, value2, fromIndex) { + return value2 === value2 ? strictIndexOf(array2, value2, fromIndex) : baseFindIndex(array2, baseIsNaN, fromIndex); + } + function arrayIncludes(array2, value2) { + var length2 = array2 == null ? 0 : array2.length; + return !!length2 && baseIndexOf(array2, value2, 0) > -1; + } + function keys$1(object2) { + return isArrayLike(object2) ? arrayLikeKeys(object2) : baseKeys(object2); + } + var reIsDeepProp = /\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/, reIsPlainProp = /^\w*$/; + function isKey(value2, object2) { + if (isArray$1(value2)) { + return false; + } + var type2 = typeof value2; + if (type2 == "number" || type2 == "symbol" || type2 == "boolean" || value2 == null || isSymbol(value2)) { + return true; + } + return reIsPlainProp.test(value2) || !reIsDeepProp.test(value2) || object2 != null && value2 in Object(object2); + } + var MAX_MEMOIZE_SIZE = 500; + function memoizeCapped(func) { + var result = memoize(func, function(key) { + if (cache.size === MAX_MEMOIZE_SIZE) { + cache.clear(); + } + return key; + }); + var cache = result.cache; + return result; + } + var rePropName = /[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g; + var reEscapeChar = /\\(\\)?/g; + var stringToPath = memoizeCapped(function(string2) { + var result = []; + if (string2.charCodeAt(0) === 46) { + result.push(""); + } + string2.replace(rePropName, function(match, number2, quote, subString) { + result.push(quote ? subString.replace(reEscapeChar, "$1") : number2 || match); + }); + return result; + }); + const stringToPath$1 = stringToPath; + function toString$1(value2) { + return value2 == null ? "" : baseToString(value2); + } + function castPath(value2, object2) { + if (isArray$1(value2)) { + return value2; + } + return isKey(value2, object2) ? [value2] : stringToPath$1(toString$1(value2)); + } + var INFINITY$1 = 1 / 0; + function toKey(value2) { + if (typeof value2 == "string" || isSymbol(value2)) { + return value2; + } + var result = value2 + ""; + return result == "0" && 1 / value2 == -INFINITY$1 ? "-0" : result; + } + function baseGet(object2, path2) { + path2 = castPath(path2, object2); + var index2 = 0, length2 = path2.length; + while (object2 != null && index2 < length2) { + object2 = object2[toKey(path2[index2++])]; + } + return index2 && index2 == length2 ? object2 : void 0; + } + function get$1(object2, path2, defaultValue) { + var result = object2 == null ? void 0 : baseGet(object2, path2); + return result === void 0 ? defaultValue : result; + } + function arrayPush(array2, values2) { + var index2 = -1, length2 = values2.length, offset = array2.length; + while (++index2 < length2) { + array2[offset + index2] = values2[index2]; + } + return array2; + } + var spreadableSymbol = Symbol$2 ? Symbol$2.isConcatSpreadable : void 0; + function isFlattenable(value2) { + return isArray$1(value2) || isArguments$1(value2) || !!(spreadableSymbol && value2 && value2[spreadableSymbol]); + } + function baseFlatten(array2, depth, predicate, isStrict, result) { + var index2 = -1, length2 = array2.length; + predicate || (predicate = isFlattenable); + result || (result = []); + while (++index2 < length2) { + var value2 = array2[index2]; + if (depth > 0 && predicate(value2)) { + if (depth > 1) { + baseFlatten(value2, depth - 1, predicate, isStrict, result); + } else { + arrayPush(result, value2); + } + } else if (!isStrict) { + result[result.length] = value2; + } + } + return result; + } + function flatten(array2) { + var length2 = array2 == null ? 0 : array2.length; + return length2 ? baseFlatten(array2, 1) : []; + } + function flatRest(func) { + return setToString$1(overRest(func, void 0, flatten), func + ""); + } + function arrayReduce(array2, iteratee, accumulator, initAccum) { + var index2 = -1, length2 = array2 == null ? 0 : array2.length; + if (initAccum && length2) { + accumulator = array2[++index2]; + } + while (++index2 < length2) { + accumulator = iteratee(accumulator, array2[index2], index2, array2); + } + return accumulator; + } + function baseAssign(object2, source) { + return object2 && copyObject(source, keys$1(source), object2); + } + function baseAssignIn(object2, source) { + return object2 && copyObject(source, keysIn(source), object2); + } + function arrayFilter(array2, predicate) { + var index2 = -1, length2 = array2 == null ? 0 : array2.length, resIndex = 0, result = []; + while (++index2 < length2) { + var value2 = array2[index2]; + if (predicate(value2, index2, array2)) { + result[resIndex++] = value2; + } + } + return result; + } + function stubArray() { + return []; + } + var objectProto$5 = Object.prototype; + var propertyIsEnumerable = objectProto$5.propertyIsEnumerable; + var nativeGetSymbols$1 = Object.getOwnPropertySymbols; + var getSymbols = !nativeGetSymbols$1 ? stubArray : function(object2) { + if (object2 == null) { + return []; + } + object2 = Object(object2); + return arrayFilter(nativeGetSymbols$1(object2), function(symbol) { + return propertyIsEnumerable.call(object2, symbol); + }); + }; + const getSymbols$1 = getSymbols; + function copySymbols(source, object2) { + return copyObject(source, getSymbols$1(source), object2); + } + var nativeGetSymbols = Object.getOwnPropertySymbols; + var getSymbolsIn = !nativeGetSymbols ? stubArray : function(object2) { + var result = []; + while (object2) { + arrayPush(result, getSymbols$1(object2)); + object2 = getPrototype$1(object2); + } + return result; + }; + const getSymbolsIn$1 = getSymbolsIn; + function copySymbolsIn(source, object2) { + return copyObject(source, getSymbolsIn$1(source), object2); + } + function baseGetAllKeys(object2, keysFunc, symbolsFunc) { + var result = keysFunc(object2); + return isArray$1(object2) ? result : arrayPush(result, symbolsFunc(object2)); + } + function getAllKeys(object2) { + return baseGetAllKeys(object2, keys$1, getSymbols$1); + } + function getAllKeysIn(object2) { + return baseGetAllKeys(object2, keysIn, getSymbolsIn$1); + } + var objectProto$4 = Object.prototype; + var hasOwnProperty$5 = objectProto$4.hasOwnProperty; + function initCloneArray(array2) { + var length2 = array2.length, result = new array2.constructor(length2); + if (length2 && typeof array2[0] == "string" && hasOwnProperty$5.call(array2, "index")) { + result.index = array2.index; + result.input = array2.input; + } + return result; + } + function cloneDataView(dataView, isDeep) { + var buffer = isDeep ? cloneArrayBuffer(dataView.buffer) : dataView.buffer; + return new dataView.constructor(buffer, dataView.byteOffset, dataView.byteLength); + } + var reFlags = /\w*$/; + function cloneRegExp(regexp) { + var result = new regexp.constructor(regexp.source, reFlags.exec(regexp)); + result.lastIndex = regexp.lastIndex; + return result; + } + var symbolProto$1 = Symbol$2 ? Symbol$2.prototype : void 0, symbolValueOf$1 = symbolProto$1 ? symbolProto$1.valueOf : void 0; + function cloneSymbol(symbol) { + return symbolValueOf$1 ? Object(symbolValueOf$1.call(symbol)) : {}; + } + var boolTag$2 = "[object Boolean]", dateTag$2 = "[object Date]", mapTag$3 = "[object Map]", numberTag$2 = "[object Number]", regexpTag$2 = "[object RegExp]", setTag$3 = "[object Set]", stringTag$2 = "[object String]", symbolTag$2 = "[object Symbol]"; + var arrayBufferTag$2 = "[object ArrayBuffer]", dataViewTag$2 = "[object DataView]", float32Tag$1 = "[object Float32Array]", float64Tag$1 = "[object Float64Array]", int8Tag$1 = "[object Int8Array]", int16Tag$1 = "[object Int16Array]", int32Tag$1 = "[object Int32Array]", uint8Tag$1 = "[object Uint8Array]", uint8ClampedTag$1 = "[object Uint8ClampedArray]", uint16Tag$1 = "[object Uint16Array]", uint32Tag$1 = "[object Uint32Array]"; + function initCloneByTag(object2, tag, isDeep) { + var Ctor = object2.constructor; + switch (tag) { + case arrayBufferTag$2: + return cloneArrayBuffer(object2); + case boolTag$2: + case dateTag$2: + return new Ctor(+object2); + case dataViewTag$2: + return cloneDataView(object2, isDeep); + case float32Tag$1: + case float64Tag$1: + case int8Tag$1: + case int16Tag$1: + case int32Tag$1: + case uint8Tag$1: + case uint8ClampedTag$1: + case uint16Tag$1: + case uint32Tag$1: + return cloneTypedArray(object2, isDeep); + case mapTag$3: + return new Ctor(); + case numberTag$2: + case stringTag$2: + return new Ctor(object2); + case regexpTag$2: + return cloneRegExp(object2); + case setTag$3: + return new Ctor(); + case symbolTag$2: + return cloneSymbol(object2); + } + } + var mapTag$2 = "[object Map]"; + function baseIsMap(value2) { + return isObjectLike(value2) && getTag$1(value2) == mapTag$2; + } + var nodeIsMap = nodeUtil$1 && nodeUtil$1.isMap; + var isMap = nodeIsMap ? baseUnary(nodeIsMap) : baseIsMap; + const isMap$1 = isMap; + var setTag$2 = "[object Set]"; + function baseIsSet(value2) { + return isObjectLike(value2) && getTag$1(value2) == setTag$2; + } + var nodeIsSet = nodeUtil$1 && nodeUtil$1.isSet; + var isSet = nodeIsSet ? baseUnary(nodeIsSet) : baseIsSet; + const isSet$1 = isSet; + var CLONE_DEEP_FLAG$1 = 1, CLONE_FLAT_FLAG = 2, CLONE_SYMBOLS_FLAG$2 = 4; + var argsTag$1 = "[object Arguments]", arrayTag$1 = "[object Array]", boolTag$1 = "[object Boolean]", dateTag$1 = "[object Date]", errorTag$1 = "[object Error]", funcTag = "[object Function]", genTag = "[object GeneratorFunction]", mapTag$1 = "[object Map]", numberTag$1 = "[object Number]", objectTag$1 = "[object Object]", regexpTag$1 = "[object RegExp]", setTag$1 = "[object Set]", stringTag$1 = "[object String]", symbolTag$1 = "[object Symbol]", weakMapTag = "[object WeakMap]"; + var arrayBufferTag$1 = "[object ArrayBuffer]", dataViewTag$1 = "[object DataView]", float32Tag = "[object Float32Array]", float64Tag = "[object Float64Array]", int8Tag = "[object Int8Array]", int16Tag = "[object Int16Array]", int32Tag = "[object Int32Array]", uint8Tag = "[object Uint8Array]", uint8ClampedTag = "[object Uint8ClampedArray]", uint16Tag = "[object Uint16Array]", uint32Tag = "[object Uint32Array]"; + var cloneableTags = {}; + cloneableTags[argsTag$1] = cloneableTags[arrayTag$1] = cloneableTags[arrayBufferTag$1] = cloneableTags[dataViewTag$1] = cloneableTags[boolTag$1] = cloneableTags[dateTag$1] = cloneableTags[float32Tag] = cloneableTags[float64Tag] = cloneableTags[int8Tag] = cloneableTags[int16Tag] = cloneableTags[int32Tag] = cloneableTags[mapTag$1] = cloneableTags[numberTag$1] = cloneableTags[objectTag$1] = cloneableTags[regexpTag$1] = cloneableTags[setTag$1] = cloneableTags[stringTag$1] = cloneableTags[symbolTag$1] = cloneableTags[uint8Tag] = cloneableTags[uint8ClampedTag] = cloneableTags[uint16Tag] = cloneableTags[uint32Tag] = true; + cloneableTags[errorTag$1] = cloneableTags[funcTag] = cloneableTags[weakMapTag] = false; + function baseClone(value2, bitmask, customizer, key, object2, stack) { + var result, isDeep = bitmask & CLONE_DEEP_FLAG$1, isFlat = bitmask & CLONE_FLAT_FLAG, isFull = bitmask & CLONE_SYMBOLS_FLAG$2; + if (customizer) { + result = object2 ? customizer(value2, key, object2, stack) : customizer(value2); + } + if (result !== void 0) { + return result; + } + if (!isObject$1(value2)) { + return value2; + } + var isArr = isArray$1(value2); + if (isArr) { + result = initCloneArray(value2); + if (!isDeep) { + return copyArray(value2, result); + } + } else { + var tag = getTag$1(value2), isFunc = tag == funcTag || tag == genTag; + if (isBuffer$1(value2)) { + return cloneBuffer(value2, isDeep); + } + if (tag == objectTag$1 || tag == argsTag$1 || isFunc && !object2) { + result = isFlat || isFunc ? {} : initCloneObject(value2); + if (!isDeep) { + return isFlat ? copySymbolsIn(value2, baseAssignIn(result, value2)) : copySymbols(value2, baseAssign(result, value2)); + } + } else { + if (!cloneableTags[tag]) { + return object2 ? value2 : {}; + } + result = initCloneByTag(value2, tag, isDeep); + } + } + stack || (stack = new Stack()); + var stacked = stack.get(value2); + if (stacked) { + return stacked; + } + stack.set(value2, result); + if (isSet$1(value2)) { + value2.forEach(function(subValue) { + result.add(baseClone(subValue, bitmask, customizer, subValue, value2, stack)); + }); + } else if (isMap$1(value2)) { + value2.forEach(function(subValue, key2) { + result.set(key2, baseClone(subValue, bitmask, customizer, key2, value2, stack)); + }); + } + var keysFunc = isFull ? isFlat ? getAllKeysIn : getAllKeys : isFlat ? keysIn : keys$1; + var props = isArr ? void 0 : keysFunc(value2); + arrayEach(props || value2, function(subValue, key2) { + if (props) { + key2 = subValue; + subValue = value2[key2]; + } + assignValue(result, key2, baseClone(subValue, bitmask, customizer, key2, value2, stack)); + }); + return result; + } + var CLONE_SYMBOLS_FLAG$1 = 4; + function clone$1(value2) { + return baseClone(value2, CLONE_SYMBOLS_FLAG$1); + } + var CLONE_DEEP_FLAG = 1, CLONE_SYMBOLS_FLAG = 4; + function cloneDeep(value2) { + return baseClone(value2, CLONE_DEEP_FLAG | CLONE_SYMBOLS_FLAG); + } + var HASH_UNDEFINED = "__lodash_hash_undefined__"; + function setCacheAdd(value2) { + this.__data__.set(value2, HASH_UNDEFINED); + return this; + } + function setCacheHas(value2) { + return this.__data__.has(value2); + } + function SetCache(values2) { + var index2 = -1, length2 = values2 == null ? 0 : values2.length; + this.__data__ = new MapCache(); + while (++index2 < length2) { + this.add(values2[index2]); + } + } + SetCache.prototype.add = SetCache.prototype.push = setCacheAdd; + SetCache.prototype.has = setCacheHas; + function arraySome(array2, predicate) { + var index2 = -1, length2 = array2 == null ? 0 : array2.length; + while (++index2 < length2) { + if (predicate(array2[index2], index2, array2)) { + return true; + } + } + return false; + } + function cacheHas(cache, key) { + return cache.has(key); + } + var COMPARE_PARTIAL_FLAG$5 = 1, COMPARE_UNORDERED_FLAG$3 = 2; + function equalArrays(array2, other, bitmask, customizer, equalFunc, stack) { + var isPartial = bitmask & COMPARE_PARTIAL_FLAG$5, arrLength = array2.length, othLength = other.length; + if (arrLength != othLength && !(isPartial && othLength > arrLength)) { + return false; + } + var arrStacked = stack.get(array2); + var othStacked = stack.get(other); + if (arrStacked && othStacked) { + return arrStacked == other && othStacked == array2; + } + var index2 = -1, result = true, seen = bitmask & COMPARE_UNORDERED_FLAG$3 ? new SetCache() : void 0; + stack.set(array2, other); + stack.set(other, array2); + while (++index2 < arrLength) { + var arrValue = array2[index2], othValue = other[index2]; + if (customizer) { + var compared = isPartial ? customizer(othValue, arrValue, index2, other, array2, stack) : customizer(arrValue, othValue, index2, array2, other, stack); + } + if (compared !== void 0) { + if (compared) { + continue; + } + result = false; + break; + } + if (seen) { + if (!arraySome(other, function(othValue2, othIndex) { + if (!cacheHas(seen, othIndex) && (arrValue === othValue2 || equalFunc(arrValue, othValue2, bitmask, customizer, stack))) { + return seen.push(othIndex); + } + })) { + result = false; + break; + } + } else if (!(arrValue === othValue || equalFunc(arrValue, othValue, bitmask, customizer, stack))) { + result = false; + break; + } + } + stack["delete"](array2); + stack["delete"](other); + return result; + } + function mapToArray(map2) { + var index2 = -1, result = Array(map2.size); + map2.forEach(function(value2, key) { + result[++index2] = [key, value2]; + }); + return result; + } + function setToArray(set2) { + var index2 = -1, result = Array(set2.size); + set2.forEach(function(value2) { + result[++index2] = value2; + }); + return result; + } + var COMPARE_PARTIAL_FLAG$4 = 1, COMPARE_UNORDERED_FLAG$2 = 2; + var boolTag = "[object Boolean]", dateTag = "[object Date]", errorTag = "[object Error]", mapTag = "[object Map]", numberTag = "[object Number]", regexpTag = "[object RegExp]", setTag = "[object Set]", stringTag = "[object String]", symbolTag = "[object Symbol]"; + var arrayBufferTag = "[object ArrayBuffer]", dataViewTag = "[object DataView]"; + var symbolProto = Symbol$2 ? Symbol$2.prototype : void 0, symbolValueOf = symbolProto ? symbolProto.valueOf : void 0; + function equalByTag(object2, other, tag, bitmask, customizer, equalFunc, stack) { + switch (tag) { + case dataViewTag: + if (object2.byteLength != other.byteLength || object2.byteOffset != other.byteOffset) { + return false; + } + object2 = object2.buffer; + other = other.buffer; + case arrayBufferTag: + if (object2.byteLength != other.byteLength || !equalFunc(new Uint8Array$2(object2), new Uint8Array$2(other))) { + return false; + } + return true; + case boolTag: + case dateTag: + case numberTag: + return eq(+object2, +other); + case errorTag: + return object2.name == other.name && object2.message == other.message; + case regexpTag: + case stringTag: + return object2 == other + ""; + case mapTag: + var convert = mapToArray; + case setTag: + var isPartial = bitmask & COMPARE_PARTIAL_FLAG$4; + convert || (convert = setToArray); + if (object2.size != other.size && !isPartial) { + return false; + } + var stacked = stack.get(object2); + if (stacked) { + return stacked == other; + } + bitmask |= COMPARE_UNORDERED_FLAG$2; + stack.set(object2, other); + var result = equalArrays(convert(object2), convert(other), bitmask, customizer, equalFunc, stack); + stack["delete"](object2); + return result; + case symbolTag: + if (symbolValueOf) { + return symbolValueOf.call(object2) == symbolValueOf.call(other); + } + } + return false; + } + var COMPARE_PARTIAL_FLAG$3 = 1; + var objectProto$3 = Object.prototype; + var hasOwnProperty$4 = objectProto$3.hasOwnProperty; + function equalObjects(object2, other, bitmask, customizer, equalFunc, stack) { + var isPartial = bitmask & COMPARE_PARTIAL_FLAG$3, objProps = getAllKeys(object2), objLength = objProps.length, othProps = getAllKeys(other), othLength = othProps.length; + if (objLength != othLength && !isPartial) { + return false; + } + var index2 = objLength; + while (index2--) { + var key = objProps[index2]; + if (!(isPartial ? key in other : hasOwnProperty$4.call(other, key))) { + return false; + } + } + var objStacked = stack.get(object2); + var othStacked = stack.get(other); + if (objStacked && othStacked) { + return objStacked == other && othStacked == object2; + } + var result = true; + stack.set(object2, other); + stack.set(other, object2); + var skipCtor = isPartial; + while (++index2 < objLength) { + key = objProps[index2]; + var objValue = object2[key], othValue = other[key]; + if (customizer) { + var compared = isPartial ? customizer(othValue, objValue, key, other, object2, stack) : customizer(objValue, othValue, key, object2, other, stack); + } + if (!(compared === void 0 ? objValue === othValue || equalFunc(objValue, othValue, bitmask, customizer, stack) : compared)) { + result = false; + break; + } + skipCtor || (skipCtor = key == "constructor"); + } + if (result && !skipCtor) { + var objCtor = object2.constructor, othCtor = other.constructor; + if (objCtor != othCtor && ("constructor" in object2 && "constructor" in other) && !(typeof objCtor == "function" && objCtor instanceof objCtor && typeof othCtor == "function" && othCtor instanceof othCtor)) { + result = false; + } + } + stack["delete"](object2); + stack["delete"](other); + return result; + } + var COMPARE_PARTIAL_FLAG$2 = 1; + var argsTag = "[object Arguments]", arrayTag = "[object Array]", objectTag = "[object Object]"; + var objectProto$2 = Object.prototype; + var hasOwnProperty$3 = objectProto$2.hasOwnProperty; + function baseIsEqualDeep(object2, other, bitmask, customizer, equalFunc, stack) { + var objIsArr = isArray$1(object2), othIsArr = isArray$1(other), objTag = objIsArr ? arrayTag : getTag$1(object2), othTag = othIsArr ? arrayTag : getTag$1(other); + objTag = objTag == argsTag ? objectTag : objTag; + othTag = othTag == argsTag ? objectTag : othTag; + var objIsObj = objTag == objectTag, othIsObj = othTag == objectTag, isSameTag = objTag == othTag; + if (isSameTag && isBuffer$1(object2)) { + if (!isBuffer$1(other)) { + return false; + } + objIsArr = true; + objIsObj = false; + } + if (isSameTag && !objIsObj) { + stack || (stack = new Stack()); + return objIsArr || isTypedArray$1(object2) ? equalArrays(object2, other, bitmask, customizer, equalFunc, stack) : equalByTag(object2, other, objTag, bitmask, customizer, equalFunc, stack); + } + if (!(bitmask & COMPARE_PARTIAL_FLAG$2)) { + var objIsWrapped = objIsObj && hasOwnProperty$3.call(object2, "__wrapped__"), othIsWrapped = othIsObj && hasOwnProperty$3.call(other, "__wrapped__"); + if (objIsWrapped || othIsWrapped) { + var objUnwrapped = objIsWrapped ? object2.value() : object2, othUnwrapped = othIsWrapped ? other.value() : other; + stack || (stack = new Stack()); + return equalFunc(objUnwrapped, othUnwrapped, bitmask, customizer, stack); + } + } + if (!isSameTag) { + return false; + } + stack || (stack = new Stack()); + return equalObjects(object2, other, bitmask, customizer, equalFunc, stack); + } + function baseIsEqual(value2, other, bitmask, customizer, stack) { + if (value2 === other) { + return true; + } + if (value2 == null || other == null || !isObjectLike(value2) && !isObjectLike(other)) { + return value2 !== value2 && other !== other; + } + return baseIsEqualDeep(value2, other, bitmask, customizer, baseIsEqual, stack); + } + var COMPARE_PARTIAL_FLAG$1 = 1, COMPARE_UNORDERED_FLAG$1 = 2; + function baseIsMatch(object2, source, matchData, customizer) { + var index2 = matchData.length, length2 = index2, noCustomizer = !customizer; + if (object2 == null) { + return !length2; + } + object2 = Object(object2); + while (index2--) { + var data = matchData[index2]; + if (noCustomizer && data[2] ? data[1] !== object2[data[0]] : !(data[0] in object2)) { + return false; + } + } + while (++index2 < length2) { + data = matchData[index2]; + var key = data[0], objValue = object2[key], srcValue = data[1]; + if (noCustomizer && data[2]) { + if (objValue === void 0 && !(key in object2)) { + return false; + } + } else { + var stack = new Stack(); + if (customizer) { + var result = customizer(objValue, srcValue, key, object2, source, stack); + } + if (!(result === void 0 ? baseIsEqual(srcValue, objValue, COMPARE_PARTIAL_FLAG$1 | COMPARE_UNORDERED_FLAG$1, customizer, stack) : result)) { + return false; + } + } + } + return true; + } + function isStrictComparable(value2) { + return value2 === value2 && !isObject$1(value2); + } + function getMatchData(object2) { + var result = keys$1(object2), length2 = result.length; + while (length2--) { + var key = result[length2], value2 = object2[key]; + result[length2] = [key, value2, isStrictComparable(value2)]; + } + return result; + } + function matchesStrictComparable(key, srcValue) { + return function(object2) { + if (object2 == null) { + return false; + } + return object2[key] === srcValue && (srcValue !== void 0 || key in Object(object2)); + }; + } + function baseMatches(source) { + var matchData = getMatchData(source); + if (matchData.length == 1 && matchData[0][2]) { + return matchesStrictComparable(matchData[0][0], matchData[0][1]); + } + return function(object2) { + return object2 === source || baseIsMatch(object2, source, matchData); + }; + } + function baseHasIn(object2, key) { + return object2 != null && key in Object(object2); + } + function hasPath(object2, path2, hasFunc) { + path2 = castPath(path2, object2); + var index2 = -1, length2 = path2.length, result = false; + while (++index2 < length2) { + var key = toKey(path2[index2]); + if (!(result = object2 != null && hasFunc(object2, key))) { + break; + } + object2 = object2[key]; + } + if (result || ++index2 != length2) { + return result; + } + length2 = object2 == null ? 0 : object2.length; + return !!length2 && isLength(length2) && isIndex(key, length2) && (isArray$1(object2) || isArguments$1(object2)); + } + function hasIn(object2, path2) { + return object2 != null && hasPath(object2, path2, baseHasIn); + } + var COMPARE_PARTIAL_FLAG = 1, COMPARE_UNORDERED_FLAG = 2; + function baseMatchesProperty(path2, srcValue) { + if (isKey(path2) && isStrictComparable(srcValue)) { + return matchesStrictComparable(toKey(path2), srcValue); + } + return function(object2) { + var objValue = get$1(object2, path2); + return objValue === void 0 && objValue === srcValue ? hasIn(object2, path2) : baseIsEqual(srcValue, objValue, COMPARE_PARTIAL_FLAG | COMPARE_UNORDERED_FLAG); + }; + } + function baseProperty(key) { + return function(object2) { + return object2 == null ? void 0 : object2[key]; + }; + } + function basePropertyDeep(path2) { + return function(object2) { + return baseGet(object2, path2); + }; + } + function property(path2) { + return isKey(path2) ? baseProperty(toKey(path2)) : basePropertyDeep(path2); + } + function baseIteratee(value2) { + if (typeof value2 == "function") { + return value2; + } + if (value2 == null) { + return identity; + } + if (typeof value2 == "object") { + return isArray$1(value2) ? baseMatchesProperty(value2[0], value2[1]) : baseMatches(value2); + } + return property(value2); + } + function baseForOwn(object2, iteratee) { + return object2 && baseFor$1(object2, iteratee, keys$1); + } + function createBaseEach(eachFunc, fromRight) { + return function(collection, iteratee) { + if (collection == null) { + return collection; + } + if (!isArrayLike(collection)) { + return eachFunc(collection, iteratee); + } + var length2 = collection.length, index2 = fromRight ? length2 : -1, iterable = Object(collection); + while (fromRight ? index2-- : ++index2 < length2) { + if (iteratee(iterable[index2], index2, iterable) === false) { + break; + } + } + return collection; + }; + } + var baseEach = createBaseEach(baseForOwn); + const baseEach$1 = baseEach; + var now = function() { + return root$1.Date.now(); + }; + const now$1 = now; + var objectProto$1 = Object.prototype; + var hasOwnProperty$2 = objectProto$1.hasOwnProperty; + var defaults = baseRest(function(object2, sources) { + object2 = Object(object2); + var index2 = -1; + var length2 = sources.length; + var guard = length2 > 2 ? sources[2] : void 0; + if (guard && isIterateeCall(sources[0], sources[1], guard)) { + length2 = 1; + } + while (++index2 < length2) { + var source = sources[index2]; + var props = keysIn(source); + var propsIndex = -1; + var propsLength = props.length; + while (++propsIndex < propsLength) { + var key = props[propsIndex]; + var value2 = object2[key]; + if (value2 === void 0 || eq(value2, objectProto$1[key]) && !hasOwnProperty$2.call(object2, key)) { + object2[key] = source[key]; + } + } + } + return object2; + }); + const defaults$1 = defaults; + function arrayIncludesWith(array2, value2, comparator) { + var index2 = -1, length2 = array2 == null ? 0 : array2.length; + while (++index2 < length2) { + if (comparator(value2, array2[index2])) { + return true; + } + } + return false; + } + function last(array2) { + var length2 = array2 == null ? 0 : array2.length; + return length2 ? array2[length2 - 1] : void 0; + } + function castFunction(value2) { + return typeof value2 == "function" ? value2 : identity; + } + function forEach(collection, iteratee) { + var func = isArray$1(collection) ? arrayEach : baseEach$1; + return func(collection, castFunction(iteratee)); + } + function baseFilter(collection, predicate) { + var result = []; + baseEach$1(collection, function(value2, index2, collection2) { + if (predicate(value2, index2, collection2)) { + result.push(value2); + } + }); + return result; + } + function filter(collection, predicate) { + var func = isArray$1(collection) ? arrayFilter : baseFilter; + return func(collection, baseIteratee(predicate)); + } + function createFind(findIndexFunc) { + return function(collection, predicate, fromIndex) { + var iterable = Object(collection); + if (!isArrayLike(collection)) { + var iteratee = baseIteratee(predicate); + collection = keys$1(collection); + predicate = function(key) { + return iteratee(iterable[key], key, iterable); + }; + } + var index2 = findIndexFunc(collection, predicate, fromIndex); + return index2 > -1 ? iterable[iteratee ? collection[index2] : index2] : void 0; + }; + } + var nativeMax$1 = Math.max; + function findIndex(array2, predicate, fromIndex) { + var length2 = array2 == null ? 0 : array2.length; + if (!length2) { + return -1; + } + var index2 = fromIndex == null ? 0 : toInteger(fromIndex); + if (index2 < 0) { + index2 = nativeMax$1(length2 + index2, 0); + } + return baseFindIndex(array2, baseIteratee(predicate), index2); + } + var find$1 = createFind(findIndex); + const find$2 = find$1; + function baseMap(collection, iteratee) { + var index2 = -1, result = isArrayLike(collection) ? Array(collection.length) : []; + baseEach$1(collection, function(value2, key, collection2) { + result[++index2] = iteratee(value2, key, collection2); + }); + return result; + } + function map(collection, iteratee) { + var func = isArray$1(collection) ? arrayMap : baseMap; + return func(collection, baseIteratee(iteratee)); + } + function forIn(object2, iteratee) { + return object2 == null ? object2 : baseFor$1(object2, castFunction(iteratee), keysIn); + } + function forOwn(object2, iteratee) { + return object2 && baseForOwn(object2, castFunction(iteratee)); + } + function baseGt(value2, other) { + return value2 > other; + } + var objectProto = Object.prototype; + var hasOwnProperty$1 = objectProto.hasOwnProperty; + function baseHas(object2, key) { + return object2 != null && hasOwnProperty$1.call(object2, key); + } + function has(object2, path2) { + return object2 != null && hasPath(object2, path2, baseHas); + } + function baseValues(object2, props) { + return arrayMap(props, function(key) { + return object2[key]; + }); + } + function values(object2) { + return object2 == null ? [] : baseValues(object2, keys$1(object2)); + } + function isUndefined(value2) { + return value2 === void 0; + } + function baseLt(value2, other) { + return value2 < other; + } + function mapValues(object2, iteratee) { + var result = {}; + iteratee = baseIteratee(iteratee); + baseForOwn(object2, function(value2, key, object3) { + baseAssignValue(result, key, iteratee(value2, key, object3)); + }); + return result; + } + function baseExtremum(array2, iteratee, comparator) { + var index2 = -1, length2 = array2.length; + while (++index2 < length2) { + var value2 = array2[index2], current = iteratee(value2); + if (current != null && (computed === void 0 ? current === current && !isSymbol(current) : comparator(current, computed))) { + var computed = current, result = value2; + } + } + return result; + } + function max$1(array2) { + return array2 && array2.length ? baseExtremum(array2, identity, baseGt) : void 0; + } + function min$1(array2) { + return array2 && array2.length ? baseExtremum(array2, identity, baseLt) : void 0; + } + function minBy(array2, iteratee) { + return array2 && array2.length ? baseExtremum(array2, baseIteratee(iteratee), baseLt) : void 0; + } + function baseSet(object2, path2, value2, customizer) { + if (!isObject$1(object2)) { + return object2; + } + path2 = castPath(path2, object2); + var index2 = -1, length2 = path2.length, lastIndex = length2 - 1, nested = object2; + while (nested != null && ++index2 < length2) { + var key = toKey(path2[index2]), newValue = value2; + if (key === "__proto__" || key === "constructor" || key === "prototype") { + return object2; + } + if (index2 != lastIndex) { + var objValue = nested[key]; + newValue = customizer ? customizer(objValue, key, nested) : void 0; + if (newValue === void 0) { + newValue = isObject$1(objValue) ? objValue : isIndex(path2[index2 + 1]) ? [] : {}; + } + } + assignValue(nested, key, newValue); + nested = nested[key]; + } + return object2; + } + function basePickBy(object2, paths, predicate) { + var index2 = -1, length2 = paths.length, result = {}; + while (++index2 < length2) { + var path2 = paths[index2], value2 = baseGet(object2, path2); + if (predicate(value2, path2)) { + baseSet(result, castPath(path2, object2), value2); + } + } + return result; + } + function baseSortBy(array2, comparer) { + var length2 = array2.length; + array2.sort(comparer); + while (length2--) { + array2[length2] = array2[length2].value; + } + return array2; + } + function compareAscending(value2, other) { + if (value2 !== other) { + var valIsDefined = value2 !== void 0, valIsNull = value2 === null, valIsReflexive = value2 === value2, valIsSymbol = isSymbol(value2); + var othIsDefined = other !== void 0, othIsNull = other === null, othIsReflexive = other === other, othIsSymbol = isSymbol(other); + if (!othIsNull && !othIsSymbol && !valIsSymbol && value2 > other || valIsSymbol && othIsDefined && othIsReflexive && !othIsNull && !othIsSymbol || valIsNull && othIsDefined && othIsReflexive || !valIsDefined && othIsReflexive || !valIsReflexive) { + return 1; + } + if (!valIsNull && !valIsSymbol && !othIsSymbol && value2 < other || othIsSymbol && valIsDefined && valIsReflexive && !valIsNull && !valIsSymbol || othIsNull && valIsDefined && valIsReflexive || !othIsDefined && valIsReflexive || !othIsReflexive) { + return -1; + } + } + return 0; + } + function compareMultiple(object2, other, orders) { + var index2 = -1, objCriteria = object2.criteria, othCriteria = other.criteria, length2 = objCriteria.length, ordersLength = orders.length; + while (++index2 < length2) { + var result = compareAscending(objCriteria[index2], othCriteria[index2]); + if (result) { + if (index2 >= ordersLength) { + return result; + } + var order2 = orders[index2]; + return result * (order2 == "desc" ? -1 : 1); + } + } + return object2.index - other.index; + } + function baseOrderBy(collection, iteratees, orders) { + if (iteratees.length) { + iteratees = arrayMap(iteratees, function(iteratee) { + if (isArray$1(iteratee)) { + return function(value2) { + return baseGet(value2, iteratee.length === 1 ? iteratee[0] : iteratee); + }; + } + return iteratee; + }); + } else { + iteratees = [identity]; + } + var index2 = -1; + iteratees = arrayMap(iteratees, baseUnary(baseIteratee)); + var result = baseMap(collection, function(value2, key, collection2) { + var criteria = arrayMap(iteratees, function(iteratee) { + return iteratee(value2); + }); + return { "criteria": criteria, "index": ++index2, "value": value2 }; + }); + return baseSortBy(result, function(object2, other) { + return compareMultiple(object2, other, orders); + }); + } + function basePick(object2, paths) { + return basePickBy(object2, paths, function(value2, path2) { + return hasIn(object2, path2); + }); + } + var pick = flatRest(function(object2, paths) { + return object2 == null ? {} : basePick(object2, paths); + }); + const pick$1 = pick; + var nativeCeil = Math.ceil, nativeMax = Math.max; + function baseRange(start2, end2, step, fromRight) { + var index2 = -1, length2 = nativeMax(nativeCeil((end2 - start2) / (step || 1)), 0), result = Array(length2); + while (length2--) { + result[fromRight ? length2 : ++index2] = start2; + start2 += step; + } + return result; + } + function createRange(fromRight) { + return function(start2, end2, step) { + if (step && typeof step != "number" && isIterateeCall(start2, end2, step)) { + end2 = step = void 0; + } + start2 = toFinite(start2); + if (end2 === void 0) { + end2 = start2; + start2 = 0; + } else { + end2 = toFinite(end2); + } + step = step === void 0 ? start2 < end2 ? 1 : -1 : toFinite(step); + return baseRange(start2, end2, step, fromRight); + }; + } + var range = createRange(); + const range$1 = range; + function baseReduce(collection, iteratee, accumulator, initAccum, eachFunc) { + eachFunc(collection, function(value2, index2, collection2) { + accumulator = initAccum ? (initAccum = false, value2) : iteratee(accumulator, value2, index2, collection2); + }); + return accumulator; + } + function reduce(collection, iteratee, accumulator) { + var func = isArray$1(collection) ? arrayReduce : baseReduce, initAccum = arguments.length < 3; + return func(collection, baseIteratee(iteratee), accumulator, initAccum, baseEach$1); + } + var sortBy = baseRest(function(collection, iteratees) { + if (collection == null) { + return []; + } + var length2 = iteratees.length; + if (length2 > 1 && isIterateeCall(collection, iteratees[0], iteratees[1])) { + iteratees = []; + } else if (length2 > 2 && isIterateeCall(iteratees[0], iteratees[1], iteratees[2])) { + iteratees = [iteratees[0]]; + } + return baseOrderBy(collection, baseFlatten(iteratees, 1), []); + }); + const sortBy$1 = sortBy; + var INFINITY = 1 / 0; + var createSet = !(Set$2 && 1 / setToArray(new Set$2([, -0]))[1] == INFINITY) ? noop : function(values2) { + return new Set$2(values2); + }; + const createSet$1 = createSet; + var LARGE_ARRAY_SIZE = 200; + function baseUniq(array2, iteratee, comparator) { + var index2 = -1, includes2 = arrayIncludes, length2 = array2.length, isCommon = true, result = [], seen = result; + if (comparator) { + isCommon = false; + includes2 = arrayIncludesWith; + } else if (length2 >= LARGE_ARRAY_SIZE) { + var set2 = iteratee ? null : createSet$1(array2); + if (set2) { + return setToArray(set2); + } + isCommon = false; + includes2 = cacheHas; + seen = new SetCache(); + } else { + seen = iteratee ? [] : result; + } + outer: + while (++index2 < length2) { + var value2 = array2[index2], computed = iteratee ? iteratee(value2) : value2; + value2 = comparator || value2 !== 0 ? value2 : 0; + if (isCommon && computed === computed) { + var seenIndex = seen.length; + while (seenIndex--) { + if (seen[seenIndex] === computed) { + continue outer; + } + } + if (iteratee) { + seen.push(computed); + } + result.push(value2); + } else if (!includes2(seen, computed, comparator)) { + if (seen !== result) { + seen.push(computed); + } + result.push(value2); + } + } + return result; + } + var union = baseRest(function(arrays) { + return baseUniq(baseFlatten(arrays, 1, isArrayLikeObject, true)); + }); + const union$1 = union; + var idCounter = 0; + function uniqueId(prefix) { + var id2 = ++idCounter; + return toString$1(prefix) + id2; + } + function baseZipObject(props, values2, assignFunc) { + var index2 = -1, length2 = props.length, valsLength = values2.length, result = {}; + while (++index2 < length2) { + var value2 = index2 < valsLength ? values2[index2] : void 0; + assignFunc(result, props[index2], value2); + } + return result; + } + function zipObject(props, values2) { + return baseZipObject(props || [], values2 || [], assignValue); + } + var DEFAULT_EDGE_NAME = "\0"; + var GRAPH_NODE = "\0"; + var EDGE_KEY_DELIM = ""; + class Graph { + constructor(opts = {}) { + this._isDirected = has(opts, "directed") ? opts.directed : true; + this._isMultigraph = has(opts, "multigraph") ? opts.multigraph : false; + this._isCompound = has(opts, "compound") ? opts.compound : false; + this._label = void 0; + this._defaultNodeLabelFn = constant$2(void 0); + this._defaultEdgeLabelFn = constant$2(void 0); + this._nodes = {}; + if (this._isCompound) { + this._parent = {}; + this._children = {}; + this._children[GRAPH_NODE] = {}; + } + this._in = {}; + this._preds = {}; + this._out = {}; + this._sucs = {}; + this._edgeObjs = {}; + this._edgeLabels = {}; + } + /* === Graph functions ========= */ + isDirected() { + return this._isDirected; + } + isMultigraph() { + return this._isMultigraph; + } + isCompound() { + return this._isCompound; + } + setGraph(label) { + this._label = label; + return this; + } + graph() { + return this._label; + } + /* === Node functions ========== */ + setDefaultNodeLabel(newDefault) { + if (!isFunction(newDefault)) { + newDefault = constant$2(newDefault); + } + this._defaultNodeLabelFn = newDefault; + return this; + } + nodeCount() { + return this._nodeCount; + } + nodes() { + return keys$1(this._nodes); + } + sources() { + var self2 = this; + return filter(this.nodes(), function(v) { + return isEmpty(self2._in[v]); + }); + } + sinks() { + var self2 = this; + return filter(this.nodes(), function(v) { + return isEmpty(self2._out[v]); + }); + } + setNodes(vs, value2) { + var args = arguments; + var self2 = this; + forEach(vs, function(v) { + if (args.length > 1) { + self2.setNode(v, value2); + } else { + self2.setNode(v); + } + }); + return this; + } + setNode(v, value2) { + if (has(this._nodes, v)) { + if (arguments.length > 1) { + this._nodes[v] = value2; + } + return this; + } + this._nodes[v] = arguments.length > 1 ? value2 : this._defaultNodeLabelFn(v); + if (this._isCompound) { + this._parent[v] = GRAPH_NODE; + this._children[v] = {}; + this._children[GRAPH_NODE][v] = true; + } + this._in[v] = {}; + this._preds[v] = {}; + this._out[v] = {}; + this._sucs[v] = {}; + ++this._nodeCount; + return this; + } + node(v) { + return this._nodes[v]; + } + hasNode(v) { + return has(this._nodes, v); + } + removeNode(v) { + var self2 = this; + if (has(this._nodes, v)) { + var removeEdge = function(e) { + self2.removeEdge(self2._edgeObjs[e]); + }; + delete this._nodes[v]; + if (this._isCompound) { + this._removeFromParentsChildList(v); + delete this._parent[v]; + forEach(this.children(v), function(child) { + self2.setParent(child); + }); + delete this._children[v]; + } + forEach(keys$1(this._in[v]), removeEdge); + delete this._in[v]; + delete this._preds[v]; + forEach(keys$1(this._out[v]), removeEdge); + delete this._out[v]; + delete this._sucs[v]; + --this._nodeCount; + } + return this; + } + setParent(v, parent) { + if (!this._isCompound) { + throw new Error("Cannot set parent in a non-compound graph"); + } + if (isUndefined(parent)) { + parent = GRAPH_NODE; + } else { + parent += ""; + for (var ancestor = parent; !isUndefined(ancestor); ancestor = this.parent(ancestor)) { + if (ancestor === v) { + throw new Error("Setting " + parent + " as parent of " + v + " would create a cycle"); + } + } + this.setNode(parent); + } + this.setNode(v); + this._removeFromParentsChildList(v); + this._parent[v] = parent; + this._children[parent][v] = true; + return this; + } + _removeFromParentsChildList(v) { + delete this._children[this._parent[v]][v]; + } + parent(v) { + if (this._isCompound) { + var parent = this._parent[v]; + if (parent !== GRAPH_NODE) { + return parent; + } + } + } + children(v) { + if (isUndefined(v)) { + v = GRAPH_NODE; + } + if (this._isCompound) { + var children2 = this._children[v]; + if (children2) { + return keys$1(children2); + } + } else if (v === GRAPH_NODE) { + return this.nodes(); + } else if (this.hasNode(v)) { + return []; + } + } + predecessors(v) { + var predsV = this._preds[v]; + if (predsV) { + return keys$1(predsV); + } + } + successors(v) { + var sucsV = this._sucs[v]; + if (sucsV) { + return keys$1(sucsV); + } + } + neighbors(v) { + var preds = this.predecessors(v); + if (preds) { + return union$1(preds, this.successors(v)); + } + } + isLeaf(v) { + var neighbors; + if (this.isDirected()) { + neighbors = this.successors(v); + } else { + neighbors = this.neighbors(v); + } + return neighbors.length === 0; + } + filterNodes(filter2) { + var copy2 = new this.constructor({ + directed: this._isDirected, + multigraph: this._isMultigraph, + compound: this._isCompound + }); + copy2.setGraph(this.graph()); + var self2 = this; + forEach(this._nodes, function(value2, v) { + if (filter2(v)) { + copy2.setNode(v, value2); + } + }); + forEach(this._edgeObjs, function(e) { + if (copy2.hasNode(e.v) && copy2.hasNode(e.w)) { + copy2.setEdge(e, self2.edge(e)); + } + }); + var parents2 = {}; + function findParent(v) { + var parent = self2.parent(v); + if (parent === void 0 || copy2.hasNode(parent)) { + parents2[v] = parent; + return parent; + } else if (parent in parents2) { + return parents2[parent]; + } else { + return findParent(parent); + } + } + if (this._isCompound) { + forEach(copy2.nodes(), function(v) { + copy2.setParent(v, findParent(v)); + }); + } + return copy2; + } + /* === Edge functions ========== */ + setDefaultEdgeLabel(newDefault) { + if (!isFunction(newDefault)) { + newDefault = constant$2(newDefault); + } + this._defaultEdgeLabelFn = newDefault; + return this; + } + edgeCount() { + return this._edgeCount; + } + edges() { + return values(this._edgeObjs); + } + setPath(vs, value2) { + var self2 = this; + var args = arguments; + reduce(vs, function(v, w2) { + if (args.length > 1) { + self2.setEdge(v, w2, value2); + } else { + self2.setEdge(v, w2); + } + return w2; + }); + return this; + } + /* + * setEdge(v, w, [value, [name]]) + * setEdge({ v, w, [name] }, [value]) + */ + setEdge() { + var v, w2, name, value2; + var valueSpecified = false; + var arg0 = arguments[0]; + if (typeof arg0 === "object" && arg0 !== null && "v" in arg0) { + v = arg0.v; + w2 = arg0.w; + name = arg0.name; + if (arguments.length === 2) { + value2 = arguments[1]; + valueSpecified = true; + } + } else { + v = arg0; + w2 = arguments[1]; + name = arguments[3]; + if (arguments.length > 2) { + value2 = arguments[2]; + valueSpecified = true; + } + } + v = "" + v; + w2 = "" + w2; + if (!isUndefined(name)) { + name = "" + name; + } + var e = edgeArgsToId(this._isDirected, v, w2, name); + if (has(this._edgeLabels, e)) { + if (valueSpecified) { + this._edgeLabels[e] = value2; + } + return this; + } + if (!isUndefined(name) && !this._isMultigraph) { + throw new Error("Cannot set a named edge when isMultigraph = false"); + } + this.setNode(v); + this.setNode(w2); + this._edgeLabels[e] = valueSpecified ? value2 : this._defaultEdgeLabelFn(v, w2, name); + var edgeObj = edgeArgsToObj(this._isDirected, v, w2, name); + v = edgeObj.v; + w2 = edgeObj.w; + Object.freeze(edgeObj); + this._edgeObjs[e] = edgeObj; + incrementOrInitEntry(this._preds[w2], v); + incrementOrInitEntry(this._sucs[v], w2); + this._in[w2][e] = edgeObj; + this._out[v][e] = edgeObj; + this._edgeCount++; + return this; + } + edge(v, w2, name) { + var e = arguments.length === 1 ? edgeObjToId(this._isDirected, arguments[0]) : edgeArgsToId(this._isDirected, v, w2, name); + return this._edgeLabels[e]; + } + hasEdge(v, w2, name) { + var e = arguments.length === 1 ? edgeObjToId(this._isDirected, arguments[0]) : edgeArgsToId(this._isDirected, v, w2, name); + return has(this._edgeLabels, e); + } + removeEdge(v, w2, name) { + var e = arguments.length === 1 ? edgeObjToId(this._isDirected, arguments[0]) : edgeArgsToId(this._isDirected, v, w2, name); + var edge = this._edgeObjs[e]; + if (edge) { + v = edge.v; + w2 = edge.w; + delete this._edgeLabels[e]; + delete this._edgeObjs[e]; + decrementOrRemoveEntry(this._preds[w2], v); + decrementOrRemoveEntry(this._sucs[v], w2); + delete this._in[w2][e]; + delete this._out[v][e]; + this._edgeCount--; + } + return this; + } + inEdges(v, u) { + var inV = this._in[v]; + if (inV) { + var edges2 = values(inV); + if (!u) { + return edges2; + } + return filter(edges2, function(edge) { + return edge.v === u; + }); + } + } + outEdges(v, w2) { + var outV = this._out[v]; + if (outV) { + var edges2 = values(outV); + if (!w2) { + return edges2; + } + return filter(edges2, function(edge) { + return edge.w === w2; + }); + } + } + nodeEdges(v, w2) { + var inEdges = this.inEdges(v, w2); + if (inEdges) { + return inEdges.concat(this.outEdges(v, w2)); + } + } + } + Graph.prototype._nodeCount = 0; + Graph.prototype._edgeCount = 0; + function incrementOrInitEntry(map2, k) { + if (map2[k]) { + map2[k]++; + } else { + map2[k] = 1; + } + } + function decrementOrRemoveEntry(map2, k) { + if (!--map2[k]) { + delete map2[k]; + } + } + function edgeArgsToId(isDirected, v_, w_, name) { + var v = "" + v_; + var w2 = "" + w_; + if (!isDirected && v > w2) { + var tmp = v; + v = w2; + w2 = tmp; + } + return v + EDGE_KEY_DELIM + w2 + EDGE_KEY_DELIM + (isUndefined(name) ? DEFAULT_EDGE_NAME : name); + } + function edgeArgsToObj(isDirected, v_, w_, name) { + var v = "" + v_; + var w2 = "" + w_; + if (!isDirected && v > w2) { + var tmp = v; + v = w2; + w2 = tmp; + } + var edgeObj = { v, w: w2 }; + if (name) { + edgeObj.name = name; + } + return edgeObj; + } + function edgeObjToId(isDirected, edgeObj) { + return edgeArgsToId(isDirected, edgeObj.v, edgeObj.w, edgeObj.name); + } + class List { + constructor() { + var sentinel = {}; + sentinel._next = sentinel._prev = sentinel; + this._sentinel = sentinel; + } + dequeue() { + var sentinel = this._sentinel; + var entry = sentinel._prev; + if (entry !== sentinel) { + unlink(entry); + return entry; + } + } + enqueue(entry) { + var sentinel = this._sentinel; + if (entry._prev && entry._next) { + unlink(entry); + } + entry._next = sentinel._next; + sentinel._next._prev = entry; + sentinel._next = entry; + entry._prev = sentinel; + } + toString() { + var strs = []; + var sentinel = this._sentinel; + var curr = sentinel._prev; + while (curr !== sentinel) { + strs.push(JSON.stringify(curr, filterOutLinks)); + curr = curr._prev; + } + return "[" + strs.join(", ") + "]"; + } + } + function unlink(entry) { + entry._prev._next = entry._next; + entry._next._prev = entry._prev; + delete entry._next; + delete entry._prev; + } + function filterOutLinks(k, v) { + if (k !== "_next" && k !== "_prev") { + return v; + } + } + var DEFAULT_WEIGHT_FN = constant$2(1); + function greedyFAS(g, weightFn) { + if (g.nodeCount() <= 1) { + return []; + } + var state2 = buildState(g, weightFn || DEFAULT_WEIGHT_FN); + var results = doGreedyFAS(state2.graph, state2.buckets, state2.zeroIdx); + return flatten( + map(results, function(e) { + return g.outEdges(e.v, e.w); + }) + ); + } + function doGreedyFAS(g, buckets, zeroIdx) { + var results = []; + var sources = buckets[buckets.length - 1]; + var sinks = buckets[0]; + var entry; + while (g.nodeCount()) { + while (entry = sinks.dequeue()) { + removeNode(g, buckets, zeroIdx, entry); + } + while (entry = sources.dequeue()) { + removeNode(g, buckets, zeroIdx, entry); + } + if (g.nodeCount()) { + for (var i2 = buckets.length - 2; i2 > 0; --i2) { + entry = buckets[i2].dequeue(); + if (entry) { + results = results.concat(removeNode(g, buckets, zeroIdx, entry, true)); + break; + } + } + } + } + return results; + } + function removeNode(g, buckets, zeroIdx, entry, collectPredecessors) { + var results = collectPredecessors ? [] : void 0; + forEach(g.inEdges(entry.v), function(edge) { + var weight = g.edge(edge); + var uEntry = g.node(edge.v); + if (collectPredecessors) { + results.push({ v: edge.v, w: edge.w }); + } + uEntry.out -= weight; + assignBucket(buckets, zeroIdx, uEntry); + }); + forEach(g.outEdges(entry.v), function(edge) { + var weight = g.edge(edge); + var w2 = edge.w; + var wEntry = g.node(w2); + wEntry["in"] -= weight; + assignBucket(buckets, zeroIdx, wEntry); + }); + g.removeNode(entry.v); + return results; + } + function buildState(g, weightFn) { + var fasGraph = new Graph(); + var maxIn = 0; + var maxOut = 0; + forEach(g.nodes(), function(v) { + fasGraph.setNode(v, { v, in: 0, out: 0 }); + }); + forEach(g.edges(), function(e) { + var prevWeight = fasGraph.edge(e.v, e.w) || 0; + var weight = weightFn(e); + var edgeWeight = prevWeight + weight; + fasGraph.setEdge(e.v, e.w, edgeWeight); + maxOut = Math.max(maxOut, fasGraph.node(e.v).out += weight); + maxIn = Math.max(maxIn, fasGraph.node(e.w)["in"] += weight); + }); + var buckets = range$1(maxOut + maxIn + 3).map(function() { + return new List(); + }); + var zeroIdx = maxIn + 1; + forEach(fasGraph.nodes(), function(v) { + assignBucket(buckets, zeroIdx, fasGraph.node(v)); + }); + return { graph: fasGraph, buckets, zeroIdx }; + } + function assignBucket(buckets, zeroIdx, entry) { + if (!entry.out) { + buckets[0].enqueue(entry); + } else if (!entry["in"]) { + buckets[buckets.length - 1].enqueue(entry); + } else { + buckets[entry.out - entry["in"] + zeroIdx].enqueue(entry); + } + } + function run$2(g) { + var fas = g.graph().acyclicer === "greedy" ? greedyFAS(g, weightFn(g)) : dfsFAS(g); + forEach(fas, function(e) { + var label = g.edge(e); + g.removeEdge(e); + label.forwardName = e.name; + label.reversed = true; + g.setEdge(e.w, e.v, label, uniqueId("rev")); + }); + function weightFn(g2) { + return function(e) { + return g2.edge(e).weight; + }; + } + } + function dfsFAS(g) { + var fas = []; + var stack = {}; + var visited = {}; + function dfs2(v) { + if (has(visited, v)) { + return; + } + visited[v] = true; + stack[v] = true; + forEach(g.outEdges(v), function(e) { + if (has(stack, e.w)) { + fas.push(e); + } else { + dfs2(e.w); + } + }); + delete stack[v]; + } + forEach(g.nodes(), dfs2); + return fas; + } + function undo$2(g) { + forEach(g.edges(), function(e) { + var label = g.edge(e); + if (label.reversed) { + g.removeEdge(e); + var forwardName = label.forwardName; + delete label.reversed; + delete label.forwardName; + g.setEdge(e.w, e.v, label, forwardName); + } + }); + } + function addDummyNode(g, type2, attrs, name) { + var v; + do { + v = uniqueId(name); + } while (g.hasNode(v)); + attrs.dummy = type2; + g.setNode(v, attrs); + return v; + } + function simplify(g) { + var simplified = new Graph().setGraph(g.graph()); + forEach(g.nodes(), function(v) { + simplified.setNode(v, g.node(v)); + }); + forEach(g.edges(), function(e) { + var simpleLabel = simplified.edge(e.v, e.w) || { weight: 0, minlen: 1 }; + var label = g.edge(e); + simplified.setEdge(e.v, e.w, { + weight: simpleLabel.weight + label.weight, + minlen: Math.max(simpleLabel.minlen, label.minlen) + }); + }); + return simplified; + } + function asNonCompoundGraph(g) { + var simplified = new Graph({ multigraph: g.isMultigraph() }).setGraph(g.graph()); + forEach(g.nodes(), function(v) { + if (!g.children(v).length) { + simplified.setNode(v, g.node(v)); + } + }); + forEach(g.edges(), function(e) { + simplified.setEdge(e, g.edge(e)); + }); + return simplified; + } + function intersectRect$3(rect2, point2) { + var x2 = rect2.x; + var y2 = rect2.y; + var dx = point2.x - x2; + var dy = point2.y - y2; + var w2 = rect2.width / 2; + var h = rect2.height / 2; + if (!dx && !dy) { + throw new Error("Not possible to find intersection inside of the rectangle"); + } + var sx, sy; + if (Math.abs(dy) * w2 > Math.abs(dx) * h) { + if (dy < 0) { + h = -h; + } + sx = h * dx / dy; + sy = h; + } else { + if (dx < 0) { + w2 = -w2; + } + sx = w2; + sy = w2 * dy / dx; + } + return { x: x2 + sx, y: y2 + sy }; + } + function buildLayerMatrix(g) { + var layering = map(range$1(maxRank(g) + 1), function() { + return []; + }); + forEach(g.nodes(), function(v) { + var node2 = g.node(v); + var rank2 = node2.rank; + if (!isUndefined(rank2)) { + layering[rank2][node2.order] = v; + } + }); + return layering; + } + function normalizeRanks(g) { + var min2 = min$1( + map(g.nodes(), function(v) { + return g.node(v).rank; + }) + ); + forEach(g.nodes(), function(v) { + var node2 = g.node(v); + if (has(node2, "rank")) { + node2.rank -= min2; + } + }); + } + function removeEmptyRanks(g) { + var offset = min$1( + map(g.nodes(), function(v) { + return g.node(v).rank; + }) + ); + var layers = []; + forEach(g.nodes(), function(v) { + var rank2 = g.node(v).rank - offset; + if (!layers[rank2]) { + layers[rank2] = []; + } + layers[rank2].push(v); + }); + var delta = 0; + var nodeRankFactor = g.graph().nodeRankFactor; + forEach(layers, function(vs, i2) { + if (isUndefined(vs) && i2 % nodeRankFactor !== 0) { + --delta; + } else if (delta) { + forEach(vs, function(v) { + g.node(v).rank += delta; + }); + } + }); + } + function addBorderNode$1(g, prefix, rank2, order2) { + var node2 = { + width: 0, + height: 0 + }; + if (arguments.length >= 4) { + node2.rank = rank2; + node2.order = order2; + } + return addDummyNode(g, "border", node2, prefix); + } + function maxRank(g) { + return max$1( + map(g.nodes(), function(v) { + var rank2 = g.node(v).rank; + if (!isUndefined(rank2)) { + return rank2; + } + }) + ); + } + function partition(collection, fn) { + var result = { lhs: [], rhs: [] }; + forEach(collection, function(value2) { + if (fn(value2)) { + result.lhs.push(value2); + } else { + result.rhs.push(value2); + } + }); + return result; + } + function time(name, fn) { + var start2 = now$1(); + try { + return fn(); + } finally { + console.log(name + " time: " + (now$1() - start2) + "ms"); + } + } + function notime(name, fn) { + return fn(); + } + function addBorderSegments(g) { + function dfs2(v) { + var children2 = g.children(v); + var node2 = g.node(v); + if (children2.length) { + forEach(children2, dfs2); + } + if (has(node2, "minRank")) { + node2.borderLeft = []; + node2.borderRight = []; + for (var rank2 = node2.minRank, maxRank2 = node2.maxRank + 1; rank2 < maxRank2; ++rank2) { + addBorderNode(g, "borderLeft", "_bl", v, node2, rank2); + addBorderNode(g, "borderRight", "_br", v, node2, rank2); + } + } + } + forEach(g.children(), dfs2); + } + function addBorderNode(g, prop, prefix, sg, sgNode, rank2) { + var label = { width: 0, height: 0, rank: rank2, borderType: prop }; + var prev2 = sgNode[prop][rank2 - 1]; + var curr = addDummyNode(g, "border", label, prefix); + sgNode[prop][rank2] = curr; + g.setParent(curr, sg); + if (prev2) { + g.setEdge(prev2, curr, { weight: 1 }); + } + } + function adjust(g) { + var rankDir = g.graph().rankdir.toLowerCase(); + if (rankDir === "lr" || rankDir === "rl") { + swapWidthHeight(g); + } + } + function undo$1(g) { + var rankDir = g.graph().rankdir.toLowerCase(); + if (rankDir === "bt" || rankDir === "rl") { + reverseY(g); + } + if (rankDir === "lr" || rankDir === "rl") { + swapXY(g); + swapWidthHeight(g); + } + } + function swapWidthHeight(g) { + forEach(g.nodes(), function(v) { + swapWidthHeightOne(g.node(v)); + }); + forEach(g.edges(), function(e) { + swapWidthHeightOne(g.edge(e)); + }); + } + function swapWidthHeightOne(attrs) { + var w2 = attrs.width; + attrs.width = attrs.height; + attrs.height = w2; + } + function reverseY(g) { + forEach(g.nodes(), function(v) { + reverseYOne(g.node(v)); + }); + forEach(g.edges(), function(e) { + var edge = g.edge(e); + forEach(edge.points, reverseYOne); + if (has(edge, "y")) { + reverseYOne(edge); + } + }); + } + function reverseYOne(attrs) { + attrs.y = -attrs.y; + } + function swapXY(g) { + forEach(g.nodes(), function(v) { + swapXYOne(g.node(v)); + }); + forEach(g.edges(), function(e) { + var edge = g.edge(e); + forEach(edge.points, swapXYOne); + if (has(edge, "x")) { + swapXYOne(edge); + } + }); + } + function swapXYOne(attrs) { + var x2 = attrs.x; + attrs.x = attrs.y; + attrs.y = x2; + } + function run$1(g) { + g.graph().dummyChains = []; + forEach(g.edges(), function(edge) { + normalizeEdge(g, edge); + }); + } + function normalizeEdge(g, e) { + var v = e.v; + var vRank = g.node(v).rank; + var w2 = e.w; + var wRank = g.node(w2).rank; + var name = e.name; + var edgeLabel = g.edge(e); + var labelRank = edgeLabel.labelRank; + if (wRank === vRank + 1) + return; + g.removeEdge(e); + var dummy, attrs, i2; + for (i2 = 0, ++vRank; vRank < wRank; ++i2, ++vRank) { + edgeLabel.points = []; + attrs = { + width: 0, + height: 0, + edgeLabel, + edgeObj: e, + rank: vRank + }; + dummy = addDummyNode(g, "edge", attrs, "_d"); + if (vRank === labelRank) { + attrs.width = edgeLabel.width; + attrs.height = edgeLabel.height; + attrs.dummy = "edge-label"; + attrs.labelpos = edgeLabel.labelpos; + } + g.setEdge(v, dummy, { weight: edgeLabel.weight }, name); + if (i2 === 0) { + g.graph().dummyChains.push(dummy); + } + v = dummy; + } + g.setEdge(v, w2, { weight: edgeLabel.weight }, name); + } + function undo(g) { + forEach(g.graph().dummyChains, function(v) { + var node2 = g.node(v); + var origLabel = node2.edgeLabel; + var w2; + g.setEdge(node2.edgeObj, origLabel); + while (node2.dummy) { + w2 = g.successors(v)[0]; + g.removeNode(v); + origLabel.points.push({ x: node2.x, y: node2.y }); + if (node2.dummy === "edge-label") { + origLabel.x = node2.x; + origLabel.y = node2.y; + origLabel.width = node2.width; + origLabel.height = node2.height; + } + v = w2; + node2 = g.node(v); + } + }); + } + function longestPath(g) { + var visited = {}; + function dfs2(v) { + var label = g.node(v); + if (has(visited, v)) { + return label.rank; + } + visited[v] = true; + var rank2 = min$1( + map(g.outEdges(v), function(e) { + return dfs2(e.w) - g.edge(e).minlen; + }) + ); + if (rank2 === Number.POSITIVE_INFINITY || // return value of _.map([]) for Lodash 3 + rank2 === void 0 || // return value of _.map([]) for Lodash 4 + rank2 === null) { + rank2 = 0; + } + return label.rank = rank2; + } + forEach(g.sources(), dfs2); + } + function slack(g, e) { + return g.node(e.w).rank - g.node(e.v).rank - g.edge(e).minlen; + } + function feasibleTree(g) { + var t = new Graph({ directed: false }); + var start2 = g.nodes()[0]; + var size2 = g.nodeCount(); + t.setNode(start2, {}); + var edge, delta; + while (tightTree(t, g) < size2) { + edge = findMinSlackEdge(t, g); + delta = t.hasNode(edge.v) ? slack(g, edge) : -slack(g, edge); + shiftRanks(t, g, delta); + } + return t; + } + function tightTree(t, g) { + function dfs2(v) { + forEach(g.nodeEdges(v), function(e) { + var edgeV = e.v, w2 = v === edgeV ? e.w : edgeV; + if (!t.hasNode(w2) && !slack(g, e)) { + t.setNode(w2, {}); + t.setEdge(v, w2, {}); + dfs2(w2); + } + }); + } + forEach(t.nodes(), dfs2); + return t.nodeCount(); + } + function findMinSlackEdge(t, g) { + return minBy(g.edges(), function(e) { + if (t.hasNode(e.v) !== t.hasNode(e.w)) { + return slack(g, e); + } + }); + } + function shiftRanks(t, g, delta) { + forEach(t.nodes(), function(v) { + g.node(v).rank += delta; + }); + } + function CycleException() { + } + CycleException.prototype = new Error(); + function dfs$1(g, vs, order2) { + if (!isArray$1(vs)) { + vs = [vs]; + } + var navigation = (g.isDirected() ? g.successors : g.neighbors).bind(g); + var acc = []; + var visited = {}; + forEach(vs, function(v) { + if (!g.hasNode(v)) { + throw new Error("Graph does not have node: " + v); + } + doDfs(g, v, order2 === "post", visited, navigation, acc); + }); + return acc; + } + function doDfs(g, v, postorder2, visited, navigation, acc) { + if (!has(visited, v)) { + visited[v] = true; + if (!postorder2) { + acc.push(v); + } + forEach(navigation(v), function(w2) { + doDfs(g, w2, postorder2, visited, navigation, acc); + }); + if (postorder2) { + acc.push(v); + } + } + } + function postorder$1(g, vs) { + return dfs$1(g, vs, "post"); + } + function preorder(g, vs) { + return dfs$1(g, vs, "pre"); + } + networkSimplex.initLowLimValues = initLowLimValues; + networkSimplex.initCutValues = initCutValues; + networkSimplex.calcCutValue = calcCutValue; + networkSimplex.leaveEdge = leaveEdge; + networkSimplex.enterEdge = enterEdge; + networkSimplex.exchangeEdges = exchangeEdges; + function networkSimplex(g) { + g = simplify(g); + longestPath(g); + var t = feasibleTree(g); + initLowLimValues(t); + initCutValues(t, g); + var e, f2; + while (e = leaveEdge(t)) { + f2 = enterEdge(t, g, e); + exchangeEdges(t, g, e, f2); + } + } + function initCutValues(t, g) { + var vs = postorder$1(t, t.nodes()); + vs = vs.slice(0, vs.length - 1); + forEach(vs, function(v) { + assignCutValue(t, g, v); + }); + } + function assignCutValue(t, g, child) { + var childLab = t.node(child); + var parent = childLab.parent; + t.edge(child, parent).cutvalue = calcCutValue(t, g, child); + } + function calcCutValue(t, g, child) { + var childLab = t.node(child); + var parent = childLab.parent; + var childIsTail = true; + var graphEdge = g.edge(child, parent); + var cutValue = 0; + if (!graphEdge) { + childIsTail = false; + graphEdge = g.edge(parent, child); + } + cutValue = graphEdge.weight; + forEach(g.nodeEdges(child), function(e) { + var isOutEdge = e.v === child, other = isOutEdge ? e.w : e.v; + if (other !== parent) { + var pointsToHead = isOutEdge === childIsTail, otherWeight = g.edge(e).weight; + cutValue += pointsToHead ? otherWeight : -otherWeight; + if (isTreeEdge(t, child, other)) { + var otherCutValue = t.edge(child, other).cutvalue; + cutValue += pointsToHead ? -otherCutValue : otherCutValue; + } + } + }); + return cutValue; + } + function initLowLimValues(tree, root2) { + if (arguments.length < 2) { + root2 = tree.nodes()[0]; + } + dfsAssignLowLim(tree, {}, 1, root2); + } + function dfsAssignLowLim(tree, visited, nextLim, v, parent) { + var low = nextLim; + var label = tree.node(v); + visited[v] = true; + forEach(tree.neighbors(v), function(w2) { + if (!has(visited, w2)) { + nextLim = dfsAssignLowLim(tree, visited, nextLim, w2, v); + } + }); + label.low = low; + label.lim = nextLim++; + if (parent) { + label.parent = parent; + } else { + delete label.parent; + } + return nextLim; + } + function leaveEdge(tree) { + return find$2(tree.edges(), function(e) { + return tree.edge(e).cutvalue < 0; + }); + } + function enterEdge(t, g, edge) { + var v = edge.v; + var w2 = edge.w; + if (!g.hasEdge(v, w2)) { + v = edge.w; + w2 = edge.v; + } + var vLabel = t.node(v); + var wLabel = t.node(w2); + var tailLabel = vLabel; + var flip = false; + if (vLabel.lim > wLabel.lim) { + tailLabel = wLabel; + flip = true; + } + var candidates = filter(g.edges(), function(edge2) { + return flip === isDescendant$1(t, t.node(edge2.v), tailLabel) && flip !== isDescendant$1(t, t.node(edge2.w), tailLabel); + }); + return minBy(candidates, function(edge2) { + return slack(g, edge2); + }); + } + function exchangeEdges(t, g, e, f2) { + var v = e.v; + var w2 = e.w; + t.removeEdge(v, w2); + t.setEdge(f2.v, f2.w, {}); + initLowLimValues(t); + initCutValues(t, g); + updateRanks(t, g); + } + function updateRanks(t, g) { + var root2 = find$2(t.nodes(), function(v) { + return !g.node(v).parent; + }); + var vs = preorder(t, root2); + vs = vs.slice(1); + forEach(vs, function(v) { + var parent = t.node(v).parent, edge = g.edge(v, parent), flipped = false; + if (!edge) { + edge = g.edge(parent, v); + flipped = true; + } + g.node(v).rank = g.node(parent).rank + (flipped ? edge.minlen : -edge.minlen); + }); + } + function isTreeEdge(tree, u, v) { + return tree.hasEdge(u, v); + } + function isDescendant$1(tree, vLabel, rootLabel) { + return rootLabel.low <= vLabel.lim && vLabel.lim <= rootLabel.lim; + } + function rank(g) { + switch (g.graph().ranker) { + case "network-simplex": + networkSimplexRanker(g); + break; + case "tight-tree": + tightTreeRanker(g); + break; + case "longest-path": + longestPathRanker(g); + break; + default: + networkSimplexRanker(g); + } + } + var longestPathRanker = longestPath; + function tightTreeRanker(g) { + longestPath(g); + feasibleTree(g); + } + function networkSimplexRanker(g) { + networkSimplex(g); + } + function run(g) { + var root2 = addDummyNode(g, "root", {}, "_root"); + var depths = treeDepths(g); + var height = max$1(values(depths)) - 1; + var nodeSep = 2 * height + 1; + g.graph().nestingRoot = root2; + forEach(g.edges(), function(e) { + g.edge(e).minlen *= nodeSep; + }); + var weight = sumWeights(g) + 1; + forEach(g.children(), function(child) { + dfs(g, root2, nodeSep, weight, height, depths, child); + }); + g.graph().nodeRankFactor = nodeSep; + } + function dfs(g, root2, nodeSep, weight, height, depths, v) { + var children2 = g.children(v); + if (!children2.length) { + if (v !== root2) { + g.setEdge(root2, v, { weight: 0, minlen: nodeSep }); + } + return; + } + var top2 = addBorderNode$1(g, "_bt"); + var bottom2 = addBorderNode$1(g, "_bb"); + var label = g.node(v); + g.setParent(top2, v); + label.borderTop = top2; + g.setParent(bottom2, v); + label.borderBottom = bottom2; + forEach(children2, function(child) { + dfs(g, root2, nodeSep, weight, height, depths, child); + var childNode = g.node(child); + var childTop = childNode.borderTop ? childNode.borderTop : child; + var childBottom = childNode.borderBottom ? childNode.borderBottom : child; + var thisWeight = childNode.borderTop ? weight : 2 * weight; + var minlen = childTop !== childBottom ? 1 : height - depths[v] + 1; + g.setEdge(top2, childTop, { + weight: thisWeight, + minlen, + nestingEdge: true + }); + g.setEdge(childBottom, bottom2, { + weight: thisWeight, + minlen, + nestingEdge: true + }); + }); + if (!g.parent(v)) { + g.setEdge(root2, top2, { weight: 0, minlen: height + depths[v] }); + } + } + function treeDepths(g) { + var depths = {}; + function dfs2(v, depth) { + var children2 = g.children(v); + if (children2 && children2.length) { + forEach(children2, function(child) { + dfs2(child, depth + 1); + }); + } + depths[v] = depth; + } + forEach(g.children(), function(v) { + dfs2(v, 1); + }); + return depths; + } + function sumWeights(g) { + return reduce( + g.edges(), + function(acc, e) { + return acc + g.edge(e).weight; + }, + 0 + ); + } + function cleanup(g) { + var graphLabel = g.graph(); + g.removeNode(graphLabel.nestingRoot); + delete graphLabel.nestingRoot; + forEach(g.edges(), function(e) { + var edge = g.edge(e); + if (edge.nestingEdge) { + g.removeEdge(e); + } + }); + } + function addSubgraphConstraints(g, cg, vs) { + var prev2 = {}, rootPrev; + forEach(vs, function(v) { + var child = g.parent(v), parent, prevChild; + while (child) { + parent = g.parent(child); + if (parent) { + prevChild = prev2[parent]; + prev2[parent] = child; + } else { + prevChild = rootPrev; + rootPrev = child; + } + if (prevChild && prevChild !== child) { + cg.setEdge(prevChild, child); + return; + } + child = parent; + } + }); + } + function buildLayerGraph(g, rank2, relationship) { + var root2 = createRootNode(g), result = new Graph({ compound: true }).setGraph({ root: root2 }).setDefaultNodeLabel(function(v) { + return g.node(v); + }); + forEach(g.nodes(), function(v) { + var node2 = g.node(v), parent = g.parent(v); + if (node2.rank === rank2 || node2.minRank <= rank2 && rank2 <= node2.maxRank) { + result.setNode(v); + result.setParent(v, parent || root2); + forEach(g[relationship](v), function(e) { + var u = e.v === v ? e.w : e.v, edge = result.edge(u, v), weight = !isUndefined(edge) ? edge.weight : 0; + result.setEdge(u, v, { weight: g.edge(e).weight + weight }); + }); + if (has(node2, "minRank")) { + result.setNode(v, { + borderLeft: node2.borderLeft[rank2], + borderRight: node2.borderRight[rank2] + }); + } + } + }); + return result; + } + function createRootNode(g) { + var v; + while (g.hasNode(v = uniqueId("_root"))) + ; + return v; + } + function crossCount(g, layering) { + var cc = 0; + for (var i2 = 1; i2 < layering.length; ++i2) { + cc += twoLayerCrossCount(g, layering[i2 - 1], layering[i2]); + } + return cc; + } + function twoLayerCrossCount(g, northLayer, southLayer) { + var southPos = zipObject( + southLayer, + map(southLayer, function(v, i2) { + return i2; + }) + ); + var southEntries = flatten( + map(northLayer, function(v) { + return sortBy$1( + map(g.outEdges(v), function(e) { + return { pos: southPos[e.w], weight: g.edge(e).weight }; + }), + "pos" + ); + }) + ); + var firstIndex = 1; + while (firstIndex < southLayer.length) + firstIndex <<= 1; + var treeSize = 2 * firstIndex - 1; + firstIndex -= 1; + var tree = map(new Array(treeSize), function() { + return 0; + }); + var cc = 0; + forEach( + // @ts-expect-error + southEntries.forEach(function(entry) { + var index2 = entry.pos + firstIndex; + tree[index2] += entry.weight; + var weightSum = 0; + while (index2 > 0) { + if (index2 % 2) { + weightSum += tree[index2 + 1]; + } + index2 = index2 - 1 >> 1; + tree[index2] += entry.weight; + } + cc += entry.weight * weightSum; + }) + ); + return cc; + } + function initOrder(g) { + var visited = {}; + var simpleNodes = filter(g.nodes(), function(v) { + return !g.children(v).length; + }); + var maxRank2 = max$1( + map(simpleNodes, function(v) { + return g.node(v).rank; + }) + ); + var layers = map(range$1(maxRank2 + 1), function() { + return []; + }); + function dfs2(v) { + if (has(visited, v)) + return; + visited[v] = true; + var node2 = g.node(v); + layers[node2.rank].push(v); + forEach(g.successors(v), dfs2); + } + var orderedVs = sortBy$1(simpleNodes, function(v) { + return g.node(v).rank; + }); + forEach(orderedVs, dfs2); + return layers; + } + function barycenter(g, movable) { + return map(movable, function(v) { + var inV = g.inEdges(v); + if (!inV.length) { + return { v }; + } else { + var result = reduce( + inV, + function(acc, e) { + var edge = g.edge(e), nodeU = g.node(e.v); + return { + sum: acc.sum + edge.weight * nodeU.order, + weight: acc.weight + edge.weight + }; + }, + { sum: 0, weight: 0 } + ); + return { + v, + barycenter: result.sum / result.weight, + weight: result.weight + }; + } + }); + } + function resolveConflicts(entries2, cg) { + var mappedEntries = {}; + forEach(entries2, function(entry, i2) { + var tmp = mappedEntries[entry.v] = { + indegree: 0, + in: [], + out: [], + vs: [entry.v], + i: i2 + }; + if (!isUndefined(entry.barycenter)) { + tmp.barycenter = entry.barycenter; + tmp.weight = entry.weight; + } + }); + forEach(cg.edges(), function(e) { + var entryV = mappedEntries[e.v]; + var entryW = mappedEntries[e.w]; + if (!isUndefined(entryV) && !isUndefined(entryW)) { + entryW.indegree++; + entryV.out.push(mappedEntries[e.w]); + } + }); + var sourceSet = filter(mappedEntries, function(entry) { + return !entry.indegree; + }); + return doResolveConflicts(sourceSet); + } + function doResolveConflicts(sourceSet) { + var entries2 = []; + function handleIn(vEntry) { + return function(uEntry) { + if (uEntry.merged) { + return; + } + if (isUndefined(uEntry.barycenter) || isUndefined(vEntry.barycenter) || uEntry.barycenter >= vEntry.barycenter) { + mergeEntries(vEntry, uEntry); + } + }; + } + function handleOut(vEntry) { + return function(wEntry) { + wEntry["in"].push(vEntry); + if (--wEntry.indegree === 0) { + sourceSet.push(wEntry); + } + }; + } + while (sourceSet.length) { + var entry = sourceSet.pop(); + entries2.push(entry); + forEach(entry["in"].reverse(), handleIn(entry)); + forEach(entry.out, handleOut(entry)); + } + return map( + filter(entries2, function(entry2) { + return !entry2.merged; + }), + function(entry2) { + return pick$1(entry2, ["vs", "i", "barycenter", "weight"]); + } + ); + } + function mergeEntries(target, source) { + var sum2 = 0; + var weight = 0; + if (target.weight) { + sum2 += target.barycenter * target.weight; + weight += target.weight; + } + if (source.weight) { + sum2 += source.barycenter * source.weight; + weight += source.weight; + } + target.vs = source.vs.concat(target.vs); + target.barycenter = sum2 / weight; + target.weight = weight; + target.i = Math.min(source.i, target.i); + source.merged = true; + } + function sort(entries2, biasRight) { + var parts = partition(entries2, function(entry) { + return has(entry, "barycenter"); + }); + var sortable = parts.lhs, unsortable = sortBy$1(parts.rhs, function(entry) { + return -entry.i; + }), vs = [], sum2 = 0, weight = 0, vsIndex = 0; + sortable.sort(compareWithBias(!!biasRight)); + vsIndex = consumeUnsortable(vs, unsortable, vsIndex); + forEach(sortable, function(entry) { + vsIndex += entry.vs.length; + vs.push(entry.vs); + sum2 += entry.barycenter * entry.weight; + weight += entry.weight; + vsIndex = consumeUnsortable(vs, unsortable, vsIndex); + }); + var result = { vs: flatten(vs) }; + if (weight) { + result.barycenter = sum2 / weight; + result.weight = weight; + } + return result; + } + function consumeUnsortable(vs, unsortable, index2) { + var last$1; + while (unsortable.length && (last$1 = last(unsortable)).i <= index2) { + unsortable.pop(); + vs.push(last$1.vs); + index2++; + } + return index2; + } + function compareWithBias(bias) { + return function(entryV, entryW) { + if (entryV.barycenter < entryW.barycenter) { + return -1; + } else if (entryV.barycenter > entryW.barycenter) { + return 1; + } + return !bias ? entryV.i - entryW.i : entryW.i - entryV.i; + }; + } + function sortSubgraph(g, v, cg, biasRight) { + var movable = g.children(v); + var node2 = g.node(v); + var bl = node2 ? node2.borderLeft : void 0; + var br = node2 ? node2.borderRight : void 0; + var subgraphs = {}; + if (bl) { + movable = filter(movable, function(w2) { + return w2 !== bl && w2 !== br; + }); + } + var barycenters = barycenter(g, movable); + forEach(barycenters, function(entry) { + if (g.children(entry.v).length) { + var subgraphResult = sortSubgraph(g, entry.v, cg, biasRight); + subgraphs[entry.v] = subgraphResult; + if (has(subgraphResult, "barycenter")) { + mergeBarycenters(entry, subgraphResult); + } + } + }); + var entries2 = resolveConflicts(barycenters, cg); + expandSubgraphs(entries2, subgraphs); + var result = sort(entries2, biasRight); + if (bl) { + result.vs = flatten([bl, result.vs, br]); + if (g.predecessors(bl).length) { + var blPred = g.node(g.predecessors(bl)[0]), brPred = g.node(g.predecessors(br)[0]); + if (!has(result, "barycenter")) { + result.barycenter = 0; + result.weight = 0; + } + result.barycenter = (result.barycenter * result.weight + blPred.order + brPred.order) / (result.weight + 2); + result.weight += 2; + } + } + return result; + } + function expandSubgraphs(entries2, subgraphs) { + forEach(entries2, function(entry) { + entry.vs = flatten( + entry.vs.map(function(v) { + if (subgraphs[v]) { + return subgraphs[v].vs; + } + return v; + }) + ); + }); + } + function mergeBarycenters(target, other) { + if (!isUndefined(target.barycenter)) { + target.barycenter = (target.barycenter * target.weight + other.barycenter * other.weight) / (target.weight + other.weight); + target.weight += other.weight; + } else { + target.barycenter = other.barycenter; + target.weight = other.weight; + } + } + function order(g) { + var maxRank$1 = maxRank(g), downLayerGraphs = buildLayerGraphs(g, range$1(1, maxRank$1 + 1), "inEdges"), upLayerGraphs = buildLayerGraphs(g, range$1(maxRank$1 - 1, -1, -1), "outEdges"); + var layering = initOrder(g); + assignOrder(g, layering); + var bestCC = Number.POSITIVE_INFINITY, best; + for (var i2 = 0, lastBest = 0; lastBest < 4; ++i2, ++lastBest) { + sweepLayerGraphs(i2 % 2 ? downLayerGraphs : upLayerGraphs, i2 % 4 >= 2); + layering = buildLayerMatrix(g); + var cc = crossCount(g, layering); + if (cc < bestCC) { + lastBest = 0; + best = cloneDeep(layering); + bestCC = cc; + } + } + assignOrder(g, best); + } + function buildLayerGraphs(g, ranks, relationship) { + return map(ranks, function(rank2) { + return buildLayerGraph(g, rank2, relationship); + }); + } + function sweepLayerGraphs(layerGraphs, biasRight) { + var cg = new Graph(); + forEach(layerGraphs, function(lg) { + var root2 = lg.graph().root; + var sorted = sortSubgraph(lg, root2, cg, biasRight); + forEach(sorted.vs, function(v, i2) { + lg.node(v).order = i2; + }); + addSubgraphConstraints(lg, cg, sorted.vs); + }); + } + function assignOrder(g, layering) { + forEach(layering, function(layer) { + forEach(layer, function(v, i2) { + g.node(v).order = i2; + }); + }); + } + function parentDummyChains(g) { + var postorderNums = postorder(g); + forEach(g.graph().dummyChains, function(v) { + var node2 = g.node(v); + var edgeObj = node2.edgeObj; + var pathData = findPath(g, postorderNums, edgeObj.v, edgeObj.w); + var path2 = pathData.path; + var lca = pathData.lca; + var pathIdx = 0; + var pathV = path2[pathIdx]; + var ascending2 = true; + while (v !== edgeObj.w) { + node2 = g.node(v); + if (ascending2) { + while ((pathV = path2[pathIdx]) !== lca && g.node(pathV).maxRank < node2.rank) { + pathIdx++; + } + if (pathV === lca) { + ascending2 = false; + } + } + if (!ascending2) { + while (pathIdx < path2.length - 1 && g.node(pathV = path2[pathIdx + 1]).minRank <= node2.rank) { + pathIdx++; + } + pathV = path2[pathIdx]; + } + g.setParent(v, pathV); + v = g.successors(v)[0]; + } + }); + } + function findPath(g, postorderNums, v, w2) { + var vPath = []; + var wPath = []; + var low = Math.min(postorderNums[v].low, postorderNums[w2].low); + var lim = Math.max(postorderNums[v].lim, postorderNums[w2].lim); + var parent; + var lca; + parent = v; + do { + parent = g.parent(parent); + vPath.push(parent); + } while (parent && (postorderNums[parent].low > low || lim > postorderNums[parent].lim)); + lca = parent; + parent = w2; + while ((parent = g.parent(parent)) !== lca) { + wPath.push(parent); + } + return { path: vPath.concat(wPath.reverse()), lca }; + } + function postorder(g) { + var result = {}; + var lim = 0; + function dfs2(v) { + var low = lim; + forEach(g.children(v), dfs2); + result[v] = { low, lim: lim++ }; + } + forEach(g.children(), dfs2); + return result; + } + function findType1Conflicts(g, layering) { + var conflicts = {}; + function visitLayer(prevLayer, layer) { + var k0 = 0, scanPos = 0, prevLayerLength = prevLayer.length, lastNode = last(layer); + forEach(layer, function(v, i2) { + var w2 = findOtherInnerSegmentNode(g, v), k1 = w2 ? g.node(w2).order : prevLayerLength; + if (w2 || v === lastNode) { + forEach(layer.slice(scanPos, i2 + 1), function(scanNode) { + forEach(g.predecessors(scanNode), function(u) { + var uLabel = g.node(u), uPos = uLabel.order; + if ((uPos < k0 || k1 < uPos) && !(uLabel.dummy && g.node(scanNode).dummy)) { + addConflict(conflicts, u, scanNode); + } + }); + }); + scanPos = i2 + 1; + k0 = k1; + } + }); + return layer; + } + reduce(layering, visitLayer); + return conflicts; + } + function findType2Conflicts(g, layering) { + var conflicts = {}; + function scan(south, southPos, southEnd, prevNorthBorder, nextNorthBorder) { + var v; + forEach(range$1(southPos, southEnd), function(i2) { + v = south[i2]; + if (g.node(v).dummy) { + forEach(g.predecessors(v), function(u) { + var uNode = g.node(u); + if (uNode.dummy && (uNode.order < prevNorthBorder || uNode.order > nextNorthBorder)) { + addConflict(conflicts, u, v); + } + }); + } + }); + } + function visitLayer(north, south) { + var prevNorthPos = -1, nextNorthPos, southPos = 0; + forEach(south, function(v, southLookahead) { + if (g.node(v).dummy === "border") { + var predecessors = g.predecessors(v); + if (predecessors.length) { + nextNorthPos = g.node(predecessors[0]).order; + scan(south, southPos, southLookahead, prevNorthPos, nextNorthPos); + southPos = southLookahead; + prevNorthPos = nextNorthPos; + } + } + scan(south, southPos, south.length, nextNorthPos, north.length); + }); + return south; + } + reduce(layering, visitLayer); + return conflicts; + } + function findOtherInnerSegmentNode(g, v) { + if (g.node(v).dummy) { + return find$2(g.predecessors(v), function(u) { + return g.node(u).dummy; + }); + } + } + function addConflict(conflicts, v, w2) { + if (v > w2) { + var tmp = v; + v = w2; + w2 = tmp; + } + var conflictsV = conflicts[v]; + if (!conflictsV) { + conflicts[v] = conflictsV = {}; + } + conflictsV[w2] = true; + } + function hasConflict(conflicts, v, w2) { + if (v > w2) { + var tmp = v; + v = w2; + w2 = tmp; + } + return has(conflicts[v], w2); + } + function verticalAlignment(g, layering, conflicts, neighborFn) { + var root2 = {}, align = {}, pos = {}; + forEach(layering, function(layer) { + forEach(layer, function(v, order2) { + root2[v] = v; + align[v] = v; + pos[v] = order2; + }); + }); + forEach(layering, function(layer) { + var prevIdx = -1; + forEach(layer, function(v) { + var ws = neighborFn(v); + if (ws.length) { + ws = sortBy$1(ws, function(w3) { + return pos[w3]; + }); + var mp = (ws.length - 1) / 2; + for (var i2 = Math.floor(mp), il = Math.ceil(mp); i2 <= il; ++i2) { + var w2 = ws[i2]; + if (align[v] === v && prevIdx < pos[w2] && !hasConflict(conflicts, v, w2)) { + align[w2] = v; + align[v] = root2[v] = root2[w2]; + prevIdx = pos[w2]; + } + } + } + }); + }); + return { root: root2, align }; + } + function horizontalCompaction(g, layering, root2, align, reverseSep) { + var xs = {}, blockG = buildBlockGraph(g, layering, root2, reverseSep), borderType = reverseSep ? "borderLeft" : "borderRight"; + function iterate(setXsFunc, nextNodesFunc) { + var stack = blockG.nodes(); + var elem = stack.pop(); + var visited = {}; + while (elem) { + if (visited[elem]) { + setXsFunc(elem); + } else { + visited[elem] = true; + stack.push(elem); + stack = stack.concat(nextNodesFunc(elem)); + } + elem = stack.pop(); + } + } + function pass1(elem) { + xs[elem] = blockG.inEdges(elem).reduce(function(acc, e) { + return Math.max(acc, xs[e.v] + blockG.edge(e)); + }, 0); + } + function pass2(elem) { + var min2 = blockG.outEdges(elem).reduce(function(acc, e) { + return Math.min(acc, xs[e.w] - blockG.edge(e)); + }, Number.POSITIVE_INFINITY); + var node2 = g.node(elem); + if (min2 !== Number.POSITIVE_INFINITY && node2.borderType !== borderType) { + xs[elem] = Math.max(xs[elem], min2); + } + } + iterate(pass1, blockG.predecessors.bind(blockG)); + iterate(pass2, blockG.successors.bind(blockG)); + forEach(align, function(v) { + xs[v] = xs[root2[v]]; + }); + return xs; + } + function buildBlockGraph(g, layering, root2, reverseSep) { + var blockGraph = new Graph(), graphLabel = g.graph(), sepFn = sep(graphLabel.nodesep, graphLabel.edgesep, reverseSep); + forEach(layering, function(layer) { + var u; + forEach(layer, function(v) { + var vRoot = root2[v]; + blockGraph.setNode(vRoot); + if (u) { + var uRoot = root2[u], prevMax = blockGraph.edge(uRoot, vRoot); + blockGraph.setEdge(uRoot, vRoot, Math.max(sepFn(g, v, u), prevMax || 0)); + } + u = v; + }); + }); + return blockGraph; + } + function findSmallestWidthAlignment(g, xss) { + return minBy(values(xss), function(xs) { + var max2 = Number.NEGATIVE_INFINITY; + var min2 = Number.POSITIVE_INFINITY; + forIn(xs, function(x2, v) { + var halfWidth = width(g, v) / 2; + max2 = Math.max(x2 + halfWidth, max2); + min2 = Math.min(x2 - halfWidth, min2); + }); + return max2 - min2; + }); + } + function alignCoordinates(xss, alignTo) { + var alignToVals = values(alignTo), alignToMin = min$1(alignToVals), alignToMax = max$1(alignToVals); + forEach(["u", "d"], function(vert) { + forEach(["l", "r"], function(horiz) { + var alignment = vert + horiz, xs = xss[alignment], delta; + if (xs === alignTo) + return; + var xsVals = values(xs); + delta = horiz === "l" ? alignToMin - min$1(xsVals) : alignToMax - max$1(xsVals); + if (delta) { + xss[alignment] = mapValues(xs, function(x2) { + return x2 + delta; + }); + } + }); + }); + } + function balance(xss, align) { + return mapValues(xss.ul, function(ignore, v) { + if (align) { + return xss[align.toLowerCase()][v]; + } else { + var xs = sortBy$1(map(xss, v)); + return (xs[1] + xs[2]) / 2; + } + }); + } + function positionX(g) { + var layering = buildLayerMatrix(g); + var conflicts = merge$3(findType1Conflicts(g, layering), findType2Conflicts(g, layering)); + var xss = {}; + var adjustedLayering; + forEach(["u", "d"], function(vert) { + adjustedLayering = vert === "u" ? layering : values(layering).reverse(); + forEach(["l", "r"], function(horiz) { + if (horiz === "r") { + adjustedLayering = map(adjustedLayering, function(inner2) { + return values(inner2).reverse(); + }); + } + var neighborFn = (vert === "u" ? g.predecessors : g.successors).bind(g); + var align = verticalAlignment(g, adjustedLayering, conflicts, neighborFn); + var xs = horizontalCompaction(g, adjustedLayering, align.root, align.align, horiz === "r"); + if (horiz === "r") { + xs = mapValues(xs, function(x2) { + return -x2; + }); + } + xss[vert + horiz] = xs; + }); + }); + var smallestWidth = findSmallestWidthAlignment(g, xss); + alignCoordinates(xss, smallestWidth); + return balance(xss, g.graph().align); + } + function sep(nodeSep, edgeSep, reverseSep) { + return function(g, v, w2) { + var vLabel = g.node(v); + var wLabel = g.node(w2); + var sum2 = 0; + var delta; + sum2 += vLabel.width / 2; + if (has(vLabel, "labelpos")) { + switch (vLabel.labelpos.toLowerCase()) { + case "l": + delta = -vLabel.width / 2; + break; + case "r": + delta = vLabel.width / 2; + break; + } + } + if (delta) { + sum2 += reverseSep ? delta : -delta; + } + delta = 0; + sum2 += (vLabel.dummy ? edgeSep : nodeSep) / 2; + sum2 += (wLabel.dummy ? edgeSep : nodeSep) / 2; + sum2 += wLabel.width / 2; + if (has(wLabel, "labelpos")) { + switch (wLabel.labelpos.toLowerCase()) { + case "l": + delta = wLabel.width / 2; + break; + case "r": + delta = -wLabel.width / 2; + break; + } + } + if (delta) { + sum2 += reverseSep ? delta : -delta; + } + delta = 0; + return sum2; + }; + } + function width(g, v) { + return g.node(v).width; + } + function position$1(g) { + g = asNonCompoundGraph(g); + positionY(g); + forOwn(positionX(g), function(x2, v) { + g.node(v).x = x2; + }); + } + function positionY(g) { + var layering = buildLayerMatrix(g); + var rankSep = g.graph().ranksep; + var prevY = 0; + forEach(layering, function(layer) { + var maxHeight = max$1( + map(layer, function(v) { + return g.node(v).height; + }) + ); + forEach(layer, function(v) { + g.node(v).y = prevY + maxHeight / 2; + }); + prevY += maxHeight + rankSep; + }); + } + function layout$1(g, opts) { + var time$12 = opts && opts.debugTiming ? time : notime; + time$12("layout", function() { + var layoutGraph = time$12(" buildLayoutGraph", function() { + return buildLayoutGraph(g); + }); + time$12(" runLayout", function() { + runLayout(layoutGraph, time$12); + }); + time$12(" updateInputGraph", function() { + updateInputGraph(g, layoutGraph); + }); + }); + } + function runLayout(g, time2) { + time2(" makeSpaceForEdgeLabels", function() { + makeSpaceForEdgeLabels(g); + }); + time2(" removeSelfEdges", function() { + removeSelfEdges(g); + }); + time2(" acyclic", function() { + run$2(g); + }); + time2(" nestingGraph.run", function() { + run(g); + }); + time2(" rank", function() { + rank(asNonCompoundGraph(g)); + }); + time2(" injectEdgeLabelProxies", function() { + injectEdgeLabelProxies(g); + }); + time2(" removeEmptyRanks", function() { + removeEmptyRanks(g); + }); + time2(" nestingGraph.cleanup", function() { + cleanup(g); + }); + time2(" normalizeRanks", function() { + normalizeRanks(g); + }); + time2(" assignRankMinMax", function() { + assignRankMinMax(g); + }); + time2(" removeEdgeLabelProxies", function() { + removeEdgeLabelProxies(g); + }); + time2(" normalize.run", function() { + run$1(g); + }); + time2(" parentDummyChains", function() { + parentDummyChains(g); + }); + time2(" addBorderSegments", function() { + addBorderSegments(g); + }); + time2(" order", function() { + order(g); + }); + time2(" insertSelfEdges", function() { + insertSelfEdges(g); + }); + time2(" adjustCoordinateSystem", function() { + adjust(g); + }); + time2(" position", function() { + position$1(g); + }); + time2(" positionSelfEdges", function() { + positionSelfEdges(g); + }); + time2(" removeBorderNodes", function() { + removeBorderNodes(g); + }); + time2(" normalize.undo", function() { + undo(g); + }); + time2(" fixupEdgeLabelCoords", function() { + fixupEdgeLabelCoords(g); + }); + time2(" undoCoordinateSystem", function() { + undo$1(g); + }); + time2(" translateGraph", function() { + translateGraph(g); + }); + time2(" assignNodeIntersects", function() { + assignNodeIntersects(g); + }); + time2(" reversePoints", function() { + reversePointsForReversedEdges(g); + }); + time2(" acyclic.undo", function() { + undo$2(g); + }); + } + function updateInputGraph(inputGraph, layoutGraph) { + forEach(inputGraph.nodes(), function(v) { + var inputLabel = inputGraph.node(v); + var layoutLabel = layoutGraph.node(v); + if (inputLabel) { + inputLabel.x = layoutLabel.x; + inputLabel.y = layoutLabel.y; + if (layoutGraph.children(v).length) { + inputLabel.width = layoutLabel.width; + inputLabel.height = layoutLabel.height; + } + } + }); + forEach(inputGraph.edges(), function(e) { + var inputLabel = inputGraph.edge(e); + var layoutLabel = layoutGraph.edge(e); + inputLabel.points = layoutLabel.points; + if (has(layoutLabel, "x")) { + inputLabel.x = layoutLabel.x; + inputLabel.y = layoutLabel.y; + } + }); + inputGraph.graph().width = layoutGraph.graph().width; + inputGraph.graph().height = layoutGraph.graph().height; + } + var graphNumAttrs = ["nodesep", "edgesep", "ranksep", "marginx", "marginy"]; + var graphDefaults = { ranksep: 50, edgesep: 20, nodesep: 50, rankdir: "tb" }; + var graphAttrs = ["acyclicer", "ranker", "rankdir", "align"]; + var nodeNumAttrs = ["width", "height"]; + var nodeDefaults = { width: 0, height: 0 }; + var edgeNumAttrs = ["minlen", "weight", "width", "height", "labeloffset"]; + var edgeDefaults = { + minlen: 1, + weight: 1, + width: 0, + height: 0, + labeloffset: 10, + labelpos: "r" + }; + var edgeAttrs = ["labelpos"]; + function buildLayoutGraph(inputGraph) { + var g = new Graph({ multigraph: true, compound: true }); + var graph = canonicalize(inputGraph.graph()); + g.setGraph( + merge$3({}, graphDefaults, selectNumberAttrs(graph, graphNumAttrs), pick$1(graph, graphAttrs)) + ); + forEach(inputGraph.nodes(), function(v) { + var node2 = canonicalize(inputGraph.node(v)); + g.setNode(v, defaults$1(selectNumberAttrs(node2, nodeNumAttrs), nodeDefaults)); + g.setParent(v, inputGraph.parent(v)); + }); + forEach(inputGraph.edges(), function(e) { + var edge = canonicalize(inputGraph.edge(e)); + g.setEdge( + e, + merge$3({}, edgeDefaults, selectNumberAttrs(edge, edgeNumAttrs), pick$1(edge, edgeAttrs)) + ); + }); + return g; + } + function makeSpaceForEdgeLabels(g) { + var graph = g.graph(); + graph.ranksep /= 2; + forEach(g.edges(), function(e) { + var edge = g.edge(e); + edge.minlen *= 2; + if (edge.labelpos.toLowerCase() !== "c") { + if (graph.rankdir === "TB" || graph.rankdir === "BT") { + edge.width += edge.labeloffset; + } else { + edge.height += edge.labeloffset; + } + } + }); + } + function injectEdgeLabelProxies(g) { + forEach(g.edges(), function(e) { + var edge = g.edge(e); + if (edge.width && edge.height) { + var v = g.node(e.v); + var w2 = g.node(e.w); + var label = { rank: (w2.rank - v.rank) / 2 + v.rank, e }; + addDummyNode(g, "edge-proxy", label, "_ep"); + } + }); + } + function assignRankMinMax(g) { + var maxRank2 = 0; + forEach(g.nodes(), function(v) { + var node2 = g.node(v); + if (node2.borderTop) { + node2.minRank = g.node(node2.borderTop).rank; + node2.maxRank = g.node(node2.borderBottom).rank; + maxRank2 = max$1(maxRank2, node2.maxRank); + } + }); + g.graph().maxRank = maxRank2; + } + function removeEdgeLabelProxies(g) { + forEach(g.nodes(), function(v) { + var node2 = g.node(v); + if (node2.dummy === "edge-proxy") { + g.edge(node2.e).labelRank = node2.rank; + g.removeNode(v); + } + }); + } + function translateGraph(g) { + var minX = Number.POSITIVE_INFINITY; + var maxX = 0; + var minY = Number.POSITIVE_INFINITY; + var maxY = 0; + var graphLabel = g.graph(); + var marginX = graphLabel.marginx || 0; + var marginY = graphLabel.marginy || 0; + function getExtremes(attrs) { + var x2 = attrs.x; + var y2 = attrs.y; + var w2 = attrs.width; + var h = attrs.height; + minX = Math.min(minX, x2 - w2 / 2); + maxX = Math.max(maxX, x2 + w2 / 2); + minY = Math.min(minY, y2 - h / 2); + maxY = Math.max(maxY, y2 + h / 2); + } + forEach(g.nodes(), function(v) { + getExtremes(g.node(v)); + }); + forEach(g.edges(), function(e) { + var edge = g.edge(e); + if (has(edge, "x")) { + getExtremes(edge); + } + }); + minX -= marginX; + minY -= marginY; + forEach(g.nodes(), function(v) { + var node2 = g.node(v); + node2.x -= minX; + node2.y -= minY; + }); + forEach(g.edges(), function(e) { + var edge = g.edge(e); + forEach(edge.points, function(p) { + p.x -= minX; + p.y -= minY; + }); + if (has(edge, "x")) { + edge.x -= minX; + } + if (has(edge, "y")) { + edge.y -= minY; + } + }); + graphLabel.width = maxX - minX + marginX; + graphLabel.height = maxY - minY + marginY; + } + function assignNodeIntersects(g) { + forEach(g.edges(), function(e) { + var edge = g.edge(e); + var nodeV = g.node(e.v); + var nodeW = g.node(e.w); + var p1, p2; + if (!edge.points) { + edge.points = []; + p1 = nodeW; + p2 = nodeV; + } else { + p1 = edge.points[0]; + p2 = edge.points[edge.points.length - 1]; + } + edge.points.unshift(intersectRect$3(nodeV, p1)); + edge.points.push(intersectRect$3(nodeW, p2)); + }); + } + function fixupEdgeLabelCoords(g) { + forEach(g.edges(), function(e) { + var edge = g.edge(e); + if (has(edge, "x")) { + if (edge.labelpos === "l" || edge.labelpos === "r") { + edge.width -= edge.labeloffset; + } + switch (edge.labelpos) { + case "l": + edge.x -= edge.width / 2 + edge.labeloffset; + break; + case "r": + edge.x += edge.width / 2 + edge.labeloffset; + break; + } + } + }); + } + function reversePointsForReversedEdges(g) { + forEach(g.edges(), function(e) { + var edge = g.edge(e); + if (edge.reversed) { + edge.points.reverse(); + } + }); + } + function removeBorderNodes(g) { + forEach(g.nodes(), function(v) { + if (g.children(v).length) { + var node2 = g.node(v); + var t = g.node(node2.borderTop); + var b = g.node(node2.borderBottom); + var l = g.node(last(node2.borderLeft)); + var r = g.node(last(node2.borderRight)); + node2.width = Math.abs(r.x - l.x); + node2.height = Math.abs(b.y - t.y); + node2.x = l.x + node2.width / 2; + node2.y = t.y + node2.height / 2; + } + }); + forEach(g.nodes(), function(v) { + if (g.node(v).dummy === "border") { + g.removeNode(v); + } + }); + } + function removeSelfEdges(g) { + forEach(g.edges(), function(e) { + if (e.v === e.w) { + var node2 = g.node(e.v); + if (!node2.selfEdges) { + node2.selfEdges = []; + } + node2.selfEdges.push({ e, label: g.edge(e) }); + g.removeEdge(e); + } + }); + } + function insertSelfEdges(g) { + var layers = buildLayerMatrix(g); + forEach(layers, function(layer) { + var orderShift = 0; + forEach(layer, function(v, i2) { + var node2 = g.node(v); + node2.order = i2 + orderShift; + forEach(node2.selfEdges, function(selfEdge) { + addDummyNode( + g, + "selfedge", + { + width: selfEdge.label.width, + height: selfEdge.label.height, + rank: node2.rank, + order: i2 + ++orderShift, + e: selfEdge.e, + label: selfEdge.label + }, + "_se" + ); + }); + delete node2.selfEdges; + }); + }); + } + function positionSelfEdges(g) { + forEach(g.nodes(), function(v) { + var node2 = g.node(v); + if (node2.dummy === "selfedge") { + var selfNode = g.node(node2.e.v); + var x2 = selfNode.x + selfNode.width / 2; + var y2 = selfNode.y; + var dx = node2.x - x2; + var dy = selfNode.height / 2; + g.setEdge(node2.e, node2.label); + g.removeNode(v); + node2.label.points = [ + { x: x2 + 2 * dx / 3, y: y2 - dy }, + { x: x2 + 5 * dx / 6, y: y2 - dy }, + { x: x2 + dx, y: y2 }, + { x: x2 + 5 * dx / 6, y: y2 + dy }, + { x: x2 + 2 * dx / 3, y: y2 + dy } + ]; + node2.label.x = node2.x; + node2.label.y = node2.y; + } + }); + } + function selectNumberAttrs(obj, attrs) { + return mapValues(pick$1(obj, attrs), Number); + } + function canonicalize(attrs) { + var newAttrs = {}; + forEach(attrs, function(v, k) { + newAttrs[k.toLowerCase()] = v; + }); + return newAttrs; + } + function isSubgraph(g, v) { + return !!g.children(v).length; + } + function edgeToId(e) { + return escapeId(e.v) + ":" + escapeId(e.w) + ":" + escapeId(e.name); + } + var ID_DELIM = /:/g; + function escapeId(str2) { + return str2 ? String(str2).replace(ID_DELIM, "\\:") : ""; + } + function applyStyle$2(dom, styleFn) { + if (styleFn) { + dom.attr("style", styleFn); + } + } + function applyClass(dom, classFn, otherClasses) { + if (classFn) { + dom.attr("class", classFn).attr("class", otherClasses + " " + dom.attr("class")); + } + } + function applyTransition(selection2, g) { + var graph = g.graph(); + if (isPlainObject(graph)) { + var transition = graph.transition; + if (isFunction(transition)) { + return transition(selection2); + } + } + return selection2; + } + var arrows = { + normal, + vee, + undirected + }; + function setArrows(value2) { + arrows = value2; + } + function normal(parent, id2, edge, type2) { + var marker = parent.append("marker").attr("id", id2).attr("viewBox", "0 0 10 10").attr("refX", 9).attr("refY", 5).attr("markerUnits", "strokeWidth").attr("markerWidth", 8).attr("markerHeight", 6).attr("orient", "auto"); + var path2 = marker.append("path").attr("d", "M 0 0 L 10 5 L 0 10 z").style("stroke-width", 1).style("stroke-dasharray", "1,0"); + applyStyle$2(path2, edge[type2 + "Style"]); + if (edge[type2 + "Class"]) { + path2.attr("class", edge[type2 + "Class"]); + } + } + function vee(parent, id2, edge, type2) { + var marker = parent.append("marker").attr("id", id2).attr("viewBox", "0 0 10 10").attr("refX", 9).attr("refY", 5).attr("markerUnits", "strokeWidth").attr("markerWidth", 8).attr("markerHeight", 6).attr("orient", "auto"); + var path2 = marker.append("path").attr("d", "M 0 0 L 10 5 L 0 10 L 4 5 z").style("stroke-width", 1).style("stroke-dasharray", "1,0"); + applyStyle$2(path2, edge[type2 + "Style"]); + if (edge[type2 + "Class"]) { + path2.attr("class", edge[type2 + "Class"]); + } + } + function undirected(parent, id2, edge, type2) { + var marker = parent.append("marker").attr("id", id2).attr("viewBox", "0 0 10 10").attr("refX", 9).attr("refY", 5).attr("markerUnits", "strokeWidth").attr("markerWidth", 8).attr("markerHeight", 6).attr("orient", "auto"); + var path2 = marker.append("path").attr("d", "M 0 5 L 10 5").style("stroke-width", 1).style("stroke-dasharray", "1,0"); + applyStyle$2(path2, edge[type2 + "Style"]); + if (edge[type2 + "Class"]) { + path2.attr("class", edge[type2 + "Class"]); + } + } + function addHtmlLabel$1(root2, node2) { + var fo = root2.append("foreignObject").attr("width", "100000"); + var div = fo.append("xhtml:div"); + div.attr("xmlns", "http://www.w3.org/1999/xhtml"); + var label = node2.label; + switch (typeof label) { + case "function": + div.insert(label); + break; + case "object": + div.insert(function() { + return label; + }); + break; + default: + div.html(label); + } + applyStyle$2(div, node2.labelStyle); + div.style("display", "inline-block"); + div.style("white-space", "nowrap"); + var client = div.node().getBoundingClientRect(); + fo.attr("width", client.width).attr("height", client.height); + return fo; + } + function addSVGLabel(root2, node2) { + var domNode = root2; + domNode.node().appendChild(node2.label); + applyStyle$2(domNode, node2.labelStyle); + return domNode; + } + function addTextLabel(root2, node2) { + var domNode = root2.append("text"); + var lines = processEscapeSequences(node2.label).split("\n"); + for (var i2 = 0; i2 < lines.length; i2++) { + domNode.append("tspan").attr("xml:space", "preserve").attr("dy", "1em").attr("x", "1").text(lines[i2]); + } + applyStyle$2(domNode, node2.labelStyle); + return domNode; + } + function processEscapeSequences(text2) { + var newText = ""; + var escaped = false; + var ch2; + for (var i2 = 0; i2 < text2.length; ++i2) { + ch2 = text2[i2]; + if (escaped) { + switch (ch2) { + case "n": + newText += "\n"; + break; + default: + newText += ch2; + } + escaped = false; + } else if (ch2 === "\\") { + escaped = true; + } else { + newText += ch2; + } + } + return newText; + } + function addLabel(root2, node2, location2) { + var label = node2.label; + var labelSvg = root2.append("g"); + if (node2.labelType === "svg") { + addSVGLabel(labelSvg, node2); + } else if (typeof label !== "string" || node2.labelType === "html") { + addHtmlLabel$1(labelSvg, node2); + } else { + addTextLabel(labelSvg, node2); + } + var labelBBox = labelSvg.node().getBBox(); + var y2; + switch (location2) { + case "top": + y2 = -node2.height / 2; + break; + case "bottom": + y2 = node2.height / 2 - labelBBox.height; + break; + default: + y2 = -labelBBox.height / 2; + } + labelSvg.attr("transform", "translate(" + -labelBBox.width / 2 + "," + y2 + ")"); + return labelSvg; + } + var createClusters = function(selection2, g) { + var clusters = g.nodes().filter(function(v) { + return isSubgraph(g, v); + }); + var svgClusters = selection2.selectAll("g.cluster").data(clusters, function(v) { + return v; + }); + applyTransition(svgClusters.exit(), g).style("opacity", 0).remove(); + var enterSelection = svgClusters.enter().append("g").attr("class", "cluster").attr("id", function(v) { + var node2 = g.node(v); + return node2.id; + }).style("opacity", 0).each(function(v) { + var node2 = g.node(v); + var thisGroup = d3select(this); + d3select(this).append("rect"); + var labelGroup = thisGroup.append("g").attr("class", "label"); + addLabel(labelGroup, node2, node2.clusterLabelPos); + }); + svgClusters = svgClusters.merge(enterSelection); + svgClusters = applyTransition(svgClusters, g).style("opacity", 1); + svgClusters.selectAll("rect").each(function(c2) { + var node2 = g.node(c2); + var domCluster = d3select(this); + applyStyle$2(domCluster, node2.style); + }); + return svgClusters; + }; + function setCreateClusters(value2) { + createClusters = value2; + } + let createEdgeLabels = function(selection2, g) { + var svgEdgeLabels = selection2.selectAll("g.edgeLabel").data(g.edges(), function(e) { + return edgeToId(e); + }).classed("update", true); + svgEdgeLabels.exit().remove(); + svgEdgeLabels.enter().append("g").classed("edgeLabel", true).style("opacity", 0); + svgEdgeLabels = selection2.selectAll("g.edgeLabel"); + svgEdgeLabels.each(function(e) { + var root2 = d3select(this); + root2.select(".label").remove(); + var edge = g.edge(e); + var label = addLabel(root2, g.edge(e), 0).classed("label", true); + var bbox = label.node().getBBox(); + if (edge.labelId) { + label.attr("id", edge.labelId); + } + if (!has(edge, "width")) { + edge.width = bbox.width; + } + if (!has(edge, "height")) { + edge.height = bbox.height; + } + }); + var exitSelection; + if (svgEdgeLabels.exit) { + exitSelection = svgEdgeLabels.exit(); + } else { + exitSelection = svgEdgeLabels.selectAll(null); + } + applyTransition(exitSelection, g).style("opacity", 0).remove(); + return svgEdgeLabels; + }; + function setCreateEdgeLabels(value2) { + createEdgeLabels = value2; + } + function intersectNode$1(node2, point2) { + return node2.intersect(point2); + } + var createEdgePaths = function(selection2, g, arrows2) { + var previousPaths = selection2.selectAll("g.edgePath").data(g.edges(), function(e) { + return edgeToId(e); + }).classed("update", true); + var newPaths = enter(previousPaths, g); + exit$1(previousPaths, g); + var svgPaths = previousPaths.merge !== void 0 ? previousPaths.merge(newPaths) : previousPaths; + applyTransition(svgPaths, g).style("opacity", 1); + svgPaths.each(function(e) { + var domEdge = d3select(this); + var edge = g.edge(e); + edge.elem = this; + if (edge.id) { + domEdge.attr("id", edge.id); + } + applyClass( + domEdge, + edge["class"], + (domEdge.classed("update") ? "update " : "") + "edgePath" + ); + }); + svgPaths.selectAll("path.path").each(function(e) { + var edge = g.edge(e); + edge.arrowheadId = uniqueId("arrowhead"); + var domEdge = d3select(this).attr("marker-end", function() { + return "url(" + makeFragmentRef(location.href, edge.arrowheadId) + ")"; + }).style("fill", "none"); + applyTransition(domEdge, g).attr("d", function(e3) { + return calcPoints(g, e3); + }); + applyStyle$2(domEdge, edge.style); + }); + svgPaths.selectAll("defs *").remove(); + svgPaths.selectAll("defs").each(function(e) { + var edge = g.edge(e); + var arrowhead = arrows2[edge.arrowhead]; + arrowhead(d3select(this), edge.arrowheadId, edge, "arrowhead"); + }); + return svgPaths; + }; + function setCreateEdgePaths(value2) { + createEdgePaths = value2; + } + function makeFragmentRef(url, fragmentId) { + var baseUrl = url.split("#")[0]; + return baseUrl + "#" + fragmentId; + } + function calcPoints(g, e) { + var edge = g.edge(e); + var tail = g.node(e.v); + var head2 = g.node(e.w); + var points = edge.points.slice(1, edge.points.length - 1); + points.unshift(intersectNode$1(tail, points[0])); + points.push(intersectNode$1(head2, points[points.length - 1])); + return createLine(edge, points); + } + function createLine(edge, points) { + var line2 = (line$1 || svg$2.line)().x(function(d) { + return d.x; + }).y(function(d) { + return d.y; + }); + (line2.curve || line2.interpolate)(edge.curve); + return line2(points); + } + function getCoords(elem) { + var bbox = elem.getBBox(); + var matrix = elem.ownerSVGElement.getScreenCTM().inverse().multiply(elem.getScreenCTM()).translate(bbox.width / 2, bbox.height / 2); + return { x: matrix.e, y: matrix.f }; + } + function enter(svgPaths, g) { + var svgPathsEnter = svgPaths.enter().append("g").attr("class", "edgePath").style("opacity", 0); + svgPathsEnter.append("path").attr("class", "path").attr("d", function(e) { + var edge = g.edge(e); + var sourceElem = g.node(e.v).elem; + var points = range$1(edge.points.length).map(function() { + return getCoords(sourceElem); + }); + return createLine(edge, points); + }); + svgPathsEnter.append("defs"); + return svgPathsEnter; + } + function exit$1(svgPaths, g) { + var svgPathExit = svgPaths.exit(); + applyTransition(svgPathExit, g).style("opacity", 0).remove(); + } + var createNodes = function(selection2, g, shapes2) { + var simpleNodes = g.nodes().filter(function(v) { + return !isSubgraph(g, v); + }); + var svgNodes = selection2.selectAll("g.node").data(simpleNodes, function(v) { + return v; + }).classed("update", true); + svgNodes.exit().remove(); + svgNodes.enter().append("g").attr("class", "node").style("opacity", 0); + svgNodes = selection2.selectAll("g.node"); + svgNodes.each(function(v) { + var node2 = g.node(v); + var thisGroup = d3select(this); + applyClass( + thisGroup, + node2["class"], + (thisGroup.classed("update") ? "update " : "") + "node" + ); + thisGroup.select("g.label").remove(); + var labelGroup = thisGroup.append("g").attr("class", "label"); + var labelDom = addLabel(labelGroup, node2); + var shape = shapes2[node2.shape]; + var bbox = pick$1(labelDom.node().getBBox(), "width", "height"); + node2.elem = this; + if (node2.id) { + thisGroup.attr("id", node2.id); + } + if (node2.labelId) { + labelGroup.attr("id", node2.labelId); + } + if (has(node2, "width")) { + bbox.width = node2.width; + } + if (has(node2, "height")) { + bbox.height = node2.height; + } + bbox.width += node2.paddingLeft + node2.paddingRight; + bbox.height += node2.paddingTop + node2.paddingBottom; + labelGroup.attr( + "transform", + "translate(" + (node2.paddingLeft - node2.paddingRight) / 2 + "," + (node2.paddingTop - node2.paddingBottom) / 2 + ")" + ); + var root2 = d3select(this); + root2.select(".label-container").remove(); + var shapeSvg = shape(root2, bbox, node2).classed("label-container", true); + applyStyle$2(shapeSvg, node2.style); + var shapeBBox = shapeSvg.node().getBBox(); + node2.width = shapeBBox.width; + node2.height = shapeBBox.height; + }); + var exitSelection; + if (svgNodes.exit) { + exitSelection = svgNodes.exit(); + } else { + exitSelection = svgNodes.selectAll(null); + } + applyTransition(exitSelection, g).style("opacity", 0).remove(); + return svgNodes; + }; + function setCreateNodes(value2) { + createNodes = value2; + } + function positionClusters(selection2, g) { + var created = selection2.filter(function() { + return !d3select(this).classed("update"); + }); + function translate(v) { + var node2 = g.node(v); + return "translate(" + node2.x + "," + node2.y + ")"; + } + created.attr("transform", translate); + applyTransition(selection2, g).style("opacity", 1).attr("transform", translate); + applyTransition(created.selectAll("rect"), g).attr("width", function(v) { + return g.node(v).width; + }).attr("height", function(v) { + return g.node(v).height; + }).attr("x", function(v) { + var node2 = g.node(v); + return -node2.width / 2; + }).attr("y", function(v) { + var node2 = g.node(v); + return -node2.height / 2; + }); + } + function positionEdgeLabels(selection2, g) { + var created = selection2.filter(function() { + return !d3select(this).classed("update"); + }); + function translate(e) { + var edge = g.edge(e); + return has(edge, "x") ? "translate(" + edge.x + "," + edge.y + ")" : ""; + } + created.attr("transform", translate); + applyTransition(selection2, g).style("opacity", 1).attr("transform", translate); + } + function positionNodes$1(selection2, g) { + var created = selection2.filter(function() { + return !d3select(this).classed("update"); + }); + function translate(v) { + var node2 = g.node(v); + return "translate(" + node2.x + "," + node2.y + ")"; + } + created.attr("transform", translate); + applyTransition(selection2, g).style("opacity", 1).attr("transform", translate); + } + function intersectEllipse$1(node2, rx, ry, point2) { + var cx = node2.x; + var cy = node2.y; + var px = cx - point2.x; + var py = cy - point2.y; + var det = Math.sqrt(rx * rx * py * py + ry * ry * px * px); + var dx = Math.abs(rx * ry * px / det); + if (point2.x < cx) { + dx = -dx; + } + var dy = Math.abs(rx * ry * py / det); + if (point2.y < cy) { + dy = -dy; + } + return { x: cx + dx, y: cy + dy }; + } + function intersectCircle$1(node2, rx, point2) { + return intersectEllipse$1(node2, rx, rx, point2); + } + function intersectLine$1(p1, p2, q1, q2) { + var a1, a2, b1, b2, c1, c2; + var r1, r2, r3, r4; + var denom, offset, num; + var x2, y2; + a1 = p2.y - p1.y; + b1 = p1.x - p2.x; + c1 = p2.x * p1.y - p1.x * p2.y; + r3 = a1 * q1.x + b1 * q1.y + c1; + r4 = a1 * q2.x + b1 * q2.y + c1; + if (r3 !== 0 && r4 !== 0 && sameSign$1(r3, r4)) { + return; + } + a2 = q2.y - q1.y; + b2 = q1.x - q2.x; + c2 = q2.x * q1.y - q1.x * q2.y; + r1 = a2 * p1.x + b2 * p1.y + c2; + r2 = a2 * p2.x + b2 * p2.y + c2; + if (r1 !== 0 && r2 !== 0 && sameSign$1(r1, r2)) { + return; + } + denom = a1 * b2 - a2 * b1; + if (denom === 0) { + return; + } + offset = Math.abs(denom / 2); + num = b1 * c2 - b2 * c1; + x2 = num < 0 ? (num - offset) / denom : (num + offset) / denom; + num = a2 * c1 - a1 * c2; + y2 = num < 0 ? (num - offset) / denom : (num + offset) / denom; + return { x: x2, y: y2 }; + } + function sameSign$1(r1, r2) { + return r1 * r2 > 0; + } + function intersectPolygon$1(node2, polyPoints, point2) { + var x1 = node2.x; + var y1 = node2.y; + var intersections = []; + var minX = Number.POSITIVE_INFINITY; + var minY = Number.POSITIVE_INFINITY; + polyPoints.forEach(function(entry) { + minX = Math.min(minX, entry.x); + minY = Math.min(minY, entry.y); + }); + var left2 = x1 - node2.width / 2 - minX; + var top2 = y1 - node2.height / 2 - minY; + for (var i2 = 0; i2 < polyPoints.length; i2++) { + var p1 = polyPoints[i2]; + var p2 = polyPoints[i2 < polyPoints.length - 1 ? i2 + 1 : 0]; + var intersect2 = intersectLine$1( + node2, + point2, + { x: left2 + p1.x, y: top2 + p1.y }, + { x: left2 + p2.x, y: top2 + p2.y } + ); + if (intersect2) { + intersections.push(intersect2); + } + } + if (!intersections.length) { + console.log("NO INTERSECTION FOUND, RETURN NODE CENTER", node2); + return node2; + } + if (intersections.length > 1) { + intersections.sort(function(p, q) { + var pdx = p.x - point2.x; + var pdy = p.y - point2.y; + var distp = Math.sqrt(pdx * pdx + pdy * pdy); + var qdx = q.x - point2.x; + var qdy = q.y - point2.y; + var distq = Math.sqrt(qdx * qdx + qdy * qdy); + return distp < distq ? -1 : distp === distq ? 0 : 1; + }); + } + return intersections[0]; + } + function intersectRect$2(node2, point2) { + var x2 = node2.x; + var y2 = node2.y; + var dx = point2.x - x2; + var dy = point2.y - y2; + var w2 = node2.width / 2; + var h = node2.height / 2; + var sx, sy; + if (Math.abs(dy) * w2 > Math.abs(dx) * h) { + if (dy < 0) { + h = -h; + } + sx = dy === 0 ? 0 : h * dx / dy; + sy = h; + } else { + if (dx < 0) { + w2 = -w2; + } + sx = w2; + sy = dx === 0 ? 0 : w2 * dy / dx; + } + return { x: x2 + sx, y: y2 + sy }; + } + var shapes$2 = { + rect: rect$2, + ellipse, + circle: circle$2, + diamond + }; + function setShapes(value2) { + shapes$2 = value2; + } + function rect$2(parent, bbox, node2) { + var shapeSvg = parent.insert("rect", ":first-child").attr("rx", node2.rx).attr("ry", node2.ry).attr("x", -bbox.width / 2).attr("y", -bbox.height / 2).attr("width", bbox.width).attr("height", bbox.height); + node2.intersect = function(point2) { + return intersectRect$2(node2, point2); + }; + return shapeSvg; + } + function ellipse(parent, bbox, node2) { + var rx = bbox.width / 2; + var ry = bbox.height / 2; + var shapeSvg = parent.insert("ellipse", ":first-child").attr("x", -bbox.width / 2).attr("y", -bbox.height / 2).attr("rx", rx).attr("ry", ry); + node2.intersect = function(point2) { + return intersectEllipse$1(node2, rx, ry, point2); + }; + return shapeSvg; + } + function circle$2(parent, bbox, node2) { + var r = Math.max(bbox.width, bbox.height) / 2; + var shapeSvg = parent.insert("circle", ":first-child").attr("x", -bbox.width / 2).attr("y", -bbox.height / 2).attr("r", r); + node2.intersect = function(point2) { + return intersectCircle$1(node2, r, point2); + }; + return shapeSvg; + } + function diamond(parent, bbox, node2) { + var w2 = bbox.width * Math.SQRT2 / 2; + var h = bbox.height * Math.SQRT2 / 2; + var points = [ + { x: 0, y: -h }, + { x: -w2, y: 0 }, + { x: 0, y: h }, + { x: w2, y: 0 } + ]; + var shapeSvg = parent.insert("polygon", ":first-child").attr( + "points", + points.map(function(p) { + return p.x + "," + p.y; + }).join(" ") + ); + node2.intersect = function(p) { + return intersectPolygon$1(node2, points, p); + }; + return shapeSvg; + } + function render$1() { + var fn = function(svg2, g) { + preProcessGraph(g); + var outputGroup = createOrSelectGroup(svg2, "output"); + var clustersGroup = createOrSelectGroup(outputGroup, "clusters"); + var edgePathsGroup = createOrSelectGroup(outputGroup, "edgePaths"); + var edgeLabels2 = createEdgeLabels(createOrSelectGroup(outputGroup, "edgeLabels"), g); + var nodes2 = createNodes(createOrSelectGroup(outputGroup, "nodes"), g, shapes$2); + layout$1(g); + positionNodes$1(nodes2, g); + positionEdgeLabels(edgeLabels2, g); + createEdgePaths(edgePathsGroup, g, arrows); + var clusters = createClusters(clustersGroup, g); + positionClusters(clusters, g); + postProcessGraph(g); + }; + fn.createNodes = function(value2) { + if (!arguments.length) + return createNodes; + setCreateNodes(value2); + return fn; + }; + fn.createClusters = function(value2) { + if (!arguments.length) + return createClusters; + setCreateClusters(value2); + return fn; + }; + fn.createEdgeLabels = function(value2) { + if (!arguments.length) + return createEdgeLabels; + setCreateEdgeLabels(value2); + return fn; + }; + fn.createEdgePaths = function(value2) { + if (!arguments.length) + return createEdgePaths; + setCreateEdgePaths(value2); + return fn; + }; + fn.shapes = function(value2) { + if (!arguments.length) + return shapes$2; + setShapes(value2); + return fn; + }; + fn.arrows = function(value2) { + if (!arguments.length) + return arrows; + setArrows(value2); + return fn; + }; + return fn; + } + var NODE_DEFAULT_ATTRS = { + paddingLeft: 10, + paddingRight: 10, + paddingTop: 10, + paddingBottom: 10, + rx: 0, + ry: 0, + shape: "rect" + }; + var EDGE_DEFAULT_ATTRS = { + arrowhead: "normal", + curve: curveLinear + }; + function preProcessGraph(g) { + g.nodes().forEach(function(v) { + var node2 = g.node(v); + if (!has(node2, "label") && !g.children(v).length) { + node2.label = v; + } + if (has(node2, "paddingX")) { + defaults$1(node2, { + paddingLeft: node2.paddingX, + paddingRight: node2.paddingX + }); + } + if (has(node2, "paddingY")) { + defaults$1(node2, { + paddingTop: node2.paddingY, + paddingBottom: node2.paddingY + }); + } + if (has(node2, "padding")) { + defaults$1(node2, { + paddingLeft: node2.padding, + paddingRight: node2.padding, + paddingTop: node2.padding, + paddingBottom: node2.padding + }); + } + defaults$1(node2, NODE_DEFAULT_ATTRS); + forEach(["paddingLeft", "paddingRight", "paddingTop", "paddingBottom"], function(k) { + node2[k] = Number(node2[k]); + }); + if (has(node2, "width")) { + node2._prevWidth = node2.width; + } + if (has(node2, "height")) { + node2._prevHeight = node2.height; + } + }); + g.edges().forEach(function(e) { + var edge = g.edge(e); + if (!has(edge, "label")) { + edge.label = ""; + } + defaults$1(edge, EDGE_DEFAULT_ATTRS); + }); + } + function postProcessGraph(g) { + forEach(g.nodes(), function(v) { + var node2 = g.node(v); + if (has(node2, "_prevWidth")) { + node2.width = node2._prevWidth; + } else { + delete node2.width; + } + if (has(node2, "_prevHeight")) { + node2.height = node2._prevHeight; + } else { + delete node2.height; + } + delete node2._prevWidth; + delete node2._prevHeight; + }); + } + function createOrSelectGroup(root2, name) { + var selection2 = root2.select("g." + name); + if (selection2.empty()) { + selection2 = root2.append("g").attr("class", name); + } + return selection2; + } + function question$1(parent, bbox, node2) { + const w2 = bbox.width; + const h = bbox.height; + const s = (w2 + h) * 0.9; + const points = [ + { x: s / 2, y: 0 }, + { x: s, y: -s / 2 }, + { x: s / 2, y: -s }, + { x: 0, y: -s / 2 } + ]; + const shapeSvg = insertPolygonShape$2(parent, s, s, points); + node2.intersect = function(point2) { + return intersectPolygon$1(node2, points, point2); + }; + return shapeSvg; + } + function hexagon$1(parent, bbox, node2) { + const f2 = 4; + const h = bbox.height; + const m = h / f2; + const w2 = bbox.width + 2 * m; + const points = [ + { x: m, y: 0 }, + { x: w2 - m, y: 0 }, + { x: w2, y: -h / 2 }, + { x: w2 - m, y: -h }, + { x: m, y: -h }, + { x: 0, y: -h / 2 } + ]; + const shapeSvg = insertPolygonShape$2(parent, w2, h, points); + node2.intersect = function(point2) { + return intersectPolygon$1(node2, points, point2); + }; + return shapeSvg; + } + function rect_left_inv_arrow$1(parent, bbox, node2) { + const w2 = bbox.width; + const h = bbox.height; + const points = [ + { x: -h / 2, y: 0 }, + { x: w2, y: 0 }, + { x: w2, y: -h }, + { x: -h / 2, y: -h }, + { x: 0, y: -h / 2 } + ]; + const shapeSvg = insertPolygonShape$2(parent, w2, h, points); + node2.intersect = function(point2) { + return intersectPolygon$1(node2, points, point2); + }; + return shapeSvg; + } + function lean_right$1(parent, bbox, node2) { + const w2 = bbox.width; + const h = bbox.height; + const points = [ + { x: -2 * h / 6, y: 0 }, + { x: w2 - h / 6, y: 0 }, + { x: w2 + 2 * h / 6, y: -h }, + { x: h / 6, y: -h } + ]; + const shapeSvg = insertPolygonShape$2(parent, w2, h, points); + node2.intersect = function(point2) { + return intersectPolygon$1(node2, points, point2); + }; + return shapeSvg; + } + function lean_left$1(parent, bbox, node2) { + const w2 = bbox.width; + const h = bbox.height; + const points = [ + { x: 2 * h / 6, y: 0 }, + { x: w2 + h / 6, y: 0 }, + { x: w2 - 2 * h / 6, y: -h }, + { x: -h / 6, y: -h } + ]; + const shapeSvg = insertPolygonShape$2(parent, w2, h, points); + node2.intersect = function(point2) { + return intersectPolygon$1(node2, points, point2); + }; + return shapeSvg; + } + function trapezoid$1(parent, bbox, node2) { + const w2 = bbox.width; + const h = bbox.height; + const points = [ + { x: -2 * h / 6, y: 0 }, + { x: w2 + 2 * h / 6, y: 0 }, + { x: w2 - h / 6, y: -h }, + { x: h / 6, y: -h } + ]; + const shapeSvg = insertPolygonShape$2(parent, w2, h, points); + node2.intersect = function(point2) { + return intersectPolygon$1(node2, points, point2); + }; + return shapeSvg; + } + function inv_trapezoid$1(parent, bbox, node2) { + const w2 = bbox.width; + const h = bbox.height; + const points = [ + { x: h / 6, y: 0 }, + { x: w2 - h / 6, y: 0 }, + { x: w2 + 2 * h / 6, y: -h }, + { x: -2 * h / 6, y: -h } + ]; + const shapeSvg = insertPolygonShape$2(parent, w2, h, points); + node2.intersect = function(point2) { + return intersectPolygon$1(node2, points, point2); + }; + return shapeSvg; + } + function rect_right_inv_arrow$1(parent, bbox, node2) { + const w2 = bbox.width; + const h = bbox.height; + const points = [ + { x: 0, y: 0 }, + { x: w2 + h / 2, y: 0 }, + { x: w2, y: -h / 2 }, + { x: w2 + h / 2, y: -h }, + { x: 0, y: -h } + ]; + const shapeSvg = insertPolygonShape$2(parent, w2, h, points); + node2.intersect = function(point2) { + return intersectPolygon$1(node2, points, point2); + }; + return shapeSvg; + } + function stadium$1(parent, bbox, node2) { + const h = bbox.height; + const w2 = bbox.width + h / 4; + const shapeSvg = parent.insert("rect", ":first-child").attr("rx", h / 2).attr("ry", h / 2).attr("x", -w2 / 2).attr("y", -h / 2).attr("width", w2).attr("height", h); + node2.intersect = function(point2) { + return intersectRect$2(node2, point2); + }; + return shapeSvg; + } + function subroutine$1(parent, bbox, node2) { + const w2 = bbox.width; + const h = bbox.height; + const points = [ + { x: 0, y: 0 }, + { x: w2, y: 0 }, + { x: w2, y: -h }, + { x: 0, y: -h }, + { x: 0, y: 0 }, + { x: -8, y: 0 }, + { x: w2 + 8, y: 0 }, + { x: w2 + 8, y: -h }, + { x: -8, y: -h }, + { x: -8, y: 0 } + ]; + const shapeSvg = insertPolygonShape$2(parent, w2, h, points); + node2.intersect = function(point2) { + return intersectPolygon$1(node2, points, point2); + }; + return shapeSvg; + } + function cylinder$1(parent, bbox, node2) { + const w2 = bbox.width; + const rx = w2 / 2; + const ry = rx / (2.5 + w2 / 50); + const h = bbox.height + ry; + const shape = "M 0," + ry + " a " + rx + "," + ry + " 0,0,0 " + w2 + " 0 a " + rx + "," + ry + " 0,0,0 " + -w2 + " 0 l 0," + h + " a " + rx + "," + ry + " 0,0,0 " + w2 + " 0 l 0," + -h; + const shapeSvg = parent.attr("label-offset-y", ry).insert("path", ":first-child").attr("d", shape).attr("transform", "translate(" + -w2 / 2 + "," + -(h / 2 + ry) + ")"); + node2.intersect = function(point2) { + const pos = intersectRect$2(node2, point2); + const x2 = pos.x - node2.x; + if (rx != 0 && (Math.abs(x2) < node2.width / 2 || Math.abs(x2) == node2.width / 2 && Math.abs(pos.y - node2.y) > node2.height / 2 - ry)) { + let y2 = ry * ry * (1 - x2 * x2 / (rx * rx)); + if (y2 != 0) { + y2 = Math.sqrt(y2); + } + y2 = ry - y2; + if (point2.y - node2.y > 0) { + y2 = -y2; + } + pos.y += y2; + } + return pos; + }; + return shapeSvg; + } + function addToRender(render2) { + render2.shapes().question = question$1; + render2.shapes().hexagon = hexagon$1; + render2.shapes().stadium = stadium$1; + render2.shapes().subroutine = subroutine$1; + render2.shapes().cylinder = cylinder$1; + render2.shapes().rect_left_inv_arrow = rect_left_inv_arrow$1; + render2.shapes().lean_right = lean_right$1; + render2.shapes().lean_left = lean_left$1; + render2.shapes().trapezoid = trapezoid$1; + render2.shapes().inv_trapezoid = inv_trapezoid$1; + render2.shapes().rect_right_inv_arrow = rect_right_inv_arrow$1; + } + function addToRenderV2(addShape) { + addShape({ question: question$1 }); + addShape({ hexagon: hexagon$1 }); + addShape({ stadium: stadium$1 }); + addShape({ subroutine: subroutine$1 }); + addShape({ cylinder: cylinder$1 }); + addShape({ rect_left_inv_arrow: rect_left_inv_arrow$1 }); + addShape({ lean_right: lean_right$1 }); + addShape({ lean_left: lean_left$1 }); + addShape({ trapezoid: trapezoid$1 }); + addShape({ inv_trapezoid: inv_trapezoid$1 }); + addShape({ rect_right_inv_arrow: rect_right_inv_arrow$1 }); + } + function insertPolygonShape$2(parent, w2, h, points) { + return parent.insert("polygon", ":first-child").attr( + "points", + points.map(function(d) { + return d.x + "," + d.y; + }).join(" ") + ).attr("transform", "translate(" + -w2 / 2 + "," + h / 2 + ")"); + } + const flowChartShapes = { + addToRender, + addToRenderV2 + }; + const conf$8 = {}; + const setConf$8 = function(cnf) { + const keys2 = Object.keys(cnf); + for (const key of keys2) { + conf$8[key] = cnf[key]; + } + }; + const addVertices$2 = async function(vert, g, svgId, root2, _doc, diagObj) { + const svg2 = !root2 ? d3select(`[id="${svgId}"]`) : root2.select(`[id="${svgId}"]`); + const doc = !_doc ? document : _doc; + const keys2 = Object.keys(vert); + for (const id2 of keys2) { + const vertex = vert[id2]; + let classStr = "default"; + if (vertex.classes.length > 0) { + classStr = vertex.classes.join(" "); + } + const styles2 = getStylesFromArray(vertex.styles); + let vertexText = vertex.text !== void 0 ? vertex.text : vertex.id; + let vertexNode; + if (evaluate(getConfig$1().flowchart.htmlLabels)) { + const node2 = { + label: await renderKatex( + vertexText.replace( + /fa[blrs]?:fa-[\w-]+/g, + // cspell:disable-line + (s) => `` + ), + getConfig$1() + ) + }; + vertexNode = addHtmlLabel$1(svg2, node2).node(); + vertexNode.parentNode.removeChild(vertexNode); + } else { + const svgLabel = doc.createElementNS("http://www.w3.org/2000/svg", "text"); + svgLabel.setAttribute("style", styles2.labelStyle.replace("color:", "fill:")); + const rows = vertexText.split(common$1.lineBreakRegex); + for (const row of rows) { + const tspan = doc.createElementNS("http://www.w3.org/2000/svg", "tspan"); + tspan.setAttributeNS("http://www.w3.org/XML/1998/namespace", "xml:space", "preserve"); + tspan.setAttribute("dy", "1em"); + tspan.setAttribute("x", "1"); + tspan.textContent = row; + svgLabel.appendChild(tspan); + } + vertexNode = svgLabel; + } + let radius = 0; + let _shape = ""; + switch (vertex.type) { + case "round": + radius = 5; + _shape = "rect"; + break; + case "square": + _shape = "rect"; + break; + case "diamond": + _shape = "question"; + break; + case "hexagon": + _shape = "hexagon"; + break; + case "odd": + _shape = "rect_left_inv_arrow"; + break; + case "lean_right": + _shape = "lean_right"; + break; + case "lean_left": + _shape = "lean_left"; + break; + case "trapezoid": + _shape = "trapezoid"; + break; + case "inv_trapezoid": + _shape = "inv_trapezoid"; + break; + case "odd_right": + _shape = "rect_left_inv_arrow"; + break; + case "circle": + _shape = "circle"; + break; + case "ellipse": + _shape = "ellipse"; + break; + case "stadium": + _shape = "stadium"; + break; + case "subroutine": + _shape = "subroutine"; + break; + case "cylinder": + _shape = "cylinder"; + break; + case "group": + _shape = "rect"; + break; + default: + _shape = "rect"; + } + log$1.warn("Adding node", vertex.id, vertex.domId); + g.setNode(diagObj.db.lookUpDomId(vertex.id), { + labelType: "svg", + labelStyle: styles2.labelStyle, + shape: _shape, + label: vertexNode, + rx: radius, + ry: radius, + class: classStr, + style: styles2.style, + id: diagObj.db.lookUpDomId(vertex.id) + }); + } + }; + const addEdges$2 = async function(edges2, g, diagObj) { + let cnt2 = 0; + let defaultStyle2; + let defaultLabelStyle; + if (edges2.defaultStyle !== void 0) { + const defaultStyles = getStylesFromArray(edges2.defaultStyle); + defaultStyle2 = defaultStyles.style; + defaultLabelStyle = defaultStyles.labelStyle; + } + for (const edge of edges2) { + cnt2++; + const linkId = "L-" + edge.start + "-" + edge.end; + const linkNameStart = "LS-" + edge.start; + const linkNameEnd = "LE-" + edge.end; + const edgeData = {}; + if (edge.type === "arrow_open") { + edgeData.arrowhead = "none"; + } else { + edgeData.arrowhead = "normal"; + } + let style = ""; + let labelStyle = ""; + if (edge.style !== void 0) { + const styles2 = getStylesFromArray(edge.style); + style = styles2.style; + labelStyle = styles2.labelStyle; + } else { + switch (edge.stroke) { + case "normal": + style = "fill:none"; + if (defaultStyle2 !== void 0) { + style = defaultStyle2; + } + if (defaultLabelStyle !== void 0) { + labelStyle = defaultLabelStyle; + } + break; + case "dotted": + style = "fill:none;stroke-width:2px;stroke-dasharray:3;"; + break; + case "thick": + style = " stroke-width: 3.5px;fill:none"; + break; + } + } + edgeData.style = style; + edgeData.labelStyle = labelStyle; + if (edge.interpolate !== void 0) { + edgeData.curve = interpolateToCurve(edge.interpolate, curveLinear); + } else if (edges2.defaultInterpolate !== void 0) { + edgeData.curve = interpolateToCurve(edges2.defaultInterpolate, curveLinear); + } else { + edgeData.curve = interpolateToCurve(conf$8.curve, curveLinear); + } + if (edge.text === void 0) { + if (edge.style !== void 0) { + edgeData.arrowheadStyle = "fill: #333"; + } + } else { + edgeData.arrowheadStyle = "fill: #333"; + edgeData.labelpos = "c"; + if (evaluate(getConfig$1().flowchart.htmlLabels)) { + edgeData.labelType = "html"; + edgeData.label = `${await renderKatex( + edge.text.replace( + /fa[blrs]?:fa-[\w-]+/g, + // cspell:disable-line + (s) => `` + ), + getConfig$1() + )}`; + } else { + edgeData.labelType = "text"; + edgeData.label = edge.text.replace(common$1.lineBreakRegex, "\n"); + if (edge.style === void 0) { + edgeData.style = edgeData.style || "stroke: #333; stroke-width: 1.5px;fill:none"; + } + edgeData.labelStyle = edgeData.labelStyle.replace("color:", "fill:"); + } + } + edgeData.id = linkId; + edgeData.class = linkNameStart + " " + linkNameEnd; + edgeData.minlen = edge.length || 1; + g.setEdge(diagObj.db.lookUpDomId(edge.start), diagObj.db.lookUpDomId(edge.end), edgeData, cnt2); + } + }; + const getClasses$7 = function(text2, diagObj) { + log$1.info("Extracting classes"); + return diagObj.db.getClasses(); + }; + const draw$k = async function(text2, id2, _version, diagObj) { + log$1.info("Drawing flowchart"); + const { securityLevel, flowchart: conf2 } = getConfig$1(); + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = d3select("#i" + id2); + } + const root2 = securityLevel === "sandbox" ? d3select(sandboxElement.nodes()[0].contentDocument.body) : d3select("body"); + const doc = securityLevel === "sandbox" ? sandboxElement.nodes()[0].contentDocument : document; + let dir2 = diagObj.db.getDirection(); + if (dir2 === void 0) { + dir2 = "TD"; + } + const nodeSpacing = conf2.nodeSpacing || 50; + const rankSpacing = conf2.rankSpacing || 50; + const g = new Graph({ + multigraph: true, + compound: true + }).setGraph({ + rankdir: dir2, + nodesep: nodeSpacing, + ranksep: rankSpacing, + marginx: 8, + marginy: 8 + }).setDefaultEdgeLabel(function() { + return {}; + }); + let subG; + const subGraphs2 = diagObj.db.getSubGraphs(); + for (let i3 = subGraphs2.length - 1; i3 >= 0; i3--) { + subG = subGraphs2[i3]; + diagObj.db.addVertex(subG.id, subG.title, "group", void 0, subG.classes); + } + const vert = diagObj.db.getVertices(); + log$1.warn("Get vertices", vert); + const edges2 = diagObj.db.getEdges(); + let i2 = 0; + for (i2 = subGraphs2.length - 1; i2 >= 0; i2--) { + subG = subGraphs2[i2]; + selectAll("cluster").append("text"); + for (let j = 0; j < subG.nodes.length; j++) { + log$1.warn( + "Setting subgraph", + subG.nodes[j], + diagObj.db.lookUpDomId(subG.nodes[j]), + diagObj.db.lookUpDomId(subG.id) + ); + g.setParent(diagObj.db.lookUpDomId(subG.nodes[j]), diagObj.db.lookUpDomId(subG.id)); + } + } + await addVertices$2(vert, g, id2, root2, doc, diagObj); + await addEdges$2(edges2, g, diagObj); + const render2 = new render$1(); + flowChartShapes.addToRender(render2); + render2.arrows().none = function normal2(parent, id3, edge, type2) { + const marker = parent.append("marker").attr("id", id3).attr("viewBox", "0 0 10 10").attr("refX", 9).attr("refY", 5).attr("markerUnits", "strokeWidth").attr("markerWidth", 8).attr("markerHeight", 6).attr("orient", "auto"); + const path2 = marker.append("path").attr("d", "M 0 0 L 0 0 L 0 0 z"); + applyStyle$2(path2, edge[type2 + "Style"]); + }; + render2.arrows().normal = function normal2(parent, id3) { + const marker = parent.append("marker").attr("id", id3).attr("viewBox", "0 0 10 10").attr("refX", 9).attr("refY", 5).attr("markerUnits", "strokeWidth").attr("markerWidth", 8).attr("markerHeight", 6).attr("orient", "auto"); + marker.append("path").attr("d", "M 0 0 L 10 5 L 0 10 z").attr("class", "arrowheadPath").style("stroke-width", 1).style("stroke-dasharray", "1,0"); + }; + const svg2 = root2.select(`[id="${id2}"]`); + const element2 = root2.select("#" + id2 + " g"); + render2(element2, g); + element2.selectAll("g.node").attr("title", function() { + return diagObj.db.getTooltip(this.id); + }); + diagObj.db.indexNodes("subGraph" + i2); + for (i2 = 0; i2 < subGraphs2.length; i2++) { + subG = subGraphs2[i2]; + if (subG.title !== "undefined") { + const clusterRects = doc.querySelectorAll( + "#" + id2 + ' [id="' + diagObj.db.lookUpDomId(subG.id) + '"] rect' + ); + const clusterEl = doc.querySelectorAll( + "#" + id2 + ' [id="' + diagObj.db.lookUpDomId(subG.id) + '"]' + ); + const xPos = clusterRects[0].x.baseVal.value; + const yPos = clusterRects[0].y.baseVal.value; + const _width = clusterRects[0].width.baseVal.value; + const cluster = d3select(clusterEl[0]); + const te = cluster.select(".label"); + te.attr("transform", `translate(${xPos + _width / 2}, ${yPos + 14})`); + te.attr("id", id2 + "Text"); + for (let j = 0; j < subG.classes.length; j++) { + clusterEl[0].classList.add(subG.classes[j]); + } + } + } + if (!conf2.htmlLabels) { + const labels = doc.querySelectorAll('[id="' + id2 + '"] .edgeLabel .label'); + for (const label of labels) { + const dim = label.getBBox(); + const rect2 = doc.createElementNS("http://www.w3.org/2000/svg", "rect"); + rect2.setAttribute("rx", 0); + rect2.setAttribute("ry", 0); + rect2.setAttribute("width", dim.width); + rect2.setAttribute("height", dim.height); + label.insertBefore(rect2, label.firstChild); + } + } + setupGraphViewbox$1(g, svg2, conf2.diagramPadding, conf2.useMaxWidth); + const keys2 = Object.keys(vert); + keys2.forEach(function(key) { + const vertex = vert[key]; + if (vertex.link) { + const node2 = root2.select("#" + id2 + ' [id="' + diagObj.db.lookUpDomId(key) + '"]'); + if (node2) { + const link2 = doc.createElementNS("http://www.w3.org/2000/svg", "a"); + link2.setAttributeNS("http://www.w3.org/2000/svg", "class", vertex.classes.join(" ")); + link2.setAttributeNS("http://www.w3.org/2000/svg", "href", vertex.link); + link2.setAttributeNS("http://www.w3.org/2000/svg", "rel", "noopener"); + if (securityLevel === "sandbox") { + link2.setAttributeNS("http://www.w3.org/2000/svg", "target", "_top"); + } else if (vertex.linkTarget) { + link2.setAttributeNS("http://www.w3.org/2000/svg", "target", vertex.linkTarget); + } + const linkNode = node2.insert(function() { + return link2; + }, ":first-child"); + const shape = node2.select(".label-container"); + if (shape) { + linkNode.append(function() { + return shape.node(); + }); + } + const label = node2.select(".label"); + if (label) { + linkNode.append(function() { + return label.node(); + }); + } + } + } + }); + }; + const flowRenderer = { + setConf: setConf$8, + addVertices: addVertices$2, + addEdges: addEdges$2, + getClasses: getClasses$7, + draw: draw$k + }; + function write(g) { + var json2 = { + options: { + directed: g.isDirected(), + multigraph: g.isMultigraph(), + compound: g.isCompound() + }, + nodes: writeNodes(g), + edges: writeEdges(g) + }; + if (!isUndefined(g.graph())) { + json2.value = clone$1(g.graph()); + } + return json2; + } + function writeNodes(g) { + return map(g.nodes(), function(v) { + var nodeValue = g.node(v); + var parent = g.parent(v); + var node2 = { v }; + if (!isUndefined(nodeValue)) { + node2.value = nodeValue; + } + if (!isUndefined(parent)) { + node2.parent = parent; + } + return node2; + }); + } + function writeEdges(g) { + return map(g.edges(), function(e) { + var edgeValue = g.edge(e); + var edge = { v: e.v, w: e.w }; + if (!isUndefined(e.name)) { + edge.name = e.name; + } + if (!isUndefined(edgeValue)) { + edge.value = edgeValue; + } + return edge; + }); + } + const insertMarkers$3 = (elem, markerArray, type2, id2) => { + markerArray.forEach((markerName) => { + markers$1[markerName](elem, type2, id2); + }); + }; + const extension$1 = (elem, type2, id2) => { + log$1.trace("Making markers for ", id2); + elem.append("defs").append("marker").attr("id", id2 + "_" + type2 + "-extensionStart").attr("class", "marker extension " + type2).attr("refX", 18).attr("refY", 7).attr("markerWidth", 190).attr("markerHeight", 240).attr("orient", "auto").append("path").attr("d", "M 1,7 L18,13 V 1 Z"); + elem.append("defs").append("marker").attr("id", id2 + "_" + type2 + "-extensionEnd").attr("class", "marker extension " + type2).attr("refX", 1).attr("refY", 7).attr("markerWidth", 20).attr("markerHeight", 28).attr("orient", "auto").append("path").attr("d", "M 1,1 V 13 L18,7 Z"); + }; + const composition = (elem, type2, id2) => { + elem.append("defs").append("marker").attr("id", id2 + "_" + type2 + "-compositionStart").attr("class", "marker composition " + type2).attr("refX", 18).attr("refY", 7).attr("markerWidth", 190).attr("markerHeight", 240).attr("orient", "auto").append("path").attr("d", "M 18,7 L9,13 L1,7 L9,1 Z"); + elem.append("defs").append("marker").attr("id", id2 + "_" + type2 + "-compositionEnd").attr("class", "marker composition " + type2).attr("refX", 1).attr("refY", 7).attr("markerWidth", 20).attr("markerHeight", 28).attr("orient", "auto").append("path").attr("d", "M 18,7 L9,13 L1,7 L9,1 Z"); + }; + const aggregation = (elem, type2, id2) => { + elem.append("defs").append("marker").attr("id", id2 + "_" + type2 + "-aggregationStart").attr("class", "marker aggregation " + type2).attr("refX", 18).attr("refY", 7).attr("markerWidth", 190).attr("markerHeight", 240).attr("orient", "auto").append("path").attr("d", "M 18,7 L9,13 L1,7 L9,1 Z"); + elem.append("defs").append("marker").attr("id", id2 + "_" + type2 + "-aggregationEnd").attr("class", "marker aggregation " + type2).attr("refX", 1).attr("refY", 7).attr("markerWidth", 20).attr("markerHeight", 28).attr("orient", "auto").append("path").attr("d", "M 18,7 L9,13 L1,7 L9,1 Z"); + }; + const dependency = (elem, type2, id2) => { + elem.append("defs").append("marker").attr("id", id2 + "_" + type2 + "-dependencyStart").attr("class", "marker dependency " + type2).attr("refX", 6).attr("refY", 7).attr("markerWidth", 190).attr("markerHeight", 240).attr("orient", "auto").append("path").attr("d", "M 5,7 L9,13 L1,7 L9,1 Z"); + elem.append("defs").append("marker").attr("id", id2 + "_" + type2 + "-dependencyEnd").attr("class", "marker dependency " + type2).attr("refX", 13).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"); + }; + const lollipop = (elem, type2, id2) => { + elem.append("defs").append("marker").attr("id", id2 + "_" + type2 + "-lollipopStart").attr("class", "marker lollipop " + type2).attr("refX", 13).attr("refY", 7).attr("markerWidth", 190).attr("markerHeight", 240).attr("orient", "auto").append("circle").attr("stroke", "black").attr("fill", "transparent").attr("cx", 7).attr("cy", 7).attr("r", 6); + elem.append("defs").append("marker").attr("id", id2 + "_" + type2 + "-lollipopEnd").attr("class", "marker lollipop " + type2).attr("refX", 1).attr("refY", 7).attr("markerWidth", 190).attr("markerHeight", 240).attr("orient", "auto").append("circle").attr("stroke", "black").attr("fill", "transparent").attr("cx", 7).attr("cy", 7).attr("r", 6); + }; + const point$2 = (elem, type2, id2) => { + elem.append("marker").attr("id", id2 + "_" + type2 + "-pointEnd").attr("class", "marker " + type2).attr("viewBox", "0 0 10 10").attr("refX", 6).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").attr("class", "arrowMarkerPath").style("stroke-width", 1).style("stroke-dasharray", "1,0"); + elem.append("marker").attr("id", id2 + "_" + type2 + "-pointStart").attr("class", "marker " + type2).attr("viewBox", "0 0 10 10").attr("refX", 4.5).attr("refY", 5).attr("markerUnits", "userSpaceOnUse").attr("markerWidth", 12).attr("markerHeight", 12).attr("orient", "auto").append("path").attr("d", "M 0 5 L 10 10 L 10 0 z").attr("class", "arrowMarkerPath").style("stroke-width", 1).style("stroke-dasharray", "1,0"); + }; + const circle$1 = (elem, type2, id2) => { + elem.append("marker").attr("id", id2 + "_" + type2 + "-circleEnd").attr("class", "marker " + type2).attr("viewBox", "0 0 10 10").attr("refX", 11).attr("refY", 5).attr("markerUnits", "userSpaceOnUse").attr("markerWidth", 11).attr("markerHeight", 11).attr("orient", "auto").append("circle").attr("cx", "5").attr("cy", "5").attr("r", "5").attr("class", "arrowMarkerPath").style("stroke-width", 1).style("stroke-dasharray", "1,0"); + elem.append("marker").attr("id", id2 + "_" + type2 + "-circleStart").attr("class", "marker " + type2).attr("viewBox", "0 0 10 10").attr("refX", -1).attr("refY", 5).attr("markerUnits", "userSpaceOnUse").attr("markerWidth", 11).attr("markerHeight", 11).attr("orient", "auto").append("circle").attr("cx", "5").attr("cy", "5").attr("r", "5").attr("class", "arrowMarkerPath").style("stroke-width", 1).style("stroke-dasharray", "1,0"); + }; + const cross = (elem, type2, id2) => { + elem.append("marker").attr("id", id2 + "_" + type2 + "-crossEnd").attr("class", "marker cross " + type2).attr("viewBox", "0 0 11 11").attr("refX", 12).attr("refY", 5.2).attr("markerUnits", "userSpaceOnUse").attr("markerWidth", 11).attr("markerHeight", 11).attr("orient", "auto").append("path").attr("d", "M 1,1 l 9,9 M 10,1 l -9,9").attr("class", "arrowMarkerPath").style("stroke-width", 2).style("stroke-dasharray", "1,0"); + elem.append("marker").attr("id", id2 + "_" + type2 + "-crossStart").attr("class", "marker cross " + type2).attr("viewBox", "0 0 11 11").attr("refX", -1).attr("refY", 5.2).attr("markerUnits", "userSpaceOnUse").attr("markerWidth", 11).attr("markerHeight", 11).attr("orient", "auto").append("path").attr("d", "M 1,1 l 9,9 M 10,1 l -9,9").attr("class", "arrowMarkerPath").style("stroke-width", 2).style("stroke-dasharray", "1,0"); + }; + const barb = (elem, type2, id2) => { + elem.append("defs").append("marker").attr("id", id2 + "_" + type2 + "-barbEnd").attr("refX", 19).attr("refY", 7).attr("markerWidth", 20).attr("markerHeight", 14).attr("markerUnits", "strokeWidth").attr("orient", "auto").append("path").attr("d", "M 19,7 L9,13 L14,7 L9,1 Z"); + }; + const markers$1 = { + extension: extension$1, + composition, + aggregation, + dependency, + lollipop, + point: point$2, + circle: circle$1, + cross, + barb + }; + const insertMarkers$4 = insertMarkers$3; + function applyStyle$1(dom, styleFn) { + if (styleFn) { + dom.attr("style", styleFn); + } + } + function addHtmlLabel(node2) { + const fo = d3select(document.createElementNS("http://www.w3.org/2000/svg", "foreignObject")); + const div = fo.append("xhtml:div"); + const label = node2.label; + const labelClass = node2.isNode ? "nodeLabel" : "edgeLabel"; + div.html( + '" + label + "" + ); + applyStyle$1(div, node2.labelStyle); + div.style("display", "inline-block"); + div.style("white-space", "nowrap"); + div.attr("xmlns", "http://www.w3.org/1999/xhtml"); + return fo.node(); + } + const createLabel = (_vertexText, style, isTitle, isNode) => { + let vertexText = _vertexText || ""; + if (typeof vertexText === "object") { + vertexText = vertexText[0]; + } + if (evaluate(getConfig$1().flowchart.htmlLabels)) { + vertexText = vertexText.replace(/\\n|\n/g, "
    "); + log$1.debug("vertexText" + vertexText); + const node2 = { + isNode, + label: decodeEntities(vertexText).replace( + /fa[blrs]?:fa-[\w-]+/g, + // cspell: disable-line + (s) => `` + ), + labelStyle: style.replace("fill:", "color:") + }; + let vertexNode = addHtmlLabel(node2); + return vertexNode; + } else { + const svgLabel = document.createElementNS("http://www.w3.org/2000/svg", "text"); + svgLabel.setAttribute("style", style.replace("color:", "fill:")); + let rows = []; + if (typeof vertexText === "string") { + rows = vertexText.split(/\\n|\n|/gi); + } else if (Array.isArray(vertexText)) { + rows = vertexText; + } else { + rows = []; + } + for (const row of rows) { + const tspan = document.createElementNS("http://www.w3.org/2000/svg", "tspan"); + tspan.setAttributeNS("http://www.w3.org/XML/1998/namespace", "xml:space", "preserve"); + tspan.setAttribute("dy", "1em"); + tspan.setAttribute("x", "0"); + if (isTitle) { + tspan.setAttribute("class", "title-row"); + } else { + tspan.setAttribute("class", "row"); + } + tspan.textContent = row.trim(); + svgLabel.appendChild(tspan); + } + return svgLabel; + } + }; + const createLabel$1 = createLabel; + const emptyOptions = {}; + function toString(value2, options2) { + const settings = options2 || emptyOptions; + const includeImageAlt = typeof settings.includeImageAlt === "boolean" ? settings.includeImageAlt : true; + const includeHtml = typeof settings.includeHtml === "boolean" ? settings.includeHtml : true; + return one(value2, includeImageAlt, includeHtml); + } + function one(value2, includeImageAlt, includeHtml) { + if (node(value2)) { + if ("value" in value2) { + return value2.type === "html" && !includeHtml ? "" : value2.value; + } + if (includeImageAlt && "alt" in value2 && value2.alt) { + return value2.alt; + } + if ("children" in value2) { + return all(value2.children, includeImageAlt, includeHtml); + } + } + if (Array.isArray(value2)) { + return all(value2, includeImageAlt, includeHtml); + } + return ""; + } + function all(values2, includeImageAlt, includeHtml) { + const result = []; + let index2 = -1; + while (++index2 < values2.length) { + result[index2] = one(values2[index2], includeImageAlt, includeHtml); + } + return result.join(""); + } + function node(value2) { + return Boolean(value2 && typeof value2 === "object"); + } + function splice(list2, start2, remove2, items) { + const end2 = list2.length; + let chunkStart = 0; + let parameters; + if (start2 < 0) { + start2 = -start2 > end2 ? 0 : end2 + start2; + } else { + start2 = start2 > end2 ? end2 : start2; + } + remove2 = remove2 > 0 ? remove2 : 0; + if (items.length < 1e4) { + parameters = Array.from(items); + parameters.unshift(start2, remove2); + list2.splice(...parameters); + } else { + if (remove2) + list2.splice(start2, remove2); + while (chunkStart < items.length) { + parameters = items.slice(chunkStart, chunkStart + 1e4); + parameters.unshift(start2, 0); + list2.splice(...parameters); + chunkStart += 1e4; + start2 += 1e4; + } + } + } + function push(list2, items) { + if (list2.length > 0) { + splice(list2, list2.length, 0, items); + return list2; + } + return items; + } + const hasOwnProperty = {}.hasOwnProperty; + function combineExtensions(extensions) { + const all2 = {}; + let index2 = -1; + while (++index2 < extensions.length) { + syntaxExtension(all2, extensions[index2]); + } + return all2; + } + function syntaxExtension(all2, extension2) { + let hook; + for (hook in extension2) { + const maybe = hasOwnProperty.call(all2, hook) ? all2[hook] : void 0; + const left2 = maybe || (all2[hook] = {}); + const right2 = extension2[hook]; + let code; + if (right2) { + for (code in right2) { + if (!hasOwnProperty.call(left2, code)) + left2[code] = []; + const value2 = right2[code]; + constructs( + // @ts-expect-error Looks like a list. + left2[code], + Array.isArray(value2) ? value2 : value2 ? [value2] : [] + ); + } + } + } + } + function constructs(existing, list2) { + let index2 = -1; + const before = []; + while (++index2 < list2.length) { + (list2[index2].add === "after" ? existing : before).push(list2[index2]); + } + splice(existing, 0, 0, before); + } + const unicodePunctuationRegex = /[!-\/:-@\[-`\{-~\xA1\xA7\xAB\xB6\xB7\xBB\xBF\u037E\u0387\u055A-\u055F\u0589\u058A\u05BE\u05C0\u05C3\u05C6\u05F3\u05F4\u0609\u060A\u060C\u060D\u061B\u061D-\u061F\u066A-\u066D\u06D4\u0700-\u070D\u07F7-\u07F9\u0830-\u083E\u085E\u0964\u0965\u0970\u09FD\u0A76\u0AF0\u0C77\u0C84\u0DF4\u0E4F\u0E5A\u0E5B\u0F04-\u0F12\u0F14\u0F3A-\u0F3D\u0F85\u0FD0-\u0FD4\u0FD9\u0FDA\u104A-\u104F\u10FB\u1360-\u1368\u1400\u166E\u169B\u169C\u16EB-\u16ED\u1735\u1736\u17D4-\u17D6\u17D8-\u17DA\u1800-\u180A\u1944\u1945\u1A1E\u1A1F\u1AA0-\u1AA6\u1AA8-\u1AAD\u1B5A-\u1B60\u1B7D\u1B7E\u1BFC-\u1BFF\u1C3B-\u1C3F\u1C7E\u1C7F\u1CC0-\u1CC7\u1CD3\u2010-\u2027\u2030-\u2043\u2045-\u2051\u2053-\u205E\u207D\u207E\u208D\u208E\u2308-\u230B\u2329\u232A\u2768-\u2775\u27C5\u27C6\u27E6-\u27EF\u2983-\u2998\u29D8-\u29DB\u29FC\u29FD\u2CF9-\u2CFC\u2CFE\u2CFF\u2D70\u2E00-\u2E2E\u2E30-\u2E4F\u2E52-\u2E5D\u3001-\u3003\u3008-\u3011\u3014-\u301F\u3030\u303D\u30A0\u30FB\uA4FE\uA4FF\uA60D-\uA60F\uA673\uA67E\uA6F2-\uA6F7\uA874-\uA877\uA8CE\uA8CF\uA8F8-\uA8FA\uA8FC\uA92E\uA92F\uA95F\uA9C1-\uA9CD\uA9DE\uA9DF\uAA5C-\uAA5F\uAADE\uAADF\uAAF0\uAAF1\uABEB\uFD3E\uFD3F\uFE10-\uFE19\uFE30-\uFE52\uFE54-\uFE61\uFE63\uFE68\uFE6A\uFE6B\uFF01-\uFF03\uFF05-\uFF0A\uFF0C-\uFF0F\uFF1A\uFF1B\uFF1F\uFF20\uFF3B-\uFF3D\uFF3F\uFF5B\uFF5D\uFF5F-\uFF65]/; + const asciiAlpha = regexCheck(/[A-Za-z]/); + const asciiAlphanumeric = regexCheck(/[\dA-Za-z]/); + const asciiAtext = regexCheck(/[#-'*+\--9=?A-Z^-~]/); + function asciiControl(code) { + return ( + // Special whitespace codes (which have negative values), C0 and Control + // character DEL + code !== null && (code < 32 || code === 127) + ); + } + const asciiDigit = regexCheck(/\d/); + const asciiHexDigit = regexCheck(/[\dA-Fa-f]/); + const asciiPunctuation = regexCheck(/[!-/:-@[-`{-~]/); + function markdownLineEnding(code) { + return code !== null && code < -2; + } + function markdownLineEndingOrSpace(code) { + return code !== null && (code < 0 || code === 32); + } + function markdownSpace(code) { + return code === -2 || code === -1 || code === 32; + } + const unicodePunctuation = regexCheck(unicodePunctuationRegex); + const unicodeWhitespace = regexCheck(/\s/); + function regexCheck(regex) { + return check; + function check(code) { + return code !== null && regex.test(String.fromCharCode(code)); + } + } + function factorySpace(effects, ok, type2, max2) { + const limit = max2 ? max2 - 1 : Number.POSITIVE_INFINITY; + let size2 = 0; + return start2; + function start2(code) { + if (markdownSpace(code)) { + effects.enter(type2); + return prefix(code); + } + return ok(code); + } + function prefix(code) { + if (markdownSpace(code) && size2++ < limit) { + effects.consume(code); + return prefix; + } + effects.exit(type2); + return ok(code); + } + } + const content$1 = { + tokenize: initializeContent + }; + function initializeContent(effects) { + const contentStart = effects.attempt( + this.parser.constructs.contentInitial, + afterContentStartConstruct, + paragraphInitial + ); + let previous2; + return contentStart; + function afterContentStartConstruct(code) { + if (code === null) { + effects.consume(code); + return; + } + effects.enter("lineEnding"); + effects.consume(code); + effects.exit("lineEnding"); + return factorySpace(effects, contentStart, "linePrefix"); + } + function paragraphInitial(code) { + effects.enter("paragraph"); + return lineStart(code); + } + function lineStart(code) { + const token2 = effects.enter("chunkText", { + contentType: "text", + previous: previous2 + }); + if (previous2) { + previous2.next = token2; + } + previous2 = token2; + return data(code); + } + function data(code) { + if (code === null) { + effects.exit("chunkText"); + effects.exit("paragraph"); + effects.consume(code); + return; + } + if (markdownLineEnding(code)) { + effects.consume(code); + effects.exit("chunkText"); + return lineStart; + } + effects.consume(code); + return data; + } + } + const document$2 = { + tokenize: initializeDocument + }; + const containerConstruct = { + tokenize: tokenizeContainer + }; + function initializeDocument(effects) { + const self2 = this; + const stack = []; + let continued = 0; + let childFlow; + let childToken; + let lineStartOffset; + return start2; + function start2(code) { + if (continued < stack.length) { + const item = stack[continued]; + self2.containerState = item[1]; + return effects.attempt( + item[0].continuation, + documentContinue, + checkNewContainers + )(code); + } + return checkNewContainers(code); + } + function documentContinue(code) { + continued++; + if (self2.containerState._closeFlow) { + self2.containerState._closeFlow = void 0; + if (childFlow) { + closeFlow(); + } + const indexBeforeExits = self2.events.length; + let indexBeforeFlow = indexBeforeExits; + let point2; + while (indexBeforeFlow--) { + if (self2.events[indexBeforeFlow][0] === "exit" && self2.events[indexBeforeFlow][1].type === "chunkFlow") { + point2 = self2.events[indexBeforeFlow][1].end; + break; + } + } + exitContainers(continued); + let index2 = indexBeforeExits; + while (index2 < self2.events.length) { + self2.events[index2][1].end = Object.assign({}, point2); + index2++; + } + splice( + self2.events, + indexBeforeFlow + 1, + 0, + self2.events.slice(indexBeforeExits) + ); + self2.events.length = index2; + return checkNewContainers(code); + } + return start2(code); + } + function checkNewContainers(code) { + if (continued === stack.length) { + if (!childFlow) { + return documentContinued(code); + } + if (childFlow.currentConstruct && childFlow.currentConstruct.concrete) { + return flowStart(code); + } + self2.interrupt = Boolean( + childFlow.currentConstruct && !childFlow._gfmTableDynamicInterruptHack + ); + } + self2.containerState = {}; + return effects.check( + containerConstruct, + thereIsANewContainer, + thereIsNoNewContainer + )(code); + } + function thereIsANewContainer(code) { + if (childFlow) + closeFlow(); + exitContainers(continued); + return documentContinued(code); + } + function thereIsNoNewContainer(code) { + self2.parser.lazy[self2.now().line] = continued !== stack.length; + lineStartOffset = self2.now().offset; + return flowStart(code); + } + function documentContinued(code) { + self2.containerState = {}; + return effects.attempt( + containerConstruct, + containerContinue, + flowStart + )(code); + } + function containerContinue(code) { + continued++; + stack.push([self2.currentConstruct, self2.containerState]); + return documentContinued(code); + } + function flowStart(code) { + if (code === null) { + if (childFlow) + closeFlow(); + exitContainers(0); + effects.consume(code); + return; + } + childFlow = childFlow || self2.parser.flow(self2.now()); + effects.enter("chunkFlow", { + contentType: "flow", + previous: childToken, + _tokenizer: childFlow + }); + return flowContinue(code); + } + function flowContinue(code) { + if (code === null) { + writeToChild(effects.exit("chunkFlow"), true); + exitContainers(0); + effects.consume(code); + return; + } + if (markdownLineEnding(code)) { + effects.consume(code); + writeToChild(effects.exit("chunkFlow")); + continued = 0; + self2.interrupt = void 0; + return start2; + } + effects.consume(code); + return flowContinue; + } + function writeToChild(token2, eof) { + const stream = self2.sliceStream(token2); + if (eof) + stream.push(null); + token2.previous = childToken; + if (childToken) + childToken.next = token2; + childToken = token2; + childFlow.defineSkip(token2.start); + childFlow.write(stream); + if (self2.parser.lazy[token2.start.line]) { + let index2 = childFlow.events.length; + while (index2--) { + if ( + // The token starts before the line ending… + childFlow.events[index2][1].start.offset < lineStartOffset && // …and either is not ended yet… + (!childFlow.events[index2][1].end || // …or ends after it. + childFlow.events[index2][1].end.offset > lineStartOffset) + ) { + return; + } + } + const indexBeforeExits = self2.events.length; + let indexBeforeFlow = indexBeforeExits; + let seen; + let point2; + while (indexBeforeFlow--) { + if (self2.events[indexBeforeFlow][0] === "exit" && self2.events[indexBeforeFlow][1].type === "chunkFlow") { + if (seen) { + point2 = self2.events[indexBeforeFlow][1].end; + break; + } + seen = true; + } + } + exitContainers(continued); + index2 = indexBeforeExits; + while (index2 < self2.events.length) { + self2.events[index2][1].end = Object.assign({}, point2); + index2++; + } + splice( + self2.events, + indexBeforeFlow + 1, + 0, + self2.events.slice(indexBeforeExits) + ); + self2.events.length = index2; + } + } + function exitContainers(size2) { + let index2 = stack.length; + while (index2-- > size2) { + const entry = stack[index2]; + self2.containerState = entry[1]; + entry[0].exit.call(self2, effects); + } + stack.length = size2; + } + function closeFlow() { + childFlow.write([null]); + childToken = void 0; + childFlow = void 0; + self2.containerState._closeFlow = void 0; + } + } + function tokenizeContainer(effects, ok, nok) { + return factorySpace( + effects, + effects.attempt(this.parser.constructs.document, ok, nok), + "linePrefix", + this.parser.constructs.disable.null.includes("codeIndented") ? void 0 : 4 + ); + } + function classifyCharacter(code) { + if (code === null || markdownLineEndingOrSpace(code) || unicodeWhitespace(code)) { + return 1; + } + if (unicodePunctuation(code)) { + return 2; + } + } + function resolveAll(constructs2, events, context) { + const called = []; + let index2 = -1; + while (++index2 < constructs2.length) { + const resolve = constructs2[index2].resolveAll; + if (resolve && !called.includes(resolve)) { + events = resolve(events, context); + called.push(resolve); + } + } + return events; + } + const attention = { + name: "attention", + tokenize: tokenizeAttention, + resolveAll: resolveAllAttention + }; + function resolveAllAttention(events, context) { + let index2 = -1; + let open2; + let group; + let text2; + let openingSequence; + let closingSequence; + let use; + let nextEvents; + let offset; + while (++index2 < events.length) { + if (events[index2][0] === "enter" && events[index2][1].type === "attentionSequence" && events[index2][1]._close) { + open2 = index2; + while (open2--) { + if (events[open2][0] === "exit" && events[open2][1].type === "attentionSequence" && events[open2][1]._open && // If the markers are the same: + context.sliceSerialize(events[open2][1]).charCodeAt(0) === context.sliceSerialize(events[index2][1]).charCodeAt(0)) { + if ((events[open2][1]._close || events[index2][1]._open) && (events[index2][1].end.offset - events[index2][1].start.offset) % 3 && !((events[open2][1].end.offset - events[open2][1].start.offset + events[index2][1].end.offset - events[index2][1].start.offset) % 3)) { + continue; + } + use = events[open2][1].end.offset - events[open2][1].start.offset > 1 && events[index2][1].end.offset - events[index2][1].start.offset > 1 ? 2 : 1; + const start2 = Object.assign({}, events[open2][1].end); + const end2 = Object.assign({}, events[index2][1].start); + movePoint(start2, -use); + movePoint(end2, use); + openingSequence = { + type: use > 1 ? "strongSequence" : "emphasisSequence", + start: start2, + end: Object.assign({}, events[open2][1].end) + }; + closingSequence = { + type: use > 1 ? "strongSequence" : "emphasisSequence", + start: Object.assign({}, events[index2][1].start), + end: end2 + }; + text2 = { + type: use > 1 ? "strongText" : "emphasisText", + start: Object.assign({}, events[open2][1].end), + end: Object.assign({}, events[index2][1].start) + }; + group = { + type: use > 1 ? "strong" : "emphasis", + start: Object.assign({}, openingSequence.start), + end: Object.assign({}, closingSequence.end) + }; + events[open2][1].end = Object.assign({}, openingSequence.start); + events[index2][1].start = Object.assign({}, closingSequence.end); + nextEvents = []; + if (events[open2][1].end.offset - events[open2][1].start.offset) { + nextEvents = push(nextEvents, [ + ["enter", events[open2][1], context], + ["exit", events[open2][1], context] + ]); + } + nextEvents = push(nextEvents, [ + ["enter", group, context], + ["enter", openingSequence, context], + ["exit", openingSequence, context], + ["enter", text2, context] + ]); + nextEvents = push( + nextEvents, + resolveAll( + context.parser.constructs.insideSpan.null, + events.slice(open2 + 1, index2), + context + ) + ); + nextEvents = push(nextEvents, [ + ["exit", text2, context], + ["enter", closingSequence, context], + ["exit", closingSequence, context], + ["exit", group, context] + ]); + if (events[index2][1].end.offset - events[index2][1].start.offset) { + offset = 2; + nextEvents = push(nextEvents, [ + ["enter", events[index2][1], context], + ["exit", events[index2][1], context] + ]); + } else { + offset = 0; + } + splice(events, open2 - 1, index2 - open2 + 3, nextEvents); + index2 = open2 + nextEvents.length - offset - 2; + break; + } + } + } + } + index2 = -1; + while (++index2 < events.length) { + if (events[index2][1].type === "attentionSequence") { + events[index2][1].type = "data"; + } + } + return events; + } + function tokenizeAttention(effects, ok) { + const attentionMarkers2 = this.parser.constructs.attentionMarkers.null; + const previous2 = this.previous; + const before = classifyCharacter(previous2); + let marker; + return start2; + function start2(code) { + marker = code; + effects.enter("attentionSequence"); + return inside(code); + } + function inside(code) { + if (code === marker) { + effects.consume(code); + return inside; + } + const token2 = effects.exit("attentionSequence"); + const after = classifyCharacter(code); + const open2 = !after || after === 2 && before || attentionMarkers2.includes(code); + const close2 = !before || before === 2 && after || attentionMarkers2.includes(previous2); + token2._open = Boolean(marker === 42 ? open2 : open2 && (before || !close2)); + token2._close = Boolean(marker === 42 ? close2 : close2 && (after || !open2)); + return ok(code); + } + } + function movePoint(point2, offset) { + point2.column += offset; + point2.offset += offset; + point2._bufferIndex += offset; + } + const autolink = { + name: "autolink", + tokenize: tokenizeAutolink + }; + function tokenizeAutolink(effects, ok, nok) { + let size2 = 0; + return start2; + function start2(code) { + effects.enter("autolink"); + effects.enter("autolinkMarker"); + effects.consume(code); + effects.exit("autolinkMarker"); + effects.enter("autolinkProtocol"); + return open2; + } + function open2(code) { + if (asciiAlpha(code)) { + effects.consume(code); + return schemeOrEmailAtext; + } + return emailAtext(code); + } + function schemeOrEmailAtext(code) { + if (code === 43 || code === 45 || code === 46 || asciiAlphanumeric(code)) { + size2 = 1; + return schemeInsideOrEmailAtext(code); + } + return emailAtext(code); + } + function schemeInsideOrEmailAtext(code) { + if (code === 58) { + effects.consume(code); + size2 = 0; + return urlInside; + } + if ((code === 43 || code === 45 || code === 46 || asciiAlphanumeric(code)) && size2++ < 32) { + effects.consume(code); + return schemeInsideOrEmailAtext; + } + size2 = 0; + return emailAtext(code); + } + function urlInside(code) { + if (code === 62) { + effects.exit("autolinkProtocol"); + effects.enter("autolinkMarker"); + effects.consume(code); + effects.exit("autolinkMarker"); + effects.exit("autolink"); + return ok; + } + if (code === null || code === 32 || code === 60 || asciiControl(code)) { + return nok(code); + } + effects.consume(code); + return urlInside; + } + function emailAtext(code) { + if (code === 64) { + effects.consume(code); + return emailAtSignOrDot; + } + if (asciiAtext(code)) { + effects.consume(code); + return emailAtext; + } + return nok(code); + } + function emailAtSignOrDot(code) { + return asciiAlphanumeric(code) ? emailLabel(code) : nok(code); + } + function emailLabel(code) { + if (code === 46) { + effects.consume(code); + size2 = 0; + return emailAtSignOrDot; + } + if (code === 62) { + effects.exit("autolinkProtocol").type = "autolinkEmail"; + effects.enter("autolinkMarker"); + effects.consume(code); + effects.exit("autolinkMarker"); + effects.exit("autolink"); + return ok; + } + return emailValue(code); + } + function emailValue(code) { + if ((code === 45 || asciiAlphanumeric(code)) && size2++ < 63) { + const next2 = code === 45 ? emailValue : emailLabel; + effects.consume(code); + return next2; + } + return nok(code); + } + } + const blankLine = { + tokenize: tokenizeBlankLine, + partial: true + }; + function tokenizeBlankLine(effects, ok, nok) { + return start2; + function start2(code) { + return markdownSpace(code) ? factorySpace(effects, after, "linePrefix")(code) : after(code); + } + function after(code) { + return code === null || markdownLineEnding(code) ? ok(code) : nok(code); + } + } + const blockQuote = { + name: "blockQuote", + tokenize: tokenizeBlockQuoteStart, + continuation: { + tokenize: tokenizeBlockQuoteContinuation + }, + exit + }; + function tokenizeBlockQuoteStart(effects, ok, nok) { + const self2 = this; + return start2; + function start2(code) { + if (code === 62) { + const state2 = self2.containerState; + if (!state2.open) { + effects.enter("blockQuote", { + _container: true + }); + state2.open = true; + } + effects.enter("blockQuotePrefix"); + effects.enter("blockQuoteMarker"); + effects.consume(code); + effects.exit("blockQuoteMarker"); + return after; + } + return nok(code); + } + function after(code) { + if (markdownSpace(code)) { + effects.enter("blockQuotePrefixWhitespace"); + effects.consume(code); + effects.exit("blockQuotePrefixWhitespace"); + effects.exit("blockQuotePrefix"); + return ok; + } + effects.exit("blockQuotePrefix"); + return ok(code); + } + } + function tokenizeBlockQuoteContinuation(effects, ok, nok) { + const self2 = this; + return contStart; + function contStart(code) { + if (markdownSpace(code)) { + return factorySpace( + effects, + contBefore, + "linePrefix", + self2.parser.constructs.disable.null.includes("codeIndented") ? void 0 : 4 + )(code); + } + return contBefore(code); + } + function contBefore(code) { + return effects.attempt(blockQuote, ok, nok)(code); + } + } + function exit(effects) { + effects.exit("blockQuote"); + } + const characterEscape = { + name: "characterEscape", + tokenize: tokenizeCharacterEscape + }; + function tokenizeCharacterEscape(effects, ok, nok) { + return start2; + function start2(code) { + effects.enter("characterEscape"); + effects.enter("escapeMarker"); + effects.consume(code); + effects.exit("escapeMarker"); + return inside; + } + function inside(code) { + if (asciiPunctuation(code)) { + effects.enter("characterEscapeValue"); + effects.consume(code); + effects.exit("characterEscapeValue"); + effects.exit("characterEscape"); + return ok; + } + return nok(code); + } + } + const element = document.createElement("i"); + function decodeNamedCharacterReference(value2) { + const characterReference2 = "&" + value2 + ";"; + element.innerHTML = characterReference2; + const char2 = element.textContent; + if (char2.charCodeAt(char2.length - 1) === 59 && value2 !== "semi") { + return false; + } + return char2 === characterReference2 ? false : char2; + } + const characterReference = { + name: "characterReference", + tokenize: tokenizeCharacterReference + }; + function tokenizeCharacterReference(effects, ok, nok) { + const self2 = this; + let size2 = 0; + let max2; + let test; + return start2; + function start2(code) { + effects.enter("characterReference"); + effects.enter("characterReferenceMarker"); + effects.consume(code); + effects.exit("characterReferenceMarker"); + return open2; + } + function open2(code) { + if (code === 35) { + effects.enter("characterReferenceMarkerNumeric"); + effects.consume(code); + effects.exit("characterReferenceMarkerNumeric"); + return numeric; + } + effects.enter("characterReferenceValue"); + max2 = 31; + test = asciiAlphanumeric; + return value2(code); + } + function numeric(code) { + if (code === 88 || code === 120) { + effects.enter("characterReferenceMarkerHexadecimal"); + effects.consume(code); + effects.exit("characterReferenceMarkerHexadecimal"); + effects.enter("characterReferenceValue"); + max2 = 6; + test = asciiHexDigit; + return value2; + } + effects.enter("characterReferenceValue"); + max2 = 7; + test = asciiDigit; + return value2(code); + } + function value2(code) { + if (code === 59 && size2) { + const token2 = effects.exit("characterReferenceValue"); + if (test === asciiAlphanumeric && !decodeNamedCharacterReference(self2.sliceSerialize(token2))) { + return nok(code); + } + effects.enter("characterReferenceMarker"); + effects.consume(code); + effects.exit("characterReferenceMarker"); + effects.exit("characterReference"); + return ok; + } + if (test(code) && size2++ < max2) { + effects.consume(code); + return value2; + } + return nok(code); + } + } + const nonLazyContinuation = { + tokenize: tokenizeNonLazyContinuation, + partial: true + }; + const codeFenced = { + name: "codeFenced", + tokenize: tokenizeCodeFenced, + concrete: true + }; + function tokenizeCodeFenced(effects, ok, nok) { + const self2 = this; + const closeStart = { + tokenize: tokenizeCloseStart, + partial: true + }; + let initialPrefix = 0; + let sizeOpen = 0; + let marker; + return start2; + function start2(code) { + return beforeSequenceOpen(code); + } + function beforeSequenceOpen(code) { + const tail = self2.events[self2.events.length - 1]; + initialPrefix = tail && tail[1].type === "linePrefix" ? tail[2].sliceSerialize(tail[1], true).length : 0; + marker = code; + effects.enter("codeFenced"); + effects.enter("codeFencedFence"); + effects.enter("codeFencedFenceSequence"); + return sequenceOpen(code); + } + function sequenceOpen(code) { + if (code === marker) { + sizeOpen++; + effects.consume(code); + return sequenceOpen; + } + if (sizeOpen < 3) { + return nok(code); + } + effects.exit("codeFencedFenceSequence"); + return markdownSpace(code) ? factorySpace(effects, infoBefore, "whitespace")(code) : infoBefore(code); + } + function infoBefore(code) { + if (code === null || markdownLineEnding(code)) { + effects.exit("codeFencedFence"); + return self2.interrupt ? ok(code) : effects.check(nonLazyContinuation, atNonLazyBreak, after)(code); + } + effects.enter("codeFencedFenceInfo"); + effects.enter("chunkString", { + contentType: "string" + }); + return info2(code); + } + function info2(code) { + if (code === null || markdownLineEnding(code)) { + effects.exit("chunkString"); + effects.exit("codeFencedFenceInfo"); + return infoBefore(code); + } + if (markdownSpace(code)) { + effects.exit("chunkString"); + effects.exit("codeFencedFenceInfo"); + return factorySpace(effects, metaBefore, "whitespace")(code); + } + if (code === 96 && code === marker) { + return nok(code); + } + effects.consume(code); + return info2; + } + function metaBefore(code) { + if (code === null || markdownLineEnding(code)) { + return infoBefore(code); + } + effects.enter("codeFencedFenceMeta"); + effects.enter("chunkString", { + contentType: "string" + }); + return meta(code); + } + function meta(code) { + if (code === null || markdownLineEnding(code)) { + effects.exit("chunkString"); + effects.exit("codeFencedFenceMeta"); + return infoBefore(code); + } + if (code === 96 && code === marker) { + return nok(code); + } + effects.consume(code); + return meta; + } + function atNonLazyBreak(code) { + return effects.attempt(closeStart, after, contentBefore)(code); + } + function contentBefore(code) { + effects.enter("lineEnding"); + effects.consume(code); + effects.exit("lineEnding"); + return contentStart; + } + function contentStart(code) { + return initialPrefix > 0 && markdownSpace(code) ? factorySpace( + effects, + beforeContentChunk, + "linePrefix", + initialPrefix + 1 + )(code) : beforeContentChunk(code); + } + function beforeContentChunk(code) { + if (code === null || markdownLineEnding(code)) { + return effects.check(nonLazyContinuation, atNonLazyBreak, after)(code); + } + effects.enter("codeFlowValue"); + return contentChunk(code); + } + function contentChunk(code) { + if (code === null || markdownLineEnding(code)) { + effects.exit("codeFlowValue"); + return beforeContentChunk(code); + } + effects.consume(code); + return contentChunk; + } + function after(code) { + effects.exit("codeFenced"); + return ok(code); + } + function tokenizeCloseStart(effects2, ok2, nok2) { + let size2 = 0; + return startBefore; + function startBefore(code) { + effects2.enter("lineEnding"); + effects2.consume(code); + effects2.exit("lineEnding"); + return start3; + } + function start3(code) { + effects2.enter("codeFencedFence"); + return markdownSpace(code) ? factorySpace( + effects2, + beforeSequenceClose, + "linePrefix", + self2.parser.constructs.disable.null.includes("codeIndented") ? void 0 : 4 + )(code) : beforeSequenceClose(code); + } + function beforeSequenceClose(code) { + if (code === marker) { + effects2.enter("codeFencedFenceSequence"); + return sequenceClose(code); + } + return nok2(code); + } + function sequenceClose(code) { + if (code === marker) { + size2++; + effects2.consume(code); + return sequenceClose; + } + if (size2 >= sizeOpen) { + effects2.exit("codeFencedFenceSequence"); + return markdownSpace(code) ? factorySpace(effects2, sequenceCloseAfter, "whitespace")(code) : sequenceCloseAfter(code); + } + return nok2(code); + } + function sequenceCloseAfter(code) { + if (code === null || markdownLineEnding(code)) { + effects2.exit("codeFencedFence"); + return ok2(code); + } + return nok2(code); + } + } + } + function tokenizeNonLazyContinuation(effects, ok, nok) { + const self2 = this; + return start2; + function start2(code) { + if (code === null) { + return nok(code); + } + effects.enter("lineEnding"); + effects.consume(code); + effects.exit("lineEnding"); + return lineStart; + } + function lineStart(code) { + return self2.parser.lazy[self2.now().line] ? nok(code) : ok(code); + } + } + const codeIndented = { + name: "codeIndented", + tokenize: tokenizeCodeIndented + }; + const furtherStart = { + tokenize: tokenizeFurtherStart, + partial: true + }; + function tokenizeCodeIndented(effects, ok, nok) { + const self2 = this; + return start2; + function start2(code) { + effects.enter("codeIndented"); + return factorySpace(effects, afterPrefix, "linePrefix", 4 + 1)(code); + } + function afterPrefix(code) { + const tail = self2.events[self2.events.length - 1]; + return tail && tail[1].type === "linePrefix" && tail[2].sliceSerialize(tail[1], true).length >= 4 ? atBreak(code) : nok(code); + } + function atBreak(code) { + if (code === null) { + return after(code); + } + if (markdownLineEnding(code)) { + return effects.attempt(furtherStart, atBreak, after)(code); + } + effects.enter("codeFlowValue"); + return inside(code); + } + function inside(code) { + if (code === null || markdownLineEnding(code)) { + effects.exit("codeFlowValue"); + return atBreak(code); + } + effects.consume(code); + return inside; + } + function after(code) { + effects.exit("codeIndented"); + return ok(code); + } + } + function tokenizeFurtherStart(effects, ok, nok) { + const self2 = this; + return furtherStart2; + function furtherStart2(code) { + if (self2.parser.lazy[self2.now().line]) { + return nok(code); + } + if (markdownLineEnding(code)) { + effects.enter("lineEnding"); + effects.consume(code); + effects.exit("lineEnding"); + return furtherStart2; + } + return factorySpace(effects, afterPrefix, "linePrefix", 4 + 1)(code); + } + function afterPrefix(code) { + const tail = self2.events[self2.events.length - 1]; + return tail && tail[1].type === "linePrefix" && tail[2].sliceSerialize(tail[1], true).length >= 4 ? ok(code) : markdownLineEnding(code) ? furtherStart2(code) : nok(code); + } + } + const codeText = { + name: "codeText", + tokenize: tokenizeCodeText, + resolve: resolveCodeText, + previous + }; + function resolveCodeText(events) { + let tailExitIndex = events.length - 4; + let headEnterIndex = 3; + let index2; + let enter2; + if ((events[headEnterIndex][1].type === "lineEnding" || events[headEnterIndex][1].type === "space") && (events[tailExitIndex][1].type === "lineEnding" || events[tailExitIndex][1].type === "space")) { + index2 = headEnterIndex; + while (++index2 < tailExitIndex) { + if (events[index2][1].type === "codeTextData") { + events[headEnterIndex][1].type = "codeTextPadding"; + events[tailExitIndex][1].type = "codeTextPadding"; + headEnterIndex += 2; + tailExitIndex -= 2; + break; + } + } + } + index2 = headEnterIndex - 1; + tailExitIndex++; + while (++index2 <= tailExitIndex) { + if (enter2 === void 0) { + if (index2 !== tailExitIndex && events[index2][1].type !== "lineEnding") { + enter2 = index2; + } + } else if (index2 === tailExitIndex || events[index2][1].type === "lineEnding") { + events[enter2][1].type = "codeTextData"; + if (index2 !== enter2 + 2) { + events[enter2][1].end = events[index2 - 1][1].end; + events.splice(enter2 + 2, index2 - enter2 - 2); + tailExitIndex -= index2 - enter2 - 2; + index2 = enter2 + 2; + } + enter2 = void 0; + } + } + return events; + } + function previous(code) { + return code !== 96 || this.events[this.events.length - 1][1].type === "characterEscape"; + } + function tokenizeCodeText(effects, ok, nok) { + let sizeOpen = 0; + let size2; + let token2; + return start2; + function start2(code) { + effects.enter("codeText"); + effects.enter("codeTextSequence"); + return sequenceOpen(code); + } + function sequenceOpen(code) { + if (code === 96) { + effects.consume(code); + sizeOpen++; + return sequenceOpen; + } + effects.exit("codeTextSequence"); + return between(code); + } + function between(code) { + if (code === null) { + return nok(code); + } + if (code === 32) { + effects.enter("space"); + effects.consume(code); + effects.exit("space"); + return between; + } + if (code === 96) { + token2 = effects.enter("codeTextSequence"); + size2 = 0; + return sequenceClose(code); + } + if (markdownLineEnding(code)) { + effects.enter("lineEnding"); + effects.consume(code); + effects.exit("lineEnding"); + return between; + } + effects.enter("codeTextData"); + return data(code); + } + function data(code) { + if (code === null || code === 32 || code === 96 || markdownLineEnding(code)) { + effects.exit("codeTextData"); + return between(code); + } + effects.consume(code); + return data; + } + function sequenceClose(code) { + if (code === 96) { + effects.consume(code); + size2++; + return sequenceClose; + } + if (size2 === sizeOpen) { + effects.exit("codeTextSequence"); + effects.exit("codeText"); + return ok(code); + } + token2.type = "codeTextData"; + return data(code); + } + } + function subtokenize(events) { + const jumps = {}; + let index2 = -1; + let event; + let lineIndex; + let otherIndex; + let otherEvent; + let parameters; + let subevents; + let more; + while (++index2 < events.length) { + while (index2 in jumps) { + index2 = jumps[index2]; + } + event = events[index2]; + if (index2 && event[1].type === "chunkFlow" && events[index2 - 1][1].type === "listItemPrefix") { + subevents = event[1]._tokenizer.events; + otherIndex = 0; + if (otherIndex < subevents.length && subevents[otherIndex][1].type === "lineEndingBlank") { + otherIndex += 2; + } + if (otherIndex < subevents.length && subevents[otherIndex][1].type === "content") { + while (++otherIndex < subevents.length) { + if (subevents[otherIndex][1].type === "content") { + break; + } + if (subevents[otherIndex][1].type === "chunkText") { + subevents[otherIndex][1]._isInFirstContentOfListItem = true; + otherIndex++; + } + } + } + } + if (event[0] === "enter") { + if (event[1].contentType) { + Object.assign(jumps, subcontent(events, index2)); + index2 = jumps[index2]; + more = true; + } + } else if (event[1]._container) { + otherIndex = index2; + lineIndex = void 0; + while (otherIndex--) { + otherEvent = events[otherIndex]; + if (otherEvent[1].type === "lineEnding" || otherEvent[1].type === "lineEndingBlank") { + if (otherEvent[0] === "enter") { + if (lineIndex) { + events[lineIndex][1].type = "lineEndingBlank"; + } + otherEvent[1].type = "lineEnding"; + lineIndex = otherIndex; + } + } else { + break; + } + } + if (lineIndex) { + event[1].end = Object.assign({}, events[lineIndex][1].start); + parameters = events.slice(lineIndex, index2); + parameters.unshift(event); + splice(events, lineIndex, index2 - lineIndex + 1, parameters); + } + } + } + return !more; + } + function subcontent(events, eventIndex) { + const token2 = events[eventIndex][1]; + const context = events[eventIndex][2]; + let startPosition = eventIndex - 1; + const startPositions = []; + const tokenizer = token2._tokenizer || context.parser[token2.contentType](token2.start); + const childEvents = tokenizer.events; + const jumps = []; + const gaps = {}; + let stream; + let previous2; + let index2 = -1; + let current = token2; + let adjust2 = 0; + let start2 = 0; + const breaks = [start2]; + while (current) { + while (events[++startPosition][1] !== current) { + } + startPositions.push(startPosition); + if (!current._tokenizer) { + stream = context.sliceStream(current); + if (!current.next) { + stream.push(null); + } + if (previous2) { + tokenizer.defineSkip(current.start); + } + if (current._isInFirstContentOfListItem) { + tokenizer._gfmTasklistFirstContentOfListItem = true; + } + tokenizer.write(stream); + if (current._isInFirstContentOfListItem) { + tokenizer._gfmTasklistFirstContentOfListItem = void 0; + } + } + previous2 = current; + current = current.next; + } + current = token2; + while (++index2 < childEvents.length) { + if ( + // Find a void token that includes a break. + childEvents[index2][0] === "exit" && childEvents[index2 - 1][0] === "enter" && childEvents[index2][1].type === childEvents[index2 - 1][1].type && childEvents[index2][1].start.line !== childEvents[index2][1].end.line + ) { + start2 = index2 + 1; + breaks.push(start2); + current._tokenizer = void 0; + current.previous = void 0; + current = current.next; + } + } + tokenizer.events = []; + if (current) { + current._tokenizer = void 0; + current.previous = void 0; + } else { + breaks.pop(); + } + index2 = breaks.length; + while (index2--) { + const slice2 = childEvents.slice(breaks[index2], breaks[index2 + 1]); + const start3 = startPositions.pop(); + jumps.unshift([start3, start3 + slice2.length - 1]); + splice(events, start3, 2, slice2); + } + index2 = -1; + while (++index2 < jumps.length) { + gaps[adjust2 + jumps[index2][0]] = adjust2 + jumps[index2][1]; + adjust2 += jumps[index2][1] - jumps[index2][0] - 1; + } + return gaps; + } + const content = { + tokenize: tokenizeContent, + resolve: resolveContent + }; + const continuationConstruct = { + tokenize: tokenizeContinuation, + partial: true + }; + function resolveContent(events) { + subtokenize(events); + return events; + } + function tokenizeContent(effects, ok) { + let previous2; + return chunkStart; + function chunkStart(code) { + effects.enter("content"); + previous2 = effects.enter("chunkContent", { + contentType: "content" + }); + return chunkInside(code); + } + function chunkInside(code) { + if (code === null) { + return contentEnd(code); + } + if (markdownLineEnding(code)) { + return effects.check( + continuationConstruct, + contentContinue, + contentEnd + )(code); + } + effects.consume(code); + return chunkInside; + } + function contentEnd(code) { + effects.exit("chunkContent"); + effects.exit("content"); + return ok(code); + } + function contentContinue(code) { + effects.consume(code); + effects.exit("chunkContent"); + previous2.next = effects.enter("chunkContent", { + contentType: "content", + previous: previous2 + }); + previous2 = previous2.next; + return chunkInside; + } + } + function tokenizeContinuation(effects, ok, nok) { + const self2 = this; + return startLookahead; + function startLookahead(code) { + effects.exit("chunkContent"); + effects.enter("lineEnding"); + effects.consume(code); + effects.exit("lineEnding"); + return factorySpace(effects, prefixed, "linePrefix"); + } + function prefixed(code) { + if (code === null || markdownLineEnding(code)) { + return nok(code); + } + const tail = self2.events[self2.events.length - 1]; + if (!self2.parser.constructs.disable.null.includes("codeIndented") && tail && tail[1].type === "linePrefix" && tail[2].sliceSerialize(tail[1], true).length >= 4) { + return ok(code); + } + return effects.interrupt(self2.parser.constructs.flow, nok, ok)(code); + } + } + function factoryDestination(effects, ok, nok, type2, literalType, literalMarkerType, rawType, stringType, max2) { + const limit = max2 || Number.POSITIVE_INFINITY; + let balance2 = 0; + return start2; + function start2(code) { + if (code === 60) { + effects.enter(type2); + effects.enter(literalType); + effects.enter(literalMarkerType); + effects.consume(code); + effects.exit(literalMarkerType); + return enclosedBefore; + } + if (code === null || code === 32 || code === 41 || asciiControl(code)) { + return nok(code); + } + effects.enter(type2); + effects.enter(rawType); + effects.enter(stringType); + effects.enter("chunkString", { + contentType: "string" + }); + return raw(code); + } + function enclosedBefore(code) { + if (code === 62) { + effects.enter(literalMarkerType); + effects.consume(code); + effects.exit(literalMarkerType); + effects.exit(literalType); + effects.exit(type2); + return ok; + } + effects.enter(stringType); + effects.enter("chunkString", { + contentType: "string" + }); + return enclosed(code); + } + function enclosed(code) { + if (code === 62) { + effects.exit("chunkString"); + effects.exit(stringType); + return enclosedBefore(code); + } + if (code === null || code === 60 || markdownLineEnding(code)) { + return nok(code); + } + effects.consume(code); + return code === 92 ? enclosedEscape : enclosed; + } + function enclosedEscape(code) { + if (code === 60 || code === 62 || code === 92) { + effects.consume(code); + return enclosed; + } + return enclosed(code); + } + function raw(code) { + if (!balance2 && (code === null || code === 41 || markdownLineEndingOrSpace(code))) { + effects.exit("chunkString"); + effects.exit(stringType); + effects.exit(rawType); + effects.exit(type2); + return ok(code); + } + if (balance2 < limit && code === 40) { + effects.consume(code); + balance2++; + return raw; + } + if (code === 41) { + effects.consume(code); + balance2--; + return raw; + } + if (code === null || code === 32 || code === 40 || asciiControl(code)) { + return nok(code); + } + effects.consume(code); + return code === 92 ? rawEscape : raw; + } + function rawEscape(code) { + if (code === 40 || code === 41 || code === 92) { + effects.consume(code); + return raw; + } + return raw(code); + } + } + function factoryLabel(effects, ok, nok, type2, markerType, stringType) { + const self2 = this; + let size2 = 0; + let seen; + return start2; + function start2(code) { + effects.enter(type2); + effects.enter(markerType); + effects.consume(code); + effects.exit(markerType); + effects.enter(stringType); + return atBreak; + } + function atBreak(code) { + if (size2 > 999 || code === null || code === 91 || code === 93 && !seen || // To do: remove in the future once we’ve switched from + // `micromark-extension-footnote` to `micromark-extension-gfm-footnote`, + // which doesn’t need this. + // Hidden footnotes hook. + /* c8 ignore next 3 */ + code === 94 && !size2 && "_hiddenFootnoteSupport" in self2.parser.constructs) { + return nok(code); + } + if (code === 93) { + effects.exit(stringType); + effects.enter(markerType); + effects.consume(code); + effects.exit(markerType); + effects.exit(type2); + return ok; + } + if (markdownLineEnding(code)) { + effects.enter("lineEnding"); + effects.consume(code); + effects.exit("lineEnding"); + return atBreak; + } + effects.enter("chunkString", { + contentType: "string" + }); + return labelInside(code); + } + function labelInside(code) { + if (code === null || code === 91 || code === 93 || markdownLineEnding(code) || size2++ > 999) { + effects.exit("chunkString"); + return atBreak(code); + } + effects.consume(code); + if (!seen) + seen = !markdownSpace(code); + return code === 92 ? labelEscape : labelInside; + } + function labelEscape(code) { + if (code === 91 || code === 92 || code === 93) { + effects.consume(code); + size2++; + return labelInside; + } + return labelInside(code); + } + } + function factoryTitle(effects, ok, nok, type2, markerType, stringType) { + let marker; + return start2; + function start2(code) { + if (code === 34 || code === 39 || code === 40) { + effects.enter(type2); + effects.enter(markerType); + effects.consume(code); + effects.exit(markerType); + marker = code === 40 ? 41 : code; + return begin; + } + return nok(code); + } + function begin(code) { + if (code === marker) { + effects.enter(markerType); + effects.consume(code); + effects.exit(markerType); + effects.exit(type2); + return ok; + } + effects.enter(stringType); + return atBreak(code); + } + function atBreak(code) { + if (code === marker) { + effects.exit(stringType); + return begin(marker); + } + if (code === null) { + return nok(code); + } + if (markdownLineEnding(code)) { + effects.enter("lineEnding"); + effects.consume(code); + effects.exit("lineEnding"); + return factorySpace(effects, atBreak, "linePrefix"); + } + effects.enter("chunkString", { + contentType: "string" + }); + return inside(code); + } + function inside(code) { + if (code === marker || code === null || markdownLineEnding(code)) { + effects.exit("chunkString"); + return atBreak(code); + } + effects.consume(code); + return code === 92 ? escape2 : inside; + } + function escape2(code) { + if (code === marker || code === 92) { + effects.consume(code); + return inside; + } + return inside(code); + } + } + function factoryWhitespace(effects, ok) { + let seen; + return start2; + function start2(code) { + if (markdownLineEnding(code)) { + effects.enter("lineEnding"); + effects.consume(code); + effects.exit("lineEnding"); + seen = true; + return start2; + } + if (markdownSpace(code)) { + return factorySpace( + effects, + start2, + seen ? "linePrefix" : "lineSuffix" + )(code); + } + return ok(code); + } + } + function normalizeIdentifier(value2) { + return value2.replace(/[\t\n\r ]+/g, " ").replace(/^ | $/g, "").toLowerCase().toUpperCase(); + } + const definition = { + name: "definition", + tokenize: tokenizeDefinition + }; + const titleBefore = { + tokenize: tokenizeTitleBefore, + partial: true + }; + function tokenizeDefinition(effects, ok, nok) { + const self2 = this; + let identifier2; + return start2; + function start2(code) { + effects.enter("definition"); + return before(code); + } + function before(code) { + return factoryLabel.call( + self2, + effects, + labelAfter, + // Note: we don’t need to reset the way `markdown-rs` does. + nok, + "definitionLabel", + "definitionLabelMarker", + "definitionLabelString" + )(code); + } + function labelAfter(code) { + identifier2 = normalizeIdentifier( + self2.sliceSerialize(self2.events[self2.events.length - 1][1]).slice(1, -1) + ); + if (code === 58) { + effects.enter("definitionMarker"); + effects.consume(code); + effects.exit("definitionMarker"); + return markerAfter; + } + return nok(code); + } + function markerAfter(code) { + return markdownLineEndingOrSpace(code) ? factoryWhitespace(effects, destinationBefore)(code) : destinationBefore(code); + } + function destinationBefore(code) { + return factoryDestination( + effects, + destinationAfter, + // Note: we don’t need to reset the way `markdown-rs` does. + nok, + "definitionDestination", + "definitionDestinationLiteral", + "definitionDestinationLiteralMarker", + "definitionDestinationRaw", + "definitionDestinationString" + )(code); + } + function destinationAfter(code) { + return effects.attempt(titleBefore, after, after)(code); + } + function after(code) { + return markdownSpace(code) ? factorySpace(effects, afterWhitespace, "whitespace")(code) : afterWhitespace(code); + } + function afterWhitespace(code) { + if (code === null || markdownLineEnding(code)) { + effects.exit("definition"); + self2.parser.defined.push(identifier2); + return ok(code); + } + return nok(code); + } + } + function tokenizeTitleBefore(effects, ok, nok) { + return titleBefore2; + function titleBefore2(code) { + return markdownLineEndingOrSpace(code) ? factoryWhitespace(effects, beforeMarker)(code) : nok(code); + } + function beforeMarker(code) { + return factoryTitle( + effects, + titleAfter, + nok, + "definitionTitle", + "definitionTitleMarker", + "definitionTitleString" + )(code); + } + function titleAfter(code) { + return markdownSpace(code) ? factorySpace(effects, titleAfterOptionalWhitespace, "whitespace")(code) : titleAfterOptionalWhitespace(code); + } + function titleAfterOptionalWhitespace(code) { + return code === null || markdownLineEnding(code) ? ok(code) : nok(code); + } + } + const hardBreakEscape = { + name: "hardBreakEscape", + tokenize: tokenizeHardBreakEscape + }; + function tokenizeHardBreakEscape(effects, ok, nok) { + return start2; + function start2(code) { + effects.enter("hardBreakEscape"); + effects.consume(code); + return after; + } + function after(code) { + if (markdownLineEnding(code)) { + effects.exit("hardBreakEscape"); + return ok(code); + } + return nok(code); + } + } + const headingAtx = { + name: "headingAtx", + tokenize: tokenizeHeadingAtx, + resolve: resolveHeadingAtx + }; + function resolveHeadingAtx(events, context) { + let contentEnd = events.length - 2; + let contentStart = 3; + let content2; + let text2; + if (events[contentStart][1].type === "whitespace") { + contentStart += 2; + } + if (contentEnd - 2 > contentStart && events[contentEnd][1].type === "whitespace") { + contentEnd -= 2; + } + if (events[contentEnd][1].type === "atxHeadingSequence" && (contentStart === contentEnd - 1 || contentEnd - 4 > contentStart && events[contentEnd - 2][1].type === "whitespace")) { + contentEnd -= contentStart + 1 === contentEnd ? 2 : 4; + } + if (contentEnd > contentStart) { + content2 = { + type: "atxHeadingText", + start: events[contentStart][1].start, + end: events[contentEnd][1].end + }; + text2 = { + type: "chunkText", + start: events[contentStart][1].start, + end: events[contentEnd][1].end, + contentType: "text" + }; + splice(events, contentStart, contentEnd - contentStart + 1, [ + ["enter", content2, context], + ["enter", text2, context], + ["exit", text2, context], + ["exit", content2, context] + ]); + } + return events; + } + function tokenizeHeadingAtx(effects, ok, nok) { + let size2 = 0; + return start2; + function start2(code) { + effects.enter("atxHeading"); + return before(code); + } + function before(code) { + effects.enter("atxHeadingSequence"); + return sequenceOpen(code); + } + function sequenceOpen(code) { + if (code === 35 && size2++ < 6) { + effects.consume(code); + return sequenceOpen; + } + if (code === null || markdownLineEndingOrSpace(code)) { + effects.exit("atxHeadingSequence"); + return atBreak(code); + } + return nok(code); + } + function atBreak(code) { + if (code === 35) { + effects.enter("atxHeadingSequence"); + return sequenceFurther(code); + } + if (code === null || markdownLineEnding(code)) { + effects.exit("atxHeading"); + return ok(code); + } + if (markdownSpace(code)) { + return factorySpace(effects, atBreak, "whitespace")(code); + } + effects.enter("atxHeadingText"); + return data(code); + } + function sequenceFurther(code) { + if (code === 35) { + effects.consume(code); + return sequenceFurther; + } + effects.exit("atxHeadingSequence"); + return atBreak(code); + } + function data(code) { + if (code === null || code === 35 || markdownLineEndingOrSpace(code)) { + effects.exit("atxHeadingText"); + return atBreak(code); + } + effects.consume(code); + return data; + } + } + const htmlBlockNames = [ + "address", + "article", + "aside", + "base", + "basefont", + "blockquote", + "body", + "caption", + "center", + "col", + "colgroup", + "dd", + "details", + "dialog", + "dir", + "div", + "dl", + "dt", + "fieldset", + "figcaption", + "figure", + "footer", + "form", + "frame", + "frameset", + "h1", + "h2", + "h3", + "h4", + "h5", + "h6", + "head", + "header", + "hr", + "html", + "iframe", + "legend", + "li", + "link", + "main", + "menu", + "menuitem", + "nav", + "noframes", + "ol", + "optgroup", + "option", + "p", + "param", + "search", + "section", + "summary", + "table", + "tbody", + "td", + "tfoot", + "th", + "thead", + "title", + "tr", + "track", + "ul" + ]; + const htmlRawNames = ["pre", "script", "style", "textarea"]; + const htmlFlow = { + name: "htmlFlow", + tokenize: tokenizeHtmlFlow, + resolveTo: resolveToHtmlFlow, + concrete: true + }; + const blankLineBefore = { + tokenize: tokenizeBlankLineBefore, + partial: true + }; + const nonLazyContinuationStart = { + tokenize: tokenizeNonLazyContinuationStart, + partial: true + }; + function resolveToHtmlFlow(events) { + let index2 = events.length; + while (index2--) { + if (events[index2][0] === "enter" && events[index2][1].type === "htmlFlow") { + break; + } + } + if (index2 > 1 && events[index2 - 2][1].type === "linePrefix") { + events[index2][1].start = events[index2 - 2][1].start; + events[index2 + 1][1].start = events[index2 - 2][1].start; + events.splice(index2 - 2, 2); + } + return events; + } + function tokenizeHtmlFlow(effects, ok, nok) { + const self2 = this; + let marker; + let closingTag; + let buffer; + let index2; + let markerB; + return start2; + function start2(code) { + return before(code); + } + function before(code) { + effects.enter("htmlFlow"); + effects.enter("htmlFlowData"); + effects.consume(code); + return open2; + } + function open2(code) { + if (code === 33) { + effects.consume(code); + return declarationOpen; + } + if (code === 47) { + effects.consume(code); + closingTag = true; + return tagCloseStart; + } + if (code === 63) { + effects.consume(code); + marker = 3; + return self2.interrupt ? ok : continuationDeclarationInside; + } + if (asciiAlpha(code)) { + effects.consume(code); + buffer = String.fromCharCode(code); + return tagName; + } + return nok(code); + } + function declarationOpen(code) { + if (code === 45) { + effects.consume(code); + marker = 2; + return commentOpenInside; + } + if (code === 91) { + effects.consume(code); + marker = 5; + index2 = 0; + return cdataOpenInside; + } + if (asciiAlpha(code)) { + effects.consume(code); + marker = 4; + return self2.interrupt ? ok : continuationDeclarationInside; + } + return nok(code); + } + function commentOpenInside(code) { + if (code === 45) { + effects.consume(code); + return self2.interrupt ? ok : continuationDeclarationInside; + } + return nok(code); + } + function cdataOpenInside(code) { + const value2 = "CDATA["; + if (code === value2.charCodeAt(index2++)) { + effects.consume(code); + if (index2 === value2.length) { + return self2.interrupt ? ok : continuation; + } + return cdataOpenInside; + } + return nok(code); + } + function tagCloseStart(code) { + if (asciiAlpha(code)) { + effects.consume(code); + buffer = String.fromCharCode(code); + return tagName; + } + return nok(code); + } + function tagName(code) { + if (code === null || code === 47 || code === 62 || markdownLineEndingOrSpace(code)) { + const slash = code === 47; + const name = buffer.toLowerCase(); + if (!slash && !closingTag && htmlRawNames.includes(name)) { + marker = 1; + return self2.interrupt ? ok(code) : continuation(code); + } + if (htmlBlockNames.includes(buffer.toLowerCase())) { + marker = 6; + if (slash) { + effects.consume(code); + return basicSelfClosing; + } + return self2.interrupt ? ok(code) : continuation(code); + } + marker = 7; + return self2.interrupt && !self2.parser.lazy[self2.now().line] ? nok(code) : closingTag ? completeClosingTagAfter(code) : completeAttributeNameBefore(code); + } + if (code === 45 || asciiAlphanumeric(code)) { + effects.consume(code); + buffer += String.fromCharCode(code); + return tagName; + } + return nok(code); + } + function basicSelfClosing(code) { + if (code === 62) { + effects.consume(code); + return self2.interrupt ? ok : continuation; + } + return nok(code); + } + function completeClosingTagAfter(code) { + if (markdownSpace(code)) { + effects.consume(code); + return completeClosingTagAfter; + } + return completeEnd(code); + } + function completeAttributeNameBefore(code) { + if (code === 47) { + effects.consume(code); + return completeEnd; + } + if (code === 58 || code === 95 || asciiAlpha(code)) { + effects.consume(code); + return completeAttributeName; + } + if (markdownSpace(code)) { + effects.consume(code); + return completeAttributeNameBefore; + } + return completeEnd(code); + } + function completeAttributeName(code) { + if (code === 45 || code === 46 || code === 58 || code === 95 || asciiAlphanumeric(code)) { + effects.consume(code); + return completeAttributeName; + } + return completeAttributeNameAfter(code); + } + function completeAttributeNameAfter(code) { + if (code === 61) { + effects.consume(code); + return completeAttributeValueBefore; + } + if (markdownSpace(code)) { + effects.consume(code); + return completeAttributeNameAfter; + } + return completeAttributeNameBefore(code); + } + function completeAttributeValueBefore(code) { + if (code === null || code === 60 || code === 61 || code === 62 || code === 96) { + return nok(code); + } + if (code === 34 || code === 39) { + effects.consume(code); + markerB = code; + return completeAttributeValueQuoted; + } + if (markdownSpace(code)) { + effects.consume(code); + return completeAttributeValueBefore; + } + return completeAttributeValueUnquoted(code); + } + function completeAttributeValueQuoted(code) { + if (code === markerB) { + effects.consume(code); + markerB = null; + return completeAttributeValueQuotedAfter; + } + if (code === null || markdownLineEnding(code)) { + return nok(code); + } + effects.consume(code); + return completeAttributeValueQuoted; + } + function completeAttributeValueUnquoted(code) { + if (code === null || code === 34 || code === 39 || code === 47 || code === 60 || code === 61 || code === 62 || code === 96 || markdownLineEndingOrSpace(code)) { + return completeAttributeNameAfter(code); + } + effects.consume(code); + return completeAttributeValueUnquoted; + } + function completeAttributeValueQuotedAfter(code) { + if (code === 47 || code === 62 || markdownSpace(code)) { + return completeAttributeNameBefore(code); + } + return nok(code); + } + function completeEnd(code) { + if (code === 62) { + effects.consume(code); + return completeAfter; + } + return nok(code); + } + function completeAfter(code) { + if (code === null || markdownLineEnding(code)) { + return continuation(code); + } + if (markdownSpace(code)) { + effects.consume(code); + return completeAfter; + } + return nok(code); + } + function continuation(code) { + if (code === 45 && marker === 2) { + effects.consume(code); + return continuationCommentInside; + } + if (code === 60 && marker === 1) { + effects.consume(code); + return continuationRawTagOpen; + } + if (code === 62 && marker === 4) { + effects.consume(code); + return continuationClose; + } + if (code === 63 && marker === 3) { + effects.consume(code); + return continuationDeclarationInside; + } + if (code === 93 && marker === 5) { + effects.consume(code); + return continuationCdataInside; + } + if (markdownLineEnding(code) && (marker === 6 || marker === 7)) { + effects.exit("htmlFlowData"); + return effects.check( + blankLineBefore, + continuationAfter, + continuationStart + )(code); + } + if (code === null || markdownLineEnding(code)) { + effects.exit("htmlFlowData"); + return continuationStart(code); + } + effects.consume(code); + return continuation; + } + function continuationStart(code) { + return effects.check( + nonLazyContinuationStart, + continuationStartNonLazy, + continuationAfter + )(code); + } + function continuationStartNonLazy(code) { + effects.enter("lineEnding"); + effects.consume(code); + effects.exit("lineEnding"); + return continuationBefore; + } + function continuationBefore(code) { + if (code === null || markdownLineEnding(code)) { + return continuationStart(code); + } + effects.enter("htmlFlowData"); + return continuation(code); + } + function continuationCommentInside(code) { + if (code === 45) { + effects.consume(code); + return continuationDeclarationInside; + } + return continuation(code); + } + function continuationRawTagOpen(code) { + if (code === 47) { + effects.consume(code); + buffer = ""; + return continuationRawEndTag; + } + return continuation(code); + } + function continuationRawEndTag(code) { + if (code === 62) { + const name = buffer.toLowerCase(); + if (htmlRawNames.includes(name)) { + effects.consume(code); + return continuationClose; + } + return continuation(code); + } + if (asciiAlpha(code) && buffer.length < 8) { + effects.consume(code); + buffer += String.fromCharCode(code); + return continuationRawEndTag; + } + return continuation(code); + } + function continuationCdataInside(code) { + if (code === 93) { + effects.consume(code); + return continuationDeclarationInside; + } + return continuation(code); + } + function continuationDeclarationInside(code) { + if (code === 62) { + effects.consume(code); + return continuationClose; + } + if (code === 45 && marker === 2) { + effects.consume(code); + return continuationDeclarationInside; + } + return continuation(code); + } + function continuationClose(code) { + if (code === null || markdownLineEnding(code)) { + effects.exit("htmlFlowData"); + return continuationAfter(code); + } + effects.consume(code); + return continuationClose; + } + function continuationAfter(code) { + effects.exit("htmlFlow"); + return ok(code); + } + } + function tokenizeNonLazyContinuationStart(effects, ok, nok) { + const self2 = this; + return start2; + function start2(code) { + if (markdownLineEnding(code)) { + effects.enter("lineEnding"); + effects.consume(code); + effects.exit("lineEnding"); + return after; + } + return nok(code); + } + function after(code) { + return self2.parser.lazy[self2.now().line] ? nok(code) : ok(code); + } + } + function tokenizeBlankLineBefore(effects, ok, nok) { + return start2; + function start2(code) { + effects.enter("lineEnding"); + effects.consume(code); + effects.exit("lineEnding"); + return effects.attempt(blankLine, ok, nok); + } + } + const htmlText = { + name: "htmlText", + tokenize: tokenizeHtmlText + }; + function tokenizeHtmlText(effects, ok, nok) { + const self2 = this; + let marker; + let index2; + let returnState; + return start2; + function start2(code) { + effects.enter("htmlText"); + effects.enter("htmlTextData"); + effects.consume(code); + return open2; + } + function open2(code) { + if (code === 33) { + effects.consume(code); + return declarationOpen; + } + if (code === 47) { + effects.consume(code); + return tagCloseStart; + } + if (code === 63) { + effects.consume(code); + return instruction; + } + if (asciiAlpha(code)) { + effects.consume(code); + return tagOpen; + } + return nok(code); + } + function declarationOpen(code) { + if (code === 45) { + effects.consume(code); + return commentOpenInside; + } + if (code === 91) { + effects.consume(code); + index2 = 0; + return cdataOpenInside; + } + if (asciiAlpha(code)) { + effects.consume(code); + return declaration2; + } + return nok(code); + } + function commentOpenInside(code) { + if (code === 45) { + effects.consume(code); + return commentEnd; + } + return nok(code); + } + function comment2(code) { + if (code === null) { + return nok(code); + } + if (code === 45) { + effects.consume(code); + return commentClose; + } + if (markdownLineEnding(code)) { + returnState = comment2; + return lineEndingBefore(code); + } + effects.consume(code); + return comment2; + } + function commentClose(code) { + if (code === 45) { + effects.consume(code); + return commentEnd; + } + return comment2(code); + } + function commentEnd(code) { + return code === 62 ? end2(code) : code === 45 ? commentClose(code) : comment2(code); + } + function cdataOpenInside(code) { + const value2 = "CDATA["; + if (code === value2.charCodeAt(index2++)) { + effects.consume(code); + return index2 === value2.length ? cdata : cdataOpenInside; + } + return nok(code); + } + function cdata(code) { + if (code === null) { + return nok(code); + } + if (code === 93) { + effects.consume(code); + return cdataClose; + } + if (markdownLineEnding(code)) { + returnState = cdata; + return lineEndingBefore(code); + } + effects.consume(code); + return cdata; + } + function cdataClose(code) { + if (code === 93) { + effects.consume(code); + return cdataEnd; + } + return cdata(code); + } + function cdataEnd(code) { + if (code === 62) { + return end2(code); + } + if (code === 93) { + effects.consume(code); + return cdataEnd; + } + return cdata(code); + } + function declaration2(code) { + if (code === null || code === 62) { + return end2(code); + } + if (markdownLineEnding(code)) { + returnState = declaration2; + return lineEndingBefore(code); + } + effects.consume(code); + return declaration2; + } + function instruction(code) { + if (code === null) { + return nok(code); + } + if (code === 63) { + effects.consume(code); + return instructionClose; + } + if (markdownLineEnding(code)) { + returnState = instruction; + return lineEndingBefore(code); + } + effects.consume(code); + return instruction; + } + function instructionClose(code) { + return code === 62 ? end2(code) : instruction(code); + } + function tagCloseStart(code) { + if (asciiAlpha(code)) { + effects.consume(code); + return tagClose; + } + return nok(code); + } + function tagClose(code) { + if (code === 45 || asciiAlphanumeric(code)) { + effects.consume(code); + return tagClose; + } + return tagCloseBetween(code); + } + function tagCloseBetween(code) { + if (markdownLineEnding(code)) { + returnState = tagCloseBetween; + return lineEndingBefore(code); + } + if (markdownSpace(code)) { + effects.consume(code); + return tagCloseBetween; + } + return end2(code); + } + function tagOpen(code) { + if (code === 45 || asciiAlphanumeric(code)) { + effects.consume(code); + return tagOpen; + } + if (code === 47 || code === 62 || markdownLineEndingOrSpace(code)) { + return tagOpenBetween(code); + } + return nok(code); + } + function tagOpenBetween(code) { + if (code === 47) { + effects.consume(code); + return end2; + } + if (code === 58 || code === 95 || asciiAlpha(code)) { + effects.consume(code); + return tagOpenAttributeName; + } + if (markdownLineEnding(code)) { + returnState = tagOpenBetween; + return lineEndingBefore(code); + } + if (markdownSpace(code)) { + effects.consume(code); + return tagOpenBetween; + } + return end2(code); + } + function tagOpenAttributeName(code) { + if (code === 45 || code === 46 || code === 58 || code === 95 || asciiAlphanumeric(code)) { + effects.consume(code); + return tagOpenAttributeName; + } + return tagOpenAttributeNameAfter(code); + } + function tagOpenAttributeNameAfter(code) { + if (code === 61) { + effects.consume(code); + return tagOpenAttributeValueBefore; + } + if (markdownLineEnding(code)) { + returnState = tagOpenAttributeNameAfter; + return lineEndingBefore(code); + } + if (markdownSpace(code)) { + effects.consume(code); + return tagOpenAttributeNameAfter; + } + return tagOpenBetween(code); + } + function tagOpenAttributeValueBefore(code) { + if (code === null || code === 60 || code === 61 || code === 62 || code === 96) { + return nok(code); + } + if (code === 34 || code === 39) { + effects.consume(code); + marker = code; + return tagOpenAttributeValueQuoted; + } + if (markdownLineEnding(code)) { + returnState = tagOpenAttributeValueBefore; + return lineEndingBefore(code); + } + if (markdownSpace(code)) { + effects.consume(code); + return tagOpenAttributeValueBefore; + } + effects.consume(code); + return tagOpenAttributeValueUnquoted; + } + function tagOpenAttributeValueQuoted(code) { + if (code === marker) { + effects.consume(code); + marker = void 0; + return tagOpenAttributeValueQuotedAfter; + } + if (code === null) { + return nok(code); + } + if (markdownLineEnding(code)) { + returnState = tagOpenAttributeValueQuoted; + return lineEndingBefore(code); + } + effects.consume(code); + return tagOpenAttributeValueQuoted; + } + function tagOpenAttributeValueUnquoted(code) { + if (code === null || code === 34 || code === 39 || code === 60 || code === 61 || code === 96) { + return nok(code); + } + if (code === 47 || code === 62 || markdownLineEndingOrSpace(code)) { + return tagOpenBetween(code); + } + effects.consume(code); + return tagOpenAttributeValueUnquoted; + } + function tagOpenAttributeValueQuotedAfter(code) { + if (code === 47 || code === 62 || markdownLineEndingOrSpace(code)) { + return tagOpenBetween(code); + } + return nok(code); + } + function end2(code) { + if (code === 62) { + effects.consume(code); + effects.exit("htmlTextData"); + effects.exit("htmlText"); + return ok; + } + return nok(code); + } + function lineEndingBefore(code) { + effects.exit("htmlTextData"); + effects.enter("lineEnding"); + effects.consume(code); + effects.exit("lineEnding"); + return lineEndingAfter; + } + function lineEndingAfter(code) { + return markdownSpace(code) ? factorySpace( + effects, + lineEndingAfterPrefix, + "linePrefix", + self2.parser.constructs.disable.null.includes("codeIndented") ? void 0 : 4 + )(code) : lineEndingAfterPrefix(code); + } + function lineEndingAfterPrefix(code) { + effects.enter("htmlTextData"); + return returnState(code); + } + } + const labelEnd = { + name: "labelEnd", + tokenize: tokenizeLabelEnd, + resolveTo: resolveToLabelEnd, + resolveAll: resolveAllLabelEnd + }; + const resourceConstruct = { + tokenize: tokenizeResource + }; + const referenceFullConstruct = { + tokenize: tokenizeReferenceFull + }; + const referenceCollapsedConstruct = { + tokenize: tokenizeReferenceCollapsed + }; + function resolveAllLabelEnd(events) { + let index2 = -1; + while (++index2 < events.length) { + const token2 = events[index2][1]; + if (token2.type === "labelImage" || token2.type === "labelLink" || token2.type === "labelEnd") { + events.splice(index2 + 1, token2.type === "labelImage" ? 4 : 2); + token2.type = "data"; + index2++; + } + } + return events; + } + function resolveToLabelEnd(events, context) { + let index2 = events.length; + let offset = 0; + let token2; + let open2; + let close2; + let media; + while (index2--) { + token2 = events[index2][1]; + if (open2) { + if (token2.type === "link" || token2.type === "labelLink" && token2._inactive) { + break; + } + if (events[index2][0] === "enter" && token2.type === "labelLink") { + token2._inactive = true; + } + } else if (close2) { + if (events[index2][0] === "enter" && (token2.type === "labelImage" || token2.type === "labelLink") && !token2._balanced) { + open2 = index2; + if (token2.type !== "labelLink") { + offset = 2; + break; + } + } + } else if (token2.type === "labelEnd") { + close2 = index2; + } + } + const group = { + type: events[open2][1].type === "labelLink" ? "link" : "image", + start: Object.assign({}, events[open2][1].start), + end: Object.assign({}, events[events.length - 1][1].end) + }; + const label = { + type: "label", + start: Object.assign({}, events[open2][1].start), + end: Object.assign({}, events[close2][1].end) + }; + const text2 = { + type: "labelText", + start: Object.assign({}, events[open2 + offset + 2][1].end), + end: Object.assign({}, events[close2 - 2][1].start) + }; + media = [ + ["enter", group, context], + ["enter", label, context] + ]; + media = push(media, events.slice(open2 + 1, open2 + offset + 3)); + media = push(media, [["enter", text2, context]]); + media = push( + media, + resolveAll( + context.parser.constructs.insideSpan.null, + events.slice(open2 + offset + 4, close2 - 3), + context + ) + ); + media = push(media, [ + ["exit", text2, context], + events[close2 - 2], + events[close2 - 1], + ["exit", label, context] + ]); + media = push(media, events.slice(close2 + 1)); + media = push(media, [["exit", group, context]]); + splice(events, open2, events.length, media); + return events; + } + function tokenizeLabelEnd(effects, ok, nok) { + const self2 = this; + let index2 = self2.events.length; + let labelStart; + let defined; + while (index2--) { + if ((self2.events[index2][1].type === "labelImage" || self2.events[index2][1].type === "labelLink") && !self2.events[index2][1]._balanced) { + labelStart = self2.events[index2][1]; + break; + } + } + return start2; + function start2(code) { + if (!labelStart) { + return nok(code); + } + if (labelStart._inactive) { + return labelEndNok(code); + } + defined = self2.parser.defined.includes( + normalizeIdentifier( + self2.sliceSerialize({ + start: labelStart.end, + end: self2.now() + }) + ) + ); + effects.enter("labelEnd"); + effects.enter("labelMarker"); + effects.consume(code); + effects.exit("labelMarker"); + effects.exit("labelEnd"); + return after; + } + function after(code) { + if (code === 40) { + return effects.attempt( + resourceConstruct, + labelEndOk, + defined ? labelEndOk : labelEndNok + )(code); + } + if (code === 91) { + return effects.attempt( + referenceFullConstruct, + labelEndOk, + defined ? referenceNotFull : labelEndNok + )(code); + } + return defined ? labelEndOk(code) : labelEndNok(code); + } + function referenceNotFull(code) { + return effects.attempt( + referenceCollapsedConstruct, + labelEndOk, + labelEndNok + )(code); + } + function labelEndOk(code) { + return ok(code); + } + function labelEndNok(code) { + labelStart._balanced = true; + return nok(code); + } + } + function tokenizeResource(effects, ok, nok) { + return resourceStart; + function resourceStart(code) { + effects.enter("resource"); + effects.enter("resourceMarker"); + effects.consume(code); + effects.exit("resourceMarker"); + return resourceBefore; + } + function resourceBefore(code) { + return markdownLineEndingOrSpace(code) ? factoryWhitespace(effects, resourceOpen)(code) : resourceOpen(code); + } + function resourceOpen(code) { + if (code === 41) { + return resourceEnd(code); + } + return factoryDestination( + effects, + resourceDestinationAfter, + resourceDestinationMissing, + "resourceDestination", + "resourceDestinationLiteral", + "resourceDestinationLiteralMarker", + "resourceDestinationRaw", + "resourceDestinationString", + 32 + )(code); + } + function resourceDestinationAfter(code) { + return markdownLineEndingOrSpace(code) ? factoryWhitespace(effects, resourceBetween)(code) : resourceEnd(code); + } + function resourceDestinationMissing(code) { + return nok(code); + } + function resourceBetween(code) { + if (code === 34 || code === 39 || code === 40) { + return factoryTitle( + effects, + resourceTitleAfter, + nok, + "resourceTitle", + "resourceTitleMarker", + "resourceTitleString" + )(code); + } + return resourceEnd(code); + } + function resourceTitleAfter(code) { + return markdownLineEndingOrSpace(code) ? factoryWhitespace(effects, resourceEnd)(code) : resourceEnd(code); + } + function resourceEnd(code) { + if (code === 41) { + effects.enter("resourceMarker"); + effects.consume(code); + effects.exit("resourceMarker"); + effects.exit("resource"); + return ok; + } + return nok(code); + } + } + function tokenizeReferenceFull(effects, ok, nok) { + const self2 = this; + return referenceFull; + function referenceFull(code) { + return factoryLabel.call( + self2, + effects, + referenceFullAfter, + referenceFullMissing, + "reference", + "referenceMarker", + "referenceString" + )(code); + } + function referenceFullAfter(code) { + return self2.parser.defined.includes( + normalizeIdentifier( + self2.sliceSerialize(self2.events[self2.events.length - 1][1]).slice(1, -1) + ) + ) ? ok(code) : nok(code); + } + function referenceFullMissing(code) { + return nok(code); + } + } + function tokenizeReferenceCollapsed(effects, ok, nok) { + return referenceCollapsedStart; + function referenceCollapsedStart(code) { + effects.enter("reference"); + effects.enter("referenceMarker"); + effects.consume(code); + effects.exit("referenceMarker"); + return referenceCollapsedOpen; + } + function referenceCollapsedOpen(code) { + if (code === 93) { + effects.enter("referenceMarker"); + effects.consume(code); + effects.exit("referenceMarker"); + effects.exit("reference"); + return ok; + } + return nok(code); + } + } + const labelStartImage = { + name: "labelStartImage", + tokenize: tokenizeLabelStartImage, + resolveAll: labelEnd.resolveAll + }; + function tokenizeLabelStartImage(effects, ok, nok) { + const self2 = this; + return start2; + function start2(code) { + effects.enter("labelImage"); + effects.enter("labelImageMarker"); + effects.consume(code); + effects.exit("labelImageMarker"); + return open2; + } + function open2(code) { + if (code === 91) { + effects.enter("labelMarker"); + effects.consume(code); + effects.exit("labelMarker"); + effects.exit("labelImage"); + return after; + } + return nok(code); + } + function after(code) { + return code === 94 && "_hiddenFootnoteSupport" in self2.parser.constructs ? nok(code) : ok(code); + } + } + const labelStartLink = { + name: "labelStartLink", + tokenize: tokenizeLabelStartLink, + resolveAll: labelEnd.resolveAll + }; + function tokenizeLabelStartLink(effects, ok, nok) { + const self2 = this; + return start2; + function start2(code) { + effects.enter("labelLink"); + effects.enter("labelMarker"); + effects.consume(code); + effects.exit("labelMarker"); + effects.exit("labelLink"); + return after; + } + function after(code) { + return code === 94 && "_hiddenFootnoteSupport" in self2.parser.constructs ? nok(code) : ok(code); + } + } + const lineEnding = { + name: "lineEnding", + tokenize: tokenizeLineEnding + }; + function tokenizeLineEnding(effects, ok) { + return start2; + function start2(code) { + effects.enter("lineEnding"); + effects.consume(code); + effects.exit("lineEnding"); + return factorySpace(effects, ok, "linePrefix"); + } + } + const thematicBreak = { + name: "thematicBreak", + tokenize: tokenizeThematicBreak + }; + function tokenizeThematicBreak(effects, ok, nok) { + let size2 = 0; + let marker; + return start2; + function start2(code) { + effects.enter("thematicBreak"); + return before(code); + } + function before(code) { + marker = code; + return atBreak(code); + } + function atBreak(code) { + if (code === marker) { + effects.enter("thematicBreakSequence"); + return sequence2(code); + } + if (size2 >= 3 && (code === null || markdownLineEnding(code))) { + effects.exit("thematicBreak"); + return ok(code); + } + return nok(code); + } + function sequence2(code) { + if (code === marker) { + effects.consume(code); + size2++; + return sequence2; + } + effects.exit("thematicBreakSequence"); + return markdownSpace(code) ? factorySpace(effects, atBreak, "whitespace")(code) : atBreak(code); + } + } + const list = { + name: "list", + tokenize: tokenizeListStart, + continuation: { + tokenize: tokenizeListContinuation + }, + exit: tokenizeListEnd + }; + const listItemPrefixWhitespaceConstruct = { + tokenize: tokenizeListItemPrefixWhitespace, + partial: true + }; + const indentConstruct = { + tokenize: tokenizeIndent, + partial: true + }; + function tokenizeListStart(effects, ok, nok) { + const self2 = this; + const tail = self2.events[self2.events.length - 1]; + let initialSize = tail && tail[1].type === "linePrefix" ? tail[2].sliceSerialize(tail[1], true).length : 0; + let size2 = 0; + return start2; + function start2(code) { + const kind = self2.containerState.type || (code === 42 || code === 43 || code === 45 ? "listUnordered" : "listOrdered"); + if (kind === "listUnordered" ? !self2.containerState.marker || code === self2.containerState.marker : asciiDigit(code)) { + if (!self2.containerState.type) { + self2.containerState.type = kind; + effects.enter(kind, { + _container: true + }); + } + if (kind === "listUnordered") { + effects.enter("listItemPrefix"); + return code === 42 || code === 45 ? effects.check(thematicBreak, nok, atMarker)(code) : atMarker(code); + } + if (!self2.interrupt || code === 49) { + effects.enter("listItemPrefix"); + effects.enter("listItemValue"); + return inside(code); + } + } + return nok(code); + } + function inside(code) { + if (asciiDigit(code) && ++size2 < 10) { + effects.consume(code); + return inside; + } + if ((!self2.interrupt || size2 < 2) && (self2.containerState.marker ? code === self2.containerState.marker : code === 41 || code === 46)) { + effects.exit("listItemValue"); + return atMarker(code); + } + return nok(code); + } + function atMarker(code) { + effects.enter("listItemMarker"); + effects.consume(code); + effects.exit("listItemMarker"); + self2.containerState.marker = self2.containerState.marker || code; + return effects.check( + blankLine, + // Can’t be empty when interrupting. + self2.interrupt ? nok : onBlank, + effects.attempt( + listItemPrefixWhitespaceConstruct, + endOfPrefix, + otherPrefix + ) + ); + } + function onBlank(code) { + self2.containerState.initialBlankLine = true; + initialSize++; + return endOfPrefix(code); + } + function otherPrefix(code) { + if (markdownSpace(code)) { + effects.enter("listItemPrefixWhitespace"); + effects.consume(code); + effects.exit("listItemPrefixWhitespace"); + return endOfPrefix; + } + return nok(code); + } + function endOfPrefix(code) { + self2.containerState.size = initialSize + self2.sliceSerialize(effects.exit("listItemPrefix"), true).length; + return ok(code); + } + } + function tokenizeListContinuation(effects, ok, nok) { + const self2 = this; + self2.containerState._closeFlow = void 0; + return effects.check(blankLine, onBlank, notBlank); + function onBlank(code) { + self2.containerState.furtherBlankLines = self2.containerState.furtherBlankLines || self2.containerState.initialBlankLine; + return factorySpace( + effects, + ok, + "listItemIndent", + self2.containerState.size + 1 + )(code); + } + function notBlank(code) { + if (self2.containerState.furtherBlankLines || !markdownSpace(code)) { + self2.containerState.furtherBlankLines = void 0; + self2.containerState.initialBlankLine = void 0; + return notInCurrentItem(code); + } + self2.containerState.furtherBlankLines = void 0; + self2.containerState.initialBlankLine = void 0; + return effects.attempt(indentConstruct, ok, notInCurrentItem)(code); + } + function notInCurrentItem(code) { + self2.containerState._closeFlow = true; + self2.interrupt = void 0; + return factorySpace( + effects, + effects.attempt(list, ok, nok), + "linePrefix", + self2.parser.constructs.disable.null.includes("codeIndented") ? void 0 : 4 + )(code); + } + } + function tokenizeIndent(effects, ok, nok) { + const self2 = this; + return factorySpace( + effects, + afterPrefix, + "listItemIndent", + self2.containerState.size + 1 + ); + function afterPrefix(code) { + const tail = self2.events[self2.events.length - 1]; + return tail && tail[1].type === "listItemIndent" && tail[2].sliceSerialize(tail[1], true).length === self2.containerState.size ? ok(code) : nok(code); + } + } + function tokenizeListEnd(effects) { + effects.exit(this.containerState.type); + } + function tokenizeListItemPrefixWhitespace(effects, ok, nok) { + const self2 = this; + return factorySpace( + effects, + afterPrefix, + "listItemPrefixWhitespace", + self2.parser.constructs.disable.null.includes("codeIndented") ? void 0 : 4 + 1 + ); + function afterPrefix(code) { + const tail = self2.events[self2.events.length - 1]; + return !markdownSpace(code) && tail && tail[1].type === "listItemPrefixWhitespace" ? ok(code) : nok(code); + } + } + const setextUnderline = { + name: "setextUnderline", + tokenize: tokenizeSetextUnderline, + resolveTo: resolveToSetextUnderline + }; + function resolveToSetextUnderline(events, context) { + let index2 = events.length; + let content2; + let text2; + let definition2; + while (index2--) { + if (events[index2][0] === "enter") { + if (events[index2][1].type === "content") { + content2 = index2; + break; + } + if (events[index2][1].type === "paragraph") { + text2 = index2; + } + } else { + if (events[index2][1].type === "content") { + events.splice(index2, 1); + } + if (!definition2 && events[index2][1].type === "definition") { + definition2 = index2; + } + } + } + const heading = { + type: "setextHeading", + start: Object.assign({}, events[text2][1].start), + end: Object.assign({}, events[events.length - 1][1].end) + }; + events[text2][1].type = "setextHeadingText"; + if (definition2) { + events.splice(text2, 0, ["enter", heading, context]); + events.splice(definition2 + 1, 0, ["exit", events[content2][1], context]); + events[content2][1].end = Object.assign({}, events[definition2][1].end); + } else { + events[content2][1] = heading; + } + events.push(["exit", heading, context]); + return events; + } + function tokenizeSetextUnderline(effects, ok, nok) { + const self2 = this; + let marker; + return start2; + function start2(code) { + let index2 = self2.events.length; + let paragraph; + while (index2--) { + if (self2.events[index2][1].type !== "lineEnding" && self2.events[index2][1].type !== "linePrefix" && self2.events[index2][1].type !== "content") { + paragraph = self2.events[index2][1].type === "paragraph"; + break; + } + } + if (!self2.parser.lazy[self2.now().line] && (self2.interrupt || paragraph)) { + effects.enter("setextHeadingLine"); + marker = code; + return before(code); + } + return nok(code); + } + function before(code) { + effects.enter("setextHeadingLineSequence"); + return inside(code); + } + function inside(code) { + if (code === marker) { + effects.consume(code); + return inside; + } + effects.exit("setextHeadingLineSequence"); + return markdownSpace(code) ? factorySpace(effects, after, "lineSuffix")(code) : after(code); + } + function after(code) { + if (code === null || markdownLineEnding(code)) { + effects.exit("setextHeadingLine"); + return ok(code); + } + return nok(code); + } + } + const flow$1 = { + tokenize: initializeFlow + }; + function initializeFlow(effects) { + const self2 = this; + const initial = effects.attempt( + // Try to parse a blank line. + blankLine, + atBlankEnding, + // Try to parse initial flow (essentially, only code). + effects.attempt( + this.parser.constructs.flowInitial, + afterConstruct, + factorySpace( + effects, + effects.attempt( + this.parser.constructs.flow, + afterConstruct, + effects.attempt(content, afterConstruct) + ), + "linePrefix" + ) + ) + ); + return initial; + function atBlankEnding(code) { + if (code === null) { + effects.consume(code); + return; + } + effects.enter("lineEndingBlank"); + effects.consume(code); + effects.exit("lineEndingBlank"); + self2.currentConstruct = void 0; + return initial; + } + function afterConstruct(code) { + if (code === null) { + effects.consume(code); + return; + } + effects.enter("lineEnding"); + effects.consume(code); + effects.exit("lineEnding"); + self2.currentConstruct = void 0; + return initial; + } + } + const resolver = { + resolveAll: createResolver() + }; + const string$1 = initializeFactory("string"); + const text$1 = initializeFactory("text"); + function initializeFactory(field) { + return { + tokenize: initializeText, + resolveAll: createResolver( + field === "text" ? resolveAllLineSuffixes : void 0 + ) + }; + function initializeText(effects) { + const self2 = this; + const constructs2 = this.parser.constructs[field]; + const text2 = effects.attempt(constructs2, start2, notText); + return start2; + function start2(code) { + return atBreak(code) ? text2(code) : notText(code); + } + function notText(code) { + if (code === null) { + effects.consume(code); + return; + } + effects.enter("data"); + effects.consume(code); + return data; + } + function data(code) { + if (atBreak(code)) { + effects.exit("data"); + return text2(code); + } + effects.consume(code); + return data; + } + function atBreak(code) { + if (code === null) { + return true; + } + const list2 = constructs2[code]; + let index2 = -1; + if (list2) { + while (++index2 < list2.length) { + const item = list2[index2]; + if (!item.previous || item.previous.call(self2, self2.previous)) { + return true; + } + } + } + return false; + } + } + } + function createResolver(extraResolver) { + return resolveAllText; + function resolveAllText(events, context) { + let index2 = -1; + let enter2; + while (++index2 <= events.length) { + if (enter2 === void 0) { + if (events[index2] && events[index2][1].type === "data") { + enter2 = index2; + index2++; + } + } else if (!events[index2] || events[index2][1].type !== "data") { + if (index2 !== enter2 + 2) { + events[enter2][1].end = events[index2 - 1][1].end; + events.splice(enter2 + 2, index2 - enter2 - 2); + index2 = enter2 + 2; + } + enter2 = void 0; + } + } + return extraResolver ? extraResolver(events, context) : events; + } + } + function resolveAllLineSuffixes(events, context) { + let eventIndex = 0; + while (++eventIndex <= events.length) { + if ((eventIndex === events.length || events[eventIndex][1].type === "lineEnding") && events[eventIndex - 1][1].type === "data") { + const data = events[eventIndex - 1][1]; + const chunks = context.sliceStream(data); + let index2 = chunks.length; + let bufferIndex = -1; + let size2 = 0; + let tabs; + while (index2--) { + const chunk = chunks[index2]; + if (typeof chunk === "string") { + bufferIndex = chunk.length; + while (chunk.charCodeAt(bufferIndex - 1) === 32) { + size2++; + bufferIndex--; + } + if (bufferIndex) + break; + bufferIndex = -1; + } else if (chunk === -2) { + tabs = true; + size2++; + } else if (chunk === -1) + ; + else { + index2++; + break; + } + } + if (size2) { + const token2 = { + type: eventIndex === events.length || tabs || size2 < 2 ? "lineSuffix" : "hardBreakTrailing", + start: { + line: data.end.line, + column: data.end.column - size2, + offset: data.end.offset - size2, + _index: data.start._index + index2, + _bufferIndex: index2 ? bufferIndex : data.start._bufferIndex + bufferIndex + }, + end: Object.assign({}, data.end) + }; + data.end = Object.assign({}, token2.start); + if (data.start.offset === data.end.offset) { + Object.assign(data, token2); + } else { + events.splice( + eventIndex, + 0, + ["enter", token2, context], + ["exit", token2, context] + ); + eventIndex += 2; + } + } + eventIndex++; + } + } + return events; + } + function createTokenizer(parser2, initialize2, from2) { + let point2 = Object.assign( + from2 ? Object.assign({}, from2) : { + line: 1, + column: 1, + offset: 0 + }, + { + _index: 0, + _bufferIndex: -1 + } + ); + const columnStart = {}; + const resolveAllConstructs = []; + let chunks = []; + let stack = []; + const effects = { + consume, + enter: enter2, + exit: exit2, + attempt: constructFactory(onsuccessfulconstruct), + check: constructFactory(onsuccessfulcheck), + interrupt: constructFactory(onsuccessfulcheck, { + interrupt: true + }) + }; + const context = { + previous: null, + code: null, + containerState: {}, + events: [], + parser: parser2, + sliceStream, + sliceSerialize, + now: now2, + defineSkip, + write: write2 + }; + let state2 = initialize2.tokenize.call(context, effects); + if (initialize2.resolveAll) { + resolveAllConstructs.push(initialize2); + } + return context; + function write2(slice2) { + chunks = push(chunks, slice2); + main2(); + if (chunks[chunks.length - 1] !== null) { + return []; + } + addResult(initialize2, 0); + context.events = resolveAll(resolveAllConstructs, context.events, context); + return context.events; + } + function sliceSerialize(token2, expandTabs) { + return serializeChunks(sliceStream(token2), expandTabs); + } + function sliceStream(token2) { + return sliceChunks(chunks, token2); + } + function now2() { + const { line: line2, column: column2, offset, _index, _bufferIndex } = point2; + return { + line: line2, + column: column2, + offset, + _index, + _bufferIndex + }; + } + function defineSkip(value2) { + columnStart[value2.line] = value2.column; + accountForPotentialSkip(); + } + function main2() { + let chunkIndex; + while (point2._index < chunks.length) { + const chunk = chunks[point2._index]; + if (typeof chunk === "string") { + chunkIndex = point2._index; + if (point2._bufferIndex < 0) { + point2._bufferIndex = 0; + } + while (point2._index === chunkIndex && point2._bufferIndex < chunk.length) { + go(chunk.charCodeAt(point2._bufferIndex)); + } + } else { + go(chunk); + } + } + } + function go(code) { + state2 = state2(code); + } + function consume(code) { + if (markdownLineEnding(code)) { + point2.line++; + point2.column = 1; + point2.offset += code === -3 ? 2 : 1; + accountForPotentialSkip(); + } else if (code !== -1) { + point2.column++; + point2.offset++; + } + if (point2._bufferIndex < 0) { + point2._index++; + } else { + point2._bufferIndex++; + if (point2._bufferIndex === chunks[point2._index].length) { + point2._bufferIndex = -1; + point2._index++; + } + } + context.previous = code; + } + function enter2(type2, fields) { + const token2 = fields || {}; + token2.type = type2; + token2.start = now2(); + context.events.push(["enter", token2, context]); + stack.push(token2); + return token2; + } + function exit2(type2) { + const token2 = stack.pop(); + token2.end = now2(); + context.events.push(["exit", token2, context]); + return token2; + } + function onsuccessfulconstruct(construct2, info2) { + addResult(construct2, info2.from); + } + function onsuccessfulcheck(_2, info2) { + info2.restore(); + } + function constructFactory(onreturn, fields) { + return hook; + function hook(constructs2, returnState, bogusState) { + let listOfConstructs; + let constructIndex; + let currentConstruct; + let info2; + return Array.isArray(constructs2) ? handleListOfConstructs(constructs2) : "tokenize" in constructs2 ? ( + // @ts-expect-error Looks like a construct. + handleListOfConstructs([constructs2]) + ) : handleMapOfConstructs(constructs2); + function handleMapOfConstructs(map2) { + return start2; + function start2(code) { + const def = code !== null && map2[code]; + const all2 = code !== null && map2.null; + const list2 = [ + // To do: add more extension tests. + /* c8 ignore next 2 */ + ...Array.isArray(def) ? def : def ? [def] : [], + ...Array.isArray(all2) ? all2 : all2 ? [all2] : [] + ]; + return handleListOfConstructs(list2)(code); + } + } + function handleListOfConstructs(list2) { + listOfConstructs = list2; + constructIndex = 0; + if (list2.length === 0) { + return bogusState; + } + return handleConstruct(list2[constructIndex]); + } + function handleConstruct(construct2) { + return start2; + function start2(code) { + info2 = store(); + currentConstruct = construct2; + if (!construct2.partial) { + context.currentConstruct = construct2; + } + if (construct2.name && context.parser.constructs.disable.null.includes(construct2.name)) { + return nok(); + } + return construct2.tokenize.call( + // If we do have fields, create an object w/ `context` as its + // prototype. + // This allows a “live binding”, which is needed for `interrupt`. + fields ? Object.assign(Object.create(context), fields) : context, + effects, + ok, + nok + )(code); + } + } + function ok(code) { + onreturn(currentConstruct, info2); + return returnState; + } + function nok(code) { + info2.restore(); + if (++constructIndex < listOfConstructs.length) { + return handleConstruct(listOfConstructs[constructIndex]); + } + return bogusState; + } + } + } + function addResult(construct2, from3) { + if (construct2.resolveAll && !resolveAllConstructs.includes(construct2)) { + resolveAllConstructs.push(construct2); + } + if (construct2.resolve) { + splice( + context.events, + from3, + context.events.length - from3, + construct2.resolve(context.events.slice(from3), context) + ); + } + if (construct2.resolveTo) { + context.events = construct2.resolveTo(context.events, context); + } + } + function store() { + const startPoint = now2(); + const startPrevious = context.previous; + const startCurrentConstruct = context.currentConstruct; + const startEventsIndex = context.events.length; + const startStack = Array.from(stack); + return { + restore, + from: startEventsIndex + }; + function restore() { + point2 = startPoint; + context.previous = startPrevious; + context.currentConstruct = startCurrentConstruct; + context.events.length = startEventsIndex; + stack = startStack; + accountForPotentialSkip(); + } + } + function accountForPotentialSkip() { + if (point2.line in columnStart && point2.column < 2) { + point2.column = columnStart[point2.line]; + point2.offset += columnStart[point2.line] - 1; + } + } + } + function sliceChunks(chunks, token2) { + const startIndex = token2.start._index; + const startBufferIndex = token2.start._bufferIndex; + const endIndex = token2.end._index; + const endBufferIndex = token2.end._bufferIndex; + let view; + if (startIndex === endIndex) { + view = [chunks[startIndex].slice(startBufferIndex, endBufferIndex)]; + } else { + view = chunks.slice(startIndex, endIndex); + if (startBufferIndex > -1) { + const head2 = view[0]; + if (typeof head2 === "string") { + view[0] = head2.slice(startBufferIndex); + } else { + view.shift(); + } + } + if (endBufferIndex > 0) { + view.push(chunks[endIndex].slice(0, endBufferIndex)); + } + } + return view; + } + function serializeChunks(chunks, expandTabs) { + let index2 = -1; + const result = []; + let atTab; + while (++index2 < chunks.length) { + const chunk = chunks[index2]; + let value2; + if (typeof chunk === "string") { + value2 = chunk; + } else + switch (chunk) { + case -5: { + value2 = "\r"; + break; + } + case -4: { + value2 = "\n"; + break; + } + case -3: { + value2 = "\r\n"; + break; + } + case -2: { + value2 = expandTabs ? " " : " "; + break; + } + case -1: { + if (!expandTabs && atTab) + continue; + value2 = " "; + break; + } + default: { + value2 = String.fromCharCode(chunk); + } + } + atTab = chunk === -2; + result.push(value2); + } + return result.join(""); + } + const document$1 = { + [42]: list, + [43]: list, + [45]: list, + [48]: list, + [49]: list, + [50]: list, + [51]: list, + [52]: list, + [53]: list, + [54]: list, + [55]: list, + [56]: list, + [57]: list, + [62]: blockQuote + }; + const contentInitial = { + [91]: definition + }; + const flowInitial = { + [-2]: codeIndented, + [-1]: codeIndented, + [32]: codeIndented + }; + const flow = { + [35]: headingAtx, + [42]: thematicBreak, + [45]: [setextUnderline, thematicBreak], + [60]: htmlFlow, + [61]: setextUnderline, + [95]: thematicBreak, + [96]: codeFenced, + [126]: codeFenced + }; + const string = { + [38]: characterReference, + [92]: characterEscape + }; + const text = { + [-5]: lineEnding, + [-4]: lineEnding, + [-3]: lineEnding, + [33]: labelStartImage, + [38]: characterReference, + [42]: attention, + [60]: [autolink, htmlText], + [91]: labelStartLink, + [92]: [hardBreakEscape, characterEscape], + [93]: labelEnd, + [95]: attention, + [96]: codeText + }; + const insideSpan = { + null: [attention, resolver] + }; + const attentionMarkers = { + null: [42, 95] + }; + const disable = { + null: [] + }; + const defaultConstructs = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + attentionMarkers, + contentInitial, + disable, + document: document$1, + flow, + flowInitial, + insideSpan, + string, + text + }, Symbol.toStringTag, { value: "Module" })); + function parse$1(options2) { + const settings = options2 || {}; + const constructs2 = ( + /** @type {FullNormalizedExtension} */ + combineExtensions([defaultConstructs, ...settings.extensions || []]) + ); + const parser2 = { + defined: [], + lazy: {}, + constructs: constructs2, + content: create2(content$1), + document: create2(document$2), + flow: create2(flow$1), + string: create2(string$1), + text: create2(text$1) + }; + return parser2; + function create2(initial) { + return creator2; + function creator2(from2) { + return createTokenizer(parser2, initial, from2); + } + } + } + const search = /[\0\t\n\r]/g; + function preprocess() { + let column2 = 1; + let buffer = ""; + let start2 = true; + let atCarriageReturn; + return preprocessor; + function preprocessor(value2, encoding, end2) { + const chunks = []; + let match; + let next2; + let startPosition; + let endPosition; + let code; + value2 = buffer + value2.toString(encoding); + startPosition = 0; + buffer = ""; + if (start2) { + if (value2.charCodeAt(0) === 65279) { + startPosition++; + } + start2 = void 0; + } + while (startPosition < value2.length) { + search.lastIndex = startPosition; + match = search.exec(value2); + endPosition = match && match.index !== void 0 ? match.index : value2.length; + code = value2.charCodeAt(endPosition); + if (!match) { + buffer = value2.slice(startPosition); + break; + } + if (code === 10 && startPosition === endPosition && atCarriageReturn) { + chunks.push(-3); + atCarriageReturn = void 0; + } else { + if (atCarriageReturn) { + chunks.push(-5); + atCarriageReturn = void 0; + } + if (startPosition < endPosition) { + chunks.push(value2.slice(startPosition, endPosition)); + column2 += endPosition - startPosition; + } + switch (code) { + case 0: { + chunks.push(65533); + column2++; + break; + } + case 9: { + next2 = Math.ceil(column2 / 4) * 4; + chunks.push(-2); + while (column2++ < next2) + chunks.push(-1); + break; + } + case 10: { + chunks.push(-4); + column2 = 1; + break; + } + default: { + atCarriageReturn = true; + column2 = 1; + } + } + } + startPosition = endPosition + 1; + } + if (end2) { + if (atCarriageReturn) + chunks.push(-5); + if (buffer) + chunks.push(buffer); + chunks.push(null); + } + return chunks; + } + } + function postprocess(events) { + while (!subtokenize(events)) { + } + return events; + } + function decodeNumericCharacterReference(value2, base) { + const code = Number.parseInt(value2, base); + if ( + // C0 except for HT, LF, FF, CR, space. + code < 9 || code === 11 || code > 13 && code < 32 || // Control character (DEL) of C0, and C1 controls. + code > 126 && code < 160 || // Lone high surrogates and low surrogates. + code > 55295 && code < 57344 || // Noncharacters. + code > 64975 && code < 65008 || (code & 65535) === 65535 || (code & 65535) === 65534 || // Out of range + code > 1114111 + ) { + return "�"; + } + return String.fromCharCode(code); + } + const characterEscapeOrReference = /\\([!-/:-@[-`{-~])|&(#(?:\d{1,7}|x[\da-f]{1,6})|[\da-z]{1,31});/gi; + function decodeString(value2) { + return value2.replace(characterEscapeOrReference, decode); + } + function decode($0, $1, $2) { + if ($1) { + return $1; + } + const head2 = $2.charCodeAt(0); + if (head2 === 35) { + const head3 = $2.charCodeAt(1); + const hex2 = head3 === 120 || head3 === 88; + return decodeNumericCharacterReference($2.slice(hex2 ? 2 : 1), hex2 ? 16 : 10); + } + return decodeNamedCharacterReference($2) || $0; + } + function stringifyPosition(value2) { + if (!value2 || typeof value2 !== "object") { + return ""; + } + if ("position" in value2 || "type" in value2) { + return position(value2.position); + } + if ("start" in value2 || "end" in value2) { + return position(value2); + } + if ("line" in value2 || "column" in value2) { + return point$1(value2); + } + return ""; + } + function point$1(point2) { + return index(point2 && point2.line) + ":" + index(point2 && point2.column); + } + function position(pos) { + return point$1(pos && pos.start) + "-" + point$1(pos && pos.end); + } + function index(value2) { + return value2 && typeof value2 === "number" ? value2 : 1; + } + const own = {}.hasOwnProperty; + const fromMarkdown = ( + /** + * @type {( + * ((value: Value, encoding: Encoding, options?: Options | null | undefined) => Root) & + * ((value: Value, options?: Options | null | undefined) => Root) + * )} + */ + /** + * @param {Value} value + * @param {Encoding | Options | null | undefined} [encoding] + * @param {Options | null | undefined} [options] + * @returns {Root} + */ + function(value2, encoding, options2) { + if (typeof encoding !== "string") { + options2 = encoding; + encoding = void 0; + } + return compiler(options2)( + postprocess( + parse$1(options2).document().write(preprocess()(value2, encoding, true)) + ) + ); + } + ); + function compiler(options2) { + const config2 = { + transforms: [], + canContainEols: ["emphasis", "fragment", "heading", "paragraph", "strong"], + enter: { + autolink: opener(link2), + autolinkProtocol: onenterdata, + autolinkEmail: onenterdata, + atxHeading: opener(heading), + blockQuote: opener(blockQuote2), + characterEscape: onenterdata, + characterReference: onenterdata, + codeFenced: opener(codeFlow), + codeFencedFenceInfo: buffer, + codeFencedFenceMeta: buffer, + codeIndented: opener(codeFlow, buffer), + codeText: opener(codeText2, buffer), + codeTextData: onenterdata, + data: onenterdata, + codeFlowValue: onenterdata, + definition: opener(definition2), + definitionDestinationString: buffer, + definitionLabelString: buffer, + definitionTitleString: buffer, + emphasis: opener(emphasis), + hardBreakEscape: opener(hardBreak), + hardBreakTrailing: opener(hardBreak), + htmlFlow: opener(html2, buffer), + htmlFlowData: onenterdata, + htmlText: opener(html2, buffer), + htmlTextData: onenterdata, + image: opener(image), + label: buffer, + link: opener(link2), + listItem: opener(listItem), + listItemValue: onenterlistitemvalue, + listOrdered: opener(list2, onenterlistordered), + listUnordered: opener(list2), + paragraph: opener(paragraph), + reference: onenterreference, + referenceString: buffer, + resourceDestinationString: buffer, + resourceTitleString: buffer, + setextHeading: opener(heading), + strong: opener(strong), + thematicBreak: opener(thematicBreak2) + }, + exit: { + atxHeading: closer(), + atxHeadingSequence: onexitatxheadingsequence, + autolink: closer(), + autolinkEmail: onexitautolinkemail, + autolinkProtocol: onexitautolinkprotocol, + blockQuote: closer(), + characterEscapeValue: onexitdata, + characterReferenceMarkerHexadecimal: onexitcharacterreferencemarker, + characterReferenceMarkerNumeric: onexitcharacterreferencemarker, + characterReferenceValue: onexitcharacterreferencevalue, + codeFenced: closer(onexitcodefenced), + codeFencedFence: onexitcodefencedfence, + codeFencedFenceInfo: onexitcodefencedfenceinfo, + codeFencedFenceMeta: onexitcodefencedfencemeta, + codeFlowValue: onexitdata, + codeIndented: closer(onexitcodeindented), + codeText: closer(onexitcodetext), + codeTextData: onexitdata, + data: onexitdata, + definition: closer(), + definitionDestinationString: onexitdefinitiondestinationstring, + definitionLabelString: onexitdefinitionlabelstring, + definitionTitleString: onexitdefinitiontitlestring, + emphasis: closer(), + hardBreakEscape: closer(onexithardbreak), + hardBreakTrailing: closer(onexithardbreak), + htmlFlow: closer(onexithtmlflow), + htmlFlowData: onexitdata, + htmlText: closer(onexithtmltext), + htmlTextData: onexitdata, + image: closer(onexitimage), + label: onexitlabel, + labelText: onexitlabeltext, + lineEnding: onexitlineending, + link: closer(onexitlink), + listItem: closer(), + listOrdered: closer(), + listUnordered: closer(), + paragraph: closer(), + referenceString: onexitreferencestring, + resourceDestinationString: onexitresourcedestinationstring, + resourceTitleString: onexitresourcetitlestring, + resource: onexitresource, + setextHeading: closer(onexitsetextheading), + setextHeadingLineSequence: onexitsetextheadinglinesequence, + setextHeadingText: onexitsetextheadingtext, + strong: closer(), + thematicBreak: closer() + } + }; + configure(config2, (options2 || {}).mdastExtensions || []); + const data = {}; + return compile2; + function compile2(events) { + let tree = { + type: "root", + children: [] + }; + const context = { + stack: [tree], + tokenStack: [], + config: config2, + enter: enter2, + exit: exit2, + buffer, + resume, + setData, + getData + }; + const listStack = []; + let index2 = -1; + while (++index2 < events.length) { + if (events[index2][1].type === "listOrdered" || events[index2][1].type === "listUnordered") { + if (events[index2][0] === "enter") { + listStack.push(index2); + } else { + const tail = listStack.pop(); + index2 = prepareList(events, tail, index2); + } + } + } + index2 = -1; + while (++index2 < events.length) { + const handler = config2[events[index2][0]]; + if (own.call(handler, events[index2][1].type)) { + handler[events[index2][1].type].call( + Object.assign( + { + sliceSerialize: events[index2][2].sliceSerialize + }, + context + ), + events[index2][1] + ); + } + } + if (context.tokenStack.length > 0) { + const tail = context.tokenStack[context.tokenStack.length - 1]; + const handler = tail[1] || defaultOnError; + handler.call(context, void 0, tail[0]); + } + tree.position = { + start: point( + events.length > 0 ? events[0][1].start : { + line: 1, + column: 1, + offset: 0 + } + ), + end: point( + events.length > 0 ? events[events.length - 2][1].end : { + line: 1, + column: 1, + offset: 0 + } + ) + }; + index2 = -1; + while (++index2 < config2.transforms.length) { + tree = config2.transforms[index2](tree) || tree; + } + return tree; + } + function prepareList(events, start2, length2) { + let index2 = start2 - 1; + let containerBalance = -1; + let listSpread = false; + let listItem2; + let lineIndex; + let firstBlankLineIndex; + let atMarker; + while (++index2 <= length2) { + const event = events[index2]; + if (event[1].type === "listUnordered" || event[1].type === "listOrdered" || event[1].type === "blockQuote") { + if (event[0] === "enter") { + containerBalance++; + } else { + containerBalance--; + } + atMarker = void 0; + } else if (event[1].type === "lineEndingBlank") { + if (event[0] === "enter") { + if (listItem2 && !atMarker && !containerBalance && !firstBlankLineIndex) { + firstBlankLineIndex = index2; + } + atMarker = void 0; + } + } else if (event[1].type === "linePrefix" || event[1].type === "listItemValue" || event[1].type === "listItemMarker" || event[1].type === "listItemPrefix" || event[1].type === "listItemPrefixWhitespace") + ; + else { + atMarker = void 0; + } + if (!containerBalance && event[0] === "enter" && event[1].type === "listItemPrefix" || containerBalance === -1 && event[0] === "exit" && (event[1].type === "listUnordered" || event[1].type === "listOrdered")) { + if (listItem2) { + let tailIndex = index2; + lineIndex = void 0; + while (tailIndex--) { + const tailEvent = events[tailIndex]; + if (tailEvent[1].type === "lineEnding" || tailEvent[1].type === "lineEndingBlank") { + if (tailEvent[0] === "exit") + continue; + if (lineIndex) { + events[lineIndex][1].type = "lineEndingBlank"; + listSpread = true; + } + tailEvent[1].type = "lineEnding"; + lineIndex = tailIndex; + } else if (tailEvent[1].type === "linePrefix" || tailEvent[1].type === "blockQuotePrefix" || tailEvent[1].type === "blockQuotePrefixWhitespace" || tailEvent[1].type === "blockQuoteMarker" || tailEvent[1].type === "listItemIndent") + ; + else { + break; + } + } + if (firstBlankLineIndex && (!lineIndex || firstBlankLineIndex < lineIndex)) { + listItem2._spread = true; + } + listItem2.end = Object.assign( + {}, + lineIndex ? events[lineIndex][1].start : event[1].end + ); + events.splice(lineIndex || index2, 0, ["exit", listItem2, event[2]]); + index2++; + length2++; + } + if (event[1].type === "listItemPrefix") { + listItem2 = { + type: "listItem", + _spread: false, + start: Object.assign({}, event[1].start), + // @ts-expect-error: we’ll add `end` in a second. + end: void 0 + }; + events.splice(index2, 0, ["enter", listItem2, event[2]]); + index2++; + length2++; + firstBlankLineIndex = void 0; + atMarker = true; + } + } + } + events[start2][1]._spread = listSpread; + return length2; + } + function setData(key, value2) { + data[key] = value2; + } + function getData(key) { + return data[key]; + } + function opener(create2, and) { + return open2; + function open2(token2) { + enter2.call(this, create2(token2), token2); + if (and) + and.call(this, token2); + } + } + function buffer() { + this.stack.push({ + type: "fragment", + children: [] + }); + } + function enter2(node2, token2, errorHandler) { + const parent = this.stack[this.stack.length - 1]; + parent.children.push(node2); + this.stack.push(node2); + this.tokenStack.push([token2, errorHandler]); + node2.position = { + start: point(token2.start) + }; + return node2; + } + function closer(and) { + return close2; + function close2(token2) { + if (and) + and.call(this, token2); + exit2.call(this, token2); + } + } + function exit2(token2, onExitError) { + const node2 = this.stack.pop(); + const open2 = this.tokenStack.pop(); + if (!open2) { + throw new Error( + "Cannot close `" + token2.type + "` (" + stringifyPosition({ + start: token2.start, + end: token2.end + }) + "): it’s not open" + ); + } else if (open2[0].type !== token2.type) { + if (onExitError) { + onExitError.call(this, token2, open2[0]); + } else { + const handler = open2[1] || defaultOnError; + handler.call(this, token2, open2[0]); + } + } + node2.position.end = point(token2.end); + return node2; + } + function resume() { + return toString(this.stack.pop()); + } + function onenterlistordered() { + setData("expectingFirstListItemValue", true); + } + function onenterlistitemvalue(token2) { + if (getData("expectingFirstListItemValue")) { + const ancestor = this.stack[this.stack.length - 2]; + ancestor.start = Number.parseInt(this.sliceSerialize(token2), 10); + setData("expectingFirstListItemValue"); + } + } + function onexitcodefencedfenceinfo() { + const data2 = this.resume(); + const node2 = this.stack[this.stack.length - 1]; + node2.lang = data2; + } + function onexitcodefencedfencemeta() { + const data2 = this.resume(); + const node2 = this.stack[this.stack.length - 1]; + node2.meta = data2; + } + function onexitcodefencedfence() { + if (getData("flowCodeInside")) + return; + this.buffer(); + setData("flowCodeInside", true); + } + function onexitcodefenced() { + const data2 = this.resume(); + const node2 = this.stack[this.stack.length - 1]; + node2.value = data2.replace(/^(\r?\n|\r)|(\r?\n|\r)$/g, ""); + setData("flowCodeInside"); + } + function onexitcodeindented() { + const data2 = this.resume(); + const node2 = this.stack[this.stack.length - 1]; + node2.value = data2.replace(/(\r?\n|\r)$/g, ""); + } + function onexitdefinitionlabelstring(token2) { + const label = this.resume(); + const node2 = this.stack[this.stack.length - 1]; + node2.label = label; + node2.identifier = normalizeIdentifier( + this.sliceSerialize(token2) + ).toLowerCase(); + } + function onexitdefinitiontitlestring() { + const data2 = this.resume(); + const node2 = this.stack[this.stack.length - 1]; + node2.title = data2; + } + function onexitdefinitiondestinationstring() { + const data2 = this.resume(); + const node2 = this.stack[this.stack.length - 1]; + node2.url = data2; + } + function onexitatxheadingsequence(token2) { + const node2 = this.stack[this.stack.length - 1]; + if (!node2.depth) { + const depth = this.sliceSerialize(token2).length; + node2.depth = depth; + } + } + function onexitsetextheadingtext() { + setData("setextHeadingSlurpLineEnding", true); + } + function onexitsetextheadinglinesequence(token2) { + const node2 = this.stack[this.stack.length - 1]; + node2.depth = this.sliceSerialize(token2).charCodeAt(0) === 61 ? 1 : 2; + } + function onexitsetextheading() { + setData("setextHeadingSlurpLineEnding"); + } + function onenterdata(token2) { + const node2 = this.stack[this.stack.length - 1]; + let tail = node2.children[node2.children.length - 1]; + if (!tail || tail.type !== "text") { + tail = text2(); + tail.position = { + start: point(token2.start) + }; + node2.children.push(tail); + } + this.stack.push(tail); + } + function onexitdata(token2) { + const tail = this.stack.pop(); + tail.value += this.sliceSerialize(token2); + tail.position.end = point(token2.end); + } + function onexitlineending(token2) { + const context = this.stack[this.stack.length - 1]; + if (getData("atHardBreak")) { + const tail = context.children[context.children.length - 1]; + tail.position.end = point(token2.end); + setData("atHardBreak"); + return; + } + if (!getData("setextHeadingSlurpLineEnding") && config2.canContainEols.includes(context.type)) { + onenterdata.call(this, token2); + onexitdata.call(this, token2); + } + } + function onexithardbreak() { + setData("atHardBreak", true); + } + function onexithtmlflow() { + const data2 = this.resume(); + const node2 = this.stack[this.stack.length - 1]; + node2.value = data2; + } + function onexithtmltext() { + const data2 = this.resume(); + const node2 = this.stack[this.stack.length - 1]; + node2.value = data2; + } + function onexitcodetext() { + const data2 = this.resume(); + const node2 = this.stack[this.stack.length - 1]; + node2.value = data2; + } + function onexitlink() { + const node2 = this.stack[this.stack.length - 1]; + if (getData("inReference")) { + const referenceType = getData("referenceType") || "shortcut"; + node2.type += "Reference"; + node2.referenceType = referenceType; + delete node2.url; + delete node2.title; + } else { + delete node2.identifier; + delete node2.label; + } + setData("referenceType"); + } + function onexitimage() { + const node2 = this.stack[this.stack.length - 1]; + if (getData("inReference")) { + const referenceType = getData("referenceType") || "shortcut"; + node2.type += "Reference"; + node2.referenceType = referenceType; + delete node2.url; + delete node2.title; + } else { + delete node2.identifier; + delete node2.label; + } + setData("referenceType"); + } + function onexitlabeltext(token2) { + const string2 = this.sliceSerialize(token2); + const ancestor = this.stack[this.stack.length - 2]; + ancestor.label = decodeString(string2); + ancestor.identifier = normalizeIdentifier(string2).toLowerCase(); + } + function onexitlabel() { + const fragment = this.stack[this.stack.length - 1]; + const value2 = this.resume(); + const node2 = this.stack[this.stack.length - 1]; + setData("inReference", true); + if (node2.type === "link") { + const children2 = fragment.children; + node2.children = children2; + } else { + node2.alt = value2; + } + } + function onexitresourcedestinationstring() { + const data2 = this.resume(); + const node2 = this.stack[this.stack.length - 1]; + node2.url = data2; + } + function onexitresourcetitlestring() { + const data2 = this.resume(); + const node2 = this.stack[this.stack.length - 1]; + node2.title = data2; + } + function onexitresource() { + setData("inReference"); + } + function onenterreference() { + setData("referenceType", "collapsed"); + } + function onexitreferencestring(token2) { + const label = this.resume(); + const node2 = this.stack[this.stack.length - 1]; + node2.label = label; + node2.identifier = normalizeIdentifier( + this.sliceSerialize(token2) + ).toLowerCase(); + setData("referenceType", "full"); + } + function onexitcharacterreferencemarker(token2) { + setData("characterReferenceType", token2.type); + } + function onexitcharacterreferencevalue(token2) { + const data2 = this.sliceSerialize(token2); + const type2 = getData("characterReferenceType"); + let value2; + if (type2) { + value2 = decodeNumericCharacterReference( + data2, + type2 === "characterReferenceMarkerNumeric" ? 10 : 16 + ); + setData("characterReferenceType"); + } else { + const result = decodeNamedCharacterReference(data2); + value2 = result; + } + const tail = this.stack.pop(); + tail.value += value2; + tail.position.end = point(token2.end); + } + function onexitautolinkprotocol(token2) { + onexitdata.call(this, token2); + const node2 = this.stack[this.stack.length - 1]; + node2.url = this.sliceSerialize(token2); + } + function onexitautolinkemail(token2) { + onexitdata.call(this, token2); + const node2 = this.stack[this.stack.length - 1]; + node2.url = "mailto:" + this.sliceSerialize(token2); + } + function blockQuote2() { + return { + type: "blockquote", + children: [] + }; + } + function codeFlow() { + return { + type: "code", + lang: null, + meta: null, + value: "" + }; + } + function codeText2() { + return { + type: "inlineCode", + value: "" + }; + } + function definition2() { + return { + type: "definition", + identifier: "", + label: null, + title: null, + url: "" + }; + } + function emphasis() { + return { + type: "emphasis", + children: [] + }; + } + function heading() { + return { + type: "heading", + depth: void 0, + children: [] + }; + } + function hardBreak() { + return { + type: "break" + }; + } + function html2() { + return { + type: "html", + value: "" + }; + } + function image() { + return { + type: "image", + title: null, + url: "", + alt: null + }; + } + function link2() { + return { + type: "link", + title: null, + url: "", + children: [] + }; + } + function list2(token2) { + return { + type: "list", + ordered: token2.type === "listOrdered", + start: null, + spread: token2._spread, + children: [] + }; + } + function listItem(token2) { + return { + type: "listItem", + spread: token2._spread, + checked: null, + children: [] + }; + } + function paragraph() { + return { + type: "paragraph", + children: [] + }; + } + function strong() { + return { + type: "strong", + children: [] + }; + } + function text2() { + return { + type: "text", + value: "" + }; + } + function thematicBreak2() { + return { + type: "thematicBreak" + }; + } + } + function point(d) { + return { + line: d.line, + column: d.column, + offset: d.offset + }; + } + function configure(combined, extensions) { + let index2 = -1; + while (++index2 < extensions.length) { + const value2 = extensions[index2]; + if (Array.isArray(value2)) { + configure(combined, value2); + } else { + extension(combined, value2); + } + } + } + function extension(combined, extension2) { + let key; + for (key in extension2) { + if (own.call(extension2, key)) { + if (key === "canContainEols") { + const right2 = extension2[key]; + if (right2) { + combined[key].push(...right2); + } + } else if (key === "transforms") { + const right2 = extension2[key]; + if (right2) { + combined[key].push(...right2); + } + } else if (key === "enter" || key === "exit") { + const right2 = extension2[key]; + if (right2) { + Object.assign(combined[key], right2); + } + } + } + } + } + function defaultOnError(left2, right2) { + if (left2) { + throw new Error( + "Cannot close `" + left2.type + "` (" + stringifyPosition({ + start: left2.start, + end: left2.end + }) + "): a different token (`" + right2.type + "`, " + stringifyPosition({ + start: right2.start, + end: right2.end + }) + ") is open" + ); + } else { + throw new Error( + "Cannot close document, a token (`" + right2.type + "`, " + stringifyPosition({ + start: right2.start, + end: right2.end + }) + ") is still open" + ); + } + } + function preprocessMarkdown(markdown) { + const withoutMultipleNewlines = markdown.replace(/\n{2,}/g, "\n"); + const withoutExtraSpaces = dedent(withoutMultipleNewlines); + return withoutExtraSpaces; + } + function markdownToLines(markdown) { + const preprocessedMarkdown = preprocessMarkdown(markdown); + const { children: children2 } = fromMarkdown(preprocessedMarkdown); + const lines = [[]]; + let currentLine = 0; + function processNode(node2, parentType = "normal") { + if (node2.type === "text") { + const textLines = node2.value.split("\n"); + textLines.forEach((textLine, index2) => { + if (index2 !== 0) { + currentLine++; + lines.push([]); + } + textLine.split(" ").forEach((word) => { + if (word) { + lines[currentLine].push({ content: word, type: parentType }); + } + }); + }); + } else if (node2.type === "strong" || node2.type === "emphasis") { + node2.children.forEach((contentNode) => { + processNode(contentNode, node2.type); + }); + } + } + children2.forEach((treeNode) => { + if (treeNode.type === "paragraph") { + treeNode.children.forEach((contentNode) => { + processNode(contentNode); + }); + } + }); + return lines; + } + function markdownToHTML(markdown) { + const { children: children2 } = fromMarkdown(markdown); + function output(node2) { + if (node2.type === "text") { + return node2.value.replace(/\n/g, "
    "); + } else if (node2.type === "strong") { + return `${node2.children.map(output).join("")}`; + } else if (node2.type === "emphasis") { + return `${node2.children.map(output).join("")}`; + } else if (node2.type === "paragraph") { + return `

    ${node2.children.map(output).join("")}

    `; + } + return `Unsupported markdown: ${node2.type}`; + } + return children2.map(output).join(""); + } + function splitTextToChars(text2) { + if (Intl.Segmenter) { + return [...new Intl.Segmenter().segment(text2)].map((s) => s.segment); + } + return [...text2]; + } + function splitWordToFitWidth(checkFit, word) { + const characters2 = splitTextToChars(word.content); + return splitWordToFitWidthRecursion(checkFit, [], characters2, word.type); + } + function splitWordToFitWidthRecursion(checkFit, usedChars, remainingChars, type2) { + if (remainingChars.length === 0) { + return [ + { content: usedChars.join(""), type: type2 }, + { content: "", type: type2 } + ]; + } + const [nextChar, ...rest] = remainingChars; + const newWord = [...usedChars, nextChar]; + if (checkFit([{ content: newWord.join(""), type: type2 }])) { + return splitWordToFitWidthRecursion(checkFit, newWord, rest, type2); + } + if (usedChars.length === 0 && nextChar) { + usedChars.push(nextChar); + remainingChars.shift(); + } + return [ + { content: usedChars.join(""), type: type2 }, + { content: remainingChars.join(""), type: type2 } + ]; + } + function splitLineToFitWidth(line2, checkFit) { + if (line2.some(({ content: content2 }) => content2.includes("\n"))) { + throw new Error("splitLineToFitWidth does not support newlines in the line"); + } + return splitLineToFitWidthRecursion(line2, checkFit); + } + function splitLineToFitWidthRecursion(words, checkFit, lines = [], newLine = []) { + if (words.length === 0) { + if (newLine.length > 0) { + lines.push(newLine); + } + return lines.length > 0 ? lines : []; + } + let joiner = ""; + if (words[0].content === " ") { + joiner = " "; + words.shift(); + } + const nextWord = words.shift() ?? { content: " ", type: "normal" }; + const lineWithNextWord = [...newLine]; + if (joiner !== "") { + lineWithNextWord.push({ content: joiner, type: "normal" }); + } + lineWithNextWord.push(nextWord); + if (checkFit(lineWithNextWord)) { + return splitLineToFitWidthRecursion(words, checkFit, lines, lineWithNextWord); + } + if (newLine.length > 0) { + lines.push(newLine); + words.unshift(nextWord); + } else if (nextWord.content) { + const [line2, rest] = splitWordToFitWidth(checkFit, nextWord); + lines.push([line2]); + if (rest.content) { + words.unshift(rest); + } + } + return splitLineToFitWidthRecursion(words, checkFit, lines); + } + function applyStyle(dom, styleFn) { + if (styleFn) { + dom.attr("style", styleFn); + } + } + function addHtmlSpan(element2, node2, width2, classes2, addBackground = false) { + const fo = element2.append("foreignObject"); + const div = fo.append("xhtml:div"); + const label = node2.label; + const labelClass = node2.isNode ? "nodeLabel" : "edgeLabel"; + div.html( + ` + " + label + "" + ); + applyStyle(div, node2.labelStyle); + div.style("display", "table-cell"); + div.style("white-space", "nowrap"); + div.style("max-width", width2 + "px"); + div.attr("xmlns", "http://www.w3.org/1999/xhtml"); + if (addBackground) { + div.attr("class", "labelBkg"); + } + let bbox = div.node().getBoundingClientRect(); + if (bbox.width === width2) { + div.style("display", "table"); + div.style("white-space", "break-spaces"); + div.style("width", width2 + "px"); + bbox = div.node().getBoundingClientRect(); + } + fo.style("width", bbox.width); + fo.style("height", bbox.height); + return fo.node(); + } + function createTspan(textElement, lineIndex, lineHeight) { + return textElement.append("tspan").attr("class", "text-outer-tspan").attr("x", 0).attr("y", lineIndex * lineHeight - 0.1 + "em").attr("dy", lineHeight + "em"); + } + function computeWidthOfText(parentNode, lineHeight, line2) { + const testElement = parentNode.append("text"); + const testSpan = createTspan(testElement, 1, lineHeight); + updateTextContentAndStyles(testSpan, line2); + const textLength = testSpan.node().getComputedTextLength(); + testElement.remove(); + return textLength; + } + function computeDimensionOfText(parentNode, lineHeight, text2) { + var _a2; + const testElement = parentNode.append("text"); + const testSpan = createTspan(testElement, 1, lineHeight); + updateTextContentAndStyles(testSpan, [{ content: text2, type: "normal" }]); + const textDimension = (_a2 = testSpan.node()) == null ? void 0 : _a2.getBoundingClientRect(); + if (textDimension) { + testElement.remove(); + } + return textDimension; + } + function createFormattedText(width2, g, structuredText, addBackground = false) { + const lineHeight = 1.1; + const labelGroup = g.append("g"); + const bkg = labelGroup.insert("rect").attr("class", "background"); + const textElement = labelGroup.append("text").attr("y", "-10.1"); + let lineIndex = 0; + for (const line2 of structuredText) { + const checkWidth = (line22) => computeWidthOfText(labelGroup, lineHeight, line22) <= width2; + const linesUnderWidth = checkWidth(line2) ? [line2] : splitLineToFitWidth(line2, checkWidth); + for (const preparedLine of linesUnderWidth) { + const tspan = createTspan(textElement, lineIndex, lineHeight); + updateTextContentAndStyles(tspan, preparedLine); + lineIndex++; + } + } + if (addBackground) { + const bbox = textElement.node().getBBox(); + const padding2 = 2; + bkg.attr("x", -padding2).attr("y", -padding2).attr("width", bbox.width + 2 * padding2).attr("height", bbox.height + 2 * padding2); + return labelGroup.node(); + } else { + return textElement.node(); + } + } + function updateTextContentAndStyles(tspan, wrappedLine) { + tspan.text(""); + wrappedLine.forEach((word, index2) => { + const innerTspan = tspan.append("tspan").attr("font-style", word.type === "emphasis" ? "italic" : "normal").attr("class", "text-inner-tspan").attr("font-weight", word.type === "strong" ? "bold" : "normal"); + if (index2 === 0) { + innerTspan.text(word.content); + } else { + innerTspan.text(" " + word.content); + } + }); + } + const createText = (el, text2 = "", { + style = "", + isTitle = false, + classes: classes2 = "", + useHtmlLabels = true, + isNode = true, + width: width2 = 200, + addSvgBackground = false + } = {}) => { + log$1.info("createText", text2, style, isTitle, classes2, useHtmlLabels, isNode, addSvgBackground); + if (useHtmlLabels) { + const htmlText2 = markdownToHTML(text2); + const node2 = { + isNode, + label: decodeEntities(htmlText2).replace( + /fa[blrs]?:fa-[\w-]+/g, + // cspell: disable-line + (s) => `` + ), + labelStyle: style.replace("fill:", "color:") + }; + const vertexNode = addHtmlSpan(el, node2, width2, classes2, addSvgBackground); + return vertexNode; + } else { + const structuredText = markdownToLines(text2); + const svgLabel = createFormattedText(width2, el, structuredText, addSvgBackground); + return svgLabel; + } + }; + const labelHelper = async (parent, node2, _classes, isNode) => { + let classes2; + const useHtmlLabels = node2.useHtmlLabels || evaluate(getConfig$1().flowchart.htmlLabels); + if (!_classes) { + classes2 = "node default"; + } else { + classes2 = _classes; + } + const shapeSvg = parent.insert("g").attr("class", classes2).attr("id", node2.domId || node2.id); + const label = shapeSvg.insert("g").attr("class", "label").attr("style", node2.labelStyle); + let labelText; + if (node2.labelText === void 0) { + labelText = ""; + } else { + labelText = typeof node2.labelText === "string" ? node2.labelText : node2.labelText[0]; + } + const textNode = label.node(); + let text2; + if (node2.labelType === "markdown") { + text2 = createText(label, sanitizeText$6(decodeEntities(labelText), getConfig$1()), { + useHtmlLabels, + width: node2.width || getConfig$1().flowchart.wrappingWidth, + classes: "markdown-node-label" + }); + } else { + text2 = textNode.appendChild( + createLabel$1( + sanitizeText$6(decodeEntities(labelText), getConfig$1()), + node2.labelStyle, + false, + isNode + ) + ); + } + let bbox = text2.getBBox(); + const halfPadding = node2.padding / 2; + if (evaluate(getConfig$1().flowchart.htmlLabels)) { + const div = text2.children[0]; + const dv = d3select(text2); + const images = div.getElementsByTagName("img"); + if (images) { + const noImgText = labelText.replace(/]*>/g, "").trim() === ""; + await Promise.all( + [...images].map( + (img) => new Promise((res) => { + function setupImage() { + img.style.display = "flex"; + img.style.flexDirection = "column"; + if (noImgText) { + const bodyFontSize = getConfig$1().fontSize ? getConfig$1().fontSize : window.getComputedStyle(document.body).fontSize; + const enlargingFactor = 5; + const width2 = parseInt(bodyFontSize, 10) * enlargingFactor + "px"; + img.style.minWidth = width2; + img.style.maxWidth = width2; + } else { + img.style.width = "100%"; + } + res(img); + } + setTimeout(() => { + if (img.complete) { + setupImage(); + } + }); + img.addEventListener("error", setupImage); + img.addEventListener("load", setupImage); + }) + ) + ); + } + bbox = div.getBoundingClientRect(); + dv.attr("width", bbox.width); + dv.attr("height", bbox.height); + } + if (useHtmlLabels) { + label.attr("transform", "translate(" + -bbox.width / 2 + ", " + -bbox.height / 2 + ")"); + } else { + label.attr("transform", "translate(0, " + -bbox.height / 2 + ")"); + } + if (node2.centerLabel) { + label.attr("transform", "translate(" + -bbox.width / 2 + ", " + -bbox.height / 2 + ")"); + } + label.insert("rect", ":first-child"); + return { shapeSvg, bbox, halfPadding, label }; + }; + const updateNodeBounds = (node2, element2) => { + const bbox = element2.node().getBBox(); + node2.width = bbox.width; + node2.height = bbox.height; + }; + function insertPolygonShape$1(parent, w2, h, points) { + return parent.insert("polygon", ":first-child").attr( + "points", + points.map(function(d) { + return d.x + "," + d.y; + }).join(" ") + ).attr("class", "label-container").attr("transform", "translate(" + -w2 / 2 + "," + h / 2 + ")"); + } + let clusterDb = {}; + let descendants = {}; + let parents = {}; + const clear$k = () => { + descendants = {}; + parents = {}; + clusterDb = {}; + }; + const isDescendant = (id2, ancestorId) => { + log$1.trace("In isDescendant", ancestorId, " ", id2, " = ", descendants[ancestorId].includes(id2)); + if (descendants[ancestorId].includes(id2)) { + return true; + } + return false; + }; + const edgeInCluster = (edge, clusterId) => { + log$1.info("Descendants of ", clusterId, " is ", descendants[clusterId]); + log$1.info("Edge is ", edge); + if (edge.v === clusterId) { + return false; + } + if (edge.w === clusterId) { + return false; + } + if (!descendants[clusterId]) { + log$1.debug("Tilt, ", clusterId, ",not in descendants"); + return false; + } + return descendants[clusterId].includes(edge.v) || isDescendant(edge.v, clusterId) || isDescendant(edge.w, clusterId) || descendants[clusterId].includes(edge.w); + }; + const copy = (clusterId, graph, newGraph, rootId) => { + log$1.warn( + "Copying children of ", + clusterId, + "root", + rootId, + "data", + graph.node(clusterId), + rootId + ); + const nodes2 = graph.children(clusterId) || []; + if (clusterId !== rootId) { + nodes2.push(clusterId); + } + log$1.warn("Copying (nodes) clusterId", clusterId, "nodes", nodes2); + nodes2.forEach((node2) => { + if (graph.children(node2).length > 0) { + copy(node2, graph, newGraph, rootId); + } else { + const data = graph.node(node2); + log$1.info("cp ", node2, " to ", rootId, " with parent ", clusterId); + newGraph.setNode(node2, data); + if (rootId !== graph.parent(node2)) { + log$1.warn("Setting parent", node2, graph.parent(node2)); + newGraph.setParent(node2, graph.parent(node2)); + } + if (clusterId !== rootId && node2 !== clusterId) { + log$1.debug("Setting parent", node2, clusterId); + newGraph.setParent(node2, clusterId); + } else { + log$1.info("In copy ", clusterId, "root", rootId, "data", graph.node(clusterId), rootId); + log$1.debug( + "Not Setting parent for node=", + node2, + "cluster!==rootId", + clusterId !== rootId, + "node!==clusterId", + node2 !== clusterId + ); + } + const edges2 = graph.edges(node2); + log$1.debug("Copying Edges", edges2); + edges2.forEach((edge) => { + log$1.info("Edge", edge); + const data2 = graph.edge(edge.v, edge.w, edge.name); + log$1.info("Edge data", data2, rootId); + try { + if (edgeInCluster(edge, rootId)) { + log$1.info("Copying as ", edge.v, edge.w, data2, edge.name); + newGraph.setEdge(edge.v, edge.w, data2, edge.name); + log$1.info("newGraph edges ", newGraph.edges(), newGraph.edge(newGraph.edges()[0])); + } else { + log$1.info( + "Skipping copy of edge ", + edge.v, + "-->", + edge.w, + " rootId: ", + rootId, + " clusterId:", + clusterId + ); + } + } catch (e) { + log$1.error(e); + } + }); + } + log$1.debug("Removing node", node2); + graph.removeNode(node2); + }); + }; + const extractDescendants = (id2, graph) => { + const children2 = graph.children(id2); + let res = [...children2]; + for (const child of children2) { + parents[child] = id2; + res = [...res, ...extractDescendants(child, graph)]; + } + return res; + }; + const findNonClusterChild = (id2, graph) => { + log$1.trace("Searching", id2); + const children2 = graph.children(id2); + log$1.trace("Searching children of id ", id2, children2); + if (children2.length < 1) { + log$1.trace("This is a valid node", id2); + return id2; + } + for (const child of children2) { + const _id = findNonClusterChild(child, graph); + if (_id) { + log$1.trace("Found replacement for", id2, " => ", _id); + return _id; + } + } + }; + const getAnchorId = (id2) => { + if (!clusterDb[id2]) { + return id2; + } + if (!clusterDb[id2].externalConnections) { + return id2; + } + if (clusterDb[id2]) { + return clusterDb[id2].id; + } + return id2; + }; + const adjustClustersAndEdges = (graph, depth) => { + if (!graph || depth > 10) { + log$1.debug("Opting out, no graph "); + return; + } else { + log$1.debug("Opting in, graph "); + } + graph.nodes().forEach(function(id2) { + const children2 = graph.children(id2); + if (children2.length > 0) { + log$1.warn( + "Cluster identified", + id2, + " Replacement id in edges: ", + findNonClusterChild(id2, graph) + ); + descendants[id2] = extractDescendants(id2, graph); + clusterDb[id2] = { id: findNonClusterChild(id2, graph), clusterData: graph.node(id2) }; + } + }); + graph.nodes().forEach(function(id2) { + const children2 = graph.children(id2); + const edges2 = graph.edges(); + if (children2.length > 0) { + log$1.debug("Cluster identified", id2, descendants); + edges2.forEach((edge) => { + if (edge.v !== id2 && edge.w !== id2) { + const d1 = isDescendant(edge.v, id2); + const d2 = isDescendant(edge.w, id2); + if (d1 ^ d2) { + log$1.warn("Edge: ", edge, " leaves cluster ", id2); + log$1.warn("Descendants of XXX ", id2, ": ", descendants[id2]); + clusterDb[id2].externalConnections = true; + } + } + }); + } else { + log$1.debug("Not a cluster ", id2, descendants); + } + }); + for (let id2 of Object.keys(clusterDb)) { + const nonClusterChild = clusterDb[id2].id; + const parent = graph.parent(nonClusterChild); + if (parent !== id2 && clusterDb[parent] && !clusterDb[parent].externalConnections) { + clusterDb[id2].id = parent; + } + } + graph.edges().forEach(function(e) { + const edge = graph.edge(e); + log$1.warn("Edge " + e.v + " -> " + e.w + ": " + JSON.stringify(e)); + log$1.warn("Edge " + e.v + " -> " + e.w + ": " + JSON.stringify(graph.edge(e))); + let v = e.v; + let w2 = e.w; + log$1.warn( + "Fix XXX", + clusterDb, + "ids:", + e.v, + e.w, + "Translating: ", + clusterDb[e.v], + " --- ", + clusterDb[e.w] + ); + if (clusterDb[e.v] && clusterDb[e.w] && clusterDb[e.v] === clusterDb[e.w]) { + log$1.warn("Fixing and trixing link to self - removing XXX", e.v, e.w, e.name); + log$1.warn("Fixing and trixing - removing XXX", e.v, e.w, e.name); + v = getAnchorId(e.v); + w2 = getAnchorId(e.w); + graph.removeEdge(e.v, e.w, e.name); + const specialId = e.w + "---" + e.v; + graph.setNode(specialId, { + domId: specialId, + id: specialId, + labelStyle: "", + labelText: edge.label, + padding: 0, + shape: "labelRect", + style: "" + }); + const edge1 = structuredClone(edge); + const edge2 = structuredClone(edge); + edge1.label = ""; + edge1.arrowTypeEnd = "none"; + edge2.label = ""; + edge1.fromCluster = e.v; + edge2.toCluster = e.v; + graph.setEdge(v, specialId, edge1, e.name + "-cyclic-special"); + graph.setEdge(specialId, w2, edge2, e.name + "-cyclic-special"); + } else if (clusterDb[e.v] || clusterDb[e.w]) { + log$1.warn("Fixing and trixing - removing XXX", e.v, e.w, e.name); + v = getAnchorId(e.v); + w2 = getAnchorId(e.w); + graph.removeEdge(e.v, e.w, e.name); + if (v !== e.v) { + const parent = graph.parent(v); + clusterDb[parent].externalConnections = true; + edge.fromCluster = e.v; + } + if (w2 !== e.w) { + const parent = graph.parent(w2); + clusterDb[parent].externalConnections = true; + edge.toCluster = e.w; + } + log$1.warn("Fix Replacing with XXX", v, w2, e.name); + graph.setEdge(v, w2, edge, e.name); + } + }); + log$1.warn("Adjusted Graph", write(graph)); + extractor(graph, 0); + log$1.trace(clusterDb); + }; + const extractor = (graph, depth) => { + log$1.warn("extractor - ", depth, write(graph), graph.children("D")); + if (depth > 10) { + log$1.error("Bailing out"); + return; + } + let nodes2 = graph.nodes(); + let hasChildren = false; + for (const node2 of nodes2) { + const children2 = graph.children(node2); + hasChildren = hasChildren || children2.length > 0; + } + if (!hasChildren) { + log$1.debug("Done, no node has children", graph.nodes()); + return; + } + log$1.debug("Nodes = ", nodes2, depth); + for (const node2 of nodes2) { + log$1.debug( + "Extracting node", + node2, + clusterDb, + clusterDb[node2] && !clusterDb[node2].externalConnections, + !graph.parent(node2), + graph.node(node2), + graph.children("D"), + " Depth ", + depth + ); + if (!clusterDb[node2]) { + log$1.debug("Not a cluster", node2, depth); + } else if (!clusterDb[node2].externalConnections && // !graph.parent(node) && + graph.children(node2) && graph.children(node2).length > 0) { + log$1.warn( + "Cluster without external connections, without a parent and with children", + node2, + depth + ); + const graphSettings = graph.graph(); + let dir2 = graphSettings.rankdir === "TB" ? "LR" : "TB"; + if (clusterDb[node2] && clusterDb[node2].clusterData && clusterDb[node2].clusterData.dir) { + dir2 = clusterDb[node2].clusterData.dir; + log$1.warn("Fixing dir", clusterDb[node2].clusterData.dir, dir2); + } + const clusterGraph = new Graph({ + multigraph: true, + compound: true + }).setGraph({ + rankdir: dir2, + // Todo: set proper spacing + nodesep: 50, + ranksep: 50, + marginx: 8, + marginy: 8 + }).setDefaultEdgeLabel(function() { + return {}; + }); + log$1.warn("Old graph before copy", write(graph)); + copy(node2, graph, clusterGraph, node2); + graph.setNode(node2, { + clusterNode: true, + id: node2, + clusterData: clusterDb[node2].clusterData, + labelText: clusterDb[node2].labelText, + graph: clusterGraph + }); + log$1.warn("New graph after copy node: (", node2, ")", write(clusterGraph)); + log$1.debug("Old graph after copy", write(graph)); + } else { + log$1.warn( + "Cluster ** ", + node2, + " **not meeting the criteria !externalConnections:", + !clusterDb[node2].externalConnections, + " no parent: ", + !graph.parent(node2), + " children ", + graph.children(node2) && graph.children(node2).length > 0, + graph.children("D"), + depth + ); + log$1.debug(clusterDb); + } + } + nodes2 = graph.nodes(); + log$1.warn("New list of nodes", nodes2); + for (const node2 of nodes2) { + const data = graph.node(node2); + log$1.warn(" Now next level", node2, data); + if (data.clusterNode) { + extractor(data.graph, depth + 1); + } + } + }; + const sorter = (graph, nodes2) => { + if (nodes2.length === 0) { + return []; + } + let result = Object.assign(nodes2); + nodes2.forEach((node2) => { + const children2 = graph.children(node2); + const sorted = sorter(graph, children2); + result = [...result, ...sorted]; + }); + return result; + }; + const sortNodesByHierarchy = (graph) => sorter(graph, graph.children()); + function intersectNode(node2, point2) { + return node2.intersect(point2); + } + function intersectEllipse(node2, rx, ry, point2) { + var cx = node2.x; + var cy = node2.y; + var px = cx - point2.x; + var py = cy - point2.y; + var det = Math.sqrt(rx * rx * py * py + ry * ry * px * px); + var dx = Math.abs(rx * ry * px / det); + if (point2.x < cx) { + dx = -dx; + } + var dy = Math.abs(rx * ry * py / det); + if (point2.y < cy) { + dy = -dy; + } + return { x: cx + dx, y: cy + dy }; + } + function intersectCircle(node2, rx, point2) { + return intersectEllipse(node2, rx, rx, point2); + } + function intersectLine(p1, p2, q1, q2) { + var a1, a2, b1, b2, c1, c2; + var r1, r2, r3, r4; + var denom, offset, num; + var x2, y2; + a1 = p2.y - p1.y; + b1 = p1.x - p2.x; + c1 = p2.x * p1.y - p1.x * p2.y; + r3 = a1 * q1.x + b1 * q1.y + c1; + r4 = a1 * q2.x + b1 * q2.y + c1; + if (r3 !== 0 && r4 !== 0 && sameSign(r3, r4)) { + return; + } + a2 = q2.y - q1.y; + b2 = q1.x - q2.x; + c2 = q2.x * q1.y - q1.x * q2.y; + r1 = a2 * p1.x + b2 * p1.y + c2; + r2 = a2 * p2.x + b2 * p2.y + c2; + if (r1 !== 0 && r2 !== 0 && sameSign(r1, r2)) { + return; + } + denom = a1 * b2 - a2 * b1; + if (denom === 0) { + return; + } + offset = Math.abs(denom / 2); + num = b1 * c2 - b2 * c1; + x2 = num < 0 ? (num - offset) / denom : (num + offset) / denom; + num = a2 * c1 - a1 * c2; + y2 = num < 0 ? (num - offset) / denom : (num + offset) / denom; + return { x: x2, y: y2 }; + } + function sameSign(r1, r2) { + return r1 * r2 > 0; + } + function intersectPolygon(node2, polyPoints, point2) { + var x1 = node2.x; + var y1 = node2.y; + var intersections = []; + var minX = Number.POSITIVE_INFINITY; + var minY = Number.POSITIVE_INFINITY; + if (typeof polyPoints.forEach === "function") { + polyPoints.forEach(function(entry) { + minX = Math.min(minX, entry.x); + minY = Math.min(minY, entry.y); + }); + } else { + minX = Math.min(minX, polyPoints.x); + minY = Math.min(minY, polyPoints.y); + } + var left2 = x1 - node2.width / 2 - minX; + var top2 = y1 - node2.height / 2 - minY; + for (var i2 = 0; i2 < polyPoints.length; i2++) { + var p1 = polyPoints[i2]; + var p2 = polyPoints[i2 < polyPoints.length - 1 ? i2 + 1 : 0]; + var intersect2 = intersectLine( + node2, + point2, + { x: left2 + p1.x, y: top2 + p1.y }, + { x: left2 + p2.x, y: top2 + p2.y } + ); + if (intersect2) { + intersections.push(intersect2); + } + } + if (!intersections.length) { + return node2; + } + if (intersections.length > 1) { + intersections.sort(function(p, q) { + var pdx = p.x - point2.x; + var pdy = p.y - point2.y; + var distp = Math.sqrt(pdx * pdx + pdy * pdy); + var qdx = q.x - point2.x; + var qdy = q.y - point2.y; + var distq = Math.sqrt(qdx * qdx + qdy * qdy); + return distp < distq ? -1 : distp === distq ? 0 : 1; + }); + } + return intersections[0]; + } + const intersectRect = (node2, point2) => { + var x2 = node2.x; + var y2 = node2.y; + var dx = point2.x - x2; + var dy = point2.y - y2; + var w2 = node2.width / 2; + var h = node2.height / 2; + var sx, sy; + if (Math.abs(dy) * w2 > Math.abs(dx) * h) { + if (dy < 0) { + h = -h; + } + sx = dy === 0 ? 0 : h * dx / dy; + sy = h; + } else { + if (dx < 0) { + w2 = -w2; + } + sx = w2; + sy = dx === 0 ? 0 : w2 * dy / dx; + } + return { x: x2 + sx, y: y2 + sy }; + }; + const intersectRect$1 = intersectRect; + const intersect = { + node: intersectNode, + circle: intersectCircle, + ellipse: intersectEllipse, + polygon: intersectPolygon, + rect: intersectRect$1 + }; + const note = async (parent, node2) => { + const useHtmlLabels = node2.useHtmlLabels || getConfig$1().flowchart.htmlLabels; + if (!useHtmlLabels) { + node2.centerLabel = true; + } + const { shapeSvg, bbox, halfPadding } = await labelHelper( + parent, + node2, + "node " + node2.classes, + true + ); + log$1.info("Classes = ", node2.classes); + const rect2 = shapeSvg.insert("rect", ":first-child"); + rect2.attr("rx", node2.rx).attr("ry", node2.ry).attr("x", -bbox.width / 2 - halfPadding).attr("y", -bbox.height / 2 - halfPadding).attr("width", bbox.width + node2.padding).attr("height", bbox.height + node2.padding); + updateNodeBounds(node2, rect2); + node2.intersect = function(point2) { + return intersect.rect(node2, point2); + }; + return shapeSvg; + }; + const note$1 = note; + const expandAndDeduplicateDirections = (directions) => { + const uniqueDirections = /* @__PURE__ */ new Set(); + for (const direction2 of directions) { + switch (direction2) { + case "x": + uniqueDirections.add("right"); + uniqueDirections.add("left"); + break; + case "y": + uniqueDirections.add("up"); + uniqueDirections.add("down"); + break; + default: + uniqueDirections.add(direction2); + break; + } + } + return uniqueDirections; + }; + const getArrowPoints = (duplicatedDirections, bbox, node2) => { + const directions = expandAndDeduplicateDirections(duplicatedDirections); + const f2 = 2; + const height = bbox.height + 2 * node2.padding; + const midpoint = height / f2; + const width2 = bbox.width + 2 * midpoint + node2.padding; + const padding2 = node2.padding / 2; + if (directions.has("right") && directions.has("left") && directions.has("up") && directions.has("down")) { + return [ + // Bottom + { x: 0, y: 0 }, + { x: midpoint, y: 0 }, + { x: width2 / 2, y: 2 * padding2 }, + { x: width2 - midpoint, y: 0 }, + { x: width2, y: 0 }, + // Right + { x: width2, y: -height / 3 }, + { x: width2 + 2 * padding2, y: -height / 2 }, + { x: width2, y: -2 * height / 3 }, + { x: width2, y: -height }, + // Top + { x: width2 - midpoint, y: -height }, + { x: width2 / 2, y: -height - 2 * padding2 }, + { x: midpoint, y: -height }, + // Left + { x: 0, y: -height }, + { x: 0, y: -2 * height / 3 }, + { x: -2 * padding2, y: -height / 2 }, + { x: 0, y: -height / 3 } + ]; + } + if (directions.has("right") && directions.has("left") && directions.has("up")) { + return [ + { x: midpoint, y: 0 }, + { x: width2 - midpoint, y: 0 }, + { x: width2, y: -height / 2 }, + { x: width2 - midpoint, y: -height }, + { x: midpoint, y: -height }, + { x: 0, y: -height / 2 } + ]; + } + if (directions.has("right") && directions.has("left") && directions.has("down")) { + return [ + { x: 0, y: 0 }, + { x: midpoint, y: -height }, + { x: width2 - midpoint, y: -height }, + { x: width2, y: 0 } + ]; + } + if (directions.has("right") && directions.has("up") && directions.has("down")) { + return [ + { x: 0, y: 0 }, + { x: width2, y: -midpoint }, + { x: width2, y: -height + midpoint }, + { x: 0, y: -height } + ]; + } + if (directions.has("left") && directions.has("up") && directions.has("down")) { + return [ + { x: width2, y: 0 }, + { x: 0, y: -midpoint }, + { x: 0, y: -height + midpoint }, + { x: width2, y: -height } + ]; + } + if (directions.has("right") && directions.has("left")) { + return [ + { x: midpoint, y: 0 }, + { x: midpoint, y: -padding2 }, + { x: width2 - midpoint, y: -padding2 }, + { x: width2 - midpoint, y: 0 }, + { x: width2, y: -height / 2 }, + { x: width2 - midpoint, y: -height }, + { x: width2 - midpoint, y: -height + padding2 }, + { x: midpoint, y: -height + padding2 }, + { x: midpoint, y: -height }, + { x: 0, y: -height / 2 } + ]; + } + if (directions.has("up") && directions.has("down")) { + return [ + // Bottom center + { x: width2 / 2, y: 0 }, + // Left pont of bottom arrow + { x: 0, y: -padding2 }, + { x: midpoint, y: -padding2 }, + // Left top over vertical section + { x: midpoint, y: -height + padding2 }, + { x: 0, y: -height + padding2 }, + // Top of arrow + { x: width2 / 2, y: -height }, + { x: width2, y: -height + padding2 }, + // Top of right vertical bar + { x: width2 - midpoint, y: -height + padding2 }, + { x: width2 - midpoint, y: -padding2 }, + { x: width2, y: -padding2 } + ]; + } + if (directions.has("right") && directions.has("up")) { + return [ + { x: 0, y: 0 }, + { x: width2, y: -midpoint }, + { x: 0, y: -height } + ]; + } + if (directions.has("right") && directions.has("down")) { + return [ + { x: 0, y: 0 }, + { x: width2, y: 0 }, + { x: 0, y: -height } + ]; + } + if (directions.has("left") && directions.has("up")) { + return [ + { x: width2, y: 0 }, + { x: 0, y: -midpoint }, + { x: width2, y: -height } + ]; + } + if (directions.has("left") && directions.has("down")) { + return [ + { x: width2, y: 0 }, + { x: 0, y: 0 }, + { x: width2, y: -height } + ]; + } + if (directions.has("right")) { + return [ + { x: midpoint, y: -padding2 }, + { x: midpoint, y: -padding2 }, + { x: width2 - midpoint, y: -padding2 }, + { x: width2 - midpoint, y: 0 }, + { x: width2, y: -height / 2 }, + { x: width2 - midpoint, y: -height }, + { x: width2 - midpoint, y: -height + padding2 }, + // top left corner of arrow + { x: midpoint, y: -height + padding2 }, + { x: midpoint, y: -height + padding2 } + ]; + } + if (directions.has("left")) { + return [ + { x: midpoint, y: 0 }, + { x: midpoint, y: -padding2 }, + // Two points, the right corners + { x: width2 - midpoint, y: -padding2 }, + { x: width2 - midpoint, y: -height + padding2 }, + { x: midpoint, y: -height + padding2 }, + { x: midpoint, y: -height }, + { x: 0, y: -height / 2 } + ]; + } + if (directions.has("up")) { + return [ + // Bottom center + { x: midpoint, y: -padding2 }, + // Left top over vertical section + { x: midpoint, y: -height + padding2 }, + { x: 0, y: -height + padding2 }, + // Top of arrow + { x: width2 / 2, y: -height }, + { x: width2, y: -height + padding2 }, + // Top of right vertical bar + { x: width2 - midpoint, y: -height + padding2 }, + { x: width2 - midpoint, y: -padding2 } + ]; + } + if (directions.has("down")) { + return [ + // Bottom center + { x: width2 / 2, y: 0 }, + // Left pont of bottom arrow + { x: 0, y: -padding2 }, + { x: midpoint, y: -padding2 }, + // Left top over vertical section + { x: midpoint, y: -height + padding2 }, + { x: width2 - midpoint, y: -height + padding2 }, + { x: width2 - midpoint, y: -padding2 }, + { x: width2, y: -padding2 } + ]; + } + return [{ x: 0, y: 0 }]; + }; + const formatClass = (str2) => { + if (str2) { + return " " + str2; + } + return ""; + }; + const getClassesFromNode = (node2, otherClasses) => { + return `${otherClasses ? otherClasses : "node default"}${formatClass(node2.classes)} ${formatClass( + node2.class + )}`; + }; + const question = async (parent, node2) => { + const { shapeSvg, bbox } = await labelHelper( + parent, + node2, + getClassesFromNode(node2, void 0), + true + ); + const w2 = bbox.width + node2.padding; + const h = bbox.height + node2.padding; + const s = w2 + h; + const points = [ + { x: s / 2, y: 0 }, + { x: s, y: -s / 2 }, + { x: s / 2, y: -s }, + { x: 0, y: -s / 2 } + ]; + log$1.info("Question main (Circle)"); + const questionElem = insertPolygonShape$1(shapeSvg, s, s, points); + questionElem.attr("style", node2.style); + updateNodeBounds(node2, questionElem); + node2.intersect = function(point2) { + log$1.warn("Intersect called"); + return intersect.polygon(node2, points, point2); + }; + return shapeSvg; + }; + const choice = (parent, node2) => { + const shapeSvg = parent.insert("g").attr("class", "node default").attr("id", node2.domId || node2.id); + const s = 28; + const points = [ + { x: 0, y: s / 2 }, + { x: s / 2, y: 0 }, + { x: 0, y: -s / 2 }, + { x: -s / 2, y: 0 } + ]; + const choice2 = shapeSvg.insert("polygon", ":first-child").attr( + "points", + points.map(function(d) { + return d.x + "," + d.y; + }).join(" ") + ); + choice2.attr("class", "state-start").attr("r", 7).attr("width", 28).attr("height", 28); + node2.width = 28; + node2.height = 28; + node2.intersect = function(point2) { + return intersect.circle(node2, 14, point2); + }; + return shapeSvg; + }; + const hexagon = async (parent, node2) => { + const { shapeSvg, bbox } = await labelHelper( + parent, + node2, + getClassesFromNode(node2, void 0), + true + ); + const f2 = 4; + const h = bbox.height + node2.padding; + const m = h / f2; + const w2 = bbox.width + 2 * m + node2.padding; + const points = [ + { x: m, y: 0 }, + { x: w2 - m, y: 0 }, + { x: w2, y: -h / 2 }, + { x: w2 - m, y: -h }, + { x: m, y: -h }, + { x: 0, y: -h / 2 } + ]; + const hex2 = insertPolygonShape$1(shapeSvg, w2, h, points); + hex2.attr("style", node2.style); + updateNodeBounds(node2, hex2); + node2.intersect = function(point2) { + return intersect.polygon(node2, points, point2); + }; + return shapeSvg; + }; + const block_arrow = async (parent, node2) => { + const { shapeSvg, bbox } = await labelHelper(parent, node2, void 0, true); + const f2 = 2; + const h = bbox.height + 2 * node2.padding; + const m = h / f2; + const w2 = bbox.width + 2 * m + node2.padding; + const points = getArrowPoints(node2.directions, bbox, node2); + const blockArrow = insertPolygonShape$1(shapeSvg, w2, h, points); + blockArrow.attr("style", node2.style); + updateNodeBounds(node2, blockArrow); + node2.intersect = function(point2) { + return intersect.polygon(node2, points, point2); + }; + return shapeSvg; + }; + const rect_left_inv_arrow = async (parent, node2) => { + const { shapeSvg, bbox } = await labelHelper( + parent, + node2, + getClassesFromNode(node2, void 0), + true + ); + const w2 = bbox.width + node2.padding; + const h = bbox.height + node2.padding; + const points = [ + { x: -h / 2, y: 0 }, + { x: w2, y: 0 }, + { x: w2, y: -h }, + { x: -h / 2, y: -h }, + { x: 0, y: -h / 2 } + ]; + const el = insertPolygonShape$1(shapeSvg, w2, h, points); + el.attr("style", node2.style); + node2.width = w2 + h; + node2.height = h; + node2.intersect = function(point2) { + return intersect.polygon(node2, points, point2); + }; + return shapeSvg; + }; + const lean_right = async (parent, node2) => { + const { shapeSvg, bbox } = await labelHelper(parent, node2, getClassesFromNode(node2), true); + const w2 = bbox.width + node2.padding; + const h = bbox.height + node2.padding; + const points = [ + { x: -2 * h / 6, y: 0 }, + { x: w2 - h / 6, y: 0 }, + { x: w2 + 2 * h / 6, y: -h }, + { x: h / 6, y: -h } + ]; + const el = insertPolygonShape$1(shapeSvg, w2, h, points); + el.attr("style", node2.style); + updateNodeBounds(node2, el); + node2.intersect = function(point2) { + return intersect.polygon(node2, points, point2); + }; + return shapeSvg; + }; + const lean_left = async (parent, node2) => { + const { shapeSvg, bbox } = await labelHelper( + parent, + node2, + getClassesFromNode(node2, void 0), + true + ); + const w2 = bbox.width + node2.padding; + const h = bbox.height + node2.padding; + const points = [ + { x: 2 * h / 6, y: 0 }, + { x: w2 + h / 6, y: 0 }, + { x: w2 - 2 * h / 6, y: -h }, + { x: -h / 6, y: -h } + ]; + const el = insertPolygonShape$1(shapeSvg, w2, h, points); + el.attr("style", node2.style); + updateNodeBounds(node2, el); + node2.intersect = function(point2) { + return intersect.polygon(node2, points, point2); + }; + return shapeSvg; + }; + const trapezoid = async (parent, node2) => { + const { shapeSvg, bbox } = await labelHelper( + parent, + node2, + getClassesFromNode(node2, void 0), + true + ); + const w2 = bbox.width + node2.padding; + const h = bbox.height + node2.padding; + const points = [ + { x: -2 * h / 6, y: 0 }, + { x: w2 + 2 * h / 6, y: 0 }, + { x: w2 - h / 6, y: -h }, + { x: h / 6, y: -h } + ]; + const el = insertPolygonShape$1(shapeSvg, w2, h, points); + el.attr("style", node2.style); + updateNodeBounds(node2, el); + node2.intersect = function(point2) { + return intersect.polygon(node2, points, point2); + }; + return shapeSvg; + }; + const inv_trapezoid = async (parent, node2) => { + const { shapeSvg, bbox } = await labelHelper( + parent, + node2, + getClassesFromNode(node2, void 0), + true + ); + const w2 = bbox.width + node2.padding; + const h = bbox.height + node2.padding; + const points = [ + { x: h / 6, y: 0 }, + { x: w2 - h / 6, y: 0 }, + { x: w2 + 2 * h / 6, y: -h }, + { x: -2 * h / 6, y: -h } + ]; + const el = insertPolygonShape$1(shapeSvg, w2, h, points); + el.attr("style", node2.style); + updateNodeBounds(node2, el); + node2.intersect = function(point2) { + return intersect.polygon(node2, points, point2); + }; + return shapeSvg; + }; + const rect_right_inv_arrow = async (parent, node2) => { + const { shapeSvg, bbox } = await labelHelper( + parent, + node2, + getClassesFromNode(node2, void 0), + true + ); + const w2 = bbox.width + node2.padding; + const h = bbox.height + node2.padding; + const points = [ + { x: 0, y: 0 }, + { x: w2 + h / 2, y: 0 }, + { x: w2, y: -h / 2 }, + { x: w2 + h / 2, y: -h }, + { x: 0, y: -h } + ]; + const el = insertPolygonShape$1(shapeSvg, w2, h, points); + el.attr("style", node2.style); + updateNodeBounds(node2, el); + node2.intersect = function(point2) { + return intersect.polygon(node2, points, point2); + }; + return shapeSvg; + }; + const cylinder = async (parent, node2) => { + const { shapeSvg, bbox } = await labelHelper( + parent, + node2, + getClassesFromNode(node2, void 0), + true + ); + const w2 = bbox.width + node2.padding; + const rx = w2 / 2; + const ry = rx / (2.5 + w2 / 50); + const h = bbox.height + ry + node2.padding; + const shape = "M 0," + ry + " a " + rx + "," + ry + " 0,0,0 " + w2 + " 0 a " + rx + "," + ry + " 0,0,0 " + -w2 + " 0 l 0," + h + " a " + rx + "," + ry + " 0,0,0 " + w2 + " 0 l 0," + -h; + const el = shapeSvg.attr("label-offset-y", ry).insert("path", ":first-child").attr("style", node2.style).attr("d", shape).attr("transform", "translate(" + -w2 / 2 + "," + -(h / 2 + ry) + ")"); + updateNodeBounds(node2, el); + node2.intersect = function(point2) { + const pos = intersect.rect(node2, point2); + const x2 = pos.x - node2.x; + if (rx != 0 && (Math.abs(x2) < node2.width / 2 || Math.abs(x2) == node2.width / 2 && Math.abs(pos.y - node2.y) > node2.height / 2 - ry)) { + let y2 = ry * ry * (1 - x2 * x2 / (rx * rx)); + if (y2 != 0) { + y2 = Math.sqrt(y2); + } + y2 = ry - y2; + if (point2.y - node2.y > 0) { + y2 = -y2; + } + pos.y += y2; + } + return pos; + }; + return shapeSvg; + }; + const rect$1 = async (parent, node2) => { + const { shapeSvg, bbox, halfPadding } = await labelHelper( + parent, + node2, + "node " + node2.classes + " " + node2.class, + true + ); + const rect2 = shapeSvg.insert("rect", ":first-child"); + const totalWidth = node2.positioned ? node2.width : bbox.width + node2.padding; + const totalHeight = node2.positioned ? node2.height : bbox.height + node2.padding; + const x2 = node2.positioned ? -totalWidth / 2 : -bbox.width / 2 - halfPadding; + const y2 = node2.positioned ? -totalHeight / 2 : -bbox.height / 2 - halfPadding; + rect2.attr("class", "basic label-container").attr("style", node2.style).attr("rx", node2.rx).attr("ry", node2.ry).attr("x", x2).attr("y", y2).attr("width", totalWidth).attr("height", totalHeight); + if (node2.props) { + const propKeys = new Set(Object.keys(node2.props)); + if (node2.props.borders) { + applyNodePropertyBorders(rect2, node2.props.borders, totalWidth, totalHeight); + propKeys.delete("borders"); + } + propKeys.forEach((propKey) => { + log$1.warn(`Unknown node property ${propKey}`); + }); + } + updateNodeBounds(node2, rect2); + node2.intersect = function(point2) { + return intersect.rect(node2, point2); + }; + return shapeSvg; + }; + const composite = async (parent, node2) => { + const { shapeSvg, bbox, halfPadding } = await labelHelper( + parent, + node2, + "node " + node2.classes, + true + ); + const rect2 = shapeSvg.insert("rect", ":first-child"); + const totalWidth = node2.positioned ? node2.width : bbox.width + node2.padding; + const totalHeight = node2.positioned ? node2.height : bbox.height + node2.padding; + const x2 = node2.positioned ? -totalWidth / 2 : -bbox.width / 2 - halfPadding; + const y2 = node2.positioned ? -totalHeight / 2 : -bbox.height / 2 - halfPadding; + rect2.attr("class", "basic cluster composite label-container").attr("style", node2.style).attr("rx", node2.rx).attr("ry", node2.ry).attr("x", x2).attr("y", y2).attr("width", totalWidth).attr("height", totalHeight); + if (node2.props) { + const propKeys = new Set(Object.keys(node2.props)); + if (node2.props.borders) { + applyNodePropertyBorders(rect2, node2.props.borders, totalWidth, totalHeight); + propKeys.delete("borders"); + } + propKeys.forEach((propKey) => { + log$1.warn(`Unknown node property ${propKey}`); + }); + } + updateNodeBounds(node2, rect2); + node2.intersect = function(point2) { + return intersect.rect(node2, point2); + }; + return shapeSvg; + }; + const labelRect = async (parent, node2) => { + const { shapeSvg } = await labelHelper(parent, node2, "label", true); + log$1.trace("Classes = ", node2.class); + const rect2 = shapeSvg.insert("rect", ":first-child"); + const totalWidth = 0; + const totalHeight = 0; + rect2.attr("width", totalWidth).attr("height", totalHeight); + shapeSvg.attr("class", "label edgeLabel"); + if (node2.props) { + const propKeys = new Set(Object.keys(node2.props)); + if (node2.props.borders) { + applyNodePropertyBorders(rect2, node2.props.borders, totalWidth, totalHeight); + propKeys.delete("borders"); + } + propKeys.forEach((propKey) => { + log$1.warn(`Unknown node property ${propKey}`); + }); + } + updateNodeBounds(node2, rect2); + node2.intersect = function(point2) { + return intersect.rect(node2, point2); + }; + return shapeSvg; + }; + function applyNodePropertyBorders(rect2, borders, totalWidth, totalHeight) { + const strokeDashArray = []; + const addBorder = (length2) => { + strokeDashArray.push(length2, 0); + }; + const skipBorder = (length2) => { + strokeDashArray.push(0, length2); + }; + if (borders.includes("t")) { + log$1.debug("add top border"); + addBorder(totalWidth); + } else { + skipBorder(totalWidth); + } + if (borders.includes("r")) { + log$1.debug("add right border"); + addBorder(totalHeight); + } else { + skipBorder(totalHeight); + } + if (borders.includes("b")) { + log$1.debug("add bottom border"); + addBorder(totalWidth); + } else { + skipBorder(totalWidth); + } + if (borders.includes("l")) { + log$1.debug("add left border"); + addBorder(totalHeight); + } else { + skipBorder(totalHeight); + } + rect2.attr("stroke-dasharray", strokeDashArray.join(" ")); + } + const rectWithTitle = (parent, node2) => { + let classes2; + if (!node2.classes) { + classes2 = "node default"; + } else { + classes2 = "node " + node2.classes; + } + const shapeSvg = parent.insert("g").attr("class", classes2).attr("id", node2.domId || node2.id); + const rect2 = shapeSvg.insert("rect", ":first-child"); + const innerLine = shapeSvg.insert("line"); + const label = shapeSvg.insert("g").attr("class", "label"); + const text2 = node2.labelText.flat ? node2.labelText.flat() : node2.labelText; + let title2 = ""; + if (typeof text2 === "object") { + title2 = text2[0]; + } else { + title2 = text2; + } + log$1.info("Label text abc79", title2, text2, typeof text2 === "object"); + const text3 = label.node().appendChild(createLabel$1(title2, node2.labelStyle, true, true)); + let bbox = { width: 0, height: 0 }; + if (evaluate(getConfig$1().flowchart.htmlLabels)) { + const div = text3.children[0]; + const dv = d3select(text3); + bbox = div.getBoundingClientRect(); + dv.attr("width", bbox.width); + dv.attr("height", bbox.height); + } + log$1.info("Text 2", text2); + const textRows = text2.slice(1, text2.length); + let titleBox = text3.getBBox(); + const descr = label.node().appendChild( + createLabel$1(textRows.join ? textRows.join("
    ") : textRows, node2.labelStyle, true, true) + ); + if (evaluate(getConfig$1().flowchart.htmlLabels)) { + const div = descr.children[0]; + const dv = d3select(descr); + bbox = div.getBoundingClientRect(); + dv.attr("width", bbox.width); + dv.attr("height", bbox.height); + } + const halfPadding = node2.padding / 2; + d3select(descr).attr( + "transform", + "translate( " + // (titleBox.width - bbox.width) / 2 + + (bbox.width > titleBox.width ? 0 : (titleBox.width - bbox.width) / 2) + ", " + (titleBox.height + halfPadding + 5) + ")" + ); + d3select(text3).attr( + "transform", + "translate( " + // (titleBox.width - bbox.width) / 2 + + (bbox.width < titleBox.width ? 0 : -(titleBox.width - bbox.width) / 2) + ", 0)" + ); + bbox = label.node().getBBox(); + label.attr( + "transform", + "translate(" + -bbox.width / 2 + ", " + (-bbox.height / 2 - halfPadding + 3) + ")" + ); + rect2.attr("class", "outer title-state").attr("x", -bbox.width / 2 - halfPadding).attr("y", -bbox.height / 2 - halfPadding).attr("width", bbox.width + node2.padding).attr("height", bbox.height + node2.padding); + innerLine.attr("class", "divider").attr("x1", -bbox.width / 2 - halfPadding).attr("x2", bbox.width / 2 + halfPadding).attr("y1", -bbox.height / 2 - halfPadding + titleBox.height + halfPadding).attr("y2", -bbox.height / 2 - halfPadding + titleBox.height + halfPadding); + updateNodeBounds(node2, rect2); + node2.intersect = function(point2) { + return intersect.rect(node2, point2); + }; + return shapeSvg; + }; + const stadium = async (parent, node2) => { + const { shapeSvg, bbox } = await labelHelper( + parent, + node2, + getClassesFromNode(node2, void 0), + true + ); + const h = bbox.height + node2.padding; + const w2 = bbox.width + h / 4 + node2.padding; + const rect2 = shapeSvg.insert("rect", ":first-child").attr("style", node2.style).attr("rx", h / 2).attr("ry", h / 2).attr("x", -w2 / 2).attr("y", -h / 2).attr("width", w2).attr("height", h); + updateNodeBounds(node2, rect2); + node2.intersect = function(point2) { + return intersect.rect(node2, point2); + }; + return shapeSvg; + }; + const circle = async (parent, node2) => { + const { shapeSvg, bbox, halfPadding } = await labelHelper( + parent, + node2, + getClassesFromNode(node2, void 0), + true + ); + const circle2 = shapeSvg.insert("circle", ":first-child"); + circle2.attr("style", node2.style).attr("rx", node2.rx).attr("ry", node2.ry).attr("r", bbox.width / 2 + halfPadding).attr("width", bbox.width + node2.padding).attr("height", bbox.height + node2.padding); + log$1.info("Circle main"); + updateNodeBounds(node2, circle2); + node2.intersect = function(point2) { + log$1.info("Circle intersect", node2, bbox.width / 2 + halfPadding, point2); + return intersect.circle(node2, bbox.width / 2 + halfPadding, point2); + }; + return shapeSvg; + }; + const doublecircle = async (parent, node2) => { + const { shapeSvg, bbox, halfPadding } = await labelHelper( + parent, + node2, + getClassesFromNode(node2, void 0), + true + ); + const gap = 5; + const circleGroup = shapeSvg.insert("g", ":first-child"); + const outerCircle = circleGroup.insert("circle"); + const innerCircle = circleGroup.insert("circle"); + circleGroup.attr("class", node2.class); + outerCircle.attr("style", node2.style).attr("rx", node2.rx).attr("ry", node2.ry).attr("r", bbox.width / 2 + halfPadding + gap).attr("width", bbox.width + node2.padding + gap * 2).attr("height", bbox.height + node2.padding + gap * 2); + innerCircle.attr("style", node2.style).attr("rx", node2.rx).attr("ry", node2.ry).attr("r", bbox.width / 2 + halfPadding).attr("width", bbox.width + node2.padding).attr("height", bbox.height + node2.padding); + log$1.info("DoubleCircle main"); + updateNodeBounds(node2, outerCircle); + node2.intersect = function(point2) { + log$1.info("DoubleCircle intersect", node2, bbox.width / 2 + halfPadding + gap, point2); + return intersect.circle(node2, bbox.width / 2 + halfPadding + gap, point2); + }; + return shapeSvg; + }; + const subroutine = async (parent, node2) => { + const { shapeSvg, bbox } = await labelHelper( + parent, + node2, + getClassesFromNode(node2, void 0), + true + ); + const w2 = bbox.width + node2.padding; + const h = bbox.height + node2.padding; + const points = [ + { x: 0, y: 0 }, + { x: w2, y: 0 }, + { x: w2, y: -h }, + { x: 0, y: -h }, + { x: 0, y: 0 }, + { x: -8, y: 0 }, + { x: w2 + 8, y: 0 }, + { x: w2 + 8, y: -h }, + { x: -8, y: -h }, + { x: -8, y: 0 } + ]; + const el = insertPolygonShape$1(shapeSvg, w2, h, points); + el.attr("style", node2.style); + updateNodeBounds(node2, el); + node2.intersect = function(point2) { + return intersect.polygon(node2, points, point2); + }; + return shapeSvg; + }; + const start = (parent, node2) => { + const shapeSvg = parent.insert("g").attr("class", "node default").attr("id", node2.domId || node2.id); + const circle2 = shapeSvg.insert("circle", ":first-child"); + circle2.attr("class", "state-start").attr("r", 7).attr("width", 14).attr("height", 14); + updateNodeBounds(node2, circle2); + node2.intersect = function(point2) { + return intersect.circle(node2, 7, point2); + }; + return shapeSvg; + }; + const forkJoin = (parent, node2, dir2) => { + const shapeSvg = parent.insert("g").attr("class", "node default").attr("id", node2.domId || node2.id); + let width2 = 70; + let height = 10; + if (dir2 === "LR") { + width2 = 10; + height = 70; + } + const shape = shapeSvg.append("rect").attr("x", -1 * width2 / 2).attr("y", -1 * height / 2).attr("width", width2).attr("height", height).attr("class", "fork-join"); + updateNodeBounds(node2, shape); + node2.height = node2.height + node2.padding / 2; + node2.width = node2.width + node2.padding / 2; + node2.intersect = function(point2) { + return intersect.rect(node2, point2); + }; + return shapeSvg; + }; + const end = (parent, node2) => { + const shapeSvg = parent.insert("g").attr("class", "node default").attr("id", node2.domId || node2.id); + const innerCircle = shapeSvg.insert("circle", ":first-child"); + const circle2 = shapeSvg.insert("circle", ":first-child"); + circle2.attr("class", "state-start").attr("r", 7).attr("width", 14).attr("height", 14); + innerCircle.attr("class", "state-end").attr("r", 5).attr("width", 10).attr("height", 10); + updateNodeBounds(node2, circle2); + node2.intersect = function(point2) { + return intersect.circle(node2, 7, point2); + }; + return shapeSvg; + }; + const class_box = (parent, node2) => { + const halfPadding = node2.padding / 2; + const rowPadding = 4; + const lineHeight = 8; + let classes2; + if (!node2.classes) { + classes2 = "node default"; + } else { + classes2 = "node " + node2.classes; + } + const shapeSvg = parent.insert("g").attr("class", classes2).attr("id", node2.domId || node2.id); + const rect2 = shapeSvg.insert("rect", ":first-child"); + const topLine = shapeSvg.insert("line"); + const bottomLine = shapeSvg.insert("line"); + let maxWidth = 0; + let maxHeight = rowPadding; + const labelContainer = shapeSvg.insert("g").attr("class", "label"); + let verticalPos = 0; + const hasInterface = node2.classData.annotations && node2.classData.annotations[0]; + const interfaceLabelText = node2.classData.annotations[0] ? "«" + node2.classData.annotations[0] + "»" : ""; + const interfaceLabel = labelContainer.node().appendChild(createLabel$1(interfaceLabelText, node2.labelStyle, true, true)); + let interfaceBBox = interfaceLabel.getBBox(); + if (evaluate(getConfig$1().flowchart.htmlLabels)) { + const div = interfaceLabel.children[0]; + const dv = d3select(interfaceLabel); + interfaceBBox = div.getBoundingClientRect(); + dv.attr("width", interfaceBBox.width); + dv.attr("height", interfaceBBox.height); + } + if (node2.classData.annotations[0]) { + maxHeight += interfaceBBox.height + rowPadding; + maxWidth += interfaceBBox.width; + } + let classTitleString = node2.classData.label; + if (node2.classData.type !== void 0 && node2.classData.type !== "") { + if (getConfig$1().flowchart.htmlLabels) { + classTitleString += "<" + node2.classData.type + ">"; + } else { + classTitleString += "<" + node2.classData.type + ">"; + } + } + const classTitleLabel = labelContainer.node().appendChild(createLabel$1(classTitleString, node2.labelStyle, true, true)); + d3select(classTitleLabel).attr("class", "classTitle"); + let classTitleBBox = classTitleLabel.getBBox(); + if (evaluate(getConfig$1().flowchart.htmlLabels)) { + const div = classTitleLabel.children[0]; + const dv = d3select(classTitleLabel); + classTitleBBox = div.getBoundingClientRect(); + dv.attr("width", classTitleBBox.width); + dv.attr("height", classTitleBBox.height); + } + maxHeight += classTitleBBox.height + rowPadding; + if (classTitleBBox.width > maxWidth) { + maxWidth = classTitleBBox.width; + } + const classAttributes = []; + node2.classData.members.forEach((member) => { + const parsedInfo = member.getDisplayDetails(); + let parsedText = parsedInfo.displayText; + if (getConfig$1().flowchart.htmlLabels) { + parsedText = parsedText.replace(//g, ">"); + } + const lbl = labelContainer.node().appendChild( + createLabel$1( + parsedText, + parsedInfo.cssStyle ? parsedInfo.cssStyle : node2.labelStyle, + true, + true + ) + ); + let bbox = lbl.getBBox(); + if (evaluate(getConfig$1().flowchart.htmlLabels)) { + const div = lbl.children[0]; + const dv = d3select(lbl); + bbox = div.getBoundingClientRect(); + dv.attr("width", bbox.width); + dv.attr("height", bbox.height); + } + if (bbox.width > maxWidth) { + maxWidth = bbox.width; + } + maxHeight += bbox.height + rowPadding; + classAttributes.push(lbl); + }); + maxHeight += lineHeight; + const classMethods = []; + node2.classData.methods.forEach((member) => { + const parsedInfo = member.getDisplayDetails(); + let displayText = parsedInfo.displayText; + if (getConfig$1().flowchart.htmlLabels) { + displayText = displayText.replace(//g, ">"); + } + const lbl = labelContainer.node().appendChild( + createLabel$1( + displayText, + parsedInfo.cssStyle ? parsedInfo.cssStyle : node2.labelStyle, + true, + true + ) + ); + let bbox = lbl.getBBox(); + if (evaluate(getConfig$1().flowchart.htmlLabels)) { + const div = lbl.children[0]; + const dv = d3select(lbl); + bbox = div.getBoundingClientRect(); + dv.attr("width", bbox.width); + dv.attr("height", bbox.height); + } + if (bbox.width > maxWidth) { + maxWidth = bbox.width; + } + maxHeight += bbox.height + rowPadding; + classMethods.push(lbl); + }); + maxHeight += lineHeight; + if (hasInterface) { + let diffX2 = (maxWidth - interfaceBBox.width) / 2; + d3select(interfaceLabel).attr( + "transform", + "translate( " + (-1 * maxWidth / 2 + diffX2) + ", " + -1 * maxHeight / 2 + ")" + ); + verticalPos = interfaceBBox.height + rowPadding; + } + let diffX = (maxWidth - classTitleBBox.width) / 2; + d3select(classTitleLabel).attr( + "transform", + "translate( " + (-1 * maxWidth / 2 + diffX) + ", " + (-1 * maxHeight / 2 + verticalPos) + ")" + ); + verticalPos += classTitleBBox.height + rowPadding; + topLine.attr("class", "divider").attr("x1", -maxWidth / 2 - halfPadding).attr("x2", maxWidth / 2 + halfPadding).attr("y1", -maxHeight / 2 - halfPadding + lineHeight + verticalPos).attr("y2", -maxHeight / 2 - halfPadding + lineHeight + verticalPos); + verticalPos += lineHeight; + classAttributes.forEach((lbl) => { + d3select(lbl).attr( + "transform", + "translate( " + -maxWidth / 2 + ", " + (-1 * maxHeight / 2 + verticalPos + lineHeight / 2) + ")" + ); + const memberBBox = lbl == null ? void 0 : lbl.getBBox(); + verticalPos += ((memberBBox == null ? void 0 : memberBBox.height) ?? 0) + rowPadding; + }); + verticalPos += lineHeight; + bottomLine.attr("class", "divider").attr("x1", -maxWidth / 2 - halfPadding).attr("x2", maxWidth / 2 + halfPadding).attr("y1", -maxHeight / 2 - halfPadding + lineHeight + verticalPos).attr("y2", -maxHeight / 2 - halfPadding + lineHeight + verticalPos); + verticalPos += lineHeight; + classMethods.forEach((lbl) => { + d3select(lbl).attr( + "transform", + "translate( " + -maxWidth / 2 + ", " + (-1 * maxHeight / 2 + verticalPos) + ")" + ); + const memberBBox = lbl == null ? void 0 : lbl.getBBox(); + verticalPos += ((memberBBox == null ? void 0 : memberBBox.height) ?? 0) + rowPadding; + }); + rect2.attr("style", node2.style).attr("class", "outer title-state").attr("x", -maxWidth / 2 - halfPadding).attr("y", -(maxHeight / 2) - halfPadding).attr("width", maxWidth + node2.padding).attr("height", maxHeight + node2.padding); + updateNodeBounds(node2, rect2); + node2.intersect = function(point2) { + return intersect.rect(node2, point2); + }; + return shapeSvg; + }; + const shapes$1 = { + rhombus: question, + composite, + question, + rect: rect$1, + labelRect, + rectWithTitle, + choice, + circle, + doublecircle, + stadium, + hexagon, + block_arrow, + rect_left_inv_arrow, + lean_right, + lean_left, + trapezoid, + inv_trapezoid, + rect_right_inv_arrow, + cylinder, + start, + end, + note: note$1, + subroutine, + fork: forkJoin, + join: forkJoin, + class_box + }; + let nodeElems = {}; + const insertNode = async (elem, node2, dir2) => { + let newEl; + let el; + if (node2.link) { + let target; + if (getConfig$1().securityLevel === "sandbox") { + target = "_top"; + } else if (node2.linkTarget) { + target = node2.linkTarget || "_blank"; + } + newEl = elem.insert("svg:a").attr("xlink:href", node2.link).attr("target", target); + el = await shapes$1[node2.shape](newEl, node2, dir2); + } else { + el = await shapes$1[node2.shape](elem, node2, dir2); + newEl = el; + } + if (node2.tooltip) { + el.attr("title", node2.tooltip); + } + if (node2.class) { + el.attr("class", "node default " + node2.class); + } + newEl.attr("data-node", "true"); + newEl.attr("data-id", node2.id); + nodeElems[node2.id] = newEl; + if (node2.haveCallback) { + nodeElems[node2.id].attr("class", nodeElems[node2.id].attr("class") + " clickable"); + } + return newEl; + }; + const setNodeElem = (elem, node2) => { + nodeElems[node2.id] = elem; + }; + const clear$j = () => { + nodeElems = {}; + }; + const positionNode$1 = (node2) => { + const el = nodeElems[node2.id]; + log$1.trace( + "Transforming node", + node2.diff, + node2, + "translate(" + (node2.x - node2.width / 2 - 5) + ", " + node2.width / 2 + ")" + ); + const padding2 = 8; + const diff = node2.diff || 0; + if (node2.clusterNode) { + el.attr( + "transform", + "translate(" + (node2.x + diff - node2.width / 2) + ", " + (node2.y - node2.height / 2 - padding2) + ")" + ); + } else { + el.attr("transform", "translate(" + node2.x + ", " + node2.y + ")"); + } + return diff; + }; + const getSubGraphTitleMargins = ({ + flowchart: flowchart2 + }) => { + var _a2, _b2; + const subGraphTitleTopMargin = ((_a2 = flowchart2 == null ? void 0 : flowchart2.subGraphTitleMargin) == null ? void 0 : _a2.top) ?? 0; + const subGraphTitleBottomMargin = ((_b2 = flowchart2 == null ? void 0 : flowchart2.subGraphTitleMargin) == null ? void 0 : _b2.bottom) ?? 0; + const subGraphTitleTotalMargin = subGraphTitleTopMargin + subGraphTitleBottomMargin; + return { + subGraphTitleTopMargin, + subGraphTitleBottomMargin, + subGraphTitleTotalMargin + }; + }; + const rect = (parent, node2) => { + log$1.info("Creating subgraph rect for ", node2.id, node2); + const siteConfig2 = getConfig$1(); + const shapeSvg = parent.insert("g").attr("class", "cluster" + (node2.class ? " " + node2.class : "")).attr("id", node2.id); + const rect2 = shapeSvg.insert("rect", ":first-child"); + const useHtmlLabels = evaluate(siteConfig2.flowchart.htmlLabels); + const label = shapeSvg.insert("g").attr("class", "cluster-label"); + const text2 = node2.labelType === "markdown" ? createText(label, node2.labelText, { style: node2.labelStyle, useHtmlLabels }) : label.node().appendChild(createLabel$1(node2.labelText, node2.labelStyle, void 0, true)); + let bbox = text2.getBBox(); + if (evaluate(siteConfig2.flowchart.htmlLabels)) { + const div = text2.children[0]; + const dv = d3select(text2); + bbox = div.getBoundingClientRect(); + dv.attr("width", bbox.width); + dv.attr("height", bbox.height); + } + const padding2 = 0 * node2.padding; + const halfPadding = padding2 / 2; + const width2 = node2.width <= bbox.width + padding2 ? bbox.width + padding2 : node2.width; + if (node2.width <= bbox.width + padding2) { + node2.diff = (bbox.width - node2.width) / 2 - node2.padding / 2; + } else { + node2.diff = -node2.padding / 2; + } + log$1.trace("Data ", node2, JSON.stringify(node2)); + rect2.attr("style", node2.style).attr("rx", node2.rx).attr("ry", node2.ry).attr("x", node2.x - width2 / 2).attr("y", node2.y - node2.height / 2 - halfPadding).attr("width", width2).attr("height", node2.height + padding2); + const { subGraphTitleTopMargin } = getSubGraphTitleMargins(siteConfig2); + if (useHtmlLabels) { + label.attr( + "transform", + // This puts the label on top of the box instead of inside it + `translate(${node2.x - bbox.width / 2}, ${node2.y - node2.height / 2 + subGraphTitleTopMargin})` + ); + } else { + label.attr( + "transform", + // This puts the label on top of the box instead of inside it + `translate(${node2.x}, ${node2.y - node2.height / 2 + subGraphTitleTopMargin})` + ); + } + const rectBox = rect2.node().getBBox(); + node2.width = rectBox.width; + node2.height = rectBox.height; + node2.intersect = function(point2) { + return intersectRect$1(node2, point2); + }; + return shapeSvg; + }; + const noteGroup = (parent, node2) => { + const shapeSvg = parent.insert("g").attr("class", "note-cluster").attr("id", node2.id); + const rect2 = shapeSvg.insert("rect", ":first-child"); + const padding2 = 0 * node2.padding; + const halfPadding = padding2 / 2; + rect2.attr("rx", node2.rx).attr("ry", node2.ry).attr("x", node2.x - node2.width / 2 - halfPadding).attr("y", node2.y - node2.height / 2 - halfPadding).attr("width", node2.width + padding2).attr("height", node2.height + padding2).attr("fill", "none"); + const rectBox = rect2.node().getBBox(); + node2.width = rectBox.width; + node2.height = rectBox.height; + node2.intersect = function(point2) { + return intersectRect$1(node2, point2); + }; + return shapeSvg; + }; + const roundedWithTitle = (parent, node2) => { + const siteConfig2 = getConfig$1(); + const shapeSvg = parent.insert("g").attr("class", node2.classes).attr("id", node2.id); + const rect2 = shapeSvg.insert("rect", ":first-child"); + const label = shapeSvg.insert("g").attr("class", "cluster-label"); + const innerRect = shapeSvg.append("rect"); + const text2 = label.node().appendChild(createLabel$1(node2.labelText, node2.labelStyle, void 0, true)); + let bbox = text2.getBBox(); + if (evaluate(siteConfig2.flowchart.htmlLabels)) { + const div = text2.children[0]; + const dv = d3select(text2); + bbox = div.getBoundingClientRect(); + dv.attr("width", bbox.width); + dv.attr("height", bbox.height); + } + bbox = text2.getBBox(); + const padding2 = 0 * node2.padding; + const halfPadding = padding2 / 2; + const width2 = node2.width <= bbox.width + node2.padding ? bbox.width + node2.padding : node2.width; + if (node2.width <= bbox.width + node2.padding) { + node2.diff = (bbox.width + node2.padding * 0 - node2.width) / 2; + } else { + node2.diff = -node2.padding / 2; + } + rect2.attr("class", "outer").attr("x", node2.x - width2 / 2 - halfPadding).attr("y", node2.y - node2.height / 2 - halfPadding).attr("width", width2 + padding2).attr("height", node2.height + padding2); + innerRect.attr("class", "inner").attr("x", node2.x - width2 / 2 - halfPadding).attr("y", node2.y - node2.height / 2 - halfPadding + bbox.height - 1).attr("width", width2 + padding2).attr("height", node2.height + padding2 - bbox.height - 3); + const { subGraphTitleTopMargin } = getSubGraphTitleMargins(siteConfig2); + label.attr( + "transform", + `translate(${node2.x - bbox.width / 2}, ${node2.y - node2.height / 2 - node2.padding / 3 + (evaluate(siteConfig2.flowchart.htmlLabels) ? 5 : 3) + subGraphTitleTopMargin})` + ); + const rectBox = rect2.node().getBBox(); + node2.height = rectBox.height; + node2.intersect = function(point2) { + return intersectRect$1(node2, point2); + }; + return shapeSvg; + }; + const divider = (parent, node2) => { + const shapeSvg = parent.insert("g").attr("class", node2.classes).attr("id", node2.id); + const rect2 = shapeSvg.insert("rect", ":first-child"); + const padding2 = 0 * node2.padding; + const halfPadding = padding2 / 2; + rect2.attr("class", "divider").attr("x", node2.x - node2.width / 2 - halfPadding).attr("y", node2.y - node2.height / 2).attr("width", node2.width + padding2).attr("height", node2.height + padding2); + const rectBox = rect2.node().getBBox(); + node2.width = rectBox.width; + node2.height = rectBox.height; + node2.diff = -node2.padding / 2; + node2.intersect = function(point2) { + return intersectRect$1(node2, point2); + }; + return shapeSvg; + }; + const shapes = { rect, roundedWithTitle, noteGroup, divider }; + let clusterElems = {}; + const insertCluster = (elem, node2) => { + log$1.trace("Inserting cluster"); + const shape = node2.shape || "rect"; + clusterElems[node2.id] = shapes[shape](elem, node2); + }; + const clear$i = () => { + clusterElems = {}; + }; + const markerOffsets = { + aggregation: 18, + extension: 18, + composition: 18, + dependency: 6, + lollipop: 13.5, + arrow_point: 5.3 + }; + function calculateDeltaAndAngle(point1, point2) { + if (point1 === void 0 || point2 === void 0) { + return { angle: 0, deltaX: 0, deltaY: 0 }; + } + point1 = pointTransformer(point1); + point2 = pointTransformer(point2); + const [x1, y1] = [point1.x, point1.y]; + const [x2, y2] = [point2.x, point2.y]; + const deltaX = x2 - x1; + const deltaY = y2 - y1; + return { angle: Math.atan(deltaY / deltaX), deltaX, deltaY }; + } + const pointTransformer = (data) => { + if (Array.isArray(data)) { + return { x: data[0], y: data[1] }; + } + return data; + }; + const getLineFunctionsWithOffset = (edge) => { + return { + x: function(d, i2, data) { + let offset = 0; + if (i2 === 0 && Object.hasOwn(markerOffsets, edge.arrowTypeStart)) { + const { angle, deltaX } = calculateDeltaAndAngle(data[0], data[1]); + offset = markerOffsets[edge.arrowTypeStart] * Math.cos(angle) * (deltaX >= 0 ? 1 : -1); + } else if (i2 === data.length - 1 && Object.hasOwn(markerOffsets, edge.arrowTypeEnd)) { + const { angle, deltaX } = calculateDeltaAndAngle( + data[data.length - 1], + data[data.length - 2] + ); + offset = markerOffsets[edge.arrowTypeEnd] * Math.cos(angle) * (deltaX >= 0 ? 1 : -1); + } + return pointTransformer(d).x + offset; + }, + y: function(d, i2, data) { + let offset = 0; + if (i2 === 0 && Object.hasOwn(markerOffsets, edge.arrowTypeStart)) { + const { angle, deltaY } = calculateDeltaAndAngle(data[0], data[1]); + offset = markerOffsets[edge.arrowTypeStart] * Math.abs(Math.sin(angle)) * (deltaY >= 0 ? 1 : -1); + } else if (i2 === data.length - 1 && Object.hasOwn(markerOffsets, edge.arrowTypeEnd)) { + const { angle, deltaY } = calculateDeltaAndAngle( + data[data.length - 1], + data[data.length - 2] + ); + offset = markerOffsets[edge.arrowTypeEnd] * Math.abs(Math.sin(angle)) * (deltaY >= 0 ? 1 : -1); + } + return pointTransformer(d).y + offset; + } + }; + }; + const addEdgeMarkers = (svgPath, edge, url, id2, diagramType) => { + if (edge.arrowTypeStart) { + addEdgeMarker(svgPath, "start", edge.arrowTypeStart, url, id2, diagramType); + } + if (edge.arrowTypeEnd) { + addEdgeMarker(svgPath, "end", edge.arrowTypeEnd, url, id2, diagramType); + } + }; + const arrowTypesMap = { + arrow_cross: "cross", + arrow_point: "point", + arrow_barb: "barb", + arrow_circle: "circle", + aggregation: "aggregation", + extension: "extension", + composition: "composition", + dependency: "dependency", + lollipop: "lollipop" + }; + const addEdgeMarker = (svgPath, position2, arrowType, url, id2, diagramType) => { + const endMarkerType = arrowTypesMap[arrowType]; + if (!endMarkerType) { + log$1.warn(`Unknown arrow type: ${arrowType}`); + return; + } + const suffix = position2 === "start" ? "Start" : "End"; + svgPath.attr(`marker-${position2}`, `url(${url}#${id2}_${diagramType}-${endMarkerType}${suffix})`); + }; + let edgeLabels = {}; + let terminalLabels = {}; + const clear$h = () => { + edgeLabels = {}; + terminalLabels = {}; + }; + const insertEdgeLabel = (elem, edge) => { + const useHtmlLabels = evaluate(getConfig$1().flowchart.htmlLabels); + const labelElement = edge.labelType === "markdown" ? createText(elem, edge.label, { + style: edge.labelStyle, + useHtmlLabels, + addSvgBackground: true + }) : createLabel$1(edge.label, edge.labelStyle); + const edgeLabel = elem.insert("g").attr("class", "edgeLabel"); + const label = edgeLabel.insert("g").attr("class", "label"); + label.node().appendChild(labelElement); + let bbox = labelElement.getBBox(); + if (useHtmlLabels) { + const div = labelElement.children[0]; + const dv = d3select(labelElement); + bbox = div.getBoundingClientRect(); + dv.attr("width", bbox.width); + dv.attr("height", bbox.height); + } + label.attr("transform", "translate(" + -bbox.width / 2 + ", " + -bbox.height / 2 + ")"); + edgeLabels[edge.id] = edgeLabel; + edge.width = bbox.width; + edge.height = bbox.height; + let fo; + if (edge.startLabelLeft) { + const startLabelElement = createLabel$1(edge.startLabelLeft, edge.labelStyle); + const startEdgeLabelLeft = elem.insert("g").attr("class", "edgeTerminals"); + const inner2 = startEdgeLabelLeft.insert("g").attr("class", "inner"); + fo = inner2.node().appendChild(startLabelElement); + const slBox = startLabelElement.getBBox(); + inner2.attr("transform", "translate(" + -slBox.width / 2 + ", " + -slBox.height / 2 + ")"); + if (!terminalLabels[edge.id]) { + terminalLabels[edge.id] = {}; + } + terminalLabels[edge.id].startLeft = startEdgeLabelLeft; + setTerminalWidth(fo, edge.startLabelLeft); + } + if (edge.startLabelRight) { + const startLabelElement = createLabel$1(edge.startLabelRight, edge.labelStyle); + const startEdgeLabelRight = elem.insert("g").attr("class", "edgeTerminals"); + const inner2 = startEdgeLabelRight.insert("g").attr("class", "inner"); + fo = startEdgeLabelRight.node().appendChild(startLabelElement); + inner2.node().appendChild(startLabelElement); + const slBox = startLabelElement.getBBox(); + inner2.attr("transform", "translate(" + -slBox.width / 2 + ", " + -slBox.height / 2 + ")"); + if (!terminalLabels[edge.id]) { + terminalLabels[edge.id] = {}; + } + terminalLabels[edge.id].startRight = startEdgeLabelRight; + setTerminalWidth(fo, edge.startLabelRight); + } + if (edge.endLabelLeft) { + const endLabelElement = createLabel$1(edge.endLabelLeft, edge.labelStyle); + const endEdgeLabelLeft = elem.insert("g").attr("class", "edgeTerminals"); + const inner2 = endEdgeLabelLeft.insert("g").attr("class", "inner"); + fo = inner2.node().appendChild(endLabelElement); + const slBox = endLabelElement.getBBox(); + inner2.attr("transform", "translate(" + -slBox.width / 2 + ", " + -slBox.height / 2 + ")"); + endEdgeLabelLeft.node().appendChild(endLabelElement); + if (!terminalLabels[edge.id]) { + terminalLabels[edge.id] = {}; + } + terminalLabels[edge.id].endLeft = endEdgeLabelLeft; + setTerminalWidth(fo, edge.endLabelLeft); + } + if (edge.endLabelRight) { + const endLabelElement = createLabel$1(edge.endLabelRight, edge.labelStyle); + const endEdgeLabelRight = elem.insert("g").attr("class", "edgeTerminals"); + const inner2 = endEdgeLabelRight.insert("g").attr("class", "inner"); + fo = inner2.node().appendChild(endLabelElement); + const slBox = endLabelElement.getBBox(); + inner2.attr("transform", "translate(" + -slBox.width / 2 + ", " + -slBox.height / 2 + ")"); + endEdgeLabelRight.node().appendChild(endLabelElement); + if (!terminalLabels[edge.id]) { + terminalLabels[edge.id] = {}; + } + terminalLabels[edge.id].endRight = endEdgeLabelRight; + setTerminalWidth(fo, edge.endLabelRight); + } + return labelElement; + }; + function setTerminalWidth(fo, value2) { + if (getConfig$1().flowchart.htmlLabels && fo) { + fo.style.width = value2.length * 9 + "px"; + fo.style.height = "12px"; + } + } + const positionEdgeLabel = (edge, paths) => { + log$1.debug("Moving label abc88 ", edge.id, edge.label, edgeLabels[edge.id], paths); + let path2 = paths.updatedPath ? paths.updatedPath : paths.originalPath; + const siteConfig2 = getConfig$1(); + const { subGraphTitleTotalMargin } = getSubGraphTitleMargins(siteConfig2); + if (edge.label) { + const el = edgeLabels[edge.id]; + let x2 = edge.x; + let y2 = edge.y; + if (path2) { + const pos = utils$1.calcLabelPosition(path2); + log$1.debug( + "Moving label " + edge.label + " from (", + x2, + ",", + y2, + ") to (", + pos.x, + ",", + pos.y, + ") abc88" + ); + if (paths.updatedPath) { + x2 = pos.x; + y2 = pos.y; + } + } + el.attr("transform", `translate(${x2}, ${y2 + subGraphTitleTotalMargin / 2})`); + } + if (edge.startLabelLeft) { + const el = terminalLabels[edge.id].startLeft; + let x2 = edge.x; + let y2 = edge.y; + if (path2) { + const pos = utils$1.calcTerminalLabelPosition(edge.arrowTypeStart ? 10 : 0, "start_left", path2); + x2 = pos.x; + y2 = pos.y; + } + el.attr("transform", `translate(${x2}, ${y2})`); + } + if (edge.startLabelRight) { + const el = terminalLabels[edge.id].startRight; + let x2 = edge.x; + let y2 = edge.y; + if (path2) { + const pos = utils$1.calcTerminalLabelPosition( + edge.arrowTypeStart ? 10 : 0, + "start_right", + path2 + ); + x2 = pos.x; + y2 = pos.y; + } + el.attr("transform", `translate(${x2}, ${y2})`); + } + if (edge.endLabelLeft) { + const el = terminalLabels[edge.id].endLeft; + let x2 = edge.x; + let y2 = edge.y; + if (path2) { + const pos = utils$1.calcTerminalLabelPosition(edge.arrowTypeEnd ? 10 : 0, "end_left", path2); + x2 = pos.x; + y2 = pos.y; + } + el.attr("transform", `translate(${x2}, ${y2})`); + } + if (edge.endLabelRight) { + const el = terminalLabels[edge.id].endRight; + let x2 = edge.x; + let y2 = edge.y; + if (path2) { + const pos = utils$1.calcTerminalLabelPosition(edge.arrowTypeEnd ? 10 : 0, "end_right", path2); + x2 = pos.x; + y2 = pos.y; + } + el.attr("transform", `translate(${x2}, ${y2})`); + } + }; + const outsideNode = (node2, point2) => { + const x2 = node2.x; + const y2 = node2.y; + const dx = Math.abs(point2.x - x2); + const dy = Math.abs(point2.y - y2); + const w2 = node2.width / 2; + const h = node2.height / 2; + if (dx >= w2 || dy >= h) { + return true; + } + return false; + }; + const intersection = (node2, outsidePoint, insidePoint) => { + log$1.debug(`intersection calc abc89: + outsidePoint: ${JSON.stringify(outsidePoint)} + insidePoint : ${JSON.stringify(insidePoint)} + node : x:${node2.x} y:${node2.y} w:${node2.width} h:${node2.height}`); + const x2 = node2.x; + const y2 = node2.y; + const dx = Math.abs(x2 - insidePoint.x); + const w2 = node2.width / 2; + let r = insidePoint.x < outsidePoint.x ? w2 - dx : w2 + dx; + const h = node2.height / 2; + const Q = Math.abs(outsidePoint.y - insidePoint.y); + const R = Math.abs(outsidePoint.x - insidePoint.x); + if (Math.abs(y2 - outsidePoint.y) * w2 > Math.abs(x2 - outsidePoint.x) * h) { + let q = insidePoint.y < outsidePoint.y ? outsidePoint.y - h - y2 : y2 - h - outsidePoint.y; + r = R * q / Q; + const res = { + x: insidePoint.x < outsidePoint.x ? insidePoint.x + r : insidePoint.x - R + r, + y: insidePoint.y < outsidePoint.y ? insidePoint.y + Q - q : insidePoint.y - Q + q + }; + if (r === 0) { + res.x = outsidePoint.x; + res.y = outsidePoint.y; + } + if (R === 0) { + res.x = outsidePoint.x; + } + if (Q === 0) { + res.y = outsidePoint.y; + } + log$1.debug(`abc89 topp/bott calc, Q ${Q}, q ${q}, R ${R}, r ${r}`, res); + return res; + } else { + if (insidePoint.x < outsidePoint.x) { + r = outsidePoint.x - w2 - x2; + } else { + r = x2 - w2 - outsidePoint.x; + } + let q = Q * r / R; + let _x = insidePoint.x < outsidePoint.x ? insidePoint.x + R - r : insidePoint.x - R + r; + let _y = insidePoint.y < outsidePoint.y ? insidePoint.y + q : insidePoint.y - q; + log$1.debug(`sides calc abc89, Q ${Q}, q ${q}, R ${R}, r ${r}`, { _x, _y }); + if (r === 0) { + _x = outsidePoint.x; + _y = outsidePoint.y; + } + if (R === 0) { + _x = outsidePoint.x; + } + if (Q === 0) { + _y = outsidePoint.y; + } + return { x: _x, y: _y }; + } + }; + const cutPathAtIntersect = (_points, boundaryNode) => { + log$1.debug("abc88 cutPathAtIntersect", _points, boundaryNode); + let points = []; + let lastPointOutside = _points[0]; + let isInside = false; + _points.forEach((point2) => { + if (!outsideNode(boundaryNode, point2) && !isInside) { + const inter = intersection(boundaryNode, lastPointOutside, point2); + let pointPresent = false; + points.forEach((p) => { + pointPresent = pointPresent || p.x === inter.x && p.y === inter.y; + }); + if (!points.some((e) => e.x === inter.x && e.y === inter.y)) { + points.push(inter); + } + isInside = true; + } else { + lastPointOutside = point2; + if (!isInside) { + points.push(point2); + } + } + }); + return points; + }; + const insertEdge$1 = function(elem, e, edge, clusterDb2, diagramType, graph, id2) { + let points = edge.points; + log$1.debug("abc88 InsertEdge: edge=", edge, "e=", e); + let pointsHasChanged = false; + const tail = graph.node(e.v); + var head2 = graph.node(e.w); + if ((head2 == null ? void 0 : head2.intersect) && (tail == null ? void 0 : tail.intersect)) { + points = points.slice(1, edge.points.length - 1); + points.unshift(tail.intersect(points[0])); + points.push(head2.intersect(points[points.length - 1])); + } + if (edge.toCluster) { + log$1.debug("to cluster abc88", clusterDb2[edge.toCluster]); + points = cutPathAtIntersect(edge.points, clusterDb2[edge.toCluster].node); + pointsHasChanged = true; + } + if (edge.fromCluster) { + log$1.debug("from cluster abc88", clusterDb2[edge.fromCluster]); + points = cutPathAtIntersect(points.reverse(), clusterDb2[edge.fromCluster].node).reverse(); + pointsHasChanged = true; + } + const lineData = points.filter((p) => !Number.isNaN(p.y)); + let curve = curveBasis; + if (edge.curve && (diagramType === "graph" || diagramType === "flowchart")) { + curve = edge.curve; + } + const { x: x2, y: y2 } = getLineFunctionsWithOffset(edge); + const lineFunction = line$1().x(x2).y(y2).curve(curve); + let strokeClasses; + switch (edge.thickness) { + case "normal": + strokeClasses = "edge-thickness-normal"; + break; + case "thick": + strokeClasses = "edge-thickness-thick"; + break; + case "invisible": + strokeClasses = "edge-thickness-thick"; + break; + default: + strokeClasses = ""; + } + switch (edge.pattern) { + case "solid": + strokeClasses += " edge-pattern-solid"; + break; + case "dotted": + strokeClasses += " edge-pattern-dotted"; + break; + case "dashed": + strokeClasses += " edge-pattern-dashed"; + break; + } + const svgPath = elem.append("path").attr("d", lineFunction(lineData)).attr("id", edge.id).attr("class", " " + strokeClasses + (edge.classes ? " " + edge.classes : "")).attr("style", edge.style); + let url = ""; + if (getConfig$1().flowchart.arrowMarkerAbsolute || getConfig$1().state.arrowMarkerAbsolute) { + url = window.location.protocol + "//" + window.location.host + window.location.pathname + window.location.search; + url = url.replace(/\(/g, "\\("); + url = url.replace(/\)/g, "\\)"); + } + addEdgeMarkers(svgPath, edge, url, id2, diagramType); + let paths = {}; + if (pointsHasChanged) { + paths.updatedPath = points; + } + paths.originalPath = edge.points; + return paths; + }; + const recursiveRender = async (_elem, graph, diagramType, id2, parentCluster, siteConfig2) => { + log$1.info("Graph in recursive render: XXX", write(graph), parentCluster); + const dir2 = graph.graph().rankdir; + log$1.trace("Dir in recursive render - dir:", dir2); + const elem = _elem.insert("g").attr("class", "root"); + if (!graph.nodes()) { + log$1.info("No nodes found for", graph); + } else { + log$1.info("Recursive render XXX", graph.nodes()); + } + if (graph.edges().length > 0) { + log$1.trace("Recursive edges", graph.edge(graph.edges()[0])); + } + const clusters = elem.insert("g").attr("class", "clusters"); + const edgePaths = elem.insert("g").attr("class", "edgePaths"); + const edgeLabels2 = elem.insert("g").attr("class", "edgeLabels"); + const nodes2 = elem.insert("g").attr("class", "nodes"); + await Promise.all( + graph.nodes().map(async function(v) { + const node2 = graph.node(v); + if (parentCluster !== void 0) { + const data = JSON.parse(JSON.stringify(parentCluster.clusterData)); + log$1.info("Setting data for cluster XXX (", v, ") ", data, parentCluster); + graph.setNode(parentCluster.id, data); + if (!graph.parent(v)) { + log$1.trace("Setting parent", v, parentCluster.id); + graph.setParent(v, parentCluster.id, data); + } + } + log$1.info("(Insert) Node XXX" + v + ": " + JSON.stringify(graph.node(v))); + if (node2 && node2.clusterNode) { + log$1.info("Cluster identified", v, node2.width, graph.node(v)); + const o = await recursiveRender( + nodes2, + node2.graph, + diagramType, + id2, + graph.node(v), + siteConfig2 + ); + const newEl = o.elem; + updateNodeBounds(node2, newEl); + node2.diff = o.diff || 0; + log$1.info("Node bounds (abc123)", v, node2, node2.width, node2.x, node2.y); + setNodeElem(newEl, node2); + log$1.warn("Recursive render complete ", newEl, node2); + } else { + if (graph.children(v).length > 0) { + log$1.info("Cluster - the non recursive path XXX", v, node2.id, node2, graph); + log$1.info(findNonClusterChild(node2.id, graph)); + clusterDb[node2.id] = { id: findNonClusterChild(node2.id, graph), node: node2 }; + } else { + log$1.info("Node - the non recursive path", v, node2.id, node2); + await insertNode(nodes2, graph.node(v), dir2); + } + } + }) + ); + graph.edges().forEach(function(e) { + const edge = graph.edge(e.v, e.w, e.name); + log$1.info("Edge " + e.v + " -> " + e.w + ": " + JSON.stringify(e)); + log$1.info("Edge " + e.v + " -> " + e.w + ": ", e, " ", JSON.stringify(graph.edge(e))); + log$1.info("Fix", clusterDb, "ids:", e.v, e.w, "Translating: ", clusterDb[e.v], clusterDb[e.w]); + insertEdgeLabel(edgeLabels2, edge); + }); + graph.edges().forEach(function(e) { + log$1.info("Edge " + e.v + " -> " + e.w + ": " + JSON.stringify(e)); + }); + log$1.info("#############################################"); + log$1.info("### Layout ###"); + log$1.info("#############################################"); + log$1.info(graph); + layout$1(graph); + log$1.info("Graph after layout:", write(graph)); + let diff = 0; + const { subGraphTitleTotalMargin } = getSubGraphTitleMargins(siteConfig2); + sortNodesByHierarchy(graph).forEach(function(v) { + const node2 = graph.node(v); + log$1.info("Position " + v + ": " + JSON.stringify(graph.node(v))); + log$1.info( + "Position " + v + ": (" + node2.x, + "," + node2.y, + ") width: ", + node2.width, + " height: ", + node2.height + ); + if (node2 && node2.clusterNode) { + node2.y += subGraphTitleTotalMargin; + positionNode$1(node2); + } else { + if (graph.children(v).length > 0) { + node2.height += subGraphTitleTotalMargin; + insertCluster(clusters, node2); + clusterDb[node2.id].node = node2; + } else { + node2.y += subGraphTitleTotalMargin / 2; + positionNode$1(node2); + } + } + }); + graph.edges().forEach(function(e) { + const edge = graph.edge(e); + log$1.info("Edge " + e.v + " -> " + e.w + ": " + JSON.stringify(edge), edge); + edge.points.forEach((point2) => point2.y += subGraphTitleTotalMargin / 2); + const paths = insertEdge$1(edgePaths, e, edge, clusterDb, diagramType, graph, id2); + positionEdgeLabel(edge, paths); + }); + graph.nodes().forEach(function(v) { + const n = graph.node(v); + log$1.info(v, n.type, n.diff); + if (n.type === "group") { + diff = n.diff; + } + }); + return { elem, diff }; + }; + const render = async (elem, graph, markers2, diagramType, id2) => { + insertMarkers$4(elem, markers2, diagramType, id2); + clear$j(); + clear$h(); + clear$i(); + clear$k(); + log$1.warn("Graph at first:", JSON.stringify(write(graph))); + adjustClustersAndEdges(graph); + log$1.warn("Graph after:", JSON.stringify(write(graph))); + const siteConfig2 = getConfig$1(); + await recursiveRender(elem, graph, diagramType, id2, void 0, siteConfig2); + }; + const conf$7 = {}; + const setConf$7 = function(cnf) { + const keys2 = Object.keys(cnf); + for (const key of keys2) { + conf$7[key] = cnf[key]; + } + }; + const addVertices$1 = async function(vert, g, svgId, root2, doc, diagObj) { + const svg2 = root2.select(`[id="${svgId}"]`); + const keys2 = Object.keys(vert); + for (const id2 of keys2) { + const vertex = vert[id2]; + let classStr = "default"; + if (vertex.classes.length > 0) { + classStr = vertex.classes.join(" "); + } + classStr = classStr + " flowchart-label"; + const styles2 = getStylesFromArray(vertex.styles); + let vertexText = vertex.text !== void 0 ? vertex.text : vertex.id; + let vertexNode; + log$1.info("vertex", vertex, vertex.labelType); + if (vertex.labelType === "markdown") { + log$1.info("vertex", vertex, vertex.labelType); + } else { + if (evaluate(getConfig$1().flowchart.htmlLabels)) { + const node2 = { + label: vertexText + }; + vertexNode = addHtmlLabel$1(svg2, node2).node(); + vertexNode.parentNode.removeChild(vertexNode); + } else { + const svgLabel = doc.createElementNS("http://www.w3.org/2000/svg", "text"); + svgLabel.setAttribute("style", styles2.labelStyle.replace("color:", "fill:")); + const rows = vertexText.split(common$1.lineBreakRegex); + for (const row of rows) { + const tspan = doc.createElementNS("http://www.w3.org/2000/svg", "tspan"); + tspan.setAttributeNS("http://www.w3.org/XML/1998/namespace", "xml:space", "preserve"); + tspan.setAttribute("dy", "1em"); + tspan.setAttribute("x", "1"); + tspan.textContent = row; + svgLabel.appendChild(tspan); + } + vertexNode = svgLabel; + } + } + let radius = 0; + let _shape = ""; + switch (vertex.type) { + case "round": + radius = 5; + _shape = "rect"; + break; + case "square": + _shape = "rect"; + break; + case "diamond": + _shape = "question"; + break; + case "hexagon": + _shape = "hexagon"; + break; + case "odd": + _shape = "rect_left_inv_arrow"; + break; + case "lean_right": + _shape = "lean_right"; + break; + case "lean_left": + _shape = "lean_left"; + break; + case "trapezoid": + _shape = "trapezoid"; + break; + case "inv_trapezoid": + _shape = "inv_trapezoid"; + break; + case "odd_right": + _shape = "rect_left_inv_arrow"; + break; + case "circle": + _shape = "circle"; + break; + case "ellipse": + _shape = "ellipse"; + break; + case "stadium": + _shape = "stadium"; + break; + case "subroutine": + _shape = "subroutine"; + break; + case "cylinder": + _shape = "cylinder"; + break; + case "group": + _shape = "rect"; + break; + case "doublecircle": + _shape = "doublecircle"; + break; + default: + _shape = "rect"; + } + const labelText = await renderKatex(vertexText, getConfig$1()); + g.setNode(vertex.id, { + labelStyle: styles2.labelStyle, + shape: _shape, + labelText, + labelType: vertex.labelType, + rx: radius, + ry: radius, + class: classStr, + style: styles2.style, + id: vertex.id, + link: vertex.link, + linkTarget: vertex.linkTarget, + tooltip: diagObj.db.getTooltip(vertex.id) || "", + domId: diagObj.db.lookUpDomId(vertex.id), + haveCallback: vertex.haveCallback, + width: vertex.type === "group" ? 500 : void 0, + dir: vertex.dir, + type: vertex.type, + props: vertex.props, + padding: getConfig$1().flowchart.padding + }); + log$1.info("setNode", { + labelStyle: styles2.labelStyle, + labelType: vertex.labelType, + shape: _shape, + labelText, + rx: radius, + ry: radius, + class: classStr, + style: styles2.style, + id: vertex.id, + domId: diagObj.db.lookUpDomId(vertex.id), + width: vertex.type === "group" ? 500 : void 0, + type: vertex.type, + dir: vertex.dir, + props: vertex.props, + padding: getConfig$1().flowchart.padding + }); + } + }; + const addEdges$1 = async function(edges2, g, diagObj) { + log$1.info("abc78 edges = ", edges2); + let cnt2 = 0; + let linkIdCnt = {}; + let defaultStyle2; + let defaultLabelStyle; + if (edges2.defaultStyle !== void 0) { + const defaultStyles = getStylesFromArray(edges2.defaultStyle); + defaultStyle2 = defaultStyles.style; + defaultLabelStyle = defaultStyles.labelStyle; + } + for (const edge of edges2) { + cnt2++; + const linkIdBase = "L-" + edge.start + "-" + edge.end; + if (linkIdCnt[linkIdBase] === void 0) { + linkIdCnt[linkIdBase] = 0; + log$1.info("abc78 new entry", linkIdBase, linkIdCnt[linkIdBase]); + } else { + linkIdCnt[linkIdBase]++; + log$1.info("abc78 new entry", linkIdBase, linkIdCnt[linkIdBase]); + } + let linkId = linkIdBase + "-" + linkIdCnt[linkIdBase]; + log$1.info("abc78 new link id to be used is", linkIdBase, linkId, linkIdCnt[linkIdBase]); + const linkNameStart = "LS-" + edge.start; + const linkNameEnd = "LE-" + edge.end; + const edgeData = { style: "", labelStyle: "" }; + edgeData.minlen = edge.length || 1; + if (edge.type === "arrow_open") { + edgeData.arrowhead = "none"; + } else { + edgeData.arrowhead = "normal"; + } + edgeData.arrowTypeStart = "arrow_open"; + edgeData.arrowTypeEnd = "arrow_open"; + switch (edge.type) { + case "double_arrow_cross": + edgeData.arrowTypeStart = "arrow_cross"; + case "arrow_cross": + edgeData.arrowTypeEnd = "arrow_cross"; + break; + case "double_arrow_point": + edgeData.arrowTypeStart = "arrow_point"; + case "arrow_point": + edgeData.arrowTypeEnd = "arrow_point"; + break; + case "double_arrow_circle": + edgeData.arrowTypeStart = "arrow_circle"; + case "arrow_circle": + edgeData.arrowTypeEnd = "arrow_circle"; + break; + } + let style = ""; + let labelStyle = ""; + switch (edge.stroke) { + case "normal": + style = "fill:none;"; + if (defaultStyle2 !== void 0) { + style = defaultStyle2; + } + if (defaultLabelStyle !== void 0) { + labelStyle = defaultLabelStyle; + } + edgeData.thickness = "normal"; + edgeData.pattern = "solid"; + break; + case "dotted": + edgeData.thickness = "normal"; + edgeData.pattern = "dotted"; + edgeData.style = "fill:none;stroke-width:2px;stroke-dasharray:3;"; + break; + case "thick": + edgeData.thickness = "thick"; + edgeData.pattern = "solid"; + edgeData.style = "stroke-width: 3.5px;fill:none;"; + break; + case "invisible": + edgeData.thickness = "invisible"; + edgeData.pattern = "solid"; + edgeData.style = "stroke-width: 0;fill:none;"; + break; + } + if (edge.style !== void 0) { + const styles2 = getStylesFromArray(edge.style); + style = styles2.style; + labelStyle = styles2.labelStyle; + } + edgeData.style = edgeData.style += style; + edgeData.labelStyle = edgeData.labelStyle += labelStyle; + if (edge.interpolate !== void 0) { + edgeData.curve = interpolateToCurve(edge.interpolate, curveLinear); + } else if (edges2.defaultInterpolate !== void 0) { + edgeData.curve = interpolateToCurve(edges2.defaultInterpolate, curveLinear); + } else { + edgeData.curve = interpolateToCurve(conf$7.curve, curveLinear); + } + if (edge.text === void 0) { + if (edge.style !== void 0) { + edgeData.arrowheadStyle = "fill: #333"; + } + } else { + edgeData.arrowheadStyle = "fill: #333"; + edgeData.labelpos = "c"; + } + edgeData.labelType = edge.labelType; + edgeData.label = await renderKatex(edge.text.replace(common$1.lineBreakRegex, "\n"), getConfig$1()); + if (edge.style === void 0) { + edgeData.style = edgeData.style || "stroke: #333; stroke-width: 1.5px;fill:none;"; + } + edgeData.labelStyle = edgeData.labelStyle.replace("color:", "fill:"); + edgeData.id = linkId; + edgeData.classes = "flowchart-link " + linkNameStart + " " + linkNameEnd; + g.setEdge(edge.start, edge.end, edgeData, cnt2); + } + }; + const getClasses$6 = function(text2, diagObj) { + return diagObj.db.getClasses(); + }; + const draw$j = async function(text2, id2, _version, diagObj) { + log$1.info("Drawing flowchart"); + let dir2 = diagObj.db.getDirection(); + if (dir2 === void 0) { + dir2 = "TD"; + } + const { securityLevel, flowchart: conf2 } = getConfig$1(); + const nodeSpacing = conf2.nodeSpacing || 50; + const rankSpacing = conf2.rankSpacing || 50; + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = d3select("#i" + id2); + } + const root2 = securityLevel === "sandbox" ? d3select(sandboxElement.nodes()[0].contentDocument.body) : d3select("body"); + const doc = securityLevel === "sandbox" ? sandboxElement.nodes()[0].contentDocument : document; + const g = new Graph({ + multigraph: true, + compound: true + }).setGraph({ + rankdir: dir2, + nodesep: nodeSpacing, + ranksep: rankSpacing, + marginx: 0, + marginy: 0 + }).setDefaultEdgeLabel(function() { + return {}; + }); + let subG; + const subGraphs2 = diagObj.db.getSubGraphs(); + log$1.info("Subgraphs - ", subGraphs2); + for (let i3 = subGraphs2.length - 1; i3 >= 0; i3--) { + subG = subGraphs2[i3]; + log$1.info("Subgraph - ", subG); + diagObj.db.addVertex( + subG.id, + { text: subG.title, type: subG.labelType }, + "group", + void 0, + subG.classes, + subG.dir + ); + } + const vert = diagObj.db.getVertices(); + const edges2 = diagObj.db.getEdges(); + log$1.info("Edges", edges2); + let i2 = 0; + for (i2 = subGraphs2.length - 1; i2 >= 0; i2--) { + subG = subGraphs2[i2]; + selectAll("cluster").append("text"); + for (let j = 0; j < subG.nodes.length; j++) { + log$1.info("Setting up subgraphs", subG.nodes[j], subG.id); + g.setParent(subG.nodes[j], subG.id); + } + } + await addVertices$1(vert, g, id2, root2, doc, diagObj); + await addEdges$1(edges2, g); + const svg2 = root2.select(`[id="${id2}"]`); + const element2 = root2.select("#" + id2 + " g"); + await render(element2, g, ["point", "circle", "cross"], "flowchart", id2); + utils$1.insertTitle(svg2, "flowchartTitleText", conf2.titleTopMargin, diagObj.db.getDiagramTitle()); + setupGraphViewbox$1(g, svg2, conf2.diagramPadding, conf2.useMaxWidth); + diagObj.db.indexNodes("subGraph" + i2); + if (!conf2.htmlLabels) { + const labels = doc.querySelectorAll('[id="' + id2 + '"] .edgeLabel .label'); + for (const label of labels) { + const dim = label.getBBox(); + const rect2 = doc.createElementNS("http://www.w3.org/2000/svg", "rect"); + rect2.setAttribute("rx", 0); + rect2.setAttribute("ry", 0); + rect2.setAttribute("width", dim.width); + rect2.setAttribute("height", dim.height); + label.insertBefore(rect2, label.firstChild); + } + } + const keys2 = Object.keys(vert); + keys2.forEach(function(key) { + const vertex = vert[key]; + if (vertex.link) { + const node2 = d3select("#" + id2 + ' [id="' + key + '"]'); + if (node2) { + const link2 = doc.createElementNS("http://www.w3.org/2000/svg", "a"); + link2.setAttributeNS("http://www.w3.org/2000/svg", "class", vertex.classes.join(" ")); + link2.setAttributeNS("http://www.w3.org/2000/svg", "href", vertex.link); + link2.setAttributeNS("http://www.w3.org/2000/svg", "rel", "noopener"); + if (securityLevel === "sandbox") { + link2.setAttributeNS("http://www.w3.org/2000/svg", "target", "_top"); + } else if (vertex.linkTarget) { + link2.setAttributeNS("http://www.w3.org/2000/svg", "target", vertex.linkTarget); + } + const linkNode = node2.insert(function() { + return link2; + }, ":first-child"); + const shape = node2.select(".label-container"); + if (shape) { + linkNode.append(function() { + return shape.node(); + }); + } + const label = node2.select(".label"); + if (label) { + linkNode.append(function() { + return label.node(); + }); + } + } + } + }); + }; + const flowRendererV2 = { + setConf: setConf$7, + addVertices: addVertices$1, + addEdges: addEdges$1, + getClasses: getClasses$6, + draw: draw$j + }; + const fade$1 = (color2, opacity) => { + const channel2 = channel$1; + const r = channel2(color2, "r"); + const g = channel2(color2, "g"); + const b = channel2(color2, "b"); + return rgba$1(r, g, b, opacity); + }; + const getStyles$d = (options2) => `.label { + font-family: ${options2.fontFamily}; + color: ${options2.nodeTextColor || options2.textColor}; + } + .cluster-label text { + fill: ${options2.titleColor}; + } + .cluster-label span,p { + color: ${options2.titleColor}; + } + + .label text,span,p { + fill: ${options2.nodeTextColor || options2.textColor}; + color: ${options2.nodeTextColor || options2.textColor}; + } + + .node rect, + .node circle, + .node ellipse, + .node polygon, + .node path { + fill: ${options2.mainBkg}; + stroke: ${options2.nodeBorder}; + stroke-width: 1px; + } + .flowchart-label text { + text-anchor: middle; + } + // .flowchart-label .text-outer-tspan { + // text-anchor: middle; + // } + // .flowchart-label .text-inner-tspan { + // text-anchor: start; + // } + + .node .katex path { + fill: #000; + stroke: #000; + stroke-width: 1px; + } + + .node .label { + text-align: center; + } + .node.clickable { + cursor: pointer; + } + + .arrowheadPath { + fill: ${options2.arrowheadColor}; + } + + .edgePath .path { + stroke: ${options2.lineColor}; + stroke-width: 2.0px; + } + + .flowchart-link { + stroke: ${options2.lineColor}; + fill: none; + } + + .edgeLabel { + background-color: ${options2.edgeLabelBackground}; + rect { + opacity: 0.5; + background-color: ${options2.edgeLabelBackground}; + fill: ${options2.edgeLabelBackground}; + } + text-align: center; + } + + /* For html labels only */ + .labelBkg { + background-color: ${fade$1(options2.edgeLabelBackground, 0.5)}; + // background-color: + } + + .cluster rect { + fill: ${options2.clusterBkg}; + stroke: ${options2.clusterBorder}; + stroke-width: 1px; + } + + .cluster text { + fill: ${options2.titleColor}; + } + + .cluster span,p { + color: ${options2.titleColor}; + } + /* .cluster div { + color: ${options2.titleColor}; + } */ + + div.mermaidTooltip { + position: absolute; + text-align: center; + max-width: 200px; + padding: 2px; + font-family: ${options2.fontFamily}; + font-size: 12px; + background: ${options2.tertiaryColor}; + border: 1px solid ${options2.border2}; + border-radius: 2px; + pointer-events: none; + z-index: 100; + } + + .flowchartTitleText { + text-anchor: middle; + font-size: 18px; + fill: ${options2.textColor}; + } +`; + const flowStyles$1 = getStyles$d; + const diagram$k = { + parser: parser$u, + db: flowDb, + renderer: flowRendererV2, + styles: flowStyles$1, + init: (cnf) => { + if (!cnf.flowchart) { + cnf.flowchart = {}; + } + cnf.flowchart.arrowMarkerAbsolute = cnf.arrowMarkerAbsolute; + flowRenderer.setConf(cnf.flowchart); + flowDb.clear(); + flowDb.setGen("gen-1"); + } + }; + const flowDiagram = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + diagram: diagram$k + }, Symbol.toStringTag, { value: "Module" })); + const diagram$j = { + parser: parser$u, + db: flowDb, + renderer: flowRendererV2, + styles: flowStyles$1, + init: (cnf) => { + if (!cnf.flowchart) { + cnf.flowchart = {}; + } + cnf.flowchart.arrowMarkerAbsolute = cnf.arrowMarkerAbsolute; + setConfig({ flowchart: { arrowMarkerAbsolute: cnf.arrowMarkerAbsolute } }); + flowRendererV2.setConf(cnf.flowchart); + flowDb.clear(); + flowDb.setGen("gen-2"); + } + }; + const flowDiagramV2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + diagram: diagram$j + }, Symbol.toStringTag, { value: "Module" })); + var parser$s = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [6, 8, 10, 20, 22, 24, 26, 27, 28], $V1 = [1, 10], $V2 = [1, 11], $V3 = [1, 12], $V4 = [1, 13], $V5 = [1, 14], $V6 = [1, 15], $V7 = [1, 21], $V8 = [1, 22], $V9 = [1, 23], $Va = [1, 24], $Vb = [1, 25], $Vc = [6, 8, 10, 13, 15, 18, 19, 20, 22, 24, 26, 27, 28, 41, 42, 43, 44, 45], $Vd = [1, 34], $Ve = [27, 28, 46, 47], $Vf = [41, 42, 43, 44, 45], $Vg = [17, 34], $Vh = [1, 54], $Vi = [1, 53], $Vj = [17, 34, 36, 38]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "ER_DIAGRAM": 4, "document": 5, "EOF": 6, "line": 7, "SPACE": 8, "statement": 9, "NEWLINE": 10, "entityName": 11, "relSpec": 12, ":": 13, "role": 14, "BLOCK_START": 15, "attributes": 16, "BLOCK_STOP": 17, "SQS": 18, "SQE": 19, "title": 20, "title_value": 21, "acc_title": 22, "acc_title_value": 23, "acc_descr": 24, "acc_descr_value": 25, "acc_descr_multiline_value": 26, "ALPHANUM": 27, "ENTITY_NAME": 28, "attribute": 29, "attributeType": 30, "attributeName": 31, "attributeKeyTypeList": 32, "attributeComment": 33, "ATTRIBUTE_WORD": 34, "attributeKeyType": 35, "COMMA": 36, "ATTRIBUTE_KEY": 37, "COMMENT": 38, "cardinality": 39, "relType": 40, "ZERO_OR_ONE": 41, "ZERO_OR_MORE": 42, "ONE_OR_MORE": 43, "ONLY_ONE": 44, "MD_PARENT": 45, "NON_IDENTIFYING": 46, "IDENTIFYING": 47, "WORD": 48, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 4: "ER_DIAGRAM", 6: "EOF", 8: "SPACE", 10: "NEWLINE", 13: ":", 15: "BLOCK_START", 17: "BLOCK_STOP", 18: "SQS", 19: "SQE", 20: "title", 21: "title_value", 22: "acc_title", 23: "acc_title_value", 24: "acc_descr", 25: "acc_descr_value", 26: "acc_descr_multiline_value", 27: "ALPHANUM", 28: "ENTITY_NAME", 34: "ATTRIBUTE_WORD", 36: "COMMA", 37: "ATTRIBUTE_KEY", 38: "COMMENT", 41: "ZERO_OR_ONE", 42: "ZERO_OR_MORE", 43: "ONE_OR_MORE", 44: "ONLY_ONE", 45: "MD_PARENT", 46: "NON_IDENTIFYING", 47: "IDENTIFYING", 48: "WORD" }, + productions_: [0, [3, 3], [5, 0], [5, 2], [7, 2], [7, 1], [7, 1], [7, 1], [9, 5], [9, 4], [9, 3], [9, 1], [9, 7], [9, 6], [9, 4], [9, 2], [9, 2], [9, 2], [9, 1], [11, 1], [11, 1], [16, 1], [16, 2], [29, 2], [29, 3], [29, 3], [29, 4], [30, 1], [31, 1], [32, 1], [32, 3], [35, 1], [33, 1], [12, 3], [39, 1], [39, 1], [39, 1], [39, 1], [39, 1], [40, 1], [40, 1], [14, 1], [14, 1], [14, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 1: + break; + case 2: + this.$ = []; + break; + case 3: + $$[$0 - 1].push($$[$0]); + this.$ = $$[$0 - 1]; + break; + case 4: + case 5: + this.$ = $$[$0]; + break; + case 6: + case 7: + this.$ = []; + break; + case 8: + yy.addEntity($$[$0 - 4]); + yy.addEntity($$[$0 - 2]); + yy.addRelationship($$[$0 - 4], $$[$0], $$[$0 - 2], $$[$0 - 3]); + break; + case 9: + yy.addEntity($$[$0 - 3]); + yy.addAttributes($$[$0 - 3], $$[$0 - 1]); + break; + case 10: + yy.addEntity($$[$0 - 2]); + break; + case 11: + yy.addEntity($$[$0]); + break; + case 12: + yy.addEntity($$[$0 - 6], $$[$0 - 4]); + yy.addAttributes($$[$0 - 6], $$[$0 - 1]); + break; + case 13: + yy.addEntity($$[$0 - 5], $$[$0 - 3]); + break; + case 14: + yy.addEntity($$[$0 - 3], $$[$0 - 1]); + break; + case 15: + case 16: + this.$ = $$[$0].trim(); + yy.setAccTitle(this.$); + break; + case 17: + case 18: + this.$ = $$[$0].trim(); + yy.setAccDescription(this.$); + break; + case 19: + case 43: + this.$ = $$[$0]; + break; + case 20: + case 41: + case 42: + this.$ = $$[$0].replace(/"/g, ""); + break; + case 21: + case 29: + this.$ = [$$[$0]]; + break; + case 22: + $$[$0].push($$[$0 - 1]); + this.$ = $$[$0]; + break; + case 23: + this.$ = { attributeType: $$[$0 - 1], attributeName: $$[$0] }; + break; + case 24: + this.$ = { attributeType: $$[$0 - 2], attributeName: $$[$0 - 1], attributeKeyTypeList: $$[$0] }; + break; + case 25: + this.$ = { attributeType: $$[$0 - 2], attributeName: $$[$0 - 1], attributeComment: $$[$0] }; + break; + case 26: + this.$ = { attributeType: $$[$0 - 3], attributeName: $$[$0 - 2], attributeKeyTypeList: $$[$0 - 1], attributeComment: $$[$0] }; + break; + case 27: + case 28: + case 31: + this.$ = $$[$0]; + break; + case 30: + $$[$0 - 2].push($$[$0]); + this.$ = $$[$0 - 2]; + break; + case 32: + this.$ = $$[$0].replace(/"/g, ""); + break; + case 33: + this.$ = { cardA: $$[$0], relType: $$[$0 - 1], cardB: $$[$0 - 2] }; + break; + case 34: + this.$ = yy.Cardinality.ZERO_OR_ONE; + break; + case 35: + this.$ = yy.Cardinality.ZERO_OR_MORE; + break; + case 36: + this.$ = yy.Cardinality.ONE_OR_MORE; + break; + case 37: + this.$ = yy.Cardinality.ONLY_ONE; + break; + case 38: + this.$ = yy.Cardinality.MD_PARENT; + break; + case 39: + this.$ = yy.Identification.NON_IDENTIFYING; + break; + case 40: + this.$ = yy.Identification.IDENTIFYING; + break; + } + }, + table: [{ 3: 1, 4: [1, 2] }, { 1: [3] }, o($V0, [2, 2], { 5: 3 }), { 6: [1, 4], 7: 5, 8: [1, 6], 9: 7, 10: [1, 8], 11: 9, 20: $V1, 22: $V2, 24: $V3, 26: $V4, 27: $V5, 28: $V6 }, o($V0, [2, 7], { 1: [2, 1] }), o($V0, [2, 3]), { 9: 16, 11: 9, 20: $V1, 22: $V2, 24: $V3, 26: $V4, 27: $V5, 28: $V6 }, o($V0, [2, 5]), o($V0, [2, 6]), o($V0, [2, 11], { 12: 17, 39: 20, 15: [1, 18], 18: [1, 19], 41: $V7, 42: $V8, 43: $V9, 44: $Va, 45: $Vb }), { 21: [1, 26] }, { 23: [1, 27] }, { 25: [1, 28] }, o($V0, [2, 18]), o($Vc, [2, 19]), o($Vc, [2, 20]), o($V0, [2, 4]), { 11: 29, 27: $V5, 28: $V6 }, { 16: 30, 17: [1, 31], 29: 32, 30: 33, 34: $Vd }, { 11: 35, 27: $V5, 28: $V6 }, { 40: 36, 46: [1, 37], 47: [1, 38] }, o($Ve, [2, 34]), o($Ve, [2, 35]), o($Ve, [2, 36]), o($Ve, [2, 37]), o($Ve, [2, 38]), o($V0, [2, 15]), o($V0, [2, 16]), o($V0, [2, 17]), { 13: [1, 39] }, { 17: [1, 40] }, o($V0, [2, 10]), { 16: 41, 17: [2, 21], 29: 32, 30: 33, 34: $Vd }, { 31: 42, 34: [1, 43] }, { 34: [2, 27] }, { 19: [1, 44] }, { 39: 45, 41: $V7, 42: $V8, 43: $V9, 44: $Va, 45: $Vb }, o($Vf, [2, 39]), o($Vf, [2, 40]), { 14: 46, 27: [1, 49], 28: [1, 48], 48: [1, 47] }, o($V0, [2, 9]), { 17: [2, 22] }, o($Vg, [2, 23], { 32: 50, 33: 51, 35: 52, 37: $Vh, 38: $Vi }), o([17, 34, 37, 38], [2, 28]), o($V0, [2, 14], { 15: [1, 55] }), o([27, 28], [2, 33]), o($V0, [2, 8]), o($V0, [2, 41]), o($V0, [2, 42]), o($V0, [2, 43]), o($Vg, [2, 24], { 33: 56, 36: [1, 57], 38: $Vi }), o($Vg, [2, 25]), o($Vj, [2, 29]), o($Vg, [2, 32]), o($Vj, [2, 31]), { 16: 58, 17: [1, 59], 29: 32, 30: 33, 34: $Vd }, o($Vg, [2, 26]), { 35: 60, 37: $Vh }, { 17: [1, 61] }, o($V0, [2, 13]), o($Vj, [2, 30]), o($V0, [2, 12])], + defaultActions: { 34: [2, 27], 41: [2, 22] }, + parseError: function parseError(str2, hash) { + if (hash.recoverable) { + this.trace(str2); + } else { + var error = new Error(str2); + error.hash = hash; + throw error; + } + }, + parse: function parse2(input) { + var self2 = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex2() { + var token2; + token2 = tstack.pop() || lexer2.lex() || EOF; + if (typeof token2 !== "number") { + if (token2 instanceof Array) { + tstack = token2; + token2 = tstack.pop(); + } + token2 = self2.symbols_[token2] || token2; + } + return token2; + } + var symbol, state2, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state2 = stack[stack.length - 1]; + if (this.defaultActions[state2]) { + action = this.defaultActions[state2]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex2(); + } + action = table[state2] && table[state2][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state2]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state2 + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str2, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str2, hash); + } else { + throw new Error(str2); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch2 = this._input[0]; + this.yytext += ch2; + this.yyleng++; + this.offset++; + this.match += ch2; + this.matched += ch2; + var lines = ch2.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch2; + }, + // unshifts one char (or a string) into the input + unput: function(ch2) { + var len = ch2.length; + var lines = ch2.split(/(?:\r\n?|\n)/g); + this._input = ch2 + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next2 = this.match; + if (next2.length < 20) { + next2 += this._input.substr(0, 20 - next2.length); + } + return (next2.substr(0, 20) + (next2.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c2 = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c2 + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token2, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token2 = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token2) { + return token2; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token2, match, tempMatch, index2; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i2 = 0; i2 < rules.length; i2++) { + tempMatch = this._input.match(this.rules[rules[i2]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index2 = i2; + if (this.options.backtrack_lexer) { + token2 = this.test_match(tempMatch, rules[i2]); + if (token2 !== false) { + return token2; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token2 = this.test_match(match, rules[index2]); + if (token2 !== false) { + return token2; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex2() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + this.begin("acc_title"); + return 22; + case 1: + this.popState(); + return "acc_title_value"; + case 2: + this.begin("acc_descr"); + return 24; + case 3: + this.popState(); + return "acc_descr_value"; + case 4: + this.begin("acc_descr_multiline"); + break; + case 5: + this.popState(); + break; + case 6: + return "acc_descr_multiline_value"; + case 7: + return 10; + case 8: + break; + case 9: + return 8; + case 10: + return 28; + case 11: + return 48; + case 12: + return 4; + case 13: + this.begin("block"); + return 15; + case 14: + return 36; + case 15: + break; + case 16: + return 37; + case 17: + return 34; + case 18: + return 34; + case 19: + return 38; + case 20: + break; + case 21: + this.popState(); + return 17; + case 22: + return yy_.yytext[0]; + case 23: + return 18; + case 24: + return 19; + case 25: + return 41; + case 26: + return 43; + case 27: + return 43; + case 28: + return 43; + case 29: + return 41; + case 30: + return 41; + case 31: + return 42; + case 32: + return 42; + case 33: + return 42; + case 34: + return 42; + case 35: + return 42; + case 36: + return 43; + case 37: + return 42; + case 38: + return 43; + case 39: + return 44; + case 40: + return 44; + case 41: + return 44; + case 42: + return 44; + case 43: + return 41; + case 44: + return 42; + case 45: + return 43; + case 46: + return 45; + case 47: + return 46; + case 48: + return 47; + case 49: + return 47; + case 50: + return 46; + case 51: + return 46; + case 52: + return 46; + case 53: + return 27; + case 54: + return yy_.yytext[0]; + case 55: + return 6; + } + }, + rules: [/^(?:accTitle\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*\{\s*)/i, /^(?:[\}])/i, /^(?:[^\}]*)/i, /^(?:[\n]+)/i, /^(?:\s+)/i, /^(?:[\s]+)/i, /^(?:"[^"%\r\n\v\b\\]+")/i, /^(?:"[^"]*")/i, /^(?:erDiagram\b)/i, /^(?:\{)/i, /^(?:,)/i, /^(?:\s+)/i, /^(?:\b((?:PK)|(?:FK)|(?:UK))\b)/i, /^(?:(.*?)[~](.*?)*[~])/i, /^(?:[\*A-Za-z_][A-Za-z0-9\-_\[\]\(\)]*)/i, /^(?:"[^"]*")/i, /^(?:[\n]+)/i, /^(?:\})/i, /^(?:.)/i, /^(?:\[)/i, /^(?:\])/i, /^(?:one or zero\b)/i, /^(?:one or more\b)/i, /^(?:one or many\b)/i, /^(?:1\+)/i, /^(?:\|o\b)/i, /^(?:zero or one\b)/i, /^(?:zero or more\b)/i, /^(?:zero or many\b)/i, /^(?:0\+)/i, /^(?:\}o\b)/i, /^(?:many\(0\))/i, /^(?:many\(1\))/i, /^(?:many\b)/i, /^(?:\}\|)/i, /^(?:one\b)/i, /^(?:only one\b)/i, /^(?:1\b)/i, /^(?:\|\|)/i, /^(?:o\|)/i, /^(?:o\{)/i, /^(?:\|\{)/i, /^(?:\s*u\b)/i, /^(?:\.\.)/i, /^(?:--)/i, /^(?:to\b)/i, /^(?:optionally to\b)/i, /^(?:\.-)/i, /^(?:-\.)/i, /^(?:[A-Za-z_][A-Za-z0-9\-_]*)/i, /^(?:.)/i, /^(?:$)/i], + conditions: { "acc_descr_multiline": { "rules": [5, 6], "inclusive": false }, "acc_descr": { "rules": [3], "inclusive": false }, "acc_title": { "rules": [1], "inclusive": false }, "block": { "rules": [14, 15, 16, 17, 18, 19, 20, 21, 22], "inclusive": false }, "INITIAL": { "rules": [0, 2, 4, 7, 8, 9, 10, 11, 12, 13, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser2() { + this.yy = {}; + } + Parser2.prototype = parser2; + parser2.Parser = Parser2; + return new Parser2(); + }(); + parser$s.parser = parser$s; + const erParser = parser$s; + let entities = {}; + let relationships = []; + const Cardinality = { + ZERO_OR_ONE: "ZERO_OR_ONE", + ZERO_OR_MORE: "ZERO_OR_MORE", + ONE_OR_MORE: "ONE_OR_MORE", + ONLY_ONE: "ONLY_ONE", + MD_PARENT: "MD_PARENT" + }; + const Identification = { + NON_IDENTIFYING: "NON_IDENTIFYING", + IDENTIFYING: "IDENTIFYING" + }; + const addEntity = function(name, alias = void 0) { + if (entities[name] === void 0) { + entities[name] = { attributes: [], alias }; + log$1.info("Added new entity :", name); + } else if (entities[name] && !entities[name].alias && alias) { + entities[name].alias = alias; + log$1.info(`Add alias '${alias}' to entity '${name}'`); + } + return entities[name]; + }; + const getEntities = () => entities; + const addAttributes = function(entityName, attribs) { + let entity = addEntity(entityName); + let i2; + for (i2 = attribs.length - 1; i2 >= 0; i2--) { + entity.attributes.push(attribs[i2]); + log$1.debug("Added attribute ", attribs[i2].attributeName); + } + }; + const addRelationship$1 = function(entA, rolA, entB, rSpec) { + let rel2 = { + entityA: entA, + roleA: rolA, + entityB: entB, + relSpec: rSpec + }; + relationships.push(rel2); + log$1.debug("Added new relationship :", rel2); + }; + const getRelationships$1 = () => relationships; + const clear$g = function() { + entities = {}; + relationships = []; + clear$n(); + }; + const erDb = { + Cardinality, + Identification, + getConfig: () => getConfig$1().er, + addEntity, + addAttributes, + getEntities, + addRelationship: addRelationship$1, + getRelationships: getRelationships$1, + clear: clear$g, + setAccTitle, + getAccTitle, + setAccDescription, + getAccDescription, + setDiagramTitle, + getDiagramTitle + }; + const ERMarkers = { + ONLY_ONE_START: "ONLY_ONE_START", + ONLY_ONE_END: "ONLY_ONE_END", + ZERO_OR_ONE_START: "ZERO_OR_ONE_START", + ZERO_OR_ONE_END: "ZERO_OR_ONE_END", + ONE_OR_MORE_START: "ONE_OR_MORE_START", + ONE_OR_MORE_END: "ONE_OR_MORE_END", + ZERO_OR_MORE_START: "ZERO_OR_MORE_START", + ZERO_OR_MORE_END: "ZERO_OR_MORE_END", + MD_PARENT_END: "MD_PARENT_END", + MD_PARENT_START: "MD_PARENT_START" + }; + const insertMarkers$2 = function(elem, conf2) { + let marker; + elem.append("defs").append("marker").attr("id", ERMarkers.MD_PARENT_START).attr("refX", 0).attr("refY", 7).attr("markerWidth", 190).attr("markerHeight", 240).attr("orient", "auto").append("path").attr("d", "M 18,7 L9,13 L1,7 L9,1 Z"); + elem.append("defs").append("marker").attr("id", ERMarkers.MD_PARENT_END).attr("refX", 19).attr("refY", 7).attr("markerWidth", 20).attr("markerHeight", 28).attr("orient", "auto").append("path").attr("d", "M 18,7 L9,13 L1,7 L9,1 Z"); + elem.append("defs").append("marker").attr("id", ERMarkers.ONLY_ONE_START).attr("refX", 0).attr("refY", 9).attr("markerWidth", 18).attr("markerHeight", 18).attr("orient", "auto").append("path").attr("stroke", conf2.stroke).attr("fill", "none").attr("d", "M9,0 L9,18 M15,0 L15,18"); + elem.append("defs").append("marker").attr("id", ERMarkers.ONLY_ONE_END).attr("refX", 18).attr("refY", 9).attr("markerWidth", 18).attr("markerHeight", 18).attr("orient", "auto").append("path").attr("stroke", conf2.stroke).attr("fill", "none").attr("d", "M3,0 L3,18 M9,0 L9,18"); + marker = elem.append("defs").append("marker").attr("id", ERMarkers.ZERO_OR_ONE_START).attr("refX", 0).attr("refY", 9).attr("markerWidth", 30).attr("markerHeight", 18).attr("orient", "auto"); + marker.append("circle").attr("stroke", conf2.stroke).attr("fill", "white").attr("cx", 21).attr("cy", 9).attr("r", 6); + marker.append("path").attr("stroke", conf2.stroke).attr("fill", "none").attr("d", "M9,0 L9,18"); + marker = elem.append("defs").append("marker").attr("id", ERMarkers.ZERO_OR_ONE_END).attr("refX", 30).attr("refY", 9).attr("markerWidth", 30).attr("markerHeight", 18).attr("orient", "auto"); + marker.append("circle").attr("stroke", conf2.stroke).attr("fill", "white").attr("cx", 9).attr("cy", 9).attr("r", 6); + marker.append("path").attr("stroke", conf2.stroke).attr("fill", "none").attr("d", "M21,0 L21,18"); + elem.append("defs").append("marker").attr("id", ERMarkers.ONE_OR_MORE_START).attr("refX", 18).attr("refY", 18).attr("markerWidth", 45).attr("markerHeight", 36).attr("orient", "auto").append("path").attr("stroke", conf2.stroke).attr("fill", "none").attr("d", "M0,18 Q 18,0 36,18 Q 18,36 0,18 M42,9 L42,27"); + elem.append("defs").append("marker").attr("id", ERMarkers.ONE_OR_MORE_END).attr("refX", 27).attr("refY", 18).attr("markerWidth", 45).attr("markerHeight", 36).attr("orient", "auto").append("path").attr("stroke", conf2.stroke).attr("fill", "none").attr("d", "M3,9 L3,27 M9,18 Q27,0 45,18 Q27,36 9,18"); + marker = elem.append("defs").append("marker").attr("id", ERMarkers.ZERO_OR_MORE_START).attr("refX", 18).attr("refY", 18).attr("markerWidth", 57).attr("markerHeight", 36).attr("orient", "auto"); + marker.append("circle").attr("stroke", conf2.stroke).attr("fill", "white").attr("cx", 48).attr("cy", 18).attr("r", 6); + marker.append("path").attr("stroke", conf2.stroke).attr("fill", "none").attr("d", "M0,18 Q18,0 36,18 Q18,36 0,18"); + marker = elem.append("defs").append("marker").attr("id", ERMarkers.ZERO_OR_MORE_END).attr("refX", 39).attr("refY", 18).attr("markerWidth", 57).attr("markerHeight", 36).attr("orient", "auto"); + marker.append("circle").attr("stroke", conf2.stroke).attr("fill", "white").attr("cx", 9).attr("cy", 18).attr("r", 6); + marker.append("path").attr("stroke", conf2.stroke).attr("fill", "none").attr("d", "M21,18 Q39,0 57,18 Q39,36 21,18"); + return; + }; + const erMarkers = { + ERMarkers, + insertMarkers: insertMarkers$2 + }; + const REGEX = /^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000)$/i; + function validate(uuid) { + return typeof uuid === "string" && REGEX.test(uuid); + } + const byteToHex = []; + for (let i2 = 0; i2 < 256; ++i2) { + byteToHex.push((i2 + 256).toString(16).slice(1)); + } + function unsafeStringify(arr, offset = 0) { + return byteToHex[arr[offset + 0]] + byteToHex[arr[offset + 1]] + byteToHex[arr[offset + 2]] + byteToHex[arr[offset + 3]] + "-" + byteToHex[arr[offset + 4]] + byteToHex[arr[offset + 5]] + "-" + byteToHex[arr[offset + 6]] + byteToHex[arr[offset + 7]] + "-" + byteToHex[arr[offset + 8]] + byteToHex[arr[offset + 9]] + "-" + byteToHex[arr[offset + 10]] + byteToHex[arr[offset + 11]] + byteToHex[arr[offset + 12]] + byteToHex[arr[offset + 13]] + byteToHex[arr[offset + 14]] + byteToHex[arr[offset + 15]]; + } + function parse(uuid) { + if (!validate(uuid)) { + throw TypeError("Invalid UUID"); + } + let v; + const arr = new Uint8Array(16); + arr[0] = (v = parseInt(uuid.slice(0, 8), 16)) >>> 24; + arr[1] = v >>> 16 & 255; + arr[2] = v >>> 8 & 255; + arr[3] = v & 255; + arr[4] = (v = parseInt(uuid.slice(9, 13), 16)) >>> 8; + arr[5] = v & 255; + arr[6] = (v = parseInt(uuid.slice(14, 18), 16)) >>> 8; + arr[7] = v & 255; + arr[8] = (v = parseInt(uuid.slice(19, 23), 16)) >>> 8; + arr[9] = v & 255; + arr[10] = (v = parseInt(uuid.slice(24, 36), 16)) / 1099511627776 & 255; + arr[11] = v / 4294967296 & 255; + arr[12] = v >>> 24 & 255; + arr[13] = v >>> 16 & 255; + arr[14] = v >>> 8 & 255; + arr[15] = v & 255; + return arr; + } + function stringToBytes(str2) { + str2 = unescape(encodeURIComponent(str2)); + const bytes = []; + for (let i2 = 0; i2 < str2.length; ++i2) { + bytes.push(str2.charCodeAt(i2)); + } + return bytes; + } + const DNS = "6ba7b810-9dad-11d1-80b4-00c04fd430c8"; + const URL = "6ba7b811-9dad-11d1-80b4-00c04fd430c8"; + function v35(name, version2, hashfunc) { + function generateUUID(value2, namespace2, buf, offset) { + var _namespace; + if (typeof value2 === "string") { + value2 = stringToBytes(value2); + } + if (typeof namespace2 === "string") { + namespace2 = parse(namespace2); + } + if (((_namespace = namespace2) === null || _namespace === void 0 ? void 0 : _namespace.length) !== 16) { + throw TypeError("Namespace must be array-like (16 iterable integer values, 0-255)"); + } + let bytes = new Uint8Array(16 + value2.length); + bytes.set(namespace2); + bytes.set(value2, namespace2.length); + bytes = hashfunc(bytes); + bytes[6] = bytes[6] & 15 | version2; + bytes[8] = bytes[8] & 63 | 128; + if (buf) { + offset = offset || 0; + for (let i2 = 0; i2 < 16; ++i2) { + buf[offset + i2] = bytes[i2]; + } + return buf; + } + return unsafeStringify(bytes); + } + try { + generateUUID.name = name; + } catch (err) { + } + generateUUID.DNS = DNS; + generateUUID.URL = URL; + return generateUUID; + } + function f(s, x2, y2, z) { + switch (s) { + case 0: + return x2 & y2 ^ ~x2 & z; + case 1: + return x2 ^ y2 ^ z; + case 2: + return x2 & y2 ^ x2 & z ^ y2 & z; + case 3: + return x2 ^ y2 ^ z; + } + } + function ROTL(x2, n) { + return x2 << n | x2 >>> 32 - n; + } + function sha1(bytes) { + const K2 = [1518500249, 1859775393, 2400959708, 3395469782]; + const H = [1732584193, 4023233417, 2562383102, 271733878, 3285377520]; + if (typeof bytes === "string") { + const msg = unescape(encodeURIComponent(bytes)); + bytes = []; + for (let i2 = 0; i2 < msg.length; ++i2) { + bytes.push(msg.charCodeAt(i2)); + } + } else if (!Array.isArray(bytes)) { + bytes = Array.prototype.slice.call(bytes); + } + bytes.push(128); + const l = bytes.length / 4 + 2; + const N = Math.ceil(l / 16); + const M = new Array(N); + for (let i2 = 0; i2 < N; ++i2) { + const arr = new Uint32Array(16); + for (let j = 0; j < 16; ++j) { + arr[j] = bytes[i2 * 64 + j * 4] << 24 | bytes[i2 * 64 + j * 4 + 1] << 16 | bytes[i2 * 64 + j * 4 + 2] << 8 | bytes[i2 * 64 + j * 4 + 3]; + } + M[i2] = arr; + } + M[N - 1][14] = (bytes.length - 1) * 8 / Math.pow(2, 32); + M[N - 1][14] = Math.floor(M[N - 1][14]); + M[N - 1][15] = (bytes.length - 1) * 8 & 4294967295; + for (let i2 = 0; i2 < N; ++i2) { + const W = new Uint32Array(80); + for (let t = 0; t < 16; ++t) { + W[t] = M[i2][t]; + } + for (let t = 16; t < 80; ++t) { + W[t] = ROTL(W[t - 3] ^ W[t - 8] ^ W[t - 14] ^ W[t - 16], 1); + } + let a = H[0]; + let b = H[1]; + let c2 = H[2]; + let d = H[3]; + let e = H[4]; + for (let t = 0; t < 80; ++t) { + const s = Math.floor(t / 20); + const T2 = ROTL(a, 5) + f(s, b, c2, d) + e + K2[s] + W[t] >>> 0; + e = d; + d = c2; + c2 = ROTL(b, 30) >>> 0; + b = a; + a = T2; + } + H[0] = H[0] + a >>> 0; + H[1] = H[1] + b >>> 0; + H[2] = H[2] + c2 >>> 0; + H[3] = H[3] + d >>> 0; + H[4] = H[4] + e >>> 0; + } + return [H[0] >> 24 & 255, H[0] >> 16 & 255, H[0] >> 8 & 255, H[0] & 255, H[1] >> 24 & 255, H[1] >> 16 & 255, H[1] >> 8 & 255, H[1] & 255, H[2] >> 24 & 255, H[2] >> 16 & 255, H[2] >> 8 & 255, H[2] & 255, H[3] >> 24 & 255, H[3] >> 16 & 255, H[3] >> 8 & 255, H[3] & 255, H[4] >> 24 & 255, H[4] >> 16 & 255, H[4] >> 8 & 255, H[4] & 255]; + } + const v5 = v35("v5", 80, sha1); + const uuid5 = v5; + const BAD_ID_CHARS_REGEXP = /[^\dA-Za-z](\W)*/g; + let conf$6 = {}; + let entityNameIds = /* @__PURE__ */ new Map(); + const setConf$6 = function(cnf) { + const keys2 = Object.keys(cnf); + for (const key of keys2) { + conf$6[key] = cnf[key]; + } + }; + const drawAttributes = (groupNode, entityTextNode, attributes) => { + const heightPadding = conf$6.entityPadding / 3; + const widthPadding = conf$6.entityPadding / 3; + const attrFontSize = conf$6.fontSize * 0.85; + const labelBBox = entityTextNode.node().getBBox(); + const attributeNodes = []; + let hasKeyType = false; + let hasComment = false; + let maxTypeWidth = 0; + let maxNameWidth = 0; + let maxKeyWidth = 0; + let maxCommentWidth = 0; + let cumulativeHeight = labelBBox.height + heightPadding * 2; + let attrNum = 1; + attributes.forEach((item) => { + if (item.attributeKeyTypeList !== void 0 && item.attributeKeyTypeList.length > 0) { + hasKeyType = true; + } + if (item.attributeComment !== void 0) { + hasComment = true; + } + }); + attributes.forEach((item) => { + const attrPrefix = `${entityTextNode.node().id}-attr-${attrNum}`; + let nodeHeight = 0; + const attributeType = parseGenericTypes(item.attributeType); + const typeNode = groupNode.append("text").classed("er entityLabel", true).attr("id", `${attrPrefix}-type`).attr("x", 0).attr("y", 0).style("dominant-baseline", "middle").style("text-anchor", "left").style("font-family", getConfig$1().fontFamily).style("font-size", attrFontSize + "px").text(attributeType); + const nameNode = groupNode.append("text").classed("er entityLabel", true).attr("id", `${attrPrefix}-name`).attr("x", 0).attr("y", 0).style("dominant-baseline", "middle").style("text-anchor", "left").style("font-family", getConfig$1().fontFamily).style("font-size", attrFontSize + "px").text(item.attributeName); + const attributeNode = {}; + attributeNode.tn = typeNode; + attributeNode.nn = nameNode; + const typeBBox = typeNode.node().getBBox(); + const nameBBox = nameNode.node().getBBox(); + maxTypeWidth = Math.max(maxTypeWidth, typeBBox.width); + maxNameWidth = Math.max(maxNameWidth, nameBBox.width); + nodeHeight = Math.max(typeBBox.height, nameBBox.height); + if (hasKeyType) { + const keyTypeNodeText = item.attributeKeyTypeList !== void 0 ? item.attributeKeyTypeList.join(",") : ""; + const keyTypeNode = groupNode.append("text").classed("er entityLabel", true).attr("id", `${attrPrefix}-key`).attr("x", 0).attr("y", 0).style("dominant-baseline", "middle").style("text-anchor", "left").style("font-family", getConfig$1().fontFamily).style("font-size", attrFontSize + "px").text(keyTypeNodeText); + attributeNode.kn = keyTypeNode; + const keyTypeBBox = keyTypeNode.node().getBBox(); + maxKeyWidth = Math.max(maxKeyWidth, keyTypeBBox.width); + nodeHeight = Math.max(nodeHeight, keyTypeBBox.height); + } + if (hasComment) { + const commentNode = groupNode.append("text").classed("er entityLabel", true).attr("id", `${attrPrefix}-comment`).attr("x", 0).attr("y", 0).style("dominant-baseline", "middle").style("text-anchor", "left").style("font-family", getConfig$1().fontFamily).style("font-size", attrFontSize + "px").text(item.attributeComment || ""); + attributeNode.cn = commentNode; + const commentNodeBBox = commentNode.node().getBBox(); + maxCommentWidth = Math.max(maxCommentWidth, commentNodeBBox.width); + nodeHeight = Math.max(nodeHeight, commentNodeBBox.height); + } + attributeNode.height = nodeHeight; + attributeNodes.push(attributeNode); + cumulativeHeight += nodeHeight + heightPadding * 2; + attrNum += 1; + }); + let widthPaddingFactor = 4; + if (hasKeyType) { + widthPaddingFactor += 2; + } + if (hasComment) { + widthPaddingFactor += 2; + } + const maxWidth = maxTypeWidth + maxNameWidth + maxKeyWidth + maxCommentWidth; + const bBox = { + width: Math.max( + conf$6.minEntityWidth, + Math.max( + labelBBox.width + conf$6.entityPadding * 2, + maxWidth + widthPadding * widthPaddingFactor + ) + ), + height: attributes.length > 0 ? cumulativeHeight : Math.max(conf$6.minEntityHeight, labelBBox.height + conf$6.entityPadding * 2) + }; + if (attributes.length > 0) { + const spareColumnWidth = Math.max( + 0, + (bBox.width - maxWidth - widthPadding * widthPaddingFactor) / (widthPaddingFactor / 2) + ); + entityTextNode.attr( + "transform", + "translate(" + bBox.width / 2 + "," + (heightPadding + labelBBox.height / 2) + ")" + ); + let heightOffset = labelBBox.height + heightPadding * 2; + let attribStyle = "attributeBoxOdd"; + attributeNodes.forEach((attributeNode) => { + const alignY = heightOffset + heightPadding + attributeNode.height / 2; + attributeNode.tn.attr("transform", "translate(" + widthPadding + "," + alignY + ")"); + const typeRect = groupNode.insert("rect", "#" + attributeNode.tn.node().id).classed(`er ${attribStyle}`, true).attr("x", 0).attr("y", heightOffset).attr("width", maxTypeWidth + widthPadding * 2 + spareColumnWidth).attr("height", attributeNode.height + heightPadding * 2); + const nameXOffset = parseFloat(typeRect.attr("x")) + parseFloat(typeRect.attr("width")); + attributeNode.nn.attr( + "transform", + "translate(" + (nameXOffset + widthPadding) + "," + alignY + ")" + ); + const nameRect = groupNode.insert("rect", "#" + attributeNode.nn.node().id).classed(`er ${attribStyle}`, true).attr("x", nameXOffset).attr("y", heightOffset).attr("width", maxNameWidth + widthPadding * 2 + spareColumnWidth).attr("height", attributeNode.height + heightPadding * 2); + let keyTypeAndCommentXOffset = parseFloat(nameRect.attr("x")) + parseFloat(nameRect.attr("width")); + if (hasKeyType) { + attributeNode.kn.attr( + "transform", + "translate(" + (keyTypeAndCommentXOffset + widthPadding) + "," + alignY + ")" + ); + const keyTypeRect = groupNode.insert("rect", "#" + attributeNode.kn.node().id).classed(`er ${attribStyle}`, true).attr("x", keyTypeAndCommentXOffset).attr("y", heightOffset).attr("width", maxKeyWidth + widthPadding * 2 + spareColumnWidth).attr("height", attributeNode.height + heightPadding * 2); + keyTypeAndCommentXOffset = parseFloat(keyTypeRect.attr("x")) + parseFloat(keyTypeRect.attr("width")); + } + if (hasComment) { + attributeNode.cn.attr( + "transform", + "translate(" + (keyTypeAndCommentXOffset + widthPadding) + "," + alignY + ")" + ); + groupNode.insert("rect", "#" + attributeNode.cn.node().id).classed(`er ${attribStyle}`, "true").attr("x", keyTypeAndCommentXOffset).attr("y", heightOffset).attr("width", maxCommentWidth + widthPadding * 2 + spareColumnWidth).attr("height", attributeNode.height + heightPadding * 2); + } + heightOffset += attributeNode.height + heightPadding * 2; + attribStyle = attribStyle === "attributeBoxOdd" ? "attributeBoxEven" : "attributeBoxOdd"; + }); + } else { + bBox.height = Math.max(conf$6.minEntityHeight, cumulativeHeight); + entityTextNode.attr("transform", "translate(" + bBox.width / 2 + "," + bBox.height / 2 + ")"); + } + return bBox; + }; + const drawEntities = function(svgNode2, entities2, graph) { + const keys2 = Object.keys(entities2); + let firstOne; + keys2.forEach(function(entityName) { + const entityId = generateId$1(entityName, "entity"); + entityNameIds.set(entityName, entityId); + const groupNode = svgNode2.append("g").attr("id", entityId); + firstOne = firstOne === void 0 ? entityId : firstOne; + const textId = "text-" + entityId; + const textNode = groupNode.append("text").classed("er entityLabel", true).attr("id", textId).attr("x", 0).attr("y", 0).style("dominant-baseline", "middle").style("text-anchor", "middle").style("font-family", getConfig$1().fontFamily).style("font-size", conf$6.fontSize + "px").text(entities2[entityName].alias ?? entityName); + const { width: entityWidth, height: entityHeight } = drawAttributes( + groupNode, + textNode, + entities2[entityName].attributes + ); + const rectNode = groupNode.insert("rect", "#" + textId).classed("er entityBox", true).attr("x", 0).attr("y", 0).attr("width", entityWidth).attr("height", entityHeight); + const rectBBox = rectNode.node().getBBox(); + graph.setNode(entityId, { + width: rectBBox.width, + height: rectBBox.height, + shape: "rect", + id: entityId + }); + }); + return firstOne; + }; + const adjustEntities$1 = function(svgNode2, graph) { + graph.nodes().forEach(function(v) { + if (v !== void 0 && graph.node(v) !== void 0) { + svgNode2.select("#" + v).attr( + "transform", + "translate(" + (graph.node(v).x - graph.node(v).width / 2) + "," + (graph.node(v).y - graph.node(v).height / 2) + " )" + ); + } + }); + }; + const getEdgeName = function(rel2) { + return (rel2.entityA + rel2.roleA + rel2.entityB).replace(/\s/g, ""); + }; + const addRelationships$1 = function(relationships2, g) { + relationships2.forEach(function(r) { + g.setEdge( + entityNameIds.get(r.entityA), + entityNameIds.get(r.entityB), + { relationship: r }, + getEdgeName(r) + ); + }); + return relationships2; + }; + let relCnt$1 = 0; + const drawRelationshipFromLayout$1 = function(svg2, rel2, g, insert, diagObj) { + relCnt$1++; + const edge = g.edge( + entityNameIds.get(rel2.entityA), + entityNameIds.get(rel2.entityB), + getEdgeName(rel2) + ); + const lineFunction = line$1().x(function(d) { + return d.x; + }).y(function(d) { + return d.y; + }).curve(curveBasis); + const svgPath = svg2.insert("path", "#" + insert).classed("er relationshipLine", true).attr("d", lineFunction(edge.points)).style("stroke", conf$6.stroke).style("fill", "none"); + if (rel2.relSpec.relType === diagObj.db.Identification.NON_IDENTIFYING) { + svgPath.attr("stroke-dasharray", "8,8"); + } + let url = ""; + if (conf$6.arrowMarkerAbsolute) { + url = window.location.protocol + "//" + window.location.host + window.location.pathname + window.location.search; + url = url.replace(/\(/g, "\\("); + url = url.replace(/\)/g, "\\)"); + } + switch (rel2.relSpec.cardA) { + case diagObj.db.Cardinality.ZERO_OR_ONE: + svgPath.attr("marker-end", "url(" + url + "#" + erMarkers.ERMarkers.ZERO_OR_ONE_END + ")"); + break; + case diagObj.db.Cardinality.ZERO_OR_MORE: + svgPath.attr("marker-end", "url(" + url + "#" + erMarkers.ERMarkers.ZERO_OR_MORE_END + ")"); + break; + case diagObj.db.Cardinality.ONE_OR_MORE: + svgPath.attr("marker-end", "url(" + url + "#" + erMarkers.ERMarkers.ONE_OR_MORE_END + ")"); + break; + case diagObj.db.Cardinality.ONLY_ONE: + svgPath.attr("marker-end", "url(" + url + "#" + erMarkers.ERMarkers.ONLY_ONE_END + ")"); + break; + case diagObj.db.Cardinality.MD_PARENT: + svgPath.attr("marker-end", "url(" + url + "#" + erMarkers.ERMarkers.MD_PARENT_END + ")"); + break; + } + switch (rel2.relSpec.cardB) { + case diagObj.db.Cardinality.ZERO_OR_ONE: + svgPath.attr( + "marker-start", + "url(" + url + "#" + erMarkers.ERMarkers.ZERO_OR_ONE_START + ")" + ); + break; + case diagObj.db.Cardinality.ZERO_OR_MORE: + svgPath.attr( + "marker-start", + "url(" + url + "#" + erMarkers.ERMarkers.ZERO_OR_MORE_START + ")" + ); + break; + case diagObj.db.Cardinality.ONE_OR_MORE: + svgPath.attr( + "marker-start", + "url(" + url + "#" + erMarkers.ERMarkers.ONE_OR_MORE_START + ")" + ); + break; + case diagObj.db.Cardinality.ONLY_ONE: + svgPath.attr("marker-start", "url(" + url + "#" + erMarkers.ERMarkers.ONLY_ONE_START + ")"); + break; + case diagObj.db.Cardinality.MD_PARENT: + svgPath.attr("marker-start", "url(" + url + "#" + erMarkers.ERMarkers.MD_PARENT_START + ")"); + break; + } + const len = svgPath.node().getTotalLength(); + const labelPoint = svgPath.node().getPointAtLength(len * 0.5); + const labelId = "rel" + relCnt$1; + const labelNode = svg2.append("text").classed("er relationshipLabel", true).attr("id", labelId).attr("x", labelPoint.x).attr("y", labelPoint.y).style("text-anchor", "middle").style("dominant-baseline", "middle").style("font-family", getConfig$1().fontFamily).style("font-size", conf$6.fontSize + "px").text(rel2.roleA); + const labelBBox = labelNode.node().getBBox(); + svg2.insert("rect", "#" + labelId).classed("er relationshipLabelBox", true).attr("x", labelPoint.x - labelBBox.width / 2).attr("y", labelPoint.y - labelBBox.height / 2).attr("width", labelBBox.width).attr("height", labelBBox.height); + }; + const draw$i = function(text2, id2, _version, diagObj) { + conf$6 = getConfig$1().er; + log$1.info("Drawing ER diagram"); + const securityLevel = getConfig$1().securityLevel; + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = d3select("#i" + id2); + } + const root2 = securityLevel === "sandbox" ? d3select(sandboxElement.nodes()[0].contentDocument.body) : d3select("body"); + const svg2 = root2.select(`[id='${id2}']`); + erMarkers.insertMarkers(svg2, conf$6); + let g; + g = new Graph({ + multigraph: true, + directed: true, + compound: false + }).setGraph({ + rankdir: conf$6.layoutDirection, + marginx: 20, + marginy: 20, + nodesep: 100, + edgesep: 100, + ranksep: 100 + }).setDefaultEdgeLabel(function() { + return {}; + }); + const firstEntity = drawEntities(svg2, diagObj.db.getEntities(), g); + const relationships2 = addRelationships$1(diagObj.db.getRelationships(), g); + layout$1(g); + adjustEntities$1(svg2, g); + relationships2.forEach(function(rel2) { + drawRelationshipFromLayout$1(svg2, rel2, g, firstEntity, diagObj); + }); + const padding2 = conf$6.diagramPadding; + utils$1.insertTitle(svg2, "entityTitleText", conf$6.titleTopMargin, diagObj.db.getDiagramTitle()); + const svgBounds = svg2.node().getBBox(); + const width2 = svgBounds.width + padding2 * 2; + const height = svgBounds.height + padding2 * 2; + configureSvgSize(svg2, height, width2, conf$6.useMaxWidth); + svg2.attr("viewBox", `${svgBounds.x - padding2} ${svgBounds.y - padding2} ${width2} ${height}`); + }; + const MERMAID_ERDIAGRAM_UUID = "28e9f9db-3c8d-5aa5-9faf-44286ae5937c"; + function generateId$1(str2 = "", prefix = "") { + const simplifiedStr = str2.replace(BAD_ID_CHARS_REGEXP, ""); + return `${strWithHyphen(prefix)}${strWithHyphen(simplifiedStr)}${uuid5( + str2, + MERMAID_ERDIAGRAM_UUID + )}`; + } + function strWithHyphen(str2 = "") { + return str2.length > 0 ? `${str2}-` : ""; + } + const erRenderer = { + setConf: setConf$6, + draw: draw$i + }; + const getStyles$c = (options2) => ` + .entityBox { + fill: ${options2.mainBkg}; + stroke: ${options2.nodeBorder}; + } + + .attributeBoxOdd { + fill: ${options2.attributeBackgroundColorOdd}; + stroke: ${options2.nodeBorder}; + } + + .attributeBoxEven { + fill: ${options2.attributeBackgroundColorEven}; + stroke: ${options2.nodeBorder}; + } + + .relationshipLabelBox { + fill: ${options2.tertiaryColor}; + opacity: 0.7; + background-color: ${options2.tertiaryColor}; + rect { + opacity: 0.5; + } + } + + .relationshipLine { + stroke: ${options2.lineColor}; + } + + .entityTitleText { + text-anchor: middle; + font-size: 18px; + fill: ${options2.textColor}; + } + #MD_PARENT_START { + fill: #f5f5f5 !important; + stroke: ${options2.lineColor} !important; + stroke-width: 1; + } + #MD_PARENT_END { + fill: #f5f5f5 !important; + stroke: ${options2.lineColor} !important; + stroke-width: 1; + } + +`; + const erStyles = getStyles$c; + const diagram$i = { + parser: erParser, + db: erDb, + renderer: erRenderer, + styles: erStyles + }; + const erDiagram = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + diagram: diagram$i + }, Symbol.toStringTag, { value: "Module" })); + var parser$r = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 3], $V1 = [1, 6], $V2 = [1, 4], $V3 = [1, 5], $V4 = [2, 5], $V5 = [1, 12], $V6 = [5, 7, 13, 19, 21, 23, 24, 26, 28, 31, 37, 40, 47], $V7 = [7, 13, 19, 21, 23, 24, 26, 28, 31, 37, 40], $V8 = [7, 12, 13, 19, 21, 23, 24, 26, 28, 31, 37, 40], $V9 = [7, 13, 47], $Va = [1, 42], $Vb = [1, 41], $Vc = [7, 13, 29, 32, 35, 38, 47], $Vd = [1, 55], $Ve = [1, 56], $Vf = [1, 57], $Vg = [7, 13, 32, 35, 42, 47]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "eol": 4, "GG": 5, "document": 6, "EOF": 7, ":": 8, "DIR": 9, "options": 10, "body": 11, "OPT": 12, "NL": 13, "line": 14, "statement": 15, "commitStatement": 16, "mergeStatement": 17, "cherryPickStatement": 18, "acc_title": 19, "acc_title_value": 20, "acc_descr": 21, "acc_descr_value": 22, "acc_descr_multiline_value": 23, "section": 24, "branchStatement": 25, "CHECKOUT": 26, "ref": 27, "BRANCH": 28, "ORDER": 29, "NUM": 30, "CHERRY_PICK": 31, "COMMIT_ID": 32, "STR": 33, "PARENT_COMMIT": 34, "COMMIT_TAG": 35, "EMPTYSTR": 36, "MERGE": 37, "COMMIT_TYPE": 38, "commitType": 39, "COMMIT": 40, "commit_arg": 41, "COMMIT_MSG": 42, "NORMAL": 43, "REVERSE": 44, "HIGHLIGHT": 45, "ID": 46, ";": 47, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 5: "GG", 7: "EOF", 8: ":", 9: "DIR", 12: "OPT", 13: "NL", 19: "acc_title", 20: "acc_title_value", 21: "acc_descr", 22: "acc_descr_value", 23: "acc_descr_multiline_value", 24: "section", 26: "CHECKOUT", 28: "BRANCH", 29: "ORDER", 30: "NUM", 31: "CHERRY_PICK", 32: "COMMIT_ID", 33: "STR", 34: "PARENT_COMMIT", 35: "COMMIT_TAG", 36: "EMPTYSTR", 37: "MERGE", 38: "COMMIT_TYPE", 40: "COMMIT", 42: "COMMIT_MSG", 43: "NORMAL", 44: "REVERSE", 45: "HIGHLIGHT", 46: "ID", 47: ";" }, + productions_: [0, [3, 2], [3, 3], [3, 4], [3, 5], [6, 0], [6, 2], [10, 2], [10, 1], [11, 0], [11, 2], [14, 2], [14, 1], [15, 1], [15, 1], [15, 1], [15, 2], [15, 2], [15, 1], [15, 1], [15, 1], [15, 2], [25, 2], [25, 4], [18, 3], [18, 5], [18, 5], [18, 7], [18, 7], [18, 5], [18, 5], [18, 5], [18, 7], [18, 7], [18, 7], [18, 7], [17, 2], [17, 4], [17, 4], [17, 4], [17, 6], [17, 6], [17, 6], [17, 6], [17, 6], [17, 6], [17, 8], [17, 8], [17, 8], [17, 8], [17, 8], [17, 8], [16, 2], [16, 3], [16, 3], [16, 5], [16, 5], [16, 3], [16, 5], [16, 5], [16, 5], [16, 5], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 3], [16, 5], [16, 5], [16, 5], [16, 5], [16, 5], [16, 5], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [41, 0], [41, 1], [39, 1], [39, 1], [39, 1], [27, 1], [27, 1], [4, 1], [4, 1], [4, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 2: + return $$[$0]; + case 3: + return $$[$0 - 1]; + case 4: + yy.setDirection($$[$0 - 3]); + return $$[$0 - 1]; + case 6: + yy.setOptions($$[$0 - 1]); + this.$ = $$[$0]; + break; + case 7: + $$[$0 - 1] += $$[$0]; + this.$ = $$[$0 - 1]; + break; + case 9: + this.$ = []; + break; + case 10: + $$[$0 - 1].push($$[$0]); + this.$ = $$[$0 - 1]; + break; + case 11: + this.$ = $$[$0 - 1]; + break; + case 16: + this.$ = $$[$0].trim(); + yy.setAccTitle(this.$); + break; + case 17: + case 18: + this.$ = $$[$0].trim(); + yy.setAccDescription(this.$); + break; + case 19: + yy.addSection($$[$0].substr(8)); + this.$ = $$[$0].substr(8); + break; + case 21: + yy.checkout($$[$0]); + break; + case 22: + yy.branch($$[$0]); + break; + case 23: + yy.branch($$[$0 - 2], $$[$0]); + break; + case 24: + yy.cherryPick($$[$0], "", void 0); + break; + case 25: + yy.cherryPick($$[$0 - 2], "", void 0, $$[$0]); + break; + case 26: + yy.cherryPick($$[$0 - 2], "", $$[$0]); + break; + case 27: + yy.cherryPick($$[$0 - 4], "", $$[$0], $$[$0 - 2]); + break; + case 28: + yy.cherryPick($$[$0 - 4], "", $$[$0 - 2], $$[$0]); + break; + case 29: + yy.cherryPick($$[$0], "", $$[$0 - 2]); + break; + case 30: + yy.cherryPick($$[$0], "", ""); + break; + case 31: + yy.cherryPick($$[$0 - 2], "", ""); + break; + case 32: + yy.cherryPick($$[$0 - 4], "", "", $$[$0 - 2]); + break; + case 33: + yy.cherryPick($$[$0 - 4], "", "", $$[$0]); + break; + case 34: + yy.cherryPick($$[$0 - 2], "", $$[$0 - 4], $$[$0]); + break; + case 35: + yy.cherryPick($$[$0 - 2], "", "", $$[$0]); + break; + case 36: + yy.merge($$[$0], "", "", ""); + break; + case 37: + yy.merge($$[$0 - 2], $$[$0], "", ""); + break; + case 38: + yy.merge($$[$0 - 2], "", $$[$0], ""); + break; + case 39: + yy.merge($$[$0 - 2], "", "", $$[$0]); + break; + case 40: + yy.merge($$[$0 - 4], $$[$0], "", $$[$0 - 2]); + break; + case 41: + yy.merge($$[$0 - 4], "", $$[$0], $$[$0 - 2]); + break; + case 42: + yy.merge($$[$0 - 4], "", $$[$0 - 2], $$[$0]); + break; + case 43: + yy.merge($$[$0 - 4], $$[$0 - 2], $$[$0], ""); + break; + case 44: + yy.merge($$[$0 - 4], $$[$0 - 2], "", $$[$0]); + break; + case 45: + yy.merge($$[$0 - 4], $$[$0], $$[$0 - 2], ""); + break; + case 46: + yy.merge($$[$0 - 6], $$[$0 - 4], $$[$0 - 2], $$[$0]); + break; + case 47: + yy.merge($$[$0 - 6], $$[$0], $$[$0 - 4], $$[$0 - 2]); + break; + case 48: + yy.merge($$[$0 - 6], $$[$0 - 4], $$[$0], $$[$0 - 2]); + break; + case 49: + yy.merge($$[$0 - 6], $$[$0 - 2], $$[$0 - 4], $$[$0]); + break; + case 50: + yy.merge($$[$0 - 6], $$[$0], $$[$0 - 2], $$[$0 - 4]); + break; + case 51: + yy.merge($$[$0 - 6], $$[$0 - 2], $$[$0], $$[$0 - 4]); + break; + case 52: + yy.commit($$[$0]); + break; + case 53: + yy.commit("", "", yy.commitType.NORMAL, $$[$0]); + break; + case 54: + yy.commit("", "", $$[$0], ""); + break; + case 55: + yy.commit("", "", $$[$0], $$[$0 - 2]); + break; + case 56: + yy.commit("", "", $$[$0 - 2], $$[$0]); + break; + case 57: + yy.commit("", $$[$0], yy.commitType.NORMAL, ""); + break; + case 58: + yy.commit("", $$[$0 - 2], yy.commitType.NORMAL, $$[$0]); + break; + case 59: + yy.commit("", $$[$0], yy.commitType.NORMAL, $$[$0 - 2]); + break; + case 60: + yy.commit("", $$[$0 - 2], $$[$0], ""); + break; + case 61: + yy.commit("", $$[$0], $$[$0 - 2], ""); + break; + case 62: + yy.commit("", $$[$0 - 4], $$[$0 - 2], $$[$0]); + break; + case 63: + yy.commit("", $$[$0 - 4], $$[$0], $$[$0 - 2]); + break; + case 64: + yy.commit("", $$[$0 - 2], $$[$0 - 4], $$[$0]); + break; + case 65: + yy.commit("", $$[$0], $$[$0 - 4], $$[$0 - 2]); + break; + case 66: + yy.commit("", $$[$0], $$[$0 - 2], $$[$0 - 4]); + break; + case 67: + yy.commit("", $$[$0 - 2], $$[$0], $$[$0 - 4]); + break; + case 68: + yy.commit($$[$0], "", yy.commitType.NORMAL, ""); + break; + case 69: + yy.commit($$[$0], "", yy.commitType.NORMAL, $$[$0 - 2]); + break; + case 70: + yy.commit($$[$0 - 2], "", yy.commitType.NORMAL, $$[$0]); + break; + case 71: + yy.commit($$[$0 - 2], "", $$[$0], ""); + break; + case 72: + yy.commit($$[$0], "", $$[$0 - 2], ""); + break; + case 73: + yy.commit($$[$0], $$[$0 - 2], yy.commitType.NORMAL, ""); + break; + case 74: + yy.commit($$[$0 - 2], $$[$0], yy.commitType.NORMAL, ""); + break; + case 75: + yy.commit($$[$0 - 4], "", $$[$0 - 2], $$[$0]); + break; + case 76: + yy.commit($$[$0 - 4], "", $$[$0], $$[$0 - 2]); + break; + case 77: + yy.commit($$[$0 - 2], "", $$[$0 - 4], $$[$0]); + break; + case 78: + yy.commit($$[$0], "", $$[$0 - 4], $$[$0 - 2]); + break; + case 79: + yy.commit($$[$0], "", $$[$0 - 2], $$[$0 - 4]); + break; + case 80: + yy.commit($$[$0 - 2], "", $$[$0], $$[$0 - 4]); + break; + case 81: + yy.commit($$[$0 - 4], $$[$0], $$[$0 - 2], ""); + break; + case 82: + yy.commit($$[$0 - 4], $$[$0 - 2], $$[$0], ""); + break; + case 83: + yy.commit($$[$0 - 2], $$[$0], $$[$0 - 4], ""); + break; + case 84: + yy.commit($$[$0], $$[$0 - 2], $$[$0 - 4], ""); + break; + case 85: + yy.commit($$[$0], $$[$0 - 4], $$[$0 - 2], ""); + break; + case 86: + yy.commit($$[$0 - 2], $$[$0 - 4], $$[$0], ""); + break; + case 87: + yy.commit($$[$0 - 4], $$[$0], yy.commitType.NORMAL, $$[$0 - 2]); + break; + case 88: + yy.commit($$[$0 - 4], $$[$0 - 2], yy.commitType.NORMAL, $$[$0]); + break; + case 89: + yy.commit($$[$0 - 2], $$[$0], yy.commitType.NORMAL, $$[$0 - 4]); + break; + case 90: + yy.commit($$[$0], $$[$0 - 2], yy.commitType.NORMAL, $$[$0 - 4]); + break; + case 91: + yy.commit($$[$0], $$[$0 - 4], yy.commitType.NORMAL, $$[$0 - 2]); + break; + case 92: + yy.commit($$[$0 - 2], $$[$0 - 4], yy.commitType.NORMAL, $$[$0]); + break; + case 93: + yy.commit($$[$0 - 6], $$[$0 - 4], $$[$0 - 2], $$[$0]); + break; + case 94: + yy.commit($$[$0 - 6], $$[$0 - 4], $$[$0], $$[$0 - 2]); + break; + case 95: + yy.commit($$[$0 - 6], $$[$0 - 2], $$[$0 - 4], $$[$0]); + break; + case 96: + yy.commit($$[$0 - 6], $$[$0], $$[$0 - 4], $$[$0 - 2]); + break; + case 97: + yy.commit($$[$0 - 6], $$[$0 - 2], $$[$0], $$[$0 - 4]); + break; + case 98: + yy.commit($$[$0 - 6], $$[$0], $$[$0 - 2], $$[$0 - 4]); + break; + case 99: + yy.commit($$[$0 - 4], $$[$0 - 6], $$[$0 - 2], $$[$0]); + break; + case 100: + yy.commit($$[$0 - 4], $$[$0 - 6], $$[$0], $$[$0 - 2]); + break; + case 101: + yy.commit($$[$0 - 2], $$[$0 - 6], $$[$0 - 4], $$[$0]); + break; + case 102: + yy.commit($$[$0], $$[$0 - 6], $$[$0 - 4], $$[$0 - 2]); + break; + case 103: + yy.commit($$[$0 - 2], $$[$0 - 6], $$[$0], $$[$0 - 4]); + break; + case 104: + yy.commit($$[$0], $$[$0 - 6], $$[$0 - 2], $$[$0 - 4]); + break; + case 105: + yy.commit($$[$0], $$[$0 - 4], $$[$0 - 2], $$[$0 - 6]); + break; + case 106: + yy.commit($$[$0 - 2], $$[$0 - 4], $$[$0], $$[$0 - 6]); + break; + case 107: + yy.commit($$[$0], $$[$0 - 2], $$[$0 - 4], $$[$0 - 6]); + break; + case 108: + yy.commit($$[$0 - 2], $$[$0], $$[$0 - 4], $$[$0 - 6]); + break; + case 109: + yy.commit($$[$0 - 4], $$[$0 - 2], $$[$0], $$[$0 - 6]); + break; + case 110: + yy.commit($$[$0 - 4], $$[$0], $$[$0 - 2], $$[$0 - 6]); + break; + case 111: + yy.commit($$[$0 - 2], $$[$0 - 4], $$[$0 - 6], $$[$0]); + break; + case 112: + yy.commit($$[$0], $$[$0 - 4], $$[$0 - 6], $$[$0 - 2]); + break; + case 113: + yy.commit($$[$0 - 2], $$[$0], $$[$0 - 6], $$[$0 - 4]); + break; + case 114: + yy.commit($$[$0], $$[$0 - 2], $$[$0 - 6], $$[$0 - 4]); + break; + case 115: + yy.commit($$[$0 - 4], $$[$0 - 2], $$[$0 - 6], $$[$0]); + break; + case 116: + yy.commit($$[$0 - 4], $$[$0], $$[$0 - 6], $$[$0 - 2]); + break; + case 117: + this.$ = ""; + break; + case 118: + this.$ = $$[$0]; + break; + case 119: + this.$ = yy.commitType.NORMAL; + break; + case 120: + this.$ = yy.commitType.REVERSE; + break; + case 121: + this.$ = yy.commitType.HIGHLIGHT; + break; + } + }, + table: [{ 3: 1, 4: 2, 5: $V0, 7: $V1, 13: $V2, 47: $V3 }, { 1: [3] }, { 3: 7, 4: 2, 5: $V0, 7: $V1, 13: $V2, 47: $V3 }, { 6: 8, 7: $V4, 8: [1, 9], 9: [1, 10], 10: 11, 13: $V5 }, o($V6, [2, 124]), o($V6, [2, 125]), o($V6, [2, 126]), { 1: [2, 1] }, { 7: [1, 13] }, { 6: 14, 7: $V4, 10: 11, 13: $V5 }, { 8: [1, 15] }, o($V7, [2, 9], { 11: 16, 12: [1, 17] }), o($V8, [2, 8]), { 1: [2, 2] }, { 7: [1, 18] }, { 6: 19, 7: $V4, 10: 11, 13: $V5 }, { 7: [2, 6], 13: [1, 22], 14: 20, 15: 21, 16: 23, 17: 24, 18: 25, 19: [1, 26], 21: [1, 27], 23: [1, 28], 24: [1, 29], 25: 30, 26: [1, 31], 28: [1, 35], 31: [1, 34], 37: [1, 33], 40: [1, 32] }, o($V8, [2, 7]), { 1: [2, 3] }, { 7: [1, 36] }, o($V7, [2, 10]), { 4: 37, 7: $V1, 13: $V2, 47: $V3 }, o($V7, [2, 12]), o($V9, [2, 13]), o($V9, [2, 14]), o($V9, [2, 15]), { 20: [1, 38] }, { 22: [1, 39] }, o($V9, [2, 18]), o($V9, [2, 19]), o($V9, [2, 20]), { 27: 40, 33: $Va, 46: $Vb }, o($V9, [2, 117], { 41: 43, 32: [1, 46], 33: [1, 48], 35: [1, 44], 38: [1, 45], 42: [1, 47] }), { 27: 49, 33: $Va, 46: $Vb }, { 32: [1, 50], 35: [1, 51] }, { 27: 52, 33: $Va, 46: $Vb }, { 1: [2, 4] }, o($V7, [2, 11]), o($V9, [2, 16]), o($V9, [2, 17]), o($V9, [2, 21]), o($Vc, [2, 122]), o($Vc, [2, 123]), o($V9, [2, 52]), { 33: [1, 53] }, { 39: 54, 43: $Vd, 44: $Ve, 45: $Vf }, { 33: [1, 58] }, { 33: [1, 59] }, o($V9, [2, 118]), o($V9, [2, 36], { 32: [1, 60], 35: [1, 62], 38: [1, 61] }), { 33: [1, 63] }, { 33: [1, 64], 36: [1, 65] }, o($V9, [2, 22], { 29: [1, 66] }), o($V9, [2, 53], { 32: [1, 68], 38: [1, 67], 42: [1, 69] }), o($V9, [2, 54], { 32: [1, 71], 35: [1, 70], 42: [1, 72] }), o($Vg, [2, 119]), o($Vg, [2, 120]), o($Vg, [2, 121]), o($V9, [2, 57], { 35: [1, 73], 38: [1, 74], 42: [1, 75] }), o($V9, [2, 68], { 32: [1, 78], 35: [1, 76], 38: [1, 77] }), { 33: [1, 79] }, { 39: 80, 43: $Vd, 44: $Ve, 45: $Vf }, { 33: [1, 81] }, o($V9, [2, 24], { 34: [1, 82], 35: [1, 83] }), { 32: [1, 84] }, { 32: [1, 85] }, { 30: [1, 86] }, { 39: 87, 43: $Vd, 44: $Ve, 45: $Vf }, { 33: [1, 88] }, { 33: [1, 89] }, { 33: [1, 90] }, { 33: [1, 91] }, { 33: [1, 92] }, { 33: [1, 93] }, { 39: 94, 43: $Vd, 44: $Ve, 45: $Vf }, { 33: [1, 95] }, { 33: [1, 96] }, { 39: 97, 43: $Vd, 44: $Ve, 45: $Vf }, { 33: [1, 98] }, o($V9, [2, 37], { 35: [1, 100], 38: [1, 99] }), o($V9, [2, 38], { 32: [1, 102], 35: [1, 101] }), o($V9, [2, 39], { 32: [1, 103], 38: [1, 104] }), { 33: [1, 105] }, { 33: [1, 106], 36: [1, 107] }, { 33: [1, 108] }, { 33: [1, 109] }, o($V9, [2, 23]), o($V9, [2, 55], { 32: [1, 110], 42: [1, 111] }), o($V9, [2, 59], { 38: [1, 112], 42: [1, 113] }), o($V9, [2, 69], { 32: [1, 115], 38: [1, 114] }), o($V9, [2, 56], { 32: [1, 116], 42: [1, 117] }), o($V9, [2, 61], { 35: [1, 118], 42: [1, 119] }), o($V9, [2, 72], { 32: [1, 121], 35: [1, 120] }), o($V9, [2, 58], { 38: [1, 122], 42: [1, 123] }), o($V9, [2, 60], { 35: [1, 124], 42: [1, 125] }), o($V9, [2, 73], { 35: [1, 127], 38: [1, 126] }), o($V9, [2, 70], { 32: [1, 129], 38: [1, 128] }), o($V9, [2, 71], { 32: [1, 131], 35: [1, 130] }), o($V9, [2, 74], { 35: [1, 133], 38: [1, 132] }), { 39: 134, 43: $Vd, 44: $Ve, 45: $Vf }, { 33: [1, 135] }, { 33: [1, 136] }, { 33: [1, 137] }, { 33: [1, 138] }, { 39: 139, 43: $Vd, 44: $Ve, 45: $Vf }, o($V9, [2, 25], { 35: [1, 140] }), o($V9, [2, 26], { 34: [1, 141] }), o($V9, [2, 31], { 34: [1, 142] }), o($V9, [2, 29], { 34: [1, 143] }), o($V9, [2, 30], { 34: [1, 144] }), { 33: [1, 145] }, { 33: [1, 146] }, { 39: 147, 43: $Vd, 44: $Ve, 45: $Vf }, { 33: [1, 148] }, { 39: 149, 43: $Vd, 44: $Ve, 45: $Vf }, { 33: [1, 150] }, { 33: [1, 151] }, { 33: [1, 152] }, { 33: [1, 153] }, { 33: [1, 154] }, { 33: [1, 155] }, { 33: [1, 156] }, { 39: 157, 43: $Vd, 44: $Ve, 45: $Vf }, { 33: [1, 158] }, { 33: [1, 159] }, { 33: [1, 160] }, { 39: 161, 43: $Vd, 44: $Ve, 45: $Vf }, { 33: [1, 162] }, { 39: 163, 43: $Vd, 44: $Ve, 45: $Vf }, { 33: [1, 164] }, { 33: [1, 165] }, { 33: [1, 166] }, { 39: 167, 43: $Vd, 44: $Ve, 45: $Vf }, { 33: [1, 168] }, o($V9, [2, 43], { 35: [1, 169] }), o($V9, [2, 44], { 38: [1, 170] }), o($V9, [2, 42], { 32: [1, 171] }), o($V9, [2, 45], { 35: [1, 172] }), o($V9, [2, 40], { 38: [1, 173] }), o($V9, [2, 41], { 32: [1, 174] }), { 33: [1, 175], 36: [1, 176] }, { 33: [1, 177] }, { 33: [1, 178] }, { 33: [1, 179] }, { 33: [1, 180] }, o($V9, [2, 66], { 42: [1, 181] }), o($V9, [2, 79], { 32: [1, 182] }), o($V9, [2, 67], { 42: [1, 183] }), o($V9, [2, 90], { 38: [1, 184] }), o($V9, [2, 80], { 32: [1, 185] }), o($V9, [2, 89], { 38: [1, 186] }), o($V9, [2, 65], { 42: [1, 187] }), o($V9, [2, 78], { 32: [1, 188] }), o($V9, [2, 64], { 42: [1, 189] }), o($V9, [2, 84], { 35: [1, 190] }), o($V9, [2, 77], { 32: [1, 191] }), o($V9, [2, 83], { 35: [1, 192] }), o($V9, [2, 63], { 42: [1, 193] }), o($V9, [2, 91], { 38: [1, 194] }), o($V9, [2, 62], { 42: [1, 195] }), o($V9, [2, 85], { 35: [1, 196] }), o($V9, [2, 86], { 35: [1, 197] }), o($V9, [2, 92], { 38: [1, 198] }), o($V9, [2, 76], { 32: [1, 199] }), o($V9, [2, 87], { 38: [1, 200] }), o($V9, [2, 75], { 32: [1, 201] }), o($V9, [2, 81], { 35: [1, 202] }), o($V9, [2, 82], { 35: [1, 203] }), o($V9, [2, 88], { 38: [1, 204] }), { 33: [1, 205] }, { 39: 206, 43: $Vd, 44: $Ve, 45: $Vf }, { 33: [1, 207] }, { 33: [1, 208] }, { 39: 209, 43: $Vd, 44: $Ve, 45: $Vf }, { 33: [1, 210] }, o($V9, [2, 27]), o($V9, [2, 32]), o($V9, [2, 28]), o($V9, [2, 33]), o($V9, [2, 34]), o($V9, [2, 35]), { 33: [1, 211] }, { 33: [1, 212] }, { 33: [1, 213] }, { 39: 214, 43: $Vd, 44: $Ve, 45: $Vf }, { 33: [1, 215] }, { 39: 216, 43: $Vd, 44: $Ve, 45: $Vf }, { 33: [1, 217] }, { 33: [1, 218] }, { 33: [1, 219] }, { 33: [1, 220] }, { 33: [1, 221] }, { 33: [1, 222] }, { 33: [1, 223] }, { 39: 224, 43: $Vd, 44: $Ve, 45: $Vf }, { 33: [1, 225] }, { 33: [1, 226] }, { 33: [1, 227] }, { 39: 228, 43: $Vd, 44: $Ve, 45: $Vf }, { 33: [1, 229] }, { 39: 230, 43: $Vd, 44: $Ve, 45: $Vf }, { 33: [1, 231] }, { 33: [1, 232] }, { 33: [1, 233] }, { 39: 234, 43: $Vd, 44: $Ve, 45: $Vf }, o($V9, [2, 46]), o($V9, [2, 48]), o($V9, [2, 47]), o($V9, [2, 49]), o($V9, [2, 51]), o($V9, [2, 50]), o($V9, [2, 107]), o($V9, [2, 108]), o($V9, [2, 105]), o($V9, [2, 106]), o($V9, [2, 110]), o($V9, [2, 109]), o($V9, [2, 114]), o($V9, [2, 113]), o($V9, [2, 112]), o($V9, [2, 111]), o($V9, [2, 116]), o($V9, [2, 115]), o($V9, [2, 104]), o($V9, [2, 103]), o($V9, [2, 102]), o($V9, [2, 101]), o($V9, [2, 99]), o($V9, [2, 100]), o($V9, [2, 98]), o($V9, [2, 97]), o($V9, [2, 96]), o($V9, [2, 95]), o($V9, [2, 93]), o($V9, [2, 94])], + defaultActions: { 7: [2, 1], 13: [2, 2], 18: [2, 3], 36: [2, 4] }, + parseError: function parseError(str2, hash) { + if (hash.recoverable) { + this.trace(str2); + } else { + var error = new Error(str2); + error.hash = hash; + throw error; + } + }, + parse: function parse2(input) { + var self2 = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex2() { + var token2; + token2 = tstack.pop() || lexer2.lex() || EOF; + if (typeof token2 !== "number") { + if (token2 instanceof Array) { + tstack = token2; + token2 = tstack.pop(); + } + token2 = self2.symbols_[token2] || token2; + } + return token2; + } + var symbol, state2, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state2 = stack[stack.length - 1]; + if (this.defaultActions[state2]) { + action = this.defaultActions[state2]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex2(); + } + action = table[state2] && table[state2][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state2]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state2 + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str2, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str2, hash); + } else { + throw new Error(str2); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch2 = this._input[0]; + this.yytext += ch2; + this.yyleng++; + this.offset++; + this.match += ch2; + this.matched += ch2; + var lines = ch2.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch2; + }, + // unshifts one char (or a string) into the input + unput: function(ch2) { + var len = ch2.length; + var lines = ch2.split(/(?:\r\n?|\n)/g); + this._input = ch2 + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next2 = this.match; + if (next2.length < 20) { + next2 += this._input.substr(0, 20 - next2.length); + } + return (next2.substr(0, 20) + (next2.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c2 = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c2 + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token2, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token2 = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token2) { + return token2; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token2, match, tempMatch, index2; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i2 = 0; i2 < rules.length; i2++) { + tempMatch = this._input.match(this.rules[rules[i2]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index2 = i2; + if (this.options.backtrack_lexer) { + token2 = this.test_match(tempMatch, rules[i2]); + if (token2 !== false) { + return token2; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token2 = this.test_match(match, rules[index2]); + if (token2 !== false) { + return token2; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex2() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + this.begin("acc_title"); + return 19; + case 1: + this.popState(); + return "acc_title_value"; + case 2: + this.begin("acc_descr"); + return 21; + case 3: + this.popState(); + return "acc_descr_value"; + case 4: + this.begin("acc_descr_multiline"); + break; + case 5: + this.popState(); + break; + case 6: + return "acc_descr_multiline_value"; + case 7: + return 13; + case 8: + break; + case 9: + break; + case 10: + return 5; + case 11: + return 40; + case 12: + return 32; + case 13: + return 38; + case 14: + return 42; + case 15: + return 43; + case 16: + return 44; + case 17: + return 45; + case 18: + return 35; + case 19: + return 28; + case 20: + return 29; + case 21: + return 37; + case 22: + return 31; + case 23: + return 34; + case 24: + return 26; + case 25: + return 9; + case 26: + return 9; + case 27: + return 8; + case 28: + return "CARET"; + case 29: + this.begin("options"); + break; + case 30: + this.popState(); + break; + case 31: + return 12; + case 32: + return 36; + case 33: + this.begin("string"); + break; + case 34: + this.popState(); + break; + case 35: + return 33; + case 36: + return 30; + case 37: + return 46; + case 38: + return 7; + } + }, + rules: [/^(?:accTitle\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*\{\s*)/i, /^(?:[\}])/i, /^(?:[^\}]*)/i, /^(?:(\r?\n)+)/i, /^(?:#[^\n]*)/i, /^(?:%[^\n]*)/i, /^(?:gitGraph\b)/i, /^(?:commit(?=\s|$))/i, /^(?:id:)/i, /^(?:type:)/i, /^(?:msg:)/i, /^(?:NORMAL\b)/i, /^(?:REVERSE\b)/i, /^(?:HIGHLIGHT\b)/i, /^(?:tag:)/i, /^(?:branch(?=\s|$))/i, /^(?:order:)/i, /^(?:merge(?=\s|$))/i, /^(?:cherry-pick(?=\s|$))/i, /^(?:parent:)/i, /^(?:checkout(?=\s|$))/i, /^(?:LR\b)/i, /^(?:TB\b)/i, /^(?::)/i, /^(?:\^)/i, /^(?:options\r?\n)/i, /^(?:[ \r\n\t]+end\b)/i, /^(?:[\s\S]+(?=[ \r\n\t]+end))/i, /^(?:["]["])/i, /^(?:["])/i, /^(?:["])/i, /^(?:[^"]*)/i, /^(?:[0-9]+(?=\s|$))/i, /^(?:\w([-\./\w]*[-\w])?)/i, /^(?:$)/i, /^(?:\s+)/i], + conditions: { "acc_descr_multiline": { "rules": [5, 6], "inclusive": false }, "acc_descr": { "rules": [3], "inclusive": false }, "acc_title": { "rules": [1], "inclusive": false }, "options": { "rules": [30, 31], "inclusive": false }, "string": { "rules": [34, 35], "inclusive": false }, "INITIAL": { "rules": [0, 2, 4, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 32, 33, 36, 37, 38, 39], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser2() { + this.yy = {}; + } + Parser2.prototype = parser2; + parser2.Parser = Parser2; + return new Parser2(); + }(); + parser$r.parser = parser$r; + const gitGraphParser = parser$r; + let mainBranchName = getConfig$1().gitGraph.mainBranchName; + let mainBranchOrder = getConfig$1().gitGraph.mainBranchOrder; + let commits = {}; + let head = null; + let branchesConfig = {}; + branchesConfig[mainBranchName] = { name: mainBranchName, order: mainBranchOrder }; + let branches = {}; + branches[mainBranchName] = head; + let curBranch = mainBranchName; + let direction$2 = "LR"; + let seq = 0; + function getId() { + return random({ length: 7 }); + } + function uniqBy(list2, fn) { + const recordMap = /* @__PURE__ */ Object.create(null); + return list2.reduce((out, item) => { + const key = fn(item); + if (!recordMap[key]) { + recordMap[key] = true; + out.push(item); + } + return out; + }, []); + } + const setDirection$2 = function(dir2) { + direction$2 = dir2; + }; + let options = {}; + const setOptions = function(rawOptString) { + log$1.debug("options str", rawOptString); + rawOptString = rawOptString && rawOptString.trim(); + rawOptString = rawOptString || "{}"; + try { + options = JSON.parse(rawOptString); + } catch (e) { + log$1.error("error while parsing gitGraph options", e.message); + } + }; + const getOptions = function() { + return options; + }; + const commit = function(msg, id2, type2, tag) { + log$1.debug("Entering commit:", msg, id2, type2, tag); + id2 = common$1.sanitizeText(id2, getConfig$1()); + msg = common$1.sanitizeText(msg, getConfig$1()); + tag = common$1.sanitizeText(tag, getConfig$1()); + const commit2 = { + id: id2 ? id2 : seq + "-" + getId(), + message: msg, + seq: seq++, + type: type2 ? type2 : commitType$1.NORMAL, + tag: tag ? tag : "", + parents: head == null ? [] : [head.id], + branch: curBranch + }; + head = commit2; + commits[commit2.id] = commit2; + branches[curBranch] = commit2.id; + log$1.debug("in pushCommit " + commit2.id); + }; + const branch = function(name, order2) { + name = common$1.sanitizeText(name, getConfig$1()); + if (branches[name] === void 0) { + branches[name] = head != null ? head.id : null; + branchesConfig[name] = { name, order: order2 ? parseInt(order2, 10) : null }; + checkout(name); + log$1.debug("in createBranch"); + } else { + let error = new Error( + 'Trying to create an existing branch. (Help: Either use a new name if you want create a new branch or try using "checkout ' + name + '")' + ); + error.hash = { + text: "branch " + name, + token: "branch " + name, + line: "1", + loc: { first_line: 1, last_line: 1, first_column: 1, last_column: 1 }, + expected: ['"checkout ' + name + '"'] + }; + throw error; + } + }; + const merge = function(otherBranch, custom_id, override_type, custom_tag) { + otherBranch = common$1.sanitizeText(otherBranch, getConfig$1()); + custom_id = common$1.sanitizeText(custom_id, getConfig$1()); + const currentCommit = commits[branches[curBranch]]; + const otherCommit = commits[branches[otherBranch]]; + if (curBranch === otherBranch) { + let error = new Error('Incorrect usage of "merge". Cannot merge a branch to itself'); + error.hash = { + text: "merge " + otherBranch, + token: "merge " + otherBranch, + line: "1", + loc: { first_line: 1, last_line: 1, first_column: 1, last_column: 1 }, + expected: ["branch abc"] + }; + throw error; + } else if (currentCommit === void 0 || !currentCommit) { + let error = new Error( + 'Incorrect usage of "merge". Current branch (' + curBranch + ")has no commits" + ); + error.hash = { + text: "merge " + otherBranch, + token: "merge " + otherBranch, + line: "1", + loc: { first_line: 1, last_line: 1, first_column: 1, last_column: 1 }, + expected: ["commit"] + }; + throw error; + } else if (branches[otherBranch] === void 0) { + let error = new Error( + 'Incorrect usage of "merge". Branch to be merged (' + otherBranch + ") does not exist" + ); + error.hash = { + text: "merge " + otherBranch, + token: "merge " + otherBranch, + line: "1", + loc: { first_line: 1, last_line: 1, first_column: 1, last_column: 1 }, + expected: ["branch " + otherBranch] + }; + throw error; + } else if (otherCommit === void 0 || !otherCommit) { + let error = new Error( + 'Incorrect usage of "merge". Branch to be merged (' + otherBranch + ") has no commits" + ); + error.hash = { + text: "merge " + otherBranch, + token: "merge " + otherBranch, + line: "1", + loc: { first_line: 1, last_line: 1, first_column: 1, last_column: 1 }, + expected: ['"commit"'] + }; + throw error; + } else if (currentCommit === otherCommit) { + let error = new Error('Incorrect usage of "merge". Both branches have same head'); + error.hash = { + text: "merge " + otherBranch, + token: "merge " + otherBranch, + line: "1", + loc: { first_line: 1, last_line: 1, first_column: 1, last_column: 1 }, + expected: ["branch abc"] + }; + throw error; + } else if (custom_id && commits[custom_id] !== void 0) { + let error = new Error( + 'Incorrect usage of "merge". Commit with id:' + custom_id + " already exists, use different custom Id" + ); + error.hash = { + text: "merge " + otherBranch + custom_id + override_type + custom_tag, + token: "merge " + otherBranch + custom_id + override_type + custom_tag, + line: "1", + loc: { first_line: 1, last_line: 1, first_column: 1, last_column: 1 }, + expected: [ + "merge " + otherBranch + " " + custom_id + "_UNIQUE " + override_type + " " + custom_tag + ] + }; + throw error; + } + const commit2 = { + id: custom_id ? custom_id : seq + "-" + getId(), + message: "merged branch " + otherBranch + " into " + curBranch, + seq: seq++, + parents: [head == null ? null : head.id, branches[otherBranch]], + branch: curBranch, + type: commitType$1.MERGE, + customType: override_type, + customId: custom_id ? true : false, + tag: custom_tag ? custom_tag : "" + }; + head = commit2; + commits[commit2.id] = commit2; + branches[curBranch] = commit2.id; + log$1.debug(branches); + log$1.debug("in mergeBranch"); + }; + const cherryPick = function(sourceId, targetId, tag, parentCommitId) { + log$1.debug("Entering cherryPick:", sourceId, targetId, tag); + sourceId = common$1.sanitizeText(sourceId, getConfig$1()); + targetId = common$1.sanitizeText(targetId, getConfig$1()); + tag = common$1.sanitizeText(tag, getConfig$1()); + parentCommitId = common$1.sanitizeText(parentCommitId, getConfig$1()); + if (!sourceId || commits[sourceId] === void 0) { + let error = new Error( + 'Incorrect usage of "cherryPick". Source commit id should exist and provided' + ); + error.hash = { + text: "cherryPick " + sourceId + " " + targetId, + token: "cherryPick " + sourceId + " " + targetId, + line: "1", + loc: { first_line: 1, last_line: 1, first_column: 1, last_column: 1 }, + expected: ["cherry-pick abc"] + }; + throw error; + } + let sourceCommit = commits[sourceId]; + let sourceCommitBranch = sourceCommit.branch; + if (parentCommitId && !(Array.isArray(sourceCommit.parents) && sourceCommit.parents.includes(parentCommitId))) { + let error = new Error( + "Invalid operation: The specified parent commit is not an immediate parent of the cherry-picked commit." + ); + throw error; + } + if (sourceCommit.type === commitType$1.MERGE && !parentCommitId) { + let error = new Error( + "Incorrect usage of cherry-pick: If the source commit is a merge commit, an immediate parent commit must be specified." + ); + throw error; + } + if (!targetId || commits[targetId] === void 0) { + if (sourceCommitBranch === curBranch) { + let error = new Error( + 'Incorrect usage of "cherryPick". Source commit is already on current branch' + ); + error.hash = { + text: "cherryPick " + sourceId + " " + targetId, + token: "cherryPick " + sourceId + " " + targetId, + line: "1", + loc: { first_line: 1, last_line: 1, first_column: 1, last_column: 1 }, + expected: ["cherry-pick abc"] + }; + throw error; + } + const currentCommit = commits[branches[curBranch]]; + if (currentCommit === void 0 || !currentCommit) { + let error = new Error( + 'Incorrect usage of "cherry-pick". Current branch (' + curBranch + ")has no commits" + ); + error.hash = { + text: "cherryPick " + sourceId + " " + targetId, + token: "cherryPick " + sourceId + " " + targetId, + line: "1", + loc: { first_line: 1, last_line: 1, first_column: 1, last_column: 1 }, + expected: ["cherry-pick abc"] + }; + throw error; + } + const commit2 = { + id: seq + "-" + getId(), + message: "cherry-picked " + sourceCommit + " into " + curBranch, + seq: seq++, + parents: [head == null ? null : head.id, sourceCommit.id], + branch: curBranch, + type: commitType$1.CHERRY_PICK, + tag: tag ?? `cherry-pick:${sourceCommit.id}${sourceCommit.type === commitType$1.MERGE ? `|parent:${parentCommitId}` : ""}` + }; + head = commit2; + commits[commit2.id] = commit2; + branches[curBranch] = commit2.id; + log$1.debug(branches); + log$1.debug("in cherryPick"); + } + }; + const checkout = function(branch2) { + branch2 = common$1.sanitizeText(branch2, getConfig$1()); + if (branches[branch2] === void 0) { + let error = new Error( + 'Trying to checkout branch which is not yet created. (Help try using "branch ' + branch2 + '")' + ); + error.hash = { + text: "checkout " + branch2, + token: "checkout " + branch2, + line: "1", + loc: { first_line: 1, last_line: 1, first_column: 1, last_column: 1 }, + expected: ['"branch ' + branch2 + '"'] + }; + throw error; + } else { + curBranch = branch2; + const id2 = branches[curBranch]; + head = commits[id2]; + } + }; + function upsert(arr, key, newVal) { + const index2 = arr.indexOf(key); + if (index2 === -1) { + arr.push(newVal); + } else { + arr.splice(index2, 1, newVal); + } + } + function prettyPrintCommitHistory(commitArr) { + const commit2 = commitArr.reduce((out, commit3) => { + if (out.seq > commit3.seq) { + return out; + } + return commit3; + }, commitArr[0]); + let line2 = ""; + commitArr.forEach(function(c2) { + if (c2 === commit2) { + line2 += " *"; + } else { + line2 += " |"; + } + }); + const label = [line2, commit2.id, commit2.seq]; + for (let branch2 in branches) { + if (branches[branch2] === commit2.id) { + label.push(branch2); + } + } + log$1.debug(label.join(" ")); + if (commit2.parents && commit2.parents.length == 2) { + const newCommit = commits[commit2.parents[0]]; + upsert(commitArr, commit2, newCommit); + commitArr.push(commits[commit2.parents[1]]); + } else if (commit2.parents.length == 0) { + return; + } else { + const nextCommit = commits[commit2.parents]; + upsert(commitArr, commit2, nextCommit); + } + commitArr = uniqBy(commitArr, (c2) => c2.id); + prettyPrintCommitHistory(commitArr); + } + const prettyPrint = function() { + log$1.debug(commits); + const node2 = getCommitsArray()[0]; + prettyPrintCommitHistory([node2]); + }; + const clear$f = function() { + commits = {}; + head = null; + let mainBranch = getConfig$1().gitGraph.mainBranchName; + let mainBranchOrder2 = getConfig$1().gitGraph.mainBranchOrder; + branches = {}; + branches[mainBranch] = null; + branchesConfig = {}; + branchesConfig[mainBranch] = { name: mainBranch, order: mainBranchOrder2 }; + curBranch = mainBranch; + seq = 0; + clear$n(); + }; + const getBranchesAsObjArray = function() { + const branchesArray = Object.values(branchesConfig).map((branchConfig, i2) => { + if (branchConfig.order !== null) { + return branchConfig; + } + return { + ...branchConfig, + order: parseFloat(`0.${i2}`, 10) + }; + }).sort((a, b) => a.order - b.order).map(({ name }) => ({ name })); + return branchesArray; + }; + const getBranches = function() { + return branches; + }; + const getCommits = function() { + return commits; + }; + const getCommitsArray = function() { + const commitArr = Object.keys(commits).map(function(key) { + return commits[key]; + }); + commitArr.forEach(function(o) { + log$1.debug(o.id); + }); + commitArr.sort((a, b) => a.seq - b.seq); + return commitArr; + }; + const getCurrentBranch = function() { + return curBranch; + }; + const getDirection$2 = function() { + return direction$2; + }; + const getHead = function() { + return head; + }; + const commitType$1 = { + NORMAL: 0, + REVERSE: 1, + HIGHLIGHT: 2, + MERGE: 3, + CHERRY_PICK: 4 + }; + const gitGraphDb = { + getConfig: () => getConfig$1().gitGraph, + setDirection: setDirection$2, + setOptions, + getOptions, + commit, + branch, + merge, + cherryPick, + checkout, + //reset, + prettyPrint, + clear: clear$f, + getBranchesAsObjArray, + getBranches, + getCommits, + getCommitsArray, + getCurrentBranch, + getDirection: getDirection$2, + getHead, + setAccTitle, + getAccTitle, + getAccDescription, + setAccDescription, + setDiagramTitle, + getDiagramTitle, + commitType: commitType$1 + }; + let allCommitsDict = {}; + const commitType = { + NORMAL: 0, + REVERSE: 1, + HIGHLIGHT: 2, + MERGE: 3, + CHERRY_PICK: 4 + }; + const THEME_COLOR_LIMIT = 8; + let branchPos = {}; + let commitPos = {}; + let lanes = []; + let maxPos = 0; + let dir = "LR"; + const clear$e = () => { + branchPos = {}; + commitPos = {}; + allCommitsDict = {}; + maxPos = 0; + lanes = []; + dir = "LR"; + }; + const drawText$3 = (txt) => { + const svgLabel = document.createElementNS("http://www.w3.org/2000/svg", "text"); + let rows = []; + if (typeof txt === "string") { + rows = txt.split(/\\n|\n|/gi); + } else if (Array.isArray(txt)) { + rows = txt; + } else { + rows = []; + } + for (const row of rows) { + const tspan = document.createElementNS("http://www.w3.org/2000/svg", "tspan"); + tspan.setAttributeNS("http://www.w3.org/XML/1998/namespace", "xml:space", "preserve"); + tspan.setAttribute("dy", "1em"); + tspan.setAttribute("x", "0"); + tspan.setAttribute("class", "row"); + tspan.textContent = row.trim(); + svgLabel.appendChild(tspan); + } + return svgLabel; + }; + const findClosestParent = (parents2) => { + let closestParent = ""; + let maxPosition = 0; + parents2.forEach((parent) => { + const parentPosition = dir === "TB" ? commitPos[parent].y : commitPos[parent].x; + if (parentPosition >= maxPosition) { + closestParent = parent; + maxPosition = parentPosition; + } + }); + return closestParent || void 0; + }; + const drawCommits = (svg2, commits2, modifyGraph) => { + const gitGraphConfig = getConfig$1().gitGraph; + const gBullets = svg2.append("g").attr("class", "commit-bullets"); + const gLabels = svg2.append("g").attr("class", "commit-labels"); + let pos = 0; + if (dir === "TB") { + pos = 30; + } + const keys2 = Object.keys(commits2); + const sortedKeys = keys2.sort((a, b) => { + return commits2[a].seq - commits2[b].seq; + }); + const isParallelCommits = gitGraphConfig.parallelCommits; + const layoutOffset = 10; + const commitStep = 40; + sortedKeys.forEach((key) => { + const commit2 = commits2[key]; + if (isParallelCommits) { + if (commit2.parents.length) { + const closestParent = findClosestParent(commit2.parents); + pos = dir === "TB" ? commitPos[closestParent].y + commitStep : commitPos[closestParent].x + commitStep; + } else { + pos = 0; + if (dir === "TB") { + pos = 30; + } + } + } + const posWithOffset = pos + layoutOffset; + const y2 = dir === "TB" ? posWithOffset : branchPos[commit2.branch].pos; + const x2 = dir === "TB" ? branchPos[commit2.branch].pos : posWithOffset; + if (modifyGraph) { + let typeClass; + let commitSymbolType = commit2.customType !== void 0 && commit2.customType !== "" ? commit2.customType : commit2.type; + switch (commitSymbolType) { + case commitType.NORMAL: + typeClass = "commit-normal"; + break; + case commitType.REVERSE: + typeClass = "commit-reverse"; + break; + case commitType.HIGHLIGHT: + typeClass = "commit-highlight"; + break; + case commitType.MERGE: + typeClass = "commit-merge"; + break; + case commitType.CHERRY_PICK: + typeClass = "commit-cherry-pick"; + break; + default: + typeClass = "commit-normal"; + } + if (commitSymbolType === commitType.HIGHLIGHT) { + const circle2 = gBullets.append("rect"); + circle2.attr("x", x2 - 10); + circle2.attr("y", y2 - 10); + circle2.attr("height", 20); + circle2.attr("width", 20); + circle2.attr( + "class", + `commit ${commit2.id} commit-highlight${branchPos[commit2.branch].index % THEME_COLOR_LIMIT} ${typeClass}-outer` + ); + gBullets.append("rect").attr("x", x2 - 6).attr("y", y2 - 6).attr("height", 12).attr("width", 12).attr( + "class", + `commit ${commit2.id} commit${branchPos[commit2.branch].index % THEME_COLOR_LIMIT} ${typeClass}-inner` + ); + } else if (commitSymbolType === commitType.CHERRY_PICK) { + gBullets.append("circle").attr("cx", x2).attr("cy", y2).attr("r", 10).attr("class", `commit ${commit2.id} ${typeClass}`); + gBullets.append("circle").attr("cx", x2 - 3).attr("cy", y2 + 2).attr("r", 2.75).attr("fill", "#fff").attr("class", `commit ${commit2.id} ${typeClass}`); + gBullets.append("circle").attr("cx", x2 + 3).attr("cy", y2 + 2).attr("r", 2.75).attr("fill", "#fff").attr("class", `commit ${commit2.id} ${typeClass}`); + gBullets.append("line").attr("x1", x2 + 3).attr("y1", y2 + 1).attr("x2", x2).attr("y2", y2 - 5).attr("stroke", "#fff").attr("class", `commit ${commit2.id} ${typeClass}`); + gBullets.append("line").attr("x1", x2 - 3).attr("y1", y2 + 1).attr("x2", x2).attr("y2", y2 - 5).attr("stroke", "#fff").attr("class", `commit ${commit2.id} ${typeClass}`); + } else { + const circle2 = gBullets.append("circle"); + circle2.attr("cx", x2); + circle2.attr("cy", y2); + circle2.attr("r", commit2.type === commitType.MERGE ? 9 : 10); + circle2.attr( + "class", + `commit ${commit2.id} commit${branchPos[commit2.branch].index % THEME_COLOR_LIMIT}` + ); + if (commitSymbolType === commitType.MERGE) { + const circle22 = gBullets.append("circle"); + circle22.attr("cx", x2); + circle22.attr("cy", y2); + circle22.attr("r", 6); + circle22.attr( + "class", + `commit ${typeClass} ${commit2.id} commit${branchPos[commit2.branch].index % THEME_COLOR_LIMIT}` + ); + } + if (commitSymbolType === commitType.REVERSE) { + const cross2 = gBullets.append("path"); + cross2.attr("d", `M ${x2 - 5},${y2 - 5}L${x2 + 5},${y2 + 5}M${x2 - 5},${y2 + 5}L${x2 + 5},${y2 - 5}`).attr( + "class", + `commit ${typeClass} ${commit2.id} commit${branchPos[commit2.branch].index % THEME_COLOR_LIMIT}` + ); + } + } + } + if (dir === "TB") { + commitPos[commit2.id] = { x: x2, y: posWithOffset }; + } else { + commitPos[commit2.id] = { x: posWithOffset, y: y2 }; + } + if (modifyGraph) { + const px = 4; + const py = 2; + if (commit2.type !== commitType.CHERRY_PICK && (commit2.customId && commit2.type === commitType.MERGE || commit2.type !== commitType.MERGE) && gitGraphConfig.showCommitLabel) { + const wrapper = gLabels.append("g"); + const labelBkg = wrapper.insert("rect").attr("class", "commit-label-bkg"); + const text2 = wrapper.append("text").attr("x", pos).attr("y", y2 + 25).attr("class", "commit-label").text(commit2.id); + let bbox = text2.node().getBBox(); + labelBkg.attr("x", posWithOffset - bbox.width / 2 - py).attr("y", y2 + 13.5).attr("width", bbox.width + 2 * py).attr("height", bbox.height + 2 * py); + if (dir === "TB") { + labelBkg.attr("x", x2 - (bbox.width + 4 * px + 5)).attr("y", y2 - 12); + text2.attr("x", x2 - (bbox.width + 4 * px)).attr("y", y2 + bbox.height - 12); + } + if (dir !== "TB") { + text2.attr("x", posWithOffset - bbox.width / 2); + } + if (gitGraphConfig.rotateCommitLabel) { + if (dir === "TB") { + text2.attr("transform", "rotate(-45, " + x2 + ", " + y2 + ")"); + labelBkg.attr("transform", "rotate(-45, " + x2 + ", " + y2 + ")"); + } else { + let r_x = -7.5 - (bbox.width + 10) / 25 * 9.5; + let r_y = 10 + bbox.width / 25 * 8.5; + wrapper.attr( + "transform", + "translate(" + r_x + ", " + r_y + ") rotate(-45, " + pos + ", " + y2 + ")" + ); + } + } + } + if (commit2.tag) { + const rect2 = gLabels.insert("polygon"); + const hole = gLabels.append("circle"); + const tag = gLabels.append("text").attr("y", y2 - 16).attr("class", "tag-label").text(commit2.tag); + let tagBbox = tag.node().getBBox(); + tag.attr("x", posWithOffset - tagBbox.width / 2); + const h2 = tagBbox.height / 2; + const ly = y2 - 19.2; + rect2.attr("class", "tag-label-bkg").attr( + "points", + ` + ${pos - tagBbox.width / 2 - px / 2},${ly + py} + ${pos - tagBbox.width / 2 - px / 2},${ly - py} + ${posWithOffset - tagBbox.width / 2 - px},${ly - h2 - py} + ${posWithOffset + tagBbox.width / 2 + px},${ly - h2 - py} + ${posWithOffset + tagBbox.width / 2 + px},${ly + h2 + py} + ${posWithOffset - tagBbox.width / 2 - px},${ly + h2 + py}` + ); + hole.attr("cx", pos - tagBbox.width / 2 + px / 2).attr("cy", ly).attr("r", 1.5).attr("class", "tag-hole"); + if (dir === "TB") { + rect2.attr("class", "tag-label-bkg").attr( + "points", + ` + ${x2},${pos + py} + ${x2},${pos - py} + ${x2 + layoutOffset},${pos - h2 - py} + ${x2 + layoutOffset + tagBbox.width + px},${pos - h2 - py} + ${x2 + layoutOffset + tagBbox.width + px},${pos + h2 + py} + ${x2 + layoutOffset},${pos + h2 + py}` + ).attr("transform", "translate(12,12) rotate(45, " + x2 + "," + pos + ")"); + hole.attr("cx", x2 + px / 2).attr("cy", pos).attr("transform", "translate(12,12) rotate(45, " + x2 + "," + pos + ")"); + tag.attr("x", x2 + 5).attr("y", pos + 3).attr("transform", "translate(14,14) rotate(45, " + x2 + "," + pos + ")"); + } + } + } + pos += commitStep + layoutOffset; + if (pos > maxPos) { + maxPos = pos; + } + }); + }; + const shouldRerouteArrow = (commitA, commitB, p1, p2, allCommits) => { + const commitBIsFurthest = dir === "TB" ? p1.x < p2.x : p1.y < p2.y; + const branchToGetCurve = commitBIsFurthest ? commitB.branch : commitA.branch; + const isOnBranchToGetCurve = (x2) => x2.branch === branchToGetCurve; + const isBetweenCommits = (x2) => x2.seq > commitA.seq && x2.seq < commitB.seq; + return Object.values(allCommits).some((commitX) => { + return isBetweenCommits(commitX) && isOnBranchToGetCurve(commitX); + }); + }; + const findLane = (y1, y2, depth = 0) => { + const candidate = y1 + Math.abs(y1 - y2) / 2; + if (depth > 5) { + return candidate; + } + let ok = lanes.every((lane) => Math.abs(lane - candidate) >= 10); + if (ok) { + lanes.push(candidate); + return candidate; + } + const diff = Math.abs(y1 - y2); + return findLane(y1, y2 - diff / 5, depth + 1); + }; + const drawArrow = (svg2, commitA, commitB, allCommits) => { + const p1 = commitPos[commitA.id]; + const p2 = commitPos[commitB.id]; + const arrowNeedsRerouting = shouldRerouteArrow(commitA, commitB, p1, p2, allCommits); + let arc = ""; + let arc2 = ""; + let radius = 0; + let offset = 0; + let colorClassNum = branchPos[commitB.branch].index; + if (commitB.type === commitType.MERGE && commitA.id !== commitB.parents[0]) { + colorClassNum = branchPos[commitA.branch].index; + } + let lineDef; + if (arrowNeedsRerouting) { + arc = "A 10 10, 0, 0, 0,"; + arc2 = "A 10 10, 0, 0, 1,"; + radius = 10; + offset = 10; + const lineY = p1.y < p2.y ? findLane(p1.y, p2.y) : findLane(p2.y, p1.y); + const lineX = p1.x < p2.x ? findLane(p1.x, p2.x) : findLane(p2.x, p1.x); + if (dir === "TB") { + if (p1.x < p2.x) { + lineDef = `M ${p1.x} ${p1.y} L ${lineX - radius} ${p1.y} ${arc2} ${lineX} ${p1.y + offset} L ${lineX} ${p2.y - radius} ${arc} ${lineX + offset} ${p2.y} L ${p2.x} ${p2.y}`; + } else { + colorClassNum = branchPos[commitA.branch].index; + lineDef = `M ${p1.x} ${p1.y} L ${lineX + radius} ${p1.y} ${arc} ${lineX} ${p1.y + offset} L ${lineX} ${p2.y - radius} ${arc2} ${lineX - offset} ${p2.y} L ${p2.x} ${p2.y}`; + } + } else { + if (p1.y < p2.y) { + lineDef = `M ${p1.x} ${p1.y} L ${p1.x} ${lineY - radius} ${arc} ${p1.x + offset} ${lineY} L ${p2.x - radius} ${lineY} ${arc2} ${p2.x} ${lineY + offset} L ${p2.x} ${p2.y}`; + } else { + colorClassNum = branchPos[commitA.branch].index; + lineDef = `M ${p1.x} ${p1.y} L ${p1.x} ${lineY + radius} ${arc2} ${p1.x + offset} ${lineY} L ${p2.x - radius} ${lineY} ${arc} ${p2.x} ${lineY - offset} L ${p2.x} ${p2.y}`; + } + } + } else { + arc = "A 20 20, 0, 0, 0,"; + arc2 = "A 20 20, 0, 0, 1,"; + radius = 20; + offset = 20; + if (dir === "TB") { + if (p1.x < p2.x) { + if (commitB.type === commitType.MERGE && commitA.id !== commitB.parents[0]) { + lineDef = `M ${p1.x} ${p1.y} L ${p1.x} ${p2.y - radius} ${arc} ${p1.x + offset} ${p2.y} L ${p2.x} ${p2.y}`; + } else { + lineDef = `M ${p1.x} ${p1.y} L ${p2.x - radius} ${p1.y} ${arc2} ${p2.x} ${p1.y + offset} L ${p2.x} ${p2.y}`; + } + } + if (p1.x > p2.x) { + arc = "A 20 20, 0, 0, 0,"; + arc2 = "A 20 20, 0, 0, 1,"; + radius = 20; + offset = 20; + if (commitB.type === commitType.MERGE && commitA.id !== commitB.parents[0]) { + lineDef = `M ${p1.x} ${p1.y} L ${p1.x} ${p2.y - radius} ${arc2} ${p1.x - offset} ${p2.y} L ${p2.x} ${p2.y}`; + } else { + lineDef = `M ${p1.x} ${p1.y} L ${p2.x + radius} ${p1.y} ${arc} ${p2.x} ${p1.y + offset} L ${p2.x} ${p2.y}`; + } + } + if (p1.x === p2.x) { + lineDef = `M ${p1.x} ${p1.y} L ${p2.x} ${p2.y}`; + } + } else { + if (p1.y < p2.y) { + if (commitB.type === commitType.MERGE && commitA.id !== commitB.parents[0]) { + lineDef = `M ${p1.x} ${p1.y} L ${p2.x - radius} ${p1.y} ${arc2} ${p2.x} ${p1.y + offset} L ${p2.x} ${p2.y}`; + } else { + lineDef = `M ${p1.x} ${p1.y} L ${p1.x} ${p2.y - radius} ${arc} ${p1.x + offset} ${p2.y} L ${p2.x} ${p2.y}`; + } + } + if (p1.y > p2.y) { + if (commitB.type === commitType.MERGE && commitA.id !== commitB.parents[0]) { + lineDef = `M ${p1.x} ${p1.y} L ${p2.x - radius} ${p1.y} ${arc} ${p2.x} ${p1.y - offset} L ${p2.x} ${p2.y}`; + } else { + lineDef = `M ${p1.x} ${p1.y} L ${p1.x} ${p2.y + radius} ${arc2} ${p1.x + offset} ${p2.y} L ${p2.x} ${p2.y}`; + } + } + if (p1.y === p2.y) { + lineDef = `M ${p1.x} ${p1.y} L ${p2.x} ${p2.y}`; + } + } + } + svg2.append("path").attr("d", lineDef).attr("class", "arrow arrow" + colorClassNum % THEME_COLOR_LIMIT); + }; + const drawArrows = (svg2, commits2) => { + const gArrows = svg2.append("g").attr("class", "commit-arrows"); + Object.keys(commits2).forEach((key) => { + const commit2 = commits2[key]; + if (commit2.parents && commit2.parents.length > 0) { + commit2.parents.forEach((parent) => { + drawArrow(gArrows, commits2[parent], commit2, commits2); + }); + } + }); + }; + const drawBranches = (svg2, branches2) => { + const gitGraphConfig = getConfig$1().gitGraph; + const g = svg2.append("g"); + branches2.forEach((branch2, index2) => { + const adjustIndexForTheme = index2 % THEME_COLOR_LIMIT; + const pos = branchPos[branch2.name].pos; + const line2 = g.append("line"); + line2.attr("x1", 0); + line2.attr("y1", pos); + line2.attr("x2", maxPos); + line2.attr("y2", pos); + line2.attr("class", "branch branch" + adjustIndexForTheme); + if (dir === "TB") { + line2.attr("y1", 30); + line2.attr("x1", pos); + line2.attr("y2", maxPos); + line2.attr("x2", pos); + } + lanes.push(pos); + let name = branch2.name; + const labelElement = drawText$3(name); + const bkg = g.insert("rect"); + const branchLabel = g.insert("g").attr("class", "branchLabel"); + const label = branchLabel.insert("g").attr("class", "label branch-label" + adjustIndexForTheme); + label.node().appendChild(labelElement); + let bbox = labelElement.getBBox(); + bkg.attr("class", "branchLabelBkg label" + adjustIndexForTheme).attr("rx", 4).attr("ry", 4).attr("x", -bbox.width - 4 - (gitGraphConfig.rotateCommitLabel === true ? 30 : 0)).attr("y", -bbox.height / 2 + 8).attr("width", bbox.width + 18).attr("height", bbox.height + 4); + label.attr( + "transform", + "translate(" + (-bbox.width - 14 - (gitGraphConfig.rotateCommitLabel === true ? 30 : 0)) + ", " + (pos - bbox.height / 2 - 1) + ")" + ); + if (dir === "TB") { + bkg.attr("x", pos - bbox.width / 2 - 10).attr("y", 0); + label.attr("transform", "translate(" + (pos - bbox.width / 2 - 5) + ", 0)"); + } + if (dir !== "TB") { + bkg.attr("transform", "translate(-19, " + (pos - bbox.height / 2) + ")"); + } + }); + }; + const draw$h = function(txt, id2, ver, diagObj) { + clear$e(); + const conf2 = getConfig$1(); + const gitGraphConfig = conf2.gitGraph; + log$1.debug("in gitgraph renderer", txt + "\n", "id:", id2, ver); + allCommitsDict = diagObj.db.getCommits(); + const branches2 = diagObj.db.getBranchesAsObjArray(); + dir = diagObj.db.getDirection(); + const diagram2 = d3select(`[id="${id2}"]`); + let pos = 0; + branches2.forEach((branch2, index2) => { + const labelElement = drawText$3(branch2.name); + const g = diagram2.append("g"); + const branchLabel = g.insert("g").attr("class", "branchLabel"); + const label = branchLabel.insert("g").attr("class", "label branch-label"); + label.node().appendChild(labelElement); + let bbox = labelElement.getBBox(); + branchPos[branch2.name] = { pos, index: index2 }; + pos += 50 + (gitGraphConfig.rotateCommitLabel ? 40 : 0) + (dir === "TB" ? bbox.width / 2 : 0); + label.remove(); + branchLabel.remove(); + g.remove(); + }); + drawCommits(diagram2, allCommitsDict, false); + if (gitGraphConfig.showBranches) { + drawBranches(diagram2, branches2); + } + drawArrows(diagram2, allCommitsDict); + drawCommits(diagram2, allCommitsDict, true); + utils$1.insertTitle( + diagram2, + "gitTitleText", + gitGraphConfig.titleTopMargin, + diagObj.db.getDiagramTitle() + ); + setupGraphViewbox( + void 0, + diagram2, + gitGraphConfig.diagramPadding, + gitGraphConfig.useMaxWidth ?? conf2.useMaxWidth + ); + }; + const gitGraphRenderer = { + draw: draw$h + }; + const getStyles$b = (options2) => ` + .commit-id, + .commit-msg, + .branch-label { + fill: lightgrey; + color: lightgrey; + font-family: 'trebuchet ms', verdana, arial, sans-serif; + font-family: var(--mermaid-font-family); + } + ${[0, 1, 2, 3, 4, 5, 6, 7].map( + (i2) => ` + .branch-label${i2} { fill: ${options2["gitBranchLabel" + i2]}; } + .commit${i2} { stroke: ${options2["git" + i2]}; fill: ${options2["git" + i2]}; } + .commit-highlight${i2} { stroke: ${options2["gitInv" + i2]}; fill: ${options2["gitInv" + i2]}; } + .label${i2} { fill: ${options2["git" + i2]}; } + .arrow${i2} { stroke: ${options2["git" + i2]}; } + ` + ).join("\n")} + + .branch { + stroke-width: 1; + stroke: ${options2.lineColor}; + stroke-dasharray: 2; + } + .commit-label { font-size: ${options2.commitLabelFontSize}; fill: ${options2.commitLabelColor};} + .commit-label-bkg { font-size: ${options2.commitLabelFontSize}; fill: ${options2.commitLabelBackground}; opacity: 0.5; } + .tag-label { font-size: ${options2.tagLabelFontSize}; fill: ${options2.tagLabelColor};} + .tag-label-bkg { fill: ${options2.tagLabelBackground}; stroke: ${options2.tagLabelBorder}; } + .tag-hole { fill: ${options2.textColor}; } + + .commit-merge { + stroke: ${options2.primaryColor}; + fill: ${options2.primaryColor}; + } + .commit-reverse { + stroke: ${options2.primaryColor}; + fill: ${options2.primaryColor}; + stroke-width: 3; + } + .commit-highlight-outer { + } + .commit-highlight-inner { + stroke: ${options2.primaryColor}; + fill: ${options2.primaryColor}; + } + + .arrow { stroke-width: 8; stroke-linecap: round; fill: none} + .gitTitleText { + text-anchor: middle; + font-size: 18px; + fill: ${options2.textColor}; + } +`; + const gitGraphStyles = getStyles$b; + const diagram$h = { + parser: gitGraphParser, + db: gitGraphDb, + renderer: gitGraphRenderer, + styles: gitGraphStyles + }; + const gitGraphDiagram = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + diagram: diagram$h + }, Symbol.toStringTag, { value: "Module" })); + var parser$q = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [6, 8, 10, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 30, 32, 33, 35, 37], $V1 = [1, 25], $V2 = [1, 26], $V3 = [1, 27], $V4 = [1, 28], $V5 = [1, 29], $V6 = [1, 30], $V7 = [1, 31], $V8 = [1, 9], $V9 = [1, 10], $Va = [1, 11], $Vb = [1, 12], $Vc = [1, 13], $Vd = [1, 14], $Ve = [1, 15], $Vf = [1, 16], $Vg = [1, 18], $Vh = [1, 19], $Vi = [1, 20], $Vj = [1, 21], $Vk = [1, 22], $Vl = [1, 24], $Vm = [1, 32]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "gantt": 4, "document": 5, "EOF": 6, "line": 7, "SPACE": 8, "statement": 9, "NL": 10, "weekday": 11, "weekday_monday": 12, "weekday_tuesday": 13, "weekday_wednesday": 14, "weekday_thursday": 15, "weekday_friday": 16, "weekday_saturday": 17, "weekday_sunday": 18, "dateFormat": 19, "inclusiveEndDates": 20, "topAxis": 21, "axisFormat": 22, "tickInterval": 23, "excludes": 24, "includes": 25, "todayMarker": 26, "title": 27, "acc_title": 28, "acc_title_value": 29, "acc_descr": 30, "acc_descr_value": 31, "acc_descr_multiline_value": 32, "section": 33, "clickStatement": 34, "taskTxt": 35, "taskData": 36, "click": 37, "callbackname": 38, "callbackargs": 39, "href": 40, "clickStatementDebug": 41, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 4: "gantt", 6: "EOF", 8: "SPACE", 10: "NL", 12: "weekday_monday", 13: "weekday_tuesday", 14: "weekday_wednesday", 15: "weekday_thursday", 16: "weekday_friday", 17: "weekday_saturday", 18: "weekday_sunday", 19: "dateFormat", 20: "inclusiveEndDates", 21: "topAxis", 22: "axisFormat", 23: "tickInterval", 24: "excludes", 25: "includes", 26: "todayMarker", 27: "title", 28: "acc_title", 29: "acc_title_value", 30: "acc_descr", 31: "acc_descr_value", 32: "acc_descr_multiline_value", 33: "section", 35: "taskTxt", 36: "taskData", 37: "click", 38: "callbackname", 39: "callbackargs", 40: "href" }, + productions_: [0, [3, 3], [5, 0], [5, 2], [7, 2], [7, 1], [7, 1], [7, 1], [11, 1], [11, 1], [11, 1], [11, 1], [11, 1], [11, 1], [11, 1], [9, 1], [9, 1], [9, 1], [9, 1], [9, 1], [9, 1], [9, 1], [9, 1], [9, 1], [9, 1], [9, 2], [9, 2], [9, 1], [9, 1], [9, 1], [9, 2], [34, 2], [34, 3], [34, 3], [34, 4], [34, 3], [34, 4], [34, 2], [41, 2], [41, 3], [41, 3], [41, 4], [41, 3], [41, 4], [41, 2]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 1: + return $$[$0 - 1]; + case 2: + this.$ = []; + break; + case 3: + $$[$0 - 1].push($$[$0]); + this.$ = $$[$0 - 1]; + break; + case 4: + case 5: + this.$ = $$[$0]; + break; + case 6: + case 7: + this.$ = []; + break; + case 8: + yy.setWeekday("monday"); + break; + case 9: + yy.setWeekday("tuesday"); + break; + case 10: + yy.setWeekday("wednesday"); + break; + case 11: + yy.setWeekday("thursday"); + break; + case 12: + yy.setWeekday("friday"); + break; + case 13: + yy.setWeekday("saturday"); + break; + case 14: + yy.setWeekday("sunday"); + break; + case 15: + yy.setDateFormat($$[$0].substr(11)); + this.$ = $$[$0].substr(11); + break; + case 16: + yy.enableInclusiveEndDates(); + this.$ = $$[$0].substr(18); + break; + case 17: + yy.TopAxis(); + this.$ = $$[$0].substr(8); + break; + case 18: + yy.setAxisFormat($$[$0].substr(11)); + this.$ = $$[$0].substr(11); + break; + case 19: + yy.setTickInterval($$[$0].substr(13)); + this.$ = $$[$0].substr(13); + break; + case 20: + yy.setExcludes($$[$0].substr(9)); + this.$ = $$[$0].substr(9); + break; + case 21: + yy.setIncludes($$[$0].substr(9)); + this.$ = $$[$0].substr(9); + break; + case 22: + yy.setTodayMarker($$[$0].substr(12)); + this.$ = $$[$0].substr(12); + break; + case 24: + yy.setDiagramTitle($$[$0].substr(6)); + this.$ = $$[$0].substr(6); + break; + case 25: + this.$ = $$[$0].trim(); + yy.setAccTitle(this.$); + break; + case 26: + case 27: + this.$ = $$[$0].trim(); + yy.setAccDescription(this.$); + break; + case 28: + yy.addSection($$[$0].substr(8)); + this.$ = $$[$0].substr(8); + break; + case 30: + yy.addTask($$[$0 - 1], $$[$0]); + this.$ = "task"; + break; + case 31: + this.$ = $$[$0 - 1]; + yy.setClickEvent($$[$0 - 1], $$[$0], null); + break; + case 32: + this.$ = $$[$0 - 2]; + yy.setClickEvent($$[$0 - 2], $$[$0 - 1], $$[$0]); + break; + case 33: + this.$ = $$[$0 - 2]; + yy.setClickEvent($$[$0 - 2], $$[$0 - 1], null); + yy.setLink($$[$0 - 2], $$[$0]); + break; + case 34: + this.$ = $$[$0 - 3]; + yy.setClickEvent($$[$0 - 3], $$[$0 - 2], $$[$0 - 1]); + yy.setLink($$[$0 - 3], $$[$0]); + break; + case 35: + this.$ = $$[$0 - 2]; + yy.setClickEvent($$[$0 - 2], $$[$0], null); + yy.setLink($$[$0 - 2], $$[$0 - 1]); + break; + case 36: + this.$ = $$[$0 - 3]; + yy.setClickEvent($$[$0 - 3], $$[$0 - 1], $$[$0]); + yy.setLink($$[$0 - 3], $$[$0 - 2]); + break; + case 37: + this.$ = $$[$0 - 1]; + yy.setLink($$[$0 - 1], $$[$0]); + break; + case 38: + case 44: + this.$ = $$[$0 - 1] + " " + $$[$0]; + break; + case 39: + case 40: + case 42: + this.$ = $$[$0 - 2] + " " + $$[$0 - 1] + " " + $$[$0]; + break; + case 41: + case 43: + this.$ = $$[$0 - 3] + " " + $$[$0 - 2] + " " + $$[$0 - 1] + " " + $$[$0]; + break; + } + }, + table: [{ 3: 1, 4: [1, 2] }, { 1: [3] }, o($V0, [2, 2], { 5: 3 }), { 6: [1, 4], 7: 5, 8: [1, 6], 9: 7, 10: [1, 8], 11: 17, 12: $V1, 13: $V2, 14: $V3, 15: $V4, 16: $V5, 17: $V6, 18: $V7, 19: $V8, 20: $V9, 21: $Va, 22: $Vb, 23: $Vc, 24: $Vd, 25: $Ve, 26: $Vf, 27: $Vg, 28: $Vh, 30: $Vi, 32: $Vj, 33: $Vk, 34: 23, 35: $Vl, 37: $Vm }, o($V0, [2, 7], { 1: [2, 1] }), o($V0, [2, 3]), { 9: 33, 11: 17, 12: $V1, 13: $V2, 14: $V3, 15: $V4, 16: $V5, 17: $V6, 18: $V7, 19: $V8, 20: $V9, 21: $Va, 22: $Vb, 23: $Vc, 24: $Vd, 25: $Ve, 26: $Vf, 27: $Vg, 28: $Vh, 30: $Vi, 32: $Vj, 33: $Vk, 34: 23, 35: $Vl, 37: $Vm }, o($V0, [2, 5]), o($V0, [2, 6]), o($V0, [2, 15]), o($V0, [2, 16]), o($V0, [2, 17]), o($V0, [2, 18]), o($V0, [2, 19]), o($V0, [2, 20]), o($V0, [2, 21]), o($V0, [2, 22]), o($V0, [2, 23]), o($V0, [2, 24]), { 29: [1, 34] }, { 31: [1, 35] }, o($V0, [2, 27]), o($V0, [2, 28]), o($V0, [2, 29]), { 36: [1, 36] }, o($V0, [2, 8]), o($V0, [2, 9]), o($V0, [2, 10]), o($V0, [2, 11]), o($V0, [2, 12]), o($V0, [2, 13]), o($V0, [2, 14]), { 38: [1, 37], 40: [1, 38] }, o($V0, [2, 4]), o($V0, [2, 25]), o($V0, [2, 26]), o($V0, [2, 30]), o($V0, [2, 31], { 39: [1, 39], 40: [1, 40] }), o($V0, [2, 37], { 38: [1, 41] }), o($V0, [2, 32], { 40: [1, 42] }), o($V0, [2, 33]), o($V0, [2, 35], { 39: [1, 43] }), o($V0, [2, 34]), o($V0, [2, 36])], + defaultActions: {}, + parseError: function parseError(str2, hash) { + if (hash.recoverable) { + this.trace(str2); + } else { + var error = new Error(str2); + error.hash = hash; + throw error; + } + }, + parse: function parse2(input) { + var self2 = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex2() { + var token2; + token2 = tstack.pop() || lexer2.lex() || EOF; + if (typeof token2 !== "number") { + if (token2 instanceof Array) { + tstack = token2; + token2 = tstack.pop(); + } + token2 = self2.symbols_[token2] || token2; + } + return token2; + } + var symbol, state2, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state2 = stack[stack.length - 1]; + if (this.defaultActions[state2]) { + action = this.defaultActions[state2]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex2(); + } + action = table[state2] && table[state2][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state2]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state2 + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str2, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str2, hash); + } else { + throw new Error(str2); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch2 = this._input[0]; + this.yytext += ch2; + this.yyleng++; + this.offset++; + this.match += ch2; + this.matched += ch2; + var lines = ch2.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch2; + }, + // unshifts one char (or a string) into the input + unput: function(ch2) { + var len = ch2.length; + var lines = ch2.split(/(?:\r\n?|\n)/g); + this._input = ch2 + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next2 = this.match; + if (next2.length < 20) { + next2 += this._input.substr(0, 20 - next2.length); + } + return (next2.substr(0, 20) + (next2.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c2 = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c2 + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token2, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token2 = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token2) { + return token2; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token2, match, tempMatch, index2; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i2 = 0; i2 < rules.length; i2++) { + tempMatch = this._input.match(this.rules[rules[i2]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index2 = i2; + if (this.options.backtrack_lexer) { + token2 = this.test_match(tempMatch, rules[i2]); + if (token2 !== false) { + return token2; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token2 = this.test_match(match, rules[index2]); + if (token2 !== false) { + return token2; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex2() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + this.begin("open_directive"); + return "open_directive"; + case 1: + this.begin("acc_title"); + return 28; + case 2: + this.popState(); + return "acc_title_value"; + case 3: + this.begin("acc_descr"); + return 30; + case 4: + this.popState(); + return "acc_descr_value"; + case 5: + this.begin("acc_descr_multiline"); + break; + case 6: + this.popState(); + break; + case 7: + return "acc_descr_multiline_value"; + case 8: + break; + case 9: + break; + case 10: + break; + case 11: + return 10; + case 12: + break; + case 13: + break; + case 14: + this.begin("href"); + break; + case 15: + this.popState(); + break; + case 16: + return 40; + case 17: + this.begin("callbackname"); + break; + case 18: + this.popState(); + break; + case 19: + this.popState(); + this.begin("callbackargs"); + break; + case 20: + return 38; + case 21: + this.popState(); + break; + case 22: + return 39; + case 23: + this.begin("click"); + break; + case 24: + this.popState(); + break; + case 25: + return 37; + case 26: + return 4; + case 27: + return 19; + case 28: + return 20; + case 29: + return 21; + case 30: + return 22; + case 31: + return 23; + case 32: + return 25; + case 33: + return 24; + case 34: + return 26; + case 35: + return 12; + case 36: + return 13; + case 37: + return 14; + case 38: + return 15; + case 39: + return 16; + case 40: + return 17; + case 41: + return 18; + case 42: + return "date"; + case 43: + return 27; + case 44: + return "accDescription"; + case 45: + return 33; + case 46: + return 35; + case 47: + return 36; + case 48: + return ":"; + case 49: + return 6; + case 50: + return "INVALID"; + } + }, + rules: [/^(?:%%\{)/i, /^(?:accTitle\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*\{\s*)/i, /^(?:[\}])/i, /^(?:[^\}]*)/i, /^(?:%%(?!\{)*[^\n]*)/i, /^(?:[^\}]%%*[^\n]*)/i, /^(?:%%*[^\n]*[\n]*)/i, /^(?:[\n]+)/i, /^(?:\s+)/i, /^(?:%[^\n]*)/i, /^(?:href[\s]+["])/i, /^(?:["])/i, /^(?:[^"]*)/i, /^(?:call[\s]+)/i, /^(?:\([\s]*\))/i, /^(?:\()/i, /^(?:[^(]*)/i, /^(?:\))/i, /^(?:[^)]*)/i, /^(?:click[\s]+)/i, /^(?:[\s\n])/i, /^(?:[^\s\n]*)/i, /^(?:gantt\b)/i, /^(?:dateFormat\s[^#\n;]+)/i, /^(?:inclusiveEndDates\b)/i, /^(?:topAxis\b)/i, /^(?:axisFormat\s[^#\n;]+)/i, /^(?:tickInterval\s[^#\n;]+)/i, /^(?:includes\s[^#\n;]+)/i, /^(?:excludes\s[^#\n;]+)/i, /^(?:todayMarker\s[^\n;]+)/i, /^(?:weekday\s+monday\b)/i, /^(?:weekday\s+tuesday\b)/i, /^(?:weekday\s+wednesday\b)/i, /^(?:weekday\s+thursday\b)/i, /^(?:weekday\s+friday\b)/i, /^(?:weekday\s+saturday\b)/i, /^(?:weekday\s+sunday\b)/i, /^(?:\d\d\d\d-\d\d-\d\d\b)/i, /^(?:title\s[^\n]+)/i, /^(?:accDescription\s[^#\n;]+)/i, /^(?:section\s[^\n]+)/i, /^(?:[^:\n]+)/i, /^(?::[^#\n;]+)/i, /^(?::)/i, /^(?:$)/i, /^(?:.)/i], + conditions: { "acc_descr_multiline": { "rules": [6, 7], "inclusive": false }, "acc_descr": { "rules": [4], "inclusive": false }, "acc_title": { "rules": [2], "inclusive": false }, "callbackargs": { "rules": [21, 22], "inclusive": false }, "callbackname": { "rules": [18, 19, 20], "inclusive": false }, "href": { "rules": [15, 16], "inclusive": false }, "click": { "rules": [24, 25], "inclusive": false }, "INITIAL": { "rules": [0, 1, 3, 5, 8, 9, 10, 11, 12, 13, 14, 17, 23, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser2() { + this.yy = {}; + } + Parser2.prototype = parser2; + parser2.Parser = Parser2; + return new Parser2(); + }(); + parser$q.parser = parser$q; + const ganttParser = parser$q; + var isoWeek = { exports: {} }; + (function(module2, exports2) { + !function(e, t) { + module2.exports = t(); + }(commonjsGlobal, function() { + var e = "day"; + return function(t, i2, s) { + var a = function(t4) { + return t4.add(4 - t4.isoWeekday(), e); + }, d = i2.prototype; + d.isoWeekYear = function() { + return a(this).year(); + }, d.isoWeek = function(t4) { + if (!this.$utils().u(t4)) + return this.add(7 * (t4 - this.isoWeek()), e); + var i3, d2, n2, o, r = a(this), u = (i3 = this.isoWeekYear(), d2 = this.$u, n2 = (d2 ? s.utc : s)().year(i3).startOf("year"), o = 4 - n2.isoWeekday(), n2.isoWeekday() > 4 && (o += 7), n2.add(o, e)); + return r.diff(u, "week") + 1; + }, d.isoWeekday = function(e3) { + return this.$utils().u(e3) ? this.day() || 7 : this.day(this.day() % 7 ? e3 : e3 - 7); + }; + var n = d.startOf; + d.startOf = function(e3, t4) { + var i3 = this.$utils(), s2 = !!i3.u(t4) || t4; + return "isoweek" === i3.p(e3) ? s2 ? this.date(this.date() - (this.isoWeekday() - 1)).startOf("day") : this.date(this.date() - 1 - (this.isoWeekday() - 1) + 7).endOf("day") : n.bind(this)(e3, t4); + }; + }; + }); + })(isoWeek); + var isoWeekExports = isoWeek.exports; + const dayjsIsoWeek = /* @__PURE__ */ getDefaultExportFromCjs(isoWeekExports); + var customParseFormat = { exports: {} }; + (function(module2, exports2) { + !function(e, t) { + module2.exports = t(); + }(commonjsGlobal, function() { + var e = { LTS: "h:mm:ss A", LT: "h:mm A", L: "MM/DD/YYYY", LL: "MMMM D, YYYY", LLL: "MMMM D, YYYY h:mm A", LLLL: "dddd, MMMM D, YYYY h:mm A" }, t = /(\[[^[]*\])|([-_:/.,()\s]+)|(A|a|YYYY|YY?|MM?M?M?|Do|DD?|hh?|HH?|mm?|ss?|S{1,3}|z|ZZ?)/g, n = /\d\d/, r = /\d\d?/, i2 = /\d*[^-_:/,()\s\d]+/, o = {}, s = function(e3) { + return (e3 = +e3) + (e3 > 68 ? 1900 : 2e3); + }; + var a = function(e3) { + return function(t4) { + this[e3] = +t4; + }; + }, f2 = [/[+-]\d\d:?(\d\d)?|Z/, function(e3) { + (this.zone || (this.zone = {})).offset = function(e4) { + if (!e4) + return 0; + if ("Z" === e4) + return 0; + var t4 = e4.match(/([+-]|\d\d)/g), n2 = 60 * t4[1] + (+t4[2] || 0); + return 0 === n2 ? 0 : "+" === t4[0] ? -n2 : n2; + }(e3); + }], h = function(e3) { + var t4 = o[e3]; + return t4 && (t4.indexOf ? t4 : t4.s.concat(t4.f)); + }, u = function(e3, t4) { + var n2, r2 = o.meridiem; + if (r2) { + for (var i3 = 1; i3 <= 24; i3 += 1) + if (e3.indexOf(r2(i3, 0, t4)) > -1) { + n2 = i3 > 12; + break; + } + } else + n2 = e3 === (t4 ? "pm" : "PM"); + return n2; + }, d = { A: [i2, function(e3) { + this.afternoon = u(e3, false); + }], a: [i2, function(e3) { + this.afternoon = u(e3, true); + }], S: [/\d/, function(e3) { + this.milliseconds = 100 * +e3; + }], SS: [n, function(e3) { + this.milliseconds = 10 * +e3; + }], SSS: [/\d{3}/, function(e3) { + this.milliseconds = +e3; + }], s: [r, a("seconds")], ss: [r, a("seconds")], m: [r, a("minutes")], mm: [r, a("minutes")], H: [r, a("hours")], h: [r, a("hours")], HH: [r, a("hours")], hh: [r, a("hours")], D: [r, a("day")], DD: [n, a("day")], Do: [i2, function(e3) { + var t4 = o.ordinal, n2 = e3.match(/\d+/); + if (this.day = n2[0], t4) + for (var r2 = 1; r2 <= 31; r2 += 1) + t4(r2).replace(/\[|\]/g, "") === e3 && (this.day = r2); + }], M: [r, a("month")], MM: [n, a("month")], MMM: [i2, function(e3) { + var t4 = h("months"), n2 = (h("monthsShort") || t4.map(function(e4) { + return e4.slice(0, 3); + })).indexOf(e3) + 1; + if (n2 < 1) + throw new Error(); + this.month = n2 % 12 || n2; + }], MMMM: [i2, function(e3) { + var t4 = h("months").indexOf(e3) + 1; + if (t4 < 1) + throw new Error(); + this.month = t4 % 12 || t4; + }], Y: [/[+-]?\d+/, a("year")], YY: [n, function(e3) { + this.year = s(e3); + }], YYYY: [/\d{4}/, a("year")], Z: f2, ZZ: f2 }; + function c2(n2) { + var r2, i3; + r2 = n2, i3 = o && o.formats; + for (var s2 = (n2 = r2.replace(/(\[[^\]]+])|(LTS?|l{1,4}|L{1,4})/g, function(t4, n3, r3) { + var o2 = r3 && r3.toUpperCase(); + return n3 || i3[r3] || e[r3] || i3[o2].replace(/(\[[^\]]+])|(MMMM|MM|DD|dddd)/g, function(e3, t5, n4) { + return t5 || n4.slice(1); + }); + })).match(t), a2 = s2.length, f3 = 0; f3 < a2; f3 += 1) { + var h2 = s2[f3], u2 = d[h2], c3 = u2 && u2[0], l = u2 && u2[1]; + s2[f3] = l ? { regex: c3, parser: l } : h2.replace(/^\[|\]$/g, ""); + } + return function(e3) { + for (var t4 = {}, n3 = 0, r3 = 0; n3 < a2; n3 += 1) { + var i4 = s2[n3]; + if ("string" == typeof i4) + r3 += i4.length; + else { + var o2 = i4.regex, f4 = i4.parser, h3 = e3.slice(r3), u3 = o2.exec(h3)[0]; + f4.call(t4, u3), e3 = e3.replace(u3, ""); + } + } + return function(e4) { + var t5 = e4.afternoon; + if (void 0 !== t5) { + var n4 = e4.hours; + t5 ? n4 < 12 && (e4.hours += 12) : 12 === n4 && (e4.hours = 0), delete e4.afternoon; + } + }(t4), t4; + }; + } + return function(e3, t4, n2) { + n2.p.customParseFormat = true, e3 && e3.parseTwoDigitYear && (s = e3.parseTwoDigitYear); + var r2 = t4.prototype, i3 = r2.parse; + r2.parse = function(e4) { + var t5 = e4.date, r3 = e4.utc, s2 = e4.args; + this.$u = r3; + var a2 = s2[1]; + if ("string" == typeof a2) { + var f3 = true === s2[2], h2 = true === s2[3], u2 = f3 || h2, d2 = s2[2]; + h2 && (d2 = s2[2]), o = this.$locale(), !f3 && d2 && (o = n2.Ls[d2]), this.$d = function(e6, t6, n3) { + try { + if (["x", "X"].indexOf(t6) > -1) + return new Date(("X" === t6 ? 1e3 : 1) * e6); + var r4 = c2(t6)(e6), i4 = r4.year, o2 = r4.month, s3 = r4.day, a3 = r4.hours, f4 = r4.minutes, h3 = r4.seconds, u3 = r4.milliseconds, d3 = r4.zone, l2 = /* @__PURE__ */ new Date(), m2 = s3 || (i4 || o2 ? 1 : l2.getDate()), M2 = i4 || l2.getFullYear(), Y = 0; + i4 && !o2 || (Y = o2 > 0 ? o2 - 1 : l2.getMonth()); + var p = a3 || 0, v = f4 || 0, D2 = h3 || 0, g = u3 || 0; + return d3 ? new Date(Date.UTC(M2, Y, m2, p, v, D2, g + 60 * d3.offset * 1e3)) : n3 ? new Date(Date.UTC(M2, Y, m2, p, v, D2, g)) : new Date(M2, Y, m2, p, v, D2, g); + } catch (e7) { + return /* @__PURE__ */ new Date(""); + } + }(t5, a2, r3), this.init(), d2 && true !== d2 && (this.$L = this.locale(d2).$L), u2 && t5 != this.format(a2) && (this.$d = /* @__PURE__ */ new Date("")), o = {}; + } else if (a2 instanceof Array) + for (var l = a2.length, m = 1; m <= l; m += 1) { + s2[1] = a2[m - 1]; + var M = n2.apply(this, s2); + if (M.isValid()) { + this.$d = M.$d, this.$L = M.$L, this.init(); + break; + } + m === l && (this.$d = /* @__PURE__ */ new Date("")); + } + else + i3.call(this, e4); + }; + }; + }); + })(customParseFormat); + var customParseFormatExports = customParseFormat.exports; + const dayjsCustomParseFormat = /* @__PURE__ */ getDefaultExportFromCjs(customParseFormatExports); + var advancedFormat = { exports: {} }; + (function(module2, exports2) { + !function(e, t) { + module2.exports = t(); + }(commonjsGlobal, function() { + return function(e, t) { + var r = t.prototype, n = r.format; + r.format = function(e3) { + var t4 = this, r2 = this.$locale(); + if (!this.isValid()) + return n.bind(this)(e3); + var s = this.$utils(), a = (e3 || "YYYY-MM-DDTHH:mm:ssZ").replace(/\[([^\]]+)]|Q|wo|ww|w|WW|W|zzz|z|gggg|GGGG|Do|X|x|k{1,2}|S/g, function(e4) { + switch (e4) { + case "Q": + return Math.ceil((t4.$M + 1) / 3); + case "Do": + return r2.ordinal(t4.$D); + case "gggg": + return t4.weekYear(); + case "GGGG": + return t4.isoWeekYear(); + case "wo": + return r2.ordinal(t4.week(), "W"); + case "w": + case "ww": + return s.s(t4.week(), "w" === e4 ? 1 : 2, "0"); + case "W": + case "WW": + return s.s(t4.isoWeek(), "W" === e4 ? 1 : 2, "0"); + case "k": + case "kk": + return s.s(String(0 === t4.$H ? 24 : t4.$H), "k" === e4 ? 1 : 2, "0"); + case "X": + return Math.floor(t4.$d.getTime() / 1e3); + case "x": + return t4.$d.getTime(); + case "z": + return "[" + t4.offsetName() + "]"; + case "zzz": + return "[" + t4.offsetName("long") + "]"; + default: + return e4; + } + }); + return n.bind(this)(a); + }; + }; + }); + })(advancedFormat); + var advancedFormatExports = advancedFormat.exports; + const dayjsAdvancedFormat = /* @__PURE__ */ getDefaultExportFromCjs(advancedFormatExports); + dayjs.extend(dayjsIsoWeek); + dayjs.extend(dayjsCustomParseFormat); + dayjs.extend(dayjsAdvancedFormat); + let dateFormat = ""; + let axisFormat = ""; + let tickInterval = void 0; + let todayMarker = ""; + let includes = []; + let excludes = []; + let links$1 = {}; + let sections$3 = []; + let tasks$2 = []; + let currentSection$2 = ""; + let displayMode = ""; + const tags = ["active", "done", "crit", "milestone"]; + let funs = []; + let inclusiveEndDates = false; + let topAxis = false; + let weekday = "sunday"; + let lastOrder = 0; + const clear$d = function() { + sections$3 = []; + tasks$2 = []; + currentSection$2 = ""; + funs = []; + taskCnt = 0; + lastTask = void 0; + lastTaskID = void 0; + rawTasks$2 = []; + dateFormat = ""; + axisFormat = ""; + displayMode = ""; + tickInterval = void 0; + todayMarker = ""; + includes = []; + excludes = []; + inclusiveEndDates = false; + topAxis = false; + lastOrder = 0; + links$1 = {}; + clear$n(); + weekday = "sunday"; + }; + const setAxisFormat = function(txt) { + axisFormat = txt; + }; + const getAxisFormat = function() { + return axisFormat; + }; + const setTickInterval = function(txt) { + tickInterval = txt; + }; + const getTickInterval = function() { + return tickInterval; + }; + const setTodayMarker = function(txt) { + todayMarker = txt; + }; + const getTodayMarker = function() { + return todayMarker; + }; + const setDateFormat = function(txt) { + dateFormat = txt; + }; + const enableInclusiveEndDates = function() { + inclusiveEndDates = true; + }; + const endDatesAreInclusive = function() { + return inclusiveEndDates; + }; + const enableTopAxis = function() { + topAxis = true; + }; + const topAxisEnabled = function() { + return topAxis; + }; + const setDisplayMode = function(txt) { + displayMode = txt; + }; + const getDisplayMode = function() { + return displayMode; + }; + const getDateFormat = function() { + return dateFormat; + }; + const setIncludes = function(txt) { + includes = txt.toLowerCase().split(/[\s,]+/); + }; + const getIncludes = function() { + return includes; + }; + const setExcludes = function(txt) { + excludes = txt.toLowerCase().split(/[\s,]+/); + }; + const getExcludes = function() { + return excludes; + }; + const getLinks$1 = function() { + return links$1; + }; + const addSection$3 = function(txt) { + currentSection$2 = txt; + sections$3.push(txt); + }; + const getSections$3 = function() { + return sections$3; + }; + const getTasks$2 = function() { + let allItemsProcessed = compileTasks$2(); + const maxDepth = 10; + let iterationCount = 0; + while (!allItemsProcessed && iterationCount < maxDepth) { + allItemsProcessed = compileTasks$2(); + iterationCount++; + } + tasks$2 = rawTasks$2; + return tasks$2; + }; + const isInvalidDate = function(date2, dateFormat2, excludes2, includes2) { + if (includes2.includes(date2.format(dateFormat2.trim()))) { + return false; + } + if (date2.isoWeekday() >= 6 && excludes2.includes("weekends")) { + return true; + } + if (excludes2.includes(date2.format("dddd").toLowerCase())) { + return true; + } + return excludes2.includes(date2.format(dateFormat2.trim())); + }; + const setWeekday = function(txt) { + weekday = txt; + }; + const getWeekday = function() { + return weekday; + }; + const checkTaskDates = function(task, dateFormat2, excludes2, includes2) { + if (!excludes2.length || task.manualEndTime) { + return; + } + let startTime; + if (task.startTime instanceof Date) { + startTime = dayjs(task.startTime); + } else { + startTime = dayjs(task.startTime, dateFormat2, true); + } + startTime = startTime.add(1, "d"); + let originalEndTime; + if (task.endTime instanceof Date) { + originalEndTime = dayjs(task.endTime); + } else { + originalEndTime = dayjs(task.endTime, dateFormat2, true); + } + const [fixedEndTime, renderEndTime] = fixTaskDates( + startTime, + originalEndTime, + dateFormat2, + excludes2, + includes2 + ); + task.endTime = fixedEndTime.toDate(); + task.renderEndTime = renderEndTime; + }; + const fixTaskDates = function(startTime, endTime, dateFormat2, excludes2, includes2) { + let invalid = false; + let renderEndTime = null; + while (startTime <= endTime) { + if (!invalid) { + renderEndTime = endTime.toDate(); + } + invalid = isInvalidDate(startTime, dateFormat2, excludes2, includes2); + if (invalid) { + endTime = endTime.add(1, "d"); + } + startTime = startTime.add(1, "d"); + } + return [endTime, renderEndTime]; + }; + const getStartDate = function(prevTime, dateFormat2, str2) { + str2 = str2.trim(); + const afterRePattern = /^after\s+(?[\d\w- ]+)/; + const afterStatement = afterRePattern.exec(str2); + if (afterStatement !== null) { + let latestTask = null; + for (const id2 of afterStatement.groups.ids.split(" ")) { + let task = findTaskById(id2); + if (task !== void 0 && (!latestTask || task.endTime > latestTask.endTime)) { + latestTask = task; + } + } + if (latestTask) { + return latestTask.endTime; + } + const today = /* @__PURE__ */ new Date(); + today.setHours(0, 0, 0, 0); + return today; + } + let mDate = dayjs(str2, dateFormat2.trim(), true); + if (mDate.isValid()) { + return mDate.toDate(); + } else { + log$1.debug("Invalid date:" + str2); + log$1.debug("With date format:" + dateFormat2.trim()); + const d = new Date(str2); + if (d === void 0 || isNaN(d.getTime()) || // WebKit browsers can mis-parse invalid dates to be ridiculously + // huge numbers, e.g. new Date('202304') gets parsed as January 1, 202304. + // This can cause virtually infinite loops while rendering, so for the + // purposes of Gantt charts we'll just treat any date beyond 10,000 AD/BC as + // invalid. + d.getFullYear() < -1e4 || d.getFullYear() > 1e4) { + throw new Error("Invalid date:" + str2); + } + return d; + } + }; + const parseDuration = function(str2) { + const statement = /^(\d+(?:\.\d+)?)([Mdhmswy]|ms)$/.exec(str2.trim()); + if (statement !== null) { + return [Number.parseFloat(statement[1]), statement[2]]; + } + return [NaN, "ms"]; + }; + const getEndDate = function(prevTime, dateFormat2, str2, inclusive = false) { + str2 = str2.trim(); + const untilRePattern = /^until\s+(?[\d\w- ]+)/; + const untilStatement = untilRePattern.exec(str2); + if (untilStatement !== null) { + let earliestTask = null; + for (const id2 of untilStatement.groups.ids.split(" ")) { + let task = findTaskById(id2); + if (task !== void 0 && (!earliestTask || task.startTime < earliestTask.startTime)) { + earliestTask = task; + } + } + if (earliestTask) { + return earliestTask.startTime; + } + const today = /* @__PURE__ */ new Date(); + today.setHours(0, 0, 0, 0); + return today; + } + let parsedDate = dayjs(str2, dateFormat2.trim(), true); + if (parsedDate.isValid()) { + if (inclusive) { + parsedDate = parsedDate.add(1, "d"); + } + return parsedDate.toDate(); + } + let endTime = dayjs(prevTime); + const [durationValue, durationUnit] = parseDuration(str2); + if (!Number.isNaN(durationValue)) { + const newEndTime = endTime.add(durationValue, durationUnit); + if (newEndTime.isValid()) { + endTime = newEndTime; + } + } + return endTime.toDate(); + }; + let taskCnt = 0; + const parseId = function(idStr) { + if (idStr === void 0) { + taskCnt = taskCnt + 1; + return "task" + taskCnt; + } + return idStr; + }; + const compileData = function(prevTask, dataStr) { + let ds; + if (dataStr.substr(0, 1) === ":") { + ds = dataStr.substr(1, dataStr.length); + } else { + ds = dataStr; + } + const data = ds.split(","); + const task = {}; + getTaskTags(data, task, tags); + for (let i2 = 0; i2 < data.length; i2++) { + data[i2] = data[i2].trim(); + } + let endTimeData = ""; + switch (data.length) { + case 1: + task.id = parseId(); + task.startTime = prevTask.endTime; + endTimeData = data[0]; + break; + case 2: + task.id = parseId(); + task.startTime = getStartDate(void 0, dateFormat, data[0]); + endTimeData = data[1]; + break; + case 3: + task.id = parseId(data[0]); + task.startTime = getStartDate(void 0, dateFormat, data[1]); + endTimeData = data[2]; + break; + } + if (endTimeData) { + task.endTime = getEndDate(task.startTime, dateFormat, endTimeData, inclusiveEndDates); + task.manualEndTime = dayjs(endTimeData, "YYYY-MM-DD", true).isValid(); + checkTaskDates(task, dateFormat, excludes, includes); + } + return task; + }; + const parseData = function(prevTaskId, dataStr) { + let ds; + if (dataStr.substr(0, 1) === ":") { + ds = dataStr.substr(1, dataStr.length); + } else { + ds = dataStr; + } + const data = ds.split(","); + const task = {}; + getTaskTags(data, task, tags); + for (let i2 = 0; i2 < data.length; i2++) { + data[i2] = data[i2].trim(); + } + switch (data.length) { + case 1: + task.id = parseId(); + task.startTime = { + type: "prevTaskEnd", + id: prevTaskId + }; + task.endTime = { + data: data[0] + }; + break; + case 2: + task.id = parseId(); + task.startTime = { + type: "getStartDate", + startData: data[0] + }; + task.endTime = { + data: data[1] + }; + break; + case 3: + task.id = parseId(data[0]); + task.startTime = { + type: "getStartDate", + startData: data[1] + }; + task.endTime = { + data: data[2] + }; + break; + } + return task; + }; + let lastTask; + let lastTaskID; + let rawTasks$2 = []; + const taskDb = {}; + const addTask$2 = function(descr, data) { + const rawTask = { + section: currentSection$2, + type: currentSection$2, + processed: false, + manualEndTime: false, + renderEndTime: null, + raw: { data }, + task: descr, + classes: [] + }; + const taskInfo = parseData(lastTaskID, data); + rawTask.raw.startTime = taskInfo.startTime; + rawTask.raw.endTime = taskInfo.endTime; + rawTask.id = taskInfo.id; + rawTask.prevTaskId = lastTaskID; + rawTask.active = taskInfo.active; + rawTask.done = taskInfo.done; + rawTask.crit = taskInfo.crit; + rawTask.milestone = taskInfo.milestone; + rawTask.order = lastOrder; + lastOrder++; + const pos = rawTasks$2.push(rawTask); + lastTaskID = rawTask.id; + taskDb[rawTask.id] = pos - 1; + }; + const findTaskById = function(id2) { + const pos = taskDb[id2]; + return rawTasks$2[pos]; + }; + const addTaskOrg$2 = function(descr, data) { + const newTask = { + section: currentSection$2, + type: currentSection$2, + description: descr, + task: descr, + classes: [] + }; + const taskInfo = compileData(lastTask, data); + newTask.startTime = taskInfo.startTime; + newTask.endTime = taskInfo.endTime; + newTask.id = taskInfo.id; + newTask.active = taskInfo.active; + newTask.done = taskInfo.done; + newTask.crit = taskInfo.crit; + newTask.milestone = taskInfo.milestone; + lastTask = newTask; + tasks$2.push(newTask); + }; + const compileTasks$2 = function() { + const compileTask = function(pos) { + const task = rawTasks$2[pos]; + let startTime = ""; + switch (rawTasks$2[pos].raw.startTime.type) { + case "prevTaskEnd": { + const prevTask = findTaskById(task.prevTaskId); + task.startTime = prevTask.endTime; + break; + } + case "getStartDate": + startTime = getStartDate(void 0, dateFormat, rawTasks$2[pos].raw.startTime.startData); + if (startTime) { + rawTasks$2[pos].startTime = startTime; + } + break; + } + if (rawTasks$2[pos].startTime) { + rawTasks$2[pos].endTime = getEndDate( + rawTasks$2[pos].startTime, + dateFormat, + rawTasks$2[pos].raw.endTime.data, + inclusiveEndDates + ); + if (rawTasks$2[pos].endTime) { + rawTasks$2[pos].processed = true; + rawTasks$2[pos].manualEndTime = dayjs( + rawTasks$2[pos].raw.endTime.data, + "YYYY-MM-DD", + true + ).isValid(); + checkTaskDates(rawTasks$2[pos], dateFormat, excludes, includes); + } + } + return rawTasks$2[pos].processed; + }; + let allProcessed = true; + for (const [i2, rawTask] of rawTasks$2.entries()) { + compileTask(i2); + allProcessed = allProcessed && rawTask.processed; + } + return allProcessed; + }; + const setLink$1 = function(ids, _linkStr) { + let linkStr = _linkStr; + if (getConfig$1().securityLevel !== "loose") { + linkStr = dist.sanitizeUrl(_linkStr); + } + ids.split(",").forEach(function(id2) { + let rawTask = findTaskById(id2); + if (rawTask !== void 0) { + pushFun(id2, () => { + window.open(linkStr, "_self"); + }); + links$1[id2] = linkStr; + } + }); + setClass(ids, "clickable"); + }; + const setClass = function(ids, className) { + ids.split(",").forEach(function(id2) { + let rawTask = findTaskById(id2); + if (rawTask !== void 0) { + rawTask.classes.push(className); + } + }); + }; + const setClickFun = function(id2, functionName, functionArgs) { + if (getConfig$1().securityLevel !== "loose") { + return; + } + if (functionName === void 0) { + return; + } + let argList = []; + if (typeof functionArgs === "string") { + argList = functionArgs.split(/,(?=(?:(?:[^"]*"){2})*[^"]*$)/); + for (let i2 = 0; i2 < argList.length; i2++) { + let item = argList[i2].trim(); + if (item.charAt(0) === '"' && item.charAt(item.length - 1) === '"') { + item = item.substr(1, item.length - 2); + } + argList[i2] = item; + } + } + if (argList.length === 0) { + argList.push(id2); + } + let rawTask = findTaskById(id2); + if (rawTask !== void 0) { + pushFun(id2, () => { + utils$1.runFunc(functionName, ...argList); + }); + } + }; + const pushFun = function(id2, callbackFunction) { + funs.push( + function() { + const elem = document.querySelector(`[id="${id2}"]`); + if (elem !== null) { + elem.addEventListener("click", function() { + callbackFunction(); + }); + } + }, + function() { + const elem = document.querySelector(`[id="${id2}-text"]`); + if (elem !== null) { + elem.addEventListener("click", function() { + callbackFunction(); + }); + } + } + ); + }; + const setClickEvent$1 = function(ids, functionName, functionArgs) { + ids.split(",").forEach(function(id2) { + setClickFun(id2, functionName, functionArgs); + }); + setClass(ids, "clickable"); + }; + const bindFunctions$1 = function(element2) { + funs.forEach(function(fun) { + fun(element2); + }); + }; + const ganttDb = { + getConfig: () => getConfig$1().gantt, + clear: clear$d, + setDateFormat, + getDateFormat, + enableInclusiveEndDates, + endDatesAreInclusive, + enableTopAxis, + topAxisEnabled, + setAxisFormat, + getAxisFormat, + setTickInterval, + getTickInterval, + setTodayMarker, + getTodayMarker, + setAccTitle, + getAccTitle, + setDiagramTitle, + getDiagramTitle, + setDisplayMode, + getDisplayMode, + setAccDescription, + getAccDescription, + addSection: addSection$3, + getSections: getSections$3, + getTasks: getTasks$2, + addTask: addTask$2, + findTaskById, + addTaskOrg: addTaskOrg$2, + setIncludes, + getIncludes, + setExcludes, + getExcludes, + setClickEvent: setClickEvent$1, + setLink: setLink$1, + getLinks: getLinks$1, + bindFunctions: bindFunctions$1, + parseDuration, + isInvalidDate, + setWeekday, + getWeekday + }; + function getTaskTags(data, task, tags2) { + let matchFound = true; + while (matchFound) { + matchFound = false; + tags2.forEach(function(t) { + const pattern = "^\\s*" + t + "\\s*$"; + const regex = new RegExp(pattern); + if (data[0].match(regex)) { + task[t] = true; + data.shift(1); + matchFound = true; + } + }); + } + } + const setConf$5 = function() { + log$1.debug("Something is calling, setConf, remove the call"); + }; + const mapWeekdayToTimeFunction = { + monday: timeMonday, + tuesday: timeTuesday, + wednesday: timeWednesday, + thursday: timeThursday, + friday: timeFriday, + saturday: timeSaturday, + sunday: timeSunday + }; + const getMaxIntersections = (tasks2, orderOffset) => { + let timeline2 = [...tasks2].map(() => -Infinity); + let sorted = [...tasks2].sort((a, b) => a.startTime - b.startTime || a.order - b.order); + let maxIntersections = 0; + for (const element2 of sorted) { + for (let j = 0; j < timeline2.length; j++) { + if (element2.startTime >= timeline2[j]) { + timeline2[j] = element2.endTime; + element2.order = j + orderOffset; + if (j > maxIntersections) { + maxIntersections = j; + } + break; + } + } + } + return maxIntersections; + }; + let w; + const draw$g = function(text2, id2, version2, diagObj) { + const conf2 = getConfig$1().gantt; + const securityLevel = getConfig$1().securityLevel; + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = d3select("#i" + id2); + } + const root2 = securityLevel === "sandbox" ? d3select(sandboxElement.nodes()[0].contentDocument.body) : d3select("body"); + const doc = securityLevel === "sandbox" ? sandboxElement.nodes()[0].contentDocument : document; + const elem = doc.getElementById(id2); + w = elem.parentElement.offsetWidth; + if (w === void 0) { + w = 1200; + } + if (conf2.useWidth !== void 0) { + w = conf2.useWidth; + } + const taskArray = diagObj.db.getTasks(); + let categories = []; + for (const element2 of taskArray) { + categories.push(element2.type); + } + categories = checkUnique(categories); + const categoryHeights = {}; + let h = 2 * conf2.topPadding; + if (diagObj.db.getDisplayMode() === "compact" || conf2.displayMode === "compact") { + const categoryElements = {}; + for (const element2 of taskArray) { + if (categoryElements[element2.section] === void 0) { + categoryElements[element2.section] = [element2]; + } else { + categoryElements[element2.section].push(element2); + } + } + let intersections = 0; + for (const category of Object.keys(categoryElements)) { + const categoryHeight = getMaxIntersections(categoryElements[category], intersections) + 1; + intersections += categoryHeight; + h += categoryHeight * (conf2.barHeight + conf2.barGap); + categoryHeights[category] = categoryHeight; + } + } else { + h += taskArray.length * (conf2.barHeight + conf2.barGap); + for (const category of categories) { + categoryHeights[category] = taskArray.filter((task) => task.type === category).length; + } + } + elem.setAttribute("viewBox", "0 0 " + w + " " + h); + const svg2 = root2.select(`[id="${id2}"]`); + const timeScale = time$1().domain([ + min$3(taskArray, function(d) { + return d.startTime; + }), + max$3(taskArray, function(d) { + return d.endTime; + }) + ]).rangeRound([0, w - conf2.leftPadding - conf2.rightPadding]); + function taskCompare(a, b) { + const taskA = a.startTime; + const taskB = b.startTime; + let result = 0; + if (taskA > taskB) { + result = 1; + } else if (taskA < taskB) { + result = -1; + } + return result; + } + taskArray.sort(taskCompare); + makeGantt(taskArray, w, h); + configureSvgSize(svg2, h, w, conf2.useMaxWidth); + svg2.append("text").text(diagObj.db.getDiagramTitle()).attr("x", w / 2).attr("y", conf2.titleTopMargin).attr("class", "titleText"); + function makeGantt(tasks2, pageWidth, pageHeight) { + const barHeight = conf2.barHeight; + const gap = barHeight + conf2.barGap; + const topPadding = conf2.topPadding; + const leftPadding = conf2.leftPadding; + const colorScale = linear().domain([0, categories.length]).range(["#00B9FA", "#F95002"]).interpolate(interpolateHcl); + drawExcludeDays( + gap, + topPadding, + leftPadding, + pageWidth, + pageHeight, + tasks2, + diagObj.db.getExcludes(), + diagObj.db.getIncludes() + ); + makeGrid(leftPadding, topPadding, pageWidth, pageHeight); + drawRects(tasks2, gap, topPadding, leftPadding, barHeight, colorScale, pageWidth); + vertLabels(gap, topPadding); + drawToday(leftPadding, topPadding, pageWidth, pageHeight); + } + function drawRects(theArray, theGap, theTopPad, theSidePad, theBarHeight, theColorScale, w2) { + const uniqueTaskOrderIds = [...new Set(theArray.map((item) => item.order))]; + const uniqueTasks = uniqueTaskOrderIds.map((id3) => theArray.find((item) => item.order === id3)); + svg2.append("g").selectAll("rect").data(uniqueTasks).enter().append("rect").attr("x", 0).attr("y", function(d, i2) { + i2 = d.order; + return i2 * theGap + theTopPad - 2; + }).attr("width", function() { + return w2 - conf2.rightPadding / 2; + }).attr("height", theGap).attr("class", function(d) { + for (const [i2, category] of categories.entries()) { + if (d.type === category) { + return "section section" + i2 % conf2.numberSectionStyles; + } + } + return "section section0"; + }); + const rectangles = svg2.append("g").selectAll("rect").data(theArray).enter(); + const links2 = diagObj.db.getLinks(); + rectangles.append("rect").attr("id", function(d) { + return d.id; + }).attr("rx", 3).attr("ry", 3).attr("x", function(d) { + if (d.milestone) { + return timeScale(d.startTime) + theSidePad + 0.5 * (timeScale(d.endTime) - timeScale(d.startTime)) - 0.5 * theBarHeight; + } + return timeScale(d.startTime) + theSidePad; + }).attr("y", function(d, i2) { + i2 = d.order; + return i2 * theGap + theTopPad; + }).attr("width", function(d) { + if (d.milestone) { + return theBarHeight; + } + return timeScale(d.renderEndTime || d.endTime) - timeScale(d.startTime); + }).attr("height", theBarHeight).attr("transform-origin", function(d, i2) { + i2 = d.order; + return (timeScale(d.startTime) + theSidePad + 0.5 * (timeScale(d.endTime) - timeScale(d.startTime))).toString() + "px " + (i2 * theGap + theTopPad + 0.5 * theBarHeight).toString() + "px"; + }).attr("class", function(d) { + const res = "task"; + let classStr = ""; + if (d.classes.length > 0) { + classStr = d.classes.join(" "); + } + let secNum = 0; + for (const [i2, category] of categories.entries()) { + if (d.type === category) { + secNum = i2 % conf2.numberSectionStyles; + } + } + let taskClass = ""; + if (d.active) { + if (d.crit) { + taskClass += " activeCrit"; + } else { + taskClass = " active"; + } + } else if (d.done) { + if (d.crit) { + taskClass = " doneCrit"; + } else { + taskClass = " done"; + } + } else { + if (d.crit) { + taskClass += " crit"; + } + } + if (taskClass.length === 0) { + taskClass = " task"; + } + if (d.milestone) { + taskClass = " milestone " + taskClass; + } + taskClass += secNum; + taskClass += " " + classStr; + return res + taskClass; + }); + rectangles.append("text").attr("id", function(d) { + return d.id + "-text"; + }).text(function(d) { + return d.task; + }).attr("font-size", conf2.fontSize).attr("x", function(d) { + let startX = timeScale(d.startTime); + let endX = timeScale(d.renderEndTime || d.endTime); + if (d.milestone) { + startX += 0.5 * (timeScale(d.endTime) - timeScale(d.startTime)) - 0.5 * theBarHeight; + } + if (d.milestone) { + endX = startX + theBarHeight; + } + const textWidth = this.getBBox().width; + if (textWidth > endX - startX) { + if (endX + textWidth + 1.5 * conf2.leftPadding > w2) { + return startX + theSidePad - 5; + } else { + return endX + theSidePad + 5; + } + } else { + return (endX - startX) / 2 + startX + theSidePad; + } + }).attr("y", function(d, i2) { + i2 = d.order; + return i2 * theGap + conf2.barHeight / 2 + (conf2.fontSize / 2 - 2) + theTopPad; + }).attr("text-height", theBarHeight).attr("class", function(d) { + const startX = timeScale(d.startTime); + let endX = timeScale(d.endTime); + if (d.milestone) { + endX = startX + theBarHeight; + } + const textWidth = this.getBBox().width; + let classStr = ""; + if (d.classes.length > 0) { + classStr = d.classes.join(" "); + } + let secNum = 0; + for (const [i2, category] of categories.entries()) { + if (d.type === category) { + secNum = i2 % conf2.numberSectionStyles; + } + } + let taskType = ""; + if (d.active) { + if (d.crit) { + taskType = "activeCritText" + secNum; + } else { + taskType = "activeText" + secNum; + } + } + if (d.done) { + if (d.crit) { + taskType = taskType + " doneCritText" + secNum; + } else { + taskType = taskType + " doneText" + secNum; + } + } else { + if (d.crit) { + taskType = taskType + " critText" + secNum; + } + } + if (d.milestone) { + taskType += " milestoneText"; + } + if (textWidth > endX - startX) { + if (endX + textWidth + 1.5 * conf2.leftPadding > w2) { + return classStr + " taskTextOutsideLeft taskTextOutside" + secNum + " " + taskType; + } else { + return classStr + " taskTextOutsideRight taskTextOutside" + secNum + " " + taskType + " width-" + textWidth; + } + } else { + return classStr + " taskText taskText" + secNum + " " + taskType + " width-" + textWidth; + } + }); + const securityLevel2 = getConfig$1().securityLevel; + if (securityLevel2 === "sandbox") { + let sandboxElement2; + sandboxElement2 = d3select("#i" + id2); + const doc2 = sandboxElement2.nodes()[0].contentDocument; + rectangles.filter(function(d) { + return links2[d.id] !== void 0; + }).each(function(o) { + var taskRect = doc2.querySelector("#" + o.id); + var taskText = doc2.querySelector("#" + o.id + "-text"); + const oldParent = taskRect.parentNode; + var Link = doc2.createElement("a"); + Link.setAttribute("xlink:href", links2[o.id]); + Link.setAttribute("target", "_top"); + oldParent.appendChild(Link); + Link.appendChild(taskRect); + Link.appendChild(taskText); + }); + } + } + function drawExcludeDays(theGap, theTopPad, theSidePad, w2, h2, tasks2, excludes2, includes2) { + if (excludes2.length === 0 && includes2.length === 0) { + return; + } + let minTime; + let maxTime; + for (const { startTime, endTime } of tasks2) { + if (minTime === void 0 || startTime < minTime) { + minTime = startTime; + } + if (maxTime === void 0 || endTime > maxTime) { + maxTime = endTime; + } + } + if (!minTime || !maxTime) { + return; + } + if (dayjs(maxTime).diff(dayjs(minTime), "year") > 5) { + log$1.warn( + "The difference between the min and max time is more than 5 years. This will cause performance issues. Skipping drawing exclude days." + ); + return; + } + const dateFormat2 = diagObj.db.getDateFormat(); + const excludeRanges = []; + let range2 = null; + let d = dayjs(minTime); + while (d.valueOf() <= maxTime) { + if (diagObj.db.isInvalidDate(d, dateFormat2, excludes2, includes2)) { + if (!range2) { + range2 = { + start: d, + end: d + }; + } else { + range2.end = d; + } + } else { + if (range2) { + excludeRanges.push(range2); + range2 = null; + } + } + d = d.add(1, "d"); + } + const rectangles = svg2.append("g").selectAll("rect").data(excludeRanges).enter(); + rectangles.append("rect").attr("id", function(d2) { + return "exclude-" + d2.start.format("YYYY-MM-DD"); + }).attr("x", function(d2) { + return timeScale(d2.start) + theSidePad; + }).attr("y", conf2.gridLineStartPadding).attr("width", function(d2) { + const renderEnd = d2.end.add(1, "day"); + return timeScale(renderEnd) - timeScale(d2.start); + }).attr("height", h2 - theTopPad - conf2.gridLineStartPadding).attr("transform-origin", function(d2, i2) { + return (timeScale(d2.start) + theSidePad + 0.5 * (timeScale(d2.end) - timeScale(d2.start))).toString() + "px " + (i2 * theGap + 0.5 * h2).toString() + "px"; + }).attr("class", "exclude-range"); + } + function makeGrid(theSidePad, theTopPad, w2, h2) { + let bottomXAxis = axisBottom(timeScale).tickSize(-h2 + theTopPad + conf2.gridLineStartPadding).tickFormat(timeFormat(diagObj.db.getAxisFormat() || conf2.axisFormat || "%Y-%m-%d")); + const reTickInterval = /^([1-9]\d*)(millisecond|second|minute|hour|day|week|month)$/; + const resultTickInterval = reTickInterval.exec( + diagObj.db.getTickInterval() || conf2.tickInterval + ); + if (resultTickInterval !== null) { + const every = resultTickInterval[1]; + const interval2 = resultTickInterval[2]; + const weekday2 = diagObj.db.getWeekday() || conf2.weekday; + switch (interval2) { + case "millisecond": + bottomXAxis.ticks(millisecond.every(every)); + break; + case "second": + bottomXAxis.ticks(second.every(every)); + break; + case "minute": + bottomXAxis.ticks(timeMinute.every(every)); + break; + case "hour": + bottomXAxis.ticks(timeHour.every(every)); + break; + case "day": + bottomXAxis.ticks(timeDay.every(every)); + break; + case "week": + bottomXAxis.ticks(mapWeekdayToTimeFunction[weekday2].every(every)); + break; + case "month": + bottomXAxis.ticks(timeMonth.every(every)); + break; + } + } + svg2.append("g").attr("class", "grid").attr("transform", "translate(" + theSidePad + ", " + (h2 - 50) + ")").call(bottomXAxis).selectAll("text").style("text-anchor", "middle").attr("fill", "#000").attr("stroke", "none").attr("font-size", 10).attr("dy", "1em"); + if (diagObj.db.topAxisEnabled() || conf2.topAxis) { + let topXAxis = axisTop(timeScale).tickSize(-h2 + theTopPad + conf2.gridLineStartPadding).tickFormat(timeFormat(diagObj.db.getAxisFormat() || conf2.axisFormat || "%Y-%m-%d")); + if (resultTickInterval !== null) { + const every = resultTickInterval[1]; + const interval2 = resultTickInterval[2]; + const weekday2 = diagObj.db.getWeekday() || conf2.weekday; + switch (interval2) { + case "millisecond": + topXAxis.ticks(millisecond.every(every)); + break; + case "second": + topXAxis.ticks(second.every(every)); + break; + case "minute": + topXAxis.ticks(timeMinute.every(every)); + break; + case "hour": + topXAxis.ticks(timeHour.every(every)); + break; + case "day": + topXAxis.ticks(timeDay.every(every)); + break; + case "week": + topXAxis.ticks(mapWeekdayToTimeFunction[weekday2].every(every)); + break; + case "month": + topXAxis.ticks(timeMonth.every(every)); + break; + } + } + svg2.append("g").attr("class", "grid").attr("transform", "translate(" + theSidePad + ", " + theTopPad + ")").call(topXAxis).selectAll("text").style("text-anchor", "middle").attr("fill", "#000").attr("stroke", "none").attr("font-size", 10); + } + } + function vertLabels(theGap, theTopPad) { + let prevGap = 0; + const numOccurrences = Object.keys(categoryHeights).map((d) => [d, categoryHeights[d]]); + svg2.append("g").selectAll("text").data(numOccurrences).enter().append(function(d) { + const rows = d[0].split(common$1.lineBreakRegex); + const dy = -(rows.length - 1) / 2; + const svgLabel = doc.createElementNS("http://www.w3.org/2000/svg", "text"); + svgLabel.setAttribute("dy", dy + "em"); + for (const [j, row] of rows.entries()) { + const tspan = doc.createElementNS("http://www.w3.org/2000/svg", "tspan"); + tspan.setAttribute("alignment-baseline", "central"); + tspan.setAttribute("x", "10"); + if (j > 0) { + tspan.setAttribute("dy", "1em"); + } + tspan.textContent = row; + svgLabel.appendChild(tspan); + } + return svgLabel; + }).attr("x", 10).attr("y", function(d, i2) { + if (i2 > 0) { + for (let j = 0; j < i2; j++) { + prevGap += numOccurrences[i2 - 1][1]; + return d[1] * theGap / 2 + prevGap * theGap + theTopPad; + } + } else { + return d[1] * theGap / 2 + theTopPad; + } + }).attr("font-size", conf2.sectionFontSize).attr("class", function(d) { + for (const [i2, category] of categories.entries()) { + if (d[0] === category) { + return "sectionTitle sectionTitle" + i2 % conf2.numberSectionStyles; + } + } + return "sectionTitle"; + }); + } + function drawToday(theSidePad, theTopPad, w2, h2) { + const todayMarker2 = diagObj.db.getTodayMarker(); + if (todayMarker2 === "off") { + return; + } + const todayG = svg2.append("g").attr("class", "today"); + const today = /* @__PURE__ */ new Date(); + const todayLine = todayG.append("line"); + todayLine.attr("x1", timeScale(today) + theSidePad).attr("x2", timeScale(today) + theSidePad).attr("y1", conf2.titleTopMargin).attr("y2", h2 - conf2.titleTopMargin).attr("class", "today"); + if (todayMarker2 !== "") { + todayLine.attr("style", todayMarker2.replace(/,/g, ";")); + } + } + function checkUnique(arr) { + const hash = {}; + const result = []; + for (let i2 = 0, l = arr.length; i2 < l; ++i2) { + if (!Object.prototype.hasOwnProperty.call(hash, arr[i2])) { + hash[arr[i2]] = true; + result.push(arr[i2]); + } + } + return result; + } + }; + const ganttRenderer = { + setConf: setConf$5, + draw: draw$g + }; + const getStyles$a = (options2) => ` + .mermaid-main-font { + font-family: var(--mermaid-font-family, "trebuchet ms", verdana, arial, sans-serif); + } + + .exclude-range { + fill: ${options2.excludeBkgColor}; + } + + .section { + stroke: none; + opacity: 0.2; + } + + .section0 { + fill: ${options2.sectionBkgColor}; + } + + .section2 { + fill: ${options2.sectionBkgColor2}; + } + + .section1, + .section3 { + fill: ${options2.altSectionBkgColor}; + opacity: 0.2; + } + + .sectionTitle0 { + fill: ${options2.titleColor}; + } + + .sectionTitle1 { + fill: ${options2.titleColor}; + } + + .sectionTitle2 { + fill: ${options2.titleColor}; + } + + .sectionTitle3 { + fill: ${options2.titleColor}; + } + + .sectionTitle { + text-anchor: start; + font-family: var(--mermaid-font-family, "trebuchet ms", verdana, arial, sans-serif); + } + + + /* Grid and axis */ + + .grid .tick { + stroke: ${options2.gridColor}; + opacity: 0.8; + shape-rendering: crispEdges; + } + + .grid .tick text { + font-family: ${options2.fontFamily}; + fill: ${options2.textColor}; + } + + .grid path { + stroke-width: 0; + } + + + /* Today line */ + + .today { + fill: none; + stroke: ${options2.todayLineColor}; + stroke-width: 2px; + } + + + /* Task styling */ + + /* Default task */ + + .task { + stroke-width: 2; + } + + .taskText { + text-anchor: middle; + font-family: var(--mermaid-font-family, "trebuchet ms", verdana, arial, sans-serif); + } + + .taskTextOutsideRight { + fill: ${options2.taskTextDarkColor}; + text-anchor: start; + font-family: var(--mermaid-font-family, "trebuchet ms", verdana, arial, sans-serif); + } + + .taskTextOutsideLeft { + fill: ${options2.taskTextDarkColor}; + text-anchor: end; + } + + + /* Special case clickable */ + + .task.clickable { + cursor: pointer; + } + + .taskText.clickable { + cursor: pointer; + fill: ${options2.taskTextClickableColor} !important; + font-weight: bold; + } + + .taskTextOutsideLeft.clickable { + cursor: pointer; + fill: ${options2.taskTextClickableColor} !important; + font-weight: bold; + } + + .taskTextOutsideRight.clickable { + cursor: pointer; + fill: ${options2.taskTextClickableColor} !important; + font-weight: bold; + } + + + /* Specific task settings for the sections*/ + + .taskText0, + .taskText1, + .taskText2, + .taskText3 { + fill: ${options2.taskTextColor}; + } + + .task0, + .task1, + .task2, + .task3 { + fill: ${options2.taskBkgColor}; + stroke: ${options2.taskBorderColor}; + } + + .taskTextOutside0, + .taskTextOutside2 + { + fill: ${options2.taskTextOutsideColor}; + } + + .taskTextOutside1, + .taskTextOutside3 { + fill: ${options2.taskTextOutsideColor}; + } + + + /* Active task */ + + .active0, + .active1, + .active2, + .active3 { + fill: ${options2.activeTaskBkgColor}; + stroke: ${options2.activeTaskBorderColor}; + } + + .activeText0, + .activeText1, + .activeText2, + .activeText3 { + fill: ${options2.taskTextDarkColor} !important; + } + + + /* Completed task */ + + .done0, + .done1, + .done2, + .done3 { + stroke: ${options2.doneTaskBorderColor}; + fill: ${options2.doneTaskBkgColor}; + stroke-width: 2; + } + + .doneText0, + .doneText1, + .doneText2, + .doneText3 { + fill: ${options2.taskTextDarkColor} !important; + } + + + /* Tasks on the critical line */ + + .crit0, + .crit1, + .crit2, + .crit3 { + stroke: ${options2.critBorderColor}; + fill: ${options2.critBkgColor}; + stroke-width: 2; + } + + .activeCrit0, + .activeCrit1, + .activeCrit2, + .activeCrit3 { + stroke: ${options2.critBorderColor}; + fill: ${options2.activeTaskBkgColor}; + stroke-width: 2; + } + + .doneCrit0, + .doneCrit1, + .doneCrit2, + .doneCrit3 { + stroke: ${options2.critBorderColor}; + fill: ${options2.doneTaskBkgColor}; + stroke-width: 2; + cursor: pointer; + shape-rendering: crispEdges; + } + + .milestone { + transform: rotate(45deg) scale(0.8,0.8); + } + + .milestoneText { + font-style: italic; + } + .doneCritText0, + .doneCritText1, + .doneCritText2, + .doneCritText3 { + fill: ${options2.taskTextDarkColor} !important; + } + + .activeCritText0, + .activeCritText1, + .activeCritText2, + .activeCritText3 { + fill: ${options2.taskTextDarkColor} !important; + } + + .titleText { + text-anchor: middle; + font-size: 18px; + fill: ${options2.titleColor || options2.textColor}; + font-family: var(--mermaid-font-family, "trebuchet ms", verdana, arial, sans-serif); + } +`; + const ganttStyles = getStyles$a; + const diagram$g = { + parser: ganttParser, + db: ganttDb, + renderer: ganttRenderer, + styles: ganttStyles + }; + const ganttDiagram = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + diagram: diagram$g + }, Symbol.toStringTag, { value: "Module" })); + var parser$o = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [6, 9, 10]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "info": 4, "document": 5, "EOF": 6, "line": 7, "statement": 8, "NL": 9, "showInfo": 10, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 4: "info", 6: "EOF", 9: "NL", 10: "showInfo" }, + productions_: [0, [3, 3], [5, 0], [5, 2], [7, 1], [7, 1], [8, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + $$.length - 1; + switch (yystate) { + case 1: + return yy; + case 4: + break; + case 6: + yy.setInfo(true); + break; + } + }, + table: [{ 3: 1, 4: [1, 2] }, { 1: [3] }, o($V0, [2, 2], { 5: 3 }), { 6: [1, 4], 7: 5, 8: 6, 9: [1, 7], 10: [1, 8] }, { 1: [2, 1] }, o($V0, [2, 3]), o($V0, [2, 4]), o($V0, [2, 5]), o($V0, [2, 6])], + defaultActions: { 4: [2, 1] }, + parseError: function parseError(str2, hash) { + if (hash.recoverable) { + this.trace(str2); + } else { + var error = new Error(str2); + error.hash = hash; + throw error; + } + }, + parse: function parse2(input) { + var self2 = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex2() { + var token2; + token2 = tstack.pop() || lexer2.lex() || EOF; + if (typeof token2 !== "number") { + if (token2 instanceof Array) { + tstack = token2; + token2 = tstack.pop(); + } + token2 = self2.symbols_[token2] || token2; + } + return token2; + } + var symbol, state2, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state2 = stack[stack.length - 1]; + if (this.defaultActions[state2]) { + action = this.defaultActions[state2]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex2(); + } + action = table[state2] && table[state2][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state2]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state2 + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str2, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str2, hash); + } else { + throw new Error(str2); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch2 = this._input[0]; + this.yytext += ch2; + this.yyleng++; + this.offset++; + this.match += ch2; + this.matched += ch2; + var lines = ch2.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch2; + }, + // unshifts one char (or a string) into the input + unput: function(ch2) { + var len = ch2.length; + var lines = ch2.split(/(?:\r\n?|\n)/g); + this._input = ch2 + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next2 = this.match; + if (next2.length < 20) { + next2 += this._input.substr(0, 20 - next2.length); + } + return (next2.substr(0, 20) + (next2.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c2 = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c2 + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token2, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token2 = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token2) { + return token2; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token2, match, tempMatch, index2; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i2 = 0; i2 < rules.length; i2++) { + tempMatch = this._input.match(this.rules[rules[i2]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index2 = i2; + if (this.options.backtrack_lexer) { + token2 = this.test_match(tempMatch, rules[i2]); + if (token2 !== false) { + return token2; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token2 = this.test_match(match, rules[index2]); + if (token2 !== false) { + return token2; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex2() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + return 4; + case 1: + return 9; + case 2: + return "space"; + case 3: + return 10; + case 4: + return 6; + case 5: + return "TXT"; + } + }, + rules: [/^(?:info\b)/i, /^(?:[\s\n\r]+)/i, /^(?:[\s]+)/i, /^(?:showInfo\b)/i, /^(?:$)/i, /^(?:.)/i], + conditions: { "INITIAL": { "rules": [0, 1, 2, 3, 4, 5], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser2() { + this.yy = {}; + } + Parser2.prototype = parser2; + parser2.Parser = Parser2; + return new Parser2(); + }(); + parser$o.parser = parser$o; + const parser$p = parser$o; + const DEFAULT_INFO_DB = { + info: false + }; + let info = DEFAULT_INFO_DB.info; + const setInfo = (toggle) => { + info = toggle; + }; + const getInfo = () => info; + const clear$c = () => { + info = DEFAULT_INFO_DB.info; + }; + const db$e = { + clear: clear$c, + setInfo, + getInfo + }; + const draw$f = (text2, id2, version2) => { + log$1.debug("rendering info diagram\n" + text2); + const svg2 = selectSvgElement(id2); + configureSvgSize(svg2, 100, 400, true); + const group = svg2.append("g"); + group.append("text").attr("x", 100).attr("y", 40).attr("class", "version").attr("font-size", 32).style("text-anchor", "middle").text(`v${version2}`); + }; + const renderer$f = { draw: draw$f }; + const diagram$f = { + parser: parser$p, + db: db$e, + renderer: renderer$f + }; + const infoDiagram = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + diagram: diagram$f + }, Symbol.toStringTag, { value: "Module" })); + var parser$m = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 3], $V1 = [1, 4], $V2 = [1, 5], $V3 = [1, 6], $V4 = [1, 10, 12, 14, 16, 18, 19, 20, 21, 22], $V5 = [2, 4], $V6 = [1, 5, 10, 12, 14, 16, 18, 19, 20, 21, 22], $V7 = [20, 21, 22], $V8 = [2, 7], $V9 = [1, 12], $Va = [1, 13], $Vb = [1, 14], $Vc = [1, 15], $Vd = [1, 16], $Ve = [1, 17]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "eol": 4, "PIE": 5, "document": 6, "showData": 7, "line": 8, "statement": 9, "txt": 10, "value": 11, "title": 12, "title_value": 13, "acc_title": 14, "acc_title_value": 15, "acc_descr": 16, "acc_descr_value": 17, "acc_descr_multiline_value": 18, "section": 19, "NEWLINE": 20, ";": 21, "EOF": 22, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 5: "PIE", 7: "showData", 10: "txt", 11: "value", 12: "title", 13: "title_value", 14: "acc_title", 15: "acc_title_value", 16: "acc_descr", 17: "acc_descr_value", 18: "acc_descr_multiline_value", 19: "section", 20: "NEWLINE", 21: ";", 22: "EOF" }, + productions_: [0, [3, 2], [3, 2], [3, 3], [6, 0], [6, 2], [8, 2], [9, 0], [9, 2], [9, 2], [9, 2], [9, 2], [9, 1], [9, 1], [4, 1], [4, 1], [4, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 3: + yy.setShowData(true); + break; + case 6: + this.$ = $$[$0 - 1]; + break; + case 8: + yy.addSection($$[$0 - 1], yy.cleanupValue($$[$0])); + break; + case 9: + this.$ = $$[$0].trim(); + yy.setDiagramTitle(this.$); + break; + case 10: + this.$ = $$[$0].trim(); + yy.setAccTitle(this.$); + break; + case 11: + case 12: + this.$ = $$[$0].trim(); + yy.setAccDescription(this.$); + break; + case 13: + yy.addSection($$[$0].substr(8)); + this.$ = $$[$0].substr(8); + break; + } + }, + table: [{ 3: 1, 4: 2, 5: $V0, 20: $V1, 21: $V2, 22: $V3 }, { 1: [3] }, { 3: 7, 4: 2, 5: $V0, 20: $V1, 21: $V2, 22: $V3 }, o($V4, $V5, { 6: 8, 7: [1, 9] }), o($V6, [2, 14]), o($V6, [2, 15]), o($V6, [2, 16]), { 1: [2, 1] }, o($V7, $V8, { 8: 10, 9: 11, 1: [2, 2], 10: $V9, 12: $Va, 14: $Vb, 16: $Vc, 18: $Vd, 19: $Ve }), o($V4, $V5, { 6: 18 }), o($V4, [2, 5]), { 4: 19, 20: $V1, 21: $V2, 22: $V3 }, { 11: [1, 20] }, { 13: [1, 21] }, { 15: [1, 22] }, { 17: [1, 23] }, o($V7, [2, 12]), o($V7, [2, 13]), o($V7, $V8, { 8: 10, 9: 11, 1: [2, 3], 10: $V9, 12: $Va, 14: $Vb, 16: $Vc, 18: $Vd, 19: $Ve }), o($V4, [2, 6]), o($V7, [2, 8]), o($V7, [2, 9]), o($V7, [2, 10]), o($V7, [2, 11])], + defaultActions: { 7: [2, 1] }, + parseError: function parseError(str2, hash) { + if (hash.recoverable) { + this.trace(str2); + } else { + var error = new Error(str2); + error.hash = hash; + throw error; + } + }, + parse: function parse2(input) { + var self2 = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex2() { + var token2; + token2 = tstack.pop() || lexer2.lex() || EOF; + if (typeof token2 !== "number") { + if (token2 instanceof Array) { + tstack = token2; + token2 = tstack.pop(); + } + token2 = self2.symbols_[token2] || token2; + } + return token2; + } + var symbol, state2, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state2 = stack[stack.length - 1]; + if (this.defaultActions[state2]) { + action = this.defaultActions[state2]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex2(); + } + action = table[state2] && table[state2][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state2]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state2 + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str2, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str2, hash); + } else { + throw new Error(str2); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch2 = this._input[0]; + this.yytext += ch2; + this.yyleng++; + this.offset++; + this.match += ch2; + this.matched += ch2; + var lines = ch2.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch2; + }, + // unshifts one char (or a string) into the input + unput: function(ch2) { + var len = ch2.length; + var lines = ch2.split(/(?:\r\n?|\n)/g); + this._input = ch2 + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next2 = this.match; + if (next2.length < 20) { + next2 += this._input.substr(0, 20 - next2.length); + } + return (next2.substr(0, 20) + (next2.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c2 = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c2 + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token2, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token2 = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token2) { + return token2; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token2, match, tempMatch, index2; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i2 = 0; i2 < rules.length; i2++) { + tempMatch = this._input.match(this.rules[rules[i2]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index2 = i2; + if (this.options.backtrack_lexer) { + token2 = this.test_match(tempMatch, rules[i2]); + if (token2 !== false) { + return token2; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token2 = this.test_match(match, rules[index2]); + if (token2 !== false) { + return token2; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex2() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + break; + case 1: + break; + case 2: + return 20; + case 3: + break; + case 4: + break; + case 5: + this.begin("title"); + return 12; + case 6: + this.popState(); + return "title_value"; + case 7: + this.begin("acc_title"); + return 14; + case 8: + this.popState(); + return "acc_title_value"; + case 9: + this.begin("acc_descr"); + return 16; + case 10: + this.popState(); + return "acc_descr_value"; + case 11: + this.begin("acc_descr_multiline"); + break; + case 12: + this.popState(); + break; + case 13: + return "acc_descr_multiline_value"; + case 14: + this.begin("string"); + break; + case 15: + this.popState(); + break; + case 16: + return "txt"; + case 17: + return 5; + case 18: + return 7; + case 19: + return "value"; + case 20: + return 22; + } + }, + rules: [/^(?:%%(?!\{)[^\n]*)/i, /^(?:[^\}]%%[^\n]*)/i, /^(?:[\n\r]+)/i, /^(?:%%[^\n]*)/i, /^(?:[\s]+)/i, /^(?:title\b)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accTitle\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*\{\s*)/i, /^(?:[\}])/i, /^(?:[^\}]*)/i, /^(?:["])/i, /^(?:["])/i, /^(?:[^"]*)/i, /^(?:pie\b)/i, /^(?:showData\b)/i, /^(?::[\s]*[\d]+(?:\.[\d]+)?)/i, /^(?:$)/i], + conditions: { "acc_descr_multiline": { "rules": [12, 13], "inclusive": false }, "acc_descr": { "rules": [10], "inclusive": false }, "acc_title": { "rules": [8], "inclusive": false }, "title": { "rules": [6], "inclusive": false }, "string": { "rules": [15, 16], "inclusive": false }, "INITIAL": { "rules": [0, 1, 2, 3, 4, 5, 7, 9, 11, 14, 17, 18, 19, 20], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser2() { + this.yy = {}; + } + Parser2.prototype = parser2; + parser2.Parser = Parser2; + return new Parser2(); + }(); + parser$m.parser = parser$m; + const parser$n = parser$m; + const DEFAULT_PIE_CONFIG = defaultConfig$2.pie; + const DEFAULT_PIE_DB = { + sections: {}, + showData: false, + config: DEFAULT_PIE_CONFIG + }; + let sections$2 = DEFAULT_PIE_DB.sections; + let showData = DEFAULT_PIE_DB.showData; + const config$2 = structuredClone(DEFAULT_PIE_CONFIG); + const getConfig = () => structuredClone(config$2); + const clear$b = () => { + sections$2 = structuredClone(DEFAULT_PIE_DB.sections); + showData = DEFAULT_PIE_DB.showData; + clear$n(); + }; + const addSection$2 = (label, value2) => { + label = sanitizeText$6(label, getConfig$1()); + if (sections$2[label] === void 0) { + sections$2[label] = value2; + log$1.debug(`added new section: ${label}, with value: ${value2}`); + } + }; + const getSections$2 = () => sections$2; + const cleanupValue = (value2) => { + if (value2.substring(0, 1) === ":") { + value2 = value2.substring(1).trim(); + } + return Number(value2.trim()); + }; + const setShowData = (toggle) => { + showData = toggle; + }; + const getShowData = () => showData; + const db$d = { + getConfig, + clear: clear$b, + setDiagramTitle, + getDiagramTitle, + setAccTitle, + getAccTitle, + setAccDescription, + getAccDescription, + addSection: addSection$2, + getSections: getSections$2, + cleanupValue, + setShowData, + getShowData + }; + const getStyles$9 = (options2) => ` + .pieCircle{ + stroke: ${options2.pieStrokeColor}; + stroke-width : ${options2.pieStrokeWidth}; + opacity : ${options2.pieOpacity}; + } + .pieOuterCircle{ + stroke: ${options2.pieOuterStrokeColor}; + stroke-width: ${options2.pieOuterStrokeWidth}; + fill: none; + } + .pieTitleText { + text-anchor: middle; + font-size: ${options2.pieTitleTextSize}; + fill: ${options2.pieTitleTextColor}; + font-family: ${options2.fontFamily}; + } + .slice { + font-family: ${options2.fontFamily}; + fill: ${options2.pieSectionTextColor}; + font-size:${options2.pieSectionTextSize}; + // fill: white; + } + .legend text { + fill: ${options2.pieLegendTextColor}; + font-family: ${options2.fontFamily}; + font-size: ${options2.pieLegendTextSize}; + } +`; + const styles$8 = getStyles$9; + const createPieArcs = (sections2) => { + const pieData = Object.entries(sections2).map((element2) => { + return { + label: element2[0], + value: element2[1] + }; + }).sort((a, b) => { + return b.value - a.value; + }); + const pie2 = d3pie().value( + (d3Section) => d3Section.value + ); + return pie2(pieData); + }; + const draw$e = (text2, id2, _version, diagObj) => { + log$1.debug("rendering pie chart\n" + text2); + const db2 = diagObj.db; + const globalConfig = getConfig$1(); + const pieConfig = cleanAndMerge(db2.getConfig(), globalConfig.pie); + const MARGIN = 40; + const LEGEND_RECT_SIZE = 18; + const LEGEND_SPACING = 4; + const height = 450; + const pieWidth = height; + const svg2 = selectSvgElement(id2); + const group = svg2.append("g"); + const sections2 = db2.getSections(); + group.attr("transform", "translate(" + pieWidth / 2 + "," + height / 2 + ")"); + const { themeVariables } = globalConfig; + let [outerStrokeWidth] = parseFontSize(themeVariables.pieOuterStrokeWidth); + outerStrokeWidth ?? (outerStrokeWidth = 2); + const textPosition = pieConfig.textPosition; + const radius = Math.min(pieWidth, height) / 2 - MARGIN; + const arcGenerator = d3arc().innerRadius(0).outerRadius(radius); + const labelArcGenerator = d3arc().innerRadius(radius * textPosition).outerRadius(radius * textPosition); + group.append("circle").attr("cx", 0).attr("cy", 0).attr("r", radius + outerStrokeWidth / 2).attr("class", "pieOuterCircle"); + const arcs = createPieArcs(sections2); + const myGeneratedColors = [ + themeVariables.pie1, + themeVariables.pie2, + themeVariables.pie3, + themeVariables.pie4, + themeVariables.pie5, + themeVariables.pie6, + themeVariables.pie7, + themeVariables.pie8, + themeVariables.pie9, + themeVariables.pie10, + themeVariables.pie11, + themeVariables.pie12 + ]; + const color2 = ordinal(myGeneratedColors); + group.selectAll("mySlices").data(arcs).enter().append("path").attr("d", arcGenerator).attr("fill", (datum2) => { + return color2(datum2.data.label); + }).attr("class", "pieCircle"); + let sum2 = 0; + Object.keys(sections2).forEach((key) => { + sum2 += sections2[key]; + }); + group.selectAll("mySlices").data(arcs).enter().append("text").text((datum2) => { + return (datum2.data.value / sum2 * 100).toFixed(0) + "%"; + }).attr("transform", (datum2) => { + return "translate(" + labelArcGenerator.centroid(datum2) + ")"; + }).style("text-anchor", "middle").attr("class", "slice"); + group.append("text").text(db2.getDiagramTitle()).attr("x", 0).attr("y", -(height - 50) / 2).attr("class", "pieTitleText"); + const legend = group.selectAll(".legend").data(color2.domain()).enter().append("g").attr("class", "legend").attr("transform", (_datum, index2) => { + const height2 = LEGEND_RECT_SIZE + LEGEND_SPACING; + const offset = height2 * color2.domain().length / 2; + const horizontal = 12 * LEGEND_RECT_SIZE; + const vertical = index2 * height2 - offset; + return "translate(" + horizontal + "," + vertical + ")"; + }); + legend.append("rect").attr("width", LEGEND_RECT_SIZE).attr("height", LEGEND_RECT_SIZE).style("fill", color2).style("stroke", color2); + legend.data(arcs).append("text").attr("x", LEGEND_RECT_SIZE + LEGEND_SPACING).attr("y", LEGEND_RECT_SIZE - LEGEND_SPACING).text((datum2) => { + const { label, value: value2 } = datum2.data; + if (db2.getShowData()) { + return `${label} [${value2}]`; + } + return label; + }); + const longestTextWidth = Math.max( + ...legend.selectAll("text").nodes().map((node2) => (node2 == null ? void 0 : node2.getBoundingClientRect().width) ?? 0) + ); + const totalWidth = pieWidth + MARGIN + LEGEND_RECT_SIZE + LEGEND_SPACING + longestTextWidth; + svg2.attr("viewBox", `0 0 ${totalWidth} ${height}`); + configureSvgSize(svg2, height, totalWidth, pieConfig.useMaxWidth); + }; + const renderer$e = { draw: draw$e }; + const diagram$e = { + parser: parser$n, + db: db$d, + renderer: renderer$e, + styles: styles$8 + }; + const pieDiagram = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + diagram: diagram$e + }, Symbol.toStringTag, { value: "Module" })); + var parser$k = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 3], $V1 = [1, 4], $V2 = [1, 5], $V3 = [1, 6], $V4 = [1, 7], $V5 = [1, 5, 13, 15, 17, 19, 20, 25, 27, 28, 29, 30, 31, 32, 33, 34, 37, 38, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50], $V6 = [1, 5, 6, 13, 15, 17, 19, 20, 25, 27, 28, 29, 30, 31, 32, 33, 34, 37, 38, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50], $V7 = [32, 33, 34], $V8 = [2, 7], $V9 = [1, 13], $Va = [1, 17], $Vb = [1, 18], $Vc = [1, 19], $Vd = [1, 20], $Ve = [1, 21], $Vf = [1, 22], $Vg = [1, 23], $Vh = [1, 24], $Vi = [1, 25], $Vj = [1, 26], $Vk = [1, 27], $Vl = [1, 30], $Vm = [1, 31], $Vn = [1, 32], $Vo = [1, 33], $Vp = [1, 34], $Vq = [1, 35], $Vr = [1, 36], $Vs = [1, 37], $Vt = [1, 38], $Vu = [1, 39], $Vv = [1, 40], $Vw = [1, 41], $Vx = [1, 42], $Vy = [1, 57], $Vz = [1, 58], $VA = [5, 22, 26, 32, 33, 34, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "eol": 4, "SPACE": 5, "QUADRANT": 6, "document": 7, "line": 8, "statement": 9, "axisDetails": 10, "quadrantDetails": 11, "points": 12, "title": 13, "title_value": 14, "acc_title": 15, "acc_title_value": 16, "acc_descr": 17, "acc_descr_value": 18, "acc_descr_multiline_value": 19, "section": 20, "text": 21, "point_start": 22, "point_x": 23, "point_y": 24, "X-AXIS": 25, "AXIS-TEXT-DELIMITER": 26, "Y-AXIS": 27, "QUADRANT_1": 28, "QUADRANT_2": 29, "QUADRANT_3": 30, "QUADRANT_4": 31, "NEWLINE": 32, "SEMI": 33, "EOF": 34, "alphaNumToken": 35, "textNoTagsToken": 36, "STR": 37, "MD_STR": 38, "alphaNum": 39, "PUNCTUATION": 40, "AMP": 41, "NUM": 42, "ALPHA": 43, "COMMA": 44, "PLUS": 45, "EQUALS": 46, "MULT": 47, "DOT": 48, "BRKT": 49, "UNDERSCORE": 50, "MINUS": 51, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 5: "SPACE", 6: "QUADRANT", 13: "title", 14: "title_value", 15: "acc_title", 16: "acc_title_value", 17: "acc_descr", 18: "acc_descr_value", 19: "acc_descr_multiline_value", 20: "section", 22: "point_start", 23: "point_x", 24: "point_y", 25: "X-AXIS", 26: "AXIS-TEXT-DELIMITER", 27: "Y-AXIS", 28: "QUADRANT_1", 29: "QUADRANT_2", 30: "QUADRANT_3", 31: "QUADRANT_4", 32: "NEWLINE", 33: "SEMI", 34: "EOF", 37: "STR", 38: "MD_STR", 40: "PUNCTUATION", 41: "AMP", 42: "NUM", 43: "ALPHA", 44: "COMMA", 45: "PLUS", 46: "EQUALS", 47: "MULT", 48: "DOT", 49: "BRKT", 50: "UNDERSCORE", 51: "MINUS" }, + productions_: [0, [3, 2], [3, 2], [3, 2], [7, 0], [7, 2], [8, 2], [9, 0], [9, 2], [9, 1], [9, 1], [9, 1], [9, 2], [9, 2], [9, 2], [9, 1], [9, 1], [12, 4], [10, 4], [10, 3], [10, 2], [10, 4], [10, 3], [10, 2], [11, 2], [11, 2], [11, 2], [11, 2], [4, 1], [4, 1], [4, 1], [21, 1], [21, 2], [21, 1], [21, 1], [39, 1], [39, 2], [35, 1], [35, 1], [35, 1], [35, 1], [35, 1], [35, 1], [35, 1], [35, 1], [35, 1], [35, 1], [35, 1], [36, 1], [36, 1], [36, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 12: + this.$ = $$[$0].trim(); + yy.setDiagramTitle(this.$); + break; + case 13: + this.$ = $$[$0].trim(); + yy.setAccTitle(this.$); + break; + case 14: + case 15: + this.$ = $$[$0].trim(); + yy.setAccDescription(this.$); + break; + case 16: + yy.addSection($$[$0].substr(8)); + this.$ = $$[$0].substr(8); + break; + case 17: + yy.addPoint($$[$0 - 3], $$[$0 - 1], $$[$0]); + break; + case 18: + yy.setXAxisLeftText($$[$0 - 2]); + yy.setXAxisRightText($$[$0]); + break; + case 19: + $$[$0 - 1].text += " ⟶ "; + yy.setXAxisLeftText($$[$0 - 1]); + break; + case 20: + yy.setXAxisLeftText($$[$0]); + break; + case 21: + yy.setYAxisBottomText($$[$0 - 2]); + yy.setYAxisTopText($$[$0]); + break; + case 22: + $$[$0 - 1].text += " ⟶ "; + yy.setYAxisBottomText($$[$0 - 1]); + break; + case 23: + yy.setYAxisBottomText($$[$0]); + break; + case 24: + yy.setQuadrant1Text($$[$0]); + break; + case 25: + yy.setQuadrant2Text($$[$0]); + break; + case 26: + yy.setQuadrant3Text($$[$0]); + break; + case 27: + yy.setQuadrant4Text($$[$0]); + break; + case 31: + this.$ = { text: $$[$0], type: "text" }; + break; + case 32: + this.$ = { text: $$[$0 - 1].text + "" + $$[$0], type: $$[$0 - 1].type }; + break; + case 33: + this.$ = { text: $$[$0], type: "text" }; + break; + case 34: + this.$ = { text: $$[$0], type: "markdown" }; + break; + case 35: + this.$ = $$[$0]; + break; + case 36: + this.$ = $$[$0 - 1] + "" + $$[$0]; + break; + } + }, + table: [{ 3: 1, 4: 2, 5: $V0, 6: $V1, 32: $V2, 33: $V3, 34: $V4 }, { 1: [3] }, { 3: 8, 4: 2, 5: $V0, 6: $V1, 32: $V2, 33: $V3, 34: $V4 }, { 3: 9, 4: 2, 5: $V0, 6: $V1, 32: $V2, 33: $V3, 34: $V4 }, o($V5, [2, 4], { 7: 10 }), o($V6, [2, 28]), o($V6, [2, 29]), o($V6, [2, 30]), { 1: [2, 1] }, { 1: [2, 2] }, o($V7, $V8, { 8: 11, 9: 12, 10: 14, 11: 15, 12: 16, 21: 28, 35: 29, 1: [2, 3], 5: $V9, 13: $Va, 15: $Vb, 17: $Vc, 19: $Vd, 20: $Ve, 25: $Vf, 27: $Vg, 28: $Vh, 29: $Vi, 30: $Vj, 31: $Vk, 37: $Vl, 38: $Vm, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx }), o($V5, [2, 5]), { 4: 43, 32: $V2, 33: $V3, 34: $V4 }, o($V7, $V8, { 10: 14, 11: 15, 12: 16, 21: 28, 35: 29, 9: 44, 5: $V9, 13: $Va, 15: $Vb, 17: $Vc, 19: $Vd, 20: $Ve, 25: $Vf, 27: $Vg, 28: $Vh, 29: $Vi, 30: $Vj, 31: $Vk, 37: $Vl, 38: $Vm, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx }), o($V7, [2, 9]), o($V7, [2, 10]), o($V7, [2, 11]), { 14: [1, 45] }, { 16: [1, 46] }, { 18: [1, 47] }, o($V7, [2, 15]), o($V7, [2, 16]), { 21: 48, 35: 29, 37: $Vl, 38: $Vm, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx }, { 21: 49, 35: 29, 37: $Vl, 38: $Vm, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx }, { 21: 50, 35: 29, 37: $Vl, 38: $Vm, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx }, { 21: 51, 35: 29, 37: $Vl, 38: $Vm, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx }, { 21: 52, 35: 29, 37: $Vl, 38: $Vm, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx }, { 21: 53, 35: 29, 37: $Vl, 38: $Vm, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx }, { 5: $Vy, 22: [1, 54], 35: 56, 36: 55, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx, 51: $Vz }, o($VA, [2, 31]), o($VA, [2, 33]), o($VA, [2, 34]), o($VA, [2, 37]), o($VA, [2, 38]), o($VA, [2, 39]), o($VA, [2, 40]), o($VA, [2, 41]), o($VA, [2, 42]), o($VA, [2, 43]), o($VA, [2, 44]), o($VA, [2, 45]), o($VA, [2, 46]), o($VA, [2, 47]), o($V5, [2, 6]), o($V7, [2, 8]), o($V7, [2, 12]), o($V7, [2, 13]), o($V7, [2, 14]), o($V7, [2, 20], { 36: 55, 35: 56, 5: $Vy, 26: [1, 59], 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx, 51: $Vz }), o($V7, [2, 23], { 36: 55, 35: 56, 5: $Vy, 26: [1, 60], 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx, 51: $Vz }), o($V7, [2, 24], { 36: 55, 35: 56, 5: $Vy, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx, 51: $Vz }), o($V7, [2, 25], { 36: 55, 35: 56, 5: $Vy, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx, 51: $Vz }), o($V7, [2, 26], { 36: 55, 35: 56, 5: $Vy, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx, 51: $Vz }), o($V7, [2, 27], { 36: 55, 35: 56, 5: $Vy, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx, 51: $Vz }), { 23: [1, 61] }, o($VA, [2, 32]), o($VA, [2, 48]), o($VA, [2, 49]), o($VA, [2, 50]), o($V7, [2, 19], { 35: 29, 21: 62, 37: $Vl, 38: $Vm, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx }), o($V7, [2, 22], { 35: 29, 21: 63, 37: $Vl, 38: $Vm, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx }), { 24: [1, 64] }, o($V7, [2, 18], { 36: 55, 35: 56, 5: $Vy, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx, 51: $Vz }), o($V7, [2, 21], { 36: 55, 35: 56, 5: $Vy, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx, 51: $Vz }), o($V7, [2, 17])], + defaultActions: { 8: [2, 1], 9: [2, 2] }, + parseError: function parseError(str2, hash) { + if (hash.recoverable) { + this.trace(str2); + } else { + var error = new Error(str2); + error.hash = hash; + throw error; + } + }, + parse: function parse2(input) { + var self2 = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex2() { + var token2; + token2 = tstack.pop() || lexer2.lex() || EOF; + if (typeof token2 !== "number") { + if (token2 instanceof Array) { + tstack = token2; + token2 = tstack.pop(); + } + token2 = self2.symbols_[token2] || token2; + } + return token2; + } + var symbol, state2, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state2 = stack[stack.length - 1]; + if (this.defaultActions[state2]) { + action = this.defaultActions[state2]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex2(); + } + action = table[state2] && table[state2][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state2]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state2 + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str2, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str2, hash); + } else { + throw new Error(str2); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch2 = this._input[0]; + this.yytext += ch2; + this.yyleng++; + this.offset++; + this.match += ch2; + this.matched += ch2; + var lines = ch2.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch2; + }, + // unshifts one char (or a string) into the input + unput: function(ch2) { + var len = ch2.length; + var lines = ch2.split(/(?:\r\n?|\n)/g); + this._input = ch2 + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next2 = this.match; + if (next2.length < 20) { + next2 += this._input.substr(0, 20 - next2.length); + } + return (next2.substr(0, 20) + (next2.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c2 = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c2 + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token2, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token2 = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token2) { + return token2; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token2, match, tempMatch, index2; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i2 = 0; i2 < rules.length; i2++) { + tempMatch = this._input.match(this.rules[rules[i2]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index2 = i2; + if (this.options.backtrack_lexer) { + token2 = this.test_match(tempMatch, rules[i2]); + if (token2 !== false) { + return token2; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token2 = this.test_match(match, rules[index2]); + if (token2 !== false) { + return token2; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex2() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + break; + case 1: + break; + case 2: + return 32; + case 3: + break; + case 4: + this.begin("title"); + return 13; + case 5: + this.popState(); + return "title_value"; + case 6: + this.begin("acc_title"); + return 15; + case 7: + this.popState(); + return "acc_title_value"; + case 8: + this.begin("acc_descr"); + return 17; + case 9: + this.popState(); + return "acc_descr_value"; + case 10: + this.begin("acc_descr_multiline"); + break; + case 11: + this.popState(); + break; + case 12: + return "acc_descr_multiline_value"; + case 13: + return 25; + case 14: + return 27; + case 15: + return 26; + case 16: + return 28; + case 17: + return 29; + case 18: + return 30; + case 19: + return 31; + case 20: + this.begin("md_string"); + break; + case 21: + return "MD_STR"; + case 22: + this.popState(); + break; + case 23: + this.begin("string"); + break; + case 24: + this.popState(); + break; + case 25: + return "STR"; + case 26: + this.begin("point_start"); + return 22; + case 27: + this.begin("point_x"); + return 23; + case 28: + this.popState(); + break; + case 29: + this.popState(); + this.begin("point_y"); + break; + case 30: + this.popState(); + return 24; + case 31: + return 6; + case 32: + return 43; + case 33: + return "COLON"; + case 34: + return 45; + case 35: + return 44; + case 36: + return 46; + case 37: + return 46; + case 38: + return 47; + case 39: + return 49; + case 40: + return 50; + case 41: + return 48; + case 42: + return 41; + case 43: + return 51; + case 44: + return 42; + case 45: + return 5; + case 46: + return 33; + case 47: + return 40; + case 48: + return 34; + } + }, + rules: [/^(?:%%(?!\{)[^\n]*)/i, /^(?:[^\}]%%[^\n]*)/i, /^(?:[\n\r]+)/i, /^(?:%%[^\n]*)/i, /^(?:title\b)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accTitle\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*\{\s*)/i, /^(?:[\}])/i, /^(?:[^\}]*)/i, /^(?: *x-axis *)/i, /^(?: *y-axis *)/i, /^(?: *--+> *)/i, /^(?: *quadrant-1 *)/i, /^(?: *quadrant-2 *)/i, /^(?: *quadrant-3 *)/i, /^(?: *quadrant-4 *)/i, /^(?:["][`])/i, /^(?:[^`"]+)/i, /^(?:[`]["])/i, /^(?:["])/i, /^(?:["])/i, /^(?:[^"]*)/i, /^(?:\s*:\s*\[\s*)/i, /^(?:(1)|(0(.\d+)?))/i, /^(?:\s*\] *)/i, /^(?:\s*,\s*)/i, /^(?:(1)|(0(.\d+)?))/i, /^(?: *quadrantChart *)/i, /^(?:[A-Za-z]+)/i, /^(?::)/i, /^(?:\+)/i, /^(?:,)/i, /^(?:=)/i, /^(?:=)/i, /^(?:\*)/i, /^(?:#)/i, /^(?:[\_])/i, /^(?:\.)/i, /^(?:&)/i, /^(?:-)/i, /^(?:[0-9]+)/i, /^(?:\s)/i, /^(?:;)/i, /^(?:[!"#$%&'*+,-.`?\\_/])/i, /^(?:$)/i], + conditions: { "point_y": { "rules": [30], "inclusive": false }, "point_x": { "rules": [29], "inclusive": false }, "point_start": { "rules": [27, 28], "inclusive": false }, "acc_descr_multiline": { "rules": [11, 12], "inclusive": false }, "acc_descr": { "rules": [9], "inclusive": false }, "acc_title": { "rules": [7], "inclusive": false }, "title": { "rules": [5], "inclusive": false }, "md_string": { "rules": [21, 22], "inclusive": false }, "string": { "rules": [24, 25], "inclusive": false }, "INITIAL": { "rules": [0, 1, 2, 3, 4, 6, 8, 10, 13, 14, 15, 16, 17, 18, 19, 20, 23, 26, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser2() { + this.yy = {}; + } + Parser2.prototype = parser2; + parser2.Parser = Parser2; + return new Parser2(); + }(); + parser$k.parser = parser$k; + const parser$l = parser$k; + const defaultThemeVariables = getThemeVariables$2(); + class QuadrantBuilder { + constructor() { + this.config = this.getDefaultConfig(); + this.themeConfig = this.getDefaultThemeConfig(); + this.data = this.getDefaultData(); + } + getDefaultData() { + return { + titleText: "", + quadrant1Text: "", + quadrant2Text: "", + quadrant3Text: "", + quadrant4Text: "", + xAxisLeftText: "", + xAxisRightText: "", + yAxisBottomText: "", + yAxisTopText: "", + points: [] + }; + } + getDefaultConfig() { + var _a2, _b2, _c, _d, _e, _f, _g, _h, _i6, _j, _k, _l, _m, _n, _o, _p, _q, _r; + return { + showXAxis: true, + showYAxis: true, + showTitle: true, + chartHeight: ((_a2 = defaultConfig$2.quadrantChart) == null ? void 0 : _a2.chartWidth) || 500, + chartWidth: ((_b2 = defaultConfig$2.quadrantChart) == null ? void 0 : _b2.chartHeight) || 500, + titlePadding: ((_c = defaultConfig$2.quadrantChart) == null ? void 0 : _c.titlePadding) || 10, + titleFontSize: ((_d = defaultConfig$2.quadrantChart) == null ? void 0 : _d.titleFontSize) || 20, + quadrantPadding: ((_e = defaultConfig$2.quadrantChart) == null ? void 0 : _e.quadrantPadding) || 5, + xAxisLabelPadding: ((_f = defaultConfig$2.quadrantChart) == null ? void 0 : _f.xAxisLabelPadding) || 5, + yAxisLabelPadding: ((_g = defaultConfig$2.quadrantChart) == null ? void 0 : _g.yAxisLabelPadding) || 5, + xAxisLabelFontSize: ((_h = defaultConfig$2.quadrantChart) == null ? void 0 : _h.xAxisLabelFontSize) || 16, + yAxisLabelFontSize: ((_i6 = defaultConfig$2.quadrantChart) == null ? void 0 : _i6.yAxisLabelFontSize) || 16, + quadrantLabelFontSize: ((_j = defaultConfig$2.quadrantChart) == null ? void 0 : _j.quadrantLabelFontSize) || 16, + quadrantTextTopPadding: ((_k = defaultConfig$2.quadrantChart) == null ? void 0 : _k.quadrantTextTopPadding) || 5, + pointTextPadding: ((_l = defaultConfig$2.quadrantChart) == null ? void 0 : _l.pointTextPadding) || 5, + pointLabelFontSize: ((_m = defaultConfig$2.quadrantChart) == null ? void 0 : _m.pointLabelFontSize) || 12, + pointRadius: ((_n = defaultConfig$2.quadrantChart) == null ? void 0 : _n.pointRadius) || 5, + xAxisPosition: ((_o = defaultConfig$2.quadrantChart) == null ? void 0 : _o.xAxisPosition) || "top", + yAxisPosition: ((_p = defaultConfig$2.quadrantChart) == null ? void 0 : _p.yAxisPosition) || "left", + quadrantInternalBorderStrokeWidth: ((_q = defaultConfig$2.quadrantChart) == null ? void 0 : _q.quadrantInternalBorderStrokeWidth) || 1, + quadrantExternalBorderStrokeWidth: ((_r = defaultConfig$2.quadrantChart) == null ? void 0 : _r.quadrantExternalBorderStrokeWidth) || 2 + }; + } + getDefaultThemeConfig() { + return { + quadrant1Fill: defaultThemeVariables.quadrant1Fill, + quadrant2Fill: defaultThemeVariables.quadrant2Fill, + quadrant3Fill: defaultThemeVariables.quadrant3Fill, + quadrant4Fill: defaultThemeVariables.quadrant4Fill, + quadrant1TextFill: defaultThemeVariables.quadrant1TextFill, + quadrant2TextFill: defaultThemeVariables.quadrant2TextFill, + quadrant3TextFill: defaultThemeVariables.quadrant3TextFill, + quadrant4TextFill: defaultThemeVariables.quadrant4TextFill, + quadrantPointFill: defaultThemeVariables.quadrantPointFill, + quadrantPointTextFill: defaultThemeVariables.quadrantPointTextFill, + quadrantXAxisTextFill: defaultThemeVariables.quadrantXAxisTextFill, + quadrantYAxisTextFill: defaultThemeVariables.quadrantYAxisTextFill, + quadrantTitleFill: defaultThemeVariables.quadrantTitleFill, + quadrantInternalBorderStrokeFill: defaultThemeVariables.quadrantInternalBorderStrokeFill, + quadrantExternalBorderStrokeFill: defaultThemeVariables.quadrantExternalBorderStrokeFill + }; + } + clear() { + this.config = this.getDefaultConfig(); + this.themeConfig = this.getDefaultThemeConfig(); + this.data = this.getDefaultData(); + log$1.info("clear called"); + } + setData(data) { + this.data = { ...this.data, ...data }; + } + addPoints(points) { + this.data.points = [...points, ...this.data.points]; + } + setConfig(config2) { + log$1.trace("setConfig called with: ", config2); + this.config = { ...this.config, ...config2 }; + } + setThemeConfig(themeConfig) { + log$1.trace("setThemeConfig called with: ", themeConfig); + this.themeConfig = { ...this.themeConfig, ...themeConfig }; + } + calculateSpace(xAxisPosition, showXAxis, showYAxis, showTitle) { + const xAxisSpaceCalculation = this.config.xAxisLabelPadding * 2 + this.config.xAxisLabelFontSize; + const xAxisSpace = { + top: xAxisPosition === "top" && showXAxis ? xAxisSpaceCalculation : 0, + bottom: xAxisPosition === "bottom" && showXAxis ? xAxisSpaceCalculation : 0 + }; + const yAxisSpaceCalculation = this.config.yAxisLabelPadding * 2 + this.config.yAxisLabelFontSize; + const yAxisSpace = { + left: this.config.yAxisPosition === "left" && showYAxis ? yAxisSpaceCalculation : 0, + right: this.config.yAxisPosition === "right" && showYAxis ? yAxisSpaceCalculation : 0 + }; + const titleSpaceCalculation = this.config.titleFontSize + this.config.titlePadding * 2; + const titleSpace = { + top: showTitle ? titleSpaceCalculation : 0 + }; + const quadrantLeft = this.config.quadrantPadding + yAxisSpace.left; + const quadrantTop = this.config.quadrantPadding + xAxisSpace.top + titleSpace.top; + const quadrantWidth = this.config.chartWidth - this.config.quadrantPadding * 2 - yAxisSpace.left - yAxisSpace.right; + const quadrantHeight = this.config.chartHeight - this.config.quadrantPadding * 2 - xAxisSpace.top - xAxisSpace.bottom - titleSpace.top; + const quadrantHalfWidth = quadrantWidth / 2; + const quadrantHalfHeight = quadrantHeight / 2; + const quadrantSpace = { + quadrantLeft, + quadrantTop, + quadrantWidth, + quadrantHalfWidth, + quadrantHeight, + quadrantHalfHeight + }; + return { + xAxisSpace, + yAxisSpace, + titleSpace, + quadrantSpace + }; + } + getAxisLabels(xAxisPosition, showXAxis, showYAxis, spaceData) { + const { quadrantSpace, titleSpace } = spaceData; + const { + quadrantHalfHeight, + quadrantHeight, + quadrantLeft, + quadrantHalfWidth, + quadrantTop, + quadrantWidth + } = quadrantSpace; + const drawXAxisLabelsInMiddle = Boolean(this.data.xAxisRightText); + const drawYAxisLabelsInMiddle = Boolean(this.data.yAxisTopText); + const axisLabels = []; + if (this.data.xAxisLeftText && showXAxis) { + axisLabels.push({ + text: this.data.xAxisLeftText, + fill: this.themeConfig.quadrantXAxisTextFill, + x: quadrantLeft + (drawXAxisLabelsInMiddle ? quadrantHalfWidth / 2 : 0), + y: xAxisPosition === "top" ? this.config.xAxisLabelPadding + titleSpace.top : this.config.xAxisLabelPadding + quadrantTop + quadrantHeight + this.config.quadrantPadding, + fontSize: this.config.xAxisLabelFontSize, + verticalPos: drawXAxisLabelsInMiddle ? "center" : "left", + horizontalPos: "top", + rotation: 0 + }); + } + if (this.data.xAxisRightText && showXAxis) { + axisLabels.push({ + text: this.data.xAxisRightText, + fill: this.themeConfig.quadrantXAxisTextFill, + x: quadrantLeft + quadrantHalfWidth + (drawXAxisLabelsInMiddle ? quadrantHalfWidth / 2 : 0), + y: xAxisPosition === "top" ? this.config.xAxisLabelPadding + titleSpace.top : this.config.xAxisLabelPadding + quadrantTop + quadrantHeight + this.config.quadrantPadding, + fontSize: this.config.xAxisLabelFontSize, + verticalPos: drawXAxisLabelsInMiddle ? "center" : "left", + horizontalPos: "top", + rotation: 0 + }); + } + if (this.data.yAxisBottomText && showYAxis) { + axisLabels.push({ + text: this.data.yAxisBottomText, + fill: this.themeConfig.quadrantYAxisTextFill, + x: this.config.yAxisPosition === "left" ? this.config.yAxisLabelPadding : this.config.yAxisLabelPadding + quadrantLeft + quadrantWidth + this.config.quadrantPadding, + y: quadrantTop + quadrantHeight - (drawYAxisLabelsInMiddle ? quadrantHalfHeight / 2 : 0), + fontSize: this.config.yAxisLabelFontSize, + verticalPos: drawYAxisLabelsInMiddle ? "center" : "left", + horizontalPos: "top", + rotation: -90 + }); + } + if (this.data.yAxisTopText && showYAxis) { + axisLabels.push({ + text: this.data.yAxisTopText, + fill: this.themeConfig.quadrantYAxisTextFill, + x: this.config.yAxisPosition === "left" ? this.config.yAxisLabelPadding : this.config.yAxisLabelPadding + quadrantLeft + quadrantWidth + this.config.quadrantPadding, + y: quadrantTop + quadrantHalfHeight - (drawYAxisLabelsInMiddle ? quadrantHalfHeight / 2 : 0), + fontSize: this.config.yAxisLabelFontSize, + verticalPos: drawYAxisLabelsInMiddle ? "center" : "left", + horizontalPos: "top", + rotation: -90 + }); + } + return axisLabels; + } + getQuadrants(spaceData) { + const { quadrantSpace } = spaceData; + const { quadrantHalfHeight, quadrantLeft, quadrantHalfWidth, quadrantTop } = quadrantSpace; + const quadrants = [ + { + text: { + text: this.data.quadrant1Text, + fill: this.themeConfig.quadrant1TextFill, + x: 0, + y: 0, + fontSize: this.config.quadrantLabelFontSize, + verticalPos: "center", + horizontalPos: "middle", + rotation: 0 + }, + x: quadrantLeft + quadrantHalfWidth, + y: quadrantTop, + width: quadrantHalfWidth, + height: quadrantHalfHeight, + fill: this.themeConfig.quadrant1Fill + }, + { + text: { + text: this.data.quadrant2Text, + fill: this.themeConfig.quadrant2TextFill, + x: 0, + y: 0, + fontSize: this.config.quadrantLabelFontSize, + verticalPos: "center", + horizontalPos: "middle", + rotation: 0 + }, + x: quadrantLeft, + y: quadrantTop, + width: quadrantHalfWidth, + height: quadrantHalfHeight, + fill: this.themeConfig.quadrant2Fill + }, + { + text: { + text: this.data.quadrant3Text, + fill: this.themeConfig.quadrant3TextFill, + x: 0, + y: 0, + fontSize: this.config.quadrantLabelFontSize, + verticalPos: "center", + horizontalPos: "middle", + rotation: 0 + }, + x: quadrantLeft, + y: quadrantTop + quadrantHalfHeight, + width: quadrantHalfWidth, + height: quadrantHalfHeight, + fill: this.themeConfig.quadrant3Fill + }, + { + text: { + text: this.data.quadrant4Text, + fill: this.themeConfig.quadrant4TextFill, + x: 0, + y: 0, + fontSize: this.config.quadrantLabelFontSize, + verticalPos: "center", + horizontalPos: "middle", + rotation: 0 + }, + x: quadrantLeft + quadrantHalfWidth, + y: quadrantTop + quadrantHalfHeight, + width: quadrantHalfWidth, + height: quadrantHalfHeight, + fill: this.themeConfig.quadrant4Fill + } + ]; + for (const quadrant of quadrants) { + quadrant.text.x = quadrant.x + quadrant.width / 2; + if (this.data.points.length === 0) { + quadrant.text.y = quadrant.y + quadrant.height / 2; + quadrant.text.horizontalPos = "middle"; + } else { + quadrant.text.y = quadrant.y + this.config.quadrantTextTopPadding; + quadrant.text.horizontalPos = "top"; + } + } + return quadrants; + } + getQuadrantPoints(spaceData) { + const { quadrantSpace } = spaceData; + const { quadrantHeight, quadrantLeft, quadrantTop, quadrantWidth } = quadrantSpace; + const xAxis = linear().domain([0, 1]).range([quadrantLeft, quadrantWidth + quadrantLeft]); + const yAxis = linear().domain([0, 1]).range([quadrantHeight + quadrantTop, quadrantTop]); + const points = this.data.points.map((point2) => { + const props = { + x: xAxis(point2.x), + y: yAxis(point2.y), + fill: this.themeConfig.quadrantPointFill, + radius: this.config.pointRadius, + text: { + text: point2.text, + fill: this.themeConfig.quadrantPointTextFill, + x: xAxis(point2.x), + y: yAxis(point2.y) + this.config.pointTextPadding, + verticalPos: "center", + horizontalPos: "top", + fontSize: this.config.pointLabelFontSize, + rotation: 0 + } + }; + return props; + }); + return points; + } + getBorders(spaceData) { + const halfExternalBorderWidth = this.config.quadrantExternalBorderStrokeWidth / 2; + const { quadrantSpace } = spaceData; + const { + quadrantHalfHeight, + quadrantHeight, + quadrantLeft, + quadrantHalfWidth, + quadrantTop, + quadrantWidth + } = quadrantSpace; + const borderLines = [ + // top border + { + strokeFill: this.themeConfig.quadrantExternalBorderStrokeFill, + strokeWidth: this.config.quadrantExternalBorderStrokeWidth, + x1: quadrantLeft - halfExternalBorderWidth, + y1: quadrantTop, + x2: quadrantLeft + quadrantWidth + halfExternalBorderWidth, + y2: quadrantTop + }, + // right border + { + strokeFill: this.themeConfig.quadrantExternalBorderStrokeFill, + strokeWidth: this.config.quadrantExternalBorderStrokeWidth, + x1: quadrantLeft + quadrantWidth, + y1: quadrantTop + halfExternalBorderWidth, + x2: quadrantLeft + quadrantWidth, + y2: quadrantTop + quadrantHeight - halfExternalBorderWidth + }, + // bottom border + { + strokeFill: this.themeConfig.quadrantExternalBorderStrokeFill, + strokeWidth: this.config.quadrantExternalBorderStrokeWidth, + x1: quadrantLeft - halfExternalBorderWidth, + y1: quadrantTop + quadrantHeight, + x2: quadrantLeft + quadrantWidth + halfExternalBorderWidth, + y2: quadrantTop + quadrantHeight + }, + // left border + { + strokeFill: this.themeConfig.quadrantExternalBorderStrokeFill, + strokeWidth: this.config.quadrantExternalBorderStrokeWidth, + x1: quadrantLeft, + y1: quadrantTop + halfExternalBorderWidth, + x2: quadrantLeft, + y2: quadrantTop + quadrantHeight - halfExternalBorderWidth + }, + // vertical inner border + { + strokeFill: this.themeConfig.quadrantInternalBorderStrokeFill, + strokeWidth: this.config.quadrantInternalBorderStrokeWidth, + x1: quadrantLeft + quadrantHalfWidth, + y1: quadrantTop + halfExternalBorderWidth, + x2: quadrantLeft + quadrantHalfWidth, + y2: quadrantTop + quadrantHeight - halfExternalBorderWidth + }, + // horizontal inner border + { + strokeFill: this.themeConfig.quadrantInternalBorderStrokeFill, + strokeWidth: this.config.quadrantInternalBorderStrokeWidth, + x1: quadrantLeft + halfExternalBorderWidth, + y1: quadrantTop + quadrantHalfHeight, + x2: quadrantLeft + quadrantWidth - halfExternalBorderWidth, + y2: quadrantTop + quadrantHalfHeight + } + ]; + return borderLines; + } + getTitle(showTitle) { + if (showTitle) { + return { + text: this.data.titleText, + fill: this.themeConfig.quadrantTitleFill, + fontSize: this.config.titleFontSize, + horizontalPos: "top", + verticalPos: "center", + rotation: 0, + y: this.config.titlePadding, + x: this.config.chartWidth / 2 + }; + } + return; + } + build() { + const showXAxis = this.config.showXAxis && !!(this.data.xAxisLeftText || this.data.xAxisRightText); + const showYAxis = this.config.showYAxis && !!(this.data.yAxisTopText || this.data.yAxisBottomText); + const showTitle = this.config.showTitle && !!this.data.titleText; + const xAxisPosition = this.data.points.length > 0 ? "bottom" : this.config.xAxisPosition; + const calculatedSpace = this.calculateSpace(xAxisPosition, showXAxis, showYAxis, showTitle); + return { + points: this.getQuadrantPoints(calculatedSpace), + quadrants: this.getQuadrants(calculatedSpace), + axisLabels: this.getAxisLabels(xAxisPosition, showXAxis, showYAxis, calculatedSpace), + borderLines: this.getBorders(calculatedSpace), + title: this.getTitle(showTitle) + }; + } + } + const config$1 = getConfig$1(); + function textSanitizer$1(text2) { + return sanitizeText$6(text2.trim(), config$1); + } + const quadrantBuilder = new QuadrantBuilder(); + function setQuadrant1Text(textObj) { + quadrantBuilder.setData({ quadrant1Text: textSanitizer$1(textObj.text) }); + } + function setQuadrant2Text(textObj) { + quadrantBuilder.setData({ quadrant2Text: textSanitizer$1(textObj.text) }); + } + function setQuadrant3Text(textObj) { + quadrantBuilder.setData({ quadrant3Text: textSanitizer$1(textObj.text) }); + } + function setQuadrant4Text(textObj) { + quadrantBuilder.setData({ quadrant4Text: textSanitizer$1(textObj.text) }); + } + function setXAxisLeftText(textObj) { + quadrantBuilder.setData({ xAxisLeftText: textSanitizer$1(textObj.text) }); + } + function setXAxisRightText(textObj) { + quadrantBuilder.setData({ xAxisRightText: textSanitizer$1(textObj.text) }); + } + function setYAxisTopText(textObj) { + quadrantBuilder.setData({ yAxisTopText: textSanitizer$1(textObj.text) }); + } + function setYAxisBottomText(textObj) { + quadrantBuilder.setData({ yAxisBottomText: textSanitizer$1(textObj.text) }); + } + function addPoint(textObj, x2, y2) { + quadrantBuilder.addPoints([{ x: x2, y: y2, text: textSanitizer$1(textObj.text) }]); + } + function setWidth(width2) { + quadrantBuilder.setConfig({ chartWidth: width2 }); + } + function setHeight(height) { + quadrantBuilder.setConfig({ chartHeight: height }); + } + function getQuadrantData() { + const config2 = getConfig$1(); + const { themeVariables, quadrantChart: quadrantChartConfig } = config2; + if (quadrantChartConfig) { + quadrantBuilder.setConfig(quadrantChartConfig); + } + quadrantBuilder.setThemeConfig({ + quadrant1Fill: themeVariables.quadrant1Fill, + quadrant2Fill: themeVariables.quadrant2Fill, + quadrant3Fill: themeVariables.quadrant3Fill, + quadrant4Fill: themeVariables.quadrant4Fill, + quadrant1TextFill: themeVariables.quadrant1TextFill, + quadrant2TextFill: themeVariables.quadrant2TextFill, + quadrant3TextFill: themeVariables.quadrant3TextFill, + quadrant4TextFill: themeVariables.quadrant4TextFill, + quadrantPointFill: themeVariables.quadrantPointFill, + quadrantPointTextFill: themeVariables.quadrantPointTextFill, + quadrantXAxisTextFill: themeVariables.quadrantXAxisTextFill, + quadrantYAxisTextFill: themeVariables.quadrantYAxisTextFill, + quadrantExternalBorderStrokeFill: themeVariables.quadrantExternalBorderStrokeFill, + quadrantInternalBorderStrokeFill: themeVariables.quadrantInternalBorderStrokeFill, + quadrantTitleFill: themeVariables.quadrantTitleFill + }); + quadrantBuilder.setData({ titleText: getDiagramTitle() }); + return quadrantBuilder.build(); + } + const clear$a = function() { + quadrantBuilder.clear(); + clear$n(); + }; + const db$c = { + setWidth, + setHeight, + setQuadrant1Text, + setQuadrant2Text, + setQuadrant3Text, + setQuadrant4Text, + setXAxisLeftText, + setXAxisRightText, + setYAxisTopText, + setYAxisBottomText, + addPoint, + getQuadrantData, + clear: clear$a, + setAccTitle, + getAccTitle, + setDiagramTitle, + getDiagramTitle, + getAccDescription, + setAccDescription + }; + const draw$d = (txt, id2, _version, diagObj) => { + var _a2, _b2, _c; + function getDominantBaseLine(horizontalPos) { + return horizontalPos === "top" ? "hanging" : "middle"; + } + function getTextAnchor(verticalPos) { + return verticalPos === "left" ? "start" : "middle"; + } + function getTransformation(data) { + return `translate(${data.x}, ${data.y}) rotate(${data.rotation || 0})`; + } + const conf2 = getConfig$1(); + log$1.debug("Rendering quadrant chart\n" + txt); + const securityLevel = conf2.securityLevel; + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = d3select("#i" + id2); + } + const root2 = securityLevel === "sandbox" ? d3select(sandboxElement.nodes()[0].contentDocument.body) : d3select("body"); + const svg2 = root2.select(`[id="${id2}"]`); + const group = svg2.append("g").attr("class", "main"); + const width2 = ((_a2 = conf2.quadrantChart) == null ? void 0 : _a2.chartWidth) || 500; + const height = ((_b2 = conf2.quadrantChart) == null ? void 0 : _b2.chartHeight) || 500; + configureSvgSize(svg2, height, width2, ((_c = conf2.quadrantChart) == null ? void 0 : _c.useMaxWidth) || true); + svg2.attr("viewBox", "0 0 " + width2 + " " + height); + diagObj.db.setHeight(height); + diagObj.db.setWidth(width2); + const quadrantData = diagObj.db.getQuadrantData(); + const quadrantsGroup = group.append("g").attr("class", "quadrants"); + const borderGroup = group.append("g").attr("class", "border"); + const dataPointGroup = group.append("g").attr("class", "data-points"); + const labelGroup = group.append("g").attr("class", "labels"); + const titleGroup = group.append("g").attr("class", "title"); + if (quadrantData.title) { + titleGroup.append("text").attr("x", 0).attr("y", 0).attr("fill", quadrantData.title.fill).attr("font-size", quadrantData.title.fontSize).attr("dominant-baseline", getDominantBaseLine(quadrantData.title.horizontalPos)).attr("text-anchor", getTextAnchor(quadrantData.title.verticalPos)).attr("transform", getTransformation(quadrantData.title)).text(quadrantData.title.text); + } + if (quadrantData.borderLines) { + borderGroup.selectAll("line").data(quadrantData.borderLines).enter().append("line").attr("x1", (data) => data.x1).attr("y1", (data) => data.y1).attr("x2", (data) => data.x2).attr("y2", (data) => data.y2).style("stroke", (data) => data.strokeFill).style("stroke-width", (data) => data.strokeWidth); + } + const quadrants = quadrantsGroup.selectAll("g.quadrant").data(quadrantData.quadrants).enter().append("g").attr("class", "quadrant"); + quadrants.append("rect").attr("x", (data) => data.x).attr("y", (data) => data.y).attr("width", (data) => data.width).attr("height", (data) => data.height).attr("fill", (data) => data.fill); + quadrants.append("text").attr("x", 0).attr("y", 0).attr("fill", (data) => data.text.fill).attr("font-size", (data) => data.text.fontSize).attr( + "dominant-baseline", + (data) => getDominantBaseLine(data.text.horizontalPos) + ).attr("text-anchor", (data) => getTextAnchor(data.text.verticalPos)).attr("transform", (data) => getTransformation(data.text)).text((data) => data.text.text); + const labels = labelGroup.selectAll("g.label").data(quadrantData.axisLabels).enter().append("g").attr("class", "label"); + labels.append("text").attr("x", 0).attr("y", 0).text((data) => data.text).attr("fill", (data) => data.fill).attr("font-size", (data) => data.fontSize).attr("dominant-baseline", (data) => getDominantBaseLine(data.horizontalPos)).attr("text-anchor", (data) => getTextAnchor(data.verticalPos)).attr("transform", (data) => getTransformation(data)); + const dataPoints = dataPointGroup.selectAll("g.data-point").data(quadrantData.points).enter().append("g").attr("class", "data-point"); + dataPoints.append("circle").attr("cx", (data) => data.x).attr("cy", (data) => data.y).attr("r", (data) => data.radius).attr("fill", (data) => data.fill); + dataPoints.append("text").attr("x", 0).attr("y", 0).text((data) => data.text.text).attr("fill", (data) => data.text.fill).attr("font-size", (data) => data.text.fontSize).attr( + "dominant-baseline", + (data) => getDominantBaseLine(data.text.horizontalPos) + ).attr("text-anchor", (data) => getTextAnchor(data.text.verticalPos)).attr("transform", (data) => getTransformation(data.text)); + }; + const renderer$d = { + draw: draw$d + }; + const diagram$d = { + parser: parser$l, + db: db$c, + renderer: renderer$d, + styles: () => "" + }; + const quadrantDiagram = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + diagram: diagram$d + }, Symbol.toStringTag, { value: "Module" })); + var parser$i = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 10, 12, 14, 16, 18, 19, 21, 23], $V1 = [2, 6], $V2 = [1, 3], $V3 = [1, 5], $V4 = [1, 6], $V5 = [1, 7], $V6 = [1, 5, 10, 12, 14, 16, 18, 19, 21, 23, 34, 35, 36], $V7 = [1, 25], $V8 = [1, 26], $V9 = [1, 28], $Va = [1, 29], $Vb = [1, 30], $Vc = [1, 31], $Vd = [1, 32], $Ve = [1, 33], $Vf = [1, 34], $Vg = [1, 35], $Vh = [1, 36], $Vi = [1, 37], $Vj = [1, 43], $Vk = [1, 42], $Vl = [1, 47], $Vm = [1, 50], $Vn = [1, 10, 12, 14, 16, 18, 19, 21, 23, 34, 35, 36], $Vo = [1, 10, 12, 14, 16, 18, 19, 21, 23, 24, 26, 27, 28, 34, 35, 36], $Vp = [1, 10, 12, 14, 16, 18, 19, 21, 23, 24, 26, 27, 28, 34, 35, 36, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50], $Vq = [1, 64]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "eol": 4, "XYCHART": 5, "chartConfig": 6, "document": 7, "CHART_ORIENTATION": 8, "statement": 9, "title": 10, "text": 11, "X_AXIS": 12, "parseXAxis": 13, "Y_AXIS": 14, "parseYAxis": 15, "LINE": 16, "plotData": 17, "BAR": 18, "acc_title": 19, "acc_title_value": 20, "acc_descr": 21, "acc_descr_value": 22, "acc_descr_multiline_value": 23, "SQUARE_BRACES_START": 24, "commaSeparatedNumbers": 25, "SQUARE_BRACES_END": 26, "NUMBER_WITH_DECIMAL": 27, "COMMA": 28, "xAxisData": 29, "bandData": 30, "ARROW_DELIMITER": 31, "commaSeparatedTexts": 32, "yAxisData": 33, "NEWLINE": 34, "SEMI": 35, "EOF": 36, "alphaNum": 37, "STR": 38, "MD_STR": 39, "alphaNumToken": 40, "AMP": 41, "NUM": 42, "ALPHA": 43, "PLUS": 44, "EQUALS": 45, "MULT": 46, "DOT": 47, "BRKT": 48, "MINUS": 49, "UNDERSCORE": 50, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 5: "XYCHART", 8: "CHART_ORIENTATION", 10: "title", 12: "X_AXIS", 14: "Y_AXIS", 16: "LINE", 18: "BAR", 19: "acc_title", 20: "acc_title_value", 21: "acc_descr", 22: "acc_descr_value", 23: "acc_descr_multiline_value", 24: "SQUARE_BRACES_START", 26: "SQUARE_BRACES_END", 27: "NUMBER_WITH_DECIMAL", 28: "COMMA", 31: "ARROW_DELIMITER", 34: "NEWLINE", 35: "SEMI", 36: "EOF", 38: "STR", 39: "MD_STR", 41: "AMP", 42: "NUM", 43: "ALPHA", 44: "PLUS", 45: "EQUALS", 46: "MULT", 47: "DOT", 48: "BRKT", 49: "MINUS", 50: "UNDERSCORE" }, + productions_: [0, [3, 2], [3, 3], [3, 2], [3, 1], [6, 1], [7, 0], [7, 2], [9, 2], [9, 2], [9, 2], [9, 2], [9, 2], [9, 3], [9, 2], [9, 3], [9, 2], [9, 2], [9, 1], [17, 3], [25, 3], [25, 1], [13, 1], [13, 2], [13, 1], [29, 1], [29, 3], [30, 3], [32, 3], [32, 1], [15, 1], [15, 2], [15, 1], [33, 3], [4, 1], [4, 1], [4, 1], [11, 1], [11, 1], [11, 1], [37, 1], [37, 2], [40, 1], [40, 1], [40, 1], [40, 1], [40, 1], [40, 1], [40, 1], [40, 1], [40, 1], [40, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 5: + yy.setOrientation($$[$0]); + break; + case 9: + yy.setDiagramTitle($$[$0].text.trim()); + break; + case 12: + yy.setLineData({ text: "", type: "text" }, $$[$0]); + break; + case 13: + yy.setLineData($$[$0 - 1], $$[$0]); + break; + case 14: + yy.setBarData({ text: "", type: "text" }, $$[$0]); + break; + case 15: + yy.setBarData($$[$0 - 1], $$[$0]); + break; + case 16: + this.$ = $$[$0].trim(); + yy.setAccTitle(this.$); + break; + case 17: + case 18: + this.$ = $$[$0].trim(); + yy.setAccDescription(this.$); + break; + case 19: + this.$ = $$[$0 - 1]; + break; + case 20: + this.$ = [Number($$[$0 - 2]), ...$$[$0]]; + break; + case 21: + this.$ = [Number($$[$0])]; + break; + case 22: + yy.setXAxisTitle($$[$0]); + break; + case 23: + yy.setXAxisTitle($$[$0 - 1]); + break; + case 24: + yy.setXAxisTitle({ type: "text", text: "" }); + break; + case 25: + yy.setXAxisBand($$[$0]); + break; + case 26: + yy.setXAxisRangeData(Number($$[$0 - 2]), Number($$[$0])); + break; + case 27: + this.$ = $$[$0 - 1]; + break; + case 28: + this.$ = [$$[$0 - 2], ...$$[$0]]; + break; + case 29: + this.$ = [$$[$0]]; + break; + case 30: + yy.setYAxisTitle($$[$0]); + break; + case 31: + yy.setYAxisTitle($$[$0 - 1]); + break; + case 32: + yy.setYAxisTitle({ type: "text", text: "" }); + break; + case 33: + yy.setYAxisRangeData(Number($$[$0 - 2]), Number($$[$0])); + break; + case 37: + this.$ = { text: $$[$0], type: "text" }; + break; + case 38: + this.$ = { text: $$[$0], type: "text" }; + break; + case 39: + this.$ = { text: $$[$0], type: "markdown" }; + break; + case 40: + this.$ = $$[$0]; + break; + case 41: + this.$ = $$[$0 - 1] + "" + $$[$0]; + break; + } + }, + table: [o($V0, $V1, { 3: 1, 4: 2, 7: 4, 5: $V2, 34: $V3, 35: $V4, 36: $V5 }), { 1: [3] }, o($V0, $V1, { 4: 2, 7: 4, 3: 8, 5: $V2, 34: $V3, 35: $V4, 36: $V5 }), o($V0, $V1, { 4: 2, 7: 4, 6: 9, 3: 10, 5: $V2, 8: [1, 11], 34: $V3, 35: $V4, 36: $V5 }), { 1: [2, 4], 9: 12, 10: [1, 13], 12: [1, 14], 14: [1, 15], 16: [1, 16], 18: [1, 17], 19: [1, 18], 21: [1, 19], 23: [1, 20] }, o($V6, [2, 34]), o($V6, [2, 35]), o($V6, [2, 36]), { 1: [2, 1] }, o($V0, $V1, { 4: 2, 7: 4, 3: 21, 5: $V2, 34: $V3, 35: $V4, 36: $V5 }), { 1: [2, 3] }, o($V6, [2, 5]), o($V0, [2, 7], { 4: 22, 34: $V3, 35: $V4, 36: $V5 }), { 11: 23, 37: 24, 38: $V7, 39: $V8, 40: 27, 41: $V9, 42: $Va, 43: $Vb, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi }, { 11: 39, 13: 38, 24: $Vj, 27: $Vk, 29: 40, 30: 41, 37: 24, 38: $V7, 39: $V8, 40: 27, 41: $V9, 42: $Va, 43: $Vb, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi }, { 11: 45, 15: 44, 27: $Vl, 33: 46, 37: 24, 38: $V7, 39: $V8, 40: 27, 41: $V9, 42: $Va, 43: $Vb, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi }, { 11: 49, 17: 48, 24: $Vm, 37: 24, 38: $V7, 39: $V8, 40: 27, 41: $V9, 42: $Va, 43: $Vb, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi }, { 11: 52, 17: 51, 24: $Vm, 37: 24, 38: $V7, 39: $V8, 40: 27, 41: $V9, 42: $Va, 43: $Vb, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi }, { 20: [1, 53] }, { 22: [1, 54] }, o($Vn, [2, 18]), { 1: [2, 2] }, o($Vn, [2, 8]), o($Vn, [2, 9]), o($Vo, [2, 37], { 40: 55, 41: $V9, 42: $Va, 43: $Vb, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi }), o($Vo, [2, 38]), o($Vo, [2, 39]), o($Vp, [2, 40]), o($Vp, [2, 42]), o($Vp, [2, 43]), o($Vp, [2, 44]), o($Vp, [2, 45]), o($Vp, [2, 46]), o($Vp, [2, 47]), o($Vp, [2, 48]), o($Vp, [2, 49]), o($Vp, [2, 50]), o($Vp, [2, 51]), o($Vn, [2, 10]), o($Vn, [2, 22], { 30: 41, 29: 56, 24: $Vj, 27: $Vk }), o($Vn, [2, 24]), o($Vn, [2, 25]), { 31: [1, 57] }, { 11: 59, 32: 58, 37: 24, 38: $V7, 39: $V8, 40: 27, 41: $V9, 42: $Va, 43: $Vb, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi }, o($Vn, [2, 11]), o($Vn, [2, 30], { 33: 60, 27: $Vl }), o($Vn, [2, 32]), { 31: [1, 61] }, o($Vn, [2, 12]), { 17: 62, 24: $Vm }, { 25: 63, 27: $Vq }, o($Vn, [2, 14]), { 17: 65, 24: $Vm }, o($Vn, [2, 16]), o($Vn, [2, 17]), o($Vp, [2, 41]), o($Vn, [2, 23]), { 27: [1, 66] }, { 26: [1, 67] }, { 26: [2, 29], 28: [1, 68] }, o($Vn, [2, 31]), { 27: [1, 69] }, o($Vn, [2, 13]), { 26: [1, 70] }, { 26: [2, 21], 28: [1, 71] }, o($Vn, [2, 15]), o($Vn, [2, 26]), o($Vn, [2, 27]), { 11: 59, 32: 72, 37: 24, 38: $V7, 39: $V8, 40: 27, 41: $V9, 42: $Va, 43: $Vb, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi }, o($Vn, [2, 33]), o($Vn, [2, 19]), { 25: 73, 27: $Vq }, { 26: [2, 28] }, { 26: [2, 20] }], + defaultActions: { 8: [2, 1], 10: [2, 3], 21: [2, 2], 72: [2, 28], 73: [2, 20] }, + parseError: function parseError(str2, hash) { + if (hash.recoverable) { + this.trace(str2); + } else { + var error = new Error(str2); + error.hash = hash; + throw error; + } + }, + parse: function parse2(input) { + var self2 = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex2() { + var token2; + token2 = tstack.pop() || lexer2.lex() || EOF; + if (typeof token2 !== "number") { + if (token2 instanceof Array) { + tstack = token2; + token2 = tstack.pop(); + } + token2 = self2.symbols_[token2] || token2; + } + return token2; + } + var symbol, state2, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state2 = stack[stack.length - 1]; + if (this.defaultActions[state2]) { + action = this.defaultActions[state2]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex2(); + } + action = table[state2] && table[state2][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state2]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state2 + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str2, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str2, hash); + } else { + throw new Error(str2); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch2 = this._input[0]; + this.yytext += ch2; + this.yyleng++; + this.offset++; + this.match += ch2; + this.matched += ch2; + var lines = ch2.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch2; + }, + // unshifts one char (or a string) into the input + unput: function(ch2) { + var len = ch2.length; + var lines = ch2.split(/(?:\r\n?|\n)/g); + this._input = ch2 + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next2 = this.match; + if (next2.length < 20) { + next2 += this._input.substr(0, 20 - next2.length); + } + return (next2.substr(0, 20) + (next2.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c2 = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c2 + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token2, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token2 = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token2) { + return token2; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token2, match, tempMatch, index2; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i2 = 0; i2 < rules.length; i2++) { + tempMatch = this._input.match(this.rules[rules[i2]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index2 = i2; + if (this.options.backtrack_lexer) { + token2 = this.test_match(tempMatch, rules[i2]); + if (token2 !== false) { + return token2; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token2 = this.test_match(match, rules[index2]); + if (token2 !== false) { + return token2; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex2() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + break; + case 1: + break; + case 2: + this.popState(); + return 34; + case 3: + this.popState(); + return 34; + case 4: + return 34; + case 5: + break; + case 6: + return 10; + case 7: + this.pushState("acc_title"); + return 19; + case 8: + this.popState(); + return "acc_title_value"; + case 9: + this.pushState("acc_descr"); + return 21; + case 10: + this.popState(); + return "acc_descr_value"; + case 11: + this.pushState("acc_descr_multiline"); + break; + case 12: + this.popState(); + break; + case 13: + return "acc_descr_multiline_value"; + case 14: + return 5; + case 15: + return 8; + case 16: + this.pushState("axis_data"); + return "X_AXIS"; + case 17: + this.pushState("axis_data"); + return "Y_AXIS"; + case 18: + this.pushState("axis_band_data"); + return 24; + case 19: + return 31; + case 20: + this.pushState("data"); + return 16; + case 21: + this.pushState("data"); + return 18; + case 22: + this.pushState("data_inner"); + return 24; + case 23: + return 27; + case 24: + this.popState(); + return 26; + case 25: + this.popState(); + break; + case 26: + this.pushState("string"); + break; + case 27: + this.popState(); + break; + case 28: + return "STR"; + case 29: + return 24; + case 30: + return 26; + case 31: + return 43; + case 32: + return "COLON"; + case 33: + return 44; + case 34: + return 28; + case 35: + return 45; + case 36: + return 46; + case 37: + return 48; + case 38: + return 50; + case 39: + return 47; + case 40: + return 41; + case 41: + return 49; + case 42: + return 42; + case 43: + break; + case 44: + return 35; + case 45: + return 36; + } + }, + rules: [/^(?:%%(?!\{)[^\n]*)/i, /^(?:[^\}]%%[^\n]*)/i, /^(?:(\r?\n))/i, /^(?:(\r?\n))/i, /^(?:[\n\r]+)/i, /^(?:%%[^\n]*)/i, /^(?:title\b)/i, /^(?:accTitle\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*\{\s*)/i, /^(?:\{)/i, /^(?:[^\}]*)/i, /^(?:xychart-beta\b)/i, /^(?:(?:vertical|horizontal))/i, /^(?:x-axis\b)/i, /^(?:y-axis\b)/i, /^(?:\[)/i, /^(?:-->)/i, /^(?:line\b)/i, /^(?:bar\b)/i, /^(?:\[)/i, /^(?:[+-]?(?:\d+(?:\.\d+)?|\.\d+))/i, /^(?:\])/i, /^(?:(?:`\) \{ this\.pushState\(md_string\); \}\n\(\?:\(\?!`"\)\.\)\+ \{ return MD_STR; \}\n\(\?:`))/i, /^(?:["])/i, /^(?:["])/i, /^(?:[^"]*)/i, /^(?:\[)/i, /^(?:\])/i, /^(?:[A-Za-z]+)/i, /^(?::)/i, /^(?:\+)/i, /^(?:,)/i, /^(?:=)/i, /^(?:\*)/i, /^(?:#)/i, /^(?:[\_])/i, /^(?:\.)/i, /^(?:&)/i, /^(?:-)/i, /^(?:[0-9]+)/i, /^(?:\s+)/i, /^(?:;)/i, /^(?:$)/i], + conditions: { "data_inner": { "rules": [0, 1, 4, 5, 6, 7, 9, 11, 14, 15, 16, 17, 20, 21, 23, 24, 25, 26, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45], "inclusive": true }, "data": { "rules": [0, 1, 3, 4, 5, 6, 7, 9, 11, 14, 15, 16, 17, 20, 21, 22, 25, 26, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45], "inclusive": true }, "axis_band_data": { "rules": [0, 1, 4, 5, 6, 7, 9, 11, 14, 15, 16, 17, 20, 21, 24, 25, 26, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45], "inclusive": true }, "axis_data": { "rules": [0, 1, 2, 4, 5, 6, 7, 9, 11, 14, 15, 16, 17, 18, 19, 20, 21, 23, 25, 26, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45], "inclusive": true }, "acc_descr_multiline": { "rules": [12, 13], "inclusive": false }, "acc_descr": { "rules": [10], "inclusive": false }, "acc_title": { "rules": [8], "inclusive": false }, "title": { "rules": [], "inclusive": false }, "md_string": { "rules": [], "inclusive": false }, "string": { "rules": [27, 28], "inclusive": false }, "INITIAL": { "rules": [0, 1, 4, 5, 6, 7, 9, 11, 14, 15, 16, 17, 20, 21, 25, 26, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser2() { + this.yy = {}; + } + Parser2.prototype = parser2; + parser2.Parser = Parser2; + return new Parser2(); + }(); + parser$i.parser = parser$i; + const parser$j = parser$i; + function isBarPlot(data) { + return data.type === "bar"; + } + function isBandAxisData(data) { + return data.type === "band"; + } + function isLinearAxisData(data) { + return data.type === "linear"; + } + class TextDimensionCalculatorWithFont { + constructor(parentGroup) { + this.parentGroup = parentGroup; + } + getMaxDimension(texts, fontSize) { + if (!this.parentGroup) { + return { + width: texts.reduce((acc, cur) => Math.max(cur.length, acc), 0) * fontSize, + height: fontSize + }; + } + const dimension = { + width: 0, + height: 0 + }; + const elem = this.parentGroup.append("g").attr("visibility", "hidden").attr("font-size", fontSize); + for (const t of texts) { + const bbox = computeDimensionOfText(elem, 1, t); + const width2 = bbox ? bbox.width : t.length * fontSize; + const height = bbox ? bbox.height : fontSize; + dimension.width = Math.max(dimension.width, width2); + dimension.height = Math.max(dimension.height, height); + } + elem.remove(); + return dimension; + } + } + const BAR_WIDTH_TO_TICK_WIDTH_RATIO = 0.7; + const MAX_OUTER_PADDING_PERCENT_FOR_WRT_LABEL = 0.2; + class BaseAxis { + constructor(axisConfig, title2, textDimensionCalculator, axisThemeConfig) { + this.axisConfig = axisConfig; + this.title = title2; + this.textDimensionCalculator = textDimensionCalculator; + this.axisThemeConfig = axisThemeConfig; + this.boundingRect = { x: 0, y: 0, width: 0, height: 0 }; + this.axisPosition = "left"; + this.showTitle = false; + this.showLabel = false; + this.showTick = false; + this.showAxisLine = false; + this.outerPadding = 0; + this.titleTextHeight = 0; + this.labelTextHeight = 0; + this.range = [0, 10]; + this.boundingRect = { x: 0, y: 0, width: 0, height: 0 }; + this.axisPosition = "left"; + } + setRange(range2) { + this.range = range2; + if (this.axisPosition === "left" || this.axisPosition === "right") { + this.boundingRect.height = range2[1] - range2[0]; + } else { + this.boundingRect.width = range2[1] - range2[0]; + } + this.recalculateScale(); + } + getRange() { + return [this.range[0] + this.outerPadding, this.range[1] - this.outerPadding]; + } + setAxisPosition(axisPosition) { + this.axisPosition = axisPosition; + this.setRange(this.range); + } + getTickDistance() { + const range2 = this.getRange(); + return Math.abs(range2[0] - range2[1]) / this.getTickValues().length; + } + getAxisOuterPadding() { + return this.outerPadding; + } + getLabelDimension() { + return this.textDimensionCalculator.getMaxDimension( + this.getTickValues().map((tick) => tick.toString()), + this.axisConfig.labelFontSize + ); + } + recalculateOuterPaddingToDrawBar() { + if (BAR_WIDTH_TO_TICK_WIDTH_RATIO * this.getTickDistance() > this.outerPadding * 2) { + this.outerPadding = Math.floor(BAR_WIDTH_TO_TICK_WIDTH_RATIO * this.getTickDistance() / 2); + } + this.recalculateScale(); + } + calculateSpaceIfDrawnHorizontally(availableSpace) { + let availableHeight = availableSpace.height; + if (this.axisConfig.showAxisLine && availableHeight > this.axisConfig.axisLineWidth) { + availableHeight -= this.axisConfig.axisLineWidth; + this.showAxisLine = true; + } + if (this.axisConfig.showLabel) { + const spaceRequired = this.getLabelDimension(); + const maxPadding = MAX_OUTER_PADDING_PERCENT_FOR_WRT_LABEL * availableSpace.width; + this.outerPadding = Math.min(spaceRequired.width / 2, maxPadding); + const heightRequired = spaceRequired.height + this.axisConfig.labelPadding * 2; + this.labelTextHeight = spaceRequired.height; + if (heightRequired <= availableHeight) { + availableHeight -= heightRequired; + this.showLabel = true; + } + } + if (this.axisConfig.showTick && availableHeight >= this.axisConfig.tickLength) { + this.showTick = true; + availableHeight -= this.axisConfig.tickLength; + } + if (this.axisConfig.showTitle && this.title) { + const spaceRequired = this.textDimensionCalculator.getMaxDimension( + [this.title], + this.axisConfig.titleFontSize + ); + const heightRequired = spaceRequired.height + this.axisConfig.titlePadding * 2; + this.titleTextHeight = spaceRequired.height; + if (heightRequired <= availableHeight) { + availableHeight -= heightRequired; + this.showTitle = true; + } + } + this.boundingRect.width = availableSpace.width; + this.boundingRect.height = availableSpace.height - availableHeight; + } + calculateSpaceIfDrawnVertical(availableSpace) { + let availableWidth = availableSpace.width; + if (this.axisConfig.showAxisLine && availableWidth > this.axisConfig.axisLineWidth) { + availableWidth -= this.axisConfig.axisLineWidth; + this.showAxisLine = true; + } + if (this.axisConfig.showLabel) { + const spaceRequired = this.getLabelDimension(); + const maxPadding = MAX_OUTER_PADDING_PERCENT_FOR_WRT_LABEL * availableSpace.height; + this.outerPadding = Math.min(spaceRequired.height / 2, maxPadding); + const widthRequired = spaceRequired.width + this.axisConfig.labelPadding * 2; + if (widthRequired <= availableWidth) { + availableWidth -= widthRequired; + this.showLabel = true; + } + } + if (this.axisConfig.showTick && availableWidth >= this.axisConfig.tickLength) { + this.showTick = true; + availableWidth -= this.axisConfig.tickLength; + } + if (this.axisConfig.showTitle && this.title) { + const spaceRequired = this.textDimensionCalculator.getMaxDimension( + [this.title], + this.axisConfig.titleFontSize + ); + const widthRequired = spaceRequired.height + this.axisConfig.titlePadding * 2; + this.titleTextHeight = spaceRequired.height; + if (widthRequired <= availableWidth) { + availableWidth -= widthRequired; + this.showTitle = true; + } + } + this.boundingRect.width = availableSpace.width - availableWidth; + this.boundingRect.height = availableSpace.height; + } + calculateSpace(availableSpace) { + if (this.axisPosition === "left" || this.axisPosition === "right") { + this.calculateSpaceIfDrawnVertical(availableSpace); + } else { + this.calculateSpaceIfDrawnHorizontally(availableSpace); + } + this.recalculateScale(); + return { + width: this.boundingRect.width, + height: this.boundingRect.height + }; + } + setBoundingBoxXY(point2) { + this.boundingRect.x = point2.x; + this.boundingRect.y = point2.y; + } + getDrawableElementsForLeftAxis() { + const drawableElement = []; + if (this.showAxisLine) { + const x2 = this.boundingRect.x + this.boundingRect.width - this.axisConfig.axisLineWidth / 2; + drawableElement.push({ + type: "path", + groupTexts: ["left-axis", "axisl-line"], + data: [ + { + path: `M ${x2},${this.boundingRect.y} L ${x2},${this.boundingRect.y + this.boundingRect.height} `, + strokeFill: this.axisThemeConfig.axisLineColor, + strokeWidth: this.axisConfig.axisLineWidth + } + ] + }); + } + if (this.showLabel) { + drawableElement.push({ + type: "text", + groupTexts: ["left-axis", "label"], + data: this.getTickValues().map((tick) => ({ + text: tick.toString(), + x: this.boundingRect.x + this.boundingRect.width - (this.showLabel ? this.axisConfig.labelPadding : 0) - (this.showTick ? this.axisConfig.tickLength : 0) - (this.showAxisLine ? this.axisConfig.axisLineWidth : 0), + y: this.getScaleValue(tick), + fill: this.axisThemeConfig.labelColor, + fontSize: this.axisConfig.labelFontSize, + rotation: 0, + verticalPos: "middle", + horizontalPos: "right" + })) + }); + } + if (this.showTick) { + const x2 = this.boundingRect.x + this.boundingRect.width - (this.showAxisLine ? this.axisConfig.axisLineWidth : 0); + drawableElement.push({ + type: "path", + groupTexts: ["left-axis", "ticks"], + data: this.getTickValues().map((tick) => ({ + path: `M ${x2},${this.getScaleValue(tick)} L ${x2 - this.axisConfig.tickLength},${this.getScaleValue(tick)}`, + strokeFill: this.axisThemeConfig.tickColor, + strokeWidth: this.axisConfig.tickWidth + })) + }); + } + if (this.showTitle) { + drawableElement.push({ + type: "text", + groupTexts: ["left-axis", "title"], + data: [ + { + text: this.title, + x: this.boundingRect.x + this.axisConfig.titlePadding, + y: this.boundingRect.y + this.boundingRect.height / 2, + fill: this.axisThemeConfig.titleColor, + fontSize: this.axisConfig.titleFontSize, + rotation: 270, + verticalPos: "top", + horizontalPos: "center" + } + ] + }); + } + return drawableElement; + } + getDrawableElementsForBottomAxis() { + const drawableElement = []; + if (this.showAxisLine) { + const y2 = this.boundingRect.y + this.axisConfig.axisLineWidth / 2; + drawableElement.push({ + type: "path", + groupTexts: ["bottom-axis", "axis-line"], + data: [ + { + path: `M ${this.boundingRect.x},${y2} L ${this.boundingRect.x + this.boundingRect.width},${y2}`, + strokeFill: this.axisThemeConfig.axisLineColor, + strokeWidth: this.axisConfig.axisLineWidth + } + ] + }); + } + if (this.showLabel) { + drawableElement.push({ + type: "text", + groupTexts: ["bottom-axis", "label"], + data: this.getTickValues().map((tick) => ({ + text: tick.toString(), + x: this.getScaleValue(tick), + y: this.boundingRect.y + this.axisConfig.labelPadding + (this.showTick ? this.axisConfig.tickLength : 0) + (this.showAxisLine ? this.axisConfig.axisLineWidth : 0), + fill: this.axisThemeConfig.labelColor, + fontSize: this.axisConfig.labelFontSize, + rotation: 0, + verticalPos: "top", + horizontalPos: "center" + })) + }); + } + if (this.showTick) { + const y2 = this.boundingRect.y + (this.showAxisLine ? this.axisConfig.axisLineWidth : 0); + drawableElement.push({ + type: "path", + groupTexts: ["bottom-axis", "ticks"], + data: this.getTickValues().map((tick) => ({ + path: `M ${this.getScaleValue(tick)},${y2} L ${this.getScaleValue(tick)},${y2 + this.axisConfig.tickLength}`, + strokeFill: this.axisThemeConfig.tickColor, + strokeWidth: this.axisConfig.tickWidth + })) + }); + } + if (this.showTitle) { + drawableElement.push({ + type: "text", + groupTexts: ["bottom-axis", "title"], + data: [ + { + text: this.title, + x: this.range[0] + (this.range[1] - this.range[0]) / 2, + y: this.boundingRect.y + this.boundingRect.height - this.axisConfig.titlePadding - this.titleTextHeight, + fill: this.axisThemeConfig.titleColor, + fontSize: this.axisConfig.titleFontSize, + rotation: 0, + verticalPos: "top", + horizontalPos: "center" + } + ] + }); + } + return drawableElement; + } + getDrawableElementsForTopAxis() { + const drawableElement = []; + if (this.showAxisLine) { + const y2 = this.boundingRect.y + this.boundingRect.height - this.axisConfig.axisLineWidth / 2; + drawableElement.push({ + type: "path", + groupTexts: ["top-axis", "axis-line"], + data: [ + { + path: `M ${this.boundingRect.x},${y2} L ${this.boundingRect.x + this.boundingRect.width},${y2}`, + strokeFill: this.axisThemeConfig.axisLineColor, + strokeWidth: this.axisConfig.axisLineWidth + } + ] + }); + } + if (this.showLabel) { + drawableElement.push({ + type: "text", + groupTexts: ["top-axis", "label"], + data: this.getTickValues().map((tick) => ({ + text: tick.toString(), + x: this.getScaleValue(tick), + y: this.boundingRect.y + (this.showTitle ? this.titleTextHeight + this.axisConfig.titlePadding * 2 : 0) + this.axisConfig.labelPadding, + fill: this.axisThemeConfig.labelColor, + fontSize: this.axisConfig.labelFontSize, + rotation: 0, + verticalPos: "top", + horizontalPos: "center" + })) + }); + } + if (this.showTick) { + const y2 = this.boundingRect.y; + drawableElement.push({ + type: "path", + groupTexts: ["top-axis", "ticks"], + data: this.getTickValues().map((tick) => ({ + path: `M ${this.getScaleValue(tick)},${y2 + this.boundingRect.height - (this.showAxisLine ? this.axisConfig.axisLineWidth : 0)} L ${this.getScaleValue(tick)},${y2 + this.boundingRect.height - this.axisConfig.tickLength - (this.showAxisLine ? this.axisConfig.axisLineWidth : 0)}`, + strokeFill: this.axisThemeConfig.tickColor, + strokeWidth: this.axisConfig.tickWidth + })) + }); + } + if (this.showTitle) { + drawableElement.push({ + type: "text", + groupTexts: ["top-axis", "title"], + data: [ + { + text: this.title, + x: this.boundingRect.x + this.boundingRect.width / 2, + y: this.boundingRect.y + this.axisConfig.titlePadding, + fill: this.axisThemeConfig.titleColor, + fontSize: this.axisConfig.titleFontSize, + rotation: 0, + verticalPos: "top", + horizontalPos: "center" + } + ] + }); + } + return drawableElement; + } + getDrawableElements() { + if (this.axisPosition === "left") { + return this.getDrawableElementsForLeftAxis(); + } + if (this.axisPosition === "right") { + throw Error("Drawing of right axis is not implemented"); + } + if (this.axisPosition === "bottom") { + return this.getDrawableElementsForBottomAxis(); + } + if (this.axisPosition === "top") { + return this.getDrawableElementsForTopAxis(); + } + return []; + } + } + class BandAxis extends BaseAxis { + constructor(axisConfig, axisThemeConfig, categories, title2, textDimensionCalculator) { + super(axisConfig, title2, textDimensionCalculator, axisThemeConfig); + this.categories = categories; + this.scale = band().domain(this.categories).range(this.getRange()); + } + setRange(range2) { + super.setRange(range2); + } + recalculateScale() { + this.scale = band().domain(this.categories).range(this.getRange()).paddingInner(1).paddingOuter(0).align(0.5); + log$1.trace("BandAxis axis final categories, range: ", this.categories, this.getRange()); + } + getTickValues() { + return this.categories; + } + getScaleValue(value2) { + return this.scale(value2) || this.getRange()[0]; + } + } + class LinearAxis extends BaseAxis { + constructor(axisConfig, axisThemeConfig, domain, title2, textDimensionCalculator) { + super(axisConfig, title2, textDimensionCalculator, axisThemeConfig); + this.domain = domain; + this.scale = linear().domain(this.domain).range(this.getRange()); + } + getTickValues() { + return this.scale.ticks(); + } + recalculateScale() { + const domain = [...this.domain]; + if (this.axisPosition === "left") { + domain.reverse(); + } + this.scale = linear().domain(domain).range(this.getRange()); + } + getScaleValue(value2) { + return this.scale(value2); + } + } + function getAxis(data, axisConfig, axisThemeConfig, tmpSVGGroup2) { + const textDimensionCalculator = new TextDimensionCalculatorWithFont(tmpSVGGroup2); + if (isBandAxisData(data)) { + return new BandAxis( + axisConfig, + axisThemeConfig, + data.categories, + data.title, + textDimensionCalculator + ); + } + return new LinearAxis( + axisConfig, + axisThemeConfig, + [data.min, data.max], + data.title, + textDimensionCalculator + ); + } + class ChartTitle { + constructor(textDimensionCalculator, chartConfig, chartData, chartThemeConfig) { + this.textDimensionCalculator = textDimensionCalculator; + this.chartConfig = chartConfig; + this.chartData = chartData; + this.chartThemeConfig = chartThemeConfig; + this.boundingRect = { + x: 0, + y: 0, + width: 0, + height: 0 + }; + this.showChartTitle = false; + } + setBoundingBoxXY(point2) { + this.boundingRect.x = point2.x; + this.boundingRect.y = point2.y; + } + calculateSpace(availableSpace) { + const titleDimension = this.textDimensionCalculator.getMaxDimension( + [this.chartData.title], + this.chartConfig.titleFontSize + ); + const widthRequired = Math.max(titleDimension.width, availableSpace.width); + const heightRequired = titleDimension.height + 2 * this.chartConfig.titlePadding; + if (titleDimension.width <= widthRequired && titleDimension.height <= heightRequired && this.chartConfig.showTitle && this.chartData.title) { + this.boundingRect.width = widthRequired; + this.boundingRect.height = heightRequired; + this.showChartTitle = true; + } + return { + width: this.boundingRect.width, + height: this.boundingRect.height + }; + } + getDrawableElements() { + const drawableElem = []; + if (this.showChartTitle) { + drawableElem.push({ + groupTexts: ["chart-title"], + type: "text", + data: [ + { + fontSize: this.chartConfig.titleFontSize, + text: this.chartData.title, + verticalPos: "middle", + horizontalPos: "center", + x: this.boundingRect.x + this.boundingRect.width / 2, + y: this.boundingRect.y + this.boundingRect.height / 2, + fill: this.chartThemeConfig.titleColor, + rotation: 0 + } + ] + }); + } + return drawableElem; + } + } + function getChartTitleComponent(chartConfig, chartData, chartThemeConfig, tmpSVGGroup2) { + const textDimensionCalculator = new TextDimensionCalculatorWithFont(tmpSVGGroup2); + return new ChartTitle(textDimensionCalculator, chartConfig, chartData, chartThemeConfig); + } + class LinePlot { + constructor(plotData, xAxis, yAxis, orientation, plotIndex2) { + this.plotData = plotData; + this.xAxis = xAxis; + this.yAxis = yAxis; + this.orientation = orientation; + this.plotIndex = plotIndex2; + } + getDrawableElement() { + const finalData = this.plotData.data.map((d) => [ + this.xAxis.getScaleValue(d[0]), + this.yAxis.getScaleValue(d[1]) + ]); + let path2; + if (this.orientation === "horizontal") { + path2 = line$1().y((d) => d[0]).x((d) => d[1])(finalData); + } else { + path2 = line$1().x((d) => d[0]).y((d) => d[1])(finalData); + } + if (!path2) { + return []; + } + return [ + { + groupTexts: ["plot", `line-plot-${this.plotIndex}`], + type: "path", + data: [ + { + path: path2, + strokeFill: this.plotData.strokeFill, + strokeWidth: this.plotData.strokeWidth + } + ] + } + ]; + } + } + class BarPlot { + constructor(barData, boundingRect, xAxis, yAxis, orientation, plotIndex2) { + this.barData = barData; + this.boundingRect = boundingRect; + this.xAxis = xAxis; + this.yAxis = yAxis; + this.orientation = orientation; + this.plotIndex = plotIndex2; + } + getDrawableElement() { + const finalData = this.barData.data.map((d) => [ + this.xAxis.getScaleValue(d[0]), + this.yAxis.getScaleValue(d[1]) + ]); + const barPaddingPercent = 0.05; + const barWidth = Math.min(this.xAxis.getAxisOuterPadding() * 2, this.xAxis.getTickDistance()) * (1 - barPaddingPercent); + const barWidthHalf = barWidth / 2; + if (this.orientation === "horizontal") { + return [ + { + groupTexts: ["plot", `bar-plot-${this.plotIndex}`], + type: "rect", + data: finalData.map((data) => ({ + x: this.boundingRect.x, + y: data[0] - barWidthHalf, + height: barWidth, + width: data[1] - this.boundingRect.x, + fill: this.barData.fill, + strokeWidth: 0, + strokeFill: this.barData.fill + })) + } + ]; + } + return [ + { + groupTexts: ["plot", `bar-plot-${this.plotIndex}`], + type: "rect", + data: finalData.map((data) => ({ + x: data[0] - barWidthHalf, + y: data[1], + width: barWidth, + height: this.boundingRect.y + this.boundingRect.height - data[1], + fill: this.barData.fill, + strokeWidth: 0, + strokeFill: this.barData.fill + })) + } + ]; + } + } + class BasePlot { + constructor(chartConfig, chartData, chartThemeConfig) { + this.chartConfig = chartConfig; + this.chartData = chartData; + this.chartThemeConfig = chartThemeConfig; + this.boundingRect = { + x: 0, + y: 0, + width: 0, + height: 0 + }; + } + setAxes(xAxis, yAxis) { + this.xAxis = xAxis; + this.yAxis = yAxis; + } + setBoundingBoxXY(point2) { + this.boundingRect.x = point2.x; + this.boundingRect.y = point2.y; + } + calculateSpace(availableSpace) { + this.boundingRect.width = availableSpace.width; + this.boundingRect.height = availableSpace.height; + return { + width: this.boundingRect.width, + height: this.boundingRect.height + }; + } + getDrawableElements() { + if (!(this.xAxis && this.yAxis)) { + throw Error("Axes must be passed to render Plots"); + } + const drawableElem = []; + for (const [i2, plot] of this.chartData.plots.entries()) { + switch (plot.type) { + case "line": + { + const linePlot = new LinePlot( + plot, + this.xAxis, + this.yAxis, + this.chartConfig.chartOrientation, + i2 + ); + drawableElem.push(...linePlot.getDrawableElement()); + } + break; + case "bar": + { + const barPlot = new BarPlot( + plot, + this.boundingRect, + this.xAxis, + this.yAxis, + this.chartConfig.chartOrientation, + i2 + ); + drawableElem.push(...barPlot.getDrawableElement()); + } + break; + } + } + return drawableElem; + } + } + function getPlotComponent(chartConfig, chartData, chartThemeConfig) { + return new BasePlot(chartConfig, chartData, chartThemeConfig); + } + class Orchestrator { + constructor(chartConfig, chartData, chartThemeConfig, tmpSVGGroup2) { + this.chartConfig = chartConfig; + this.chartData = chartData; + this.componentStore = { + title: getChartTitleComponent(chartConfig, chartData, chartThemeConfig, tmpSVGGroup2), + plot: getPlotComponent(chartConfig, chartData, chartThemeConfig), + xAxis: getAxis( + chartData.xAxis, + chartConfig.xAxis, + { + titleColor: chartThemeConfig.xAxisTitleColor, + labelColor: chartThemeConfig.xAxisLabelColor, + tickColor: chartThemeConfig.xAxisTickColor, + axisLineColor: chartThemeConfig.xAxisLineColor + }, + tmpSVGGroup2 + ), + yAxis: getAxis( + chartData.yAxis, + chartConfig.yAxis, + { + titleColor: chartThemeConfig.yAxisTitleColor, + labelColor: chartThemeConfig.yAxisLabelColor, + tickColor: chartThemeConfig.yAxisTickColor, + axisLineColor: chartThemeConfig.yAxisLineColor + }, + tmpSVGGroup2 + ) + }; + } + calculateVerticalSpace() { + let availableWidth = this.chartConfig.width; + let availableHeight = this.chartConfig.height; + let plotX = 0; + let plotY = 0; + let chartWidth = Math.floor(availableWidth * this.chartConfig.plotReservedSpacePercent / 100); + let chartHeight = Math.floor( + availableHeight * this.chartConfig.plotReservedSpacePercent / 100 + ); + let spaceUsed = this.componentStore.plot.calculateSpace({ + width: chartWidth, + height: chartHeight + }); + availableWidth -= spaceUsed.width; + availableHeight -= spaceUsed.height; + spaceUsed = this.componentStore.title.calculateSpace({ + width: this.chartConfig.width, + height: availableHeight + }); + plotY = spaceUsed.height; + availableHeight -= spaceUsed.height; + this.componentStore.xAxis.setAxisPosition("bottom"); + spaceUsed = this.componentStore.xAxis.calculateSpace({ + width: availableWidth, + height: availableHeight + }); + availableHeight -= spaceUsed.height; + this.componentStore.yAxis.setAxisPosition("left"); + spaceUsed = this.componentStore.yAxis.calculateSpace({ + width: availableWidth, + height: availableHeight + }); + plotX = spaceUsed.width; + availableWidth -= spaceUsed.width; + if (availableWidth > 0) { + chartWidth += availableWidth; + availableWidth = 0; + } + if (availableHeight > 0) { + chartHeight += availableHeight; + availableHeight = 0; + } + this.componentStore.plot.calculateSpace({ + width: chartWidth, + height: chartHeight + }); + this.componentStore.plot.setBoundingBoxXY({ x: plotX, y: plotY }); + this.componentStore.xAxis.setRange([plotX, plotX + chartWidth]); + this.componentStore.xAxis.setBoundingBoxXY({ x: plotX, y: plotY + chartHeight }); + this.componentStore.yAxis.setRange([plotY, plotY + chartHeight]); + this.componentStore.yAxis.setBoundingBoxXY({ x: 0, y: plotY }); + if (this.chartData.plots.some((p) => isBarPlot(p))) { + this.componentStore.xAxis.recalculateOuterPaddingToDrawBar(); + } + } + calculateHorizontalSpace() { + let availableWidth = this.chartConfig.width; + let availableHeight = this.chartConfig.height; + let titleYEnd = 0; + let plotX = 0; + let plotY = 0; + let chartWidth = Math.floor(availableWidth * this.chartConfig.plotReservedSpacePercent / 100); + let chartHeight = Math.floor( + availableHeight * this.chartConfig.plotReservedSpacePercent / 100 + ); + let spaceUsed = this.componentStore.plot.calculateSpace({ + width: chartWidth, + height: chartHeight + }); + availableWidth -= spaceUsed.width; + availableHeight -= spaceUsed.height; + spaceUsed = this.componentStore.title.calculateSpace({ + width: this.chartConfig.width, + height: availableHeight + }); + titleYEnd = spaceUsed.height; + availableHeight -= spaceUsed.height; + this.componentStore.xAxis.setAxisPosition("left"); + spaceUsed = this.componentStore.xAxis.calculateSpace({ + width: availableWidth, + height: availableHeight + }); + availableWidth -= spaceUsed.width; + plotX = spaceUsed.width; + this.componentStore.yAxis.setAxisPosition("top"); + spaceUsed = this.componentStore.yAxis.calculateSpace({ + width: availableWidth, + height: availableHeight + }); + availableHeight -= spaceUsed.height; + plotY = titleYEnd + spaceUsed.height; + if (availableWidth > 0) { + chartWidth += availableWidth; + availableWidth = 0; + } + if (availableHeight > 0) { + chartHeight += availableHeight; + availableHeight = 0; + } + this.componentStore.plot.calculateSpace({ + width: chartWidth, + height: chartHeight + }); + this.componentStore.plot.setBoundingBoxXY({ x: plotX, y: plotY }); + this.componentStore.yAxis.setRange([plotX, plotX + chartWidth]); + this.componentStore.yAxis.setBoundingBoxXY({ x: plotX, y: titleYEnd }); + this.componentStore.xAxis.setRange([plotY, plotY + chartHeight]); + this.componentStore.xAxis.setBoundingBoxXY({ x: 0, y: plotY }); + if (this.chartData.plots.some((p) => isBarPlot(p))) { + this.componentStore.xAxis.recalculateOuterPaddingToDrawBar(); + } + } + calculateSpace() { + if (this.chartConfig.chartOrientation === "horizontal") { + this.calculateHorizontalSpace(); + } else { + this.calculateVerticalSpace(); + } + } + getDrawableElement() { + this.calculateSpace(); + const drawableElem = []; + this.componentStore.plot.setAxes(this.componentStore.xAxis, this.componentStore.yAxis); + for (const component of Object.values(this.componentStore)) { + drawableElem.push(...component.getDrawableElements()); + } + return drawableElem; + } + } + class XYChartBuilder { + static build(config2, chartData, chartThemeConfig, tmpSVGGroup2) { + const orchestrator = new Orchestrator(config2, chartData, chartThemeConfig, tmpSVGGroup2); + return orchestrator.getDrawableElement(); + } + } + let plotIndex = 0; + let tmpSVGGroup; + let xyChartConfig = getChartDefaultConfig(); + let xyChartThemeConfig = getChartDefaultThemeConfig(); + let xyChartData = getChartDefaultData(); + let plotColorPalette = xyChartThemeConfig.plotColorPalette.split(",").map((color2) => color2.trim()); + let hasSetXAxis = false; + let hasSetYAxis = false; + function getChartDefaultThemeConfig() { + const defaultThemeVariables2 = getThemeVariables$2(); + const config2 = getConfig$2(); + return cleanAndMerge(defaultThemeVariables2.xyChart, config2.themeVariables.xyChart); + } + function getChartDefaultConfig() { + const config2 = getConfig$2(); + return cleanAndMerge( + defaultConfig$2.xyChart, + config2.xyChart + ); + } + function getChartDefaultData() { + return { + yAxis: { + type: "linear", + title: "", + min: Infinity, + max: -Infinity + }, + xAxis: { + type: "band", + title: "", + categories: [] + }, + title: "", + plots: [] + }; + } + function textSanitizer(text2) { + const config2 = getConfig$2(); + return sanitizeText$6(text2.trim(), config2); + } + function setTmpSVGG(SVGG) { + tmpSVGGroup = SVGG; + } + function setOrientation(orientation) { + if (orientation === "horizontal") { + xyChartConfig.chartOrientation = "horizontal"; + } else { + xyChartConfig.chartOrientation = "vertical"; + } + } + function setXAxisTitle(title2) { + xyChartData.xAxis.title = textSanitizer(title2.text); + } + function setXAxisRangeData(min2, max2) { + xyChartData.xAxis = { type: "linear", title: xyChartData.xAxis.title, min: min2, max: max2 }; + hasSetXAxis = true; + } + function setXAxisBand(categories) { + xyChartData.xAxis = { + type: "band", + title: xyChartData.xAxis.title, + categories: categories.map((c2) => textSanitizer(c2.text)) + }; + hasSetXAxis = true; + } + function setYAxisTitle(title2) { + xyChartData.yAxis.title = textSanitizer(title2.text); + } + function setYAxisRangeData(min2, max2) { + xyChartData.yAxis = { type: "linear", title: xyChartData.yAxis.title, min: min2, max: max2 }; + hasSetYAxis = true; + } + function setYAxisRangeFromPlotData(data) { + const minValue = Math.min(...data); + const maxValue = Math.max(...data); + const prevMinValue = isLinearAxisData(xyChartData.yAxis) ? xyChartData.yAxis.min : Infinity; + const prevMaxValue = isLinearAxisData(xyChartData.yAxis) ? xyChartData.yAxis.max : -Infinity; + xyChartData.yAxis = { + type: "linear", + title: xyChartData.yAxis.title, + min: Math.min(prevMinValue, minValue), + max: Math.max(prevMaxValue, maxValue) + }; + } + function transformDataWithoutCategory(data) { + let retData = []; + if (data.length === 0) { + return retData; + } + if (!hasSetXAxis) { + const prevMinValue = isLinearAxisData(xyChartData.xAxis) ? xyChartData.xAxis.min : Infinity; + const prevMaxValue = isLinearAxisData(xyChartData.xAxis) ? xyChartData.xAxis.max : -Infinity; + setXAxisRangeData(Math.min(prevMinValue, 1), Math.max(prevMaxValue, data.length)); + } + if (!hasSetYAxis) { + setYAxisRangeFromPlotData(data); + } + if (isBandAxisData(xyChartData.xAxis)) { + retData = xyChartData.xAxis.categories.map((c2, i2) => [c2, data[i2]]); + } + if (isLinearAxisData(xyChartData.xAxis)) { + const min2 = xyChartData.xAxis.min; + const max2 = xyChartData.xAxis.max; + const step = (max2 - min2 + 1) / data.length; + const categories = []; + for (let i2 = min2; i2 <= max2; i2 += step) { + categories.push(`${i2}`); + } + retData = categories.map((c2, i2) => [c2, data[i2]]); + } + return retData; + } + function getPlotColorFromPalette(plotIndex2) { + return plotColorPalette[plotIndex2 === 0 ? 0 : plotIndex2 % plotColorPalette.length]; + } + function setLineData(title2, data) { + const plotData = transformDataWithoutCategory(data); + xyChartData.plots.push({ + type: "line", + strokeFill: getPlotColorFromPalette(plotIndex), + strokeWidth: 2, + data: plotData + }); + plotIndex++; + } + function setBarData(title2, data) { + const plotData = transformDataWithoutCategory(data); + xyChartData.plots.push({ + type: "bar", + fill: getPlotColorFromPalette(plotIndex), + data: plotData + }); + plotIndex++; + } + function getDrawableElem() { + if (xyChartData.plots.length === 0) { + throw Error("No Plot to render, please provide a plot with some data"); + } + xyChartData.title = getDiagramTitle(); + return XYChartBuilder.build(xyChartConfig, xyChartData, xyChartThemeConfig, tmpSVGGroup); + } + function getChartThemeConfig() { + return xyChartThemeConfig; + } + function getChartConfig() { + return xyChartConfig; + } + const clear$9 = function() { + clear$n(); + plotIndex = 0; + xyChartConfig = getChartDefaultConfig(); + xyChartData = getChartDefaultData(); + xyChartThemeConfig = getChartDefaultThemeConfig(); + plotColorPalette = xyChartThemeConfig.plotColorPalette.split(",").map((color2) => color2.trim()); + hasSetXAxis = false; + hasSetYAxis = false; + }; + const db$b = { + getDrawableElem, + clear: clear$9, + setAccTitle, + getAccTitle, + setDiagramTitle, + getDiagramTitle, + getAccDescription, + setAccDescription, + setOrientation, + setXAxisTitle, + setXAxisRangeData, + setXAxisBand, + setYAxisTitle, + setYAxisRangeData, + setLineData, + setBarData, + setTmpSVGG, + getChartThemeConfig, + getChartConfig + }; + const draw$c = (txt, id2, _version, diagObj) => { + const db2 = diagObj.db; + const themeConfig = db2.getChartThemeConfig(); + const chartConfig = db2.getChartConfig(); + function getDominantBaseLine(horizontalPos) { + return horizontalPos === "top" ? "text-before-edge" : "middle"; + } + function getTextAnchor(verticalPos) { + return verticalPos === "left" ? "start" : verticalPos === "right" ? "end" : "middle"; + } + function getTextTransformation(data) { + return `translate(${data.x}, ${data.y}) rotate(${data.rotation || 0})`; + } + log$1.debug("Rendering xychart chart\n" + txt); + const svg2 = selectSvgElement(id2); + const group = svg2.append("g").attr("class", "main"); + const background = group.append("rect").attr("width", chartConfig.width).attr("height", chartConfig.height).attr("class", "background"); + configureSvgSize(svg2, chartConfig.height, chartConfig.width, true); + svg2.attr("viewBox", `0 0 ${chartConfig.width} ${chartConfig.height}`); + background.attr("fill", themeConfig.backgroundColor); + db2.setTmpSVGG(svg2.append("g").attr("class", "mermaid-tmp-group")); + const shapes2 = db2.getDrawableElem(); + const groups = {}; + function getGroup(gList) { + let elem = group; + let prefix = ""; + for (const [i2] of gList.entries()) { + let parent = group; + if (i2 > 0 && groups[prefix]) { + parent = groups[prefix]; + } + prefix += gList[i2]; + elem = groups[prefix]; + if (!elem) { + elem = groups[prefix] = parent.append("g").attr("class", gList[i2]); + } + } + return elem; + } + for (const shape of shapes2) { + if (shape.data.length === 0) { + continue; + } + const shapeGroup = getGroup(shape.groupTexts); + switch (shape.type) { + case "rect": + shapeGroup.selectAll("rect").data(shape.data).enter().append("rect").attr("x", (data) => data.x).attr("y", (data) => data.y).attr("width", (data) => data.width).attr("height", (data) => data.height).attr("fill", (data) => data.fill).attr("stroke", (data) => data.strokeFill).attr("stroke-width", (data) => data.strokeWidth); + break; + case "text": + shapeGroup.selectAll("text").data(shape.data).enter().append("text").attr("x", 0).attr("y", 0).attr("fill", (data) => data.fill).attr("font-size", (data) => data.fontSize).attr("dominant-baseline", (data) => getDominantBaseLine(data.verticalPos)).attr("text-anchor", (data) => getTextAnchor(data.horizontalPos)).attr("transform", (data) => getTextTransformation(data)).text((data) => data.text); + break; + case "path": + shapeGroup.selectAll("path").data(shape.data).enter().append("path").attr("d", (data) => data.path).attr("fill", (data) => data.fill ? data.fill : "none").attr("stroke", (data) => data.strokeFill).attr("stroke-width", (data) => data.strokeWidth); + break; + } + } + }; + const renderer$c = { + draw: draw$c + }; + const diagram$c = { + parser: parser$j, + db: db$b, + renderer: renderer$c + }; + const xychartDiagram = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + diagram: diagram$c + }, Symbol.toStringTag, { value: "Module" })); + var parser$g = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 3], $V1 = [1, 4], $V2 = [1, 5], $V3 = [1, 6], $V4 = [5, 6, 8, 9, 11, 13, 31, 32, 33, 34, 35, 36, 44, 62, 63], $V5 = [1, 18], $V6 = [2, 7], $V7 = [1, 22], $V8 = [1, 23], $V9 = [1, 24], $Va = [1, 25], $Vb = [1, 26], $Vc = [1, 27], $Vd = [1, 20], $Ve = [1, 28], $Vf = [1, 29], $Vg = [62, 63], $Vh = [5, 8, 9, 11, 13, 31, 32, 33, 34, 35, 36, 44, 51, 53, 62, 63], $Vi = [1, 47], $Vj = [1, 48], $Vk = [1, 49], $Vl = [1, 50], $Vm = [1, 51], $Vn = [1, 52], $Vo = [1, 53], $Vp = [53, 54], $Vq = [1, 64], $Vr = [1, 60], $Vs = [1, 61], $Vt = [1, 62], $Vu = [1, 63], $Vv = [1, 65], $Vw = [1, 69], $Vx = [1, 70], $Vy = [1, 67], $Vz = [1, 68], $VA = [5, 8, 9, 11, 13, 31, 32, 33, 34, 35, 36, 44, 62, 63]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "directive": 4, "NEWLINE": 5, "RD": 6, "diagram": 7, "EOF": 8, "acc_title": 9, "acc_title_value": 10, "acc_descr": 11, "acc_descr_value": 12, "acc_descr_multiline_value": 13, "requirementDef": 14, "elementDef": 15, "relationshipDef": 16, "requirementType": 17, "requirementName": 18, "STRUCT_START": 19, "requirementBody": 20, "ID": 21, "COLONSEP": 22, "id": 23, "TEXT": 24, "text": 25, "RISK": 26, "riskLevel": 27, "VERIFYMTHD": 28, "verifyType": 29, "STRUCT_STOP": 30, "REQUIREMENT": 31, "FUNCTIONAL_REQUIREMENT": 32, "INTERFACE_REQUIREMENT": 33, "PERFORMANCE_REQUIREMENT": 34, "PHYSICAL_REQUIREMENT": 35, "DESIGN_CONSTRAINT": 36, "LOW_RISK": 37, "MED_RISK": 38, "HIGH_RISK": 39, "VERIFY_ANALYSIS": 40, "VERIFY_DEMONSTRATION": 41, "VERIFY_INSPECTION": 42, "VERIFY_TEST": 43, "ELEMENT": 44, "elementName": 45, "elementBody": 46, "TYPE": 47, "type": 48, "DOCREF": 49, "ref": 50, "END_ARROW_L": 51, "relationship": 52, "LINE": 53, "END_ARROW_R": 54, "CONTAINS": 55, "COPIES": 56, "DERIVES": 57, "SATISFIES": 58, "VERIFIES": 59, "REFINES": 60, "TRACES": 61, "unqString": 62, "qString": 63, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 5: "NEWLINE", 6: "RD", 8: "EOF", 9: "acc_title", 10: "acc_title_value", 11: "acc_descr", 12: "acc_descr_value", 13: "acc_descr_multiline_value", 19: "STRUCT_START", 21: "ID", 22: "COLONSEP", 24: "TEXT", 26: "RISK", 28: "VERIFYMTHD", 30: "STRUCT_STOP", 31: "REQUIREMENT", 32: "FUNCTIONAL_REQUIREMENT", 33: "INTERFACE_REQUIREMENT", 34: "PERFORMANCE_REQUIREMENT", 35: "PHYSICAL_REQUIREMENT", 36: "DESIGN_CONSTRAINT", 37: "LOW_RISK", 38: "MED_RISK", 39: "HIGH_RISK", 40: "VERIFY_ANALYSIS", 41: "VERIFY_DEMONSTRATION", 42: "VERIFY_INSPECTION", 43: "VERIFY_TEST", 44: "ELEMENT", 47: "TYPE", 49: "DOCREF", 51: "END_ARROW_L", 53: "LINE", 54: "END_ARROW_R", 55: "CONTAINS", 56: "COPIES", 57: "DERIVES", 58: "SATISFIES", 59: "VERIFIES", 60: "REFINES", 61: "TRACES", 62: "unqString", 63: "qString" }, + productions_: [0, [3, 3], [3, 2], [3, 4], [4, 2], [4, 2], [4, 1], [7, 0], [7, 2], [7, 2], [7, 2], [7, 2], [7, 2], [14, 5], [20, 5], [20, 5], [20, 5], [20, 5], [20, 2], [20, 1], [17, 1], [17, 1], [17, 1], [17, 1], [17, 1], [17, 1], [27, 1], [27, 1], [27, 1], [29, 1], [29, 1], [29, 1], [29, 1], [15, 5], [46, 5], [46, 5], [46, 2], [46, 1], [16, 5], [16, 5], [52, 1], [52, 1], [52, 1], [52, 1], [52, 1], [52, 1], [52, 1], [18, 1], [18, 1], [23, 1], [23, 1], [25, 1], [25, 1], [45, 1], [45, 1], [48, 1], [48, 1], [50, 1], [50, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 4: + this.$ = $$[$0].trim(); + yy.setAccTitle(this.$); + break; + case 5: + case 6: + this.$ = $$[$0].trim(); + yy.setAccDescription(this.$); + break; + case 7: + this.$ = []; + break; + case 13: + yy.addRequirement($$[$0 - 3], $$[$0 - 4]); + break; + case 14: + yy.setNewReqId($$[$0 - 2]); + break; + case 15: + yy.setNewReqText($$[$0 - 2]); + break; + case 16: + yy.setNewReqRisk($$[$0 - 2]); + break; + case 17: + yy.setNewReqVerifyMethod($$[$0 - 2]); + break; + case 20: + this.$ = yy.RequirementType.REQUIREMENT; + break; + case 21: + this.$ = yy.RequirementType.FUNCTIONAL_REQUIREMENT; + break; + case 22: + this.$ = yy.RequirementType.INTERFACE_REQUIREMENT; + break; + case 23: + this.$ = yy.RequirementType.PERFORMANCE_REQUIREMENT; + break; + case 24: + this.$ = yy.RequirementType.PHYSICAL_REQUIREMENT; + break; + case 25: + this.$ = yy.RequirementType.DESIGN_CONSTRAINT; + break; + case 26: + this.$ = yy.RiskLevel.LOW_RISK; + break; + case 27: + this.$ = yy.RiskLevel.MED_RISK; + break; + case 28: + this.$ = yy.RiskLevel.HIGH_RISK; + break; + case 29: + this.$ = yy.VerifyType.VERIFY_ANALYSIS; + break; + case 30: + this.$ = yy.VerifyType.VERIFY_DEMONSTRATION; + break; + case 31: + this.$ = yy.VerifyType.VERIFY_INSPECTION; + break; + case 32: + this.$ = yy.VerifyType.VERIFY_TEST; + break; + case 33: + yy.addElement($$[$0 - 3]); + break; + case 34: + yy.setNewElementType($$[$0 - 2]); + break; + case 35: + yy.setNewElementDocRef($$[$0 - 2]); + break; + case 38: + yy.addRelationship($$[$0 - 2], $$[$0], $$[$0 - 4]); + break; + case 39: + yy.addRelationship($$[$0 - 2], $$[$0 - 4], $$[$0]); + break; + case 40: + this.$ = yy.Relationships.CONTAINS; + break; + case 41: + this.$ = yy.Relationships.COPIES; + break; + case 42: + this.$ = yy.Relationships.DERIVES; + break; + case 43: + this.$ = yy.Relationships.SATISFIES; + break; + case 44: + this.$ = yy.Relationships.VERIFIES; + break; + case 45: + this.$ = yy.Relationships.REFINES; + break; + case 46: + this.$ = yy.Relationships.TRACES; + break; + } + }, + table: [{ 3: 1, 4: 2, 6: $V0, 9: $V1, 11: $V2, 13: $V3 }, { 1: [3] }, { 3: 8, 4: 2, 5: [1, 7], 6: $V0, 9: $V1, 11: $V2, 13: $V3 }, { 5: [1, 9] }, { 10: [1, 10] }, { 12: [1, 11] }, o($V4, [2, 6]), { 3: 12, 4: 2, 6: $V0, 9: $V1, 11: $V2, 13: $V3 }, { 1: [2, 2] }, { 4: 17, 5: $V5, 7: 13, 8: $V6, 9: $V1, 11: $V2, 13: $V3, 14: 14, 15: 15, 16: 16, 17: 19, 23: 21, 31: $V7, 32: $V8, 33: $V9, 34: $Va, 35: $Vb, 36: $Vc, 44: $Vd, 62: $Ve, 63: $Vf }, o($V4, [2, 4]), o($V4, [2, 5]), { 1: [2, 1] }, { 8: [1, 30] }, { 4: 17, 5: $V5, 7: 31, 8: $V6, 9: $V1, 11: $V2, 13: $V3, 14: 14, 15: 15, 16: 16, 17: 19, 23: 21, 31: $V7, 32: $V8, 33: $V9, 34: $Va, 35: $Vb, 36: $Vc, 44: $Vd, 62: $Ve, 63: $Vf }, { 4: 17, 5: $V5, 7: 32, 8: $V6, 9: $V1, 11: $V2, 13: $V3, 14: 14, 15: 15, 16: 16, 17: 19, 23: 21, 31: $V7, 32: $V8, 33: $V9, 34: $Va, 35: $Vb, 36: $Vc, 44: $Vd, 62: $Ve, 63: $Vf }, { 4: 17, 5: $V5, 7: 33, 8: $V6, 9: $V1, 11: $V2, 13: $V3, 14: 14, 15: 15, 16: 16, 17: 19, 23: 21, 31: $V7, 32: $V8, 33: $V9, 34: $Va, 35: $Vb, 36: $Vc, 44: $Vd, 62: $Ve, 63: $Vf }, { 4: 17, 5: $V5, 7: 34, 8: $V6, 9: $V1, 11: $V2, 13: $V3, 14: 14, 15: 15, 16: 16, 17: 19, 23: 21, 31: $V7, 32: $V8, 33: $V9, 34: $Va, 35: $Vb, 36: $Vc, 44: $Vd, 62: $Ve, 63: $Vf }, { 4: 17, 5: $V5, 7: 35, 8: $V6, 9: $V1, 11: $V2, 13: $V3, 14: 14, 15: 15, 16: 16, 17: 19, 23: 21, 31: $V7, 32: $V8, 33: $V9, 34: $Va, 35: $Vb, 36: $Vc, 44: $Vd, 62: $Ve, 63: $Vf }, { 18: 36, 62: [1, 37], 63: [1, 38] }, { 45: 39, 62: [1, 40], 63: [1, 41] }, { 51: [1, 42], 53: [1, 43] }, o($Vg, [2, 20]), o($Vg, [2, 21]), o($Vg, [2, 22]), o($Vg, [2, 23]), o($Vg, [2, 24]), o($Vg, [2, 25]), o($Vh, [2, 49]), o($Vh, [2, 50]), { 1: [2, 3] }, { 8: [2, 8] }, { 8: [2, 9] }, { 8: [2, 10] }, { 8: [2, 11] }, { 8: [2, 12] }, { 19: [1, 44] }, { 19: [2, 47] }, { 19: [2, 48] }, { 19: [1, 45] }, { 19: [2, 53] }, { 19: [2, 54] }, { 52: 46, 55: $Vi, 56: $Vj, 57: $Vk, 58: $Vl, 59: $Vm, 60: $Vn, 61: $Vo }, { 52: 54, 55: $Vi, 56: $Vj, 57: $Vk, 58: $Vl, 59: $Vm, 60: $Vn, 61: $Vo }, { 5: [1, 55] }, { 5: [1, 56] }, { 53: [1, 57] }, o($Vp, [2, 40]), o($Vp, [2, 41]), o($Vp, [2, 42]), o($Vp, [2, 43]), o($Vp, [2, 44]), o($Vp, [2, 45]), o($Vp, [2, 46]), { 54: [1, 58] }, { 5: $Vq, 20: 59, 21: $Vr, 24: $Vs, 26: $Vt, 28: $Vu, 30: $Vv }, { 5: $Vw, 30: $Vx, 46: 66, 47: $Vy, 49: $Vz }, { 23: 71, 62: $Ve, 63: $Vf }, { 23: 72, 62: $Ve, 63: $Vf }, o($VA, [2, 13]), { 22: [1, 73] }, { 22: [1, 74] }, { 22: [1, 75] }, { 22: [1, 76] }, { 5: $Vq, 20: 77, 21: $Vr, 24: $Vs, 26: $Vt, 28: $Vu, 30: $Vv }, o($VA, [2, 19]), o($VA, [2, 33]), { 22: [1, 78] }, { 22: [1, 79] }, { 5: $Vw, 30: $Vx, 46: 80, 47: $Vy, 49: $Vz }, o($VA, [2, 37]), o($VA, [2, 38]), o($VA, [2, 39]), { 23: 81, 62: $Ve, 63: $Vf }, { 25: 82, 62: [1, 83], 63: [1, 84] }, { 27: 85, 37: [1, 86], 38: [1, 87], 39: [1, 88] }, { 29: 89, 40: [1, 90], 41: [1, 91], 42: [1, 92], 43: [1, 93] }, o($VA, [2, 18]), { 48: 94, 62: [1, 95], 63: [1, 96] }, { 50: 97, 62: [1, 98], 63: [1, 99] }, o($VA, [2, 36]), { 5: [1, 100] }, { 5: [1, 101] }, { 5: [2, 51] }, { 5: [2, 52] }, { 5: [1, 102] }, { 5: [2, 26] }, { 5: [2, 27] }, { 5: [2, 28] }, { 5: [1, 103] }, { 5: [2, 29] }, { 5: [2, 30] }, { 5: [2, 31] }, { 5: [2, 32] }, { 5: [1, 104] }, { 5: [2, 55] }, { 5: [2, 56] }, { 5: [1, 105] }, { 5: [2, 57] }, { 5: [2, 58] }, { 5: $Vq, 20: 106, 21: $Vr, 24: $Vs, 26: $Vt, 28: $Vu, 30: $Vv }, { 5: $Vq, 20: 107, 21: $Vr, 24: $Vs, 26: $Vt, 28: $Vu, 30: $Vv }, { 5: $Vq, 20: 108, 21: $Vr, 24: $Vs, 26: $Vt, 28: $Vu, 30: $Vv }, { 5: $Vq, 20: 109, 21: $Vr, 24: $Vs, 26: $Vt, 28: $Vu, 30: $Vv }, { 5: $Vw, 30: $Vx, 46: 110, 47: $Vy, 49: $Vz }, { 5: $Vw, 30: $Vx, 46: 111, 47: $Vy, 49: $Vz }, o($VA, [2, 14]), o($VA, [2, 15]), o($VA, [2, 16]), o($VA, [2, 17]), o($VA, [2, 34]), o($VA, [2, 35])], + defaultActions: { 8: [2, 2], 12: [2, 1], 30: [2, 3], 31: [2, 8], 32: [2, 9], 33: [2, 10], 34: [2, 11], 35: [2, 12], 37: [2, 47], 38: [2, 48], 40: [2, 53], 41: [2, 54], 83: [2, 51], 84: [2, 52], 86: [2, 26], 87: [2, 27], 88: [2, 28], 90: [2, 29], 91: [2, 30], 92: [2, 31], 93: [2, 32], 95: [2, 55], 96: [2, 56], 98: [2, 57], 99: [2, 58] }, + parseError: function parseError(str2, hash) { + if (hash.recoverable) { + this.trace(str2); + } else { + var error = new Error(str2); + error.hash = hash; + throw error; + } + }, + parse: function parse2(input) { + var self2 = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex2() { + var token2; + token2 = tstack.pop() || lexer2.lex() || EOF; + if (typeof token2 !== "number") { + if (token2 instanceof Array) { + tstack = token2; + token2 = tstack.pop(); + } + token2 = self2.symbols_[token2] || token2; + } + return token2; + } + var symbol, state2, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state2 = stack[stack.length - 1]; + if (this.defaultActions[state2]) { + action = this.defaultActions[state2]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex2(); + } + action = table[state2] && table[state2][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state2]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state2 + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str2, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str2, hash); + } else { + throw new Error(str2); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch2 = this._input[0]; + this.yytext += ch2; + this.yyleng++; + this.offset++; + this.match += ch2; + this.matched += ch2; + var lines = ch2.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch2; + }, + // unshifts one char (or a string) into the input + unput: function(ch2) { + var len = ch2.length; + var lines = ch2.split(/(?:\r\n?|\n)/g); + this._input = ch2 + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next2 = this.match; + if (next2.length < 20) { + next2 += this._input.substr(0, 20 - next2.length); + } + return (next2.substr(0, 20) + (next2.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c2 = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c2 + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token2, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token2 = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token2) { + return token2; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token2, match, tempMatch, index2; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i2 = 0; i2 < rules.length; i2++) { + tempMatch = this._input.match(this.rules[rules[i2]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index2 = i2; + if (this.options.backtrack_lexer) { + token2 = this.test_match(tempMatch, rules[i2]); + if (token2 !== false) { + return token2; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token2 = this.test_match(match, rules[index2]); + if (token2 !== false) { + return token2; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex2() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + return "title"; + case 1: + this.begin("acc_title"); + return 9; + case 2: + this.popState(); + return "acc_title_value"; + case 3: + this.begin("acc_descr"); + return 11; + case 4: + this.popState(); + return "acc_descr_value"; + case 5: + this.begin("acc_descr_multiline"); + break; + case 6: + this.popState(); + break; + case 7: + return "acc_descr_multiline_value"; + case 8: + return 5; + case 9: + break; + case 10: + break; + case 11: + break; + case 12: + return 8; + case 13: + return 6; + case 14: + return 19; + case 15: + return 30; + case 16: + return 22; + case 17: + return 21; + case 18: + return 24; + case 19: + return 26; + case 20: + return 28; + case 21: + return 31; + case 22: + return 32; + case 23: + return 33; + case 24: + return 34; + case 25: + return 35; + case 26: + return 36; + case 27: + return 37; + case 28: + return 38; + case 29: + return 39; + case 30: + return 40; + case 31: + return 41; + case 32: + return 42; + case 33: + return 43; + case 34: + return 44; + case 35: + return 55; + case 36: + return 56; + case 37: + return 57; + case 38: + return 58; + case 39: + return 59; + case 40: + return 60; + case 41: + return 61; + case 42: + return 47; + case 43: + return 49; + case 44: + return 51; + case 45: + return 54; + case 46: + return 53; + case 47: + this.begin("string"); + break; + case 48: + this.popState(); + break; + case 49: + return "qString"; + case 50: + yy_.yytext = yy_.yytext.trim(); + return 62; + } + }, + rules: [/^(?:title\s[^#\n;]+)/i, /^(?:accTitle\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*\{\s*)/i, /^(?:[\}])/i, /^(?:[^\}]*)/i, /^(?:(\r?\n)+)/i, /^(?:\s+)/i, /^(?:#[^\n]*)/i, /^(?:%[^\n]*)/i, /^(?:$)/i, /^(?:requirementDiagram\b)/i, /^(?:\{)/i, /^(?:\})/i, /^(?::)/i, /^(?:id\b)/i, /^(?:text\b)/i, /^(?:risk\b)/i, /^(?:verifyMethod\b)/i, /^(?:requirement\b)/i, /^(?:functionalRequirement\b)/i, /^(?:interfaceRequirement\b)/i, /^(?:performanceRequirement\b)/i, /^(?:physicalRequirement\b)/i, /^(?:designConstraint\b)/i, /^(?:low\b)/i, /^(?:medium\b)/i, /^(?:high\b)/i, /^(?:analysis\b)/i, /^(?:demonstration\b)/i, /^(?:inspection\b)/i, /^(?:test\b)/i, /^(?:element\b)/i, /^(?:contains\b)/i, /^(?:copies\b)/i, /^(?:derives\b)/i, /^(?:satisfies\b)/i, /^(?:verifies\b)/i, /^(?:refines\b)/i, /^(?:traces\b)/i, /^(?:type\b)/i, /^(?:docref\b)/i, /^(?:<-)/i, /^(?:->)/i, /^(?:-)/i, /^(?:["])/i, /^(?:["])/i, /^(?:[^"]*)/i, /^(?:[\w][^\r\n\{\<\>\-\=]*)/i], + conditions: { "acc_descr_multiline": { "rules": [6, 7], "inclusive": false }, "acc_descr": { "rules": [4], "inclusive": false }, "acc_title": { "rules": [2], "inclusive": false }, "unqString": { "rules": [], "inclusive": false }, "token": { "rules": [], "inclusive": false }, "string": { "rules": [48, 49], "inclusive": false }, "INITIAL": { "rules": [0, 1, 3, 5, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 50], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser2() { + this.yy = {}; + } + Parser2.prototype = parser2; + parser2.Parser = Parser2; + return new Parser2(); + }(); + parser$g.parser = parser$g; + const parser$h = parser$g; + let relations$1 = []; + let latestRequirement = {}; + let requirements = {}; + let latestElement = {}; + let elements$1 = {}; + const RequirementType = { + REQUIREMENT: "Requirement", + FUNCTIONAL_REQUIREMENT: "Functional Requirement", + INTERFACE_REQUIREMENT: "Interface Requirement", + PERFORMANCE_REQUIREMENT: "Performance Requirement", + PHYSICAL_REQUIREMENT: "Physical Requirement", + DESIGN_CONSTRAINT: "Design Constraint" + }; + const RiskLevel = { + LOW_RISK: "Low", + MED_RISK: "Medium", + HIGH_RISK: "High" + }; + const VerifyType = { + VERIFY_ANALYSIS: "Analysis", + VERIFY_DEMONSTRATION: "Demonstration", + VERIFY_INSPECTION: "Inspection", + VERIFY_TEST: "Test" + }; + const Relationships = { + CONTAINS: "contains", + COPIES: "copies", + DERIVES: "derives", + SATISFIES: "satisfies", + VERIFIES: "verifies", + REFINES: "refines", + TRACES: "traces" + }; + const addRequirement = (name, type2) => { + if (requirements[name] === void 0) { + requirements[name] = { + name, + type: type2, + id: latestRequirement.id, + text: latestRequirement.text, + risk: latestRequirement.risk, + verifyMethod: latestRequirement.verifyMethod + }; + } + latestRequirement = {}; + return requirements[name]; + }; + const getRequirements = () => requirements; + const setNewReqId = (id2) => { + if (latestRequirement !== void 0) { + latestRequirement.id = id2; + } + }; + const setNewReqText = (text2) => { + if (latestRequirement !== void 0) { + latestRequirement.text = text2; + } + }; + const setNewReqRisk = (risk) => { + if (latestRequirement !== void 0) { + latestRequirement.risk = risk; + } + }; + const setNewReqVerifyMethod = (verifyMethod) => { + if (latestRequirement !== void 0) { + latestRequirement.verifyMethod = verifyMethod; + } + }; + const addElement = (name) => { + if (elements$1[name] === void 0) { + elements$1[name] = { + name, + type: latestElement.type, + docRef: latestElement.docRef + }; + log$1.info("Added new requirement: ", name); + } + latestElement = {}; + return elements$1[name]; + }; + const getElements = () => elements$1; + const setNewElementType = (type2) => { + if (latestElement !== void 0) { + latestElement.type = type2; + } + }; + const setNewElementDocRef = (docRef) => { + if (latestElement !== void 0) { + latestElement.docRef = docRef; + } + }; + const addRelationship = (type2, src, dst) => { + relations$1.push({ + type: type2, + src, + dst + }); + }; + const getRelationships = () => relations$1; + const clear$8 = () => { + relations$1 = []; + latestRequirement = {}; + requirements = {}; + latestElement = {}; + elements$1 = {}; + clear$n(); + }; + const db$a = { + RequirementType, + RiskLevel, + VerifyType, + Relationships, + getConfig: () => getConfig$1().req, + addRequirement, + getRequirements, + setNewReqId, + setNewReqText, + setNewReqRisk, + setNewReqVerifyMethod, + setAccTitle, + getAccTitle, + setAccDescription, + getAccDescription, + addElement, + getElements, + setNewElementType, + setNewElementDocRef, + addRelationship, + getRelationships, + clear: clear$8 + }; + const getStyles$8 = (options2) => ` + + marker { + fill: ${options2.relationColor}; + stroke: ${options2.relationColor}; + } + + marker.cross { + stroke: ${options2.lineColor}; + } + + svg { + font-family: ${options2.fontFamily}; + font-size: ${options2.fontSize}; + } + + .reqBox { + fill: ${options2.requirementBackground}; + fill-opacity: 1.0; + stroke: ${options2.requirementBorderColor}; + stroke-width: ${options2.requirementBorderSize}; + } + + .reqTitle, .reqLabel{ + fill: ${options2.requirementTextColor}; + } + .reqLabelBox { + fill: ${options2.relationLabelBackground}; + fill-opacity: 1.0; + } + + .req-title-line { + stroke: ${options2.requirementBorderColor}; + stroke-width: ${options2.requirementBorderSize}; + } + .relationshipLine { + stroke: ${options2.relationColor}; + stroke-width: 1; + } + .relationshipLabel { + fill: ${options2.relationLabelColor}; + } + +`; + const styles$7 = getStyles$8; + const ReqMarkers = { + CONTAINS: "contains", + ARROW: "arrow" + }; + const insertLineEndings = (parentNode, conf2) => { + let containsNode = parentNode.append("defs").append("marker").attr("id", ReqMarkers.CONTAINS + "_line_ending").attr("refX", 0).attr("refY", conf2.line_height / 2).attr("markerWidth", conf2.line_height).attr("markerHeight", conf2.line_height).attr("orient", "auto").append("g"); + containsNode.append("circle").attr("cx", conf2.line_height / 2).attr("cy", conf2.line_height / 2).attr("r", conf2.line_height / 2).attr("fill", "none"); + containsNode.append("line").attr("x1", 0).attr("x2", conf2.line_height).attr("y1", conf2.line_height / 2).attr("y2", conf2.line_height / 2).attr("stroke-width", 1); + containsNode.append("line").attr("y1", 0).attr("y2", conf2.line_height).attr("x1", conf2.line_height / 2).attr("x2", conf2.line_height / 2).attr("stroke-width", 1); + parentNode.append("defs").append("marker").attr("id", ReqMarkers.ARROW + "_line_ending").attr("refX", conf2.line_height).attr("refY", 0.5 * conf2.line_height).attr("markerWidth", conf2.line_height).attr("markerHeight", conf2.line_height).attr("orient", "auto").append("path").attr( + "d", + `M0,0 + L${conf2.line_height},${conf2.line_height / 2} + M${conf2.line_height},${conf2.line_height / 2} + L0,${conf2.line_height}` + ).attr("stroke-width", 1); + }; + const markers = { + ReqMarkers, + insertLineEndings + }; + let conf$5 = {}; + let relCnt = 0; + const newRectNode = (parentNode, id2) => { + return parentNode.insert("rect", "#" + id2).attr("class", "req reqBox").attr("x", 0).attr("y", 0).attr("width", conf$5.rect_min_width + "px").attr("height", conf$5.rect_min_height + "px"); + }; + const newTitleNode = (parentNode, id2, txts) => { + let x2 = conf$5.rect_min_width / 2; + let title2 = parentNode.append("text").attr("class", "req reqLabel reqTitle").attr("id", id2).attr("x", x2).attr("y", conf$5.rect_padding).attr("dominant-baseline", "hanging"); + let i2 = 0; + txts.forEach((textStr) => { + if (i2 == 0) { + title2.append("tspan").attr("text-anchor", "middle").attr("x", conf$5.rect_min_width / 2).attr("dy", 0).text(textStr); + } else { + title2.append("tspan").attr("text-anchor", "middle").attr("x", conf$5.rect_min_width / 2).attr("dy", conf$5.line_height * 0.75).text(textStr); + } + i2++; + }); + let yPadding = 1.5 * conf$5.rect_padding; + let linePadding = i2 * conf$5.line_height * 0.75; + let totalY = yPadding + linePadding; + parentNode.append("line").attr("class", "req-title-line").attr("x1", "0").attr("x2", conf$5.rect_min_width).attr("y1", totalY).attr("y2", totalY); + return { + titleNode: title2, + y: totalY + }; + }; + const newBodyNode = (parentNode, id2, txts, yStart) => { + let body = parentNode.append("text").attr("class", "req reqLabel").attr("id", id2).attr("x", conf$5.rect_padding).attr("y", yStart).attr("dominant-baseline", "hanging"); + let currentRow = 0; + const charLimit = 30; + let wrappedTxts = []; + txts.forEach((textStr) => { + let currentTextLen = textStr.length; + while (currentTextLen > charLimit && currentRow < 3) { + let firstPart = textStr.substring(0, charLimit); + textStr = textStr.substring(charLimit, textStr.length); + currentTextLen = textStr.length; + wrappedTxts[wrappedTxts.length] = firstPart; + currentRow++; + } + if (currentRow == 3) { + let lastStr = wrappedTxts[wrappedTxts.length - 1]; + wrappedTxts[wrappedTxts.length - 1] = lastStr.substring(0, lastStr.length - 4) + "..."; + } else { + wrappedTxts[wrappedTxts.length] = textStr; + } + currentRow = 0; + }); + wrappedTxts.forEach((textStr) => { + body.append("tspan").attr("x", conf$5.rect_padding).attr("dy", conf$5.line_height).text(textStr); + }); + return body; + }; + const addEdgeLabel = (parentNode, svgPath, conf2, txt) => { + const len = svgPath.node().getTotalLength(); + const labelPoint = svgPath.node().getPointAtLength(len * 0.5); + const labelId = "rel" + relCnt; + relCnt++; + const labelNode = parentNode.append("text").attr("class", "req relationshipLabel").attr("id", labelId).attr("x", labelPoint.x).attr("y", labelPoint.y).attr("text-anchor", "middle").attr("dominant-baseline", "middle").text(txt); + const labelBBox = labelNode.node().getBBox(); + parentNode.insert("rect", "#" + labelId).attr("class", "req reqLabelBox").attr("x", labelPoint.x - labelBBox.width / 2).attr("y", labelPoint.y - labelBBox.height / 2).attr("width", labelBBox.width).attr("height", labelBBox.height).attr("fill", "white").attr("fill-opacity", "85%"); + }; + const drawRelationshipFromLayout = function(svg2, rel2, g, insert, diagObj) { + const edge = g.edge(elementString(rel2.src), elementString(rel2.dst)); + const lineFunction = line$1().x(function(d) { + return d.x; + }).y(function(d) { + return d.y; + }); + const svgPath = svg2.insert("path", "#" + insert).attr("class", "er relationshipLine").attr("d", lineFunction(edge.points)).attr("fill", "none"); + if (rel2.type == diagObj.db.Relationships.CONTAINS) { + svgPath.attr( + "marker-start", + "url(" + common$1.getUrl(conf$5.arrowMarkerAbsolute) + "#" + rel2.type + "_line_ending)" + ); + } else { + svgPath.attr("stroke-dasharray", "10,7"); + svgPath.attr( + "marker-end", + "url(" + common$1.getUrl(conf$5.arrowMarkerAbsolute) + "#" + markers.ReqMarkers.ARROW + "_line_ending)" + ); + } + addEdgeLabel(svg2, svgPath, conf$5, `<<${rel2.type}>>`); + return; + }; + const drawReqs = (reqs, graph, svgNode2) => { + Object.keys(reqs).forEach((reqName) => { + let req = reqs[reqName]; + reqName = elementString(reqName); + log$1.info("Added new requirement: ", reqName); + const groupNode = svgNode2.append("g").attr("id", reqName); + const textId = "req-" + reqName; + const rectNode = newRectNode(groupNode, textId); + let titleNodeInfo = newTitleNode(groupNode, reqName + "_title", [ + `<<${req.type}>>`, + `${req.name}` + ]); + newBodyNode( + groupNode, + reqName + "_body", + [ + `Id: ${req.id}`, + `Text: ${req.text}`, + `Risk: ${req.risk}`, + `Verification: ${req.verifyMethod}` + ], + titleNodeInfo.y + ); + const rectBBox = rectNode.node().getBBox(); + graph.setNode(reqName, { + width: rectBBox.width, + height: rectBBox.height, + shape: "rect", + id: reqName + }); + }); + }; + const drawElements = (els, graph, svgNode2) => { + Object.keys(els).forEach((elName) => { + let el = els[elName]; + const id2 = elementString(elName); + const groupNode = svgNode2.append("g").attr("id", id2); + const textId = "element-" + id2; + const rectNode = newRectNode(groupNode, textId); + let titleNodeInfo = newTitleNode(groupNode, textId + "_title", [`<>`, `${elName}`]); + newBodyNode( + groupNode, + textId + "_body", + [`Type: ${el.type || "Not Specified"}`, `Doc Ref: ${el.docRef || "None"}`], + titleNodeInfo.y + ); + const rectBBox = rectNode.node().getBBox(); + graph.setNode(id2, { + width: rectBBox.width, + height: rectBBox.height, + shape: "rect", + id: id2 + }); + }); + }; + const addRelationships = (relationships2, g) => { + relationships2.forEach(function(r) { + let src = elementString(r.src); + let dst = elementString(r.dst); + g.setEdge(src, dst, { relationship: r }); + }); + return relationships2; + }; + const adjustEntities = function(svgNode2, graph) { + graph.nodes().forEach(function(v) { + if (v !== void 0 && graph.node(v) !== void 0) { + svgNode2.select("#" + v); + svgNode2.select("#" + v).attr( + "transform", + "translate(" + (graph.node(v).x - graph.node(v).width / 2) + "," + (graph.node(v).y - graph.node(v).height / 2) + " )" + ); + } + }); + return; + }; + const elementString = (str2) => { + return str2.replace(/\s/g, "").replace(/\./g, "_"); + }; + const draw$b = (text2, id2, _version, diagObj) => { + conf$5 = getConfig$1().requirement; + const securityLevel = conf$5.securityLevel; + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = d3select("#i" + id2); + } + const root2 = securityLevel === "sandbox" ? d3select(sandboxElement.nodes()[0].contentDocument.body) : d3select("body"); + const svg2 = root2.select(`[id='${id2}']`); + markers.insertLineEndings(svg2, conf$5); + const g = new Graph({ + multigraph: false, + compound: false, + directed: true + }).setGraph({ + rankdir: conf$5.layoutDirection, + marginx: 20, + marginy: 20, + nodesep: 100, + edgesep: 100, + ranksep: 100 + }).setDefaultEdgeLabel(function() { + return {}; + }); + let requirements2 = diagObj.db.getRequirements(); + let elements2 = diagObj.db.getElements(); + let relationships2 = diagObj.db.getRelationships(); + drawReqs(requirements2, g, svg2); + drawElements(elements2, g, svg2); + addRelationships(relationships2, g); + layout$1(g); + adjustEntities(svg2, g); + relationships2.forEach(function(rel2) { + drawRelationshipFromLayout(svg2, rel2, g, id2, diagObj); + }); + const padding2 = conf$5.rect_padding; + const svgBounds = svg2.node().getBBox(); + const width2 = svgBounds.width + padding2 * 2; + const height = svgBounds.height + padding2 * 2; + configureSvgSize(svg2, height, width2, conf$5.useMaxWidth); + svg2.attr("viewBox", `${svgBounds.x - padding2} ${svgBounds.y - padding2} ${width2} ${height}`); + }; + const renderer$b = { + draw: draw$b + }; + const diagram$b = { + parser: parser$h, + db: db$a, + renderer: renderer$b, + styles: styles$7 + }; + const requirementDiagram = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + diagram: diagram$b + }, Symbol.toStringTag, { value: "Module" })); + var parser$e = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 2], $V1 = [1, 3], $V2 = [1, 4], $V3 = [2, 4], $V4 = [1, 9], $V5 = [1, 11], $V6 = [1, 13], $V7 = [1, 14], $V8 = [1, 16], $V9 = [1, 17], $Va = [1, 18], $Vb = [1, 24], $Vc = [1, 25], $Vd = [1, 26], $Ve = [1, 27], $Vf = [1, 28], $Vg = [1, 29], $Vh = [1, 30], $Vi = [1, 31], $Vj = [1, 32], $Vk = [1, 33], $Vl = [1, 34], $Vm = [1, 35], $Vn = [1, 36], $Vo = [1, 37], $Vp = [1, 38], $Vq = [1, 39], $Vr = [1, 41], $Vs = [1, 42], $Vt = [1, 43], $Vu = [1, 44], $Vv = [1, 45], $Vw = [1, 46], $Vx = [1, 4, 5, 13, 14, 16, 18, 21, 23, 29, 30, 31, 33, 35, 36, 37, 38, 39, 41, 43, 44, 46, 47, 48, 49, 50, 52, 53, 54, 59, 60, 61, 62, 70], $Vy = [4, 5, 16, 50, 52, 53], $Vz = [4, 5, 13, 14, 16, 18, 21, 23, 29, 30, 31, 33, 35, 36, 37, 38, 39, 41, 43, 44, 46, 50, 52, 53, 54, 59, 60, 61, 62, 70], $VA = [4, 5, 13, 14, 16, 18, 21, 23, 29, 30, 31, 33, 35, 36, 37, 38, 39, 41, 43, 44, 46, 49, 50, 52, 53, 54, 59, 60, 61, 62, 70], $VB = [4, 5, 13, 14, 16, 18, 21, 23, 29, 30, 31, 33, 35, 36, 37, 38, 39, 41, 43, 44, 46, 48, 50, 52, 53, 54, 59, 60, 61, 62, 70], $VC = [4, 5, 13, 14, 16, 18, 21, 23, 29, 30, 31, 33, 35, 36, 37, 38, 39, 41, 43, 44, 46, 47, 50, 52, 53, 54, 59, 60, 61, 62, 70], $VD = [68, 69, 70], $VE = [1, 120]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "SPACE": 4, "NEWLINE": 5, "SD": 6, "document": 7, "line": 8, "statement": 9, "box_section": 10, "box_line": 11, "participant_statement": 12, "create": 13, "box": 14, "restOfLine": 15, "end": 16, "signal": 17, "autonumber": 18, "NUM": 19, "off": 20, "activate": 21, "actor": 22, "deactivate": 23, "note_statement": 24, "links_statement": 25, "link_statement": 26, "properties_statement": 27, "details_statement": 28, "title": 29, "legacy_title": 30, "acc_title": 31, "acc_title_value": 32, "acc_descr": 33, "acc_descr_value": 34, "acc_descr_multiline_value": 35, "loop": 36, "rect": 37, "opt": 38, "alt": 39, "else_sections": 40, "par": 41, "par_sections": 42, "par_over": 43, "critical": 44, "option_sections": 45, "break": 46, "option": 47, "and": 48, "else": 49, "participant": 50, "AS": 51, "participant_actor": 52, "destroy": 53, "note": 54, "placement": 55, "text2": 56, "over": 57, "actor_pair": 58, "links": 59, "link": 60, "properties": 61, "details": 62, "spaceList": 63, ",": 64, "left_of": 65, "right_of": 66, "signaltype": 67, "+": 68, "-": 69, "ACTOR": 70, "SOLID_OPEN_ARROW": 71, "DOTTED_OPEN_ARROW": 72, "SOLID_ARROW": 73, "DOTTED_ARROW": 74, "SOLID_CROSS": 75, "DOTTED_CROSS": 76, "SOLID_POINT": 77, "DOTTED_POINT": 78, "TXT": 79, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 4: "SPACE", 5: "NEWLINE", 6: "SD", 13: "create", 14: "box", 15: "restOfLine", 16: "end", 18: "autonumber", 19: "NUM", 20: "off", 21: "activate", 23: "deactivate", 29: "title", 30: "legacy_title", 31: "acc_title", 32: "acc_title_value", 33: "acc_descr", 34: "acc_descr_value", 35: "acc_descr_multiline_value", 36: "loop", 37: "rect", 38: "opt", 39: "alt", 41: "par", 43: "par_over", 44: "critical", 46: "break", 47: "option", 48: "and", 49: "else", 50: "participant", 51: "AS", 52: "participant_actor", 53: "destroy", 54: "note", 57: "over", 59: "links", 60: "link", 61: "properties", 62: "details", 64: ",", 65: "left_of", 66: "right_of", 68: "+", 69: "-", 70: "ACTOR", 71: "SOLID_OPEN_ARROW", 72: "DOTTED_OPEN_ARROW", 73: "SOLID_ARROW", 74: "DOTTED_ARROW", 75: "SOLID_CROSS", 76: "DOTTED_CROSS", 77: "SOLID_POINT", 78: "DOTTED_POINT", 79: "TXT" }, + productions_: [0, [3, 2], [3, 2], [3, 2], [7, 0], [7, 2], [8, 2], [8, 1], [8, 1], [10, 0], [10, 2], [11, 2], [11, 1], [11, 1], [9, 1], [9, 2], [9, 4], [9, 2], [9, 4], [9, 3], [9, 3], [9, 2], [9, 3], [9, 3], [9, 2], [9, 2], [9, 2], [9, 2], [9, 2], [9, 1], [9, 1], [9, 2], [9, 2], [9, 1], [9, 4], [9, 4], [9, 4], [9, 4], [9, 4], [9, 4], [9, 4], [9, 4], [45, 1], [45, 4], [42, 1], [42, 4], [40, 1], [40, 4], [12, 5], [12, 3], [12, 5], [12, 3], [12, 3], [24, 4], [24, 4], [25, 3], [26, 3], [27, 3], [28, 3], [63, 2], [63, 1], [58, 3], [58, 1], [55, 1], [55, 1], [17, 5], [17, 5], [17, 4], [22, 1], [67, 1], [67, 1], [67, 1], [67, 1], [67, 1], [67, 1], [67, 1], [67, 1], [56, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 3: + yy.apply($$[$0]); + return $$[$0]; + case 4: + case 9: + this.$ = []; + break; + case 5: + case 10: + $$[$0 - 1].push($$[$0]); + this.$ = $$[$0 - 1]; + break; + case 6: + case 7: + case 11: + case 12: + this.$ = $$[$0]; + break; + case 8: + case 13: + this.$ = []; + break; + case 15: + $$[$0].type = "createParticipant"; + this.$ = $$[$0]; + break; + case 16: + $$[$0 - 1].unshift({ type: "boxStart", boxData: yy.parseBoxData($$[$0 - 2]) }); + $$[$0 - 1].push({ type: "boxEnd", boxText: $$[$0 - 2] }); + this.$ = $$[$0 - 1]; + break; + case 18: + this.$ = { type: "sequenceIndex", sequenceIndex: Number($$[$0 - 2]), sequenceIndexStep: Number($$[$0 - 1]), sequenceVisible: true, signalType: yy.LINETYPE.AUTONUMBER }; + break; + case 19: + this.$ = { type: "sequenceIndex", sequenceIndex: Number($$[$0 - 1]), sequenceIndexStep: 1, sequenceVisible: true, signalType: yy.LINETYPE.AUTONUMBER }; + break; + case 20: + this.$ = { type: "sequenceIndex", sequenceVisible: false, signalType: yy.LINETYPE.AUTONUMBER }; + break; + case 21: + this.$ = { type: "sequenceIndex", sequenceVisible: true, signalType: yy.LINETYPE.AUTONUMBER }; + break; + case 22: + this.$ = { type: "activeStart", signalType: yy.LINETYPE.ACTIVE_START, actor: $$[$0 - 1] }; + break; + case 23: + this.$ = { type: "activeEnd", signalType: yy.LINETYPE.ACTIVE_END, actor: $$[$0 - 1] }; + break; + case 29: + yy.setDiagramTitle($$[$0].substring(6)); + this.$ = $$[$0].substring(6); + break; + case 30: + yy.setDiagramTitle($$[$0].substring(7)); + this.$ = $$[$0].substring(7); + break; + case 31: + this.$ = $$[$0].trim(); + yy.setAccTitle(this.$); + break; + case 32: + case 33: + this.$ = $$[$0].trim(); + yy.setAccDescription(this.$); + break; + case 34: + $$[$0 - 1].unshift({ type: "loopStart", loopText: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.LOOP_START }); + $$[$0 - 1].push({ type: "loopEnd", loopText: $$[$0 - 2], signalType: yy.LINETYPE.LOOP_END }); + this.$ = $$[$0 - 1]; + break; + case 35: + $$[$0 - 1].unshift({ type: "rectStart", color: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.RECT_START }); + $$[$0 - 1].push({ type: "rectEnd", color: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.RECT_END }); + this.$ = $$[$0 - 1]; + break; + case 36: + $$[$0 - 1].unshift({ type: "optStart", optText: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.OPT_START }); + $$[$0 - 1].push({ type: "optEnd", optText: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.OPT_END }); + this.$ = $$[$0 - 1]; + break; + case 37: + $$[$0 - 1].unshift({ type: "altStart", altText: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.ALT_START }); + $$[$0 - 1].push({ type: "altEnd", signalType: yy.LINETYPE.ALT_END }); + this.$ = $$[$0 - 1]; + break; + case 38: + $$[$0 - 1].unshift({ type: "parStart", parText: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.PAR_START }); + $$[$0 - 1].push({ type: "parEnd", signalType: yy.LINETYPE.PAR_END }); + this.$ = $$[$0 - 1]; + break; + case 39: + $$[$0 - 1].unshift({ type: "parStart", parText: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.PAR_OVER_START }); + $$[$0 - 1].push({ type: "parEnd", signalType: yy.LINETYPE.PAR_END }); + this.$ = $$[$0 - 1]; + break; + case 40: + $$[$0 - 1].unshift({ type: "criticalStart", criticalText: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.CRITICAL_START }); + $$[$0 - 1].push({ type: "criticalEnd", signalType: yy.LINETYPE.CRITICAL_END }); + this.$ = $$[$0 - 1]; + break; + case 41: + $$[$0 - 1].unshift({ type: "breakStart", breakText: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.BREAK_START }); + $$[$0 - 1].push({ type: "breakEnd", optText: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.BREAK_END }); + this.$ = $$[$0 - 1]; + break; + case 43: + this.$ = $$[$0 - 3].concat([{ type: "option", optionText: yy.parseMessage($$[$0 - 1]), signalType: yy.LINETYPE.CRITICAL_OPTION }, $$[$0]]); + break; + case 45: + this.$ = $$[$0 - 3].concat([{ type: "and", parText: yy.parseMessage($$[$0 - 1]), signalType: yy.LINETYPE.PAR_AND }, $$[$0]]); + break; + case 47: + this.$ = $$[$0 - 3].concat([{ type: "else", altText: yy.parseMessage($$[$0 - 1]), signalType: yy.LINETYPE.ALT_ELSE }, $$[$0]]); + break; + case 48: + $$[$0 - 3].draw = "participant"; + $$[$0 - 3].type = "addParticipant"; + $$[$0 - 3].description = yy.parseMessage($$[$0 - 1]); + this.$ = $$[$0 - 3]; + break; + case 49: + $$[$0 - 1].draw = "participant"; + $$[$0 - 1].type = "addParticipant"; + this.$ = $$[$0 - 1]; + break; + case 50: + $$[$0 - 3].draw = "actor"; + $$[$0 - 3].type = "addParticipant"; + $$[$0 - 3].description = yy.parseMessage($$[$0 - 1]); + this.$ = $$[$0 - 3]; + break; + case 51: + $$[$0 - 1].draw = "actor"; + $$[$0 - 1].type = "addParticipant"; + this.$ = $$[$0 - 1]; + break; + case 52: + $$[$0 - 1].type = "destroyParticipant"; + this.$ = $$[$0 - 1]; + break; + case 53: + this.$ = [$$[$0 - 1], { type: "addNote", placement: $$[$0 - 2], actor: $$[$0 - 1].actor, text: $$[$0] }]; + break; + case 54: + $$[$0 - 2] = [].concat($$[$0 - 1], $$[$0 - 1]).slice(0, 2); + $$[$0 - 2][0] = $$[$0 - 2][0].actor; + $$[$0 - 2][1] = $$[$0 - 2][1].actor; + this.$ = [$$[$0 - 1], { type: "addNote", placement: yy.PLACEMENT.OVER, actor: $$[$0 - 2].slice(0, 2), text: $$[$0] }]; + break; + case 55: + this.$ = [$$[$0 - 1], { type: "addLinks", actor: $$[$0 - 1].actor, text: $$[$0] }]; + break; + case 56: + this.$ = [$$[$0 - 1], { type: "addALink", actor: $$[$0 - 1].actor, text: $$[$0] }]; + break; + case 57: + this.$ = [$$[$0 - 1], { type: "addProperties", actor: $$[$0 - 1].actor, text: $$[$0] }]; + break; + case 58: + this.$ = [$$[$0 - 1], { type: "addDetails", actor: $$[$0 - 1].actor, text: $$[$0] }]; + break; + case 61: + this.$ = [$$[$0 - 2], $$[$0]]; + break; + case 62: + this.$ = $$[$0]; + break; + case 63: + this.$ = yy.PLACEMENT.LEFTOF; + break; + case 64: + this.$ = yy.PLACEMENT.RIGHTOF; + break; + case 65: + this.$ = [ + $$[$0 - 4], + $$[$0 - 1], + { type: "addMessage", from: $$[$0 - 4].actor, to: $$[$0 - 1].actor, signalType: $$[$0 - 3], msg: $$[$0], activate: true }, + { type: "activeStart", signalType: yy.LINETYPE.ACTIVE_START, actor: $$[$0 - 1] } + ]; + break; + case 66: + this.$ = [ + $$[$0 - 4], + $$[$0 - 1], + { type: "addMessage", from: $$[$0 - 4].actor, to: $$[$0 - 1].actor, signalType: $$[$0 - 3], msg: $$[$0] }, + { type: "activeEnd", signalType: yy.LINETYPE.ACTIVE_END, actor: $$[$0 - 4] } + ]; + break; + case 67: + this.$ = [$$[$0 - 3], $$[$0 - 1], { type: "addMessage", from: $$[$0 - 3].actor, to: $$[$0 - 1].actor, signalType: $$[$0 - 2], msg: $$[$0] }]; + break; + case 68: + this.$ = { type: "addParticipant", actor: $$[$0] }; + break; + case 69: + this.$ = yy.LINETYPE.SOLID_OPEN; + break; + case 70: + this.$ = yy.LINETYPE.DOTTED_OPEN; + break; + case 71: + this.$ = yy.LINETYPE.SOLID; + break; + case 72: + this.$ = yy.LINETYPE.DOTTED; + break; + case 73: + this.$ = yy.LINETYPE.SOLID_CROSS; + break; + case 74: + this.$ = yy.LINETYPE.DOTTED_CROSS; + break; + case 75: + this.$ = yy.LINETYPE.SOLID_POINT; + break; + case 76: + this.$ = yy.LINETYPE.DOTTED_POINT; + break; + case 77: + this.$ = yy.parseMessage($$[$0].trim().substring(1)); + break; + } + }, + table: [{ 3: 1, 4: $V0, 5: $V1, 6: $V2 }, { 1: [3] }, { 3: 5, 4: $V0, 5: $V1, 6: $V2 }, { 3: 6, 4: $V0, 5: $V1, 6: $V2 }, o([1, 4, 5, 13, 14, 18, 21, 23, 29, 30, 31, 33, 35, 36, 37, 38, 39, 41, 43, 44, 46, 50, 52, 53, 54, 59, 60, 61, 62, 70], $V3, { 7: 7 }), { 1: [2, 1] }, { 1: [2, 2] }, { 1: [2, 3], 4: $V4, 5: $V5, 8: 8, 9: 10, 12: 12, 13: $V6, 14: $V7, 17: 15, 18: $V8, 21: $V9, 22: 40, 23: $Va, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: $Vb, 30: $Vc, 31: $Vd, 33: $Ve, 35: $Vf, 36: $Vg, 37: $Vh, 38: $Vi, 39: $Vj, 41: $Vk, 43: $Vl, 44: $Vm, 46: $Vn, 50: $Vo, 52: $Vp, 53: $Vq, 54: $Vr, 59: $Vs, 60: $Vt, 61: $Vu, 62: $Vv, 70: $Vw }, o($Vx, [2, 5]), { 9: 47, 12: 12, 13: $V6, 14: $V7, 17: 15, 18: $V8, 21: $V9, 22: 40, 23: $Va, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: $Vb, 30: $Vc, 31: $Vd, 33: $Ve, 35: $Vf, 36: $Vg, 37: $Vh, 38: $Vi, 39: $Vj, 41: $Vk, 43: $Vl, 44: $Vm, 46: $Vn, 50: $Vo, 52: $Vp, 53: $Vq, 54: $Vr, 59: $Vs, 60: $Vt, 61: $Vu, 62: $Vv, 70: $Vw }, o($Vx, [2, 7]), o($Vx, [2, 8]), o($Vx, [2, 14]), { 12: 48, 50: $Vo, 52: $Vp, 53: $Vq }, { 15: [1, 49] }, { 5: [1, 50] }, { 5: [1, 53], 19: [1, 51], 20: [1, 52] }, { 22: 54, 70: $Vw }, { 22: 55, 70: $Vw }, { 5: [1, 56] }, { 5: [1, 57] }, { 5: [1, 58] }, { 5: [1, 59] }, { 5: [1, 60] }, o($Vx, [2, 29]), o($Vx, [2, 30]), { 32: [1, 61] }, { 34: [1, 62] }, o($Vx, [2, 33]), { 15: [1, 63] }, { 15: [1, 64] }, { 15: [1, 65] }, { 15: [1, 66] }, { 15: [1, 67] }, { 15: [1, 68] }, { 15: [1, 69] }, { 15: [1, 70] }, { 22: 71, 70: $Vw }, { 22: 72, 70: $Vw }, { 22: 73, 70: $Vw }, { 67: 74, 71: [1, 75], 72: [1, 76], 73: [1, 77], 74: [1, 78], 75: [1, 79], 76: [1, 80], 77: [1, 81], 78: [1, 82] }, { 55: 83, 57: [1, 84], 65: [1, 85], 66: [1, 86] }, { 22: 87, 70: $Vw }, { 22: 88, 70: $Vw }, { 22: 89, 70: $Vw }, { 22: 90, 70: $Vw }, o([5, 51, 64, 71, 72, 73, 74, 75, 76, 77, 78, 79], [2, 68]), o($Vx, [2, 6]), o($Vx, [2, 15]), o($Vy, [2, 9], { 10: 91 }), o($Vx, [2, 17]), { 5: [1, 93], 19: [1, 92] }, { 5: [1, 94] }, o($Vx, [2, 21]), { 5: [1, 95] }, { 5: [1, 96] }, o($Vx, [2, 24]), o($Vx, [2, 25]), o($Vx, [2, 26]), o($Vx, [2, 27]), o($Vx, [2, 28]), o($Vx, [2, 31]), o($Vx, [2, 32]), o($Vz, $V3, { 7: 97 }), o($Vz, $V3, { 7: 98 }), o($Vz, $V3, { 7: 99 }), o($VA, $V3, { 40: 100, 7: 101 }), o($VB, $V3, { 42: 102, 7: 103 }), o($VB, $V3, { 7: 103, 42: 104 }), o($VC, $V3, { 45: 105, 7: 106 }), o($Vz, $V3, { 7: 107 }), { 5: [1, 109], 51: [1, 108] }, { 5: [1, 111], 51: [1, 110] }, { 5: [1, 112] }, { 22: 115, 68: [1, 113], 69: [1, 114], 70: $Vw }, o($VD, [2, 69]), o($VD, [2, 70]), o($VD, [2, 71]), o($VD, [2, 72]), o($VD, [2, 73]), o($VD, [2, 74]), o($VD, [2, 75]), o($VD, [2, 76]), { 22: 116, 70: $Vw }, { 22: 118, 58: 117, 70: $Vw }, { 70: [2, 63] }, { 70: [2, 64] }, { 56: 119, 79: $VE }, { 56: 121, 79: $VE }, { 56: 122, 79: $VE }, { 56: 123, 79: $VE }, { 4: [1, 126], 5: [1, 128], 11: 125, 12: 127, 16: [1, 124], 50: $Vo, 52: $Vp, 53: $Vq }, { 5: [1, 129] }, o($Vx, [2, 19]), o($Vx, [2, 20]), o($Vx, [2, 22]), o($Vx, [2, 23]), { 4: $V4, 5: $V5, 8: 8, 9: 10, 12: 12, 13: $V6, 14: $V7, 16: [1, 130], 17: 15, 18: $V8, 21: $V9, 22: 40, 23: $Va, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: $Vb, 30: $Vc, 31: $Vd, 33: $Ve, 35: $Vf, 36: $Vg, 37: $Vh, 38: $Vi, 39: $Vj, 41: $Vk, 43: $Vl, 44: $Vm, 46: $Vn, 50: $Vo, 52: $Vp, 53: $Vq, 54: $Vr, 59: $Vs, 60: $Vt, 61: $Vu, 62: $Vv, 70: $Vw }, { 4: $V4, 5: $V5, 8: 8, 9: 10, 12: 12, 13: $V6, 14: $V7, 16: [1, 131], 17: 15, 18: $V8, 21: $V9, 22: 40, 23: $Va, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: $Vb, 30: $Vc, 31: $Vd, 33: $Ve, 35: $Vf, 36: $Vg, 37: $Vh, 38: $Vi, 39: $Vj, 41: $Vk, 43: $Vl, 44: $Vm, 46: $Vn, 50: $Vo, 52: $Vp, 53: $Vq, 54: $Vr, 59: $Vs, 60: $Vt, 61: $Vu, 62: $Vv, 70: $Vw }, { 4: $V4, 5: $V5, 8: 8, 9: 10, 12: 12, 13: $V6, 14: $V7, 16: [1, 132], 17: 15, 18: $V8, 21: $V9, 22: 40, 23: $Va, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: $Vb, 30: $Vc, 31: $Vd, 33: $Ve, 35: $Vf, 36: $Vg, 37: $Vh, 38: $Vi, 39: $Vj, 41: $Vk, 43: $Vl, 44: $Vm, 46: $Vn, 50: $Vo, 52: $Vp, 53: $Vq, 54: $Vr, 59: $Vs, 60: $Vt, 61: $Vu, 62: $Vv, 70: $Vw }, { 16: [1, 133] }, { 4: $V4, 5: $V5, 8: 8, 9: 10, 12: 12, 13: $V6, 14: $V7, 16: [2, 46], 17: 15, 18: $V8, 21: $V9, 22: 40, 23: $Va, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: $Vb, 30: $Vc, 31: $Vd, 33: $Ve, 35: $Vf, 36: $Vg, 37: $Vh, 38: $Vi, 39: $Vj, 41: $Vk, 43: $Vl, 44: $Vm, 46: $Vn, 49: [1, 134], 50: $Vo, 52: $Vp, 53: $Vq, 54: $Vr, 59: $Vs, 60: $Vt, 61: $Vu, 62: $Vv, 70: $Vw }, { 16: [1, 135] }, { 4: $V4, 5: $V5, 8: 8, 9: 10, 12: 12, 13: $V6, 14: $V7, 16: [2, 44], 17: 15, 18: $V8, 21: $V9, 22: 40, 23: $Va, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: $Vb, 30: $Vc, 31: $Vd, 33: $Ve, 35: $Vf, 36: $Vg, 37: $Vh, 38: $Vi, 39: $Vj, 41: $Vk, 43: $Vl, 44: $Vm, 46: $Vn, 48: [1, 136], 50: $Vo, 52: $Vp, 53: $Vq, 54: $Vr, 59: $Vs, 60: $Vt, 61: $Vu, 62: $Vv, 70: $Vw }, { 16: [1, 137] }, { 16: [1, 138] }, { 4: $V4, 5: $V5, 8: 8, 9: 10, 12: 12, 13: $V6, 14: $V7, 16: [2, 42], 17: 15, 18: $V8, 21: $V9, 22: 40, 23: $Va, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: $Vb, 30: $Vc, 31: $Vd, 33: $Ve, 35: $Vf, 36: $Vg, 37: $Vh, 38: $Vi, 39: $Vj, 41: $Vk, 43: $Vl, 44: $Vm, 46: $Vn, 47: [1, 139], 50: $Vo, 52: $Vp, 53: $Vq, 54: $Vr, 59: $Vs, 60: $Vt, 61: $Vu, 62: $Vv, 70: $Vw }, { 4: $V4, 5: $V5, 8: 8, 9: 10, 12: 12, 13: $V6, 14: $V7, 16: [1, 140], 17: 15, 18: $V8, 21: $V9, 22: 40, 23: $Va, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: $Vb, 30: $Vc, 31: $Vd, 33: $Ve, 35: $Vf, 36: $Vg, 37: $Vh, 38: $Vi, 39: $Vj, 41: $Vk, 43: $Vl, 44: $Vm, 46: $Vn, 50: $Vo, 52: $Vp, 53: $Vq, 54: $Vr, 59: $Vs, 60: $Vt, 61: $Vu, 62: $Vv, 70: $Vw }, { 15: [1, 141] }, o($Vx, [2, 49]), { 15: [1, 142] }, o($Vx, [2, 51]), o($Vx, [2, 52]), { 22: 143, 70: $Vw }, { 22: 144, 70: $Vw }, { 56: 145, 79: $VE }, { 56: 146, 79: $VE }, { 56: 147, 79: $VE }, { 64: [1, 148], 79: [2, 62] }, { 5: [2, 55] }, { 5: [2, 77] }, { 5: [2, 56] }, { 5: [2, 57] }, { 5: [2, 58] }, o($Vx, [2, 16]), o($Vy, [2, 10]), { 12: 149, 50: $Vo, 52: $Vp, 53: $Vq }, o($Vy, [2, 12]), o($Vy, [2, 13]), o($Vx, [2, 18]), o($Vx, [2, 34]), o($Vx, [2, 35]), o($Vx, [2, 36]), o($Vx, [2, 37]), { 15: [1, 150] }, o($Vx, [2, 38]), { 15: [1, 151] }, o($Vx, [2, 39]), o($Vx, [2, 40]), { 15: [1, 152] }, o($Vx, [2, 41]), { 5: [1, 153] }, { 5: [1, 154] }, { 56: 155, 79: $VE }, { 56: 156, 79: $VE }, { 5: [2, 67] }, { 5: [2, 53] }, { 5: [2, 54] }, { 22: 157, 70: $Vw }, o($Vy, [2, 11]), o($VA, $V3, { 7: 101, 40: 158 }), o($VB, $V3, { 7: 103, 42: 159 }), o($VC, $V3, { 7: 106, 45: 160 }), o($Vx, [2, 48]), o($Vx, [2, 50]), { 5: [2, 65] }, { 5: [2, 66] }, { 79: [2, 61] }, { 16: [2, 47] }, { 16: [2, 45] }, { 16: [2, 43] }], + defaultActions: { 5: [2, 1], 6: [2, 2], 85: [2, 63], 86: [2, 64], 119: [2, 55], 120: [2, 77], 121: [2, 56], 122: [2, 57], 123: [2, 58], 145: [2, 67], 146: [2, 53], 147: [2, 54], 155: [2, 65], 156: [2, 66], 157: [2, 61], 158: [2, 47], 159: [2, 45], 160: [2, 43] }, + parseError: function parseError(str2, hash) { + if (hash.recoverable) { + this.trace(str2); + } else { + var error = new Error(str2); + error.hash = hash; + throw error; + } + }, + parse: function parse2(input) { + var self2 = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex2() { + var token2; + token2 = tstack.pop() || lexer2.lex() || EOF; + if (typeof token2 !== "number") { + if (token2 instanceof Array) { + tstack = token2; + token2 = tstack.pop(); + } + token2 = self2.symbols_[token2] || token2; + } + return token2; + } + var symbol, state2, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state2 = stack[stack.length - 1]; + if (this.defaultActions[state2]) { + action = this.defaultActions[state2]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex2(); + } + action = table[state2] && table[state2][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state2]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state2 + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str2, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str2, hash); + } else { + throw new Error(str2); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch2 = this._input[0]; + this.yytext += ch2; + this.yyleng++; + this.offset++; + this.match += ch2; + this.matched += ch2; + var lines = ch2.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch2; + }, + // unshifts one char (or a string) into the input + unput: function(ch2) { + var len = ch2.length; + var lines = ch2.split(/(?:\r\n?|\n)/g); + this._input = ch2 + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next2 = this.match; + if (next2.length < 20) { + next2 += this._input.substr(0, 20 - next2.length); + } + return (next2.substr(0, 20) + (next2.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c2 = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c2 + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token2, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token2 = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token2) { + return token2; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token2, match, tempMatch, index2; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i2 = 0; i2 < rules.length; i2++) { + tempMatch = this._input.match(this.rules[rules[i2]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index2 = i2; + if (this.options.backtrack_lexer) { + token2 = this.test_match(tempMatch, rules[i2]); + if (token2 !== false) { + return token2; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token2 = this.test_match(match, rules[index2]); + if (token2 !== false) { + return token2; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex2() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + return 5; + case 1: + break; + case 2: + break; + case 3: + break; + case 4: + break; + case 5: + break; + case 6: + return 19; + case 7: + this.begin("LINE"); + return 14; + case 8: + this.begin("ID"); + return 50; + case 9: + this.begin("ID"); + return 52; + case 10: + return 13; + case 11: + this.begin("ID"); + return 53; + case 12: + yy_.yytext = yy_.yytext.trim(); + this.begin("ALIAS"); + return 70; + case 13: + this.popState(); + this.popState(); + this.begin("LINE"); + return 51; + case 14: + this.popState(); + this.popState(); + return 5; + case 15: + this.begin("LINE"); + return 36; + case 16: + this.begin("LINE"); + return 37; + case 17: + this.begin("LINE"); + return 38; + case 18: + this.begin("LINE"); + return 39; + case 19: + this.begin("LINE"); + return 49; + case 20: + this.begin("LINE"); + return 41; + case 21: + this.begin("LINE"); + return 43; + case 22: + this.begin("LINE"); + return 48; + case 23: + this.begin("LINE"); + return 44; + case 24: + this.begin("LINE"); + return 47; + case 25: + this.begin("LINE"); + return 46; + case 26: + this.popState(); + return 15; + case 27: + return 16; + case 28: + return 65; + case 29: + return 66; + case 30: + return 59; + case 31: + return 60; + case 32: + return 61; + case 33: + return 62; + case 34: + return 57; + case 35: + return 54; + case 36: + this.begin("ID"); + return 21; + case 37: + this.begin("ID"); + return 23; + case 38: + return 29; + case 39: + return 30; + case 40: + this.begin("acc_title"); + return 31; + case 41: + this.popState(); + return "acc_title_value"; + case 42: + this.begin("acc_descr"); + return 33; + case 43: + this.popState(); + return "acc_descr_value"; + case 44: + this.begin("acc_descr_multiline"); + break; + case 45: + this.popState(); + break; + case 46: + return "acc_descr_multiline_value"; + case 47: + return 6; + case 48: + return 18; + case 49: + return 20; + case 50: + return 64; + case 51: + return 5; + case 52: + yy_.yytext = yy_.yytext.trim(); + return 70; + case 53: + return 73; + case 54: + return 74; + case 55: + return 71; + case 56: + return 72; + case 57: + return 75; + case 58: + return 76; + case 59: + return 77; + case 60: + return 78; + case 61: + return 79; + case 62: + return 68; + case 63: + return 69; + case 64: + return 5; + case 65: + return "INVALID"; + } + }, + rules: [/^(?:[\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, /^(?:create\b)/i, /^(?:destroy\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, /^(?:par_over\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": [45, 46], "inclusive": false }, "acc_descr": { "rules": [43], "inclusive": false }, "acc_title": { "rules": [41], "inclusive": false }, "ID": { "rules": [2, 3, 12], "inclusive": false }, "ALIAS": { "rules": [2, 3, 13, 14], "inclusive": false }, "LINE": { "rules": [2, 3, 26], "inclusive": false }, "INITIAL": { "rules": [0, 1, 3, 4, 5, 6, 7, 8, 9, 10, 11, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 42, 44, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser2() { + this.yy = {}; + } + Parser2.prototype = parser2; + parser2.Parser = Parser2; + return new Parser2(); + }(); + parser$e.parser = parser$e; + const parser$f = parser$e; + class ImperativeState { + /** + * @param init - Function that creates the default state. + */ + constructor(init2) { + this.init = init2; + this.records = this.init(); + } + reset() { + this.records = this.init(); + } + } + const state = new ImperativeState(() => ({ + prevActor: void 0, + actors: {}, + createdActors: {}, + destroyedActors: {}, + boxes: [], + messages: [], + notes: [], + sequenceNumbersEnabled: false, + wrapEnabled: void 0, + currentBox: void 0, + lastCreated: void 0, + lastDestroyed: void 0 + })); + const addBox = function(data) { + state.records.boxes.push({ + name: data.text, + wrap: data.wrap === void 0 && autoWrap() || !!data.wrap, + fill: data.color, + actorKeys: [] + }); + state.records.currentBox = state.records.boxes.slice(-1)[0]; + }; + const addActor = function(id2, name, description, type2) { + let assignedBox = state.records.currentBox; + const old = state.records.actors[id2]; + if (old) { + if (state.records.currentBox && old.box && state.records.currentBox !== old.box) { + throw new Error( + "A same participant should only be defined in one Box: " + old.name + " can't be in '" + old.box.name + "' and in '" + state.records.currentBox.name + "' at the same time." + ); + } + assignedBox = old.box ? old.box : state.records.currentBox; + old.box = assignedBox; + if (old && name === old.name && description == null) { + return; + } + } + if (description == null || description.text == null) { + description = { text: name, wrap: null, type: type2 }; + } + if (type2 == null || description.text == null) { + description = { text: name, wrap: null, type: type2 }; + } + state.records.actors[id2] = { + box: assignedBox, + name, + description: description.text, + wrap: description.wrap === void 0 && autoWrap() || !!description.wrap, + prevActor: state.records.prevActor, + links: {}, + properties: {}, + actorCnt: null, + rectData: null, + type: type2 || "participant" + }; + if (state.records.prevActor && state.records.actors[state.records.prevActor]) { + state.records.actors[state.records.prevActor].nextActor = id2; + } + if (state.records.currentBox) { + state.records.currentBox.actorKeys.push(id2); + } + state.records.prevActor = id2; + }; + const activationCount = (part) => { + let i2; + let count = 0; + for (i2 = 0; i2 < state.records.messages.length; i2++) { + if (state.records.messages[i2].type === LINETYPE.ACTIVE_START && state.records.messages[i2].from.actor === part) { + count++; + } + if (state.records.messages[i2].type === LINETYPE.ACTIVE_END && state.records.messages[i2].from.actor === part) { + count--; + } + } + return count; + }; + const addMessage = function(idFrom, idTo, message, answer) { + state.records.messages.push({ + from: idFrom, + to: idTo, + message: message.text, + wrap: message.wrap === void 0 && autoWrap() || !!message.wrap, + answer + }); + }; + const addSignal = function(idFrom, idTo, message = { text: void 0, wrap: void 0 }, messageType, activate = false) { + if (messageType === LINETYPE.ACTIVE_END) { + const cnt2 = activationCount(idFrom.actor); + if (cnt2 < 1) { + let error = new Error("Trying to inactivate an inactive participant (" + idFrom.actor + ")"); + error.hash = { + text: "->>-", + token: "->>-", + line: "1", + loc: { first_line: 1, last_line: 1, first_column: 1, last_column: 1 }, + expected: ["'ACTIVE_PARTICIPANT'"] + }; + throw error; + } + } + state.records.messages.push({ + from: idFrom, + to: idTo, + message: message.text, + wrap: message.wrap === void 0 && autoWrap() || !!message.wrap, + type: messageType, + activate + }); + return true; + }; + const hasAtLeastOneBox = function() { + return state.records.boxes.length > 0; + }; + const hasAtLeastOneBoxWithTitle = function() { + return state.records.boxes.some((b) => b.name); + }; + const getMessages = function() { + return state.records.messages; + }; + const getBoxes = function() { + return state.records.boxes; + }; + const getActors$1 = function() { + return state.records.actors; + }; + const getCreatedActors = function() { + return state.records.createdActors; + }; + const getDestroyedActors = function() { + return state.records.destroyedActors; + }; + const getActor = function(id2) { + return state.records.actors[id2]; + }; + const getActorKeys = function() { + return Object.keys(state.records.actors); + }; + const enableSequenceNumbers = function() { + state.records.sequenceNumbersEnabled = true; + }; + const disableSequenceNumbers = function() { + state.records.sequenceNumbersEnabled = false; + }; + const showSequenceNumbers = () => state.records.sequenceNumbersEnabled; + const setWrap = function(wrapSetting) { + state.records.wrapEnabled = wrapSetting; + }; + const autoWrap = () => { + if (state.records.wrapEnabled !== void 0) { + return state.records.wrapEnabled; + } + return getConfig$1().sequence.wrap; + }; + const clear$7 = function() { + state.reset(); + clear$n(); + }; + const parseMessage = function(str2) { + const _str = str2.trim(); + const message = { + text: _str.replace(/^:?(?:no)?wrap:/, "").trim(), + wrap: _str.match(/^:?wrap:/) !== null ? true : _str.match(/^:?nowrap:/) !== null ? false : void 0 + }; + log$1.debug("parseMessage:", message); + return message; + }; + const parseBoxData = function(str2) { + const match = str2.match(/^((?:rgba?|hsla?)\s*\(.*\)|\w*)(.*)$/); + let color2 = match != null && match[1] ? match[1].trim() : "transparent"; + let title2 = match != null && match[2] ? match[2].trim() : void 0; + if (window && window.CSS) { + if (!window.CSS.supports("color", color2)) { + color2 = "transparent"; + title2 = str2.trim(); + } + } else { + const style = new Option().style; + style.color = color2; + if (style.color !== color2) { + color2 = "transparent"; + title2 = str2.trim(); + } + } + return { + color: color2, + text: title2 !== void 0 ? sanitizeText$6(title2.replace(/^:?(?:no)?wrap:/, ""), getConfig$1()) : void 0, + wrap: title2 !== void 0 ? title2.match(/^:?wrap:/) !== null ? true : title2.match(/^:?nowrap:/) !== null ? false : void 0 : void 0 + }; + }; + const LINETYPE = { + 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, + PAR_OVER_START: 32 + }; + const ARROWTYPE = { + FILLED: 0, + OPEN: 1 + }; + const PLACEMENT = { + LEFTOF: 0, + RIGHTOF: 1, + OVER: 2 + }; + const addNote$1 = function(actor, placement, message) { + const note2 = { + actor, + placement, + message: message.text, + wrap: message.wrap === void 0 && autoWrap() || !!message.wrap + }; + const actors2 = [].concat(actor, actor); + state.records.notes.push(note2); + state.records.messages.push({ + from: actors2[0], + to: actors2[1], + message: message.text, + wrap: message.wrap === void 0 && autoWrap() || !!message.wrap, + type: LINETYPE.NOTE, + placement + }); + }; + const addLinks = function(actorId, text2) { + const actor = getActor(actorId); + try { + let sanitizedText = sanitizeText$6(text2.text, getConfig$1()); + sanitizedText = sanitizedText.replace(/&/g, "&"); + sanitizedText = sanitizedText.replace(/=/g, "="); + const links2 = JSON.parse(sanitizedText); + insertLinks(actor, links2); + } catch (e) { + log$1.error("error while parsing actor link text", e); + } + }; + const addALink = function(actorId, text2) { + const actor = getActor(actorId); + try { + const links2 = {}; + let sanitizedText = sanitizeText$6(text2.text, getConfig$1()); + var sep2 = sanitizedText.indexOf("@"); + sanitizedText = sanitizedText.replace(/&/g, "&"); + sanitizedText = sanitizedText.replace(/=/g, "="); + var label = sanitizedText.slice(0, sep2 - 1).trim(); + var link2 = sanitizedText.slice(sep2 + 1).trim(); + links2[label] = link2; + insertLinks(actor, links2); + } catch (e) { + log$1.error("error while parsing actor link text", e); + } + }; + function insertLinks(actor, links2) { + if (actor.links == null) { + actor.links = links2; + } else { + for (let key in links2) { + actor.links[key] = links2[key]; + } + } + } + const addProperties = function(actorId, text2) { + const actor = getActor(actorId); + try { + let sanitizedText = sanitizeText$6(text2.text, getConfig$1()); + const properties = JSON.parse(sanitizedText); + insertProperties(actor, properties); + } catch (e) { + log$1.error("error while parsing actor properties text", e); + } + }; + function insertProperties(actor, properties) { + if (actor.properties == null) { + actor.properties = properties; + } else { + for (let key in properties) { + actor.properties[key] = properties[key]; + } + } + } + function boxEnd() { + state.records.currentBox = void 0; + } + const addDetails = function(actorId, text2) { + const actor = getActor(actorId); + const elem = document.getElementById(text2.text); + try { + const text3 = elem.innerHTML; + const details = JSON.parse(text3); + if (details["properties"]) { + insertProperties(actor, details["properties"]); + } + if (details["links"]) { + insertLinks(actor, details["links"]); + } + } catch (e) { + log$1.error("error while parsing actor details text", e); + } + }; + const getActorProperty = function(actor, key) { + if (actor !== void 0 && actor.properties !== void 0) { + return actor.properties[key]; + } + return void 0; + }; + const apply = function(param) { + if (Array.isArray(param)) { + param.forEach(function(item) { + apply(item); + }); + } else { + switch (param.type) { + case "sequenceIndex": + state.records.messages.push({ + from: void 0, + to: void 0, + message: { + start: param.sequenceIndex, + step: param.sequenceIndexStep, + visible: param.sequenceVisible + }, + wrap: false, + type: param.signalType + }); + break; + case "addParticipant": + addActor(param.actor, param.actor, param.description, param.draw); + break; + case "createParticipant": + if (state.records.actors[param.actor]) { + throw new Error( + "It is not possible to have actors with the same id, even if one is destroyed before the next is created. Use 'AS' aliases to simulate the behavior" + ); + } + state.records.lastCreated = param.actor; + addActor(param.actor, param.actor, param.description, param.draw); + state.records.createdActors[param.actor] = state.records.messages.length; + break; + case "destroyParticipant": + state.records.lastDestroyed = param.actor; + state.records.destroyedActors[param.actor] = state.records.messages.length; + break; + case "activeStart": + addSignal(param.actor, void 0, void 0, param.signalType); + break; + case "activeEnd": + addSignal(param.actor, void 0, void 0, param.signalType); + break; + case "addNote": + addNote$1(param.actor, param.placement, param.text); + break; + case "addLinks": + addLinks(param.actor, param.text); + break; + case "addALink": + addALink(param.actor, param.text); + break; + case "addProperties": + addProperties(param.actor, param.text); + break; + case "addDetails": + addDetails(param.actor, param.text); + break; + case "addMessage": + if (state.records.lastCreated) { + if (param.to !== state.records.lastCreated) { + throw new Error( + "The created participant " + state.records.lastCreated + " does not have an associated creating message after its declaration. Please check the sequence diagram." + ); + } else { + state.records.lastCreated = void 0; + } + } else if (state.records.lastDestroyed) { + if (param.to !== state.records.lastDestroyed && param.from !== state.records.lastDestroyed) { + throw new Error( + "The destroyed participant " + state.records.lastDestroyed + " does not have an associated destroying message after its declaration. Please check the sequence diagram." + ); + } else { + state.records.lastDestroyed = void 0; + } + } + addSignal(param.from, param.to, param.msg, param.signalType, param.activate); + break; + case "boxStart": + addBox(param.boxData); + break; + case "boxEnd": + boxEnd(); + break; + case "loopStart": + addSignal(void 0, void 0, param.loopText, param.signalType); + break; + case "loopEnd": + addSignal(void 0, void 0, void 0, param.signalType); + break; + case "rectStart": + addSignal(void 0, void 0, param.color, param.signalType); + break; + case "rectEnd": + addSignal(void 0, void 0, void 0, param.signalType); + break; + case "optStart": + addSignal(void 0, void 0, param.optText, param.signalType); + break; + case "optEnd": + addSignal(void 0, void 0, void 0, param.signalType); + break; + case "altStart": + addSignal(void 0, void 0, param.altText, param.signalType); + break; + case "else": + addSignal(void 0, void 0, param.altText, param.signalType); + break; + case "altEnd": + addSignal(void 0, void 0, void 0, param.signalType); + break; + case "setAccTitle": + setAccTitle(param.text); + break; + case "parStart": + addSignal(void 0, void 0, param.parText, param.signalType); + break; + case "and": + addSignal(void 0, void 0, param.parText, param.signalType); + break; + case "parEnd": + addSignal(void 0, void 0, void 0, param.signalType); + break; + case "criticalStart": + addSignal(void 0, void 0, param.criticalText, param.signalType); + break; + case "option": + addSignal(void 0, void 0, param.optionText, param.signalType); + break; + case "criticalEnd": + addSignal(void 0, void 0, void 0, param.signalType); + break; + case "breakStart": + addSignal(void 0, void 0, param.breakText, param.signalType); + break; + case "breakEnd": + addSignal(void 0, void 0, void 0, param.signalType); + break; + } + } + }; + const db$9 = { + addActor, + addMessage, + addSignal, + addLinks, + addDetails, + addProperties, + autoWrap, + setWrap, + enableSequenceNumbers, + disableSequenceNumbers, + showSequenceNumbers, + getMessages, + getActors: getActors$1, + getCreatedActors, + getDestroyedActors, + getActor, + getActorKeys, + getActorProperty, + getAccTitle, + getBoxes, + getDiagramTitle, + setDiagramTitle, + getConfig: () => getConfig$1().sequence, + clear: clear$7, + parseMessage, + parseBoxData, + LINETYPE, + ARROWTYPE, + PLACEMENT, + addNote: addNote$1, + setAccTitle, + apply, + setAccDescription, + getAccDescription, + hasAtLeastOneBox, + hasAtLeastOneBoxWithTitle + }; + const getStyles$7 = (options2) => `.actor { + stroke: ${options2.actorBorder}; + fill: ${options2.actorBkg}; + } + + text.actor > tspan { + fill: ${options2.actorTextColor}; + stroke: none; + } + + .actor-line { + stroke: ${options2.actorLineColor}; + } + + .messageLine0 { + stroke-width: 1.5; + stroke-dasharray: none; + stroke: ${options2.signalColor}; + } + + .messageLine1 { + stroke-width: 1.5; + stroke-dasharray: 2, 2; + stroke: ${options2.signalColor}; + } + + #arrowhead path { + fill: ${options2.signalColor}; + stroke: ${options2.signalColor}; + } + + .sequenceNumber { + fill: ${options2.sequenceNumberColor}; + } + + #sequencenumber { + fill: ${options2.signalColor}; + } + + #crosshead path { + fill: ${options2.signalColor}; + stroke: ${options2.signalColor}; + } + + .messageText { + fill: ${options2.signalTextColor}; + stroke: none; + } + + .labelBox { + stroke: ${options2.labelBoxBorderColor}; + fill: ${options2.labelBoxBkgColor}; + } + + .labelText, .labelText > tspan { + fill: ${options2.labelTextColor}; + stroke: none; + } + + .loopText, .loopText > tspan { + fill: ${options2.loopTextColor}; + stroke: none; + } + + .loopLine { + stroke-width: 2px; + stroke-dasharray: 2, 2; + stroke: ${options2.labelBoxBorderColor}; + fill: ${options2.labelBoxBorderColor}; + } + + .note { + //stroke: #decc93; + stroke: ${options2.noteBorderColor}; + fill: ${options2.noteBkgColor}; + } + + .noteText, .noteText > tspan { + fill: ${options2.noteTextColor}; + stroke: none; + } + + .activation0 { + fill: ${options2.activationBkgColor}; + stroke: ${options2.activationBorderColor}; + } + + .activation1 { + fill: ${options2.activationBkgColor}; + stroke: ${options2.activationBorderColor}; + } + + .activation2 { + fill: ${options2.activationBkgColor}; + stroke: ${options2.activationBorderColor}; + } + + .actorPopupMenu { + position: absolute; + } + + .actorPopupMenuPanel { + position: absolute; + fill: ${options2.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: ${options2.actorBorder}; + fill: ${options2.actorBkg}; + } + .actor-man circle, line { + stroke: ${options2.actorBorder}; + fill: ${options2.actorBkg}; + stroke-width: 2px; + } +`; + const styles$6 = getStyles$7; + const ACTOR_TYPE_WIDTH = 18 * 2; + const TOP_ACTOR_CLASS = "actor-top"; + const BOTTOM_ACTOR_CLASS = "actor-bottom"; + const drawRect$2 = function(elem, rectData) { + return drawRect$4(elem, rectData); + }; + const drawPopup = function(elem, actor, minMenuWidth, textAttrs, forceMenus) { + if (actor.links === void 0 || actor.links === null || Object.keys(actor.links).length === 0) { + return { height: 0, width: 0 }; + } + const links2 = actor.links; + const actorCnt2 = actor.actorCnt; + const rectData = actor.rectData; + var displayValue = "none"; + if (forceMenus) { + displayValue = "block !important"; + } + const g = elem.append("g"); + g.attr("id", "actor" + actorCnt2 + "_popup"); + g.attr("class", "actorPopupMenu"); + g.attr("display", displayValue); + var actorClass = ""; + if (rectData.class !== void 0) { + actorClass = " " + rectData.class; + } + let menuWidth = rectData.width > minMenuWidth ? rectData.width : minMenuWidth; + const rectElem = g.append("rect"); + rectElem.attr("class", "actorPopupMenuPanel" + actorClass); + rectElem.attr("x", rectData.x); + rectElem.attr("y", rectData.height); + rectElem.attr("fill", rectData.fill); + rectElem.attr("stroke", rectData.stroke); + rectElem.attr("width", menuWidth); + rectElem.attr("height", rectData.height); + rectElem.attr("rx", rectData.rx); + rectElem.attr("ry", rectData.ry); + if (links2 != null) { + var linkY = 20; + for (let key in links2) { + var linkElem = g.append("a"); + var sanitizedLink = dist.sanitizeUrl(links2[key]); + linkElem.attr("xlink:href", sanitizedLink); + linkElem.attr("target", "_blank"); + _drawMenuItemTextCandidateFunc(textAttrs)( + key, + linkElem, + rectData.x + 10, + rectData.height + linkY, + menuWidth, + 20, + { class: "actor" }, + textAttrs + ); + linkY += 30; + } + } + rectElem.attr("height", linkY); + return { height: rectData.height + linkY, width: menuWidth }; + }; + const popupMenuToggle = function(popId) { + return "var pu = document.getElementById('" + popId + "'); if (pu != null) { pu.style.display = pu.style.display == 'block' ? 'none' : 'block'; }"; + }; + const drawKatex = async function(elem, textData, msgModel = null) { + let textElem = elem.append("foreignObject"); + const lines = await renderKatex(textData.text, getConfig$2()); + const divElem = textElem.append("xhtml:div").attr("style", "width: fit-content;").attr("xmlns", "http://www.w3.org/1999/xhtml").html(lines); + const dim = divElem.node().getBoundingClientRect(); + textElem.attr("height", Math.round(dim.height)).attr("width", Math.round(dim.width)); + if (textData.class === "noteText") { + const rectElem = elem.node().firstChild; + rectElem.setAttribute("height", dim.height + 2 * textData.textMargin); + const rectDim = rectElem.getBBox(); + textElem.attr("x", Math.round(rectDim.x + rectDim.width / 2 - dim.width / 2)).attr("y", Math.round(rectDim.y + rectDim.height / 2 - dim.height / 2)); + } else if (msgModel) { + let { startx, stopx, starty } = msgModel; + if (startx > stopx) { + const temp = startx; + startx = stopx; + stopx = temp; + } + textElem.attr("x", Math.round(startx + Math.abs(startx - stopx) / 2 - dim.width / 2)); + if (textData.class === "loopText") { + textElem.attr("y", Math.round(starty)); + } else { + textElem.attr("y", Math.round(starty - dim.height)); + } + } + return [textElem]; + }; + const drawText$2 = function(elem, textData) { + let prevTextHeight = 0; + let textHeight = 0; + const lines = textData.text.split(common$1.lineBreakRegex); + const [_textFontSize, _textFontSizePx] = parseFontSize(textData.fontSize); + let textElems = []; + let dy = 0; + let yfunc = () => textData.y; + if (textData.valign !== void 0 && textData.textMargin !== void 0 && textData.textMargin > 0) { + switch (textData.valign) { + case "top": + case "start": + yfunc = () => Math.round(textData.y + textData.textMargin); + break; + case "middle": + case "center": + yfunc = () => Math.round(textData.y + (prevTextHeight + textHeight + textData.textMargin) / 2); + break; + case "bottom": + case "end": + yfunc = () => Math.round( + textData.y + (prevTextHeight + textHeight + 2 * textData.textMargin) - textData.textMargin + ); + break; + } + } + if (textData.anchor !== void 0 && textData.textMargin !== void 0 && textData.width !== void 0) { + switch (textData.anchor) { + case "left": + case "start": + textData.x = Math.round(textData.x + textData.textMargin); + textData.anchor = "start"; + textData.dominantBaseline = "middle"; + textData.alignmentBaseline = "middle"; + break; + case "middle": + case "center": + textData.x = Math.round(textData.x + textData.width / 2); + textData.anchor = "middle"; + textData.dominantBaseline = "middle"; + textData.alignmentBaseline = "middle"; + break; + case "right": + case "end": + textData.x = Math.round(textData.x + textData.width - textData.textMargin); + textData.anchor = "end"; + textData.dominantBaseline = "middle"; + textData.alignmentBaseline = "middle"; + break; + } + } + for (let [i2, line2] of lines.entries()) { + if (textData.textMargin !== void 0 && textData.textMargin === 0 && _textFontSize !== void 0) { + dy = i2 * _textFontSize; + } + const textElem = elem.append("text"); + textElem.attr("x", textData.x); + textElem.attr("y", yfunc()); + if (textData.anchor !== void 0) { + textElem.attr("text-anchor", textData.anchor).attr("dominant-baseline", textData.dominantBaseline).attr("alignment-baseline", textData.alignmentBaseline); + } + if (textData.fontFamily !== void 0) { + textElem.style("font-family", textData.fontFamily); + } + if (_textFontSizePx !== void 0) { + textElem.style("font-size", _textFontSizePx); + } + if (textData.fontWeight !== void 0) { + textElem.style("font-weight", textData.fontWeight); + } + if (textData.fill !== void 0) { + textElem.attr("fill", textData.fill); + } + if (textData.class !== void 0) { + textElem.attr("class", textData.class); + } + if (textData.dy !== void 0) { + textElem.attr("dy", textData.dy); + } else if (dy !== 0) { + textElem.attr("dy", dy); + } + const text2 = line2 || ZERO_WIDTH_SPACE; + if (textData.tspan) { + const span = textElem.append("tspan"); + span.attr("x", textData.x); + if (textData.fill !== void 0) { + span.attr("fill", textData.fill); + } + span.text(text2); + } else { + textElem.text(text2); + } + if (textData.valign !== void 0 && textData.textMargin !== void 0 && textData.textMargin > 0) { + textHeight += (textElem._groups || textElem)[0][0].getBBox().height; + prevTextHeight = textHeight; + } + textElems.push(textElem); + } + return textElems; + }; + const drawLabel$2 = function(elem, txtObject) { + function genPoints(x2, y2, width2, height, cut) { + return x2 + "," + y2 + " " + (x2 + width2) + "," + y2 + " " + (x2 + width2) + "," + (y2 + height - cut) + " " + (x2 + width2 - cut * 1.2) + "," + (y2 + height) + " " + x2 + "," + (y2 + height); + } + const polygon = elem.append("polygon"); + polygon.attr("points", genPoints(txtObject.x, txtObject.y, txtObject.width, txtObject.height, 7)); + polygon.attr("class", "labelBox"); + txtObject.y = txtObject.y + txtObject.height / 2; + drawText$2(elem, txtObject); + return polygon; + }; + let actorCnt = -1; + const fixLifeLineHeights = (diagram2, actors2, actorKeys, conf2) => { + if (!diagram2.select) { + return; + } + actorKeys.forEach((actorKey) => { + const actor = actors2[actorKey]; + const actorDOM = diagram2.select("#actor" + actor.actorCnt); + if (!conf2.mirrorActors && actor.stopy) { + actorDOM.attr("y2", actor.stopy + actor.height / 2); + } else if (conf2.mirrorActors) { + actorDOM.attr("y2", actor.stopy); + } + }); + }; + const drawActorTypeParticipant = async function(elem, actor, conf2, isFooter) { + const actorY = isFooter ? actor.stopy : actor.starty; + const center2 = actor.x + actor.width / 2; + const centerY = actorY + 5; + const boxplusLineGroup = elem.append("g").lower(); + var g = boxplusLineGroup; + if (!isFooter) { + actorCnt++; + if (Object.keys(actor.links || {}).length && !conf2.forceMenus) { + g.attr("onclick", popupMenuToggle(`actor${actorCnt}_popup`)).attr("cursor", "pointer"); + } + g.append("line").attr("id", "actor" + actorCnt).attr("x1", center2).attr("y1", centerY).attr("x2", center2).attr("y2", 2e3).attr("class", "actor-line").attr("class", "200").attr("stroke-width", "0.5px").attr("stroke", "#999"); + g = boxplusLineGroup.append("g"); + actor.actorCnt = actorCnt; + if (actor.links != null) { + g.attr("id", "root-" + actorCnt); + } + } + const rect2 = getNoteRect$2(); + var cssclass = "actor"; + if (actor.properties != null && actor.properties["class"]) { + cssclass = actor.properties["class"]; + } else { + rect2.fill = "#eaeaea"; + } + if (isFooter) { + cssclass += ` ${BOTTOM_ACTOR_CLASS}`; + } else { + cssclass += ` ${TOP_ACTOR_CLASS}`; + } + rect2.x = actor.x; + rect2.y = actorY; + rect2.width = actor.width; + rect2.height = actor.height; + rect2.class = cssclass; + rect2.rx = 3; + rect2.ry = 3; + rect2.name = actor.name; + const rectElem = drawRect$2(g, rect2); + actor.rectData = rect2; + if (actor.properties != null && actor.properties["icon"]) { + const iconSrc = actor.properties["icon"].trim(); + if (iconSrc.charAt(0) === "@") { + drawEmbeddedImage(g, rect2.x + rect2.width - 20, rect2.y + 10, iconSrc.substr(1)); + } else { + drawImage$1(g, rect2.x + rect2.width - 20, rect2.y + 10, iconSrc); + } + } + await _drawTextCandidateFunc$2(conf2, hasKatex(actor.description))( + actor.description, + g, + rect2.x, + rect2.y, + rect2.width, + rect2.height, + { class: "actor" }, + conf2 + ); + let height = actor.height; + if (rectElem.node) { + const bounds2 = rectElem.node().getBBox(); + actor.height = bounds2.height; + height = bounds2.height; + } + return height; + }; + const drawActorTypeActor = async function(elem, actor, conf2, isFooter) { + const actorY = isFooter ? actor.stopy : actor.starty; + const center2 = actor.x + actor.width / 2; + const centerY = actorY + 80; + elem.lower(); + if (!isFooter) { + actorCnt++; + elem.append("line").attr("id", "actor" + actorCnt).attr("x1", center2).attr("y1", centerY).attr("x2", center2).attr("y2", 2e3).attr("class", "actor-line").attr("class", "200").attr("stroke-width", "0.5px").attr("stroke", "#999"); + actor.actorCnt = actorCnt; + } + const actElem = elem.append("g"); + let cssClass = "actor-man"; + if (isFooter) { + cssClass += ` ${BOTTOM_ACTOR_CLASS}`; + } else { + cssClass += ` ${TOP_ACTOR_CLASS}`; + } + actElem.attr("class", cssClass); + actElem.attr("name", actor.name); + const rect2 = getNoteRect$2(); + rect2.x = actor.x; + rect2.y = actorY; + rect2.fill = "#eaeaea"; + rect2.width = actor.width; + rect2.height = actor.height; + rect2.class = "actor"; + rect2.rx = 3; + rect2.ry = 3; + actElem.append("line").attr("id", "actor-man-torso" + actorCnt).attr("x1", center2).attr("y1", actorY + 25).attr("x2", center2).attr("y2", actorY + 45); + actElem.append("line").attr("id", "actor-man-arms" + actorCnt).attr("x1", center2 - ACTOR_TYPE_WIDTH / 2).attr("y1", actorY + 33).attr("x2", center2 + ACTOR_TYPE_WIDTH / 2).attr("y2", actorY + 33); + actElem.append("line").attr("x1", center2 - ACTOR_TYPE_WIDTH / 2).attr("y1", actorY + 60).attr("x2", center2).attr("y2", actorY + 45); + actElem.append("line").attr("x1", center2).attr("y1", actorY + 45).attr("x2", center2 + ACTOR_TYPE_WIDTH / 2 - 2).attr("y2", actorY + 60); + const circle2 = actElem.append("circle"); + circle2.attr("cx", actor.x + actor.width / 2); + circle2.attr("cy", actorY + 10); + circle2.attr("r", 15); + circle2.attr("width", actor.width); + circle2.attr("height", actor.height); + const bounds2 = actElem.node().getBBox(); + actor.height = bounds2.height; + await _drawTextCandidateFunc$2(conf2, hasKatex(actor.description))( + actor.description, + actElem, + rect2.x, + rect2.y + 35, + rect2.width, + rect2.height, + { class: "actor" }, + conf2 + ); + return actor.height; + }; + const drawActor = async function(elem, actor, conf2, isFooter) { + switch (actor.type) { + case "actor": + return await drawActorTypeActor(elem, actor, conf2, isFooter); + case "participant": + return await drawActorTypeParticipant(elem, actor, conf2, isFooter); + } + }; + const drawBox = async function(elem, box, conf2) { + const boxplusTextGroup = elem.append("g"); + const g = boxplusTextGroup; + drawBackgroundRect$2(g, box); + if (box.name) { + await _drawTextCandidateFunc$2(conf2)( + box.name, + g, + box.x, + box.y + (box.textMaxHeight || 0) / 2, + box.width, + 0, + { class: "text" }, + conf2 + ); + } + g.lower(); + }; + const anchorElement = function(elem) { + return elem.append("g"); + }; + const drawActivation = function(elem, bounds2, verticalPos, conf2, actorActivations2) { + const rect2 = getNoteRect$2(); + const g = bounds2.anchored; + rect2.x = bounds2.startx; + rect2.y = bounds2.starty; + rect2.class = "activation" + actorActivations2 % 3; + rect2.width = bounds2.stopx - bounds2.startx; + rect2.height = verticalPos - bounds2.starty; + drawRect$2(g, rect2); + }; + const drawLoop = async function(elem, loopModel, labelText, conf2) { + const { + boxMargin, + boxTextMargin, + labelBoxHeight, + labelBoxWidth, + messageFontFamily: fontFamily, + messageFontSize: fontSize, + messageFontWeight: fontWeight + } = conf2; + const g = elem.append("g"); + const drawLoopLine = function(startx, starty, stopx, stopy) { + return g.append("line").attr("x1", startx).attr("y1", starty).attr("x2", stopx).attr("y2", stopy).attr("class", "loopLine"); + }; + drawLoopLine(loopModel.startx, loopModel.starty, loopModel.stopx, loopModel.starty); + drawLoopLine(loopModel.stopx, loopModel.starty, loopModel.stopx, loopModel.stopy); + drawLoopLine(loopModel.startx, loopModel.stopy, loopModel.stopx, loopModel.stopy); + drawLoopLine(loopModel.startx, loopModel.starty, loopModel.startx, loopModel.stopy); + if (loopModel.sections !== void 0) { + loopModel.sections.forEach(function(item) { + drawLoopLine(loopModel.startx, item.y, loopModel.stopx, item.y).style( + "stroke-dasharray", + "3, 3" + ); + }); + } + let txt = getTextObj$2(); + txt.text = labelText; + txt.x = loopModel.startx; + txt.y = loopModel.starty; + txt.fontFamily = fontFamily; + txt.fontSize = fontSize; + txt.fontWeight = fontWeight; + txt.anchor = "middle"; + txt.valign = "middle"; + txt.tspan = false; + txt.width = labelBoxWidth || 50; + txt.height = labelBoxHeight || 20; + txt.textMargin = boxTextMargin; + txt.class = "labelText"; + drawLabel$2(g, txt); + txt = getTextObj$1(); + txt.text = loopModel.title; + txt.x = loopModel.startx + labelBoxWidth / 2 + (loopModel.stopx - loopModel.startx) / 2; + txt.y = loopModel.starty + boxMargin + boxTextMargin; + txt.anchor = "middle"; + txt.valign = "middle"; + txt.textMargin = boxTextMargin; + txt.class = "loopText"; + txt.fontFamily = fontFamily; + txt.fontSize = fontSize; + txt.fontWeight = fontWeight; + txt.wrap = true; + let textElem = hasKatex(txt.text) ? await drawKatex(g, txt, loopModel) : drawText$2(g, txt); + if (loopModel.sectionTitles !== void 0) { + for (const [idx, item] of Object.entries(loopModel.sectionTitles)) { + if (item.message) { + txt.text = item.message; + txt.x = loopModel.startx + (loopModel.stopx - loopModel.startx) / 2; + txt.y = loopModel.sections[idx].y + boxMargin + boxTextMargin; + txt.class = "loopText"; + txt.anchor = "middle"; + txt.valign = "middle"; + txt.tspan = false; + txt.fontFamily = fontFamily; + txt.fontSize = fontSize; + txt.fontWeight = fontWeight; + txt.wrap = loopModel.wrap; + if (hasKatex(txt.text)) { + loopModel.starty = loopModel.sections[idx].y; + await drawKatex(g, txt, loopModel); + } else { + drawText$2(g, txt); + } + let sectionHeight = Math.round( + textElem.map((te) => (te._groups || te)[0][0].getBBox().height).reduce((acc, curr) => acc + curr) + ); + loopModel.sections[idx].height += sectionHeight - (boxMargin + boxTextMargin); + } + } + } + loopModel.height = Math.round(loopModel.stopy - loopModel.starty); + return g; + }; + const drawBackgroundRect$2 = function(elem, bounds2) { + drawBackgroundRect$3(elem, bounds2); + }; + const insertDatabaseIcon = function(elem) { + elem.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-.047.148-.048.143-.049.139-.049.136-.05.131-.05.126-.05.123-.051.118-.052.114-.051.11-.052.106-.052.101-.052.096-.052.092-.052.088-.053.083-.051.079-.052.074-.052.07-.051.065-.051.06-.051.056-.05.051-.05.023-.024.023-.025.021-.024.02-.024.019-.024.018-.024.017-.024.015-.023.014-.024.013-.023.012-.023.01-.023.01-.022.008-.022.006-.022.006-.022.004-.022.004-.021.001-.021.001-.021v-4.127l-.077.055-.08.053-.083.054-.085.053-.087.052-.09.052-.093.051-.095.05-.097.05-.1.049-.102.049-.105.048-.106.047-.109.047-.111.046-.114.045-.115.045-.118.044-.12.043-.122.042-.124.042-.126.041-.128.04-.13.04-.132.038-.134.038-.135.037-.138.037-.139.035-.142.035-.143.034-.144.033-.147.032-.148.031-.15.03-.151.03-.153.029-.154.027-.156.027-.158.026-.159.025-.161.024-.162.023-.163.022-.165.021-.166.02-.167.019-.169.018-.169.017-.171.016-.173.015-.173.014-.175.013-.175.012-.177.011-.178.01-.179.008-.179.008-.181.006-.182.005-.182.004-.184.003-.184.002h-.37l-.184-.002-.184-.003-.182-.004-.182-.005-.181-.006-.179-.008-.179-.008-.178-.01-.176-.011-.176-.012-.175-.013-.173-.014-.172-.015-.171-.016-.17-.017-.169-.018-.167-.019-.166-.02-.165-.021-.163-.022-.162-.023-.161-.024-.159-.025-.157-.026-.156-.027-.155-.027-.153-.029-.151-.03-.15-.03-.148-.031-.146-.032-.145-.033-.143-.034-.141-.035-.14-.035-.137-.037-.136-.037-.134-.038-.132-.038-.13-.04-.128-.04-.126-.041-.124-.042-.122-.042-.12-.044-.117-.043-.116-.045-.113-.045-.112-.046-.109-.047-.106-.047-.105-.048-.102-.049-.1-.049-.097-.05-.095-.05-.093-.052-.09-.051-.087-.052-.085-.053-.083-.054-.08-.054-.077-.054v4.127zm0-5.654v.011l.001.021.003.021.004.021.005.022.006.022.007.022.009.022.01.022.011.023.012.023.013.023.015.024.016.023.017.024.018.024.019.024.021.024.022.024.023.025.024.024.052.05.056.05.061.05.066.051.07.051.075.052.079.051.084.052.088.052.092.052.097.052.102.052.105.052.11.051.114.051.119.052.123.05.127.051.131.05.135.049.139.049.144.048.147.048.152.047.155.046.16.045.163.045.167.044.171.042.176.042.178.04.183.04.187.038.19.037.194.036.197.034.202.033.204.032.209.03.212.028.216.027.219.025.222.024.226.022.23.02.233.018.236.016.24.014.243.012.246.01.249.008.253.006.256.003.259.001.26-.001.257-.003.254-.006.25-.008.247-.01.244-.012.241-.015.237-.016.233-.018.231-.02.226-.022.224-.024.22-.025.216-.027.212-.029.21-.03.205-.032.202-.033.198-.035.194-.036.191-.037.187-.039.183-.039.179-.041.175-.042.172-.043.168-.044.163-.045.16-.045.155-.047.152-.047.148-.048.143-.048.139-.05.136-.049.131-.05.126-.051.123-.051.118-.051.114-.052.11-.052.106-.052.101-.052.096-.052.092-.052.088-.052.083-.052.079-.052.074-.051.07-.052.065-.051.06-.05.056-.051.051-.049.023-.025.023-.024.021-.025.02-.024.019-.024.018-.024.017-.024.015-.023.014-.023.013-.024.012-.022.01-.023.01-.023.008-.022.006-.022.006-.022.004-.021.004-.022.001-.021.001-.021v-4.139l-.077.054-.08.054-.083.054-.085.052-.087.053-.09.051-.093.051-.095.051-.097.05-.1.049-.102.049-.105.048-.106.047-.109.047-.111.046-.114.045-.115.044-.118.044-.12.044-.122.042-.124.042-.126.041-.128.04-.13.039-.132.039-.134.038-.135.037-.138.036-.139.036-.142.035-.143.033-.144.033-.147.033-.148.031-.15.03-.151.03-.153.028-.154.028-.156.027-.158.026-.159.025-.161.024-.162.023-.163.022-.165.021-.166.02-.167.019-.169.018-.169.017-.171.016-.173.015-.173.014-.175.013-.175.012-.177.011-.178.009-.179.009-.179.007-.181.007-.182.005-.182.004-.184.003-.184.002h-.37l-.184-.002-.184-.003-.182-.004-.182-.005-.181-.007-.179-.007-.179-.009-.178-.009-.176-.011-.176-.012-.175-.013-.173-.014-.172-.015-.171-.016-.17-.017-.169-.018-.167-.019-.166-.02-.165-.021-.163-.022-.162-.023-.161-.024-.159-.025-.157-.026-.156-.027-.155-.028-.153-.028-.151-.03-.15-.03-.148-.031-.146-.033-.145-.033-.143-.033-.141-.035-.14-.036-.137-.036-.136-.037-.134-.038-.132-.039-.13-.039-.128-.04-.126-.041-.124-.042-.122-.043-.12-.043-.117-.044-.116-.044-.113-.046-.112-.046-.109-.046-.106-.047-.105-.048-.102-.049-.1-.049-.097-.05-.095-.051-.093-.051-.09-.051-.087-.053-.085-.052-.083-.054-.08-.054-.077-.054v4.139zm0-5.666v.011l.001.02.003.022.004.021.005.022.006.021.007.022.009.023.01.022.011.023.012.023.013.023.015.023.016.024.017.024.018.023.019.024.021.025.022.024.023.024.024.025.052.05.056.05.061.05.066.051.07.051.075.052.079.051.084.052.088.052.092.052.097.052.102.052.105.051.11.052.114.051.119.051.123.051.127.05.131.05.135.05.139.049.144.048.147.048.152.047.155.046.16.045.163.045.167.043.171.043.176.042.178.04.183.04.187.038.19.037.194.036.197.034.202.033.204.032.209.03.212.028.216.027.219.025.222.024.226.021.23.02.233.018.236.017.24.014.243.012.246.01.249.008.253.006.256.003.259.001.26-.001.257-.003.254-.006.25-.008.247-.01.244-.013.241-.014.237-.016.233-.018.231-.02.226-.022.224-.024.22-.025.216-.027.212-.029.21-.03.205-.032.202-.033.198-.035.194-.036.191-.037.187-.039.183-.039.179-.041.175-.042.172-.043.168-.044.163-.045.16-.045.155-.047.152-.047.148-.048.143-.049.139-.049.136-.049.131-.051.126-.05.123-.051.118-.052.114-.051.11-.052.106-.052.101-.052.096-.052.092-.052.088-.052.083-.052.079-.052.074-.052.07-.051.065-.051.06-.051.056-.05.051-.049.023-.025.023-.025.021-.024.02-.024.019-.024.018-.024.017-.024.015-.023.014-.024.013-.023.012-.023.01-.022.01-.023.008-.022.006-.022.006-.022.004-.022.004-.021.001-.021.001-.021v-4.153l-.077.054-.08.054-.083.053-.085.053-.087.053-.09.051-.093.051-.095.051-.097.05-.1.049-.102.048-.105.048-.106.048-.109.046-.111.046-.114.046-.115.044-.118.044-.12.043-.122.043-.124.042-.126.041-.128.04-.13.039-.132.039-.134.038-.135.037-.138.036-.139.036-.142.034-.143.034-.144.033-.147.032-.148.032-.15.03-.151.03-.153.028-.154.028-.156.027-.158.026-.159.024-.161.024-.162.023-.163.023-.165.021-.166.02-.167.019-.169.018-.169.017-.171.016-.173.015-.173.014-.175.013-.175.012-.177.01-.178.01-.179.009-.179.007-.181.006-.182.006-.182.004-.184.003-.184.001-.185.001-.185-.001-.184-.001-.184-.003-.182-.004-.182-.006-.181-.006-.179-.007-.179-.009-.178-.01-.176-.01-.176-.012-.175-.013-.173-.014-.172-.015-.171-.016-.17-.017-.169-.018-.167-.019-.166-.02-.165-.021-.163-.023-.162-.023-.161-.024-.159-.024-.157-.026-.156-.027-.155-.028-.153-.028-.151-.03-.15-.03-.148-.032-.146-.032-.145-.033-.143-.034-.141-.034-.14-.036-.137-.036-.136-.037-.134-.038-.132-.039-.13-.039-.128-.041-.126-.041-.124-.041-.122-.043-.12-.043-.117-.044-.116-.044-.113-.046-.112-.046-.109-.046-.106-.048-.105-.048-.102-.048-.1-.05-.097-.049-.095-.051-.093-.051-.09-.052-.087-.052-.085-.053-.083-.053-.08-.054-.077-.054v4.153zm8.74-8.179l-.257.004-.254.005-.25.008-.247.011-.244.012-.241.014-.237.016-.233.018-.231.021-.226.022-.224.023-.22.026-.216.027-.212.028-.21.031-.205.032-.202.033-.198.034-.194.036-.191.038-.187.038-.183.04-.179.041-.175.042-.172.043-.168.043-.163.045-.16.046-.155.046-.152.048-.148.048-.143.048-.139.049-.136.05-.131.05-.126.051-.123.051-.118.051-.114.052-.11.052-.106.052-.101.052-.096.052-.092.052-.088.052-.083.052-.079.052-.074.051-.07.052-.065.051-.06.05-.056.05-.051.05-.023.025-.023.024-.021.024-.02.025-.019.024-.018.024-.017.023-.015.024-.014.023-.013.023-.012.023-.01.023-.01.022-.008.022-.006.023-.006.021-.004.022-.004.021-.001.021-.001.021.001.021.001.021.004.021.004.022.006.021.006.023.008.022.01.022.01.023.012.023.013.023.014.023.015.024.017.023.018.024.019.024.02.025.021.024.023.024.023.025.051.05.056.05.06.05.065.051.07.052.074.051.079.052.083.052.088.052.092.052.096.052.101.052.106.052.11.052.114.052.118.051.123.051.126.051.131.05.136.05.139.049.143.048.148.048.152.048.155.046.16.046.163.045.168.043.172.043.175.042.179.041.183.04.187.038.191.038.194.036.198.034.202.033.205.032.21.031.212.028.216.027.22.026.224.023.226.022.231.021.233.018.237.016.241.014.244.012.247.011.25.008.254.005.257.004.26.001.26-.001.257-.004.254-.005.25-.008.247-.011.244-.012.241-.014.237-.016.233-.018.231-.021.226-.022.224-.023.22-.026.216-.027.212-.028.21-.031.205-.032.202-.033.198-.034.194-.036.191-.038.187-.038.183-.04.179-.041.175-.042.172-.043.168-.043.163-.045.16-.046.155-.046.152-.048.148-.048.143-.048.139-.049.136-.05.131-.05.126-.051.123-.051.118-.051.114-.052.11-.052.106-.052.101-.052.096-.052.092-.052.088-.052.083-.052.079-.052.074-.051.07-.052.065-.051.06-.05.056-.05.051-.05.023-.025.023-.024.021-.024.02-.025.019-.024.018-.024.017-.023.015-.024.014-.023.013-.023.012-.023.01-.023.01-.022.008-.022.006-.023.006-.021.004-.022.004-.021.001-.021.001-.021-.001-.021-.001-.021-.004-.021-.004-.022-.006-.021-.006-.023-.008-.022-.01-.022-.01-.023-.012-.023-.013-.023-.014-.023-.015-.024-.017-.023-.018-.024-.019-.024-.02-.025-.021-.024-.023-.024-.023-.025-.051-.05-.056-.05-.06-.05-.065-.051-.07-.052-.074-.051-.079-.052-.083-.052-.088-.052-.092-.052-.096-.052-.101-.052-.106-.052-.11-.052-.114-.052-.118-.051-.123-.051-.126-.051-.131-.05-.136-.05-.139-.049-.143-.048-.148-.048-.152-.048-.155-.046-.16-.046-.163-.045-.168-.043-.172-.043-.175-.042-.179-.041-.183-.04-.187-.038-.191-.038-.194-.036-.198-.034-.202-.033-.205-.032-.21-.031-.212-.028-.216-.027-.22-.026-.224-.023-.226-.022-.231-.021-.233-.018-.237-.016-.241-.014-.244-.012-.247-.011-.25-.008-.254-.005-.257-.004-.26-.001-.26.001z" + ); + }; + const insertComputerIcon = function(elem) { + elem.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" + ); + }; + const insertClockIcon = function(elem) { + elem.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" + ); + }; + const insertArrowHead = function(elem) { + elem.append("defs").append("marker").attr("id", "arrowhead").attr("refX", 7.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"); + }; + const insertArrowFilledHead = function(elem) { + elem.append("defs").append("marker").attr("id", "filled-head").attr("refX", 15.5).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"); + }; + const insertSequenceNumber = function(elem) { + elem.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); + }; + const insertArrowCrossHead = function(elem) { + const defs = elem.append("defs"); + const marker = defs.append("marker").attr("id", "crosshead").attr("markerWidth", 15).attr("markerHeight", 8).attr("orient", "auto").attr("refX", 4).attr("refY", 4.5); + marker.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"); + }; + const getTextObj$1 = 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: true, + valign: void 0 + }; + }; + const getNoteRect$1 = function() { + return { + x: 0, + y: 0, + fill: "#EDF2AE", + stroke: "#666", + width: 100, + anchor: "start", + height: 100, + rx: 0, + ry: 0 + }; + }; + const _drawTextCandidateFunc$2 = function() { + function byText(content2, g, x2, y2, width2, height, textAttrs) { + const text2 = g.append("text").attr("x", x2 + width2 / 2).attr("y", y2 + height / 2 + 5).style("text-anchor", "middle").text(content2); + _setTextAttrs(text2, textAttrs); + } + function byTspan(content2, g, x2, y2, width2, height, textAttrs, conf2) { + const { actorFontSize, actorFontFamily, actorFontWeight } = conf2; + const [_actorFontSize, _actorFontSizePx] = parseFontSize(actorFontSize); + const lines = content2.split(common$1.lineBreakRegex); + for (let i2 = 0; i2 < lines.length; i2++) { + const dy = i2 * _actorFontSize - _actorFontSize * (lines.length - 1) / 2; + const text2 = g.append("text").attr("x", x2 + width2 / 2).attr("y", y2).style("text-anchor", "middle").style("font-size", _actorFontSizePx).style("font-weight", actorFontWeight).style("font-family", actorFontFamily); + text2.append("tspan").attr("x", x2 + width2 / 2).attr("dy", dy).text(lines[i2]); + text2.attr("y", y2 + height / 2).attr("dominant-baseline", "central").attr("alignment-baseline", "central"); + _setTextAttrs(text2, textAttrs); + } + } + function byFo(content2, g, x2, y2, width2, height, textAttrs, conf2) { + const s = g.append("switch"); + const f2 = s.append("foreignObject").attr("x", x2).attr("y", y2).attr("width", width2).attr("height", height); + const text2 = f2.append("xhtml:div").style("display", "table").style("height", "100%").style("width", "100%"); + text2.append("div").style("display", "table-cell").style("text-align", "center").style("vertical-align", "middle").text(content2); + byTspan(content2, s, x2, y2, width2, height, textAttrs, conf2); + _setTextAttrs(text2, textAttrs); + } + async function byKatex(content2, g, x2, y2, width2, height, textAttrs, conf2) { + const dim = await calculateMathMLDimensions(content2, getConfig$2()); + const s = g.append("switch"); + const f2 = s.append("foreignObject").attr("x", x2 + width2 / 2 - dim.width / 2).attr("y", y2 + height / 2 - dim.height / 2).attr("width", dim.width).attr("height", dim.height); + const text2 = f2.append("xhtml:div").style("height", "100%").style("width", "100%"); + text2.append("div").style("text-align", "center").style("vertical-align", "middle").html(await renderKatex(content2, getConfig$2())); + byTspan(content2, s, x2, y2, width2, height, textAttrs, conf2); + _setTextAttrs(text2, textAttrs); + } + function _setTextAttrs(toText, fromTextAttrsDict) { + for (const key in fromTextAttrsDict) { + if (fromTextAttrsDict.hasOwnProperty(key)) { + toText.attr(key, fromTextAttrsDict[key]); + } + } + } + return function(conf2, hasKatex2 = false) { + if (hasKatex2) { + return byKatex; + } + return conf2.textPlacement === "fo" ? byFo : conf2.textPlacement === "old" ? byText : byTspan; + }; + }(); + const _drawMenuItemTextCandidateFunc = function() { + function byText(content2, g, x2, y2, width2, height, textAttrs) { + const text2 = g.append("text").attr("x", x2).attr("y", y2).style("text-anchor", "start").text(content2); + _setTextAttrs(text2, textAttrs); + } + function byTspan(content2, g, x2, y2, width2, height, textAttrs, conf2) { + const { actorFontSize, actorFontFamily, actorFontWeight } = conf2; + const lines = content2.split(common$1.lineBreakRegex); + for (let i2 = 0; i2 < lines.length; i2++) { + const dy = i2 * actorFontSize - actorFontSize * (lines.length - 1) / 2; + const text2 = g.append("text").attr("x", x2).attr("y", y2).style("text-anchor", "start").style("font-size", actorFontSize).style("font-weight", actorFontWeight).style("font-family", actorFontFamily); + text2.append("tspan").attr("x", x2).attr("dy", dy).text(lines[i2]); + text2.attr("y", y2 + height / 2).attr("dominant-baseline", "central").attr("alignment-baseline", "central"); + _setTextAttrs(text2, textAttrs); + } + } + function byFo(content2, g, x2, y2, width2, height, textAttrs, conf2) { + const s = g.append("switch"); + const f2 = s.append("foreignObject").attr("x", x2).attr("y", y2).attr("width", width2).attr("height", height); + const text2 = f2.append("xhtml:div").style("display", "table").style("height", "100%").style("width", "100%"); + text2.append("div").style("display", "table-cell").style("text-align", "center").style("vertical-align", "middle").text(content2); + byTspan(content2, s, x2, y2, width2, height, textAttrs, conf2); + _setTextAttrs(text2, textAttrs); + } + function _setTextAttrs(toText, fromTextAttrsDict) { + for (const key in fromTextAttrsDict) { + if (fromTextAttrsDict.hasOwnProperty(key)) { + toText.attr(key, fromTextAttrsDict[key]); + } + } + } + return function(conf2) { + return conf2.textPlacement === "fo" ? byFo : conf2.textPlacement === "old" ? byText : byTspan; + }; + }(); + const svgDraw$3 = { + drawRect: drawRect$2, + drawText: drawText$2, + drawLabel: drawLabel$2, + drawActor, + drawBox, + drawPopup, + anchorElement, + drawActivation, + drawLoop, + drawBackgroundRect: drawBackgroundRect$2, + insertArrowHead, + insertArrowFilledHead, + insertSequenceNumber, + insertArrowCrossHead, + insertDatabaseIcon, + insertComputerIcon, + insertClockIcon, + getTextObj: getTextObj$1, + getNoteRect: getNoteRect$1, + fixLifeLineHeights, + sanitizeUrl: dist.sanitizeUrl + }; + let conf$4 = {}; + const bounds$1 = { + 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((actor) => actor.height || 0) + ) + (this.loops.length === 0 ? 0 : this.loops.map((it) => it.height || 0).reduce((acc, h) => acc + h)) + (this.messages.length === 0 ? 0 : this.messages.map((it) => it.height || 0).reduce((acc, h) => acc + h)) + (this.notes.length === 0 ? 0 : this.notes.map((it) => it.height || 0).reduce((acc, h) => acc + h)); + }, + clear: function() { + this.actors = []; + this.boxes = []; + this.loops = []; + this.messages = []; + this.notes = []; + }, + addBox: function(boxModel) { + this.boxes.push(boxModel); + }, + addActor: function(actorModel) { + this.actors.push(actorModel); + }, + addLoop: function(loopModel) { + this.loops.push(loopModel); + }, + addMessage: function(msgModel) { + this.messages.push(msgModel); + }, + addNote: function(noteModel) { + this.notes.push(noteModel); + }, + 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; + setConf$4(getConfig$1()); + }, + updateVal: function(obj, key, val, fun) { + if (obj[key] === void 0) { + obj[key] = val; + } else { + obj[key] = fun(val, obj[key]); + } + }, + updateBounds: function(startx, starty, stopx, stopy) { + const _self = this; + let cnt2 = 0; + function updateFn(type2) { + return function updateItemBounds(item) { + cnt2++; + const n = _self.sequenceItems.length - cnt2 + 1; + _self.updateVal(item, "starty", starty - n * conf$4.boxMargin, Math.min); + _self.updateVal(item, "stopy", stopy + n * conf$4.boxMargin, Math.max); + _self.updateVal(bounds$1.data, "startx", startx - n * conf$4.boxMargin, Math.min); + _self.updateVal(bounds$1.data, "stopx", stopx + n * conf$4.boxMargin, Math.max); + if (!(type2 === "activation")) { + _self.updateVal(item, "startx", startx - n * conf$4.boxMargin, Math.min); + _self.updateVal(item, "stopx", stopx + n * conf$4.boxMargin, Math.max); + _self.updateVal(bounds$1.data, "starty", starty - n * conf$4.boxMargin, Math.min); + _self.updateVal(bounds$1.data, "stopy", stopy + n * conf$4.boxMargin, Math.max); + } + }; + } + this.sequenceItems.forEach(updateFn()); + this.activations.forEach(updateFn("activation")); + }, + insert: function(startx, starty, stopx, stopy) { + const _startx = common$1.getMin(startx, stopx); + const _stopx = common$1.getMax(startx, stopx); + const _starty = common$1.getMin(starty, stopy); + const _stopy = common$1.getMax(starty, stopy); + this.updateVal(bounds$1.data, "startx", _startx, Math.min); + this.updateVal(bounds$1.data, "starty", _starty, Math.min); + this.updateVal(bounds$1.data, "stopx", _stopx, Math.max); + this.updateVal(bounds$1.data, "stopy", _stopy, Math.max); + this.updateBounds(_startx, _starty, _stopx, _stopy); + }, + newActivation: function(message, diagram2, actors2) { + const actorRect = actors2[message.from.actor]; + const stackedSize = actorActivations(message.from.actor).length || 0; + const x2 = actorRect.x + actorRect.width / 2 + (stackedSize - 1) * conf$4.activationWidth / 2; + this.activations.push({ + startx: x2, + starty: this.verticalPos + 2, + stopx: x2 + conf$4.activationWidth, + stopy: void 0, + actor: message.from.actor, + anchored: svgDraw$3.anchorElement(diagram2) + }); + }, + endActivation: function(message) { + const lastActorActivationIdx = this.activations.map(function(activation) { + return activation.actor; + }).lastIndexOf(message.from.actor); + return this.activations.splice(lastActorActivationIdx, 1)[0]; + }, + createLoop: function(title2 = { message: void 0, wrap: false, width: void 0 }, fill) { + return { + startx: void 0, + starty: this.verticalPos, + stopx: void 0, + stopy: void 0, + title: title2.message, + wrap: title2.wrap, + width: title2.width, + height: 0, + fill + }; + }, + newLoop: function(title2 = { message: void 0, wrap: false, width: void 0 }, fill) { + this.sequenceItems.push(this.createLoop(title2, fill)); + }, + endLoop: function() { + return this.sequenceItems.pop(); + }, + isLoopOverlap: function() { + return this.sequenceItems.length ? this.sequenceItems[this.sequenceItems.length - 1].overlap : false; + }, + addSectionToLoop: function(message) { + const loop = this.sequenceItems.pop(); + loop.sections = loop.sections || []; + loop.sectionTitles = loop.sectionTitles || []; + loop.sections.push({ y: bounds$1.getVerticalPos(), height: 0 }); + loop.sectionTitles.push(message); + this.sequenceItems.push(loop); + }, + saveVerticalPos: function() { + if (this.isLoopOverlap()) { + this.savedVerticalPos = this.verticalPos; + } + }, + resetVerticalPos: function() { + if (this.isLoopOverlap()) { + this.verticalPos = this.savedVerticalPos; + } + }, + bumpVerticalPos: function(bump) { + this.verticalPos = this.verticalPos + bump; + this.data.stopy = common$1.getMax(this.data.stopy, this.verticalPos); + }, + getVerticalPos: function() { + return this.verticalPos; + }, + getBounds: function() { + return { bounds: this.data, models: this.models }; + } + }; + const drawNote$2 = async function(elem, noteModel) { + bounds$1.bumpVerticalPos(conf$4.boxMargin); + noteModel.height = conf$4.boxMargin; + noteModel.starty = bounds$1.getVerticalPos(); + const rect2 = getNoteRect$2(); + rect2.x = noteModel.startx; + rect2.y = noteModel.starty; + rect2.width = noteModel.width || conf$4.width; + rect2.class = "note"; + const g = elem.append("g"); + const rectElem = svgDraw$3.drawRect(g, rect2); + const textObj = getTextObj$2(); + textObj.x = noteModel.startx; + textObj.y = noteModel.starty; + textObj.width = rect2.width; + textObj.dy = "1em"; + textObj.text = noteModel.message; + textObj.class = "noteText"; + textObj.fontFamily = conf$4.noteFontFamily; + textObj.fontSize = conf$4.noteFontSize; + textObj.fontWeight = conf$4.noteFontWeight; + textObj.anchor = conf$4.noteAlign; + textObj.textMargin = conf$4.noteMargin; + textObj.valign = "center"; + const textElem = hasKatex(textObj.text) ? await drawKatex(g, textObj) : drawText$2(g, textObj); + const textHeight = Math.round( + textElem.map((te) => (te._groups || te)[0][0].getBBox().height).reduce((acc, curr) => acc + curr) + ); + rectElem.attr("height", textHeight + 2 * conf$4.noteMargin); + noteModel.height += textHeight + 2 * conf$4.noteMargin; + bounds$1.bumpVerticalPos(textHeight + 2 * conf$4.noteMargin); + noteModel.stopy = noteModel.starty + textHeight + 2 * conf$4.noteMargin; + noteModel.stopx = noteModel.startx + rect2.width; + bounds$1.insert(noteModel.startx, noteModel.starty, noteModel.stopx, noteModel.stopy); + bounds$1.models.addNote(noteModel); + }; + const messageFont = (cnf) => { + return { + fontFamily: cnf.messageFontFamily, + fontSize: cnf.messageFontSize, + fontWeight: cnf.messageFontWeight + }; + }; + const noteFont = (cnf) => { + return { + fontFamily: cnf.noteFontFamily, + fontSize: cnf.noteFontSize, + fontWeight: cnf.noteFontWeight + }; + }; + const actorFont = (cnf) => { + return { + fontFamily: cnf.actorFontFamily, + fontSize: cnf.actorFontSize, + fontWeight: cnf.actorFontWeight + }; + }; + async function boundMessage(_diagram, msgModel) { + bounds$1.bumpVerticalPos(10); + const { startx, stopx, message } = msgModel; + const lines = common$1.splitBreaks(message).length; + const isKatexMsg = hasKatex(message); + const textDims = isKatexMsg ? await calculateMathMLDimensions(message, getConfig$1()) : utils$1.calculateTextDimensions(message, messageFont(conf$4)); + if (!isKatexMsg) { + const lineHeight = textDims.height / lines; + msgModel.height += lineHeight; + bounds$1.bumpVerticalPos(lineHeight); + } + let lineStartY; + let totalOffset = textDims.height - 10; + const textWidth = textDims.width; + if (startx === stopx) { + lineStartY = bounds$1.getVerticalPos() + totalOffset; + if (!conf$4.rightAngles) { + totalOffset += conf$4.boxMargin; + lineStartY = bounds$1.getVerticalPos() + totalOffset; + } + totalOffset += 30; + const dx = common$1.getMax(textWidth / 2, conf$4.width / 2); + bounds$1.insert( + startx - dx, + bounds$1.getVerticalPos() - 10 + totalOffset, + stopx + dx, + bounds$1.getVerticalPos() + 30 + totalOffset + ); + } else { + totalOffset += conf$4.boxMargin; + lineStartY = bounds$1.getVerticalPos() + totalOffset; + bounds$1.insert(startx, lineStartY - 10, stopx, lineStartY); + } + bounds$1.bumpVerticalPos(totalOffset); + msgModel.height += totalOffset; + msgModel.stopy = msgModel.starty + msgModel.height; + bounds$1.insert(msgModel.fromBounds, msgModel.starty, msgModel.toBounds, msgModel.stopy); + return lineStartY; + } + const drawMessage = async function(diagram2, msgModel, lineStartY, diagObj) { + const { startx, stopx, starty, message, type: type2, sequenceIndex, sequenceVisible } = msgModel; + const textDims = utils$1.calculateTextDimensions(message, messageFont(conf$4)); + const textObj = getTextObj$2(); + textObj.x = startx; + textObj.y = starty + 10; + textObj.width = stopx - startx; + textObj.class = "messageText"; + textObj.dy = "1em"; + textObj.text = message; + textObj.fontFamily = conf$4.messageFontFamily; + textObj.fontSize = conf$4.messageFontSize; + textObj.fontWeight = conf$4.messageFontWeight; + textObj.anchor = conf$4.messageAlign; + textObj.valign = "center"; + textObj.textMargin = conf$4.wrapPadding; + textObj.tspan = false; + hasKatex(textObj.text) ? await drawKatex(diagram2, textObj, { startx, stopx, starty: lineStartY }) : drawText$2(diagram2, textObj); + const textWidth = textDims.width; + let line2; + if (startx === stopx) { + if (conf$4.rightAngles) { + line2 = diagram2.append("path").attr( + "d", + `M ${startx},${lineStartY} H ${startx + common$1.getMax(conf$4.width / 2, textWidth / 2)} V ${lineStartY + 25} H ${startx}` + ); + } else { + line2 = diagram2.append("path").attr( + "d", + "M " + startx + "," + lineStartY + " C " + (startx + 60) + "," + (lineStartY - 10) + " " + (startx + 60) + "," + (lineStartY + 30) + " " + startx + "," + (lineStartY + 20) + ); + } + } else { + line2 = diagram2.append("line"); + line2.attr("x1", startx); + line2.attr("y1", lineStartY); + line2.attr("x2", stopx); + line2.attr("y2", lineStartY); + } + if (type2 === diagObj.db.LINETYPE.DOTTED || type2 === diagObj.db.LINETYPE.DOTTED_CROSS || type2 === diagObj.db.LINETYPE.DOTTED_POINT || type2 === diagObj.db.LINETYPE.DOTTED_OPEN) { + line2.style("stroke-dasharray", "3, 3"); + line2.attr("class", "messageLine1"); + } else { + line2.attr("class", "messageLine0"); + } + let url = ""; + if (conf$4.arrowMarkerAbsolute) { + url = window.location.protocol + "//" + window.location.host + window.location.pathname + window.location.search; + url = url.replace(/\(/g, "\\("); + url = url.replace(/\)/g, "\\)"); + } + line2.attr("stroke-width", 2); + line2.attr("stroke", "none"); + line2.style("fill", "none"); + if (type2 === diagObj.db.LINETYPE.SOLID || type2 === diagObj.db.LINETYPE.DOTTED) { + line2.attr("marker-end", "url(" + url + "#arrowhead)"); + } + if (type2 === diagObj.db.LINETYPE.SOLID_POINT || type2 === diagObj.db.LINETYPE.DOTTED_POINT) { + line2.attr("marker-end", "url(" + url + "#filled-head)"); + } + if (type2 === diagObj.db.LINETYPE.SOLID_CROSS || type2 === diagObj.db.LINETYPE.DOTTED_CROSS) { + line2.attr("marker-end", "url(" + url + "#crosshead)"); + } + if (sequenceVisible || conf$4.showSequenceNumbers) { + line2.attr("marker-start", "url(" + url + "#sequencenumber)"); + diagram2.append("text").attr("x", startx).attr("y", lineStartY + 4).attr("font-family", "sans-serif").attr("font-size", "12px").attr("text-anchor", "middle").attr("class", "sequenceNumber").text(sequenceIndex); + } + }; + const addActorRenderingData = async function(diagram2, actors2, createdActors, actorKeys, verticalPos, messages, isFooter) { + let prevWidth = 0; + let prevMargin = 0; + let prevBox = void 0; + let maxHeight = 0; + for (const actorKey of actorKeys) { + const actor = actors2[actorKey]; + const box = actor.box; + if (prevBox && prevBox != box) { + if (!isFooter) { + bounds$1.models.addBox(prevBox); + } + prevMargin += conf$4.boxMargin + prevBox.margin; + } + if (box && box != prevBox) { + if (!isFooter) { + box.x = prevWidth + prevMargin; + box.y = verticalPos; + } + prevMargin += box.margin; + } + actor.width = actor.width || conf$4.width; + actor.height = common$1.getMax(actor.height || conf$4.height, conf$4.height); + actor.margin = actor.margin || conf$4.actorMargin; + maxHeight = common$1.getMax(maxHeight, actor.height); + if (createdActors[actor.name]) { + prevMargin += actor.width / 2; + } + actor.x = prevWidth + prevMargin; + actor.starty = bounds$1.getVerticalPos(); + bounds$1.insert(actor.x, verticalPos, actor.x + actor.width, actor.height); + prevWidth += actor.width + prevMargin; + if (actor.box) { + actor.box.width = prevWidth + box.margin - actor.box.x; + } + prevMargin = actor.margin; + prevBox = actor.box; + bounds$1.models.addActor(actor); + } + if (prevBox && !isFooter) { + bounds$1.models.addBox(prevBox); + } + bounds$1.bumpVerticalPos(maxHeight); + }; + const drawActors = async function(diagram2, actors2, actorKeys, isFooter) { + if (!isFooter) { + for (const actorKey of actorKeys) { + const actor = actors2[actorKey]; + await svgDraw$3.drawActor(diagram2, actor, conf$4, false); + } + } else { + let maxHeight = 0; + bounds$1.bumpVerticalPos(conf$4.boxMargin * 2); + for (const actorKey of actorKeys) { + const actor = actors2[actorKey]; + if (!actor.stopy) { + actor.stopy = bounds$1.getVerticalPos(); + } + const height = await svgDraw$3.drawActor(diagram2, actor, conf$4, true); + maxHeight = common$1.getMax(maxHeight, height); + } + bounds$1.bumpVerticalPos(maxHeight + conf$4.boxMargin); + } + }; + const drawActorsPopup = function(diagram2, actors2, actorKeys, doc) { + let maxHeight = 0; + let maxWidth = 0; + for (const actorKey of actorKeys) { + const actor = actors2[actorKey]; + const minMenuWidth = getRequiredPopupWidth(actor); + const menuDimensions = svgDraw$3.drawPopup( + diagram2, + actor, + minMenuWidth, + conf$4, + conf$4.forceMenus, + doc + ); + if (menuDimensions.height > maxHeight) { + maxHeight = menuDimensions.height; + } + if (menuDimensions.width + actor.x > maxWidth) { + maxWidth = menuDimensions.width + actor.x; + } + } + return { maxHeight, maxWidth }; + }; + const setConf$4 = function(cnf) { + assignWithDepth$1(conf$4, cnf); + if (cnf.fontFamily) { + conf$4.actorFontFamily = conf$4.noteFontFamily = conf$4.messageFontFamily = cnf.fontFamily; + } + if (cnf.fontSize) { + conf$4.actorFontSize = conf$4.noteFontSize = conf$4.messageFontSize = cnf.fontSize; + } + if (cnf.fontWeight) { + conf$4.actorFontWeight = conf$4.noteFontWeight = conf$4.messageFontWeight = cnf.fontWeight; + } + }; + const actorActivations = function(actor) { + return bounds$1.activations.filter(function(activation) { + return activation.actor === actor; + }); + }; + const activationBounds = function(actor, actors2) { + const actorObj = actors2[actor]; + const activations = actorActivations(actor); + const left2 = activations.reduce(function(acc, activation) { + return common$1.getMin(acc, activation.startx); + }, actorObj.x + actorObj.width / 2 - 1); + const right2 = activations.reduce(function(acc, activation) { + return common$1.getMax(acc, activation.stopx); + }, actorObj.x + actorObj.width / 2 + 1); + return [left2, right2]; + }; + function adjustLoopHeightForWrap(loopWidths, msg, preMargin, postMargin, addLoopFn) { + bounds$1.bumpVerticalPos(preMargin); + let heightAdjust = postMargin; + if (msg.id && msg.message && loopWidths[msg.id]) { + const loopWidth = loopWidths[msg.id].width; + const textConf = messageFont(conf$4); + msg.message = utils$1.wrapLabel(`[${msg.message}]`, loopWidth - 2 * conf$4.wrapPadding, textConf); + msg.width = loopWidth; + msg.wrap = true; + const textDims = utils$1.calculateTextDimensions(msg.message, textConf); + const totalOffset = common$1.getMax(textDims.height, conf$4.labelBoxHeight); + heightAdjust = postMargin + totalOffset; + log$1.debug(`${totalOffset} - ${msg.message}`); + } + addLoopFn(msg); + bounds$1.bumpVerticalPos(heightAdjust); + } + function adjustCreatedDestroyedData(msg, msgModel, lineStartY, index2, actors2, createdActors, destroyedActors) { + function receiverAdjustment(actor, adjustment) { + if (actor.x < actors2[msg.from].x) { + bounds$1.insert( + msgModel.stopx - adjustment, + msgModel.starty, + msgModel.startx, + msgModel.stopy + actor.height / 2 + conf$4.noteMargin + ); + msgModel.stopx = msgModel.stopx + adjustment; + } else { + bounds$1.insert( + msgModel.startx, + msgModel.starty, + msgModel.stopx + adjustment, + msgModel.stopy + actor.height / 2 + conf$4.noteMargin + ); + msgModel.stopx = msgModel.stopx - adjustment; + } + } + function senderAdjustment(actor, adjustment) { + if (actor.x < actors2[msg.to].x) { + bounds$1.insert( + msgModel.startx - adjustment, + msgModel.starty, + msgModel.stopx, + msgModel.stopy + actor.height / 2 + conf$4.noteMargin + ); + msgModel.startx = msgModel.startx + adjustment; + } else { + bounds$1.insert( + msgModel.stopx, + msgModel.starty, + msgModel.startx + adjustment, + msgModel.stopy + actor.height / 2 + conf$4.noteMargin + ); + msgModel.startx = msgModel.startx - adjustment; + } + } + if (createdActors[msg.to] == index2) { + const actor = actors2[msg.to]; + const adjustment = actor.type == "actor" ? ACTOR_TYPE_WIDTH / 2 + 3 : actor.width / 2 + 3; + receiverAdjustment(actor, adjustment); + actor.starty = lineStartY - actor.height / 2; + bounds$1.bumpVerticalPos(actor.height / 2); + } else if (destroyedActors[msg.from] == index2) { + const actor = actors2[msg.from]; + if (conf$4.mirrorActors) { + const adjustment = actor.type == "actor" ? ACTOR_TYPE_WIDTH / 2 : actor.width / 2; + senderAdjustment(actor, adjustment); + } + actor.stopy = lineStartY - actor.height / 2; + bounds$1.bumpVerticalPos(actor.height / 2); + } else if (destroyedActors[msg.to] == index2) { + const actor = actors2[msg.to]; + if (conf$4.mirrorActors) { + const adjustment = actor.type == "actor" ? ACTOR_TYPE_WIDTH / 2 + 3 : actor.width / 2 + 3; + receiverAdjustment(actor, adjustment); + } + actor.stopy = lineStartY - actor.height / 2; + bounds$1.bumpVerticalPos(actor.height / 2); + } + } + const draw$a = async function(_text, id2, _version, diagObj) { + const { securityLevel, sequence: sequence2 } = getConfig$1(); + conf$4 = sequence2; + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = d3select("#i" + id2); + } + const root2 = securityLevel === "sandbox" ? d3select(sandboxElement.nodes()[0].contentDocument.body) : d3select("body"); + const doc = securityLevel === "sandbox" ? sandboxElement.nodes()[0].contentDocument : document; + bounds$1.init(); + log$1.debug(diagObj.db); + const diagram2 = securityLevel === "sandbox" ? root2.select(`[id="${id2}"]`) : d3select(`[id="${id2}"]`); + const actors2 = diagObj.db.getActors(); + const createdActors = diagObj.db.getCreatedActors(); + const destroyedActors = diagObj.db.getDestroyedActors(); + const boxes = diagObj.db.getBoxes(); + let actorKeys = diagObj.db.getActorKeys(); + const messages = diagObj.db.getMessages(); + const title2 = diagObj.db.getDiagramTitle(); + const hasBoxes = diagObj.db.hasAtLeastOneBox(); + const hasBoxTitles = diagObj.db.hasAtLeastOneBoxWithTitle(); + const maxMessageWidthPerActor = await getMaxMessageWidthPerActor(actors2, messages, diagObj); + conf$4.height = await calculateActorMargins(actors2, maxMessageWidthPerActor, boxes); + svgDraw$3.insertComputerIcon(diagram2); + svgDraw$3.insertDatabaseIcon(diagram2); + svgDraw$3.insertClockIcon(diagram2); + if (hasBoxes) { + bounds$1.bumpVerticalPos(conf$4.boxMargin); + if (hasBoxTitles) { + bounds$1.bumpVerticalPos(boxes[0].textMaxHeight); + } + } + if (conf$4.hideUnusedParticipants === true) { + const newActors = /* @__PURE__ */ new Set(); + messages.forEach((message) => { + newActors.add(message.from); + newActors.add(message.to); + }); + actorKeys = actorKeys.filter((actorKey) => newActors.has(actorKey)); + } + await addActorRenderingData(diagram2, actors2, createdActors, actorKeys, 0, messages, false); + const loopWidths = await calculateLoopBounds(messages, actors2, maxMessageWidthPerActor, diagObj); + svgDraw$3.insertArrowHead(diagram2); + svgDraw$3.insertArrowCrossHead(diagram2); + svgDraw$3.insertArrowFilledHead(diagram2); + svgDraw$3.insertSequenceNumber(diagram2); + function activeEnd(msg, verticalPos) { + const activationData = bounds$1.endActivation(msg); + if (activationData.starty + 18 > verticalPos) { + activationData.starty = verticalPos - 6; + verticalPos += 12; + } + svgDraw$3.drawActivation( + diagram2, + activationData, + verticalPos, + conf$4, + actorActivations(msg.from.actor).length + ); + bounds$1.insert(activationData.startx, verticalPos - 10, activationData.stopx, verticalPos); + } + let sequenceIndex = 1; + let sequenceIndexStep = 1; + const messagesToDraw = []; + const backgrounds = []; + let index2 = 0; + for (const msg of messages) { + let loopModel, noteModel, msgModel; + switch (msg.type) { + case diagObj.db.LINETYPE.NOTE: + bounds$1.resetVerticalPos(); + noteModel = msg.noteModel; + await drawNote$2(diagram2, noteModel); + break; + case diagObj.db.LINETYPE.ACTIVE_START: + bounds$1.newActivation(msg, diagram2, actors2); + break; + case diagObj.db.LINETYPE.ACTIVE_END: + activeEnd(msg, bounds$1.getVerticalPos()); + break; + case diagObj.db.LINETYPE.LOOP_START: + adjustLoopHeightForWrap( + loopWidths, + msg, + conf$4.boxMargin, + conf$4.boxMargin + conf$4.boxTextMargin, + (message) => bounds$1.newLoop(message) + ); + break; + case diagObj.db.LINETYPE.LOOP_END: + loopModel = bounds$1.endLoop(); + await svgDraw$3.drawLoop(diagram2, loopModel, "loop", conf$4); + bounds$1.bumpVerticalPos(loopModel.stopy - bounds$1.getVerticalPos()); + bounds$1.models.addLoop(loopModel); + break; + case diagObj.db.LINETYPE.RECT_START: + adjustLoopHeightForWrap( + loopWidths, + msg, + conf$4.boxMargin, + conf$4.boxMargin, + (message) => bounds$1.newLoop(void 0, message.message) + ); + break; + case diagObj.db.LINETYPE.RECT_END: + loopModel = bounds$1.endLoop(); + backgrounds.push(loopModel); + bounds$1.models.addLoop(loopModel); + bounds$1.bumpVerticalPos(loopModel.stopy - bounds$1.getVerticalPos()); + break; + case diagObj.db.LINETYPE.OPT_START: + adjustLoopHeightForWrap( + loopWidths, + msg, + conf$4.boxMargin, + conf$4.boxMargin + conf$4.boxTextMargin, + (message) => bounds$1.newLoop(message) + ); + break; + case diagObj.db.LINETYPE.OPT_END: + loopModel = bounds$1.endLoop(); + await svgDraw$3.drawLoop(diagram2, loopModel, "opt", conf$4); + bounds$1.bumpVerticalPos(loopModel.stopy - bounds$1.getVerticalPos()); + bounds$1.models.addLoop(loopModel); + break; + case diagObj.db.LINETYPE.ALT_START: + adjustLoopHeightForWrap( + loopWidths, + msg, + conf$4.boxMargin, + conf$4.boxMargin + conf$4.boxTextMargin, + (message) => bounds$1.newLoop(message) + ); + break; + case diagObj.db.LINETYPE.ALT_ELSE: + adjustLoopHeightForWrap( + loopWidths, + msg, + conf$4.boxMargin + conf$4.boxTextMargin, + conf$4.boxMargin, + (message) => bounds$1.addSectionToLoop(message) + ); + break; + case diagObj.db.LINETYPE.ALT_END: + loopModel = bounds$1.endLoop(); + await svgDraw$3.drawLoop(diagram2, loopModel, "alt", conf$4); + bounds$1.bumpVerticalPos(loopModel.stopy - bounds$1.getVerticalPos()); + bounds$1.models.addLoop(loopModel); + break; + case diagObj.db.LINETYPE.PAR_START: + case diagObj.db.LINETYPE.PAR_OVER_START: + adjustLoopHeightForWrap( + loopWidths, + msg, + conf$4.boxMargin, + conf$4.boxMargin + conf$4.boxTextMargin, + (message) => bounds$1.newLoop(message) + ); + bounds$1.saveVerticalPos(); + break; + case diagObj.db.LINETYPE.PAR_AND: + adjustLoopHeightForWrap( + loopWidths, + msg, + conf$4.boxMargin + conf$4.boxTextMargin, + conf$4.boxMargin, + (message) => bounds$1.addSectionToLoop(message) + ); + break; + case diagObj.db.LINETYPE.PAR_END: + loopModel = bounds$1.endLoop(); + await svgDraw$3.drawLoop(diagram2, loopModel, "par", conf$4); + bounds$1.bumpVerticalPos(loopModel.stopy - bounds$1.getVerticalPos()); + bounds$1.models.addLoop(loopModel); + break; + case diagObj.db.LINETYPE.AUTONUMBER: + sequenceIndex = msg.message.start || sequenceIndex; + sequenceIndexStep = msg.message.step || sequenceIndexStep; + if (msg.message.visible) { + diagObj.db.enableSequenceNumbers(); + } else { + diagObj.db.disableSequenceNumbers(); + } + break; + case diagObj.db.LINETYPE.CRITICAL_START: + adjustLoopHeightForWrap( + loopWidths, + msg, + conf$4.boxMargin, + conf$4.boxMargin + conf$4.boxTextMargin, + (message) => bounds$1.newLoop(message) + ); + break; + case diagObj.db.LINETYPE.CRITICAL_OPTION: + adjustLoopHeightForWrap( + loopWidths, + msg, + conf$4.boxMargin + conf$4.boxTextMargin, + conf$4.boxMargin, + (message) => bounds$1.addSectionToLoop(message) + ); + break; + case diagObj.db.LINETYPE.CRITICAL_END: + loopModel = bounds$1.endLoop(); + await svgDraw$3.drawLoop(diagram2, loopModel, "critical", conf$4); + bounds$1.bumpVerticalPos(loopModel.stopy - bounds$1.getVerticalPos()); + bounds$1.models.addLoop(loopModel); + break; + case diagObj.db.LINETYPE.BREAK_START: + adjustLoopHeightForWrap( + loopWidths, + msg, + conf$4.boxMargin, + conf$4.boxMargin + conf$4.boxTextMargin, + (message) => bounds$1.newLoop(message) + ); + break; + case diagObj.db.LINETYPE.BREAK_END: + loopModel = bounds$1.endLoop(); + await svgDraw$3.drawLoop(diagram2, loopModel, "break", conf$4); + bounds$1.bumpVerticalPos(loopModel.stopy - bounds$1.getVerticalPos()); + bounds$1.models.addLoop(loopModel); + break; + default: + try { + msgModel = msg.msgModel; + msgModel.starty = bounds$1.getVerticalPos(); + msgModel.sequenceIndex = sequenceIndex; + msgModel.sequenceVisible = diagObj.db.showSequenceNumbers(); + const lineStartY = await boundMessage(diagram2, msgModel); + adjustCreatedDestroyedData( + msg, + msgModel, + lineStartY, + index2, + actors2, + createdActors, + destroyedActors + ); + messagesToDraw.push({ messageModel: msgModel, lineStartY }); + bounds$1.models.addMessage(msgModel); + } catch (e) { + log$1.error("error while drawing message", e); + } + } + if ([ + diagObj.db.LINETYPE.SOLID_OPEN, + diagObj.db.LINETYPE.DOTTED_OPEN, + diagObj.db.LINETYPE.SOLID, + diagObj.db.LINETYPE.DOTTED, + diagObj.db.LINETYPE.SOLID_CROSS, + diagObj.db.LINETYPE.DOTTED_CROSS, + diagObj.db.LINETYPE.SOLID_POINT, + diagObj.db.LINETYPE.DOTTED_POINT + ].includes(msg.type)) { + sequenceIndex = sequenceIndex + sequenceIndexStep; + } + index2++; + } + log$1.debug("createdActors", createdActors); + log$1.debug("destroyedActors", destroyedActors); + await drawActors(diagram2, actors2, actorKeys, false); + for (const e of messagesToDraw) { + await drawMessage(diagram2, e.messageModel, e.lineStartY, diagObj); + } + if (conf$4.mirrorActors) { + await drawActors(diagram2, actors2, actorKeys, true); + } + backgrounds.forEach((e) => svgDraw$3.drawBackgroundRect(diagram2, e)); + fixLifeLineHeights(diagram2, actors2, actorKeys, conf$4); + for (const box2 of bounds$1.models.boxes) { + box2.height = bounds$1.getVerticalPos() - box2.y; + bounds$1.insert(box2.x, box2.y, box2.x + box2.width, box2.height); + box2.startx = box2.x; + box2.starty = box2.y; + box2.stopx = box2.startx + box2.width; + box2.stopy = box2.starty + box2.height; + box2.stroke = "rgb(0,0,0, 0.5)"; + await svgDraw$3.drawBox(diagram2, box2, conf$4); + } + if (hasBoxes) { + bounds$1.bumpVerticalPos(conf$4.boxMargin); + } + const requiredBoxSize = drawActorsPopup(diagram2, actors2, actorKeys, doc); + const { bounds: box } = bounds$1.getBounds(); + let boxHeight = box.stopy - box.starty; + if (boxHeight < requiredBoxSize.maxHeight) { + boxHeight = requiredBoxSize.maxHeight; + } + let height = boxHeight + 2 * conf$4.diagramMarginY; + if (conf$4.mirrorActors) { + height = height - conf$4.boxMargin + conf$4.bottomMarginAdj; + } + let boxWidth = box.stopx - box.startx; + if (boxWidth < requiredBoxSize.maxWidth) { + boxWidth = requiredBoxSize.maxWidth; + } + const width2 = boxWidth + 2 * conf$4.diagramMarginX; + if (title2) { + diagram2.append("text").text(title2).attr("x", (box.stopx - box.startx) / 2 - 2 * conf$4.diagramMarginX).attr("y", -25); + } + configureSvgSize(diagram2, height, width2, conf$4.useMaxWidth); + const extraVertForTitle = title2 ? 40 : 0; + diagram2.attr( + "viewBox", + box.startx - conf$4.diagramMarginX + " -" + (conf$4.diagramMarginY + extraVertForTitle) + " " + width2 + " " + (height + extraVertForTitle) + ); + log$1.debug(`models:`, bounds$1.models); + }; + async function getMaxMessageWidthPerActor(actors2, messages, diagObj) { + const maxMessageWidthPerActor = {}; + for (const msg of messages) { + if (actors2[msg.to] && actors2[msg.from]) { + const actor = actors2[msg.to]; + if (msg.placement === diagObj.db.PLACEMENT.LEFTOF && !actor.prevActor) { + continue; + } + if (msg.placement === diagObj.db.PLACEMENT.RIGHTOF && !actor.nextActor) { + continue; + } + const isNote = msg.placement !== void 0; + const isMessage = !isNote; + const textFont = isNote ? noteFont(conf$4) : messageFont(conf$4); + const wrappedMessage = msg.wrap ? utils$1.wrapLabel(msg.message, conf$4.width - 2 * conf$4.wrapPadding, textFont) : msg.message; + const messageDimensions = hasKatex(wrappedMessage) ? await calculateMathMLDimensions(msg.message, getConfig$1()) : utils$1.calculateTextDimensions(wrappedMessage, textFont); + const messageWidth = messageDimensions.width + 2 * conf$4.wrapPadding; + if (isMessage && msg.from === actor.nextActor) { + maxMessageWidthPerActor[msg.to] = common$1.getMax( + maxMessageWidthPerActor[msg.to] || 0, + messageWidth + ); + } else if (isMessage && msg.from === actor.prevActor) { + maxMessageWidthPerActor[msg.from] = common$1.getMax( + maxMessageWidthPerActor[msg.from] || 0, + messageWidth + ); + } else if (isMessage && msg.from === msg.to) { + maxMessageWidthPerActor[msg.from] = common$1.getMax( + maxMessageWidthPerActor[msg.from] || 0, + messageWidth / 2 + ); + maxMessageWidthPerActor[msg.to] = common$1.getMax( + maxMessageWidthPerActor[msg.to] || 0, + messageWidth / 2 + ); + } else if (msg.placement === diagObj.db.PLACEMENT.RIGHTOF) { + maxMessageWidthPerActor[msg.from] = common$1.getMax( + maxMessageWidthPerActor[msg.from] || 0, + messageWidth + ); + } else if (msg.placement === diagObj.db.PLACEMENT.LEFTOF) { + maxMessageWidthPerActor[actor.prevActor] = common$1.getMax( + maxMessageWidthPerActor[actor.prevActor] || 0, + messageWidth + ); + } else if (msg.placement === diagObj.db.PLACEMENT.OVER) { + if (actor.prevActor) { + maxMessageWidthPerActor[actor.prevActor] = common$1.getMax( + maxMessageWidthPerActor[actor.prevActor] || 0, + messageWidth / 2 + ); + } + if (actor.nextActor) { + maxMessageWidthPerActor[msg.from] = common$1.getMax( + maxMessageWidthPerActor[msg.from] || 0, + messageWidth / 2 + ); + } + } + } + } + log$1.debug("maxMessageWidthPerActor:", maxMessageWidthPerActor); + return maxMessageWidthPerActor; + } + const getRequiredPopupWidth = function(actor) { + let requiredPopupWidth = 0; + const textFont = actorFont(conf$4); + for (const key in actor.links) { + const labelDimensions = utils$1.calculateTextDimensions(key, textFont); + const labelWidth = labelDimensions.width + 2 * conf$4.wrapPadding + 2 * conf$4.boxMargin; + if (requiredPopupWidth < labelWidth) { + requiredPopupWidth = labelWidth; + } + } + return requiredPopupWidth; + }; + async function calculateActorMargins(actors2, actorToMessageWidth, boxes) { + let maxHeight = 0; + for (const prop of Object.keys(actors2)) { + const actor = actors2[prop]; + if (actor.wrap) { + actor.description = utils$1.wrapLabel( + actor.description, + conf$4.width - 2 * conf$4.wrapPadding, + actorFont(conf$4) + ); + } + const actDims = hasKatex(actor.description) ? await calculateMathMLDimensions(actor.description, getConfig$1()) : utils$1.calculateTextDimensions(actor.description, actorFont(conf$4)); + actor.width = actor.wrap ? conf$4.width : common$1.getMax(conf$4.width, actDims.width + 2 * conf$4.wrapPadding); + actor.height = actor.wrap ? common$1.getMax(actDims.height, conf$4.height) : conf$4.height; + maxHeight = common$1.getMax(maxHeight, actor.height); + } + for (const actorKey in actorToMessageWidth) { + const actor = actors2[actorKey]; + if (!actor) { + continue; + } + const nextActor = actors2[actor.nextActor]; + if (!nextActor) { + const messageWidth2 = actorToMessageWidth[actorKey]; + const actorWidth2 = messageWidth2 + conf$4.actorMargin - actor.width / 2; + actor.margin = common$1.getMax(actorWidth2, conf$4.actorMargin); + continue; + } + const messageWidth = actorToMessageWidth[actorKey]; + const actorWidth = messageWidth + conf$4.actorMargin - actor.width / 2 - nextActor.width / 2; + actor.margin = common$1.getMax(actorWidth, conf$4.actorMargin); + } + let maxBoxHeight = 0; + boxes.forEach((box) => { + const textFont = messageFont(conf$4); + let totalWidth = box.actorKeys.reduce((total, aKey) => { + return total += actors2[aKey].width + (actors2[aKey].margin || 0); + }, 0); + totalWidth -= 2 * conf$4.boxTextMargin; + if (box.wrap) { + box.name = utils$1.wrapLabel(box.name, totalWidth - 2 * conf$4.wrapPadding, textFont); + } + const boxMsgDimensions = utils$1.calculateTextDimensions(box.name, textFont); + maxBoxHeight = common$1.getMax(boxMsgDimensions.height, maxBoxHeight); + const minWidth = common$1.getMax(totalWidth, boxMsgDimensions.width + 2 * conf$4.wrapPadding); + box.margin = conf$4.boxTextMargin; + if (totalWidth < minWidth) { + const missing = (minWidth - totalWidth) / 2; + box.margin += missing; + } + }); + boxes.forEach((box) => box.textMaxHeight = maxBoxHeight); + return common$1.getMax(maxHeight, conf$4.height); + } + const buildNoteModel = async function(msg, actors2, diagObj) { + const startx = actors2[msg.from].x; + const stopx = actors2[msg.to].x; + const shouldWrap = msg.wrap && msg.message; + let textDimensions = hasKatex(msg.message) ? await calculateMathMLDimensions(msg.message, getConfig$1()) : utils$1.calculateTextDimensions( + shouldWrap ? utils$1.wrapLabel(msg.message, conf$4.width, noteFont(conf$4)) : msg.message, + noteFont(conf$4) + ); + const noteModel = { + width: shouldWrap ? conf$4.width : common$1.getMax(conf$4.width, textDimensions.width + 2 * conf$4.noteMargin), + height: 0, + startx: actors2[msg.from].x, + stopx: 0, + starty: 0, + stopy: 0, + message: msg.message + }; + if (msg.placement === diagObj.db.PLACEMENT.RIGHTOF) { + noteModel.width = shouldWrap ? common$1.getMax(conf$4.width, textDimensions.width) : common$1.getMax( + actors2[msg.from].width / 2 + actors2[msg.to].width / 2, + textDimensions.width + 2 * conf$4.noteMargin + ); + noteModel.startx = startx + (actors2[msg.from].width + conf$4.actorMargin) / 2; + } else if (msg.placement === diagObj.db.PLACEMENT.LEFTOF) { + noteModel.width = shouldWrap ? common$1.getMax(conf$4.width, textDimensions.width + 2 * conf$4.noteMargin) : common$1.getMax( + actors2[msg.from].width / 2 + actors2[msg.to].width / 2, + textDimensions.width + 2 * conf$4.noteMargin + ); + noteModel.startx = startx - noteModel.width + (actors2[msg.from].width - conf$4.actorMargin) / 2; + } else if (msg.to === msg.from) { + textDimensions = utils$1.calculateTextDimensions( + shouldWrap ? utils$1.wrapLabel( + msg.message, + common$1.getMax(conf$4.width, actors2[msg.from].width), + noteFont(conf$4) + ) : msg.message, + noteFont(conf$4) + ); + noteModel.width = shouldWrap ? common$1.getMax(conf$4.width, actors2[msg.from].width) : common$1.getMax( + actors2[msg.from].width, + conf$4.width, + textDimensions.width + 2 * conf$4.noteMargin + ); + noteModel.startx = startx + (actors2[msg.from].width - noteModel.width) / 2; + } else { + noteModel.width = Math.abs(startx + actors2[msg.from].width / 2 - (stopx + actors2[msg.to].width / 2)) + conf$4.actorMargin; + noteModel.startx = startx < stopx ? startx + actors2[msg.from].width / 2 - conf$4.actorMargin / 2 : stopx + actors2[msg.to].width / 2 - conf$4.actorMargin / 2; + } + if (shouldWrap) { + noteModel.message = utils$1.wrapLabel( + msg.message, + noteModel.width - 2 * conf$4.wrapPadding, + noteFont(conf$4) + ); + } + log$1.debug( + `NM:[${noteModel.startx},${noteModel.stopx},${noteModel.starty},${noteModel.stopy}:${noteModel.width},${noteModel.height}=${msg.message}]` + ); + return noteModel; + }; + const buildMessageModel = function(msg, actors2, diagObj) { + if (![ + diagObj.db.LINETYPE.SOLID_OPEN, + diagObj.db.LINETYPE.DOTTED_OPEN, + diagObj.db.LINETYPE.SOLID, + diagObj.db.LINETYPE.DOTTED, + diagObj.db.LINETYPE.SOLID_CROSS, + diagObj.db.LINETYPE.DOTTED_CROSS, + diagObj.db.LINETYPE.SOLID_POINT, + diagObj.db.LINETYPE.DOTTED_POINT + ].includes(msg.type)) { + return {}; + } + const [fromLeft, fromRight] = activationBounds(msg.from, actors2); + const [toLeft, toRight] = activationBounds(msg.to, actors2); + const isArrowToRight = fromLeft <= toLeft; + const startx = isArrowToRight ? fromRight : fromLeft; + let stopx = isArrowToRight ? toLeft : toRight; + const isArrowToActivation = Math.abs(toLeft - toRight) > 2; + const adjustValue = (value2) => { + return isArrowToRight ? -value2 : value2; + }; + if (msg.from === msg.to) { + stopx = startx; + } else { + if (msg.activate && !isArrowToActivation) { + stopx += adjustValue(conf$4.activationWidth / 2 - 1); + } + if (![diagObj.db.LINETYPE.SOLID_OPEN, diagObj.db.LINETYPE.DOTTED_OPEN].includes(msg.type)) { + stopx += adjustValue(3); + } + } + const allBounds = [fromLeft, fromRight, toLeft, toRight]; + const boundedWidth = Math.abs(startx - stopx); + if (msg.wrap && msg.message) { + msg.message = utils$1.wrapLabel( + msg.message, + common$1.getMax(boundedWidth + 2 * conf$4.wrapPadding, conf$4.width), + messageFont(conf$4) + ); + } + const msgDims = utils$1.calculateTextDimensions(msg.message, messageFont(conf$4)); + return { + width: common$1.getMax( + msg.wrap ? 0 : msgDims.width + 2 * conf$4.wrapPadding, + boundedWidth + 2 * conf$4.wrapPadding, + conf$4.width + ), + height: 0, + startx, + stopx, + starty: 0, + stopy: 0, + message: msg.message, + type: msg.type, + wrap: msg.wrap, + fromBounds: Math.min.apply(null, allBounds), + toBounds: Math.max.apply(null, allBounds) + }; + }; + const calculateLoopBounds = async function(messages, actors2, _maxWidthPerActor, diagObj) { + const loops = {}; + const stack = []; + let current, noteModel, msgModel; + for (const msg of messages) { + msg.id = utils$1.random({ length: 10 }); + switch (msg.type) { + case diagObj.db.LINETYPE.LOOP_START: + case diagObj.db.LINETYPE.ALT_START: + case diagObj.db.LINETYPE.OPT_START: + case diagObj.db.LINETYPE.PAR_START: + case diagObj.db.LINETYPE.PAR_OVER_START: + case diagObj.db.LINETYPE.CRITICAL_START: + case diagObj.db.LINETYPE.BREAK_START: + stack.push({ + id: msg.id, + msg: msg.message, + from: Number.MAX_SAFE_INTEGER, + to: Number.MIN_SAFE_INTEGER, + width: 0 + }); + break; + case diagObj.db.LINETYPE.ALT_ELSE: + case diagObj.db.LINETYPE.PAR_AND: + case diagObj.db.LINETYPE.CRITICAL_OPTION: + if (msg.message) { + current = stack.pop(); + loops[current.id] = current; + loops[msg.id] = current; + stack.push(current); + } + break; + case diagObj.db.LINETYPE.LOOP_END: + case diagObj.db.LINETYPE.ALT_END: + case diagObj.db.LINETYPE.OPT_END: + case diagObj.db.LINETYPE.PAR_END: + case diagObj.db.LINETYPE.CRITICAL_END: + case diagObj.db.LINETYPE.BREAK_END: + current = stack.pop(); + loops[current.id] = current; + break; + case diagObj.db.LINETYPE.ACTIVE_START: + { + const actorRect = actors2[msg.from ? msg.from.actor : msg.to.actor]; + const stackedSize = actorActivations(msg.from ? msg.from.actor : msg.to.actor).length; + const x2 = actorRect.x + actorRect.width / 2 + (stackedSize - 1) * conf$4.activationWidth / 2; + const toAdd = { + startx: x2, + stopx: x2 + conf$4.activationWidth, + actor: msg.from.actor, + enabled: true + }; + bounds$1.activations.push(toAdd); + } + break; + case diagObj.db.LINETYPE.ACTIVE_END: + { + const lastActorActivationIdx = bounds$1.activations.map((a) => a.actor).lastIndexOf(msg.from.actor); + delete bounds$1.activations.splice(lastActorActivationIdx, 1)[0]; + } + break; + } + const isNote = msg.placement !== void 0; + if (isNote) { + noteModel = await buildNoteModel(msg, actors2, diagObj); + msg.noteModel = noteModel; + stack.forEach((stk) => { + current = stk; + current.from = common$1.getMin(current.from, noteModel.startx); + current.to = common$1.getMax(current.to, noteModel.startx + noteModel.width); + current.width = common$1.getMax(current.width, Math.abs(current.from - current.to)) - conf$4.labelBoxWidth; + }); + } else { + msgModel = buildMessageModel(msg, actors2, diagObj); + msg.msgModel = msgModel; + if (msgModel.startx && msgModel.stopx && stack.length > 0) { + stack.forEach((stk) => { + current = stk; + if (msgModel.startx === msgModel.stopx) { + const from2 = actors2[msg.from]; + const to = actors2[msg.to]; + current.from = common$1.getMin( + from2.x - msgModel.width / 2, + from2.x - from2.width / 2, + current.from + ); + current.to = common$1.getMax( + to.x + msgModel.width / 2, + to.x + from2.width / 2, + current.to + ); + current.width = common$1.getMax(current.width, Math.abs(current.to - current.from)) - conf$4.labelBoxWidth; + } else { + current.from = common$1.getMin(msgModel.startx, current.from); + current.to = common$1.getMax(msgModel.stopx, current.to); + current.width = common$1.getMax(current.width, msgModel.width) - conf$4.labelBoxWidth; + } + }); + } + } + } + bounds$1.activations = []; + log$1.debug("Loop type widths:", loops); + return loops; + }; + const renderer$a = { + bounds: bounds$1, + drawActors, + drawActorsPopup, + setConf: setConf$4, + draw: draw$a + }; + const diagram$a = { + parser: parser$f, + db: db$9, + renderer: renderer$a, + styles: styles$6, + init: ({ wrap: wrap2 }) => { + db$9.setWrap(wrap2); + } + }; + const sequenceDiagram = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + diagram: diagram$a + }, Symbol.toStringTag, { value: "Module" })); + var parser$c = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 17], $V1 = [1, 18], $V2 = [1, 19], $V3 = [1, 39], $V4 = [1, 40], $V5 = [1, 25], $V6 = [1, 23], $V7 = [1, 24], $V8 = [1, 31], $V9 = [1, 32], $Va = [1, 33], $Vb = [1, 34], $Vc = [1, 35], $Vd = [1, 36], $Ve = [1, 26], $Vf = [1, 27], $Vg = [1, 28], $Vh = [1, 29], $Vi = [1, 43], $Vj = [1, 30], $Vk = [1, 42], $Vl = [1, 44], $Vm = [1, 41], $Vn = [1, 45], $Vo = [1, 9], $Vp = [1, 8, 9], $Vq = [1, 56], $Vr = [1, 57], $Vs = [1, 58], $Vt = [1, 59], $Vu = [1, 60], $Vv = [1, 61], $Vw = [1, 62], $Vx = [1, 8, 9, 39], $Vy = [1, 74], $Vz = [1, 8, 9, 12, 13, 21, 37, 39, 42, 59, 60, 61, 62, 63, 64, 65, 70, 72], $VA = [1, 8, 9, 12, 13, 19, 21, 37, 39, 42, 46, 59, 60, 61, 62, 63, 64, 65, 70, 72, 74, 80, 95, 97, 98], $VB = [13, 74, 80, 95, 97, 98], $VC = [13, 64, 65, 74, 80, 95, 97, 98], $VD = [13, 59, 60, 61, 62, 63, 74, 80, 95, 97, 98], $VE = [1, 93], $VF = [1, 110], $VG = [1, 108], $VH = [1, 102], $VI = [1, 103], $VJ = [1, 104], $VK = [1, 105], $VL = [1, 106], $VM = [1, 107], $VN = [1, 109], $VO = [1, 8, 9, 37, 39, 42], $VP = [1, 8, 9, 21], $VQ = [1, 8, 9, 78], $VR = [1, 8, 9, 21, 73, 74, 78, 80, 81, 82, 83, 84, 85]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "mermaidDoc": 4, "statements": 5, "graphConfig": 6, "CLASS_DIAGRAM": 7, "NEWLINE": 8, "EOF": 9, "statement": 10, "classLabel": 11, "SQS": 12, "STR": 13, "SQE": 14, "namespaceName": 15, "alphaNumToken": 16, "className": 17, "classLiteralName": 18, "GENERICTYPE": 19, "relationStatement": 20, "LABEL": 21, "namespaceStatement": 22, "classStatement": 23, "memberStatement": 24, "annotationStatement": 25, "clickStatement": 26, "styleStatement": 27, "cssClassStatement": 28, "noteStatement": 29, "direction": 30, "acc_title": 31, "acc_title_value": 32, "acc_descr": 33, "acc_descr_value": 34, "acc_descr_multiline_value": 35, "namespaceIdentifier": 36, "STRUCT_START": 37, "classStatements": 38, "STRUCT_STOP": 39, "NAMESPACE": 40, "classIdentifier": 41, "STYLE_SEPARATOR": 42, "members": 43, "CLASS": 44, "ANNOTATION_START": 45, "ANNOTATION_END": 46, "MEMBER": 47, "SEPARATOR": 48, "relation": 49, "NOTE_FOR": 50, "noteText": 51, "NOTE": 52, "direction_tb": 53, "direction_bt": 54, "direction_rl": 55, "direction_lr": 56, "relationType": 57, "lineType": 58, "AGGREGATION": 59, "EXTENSION": 60, "COMPOSITION": 61, "DEPENDENCY": 62, "LOLLIPOP": 63, "LINE": 64, "DOTTED_LINE": 65, "CALLBACK": 66, "LINK": 67, "LINK_TARGET": 68, "CLICK": 69, "CALLBACK_NAME": 70, "CALLBACK_ARGS": 71, "HREF": 72, "STYLE": 73, "ALPHA": 74, "stylesOpt": 75, "CSSCLASS": 76, "style": 77, "COMMA": 78, "styleComponent": 79, "NUM": 80, "COLON": 81, "UNIT": 82, "SPACE": 83, "BRKT": 84, "PCT": 85, "commentToken": 86, "textToken": 87, "graphCodeTokens": 88, "textNoTagsToken": 89, "TAGSTART": 90, "TAGEND": 91, "==": 92, "--": 93, "DEFAULT": 94, "MINUS": 95, "keywords": 96, "UNICODE_TEXT": 97, "BQUOTE_STR": 98, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 7: "CLASS_DIAGRAM", 8: "NEWLINE", 9: "EOF", 12: "SQS", 13: "STR", 14: "SQE", 19: "GENERICTYPE", 21: "LABEL", 31: "acc_title", 32: "acc_title_value", 33: "acc_descr", 34: "acc_descr_value", 35: "acc_descr_multiline_value", 37: "STRUCT_START", 39: "STRUCT_STOP", 40: "NAMESPACE", 42: "STYLE_SEPARATOR", 44: "CLASS", 45: "ANNOTATION_START", 46: "ANNOTATION_END", 47: "MEMBER", 48: "SEPARATOR", 50: "NOTE_FOR", 52: "NOTE", 53: "direction_tb", 54: "direction_bt", 55: "direction_rl", 56: "direction_lr", 59: "AGGREGATION", 60: "EXTENSION", 61: "COMPOSITION", 62: "DEPENDENCY", 63: "LOLLIPOP", 64: "LINE", 65: "DOTTED_LINE", 66: "CALLBACK", 67: "LINK", 68: "LINK_TARGET", 69: "CLICK", 70: "CALLBACK_NAME", 71: "CALLBACK_ARGS", 72: "HREF", 73: "STYLE", 74: "ALPHA", 76: "CSSCLASS", 78: "COMMA", 80: "NUM", 81: "COLON", 82: "UNIT", 83: "SPACE", 84: "BRKT", 85: "PCT", 88: "graphCodeTokens", 90: "TAGSTART", 91: "TAGEND", 92: "==", 93: "--", 94: "DEFAULT", 95: "MINUS", 96: "keywords", 97: "UNICODE_TEXT", 98: "BQUOTE_STR" }, + productions_: [0, [3, 1], [3, 1], [4, 1], [6, 4], [5, 1], [5, 2], [5, 3], [11, 3], [15, 1], [15, 2], [17, 1], [17, 1], [17, 2], [17, 2], [17, 2], [10, 1], [10, 2], [10, 1], [10, 1], [10, 1], [10, 1], [10, 1], [10, 1], [10, 1], [10, 1], [10, 1], [10, 2], [10, 2], [10, 1], [22, 4], [22, 5], [36, 2], [38, 1], [38, 2], [38, 3], [23, 1], [23, 3], [23, 4], [23, 6], [41, 2], [41, 3], [25, 4], [43, 1], [43, 2], [24, 1], [24, 2], [24, 1], [24, 1], [20, 3], [20, 4], [20, 4], [20, 5], [29, 3], [29, 2], [30, 1], [30, 1], [30, 1], [30, 1], [49, 3], [49, 2], [49, 2], [49, 1], [57, 1], [57, 1], [57, 1], [57, 1], [57, 1], [58, 1], [58, 1], [26, 3], [26, 4], [26, 3], [26, 4], [26, 4], [26, 5], [26, 3], [26, 4], [26, 4], [26, 5], [26, 4], [26, 5], [26, 5], [26, 6], [27, 3], [28, 3], [75, 1], [75, 3], [77, 1], [77, 2], [79, 1], [79, 1], [79, 1], [79, 1], [79, 1], [79, 1], [79, 1], [79, 1], [79, 1], [86, 1], [86, 1], [87, 1], [87, 1], [87, 1], [87, 1], [87, 1], [87, 1], [87, 1], [89, 1], [89, 1], [89, 1], [89, 1], [16, 1], [16, 1], [16, 1], [16, 1], [18, 1], [51, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 8: + this.$ = $$[$0 - 1]; + break; + case 9: + case 11: + case 12: + this.$ = $$[$0]; + break; + case 10: + case 13: + this.$ = $$[$0 - 1] + $$[$0]; + break; + case 14: + case 15: + this.$ = $$[$0 - 1] + "~" + $$[$0] + "~"; + break; + case 16: + yy.addRelation($$[$0]); + break; + case 17: + $$[$0 - 1].title = yy.cleanupLabel($$[$0]); + yy.addRelation($$[$0 - 1]); + break; + case 27: + this.$ = $$[$0].trim(); + yy.setAccTitle(this.$); + break; + case 28: + case 29: + this.$ = $$[$0].trim(); + yy.setAccDescription(this.$); + break; + case 30: + yy.addClassesToNamespace($$[$0 - 3], $$[$0 - 1]); + break; + case 31: + yy.addClassesToNamespace($$[$0 - 4], $$[$0 - 1]); + break; + case 32: + this.$ = $$[$0]; + yy.addNamespace($$[$0]); + break; + case 33: + this.$ = [$$[$0]]; + break; + case 34: + this.$ = [$$[$0 - 1]]; + break; + case 35: + $$[$0].unshift($$[$0 - 2]); + this.$ = $$[$0]; + break; + case 37: + yy.setCssClass($$[$0 - 2], $$[$0]); + break; + case 38: + yy.addMembers($$[$0 - 3], $$[$0 - 1]); + break; + case 39: + yy.setCssClass($$[$0 - 5], $$[$0 - 3]); + yy.addMembers($$[$0 - 5], $$[$0 - 1]); + break; + case 40: + this.$ = $$[$0]; + yy.addClass($$[$0]); + break; + case 41: + this.$ = $$[$0 - 1]; + yy.addClass($$[$0 - 1]); + yy.setClassLabel($$[$0 - 1], $$[$0]); + break; + case 42: + yy.addAnnotation($$[$0], $$[$0 - 2]); + break; + case 43: + this.$ = [$$[$0]]; + break; + case 44: + $$[$0].push($$[$0 - 1]); + this.$ = $$[$0]; + break; + case 45: + break; + case 46: + yy.addMember($$[$0 - 1], yy.cleanupLabel($$[$0])); + break; + case 47: + break; + case 48: + break; + case 49: + this.$ = { "id1": $$[$0 - 2], "id2": $$[$0], relation: $$[$0 - 1], relationTitle1: "none", relationTitle2: "none" }; + break; + case 50: + this.$ = { id1: $$[$0 - 3], id2: $$[$0], relation: $$[$0 - 1], relationTitle1: $$[$0 - 2], relationTitle2: "none" }; + break; + case 51: + this.$ = { id1: $$[$0 - 3], id2: $$[$0], relation: $$[$0 - 2], relationTitle1: "none", relationTitle2: $$[$0 - 1] }; + break; + case 52: + this.$ = { id1: $$[$0 - 4], id2: $$[$0], relation: $$[$0 - 2], relationTitle1: $$[$0 - 3], relationTitle2: $$[$0 - 1] }; + break; + case 53: + yy.addNote($$[$0], $$[$0 - 1]); + break; + case 54: + yy.addNote($$[$0]); + break; + case 55: + yy.setDirection("TB"); + break; + case 56: + yy.setDirection("BT"); + break; + case 57: + yy.setDirection("RL"); + break; + case 58: + yy.setDirection("LR"); + break; + case 59: + this.$ = { type1: $$[$0 - 2], type2: $$[$0], lineType: $$[$0 - 1] }; + break; + case 60: + this.$ = { type1: "none", type2: $$[$0], lineType: $$[$0 - 1] }; + break; + case 61: + this.$ = { type1: $$[$0 - 1], type2: "none", lineType: $$[$0] }; + break; + case 62: + this.$ = { type1: "none", type2: "none", lineType: $$[$0] }; + break; + case 63: + this.$ = yy.relationType.AGGREGATION; + break; + case 64: + this.$ = yy.relationType.EXTENSION; + break; + case 65: + this.$ = yy.relationType.COMPOSITION; + break; + case 66: + this.$ = yy.relationType.DEPENDENCY; + break; + case 67: + this.$ = yy.relationType.LOLLIPOP; + break; + case 68: + this.$ = yy.lineType.LINE; + break; + case 69: + this.$ = yy.lineType.DOTTED_LINE; + break; + case 70: + case 76: + this.$ = $$[$0 - 2]; + yy.setClickEvent($$[$0 - 1], $$[$0]); + break; + case 71: + case 77: + this.$ = $$[$0 - 3]; + yy.setClickEvent($$[$0 - 2], $$[$0 - 1]); + yy.setTooltip($$[$0 - 2], $$[$0]); + break; + case 72: + this.$ = $$[$0 - 2]; + yy.setLink($$[$0 - 1], $$[$0]); + break; + case 73: + this.$ = $$[$0 - 3]; + yy.setLink($$[$0 - 2], $$[$0 - 1], $$[$0]); + break; + case 74: + this.$ = $$[$0 - 3]; + yy.setLink($$[$0 - 2], $$[$0 - 1]); + yy.setTooltip($$[$0 - 2], $$[$0]); + break; + case 75: + this.$ = $$[$0 - 4]; + yy.setLink($$[$0 - 3], $$[$0 - 2], $$[$0]); + yy.setTooltip($$[$0 - 3], $$[$0 - 1]); + break; + case 78: + this.$ = $$[$0 - 3]; + yy.setClickEvent($$[$0 - 2], $$[$0 - 1], $$[$0]); + break; + case 79: + this.$ = $$[$0 - 4]; + yy.setClickEvent($$[$0 - 3], $$[$0 - 2], $$[$0 - 1]); + yy.setTooltip($$[$0 - 3], $$[$0]); + break; + case 80: + this.$ = $$[$0 - 3]; + yy.setLink($$[$0 - 2], $$[$0]); + break; + case 81: + this.$ = $$[$0 - 4]; + yy.setLink($$[$0 - 3], $$[$0 - 1], $$[$0]); + break; + case 82: + this.$ = $$[$0 - 4]; + yy.setLink($$[$0 - 3], $$[$0 - 1]); + yy.setTooltip($$[$0 - 3], $$[$0]); + break; + case 83: + this.$ = $$[$0 - 5]; + yy.setLink($$[$0 - 4], $$[$0 - 2], $$[$0]); + yy.setTooltip($$[$0 - 4], $$[$0 - 1]); + break; + case 84: + this.$ = $$[$0 - 2]; + yy.setCssStyle($$[$0 - 1], $$[$0]); + break; + case 85: + yy.setCssClass($$[$0 - 1], $$[$0]); + break; + case 86: + this.$ = [$$[$0]]; + break; + case 87: + $$[$0 - 2].push($$[$0]); + this.$ = $$[$0 - 2]; + break; + case 89: + this.$ = $$[$0 - 1] + $$[$0]; + break; + } + }, + table: [{ 3: 1, 4: 2, 5: 3, 6: 4, 7: [1, 6], 10: 5, 16: 37, 17: 20, 18: 38, 20: 7, 22: 8, 23: 9, 24: 10, 25: 11, 26: 12, 27: 13, 28: 14, 29: 15, 30: 16, 31: $V0, 33: $V1, 35: $V2, 36: 21, 40: $V3, 41: 22, 44: $V4, 45: $V5, 47: $V6, 48: $V7, 50: $V8, 52: $V9, 53: $Va, 54: $Vb, 55: $Vc, 56: $Vd, 66: $Ve, 67: $Vf, 69: $Vg, 73: $Vh, 74: $Vi, 76: $Vj, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, { 1: [3] }, { 1: [2, 1] }, { 1: [2, 2] }, { 1: [2, 3] }, o($Vo, [2, 5], { 8: [1, 46] }), { 8: [1, 47] }, o($Vp, [2, 16], { 21: [1, 48] }), o($Vp, [2, 18]), o($Vp, [2, 19]), o($Vp, [2, 20]), o($Vp, [2, 21]), o($Vp, [2, 22]), o($Vp, [2, 23]), o($Vp, [2, 24]), o($Vp, [2, 25]), o($Vp, [2, 26]), { 32: [1, 49] }, { 34: [1, 50] }, o($Vp, [2, 29]), o($Vp, [2, 45], { 49: 51, 57: 54, 58: 55, 13: [1, 52], 21: [1, 53], 59: $Vq, 60: $Vr, 61: $Vs, 62: $Vt, 63: $Vu, 64: $Vv, 65: $Vw }), { 37: [1, 63] }, o($Vx, [2, 36], { 37: [1, 65], 42: [1, 64] }), o($Vp, [2, 47]), o($Vp, [2, 48]), { 16: 66, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm }, { 16: 37, 17: 67, 18: 38, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, { 16: 37, 17: 68, 18: 38, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, { 16: 37, 17: 69, 18: 38, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, { 74: [1, 70] }, { 13: [1, 71] }, { 16: 37, 17: 72, 18: 38, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, { 13: $Vy, 51: 73 }, o($Vp, [2, 55]), o($Vp, [2, 56]), o($Vp, [2, 57]), o($Vp, [2, 58]), o($Vz, [2, 11], { 16: 37, 18: 38, 17: 75, 19: [1, 76], 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }), o($Vz, [2, 12], { 19: [1, 77] }), { 15: 78, 16: 79, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm }, { 16: 37, 17: 80, 18: 38, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, o($VA, [2, 112]), o($VA, [2, 113]), o($VA, [2, 114]), o($VA, [2, 115]), o([1, 8, 9, 12, 13, 19, 21, 37, 39, 42, 59, 60, 61, 62, 63, 64, 65, 70, 72], [2, 116]), o($Vo, [2, 6], { 10: 5, 20: 7, 22: 8, 23: 9, 24: 10, 25: 11, 26: 12, 27: 13, 28: 14, 29: 15, 30: 16, 17: 20, 36: 21, 41: 22, 16: 37, 18: 38, 5: 81, 31: $V0, 33: $V1, 35: $V2, 40: $V3, 44: $V4, 45: $V5, 47: $V6, 48: $V7, 50: $V8, 52: $V9, 53: $Va, 54: $Vb, 55: $Vc, 56: $Vd, 66: $Ve, 67: $Vf, 69: $Vg, 73: $Vh, 74: $Vi, 76: $Vj, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }), { 5: 82, 10: 5, 16: 37, 17: 20, 18: 38, 20: 7, 22: 8, 23: 9, 24: 10, 25: 11, 26: 12, 27: 13, 28: 14, 29: 15, 30: 16, 31: $V0, 33: $V1, 35: $V2, 36: 21, 40: $V3, 41: 22, 44: $V4, 45: $V5, 47: $V6, 48: $V7, 50: $V8, 52: $V9, 53: $Va, 54: $Vb, 55: $Vc, 56: $Vd, 66: $Ve, 67: $Vf, 69: $Vg, 73: $Vh, 74: $Vi, 76: $Vj, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, o($Vp, [2, 17]), o($Vp, [2, 27]), o($Vp, [2, 28]), { 13: [1, 84], 16: 37, 17: 83, 18: 38, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, { 49: 85, 57: 54, 58: 55, 59: $Vq, 60: $Vr, 61: $Vs, 62: $Vt, 63: $Vu, 64: $Vv, 65: $Vw }, o($Vp, [2, 46]), { 58: 86, 64: $Vv, 65: $Vw }, o($VB, [2, 62], { 57: 87, 59: $Vq, 60: $Vr, 61: $Vs, 62: $Vt, 63: $Vu }), o($VC, [2, 63]), o($VC, [2, 64]), o($VC, [2, 65]), o($VC, [2, 66]), o($VC, [2, 67]), o($VD, [2, 68]), o($VD, [2, 69]), { 8: [1, 89], 23: 90, 38: 88, 41: 22, 44: $V4 }, { 16: 91, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm }, { 43: 92, 47: $VE }, { 46: [1, 94] }, { 13: [1, 95] }, { 13: [1, 96] }, { 70: [1, 97], 72: [1, 98] }, { 21: $VF, 73: $VG, 74: $VH, 75: 99, 77: 100, 79: 101, 80: $VI, 81: $VJ, 82: $VK, 83: $VL, 84: $VM, 85: $VN }, { 74: [1, 111] }, { 13: $Vy, 51: 112 }, o($Vp, [2, 54]), o($Vp, [2, 117]), o($Vz, [2, 13]), o($Vz, [2, 14]), o($Vz, [2, 15]), { 37: [2, 32] }, { 15: 113, 16: 79, 37: [2, 9], 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm }, o($VO, [2, 40], { 11: 114, 12: [1, 115] }), o($Vo, [2, 7]), { 9: [1, 116] }, o($VP, [2, 49]), { 16: 37, 17: 117, 18: 38, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, { 13: [1, 119], 16: 37, 17: 118, 18: 38, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, o($VB, [2, 61], { 57: 120, 59: $Vq, 60: $Vr, 61: $Vs, 62: $Vt, 63: $Vu }), o($VB, [2, 60]), { 39: [1, 121] }, { 23: 90, 38: 122, 41: 22, 44: $V4 }, { 8: [1, 123], 39: [2, 33] }, o($Vx, [2, 37], { 37: [1, 124] }), { 39: [1, 125] }, { 39: [2, 43], 43: 126, 47: $VE }, { 16: 37, 17: 127, 18: 38, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, o($Vp, [2, 70], { 13: [1, 128] }), o($Vp, [2, 72], { 13: [1, 130], 68: [1, 129] }), o($Vp, [2, 76], { 13: [1, 131], 71: [1, 132] }), { 13: [1, 133] }, o($Vp, [2, 84], { 78: [1, 134] }), o($VQ, [2, 86], { 79: 135, 21: $VF, 73: $VG, 74: $VH, 80: $VI, 81: $VJ, 82: $VK, 83: $VL, 84: $VM, 85: $VN }), o($VR, [2, 88]), o($VR, [2, 90]), o($VR, [2, 91]), o($VR, [2, 92]), o($VR, [2, 93]), o($VR, [2, 94]), o($VR, [2, 95]), o($VR, [2, 96]), o($VR, [2, 97]), o($VR, [2, 98]), o($Vp, [2, 85]), o($Vp, [2, 53]), { 37: [2, 10] }, o($VO, [2, 41]), { 13: [1, 136] }, { 1: [2, 4] }, o($VP, [2, 51]), o($VP, [2, 50]), { 16: 37, 17: 137, 18: 38, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, o($VB, [2, 59]), o($Vp, [2, 30]), { 39: [1, 138] }, { 23: 90, 38: 139, 39: [2, 34], 41: 22, 44: $V4 }, { 43: 140, 47: $VE }, o($Vx, [2, 38]), { 39: [2, 44] }, o($Vp, [2, 42]), o($Vp, [2, 71]), o($Vp, [2, 73]), o($Vp, [2, 74], { 68: [1, 141] }), o($Vp, [2, 77]), o($Vp, [2, 78], { 13: [1, 142] }), o($Vp, [2, 80], { 13: [1, 144], 68: [1, 143] }), { 21: $VF, 73: $VG, 74: $VH, 77: 145, 79: 101, 80: $VI, 81: $VJ, 82: $VK, 83: $VL, 84: $VM, 85: $VN }, o($VR, [2, 89]), { 14: [1, 146] }, o($VP, [2, 52]), o($Vp, [2, 31]), { 39: [2, 35] }, { 39: [1, 147] }, o($Vp, [2, 75]), o($Vp, [2, 79]), o($Vp, [2, 81]), o($Vp, [2, 82], { 68: [1, 148] }), o($VQ, [2, 87], { 79: 135, 21: $VF, 73: $VG, 74: $VH, 80: $VI, 81: $VJ, 82: $VK, 83: $VL, 84: $VM, 85: $VN }), o($VO, [2, 8]), o($Vx, [2, 39]), o($Vp, [2, 83])], + defaultActions: { 2: [2, 1], 3: [2, 2], 4: [2, 3], 78: [2, 32], 113: [2, 10], 116: [2, 4], 126: [2, 44], 139: [2, 35] }, + parseError: function parseError(str2, hash) { + if (hash.recoverable) { + this.trace(str2); + } else { + var error = new Error(str2); + error.hash = hash; + throw error; + } + }, + parse: function parse2(input) { + var self2 = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex2() { + var token2; + token2 = tstack.pop() || lexer2.lex() || EOF; + if (typeof token2 !== "number") { + if (token2 instanceof Array) { + tstack = token2; + token2 = tstack.pop(); + } + token2 = self2.symbols_[token2] || token2; + } + return token2; + } + var symbol, state2, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state2 = stack[stack.length - 1]; + if (this.defaultActions[state2]) { + action = this.defaultActions[state2]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex2(); + } + action = table[state2] && table[state2][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state2]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state2 + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str2, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str2, hash); + } else { + throw new Error(str2); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch2 = this._input[0]; + this.yytext += ch2; + this.yyleng++; + this.offset++; + this.match += ch2; + this.matched += ch2; + var lines = ch2.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch2; + }, + // unshifts one char (or a string) into the input + unput: function(ch2) { + var len = ch2.length; + var lines = ch2.split(/(?:\r\n?|\n)/g); + this._input = ch2 + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next2 = this.match; + if (next2.length < 20) { + next2 += this._input.substr(0, 20 - next2.length); + } + return (next2.substr(0, 20) + (next2.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c2 = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c2 + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token2, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token2 = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token2) { + return token2; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token2, match, tempMatch, index2; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i2 = 0; i2 < rules.length; i2++) { + tempMatch = this._input.match(this.rules[rules[i2]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index2 = i2; + if (this.options.backtrack_lexer) { + token2 = this.test_match(tempMatch, rules[i2]); + if (token2 !== false) { + return token2; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token2 = this.test_match(match, rules[index2]); + if (token2 !== false) { + return token2; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex2() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: {}, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + return 53; + case 1: + return 54; + case 2: + return 55; + case 3: + return 56; + case 4: + break; + case 5: + break; + case 6: + this.begin("acc_title"); + return 31; + case 7: + this.popState(); + return "acc_title_value"; + case 8: + this.begin("acc_descr"); + return 33; + case 9: + this.popState(); + return "acc_descr_value"; + case 10: + this.begin("acc_descr_multiline"); + break; + case 11: + this.popState(); + break; + case 12: + return "acc_descr_multiline_value"; + case 13: + return 8; + case 14: + break; + case 15: + return 7; + case 16: + return 7; + case 17: + return "EDGE_STATE"; + case 18: + this.begin("callback_name"); + break; + case 19: + this.popState(); + break; + case 20: + this.popState(); + this.begin("callback_args"); + break; + case 21: + return 70; + case 22: + this.popState(); + break; + case 23: + return 71; + case 24: + this.popState(); + break; + case 25: + return "STR"; + case 26: + this.begin("string"); + break; + case 27: + return 73; + case 28: + this.begin("namespace"); + return 40; + case 29: + this.popState(); + return 8; + case 30: + break; + case 31: + this.begin("namespace-body"); + return 37; + case 32: + this.popState(); + return 39; + case 33: + return "EOF_IN_STRUCT"; + case 34: + return 8; + case 35: + break; + case 36: + return "EDGE_STATE"; + case 37: + this.begin("class"); + return 44; + case 38: + this.popState(); + return 8; + case 39: + break; + case 40: + this.popState(); + this.popState(); + return 39; + case 41: + this.begin("class-body"); + return 37; + case 42: + this.popState(); + return 39; + case 43: + return "EOF_IN_STRUCT"; + case 44: + return "EDGE_STATE"; + case 45: + return "OPEN_IN_STRUCT"; + case 46: + break; + case 47: + return "MEMBER"; + case 48: + return 76; + case 49: + return 66; + case 50: + return 67; + case 51: + return 69; + case 52: + return 50; + case 53: + return 52; + case 54: + return 45; + case 55: + return 46; + case 56: + return 72; + case 57: + this.popState(); + break; + case 58: + return "GENERICTYPE"; + case 59: + this.begin("generic"); + break; + case 60: + this.popState(); + break; + case 61: + return "BQUOTE_STR"; + case 62: + this.begin("bqstring"); + break; + case 63: + return 68; + case 64: + return 68; + case 65: + return 68; + case 66: + return 68; + case 67: + return 60; + case 68: + return 60; + case 69: + return 62; + case 70: + return 62; + case 71: + return 61; + case 72: + return 59; + case 73: + return 63; + case 74: + return 64; + case 75: + return 65; + case 76: + return 21; + case 77: + return 42; + case 78: + return 95; + case 79: + return "DOT"; + case 80: + return "PLUS"; + case 81: + return 81; + case 82: + return 78; + case 83: + return 84; + case 84: + return 84; + case 85: + return 85; + case 86: + return "EQUALS"; + case 87: + return "EQUALS"; + case 88: + return 74; + case 89: + return 12; + case 90: + return 14; + case 91: + return "PUNCTUATION"; + case 92: + return 80; + case 93: + return 97; + case 94: + return 83; + case 95: + return 83; + case 96: + return 9; + } + }, + rules: [/^(?:.*direction\s+TB[^\n]*)/, /^(?:.*direction\s+BT[^\n]*)/, /^(?:.*direction\s+RL[^\n]*)/, /^(?:.*direction\s+LR[^\n]*)/, /^(?:%%(?!\{)*[^\n]*(\r?\n?)+)/, /^(?:%%[^\n]*(\r?\n)*)/, /^(?:accTitle\s*:\s*)/, /^(?:(?!\n||)*[^\n]*)/, /^(?:accDescr\s*:\s*)/, /^(?:(?!\n||)*[^\n]*)/, /^(?:accDescr\s*\{\s*)/, /^(?:[\}])/, /^(?:[^\}]*)/, /^(?:\s*(\r?\n)+)/, /^(?:\s+)/, /^(?:classDiagram-v2\b)/, /^(?:classDiagram\b)/, /^(?:\[\*\])/, /^(?:call[\s]+)/, /^(?:\([\s]*\))/, /^(?:\()/, /^(?:[^(]*)/, /^(?:\))/, /^(?:[^)]*)/, /^(?:["])/, /^(?:[^"]*)/, /^(?:["])/, /^(?:style\b)/, /^(?:namespace\b)/, /^(?:\s*(\r?\n)+)/, /^(?:\s+)/, /^(?:[{])/, /^(?:[}])/, /^(?:$)/, /^(?:\s*(\r?\n)+)/, /^(?:\s+)/, /^(?:\[\*\])/, /^(?:class\b)/, /^(?:\s*(\r?\n)+)/, /^(?:\s+)/, /^(?:[}])/, /^(?:[{])/, /^(?:[}])/, /^(?:$)/, /^(?:\[\*\])/, /^(?:[{])/, /^(?:[\n])/, /^(?:[^{}\n]*)/, /^(?:cssClass\b)/, /^(?:callback\b)/, /^(?:link\b)/, /^(?:click\b)/, /^(?:note for\b)/, /^(?:note\b)/, /^(?:<<)/, /^(?:>>)/, /^(?:href\b)/, /^(?:[~])/, /^(?:[^~]*)/, /^(?:~)/, /^(?:[`])/, /^(?:[^`]+)/, /^(?:[`])/, /^(?:_self\b)/, /^(?:_blank\b)/, /^(?:_parent\b)/, /^(?:_top\b)/, /^(?:\s*<\|)/, /^(?:\s*\|>)/, /^(?:\s*>)/, /^(?:\s*<)/, /^(?:\s*\*)/, /^(?:\s*o\b)/, /^(?:\s*\(\))/, /^(?:--)/, /^(?:\.\.)/, /^(?::{1}[^:\n;]+)/, /^(?::{3})/, /^(?:-)/, /^(?:\.)/, /^(?:\+)/, /^(?::)/, /^(?:,)/, /^(?:#)/, /^(?:#)/, /^(?:%)/, /^(?:=)/, /^(?:=)/, /^(?:\w+)/, /^(?:\[)/, /^(?:\])/, /^(?:[!"#$%&'*+,-.`?\\/])/, /^(?:[0-9]+)/, /^(?:[\u00AA\u00B5\u00BA\u00C0-\u00D6\u00D8-\u00F6]|[\u00F8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377]|[\u037A-\u037D\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5]|[\u03F7-\u0481\u048A-\u0527\u0531-\u0556\u0559\u0561-\u0587\u05D0-\u05EA]|[\u05F0-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE]|[\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA]|[\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u08A0]|[\u08A2-\u08AC\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0977]|[\u0979-\u097F\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2]|[\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u0A05-\u0A0A]|[\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39]|[\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8]|[\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0B05-\u0B0C]|[\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C]|[\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99]|[\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0]|[\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C33\u0C35-\u0C39\u0C3D]|[\u0C58\u0C59\u0C60\u0C61\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3]|[\u0CB5-\u0CB9\u0CBD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D05-\u0D0C\u0D0E-\u0D10]|[\u0D12-\u0D3A\u0D3D\u0D4E\u0D60\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1]|[\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81]|[\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3]|[\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6]|[\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A]|[\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081]|[\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D]|[\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0]|[\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310]|[\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F4\u1401-\u166C]|[\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u1700-\u170C\u170E-\u1711]|[\u1720-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7]|[\u17DC\u1820-\u1877\u1880-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191C]|[\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19C1-\u19C7\u1A00-\u1A16]|[\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4B\u1B83-\u1BA0\u1BAE\u1BAF]|[\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1CE9-\u1CEC]|[\u1CEE-\u1CF1\u1CF5\u1CF6\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D]|[\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D]|[\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3]|[\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F]|[\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128]|[\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2183\u2184]|[\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3]|[\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6]|[\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE]|[\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005\u3006\u3031-\u3035\u303B\u303C]|[\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312D]|[\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FCC]|[\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B]|[\uA640-\uA66E\uA67F-\uA697\uA6A0-\uA6E5\uA717-\uA71F\uA722-\uA788]|[\uA78B-\uA78E\uA790-\uA793\uA7A0-\uA7AA\uA7F8-\uA801\uA803-\uA805]|[\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB]|[\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uAA00-\uAA28]|[\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA80-\uAAAF\uAAB1\uAAB5]|[\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4]|[\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E]|[\uABC0-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D]|[\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36]|[\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D]|[\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC]|[\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF]|[\uFFD2-\uFFD7\uFFDA-\uFFDC])/, /^(?:\s)/, /^(?:\s)/, /^(?:$)/], + conditions: { "namespace-body": { "rules": [26, 32, 33, 34, 35, 36, 37, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "namespace": { "rules": [26, 28, 29, 30, 31, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "class-body": { "rules": [26, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "class": { "rules": [26, 38, 39, 40, 41, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "acc_descr_multiline": { "rules": [11, 12, 26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "acc_descr": { "rules": [9, 26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "acc_title": { "rules": [7, 26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "callback_args": { "rules": [22, 23, 26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "callback_name": { "rules": [19, 20, 21, 26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "href": { "rules": [26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "struct": { "rules": [26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "generic": { "rules": [26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "bqstring": { "rules": [26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "string": { "rules": [24, 25, 26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "INITIAL": { "rules": [0, 1, 2, 3, 4, 5, 6, 8, 10, 13, 14, 15, 16, 17, 18, 26, 27, 28, 37, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser2() { + this.yy = {}; + } + Parser2.prototype = parser2; + parser2.Parser = Parser2; + return new Parser2(); + }(); + parser$c.parser = parser$c; + const parser$d = parser$c; + const visibilityValues = ["#", "+", "~", "-", ""]; + class ClassMember { + constructor(input, memberType) { + this.memberType = memberType; + this.visibility = ""; + this.classifier = ""; + const sanitizedInput = sanitizeText$6(input, getConfig$1()); + this.parseMember(sanitizedInput); + } + getDisplayDetails() { + let displayText = this.visibility + parseGenericTypes(this.id); + if (this.memberType === "method") { + displayText += `(${parseGenericTypes(this.parameters.trim())})`; + if (this.returnType) { + displayText += " : " + parseGenericTypes(this.returnType); + } + } + displayText = displayText.trim(); + const cssStyle = this.parseClassifier(); + return { + displayText, + cssStyle + }; + } + parseMember(input) { + let potentialClassifier = ""; + if (this.memberType === "method") { + const methodRegEx = /([#+~-])?(.+)\((.*)\)([\s$*])?(.*)([$*])?/; + const match = input.match(methodRegEx); + if (match) { + const detectedVisibility = match[1] ? match[1].trim() : ""; + if (visibilityValues.includes(detectedVisibility)) { + this.visibility = detectedVisibility; + } + this.id = match[2].trim(); + this.parameters = match[3] ? match[3].trim() : ""; + potentialClassifier = match[4] ? match[4].trim() : ""; + this.returnType = match[5] ? match[5].trim() : ""; + if (potentialClassifier === "") { + const lastChar = this.returnType.substring(this.returnType.length - 1); + if (lastChar.match(/[$*]/)) { + potentialClassifier = lastChar; + this.returnType = this.returnType.substring(0, this.returnType.length - 1); + } + } + } + } else { + const length2 = input.length; + const firstChar = input.substring(0, 1); + const lastChar = input.substring(length2 - 1); + if (visibilityValues.includes(firstChar)) { + this.visibility = firstChar; + } + if (lastChar.match(/[$*]/)) { + potentialClassifier = lastChar; + } + this.id = input.substring( + this.visibility === "" ? 0 : 1, + potentialClassifier === "" ? length2 : length2 - 1 + ); + } + this.classifier = potentialClassifier; + } + parseClassifier() { + switch (this.classifier) { + case "*": + return "font-style:italic;"; + case "$": + return "text-decoration:underline;"; + default: + return ""; + } + } + } + const MERMAID_DOM_ID_PREFIX = "classId-"; + let relations = []; + let classes$2 = {}; + let notes = []; + let classCounter = 0; + let namespaces = {}; + let namespaceCounter = 0; + let functions = []; + const sanitizeText$2 = (txt) => common$1.sanitizeText(txt, getConfig$1()); + const splitClassNameAndType = function(_id) { + const id2 = common$1.sanitizeText(_id, getConfig$1()); + let genericType = ""; + let className = id2; + if (id2.indexOf("~") > 0) { + const split = id2.split("~"); + className = sanitizeText$2(split[0]); + genericType = sanitizeText$2(split[1]); + } + return { className, type: genericType }; + }; + const setClassLabel = function(_id, label) { + const id2 = common$1.sanitizeText(_id, getConfig$1()); + if (label) { + label = sanitizeText$2(label); + } + const { className } = splitClassNameAndType(id2); + classes$2[className].label = label; + }; + const addClass = function(_id) { + const id2 = common$1.sanitizeText(_id, getConfig$1()); + const { className, type: type2 } = splitClassNameAndType(id2); + if (Object.hasOwn(classes$2, className)) { + return; + } + const name = common$1.sanitizeText(className, getConfig$1()); + classes$2[name] = { + id: name, + type: type2, + label: name, + cssClasses: [], + methods: [], + members: [], + annotations: [], + styles: [], + domId: MERMAID_DOM_ID_PREFIX + name + "-" + classCounter + }; + classCounter++; + }; + const lookUpDomId = function(_id) { + const id2 = common$1.sanitizeText(_id, getConfig$1()); + if (id2 in classes$2) { + return classes$2[id2].domId; + } + throw new Error("Class not found: " + id2); + }; + const clear$6 = function() { + relations = []; + classes$2 = {}; + notes = []; + functions = []; + functions.push(setupToolTips); + namespaces = {}; + namespaceCounter = 0; + clear$n(); + }; + const getClass = function(id2) { + return classes$2[id2]; + }; + const getClasses$5 = function() { + return classes$2; + }; + const getRelations$1 = function() { + return relations; + }; + const getNotes = function() { + return notes; + }; + const addRelation$1 = function(relation) { + log$1.debug("Adding relation: " + JSON.stringify(relation)); + addClass(relation.id1); + addClass(relation.id2); + relation.id1 = splitClassNameAndType(relation.id1).className; + relation.id2 = splitClassNameAndType(relation.id2).className; + relation.relationTitle1 = common$1.sanitizeText(relation.relationTitle1.trim(), getConfig$1()); + relation.relationTitle2 = common$1.sanitizeText(relation.relationTitle2.trim(), getConfig$1()); + relations.push(relation); + }; + const addAnnotation = function(className, annotation) { + const validatedClassName = splitClassNameAndType(className).className; + classes$2[validatedClassName].annotations.push(annotation); + }; + const addMember = function(className, member) { + addClass(className); + const validatedClassName = splitClassNameAndType(className).className; + const theClass = classes$2[validatedClassName]; + if (typeof member === "string") { + const memberString = member.trim(); + if (memberString.startsWith("<<") && memberString.endsWith(">>")) { + theClass.annotations.push(sanitizeText$2(memberString.substring(2, memberString.length - 2))); + } else if (memberString.indexOf(")") > 0) { + theClass.methods.push(new ClassMember(memberString, "method")); + } else if (memberString) { + theClass.members.push(new ClassMember(memberString, "attribute")); + } + } + }; + const addMembers = function(className, members) { + if (Array.isArray(members)) { + members.reverse(); + members.forEach((member) => addMember(className, member)); + } + }; + const addNote = function(text2, className) { + const note2 = { + id: `note${notes.length}`, + class: className, + text: text2 + }; + notes.push(note2); + }; + const cleanupLabel$1 = function(label) { + if (label.startsWith(":")) { + label = label.substring(1); + } + return sanitizeText$2(label.trim()); + }; + const setCssClass$2 = function(ids, className) { + ids.split(",").forEach(function(_id) { + let id2 = _id; + if (_id[0].match(/\d/)) { + id2 = MERMAID_DOM_ID_PREFIX + id2; + } + if (classes$2[id2] !== void 0) { + classes$2[id2].cssClasses.push(className); + } + }); + }; + const setTooltip = function(ids, tooltip) { + ids.split(",").forEach(function(id2) { + if (tooltip !== void 0) { + classes$2[id2].tooltip = sanitizeText$2(tooltip); + } + }); + }; + const getTooltip = function(id2, namespace2) { + if (namespace2) { + return namespaces[namespace2].classes[id2].tooltip; + } + return classes$2[id2].tooltip; + }; + const setLink = function(ids, linkStr, target) { + const config2 = getConfig$1(); + ids.split(",").forEach(function(_id) { + let id2 = _id; + if (_id[0].match(/\d/)) { + id2 = MERMAID_DOM_ID_PREFIX + id2; + } + if (classes$2[id2] !== void 0) { + classes$2[id2].link = utils$1.formatUrl(linkStr, config2); + if (config2.securityLevel === "sandbox") { + classes$2[id2].linkTarget = "_top"; + } else if (typeof target === "string") { + classes$2[id2].linkTarget = sanitizeText$2(target); + } else { + classes$2[id2].linkTarget = "_blank"; + } + } + }); + setCssClass$2(ids, "clickable"); + }; + const setClickEvent = function(ids, functionName, functionArgs) { + ids.split(",").forEach(function(id2) { + setClickFunc(id2, functionName, functionArgs); + classes$2[id2].haveCallback = true; + }); + setCssClass$2(ids, "clickable"); + }; + const setClickFunc = function(_domId, functionName, functionArgs) { + const domId = common$1.sanitizeText(_domId, getConfig$1()); + const config2 = getConfig$1(); + if (config2.securityLevel !== "loose") { + return; + } + if (functionName === void 0) { + return; + } + const id2 = domId; + if (classes$2[id2] !== void 0) { + const elemId = lookUpDomId(id2); + let argList = []; + if (typeof functionArgs === "string") { + argList = functionArgs.split(/,(?=(?:(?:[^"]*"){2})*[^"]*$)/); + for (let i2 = 0; i2 < argList.length; i2++) { + let item = argList[i2].trim(); + if (item.charAt(0) === '"' && item.charAt(item.length - 1) === '"') { + item = item.substr(1, item.length - 2); + } + argList[i2] = item; + } + } + if (argList.length === 0) { + argList.push(elemId); + } + functions.push(function() { + const elem = document.querySelector(`[id="${elemId}"]`); + if (elem !== null) { + elem.addEventListener( + "click", + function() { + utils$1.runFunc(functionName, ...argList); + }, + false + ); + } + }); + } + }; + const bindFunctions = function(element2) { + functions.forEach(function(fun) { + fun(element2); + }); + }; + const lineType$1 = { + LINE: 0, + DOTTED_LINE: 1 + }; + const relationType$1 = { + AGGREGATION: 0, + EXTENSION: 1, + COMPOSITION: 2, + DEPENDENCY: 3, + LOLLIPOP: 4 + }; + const setupToolTips = function(element2) { + let tooltipElem = d3select(".mermaidTooltip"); + if ((tooltipElem._groups || tooltipElem)[0][0] === null) { + tooltipElem = d3select("body").append("div").attr("class", "mermaidTooltip").style("opacity", 0); + } + const svg2 = d3select(element2).select("svg"); + const nodes2 = svg2.selectAll("g.node"); + nodes2.on("mouseover", function() { + const el = d3select(this); + const title2 = el.attr("title"); + if (title2 === null) { + return; + } + const rect2 = this.getBoundingClientRect(); + tooltipElem.transition().duration(200).style("opacity", ".9"); + tooltipElem.text(el.attr("title")).style("left", window.scrollX + rect2.left + (rect2.right - rect2.left) / 2 + "px").style("top", window.scrollY + rect2.top - 14 + document.body.scrollTop + "px"); + tooltipElem.html(tooltipElem.html().replace(/<br\/>/g, "
    ")); + el.classed("hover", true); + }).on("mouseout", function() { + tooltipElem.transition().duration(500).style("opacity", 0); + const el = d3select(this); + el.classed("hover", false); + }); + }; + functions.push(setupToolTips); + let direction$1 = "TB"; + const getDirection$1 = () => direction$1; + const setDirection$1 = (dir2) => { + direction$1 = dir2; + }; + const addNamespace = function(id2) { + if (namespaces[id2] !== void 0) { + return; + } + namespaces[id2] = { + id: id2, + classes: {}, + children: {}, + domId: MERMAID_DOM_ID_PREFIX + id2 + "-" + namespaceCounter + }; + namespaceCounter++; + }; + const getNamespace = function(name) { + return namespaces[name]; + }; + const getNamespaces = function() { + return namespaces; + }; + const addClassesToNamespace = function(id2, classNames) { + if (namespaces[id2] === void 0) { + return; + } + for (const name of classNames) { + const { className } = splitClassNameAndType(name); + classes$2[className].parent = id2; + namespaces[id2].classes[className] = classes$2[className]; + } + }; + const setCssStyle = function(id2, styles2) { + const thisClass = classes$2[id2]; + if (!styles2 || !thisClass) { + return; + } + for (const s of styles2) { + if (s.includes(",")) { + thisClass.styles.push(...s.split(",")); + } else { + thisClass.styles.push(s); + } + } + }; + const db$8 = { + setAccTitle, + getAccTitle, + getAccDescription, + setAccDescription, + getConfig: () => getConfig$1().class, + addClass, + bindFunctions, + clear: clear$6, + getClass, + getClasses: getClasses$5, + getNotes, + addAnnotation, + addNote, + getRelations: getRelations$1, + addRelation: addRelation$1, + getDirection: getDirection$1, + setDirection: setDirection$1, + addMember, + addMembers, + cleanupLabel: cleanupLabel$1, + lineType: lineType$1, + relationType: relationType$1, + setClickEvent, + setCssClass: setCssClass$2, + setLink, + getTooltip, + setTooltip, + lookUpDomId, + setDiagramTitle, + getDiagramTitle, + setClassLabel, + addNamespace, + addClassesToNamespace, + getNamespace, + getNamespaces, + setCssStyle + }; + const getStyles$6 = (options2) => `g.classGroup text { + fill: ${options2.nodeBorder || options2.classText}; + stroke: none; + font-family: ${options2.fontFamily}; + font-size: 10px; + + .title { + font-weight: bolder; + } + +} + +.nodeLabel, .edgeLabel { + color: ${options2.classText}; +} +.edgeLabel .label rect { + fill: ${options2.mainBkg}; +} +.label text { + fill: ${options2.classText}; +} +.edgeLabel .label span { + background: ${options2.mainBkg}; +} + +.classTitle { + font-weight: bolder; +} +.node rect, + .node circle, + .node ellipse, + .node polygon, + .node path { + fill: ${options2.mainBkg}; + stroke: ${options2.nodeBorder}; + stroke-width: 1px; + } + + +.divider { + stroke: ${options2.nodeBorder}; + stroke-width: 1; +} + +g.clickable { + cursor: pointer; +} + +g.classGroup rect { + fill: ${options2.mainBkg}; + stroke: ${options2.nodeBorder}; +} + +g.classGroup line { + stroke: ${options2.nodeBorder}; + stroke-width: 1; +} + +.classLabel .box { + stroke: none; + stroke-width: 0; + fill: ${options2.mainBkg}; + opacity: 0.5; +} + +.classLabel .label { + fill: ${options2.nodeBorder}; + font-size: 10px; +} + +.relation { + stroke: ${options2.lineColor}; + stroke-width: 1; + fill: none; +} + +.dashed-line{ + stroke-dasharray: 3; +} + +.dotted-line{ + stroke-dasharray: 1 2; +} + +#compositionStart, .composition { + fill: ${options2.lineColor} !important; + stroke: ${options2.lineColor} !important; + stroke-width: 1; +} + +#compositionEnd, .composition { + fill: ${options2.lineColor} !important; + stroke: ${options2.lineColor} !important; + stroke-width: 1; +} + +#dependencyStart, .dependency { + fill: ${options2.lineColor} !important; + stroke: ${options2.lineColor} !important; + stroke-width: 1; +} + +#dependencyStart, .dependency { + fill: ${options2.lineColor} !important; + stroke: ${options2.lineColor} !important; + stroke-width: 1; +} + +#extensionStart, .extension { + fill: transparent !important; + stroke: ${options2.lineColor} !important; + stroke-width: 1; +} + +#extensionEnd, .extension { + fill: transparent !important; + stroke: ${options2.lineColor} !important; + stroke-width: 1; +} + +#aggregationStart, .aggregation { + fill: transparent !important; + stroke: ${options2.lineColor} !important; + stroke-width: 1; +} + +#aggregationEnd, .aggregation { + fill: transparent !important; + stroke: ${options2.lineColor} !important; + stroke-width: 1; +} + +#lollipopStart, .lollipop { + fill: ${options2.mainBkg} !important; + stroke: ${options2.lineColor} !important; + stroke-width: 1; +} + +#lollipopEnd, .lollipop { + fill: ${options2.mainBkg} !important; + stroke: ${options2.lineColor} !important; + stroke-width: 1; +} + +.edgeTerminals { + font-size: 11px; + line-height: initial; +} + +.classTitleText { + text-anchor: middle; + font-size: 18px; + fill: ${options2.textColor}; +} +`; + const styles$5 = getStyles$6; + let edgeCount$2 = 0; + const drawEdge$1 = function(elem, path2, relation, conf2, diagObj) { + const getRelationType = function(type2) { + switch (type2) { + case diagObj.db.relationType.AGGREGATION: + return "aggregation"; + case diagObj.db.relationType.EXTENSION: + return "extension"; + case diagObj.db.relationType.COMPOSITION: + return "composition"; + case diagObj.db.relationType.DEPENDENCY: + return "dependency"; + case diagObj.db.relationType.LOLLIPOP: + return "lollipop"; + } + }; + path2.points = path2.points.filter((p) => !Number.isNaN(p.y)); + const lineData = path2.points; + const lineFunction = line$1().x(function(d) { + return d.x; + }).y(function(d) { + return d.y; + }).curve(curveBasis); + const svgPath = elem.append("path").attr("d", lineFunction(lineData)).attr("id", "edge" + edgeCount$2).attr("class", "relation"); + let url = ""; + if (conf2.arrowMarkerAbsolute) { + url = window.location.protocol + "//" + window.location.host + window.location.pathname + window.location.search; + url = url.replace(/\(/g, "\\("); + url = url.replace(/\)/g, "\\)"); + } + if (relation.relation.lineType == 1) { + svgPath.attr("class", "relation dashed-line"); + } + if (relation.relation.lineType == 10) { + svgPath.attr("class", "relation dotted-line"); + } + if (relation.relation.type1 !== "none") { + svgPath.attr( + "marker-start", + "url(" + url + "#" + getRelationType(relation.relation.type1) + "Start)" + ); + } + if (relation.relation.type2 !== "none") { + svgPath.attr( + "marker-end", + "url(" + url + "#" + getRelationType(relation.relation.type2) + "End)" + ); + } + let x2, y2; + const l = path2.points.length; + let labelPosition = utils$1.calcLabelPosition(path2.points); + x2 = labelPosition.x; + y2 = labelPosition.y; + let p1_card_x, p1_card_y; + let p2_card_x, p2_card_y; + if (l % 2 !== 0 && l > 1) { + let cardinality_1_point = utils$1.calcCardinalityPosition( + relation.relation.type1 !== "none", + path2.points, + path2.points[0] + ); + let cardinality_2_point = utils$1.calcCardinalityPosition( + relation.relation.type2 !== "none", + path2.points, + path2.points[l - 1] + ); + log$1.debug("cardinality_1_point " + JSON.stringify(cardinality_1_point)); + log$1.debug("cardinality_2_point " + JSON.stringify(cardinality_2_point)); + p1_card_x = cardinality_1_point.x; + p1_card_y = cardinality_1_point.y; + p2_card_x = cardinality_2_point.x; + p2_card_y = cardinality_2_point.y; + } + if (relation.title !== void 0) { + const g = elem.append("g").attr("class", "classLabel"); + const label = g.append("text").attr("class", "label").attr("x", x2).attr("y", y2).attr("fill", "red").attr("text-anchor", "middle").text(relation.title); + window.label = label; + const bounds2 = label.node().getBBox(); + g.insert("rect", ":first-child").attr("class", "box").attr("x", bounds2.x - conf2.padding / 2).attr("y", bounds2.y - conf2.padding / 2).attr("width", bounds2.width + conf2.padding).attr("height", bounds2.height + conf2.padding); + } + log$1.info("Rendering relation " + JSON.stringify(relation)); + if (relation.relationTitle1 !== void 0 && relation.relationTitle1 !== "none") { + const g = elem.append("g").attr("class", "cardinality"); + g.append("text").attr("class", "type1").attr("x", p1_card_x).attr("y", p1_card_y).attr("fill", "black").attr("font-size", "6").text(relation.relationTitle1); + } + if (relation.relationTitle2 !== void 0 && relation.relationTitle2 !== "none") { + const g = elem.append("g").attr("class", "cardinality"); + g.append("text").attr("class", "type2").attr("x", p2_card_x).attr("y", p2_card_y).attr("fill", "black").attr("font-size", "6").text(relation.relationTitle2); + } + edgeCount$2++; + }; + const drawClass = function(elem, classDef, conf2, diagObj) { + log$1.debug("Rendering class ", classDef, conf2); + const id2 = classDef.id; + const classInfo = { + id: id2, + label: classDef.id, + width: 0, + height: 0 + }; + const g = elem.append("g").attr("id", diagObj.db.lookUpDomId(id2)).attr("class", "classGroup"); + let title2; + if (classDef.link) { + title2 = g.append("svg:a").attr("xlink:href", classDef.link).attr("target", classDef.linkTarget).append("text").attr("y", conf2.textHeight + conf2.padding).attr("x", 0); + } else { + title2 = g.append("text").attr("y", conf2.textHeight + conf2.padding).attr("x", 0); + } + let isFirst = true; + classDef.annotations.forEach(function(member) { + const titleText2 = title2.append("tspan").text("«" + member + "»"); + if (!isFirst) { + titleText2.attr("dy", conf2.textHeight); + } + isFirst = false; + }); + let classTitleString = getClassTitleString(classDef); + const classTitle = title2.append("tspan").text(classTitleString).attr("class", "title"); + if (!isFirst) { + classTitle.attr("dy", conf2.textHeight); + } + const titleHeight = title2.node().getBBox().height; + let membersLine; + let membersBox; + let methodsLine; + if (classDef.members.length > 0) { + membersLine = g.append("line").attr("x1", 0).attr("y1", conf2.padding + titleHeight + conf2.dividerMargin / 2).attr("y2", conf2.padding + titleHeight + conf2.dividerMargin / 2); + const members = g.append("text").attr("x", conf2.padding).attr("y", titleHeight + conf2.dividerMargin + conf2.textHeight).attr("fill", "white").attr("class", "classText"); + isFirst = true; + classDef.members.forEach(function(member) { + addTspan(members, member, isFirst, conf2); + isFirst = false; + }); + membersBox = members.node().getBBox(); + } + if (classDef.methods.length > 0) { + methodsLine = g.append("line").attr("x1", 0).attr("y1", conf2.padding + titleHeight + conf2.dividerMargin + membersBox.height).attr("y2", conf2.padding + titleHeight + conf2.dividerMargin + membersBox.height); + const methods = g.append("text").attr("x", conf2.padding).attr("y", titleHeight + 2 * conf2.dividerMargin + membersBox.height + conf2.textHeight).attr("fill", "white").attr("class", "classText"); + isFirst = true; + classDef.methods.forEach(function(method) { + addTspan(methods, method, isFirst, conf2); + isFirst = false; + }); + } + const classBox = g.node().getBBox(); + var cssClassStr = " "; + if (classDef.cssClasses.length > 0) { + cssClassStr = cssClassStr + classDef.cssClasses.join(" "); + } + const rect2 = g.insert("rect", ":first-child").attr("x", 0).attr("y", 0).attr("width", classBox.width + 2 * conf2.padding).attr("height", classBox.height + conf2.padding + 0.5 * conf2.dividerMargin).attr("class", cssClassStr); + const rectWidth = rect2.node().getBBox().width; + title2.node().childNodes.forEach(function(x2) { + x2.setAttribute("x", (rectWidth - x2.getBBox().width) / 2); + }); + if (classDef.tooltip) { + title2.insert("title").text(classDef.tooltip); + } + if (membersLine) { + membersLine.attr("x2", rectWidth); + } + if (methodsLine) { + methodsLine.attr("x2", rectWidth); + } + classInfo.width = rectWidth; + classInfo.height = classBox.height + conf2.padding + 0.5 * conf2.dividerMargin; + return classInfo; + }; + const getClassTitleString = function(classDef) { + let classTitleString = classDef.id; + if (classDef.type) { + classTitleString += "<" + parseGenericTypes(classDef.type) + ">"; + } + return classTitleString; + }; + const drawNote$1 = function(elem, note2, conf2, diagObj) { + log$1.debug("Rendering note ", note2, conf2); + const id2 = note2.id; + const noteInfo = { + id: id2, + text: note2.text, + width: 0, + height: 0 + }; + const g = elem.append("g").attr("id", id2).attr("class", "classGroup"); + let text2 = g.append("text").attr("y", conf2.textHeight + conf2.padding).attr("x", 0); + const lines = JSON.parse(`"${note2.text}"`).split("\n"); + lines.forEach(function(line2) { + log$1.debug(`Adding line: ${line2}`); + text2.append("tspan").text(line2).attr("class", "title").attr("dy", conf2.textHeight); + }); + const noteBox = g.node().getBBox(); + const rect2 = g.insert("rect", ":first-child").attr("x", 0).attr("y", 0).attr("width", noteBox.width + 2 * conf2.padding).attr( + "height", + noteBox.height + lines.length * conf2.textHeight + conf2.padding + 0.5 * conf2.dividerMargin + ); + const rectWidth = rect2.node().getBBox().width; + text2.node().childNodes.forEach(function(x2) { + x2.setAttribute("x", (rectWidth - x2.getBBox().width) / 2); + }); + noteInfo.width = rectWidth; + noteInfo.height = noteBox.height + lines.length * conf2.textHeight + conf2.padding + 0.5 * conf2.dividerMargin; + return noteInfo; + }; + const addTspan = function(textEl, member, isFirst, conf2) { + const { displayText, cssStyle } = member.getDisplayDetails(); + const tSpan = textEl.append("tspan").attr("x", conf2.padding).text(displayText); + if (cssStyle !== "") { + tSpan.attr("style", member.cssStyle); + } + if (!isFirst) { + tSpan.attr("dy", conf2.textHeight); + } + }; + const svgDraw$2 = { + getClassTitleString, + drawClass, + drawEdge: drawEdge$1, + drawNote: drawNote$1 + }; + let idCache$2 = {}; + const padding$1 = 20; + const getGraphId = function(label) { + const foundEntry = Object.entries(idCache$2).find((entry) => entry[1].label === label); + if (foundEntry) { + return foundEntry[0]; + } + }; + const insertMarkers$1 = function(elem) { + elem.append("defs").append("marker").attr("id", "extensionStart").attr("class", "extension").attr("refX", 0).attr("refY", 7).attr("markerWidth", 190).attr("markerHeight", 240).attr("orient", "auto").append("path").attr("d", "M 1,7 L18,13 V 1 Z"); + elem.append("defs").append("marker").attr("id", "extensionEnd").attr("refX", 19).attr("refY", 7).attr("markerWidth", 20).attr("markerHeight", 28).attr("orient", "auto").append("path").attr("d", "M 1,1 V 13 L18,7 Z"); + elem.append("defs").append("marker").attr("id", "compositionStart").attr("class", "extension").attr("refX", 0).attr("refY", 7).attr("markerWidth", 190).attr("markerHeight", 240).attr("orient", "auto").append("path").attr("d", "M 18,7 L9,13 L1,7 L9,1 Z"); + elem.append("defs").append("marker").attr("id", "compositionEnd").attr("refX", 19).attr("refY", 7).attr("markerWidth", 20).attr("markerHeight", 28).attr("orient", "auto").append("path").attr("d", "M 18,7 L9,13 L1,7 L9,1 Z"); + elem.append("defs").append("marker").attr("id", "aggregationStart").attr("class", "extension").attr("refX", 0).attr("refY", 7).attr("markerWidth", 190).attr("markerHeight", 240).attr("orient", "auto").append("path").attr("d", "M 18,7 L9,13 L1,7 L9,1 Z"); + elem.append("defs").append("marker").attr("id", "aggregationEnd").attr("refX", 19).attr("refY", 7).attr("markerWidth", 20).attr("markerHeight", 28).attr("orient", "auto").append("path").attr("d", "M 18,7 L9,13 L1,7 L9,1 Z"); + elem.append("defs").append("marker").attr("id", "dependencyStart").attr("class", "extension").attr("refX", 0).attr("refY", 7).attr("markerWidth", 190).attr("markerHeight", 240).attr("orient", "auto").append("path").attr("d", "M 5,7 L9,13 L1,7 L9,1 Z"); + elem.append("defs").append("marker").attr("id", "dependencyEnd").attr("refX", 19).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"); + }; + const draw$9 = function(text2, id2, _version, diagObj) { + const conf2 = getConfig$1().class; + idCache$2 = {}; + log$1.info("Rendering diagram " + text2); + const securityLevel = getConfig$1().securityLevel; + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = d3select("#i" + id2); + } + const root2 = securityLevel === "sandbox" ? d3select(sandboxElement.nodes()[0].contentDocument.body) : d3select("body"); + const diagram2 = root2.select(`[id='${id2}']`); + insertMarkers$1(diagram2); + const g = new Graph({ + multigraph: true + }); + g.setGraph({ + isMultiGraph: true + }); + g.setDefaultEdgeLabel(function() { + return {}; + }); + const classes2 = diagObj.db.getClasses(); + const keys2 = Object.keys(classes2); + for (const key of keys2) { + const classDef = classes2[key]; + const node2 = svgDraw$2.drawClass(diagram2, classDef, conf2, diagObj); + idCache$2[node2.id] = node2; + g.setNode(node2.id, node2); + log$1.info("Org height: " + node2.height); + } + const relations2 = diagObj.db.getRelations(); + relations2.forEach(function(relation) { + log$1.info( + // cspell:ignore tjoho + "tjoho" + getGraphId(relation.id1) + getGraphId(relation.id2) + JSON.stringify(relation) + ); + g.setEdge( + getGraphId(relation.id1), + getGraphId(relation.id2), + { + relation + }, + relation.title || "DEFAULT" + ); + }); + const notes2 = diagObj.db.getNotes(); + notes2.forEach(function(note2) { + log$1.debug(`Adding note: ${JSON.stringify(note2)}`); + const node2 = svgDraw$2.drawNote(diagram2, note2, conf2, diagObj); + idCache$2[node2.id] = node2; + g.setNode(node2.id, node2); + if (note2.class && note2.class in classes2) { + g.setEdge( + note2.id, + getGraphId(note2.class), + { + relation: { + id1: note2.id, + id2: note2.class, + relation: { + type1: "none", + type2: "none", + lineType: 10 + } + } + }, + "DEFAULT" + ); + } + }); + layout$1(g); + g.nodes().forEach(function(v) { + if (v !== void 0 && g.node(v) !== void 0) { + log$1.debug("Node " + v + ": " + JSON.stringify(g.node(v))); + root2.select("#" + (diagObj.db.lookUpDomId(v) || v)).attr( + "transform", + "translate(" + (g.node(v).x - g.node(v).width / 2) + "," + (g.node(v).y - g.node(v).height / 2) + " )" + ); + } + }); + g.edges().forEach(function(e) { + if (e !== void 0 && g.edge(e) !== void 0) { + log$1.debug("Edge " + e.v + " -> " + e.w + ": " + JSON.stringify(g.edge(e))); + svgDraw$2.drawEdge(diagram2, g.edge(e), g.edge(e).relation, conf2, diagObj); + } + }); + const svgBounds = diagram2.node().getBBox(); + const width2 = svgBounds.width + padding$1 * 2; + const height = svgBounds.height + padding$1 * 2; + configureSvgSize(diagram2, height, width2, conf2.useMaxWidth); + const vBox = `${svgBounds.x - padding$1} ${svgBounds.y - padding$1} ${width2} ${height}`; + log$1.debug(`viewBox ${vBox}`); + diagram2.attr("viewBox", vBox); + }; + const renderer$9 = { + draw: draw$9 + }; + const diagram$9 = { + parser: parser$d, + db: db$8, + renderer: renderer$9, + styles: styles$5, + init: (cnf) => { + if (!cnf.class) { + cnf.class = {}; + } + cnf.class.arrowMarkerAbsolute = cnf.arrowMarkerAbsolute; + db$8.clear(); + } + }; + const classDiagram = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + diagram: diagram$9 + }, Symbol.toStringTag, { value: "Module" })); + const sanitizeText$1 = (txt) => common$1.sanitizeText(txt, getConfig$1()); + let conf$3 = { + dividerMargin: 10, + padding: 5, + textHeight: 10, + curve: void 0 + }; + const addNamespaces = function(namespaces2, g, _id, diagObj) { + const keys2 = Object.keys(namespaces2); + log$1.info("keys:", keys2); + log$1.info(namespaces2); + keys2.forEach(function(id2) { + var _a2, _b2; + const vertex = namespaces2[id2]; + const shape = "rect"; + const node2 = { + shape, + id: vertex.id, + domId: vertex.domId, + labelText: sanitizeText$1(vertex.id), + labelStyle: "", + style: "fill: none; stroke: black", + // TODO V10: Flowchart ? Keeping flowchart for backwards compatibility. Remove in next major release + padding: ((_a2 = getConfig$1().flowchart) == null ? void 0 : _a2.padding) ?? ((_b2 = getConfig$1().class) == null ? void 0 : _b2.padding) + }; + g.setNode(vertex.id, node2); + addClasses(vertex.classes, g, _id, diagObj, vertex.id); + log$1.info("setNode", node2); + }); + }; + const addClasses = function(classes2, g, _id, diagObj, parent) { + const keys2 = Object.keys(classes2); + log$1.info("keys:", keys2); + log$1.info(classes2); + keys2.filter((id2) => classes2[id2].parent == parent).forEach(function(id2) { + var _a2, _b2; + const vertex = classes2[id2]; + const cssClassStr = vertex.cssClasses.join(" "); + const styles2 = getStylesFromArray(vertex.styles); + const vertexText = vertex.label ?? vertex.id; + const radius = 0; + const shape = "class_box"; + const node2 = { + labelStyle: styles2.labelStyle, + shape, + labelText: sanitizeText$1(vertexText), + classData: vertex, + rx: radius, + ry: radius, + class: cssClassStr, + style: styles2.style, + id: vertex.id, + domId: vertex.domId, + tooltip: diagObj.db.getTooltip(vertex.id, parent) || "", + haveCallback: vertex.haveCallback, + link: vertex.link, + width: vertex.type === "group" ? 500 : void 0, + type: vertex.type, + // TODO V10: Flowchart ? Keeping flowchart for backwards compatibility. Remove in next major release + padding: ((_a2 = getConfig$1().flowchart) == null ? void 0 : _a2.padding) ?? ((_b2 = getConfig$1().class) == null ? void 0 : _b2.padding) + }; + g.setNode(vertex.id, node2); + if (parent) { + g.setParent(vertex.id, parent); + } + log$1.info("setNode", node2); + }); + }; + const addNotes = function(notes2, g, startEdgeId, classes2) { + log$1.info(notes2); + notes2.forEach(function(note2, i2) { + var _a2, _b2; + const vertex = note2; + const cssNoteStr = ""; + const styles2 = { labelStyle: "", style: "" }; + const vertexText = vertex.text; + const radius = 0; + const shape = "note"; + const node2 = { + labelStyle: styles2.labelStyle, + shape, + labelText: sanitizeText$1(vertexText), + noteData: vertex, + rx: radius, + ry: radius, + class: cssNoteStr, + style: styles2.style, + id: vertex.id, + domId: vertex.id, + tooltip: "", + type: "note", + // TODO V10: Flowchart ? Keeping flowchart for backwards compatibility. Remove in next major release + padding: ((_a2 = getConfig$1().flowchart) == null ? void 0 : _a2.padding) ?? ((_b2 = getConfig$1().class) == null ? void 0 : _b2.padding) + }; + g.setNode(vertex.id, node2); + log$1.info("setNode", node2); + if (!vertex.class || !(vertex.class in classes2)) { + return; + } + const edgeId = startEdgeId + i2; + const edgeData = { + id: `edgeNote${edgeId}`, + //Set relationship style and line type + classes: "relation", + pattern: "dotted", + // Set link type for rendering + arrowhead: "none", + //Set edge extra labels + startLabelRight: "", + endLabelLeft: "", + //Set relation arrow types + arrowTypeStart: "none", + arrowTypeEnd: "none", + style: "fill:none", + labelStyle: "", + curve: interpolateToCurve(conf$3.curve, curveLinear) + }; + g.setEdge(vertex.id, vertex.class, edgeData, edgeId); + }); + }; + const addRelations = function(relations2, g) { + const conf2 = getConfig$1().flowchart; + let cnt2 = 0; + relations2.forEach(function(edge) { + var _a2; + cnt2++; + const edgeData = { + //Set relationship style and line type + classes: "relation", + pattern: edge.relation.lineType == 1 ? "dashed" : "solid", + id: `id_${edge.id1}_${edge.id2}_${cnt2}`, + // Set link type for rendering + arrowhead: edge.type === "arrow_open" ? "none" : "normal", + //Set edge extra labels + startLabelRight: edge.relationTitle1 === "none" ? "" : edge.relationTitle1, + endLabelLeft: edge.relationTitle2 === "none" ? "" : edge.relationTitle2, + //Set relation arrow types + arrowTypeStart: getArrowMarker(edge.relation.type1), + arrowTypeEnd: getArrowMarker(edge.relation.type2), + style: "fill:none", + labelStyle: "", + curve: interpolateToCurve(conf2 == null ? void 0 : conf2.curve, curveLinear) + }; + log$1.info(edgeData, edge); + if (edge.style !== void 0) { + const styles2 = getStylesFromArray(edge.style); + edgeData.style = styles2.style; + edgeData.labelStyle = styles2.labelStyle; + } + edge.text = edge.title; + if (edge.text === void 0) { + if (edge.style !== void 0) { + edgeData.arrowheadStyle = "fill: #333"; + } + } else { + edgeData.arrowheadStyle = "fill: #333"; + edgeData.labelpos = "c"; + if (((_a2 = getConfig$1().flowchart) == null ? void 0 : _a2.htmlLabels) ?? getConfig$1().htmlLabels) { + edgeData.labelType = "html"; + edgeData.label = '' + edge.text + ""; + } else { + edgeData.labelType = "text"; + edgeData.label = edge.text.replace(common$1.lineBreakRegex, "\n"); + if (edge.style === void 0) { + edgeData.style = edgeData.style || "stroke: #333; stroke-width: 1.5px;fill:none"; + } + edgeData.labelStyle = edgeData.labelStyle.replace("color:", "fill:"); + } + } + g.setEdge(edge.id1, edge.id2, edgeData, cnt2); + }); + }; + const setConf$3 = function(cnf) { + conf$3 = { + ...conf$3, + ...cnf + }; + }; + const draw$8 = async function(text2, id2, _version, diagObj) { + log$1.info("Drawing class - ", id2); + const conf2 = getConfig$1().flowchart ?? getConfig$1().class; + const securityLevel = getConfig$1().securityLevel; + log$1.info("config:", conf2); + const nodeSpacing = (conf2 == null ? void 0 : conf2.nodeSpacing) ?? 50; + const rankSpacing = (conf2 == null ? void 0 : conf2.rankSpacing) ?? 50; + const g = new Graph({ + multigraph: true, + compound: true + }).setGraph({ + rankdir: diagObj.db.getDirection(), + nodesep: nodeSpacing, + ranksep: rankSpacing, + marginx: 8, + marginy: 8 + }).setDefaultEdgeLabel(function() { + return {}; + }); + const namespaces2 = diagObj.db.getNamespaces(); + const classes2 = diagObj.db.getClasses(); + const relations2 = diagObj.db.getRelations(); + const notes2 = diagObj.db.getNotes(); + log$1.info(relations2); + addNamespaces(namespaces2, g, id2, diagObj); + addClasses(classes2, g, id2, diagObj); + addRelations(relations2, g); + addNotes(notes2, g, relations2.length + 1, classes2); + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = d3select("#i" + id2); + } + const root2 = securityLevel === "sandbox" ? d3select(sandboxElement.nodes()[0].contentDocument.body) : d3select("body"); + const svg2 = root2.select(`[id="${id2}"]`); + const element2 = root2.select("#" + id2 + " g"); + await render( + element2, + g, + ["aggregation", "extension", "composition", "dependency", "lollipop"], + "classDiagram", + id2 + ); + utils$1.insertTitle(svg2, "classTitleText", (conf2 == null ? void 0 : conf2.titleTopMargin) ?? 5, diagObj.db.getDiagramTitle()); + setupGraphViewbox$1(g, svg2, conf2 == null ? void 0 : conf2.diagramPadding, conf2 == null ? void 0 : conf2.useMaxWidth); + if (!(conf2 == null ? void 0 : conf2.htmlLabels)) { + const doc = securityLevel === "sandbox" ? sandboxElement.nodes()[0].contentDocument : document; + const labels = doc.querySelectorAll('[id="' + id2 + '"] .edgeLabel .label'); + for (const label of labels) { + const dim = label.getBBox(); + const rect2 = doc.createElementNS("http://www.w3.org/2000/svg", "rect"); + rect2.setAttribute("rx", 0); + rect2.setAttribute("ry", 0); + rect2.setAttribute("width", dim.width); + rect2.setAttribute("height", dim.height); + label.insertBefore(rect2, label.firstChild); + } + } + }; + function getArrowMarker(type2) { + let marker; + switch (type2) { + case 0: + marker = "aggregation"; + break; + case 1: + marker = "extension"; + break; + case 2: + marker = "composition"; + break; + case 3: + marker = "dependency"; + break; + case 4: + marker = "lollipop"; + break; + default: + marker = "none"; + } + return marker; + } + const renderer$8 = { + setConf: setConf$3, + draw: draw$8 + }; + const diagram$8 = { + parser: parser$d, + db: db$8, + renderer: renderer$8, + styles: styles$5, + init: (cnf) => { + if (!cnf.class) { + cnf.class = {}; + } + cnf.class.arrowMarkerAbsolute = cnf.arrowMarkerAbsolute; + db$8.clear(); + } + }; + const classDiagramV2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + diagram: diagram$8 + }, Symbol.toStringTag, { value: "Module" })); + var parser$a = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 2], $V1 = [1, 3], $V2 = [1, 4], $V3 = [2, 4], $V4 = [1, 9], $V5 = [1, 11], $V6 = [1, 15], $V7 = [1, 16], $V8 = [1, 17], $V9 = [1, 18], $Va = [1, 30], $Vb = [1, 19], $Vc = [1, 20], $Vd = [1, 21], $Ve = [1, 22], $Vf = [1, 23], $Vg = [1, 25], $Vh = [1, 26], $Vi = [1, 27], $Vj = [1, 28], $Vk = [1, 29], $Vl = [1, 32], $Vm = [1, 33], $Vn = [1, 34], $Vo = [1, 35], $Vp = [1, 31], $Vq = [1, 4, 5, 15, 16, 18, 20, 21, 23, 24, 25, 26, 27, 28, 32, 34, 36, 37, 41, 44, 45, 46, 47, 50], $Vr = [1, 4, 5, 13, 14, 15, 16, 18, 20, 21, 23, 24, 25, 26, 27, 28, 32, 34, 36, 37, 41, 44, 45, 46, 47, 50], $Vs = [4, 5, 15, 16, 18, 20, 21, 23, 24, 25, 26, 27, 28, 32, 34, 36, 37, 41, 44, 45, 46, 47, 50]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "SPACE": 4, "NL": 5, "SD": 6, "document": 7, "line": 8, "statement": 9, "classDefStatement": 10, "cssClassStatement": 11, "idStatement": 12, "DESCR": 13, "-->": 14, "HIDE_EMPTY": 15, "scale": 16, "WIDTH": 17, "COMPOSIT_STATE": 18, "STRUCT_START": 19, "STRUCT_STOP": 20, "STATE_DESCR": 21, "AS": 22, "ID": 23, "FORK": 24, "JOIN": 25, "CHOICE": 26, "CONCURRENT": 27, "note": 28, "notePosition": 29, "NOTE_TEXT": 30, "direction": 31, "acc_title": 32, "acc_title_value": 33, "acc_descr": 34, "acc_descr_value": 35, "acc_descr_multiline_value": 36, "classDef": 37, "CLASSDEF_ID": 38, "CLASSDEF_STYLEOPTS": 39, "DEFAULT": 40, "class": 41, "CLASSENTITY_IDS": 42, "STYLECLASS": 43, "direction_tb": 44, "direction_bt": 45, "direction_rl": 46, "direction_lr": 47, "eol": 48, ";": 49, "EDGE_STATE": 50, "STYLE_SEPARATOR": 51, "left_of": 52, "right_of": 53, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 4: "SPACE", 5: "NL", 6: "SD", 13: "DESCR", 14: "-->", 15: "HIDE_EMPTY", 16: "scale", 17: "WIDTH", 18: "COMPOSIT_STATE", 19: "STRUCT_START", 20: "STRUCT_STOP", 21: "STATE_DESCR", 22: "AS", 23: "ID", 24: "FORK", 25: "JOIN", 26: "CHOICE", 27: "CONCURRENT", 28: "note", 30: "NOTE_TEXT", 32: "acc_title", 33: "acc_title_value", 34: "acc_descr", 35: "acc_descr_value", 36: "acc_descr_multiline_value", 37: "classDef", 38: "CLASSDEF_ID", 39: "CLASSDEF_STYLEOPTS", 40: "DEFAULT", 41: "class", 42: "CLASSENTITY_IDS", 43: "STYLECLASS", 44: "direction_tb", 45: "direction_bt", 46: "direction_rl", 47: "direction_lr", 49: ";", 50: "EDGE_STATE", 51: "STYLE_SEPARATOR", 52: "left_of", 53: "right_of" }, + productions_: [0, [3, 2], [3, 2], [3, 2], [7, 0], [7, 2], [8, 2], [8, 1], [8, 1], [9, 1], [9, 1], [9, 1], [9, 2], [9, 3], [9, 4], [9, 1], [9, 2], [9, 1], [9, 4], [9, 3], [9, 6], [9, 1], [9, 1], [9, 1], [9, 1], [9, 4], [9, 4], [9, 1], [9, 2], [9, 2], [9, 1], [10, 3], [10, 3], [11, 3], [31, 1], [31, 1], [31, 1], [31, 1], [48, 1], [48, 1], [12, 1], [12, 1], [12, 3], [12, 3], [29, 1], [29, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 3: + yy.setRootDoc($$[$0]); + return $$[$0]; + case 4: + this.$ = []; + break; + case 5: + if ($$[$0] != "nl") { + $$[$0 - 1].push($$[$0]); + this.$ = $$[$0 - 1]; + } + break; + case 6: + case 7: + this.$ = $$[$0]; + break; + case 8: + this.$ = "nl"; + break; + case 11: + this.$ = $$[$0]; + break; + case 12: + const stateStmt = $$[$0 - 1]; + stateStmt.description = yy.trimColon($$[$0]); + this.$ = stateStmt; + break; + case 13: + this.$ = { stmt: "relation", state1: $$[$0 - 2], state2: $$[$0] }; + break; + case 14: + const relDescription = yy.trimColon($$[$0]); + this.$ = { stmt: "relation", state1: $$[$0 - 3], state2: $$[$0 - 1], description: relDescription }; + break; + case 18: + this.$ = { stmt: "state", id: $$[$0 - 3], type: "default", description: "", doc: $$[$0 - 1] }; + break; + case 19: + var id2 = $$[$0]; + var description = $$[$0 - 2].trim(); + if ($$[$0].match(":")) { + var parts = $$[$0].split(":"); + id2 = parts[0]; + description = [description, parts[1]]; + } + this.$ = { stmt: "state", id: id2, type: "default", description }; + break; + case 20: + this.$ = { stmt: "state", id: $$[$0 - 3], type: "default", description: $$[$0 - 5], doc: $$[$0 - 1] }; + break; + case 21: + this.$ = { stmt: "state", id: $$[$0], type: "fork" }; + break; + case 22: + this.$ = { stmt: "state", id: $$[$0], type: "join" }; + break; + case 23: + this.$ = { stmt: "state", id: $$[$0], type: "choice" }; + break; + case 24: + this.$ = { stmt: "state", id: yy.getDividerId(), type: "divider" }; + break; + case 25: + this.$ = { stmt: "state", id: $$[$0 - 1].trim(), note: { position: $$[$0 - 2].trim(), text: $$[$0].trim() } }; + break; + case 28: + this.$ = $$[$0].trim(); + yy.setAccTitle(this.$); + break; + case 29: + case 30: + this.$ = $$[$0].trim(); + yy.setAccDescription(this.$); + break; + case 31: + case 32: + this.$ = { stmt: "classDef", id: $$[$0 - 1].trim(), classes: $$[$0].trim() }; + break; + case 33: + this.$ = { stmt: "applyClass", id: $$[$0 - 1].trim(), styleClass: $$[$0].trim() }; + break; + case 34: + yy.setDirection("TB"); + this.$ = { stmt: "dir", value: "TB" }; + break; + case 35: + yy.setDirection("BT"); + this.$ = { stmt: "dir", value: "BT" }; + break; + case 36: + yy.setDirection("RL"); + this.$ = { stmt: "dir", value: "RL" }; + break; + case 37: + yy.setDirection("LR"); + this.$ = { stmt: "dir", value: "LR" }; + break; + case 40: + case 41: + this.$ = { stmt: "state", id: $$[$0].trim(), type: "default", description: "" }; + break; + case 42: + this.$ = { stmt: "state", id: $$[$0 - 2].trim(), classes: [$$[$0].trim()], type: "default", description: "" }; + break; + case 43: + this.$ = { stmt: "state", id: $$[$0 - 2].trim(), classes: [$$[$0].trim()], type: "default", description: "" }; + break; + } + }, + table: [{ 3: 1, 4: $V0, 5: $V1, 6: $V2 }, { 1: [3] }, { 3: 5, 4: $V0, 5: $V1, 6: $V2 }, { 3: 6, 4: $V0, 5: $V1, 6: $V2 }, o([1, 4, 5, 15, 16, 18, 21, 23, 24, 25, 26, 27, 28, 32, 34, 36, 37, 41, 44, 45, 46, 47, 50], $V3, { 7: 7 }), { 1: [2, 1] }, { 1: [2, 2] }, { 1: [2, 3], 4: $V4, 5: $V5, 8: 8, 9: 10, 10: 12, 11: 13, 12: 14, 15: $V6, 16: $V7, 18: $V8, 21: $V9, 23: $Va, 24: $Vb, 25: $Vc, 26: $Vd, 27: $Ve, 28: $Vf, 31: 24, 32: $Vg, 34: $Vh, 36: $Vi, 37: $Vj, 41: $Vk, 44: $Vl, 45: $Vm, 46: $Vn, 47: $Vo, 50: $Vp }, o($Vq, [2, 5]), { 9: 36, 10: 12, 11: 13, 12: 14, 15: $V6, 16: $V7, 18: $V8, 21: $V9, 23: $Va, 24: $Vb, 25: $Vc, 26: $Vd, 27: $Ve, 28: $Vf, 31: 24, 32: $Vg, 34: $Vh, 36: $Vi, 37: $Vj, 41: $Vk, 44: $Vl, 45: $Vm, 46: $Vn, 47: $Vo, 50: $Vp }, o($Vq, [2, 7]), o($Vq, [2, 8]), o($Vq, [2, 9]), o($Vq, [2, 10]), o($Vq, [2, 11], { 13: [1, 37], 14: [1, 38] }), o($Vq, [2, 15]), { 17: [1, 39] }, o($Vq, [2, 17], { 19: [1, 40] }), { 22: [1, 41] }, o($Vq, [2, 21]), o($Vq, [2, 22]), o($Vq, [2, 23]), o($Vq, [2, 24]), { 29: 42, 30: [1, 43], 52: [1, 44], 53: [1, 45] }, o($Vq, [2, 27]), { 33: [1, 46] }, { 35: [1, 47] }, o($Vq, [2, 30]), { 38: [1, 48], 40: [1, 49] }, { 42: [1, 50] }, o($Vr, [2, 40], { 51: [1, 51] }), o($Vr, [2, 41], { 51: [1, 52] }), o($Vq, [2, 34]), o($Vq, [2, 35]), o($Vq, [2, 36]), o($Vq, [2, 37]), o($Vq, [2, 6]), o($Vq, [2, 12]), { 12: 53, 23: $Va, 50: $Vp }, o($Vq, [2, 16]), o($Vs, $V3, { 7: 54 }), { 23: [1, 55] }, { 23: [1, 56] }, { 22: [1, 57] }, { 23: [2, 44] }, { 23: [2, 45] }, o($Vq, [2, 28]), o($Vq, [2, 29]), { 39: [1, 58] }, { 39: [1, 59] }, { 43: [1, 60] }, { 23: [1, 61] }, { 23: [1, 62] }, o($Vq, [2, 13], { 13: [1, 63] }), { 4: $V4, 5: $V5, 8: 8, 9: 10, 10: 12, 11: 13, 12: 14, 15: $V6, 16: $V7, 18: $V8, 20: [1, 64], 21: $V9, 23: $Va, 24: $Vb, 25: $Vc, 26: $Vd, 27: $Ve, 28: $Vf, 31: 24, 32: $Vg, 34: $Vh, 36: $Vi, 37: $Vj, 41: $Vk, 44: $Vl, 45: $Vm, 46: $Vn, 47: $Vo, 50: $Vp }, o($Vq, [2, 19], { 19: [1, 65] }), { 30: [1, 66] }, { 23: [1, 67] }, o($Vq, [2, 31]), o($Vq, [2, 32]), o($Vq, [2, 33]), o($Vr, [2, 42]), o($Vr, [2, 43]), o($Vq, [2, 14]), o($Vq, [2, 18]), o($Vs, $V3, { 7: 68 }), o($Vq, [2, 25]), o($Vq, [2, 26]), { 4: $V4, 5: $V5, 8: 8, 9: 10, 10: 12, 11: 13, 12: 14, 15: $V6, 16: $V7, 18: $V8, 20: [1, 69], 21: $V9, 23: $Va, 24: $Vb, 25: $Vc, 26: $Vd, 27: $Ve, 28: $Vf, 31: 24, 32: $Vg, 34: $Vh, 36: $Vi, 37: $Vj, 41: $Vk, 44: $Vl, 45: $Vm, 46: $Vn, 47: $Vo, 50: $Vp }, o($Vq, [2, 20])], + defaultActions: { 5: [2, 1], 6: [2, 2], 44: [2, 44], 45: [2, 45] }, + parseError: function parseError(str2, hash) { + if (hash.recoverable) { + this.trace(str2); + } else { + var error = new Error(str2); + error.hash = hash; + throw error; + } + }, + parse: function parse2(input) { + var self2 = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex2() { + var token2; + token2 = tstack.pop() || lexer2.lex() || EOF; + if (typeof token2 !== "number") { + if (token2 instanceof Array) { + tstack = token2; + token2 = tstack.pop(); + } + token2 = self2.symbols_[token2] || token2; + } + return token2; + } + var symbol, state2, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state2 = stack[stack.length - 1]; + if (this.defaultActions[state2]) { + action = this.defaultActions[state2]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex2(); + } + action = table[state2] && table[state2][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state2]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state2 + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str2, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str2, hash); + } else { + throw new Error(str2); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch2 = this._input[0]; + this.yytext += ch2; + this.yyleng++; + this.offset++; + this.match += ch2; + this.matched += ch2; + var lines = ch2.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch2; + }, + // unshifts one char (or a string) into the input + unput: function(ch2) { + var len = ch2.length; + var lines = ch2.split(/(?:\r\n?|\n)/g); + this._input = ch2 + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next2 = this.match; + if (next2.length < 20) { + next2 += this._input.substr(0, 20 - next2.length); + } + return (next2.substr(0, 20) + (next2.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c2 = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c2 + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token2, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token2 = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token2) { + return token2; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token2, match, tempMatch, index2; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i2 = 0; i2 < rules.length; i2++) { + tempMatch = this._input.match(this.rules[rules[i2]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index2 = i2; + if (this.options.backtrack_lexer) { + token2 = this.test_match(tempMatch, rules[i2]); + if (token2 !== false) { + return token2; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token2 = this.test_match(match, rules[index2]); + if (token2 !== false) { + return token2; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex2() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + return 40; + case 1: + return 44; + case 2: + return 45; + case 3: + return 46; + case 4: + return 47; + case 5: + break; + case 6: + break; + case 7: + return 5; + case 8: + break; + case 9: + break; + case 10: + break; + case 11: + break; + case 12: + this.pushState("SCALE"); + return 16; + case 13: + return 17; + case 14: + this.popState(); + break; + case 15: + this.begin("acc_title"); + return 32; + case 16: + this.popState(); + return "acc_title_value"; + case 17: + this.begin("acc_descr"); + return 34; + case 18: + this.popState(); + return "acc_descr_value"; + case 19: + this.begin("acc_descr_multiline"); + break; + case 20: + this.popState(); + break; + case 21: + return "acc_descr_multiline_value"; + case 22: + this.pushState("CLASSDEF"); + return 37; + case 23: + this.popState(); + this.pushState("CLASSDEFID"); + return "DEFAULT_CLASSDEF_ID"; + case 24: + this.popState(); + this.pushState("CLASSDEFID"); + return 38; + case 25: + this.popState(); + return 39; + case 26: + this.pushState("CLASS"); + return 41; + case 27: + this.popState(); + this.pushState("CLASS_STYLE"); + return 42; + case 28: + this.popState(); + return 43; + case 29: + this.pushState("SCALE"); + return 16; + case 30: + return 17; + case 31: + this.popState(); + break; + case 32: + this.pushState("STATE"); + break; + case 33: + this.popState(); + yy_.yytext = yy_.yytext.slice(0, -8).trim(); + return 24; + case 34: + this.popState(); + yy_.yytext = yy_.yytext.slice(0, -8).trim(); + return 25; + case 35: + this.popState(); + yy_.yytext = yy_.yytext.slice(0, -10).trim(); + return 26; + case 36: + this.popState(); + yy_.yytext = yy_.yytext.slice(0, -8).trim(); + return 24; + case 37: + this.popState(); + yy_.yytext = yy_.yytext.slice(0, -8).trim(); + return 25; + case 38: + this.popState(); + yy_.yytext = yy_.yytext.slice(0, -10).trim(); + return 26; + case 39: + return 44; + case 40: + return 45; + case 41: + return 46; + case 42: + return 47; + case 43: + this.pushState("STATE_STRING"); + break; + case 44: + this.pushState("STATE_ID"); + return "AS"; + case 45: + this.popState(); + return "ID"; + case 46: + this.popState(); + break; + case 47: + return "STATE_DESCR"; + case 48: + return 18; + case 49: + this.popState(); + break; + case 50: + this.popState(); + this.pushState("struct"); + return 19; + case 51: + break; + case 52: + this.popState(); + return 20; + case 53: + break; + case 54: + this.begin("NOTE"); + return 28; + case 55: + this.popState(); + this.pushState("NOTE_ID"); + return 52; + case 56: + this.popState(); + this.pushState("NOTE_ID"); + return 53; + case 57: + this.popState(); + this.pushState("FLOATING_NOTE"); + break; + case 58: + this.popState(); + this.pushState("FLOATING_NOTE_ID"); + return "AS"; + case 59: + break; + case 60: + return "NOTE_TEXT"; + case 61: + this.popState(); + return "ID"; + case 62: + this.popState(); + this.pushState("NOTE_TEXT"); + return 23; + case 63: + this.popState(); + yy_.yytext = yy_.yytext.substr(2).trim(); + return 30; + case 64: + this.popState(); + yy_.yytext = yy_.yytext.slice(0, -8).trim(); + return 30; + case 65: + return 6; + case 66: + return 6; + case 67: + return 15; + case 68: + return 50; + case 69: + return 23; + case 70: + yy_.yytext = yy_.yytext.trim(); + return 13; + case 71: + return 14; + case 72: + return 27; + case 73: + return 51; + case 74: + return 5; + case 75: + return "INVALID"; + } + }, + rules: [/^(?:default\b)/i, /^(?:.*direction\s+TB[^\n]*)/i, /^(?:.*direction\s+BT[^\n]*)/i, /^(?:.*direction\s+RL[^\n]*)/i, /^(?:.*direction\s+LR[^\n]*)/i, /^(?:%%(?!\{)[^\n]*)/i, /^(?:[^\}]%%[^\n]*)/i, /^(?:[\n]+)/i, /^(?:[\s]+)/i, /^(?:((?!\n)\s)+)/i, /^(?:#[^\n]*)/i, /^(?:%[^\n]*)/i, /^(?:scale\s+)/i, /^(?:\d+)/i, /^(?:\s+width\b)/i, /^(?:accTitle\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*\{\s*)/i, /^(?:[\}])/i, /^(?:[^\}]*)/i, /^(?:classDef\s+)/i, /^(?:DEFAULT\s+)/i, /^(?:\w+\s+)/i, /^(?:[^\n]*)/i, /^(?:class\s+)/i, /^(?:(\w+)+((,\s*\w+)*))/i, /^(?:[^\n]*)/i, /^(?:scale\s+)/i, /^(?:\d+)/i, /^(?:\s+width\b)/i, /^(?:state\s+)/i, /^(?:.*<>)/i, /^(?:.*<>)/i, /^(?:.*<>)/i, /^(?:.*\[\[fork\]\])/i, /^(?:.*\[\[join\]\])/i, /^(?:.*\[\[choice\]\])/i, /^(?:.*direction\s+TB[^\n]*)/i, /^(?:.*direction\s+BT[^\n]*)/i, /^(?:.*direction\s+RL[^\n]*)/i, /^(?:.*direction\s+LR[^\n]*)/i, /^(?:["])/i, /^(?:\s*as\s+)/i, /^(?:[^\n\{]*)/i, /^(?:["])/i, /^(?:[^"]*)/i, /^(?:[^\n\s\{]+)/i, /^(?:\n)/i, /^(?:\{)/i, /^(?:%%(?!\{)[^\n]*)/i, /^(?:\})/i, /^(?:[\n])/i, /^(?:note\s+)/i, /^(?:left of\b)/i, /^(?:right of\b)/i, /^(?:")/i, /^(?:\s*as\s*)/i, /^(?:["])/i, /^(?:[^"]*)/i, /^(?:[^\n]*)/i, /^(?:\s*[^:\n\s\-]+)/i, /^(?:\s*:[^:\n;]+)/i, /^(?:[\s\S]*?end note\b)/i, /^(?:stateDiagram\s+)/i, /^(?:stateDiagram-v2\s+)/i, /^(?:hide empty description\b)/i, /^(?:\[\*\])/i, /^(?:[^:\n\s\-\{]+)/i, /^(?:\s*:[^:\n;]+)/i, /^(?:-->)/i, /^(?:--)/i, /^(?::::)/i, /^(?:$)/i, /^(?:.)/i], + conditions: { "LINE": { "rules": [9, 10], "inclusive": false }, "struct": { "rules": [9, 10, 22, 26, 32, 39, 40, 41, 42, 51, 52, 53, 54, 68, 69, 70, 71, 72], "inclusive": false }, "FLOATING_NOTE_ID": { "rules": [61], "inclusive": false }, "FLOATING_NOTE": { "rules": [58, 59, 60], "inclusive": false }, "NOTE_TEXT": { "rules": [63, 64], "inclusive": false }, "NOTE_ID": { "rules": [62], "inclusive": false }, "NOTE": { "rules": [55, 56, 57], "inclusive": false }, "CLASS_STYLE": { "rules": [28], "inclusive": false }, "CLASS": { "rules": [27], "inclusive": false }, "CLASSDEFID": { "rules": [25], "inclusive": false }, "CLASSDEF": { "rules": [23, 24], "inclusive": false }, "acc_descr_multiline": { "rules": [20, 21], "inclusive": false }, "acc_descr": { "rules": [18], "inclusive": false }, "acc_title": { "rules": [16], "inclusive": false }, "SCALE": { "rules": [13, 14, 30, 31], "inclusive": false }, "ALIAS": { "rules": [], "inclusive": false }, "STATE_ID": { "rules": [45], "inclusive": false }, "STATE_STRING": { "rules": [46, 47], "inclusive": false }, "FORK_STATE": { "rules": [], "inclusive": false }, "STATE": { "rules": [9, 10, 33, 34, 35, 36, 37, 38, 43, 44, 48, 49, 50], "inclusive": false }, "ID": { "rules": [9, 10], "inclusive": false }, "INITIAL": { "rules": [0, 1, 2, 3, 4, 5, 6, 7, 8, 10, 11, 12, 15, 17, 19, 22, 26, 29, 32, 50, 54, 65, 66, 67, 68, 69, 70, 71, 73, 74, 75], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser2() { + this.yy = {}; + } + Parser2.prototype = parser2; + parser2.Parser = Parser2; + return new Parser2(); + }(); + parser$a.parser = parser$a; + const parser$b = parser$a; + const DEFAULT_DIAGRAM_DIRECTION = "LR"; + const DEFAULT_NESTED_DOC_DIR = "TB"; + const STMT_STATE = "state"; + const STMT_RELATION = "relation"; + const STMT_CLASSDEF = "classDef"; + const STMT_APPLYCLASS = "applyClass"; + const DEFAULT_STATE_TYPE = "default"; + const DIVIDER_TYPE = "divider"; + const START_NODE = "[*]"; + const START_TYPE = "start"; + const END_NODE = START_NODE; + const END_TYPE = "end"; + const COLOR_KEYWORD$1 = "color"; + const FILL_KEYWORD$1 = "fill"; + const BG_FILL$1 = "bgFill"; + const STYLECLASS_SEP$1 = ","; + function newClassesList() { + return {}; + } + let direction = DEFAULT_DIAGRAM_DIRECTION; + let rootDoc = []; + let classes$1 = newClassesList(); + const newDoc = () => { + return { + relations: [], + states: {}, + documents: {} + }; + }; + let documents = { + root: newDoc() + }; + let currentDocument = documents.root; + let startEndCount = 0; + let dividerCnt = 0; + const lineType = { + LINE: 0, + DOTTED_LINE: 1 + }; + const relationType = { + AGGREGATION: 0, + EXTENSION: 1, + COMPOSITION: 2, + DEPENDENCY: 3 + }; + const clone = (o) => JSON.parse(JSON.stringify(o)); + const setRootDoc = (o) => { + log$1.info("Setting root doc", o); + rootDoc = o; + }; + const getRootDoc = () => rootDoc; + const docTranslator = (parent, node2, first) => { + if (node2.stmt === STMT_RELATION) { + docTranslator(parent, node2.state1, true); + docTranslator(parent, node2.state2, false); + } else { + if (node2.stmt === STMT_STATE) { + if (node2.id === "[*]") { + node2.id = first ? parent.id + "_start" : parent.id + "_end"; + node2.start = first; + } else { + node2.id = node2.id.trim(); + } + } + if (node2.doc) { + const doc = []; + let currentDoc = []; + let i2; + for (i2 = 0; i2 < node2.doc.length; i2++) { + if (node2.doc[i2].type === DIVIDER_TYPE) { + const newNode = clone(node2.doc[i2]); + newNode.doc = clone(currentDoc); + doc.push(newNode); + currentDoc = []; + } else { + currentDoc.push(node2.doc[i2]); + } + } + if (doc.length > 0 && currentDoc.length > 0) { + const newNode = { + stmt: STMT_STATE, + id: generateId$2(), + type: "divider", + doc: clone(currentDoc) + }; + doc.push(clone(newNode)); + node2.doc = doc; + } + node2.doc.forEach((docNode) => docTranslator(node2, docNode, true)); + } + } + }; + const getRootDocV2 = () => { + docTranslator({ id: "root" }, { id: "root", doc: rootDoc }, true); + return { id: "root", doc: rootDoc }; + }; + const extract = (_doc) => { + let doc; + if (_doc.doc) { + doc = _doc.doc; + } else { + doc = _doc; + } + log$1.info(doc); + clear$5(true); + log$1.info("Extract", doc); + doc.forEach((item) => { + switch (item.stmt) { + case STMT_STATE: + addState( + item.id.trim(), + item.type, + item.doc, + item.description, + item.note, + item.classes, + item.styles, + item.textStyles + ); + break; + case STMT_RELATION: + addRelation(item.state1, item.state2, item.description); + break; + case STMT_CLASSDEF: + addStyleClass$1(item.id.trim(), item.classes); + break; + case STMT_APPLYCLASS: + setCssClass$1(item.id.trim(), item.styleClass); + break; + } + }); + }; + const addState = function(id2, type2 = DEFAULT_STATE_TYPE, doc = null, descr = null, note2 = null, classes2 = null, styles2 = null, textStyles = null) { + const trimmedId = id2 == null ? void 0 : id2.trim(); + if (currentDocument.states[trimmedId] === void 0) { + log$1.info("Adding state ", trimmedId, descr); + currentDocument.states[trimmedId] = { + id: trimmedId, + descriptions: [], + type: type2, + doc, + note: note2, + classes: [], + styles: [], + textStyles: [] + }; + } else { + if (!currentDocument.states[trimmedId].doc) { + currentDocument.states[trimmedId].doc = doc; + } + if (!currentDocument.states[trimmedId].type) { + currentDocument.states[trimmedId].type = type2; + } + } + if (descr) { + log$1.info("Setting state description", trimmedId, descr); + if (typeof descr === "string") { + addDescription(trimmedId, descr.trim()); + } + if (typeof descr === "object") { + descr.forEach((des) => addDescription(trimmedId, des.trim())); + } + } + if (note2) { + currentDocument.states[trimmedId].note = note2; + currentDocument.states[trimmedId].note.text = common$1.sanitizeText( + currentDocument.states[trimmedId].note.text, + getConfig$1() + ); + } + if (classes2) { + log$1.info("Setting state classes", trimmedId, classes2); + const classesList = typeof classes2 === "string" ? [classes2] : classes2; + classesList.forEach((cssClass) => setCssClass$1(trimmedId, cssClass.trim())); + } + if (styles2) { + log$1.info("Setting state styles", trimmedId, styles2); + const stylesList = typeof styles2 === "string" ? [styles2] : styles2; + stylesList.forEach((style) => setStyle(trimmedId, style.trim())); + } + if (textStyles) { + log$1.info("Setting state styles", trimmedId, styles2); + const textStylesList = typeof textStyles === "string" ? [textStyles] : textStyles; + textStylesList.forEach((textStyle) => setTextStyle(trimmedId, textStyle.trim())); + } + }; + const clear$5 = function(saveCommon) { + documents = { + root: newDoc() + }; + currentDocument = documents.root; + startEndCount = 0; + classes$1 = newClassesList(); + if (!saveCommon) { + clear$n(); + } + }; + const getState = function(id2) { + return currentDocument.states[id2]; + }; + const getStates = function() { + return currentDocument.states; + }; + const logDocuments = function() { + log$1.info("Documents = ", documents); + }; + const getRelations = function() { + return currentDocument.relations; + }; + function startIdIfNeeded(id2 = "") { + let fixedId = id2; + if (id2 === START_NODE) { + startEndCount++; + fixedId = `${START_TYPE}${startEndCount}`; + } + return fixedId; + } + function startTypeIfNeeded(id2 = "", type2 = DEFAULT_STATE_TYPE) { + return id2 === START_NODE ? START_TYPE : type2; + } + function endIdIfNeeded(id2 = "") { + let fixedId = id2; + if (id2 === END_NODE) { + startEndCount++; + fixedId = `${END_TYPE}${startEndCount}`; + } + return fixedId; + } + function endTypeIfNeeded(id2 = "", type2 = DEFAULT_STATE_TYPE) { + return id2 === END_NODE ? END_TYPE : type2; + } + function addRelationObjs(item1, item2, relationTitle) { + let id1 = startIdIfNeeded(item1.id.trim()); + let type1 = startTypeIfNeeded(item1.id.trim(), item1.type); + let id2 = startIdIfNeeded(item2.id.trim()); + let type2 = startTypeIfNeeded(item2.id.trim(), item2.type); + addState( + id1, + type1, + item1.doc, + item1.description, + item1.note, + item1.classes, + item1.styles, + item1.textStyles + ); + addState( + id2, + type2, + item2.doc, + item2.description, + item2.note, + item2.classes, + item2.styles, + item2.textStyles + ); + currentDocument.relations.push({ + id1, + id2, + relationTitle: common$1.sanitizeText(relationTitle, getConfig$1()) + }); + } + const addRelation = function(item1, item2, title2) { + if (typeof item1 === "object") { + addRelationObjs(item1, item2, title2); + } else { + const id1 = startIdIfNeeded(item1.trim()); + const type1 = startTypeIfNeeded(item1); + const id2 = endIdIfNeeded(item2.trim()); + const type2 = endTypeIfNeeded(item2); + addState(id1, type1); + addState(id2, type2); + currentDocument.relations.push({ + id1, + id2, + title: common$1.sanitizeText(title2, getConfig$1()) + }); + } + }; + const addDescription = function(id2, descr) { + const theState = currentDocument.states[id2]; + const _descr = descr.startsWith(":") ? descr.replace(":", "").trim() : descr; + theState.descriptions.push(common$1.sanitizeText(_descr, getConfig$1())); + }; + const cleanupLabel = function(label) { + if (label.substring(0, 1) === ":") { + return label.substr(2).trim(); + } else { + return label.trim(); + } + }; + const getDividerId = () => { + dividerCnt++; + return "divider-id-" + dividerCnt; + }; + const addStyleClass$1 = function(id2, styleAttributes = "") { + if (classes$1[id2] === void 0) { + classes$1[id2] = { id: id2, styles: [], textStyles: [] }; + } + const foundClass = classes$1[id2]; + if (styleAttributes !== void 0 && styleAttributes !== null) { + styleAttributes.split(STYLECLASS_SEP$1).forEach((attrib) => { + const fixedAttrib = attrib.replace(/([^;]*);/, "$1").trim(); + if (attrib.match(COLOR_KEYWORD$1)) { + const newStyle1 = fixedAttrib.replace(FILL_KEYWORD$1, BG_FILL$1); + const newStyle2 = newStyle1.replace(COLOR_KEYWORD$1, FILL_KEYWORD$1); + foundClass.textStyles.push(newStyle2); + } + foundClass.styles.push(fixedAttrib); + }); + } + }; + const getClasses$4 = function() { + return classes$1; + }; + const setCssClass$1 = function(itemIds, cssClassName) { + itemIds.split(",").forEach(function(id2) { + let foundState = getState(id2); + if (foundState === void 0) { + const trimmedId = id2.trim(); + addState(trimmedId); + foundState = getState(trimmedId); + } + foundState.classes.push(cssClassName); + }); + }; + const setStyle = function(itemId, styleText) { + const item = getState(itemId); + if (item !== void 0) { + item.textStyles.push(styleText); + } + }; + const setTextStyle = function(itemId, cssClassName) { + const item = getState(itemId); + if (item !== void 0) { + item.textStyles.push(cssClassName); + } + }; + const getDirection = () => direction; + const setDirection = (dir2) => { + direction = dir2; + }; + const trimColon = (str2) => str2 && str2[0] === ":" ? str2.substr(1).trim() : str2.trim(); + const db$7 = { + getConfig: () => getConfig$1().state, + addState, + clear: clear$5, + getState, + getStates, + getRelations, + getClasses: getClasses$4, + getDirection, + addRelation, + getDividerId, + setDirection, + cleanupLabel, + lineType, + relationType, + logDocuments, + getRootDoc, + setRootDoc, + getRootDocV2, + extract, + trimColon, + getAccTitle, + setAccTitle, + getAccDescription, + setAccDescription, + addStyleClass: addStyleClass$1, + setCssClass: setCssClass$1, + addDescription, + setDiagramTitle, + getDiagramTitle + }; + const getStyles$5 = (options2) => ` +defs #statediagram-barbEnd { + fill: ${options2.transitionColor}; + stroke: ${options2.transitionColor}; + } +g.stateGroup text { + fill: ${options2.nodeBorder}; + stroke: none; + font-size: 10px; +} +g.stateGroup text { + fill: ${options2.textColor}; + stroke: none; + font-size: 10px; + +} +g.stateGroup .state-title { + font-weight: bolder; + fill: ${options2.stateLabelColor}; +} + +g.stateGroup rect { + fill: ${options2.mainBkg}; + stroke: ${options2.nodeBorder}; +} + +g.stateGroup line { + stroke: ${options2.lineColor}; + stroke-width: 1; +} + +.transition { + stroke: ${options2.transitionColor}; + stroke-width: 1; + fill: none; +} + +.stateGroup .composit { + fill: ${options2.background}; + border-bottom: 1px +} + +.stateGroup .alt-composit { + fill: #e0e0e0; + border-bottom: 1px +} + +.state-note { + stroke: ${options2.noteBorderColor}; + fill: ${options2.noteBkgColor}; + + text { + fill: ${options2.noteTextColor}; + stroke: none; + font-size: 10px; + } +} + +.stateLabel .box { + stroke: none; + stroke-width: 0; + fill: ${options2.mainBkg}; + opacity: 0.5; +} + +.edgeLabel .label rect { + fill: ${options2.labelBackgroundColor}; + opacity: 0.5; +} +.edgeLabel .label text { + fill: ${options2.transitionLabelColor || options2.tertiaryTextColor}; +} +.label div .edgeLabel { + color: ${options2.transitionLabelColor || options2.tertiaryTextColor}; +} + +.stateLabel text { + fill: ${options2.stateLabelColor}; + font-size: 10px; + font-weight: bold; +} + +.node circle.state-start { + fill: ${options2.specialStateColor}; + stroke: ${options2.specialStateColor}; +} + +.node .fork-join { + fill: ${options2.specialStateColor}; + stroke: ${options2.specialStateColor}; +} + +.node circle.state-end { + fill: ${options2.innerEndBackground}; + stroke: ${options2.background}; + stroke-width: 1.5 +} +.end-state-inner { + fill: ${options2.compositeBackground || options2.background}; + // stroke: ${options2.background}; + stroke-width: 1.5 +} + +.node rect { + fill: ${options2.stateBkg || options2.mainBkg}; + stroke: ${options2.stateBorder || options2.nodeBorder}; + stroke-width: 1px; +} +.node polygon { + fill: ${options2.mainBkg}; + stroke: ${options2.stateBorder || options2.nodeBorder};; + stroke-width: 1px; +} +#statediagram-barbEnd { + fill: ${options2.lineColor}; +} + +.statediagram-cluster rect { + fill: ${options2.compositeTitleBackground}; + stroke: ${options2.stateBorder || options2.nodeBorder}; + stroke-width: 1px; +} + +.cluster-label, .nodeLabel { + color: ${options2.stateLabelColor}; +} + +.statediagram-cluster rect.outer { + rx: 5px; + ry: 5px; +} +.statediagram-state .divider { + stroke: ${options2.stateBorder || options2.nodeBorder}; +} + +.statediagram-state .title-state { + rx: 5px; + ry: 5px; +} +.statediagram-cluster.statediagram-cluster .inner { + fill: ${options2.compositeBackground || options2.background}; +} +.statediagram-cluster.statediagram-cluster-alt .inner { + fill: ${options2.altBackground ? options2.altBackground : "#efefef"}; +} + +.statediagram-cluster .inner { + rx:0; + ry:0; +} + +.statediagram-state rect.basic { + rx: 5px; + ry: 5px; +} +.statediagram-state rect.divider { + stroke-dasharray: 10,10; + fill: ${options2.altBackground ? options2.altBackground : "#efefef"}; +} + +.note-edge { + stroke-dasharray: 5; +} + +.statediagram-note rect { + fill: ${options2.noteBkgColor}; + stroke: ${options2.noteBorderColor}; + stroke-width: 1px; + rx: 0; + ry: 0; +} +.statediagram-note rect { + fill: ${options2.noteBkgColor}; + stroke: ${options2.noteBorderColor}; + stroke-width: 1px; + rx: 0; + ry: 0; +} + +.statediagram-note text { + fill: ${options2.noteTextColor}; +} + +.statediagram-note .nodeLabel { + color: ${options2.noteTextColor}; +} +.statediagram .edgeLabel { + color: red; // ${options2.noteTextColor}; +} + +#dependencyStart, #dependencyEnd { + fill: ${options2.lineColor}; + stroke: ${options2.lineColor}; + stroke-width: 1; +} + +.statediagramTitleText { + text-anchor: middle; + font-size: 18px; + fill: ${options2.textColor}; +} +`; + const styles$4 = getStyles$5; + const idCache = {}; + const set = (key, val) => { + idCache[key] = val; + }; + const get = (k) => idCache[k]; + const keys = () => Object.keys(idCache); + const size = () => keys().length; + const idCache$1 = { + get, + set, + keys, + size + }; + const drawStartState = (g) => g.append("circle").attr("class", "start-state").attr("r", getConfig$1().state.sizeUnit).attr("cx", getConfig$1().state.padding + getConfig$1().state.sizeUnit).attr("cy", getConfig$1().state.padding + getConfig$1().state.sizeUnit); + const drawDivider = (g) => g.append("line").style("stroke", "grey").style("stroke-dasharray", "3").attr("x1", getConfig$1().state.textHeight).attr("class", "divider").attr("x2", getConfig$1().state.textHeight * 2).attr("y1", 0).attr("y2", 0); + const drawSimpleState = (g, stateDef) => { + const state2 = g.append("text").attr("x", 2 * getConfig$1().state.padding).attr("y", getConfig$1().state.textHeight + 2 * getConfig$1().state.padding).attr("font-size", getConfig$1().state.fontSize).attr("class", "state-title").text(stateDef.id); + const classBox = state2.node().getBBox(); + g.insert("rect", ":first-child").attr("x", getConfig$1().state.padding).attr("y", getConfig$1().state.padding).attr("width", classBox.width + 2 * getConfig$1().state.padding).attr("height", classBox.height + 2 * getConfig$1().state.padding).attr("rx", getConfig$1().state.radius); + return state2; + }; + const drawDescrState = (g, stateDef) => { + const addTspan2 = function(textEl, txt, isFirst2) { + const tSpan = textEl.append("tspan").attr("x", 2 * getConfig$1().state.padding).text(txt); + if (!isFirst2) { + tSpan.attr("dy", getConfig$1().state.textHeight); + } + }; + const title2 = g.append("text").attr("x", 2 * getConfig$1().state.padding).attr("y", getConfig$1().state.textHeight + 1.3 * getConfig$1().state.padding).attr("font-size", getConfig$1().state.fontSize).attr("class", "state-title").text(stateDef.descriptions[0]); + const titleBox = title2.node().getBBox(); + const titleHeight = titleBox.height; + const description = g.append("text").attr("x", getConfig$1().state.padding).attr( + "y", + titleHeight + getConfig$1().state.padding * 0.4 + getConfig$1().state.dividerMargin + getConfig$1().state.textHeight + ).attr("class", "state-description"); + let isFirst = true; + let isSecond = true; + stateDef.descriptions.forEach(function(descr) { + if (!isFirst) { + addTspan2(description, descr, isSecond); + isSecond = false; + } + isFirst = false; + }); + const descrLine = g.append("line").attr("x1", getConfig$1().state.padding).attr("y1", getConfig$1().state.padding + titleHeight + getConfig$1().state.dividerMargin / 2).attr("y2", getConfig$1().state.padding + titleHeight + getConfig$1().state.dividerMargin / 2).attr("class", "descr-divider"); + const descrBox = description.node().getBBox(); + const width2 = Math.max(descrBox.width, titleBox.width); + descrLine.attr("x2", width2 + 3 * getConfig$1().state.padding); + g.insert("rect", ":first-child").attr("x", getConfig$1().state.padding).attr("y", getConfig$1().state.padding).attr("width", width2 + 2 * getConfig$1().state.padding).attr("height", descrBox.height + titleHeight + 2 * getConfig$1().state.padding).attr("rx", getConfig$1().state.radius); + return g; + }; + const addTitleAndBox = (g, stateDef, altBkg) => { + const pad2 = getConfig$1().state.padding; + const dblPad = 2 * getConfig$1().state.padding; + const orgBox = g.node().getBBox(); + const orgWidth = orgBox.width; + const orgX = orgBox.x; + const title2 = g.append("text").attr("x", 0).attr("y", getConfig$1().state.titleShift).attr("font-size", getConfig$1().state.fontSize).attr("class", "state-title").text(stateDef.id); + const titleBox = title2.node().getBBox(); + const titleWidth = titleBox.width + dblPad; + let width2 = Math.max(titleWidth, orgWidth); + if (width2 === orgWidth) { + width2 = width2 + dblPad; + } + let startX; + const graphBox = g.node().getBBox(); + if (stateDef.doc) + ; + startX = orgX - pad2; + if (titleWidth > orgWidth) { + startX = (orgWidth - width2) / 2 + pad2; + } + if (Math.abs(orgX - graphBox.x) < pad2 && titleWidth > orgWidth) { + startX = orgX - (titleWidth - orgWidth) / 2; + } + const lineY = 1 - getConfig$1().state.textHeight; + g.insert("rect", ":first-child").attr("x", startX).attr("y", lineY).attr("class", altBkg ? "alt-composit" : "composit").attr("width", width2).attr( + "height", + graphBox.height + getConfig$1().state.textHeight + getConfig$1().state.titleShift + 1 + ).attr("rx", "0"); + title2.attr("x", startX + pad2); + if (titleWidth <= orgWidth) { + title2.attr("x", orgX + (width2 - dblPad) / 2 - titleWidth / 2 + pad2); + } + g.insert("rect", ":first-child").attr("x", startX).attr( + "y", + getConfig$1().state.titleShift - getConfig$1().state.textHeight - getConfig$1().state.padding + ).attr("width", width2).attr("height", getConfig$1().state.textHeight * 3).attr("rx", getConfig$1().state.radius); + g.insert("rect", ":first-child").attr("x", startX).attr( + "y", + getConfig$1().state.titleShift - getConfig$1().state.textHeight - getConfig$1().state.padding + ).attr("width", width2).attr("height", graphBox.height + 3 + 2 * getConfig$1().state.textHeight).attr("rx", getConfig$1().state.radius); + return g; + }; + const drawEndState = (g) => { + g.append("circle").attr("class", "end-state-outer").attr("r", getConfig$1().state.sizeUnit + getConfig$1().state.miniPadding).attr( + "cx", + getConfig$1().state.padding + getConfig$1().state.sizeUnit + getConfig$1().state.miniPadding + ).attr( + "cy", + getConfig$1().state.padding + getConfig$1().state.sizeUnit + getConfig$1().state.miniPadding + ); + return g.append("circle").attr("class", "end-state-inner").attr("r", getConfig$1().state.sizeUnit).attr("cx", getConfig$1().state.padding + getConfig$1().state.sizeUnit + 2).attr("cy", getConfig$1().state.padding + getConfig$1().state.sizeUnit + 2); + }; + const drawForkJoinState = (g, stateDef) => { + let width2 = getConfig$1().state.forkWidth; + let height = getConfig$1().state.forkHeight; + if (stateDef.parentId) { + let tmp = width2; + width2 = height; + height = tmp; + } + return g.append("rect").style("stroke", "black").style("fill", "black").attr("width", width2).attr("height", height).attr("x", getConfig$1().state.padding).attr("y", getConfig$1().state.padding); + }; + const _drawLongText = (_text, x2, y2, g) => { + let textHeight = 0; + const textElem = g.append("text"); + textElem.style("text-anchor", "start"); + textElem.attr("class", "noteText"); + let text2 = _text.replace(/\r\n/g, "
    "); + text2 = text2.replace(/\n/g, "
    "); + const lines = text2.split(common$1.lineBreakRegex); + let tHeight = 1.25 * getConfig$1().state.noteMargin; + for (const line2 of lines) { + const txt = line2.trim(); + if (txt.length > 0) { + const span = textElem.append("tspan"); + span.text(txt); + if (tHeight === 0) { + const textBounds = span.node().getBBox(); + tHeight += textBounds.height; + } + textHeight += tHeight; + span.attr("x", x2 + getConfig$1().state.noteMargin); + span.attr("y", y2 + textHeight + 1.25 * getConfig$1().state.noteMargin); + } + } + return { textWidth: textElem.node().getBBox().width, textHeight }; + }; + const drawNote = (text2, g) => { + g.attr("class", "state-note"); + const note2 = g.append("rect").attr("x", 0).attr("y", getConfig$1().state.padding); + const rectElem = g.append("g"); + const { textWidth, textHeight } = _drawLongText(text2, 0, 0, rectElem); + note2.attr("height", textHeight + 2 * getConfig$1().state.noteMargin); + note2.attr("width", textWidth + getConfig$1().state.noteMargin * 2); + return note2; + }; + const drawState = function(elem, stateDef) { + const id2 = stateDef.id; + const stateInfo = { + id: id2, + label: stateDef.id, + width: 0, + height: 0 + }; + const g = elem.append("g").attr("id", id2).attr("class", "stateGroup"); + if (stateDef.type === "start") { + drawStartState(g); + } + if (stateDef.type === "end") { + drawEndState(g); + } + if (stateDef.type === "fork" || stateDef.type === "join") { + drawForkJoinState(g, stateDef); + } + if (stateDef.type === "note") { + drawNote(stateDef.note.text, g); + } + if (stateDef.type === "divider") { + drawDivider(g); + } + if (stateDef.type === "default" && stateDef.descriptions.length === 0) { + drawSimpleState(g, stateDef); + } + if (stateDef.type === "default" && stateDef.descriptions.length > 0) { + drawDescrState(g, stateDef); + } + const stateBox = g.node().getBBox(); + stateInfo.width = stateBox.width + 2 * getConfig$1().state.padding; + stateInfo.height = stateBox.height + 2 * getConfig$1().state.padding; + idCache$1.set(id2, stateInfo); + return stateInfo; + }; + let edgeCount$1 = 0; + const drawEdge = function(elem, path2, relation) { + const getRelationType = function(type2) { + switch (type2) { + case db$7.relationType.AGGREGATION: + return "aggregation"; + case db$7.relationType.EXTENSION: + return "extension"; + case db$7.relationType.COMPOSITION: + return "composition"; + case db$7.relationType.DEPENDENCY: + return "dependency"; + } + }; + path2.points = path2.points.filter((p) => !Number.isNaN(p.y)); + const lineData = path2.points; + const lineFunction = line$1().x(function(d) { + return d.x; + }).y(function(d) { + return d.y; + }).curve(curveBasis); + const svgPath = elem.append("path").attr("d", lineFunction(lineData)).attr("id", "edge" + edgeCount$1).attr("class", "transition"); + let url = ""; + if (getConfig$1().state.arrowMarkerAbsolute) { + url = window.location.protocol + "//" + window.location.host + window.location.pathname + window.location.search; + url = url.replace(/\(/g, "\\("); + url = url.replace(/\)/g, "\\)"); + } + svgPath.attr( + "marker-end", + "url(" + url + "#" + getRelationType(db$7.relationType.DEPENDENCY) + "End)" + ); + if (relation.title !== void 0) { + const label = elem.append("g").attr("class", "stateLabel"); + const { x: x2, y: y2 } = utils$1.calcLabelPosition(path2.points); + const rows = common$1.getRows(relation.title); + let titleHeight = 0; + const titleRows = []; + let maxWidth = 0; + let minX = 0; + for (let i2 = 0; i2 <= rows.length; i2++) { + const title2 = label.append("text").attr("text-anchor", "middle").text(rows[i2]).attr("x", x2).attr("y", y2 + titleHeight); + const boundsTmp = title2.node().getBBox(); + maxWidth = Math.max(maxWidth, boundsTmp.width); + minX = Math.min(minX, boundsTmp.x); + log$1.info(boundsTmp.x, x2, y2 + titleHeight); + if (titleHeight === 0) { + const titleBox = title2.node().getBBox(); + titleHeight = titleBox.height; + log$1.info("Title height", titleHeight, y2); + } + titleRows.push(title2); + } + let boxHeight = titleHeight * rows.length; + if (rows.length > 1) { + const heightAdj = (rows.length - 1) * titleHeight * 0.5; + titleRows.forEach((title2, i2) => title2.attr("y", y2 + i2 * titleHeight - heightAdj)); + boxHeight = titleHeight * rows.length; + } + const bounds2 = label.node().getBBox(); + label.insert("rect", ":first-child").attr("class", "box").attr("x", x2 - maxWidth / 2 - getConfig$1().state.padding / 2).attr("y", y2 - boxHeight / 2 - getConfig$1().state.padding / 2 - 3.5).attr("width", maxWidth + getConfig$1().state.padding).attr("height", boxHeight + getConfig$1().state.padding); + log$1.info(bounds2); + } + edgeCount$1++; + }; + let conf$2; + const transformationLog = {}; + const setConf$2 = function() { + }; + const insertMarkers = function(elem) { + elem.append("defs").append("marker").attr("id", "dependencyEnd").attr("refX", 19).attr("refY", 7).attr("markerWidth", 20).attr("markerHeight", 28).attr("orient", "auto").append("path").attr("d", "M 19,7 L9,13 L14,7 L9,1 Z"); + }; + const draw$7 = function(text2, id2, _version, diagObj) { + conf$2 = getConfig$1().state; + const securityLevel = getConfig$1().securityLevel; + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = d3select("#i" + id2); + } + const root2 = securityLevel === "sandbox" ? d3select(sandboxElement.nodes()[0].contentDocument.body) : d3select("body"); + const doc = securityLevel === "sandbox" ? sandboxElement.nodes()[0].contentDocument : document; + log$1.debug("Rendering diagram " + text2); + const diagram2 = root2.select(`[id='${id2}']`); + insertMarkers(diagram2); + const rootDoc2 = diagObj.db.getRootDoc(); + renderDoc(rootDoc2, diagram2, void 0, false, root2, doc, diagObj); + const padding2 = conf$2.padding; + const bounds2 = diagram2.node().getBBox(); + const width2 = bounds2.width + padding2 * 2; + const height = bounds2.height + padding2 * 2; + const svgWidth = width2 * 1.75; + configureSvgSize(diagram2, height, svgWidth, conf$2.useMaxWidth); + diagram2.attr( + "viewBox", + `${bounds2.x - conf$2.padding} ${bounds2.y - conf$2.padding} ` + width2 + " " + height + ); + }; + const getLabelWidth = (text2) => { + return text2 ? text2.length * conf$2.fontSizeFactor : 1; + }; + const renderDoc = (doc, diagram2, parentId, altBkg, root2, domDocument, diagObj) => { + const graph = new Graph({ + compound: true, + multigraph: true + }); + let i2; + let edgeFreeDoc = true; + for (i2 = 0; i2 < doc.length; i2++) { + if (doc[i2].stmt === "relation") { + edgeFreeDoc = false; + break; + } + } + if (parentId) { + graph.setGraph({ + rankdir: "LR", + multigraph: true, + compound: true, + // acyclicer: 'greedy', + ranker: "tight-tree", + ranksep: edgeFreeDoc ? 1 : conf$2.edgeLengthFactor, + nodeSep: edgeFreeDoc ? 1 : 50, + isMultiGraph: true + // ranksep: 5, + // nodesep: 1 + }); + } else { + graph.setGraph({ + rankdir: "TB", + multigraph: true, + compound: true, + // isCompound: true, + // acyclicer: 'greedy', + // ranker: 'longest-path' + ranksep: edgeFreeDoc ? 1 : conf$2.edgeLengthFactor, + nodeSep: edgeFreeDoc ? 1 : 50, + ranker: "tight-tree", + // ranker: 'network-simplex' + isMultiGraph: true + }); + } + graph.setDefaultEdgeLabel(function() { + return {}; + }); + diagObj.db.extract(doc); + const states = diagObj.db.getStates(); + const relations2 = diagObj.db.getRelations(); + const keys2 = Object.keys(states); + for (const key of keys2) { + const stateDef = states[key]; + if (parentId) { + stateDef.parentId = parentId; + } + let node2; + if (stateDef.doc) { + let sub2 = diagram2.append("g").attr("id", stateDef.id).attr("class", "stateGroup"); + node2 = renderDoc(stateDef.doc, sub2, stateDef.id, !altBkg, root2, domDocument, diagObj); + { + sub2 = addTitleAndBox(sub2, stateDef, altBkg); + let boxBounds = sub2.node().getBBox(); + node2.width = boxBounds.width; + node2.height = boxBounds.height + conf$2.padding / 2; + transformationLog[stateDef.id] = { y: conf$2.compositTitleSize }; + } + } else { + node2 = drawState(diagram2, stateDef); + } + if (stateDef.note) { + const noteDef = { + descriptions: [], + id: stateDef.id + "-note", + note: stateDef.note, + type: "note" + }; + const note2 = drawState(diagram2, noteDef); + if (stateDef.note.position === "left of") { + graph.setNode(node2.id + "-note", note2); + graph.setNode(node2.id, node2); + } else { + graph.setNode(node2.id, node2); + graph.setNode(node2.id + "-note", note2); + } + graph.setParent(node2.id, node2.id + "-group"); + graph.setParent(node2.id + "-note", node2.id + "-group"); + } else { + graph.setNode(node2.id, node2); + } + } + log$1.debug("Count=", graph.nodeCount(), graph); + let cnt2 = 0; + relations2.forEach(function(relation) { + cnt2++; + log$1.debug("Setting edge", relation); + graph.setEdge( + relation.id1, + relation.id2, + { + relation, + width: getLabelWidth(relation.title), + height: conf$2.labelHeight * common$1.getRows(relation.title).length, + labelpos: "c" + }, + "id" + cnt2 + ); + }); + layout$1(graph); + log$1.debug("Graph after layout", graph.nodes()); + const svgElem = diagram2.node(); + graph.nodes().forEach(function(v) { + if (v !== void 0 && graph.node(v) !== void 0) { + log$1.warn("Node " + v + ": " + JSON.stringify(graph.node(v))); + root2.select("#" + svgElem.id + " #" + v).attr( + "transform", + "translate(" + (graph.node(v).x - graph.node(v).width / 2) + "," + (graph.node(v).y + (transformationLog[v] ? transformationLog[v].y : 0) - graph.node(v).height / 2) + " )" + ); + root2.select("#" + svgElem.id + " #" + v).attr("data-x-shift", graph.node(v).x - graph.node(v).width / 2); + const dividers = domDocument.querySelectorAll("#" + svgElem.id + " #" + v + " .divider"); + dividers.forEach((divider2) => { + const parent = divider2.parentElement; + let pWidth = 0; + let pShift = 0; + if (parent) { + if (parent.parentElement) { + pWidth = parent.parentElement.getBBox().width; + } + pShift = parseInt(parent.getAttribute("data-x-shift"), 10); + if (Number.isNaN(pShift)) { + pShift = 0; + } + } + divider2.setAttribute("x1", 0 - pShift + 8); + divider2.setAttribute("x2", pWidth - pShift - 8); + }); + } else { + log$1.debug("No Node " + v + ": " + JSON.stringify(graph.node(v))); + } + }); + let stateBox = svgElem.getBBox(); + graph.edges().forEach(function(e) { + if (e !== void 0 && graph.edge(e) !== void 0) { + log$1.debug("Edge " + e.v + " -> " + e.w + ": " + JSON.stringify(graph.edge(e))); + drawEdge(diagram2, graph.edge(e), graph.edge(e).relation); + } + }); + stateBox = svgElem.getBBox(); + const stateInfo = { + id: parentId ? parentId : "root", + label: parentId ? parentId : "root", + width: 0, + height: 0 + }; + stateInfo.width = stateBox.width + 2 * conf$2.padding; + stateInfo.height = stateBox.height + 2 * conf$2.padding; + log$1.debug("Doc rendered", stateInfo, graph); + return stateInfo; + }; + const renderer$7 = { + setConf: setConf$2, + draw: draw$7 + }; + const diagram$7 = { + parser: parser$b, + db: db$7, + renderer: renderer$7, + styles: styles$4, + init: (cnf) => { + if (!cnf.state) { + cnf.state = {}; + } + cnf.state.arrowMarkerAbsolute = cnf.arrowMarkerAbsolute; + db$7.clear(); + } + }; + const stateDiagram = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + diagram: diagram$7 + }, Symbol.toStringTag, { value: "Module" })); + const SHAPE_STATE = "rect"; + const SHAPE_STATE_WITH_DESC = "rectWithTitle"; + const SHAPE_START = "start"; + const SHAPE_END = "end"; + const SHAPE_DIVIDER = "divider"; + const SHAPE_GROUP = "roundedWithTitle"; + const SHAPE_NOTE = "note"; + const SHAPE_NOTEGROUP = "noteGroup"; + const CSS_DIAGRAM = "statediagram"; + const CSS_STATE = "state"; + const CSS_DIAGRAM_STATE = `${CSS_DIAGRAM}-${CSS_STATE}`; + const CSS_EDGE = "transition"; + const CSS_NOTE = "note"; + const CSS_NOTE_EDGE = "note-edge"; + const CSS_EDGE_NOTE_EDGE = `${CSS_EDGE} ${CSS_NOTE_EDGE}`; + const CSS_DIAGRAM_NOTE = `${CSS_DIAGRAM}-${CSS_NOTE}`; + const CSS_CLUSTER = "cluster"; + const CSS_DIAGRAM_CLUSTER = `${CSS_DIAGRAM}-${CSS_CLUSTER}`; + const CSS_CLUSTER_ALT = "cluster-alt"; + const CSS_DIAGRAM_CLUSTER_ALT = `${CSS_DIAGRAM}-${CSS_CLUSTER_ALT}`; + const PARENT = "parent"; + const NOTE = "note"; + const DOMID_STATE = "state"; + const DOMID_TYPE_SPACER = "----"; + const NOTE_ID = `${DOMID_TYPE_SPACER}${NOTE}`; + const PARENT_ID = `${DOMID_TYPE_SPACER}${PARENT}`; + const G_EDGE_STYLE = "fill:none"; + const G_EDGE_ARROWHEADSTYLE = "fill: #333"; + const G_EDGE_LABELPOS = "c"; + const G_EDGE_LABELTYPE = "text"; + const G_EDGE_THICKNESS = "normal"; + let nodeDb$1 = {}; + let graphItemCount = 0; + const setConf$1 = function(cnf) { + const keys2 = Object.keys(cnf); + for (const key of keys2) { + cnf[key]; + } + }; + const getClasses$3 = function(text2, diagramObj) { + diagramObj.db.extract(diagramObj.db.getRootDocV2()); + return diagramObj.db.getClasses(); + }; + function getClassesFromDbInfo(dbInfoItem) { + if (dbInfoItem === void 0 || dbInfoItem === null) { + return ""; + } else { + if (dbInfoItem.classes) { + return dbInfoItem.classes.join(" "); + } else { + return ""; + } + } + } + function stateDomId(itemId = "", counter = 0, type2 = "", typeSpacer = DOMID_TYPE_SPACER) { + const typeStr = type2 !== null && type2.length > 0 ? `${typeSpacer}${type2}` : ""; + return `${DOMID_STATE}-${itemId}${typeStr}-${counter}`; + } + const setupNode = (g, parent, parsedItem, diagramStates, diagramDb, altFlag) => { + const itemId = parsedItem.id; + const classStr = getClassesFromDbInfo(diagramStates[itemId]); + if (itemId !== "root") { + let shape = SHAPE_STATE; + if (parsedItem.start === true) { + shape = SHAPE_START; + } + if (parsedItem.start === false) { + shape = SHAPE_END; + } + if (parsedItem.type !== DEFAULT_STATE_TYPE) { + shape = parsedItem.type; + } + if (!nodeDb$1[itemId]) { + nodeDb$1[itemId] = { + id: itemId, + shape, + description: common$1.sanitizeText(itemId, getConfig$1()), + classes: `${classStr} ${CSS_DIAGRAM_STATE}` + }; + } + const newNode = nodeDb$1[itemId]; + if (parsedItem.description) { + if (Array.isArray(newNode.description)) { + newNode.shape = SHAPE_STATE_WITH_DESC; + newNode.description.push(parsedItem.description); + } else { + if (newNode.description.length > 0) { + newNode.shape = SHAPE_STATE_WITH_DESC; + if (newNode.description === itemId) { + newNode.description = [parsedItem.description]; + } else { + newNode.description = [newNode.description, parsedItem.description]; + } + } else { + newNode.shape = SHAPE_STATE; + newNode.description = parsedItem.description; + } + } + newNode.description = common$1.sanitizeTextOrArray(newNode.description, getConfig$1()); + } + if (newNode.description.length === 1 && newNode.shape === SHAPE_STATE_WITH_DESC) { + newNode.shape = SHAPE_STATE; + } + if (!newNode.type && parsedItem.doc) { + log$1.info("Setting cluster for ", itemId, getDir(parsedItem)); + newNode.type = "group"; + newNode.dir = getDir(parsedItem); + newNode.shape = parsedItem.type === DIVIDER_TYPE ? SHAPE_DIVIDER : SHAPE_GROUP; + newNode.classes = newNode.classes + " " + CSS_DIAGRAM_CLUSTER + " " + (altFlag ? CSS_DIAGRAM_CLUSTER_ALT : ""); + } + const nodeData = { + labelStyle: "", + shape: newNode.shape, + labelText: newNode.description, + // typeof newNode.description === 'object' + // ? newNode.description[0] + // : newNode.description, + classes: newNode.classes, + style: "", + //styles.style, + id: itemId, + dir: newNode.dir, + domId: stateDomId(itemId, graphItemCount), + type: newNode.type, + padding: 15 + //getConfig().flowchart.padding + }; + nodeData.centerLabel = true; + if (parsedItem.note) { + const noteData = { + labelStyle: "", + shape: SHAPE_NOTE, + labelText: parsedItem.note.text, + classes: CSS_DIAGRAM_NOTE, + // useHtmlLabels: false, + style: "", + // styles.style, + id: itemId + NOTE_ID + "-" + graphItemCount, + domId: stateDomId(itemId, graphItemCount, NOTE), + type: newNode.type, + padding: 15 + //getConfig().flowchart.padding + }; + const groupData = { + labelStyle: "", + shape: SHAPE_NOTEGROUP, + labelText: parsedItem.note.text, + classes: newNode.classes, + style: "", + // styles.style, + id: itemId + PARENT_ID, + domId: stateDomId(itemId, graphItemCount, PARENT), + type: "group", + padding: 0 + //getConfig().flowchart.padding + }; + graphItemCount++; + const parentNodeId = itemId + PARENT_ID; + g.setNode(parentNodeId, groupData); + g.setNode(noteData.id, noteData); + g.setNode(itemId, nodeData); + g.setParent(itemId, parentNodeId); + g.setParent(noteData.id, parentNodeId); + let from2 = itemId; + let to = noteData.id; + if (parsedItem.note.position === "left of") { + from2 = noteData.id; + to = itemId; + } + g.setEdge(from2, to, { + arrowhead: "none", + arrowType: "", + style: G_EDGE_STYLE, + labelStyle: "", + classes: CSS_EDGE_NOTE_EDGE, + arrowheadStyle: G_EDGE_ARROWHEADSTYLE, + labelpos: G_EDGE_LABELPOS, + labelType: G_EDGE_LABELTYPE, + thickness: G_EDGE_THICKNESS + }); + } else { + g.setNode(itemId, nodeData); + } + } + if (parent && parent.id !== "root") { + log$1.trace("Setting node ", itemId, " to be child of its parent ", parent.id); + g.setParent(itemId, parent.id); + } + if (parsedItem.doc) { + log$1.trace("Adding nodes children "); + setupDoc(g, parsedItem, parsedItem.doc, diagramStates, diagramDb, !altFlag); + } + }; + const setupDoc = (g, parentParsedItem, doc, diagramStates, diagramDb, altFlag) => { + log$1.trace("items", doc); + doc.forEach((item) => { + switch (item.stmt) { + case STMT_STATE: + setupNode(g, parentParsedItem, item, diagramStates, diagramDb, altFlag); + break; + case DEFAULT_STATE_TYPE: + setupNode(g, parentParsedItem, item, diagramStates, diagramDb, altFlag); + break; + case STMT_RELATION: + { + setupNode(g, parentParsedItem, item.state1, diagramStates, diagramDb, altFlag); + setupNode(g, parentParsedItem, item.state2, diagramStates, diagramDb, altFlag); + const edgeData = { + id: "edge" + graphItemCount, + arrowhead: "normal", + arrowTypeEnd: "arrow_barb", + style: G_EDGE_STYLE, + labelStyle: "", + label: common$1.sanitizeText(item.description, getConfig$1()), + arrowheadStyle: G_EDGE_ARROWHEADSTYLE, + labelpos: G_EDGE_LABELPOS, + labelType: G_EDGE_LABELTYPE, + thickness: G_EDGE_THICKNESS, + classes: CSS_EDGE + }; + g.setEdge(item.state1.id, item.state2.id, edgeData, graphItemCount); + graphItemCount++; + } + break; + } + }); + }; + const getDir = (parsedItem, defaultDir = DEFAULT_NESTED_DOC_DIR) => { + let dir2 = defaultDir; + if (parsedItem.doc) { + for (let i2 = 0; i2 < parsedItem.doc.length; i2++) { + const parsedItemDoc = parsedItem.doc[i2]; + if (parsedItemDoc.stmt === "dir") { + dir2 = parsedItemDoc.value; + } + } + } + return dir2; + }; + const draw$6 = async function(text2, id2, _version, diag) { + log$1.info("Drawing state diagram (v2)", id2); + nodeDb$1 = {}; + diag.db.getDirection(); + const { securityLevel, state: conf2 } = getConfig$1(); + const nodeSpacing = conf2.nodeSpacing || 50; + const rankSpacing = conf2.rankSpacing || 50; + log$1.info(diag.db.getRootDocV2()); + diag.db.extract(diag.db.getRootDocV2()); + log$1.info(diag.db.getRootDocV2()); + const diagramStates = diag.db.getStates(); + const g = new Graph({ + multigraph: true, + compound: true + }).setGraph({ + rankdir: getDir(diag.db.getRootDocV2()), + nodesep: nodeSpacing, + ranksep: rankSpacing, + marginx: 8, + marginy: 8 + }).setDefaultEdgeLabel(function() { + return {}; + }); + setupNode(g, void 0, diag.db.getRootDocV2(), diagramStates, diag.db, true); + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = d3select("#i" + id2); + } + const root2 = securityLevel === "sandbox" ? d3select(sandboxElement.nodes()[0].contentDocument.body) : d3select("body"); + const svg2 = root2.select(`[id="${id2}"]`); + const element2 = root2.select("#" + id2 + " g"); + await render(element2, g, ["barb"], CSS_DIAGRAM, id2); + const padding2 = 8; + utils$1.insertTitle(svg2, "statediagramTitleText", conf2.titleTopMargin, diag.db.getDiagramTitle()); + const bounds2 = svg2.node().getBBox(); + const width2 = bounds2.width + padding2 * 2; + const height = bounds2.height + padding2 * 2; + svg2.attr("class", CSS_DIAGRAM); + const svgBounds = svg2.node().getBBox(); + configureSvgSize(svg2, height, width2, conf2.useMaxWidth); + const vBox = `${svgBounds.x - padding2} ${svgBounds.y - padding2} ${width2} ${height}`; + log$1.debug(`viewBox ${vBox}`); + svg2.attr("viewBox", vBox); + const labels = document.querySelectorAll('[id="' + id2 + '"] .edgeLabel .label'); + for (const label of labels) { + const dim = label.getBBox(); + const rect2 = document.createElementNS("http://www.w3.org/2000/svg", SHAPE_STATE); + rect2.setAttribute("rx", 0); + rect2.setAttribute("ry", 0); + rect2.setAttribute("width", dim.width); + rect2.setAttribute("height", dim.height); + label.insertBefore(rect2, label.firstChild); + } + }; + const renderer$6 = { + setConf: setConf$1, + getClasses: getClasses$3, + draw: draw$6 + }; + const diagram$6 = { + parser: parser$b, + db: db$7, + renderer: renderer$6, + styles: styles$4, + init: (cnf) => { + if (!cnf.state) { + cnf.state = {}; + } + cnf.state.arrowMarkerAbsolute = cnf.arrowMarkerAbsolute; + db$7.clear(); + } + }; + const stateDiagramV2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + diagram: diagram$6 + }, Symbol.toStringTag, { value: "Module" })); + var parser$8 = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [6, 8, 10, 11, 12, 14, 16, 17, 18], $V1 = [1, 9], $V2 = [1, 10], $V3 = [1, 11], $V4 = [1, 12], $V5 = [1, 13], $V6 = [1, 14]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "journey": 4, "document": 5, "EOF": 6, "line": 7, "SPACE": 8, "statement": 9, "NEWLINE": 10, "title": 11, "acc_title": 12, "acc_title_value": 13, "acc_descr": 14, "acc_descr_value": 15, "acc_descr_multiline_value": 16, "section": 17, "taskName": 18, "taskData": 19, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 4: "journey", 6: "EOF", 8: "SPACE", 10: "NEWLINE", 11: "title", 12: "acc_title", 13: "acc_title_value", 14: "acc_descr", 15: "acc_descr_value", 16: "acc_descr_multiline_value", 17: "section", 18: "taskName", 19: "taskData" }, + productions_: [0, [3, 3], [5, 0], [5, 2], [7, 2], [7, 1], [7, 1], [7, 1], [9, 1], [9, 2], [9, 2], [9, 1], [9, 1], [9, 2]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 1: + return $$[$0 - 1]; + case 2: + this.$ = []; + break; + case 3: + $$[$0 - 1].push($$[$0]); + this.$ = $$[$0 - 1]; + break; + case 4: + case 5: + this.$ = $$[$0]; + break; + case 6: + case 7: + this.$ = []; + break; + case 8: + yy.setDiagramTitle($$[$0].substr(6)); + this.$ = $$[$0].substr(6); + break; + case 9: + this.$ = $$[$0].trim(); + yy.setAccTitle(this.$); + break; + case 10: + case 11: + this.$ = $$[$0].trim(); + yy.setAccDescription(this.$); + break; + case 12: + yy.addSection($$[$0].substr(8)); + this.$ = $$[$0].substr(8); + break; + case 13: + yy.addTask($$[$0 - 1], $$[$0]); + this.$ = "task"; + break; + } + }, + table: [{ 3: 1, 4: [1, 2] }, { 1: [3] }, o($V0, [2, 2], { 5: 3 }), { 6: [1, 4], 7: 5, 8: [1, 6], 9: 7, 10: [1, 8], 11: $V1, 12: $V2, 14: $V3, 16: $V4, 17: $V5, 18: $V6 }, o($V0, [2, 7], { 1: [2, 1] }), o($V0, [2, 3]), { 9: 15, 11: $V1, 12: $V2, 14: $V3, 16: $V4, 17: $V5, 18: $V6 }, o($V0, [2, 5]), o($V0, [2, 6]), o($V0, [2, 8]), { 13: [1, 16] }, { 15: [1, 17] }, o($V0, [2, 11]), o($V0, [2, 12]), { 19: [1, 18] }, o($V0, [2, 4]), o($V0, [2, 9]), o($V0, [2, 10]), o($V0, [2, 13])], + defaultActions: {}, + parseError: function parseError(str2, hash) { + if (hash.recoverable) { + this.trace(str2); + } else { + var error = new Error(str2); + error.hash = hash; + throw error; + } + }, + parse: function parse2(input) { + var self2 = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex2() { + var token2; + token2 = tstack.pop() || lexer2.lex() || EOF; + if (typeof token2 !== "number") { + if (token2 instanceof Array) { + tstack = token2; + token2 = tstack.pop(); + } + token2 = self2.symbols_[token2] || token2; + } + return token2; + } + var symbol, state2, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state2 = stack[stack.length - 1]; + if (this.defaultActions[state2]) { + action = this.defaultActions[state2]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex2(); + } + action = table[state2] && table[state2][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state2]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state2 + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str2, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str2, hash); + } else { + throw new Error(str2); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch2 = this._input[0]; + this.yytext += ch2; + this.yyleng++; + this.offset++; + this.match += ch2; + this.matched += ch2; + var lines = ch2.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch2; + }, + // unshifts one char (or a string) into the input + unput: function(ch2) { + var len = ch2.length; + var lines = ch2.split(/(?:\r\n?|\n)/g); + this._input = ch2 + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next2 = this.match; + if (next2.length < 20) { + next2 += this._input.substr(0, 20 - next2.length); + } + return (next2.substr(0, 20) + (next2.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c2 = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c2 + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token2, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token2 = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token2) { + return token2; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token2, match, tempMatch, index2; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i2 = 0; i2 < rules.length; i2++) { + tempMatch = this._input.match(this.rules[rules[i2]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index2 = i2; + if (this.options.backtrack_lexer) { + token2 = this.test_match(tempMatch, rules[i2]); + if (token2 !== false) { + return token2; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token2 = this.test_match(match, rules[index2]); + if (token2 !== false) { + return token2; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex2() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + break; + case 1: + break; + case 2: + return 10; + case 3: + break; + case 4: + break; + case 5: + return 4; + case 6: + return 11; + case 7: + this.begin("acc_title"); + return 12; + case 8: + this.popState(); + return "acc_title_value"; + case 9: + this.begin("acc_descr"); + return 14; + case 10: + this.popState(); + return "acc_descr_value"; + case 11: + this.begin("acc_descr_multiline"); + break; + case 12: + this.popState(); + break; + case 13: + return "acc_descr_multiline_value"; + case 14: + return 17; + case 15: + return 18; + case 16: + return 19; + case 17: + return ":"; + case 18: + return 6; + case 19: + return "INVALID"; + } + }, + rules: [/^(?:%(?!\{)[^\n]*)/i, /^(?:[^\}]%%[^\n]*)/i, /^(?:[\n]+)/i, /^(?:\s+)/i, /^(?:#[^\n]*)/i, /^(?:journey\b)/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, /^(?:section\s[^#:\n;]+)/i, /^(?:[^#:\n;]+)/i, /^(?::[^#\n;]+)/i, /^(?::)/i, /^(?:$)/i, /^(?:.)/i], + conditions: { "acc_descr_multiline": { "rules": [12, 13], "inclusive": false }, "acc_descr": { "rules": [10], "inclusive": false }, "acc_title": { "rules": [8], "inclusive": false }, "INITIAL": { "rules": [0, 1, 2, 3, 4, 5, 6, 7, 9, 11, 14, 15, 16, 17, 18, 19], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser2() { + this.yy = {}; + } + Parser2.prototype = parser2; + parser2.Parser = Parser2; + return new Parser2(); + }(); + parser$8.parser = parser$8; + const parser$9 = parser$8; + let currentSection$1 = ""; + const sections$1 = []; + const tasks$1 = []; + const rawTasks$1 = []; + const clear$4 = function() { + sections$1.length = 0; + tasks$1.length = 0; + currentSection$1 = ""; + rawTasks$1.length = 0; + clear$n(); + }; + const addSection$1 = function(txt) { + currentSection$1 = txt; + sections$1.push(txt); + }; + const getSections$1 = function() { + return sections$1; + }; + const getTasks$1 = function() { + let allItemsProcessed = compileTasks$1(); + const maxDepth = 100; + let iterationCount = 0; + while (!allItemsProcessed && iterationCount < maxDepth) { + allItemsProcessed = compileTasks$1(); + iterationCount++; + } + tasks$1.push(...rawTasks$1); + return tasks$1; + }; + const updateActors = function() { + const tempActors = []; + tasks$1.forEach((task) => { + if (task.people) { + tempActors.push(...task.people); + } + }); + const unique = new Set(tempActors); + return [...unique].sort(); + }; + const addTask$1 = function(descr, taskData) { + const pieces = taskData.substr(1).split(":"); + let score = 0; + let peeps = []; + if (pieces.length === 1) { + score = Number(pieces[0]); + peeps = []; + } else { + score = Number(pieces[0]); + peeps = pieces[1].split(","); + } + const peopleList = peeps.map((s) => s.trim()); + const rawTask = { + section: currentSection$1, + type: currentSection$1, + people: peopleList, + task: descr, + score + }; + rawTasks$1.push(rawTask); + }; + const addTaskOrg$1 = function(descr) { + const newTask = { + section: currentSection$1, + type: currentSection$1, + description: descr, + task: descr, + classes: [] + }; + tasks$1.push(newTask); + }; + const compileTasks$1 = function() { + const compileTask = function(pos) { + return rawTasks$1[pos].processed; + }; + let allProcessed = true; + for (const [i2, rawTask] of rawTasks$1.entries()) { + compileTask(i2); + allProcessed = allProcessed && rawTask.processed; + } + return allProcessed; + }; + const getActors = function() { + return updateActors(); + }; + const db$6 = { + getConfig: () => getConfig$1().journey, + clear: clear$4, + setDiagramTitle, + getDiagramTitle, + setAccTitle, + getAccTitle, + setAccDescription, + getAccDescription, + addSection: addSection$1, + getSections: getSections$1, + getTasks: getTasks$1, + addTask: addTask$1, + addTaskOrg: addTaskOrg$1, + getActors + }; + const getStyles$4 = (options2) => `.label { + font-family: 'trebuchet ms', verdana, arial, sans-serif; + font-family: var(--mermaid-font-family); + color: ${options2.textColor}; + } + .mouth { + stroke: #666; + } + + line { + stroke: ${options2.textColor} + } + + .legend { + fill: ${options2.textColor}; + } + + .label text { + fill: #333; + } + .label { + color: ${options2.textColor} + } + + .face { + ${options2.faceColor ? `fill: ${options2.faceColor}` : "fill: #FFF8DC"}; + stroke: #999; + } + + .node rect, + .node circle, + .node ellipse, + .node polygon, + .node path { + fill: ${options2.mainBkg}; + stroke: ${options2.nodeBorder}; + stroke-width: 1px; + } + + .node .label { + text-align: center; + } + .node.clickable { + cursor: pointer; + } + + .arrowheadPath { + fill: ${options2.arrowheadColor}; + } + + .edgePath .path { + stroke: ${options2.lineColor}; + stroke-width: 1.5px; + } + + .flowchart-link { + stroke: ${options2.lineColor}; + fill: none; + } + + .edgeLabel { + background-color: ${options2.edgeLabelBackground}; + rect { + opacity: 0.5; + } + text-align: center; + } + + .cluster rect { + } + + .cluster text { + fill: ${options2.titleColor}; + } + + div.mermaidTooltip { + position: absolute; + text-align: center; + max-width: 200px; + padding: 2px; + font-family: 'trebuchet ms', verdana, arial, sans-serif; + font-family: var(--mermaid-font-family); + font-size: 12px; + background: ${options2.tertiaryColor}; + border: 1px solid ${options2.border2}; + border-radius: 2px; + pointer-events: none; + z-index: 100; + } + + .task-type-0, .section-type-0 { + ${options2.fillType0 ? `fill: ${options2.fillType0}` : ""}; + } + .task-type-1, .section-type-1 { + ${options2.fillType0 ? `fill: ${options2.fillType1}` : ""}; + } + .task-type-2, .section-type-2 { + ${options2.fillType0 ? `fill: ${options2.fillType2}` : ""}; + } + .task-type-3, .section-type-3 { + ${options2.fillType0 ? `fill: ${options2.fillType3}` : ""}; + } + .task-type-4, .section-type-4 { + ${options2.fillType0 ? `fill: ${options2.fillType4}` : ""}; + } + .task-type-5, .section-type-5 { + ${options2.fillType0 ? `fill: ${options2.fillType5}` : ""}; + } + .task-type-6, .section-type-6 { + ${options2.fillType0 ? `fill: ${options2.fillType6}` : ""}; + } + .task-type-7, .section-type-7 { + ${options2.fillType0 ? `fill: ${options2.fillType7}` : ""}; + } + + .actor-0 { + ${options2.actor0 ? `fill: ${options2.actor0}` : ""}; + } + .actor-1 { + ${options2.actor1 ? `fill: ${options2.actor1}` : ""}; + } + .actor-2 { + ${options2.actor2 ? `fill: ${options2.actor2}` : ""}; + } + .actor-3 { + ${options2.actor3 ? `fill: ${options2.actor3}` : ""}; + } + .actor-4 { + ${options2.actor4 ? `fill: ${options2.actor4}` : ""}; + } + .actor-5 { + ${options2.actor5 ? `fill: ${options2.actor5}` : ""}; + } +`; + const styles$3 = getStyles$4; + const drawRect$1 = function(elem, rectData) { + return drawRect$4(elem, rectData); + }; + const drawFace$1 = function(element2, faceData) { + const radius = 15; + const circleElement = element2.append("circle").attr("cx", faceData.cx).attr("cy", faceData.cy).attr("class", "face").attr("r", radius).attr("stroke-width", 2).attr("overflow", "visible"); + const face = element2.append("g"); + face.append("circle").attr("cx", faceData.cx - radius / 3).attr("cy", faceData.cy - radius / 3).attr("r", 1.5).attr("stroke-width", 2).attr("fill", "#666").attr("stroke", "#666"); + face.append("circle").attr("cx", faceData.cx + radius / 3).attr("cy", faceData.cy - radius / 3).attr("r", 1.5).attr("stroke-width", 2).attr("fill", "#666").attr("stroke", "#666"); + function smile(face2) { + const arc = d3arc().startAngle(Math.PI / 2).endAngle(3 * (Math.PI / 2)).innerRadius(radius / 2).outerRadius(radius / 2.2); + face2.append("path").attr("class", "mouth").attr("d", arc).attr("transform", "translate(" + faceData.cx + "," + (faceData.cy + 2) + ")"); + } + function sad(face2) { + const arc = d3arc().startAngle(3 * Math.PI / 2).endAngle(5 * (Math.PI / 2)).innerRadius(radius / 2).outerRadius(radius / 2.2); + face2.append("path").attr("class", "mouth").attr("d", arc).attr("transform", "translate(" + faceData.cx + "," + (faceData.cy + 7) + ")"); + } + function ambivalent(face2) { + face2.append("line").attr("class", "mouth").attr("stroke", 2).attr("x1", faceData.cx - 5).attr("y1", faceData.cy + 7).attr("x2", faceData.cx + 5).attr("y2", faceData.cy + 7).attr("class", "mouth").attr("stroke-width", "1px").attr("stroke", "#666"); + } + if (faceData.score > 3) { + smile(face); + } else if (faceData.score < 3) { + sad(face); + } else { + ambivalent(face); + } + return circleElement; + }; + const drawCircle$1 = function(element2, circleData) { + const circleElement = element2.append("circle"); + circleElement.attr("cx", circleData.cx); + circleElement.attr("cy", circleData.cy); + circleElement.attr("class", "actor-" + circleData.pos); + circleElement.attr("fill", circleData.fill); + circleElement.attr("stroke", circleData.stroke); + circleElement.attr("r", circleData.r); + if (circleElement.class !== void 0) { + circleElement.attr("class", circleElement.class); + } + if (circleData.title !== void 0) { + circleElement.append("title").text(circleData.title); + } + return circleElement; + }; + const drawText$1 = function(elem, textData) { + return drawText$4(elem, textData); + }; + const drawLabel$1 = function(elem, txtObject) { + function genPoints(x2, y2, width2, height, cut) { + return x2 + "," + y2 + " " + (x2 + width2) + "," + y2 + " " + (x2 + width2) + "," + (y2 + height - cut) + " " + (x2 + width2 - cut * 1.2) + "," + (y2 + height) + " " + x2 + "," + (y2 + height); + } + const polygon = elem.append("polygon"); + polygon.attr("points", genPoints(txtObject.x, txtObject.y, 50, 20, 7)); + polygon.attr("class", "labelBox"); + txtObject.y = txtObject.y + txtObject.labelMargin; + txtObject.x = txtObject.x + 0.5 * txtObject.labelMargin; + drawText$1(elem, txtObject); + }; + const drawSection$1 = function(elem, section, conf2) { + const g = elem.append("g"); + const rect2 = getNoteRect$2(); + rect2.x = section.x; + rect2.y = section.y; + rect2.fill = section.fill; + rect2.width = conf2.width * section.taskCount + // width of the tasks + conf2.diagramMarginX * (section.taskCount - 1); + rect2.height = conf2.height; + rect2.class = "journey-section section-type-" + section.num; + rect2.rx = 3; + rect2.ry = 3; + drawRect$1(g, rect2); + _drawTextCandidateFunc$1(conf2)( + section.text, + g, + rect2.x, + rect2.y, + rect2.width, + rect2.height, + { class: "journey-section section-type-" + section.num }, + conf2, + section.colour + ); + }; + let taskCount$1 = -1; + const drawTask$1 = function(elem, task, conf2) { + const center2 = task.x + conf2.width / 2; + const g = elem.append("g"); + taskCount$1++; + const maxHeight = 300 + 5 * 30; + g.append("line").attr("id", "task" + taskCount$1).attr("x1", center2).attr("y1", task.y).attr("x2", center2).attr("y2", maxHeight).attr("class", "task-line").attr("stroke-width", "1px").attr("stroke-dasharray", "4 2").attr("stroke", "#666"); + drawFace$1(g, { + cx: center2, + cy: 300 + (5 - task.score) * 30, + score: task.score + }); + const rect2 = getNoteRect$2(); + rect2.x = task.x; + rect2.y = task.y; + rect2.fill = task.fill; + rect2.width = conf2.width; + rect2.height = conf2.height; + rect2.class = "task task-type-" + task.num; + rect2.rx = 3; + rect2.ry = 3; + drawRect$1(g, rect2); + let xPos = task.x + 14; + task.people.forEach((person) => { + const colour = task.actors[person].color; + const circle2 = { + cx: xPos, + cy: task.y, + r: 7, + fill: colour, + stroke: "#000", + title: person, + pos: task.actors[person].position + }; + drawCircle$1(g, circle2); + xPos += 10; + }); + _drawTextCandidateFunc$1(conf2)( + task.task, + g, + rect2.x, + rect2.y, + rect2.width, + rect2.height, + { class: "task" }, + conf2, + task.colour + ); + }; + const drawBackgroundRect$1 = function(elem, bounds2) { + drawBackgroundRect$3(elem, bounds2); + }; + const _drawTextCandidateFunc$1 = function() { + function byText(content2, g, x2, y2, width2, height, textAttrs, colour) { + const text2 = g.append("text").attr("x", x2 + width2 / 2).attr("y", y2 + height / 2 + 5).style("font-color", colour).style("text-anchor", "middle").text(content2); + _setTextAttrs(text2, textAttrs); + } + function byTspan(content2, g, x2, y2, width2, height, textAttrs, conf2, colour) { + const { taskFontSize, taskFontFamily } = conf2; + const lines = content2.split(//gi); + for (let i2 = 0; i2 < lines.length; i2++) { + const dy = i2 * taskFontSize - taskFontSize * (lines.length - 1) / 2; + const text2 = g.append("text").attr("x", x2 + width2 / 2).attr("y", y2).attr("fill", colour).style("text-anchor", "middle").style("font-size", taskFontSize).style("font-family", taskFontFamily); + text2.append("tspan").attr("x", x2 + width2 / 2).attr("dy", dy).text(lines[i2]); + text2.attr("y", y2 + height / 2).attr("dominant-baseline", "central").attr("alignment-baseline", "central"); + _setTextAttrs(text2, textAttrs); + } + } + function byFo(content2, g, x2, y2, width2, height, textAttrs, conf2) { + const body = g.append("switch"); + const f2 = body.append("foreignObject").attr("x", x2).attr("y", y2).attr("width", width2).attr("height", height).attr("position", "fixed"); + const text2 = f2.append("xhtml:div").style("display", "table").style("height", "100%").style("width", "100%"); + text2.append("div").attr("class", "label").style("display", "table-cell").style("text-align", "center").style("vertical-align", "middle").text(content2); + byTspan(content2, body, x2, y2, width2, height, textAttrs, conf2); + _setTextAttrs(text2, textAttrs); + } + function _setTextAttrs(toText, fromTextAttrsDict) { + for (const key in fromTextAttrsDict) { + if (key in fromTextAttrsDict) { + toText.attr(key, fromTextAttrsDict[key]); + } + } + } + return function(conf2) { + return conf2.textPlacement === "fo" ? byFo : conf2.textPlacement === "old" ? byText : byTspan; + }; + }(); + const initGraphics$1 = function(graphics) { + graphics.append("defs").append("marker").attr("id", "arrowhead").attr("refX", 5).attr("refY", 2).attr("markerWidth", 6).attr("markerHeight", 4).attr("orient", "auto").append("path").attr("d", "M 0,0 V 4 L6,2 Z"); + }; + const svgDraw$1 = { + drawRect: drawRect$1, + drawCircle: drawCircle$1, + drawSection: drawSection$1, + drawText: drawText$1, + drawLabel: drawLabel$1, + drawTask: drawTask$1, + drawBackgroundRect: drawBackgroundRect$1, + initGraphics: initGraphics$1 + }; + const setConf = function(cnf) { + const keys2 = Object.keys(cnf); + keys2.forEach(function(key) { + conf$1[key] = cnf[key]; + }); + }; + const actors = {}; + function drawActorLegend(diagram2) { + const conf2 = getConfig$1().journey; + let yPos = 60; + Object.keys(actors).forEach((person) => { + const colour = actors[person].color; + const circleData = { + cx: 20, + cy: yPos, + r: 7, + fill: colour, + stroke: "#000", + pos: actors[person].position + }; + svgDraw$1.drawCircle(diagram2, circleData); + const labelData = { + x: 40, + y: yPos + 7, + fill: "#666", + text: person, + textMargin: conf2.boxTextMargin | 5 + }; + svgDraw$1.drawText(diagram2, labelData); + yPos += 20; + }); + } + const conf$1 = getConfig$1().journey; + const LEFT_MARGIN = conf$1.leftMargin; + const draw$5 = function(text2, id2, version2, diagObj) { + const conf2 = getConfig$1().journey; + const securityLevel = getConfig$1().securityLevel; + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = d3select("#i" + id2); + } + const root2 = securityLevel === "sandbox" ? d3select(sandboxElement.nodes()[0].contentDocument.body) : d3select("body"); + bounds.init(); + const diagram2 = root2.select("#" + id2); + svgDraw$1.initGraphics(diagram2); + const tasks2 = diagObj.db.getTasks(); + const title2 = diagObj.db.getDiagramTitle(); + const actorNames = diagObj.db.getActors(); + for (const member in actors) { + delete actors[member]; + } + let actorPos = 0; + actorNames.forEach((actorName) => { + actors[actorName] = { + color: conf2.actorColours[actorPos % conf2.actorColours.length], + position: actorPos + }; + actorPos++; + }); + drawActorLegend(diagram2); + bounds.insert(0, 0, LEFT_MARGIN, Object.keys(actors).length * 50); + drawTasks$1(diagram2, tasks2, 0); + const box = bounds.getBounds(); + if (title2) { + diagram2.append("text").text(title2).attr("x", LEFT_MARGIN).attr("font-size", "4ex").attr("font-weight", "bold").attr("y", 25); + } + const height = box.stopy - box.starty + 2 * conf2.diagramMarginY; + const width2 = LEFT_MARGIN + box.stopx + 2 * conf2.diagramMarginX; + configureSvgSize(diagram2, height, width2, conf2.useMaxWidth); + diagram2.append("line").attr("x1", LEFT_MARGIN).attr("y1", conf2.height * 4).attr("x2", width2 - LEFT_MARGIN - 4).attr("y2", conf2.height * 4).attr("stroke-width", 4).attr("stroke", "black").attr("marker-end", "url(#arrowhead)"); + const extraVertForTitle = title2 ? 70 : 0; + diagram2.attr("viewBox", `${box.startx} -25 ${width2} ${height + extraVertForTitle}`); + diagram2.attr("preserveAspectRatio", "xMinYMin meet"); + diagram2.attr("height", height + extraVertForTitle + 25); + }; + const bounds = { + data: { + startx: void 0, + stopx: void 0, + starty: void 0, + stopy: void 0 + }, + verticalPos: 0, + sequenceItems: [], + init: function() { + this.sequenceItems = []; + this.data = { + startx: void 0, + stopx: void 0, + starty: void 0, + stopy: void 0 + }; + this.verticalPos = 0; + }, + updateVal: function(obj, key, val, fun) { + if (obj[key] === void 0) { + obj[key] = val; + } else { + obj[key] = fun(val, obj[key]); + } + }, + updateBounds: function(startx, starty, stopx, stopy) { + const conf2 = getConfig$1().journey; + const _self = this; + let cnt2 = 0; + function updateFn(type2) { + return function updateItemBounds(item) { + cnt2++; + const n = _self.sequenceItems.length - cnt2 + 1; + _self.updateVal(item, "starty", starty - n * conf2.boxMargin, Math.min); + _self.updateVal(item, "stopy", stopy + n * conf2.boxMargin, Math.max); + _self.updateVal(bounds.data, "startx", startx - n * conf2.boxMargin, Math.min); + _self.updateVal(bounds.data, "stopx", stopx + n * conf2.boxMargin, Math.max); + if (!(type2 === "activation")) { + _self.updateVal(item, "startx", startx - n * conf2.boxMargin, Math.min); + _self.updateVal(item, "stopx", stopx + n * conf2.boxMargin, Math.max); + _self.updateVal(bounds.data, "starty", starty - n * conf2.boxMargin, Math.min); + _self.updateVal(bounds.data, "stopy", stopy + n * conf2.boxMargin, Math.max); + } + }; + } + this.sequenceItems.forEach(updateFn()); + }, + insert: function(startx, starty, stopx, stopy) { + const _startx = Math.min(startx, stopx); + const _stopx = Math.max(startx, stopx); + const _starty = Math.min(starty, stopy); + const _stopy = Math.max(starty, stopy); + this.updateVal(bounds.data, "startx", _startx, Math.min); + this.updateVal(bounds.data, "starty", _starty, Math.min); + this.updateVal(bounds.data, "stopx", _stopx, Math.max); + this.updateVal(bounds.data, "stopy", _stopy, Math.max); + this.updateBounds(_startx, _starty, _stopx, _stopy); + }, + bumpVerticalPos: function(bump) { + this.verticalPos = this.verticalPos + bump; + this.data.stopy = this.verticalPos; + }, + getVerticalPos: function() { + return this.verticalPos; + }, + getBounds: function() { + return this.data; + } + }; + const fills = conf$1.sectionFills; + const textColours = conf$1.sectionColours; + const drawTasks$1 = function(diagram2, tasks2, verticalPos) { + const conf2 = getConfig$1().journey; + let lastSection = ""; + const sectionVHeight = conf2.height * 2 + conf2.diagramMarginY; + const taskPos = verticalPos + sectionVHeight; + let sectionNumber = 0; + let fill = "#CCC"; + let colour = "black"; + let num = 0; + for (const [i2, task] of tasks2.entries()) { + if (lastSection !== task.section) { + fill = fills[sectionNumber % fills.length]; + num = sectionNumber % fills.length; + colour = textColours[sectionNumber % textColours.length]; + let taskInSectionCount = 0; + const currentSection2 = task.section; + for (let taskIndex = i2; taskIndex < tasks2.length; taskIndex++) { + if (tasks2[taskIndex].section == currentSection2) { + taskInSectionCount = taskInSectionCount + 1; + } else { + break; + } + } + const section = { + x: i2 * conf2.taskMargin + i2 * conf2.width + LEFT_MARGIN, + y: 50, + text: task.section, + fill, + num, + colour, + taskCount: taskInSectionCount + }; + svgDraw$1.drawSection(diagram2, section, conf2); + lastSection = task.section; + sectionNumber++; + } + const taskActors = task.people.reduce((acc, actorName) => { + if (actors[actorName]) { + acc[actorName] = actors[actorName]; + } + return acc; + }, {}); + task.x = i2 * conf2.taskMargin + i2 * conf2.width + LEFT_MARGIN; + task.y = taskPos; + task.width = conf2.diagramMarginX; + task.height = conf2.diagramMarginY; + task.colour = colour; + task.fill = fill; + task.num = num; + task.actors = taskActors; + svgDraw$1.drawTask(diagram2, task, conf2); + bounds.insert(task.x, task.y, task.x + task.width + conf2.taskMargin, 300 + 5 * 30); + } + }; + const renderer$5 = { + setConf, + draw: draw$5 + }; + const diagram$5 = { + parser: parser$9, + db: db$6, + renderer: renderer$5, + styles: styles$3, + init: (cnf) => { + renderer$5.setConf(cnf.journey); + db$6.clear(); + } + }; + const journeyDiagram = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + diagram: diagram$5 + }, Symbol.toStringTag, { value: "Module" })); + const findCommonAncestor = (id1, id2, treeData) => { + const { parentById } = treeData; + const visited = /* @__PURE__ */ new Set(); + let currentId = id1; + while (currentId) { + visited.add(currentId); + if (currentId === id2) { + return currentId; + } + currentId = parentById[currentId]; + } + currentId = id2; + while (currentId) { + if (visited.has(currentId)) { + return currentId; + } + currentId = parentById[currentId]; + } + return "root"; + }; + function commonjsRequire(path2) { + throw new Error('Could not dynamically require "' + path2 + '". Please configure the dynamicRequireTargets or/and ignoreDynamicRequires option of @rollup/plugin-commonjs appropriately for this require call to work.'); + } + var elk_bundled = { exports: {} }; + (function(module2, exports2) { + (function(f2) { + { + module2.exports = f2(); + } + })(function() { + return function() { + function r(e, n, t) { + function o(i3, f2) { + if (!n[i3]) { + if (!e[i3]) { + var c2 = "function" == typeof commonjsRequire && commonjsRequire; + if (!f2 && c2) + return c2(i3, true); + if (u) + return u(i3, true); + var a = new Error("Cannot find module '" + i3 + "'"); + throw a.code = "MODULE_NOT_FOUND", a; + } + var p = n[i3] = { exports: {} }; + e[i3][0].call(p.exports, function(r2) { + var n2 = e[i3][1][r2]; + return o(n2 || r2); + }, p, p.exports, r, e, n, t); + } + return n[i3].exports; + } + for (var u = "function" == typeof commonjsRequire && commonjsRequire, i2 = 0; i2 < t.length; i2++) + o(t[i2]); + return o; + } + return r; + }()({ 1: [function(require, module3, exports3) { + Object.defineProperty(exports3, "__esModule", { + value: true + }); + var _createClass = function() { + function defineProperties(target, props) { + for (var i2 = 0; i2 < props.length; i2++) { + var descriptor = props[i2]; + descriptor.enumerable = descriptor.enumerable || false; + descriptor.configurable = true; + if ("value" in descriptor) + descriptor.writable = true; + Object.defineProperty(target, descriptor.key, descriptor); + } + } + return function(Constructor, protoProps, staticProps) { + if (protoProps) + defineProperties(Constructor.prototype, protoProps); + if (staticProps) + defineProperties(Constructor, staticProps); + return Constructor; + }; + }(); + function _classCallCheck(instance2, Constructor) { + if (!(instance2 instanceof Constructor)) { + throw new TypeError("Cannot call a class as a function"); + } + } + var ELK2 = function() { + function ELK3() { + var _this = this; + var _ref = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, _ref$defaultLayoutOpt = _ref.defaultLayoutOptions, defaultLayoutOptions = _ref$defaultLayoutOpt === void 0 ? {} : _ref$defaultLayoutOpt, _ref$algorithms = _ref.algorithms, algorithms = _ref$algorithms === void 0 ? ["layered", "stress", "mrtree", "radial", "force", "disco", "sporeOverlap", "sporeCompaction", "rectpacking"] : _ref$algorithms, workerFactory = _ref.workerFactory, workerUrl = _ref.workerUrl; + _classCallCheck(this, ELK3); + this.defaultLayoutOptions = defaultLayoutOptions; + this.initialized = false; + if (typeof workerUrl === "undefined" && typeof workerFactory === "undefined") { + throw new Error("Cannot construct an ELK without both 'workerUrl' and 'workerFactory'."); + } + var factory = workerFactory; + if (typeof workerUrl !== "undefined" && typeof workerFactory === "undefined") { + factory = function factory2(url) { + return new Worker(url); + }; + } + var worker = factory(workerUrl); + if (typeof worker.postMessage !== "function") { + throw new TypeError("Created worker does not provide the required 'postMessage' function."); + } + this.worker = new PromisedWorker(worker); + this.worker.postMessage({ + cmd: "register", + algorithms + }).then(function(r) { + return _this.initialized = true; + }).catch(console.err); + } + _createClass(ELK3, [{ + key: "layout", + value: function layout2(graph) { + var _ref2 = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}, _ref2$layoutOptions = _ref2.layoutOptions, layoutOptions = _ref2$layoutOptions === void 0 ? this.defaultLayoutOptions : _ref2$layoutOptions, _ref2$logging = _ref2.logging, logging = _ref2$logging === void 0 ? false : _ref2$logging, _ref2$measureExecutio = _ref2.measureExecutionTime, measureExecutionTime = _ref2$measureExecutio === void 0 ? false : _ref2$measureExecutio; + if (!graph) { + return Promise.reject(new Error("Missing mandatory parameter 'graph'.")); + } + return this.worker.postMessage({ + cmd: "layout", + graph, + layoutOptions, + options: { + logging, + measureExecutionTime + } + }); + } + }, { + key: "knownLayoutAlgorithms", + value: function knownLayoutAlgorithms() { + return this.worker.postMessage({ cmd: "algorithms" }); + } + }, { + key: "knownLayoutOptions", + value: function knownLayoutOptions() { + return this.worker.postMessage({ cmd: "options" }); + } + }, { + key: "knownLayoutCategories", + value: function knownLayoutCategories() { + return this.worker.postMessage({ cmd: "categories" }); + } + }, { + key: "terminateWorker", + value: function terminateWorker() { + this.worker.terminate(); + } + }]); + return ELK3; + }(); + exports3.default = ELK2; + var PromisedWorker = function() { + function PromisedWorker2(worker) { + var _this2 = this; + _classCallCheck(this, PromisedWorker2); + if (worker === void 0) { + throw new Error("Missing mandatory parameter 'worker'."); + } + this.resolvers = {}; + this.worker = worker; + this.worker.onmessage = function(answer) { + setTimeout(function() { + _this2.receive(_this2, answer); + }, 0); + }; + } + _createClass(PromisedWorker2, [{ + key: "postMessage", + value: function postMessage(msg) { + var id2 = this.id || 0; + this.id = id2 + 1; + msg.id = id2; + var self2 = this; + return new Promise(function(resolve, reject) { + self2.resolvers[id2] = function(err, res) { + if (err) { + self2.convertGwtStyleError(err); + reject(err); + } else { + resolve(res); + } + }; + self2.worker.postMessage(msg); + }); + } + }, { + key: "receive", + value: function receive(self2, answer) { + var json2 = answer.data; + var resolver2 = self2.resolvers[json2.id]; + if (resolver2) { + delete self2.resolvers[json2.id]; + if (json2.error) { + resolver2(json2.error); + } else { + resolver2(null, json2.data); + } + } + } + }, { + key: "terminate", + value: function terminate() { + if (this.worker.terminate) { + this.worker.terminate(); + } + } + }, { + key: "convertGwtStyleError", + value: function convertGwtStyleError(err) { + if (!err) { + return; + } + var javaException = err["__java$exception"]; + if (javaException) { + if (javaException.cause && javaException.cause.backingJsObject) { + err.cause = javaException.cause.backingJsObject; + this.convertGwtStyleError(err.cause); + } + delete err["__java$exception"]; + } + } + }]); + return PromisedWorker2; + }(); + }, {}], 2: [function(require, module3, exports3) { + (function(global2) { + (function() { + var $wnd; + if (typeof window !== "undefined") + $wnd = window; + else if (typeof global2 !== "undefined") + $wnd = global2; + else if (typeof self !== "undefined") + $wnd = self; + var o; + function nb() { + } + function xb() { + } + function Fd() { + } + function hh() { + } + function lq() { + } + function Nq() { + } + function ir() { + } + function Ws() { + } + function Zw() { + } + function jx() { + } + function rx() { + } + function sx() { + } + function My() { + } + function bA() { + } + function mA() { + } + function tA() { + } + function aB() { + } + function dB() { + } + function jB() { + } + function dC() { + } + function keb() { + } + function geb() { + } + function oeb() { + } + function iob() { + } + function Job() { + } + function Rob() { + } + function apb() { + } + function ipb() { + } + function nrb() { + } + function wrb() { + } + function Brb() { + } + function Prb() { + } + function ltb() { + } + function svb() { + } + function xvb() { + } + function zvb() { + } + function $xb() { + } + function Gzb() { + } + function NAb() { + } + function VAb() { + } + function rBb() { + } + function RBb() { + } + function TBb() { + } + function XBb() { + } + function ZBb() { + } + function _Bb() { + } + function bCb() { + } + function dCb() { + } + function fCb() { + } + function jCb() { + } + function rCb() { + } + function uCb() { + } + function wCb() { + } + function yCb() { + } + function ACb() { + } + function ECb() { + } + function FEb() { + } + function IEb() { + } + function KEb() { + } + function MEb() { + } + function gFb() { + } + function FFb() { + } + function JFb() { + } + function xGb() { + } + function AGb() { + } + function YGb() { + } + function oHb() { + } + function tHb() { + } + function xHb() { + } + function pIb() { + } + function BJb() { + } + function kLb() { + } + function mLb() { + } + function oLb() { + } + function qLb() { + } + function FLb() { + } + function JLb() { + } + function KMb() { + } + function MMb() { + } + function OMb() { + } + function YMb() { + } + function MNb() { + } + function ONb() { + } + function aOb() { + } + function eOb() { + } + function xOb() { + } + function BOb() { + } + function DOb() { + } + function FOb() { + } + function IOb() { + } + function MOb() { + } + function POb() { + } + function UOb() { + } + function ZOb() { + } + function cPb() { + } + function gPb() { + } + function nPb() { + } + function qPb() { + } + function tPb() { + } + function wPb() { + } + function CPb() { + } + function qQb() { + } + function GQb() { + } + function bRb() { + } + function gRb() { + } + function kRb() { + } + function pRb() { + } + function wRb() { + } + function xSb() { + } + function TSb() { + } + function VSb() { + } + function XSb() { + } + function ZSb() { + } + function _Sb() { + } + function tTb() { + } + function DTb() { + } + function FTb() { + } + function FXb() { + } + function hXb() { + } + function hWb() { + } + function mWb() { + } + function CVb() { + } + function XXb() { + } + function $Xb() { + } + function bYb() { + } + function lYb() { + } + function FYb() { + } + function XYb() { + } + function aZb() { + } + function SZb() { + } + function ZZb() { + } + function Z_b() { + } + function j_b() { + } + function j$b() { + } + function b$b() { + } + function f$b() { + } + function n$b() { + } + function K_b() { + } + function V_b() { + } + function b0b() { + } + function l0b() { + } + function X1b() { + } + function _1b() { + } + function x3b() { + } + function r4b() { + } + function w4b() { + } + function A4b() { + } + function E4b() { + } + function I4b() { + } + function M4b() { + } + function o5b() { + } + function q5b() { + } + function w5b() { + } + function A5b() { + } + function E5b() { + } + function h6b() { + } + function j6b() { + } + function l6b() { + } + function q6b() { + } + function v6b() { + } + function y6b() { + } + function G6b() { + } + function K6b() { + } + function N6b() { + } + function P6b() { + } + function R6b() { + } + function b7b() { + } + function f7b() { + } + function j7b() { + } + function n7b() { + } + function C7b() { + } + function H7b() { + } + function J7b() { + } + function L7b() { + } + function N7b() { + } + function P7b() { + } + function a8b() { + } + function c8b() { + } + function e8b() { + } + function g8b() { + } + function i8b() { + } + function m8b() { + } + function Z8b() { + } + function f9b() { + } + function i9b() { + } + function o9b() { + } + function C9b() { + } + function F9b() { + } + function K9b() { + } + function Q9b() { + } + function aac() { + } + function bac() { + } + function eac() { + } + function mac() { + } + function pac() { + } + function rac() { + } + function tac() { + } + function xac() { + } + function Aac() { + } + function Dac() { + } + function Iac() { + } + function Oac() { + } + function Uac() { + } + function Ucc() { + } + function scc() { + } + function ycc() { + } + function Acc() { + } + function Ccc() { + } + function Ncc() { + } + function Wcc() { + } + function ydc() { + } + function Adc() { + } + function Gdc() { + } + function Ldc() { + } + function Zdc() { + } + function fec() { + } + function Dec() { + } + function Gec() { + } + function Kec() { + } + function efc() { + } + function jfc() { + } + function nfc() { + } + function Bfc() { + } + function Ifc() { + } + function Lfc() { + } + function Rfc() { + } + function Ufc() { + } + function Zfc() { + } + function cgc() { + } + function egc() { + } + function ggc() { + } + function igc() { + } + function kgc() { + } + function Dgc() { + } + function Hgc() { + } + function Lgc() { + } + function Ngc() { + } + function Pgc() { + } + function Vgc() { + } + function Ygc() { + } + function chc() { + } + function ehc() { + } + function ghc() { + } + function ihc() { + } + function mhc() { + } + function rhc() { + } + function uhc() { + } + function whc() { + } + function yhc() { + } + function Ahc() { + } + function Chc() { + } + function Ghc() { + } + function Nhc() { + } + function Phc() { + } + function Rhc() { + } + function Thc() { + } + function $hc() { + } + function aic() { + } + function cic() { + } + function eic() { + } + function jic() { + } + function nic() { + } + function pic() { + } + function ric() { + } + function vic() { + } + function yic() { + } + function Dic() { + } + function Ric() { + } + function Zic() { + } + function bjc() { + } + function djc() { + } + function jjc() { + } + function njc() { + } + function rjc() { + } + function tjc() { + } + function zjc() { + } + function Djc() { + } + function Fjc() { + } + function Ljc() { + } + function Pjc() { + } + function Rjc() { + } + function fkc() { + } + function Kkc() { + } + function Mkc() { + } + function Okc() { + } + function Qkc() { + } + function Skc() { + } + function Ukc() { + } + function Wkc() { + } + function clc() { + } + function elc() { + } + function klc() { + } + function mlc() { + } + function olc() { + } + function qlc() { + } + function wlc() { + } + function ylc() { + } + function Alc() { + } + function Jlc() { + } + function Joc() { + } + function poc() { + } + function roc() { + } + function toc() { + } + function voc() { + } + function Boc() { + } + function Foc() { + } + function Hoc() { + } + function Loc() { + } + function Noc() { + } + function Poc() { + } + function qnc() { + } + function unc() { + } + function upc() { + } + function kpc() { + } + function mpc() { + } + function opc() { + } + function qpc() { + } + function ypc() { + } + function Cpc() { + } + function Mpc() { + } + function Qpc() { + } + function dqc() { + } + function jqc() { + } + function Aqc() { + } + function Eqc() { + } + function Gqc() { + } + function Sqc() { + } + function arc() { + } + function lrc() { + } + function zrc() { + } + function Hrc() { + } + function bsc() { + } + function dsc() { + } + function fsc() { + } + function ksc() { + } + function msc() { + } + function Asc() { + } + function Csc() { + } + function Esc() { + } + function Ksc() { + } + function Nsc() { + } + function Ssc() { + } + function CCc() { + } + function tGc() { + } + function aHc() { + } + function gHc() { + } + function nIc() { + } + function PJc() { + } + function XKc() { + } + function fLc() { + } + function hLc() { + } + function lLc() { + } + function eNc() { + } + function IOc() { + } + function MOc() { + } + function WOc() { + } + function YOc() { + } + function $Oc() { + } + function cPc() { + } + function iPc() { + } + function mPc() { + } + function oPc() { + } + function qPc() { + } + function sPc() { + } + function wPc() { + } + function APc() { + } + function FPc() { + } + function HPc() { + } + function NPc() { + } + function PPc() { + } + function TPc() { + } + function VPc() { + } + function ZPc() { + } + function _Pc() { + } + function bQc() { + } + function dQc() { + } + function SQc() { + } + function hRc() { + } + function HRc() { + } + function HSc() { + } + function pSc() { + } + function xSc() { + } + function zSc() { + } + function BSc() { + } + function DSc() { + } + function FSc() { + } + function CTc() { + } + function ITc() { + } + function KTc() { + } + function MTc() { + } + function XTc() { + } + function ZTc() { + } + function jVc() { + } + function lVc() { + } + function zVc() { + } + function IVc() { + } + function KVc() { + } + function KWc() { + } + function uWc() { + } + function xWc() { + } + function AWc() { + } + function QWc() { + } + function UWc() { + } + function qXc() { + } + function KXc() { + } + function OXc() { + } + function SXc() { + } + function $Xc() { + } + function mYc() { + } + function rYc() { + } + function zYc() { + } + function DYc() { + } + function FYc() { + } + function HYc() { + } + function JYc() { + } + function cZc() { + } + function gZc() { + } + function iZc() { + } + function pZc() { + } + function tZc() { + } + function vZc() { + } + function AZc() { + } + function GZc() { + } + function l_c() { + } + function l1c() { + } + function b1c() { + } + function d1c() { + } + function h1c() { + } + function n1c() { + } + function r1c() { + } + function v1c() { + } + function x1c() { + } + function D1c() { + } + function H1c() { + } + function L1c() { + } + function R1c() { + } + function V1c() { + } + function Z1c() { + } + function Z0c() { + } + function a0c() { + } + function c0c() { + } + function e0c() { + } + function k0c() { + } + function o0c() { + } + function b2c() { + } + function l2c() { + } + function p2c() { + } + function Y2c() { + } + function _2c() { + } + function A3c() { + } + function F3c() { + } + function I3c() { + } + function K3c() { + } + function M3c() { + } + function Q3c() { + } + function U3c() { + } + function c5c() { + } + function D5c() { + } + function G5c() { + } + function J5c() { + } + function N5c() { + } + function V5c() { + } + function p6c() { + } + function s6c() { + } + function H6c() { + } + function K6c() { + } + function _7c() { + } + function h8c() { + } + function j8c() { + } + function o8c() { + } + function r8c() { + } + function u8c() { + } + function R8c() { + } + function X8c() { + } + function o9c() { + } + function s9c() { + } + function x9c() { + } + function Qad() { + } + function rcd() { + } + function Xcd() { + } + function vdd() { + } + function Tdd() { + } + function _dd() { + } + function qed() { + } + function sed() { + } + function ved() { + } + function Hed() { + } + function Zed() { + } + function bfd() { + } + function ifd() { + } + function Gfd() { + } + function Ifd() { + } + function Igd() { + } + function agd() { + } + function dgd() { + } + function pgd() { + } + function Hgd() { + } + function Kgd() { + } + function Mgd() { + } + function Ogd() { + } + function Qgd() { + } + function Sgd() { + } + function Ugd() { + } + function Wgd() { + } + function Ygd() { + } + function $gd() { + } + function ahd() { + } + function chd() { + } + function ehd() { + } + function ghd() { + } + function ihd() { + } + function khd() { + } + function mhd() { + } + function ohd() { + } + function qhd() { + } + function shd() { + } + function Shd() { + } + function lkd() { + } + function znd() { + } + function Jpd() { + } + function jrd() { + } + function Mrd() { + } + function Qrd() { + } + function Urd() { + } + function Yrd() { + } + function Yud() { + } + function eud() { + } + function asd() { + } + function Lsd() { + } + function btd() { + } + function dtd() { + } + function jtd() { + } + function otd() { + } + function ztd() { + } + function Xxd() { + } + function $yd() { + } + function rzd() { + } + function Rzd() { + } + function KAd() { + } + function hCd() { + } + function _Cd() { + } + function _Sd() { + } + function OSd() { + } + function BDd() { + } + function BId() { + } + function JId() { + } + function YHd() { + } + function fLd() { + } + function cPd() { + } + function hQd() { + } + function AQd() { + } + function kUd() { + } + function VUd() { + } + function pVd() { + } + function W$d() { + } + function Z$d() { + } + function a_d() { + } + function i_d() { + } + function v_d() { + } + function y_d() { + } + function f1d() { + } + function L5d() { + } + function v6d() { + } + function b8d() { + } + function e8d() { + } + function h8d() { + } + function k8d() { + } + function n8d() { + } + function q8d() { + } + function t8d() { + } + function w8d() { + } + function z8d() { + } + function X9d() { + } + function _9d() { + } + function Mae() { + } + function cbe() { + } + function ebe() { + } + function hbe() { + } + function kbe() { + } + function nbe() { + } + function qbe() { + } + function tbe() { + } + function wbe() { + } + function zbe() { + } + function Cbe() { + } + function Fbe() { + } + function Ibe() { + } + function Lbe() { + } + function Obe() { + } + function Rbe() { + } + function Ube() { + } + function Xbe() { + } + function $be() { + } + function bce() { + } + function ece() { + } + function hce() { + } + function kce() { + } + function nce() { + } + function qce() { + } + function tce() { + } + function wce() { + } + function zce() { + } + function Cce() { + } + function Fce() { + } + function Ice() { + } + function Lce() { + } + function Oce() { + } + function Rce() { + } + function Uce() { + } + function Xce() { + } + function $ce() { + } + function bde() { + } + function ede() { + } + function hde() { + } + function kde() { + } + function nde() { + } + function qde() { + } + function tde() { + } + function wde() { + } + function Hie() { + } + function rke() { + } + function rne() { + } + function Ene() { + } + function Gne() { + } + function Jne() { + } + function Mne() { + } + function Pne() { + } + function Sne() { + } + function Vne() { + } + function Yne() { + } + function _ne() { + } + function yme() { + } + function coe() { + } + function foe() { + } + function ioe() { + } + function loe() { + } + function ooe() { + } + function roe() { + } + function uoe() { + } + function xoe() { + } + function Aoe() { + } + function Doe() { + } + function Goe() { + } + function Joe() { + } + function Moe() { + } + function Poe() { + } + function Soe() { + } + function Voe() { + } + function Yoe() { + } + function _oe() { + } + function cpe() { + } + function fpe() { + } + function ipe() { + } + function lpe() { + } + function ope() { + } + function rpe() { + } + function upe() { + } + function xpe() { + } + function Ape() { + } + function Dpe() { + } + function Gpe() { + } + function Jpe() { + } + function Mpe() { + } + function Ppe() { + } + function Spe() { + } + function Vpe() { + } + function Ype() { + } + function _pe() { + } + function cqe() { + } + function fqe() { + } + function iqe() { + } + function lqe() { + } + function oqe() { + } + function rqe() { + } + function uqe() { + } + function Tqe() { + } + function sue() { + } + function Cue() { + } + function zl() { + wb(); + } + function z7b() { + s7b(); + } + function ZHb() { + YHb(); + } + function fSb() { + eSb(); + } + function vSb() { + tSb(); + } + function PUb() { + OUb(); + } + function AVb() { + yVb(); + } + function RVb() { + QVb(); + } + function fWb() { + dWb(); + } + function N5b() { + H5b(); + } + function $9b() { + U9b(); + } + function Lcc() { + Hcc(); + } + function pdc() { + Zcc(); + } + function pec() { + iec(); + } + function pGc() { + nGc(); + } + function jGc() { + gGc(); + } + function YGc() { + SGc(); + } + function cGc() { + _Fc(); + } + function NFc() { + KFc(); + } + function xgc() { + sgc(); + } + function xHc() { + tHc(); + } + function pHc() { + lHc(); + } + function IHc() { + CHc(); + } + function XHc() { + RHc(); + } + function boc() { + Mnc(); + } + function yqc() { + mqc(); + } + function Pzc() { + Ozc(); + } + function ACc() { + yCc(); + } + function aKc() { + YJc(); + } + function FLc() { + DLc(); + } + function DNc() { + ANc(); + } + function TNc() { + JNc(); + } + function iQc() { + gQc(); + } + function WRc() { + TRc(); + } + function C$c() { + B$c(); + } + function J0c() { + B0c(); + } + function x0c() { + r0c(); + } + function j_c() { + h_c(); + } + function N_c() { + H_c(); + } + function V_c() { + R_c(); + } + function E4c() { + D4c(); + } + function a5c() { + $4c(); + } + function v7c() { + u7c(); + } + function Z7c() { + X7c(); + } + function pcd() { + ncd(); + } + function Lcd() { + Kcd(); + } + function Vcd() { + Tcd(); + } + function fUd() { + TTd(); + } + function Bfd() { + Afd(); + } + function jkd() { + hkd(); + } + function vmd() { + umd(); + } + function xnd() { + vnd(); + } + function Hpd() { + Fpd(); + } + function HYd() { + lYd(); + } + function yAd() { + qAd(); + } + function gke() { + rue(); + } + function Yxb(a) { + uFb(a); + } + function Yb(a) { + this.a = a; + } + function cc(a) { + this.a = a; + } + function df(a) { + this.a = a; + } + function kf(a) { + this.a = a; + } + function kj(a) { + this.a = a; + } + function qj(a) { + this.a = a; + } + function Lj(a) { + this.a = a; + } + function jh(a) { + this.a = a; + } + function th(a) { + this.a = a; + } + function Bh(a) { + this.a = a; + } + function Xh(a) { + this.a = a; + } + function Xn2(a) { + this.a = a; + } + function Di(a) { + this.a = a; + } + function Ki(a) { + this.a = a; + } + function Ik(a) { + this.a = a; + } + function Qk(a) { + this.a = a; + } + function mp(a) { + this.a = a; + } + function Lp(a) { + this.a = a; + } + function iq(a) { + this.a = a; + } + function Eq(a) { + this.a = a; + } + function Vq(a) { + this.a = a; + } + function Or(a) { + this.a = a; + } + function $r(a) { + this.b = a; + } + function Aj(a) { + this.c = a; + } + function vu(a) { + this.a = a; + } + function vw(a) { + this.a = a; + } + function gw(a) { + this.a = a; + } + function lw(a) { + this.a = a; + } + function Iw(a) { + this.a = a; + } + function Nw(a) { + this.a = a; + } + function Sw(a) { + this.a = a; + } + function ex(a) { + this.a = a; + } + function fx(a) { + this.a = a; + } + function lx(a) { + this.a = a; + } + function my(a) { + this.a = a; + } + function qy(a) { + this.a = a; + } + function Oy(a) { + this.a = a; + } + function NB(a) { + this.a = a; + } + function XB(a) { + this.a = a; + } + function hC(a) { + this.a = a; + } + function vC(a) { + this.a = a; + } + function MB() { + this.a = []; + } + function HEb(a, b) { + a.a = b; + } + function E2b(a, b) { + a.a = b; + } + function F2b(a, b) { + a.b = b; + } + function PRb(a, b) { + a.b = b; + } + function RRb(a, b) { + a.b = b; + } + function QJb(a, b) { + a.j = b; + } + function hQb(a, b) { + a.g = b; + } + function iQb(a, b) { + a.i = b; + } + function _Tb(a, b) { + a.c = b; + } + function G2b(a, b) { + a.c = b; + } + function H2b(a, b) { + a.d = b; + } + function aUb(a, b) { + a.d = b; + } + function h3b(a, b) { + a.k = b; + } + function O3b(a, b) { + a.c = b; + } + function Tmc(a, b) { + a.c = b; + } + function Smc(a, b) { + a.a = b; + } + function DJc(a, b) { + a.a = b; + } + function EJc(a, b) { + a.f = b; + } + function NSc(a, b) { + a.a = b; + } + function OSc(a, b) { + a.b = b; + } + function PSc(a, b) { + a.d = b; + } + function QSc(a, b) { + a.i = b; + } + function RSc(a, b) { + a.o = b; + } + function SSc2(a, b) { + a.r = b; + } + function yUc(a, b) { + a.a = b; + } + function zUc(a, b) { + a.b = b; + } + function q3c(a, b) { + a.e = b; + } + function r3c(a, b) { + a.f = b; + } + function s3c(a, b) { + a.g = b; + } + function Y9c(a, b) { + a.e = b; + } + function Z9c(a, b) { + a.f = b; + } + function kad(a, b) { + a.f = b; + } + function Ntd(a, b) { + a.a = b; + } + function Otd(a, b) { + a.b = b; + } + function BWd(a, b) { + a.n = b; + } + function $ee(a, b) { + a.a = b; + } + function _ee(a, b) { + a.c = b; + } + function ife(a, b) { + a.c = b; + } + function Efe(a, b) { + a.c = b; + } + function hfe(a, b) { + a.a = b; + } + function Dfe(a, b) { + a.a = b; + } + function jfe(a, b) { + a.d = b; + } + function Ffe(a, b) { + a.d = b; + } + function kfe(a, b) { + a.e = b; + } + function Gfe(a, b) { + a.e = b; + } + function lfe(a, b) { + a.g = b; + } + function Hfe(a, b) { + a.f = b; + } + function Ife(a, b) { + a.j = b; + } + function wme(a, b) { + a.a = b; + } + function Fme(a, b) { + a.a = b; + } + function xme(a, b) { + a.b = b; + } + function gmc(a) { + a.b = a.a; + } + function Lg(a) { + a.c = a.d.d; + } + function fgb(a) { + this.a = a; + } + function zgb(a) { + this.a = a; + } + function Xgb(a) { + this.a = a; + } + function Xkb(a) { + this.a = a; + } + function mkb(a) { + this.a = a; + } + function reb(a) { + this.a = a; + } + function Seb(a) { + this.a = a; + } + function bfb(a) { + this.a = a; + } + function Tfb(a) { + this.a = a; + } + function blb(a) { + this.a = a; + } + function glb(a) { + this.a = a; + } + function llb(a) { + this.a = a; + } + function Ulb(a) { + this.a = a; + } + function _lb(a) { + this.a = a; + } + function Plb(a) { + this.b = a; + } + function Ppb(a) { + this.b = a; + } + function xpb(a) { + this.b = a; + } + function mpb(a) { + this.a = a; + } + function Yqb(a) { + this.a = a; + } + function uqb(a) { + this.c = a; + } + function Anb(a) { + this.c = a; + } + function zwb(a) { + this.c = a; + } + function Dkb(a) { + this.d = a; + } + function brb(a) { + this.a = a; + } + function Frb(a) { + this.a = a; + } + function hsb(a) { + this.a = a; + } + function ctb(a) { + this.a = a; + } + function cxb(a) { + this.a = a; + } + function axb(a) { + this.a = a; + } + function exb(a) { + this.a = a; + } + function gxb(a) { + this.a = a; + } + function wub(a) { + this.a = a; + } + function zAb(a) { + this.a = a; + } + function JAb(a) { + this.a = a; + } + function LAb(a) { + this.a = a; + } + function PAb(a) { + this.a = a; + } + function VBb(a) { + this.a = a; + } + function lCb(a) { + this.a = a; + } + function nCb(a) { + this.a = a; + } + function pCb(a) { + this.a = a; + } + function CCb(a) { + this.a = a; + } + function GCb(a) { + this.a = a; + } + function bDb(a) { + this.a = a; + } + function dDb(a) { + this.a = a; + } + function fDb(a) { + this.a = a; + } + function uDb(a) { + this.a = a; + } + function $Db(a) { + this.a = a; + } + function aEb(a) { + this.a = a; + } + function eEb(a) { + this.a = a; + } + function OEb(a) { + this.a = a; + } + function SEb(a) { + this.a = a; + } + function SFb(a) { + this.a = a; + } + function HFb(a) { + this.a = a; + } + function NFb(a) { + this.a = a; + } + function WGb(a) { + this.a = a; + } + function HJb(a) { + this.a = a; + } + function PJb(a) { + this.a = a; + } + function kNb(a) { + this.a = a; + } + function tOb(a) { + this.a = a; + } + function APb(a) { + this.a = a; + } + function IQb(a) { + this.a = a; + } + function bTb(a) { + this.a = a; + } + function dTb(a) { + this.a = a; + } + function wTb(a) { + this.a = a; + } + function GWb(a) { + this.a = a; + } + function UWb(a) { + this.a = a; + } + function WWb(a) { + this.a = a; + } + function fXb(a) { + this.a = a; + } + function jXb(a) { + this.a = a; + } + function M0b(a) { + this.a = a; + } + function r1b(a) { + this.a = a; + } + function D1b(a) { + this.e = a; + } + function T3b(a) { + this.a = a; + } + function W3b(a) { + this.a = a; + } + function _3b(a) { + this.a = a; + } + function c4b(a) { + this.a = a; + } + function s5b(a) { + this.a = a; + } + function u5b(a) { + this.a = a; + } + function y5b(a) { + this.a = a; + } + function C5b(a) { + this.a = a; + } + function Q5b(a) { + this.a = a; + } + function S5b(a) { + this.a = a; + } + function U5b(a) { + this.a = a; + } + function W5b(a) { + this.a = a; + } + function l7b(a) { + this.a = a; + } + function p7b(a) { + this.a = a; + } + function k8b(a) { + this.a = a; + } + function L8b(a) { + this.a = a; + } + function Rac(a) { + this.a = a; + } + function Xac(a) { + this.a = a; + } + function $ac(a) { + this.a = a; + } + function bbc(a) { + this.a = a; + } + function Cdc(a) { + this.a = a; + } + function Edc(a) { + this.a = a; + } + function Ehc(a) { + this.a = a; + } + function khc(a) { + this.a = a; + } + function Ihc(a) { + this.a = a; + } + function qfc(a) { + this.a = a; + } + function tfc(a) { + this.a = a; + } + function Wfc(a) { + this.a = a; + } + function Fic(a) { + this.a = a; + } + function Vic(a) { + this.a = a; + } + function fjc(a) { + this.a = a; + } + function pjc(a) { + this.a = a; + } + function ckc(a) { + this.a = a; + } + function hkc(a) { + this.a = a; + } + function Ykc(a) { + this.a = a; + } + function $kc(a) { + this.a = a; + } + function alc(a) { + this.a = a; + } + function glc(a) { + this.a = a; + } + function ilc(a) { + this.a = a; + } + function slc(a) { + this.a = a; + } + function Clc(a) { + this.a = a; + } + function xoc(a) { + this.a = a; + } + function zoc(a) { + this.a = a; + } + function spc(a) { + this.a = a; + } + function Vqc(a) { + this.a = a; + } + function Xqc(a) { + this.a = a; + } + function Gsc(a) { + this.a = a; + } + function Isc(a) { + this.a = a; + } + function JGc(a) { + this.a = a; + } + function NGc(a) { + this.a = a; + } + function MHc(a) { + this.a = a; + } + function JIc(a) { + this.a = a; + } + function fJc(a) { + this.a = a; + } + function BJc(a) { + this.a = a; + } + function dJc(a) { + this.c = a; + } + function Trc(a) { + this.b = a; + } + function eKc(a) { + this.a = a; + } + function IKc(a) { + this.a = a; + } + function KKc(a) { + this.a = a; + } + function MKc(a) { + this.a = a; + } + function yLc(a) { + this.a = a; + } + function HMc(a) { + this.a = a; + } + function LMc(a) { + this.a = a; + } + function PMc(a) { + this.a = a; + } + function TMc(a) { + this.a = a; + } + function XMc(a) { + this.a = a; + } + function ZMc(a) { + this.a = a; + } + function aNc(a) { + this.a = a; + } + function jNc(a) { + this.a = a; + } + function aPc(a) { + this.a = a; + } + function gPc(a) { + this.a = a; + } + function kPc(a) { + this.a = a; + } + function yPc(a) { + this.a = a; + } + function CPc(a) { + this.a = a; + } + function JPc(a) { + this.a = a; + } + function RPc(a) { + this.a = a; + } + function XPc(a) { + this.a = a; + } + function mRc(a) { + this.a = a; + } + function xTc(a) { + this.a = a; + } + function CWc(a) { + this.a = a; + } + function EWc(a) { + this.a = a; + } + function IWc(a) { + this.a = a; + } + function OWc(a) { + this.a = a; + } + function dXc(a) { + this.a = a; + } + function gXc(a) { + this.a = a; + } + function EXc(a) { + this.a = a; + } + function WXc(a) { + this.a = a; + } + function YXc(a) { + this.a = a; + } + function aYc(a) { + this.a = a; + } + function cYc(a) { + this.a = a; + } + function eYc(a) { + this.a = a; + } + function iYc(a) { + this.a = a; + } + function i0c(a) { + this.a = a; + } + function g0c(a) { + this.a = a; + } + function P1c(a) { + this.a = a; + } + function Sad(a) { + this.a = a; + } + function Uad(a) { + this.a = a; + } + function Wad(a) { + this.a = a; + } + function Yad(a) { + this.a = a; + } + function cbd(a) { + this.a = a; + } + function ydd(a) { + this.a = a; + } + function Kdd(a) { + this.a = a; + } + function Mdd(a) { + this.a = a; + } + function _ed(a) { + this.a = a; + } + function dfd(a) { + this.a = a; + } + function Kfd(a) { + this.a = a; + } + function prd(a) { + this.a = a; + } + function $rd(a) { + this.a = a; + } + function csd(a) { + this.a = a; + } + function Usd(a) { + this.a = a; + } + function Vtd(a) { + this.a = a; + } + function wud(a) { + this.a = a; + } + function Rud(a) { + this.f = a; + } + function LEd(a) { + this.a = a; + } + function UEd(a) { + this.a = a; + } + function VEd(a) { + this.a = a; + } + function WEd(a) { + this.a = a; + } + function XEd(a) { + this.a = a; + } + function YEd(a) { + this.a = a; + } + function ZEd(a) { + this.a = a; + } + function $Ed(a) { + this.a = a; + } + function _Ed(a) { + this.a = a; + } + function aFd(a) { + this.a = a; + } + function gFd(a) { + this.a = a; + } + function iFd(a) { + this.a = a; + } + function jFd(a) { + this.a = a; + } + function kFd(a) { + this.a = a; + } + function lFd(a) { + this.a = a; + } + function nFd(a) { + this.a = a; + } + function qFd(a) { + this.a = a; + } + function wFd(a) { + this.a = a; + } + function xFd(a) { + this.a = a; + } + function zFd(a) { + this.a = a; + } + function AFd(a) { + this.a = a; + } + function BFd(a) { + this.a = a; + } + function CFd(a) { + this.a = a; + } + function DFd(a) { + this.a = a; + } + function MFd(a) { + this.a = a; + } + function OFd(a) { + this.a = a; + } + function QFd(a) { + this.a = a; + } + function SFd(a) { + this.a = a; + } + function uGd(a) { + this.a = a; + } + function QGd(a) { + this.a = a; + } + function jGd(a) { + this.b = a; + } + function YOd(a) { + this.a = a; + } + function ePd(a) { + this.a = a; + } + function kPd(a) { + this.a = a; + } + function qPd(a) { + this.a = a; + } + function IPd(a) { + this.a = a; + } + function w$d(a) { + this.a = a; + } + function e_d(a) { + this.a = a; + } + function Q_d(a) { + this.b = a; + } + function c1d(a) { + this.a = a; + } + function c2d(a) { + this.a = a; + } + function l5d(a) { + this.a = a; + } + function I9d(a) { + this.a = a; + } + function L6d(a) { + this.c = a; + } + function t7d(a) { + this.e = a; + } + function pae(a) { + this.a = a; + } + function xae(a) { + this.a = a; + } + function Zde(a) { + this.a = a; + } + function Sde(a) { + this.d = a; + } + function mee(a) { + this.a = a; + } + function uje(a) { + this.a = a; + } + function Bte(a) { + this.a = a; + } + function Wse(a) { + this.e = a; + } + function Xsd() { + this.a = 0; + } + function Tsb() { + akb(this); + } + function bnb() { + Pmb(this); + } + function cHb() { + bHb(this); + } + function I2b() { + } + function s2d() { + this.c = d2d; + } + function Prc(a, b) { + a.b += b; + } + function Uje(a, b) { + b.Wb(a); + } + function UC(a) { + return a.a; + } + function nC(a) { + return a.a; + } + function BC(a) { + return a.a; + } + function TB(a) { + return a.a; + } + function _B(a) { + return a.a; + } + function Adb(a) { + return a.e; + } + function gC() { + return null; + } + function MC() { + return null; + } + function leb() { + MId(); + OId(); + } + function qMb(a) { + a.b.Of(a.e); + } + function A$b(a) { + a.b = new Ri(); + } + function A8b(a, b) { + a.b = b - a.b; + } + function x8b(a, b) { + a.a = b - a.a; + } + function ZEb(a, b) { + a.push(b); + } + function bFb(a, b) { + a.sort(b); + } + function Q5c(a, b) { + b.jd(a.a); + } + function Voc(a, b) { + Q3b(b, a); + } + function tp(a, b, c2) { + a.Yd(c2, b); + } + function Ss(a, b) { + a.e = b; + b.b = a; + } + function im(a) { + _l(); + this.a = a; + } + function xq(a) { + _l(); + this.a = a; + } + function Gq(a) { + _l(); + this.a = a; + } + function Xq(a) { + tm(); + this.a = a; + } + function gA(a) { + fA(); + eA.le(a); + } + function vA() { + vA = geb; + new Tsb(); + } + function xz() { + mz.call(this); + } + function Ceb() { + mz.call(this); + } + function ueb() { + xz.call(this); + } + function yeb() { + xz.call(this); + } + function Hfb() { + xz.call(this); + } + function _fb() { + xz.call(this); + } + function cgb() { + xz.call(this); + } + function Ngb() { + xz.call(this); + } + function jib() { + xz.call(this); + } + function Jrb() { + xz.call(this); + } + function Srb() { + xz.call(this); + } + function Dvb() { + xz.call(this); + } + function Ied() { + xz.call(this); + } + function R1d() { + this.a = this; + } + function k1d() { + this.Bb |= 256; + } + function vWb() { + this.b = new Et(); + } + function aFb(a, b) { + a.length = b; + } + function dyb(a, b) { + Rmb(a.a, b); + } + function jNb(a, b) { + LKb(a.c, b); + } + function qRc(a, b) { + Ysb(a.b, b); + } + function VOd(a, b) { + UNd(a.a, b); + } + function WOd(a, b) { + VNd(a.a, b); + } + function eZd(a, b) { + qvd(a.e, b); + } + function Cke(a) { + bge(a.c, a.b); + } + function uj(a, b) { + a.kc().Nb(b); + } + function Ufb(a) { + this.a = Zfb(a); + } + function _sb() { + this.a = new Tsb(); + } + function $Ab() { + this.a = new Tsb(); + } + function xAb() { + this.a = new dzb(); + } + function gyb() { + this.a = new bnb(); + } + function BIb() { + this.a = new bnb(); + } + function GIb() { + this.a = new bnb(); + } + function wIb() { + this.a = new pIb(); + } + function gJb() { + this.a = new DIb(); + } + function TTb() { + this.a = new DTb(); + } + function jGb() { + this.a = new fGb(); + } + function qGb() { + this.a = new kGb(); + } + function q_b() { + this.a = new bnb(); + } + function E_b() { + this.a = new bnb(); + } + function EZb() { + this.a = new bnb(); + } + function J$b() { + this.a = new bnb(); + } + function YNb() { + this.d = new bnb(); + } + function lXb() { + this.a = new RWb(); + } + function y_b() { + this.a = new _sb(); + } + function k5b() { + this.a = new Tsb(); + } + function E0b() { + this.b = new Tsb(); + } + function jHc() { + this.b = new bnb(); + } + function ZNc() { + this.e = new bnb(); + } + function ahc() { + this.a = new boc(); + } + function UQc() { + this.d = new bnb(); + } + function uRc() { + tRc.call(this); + } + function BRc() { + tRc.call(this); + } + function VOc() { + bnb.call(this); + } + function web() { + ueb.call(this); + } + function Fyb() { + gyb.call(this); + } + function fKb() { + RJb.call(this); + } + function N$b() { + J$b.call(this); + } + function P2b() { + I2b.call(this); + } + function T2b() { + P2b.call(this); + } + function z3b() { + I2b.call(this); + } + function C3b() { + z3b.call(this); + } + function cUc() { + aUc.call(this); + } + function hUc() { + aUc.call(this); + } + function mUc() { + aUc.call(this); + } + function Hdd() { + Ddd.call(this); + } + function ACd() { + $yd.call(this); + } + function PCd() { + $yd.call(this); + } + function Ejd() { + Yub.call(this); + } + function LQd() { + wQd.call(this); + } + function lRd() { + wQd.call(this); + } + function MSd() { + Tsb.call(this); + } + function VSd() { + Tsb.call(this); + } + function eTd() { + Tsb.call(this); + } + function mXd() { + HWd.call(this); + } + function i1d() { + _sb.call(this); + } + function A1d() { + k1d.call(this); + } + function q4d() { + dWd.call(this); + } + function O5d() { + Tsb.call(this); + } + function R5d() { + dWd.call(this); + } + function lae() { + Tsb.call(this); + } + function Cae() { + Tsb.call(this); + } + function ome() { + kUd.call(this); + } + function Hme() { + ome.call(this); + } + function Nme() { + kUd.call(this); + } + function Gre() { + Tqe.call(this); + } + function aUc() { + this.a = new _sb(); + } + function nZc() { + this.a = new Tsb(); + } + function DZc() { + this.a = new bnb(); + } + function Ddd() { + this.a = new Tsb(); + } + function Oqd() { + this.a = new Yub(); + } + function Oed() { + this.j = new bnb(); + } + function obd() { + this.a = new nbd(); + } + function wQd() { + this.a = new AQd(); + } + function R5c() { + this.a = new V5c(); + } + function wb() { + wb = geb; + vb = new xb(); + } + function Wk() { + Wk = geb; + Vk = new Xk(); + } + function kl() { + kl = geb; + jl = new ll(); + } + function ll() { + Qk.call(this, ""); + } + function Xk() { + Qk.call(this, ""); + } + function Dd(a) { + yd.call(this, a); + } + function Hd(a) { + yd.call(this, a); + } + function xh(a) { + th.call(this, a); + } + function $h(a) { + Wc.call(this, a); + } + function Qi(a) { + Wc.call(this, a); + } + function wi(a) { + $h.call(this, a); + } + function Sp(a) { + $h.call(this, a); + } + function Js(a) { + $h.call(this, a); + } + function Jp(a) { + Xo.call(this, a); + } + function Qp(a) { + Xo.call(this, a); + } + function dq(a) { + ho.call(this, a); + } + function Fv(a) { + uv.call(this, a); + } + function aw(a) { + Tr.call(this, a); + } + function cw(a) { + Tr.call(this, a); + } + function _w(a) { + Tr.call(this, a); + } + function Mx(a) { + Gn.call(this, a); + } + function Nx(a) { + Mx.call(this, a); + } + function yz(a) { + nz.call(this, a); + } + function aC(a) { + yz.call(this, a); + } + function uC() { + vC.call(this, {}); + } + function cC() { + cC = geb; + bC = new dC(); + } + function zs() { + zs = geb; + ys = new As(); + } + function Az() { + Az = geb; + zz = new nb(); + } + function $z() { + $z = geb; + Zz = new bA(); + } + function $A() { + $A = geb; + ZA = new aB(); + } + function Ovb(a) { + Kvb(); + this.a = a; + } + function FKc(a) { + jKc(); + this.a = a; + } + function zud(a) { + nud(); + this.f = a; + } + function Bud(a) { + nud(); + this.f = a; + } + function Cde(a) { + KMd(); + this.a = a; + } + function Lyb(a) { + a.b = null; + a.c = 0; + } + function kz(a, b) { + a.e = b; + hz(a, b); + } + function NYb(a, b) { + a.a = b; + PYb(a); + } + function cLb(a, b, c2) { + a.a[b.g] = c2; + } + function zsd(a, b, c2) { + Hsd(c2, a, b); + } + function shc(a, b) { + Xmc(b.i, a.n); + } + function HCc(a, b) { + ICc(a).Cd(b); + } + function yw(a, b) { + a.a.ec().Mc(b); + } + function ns(a, b) { + return a.g - b.g; + } + function AUb(a, b) { + return a * a / b; + } + function Heb(a) { + return uFb(a), a; + } + function Kfb(a) { + return uFb(a), a; + } + function Mfb(a) { + return uFb(a), a; + } + function JC(a) { + return new hC(a); + } + function LC(a) { + return new OC(a); + } + function shb(a) { + return uFb(a), a; + } + function Chb(a) { + return uFb(a), a; + } + function teb(a) { + yz.call(this, a); + } + function veb(a) { + yz.call(this, a); + } + function zeb(a) { + yz.call(this, a); + } + function Aeb(a) { + nz.call(this, a); + } + function Ifb(a) { + yz.call(this, a); + } + function agb(a) { + yz.call(this, a); + } + function dgb(a) { + yz.call(this, a); + } + function Mgb(a) { + yz.call(this, a); + } + function Ogb(a) { + yz.call(this, a); + } + function kib(a) { + yz.call(this, a); + } + function Jed(a) { + yz.call(this, a); + } + function Ked(a) { + yz.call(this, a); + } + function CDd(a) { + yz.call(this, a); + } + function Mle(a) { + yz.call(this, a); + } + function Lqe(a) { + yz.call(this, a); + } + function mob(a) { + uFb(a); + this.a = a; + } + function yYb(a) { + sYb(a); + return a; + } + function Nnb(a) { + Snb(a, a.length); + } + function nmb(a) { + return a.b == a.c; + } + function Vyb(a) { + return !!a && a.b; + } + function gLb(a) { + return !!a && a.k; + } + function hLb(a) { + return !!a && a.j; + } + function F_b(a, b, c2) { + a.c.Ef(b, c2); + } + function Ts(a, b) { + a.be(b); + b.ae(a); + } + function Fy(a) { + _l(); + this.a = Qb(a); + } + function Gb() { + this.a = WD(Qb(pve)); + } + function jc() { + throw Adb(new jib()); + } + function jn() { + throw Adb(new jib()); + } + function Hh() { + throw Adb(new jib()); + } + function Xi() { + throw Adb(new jib()); + } + function Xj() { + throw Adb(new jib()); + } + function Yj() { + throw Adb(new jib()); + } + function Qz() { + Qz = geb; + !!(fA(), eA); + } + function Qhb() { + reb.call(this, ""); + } + function Rhb() { + reb.call(this, ""); + } + function bib() { + reb.call(this, ""); + } + function cib() { + reb.call(this, ""); + } + function eib(a) { + veb.call(this, a); + } + function xeb(a) { + veb.call(this, a); + } + function Vgb(a) { + agb.call(this, a); + } + function Lqb(a) { + xpb.call(this, a); + } + function Sqb(a) { + Lqb.call(this, a); + } + function irb(a) { + Upb.call(this, a); + } + function pc(a) { + qc.call(this, a, 0); + } + function Ri() { + Si.call(this, 12, 3); + } + function WC(a, b) { + return xfb(a, b); + } + function cFb(a, b) { + return dD(a, b); + } + function Reb(a, b) { + return a.a - b.a; + } + function afb(a, b) { + return a.a - b.a; + } + function Wgb(a, b) { + return a.a - b.a; + } + function pC(b, a) { + return a in b.a; + } + function Vvb(a) { + return a.a ? a.b : 0; + } + function cwb(a) { + return a.a ? a.b : 0; + } + function Fxb(a, b, c2) { + b.Cd(a.a[c2]); + } + function Kxb(a, b, c2) { + b.Pe(a.a[c2]); + } + function uKb(a, b) { + a.b = new sjd(b); + } + function QGb(a, b) { + a.b = b; + return a; + } + function RGb(a, b) { + a.c = b; + return a; + } + function SGb(a, b) { + a.f = b; + return a; + } + function TGb(a, b) { + a.g = b; + return a; + } + function yJb(a, b) { + a.a = b; + return a; + } + function zJb(a, b) { + a.f = b; + return a; + } + function AJb(a, b) { + a.k = b; + return a; + } + function WNb(a, b) { + a.a = b; + return a; + } + function XNb(a, b) { + a.e = b; + return a; + } + function BYb(a, b) { + a.e = b; + return a; + } + function CYb(a, b) { + a.f = b; + return a; + } + function BRb(a, b) { + a.b = true; + a.d = b; + } + function WNc(a, b) { + return a.b - b.b; + } + function KSc(a, b) { + return a.g - b.g; + } + function pmc(a, b) { + return a ? 0 : b - 1; + } + function qKc(a, b) { + return a ? 0 : b - 1; + } + function pKc(a, b) { + return a ? b - 1 : 0; + } + function uVc(a, b) { + return a.s - b.s; + } + function Xed(a, b) { + return b.rg(a); + } + function Xfd(a, b) { + a.b = b; + return a; + } + function Wfd(a, b) { + a.a = b; + return a; + } + function Yfd(a, b) { + a.c = b; + return a; + } + function Zfd(a, b) { + a.d = b; + return a; + } + function $fd(a, b) { + a.e = b; + return a; + } + function _fd(a, b) { + a.f = b; + return a; + } + function mgd(a, b) { + a.a = b; + return a; + } + function ngd(a, b) { + a.b = b; + return a; + } + function ogd(a, b) { + a.c = b; + return a; + } + function Khd(a, b) { + a.c = b; + return a; + } + function Jhd(a, b) { + a.b = b; + return a; + } + function Lhd(a, b) { + a.d = b; + return a; + } + function Mhd(a, b) { + a.e = b; + return a; + } + function Nhd(a, b) { + a.f = b; + return a; + } + function Ohd(a, b) { + a.g = b; + return a; + } + function Phd(a, b) { + a.a = b; + return a; + } + function Qhd(a, b) { + a.i = b; + return a; + } + function Rhd(a, b) { + a.j = b; + return a; + } + function coc(a, b) { + Mnc(); + P3b(b, a); + } + function bbd(a, b, c2) { + _ad(a.a, b, c2); + } + function Fjd(a) { + Zub.call(this, a); + } + function TRb(a) { + SRb.call(this, a); + } + function pLc(a) { + CIc.call(this, a); + } + function ILc(a) { + CIc.call(this, a); + } + function gLd(a) { + ZHd.call(this, a); + } + function DPd(a) { + xPd.call(this, a); + } + function FPd(a) { + xPd.call(this, a); + } + function x2b() { + y2b.call(this, ""); + } + function pjd() { + this.a = 0; + this.b = 0; + } + function ATc() { + this.b = 0; + this.a = 0; + } + function lXd(a, b) { + a.b = 0; + bWd(a, b); + } + function Kqd(a, b) { + a.k = b; + return a; + } + function Lqd(a, b) { + a.j = b; + return a; + } + function vfe(a, b) { + a.c = b; + a.b = true; + } + function Etb() { + Etb = geb; + Dtb = Gtb(); + } + function bvd() { + bvd = geb; + avd = OAd(); + } + function dvd() { + dvd = geb; + cvd = aCd(); + } + function MId() { + MId = geb; + LId = ygd(); + } + function jTd() { + jTd = geb; + iTd = Qae(); + } + function Ole() { + Ole = geb; + Nle = vne(); + } + function Qle() { + Qle = geb; + Ple = Cne(); + } + function mfb(a) { + return a.e && a.e(); + } + function FD(a) { + return a.l | a.m << 22; + } + function Oc(a, b) { + return a.c._b(b); + } + function En(a, b) { + return Wv(a.b, b); + } + function Vd(a) { + return !a ? null : a.d; + } + function Vv(a) { + return !a ? null : a.g; + } + function $v(a) { + return !a ? null : a.i; + } + function nfb(a) { + lfb(a); + return a.o; + } + function Khb(a, b) { + a.a += b; + return a; + } + function Lhb(a, b) { + a.a += b; + return a; + } + function Ohb(a, b) { + a.a += b; + return a; + } + function Uhb(a, b) { + a.a += b; + return a; + } + function _wb(a, b) { + while (a.Bd(b)) + ; + } + function atb(a) { + this.a = new Usb(a); + } + function $tb() { + throw Adb(new jib()); + } + function qpb() { + throw Adb(new jib()); + } + function rpb() { + throw Adb(new jib()); + } + function spb() { + throw Adb(new jib()); + } + function vpb() { + throw Adb(new jib()); + } + function Opb() { + throw Adb(new jib()); + } + function yAb(a) { + this.a = new ezb(a); + } + function H2c() { + this.a = new Wed(s0); + } + function TVc() { + this.b = new Wed(H$); + } + function l6c() { + this.a = new Wed(V0); + } + function $ad() { + this.b = new Wed(I1); + } + function nbd() { + this.b = new Wed(I1); + } + function T2c(a) { + this.a = 0; + this.b = a; + } + function Bib(a) { + tib(); + vib(this, a); + } + function QDb(a) { + LCb(a); + return a.a; + } + function dvb(a) { + return a.b != a.d.c; + } + function AMc(a, b) { + return a.d[b.p]; + } + function ued(a, b) { + return ned(a, b); + } + function $Eb(a, b, c2) { + a.splice(b, c2); + } + function ixb(a, b) { + while (a.Re(b)) + ; + } + function NKb(a) { + a.c ? MKb(a) : OKb(a); + } + function mQd() { + throw Adb(new jib()); + } + function nQd() { + throw Adb(new jib()); + } + function oQd() { + throw Adb(new jib()); + } + function pQd() { + throw Adb(new jib()); + } + function qQd() { + throw Adb(new jib()); + } + function rQd() { + throw Adb(new jib()); + } + function sQd() { + throw Adb(new jib()); + } + function tQd() { + throw Adb(new jib()); + } + function uQd() { + throw Adb(new jib()); + } + function vQd() { + throw Adb(new jib()); + } + function zue() { + throw Adb(new Dvb()); + } + function Aue() { + throw Adb(new Dvb()); + } + function oue(a) { + this.a = new Dte(a); + } + function Dte(a) { + Cte(this, a, sse()); + } + function cve(a) { + return !a || bve(a); + } + function Cqe(a) { + return xqe[a] != -1; + } + function Yz() { + Nz != 0 && (Nz = 0); + Pz = -1; + } + function beb() { + _db == null && (_db = []); + } + function eg(a, b) { + zf.call(this, a, b); + } + function gg(a, b) { + eg.call(this, a, b); + } + function Nj(a, b) { + this.a = a; + this.b = b; + } + function hk(a, b) { + this.a = a; + this.b = b; + } + function nk(a, b) { + this.a = a; + this.b = b; + } + function pk(a, b) { + this.a = a; + this.b = b; + } + function xk(a, b) { + this.a = a; + this.b = b; + } + function zk(a, b) { + this.a = a; + this.b = b; + } + function Kk(a, b) { + this.a = a; + this.b = b; + } + function ne(a, b) { + this.e = a; + this.d = b; + } + function Hf(a, b) { + this.b = a; + this.c = b; + } + function cp(a, b) { + this.b = a; + this.a = b; + } + function Cp(a, b) { + this.b = a; + this.a = b; + } + function qr(a, b) { + this.b = a; + this.a = b; + } + function Rr(a, b) { + this.b = a; + this.a = b; + } + function vr(a, b) { + this.a = a; + this.b = b; + } + function su(a, b) { + this.a = a; + this.b = b; + } + function Hu(a, b) { + this.a = a; + this.f = b; + } + function gp(a, b) { + this.g = a; + this.i = b; + } + function qs(a, b) { + this.f = a; + this.g = b; + } + function Gv(a, b) { + this.b = a; + this.c = b; + } + function Wc(a) { + Lb(a.dc()); + this.c = a; + } + function Ex(a, b) { + this.a = a; + this.b = b; + } + function ey(a, b) { + this.a = a; + this.b = b; + } + function pv(a) { + this.a = RD(Qb(a), 15); + } + function uv(a) { + this.a = RD(Qb(a), 15); + } + function nw(a) { + this.a = RD(Qb(a), 85); + } + function rf(a) { + this.b = RD(Qb(a), 85); + } + function Tr(a) { + this.b = RD(Qb(a), 51); + } + function uB() { + this.q = new $wnd.Date(); + } + function CC(a, b) { + this.a = a; + this.b = b; + } + function Bt(a, b) { + return Ujb(a.b, b); + } + function tpb(a, b) { + return a.b.Hc(b); + } + function upb(a, b) { + return a.b.Ic(b); + } + function wpb(a, b) { + return a.b.Qc(b); + } + function Pqb(a, b) { + return a.b.Hc(b); + } + function pqb(a, b) { + return a.c.uc(b); + } + function rqb(a, b) { + return pb(a.c, b); + } + function Zsb(a, b) { + return a.a._b(b); + } + function Xp(a, b) { + return a > b && b < hwe; + } + function bkb(a) { + return a.f.c + a.i.c; + } + function IC(a) { + return WB(), a ? VB : UB; + } + function Usb(a) { + ckb.call(this, a, 0); + } + function dzb() { + ezb.call(this, null); + } + function Osb(a) { + this.c = a; + Lsb(this); + } + function Yub() { + Lub(this); + Xub(this); + } + function gib() { + gib = geb; + fib = new oeb(); + } + function Qob() { + Qob = geb; + Pob = new Rob(); + } + function Tvb() { + Tvb = geb; + Svb = new Xvb(); + } + function bwb() { + bwb = geb; + awb = new dwb(); + } + function SAb() { + SAb = geb; + RAb = new VAb(); + } + function rDb() { + NCb.call(this, null); + } + function xDb() { + xDb = geb; + wDb = new KEb(); + } + function FDb(a, b) { + LCb(a); + a.a.Nb(b); + } + function sAb(a, b) { + return a.a.Xc(b); + } + function tAb(a, b) { + return a.a.Yc(b); + } + function uAb(a, b) { + return a.a.$c(b); + } + function vAb(a, b) { + return a.a._c(b); + } + function JBb(a, b) { + return a.Gc(b), a; + } + function KBb(a, b) { + return ye(a, b), a; + } + function m_d(a, b) { + pLd(xYd(a.a), b); + } + function r_d(a, b) { + pLd(xYd(a.a), b); + } + function EBb(a, b) { + a.Gc(b); + return a; + } + function hGb(a, b) { + a.a.f = b; + return a; + } + function nGb(a, b) { + a.a.d = b; + return a; + } + function oGb(a, b) { + a.a.g = b; + return a; + } + function pGb(a, b) { + a.a.j = b; + return a; + } + function sIb(a, b) { + a.a.a = b; + return a; + } + function tIb(a, b) { + a.a.d = b; + return a; + } + function uIb(a, b) { + a.a.e = b; + return a; + } + function vIb(a, b) { + a.a.g = b; + return a; + } + function fJb(a, b) { + a.a.f = b; + return a; + } + function KJb(a) { + a.b = false; + return a; + } + function wGb() { + wGb = geb; + vGb = new xGb(); + } + function VRb() { + VRb = geb; + URb = new WRb(); + } + function zXb() { + zXb = geb; + yXb = new FXb(); + } + function kYb() { + kYb = geb; + jYb = new lYb(); + } + function pYb() { + pYb = geb; + oYb = new QYb(); + } + function NZb() { + NZb = geb; + MZb = new SZb(); + } + function g0b() { + g0b = geb; + f0b = new l0b(); + } + function i1b() { + i1b = geb; + h1b = new X1b(); + } + function s7b() { + s7b = geb; + r7b = new C7b(); + } + function H5b() { + H5b = geb; + G5b = new pjd(); + } + function Hcc() { + Hcc = geb; + Gcc = new Ncc(); + } + function Wjc() { + Wjc = geb; + Vjc = new Jlc(); + } + function mqc() { + mqc = geb; + lqc = new Aqc(); + } + function GCc() { + GCc = geb; + FCc = new Yrd(); + } + function sbd() { + sbd = geb; + rbd = new ubd(); + } + function Cbd() { + Cbd = geb; + Bbd = new Dbd(); + } + function _cd() { + _cd = geb; + $cd = new cdd(); + } + function GGc() { + yGc(); + this.c = new Ri(); + } + function ubd() { + qs.call(this, DBe, 0); + } + function Mfd(a, b, c2) { + $jb(a.d, b.f, c2); + } + function bNb(a, b, c2, d) { + aNb(a, d, b, c2); + } + function V6b(a, b, c2, d) { + $6b(d, a, b, c2); + } + function vcc(a, b, c2, d) { + wcc(d, a, b, c2); + } + function Dgd(a, b) { + dub(a.c.c, b.b, b); + } + function Cgd(a, b) { + dub(a.c.b, b.c, b); + } + function BYc(a) { + return a.e.b + a.f.b; + } + function AYc(a) { + return a.e.a + a.f.a; + } + function N1d(a) { + return a.b ? a.b : a.a; + } + function yTc(a) { + return (a.c + a.a) / 2; + } + function b2d(a, b) { + return GA(a.a, b); + } + function rfd(a, b) { + a.a = b.g; + return a; + } + function hTd() { + hTd = geb; + gTd = new Cae(); + } + function cTd() { + cTd = geb; + bTd = new eTd(); + } + function lud() { + lud = geb; + kud = new Yud(); + } + function $Sd() { + $Sd = geb; + ZSd = new _Sd(); + } + function TSd() { + TSd = geb; + SSd = new VSd(); + } + function YSd() { + YSd = geb; + XSd = new O5d(); + } + function PRd() { + PRd = geb; + ORd = new Tsb(); + } + function N2d() { + N2d = geb; + M2d = new Uhe(); + } + function j3d() { + j3d = geb; + i3d = new Yhe(); + } + function Gie() { + Gie = geb; + Fie = new Hie(); + } + function nke() { + nke = geb; + mke = new rke(); + } + function uue() { + uue = geb; + tue = new Cue(); + } + function Tae() { + Tae = geb; + Rae = new bnb(); + } + function _v(a) { + return RD(a, 44).ld(); + } + function Akb(a) { + return a.b < a.d.gc(); + } + function meb(b, a) { + return a.split(b); + } + function Idb(a, b) { + return Ddb(a, b) > 0; + } + function Ldb(a, b) { + return Ddb(a, b) < 0; + } + function Urb(a, b) { + return Bsb(a.a, b); + } + function Beb(a, b) { + oz.call(this, a, b); + } + function Qx(a) { + Px(); + ho.call(this, a); + } + function Lnb(a, b) { + Pnb(a, a.length, b); + } + function Mnb(a, b) { + Rnb(a, a.length, b); + } + function Ktb(a, b) { + return a.a.get(b); + } + function bub(a, b) { + return Ujb(a.e, b); + } + function Zxb(a) { + return uFb(a), false; + } + function zw(a) { + this.a = RD(Qb(a), 229); + } + function $wb(a) { + Swb.call(this, a, 21); + } + function dAb(a, b) { + qs.call(this, a, b); + } + function yBb(a, b) { + qs.call(this, a, b); + } + function ssb(a, b) { + this.b = a; + this.a = b; + } + function xlb(a, b) { + this.d = a; + this.e = b; + } + function jEb(a, b) { + this.a = a; + this.b = b; + } + function pEb(a, b) { + this.a = a; + this.b = b; + } + function vEb(a, b) { + this.a = a; + this.b = b; + } + function BEb(a, b) { + this.a = a; + this.b = b; + } + function TFb(a, b) { + this.a = a; + this.b = b; + } + function QEb(a, b) { + this.b = a; + this.a = b; + } + function sHb(a, b) { + this.b = a; + this.a = b; + } + function EHb(a, b) { + qs.call(this, a, b); + } + function MHb(a, b) { + qs.call(this, a, b); + } + function jIb(a, b) { + qs.call(this, a, b); + } + function $Jb(a, b) { + qs.call(this, a, b); + } + function FKb(a, b) { + qs.call(this, a, b); + } + function wLb(a, b) { + qs.call(this, a, b); + } + function nOb(a, b) { + qs.call(this, a, b); + } + function kPb(a, b) { + this.b = a; + this.a = b; + } + function JPb(a, b) { + qs.call(this, a, b); + } + function fRb(a, b) { + this.b = a; + this.a = b; + } + function JRb(a, b) { + qs.call(this, a, b); + } + function OTb(a, b) { + this.b = a; + this.a = b; + } + function UUb(a, b) { + qs.call(this, a, b); + } + function BWb(a, b) { + qs.call(this, a, b); + } + function tXb(a, b) { + qs.call(this, a, b); + } + function XEb(a, b, c2) { + a.splice(b, 0, c2); + } + function pr(a, b, c2) { + a.Mb(c2) && b.Cd(c2); + } + function lEb(a, b, c2) { + b.Pe(a.a.Ye(c2)); + } + function rEb(a, b, c2) { + b.Dd(a.a.Ze(c2)); + } + function xEb(a, b, c2) { + b.Cd(a.a.Kb(c2)); + } + function eYb(a, b) { + return Csb(a.c, b); + } + function cGb(a, b) { + return Csb(a.e, b); + } + function qZb(a, b) { + qs.call(this, a, b); + } + function V$b(a, b) { + qs.call(this, a, b); + } + function s3b(a, b) { + qs.call(this, a, b); + } + function Q8b(a, b) { + qs.call(this, a, b); + } + function icc(a, b) { + qs.call(this, a, b); + } + function xec(a, b) { + qs.call(this, a, b); + } + function gic(a, b) { + this.a = a; + this.b = b; + } + function Xic(a, b) { + this.a = a; + this.b = b; + } + function h4b(a, b) { + this.a = a; + this.b = b; + } + function vjc(a, b) { + this.a = a; + this.b = b; + } + function xjc(a, b) { + this.a = a; + this.b = b; + } + function Hjc(a, b) { + this.a = a; + this.b = b; + } + function hjc(a, b) { + this.b = a; + this.a = b; + } + function Jjc(a, b) { + this.b = a; + this.a = b; + } + function _Yb(a, b) { + this.b = a; + this.a = b; + } + function eZb(a, b) { + this.c = a; + this.d = b; + } + function Q1b(a, b) { + this.e = a; + this.d = b; + } + function Tjc(a, b) { + this.a = a; + this.b = b; + } + function ulc(a, b) { + this.a = a; + this.b = b; + } + function Elc(a, b) { + this.a = a; + this.b = b; + } + function fqc(a, b) { + this.b = a; + this.a = b; + } + function smc(a, b) { + this.b = b; + this.c = a; + } + function fnc(a, b) { + qs.call(this, a, b); + } + function Cnc(a, b) { + qs.call(this, a, b); + } + function koc(a, b) { + qs.call(this, a, b); + } + function ktc(a, b) { + qs.call(this, a, b); + } + function ctc(a, b) { + qs.call(this, a, b); + } + function utc(a, b) { + qs.call(this, a, b); + } + function Ftc(a, b) { + qs.call(this, a, b); + } + function Rtc(a, b) { + qs.call(this, a, b); + } + function _tc(a, b) { + qs.call(this, a, b); + } + function iuc(a, b) { + qs.call(this, a, b); + } + function vuc(a, b) { + qs.call(this, a, b); + } + function Duc(a, b) { + qs.call(this, a, b); + } + function Puc(a, b) { + qs.call(this, a, b); + } + function _uc(a, b) { + qs.call(this, a, b); + } + function pvc(a, b) { + qs.call(this, a, b); + } + function yvc(a, b) { + qs.call(this, a, b); + } + function Hvc(a, b) { + qs.call(this, a, b); + } + function Pvc(a, b) { + qs.call(this, a, b); + } + function dxc(a, b) { + qs.call(this, a, b); + } + function bDc(a, b) { + qs.call(this, a, b); + } + function nDc(a, b) { + qs.call(this, a, b); + } + function yDc(a, b) { + qs.call(this, a, b); + } + function LDc(a, b) { + qs.call(this, a, b); + } + function bEc(a, b) { + qs.call(this, a, b); + } + function lEc(a, b) { + qs.call(this, a, b); + } + function tEc(a, b) { + qs.call(this, a, b); + } + function CEc(a, b) { + qs.call(this, a, b); + } + function LEc(a, b) { + qs.call(this, a, b); + } + function UEc(a, b) { + qs.call(this, a, b); + } + function mFc(a, b) { + qs.call(this, a, b); + } + function vFc(a, b) { + qs.call(this, a, b); + } + function EFc(a, b) { + qs.call(this, a, b); + } + function SKc(a, b) { + qs.call(this, a, b); + } + function cNc(a, b) { + this.b = a; + this.a = b; + } + function tNc(a, b) { + qs.call(this, a, b); + } + function QOc(a, b) { + this.a = a; + this.b = b; + } + function ePc(a, b) { + this.a = a; + this.b = b; + } + function LPc(a, b) { + this.a = a; + this.b = b; + } + function xQc(a, b) { + qs.call(this, a, b); + } + function FQc(a, b) { + qs.call(this, a, b); + } + function MQc(a, b) { + this.a = a; + this.b = b; + } + function FMc(a, b) { + dMc(); + return b != a; + } + function Uvb(a) { + sFb(a.a); + return a.b; + } + function qYb(a) { + rYb(a, a.c); + return a; + } + function Itb() { + Etb(); + return new Dtb(); + } + function _ec() { + Rec(); + this.a = new e6b(); + } + function lSc() { + dSc(); + this.a = new _sb(); + } + function aRc() { + WQc(); + this.b = new _sb(); + } + function xRc(a, b) { + this.b = a; + this.d = b; + } + function nVc(a, b) { + this.a = a; + this.b = b; + } + function pVc(a, b) { + this.a = a; + this.b = b; + } + function GWc(a, b) { + this.a = a; + this.b = b; + } + function IXc(a, b) { + this.b = a; + this.a = b; + } + function gTc(a, b) { + qs.call(this, a, b); + } + function eVc(a, b) { + qs.call(this, a, b); + } + function $Vc(a, b) { + qs.call(this, a, b); + } + function XYc(a, b) { + qs.call(this, a, b); + } + function MZc(a, b) { + qs.call(this, a, b); + } + function t_c(a, b) { + qs.call(this, a, b); + } + function B_c(a, b) { + qs.call(this, a, b); + } + function z2c(a, b) { + qs.call(this, a, b); + } + function h3c(a, b) { + qs.call(this, a, b); + } + function $3c(a, b) { + qs.call(this, a, b); + } + function i4c(a, b) { + qs.call(this, a, b); + } + function l5c(a, b) { + qs.call(this, a, b); + } + function v5c(a, b) { + qs.call(this, a, b); + } + function g6c(a, b) { + qs.call(this, a, b); + } + function A6c(a, b) { + qs.call(this, a, b); + } + function a7c(a, b) { + qs.call(this, a, b); + } + function B8c(a, b) { + qs.call(this, a, b); + } + function d9c(a, b) { + qs.call(this, a, b); + } + function D9c(a, b) { + qs.call(this, a, b); + } + function tad(a, b) { + qs.call(this, a, b); + } + function hbd(a, b) { + qs.call(this, a, b); + } + function Nbd(a, b) { + qs.call(this, a, b); + } + function Ybd(a, b) { + qs.call(this, a, b); + } + function ndd(a, b) { + qs.call(this, a, b); + } + function z1c(a, b) { + this.b = a; + this.a = b; + } + function B1c(a, b) { + this.b = a; + this.a = b; + } + function d2c(a, b) { + this.b = a; + this.a = b; + } + function f2c(a, b) { + this.b = a; + this.a = b; + } + function m9c(a, b) { + this.a = a; + this.b = b; + } + function xed(a, b) { + this.a = a; + this.b = b; + } + function ffd(a, b) { + this.a = a; + this.b = b; + } + function rjd(a, b) { + this.a = a; + this.b = b; + } + function Sjd(a, b) { + qs.call(this, a, b); + } + function Zhd(a, b) { + qs.call(this, a, b); + } + function lid(a, b) { + qs.call(this, a, b); + } + function vkd(a, b) { + qs.call(this, a, b); + } + function Gmd(a, b) { + qs.call(this, a, b); + } + function Pmd(a, b) { + qs.call(this, a, b); + } + function Zmd(a, b) { + qs.call(this, a, b); + } + function jnd(a, b) { + qs.call(this, a, b); + } + function Gnd(a, b) { + qs.call(this, a, b); + } + function Rnd(a, b) { + qs.call(this, a, b); + } + function eod(a, b) { + qs.call(this, a, b); + } + function qod(a, b) { + qs.call(this, a, b); + } + function Eod(a, b) { + qs.call(this, a, b); + } + function Qod(a, b) { + qs.call(this, a, b); + } + function upd(a, b) { + qs.call(this, a, b); + } + function Rpd(a, b) { + qs.call(this, a, b); + } + function eqd(a, b) { + qs.call(this, a, b); + } + function nqd(a, b) { + qs.call(this, a, b); + } + function vqd(a, b) { + qs.call(this, a, b); + } + function Hrd(a, b) { + qs.call(this, a, b); + } + function esd(a, b) { + this.a = a; + this.b = b; + } + function gsd(a, b) { + this.a = a; + this.b = b; + } + function isd(a, b) { + this.a = a; + this.b = b; + } + function Osd(a, b) { + this.a = a; + this.b = b; + } + function Qsd(a, b) { + this.a = a; + this.b = b; + } + function Ssd(a, b) { + this.a = a; + this.b = b; + } + function Ptd(a, b) { + this.a = a; + this.b = b; + } + function JEd(a, b) { + this.a = a; + this.b = b; + } + function KEd(a, b) { + this.a = a; + this.b = b; + } + function MEd(a, b) { + this.a = a; + this.b = b; + } + function NEd(a, b) { + this.a = a; + this.b = b; + } + function QEd(a, b) { + this.a = a; + this.b = b; + } + function REd(a, b) { + this.a = a; + this.b = b; + } + function SEd(a, b) { + this.b = a; + this.a = b; + } + function TEd(a, b) { + this.b = a; + this.a = b; + } + function bFd(a, b) { + this.b = a; + this.a = b; + } + function dFd(a, b) { + this.b = a; + this.a = b; + } + function fFd(a, b) { + this.a = a; + this.b = b; + } + function hFd(a, b) { + this.a = a; + this.b = b; + } + function utd(a, b) { + qs.call(this, a, b); + } + function sFd(a, b) { + this.a = a; + this.b = b; + } + function uFd(a, b) { + this.a = a; + this.b = b; + } + function bGd(a, b) { + qs.call(this, a, b); + } + function uId(a, b) { + this.f = a; + this.c = b; + } + function Ofd(a, b) { + return Csb(a.g, b); + } + function Tqc(a, b) { + return Csb(b.b, a); + } + function HPd(a, b) { + return QNd(a.a, b); + } + function Idd(a, b) { + return -a.b.af(b); + } + function IId(a, b) { + !!a && Zjb(CId, a, b); + } + function yWd(a, b) { + a.i = null; + zWd(a, b); + } + function kEd(a, b, c2) { + pDd(b, KDd(a, c2)); + } + function lEd(a, b, c2) { + pDd(b, KDd(a, c2)); + } + function mFd(a, b) { + vEd(a.a, RD(b, 58)); + } + function _Mc(a, b) { + GMc(a.a, RD(b, 12)); + } + function KTd(a, b) { + this.a = a; + this.b = b; + } + function NTd(a, b) { + this.a = a; + this.b = b; + } + function B5d(a, b) { + this.a = a; + this.b = b; + } + function Z6d(a, b) { + this.a = a; + this.b = b; + } + function Ble(a, b) { + this.a = a; + this.b = b; + } + function afe(a, b) { + this.d = a; + this.b = b; + } + function wfe(a, b) { + this.e = a; + this.a = b; + } + function Eke(a, b) { + this.b = a; + this.c = b; + } + function zNd(a, b) { + this.i = a; + this.g = b; + } + function kZd(a, b) { + this.d = a; + this.e = b; + } + function ave(a, b) { + eve(new dMd(a), b); + } + function Dke(a) { + return pge(a.c, a.b); + } + function Wd(a) { + return !a ? null : a.md(); + } + function dE(a) { + return a == null ? null : a; + } + function bE(a) { + return typeof a === jve; + } + function $D(a) { + return typeof a === hve; + } + function _D(a) { + return typeof a === ive; + } + function Gdb(a, b) { + return Ddb(a, b) == 0; + } + function Jdb(a, b) { + return Ddb(a, b) >= 0; + } + function Pdb(a, b) { + return Ddb(a, b) != 0; + } + function ar(a, b) { + return zr(a.Kc(), b); + } + function Qm(a, b) { + return a.Rd().Xb(b); + } + function kg(a) { + ig(a); + return a.d.gc(); + } + function fE(a) { + CFb(a == null); + return a; + } + function Mhb(a, b) { + a.a += "" + b; + return a; + } + function Nhb(a, b) { + a.a += "" + b; + return a; + } + function Whb(a, b) { + a.a += "" + b; + return a; + } + function Yhb(a, b) { + a.a += "" + b; + return a; + } + function Zhb(a, b) { + a.a += "" + b; + return a; + } + function Vhb(a, b) { + return a.a += "" + b, a; + } + function Pfb(a) { + return "" + (uFb(a), a); + } + function Vsb(a) { + akb(this); + Ld(this, a); + } + function YFc() { + RFc(); + UFc.call(this); + } + function pxb(a, b) { + kxb.call(this, a, b); + } + function txb(a, b) { + kxb.call(this, a, b); + } + function xxb(a, b) { + kxb.call(this, a, b); + } + function Oub(a, b) { + Pub(a, b, a.c.b, a.c); + } + function Nub(a, b) { + Pub(a, b, a.a, a.a.a); + } + function Iob(a) { + tFb(a, 0); + return null; + } + function Xvb() { + this.b = 0; + this.a = false; + } + function dwb() { + this.b = 0; + this.a = false; + } + function Et() { + this.b = new Usb(Sv(12)); + } + function pMb() { + pMb = geb; + oMb = ss(nMb()); + } + function ncc() { + ncc = geb; + mcc = ss(lcc()); + } + function aZc() { + aZc = geb; + _Yc = ss($Yc()); + } + function WA() { + WA = geb; + vA(); + VA = new Tsb(); + } + function hjd(a) { + a.a = 0; + a.b = 0; + return a; + } + function qfd(a, b) { + a.a = b.g + 1; + return a; + } + function yNd(a, b) { + aMd.call(this, a, b); + } + function lGd(a, b) { + kGd.call(this, a, b); + } + function N$d(a, b) { + zNd.call(this, a, b); + } + function Whe(a, b) { + Q2d.call(this, a, b); + } + function She(a, b) { + Phe.call(this, a, b); + } + function RRd(a, b) { + PRd(); + Zjb(ORd, a, b); + } + function sB(a, b) { + a.q.setTime(Xdb(b)); + } + function Xz(a) { + $wnd.clearTimeout(a); + } + function cr(a) { + return Qb(a), new Dl(a); + } + function mb(a, b) { + return dE(a) === dE(b); + } + function Mw(a, b) { + return a.a.a.a.cc(b); + } + function qeb(a, b) { + return zhb(a.a, 0, b); + } + function SSb(a) { + return MSb(RD(a, 74)); + } + function Nfb(a) { + return eE((uFb(a), a)); + } + function Ofb(a) { + return eE((uFb(a), a)); + } + function gD(a) { + return hD(a.l, a.m, a.h); + } + function egb(a, b) { + return hgb(a.a, b.a); + } + function ygb(a, b) { + return Agb(a.a, b.a); + } + function Sfb(a, b) { + return Qfb(a.a, b.a); + } + function qhb(a, b) { + return a.indexOf(b); + } + function nOc(a, b) { + return a.j[b.p] == 2; + } + function cz(a, b) { + return a == b ? 0 : a ? 1 : -1; + } + function AB(a) { + return a < 10 ? "0" + a : "" + a; + } + function Kdb(a) { + return typeof a === ive; + } + function oZb(a) { + return a == jZb || a == mZb; + } + function pZb(a) { + return a == jZb || a == kZb; + } + function ELb(a, b) { + return hgb(a.g, b.g); + } + function Q4b(a) { + return Wmb(a.b.b, a, 0); + } + function Q2b() { + J2b.call(this, 0, 0, 0, 0); + } + function Iub() { + ctb.call(this, new gub()); + } + function Znb(a, b) { + Wnb(a, 0, a.length, b); + } + function Eyb(a, b) { + Rmb(a.a, b); + return b; + } + function Fkc(a, b) { + lkc(); + return b.a += a; + } + function Hkc(a, b) { + lkc(); + return b.a += a; + } + function Gkc(a, b) { + lkc(); + return b.c += a; + } + function ied(a, b) { + Rmb(a.c, b); + return a; + } + function Ped(a, b) { + ofd(a.a, b); + return a; + } + function ttb(a) { + this.a = Itb(); + this.b = a; + } + function Ntb(a) { + this.a = Itb(); + this.b = a; + } + function sjd(a) { + this.a = a.a; + this.b = a.b; + } + function Dl(a) { + this.a = a; + zl.call(this); + } + function Gl(a) { + this.a = a; + zl.call(this); + } + function Tid() { + Uid2.call(this, 0, 0, 0, 0); + } + function vfd(a) { + return ofd(new ufd(), a); + } + function Ksd(a) { + return iyd(RD(a, 123)); + } + function Mvd(a) { + return a.vh() && a.wh(); + } + function Dod(a) { + return a != zod && a != Aod; + } + function Dmd(a) { + return a == ymd || a == zmd; + } + function Emd(a) { + return a == Bmd || a == xmd; + } + function xDc(a) { + return a == tDc || a == sDc; + } + function yrc(a, b) { + return hgb(a.g, b.g); + } + function Yfe(a, b) { + return new Phe(b, a); + } + function Zfe(a, b) { + return new Phe(b, a); + } + function lr(a) { + return Dr(a.b.Kc(), a.a); + } + function IXd(a, b) { + yXd(a, b); + zXd(a, a.D); + } + function Uxd(a, b, c2) { + Vxd(a, b); + Wxd(a, c2); + } + function zyd(a, b, c2) { + Cyd(a, b); + Ayd(a, c2); + } + function Byd(a, b, c2) { + Dyd(a, b); + Eyd(a, c2); + } + function Gzd(a, b, c2) { + Hzd(a, b); + Izd(a, c2); + } + function Nzd(a, b, c2) { + Ozd(a, b); + Pzd(a, c2); + } + function eh(a, b, c2) { + bh.call(this, a, b, c2); + } + function zId(a) { + uId.call(this, a, true); + } + function nAb() { + dAb.call(this, "Tail", 3); + } + function iAb() { + dAb.call(this, "Head", 1); + } + function ejb(a) { + Pib(); + fjb.call(this, a); + } + function A3b(a) { + J2b.call(this, a, a, a, a); + } + function Pmb(a) { + a.c = $C(jJ, rve, 1, 0, 5, 1); + } + function yRb(a) { + a.b && CRb(a); + return a.a; + } + function zRb(a) { + a.b && CRb(a); + return a.c; + } + function mBb(a, b) { + if (dBb) { + return; + } + a.b = b; + } + function YCb(a, b) { + return a[a.length] = b; + } + function _Cb(a, b) { + return a[a.length] = b; + } + function l5b(a, b) { + return NGd(b, MCd(a)); + } + function m5b(a, b) { + return NGd(b, MCd(a)); + } + function DDd(a, b) { + return lp(Co(a.d), b); + } + function EDd(a, b) { + return lp(Co(a.g), b); + } + function FDd(a, b) { + return lp(Co(a.j), b); + } + function mGd(a, b) { + kGd.call(this, a.b, b); + } + function s0d(a, b) { + WGd(tYd(a.a), v0d(b)); + } + function B4d(a, b) { + WGd(o4d(a.a), E4d(b)); + } + function Asd(a, b, c2) { + Byd(c2, c2.i + a, c2.j + b); + } + function eFc(a, b, c2) { + bD(a.c[b.g], b.g, c2); + } + function zVd(a, b, c2) { + RD(a.c, 71).Gi(b, c2); + } + function LMd(a, b, c2) { + bD(a, b, c2); + return c2; + } + function DJb(a) { + Umb(a.Sf(), new HJb(a)); + } + function Gvb(a) { + return a != null ? tb(a) : 0; + } + function aOd(a) { + return a == null ? 0 : tb(a); + } + function iue(a) { + Vse(); + Wse.call(this, a); + } + function Ug(a) { + this.a = a; + Og.call(this, a); + } + function Zy() { + Zy = geb; + $wnd.Math.log(2); + } + function s7d() { + s7d = geb; + r7d = ($Sd(), ZSd); + } + function FRc() { + FRc = geb; + ERc = new Zrb(u3); + } + function Hde() { + Hde = geb; + new Ide(); + new bnb(); + } + function Ide() { + new Tsb(); + new Tsb(); + new Tsb(); + } + function yue() { + throw Adb(new kib(bMe)); + } + function Nue() { + throw Adb(new kib(bMe)); + } + function Bue() { + throw Adb(new kib(cMe)); + } + function Que() { + throw Adb(new kib(cMe)); + } + function Gp(a) { + this.a = a; + rf.call(this, a); + } + function Np(a) { + this.a = a; + rf.call(this, a); + } + function Sq(a, b) { + tm(); + this.a = a; + this.b = b; + } + function Jh(a, b) { + Qb(b); + Ih(a).Jc(new jx()); + } + function _mb(a, b) { + Ynb(a.c, a.c.length, b); + } + function xnb(a) { + return a.a < a.c.c.length; + } + function Msb(a) { + return a.a < a.c.a.length; + } + function Wvb(a, b) { + return a.a ? a.b : b.We(); + } + function hgb(a, b) { + return a < b ? -1 : a > b ? 1 : 0; + } + function Kgb(a, b) { + return Ddb(a, b) > 0 ? a : b; + } + function hD(a, b, c2) { + return { l: a, m: b, h: c2 }; + } + function Mvb(a, b) { + a.a != null && _Mc(b, a.a); + } + function Lhc(a) { + Y0b(a, null); + Z0b(a, null); + } + function xkc(a, b, c2) { + return Zjb(a.g, c2, b); + } + function bFc(a, b, c2) { + return _Ec(b, c2, a.c); + } + function jOc(a, b, c2) { + return Zjb(a.k, c2, b); + } + function pOc(a, b, c2) { + qOc(a, b, c2); + return c2; + } + function FOc(a, b) { + dOc(); + return b.n.b += a; + } + function lUb(a) { + VTb.call(this); + this.b = a; + } + function y2b(a) { + v2b.call(this); + this.a = a; + } + function kAb() { + dAb.call(this, "Range", 2); + } + function $Fb(a) { + this.b = a; + this.a = new bnb(); + } + function WQb(a) { + this.b = new gRb(); + this.a = a; + } + function Lub(a) { + a.a = new svb(); + a.c = new svb(); + } + function nrc(a) { + a.a = new Tsb(); + a.d = new Tsb(); + } + function $Sc(a) { + _Sc(a, null); + aTc(a, null); + } + function a2d(a, b) { + return xA(a.a, b, null); + } + function Cdd(a, b) { + return Zjb(a.a, b.a, b); + } + function ajd(a) { + return new rjd(a.a, a.b); + } + function Pid(a) { + return new rjd(a.c, a.d); + } + function Qid(a) { + return new rjd(a.c, a.d); + } + function Ake(a, b) { + return Tfe(a.c, a.b, b); + } + function ZD(a, b) { + return a != null && QD(a, b); + } + function br(a, b) { + return Jr(a.Kc(), b) != -1; + } + function Hr(a) { + return a.Ob() ? a.Pb() : null; + } + function _p(a) { + this.b = (yob(), new uqb(a)); + } + function zke(a) { + this.a = a; + Tsb.call(this); + } + function Uhe() { + Q2d.call(this, null, null); + } + function Yhe() { + p3d.call(this, null, null); + } + function As() { + qs.call(this, "INSTANCE", 0); + } + function dXb() { + _Wb(); + this.a = new Wed(UP); + } + function Hhb(a) { + return Ihb(a, 0, a.length); + } + function Rv(a, b) { + return new ew(a.Kc(), b); + } + function $sb(a, b) { + return a.a.Bc(b) != null; + } + function hZd(a, b) { + sLd(a); + a.Gc(RD(b, 15)); + } + function ONd(a, b, c2) { + a.c.bd(b, RD(c2, 136)); + } + function eOd(a, b, c2) { + a.c.Ui(b, RD(c2, 136)); + } + function eub(a, b) { + if (a.c) { + rub(b); + qub(b); + } + } + function oB(a, b) { + a.q.setHours(b); + mB(a, b); + } + function vTb(a, b) { + Zid(b, a.a.a.a, a.a.a.b); + } + function tKb(a, b, c2, d) { + bD(a.a[b.g], c2.g, d); + } + function oKb(a, b, c2) { + return a.a[b.g][c2.g]; + } + function AIc(a, b) { + return a.e[b.c.p][b.p]; + } + function TIc(a, b) { + return a.c[b.c.p][b.p]; + } + function pJc(a, b) { + return a.a[b.c.p][b.p]; + } + function mOc(a, b) { + return a.j[b.p] = AOc(b); + } + function wAb(a, b) { + return a.a.Bc(b) != null; + } + function wXc(a, b) { + return Kfb(UD(b.a)) <= a; + } + function xXc(a, b) { + return Kfb(UD(b.a)) >= a; + } + function vhd(a, b) { + return jhb(a.f, b.Pg()); + } + function cjd(a, b) { + return a.a * b.a + a.b * b.b; + } + function Wsd(a, b) { + return a.a < Qeb(b) ? -1 : 1; + } + function gGd(a, b) { + return jhb(a.b, b.Pg()); + } + function xIc(a, b, c2) { + return c2 ? b != 0 : b != a - 1; + } + function Mwb(a, b, c2) { + a.a = b ^ 1502; + a.b = c2 ^ Mxe; + } + function ljd(a, b, c2) { + a.a = b; + a.b = c2; + return a; + } + function ijd(a, b) { + a.a *= b; + a.b *= b; + return a; + } + function Rmb(a, b) { + ZEb(a.c, b); + return true; + } + function MHd(a, b, c2) { + bD(a.g, b, c2); + return c2; + } + function XZd(a, b, c2) { + PZd.call(this, a, b, c2); + } + function _Zd(a, b, c2) { + XZd.call(this, a, b, c2); + } + function aie(a, b, c2) { + Kfe.call(this, a, b, c2); + } + function eie(a, b, c2) { + Kfe.call(this, a, b, c2); + } + function gie(a, b, c2) { + aie.call(this, a, b, c2); + } + function iie(a, b, c2) { + XZd.call(this, a, b, c2); + } + function lie(a, b, c2) { + _Zd.call(this, a, b, c2); + } + function vie(a, b, c2) { + PZd.call(this, a, b, c2); + } + function zie(a, b, c2) { + PZd.call(this, a, b, c2); + } + function Cie(a, b, c2) { + vie.call(this, a, b, c2); + } + function ez(a) { + a.j = $C(mJ, Nve, 319, 0, 0, 1); + } + function wmb() { + this.a = $C(jJ, rve, 1, 8, 5, 1); + } + function dWd() { + this.Bb |= 256; + this.Bb |= 512; + } + function dMd(a) { + this.i = a; + this.f = this.i.j; + } + function Rue(a) { + this.c = a; + this.a = this.c.a; + } + function zf(a, b) { + this.a = a; + rf.call(this, b); + } + function Eb(a, b) { + return Db(a, new bib(), b).a; + } + function Lb(a) { + if (!a) { + throw Adb(new _fb()); + } + } + function Ub(a) { + if (!a) { + throw Adb(new cgb()); + } + } + function Txb() { + Txb = geb; + Txb(); + Sxb = new $xb(); + } + function fke() { + fke = geb; + Gie(); + eke = new gke(); + } + function Kvb() { + Kvb = geb; + Jvb = new Ovb(null); + } + function OGd(a) { + Ivb(a, IIe); + pzd(a, GGd(a)); + } + function mNd(a) { + a.a = RD(Ywd(a.b.a, 4), 129); + } + function uNd(a) { + a.a = RD(Ywd(a.b.a, 4), 129); + } + function Mg(a) { + a.b.Qb(); + --a.d.f.d; + jg(a.d); + } + function Zj(a) { + this.a = a; + Aj.call(this, a.d); + } + function ij(a, b) { + this.a = a; + pc.call(this, b); + } + function sj(a, b) { + this.a = a; + pc.call(this, b); + } + function Rj(a, b) { + this.a = a; + pc.call(this, b); + } + function Il(a, b) { + this.a = b; + pc.call(this, a); + } + function ap(a, b) { + this.a = b; + Xo.call(this, a); + } + function Ap(a, b) { + this.a = a; + Xo.call(this, b); + } + function Yr(a, b) { + this.a = b; + Tr.call(this, a); + } + function ew(a, b) { + this.a = b; + Tr.call(this, a); + } + function Mr(a, b) { + Qb(b); + return new Yr(a, b); + } + function ru(a, b) { + return new Ou(a.a, a.b, b); + } + function rhb(a, b, c2) { + return a.indexOf(b, c2); + } + function thb(a, b) { + return a.lastIndexOf(b); + } + function Ghb(a) { + return a == null ? vve : jeb(a); + } + function Ez(a) { + return a == null ? null : a.name; + } + function qD(a) { + return a.l + a.m * gxe + a.h * hxe; + } + function Gr(a) { + return dvb(a.a) ? Fr(a) : null; + } + function Shb(a) { + reb.call(this, (uFb(a), a)); + } + function dib(a) { + reb.call(this, (uFb(a), a)); + } + function dl(a) { + Qk.call(this, RD(Qb(a), 34)); + } + function tl(a) { + Qk.call(this, RD(Qb(a), 34)); + } + function Jub(a) { + ctb.call(this, new hub(a)); + } + function Upb(a) { + xpb.call(this, a); + this.a = a; + } + function hqb(a) { + Ppb.call(this, a); + this.a = a; + } + function jrb(a) { + Lqb.call(this, a); + this.a = a; + } + function mz() { + ez(this); + gz(this); + this.je(); + } + function Dzb(a) { + this.a = a; + Plb.call(this, a); + } + function Lvb(a) { + sFb(a.a != null); + return a.a; + } + function gGb(a, b) { + Rmb(b.a, a.a); + return a.a; + } + function mGb(a, b) { + Rmb(b.b, a.a); + return a.a; + } + function eJb(a, b) { + Rmb(b.a, a.a); + return a.a; + } + function aib(a, b, c2) { + peb(a, b, b, c2); + return a; + } + function EIb(a, b) { + ++a.b; + return Rmb(a.a, b); + } + function FIb(a, b) { + ++a.b; + return Ymb(a.a, b); + } + function NNb(a, b) { + return Qfb(a.c.d, b.c.d); + } + function ZNb(a, b) { + return Qfb(a.c.c, b.c.c); + } + function E9b(a, b) { + return Qfb(a.n.a, b.n.a); + } + function B$b(a, b) { + return RD(Qc(a.b, b), 15); + } + function Jac(a, b) { + return a.n.b = (uFb(b), b); + } + function Kac(a, b) { + return a.n.b = (uFb(b), b); + } + function Csb(a, b) { + return !!b && a.b[b.g] == b; + } + function k4b(a) { + return xnb(a.a) || xnb(a.b); + } + function kFb(a) { + return a.$H || (a.$H = ++iFb); + } + function Nvb(a) { + return a.a != null ? a.a : null; + } + function uXc(a, b) { + return Qfb(a.e.b, b.e.b); + } + function CXc(a, b) { + return Qfb(a.e.a, b.e.a); + } + function ZEc(a, b, c2) { + return $Ec(a, b, c2, a.b); + } + function aFc(a, b, c2) { + return $Ec(a, b, c2, a.c); + } + function Ikc(a) { + lkc(); + return !!a && !a.dc(); + } + function Yjc() { + Wjc(); + this.b = new ckc(this); + } + function tNb() { + tNb = geb; + sNb = new kGd(Xye, 0); + } + function Geb() { + Geb = geb; + Eeb = false; + Feb = true; + } + function E8b(a) { + var b; + b = a.a; + a.a = a.b; + a.b = b; + } + function Q2d(a, b) { + N2d(); + this.a = a; + this.b = b; + } + function p3d(a, b) { + j3d(); + this.b = a; + this.c = b; + } + function Fud(a, b) { + nud(); + this.f = b; + this.d = a; + } + function qc(a, b) { + Sb(b, a); + this.d = a; + this.c = b; + } + function IXb(a, b) { + JXb.call(this, a, b, null); + } + function Kg(a, b, c2, d) { + yg.call(this, a, b, c2, d); + } + function mMd(a) { + this.d = a; + dMd.call(this, a); + } + function yMd(a) { + this.c = a; + dMd.call(this, a); + } + function BMd(a) { + this.c = a; + mMd.call(this, a); + } + function Zse(a) { + return new Kte(3, a); + } + function ev(a) { + dk(a, iwe); + return new cnb(a); + } + function jA(a) { + fA(); + return parseInt(a) || -1; + } + function Fs(a) { + zs(); + return ws((Is(), Hs), a); + } + function phb(a, b, c2) { + return rhb(a, Fhb(b), c2); + } + function um(a, b) { + return new fq(a, a.gc(), b); + } + function zj(a, b) { + return hn(a.c).Md().Xb(b); + } + function hu(a, b, c2) { + var d; + d = a.fd(b); + d.Rb(c2); + } + function tfd(a, b, c2) { + RD(Med(a, b), 21).Fc(c2); + } + function XOd(a, b, c2) { + VNd(a.a, c2); + UNd(a.a, b); + } + function aAd(a) { + ZD(a, 158) && RD(a, 158).pi(); + } + function tub(a) { + uub.call(this, a, null, null); + } + function Yvb(a) { + Tvb(); + this.b = a; + this.a = true; + } + function ewb(a) { + bwb(); + this.b = a; + this.a = true; + } + function Qub(a) { + sFb(a.b != 0); + return a.a.a.c; + } + function Rub(a) { + sFb(a.b != 0); + return a.c.b.c; + } + function Phb(a, b) { + peb(a, b, b + 1, ""); + return a; + } + function nQb(a, b) { + return !!a.q && Ujb(a.q, b); + } + function vzb(a) { + return a.b = RD(Bkb(a.a), 44); + } + function os(a) { + return a.f != null ? a.f : "" + a.g; + } + function ps(a) { + return a.f != null ? a.f : "" + a.g; + } + function yUb(a, b) { + return a > 0 ? b / (a * a) : b * 100; + } + function FUb(a, b) { + return a > 0 ? b * b / a : b * b * 100; + } + function $5b(a, b) { + return RD(cub(a.a, b), 34); + } + function doc(a, b) { + Mnc(); + return Rc(a, b.e, b); + } + function NCc(a, b, c2) { + GCc(); + return c2.Mg(a, b); + } + function L0c(a) { + B0c(); + return a.e.a + a.f.a / 2; + } + function N0c(a, b, c2) { + B0c(); + return c2.e.a - a * b; + } + function V0c(a) { + B0c(); + return a.e.b + a.f.b / 2; + } + function X0c(a, b, c2) { + B0c(); + return c2.e.b - a * b; + } + function _tb(a) { + a.d = new tub(a); + a.e = new Tsb(); + } + function x3c() { + this.a = new Tp(); + this.b = new Tp(); + } + function hmc(a) { + this.c = a; + this.a = 1; + this.b = 1; + } + function C$b(a) { + z$b(); + A$b(this); + this.Ff(a); + } + function Efd(a, b, c2) { + Afd(); + a.pf(b) && c2.Cd(a); + } + function Red(a, b, c2) { + return Rmb(b, Ted(a, c2)); + } + function Zid(a, b, c2) { + a.a += b; + a.b += c2; + return a; + } + function jjd(a, b, c2) { + a.a *= b; + a.b *= c2; + return a; + } + function mjd(a, b) { + a.a = b.a; + a.b = b.b; + return a; + } + function fjd(a) { + a.a = -a.a; + a.b = -a.b; + return a; + } + function njd(a, b, c2) { + a.a -= b; + a.b -= c2; + return a; + } + function Gjd(a) { + Yub.call(this); + zjd(this, a); + } + function Dbd() { + qs.call(this, "GROW_TREE", 0); + } + function WRb() { + qs.call(this, "POLYOMINO", 0); + } + function SVd(a, b, c2) { + DVd.call(this, a, b, c2, 2); + } + function r0d(a, b, c2) { + VGd(tYd(a.a), b, v0d(c2)); + } + function e3d(a, b) { + N2d(); + Q2d.call(this, a, b); + } + function D3d(a, b) { + j3d(); + p3d.call(this, a, b); + } + function F3d(a, b) { + j3d(); + D3d.call(this, a, b); + } + function H3d(a, b) { + j3d(); + p3d.call(this, a, b); + } + function PNd(a, b) { + return a.c.Fc(RD(b, 136)); + } + function A4d(a, b, c2) { + VGd(o4d(a.a), b, E4d(c2)); + } + function Ard(a) { + this.c = a; + Dyd(a, 0); + Eyd(a, 0); + } + function Z8d(a, b) { + s7d(); + N8d.call(this, a, b); + } + function _8d(a, b) { + s7d(); + Z8d.call(this, a, b); + } + function b9d(a, b) { + s7d(); + Z8d.call(this, a, b); + } + function n9d(a, b) { + s7d(); + N8d.call(this, a, b); + } + function d9d(a, b) { + s7d(); + b9d.call(this, a, b); + } + function p9d(a, b) { + s7d(); + n9d.call(this, a, b); + } + function v9d(a, b) { + s7d(); + N8d.call(this, a, b); + } + function lge(a, b, c2) { + return b.zl(a.e, a.c, c2); + } + function nge(a, b, c2) { + return b.Al(a.e, a.c, c2); + } + function Wee(a, b, c2) { + return tfe(Pee(a, b), c2); + } + function Age(a, b) { + return Vvd(a.e, RD(b, 54)); + } + function _me(a) { + return a == null ? null : Bqe(a); + } + function dne(a) { + return a == null ? null : Iqe(a); + } + function gne(a) { + return a == null ? null : jeb(a); + } + function hne(a) { + return a == null ? null : jeb(a); + } + function TD(a) { + CFb(a == null || $D(a)); + return a; + } + function UD(a) { + CFb(a == null || _D(a)); + return a; + } + function WD(a) { + CFb(a == null || bE(a)); + return a; + } + function lfb(a) { + if (a.o != null) { + return; + } + Bfb(a); + } + function lFb(a) { + if (!a) { + throw Adb(new _fb()); + } + } + function pFb(a) { + if (!a) { + throw Adb(new yeb()); + } + } + function sFb(a) { + if (!a) { + throw Adb(new Dvb()); + } + } + function yFb(a) { + if (!a) { + throw Adb(new cgb()); + } + } + function zmb(a) { + if (!a) { + throw Adb(new Jrb()); + } + } + function jQd() { + jQd = geb; + iQd = new LQd(); + new lRd(); + } + function u2c() { + u2c = geb; + t2c = new jGd("root"); + } + function d6d() { + HWd.call(this); + this.Bb |= txe; + } + function Pg(a, b) { + this.d = a; + Lg(this); + this.b = b; + } + function WCb(a, b) { + NCb.call(this, a); + this.a = b; + } + function oDb(a, b) { + NCb.call(this, a); + this.a = b; + } + function bh(a, b, c2) { + lg.call(this, a, b, c2, null); + } + function fh(a, b, c2) { + lg.call(this, a, b, c2, null); + } + function Mf(a, b) { + this.c = a; + ne.call(this, a, b); + } + function Uf(a, b) { + this.a = a; + Mf.call(this, a, b); + } + function wB(a) { + this.q = new $wnd.Date(Xdb(a)); + } + function OPb(a) { + if (a > 8) { + return 0; + } + return a + 1; + } + function iBb(a, b) { + if (dBb) { + return; + } + Rmb(a.a, b); + } + function P5b(a, b) { + H5b(); + return n2b(b.d.i, a); + } + function qdc(a, b) { + Zcc(); + return new xdc(b, a); + } + function HAb(a, b, c2) { + return a.Ne(b, c2) <= 0 ? c2 : b; + } + function IAb(a, b, c2) { + return a.Ne(b, c2) <= 0 ? b : c2; + } + function rgd(a, b) { + return RD(cub(a.b, b), 143); + } + function tgd(a, b) { + return RD(cub(a.c, b), 233); + } + function amc(a) { + return RD(Vmb(a.a, a.b), 294); + } + function Mid(a) { + return new rjd(a.c, a.d + a.a); + } + function Jeb(a) { + return (uFb(a), a) ? 1231 : 1237; + } + function EPc(a) { + return dOc(), xDc(RD(a, 203)); + } + function RMb() { + RMb = geb; + QMb = xsb((Qpd(), Ppd)); + } + function YQb(a, b) { + b.a ? ZQb(a, b) : wAb(a.a, b.b); + } + function aJd(a, b, c2) { + ++a.j; + a.tj(); + $Gd(a, b, c2); + } + function $Id(a, b, c2) { + ++a.j; + a.qj(b, a.Zi(b, c2)); + } + function B2d(a, b, c2) { + var d; + d = a.fd(b); + d.Rb(c2); + } + function Bzd(a, b, c2) { + c2 = xvd(a, b, 6, c2); + return c2; + } + function izd(a, b, c2) { + c2 = xvd(a, b, 3, c2); + return c2; + } + function KCd(a, b, c2) { + c2 = xvd(a, b, 9, c2); + return c2; + } + function SKb(a, b) { + Ivb(b, Pye); + a.f = b; + return a; + } + function bOd(a, b) { + return (b & lve) % a.d.length; + } + function Bke(a, b, c2) { + return age(a.c, a.b, b, c2); + } + function ZLd(a, b) { + this.c = a; + ZHd.call(this, b); + } + function w0d(a, b) { + this.a = a; + Q_d.call(this, b); + } + function F4d(a, b) { + this.a = a; + Q_d.call(this, b); + } + function kGd(a, b) { + jGd.call(this, a); + this.a = b; + } + function U6d(a, b) { + L6d.call(this, a); + this.a = b; + } + function S9d(a, b) { + L6d.call(this, a); + this.a = b; + } + function jQb(a) { + gQb.call(this, 0, 0); + this.f = a; + } + function _hb(a, b, c2) { + a.a += Ihb(b, 0, c2); + return a; + } + function _A(a) { + !a.a && (a.a = new jB()); + return a.a; + } + function qlb(a, b) { + var c2; + c2 = a.e; + a.e = b; + return c2; + } + function Clb(a, b) { + var c2; + c2 = b; + return !!a.Fe(c2); + } + function Keb(a, b) { + Geb(); + return a == b ? 0 : a ? 1 : -1; + } + function Ikb(a, b) { + a.a.bd(a.b, b); + ++a.b; + a.c = -1; + } + function hg(a) { + a.b ? hg(a.b) : a.f.c.zc(a.e, a.d); + } + function aub(a) { + akb(a.e); + a.d.b = a.d; + a.d.a = a.d; + } + function VDb(a, b, c2) { + xDb(); + HEb(a, b.Ve(a.a, c2)); + } + function Xrb(a, b, c2) { + return Wrb(a, RD(b, 22), c2); + } + function WEb(a, b) { + return cFb(new Array(b), a); + } + function Fgb(a) { + return Ydb(Udb(a, 32)) ^ Ydb(a); + } + function XD(a) { + return String.fromCharCode(a); + } + function Dz(a) { + return a == null ? null : a.message; + } + function Rz(a, b, c2) { + return a.apply(b, c2); + } + function Btb(a, b) { + var c2; + c2 = a[Jxe]; + c2.call(a, b); + } + function Ctb(a, b) { + var c2; + c2 = a[Jxe]; + c2.call(a, b); + } + function O5b(a, b) { + H5b(); + return !n2b(b.d.i, a); + } + function R2b(a, b, c2, d) { + J2b.call(this, a, b, c2, d); + } + function TJb() { + RJb.call(this); + this.a = new pjd(); + } + function v2b() { + this.n = new pjd(); + this.o = new pjd(); + } + function kGb() { + this.b = new pjd(); + this.c = new bnb(); + } + function cUb() { + this.a = new bnb(); + this.b = new bnb(); + } + function kWb() { + this.a = new DTb(); + this.b = new vWb(); + } + function e6b() { + this.b = new gub(); + this.a = new gub(); + } + function jIc() { + this.b = new _sb(); + this.a = new _sb(); + } + function vYc() { + this.b = new Tsb(); + this.a = new Tsb(); + } + function fWc() { + this.b = new TVc(); + this.a = new IVc(); + } + function Yhc() { + this.a = new yqc(); + this.b = new Sqc(); + } + function lNc() { + this.a = new bnb(); + this.d = new bnb(); + } + function RJb() { + this.n = new z3b(); + this.i = new Tid(); + } + function hq(a) { + this.a = (dk(a, iwe), new cnb(a)); + } + function oq(a) { + this.a = (dk(a, iwe), new cnb(a)); + } + function tLd(a) { + return a < 100 ? null : new gLd(a); + } + function Lac(a, b) { + return a.n.a = (uFb(b), b) + 10; + } + function Mac(a, b) { + return a.n.a = (uFb(b), b) + 10; + } + function DYd(a, b) { + return b == a || PHd(sYd(b), a); + } + function nae(a, b) { + return Zjb(a.a, b, "") == null; + } + function Hee(a, b) { + var c2; + c2 = b.qi(a.a); + return c2; + } + function $id(a, b) { + a.a += b.a; + a.b += b.b; + return a; + } + function ojd(a, b) { + a.a -= b.a; + a.b -= b.b; + return a; + } + function sfd(a) { + aFb(a.j.c, 0); + a.a = -1; + return a; + } + function rCd(a, b, c2) { + c2 = xvd(a, b, 11, c2); + return c2; + } + function SDd(a, b, c2) { + c2 != null && Kzd(b, uEd(a, c2)); + } + function TDd(a, b, c2) { + c2 != null && Lzd(b, uEd(a, c2)); + } + function G5d(a, b, c2, d) { + C5d.call(this, a, b, c2, d); + } + function oie(a, b, c2, d) { + C5d.call(this, a, b, c2, d); + } + function sie(a, b, c2, d) { + oie.call(this, a, b, c2, d); + } + function Nie(a, b, c2, d) { + Iie.call(this, a, b, c2, d); + } + function Pie(a, b, c2, d) { + Iie.call(this, a, b, c2, d); + } + function Vie(a, b, c2, d) { + Iie.call(this, a, b, c2, d); + } + function Tie(a, b, c2, d) { + Pie.call(this, a, b, c2, d); + } + function $ie(a, b, c2, d) { + Pie.call(this, a, b, c2, d); + } + function Yie(a, b, c2, d) { + Vie.call(this, a, b, c2, d); + } + function bje(a, b, c2, d) { + $ie.call(this, a, b, c2, d); + } + function Dje(a, b, c2, d) { + wje.call(this, a, b, c2, d); + } + function aMd(a, b) { + veb.call(this, HJe + a + NIe + b); + } + function Hje(a, b) { + return a.jk().wi().ri(a, b); + } + function Ije(a, b) { + return a.jk().wi().ti(a, b); + } + function Lfb(a, b) { + return uFb(a), dE(a) === dE(b); + } + function lhb(a, b) { + return uFb(a), dE(a) === dE(b); + } + function mEb(a, b) { + return a.b.Bd(new pEb(a, b)); + } + function sEb(a, b) { + return a.b.Bd(new vEb(a, b)); + } + function yEb(a, b) { + return a.b.Bd(new BEb(a, b)); + } + function Bk(a, b) { + return a.e = RD(a.d.Kb(b), 159); + } + function uhb(a, b, c2) { + return a.lastIndexOf(b, c2); + } + function wWb(a, b, c2) { + return Qfb(a[b.a], a[c2.a]); + } + function TWb(a, b) { + return pQb(b, (yCc(), gAc), a); + } + function Lpc(a, b) { + return hgb(b.a.d.p, a.a.d.p); + } + function Kpc(a, b) { + return hgb(a.a.d.p, b.a.d.p); + } + function zTc(a, b) { + return Qfb(a.c - a.s, b.c - b.s); + } + function qWc(a, b) { + return Qfb(a.b.e.a, b.b.e.a); + } + function sWc(a, b) { + return Qfb(a.c.e.a, b.c.e.a); + } + function $2b(a) { + return !a.c ? -1 : Wmb(a.c.a, a, 0); + } + function Cod(a) { + return a == vod || a == xod || a == wod; + } + function CMd(a, b) { + this.c = a; + nMd.call(this, a, b); + } + function fq(a, b, c2) { + this.a = a; + qc.call(this, b, c2); + } + function YDb(a) { + this.c = a; + xxb.call(this, Sve, 0); + } + function rk(a, b, c2) { + this.c = b; + this.b = c2; + this.a = a; + } + function DMc(a) { + dMc(); + this.d = a; + this.a = new wmb(); + } + function ho(a) { + _l(); + this.a = (yob(), new Lqb(a)); + } + function Xmc(a, b) { + Dmd(a.f) ? Ymc(a, b) : Zmc(a, b); + } + function Lxb(a, b) { + Mxb.call(this, a, a.length, b); + } + function nBb(a, b) { + if (dBb) { + return; + } + !!b && (a.d = b); + } + function ZNd(a, b) { + return ZD(b, 15) && _Gd(a.c, b); + } + function AVd(a, b, c2) { + return RD(a.c, 71).Wk(b, c2); + } + function BVd(a, b, c2) { + return RD(a.c, 71).Xk(b, c2); + } + function mge(a, b, c2) { + return lge(a, RD(b, 343), c2); + } + function oge(a, b, c2) { + return nge(a, RD(b, 343), c2); + } + function Ige(a, b, c2) { + return Hge(a, RD(b, 343), c2); + } + function Kge(a, b, c2) { + return Jge(a, RD(b, 343), c2); + } + function Fn(a, b) { + return b == null ? null : Xv(a.b, b); + } + function Qeb(a) { + return _D(a) ? (uFb(a), a) : a.ue(); + } + function Rfb(a) { + return !isNaN(a) && !isFinite(a); + } + function Zub(a) { + Lub(this); + Xub(this); + ye(this, a); + } + function dnb(a) { + Pmb(this); + YEb(this.c, 0, a.Pc()); + } + function Fsb(a, b, c2) { + this.a = a; + this.b = b; + this.c = c2; + } + function Vtb(a, b, c2) { + this.a = a; + this.b = b; + this.c = c2; + } + function hvb(a, b, c2) { + this.d = a; + this.b = c2; + this.a = b; + } + function aBb(a) { + this.a = a; + gib(); + Hdb(Date.now()); + } + function wzb(a) { + Ckb(a.a); + Yyb(a.c, a.b); + a.b = null; + } + function wvb() { + wvb = geb; + uvb = new xvb(); + vvb = new zvb(); + } + function KMd() { + KMd = geb; + JMd = $C(jJ, rve, 1, 0, 5, 1); + } + function TTd() { + TTd = geb; + STd = $C(jJ, rve, 1, 0, 5, 1); + } + function yUd() { + yUd = geb; + xUd = $C(jJ, rve, 1, 0, 5, 1); + } + function _l() { + _l = geb; + new im((yob(), yob(), vob)); + } + function gAb(a) { + cAb(); + return ws((qAb(), pAb), a); + } + function zBb(a) { + xBb(); + return ws((CBb(), BBb), a); + } + function FHb(a) { + DHb(); + return ws((IHb(), HHb), a); + } + function NHb(a) { + LHb(); + return ws((QHb(), PHb), a); + } + function kIb(a) { + iIb(); + return ws((nIb(), mIb), a); + } + function _Jb(a) { + ZJb(); + return ws((cKb(), bKb), a); + } + function GKb(a) { + EKb(); + return ws((JKb(), IKb), a); + } + function xLb(a) { + vLb(); + return ws((ALb(), zLb), a); + } + function mMb(a) { + hMb(); + return ws((pMb(), oMb), a); + } + function oOb(a) { + mOb(); + return ws((rOb(), qOb), a); + } + function KPb(a) { + IPb(); + return ws((NPb(), MPb), a); + } + function KRb(a) { + IRb(); + return ws((NRb(), MRb), a); + } + function XRb(a) { + VRb(); + return ws(($Rb(), ZRb), a); + } + function VUb(a) { + TUb(); + return ws((YUb(), XUb), a); + } + function CWb(a) { + AWb(); + return ws((FWb(), EWb), a); + } + function uXb(a) { + sXb(); + return ws((xXb(), wXb), a); + } + function tZb(a) { + nZb(); + return ws((wZb(), vZb), a); + } + function W$b(a) { + U$b(); + return ws((Z$b(), Y$b), a); + } + function Mb(a, b) { + if (!a) { + throw Adb(new agb(b)); + } + } + function Vb(a) { + if (!a) { + throw Adb(new dgb(tve)); + } + } + function rFb(a, b) { + if (a != b) { + throw Adb(new Jrb()); + } + } + function KQb(a, b, c2) { + this.a = a; + this.b = b; + this.c = c2; + } + function lRb(a, b, c2) { + this.a = a; + this.b = b; + this.c = c2; + } + function h7b(a, b, c2) { + this.a = a; + this.b = b; + this.c = c2; + } + function J0b(a, b, c2) { + this.b = a; + this.a = b; + this.c = c2; + } + function dNb(a, b, c2) { + this.b = a; + this.c = b; + this.a = c2; + } + function oac(a, b, c2) { + this.a = a; + this.b = b; + this.c = c2; + } + function F1b(a, b, c2) { + this.e = b; + this.b = a; + this.d = c2; + } + function Ecc(a, b, c2) { + this.b = a; + this.a = b; + this.c = c2; + } + function UDb(a, b, c2) { + xDb(); + a.a.Yd(b, c2); + return b; + } + function CJb(a) { + var b; + b = new BJb(); + b.e = a; + return b; + } + function _Nb(a) { + var b; + b = new YNb(); + b.b = a; + return b; + } + function U9b() { + U9b = geb; + S9b = new bac(); + T9b = new eac(); + } + function Rec() { + Rec = geb; + Qec = new efc(); + Pec = new jfc(); + } + function lkc() { + lkc = geb; + jkc = new Mkc(); + kkc = new Okc(); + } + function loc(a) { + joc(); + return ws((ooc(), noc), a); + } + function kcc(a) { + hcc(); + return ws((ncc(), mcc), a); + } + function yec(a) { + vec(); + return ws((Bec(), Aec), a); + } + function gnc(a) { + enc(); + return ws((jnc(), inc), a); + } + function Enc(a) { + Bnc(); + return ws((Hnc(), Gnc), a); + } + function gpc(a) { + epc(); + return ws((jpc(), ipc), a); + } + function dtc(a) { + btc(); + return ws((gtc(), ftc), a); + } + function ltc(a) { + jtc(); + return ws((otc(), ntc), a); + } + function xtc(a) { + stc(); + return ws((Atc(), ztc), a); + } + function Gtc(a) { + Etc(); + return ws((Jtc(), Itc), a); + } + function Utc(a) { + Ptc(); + return ws((Xtc(), Wtc), a); + } + function auc(a) { + $tc(); + return ws((duc(), cuc), a); + } + function avc(a) { + $uc(); + return ws((dvc(), cvc), a); + } + function qvc(a) { + ovc(); + return ws((tvc(), svc), a); + } + function zvc(a) { + xvc(); + return ws((Cvc(), Bvc), a); + } + function Ivc(a) { + Gvc(); + return ws((Lvc(), Kvc), a); + } + function Qvc(a) { + Ovc(); + return ws((Tvc(), Svc), a); + } + function Quc(a) { + Ouc(); + return ws((Tuc(), Suc), a); + } + function juc(a) { + huc(); + return ws((muc(), luc), a); + } + function wuc(a) { + tuc(); + return ws((zuc(), yuc), a); + } + function Euc(a) { + Cuc(); + return ws((Huc(), Guc), a); + } + function exc(a) { + cxc(); + return ws((hxc(), gxc), a); + } + function eDc(a) { + _Cc(); + return ws((hDc(), gDc), a); + } + function oDc(a) { + lDc(); + return ws((rDc(), qDc), a); + } + function ADc(a) { + wDc(); + return ws((DDc(), CDc), a); + } + function ODc(a) { + JDc(); + return ws((RDc(), QDc), a); + } + function cEc(a) { + aEc(); + return ws((fEc(), eEc), a); + } + function mEc(a) { + kEc(); + return ws((pEc(), oEc), a); + } + function uEc(a) { + sEc(); + return ws((xEc(), wEc), a); + } + function DEc(a) { + BEc(); + return ws((GEc(), FEc), a); + } + function MEc(a) { + KEc(); + return ws((PEc(), OEc), a); + } + function VEc(a) { + TEc(); + return ws((YEc(), XEc), a); + } + function nFc(a) { + lFc(); + return ws((qFc(), pFc), a); + } + function wFc(a) { + uFc(); + return ws((zFc(), yFc), a); + } + function FFc(a) { + DFc(); + return ws((IFc(), HFc), a); + } + function TKc(a) { + RKc(); + return ws((WKc(), VKc), a); + } + function uNc(a) { + sNc(); + return ws((xNc(), wNc), a); + } + function yQc(a) { + wQc(); + return ws((BQc(), AQc), a); + } + function GQc(a) { + EQc(); + return ws((JQc(), IQc), a); + } + function hTc(a) { + fTc(); + return ws((kTc(), jTc), a); + } + function fVc(a) { + dVc(); + return ws((iVc(), hVc), a); + } + function bWc(a) { + YVc(); + return ws((eWc(), dWc), a); + } + function ZYc(a) { + WYc(); + return ws((aZc(), _Yc), a); + } + function NZc(a) { + LZc(); + return ws((QZc(), PZc), a); + } + function u_c(a) { + s_c(); + return ws((x_c(), w_c), a); + } + function C_c(a) { + A_c(); + return ws((F_c(), E_c), a); + } + function C2c(a) { + x2c(); + return ws((F2c(), E2c), a); + } + function j3c(a) { + g3c(); + return ws((m3c(), l3c), a); + } + function j4c(a) { + g4c(); + return ws((m4c(), l4c), a); + } + function _3c(a) { + Y3c(); + return ws((c4c(), b4c), a); + } + function m5c(a) { + j5c(); + return ws((p5c(), o5c), a); + } + function w5c(a) { + t5c(); + return ws((z5c(), y5c), a); + } + function h6c(a) { + f6c(); + return ws((k6c(), j6c), a); + } + function C6c(a) { + z6c(); + return ws((F6c(), E6c), a); + } + function b7c(a) { + _6c(); + return ws((e7c(), d7c), a); + } + function E8c(a) { + z8c(); + return ws((H8c(), G8c), a); + } + function R8b(a) { + P8b(); + return ws((U8b(), T8b), a); + } + function t3b(a) { + r3b(); + return ws((w3b(), v3b), a); + } + function g9c(a) { + b9c(); + return ws((j9c(), i9c), a); + } + function G9c(a) { + B9c(); + return ws((J9c(), I9c), a); + } + function uad(a) { + sad(); + return ws((xad(), wad), a); + } + function xbd(a) { + sbd(); + return ws((Abd(), zbd), a); + } + function ibd(a) { + gbd(); + return ws((lbd(), kbd), a); + } + function Gbd(a) { + Cbd(); + return ws((Jbd(), Ibd), a); + } + function Obd(a) { + Mbd(); + return ws((Rbd(), Qbd), a); + } + function Zbd(a) { + Xbd(); + return ws((acd(), _bd), a); + } + function fdd(a) { + _cd(); + return ws((idd(), hdd), a); + } + function qdd(a) { + ldd(); + return ws((tdd(), sdd), a); + } + function $hd(a) { + Yhd(); + return ws((bid(), aid), a); + } + function mid(a) { + kid(); + return ws((pid(), oid), a); + } + function Tjd(a) { + Rjd(); + return ws((Wjd(), Vjd), a); + } + function wkd(a) { + ukd(); + return ws((zkd(), ykd), a); + } + function Hmd(a) { + Cmd(); + return ws((Kmd(), Jmd), a); + } + function Qmd(a) { + Omd(); + return ws((Tmd(), Smd), a); + } + function $md(a) { + Ymd(); + return ws((bnd(), and), a); + } + function knd(a) { + ind(); + return ws((nnd(), mnd), a); + } + function Hnd(a) { + Fnd(); + return ws((Knd(), Jnd), a); + } + function Snd(a) { + Pnd(); + return ws((Vnd(), Und), a); + } + function god(a) { + dod(); + return ws((jod(), iod), a); + } + function rod(a) { + pod(); + return ws((uod(), tod), a); + } + function Fod(a) { + Bod(); + return ws((Iod(), Hod), a); + } + function Tod(a) { + Pod(); + return ws((Wod(), Vod), a); + } + function wpd(a) { + qpd(); + return ws((zpd(), ypd), a); + } + function Spd(a) { + Qpd(); + return ws((Vpd(), Upd), a); + } + function fqd(a) { + dqd(); + return ws((iqd(), hqd), a); + } + function oqd(a) { + mqd(); + return ws((rqd(), qqd), a); + } + function zsc(a, b) { + return (uFb(a), a) + (uFb(b), b); + } + function wqd(a) { + uqd(); + return ws((Eqd(), Dqd), a); + } + function Ird(a) { + Grd(); + return ws((Lrd(), Krd), a); + } + function vtd(a) { + ttd(); + return ws((ytd(), xtd), a); + } + function dMc() { + dMc = geb; + bMc = (qpd(), ppd); + cMc = Xod; + } + function uqd() { + uqd = geb; + sqd = new zqd(); + tqd = new Bqd(); + } + function wJc(a) { + !a.e && (a.e = new bnb()); + return a.e; + } + function BTc(a, b) { + this.c = a; + this.a = b; + this.b = b - a; + } + function g8c(a, b, c2) { + this.a = a; + this.b = b; + this.c = c2; + } + function gud(a, b, c2) { + this.a = a; + this.b = b; + this.c = c2; + } + function Wdd(a, b, c2) { + this.a = a; + this.b = b; + this.c = c2; + } + function ced(a, b, c2) { + this.a = a; + this.b = b; + this.c = c2; + } + function pFd(a, b, c2) { + this.a = a; + this.b = b; + this.c = c2; + } + function ZPd(a, b, c2) { + this.a = a; + this.b = b; + this.c = c2; + } + function g7d(a, b, c2) { + this.e = a; + this.a = b; + this.c = c2; + } + function K7d(a, b, c2) { + s7d(); + C7d.call(this, a, b, c2); + } + function f9d(a, b, c2) { + s7d(); + O8d.call(this, a, b, c2); + } + function r9d(a, b, c2) { + s7d(); + O8d.call(this, a, b, c2); + } + function x9d(a, b, c2) { + s7d(); + O8d.call(this, a, b, c2); + } + function h9d(a, b, c2) { + s7d(); + f9d.call(this, a, b, c2); + } + function j9d(a, b, c2) { + s7d(); + f9d.call(this, a, b, c2); + } + function l9d(a, b, c2) { + s7d(); + j9d.call(this, a, b, c2); + } + function t9d(a, b, c2) { + s7d(); + r9d.call(this, a, b, c2); + } + function z9d(a, b, c2) { + s7d(); + x9d.call(this, a, b, c2); + } + function S2b(a) { + J2b.call(this, a.d, a.c, a.a, a.b); + } + function B3b(a) { + J2b.call(this, a.d, a.c, a.a, a.b); + } + function Og(a) { + this.d = a; + Lg(this); + this.b = ed(a.d); + } + function cGd(a) { + aGd(); + return ws((fGd(), eGd), a); + } + function gk(a, b) { + Qb(a); + Qb(b); + return new hk(a, b); + } + function dr(a, b) { + Qb(a); + Qb(b); + return new mr(a, b); + } + function hr(a, b) { + Qb(a); + Qb(b); + return new sr(a, b); + } + function Dr(a, b) { + Qb(a); + Qb(b); + return new Rr(a, b); + } + function Uub(a) { + sFb(a.b != 0); + return Wub(a, a.a.a); + } + function Vub(a) { + sFb(a.b != 0); + return Wub(a, a.c.b); + } + function q$d(a) { + !a.c && (a.c = new X9d()); + return a.c; + } + function cv(a) { + var b; + b = new bnb(); + xr(b, a); + return b; + } + function Vx(a) { + var b; + b = new _sb(); + xr(b, a); + return b; + } + function Yx(a) { + var b; + b = new xAb(); + _q(b, a); + return b; + } + function gv(a) { + var b; + b = new Yub(); + _q(b, a); + return b; + } + function RD(a, b) { + CFb(a == null || QD(a, b)); + return a; + } + function Mxb(a, b, c2) { + Axb.call(this, b, c2); + this.a = a; + } + function kB(a, b) { + this.c = a; + this.b = b; + this.a = false; + } + function hCb() { + this.a = ";,;"; + this.b = ""; + this.c = ""; + } + function $Cb(a, b, c2) { + this.b = a; + pxb.call(this, b, c2); + } + function uub(a, b, c2) { + this.c = a; + xlb.call(this, b, c2); + } + function fZb(a, b, c2) { + eZb.call(this, a, b); + this.b = c2; + } + function YEb(a, b, c2) { + VEb(c2, 0, a, b, c2.length, false); + } + function JYb(a, b, c2, d, e) { + a.b = b; + a.c = c2; + a.d = d; + a.a = e; + } + function D2b(a, b, c2, d, e) { + a.d = b; + a.c = c2; + a.a = d; + a.b = e; + } + function XDb(a, b) { + if (b) { + a.b = b; + a.a = (LCb(b), b.a); + } + } + function mFb(a, b) { + if (!a) { + throw Adb(new agb(b)); + } + } + function zFb(a, b) { + if (!a) { + throw Adb(new dgb(b)); + } + } + function qFb(a, b) { + if (!a) { + throw Adb(new zeb(b)); + } + } + function zqc(a, b) { + mqc(); + return hgb(a.d.p, b.d.p); + } + function T0c(a, b) { + B0c(); + return Qfb(a.e.b, b.e.b); + } + function U0c(a, b) { + B0c(); + return Qfb(a.e.a, b.e.a); + } + function Xoc(a, b) { + return hgb(N3b(a.d), N3b(b.d)); + } + function Izb(a, b) { + return !!b && Jzb(a, b.d) ? b : null; + } + function $lc(a, b) { + return b == (qpd(), ppd) ? a.c : a.d; + } + function Qdb(a) { + return Edb(yD(Kdb(a) ? Wdb(a) : a)); + } + function Nid(a) { + return new rjd(a.c + a.b, a.d + a.a); + } + function GSd(a) { + return a != null && !mSd(a, aSd, bSd); + } + function DSd(a, b) { + return (JSd(a) << 4 | JSd(b)) & Bwe; + } + function Rid(a, b, c2, d, e) { + a.c = b; + a.d = c2; + a.b = d; + a.a = e; + } + function y8b(a) { + var b, c2; + b = a.b; + c2 = a.c; + a.b = c2; + a.c = b; + } + function B8b(a) { + var b, c2; + c2 = a.d; + b = a.a; + a.d = b; + a.a = c2; + } + function u6d(a, b) { + var c2; + c2 = a.c; + t6d(a, b); + return c2; + } + function Nqd(a, b) { + b < 0 ? a.g = -1 : a.g = b; + return a; + } + function kjd(a, b) { + gjd(a); + a.a *= b; + a.b *= b; + return a; + } + function hrc(a, b, c2) { + grc.call(this, b, c2); + this.d = a; + } + function PZd(a, b, c2) { + kZd.call(this, a, b); + this.c = c2; + } + function Kfe(a, b, c2) { + kZd.call(this, a, b); + this.c = c2; + } + function zUd(a) { + yUd(); + kUd.call(this); + this.ci(a); + } + function Yee() { + ree(); + Zee.call(this, (YSd(), XSd)); + } + function Yse(a) { + Vse(); + return new Hte(0, a); + } + function uke() { + uke = geb; + tke = (yob(), new mpb(eLe)); + } + function ux() { + ux = geb; + new wx((kl(), jl), (Wk(), Vk)); + } + function ugb() { + ugb = geb; + tgb = $C(bJ, Nve, 17, 256, 0, 1); + } + function zUb() { + this.b = Kfb(UD(iGd((yVb(), sVb)))); + } + function Pq(a) { + this.b = a; + this.a = gn(this.b.a).Od(); + } + function mr(a, b) { + this.b = a; + this.a = b; + zl.call(this); + } + function sr(a, b) { + this.a = a; + this.b = b; + zl.call(this); + } + function s_d(a, b, c2) { + this.a = a; + N$d.call(this, b, c2); + } + function n_d(a, b, c2) { + this.a = a; + N$d.call(this, b, c2); + } + function sDd(a, b, c2) { + var d; + d = new OC(c2); + sC(a, b, d); + } + function _Eb(a, b, c2) { + var d; + d = a[b]; + a[b] = c2; + return d; + } + function UEb(a) { + var b; + b = a.slice(); + return dD(b, a); + } + function SJb(a) { + var b; + b = a.n; + return a.a.b + b.d + b.a; + } + function PKb(a) { + var b; + b = a.n; + return a.e.b + b.d + b.a; + } + function QKb(a) { + var b; + b = a.n; + return a.e.a + b.b + b.c; + } + function rub(a) { + a.a.b = a.b; + a.b.a = a.a; + a.a = a.b = null; + } + function Mub(a, b) { + Pub(a, b, a.c.b, a.c); + return true; + } + function w2b(a) { + if (a.a) { + return a.a; + } + return R0b(a); + } + function NSb(a) { + HSb(); + return JGd(a) == vCd(LGd(a)); + } + function OSb(a) { + HSb(); + return LGd(a) == vCd(JGd(a)); + } + function l_b(a, b) { + return k_b(a, new eZb(b.a, b.b)); + } + function xn(a, b) { + return fn(), ck(a, b), new zy(a, b); + } + function fmc(a, b) { + return a.c < b.c ? -1 : a.c == b.c ? 0 : 1; + } + function snc(a) { + return a.b.c.length - a.e.c.length; + } + function N3b(a) { + return a.e.c.length - a.g.c.length; + } + function L3b(a) { + return a.e.c.length + a.g.c.length; + } + function Lgb(a) { + return a == 0 || isNaN(a) ? a : a < 0 ? -1 : 1; + } + function V0b(a) { + return !W0b(a) && a.c.i.c == a.d.i.c; + } + function DOc(a) { + dOc(); + return (qpd(), apd).Hc(a.j); + } + function M0c(a, b, c2) { + B0c(); + return c2.e.a + c2.f.a + a * b; + } + function W0c(a, b, c2) { + B0c(); + return c2.e.b + c2.f.b + a * b; + } + function SUc(a, b, c2) { + return Zjb(a.b, RD(c2.b, 18), b); + } + function TUc(a, b, c2) { + return Zjb(a.b, RD(c2.b, 18), b); + } + function oFd(a, b, c2) { + iEd(a.a, a.b, a.c, RD(b, 166), c2); + } + function lad(a, b, c2, d) { + mad.call(this, a, b, c2, d, 0, 0); + } + function LUd(a) { + yUd(); + zUd.call(this, a); + this.a = -1; + } + function Gxb(a, b) { + Axb.call(this, b, 1040); + this.a = a; + } + function zqd() { + vqd.call(this, "COUNT_CHILDREN", 0); + } + function ole(a, b) { + Eke.call(this, a, b); + this.a = this; + } + function ufb(a, b) { + var c2; + c2 = rfb(a, b); + c2.i = 2; + return c2; + } + function cJd(a, b) { + var c2; + ++a.j; + c2 = a.Cj(b); + return c2; + } + function pfd(a, b, c2) { + a.a = -1; + tfd(a, b.g, c2); + return a; + } + function Bsd(a, b) { + return Rmb(a, new rjd(b.a, b.b)); + } + function __c(a) { + return R_c(), $C(Z$, NEe, 40, a, 0, 1); + } + function dj(a) { + return a.e.Rd().gc() * a.c.Rd().gc(); + } + function fk(a, b, c2) { + return new rk(hDb(a)._e(), c2, b); + } + function mVd(a, b) { + nVd(a, b == null ? null : (uFb(b), b)); + } + function q6d(a, b) { + s6d(a, b == null ? null : (uFb(b), b)); + } + function r6d(a, b) { + s6d(a, b == null ? null : (uFb(b), b)); + } + function CFb(a) { + if (!a) { + throw Adb(new Ifb(null)); + } + } + function tt(a) { + if (a.c.e != a.a) { + throw Adb(new Jrb()); + } + } + function Au(a) { + if (a.e.c != a.b) { + throw Adb(new Jrb()); + } + } + function Ar(a) { + Qb(a); + while (a.Ob()) { + a.Pb(); + a.Qb(); + } + } + function Dy(a) { + tm(); + this.a = (yob(), new mpb(Qb(a))); + } + function mf(a) { + this.c = a; + this.b = this.c.d.vc().Kc(); + } + function hx(a) { + a.a.ld(); + RD(a.a.md(), 16).gc(); + Hh(); + } + function $hb(a, b) { + a.a += Ihb(b, 0, b.length); + return a; + } + function Vmb(a, b) { + tFb(b, a.c.length); + return a.c[b]; + } + function kob(a, b) { + tFb(b, a.a.length); + return a.a[b]; + } + function Arb(a, b) { + return uFb(b), Leb(b, (uFb(a), a)); + } + function vrb(a, b) { + return uFb(a), Leb(a, (uFb(b), b)); + } + function YC(a, b, c2, d, e, f2) { + return ZC(a, b, c2, d, e, 0, f2); + } + function GBb(a, b) { + return bD(b, 0, tCb(b[0], Hgb(1))); + } + function IBb(a, b) { + return Hgb(Bdb(Hgb(a.a).a, b.a)); + } + function tCb(a, b) { + return IBb(RD(a, 168), RD(b, 168)); + } + function Jgb() { + Jgb = geb; + Igb = $C(eJ, Nve, 168, 256, 0, 1); + } + function dhb() { + dhb = geb; + chb = $C(lJ, Nve, 191, 256, 0, 1); + } + function Zeb() { + Zeb = geb; + Yeb = $C(RI, Nve, 222, 256, 0, 1); + } + function jfb() { + jfb = geb; + ifb = $C(SI, Nve, 180, 128, 0, 1); + } + function KYb() { + JYb(this, false, false, false, false); + } + function Kub(a) { + ctb.call(this, new gub()); + ye(this, a); + } + function btb(a) { + this.a = new Usb(a.gc()); + ye(this, a); + } + function nsb(a) { + this.c = a; + this.a = new Osb(this.c.a); + } + function Kmc(a) { + this.a = a; + this.c = new Tsb(); + Emc(this); + } + function DRb() { + this.d = new rjd(0, 0); + this.e = new _sb(); + } + function SDb(a, b) { + xDb(); + NCb.call(this, a); + this.a = b; + } + function J2b(a, b, c2, d) { + D2b(this, a, b, c2, d); + } + function Uqc(a, b, c2) { + return hgb(b.d[a.g], c2.d[a.g]); + } + function wMc(a, b, c2) { + return hgb(a.d[b.p], a.d[c2.p]); + } + function xMc(a, b, c2) { + return hgb(a.d[b.p], a.d[c2.p]); + } + function yMc(a, b, c2) { + return hgb(a.d[b.p], a.d[c2.p]); + } + function zMc(a, b, c2) { + return hgb(a.d[b.p], a.d[c2.p]); + } + function Aad(a, b, c2) { + return $wnd.Math.min(c2 / a, 1 / b); + } + function SIc(a, b) { + return a ? 0 : $wnd.Math.max(0, b - 1); + } + function qSd(a, b) { + return a == null ? b == null : lhb(a, b); + } + function rSd(a, b) { + return a == null ? b == null : mhb(a, b); + } + function lQb(a) { + return !a.q ? (yob(), yob(), wob) : a.q; + } + function _lc(a) { + return a.c - RD(Vmb(a.a, a.b), 294).b; + } + function trd(a) { + if (a.c) { + return a.c.f; + } + return a.e.b; + } + function urd(a) { + if (a.c) { + return a.c.g; + } + return a.e.a; + } + function wsc(a, b) { + a.a == null && usc(a); + return a.a[b]; + } + function L2c(a) { + var b; + b = R2c(a); + return !b ? a : L2c(b); + } + function $se(a, b) { + Vse(); + return new Qte(a, b); + } + function Hte(a, b) { + Vse(); + Wse.call(this, a); + this.a = b; + } + function N8d(a, b) { + s7d(); + t7d.call(this, b); + this.a = a; + } + function iae(a, b, c2) { + this.a = a; + XZd.call(this, b, c2, 2); + } + function ntd(a) { + this.b = new Yub(); + this.a = a; + this.c = -1; + } + function ds(a) { + qc.call(this, 0, 0); + this.a = a; + this.b = 0; + } + function PSd(a) { + ZHd.call(this, a.gc()); + YGd(this, a); + } + function jg(a) { + a.b ? jg(a.b) : a.d.dc() && a.f.c.Bc(a.e); + } + function aD(a) { + return Array.isArray(a) && a.Tm === keb; + } + function Bsb(a, b) { + return ZD(b, 22) && Csb(a, RD(b, 22)); + } + function Dsb(a, b) { + return ZD(b, 22) && Esb(a, RD(b, 22)); + } + function qtb(a, b) { + return otb(a, b, ptb(a, a.b.Ce(b))); + } + function Jtb(a, b) { + return !(a.a.get(b) === void 0); + } + function Iwb(a) { + return Kwb(a, 26) * Kxe + Kwb(a, 27) * Lxe; + } + function OBb(a, b) { + return FBb(new jCb(), new VBb(a), b); + } + function Ynb(a, b, c2) { + nFb(0, b, a.length); + Wnb(a, 0, b, c2); + } + function Qmb(a, b, c2) { + wFb(b, a.c.length); + XEb(a.c, b, c2); + } + function dKb(a, b, c2) { + var d; + if (a) { + d = a.i; + d.c = b; + d.b = c2; + } + } + function eKb(a, b, c2) { + var d; + if (a) { + d = a.i; + d.d = b; + d.a = c2; + } + } + function Pnb(a, b, c2) { + var d; + for (d = 0; d < b; ++d) { + a[d] = c2; + } + } + function Qnb(a, b) { + var c2; + for (c2 = 0; c2 < b; ++c2) { + a[c2] = -1; + } + } + function ysb(a, b) { + var c2; + c2 = xsb(a); + zob(c2, b); + return c2; + } + function cA(a, b) { + !a && (a = []); + a[a.length] = b; + return a; + } + function RQb(a, b) { + $id(a.c, b); + a.b.c += b.a; + a.b.d += b.b; + } + function QQb(a, b) { + RQb(a, ojd(new rjd(b.a, b.b), a.c)); + } + function sOb(a, b) { + this.b = new Yub(); + this.a = a; + this.c = b; + } + function QYb() { + this.b = new aZb(); + this.c = new UYb(this); + } + function fHb() { + this.d = new tHb(); + this.e = new lHb(this); + } + function UFc() { + RFc(); + this.f = new Yub(); + this.e = new Yub(); + } + function yOc() { + dOc(); + this.k = new Tsb(); + this.d = new _sb(); + } + function nud() { + nud = geb; + mud = new mGd((umd(), Gld), 0); + } + function cs() { + cs = geb; + bs = new ds($C(jJ, rve, 1, 0, 5, 1)); + } + function _ad(a, b, c2) { + return Ysb(a, new TFb(b.a, c2.a)); + } + function DGc(a, b, c2) { + return -hgb(a.f[b.p], a.f[c2.p]); + } + function Mic(a, b, c2) { + Hic(c2, a, 1); + Rmb(b, new xjc(c2, a)); + } + function Nic(a, b, c2) { + Iic(c2, a, 1); + Rmb(b, new Jjc(c2, a)); + } + function h$d(a, b, c2) { + this.a = a; + _Zd.call(this, b, c2, 22); + } + function s5d(a, b, c2) { + this.a = a; + _Zd.call(this, b, c2, 14); + } + function E8d(a, b, c2, d) { + s7d(); + N7d.call(this, a, b, c2, d); + } + function L8d(a, b, c2, d) { + s7d(); + N7d.call(this, a, b, c2, d); + } + function nfd(a, b, c2) { + a.a = -1; + tfd(a, b.g + 1, c2); + return a; + } + function bCd(a, b, c2) { + c2 = xvd(a, RD(b, 54), 7, c2); + return c2; + } + function hVd(a, b, c2) { + c2 = xvd(a, RD(b, 54), 3, c2); + return c2; + } + function Ydb(a) { + if (Kdb(a)) { + return a | 0; + } + return FD(a); + } + function cte(a) { + Vse(); + return new eue(10, a, 0); + } + function fe(a) { + var b; + b = a.f; + return !b ? a.f = a.Dc() : b; + } + function Ec(a) { + var b; + b = a.i; + return !b ? a.i = a.bc() : b; + } + function Ahe(a) { + if (a.e.j != a.d) { + throw Adb(new Jrb()); + } + } + function gn(a) { + if (a.c) { + return a.c; + } + return a.c = a.Sd(); + } + function hn(a) { + if (a.d) { + return a.d; + } + return a.d = a.Td(); + } + function Uee(a, b) { + return ufe(Pee(a, b)) ? b.zi() : null; + } + function ed(a) { + return ZD(a, 15) ? RD(a, 15).ed() : a.Kc(); + } + function De(a) { + return a.Qc($C(jJ, rve, 1, a.gc(), 5, 1)); + } + function aE(a) { + return a != null && cE(a) && !(a.Tm === keb); + } + function YD(a) { + return !Array.isArray(a) && a.Tm === keb; + } + function vx(a, b) { + return Qb(b), a.a.Jd(b) && !a.b.Jd(b); + } + function tD(a, b) { + return hD(a.l & b.l, a.m & b.m, a.h & b.h); + } + function zD(a, b) { + return hD(a.l | b.l, a.m | b.m, a.h | b.h); + } + function HD(a, b) { + return hD(a.l ^ b.l, a.m ^ b.m, a.h ^ b.h); + } + function Sdb(a, b) { + return Edb(AD(Kdb(a) ? Wdb(a) : a, b)); + } + function Tdb(a, b) { + return Edb(BD(Kdb(a) ? Wdb(a) : a, b)); + } + function Udb(a, b) { + return Edb(CD(Kdb(a) ? Wdb(a) : a, b)); + } + function Ieb(a, b) { + return Keb((uFb(a), a), (uFb(b), b)); + } + function Jfb(a, b) { + return Qfb((uFb(a), a), (uFb(b), b)); + } + function pwb(a) { + this.b = new cnb(11); + this.a = (urb(), a); + } + function is(a) { + this.a = (cs(), bs); + this.d = RD(Qb(a), 51); + } + function Axb(a, b) { + this.c = 0; + this.d = a; + this.b = b | 64 | Ove; + } + function kxb(a, b) { + this.e = a; + this.d = (b & 64) != 0 ? b | Ove : b; + } + function ezb(a) { + this.b = null; + this.a = (urb(), !a ? rrb : a); + } + function nz(a) { + ez(this); + this.g = a; + gz(this); + this.je(); + } + function vue(a) { + uue(); + this.a = 0; + this.b = a - 1; + this.c = 1; + } + function yg(a, b, c2, d) { + this.a = a; + lg.call(this, a, b, c2, d); + } + function gEb(a, b, c2) { + if (a.a.Mb(c2)) { + a.b = true; + b.Cd(c2); + } + } + function Qwb(a) { + if (!a.d) { + a.d = a.b.Kc(); + a.c = a.b.gc(); + } + } + function lyb(a, b) { + if (a < 0 || a >= b) { + throw Adb(new web()); + } + } + function JDb(a, b) { + return MDb(a, (uFb(b), new JAb(b))); + } + function KDb(a, b) { + return MDb(a, (uFb(b), new LAb(b))); + } + function prc(a, b, c2) { + return qrc(a, RD(b, 12), RD(c2, 12)); + } + function q4b(a) { + return J3b(), RD(a, 12).g.c.length != 0; + } + function v4b(a) { + return J3b(), RD(a, 12).e.c.length != 0; + } + function sdc(a, b) { + Zcc(); + return Qfb(b.a.o.a, a.a.o.a); + } + function d_d(a, b) { + (b.Bb & QHe) != 0 && !a.a.o && (a.a.o = b); + } + function T3c(a, b) { + b.Ug("General 'Rotator", 1); + S3c(a); + } + function MCc(a, b, c2) { + b.qf(c2, Kfb(UD(Wjb(a.b, c2))) * a.a); + } + function yid(a, b, c2) { + tid(); + return xid(a, b) && xid(a, c2); + } + function Rod(a) { + Pod(); + return !a.Hc(Lod) && !a.Hc(Nod); + } + function Nrc(a) { + if (a.e) { + return Src(a.e); + } + return null; + } + function Zdb(a) { + if (Kdb(a)) { + return "" + a; + } + return GD(a); + } + function XNc(a) { + var b; + b = a; + while (b.f) { + b = b.f; + } + return b; + } + function HBb(a, b, c2) { + bD(b, 0, tCb(b[0], c2[0])); + return b; + } + function Gpc(a, b, c2, d) { + var e; + e = a.i; + e.i = b; + e.a = c2; + e.b = d; + } + function C5d(a, b, c2, d) { + XZd.call(this, a, b, c2); + this.b = d; + } + function N3d(a, b, c2, d, e) { + O3d.call(this, a, b, c2, d, e, -1); + } + function b4d(a, b, c2, d, e) { + c4d.call(this, a, b, c2, d, e, -1); + } + function Iie(a, b, c2, d) { + PZd.call(this, a, b, c2); + this.b = d; + } + function Xde(a) { + uId.call(this, a, false); + this.a = false; + } + function Bqd() { + vqd.call(this, "LOOKAHEAD_LAYOUT", 1); + } + function nNd(a) { + this.b = a; + mMd.call(this, a); + mNd(this); + } + function vNd(a) { + this.b = a; + BMd.call(this, a); + uNd(this); + } + function J5d(a, b, c2) { + this.a = a; + G5d.call(this, b, c2, 5, 6); + } + function wje(a, b, c2, d) { + this.b = a; + XZd.call(this, b, c2, d); + } + function Tj(a, b) { + this.b = a; + Aj.call(this, a.b); + this.a = b; + } + function NLc(a) { + this.a = LLc(a.a); + this.b = new dnb(a.b); + } + function Fx(a, b) { + tm(); + Ex.call(this, a, Pm(new mob(b))); + } + function _se(a, b) { + Vse(); + return new aue(a, b, 0); + } + function bte(a, b) { + Vse(); + return new aue(6, a, b); + } + function Ztb(a, b) { + uFb(b); + while (a.Ob()) { + b.Cd(a.Pb()); + } + } + function Ujb(a, b) { + return bE(b) ? Yjb(a, b) : !!qtb(a.f, b); + } + function O_d(a, b) { + return b.Vh() ? Vvd(a.b, RD(b, 54)) : b; + } + function whb(a, b) { + return lhb(a.substr(0, b.length), b); + } + function Fl(a) { + return new is(new Il(a.a.length, a.a)); + } + function Oid(a) { + return new rjd(a.c + a.b / 2, a.d + a.a / 2); + } + function yD(a) { + return hD(~a.l & dxe, ~a.m & dxe, ~a.h & exe); + } + function cE(a) { + return typeof a === gve || typeof a === kve; + } + function akb(a) { + a.f = new ttb(a); + a.i = new Ntb(a); + ++a.g; + } + function Klb(a) { + if (!a) { + throw Adb(new Dvb()); + } + return a.d; + } + function smb(a) { + var b; + b = omb(a); + sFb(b != null); + return b; + } + function tmb(a) { + var b; + b = pmb(a); + sFb(b != null); + return b; + } + function tv(a, b) { + var c2; + c2 = a.a.gc(); + Sb(b, c2); + return c2 - b; + } + function Ysb(a, b) { + var c2; + c2 = a.a.zc(b, a); + return c2 == null; + } + function rAb(a, b) { + return a.a.zc(b, (Geb(), Eeb)) == null; + } + function _nb(a) { + return new SDb(null, $nb(a, a.length)); + } + function yPb(a, b, c2) { + return zPb(a, RD(b, 42), RD(c2, 176)); + } + function Wrb(a, b, c2) { + zsb(a.a, b); + return _Eb(a.b, b.g, c2); + } + function fyb(a, b, c2) { + lyb(c2, a.a.c.length); + $mb(a.a, c2, b); + } + function Knb(a, b, c2, d) { + nFb(b, c2, a.length); + Onb(a, b, c2, d); + } + function Onb(a, b, c2, d) { + var e; + for (e = b; e < c2; ++e) { + a[e] = d; + } + } + function Snb(a, b) { + var c2; + for (c2 = 0; c2 < b; ++c2) { + a[c2] = false; + } + } + function cjb(a, b, c2) { + Pib(); + this.e = a; + this.d = b; + this.a = c2; + } + function DBb(a, b, c2) { + this.c = a; + this.a = b; + yob(); + this.b = c2; + } + function nMd(a, b) { + this.d = a; + dMd.call(this, a); + this.e = b; + } + function Ved(a, b, c2) { + Ned(a, b.g, c2); + zsb(a.c, b); + return a; + } + function xYb(a) { + vYb(a, (Cmd(), ymd)); + a.d = true; + return a; + } + function Cfe(a) { + !a.j && Ife(a, Dee(a.g, a.b)); + return a.j; + } + function At(a) { + a.a = null; + a.e = null; + akb(a.b); + a.d = 0; + ++a.c; + } + function znb(a) { + yFb(a.b != -1); + Xmb(a.c, a.a = a.b); + a.b = -1; + } + function Qte(a, b) { + Wse.call(this, 1); + this.a = a; + this.b = b; + } + function uUb(a, b) { + return a > 0 ? $wnd.Math.log(a / b) : -100; + } + function Agb(a, b) { + return Ddb(a, b) < 0 ? -1 : Ddb(a, b) > 0 ? 1 : 0; + } + function Dge(a, b) { + hZd(a, ZD(b, 160) ? b : RD(b, 2036).Rl()); + } + function vFb(a, b) { + if (a == null) { + throw Adb(new Ogb(b)); + } + } + function $nb(a, b) { + return jxb(b, a.length), new Gxb(a, b); + } + function hsc(a, b) { + if (!b) { + return false; + } + return ye(a, b); + } + function Gs() { + zs(); + return cD(WC(RG, 1), jwe, 549, 0, [ys]); + } + function Xib(a) { + return a.e == 0 ? a : new cjb(-a.e, a.d, a.a); + } + function $Nb(a, b) { + return Qfb(a.c.c + a.c.b, b.c.c + b.c.b); + } + function cvb(a, b) { + Pub(a.d, b, a.b.b, a.b); + ++a.a; + a.c = null; + } + function JCb(a, b) { + !a.c ? Rmb(a.b, b) : JCb(a.c, b); + return a; + } + function KB(a, b, c2) { + var d; + d = JB(a, b); + LB(a, b, c2); + return d; + } + function Rnb(a, b, c2) { + var d; + for (d = 0; d < b; ++d) { + bD(a, d, c2); + } + } + function nhb(a, b, c2, d, e) { + while (b < c2) { + d[e++] = ihb(a, b++); + } + } + function Qnc(a, b, c2, d, e) { + Pnc(a, RD(Qc(b.k, c2), 15), c2, d, e); + } + function Nnc(a, b) { + FDb(GDb(a.Oc(), new voc()), new xoc(b)); + } + function tXc(a, b) { + return Qfb(a.e.a + a.f.a, b.e.a + b.f.a); + } + function vXc(a, b) { + return Qfb(a.e.b + a.f.b, b.e.b + b.f.b); + } + function GOc(a) { + return $wnd.Math.abs(a.d.e - a.e.e) - a.a; + } + function ane(a) { + return a == oxe ? mLe : a == pxe ? "-INF" : "" + a; + } + function cne(a) { + return a == oxe ? mLe : a == pxe ? "-INF" : "" + a; + } + function MSb(a) { + HSb(); + return vCd(JGd(a)) == vCd(LGd(a)); + } + function kOd(a, b, c2) { + return RD(a.c.hd(b, RD(c2, 136)), 44); + } + function IFd(a, b) { + oDd(a, new OC(b.f != null ? b.f : "" + b.g)); + } + function KFd(a, b) { + oDd(a, new OC(b.f != null ? b.f : "" + b.g)); + } + function YGd(a, b) { + a.Si() && (b = bHd(a, b)); + return a.Fi(b); + } + function VVd(a, b) { + b = a.Yk(null, b); + return UVd(a, null, b); + } + function Wfe(a, b) { + ++a.j; + Tge(a, a.i, b); + Vfe(a, RD(b, 343)); + } + function UId(a) { + a ? iz(a, (gib(), fib)) : neb((gib(), a)); + } + function Twb(a) { + this.d = (uFb(a), a); + this.a = 0; + this.c = Sve; + } + function TTc(a, b) { + this.d = bUc(a); + this.c = b; + this.a = 0.5 * b; + } + function WTb(a) { + VTb.call(this); + this.a = a; + Rmb(a.a, this); + } + function Zje() { + gub.call(this); + this.a = true; + this.b = true; + } + function WB() { + WB = geb; + UB = new XB(false); + VB = new XB(true); + } + function Pc(a) { + var b; + return b = a.g, !b ? a.g = new th(a) : b; + } + function Uc(a) { + var b; + return b = a.k, !b ? a.k = new Bh(a) : b; + } + function ki(a) { + var b; + return b = a.k, !b ? a.k = new Bh(a) : b; + } + function ej(a) { + var b; + return b = a.i, !b ? a.i = new Ki(a) : b; + } + function bj(a) { + var b; + b = a.f; + return !b ? a.f = new Zj(a) : b; + } + function Fc(a) { + var b; + b = a.j; + return !b ? a.j = new Sw(a) : b; + } + function Co(a) { + var b; + b = a.d; + return !b ? a.d = new mp(a) : b; + } + function ate(a, b, c2) { + Vse(); + return new Yte(a, b, c2); + } + function yj(a, b) { + Pb(b, a.c.b.c.gc()); + return new Nj(a, b); + } + function sv(a, b) { + var c2; + c2 = a.a.gc(); + Pb(b, c2); + return c2 - 1 - b; + } + function sfb(a, b, c2) { + var d; + d = rfb(a, b); + Ffb(c2, d); + return d; + } + function rfb(a, b) { + var c2; + c2 = new pfb(); + c2.j = a; + c2.d = b; + return c2; + } + function Qb(a) { + if (a == null) { + throw Adb(new Ngb()); + } + return a; + } + function OC(a) { + if (a == null) { + throw Adb(new Ngb()); + } + this.a = a; + } + function XA(a) { + vA(); + this.b = new bnb(); + this.a = a; + IA(this, a); + } + function Zs(a) { + this.b = a; + this.a = RD(Hvb(this.b.a.e), 227); + } + function tm() { + tm = geb; + _l(); + sm = new Kx((yob(), yob(), vob)); + } + function Px() { + Px = geb; + _l(); + Ox = new Qx((yob(), yob(), xob)); + } + function lTd() { + lTd = geb; + kTd = _ae(); + !!(JTd(), nTd) && bbe(); + } + function LSc(a) { + a.s = NaN; + a.c = NaN; + MSc(a, a.e); + MSc(a, a.j); + } + function AYd(a) { + return (a.i == null && rYd(a), a.i).length; + } + function wq(a, b) { + return RD(gn(a.a).Md().Xb(b), 44).ld(); + } + function Wjb(a, b) { + return bE(b) ? Xjb(a, b) : Wd(qtb(a.f, b)); + } + function QSb(a, b) { + HSb(); + return a == JGd(b) ? LGd(b) : JGd(b); + } + function rWb(a, b, c2, d) { + return c2 == 0 || (c2 - d) / c2 < a.e || b >= a.g; + } + function bD(a, b, c2) { + pFb(c2 == null || VC(a, c2)); + return a[b] = c2; + } + function yhb(a, b) { + BFb(b, a.length + 1); + return a.substr(b); + } + function yxb(a, b) { + uFb(b); + while (a.c < a.d) { + a.Se(b, a.c++); + } + } + function Dub(a) { + this.d = a; + this.c = a.a.d.a; + this.b = a.a.e.g; + } + function Ggd(a) { + this.c = a; + this.a = new Yub(); + this.b = new Yub(); + } + function R4b(a) { + this.c = new pjd(); + this.a = new bnb(); + this.b = a; + } + function fYb(a) { + this.b = new bnb(); + this.a = new bnb(); + this.c = a; + } + function Pdd(a, b, c2) { + RD(b.b, 68); + Umb(b.a, new Wdd(a, c2, b)); + } + function rdc(a, b) { + Zcc(); + return RD(Vrb(a, b.d), 15).Fc(b); + } + function oDd(a, b) { + var c2; + c2 = a.a.length; + JB(a, c2); + LB(a, c2, b); + } + function eFb(a, b) { + var c2; + c2 = console[a]; + c2.call(console, b); + } + function _Id(a, b) { + var c2; + ++a.j; + c2 = a.Ej(); + a.rj(a.Zi(c2, b)); + } + function lMc(a, b, c2) { + var d; + d = rMc(a, b, c2); + return kMc(a, d); + } + function j2d(a) { + !a.d && (a.d = new XZd(o7, a, 1)); + return a.d; + } + function jVd(a) { + !a.a && (a.a = new XZd(r7, a, 4)); + return a.a; + } + function Jhb(a, b) { + a.a += String.fromCharCode(b); + return a; + } + function Thb(a, b) { + a.a += String.fromCharCode(b); + return a; + } + function D9d(a, b, c2) { + this.a = a; + L6d.call(this, b); + this.b = c2; + } + function Fde(a, b, c2) { + this.a = a; + MKd.call(this, 8, b, null, c2); + } + function aue(a, b, c2) { + Wse.call(this, a); + this.a = b; + this.b = c2; + } + function O8d(a, b, c2) { + t7d.call(this, b); + this.a = a; + this.b = c2; + } + function ut(a) { + this.c = a; + this.b = this.c.a; + this.a = this.c.e; + } + function Zee(a) { + this.a = (uFb(qKe), qKe); + this.b = a; + new O5d(); + } + function Trb(a) { + Ae(a.a); + a.b = $C(jJ, rve, 1, a.b.length, 5, 1); + } + function Ckb(a) { + yFb(a.c != -1); + a.d.gd(a.c); + a.b = a.c; + a.c = -1; + } + function ejd(a) { + return $wnd.Math.sqrt(a.a * a.a + a.b * a.b); + } + function Jzb(a, b) { + return Tyb(a.c, a.f, b, a.b, a.a, a.e, a.d); + } + function eyb(a, b) { + return lyb(b, a.a.c.length), Vmb(a.a, b); + } + function Hb(a, b) { + return dE(a) === dE(b) || a != null && pb(a, b); + } + function O2d(a) { + return ZD(a, 102) && (RD(a, 19).Bb & QHe) != 0; + } + function Fb(a) { + Hvb(a); + return ZD(a, 484) ? RD(a, 484) : jeb(a); + } + function bve(a) { + if (a) + return a.dc(); + return !a.Kc().Ob(); + } + function kte(a) { + if (!Ase) + return false; + return Yjb(Ase, a); + } + function hDb(a) { + if (0 >= a) { + return new rDb(); + } + return iDb(a - 1); + } + function Y2b(a) { + if (!a.a && !!a.c) { + return a.c.b; + } + return a.a; + } + function Zx(a) { + if (ZD(a, 616)) { + return a; + } + return new sy(a); + } + function LCb(a) { + if (!a.c) { + MCb(a); + a.d = true; + } else { + LCb(a.c); + } + } + function ICb(a) { + if (!a.c) { + a.d = true; + KCb(a); + } else { + a.c.$e(); + } + } + function bHb(a) { + a.b = false; + a.c = false; + a.d = false; + a.a = false; + } + function uMc(a) { + var b, c2; + b = a.c.i.c; + c2 = a.d.i.c; + return b == c2; + } + function _vd(a, b) { + var c2; + c2 = a.Ih(b); + c2 >= 0 ? a.ki(c2) : Tvd(a, b); + } + function mtd(a, b) { + a.c < 0 || a.b.b < a.c ? Oub(a.b, b) : a.a.tf(b); + } + function aBd(a, b) { + WGd((!a.a && (a.a = new F4d(a, a)), a.a), b); + } + function DQb(a, b) { + RQb(RD(b.b, 68), a); + Umb(b.a, new IQb(a)); + } + function Woc(a, b) { + return hgb(b.j.c.length, a.j.c.length); + } + function oed(a, b, c2) { + hed(); + return c2.Lg(a, RD(b.ld(), 149)); + } + function Hvb(a) { + if (a == null) { + throw Adb(new Ngb()); + } + return a; + } + function uFb(a) { + if (a == null) { + throw Adb(new Ngb()); + } + return a; + } + function uKd(a) { + if (a.p != 4) + throw Adb(new cgb()); + return a.e; + } + function tKd(a) { + if (a.p != 3) + throw Adb(new cgb()); + return a.e; + } + function CKd(a) { + if (a.p != 3) + throw Adb(new cgb()); + return a.j; + } + function DKd(a) { + if (a.p != 4) + throw Adb(new cgb()); + return a.j; + } + function wKd(a) { + if (a.p != 6) + throw Adb(new cgb()); + return a.f; + } + function FKd(a) { + if (a.p != 6) + throw Adb(new cgb()); + return a.k; + } + function $9d(a) { + !a.b && (a.b = new pae(new lae())); + return a.b; + } + function yfe(a) { + a.c == -2 && Efe(a, vee2(a.g, a.b)); + return a.c; + } + function vfb(a, b) { + var c2; + c2 = rfb("", a); + c2.n = b; + c2.i = 1; + return c2; + } + function kp(a, b, c2, d) { + gp.call(this, a, c2); + this.a = b; + this.f = d; + } + function ct(a, b, c2, d) { + gp.call(this, a, b); + this.d = c2; + this.a = d; + } + function zy(a, b) { + _p.call(this, Gob(Qb(a), Qb(b))); + this.a = b; + } + function ufd() { + Oed.call(this); + aFb(this.j.c, 0); + this.a = -1; + } + function $ae() { + FBd.call(this, AKe, (jTd(), iTd)); + Uae(this); + } + function Bne() { + FBd.call(this, dLe, (Ole(), Nle)); + xne(this); + } + function cdd() { + qs.call(this, "DELAUNAY_TRIANGULATION", 0); + } + function Ehb(a) { + return String.fromCharCode.apply(null, a); + } + function Zjb(a, b, c2) { + return bE(b) ? $jb(a, b, c2) : rtb(a.f, b, c2); + } + function Fob(a) { + yob(); + return !a ? (urb(), urb(), trb) : a.Oe(); + } + function Zu(a) { + dk(a, lwe); + return dz(Bdb(Bdb(5, a), a / 10 | 0)); + } + function yx(a, b) { + ux(); + return new wx(new tl(a), new dl(b)); + } + function fn() { + fn = geb; + en = new Nx(cD(WC(UK, 1), Zve, 44, 0, [])); + } + function tqb(a) { + !a.d && (a.d = new xpb(a.c.Cc())); + return a.d; + } + function qqb(a) { + !a.a && (a.a = new Sqb(a.c.vc())); + return a.a; + } + function sqb(a) { + !a.b && (a.b = new Lqb(a.c.ec())); + return a.b; + } + function qgb(a, b) { + while (b-- > 0) { + a = a << 1 | (a < 0 ? 1 : 0); + } + return a; + } + function BGc(a, b) { + var c2; + c2 = new R4b(a); + ZEb(b.c, c2); + return c2; + } + function FMb(a, b) { + a.u.Hc((Pod(), Lod)) && DMb(a, b); + HMb(a, b); + } + function Fvb(a, b) { + return dE(a) === dE(b) || a != null && pb(a, b); + } + function Vrb(a, b) { + return Bsb(a.a, b) ? a.b[RD(b, 22).g] : null; + } + function YRb() { + VRb(); + return cD(WC($O, 1), jwe, 489, 0, [URb]); + } + function ybd() { + sbd(); + return cD(WC(M1, 1), jwe, 490, 0, [rbd]); + } + function Hbd() { + Cbd(); + return cD(WC(N1, 1), jwe, 558, 0, [Bbd]); + } + function gdd() { + _cd(); + return cD(WC(V1, 1), jwe, 539, 0, [$cd]); + } + function iyd(a) { + !a.n && (a.n = new C5d(I4, a, 1, 7)); + return a.n; + } + function wCd(a) { + !a.c && (a.c = new C5d(K4, a, 9, 9)); + return a.c; + } + function mzd(a) { + !a.c && (a.c = new Yie(E4, a, 5, 8)); + return a.c; + } + function lzd(a) { + !a.b && (a.b = new Yie(E4, a, 4, 7)); + return a.b; + } + function Sed(a) { + a.j.c.length = 0; + Ae(a.c); + sfd(a.a); + return a; + } + function Afe(a) { + a.e == fLe && Gfe(a, Aee(a.g, a.b)); + return a.e; + } + function Bfe(a) { + a.f == fLe && Hfe(a, Bee(a.g, a.b)); + return a.f; + } + function xBd(a, b, c2, d) { + wBd(a, b, c2, false); + j1d(a, d); + return a; + } + function oNd(a, b) { + this.b = a; + nMd.call(this, a, b); + mNd(this); + } + function wNd(a, b) { + this.b = a; + CMd.call(this, a, b); + uNd(this); + } + function Kmb(a) { + this.d = a; + this.a = this.d.b; + this.b = this.d.c; + } + function oy(a, b) { + this.b = a; + this.c = b; + this.a = new Osb(this.b); + } + function ihb(a, b) { + BFb(b, a.length); + return a.charCodeAt(b); + } + function NDd(a, b) { + CGd(a, Kfb(vDd(b, "x")), Kfb(vDd(b, "y"))); + } + function $Dd(a, b) { + CGd(a, Kfb(vDd(b, "x")), Kfb(vDd(b, "y"))); + } + function CDb(a, b) { + MCb(a); + return new SDb(a, new hEb(b, a.a)); + } + function GDb(a, b) { + MCb(a); + return new SDb(a, new zEb(b, a.a)); + } + function HDb(a, b) { + MCb(a); + return new WCb(a, new nEb(b, a.a)); + } + function IDb(a, b) { + MCb(a); + return new oDb(a, new tEb(b, a.a)); + } + function Ty(a, b) { + return new Ry(RD(Qb(a), 50), RD(Qb(b), 50)); + } + function nHb(a, b) { + return Qfb(a.d.c + a.d.b / 2, b.d.c + b.d.b / 2); + } + function gTb(a, b, c2) { + c2.a ? Eyd(a, b.b - a.f / 2) : Dyd(a, b.a - a.g / 2); + } + function WYb(a, b) { + return Qfb(a.g.c + a.g.b / 2, b.g.c + b.g.b / 2); + } + function RZb(a, b) { + NZb(); + return Qfb((uFb(a), a), (uFb(b), b)); + } + function wSd(a) { + return a != null && tpb(eSd, a.toLowerCase()); + } + function Ae(a) { + var b; + for (b = a.Kc(); b.Ob(); ) { + b.Pb(); + b.Qb(); + } + } + function Ih(a) { + var b; + b = a.b; + !b && (a.b = b = new Xh(a)); + return b; + } + function R0b(a) { + var b; + b = Z5b(a); + if (b) { + return b; + } + return null; + } + function BSb(a, b) { + var c2, d; + c2 = a / b; + d = eE(c2); + c2 > d && ++d; + return d; + } + function Ck(a, b, c2) { + var d; + d = RD(a.d.Kb(c2), 159); + !!d && d.Nb(b); + } + function Vhc(a, b, c2) { + tqc(a.a, c2); + Jpc(c2); + Kqc(a.b, c2); + bqc(b, c2); + } + function oNc(a, b, c2, d) { + this.a = a; + this.c = b; + this.b = c2; + this.d = d; + } + function ROc(a, b, c2, d) { + this.c = a; + this.b = b; + this.a = c2; + this.d = d; + } + function uPc(a, b, c2, d) { + this.c = a; + this.b = b; + this.d = c2; + this.a = d; + } + function Uid2(a, b, c2, d) { + this.c = a; + this.d = b; + this.b = c2; + this.a = d; + } + function GTc(a, b, c2, d) { + this.a = a; + this.d = b; + this.c = c2; + this.b = d; + } + function t1b(a, b, c2, d) { + this.a = a; + this.e = b; + this.d = c2; + this.c = d; + } + function $td(a, b, c2, d) { + this.a = a; + this.c = b; + this.d = c2; + this.b = d; + } + function ehb(a, b, c2) { + this.a = ywe; + this.d = a; + this.b = b; + this.c = c2; + } + function fpc(a, b, c2, d) { + qs.call(this, a, b); + this.a = c2; + this.b = d; + } + function Uwb(a, b) { + this.d = (uFb(a), a); + this.a = 16449; + this.c = b; + } + function CIc(a) { + this.a = new bnb(); + this.e = $C(kE, Nve, 53, a, 0, 2); + } + function ELc(a) { + a.Ug("No crossing minimization", 1); + a.Vg(); + } + function Evb() { + yz.call(this, "There is no more element."); + } + function OEd(a, b, c2, d) { + this.a = a; + this.b = b; + this.c = c2; + this.d = d; + } + function PEd(a, b, c2, d) { + this.a = a; + this.b = b; + this.c = c2; + this.d = d; + } + function h7d(a, b, c2, d) { + this.e = a; + this.a = b; + this.c = c2; + this.d = d; + } + function x7d(a, b, c2, d) { + this.a = a; + this.c = b; + this.d = c2; + this.b = d; + } + function C8d(a, b, c2, d) { + s7d(); + M7d.call(this, b, c2, d); + this.a = a; + } + function J8d(a, b, c2, d) { + s7d(); + M7d.call(this, b, c2, d); + this.a = a; + } + function lwd(a, b, c2) { + var d, e; + d = oSd(a); + e = b.ti(c2, d); + return e; + } + function lBd(a) { + var b, c2; + c2 = (b = new s2d(), b); + l2d(c2, a); + return c2; + } + function mBd(a) { + var b, c2; + c2 = (b = new s2d(), b); + p2d(c2, a); + return c2; + } + function HDd(a, b) { + var c2; + c2 = Wjb(a.f, b); + wEd(b, c2); + return null; + } + function uCd(a) { + !a.b && (a.b = new C5d(G4, a, 12, 3)); + return a.b; + } + function VD(a) { + CFb(a == null || cE(a) && !(a.Tm === keb)); + return a; + } + function gz(a) { + if (a.n) { + a.e !== rwe && a.je(); + a.j = null; + } + return a; + } + function Ng(a) { + ig(a.d); + if (a.d.d != a.c) { + throw Adb(new Jrb()); + } + } + function Bkb(a) { + sFb(a.b < a.d.gc()); + return a.d.Xb(a.c = a.b++); + } + function Xub(a) { + a.a.a = a.c; + a.c.b = a.a; + a.a.b = a.c.a = null; + a.b = 0; + } + function xPd(a) { + this.f = a; + this.c = this.f.e; + a.f > 0 && wPd(this); + } + function Vg(a, b) { + this.a = a; + Pg.call(this, a, RD(a.d, 15).fd(b)); + } + function lrd(a, b) { + return Qfb(urd(a) * trd(a), urd(b) * trd(b)); + } + function mrd(a, b) { + return Qfb(urd(a) * trd(a), urd(b) * trd(b)); + } + function n5b(a) { + return ozd(a) && Heb(TD(Gxd(a, (yCc(), OAc)))); + } + function Sfc(a, b) { + return Rc(a, RD(mQb(b, (yCc(), tBc)), 17), b); + } + function lic(a, b) { + RD(mQb(a, (Ywc(), qwc)), 15).Fc(b); + return b; + } + function C2b(a, b) { + a.b = b.b; + a.c = b.c; + a.d = b.d; + a.a = b.a; + return a; + } + function cEb(a, b, c2, d) { + this.b = a; + this.c = d; + xxb.call(this, b, c2); + } + function Ulc(a, b, c2) { + a.i = 0; + a.e = 0; + if (b == c2) { + return; + } + Qlc(a, b, c2); + } + function Vlc(a, b, c2) { + a.i = 0; + a.e = 0; + if (b == c2) { + return; + } + Rlc(a, b, c2); + } + function akc(a, b, c2) { + Wjc(); + return _Gb(RD(Wjb(a.e, b), 529), c2); + } + function nd(a) { + var b; + return b = a.f, !b ? a.f = new ne(a, a.c) : b; + } + function nTc(a, b) { + return VTc(a.j, b.s, b.c) + VTc(b.e, a.s, a.c); + } + function Rrc(a, b) { + if (!!a.e && !a.e.a) { + Prc(a.e, b); + Rrc(a.e, b); + } + } + function Qrc(a, b) { + if (!!a.d && !a.d.a) { + Prc(a.d, b); + Qrc(a.d, b); + } + } + function krd(a, b) { + return -Qfb(urd(a) * trd(a), urd(b) * trd(b)); + } + function gtd(a) { + return RD(a.ld(), 149).Pg() + ":" + jeb(a.md()); + } + function EBd() { + BBd(this, new yAd()); + this.wb = (lTd(), kTd); + jTd(); + } + function G7b(a) { + this.b = new bnb(); + Tmb(this.b, this.b); + this.a = a; + } + function WWc(a, b) { + new Yub(); + this.a = new Ejd(); + this.b = a; + this.c = b; + } + function urb() { + urb = geb; + rrb = new wrb(); + srb = new wrb(); + trb = new Brb(); + } + function yob() { + yob = geb; + vob = new Job(); + wob = new apb(); + xob = new ipb(); + } + function FGb() { + FGb = geb; + CGb = new AGb(); + EGb = new fHb(); + DGb = new YGb(); + } + function HSb() { + HSb = geb; + GSb = new bnb(); + FSb = new Tsb(); + ESb = new bnb(); + } + function Rb(a, b) { + if (a == null) { + throw Adb(new Ogb(b)); + } + return a; + } + function tCd(a) { + !a.a && (a.a = new C5d(J4, a, 10, 11)); + return a.a; + } + function uYd(a) { + !a.q && (a.q = new C5d(s7, a, 11, 10)); + return a.q; + } + function xYd(a) { + !a.s && (a.s = new C5d(y7, a, 21, 17)); + return a.s; + } + function er2(a) { + Qb(a); + return Er(new is(Mr(a.a.Kc(), new ir()))); + } + function hfd(a, b) { + rb(a); + rb(b); + return ns(RD(a, 22), RD(b, 22)); + } + function qDd(a, b, c2) { + var d, e; + d = Qeb(c2); + e = new hC(d); + sC(a, b, e); + } + function d4d(a, b, c2, d, e, f2) { + c4d.call(this, a, b, c2, d, e, f2 ? -2 : -1); + } + function sje(a, b, c2, d) { + kZd.call(this, b, c2); + this.b = a; + this.a = d; + } + function Ry(a, b) { + wi.call(this, new ezb(a)); + this.a = a; + this.b = b; + } + function Gu(a) { + this.b = a; + this.c = a; + a.e = null; + a.c = null; + this.a = 1; + } + function Dkc(a) { + lkc(); + var b; + b = RD(a.g, 10); + b.n.a = a.d.c + b.d.b; + } + function fA() { + fA = geb; + var a, b; + b = !lA(); + a = new tA(); + eA = b ? new mA() : a; + } + function Hob(a) { + yob(); + return ZD(a, 59) ? new irb(a) : new Upb(a); + } + function Ux(a) { + return ZD(a, 16) ? new btb(RD(a, 16)) : Vx(a.Kc()); + } + function Vi(a) { + return new ij(a, a.e.Rd().gc() * a.c.Rd().gc()); + } + function fj(a) { + return new sj(a, a.e.Rd().gc() * a.c.Rd().gc()); + } + function Iz(a) { + return !!a && !!a.hashCode ? a.hashCode() : kFb(a); + } + function Yjb(a, b) { + return b == null ? !!qtb(a.f, null) : Jtb(a.i, b); + } + function hYb(a, b) { + var c2; + c2 = $sb(a.a, b); + c2 && (b.d = null); + return c2; + } + function MGb(a, b, c2) { + if (a.f) { + return a.f.ef(b, c2); + } + return false; + } + function cFc(a, b, c2, d) { + bD(a.c[b.g], c2.g, d); + bD(a.c[c2.g], b.g, d); + } + function fFc(a, b, c2, d) { + bD(a.c[b.g], b.g, c2); + bD(a.b[b.g], b.g, d); + } + function sXc(a, b, c2) { + return Kfb(UD(c2.a)) <= a && Kfb(UD(c2.b)) >= b; + } + function yJc(a, b) { + this.g = a; + this.d = cD(WC(jR, 1), WAe, 10, 0, [b]); + } + function lHb(a) { + this.c = a; + this.b = new yAb(RD(Qb(new oHb()), 50)); + } + function UYb(a) { + this.c = a; + this.b = new yAb(RD(Qb(new XYb()), 50)); + } + function $Qb(a) { + this.b = a; + this.a = new yAb(RD(Qb(new bRb()), 50)); + } + function tRc() { + this.b = new _sb(); + this.d = new Yub(); + this.e = new Fyb(); + } + function VTb() { + this.c = new pjd(); + this.d = new pjd(); + this.e = new pjd(); + } + function a1b() { + this.a = new Ejd(); + this.b = (dk(3, iwe), new cnb(3)); + } + function i7d(a, b) { + this.e = a; + this.a = jJ; + this.b = pje(b); + this.c = b; + } + function Vid(a) { + this.c = a.c; + this.d = a.d; + this.b = a.b; + this.a = a.a; + } + function VLd(a, b, c2, d, e, f2) { + this.a = a; + NKd.call(this, b, c2, d, e, f2); + } + function aLd(a, b, c2, d, e, f2) { + this.a = a; + NKd.call(this, b, c2, d, e, f2); + } + function fge(a, b, c2, d, e, f2, g) { + return new lle(a.e, b, c2, d, e, f2, g); + } + function xhb(a, b, c2) { + return c2 >= 0 && lhb(a.substr(c2, b.length), b); + } + function hGd(a, b) { + return ZD(b, 149) && lhb(a.b, RD(b, 149).Pg()); + } + function Tde(a, b) { + return a.a ? b.Gh().Kc() : RD(b.Gh(), 71).Ii(); + } + function Qqb(a, b) { + var c2; + c2 = a.b.Qc(b); + Rqb(c2, a.b.gc()); + return c2; + } + function Ivb(a, b) { + if (a == null) { + throw Adb(new Ogb(b)); + } + return a; + } + function zYd(a) { + if (!a.u) { + yYd(a); + a.u = new w0d(a, a); + } + return a.u; + } + function Kx(a) { + this.a = (yob(), ZD(a, 59) ? new irb(a) : new Upb(a)); + } + function Uwd(a) { + var b; + b = RD(Ywd(a, 16), 29); + return !b ? a.ii() : b; + } + function lz(a, b) { + var c2; + c2 = nfb(a.Rm); + return b == null ? c2 : c2 + ": " + b; + } + function zhb(a, b, c2) { + AFb(b, c2, a.length); + return a.substr(b, c2 - b); + } + function VKb(a, b) { + RJb.call(this); + KKb(this); + this.a = a; + this.c = b; + } + function neb(a) { + !a ? vve : lz(a, a.ie()); + } + function Wz(a) { + Qz(); + $wnd.setTimeout(function() { + throw a; + }, 0); + } + function GHb() { + DHb(); + return cD(WC(uN, 1), jwe, 436, 0, [CHb, BHb]); + } + function OHb() { + LHb(); + return cD(WC(vN, 1), jwe, 435, 0, [JHb, KHb]); + } + function WUb() { + TUb(); + return cD(WC(BP, 1), jwe, 432, 0, [RUb, SUb]); + } + function S8b() { + P8b(); + return cD(WC(vS, 1), jwe, 517, 0, [O8b, N8b]); + } + function Rvc() { + Ovc(); + return cD(WC(lX, 1), jwe, 429, 0, [Mvc, Nvc]); + } + function buc() { + $tc(); + return cD(WC(cX, 1), jwe, 428, 0, [Ytc, Ztc]); + } + function mtc() { + jtc(); + return cD(WC($W, 1), jwe, 431, 0, [htc, itc]); + } + function vEc() { + sEc(); + return cD(WC(xX, 1), jwe, 430, 0, [qEc, rEc]); + } + function vNc() { + sNc(); + return cD(WC(MY, 1), jwe, 531, 0, [rNc, qNc]); + } + function D2c() { + x2c(); + return cD(WC(s0, 1), jwe, 501, 0, [v2c, w2c]); + } + function zQc() { + wQc(); + return cD(WC(FZ, 1), jwe, 523, 0, [vQc, uQc]); + } + function HQc() { + EQc(); + return cD(WC(GZ, 1), jwe, 522, 0, [CQc, DQc]); + } + function iTc() { + fTc(); + return cD(WC(b$, 1), jwe, 528, 0, [eTc, dTc]); + } + function Fuc() { + Cuc(); + return cD(WC(fX, 1), jwe, 488, 0, [Buc, Auc]); + } + function F8c() { + z8c(); + return cD(WC(l1, 1), jwe, 491, 0, [x8c, y8c]); + } + function H9c() { + B9c(); + return cD(WC(t12, 1), jwe, 492, 0, [z9c, A9c]); + } + function D_c() { + A_c(); + return cD(WC(K_, 1), jwe, 433, 0, [z_c, y_c]); + } + function a4c() { + Y3c(); + return cD(WC(H0, 1), jwe, 434, 0, [W3c, X3c]); + } + function gVc() { + dVc(); + return cD(WC(w$, 1), jwe, 465, 0, [bVc, cVc]); + } + function Pbd() { + Mbd(); + return cD(WC(O1, 1), jwe, 438, 0, [Lbd, Kbd]); + } + function rdd() { + ldd(); + return cD(WC(W1, 1), jwe, 437, 0, [kdd, jdd]); + } + function xqd() { + uqd(); + return cD(WC(M3, 1), jwe, 347, 0, [sqd, tqd]); + } + function Jvd(a, b, c2, d) { + return c2 >= 0 ? a.Uh(b, c2, d) : a.Ch(null, c2, d); + } + function ltd(a) { + if (a.b.b == 0) { + return a.a.sf(); + } + return Uub(a.b); + } + function vKd(a) { + if (a.p != 5) + throw Adb(new cgb()); + return Ydb(a.f); + } + function EKd(a) { + if (a.p != 5) + throw Adb(new cgb()); + return Ydb(a.k); + } + function P$d(a) { + dE(a.a) === dE((lYd(), kYd)) && Q$d(a); + return a.a; + } + function iad(a, b) { + a.b = b; + a.c > 0 && a.b > 0 && (a.g = Aad(a.c, a.b, a.a)); + } + function jad(a, b) { + a.c = b; + a.c > 0 && a.b > 0 && (a.g = Aad(a.c, a.b, a.a)); + } + function BUc(a, b) { + yUc(this, new rjd(a.a, a.b)); + zUc(this, gv(b)); + } + function Tp() { + Sp.call(this, new Usb(Sv(12))); + Lb(true); + this.a = 2; + } + function eue(a, b, c2) { + Vse(); + Wse.call(this, a); + this.b = b; + this.a = c2; + } + function C7d(a, b, c2) { + s7d(); + t7d.call(this, b); + this.a = a; + this.b = c2; + } + function qub(a) { + var b; + b = a.c.d.b; + a.b = b; + a.a = a.c.d; + b.a = a.c.d.b = a; + } + function Tub(a) { + return a.b == 0 ? null : (sFb(a.b != 0), Wub(a, a.a.a)); + } + function Xjb(a, b) { + return b == null ? Wd(qtb(a.f, null)) : Ktb(a.i, b); + } + function bzb(a, b, c2, d, e) { + return new Kzb(a, (cAb(), aAb), b, c2, d, e); + } + function Fnb(a, b) { + oFb(b); + return Hnb(a, $C(kE, Pwe, 28, b, 15, 1), b); + } + function Tx(a, b) { + Rb(a, "set1"); + Rb(b, "set2"); + return new ey(a, b); + } + function Kz(a, b) { + var c2 = Jz[a.charCodeAt(0)]; + return c2 == null ? a : c2; + } + function Xyb(a, b) { + var c2, d; + c2 = b; + d = new Gzb(); + Zyb(a, c2, d); + return d.d; + } + function EMb(a, b, c2, d) { + var e; + e = new TJb(); + b.a[c2.g] = e; + Wrb(a.b, d, e); + } + function SXb(a, b) { + var c2; + c2 = BXb(a.f, b); + return $id(fjd(c2), a.f.d); + } + function RFb(a) { + var b; + EJb(a.a); + DJb(a.a); + b = new PJb(a.a); + LJb(b); + } + function _Mb(a, b) { + $Mb(a, true); + Umb(a.e.Rf(), new dNb(a, true, b)); + } + function PSb(a, b) { + HSb(); + return a == vCd(JGd(b)) || a == vCd(LGd(b)); + } + function R0c(a, b) { + B0c(); + return RD(mQb(b, (h_c(), f_c)), 17).a == a; + } + function eE(a) { + return Math.max(Math.min(a, lve), -2147483648) | 0; + } + function sy(a) { + this.a = RD(Qb(a), 277); + this.b = (yob(), new jrb(a)); + } + function qbd(a, b, c2) { + this.i = new bnb(); + this.b = a; + this.g = b; + this.a = c2; + } + function had(a, b, c2) { + this.a = new bnb(); + this.e = a; + this.f = b; + this.c = c2; + } + function _9c(a, b, c2) { + this.c = new bnb(); + this.e = a; + this.f = b; + this.b = c2; + } + function TKb(a) { + RJb.call(this); + KKb(this); + this.a = a; + this.c = true; + } + function ieb(a) { + function b() { + } + b.prototype = a || {}; + return new b(); + } + function zfb(a) { + if (a.Ae()) { + return null; + } + var b = a.n; + return eeb[b]; + } + function kzd(a) { + if (a.Db >> 16 != 3) + return null; + return RD(a.Cb, 27); + } + function MCd(a) { + if (a.Db >> 16 != 9) + return null; + return RD(a.Cb, 27); + } + function Fzd(a) { + if (a.Db >> 16 != 6) + return null; + return RD(a.Cb, 74); + } + function dVc() { + dVc = geb; + bVc = new eVc(Nye, 0); + cVc = new eVc(Oye, 1); + } + function wQc() { + wQc = geb; + vQc = new xQc(Oye, 0); + uQc = new xQc(Nye, 1); + } + function EQc() { + EQc = geb; + CQc = new FQc(Zye, 0); + DQc = new FQc("UP", 1); + } + function Is() { + Is = geb; + Hs = ss((zs(), cD(WC(RG, 1), jwe, 549, 0, [ys]))); + } + function Wx(a) { + var b; + b = new atb(Sv(a.length)); + zob(b, a); + return b; + } + function B2b(a, b) { + a.b += b.b; + a.c += b.c; + a.d += b.d; + a.a += b.a; + return a; + } + function qmb(a, b) { + if (kmb(a, b)) { + Jmb(a); + return true; + } + return false; + } + function qC(a, b) { + if (b == null) { + throw Adb(new Ngb()); + } + return rC(a, b); + } + function nB(a, b) { + var c2; + c2 = a.q.getHours(); + a.q.setDate(b); + mB(a, c2); + } + function Xvd(a, b, c2) { + var d; + d = a.Ih(b); + d >= 0 ? a.bi(d, c2) : Svd(a, b, c2); + } + function Lvd(a, b) { + var c2; + c2 = a.Ih(b); + return c2 >= 0 ? a.Wh(c2) : Rvd(a, b); + } + function zo(a, b) { + var c2; + Qb(b); + for (c2 = a.a; c2; c2 = c2.c) { + b.Yd(c2.g, c2.i); + } + } + function pMc(a, b, c2) { + var d; + d = qMc(a, b, c2); + a.b = new _Lc(d.c.length); + } + function HId(a, b, c2) { + EId(); + !!a && Zjb(DId, a, b); + !!a && Zjb(CId, a, c2); + } + function bfc(a, b) { + Rec(); + return Geb(), RD(b.a, 17).a < a ? true : false; + } + function afc(a, b) { + Rec(); + return Geb(), RD(b.b, 17).a < a ? true : false; + } + function R7b(a, b) { + return $wnd.Math.abs(a) < $wnd.Math.abs(b) ? a : b; + } + function xCd(a) { + return !a.a && (a.a = new C5d(J4, a, 10, 11)), a.a.i > 0; + } + function sId(a) { + var b; + b = a.d; + b = a.bj(a.f); + WGd(a, b); + return b.Ob(); + } + function bHd(a, b) { + var c2; + c2 = new Kub(b); + Ve(c2, a); + return new dnb(c2); + } + function qKd(a) { + if (a.p != 0) + throw Adb(new cgb()); + return Pdb(a.f, 0); + } + function zKd(a) { + if (a.p != 0) + throw Adb(new cgb()); + return Pdb(a.k, 0); + } + function gBd(a) { + if (a.Db >> 16 != 7) + return null; + return RD(a.Cb, 241); + } + function xXd(a) { + if (a.Db >> 16 != 6) + return null; + return RD(a.Cb, 241); + } + function dCd(a) { + if (a.Db >> 16 != 7) + return null; + return RD(a.Cb, 167); + } + function vCd(a) { + if (a.Db >> 16 != 11) + return null; + return RD(a.Cb, 27); + } + function uWd(a) { + if (a.Db >> 16 != 17) + return null; + return RD(a.Cb, 29); + } + function kVd(a) { + if (a.Db >> 16 != 3) + return null; + return RD(a.Cb, 155); + } + function BDb(a) { + var b; + MCb(a); + b = new _sb(); + return CDb(a, new aEb(b)); + } + function xfb(a, b) { + var c2 = a.a = a.a || []; + return c2[b] || (c2[b] = a.ve(b)); + } + function qB(a, b) { + var c2; + c2 = a.q.getHours(); + a.q.setMonth(b); + mB(a, c2); + } + function oz(a, b) { + ez(this); + this.f = b; + this.g = a; + gz(this); + this.je(); + } + function TQb(a, b) { + this.a = a; + this.c = ajd(this.a); + this.b = new Vid(b); + } + function aGb(a, b, c2) { + this.a = b; + this.c = a; + this.b = (Qb(c2), new dnb(c2)); + } + function s$b(a, b, c2) { + this.a = b; + this.c = a; + this.b = (Qb(c2), new dnb(c2)); + } + function _Kc(a) { + this.a = a; + this.b = $C(qY, Nve, 2043, a.e.length, 0, 2); + } + function fGb() { + this.a = new Iub(); + this.e = new _sb(); + this.g = 0; + this.i = 0; + } + function EId() { + EId = geb; + DId = new Tsb(); + CId = new Tsb(); + IId(zK, new JId()); + } + function KFc() { + KFc = geb; + JFc = nfd(new ufd(), (sXb(), rXb), (hcc(), $bc)); + } + function RFc() { + RFc = geb; + QFc = nfd(new ufd(), (sXb(), rXb), (hcc(), $bc)); + } + function gGc() { + gGc = geb; + fGc = nfd(new ufd(), (sXb(), rXb), (hcc(), $bc)); + } + function ANc() { + ANc = geb; + zNc = pfd(new ufd(), (sXb(), rXb), (hcc(), ybc)); + } + function dOc() { + dOc = geb; + cOc = pfd(new ufd(), (sXb(), rXb), (hcc(), ybc)); + } + function gQc() { + gQc = geb; + fQc = pfd(new ufd(), (sXb(), rXb), (hcc(), ybc)); + } + function WQc() { + WQc = geb; + VQc = pfd(new ufd(), (sXb(), rXb), (hcc(), ybc)); + } + function dZd(a, b, c2, d, e, f2) { + return new P3d(a.e, b, a.Lj(), c2, d, e, f2); + } + function $jb(a, b, c2) { + return b == null ? rtb(a.f, null, c2) : Ltb(a.i, b, c2); + } + function Y0b(a, b) { + !!a.c && Ymb(a.c.g, a); + a.c = b; + !!a.c && Rmb(a.c.g, a); + } + function g3b(a, b) { + !!a.c && Ymb(a.c.a, a); + a.c = b; + !!a.c && Rmb(a.c.a, a); + } + function P3b(a, b) { + !!a.i && Ymb(a.i.j, a); + a.i = b; + !!a.i && Rmb(a.i.j, a); + } + function Z0b(a, b) { + !!a.d && Ymb(a.d.e, a); + a.d = b; + !!a.d && Rmb(a.d.e, a); + } + function _Sc(a, b) { + !!a.a && Ymb(a.a.k, a); + a.a = b; + !!a.a && Rmb(a.a.k, a); + } + function aTc(a, b) { + !!a.b && Ymb(a.b.f, a); + a.b = b; + !!a.b && Rmb(a.b.f, a); + } + function Odd(a, b) { + Pdd(a, a.b, a.c); + RD(a.b.b, 68); + !!b && RD(b.b, 68).b; + } + function j2c(a, b) { + return Qfb(RD(a.c, 65).c.e.b, RD(b.c, 65).c.e.b); + } + function k2c(a, b) { + return Qfb(RD(a.c, 65).c.e.a, RD(b.c, 65).c.e.a); + } + function YXb(a) { + NXb(); + return Geb(), RD(a.a, 86).d.e != 0 ? true : false; + } + function LXd(a, b) { + ZD(a.Cb, 184) && (RD(a.Cb, 184).tb = null); + PAd(a, b); + } + function CWd(a, b) { + ZD(a.Cb, 90) && v$d(yYd(RD(a.Cb, 90)), 4); + PAd(a, b); + } + function _5d(a, b) { + a6d(a, b); + ZD(a.Cb, 90) && v$d(yYd(RD(a.Cb, 90)), 2); + } + function JFd(a, b) { + var c2, d; + c2 = b.c; + d = c2 != null; + d && oDd(a, new OC(b.c)); + } + function v0d(a) { + var b, c2; + c2 = (jTd(), b = new s2d(), b); + l2d(c2, a); + return c2; + } + function E4d(a) { + var b, c2; + c2 = (jTd(), b = new s2d(), b); + l2d(c2, a); + return c2; + } + function Fr(a) { + var b; + while (true) { + b = a.Pb(); + if (!a.Ob()) { + return b; + } + } + } + function nq(a, b, c2) { + Rmb(a.a, (fn(), ck(b, c2), new gp(b, c2))); + return a; + } + function rge(a, b) { + return nke(), wWd(b) ? new ole(b, a) : new Eke(b, a); + } + function ojb(a) { + Pib(); + return Ddb(a, 0) >= 0 ? jjb(a) : Xib(jjb(Odb(a))); + } + function Asb(a) { + var b; + b = RD(UEb(a.b), 9); + return new Fsb(a.a, b, a.c); + } + function Qw(a, b) { + var c2; + c2 = RD(Xv(nd(a.a), b), 16); + return !c2 ? 0 : c2.gc(); + } + function Zmb(a, b, c2) { + var d; + xFb(b, c2, a.c.length); + d = c2 - b; + $Eb(a.c, b, d); + } + function Rkb(a, b, c2) { + xFb(b, c2, a.gc()); + this.c = a; + this.a = b; + this.b = c2 - b; + } + function fgd(a) { + this.c = new Yub(); + this.b = a.b; + this.d = a.c; + this.a = a.a; + } + function qjd(a) { + this.a = $wnd.Math.cos(a); + this.b = $wnd.Math.sin(a); + } + function bTc(a, b, c2, d) { + this.c = a; + this.d = d; + _Sc(this, b); + aTc(this, c2); + } + function Si(a, b) { + Qi.call(this, new Usb(Sv(a))); + dk(b, Mve); + this.a = b; + } + function Ryb(a, b, c2) { + return new Kzb(a, (cAb(), _zb), null, false, b, c2); + } + function czb(a, b, c2) { + return new Kzb(a, (cAb(), bAb), b, c2, null, false); + } + function ABb() { + xBb(); + return cD(WC(QL, 1), jwe, 108, 0, [uBb, vBb, wBb]); + } + function yLb() { + vLb(); + return cD(WC(TN, 1), jwe, 472, 0, [uLb, tLb, sLb]); + } + function HKb() { + EKb(); + return cD(WC(MN, 1), jwe, 471, 0, [CKb, BKb, DKb]); + } + function aKb() { + ZJb(); + return cD(WC(JN, 1), jwe, 237, 0, [WJb, XJb, YJb]); + } + function DWb() { + AWb(); + return cD(WC(JP, 1), jwe, 391, 0, [yWb, xWb, zWb]); + } + function moc() { + joc(); + return cD(WC(UV, 1), jwe, 372, 0, [ioc, hoc, goc]); + } + function ytc() { + stc(); + return cD(WC(_W, 1), jwe, 322, 0, [qtc, ptc, rtc]); + } + function Htc() { + Etc(); + return cD(WC(aX, 1), jwe, 351, 0, [Btc, Dtc, Ctc]); + } + function kuc() { + huc(); + return cD(WC(dX, 1), jwe, 460, 0, [fuc, euc, guc]); + } + function Avc() { + xvc(); + return cD(WC(jX, 1), jwe, 299, 0, [vvc, wvc, uvc]); + } + function Jvc() { + Gvc(); + return cD(WC(kX, 1), jwe, 311, 0, [Evc, Fvc, Dvc]); + } + function pDc() { + lDc(); + return cD(WC(sX, 1), jwe, 390, 0, [iDc, jDc, kDc]); + } + function EEc() { + BEc(); + return cD(WC(yX, 1), jwe, 463, 0, [AEc, yEc, zEc]); + } + function NEc() { + KEc(); + return cD(WC(zX, 1), jwe, 387, 0, [HEc, IEc, JEc]); + } + function WEc() { + TEc(); + return cD(WC(AX, 1), jwe, 349, 0, [SEc, QEc, REc]); + } + function oFc() { + lFc(); + return cD(WC(CX, 1), jwe, 350, 0, [iFc, jFc, kFc]); + } + function xFc() { + uFc(); + return cD(WC(DX, 1), jwe, 352, 0, [tFc, rFc, sFc]); + } + function GFc() { + DFc(); + return cD(WC(EX, 1), jwe, 388, 0, [BFc, CFc, AFc]); + } + function UKc() { + RKc(); + return cD(WC(nY, 1), jwe, 464, 0, [OKc, PKc, QKc]); + } + function K3b(a) { + return xjd(cD(WC(l3, 1), Nve, 8, 0, [a.i.n, a.n, a.a])); + } + function OZc() { + LZc(); + return cD(WC(F_, 1), jwe, 392, 0, [KZc, JZc, IZc]); + } + function H_c() { + H_c = geb; + G_c = nfd(new ufd(), (YVc(), WVc), (WYc(), MYc)); + } + function A_c() { + A_c = geb; + z_c = new B_c("DFS", 0); + y_c = new B_c("BFS", 1); + } + function TQc(a, b, c2) { + var d; + d = new SQc(); + d.b = b; + d.a = c2; + ++b.b; + Rmb(a.d, d); + } + function NTb(a, b, c2) { + var d; + d = new sjd(c2.d); + $id(d, a); + CGd(b, d.a, d.b); + } + function Nwb(a, b) { + Mwb(a, Ydb(Cdb(Tdb(b, 24), Pxe)), Ydb(Cdb(b, Pxe))); + } + function wFb(a, b) { + if (a < 0 || a > b) { + throw Adb(new veb(cye + a + dye + b)); + } + } + function tFb(a, b) { + if (a < 0 || a >= b) { + throw Adb(new veb(cye + a + dye + b)); + } + } + function BFb(a, b) { + if (a < 0 || a >= b) { + throw Adb(new eib(cye + a + dye + b)); + } + } + function Swb(a, b) { + this.b = (uFb(a), a); + this.a = (b & qxe) == 0 ? b | 64 | Ove : b; + } + function ODb(a) { + var b; + MCb(a); + b = (urb(), urb(), srb); + return PDb(a, b); + } + function R9c(a, b, c2) { + var d; + d = S9c(a, b, false); + return d.b <= b && d.a <= c2; + } + function h9c() { + b9c(); + return cD(WC(o1, 1), jwe, 439, 0, [$8c, a9c, _8c]); + } + function c7c() { + _6c(); + return cD(WC(a1, 1), jwe, 394, 0, [Z6c, $6c, Y6c]); + } + function i6c() { + f6c(); + return cD(WC(V0, 1), jwe, 445, 0, [c6c, d6c, e6c]); + } + function D6c() { + z6c(); + return cD(WC(Z0, 1), jwe, 456, 0, [w6c, y6c, x6c]); + } + function k4c() { + g4c(); + return cD(WC(I0, 1), jwe, 393, 0, [d4c, e4c, f4c]); + } + function x5c() { + t5c(); + return cD(WC(N0, 1), jwe, 300, 0, [r5c, s5c, q5c]); + } + function Ind() { + Fnd(); + return cD(WC(y3, 1), jwe, 346, 0, [Dnd, Cnd, End]); + } + function jbd() { + gbd(); + return cD(WC(I1, 1), jwe, 444, 0, [dbd, ebd, fbd]); + } + function Rmd() { + Omd(); + return cD(WC(t32, 1), jwe, 278, 0, [Lmd, Mmd, Nmd]); + } + function pqd() { + mqd(); + return cD(WC(J3, 1), jwe, 280, 0, [kqd, jqd, lqd]); + } + function bv(a) { + Qb(a); + return ZD(a, 16) ? new dnb(RD(a, 16)) : cv(a.Kc()); + } + function Hz(a, b) { + return !!a && !!a.equals ? a.equals(b) : dE(a) === dE(b); + } + function Cdb(a, b) { + return Edb(tD(Kdb(a) ? Wdb(a) : a, Kdb(b) ? Wdb(b) : b)); + } + function Rdb(a, b) { + return Edb(zD(Kdb(a) ? Wdb(a) : a, Kdb(b) ? Wdb(b) : b)); + } + function $db(a, b) { + return Edb(HD(Kdb(a) ? Wdb(a) : a, Kdb(b) ? Wdb(b) : b)); + } + function xs(a, b) { + var c2; + c2 = (uFb(a), a).g; + lFb(!!c2); + uFb(b); + return c2(b); + } + function rv(a, b) { + var c2, d; + d = tv(a, b); + c2 = a.a.fd(d); + return new Gv(a, c2); + } + function CXd(a) { + if (a.Db >> 16 != 6) + return null; + return RD(yvd(a), 241); + } + function sKd(a) { + if (a.p != 2) + throw Adb(new cgb()); + return Ydb(a.f) & Bwe; + } + function BKd(a) { + if (a.p != 2) + throw Adb(new cgb()); + return Ydb(a.k) & Bwe; + } + function ynb(a) { + sFb(a.a < a.c.c.length); + a.b = a.a++; + return a.c.c[a.b]; + } + function $Gb(a, b) { + a.b = a.b | b.b; + a.c = a.c | b.c; + a.d = a.d | b.d; + a.a = a.a | b.a; + } + function NJb(a, b) { + var c2; + c2 = Kfb(UD(a.a.of((umd(), cmd)))); + OJb(a, b, c2); + } + function bjb(a, b) { + cjb.call(this, 1, 2, cD(WC(kE, 1), Pwe, 28, 15, [a, b])); + } + function Yte(a, b, c2) { + Wse.call(this, 25); + this.b = a; + this.a = b; + this.c = c2; + } + function xte(a) { + Vse(); + Wse.call(this, a); + this.c = false; + this.a = false; + } + function xfe(a) { + a.a == (ree(), qee) && Dfe(a, see(a.g, a.b)); + return a.a; + } + function zfe(a) { + a.d == (ree(), qee) && Ffe(a, wee(a.g, a.b)); + return a.d; + } + function IZb(a, b) { + CZb(); + return a.c == b.c ? Qfb(b.d, a.d) : Qfb(b.c, a.c); + } + function GZb(a, b) { + CZb(); + return a.c == b.c ? Qfb(b.d, a.d) : Qfb(a.c, b.c); + } + function HZb(a, b) { + CZb(); + return a.c == b.c ? Qfb(a.d, b.d) : Qfb(a.c, b.c); + } + function JZb(a, b) { + CZb(); + return a.c == b.c ? Qfb(a.d, b.d) : Qfb(b.c, a.c); + } + function Yrb(a, b) { + return Dsb(a.a, b) ? _Eb(a.b, RD(b, 22).g, null) : null; + } + function Lwb(a) { + return Bdb(Sdb(Hdb(Kwb(a, 32)), 32), Hdb(Kwb(a, 32))); + } + function kUb(a) { + return a.b == null || a.b.length == 0 ? "n_" + a.a : "n_" + a.b; + } + function aXc(a) { + return a.c == null || a.c.length == 0 ? "n_" + a.g : "n_" + a.c; + } + function wYc(a, b) { + var c2; + c2 = a + ""; + while (c2.length < b) { + c2 = "0" + c2; + } + return c2; + } + function vkc(a, b) { + var c2; + c2 = RD(Wjb(a.g, b), 60); + Umb(b.d, new ulc(a, c2)); + } + function J_b(a, b) { + var c2, d; + c2 = l2b(a); + d = l2b(b); + return c2 < d ? -1 : c2 > d ? 1 : 0; + } + function Hmc(a, b) { + var c2, d; + c2 = Gmc(b); + d = c2; + return RD(Wjb(a.c, d), 17).a; + } + function CMc(a, b, c2) { + var d; + d = a.d[b.p]; + a.d[b.p] = a.d[c2.p]; + a.d[c2.p] = d; + } + function Jqd(a, b, c2) { + var d; + if (a.n && !!b && !!c2) { + d = new otd(); + Rmb(a.e, d); + } + } + function gYb(a, b) { + Ysb(a.a, b); + if (b.d) { + throw Adb(new yz(jye)); + } + b.d = a; + } + function Had(a, b) { + this.a = new bnb(); + this.d = new bnb(); + this.f = a; + this.c = b; + } + function RWb() { + this.c = new dXb(); + this.a = new I_b(); + this.b = new E0b(); + g0b(); + } + function med() { + hed(); + this.b = new Tsb(); + this.a = new Tsb(); + this.c = new bnb(); + } + function KKd(a, b, c2) { + this.d = a; + this.j = b; + this.e = c2; + this.o = -1; + this.p = 3; + } + function LKd(a, b, c2) { + this.d = a; + this.k = b; + this.f = c2; + this.o = -1; + this.p = 5; + } + function S3d(a, b, c2, d, e, f2) { + R3d.call(this, a, b, c2, d, e); + f2 && (this.o = -2); + } + function U3d(a, b, c2, d, e, f2) { + T3d.call(this, a, b, c2, d, e); + f2 && (this.o = -2); + } + function W3d(a, b, c2, d, e, f2) { + V3d.call(this, a, b, c2, d, e); + f2 && (this.o = -2); + } + function Y3d(a, b, c2, d, e, f2) { + X3d.call(this, a, b, c2, d, e); + f2 && (this.o = -2); + } + function $3d(a, b, c2, d, e, f2) { + Z3d.call(this, a, b, c2, d, e); + f2 && (this.o = -2); + } + function a4d(a, b, c2, d, e, f2) { + _3d.call(this, a, b, c2, d, e); + f2 && (this.o = -2); + } + function f4d(a, b, c2, d, e, f2) { + e4d.call(this, a, b, c2, d, e); + f2 && (this.o = -2); + } + function h4d(a, b, c2, d, e, f2) { + g4d.call(this, a, b, c2, d, e); + f2 && (this.o = -2); + } + function N7d(a, b, c2, d) { + t7d.call(this, c2); + this.b = a; + this.c = b; + this.d = d; + } + function mfe(a, b) { + this.f = a; + this.a = (ree(), pee); + this.c = pee; + this.b = b; + } + function Jfe(a, b) { + this.g = a; + this.d = (ree(), qee); + this.a = qee; + this.b = b; + } + function Gme(a, b) { + !a.c && (a.c = new Uge(a, 0)); + Fge(a.c, (nme(), fme), b); + } + function Oge(a, b) { + return Pge(a, b, ZD(b, 102) && (RD(b, 19).Bb & txe) != 0); + } + function lB(a, b) { + return Agb(Hdb(a.q.getTime()), Hdb(b.q.getTime())); + } + function gj(a) { + return fk(a.e.Rd().gc() * a.c.Rd().gc(), 16, new qj(a)); + } + function CYd(a) { + return !!a.u && tYd(a.u.a).i != 0 && !(!!a.n && d$d(a.n)); + } + function p4d(a) { + return !!a.a && o4d(a.a.a).i != 0 && !(!!a.b && o5d(a.b)); + } + function Cxd(a, b) { + if (b == 0) { + return !!a.o && a.o.f != 0; + } + return Kvd(a, b); + } + function Cc(a, b, c2) { + var d; + d = RD(a.Zb().xc(b), 16); + return !!d && d.Hc(c2); + } + function Gc(a, b, c2) { + var d; + d = RD(a.Zb().xc(b), 16); + return !!d && d.Mc(c2); + } + function _yb(a, b) { + var c2; + c2 = 1 - b; + a.a[c2] = azb(a.a[c2], c2); + return azb(a, b); + } + function DFb(a, b) { + var c2, d; + d = Cdb(a, yxe); + c2 = Sdb(b, 32); + return Rdb(c2, d); + } + function bGb(a, b, c2) { + var d; + d = (Qb(a), new dnb(a)); + _Fb(new aGb(d, b, c2)); + } + function t$b(a, b, c2) { + var d; + d = (Qb(a), new dnb(a)); + r$b(new s$b(d, b, c2)); + } + function vBd(a, b, c2, d, e, f2) { + wBd(a, b, c2, f2); + EYd(a, d); + FYd(a, e); + return a; + } + function Xhb(a, b, c2, d) { + a.a += "" + zhb(b == null ? vve : jeb(b), c2, d); + return a; + } + function Jkb(a, b) { + this.a = a; + Dkb.call(this, a); + wFb(b, a.gc()); + this.b = b; + } + function xmb(a) { + this.a = $C(jJ, rve, 1, mgb($wnd.Math.max(8, a)) << 1, 5, 1); + } + function t2b(a) { + return RD(anb(a, $C(jR, WAe, 10, a.c.length, 0, 1)), 199); + } + function s2b(a) { + return RD(anb(a, $C(WQ, VAe, 18, a.c.length, 0, 1)), 483); + } + function Iyb(a) { + return !a.a ? a.c : a.e.length == 0 ? a.a.a : a.a.a + ("" + a.e); + } + function Rib(a) { + while (a.d > 0 && a.a[--a.d] == 0) + ; + a.a[a.d++] == 0 && (a.e = 0); + } + function fvb(a) { + sFb(a.b.b != a.d.a); + a.c = a.b = a.b.b; + --a.a; + return a.c.c; + } + function sRc(a, b, c2) { + a.a = b; + a.c = c2; + a.b.a.$b(); + Xub(a.d); + aFb(a.e.a.c, 0); + } + function Z5c(a, b) { + var c2; + a.e = new R5c(); + c2 = Q2c(b); + _mb(c2, a.c); + $5c(a, c2, 0); + } + function zgd(a, b, c2, d) { + var e; + e = new Hgd(); + e.a = b; + e.b = c2; + e.c = d; + Mub(a.a, e); + } + function Agd(a, b, c2, d) { + var e; + e = new Hgd(); + e.a = b; + e.b = c2; + e.c = d; + Mub(a.b, e); + } + function Tb(a, b, c2) { + if (a < 0 || b < a || b > c2) { + throw Adb(new veb(Kb(a, b, c2))); + } + } + function Pb(a, b) { + if (a < 0 || a >= b) { + throw Adb(new veb(Ib(a, b))); + } + return a; + } + function qz(b) { + if (!("stack" in b)) { + try { + throw b; + } catch (a) { + } + } + return b; + } + function Zjc(a) { + Wjc(); + if (ZD(a.g, 10)) { + return RD(a.g, 10); + } + return null; + } + function nx(a) { + if (Ih(a).dc()) { + return false; + } + Jh(a, new rx()); + return true; + } + function Xdb(a) { + var b; + if (Kdb(a)) { + b = a; + return b == -0 ? 0 : b; + } + return ED(a); + } + function lkb(a, b) { + if (ZD(b, 44)) { + return Jd(a.a, RD(b, 44)); + } + return false; + } + function gsb(a, b) { + if (ZD(b, 44)) { + return Jd(a.a, RD(b, 44)); + } + return false; + } + function vub(a, b) { + if (ZD(b, 44)) { + return Jd(a.a, RD(b, 44)); + } + return false; + } + function RCb(a) { + var b; + LCb(a); + b = new Prb(); + ixb(a.a, new fDb(b)); + return b; + } + function Vae() { + var a, b, c2; + b = (c2 = (a = new s2d(), a), c2); + Rmb(Rae, b); + return b; + } + function mDb(a) { + var b; + LCb(a); + b = new ltb(); + ixb(a.a, new uDb(b)); + return b; + } + function jDb(a, b) { + if (a.a <= a.b) { + b.Dd(a.a++); + return true; + } + return false; + } + function xzb(a) { + yzb.call(this, a, (cAb(), $zb), null, false, null, false); + } + function $Rb() { + $Rb = geb; + ZRb = ss((VRb(), cD(WC($O, 1), jwe, 489, 0, [URb]))); + } + function CHc() { + CHc = geb; + BHc = yx(sgb(1), sgb(4)); + AHc = yx(sgb(1), sgb(2)); + } + function yXc(a, b) { + return new gud(b, njd(ajd(b.e), a, a), (Geb(), true)); + } + function fv(a) { + return new cnb((dk(a, lwe), dz(Bdb(Bdb(5, a), a / 10 | 0)))); + } + function Wi(a) { + return fk(a.e.Rd().gc() * a.c.Rd().gc(), 273, new kj(a)); + } + function u2b(a) { + return RD(anb(a, $C(xR, XAe, 12, a.c.length, 0, 1)), 2042); + } + function COc(a) { + dOc(); + return !W0b(a) && !(!W0b(a) && a.c.i.c == a.d.i.c); + } + function Y_c(a, b) { + R_c(); + return RD(mQb(b, (h_c(), W$c)), 17).a >= a.gc(); + } + function q8b(a, b) { + w8b(b, a); + y8b(a.d); + y8b(RD(mQb(a, (yCc(), cBc)), 214)); + } + function r8b(a, b) { + z8b(b, a); + B8b(a.d); + B8b(RD(mQb(a, (yCc(), cBc)), 214)); + } + function $0b(a, b, c2) { + !!a.d && Ymb(a.d.e, a); + a.d = b; + !!a.d && Qmb(a.d.e, c2, a); + } + function jPb(a, b, c2) { + return c2.f.c.length > 0 ? yPb(a.a, b, c2) : yPb(a.b, b, c2); + } + function Uz(a, b, c2) { + var d; + d = Sz(); + try { + return Rz(a, b, c2); + } finally { + Vz(d); + } + } + function wDd(a, b) { + var c2, d; + c2 = qC(a, b); + d = null; + !!c2 && (d = c2.pe()); + return d; + } + function yDd(a, b) { + var c2, d; + c2 = qC(a, b); + d = null; + !!c2 && (d = c2.se()); + return d; + } + function xDd(a, b) { + var c2, d; + c2 = JB(a, b); + d = null; + !!c2 && (d = c2.se()); + return d; + } + function zDd(a, b) { + var c2, d; + c2 = qC(a, b); + d = null; + !!c2 && (d = ADd(c2)); + return d; + } + function rEd(a, b, c2) { + var d; + d = uDd(c2); + Do(a.g, d, b); + Do(a.i, b, c2); + return b; + } + function UIc(a, b, c2) { + this.d = new fJc(this); + this.e = a; + this.i = b; + this.f = c2; + } + function Mk(a, b, c2, d) { + this.e = null; + this.c = a; + this.d = b; + this.a = c2; + this.b = d; + } + function urc(a, b, c2, d) { + nrc(this); + this.c = a; + this.e = b; + this.f = c2; + this.b = d; + } + function MKd(a, b, c2, d) { + this.d = a; + this.n = b; + this.g = c2; + this.o = d; + this.p = -1; + } + function Vc(a, b, c2, d) { + return ZD(c2, 59) ? new Kg(a, b, c2, d) : new yg(a, b, c2, d); + } + function gr(a) { + if (ZD(a, 16)) { + return RD(a, 16).dc(); + } + return !a.Kc().Ob(); + } + function Wo(a) { + if (a.e.g != a.b) { + throw Adb(new Jrb()); + } + return !!a.c && a.d > 0; + } + function evb(a) { + sFb(a.b != a.d.c); + a.c = a.b; + a.b = a.b.a; + ++a.a; + return a.c.c; + } + function imb(a, b) { + uFb(b); + bD(a.a, a.c, b); + a.c = a.c + 1 & a.a.length - 1; + mmb(a); + } + function hmb(a, b) { + uFb(b); + a.b = a.b - 1 & a.a.length - 1; + bD(a.a, a.b, b); + mmb(a); + } + function _je(a) { + var b; + b = a.Gh(); + this.a = ZD(b, 71) ? RD(b, 71).Ii() : b.Kc(); + } + function px(a) { + return new Swb(Dob(RD(a.a.md(), 16).gc(), a.a.ld()), 16); + } + function Abd() { + Abd = geb; + zbd = ss((sbd(), cD(WC(M1, 1), jwe, 490, 0, [rbd]))); + } + function Jbd() { + Jbd = geb; + Ibd = ss((Cbd(), cD(WC(N1, 1), jwe, 558, 0, [Bbd]))); + } + function idd() { + idd = geb; + hdd = ss((_cd(), cD(WC(V1, 1), jwe, 539, 0, [$cd]))); + } + function X$b() { + U$b(); + return cD(WC(CQ, 1), jwe, 389, 0, [T$b, R$b, Q$b, S$b]); + } + function hAb() { + cAb(); + return cD(WC(AL, 1), jwe, 304, 0, [$zb, _zb, aAb, bAb]); + } + function LPb() { + IPb(); + return cD(WC(DO, 1), jwe, 332, 0, [FPb, EPb, GPb, HPb]); + } + function LRb() { + IRb(); + return cD(WC(WO, 1), jwe, 406, 0, [FRb, ERb, GRb, HRb]); + } + function pOb() { + mOb(); + return cD(WC(hO, 1), jwe, 417, 0, [lOb, iOb, jOb, kOb]); + } + function uZb() { + nZb(); + return cD(WC(lQ, 1), jwe, 416, 0, [jZb, mZb, kZb, lZb]); + } + function hnc() { + enc(); + return cD(WC(LV, 1), jwe, 421, 0, [anc, bnc, cnc, dnc]); + } + function zec() { + vec(); + return cD(WC(qT, 1), jwe, 371, 0, [uec, sec, tec, rec]); + } + function BDc() { + wDc(); + return cD(WC(tX, 1), jwe, 203, 0, [uDc, vDc, tDc, sDc]); + } + function nEc() { + kEc(); + return cD(WC(wX, 1), jwe, 284, 0, [hEc, gEc, iEc, jEc]); + } + function Unc(a) { + var b; + return a.j == (qpd(), npd) && (b = Vnc(a), Csb(b, Xod)); + } + function qhc(a, b) { + var c2; + c2 = b.a; + Y0b(c2, b.c.d); + Z0b(c2, b.d.d); + Cjd(c2.a, a.n); + } + function _5b(a, b) { + var c2; + c2 = RD(cub(a.b, b), 67); + !c2 && (c2 = new Yub()); + return c2; + } + function $jc(a) { + Wjc(); + if (ZD(a.g, 154)) { + return RD(a.g, 154); + } + return null; + } + function gRc(a) { + a.a = null; + a.e = null; + aFb(a.b.c, 0); + aFb(a.f.c, 0); + a.c = null; + } + function Ovc() { + Ovc = geb; + Mvc = new Pvc(Kye, 0); + Nvc = new Pvc("TOP_LEFT", 1); + } + function sNc() { + sNc = geb; + rNc = new tNc("UPPER", 0); + qNc = new tNc("LOWER", 1); + } + function nWc(a, b) { + return cjd(new rjd(b.e.a + b.f.a / 2, b.e.b + b.f.b / 2), a); + } + function wqc(a, b) { + return RD(Lvb(JDb(RD(Qc(a.k, b), 15).Oc(), lqc)), 113); + } + function xqc(a, b) { + return RD(Lvb(KDb(RD(Qc(a.k, b), 15).Oc(), lqc)), 113); + } + function cWc() { + YVc(); + return cD(WC(H$, 1), jwe, 405, 0, [UVc, VVc, WVc, XVc]); + } + function v_c() { + s_c(); + return cD(WC(J_, 1), jwe, 353, 0, [r_c, p_c, q_c, o_c]); + } + function n5c() { + j5c(); + return cD(WC(M0, 1), jwe, 354, 0, [i5c, g5c, h5c, f5c]); + } + function Tpd() { + Qpd(); + return cD(WC(H3, 1), jwe, 386, 0, [Opd, Ppd, Npd, Mpd]); + } + function Tnd() { + Pnd(); + return cD(WC(z3, 1), jwe, 291, 0, [Ond, Lnd, Mnd, Nnd]); + } + function _md() { + Ymd(); + return cD(WC(u3, 1), jwe, 223, 0, [Xmd, Vmd, Umd, Wmd]); + } + function Jrd() { + Grd(); + return cD(WC(R3, 1), jwe, 320, 0, [Frd, Crd, Erd, Drd]); + } + function wtd() { + ttd(); + return cD(WC(n4, 1), jwe, 415, 0, [qtd, rtd, ptd, std]); + } + function GId(a) { + EId(); + return Ujb(DId, a) ? RD(Wjb(DId, a), 341).Qg() : null; + } + function Avd(a, b, c2) { + return b < 0 ? Rvd(a, c2) : RD(c2, 69).wk().Bk(a, a.hi(), b); + } + function sEd(a, b, c2) { + var d; + d = uDd(c2); + Do(a.j, d, b); + Zjb(a.k, b, c2); + return b; + } + function qEd(a, b, c2) { + var d; + d = uDd(c2); + Do(a.d, d, b); + Zjb(a.e, b, c2); + return b; + } + function DGd(a) { + var b, c2; + b = (bvd(), c2 = new rzd(), c2); + !!a && pzd(b, a); + return b; + } + function WHd(a) { + var b; + b = a.aj(a.i); + a.i > 0 && hib(a.g, 0, b, 0, a.i); + return b; + } + function Led(a, b) { + var c2; + for (c2 = a.j.c.length; c2 < b; c2++) { + Rmb(a.j, a.Ng()); + } + } + function $Ec(a, b, c2, d) { + var e; + e = d[b.g][c2.g]; + return Kfb(UD(mQb(a.a, e))); + } + function QRd(a, b) { + PRd(); + var c2; + c2 = RD(Wjb(ORd, a), 57); + return !c2 || c2.fk(b); + } + function rKd(a) { + if (a.p != 1) + throw Adb(new cgb()); + return Ydb(a.f) << 24 >> 24; + } + function AKd(a) { + if (a.p != 1) + throw Adb(new cgb()); + return Ydb(a.k) << 24 >> 24; + } + function GKd(a) { + if (a.p != 7) + throw Adb(new cgb()); + return Ydb(a.k) << 16 >> 16; + } + function xKd(a) { + if (a.p != 7) + throw Adb(new cgb()); + return Ydb(a.f) << 16 >> 16; + } + function Wib(a, b) { + if (b.e == 0 || a.e == 0) { + return Oib; + } + return Ljb(), Mjb(a, b); + } + function Nd(a, b) { + return dE(b) === dE(a) ? "(this Map)" : b == null ? vve : jeb(b); + } + function MFb(a, b, c2) { + return Jfb(UD(Wd(qtb(a.f, b))), UD(Wd(qtb(a.f, c2)))); + } + function wkc(a, b, c2) { + var d; + d = RD(Wjb(a.g, c2), 60); + Rmb(a.a.c, new Ptd(b, d)); + } + function Slc(a, b, c2) { + a.i = 0; + a.e = 0; + if (b == c2) { + return; + } + Rlc(a, b, c2); + Qlc(a, b, c2); + } + function rTc(a, b, c2, d, e) { + var f2; + f2 = mTc(e, c2, d); + Rmb(b, TSc(e, f2)); + vTc(a, e, b); + } + function Jrc(a, b, c2, d, e) { + this.i = a; + this.a = b; + this.e = c2; + this.j = d; + this.f = e; + } + function iUb(a, b) { + VTb.call(this); + this.a = a; + this.b = b; + Rmb(this.a.b, this); + } + function rTb(a) { + this.b = new Tsb(); + this.c = new Tsb(); + this.d = new Tsb(); + this.a = a; + } + function Dx(a, b) { + var c2; + c2 = new cib(); + a.Gd(c2); + c2.a += ".."; + b.Hd(c2); + return c2.a; + } + function Fsd(a, b) { + var c2; + c2 = b; + while (c2) { + Zid(a, c2.i, c2.j); + c2 = vCd(c2); + } + return a; + } + function pEd(a, b, c2) { + var d; + d = uDd(c2); + Zjb(a.b, d, b); + Zjb(a.c, b, c2); + return b; + } + function Kr(a) { + var b; + b = 0; + while (a.Ob()) { + a.Pb(); + b = Bdb(b, 1); + } + return dz(b); + } + function oke(a, b) { + nke(); + var c2; + c2 = RD(a, 69).vk(); + K6d(c2, b); + return c2.xl(b); + } + function tC(d, a, b) { + if (b) { + var c2 = b.oe(); + d.a[a] = c2(b); + } else { + delete d.a[a]; + } + } + function tB(a, b) { + var c2; + c2 = a.q.getHours(); + a.q.setFullYear(b + Owe); + mB(a, c2); + } + function KSd(a, b) { + return RD(b == null ? Wd(qtb(a.f, null)) : Ktb(a.i, b), 288); + } + function hOc(a, b) { + return a == (r3b(), p3b) && b == p3b ? 4 : a == p3b || b == p3b ? 8 : 32; + } + function cge(a, b, c2) { + return dge(a, b, c2, ZD(b, 102) && (RD(b, 19).Bb & txe) != 0); + } + function jge(a, b, c2) { + return kge(a, b, c2, ZD(b, 102) && (RD(b, 19).Bb & txe) != 0); + } + function Qge(a, b, c2) { + return Rge(a, b, c2, ZD(b, 102) && (RD(b, 19).Bb & txe) != 0); + } + function jmb(a) { + if (a.b == a.c) { + return; + } + a.a = $C(jJ, rve, 1, 8, 5, 1); + a.b = 0; + a.c = 0; + } + function Nsb(a) { + sFb(a.a < a.c.a.length); + a.b = a.a; + Lsb(a); + return a.c.b[a.b]; + } + function tYd(a) { + if (!a.n) { + yYd(a); + a.n = new h$d(a, o7, a); + zYd(a); + } + return a.n; + } + function oFb(a) { + if (a < 0) { + throw Adb(new Mgb("Negative array size: " + a)); + } + } + function LB(d, a, b) { + if (b) { + var c2 = b.oe(); + b = c2(b); + } else { + b = void 0; + } + d.a[a] = b; + } + function ygc(a, b) { + sgc(); + var c2; + c2 = a.j.g - b.j.g; + if (c2 != 0) { + return c2; + } + return 0; + } + function l_d(a, b) { + gib(); + return WGd(xYd(a.a), b); + } + function q_d(a, b) { + gib(); + return WGd(xYd(a.a), b); + } + function ajb(a, b) { + Pib(); + cjb.call(this, a, 1, cD(WC(kE, 1), Pwe, 28, 15, [b])); + } + function Kte(a, b) { + Vse(); + Wse.call(this, a); + this.a = b; + this.c = -1; + this.b = -1; + } + function L3d(a, b, c2, d) { + KKd.call(this, 1, c2, d); + this.c = a; + this.b = b; + } + function M3d(a, b, c2, d) { + LKd.call(this, 1, c2, d); + this.c = a; + this.b = b; + } + function lle(a, b, c2, d, e, f2, g) { + NKd.call(this, b, d, e, f2, g); + this.c = a; + this.a = c2; + } + function j7d(a, b, c2) { + this.e = a; + this.a = jJ; + this.b = pje(b); + this.c = b; + this.d = c2; + } + function Xo(a) { + this.e = a; + this.c = this.e.a; + this.b = this.e.g; + this.d = this.e.i; + } + function Qtb(a) { + this.d = a; + this.b = this.d.a.entries(); + this.a = this.b.next(); + } + function N9d(a) { + this.c = a; + this.a = RD(WVd(a), 156); + this.b = this.a.jk().wi(); + } + function gub() { + Tsb.call(this); + _tb(this); + this.d.b = this.d; + this.d.a = this.d; + } + function Pub(a, b, c2, d) { + var e; + e = new svb(); + e.c = b; + e.b = c2; + e.a = d; + d.b = c2.a = e; + ++a.b; + } + function USd(a, b) { + var c2; + return c2 = b != null ? Xjb(a, b) : Wd(qtb(a.f, b)), fE(c2); + } + function dTd(a, b) { + var c2; + return c2 = b != null ? Xjb(a, b) : Wd(qtb(a.f, b)), fE(c2); + } + function zDb(a, b) { + var c2; + return b.b.Kb(LDb(a, b.c.Xe(), (c2 = new OEb(b), c2))); + } + function Gnb(a, b) { + var c2; + oFb(b); + return c2 = a.slice(0, b), c2.length = b, dD(c2, a); + } + function Rqb(a, b) { + var c2; + for (c2 = 0; c2 < b; ++c2) { + bD(a, c2, new brb(RD(a[c2], 44))); + } + } + function Tib(a, b) { + var c2; + for (c2 = a.d - 1; c2 >= 0 && a.a[c2] === b[c2]; c2--) + ; + return c2 < 0; + } + function Xx(a) { + var b; + if (a) { + return new Kub(a); + } + b = new Iub(); + _q(b, a); + return b; + } + function nmc(a, b) { + var c2, d; + d = false; + do { + c2 = qmc(a, b); + d = d | c2; + } while (c2); + return d; + } + function Vz(a) { + a && aA(($z(), Zz)); + --Nz; + if (a) { + if (Pz != -1) { + Xz(Pz); + Pz = -1; + } + } + } + function Pwb(a) { + Hwb(); + Mwb(this, Ydb(Cdb(Tdb(a, 24), Pxe)), Ydb(Cdb(a, Pxe))); + } + function IHb() { + IHb = geb; + HHb = ss((DHb(), cD(WC(uN, 1), jwe, 436, 0, [CHb, BHb]))); + } + function QHb() { + QHb = geb; + PHb = ss((LHb(), cD(WC(vN, 1), jwe, 435, 0, [JHb, KHb]))); + } + function YUb() { + YUb = geb; + XUb = ss((TUb(), cD(WC(BP, 1), jwe, 432, 0, [RUb, SUb]))); + } + function U8b() { + U8b = geb; + T8b = ss((P8b(), cD(WC(vS, 1), jwe, 517, 0, [O8b, N8b]))); + } + function Tvc() { + Tvc = geb; + Svc = ss((Ovc(), cD(WC(lX, 1), jwe, 429, 0, [Mvc, Nvc]))); + } + function duc() { + duc = geb; + cuc = ss(($tc(), cD(WC(cX, 1), jwe, 428, 0, [Ytc, Ztc]))); + } + function Huc() { + Huc = geb; + Guc = ss((Cuc(), cD(WC(fX, 1), jwe, 488, 0, [Buc, Auc]))); + } + function xEc() { + xEc = geb; + wEc = ss((sEc(), cD(WC(xX, 1), jwe, 430, 0, [qEc, rEc]))); + } + function xNc() { + xNc = geb; + wNc = ss((sNc(), cD(WC(MY, 1), jwe, 531, 0, [rNc, qNc]))); + } + function otc() { + otc = geb; + ntc = ss((jtc(), cD(WC($W, 1), jwe, 431, 0, [htc, itc]))); + } + function F_c() { + F_c = geb; + E_c = ss((A_c(), cD(WC(K_, 1), jwe, 433, 0, [z_c, y_c]))); + } + function F2c() { + F2c = geb; + E2c = ss((x2c(), cD(WC(s0, 1), jwe, 501, 0, [v2c, w2c]))); + } + function BQc() { + BQc = geb; + AQc = ss((wQc(), cD(WC(FZ, 1), jwe, 523, 0, [vQc, uQc]))); + } + function JQc() { + JQc = geb; + IQc = ss((EQc(), cD(WC(GZ, 1), jwe, 522, 0, [CQc, DQc]))); + } + function kTc() { + kTc = geb; + jTc = ss((fTc(), cD(WC(b$, 1), jwe, 528, 0, [eTc, dTc]))); + } + function iVc() { + iVc = geb; + hVc = ss((dVc(), cD(WC(w$, 1), jwe, 465, 0, [bVc, cVc]))); + } + function c4c() { + c4c = geb; + b4c = ss((Y3c(), cD(WC(H0, 1), jwe, 434, 0, [W3c, X3c]))); + } + function H8c() { + H8c = geb; + G8c = ss((z8c(), cD(WC(l1, 1), jwe, 491, 0, [x8c, y8c]))); + } + function J9c() { + J9c = geb; + I9c = ss((B9c(), cD(WC(t12, 1), jwe, 492, 0, [z9c, A9c]))); + } + function Rbd() { + Rbd = geb; + Qbd = ss((Mbd(), cD(WC(O1, 1), jwe, 438, 0, [Lbd, Kbd]))); + } + function tdd() { + tdd = geb; + sdd = ss((ldd(), cD(WC(W1, 1), jwe, 437, 0, [kdd, jdd]))); + } + function Eqd() { + Eqd = geb; + Dqd = ss((uqd(), cD(WC(M3, 1), jwe, 347, 0, [sqd, tqd]))); + } + function Imd() { + Cmd(); + return cD(WC(s3, 1), jwe, 88, 0, [Amd, zmd, ymd, xmd, Bmd]); + } + function xpd() { + qpd(); + return cD(WC(E3, 1), NAe, 64, 0, [opd, Yod, Xod, npd, ppd]); + } + function LSd(a, b, c2) { + return RD(b == null ? rtb(a.f, null, c2) : Ltb(a.i, b, c2), 288); + } + function L6b(a) { + return (a.k == (r3b(), p3b) || a.k == m3b) && nQb(a, (Ywc(), cwc)); + } + function bUb(a) { + return !!a.c && !!a.d ? kUb(a.c) + "->" + kUb(a.d) : "e_" + kFb(a); + } + function xgb(a, b) { + var c2, d; + uFb(b); + for (d = a.Kc(); d.Ob(); ) { + c2 = d.Pb(); + b.Cd(c2); + } + } + function jEd(a, b) { + var c2; + c2 = new uC(); + qDd(c2, "x", b.a); + qDd(c2, "y", b.b); + oDd(a, c2); + } + function mEd(a, b) { + var c2; + c2 = new uC(); + qDd(c2, "x", b.a); + qDd(c2, "y", b.b); + oDd(a, c2); + } + function Gsd(a, b) { + var c2; + c2 = b; + while (c2) { + Zid(a, -c2.i, -c2.j); + c2 = vCd(c2); + } + return a; + } + function ZLc(a, b) { + var c2, d; + c2 = b; + d = 0; + while (c2 > 0) { + d += a.a[c2]; + c2 -= c2 & -c2; + } + return d; + } + function $mb(a, b, c2) { + var d; + d = (tFb(b, a.c.length), a.c[b]); + a.c[b] = c2; + return d; + } + function uIc(a, b, c2) { + a.a.c.length = 0; + yIc(a, b, c2); + a.a.c.length == 0 || rIc(a, b); + } + function wo(a) { + a.i = 0; + Mnb(a.b, null); + Mnb(a.c, null); + a.a = null; + a.e = null; + ++a.g; + } + function gBb() { + gBb = geb; + dBb = true; + bBb = false; + cBb = false; + fBb = false; + eBb = false; + } + function oBb(a) { + gBb(); + if (dBb) { + return; + } + this.c = a; + this.e = true; + this.a = new bnb(); + } + function kDb(a, b) { + this.c = 0; + this.b = b; + txb.call(this, a, 17493); + this.a = this.c; + } + function S_b(a) { + P_b(); + A$b(this); + this.a = new Yub(); + Q_b(this, a); + Mub(this.a, a); + } + function m_b() { + Pmb(this); + this.b = new rjd(oxe, oxe); + this.a = new rjd(pxe, pxe); + } + function z8c() { + z8c = geb; + x8c = new B8c(CBe, 0); + y8c = new B8c("TARGET_WIDTH", 1); + } + function yDb(a, b) { + return (MCb(a), QDb(new SDb(a, new hEb(b, a.a)))).Bd(wDb); + } + function vXb() { + sXb(); + return cD(WC(UP, 1), jwe, 367, 0, [nXb, oXb, pXb, qXb, rXb]); + } + function Fnc() { + Bnc(); + return cD(WC(TV, 1), jwe, 375, 0, [xnc, znc, Anc, ync, wnc]); + } + function Vtc() { + Ptc(); + return cD(WC(bX, 1), jwe, 348, 0, [Ltc, Ktc, Ntc, Otc, Mtc]); + } + function PDc() { + JDc(); + return cD(WC(uX, 1), jwe, 323, 0, [IDc, FDc, GDc, EDc, HDc]); + } + function fxc() { + cxc(); + return cD(WC(mX, 1), jwe, 171, 0, [bxc, Zwc, $wc, _wc, axc]); + } + function k3c() { + g3c(); + return cD(WC(x0, 1), jwe, 368, 0, [e3c, b3c, f3c, c3c, d3c]); + } + function vad() { + sad(); + return cD(WC(x1, 1), jwe, 373, 0, [oad, nad, qad, pad2, rad]); + } + function $bd() { + Xbd(); + return cD(WC(P1, 1), jwe, 324, 0, [Sbd, Tbd, Wbd, Ubd, Vbd]); + } + function _hd() { + Yhd(); + return cD(WC(d3, 1), jwe, 170, 0, [Whd, Vhd, Thd, Xhd, Uhd]); + } + function sod() { + pod(); + return cD(WC(B3, 1), jwe, 256, 0, [mod, ood, kod, lod, nod]); + } + function Tz(b) { + Qz(); + return function() { + return Uz(b, this, arguments); + }; + } + function W0b(a) { + if (!a.c || !a.d) { + return false; + } + return !!a.c.i && a.c.i == a.d.i; + } + function Nfd(a, b) { + if (ZD(b, 143)) { + return lhb(a.c, RD(b, 143).c); + } + return false; + } + function yYd(a) { + if (!a.t) { + a.t = new w$d(a); + VGd(new Cde(a), 0, a.t); + } + return a.t; + } + function jNd(a) { + this.b = a; + dMd.call(this, a); + this.a = RD(Ywd(this.b.a, 4), 129); + } + function sNd(a) { + this.b = a; + yMd.call(this, a); + this.a = RD(Ywd(this.b.a, 4), 129); + } + function Q3d(a, b, c2, d, e) { + OKd.call(this, b, d, e); + this.c = a; + this.b = c2; + } + function V3d(a, b, c2, d, e) { + KKd.call(this, b, d, e); + this.c = a; + this.a = c2; + } + function Z3d(a, b, c2, d, e) { + LKd.call(this, b, d, e); + this.c = a; + this.a = c2; + } + function g4d(a, b, c2, d, e) { + OKd.call(this, b, d, e); + this.c = a; + this.a = c2; + } + function ugd(a, b) { + var c2; + c2 = RD(cub(a.d, b), 23); + return c2 ? c2 : RD(cub(a.e, b), 23); + } + function Blb(a, b) { + var c2, d; + c2 = b.ld(); + d = a.Fe(c2); + return !!d && Fvb(d.e, b.md()); + } + function me(a, b) { + var c2; + c2 = b.ld(); + return new gp(c2, a.e.pc(c2, RD(b.md(), 16))); + } + function ptb(a, b) { + var c2; + c2 = a.a.get(b); + return c2 == null ? $C(jJ, rve, 1, 0, 5, 1) : c2; + } + function khb(a) { + var b; + b = a.length; + return lhb(sxe.substr(sxe.length - b, b), a); + } + function hs(a) { + if (gs(a)) { + a.c = a.a; + return a.a.Pb(); + } else { + throw Adb(new Dvb()); + } + } + function $ib(a, b) { + if (b == 0 || a.e == 0) { + return a; + } + return b > 0 ? tjb(a, b) : qjb(a, -b); + } + function Zib(a, b) { + if (b == 0 || a.e == 0) { + return a; + } + return b > 0 ? qjb(a, b) : tjb(a, -b); + } + function Deb(a) { + Beb.call(this, a == null ? vve : jeb(a), ZD(a, 82) ? RD(a, 82) : null); + } + function Y5d(a) { + var b; + if (!a.c) { + b = a.r; + ZD(b, 90) && (a.c = RD(b, 29)); + } + return a.c; + } + function s0b(a) { + var b; + b = new a1b(); + kQb(b, a); + pQb(b, (yCc(), RAc), null); + return b; + } + function lec(a) { + var b, c2; + b = a.c.i; + c2 = a.d.i; + return b.k == (r3b(), m3b) && c2.k == m3b; + } + function fD(a) { + var b, c2, d; + b = a & dxe; + c2 = a >> 22 & dxe; + d = a < 0 ? exe : 0; + return hD(b, c2, d); + } + function Ky(a) { + var b, c2, d, e; + for (c2 = a, d = 0, e = c2.length; d < e; ++d) { + b = c2[d]; + ICb(b); + } + } + function Tc2(a, b) { + var c2, d; + c2 = RD(Yv(a.c, b), 16); + if (c2) { + d = c2.gc(); + c2.$b(); + a.d -= d; + } + } + function Fvd(a, b, c2) { + var d; + return d = a.Ih(b), d >= 0 ? a.Lh(d, c2, true) : Qvd(a, b, c2); + } + function AXc(a, b, c2) { + return Qfb(cjd(jWc(a), ajd(b.b)), cjd(jWc(a), ajd(c2.b))); + } + function BXc(a, b, c2) { + return Qfb(cjd(jWc(a), ajd(b.e)), cjd(jWc(a), ajd(c2.e))); + } + function Kad(a, b) { + return $wnd.Math.min(bjd(b.a, a.d.d.c), bjd(b.b, a.d.d.c)); + } + function LHd(a, b) { + a._i(a.i + 1); + MHd(a, a.i, a.Zi(a.i, b)); + a.Mi(a.i++, b); + a.Ni(); + } + function OHd(a) { + var b, c2; + ++a.j; + b = a.g; + c2 = a.i; + a.g = null; + a.i = 0; + a.Oi(c2, b); + a.Ni(); + } + function yke(a, b, c2) { + var d; + d = new zke(a.a); + Ld(d, a.a.a); + rtb(d.f, b, c2); + a.a.a = d; + } + function mKb(a, b, c2, d) { + var e; + for (e = 0; e < jKb; e++) { + dKb(a.a[e][b.g], c2, d[b.g]); + } + } + function lKb(a, b, c2, d) { + var e; + for (e = 0; e < iKb; e++) { + eKb(a.a[b.g][e], c2, d[b.g]); + } + } + function Qc(a, b) { + var c2; + c2 = RD(a.c.xc(b), 16); + !c2 && (c2 = a.ic(b)); + return a.pc(b, c2); + } + function vm(a) { + var b; + b = (Qb(a), a ? new dnb(a) : cv(a.Kc())); + Eob(b); + return Pm(b); + } + function dv(a) { + var b, c2; + Qb(a); + b = Zu(a.length); + c2 = new cnb(b); + zob(c2, a); + return c2; + } + function Hjb(a, b, c2, d) { + var e; + e = $C(kE, Pwe, 28, b, 15, 1); + Ijb(e, a, b, c2, d); + return e; + } + function Sb(a, b) { + if (a < 0 || a > b) { + throw Adb(new veb(Jb(a, b, "index"))); + } + return a; + } + function Xmb(a, b) { + var c2; + c2 = (tFb(b, a.c.length), a.c[b]); + $Eb(a.c, b, 1); + return c2; + } + function jhb(a, b) { + var c2, d; + c2 = (uFb(a), a); + d = (uFb(b), b); + return c2 == d ? 0 : c2 < d ? -1 : 1; + } + function Orb(a) { + var b; + b = a.e + a.f; + if (isNaN(b) && Rfb(a.d)) { + return a.d; + } + return b; + } + function zc(a) { + a.e = 3; + a.d = a.Yb(); + if (a.e != 2) { + a.e = 0; + return true; + } + return false; + } + function Gyb(a, b) { + !a.a ? a.a = new dib(a.d) : Zhb(a.a, a.b); + Whb(a.a, b); + return a; + } + function _jb(a, b) { + return bE(b) ? b == null ? stb(a.f, null) : Mtb(a.i, b) : stb(a.f, b); + } + function nEb(a, b) { + pxb.call(this, b.zd(), b.yd() & -6); + uFb(a); + this.a = a; + this.b = b; + } + function tEb(a, b) { + txb.call(this, b.zd(), b.yd() & -6); + uFb(a); + this.a = a; + this.b = b; + } + function zEb(a, b) { + xxb.call(this, b.zd(), b.yd() & -6); + uFb(a); + this.a = a; + this.b = b; + } + function M7d(a, b, c2) { + t7d.call(this, c2); + this.b = a; + this.c = b; + this.d = (a8d(), $7d); + } + function OKd(a, b, c2) { + this.d = a; + this.k = b ? 1 : 0; + this.f = c2 ? 1 : 0; + this.o = -1; + this.p = 0; + } + function l4b(a) { + this.c = a; + this.a = new Anb(this.c.a); + this.b = new Anb(this.c.b); + } + function gUb() { + this.e = new bnb(); + this.c = new bnb(); + this.d = new bnb(); + this.b = new bnb(); + } + function DIb() { + this.g = new GIb(); + this.b = new GIb(); + this.a = new bnb(); + this.k = new bnb(); + } + function I_b() { + this.a = new J$b(); + this.b = new N$b(); + this.d = new Z_b(); + this.e = new V_b(); + } + function knc(a, b, c2) { + this.a = a; + this.c = b; + this.d = c2; + Rmb(b.e, this); + Rmb(c2.b, this); + } + function sIc(a, b, c2) { + var d, e; + d = 0; + for (e = 0; e < b.length; e++) { + d += a.tg(b[e], d, c2); + } + } + function nMc(a, b) { + var c2; + c2 = tMc(a, b); + a.b = new _Lc(c2.c.length); + return mMc(a, c2); + } + function pB(a, b) { + var c2; + c2 = a.q.getHours() + (b / 60 | 0); + a.q.setMinutes(b); + mB(a, c2); + } + function _Wc(a) { + var b; + b = a.b; + if (b.b == 0) { + return null; + } + return RD(ju(b, 0), 65).b; + } + function Src(a) { + if (a.a) { + if (a.e) { + return Src(a.e); + } + } else { + return a; + } + return null; + } + function mIc(a, b) { + if (a.p < b.p) { + return 1; + } else if (a.p > b.p) { + return -1; + } + return 0; + } + function hXd(a) { + var b; + if (!a.a) { + b = a.r; + ZD(b, 156) && (a.a = RD(b, 156)); + } + return a.a; + } + function iOd(a, b, c2) { + var d; + ++a.e; + --a.f; + d = RD(a.d[b].gd(c2), 136); + return d.md(); + } + function fd(a) { + var b, c2; + b = a.ld(); + c2 = RD(a.md(), 16); + return gk(c2.Nc(), new jh(b)); + } + function oae(a, b) { + if (Ujb(a.a, b)) { + _jb(a.a, b); + return true; + } else { + return false; + } + } + function Ui(a, b, c2) { + Pb(b, a.e.Rd().gc()); + Pb(c2, a.c.Rd().gc()); + return a.a[b][c2]; + } + function _Uc(a, b, c2) { + this.a = a; + this.b = b; + this.c = c2; + Rmb(a.t, this); + Rmb(b.i, this); + } + function lg(a, b, c2, d) { + this.f = a; + this.e = b; + this.d = c2; + this.b = d; + this.c = !d ? null : d.d; + } + function YWc() { + this.b = new Yub(); + this.a = new Yub(); + this.b = new Yub(); + this.a = new Yub(); + } + function ree() { + ree = geb; + var a, b; + pee = (jTd(), b = new k1d(), b); + qee = (a = new mXd(), a); + } + function UCb(a) { + var b; + MCb(a); + b = new $Cb(a, a.a.e, a.a.d | 4); + return new WCb(a, b); + } + function ADb(a) { + var b; + LCb(a); + b = 0; + while (a.a.Bd(new MEb())) { + b = Bdb(b, 1); + } + return b; + } + function zxb(a, b) { + uFb(b); + if (a.c < a.d) { + a.Se(b, a.c++); + return true; + } + return false; + } + function cnb(a) { + Pmb(this); + mFb(a >= 0, "Initial capacity must not be negative"); + } + function rid() { + rid = geb; + qid = new jGd("org.eclipse.elk.labels.labelManager"); + } + function iec() { + iec = geb; + hec = new kGd("separateLayerConnections", (vec(), uec)); + } + function fTc() { + fTc = geb; + eTc = new gTc("REGULAR", 0); + dTc = new gTc("CRITICAL", 1); + } + function Mbd() { + Mbd = geb; + Lbd = new Nbd("FIXED", 0); + Kbd = new Nbd("CENTER_NODE", 1); + } + function jtc() { + jtc = geb; + htc = new ktc("QUADRATIC", 0); + itc = new ktc("SCANLINE", 1); + } + function Atc() { + Atc = geb; + ztc = ss((stc(), cD(WC(_W, 1), jwe, 322, 0, [qtc, ptc, rtc]))); + } + function Jtc() { + Jtc = geb; + Itc = ss((Etc(), cD(WC(aX, 1), jwe, 351, 0, [Btc, Dtc, Ctc]))); + } + function ooc() { + ooc = geb; + noc = ss((joc(), cD(WC(UV, 1), jwe, 372, 0, [ioc, hoc, goc]))); + } + function muc() { + muc = geb; + luc = ss((huc(), cD(WC(dX, 1), jwe, 460, 0, [fuc, euc, guc]))); + } + function Cvc() { + Cvc = geb; + Bvc = ss((xvc(), cD(WC(jX, 1), jwe, 299, 0, [vvc, wvc, uvc]))); + } + function Lvc() { + Lvc = geb; + Kvc = ss((Gvc(), cD(WC(kX, 1), jwe, 311, 0, [Evc, Fvc, Dvc]))); + } + function rDc() { + rDc = geb; + qDc = ss((lDc(), cD(WC(sX, 1), jwe, 390, 0, [iDc, jDc, kDc]))); + } + function PEc() { + PEc = geb; + OEc = ss((KEc(), cD(WC(zX, 1), jwe, 387, 0, [HEc, IEc, JEc]))); + } + function YEc() { + YEc = geb; + XEc = ss((TEc(), cD(WC(AX, 1), jwe, 349, 0, [SEc, QEc, REc]))); + } + function GEc() { + GEc = geb; + FEc = ss((BEc(), cD(WC(yX, 1), jwe, 463, 0, [AEc, yEc, zEc]))); + } + function qFc() { + qFc = geb; + pFc = ss((lFc(), cD(WC(CX, 1), jwe, 350, 0, [iFc, jFc, kFc]))); + } + function zFc() { + zFc = geb; + yFc = ss((uFc(), cD(WC(DX, 1), jwe, 352, 0, [tFc, rFc, sFc]))); + } + function IFc() { + IFc = geb; + HFc = ss((DFc(), cD(WC(EX, 1), jwe, 388, 0, [BFc, CFc, AFc]))); + } + function QZc() { + QZc = geb; + PZc = ss((LZc(), cD(WC(F_, 1), jwe, 392, 0, [KZc, JZc, IZc]))); + } + function m4c() { + m4c = geb; + l4c = ss((g4c(), cD(WC(I0, 1), jwe, 393, 0, [d4c, e4c, f4c]))); + } + function z5c() { + z5c = geb; + y5c = ss((t5c(), cD(WC(N0, 1), jwe, 300, 0, [r5c, s5c, q5c]))); + } + function k6c() { + k6c = geb; + j6c = ss((f6c(), cD(WC(V0, 1), jwe, 445, 0, [c6c, d6c, e6c]))); + } + function F6c() { + F6c = geb; + E6c = ss((z6c(), cD(WC(Z0, 1), jwe, 456, 0, [w6c, y6c, x6c]))); + } + function e7c() { + e7c = geb; + d7c = ss((_6c(), cD(WC(a1, 1), jwe, 394, 0, [Z6c, $6c, Y6c]))); + } + function j9c() { + j9c = geb; + i9c = ss((b9c(), cD(WC(o1, 1), jwe, 439, 0, [$8c, a9c, _8c]))); + } + function WKc() { + WKc = geb; + VKc = ss((RKc(), cD(WC(nY, 1), jwe, 464, 0, [OKc, PKc, QKc]))); + } + function JKb() { + JKb = geb; + IKb = ss((EKb(), cD(WC(MN, 1), jwe, 471, 0, [CKb, BKb, DKb]))); + } + function cKb() { + cKb = geb; + bKb = ss((ZJb(), cD(WC(JN, 1), jwe, 237, 0, [WJb, XJb, YJb]))); + } + function ALb() { + ALb = geb; + zLb = ss((vLb(), cD(WC(TN, 1), jwe, 472, 0, [uLb, tLb, sLb]))); + } + function CBb() { + CBb = geb; + BBb = ss((xBb(), cD(WC(QL, 1), jwe, 108, 0, [uBb, vBb, wBb]))); + } + function FWb() { + FWb = geb; + EWb = ss((AWb(), cD(WC(JP, 1), jwe, 391, 0, [yWb, xWb, zWb]))); + } + function Knd() { + Knd = geb; + Jnd = ss((Fnd(), cD(WC(y3, 1), jwe, 346, 0, [Dnd, Cnd, End]))); + } + function lbd() { + lbd = geb; + kbd = ss((gbd(), cD(WC(I1, 1), jwe, 444, 0, [dbd, ebd, fbd]))); + } + function Tmd() { + Tmd = geb; + Smd = ss((Omd(), cD(WC(t32, 1), jwe, 278, 0, [Lmd, Mmd, Nmd]))); + } + function rqd() { + rqd = geb; + qqd = ss((mqd(), cD(WC(J3, 1), jwe, 280, 0, [kqd, jqd, lqd]))); + } + function Hxd(a, b) { + return !a.o && (a.o = new DVd((pvd(), mvd), X4, a, 0)), QNd(a.o, b); + } + function HMb(a, b) { + var c2; + if (a.C) { + c2 = RD(Vrb(a.b, b), 127).n; + c2.d = a.C.d; + c2.a = a.C.a; + } + } + function F8b(a) { + var b, c2, d, e; + e = a.d; + b = a.a; + c2 = a.b; + d = a.c; + a.d = c2; + a.a = d; + a.b = e; + a.c = b; + } + function cOd(a) { + !a.g && (a.g = new hQd()); + !a.g.b && (a.g.b = new ePd(a)); + return a.g.b; + } + function dOd(a) { + !a.g && (a.g = new hQd()); + !a.g.c && (a.g.c = new IPd(a)); + return a.g.c; + } + function lOd(a) { + !a.g && (a.g = new hQd()); + !a.g.d && (a.g.d = new kPd(a)); + return a.g.d; + } + function YNd(a) { + !a.g && (a.g = new hQd()); + !a.g.a && (a.g.a = new qPd(a)); + return a.g.a; + } + function B9d(a, b, c2, d) { + !!c2 && (d = c2.Rh(b, BYd(c2.Dh(), a.c.uk()), null, d)); + return d; + } + function C9d(a, b, c2, d) { + !!c2 && (d = c2.Th(b, BYd(c2.Dh(), a.c.uk()), null, d)); + return d; + } + function Cjb(a, b, c2, d) { + var e; + e = $C(kE, Pwe, 28, b + 1, 15, 1); + Djb(e, a, b, c2, d); + return e; + } + function $C(a, b, c2, d, e, f2) { + var g; + g = _C(e, d); + e != 10 && cD(WC(a, f2), b, c2, e, g); + return g; + } + function $fe(a, b, c2) { + var d, e; + e = new Phe(b, a); + for (d = 0; d < c2; ++d) { + Dhe(e); + } + return e; + } + function $Gd(a, b, c2) { + var d, e; + if (c2 != null) { + for (d = 0; d < b; ++d) { + e = c2[d]; + a.Qi(d, e); + } + } + } + function Yyb(a, b) { + var c2; + c2 = new Gzb(); + c2.c = true; + c2.d = b.md(); + return Zyb(a, b.ld(), c2); + } + function rB(a, b) { + var c2; + c2 = a.q.getHours() + (b / 3600 | 0); + a.q.setSeconds(b); + mB(a, c2); + } + function Ct(a, b) { + var c2, d; + c2 = b; + d = Hob(cv(new Nu(a, c2))); + Ar(new Nu(a, c2)); + return d; + } + function Kdc(a, b) { + b.Ug("Label management", 1); + fE(mQb(a, (rid(), qid))); + b.Vg(); + } + function wge(a, b, c2, d) { + vge(a, b, c2, kge(a, b, d, ZD(b, 102) && (RD(b, 19).Bb & txe) != 0)); + } + function BQb(a, b, c2) { + RD(a.b, 68); + RD(a.b, 68); + RD(a.b, 68); + Umb(a.a, new KQb(c2, b, a)); + } + function AFb(a, b, c2) { + if (a < 0 || b > c2 || b < a) { + throw Adb(new eib(_xe + a + bye + b + Qxe + c2)); + } + } + function NCb(a) { + if (!a) { + this.c = null; + this.b = new bnb(); + } else { + this.c = a; + this.b = null; + } + } + function Fzb(a, b) { + xlb.call(this, a, b); + this.a = $C(vL, Zve, 447, 2, 0, 1); + this.b = true; + } + function hub(a) { + ckb.call(this, a, 0); + _tb(this); + this.d.b = this.d; + this.d.a = this.d; + } + function wtb(a) { + this.e = a; + this.b = this.e.a.entries(); + this.a = $C(jJ, rve, 1, 0, 5, 1); + } + function _Fc() { + _Fc = geb; + $Fc = nfd(pfd(new ufd(), (sXb(), nXb), (hcc(), Ebc)), rXb, $bc); + } + function xuc() { + tuc(); + return cD(WC(eX, 1), jwe, 283, 0, [ouc, nuc, quc, puc, suc, ruc]); + } + function Ruc() { + Ouc(); + return cD(WC(gX, 1), jwe, 281, 0, [Luc, Kuc, Nuc, Juc, Muc, Iuc]); + } + function bvc() { + $uc(); + return cD(WC(hX, 1), jwe, 282, 0, [Yuc, Vuc, Zuc, Xuc, Wuc, Uuc]); + } + function etc() { + btc(); + return cD(WC(ZW, 1), jwe, 232, 0, [Zsc, _sc, Ysc, $sc, atc, Xsc]); + } + function u3b() { + r3b(); + return cD(WC(hR, 1), jwe, 273, 0, [p3b, o3b, m3b, q3b, n3b, l3b]); + } + function Uod() { + Pod(); + return cD(WC(D3, 1), jwe, 279, 0, [Nod, Lod, Mod, Kod, Jod, Ood]); + } + function God() { + Bod(); + return cD(WC(C3, 1), jwe, 101, 0, [Aod, zod, yod, vod, xod, wod]); + } + function lnd() { + ind(); + return cD(WC(v3, 1), jwe, 321, 0, [gnd, end2, hnd, cnd, fnd, dnd]); + } + function Ujd() { + Rjd(); + return cD(WC(n3, 1), jwe, 255, 0, [Ljd, Ojd, Pjd, Qjd, Mjd, Njd]); + } + function xkd() { + ukd(); + return cD(WC(q3, 1), jwe, 298, 0, [tkd, skd, rkd, pkd, okd, qkd]); + } + function K3d(a) { + var b; + if (!a.a && a.b != -1) { + b = a.c.Dh(); + a.a = vYd(b, a.b); + } + return a.a; + } + function WGd(a, b) { + if (a.Si() && a.Hc(b)) { + return false; + } else { + a.Hi(b); + return true; + } + } + function RKb(a, b) { + Ivb(b, "Horizontal alignment cannot be null"); + a.b = b; + return a; + } + function ite(a, b, c2) { + Vse(); + var d; + d = hte(a, b); + c2 && !!d && kte(a) && (d = null); + return d; + } + function ZKc(a, b, c2) { + var d; + d = a.b[c2.c.p][c2.p]; + d.b += b.b; + d.c += b.c; + d.a += b.a; + ++d.a; + } + function Umc(a, b, c2) { + var d; + a.d[b.g] = c2; + d = a.g.c; + d[b.g] = $wnd.Math.max(d[b.g], c2 + 1); + } + function bjd(a, b) { + var c2, d; + c2 = a.a - b.a; + d = a.b - b.b; + return $wnd.Math.sqrt(c2 * c2 + d * d); + } + function v$b(a, b) { + var c2, d; + for (d = b.Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 36); + u$b(a, c2, 0, 0); + } + } + function x$b(a, b, c2) { + var d, e; + for (e = a.Kc(); e.Ob(); ) { + d = RD(e.Pb(), 36); + w$b(d, b, c2); + } + } + function G0c(a) { + var b, c2; + for (c2 = Sub(a.a, 0); c2.b != c2.d.c; ) { + b = RD(evb(c2), 65); + H0c(b); + } + } + function nnc(a, b) { + bub(a.e, b) || dub(a.e, b, new tnc(b)); + return RD(cub(a.e, b), 113); + } + function tBb(a, b, c2, d) { + uFb(a); + uFb(b); + uFb(c2); + uFb(d); + return new DBb(a, b, new NAb()); + } + function DVd(a, b, c2, d) { + this.ak(); + this.a = b; + this.b = a; + this.c = new wje(this, b, c2, d); + } + function O3d(a, b, c2, d, e, f2) { + MKd.call(this, b, d, e, f2); + this.c = a; + this.b = c2; + } + function c4d(a, b, c2, d, e, f2) { + MKd.call(this, b, d, e, f2); + this.c = a; + this.a = c2; + } + function Q9c(a, b) { + var c2, d, e; + e = a.r; + d = a.d; + c2 = S9c(a, b, true); + return c2.b != e || c2.a != d; + } + function Vee(a, b, c2) { + var d, e; + e = (d = N5d(a.b, b), d); + return !e ? null : tfe(Pee(a, e), c2); + } + function _Dd(a, b, c2) { + var d, e, f2; + d = qC(a, c2); + e = null; + !!d && (e = ADd(d)); + f2 = e; + tEd(b, c2, f2); + } + function aEd(a, b, c2) { + var d, e, f2; + d = qC(a, c2); + e = null; + !!d && (e = ADd(d)); + f2 = e; + tEd(b, c2, f2); + } + function Evd(a, b) { + var c2; + return c2 = a.Ih(b), c2 >= 0 ? a.Lh(c2, true, true) : Qvd(a, b, true); + } + function gMc(a, b, c2) { + var d; + d = qMc(a, b, c2); + a.b = new _Lc(d.c.length); + return iMc(a, d); + } + function Pue(a) { + if (a.b <= 0) + throw Adb(new Dvb()); + --a.b; + a.a -= a.c.c; + return sgb(a.a); + } + function PGd(a) { + var b; + if (!a.a) { + throw Adb(new Evb()); + } + b = a.a; + a.a = vCd(a.a); + return b; + } + function WDb(a) { + while (!a.a) { + if (!yEb(a.c, new $Db(a))) { + return false; + } + } + return true; + } + function Nr(a) { + var b; + Qb(a); + if (ZD(a, 204)) { + b = RD(a, 204); + return b; + } + return new Or(a); + } + function Cfd(a) { + Afd(); + RD(a.of((umd(), Lld)), 181).Fc((Pod(), Mod)); + a.qf(Kld, null); + } + function Afd() { + Afd = geb; + xfd = new Gfd(); + zfd = new Ifd(); + yfd = yn((umd(), Kld), xfd, pld, zfd); + } + function Y3c() { + Y3c = geb; + W3c = new $3c("LEAF_NUMBER", 0); + X3c = new $3c("NODE_SIZE", 1); + } + function YLc(a) { + a.a = $C(kE, Pwe, 28, a.b + 1, 15, 1); + a.c = $C(kE, Pwe, 28, a.b, 15, 1); + a.d = 0; + } + function OZb(a, b) { + if (a.a.Ne(b.d, a.b) > 0) { + Rmb(a.c, new fZb(b.c, b.d, a.d)); + a.b = b.d; + } + } + function NHd(a, b) { + if (a.g == null || b >= a.i) + throw Adb(new yNd(b, a.i)); + return a.g[b]; + } + function P_d(a, b, c2) { + gHd(a, c2); + if (c2 != null && !a.fk(c2)) { + throw Adb(new yeb()); + } + return c2; + } + function dD(a, b) { + XC(b) != 10 && cD(rb(b), b.Sm, b.__elementTypeId$, XC(b), a); + return a; + } + function Wnb(a, b, c2, d) { + var e; + d = (urb(), !d ? rrb : d); + e = a.slice(b, c2); + Xnb(e, a, b, c2, -b, d); + } + function zvd(a, b, c2, d, e) { + return b < 0 ? Qvd(a, c2, d) : RD(c2, 69).wk().yk(a, a.hi(), b, d, e); + } + function J9b(a, b) { + return Qfb(Kfb(UD(mQb(a, (Ywc(), Jwc)))), Kfb(UD(mQb(b, Jwc)))); + } + function qAb() { + qAb = geb; + pAb = ss((cAb(), cD(WC(AL, 1), jwe, 304, 0, [$zb, _zb, aAb, bAb]))); + } + function cAb() { + cAb = geb; + $zb = new dAb("All", 0); + _zb = new iAb(); + aAb = new kAb(); + bAb = new nAb(); + } + function EKb() { + EKb = geb; + CKb = new FKb(Nye, 0); + BKb = new FKb(Kye, 1); + DKb = new FKb(Oye, 2); + } + function Zme() { + Zme = geb; + qAd(); + Wme = oxe; + Vme = pxe; + Yme = new Tfb(oxe); + Xme = new Tfb(pxe); + } + function rOb() { + rOb = geb; + qOb = ss((mOb(), cD(WC(hO, 1), jwe, 417, 0, [lOb, iOb, jOb, kOb]))); + } + function NRb() { + NRb = geb; + MRb = ss((IRb(), cD(WC(WO, 1), jwe, 406, 0, [FRb, ERb, GRb, HRb]))); + } + function NPb() { + NPb = geb; + MPb = ss((IPb(), cD(WC(DO, 1), jwe, 332, 0, [FPb, EPb, GPb, HPb]))); + } + function Z$b() { + Z$b = geb; + Y$b = ss((U$b(), cD(WC(CQ, 1), jwe, 389, 0, [T$b, R$b, Q$b, S$b]))); + } + function wZb() { + wZb = geb; + vZb = ss((nZb(), cD(WC(lQ, 1), jwe, 416, 0, [jZb, mZb, kZb, lZb]))); + } + function jnc() { + jnc = geb; + inc = ss((enc(), cD(WC(LV, 1), jwe, 421, 0, [anc, bnc, cnc, dnc]))); + } + function Bec() { + Bec = geb; + Aec = ss((vec(), cD(WC(qT, 1), jwe, 371, 0, [uec, sec, tec, rec]))); + } + function DDc() { + DDc = geb; + CDc = ss((wDc(), cD(WC(tX, 1), jwe, 203, 0, [uDc, vDc, tDc, sDc]))); + } + function pEc() { + pEc = geb; + oEc = ss((kEc(), cD(WC(wX, 1), jwe, 284, 0, [hEc, gEc, iEc, jEc]))); + } + function Cuc() { + Cuc = geb; + Buc = new Duc(LAe, 0); + Auc = new Duc("IMPROVE_STRAIGHTNESS", 1); + } + function _i6(a, b) { + var c2, d; + d = b / a.c.Rd().gc() | 0; + c2 = b % a.c.Rd().gc(); + return Ui(a, d, c2); + } + function iZd(a) { + var b; + if (a.nl()) { + for (b = a.i - 1; b >= 0; --b) { + QHd(a, b); + } + } + return WHd(a); + } + function Nyb(a) { + var b, c2; + if (!a.b) { + return null; + } + c2 = a.b; + while (b = c2.a[0]) { + c2 = b; + } + return c2; + } + function Oyb(a) { + var b, c2; + if (!a.b) { + return null; + } + c2 = a.b; + while (b = c2.a[1]) { + c2 = b; + } + return c2; + } + function Hae(a) { + if (ZD(a, 180)) { + return "" + RD(a, 180).a; + } + return a == null ? null : jeb(a); + } + function Iae(a) { + if (ZD(a, 180)) { + return "" + RD(a, 180).a; + } + return a == null ? null : jeb(a); + } + function eGb(a, b) { + if (b.a) { + throw Adb(new yz(jye)); + } + Ysb(a.a, b); + b.a = a; + !a.j && (a.j = b); + } + function hEb(a, b) { + xxb.call(this, b.zd(), b.yd() & -16449); + uFb(a); + this.a = a; + this.c = b; + } + function zXc(a, b) { + return new gud(b, Zid(ajd(b.e), b.f.a + a, b.f.b + a), (Geb(), false)); + } + function EMc(a, b) { + dMc(); + return Rmb(a, new Ptd(b, sgb(b.e.c.length + b.g.c.length))); + } + function GMc(a, b) { + dMc(); + return Rmb(a, new Ptd(b, sgb(b.e.c.length + b.g.c.length))); + } + function p5c() { + p5c = geb; + o5c = ss((j5c(), cD(WC(M0, 1), jwe, 354, 0, [i5c, g5c, h5c, f5c]))); + } + function x_c() { + x_c = geb; + w_c = ss((s_c(), cD(WC(J_, 1), jwe, 353, 0, [r_c, p_c, q_c, o_c]))); + } + function eWc() { + eWc = geb; + dWc = ss((YVc(), cD(WC(H$, 1), jwe, 405, 0, [UVc, VVc, WVc, XVc]))); + } + function bnd() { + bnd = geb; + and = ss((Ymd(), cD(WC(u3, 1), jwe, 223, 0, [Xmd, Vmd, Umd, Wmd]))); + } + function Vnd() { + Vnd = geb; + Und = ss((Pnd(), cD(WC(z3, 1), jwe, 291, 0, [Ond, Lnd, Mnd, Nnd]))); + } + function Vpd() { + Vpd = geb; + Upd = ss((Qpd(), cD(WC(H3, 1), jwe, 386, 0, [Opd, Ppd, Npd, Mpd]))); + } + function Lrd() { + Lrd = geb; + Krd = ss((Grd(), cD(WC(R3, 1), jwe, 320, 0, [Frd, Crd, Erd, Drd]))); + } + function ytd() { + ytd = geb; + xtd = ss((ttd(), cD(WC(n4, 1), jwe, 415, 0, [qtd, rtd, ptd, std]))); + } + function b9c() { + b9c = geb; + $8c = new d9c(iFe, 0); + a9c = new d9c(mEe, 1); + _8c = new d9c(LAe, 2); + } + function sBb(a, b, c2, d, e) { + uFb(a); + uFb(b); + uFb(c2); + uFb(d); + uFb(e); + return new DBb(a, b, d); + } + function fub(a, b) { + var c2; + c2 = RD(_jb(a.e, b), 400); + if (c2) { + rub(c2); + return c2.e; + } + return null; + } + function Ymb(a, b) { + var c2; + c2 = Wmb(a, b, 0); + if (c2 == -1) { + return false; + } + Xmb(a, c2); + return true; + } + function LDb(a, b, c2) { + var d; + LCb(a); + d = new IEb(); + d.a = b; + a.a.Nb(new QEb(d, c2)); + return d.a; + } + function VCb(a) { + var b; + LCb(a); + b = $C(iE, vxe, 28, 0, 15, 1); + ixb(a.a, new dDb(b)); + return b; + } + function yc(a) { + var b; + if (!xc(a)) { + throw Adb(new Dvb()); + } + a.e = 1; + b = a.d; + a.d = null; + return b; + } + function Odb(a) { + var b; + if (Kdb(a)) { + b = 0 - a; + if (!isNaN(b)) { + return b; + } + } + return Edb(xD(a)); + } + function Wmb(a, b, c2) { + for (; c2 < a.c.length; ++c2) { + if (Fvb(b, a.c[c2])) { + return c2; + } + } + return -1; + } + function Gmc(a) { + var b, c2; + c2 = RD(Vmb(a.j, 0), 12); + b = RD(mQb(c2, (Ywc(), Awc)), 12); + return b; + } + function Nu(a, b) { + var c2; + this.f = a; + this.b = b; + c2 = RD(Wjb(a.b, b), 260); + this.c = !c2 ? null : c2.b; + } + function Ckc() { + lkc(); + this.b = new Tsb(); + this.f = new Tsb(); + this.g = new Tsb(); + this.e = new Tsb(); + } + function RSd(a) { + ez(this); + this.g = !a ? null : lz(a, a.ie()); + this.f = a; + gz(this); + this.je(); + } + function pKd(a) { + var b; + b = a.jj(); + b != null && a.d != -1 && RD(b, 94).xh(a); + !!a.i && a.i.oj(); + } + function asc(a) { + var b; + for (b = a.p + 1; b < a.c.a.c.length; ++b) { + --RD(Vmb(a.c.a, b), 10).p; + } + } + function ukb(a) { + yFb(!!a.c); + rFb(a.f.g, a.d); + a.c.Qb(); + a.c = null; + a.b = skb(a); + a.d = a.f.g; + } + function o4d(a) { + if (!a.b) { + a.b = new s5d(a, o7, a); + !a.a && (a.a = new F4d(a, a)); + } + return a.b; + } + function Pee(a, b) { + var c2, d; + c2 = RD(b, 690); + d = c2.xi(); + !d && c2.Ai(d = new wfe(a, b)); + return d; + } + function Qee(a, b) { + var c2, d; + c2 = RD(b, 692); + d = c2.$k(); + !d && c2.cl(d = new Jfe(a, b)); + return d; + } + function _jc(a, b) { + Wjc(); + var c2, d; + c2 = $jc(a); + d = $jc(b); + return !!c2 && !!d && !Aob(c2.k, d.k); + } + function WFb(a, b) { + return Fvb(b, Vmb(a.f, 0)) || Fvb(b, Vmb(a.f, 1)) || Fvb(b, Vmb(a.f, 2)); + } + function Med(a, b) { + if (b < 0) { + throw Adb(new veb(zGe + b)); + } + Led(a, b + 1); + return Vmb(a.j, b); + } + function Ob(a, b, c2, d) { + if (!a) { + throw Adb(new agb(hc(b, cD(WC(jJ, 1), rve, 1, 5, [c2, d])))); + } + } + function P3d(a, b, c2, d, e, f2, g) { + NKd.call(this, b, d, e, f2, g); + this.c = a; + this.b = c2; + } + function UA(a, b, c2) { + var d, e; + d = 10; + for (e = 0; e < c2 - 1; e++) { + b < d && (a.a += "0", a); + d *= 10; + } + a.a += b; + } + function Ahb(a) { + var b, c2; + c2 = a.length; + b = $C(hE, zwe, 28, c2, 15, 1); + nhb(a, 0, c2, b, 0); + return b; + } + function $eb(a) { + Zeb(); + var b, c2; + b = a + 128; + c2 = Yeb[b]; + !c2 && (c2 = Yeb[b] = new Seb(a)); + return c2; + } + function Cub(a) { + rFb(a.d.a.e.g, a.b); + sFb(a.c != a.d.a.d); + a.a = a.c; + a.c = a.c.a; + return a.a; + } + function mDc(a) { + switch (a.g) { + case 0: + return lve; + case 1: + return -1; + default: + return 0; + } + } + function ED(a) { + if (uD(a, (MD(), LD)) < 0) { + return -qD(xD(a)); + } + return a.l + a.m * gxe + a.h * hxe; + } + function etd(a) { + (!this.q ? (yob(), yob(), wob) : this.q).Ac(!a.q ? (yob(), yob(), wob) : a.q); + } + function Eud(a, b) { + Cod(RD(RD(a.f, 27).of((umd(), Hld)), 101)) && lQd(wCd(RD(a.f, 27)), b); + } + function Gvd(a, b) { + var c2; + c2 = BYd(a.d, b); + return c2 >= 0 ? Dvd(a, c2, true, true) : Qvd(a, b, true); + } + function Vwd(a) { + var b; + b = SD(Ywd(a, 32)); + if (b == null) { + Wwd(a); + b = SD(Ywd(a, 32)); + } + return b; + } + function Yvd(a) { + var b; + if (!a.Oh()) { + b = AYd(a.Dh()) - a.ji(); + a.$h().Mk(b); + } + return a.zh(); + } + function zQb(a, b) { + yQb = new kRb(); + wQb = b; + xQb = a; + RD(xQb.b, 68); + BQb(xQb, yQb, null); + AQb(xQb); + } + function AWb() { + AWb = geb; + yWb = new BWb("XY", 0); + xWb = new BWb("X", 1); + zWb = new BWb("Y", 2); + } + function vLb() { + vLb = geb; + uLb = new wLb("TOP", 0); + tLb = new wLb(Kye, 1); + sLb = new wLb(Qye, 2); + } + function Gvc() { + Gvc = geb; + Evc = new Hvc(LAe, 0); + Fvc = new Hvc("TOP", 1); + Dvc = new Hvc(Qye, 2); + } + function sEc() { + sEc = geb; + qEc = new tEc("INPUT_ORDER", 0); + rEc = new tEc("PORT_DEGREE", 1); + } + function MD() { + MD = geb; + ID = hD(dxe, dxe, 524287); + JD = hD(0, 0, fxe); + KD = fD(1); + fD(2); + LD = fD(0); + } + function wWd(a) { + var b; + if (a.d != a.r) { + b = WVd(a); + a.e = !!b && b.lk() == aKe; + a.d = b; + } + return a.e; + } + function UHd(a, b, c2) { + var d; + d = a.g[b]; + MHd(a, b, a.Zi(b, c2)); + a.Ri(b, c2, d); + a.Ni(); + return d; + } + function dHd(a, b) { + var c2; + c2 = a.dd(b); + if (c2 >= 0) { + a.gd(c2); + return true; + } else { + return false; + } + } + function xr(a, b) { + var c2; + Qb(a); + Qb(b); + c2 = false; + while (b.Ob()) { + c2 = c2 | a.Fc(b.Pb()); + } + return c2; + } + function cub(a, b) { + var c2; + c2 = RD(Wjb(a.e, b), 400); + if (c2) { + eub(a, c2); + return c2.e; + } + return null; + } + function iB(a) { + var b, c2; + b = a / 60 | 0; + c2 = a % 60; + if (c2 == 0) { + return "" + b; + } + return "" + b + ":" + ("" + c2); + } + function JB(d, a) { + var b = d.a[a]; + var c2 = (HC(), GC)[typeof b]; + return c2 ? c2(b) : NC(typeof b); + } + function EDb(a, b) { + var c2, d; + MCb(a); + d = new zEb(b, a.a); + c2 = new YDb(d); + return new SDb(a, c2); + } + function mwb(a) { + var b; + b = a.b.c.length == 0 ? null : Vmb(a.b, 0); + b != null && owb(a, 0); + return b; + } + function ukc(a, b) { + var c2, d, e; + e = b.c.i; + c2 = RD(Wjb(a.f, e), 60); + d = c2.d.c - c2.e.c; + Bjd(b.a, d, 0); + } + function XLc(a, b) { + var c2; + ++a.d; + ++a.c[b]; + c2 = b + 1; + while (c2 < a.a.length) { + ++a.a[c2]; + c2 += c2 & -c2; + } + } + function Ute(a, b, c2, d) { + Vse(); + Wse.call(this, 26); + this.c = a; + this.a = b; + this.d = c2; + this.b = d; + } + function KA(a, b) { + while (b[0] < a.length && qhb(" \r\n", Fhb(ihb(a, b[0]))) >= 0) { + ++b[0]; + } + } + function eEd(a, b) { + Dyd(a, b == null || Rfb((uFb(b), b)) || isNaN((uFb(b), b)) ? 0 : (uFb(b), b)); + } + function fEd(a, b) { + Eyd(a, b == null || Rfb((uFb(b), b)) || isNaN((uFb(b), b)) ? 0 : (uFb(b), b)); + } + function gEd(a, b) { + Cyd(a, b == null || Rfb((uFb(b), b)) || isNaN((uFb(b), b)) ? 0 : (uFb(b), b)); + } + function hEd(a, b) { + Ayd(a, b == null || Rfb((uFb(b), b)) || isNaN((uFb(b), b)) ? 0 : (uFb(b), b)); + } + function oWc(a, b, c2) { + return cjd(new rjd(c2.e.a + c2.f.a / 2, c2.e.b + c2.f.b / 2), a) == (uFb(b), b); + } + function qge(a, b) { + return ZD(b, 102) && (RD(b, 19).Bb & txe) != 0 ? new She(b, a) : new Phe(b, a); + } + function sge(a, b) { + return ZD(b, 102) && (RD(b, 19).Bb & txe) != 0 ? new She(b, a) : new Phe(b, a); + } + function XC(a) { + return a.__elementTypeCategory$ == null ? 10 : a.__elementTypeCategory$; + } + function Bhb(a, b) { + return b == (wvb(), wvb(), vvb) ? a.toLocaleLowerCase() : a.toLowerCase(); + } + function Mu(a) { + if (!a.e) { + throw Adb(new Dvb()); + } + a.c = a.a = a.e; + a.e = a.e.e; + --a.d; + return a.a.f; + } + function Lu(a) { + if (!a.c) { + throw Adb(new Dvb()); + } + a.e = a.a = a.c; + a.c = a.c.c; + ++a.d; + return a.a.f; + } + function Lsb(a) { + var b; + ++a.a; + for (b = a.c.a.length; a.a < b; ++a.a) { + if (a.c.b[a.a]) { + return; + } + } + } + function _z(a) { + var b, c2; + if (a.a) { + c2 = null; + do { + b = a.a; + a.a = null; + c2 = dA(b, c2); + } while (a.a); + a.a = c2; + } + } + function aA(a) { + var b, c2; + if (a.b) { + c2 = null; + do { + b = a.b; + a.b = null; + c2 = dA(b, c2); + } while (a.b); + a.b = c2; + } + } + function eve(a, b) { + var c2; + c2 = 0; + while (a.e != a.i.gc()) { + oFd(b, bMd(a), sgb(c2)); + c2 != lve && ++c2; + } + } + function Llc(a, b) { + var c2; + c2 = $y(a.e.c, b.e.c); + if (c2 == 0) { + return Qfb(a.e.d, b.e.d); + } + return c2; + } + function hdc(a, b) { + var c2, d; + d = b.c; + for (c2 = d + 1; c2 <= b.f; c2++) { + a.a[c2] > a.a[d] && (d = c2); + } + return d; + } + function Krc(a) { + var b; + b = RD(mQb(a, (Ywc(), Wvc)), 313); + if (b) { + return b.a == a; + } + return false; + } + function Lrc(a) { + var b; + b = RD(mQb(a, (Ywc(), Wvc)), 313); + if (b) { + return b.i == a; + } + return false; + } + function xXb() { + xXb = geb; + wXb = ss((sXb(), cD(WC(UP, 1), jwe, 367, 0, [nXb, oXb, pXb, qXb, rXb]))); + } + function Hnc() { + Hnc = geb; + Gnc = ss((Bnc(), cD(WC(TV, 1), jwe, 375, 0, [xnc, znc, Anc, ync, wnc]))); + } + function Xtc() { + Xtc = geb; + Wtc = ss((Ptc(), cD(WC(bX, 1), jwe, 348, 0, [Ltc, Ktc, Ntc, Otc, Mtc]))); + } + function RDc() { + RDc = geb; + QDc = ss((JDc(), cD(WC(uX, 1), jwe, 323, 0, [IDc, FDc, GDc, EDc, HDc]))); + } + function hxc() { + hxc = geb; + gxc = ss((cxc(), cD(WC(mX, 1), jwe, 171, 0, [bxc, Zwc, $wc, _wc, axc]))); + } + function m3c() { + m3c = geb; + l3c = ss((g3c(), cD(WC(x0, 1), jwe, 368, 0, [e3c, b3c, f3c, c3c, d3c]))); + } + function xad() { + xad = geb; + wad = ss((sad(), cD(WC(x1, 1), jwe, 373, 0, [oad, nad, qad, pad2, rad]))); + } + function acd() { + acd = geb; + _bd = ss((Xbd(), cD(WC(P1, 1), jwe, 324, 0, [Sbd, Tbd, Wbd, Ubd, Vbd]))); + } + function Kmd() { + Kmd = geb; + Jmd = ss((Cmd(), cD(WC(s3, 1), jwe, 88, 0, [Amd, zmd, ymd, xmd, Bmd]))); + } + function bid() { + bid = geb; + aid = ss((Yhd(), cD(WC(d3, 1), jwe, 170, 0, [Whd, Vhd, Thd, Xhd, Uhd]))); + } + function uod() { + uod = geb; + tod = ss((pod(), cD(WC(B3, 1), jwe, 256, 0, [mod, ood, kod, lod, nod]))); + } + function zpd() { + zpd = geb; + ypd = ss((qpd(), cD(WC(E3, 1), NAe, 64, 0, [opd, Yod, Xod, npd, ppd]))); + } + function LHb() { + LHb = geb; + JHb = new MHb("BY_SIZE", 0); + KHb = new MHb("BY_SIZE_AND_SHAPE", 1); + } + function TUb() { + TUb = geb; + RUb = new UUb("EADES", 0); + SUb = new UUb("FRUCHTERMAN_REINGOLD", 1); + } + function $tc() { + $tc = geb; + Ytc = new _tc("READING_DIRECTION", 0); + Ztc = new _tc("ROTATION", 1); + } + function CZb() { + CZb = geb; + zZb = new ZZb(); + AZb = new b$b(); + xZb = new f$b(); + yZb = new j$b(); + BZb = new n$b(); + } + function dGb(a) { + this.b = new bnb(); + this.a = new bnb(); + this.c = new bnb(); + this.d = new bnb(); + this.e = a; + } + function XZb(a) { + this.g = a; + this.f = new bnb(); + this.a = $wnd.Math.min(this.g.c.c, this.g.d.c); + } + function UKb(a, b, c2) { + RJb.call(this); + KKb(this); + this.a = a; + this.c = c2; + this.b = b.d; + this.f = b.e; + } + function d6b(a, b, c2) { + var d, e; + for (e = new Anb(c2); e.a < e.c.c.length; ) { + d = ynb(e); + c6b(a, b, d); + } + } + function sC(a, b, c2) { + var d; + if (b == null) { + throw Adb(new Ngb()); + } + d = qC(a, b); + tC(a, b, c2); + return d; + } + function ked(a, b) { + var c2; + c2 = RD(Wjb(a.a, b), 137); + if (!c2) { + c2 = new qQb(); + Zjb(a.a, b, c2); + } + return c2; + } + function vYd(a, b) { + var c2; + c2 = (a.i == null && rYd(a), a.i); + return b >= 0 && b < c2.length ? c2[b] : null; + } + function Gqd(a, b) { + var c2; + c2 = b > 0 ? b - 1 : b; + return Kqd(Lqd(Mqd(Nqd(new Oqd(), c2), a.n), a.j), a.k); + } + function nBd(a) { + var b, c2; + c2 = (b = new q4d(), b); + WGd((!a.q && (a.q = new C5d(s7, a, 11, 10)), a.q), c2); + } + function ofb(a) { + return ((a.i & 2) != 0 ? "interface " : (a.i & 1) != 0 ? "" : "class ") + (lfb(a), a.o); + } + function dz(a) { + if (Ddb(a, lve) > 0) { + return lve; + } + if (Ddb(a, qwe) < 0) { + return qwe; + } + return Ydb(a); + } + function Sv(a) { + if (a < 3) { + dk(a, fwe); + return a + 1; + } + if (a < hwe) { + return eE(a / 0.75 + 1); + } + return lve; + } + function Rwb(a, b) { + uFb(b); + Qwb(a); + if (a.d.Ob()) { + b.Cd(a.d.Pb()); + return true; + } + return false; + } + function ke(a, b) { + var c2, d; + c2 = RD(Xv(a.d, b), 16); + if (!c2) { + return null; + } + d = b; + return a.e.pc(d, c2); + } + function Ufe(a, b, c2, d) { + var e; + a.j = -1; + oLd(a, gge(a, b, c2), (nke(), e = RD(b, 69).vk(), e.xl(d))); + } + function Z_c(a, b) { + R_c(); + return -hgb(RD(mQb(a, (h_c(), W$c)), 17).a, RD(mQb(b, W$c), 17).a); + } + function xo(a, b) { + return !!Ho(a, b, Ydb(Ndb(cwe, qgb(Ydb(Ndb(b == null ? 0 : tb(b), dwe)), 15)))); + } + function dGd() { + aGd(); + return cD(WC(T5, 1), jwe, 245, 0, [_Fd, YFd, ZFd, XFd, $Fd, VFd, UFd, WFd]); + } + function nid() { + kid(); + return cD(WC(e3, 1), jwe, 285, 0, [jid, cid, gid, iid, did, eid, fid, hid]); + } + function hpc() { + epc(); + return cD(WC(hW, 1), jwe, 276, 0, [Zoc, apc, Yoc, dpc, _oc, $oc, cpc, bpc]); + } + function Kcc(a) { + var b; + b = Kfb(UD(mQb(a, (yCc(), FAc)))); + if (b < 0) { + b = 0; + pQb(a, FAc, b); + } + return b; + } + function Odc(a, b) { + var c2, d; + for (d = a.Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 72); + pQb(c2, (Ywc(), swc), b); + } + } + function Oic(a, b, c2) { + var d; + d = $wnd.Math.max(0, a.b / 2 - 0.5); + Iic(c2, d, 1); + Rmb(b, new Xic(c2, d)); + } + function lRc(a, b, c2) { + var d; + d = a.a.e[RD(b.a, 10).p] - a.a.e[RD(c2.a, 10).p]; + return eE(Lgb(d)); + } + function PDb(a, b) { + var c2; + MCb(a); + c2 = new cEb(a, a.a.zd(), a.a.yd() | 4, b); + return new SDb(a, c2); + } + function gvb(a) { + var b; + yFb(!!a.c); + b = a.c.a; + Wub(a.d, a.c); + a.b == a.c ? a.b = b : --a.a; + a.c = null; + } + function iqc(a) { + a.a >= -0.01 && a.a <= Tye && (a.a = 0); + a.b >= -0.01 && a.b <= Tye && (a.b = 0); + return a; + } + function Hid(a) { + tid(); + var b, c2; + c2 = KEe; + for (b = 0; b < a.length; b++) { + a[b] > c2 && (c2 = a[b]); + } + return c2; + } + function Zvd(a, b) { + var c2; + c2 = wYd(a.Dh(), b); + if (!c2) { + throw Adb(new agb(KHe + b + NHe)); + } + return c2; + } + function NGd(a, b) { + var c2; + c2 = a; + while (vCd(c2)) { + c2 = vCd(c2); + if (c2 == b) { + return true; + } + } + return false; + } + function ix(a, b) { + var c2, d, e; + d = b.a.ld(); + c2 = RD(b.a.md(), 16).gc(); + for (e = 0; e < c2; e++) { + a.Cd(d); + } + } + function Umb(a, b) { + var c2, d, e, f2; + uFb(b); + for (d = a.c, e = 0, f2 = d.length; e < f2; ++e) { + c2 = d[e]; + b.Cd(c2); + } + } + function q0b(a, b, c2, d, e, f2) { + var g; + g = s0b(d); + Y0b(g, e); + Z0b(g, f2); + Rc(a.a, d, new J0b(g, b, c2.f)); + } + function P8c(a, b) { + Ixd(a, (X6c(), T6c), b.f); + Ixd(a, Q6c, b.e); + Ixd(a, S6c, b.d); + Ixd(a, P6c, b.c); + } + function grc(a, b) { + this.a = new Tsb(); + this.e = new Tsb(); + this.b = (lDc(), kDc); + this.c = a; + this.b = b; + } + function yd(a) { + this.d = a; + this.c = a.c.vc().Kc(); + this.b = null; + this.a = null; + this.e = (zs(), ys); + } + function Wub(a, b) { + var c2; + c2 = b.c; + b.a.b = b.b; + b.b.a = b.a; + b.a = b.b = null; + b.c = null; + --a.b; + return c2; + } + function Esb(a, b) { + if (!!b && a.b[b.g] == b) { + bD(a.b, b.g, null); + --a.c; + return true; + } + return false; + } + function jxb(a, b) { + if (0 > a || a > b) { + throw Adb(new xeb("fromIndex: 0, toIndex: " + a + Qxe + b)); + } + } + function ZHd(a) { + if (a < 0) { + throw Adb(new agb("Illegal Capacity: " + a)); + } + this.g = this.aj(a); + } + function _y(a, b) { + Zy(); + bz(pwe); + return $wnd.Math.abs(a - b) <= pwe || a == b || isNaN(a) && isNaN(b); + } + function xJc(a, b) { + var c2, d, e, f2; + for (d = a.d, e = 0, f2 = d.length; e < f2; ++e) { + c2 = d[e]; + pJc(a.g, c2).a = b; + } + } + function BIc(a, b, c2) { + var d, e, f2; + e = b[c2]; + for (d = 0; d < e.length; d++) { + f2 = e[d]; + a.e[f2.c.p][f2.p] = d; + } + } + function nqc(a) { + var b; + for (b = 0; b < a.c.length; b++) { + (tFb(b, a.c.length), RD(a.c[b], 12)).p = b; + } + } + function qqc(a) { + var b, c2; + b = a.a.d.j; + c2 = a.c.d.j; + while (b != c2) { + zsb(a.b, b); + b = tpd(b); + } + zsb(a.b, b); + } + function gjd(a) { + var b; + b = $wnd.Math.sqrt(a.a * a.a + a.b * a.b); + if (b > 0) { + a.a /= b; + a.b /= b; + } + return a; + } + function BXd(a) { + var b; + if (a.w) { + return a.w; + } else { + b = CXd(a); + !!b && !b.Vh() && (a.w = b); + return b; + } + } + function l2d(a, b) { + var c2, d; + d = a.a; + c2 = m2d(a, b, null); + d != b && !a.e && (c2 = o2d(a, b, c2)); + !!c2 && c2.oj(); + } + function rQc(a, b, c2) { + var d, e; + d = b; + do { + e = Kfb(a.p[d.p]) + c2; + a.p[d.p] = e; + d = a.a[d.p]; + } while (d != b); + } + function heb(a, b, c2) { + var d = function() { + return a.apply(d, arguments); + }; + b.apply(d, c2); + return d; + } + function Gae(a) { + var b; + if (a == null) { + return null; + } else { + b = RD(a, 195); + return sAd(b, b.length); + } + } + function QHd(a, b) { + if (a.g == null || b >= a.i) + throw Adb(new yNd(b, a.i)); + return a.Wi(b, a.g[b]); + } + function Dob(a, b) { + yob(); + var c2, d; + d = new bnb(); + for (c2 = 0; c2 < a; ++c2) { + ZEb(d.c, b); + } + return new irb(d); + } + function NDb(a) { + MCb(a); + zFb(true, "n may not be negative"); + return new SDb(a, new DEb(a.a)); + } + function KKb(a) { + a.b = (EKb(), BKb); + a.f = (vLb(), tLb); + a.d = (dk(2, iwe), new cnb(2)); + a.e = new pjd(); + } + function zrd(a) { + this.b = (Qb(a), new dnb(a)); + this.a = new bnb(); + this.d = new bnb(); + this.e = new pjd(); + } + function ZJb() { + ZJb = geb; + WJb = new $Jb("BEGIN", 0); + XJb = new $Jb(Kye, 1); + YJb = new $Jb("END", 2); + } + function Omd() { + Omd = geb; + Lmd = new Pmd(Kye, 0); + Mmd = new Pmd("HEAD", 1); + Nmd = new Pmd("TAIL", 2); + } + function R_c() { + R_c = geb; + Q_c = mfd(mfd(mfd(rfd(new ufd(), (YVc(), VVc)), (WYc(), VYc)), OYc), SYc); + } + function B0c() { + B0c = geb; + A0c = mfd(mfd(mfd(rfd(new ufd(), (YVc(), XVc)), (WYc(), QYc)), LYc), PYc); + } + function gtc() { + gtc = geb; + ftc = ss((btc(), cD(WC(ZW, 1), jwe, 232, 0, [Zsc, _sc, Ysc, $sc, atc, Xsc]))); + } + function zuc() { + zuc = geb; + yuc = ss((tuc(), cD(WC(eX, 1), jwe, 283, 0, [ouc, nuc, quc, puc, suc, ruc]))); + } + function Tuc() { + Tuc = geb; + Suc = ss((Ouc(), cD(WC(gX, 1), jwe, 281, 0, [Luc, Kuc, Nuc, Juc, Muc, Iuc]))); + } + function dvc() { + dvc = geb; + cvc = ss(($uc(), cD(WC(hX, 1), jwe, 282, 0, [Yuc, Vuc, Zuc, Xuc, Wuc, Uuc]))); + } + function w3b() { + w3b = geb; + v3b = ss((r3b(), cD(WC(hR, 1), jwe, 273, 0, [p3b, o3b, m3b, q3b, n3b, l3b]))); + } + function Wjd() { + Wjd = geb; + Vjd = ss((Rjd(), cD(WC(n3, 1), jwe, 255, 0, [Ljd, Ojd, Pjd, Qjd, Mjd, Njd]))); + } + function zkd() { + zkd = geb; + ykd = ss((ukd(), cD(WC(q3, 1), jwe, 298, 0, [tkd, skd, rkd, pkd, okd, qkd]))); + } + function nnd() { + nnd = geb; + mnd = ss((ind(), cD(WC(v3, 1), jwe, 321, 0, [gnd, end2, hnd, cnd, fnd, dnd]))); + } + function Iod() { + Iod = geb; + Hod = ss((Bod(), cD(WC(C3, 1), jwe, 101, 0, [Aod, zod, yod, vod, xod, wod]))); + } + function Wod() { + Wod = geb; + Vod = ss((Pod(), cD(WC(D3, 1), jwe, 279, 0, [Nod, Lod, Mod, Kod, Jod, Ood]))); + } + function kKb() { + kKb = geb; + jKb = (ZJb(), cD(WC(JN, 1), jwe, 237, 0, [WJb, XJb, YJb])).length; + iKb = jKb; + } + function hod() { + dod(); + return cD(WC(A3, 1), jwe, 95, 0, [Xnd, Wnd, Znd, cod, bod, aod, $nd, _nd, Ynd]); + } + function eoc(a, b) { + Mnc(); + return hgb(a.b.c.length - a.e.c.length, b.b.c.length - b.e.c.length); + } + function Ao(a, b) { + return $v(Go(a, b, Ydb(Ndb(cwe, qgb(Ydb(Ndb(b == null ? 0 : tb(b), dwe)), 15))))); + } + function rGb(a, b) { + return Zy(), bz(pwe), $wnd.Math.abs(a - b) <= pwe || a == b || isNaN(a) && isNaN(b); + } + function Wxd(a, b) { + var c2; + c2 = a.b; + a.b = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new L3d(a, 1, c2, a.b)); + } + function Hzd(a, b) { + var c2; + c2 = a.b; + a.b = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new L3d(a, 3, c2, a.b)); + } + function Ayd(a, b) { + var c2; + c2 = a.f; + a.f = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new L3d(a, 3, c2, a.f)); + } + function Cyd(a, b) { + var c2; + c2 = a.g; + a.g = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new L3d(a, 4, c2, a.g)); + } + function Dyd(a, b) { + var c2; + c2 = a.i; + a.i = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new L3d(a, 5, c2, a.i)); + } + function Eyd(a, b) { + var c2; + c2 = a.j; + a.j = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new L3d(a, 6, c2, a.j)); + } + function Ozd(a, b) { + var c2; + c2 = a.j; + a.j = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new L3d(a, 1, c2, a.j)); + } + function Izd(a, b) { + var c2; + c2 = a.c; + a.c = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new L3d(a, 4, c2, a.c)); + } + function Pzd(a, b) { + var c2; + c2 = a.k; + a.k = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new L3d(a, 2, c2, a.k)); + } + function Vxd(a, b) { + var c2; + c2 = a.a; + a.a = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new L3d(a, 0, c2, a.a)); + } + function $Vd(a, b) { + var c2; + c2 = a.s; + a.s = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new M3d(a, 4, c2, a.s)); + } + function bWd(a, b) { + var c2; + c2 = a.t; + a.t = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new M3d(a, 5, c2, a.t)); + } + function Q1d(a, b) { + var c2; + c2 = a.d; + a.d = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new M3d(a, 2, c2, a.d)); + } + function zXd(a, b) { + var c2; + c2 = a.F; + a.F = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 5, c2, b)); + } + function IMd(a, b) { + var c2; + c2 = RD(Wjb((PRd(), ORd), a), 57); + return c2 ? c2.gk(b) : $C(jJ, rve, 1, b, 5, 1); + } + function BXb(a, b) { + var c2; + c2 = ojd(ajd(RD(Wjb(a.g, b), 8)), Pid(RD(Wjb(a.f, b), 470).b)); + return c2; + } + function FGd(a, b) { + var c2, d, e; + c2 = (d = (bvd(), e = new hCd(), e), !!b && eCd(d, b), d); + fCd(c2, a); + return c2; + } + function vDd(a, b) { + var c2, d; + c2 = b in a.a; + if (c2) { + d = qC(a, b).re(); + if (d) { + return d.a; + } + } + return null; + } + function jZd(a, b, c2) { + gHd(a, c2); + if (!a.kl() && c2 != null && !a.fk(c2)) { + throw Adb(new yeb()); + } + return c2; + } + function Mqd(a, b) { + a.n = b; + if (a.n) { + a.f = new bnb(); + a.e = new bnb(); + } else { + a.f = null; + a.e = null; + } + return a; + } + function Ffb(a, b) { + if (!a) { + return; + } + b.n = a; + var d = zfb(b); + if (!d) { + eeb[a] = [b]; + return; + } + d.Rm = b; + } + function SD(a) { + var b; + CFb(a == null || Array.isArray(a) && (b = XC(a), !(b >= 14 && b <= 16))); + return a; + } + function ws(a, b) { + var c2; + uFb(b); + c2 = a[":" + b]; + mFb(!!c2, "Enum constant undefined: " + b); + return c2; + } + function tfb(a, b, c2, d, e, f2) { + var g; + g = rfb(a, b); + Ffb(c2, g); + g.i = e ? 8 : 0; + g.f = d; + g.e = e; + g.g = f2; + return g; + } + function R3d(a, b, c2, d, e) { + this.d = b; + this.k = d; + this.f = e; + this.o = -1; + this.p = 1; + this.c = a; + this.a = c2; + } + function T3d(a, b, c2, d, e) { + this.d = b; + this.k = d; + this.f = e; + this.o = -1; + this.p = 2; + this.c = a; + this.a = c2; + } + function _3d(a, b, c2, d, e) { + this.d = b; + this.k = d; + this.f = e; + this.o = -1; + this.p = 6; + this.c = a; + this.a = c2; + } + function e4d(a, b, c2, d, e) { + this.d = b; + this.k = d; + this.f = e; + this.o = -1; + this.p = 7; + this.c = a; + this.a = c2; + } + function X3d(a, b, c2, d, e) { + this.d = b; + this.j = d; + this.e = e; + this.o = -1; + this.p = 4; + this.c = a; + this.a = c2; + } + function iGb(a, b) { + var c2, d, e, f2; + for (d = b, e = 0, f2 = d.length; e < f2; ++e) { + c2 = d[e]; + eGb(a.a, c2); + } + return a; + } + function Al(a) { + var b, c2, d, e; + for (c2 = a, d = 0, e = c2.length; d < e; ++d) { + b = c2[d]; + Qb(b); + } + return new Gl(a); + } + function ZTb(a) { + var b; + b = ojd(ajd(a.d.d), a.c.d); + wid(b, a.c.e.a, a.c.e.b); + return $id(b, a.c.d); + } + function $Tb(a) { + var b; + b = ojd(ajd(a.c.d), a.d.d); + wid(b, a.d.e.a, a.d.e.b); + return $id(b, a.d.d); + } + function iA(a) { + var b = /function(?:\s+([\w$]+))?\s*\(/; + var c2 = b.exec(a); + return c2 && c2[1] || wwe; + } + function Hnb(a, b, c2) { + var d, e; + e = a.length; + d = $wnd.Math.min(c2, e); + VEb(a, 0, b, 0, d, true); + return b; + } + function ISb(a, b, c2) { + var d, e; + for (e = b.Kc(); e.Ob(); ) { + d = RD(e.Pb(), 74); + Ysb(a, RD(c2.Kb(d), 27)); + } + } + function E1b(a, b) { + Cod(RD(mQb(RD(a.e, 10), (yCc(), BBc)), 101)) && (yob(), _mb(RD(a.e, 10).j, b)); + } + function lIb() { + iIb(); + return cD(WC(xN, 1), jwe, 257, 0, [hIb, cIb, dIb, bIb, fIb, gIb, eIb, aIb, _Hb]); + } + function fDc() { + _Cc(); + return cD(WC(rX, 1), jwe, 265, 0, [ZCc, WCc, XCc, TCc, VCc, $Cc, YCc, SCc, UCc]); + } + function RKc() { + RKc = geb; + OKc = new SKc("BARYCENTER", 0); + PKc = new SKc(jBe, 1); + QKc = new SKc(kBe, 2); + } + function uFc() { + uFc = geb; + tFc = new vFc("NO", 0); + rFc = new vFc(CBe, 1); + sFc = new vFc("LOOK_BACK", 2); + } + function Etc() { + Etc = geb; + Btc = new Ftc("ARD", 0); + Dtc = new Ftc("MSD", 1); + Ctc = new Ftc("MANUAL", 2); + } + function BEc() { + BEc = geb; + AEc = new CEc(Sye, 0); + yEc = new CEc("INPUT", 1); + zEc = new CEc("OUTPUT", 2); + } + function ygd() { + if (!qgd) { + qgd = new xgd(); + wgd(qgd, cD(WC(B2, 1), rve, 134, 0, [new vmd()])); + } + return qgd; + } + function bz(a) { + if (!(a >= 0)) { + throw Adb(new agb("tolerance (" + a + ") must be >= 0")); + } + return a; + } + function hOd(a, b) { + var c2; + if (ZD(b, 44)) { + return a.c.Mc(b); + } else { + c2 = QNd(a, b); + jOd(a, b); + return c2; + } + } + function yBd(a, b, c2) { + YVd(a, b); + PAd(a, c2); + $Vd(a, 0); + bWd(a, 1); + aWd(a, true); + _Vd(a, true); + return a; + } + function ZGd(a, b) { + var c2; + c2 = a.gc(); + if (b < 0 || b > c2) + throw Adb(new aMd(b, c2)); + return new CMd(a, b); + } + function Cad(a, b) { + a.b = $wnd.Math.max(a.b, b.d); + a.e += b.r + (a.a.c.length == 0 ? 0 : a.c); + Rmb(a.a, b); + } + function Jmb(a) { + yFb(a.c >= 0); + if (rmb(a.d, a.c) < 0) { + a.a = a.a - 1 & a.d.a.length - 1; + a.b = a.d.c; + } + a.c = -1; + } + function Nc(a) { + var b, c2; + for (c2 = a.c.Cc().Kc(); c2.Ob(); ) { + b = RD(c2.Pb(), 16); + b.$b(); + } + a.c.$b(); + a.d = 0; + } + function Zi(a) { + var b, c2, d, e; + for (c2 = a.a, d = 0, e = c2.length; d < e; ++d) { + b = c2[d]; + Rnb(b, b.length, null); + } + } + function zjd(a, b) { + var c2, d, e, f2; + for (d = b, e = 0, f2 = d.length; e < f2; ++e) { + c2 = d[e]; + Pub(a, c2, a.c.b, a.c); + } + } + function St(a, b) { + var c2, d; + for (c2 = 0, d = a.gc(); c2 < d; ++c2) { + if (Fvb(b, a.Xb(c2))) { + return c2; + } + } + return -1; + } + function ogb(a) { + var b, c2; + if (a == 0) { + return 32; + } else { + c2 = 0; + for (b = 1; (b & a) == 0; b <<= 1) { + ++c2; + } + return c2; + } + } + function dk(a, b) { + if (a < 0) { + throw Adb(new agb(b + " cannot be negative but was: " + a)); + } + return a; + } + function deb(a, b) { + typeof window === gve && typeof window["$gwt"] === gve && (window["$gwt"][a] = b); + } + function lp(a, b) { + return Vv(Ho(a.a, b, Ydb(Ndb(cwe, qgb(Ydb(Ndb(b == null ? 0 : tb(b), dwe)), 15))))); + } + function FBb(a, b, c2) { + return sBb(a, new CCb(b), new ECb(), new GCb(c2), cD(WC(QL, 1), jwe, 108, 0, [])); + } + function gqd() { + dqd(); + return cD(WC(I3, 1), jwe, 264, 0, [Ypd, $pd, Xpd, _pd, aqd, cqd, bqd, Zpd, Wpd]); + } + function wgb() { + wgb = geb; + vgb = cD(WC(kE, 1), Pwe, 28, 15, [0, 8, 4, 12, 2, 10, 6, 14, 1, 9, 5, 13, 3, 11, 7, 15]); + } + function stc() { + stc = geb; + qtc = new utc("LAYER_SWEEP", 0); + ptc = new utc(BBe, 1); + rtc = new utc(LAe, 2); + } + function nGc() { + nGc = geb; + mGc = pfd(pfd(pfd(new ufd(), (sXb(), nXb), (hcc(), obc)), oXb, Nbc), pXb, Mbc); + } + function yGc() { + yGc = geb; + xGc = pfd(pfd(pfd(new ufd(), (sXb(), nXb), (hcc(), obc)), oXb, Nbc), pXb, Mbc); + } + function SGc() { + SGc = geb; + RGc = pfd(pfd(pfd(new ufd(), (sXb(), nXb), (hcc(), obc)), oXb, Nbc), pXb, Mbc); + } + function lHc() { + lHc = geb; + kHc = pfd(pfd(pfd(new ufd(), (sXb(), nXb), (hcc(), obc)), oXb, Nbc), pXb, Mbc); + } + function tHc() { + tHc = geb; + sHc = pfd(pfd(pfd(new ufd(), (sXb(), nXb), (hcc(), obc)), oXb, Nbc), pXb, Mbc); + } + function RHc() { + RHc = geb; + QHc = pfd(pfd(pfd(new ufd(), (sXb(), nXb), (hcc(), obc)), oXb, Nbc), pXb, Mbc); + } + function YJc() { + YJc = geb; + XJc = nfd(pfd(pfd(new ufd(), (sXb(), pXb), (hcc(), Qbc)), qXb, Gbc), rXb, Pbc); + } + function EJb(a) { + var b, c2; + for (c2 = new Anb(yud(a)); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 695); + b._f(); + } + } + function aeb() { + beb(); + var a = _db; + for (var b = 0; b < arguments.length; b++) { + a.push(arguments[b]); + } + } + function EXb(a) { + zXb(); + this.g = new Tsb(); + this.f = new Tsb(); + this.b = new Tsb(); + this.c = new Tp(); + this.i = a; + } + function d1b() { + this.f = new pjd(); + this.d = new C3b(); + this.c = new pjd(); + this.a = new bnb(); + this.b = new bnb(); + } + function Cje(a, b, c2, d) { + this.ak(); + this.a = b; + this.b = a; + this.c = null; + this.c = new Dje(this, b, c2, d); + } + function NKd(a, b, c2, d, e) { + this.d = a; + this.n = b; + this.g = c2; + this.o = d; + this.p = -1; + e || (this.o = -2 - d - 1); + } + function HWd() { + dWd.call(this); + this.n = -1; + this.g = null; + this.i = null; + this.j = null; + this.Bb |= gwe; + } + function DEb(a) { + xxb.call(this, a.Ad(64) ? Kgb(0, Vdb(a.zd(), 1)) : Sve, a.yd()); + this.b = 1; + this.a = a; + } + function X_c(a, b) { + R_c(); + return RD(mQb(b, (h_c(), W$c)), 17).a < a.gc() && RD(mQb(b, W$c), 17).a >= 0; + } + function Iqd(a, b) { + if (a.r > 0 && a.c < a.r) { + a.c += b; + !!a.i && a.i.d > 0 && a.g != 0 && Iqd(a.i, b / a.r * a.i.d); + } + } + function $Cd(a, b) { + var c2; + c2 = a.c; + a.c = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 1, c2, a.c)); + } + function P1d(a, b) { + var c2; + c2 = a.c; + a.c = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 4, c2, a.c)); + } + function jyd(a, b) { + var c2; + c2 = a.k; + a.k = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 2, c2, a.k)); + } + function JXd(a, b) { + var c2; + c2 = a.D; + a.D = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 2, c2, a.D)); + } + function Kzd(a, b) { + var c2; + c2 = a.f; + a.f = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 8, c2, a.f)); + } + function Lzd(a, b) { + var c2; + c2 = a.i; + a.i = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 7, c2, a.i)); + } + function fCd(a, b) { + var c2; + c2 = a.a; + a.a = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 8, c2, a.a)); + } + function ZCd(a, b) { + var c2; + c2 = a.b; + a.b = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 0, c2, a.b)); + } + function s6d(a, b) { + var c2; + c2 = a.b; + a.b = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 0, c2, a.b)); + } + function t6d(a, b) { + var c2; + c2 = a.c; + a.c = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 1, c2, a.c)); + } + function nVd(a, b) { + var c2; + c2 = a.d; + a.d = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 1, c2, a.d)); + } + function Cte(a, b, c2) { + var d; + a.b = b; + a.a = c2; + d = (a.a & 512) == 512 ? new Gre() : new Tqe(); + a.c = Nqe(d, a.b, a.a); + } + function Gge(a, b) { + return qke(a.e, b) ? (nke(), wWd(b) ? new ole(b, a) : new Eke(b, a)) : new Ble(b, a); + } + function iDb(a) { + var b, c2; + if (0 > a) { + return new rDb(); + } + b = a + 1; + c2 = new kDb(b, a); + return new oDb(null, c2); + } + function Gob(a, b) { + yob(); + var c2; + c2 = new Usb(1); + bE(a) ? $jb(c2, a, b) : rtb(c2.f, a, b); + return new uqb(c2); + } + function pQc(a, b) { + var c2, d; + c2 = a.c; + d = b.e[a.p]; + if (d > 0) { + return RD(Vmb(c2.a, d - 1), 10); + } + return null; + } + function TOb(a, b) { + var c2, d; + c2 = a.o + a.p; + d = b.o + b.p; + if (c2 < d) { + return -1; + } + if (c2 == d) { + return 0; + } + return 1; + } + function Z5b(a) { + var b; + b = mQb(a, (Ywc(), Awc)); + if (ZD(b, 167)) { + return Y5b(RD(b, 167)); + } + return null; + } + function Wp(a) { + var b; + a = $wnd.Math.max(a, 2); + b = mgb(a); + if (a > b) { + b <<= 1; + return b > 0 ? b : hwe; + } + return b; + } + function xc(a) { + Ub(a.e != 3); + switch (a.e) { + case 2: + return false; + case 0: + return true; + } + return zc(a); + } + function djd(a, b) { + var c2; + if (ZD(b, 8)) { + c2 = RD(b, 8); + return a.a == c2.a && a.b == c2.b; + } else { + return false; + } + } + function Ydd(a, b) { + var c2; + c2 = new kRb(); + RD(b.b, 68); + RD(b.b, 68); + RD(b.b, 68); + Umb(b.a, new ced(a, c2, b)); + } + function gOd(a, b) { + var c2, d; + for (d = b.vc().Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 44); + fOd(a, c2.ld(), c2.md()); + } + } + function Jzd(a, b) { + var c2; + c2 = a.d; + a.d = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 11, c2, a.d)); + } + function zWd(a, b) { + var c2; + c2 = a.j; + a.j = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 13, c2, a.j)); + } + function b6d(a, b) { + var c2; + c2 = a.b; + a.b = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 21, c2, a.b)); + } + function YAb(a, b) { + ((gBb(), dBb) ? null : b.c).length == 0 && iBb(b, new rBb()); + $jb(a.a, dBb ? null : b.c, b); + } + function b9b(a, b) { + b.Ug("Hierarchical port constraint processing", 1); + c9b(a); + e9b(a); + b.Vg(); + } + function joc() { + joc = geb; + ioc = new koc("START", 0); + hoc = new koc("MIDDLE", 1); + goc = new koc("END", 2); + } + function x2c() { + x2c = geb; + v2c = new z2c("P1_NODE_PLACEMENT", 0); + w2c = new z2c("P2_EDGE_ROUTING", 1); + } + function JVb() { + JVb = geb; + HVb = new jGd(rAe); + IVb = new jGd(sAe); + GVb = new jGd(tAe); + FVb = new jGd(uAe); + } + function tkb(a) { + var b; + rFb(a.f.g, a.d); + sFb(a.b); + a.c = a.a; + b = RD(a.a.Pb(), 44); + a.b = skb(a); + return b; + } + function P2d(a) { + var b; + if (a.b == null) { + return j3d(), j3d(), i3d; + } + b = a.ul() ? a.tl() : a.sl(); + return b; + } + function nwb(a, b) { + var c2; + c2 = b == null ? -1 : Wmb(a.b, b, 0); + if (c2 < 0) { + return false; + } + owb(a, c2); + return true; + } + function zsb(a, b) { + var c2; + uFb(b); + c2 = b.g; + if (!a.b[c2]) { + bD(a.b, c2, b); + ++a.c; + return true; + } + return false; + } + function azb(a, b) { + var c2, d; + c2 = 1 - b; + d = a.a[c2]; + a.a[c2] = d.a[b]; + d.a[b] = a; + a.b = true; + d.b = false; + return d; + } + function xRb(a, b) { + var c2, d; + for (d = b.Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 272); + a.b = true; + Ysb(a.e, c2); + c2.b = a; + } + } + function kic(a, b) { + var c2, d; + c2 = RD(mQb(a, (yCc(), IBc)), 8); + d = RD(mQb(b, IBc), 8); + return Qfb(c2.b, d.b); + } + function SPb(a, b, c2) { + var d, e, f2; + f2 = b >> 5; + e = b & 31; + d = Cdb(Udb(a.n[c2][f2], Ydb(Sdb(e, 1))), 3); + return d; + } + function lmb(a, b, c2) { + var d, e, f2; + f2 = a.a.length - 1; + for (e = a.b, d = 0; d < c2; e = e + 1 & f2, ++d) { + bD(b, d, a.a[e]); + } + } + function owb(a, b) { + var c2; + c2 = Xmb(a.b, a.b.c.length - 1); + if (b < a.b.c.length) { + $mb(a.b, b, c2); + kwb(a, b); + } + } + function NQc(a, b) { + var c2; + c2 = RD(Wjb(a.c, b), 467); + if (!c2) { + c2 = new UQc(); + c2.c = b; + Zjb(a.c, c2.c, c2); + } + return c2; + } + function PUc(a, b) { + var c2, d; + d = new bnb(); + c2 = b; + do { + ZEb(d.c, c2); + c2 = RD(Wjb(a.k, c2), 18); + } while (c2); + return d; + } + function rMc(a, b, c2) { + var d; + d = new bnb(); + sMc(a, b, d, c2, true, true); + a.b = new _Lc(d.c.length); + return d; + } + function tvb(a, b) { + var c2, d; + c2 = a.Pc(); + Wnb(c2, 0, c2.length, b); + for (d = 0; d < c2.length; d++) { + a.hd(d, c2[d]); + } + } + function Bad(a) { + var b, c2; + for (c2 = new dMd(a); c2.e != c2.i.gc(); ) { + b = RD(bMd(c2), 27); + Dyd(b, 0); + Eyd(b, 0); + } + } + function Bu(a) { + this.e = a; + this.d = new atb(Sv(Ec(this.e).gc())); + this.c = this.e.a; + this.b = this.e.c; + } + function _Lc(a) { + this.b = a; + this.a = $C(kE, Pwe, 28, a + 1, 15, 1); + this.c = $C(kE, Pwe, 28, a, 15, 1); + this.d = 0; + } + function frc(a, b, c2) { + grc.call(this, b, c2); + this.d = $C(jR, WAe, 10, a.a.c.length, 0, 1); + anb(a.a, this.d); + } + function vLc(a, b, c2) { + UIc.call(this, a, b, c2); + this.a = new Tsb(); + this.b = new Tsb(); + this.d = new yLc(this); + } + function Pic(a) { + fHb.call(this); + this.b = Kfb(UD(mQb(a, (yCc(), TBc)))); + this.a = RD(mQb(a, yAc), 223); + } + function _q(a, b) { + var c2; + if (ZD(b, 16)) { + c2 = RD(b, 16); + return a.Gc(c2); + } + return xr(a, RD(Qb(b), 20).Kc()); + } + function KCc(a, b) { + FDb(CDb(new SDb(null, new Swb(new Xkb(a.b), 1)), new esd(a, b)), new isd(a, b)); + } + function f6b(a, b) { + b.Ug(iBe, 1); + FDb(EDb(new SDb(null, new Swb(a.b, 16)), new j6b()), new l6b()); + b.Vg(); + } + function tb(a) { + return bE(a) ? ohb(a) : _D(a) ? Nfb(a) : $D(a) ? Jeb(a) : YD(a) ? a.Hb() : aD(a) ? kFb(a) : Iz(a); + } + function xKc(a) { + var b, c2; + for (c2 = a.c.a.ec().Kc(); c2.Ob(); ) { + b = RD(c2.Pb(), 219); + DJc(b, new NLc(b.f)); + } + } + function yKc(a) { + var b, c2; + for (c2 = a.c.a.ec().Kc(); c2.Ob(); ) { + b = RD(c2.Pb(), 219); + EJc(b, new OLc(b.e)); + } + } + function PAd(a, b) { + var c2; + c2 = a.zb; + a.zb = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 1, c2, a.zb)); + } + function CBd(a, b) { + var c2; + c2 = a.xb; + a.xb = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 3, c2, a.xb)); + } + function DBd(a, b) { + var c2; + c2 = a.yb; + a.yb = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 2, c2, a.yb)); + } + function iBd(a, b) { + var c2, d; + c2 = (d = new mXd(), d); + c2.n = b; + WGd((!a.s && (a.s = new C5d(y7, a, 21, 17)), a.s), c2); + } + function oBd(a, b) { + var c2, d; + d = (c2 = new d6d(), c2); + d.n = b; + WGd((!a.s && (a.s = new C5d(y7, a, 21, 17)), a.s), d); + } + function ye(a, b) { + var c2, d, e; + uFb(b); + c2 = false; + for (e = b.Kc(); e.Ob(); ) { + d = e.Pb(); + c2 = c2 | a.Fc(d); + } + return c2; + } + function Sx(a) { + var b, c2, d; + b = 0; + for (d = a.Kc(); d.Ob(); ) { + c2 = d.Pb(); + b += c2 != null ? tb(c2) : 0; + b = ~~b; + } + return b; + } + function oC(e, a) { + var b = e.a; + var c2 = 0; + for (var d in b) { + b.hasOwnProperty(d) && (a[c2++] = d); + } + return a; + } + function gB(a) { + var b; + if (a == 0) { + return "UTC"; + } + if (a < 0) { + a = -a; + b = "UTC+"; + } else { + b = "UTC-"; + } + return b + iB(a); + } + function xib(a) { + if (a.a < 54) { + return a.f < 0 ? -1 : a.f > 0 ? 1 : 0; + } + return (!a.c && (a.c = ojb(Hdb(a.f))), a.c).e; + } + function GXd(a, b) { + if (b) { + if (a.B == null) { + a.B = a.D; + a.D = null; + } + } else if (a.B != null) { + a.D = a.B; + a.B = null; + } + } + function rZb(a, b) { + nZb(); + return a == jZb && b == mZb || a == mZb && b == jZb || a == lZb && b == kZb || a == kZb && b == lZb; + } + function sZb(a, b) { + nZb(); + return a == jZb && b == kZb || a == jZb && b == lZb || a == mZb && b == lZb || a == mZb && b == kZb; + } + function zMb(a, b) { + return Zy(), bz(Tye), $wnd.Math.abs(0 - b) <= Tye || 0 == b || isNaN(0) && isNaN(b) ? 0 : a / b; + } + function qsc(a, b) { + return Kfb(UD(Lvb(MDb(GDb(new SDb(null, new Swb(a.c.b, 16)), new Isc(a)), b)))); + } + function tsc(a, b) { + return Kfb(UD(Lvb(MDb(GDb(new SDb(null, new Swb(a.c.b, 16)), new Gsc(a)), b)))); + } + function rvc() { + ovc(); + return cD(WC(iX, 1), jwe, 259, 0, [fvc, hvc, ivc, jvc, kvc, lvc, nvc, evc, gvc, mvc]); + } + function dEc() { + aEc(); + return cD(WC(vX, 1), jwe, 243, 0, [$Dc, VDc, YDc, WDc, XDc, SDc, ZDc, _Dc, TDc, UDc]); + } + function z3c(a, b) { + var c2; + b.Ug("General Compactor", 1); + c2 = h4c(RD(Gxd(a, ($4c(), I4c)), 393)); + c2.Cg(a); + } + function T5c(a, b) { + var c2, d; + c2 = RD(Gxd(a, ($4c(), P4c)), 17); + d = RD(Gxd(b, P4c), 17); + return hgb(c2.a, d.a); + } + function Bjd(a, b, c2) { + var d, e; + for (e = Sub(a, 0); e.b != e.d.c; ) { + d = RD(evb(e), 8); + d.a += b; + d.b += c2; + } + return a; + } + function Go(a, b, c2) { + var d; + for (d = a.b[c2 & a.f]; d; d = d.b) { + if (c2 == d.a && Hb(b, d.g)) { + return d; + } + } + return null; + } + function Ho(a, b, c2) { + var d; + for (d = a.c[c2 & a.f]; d; d = d.d) { + if (c2 == d.f && Hb(b, d.i)) { + return d; + } + } + return null; + } + function sjb(a, b, c2) { + var d, e, f2; + d = 0; + for (e = 0; e < c2; e++) { + f2 = b[e]; + a[e] = f2 << 1 | d; + d = f2 >>> 31; + } + d != 0 && (a[c2] = d); + } + function yzb(a, b, c2, d, e, f2) { + var g; + this.c = a; + g = new bnb(); + Syb(a, g, b, a.b, c2, d, e, f2); + this.a = new Jkb(g, 0); + } + function _5c() { + this.c = new T2c(0); + this.b = new T2c(FEe); + this.d = new T2c(EEe); + this.a = new T2c(Gze); + } + function kMb(a, b, c2, d, e, f2, g) { + qs.call(this, a, b); + this.d = c2; + this.e = d; + this.c = e; + this.b = f2; + this.a = dv(g); + } + function tBd(a, b, c2, d, e, f2, g, h, i2, j, k, l, m) { + ABd(a, b, c2, d, e, f2, g, h, i2, j, k, l, m); + kXd(a, false); + return a; + } + function H0b(a) { + if (a.b.c.i.k == (r3b(), m3b)) { + return RD(mQb(a.b.c.i, (Ywc(), Awc)), 12); + } + return a.b.c; + } + function I0b(a) { + if (a.b.d.i.k == (r3b(), m3b)) { + return RD(mQb(a.b.d.i, (Ywc(), Awc)), 12); + } + return a.b.d; + } + function nDb(a) { + var b; + b = mDb(a); + if (Gdb(b.a, 0)) { + return bwb(), bwb(), awb; + } + return bwb(), new ewb(b.b); + } + function SCb(a) { + var b; + b = RCb(a); + if (Gdb(b.a, 0)) { + return Tvb(), Tvb(), Svb; + } + return Tvb(), new Yvb(b.b); + } + function TCb(a) { + var b; + b = RCb(a); + if (Gdb(b.a, 0)) { + return Tvb(), Tvb(), Svb; + } + return Tvb(), new Yvb(b.c); + } + function o8b(a) { + switch (a.g) { + case 2: + return qpd(), ppd; + case 4: + return qpd(), Xod; + default: + return a; + } + } + function p8b(a) { + switch (a.g) { + case 1: + return qpd(), npd; + case 3: + return qpd(), Yod; + default: + return a; + } + } + function C9c(a) { + switch (a.g) { + case 0: + return new s9c(); + case 1: + return new x9c(); + default: + return null; + } + } + function Zcc() { + Zcc = geb; + Ycc = new kGd("edgelabelcenterednessanalysis.includelabel", (Geb(), Eeb)); + } + function jKc() { + jKc = geb; + iKc = mfd(qfd(pfd(pfd(new ufd(), (sXb(), pXb), (hcc(), Qbc)), qXb, Gbc), rXb), Pbc); + } + function DLc() { + DLc = geb; + CLc = mfd(qfd(pfd(pfd(new ufd(), (sXb(), pXb), (hcc(), Qbc)), qXb, Gbc), rXb), Pbc); + } + function lYd() { + lYd = geb; + iYd = new i1d(); + kYd = cD(WC(y7, 1), lKe, 179, 0, []); + jYd = cD(WC(s7, 1), mKe, 62, 0, []); + } + function P8b() { + P8b = geb; + O8b = new Q8b("TO_INTERNAL_LTR", 0); + N8b = new Q8b("TO_INPUT_DIRECTION", 1); + } + function J3b() { + J3b = geb; + G3b = new r4b(); + E3b = new w4b(); + F3b = new A4b(); + D3b = new E4b(); + H3b = new I4b(); + I3b = new M4b(); + } + function Cac(a, b) { + b.Ug(iBe, 1); + LJb(KJb(new PJb((i1b(), new t1b(a, false, false, new _1b()))))); + b.Vg(); + } + function M_c(a, b, c2) { + c2.Ug("DFS Treeifying phase", 1); + L_c(a, b); + J_c(a, b); + a.a = null; + a.b = null; + c2.Vg(); + } + function Leb(a, b) { + Geb(); + return bE(a) ? jhb(a, WD(b)) : _D(a) ? Jfb(a, UD(b)) : $D(a) ? Ieb(a, TD(b)) : a.Fd(b); + } + function Ld(a, b) { + var c2, d; + uFb(b); + for (d = b.vc().Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 44); + a.zc(c2.ld(), c2.md()); + } + } + function ege(a, b, c2) { + var d; + for (d = c2.Kc(); d.Ob(); ) { + if (!cge(a, b, d.Pb())) { + return false; + } + } + return true; + } + function S6d(a, b, c2, d, e) { + var f2; + if (c2) { + f2 = BYd(b.Dh(), a.c); + e = c2.Rh(b, -1 - (f2 == -1 ? d : f2), null, e); + } + return e; + } + function T6d(a, b, c2, d, e) { + var f2; + if (c2) { + f2 = BYd(b.Dh(), a.c); + e = c2.Th(b, -1 - (f2 == -1 ? d : f2), null, e); + } + return e; + } + function Uib(a) { + var b; + if (a.b == -2) { + if (a.e == 0) { + b = -1; + } else { + for (b = 0; a.a[b] == 0; b++) + ; + } + a.b = b; + } + return a.b; + } + function fjb(a) { + uFb(a); + if (a.length == 0) { + throw Adb(new Vgb("Zero length BigInteger")); + } + mjb(this, a); + } + function $Hd(a) { + this.i = a.gc(); + if (this.i > 0) { + this.g = this.aj(this.i + (this.i / 8 | 0) + 1); + a.Qc(this.g); + } + } + function dmc(a, b, c2) { + this.g = a; + this.d = b; + this.e = c2; + this.a = new bnb(); + bmc(this); + yob(); + _mb(this.a, null); + } + function aad(a, b) { + b.q = a; + a.d = $wnd.Math.max(a.d, b.r); + a.b += b.d + (a.a.c.length == 0 ? 0 : a.c); + Rmb(a.a, b); + } + function xid(a, b) { + var c2, d, e, f2; + e = a.c; + c2 = a.c + a.b; + f2 = a.d; + d = a.d + a.a; + return b.a > e && b.a < c2 && b.b > f2 && b.b < d; + } + function Cjd(a, b) { + var c2, d; + for (d = Sub(a, 0); d.b != d.d.c; ) { + c2 = RD(evb(d), 8); + c2.a += b.a; + c2.b += b.b; + } + return a; + } + function $cc(a) { + var b, c2, d; + d = 0; + for (c2 = new Anb(a.b); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 30); + b.p = d; + ++d; + } + } + function Tnc(a) { + var b, c2, d; + return a.j == (qpd(), Yod) && (b = Vnc(a), c2 = Csb(b, Xod), d = Csb(b, ppd), d || d && c2); + } + function rsd(a, b) { + var c2; + c2 = wsd(a); + return qsd(new rjd(c2.c, c2.d), new rjd(c2.b, c2.a), a.Mf(), b, a.ag()); + } + function wEd(a, b) { + var c2; + c2 = RD(b, 190); + qDd(c2, "x", a.i); + qDd(c2, "y", a.j); + qDd(c2, fIe, a.g); + qDd(c2, eIe, a.f); + } + function CVd(a, b) { + var c2; + if (ZD(b, 85)) { + RD(a.c, 79).Gk(); + c2 = RD(b, 85); + gOd(a, c2); + } else { + RD(a.c, 79).Wb(b); + } + } + function Bvb(a, b) { + var c2, d; + uFb(b); + for (d = a.vc().Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 44); + b.Yd(c2.ld(), c2.md()); + } + } + function zr(a, b) { + var c2; + Qb(b); + while (a.Ob()) { + c2 = a.Pb(); + if (!oSc(RD(c2, 10))) { + return false; + } + } + return true; + } + function _Ab() { + var a; + if (!XAb) { + XAb = new $Ab(); + a = new oBb(""); + mBb(a, (SAb(), RAb)); + YAb(XAb, a); + } + return XAb; + } + function PBb(a, b) { + return sBb(new lCb(a), new nCb(b), new pCb(b), new rCb(), cD(WC(QL, 1), jwe, 108, 0, [])); + } + function t5c() { + t5c = geb; + r5c = new v5c(LAe, 0); + s5c = new v5c("POLAR_COORDINATE", 1); + q5c = new v5c("ID", 2); + } + function KEc() { + KEc = geb; + HEc = new LEc("EQUALLY", 0); + IEc = new LEc(_ye, 1); + JEc = new LEc("NORTH_SOUTH", 2); + } + function OQb() { + OQb = geb; + MQb = new kGd("debugSVG", (Geb(), false)); + NQb = new kGd("overlapsExisted", true); + } + function pid() { + pid = geb; + oid = ss((kid(), cD(WC(e3, 1), jwe, 285, 0, [jid, cid, gid, iid, did, eid, fid, hid]))); + } + function fGd() { + fGd = geb; + eGd = ss((aGd(), cD(WC(T5, 1), jwe, 245, 0, [_Fd, YFd, ZFd, XFd, $Fd, VFd, UFd, WFd]))); + } + function jpc() { + jpc = geb; + ipc = ss((epc(), cD(WC(hW, 1), jwe, 276, 0, [Zoc, apc, Yoc, dpc, _oc, $oc, cpc, bpc]))); + } + function $Yc() { + WYc(); + return cD(WC(u_, 1), jwe, 262, 0, [VYc, OYc, SYc, TYc, RYc, NYc, UYc, LYc, QYc, PYc, MYc]); + } + function $i(a, b, c2) { + var d, e; + e = RD(Fn(a.d, b), 17); + d = RD(Fn(a.b, c2), 17); + return !e || !d ? null : Ui(a, e.a, d.a); + } + function cgd(a, b) { + var c2; + c2 = sgd(ygd(), a); + if (c2) { + Ixd(b, (umd(), Tld), c2); + return true; + } else { + return false; + } + } + function TMb(a) { + RMb(); + if (a.A.Hc((Qpd(), Mpd))) { + if (!a.B.Hc((dqd(), $pd))) { + return SMb(a); + } + } + return null; + } + function tUb() { + this.a = RD(iGd((yVb(), aVb)), 17).a; + this.c = Kfb(UD(iGd(rVb))); + this.b = Kfb(UD(iGd(nVb))); + } + function vkb(a) { + this.f = a; + this.e = new Qtb(this.f.i); + this.a = this.e; + this.b = skb(this); + this.d = this.f.g; + } + function Uge(a, b) { + Kfe.call(this, Ibb, a, b); + this.b = this; + this.a = pke(a.Dh(), vYd(this.e.Dh(), this.c)); + } + function bdc(a, b) { + var c2, d; + for (d = new Anb(b.b); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 30); + a.a[c2.p] = h2b(c2); + } + } + function ofd(a, b) { + var c2; + for (c2 = 0; c2 < b.j.c.length; c2++) { + RD(Med(a, c2), 21).Gc(RD(Med(b, c2), 16)); + } + return a; + } + function peb(a, b, c2, d) { + var e; + e = a.a.length; + c2 > e ? c2 = e : BFb(b, c2 + 1); + a.a = zhb(a.a, 0, b) + ("" + d) + yhb(a.a, c2); + } + function ktb(a, b) { + a.a = Bdb(a.a, 1); + a.c = $wnd.Math.min(a.c, b); + a.b = $wnd.Math.max(a.b, b); + a.d = Bdb(a.d, b); + } + function wdc(a, b) { + return b < a.b.gc() ? RD(a.b.Xb(b), 10) : b == a.b.gc() ? a.a : RD(Vmb(a.e, b - a.b.gc() - 1), 10); + } + function rXc(a, b, c2) { + return Qfb(cjd(jWc(a), new rjd(b.e.a, b.e.b)), cjd(jWc(a), new rjd(c2.e.a, c2.e.b))); + } + function WJc(a, b, c2) { + return a == (RKc(), QKc) ? new PJc() : Kwb(b, 1) != 0 ? new ILc(c2.length) : new pLc(c2.length); + } + function qvd(a, b) { + var c2, d, e; + c2 = a.th(); + if (c2 != null && a.wh()) { + for (d = 0, e = c2.length; d < e; ++d) { + c2[d].dj(b); + } + } + } + function QBb(a, b) { + var c2, d, e; + c2 = a.c.Xe(); + for (e = b.Kc(); e.Ob(); ) { + d = e.Pb(); + a.a.Yd(c2, d); + } + return a.b.Kb(c2); + } + function n2b(a, b) { + var c2, d; + c2 = a; + d = Y2b(c2).e; + while (d) { + c2 = d; + if (c2 == b) { + return true; + } + d = Y2b(c2).e; + } + return false; + } + function Edb(a) { + var b; + b = a.h; + if (b == 0) { + return a.l + a.m * gxe; + } + if (b == exe) { + return a.l + a.m * gxe - hxe; + } + return a; + } + function LHc(a, b, c2) { + var d, e; + d = a.a.f[b.p]; + e = a.a.f[c2.p]; + if (d < e) { + return -1; + } + if (d == e) { + return 0; + } + return 1; + } + function Wmc(a, b) { + var c2, d; + for (d = new Anb(b); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 72); + Rmb(a.d, c2); + $mc(a, c2); + } + } + function E6b(a, b) { + var c2; + b.Ug("Edge and layer constraint edge reversal", 1); + c2 = D6b(a); + C6b(c2); + b.Vg(); + } + function m6c(a, b) { + var c2, d; + for (d = new dMd(a); d.e != d.i.gc(); ) { + c2 = RD(bMd(d), 27); + Byd(c2, c2.i + b.b, c2.j + b.d); + } + } + function TNd(a) { + var b; + if (a.d == null) { + ++a.e; + a.f = 0; + SNd(null); + } else { + ++a.e; + b = a.d; + a.d = null; + a.f = 0; + SNd(b); + } + } + function Ys(a) { + var b; + if (a.a == a.b.a) { + throw Adb(new Dvb()); + } + b = a.a; + a.c = b; + a.a = RD(Hvb(a.a.e), 227); + return b; + } + function Ywd(a, b) { + var c2; + if ((a.Db & b) != 0) { + c2 = Xwd(a, b); + return c2 == -1 ? a.Eb : SD(a.Eb)[c2]; + } else { + return null; + } + } + function jBd(a, b) { + var c2, d; + c2 = (d = new HYd(), d); + c2.G = b; + !a.rb && (a.rb = new J5d(a, i7, a)); + WGd(a.rb, c2); + return c2; + } + function kBd(a, b) { + var c2, d; + c2 = (d = new k1d(), d); + c2.G = b; + !a.rb && (a.rb = new J5d(a, i7, a)); + WGd(a.rb, c2); + return c2; + } + function wBd(a, b, c2, d) { + ZD(a.Cb, 184) && (RD(a.Cb, 184).tb = null); + PAd(a, c2); + !!b && HXd(a, b); + d && a.gl(true); + } + function nJc(a, b) { + if (a.c) { + oJc(a, b, true); + FDb(new SDb(null, new Swb(b, 16)), new BJc(a)); + } + oJc(a, b, false); + } + function KRc(a) { + FRc(); + var b; + if (!Urb(ERc, a)) { + b = new HRc(); + b.a = a; + Xrb(ERc, a, b); + } + return RD(Vrb(ERc, a), 645); + } + function k3d(a) { + var b; + if (a.g > 1 || a.Ob()) { + ++a.a; + a.g = 0; + b = a.i; + a.Ob(); + return b; + } else { + throw Adb(new Dvb()); + } + } + function GRc(a) { + switch (a.a.g) { + case 1: + return new lSc(); + case 3: + return new VUc(); + default: + return new WRc(); + } + } + function fyd(a, b) { + switch (b) { + case 1: + return !!a.n && a.n.i != 0; + case 2: + return a.k != null; + } + return Cxd(a, b); + } + function Hdb(a) { + if (jxe < a && a < hxe) { + return a < 0 ? $wnd.Math.ceil(a) : $wnd.Math.floor(a); + } + return Edb(vD(a)); + } + function hfb(a) { + var b; + if (a < 128) { + return jfb(), b = ifb[a], !b && (b = ifb[a] = new bfb(a)), b; + } + return new bfb(a); + } + function PCb(b, c2) { + var d; + try { + c2.de(); + } catch (a) { + a = zdb(a); + if (ZD(a, 82)) { + d = a; + ZEb(b.c, d); + } else + throw Adb(a); + } + } + function Wdb(a) { + var b, c2, d, e; + e = a; + d = 0; + if (e < 0) { + e += hxe; + d = exe; + } + c2 = eE(e / gxe); + b = eE(e - c2 * gxe); + return hD(b, c2, d); + } + function dy(a) { + var b, c2, d; + d = 0; + for (c2 = new Osb(a.a); c2.a < c2.c.a.length; ) { + b = Nsb(c2); + a.b.Hc(b) && ++d; + } + return d; + } + function _u(a) { + var b, c2, d; + b = 1; + for (d = a.Kc(); d.Ob(); ) { + c2 = d.Pb(); + b = 31 * b + (c2 == null ? 0 : tb(c2)); + b = ~~b; + } + return b; + } + function kQb(a, b) { + var c2; + if (!b) { + return a; + } + c2 = b.nf(); + c2.dc() || (!a.q ? a.q = new Vsb(c2) : Ld(a.q, c2)); + return a; + } + function Mtb(a, b) { + var c2; + c2 = a.a.get(b); + if (c2 === void 0) { + ++a.d; + } else { + Ctb(a.a, b); + --a.c; + ++a.b.g; + } + return c2; + } + function a0b(a, b) { + var c2, d, e; + c2 = b.p - a.p; + if (c2 == 0) { + d = a.f.a * a.f.b; + e = b.f.a * b.f.b; + return Qfb(d, e); + } + return c2; + } + function Jfc(a, b) { + var c2, d; + c2 = a.j; + d = b.j; + return c2 != d ? c2.g - d.g : a.p == b.p ? 0 : c2 == (qpd(), Yod) ? a.p - b.p : b.p - a.p; + } + function dFc(a, b, c2, d, e) { + bD(a.c[b.g], c2.g, d); + bD(a.c[c2.g], b.g, d); + bD(a.b[b.g], c2.g, e); + bD(a.b[c2.g], b.g, e); + } + function Jyb(a, b, c2) { + this.b = (uFb(a), a); + this.d = (uFb(b), b); + this.e = (uFb(c2), c2); + this.c = this.d + ("" + this.e); + } + function Phe(a, b) { + this.b = a; + this.e = b; + this.d = b.j; + this.f = (nke(), RD(a, 69).xk()); + this.k = pke(b.e.Dh(), a); + } + function USc(a) { + this.n = new bnb(); + this.e = new Yub(); + this.j = new Yub(); + this.k = new bnb(); + this.f = new bnb(); + this.p = a; + } + function rVc(a) { + a.r = new _sb(); + a.w = new _sb(); + a.t = new bnb(); + a.i = new bnb(); + a.d = new _sb(); + a.a = new Tid(); + a.c = new Tsb(); + } + function mOb() { + mOb = geb; + lOb = new nOb("UP", 0); + iOb = new nOb(Zye, 1); + jOb = new nOb(Nye, 2); + kOb = new nOb(Oye, 3); + } + function xvc() { + xvc = geb; + vvc = new yvc("ONE_SIDED", 0); + wvc = new yvc("TWO_SIDED", 1); + uvc = new yvc("OFF", 2); + } + function B9c() { + B9c = geb; + z9c = new D9c("EQUAL_BETWEEN_STRUCTURES", 0); + A9c = new D9c("TO_ASPECT_RATIO", 1); + } + function hDc() { + hDc = geb; + gDc = ss((_Cc(), cD(WC(rX, 1), jwe, 265, 0, [ZCc, WCc, XCc, TCc, VCc, $Cc, YCc, SCc, UCc]))); + } + function iqd() { + iqd = geb; + hqd = ss((dqd(), cD(WC(I3, 1), jwe, 264, 0, [Ypd, $pd, Xpd, _pd, aqd, cqd, bqd, Zpd, Wpd]))); + } + function jod() { + jod = geb; + iod = ss((dod(), cD(WC(A3, 1), jwe, 95, 0, [Xnd, Wnd, Znd, cod, bod, aod, $nd, _nd, Ynd]))); + } + function nIb() { + nIb = geb; + mIb = ss((iIb(), cD(WC(xN, 1), jwe, 257, 0, [hIb, cIb, dIb, bIb, fIb, gIb, eIb, aIb, _Hb]))); + } + function oSc(a) { + var b; + b = RD(mQb(a, (Ywc(), hwc)), 64); + return a.k == (r3b(), m3b) && (b == (qpd(), ppd) || b == Xod); + } + function j0b(a, b, c2) { + var d, e; + e = RD(mQb(a, (yCc(), RAc)), 75); + if (e) { + d = new Ejd(); + Ajd(d, 0, e); + Cjd(d, c2); + ye(b, d); + } + } + function U2b(a, b, c2) { + var d, e, f2, g; + g = Y2b(a); + d = g.d; + e = g.c; + f2 = a.n; + b && (f2.a = f2.a - d.b - e.a); + c2 && (f2.b = f2.b - d.d - e.b); + } + function OOb(a, b) { + var c2, d; + c2 = a.f.c.length; + d = b.f.c.length; + if (c2 < d) { + return -1; + } + if (c2 == d) { + return 0; + } + return 1; + } + function S0b(a) { + if (a.b.c.length != 0 && !!RD(Vmb(a.b, 0), 72).a) { + return RD(Vmb(a.b, 0), 72).a; + } + return R0b(a); + } + function fr(a) { + var b; + if (a) { + b = a; + if (b.dc()) { + throw Adb(new Dvb()); + } + return b.Xb(b.gc() - 1); + } + return Fr(a.Kc()); + } + function Dib(a) { + var b; + Ddb(a, 0) < 0 && (a = Qdb(a)); + return b = Ydb(Udb(a, 32)), 64 - (b != 0 ? ngb(b) : ngb(Ydb(a)) + 32); + } + function pBb() { + gBb(); + if (dBb) { + return new oBb(null); + } + return ZAb(_Ab(), "com.google.common.base.Strings"); + } + function eyd(a, b, c2, d) { + if (c2 == 1) { + return !a.n && (a.n = new C5d(I4, a, 1, 7)), rLd(a.n, b, d); + } + return Bxd(a, b, c2, d); + } + function eBd(a, b) { + var c2, d; + d = (c2 = new _9d(), c2); + PAd(d, b); + WGd((!a.A && (a.A = new iie(z7, a, 7)), a.A), d); + return d; + } + function xEd(a, b, c2) { + var d, e, f2, g; + f2 = null; + g = b; + e = wDd(g, iIe); + d = new JEd(a, c2); + f2 = (LDd(d.a, d.b, e), e); + return f2; + } + function iXd(a) { + var b; + if (!a.a || (a.Bb & 1) == 0 && a.a.Vh()) { + b = WVd(a); + ZD(b, 156) && (a.a = RD(b, 156)); + } + return a.a; + } + function Be(a, b) { + var c2, d; + uFb(b); + for (d = b.Kc(); d.Ob(); ) { + c2 = d.Pb(); + if (!a.Hc(c2)) { + return false; + } + } + return true; + } + function sD(a, b) { + var c2, d, e; + c2 = a.l + b.l; + d = a.m + b.m + (c2 >> 22); + e = a.h + b.h + (d >> 22); + return hD(c2 & dxe, d & dxe, e & exe); + } + function DD(a, b) { + var c2, d, e; + c2 = a.l - b.l; + d = a.m - b.m + (c2 >> 22); + e = a.h - b.h + (d >> 22); + return hD(c2 & dxe, d & dxe, e & exe); + } + function Jpc(a) { + var b, c2; + Hpc(a); + for (c2 = new Anb(a.d); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 105); + !!b.i && Ipc(b); + } + } + function zdb(a) { + var b; + if (ZD(a, 82)) { + return a; + } + b = a && a.__java$exception; + if (!b) { + b = new Cz(a); + gA(b); + } + return b; + } + function BGd(a) { + if (ZD(a, 193)) { + return RD(a, 123); + } else if (!a) { + throw Adb(new Ogb(HIe)); + } else { + return null; + } + } + function skb(a) { + if (a.a.Ob()) { + return true; + } + if (a.a != a.e) { + return false; + } + a.a = new wtb(a.f.f); + return a.a.Ob(); + } + function kmb(a, b) { + if (b == null) { + return false; + } + while (a.a != a.b) { + if (pb(b, Imb(a))) { + return true; + } + } + return false; + } + function dHb(a, b) { + if (!a || !b || a == b) { + return false; + } + return tGb(a.d.c, b.d.c + b.d.b) && tGb(b.d.c, a.d.c + a.d.b); + } + function Tmb(a, b) { + var c2, d; + c2 = b.Pc(); + d = c2.length; + if (d == 0) { + return false; + } + YEb(a.c, a.c.length, c2); + return true; + } + function NBb(a, b, c2) { + var d, e; + for (e = b.vc().Kc(); e.Ob(); ) { + d = RD(e.Pb(), 44); + a.yc(d.ld(), d.md(), c2); + } + return a; + } + function $Wc(a) { + var b, c2, d; + b = new Yub(); + for (d = Sub(a.d, 0); d.b != d.d.c; ) { + c2 = RD(evb(d), 65); + Mub(b, c2.c); + } + return b; + } + function Pdc(a, b) { + var c2, d; + for (d = new Anb(a.b); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 72); + pQb(c2, (Ywc(), swc), b); + } + } + function L9c(a, b, c2) { + var d, e; + for (e = new Anb(a.b); e.a < e.c.c.length; ) { + d = RD(ynb(e), 27); + Byd(d, d.i + b, d.j + c2); + } + } + function Nb(a, b) { + if (!a) { + throw Adb(new agb(hc("value already present: %s", cD(WC(jJ, 1), rve, 1, 5, [b])))); + } + } + function Aid(a, b, c2, d, e) { + tid(); + return $wnd.Math.min(Lid(a, b, c2, d, e), Lid(c2, d, a, b, fjd(new rjd(e.a, e.b)))); + } + function Rdd(a, b, c2, d) { + RD(c2.b, 68); + RD(c2.b, 68); + RD(d.b, 68); + RD(d.b, 68); + RD(d.b, 68); + Umb(d.a, new Wdd(a, b, d)); + } + function NGb(a, b) { + a.d == (Cmd(), ymd) || a.d == Bmd ? RD(b.a, 60).c.Fc(RD(b.b, 60)) : RD(b.b, 60).c.Fc(RD(b.a, 60)); + } + function Ued(a, b) { + var c2; + c2 = ev(b.a.gc()); + FDb(PDb(new SDb(null, new Swb(b, 1)), a.i), new ffd(a, c2)); + return c2; + } + function fBd(a) { + var b, c2; + c2 = (b = new _9d(), b); + PAd(c2, "T"); + WGd((!a.d && (a.d = new iie(z7, a, 11)), a.d), c2); + return c2; + } + function cHd(a) { + var b, c2, d, e; + b = 1; + for (c2 = 0, e = a.gc(); c2 < e; ++c2) { + d = a.Vi(c2); + b = 31 * b + (d == null ? 0 : tb(d)); + } + return b; + } + function cj(a, b, c2, d) { + var e; + Pb(b, a.e.Rd().gc()); + Pb(c2, a.c.Rd().gc()); + e = a.a[b][c2]; + bD(a.a[b], c2, d); + return e; + } + function cD(a, b, c2, d, e) { + e.Rm = a; + e.Sm = b; + e.Tm = keb; + e.__elementTypeId$ = c2; + e.__elementTypeCategory$ = d; + return e; + } + function vec() { + vec = geb; + uec = new xec(LAe, 0); + sec = new xec(oBe, 1); + tec = new xec(pBe, 2); + rec = new xec("BOTH", 3); + } + function enc() { + enc = geb; + anc = new fnc(Kye, 0); + bnc = new fnc(Nye, 1); + cnc = new fnc(Oye, 2); + dnc = new fnc("TOP", 3); + } + function nZb() { + nZb = geb; + jZb = new qZb("Q1", 0); + mZb = new qZb("Q4", 1); + kZb = new qZb("Q2", 2); + lZb = new qZb("Q3", 3); + } + function DFc() { + DFc = geb; + BFc = new EFc("OFF", 0); + CFc = new EFc("SINGLE_EDGE", 1); + AFc = new EFc("MULTI_EDGE", 2); + } + function ldd() { + ldd = geb; + kdd = new ndd("MINIMUM_SPANNING_TREE", 0); + jdd = new ndd("MAXIMUM_SPANNING_TREE", 1); + } + function hed() { + hed = geb; + fed = new sed(); + eed = new qed(); + } + function EGd(a) { + var b, c2; + c2 = (bvd(), b = new Rzd(), b); + !!a && WGd((!a.a && (a.a = new C5d(F4, a, 6, 6)), a.a), c2); + return c2; + } + function N2c(a) { + var b, c2, d, e; + e = new bnb(); + for (d = a.Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 27); + b = Q2c(c2); + Tmb(e, b); + } + return e; + } + function Jr(a, b) { + var c2, d; + Rb(b, "predicate"); + for (d = 0; a.Ob(); d++) { + c2 = a.Pb(); + if (b.Lb(c2)) { + return d; + } + } + return -1; + } + function xSd(a, b) { + var c2, d; + d = 0; + if (a < 64 && a <= b) { + b = b < 64 ? b : 63; + for (c2 = a; c2 <= b; c2++) { + d = Rdb(d, Sdb(1, c2)); + } + } + return d; + } + function oQc(a, b) { + var c2, d; + c2 = a.c; + d = b.e[a.p]; + if (d < c2.a.c.length - 1) { + return RD(Vmb(c2.a, d + 1), 10); + } + return null; + } + function Bob(a) { + yob(); + var b, c2, d; + d = 0; + for (c2 = a.Kc(); c2.Ob(); ) { + b = c2.Pb(); + d = d + (b != null ? tb(b) : 0); + d = d | 0; + } + return d; + } + function wsb(a) { + var b, c2, d; + b = RD(a.e && a.e(), 9); + d = (c2 = b.slice(), RD(dD(c2, b), 9)); + return new Fsb(b, d, b.length); + } + function Bdd(a, b, c2) { + var d; + akb(a.a); + Umb(c2.i, new Mdd(a)); + d = new $Fb(RD(Wjb(a.a, b.b), 68)); + Add(a, d, b); + c2.f = d; + } + function bgc(a) { + var b; + X0b(a, true); + b = Awe; + nQb(a, (yCc(), KBc)) && (b += RD(mQb(a, KBc), 17).a); + pQb(a, KBc, sgb(b)); + } + function hB(a) { + var b; + b = new dB(); + b.a = a; + b.b = fB(a); + b.c = $C(qJ, Nve, 2, 2, 6, 1); + b.c[0] = gB(a); + b.c[1] = gB(a); + return b; + } + function Z7b(a) { + var b, c2, d; + c2 = a.n; + d = a.o; + b = a.d; + return new Uid2(c2.a - b.b, c2.b - b.d, d.a + (b.b + b.c), d.b + (b.d + b.a)); + } + function UQb(a, b) { + if (!a || !b || a == b) { + return false; + } + return $y(a.b.c, b.b.c + b.b.b) < 0 && $y(b.b.c, a.b.c + a.b.b) < 0; + } + function Qnd(a) { + switch (a.g) { + case 1: + return Mnd; + case 2: + return Lnd; + case 3: + return Nnd; + default: + return Ond; + } + } + function mec(a) { + switch (RD(mQb(a, (yCc(), UAc)), 171).g) { + case 2: + case 4: + return true; + default: + return false; + } + } + function aHb(a, b, c2) { + switch (c2.g) { + case 2: + a.b = b; + break; + case 1: + a.c = b; + break; + case 4: + a.d = b; + break; + case 3: + a.a = b; + } + } + function Exd(a, b) { + switch (b) { + case 0: + !a.o && (a.o = new DVd((pvd(), mvd), X4, a, 0)); + a.o.c.$b(); + return; + } + $vd(a, b); + } + function Mad(a, b) { + var c2, d; + c2 = RD(RD(Wjb(a.g, b.a), 42).a, 68); + d = RD(RD(Wjb(a.g, b.b), 42).a, 68); + return SQb(c2, d); + } + function XGd(a, b, c2) { + var d; + d = a.gc(); + if (b > d) + throw Adb(new aMd(b, d)); + a.Si() && (c2 = bHd(a, c2)); + return a.Ei(b, c2); + } + function eQb(a, b, c2, d, e) { + var f2, g; + for (g = c2; g <= e; g++) { + for (f2 = b; f2 <= d; f2++) { + PPb(a, f2, g) || TPb(a, f2, g, true, false); + } + } + } + function uid(a) { + tid(); + var b, c2, d; + c2 = $C(l3, Nve, 8, 2, 0, 1); + d = 0; + for (b = 0; b < 2; b++) { + d += 0.5; + c2[b] = Cid(d, a); + } + return c2; + } + function xD(a) { + var b, c2, d; + b = ~a.l + 1 & dxe; + c2 = ~a.m + (b == 0 ? 1 : 0) & dxe; + d = ~a.h + (b == 0 && c2 == 0 ? 1 : 0) & exe; + return hD(b, c2, d); + } + function mgb(a) { + var b; + if (a < 0) { + return qwe; + } else if (a == 0) { + return 0; + } else { + for (b = hwe; (b & a) == 0; b >>= 1) + ; + return b; + } + } + function zSd(a, b, c2) { + if (a >= 128) + return false; + return a < 64 ? Pdb(Cdb(Sdb(1, a), c2), 0) : Pdb(Cdb(Sdb(1, a - 64), b), 0); + } + function oQb(a, b, c2) { + return c2 == null ? (!a.q && (a.q = new Tsb()), _jb(a.q, b)) : (!a.q && (a.q = new Tsb()), Zjb(a.q, b, c2)), a; + } + function pQb(a, b, c2) { + c2 == null ? (!a.q && (a.q = new Tsb()), _jb(a.q, b)) : (!a.q && (a.q = new Tsb()), Zjb(a.q, b, c2)); + return a; + } + function KTb(a) { + var b, c2; + c2 = new gUb(); + kQb(c2, a); + pQb(c2, (JVb(), HVb), a); + b = new Tsb(); + MTb(a, c2, b); + LTb(a, c2, b); + return c2; + } + function cIc(a) { + var b, c2; + b = a.t - a.k[a.o.p] * a.d + a.j[a.o.p] > a.f; + c2 = a.u + a.e[a.o.p] * a.d > a.f * a.s * a.d; + return b || c2; + } + function qmc(a, b) { + var c2, d, e, f2; + c2 = false; + d = a.a[b].length; + for (f2 = 0; f2 < d - 1; f2++) { + e = f2 + 1; + c2 = c2 | rmc(a, b, f2, e); + } + return c2; + } + function Emc(a) { + var b, c2, d, e; + for (c2 = a.a, d = 0, e = c2.length; d < e; ++d) { + b = c2[d]; + Jmc(a, b, (qpd(), npd)); + Jmc(a, b, Yod); + } + } + function tvc() { + tvc = geb; + svc = ss((ovc(), cD(WC(iX, 1), jwe, 259, 0, [fvc, hvc, ivc, jvc, kvc, lvc, nvc, evc, gvc, mvc]))); + } + function fEc() { + fEc = geb; + eEc = ss((aEc(), cD(WC(vX, 1), jwe, 243, 0, [$Dc, VDc, YDc, WDc, XDc, SDc, ZDc, _Dc, TDc, UDc]))); + } + function huc() { + huc = geb; + fuc = new iuc(LAe, 0); + euc = new iuc("INCOMING_ONLY", 1); + guc = new iuc("OUTGOING_ONLY", 2); + } + function HC() { + HC = geb; + GC = { "boolean": IC, "number": JC, "string": LC, "object": KC, "function": KC, "undefined": MC }; + } + function pfb() { + this.o = null; + this.k = null; + this.j = null; + this.d = null; + this.b = null; + this.n = null; + this.a = null; + } + function pj(a, b) { + this.c = a; + this.d = b; + this.b = this.d / this.c.c.Rd().gc() | 0; + this.a = this.d % this.c.c.Rd().gc(); + } + function R$d(a, b) { + this.b = a; + N$d.call(this, (RD(QHd(xYd((lTd(), kTd).o), 10), 19), b.i), b.g); + this.a = (lYd(), kYd); + } + function vB(a, b, c2) { + this.q = new $wnd.Date(); + this.q.setFullYear(a + Owe, b, c2); + this.q.setHours(0, 0, 0, 0); + mB(this, 0); + } + function ckb(a, b) { + mFb(a >= 0, "Negative initial capacity"); + mFb(b >= 0, "Non-positive load factor"); + akb(this); + } + function iib(a, b, c2, d, e) { + var f2, g; + g = a.length; + f2 = c2.length; + if (b < 0 || d < 0 || e < 0 || b + e > g || d + e > f2) { + throw Adb(new ueb()); + } + } + function zob(a, b) { + yob(); + var c2, d, e, f2, g; + g = false; + for (d = b, e = 0, f2 = d.length; e < f2; ++e) { + c2 = d[e]; + g = g | a.Fc(c2); + } + return g; + } + function Wyb(a, b, c2) { + var d, e; + d = new Fzb(b, c2); + e = new Gzb(); + a.b = Uyb(a, a.b, d, e); + e.b || ++a.c; + a.b.b = false; + return e.d; + } + function omb(a) { + var b; + b = a.a[a.b]; + if (b == null) { + return null; + } + bD(a.a, a.b, null); + a.b = a.b + 1 & a.a.length - 1; + return b; + } + function oD(a) { + var b, c2; + c2 = ngb(a.h); + if (c2 == 32) { + b = ngb(a.m); + return b == 32 ? ngb(a.l) + 32 : b + 20 - 10; + } else { + return c2 - 12; + } + } + function $5d(a) { + var b; + if (!a.c || (a.Bb & 1) == 0 && (a.c.Db & 64) != 0) { + b = WVd(a); + ZD(b, 90) && (a.c = RD(b, 29)); + } + return a.c; + } + function OGb(a) { + var b, c2; + for (c2 = new Anb(a.a.b); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 60); + b.d.c = -b.d.c - b.d.b; + } + IGb(a); + } + function zYb(a) { + var b, c2; + for (c2 = new Anb(a.a.b); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 86); + b.g.c = -b.g.c - b.g.b; + } + uYb(a); + } + function Jmc(a, b, c2) { + var d, e, f2, g; + g = aMc(b, c2); + f2 = 0; + for (e = g.Kc(); e.Ob(); ) { + d = RD(e.Pb(), 12); + Zjb(a.c, d, sgb(f2++)); + } + } + function qMc(a, b, c2) { + var d; + d = new bnb(); + sMc(a, b, d, (qpd(), Xod), true, false); + sMc(a, c2, d, ppd, false, false); + return d; + } + function xjd(a) { + var b, c2, d, e, f2; + b = new pjd(); + for (d = a, e = 0, f2 = d.length; e < f2; ++e) { + c2 = d[e]; + b.a += c2.a; + b.b += c2.b; + } + return b; + } + function CEd(a, b, c2) { + var d, e, f2, g; + f2 = null; + g = b; + e = wDd(g, "labels"); + d = new fFd(a, c2); + f2 = (bEd(d.a, d.b, e), e); + return f2; + } + function Jee(a, b, c2, d) { + var e; + e = Ree(a, b, c2, d); + if (!e) { + e = Iee(a, c2, d); + if (!!e && !Eee(a, b, e)) { + return null; + } + } + return e; + } + function Mee(a, b, c2, d) { + var e; + e = See(a, b, c2, d); + if (!e) { + e = Lee(a, c2, d); + if (!!e && !Eee(a, b, e)) { + return null; + } + } + return e; + } + function Cb(a, b, c2) { + Qb(b); + if (c2.Ob()) { + Vhb(b, Fb(c2.Pb())); + while (c2.Ob()) { + Vhb(b, a.a); + Vhb(b, Fb(c2.Pb())); + } + } + return b; + } + function Xb(a, b) { + var c2; + for (c2 = 0; c2 < a.a.a.length; c2++) { + if (!RD(kob(a.a, c2), 178).Lb(b)) { + return false; + } + } + return true; + } + function fB(a) { + var b; + if (a == 0) { + return "Etc/GMT"; + } + if (a < 0) { + a = -a; + b = "Etc/GMT-"; + } else { + b = "Etc/GMT+"; + } + return b + iB(a); + } + function DA(a) { + var b; + if (a.b <= 0) { + return false; + } + b = qhb("MLydhHmsSDkK", Fhb(ihb(a.c, 0))); + return b > 1 || b >= 0 && a.b < 3; + } + function nD(a) { + var b, c2, d; + b = ~a.l + 1 & dxe; + c2 = ~a.m + (b == 0 ? 1 : 0) & dxe; + d = ~a.h + (b == 0 && c2 == 0 ? 1 : 0) & exe; + a.l = b; + a.m = c2; + a.h = d; + } + function Cob(a) { + yob(); + var b, c2, d; + d = 1; + for (c2 = a.Kc(); c2.Ob(); ) { + b = c2.Pb(); + d = 31 * d + (b != null ? tb(b) : 0); + d = d | 0; + } + return d; + } + function kD(a, b, c2, d, e) { + var f2; + f2 = BD(a, b); + c2 && nD(f2); + if (e) { + a = mD(a, b); + d ? eD = xD(a) : eD = hD(a.l, a.m, a.h); + } + return f2; + } + function Qlc(a, b, c2) { + a.g = Wlc(a, b, (qpd(), Xod), a.b); + a.d = Wlc(a, c2, Xod, a.b); + if (a.g.c == 0 || a.d.c == 0) { + return; + } + Tlc(a); + } + function Rlc(a, b, c2) { + a.g = Wlc(a, b, (qpd(), ppd), a.j); + a.d = Wlc(a, c2, ppd, a.j); + if (a.g.c == 0 || a.d.c == 0) { + return; + } + Tlc(a); + } + function Xyd(a, b) { + switch (b) { + case 7: + return !!a.e && a.e.i != 0; + case 8: + return !!a.d && a.d.i != 0; + } + return wyd(a, b); + } + function STb(a, b) { + switch (b.g) { + case 0: + ZD(a.b, 641) || (a.b = new tUb()); + break; + case 1: + ZD(a.b, 642) || (a.b = new zUb()); + } + } + function tbd(a) { + switch (a.g) { + case 0: + return new _dd(); + default: + throw Adb(new agb(eGe + (a.f != null ? a.f : "" + a.g))); + } + } + function bdd(a) { + switch (a.g) { + case 0: + return new vdd(); + default: + throw Adb(new agb(eGe + (a.f != null ? a.f : "" + a.g))); + } + } + function LCc(a, b, c2) { + return !QDb(CDb(new SDb(null, new Swb(a.c, 16)), new PAb(new gsd(b, c2)))).Bd((xDb(), wDb)); + } + function mWc(a, b) { + return cjd(jWc(RD(mQb(b, (h_c(), H$c)), 88)), new rjd(a.c.e.a - a.b.e.a, a.c.e.b - a.b.e.b)) <= 0; + } + function dve(a, b) { + while (a.g == null && !a.c ? sId(a) : a.g == null || a.i != 0 && RD(a.g[a.i - 1], 51).Ob()) { + mFd(b, tId(a)); + } + } + function sYb(a) { + var b, c2; + for (c2 = new Anb(a.a.b); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 86); + b.f.$b(); + } + NYb(a.b, a); + tYb(a); + } + function Ijd(a) { + var b, c2, d; + b = new Ejd(); + for (d = Sub(a, 0); d.b != d.d.c; ) { + c2 = RD(evb(d), 8); + hu(b, 0, new sjd(c2)); + } + return b; + } + function DDb(a) { + var b; + LCb(a); + b = new IEb(); + if (a.a.Bd(b)) { + return Kvb(), new Ovb(uFb(b.a)); + } + return Kvb(), Kvb(), Jvb; + } + function Dxd(a, b, c2) { + switch (b) { + case 0: + !a.o && (a.o = new DVd((pvd(), mvd), X4, a, 0)); + CVd(a.o, c2); + return; + } + Wvd(a, b, c2); + } + function bXc(a, b, c2) { + this.g = a; + this.e = new pjd(); + this.f = new pjd(); + this.d = new Yub(); + this.b = new Yub(); + this.a = b; + this.c = c2; + } + function V9c(a, b, c2, d) { + this.b = new bnb(); + this.n = new bnb(); + this.i = d; + this.j = c2; + this.s = a; + this.t = b; + this.r = 0; + this.d = 0; + } + function gHd(a, b) { + if (!a.Li() && b == null) { + throw Adb(new agb("The 'no null' constraint is violated")); + } + return b; + } + function ohb(a) { + var b, c2; + b = 0; + for (c2 = 0; c2 < a.length; c2++) { + b = (b << 5) - b + (BFb(c2, a.length), a.charCodeAt(c2)) | 0; + } + return b; + } + function Myb(a, b) { + var c2, d, e; + e = a.b; + while (e) { + c2 = a.a.Ne(b, e.d); + if (c2 == 0) { + return e; + } + d = c2 < 0 ? 0 : 1; + e = e.a[d]; + } + return null; + } + function LBb(a, b, c2) { + var d, e; + d = (Geb(), SSb(c2) ? true : false); + e = RD(b.xc(d), 15); + if (!e) { + e = new bnb(); + b.zc(d, e); + } + e.Fc(c2); + } + function q6c(a, b) { + var c2, d; + c2 = RD(Gxd(a, (X7c(), A7c)), 17).a; + d = RD(Gxd(b, A7c), 17).a; + return c2 == d ? -1 : c2 < d ? -1 : c2 > d ? 1 : 0; + } + function ICc(a) { + Rmb(a.c, (hed(), fed)); + if (_y(a.a, Kfb(UD(iGd((QCc(), OCc)))))) { + return new asd(); + } + return new csd(a); + } + function fs(a) { + while (!a.d || !a.d.Ob()) { + if (!!a.b && !nmb(a.b)) { + a.d = RD(smb(a.b), 51); + } else { + return null; + } + } + return a.d; + } + function BVc(a) { + switch (a.g) { + case 1: + return EEe; + default: + case 2: + return 0; + case 3: + return Gze; + case 4: + return FEe; + } + } + function fte() { + Vse(); + var a; + if (Cse) + return Cse; + a = Zse(hte("M", true)); + a = $se(hte("M", false), a); + Cse = a; + return Cse; + } + function ttd() { + ttd = geb; + qtd = new utd("ELK", 0); + rtd = new utd("JSON", 1); + ptd = new utd("DOT", 2); + std = new utd("SVG", 3); + } + function TEc() { + TEc = geb; + SEc = new UEc("STACKED", 0); + QEc = new UEc("REVERSE_STACKED", 1); + REc = new UEc("SEQUENCED", 2); + } + function LZc() { + LZc = geb; + KZc = new MZc(LAe, 0); + JZc = new MZc("MIDDLE_TO_MIDDLE", 1); + IZc = new MZc("AVOID_OVERLAP", 2); + } + function sgc() { + sgc = geb; + qgc = new Lgc(); + rgc = new Ngc(); + pgc = new Dgc(); + ogc = new Pgc(); + ngc = new Hgc(); + mgc = (uFb(ngc), new nrb()); + } + function vnd() { + vnd = geb; + tnd = new A3b(15); + snd = new mGd((umd(), tld), tnd); + und = Qld; + ond = Ekd; + pnd = kld; + rnd = nld; + qnd = mld; + } + function wgd(a, b) { + var c2, d, e, f2, g; + for (d = b, e = 0, f2 = d.length; e < f2; ++e) { + c2 = d[e]; + g = new Ggd(a); + c2.hf(g); + Bgd(g); + } + akb(a.f); + } + function xw(a, b) { + var c2; + if (b === a) { + return true; + } + if (ZD(b, 229)) { + c2 = RD(b, 229); + return pb(a.Zb(), c2.Zb()); + } + return false; + } + function Q_b(a, b) { + if (R_b(a, b)) { + Rc(a.b, RD(mQb(b, (Ywc(), ewc)), 21), b); + Mub(a.a, b); + return true; + } else { + return false; + } + } + function u6b(a) { + var b, c2; + b = RD(mQb(a, (Ywc(), Iwc)), 10); + if (b) { + c2 = b.c; + Ymb(c2.a, b); + c2.a.c.length == 0 && Ymb(Y2b(b).b, c2); + } + } + function dfc(a, b) { + if (nQb(a, (Ywc(), zwc)) && nQb(b, zwc)) { + return RD(mQb(b, zwc), 17).a - RD(mQb(a, zwc), 17).a; + } + return 0; + } + function ifc(a, b) { + if (nQb(a, (Ywc(), zwc)) && nQb(b, zwc)) { + return RD(mQb(a, zwc), 17).a - RD(mQb(b, zwc), 17).a; + } + return 0; + } + function kBb(a) { + if (dBb) { + return $C(JL, Xxe, 581, 0, 0, 1); + } + return RD(anb(a.a, $C(JL, Xxe, 581, a.a.c.length, 0, 1)), 856); + } + function yn(a, b, c2, d) { + fn(); + return new Nx(cD(WC(UK, 1), Zve, 44, 0, [(ck(a, b), new gp(a, b)), (ck(c2, d), new gp(c2, d))])); + } + function bBd(a, b, c2) { + var d, e; + e = (d = new q4d(), d); + yBd(e, b, c2); + WGd((!a.q && (a.q = new C5d(s7, a, 11, 10)), a.q), e); + return e; + } + function xAd(a) { + var b, c2, d, e; + e = meb(pAd, a); + c2 = e.length; + d = $C(qJ, Nve, 2, c2, 6, 1); + for (b = 0; b < c2; ++b) { + d[b] = e[b]; + } + return d; + } + function jwb(a, b) { + var c2; + if (b * 2 + 1 >= a.b.c.length) { + return; + } + jwb(a, 2 * b + 1); + c2 = 2 * b + 2; + c2 < a.b.c.length && jwb(a, c2); + kwb(a, b); + } + function sKc(a, b) { + var c2, d; + for (d = Sub(a, 0); d.b != d.d.c; ) { + c2 = RD(evb(d), 219); + if (c2.e.length > 0) { + b.Cd(c2); + c2.i && zKc(c2); + } + } + } + function Ejb(a, b, c2) { + var d; + for (d = c2 - 1; d >= 0 && a[d] === b[d]; d--) + ; + return d < 0 ? 0 : Ldb(Cdb(a[d], yxe), Cdb(b[d], yxe)) ? -1 : 1; + } + function it(a, b, c2) { + var d, e; + this.g = a; + this.c = b; + this.a = this; + this.d = this; + e = Wp(c2); + d = $C(UG, ewe, 227, e, 0, 1); + this.b = d; + } + function fQb(a, b, c2, d, e) { + var f2, g; + for (g = c2; g <= e; g++) { + for (f2 = b; f2 <= d; f2++) { + if (PPb(a, f2, g)) { + return true; + } + } + } + return false; + } + function Dc2(a, b) { + var c2, d; + for (d = a.Zb().Cc().Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 16); + if (c2.Hc(b)) { + return true; + } + } + return false; + } + function iu(a, b, c2) { + var d, e, f2, g; + uFb(c2); + g = false; + f2 = a.fd(b); + for (e = c2.Kc(); e.Ob(); ) { + d = e.Pb(); + f2.Rb(d); + g = true; + } + return g; + } + function NMd(a, b) { + var c2, d; + d = RD(Ywd(a.a, 4), 129); + c2 = $C(d6, IJe, 424, b, 0, 1); + d != null && hib(d, 0, c2, 0, d.length); + return c2; + } + function hSd(a, b) { + var c2; + c2 = new lSd((a.f & 256) != 0, a.i, a.a, a.d, (a.f & 16) != 0, a.j, a.g, b); + a.e != null || (c2.c = a); + return c2; + } + function Tv(a, b) { + var c2; + if (a === b) { + return true; + } else if (ZD(b, 85)) { + c2 = RD(b, 85); + return Rx(gn(a), c2.vc()); + } + return false; + } + function Vjb(a, b, c2) { + var d, e; + for (e = c2.Kc(); e.Ob(); ) { + d = RD(e.Pb(), 44); + if (a.Be(b, d.md())) { + return true; + } + } + return false; + } + function lmc(a, b, c2) { + if (!a.d[b.p][c2.p]) { + kmc(a, b, c2); + a.d[b.p][c2.p] = true; + a.d[c2.p][b.p] = true; + } + return a.a[b.p][c2.p]; + } + function vMc(a, b) { + var c2; + if (!a || a == b || !nQb(b, (Ywc(), pwc))) { + return false; + } + c2 = RD(mQb(b, (Ywc(), pwc)), 10); + return c2 != a; + } + function Bhe(a) { + switch (a.i) { + case 2: { + return true; + } + case 1: { + return false; + } + case -1: { + ++a.c; + } + default: { + return a.$l(); + } + } + } + function Che(a) { + switch (a.i) { + case -2: { + return true; + } + case -1: { + return false; + } + case 1: { + --a.c; + } + default: { + return a._l(); + } + } + } + function bgb(a) { + oz.call(this, "The given string does not match the expected format for individual spacings.", a); + } + function J6c(a, b) { + var c2; + b.Ug("Min Size Preprocessing", 1); + c2 = vsd(a); + Ixd(a, (X6c(), U6c), c2.a); + Ixd(a, R6c, c2.b); + b.Vg(); + } + function Djd(a) { + var b, c2, d; + b = 0; + d = $C(l3, Nve, 8, a.b, 0, 1); + c2 = Sub(a, 0); + while (c2.b != c2.d.c) { + d[b++] = RD(evb(c2), 8); + } + return d; + } + function Ajd(a, b, c2) { + var d, e, f2; + d = new Yub(); + for (f2 = Sub(c2, 0); f2.b != f2.d.c; ) { + e = RD(evb(f2), 8); + Mub(d, new sjd(e)); + } + iu(a, b, d); + } + function az(a, b) { + var c2; + c2 = Bdb(a, b); + if (Ldb($db(a, b), 0) | Jdb($db(a, c2), 0)) { + return c2; + } + return Bdb(Sve, $db(Udb(c2, 63), 1)); + } + function le(a, b) { + var c2, d; + c2 = RD(a.d.Bc(b), 16); + if (!c2) { + return null; + } + d = a.e.hc(); + d.Gc(c2); + a.e.d -= c2.gc(); + c2.$b(); + return d; + } + function Dyb(a) { + var b; + b = a.a.c.length; + if (b > 0) { + return lyb(b - 1, a.a.c.length), Xmb(a.a, b - 1); + } else { + throw Adb(new Srb()); + } + } + function nFb(a, b, c2) { + if (a > b) { + throw Adb(new agb(_xe + a + aye + b)); + } + if (a < 0 || b > c2) { + throw Adb(new xeb(_xe + a + bye + b + Qxe + c2)); + } + } + function yXd(a, b) { + if (a.D == null && a.B != null) { + a.D = a.B; + a.B = null; + } + JXd(a, b == null ? null : (uFb(b), b)); + !!a.C && a.hl(null); + } + function JCc(a, b) { + var c2; + c2 = iGd((QCc(), OCc)) != null && b.Sg() != null ? Kfb(UD(b.Sg())) / Kfb(UD(iGd(OCc))) : 1; + Zjb(a.b, b, c2); + } + function $Lc(a, b) { + var c2, d; + d = a.c[b]; + if (d == 0) { + return; + } + a.c[b] = 0; + a.d -= d; + c2 = b + 1; + while (c2 < a.a.length) { + a.a[c2] -= d; + c2 += c2 & -c2; + } + } + function VHd(a) { + var b; + ++a.j; + if (a.i == 0) { + a.g = null; + } else if (a.i < a.g.length) { + b = a.g; + a.g = a.aj(a.i); + hib(b, 0, a.g, 0, a.i); + } + } + function Ned(a, b, c2) { + if (b < 0) { + throw Adb(new veb(zGe + b)); + } + if (b < a.j.c.length) { + $mb(a.j, b, c2); + } else { + Led(a, b); + Rmb(a.j, c2); + } + } + function uhd(a) { + if (!a.a || (a.a.i & 8) == 0) { + throw Adb(new dgb("Enumeration class expected for layout option " + a.f)); + } + } + function y1d(a) { + var b; + b = (!a.a && (a.a = new C5d(l7, a, 9, 5)), a.a); + if (b.i != 0) { + return N1d(RD(QHd(b, 0), 694)); + } + return null; + } + function yr(a) { + var b; + Qb(a); + Mb(true, "numberToAdvance must be nonnegative"); + for (b = 0; b < 0 && gs(a); b++) { + hs(a); + } + return b; + } + function eSb() { + eSb = geb; + bSb = (VRb(), URb); + aSb = new lGd(vze, bSb); + _Rb = new jGd(wze); + cSb = new jGd(xze); + dSb = new jGd(yze); + } + function s_c() { + s_c = geb; + r_c = new t_c(MAe, 0); + p_c = new t_c(QEe, 1); + q_c = new t_c("FAN", 2); + o_c = new t_c("CONSTRAINT", 3); + } + function g4c() { + g4c = geb; + d4c = new i4c(LAe, 0); + e4c = new i4c("RADIAL_COMPACTION", 1); + f4c = new i4c("WEDGE_COMPACTION", 2); + } + function lFc() { + lFc = geb; + iFc = new mFc("CONSERVATIVE", 0); + jFc = new mFc("CONSERVATIVE_SOFT", 1); + kFc = new mFc("SLOPPY", 2); + } + function xBb() { + xBb = geb; + uBb = new yBb("CONCURRENT", 0); + vBb = new yBb("IDENTITY_FINISH", 1); + wBb = new yBb("UNORDERED", 2); + } + function NXb() { + NXb = geb; + LXb = Wx(cD(WC(s3, 1), jwe, 88, 0, [(Cmd(), ymd), zmd])); + MXb = Wx(cD(WC(s3, 1), jwe, 88, 0, [Bmd, xmd])); + } + function rb(a) { + return bE(a) ? qJ : _D(a) ? VI : $D(a) ? QI : YD(a) ? a.Rm : aD(a) ? a.Rm : a.Rm || Array.isArray(a) && WC(hI, 1) || hI; + } + function Qje(a) { + return !a ? null : (a.i & 1) != 0 ? a == xdb ? QI : a == kE ? bJ : a == jE ? ZI : a == iE ? VI : a == lE ? eJ : a == wdb ? lJ : a == gE ? RI : SI : a; + } + function CIb(a) { + if (a.c != a.b.b || a.i != a.g.b) { + aFb(a.a.c, 0); + Tmb(a.a, a.b); + Tmb(a.a, a.g); + a.c = a.b.b; + a.i = a.g.b; + } + return a.a; + } + function vmb(a, b) { + var c2, d; + c2 = a.a.length - 1; + while (b != a.b) { + d = b - 1 & c2; + bD(a.a, b, a.a[d]); + b = d; + } + bD(a.a, a.b, null); + a.b = a.b + 1 & c2; + } + function umb(a, b) { + var c2, d; + c2 = a.a.length - 1; + a.c = a.c - 1 & c2; + while (b != a.c) { + d = b + 1 & c2; + bD(a.a, b, a.a[d]); + b = d; + } + bD(a.a, a.c, null); + } + function Smb(a, b, c2) { + var d, e; + wFb(b, a.c.length); + d = c2.Pc(); + e = d.length; + if (e == 0) { + return false; + } + YEb(a.c, b, d); + return true; + } + function otb(a, b, c2) { + var d, e, f2, g; + for (e = c2, f2 = 0, g = e.length; f2 < g; ++f2) { + d = e[f2]; + if (a.b.Be(b, d.ld())) { + return d; + } + } + return null; + } + function Tnb(a) { + var b, c2, d, e, f2; + f2 = 1; + for (c2 = a, d = 0, e = c2.length; d < e; ++d) { + b = c2[d]; + f2 = 31 * f2 + (b != null ? tb(b) : 0); + f2 = f2 | 0; + } + return f2; + } + function ss(a) { + var b, c2, d, e, f2; + b = {}; + for (d = a, e = 0, f2 = d.length; e < f2; ++e) { + c2 = d[e]; + b[":" + (c2.f != null ? c2.f : "" + c2.g)] = c2; + } + return b; + } + function tSd(a) { + var b, c2; + if (a == null) + return null; + for (b = 0, c2 = a.length; b < c2; b++) { + if (!GSd(a[b])) + return a[b]; + } + return null; + } + function gKb(a, b) { + if (!a) { + return 0; + } + if (b && !a.j) { + return 0; + } + if (ZD(a, 127)) { + if (RD(a, 127).a.b == 0) { + return 0; + } + } + return a.jf(); + } + function hKb(a, b) { + if (!a) { + return 0; + } + if (b && !a.k) { + return 0; + } + if (ZD(a, 127)) { + if (RD(a, 127).a.a == 0) { + return 0; + } + } + return a.kf(); + } + function orc(a, b) { + if (nQb(a, (Ywc(), zwc)) && nQb(b, zwc)) { + return hgb(RD(mQb(a, zwc), 17).a, RD(mQb(b, zwc), 17).a); + } + return 0; + } + function EHc(a) { + var b, c2, d; + d = 0; + for (c2 = new is(Mr(a.a.Kc(), new ir())); gs(c2); ) { + b = RD(hs(c2), 18); + b.c.i == b.d.i || ++d; + } + return d; + } + function Gad(a, b) { + var c2, d, e; + e = b - a.f; + for (d = new Anb(a.d); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 315); + fad(c2, c2.e, c2.f + e); + } + a.f = b; + } + function YVd(a, b) { + var c2, d, e; + d = a.Yk(b, null); + e = null; + if (b) { + e = (jTd(), c2 = new s2d(), c2); + l2d(e, a.r); + } + d = XVd(a, e, d); + !!d && d.oj(); + } + function P0b(a, b) { + var c2, d, e; + c2 = a; + e = 0; + do { + if (c2 == b) { + return e; + } + d = c2.e; + if (!d) { + throw Adb(new _fb()); + } + c2 = Y2b(d); + ++e; + } while (true); + } + function uRb(a) { + var b, c2, d, e; + d = a.b.a; + for (c2 = d.a.ec().Kc(); c2.Ob(); ) { + b = RD(c2.Pb(), 567); + e = new DSb(b, a.e, a.f); + Rmb(a.g, e); + } + } + function DZb(a) { + var b; + b = new XZb(a); + t$b(a.a, BZb, new mob(cD(WC(wQ, 1), rve, 382, 0, [b]))); + !!b.d && Rmb(b.f, b.d); + return b.f; + } + function M2b(a, b) { + var c2; + for (c2 = 0; c2 < b.length; c2++) { + if (a == (BFb(c2, b.length), b.charCodeAt(c2))) { + return true; + } + } + return false; + } + function BSd(a, b) { + return b < a.length && (BFb(b, a.length), a.charCodeAt(b) != 63) && (BFb(b, a.length), a.charCodeAt(b) != 35); + } + function trc(a, b, c2, d) { + nrc(this); + this.c = $C(jR, WAe, 10, a.a.c.length, 0, 1); + this.e = b; + anb(a.a, this.c); + this.f = c2; + this.b = d; + } + function Cz(a) { + Az(); + ez(this); + gz(this); + this.e = a; + hz(this, a); + this.g = a == null ? vve : jeb(a); + this.a = ""; + this.b = a; + this.a = ""; + } + function Pad() { + this.a = new Qad(); + this.f = new Sad(this); + this.b = new Uad(this); + this.i = new Wad(this); + this.e = new Yad(this); + } + function Ks() { + Js.call(this, new hub(Sv(16))); + dk(2, Mve); + this.b = 2; + this.a = new ct(null, null, 0, null); + Ss(this.a, this.a); + } + function NC(a) { + HC(); + throw Adb(new aC("Unexpected typeof result '" + a + "'; please report this bug to the GWT team")); + } + function AVc(a, b, c2) { + if ($wnd.Math.abs(b - a) < DEe || $wnd.Math.abs(c2 - a) < DEe) { + return true; + } + return b - a > DEe ? a - c2 > DEe : c2 - a > DEe; + } + function vjd(a, b) { + var c2; + for (c2 = 0; c2 < b.length; c2++) { + if (a == (BFb(c2, b.length), b.charCodeAt(c2))) { + return true; + } + } + return false; + } + function HSd(a) { + var b, c2; + if (a == null) + return false; + for (b = 0, c2 = a.length; b < c2; b++) { + if (!GSd(a[b])) + return false; + } + return true; + } + function M8c(a, b) { + var c2, d, e; + d = false; + c2 = b.q.d; + if (b.d < a.b) { + e = dad(b.q, a.b); + if (b.q.d > e) { + ead(b.q, e); + d = c2 != b.q.d; + } + } + return d; + } + function C3c(a, b) { + var c2, d, e, f2, g, h, i2, j; + i2 = b.i; + j = b.j; + d = a.f; + e = d.i; + f2 = d.j; + g = i2 - e; + h = j - f2; + c2 = $wnd.Math.sqrt(g * g + h * h); + return c2; + } + function pBd(a, b) { + var c2, d; + d = Hvd(a); + if (!d) { + c2 = (gSd(), nSd(b)); + d = new Sde(c2); + WGd(d.El(), a); + } + return d; + } + function Sc2(a, b) { + var c2, d; + c2 = RD(a.c.Bc(b), 16); + if (!c2) { + return a.jc(); + } + d = a.hc(); + d.Gc(c2); + a.d -= c2.gc(); + c2.$b(); + return a.mc(d); + } + function tKc(a, b) { + var c2, d; + d = Kwb(a.d, 1) != 0; + c2 = true; + while (c2) { + c2 = false; + c2 = b.c.mg(b.e, d); + c2 = c2 | DKc(a, b, d, false); + d = !d; + } + yKc(a); + } + function omc(a, b, c2, d) { + var e, f2; + a.a = b; + f2 = d ? 0 : 1; + a.f = (e = new mmc(a.c, a.a, c2, f2), new Pmc(c2, a.a, e, a.e, a.b, a.c == (RKc(), PKc))); + } + function Imb(a) { + var b; + sFb(a.a != a.b); + b = a.d.a[a.a]; + zmb(a.b == a.d.c && b != null); + a.c = a.a; + a.a = a.a + 1 & a.d.a.length - 1; + return b; + } + function Vib(a) { + var b; + if (a.c != 0) { + return a.c; + } + for (b = 0; b < a.a.length; b++) { + a.c = a.c * 33 + (a.a[b] & -1); + } + a.c = a.c * a.e; + return a.c; + } + function Oue(a) { + var b; + if (!(a.c.c < 0 ? a.a >= a.c.b : a.a <= a.c.b)) { + throw Adb(new Dvb()); + } + b = a.a; + a.a += a.c.c; + ++a.b; + return sgb(b); + } + function h5b(a) { + var b; + b = new y2b(a.a); + kQb(b, a); + pQb(b, (Ywc(), Awc), a); + b.o.a = a.g; + b.o.b = a.f; + b.n.a = a.i; + b.n.b = a.j; + return b; + } + function tVc(a) { + return (qpd(), hpd).Hc(a.j) ? Kfb(UD(mQb(a, (Ywc(), Swc)))) : xjd(cD(WC(l3, 1), Nve, 8, 0, [a.i.n, a.n, a.a])).b; + } + function ZJc(a) { + var b; + b = vfd(XJc); + RD(mQb(a, (Ywc(), kwc)), 21).Hc((ovc(), kvc)) && pfd(b, (sXb(), pXb), (hcc(), Ybc)); + return b; + } + function M2c(a) { + var b, c2, d, e; + e = new _sb(); + for (d = new Anb(a); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 27); + b = P2c(c2); + ye(e, b); + } + return e; + } + function hIc(a) { + var b, c2; + for (c2 = new Anb(a.r); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 10); + if (a.n[b.p] <= 0) { + return b; + } + } + return null; + } + function LGb(a, b, c2) { + var d, e; + for (e = b.a.a.ec().Kc(); e.Ob(); ) { + d = RD(e.Pb(), 60); + if (MGb(a, d, c2)) { + return true; + } + } + return false; + } + function Rcc(a, b, c2, d) { + var e, f2; + for (f2 = a.Kc(); f2.Ob(); ) { + e = RD(f2.Pb(), 72); + e.n.a = b.a + (d.a - e.o.a) / 2; + e.n.b = b.b; + b.b += e.o.b + c2; + } + } + function hNb(a, b, c2) { + var d; + d = new rMb(a, b); + Rc(a.r, b.ag(), d); + if (c2 && !Rod(a.u)) { + d.c = new TKb(a.d); + Umb(b.Rf(), new kNb(d)); + } + } + function Ddb(a, b) { + var c2; + if (Kdb(a) && Kdb(b)) { + c2 = a - b; + if (!isNaN(c2)) { + return c2; + } + } + return uD(Kdb(a) ? Wdb(a) : a, Kdb(b) ? Wdb(b) : b); + } + function Iid(a, b) { + var c2, d, e; + e = 1; + c2 = a; + d = b >= 0 ? b : -b; + while (d > 0) { + if (d % 2 == 0) { + c2 *= c2; + d = d / 2 | 0; + } else { + e *= c2; + d -= 1; + } + } + return b < 0 ? 1 / e : e; + } + function Jid(a, b) { + var c2, d, e; + e = 1; + c2 = a; + d = b >= 0 ? b : -b; + while (d > 0) { + if (d % 2 == 0) { + c2 *= c2; + d = d / 2 | 0; + } else { + e *= c2; + d -= 1; + } + } + return b < 0 ? 1 / e : e; + } + function Vvd(a, b) { + var c2, d, e, f2; + f2 = (e = a ? Hvd(a) : null, Pje((d = b, e ? e.Gl() : null, d))); + if (f2 == b) { + c2 = Hvd(a); + !!c2 && c2.Gl(); + } + return f2; + } + function g2d(a, b, c2) { + var d, e; + e = a.f; + a.f = b; + if ((a.Db & 4) != 0 && (a.Db & 1) == 0) { + d = new N3d(a, 1, 0, e, b); + !c2 ? c2 = d : c2.nj(d); + } + return c2; + } + function e2d(a, b, c2) { + var d, e; + e = a.b; + a.b = b; + if ((a.Db & 4) != 0 && (a.Db & 1) == 0) { + d = new N3d(a, 1, 3, e, b); + !c2 ? c2 = d : c2.nj(d); + } + return c2; + } + function rAd(a, b, c2) { + var d, e; + e = a.a; + a.a = b; + if ((a.Db & 4) != 0 && (a.Db & 1) == 0) { + d = new N3d(a, 1, 1, e, b); + !c2 ? c2 = d : c2.nj(d); + } + return c2; + } + function SNd(a) { + var b, c2; + if (a != null) { + for (c2 = 0; c2 < a.length; ++c2) { + b = a[c2]; + if (b) { + RD(b.g, 379); + b.i; + } + } + } + } + function Vnb(a, b, c2, d, e, f2, g, h) { + var i2; + i2 = c2; + while (f2 < g) { + i2 >= d || b < c2 && h.Ne(a[b], a[i2]) <= 0 ? bD(e, f2++, a[b++]) : bD(e, f2++, a[i2++]); + } + } + function Njb(a, b, c2, d, e) { + if (b == 0 || d == 0) { + return; + } + b == 1 ? e[d] = Pjb(e, c2, d, a[0]) : d == 1 ? e[b] = Pjb(e, a, b, c2[0]) : Ojb(a, c2, e, b, d); + } + function w9c(a, b, c2) { + var d, e, f2, g; + d = c2 / a.gc(); + e = 0; + for (g = a.Kc(); g.Ob(); ) { + f2 = RD(g.Pb(), 186); + Gad(f2, f2.f + d * e); + Dad(f2, b, d); + ++e; + } + } + function cad(a) { + var b, c2, d; + d = 0; + for (c2 = new Anb(a.a); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 172); + d = $wnd.Math.max(d, b.g); + } + return d; + } + function EKc(a) { + var b, c2, d; + for (d = new Anb(a.b); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 219); + b = c2.c.kg() ? c2.f : c2.a; + !!b && MLc(b, c2.j); + } + } + function lDc() { + lDc = geb; + iDc = new nDc("DUMMY_NODE_OVER", 0); + jDc = new nDc("DUMMY_NODE_UNDER", 1); + kDc = new nDc("EQUAL", 2); + } + function mqd() { + mqd = geb; + kqd = new nqd("PARALLEL_NODE", 0); + jqd = new nqd("HIERARCHICAL_NODE", 1); + lqd = new nqd("ROOT_NODE", 2); + } + function Fnd() { + Fnd = geb; + Dnd = new Gnd("INHERIT", 0); + Cnd = new Gnd("INCLUDE_CHILDREN", 1); + End = new Gnd("SEPARATE_CHILDREN", 2); + } + function hyd(a, b) { + switch (b) { + case 1: + !a.n && (a.n = new C5d(I4, a, 1, 7)); + sLd(a.n); + return; + case 2: + jyd(a, null); + return; + } + Exd(a, b); + } + function c9c(a) { + switch (a.g) { + case 0: + return new R8c(); + case 1: + return new o9c(); + case 2: + return new X8c(); + default: + return null; + } + } + function eq2(a) { + _l(); + switch (a.c) { + case 0: + return Px(), Ox; + case 1: + return new Fy(Ir(new Osb(a))); + default: + return new dq(a); + } + } + function go(a) { + _l(); + switch (a.gc()) { + case 0: + return Px(), Ox; + case 1: + return new Fy(a.Kc().Pb()); + default: + return new Qx(a); + } + } + function Pm(a) { + var b; + switch (a.gc()) { + case 0: + return sm; + case 1: + return new Dy(Qb(a.Xb(0))); + default: + b = a; + return new Kx(b); + } + } + function sgb(a) { + var b, c2; + if (a > -129 && a < 128) { + return ugb(), b = a + 128, c2 = tgb[b], !c2 && (c2 = tgb[b] = new fgb(a)), c2; + } + return new fgb(a); + } + function bhb(a) { + var b, c2; + if (a > -129 && a < 128) { + return dhb(), b = a + 128, c2 = chb[b], !c2 && (c2 = chb[b] = new Xgb(a)), c2; + } + return new Xgb(a); + } + function M$b(a, b) { + var c2; + if (a.a.c.length > 0) { + c2 = RD(Vmb(a.a, a.a.c.length - 1), 579); + if (Q_b(c2, b)) { + return; + } + } + Rmb(a.a, new S_b(b)); + } + function Ekc(a) { + lkc(); + var b, c2; + b = a.d.c - a.e.c; + c2 = RD(a.g, 154); + Umb(c2.b, new Ykc(b)); + Umb(c2.c, new $kc(b)); + xgb(c2.i, new alc(b)); + } + function Mlc(a) { + var b; + b = new bib(); + b.a += "VerticalSegment "; + Yhb(b, a.e); + b.a += " "; + Zhb(b, Eb(new Gb(), new Anb(a.k))); + return b.a; + } + function Fmc(a, b) { + var c2, d, e; + c2 = 0; + for (e = b3b(a, b).Kc(); e.Ob(); ) { + d = RD(e.Pb(), 12); + c2 += mQb(d, (Ywc(), Iwc)) != null ? 1 : 0; + } + return c2; + } + function VTc(a, b, c2) { + var d, e, f2; + d = 0; + for (f2 = Sub(a, 0); f2.b != f2.d.c; ) { + e = Kfb(UD(evb(f2))); + if (e > c2) { + break; + } else + e >= b && ++d; + } + return d; + } + function Wv(b, c2) { + Qb(b); + try { + return b._b(c2); + } catch (a) { + a = zdb(a); + if (ZD(a, 212) || ZD(a, 169)) { + return false; + } else + throw Adb(a); + } + } + function Nk(b, c2) { + Qb(b); + try { + return b.Hc(c2); + } catch (a) { + a = zdb(a); + if (ZD(a, 212) || ZD(a, 169)) { + return false; + } else + throw Adb(a); + } + } + function Ok(b, c2) { + Qb(b); + try { + return b.Mc(c2); + } catch (a) { + a = zdb(a); + if (ZD(a, 212) || ZD(a, 169)) { + return false; + } else + throw Adb(a); + } + } + function Xv(b, c2) { + Qb(b); + try { + return b.xc(c2); + } catch (a) { + a = zdb(a); + if (ZD(a, 212) || ZD(a, 169)) { + return null; + } else + throw Adb(a); + } + } + function Yv(b, c2) { + Qb(b); + try { + return b.Bc(c2); + } catch (a) { + a = zdb(a); + if (ZD(a, 212) || ZD(a, 169)) { + return null; + } else + throw Adb(a); + } + } + function aMc(a, b) { + switch (b.g) { + case 2: + case 1: + return b3b(a, b); + case 3: + case 4: + return hv(b3b(a, b)); + } + return yob(), yob(), vob; + } + function QAd(a) { + var b; + if ((a.Db & 64) != 0) + return awd(a); + b = new Shb(awd(a)); + b.a += " (name: "; + Nhb(b, a.zb); + b.a += ")"; + return b.a; + } + function Fgd(a) { + var b; + b = RD(cub(a.c.c, ""), 233); + if (!b) { + b = new fgd(ogd(ngd(new pgd(), ""), "Other")); + dub(a.c.c, "", b); + } + return b; + } + function hBd(a, b, c2) { + var d, e; + e = a.sb; + a.sb = b; + if ((a.Db & 4) != 0 && (a.Db & 1) == 0) { + d = new N3d(a, 1, 4, e, b); + !c2 ? c2 = d : c2.nj(d); + } + return c2; + } + function ZVd(a, b, c2) { + var d, e; + e = a.r; + a.r = b; + if ((a.Db & 4) != 0 && (a.Db & 1) == 0) { + d = new N3d(a, 1, 8, e, a.r); + !c2 ? c2 = d : c2.nj(d); + } + return c2; + } + function q5d(a, b, c2) { + var d, e; + d = new P3d(a.e, 4, 13, (e = b.c, e ? e : (JTd(), wTd)), null, fZd(a, b), false); + !c2 ? c2 = d : c2.nj(d); + return c2; + } + function p5d(a, b, c2) { + var d, e; + d = new P3d(a.e, 3, 13, null, (e = b.c, e ? e : (JTd(), wTd)), fZd(a, b), false); + !c2 ? c2 = d : c2.nj(d); + return c2; + } + function Oee(a, b) { + var c2, d; + c2 = RD(b, 691); + d = c2.el(); + !d && c2.fl(d = ZD(b, 90) ? new afe(a, RD(b, 29)) : new mfe(a, RD(b, 156))); + return d; + } + function KHd(a, b, c2) { + var d; + a._i(a.i + 1); + d = a.Zi(b, c2); + b != a.i && hib(a.g, b, a.g, b + 1, a.i - b); + bD(a.g, b, d); + ++a.i; + a.Mi(b, c2); + a.Ni(); + } + function Hyb(a, b) { + var c2; + if (b.a) { + c2 = b.a.a.length; + !a.a ? a.a = new dib(a.d) : Zhb(a.a, a.b); + Xhb(a.a, b.a, b.d.length, c2); + } + return a; + } + function wib(a, b) { + var c2; + a.c = b; + a.a = pjb(b); + a.a < 54 && (a.f = (c2 = b.d > 1 ? DFb(b.a[0], b.a[1]) : DFb(b.a[0], 0), Xdb(b.e > 0 ? c2 : Odb(c2)))); + } + function MDb(a, b) { + var c2; + c2 = new IEb(); + if (!a.a.Bd(c2)) { + LCb(a); + return Kvb(), Kvb(), Jvb; + } + return Kvb(), new Ovb(uFb(LDb(a, c2.a, b))); + } + function t9b(a, b) { + var c2; + if (a.c.length == 0) { + return; + } + c2 = RD(anb(a, $C(jR, WAe, 10, a.c.length, 0, 1)), 199); + Znb(c2, new F9b()); + q9b(c2, b); + } + function z9b(a, b) { + var c2; + if (a.c.length == 0) { + return; + } + c2 = RD(anb(a, $C(jR, WAe, 10, a.c.length, 0, 1)), 199); + Znb(c2, new K9b()); + q9b(c2, b); + } + function pb(a, b) { + return bE(a) ? lhb(a, b) : _D(a) ? Lfb(a, b) : $D(a) ? (uFb(a), dE(a) === dE(b)) : YD(a) ? a.Fb(b) : aD(a) ? mb(a, b) : Hz(a, b); + } + function Cvd(a, b, c2) { + if (b < 0) { + Tvd(a, c2); + } else { + if (!c2.rk()) { + throw Adb(new agb(KHe + c2.xe() + LHe)); + } + RD(c2, 69).wk().Ek(a, a.hi(), b); + } + } + function xFb(a, b, c2) { + if (a < 0 || b > c2) { + throw Adb(new veb(_xe + a + bye + b + ", size: " + c2)); + } + if (a > b) { + throw Adb(new agb(_xe + a + aye + b)); + } + } + function oVd(a) { + var b; + if ((a.Db & 64) != 0) + return awd(a); + b = new Shb(awd(a)); + b.a += " (source: "; + Nhb(b, a.d); + b.a += ")"; + return b.a; + } + function JSd(a) { + if (a >= 65 && a <= 70) { + return a - 65 + 10; + } + if (a >= 97 && a <= 102) { + return a - 97 + 10; + } + if (a >= 48 && a <= 57) { + return a - 48; + } + return 0; + } + function lMb(a) { + hMb(); + var b, c2, d, e; + for (c2 = nMb(), d = 0, e = c2.length; d < e; ++d) { + b = c2[d]; + if (Wmb(b.a, a, 0) != -1) { + return b; + } + } + return gMb; + } + function zde(a, b) { + var c2, d, e, f2; + b.ej(a.a); + f2 = RD(Ywd(a.a, 8), 2035); + if (f2 != null) { + for (c2 = f2, d = 0, e = c2.length; d < e; ++d) { + null.Um(); + } + } + } + function _Vd(a, b) { + var c2; + c2 = (a.Bb & 256) != 0; + b ? a.Bb |= 256 : a.Bb &= -257; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new Q3d(a, 1, 2, c2, b)); + } + function EYd(a, b) { + var c2; + c2 = (a.Bb & 256) != 0; + b ? a.Bb |= 256 : a.Bb &= -257; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new Q3d(a, 1, 8, c2, b)); + } + function j1d(a, b) { + var c2; + c2 = (a.Bb & 256) != 0; + b ? a.Bb |= 256 : a.Bb &= -257; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new Q3d(a, 1, 8, c2, b)); + } + function aWd(a, b) { + var c2; + c2 = (a.Bb & 512) != 0; + b ? a.Bb |= 512 : a.Bb &= -513; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new Q3d(a, 1, 3, c2, b)); + } + function FYd(a, b) { + var c2; + c2 = (a.Bb & 512) != 0; + b ? a.Bb |= 512 : a.Bb &= -513; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new Q3d(a, 1, 9, c2, b)); + } + function m2d(a, b, c2) { + var d, e; + e = a.a; + a.a = b; + if ((a.Db & 4) != 0 && (a.Db & 1) == 0) { + d = new N3d(a, 1, 5, e, a.a); + !c2 ? c2 = d : oKd(c2, d); + } + return c2; + } + function kle(a, b) { + var c2; + if (a.b == -1 && !!a.a) { + c2 = a.a.pk(); + a.b = !c2 ? BYd(a.c.Dh(), a.a) : a.c.Hh(a.a.Lj(), c2); + } + return a.c.yh(a.b, b); + } + function t0d(a, b) { + var c2, d; + for (d = new dMd(a); d.e != d.i.gc(); ) { + c2 = RD(bMd(d), 29); + if (dE(b) === dE(c2)) { + return true; + } + } + return false; + } + function a9b(a) { + var b, c2; + b = a.k; + if (b == (r3b(), m3b)) { + c2 = RD(mQb(a, (Ywc(), hwc)), 64); + return c2 == (qpd(), Yod) || c2 == npd; + } + return false; + } + function QCb(a) { + var b; + b = RCb(a); + if (Gdb(b.a, 0)) { + return Tvb(), Tvb(), Svb; + } + return Tvb(), new Yvb(Idb(b.a, 0) ? Orb(b) / Xdb(b.a) : 0); + } + function Aib(a, b) { + this.e = b; + this.a = Dib(a); + this.a < 54 ? this.f = Xdb(a) : this.c = (Pib(), Ddb(a, 0) >= 0 ? jjb(a) : Xib(jjb(Odb(a)))); + } + function G0b(a, b, c2, d, e, f2) { + this.e = new bnb(); + this.f = (BEc(), AEc); + Rmb(this.e, a); + this.d = b; + this.a = c2; + this.b = d; + this.f = e; + this.c = f2; + } + function bQb(a, b, c2) { + a.n = YC(lE, [Nve, rxe], [376, 28], 14, [c2, eE($wnd.Math.ceil(b / 32))], 2); + a.o = b; + a.p = c2; + a.j = b - 1 >> 1; + a.k = c2 - 1 >> 1; + } + function ggb(a) { + a -= a >> 1 & 1431655765; + a = (a >> 2 & 858993459) + (a & 858993459); + a = (a >> 4) + a & 252645135; + a += a >> 8; + a += a >> 16; + return a & 63; + } + function C4d(a, b) { + var c2, d; + for (d = new dMd(a); d.e != d.i.gc(); ) { + c2 = RD(bMd(d), 142); + if (dE(b) === dE(c2)) { + return true; + } + } + return false; + } + function Iee(a, b, c2) { + var d, e, f2; + f2 = (e = N5d(a.b, b), e); + if (f2) { + d = RD(tfe(Pee(a, f2), ""), 29); + if (d) { + return Ree(a, d, b, c2); + } + } + return null; + } + function Lee(a, b, c2) { + var d, e, f2; + f2 = (e = N5d(a.b, b), e); + if (f2) { + d = RD(tfe(Pee(a, f2), ""), 29); + if (d) { + return See(a, d, b, c2); + } + } + return null; + } + function IDd(a, b) { + var c2; + c2 = Ao(a.i, b); + if (c2 == null) { + throw Adb(new CDd("Node did not exist in input.")); + } + wEd(b, c2); + return null; + } + function wvd(a, b) { + var c2; + c2 = wYd(a, b); + if (ZD(c2, 331)) { + return RD(c2, 35); + } + throw Adb(new agb(KHe + b + "' is not a valid attribute")); + } + function VGd(a, b, c2) { + var d; + d = a.gc(); + if (b > d) + throw Adb(new aMd(b, d)); + if (a.Si() && a.Hc(c2)) { + throw Adb(new agb(LIe)); + } + a.Gi(b, c2); + } + function w7b(a, b) { + b.Ug("Sort end labels", 1); + FDb(CDb(EDb(new SDb(null, new Swb(a.b, 16)), new H7b()), new J7b()), new L7b()); + b.Vg(); + } + function Cmd() { + Cmd = geb; + Amd = new Gmd(Sye, 0); + zmd = new Gmd(Oye, 1); + ymd = new Gmd(Nye, 2); + xmd = new Gmd(Zye, 3); + Bmd = new Gmd("UP", 4); + } + function gbd() { + gbd = geb; + dbd = new hbd("P1_STRUCTURE", 0); + ebd = new hbd("P2_PROCESSING_ORDER", 1); + fbd = new hbd("P3_EXECUTION", 2); + } + function r0c() { + r0c = geb; + q0c = mfd(mfd(rfd(mfd(mfd(rfd(pfd(new ufd(), (YVc(), VVc), (WYc(), VYc)), WVc), RYc), TYc), XVc), NYc), UYc); + } + function s8b(a) { + switch (RD(mQb(a, (Ywc(), owc)), 311).g) { + case 1: + pQb(a, owc, (Gvc(), Dvc)); + break; + case 2: + pQb(a, owc, (Gvc(), Fvc)); + } + } + function bUc(a) { + switch (a) { + case 0: + return new mUc(); + case 1: + return new cUc(); + case 2: + return new hUc(); + default: + throw Adb(new _fb()); + } + } + function Fmd(a) { + switch (a.g) { + case 2: + return zmd; + case 1: + return ymd; + case 4: + return xmd; + case 3: + return Bmd; + default: + return Amd; + } + } + function UNb(a, b) { + switch (a.b.g) { + case 0: + case 1: + return b; + case 2: + case 3: + return new Uid2(b.d, 0, b.a, b.b); + default: + return null; + } + } + function rpd(a) { + switch (a.g) { + case 1: + return ppd; + case 2: + return Yod; + case 3: + return Xod; + case 4: + return npd; + default: + return opd; + } + } + function spd(a) { + switch (a.g) { + case 1: + return npd; + case 2: + return ppd; + case 3: + return Yod; + case 4: + return Xod; + default: + return opd; + } + } + function tpd(a) { + switch (a.g) { + case 1: + return Xod; + case 2: + return npd; + case 3: + return ppd; + case 4: + return Yod; + default: + return opd; + } + } + function cyd(a, b, c2, d) { + switch (b) { + case 1: + return !a.n && (a.n = new C5d(I4, a, 1, 7)), a.n; + case 2: + return a.k; + } + return Axd(a, b, c2, d); + } + function uLd(a, b, c2) { + var d, e; + if (a.Pj()) { + e = a.Qj(); + d = SHd(a, b, c2); + a.Jj(a.Ij(7, sgb(c2), d, b, e)); + return d; + } else { + return SHd(a, b, c2); + } + } + function VNd(a, b) { + var c2, d, e; + if (a.d == null) { + ++a.e; + --a.f; + } else { + e = b.ld(); + c2 = b.Bi(); + d = (c2 & lve) % a.d.length; + iOd(a, d, XNd(a, d, c2, e)); + } + } + function xWd(a, b) { + var c2; + c2 = (a.Bb & gwe) != 0; + b ? a.Bb |= gwe : a.Bb &= -1025; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new Q3d(a, 1, 10, c2, b)); + } + function DWd(a, b) { + var c2; + c2 = (a.Bb & qxe) != 0; + b ? a.Bb |= qxe : a.Bb &= -4097; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new Q3d(a, 1, 12, c2, b)); + } + function EWd(a, b) { + var c2; + c2 = (a.Bb & bKe) != 0; + b ? a.Bb |= bKe : a.Bb &= -8193; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new Q3d(a, 1, 15, c2, b)); + } + function FWd(a, b) { + var c2; + c2 = (a.Bb & cKe) != 0; + b ? a.Bb |= cKe : a.Bb &= -2049; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new Q3d(a, 1, 11, c2, b)); + } + function zKc(a) { + var b; + if (a.g) { + b = a.c.kg() ? a.f : a.a; + BKc(b.a, a.o, true); + BKc(b.a, a.o, false); + pQb(a.o, (yCc(), BBc), (Bod(), vod)); + } + } + function Orc(a) { + var b; + if (!a.a) { + throw Adb(new dgb("Cannot offset an unassigned cut.")); + } + b = a.c - a.b; + a.b += b; + Qrc(a, b); + Rrc(a, b); + } + function JDd(a, b) { + var c2; + c2 = Wjb(a.k, b); + if (c2 == null) { + throw Adb(new CDd("Port did not exist in input.")); + } + wEd(b, c2); + return null; + } + function Jje(a) { + var b, c2; + for (c2 = Kje(BXd(a)).Kc(); c2.Ob(); ) { + b = WD(c2.Pb()); + if (bAd(a, b)) { + return USd((TSd(), SSd), b); + } + } + return null; + } + function qJb(a) { + var b, c2; + for (c2 = a.p.a.ec().Kc(); c2.Ob(); ) { + b = RD(c2.Pb(), 218); + if (b.f && a.b[b.c] < -1e-10) { + return b; + } + } + return null; + } + function Lr(a) { + var b, c2; + c2 = Thb(new bib(), 91); + b = true; + while (a.Ob()) { + b || (c2.a += pve, c2); + b = false; + Yhb(c2, a.Pb()); + } + return (c2.a += "]", c2).a; + } + function o_b(a) { + var b, c2, d; + b = new bnb(); + for (d = new Anb(a.b); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 602); + Tmb(b, RD(c2.Cf(), 16)); + } + return b; + } + function TXb(a, b) { + var c2, d; + for (d = new Anb(b); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 42); + Ymb(a.b.b, c2.b); + hYb(RD(c2.a, 194), RD(c2.b, 86)); + } + } + function aRb(a, b) { + var c2; + c2 = Qfb(a.b.c, b.b.c); + if (c2 != 0) { + return c2; + } + c2 = Qfb(a.a.a, b.a.a); + if (c2 != 0) { + return c2; + } + return Qfb(a.a.b, b.a.b); + } + function Qfb(a, b) { + if (a < b) { + return -1; + } + if (a > b) { + return 1; + } + if (a == b) { + return a == 0 ? Qfb(1 / a, 1 / b) : 0; + } + return isNaN(a) ? isNaN(b) ? 0 : 1 : -1; + } + function pmb(a) { + var b; + b = a.a[a.c - 1 & a.a.length - 1]; + if (b == null) { + return null; + } + a.c = a.c - 1 & a.a.length - 1; + bD(a.a, a.c, null); + return b; + } + function Dqe(a) { + var b, c2, d; + d = 0; + c2 = a.length; + for (b = 0; b < c2; b++) { + a[b] == 32 || a[b] == 13 || a[b] == 10 || a[b] == 9 || (a[d++] = a[b]); + } + return d; + } + function Nge(a, b) { + var c2, d, e, f2, g; + g = pke(a.e.Dh(), b); + f2 = 0; + c2 = RD(a.g, 124); + for (e = 0; e < a.i; ++e) { + d = c2[e]; + g.am(d.Lk()) && ++f2; + } + return f2; + } + function tge(a, b, c2) { + var d, e; + e = ZD(b, 102) && (RD(b, 19).Bb & txe) != 0 ? new She(b, a) : new Phe(b, a); + for (d = 0; d < c2; ++d) { + Dhe(e); + } + return e; + } + function yrd(a, b, c2) { + var d, e; + if (a.c) { + Isd(a.c, b, c2); + } else { + for (e = new Anb(a.b); e.a < e.c.c.length; ) { + d = RD(ynb(e), 163); + yrd(d, b, c2); + } + } + } + function tGd(a, b, c2) { + var d, e; + d = RD(b.of(a.a), 34); + e = RD(c2.of(a.a), 34); + return d != null && e != null ? Leb(d, e) : d != null ? -1 : e != null ? 1 : 0; + } + function Ce(a, b) { + var c2, d, e; + uFb(b); + c2 = false; + for (d = new Anb(a); d.a < d.c.c.length; ) { + e = ynb(d); + if (b.Hc(e)) { + znb(d); + c2 = true; + } + } + return c2; + } + function xsb(a) { + var b, c2, d, e; + c2 = (b = RD(mfb((d = a.Rm, e = d.f, e == WI ? d : e)), 9), new Fsb(b, RD(WEb(b, b.length), 9), 0)); + zsb(c2, a); + return c2; + } + function i2b(a) { + var b, c2; + c2 = RD(mQb(a, (yCc(), rAc)), 88); + if (c2 == (Cmd(), Amd)) { + b = Kfb(UD(mQb(a, Tzc))); + return b >= 1 ? zmd : xmd; + } + return c2; + } + function Xhc(a) { + switch (RD(mQb(a, (yCc(), yAc)), 223).g) { + case 1: + return new jqc(); + case 3: + return new arc(); + default: + return new dqc(); + } + } + function MCb(a) { + if (a.c) { + MCb(a.c); + } else if (a.d) { + throw Adb(new dgb("Stream already terminated, can't be modified or used")); + } + } + function Ltb(a, b, c2) { + var d; + d = a.a.get(b); + a.a.set(b, c2 === void 0 ? null : c2); + if (d === void 0) { + ++a.c; + ++a.b.g; + } else { + ++a.d; + } + return d; + } + function HHc(a, b, c2) { + var d, e; + for (e = a.a.ec().Kc(); e.Ob(); ) { + d = RD(e.Pb(), 10); + if (Be(c2, RD(Vmb(b, d.p), 16))) { + return d; + } + } + return null; + } + function u0c(a, b, c2) { + var d; + d = 0; + !!b && (Emd(a.a) ? d += b.f.a / 2 : d += b.f.b / 2); + !!c2 && (Emd(a.a) ? d += c2.f.a / 2 : d += c2.f.b / 2); + return d; + } + function LWb(a, b, c2) { + var d; + d = c2; + !d && (d = Nqd(new Oqd(), 0)); + d.Ug(EAe, 2); + y0b(a.b, b, d.eh(1)); + NWb(a, b, d.eh(1)); + h0b(b, d.eh(1)); + d.Vg(); + } + function CGd(a, b, c2) { + var d, e; + d = (bvd(), e = new Xxd(), e); + Vxd(d, b); + Wxd(d, c2); + !!a && WGd((!a.a && (a.a = new XZd(D4, a, 5)), a.a), d); + return d; + } + function kyd(a) { + var b; + if ((a.Db & 64) != 0) + return awd(a); + b = new Shb(awd(a)); + b.a += " (identifier: "; + Nhb(b, a.k); + b.a += ")"; + return b.a; + } + function kXd(a, b) { + var c2; + c2 = (a.Bb & QHe) != 0; + b ? a.Bb |= QHe : a.Bb &= -32769; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new Q3d(a, 1, 18, c2, b)); + } + function a6d(a, b) { + var c2; + c2 = (a.Bb & QHe) != 0; + b ? a.Bb |= QHe : a.Bb &= -32769; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new Q3d(a, 1, 18, c2, b)); + } + function AWd(a, b) { + var c2; + c2 = (a.Bb & Ove) != 0; + b ? a.Bb |= Ove : a.Bb &= -16385; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new Q3d(a, 1, 16, c2, b)); + } + function c6d(a, b) { + var c2; + c2 = (a.Bb & txe) != 0; + b ? a.Bb |= txe : a.Bb &= -65537; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new Q3d(a, 1, 20, c2, b)); + } + function qse(a) { + var b; + b = $C(hE, zwe, 28, 2, 15, 1); + a -= txe; + b[0] = (a >> 10) + uxe & Bwe; + b[1] = (a & 1023) + 56320 & Bwe; + return Ihb(b, 0, b.length); + } + function Zfb(a) { + var b; + b = Neb(a); + if (b > 34028234663852886e22) { + return oxe; + } else if (b < -34028234663852886e22) { + return pxe; + } + return b; + } + function Bdb(a, b) { + var c2; + if (Kdb(a) && Kdb(b)) { + c2 = a + b; + if (jxe < c2 && c2 < hxe) { + return c2; + } + } + return Edb(sD(Kdb(a) ? Wdb(a) : a, Kdb(b) ? Wdb(b) : b)); + } + function Ndb(a, b) { + var c2; + if (Kdb(a) && Kdb(b)) { + c2 = a * b; + if (jxe < c2 && c2 < hxe) { + return c2; + } + } + return Edb(wD(Kdb(a) ? Wdb(a) : a, Kdb(b) ? Wdb(b) : b)); + } + function Vdb(a, b) { + var c2; + if (Kdb(a) && Kdb(b)) { + c2 = a - b; + if (jxe < c2 && c2 < hxe) { + return c2; + } + } + return Edb(DD(Kdb(a) ? Wdb(a) : a, Kdb(b) ? Wdb(b) : b)); + } + function b3b(a, b) { + var c2; + a.i || V2b(a); + c2 = RD(Vrb(a.g, b), 42); + return !c2 ? (yob(), yob(), vob) : new Rkb(a.j, RD(c2.a, 17).a, RD(c2.b, 17).a); + } + function ZXb(a) { + NXb(); + return Geb(), IYb(RD(a.a, 86).j, RD(a.b, 88)) || RD(a.a, 86).d.e != 0 && IYb(RD(a.a, 86).j, RD(a.b, 88)) ? true : false; + } + function pWc(a, b) { + return lhb(!!b.b && !!b.c ? aXc(b.b) + "->" + aXc(b.c) : "e_" + tb(b), !!a.b && !!a.c ? aXc(a.b) + "->" + aXc(a.c) : "e_" + tb(a)); + } + function rWc(a, b) { + return lhb(!!b.b && !!b.c ? aXc(b.b) + "->" + aXc(b.c) : "e_" + tb(b), !!a.b && !!a.c ? aXc(a.b) + "->" + aXc(a.c) : "e_" + tb(a)); + } + function $y(a, b) { + Zy(); + return bz(pwe), $wnd.Math.abs(a - b) <= pwe || a == b || isNaN(a) && isNaN(b) ? 0 : a < b ? -1 : a > b ? 1 : cz(isNaN(a), isNaN(b)); + } + function Ymd() { + Ymd = geb; + Xmd = new Zmd(Sye, 0); + Vmd = new Zmd("POLYLINE", 1); + Umd = new Zmd("ORTHOGONAL", 2); + Wmd = new Zmd("SPLINES", 3); + } + function _6c() { + _6c = geb; + Z6c = new a7c("ASPECT_RATIO_DRIVEN", 0); + $6c = new a7c("MAX_SCALE_DRIVEN", 1); + Y6c = new a7c("AREA_DRIVEN", 2); + } + function Db(b, c2, d) { + var e; + try { + Cb(b, c2, d); + } catch (a) { + a = zdb(a); + if (ZD(a, 606)) { + e = a; + throw Adb(new Deb(e)); + } else + throw Adb(a); + } + return c2; + } + function Im(a) { + var b, c2, d; + for (c2 = 0, d = a.length; c2 < d; c2++) { + if (a[c2] == null) { + throw Adb(new Ogb("at index " + c2)); + } + } + b = a; + return new mob(b); + } + function W2b(a) { + var b, c2, d; + b = new bnb(); + for (d = new Anb(a.j); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 12); + Rmb(b, c2.b); + } + return Qb(b), new Dl(b); + } + function Z2b(a) { + var b, c2, d; + b = new bnb(); + for (d = new Anb(a.j); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 12); + Rmb(b, c2.e); + } + return Qb(b), new Dl(b); + } + function a3b(a) { + var b, c2, d; + b = new bnb(); + for (d = new Anb(a.j); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 12); + Rmb(b, c2.g); + } + return Qb(b), new Dl(b); + } + function MBb(a, b) { + var c2, d, e; + e = new Tsb(); + for (d = b.vc().Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 44); + Zjb(e, c2.ld(), QBb(a, RD(c2.md(), 15))); + } + return e; + } + function Mje(a) { + var b, c2; + for (c2 = Nje(BXd(uWd(a))).Kc(); c2.Ob(); ) { + b = WD(c2.Pb()); + if (bAd(a, b)) + return dTd((cTd(), bTd), b); + } + return null; + } + function Cgc(a, b) { + var c2, d, e; + e = 0; + for (d = RD(b.Kb(a), 20).Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 18); + Heb(TD(mQb(c2, (Ywc(), Nwc)))) || ++e; + } + return e; + } + function Uv(a) { + var b, c2, d, e; + b = new oq(a.Rd().gc()); + e = 0; + for (d = Nr(a.Rd().Kc()); d.Ob(); ) { + c2 = d.Pb(); + nq(b, c2, sgb(e++)); + } + return sn(b.a); + } + function Cvb(a, b, c2, d) { + var e, f2; + uFb(d); + uFb(c2); + e = a.xc(b); + f2 = e == null ? c2 : EBb(RD(e, 15), RD(c2, 16)); + f2 == null ? a.Bc(b) : a.zc(b, f2); + return f2; + } + function Unb(a, b, c2, d) { + var e, f2, g; + for (e = b + 1; e < c2; ++e) { + for (f2 = e; f2 > b && d.Ne(a[f2 - 1], a[f2]) > 0; --f2) { + g = a[f2]; + bD(a, f2, a[f2 - 1]); + bD(a, f2 - 1, g); + } + } + } + function Egd(a, b) { + var c2, d, e, f2, g; + c2 = b.f; + dub(a.c.d, c2, b); + if (b.g != null) { + for (e = b.g, f2 = 0, g = e.length; f2 < g; ++f2) { + d = e[f2]; + dub(a.c.e, d, b); + } + } + } + function YSc(a, b) { + var c2, d; + c2 = Sub(a, 0); + while (c2.b != c2.d.c) { + d = Mfb(UD(evb(c2))); + if (d == b) { + return; + } else if (d > b) { + fvb(c2); + break; + } + } + cvb(c2, b); + } + function Kic(a, b) { + var c2, d, e; + d = Zjc(b); + e = Kfb(UD(hFc(d, (yCc(), TBc)))); + c2 = $wnd.Math.max(0, e / 2 - 0.5); + Iic(b, c2, 1); + Rmb(a, new hjc(b, c2)); + } + function L5c(a, b, c2) { + var d; + c2.Ug("Straight Line Edge Routing", 1); + c2.dh(b, eFe); + d = RD(Gxd(b, (u2c(), t2c)), 27); + M5c(a, d); + c2.dh(b, gFe); + } + function K9c(a, b) { + a.n.c.length == 0 && Rmb(a.n, new _9c(a.s, a.t, a.i)); + Rmb(a.b, b); + W9c(RD(Vmb(a.n, a.n.c.length - 1), 209), b); + M9c(a, b); + } + function Zrb(a) { + var b; + this.a = (b = RD(a.e && a.e(), 9), new Fsb(b, RD(WEb(b, b.length), 9), 0)); + this.b = $C(jJ, rve, 1, this.a.a.length, 5, 1); + } + function jeb(a) { + var b; + if (Array.isArray(a) && a.Tm === keb) { + return nfb(rb(a)) + "@" + (b = tb(a) >>> 0, b.toString(16)); + } + return a.toString(); + } + function jD(a, b) { + if (a.h == fxe && a.m == 0 && a.l == 0) { + b && (eD = hD(0, 0, 0)); + return gD((MD(), KD)); + } + b && (eD = hD(a.l, a.m, a.h)); + return hD(0, 0, 0); + } + function _Gb(a, b) { + switch (b.g) { + case 2: + return a.b; + case 1: + return a.c; + case 4: + return a.d; + case 3: + return a.a; + default: + return false; + } + } + function IYb(a, b) { + switch (b.g) { + case 2: + return a.b; + case 1: + return a.c; + case 4: + return a.d; + case 3: + return a.a; + default: + return false; + } + } + function vyd(a, b, c2, d) { + switch (b) { + case 3: + return a.f; + case 4: + return a.g; + case 5: + return a.i; + case 6: + return a.j; + } + return cyd(a, b, c2, d); + } + function oIb(a, b) { + if (b == a.d) { + return a.e; + } else if (b == a.e) { + return a.d; + } else { + throw Adb(new agb("Node " + b + " not part of edge " + a)); + } + } + function Uvd(a, b) { + var c2; + c2 = wYd(a.Dh(), b); + if (ZD(c2, 102)) { + return RD(c2, 19); + } + throw Adb(new agb(KHe + b + "' is not a valid reference")); + } + function Bvd(a, b, c2, d) { + if (b < 0) { + Svd(a, c2, d); + } else { + if (!c2.rk()) { + throw Adb(new agb(KHe + c2.xe() + LHe)); + } + RD(c2, 69).wk().Ck(a, a.hi(), b, d); + } + } + function ig(a) { + var b; + if (a.b) { + ig(a.b); + if (a.b.d != a.c) { + throw Adb(new Jrb()); + } + } else if (a.d.dc()) { + b = RD(a.f.c.xc(a.e), 16); + !!b && (a.d = b); + } + } + function VMb(a) { + RMb(); + var b, c2, d, e; + b = a.o.b; + for (d = RD(RD(Qc(a.r, (qpd(), npd)), 21), 87).Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 117); + e = c2.e; + e.b += b; + } + } + function SRb(a) { + var b, c2, d; + this.a = new Iub(); + for (d = new Anb(a); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 16); + b = new DRb(); + xRb(b, c2); + Ysb(this.a, b); + } + } + function fdc(a, b) { + var c2, d, e; + d = cdc(a, b); + e = d[d.length - 1] / 2; + for (c2 = 0; c2 < d.length; c2++) { + if (d[c2] >= e) { + return b.c + c2; + } + } + return b.c + b.b.gc(); + } + function lQd(a, b) { + jQd(); + var c2, d, e, f2; + d = iZd(a); + e = b; + Wnb(d, 0, d.length, e); + for (c2 = 0; c2 < d.length; c2++) { + f2 = kQd(a, d[c2], c2); + c2 != f2 && uLd(a, c2, f2); + } + } + function mSd(a, b, c2) { + var d, e; + for (d = 0, e = a.length; d < e; d++) { + if (zSd((BFb(d, a.length), a.charCodeAt(d)), b, c2)) + return true; + } + return false; + } + function ARb(a, b) { + var c2, d; + for (d = a.e.a.ec().Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 272); + if (Eid(b, c2.d) || zid(b, c2.d)) { + return true; + } + } + return false; + } + function oMc(a, b, c2, d, e) { + var f2, g, h; + g = e; + while (b.b != b.c) { + f2 = RD(smb(b), 10); + h = RD(b3b(f2, d).Xb(0), 12); + a.d[h.p] = g++; + ZEb(c2.c, h); + } + return g; + } + function vKb(a, b) { + var c2, d, e, f2, g, h; + d = 0; + c2 = 0; + for (f2 = b, g = 0, h = f2.length; g < h; ++g) { + e = f2[g]; + if (e > 0) { + d += e; + ++c2; + } + } + c2 > 1 && (d += a.d * (c2 - 1)); + return d; + } + function FFd(a) { + var b, c2, d, e, f2; + f2 = HFd(a); + c2 = cve(a.c); + d = !c2; + if (d) { + e = new MB(); + sC(f2, "knownLayouters", e); + b = new QFd(e); + xgb(a.c, b); + } + return f2; + } + function fHd(a) { + var b, c2, d; + d = new Qhb(); + d.a += "["; + for (b = 0, c2 = a.gc(); b < c2; ) { + Nhb(d, Ghb(a.Vi(b))); + ++b < c2 && (d.a += pve, d); + } + d.a += "]"; + return d.a; + } + function kSd(a) { + if (a.e == null) { + return a; + } else + !a.c && (a.c = new lSd((a.f & 256) != 0, a.i, a.a, a.d, (a.f & 16) != 0, a.j, a.g, null)); + return a.c; + } + function pnc(a) { + if (a.k != (r3b(), p3b)) { + return false; + } + return yDb(new SDb(null, new Twb(new is(Mr(a3b(a).a.Kc(), new ir())))), new qnc()); + } + function hv(a) { + var b, c2; + if (ZD(a, 307)) { + c2 = vm(RD(a, 307)); + b = c2; + return b; + } else + return ZD(a, 441) ? RD(a, 441).a : ZD(a, 59) ? new Fv(a) : new uv(a); + } + function FSd(a) { + var b; + if (a == null) + return true; + b = a.length; + return b > 0 && (BFb(b - 1, a.length), a.charCodeAt(b - 1) == 58) && !mSd(a, aSd, bSd); + } + function Sib(a, b) { + var c2; + if (dE(a) === dE(b)) { + return true; + } + if (ZD(b, 92)) { + c2 = RD(b, 92); + return a.e == c2.e && a.d == c2.d && Tib(a, c2.a); + } + return false; + } + function vpd(a) { + qpd(); + switch (a.g) { + case 4: + return Yod; + case 1: + return Xod; + case 3: + return npd; + case 2: + return ppd; + default: + return opd; + } + } + function jBb(a) { + var b, c2; + if (a.b) { + return a.b; + } + c2 = dBb ? null : a.d; + while (c2) { + b = dBb ? null : c2.b; + if (b) { + return b; + } + c2 = dBb ? null : c2.d; + } + return SAb(), RAb; + } + function LJb(a) { + var b, c2, d; + d = Kfb(UD(a.a.of((umd(), cmd)))); + for (c2 = new Anb(a.a.Sf()); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 695); + OJb(a, b, d); + } + } + function jz(a) { + var b, c2, d, e; + for (b = (a.j == null && (a.j = (fA(), e = eA.me(a), hA(e))), a.j), c2 = 0, d = b.length; c2 < d; ++c2) { + } + } + function OXb(a, b) { + var c2, d; + for (d = new Anb(b); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 42); + Rmb(a.b.b, RD(c2.b, 86)); + gYb(RD(c2.a, 194), RD(c2.b, 86)); + } + } + function nHc(a, b, c2) { + var d, e; + e = a.a.b; + for (d = e.c.length; d < c2; d++) { + Qmb(e, 0, new R4b(a.a)); + } + g3b(b, RD(Vmb(e, e.c.length - c2), 30)); + a.b[b.p] = c2; + } + function EOc(a, b, c2, d, e) { + dOc(); + rIb(uIb(tIb(sIb(vIb(new wIb(), 0), e.d.e - a), b), e.d)); + rIb(uIb(tIb(sIb(vIb(new wIb(), 0), c2 - e.a.e), e.a), d)); + } + function Ted(a, b) { + var c2; + if (a.d) { + if (Ujb(a.b, b)) { + return RD(Wjb(a.b, b), 47); + } else { + c2 = b.dg(); + Zjb(a.b, b, c2); + return c2; + } + } else { + return b.dg(); + } + } + function hFb(b) { + var c2 = b.e; + function d(a) { + if (!a || a.length == 0) { + return ""; + } + return " " + a.join("\n "); + } + return c2 && (c2.stack || d(b[xwe])); + } + function wyd(a, b) { + switch (b) { + case 3: + return a.f != 0; + case 4: + return a.g != 0; + case 5: + return a.i != 0; + case 6: + return a.j != 0; + } + return fyd(a, b); + } + function y2c(a) { + switch (a.g) { + case 0: + return new D5c(); + case 1: + return new N5c(); + default: + throw Adb(new agb(lBe + (a.f != null ? a.f : "" + a.g))); + } + } + function Z3c(a) { + switch (a.g) { + case 0: + return new G5c(); + case 1: + return new J5c(); + default: + throw Adb(new agb(mFe + (a.f != null ? a.f : "" + a.g))); + } + } + function h4c(a) { + switch (a.g) { + case 1: + return new F3c(); + case 2: + return new x3c(); + default: + throw Adb(new agb(mFe + (a.f != null ? a.f : "" + a.g))); + } + } + function mdd(a) { + switch (a.g) { + case 0: + return new Ddd(); + case 1: + return new Hdd(); + default: + throw Adb(new agb(eGe + (a.f != null ? a.f : "" + a.g))); + } + } + function Owb() { + Hwb(); + var a, b, c2; + c2 = Gwb++ + Date.now(); + a = eE($wnd.Math.floor(c2 * Nxe)) & Pxe; + b = eE(c2 - a * Oxe); + this.a = a ^ 1502; + this.b = b ^ Mxe; + } + function cxc() { + cxc = geb; + bxc = new dxc(LAe, 0); + Zwc = new dxc("FIRST", 1); + $wc = new dxc(oBe, 2); + _wc = new dxc("LAST", 3); + axc = new dxc(pBe, 4); + } + function Grd() { + Grd = geb; + Frd = new Hrd(mEe, 0); + Crd = new Hrd("GROUP_DEC", 1); + Erd = new Hrd("GROUP_MIXED", 2); + Drd = new Hrd("GROUP_INC", 3); + } + function cEd(a, b) { + var c2, d, e, f2; + if (b) { + e = vDd(b, "x"); + c2 = new wFd(a); + Ozd(c2.a, (uFb(e), e)); + f2 = vDd(b, "y"); + d = new zFd(a); + Pzd(d.a, (uFb(f2), f2)); + } + } + function nEd(a, b) { + var c2, d, e, f2; + if (b) { + e = vDd(b, "x"); + c2 = new BFd(a); + Hzd(c2.a, (uFb(e), e)); + f2 = vDd(b, "y"); + d = new CFd(a); + Izd(d.a, (uFb(f2), f2)); + } + } + function Sje(a, b) { + var c2, d, e, f2; + e = new cnb(b.gc()); + for (d = b.Kc(); d.Ob(); ) { + c2 = d.Pb(); + f2 = Rje(a, RD(c2, 58)); + !!f2 && (ZEb(e.c, f2), true); + } + return e; + } + function ze(a, b, c2) { + var d, e; + for (e = a.Kc(); e.Ob(); ) { + d = e.Pb(); + if (dE(b) === dE(d) || b != null && pb(b, d)) { + c2 && e.Qb(); + return true; + } + } + return false; + } + function Y5b(a) { + var b, c2, d; + c2 = a.jh(); + if (c2) { + b = a.Eh(); + if (ZD(b, 167)) { + d = Y5b(RD(b, 167)); + if (d != null) { + return d + "." + c2; + } + } + return c2; + } + return null; + } + function pjb(a) { + var b, c2, d; + if (a.e == 0) { + return 0; + } + b = a.d << 5; + c2 = a.a[a.d - 1]; + if (a.e < 0) { + d = Uib(a); + if (d == a.d - 1) { + --c2; + c2 = c2 | 0; + } + } + b -= ngb(c2); + return b; + } + function kjb(a) { + var b, c2, d; + if (a < Nib.length) { + return Nib[a]; + } + c2 = a >> 5; + b = a & 31; + d = $C(kE, Pwe, 28, c2 + 1, 15, 1); + d[c2] = 1 << b; + return new cjb(1, c2 + 1, d); + } + function eLd(a, b) { + var c2, d; + if (!b) { + return false; + } else { + for (c2 = 0; c2 < a.i; ++c2) { + d = RD(a.g[c2], 378); + if (d.mj(b)) { + return false; + } + } + return WGd(a, b); + } + } + function ZId(a, b, c2) { + var d, e; + ++a.j; + if (c2.dc()) { + return false; + } else { + for (e = c2.Kc(); e.Ob(); ) { + d = e.Pb(); + a.qj(b, a.Zi(b, d)); + ++b; + } + return true; + } + } + function OA(a, b, c2, d) { + var e, f2; + f2 = c2 - b; + if (f2 < 3) { + while (f2 < 3) { + a *= 10; + ++f2; + } + } else { + e = 1; + while (f2 > 3) { + e *= 10; + --f2; + } + a = (a + (e >> 1)) / e | 0; + } + d.i = a; + return true; + } + function BYd(a, b) { + var c2, d, e; + c2 = (a.i == null && rYd(a), a.i); + d = b.Lj(); + if (d != -1) { + for (e = c2.length; d < e; ++d) { + if (c2[d] == b) { + return d; + } + } + } + return -1; + } + function T$d(a) { + var b, c2, d, e, f2; + c2 = RD(a.g, 689); + for (d = a.i - 1; d >= 0; --d) { + b = c2[d]; + for (e = 0; e < d; ++e) { + f2 = c2[e]; + if (U$d(a, b, f2)) { + THd(a, d); + break; + } + } + } + } + function PId(a) { + var b, c2, d, e; + b = new MB(); + for (e = new Ppb(a.b.Kc()); e.b.Ob(); ) { + d = RD(e.b.Pb(), 701); + c2 = LFd(d); + KB(b, b.a.length, c2); + } + return b.a; + } + function VNb(a) { + var b; + !a.c && (a.c = new MNb()); + _mb(a.d, new aOb()); + SNb(a); + b = LNb(a); + FDb(new SDb(null, new Swb(a.d, 16)), new tOb(a)); + return b; + } + function I6b(a, b) { + b.Ug("End label post-processing", 1); + FDb(CDb(EDb(new SDb(null, new Swb(a.b, 16)), new N6b()), new P6b()), new R6b()); + b.Vg(); + } + function RCc(a) { + QCc(); + this.c = dv(cD(WC(g2, 1), rve, 845, 0, [FCc])); + this.b = new Tsb(); + this.a = a; + Zjb(this.b, OCc, 1); + Umb(PCc, new $rd(this)); + } + function wKb(a, b, c2) { + kKb(); + fKb.call(this); + this.a = YC(IN, [Nve, Mye], [603, 217], 0, [jKb, iKb], 2); + this.c = new Tid(); + this.g = a; + this.f = b; + this.d = c2; + } + function gQb(a, b) { + this.n = YC(lE, [Nve, rxe], [376, 28], 14, [b, eE($wnd.Math.ceil(a / 32))], 2); + this.o = a; + this.p = b; + this.j = a - 1 >> 1; + this.k = b - 1 >> 1; + } + function Dfd(a) { + Afd(); + if (RD(a.of((umd(), pld)), 181).Hc((dqd(), bqd))) { + RD(a.of(Lld), 181).Fc((Pod(), Ood)); + RD(a.of(pld), 181).Mc(bqd); + } + } + function ndc(a) { + var b, c2; + b = a.d == (btc(), Ysc); + c2 = jdc(a); + b && !c2 || !b && c2 ? pQb(a.a, (yCc(), Rzc), (Rjd(), Pjd)) : pQb(a.a, (yCc(), Rzc), (Rjd(), Ojd)); + } + function QCc() { + QCc = geb; + GCc(); + OCc = (yCc(), bCc); + PCc = dv(cD(WC(V5, 1), kEe, 149, 0, [SBc, TBc, VBc, WBc, ZBc, $Bc, _Bc, aCc, dCc, fCc, UBc, XBc, cCc])); + } + function RDb(a, b) { + var c2; + c2 = RD(zDb(a, tBb(new ZBb(), new XBb(), new wCb(), cD(WC(QL, 1), jwe, 108, 0, [(xBb(), vBb)]))), 15); + return c2.Qc(__c(c2.gc())); + } + function nXc(a, b) { + var c2, d; + d = new zAb(a.a.ad(b, true)); + if (d.a.gc() <= 1) { + throw Adb(new Ngb()); + } + c2 = d.a.ec().Kc(); + c2.Pb(); + return RD(c2.Pb(), 40); + } + function lQc(a, b, c2) { + var d, e; + d = Kfb(a.p[b.i.p]) + Kfb(a.d[b.i.p]) + b.n.b + b.a.b; + e = Kfb(a.p[c2.i.p]) + Kfb(a.d[c2.i.p]) + c2.n.b + c2.a.b; + return e - d; + } + function XHd(a, b) { + var c2; + if (a.i > 0) { + if (b.length < a.i) { + c2 = IMd(rb(b).c, a.i); + b = c2; + } + hib(a.g, 0, b, 0, a.i); + } + b.length > a.i && bD(b, a.i, null); + return b; + } + function MXd(a) { + var b; + if ((a.Db & 64) != 0) + return QAd(a); + b = new Shb(QAd(a)); + b.a += " (instanceClassName: "; + Nhb(b, a.D); + b.a += ")"; + return b.a; + } + function ySd(a) { + var b, c2, d, e; + e = 0; + for (c2 = 0, d = a.length; c2 < d; c2++) { + b = (BFb(c2, a.length), a.charCodeAt(c2)); + b < 64 && (e = Rdb(e, Sdb(1, b))); + } + return e; + } + function Fjb(a, b, c2) { + var d, e; + d = Cdb(c2, yxe); + for (e = 0; Ddb(d, 0) != 0 && e < b; e++) { + d = Bdb(d, Cdb(a[e], yxe)); + a[e] = Ydb(d); + d = Tdb(d, 32); + } + return Ydb(d); + } + function pge(a, b) { + var c2, d, e, f2; + f2 = pke(a.e.Dh(), b); + c2 = RD(a.g, 124); + for (e = 0; e < a.i; ++e) { + d = c2[e]; + if (f2.am(d.Lk())) { + return false; + } + } + return true; + } + function QNd(a, b) { + var c2, d, e; + if (a.f > 0) { + a._j(); + d = b == null ? 0 : tb(b); + e = (d & lve) % a.d.length; + c2 = XNd(a, e, d, b); + return c2 != -1; + } else { + return false; + } + } + function Nrb(a, b) { + var c2, d; + a.a = Bdb(a.a, 1); + a.c = $wnd.Math.min(a.c, b); + a.b = $wnd.Math.max(a.b, b); + a.d += b; + c2 = b - a.f; + d = a.e + c2; + a.f = d - a.e - c2; + a.e = d; + } + function yyd(a, b) { + switch (b) { + case 3: + Ayd(a, 0); + return; + case 4: + Cyd(a, 0); + return; + case 5: + Dyd(a, 0); + return; + case 6: + Eyd(a, 0); + return; + } + hyd(a, b); + } + function c3b(a, b) { + switch (b.g) { + case 1: + return dr(a.j, (J3b(), E3b)); + case 2: + return dr(a.j, (J3b(), G3b)); + default: + return yob(), yob(), vob; + } + } + function zm(a) { + tm(); + var b; + b = a.Pc(); + switch (b.length) { + case 0: + return sm; + case 1: + return new Dy(Qb(b[0])); + default: + return new Kx(Im(b)); + } + } + function kMd(b, c2) { + b.Xj(); + try { + b.d.bd(b.e++, c2); + b.f = b.d.j; + b.g = -1; + } catch (a) { + a = zdb(a); + if (ZD(a, 77)) { + throw Adb(new Jrb()); + } else + throw Adb(a); + } + } + function a8d() { + a8d = geb; + $7d = new b8d(); + T7d = new e8d(); + U7d = new h8d(); + V7d = new k8d(); + W7d = new n8d(); + X7d = new q8d(); + Y7d = new t8d(); + Z7d = new w8d(); + _7d = new z8d(); + } + function YA(a, b) { + WA(); + var c2, d; + c2 = _A(($A(), $A(), ZA)); + d = null; + b == c2 && (d = RD(Xjb(VA, a), 624)); + if (!d) { + d = new XA(a); + b == c2 && $jb(VA, a, d); + } + return d; + } + function zDc(a) { + wDc(); + var b; + (!a.q ? (yob(), yob(), wob) : a.q)._b((yCc(), iBc)) ? b = RD(mQb(a, iBc), 203) : b = RD(mQb(Y2b(a), jBc), 203); + return b; + } + function hFc(a, b) { + var c2, d; + d = null; + if (nQb(a, (yCc(), YBc))) { + c2 = RD(mQb(a, YBc), 96); + c2.pf(b) && (d = c2.of(b)); + } + d == null && (d = mQb(Y2b(a), b)); + return d; + } + function Ze(a, b) { + var c2, d, e; + if (ZD(b, 44)) { + c2 = RD(b, 44); + d = c2.ld(); + e = Xv(a.Rc(), d); + return Hb(e, c2.md()) && (e != null || a.Rc()._b(d)); + } + return false; + } + function $Nd(a, b) { + var c2, d, e; + if (a.f > 0) { + a._j(); + d = b == null ? 0 : tb(b); + e = (d & lve) % a.d.length; + c2 = WNd(a, e, d, b); + if (c2) { + return c2.md(); + } + } + return null; + } + function qLd(a, b, c2) { + var d, e, f2; + if (a.Pj()) { + d = a.i; + f2 = a.Qj(); + KHd(a, d, b); + e = a.Ij(3, null, b, d, f2); + !c2 ? c2 = e : c2.nj(e); + } else { + KHd(a, a.i, b); + } + return c2; + } + function f$d(a, b, c2) { + var d, e; + d = new P3d(a.e, 4, 10, (e = b.c, ZD(e, 90) ? RD(e, 29) : (JTd(), zTd)), null, fZd(a, b), false); + !c2 ? c2 = d : c2.nj(d); + return c2; + } + function e$d(a, b, c2) { + var d, e; + d = new P3d(a.e, 3, 10, null, (e = b.c, ZD(e, 90) ? RD(e, 29) : (JTd(), zTd)), fZd(a, b), false); + !c2 ? c2 = d : c2.nj(d); + return c2; + } + function SMb(a) { + RMb(); + var b; + b = new sjd(RD(a.e.of((umd(), nld)), 8)); + if (a.B.Hc((dqd(), Ypd))) { + b.a <= 0 && (b.a = 20); + b.b <= 0 && (b.b = 20); + } + return b; + } + function jjb(a) { + Pib(); + var b, c2; + c2 = Ydb(a); + b = Ydb(Udb(a, 32)); + if (b != 0) { + return new bjb(c2, b); + } + if (c2 > 10 || c2 < 0) { + return new ajb(1, c2); + } + return Lib[c2]; + } + function Mdb(a, b) { + var c2; + if (Kdb(a) && Kdb(b)) { + c2 = a % b; + if (jxe < c2 && c2 < hxe) { + return c2; + } + } + return Edb((iD(Kdb(a) ? Wdb(a) : a, Kdb(b) ? Wdb(b) : b, true), eD)); + } + function G8b(a, b) { + var c2; + D8b(b); + c2 = RD(mQb(a, (yCc(), xAc)), 283); + !!c2 && pQb(a, xAc, uuc(c2)); + E8b(a.c); + E8b(a.f); + F8b(a.d); + F8b(RD(mQb(a, cBc), 214)); + } + function y7b(a) { + var b, c2, d, e; + d = t7b(a); + _mb(d, r7b); + e = a.d; + e.c.length = 0; + for (c2 = new Anb(d); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 466); + Tmb(e, b.b); + } + } + function cmc(a) { + var b; + if (a.c == 0) { + return; + } + b = RD(Vmb(a.a, a.b), 294); + b.b == 1 ? (++a.b, a.b < a.a.c.length && gmc(RD(Vmb(a.a, a.b), 294))) : --b.b; + --a.c; + } + function vdc(a) { + var b; + b = a.a; + do { + b = RD(hs(new is(Mr(a3b(b).a.Kc(), new ir()))), 18).d.i; + b.k == (r3b(), o3b) && Rmb(a.e, b); + } while (b.k == (r3b(), o3b)); + } + function RLc(a) { + this.e = $C(kE, Pwe, 28, a.length, 15, 1); + this.c = $C(xdb, Hye, 28, a.length, 16, 1); + this.b = $C(xdb, Hye, 28, a.length, 16, 1); + this.f = 0; + } + function _Hc(a) { + var b, c2; + a.j = $C(iE, vxe, 28, a.p.c.length, 15, 1); + for (c2 = new Anb(a.p); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 10); + a.j[b.p] = b.o.b / a.i; + } + } + function L_c(a, b) { + var c2, d, e, f2; + f2 = b.b.b; + a.a = new Yub(); + a.b = $C(kE, Pwe, 28, f2, 15, 1); + c2 = 0; + for (e = Sub(b.b, 0); e.b != e.d.c; ) { + d = RD(evb(e), 40); + d.g = c2++; + } + } + function fad(a, b, c2) { + var d, e, f2, g; + f2 = b - a.e; + g = c2 - a.f; + for (e = new Anb(a.a); e.a < e.c.c.length; ) { + d = RD(ynb(e), 172); + U9c(d, d.s + f2, d.t + g); + } + a.e = b; + a.f = c2; + } + function ose(a, b) { + var c2, d; + d = b.length; + for (c2 = 0; c2 < d; c2 += 2) + rte(a, (BFb(c2, b.length), b.charCodeAt(c2)), (BFb(c2 + 1, b.length), b.charCodeAt(c2 + 1))); + } + function G6c(a, b) { + b.Ug("Min Size Postprocessing", 1); + Ixd(a, (X6c(), W6c), $wnd.Math.max(Kfb(UD(Gxd(a, W6c))), Kfb(UD(Gxd(a, U6c))))); + b.Vg(); + } + function Fpd() { + Fpd = geb; + Cpd = new A3b(15); + Bpd = new mGd((umd(), tld), Cpd); + Epd = new mGd(fmd, 15); + Dpd = new mGd(Sld, sgb(0)); + Apd = new mGd(Dkd, Yze); + } + function Qpd() { + Qpd = geb; + Opd = new Rpd("PORTS", 0); + Ppd = new Rpd("PORT_LABELS", 1); + Npd = new Rpd("NODE_LABELS", 2); + Mpd = new Rpd("MINIMUM_SIZE", 3); + } + function f6c() { + f6c = geb; + c6c = new g6c("P1_WIDTH_APPROXIMATION", 0); + d6c = new g6c("P2_PACKING", 1); + e6c = new g6c("P3_WHITESPACE_ELIMINATION", 2); + } + function $je(a) { + if (a.b == null) { + while (a.a.Ob()) { + a.b = a.a.Pb(); + if (!RD(a.b, 54).Jh()) { + return true; + } + } + a.b = null; + return false; + } else { + return true; + } + } + function Pyb(a, b, c2) { + var d, e, f2; + e = null; + f2 = a.b; + while (f2) { + d = a.a.Ne(b, f2.d); + if (c2 && d == 0) { + return f2; + } + if (d >= 0) { + f2 = f2.a[1]; + } else { + e = f2; + f2 = f2.a[0]; + } + } + return e; + } + function Qyb(a, b, c2) { + var d, e, f2; + e = null; + f2 = a.b; + while (f2) { + d = a.a.Ne(b, f2.d); + if (c2 && d == 0) { + return f2; + } + if (d <= 0) { + f2 = f2.a[0]; + } else { + e = f2; + f2 = f2.a[1]; + } + } + return e; + } + function rmc(a, b, c2, d) { + var e, f2, g; + e = false; + if (Lmc(a.f, c2, d)) { + Omc(a.f, a.a[b][c2], a.a[b][d]); + f2 = a.a[b]; + g = f2[d]; + f2[d] = f2[c2]; + f2[c2] = g; + e = true; + } + return e; + } + function Nqc(a, b, c2) { + var d, e, f2, g; + e = RD(Wjb(a.b, c2), 183); + d = 0; + for (g = new Anb(b.j); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 113); + e[f2.d.p] && ++d; + } + return d; + } + function lte(a, b, c2) { + var d, e; + d = RD(Xjb(wse, b), 122); + e = RD(Xjb(xse, b), 122); + if (c2) { + $jb(wse, a, d); + $jb(xse, a, e); + } else { + $jb(xse, a, d); + $jb(wse, a, e); + } + } + function qjb(a, b) { + var c2, d, e, f2; + c2 = b >> 5; + b &= 31; + e = a.d + c2 + (b == 0 ? 0 : 1); + d = $C(kE, Pwe, 28, e, 15, 1); + rjb(d, a.a, c2, b); + f2 = new cjb(a.e, e, d); + Rib(f2); + return f2; + } + function zGc(a, b) { + var c2, d, e; + for (d = new is(Mr(a3b(a).a.Kc(), new ir())); gs(d); ) { + c2 = RD(hs(d), 18); + e = c2.d.i; + if (e.c == b) { + return false; + } + } + return true; + } + function _Ec(a, b, c2) { + var d, e, f2, g, h; + g = a.k; + h = b.k; + d = c2[g.g][h.g]; + e = UD(hFc(a, d)); + f2 = UD(hFc(b, d)); + return $wnd.Math.max((uFb(e), e), (uFb(f2), f2)); + } + function lA() { + if (Error.stackTraceLimit > 0) { + $wnd.Error.stackTraceLimit = Error.stackTraceLimit = 64; + return true; + } + return "stack" in new Error(); + } + function sGb(a, b) { + return Zy(), Zy(), bz(pwe), ($wnd.Math.abs(a - b) <= pwe || a == b || isNaN(a) && isNaN(b) ? 0 : a < b ? -1 : a > b ? 1 : cz(isNaN(a), isNaN(b))) > 0; + } + function uGb(a, b) { + return Zy(), Zy(), bz(pwe), ($wnd.Math.abs(a - b) <= pwe || a == b || isNaN(a) && isNaN(b) ? 0 : a < b ? -1 : a > b ? 1 : cz(isNaN(a), isNaN(b))) < 0; + } + function tGb(a, b) { + return Zy(), Zy(), bz(pwe), ($wnd.Math.abs(a - b) <= pwe || a == b || isNaN(a) && isNaN(b) ? 0 : a < b ? -1 : a > b ? 1 : cz(isNaN(a), isNaN(b))) <= 0; + } + function Efb(a, b) { + var c2 = 0; + while (!b[c2] || b[c2] == "") { + c2++; + } + var d = b[c2++]; + for (; c2 < b.length; c2++) { + if (!b[c2] || b[c2] == "") { + continue; + } + d += a + b[c2]; + } + return d; + } + function MMd(a) { + var b, c2; + b = RD(Ywd(a.a, 4), 129); + if (b != null) { + c2 = $C(d6, IJe, 424, b.length, 0, 1); + hib(b, 0, c2, 0, b.length); + return c2; + } else { + return JMd; + } + } + function kne(a) { + var b, c2, d, e, f2; + if (a == null) + return null; + f2 = new bnb(); + for (c2 = xAd(a), d = 0, e = c2.length; d < e; ++d) { + b = c2[d]; + Rmb(f2, nue(b, true)); + } + return f2; + } + function nne(a) { + var b, c2, d, e, f2; + if (a == null) + return null; + f2 = new bnb(); + for (c2 = xAd(a), d = 0, e = c2.length; d < e; ++d) { + b = c2[d]; + Rmb(f2, nue(b, true)); + } + return f2; + } + function one2(a) { + var b, c2, d, e, f2; + if (a == null) + return null; + f2 = new bnb(); + for (c2 = xAd(a), d = 0, e = c2.length; d < e; ++d) { + b = c2[d]; + Rmb(f2, nue(b, true)); + } + return f2; + } + function vrd(a, b) { + var c2, d, e; + if (a.c) { + Ayd(a.c, b); + } else { + c2 = b - trd(a); + for (e = new Anb(a.a); e.a < e.c.c.length; ) { + d = RD(ynb(e), 163); + vrd(d, trd(d) + c2); + } + } + } + function wrd(a, b) { + var c2, d, e; + if (a.c) { + Cyd(a.c, b); + } else { + c2 = b - urd(a); + for (e = new Anb(a.d); e.a < e.c.c.length; ) { + d = RD(ynb(e), 163); + wrd(d, urd(d) + c2); + } + } + } + function Ihb(a, b, c2) { + var d, e, f2, g; + f2 = b + c2; + AFb(b, f2, a.length); + g = ""; + for (e = b; e < f2; ) { + d = $wnd.Math.min(e + 1e4, f2); + g += Ehb(a.slice(e, d)); + e = d; + } + return g; + } + function jMb(a) { + switch (a.g) { + case 12: + case 13: + case 14: + case 15: + case 16: + case 17: + case 18: + case 19: + case 20: + return true; + default: + return false; + } + } + function Ptc() { + Ptc = geb; + Ltc = new Rtc(CBe, 0); + Ktc = new Rtc(DBe, 1); + Ntc = new Rtc(BBe, 2); + Otc = new Rtc(MAe, 3); + Mtc = new Rtc("GREEDY_MODEL_ORDER", 4); + } + function kEc() { + kEc = geb; + hEc = new lEc(LAe, 0); + gEc = new lEc("NODES_AND_EDGES", 1); + iEc = new lEc("PREFER_EDGES", 2); + jEc = new lEc("PREFER_NODES", 3); + } + function mad(a, b, c2, d, e, f2) { + this.a = a; + this.c = b; + this.b = c2; + this.f = d; + this.d = e; + this.e = f2; + this.c > 0 && this.b > 0 && (this.g = Aad(this.c, this.b, this.a)); + } + function rC(f2, a) { + var b = f2.a; + var c2; + a = String(a); + b.hasOwnProperty(a) && (c2 = b[a]); + var d = (HC(), GC)[typeof c2]; + var e = d ? d(c2) : NC(typeof c2); + return e; + } + function uDd(a) { + var b, c2, d; + d = null; + b = uIe in a.a; + c2 = !b; + if (c2) { + throw Adb(new CDd("Every element must have an id.")); + } + d = tDd(qC(a, uIe)); + return d; + } + function Qqe(a) { + var b, c2; + c2 = Rqe(a); + b = null; + while (a.c == 2) { + Mqe(a); + if (!b) { + b = (Vse(), Vse(), new iue(2)); + hue2(b, c2); + c2 = b; + } + c2.Jm(Rqe(a)); + } + return c2; + } + function jOd(a, b) { + var c2, d, e; + a._j(); + d = b == null ? 0 : tb(b); + e = (d & lve) % a.d.length; + c2 = WNd(a, e, d, b); + if (c2) { + hOd(a, c2); + return c2.md(); + } else { + return null; + } + } + function Qib(a, b) { + if (a.e > b.e) { + return 1; + } + if (a.e < b.e) { + return -1; + } + if (a.d > b.d) { + return a.e; + } + if (a.d < b.d) { + return -b.e; + } + return a.e * Ejb(a.a, b.a, a.d); + } + function dfb(a) { + if (a >= 48 && a < 48 + $wnd.Math.min(10, 10)) { + return a - 48; + } + if (a >= 97 && a < 97) { + return a - 97 + 10; + } + if (a >= 65 && a < 65) { + return a - 65 + 10; + } + return -1; + } + function UHc(a, b) { + if (b.c == a) { + return b.d; + } else if (b.d == a) { + return b.c; + } + throw Adb(new agb("Input edge is not connected to the input port.")); + } + function Fae(a) { + if (mhb(FGe, a)) { + return Geb(), Feb; + } else if (mhb(GGe, a)) { + return Geb(), Eeb; + } else { + throw Adb(new agb("Expecting true or false")); + } + } + function jFb(a) { + switch (typeof a) { + case jve: + return ohb(a); + case ive: + return Nfb(a); + case hve: + return Jeb(a); + default: + return a == null ? 0 : kFb(a); + } + } + function mfd(a, b) { + if (a.a < 0) { + throw Adb(new dgb("Did not call before(...) or after(...) before calling add(...).")); + } + tfd(a, a.a, b); + return a; + } + function FId(a) { + EId(); + if (ZD(a, 162)) { + return RD(Wjb(CId, zK), 295).Rg(a); + } + if (Ujb(CId, rb(a))) { + return RD(Wjb(CId, rb(a)), 295).Rg(a); + } + return null; + } + function Wwd(a) { + var b, c2; + if ((a.Db & 32) == 0) { + c2 = (b = RD(Ywd(a, 16), 29), AYd(!b ? a.ii() : b) - AYd(a.ii())); + c2 != 0 && $wd(a, 32, $C(jJ, rve, 1, c2, 5, 1)); + } + return a; + } + function $wd(a, b, c2) { + var d; + if ((a.Db & b) != 0) { + if (c2 == null) { + Zwd(a, b); + } else { + d = Xwd(a, b); + d == -1 ? a.Eb = c2 : bD(SD(a.Eb), d, c2); + } + } else + c2 != null && Twd(a, b, c2); + } + function tTc(a, b, c2, d) { + var e, f2; + if (b.c.length == 0) { + return; + } + e = pTc(c2, d); + f2 = oTc(b); + FDb(PDb(new SDb(null, new Swb(f2, 1)), new CTc()), new GTc(a, c2, e, d)); + } + function rmb(a, b) { + var c2, d, e, f2; + d = a.a.length - 1; + c2 = b - a.b & d; + f2 = a.c - b & d; + e = a.c - a.b & d; + zmb(c2 < e); + if (c2 >= f2) { + umb(a, b); + return -1; + } else { + vmb(a, b); + return 1; + } + } + function Hvd(a) { + var b, c2, d; + d = a.Jh(); + if (!d) { + b = 0; + for (c2 = a.Ph(); c2; c2 = c2.Ph()) { + if (++b > wxe) { + return c2.Qh(); + } + d = c2.Jh(); + if (!!d || c2 == a) { + break; + } + } + } + return d; + } + function Ue(a, b) { + var c2; + if (dE(b) === dE(a)) { + return true; + } + if (!ZD(b, 21)) { + return false; + } + c2 = RD(b, 21); + if (c2.gc() != a.gc()) { + return false; + } + return a.Ic(c2); + } + function kNc(a, b) { + if (a.e < b.e) { + return -1; + } else if (a.e > b.e) { + return 1; + } else if (a.f < b.f) { + return -1; + } else if (a.f > b.f) { + return 1; + } + return tb(a) - tb(b); + } + function mhb(a, b) { + uFb(a); + if (b == null) { + return false; + } + if (lhb(a, b)) { + return true; + } + return a.length == b.length && lhb(a.toLowerCase(), b.toLowerCase()); + } + function Hgb(a) { + var b, c2; + if (Ddb(a, -129) > 0 && Ddb(a, 128) < 0) { + return Jgb(), b = Ydb(a) + 128, c2 = Igb[b], !c2 && (c2 = Igb[b] = new zgb(a)), c2; + } + return new zgb(a); + } + function U$b() { + U$b = geb; + T$b = new V$b(LAe, 0); + R$b = new V$b("INSIDE_PORT_SIDE_GROUPS", 1); + Q$b = new V$b("GROUP_MODEL_ORDER", 2); + S$b = new V$b(MAe, 3); + } + function ufe(a) { + var b; + a.b || vfe(a, (b = Hee(a.e, a.a), !b || !lhb(GGe, $Nd((!b.b && (b.b = new SVd((JTd(), FTd), C8, b)), b.b), "qualified")))); + return a.c; + } + function BA(a, b) { + var c2, d; + c2 = (BFb(b, a.length), a.charCodeAt(b)); + d = b + 1; + while (d < a.length && (BFb(d, a.length), a.charCodeAt(d) == c2)) { + ++d; + } + return d - b; + } + function dFb(a, b) { + (!b && console.groupCollapsed != null ? console.groupCollapsed : console.group != null ? console.group : console.log).call(console, a); + } + function EQb(a, b, c2, d) { + d == a ? (RD(c2.b, 68), RD(c2.b, 68), RD(d.b, 68), RD(d.b, 68).c.b) : (RD(c2.b, 68), RD(c2.b, 68), RD(d.b, 68), RD(d.b, 68).c.b); + BQb(d, b, a); + } + function vRb(a) { + var c2, d; + for (c2 = new Anb(a.g); c2.a < c2.c.c.length; ) { + RD(ynb(c2), 568); + } + d = new vQb(a.g, Kfb(a.a), a.c); + vOb(d); + a.g = d.b; + a.d = d.a; + } + function Add(a, b, c2) { + var d, e, f2; + for (f2 = new Anb(c2.a); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 225); + d = new $Fb(RD(Wjb(a.a, e.b), 68)); + Rmb(b.a, d); + Add(a, d, e); + } + } + function D4d(a, b, c2) { + var d, e, f2; + d = RD(QHd(o4d(a.a), b), 89); + f2 = (e = d.c, e ? e : (JTd(), wTd)); + (f2.Vh() ? Vvd(a.b, RD(f2, 54)) : f2) == c2 ? i2d(d) : l2d(d, c2); + return f2; + } + function cqc(a, b, c2) { + b.b = $wnd.Math.max(b.b, -c2.a); + b.c = $wnd.Math.max(b.c, c2.a - a.a); + b.d = $wnd.Math.max(b.d, -c2.b); + b.a = $wnd.Math.max(b.a, c2.b - a.b); + } + function JXb(a, b, c2) { + this.c = a; + this.f = new bnb(); + this.e = new pjd(); + this.j = new KYb(); + this.n = new KYb(); + this.b = b; + this.g = new Uid2(b.c, b.d, b.b, b.a); + this.a = c2; + } + function iYb(a) { + var b, c2, d, e; + this.a = new Iub(); + this.d = new _sb(); + this.e = 0; + for (c2 = a, d = 0, e = c2.length; d < e; ++d) { + b = c2[d]; + !this.f && (this.f = b); + gYb(this, b); + } + } + function djb(a) { + Pib(); + if (a.length == 0) { + this.e = 0; + this.d = 1; + this.a = cD(WC(kE, 1), Pwe, 28, 15, [0]); + } else { + this.e = 1; + this.d = a.length; + this.a = a; + Rib(this); + } + } + function dLb(a, b, c2) { + fKb.call(this); + this.a = $C(IN, Mye, 217, (ZJb(), cD(WC(JN, 1), jwe, 237, 0, [WJb, XJb, YJb])).length, 0, 1); + this.b = a; + this.d = b; + this.c = c2; + } + function zfc(a) { + var b, c2, d, e, f2, g; + g = RD(mQb(a, (Ywc(), Awc)), 12); + pQb(g, Swc, a.i.n.b); + b = s2b(a.e); + for (d = b, e = 0, f2 = d.length; e < f2; ++e) { + c2 = d[e]; + Z0b(c2, g); + } + } + function Afc(a) { + var b, c2, d, e, f2, g; + c2 = RD(mQb(a, (Ywc(), Awc)), 12); + pQb(c2, Swc, a.i.n.b); + b = s2b(a.g); + for (e = b, f2 = 0, g = e.length; f2 < g; ++f2) { + d = e[f2]; + Y0b(d, c2); + } + } + function dRc(a, b) { + WQc(); + var c2, d; + for (d = new is(Mr(W2b(a).a.Kc(), new ir())); gs(d); ) { + c2 = RD(hs(d), 18); + if (c2.d.i == b || c2.c.i == b) { + return c2; + } + } + return null; + } + function zee(a, b) { + var c2, d; + c2 = b.qi(a.a); + if (c2) { + d = WD($Nd((!c2.b && (c2.b = new SVd((JTd(), FTd), C8, c2)), c2.b), GIe)); + if (d != null) { + return d; + } + } + return b.xe(); + } + function Aee(a, b) { + var c2, d; + c2 = b.qi(a.a); + if (c2) { + d = WD($Nd((!c2.b && (c2.b = new SVd((JTd(), FTd), C8, c2)), c2.b), GIe)); + if (d != null) { + return d; + } + } + return b.xe(); + } + function B7b(a, b) { + var c2, d; + c2 = hgb(a.a.c.p, b.a.c.p); + if (c2 != 0) { + return c2; + } + d = hgb(a.a.d.i.p, b.a.d.i.p); + if (d != 0) { + return d; + } + return hgb(b.a.d.p, a.a.d.p); + } + function Wje(a, b) { + var c2, d, e, f2; + for (d = 0, e = b.gc(); d < e; ++d) { + c2 = b.Tl(d); + if (ZD(c2, 102) && (RD(c2, 19).Bb & QHe) != 0) { + f2 = b.Ul(d); + f2 != null && Rje(a, RD(f2, 58)); + } + } + } + function KSb(a, b) { + var c2, d, e; + Rmb(GSb, a); + b.Fc(a); + c2 = RD(Wjb(FSb, a), 21); + if (c2) { + for (e = c2.Kc(); e.Ob(); ) { + d = RD(e.Pb(), 27); + Wmb(GSb, d, 0) != -1 || KSb(d, b); + } + } + } + function Omc(a, b, c2) { + var d, e; + BMc(a.e, b, c2, (qpd(), ppd)); + BMc(a.i, b, c2, Xod); + if (a.a) { + e = RD(mQb(b, (Ywc(), Awc)), 12); + d = RD(mQb(c2, Awc), 12); + CMc(a.g, e, d); + } + } + function mJc(a, b, c2) { + var d, e, f2; + d = b.c.p; + f2 = b.p; + a.b[d][f2] = new yJc(a, b); + if (c2) { + a.a[d][f2] = new dJc(b); + e = RD(mQb(b, (Ywc(), pwc)), 10); + !!e && Rc(a.d, e, b); + } + } + function zIc(a, b, c2) { + var d, e, f2, g; + f2 = b.j; + g = c2.j; + if (f2 != g) { + return f2.g - g.g; + } else { + d = a.f[b.p]; + e = a.f[c2.p]; + return d == 0 && e == 0 ? 0 : d == 0 ? -1 : e == 0 ? 1 : Qfb(d, e); + } + } + function Sz() { + var a; + if (Nz != 0) { + a = Date.now(); + if (a - Oz > 2e3) { + Oz = a; + Pz = $wnd.setTimeout(Yz, 10); + } + } + if (Nz++ == 0) { + _z(($z(), Zz)); + return true; + } + return false; + } + function lBb(a, b, c2) { + var d; + (bBb ? (jBb(a), true) : cBb ? (SAb(), true) : fBb ? (SAb(), true) : eBb && (SAb(), false)) && (d = new aBb(b), d.b = c2, hBb(a, d), void 0); + } + function oNb(a, b) { + var c2; + c2 = !a.A.Hc((Qpd(), Ppd)) || a.q == (Bod(), wod); + a.u.Hc((Pod(), Lod)) ? c2 ? mNb(a, b) : qNb(a, b) : a.u.Hc(Nod) && (c2 ? nNb(a, b) : rNb(a, b)); + } + function Bed(a) { + var b; + if (dE(Gxd(a, (umd(), Xkd))) === dE((Fnd(), Dnd))) { + if (!vCd(a)) { + Ixd(a, Xkd, End); + } else { + b = RD(Gxd(vCd(a), Xkd), 346); + Ixd(a, Xkd, b); + } + } + } + function _fc(a) { + var b, c2; + if (nQb(a.d.i, (yCc(), tBc))) { + b = RD(mQb(a.c.i, tBc), 17); + c2 = RD(mQb(a.d.i, tBc), 17); + return hgb(b.a, c2.a) > 0; + } else { + return false; + } + } + function g_b(a, b, c2) { + return new Uid2($wnd.Math.min(a.a, b.a) - c2 / 2, $wnd.Math.min(a.b, b.b) - c2 / 2, $wnd.Math.abs(a.a - b.a) + c2, $wnd.Math.abs(a.b - b.b) + c2); + } + function _mc(a) { + var b; + this.d = new bnb(); + this.j = new pjd(); + this.g = new pjd(); + b = a.g.b; + this.f = RD(mQb(Y2b(b), (yCc(), rAc)), 88); + this.e = Kfb(UD(k2b(b, ZBc))); + } + function onc(a) { + this.d = new bnb(); + this.e = new gub(); + this.c = $C(kE, Pwe, 28, (qpd(), cD(WC(E3, 1), NAe, 64, 0, [opd, Yod, Xod, npd, ppd])).length, 15, 1); + this.b = a; + } + function $pc(a, b, c2) { + var d; + d = c2[a.g][b]; + switch (a.g) { + case 1: + case 3: + return new rjd(0, d); + case 2: + case 4: + return new rjd(d, 0); + default: + return null; + } + } + function Ced(b, c2, d) { + var e, f2; + f2 = RD(ltd(c2.f), 205); + try { + f2.rf(b, d); + mtd(c2.f, f2); + } catch (a) { + a = zdb(a); + if (ZD(a, 103)) { + e = a; + throw Adb(e); + } else + throw Adb(a); + } + } + function tEd(a, b, c2) { + var d, e, f2, g, h, i2; + d = null; + h = vgd(ygd(), b); + f2 = null; + if (h) { + e = null; + i2 = zhd(h, c2); + g = null; + i2 != null && (g = a.qf(h, i2)); + e = g; + f2 = e; + } + d = f2; + return d; + } + function sSd(a, b, c2, d) { + var e; + e = a.length; + if (b >= e) + return e; + for (b = b > 0 ? b : 0; b < e; b++) { + if (zSd((BFb(b, a.length), a.charCodeAt(b)), c2, d)) + break; + } + return b; + } + function anb(a, b) { + var c2, d; + d = a.c.length; + b.length < d && (b = cFb(new Array(d), b)); + for (c2 = 0; c2 < d; ++c2) { + bD(b, c2, a.c[c2]); + } + b.length > d && bD(b, d, null); + return b; + } + function lob(a, b) { + var c2, d; + d = a.a.length; + b.length < d && (b = cFb(new Array(d), b)); + for (c2 = 0; c2 < d; ++c2) { + bD(b, c2, a.a[c2]); + } + b.length > d && bD(b, d, null); + return b; + } + function Bde(a, b) { + var c2, d; + ++a.j; + if (b != null) { + c2 = (d = a.a.Cb, ZD(d, 99) ? RD(d, 99).th() : null); + if (Jnb(b, c2)) { + $wd(a.a, 4, c2); + return; + } + } + $wd(a.a, 4, RD(b, 129)); + } + function mne(a) { + var b; + if (a == null) + return null; + b = Hqe(nue(a, true)); + if (b == null) { + throw Adb(new Mle("Invalid hexBinary value: '" + a + "'")); + } + return b; + } + function wA(a, b, c2) { + var d; + if (b.a.length > 0) { + Rmb(a.b, new kB(b.a, c2)); + d = b.a.length; + 0 < d ? b.a = zhb(b.a, 0, 0) : 0 > d && (b.a += Hhb($C(hE, zwe, 28, -d, 15, 1))); + } + } + function yIb(a, b, c2) { + var d, e, f2; + if (c2[b.d]) { + return; + } + c2[b.d] = true; + for (e = new Anb(CIb(b)); e.a < e.c.c.length; ) { + d = RD(ynb(e), 218); + f2 = oIb(d, b); + yIb(a, f2, c2); + } + } + function dub(a, b, c2) { + var d, e, f2; + e = RD(Wjb(a.e, b), 400); + if (!e) { + d = new uub(a, b, c2); + Zjb(a.e, b, d); + qub(d); + return null; + } else { + f2 = qlb(e, c2); + eub(a, e); + return f2; + } + } + function r5d(a, b, c2, d) { + var e, f2, g; + e = new P3d(a.e, 1, 13, (g = b.c, g ? g : (JTd(), wTd)), (f2 = c2.c, f2 ? f2 : (JTd(), wTd)), fZd(a, b), false); + !d ? d = e : d.nj(e); + return d; + } + function nMb() { + hMb(); + return cD(WC(XN, 1), jwe, 164, 0, [eMb, dMb, fMb, XLb, WLb, YLb, _Lb, $Lb, ZLb, cMb, bMb, aMb, ULb, TLb, VLb, RLb, QLb, SLb, OLb, NLb, PLb, gMb]); + } + function jWc(a) { + switch (a.g) { + case 4: + return new rjd(0, -1); + case 1: + return new rjd(1, 0); + case 2: + return new rjd(-1, 0); + default: + return new rjd(0, 1); + } + } + function f_b(a) { + switch (a.g) { + case 1: + return Cmd(), Bmd; + case 4: + return Cmd(), ymd; + case 2: + return Cmd(), zmd; + case 3: + return Cmd(), xmd; + } + return Cmd(), Amd; + } + function s$d(a) { + var b; + b = a.hj(null); + switch (b) { + case 10: + return 0; + case 15: + return 1; + case 14: + return 2; + case 11: + return 3; + case 21: + return 4; + } + return -1; + } + function Yhd() { + Yhd = geb; + Whd = new Zhd("PARENTS", 0); + Vhd = new Zhd("NODES", 1); + Thd = new Zhd("EDGES", 2); + Xhd = new Zhd("PORTS", 3); + Uhd = new Zhd("LABELS", 4); + } + function AA(a, b, c2) { + var d; + d = c2.q.getFullYear() - Owe + Owe; + d < 0 && (d = -d); + switch (b) { + case 1: + a.a += d; + break; + case 2: + UA(a, d % 100, 2); + break; + default: + UA(a, d, b); + } + } + function Sub(a, b) { + var c2, d; + wFb(b, a.b); + if (b >= a.b >> 1) { + d = a.c; + for (c2 = a.b; c2 > b; --c2) { + d = d.b; + } + } else { + d = a.a.a; + for (c2 = 0; c2 < b; ++c2) { + d = d.a; + } + } + return new hvb(a, b, d); + } + function DHb() { + DHb = geb; + CHb = new EHb("NUM_OF_EXTERNAL_SIDES_THAN_NUM_OF_EXTENSIONS_LAST", 0); + BHb = new EHb("CORNER_CASES_THAN_SINGLE_SIDE_LAST", 1); + } + function tnc(a) { + this.b = new bnb(); + this.e = new bnb(); + this.d = a; + this.a = !QDb(CDb(new SDb(null, new Twb(new l4b(a.b))), new PAb(new unc()))).Bd((xDb(), wDb)); + } + function ssc(a, b) { + var c2, d, e, f2; + c2 = 0; + for (e = new Anb(b.a); e.a < e.c.c.length; ) { + d = RD(ynb(e), 10); + f2 = d.o.a + d.d.c + d.d.b + a.j; + c2 = $wnd.Math.max(c2, f2); + } + return c2; + } + function OUc(a, b) { + var c2, d, e; + e = b.d.i; + d = e.k; + if (d == (r3b(), p3b) || d == l3b) { + return; + } + c2 = new is(Mr(a3b(e).a.Kc(), new ir())); + gs(c2) && Zjb(a.k, b, RD(hs(c2), 18)); + } + function O0c(a, b) { + B0c(); + return Qfb((a.a.b == 0 ? new rjd(a.c.e.a, a.c.e.b) : RD(Qub(a.a), 8)).b, (b.a.b == 0 ? new rjd(b.c.e.a, b.c.e.b) : RD(Qub(b.a), 8)).b); + } + function P0c(a, b) { + B0c(); + return Qfb((a.a.b == 0 ? new rjd(a.c.e.a, a.c.e.b) : RD(Qub(a.a), 8)).a, (b.a.b == 0 ? new rjd(b.c.e.a, b.c.e.b) : RD(Qub(b.a), 8)).a); + } + function S0c(a, b) { + B0c(); + return Qfb((a.a.b == 0 ? new rjd(a.b.e.a, a.b.e.b) : RD(Rub(a.a), 8)).a, (b.a.b == 0 ? new rjd(b.b.e.a, b.b.e.b) : RD(Rub(b.a), 8)).a); + } + function Q0c(a, b) { + B0c(); + return Qfb((a.a.b == 0 ? new rjd(a.b.e.a, a.b.e.b) : RD(Rub(a.a), 8)).b, (b.a.b == 0 ? new rjd(b.b.e.a, b.b.e.b) : RD(Rub(b.a), 8)).b); + } + function pod() { + pod = geb; + mod = new qod("DISTRIBUTED", 0); + ood = new qod("JUSTIFIED", 1); + kod = new qod("BEGIN", 2); + lod = new qod(Kye, 3); + nod = new qod("END", 4); + } + function Kvd(a, b) { + var c2, d, e; + d = vYd(a.Dh(), b); + c2 = b - a.ji(); + return c2 < 0 ? (e = a.Ih(d), e >= 0 ? a.Wh(e) : Rvd(a, d)) : c2 < 0 ? Rvd(a, d) : RD(d, 69).wk().Bk(a, a.hi(), c2); + } + function Fxd(a) { + var b, c2, d; + d = (!a.o && (a.o = new DVd((pvd(), mvd), X4, a, 0)), a.o); + for (c2 = d.c.Kc(); c2.e != c2.i.gc(); ) { + b = RD(c2.Yj(), 44); + b.md(); + } + return dOd(d); + } + function iGd(a) { + var b; + if (ZD(a.a, 4)) { + b = FId(a.a); + if (b == null) { + throw Adb(new dgb(HGe + a.b + "'. " + DGe + (lfb(b6), b6.k) + EGe)); + } + return b; + } else { + return a.a; + } + } + function iSd(a, b) { + var c2, d; + if (a.j.length != b.j.length) + return false; + for (c2 = 0, d = a.j.length; c2 < d; c2++) { + if (!lhb(a.j[c2], b.j[c2])) + return false; + } + return true; + } + function bMd(b) { + var c2; + try { + c2 = b.i.Xb(b.e); + b.Xj(); + b.g = b.e++; + return c2; + } catch (a) { + a = zdb(a); + if (ZD(a, 77)) { + b.Xj(); + throw Adb(new Dvb()); + } else + throw Adb(a); + } + } + function xMd(b) { + var c2; + try { + c2 = b.c.Vi(b.e); + b.Xj(); + b.g = b.e++; + return c2; + } catch (a) { + a = zdb(a); + if (ZD(a, 77)) { + b.Xj(); + throw Adb(new Dvb()); + } else + throw Adb(a); + } + } + function vSd(a) { + var b, c2, d, e; + e = 0; + for (c2 = 0, d = a.length; c2 < d; c2++) { + b = (BFb(c2, a.length), a.charCodeAt(c2)); + b >= 64 && b < 128 && (e = Rdb(e, Sdb(1, b - 64))); + } + return e; + } + function k2b(a, b) { + var c2, d; + d = null; + if (nQb(a, (umd(), amd))) { + c2 = RD(mQb(a, amd), 96); + c2.pf(b) && (d = c2.of(b)); + } + d == null && !!Y2b(a) && (d = mQb(Y2b(a), b)); + return d; + } + function i0b(a, b) { + var c2; + c2 = RD(mQb(a, (yCc(), RAc)), 75); + if (br(b, f0b)) { + if (!c2) { + c2 = new Ejd(); + pQb(a, RAc, c2); + } else { + Xub(c2); + } + } else + !!c2 && pQb(a, RAc, null); + return c2; + } + function tSb() { + tSb = geb; + sSb = (umd(), Yld); + mSb = Ukd; + hSb = Dkd; + nSb = tld; + qSb = (YHb(), UHb); + pSb = SHb; + rSb = WHb; + oSb = RHb; + jSb = (eSb(), aSb); + iSb = _Rb; + kSb = cSb; + lSb = dSb; + } + function PZb(a) { + NZb(); + this.c = new bnb(); + this.d = a; + switch (a.g) { + case 0: + case 2: + this.a = Fob(MZb); + this.b = oxe; + break; + case 3: + case 1: + this.a = MZb; + this.b = pxe; + } + } + function c9b(a) { + var b; + if (!Cod(RD(mQb(a, (yCc(), BBc)), 101))) { + return; + } + b = a.b; + d9b((tFb(0, b.c.length), RD(b.c[0], 30))); + d9b(RD(Vmb(b, b.c.length - 1), 30)); + } + function ohc(a, b) { + b.Ug("Self-Loop post-processing", 1); + FDb(CDb(CDb(EDb(new SDb(null, new Swb(a.b, 16)), new uhc()), new whc()), new yhc()), new Ahc()); + b.Vg(); + } + function xrd(a, b, c2) { + var d, e; + if (a.c) { + Dyd(a.c, a.c.i + b); + Eyd(a.c, a.c.j + c2); + } else { + for (e = new Anb(a.b); e.a < e.c.c.length; ) { + d = RD(ynb(e), 163); + xrd(d, b, c2); + } + } + } + function ine(a) { + var b; + if (a == null) + return null; + b = Aqe(nue(a, true)); + if (b == null) { + throw Adb(new Mle("Invalid base64Binary value: '" + a + "'")); + } + return b; + } + function ju(b, c2) { + var d; + d = b.fd(c2); + try { + return d.Pb(); + } catch (a) { + a = zdb(a); + if (ZD(a, 112)) { + throw Adb(new veb("Can't get element " + c2)); + } else + throw Adb(a); + } + } + function ANb(a, b) { + var c2, d, e; + c2 = a.o; + for (e = RD(RD(Qc(a.r, b), 21), 87).Kc(); e.Ob(); ) { + d = RD(e.Pb(), 117); + d.e.a = uNb(d, c2.a); + d.e.b = c2.b * Kfb(UD(d.b.of(sNb))); + } + } + function kdc(a, b) { + var c2, d, e; + e = new cnb(b.gc()); + for (d = b.Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 293); + c2.c == c2.f ? _cc(a, c2, c2.c) : adc(a, c2) || (ZEb(e.c, c2), true); + } + return e; + } + function i3b(a) { + var b; + b = new bib(); + b.a += "n"; + a.k != (r3b(), p3b) && Zhb(Zhb((b.a += "(", b), ps(a.k).toLowerCase()), ")"); + Zhb((b.a += "_", b), X2b(a)); + return b.a; + } + function h9b(a, b) { + var c2, d, e, f2; + e = a.k; + c2 = Kfb(UD(mQb(a, (Ywc(), Jwc)))); + f2 = b.k; + d = Kfb(UD(mQb(b, Jwc))); + return f2 != (r3b(), m3b) ? -1 : e != m3b ? 1 : c2 == d ? 0 : c2 < d ? -1 : 1; + } + function Lad(a, b) { + var c2, d; + c2 = RD(RD(Wjb(a.g, b.a), 42).a, 68); + d = RD(RD(Wjb(a.g, b.b), 42).a, 68); + return bjd(b.a, b.b) - bjd(b.a, Pid(c2.b)) - bjd(b.b, Pid(d.b)); + } + function GMb(a, b) { + var c2; + c2 = RD(Vrb(a.b, b), 127).n; + switch (b.g) { + case 1: + a.t >= 0 && (c2.d = a.t); + break; + case 3: + a.t >= 0 && (c2.a = a.t); + } + if (a.C) { + c2.b = a.C.b; + c2.c = a.C.c; + } + } + function JDc() { + JDc = geb; + IDc = new LDc(mEe, 0); + FDc = new LDc(BBe, 1); + GDc = new LDc("LINEAR_SEGMENTS", 2); + EDc = new LDc("BRANDES_KOEPF", 3); + HDc = new LDc(lEe, 4); + } + function IRb() { + IRb = geb; + FRb = new JRb(_ye, 0); + ERb = new JRb(aze, 1); + GRb = new JRb(bze, 2); + HRb = new JRb(cze, 3); + FRb.a = false; + ERb.a = true; + GRb.a = false; + HRb.a = true; + } + function IPb() { + IPb = geb; + FPb = new JPb(_ye, 0); + EPb = new JPb(aze, 1); + GPb = new JPb(bze, 2); + HPb = new JPb(cze, 3); + FPb.a = false; + EPb.a = true; + GPb.a = false; + HPb.a = true; + } + function Ivd(a, b, c2, d) { + var e; + if (c2 >= 0) { + return a.Sh(b, c2, d); + } else { + !!a.Ph() && (d = (e = a.Fh(), e >= 0 ? a.Ah(d) : a.Ph().Th(a, -1 - e, null, d))); + return a.Ch(b, c2, d); + } + } + function Zyd(a, b) { + switch (b) { + case 7: + !a.e && (a.e = new Yie(G4, a, 7, 4)); + sLd(a.e); + return; + case 8: + !a.d && (a.d = new Yie(G4, a, 8, 5)); + sLd(a.d); + return; + } + yyd(a, b); + } + function Ixd(a, b, c2) { + c2 == null ? (!a.o && (a.o = new DVd((pvd(), mvd), X4, a, 0)), jOd(a.o, b)) : (!a.o && (a.o = new DVd((pvd(), mvd), X4, a, 0)), fOd(a.o, b, c2)); + return a; + } + function Aob(a, b) { + yob(); + var c2, d, e, f2; + c2 = a; + f2 = b; + if (ZD(a, 21) && !ZD(b, 21)) { + c2 = b; + f2 = a; + } + for (e = c2.Kc(); e.Ob(); ) { + d = e.Pb(); + if (f2.Hc(d)) { + return false; + } + } + return true; + } + function qTc(a, b, c2, d) { + if (b.a < d.a) { + return true; + } else if (b.a == d.a) { + if (b.b < d.b) { + return true; + } else if (b.b == d.b) { + if (a.b > c2.b) { + return true; + } + } + } + return false; + } + function QD(a, b) { + if (bE(a)) { + return !!PD[b]; + } else if (a.Sm) { + return !!a.Sm[b]; + } else if (_D(a)) { + return !!OD[b]; + } else if ($D(a)) { + return !!ND[b]; + } + return false; + } + function udc(a) { + var b; + b = a.a; + do { + b = RD(hs(new is(Mr(Z2b(b).a.Kc(), new ir()))), 18).c.i; + b.k == (r3b(), o3b) && a.b.Fc(b); + } while (b.k == (r3b(), o3b)); + a.b = hv(a.b); + } + function UGc(a, b) { + var c2, d, e; + e = a; + for (d = new is(Mr(Z2b(b).a.Kc(), new ir())); gs(d); ) { + c2 = RD(hs(d), 18); + !!c2.c.i.c && (e = $wnd.Math.max(e, c2.c.i.c.p)); + } + return e; + } + function INb(a, b) { + var c2, d, e; + e = 0; + d = RD(RD(Qc(a.r, b), 21), 87).Kc(); + while (d.Ob()) { + c2 = RD(d.Pb(), 117); + e += c2.d.d + c2.b.Mf().b + c2.d.a; + d.Ob() && (e += a.w); + } + return e; + } + function AMb(a, b) { + var c2, d, e; + e = 0; + d = RD(RD(Qc(a.r, b), 21), 87).Kc(); + while (d.Ob()) { + c2 = RD(d.Pb(), 117); + e += c2.d.b + c2.b.Mf().a + c2.d.c; + d.Ob() && (e += a.w); + } + return e; + } + function O2c(a) { + var b, c2, d, e; + d = 0; + e = Q2c(a); + if (e.c.length == 0) { + return 1; + } else { + for (c2 = new Anb(e); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 27); + d += O2c(b); + } + } + return d; + } + function aIc(a) { + var b, c2, d; + d = a.c.a; + a.p = (Qb(d), new dnb(d)); + for (c2 = new Anb(d); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 10); + b.p = eIc(b).a; + } + yob(); + _mb(a.p, new nIc()); + } + function UJd(a, b, c2) { + var d, e, f2, g; + d = a.dd(b); + if (d != -1) { + if (a.Pj()) { + f2 = a.Qj(); + g = cJd(a, d); + e = a.Ij(4, g, null, d, f2); + !c2 ? c2 = e : c2.nj(e); + } else { + cJd(a, d); + } + } + return c2; + } + function rLd(a, b, c2) { + var d, e, f2, g; + d = a.dd(b); + if (d != -1) { + if (a.Pj()) { + f2 = a.Qj(); + g = THd(a, d); + e = a.Ij(4, g, null, d, f2); + !c2 ? c2 = e : c2.nj(e); + } else { + THd(a, d); + } + } + return c2; + } + function Tje(a, b, c2, d) { + var e, f2, g; + if (c2.Xh(b)) { + nke(); + if (wWd(b)) { + e = RD(c2.Mh(b), 160); + Wje(a, e); + } else { + f2 = (g = b, !g ? null : RD(d, 54).gi(g)); + !!f2 && Uje(c2.Mh(b), f2); + } + } + } + function Dvd(a, b, c2, d) { + var e, f2, g; + f2 = vYd(a.Dh(), b); + e = b - a.ji(); + return e < 0 ? (g = a.Ih(f2), g >= 0 ? a.Lh(g, c2, true) : Qvd(a, f2, c2)) : RD(f2, 69).wk().yk(a, a.hi(), e, c2, d); + } + function aNb(a, b, c2, d) { + var e, f2; + f2 = b.pf((umd(), ild)) ? RD(b.of(ild), 21) : a.j; + e = lMb(f2); + if (e == (hMb(), gMb)) { + return; + } + if (c2 && !jMb(e)) { + return; + } + LKb(cNb(a, e, d), b); + } + function Y6b(a) { + switch (a.g) { + case 1: + return mOb(), lOb; + case 3: + return mOb(), iOb; + case 2: + return mOb(), kOb; + case 4: + return mOb(), jOb; + default: + return null; + } + } + function kmc(a, b, c2) { + if (a.e) { + switch (a.b) { + case 1: + Ulc(a.c, b, c2); + break; + case 0: + Vlc(a.c, b, c2); + } + } else { + Slc(a.c, b, c2); + } + a.a[b.p][c2.p] = a.c.i; + a.a[c2.p][b.p] = a.c.e; + } + function LLc(a) { + var b, c2; + if (a == null) { + return null; + } + c2 = $C(jR, Nve, 199, a.length, 0, 2); + for (b = 0; b < c2.length; b++) { + c2[b] = RD(Gnb(a[b], a[b].length), 199); + } + return c2; + } + function Dhe(a) { + var b; + if (Bhe(a)) { + Ahe(a); + if (a.ul()) { + b = Bge(a.e, a.b, a.c, a.a, a.j); + a.j = b; + } + a.g = a.a; + ++a.a; + ++a.c; + a.i = 0; + return a.j; + } else { + throw Adb(new Dvb()); + } + } + function YOb(a, b) { + var c2, d, e, f2; + f2 = a.o; + c2 = a.p; + f2 < c2 ? f2 *= f2 : c2 *= c2; + d = f2 + c2; + f2 = b.o; + c2 = b.p; + f2 < c2 ? f2 *= f2 : c2 *= c2; + e = f2 + c2; + if (d < e) { + return -1; + } + if (d == e) { + return 0; + } + return 1; + } + function fZd(a, b) { + var c2, d, e; + e = RHd(a, b); + if (e >= 0) + return e; + if (a.ol()) { + for (d = 0; d < a.i; ++d) { + c2 = a.pl(RD(a.g[d], 58)); + if (dE(c2) === dE(b)) { + return d; + } + } + } + return -1; + } + function eHd(a, b, c2) { + var d, e; + e = a.gc(); + if (b >= e) + throw Adb(new aMd(b, e)); + if (a.Si()) { + d = a.dd(c2); + if (d >= 0 && d != b) { + throw Adb(new agb(LIe)); + } + } + return a.Xi(b, c2); + } + function wx(a, b) { + this.a = RD(Qb(a), 253); + this.b = RD(Qb(b), 253); + if (a.Ed(b) > 0 || a == (Wk(), Vk) || b == (kl(), jl)) { + throw Adb(new agb("Invalid range: " + Dx(a, b))); + } + } + function p_b(a) { + var b, c2; + this.b = new bnb(); + this.c = a; + this.a = false; + for (c2 = new Anb(a.a); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 10); + this.a = this.a | b.k == (r3b(), p3b); + } + } + function xIb(a, b) { + var c2, d, e; + c2 = eJb(new gJb(), a); + for (e = new Anb(b); e.a < e.c.c.length; ) { + d = RD(ynb(e), 125); + rIb(uIb(tIb(vIb(sIb(new wIb(), 0), 0), c2), d)); + } + return c2; + } + function y0b(a, b, c2) { + c2.Ug("Compound graph preprocessor", 1); + a.a = new Tp(); + D0b(a, b, null); + x0b(a, b); + C0b(a); + pQb(b, (Ywc(), _vc), a.a); + a.a = null; + akb(a.b); + c2.Vg(); + } + function aec(a, b, c2) { + var d, e, f2; + for (e = new is(Mr((b ? Z2b(a) : a3b(a)).a.Kc(), new ir())); gs(e); ) { + d = RD(hs(e), 18); + f2 = b ? d.c.i : d.d.i; + f2.k == (r3b(), n3b) && g3b(f2, c2); + } + } + function FZc(a, b) { + var c2, d, e; + b.Ug("Untreeify", 1); + c2 = RD(mQb(a, (q$c(), k$c)), 15); + for (e = c2.Kc(); e.Ob(); ) { + d = RD(e.Pb(), 65); + Mub(d.b.d, d); + Mub(d.c.b, d); + } + b.Vg(); + } + function Znc(a) { + var b, c2, d; + for (d = RD(Qc(a.a, (Bnc(), znc)), 15).Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 105); + b = foc(c2); + Qnc(a, c2, b[0], (joc(), goc), 0); + Qnc(a, c2, b[1], ioc, 1); + } + } + function $nc(a) { + var b, c2, d; + for (d = RD(Qc(a.a, (Bnc(), Anc)), 15).Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 105); + b = foc(c2); + Qnc(a, c2, b[0], (joc(), goc), 0); + Qnc(a, c2, b[1], ioc, 1); + } + } + function wDc() { + wDc = geb; + uDc = new yDc(LAe, 0); + vDc = new yDc("PORT_POSITION", 1); + tDc = new yDc("NODE_SIZE_WHERE_SPACE_PERMITS", 2); + sDc = new yDc("NODE_SIZE", 3); + } + function z6c() { + z6c = geb; + w6c = new A6c("INTERACTIVE_NODE_REORDERER", 0); + y6c = new A6c("MIN_SIZE_PRE_PROCESSOR", 1); + x6c = new A6c("MIN_SIZE_POST_PROCESSOR", 2); + } + function Rjd() { + Rjd = geb; + Ljd = new Sjd("AUTOMATIC", 0); + Ojd = new Sjd(Nye, 1); + Pjd = new Sjd(Oye, 2); + Qjd = new Sjd("TOP", 3); + Mjd = new Sjd(Qye, 4); + Njd = new Sjd(Kye, 5); + } + function Pjb(a, b, c2, d) { + Ljb(); + var e, f2; + e = 0; + for (f2 = 0; f2 < c2; f2++) { + e = Bdb(Ndb(Cdb(b[f2], yxe), Cdb(d, yxe)), Cdb(Ydb(e), yxe)); + a[f2] = Ydb(e); + e = Udb(e, 32); + } + return Ydb(e); + } + function qKb(a, b, c2) { + var d, e; + e = 0; + for (d = 0; d < iKb; d++) { + e = $wnd.Math.max(e, gKb(a.a[b.g][d], c2)); + } + b == (ZJb(), XJb) && !!a.b && (e = $wnd.Math.max(e, a.b.b)); + return e; + } + function Jwb(a, b) { + var c2, d; + lFb(b > 0); + if ((b & -b) == b) { + return eE(b * Kwb(a, 31) * 4656612873077393e-25); + } + do { + c2 = Kwb(a, 31); + d = c2 % b; + } while (c2 - d + (b - 1) < 0); + return eE(d); + } + function d2b(a, b, c2) { + switch (c2.g) { + case 1: + a.a = b.a / 2; + a.b = 0; + break; + case 2: + a.a = b.a; + a.b = b.b / 2; + break; + case 3: + a.a = b.a / 2; + a.b = b.b; + break; + case 4: + a.a = 0; + a.b = b.b / 2; + } + } + function Onc(a, b, c2, d) { + var e, f2; + for (e = b; e < a.c.length; e++) { + f2 = (tFb(e, a.c.length), RD(a.c[e], 12)); + if (c2.Mb(f2)) { + ZEb(d.c, f2); + } else { + return e; + } + } + return a.c.length; + } + function u5c(a) { + switch (a.g) { + case 0: + return null; + case 1: + return new _5c(); + case 2: + return new R5c(); + default: + throw Adb(new agb(mFe + (a.f != null ? a.f : "" + a.g))); + } + } + function U9c(a, b, c2) { + var d, e; + L9c(a, b - a.s, c2 - a.t); + for (e = new Anb(a.n); e.a < e.c.c.length; ) { + d = RD(ynb(e), 209); + Y9c(d, d.e + b - a.s); + Z9c(d, d.f + c2 - a.t); + } + a.s = b; + a.t = c2; + } + function AIb(a) { + var b, c2, d, e, f2; + c2 = 0; + for (e = new Anb(a.a); e.a < e.c.c.length; ) { + d = RD(ynb(e), 125); + d.d = c2++; + } + b = zIb(a); + f2 = null; + b.c.length > 1 && (f2 = xIb(a, b)); + return f2; + } + function yqd(a) { + var b; + b = Kfb(UD(Gxd(a, (umd(), lmd)))) * $wnd.Math.sqrt((!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a).i); + return new rjd(b, b / Kfb(UD(Gxd(a, kmd)))); + } + function Dzd(a) { + var b; + if (!!a.f && a.f.Vh()) { + b = RD(a.f, 54); + a.f = RD(Vvd(a, b), 84); + a.f != b && (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 9, 8, b, a.f)); + } + return a.f; + } + function Ezd(a) { + var b; + if (!!a.i && a.i.Vh()) { + b = RD(a.i, 54); + a.i = RD(Vvd(a, b), 84); + a.i != b && (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 9, 7, b, a.i)); + } + return a.i; + } + function Z5d(a) { + var b; + if (!!a.b && (a.b.Db & 64) != 0) { + b = a.b; + a.b = RD(Vvd(a, b), 19); + a.b != b && (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 9, 21, b, a.b)); + } + return a.b; + } + function UNd(a, b) { + var c2, d, e; + if (a.d == null) { + ++a.e; + ++a.f; + } else { + d = b.Bi(); + _Nd(a, a.f + 1); + e = (d & lve) % a.d.length; + c2 = a.d[e]; + !c2 && (c2 = a.d[e] = a.dk()); + c2.Fc(b); + ++a.f; + } + } + function Mge(a, b, c2) { + var d; + if (b.tk()) { + return false; + } else if (b.Ik() != -2) { + d = b.ik(); + return d == null ? c2 == null : pb(d, c2); + } else + return b.qk() == a.e.Dh() && c2 == null; + } + function Io() { + var a; + dk(16, fwe); + a = Wp(16); + this.b = $C(XF, ewe, 303, a, 0, 1); + this.c = $C(XF, ewe, 303, a, 0, 1); + this.a = null; + this.e = null; + this.i = 0; + this.f = a - 1; + this.g = 0; + } + function j3b(a) { + v2b.call(this); + this.k = (r3b(), p3b); + this.j = (dk(6, iwe), new cnb(6)); + this.b = (dk(2, iwe), new cnb(2)); + this.d = new T2b(); + this.f = new C3b(); + this.a = a; + } + function wgc(a) { + var b, c2; + if (a.c.length <= 1) { + return; + } + b = tgc(a, (qpd(), npd)); + vgc(a, RD(b.a, 17).a, RD(b.b, 17).a); + c2 = tgc(a, ppd); + vgc(a, RD(c2.a, 17).a, RD(c2.b, 17).a); + } + function vHc(a, b, c2) { + var d, e; + e = a.a.b; + for (d = e.c.length; d < c2; d++) { + Qmb(e, e.c.length, new R4b(a.a)); + } + g3b(b, (tFb(c2 - 1, e.c.length), RD(e.c[c2 - 1], 30))); + a.b[b.p] = c2; + } + function K_c(a, b) { + var c2, d, e; + a.b[b.g] = 1; + for (d = Sub(b.d, 0); d.b != d.d.c; ) { + c2 = RD(evb(d), 65); + e = c2.c; + a.b[e.g] == 1 ? Mub(a.a, c2) : a.b[e.g] == 2 ? a.b[e.g] = 1 : K_c(a, e); + } + } + function u3c(a, b, c2, d) { + var e, f2, g; + e = d ? RD(Qc(a.a, b), 21) : RD(Qc(a.b, b), 21); + for (g = e.Kc(); g.Ob(); ) { + f2 = RD(g.Pb(), 27); + if (o3c(a, c2, f2)) { + return true; + } + } + return false; + } + function d$d(a) { + var b, c2; + for (c2 = new dMd(a); c2.e != c2.i.gc(); ) { + b = RD(bMd(c2), 89); + if (!!b.e || (!b.d && (b.d = new XZd(o7, b, 1)), b.d).i != 0) { + return true; + } + } + return false; + } + function o5d(a) { + var b, c2; + for (c2 = new dMd(a); c2.e != c2.i.gc(); ) { + b = RD(bMd(c2), 89); + if (!!b.e || (!b.d && (b.d = new XZd(o7, b, 1)), b.d).i != 0) { + return true; + } + } + return false; + } + function dIc(a) { + var b, c2, d; + b = 0; + for (d = new Anb(a.c.a); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 10); + b += Kr(new is(Mr(a3b(c2).a.Kc(), new ir()))); + } + return b / a.c.a.c.length; + } + function Tcd() { + Tcd = geb; + Scd = (Kcd(), Jcd); + Qcd = new A3b(8); + new mGd((umd(), tld), Qcd); + new mGd(fmd, 8); + Rcd = Hcd; + Ocd = xcd; + Pcd = ycd; + Ncd = new mGd(Mkd, (Geb(), false)); + } + function $dd(a, b, c2) { + var d; + c2.Ug("Shrinking tree compaction", 1); + if (Heb(TD(mQb(b, (OQb(), MQb))))) { + Ydd(a, b.f); + zQb(b.f, (d = b.c, d)); + } else { + zQb(b.f, b.c); + } + c2.Vg(); + } + function Uyd(a, b, c2, d) { + switch (b) { + case 7: + return !a.e && (a.e = new Yie(G4, a, 7, 4)), a.e; + case 8: + return !a.d && (a.d = new Yie(G4, a, 8, 5)), a.d; + } + return vyd(a, b, c2, d); + } + function h2d(a) { + var b; + if (!!a.a && a.a.Vh()) { + b = RD(a.a, 54); + a.a = RD(Vvd(a, b), 142); + a.a != b && (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 9, 5, b, a.a)); + } + return a.a; + } + function Xqe(a) { + if (a < 48) + return -1; + if (a > 102) + return -1; + if (a <= 57) + return a - 48; + if (a < 65) + return -1; + if (a <= 70) + return a - 65 + 10; + if (a < 97) + return -1; + return a - 97 + 10; + } + function ck(a, b) { + if (a == null) { + throw Adb(new Ogb("null key in entry: null=" + b)); + } else if (b == null) { + throw Adb(new Ogb("null value in entry: " + a + "=null")); + } + } + function Cr(a, b) { + var c2, d; + while (a.Ob()) { + if (!b.Ob()) { + return false; + } + c2 = a.Pb(); + d = b.Pb(); + if (!(dE(c2) === dE(d) || c2 != null && pb(c2, d))) { + return false; + } + } + return !b.Ob(); + } + function aLb(a, b) { + var c2; + c2 = cD(WC(iE, 1), vxe, 28, 15, [gKb(a.a[0], b), gKb(a.a[1], b), gKb(a.a[2], b)]); + if (a.d) { + c2[0] = $wnd.Math.max(c2[0], c2[2]); + c2[2] = c2[0]; + } + return c2; + } + function bLb(a, b) { + var c2; + c2 = cD(WC(iE, 1), vxe, 28, 15, [hKb(a.a[0], b), hKb(a.a[1], b), hKb(a.a[2], b)]); + if (a.d) { + c2[0] = $wnd.Math.max(c2[0], c2[2]); + c2[2] = c2[0]; + } + return c2; + } + function vIc(a, b, c2) { + if (!Cod(RD(mQb(b, (yCc(), BBc)), 101))) { + uIc(a, b, e3b(b, c2)); + uIc(a, b, e3b(b, (qpd(), npd))); + uIc(a, b, e3b(b, Yod)); + yob(); + _mb(b.j, new JIc(a)); + } + } + function sUc(a) { + var b, c2; + a.c || vUc(a); + c2 = new Ejd(); + b = new Anb(a.a); + ynb(b); + while (b.a < b.c.c.length) { + Mub(c2, RD(ynb(b), 418).a); + } + sFb(c2.b != 0); + Wub(c2, c2.c.b); + return c2; + } + function O9c(a, b, c2) { + var d, e, f2, g, h; + h = a.r + b; + a.r += b; + a.d += c2; + d = c2 / a.n.c.length; + e = 0; + for (g = new Anb(a.n); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 209); + X9c(f2, h, d, e); + ++e; + } + } + function kHb(a) { + var b, c2, d; + a.b.a.$b(); + a.a = $C(hN, rve, 60, a.c.c.a.b.c.length, 0, 1); + b = 0; + for (d = new Anb(a.c.c.a.b); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 60); + c2.f = b++; + } + } + function TYb(a) { + var b, c2, d; + a.b.a.$b(); + a.a = $C(bQ, rve, 86, a.c.a.a.b.c.length, 0, 1); + b = 0; + for (d = new Anb(a.c.a.a.b); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 86); + c2.i = b++; + } + } + function Er(a) { + var b; + b = yr(a); + if (!gs(a)) { + throw Adb(new veb("position (0) must be less than the number of elements that remained (" + b + ")")); + } + return hs(a); + } + function ZCb(a, b) { + var c2; + if (!a.a) { + c2 = $C(iE, vxe, 28, 0, 15, 1); + ixb(a.b.a, new bDb(c2)); + bFb(c2, heb(iob.prototype.Me, iob, [])); + a.a = new Lxb(c2, a.d); + } + return zxb(a.a, b); + } + function $Pb(b, c2, d) { + var e; + try { + return PPb(b, c2 + b.j, d + b.k); + } catch (a) { + a = zdb(a); + if (ZD(a, 77)) { + e = a; + throw Adb(new veb(e.g + ize + c2 + pve + d + ").")); + } else + throw Adb(a); + } + } + function _Pb(b, c2, d) { + var e; + try { + return QPb(b, c2 + b.j, d + b.k); + } catch (a) { + a = zdb(a); + if (ZD(a, 77)) { + e = a; + throw Adb(new veb(e.g + ize + c2 + pve + d + ").")); + } else + throw Adb(a); + } + } + function aQb(b, c2, d) { + var e; + try { + return RPb(b, c2 + b.j, d + b.k); + } catch (a) { + a = zdb(a); + if (ZD(a, 77)) { + e = a; + throw Adb(new veb(e.g + ize + c2 + pve + d + ").")); + } else + throw Adb(a); + } + } + function J8b(a) { + switch (a.g) { + case 1: + return qpd(), ppd; + case 4: + return qpd(), Yod; + case 3: + return qpd(), Xod; + case 2: + return qpd(), npd; + default: + return qpd(), opd; + } + } + function Imc(a, b, c2) { + if (b.k == (r3b(), p3b) && c2.k == o3b) { + a.d = Fmc(b, (qpd(), npd)); + a.b = Fmc(b, Yod); + } + if (c2.k == p3b && b.k == o3b) { + a.d = Fmc(c2, (qpd(), Yod)); + a.b = Fmc(c2, npd); + } + } + function Mmc(a, b) { + var c2, d, e; + e = b3b(a, b); + for (d = e.Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 12); + if (mQb(c2, (Ywc(), Iwc)) != null || k4b(new l4b(c2.b))) { + return true; + } + } + return false; + } + function RNc(a, b, c2) { + c2.Ug("Linear segments node placement", 1); + a.b = RD(mQb(b, (Ywc(), Qwc)), 312); + SNc(a, b); + NNc(a, b); + KNc(a, b); + QNc(a); + a.a = null; + a.b = null; + c2.Vg(); + } + function W9c(a, b) { + Dyd(b, a.e + a.d + (a.c.c.length == 0 ? 0 : a.b)); + Eyd(b, a.f); + a.a = $wnd.Math.max(a.a, b.f); + a.d += b.g + (a.c.c.length == 0 ? 0 : a.b); + Rmb(a.c, b); + return true; + } + function bad(a, b, c2) { + var d, e, f2, g; + g = 0; + d = c2 / a.a.c.length; + for (f2 = new Anb(a.a); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 172); + U9c(e, e.s, e.t + g * d); + O9c(e, a.d - e.r + b, d); + ++g; + } + } + function Cid(a, b) { + var c2, d, e, f2, g, h; + e = b.length - 1; + g = 0; + h = 0; + for (d = 0; d <= e; d++) { + f2 = b[d]; + c2 = vid(e, d) * Iid(1 - a, e - d) * Iid(a, d); + g += f2.a * c2; + h += f2.b * c2; + } + return new rjd(g, h); + } + function JHd(a, b) { + var c2, d, e, f2, g; + c2 = b.gc(); + a._i(a.i + c2); + f2 = b.Kc(); + g = a.i; + a.i += c2; + for (d = g; d < a.i; ++d) { + e = f2.Pb(); + MHd(a, d, a.Zi(d, e)); + a.Mi(d, e); + a.Ni(); + } + return c2 != 0; + } + function TJd(a, b, c2) { + var d, e, f2; + if (a.Pj()) { + d = a.Ej(); + f2 = a.Qj(); + ++a.j; + a.qj(d, a.Zi(d, b)); + e = a.Ij(3, null, b, d, f2); + !c2 ? c2 = e : c2.nj(e); + } else { + $Id(a, a.Ej(), b); + } + return c2; + } + function u0d(a, b, c2) { + var d, e, f2; + d = RD(QHd(tYd(a.a), b), 89); + f2 = (e = d.c, ZD(e, 90) ? RD(e, 29) : (JTd(), zTd)); + ((f2.Db & 64) != 0 ? Vvd(a.b, f2) : f2) == c2 ? i2d(d) : l2d(d, c2); + return f2; + } + function pne(a) { + var b; + return a == null ? null : new ejb((b = nue(a, true), b.length > 0 && (BFb(0, b.length), b.charCodeAt(0) == 43) ? (BFb(1, b.length + 1), b.substr(1)) : b)); + } + function qne(a) { + var b; + return a == null ? null : new ejb((b = nue(a, true), b.length > 0 && (BFb(0, b.length), b.charCodeAt(0) == 43) ? (BFb(1, b.length + 1), b.substr(1)) : b)); + } + function Syb(a, b, c2, d, e, f2, g, h) { + var i2, j; + if (!d) { + return; + } + i2 = d.a[0]; + !!i2 && Syb(a, b, c2, i2, e, f2, g, h); + Tyb(a, c2, d.d, e, f2, g, h) && b.Fc(d); + j = d.a[1]; + !!j && Syb(a, b, c2, j, e, f2, g, h); + } + function PPb(b, c2, d) { + try { + return Gdb(SPb(b, c2, d), 1); + } catch (a) { + a = zdb(a); + if (ZD(a, 333)) { + throw Adb(new veb(fze + b.o + "*" + b.p + gze + c2 + pve + d + hze)); + } else + throw Adb(a); + } + } + function QPb(b, c2, d) { + try { + return Gdb(SPb(b, c2, d), 0); + } catch (a) { + a = zdb(a); + if (ZD(a, 333)) { + throw Adb(new veb(fze + b.o + "*" + b.p + gze + c2 + pve + d + hze)); + } else + throw Adb(a); + } + } + function RPb(b, c2, d) { + try { + return Gdb(SPb(b, c2, d), 2); + } catch (a) { + a = zdb(a); + if (ZD(a, 333)) { + throw Adb(new veb(fze + b.o + "*" + b.p + gze + c2 + pve + d + hze)); + } else + throw Adb(a); + } + } + function lMd(b, c2) { + if (b.g == -1) { + throw Adb(new cgb()); + } + b.Xj(); + try { + b.d.hd(b.g, c2); + b.f = b.d.j; + } catch (a) { + a = zdb(a); + if (ZD(a, 77)) { + throw Adb(new Jrb()); + } else + throw Adb(a); + } + } + function Y7b(a) { + var b, c2, d, e, f2; + for (d = new Anb(a.b); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 30); + b = 0; + for (f2 = new Anb(c2.a); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 10); + e.p = b++; + } + } + } + function Ee(a, b) { + var c2, d, e, f2; + f2 = a.gc(); + b.length < f2 && (b = cFb(new Array(f2), b)); + e = b; + d = a.Kc(); + for (c2 = 0; c2 < f2; ++c2) { + bD(e, c2, d.Pb()); + } + b.length > f2 && bD(b, f2, null); + return b; + } + function av(a, b) { + var c2, d; + d = a.gc(); + if (b == null) { + for (c2 = 0; c2 < d; c2++) { + if (a.Xb(c2) == null) { + return c2; + } + } + } else { + for (c2 = 0; c2 < d; c2++) { + if (pb(b, a.Xb(c2))) { + return c2; + } + } + } + return -1; + } + function Jd(a, b) { + var c2, d, e; + c2 = b.ld(); + e = b.md(); + d = a.xc(c2); + if (!(dE(e) === dE(d) || e != null && pb(e, d))) { + return false; + } + if (d == null && !a._b(c2)) { + return false; + } + return true; + } + function mD(a, b) { + var c2, d, e; + if (b <= 22) { + c2 = a.l & (1 << b) - 1; + d = e = 0; + } else if (b <= 44) { + c2 = a.l; + d = a.m & (1 << b - 22) - 1; + e = 0; + } else { + c2 = a.l; + d = a.m; + e = a.h & (1 << b - 44) - 1; + } + return hD(c2, d, e); + } + function pNb(a, b) { + switch (b.g) { + case 1: + return a.f.n.d + a.t; + case 3: + return a.f.n.a + a.t; + case 2: + return a.f.n.c + a.s; + case 4: + return a.f.n.b + a.s; + default: + return 0; + } + } + function TNb(a, b) { + var c2, d; + d = b.c; + c2 = b.a; + switch (a.b.g) { + case 0: + c2.d = a.e - d.a - d.d; + break; + case 1: + c2.d += a.e; + break; + case 2: + c2.c = a.e - d.a - d.d; + break; + case 3: + c2.c = a.e + d.d; + } + } + function QRb(a, b, c2, d) { + var e, f2; + this.a = b; + this.c = d; + e = a.a; + PRb(this, new rjd(-e.c, -e.d)); + $id(this.b, c2); + f2 = d / 2; + b.a ? njd(this.b, 0, f2) : njd(this.b, f2, 0); + Rmb(a.c, this); + } + function i2c(a, b, c2, d) { + var e; + this.c = a; + this.d = b; + e = new Yub(); + Pub(e, c2, e.c.b, e.c); + this.a = e; + this.b = RD(mQb(d, (h_c(), H$c)), 88); + this.e = Kfb(UD(mQb(d, $$c))); + h2c(this); + } + function j5c() { + j5c = geb; + i5c = new l5c(LAe, 0); + g5c = new l5c(EBe, 1); + h5c = new l5c("EDGE_LENGTH_BY_POSITION", 2); + f5c = new l5c("CROSSING_MINIMIZATION_BY_POSITION", 3); + } + function uEd(a, b) { + var c2, d; + c2 = RD(Ao(a.g, b), 27); + if (c2) { + return c2; + } + d = RD(Ao(a.j, b), 123); + if (d) { + return d; + } + throw Adb(new CDd("Referenced shape does not exist: " + b)); + } + function Pk(b, c2) { + var d, e; + if (ZD(c2, 253)) { + e = RD(c2, 253); + try { + d = b.Ed(e); + return d == 0; + } catch (a) { + a = zdb(a); + if (ZD(a, 212)) { + return false; + } else + throw Adb(a); + } + } + return false; + } + function tWb(a, b) { + if (a.c == b) { + return a.d; + } else if (a.d == b) { + return a.c; + } else { + throw Adb(new agb("Node 'one' must be either source or target of edge 'edge'.")); + } + } + function rRc(a, b) { + if (a.c.i == b) { + return a.d.i; + } else if (a.d.i == b) { + return a.c.i; + } else { + throw Adb(new agb("Node " + b + " is neither source nor target of edge " + a)); + } + } + function $gc(a, b, c2) { + c2.Ug("Self-Loop ordering", 1); + FDb(GDb(CDb(CDb(EDb(new SDb(null, new Swb(b.b, 16)), new chc()), new ehc()), new ghc()), new ihc()), new khc(a)); + c2.Vg(); + } + function Fpc(a, b) { + var c2; + switch (b.g) { + case 2: + case 4: + c2 = a.a; + a.c.d.n.b < c2.d.n.b && (c2 = a.c); + Gpc(a, b, (enc(), dnc), c2); + break; + case 1: + case 3: + Gpc(a, b, (enc(), anc), null); + } + } + function Ypc(a, b, c2, d, e, f2) { + var g, h, i2, j, k; + g = Wpc(b, c2, f2); + h = c2 == (qpd(), Yod) || c2 == ppd ? -1 : 1; + j = a[c2.g]; + for (k = 0; k < j.length; k++) { + i2 = j[k]; + i2 > 0 && (i2 += e); + j[k] = g; + g += h * (i2 + d); + } + } + function vsc(a) { + var b, c2, d; + d = a.f; + a.n = $C(iE, vxe, 28, d, 15, 1); + a.d = $C(iE, vxe, 28, d, 15, 1); + for (b = 0; b < d; b++) { + c2 = RD(Vmb(a.c.b, b), 30); + a.n[b] = ssc(a, c2); + a.d[b] = rsc(a, c2); + } + } + function Xwd(a, b) { + var c2, d, e; + e = 0; + for (d = 2; d < b; d <<= 1) { + (a.Db & d) != 0 && ++e; + } + if (e == 0) { + for (c2 = b <<= 1; c2 <= 128; c2 <<= 1) { + if ((a.Db & c2) != 0) { + return 0; + } + } + return -1; + } else { + return e; + } + } + function Sge(a, b) { + var c2, d, e, f2, g; + g = pke(a.e.Dh(), b); + f2 = null; + c2 = RD(a.g, 124); + for (e = 0; e < a.i; ++e) { + d = c2[e]; + if (g.am(d.Lk())) { + !f2 && (f2 = new YHd()); + WGd(f2, d); + } + } + !!f2 && wLd(a, f2); + } + function ene(a) { + var b, c2, d; + if (!a) + return null; + if (a.dc()) + return ""; + d = new Qhb(); + for (c2 = a.Kc(); c2.Ob(); ) { + b = c2.Pb(); + Nhb(d, WD(b)); + d.a += " "; + } + return qeb(d, d.a.length - 1); + } + function _C(a, b) { + var c2 = new Array(b); + var d; + switch (a) { + case 14: + case 15: + d = 0; + break; + case 16: + d = false; + break; + default: + return c2; + } + for (var e = 0; e < b; ++e) { + c2[e] = d; + } + return c2; + } + function GGb(a) { + var b, c2, d; + for (c2 = new Anb(a.a.b); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 60); + b.c.$b(); + } + Dmd(a.d) ? d = a.a.c : d = a.a.d; + Umb(d, new WGb(a)); + a.c.df(a); + HGb(a); + } + function oUb(a) { + var b, c2, d, e; + for (c2 = new Anb(a.e.c); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 290); + for (e = new Anb(b.b); e.a < e.c.c.length; ) { + d = RD(ynb(e), 454); + hUb(d); + } + YTb(b); + } + } + function gad(a) { + var b, c2, d, e, f2; + d = 0; + f2 = 0; + e = 0; + for (c2 = new Anb(a.a); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 172); + f2 = $wnd.Math.max(f2, b.r); + d += b.d + (e > 0 ? a.c : 0); + ++e; + } + a.b = d; + a.d = f2; + } + function rKb(a, b) { + var c2; + c2 = cD(WC(iE, 1), vxe, 28, 15, [qKb(a, (ZJb(), WJb), b), qKb(a, XJb, b), qKb(a, YJb, b)]); + if (a.f) { + c2[0] = $wnd.Math.max(c2[0], c2[2]); + c2[2] = c2[0]; + } + return c2; + } + function cQb(b, c2, d) { + var e; + try { + TPb(b, c2 + b.j, d + b.k, false, true); + } catch (a) { + a = zdb(a); + if (ZD(a, 77)) { + e = a; + throw Adb(new veb(e.g + ize + c2 + pve + d + ").")); + } else + throw Adb(a); + } + } + function dQb(b, c2, d) { + var e; + try { + TPb(b, c2 + b.j, d + b.k, true, false); + } catch (a) { + a = zdb(a); + if (ZD(a, 77)) { + e = a; + throw Adb(new veb(e.g + ize + c2 + pve + d + ").")); + } else + throw Adb(a); + } + } + function u8b(a) { + var b; + if (!nQb(a, (yCc(), dBc))) { + return; + } + b = RD(mQb(a, dBc), 21); + if (b.Hc((dod(), Xnd))) { + b.Mc(Xnd); + b.Fc(Znd); + } else if (b.Hc(Znd)) { + b.Mc(Znd); + b.Fc(Xnd); + } + } + function v8b(a) { + var b; + if (!nQb(a, (yCc(), dBc))) { + return; + } + b = RD(mQb(a, dBc), 21); + if (b.Hc((dod(), cod))) { + b.Mc(cod); + b.Fc(aod); + } else if (b.Hc(aod)) { + b.Mc(aod); + b.Fc(cod); + } + } + function oqc(a, b, c2, d) { + var e, f2, g, h; + a.a == null && rqc(a, b); + g = b.b.j.c.length; + f2 = c2.d.p; + h = d.d.p; + e = h - 1; + e < 0 && (e = g - 1); + return f2 <= e ? a.a[e] - a.a[f2] : a.a[g - 1] - a.a[f2] + a.a[e]; + } + function Cud(a) { + var b, c2; + if (!a.b) { + a.b = fv(RD(a.f, 27).kh().i); + for (c2 = new dMd(RD(a.f, 27).kh()); c2.e != c2.i.gc(); ) { + b = RD(bMd(c2), 135); + Rmb(a.b, new Bud(b)); + } + } + return a.b; + } + function Dud(a) { + var b, c2; + if (!a.e) { + a.e = fv(wCd(RD(a.f, 27)).i); + for (c2 = new dMd(wCd(RD(a.f, 27))); c2.e != c2.i.gc(); ) { + b = RD(bMd(c2), 123); + Rmb(a.e, new Rud(b)); + } + } + return a.e; + } + function yud(a) { + var b, c2; + if (!a.a) { + a.a = fv(tCd(RD(a.f, 27)).i); + for (c2 = new dMd(tCd(RD(a.f, 27))); c2.e != c2.i.gc(); ) { + b = RD(bMd(c2), 27); + Rmb(a.a, new Fud(a, b)); + } + } + return a.a; + } + function DXd(b) { + var c2; + if (!b.C && (b.D != null || b.B != null)) { + c2 = EXd(b); + if (c2) { + b.hl(c2); + } else { + try { + b.hl(null); + } catch (a) { + a = zdb(a); + if (!ZD(a, 63)) + throw Adb(a); + } + } + } + return b.C; + } + function xMb(a) { + switch (a.q.g) { + case 5: + uMb(a, (qpd(), Yod)); + uMb(a, npd); + break; + case 4: + vMb(a, (qpd(), Yod)); + vMb(a, npd); + break; + default: + wMb(a, (qpd(), Yod)); + wMb(a, npd); + } + } + function GNb(a) { + switch (a.q.g) { + case 5: + DNb(a, (qpd(), Xod)); + DNb(a, ppd); + break; + case 4: + ENb(a, (qpd(), Xod)); + ENb(a, ppd); + break; + default: + FNb(a, (qpd(), Xod)); + FNb(a, ppd); + } + } + function G$b(a, b) { + var c2, d, e; + e = new pjd(); + for (d = a.Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 36); + w$b(c2, e.a, 0); + e.a += c2.f.a + b; + e.b = $wnd.Math.max(e.b, c2.f.b); + } + e.b > 0 && (e.b += b); + return e; + } + function I$b(a, b) { + var c2, d, e; + e = new pjd(); + for (d = a.Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 36); + w$b(c2, 0, e.b); + e.b += c2.f.b + b; + e.a = $wnd.Math.max(e.a, c2.f.a); + } + e.a > 0 && (e.a += b); + return e; + } + function l2b(a) { + var b, c2, d; + d = lve; + for (c2 = new Anb(a.a); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 10); + nQb(b, (Ywc(), zwc)) && (d = $wnd.Math.min(d, RD(mQb(b, zwc), 17).a)); + } + return d; + } + function PLc(a, b) { + var c2, d; + if (b.length == 0) { + return 0; + } + c2 = lMc(a.a, b[0], (qpd(), ppd)); + c2 += lMc(a.a, b[b.length - 1], Xod); + for (d = 0; d < b.length; d++) { + c2 += QLc(a, d, b); + } + return c2; + } + function VUc() { + HUc(); + this.c = new bnb(); + this.i = new bnb(); + this.e = new Iub(); + this.f = new Iub(); + this.g = new Iub(); + this.j = new bnb(); + this.a = new bnb(); + this.b = new Tsb(); + this.k = new Tsb(); + } + function AXd(a, b) { + var c2, d; + if (a.Db >> 16 == 6) { + return a.Cb.Th(a, 5, t7, b); + } + return d = Z5d(RD(vYd((c2 = RD(Ywd(a, 16), 29), !c2 ? a.ii() : c2), a.Db >> 16), 19)), a.Cb.Th(a, d.n, d.f, b); + } + function kA(a) { + fA(); + var b = a.e; + if (b && b.stack) { + var c2 = b.stack; + var d = b + "\n"; + c2.substring(0, d.length) == d && (c2 = c2.substring(d.length)); + return c2.split("\n"); + } + return []; + } + function pgb(a) { + var b; + b = (wgb(), vgb); + return b[a >>> 28] | b[a >> 24 & 15] << 4 | b[a >> 20 & 15] << 8 | b[a >> 16 & 15] << 12 | b[a >> 12 & 15] << 16 | b[a >> 8 & 15] << 20 | b[a >> 4 & 15] << 24 | b[a & 15] << 28; + } + function mmb(a) { + var b, c2, d; + if (a.b != a.c) { + return; + } + d = a.a.length; + c2 = mgb($wnd.Math.max(8, d)) << 1; + if (a.b != 0) { + b = WEb(a.a, c2); + lmb(a, b, d); + a.a = b; + a.b = 0; + } else { + aFb(a.a, c2); + } + a.c = d; + } + function uNb(a, b) { + var c2; + c2 = a.b; + return c2.pf((umd(), Gld)) ? c2.ag() == (qpd(), ppd) ? -c2.Mf().a - Kfb(UD(c2.of(Gld))) : b + Kfb(UD(c2.of(Gld))) : c2.ag() == (qpd(), ppd) ? -c2.Mf().a : b; + } + function X2b(a) { + var b; + if (a.b.c.length != 0 && !!RD(Vmb(a.b, 0), 72).a) { + return RD(Vmb(a.b, 0), 72).a; + } + b = R0b(a); + if (b != null) { + return b; + } + return "" + (!a.c ? -1 : Wmb(a.c.a, a, 0)); + } + function M3b(a) { + var b; + if (a.f.c.length != 0 && !!RD(Vmb(a.f, 0), 72).a) { + return RD(Vmb(a.f, 0), 72).a; + } + b = R0b(a); + if (b != null) { + return b; + } + return "" + (!a.i ? -1 : Wmb(a.i.j, a, 0)); + } + function skc(a, b) { + var c2, d; + if (b < 0 || b >= a.gc()) { + return null; + } + for (c2 = b; c2 < a.gc(); ++c2) { + d = RD(a.Xb(c2), 131); + if (c2 == a.gc() - 1 || !d.o) { + return new Ptd(sgb(c2), d); + } + } + return null; + } + function Xrc(a, b, c2) { + var d, e, f2, g, h; + f2 = a.c; + h = c2 ? b : a; + d = c2 ? a : b; + for (e = h.p + 1; e < d.p; ++e) { + g = RD(Vmb(f2.a, e), 10); + if (!(g.k == (r3b(), l3b) || Yrc(g))) { + return false; + } + } + return true; + } + function Ead(a) { + var b, c2, d, e, f2; + f2 = 0; + e = pxe; + d = 0; + for (c2 = new Anb(a.a); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 172); + f2 += b.r + (d > 0 ? a.c : 0); + e = $wnd.Math.max(e, b.d); + ++d; + } + a.e = f2; + a.b = e; + } + function Qud(a) { + var b, c2; + if (!a.b) { + a.b = fv(RD(a.f, 123).kh().i); + for (c2 = new dMd(RD(a.f, 123).kh()); c2.e != c2.i.gc(); ) { + b = RD(bMd(c2), 135); + Rmb(a.b, new Bud(b)); + } + } + return a.b; + } + function aHd(a, b) { + var c2, d, e; + if (b.dc()) { + return jQd(), jQd(), iQd; + } else { + c2 = new ZLd(a, b.gc()); + for (e = new dMd(a); e.e != e.i.gc(); ) { + d = bMd(e); + b.Hc(d) && WGd(c2, d); + } + return c2; + } + } + function Axd(a, b, c2, d) { + if (b == 0) { + return d ? (!a.o && (a.o = new DVd((pvd(), mvd), X4, a, 0)), a.o) : (!a.o && (a.o = new DVd((pvd(), mvd), X4, a, 0)), dOd(a.o)); + } + return Dvd(a, b, c2, d); + } + function rBd(a) { + var b, c2; + if (a.rb) { + for (b = 0, c2 = a.rb.i; b < c2; ++b) { + aAd(QHd(a.rb, b)); + } + } + if (a.vb) { + for (b = 0, c2 = a.vb.i; b < c2; ++b) { + aAd(QHd(a.vb, b)); + } + } + Uee((lke(), jke), a); + a.Bb |= 1; + } + function zBd(a, b, c2, d, e, f2, g, h, i2, j, k, l, m, n) { + ABd(a, b, d, null, e, f2, g, h, i2, j, m, true, n); + a6d(a, k); + ZD(a.Cb, 90) && v$d(yYd(RD(a.Cb, 90)), 2); + !!c2 && b6d(a, c2); + c6d(a, l); + return a; + } + function Jae(b) { + var c2, d; + if (b == null) { + return null; + } + d = 0; + try { + d = Oeb(b, qwe, lve) & Bwe; + } catch (a) { + a = zdb(a); + if (ZD(a, 130)) { + c2 = Ahb(b); + d = c2[0]; + } else + throw Adb(a); + } + return hfb(d); + } + function Kae(b) { + var c2, d; + if (b == null) { + return null; + } + d = 0; + try { + d = Oeb(b, qwe, lve) & Bwe; + } catch (a) { + a = zdb(a); + if (ZD(a, 130)) { + c2 = Ahb(b); + d = c2[0]; + } else + throw Adb(a); + } + return hfb(d); + } + function rD(a, b) { + var c2, d, e; + e = a.h - b.h; + if (e < 0) { + return false; + } + c2 = a.l - b.l; + d = a.m - b.m + (c2 >> 22); + e += d >> 22; + if (e < 0) { + return false; + } + a.l = c2 & dxe; + a.m = d & dxe; + a.h = e & exe; + return true; + } + function Tyb(a, b, c2, d, e, f2, g) { + var h, i2; + if (b.Te() && (i2 = a.a.Ne(c2, d), i2 < 0 || !e && i2 == 0)) { + return false; + } + if (b.Ue() && (h = a.a.Ne(c2, f2), h > 0 || !g && h == 0)) { + return false; + } + return true; + } + function Agc(a, b) { + sgc(); + var c2; + c2 = a.j.g - b.j.g; + if (c2 != 0) { + return 0; + } + switch (a.j.g) { + case 2: + return Cgc(b, rgc) - Cgc(a, rgc); + case 4: + return Cgc(a, qgc) - Cgc(b, qgc); + } + return 0; + } + function uuc(a) { + switch (a.g) { + case 0: + return nuc; + case 1: + return ouc; + case 2: + return puc; + case 3: + return quc; + case 4: + return ruc; + case 5: + return suc; + default: + return null; + } + } + function cBd(a, b, c2) { + var d, e; + d = (e = new R5d(), YVd(e, b), PAd(e, c2), WGd((!a.c && (a.c = new C5d(u7, a, 12, 10)), a.c), e), e); + $Vd(d, 0); + bWd(d, 1); + aWd(d, true); + _Vd(d, true); + return d; + } + function THd(a, b) { + var c2, d; + if (b >= a.i) + throw Adb(new yNd(b, a.i)); + ++a.j; + c2 = a.g[b]; + d = a.i - b - 1; + d > 0 && hib(a.g, b + 1, a.g, b, d); + bD(a.g, --a.i, null); + a.Qi(b, c2); + a.Ni(); + return c2; + } + function sWd(a, b) { + var c2, d; + if (a.Db >> 16 == 17) { + return a.Cb.Th(a, 21, h7, b); + } + return d = Z5d(RD(vYd((c2 = RD(Ywd(a, 16), 29), !c2 ? a.ii() : c2), a.Db >> 16), 19)), a.Cb.Th(a, d.n, d.f, b); + } + function _Fb(a) { + var b, c2, d, e; + yob(); + _mb(a.c, a.a); + for (e = new Anb(a.c); e.a < e.c.c.length; ) { + d = ynb(e); + for (c2 = new Anb(a.b); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 693); + b.bf(d); + } + } + } + function r$b(a) { + var b, c2, d, e; + yob(); + _mb(a.c, a.a); + for (e = new Anb(a.c); e.a < e.c.c.length; ) { + d = ynb(e); + for (c2 = new Anb(a.b); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 382); + b.bf(d); + } + } + } + function rJb(a) { + var b, c2, d, e, f2; + e = lve; + f2 = null; + for (d = new Anb(a.d); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 218); + if (c2.d.j ^ c2.e.j) { + b = c2.e.e - c2.d.e - c2.a; + if (b < e) { + e = b; + f2 = c2; + } + } + } + return f2; + } + function QVb() { + QVb = geb; + OVb = new lGd(vAe, (Geb(), false)); + KVb = new lGd(wAe, 100); + MVb = (AWb(), yWb); + LVb = new lGd(xAe, MVb); + NVb = new lGd(yAe, Vze); + PVb = new lGd(zAe, sgb(lve)); + } + function Xlc(a, b, c2) { + var d, e, f2, g, h, i2, j, k; + j = 0; + for (e = a.a[b], f2 = 0, g = e.length; f2 < g; ++f2) { + d = e[f2]; + k = aMc(d, c2); + for (i2 = k.Kc(); i2.Ob(); ) { + h = RD(i2.Pb(), 12); + Zjb(a.f, h, sgb(j++)); + } + } + } + function UDd(a, b, c2) { + var d, e, f2, g; + if (c2) { + e = c2.a.length; + d = new vue(e); + for (g = (d.b - d.a) * d.c < 0 ? (uue(), tue) : new Rue(d); g.Ob(); ) { + f2 = RD(g.Pb(), 17); + Rc(a, b, tDd(JB(c2, f2.a))); + } + } + } + function VDd(a, b, c2) { + var d, e, f2, g; + if (c2) { + e = c2.a.length; + d = new vue(e); + for (g = (d.b - d.a) * d.c < 0 ? (uue(), tue) : new Rue(d); g.Ob(); ) { + f2 = RD(g.Pb(), 17); + Rc(a, b, tDd(JB(c2, f2.a))); + } + } + } + function foc(a) { + Mnc(); + var b; + b = RD(Ee(Ec(a.k), $C(E3, NAe, 64, 2, 0, 1)), 126); + Wnb(b, 0, b.length, null); + if (b[0] == (qpd(), Yod) && b[1] == ppd) { + bD(b, 0, ppd); + bD(b, 1, Yod); + } + return b; + } + function hMc(a, b, c2) { + var d, e, f2; + e = fMc(a, b, c2); + f2 = iMc(a, e); + YLc(a.b); + CMc(a, b, c2); + yob(); + _mb(e, new HMc(a)); + d = iMc(a, e); + YLc(a.b); + CMc(a, c2, b); + return new Ptd(sgb(f2), sgb(d)); + } + function JNc() { + JNc = geb; + GNc = pfd(new ufd(), (sXb(), rXb), (hcc(), ybc)); + HNc = new kGd("linearSegments.inputPrio", sgb(0)); + INc = new kGd("linearSegments.outputPrio", sgb(0)); + } + function YVc() { + YVc = geb; + UVc = new $Vc("P1_TREEIFICATION", 0); + VVc = new $Vc("P2_NODE_ORDERING", 1); + WVc = new $Vc("P3_NODE_PLACEMENT", 2); + XVc = new $Vc("P4_EDGE_ROUTING", 3); + } + function yad(a) { + var b, c2, d, e; + c2 = 0; + b = 0; + for (e = new dMd(a); e.e != e.i.gc(); ) { + d = RD(bMd(e), 27); + c2 = $wnd.Math.max(d.g + d.i, c2); + b = $wnd.Math.max(d.f + d.j, b); + } + return new rjd(c2, b); + } + function ard(a, b) { + var c2, d, e, f2; + f2 = 0; + for (d = new Anb(a); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 27); + f2 += $wnd.Math.pow(c2.g * c2.f - b, 2); + } + e = $wnd.Math.sqrt(f2 / (a.c.length - 1)); + return e; + } + function Pnd() { + Pnd = geb; + Ond = new Rnd("UNKNOWN", 0); + Lnd = new Rnd("ABOVE", 1); + Mnd = new Rnd("BELOW", 2); + Nnd = new Rnd("INLINE", 3); + new kGd("org.eclipse.elk.labelSide", Ond); + } + function RHd(a, b) { + var c2; + if (a.Yi() && b != null) { + for (c2 = 0; c2 < a.i; ++c2) { + if (pb(b, a.g[c2])) { + return c2; + } + } + } else { + for (c2 = 0; c2 < a.i; ++c2) { + if (dE(a.g[c2]) === dE(b)) { + return c2; + } + } + } + return -1; + } + function L0b(a, b, c2) { + var d, e; + if (b.c == (BEc(), zEc) && c2.c == yEc) { + return -1; + } else if (b.c == yEc && c2.c == zEc) { + return 1; + } + d = P0b(b.a, a.a); + e = P0b(c2.a, a.a); + return b.c == zEc ? e - d : d - e; + } + function f3b(a, b, c2) { + if (!!c2 && (b < 0 || b > c2.a.c.length)) { + throw Adb(new agb("index must be >= 0 and <= layer node count")); + } + !!a.c && Ymb(a.c.a, a); + a.c = c2; + !!c2 && Qmb(c2.a, b, a); + } + function Gac(a, b) { + var c2, d, e; + for (d = new is(Mr(W2b(a).a.Kc(), new ir())); gs(d); ) { + c2 = RD(hs(d), 18); + e = RD(b.Kb(c2), 10); + return new cc(Qb(e.n.b + e.o.b / 2)); + } + return wb(), wb(), vb; + } + function RQc(a, b) { + this.c = new Tsb(); + this.a = a; + this.b = b; + this.d = RD(mQb(a, (Ywc(), Qwc)), 312); + dE(mQb(a, (yCc(), eBc))) === dE((Cuc(), Auc)) ? this.e = new BRc() : this.e = new uRc(); + } + function ftd(a, b) { + var c2, d; + d = null; + if (a.pf((umd(), amd))) { + c2 = RD(a.of(amd), 96); + c2.pf(b) && (d = c2.of(b)); + } + d == null && !!a.Tf() && (d = a.Tf().of(b)); + d == null && (d = iGd(b)); + return d; + } + function ku(b, c2) { + var d, e; + d = b.fd(c2); + try { + e = d.Pb(); + d.Qb(); + return e; + } catch (a) { + a = zdb(a); + if (ZD(a, 112)) { + throw Adb(new veb("Can't remove element " + c2)); + } else + throw Adb(a); + } + } + function GA(a, b) { + var c2, d, e; + d = new uB(); + e = new vB(d.q.getFullYear() - Owe, d.q.getMonth(), d.q.getDate()); + c2 = FA(a, b, e); + if (c2 == 0 || c2 < b.length) { + throw Adb(new agb(b)); + } + return e; + } + function iwb(a, b) { + var c2, d, e; + uFb(b); + lFb(b != a); + e = a.b.c.length; + for (d = b.Kc(); d.Ob(); ) { + c2 = d.Pb(); + Rmb(a.b, uFb(c2)); + } + if (e != a.b.c.length) { + jwb(a, 0); + return true; + } + return false; + } + function dWb() { + dWb = geb; + XVb = (umd(), ald); + new mGd(Pkd, (Geb(), true)); + $Vb = kld; + _Vb = nld; + aWb = pld; + ZVb = ild; + bWb = sld; + cWb = Lld; + WVb = (QVb(), OVb); + UVb = LVb; + VVb = NVb; + YVb = PVb; + TVb = KVb; + } + function U0b(a, b) { + if (b == a.c) { + return a.d; + } else if (b == a.d) { + return a.c; + } else { + throw Adb(new agb("'port' must be either the source port or target port of the edge.")); + } + } + function T6b(a, b, c2) { + var d, e; + e = a.o; + d = a.d; + switch (b.g) { + case 1: + return -d.d - c2; + case 3: + return e.b + d.a + c2; + case 2: + return e.a + d.c + c2; + case 4: + return -d.b - c2; + default: + return 0; + } + } + function Y9b(a, b, c2, d) { + var e, f2, g, h; + g3b(b, RD(d.Xb(0), 30)); + h = d.kd(1, d.gc()); + for (f2 = RD(c2.Kb(b), 20).Kc(); f2.Ob(); ) { + e = RD(f2.Pb(), 18); + g = e.c.i == b ? e.d.i : e.c.i; + Y9b(a, g, c2, h); + } + } + function Bic(a) { + var b; + b = new Tsb(); + if (nQb(a, (Ywc(), Vwc))) { + return RD(mQb(a, Vwc), 85); + } + FDb(CDb(new SDb(null, new Swb(a.j, 16)), new Dic()), new Fic(b)); + pQb(a, Vwc, b); + return b; + } + function zad(a, b) { + var c2, d, e, f2, g; + d = 0; + e = 0; + c2 = 0; + for (g = new Anb(a); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 186); + d = $wnd.Math.max(d, f2.e); + e += f2.b + (c2 > 0 ? b : 0); + ++c2; + } + return new rjd(d, e); + } + function Czd(a, b) { + var c2, d; + if (a.Db >> 16 == 6) { + return a.Cb.Th(a, 6, G4, b); + } + return d = Z5d(RD(vYd((c2 = RD(Ywd(a, 16), 29), !c2 ? (pvd(), hvd) : c2), a.Db >> 16), 19)), a.Cb.Th(a, d.n, d.f, b); + } + function cCd(a, b) { + var c2, d; + if (a.Db >> 16 == 7) { + return a.Cb.Th(a, 1, H4, b); + } + return d = Z5d(RD(vYd((c2 = RD(Ywd(a, 16), 29), !c2 ? (pvd(), jvd) : c2), a.Db >> 16), 19)), a.Cb.Th(a, d.n, d.f, b); + } + function LCd(a, b) { + var c2, d; + if (a.Db >> 16 == 9) { + return a.Cb.Th(a, 9, J4, b); + } + return d = Z5d(RD(vYd((c2 = RD(Ywd(a, 16), 29), !c2 ? (pvd(), lvd) : c2), a.Db >> 16), 19)), a.Cb.Th(a, d.n, d.f, b); + } + function M1d(a, b) { + var c2, d; + if (a.Db >> 16 == 5) { + return a.Cb.Th(a, 9, m7, b); + } + return d = Z5d(RD(vYd((c2 = RD(Ywd(a, 16), 29), !c2 ? (JTd(), tTd) : c2), a.Db >> 16), 19)), a.Cb.Th(a, d.n, d.f, b); + } + function qBd(a, b) { + var c2, d; + if (a.Db >> 16 == 7) { + return a.Cb.Th(a, 6, t7, b); + } + return d = Z5d(RD(vYd((c2 = RD(Ywd(a, 16), 29), !c2 ? (JTd(), CTd) : c2), a.Db >> 16), 19)), a.Cb.Th(a, d.n, d.f, b); + } + function iVd(a, b) { + var c2, d; + if (a.Db >> 16 == 3) { + return a.Cb.Th(a, 0, p7, b); + } + return d = Z5d(RD(vYd((c2 = RD(Ywd(a, 16), 29), !c2 ? (JTd(), mTd) : c2), a.Db >> 16), 19)), a.Cb.Th(a, d.n, d.f, b); + } + function IEd() { + this.a = new BDd(); + this.g = new Io(); + this.j = new Io(); + this.b = new Tsb(); + this.d = new Io(); + this.i = new Io(); + this.k = new Tsb(); + this.c = new Tsb(); + this.e = new Tsb(); + this.f = new Tsb(); + } + function kQd(a, b, c2) { + var d, e, f2; + c2 < 0 && (c2 = 0); + f2 = a.i; + for (e = c2; e < f2; e++) { + d = QHd(a, e); + if (b == null) { + if (d == null) { + return e; + } + } else if (dE(b) === dE(d) || pb(b, d)) { + return e; + } + } + return -1; + } + function Bee(a, b) { + var c2, d; + c2 = b.qi(a.a); + if (!c2) { + return null; + } else { + d = WD($Nd((!c2.b && (c2.b = new SVd((JTd(), FTd), C8, c2)), c2.b), _Ke)); + return lhb(aLe, d) ? Uee(a, BXd(b.qk())) : d; + } + } + function Oje(a, b) { + var c2, d; + if (b) { + if (b == a) { + return true; + } + c2 = 0; + for (d = RD(b, 54).Ph(); !!d && d != b; d = d.Ph()) { + if (++c2 > wxe) { + return Oje(a, d); + } + if (d == a) { + return true; + } + } + } + return false; + } + function yNb(a) { + tNb(); + switch (a.q.g) { + case 5: + vNb(a, (qpd(), Yod)); + vNb(a, npd); + break; + case 4: + wNb(a, (qpd(), Yod)); + wNb(a, npd); + break; + default: + xNb(a, (qpd(), Yod)); + xNb(a, npd); + } + } + function CNb(a) { + tNb(); + switch (a.q.g) { + case 5: + zNb(a, (qpd(), Xod)); + zNb(a, ppd); + break; + case 4: + ANb(a, (qpd(), Xod)); + ANb(a, ppd); + break; + default: + BNb(a, (qpd(), Xod)); + BNb(a, ppd); + } + } + function RTb(a) { + var b, c2; + b = RD(mQb(a, (yVb(), mVb)), 17); + if (b) { + c2 = b.a; + c2 == 0 ? pQb(a, (JVb(), IVb), new Owb()) : pQb(a, (JVb(), IVb), new Pwb(c2)); + } else { + pQb(a, (JVb(), IVb), new Pwb(1)); + } + } + function b2b(a, b) { + var c2; + c2 = a.i; + switch (b.g) { + case 1: + return -(a.n.b + a.o.b); + case 2: + return a.n.a - c2.o.a; + case 3: + return a.n.b - c2.o.b; + case 4: + return -(a.n.a + a.o.a); + } + return 0; + } + function wec(a, b) { + switch (a.g) { + case 0: + return b == (cxc(), $wc) ? sec : tec; + case 1: + return b == (cxc(), $wc) ? sec : rec; + case 2: + return b == (cxc(), $wc) ? rec : tec; + default: + return rec; + } + } + function Fad(a, b) { + var c2, d, e; + Ymb(a.a, b); + a.e -= b.r + (a.a.c.length == 0 ? 0 : a.c); + e = fFe; + for (d = new Anb(a.a); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 172); + e = $wnd.Math.max(e, c2.d); + } + a.b = e; + } + function jzd(a, b) { + var c2, d; + if (a.Db >> 16 == 3) { + return a.Cb.Th(a, 12, J4, b); + } + return d = Z5d(RD(vYd((c2 = RD(Ywd(a, 16), 29), !c2 ? (pvd(), gvd) : c2), a.Db >> 16), 19)), a.Cb.Th(a, d.n, d.f, b); + } + function sCd(a, b) { + var c2, d; + if (a.Db >> 16 == 11) { + return a.Cb.Th(a, 10, J4, b); + } + return d = Z5d(RD(vYd((c2 = RD(Ywd(a, 16), 29), !c2 ? (pvd(), kvd) : c2), a.Db >> 16), 19)), a.Cb.Th(a, d.n, d.f, b); + } + function n4d(a, b) { + var c2, d; + if (a.Db >> 16 == 10) { + return a.Cb.Th(a, 11, h7, b); + } + return d = Z5d(RD(vYd((c2 = RD(Ywd(a, 16), 29), !c2 ? (JTd(), ATd) : c2), a.Db >> 16), 19)), a.Cb.Th(a, d.n, d.f, b); + } + function Q5d(a, b) { + var c2, d; + if (a.Db >> 16 == 10) { + return a.Cb.Th(a, 12, s7, b); + } + return d = Z5d(RD(vYd((c2 = RD(Ywd(a, 16), 29), !c2 ? (JTd(), DTd) : c2), a.Db >> 16), 19)), a.Cb.Th(a, d.n, d.f, b); + } + function WVd(a) { + var b; + if ((a.Bb & 1) == 0 && !!a.r && a.r.Vh()) { + b = RD(a.r, 54); + a.r = RD(Vvd(a, b), 142); + a.r != b && (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 9, 8, b, a.r)); + } + return a.r; + } + function pKb(a, b, c2) { + var d; + d = cD(WC(iE, 1), vxe, 28, 15, [sKb(a, (ZJb(), WJb), b, c2), sKb(a, XJb, b, c2), sKb(a, YJb, b, c2)]); + if (a.f) { + d[0] = $wnd.Math.max(d[0], d[2]); + d[2] = d[0]; + } + return d; + } + function ddc(a, b) { + var c2, d, e; + e = kdc(a, b); + if (e.c.length == 0) { + return; + } + _mb(e, new Gdc()); + c2 = e.c.length; + for (d = 0; d < c2; d++) { + _cc(a, (tFb(d, e.c.length), RD(e.c[d], 293)), gdc(a, e, d)); + } + } + function Wnc(a) { + var b, c2, d, e; + for (e = RD(Qc(a.a, (Bnc(), wnc)), 15).Kc(); e.Ob(); ) { + d = RD(e.Pb(), 105); + for (c2 = Ec(d.k).Kc(); c2.Ob(); ) { + b = RD(c2.Pb(), 64); + Qnc(a, d, b, (joc(), hoc), 1); + } + } + } + function Yrc(a) { + var b, c2; + if (a.k == (r3b(), o3b)) { + for (c2 = new is(Mr(W2b(a).a.Kc(), new ir())); gs(c2); ) { + b = RD(hs(c2), 18); + if (!W0b(b) && a.c == T0b(b, a).c) { + return true; + } + } + } + return false; + } + function hSc(a) { + var b, c2; + if (a.k == (r3b(), o3b)) { + for (c2 = new is(Mr(W2b(a).a.Kc(), new ir())); gs(c2); ) { + b = RD(hs(c2), 18); + if (!W0b(b) && b.c.i.c == b.d.i.c) { + return true; + } + } + } + return false; + } + function XDd(a, b) { + var c2, d, e, f2, g; + if (b) { + e = b.a.length; + c2 = new vue(e); + for (g = (c2.b - c2.a) * c2.c < 0 ? (uue(), tue) : new Rue(c2); g.Ob(); ) { + f2 = RD(g.Pb(), 17); + d = xDd(b, f2.a); + !!d && AEd(a, d); + } + } + } + function bbe() { + Tae(); + var a, b; + Xae((lTd(), kTd)); + Wae(kTd); + rBd(kTd); + d2d = (JTd(), wTd); + for (b = new Anb(Rae); b.a < b.c.c.length; ) { + a = RD(ynb(b), 248); + o2d(a, wTd, null); + } + return true; + } + function uD(a, b) { + var c2, d, e, f2, g, h, i2, j; + i2 = a.h >> 19; + j = b.h >> 19; + if (i2 != j) { + return j - i2; + } + e = a.h; + h = b.h; + if (e != h) { + return e - h; + } + d = a.m; + g = b.m; + if (d != g) { + return d - g; + } + c2 = a.l; + f2 = b.l; + return c2 - f2; + } + function YHb() { + YHb = geb; + XHb = (iIb(), fIb); + WHb = new lGd(Aye, XHb); + VHb = (LHb(), KHb); + UHb = new lGd(Bye, VHb); + THb = (DHb(), CHb); + SHb = new lGd(Cye, THb); + RHb = new lGd(Dye, (Geb(), true)); + } + function Iic(a, b, c2) { + var d, e; + d = b * c2; + if (ZD(a.g, 154)) { + e = $jc(a); + if (e.f.d) { + e.f.a || (a.d.a += d + Tye); + } else { + a.d.d -= d + Tye; + a.d.a += d + Tye; + } + } else if (ZD(a.g, 10)) { + a.d.d -= d; + a.d.a += 2 * d; + } + } + function _pc(a, b, c2) { + var d, e, f2, g, h; + e = a[c2.g]; + for (h = new Anb(b.d); h.a < h.c.c.length; ) { + g = RD(ynb(h), 105); + f2 = g.i; + if (!!f2 && f2.i == c2) { + d = g.d[c2.g]; + e[d] = $wnd.Math.max(e[d], f2.j.b); + } + } + } + function k9c(a, b) { + var c2, d, e, f2, g; + d = 0; + e = 0; + c2 = 0; + for (g = new Anb(b.d); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 315); + gad(f2); + d = $wnd.Math.max(d, f2.b); + e += f2.d + (c2 > 0 ? a.b : 0); + ++c2; + } + b.b = d; + b.e = e; + } + function Fo(a) { + var b, c2, d; + d = a.b; + if (Xp(a.i, d.length)) { + c2 = d.length * 2; + a.b = $C(XF, ewe, 303, c2, 0, 1); + a.c = $C(XF, ewe, 303, c2, 0, 1); + a.f = c2 - 1; + a.i = 0; + for (b = a.a; b; b = b.c) { + Bo(a, b, b); + } + ++a.g; + } + } + function VPb(a, b, c2, d) { + var e, f2, g, h; + for (e = 0; e < b.o; e++) { + f2 = e - b.j + c2; + for (g = 0; g < b.p; g++) { + h = g - b.k + d; + PPb(b, e, g) ? aQb(a, f2, h) || cQb(a, f2, h) : RPb(b, e, g) && ($Pb(a, f2, h) || dQb(a, f2, h)); + } + } + } + function k_b(a, b) { + a.b.a = $wnd.Math.min(a.b.a, b.c); + a.b.b = $wnd.Math.min(a.b.b, b.d); + a.a.a = $wnd.Math.max(a.a.a, b.c); + a.a.b = $wnd.Math.max(a.a.b, b.d); + return ZEb(a.c, b), true; + } + function psc(a, b, c2) { + var d; + d = b.c.i; + if (d.k == (r3b(), o3b)) { + pQb(a, (Ywc(), vwc), RD(mQb(d, vwc), 12)); + pQb(a, wwc, RD(mQb(d, wwc), 12)); + } else { + pQb(a, (Ywc(), vwc), b.c); + pQb(a, wwc, c2.d); + } + } + function wid(a, b, c2) { + tid(); + var d, e, f2, g, h, i2; + g = b / 2; + f2 = c2 / 2; + d = $wnd.Math.abs(a.a); + e = $wnd.Math.abs(a.b); + h = 1; + i2 = 1; + d > g && (h = g / d); + e > f2 && (i2 = f2 / e); + ijd(a, $wnd.Math.min(h, i2)); + return a; + } + function OAd() { + qAd(); + var b, c2; + try { + c2 = RD(M5d((YSd(), XSd), $He), 2113); + if (c2) { + return c2; + } + } catch (a) { + a = zdb(a); + if (ZD(a, 103)) { + b = a; + UId((Hde(), b)); + } else + throw Adb(a); + } + return new KAd(); + } + function Qae() { + qAd(); + var b, c2; + try { + c2 = RD(M5d((YSd(), XSd), AKe), 2040); + if (c2) { + return c2; + } + } catch (a) { + a = zdb(a); + if (ZD(a, 103)) { + b = a; + UId((Hde(), b)); + } else + throw Adb(a); + } + return new Mae(); + } + function vne() { + Zme(); + var b, c2; + try { + c2 = RD(M5d((YSd(), XSd), dLe), 2122); + if (c2) { + return c2; + } + } catch (a) { + a = zdb(a); + if (ZD(a, 103)) { + b = a; + UId((Hde(), b)); + } else + throw Adb(a); + } + return new rne(); + } + function f2d(a, b, c2) { + var d, e; + e = a.e; + a.e = b; + if ((a.Db & 4) != 0 && (a.Db & 1) == 0) { + d = new N3d(a, 1, 4, e, b); + !c2 ? c2 = d : c2.nj(d); + } + e != b && (b ? c2 = o2d(a, k2d(a, b), c2) : c2 = o2d(a, a.a, c2)); + return c2; + } + function DB() { + uB.call(this); + this.e = -1; + this.a = false; + this.p = qwe; + this.k = -1; + this.c = -1; + this.b = -1; + this.g = false; + this.f = -1; + this.j = -1; + this.n = -1; + this.i = -1; + this.d = -1; + this.o = qwe; + } + function hHb(a, b) { + var c2, d, e; + d = a.b.d.d; + a.a || (d += a.b.d.a); + e = b.b.d.d; + b.a || (e += b.b.d.a); + c2 = Qfb(d, e); + if (c2 == 0) { + if (!a.a && b.a) { + return -1; + } else if (!b.a && a.a) { + return 1; + } + } + return c2; + } + function XQb(a, b) { + var c2, d, e; + d = a.b.b.d; + a.a || (d += a.b.b.a); + e = b.b.b.d; + b.a || (e += b.b.b.a); + c2 = Qfb(d, e); + if (c2 == 0) { + if (!a.a && b.a) { + return -1; + } else if (!b.a && a.a) { + return 1; + } + } + return c2; + } + function RYb(a, b) { + var c2, d, e; + d = a.b.g.d; + a.a || (d += a.b.g.a); + e = b.b.g.d; + b.a || (e += b.b.g.a); + c2 = Qfb(d, e); + if (c2 == 0) { + if (!a.a && b.a) { + return -1; + } else if (!b.a && a.a) { + return 1; + } + } + return c2; + } + function _Wb() { + _Wb = geb; + YWb = nfd(pfd(pfd(pfd(new ufd(), (sXb(), qXb), (hcc(), Dbc)), qXb, Hbc), rXb, Obc), rXb, rbc); + $Wb = pfd(pfd(new ufd(), qXb, hbc), qXb, sbc); + ZWb = nfd(new ufd(), rXb, ubc); + } + function J6b(a) { + var b, c2, d, e, f2; + b = RD(mQb(a, (Ywc(), cwc)), 85); + f2 = a.n; + for (d = b.Cc().Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 314); + e = c2.i; + e.c += f2.a; + e.d += f2.b; + c2.c ? MKb(c2) : OKb(c2); + } + pQb(a, cwc, null); + } + function Wpc(a, b, c2) { + var d, e; + e = a.b; + d = e.d; + switch (b.g) { + case 1: + return -d.d - c2; + case 2: + return e.o.a + d.c + c2; + case 3: + return e.o.b + d.a + c2; + case 4: + return -d.b - c2; + default: + return -1; + } + } + function CNc(a, b, c2) { + var d, e; + c2.Ug("Interactive node placement", 1); + a.a = RD(mQb(b, (Ywc(), Qwc)), 312); + for (e = new Anb(b.b); e.a < e.c.c.length; ) { + d = RD(ynb(e), 30); + BNc(a, d); + } + c2.Vg(); + } + function C5c(a) { + var b, c2, d, e, f2; + d = 0; + e = Hze; + if (a.b) { + for (b = 0; b < 360; b++) { + c2 = b * 0.017453292519943295; + A5c(a, a.d, 0, 0, dFe, c2); + f2 = a.b.Dg(a.d); + if (f2 < e) { + d = c2; + e = f2; + } + } + } + A5c(a, a.d, 0, 0, dFe, d); + } + function Oad(a, b) { + var c2, d, e, f2; + f2 = new Tsb(); + b.e = null; + b.f = null; + for (d = new Anb(b.i); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 68); + e = RD(Wjb(a.g, c2.a), 42); + c2.a = Oid(c2.b); + Zjb(f2, c2.a, e); + } + a.g = f2; + } + function Dad(a, b, c2) { + var d, e, f2, g, h, i2; + e = b - a.e; + f2 = e / a.d.c.length; + g = 0; + for (i2 = new Anb(a.d); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 315); + d = a.b - h.b + c2; + fad(h, h.e + g * f2, h.f); + bad(h, f2, d); + ++g; + } + } + function wPd(a) { + var b; + a.f._j(); + if (a.b != -1) { + ++a.b; + b = a.f.d[a.a]; + if (a.b < b.i) { + return; + } + ++a.a; + } + for (; a.a < a.f.d.length; ++a.a) { + b = a.f.d[a.a]; + if (!!b && b.i != 0) { + a.b = 0; + return; + } + } + a.b = -1; + } + function Jde(a, b) { + var c2, d, e; + e = b.c.length; + c2 = Lde(a, e == 0 ? "" : (tFb(0, b.c.length), WD(b.c[0]))); + for (d = 1; d < e && !!c2; ++d) { + c2 = RD(c2, 54).Zh((tFb(d, b.c.length), WD(b.c[d]))); + } + return c2; + } + function RIc(a, b) { + var c2, d; + for (d = new Anb(b); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 10); + a.c[c2.c.p][c2.p].a = Iwb(a.i); + a.c[c2.c.p][c2.p].d = Kfb(a.c[c2.c.p][c2.p].a); + a.c[c2.c.p][c2.p].b = 1; + } + } + function brd(a, b) { + var c2, d, e, f2; + f2 = 0; + for (d = new Anb(a); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 163); + f2 += $wnd.Math.pow(urd(c2) * trd(c2) - b, 2); + } + e = $wnd.Math.sqrt(f2 / (a.c.length - 1)); + return e; + } + function uMb(a, b) { + var c2, d, e, f2; + f2 = 0; + for (e = RD(RD(Qc(a.r, b), 21), 87).Kc(); e.Ob(); ) { + d = RD(e.Pb(), 117); + f2 = $wnd.Math.max(f2, d.e.a + d.b.Mf().a); + } + c2 = RD(Vrb(a.b, b), 127); + c2.n.b = 0; + c2.a.a = f2; + } + function DNb(a, b) { + var c2, d, e, f2; + c2 = 0; + for (f2 = RD(RD(Qc(a.r, b), 21), 87).Kc(); f2.Ob(); ) { + e = RD(f2.Pb(), 117); + c2 = $wnd.Math.max(c2, e.e.b + e.b.Mf().b); + } + d = RD(Vrb(a.b, b), 127); + d.n.d = 0; + d.a.b = c2; + } + function jMc(a, b, c2, d) { + var e, f2, g; + f2 = eMc(a, b, c2, d); + g = kMc(a, f2); + BMc(a, b, c2, d); + YLc(a.b); + yob(); + _mb(f2, new LMc(a)); + e = kMc(a, f2); + BMc(a, c2, b, d); + YLc(a.b); + return new Ptd(sgb(g), sgb(e)); + } + function udd(a, b) { + var c2; + b.Ug("Delaunay triangulation", 1); + c2 = new bnb(); + Umb(a.i, new ydd(c2)); + Heb(TD(mQb(a, (OQb(), MQb)))) && "null10bw"; + !a.e ? a.e = EFb(c2) : ye(a.e, EFb(c2)); + b.Vg(); + } + function Hsd(a, b, c2) { + var d, e; + Nzd(a, a.j + b, a.k + c2); + for (e = new dMd((!a.a && (a.a = new XZd(D4, a, 5)), a.a)); e.e != e.i.gc(); ) { + d = RD(bMd(e), 377); + Uxd(d, d.a + b, d.b + c2); + } + Gzd(a, a.b + b, a.c + c2); + } + function Vyd(a, b, c2, d) { + switch (c2) { + case 7: + return !a.e && (a.e = new Yie(G4, a, 7, 4)), qLd(a.e, b, d); + case 8: + return !a.d && (a.d = new Yie(G4, a, 8, 5)), qLd(a.d, b, d); + } + return dyd(a, b, c2, d); + } + function Wyd(a, b, c2, d) { + switch (c2) { + case 7: + return !a.e && (a.e = new Yie(G4, a, 7, 4)), rLd(a.e, b, d); + case 8: + return !a.d && (a.d = new Yie(G4, a, 8, 5)), rLd(a.d, b, d); + } + return eyd(a, b, c2, d); + } + function LDd(a, b, c2) { + var d, e, f2, g, h; + if (c2) { + f2 = c2.a.length; + d = new vue(f2); + for (h = (d.b - d.a) * d.c < 0 ? (uue(), tue) : new Rue(d); h.Ob(); ) { + g = RD(h.Pb(), 17); + e = xDd(c2, g.a); + !!e && DEd(a, e, b); + } + } + } + function fOd(a, b, c2) { + var d, e, f2, g, h; + a._j(); + f2 = b == null ? 0 : tb(b); + if (a.f > 0) { + g = (f2 & lve) % a.d.length; + e = WNd(a, g, f2, b); + if (e) { + h = e.nd(c2); + return h; + } + } + d = a.ck(f2, b, c2); + a.c.Fc(d); + return null; + } + function Tee(a, b) { + var c2, d, e, f2; + switch (Oee(a, b).Kl()) { + case 3: + case 2: { + c2 = mYd(b); + for (e = 0, f2 = c2.i; e < f2; ++e) { + d = RD(QHd(c2, e), 35); + if (yfe(Qee(a, d)) == 5) { + return d; + } + } + break; + } + } + return null; + } + function gt(a) { + var b, c2, d, e, f2; + if (Xp(a.f, a.b.length)) { + d = $C(UG, ewe, 227, a.b.length * 2, 0, 1); + a.b = d; + e = d.length - 1; + for (c2 = a.a; c2 != a; c2 = c2._d()) { + f2 = RD(c2, 227); + b = f2.d & e; + f2.a = d[b]; + d[b] = f2; + } + } + } + function gSc(a) { + var b, c2; + c2 = RD(mQb(a, (Ywc(), kwc)), 21); + b = vfd(ZRc); + c2.Hc((ovc(), lvc)) && ofd(b, aSc); + c2.Hc(nvc) && ofd(b, cSc); + c2.Hc(evc) && ofd(b, $Rc); + c2.Hc(gvc) && ofd(b, _Rc); + return b; + } + function Bid(a) { + if (a < 0) { + throw Adb(new agb("The input must be positive")); + } else + return a < sid.length ? Xdb(sid[a]) : $wnd.Math.sqrt(dFe * a) * (Jid(a, a) / Iid(2.718281828459045, a)); + } + function PHd(a, b) { + var c2; + if (a.Yi() && b != null) { + for (c2 = 0; c2 < a.i; ++c2) { + if (pb(b, a.g[c2])) { + return true; + } + } + } else { + for (c2 = 0; c2 < a.i; ++c2) { + if (dE(a.g[c2]) === dE(b)) { + return true; + } + } + } + return false; + } + function Br(a, b) { + if (b == null) { + while (a.a.Ob()) { + if (RD(a.a.Pb(), 44).md() == null) { + return true; + } + } + } else { + while (a.a.Ob()) { + if (pb(b, RD(a.a.Pb(), 44).md())) { + return true; + } + } + } + return false; + } + function Qy(a, b) { + var c2, d, e; + if (b === a) { + return true; + } else if (ZD(b, 678)) { + e = RD(b, 2046); + return Ue((d = a.g, !d ? a.g = new Di(a) : d), (c2 = e.g, !c2 ? e.g = new Di(e) : c2)); + } else { + return false; + } + } + function hA(a) { + var b, c2, d, e; + b = "gA"; + c2 = "vz"; + e = $wnd.Math.min(a.length, 5); + for (d = e - 1; d >= 0; d--) { + if (lhb(a[d].d, b) || lhb(a[d].d, c2)) { + a.length >= d + 1 && a.splice(0, d + 1); + break; + } + } + return a; + } + function Fdb(a, b) { + var c2; + if (Kdb(a) && Kdb(b)) { + c2 = a / b; + if (jxe < c2 && c2 < hxe) { + return c2 < 0 ? $wnd.Math.ceil(c2) : $wnd.Math.floor(c2); + } + } + return Edb(iD(Kdb(a) ? Wdb(a) : a, Kdb(b) ? Wdb(b) : b, false)); + } + function T0b(a, b) { + if (b == a.c.i) { + return a.d.i; + } else if (b == a.d.i) { + return a.c.i; + } else { + throw Adb(new agb("'node' must either be the source node or target node of the edge.")); + } + } + function M5b(a) { + var b, c2, d, e; + e = RD(mQb(a, (Ywc(), Zvc)), 36); + if (e) { + d = new pjd(); + b = Y2b(a.c.i); + while (b != e) { + c2 = b.e; + b = Y2b(c2); + Zid($id($id(d, c2.n), b.c), b.d.b, b.d.d); + } + return d; + } + return G5b; + } + function phc(a) { + var b; + b = RD(mQb(a, (Ywc(), Pwc)), 337); + FDb(EDb(new SDb(null, new Swb(b.d, 16)), new Chc()), new Ehc(a)); + FDb(CDb(new SDb(null, new Swb(b.d, 16)), new Ghc()), new Ihc(a)); + } + function Zrc(a, b) { + var c2, d, e, f2; + e = b ? a3b(a) : Z2b(a); + for (d = new is(Mr(e.a.Kc(), new ir())); gs(d); ) { + c2 = RD(hs(d), 18); + f2 = T0b(c2, a); + if (f2.k == (r3b(), o3b) && f2.c != a.c) { + return f2; + } + } + return null; + } + function fIc(a) { + var b, c2, d; + for (c2 = new Anb(a.p); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 10); + if (b.k != (r3b(), p3b)) { + continue; + } + d = b.o.b; + a.i = $wnd.Math.min(a.i, d); + a.g = $wnd.Math.max(a.g, d); + } + } + function OIc(a, b, c2) { + var d, e, f2; + for (f2 = new Anb(b); f2.a < f2.c.c.length; ) { + d = RD(ynb(f2), 10); + a.c[d.c.p][d.p].e = false; + } + for (e = new Anb(b); e.a < e.c.c.length; ) { + d = RD(ynb(e), 10); + NIc(a, d, c2); + } + } + function uTc(a, b, c2) { + var d, e; + d = VTc(b.j, c2.s, c2.c) + VTc(c2.e, b.s, b.c); + e = VTc(c2.j, b.s, b.c) + VTc(b.e, c2.s, c2.c); + if (d == e) { + if (d > 0) { + a.b += 2; + a.a += d; + } + } else { + a.b += 1; + a.a += $wnd.Math.min(d, e); + } + } + function CVc(a) { + var b; + b = RD(mQb(RD(ju(a.b, 0), 40), (h_c(), T$c)), 107); + pQb(a, (q$c(), SZc), new rjd(0, 0)); + FVc(new YWc(), a, b.b + b.c - Kfb(UD(mQb(a, ZZc))), b.d + b.a - Kfb(UD(mQb(a, _Zc)))); + } + function pDd(a, b) { + var c2, d; + d = false; + if (bE(b)) { + d = true; + oDd(a, new OC(WD(b))); + } + if (!d) { + if (ZD(b, 242)) { + d = true; + oDd(a, (c2 = Qeb(RD(b, 242)), new hC(c2))); + } + } + if (!d) { + throw Adb(new Aeb(tIe)); + } + } + function g$d(a, b, c2, d) { + var e, f2, g; + e = new P3d(a.e, 1, 10, (g = b.c, ZD(g, 90) ? RD(g, 29) : (JTd(), zTd)), (f2 = c2.c, ZD(f2, 90) ? RD(f2, 29) : (JTd(), zTd)), fZd(a, b), false); + !d ? d = e : d.nj(e); + return d; + } + function _2b(a) { + var b, c2; + switch (RD(mQb(Y2b(a), (yCc(), QAc)), 429).g) { + case 0: + b = a.n; + c2 = a.o; + return new rjd(b.a + c2.a / 2, b.b + c2.b / 2); + case 1: + return new sjd(a.n); + default: + return null; + } + } + function Ouc() { + Ouc = geb; + Luc = new Puc(LAe, 0); + Kuc = new Puc("LEFTUP", 1); + Nuc = new Puc("RIGHTUP", 2); + Juc = new Puc("LEFTDOWN", 3); + Muc = new Puc("RIGHTDOWN", 4); + Iuc = new Puc("BALANCED", 5); + } + function dKc(a, b, c2) { + var d, e, f2; + d = Qfb(a.a[b.p], a.a[c2.p]); + if (d == 0) { + e = RD(mQb(b, (Ywc(), qwc)), 15); + f2 = RD(mQb(c2, qwc), 15); + if (e.Hc(c2)) { + return -1; + } else if (f2.Hc(b)) { + return 1; + } + } + return d; + } + function k5c(a) { + switch (a.g) { + case 1: + return new K3c(); + case 2: + return new M3c(); + case 3: + return new I3c(); + case 0: + return null; + default: + throw Adb(new agb(mFe + (a.f != null ? a.f : "" + a.g))); + } + } + function gyd(a, b, c2) { + switch (b) { + case 1: + !a.n && (a.n = new C5d(I4, a, 1, 7)); + sLd(a.n); + !a.n && (a.n = new C5d(I4, a, 1, 7)); + YGd(a.n, RD(c2, 16)); + return; + case 2: + jyd(a, WD(c2)); + return; + } + Dxd(a, b, c2); + } + function xyd(a, b, c2) { + switch (b) { + case 3: + Ayd(a, Kfb(UD(c2))); + return; + case 4: + Cyd(a, Kfb(UD(c2))); + return; + case 5: + Dyd(a, Kfb(UD(c2))); + return; + case 6: + Eyd(a, Kfb(UD(c2))); + return; + } + gyd(a, b, c2); + } + function dBd(a, b, c2) { + var d, e, f2; + f2 = (d = new R5d(), d); + e = XVd(f2, b, null); + !!e && e.oj(); + PAd(f2, c2); + WGd((!a.c && (a.c = new C5d(u7, a, 12, 10)), a.c), f2); + $Vd(f2, 0); + bWd(f2, 1); + aWd(f2, true); + _Vd(f2, true); + } + function M5d(a, b) { + var c2, d, e; + c2 = Ktb(a.i, b); + if (ZD(c2, 241)) { + e = RD(c2, 241); + e.zi() == null && void 0; + return e.wi(); + } else if (ZD(c2, 507)) { + d = RD(c2, 2037); + e = d.b; + return e; + } else { + return null; + } + } + function aj(a, b, c2, d) { + var e, f2; + Qb(b); + Qb(c2); + f2 = RD(Fn(a.d, b), 17); + Ob(!!f2, "Row %s not in %s", b, a.e); + e = RD(Fn(a.b, c2), 17); + Ob(!!e, "Column %s not in %s", c2, a.c); + return cj(a, f2.a, e.a, d); + } + function ZC(a, b, c2, d, e, f2, g) { + var h, i2, j, k, l; + k = e[f2]; + j = f2 == g - 1; + h = j ? d : 0; + l = _C(h, k); + d != 10 && cD(WC(a, g - f2), b[f2], c2[f2], h, l); + if (!j) { + ++f2; + for (i2 = 0; i2 < k; ++i2) { + l[i2] = ZC(a, b, c2, d, e, f2, g); + } + } + return l; + } + function cMd(b) { + if (b.g == -1) { + throw Adb(new cgb()); + } + b.Xj(); + try { + b.i.gd(b.g); + b.f = b.i.j; + b.g < b.e && --b.e; + b.g = -1; + } catch (a) { + a = zdb(a); + if (ZD(a, 77)) { + throw Adb(new Jrb()); + } else + throw Adb(a); + } + } + function v0b(a) { + var b, c2, d, e; + e = -1; + d = 0; + for (c2 = new Anb(a); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 249); + if (b.c == (BEc(), yEc)) { + e = d == 0 ? 0 : d - 1; + break; + } else + d == a.c.length - 1 && (e = d); + d += 1; + } + return e; + } + function $9c(a) { + var b, c2, d, e; + e = 0; + b = 0; + for (d = new Anb(a.c); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 27); + Dyd(c2, a.e + e); + Eyd(c2, a.f); + e += c2.g + a.b; + b = $wnd.Math.max(b, c2.f + a.b); + } + a.d = e - a.b; + a.a = b - a.b; + } + function UGb(a) { + var b, c2, d; + for (c2 = new Anb(a.a.b); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 60); + d = b.d.c; + b.d.c = b.d.d; + b.d.d = d; + d = b.d.b; + b.d.b = b.d.a; + b.d.a = d; + d = b.b.a; + b.b.a = b.b.b; + b.b.b = d; + } + IGb(a); + } + function DYb(a) { + var b, c2, d; + for (c2 = new Anb(a.a.b); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 86); + d = b.g.c; + b.g.c = b.g.d; + b.g.d = d; + d = b.g.b; + b.g.b = b.g.a; + b.g.a = d; + d = b.e.a; + b.e.a = b.e.b; + b.e.b = d; + } + uYb(a); + } + function pqc(a) { + var b, c2, d, e, f2; + f2 = Ec(a.k); + for (c2 = (qpd(), cD(WC(E3, 1), NAe, 64, 0, [opd, Yod, Xod, npd, ppd])), d = 0, e = c2.length; d < e; ++d) { + b = c2[d]; + if (b != opd && !f2.Hc(b)) { + return b; + } + } + return null; + } + function drc(a, b) { + var c2, d; + d = RD(Nvb(DDb(CDb(new SDb(null, new Swb(b.j, 16)), new lrc()))), 12); + if (d) { + c2 = RD(Vmb(d.e, 0), 18); + if (c2) { + return RD(mQb(c2, (Ywc(), zwc)), 17).a; + } + } + return mDc(a.b); + } + function FGc(a, b) { + var c2, d, e, f2; + for (f2 = new Anb(b.a); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 10); + Nnb(a.d); + for (d = new is(Mr(a3b(e).a.Kc(), new ir())); gs(d); ) { + c2 = RD(hs(d), 18); + CGc(a, e, c2.d.i); + } + } + } + function T9c(a, b) { + var c2, d; + Ymb(a.b, b); + for (d = new Anb(a.n); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 209); + if (Wmb(c2.c, b, 0) != -1) { + Ymb(c2.c, b); + $9c(c2); + c2.c.c.length == 0 && Ymb(a.n, c2); + break; + } + } + N9c(a); + } + function ead(a, b) { + var c2, d, e, f2, g; + g = a.f; + e = 0; + f2 = 0; + for (d = new Anb(a.a); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 172); + U9c(c2, a.e, g); + Q9c(c2, b); + f2 = $wnd.Math.max(f2, c2.r); + g += c2.d + a.c; + e = g; + } + a.d = f2; + a.b = e; + } + function R2c(a) { + var b, c2; + c2 = yGd(a); + if (gr(c2)) { + return null; + } else { + b = (Qb(c2), RD(Er(new is(Mr(c2.a.Kc(), new ir()))), 74)); + return AGd(RD(QHd((!b.b && (b.b = new Yie(E4, b, 4, 7)), b.b), 0), 84)); + } + } + function vWd(a) { + var b; + if (!a.o) { + b = a.uk(); + b ? a.o = new D9d(a, a, null) : a.al() ? a.o = new U6d(a, null) : yfe(Qee((lke(), jke), a)) == 1 ? a.o = new N9d(a) : a.o = new S9d(a, null); + } + return a.o; + } + function Vje(a, b, c2, d) { + var e, f2, g, h, i2; + if (c2.Xh(b)) { + e = (g = b, !g ? null : RD(d, 54).gi(g)); + if (e) { + i2 = c2.Mh(b); + h = b.t; + if (h > 1 || h == -1) { + f2 = RD(i2, 15); + e.Wb(Sje(a, f2)); + } else { + e.Wb(Rje(a, RD(i2, 58))); + } + } + } + } + function ceb(b, c2, d, e) { + beb(); + var f2 = _db; + function g() { + for (var a = 0; a < f2.length; a++) { + f2[a](); + } + } + if (b) { + try { + fve(g)(); + } catch (a) { + b(c2, a); + } + } else { + fve(g)(); + } + } + function a6b(a, b) { + var c2, d, e, f2; + for (e = (f2 = new Xkb(a.b).a.vc().Kc(), new blb(f2)); e.a.Ob(); ) { + d = (c2 = RD(e.a.Pb(), 44), RD(c2.ld(), 34)); + if (egb(b, RD(d, 17)) < 0) { + return false; + } + } + return true; + } + function b6b(a, b) { + var c2, d, e, f2; + for (e = (f2 = new Xkb(a.b).a.vc().Kc(), new blb(f2)); e.a.Ob(); ) { + d = (c2 = RD(e.a.Pb(), 44), RD(c2.ld(), 34)); + if (egb(b, RD(d, 17)) > 0) { + return false; + } + } + return true; + } + function okc(a) { + var b, c2, d, e, f2; + for (d = new vkb(new mkb(a.b).a); d.b; ) { + c2 = tkb(d); + b = RD(c2.ld(), 10); + f2 = RD(RD(c2.md(), 42).a, 10); + e = RD(RD(c2.md(), 42).b, 8); + $id(hjd(b.n), $id(ajd(f2.n), e)); + } + } + function Roc(a) { + switch (RD(mQb(a.b, (yCc(), BAc)), 387).g) { + case 1: + FDb(GDb(EDb(new SDb(null, new Swb(a.d, 16)), new kpc()), new mpc()), new opc()); + break; + case 2: + Toc(a); + break; + case 0: + Soc(a); + } + } + function SVc(a, b, c2) { + var d, e, f2; + d = c2; + !d && (d = new Oqd()); + d.Ug("Layout", a.a.c.length); + for (f2 = new Anb(a.a); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 47); + if (d.$g()) { + return; + } + e.Kf(b, d.eh(1)); + } + d.Vg(); + } + function ukd() { + ukd = geb; + tkd = new vkd("V_TOP", 0); + skd = new vkd("V_CENTER", 1); + rkd = new vkd("V_BOTTOM", 2); + pkd = new vkd("H_LEFT", 3); + okd = new vkd("H_CENTER", 4); + qkd = new vkd("H_RIGHT", 5); + } + function GYd(a) { + var b; + if ((a.Db & 64) != 0) + return MXd(a); + b = new Shb(MXd(a)); + b.a += " (abstract: "; + Ohb(b, (a.Bb & 256) != 0); + b.a += ", interface: "; + Ohb(b, (a.Bb & 512) != 0); + b.a += ")"; + return b.a; + } + function Bz(a) { + var b; + if (a.c == null) { + b = dE(a.b) === dE(zz) ? null : a.b; + a.d = b == null ? vve : aE(b) ? Ez(VD(b)) : bE(b) ? uwe : nfb(rb(b)); + a.a = a.a + ": " + (aE(b) ? Dz(VD(b)) : b + ""); + a.c = "(" + a.d + ") " + a.a; + } + } + function Gtb() { + function b() { + try { + return (/* @__PURE__ */ new Map()).entries().next().done; + } catch (a) { + return false; + } + } + if (typeof Map === kve && Map.prototype.entries && b()) { + return Map; + } else { + return Htb(); + } + } + function tUc(a, b) { + var c2, d, e, f2; + f2 = new Jkb(a.e, 0); + c2 = 0; + while (f2.b < f2.d.gc()) { + d = Kfb((sFb(f2.b < f2.d.gc()), UD(f2.d.Xb(f2.c = f2.b++)))); + e = d - b; + if (e > AEe) { + return c2; + } else + e > -1e-6 && ++c2; + } + return c2; + } + function n2d(a, b) { + var c2; + if (b != a.b) { + c2 = null; + !!a.b && (c2 = Jvd(a.b, a, -4, c2)); + !!b && (c2 = Ivd(b, a, -4, c2)); + c2 = e2d(a, b, c2); + !!c2 && c2.oj(); + } else + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 3, b, b)); + } + function q2d(a, b) { + var c2; + if (b != a.f) { + c2 = null; + !!a.f && (c2 = Jvd(a.f, a, -1, c2)); + !!b && (c2 = Ivd(b, a, -1, c2)); + c2 = g2d(a, b, c2); + !!c2 && c2.oj(); + } else + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 0, b, b)); + } + function Lge(a, b, c2, d) { + var e, f2, g, h; + if (Mvd(a.e)) { + e = b.Lk(); + h = b.md(); + f2 = c2.md(); + g = fge(a, 1, e, h, f2, e.Jk() ? kge(a, e, f2, ZD(e, 102) && (RD(e, 19).Bb & txe) != 0) : -1, true); + d ? d.nj(g) : d = g; + } + return d; + } + function bne(a) { + var b, c2, d; + if (a == null) + return null; + c2 = RD(a, 15); + if (c2.dc()) + return ""; + d = new Qhb(); + for (b = c2.Kc(); b.Ob(); ) { + Nhb(d, (nme(), WD(b.Pb()))); + d.a += " "; + } + return qeb(d, d.a.length - 1); + } + function fne(a) { + var b, c2, d; + if (a == null) + return null; + c2 = RD(a, 15); + if (c2.dc()) + return ""; + d = new Qhb(); + for (b = c2.Kc(); b.Ob(); ) { + Nhb(d, (nme(), WD(b.Pb()))); + d.a += " "; + } + return qeb(d, d.a.length - 1); + } + function QIc(a, b, c2) { + var d, e; + d = a.c[b.c.p][b.p]; + e = a.c[c2.c.p][c2.p]; + if (d.a != null && e.a != null) { + return Jfb(d.a, e.a); + } else if (d.a != null) { + return -1; + } else if (e.a != null) { + return 1; + } + return 0; + } + function RVc(a, b, c2) { + c2.Ug("Tree layout", 1); + Sed(a.b); + Ved(a.b, (YVc(), UVc), UVc); + Ved(a.b, VVc, VVc); + Ved(a.b, WVc, WVc); + Ved(a.b, XVc, XVc); + a.a = Qed(a.b, b); + SVc(a, b, c2.eh(1)); + c2.Vg(); + return b; + } + function ZDd(a, b) { + var c2, d, e, f2, g, h; + if (b) { + f2 = b.a.length; + c2 = new vue(f2); + for (h = (c2.b - c2.a) * c2.c < 0 ? (uue(), tue) : new Rue(c2); h.Ob(); ) { + g = RD(h.Pb(), 17); + e = xDd(b, g.a); + d = new aFd(a); + $Dd(d.a, e); + } + } + } + function oEd(a, b) { + var c2, d, e, f2, g, h; + if (b) { + f2 = b.a.length; + c2 = new vue(f2); + for (h = (c2.b - c2.a) * c2.c < 0 ? (uue(), tue) : new Rue(c2); h.Ob(); ) { + g = RD(h.Pb(), 17); + e = xDd(b, g.a); + d = new LEd(a); + NDd(d.a, e); + } + } + } + function ESd(b) { + var c2; + if (b != null && b.length > 0 && ihb(b, b.length - 1) == 33) { + try { + c2 = nSd(zhb(b, 0, b.length - 1)); + return c2.e == null; + } catch (a) { + a = zdb(a); + if (!ZD(a, 33)) + throw Adb(a); + } + } + return false; + } + function u0b(a, b, c2) { + var d, e, f2; + d = Y2b(b); + e = i2b(d); + f2 = new R3b(); + P3b(f2, b); + switch (c2.g) { + case 1: + Q3b(f2, spd(vpd(e))); + break; + case 2: + Q3b(f2, vpd(e)); + } + pQb(f2, (yCc(), ABc), UD(mQb(a, ABc))); + return f2; + } + function jdc(a) { + var b, c2; + b = RD(hs(new is(Mr(Z2b(a.a).a.Kc(), new ir()))), 18); + c2 = RD(hs(new is(Mr(a3b(a.a).a.Kc(), new ir()))), 18); + return Heb(TD(mQb(b, (Ywc(), Nwc)))) || Heb(TD(mQb(c2, Nwc))); + } + function Bnc() { + Bnc = geb; + xnc = new Cnc("ONE_SIDE", 0); + znc = new Cnc("TWO_SIDES_CORNER", 1); + Anc = new Cnc("TWO_SIDES_OPPOSING", 2); + ync = new Cnc("THREE_SIDES", 3); + wnc = new Cnc("FOUR_SIDES", 4); + } + function Usc(a, b) { + var c2, d, e, f2; + f2 = new bnb(); + e = 0; + d = b.Kc(); + while (d.Ob()) { + c2 = sgb(RD(d.Pb(), 17).a + e); + while (c2.a < a.f && !wsc(a, c2.a)) { + c2 = sgb(c2.a + 1); + ++e; + } + if (c2.a >= a.f) { + break; + } + ZEb(f2.c, c2); + } + return f2; + } + function iIc(a, b) { + var c2, d, e, f2, g; + for (f2 = new Anb(b.a); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 10); + for (d = new is(Mr(Z2b(e).a.Kc(), new ir())); gs(d); ) { + c2 = RD(hs(d), 18); + g = c2.c.i.p; + a.n[g] = a.n[g] - 1; + } + } + } + function fOc(a) { + var b, c2; + for (c2 = new Anb(a.e.b); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 30); + wOc(a, b); + } + FDb(CDb(EDb(EDb(new SDb(null, new Swb(a.e.b, 16)), new wPc()), new TPc()), new VPc()), new XPc(a)); + } + function oKd(a, b) { + if (!b) { + return false; + } else { + if (a.mj(b)) { + return false; + } + if (!a.i) { + if (ZD(b, 152)) { + a.i = RD(b, 152); + return true; + } else { + a.i = new fLd(); + return a.i.nj(b); + } + } else { + return a.i.nj(b); + } + } + } + function Hge(a, b, c2) { + var d, e, f2; + d = b.Lk(); + f2 = b.md(); + e = d.Jk() ? fge(a, 3, d, null, f2, kge(a, d, f2, ZD(d, 102) && (RD(d, 19).Bb & txe) != 0), true) : fge(a, 1, d, d.ik(), f2, -1, true); + c2 ? c2.nj(e) : c2 = e; + return c2; + } + function $me(a) { + a = nue(a, true); + if (lhb(FGe, a) || lhb("1", a)) { + return Geb(), Feb; + } else if (lhb(GGe, a) || lhb("0", a)) { + return Geb(), Eeb; + } + throw Adb(new Mle("Invalid boolean value: '" + a + "'")); + } + function Kd(a, b, c2) { + var d, e, f2; + for (e = a.vc().Kc(); e.Ob(); ) { + d = RD(e.Pb(), 44); + f2 = d.ld(); + if (dE(b) === dE(f2) || b != null && pb(b, f2)) { + if (c2) { + d = new xlb(d.ld(), d.md()); + e.Qb(); + } + return d; + } + } + return null; + } + function WMb(a) { + RMb(); + var b, c2, d; + if (!a.B.Hc((dqd(), Xpd))) { + return; + } + d = a.f.i; + b = new Vid(a.a.c); + c2 = new z3b(); + c2.b = b.c - d.c; + c2.d = b.d - d.d; + c2.c = d.c + d.b - (b.c + b.b); + c2.a = d.d + d.a - (b.d + b.a); + a.e.$f(c2); + } + function CQb(a, b, c2, d) { + var e, f2, g; + g = $wnd.Math.min(c2, FQb(RD(a.b, 68), b, c2, d)); + for (f2 = new Anb(a.a); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 225); + e != b && (g = $wnd.Math.min(g, CQb(e, b, g, d))); + } + return g; + } + function c1b(a) { + var b, c2, d, e; + e = $C(jR, Nve, 199, a.b.c.length, 0, 2); + d = new Jkb(a.b, 0); + while (d.b < d.d.gc()) { + b = (sFb(d.b < d.d.gc()), RD(d.d.Xb(d.c = d.b++), 30)); + c2 = d.b - 1; + e[c2] = t2b(b.a); + } + return e; + } + function c6b(a, b, c2) { + var d, e, f2; + d = RD(cub(a.a, c2), 34); + if (d != null) { + f2 = RD(cub(a.b, d), 67); + ze(f2, c2, true); + } + e = RD(cub(a.b, b), 67); + if (!e) { + e = new Yub(); + dub(a.b, b, e); + } + Pub(e, c2, e.c.b, e.c); + dub(a.a, c2, b); + } + function _6b(a, b, c2, d, e) { + var f2, g, h, i2; + g = XNb(WNb(_Nb(Y6b(c2)), d), T6b(a, c2, e)); + for (i2 = e3b(a, c2).Kc(); i2.Ob(); ) { + h = RD(i2.Pb(), 12); + if (b[h.p]) { + f2 = b[h.p].i; + Rmb(g.d, new sOb(f2, UNb(g, f2))); + } + } + VNb(g); + } + function Ylc(a, b) { + this.f = new Tsb(); + this.b = new Tsb(); + this.j = new Tsb(); + this.a = a; + this.c = b; + this.c > 0 && Xlc(this, this.c - 1, (qpd(), Xod)); + this.c < this.a.length - 1 && Xlc(this, this.c + 1, (qpd(), ppd)); + } + function Iqc(a, b) { + var c2, d, e, f2, g; + for (f2 = new Anb(b.d); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 105); + g = RD(Wjb(a.c, e), 118).o; + for (d = new Osb(e.b); d.a < d.c.a.length; ) { + c2 = RD(Nsb(d), 64); + Umc(e, c2, g); + } + } + } + function qJc(a) { + a.length > 0 && a[0].length > 0 && (this.c = Heb(TD(mQb(Y2b(a[0][0]), (Ywc(), rwc))))); + this.a = $C(aY, Nve, 2117, a.length, 0, 2); + this.b = $C(dY, Nve, 2118, a.length, 0, 2); + this.d = new Ks(); + } + function TOc(a) { + if (a.c.length == 0) { + return false; + } + if ((tFb(0, a.c.length), RD(a.c[0], 18)).c.i.k == (r3b(), o3b)) { + return true; + } + return yDb(GDb(new SDb(null, new Swb(a, 16)), new WOc()), new YOc()); + } + function I5c(a, b) { + var c2, d, e, f2, g, h, i2; + h = Q2c(b); + f2 = b.f; + i2 = b.g; + g = $wnd.Math.sqrt(f2 * f2 + i2 * i2); + e = 0; + for (d = new Anb(h); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 27); + e += I5c(a, c2); + } + return $wnd.Math.max(e, g); + } + function Bod() { + Bod = geb; + Aod = new Eod(Sye, 0); + zod = new Eod("FREE", 1); + yod = new Eod("FIXED_SIDE", 2); + vod = new Eod("FIXED_ORDER", 3); + xod = new Eod("FIXED_RATIO", 4); + wod = new Eod("FIXED_POS", 5); + } + function Cee(a, b) { + var c2, d, e; + c2 = b.qi(a.a); + if (c2) { + e = WD($Nd((!c2.b && (c2.b = new SVd((JTd(), FTd), C8, c2)), c2.b), bLe)); + for (d = 1; d < (lke(), kke).length; ++d) { + if (lhb(kke[d], e)) { + return d; + } + } + } + return 0; + } + function aob(a) { + var b, c2, d, e, f2; + if (a == null) { + return vve; + } + f2 = new Jyb(pve, "[", "]"); + for (c2 = a, d = 0, e = c2.length; d < e; ++d) { + b = c2[d]; + Gyb(f2, "" + b); + } + return !f2.a ? f2.c : f2.e.length == 0 ? f2.a.a : f2.a.a + ("" + f2.e); + } + function gob(a) { + var b, c2, d, e, f2; + if (a == null) { + return vve; + } + f2 = new Jyb(pve, "[", "]"); + for (c2 = a, d = 0, e = c2.length; d < e; ++d) { + b = c2[d]; + Gyb(f2, "" + b); + } + return !f2.a ? f2.c : f2.e.length == 0 ? f2.a.a : f2.a.a + ("" + f2.e); + } + function Md(a) { + var b, c2, d; + d = new Jyb(pve, "{", "}"); + for (c2 = a.vc().Kc(); c2.Ob(); ) { + b = RD(c2.Pb(), 44); + Gyb(d, Nd(a, b.ld()) + "=" + Nd(a, b.md())); + } + return !d.a ? d.c : d.e.length == 0 ? d.a.a : d.a.a + ("" + d.e); + } + function vJb(a) { + var b, c2, d, e; + while (!nmb(a.o)) { + c2 = RD(smb(a.o), 42); + d = RD(c2.a, 125); + b = RD(c2.b, 218); + e = oIb(b, d); + if (b.e == d) { + EIb(e.g, b); + d.e = e.e + b.a; + } else { + EIb(e.b, b); + d.e = e.e - b.a; + } + Rmb(a.e.a, d); + } + } + function W9b(a, b) { + var c2, d, e; + c2 = null; + for (e = RD(b.Kb(a), 20).Kc(); e.Ob(); ) { + d = RD(e.Pb(), 18); + if (!c2) { + c2 = d.c.i == a ? d.d.i : d.c.i; + } else { + if ((d.c.i == a ? d.d.i : d.c.i) != c2) { + return false; + } + } + } + return true; + } + function UTc(a, b) { + var c2, d, e, f2, g; + c2 = uSc(a, false, b); + for (e = new Anb(c2); e.a < e.c.c.length; ) { + d = RD(ynb(e), 132); + d.d == 0 ? (_Sc(d, null), aTc(d, null)) : (f2 = d.a, g = d.b, _Sc(d, g), aTc(d, f2), void 0); + } + } + function QUc(a) { + var b, c2; + b = new ufd(); + ofd(b, CUc); + c2 = RD(mQb(a, (Ywc(), kwc)), 21); + c2.Hc((ovc(), nvc)) && ofd(b, GUc); + c2.Hc(evc) && ofd(b, DUc); + c2.Hc(lvc) && ofd(b, FUc); + c2.Hc(gvc) && ofd(b, EUc); + return b; + } + function iz(a, b, c2) { + var d, e, f2, g, h; + jz(a); + for (e = (a.k == null && (a.k = $C(rJ, Nve, 82, 0, 0, 1)), a.k), f2 = 0, g = e.length; f2 < g; ++f2) { + d = e[f2]; + iz(d); + } + h = a.f; + !!h && iz(h); + } + function kec(a) { + var b, c2, d, e; + jec(a); + for (c2 = new is(Mr(W2b(a).a.Kc(), new ir())); gs(c2); ) { + b = RD(hs(c2), 18); + d = b.c.i == a; + e = d ? b.d : b.c; + d ? Z0b(b, null) : Y0b(b, null); + pQb(b, (Ywc(), Ewc), e); + oec(a, e.i); + } + } + function aqc(a, b, c2, d) { + var e, f2; + f2 = b.i; + e = c2[f2.g][a.d[f2.g]]; + switch (f2.g) { + case 1: + e -= d + b.j.b; + b.g.b = e; + break; + case 3: + e += d; + b.g.b = e; + break; + case 4: + e -= d + b.j.a; + b.g.a = e; + break; + case 2: + e += d; + b.g.a = e; + } + } + function K2c(a) { + var b, c2, d; + for (c2 = new dMd((!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a)); c2.e != c2.i.gc(); ) { + b = RD(bMd(c2), 27); + d = yGd(b); + if (!gs(new is(Mr(d.a.Kc(), new ir())))) { + return b; + } + } + return null; + } + function g3c() { + g3c = geb; + e3c = new h3c("OVERLAP_REMOVAL", 0); + b3c = new h3c(iFe, 1); + f3c = new h3c("ROTATION", 2); + c3c = new h3c("GRAPH_SIZE_CALCULATION", 3); + d3c = new h3c("OUTGOING_EDGE_ANGLES", 4); + } + function aCd() { + var a; + if (YBd) + return RD(N5d((YSd(), XSd), $He), 2115); + a = RD(ZD(Xjb((YSd(), XSd), $He), 569) ? Xjb(XSd, $He) : new _Bd(), 569); + YBd = true; + ZBd(a); + $Bd(a); + rBd(a); + $jb(XSd, $He, a); + return a; + } + function Tge(a, b, c2) { + var d, e; + if (a.j == 0) + return c2; + e = RD(jZd(a, b, c2), 76); + d = c2.Lk(); + if (!d.rk() || !a.a.am(d)) { + throw Adb(new yz("Invalid entry feature '" + d.qk().zb + "." + d.xe() + "'")); + } + return e; + } + function Yi(a, b) { + var c2, d, e, f2, g, h, i2, j; + for (h = a.a, i2 = 0, j = h.length; i2 < j; ++i2) { + g = h[i2]; + for (d = g, e = 0, f2 = d.length; e < f2; ++e) { + c2 = d[e]; + if (dE(b) === dE(c2) || b != null && pb(b, c2)) { + return true; + } + } + } + return false; + } + function yjb(a) { + var b, c2, d; + if (Ddb(a, 0) >= 0) { + c2 = Fdb(a, ixe); + d = Mdb(a, ixe); + } else { + b = Udb(a, 1); + c2 = Fdb(b, 5e8); + d = Mdb(b, 5e8); + d = Bdb(Sdb(d, 1), Cdb(a, 1)); + } + return Rdb(Sdb(d, 32), Cdb(c2, yxe)); + } + function fTb(a, b, c2) { + var d, e; + d = (sFb(b.b != 0), RD(Wub(b, b.a.a), 8)); + switch (c2.g) { + case 0: + d.b = 0; + break; + case 2: + d.b = a.f; + break; + case 3: + d.a = 0; + break; + default: + d.a = a.g; + } + e = Sub(b, 0); + cvb(e, d); + return b; + } + function Vpc(a, b, c2, d) { + var e, f2, g, h, i2; + i2 = a.b; + f2 = b.d; + g = f2.j; + h = $pc(g, i2.d[g.g], c2); + e = $id(ajd(f2.n), f2.a); + switch (f2.j.g) { + case 1: + case 3: + h.a += e.a; + break; + case 2: + case 4: + h.b += e.b; + } + Pub(d, h, d.c.b, d.c); + } + function YNc(a, b, c2) { + var d, e, f2, g; + g = Wmb(a.e, b, 0); + f2 = new ZNc(); + f2.b = c2; + d = new Jkb(a.e, g); + while (d.b < d.d.gc()) { + e = (sFb(d.b < d.d.gc()), RD(d.d.Xb(d.c = d.b++), 10)); + e.p = c2; + Rmb(f2.e, e); + Ckb(d); + } + return f2; + } + function l8c(a, b, c2, d) { + var e, f2, g, h, i2; + e = null; + f2 = 0; + for (h = new Anb(b); h.a < h.c.c.length; ) { + g = RD(ynb(h), 27); + i2 = g.i + g.g; + if (a < g.j + g.f + d) { + !e ? e = g : c2.i - i2 < c2.i - f2 && (e = g); + f2 = e.i + e.g; + } + } + return !e ? 0 : f2 + d; + } + function m8c(a, b, c2, d) { + var e, f2, g, h, i2; + f2 = null; + e = 0; + for (h = new Anb(b); h.a < h.c.c.length; ) { + g = RD(ynb(h), 27); + i2 = g.j + g.f; + if (a < g.i + g.g + d) { + !f2 ? f2 = g : c2.j - i2 < c2.j - e && (f2 = g); + e = f2.j + f2.f; + } + } + return !f2 ? 0 : e + d; + } + function CA(a) { + var b, c2, d; + b = false; + d = a.b.c.length; + for (c2 = 0; c2 < d; c2++) { + if (DA(RD(Vmb(a.b, c2), 443))) { + if (!b && c2 + 1 < d && DA(RD(Vmb(a.b, c2 + 1), 443))) { + b = true; + RD(Vmb(a.b, c2), 443).a = true; + } + } else { + b = false; + } + } + } + function Ijb(a, b, c2, d, e) { + var f2, g; + f2 = 0; + for (g = 0; g < e; g++) { + f2 = Bdb(f2, Vdb(Cdb(b[g], yxe), Cdb(d[g], yxe))); + a[g] = Ydb(f2); + f2 = Tdb(f2, 32); + } + for (; g < c2; g++) { + f2 = Bdb(f2, Cdb(b[g], yxe)); + a[g] = Ydb(f2); + f2 = Tdb(f2, 32); + } + } + function Rjb(a, b) { + Ljb(); + var c2, d; + d = (Pib(), Kib); + c2 = a; + for (; b > 1; b >>= 1) { + (b & 1) != 0 && (d = Wib(d, c2)); + c2.d == 1 ? c2 = Wib(c2, c2) : c2 = new djb(Tjb(c2.a, c2.d, $C(kE, Pwe, 28, c2.d << 1, 15, 1))); + } + d = Wib(d, c2); + return d; + } + function Hwb() { + Hwb = geb; + var a, b, c2, d; + Ewb = $C(iE, vxe, 28, 25, 15, 1); + Fwb = $C(iE, vxe, 28, 33, 15, 1); + d = 152587890625e-16; + for (b = 32; b >= 0; b--) { + Fwb[b] = d; + d *= 0.5; + } + c2 = 1; + for (a = 24; a >= 0; a--) { + Ewb[a] = c2; + c2 *= 0.5; + } + } + function a5b(a) { + var b, c2; + if (Heb(TD(Gxd(a, (yCc(), NAc))))) { + for (c2 = new is(Mr(zGd(a).a.Kc(), new ir())); gs(c2); ) { + b = RD(hs(c2), 74); + if (ozd(b)) { + if (Heb(TD(Gxd(b, OAc)))) { + return true; + } + } + } + } + return false; + } + function Qmc(a, b) { + var c2, d, e; + if (Ysb(a.f, b)) { + b.b = a; + d = b.c; + Wmb(a.j, d, 0) != -1 || Rmb(a.j, d); + e = b.d; + Wmb(a.j, e, 0) != -1 || Rmb(a.j, e); + c2 = b.a.b; + if (c2.c.length != 0) { + !a.i && (a.i = new _mc(a)); + Wmc(a.i, c2); + } + } + } + function Xpc(a) { + var b, c2, d, e, f2; + c2 = a.c.d; + d = c2.j; + e = a.d.d; + f2 = e.j; + if (d == f2) { + return c2.p < e.p ? 0 : 1; + } else if (tpd(d) == f2) { + return 0; + } else if (rpd(d) == f2) { + return 1; + } else { + b = a.b; + return Csb(b.b, tpd(d)) ? 0 : 1; + } + } + function Pfd(a) { + var b; + this.d = new Tsb(); + this.c = a.c; + this.e = a.d; + this.b = a.b; + this.f = new ntd(a.e); + this.a = a.a; + !a.f ? this.g = (b = RD(mfb(T5), 9), new Fsb(b, RD(WEb(b, b.length), 9), 0)) : this.g = a.f; + } + function GEd(a, b) { + var c2, d, e, f2, g, h; + e = a; + g = yDd(e, "layoutOptions"); + !g && (g = yDd(e, cIe)); + if (g) { + h = g; + d = null; + !!h && (d = (f2 = oC(h, $C(qJ, Nve, 2, 0, 6, 1)), new CC(h, f2))); + if (d) { + c2 = new bFd(h, b); + xgb(d, c2); + } + } + } + function AGd(a) { + if (ZD(a, 207)) { + return RD(a, 27); + } else if (ZD(a, 193)) { + return MCd(RD(a, 123)); + } else if (!a) { + throw Adb(new Ogb(HIe)); + } else { + throw Adb(new kib("Only support nodes and ports.")); + } + } + function SA(a, b, c2, d) { + if (b >= 0 && lhb(a.substr(b, "GMT".length), "GMT")) { + c2[0] = b + 3; + return JA(a, c2, d); + } + if (b >= 0 && lhb(a.substr(b, "UTC".length), "UTC")) { + c2[0] = b + 3; + return JA(a, c2, d); + } + return JA(a, c2, d); + } + function Zmc(a, b) { + var c2, d, e, f2, g; + f2 = a.g.a; + g = a.g.b; + for (d = new Anb(a.d); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 72); + e = c2.n; + e.a = f2; + a.i == (qpd(), Yod) ? e.b = g + a.j.b - c2.o.b : e.b = g; + $id(e, b); + f2 += c2.o.a + a.e; + } + } + function Fqd(a, b, c2) { + if (a.b) { + throw Adb(new dgb("The task is already done.")); + } else if (a.p != null) { + return false; + } else { + a.p = b; + a.r = c2; + a.k && (a.o = (gib(), Ndb(Hdb(Date.now()), Awe))); + return true; + } + } + function HFd(a) { + var b, c2, d, e, f2, g, h; + h = new uC(); + c2 = a.Pg(); + e = c2 != null; + e && sDd(h, uIe, a.Pg()); + d = a.xe(); + f2 = d != null; + f2 && sDd(h, GIe, a.xe()); + b = a.Og(); + g = b != null; + g && sDd(h, "description", a.Og()); + return h; + } + function UVd(a, b, c2) { + var d, e, f2; + f2 = a.q; + a.q = b; + if ((a.Db & 4) != 0 && (a.Db & 1) == 0) { + e = new N3d(a, 1, 9, f2, b); + !c2 ? c2 = e : c2.nj(e); + } + if (!b) { + !!a.r && (c2 = a.Yk(null, c2)); + } else { + d = b.c; + d != a.r && (c2 = a.Yk(d, c2)); + } + return c2; + } + function gae(a, b, c2) { + var d, e, f2, g, h; + c2 = (h = b, Ivd(h, a.e, -1 - a.c, c2)); + g = $9d(a.a); + for (f2 = (d = new vkb(new mkb(g.a).a), new xae(d)); f2.a.b; ) { + e = RD(tkb(f2.a).ld(), 89); + c2 = o2d(e, k2d(e, a.a), c2); + } + return c2; + } + function hae(a, b, c2) { + var d, e, f2, g, h; + c2 = (h = b, Jvd(h, a.e, -1 - a.c, c2)); + g = $9d(a.a); + for (f2 = (d = new vkb(new mkb(g.a).a), new xae(d)); f2.a.b; ) { + e = RD(tkb(f2.a).ld(), 89); + c2 = o2d(e, k2d(e, a.a), c2); + } + return c2; + } + function rjb(a, b, c2, d) { + var e, f2, g; + if (d == 0) { + hib(b, 0, a, c2, a.length - c2); + } else { + g = 32 - d; + a[a.length - 1] = 0; + for (f2 = a.length - 1; f2 > c2; f2--) { + a[f2] |= b[f2 - c2 - 1] >>> g; + a[f2 - 1] = b[f2 - c2 - 1] << d; + } + } + for (e = 0; e < c2; e++) { + a[e] = 0; + } + } + function CMb(a) { + var b, c2, d, e, f2; + b = 0; + c2 = 0; + for (f2 = a.Kc(); f2.Ob(); ) { + d = RD(f2.Pb(), 117); + b = $wnd.Math.max(b, d.d.b); + c2 = $wnd.Math.max(c2, d.d.c); + } + for (e = a.Kc(); e.Ob(); ) { + d = RD(e.Pb(), 117); + d.d.b = b; + d.d.c = c2; + } + } + function KNb(a) { + var b, c2, d, e, f2; + c2 = 0; + b = 0; + for (f2 = a.Kc(); f2.Ob(); ) { + d = RD(f2.Pb(), 117); + c2 = $wnd.Math.max(c2, d.d.d); + b = $wnd.Math.max(b, d.d.a); + } + for (e = a.Kc(); e.Ob(); ) { + d = RD(e.Pb(), 117); + d.d.d = c2; + d.d.a = b; + } + } + function Pnc(a, b, c2, d, e) { + var f2, g; + f2 = RD(zDb(CDb(b.Oc(), new Foc()), tBb(new ZBb(), new XBb(), new wCb(), cD(WC(QL, 1), jwe, 108, 0, [(xBb(), vBb)]))), 15); + Eob(f2); + g = RD($i(a.b, c2, d), 15); + e == 0 ? g.cd(0, f2) : g.Gc(f2); + } + function Sdd(a, b, c2) { + c2.Ug("Grow Tree", 1); + a.b = b.f; + if (Heb(TD(mQb(b, (OQb(), MQb))))) { + a.c = new kRb(); + Odd(a, null); + } else { + a.c = new kRb(); + } + a.a = false; + Qdd(a, b.f); + pQb(b, NQb, (Geb(), a.a ? true : false)); + c2.Vg(); + } + function wsd(a) { + var b, c2, d, e; + b = null; + for (e = new Anb(a.Rf()); e.a < e.c.c.length; ) { + d = RD(ynb(e), 187); + c2 = new Uid2(d.Lf().a, d.Lf().b, d.Mf().a, d.Mf().b); + !b ? b = c2 : Sid(b, c2); + } + !b && (b = new Tid()); + return b; + } + function dyd(a, b, c2, d) { + var e, f2; + if (c2 == 1) { + return !a.n && (a.n = new C5d(I4, a, 1, 7)), qLd(a.n, b, d); + } + return f2 = RD(vYd((e = RD(Ywd(a, 16), 29), !e ? a.ii() : e), c2), 69), f2.wk().zk(a, Wwd(a), c2 - AYd(a.ii()), b, d); + } + function IHd(a, b, c2) { + var d, e, f2, g, h; + d = c2.gc(); + a._i(a.i + d); + h = a.i - b; + h > 0 && hib(a.g, b, a.g, b + d, h); + g = c2.Kc(); + a.i += d; + for (e = 0; e < d; ++e) { + f2 = g.Pb(); + MHd(a, b, a.Zi(b, f2)); + a.Mi(b, f2); + a.Ni(); + ++b; + } + return d != 0; + } + function XVd(a, b, c2) { + var d; + if (b != a.q) { + !!a.q && (c2 = Jvd(a.q, a, -10, c2)); + !!b && (c2 = Ivd(b, a, -10, c2)); + c2 = UVd(a, b, c2); + } else if ((a.Db & 4) != 0 && (a.Db & 1) == 0) { + d = new N3d(a, 1, 9, b, b); + !c2 ? c2 = d : c2.nj(d); + } + return c2; + } + function ek(a, b, c2, d) { + Mb((c2 & Ove) == 0, "flatMap does not support SUBSIZED characteristic"); + Mb((c2 & 4) == 0, "flatMap does not support SORTED characteristic"); + Qb(a); + Qb(b); + return new Mk(a, b, c2, d); + } + function fz(a, b) { + vFb(b, "Cannot suppress a null exception."); + mFb(b != a, "Exception can not suppress itself."); + if (a.i) { + return; + } + a.k == null ? a.k = cD(WC(rJ, 1), Nve, 82, 0, [b]) : a.k[a.k.length] = b; + } + function DLb(a, b) { + var c2; + c2 = ELb(a.b.ag(), b.b.ag()); + if (c2 != 0) { + return c2; + } + switch (a.b.ag().g) { + case 1: + case 2: + return hgb(a.b.Nf(), b.b.Nf()); + case 3: + case 4: + return hgb(b.b.Nf(), a.b.Nf()); + } + return 0; + } + function eUb(a) { + var b, c2, d; + d = a.e.c.length; + a.a = YC(kE, [Nve, Pwe], [53, 28], 15, [d, d], 2); + for (c2 = new Anb(a.c); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 290); + a.a[b.c.a][b.d.a] += RD(mQb(b, (yVb(), lVb)), 17).a; + } + } + function sAd(a, b) { + var c2, d, e, f2, g; + if (a == null) { + return null; + } else { + g = $C(hE, zwe, 28, 2 * b, 15, 1); + for (d = 0, e = 0; d < b; ++d) { + c2 = a[d] >> 4 & 15; + f2 = a[d] & 15; + g[e++] = oAd[c2]; + g[e++] = oAd[f2]; + } + return Ihb(g, 0, g.length); + } + } + function Fhb(a) { + var b, c2; + if (a >= txe) { + b = uxe + (a - txe >> 10 & 1023) & Bwe; + c2 = 56320 + (a - txe & 1023) & Bwe; + return String.fromCharCode(b) + ("" + String.fromCharCode(c2)); + } else { + return String.fromCharCode(a & Bwe); + } + } + function UMb(a, b) { + RMb(); + var c2, d, e, f2; + e = RD(RD(Qc(a.r, b), 21), 87); + if (e.gc() >= 2) { + d = RD(e.Kc().Pb(), 117); + c2 = a.u.Hc((Pod(), Kod)); + f2 = a.u.Hc(Ood); + return !d.a && !c2 && (e.gc() == 2 || f2); + } else { + return false; + } + } + function v3c(a, b, c2, d, e) { + var f2, g, h; + f2 = w3c(a, b, c2, d, e); + h = false; + while (!f2) { + n3c(a, e, true); + h = true; + f2 = w3c(a, b, c2, d, e); + } + h && n3c(a, e, false); + g = N2c(e); + if (g.c.length != 0) { + !!a.d && a.d.Gg(g); + v3c(a, e, c2, d, g); + } + } + function ind() { + ind = geb; + gnd = new jnd(LAe, 0); + end2 = new jnd("DIRECTED", 1); + hnd = new jnd("UNDIRECTED", 2); + cnd = new jnd("ASSOCIATION", 3); + fnd = new jnd("GENERALIZATION", 4); + dnd = new jnd("DEPENDENCY", 5); + } + function nsd(a, b) { + var c2; + if (!MCd(a)) { + throw Adb(new dgb(sHe)); + } + c2 = MCd(a); + switch (b.g) { + case 1: + return -(a.j + a.f); + case 2: + return a.i - c2.g; + case 3: + return a.j - c2.f; + case 4: + return -(a.i + a.g); + } + return 0; + } + function Jge(a, b, c2) { + var d, e, f2; + d = b.Lk(); + f2 = b.md(); + e = d.Jk() ? fge(a, 4, d, f2, null, kge(a, d, f2, ZD(d, 102) && (RD(d, 19).Bb & txe) != 0), true) : fge(a, d.tk() ? 2 : 1, d, f2, d.ik(), -1, true); + c2 ? c2.nj(e) : c2 = e; + return c2; + } + function lwb(a, b) { + var c2, d; + uFb(b); + d = a.b.c.length; + Rmb(a.b, b); + while (d > 0) { + c2 = d; + d = (d - 1) / 2 | 0; + if (a.a.Ne(Vmb(a.b, d), b) <= 0) { + $mb(a.b, c2, b); + return true; + } + $mb(a.b, c2, Vmb(a.b, d)); + } + $mb(a.b, d, b); + return true; + } + function sKb(a, b, c2, d) { + var e, f2; + e = 0; + if (!c2) { + for (f2 = 0; f2 < jKb; f2++) { + e = $wnd.Math.max(e, hKb(a.a[f2][b.g], d)); + } + } else { + e = hKb(a.a[c2.g][b.g], d); + } + b == (ZJb(), XJb) && !!a.b && (e = $wnd.Math.max(e, a.b.a)); + return e; + } + function Qqc(a, b) { + var c2, d, e, f2, g, h; + e = a.i; + f2 = b.i; + if (!e || !f2) { + return false; + } + if (e.i != f2.i || e.i == (qpd(), Xod) || e.i == (qpd(), ppd)) { + return false; + } + g = e.g.a; + c2 = g + e.j.a; + h = f2.g.a; + d = h + f2.j.a; + return g <= d && c2 >= h; + } + function A8c(a) { + switch (a.g) { + case 0: + return new o8c(); + case 1: + return new u8c(); + default: + throw Adb(new agb("No implementation is available for the width approximator " + (a.f != null ? a.f : "" + a.g))); + } + } + function rDd(a, b, c2, d) { + var e; + e = false; + if (bE(d)) { + e = true; + sDd(b, c2, WD(d)); + } + if (!e) { + if ($D(d)) { + e = true; + rDd(a, b, c2, d); + } + } + if (!e) { + if (ZD(d, 242)) { + e = true; + qDd(b, c2, RD(d, 242)); + } + } + if (!e) { + throw Adb(new Aeb(tIe)); + } + } + function uee(a, b) { + var c2, d, e; + c2 = b.qi(a.a); + if (c2) { + e = $Nd((!c2.b && (c2.b = new SVd((JTd(), FTd), C8, c2)), c2.b), rKe); + if (e != null) { + for (d = 1; d < (lke(), hke).length; ++d) { + if (lhb(hke[d], e)) { + return d; + } + } + } + } + return 0; + } + function vee2(a, b) { + var c2, d, e; + c2 = b.qi(a.a); + if (c2) { + e = $Nd((!c2.b && (c2.b = new SVd((JTd(), FTd), C8, c2)), c2.b), rKe); + if (e != null) { + for (d = 1; d < (lke(), ike).length; ++d) { + if (lhb(ike[d], e)) { + return d; + } + } + } + } + return 0; + } + function Ve(a, b) { + var c2, d, e, f2; + uFb(b); + f2 = a.a.gc(); + if (f2 < b.gc()) { + for (c2 = a.a.ec().Kc(); c2.Ob(); ) { + d = c2.Pb(); + b.Hc(d) && c2.Qb(); + } + } else { + for (e = b.Kc(); e.Ob(); ) { + d = e.Pb(); + a.a.Bc(d) != null; + } + } + return f2 != a.a.gc(); + } + function e_b(a) { + var b, c2; + c2 = ajd(xjd(cD(WC(l3, 1), Nve, 8, 0, [a.i.n, a.n, a.a]))); + b = a.i.d; + switch (a.j.g) { + case 1: + c2.b -= b.d; + break; + case 2: + c2.a += b.c; + break; + case 3: + c2.b += b.a; + break; + case 4: + c2.a -= b.b; + } + return c2; + } + function edc(a) { + var b; + b = (Zcc(), RD(hs(new is(Mr(Z2b(a).a.Kc(), new ir()))), 18).c.i); + while (b.k == (r3b(), o3b)) { + pQb(b, (Ywc(), twc), (Geb(), true)); + b = RD(hs(new is(Mr(Z2b(b).a.Kc(), new ir()))), 18).c.i; + } + } + function BMc(a, b, c2, d) { + var e, f2, g, h; + h = aMc(b, d); + for (g = h.Kc(); g.Ob(); ) { + e = RD(g.Pb(), 12); + a.d[e.p] = a.d[e.p] + a.c[c2.p]; + } + h = aMc(c2, d); + for (f2 = h.Kc(); f2.Ob(); ) { + e = RD(f2.Pb(), 12); + a.d[e.p] = a.d[e.p] - a.c[b.p]; + } + } + function Isd(a, b, c2) { + var d, e; + for (e = new dMd((!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a)); e.e != e.i.gc(); ) { + d = RD(bMd(e), 27); + Byd(d, d.i + b, d.j + c2); + } + xgb((!a.b && (a.b = new C5d(G4, a, 12, 3)), a.b), new Osd(b, c2)); + } + function $yb(a, b, c2, d) { + var e, f2; + f2 = b; + e = f2.d == null || a.a.Ne(c2.d, f2.d) > 0 ? 1 : 0; + while (f2.a[e] != c2) { + f2 = f2.a[e]; + e = a.a.Ne(c2.d, f2.d) > 0 ? 1 : 0; + } + f2.a[e] = d; + d.b = c2.b; + d.a[0] = c2.a[0]; + d.a[1] = c2.a[1]; + c2.a[0] = null; + c2.a[1] = null; + } + function zIb(a) { + var b, c2, d, e; + b = new bnb(); + c2 = $C(xdb, Hye, 28, a.a.c.length, 16, 1); + Snb(c2, c2.length); + for (e = new Anb(a.a); e.a < e.c.c.length; ) { + d = RD(ynb(e), 125); + if (!c2[d.d]) { + ZEb(b.c, d); + yIb(a, d, c2); + } + } + return b; + } + function UXb(a, b) { + var c2, d, e, f2, g; + e = b == 1 ? MXb : LXb; + for (d = e.a.ec().Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 88); + for (g = RD(Qc(a.f.c, c2), 21).Kc(); g.Ob(); ) { + f2 = RD(g.Pb(), 42); + Ymb(a.b.b, f2.b); + Ymb(a.b.a, RD(f2.b, 86).d); + } + } + } + function P9b(a, b) { + var c2; + b.Ug("Hierarchical port position processing", 1); + c2 = a.b; + c2.c.length > 0 && O9b((tFb(0, c2.c.length), RD(c2.c[0], 30)), a); + c2.c.length > 1 && O9b(RD(Vmb(c2, c2.c.length - 1), 30), a); + b.Vg(); + } + function Sod(a) { + Pod(); + var b, c2; + b = ysb(Lod, cD(WC(D3, 1), jwe, 279, 0, [Nod])); + if (dy(Tx(b, a)) > 1) { + return false; + } + c2 = ysb(Kod, cD(WC(D3, 1), jwe, 279, 0, [Jod, Ood])); + if (dy(Tx(c2, a)) > 1) { + return false; + } + return true; + } + function FBd(a, b) { + var c2; + c2 = Xjb((YSd(), XSd), a); + ZD(c2, 507) ? $jb(XSd, a, new B5d(this, b)) : $jb(XSd, a, this); + BBd(this, b); + if (b == (jTd(), iTd)) { + this.wb = RD(this, 2038); + RD(b, 2040); + } else { + this.wb = (lTd(), kTd); + } + } + function Lae(b) { + var c2, d, e; + if (b == null) { + return null; + } + c2 = null; + for (d = 0; d < nAd.length; ++d) { + try { + return b2d(nAd[d], b); + } catch (a) { + a = zdb(a); + if (ZD(a, 33)) { + e = a; + c2 = e; + } else + throw Adb(a); + } + } + throw Adb(new RSd(c2)); + } + function Mrb() { + Mrb = geb; + Krb = cD(WC(qJ, 1), Nve, 2, 6, ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"]); + Lrb = cD(WC(qJ, 1), Nve, 2, 6, ["Jan", "Feb", "Mar", "Apr", Gwe, "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"]); + } + function qBb(a) { + var b, c2, d; + b = lhb(typeof b, Yxe) ? null : new gFb(); + if (!b) { + return; + } + SAb(); + c2 = (d = 900, d >= Awe ? "error" : d >= 900 ? "warn" : d >= 800 ? "info" : "log"); + eFb(c2, a.a); + !!a.b && fFb(b, c2, a.b, "Exception: ", true); + } + function mQb(a, b) { + var c2, d; + d = (!a.q && (a.q = new Tsb()), Wjb(a.q, b)); + if (d != null) { + return d; + } + c2 = b.Sg(); + ZD(c2, 4) && (c2 == null ? (!a.q && (a.q = new Tsb()), _jb(a.q, b)) : (!a.q && (a.q = new Tsb()), Zjb(a.q, b, c2)), a); + return c2; + } + function sXb() { + sXb = geb; + nXb = new tXb("P1_CYCLE_BREAKING", 0); + oXb = new tXb("P2_LAYERING", 1); + pXb = new tXb("P3_NODE_ORDERING", 2); + qXb = new tXb("P4_NODE_PLACEMENT", 3); + rXb = new tXb("P5_EDGE_ROUTING", 4); + } + function KZb(a, b) { + CZb(); + var c2; + if (a.c == b.c) { + if (a.b == b.b || rZb(a.b, b.b)) { + c2 = oZb(a.b) ? 1 : -1; + if (a.a && !b.a) { + return c2; + } else if (!a.a && b.a) { + return -c2; + } + } + return hgb(a.b.g, b.b.g); + } else { + return Qfb(a.c, b.c); + } + } + function E3c(a, b) { + var c2, d, e; + if (p3c(a, b)) { + return true; + } + for (d = new Anb(b); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 27); + e = R2c(c2); + if (o3c(a, c2, e)) { + return true; + } + if (C3c(a, c2) - a.g <= a.a) { + return true; + } + } + return false; + } + function ncd() { + ncd = geb; + mcd = (Kcd(), Jcd); + jcd = Fcd; + icd = Dcd; + gcd = zcd; + hcd = Bcd; + fcd = new A3b(8); + ecd = new mGd((umd(), tld), fcd); + kcd = new mGd(fmd, 8); + lcd = Hcd; + bcd = ucd; + ccd = wcd; + dcd = new mGd(Mkd, (Geb(), false)); + } + function hkd() { + hkd = geb; + ekd = new A3b(15); + dkd = new mGd((umd(), tld), ekd); + gkd = new mGd(fmd, 15); + fkd = new mGd(Rld, sgb(0)); + $jd = Wkd; + akd = kld; + ckd = pld; + Xjd = new mGd(Dkd, KGe); + _jd = ald; + bkd = nld; + Yjd = Fkd; + Zjd = Kkd; + } + function JGd(a) { + if ((!a.b && (a.b = new Yie(E4, a, 4, 7)), a.b).i != 1 || (!a.c && (a.c = new Yie(E4, a, 5, 8)), a.c).i != 1) { + throw Adb(new agb(JIe)); + } + return AGd(RD(QHd((!a.b && (a.b = new Yie(E4, a, 4, 7)), a.b), 0), 84)); + } + function KGd(a) { + if ((!a.b && (a.b = new Yie(E4, a, 4, 7)), a.b).i != 1 || (!a.c && (a.c = new Yie(E4, a, 5, 8)), a.c).i != 1) { + throw Adb(new agb(JIe)); + } + return BGd(RD(QHd((!a.b && (a.b = new Yie(E4, a, 4, 7)), a.b), 0), 84)); + } + function MGd(a) { + if ((!a.b && (a.b = new Yie(E4, a, 4, 7)), a.b).i != 1 || (!a.c && (a.c = new Yie(E4, a, 5, 8)), a.c).i != 1) { + throw Adb(new agb(JIe)); + } + return BGd(RD(QHd((!a.c && (a.c = new Yie(E4, a, 5, 8)), a.c), 0), 84)); + } + function LGd(a) { + if ((!a.b && (a.b = new Yie(E4, a, 4, 7)), a.b).i != 1 || (!a.c && (a.c = new Yie(E4, a, 5, 8)), a.c).i != 1) { + throw Adb(new agb(JIe)); + } + return AGd(RD(QHd((!a.c && (a.c = new Yie(E4, a, 5, 8)), a.c), 0), 84)); + } + function bJd(a, b, c2) { + var d, e, f2; + ++a.j; + e = a.Ej(); + if (b >= e || b < 0) + throw Adb(new veb(MIe + b + NIe + e)); + if (c2 >= e || c2 < 0) + throw Adb(new veb(OIe + c2 + NIe + e)); + b != c2 ? d = (f2 = a.Cj(c2), a.qj(b, f2), f2) : d = a.xj(c2); + return d; + } + function Lje(a) { + var b, c2, d; + d = a; + if (a) { + b = 0; + for (c2 = a.Eh(); c2; c2 = c2.Eh()) { + if (++b > wxe) { + return Lje(c2); + } + d = c2; + if (c2 == a) { + throw Adb(new dgb("There is a cycle in the containment hierarchy of " + a)); + } + } + } + return d; + } + function Fe(a) { + var b, c2, d; + d = new Jyb(pve, "[", "]"); + for (c2 = a.Kc(); c2.Ob(); ) { + b = c2.Pb(); + Gyb(d, dE(b) === dE(a) ? "(this Collection)" : b == null ? vve : jeb(b)); + } + return !d.a ? d.c : d.e.length == 0 ? d.a.a : d.a.a + ("" + d.e); + } + function p3c(a, b) { + var c2, d; + d = false; + if (b.gc() < 2) { + return false; + } + for (c2 = 0; c2 < b.gc(); c2++) { + c2 < b.gc() - 1 ? d = d | o3c(a, RD(b.Xb(c2), 27), RD(b.Xb(c2 + 1), 27)) : d = d | o3c(a, RD(b.Xb(c2), 27), RD(b.Xb(0), 27)); + } + return d; + } + function wAd(a, b) { + var c2; + if (b != a.a) { + c2 = null; + !!a.a && (c2 = RD(a.a, 54).Th(a, 4, t7, c2)); + !!b && (c2 = RD(b, 54).Rh(a, 4, t7, c2)); + c2 = rAd(a, b, c2); + !!c2 && c2.oj(); + } else + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 1, b, b)); + } + function p2d(a, b) { + var c2; + if (b != a.e) { + !!a.e && oae($9d(a.e), a); + !!b && (!b.b && (b.b = new pae(new lae())), nae(b.b, a)); + c2 = f2d(a, b, null); + !!c2 && c2.oj(); + } else + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 4, b, b)); + } + function $mc(a, b) { + var c2; + c2 = b.o; + if (Dmd(a.f)) { + a.j.a = $wnd.Math.max(a.j.a, c2.a); + a.j.b += c2.b; + a.d.c.length > 1 && (a.j.b += a.e); + } else { + a.j.a += c2.a; + a.j.b = $wnd.Math.max(a.j.b, c2.b); + a.d.c.length > 1 && (a.j.a += a.e); + } + } + function Mnc() { + Mnc = geb; + Jnc = cD(WC(E3, 1), NAe, 64, 0, [(qpd(), Yod), Xod, npd]); + Inc = cD(WC(E3, 1), NAe, 64, 0, [Xod, npd, ppd]); + Knc = cD(WC(E3, 1), NAe, 64, 0, [npd, ppd, Yod]); + Lnc = cD(WC(E3, 1), NAe, 64, 0, [ppd, Yod, Xod]); + } + function Upc(a, b, c2, d) { + var e, f2, g, h, i2, j, k; + g = a.c.d; + h = a.d.d; + if (g.j == h.j) { + return; + } + k = a.b; + e = g.j; + i2 = null; + while (e != h.j) { + i2 = b == 0 ? tpd(e) : rpd(e); + f2 = $pc(e, k.d[e.g], c2); + j = $pc(i2, k.d[i2.g], c2); + Mub(d, $id(f2, j)); + e = i2; + } + } + function OJc(a, b, c2, d) { + var e, f2, g, h, i2; + g = hMc(a.a, b, c2); + h = RD(g.a, 17).a; + f2 = RD(g.b, 17).a; + if (d) { + i2 = RD(mQb(b, (Ywc(), Iwc)), 10); + e = RD(mQb(c2, Iwc), 10); + if (!!i2 && !!e) { + Slc(a.b, i2, e); + h += a.b.i; + f2 += a.b.e; + } + } + return h > f2; + } + function OLc(a) { + var b, c2, d, e, f2, g, h, i2, j; + this.a = LLc(a); + this.b = new bnb(); + for (c2 = a, d = 0, e = c2.length; d < e; ++d) { + b = c2[d]; + f2 = new bnb(); + Rmb(this.b, f2); + for (h = b, i2 = 0, j = h.length; i2 < j; ++i2) { + g = h[i2]; + Rmb(f2, new dnb(g.j)); + } + } + } + function QLc(a, b, c2) { + var d, e, f2; + f2 = 0; + d = c2[b]; + if (b < c2.length - 1) { + e = c2[b + 1]; + if (a.b[b]) { + f2 = iNc(a.d, d, e); + f2 += lMc(a.a, d, (qpd(), Xod)); + f2 += lMc(a.a, e, ppd); + } else { + f2 = gMc(a.a, d, e); + } + } + a.c[b] && (f2 += nMc(a.a, d)); + return f2; + } + function r0b(a, b, c2, d, e) { + var f2, g, h, i2; + i2 = null; + for (h = new Anb(d); h.a < h.c.c.length; ) { + g = RD(ynb(h), 453); + if (g != c2 && Wmb(g.e, e, 0) != -1) { + i2 = g; + break; + } + } + f2 = s0b(e); + Y0b(f2, c2.b); + Z0b(f2, i2.b); + Rc(a.a, e, new J0b(f2, b, c2.f)); + } + function h2b(a) { + var b, c2, d, e; + if (Emd(RD(mQb(a.b, (yCc(), rAc)), 88))) { + return 0; + } + b = 0; + for (d = new Anb(a.a); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 10); + if (c2.k == (r3b(), p3b)) { + e = c2.o.a; + b = $wnd.Math.max(b, e); + } + } + return b; + } + function Tlc(a) { + while (a.g.c != 0 && a.d.c != 0) { + if (amc(a.g).c > amc(a.d).c) { + a.i += a.g.c; + cmc(a.d); + } else if (amc(a.d).c > amc(a.g).c) { + a.e += a.d.c; + cmc(a.g); + } else { + a.i += _lc(a.g); + a.e += _lc(a.d); + cmc(a.g); + cmc(a.d); + } + } + } + function vTc(a, b, c2) { + var d, e, f2, g; + f2 = b.q; + g = b.r; + new bTc((fTc(), dTc), b, f2, 1); + new bTc(dTc, f2, g, 1); + for (e = new Anb(c2); e.a < e.c.c.length; ) { + d = RD(ynb(e), 118); + if (d != f2 && d != b && d != g) { + PTc(a.a, d, b); + PTc(a.a, d, g); + } + } + } + function vVc(a, b, c2, d) { + a.a.d = $wnd.Math.min(b, c2); + a.a.a = $wnd.Math.max(b, d) - a.a.d; + if (b < c2) { + a.b = 0.5 * (b + c2); + a.g = CEe * a.b + 0.9 * b; + a.f = CEe * a.b + 0.9 * c2; + } else { + a.b = 0.5 * (b + d); + a.g = CEe * a.b + 0.9 * d; + a.f = CEe * a.b + 0.9 * b; + } + } + function zZc(a) { + var b, c2, d, e; + if (a.b != 0) { + b = new Yub(); + for (e = Sub(a, 0); e.b != e.d.c; ) { + d = RD(evb(e), 40); + ye(b, $Wc(d)); + c2 = d.e; + c2.a = RD(mQb(d, (q$c(), o$c)), 17).a; + c2.b = RD(mQb(d, p$c), 17).a; + } + return b; + } + return new Yub(); + } + function t8b(a) { + switch (RD(mQb(a, (yCc(), UAc)), 171).g) { + case 1: + pQb(a, UAc, (cxc(), _wc)); + break; + case 2: + pQb(a, UAc, (cxc(), axc)); + break; + case 3: + pQb(a, UAc, (cxc(), Zwc)); + break; + case 4: + pQb(a, UAc, (cxc(), $wc)); + } + } + function Whc(a, b, c2) { + var d; + c2.Ug("Self-Loop routing", 1); + d = Xhc(b); + fE(mQb(b, (rid(), qid))); + FDb(GDb(CDb(CDb(EDb(new SDb(null, new Swb(b.b, 16)), new $hc()), new aic()), new cic()), new eic()), new gic(a, d)); + c2.Vg(); + } + function $uc() { + $uc = geb; + Yuc = new _uc(LAe, 0); + Vuc = new _uc(Nye, 1); + Zuc = new _uc(Oye, 2); + Xuc = new _uc("LEFT_RIGHT_CONSTRAINT_LOCKING", 3); + Wuc = new _uc("LEFT_RIGHT_CONNECTION_LOCKING", 4); + Uuc = new _uc(EBe, 5); + } + function tWc(a, b, c2) { + var d, e, f2, g, h, i2, j; + h = c2.a / 2; + f2 = c2.b / 2; + d = $wnd.Math.abs(b.a - a.a); + e = $wnd.Math.abs(b.b - a.b); + i2 = 1; + j = 1; + d > h && (i2 = h / d); + e > f2 && (j = f2 / e); + g = $wnd.Math.min(i2, j); + a.a += g * (b.a - a.a); + a.b += g * (b.b - a.b); + } + function I8c(a, b, c2, d, e) { + var f2, g; + g = false; + f2 = RD(Vmb(c2.b, 0), 27); + while (V8c(a, b, f2, d, e)) { + g = true; + T9c(c2, f2); + if (c2.b.c.length == 0) { + break; + } + f2 = RD(Vmb(c2.b, 0), 27); + } + c2.b.c.length == 0 && Fad(c2.j, c2); + g && gad(b.q); + return g; + } + function Eid(a, b) { + tid(); + var c2, d, e, f2; + if (b.b < 2) { + return false; + } + f2 = Sub(b, 0); + c2 = RD(evb(f2), 8); + d = c2; + while (f2.b != f2.d.c) { + e = RD(evb(f2), 8); + if (Did(a, d, e)) { + return true; + } + d = e; + } + if (Did(a, d, c2)) { + return true; + } + return false; + } + function Bxd(a, b, c2, d) { + var e, f2; + if (c2 == 0) { + return !a.o && (a.o = new DVd((pvd(), mvd), X4, a, 0)), BVd(a.o, b, d); + } + return f2 = RD(vYd((e = RD(Ywd(a, 16), 29), !e ? a.ii() : e), c2), 69), f2.wk().Ak(a, Wwd(a), c2 - AYd(a.ii()), b, d); + } + function BBd(a, b) { + var c2; + if (b != a.sb) { + c2 = null; + !!a.sb && (c2 = RD(a.sb, 54).Th(a, 1, n7, c2)); + !!b && (c2 = RD(b, 54).Rh(a, 1, n7, c2)); + c2 = hBd(a, b, c2); + !!c2 && c2.oj(); + } else + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 4, b, b)); + } + function YDd(a, b) { + var c2, d, e, f2; + if (b) { + e = vDd(b, "x"); + c2 = new ZEd(a); + Hzd(c2.a, (uFb(e), e)); + f2 = vDd(b, "y"); + d = new $Ed(a); + Izd(d.a, (uFb(f2), f2)); + } else { + throw Adb(new CDd("All edge sections need an end point.")); + } + } + function WDd(a, b) { + var c2, d, e, f2; + if (b) { + e = vDd(b, "x"); + c2 = new WEd(a); + Ozd(c2.a, (uFb(e), e)); + f2 = vDd(b, "y"); + d = new XEd(a); + Pzd(d.a, (uFb(f2), f2)); + } else { + throw Adb(new CDd("All edge sections need a start point.")); + } + } + function hBb(a, b) { + var c2, d, e, f2, g, h, i2; + for (d = kBb(a), f2 = 0, h = d.length; f2 < h; ++f2) { + qBb(b); + } + i2 = !dBb && a.e ? dBb ? null : a.d : null; + while (i2) { + for (c2 = kBb(i2), e = 0, g = c2.length; e < g; ++e) { + qBb(b); + } + i2 = !dBb && i2.e ? dBb ? null : i2.d : null; + } + } + function aXb(a, b) { + var c2, d; + d = RD(mQb(b, (yCc(), BBc)), 101); + pQb(b, (Ywc(), Fwc), d); + c2 = b.e; + !!c2 && (FDb(new SDb(null, new Swb(c2.a, 16)), new fXb(a)), FDb(EDb(new SDb(null, new Swb(c2.b, 16)), new hXb()), new jXb(a))); + } + function r3b() { + r3b = geb; + p3b = new s3b("NORMAL", 0); + o3b = new s3b("LONG_EDGE", 1); + m3b = new s3b("EXTERNAL_PORT", 2); + q3b = new s3b("NORTH_SOUTH_PORT", 3); + n3b = new s3b("LABEL", 4); + l3b = new s3b("BREAKING_POINT", 5); + } + function x7b(a) { + var b, c2, d, e; + b = false; + if (nQb(a, (Ywc(), cwc))) { + c2 = RD(mQb(a, cwc), 85); + for (e = new Anb(a.j); e.a < e.c.c.length; ) { + d = RD(ynb(e), 12); + if (v7b(d)) { + if (!b) { + u7b(Y2b(a)); + b = true; + } + y7b(RD(c2.xc(d), 314)); + } + } + } + } + function GFd(a) { + var b, c2, d, e, f2, g, h, i2, j; + j = HFd(a); + c2 = a.e; + f2 = c2 != null; + f2 && sDd(j, FIe, a.e); + h = a.k; + g = !!h; + g && sDd(j, "type", ps(a.k)); + d = cve(a.j); + e = !d; + if (e) { + i2 = new MB(); + sC(j, lIe, i2); + b = new SFd(i2); + xgb(a.j, b); + } + return j; + } + function Zv(a) { + var b, c2, d, e; + e = Thb((dk(a.gc(), "size"), new cib()), 123); + d = true; + for (c2 = gn(a).Kc(); c2.Ob(); ) { + b = RD(c2.Pb(), 44); + d || (e.a += pve, e); + d = false; + Yhb(Thb(Yhb(e, b.ld()), 61), b.md()); + } + return (e.a += "}", e).a; + } + function AD(a, b) { + var c2, d, e; + b &= 63; + if (b < 22) { + c2 = a.l << b; + d = a.m << b | a.l >> 22 - b; + e = a.h << b | a.m >> 22 - b; + } else if (b < 44) { + c2 = 0; + d = a.l << b - 22; + e = a.m << b - 22 | a.l >> 44 - b; + } else { + c2 = 0; + d = 0; + e = a.l << b - 44; + } + return hD(c2 & dxe, d & dxe, e & exe); + } + function Neb(a) { + Meb == null && (Meb = new RegExp("^\\s*[+-]?(NaN|Infinity|((\\d+\\.?\\d*)|(\\.\\d+))([eE][+-]?\\d+)?[dDfF]?)\\s*$")); + if (!Meb.test(a)) { + throw Adb(new Vgb(nxe + a + '"')); + } + return parseFloat(a); + } + function PXb(a, b) { + var c2, d, e, f2, g; + e = b == 1 ? MXb : LXb; + for (d = e.a.ec().Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 88); + for (g = RD(Qc(a.f.c, c2), 21).Kc(); g.Ob(); ) { + f2 = RD(g.Pb(), 42); + Rmb(a.b.b, RD(f2.b, 86)); + Rmb(a.b.a, RD(f2.b, 86).d); + } + } + } + function rqc(a, b) { + var c2, d, e, f2; + f2 = b.b.j; + a.a = $C(kE, Pwe, 28, f2.c.length, 15, 1); + e = 0; + for (d = 0; d < f2.c.length; d++) { + c2 = (tFb(d, f2.c.length), RD(f2.c[d], 12)); + c2.e.c.length == 0 && c2.g.c.length == 0 ? e += 1 : e += 3; + a.a[d] = e; + } + } + function tuc() { + tuc = geb; + ouc = new vuc("ALWAYS_UP", 0); + nuc = new vuc("ALWAYS_DOWN", 1); + quc = new vuc("DIRECTION_UP", 2); + puc = new vuc("DIRECTION_DOWN", 3); + suc = new vuc("SMART_UP", 4); + ruc = new vuc("SMART_DOWN", 5); + } + function vid(a, b) { + if (a < 0 || b < 0) { + throw Adb(new agb("k and n must be positive")); + } else if (b > a) { + throw Adb(new agb("k must be smaller than n")); + } else + return b == 0 || b == a ? 1 : a == 0 ? 0 : Bid(a) / (Bid(b) * Bid(a - b)); + } + function msd(a, b) { + var c2, d, e, f2; + c2 = new zId(a); + while (c2.g == null && !c2.c ? sId(c2) : c2.g == null || c2.i != 0 && RD(c2.g[c2.i - 1], 51).Ob()) { + f2 = RD(tId(c2), 58); + if (ZD(f2, 167)) { + d = RD(f2, 167); + for (e = 0; e < b.length; e++) { + b[e].Kg(d); + } + } + } + } + function Fyd(a) { + var b; + if ((a.Db & 64) != 0) + return kyd(a); + b = new Shb(kyd(a)); + b.a += " (height: "; + Khb(b, a.f); + b.a += ", width: "; + Khb(b, a.g); + b.a += ", x: "; + Khb(b, a.i); + b.a += ", y: "; + Khb(b, a.j); + b.a += ")"; + return b.a; + } + function Gn(a) { + var b, c2, d, e, f2, g, h; + b = new gub(); + for (d = a, e = 0, f2 = d.length; e < f2; ++e) { + c2 = d[e]; + g = Qb(c2.ld()); + h = dub(b, g, Qb(c2.md())); + if (h != null) { + throw Adb(new agb("duplicate key: " + g)); + } + } + this.b = (yob(), new uqb(b)); + } + function bob(a) { + var b, c2, d, e, f2; + if (a == null) { + return vve; + } + f2 = new Jyb(pve, "[", "]"); + for (c2 = a, d = 0, e = c2.length; d < e; ++d) { + b = c2[d]; + Gyb(f2, String.fromCharCode(b)); + } + return !f2.a ? f2.c : f2.e.length == 0 ? f2.a.a : f2.a.a + ("" + f2.e); + } + function OUb() { + OUb = geb; + IUb = (TUb(), SUb); + HUb = new lGd(Rze, IUb); + sgb(1); + GUb = new lGd(Sze, sgb(300)); + sgb(0); + LUb = new lGd(Tze, sgb(0)); + MUb = new lGd(Uze, Vze); + JUb = new lGd(Wze, 5); + NUb = SUb; + KUb = RUb; + } + function K6d(a, b) { + var c2; + if (b != null && !a.c.Hk().fk(b)) { + c2 = ZD(b, 58) ? RD(b, 58).Dh().zb : nfb(rb(b)); + throw Adb(new Ifb(KHe + a.c.xe() + "'s type '" + a.c.Hk().xe() + "' does not permit a value of type '" + c2 + "'")); + } + } + function k0b(a, b, c2) { + var d, e; + e = new Jkb(a.b, 0); + while (e.b < e.d.gc()) { + d = (sFb(e.b < e.d.gc()), RD(e.d.Xb(e.c = e.b++), 72)); + if (dE(mQb(d, (Ywc(), Dwc))) !== dE(b)) { + continue; + } + e2b(d.n, Y2b(a.c.i), c2); + Ckb(e); + Rmb(b.b, d); + } + } + function Arc(a) { + var b, c2; + c2 = $wnd.Math.sqrt((a.k == null && (a.k = tsc(a, new Esc())), Kfb(a.k) / (a.b * (a.g == null && (a.g = qsc(a, new Csc())), Kfb(a.g))))); + b = Ydb(Hdb($wnd.Math.round(c2))); + b = $wnd.Math.min(b, a.f); + return b; + } + function sse() { + var a, b, c2; + b = 0; + for (a = 0; a < "X".length; a++) { + c2 = rse((BFb(a, "X".length), "X".charCodeAt(a))); + if (c2 == 0) + throw Adb(new Lqe((BFb(a, "X".length + 1), "Unknown Option: " + "X".substr(a)))); + b |= c2; + } + return b; + } + function R3b() { + J3b(); + v2b.call(this); + this.j = (qpd(), opd); + this.a = new pjd(); + new T2b(); + this.f = (dk(2, iwe), new cnb(2)); + this.e = (dk(4, iwe), new cnb(4)); + this.g = (dk(4, iwe), new cnb(4)); + this.b = new h4b(this.e, this.g); + } + function A6b(a, b) { + var c2, d; + if (Heb(TD(mQb(b, (Ywc(), Nwc))))) { + return false; + } + d = b.c.i; + if (a == (cxc(), Zwc)) { + if (d.k == (r3b(), n3b)) { + return false; + } + } + c2 = RD(mQb(d, (yCc(), UAc)), 171); + if (c2 == $wc) { + return false; + } + return true; + } + function B6b(a, b) { + var c2, d; + if (Heb(TD(mQb(b, (Ywc(), Nwc))))) { + return false; + } + d = b.d.i; + if (a == (cxc(), _wc)) { + if (d.k == (r3b(), n3b)) { + return false; + } + } + c2 = RD(mQb(d, (yCc(), UAc)), 171); + if (c2 == axc) { + return false; + } + return true; + } + function a7b(a, b) { + var c2, d, e, f2, g, h, i2; + g = a.d; + i2 = a.o; + h = new Uid2(-g.b, -g.d, g.b + i2.a + g.c, g.d + i2.b + g.a); + for (d = b, e = 0, f2 = d.length; e < f2; ++e) { + c2 = d[e]; + !!c2 && Sid(h, c2.i); + } + g.b = -h.c; + g.d = -h.d; + g.c = h.b - g.b - i2.a; + g.a = h.a - g.d - i2.b; + } + function _gc(a, b) { + if (b.a) { + switch (RD(mQb(b.b, (Ywc(), Fwc)), 101).g) { + case 0: + case 1: + Roc(b); + case 2: + FDb(new SDb(null, new Swb(b.d, 16)), new mhc()); + aoc(a.a, b); + } + } else { + FDb(new SDb(null, new Swb(b.d, 16)), new mhc()); + } + } + function Xbd() { + Xbd = geb; + Sbd = new Ybd("CENTER_DISTANCE", 0); + Tbd = new Ybd("CIRCLE_UNDERLAP", 1); + Wbd = new Ybd("RECTANGLE_UNDERLAP", 2); + Ubd = new Ybd("INVERTED_OVERLAP", 3); + Vbd = new Ybd("MINIMUM_ROOT_DISTANCE", 4); + } + function Iqe(a) { + Gqe(); + var b, c2, d, e, f2; + if (a == null) + return null; + d = a.length; + e = d * 2; + b = $C(hE, zwe, 28, e, 15, 1); + for (c2 = 0; c2 < d; c2++) { + f2 = a[c2]; + f2 < 0 && (f2 += 256); + b[c2 * 2] = Fqe[f2 >> 4]; + b[c2 * 2 + 1] = Fqe[f2 & 15]; + } + return Ihb(b, 0, b.length); + } + function sn(a) { + fn(); + var b, c2, d; + d = a.c.length; + switch (d) { + case 0: + return en; + case 1: + b = RD(Ir(new Anb(a)), 44); + return xn(b.ld(), b.md()); + default: + c2 = RD(anb(a, $C(UK, Zve, 44, a.c.length, 0, 1)), 173); + return new Mx(c2); + } + } + function KWb(a) { + var b, c2, d, e, f2, g; + b = new wmb(); + c2 = new wmb(); + hmb(b, a); + hmb(c2, a); + while (c2.b != c2.c) { + e = RD(smb(c2), 36); + for (g = new Anb(e.a); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 10); + if (f2.e) { + d = f2.e; + hmb(b, d); + hmb(c2, d); + } + } + } + return b; + } + function e3b(a, b) { + switch (b.g) { + case 1: + return dr(a.j, (J3b(), F3b)); + case 2: + return dr(a.j, (J3b(), D3b)); + case 3: + return dr(a.j, (J3b(), H3b)); + case 4: + return dr(a.j, (J3b(), I3b)); + default: + return yob(), yob(), vob; + } + } + function Zlc(a, b) { + var c2, d, e; + c2 = $lc(b, a.e); + d = RD(Wjb(a.g.f, c2), 17).a; + e = a.a.c.length - 1; + if (a.a.c.length != 0 && RD(Vmb(a.a, e), 294).c == d) { + ++RD(Vmb(a.a, e), 294).a; + ++RD(Vmb(a.a, e), 294).b; + } else { + Rmb(a.a, new hmc(d)); + } + } + function tLc(a, b, c2) { + var d, e; + d = sLc(a, b, c2); + if (d != 0) { + return d; + } + if (nQb(b, (Ywc(), zwc)) && nQb(c2, zwc)) { + e = hgb(RD(mQb(b, zwc), 17).a, RD(mQb(c2, zwc), 17).a); + e < 0 ? uLc(a, b, c2) : e > 0 && uLc(a, c2, b); + return e; + } + return rLc(a, b, c2); + } + function $4c() { + $4c = geb; + R4c = (umd(), Qld); + Y4c = fmd; + K4c = kld; + L4c = nld; + M4c = pld; + J4c = ild; + N4c = sld; + Q4c = Lld; + H4c = (D4c(), o4c); + I4c = p4c; + T4c = v4c; + W4c = y4c; + U4c = w4c; + V4c = x4c; + O4c = r4c; + P4c = t4c; + S4c = u4c; + X4c = z4c; + Z4c = B4c; + G4c = n4c; + } + function P9c(a, b) { + var c2, d, e, f2, g; + if (a.e <= b) { + return a.g; + } + if (R9c(a, a.g, b)) { + return a.g; + } + f2 = a.r; + d = a.g; + g = a.r; + e = (f2 - d) / 2 + d; + while (d + 1 < f2) { + c2 = S9c(a, e, false); + if (c2.b <= e && c2.a <= b) { + g = e; + f2 = e; + } else { + d = e; + } + e = (f2 - d) / 2 + d; + } + return g; + } + function Eed(a, b, c2) { + var d; + d = zed(a, b, true); + Fqd(c2, "Recursive Graph Layout", d); + msd(b, cD(WC(j4, 1), rve, 536, 0, [new Bfd()])); + Hxd(b, (umd(), Tld)) || msd(b, cD(WC(j4, 1), rve, 536, 0, [new dgd()])); + Fed(a, b, null, c2); + Hqd(c2); + } + function Hqd(a) { + var b; + if (a.p == null) { + throw Adb(new dgb("The task has not begun yet.")); + } + if (!a.b) { + if (a.k) { + b = (gib(), Ndb(Hdb(Date.now()), Awe)); + a.q = Xdb(Vdb(b, a.o)) * 1e-9; + } + a.c < a.r && Iqd(a, a.r - a.c); + a.b = true; + } + } + function ssd(a) { + var b, c2, d; + d = new Ejd(); + Mub(d, new rjd(a.j, a.k)); + for (c2 = new dMd((!a.a && (a.a = new XZd(D4, a, 5)), a.a)); c2.e != c2.i.gc(); ) { + b = RD(bMd(c2), 377); + Mub(d, new rjd(b.a, b.b)); + } + Mub(d, new rjd(a.b, a.c)); + return d; + } + function QDd(a, b, c2, d, e) { + var f2, g, h, i2, j, k; + if (e) { + i2 = e.a.length; + f2 = new vue(i2); + for (k = (f2.b - f2.a) * f2.c < 0 ? (uue(), tue) : new Rue(f2); k.Ob(); ) { + j = RD(k.Pb(), 17); + h = xDd(e, j.a); + g = new PEd(a, b, c2, d); + RDd(g.a, g.b, g.c, g.d, h); + } + } + } + function Rx(b, c2) { + var d; + if (dE(b) === dE(c2)) { + return true; + } + if (ZD(c2, 21)) { + d = RD(c2, 21); + try { + return b.gc() == d.gc() && b.Ic(d); + } catch (a) { + a = zdb(a); + if (ZD(a, 169) || ZD(a, 212)) { + return false; + } else + throw Adb(a); + } + } + return false; + } + function Kzb(a, b, c2, d, e, f2) { + this.c = a; + switch (b.g) { + case 2: + if (a.a.Ne(e, c2) < 0) { + throw Adb(new agb(Sxe + e + Txe + c2)); + } + break; + case 1: + a.a.Ne(e, e); + break; + case 3: + a.a.Ne(c2, c2); + } + this.f = b; + this.b = c2; + this.a = d; + this.e = e; + this.d = f2; + } + function LKb(a, b) { + var c2; + Rmb(a.d, b); + c2 = b.Mf(); + if (a.c) { + a.e.a = $wnd.Math.max(a.e.a, c2.a); + a.e.b += c2.b; + a.d.c.length > 1 && (a.e.b += a.a); + } else { + a.e.a += c2.a; + a.e.b = $wnd.Math.max(a.e.b, c2.b); + a.d.c.length > 1 && (a.e.a += a.a); + } + } + function Ipc(a) { + var b, c2, d, e; + e = a.i; + b = e.b; + d = e.j; + c2 = e.g; + switch (e.a.g) { + case 0: + c2.a = (a.g.b.o.a - d.a) / 2; + break; + case 1: + c2.a = b.d.n.a + b.d.a.a; + break; + case 2: + c2.a = b.d.n.a + b.d.a.a - d.a; + break; + case 3: + c2.b = b.d.n.b + b.d.a.b; + } + } + function oOc(a, b, c2) { + var d, e, f2; + for (e = new is(Mr(W2b(c2).a.Kc(), new ir())); gs(e); ) { + d = RD(hs(e), 18); + if (!(!W0b(d) && !(!W0b(d) && d.c.i.c == d.d.i.c))) { + continue; + } + f2 = gOc(a, d, c2, new VOc()); + f2.c.length > 1 && (ZEb(b.c, f2), true); + } + } + function _id(a, b, c2, d, e) { + if (d < b || e < c2) { + throw Adb(new agb("The highx must be bigger then lowx and the highy must be bigger then lowy")); + } + a.a < b ? a.a = b : a.a > d && (a.a = d); + a.b < c2 ? a.b = c2 : a.b > e && (a.b = e); + return a; + } + function LFd(a) { + if (ZD(a, 143)) { + return EFd(RD(a, 143)); + } else if (ZD(a, 233)) { + return FFd(RD(a, 233)); + } else if (ZD(a, 23)) { + return GFd(RD(a, 23)); + } else { + throw Adb(new agb(wIe + Fe(new mob(cD(WC(jJ, 1), rve, 1, 5, [a]))))); + } + } + function ujb(a, b, c2, d, e) { + var f2, g, h; + f2 = true; + for (g = 0; g < d; g++) { + f2 = f2 & c2[g] == 0; + } + if (e == 0) { + hib(c2, d, a, 0, b); + g = b; + } else { + h = 32 - e; + f2 = f2 & c2[g] << h == 0; + for (g = 0; g < b - 1; g++) { + a[g] = c2[g + d] >>> e | c2[g + d + 1] << h; + } + a[g] = c2[g + d] >>> e; + ++g; + } + return f2; + } + function ZQc(a, b, c2, d) { + var e, f2, g; + if (b.k == (r3b(), o3b)) { + for (f2 = new is(Mr(Z2b(b).a.Kc(), new ir())); gs(f2); ) { + e = RD(hs(f2), 18); + g = e.c.i.k; + if (g == o3b && a.c.a[e.c.i.c.p] == d && a.c.a[b.c.p] == c2) { + return true; + } + } + } + return false; + } + function CD(a, b) { + var c2, d, e, f2; + b &= 63; + c2 = a.h & exe; + if (b < 22) { + f2 = c2 >>> b; + e = a.m >> b | c2 << 22 - b; + d = a.l >> b | a.m << 22 - b; + } else if (b < 44) { + f2 = 0; + e = c2 >>> b - 22; + d = a.m >> b - 22 | a.h << 44 - b; + } else { + f2 = 0; + e = 0; + d = c2 >>> b - 44; + } + return hD(d & dxe, e & dxe, f2 & exe); + } + function mmc(a, b, c2, d) { + var e; + this.b = d; + this.e = a == (RKc(), PKc); + e = b[c2]; + this.d = YC(xdb, [Nve, Hye], [183, 28], 16, [e.length, e.length], 2); + this.a = YC(kE, [Nve, Pwe], [53, 28], 15, [e.length, e.length], 2); + this.c = new Ylc(b, c2); + } + function Rmc(a) { + var b, c2, d; + a.k = new Si((qpd(), cD(WC(E3, 1), NAe, 64, 0, [opd, Yod, Xod, npd, ppd])).length, a.j.c.length); + for (d = new Anb(a.j); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 113); + b = c2.d.j; + Rc(a.k, b, c2); + } + a.e = Dnc(Ec(a.k)); + } + function sVc(a, b) { + var c2, d, e; + Ysb(a.d, b); + c2 = new zVc(); + Zjb(a.c, b, c2); + c2.f = tVc(b.c); + c2.a = tVc(b.d); + c2.d = (HUc(), e = b.c.i.k, e == (r3b(), p3b) || e == l3b); + c2.e = (d = b.d.i.k, d == p3b || d == l3b); + c2.b = b.c.j == (qpd(), ppd); + c2.c = b.d.j == Xod; + } + function sJb(a) { + var b, c2, d, e, f2; + f2 = lve; + e = lve; + for (d = new Anb(CIb(a)); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 218); + b = c2.e.e - c2.d.e; + c2.e == a && b < e ? e = b : b < f2 && (f2 = b); + } + e == lve && (e = -1); + f2 == lve && (f2 = -1); + return new Ptd(sgb(e), sgb(f2)); + } + function qTb(a, b) { + var c2, d, e; + e = Hze; + d = (IRb(), FRb); + e = $wnd.Math.abs(a.b); + c2 = $wnd.Math.abs(b.f - a.b); + if (c2 < e) { + e = c2; + d = GRb; + } + c2 = $wnd.Math.abs(a.a); + if (c2 < e) { + e = c2; + d = HRb; + } + c2 = $wnd.Math.abs(b.g - a.a); + if (c2 < e) { + e = c2; + d = ERb; + } + return d; + } + function adc(a, b) { + var c2, d, e, f2; + c2 = b.a.o.a; + f2 = new Rkb(Y2b(b.a).b, b.c, b.f + 1); + for (e = new Dkb(f2); e.b < e.d.gc(); ) { + d = (sFb(e.b < e.d.gc()), RD(e.d.Xb(e.c = e.b++), 30)); + if (d.c.a >= c2) { + _cc(a, b, d.p); + return true; + } + } + return false; + } + function EA(a, b, c2, d) { + var e, f2, g, h, i2, j; + g = c2.length; + f2 = 0; + e = -1; + j = Bhb((BFb(b, a.length + 1), a.substr(b)), (wvb(), uvb)); + for (h = 0; h < g; ++h) { + i2 = c2[h].length; + if (i2 > f2 && whb(j, Bhb(c2[h], uvb))) { + e = h; + f2 = i2; + } + } + e >= 0 && (d[0] = b + f2); + return e; + } + function gCd(a) { + var b; + if ((a.Db & 64) != 0) + return Fyd(a); + b = new dib(FHe); + !a.a || Zhb(Zhb((b.a += ' "', b), a.a), '"'); + Zhb(Uhb(Zhb(Uhb(Zhb(Uhb(Zhb(Uhb((b.a += " (", b), a.i), ","), a.j), " | "), a.g), ","), a.f), ")"); + return b.a; + } + function xge(a, b, c2) { + var d, e, f2, g, h; + h = pke(a.e.Dh(), b); + e = RD(a.g, 124); + d = 0; + for (g = 0; g < a.i; ++g) { + f2 = e[g]; + if (h.am(f2.Lk())) { + if (d == c2) { + vLd(a, g); + return nke(), RD(b, 69).xk() ? f2 : f2.md(); + } + ++d; + } + } + throw Adb(new veb(HJe + c2 + NIe + d)); + } + function Rqe(a) { + var b, c2, d; + b = a.c; + if (b == 2 || b == 7 || b == 1) { + return Vse(), Vse(), Ese; + } else { + d = Pqe(a); + c2 = null; + while ((b = a.c) != 2 && b != 7 && b != 1) { + if (!c2) { + c2 = (Vse(), Vse(), new iue(1)); + hue2(c2, d); + d = c2; + } + hue2(c2, Pqe(a)); + } + return d; + } + } + function Kb(a, b, c2) { + if (a < 0 || a > c2) { + return Jb(a, c2, "start index"); + } + if (b < 0 || b > c2) { + return Jb(b, c2, "end index"); + } + return hc("end index (%s) must not be less than start index (%s)", cD(WC(jJ, 1), rve, 1, 5, [sgb(b), sgb(a)])); + } + function dA(b, c2) { + var d, e, f2, g; + for (e = 0, f2 = b.length; e < f2; e++) { + g = b[e]; + try { + g[1] ? g[0].Um() && (c2 = cA(c2, g)) : g[0].Um(); + } catch (a) { + a = zdb(a); + if (ZD(a, 82)) { + d = a; + Qz(); + Wz(ZD(d, 486) ? RD(d, 486).ke() : d); + } else + throw Adb(a); + } + } + return c2; + } + function _cc(a, b, c2) { + var d, e, f2; + c2 != b.c + b.b.gc() && odc(b.a, wdc(b, c2 - b.c)); + f2 = b.a.c.p; + a.a[f2] = $wnd.Math.max(a.a[f2], b.a.o.a); + for (e = RD(mQb(b.a, (Ywc(), Mwc)), 15).Kc(); e.Ob(); ) { + d = RD(e.Pb(), 72); + pQb(d, Ycc, (Geb(), true)); + } + } + function Aic(a, b) { + var c2, d, e; + e = zic(b); + pQb(b, (Ywc(), xwc), e); + if (e) { + d = lve; + !!qtb(a.f, e) && (d = RD(Wd(qtb(a.f, e)), 17).a); + c2 = RD(Vmb(b.g, 0), 18); + Heb(TD(mQb(c2, Nwc))) || Zjb(a, e, sgb($wnd.Math.min(RD(mQb(c2, zwc), 17).a, d))); + } + } + function aGc(a, b, c2) { + var d, e, f2, g, h; + b.p = -1; + for (h = c3b(b, (BEc(), zEc)).Kc(); h.Ob(); ) { + g = RD(h.Pb(), 12); + for (e = new Anb(g.g); e.a < e.c.c.length; ) { + d = RD(ynb(e), 18); + f2 = d.d.i; + b != f2 && (f2.p < 0 ? c2.Fc(d) : f2.p > 0 && aGc(a, f2, c2)); + } + } + b.p = 0; + } + function Ahd(a) { + var b; + this.c = new Yub(); + this.f = a.e; + this.e = a.d; + this.i = a.g; + this.d = a.c; + this.b = a.b; + this.k = a.j; + this.a = a.a; + !a.i ? this.j = (b = RD(mfb(d3), 9), new Fsb(b, RD(WEb(b, b.length), 9), 0)) : this.j = a.i; + this.g = a.f; + } + function Wb(a) { + var b, c2, d, e; + b = Thb(Zhb(new dib("Predicates."), "and"), 40); + c2 = true; + for (e = new Dkb(a); e.b < e.d.gc(); ) { + d = (sFb(e.b < e.d.gc()), e.d.Xb(e.c = e.b++)); + c2 || (b.a += ",", b); + b.a += "" + d; + c2 = false; + } + return (b.a += ")", b).a; + } + function vgc(a, b, c2) { + var d, e, f2; + if (c2 <= b + 2) { + return; + } + e = (c2 - b) / 2 | 0; + for (d = 0; d < e; ++d) { + f2 = (tFb(b + d, a.c.length), RD(a.c[b + d], 12)); + $mb(a, b + d, (tFb(c2 - d - 1, a.c.length), RD(a.c[c2 - d - 1], 12))); + tFb(c2 - d - 1, a.c.length); + a.c[c2 - d - 1] = f2; + } + } + function Nmc(a, b, c2) { + var d, e, f2, g, h, i2, j, k; + f2 = a.d.p; + h = f2.e; + i2 = f2.r; + a.g = new DMc(i2); + g = a.d.o.c.p; + d = g > 0 ? h[g - 1] : $C(jR, WAe, 10, 0, 0, 1); + e = h[g]; + j = g < h.length - 1 ? h[g + 1] : $C(jR, WAe, 10, 0, 0, 1); + k = b == c2 - 1; + k ? pMc(a.g, e, j) : pMc(a.g, d, e); + } + function Vmc(a) { + var b; + this.j = new bnb(); + this.f = new _sb(); + this.b = (b = RD(mfb(E3), 9), new Fsb(b, RD(WEb(b, b.length), 9), 0)); + this.d = $C(kE, Pwe, 28, (qpd(), cD(WC(E3, 1), NAe, 64, 0, [opd, Yod, Xod, npd, ppd])).length, 15, 1); + this.g = a; + } + function D3c(a, b) { + var c2, d, e; + if (b.c.length != 0) { + c2 = E3c(a, b); + e = false; + while (!c2) { + n3c(a, b, true); + e = true; + c2 = E3c(a, b); + } + e && n3c(a, b, false); + d = N2c(b); + !!a.b && a.b.Gg(d); + a.a = C3c(a, (tFb(0, b.c.length), RD(b.c[0], 27))); + D3c(a, d); + } + } + function $vd(a, b) { + var c2, d, e; + d = vYd(a.Dh(), b); + c2 = b - a.ji(); + if (c2 < 0) { + if (!d) { + throw Adb(new agb(OHe + b + PHe)); + } else if (d.rk()) { + e = a.Ih(d); + e >= 0 ? a.ki(e) : Tvd(a, d); + } else { + throw Adb(new agb(KHe + d.xe() + LHe)); + } + } else { + Cvd(a, c2, d); + } + } + function ADd(a) { + var b, c2; + c2 = null; + b = false; + if (ZD(a, 211)) { + b = true; + c2 = RD(a, 211).a; + } + if (!b) { + if (ZD(a, 263)) { + b = true; + c2 = "" + RD(a, 263).a; + } + } + if (!b) { + if (ZD(a, 493)) { + b = true; + c2 = "" + RD(a, 493).a; + } + } + if (!b) { + throw Adb(new Aeb(tIe)); + } + return c2; + } + function gge(a, b, c2) { + var d, e, f2, g, h, i2; + i2 = pke(a.e.Dh(), b); + d = 0; + h = a.i; + e = RD(a.g, 124); + for (g = 0; g < a.i; ++g) { + f2 = e[g]; + if (i2.am(f2.Lk())) { + if (c2 == d) { + return g; + } + ++d; + h = g + 1; + } + } + if (c2 == d) { + return h; + } else { + throw Adb(new veb(HJe + c2 + NIe + d)); + } + } + function ucc(a, b) { + var c2, d, e, f2; + if (a.f.c.length == 0) { + return null; + } else { + f2 = new Tid(); + for (d = new Anb(a.f); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 72); + e = c2.o; + f2.b = $wnd.Math.max(f2.b, e.a); + f2.a += e.b; + } + f2.a += (a.f.c.length - 1) * b; + return f2; + } + } + function rOc(a) { + var b, c2, d, e; + c2 = new Yub(); + ye(c2, a.o); + d = new Fyb(); + while (c2.b != 0) { + b = RD(c2.b == 0 ? null : (sFb(c2.b != 0), Wub(c2, c2.a.a)), 515); + e = iOc(a, b, true); + e && Rmb(d.a, b); + } + while (d.a.c.length != 0) { + b = RD(Dyb(d), 515); + iOc(a, b, false); + } + } + function kid() { + kid = geb; + jid = new lid(Sye, 0); + cid = new lid("BOOLEAN", 1); + gid = new lid("INT", 2); + iid = new lid("STRING", 3); + did = new lid("DOUBLE", 4); + eid = new lid("ENUM", 5); + fid = new lid("ENUMSET", 6); + hid = new lid("OBJECT", 7); + } + function Sid(a, b) { + var c2, d, e, f2, g; + d = $wnd.Math.min(a.c, b.c); + f2 = $wnd.Math.min(a.d, b.d); + e = $wnd.Math.max(a.c + a.b, b.c + b.b); + g = $wnd.Math.max(a.d + a.a, b.d + b.a); + if (e < d) { + c2 = d; + d = e; + e = c2; + } + if (g < f2) { + c2 = f2; + f2 = g; + g = c2; + } + Rid(a, d, f2, e - d, g - f2); + } + function m3d(a, b) { + var c2, d; + if (a.f) { + while (b.Ob()) { + c2 = RD(b.Pb(), 76); + d = c2.Lk(); + if (ZD(d, 102) && (RD(d, 19).Bb & QHe) != 0 && (!a.e || d.pk() != C4 || d.Lj() != 0) && c2.md() != null) { + b.Ub(); + return true; + } + } + return false; + } else { + return b.Ob(); + } + } + function o3d(a, b) { + var c2, d; + if (a.f) { + while (b.Sb()) { + c2 = RD(b.Ub(), 76); + d = c2.Lk(); + if (ZD(d, 102) && (RD(d, 19).Bb & QHe) != 0 && (!a.e || d.pk() != C4 || d.Lj() != 0) && c2.md() != null) { + b.Pb(); + return true; + } + } + return false; + } else { + return b.Sb(); + } + } + function lke() { + lke = geb; + ike = cD(WC(qJ, 1), Nve, 2, 6, [TKe, UKe, VKe, WKe, XKe, YKe, FIe]); + hke = cD(WC(qJ, 1), Nve, 2, 6, [TKe, "empty", UKe, pKe, "elementOnly"]); + kke = cD(WC(qJ, 1), Nve, 2, 6, [TKe, "preserve", "replace", ZKe]); + jke = new Yee(); + } + function e2b(a, b, c2) { + var d, e, f2; + if (b == c2) { + return; + } + d = b; + do { + $id(a, d.c); + e = d.e; + if (e) { + f2 = d.d; + Zid(a, f2.b, f2.d); + $id(a, e.n); + d = Y2b(e); + } + } while (e); + d = c2; + do { + ojd(a, d.c); + e = d.e; + if (e) { + f2 = d.d; + njd(a, f2.b, f2.d); + ojd(a, e.n); + d = Y2b(e); + } + } while (e); + } + function Wlc(a, b, c2, d) { + var e, f2, g, h, i2; + if (d.f.c + d.i.c == 0) { + for (g = a.a[a.c], h = 0, i2 = g.length; h < i2; ++h) { + f2 = g[h]; + Zjb(d, f2, new dmc(a, f2, c2)); + } + } + e = RD(Wd(qtb(d.f, b)), 677); + e.b = 0; + e.c = e.f; + e.c == 0 || gmc(RD(Vmb(e.a, e.b), 294)); + return e; + } + function btc() { + btc = geb; + Zsc = new ctc("MEDIAN_LAYER", 0); + _sc = new ctc("TAIL_LAYER", 1); + Ysc = new ctc("HEAD_LAYER", 2); + $sc = new ctc("SPACE_EFFICIENT_LAYER", 3); + atc = new ctc("WIDEST_LAYER", 4); + Xsc = new ctc("CENTER_LAYER", 5); + } + function WGc(a) { + var b, c2, d, e; + a.e = 0; + for (e = Sub(a.f, 0); e.b != e.d.c; ) { + d = RD(evb(e), 10); + if (d.p >= a.d.b.c.length) { + b = new R4b(a.d); + b.p = d.p - 1; + Rmb(a.d.b, b); + c2 = new R4b(a.d); + c2.p = d.p; + Rmb(a.d.b, c2); + } + g3b(d, RD(Vmb(a.d.b, d.p), 30)); + } + } + function DVc(a, b, c2) { + var d, e, f2; + if (!a.b[b.g]) { + a.b[b.g] = true; + d = c2; + !d && (d = new YWc()); + Mub(d.b, b); + for (f2 = a.a[b.g].Kc(); f2.Ob(); ) { + e = RD(f2.Pb(), 65); + e.b != b && DVc(a, e.b, d); + e.c != b && DVc(a, e.c, d); + Mub(d.a, e); + } + return d; + } + return null; + } + function iMb(a) { + switch (a.g) { + case 0: + case 1: + case 2: + return qpd(), Yod; + case 3: + case 4: + case 5: + return qpd(), npd; + case 6: + case 7: + case 8: + return qpd(), ppd; + case 9: + case 10: + case 11: + return qpd(), Xod; + default: + return qpd(), opd; + } + } + function SOc(a, b) { + var c2; + if (a.c.length == 0) { + return false; + } + c2 = zDc((tFb(0, a.c.length), RD(a.c[0], 18)).c.i); + dOc(); + if (c2 == (wDc(), tDc) || c2 == sDc) { + return true; + } + return yDb(GDb(new SDb(null, new Swb(a, 16)), new $Oc()), new aPc(b)); + } + function KDd(a, b) { + if (ZD(b, 207)) { + return EDd(a, RD(b, 27)); + } else if (ZD(b, 193)) { + return FDd(a, RD(b, 123)); + } else if (ZD(b, 452)) { + return DDd(a, RD(b, 166)); + } else { + throw Adb(new agb(wIe + Fe(new mob(cD(WC(jJ, 1), rve, 1, 5, [b]))))); + } + } + function Ou(a, b, c2) { + var d, e; + this.f = a; + d = RD(Wjb(a.b, b), 260); + e = !d ? 0 : d.a; + Sb(c2, e); + if (c2 >= (e / 2 | 0)) { + this.e = !d ? null : d.c; + this.d = e; + while (c2++ < e) { + Mu(this); + } + } else { + this.c = !d ? null : d.b; + while (c2-- > 0) { + Lu(this); + } + } + this.b = b; + this.a = null; + } + function iHb(a, b) { + var c2, d; + b.a ? jHb(a, b) : (c2 = RD(vAb(a.b, b.b), 60), !!c2 && c2 == a.a[b.b.f] && !!c2.a && c2.a != b.b.a && c2.c.Fc(b.b), d = RD(uAb(a.b, b.b), 60), !!d && a.a[d.f] == b.b && !!d.a && d.a != b.b.a && b.b.c.Fc(d), wAb(a.b, b.b), void 0); + } + function wMb(a, b) { + var c2, d; + c2 = RD(Vrb(a.b, b), 127); + if (RD(RD(Qc(a.r, b), 21), 87).dc()) { + c2.n.b = 0; + c2.n.c = 0; + return; + } + c2.n.b = a.C.b; + c2.n.c = a.C.c; + a.A.Hc((Qpd(), Ppd)) && BMb(a, b); + d = AMb(a, b); + BLb(a, b) == (pod(), mod) && (d += 2 * a.w); + c2.a.a = d; + } + function FNb(a, b) { + var c2, d; + c2 = RD(Vrb(a.b, b), 127); + if (RD(RD(Qc(a.r, b), 21), 87).dc()) { + c2.n.d = 0; + c2.n.a = 0; + return; + } + c2.n.d = a.C.d; + c2.n.a = a.C.a; + a.A.Hc((Qpd(), Ppd)) && JNb(a, b); + d = INb(a, b); + BLb(a, b) == (pod(), mod) && (d += 2 * a.w); + c2.a.b = d; + } + function VQb(a, b) { + var c2, d, e, f2; + f2 = new bnb(); + for (d = new Anb(b); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 68); + Rmb(f2, new fRb(c2, true)); + Rmb(f2, new fRb(c2, false)); + } + e = new $Qb(a); + e.a.a.$b(); + bGb(f2, a.b, new mob(cD(WC(bN, 1), rve, 693, 0, [e]))); + } + function iTb(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m, n, o2, p, q; + i2 = a.a; + n = a.b; + j = b.a; + o2 = b.b; + k = c2.a; + p = c2.b; + l = d.a; + q = d.b; + f2 = i2 * o2 - n * j; + g = k * q - p * l; + e = (i2 - j) * (p - q) - (n - o2) * (k - l); + h = (f2 * (k - l) - g * (i2 - j)) / e; + m = (f2 * (p - q) - g * (n - o2)) / e; + return new rjd(h, m); + } + function Z6b(a, b) { + var c2, d, e; + b.Ug("End label pre-processing", 1); + c2 = Kfb(UD(mQb(a, (yCc(), VBc)))); + d = Kfb(UD(mQb(a, ZBc))); + e = Emd(RD(mQb(a, rAc), 88)); + FDb(EDb(new SDb(null, new Swb(a.b, 16)), new f7b()), new h7b(c2, d, e)); + b.Vg(); + } + function LFc(a, b) { + var c2, d, e; + if (a.d[b.p]) { + return; + } + a.d[b.p] = true; + a.a[b.p] = true; + for (d = new is(Mr(a3b(b).a.Kc(), new ir())); gs(d); ) { + c2 = RD(hs(d), 18); + if (W0b(c2)) { + continue; + } + e = c2.d.i; + a.a[e.p] ? Rmb(a.b, c2) : LFc(a, e); + } + a.a[b.p] = false; + } + function hGc(a, b, c2) { + var d; + d = 0; + switch (RD(mQb(b, (yCc(), UAc)), 171).g) { + case 2: + d = 2 * -c2 + a.a; + ++a.a; + break; + case 1: + d = -c2; + break; + case 3: + d = c2; + break; + case 4: + d = 2 * c2 + a.b; + ++a.b; + } + nQb(b, (Ywc(), zwc)) && (d += RD(mQb(b, zwc), 17).a); + return d; + } + function JSc(a, b, c2) { + var d, e, f2; + c2.zc(b, a); + Rmb(a.n, b); + f2 = a.p.zg(b); + b.j == a.p.Ag() ? YSc(a.e, f2) : YSc(a.j, f2); + LSc(a); + for (e = Fl(Al(cD(WC(cJ, 1), rve, 20, 0, [new T3b(b), new _3b(b)]))); gs(e); ) { + d = RD(hs(e), 12); + c2._b(d) || JSc(a, d, c2); + } + } + function rZc(a, b, c2) { + var d, e, f2; + c2.Ug("Processor set neighbors", 1); + a.a = b.b.b == 0 ? 1 : b.b.b; + e = null; + d = Sub(b.b, 0); + while (!e && d.b != d.d.c) { + f2 = RD(evb(d), 40); + Heb(TD(mQb(f2, (q$c(), n$c)))) && (e = f2); + } + !!e && sZc(a, new dXc(e), c2); + c2.Vg(); + } + function vsd(a) { + var b, c2, d; + c2 = RD(Gxd(a, (umd(), kld)), 21); + if (c2.Hc((Qpd(), Mpd))) { + d = RD(Gxd(a, pld), 21); + b = new sjd(RD(Gxd(a, nld), 8)); + if (d.Hc((dqd(), Ypd))) { + b.a <= 0 && (b.a = 20); + b.b <= 0 && (b.b = 20); + } + return b; + } else { + return new pjd(); + } + } + function nYd(a) { + var b, c2, d; + if (!a.b) { + d = new y_d(); + for (c2 = new yMd(qYd(a)); c2.e != c2.i.gc(); ) { + b = RD(xMd(c2), 19); + (b.Bb & QHe) != 0 && WGd(d, b); + } + VHd(d); + a.b = new N$d((RD(QHd(xYd((lTd(), kTd).o), 8), 19), d.i), d.g); + yYd(a).b &= -9; + } + return a.b; + } + function Dhb(a) { + var b, c2, d; + c2 = a.length; + d = 0; + while (d < c2 && (BFb(d, a.length), a.charCodeAt(d) <= 32)) { + ++d; + } + b = c2; + while (b > d && (BFb(b - 1, a.length), a.charCodeAt(b - 1) <= 32)) { + --b; + } + return d > 0 || b < c2 ? (AFb(d, b, a.length), a.substr(d, b - d)) : a; + } + function vqc(a, b) { + var c2, d, e, f2, g, h, i2, j; + i2 = RD(Ee(Ec(b.k), $C(E3, NAe, 64, 2, 0, 1)), 126); + j = b.g; + c2 = xqc(b, i2[0]); + e = wqc(b, i2[1]); + d = oqc(a, j, c2, e); + f2 = xqc(b, i2[1]); + h = wqc(b, i2[0]); + g = oqc(a, j, f2, h); + if (d <= g) { + b.a = c2; + b.c = e; + } else { + b.a = f2; + b.c = h; + } + } + function Eob(a) { + var h; + yob(); + var b, c2, d, e, f2, g; + if (ZD(a, 59)) { + for (e = 0, d = a.gc() - 1; e < d; ++e, --d) { + h = a.Xb(e); + a.hd(e, a.Xb(d)); + a.hd(d, h); + } + } else { + b = a.ed(); + f2 = a.fd(a.gc()); + while (b.Tb() < f2.Vb()) { + c2 = b.Pb(); + g = f2.Ub(); + b.Wb(g); + f2.Wb(c2); + } + } + } + function lKc(a, b) { + var c2, d, e, f2, g, h; + h = 0; + f2 = new wmb(); + hmb(f2, b); + while (f2.b != f2.c) { + g = RD(smb(f2), 219); + h += PLc(g.d, g.e); + for (e = new Anb(g.b); e.a < e.c.c.length; ) { + d = RD(ynb(e), 36); + c2 = RD(Vmb(a.b, d.p), 219); + c2.s || (h += lKc(a, c2)); + } + } + return h; + } + function QTc(a, b, c2, d, e) { + var f2, g, h, i2, j; + if (b) { + for (h = b.Kc(); h.Ob(); ) { + g = RD(h.Pb(), 10); + for (j = d3b(g, (BEc(), zEc), c2).Kc(); j.Ob(); ) { + i2 = RD(j.Pb(), 12); + f2 = RD(Wd(qtb(e.f, i2)), 118); + if (!f2) { + f2 = new USc(a.d); + ZEb(d.c, f2); + JSc(f2, i2, e); + } + } + } + } + } + function wVc(a, b, c2) { + var d, e; + rVc(this); + b == (dVc(), bVc) ? Ysb(this.r, a.c) : Ysb(this.w, a.c); + c2 == bVc ? Ysb(this.r, a.d) : Ysb(this.w, a.d); + sVc(this, a); + d = tVc(a.c); + e = tVc(a.d); + vVc(this, d, e, e); + this.o = (HUc(), $wnd.Math.abs(d - e) < 0.2); + } + function Ade(a, b, c2) { + var d, e, f2, g, h, i2; + h = RD(Ywd(a.a, 8), 2035); + if (h != null) { + for (e = h, f2 = 0, g = e.length; f2 < g; ++f2) { + null.Um(); + } + } + d = c2; + if ((a.a.Db & 1) == 0) { + i2 = new Fde(a, c2, b); + d.dj(i2); + } + ZD(d, 686) ? RD(d, 686).fj(a.a) : d.cj() == a.a && d.ej(null); + } + function Cne() { + var a; + if (wne) + return RD(N5d((YSd(), XSd), dLe), 2044); + Dne(); + a = RD(ZD(Xjb((YSd(), XSd), dLe), 594) ? Xjb(XSd, dLe) : new Bne(), 594); + wne = true; + zne(a); + Ane(a); + Zjb((hTd(), gTd), a, new Ene()); + rBd(a); + $jb(XSd, dLe, a); + return a; + } + function NA(a, b, c2, d) { + var e; + e = EA(a, c2, cD(WC(qJ, 1), Nve, 2, 6, [Swe, Twe, Uwe, Vwe, Wwe, Xwe, Ywe]), b); + e < 0 && (e = EA(a, c2, cD(WC(qJ, 1), Nve, 2, 6, ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"]), b)); + if (e < 0) { + return false; + } + d.d = e; + return true; + } + function QA(a, b, c2, d) { + var e; + e = EA(a, c2, cD(WC(qJ, 1), Nve, 2, 6, [Swe, Twe, Uwe, Vwe, Wwe, Xwe, Ywe]), b); + e < 0 && (e = EA(a, c2, cD(WC(qJ, 1), Nve, 2, 6, ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"]), b)); + if (e < 0) { + return false; + } + d.d = e; + return true; + } + function rtb(a, b, c2) { + var d, e, f2, g; + g = a.b.Ce(b); + e = (d = a.a.get(g), d == null ? $C(jJ, rve, 1, 0, 5, 1) : d); + if (e.length == 0) { + a.a.set(g, e); + } else { + f2 = otb(a, b, e); + if (f2) { + return f2.nd(c2); + } + } + bD(e, e.length, new xlb(b, c2)); + ++a.c; + ++a.b.g; + return null; + } + function PYb(a) { + var b, c2, d; + MYb(a); + d = new bnb(); + for (c2 = new Anb(a.a.a.b); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 86); + Rmb(d, new _Yb(b, true)); + Rmb(d, new _Yb(b, false)); + } + TYb(a.c); + t$b(d, a.b, new mob(cD(WC(wQ, 1), rve, 382, 0, [a.c]))); + OYb(a); + } + function eHb(a, b) { + var c2, d, e; + e = new bnb(); + for (d = new Anb(a.c.a.b); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 60); + if (b.Lb(c2)) { + Rmb(e, new sHb(c2, true)); + Rmb(e, new sHb(c2, false)); + } + } + kHb(a.e); + bGb(e, a.d, new mob(cD(WC(bN, 1), rve, 693, 0, [a.e]))); + } + function t7b(a) { + var b, c2, d, e; + c2 = new Tsb(); + for (e = new Anb(a.d); e.a < e.c.c.length; ) { + d = RD(ynb(e), 187); + b = RD(d.of((Ywc(), dwc)), 18); + !!qtb(c2.f, b) || Zjb(c2, b, new G7b(b)); + Rmb(RD(Wd(qtb(c2.f, b)), 466).b, d); + } + return new dnb(new glb(c2)); + } + function Xdc(a, b) { + var c2, d, e, f2, g; + d = new xmb(a.j.c.length); + c2 = null; + for (f2 = new Anb(a.j); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 12); + if (e.j != c2) { + d.b == d.c || Ydc(d, c2, b); + jmb(d); + c2 = e.j; + } + g = c7b(e); + !!g && (imb(d, g), true); + } + d.b == d.c || Ydc(d, c2, b); + } + function Lec(a, b) { + var c2, d, e; + d = new Jkb(a.b, 0); + while (d.b < d.d.gc()) { + c2 = (sFb(d.b < d.d.gc()), RD(d.d.Xb(d.c = d.b++), 72)); + e = RD(mQb(c2, (yCc(), wAc)), 278); + if (e == (Omd(), Mmd)) { + Ckb(d); + Rmb(b.b, c2); + nQb(c2, (Ywc(), dwc)) || pQb(c2, dwc, a); + } + } + } + function eIc(a) { + var b, c2, d, e, f2; + b = Kr(new is(Mr(a3b(a).a.Kc(), new ir()))); + for (e = new is(Mr(Z2b(a).a.Kc(), new ir())); gs(e); ) { + d = RD(hs(e), 18); + c2 = d.c.i; + f2 = Kr(new is(Mr(a3b(c2).a.Kc(), new ir()))); + b = $wnd.Math.max(b, f2); + } + return sgb(b); + } + function Jsd(a, b, c2) { + var d, e, f2; + d = RD(Gxd(a, (umd(), Kkd)), 21); + e = 0; + f2 = 0; + b.a > c2.a && (d.Hc((ukd(), okd)) ? e = (b.a - c2.a) / 2 : d.Hc(qkd) && (e = b.a - c2.a)); + b.b > c2.b && (d.Hc((ukd(), skd)) ? f2 = (b.b - c2.b) / 2 : d.Hc(rkd) && (f2 = b.b - c2.b)); + Isd(a, e, f2); + } + function ABd(a, b, c2, d, e, f2, g, h, i2, j, k, l, m) { + ZD(a.Cb, 90) && v$d(yYd(RD(a.Cb, 90)), 4); + PAd(a, c2); + a.f = g; + DWd(a, h); + FWd(a, i2); + xWd(a, j); + EWd(a, k); + aWd(a, l); + AWd(a, m); + _Vd(a, true); + $Vd(a, e); + a.Zk(f2); + YVd(a, b); + d != null && (a.i = null, zWd(a, d)); + } + function Jb(a, b, c2) { + if (a < 0) { + return hc(qve, cD(WC(jJ, 1), rve, 1, 5, [c2, sgb(a)])); + } else if (b < 0) { + throw Adb(new agb(sve + b)); + } else { + return hc("%s (%s) must not be greater than size (%s)", cD(WC(jJ, 1), rve, 1, 5, [c2, sgb(a), sgb(b)])); + } + } + function Xnb(a, b, c2, d, e, f2) { + var g, h, i2, j; + g = d - c2; + if (g < 7) { + Unb(b, c2, d, f2); + return; + } + i2 = c2 + e; + h = d + e; + j = i2 + (h - i2 >> 1); + Xnb(b, a, i2, j, -e, f2); + Xnb(b, a, j, h, -e, f2); + if (f2.Ne(a[j - 1], a[j]) <= 0) { + while (c2 < d) { + bD(b, c2++, a[i2++]); + } + return; + } + Vnb(a, i2, j, h, b, c2, d, f2); + } + function Mqc(a, b) { + var c2, d, e, f2, g, h, i2; + i2 = b.d; + e = b.b.j; + for (h = new Anb(i2); h.a < h.c.c.length; ) { + g = RD(ynb(h), 105); + f2 = $C(xdb, Hye, 28, e.c.length, 16, 1); + Zjb(a.b, g, f2); + c2 = g.a.d.p - 1; + d = g.c.d.p; + while (c2 != d) { + c2 = (c2 + 1) % e.c.length; + f2[c2] = true; + } + } + } + function rGc(a, b) { + nGc(); + if (nQb(a, (Ywc(), zwc)) && nQb(b, zwc)) { + return hgb(RD(mQb(a, zwc), 17).a, RD(mQb(b, zwc), 17).a); + } + throw Adb(new Ked("The BF model order layer assigner requires all real nodes to have a model order.")); + } + function $Gc(a, b) { + SGc(); + if (nQb(a, (Ywc(), zwc)) && nQb(b, zwc)) { + return hgb(RD(mQb(a, zwc), 17).a, RD(mQb(b, zwc), 17).a); + } + throw Adb(new Ked("The DF model order layer assigner requires all real nodes to have a model order.")); + } + function TSc(a, b) { + a.r = new USc(a.p); + SSc2(a.r, a); + ye(a.r.j, a.j); + Xub(a.j); + Mub(a.j, b); + Mub(a.r.e, b); + LSc(a); + LSc(a.r); + while (a.f.c.length != 0) { + $Sc(RD(Vmb(a.f, 0), 132)); + } + while (a.k.c.length != 0) { + $Sc(RD(Vmb(a.k, 0), 132)); + } + return a.r; + } + function Wvd(a, b, c2) { + var d, e, f2; + e = vYd(a.Dh(), b); + d = b - a.ji(); + if (d < 0) { + if (!e) { + throw Adb(new agb(OHe + b + PHe)); + } else if (e.rk()) { + f2 = a.Ih(e); + f2 >= 0 ? a.bi(f2, c2) : Svd(a, e, c2); + } else { + throw Adb(new agb(KHe + e.xe() + LHe)); + } + } else { + Bvd(a, d, e, c2); + } + } + function n3d(a) { + var b, c2; + if (a.f) { + while (a.n > 0) { + b = RD(a.k.Xb(a.n - 1), 76); + c2 = b.Lk(); + if (ZD(c2, 102) && (RD(c2, 19).Bb & QHe) != 0 && (!a.e || c2.pk() != C4 || c2.Lj() != 0) && b.md() != null) { + return true; + } else { + --a.n; + } + } + return false; + } else { + return a.n > 0; + } + } + function Pje(b) { + var c2, d, e, f2; + d = RD(b, 54)._h(); + if (d) { + try { + e = null; + c2 = N5d((YSd(), XSd), jSd(kSd(d))); + if (c2) { + f2 = c2.ai(); + !!f2 && (e = f2.Fl(Chb(d.e))); + } + if (!!e && e != b) { + return Pje(e); + } + } catch (a) { + a = zdb(a); + if (!ZD(a, 63)) + throw Adb(a); + } + } + return b; + } + function P3c(a, b, c2) { + var d, e, f2; + c2.Ug("Remove overlaps", 1); + c2.dh(b, eFe); + d = RD(Gxd(b, (u2c(), t2c)), 27); + a.f = d; + a.a = u5c(RD(Gxd(b, ($4c(), X4c)), 300)); + e = UD(Gxd(b, (umd(), fmd))); + s3c(a, (uFb(e), e)); + f2 = Q2c(d); + O3c(a, b, f2, c2); + c2.dh(b, gFe); + } + function Ded(a) { + var b, c2, d; + if (Heb(TD(Gxd(a, (umd(), $kd))))) { + d = new bnb(); + for (c2 = new is(Mr(zGd(a).a.Kc(), new ir())); gs(c2); ) { + b = RD(hs(c2), 74); + ozd(b) && Heb(TD(Gxd(b, _kd))) && (ZEb(d.c, b), true); + } + return d; + } else { + return yob(), yob(), vob; + } + } + function KC(a) { + if (!a) { + return cC(), bC; + } + var b = a.valueOf ? a.valueOf() : a; + if (b !== a) { + var c2 = GC[typeof b]; + return c2 ? c2(b) : NC(typeof b); + } else if (a instanceof Array || a instanceof $wnd.Array) { + return new NB(a); + } else { + return new vC(a); + } + } + function IMb(a, b, c2) { + var d, e, f2; + f2 = a.o; + d = RD(Vrb(a.p, c2), 252); + e = d.i; + e.b = ZKb(d); + e.a = YKb(d); + e.b = $wnd.Math.max(e.b, f2.a); + e.b > f2.a && !b && (e.b = f2.a); + e.c = -(e.b - f2.a) / 2; + switch (c2.g) { + case 1: + e.d = -e.a; + break; + case 3: + e.d = f2.b; + } + $Kb(d); + _Kb(d); + } + function JMb(a, b, c2) { + var d, e, f2; + f2 = a.o; + d = RD(Vrb(a.p, c2), 252); + e = d.i; + e.b = ZKb(d); + e.a = YKb(d); + e.a = $wnd.Math.max(e.a, f2.b); + e.a > f2.b && !b && (e.a = f2.b); + e.d = -(e.a - f2.b) / 2; + switch (c2.g) { + case 4: + e.c = -e.b; + break; + case 2: + e.c = f2.a; + } + $Kb(d); + _Kb(d); + } + function nkc(a, b) { + var c2, d, e, f2, g; + if (b.dc()) { + return; + } + e = RD(b.Xb(0), 131); + if (b.gc() == 1) { + mkc(a, e, e, 1, 0, b); + return; + } + c2 = 1; + while (c2 < b.gc()) { + if (e.j || !e.o) { + f2 = skc(b, c2); + if (f2) { + d = RD(f2.a, 17).a; + g = RD(f2.b, 131); + mkc(a, e, g, c2, d, b); + c2 = d + 1; + e = g; + } + } + } + } + function Soc(a) { + var b, c2, d, e, f2, g; + g = new dnb(a.d); + _mb(g, new upc()); + b = (epc(), cD(WC(hW, 1), jwe, 276, 0, [Zoc, apc, Yoc, dpc, _oc, $oc, cpc, bpc])); + c2 = 0; + for (f2 = new Anb(g); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 105); + d = b[c2 % b.length]; + Uoc(e, d); + ++c2; + } + } + function zid(a, b) { + tid(); + var c2, d, e, f2; + if (b.b < 2) { + return false; + } + f2 = Sub(b, 0); + c2 = RD(evb(f2), 8); + d = c2; + while (f2.b != f2.d.c) { + e = RD(evb(f2), 8); + if (!(xid(a, d) && xid(a, e))) { + return false; + } + d = e; + } + if (!(xid(a, d) && xid(a, c2))) { + return false; + } + return true; + } + function HEd(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l; + k = null; + l = a; + g = vDd(l, "x"); + c2 = new iFd(b); + eEd(c2.a, g); + h = vDd(l, "y"); + d = new jFd(b); + fEd(d.a, h); + i2 = vDd(l, fIe); + e = new kFd(b); + gEd(e.a, i2); + j = vDd(l, eIe); + f2 = new lFd(b); + k = (hEd(f2.a, j), j); + return k; + } + function v$d(a, b) { + r$d(a, b); + (a.b & 1) != 0 && (a.a.a = null); + (a.b & 2) != 0 && (a.a.f = null); + if ((a.b & 4) != 0) { + a.a.g = null; + a.a.i = null; + } + if ((a.b & 16) != 0) { + a.a.d = null; + a.a.e = null; + } + (a.b & 8) != 0 && (a.a.b = null); + if ((a.b & 32) != 0) { + a.a.j = null; + a.a.c = null; + } + } + function Lde(b, c2) { + var d, e, f2; + f2 = 0; + if (c2.length > 0) { + try { + f2 = Oeb(c2, qwe, lve); + } catch (a) { + a = zdb(a); + if (ZD(a, 130)) { + e = a; + throw Adb(new RSd(e)); + } else + throw Adb(a); + } + } + d = (!b.a && (b.a = new Zde(b)), b.a); + return f2 < d.i && f2 >= 0 ? RD(QHd(d, f2), 58) : null; + } + function Ib(a, b) { + if (a < 0) { + return hc(qve, cD(WC(jJ, 1), rve, 1, 5, ["index", sgb(a)])); + } else if (b < 0) { + throw Adb(new agb(sve + b)); + } else { + return hc("%s (%s) must be less than size (%s)", cD(WC(jJ, 1), rve, 1, 5, ["index", sgb(a), sgb(b)])); + } + } + function cob(a) { + var b, c2, d, e, f2; + if (a == null) { + return vve; + } + f2 = new Jyb(pve, "[", "]"); + for (c2 = a, d = 0, e = c2.length; d < e; ++d) { + b = c2[d]; + !f2.a ? f2.a = new dib(f2.d) : Zhb(f2.a, f2.b); + Whb(f2.a, "" + b); + } + return !f2.a ? f2.c : f2.e.length == 0 ? f2.a.a : f2.a.a + ("" + f2.e); + } + function dob(a) { + var b, c2, d, e, f2; + if (a == null) { + return vve; + } + f2 = new Jyb(pve, "[", "]"); + for (c2 = a, d = 0, e = c2.length; d < e; ++d) { + b = c2[d]; + !f2.a ? f2.a = new dib(f2.d) : Zhb(f2.a, f2.b); + Whb(f2.a, "" + b); + } + return !f2.a ? f2.c : f2.e.length == 0 ? f2.a.a : f2.a.a + ("" + f2.e); + } + function eob(a) { + var b, c2, d, e, f2; + if (a == null) { + return vve; + } + f2 = new Jyb(pve, "[", "]"); + for (c2 = a, d = 0, e = c2.length; d < e; ++d) { + b = c2[d]; + !f2.a ? f2.a = new dib(f2.d) : Zhb(f2.a, f2.b); + Whb(f2.a, "" + b); + } + return !f2.a ? f2.c : f2.e.length == 0 ? f2.a.a : f2.a.a + ("" + f2.e); + } + function hob(a) { + var b, c2, d, e, f2; + if (a == null) { + return vve; + } + f2 = new Jyb(pve, "[", "]"); + for (c2 = a, d = 0, e = c2.length; d < e; ++d) { + b = c2[d]; + !f2.a ? f2.a = new dib(f2.d) : Zhb(f2.a, f2.b); + Whb(f2.a, "" + b); + } + return !f2.a ? f2.c : f2.e.length == 0 ? f2.a.a : f2.a.a + ("" + f2.e); + } + function kwb(a, b) { + var c2, d, e, f2, g, h; + c2 = a.b.c.length; + e = Vmb(a.b, b); + while (b * 2 + 1 < c2) { + d = (f2 = 2 * b + 1, g = f2 + 1, h = f2, g < c2 && a.a.Ne(Vmb(a.b, g), Vmb(a.b, f2)) < 0 && (h = g), h); + if (a.a.Ne(e, Vmb(a.b, d)) < 0) { + break; + } + $mb(a.b, b, Vmb(a.b, d)); + b = d; + } + $mb(a.b, b, e); + } + function oJb(a, b, c2) { + var d, e; + d = c2.d; + e = c2.e; + if (a.g[d.d] <= a.i[b.d] && a.i[b.d] <= a.i[d.d] && a.g[e.d] <= a.i[b.d] && a.i[b.d] <= a.i[e.d]) { + if (a.i[d.d] < a.i[e.d]) { + return false; + } + return true; + } + if (a.i[d.d] < a.i[e.d]) { + return true; + } + return false; + } + function SWb(a, b) { + var c2; + c2 = RD(mQb(b, (yCc(), oAc)), 322); + if (c2 != a) { + throw Adb(new Ked("The hierarchy aware processor " + c2 + " in child node " + b + " is only allowed if the root node specifies the same hierarchical processor.")); + } + } + function Kee(a, b) { + var c2, d, e, f2, g; + d = (!b.s && (b.s = new C5d(y7, b, 21, 17)), b.s); + f2 = null; + for (e = 0, g = d.i; e < g; ++e) { + c2 = RD(QHd(d, e), 179); + switch (yfe(Qee(a, c2))) { + case 2: + case 3: { + !f2 && (f2 = new bnb()); + ZEb(f2.c, c2); + } + } + } + return !f2 ? (yob(), yob(), vob) : f2; + } + function PQb(a, b, c2) { + var d, e, f2, g, h, i2; + i2 = oxe; + for (f2 = new Anb(nRb(a.b)); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 177); + for (h = new Anb(nRb(b.b)); h.a < h.c.c.length; ) { + g = RD(ynb(h), 177); + d = Aid(e.a, e.b, g.a, g.b, c2); + i2 = $wnd.Math.min(i2, d); + } + } + return i2; + } + function Q3b(a, b) { + if (!b) { + throw Adb(new Ngb()); + } + a.j = b; + if (!a.d) { + switch (a.j.g) { + case 1: + a.a.a = a.o.a / 2; + a.a.b = 0; + break; + case 2: + a.a.a = a.o.a; + a.a.b = a.o.b / 2; + break; + case 3: + a.a.a = a.o.a / 2; + a.a.b = a.o.b; + break; + case 4: + a.a.a = 0; + a.a.b = a.o.b / 2; + } + } + } + function Jic(a, b) { + var c2, d, e; + if (ZD(b.g, 10) && RD(b.g, 10).k == (r3b(), m3b)) { + return oxe; + } + e = $jc(b); + if (e) { + return $wnd.Math.max(0, a.b / 2 - 0.5); + } + c2 = Zjc(b); + if (c2) { + d = Kfb(UD(hFc(c2, (yCc(), bCc)))); + return $wnd.Math.max(0, d / 2 - 0.5); + } + return oxe; + } + function Lic(a, b) { + var c2, d, e; + if (ZD(b.g, 10) && RD(b.g, 10).k == (r3b(), m3b)) { + return oxe; + } + e = $jc(b); + if (e) { + return $wnd.Math.max(0, a.b / 2 - 0.5); + } + c2 = Zjc(b); + if (c2) { + d = Kfb(UD(hFc(c2, (yCc(), bCc)))); + return $wnd.Math.max(0, d / 2 - 0.5); + } + return oxe; + } + function Jkc(a, b) { + lkc(); + var c2, d, e, f2, g, h; + c2 = null; + for (g = b.Kc(); g.Ob(); ) { + f2 = RD(g.Pb(), 131); + if (f2.o) { + continue; + } + d = Qid(f2.a); + e = Nid(f2.a); + h = new Nlc(d, e, null, RD(f2.d.a.ec().Kc().Pb(), 18)); + Rmb(h.c, f2.a); + ZEb(a.c, h); + !!c2 && Rmb(c2.d, h); + c2 = h; + } + } + function bmc(a) { + var b, c2, d, e, f2, g; + g = aMc(a.d, a.e); + for (f2 = g.Kc(); f2.Ob(); ) { + e = RD(f2.Pb(), 12); + d = a.e == (qpd(), ppd) ? e.e : e.g; + for (c2 = new Anb(d); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 18); + if (!W0b(b) && b.c.i.c != b.d.i.c) { + Zlc(a, b); + ++a.f; + ++a.c; + } + } + } + } + function Wsc(a, b) { + var c2, d; + if (b.dc()) { + return yob(), yob(), vob; + } + d = new bnb(); + Rmb(d, sgb(qwe)); + for (c2 = 1; c2 < a.f; ++c2) { + a.a == null && usc(a); + a.a[c2] && Rmb(d, sgb(c2)); + } + if (d.c.length == 1) { + return yob(), yob(), vob; + } + Rmb(d, sgb(lve)); + return Vsc(b, d); + } + function kOc(a, b) { + var c2, d, e, f2, g, h, i2; + g = b.c.i.k != (r3b(), p3b); + i2 = g ? b.d : b.c; + c2 = U0b(b, i2).i; + e = RD(Wjb(a.k, i2), 125); + d = a.i[c2.p].a; + if ($2b(i2.i) < (!c2.c ? -1 : Wmb(c2.c.a, c2, 0))) { + f2 = e; + h = d; + } else { + f2 = d; + h = e; + } + rIb(uIb(tIb(vIb(sIb(new wIb(), 0), 4), f2), h)); + } + function ODd(a, b, c2) { + var d, e, f2, g, h, i2; + if (c2) { + e = c2.a.length; + d = new vue(e); + for (h = (d.b - d.a) * d.c < 0 ? (uue(), tue) : new Rue(d); h.Ob(); ) { + g = RD(h.Pb(), 17); + i2 = uEd(a, tDd(JB(c2, g.a))); + if (i2) { + f2 = (!b.b && (b.b = new Yie(E4, b, 4, 7)), b.b); + WGd(f2, i2); + } + } + } + } + function PDd(a, b, c2) { + var d, e, f2, g, h, i2; + if (c2) { + e = c2.a.length; + d = new vue(e); + for (h = (d.b - d.a) * d.c < 0 ? (uue(), tue) : new Rue(d); h.Ob(); ) { + g = RD(h.Pb(), 17); + i2 = uEd(a, tDd(JB(c2, g.a))); + if (i2) { + f2 = (!b.c && (b.c = new Yie(E4, b, 5, 8)), b.c); + WGd(f2, i2); + } + } + } + } + function Bo(a, b, c2) { + var d, e; + d = b.a & a.f; + b.b = a.b[d]; + a.b[d] = b; + e = b.f & a.f; + b.d = a.c[e]; + a.c[e] = b; + if (!c2) { + b.e = a.e; + b.c = null; + !a.e ? a.a = b : a.e.c = b; + a.e = b; + } else { + b.e = c2.e; + !b.e ? a.a = b : b.e.c = b; + b.c = c2.c; + !b.c ? a.e = b : b.c.e = b; + } + ++a.i; + ++a.g; + } + function Ir(a) { + var b, c2, d; + b = a.Pb(); + if (!a.Ob()) { + return b; + } + d = Yhb(Zhb(new bib(), "expected one element but was: <"), b); + for (c2 = 0; c2 < 4 && a.Ob(); c2++) { + Yhb((d.a += pve, d), a.Pb()); + } + a.Ob() && (d.a += ", ...", d); + d.a += ">"; + throw Adb(new agb(d.a)); + } + function cB(a) { + var b, c2; + c2 = -a.a; + b = cD(WC(hE, 1), zwe, 28, 15, [43, 48, 48, 48, 48]); + if (c2 < 0) { + b[0] = 45; + c2 = -c2; + } + b[1] = b[1] + ((c2 / 60 | 0) / 10 | 0) & Bwe; + b[2] = b[2] + (c2 / 60 | 0) % 10 & Bwe; + b[3] = b[3] + (c2 % 60 / 10 | 0) & Bwe; + b[4] = b[4] + c2 % 10 & Bwe; + return Ihb(b, 0, b.length); + } + function V2b(a) { + var b, c2, d, e; + a.g = new Zrb(RD(Qb(E3), 297)); + d = 0; + c2 = (qpd(), Yod); + b = 0; + for (; b < a.j.c.length; b++) { + e = RD(Vmb(a.j, b), 12); + if (e.j != c2) { + d != b && Wrb(a.g, c2, new Ptd(sgb(d), sgb(b))); + c2 = e.j; + d = b; + } + } + Wrb(a.g, c2, new Ptd(sgb(d), sgb(b))); + } + function u7b(a) { + var b, c2, d, e, f2, g, h; + d = 0; + for (c2 = new Anb(a.b); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 30); + for (f2 = new Anb(b.a); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 10); + e.p = d++; + for (h = new Anb(e.j); h.a < h.c.c.length; ) { + g = RD(ynb(h), 12); + g.p = d++; + } + } + } + } + function Tvd(a, b) { + var c2, d, e; + e = Eee((lke(), jke), a.Dh(), b); + if (e) { + nke(); + RD(e, 69).xk() || (e = zfe(Qee(jke, e))); + d = (c2 = a.Ih(e), RD(c2 >= 0 ? a.Lh(c2, true, true) : Qvd(a, e, true), 160)); + RD(d, 220).Zl(b); + } else { + throw Adb(new agb(KHe + b.xe() + LHe)); + } + } + function Cib(a) { + var b, c2; + if (a > -140737488355328 && a < 140737488355328) { + if (a == 0) { + return 0; + } + b = a < 0; + b && (a = -a); + c2 = eE($wnd.Math.floor($wnd.Math.log(a) / 0.6931471805599453)); + (!b || a != $wnd.Math.pow(2, c2)) && ++c2; + return c2; + } + return Dib(Hdb(a)); + } + function oTc(a) { + var b, c2, d, e, f2, g, h; + f2 = new Iub(); + for (c2 = new Anb(a); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 132); + g = b.a; + h = b.b; + if (f2.a._b(g) || f2.a._b(h)) { + continue; + } + e = g; + d = h; + if (g.e.b + g.j.b > 2 && h.e.b + h.j.b <= 2) { + e = h; + d = g; + } + f2.a.zc(e, f2); + e.q = d; + } + return f2; + } + function B5c(a, b, c2) { + c2.Ug("Eades radial", 1); + c2.dh(b, gFe); + a.d = RD(Gxd(b, (u2c(), t2c)), 27); + a.c = Kfb(UD(Gxd(b, ($4c(), S4c)))); + a.e = u5c(RD(Gxd(b, X4c), 300)); + a.a = Z3c(RD(Gxd(b, Z4c), 434)); + a.b = k5c(RD(Gxd(b, O4c), 354)); + C5c(a); + c2.dh(b, gFe); + } + function t8c(a, b) { + b.Ug("Target Width Setter", 1); + if (Hxd(a, (X7c(), W7c))) { + Ixd(a, (X6c(), W6c), UD(Gxd(a, W7c))); + } else { + throw Adb(new Jed("A target width has to be set if the TargetWidthWidthApproximator should be used.")); + } + b.Vg(); + } + function _8b(a, b) { + var c2, d, e; + d = new j3b(a); + kQb(d, b); + pQb(d, (Ywc(), gwc), b); + pQb(d, (yCc(), BBc), (Bod(), wod)); + pQb(d, Rzc, (Rjd(), Njd)); + h3b(d, (r3b(), m3b)); + c2 = new R3b(); + P3b(c2, d); + Q3b(c2, (qpd(), ppd)); + e = new R3b(); + P3b(e, d); + Q3b(e, Xod); + return d; + } + function ttc(a) { + switch (a.g) { + case 0: + return new FKc((RKc(), OKc)); + case 1: + return new aKc(); + case 2: + return new FLc(); + default: + throw Adb(new agb("No implementation is available for the crossing minimizer " + (a.f != null ? a.f : "" + a.g))); + } + } + function THc(a, b) { + var c2, d, e, f2, g; + a.c[b.p] = true; + Rmb(a.a, b); + for (g = new Anb(b.j); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 12); + for (d = new l4b(f2.b); xnb(d.a) || xnb(d.b); ) { + c2 = RD(xnb(d.a) ? ynb(d.a) : ynb(d.b), 18); + e = UHc(f2, c2).i; + a.c[e.p] || THc(a, e); + } + } + } + function J2c(a) { + var b, c2, d, e, f2, g, h; + g = 0; + for (c2 = new dMd((!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a)); c2.e != c2.i.gc(); ) { + b = RD(bMd(c2), 27); + h = b.g; + e = b.f; + d = $wnd.Math.sqrt(h * h + e * e); + g = $wnd.Math.max(d, g); + f2 = J2c(b); + g = $wnd.Math.max(f2, g); + } + return g; + } + function Pod() { + Pod = geb; + Nod = new Qod("OUTSIDE", 0); + Lod = new Qod("INSIDE", 1); + Mod = new Qod("NEXT_TO_PORT_IF_POSSIBLE", 2); + Kod = new Qod("ALWAYS_SAME_SIDE", 3); + Jod = new Qod("ALWAYS_OTHER_SAME_SIDE", 4); + Ood = new Qod("SPACE_EFFICIENT", 5); + } + function DEd(a, b, c2) { + var d, e, f2, h, i2, j; + d = rEd(a, (e = (bvd(), f2 = new ACd(), f2), !!c2 && yCd(e, c2), e), b); + jyd(d, zDd(b, uIe)); + GEd(b, d); + BEd(b, d); + HEd(b, d); + h = b; + i2 = wDd(h, "ports"); + j = new hFd(a, d); + dEd(j.a, j.b, i2); + CEd(a, b, d); + xEd(a, b, d); + return d; + } + function bB(a) { + var b, c2; + c2 = -a.a; + b = cD(WC(hE, 1), zwe, 28, 15, [43, 48, 48, 58, 48, 48]); + if (c2 < 0) { + b[0] = 45; + c2 = -c2; + } + b[1] = b[1] + ((c2 / 60 | 0) / 10 | 0) & Bwe; + b[2] = b[2] + (c2 / 60 | 0) % 10 & Bwe; + b[4] = b[4] + (c2 % 60 / 10 | 0) & Bwe; + b[5] = b[5] + c2 % 10 & Bwe; + return Ihb(b, 0, b.length); + } + function eB(a) { + var b; + b = cD(WC(hE, 1), zwe, 28, 15, [71, 77, 84, 45, 48, 48, 58, 48, 48]); + if (a <= 0) { + b[3] = 43; + a = -a; + } + b[4] = b[4] + ((a / 60 | 0) / 10 | 0) & Bwe; + b[5] = b[5] + (a / 60 | 0) % 10 & Bwe; + b[7] = b[7] + (a % 60 / 10 | 0) & Bwe; + b[8] = b[8] + a % 10 & Bwe; + return Ihb(b, 0, b.length); + } + function fob(a) { + var b, c2, d, e, f2; + if (a == null) { + return vve; + } + f2 = new Jyb(pve, "[", "]"); + for (c2 = a, d = 0, e = c2.length; d < e; ++d) { + b = c2[d]; + !f2.a ? f2.a = new dib(f2.d) : Zhb(f2.a, f2.b); + Whb(f2.a, "" + Zdb(b)); + } + return !f2.a ? f2.c : f2.e.length == 0 ? f2.a.a : f2.a.a + ("" + f2.e); + } + function uJb(a, b) { + var c2, d, e; + e = lve; + for (d = new Anb(CIb(b)); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 218); + if (c2.f && !a.c[c2.c]) { + a.c[c2.c] = true; + e = $wnd.Math.min(e, uJb(a, oIb(c2, b))); + } + } + a.i[b.d] = a.j; + a.g[b.d] = $wnd.Math.min(e, a.j++); + return a.g[b.d]; + } + function vNb(a, b) { + var c2, d, e; + for (e = RD(RD(Qc(a.r, b), 21), 87).Kc(); e.Ob(); ) { + d = RD(e.Pb(), 117); + d.e.b = (c2 = d.b, c2.pf((umd(), Gld)) ? c2.ag() == (qpd(), Yod) ? -c2.Mf().b - Kfb(UD(c2.of(Gld))) : Kfb(UD(c2.of(Gld))) : c2.ag() == (qpd(), Yod) ? -c2.Mf().b : 0); + } + } + function CSb(a) { + var b, c2, d, e, f2, g, h; + c2 = zRb(a.e); + f2 = ijd(njd(ajd(yRb(a.e)), a.d * a.a, a.c * a.b), -0.5); + b = c2.a - f2.a; + e = c2.b - f2.b; + for (h = 0; h < a.c; h++) { + d = b; + for (g = 0; g < a.d; g++) { + ARb(a.e, new Uid2(d, e, a.a, a.b)) && TPb(a, g, h, false, true); + d += a.a; + } + e += a.b; + } + } + function H0c(a) { + var b, c2, d, e, f2; + b = a.a; + c2 = a.b; + e = a.c; + d = new rjd(c2.e.a + c2.f.a / 2, c2.e.b + c2.f.b / 2); + f2 = new rjd(e.e.a + e.f.a / 2, e.e.b + e.f.b / 2); + Pub(b, d, b.a, b.a.a); + Pub(b, f2, b.c.b, b.c); + tWc(d, RD(ju(b, 1), 8), a.b.f); + tWc(f2, RD(ju(b, b.b - 2), 8), a.c.f); + } + function tDd(a) { + var b, c2; + c2 = false; + if (ZD(a, 211)) { + c2 = true; + return RD(a, 211).a; + } + if (!c2) { + if (ZD(a, 263)) { + b = RD(a, 263).a % 1 == 0; + if (b) { + c2 = true; + return sgb(Ofb(RD(a, 263).a)); + } + } + } + throw Adb(new CDd("Id must be a string or an integer: '" + a + "'.")); + } + function Kde(a, b) { + var c2, d, e, f2, g, h; + f2 = null; + for (e = new Xde((!a.a && (a.a = new Zde(a)), a.a)); Ude(e); ) { + c2 = RD(tId(e), 58); + d = (g = c2.Dh(), h = (mYd(g), g.o), !h || !c2.Xh(h) ? null : Hje(iXd(h), c2.Mh(h))); + if (d != null) { + if (lhb(d, b)) { + f2 = c2; + break; + } + } + } + return f2; + } + function Rw(a, b, c2) { + var d, e, f2, g, h; + dk(c2, "occurrences"); + if (c2 == 0) { + return h = RD(Xv(nd(a.a), b), 16), !h ? 0 : h.gc(); + } + g = RD(Xv(nd(a.a), b), 16); + if (!g) { + return 0; + } + f2 = g.gc(); + if (c2 >= f2) { + g.$b(); + } else { + e = g.Kc(); + for (d = 0; d < c2; d++) { + e.Pb(); + e.Qb(); + } + } + return f2; + } + function qx(a, b, c2) { + var d, e, f2, g; + dk(c2, "oldCount"); + dk(0, "newCount"); + d = RD(Xv(nd(a.a), b), 16); + if ((!d ? 0 : d.gc()) == c2) { + dk(0, "count"); + e = (f2 = RD(Xv(nd(a.a), b), 16), !f2 ? 0 : f2.gc()); + g = -e; + g > 0 ? Hh() : g < 0 && Rw(a, b, -g); + return true; + } else { + return false; + } + } + function YKb(a) { + var b, c2, d, e, f2, g, h; + h = 0; + if (a.b == 0) { + g = aLb(a, true); + b = 0; + for (d = g, e = 0, f2 = d.length; e < f2; ++e) { + c2 = d[e]; + if (c2 > 0) { + h += c2; + ++b; + } + } + b > 1 && (h += a.c * (b - 1)); + } else { + h = Vvb(SCb(HDb(CDb(_nb(a.a), new oLb()), new qLb()))); + } + return h > 0 ? h + a.n.d + a.n.a : 0; + } + function ZKb(a) { + var b, c2, d, e, f2, g, h; + h = 0; + if (a.b == 0) { + h = Vvb(SCb(HDb(CDb(_nb(a.a), new kLb()), new mLb()))); + } else { + g = bLb(a, true); + b = 0; + for (d = g, e = 0, f2 = d.length; e < f2; ++e) { + c2 = d[e]; + if (c2 > 0) { + h += c2; + ++b; + } + } + b > 1 && (h += a.c * (b - 1)); + } + return h > 0 ? h + a.n.b + a.n.c : 0; + } + function UOc(a) { + var b, c2; + if (a.c.length != 2) { + throw Adb(new dgb("Order only allowed for two paths.")); + } + b = (tFb(0, a.c.length), RD(a.c[0], 18)); + c2 = (tFb(1, a.c.length), RD(a.c[1], 18)); + if (b.d.i != c2.c.i) { + a.c.length = 0; + ZEb(a.c, c2); + ZEb(a.c, b); + } + } + function O8c(a, b, c2) { + var d; + zyd(c2, b.g, b.f); + Byd(c2, b.i, b.j); + for (d = 0; d < (!b.a && (b.a = new C5d(J4, b, 10, 11)), b.a).i; d++) { + O8c(a, RD(QHd((!b.a && (b.a = new C5d(J4, b, 10, 11)), b.a), d), 27), RD(QHd((!c2.a && (c2.a = new C5d(J4, c2, 10, 11)), c2.a), d), 27)); + } + } + function DMb(a, b) { + var c2, d, e, f2; + f2 = RD(Vrb(a.b, b), 127); + c2 = f2.a; + for (e = RD(RD(Qc(a.r, b), 21), 87).Kc(); e.Ob(); ) { + d = RD(e.Pb(), 117); + !!d.c && (c2.a = $wnd.Math.max(c2.a, QKb(d.c))); + } + if (c2.a > 0) { + switch (b.g) { + case 2: + f2.n.c = a.s; + break; + case 4: + f2.n.b = a.s; + } + } + } + function ETb(a, b) { + var c2, d, e; + c2 = RD(mQb(b, (yVb(), lVb)), 17).a - RD(mQb(a, lVb), 17).a; + if (c2 == 0) { + d = ojd(ajd(RD(mQb(a, (JVb(), FVb)), 8)), RD(mQb(a, GVb), 8)); + e = ojd(ajd(RD(mQb(b, FVb), 8)), RD(mQb(b, GVb), 8)); + return Qfb(d.a * d.b, e.a * e.b); + } + return c2; + } + function JVc(a, b) { + var c2, d, e; + c2 = RD(mQb(b, (h_c(), X$c)), 17).a - RD(mQb(a, X$c), 17).a; + if (c2 == 0) { + d = ojd(ajd(RD(mQb(a, (q$c(), RZc)), 8)), RD(mQb(a, SZc), 8)); + e = ojd(ajd(RD(mQb(b, RZc), 8)), RD(mQb(b, SZc), 8)); + return Qfb(d.a * d.b, e.a * e.b); + } + return c2; + } + function _0b(a) { + var b, c2; + c2 = new bib(); + c2.a += "e_"; + b = S0b(a); + b != null && (c2.a += "" + b, c2); + if (!!a.c && !!a.d) { + Zhb((c2.a += " ", c2), M3b(a.c)); + Zhb(Yhb((c2.a += "[", c2), a.c.i), "]"); + Zhb((c2.a += SAe, c2), M3b(a.d)); + Zhb(Yhb((c2.a += "[", c2), a.d.i), "]"); + } + return c2.a; + } + function ZVc(a) { + switch (a.g) { + case 0: + return new N_c(); + case 1: + return new V_c(); + case 2: + return new x0c(); + case 3: + return new J0c(); + default: + throw Adb(new agb("No implementation is available for the layout phase " + (a.f != null ? a.f : "" + a.g))); + } + } + function qsd(a, b, c2, d, e) { + var f2; + f2 = 0; + switch (e.g) { + case 1: + f2 = $wnd.Math.max(0, b.b + a.b - (c2.b + d)); + break; + case 3: + f2 = $wnd.Math.max(0, -a.b - d); + break; + case 2: + f2 = $wnd.Math.max(0, -a.a - d); + break; + case 4: + f2 = $wnd.Math.max(0, b.a + a.a - (c2.a + d)); + } + return f2; + } + function MDd(a, b, c2) { + var d, e, f2, g, h; + if (c2) { + e = c2.a.length; + d = new vue(e); + for (h = (d.b - d.a) * d.c < 0 ? (uue(), tue) : new Rue(d); h.Ob(); ) { + g = RD(h.Pb(), 17); + f2 = xDd(c2, g.a); + kIe in f2.a || lIe in f2.a ? yEd(a, f2, b) : EEd(a, f2, b); + OGd(RD(Wjb(a.b, uDd(f2)), 74)); + } + } + } + function jXd(a) { + var b, c2; + switch (a.b) { + case -1: { + return true; + } + case 0: { + c2 = a.t; + if (c2 > 1 || c2 == -1) { + a.b = -1; + return true; + } else { + b = WVd(a); + if (!!b && (nke(), b.lk() == aKe)) { + a.b = -1; + return true; + } else { + a.b = 1; + return false; + } + } + } + default: + case 1: { + return false; + } + } + } + function Sqe(a, b) { + var c2, d, e, f2; + Mqe(a); + if (a.c != 0 || a.a != 123) + throw Adb(new Lqe(TId((Hde(), eJe)))); + f2 = b == 112; + d = a.d; + c2 = phb(a.i, 125, d); + if (c2 < 0) + throw Adb(new Lqe(TId((Hde(), fJe)))); + e = zhb(a.i, d, c2); + a.d = c2 + 1; + return ite(e, f2, (a.e & 512) == 512); + } + function YTb(a) { + var b, c2, d, e, f2, g, h; + d = a.a.c.length; + if (d > 0) { + g = a.c.d; + h = a.d.d; + e = ijd(ojd(new rjd(h.a, h.b), g), 1 / (d + 1)); + f2 = new rjd(g.a, g.b); + for (c2 = new Anb(a.a); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 250); + b.d.a = f2.a + e.a; + b.d.b = f2.b + e.b; + $id(f2, e); + } + } + } + function HXd(a, b) { + var c2, d, e; + if (!b) { + JXd(a, null); + zXd(a, null); + } else if ((b.i & 4) != 0) { + d = "[]"; + for (c2 = b.c; ; c2 = c2.c) { + if ((c2.i & 4) == 0) { + e = shb((lfb(c2), c2.o + d)); + JXd(a, e); + zXd(a, e); + break; + } + d += "[]"; + } + } else { + e = shb((lfb(b), b.o)); + JXd(a, e); + zXd(a, e); + } + a.hl(b); + } + function Bge(a, b, c2, d, e) { + var f2, g, h, i2; + i2 = Age(a, RD(e, 58)); + if (dE(i2) !== dE(e)) { + h = RD(a.g[c2], 76); + f2 = oke(b, i2); + MHd(a, c2, Tge(a, c2, f2)); + if (Mvd(a.e)) { + g = fge(a, 9, f2.Lk(), e, i2, d, false); + oKd(g, new P3d(a.e, 9, a.c, h, f2, d, false)); + pKd(g); + } + return i2; + } + return e; + } + function AGc(a, b, c2) { + var d, e, f2, g, h, i2; + d = RD(Qc(a.c, b), 15); + e = RD(Qc(a.c, c2), 15); + f2 = d.fd(d.gc()); + g = e.fd(e.gc()); + while (f2.Sb() && g.Sb()) { + h = RD(f2.Ub(), 17); + i2 = RD(g.Ub(), 17); + if (h != i2) { + return hgb(h.a, i2.a); + } + } + return !f2.Ob() && !g.Ob() ? 0 : f2.Ob() ? 1 : -1; + } + function FHc(a) { + var b, c2, d, e, f2, g, h; + h = ev(a.c.length); + for (e = new Anb(a); e.a < e.c.c.length; ) { + d = RD(ynb(e), 10); + g = new _sb(); + f2 = a3b(d); + for (c2 = new is(Mr(f2.a.Kc(), new ir())); gs(c2); ) { + b = RD(hs(c2), 18); + b.c.i == b.d.i || Ysb(g, b.d.i); + } + ZEb(h.c, g); + } + return h; + } + function xhd(c2, d) { + var e, f2, g; + try { + g = xs(c2.a, d); + return g; + } catch (b) { + b = zdb(b); + if (ZD(b, 33)) { + try { + f2 = Oeb(d, qwe, lve); + e = mfb(c2.a); + if (f2 >= 0 && f2 < e.length) { + return e[f2]; + } + } catch (a) { + a = zdb(a); + if (!ZD(a, 130)) + throw Adb(a); + } + return null; + } else + throw Adb(b); + } + } + function Rvd(a, b) { + var c2, d, e; + e = Eee((lke(), jke), a.Dh(), b); + if (e) { + nke(); + RD(e, 69).xk() || (e = zfe(Qee(jke, e))); + d = (c2 = a.Ih(e), RD(c2 >= 0 ? a.Lh(c2, true, true) : Qvd(a, e, true), 160)); + return RD(d, 220).Wl(b); + } else { + throw Adb(new agb(KHe + b.xe() + NHe)); + } + } + function _ae() { + Tae(); + var a; + if (Sae) + return RD(N5d((YSd(), XSd), AKe), 2038); + RRd(UK, new hde()); + abe(); + a = RD(ZD(Xjb((YSd(), XSd), AKe), 560) ? Xjb(XSd, AKe) : new $ae(), 560); + Sae = true; + Yae(a); + Zae(a); + Zjb((hTd(), gTd), a, new cbe()); + $jb(XSd, AKe, a); + return a; + } + function Vfe(a, b) { + var c2, d, e, f2; + a.j = -1; + if (Mvd(a.e)) { + c2 = a.i; + f2 = a.i != 0; + LHd(a, b); + d = new P3d(a.e, 3, a.c, null, b, c2, f2); + e = b.zl(a.e, a.c, null); + e = Hge(a, b, e); + if (!e) { + qvd(a.e, d); + } else { + e.nj(d); + e.oj(); + } + } else { + LHd(a, b); + e = b.zl(a.e, a.c, null); + !!e && e.oj(); + } + } + function HA(a, b) { + var c2, d, e; + e = 0; + d = b[0]; + if (d >= a.length) { + return -1; + } + c2 = (BFb(d, a.length), a.charCodeAt(d)); + while (c2 >= 48 && c2 <= 57) { + e = e * 10 + (c2 - 48); + ++d; + if (d >= a.length) { + break; + } + c2 = (BFb(d, a.length), a.charCodeAt(d)); + } + d > b[0] ? b[0] = d : e = -1; + return e; + } + function mPb(a) { + var b, c2, d, e, f2; + e = RD(a.a, 17).a; + f2 = RD(a.b, 17).a; + c2 = e; + d = f2; + b = $wnd.Math.max($wnd.Math.abs(e), $wnd.Math.abs(f2)); + if (e <= 0 && e == f2) { + c2 = 0; + d = f2 - 1; + } else { + if (e == -b && f2 != b) { + c2 = f2; + d = e; + f2 >= 0 && ++c2; + } else { + c2 = -f2; + d = e; + } + } + return new Ptd(sgb(c2), sgb(d)); + } + function YPb(a, b, c2, d) { + var e, f2, g, h, i2, j; + for (e = 0; e < b.o; e++) { + f2 = e - b.j + c2; + for (g = 0; g < b.p; g++) { + h = g - b.k + d; + if ((i2 = f2, j = h, i2 += a.j, j += a.k, i2 >= 0 && j >= 0 && i2 < a.o && j < a.p) && (!QPb(b, e, g) && $Pb(a, f2, h) || PPb(b, e, g) && !_Pb(a, f2, h))) { + return true; + } + } + } + return false; + } + function jSc(a, b, c2) { + var d, e, f2, g, h; + g = a.c; + h = a.d; + f2 = xjd(cD(WC(l3, 1), Nve, 8, 0, [g.i.n, g.n, g.a])).b; + e = (f2 + xjd(cD(WC(l3, 1), Nve, 8, 0, [h.i.n, h.n, h.a])).b) / 2; + d = null; + g.j == (qpd(), Xod) ? d = new rjd(b + g.i.c.c.a + c2, e) : d = new rjd(b - c2, e); + hu(a.a, 0, d); + } + function ozd(a) { + var b, c2, d, e; + b = null; + for (d = Fl(Al(cD(WC(cJ, 1), rve, 20, 0, [(!a.b && (a.b = new Yie(E4, a, 4, 7)), a.b), (!a.c && (a.c = new Yie(E4, a, 5, 8)), a.c)]))); gs(d); ) { + c2 = RD(hs(d), 84); + e = AGd(c2); + if (!b) { + b = e; + } else if (b != e) { + return false; + } + } + return true; + } + function SHd(a, b, c2) { + var d; + ++a.j; + if (b >= a.i) + throw Adb(new veb(MIe + b + NIe + a.i)); + if (c2 >= a.i) + throw Adb(new veb(OIe + c2 + NIe + a.i)); + d = a.g[c2]; + if (b != c2) { + b < c2 ? hib(a.g, b, a.g, b + 1, c2 - b) : hib(a.g, c2 + 1, a.g, c2, b - c2); + bD(a.g, b, d); + a.Pi(b, d, c2); + a.Ni(); + } + return d; + } + function Rc(a, b, c2) { + var d; + d = RD(a.c.xc(b), 16); + if (!d) { + d = a.ic(b); + if (d.Fc(c2)) { + ++a.d; + a.c.zc(b, d); + return true; + } else { + throw Adb(new Deb("New Collection violated the Collection spec")); + } + } else if (d.Fc(c2)) { + ++a.d; + return true; + } else { + return false; + } + } + function ngb(a) { + var b, c2, d; + if (a < 0) { + return 0; + } else if (a == 0) { + return 32; + } else { + d = -(a >> 16); + b = d >> 16 & 16; + c2 = 16 - b; + a = a >> b; + d = a - 256; + b = d >> 16 & 8; + c2 += b; + a <<= b; + d = a - qxe; + b = d >> 16 & 4; + c2 += b; + a <<= b; + d = a - Ove; + b = d >> 16 & 2; + c2 += b; + a <<= b; + d = a >> 14; + b = d & ~(d >> 1); + return c2 + 2 - b; + } + } + function RSb(a) { + HSb(); + var b, c2, d, e; + GSb = new bnb(); + FSb = new Tsb(); + ESb = new bnb(); + b = (!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a); + JSb(b); + for (e = new dMd(b); e.e != e.i.gc(); ) { + d = RD(bMd(e), 27); + if (Wmb(GSb, d, 0) == -1) { + c2 = new bnb(); + Rmb(ESb, c2); + KSb(d, c2); + } + } + return ESb; + } + function sTb(a, b, c2) { + var d, e, f2, g; + a.a = c2.b.d; + if (ZD(b, 326)) { + e = IGd(RD(b, 74), false, false); + f2 = ssd(e); + d = new wTb(a); + xgb(f2, d); + lsd(f2, e); + b.of((umd(), cld)) != null && xgb(RD(b.of(cld), 75), d); + } else { + g = RD(b, 422); + g.rh(g.nh() + a.a.a); + g.sh(g.oh() + a.a.b); + } + } + function hWc(a, b) { + var c2, d, e; + e = new bnb(); + for (d = Sub(b.a, 0); d.b != d.d.c; ) { + c2 = RD(evb(d), 65); + c2.c.g == a.g && dE(mQb(c2.b, (h_c(), f_c))) !== dE(mQb(c2.c, f_c)) && !yDb(new SDb(null, new Swb(e, 16)), new IWc(c2)) && (ZEb(e.c, c2), true); + } + _mb(e, new KWc()); + return e; + } + function fUb(a, b, c2) { + var d, e, f2, g; + if (ZD(b, 153) && ZD(c2, 153)) { + f2 = RD(b, 153); + g = RD(c2, 153); + return a.a[f2.a][g.a] + a.a[g.a][f2.a]; + } else if (ZD(b, 250) && ZD(c2, 250)) { + d = RD(b, 250); + e = RD(c2, 250); + if (d.a == e.a) { + return RD(mQb(e.a, (yVb(), lVb)), 17).a; + } + } + return 0; + } + function q9b(a, b) { + var c2, d, e, f2, g, h, i2, j; + j = Kfb(UD(mQb(b, (yCc(), fCc)))); + i2 = a[0].n.a + a[0].o.a + a[0].d.c + j; + for (h = 1; h < a.length; h++) { + d = a[h].n; + e = a[h].o; + c2 = a[h].d; + f2 = d.a - c2.b - i2; + f2 < 0 && (d.a -= f2); + g = b.f; + g.a = $wnd.Math.max(g.a, d.a + e.a); + i2 = d.a + e.a + c2.c + j; + } + } + function Nad(a, b) { + var c2, d, e, f2, g, h; + d = RD(RD(Wjb(a.g, b.a), 42).a, 68); + e = RD(RD(Wjb(a.g, b.b), 42).a, 68); + f2 = d.b; + g = e.b; + c2 = Kid(f2, g); + if (c2 >= 0) { + return c2; + } + h = ejd(ojd(new rjd(g.c + g.b / 2, g.d + g.a / 2), new rjd(f2.c + f2.b / 2, f2.d + f2.a / 2))); + return -(oRb(f2, g) - 1) * h; + } + function ysd(a, b, c2) { + var d; + FDb(new SDb(null, (!c2.a && (c2.a = new C5d(F4, c2, 6, 6)), new Swb(c2.a, 16))), new Qsd(a, b)); + FDb(new SDb(null, (!c2.n && (c2.n = new C5d(I4, c2, 1, 7)), new Swb(c2.n, 16))), new Ssd(a, b)); + d = RD(Gxd(c2, (umd(), cld)), 75); + !!d && Bjd(d, a, b); + } + function Qvd(a, b, c2) { + var d, e, f2; + f2 = Eee((lke(), jke), a.Dh(), b); + if (f2) { + nke(); + RD(f2, 69).xk() || (f2 = zfe(Qee(jke, f2))); + e = (d = a.Ih(f2), RD(d >= 0 ? a.Lh(d, true, true) : Qvd(a, f2, true), 160)); + return RD(e, 220).Sl(b, c2); + } else { + throw Adb(new agb(KHe + b.xe() + NHe)); + } + } + function WNd(a, b, c2, d) { + var e, f2, g, h, i2; + e = a.d[b]; + if (e) { + f2 = e.g; + i2 = e.i; + if (d != null) { + for (h = 0; h < i2; ++h) { + g = RD(f2[h], 136); + if (g.Bi() == c2 && pb(d, g.ld())) { + return g; + } + } + } else { + for (h = 0; h < i2; ++h) { + g = RD(f2[h], 136); + if (dE(g.ld()) === dE(d)) { + return g; + } + } + } + } + return null; + } + function Nee(a, b) { + var c2, d, e, f2, g; + d = (!b.s && (b.s = new C5d(y7, b, 21, 17)), b.s); + f2 = null; + for (e = 0, g = d.i; e < g; ++e) { + c2 = RD(QHd(d, e), 179); + switch (yfe(Qee(a, c2))) { + case 4: + case 5: + case 6: { + !f2 && (f2 = new bnb()); + ZEb(f2.c, c2); + break; + } + } + } + return !f2 ? (yob(), yob(), vob) : f2; + } + function Yib(a, b) { + var c2; + if (b < 0) { + throw Adb(new teb("Negative exponent")); + } + if (b == 0) { + return Kib; + } else if (b == 1 || Sib(a, Kib) || Sib(a, Oib)) { + return a; + } + if (!_ib(a, 0)) { + c2 = 1; + while (!_ib(a, c2)) { + ++c2; + } + return Wib(kjb(c2 * b), Yib($ib(a, c2), b)); + } + return Rjb(a, b); + } + function Jnb(a, b) { + var c2, d, e; + if (dE(a) === dE(b)) { + return true; + } + if (a == null || b == null) { + return false; + } + if (a.length != b.length) { + return false; + } + for (c2 = 0; c2 < a.length; ++c2) { + d = a[c2]; + e = b[c2]; + if (!(dE(d) === dE(e) || d != null && pb(d, e))) { + return false; + } + } + return true; + } + function EYb(a) { + pYb(); + var b, c2, d; + this.b = oYb; + this.c = (Cmd(), Amd); + this.f = (kYb(), jYb); + this.a = a; + BYb(this, new FYb()); + uYb(this); + for (d = new Anb(a.b); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 86); + if (!c2.d) { + b = new iYb(cD(WC(bQ, 1), rve, 86, 0, [c2])); + Rmb(a.a, b); + } + } + } + function U6b(a, b, c2) { + var d, e, f2, g, h, i2; + if (!a || a.c.length == 0) { + return null; + } + f2 = new VKb(b, !c2); + for (e = new Anb(a); e.a < e.c.c.length; ) { + d = RD(ynb(e), 72); + LKb(f2, (i1b(), new D1b(d))); + } + g = f2.i; + g.a = (i2 = f2.n, f2.e.b + i2.d + i2.a); + g.b = (h = f2.n, f2.e.a + h.b + h.c); + return f2; + } + function d9b(a) { + var b, c2, d, e, f2, g, h; + h = t2b(a.a); + Znb(h, new i9b()); + c2 = null; + for (e = h, f2 = 0, g = e.length; f2 < g; ++f2) { + d = e[f2]; + if (d.k != (r3b(), m3b)) { + break; + } + b = RD(mQb(d, (Ywc(), hwc)), 64); + if (b != (qpd(), ppd) && b != Xod) { + continue; + } + !!c2 && RD(mQb(c2, qwc), 15).Fc(d); + c2 = d; + } + } + function wTc(a, b, c2) { + var d, e, f2, g, h, i2, j; + i2 = (tFb(b, a.c.length), RD(a.c[b], 339)); + Xmb(a, b); + if (i2.b / 2 >= c2) { + d = b; + j = (i2.c + i2.a) / 2; + g = j - c2; + if (i2.c <= j - c2) { + e = new BTc(i2.c, g); + Qmb(a, d++, e); + } + h = j + c2; + if (h <= i2.a) { + f2 = new BTc(h, i2.a); + wFb(d, a.c.length); + XEb(a.c, d, f2); + } + } + } + function mZc(a, b, c2) { + var d, e, f2, g, h, i2; + if (!b.dc()) { + e = new Yub(); + for (i2 = b.Kc(); i2.Ob(); ) { + h = RD(i2.Pb(), 40); + Zjb(a.a, sgb(h.g), sgb(c2)); + for (g = (d = Sub(new dXc(h).a.d, 0), new gXc(d)); dvb(g.a); ) { + f2 = RD(evb(g.a), 65).c; + Pub(e, f2, e.c.b, e.c); + } + } + mZc(a, e, c2 + 1); + } + } + function Ude(a) { + var b; + if (!a.c && a.g == null) { + a.d = a.bj(a.f); + WGd(a, a.d); + b = a.d; + } else { + if (a.g == null) { + return true; + } else if (a.i == 0) { + return false; + } else { + b = RD(a.g[a.i - 1], 51); + } + } + if (b == a.b && null.Vm >= null.Um()) { + tId(a); + return Ude(a); + } else { + return b.Ob(); + } + } + function t_b(a) { + this.a = a; + if (a.c.i.k == (r3b(), m3b)) { + this.c = a.c; + this.d = RD(mQb(a.c.i, (Ywc(), hwc)), 64); + } else if (a.d.i.k == m3b) { + this.c = a.d; + this.d = RD(mQb(a.d.i, (Ywc(), hwc)), 64); + } else { + throw Adb(new agb("Edge " + a + " is not an external edge.")); + } + } + function O1d(a, b) { + var c2, d, e; + e = a.b; + a.b = b; + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 3, e, a.b)); + if (!b) { + PAd(a, null); + Q1d(a, 0); + P1d(a, null); + } else if (b != a) { + PAd(a, b.zb); + Q1d(a, b.d); + c2 = (d = b.c, d == null ? b.zb : d); + P1d(a, c2 == null || lhb(c2, b.zb) ? null : c2); + } + } + function hj(a, b) { + var c2; + this.e = (tm(), Qb(a), tm(), zm(a)); + this.c = (Qb(b), zm(b)); + Lb(this.e.Rd().dc() == this.c.Rd().dc()); + this.d = Uv(this.e); + this.b = Uv(this.c); + c2 = YC(jJ, [Nve, rve], [5, 1], 5, [this.e.Rd().gc(), this.c.Rd().gc()], 2); + this.a = c2; + Zi(this); + } + function Lz(b) { + !Jz && (Jz = Mz()), Jz; + var d = b.replace(/[\x00-\x1f\xad\u0600-\u0603\u06dd\u070f\u17b4\u17b5\u200b-\u200f\u2028-\u202e\u2060-\u2064\u206a-\u206f\ufeff\ufff9-\ufffb"\\]/g, function(a) { + return Kz(a); + }); + return '"' + d + '"'; + } + function VEb(a, b, c2, d, e, f2) { + var g, h, i2, j, k; + if (e == 0) { + return; + } + if (dE(a) === dE(c2)) { + a = a.slice(b, b + e); + b = 0; + } + i2 = c2; + for (h = b, j = b + e; h < j; ) { + g = $wnd.Math.min(h + 1e4, j); + e = g - h; + k = a.slice(h, g); + k.splice(0, 0, d, f2 ? e : 0); + Array.prototype.splice.apply(i2, k); + h = g; + d += e; + } + } + function VGb(a) { + FGb(); + var b, c2; + this.b = CGb; + this.c = EGb; + this.g = (wGb(), vGb); + this.d = (Cmd(), Amd); + this.a = a; + IGb(this); + for (c2 = new Anb(a.b); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 60); + !b.a && gGb(iGb(new jGb(), cD(WC(hN, 1), rve, 60, 0, [b])), a); + b.e = new Vid(b.d); + } + } + function yTb(a) { + var b, c2, d, e, f2, g; + e = a.e.c.length; + d = $C(QK, Ize, 15, e, 0, 1); + for (g = new Anb(a.e); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 153); + d[f2.a] = new Yub(); + } + for (c2 = new Anb(a.c); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 290); + d[b.c.a].Fc(b); + d[b.d.a].Fc(b); + } + return d; + } + function OMd(a, b) { + var c2, d, e, f2, g; + c2 = RD(Ywd(a.a, 4), 129); + g = c2 == null ? 0 : c2.length; + if (b >= g) + throw Adb(new aMd(b, g)); + e = c2[b]; + if (g == 1) { + d = null; + } else { + d = $C(d6, IJe, 424, g - 1, 0, 1); + hib(c2, 0, d, 0, b); + f2 = g - b - 1; + f2 > 0 && hib(c2, b + 1, d, b, f2); + } + Bde(a, d); + Ade(a, b, e); + return e; + } + function l3d(a) { + var b, c2; + if (a.f) { + while (a.n < a.o) { + b = RD(!a.j ? a.k.Xb(a.n) : a.j.$i(a.n), 76); + c2 = b.Lk(); + if (ZD(c2, 102) && (RD(c2, 19).Bb & QHe) != 0 && (!a.e || c2.pk() != C4 || c2.Lj() != 0) && b.md() != null) { + return true; + } else { + ++a.n; + } + } + return false; + } else { + return a.n < a.o; + } + } + function Lle() { + Lle = geb; + Jle = RD(QHd(xYd((Qle(), Ple).qb), 6), 35); + Gle = RD(QHd(xYd(Ple.qb), 3), 35); + Hle = RD(QHd(xYd(Ple.qb), 4), 35); + Ile = RD(QHd(xYd(Ple.qb), 5), 19); + vWd(Jle); + vWd(Gle); + vWd(Hle); + vWd(Ile); + Kle = new mob(cD(WC(y7, 1), lKe, 179, 0, [Jle, Gle])); + } + function rMb(a, b) { + var c2; + this.d = new P2b(); + this.b = b; + this.e = new sjd(b.Lf()); + c2 = a.u.Hc((Pod(), Mod)); + a.u.Hc(Lod) ? a.D ? this.a = c2 && !b.bg() : this.a = true : a.u.Hc(Nod) ? c2 ? this.a = !(b.Uf().Kc().Ob() || b.Wf().Kc().Ob()) : this.a = false : this.a = false; + } + function zNb(a, b) { + var c2, d, e, f2; + c2 = a.o.a; + for (f2 = RD(RD(Qc(a.r, b), 21), 87).Kc(); f2.Ob(); ) { + e = RD(f2.Pb(), 117); + e.e.a = (d = e.b, d.pf((umd(), Gld)) ? d.ag() == (qpd(), ppd) ? -d.Mf().a - Kfb(UD(d.of(Gld))) : c2 + Kfb(UD(d.of(Gld))) : d.ag() == (qpd(), ppd) ? -d.Mf().a : c2); + } + } + function $4b(a, b) { + var c2, d, e, f2; + c2 = RD(mQb(a, (yCc(), rAc)), 88); + f2 = RD(Gxd(b, GBc), 64); + e = RD(mQb(a, BBc), 101); + if (e != (Bod(), zod) && e != Aod) { + if (f2 == (qpd(), opd)) { + f2 = osd(b, c2); + f2 == opd && (f2 = vpd(c2)); + } + } else { + d = W4b(b); + d > 0 ? f2 = vpd(c2) : f2 = spd(vpd(c2)); + } + Ixd(b, GBc, f2); + } + function agc(a, b) { + var c2; + b.Ug("Partition preprocessing", 1); + c2 = RD(zDb(CDb(EDb(CDb(new SDb(null, new Swb(a.a, 16)), new egc()), new ggc()), new igc()), tBb(new ZBb(), new XBb(), new wCb(), cD(WC(QL, 1), jwe, 108, 0, [(xBb(), vBb)]))), 15); + FDb(c2.Oc(), new kgc()); + b.Vg(); + } + function Uoc(a, b) { + var c2, d, e, f2, g; + g = a.j; + b.a != b.b && _mb(g, new ypc()); + e = g.c.length / 2 | 0; + for (d = 0; d < e; d++) { + f2 = (tFb(d, g.c.length), RD(g.c[d], 113)); + f2.c && Q3b(f2.d, b.a); + } + for (c2 = e; c2 < g.c.length; c2++) { + f2 = (tFb(c2, g.c.length), RD(g.c[c2], 113)); + f2.c && Q3b(f2.d, b.b); + } + } + function rLc(a, b, c2) { + var d, e, f2; + d = a.c[b.c.p][b.p]; + e = a.c[c2.c.p][c2.p]; + if (d.a != null && e.a != null) { + f2 = Jfb(d.a, e.a); + f2 < 0 ? uLc(a, b, c2) : f2 > 0 && uLc(a, c2, b); + return f2; + } else if (d.a != null) { + uLc(a, b, c2); + return -1; + } else if (e.a != null) { + uLc(a, c2, b); + return 1; + } + return 0; + } + function EVc(a, b) { + var c2, d, e, f2, g; + e = b.b.b; + a.a = $C(QK, Ize, 15, e, 0, 1); + a.b = $C(xdb, Hye, 28, e, 16, 1); + for (g = Sub(b.b, 0); g.b != g.d.c; ) { + f2 = RD(evb(g), 40); + a.a[f2.g] = new Yub(); + } + for (d = Sub(b.a, 0); d.b != d.d.c; ) { + c2 = RD(evb(d), 65); + a.a[c2.b.g].Fc(c2); + a.a[c2.c.g].Fc(c2); + } + } + function SJd(a, b) { + var c2, d, e, f2; + if (a.Pj()) { + c2 = a.Ej(); + f2 = a.Qj(); + ++a.j; + a.qj(c2, a.Zi(c2, b)); + d = a.Ij(3, null, b, c2, f2); + if (a.Mj()) { + e = a.Nj(b, null); + if (!e) { + a.Jj(d); + } else { + e.nj(d); + e.oj(); + } + } else { + a.Jj(d); + } + } else { + _Id(a, b); + if (a.Mj()) { + e = a.Nj(b, null); + !!e && e.oj(); + } + } + } + function oLd(a, b, c2) { + var d, e, f2; + if (a.Pj()) { + f2 = a.Qj(); + KHd(a, b, c2); + d = a.Ij(3, null, c2, b, f2); + if (a.Mj()) { + e = a.Nj(c2, null); + a.Tj() && (e = a.Uj(c2, e)); + if (!e) { + a.Jj(d); + } else { + e.nj(d); + e.oj(); + } + } else { + a.Jj(d); + } + } else { + KHd(a, b, c2); + if (a.Mj()) { + e = a.Nj(c2, null); + !!e && e.oj(); + } + } + } + function bge(a, b) { + var c2, d, e, f2, g; + g = pke(a.e.Dh(), b); + e = new YHd(); + c2 = RD(a.g, 124); + for (f2 = a.i; --f2 >= 0; ) { + d = c2[f2]; + g.am(d.Lk()) && WGd(e, d); + } + !wLd(a, e) && Mvd(a.e) && eZd(a, b.Jk() ? fge(a, 6, b, (yob(), vob), null, -1, false) : fge(a, b.tk() ? 2 : 1, b, null, null, -1, false)); + } + function _7b(a, b) { + var c2, d, e, f2, g; + if (a.a == ($uc(), Yuc)) { + return true; + } + f2 = b.a.c; + c2 = b.a.c + b.a.b; + if (b.j) { + d = b.A; + g = d.c.c.a - d.o.a / 2; + e = f2 - (d.n.a + d.o.a); + if (e > g) { + return false; + } + } + if (b.q) { + d = b.C; + g = d.c.c.a - d.o.a / 2; + e = d.n.a - c2; + if (e > g) { + return false; + } + } + return true; + } + function bRc(a) { + WQc(); + var b, c2, d, e, f2, g, h; + c2 = new gub(); + for (e = new Anb(a.e.b); e.a < e.c.c.length; ) { + d = RD(ynb(e), 30); + for (g = new Anb(d.a); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 10); + h = a.g[f2.p]; + b = RD(cub(c2, h), 15); + if (!b) { + b = new bnb(); + dub(c2, h, b); + } + b.Fc(f2); + } + } + return c2; + } + function Qzd(a) { + var b; + if ((a.Db & 64) != 0) + return awd(a); + b = new Shb(awd(a)); + b.a += " (startX: "; + Khb(b, a.j); + b.a += ", startY: "; + Khb(b, a.k); + b.a += ", endX: "; + Khb(b, a.b); + b.a += ", endY: "; + Khb(b, a.c); + b.a += ", identifier: "; + Nhb(b, a.d); + b.a += ")"; + return b.a; + } + function cWd(a) { + var b; + if ((a.Db & 64) != 0) + return QAd(a); + b = new Shb(QAd(a)); + b.a += " (ordered: "; + Ohb(b, (a.Bb & 256) != 0); + b.a += ", unique: "; + Ohb(b, (a.Bb & 512) != 0); + b.a += ", lowerBound: "; + Lhb(b, a.s); + b.a += ", upperBound: "; + Lhb(b, a.t); + b.a += ")"; + return b.a; + } + function uBd(a, b, c2, d, e, f2, g, h) { + var i2; + ZD(a.Cb, 90) && v$d(yYd(RD(a.Cb, 90)), 4); + PAd(a, c2); + a.f = d; + DWd(a, e); + FWd(a, f2); + xWd(a, g); + EWd(a, false); + aWd(a, true); + AWd(a, h); + _Vd(a, true); + $Vd(a, 0); + a.b = 0; + bWd(a, 1); + i2 = XVd(a, b, null); + !!i2 && i2.oj(); + kXd(a, false); + return a; + } + function ZAb(a, b) { + var c2, d, e, f2; + c2 = RD(Xjb(a.a, b), 525); + if (!c2) { + d = new oBb(b); + e = (gBb(), dBb) ? null : d.c; + f2 = zhb(e, 0, $wnd.Math.max(0, thb(e, Fhb(46)))); + nBb(d, ZAb(a, f2)); + (dBb ? null : d.c).length == 0 && iBb(d, new rBb()); + $jb(a.a, dBb ? null : d.c, d); + return d; + } + return c2; + } + function sRb(a, b) { + var c2; + a.b = b; + a.g = new bnb(); + c2 = tRb(a.b); + a.e = c2; + a.f = c2; + a.c = Heb(TD(mQb(a.b, (YHb(), RHb)))); + a.a = UD(mQb(a.b, (umd(), Dkd))); + a.a == null && (a.a = 1); + Kfb(a.a) > 1 ? a.e *= Kfb(a.a) : a.f /= Kfb(a.a); + uRb(a); + vRb(a); + rRb(a); + pQb(a.b, (tSb(), lSb), a.g); + } + function n9b(a, b, c2) { + var d, e, f2, g, h, i2; + d = 0; + i2 = c2; + if (!b) { + d = c2 * (a.c.length - 1); + i2 *= -1; + } + for (f2 = new Anb(a); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 10); + pQb(e, (yCc(), Rzc), (Rjd(), Njd)); + e.o.a = d; + for (h = e3b(e, (qpd(), Xod)).Kc(); h.Ob(); ) { + g = RD(h.Pb(), 12); + g.n.a = d; + } + d += i2; + } + } + function gZd(a, b, c2) { + var d, e, f2, g, h, i2; + h = a.pl(c2); + if (h != c2) { + g = a.g[b]; + i2 = h; + MHd(a, b, a.Zi(b, i2)); + f2 = g; + a.Ri(b, i2, f2); + if (a.al()) { + d = c2; + e = a.Oj(d, null); + !RD(h, 54).Ph() && (e = a.Nj(i2, e)); + !!e && e.oj(); + } + Mvd(a.e) && eZd(a, a.Ij(9, c2, h, b, false)); + return h; + } else { + return c2; + } + } + function rYb(a, b) { + var c2, d, e, f2; + for (d = new Anb(a.a.a); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 194); + c2.g = true; + } + for (f2 = new Anb(a.a.b); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 86); + e.k = Heb(TD(a.e.Kb(new Ptd(e, b)))); + e.d.g = e.d.g & Heb(TD(a.e.Kb(new Ptd(e, b)))); + } + return a; + } + function Rdc(a, b) { + var c2, d; + if (a.c.length != 0) { + if (a.c.length == 2) { + Qdc((tFb(0, a.c.length), RD(a.c[0], 10)), (Pnd(), Lnd)); + Qdc((tFb(1, a.c.length), RD(a.c[1], 10)), Mnd); + } else { + for (d = new Anb(a); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 10); + Qdc(c2, b); + } + } + a.c.length = 0; + } + } + function Vnc(a) { + var b, c2, d, e, f2; + c2 = (b = RD(mfb(E3), 9), new Fsb(b, RD(WEb(b, b.length), 9), 0)); + f2 = RD(mQb(a, (Ywc(), Iwc)), 10); + if (f2) { + for (e = new Anb(f2.j); e.a < e.c.c.length; ) { + d = RD(ynb(e), 12); + dE(mQb(d, Awc)) === dE(a) && k4b(new l4b(d.b)) && zsb(c2, d.j); + } + } + return c2; + } + function CGc(a, b, c2) { + var d, e, f2, g, h; + if (a.d[c2.p]) { + return; + } + for (e = new is(Mr(a3b(c2).a.Kc(), new ir())); gs(e); ) { + d = RD(hs(e), 18); + h = d.d.i; + for (g = new is(Mr(Z2b(h).a.Kc(), new ir())); gs(g); ) { + f2 = RD(hs(g), 18); + f2.c.i == b && (a.a[f2.p] = true); + } + CGc(a, b, h); + } + a.d[c2.p] = true; + } + function Zwd(a, b) { + var c2, d, e, f2, g, h, i2; + d = ggb(a.Db & 254); + if (d == 1) { + a.Eb = null; + } else { + f2 = SD(a.Eb); + if (d == 2) { + e = Xwd(a, b); + a.Eb = f2[e == 0 ? 1 : 0]; + } else { + g = $C(jJ, rve, 1, d - 1, 5, 1); + for (c2 = 2, h = 0, i2 = 0; c2 <= 128; c2 <<= 1) { + c2 == b ? ++h : (a.Db & c2) != 0 && (g[i2++] = f2[h++]); + } + a.Eb = g; + } + } + a.Db &= ~b; + } + function rse(a) { + var b; + b = 0; + switch (a) { + case 105: + b = 2; + break; + case 109: + b = 8; + break; + case 115: + b = 4; + break; + case 120: + b = 16; + break; + case 117: + b = 32; + break; + case 119: + b = 64; + break; + case 70: + b = 256; + break; + case 72: + b = 128; + break; + case 88: + b = 512; + break; + case 44: + b = gwe; + } + return b; + } + function Ojb(a, b, c2, d, e) { + var f2, g, h, i2; + if (dE(a) === dE(b) && d == e) { + Tjb(a, d, c2); + return; + } + for (h = 0; h < d; h++) { + g = 0; + f2 = a[h]; + for (i2 = 0; i2 < e; i2++) { + g = Bdb(Bdb(Ndb(Cdb(f2, yxe), Cdb(b[i2], yxe)), Cdb(c2[h + i2], yxe)), Cdb(Ydb(g), yxe)); + c2[h + i2] = Ydb(g); + g = Udb(g, 32); + } + c2[h + e] = Ydb(g); + } + } + function tRb(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l; + k = 0; + j = 0; + e = a.a; + h = e.a.gc(); + for (d = e.a.ec().Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 567); + b = (c2.b && CRb(c2), c2.a); + l = b.a; + g = b.b; + k += l + g; + j += l * g; + } + i2 = $wnd.Math.sqrt(400 * h * j - 4 * j + k * k) + k; + f2 = 2 * (100 * h - 1); + if (f2 == 0) { + return i2; + } + return i2 / f2; + } + function MSc(a, b) { + if (b.b != 0) { + isNaN(a.s) ? a.s = Kfb((sFb(b.b != 0), UD(b.a.a.c))) : a.s = $wnd.Math.min(a.s, Kfb((sFb(b.b != 0), UD(b.a.a.c)))); + isNaN(a.c) ? a.c = Kfb((sFb(b.b != 0), UD(b.c.b.c))) : a.c = $wnd.Math.max(a.c, Kfb((sFb(b.b != 0), UD(b.c.b.c)))); + } + } + function nzd(a) { + var b, c2, d, e; + b = null; + for (d = Fl(Al(cD(WC(cJ, 1), rve, 20, 0, [(!a.b && (a.b = new Yie(E4, a, 4, 7)), a.b), (!a.c && (a.c = new Yie(E4, a, 5, 8)), a.c)]))); gs(d); ) { + c2 = RD(hs(d), 84); + e = AGd(c2); + if (!b) { + b = vCd(e); + } else if (b != vCd(e)) { + return true; + } + } + return false; + } + function pLd(a, b) { + var c2, d, e, f2; + if (a.Pj()) { + c2 = a.i; + f2 = a.Qj(); + LHd(a, b); + d = a.Ij(3, null, b, c2, f2); + if (a.Mj()) { + e = a.Nj(b, null); + a.Tj() && (e = a.Uj(b, e)); + if (!e) { + a.Jj(d); + } else { + e.nj(d); + e.oj(); + } + } else { + a.Jj(d); + } + } else { + LHd(a, b); + if (a.Mj()) { + e = a.Nj(b, null); + !!e && e.oj(); + } + } + } + function ZQb(a, b) { + var c2, d, e, f2; + f2 = rAb(a.a, b.b); + if (!f2) { + throw Adb(new dgb("Invalid hitboxes for scanline overlap calculation.")); + } + e = false; + for (d = a.a.a.ec().Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 68); + if (UQb(b.b, c2)) { + bbd(a.b.a, b.b, c2); + e = true; + } else { + if (e) { + break; + } + } + } + } + function whd(a) { + var b; + if (!a.a) { + throw Adb(new dgb("IDataType class expected for layout option " + a.f)); + } + b = GId(a.a); + if (b == null) { + throw Adb(new dgb("Couldn't create new instance of property '" + a.f + "'. " + DGe + (lfb(b6), b6.k) + EGe)); + } + return RD(b, 423); + } + function yvd(a) { + var b, c2, d, e, f2; + f2 = a.Ph(); + if (f2) { + if (f2.Vh()) { + e = Vvd(a, f2); + if (e != f2) { + c2 = a.Fh(); + d = (b = a.Fh(), b >= 0 ? a.Ah(null) : a.Ph().Th(a, -1 - b, null, null)); + a.Bh(RD(e, 54), c2); + !!d && d.oj(); + a.vh() && a.wh() && c2 > -1 && qvd(a, new N3d(a, 9, c2, f2, e)); + return e; + } + } + } + return f2; + } + function stb(a, b) { + var c2, d, e, f2, g; + f2 = a.b.Ce(b); + d = (c2 = a.a.get(f2), c2 == null ? $C(jJ, rve, 1, 0, 5, 1) : c2); + for (g = 0; g < d.length; g++) { + e = d[g]; + if (a.b.Be(b, e.ld())) { + if (d.length == 1) { + d.length = 0; + Btb(a.a, f2); + } else { + d.splice(g, 1); + } + --a.c; + ++a.b.g; + return e.md(); + } + } + return null; + } + function pWb(a) { + var b, c2, d, e, f2, g, h, i2; + g = 0; + f2 = a.f.e; + for (d = 0; d < f2.c.length; ++d) { + h = (tFb(d, f2.c.length), RD(f2.c[d], 153)); + for (e = d + 1; e < f2.c.length; ++e) { + i2 = (tFb(e, f2.c.length), RD(f2.c[e], 153)); + c2 = bjd(h.d, i2.d); + b = c2 - a.a[h.a][i2.a]; + g += a.i[h.a][i2.a] * b * b; + } + } + return g; + } + function oec(a, b) { + var c2; + if (nQb(b, (yCc(), UAc))) { + return; + } + c2 = wec(RD(mQb(b, hec), 371), RD(mQb(a, UAc), 171)); + pQb(b, hec, c2); + if (gs(new is(Mr(W2b(b).a.Kc(), new ir())))) { + return; + } + switch (c2.g) { + case 1: + pQb(b, UAc, (cxc(), Zwc)); + break; + case 2: + pQb(b, UAc, (cxc(), _wc)); + } + } + function aoc(a, b) { + var c2; + Snc(a); + a.a = (c2 = new Ri(), FDb(new SDb(null, new Swb(b.d, 16)), new zoc(c2)), c2); + Xnc(a, RD(mQb(b.b, (yCc(), CAc)), 349)); + Znc(a); + Ync(a); + Wnc(a); + $nc(a); + _nc(a, b); + FDb(EDb(new SDb(null, gj(ej(a.b).a)), new poc()), new roc()); + b.a = false; + a.a = null; + } + function B$c() { + B$c = geb; + r$c = new lGd(REe, (Geb(), false)); + s$c = new lGd(SEe, 7); + sgb(0); + y$c = new lGd(TEe, sgb(0)); + v$c = new lGd(UEe, sgb(-1)); + A$c = (s_c(), r_c); + z$c = new lGd(VEe, A$c); + u$c = (LZc(), IZc); + t$c = new lGd(WEe, u$c); + x$c = (A_c(), z_c); + w$c = new lGd(XEe, x$c); + } + function _Bd() { + FBd.call(this, $He, (bvd(), avd)); + this.p = null; + this.a = null; + this.f = null; + this.n = null; + this.g = null; + this.c = null; + this.i = null; + this.j = null; + this.d = null; + this.b = null; + this.e = null; + this.k = null; + this.o = null; + this.s = null; + this.q = false; + this.r = false; + } + function aGd() { + aGd = geb; + _Fd = new bGd(FBe, 0); + YFd = new bGd("INSIDE_SELF_LOOPS", 1); + ZFd = new bGd("MULTI_EDGES", 2); + XFd = new bGd("EDGE_LABELS", 3); + $Fd = new bGd("PORTS", 4); + VFd = new bGd("COMPOUND", 5); + UFd = new bGd("CLUSTERS", 6); + WFd = new bGd("DISCONNECTED", 7); + } + function RJd(a, b, c2) { + var d, e, f2; + if (a.Pj()) { + f2 = a.Qj(); + ++a.j; + a.qj(b, a.Zi(b, c2)); + d = a.Ij(3, null, c2, b, f2); + if (a.Mj()) { + e = a.Nj(c2, null); + if (!e) { + a.Jj(d); + } else { + e.nj(d); + e.oj(); + } + } else { + a.Jj(d); + } + } else { + ++a.j; + a.qj(b, a.Zi(b, c2)); + if (a.Mj()) { + e = a.Nj(c2, null); + !!e && e.oj(); + } + } + } + function _ib(a, b) { + var c2, d, e; + if (b == 0) { + return (a.a[0] & 1) != 0; + } + if (b < 0) { + throw Adb(new teb("Negative bit address")); + } + e = b >> 5; + if (e >= a.d) { + return a.e < 0; + } + c2 = a.a[e]; + b = 1 << (b & 31); + if (a.e < 0) { + d = Uib(a); + if (e < d) { + return false; + } else + d == e ? c2 = -c2 : c2 = ~c2; + } + return (c2 & b) != 0; + } + function Zdd(a, b, c2, d) { + var e; + RD(c2.b, 68); + RD(c2.b, 68); + RD(d.b, 68); + RD(d.b, 68); + e = ojd(ajd(RD(c2.b, 68).c), RD(d.b, 68).c); + kjd(e, PQb(RD(c2.b, 68), RD(d.b, 68), e)); + RD(d.b, 68); + RD(d.b, 68); + RD(d.b, 68).c.a + e.a; + RD(d.b, 68).c.b + e.b; + RD(d.b, 68); + Umb(d.a, new ced(a, b, d)); + } + function V$d(a, b) { + var c2, d, e, f2, g, h, i2; + f2 = b.e; + if (f2) { + c2 = yvd(f2); + d = RD(a.g, 689); + for (g = 0; g < a.i; ++g) { + i2 = d[g]; + if (h2d(i2) == c2) { + e = (!i2.d && (i2.d = new XZd(o7, i2, 1)), i2.d); + h = RD(c2.Mh(jwd(f2, f2.Cb, f2.Db >> 16)), 15).dd(f2); + if (h < e.i) { + return V$d(a, RD(QHd(e, h), 89)); + } + } + } + } + return b; + } + function feb(a, b, c2) { + var d = eeb, h; + var e = d[a]; + var f2 = e instanceof Array ? e[0] : null; + if (e && !f2) { + _2 = e; + } else { + _2 = (h = b && b.prototype, !h && (h = eeb[b]), ieb(h)); + _2.Sm = c2; + !b && (_2.Tm = keb); + d[a] = _2; + } + for (var g = 3; g < arguments.length; ++g) { + arguments[g].prototype = _2; + } + f2 && (_2.Rm = f2); + } + function gs(a) { + var b; + while (!RD(Qb(a.a), 51).Ob()) { + a.d = fs(a); + if (!a.d) { + return false; + } + a.a = RD(a.d.Pb(), 51); + if (ZD(a.a, 38)) { + b = RD(a.a, 38); + a.a = b.a; + !a.b && (a.b = new wmb()); + hmb(a.b, a.d); + if (b.b) { + while (!nmb(b.b)) { + hmb(a.b, RD(tmb(b.b), 51)); + } + } + a.d = b.d; + } + } + return true; + } + function xJb(a, b) { + var c2, d, e, f2; + e = 1; + b.j = true; + f2 = null; + for (d = new Anb(CIb(b)); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 218); + if (!a.c[c2.c]) { + a.c[c2.c] = true; + f2 = oIb(c2, b); + if (c2.f) { + e += xJb(a, f2); + } else if (!f2.j && c2.a == c2.e.e - c2.d.e) { + c2.f = true; + Ysb(a.p, c2); + e += xJb(a, f2); + } + } + } + return e; + } + function OYb(a) { + var b, c2, d; + for (c2 = new Anb(a.a.a.b); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 86); + d = (uFb(0), 0); + if (d > 0) { + !(Dmd(a.a.c) && b.n.d) && !(Emd(a.a.c) && b.n.b) && (b.g.d += $wnd.Math.max(0, d / 2 - 0.5)); + !(Dmd(a.a.c) && b.n.a) && !(Emd(a.a.c) && b.n.c) && (b.g.a -= d - 1); + } + } + } + function c7b(a) { + var b, c2, d, e, f2; + e = new bnb(); + f2 = d7b(a, e); + b = RD(mQb(a, (Ywc(), Iwc)), 10); + if (b) { + for (d = new Anb(b.j); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 12); + dE(mQb(c2, Awc)) === dE(a) && (f2 = $wnd.Math.max(f2, d7b(c2, e))); + } + } + e.c.length == 0 || pQb(a, ywc, f2); + return f2 != -1 ? e : null; + } + function rcc(a, b, c2) { + var d, e, f2, g, h, i2; + f2 = RD(Vmb(b.e, 0), 18).c; + d = f2.i; + e = d.k; + i2 = RD(Vmb(c2.g, 0), 18).d; + g = i2.i; + h = g.k; + e == (r3b(), o3b) ? pQb(a, (Ywc(), vwc), RD(mQb(d, vwc), 12)) : pQb(a, (Ywc(), vwc), f2); + h == o3b ? pQb(a, (Ywc(), wwc), RD(mQb(g, wwc), 12)) : pQb(a, (Ywc(), wwc), i2); + } + function ysc(a) { + var b, c2, d; + this.c = a; + d = RD(mQb(a, (yCc(), rAc)), 88); + b = Kfb(UD(mQb(a, Tzc))); + c2 = Kfb(UD(mQb(a, oCc))); + d == (Cmd(), ymd) || d == zmd || d == Amd ? this.b = b * c2 : this.b = 1 / (b * c2); + this.j = Kfb(UD(mQb(a, cCc))); + this.e = Kfb(UD(mQb(a, bCc))); + this.f = a.b.c.length; + } + function BD(a, b) { + var c2, d, e, f2, g; + b &= 63; + c2 = a.h; + d = (c2 & fxe) != 0; + d && (c2 |= -1048576); + if (b < 22) { + g = c2 >> b; + f2 = a.m >> b | c2 << 22 - b; + e = a.l >> b | a.m << 22 - b; + } else if (b < 44) { + g = d ? exe : 0; + f2 = c2 >> b - 22; + e = a.m >> b - 22 | c2 << 44 - b; + } else { + g = d ? exe : 0; + f2 = d ? dxe : 0; + e = c2 >> b - 44; + } + return hD(e & dxe, f2 & dxe, g & exe); + } + function ORb(a) { + var b, c2, d, e, f2, g; + this.c = new bnb(); + this.d = a; + d = oxe; + e = oxe; + b = pxe; + c2 = pxe; + for (g = Sub(a, 0); g.b != g.d.c; ) { + f2 = RD(evb(g), 8); + d = $wnd.Math.min(d, f2.a); + e = $wnd.Math.min(e, f2.b); + b = $wnd.Math.max(b, f2.a); + c2 = $wnd.Math.max(c2, f2.b); + } + this.a = new Uid2(d, e, b - d, c2 - e); + } + function Udc(a, b) { + var c2, d, e, f2, g, h; + for (f2 = new Anb(a.b); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 30); + for (h = new Anb(e.a); h.a < h.c.c.length; ) { + g = RD(ynb(h), 10); + g.k == (r3b(), n3b) && Qdc(g, b); + for (d = new is(Mr(a3b(g).a.Kc(), new ir())); gs(d); ) { + c2 = RD(hs(d), 18); + Pdc(c2, b); + } + } + } + } + function nec(a, b) { + var c2, d, e; + b.Ug("Layer constraint preprocessing", 1); + c2 = new bnb(); + e = new Jkb(a.a, 0); + while (e.b < e.d.gc()) { + d = (sFb(e.b < e.d.gc()), RD(e.d.Xb(e.c = e.b++), 10)); + if (mec(d)) { + kec(d); + ZEb(c2.c, d); + Ckb(e); + } + } + c2.c.length == 0 || pQb(a, (Ywc(), lwc), c2); + b.Vg(); + } + function $Hc(a) { + var b, c2; + a.e = $C(kE, Pwe, 28, a.p.c.length, 15, 1); + a.k = $C(kE, Pwe, 28, a.p.c.length, 15, 1); + for (c2 = new Anb(a.p); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 10); + a.e[b.p] = Kr(new is(Mr(Z2b(b).a.Kc(), new ir()))); + a.k[b.p] = Kr(new is(Mr(a3b(b).a.Kc(), new ir()))); + } + } + function bIc(a) { + var b, c2, d, e, f2, g; + e = 0; + a.q = new bnb(); + b = new _sb(); + for (g = new Anb(a.p); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 10); + f2.p = e; + for (d = new is(Mr(a3b(f2).a.Kc(), new ir())); gs(d); ) { + c2 = RD(hs(d), 18); + Ysb(b, c2.d.i); + } + b.a.Bc(f2) != null; + Rmb(a.q, new btb(b)); + b.a.$b(); + ++e; + } + } + function pPd(a, b) { + var c2, d, e, f2, g, h, i2, j, k; + if (a.a.f > 0 && ZD(b, 44)) { + a.a._j(); + j = RD(b, 44); + i2 = j.ld(); + f2 = i2 == null ? 0 : tb(i2); + g = bOd(a.a, f2); + c2 = a.a.d[g]; + if (c2) { + d = RD(c2.g, 379); + k = c2.i; + for (h = 0; h < k; ++h) { + e = d[h]; + if (e.Bi() == f2 && e.Fb(j)) { + pPd(a, j); + return true; + } + } + } + } + return false; + } + function Nje(a) { + var b, c2, d, e, f2, g, h; + b = a.qi(AKe); + if (b) { + h = WD($Nd((!b.b && (b.b = new SVd((JTd(), FTd), C8, b)), b.b), "settingDelegates")); + if (h != null) { + c2 = new bnb(); + for (e = vhb(h, "\\w+"), f2 = 0, g = e.length; f2 < g; ++f2) { + d = e[f2]; + ZEb(c2.c, d); + } + return c2; + } + } + return yob(), yob(), vob; + } + function Ync(a) { + var b, c2, d, e; + for (e = RD(Qc(a.a, (Bnc(), ync)), 15).Kc(); e.Ob(); ) { + d = RD(e.Pb(), 105); + c2 = (b = Ec(d.k), b.Hc((qpd(), Yod)) ? b.Hc(Xod) ? b.Hc(npd) ? b.Hc(ppd) ? null : Jnc : Lnc : Knc : Inc); + Qnc(a, d, c2[0], (joc(), goc), 0); + Qnc(a, d, c2[1], hoc, 1); + Qnc(a, d, c2[2], ioc, 1); + } + } + function Kqc(a, b) { + var c2, d; + c2 = Lqc(b); + Oqc(a, b, c2); + UTc(a.a, RD(mQb(Y2b(b.b), (Ywc(), Lwc)), 234)); + Jqc(a); + Iqc(a, b); + d = $C(kE, Pwe, 28, b.b.j.c.length, 15, 1); + Rqc(a, b, (qpd(), Yod), d, c2); + Rqc(a, b, Xod, d, c2); + Rqc(a, b, npd, d, c2); + Rqc(a, b, ppd, d, c2); + a.a = null; + a.c = null; + a.b = null; + } + function Yyd(a, b, c2) { + switch (b) { + case 7: + !a.e && (a.e = new Yie(G4, a, 7, 4)); + sLd(a.e); + !a.e && (a.e = new Yie(G4, a, 7, 4)); + YGd(a.e, RD(c2, 16)); + return; + case 8: + !a.d && (a.d = new Yie(G4, a, 8, 5)); + sLd(a.d); + !a.d && (a.d = new Yie(G4, a, 8, 5)); + YGd(a.d, RD(c2, 16)); + return; + } + xyd(a, b, c2); + } + function Rt(a, b) { + var c2, d, e, f2, g; + if (dE(b) === dE(a)) { + return true; + } + if (!ZD(b, 15)) { + return false; + } + g = RD(b, 15); + if (a.gc() != g.gc()) { + return false; + } + f2 = g.Kc(); + for (d = a.Kc(); d.Ob(); ) { + c2 = d.Pb(); + e = f2.Pb(); + if (!(dE(c2) === dE(e) || c2 != null && pb(c2, e))) { + return false; + } + } + return true; + } + function jac(a, b) { + var c2, d, e, f2; + f2 = RD(zDb(EDb(EDb(new SDb(null, new Swb(b.b, 16)), new pac()), new rac()), tBb(new ZBb(), new XBb(), new wCb(), cD(WC(QL, 1), jwe, 108, 0, [(xBb(), vBb)]))), 15); + f2.Jc(new tac()); + c2 = 0; + for (e = f2.Kc(); e.Ob(); ) { + d = RD(e.Pb(), 12); + d.p == -1 && iac(a, d, c2++); + } + } + function KDc(a) { + switch (a.g) { + case 0: + return new iQc(); + case 1: + return new DNc(); + case 2: + return new TNc(); + case 3: + return new aRc(); + case 4: + return new yOc(); + default: + throw Adb(new agb("No implementation is available for the node placer " + (a.f != null ? a.f : "" + a.g))); + } + } + function Qtc(a) { + switch (a.g) { + case 0: + return new UFc(); + case 1: + return new NFc(); + case 2: + return new cGc(); + case 3: + return new jGc(); + case 4: + return new YFc(); + default: + throw Adb(new agb("No implementation is available for the cycle breaker " + (a.f != null ? a.f : "" + a.g))); + } + } + function I_c(a, b) { + var c2, d, e, f2, g; + d = new Yub(); + Pub(d, b, d.c.b, d.c); + do { + c2 = (sFb(d.b != 0), RD(Wub(d, d.a.a), 40)); + a.b[c2.g] = 1; + for (f2 = Sub(c2.d, 0); f2.b != f2.d.c; ) { + e = RD(evb(f2), 65); + g = e.c; + a.b[g.g] == 1 ? Mub(a.a, e) : a.b[g.g] == 2 ? a.b[g.g] = 1 : Pub(d, g, d.c.b, d.c); + } + } while (d.b != 0); + } + function $$b(a, b, c2) { + var d; + d = null; + !!b && (d = b.d); + k_b(a, new eZb(b.n.a - d.b + c2.a, b.n.b - d.d + c2.b)); + k_b(a, new eZb(b.n.a - d.b + c2.a, b.n.b + b.o.b + d.a + c2.b)); + k_b(a, new eZb(b.n.a + b.o.a + d.c + c2.a, b.n.b - d.d + c2.b)); + k_b(a, new eZb(b.n.a + b.o.a + d.c + c2.a, b.n.b + b.o.b + d.a + c2.b)); + } + function iac(a, b, c2) { + var d, e, f2; + b.p = c2; + for (f2 = Fl(Al(cD(WC(cJ, 1), rve, 20, 0, [new T3b(b), new _3b(b)]))); gs(f2); ) { + d = RD(hs(f2), 12); + d.p == -1 && iac(a, d, c2); + } + if (b.i.k == (r3b(), o3b)) { + for (e = new Anb(b.i.j); e.a < e.c.c.length; ) { + d = RD(ynb(e), 12); + d != b && d.p == -1 && iac(a, d, c2); + } + } + } + function cRc(a, b) { + var c2, d, e, f2, g, h; + d = new gub(); + g = Xx(new mob(a.g)); + for (f2 = g.a.ec().Kc(); f2.Ob(); ) { + e = RD(f2.Pb(), 10); + if (!e) { + b.bh("There are no classes in a balanced layout."); + break; + } + h = a.j[e.p]; + c2 = RD(cub(d, h), 15); + if (!c2) { + c2 = new bnb(); + dub(d, h, c2); + } + c2.Fc(e); + } + return d; + } + function RTc(a) { + var b, c2, d, e, f2; + e = RD(zDb(BDb(ODb(a)), tBb(new ZBb(), new XBb(), new wCb(), cD(WC(QL, 1), jwe, 108, 0, [(xBb(), vBb)]))), 15); + d = Hze; + if (e.gc() >= 2) { + c2 = e.Kc(); + b = UD(c2.Pb()); + while (c2.Ob()) { + f2 = b; + b = UD(c2.Pb()); + d = $wnd.Math.min(d, (uFb(b), b) - (uFb(f2), f2)); + } + } + return d; + } + function iWc(a, b) { + var c2, d, e; + e = new bnb(); + for (d = Sub(b.a, 0); d.b != d.d.c; ) { + c2 = RD(evb(d), 65); + c2.b.g == a.g && !lhb(c2.b.c, IEe) && dE(mQb(c2.b, (h_c(), f_c))) !== dE(mQb(c2.c, f_c)) && !yDb(new SDb(null, new Swb(e, 16)), new OWc(c2)) && (ZEb(e.c, c2), true); + } + _mb(e, new QWc()); + return e; + } + function $u(a, b) { + var c2, d, e; + if (dE(b) === dE(Qb(a))) { + return true; + } + if (!ZD(b, 15)) { + return false; + } + d = RD(b, 15); + e = a.gc(); + if (e != d.gc()) { + return false; + } + if (ZD(d, 59)) { + for (c2 = 0; c2 < e; c2++) { + if (!Hb(a.Xb(c2), d.Xb(c2))) { + return false; + } + } + return true; + } else { + return Cr(a.Kc(), d.Kc()); + } + } + function Scc(a, b, c2, d, e, f2) { + var g, h, i2, j; + h = !QDb(CDb(a.Oc(), new PAb(new Wcc()))).Bd((xDb(), wDb)); + g = a; + f2 == (Cmd(), Bmd) && (g = hv(g)); + for (j = g.Kc(); j.Ob(); ) { + i2 = RD(j.Pb(), 72); + i2.n.a = b.a; + h ? i2.n.b = b.b + (d.b - i2.o.b) / 2 : e ? i2.n.b = b.b : i2.n.b = b.b + d.b - i2.o.b; + b.a += i2.o.a + c2; + } + } + function Tgc(a, b) { + var c2, d, e, f2, g; + b.Ug("Port side processing", 1); + for (g = new Anb(a.a); g.a < g.c.c.length; ) { + e = RD(ynb(g), 10); + Ugc(e); + } + for (d = new Anb(a.b); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 30); + for (f2 = new Anb(c2.a); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 10); + Ugc(e); + } + } + b.Vg(); + } + function bEd(a, b, c2) { + var d, e, f2, g, h, i2, j; + if (c2) { + f2 = c2.a.length; + d = new vue(f2); + for (h = (d.b - d.a) * d.c < 0 ? (uue(), tue) : new Rue(d); h.Ob(); ) { + g = RD(h.Pb(), 17); + i2 = xDd(c2, g.a); + if (i2) { + j = FGd(zDd(i2, hIe), b); + Zjb(a.f, j, i2); + e = uIe in i2.a; + e && jyd(j, zDd(i2, uIe)); + GEd(i2, j); + HEd(i2, j); + } + } + } + } + function MWb(a, b, c2) { + var d, e, f2, g, h; + h = c2; + !h && (h = Nqd(new Oqd(), 0)); + h.Ug(EAe, 1); + cXb(a.c, b); + g = H_b(a.a, b); + if (g.gc() == 1) { + OWb(RD(g.Xb(0), 36), h); + } else { + f2 = 1 / g.gc(); + for (e = g.Kc(); e.Ob(); ) { + d = RD(e.Pb(), 36); + if (c2.$g()) { + return; + } + OWb(d, h.eh(f2)); + } + } + F_b(a.a, g, b); + PWb(b); + h.Vg(); + } + function Hic(a, b, c2) { + var d, e, f2, g, h; + e = a.f; + !e && (e = RD(a.a.a.ec().Kc().Pb(), 60)); + Iic(e, b, c2); + if (a.a.a.gc() == 1) { + return; + } + d = b * c2; + for (g = a.a.a.ec().Kc(); g.Ob(); ) { + f2 = RD(g.Pb(), 60); + if (f2 != e) { + h = $jc(f2); + if (h.f.d) { + f2.d.d += d + Tye; + f2.d.a -= d + Tye; + } else + h.f.a && (f2.d.a -= d + Tye); + } + } + } + function kTb(a, b, c2, d, e) { + var f2, g, h, i2, j, k, l, m, n; + g = c2 - a; + h = d - b; + f2 = $wnd.Math.atan2(g, h); + i2 = f2 + Gze; + j = f2 - Gze; + k = e * $wnd.Math.sin(i2) + a; + m = e * $wnd.Math.cos(i2) + b; + l = e * $wnd.Math.sin(j) + a; + n = e * $wnd.Math.cos(j) + b; + return dv(cD(WC(l3, 1), Nve, 8, 0, [new rjd(k, m), new rjd(l, n)])); + } + function mQc(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l; + e = c2; + k = b; + f2 = k; + do { + f2 = a.a[f2.p]; + h = (l = a.g[f2.p], Kfb(a.p[l.p]) + Kfb(a.d[f2.p]) - f2.d.d); + i2 = pQc(f2, d); + if (i2) { + g = (j = a.g[i2.p], Kfb(a.p[j.p]) + Kfb(a.d[i2.p]) + i2.o.b + i2.d.a); + e = $wnd.Math.min(e, h - (g + bFc(a.k, f2, i2))); + } + } while (k != f2); + return e; + } + function nQc(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l; + e = c2; + k = b; + f2 = k; + do { + f2 = a.a[f2.p]; + g = (l = a.g[f2.p], Kfb(a.p[l.p]) + Kfb(a.d[f2.p]) + f2.o.b + f2.d.a); + i2 = oQc(f2, d); + if (i2) { + h = (j = a.g[i2.p], Kfb(a.p[j.p]) + Kfb(a.d[i2.p]) - i2.d.d); + e = $wnd.Math.min(e, h - (g + bFc(a.k, f2, i2))); + } + } while (k != f2); + return e; + } + function r9c(a, b) { + var c2; + b.Ug("Equal Whitespace Eliminator", 1); + if (Hxd(a, (X6c(), V6c))) { + w9c(RD(Gxd(a, V6c), 15), Kfb(UD(Gxd(a, O6c))), (c2 = Kfb(UD(Gxd(a, M6c))), Kfb(UD(Gxd(a, (X7c(), Q7c)))), c2)); + } else { + throw Adb(new Jed("The graph does not contain rows.")); + } + b.Vg(); + } + function Gxd(a, b) { + var c2, d; + d = (!a.o && (a.o = new DVd((pvd(), mvd), X4, a, 0)), $Nd(a.o, b)); + if (d != null) { + return d; + } + c2 = b.Sg(); + ZD(c2, 4) && (c2 == null ? (!a.o && (a.o = new DVd((pvd(), mvd), X4, a, 0)), jOd(a.o, b)) : (!a.o && (a.o = new DVd((pvd(), mvd), X4, a, 0)), fOd(a.o, b, c2)), a); + return c2; + } + function dod() { + dod = geb; + Xnd = new eod("H_LEFT", 0); + Wnd = new eod("H_CENTER", 1); + Znd = new eod("H_RIGHT", 2); + cod = new eod("V_TOP", 3); + bod = new eod("V_CENTER", 4); + aod = new eod("V_BOTTOM", 5); + $nd = new eod("INSIDE", 6); + _nd = new eod("OUTSIDE", 7); + Ynd = new eod("H_PRIORITY", 8); + } + function jJb(a, b) { + var c2, d, e, f2, g, h, i2; + if (!b.f) { + throw Adb(new agb("The input edge is not a tree edge.")); + } + f2 = null; + e = lve; + for (d = new Anb(a.d); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 218); + h = c2.d; + i2 = c2.e; + if (oJb(a, h, b) && !oJb(a, i2, b)) { + g = i2.e - h.e - c2.a; + if (g < e) { + e = g; + f2 = c2; + } + } + } + return f2; + } + function sWb(a) { + var b, c2, d, e, f2, g; + if (a.f.e.c.length <= 1) { + return; + } + b = 0; + e = pWb(a); + c2 = oxe; + do { + b > 0 && (e = c2); + for (g = new Anb(a.f.e); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 153); + if (Heb(TD(mQb(f2, (dWb(), WVb))))) { + continue; + } + d = oWb(a, f2); + $id(hjd(f2.d), d); + } + c2 = pWb(a); + } while (!rWb(a, b++, e, c2)); + } + function Ymc(a, b) { + var c2, d, e, f2, g; + f2 = a.g.a; + g = a.g.b; + for (d = new Anb(a.d); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 72); + e = c2.n; + a.a == (enc(), bnc) || a.i == (qpd(), Xod) ? e.a = f2 : a.a == cnc || a.i == (qpd(), ppd) ? e.a = f2 + a.j.a - c2.o.a : e.a = f2 + (a.j.a - c2.o.a) / 2; + e.b = g; + $id(e, b); + g += c2.o.b + a.e; + } + } + function BEd(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l; + j = a; + i2 = yDd(j, "individualSpacings"); + if (i2) { + d = Hxd(b, (umd(), amd)); + g = !d; + if (g) { + e = new dtd(); + Ixd(b, amd, e); + } + h = RD(Gxd(b, amd), 385); + l = i2; + f2 = null; + !!l && (f2 = (k = oC(l, $C(qJ, Nve, 2, 0, 6, 1)), new CC(l, k))); + if (f2) { + c2 = new dFd(l, h); + xgb(f2, c2); + } + } + } + function FEd(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m; + i2 = null; + l = a; + k = null; + if (DIe in l.a || EIe in l.a || nIe in l.a) { + j = null; + m = EGd(b); + g = yDd(l, DIe); + c2 = new gFd(m); + cEd(c2.a, g); + h = yDd(l, EIe); + d = new AFd(m); + nEd(d.a, h); + f2 = wDd(l, nIe); + e = new DFd(m); + j = (oEd(e.a, f2), f2); + k = j; + } + i2 = k; + return i2; + } + function ox(a, b) { + var c2, d, e; + if (b === a) { + return true; + } + if (ZD(b, 552)) { + e = RD(b, 849); + if (a.a.d != e.a.d || Ih(a).gc() != Ih(e).gc()) { + return false; + } + for (d = Ih(e).Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 425); + if (Qw(a, c2.a.ld()) != RD(c2.a.md(), 16).gc()) { + return false; + } + } + return true; + } + return false; + } + function sPb(a) { + var b, c2, d, e; + d = RD(a.a, 17).a; + e = RD(a.b, 17).a; + b = d; + c2 = e; + if (d == 0 && e == 0) { + c2 -= 1; + } else { + if (d == -1 && e <= 0) { + b = 0; + c2 -= 2; + } else { + if (d <= 0 && e > 0) { + b -= 1; + c2 -= 1; + } else { + if (d >= 0 && e < 0) { + b += 1; + c2 += 1; + } else { + if (d > 0 && e >= 0) { + b -= 1; + c2 += 1; + } else { + b += 1; + c2 -= 1; + } + } + } + } + } + return new Ptd(sgb(b), sgb(c2)); + } + function nNc(a, b) { + if (a.c < b.c) { + return -1; + } else if (a.c > b.c) { + return 1; + } else if (a.b < b.b) { + return -1; + } else if (a.b > b.b) { + return 1; + } else if (a.a != b.a) { + return tb(a.a) - tb(b.a); + } else if (a.d == (sNc(), rNc) && b.d == qNc) { + return -1; + } else if (a.d == qNc && b.d == rNc) { + return 1; + } + return 0; + } + function ARc(a, b) { + var c2, d, e, f2, g; + f2 = b.a; + f2.c.i == b.b ? g = f2.d : g = f2.c; + f2.c.i == b.b ? d = f2.c : d = f2.d; + e = lQc(a.a, g, d); + if (e > 0 && e < Hze) { + c2 = mQc(a.a, d.i, e, a.c); + rQc(a.a, d.i, -c2); + return c2 > 0; + } else if (e < 0 && -e < Hze) { + c2 = nQc(a.a, d.i, -e, a.c); + rQc(a.a, d.i, c2); + return c2 > 0; + } + return false; + } + function X9c(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l; + e = (b - a.d) / a.c.c.length; + f2 = 0; + a.a += c2; + a.d = b; + for (l = new Anb(a.c); l.a < l.c.c.length; ) { + k = RD(ynb(l), 27); + j = k.g; + i2 = k.f; + Dyd(k, k.i + f2 * e); + Eyd(k, k.j + d * c2); + Cyd(k, k.g + e); + Ayd(k, a.a); + ++f2; + h = k.g; + g = k.f; + Jsd(k, new rjd(h, g), new rjd(j, i2)); + } + } + function vAd(a) { + var b, c2, d, e, f2, g, h; + if (a == null) { + return null; + } + h = a.length; + e = (h + 1) / 2 | 0; + g = $C(gE, YHe, 28, e, 15, 1); + h % 2 != 0 && (g[--e] = JAd((BFb(h - 1, a.length), a.charCodeAt(h - 1)))); + for (c2 = 0, d = 0; c2 < e; ++c2) { + b = JAd(ihb(a, d++)); + f2 = JAd(ihb(a, d++)); + g[c2] = (b << 4 | f2) << 24 >> 24; + } + return g; + } + function Bfb(a) { + if (a.ze()) { + var b = a.c; + b.Ae() ? a.o = "[" + b.n : !b.ze() ? a.o = "[L" + b.xe() + ";" : a.o = "[" + b.xe(); + a.b = b.we() + "[]"; + a.k = b.ye() + "[]"; + return; + } + var c2 = a.j; + var d = a.d; + d = d.split("/"); + a.o = Efb(".", [c2, Efb("$", d)]); + a.b = Efb(".", [c2, Efb(".", d)]); + a.k = d[d.length - 1]; + } + function hJb(a, b) { + var c2, d, e, f2, g; + g = null; + for (f2 = new Anb(a.e.a); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 125); + if (e.b.a.c.length == e.g.a.c.length) { + d = e.e; + g = sJb(e); + for (c2 = e.e - RD(g.a, 17).a + 1; c2 < e.e + RD(g.b, 17).a; c2++) { + b[c2] < b[d] && (d = c2); + } + if (b[d] < b[e.e]) { + --b[e.e]; + ++b[d]; + e.e = d; + } + } + } + } + function qQc(a) { + var b, c2, d, e, f2, g, h, i2; + e = oxe; + d = pxe; + for (c2 = new Anb(a.e.b); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 30); + for (g = new Anb(b.a); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 10); + i2 = Kfb(a.p[f2.p]); + h = i2 + Kfb(a.b[a.g[f2.p].p]); + e = $wnd.Math.min(e, i2); + d = $wnd.Math.max(d, h); + } + } + return d - e; + } + function nSd(a) { + gSd(); + var b, c2, d, e; + d = qhb(a, Fhb(35)); + b = d == -1 ? a : (AFb(0, d, a.length), a.substr(0, d)); + c2 = d == -1 ? null : (BFb(d + 1, a.length + 1), a.substr(d + 1)); + e = KSd(fSd, b); + if (!e) { + e = ASd(b); + LSd(fSd, b, e); + c2 != null && (e = hSd(e, c2)); + } else + c2 != null && (e = hSd(e, (uFb(c2), c2))); + return e; + } + function Ree(a, b, c2, d) { + var e, f2, g, h, j; + e = Fee(a, b); + for (h = 0, j = e.gc(); h < j; ++h) { + f2 = RD(e.Xb(h), 179); + if (lhb(d, Afe(Qee(a, f2)))) { + g = Bfe(Qee(a, f2)); + if (c2 == null) { + if (g == null) { + return f2; + } + } else if (lhb(c2, g)) { + return f2; + } else + ; + } + } + return null; + } + function See(a, b, c2, d) { + var e, f2, g, h, j; + e = Gee(a, b); + for (h = 0, j = e.gc(); h < j; ++h) { + f2 = RD(e.Xb(h), 179); + if (lhb(d, Afe(Qee(a, f2)))) { + g = Bfe(Qee(a, f2)); + if (c2 == null) { + if (g == null) { + return f2; + } + } else if (lhb(c2, g)) { + return f2; + } else + ; + } + } + return null; + } + function Pge(a, b, c2) { + var d, e, f2, g, h, i2; + g = new YHd(); + h = pke(a.e.Dh(), b); + d = RD(a.g, 124); + nke(); + if (RD(b, 69).xk()) { + for (f2 = 0; f2 < a.i; ++f2) { + e = d[f2]; + h.am(e.Lk()) && WGd(g, e); + } + } else { + for (f2 = 0; f2 < a.i; ++f2) { + e = d[f2]; + if (h.am(e.Lk())) { + i2 = e.md(); + WGd(g, c2 ? Bge(a, b, f2, g.i, i2) : i2); + } + } + } + return WHd(g); + } + function Kje(a) { + var b, c2, d, e, f2, g, h; + if (a) { + b = a.qi(AKe); + if (b) { + g = WD($Nd((!b.b && (b.b = new SVd((JTd(), FTd), C8, b)), b.b), "conversionDelegates")); + if (g != null) { + h = new bnb(); + for (d = vhb(g, "\\w+"), e = 0, f2 = d.length; e < f2; ++e) { + c2 = d[e]; + ZEb(h.c, c2); + } + return h; + } + } + } + return yob(), yob(), vob; + } + function WXb(a, b) { + var c2, d, e, f2, g, h, i2, j; + g = b == 1 ? MXb : LXb; + for (f2 = g.a.ec().Kc(); f2.Ob(); ) { + e = RD(f2.Pb(), 88); + for (i2 = RD(Qc(a.f.c, e), 21).Kc(); i2.Ob(); ) { + h = RD(i2.Pb(), 42); + d = RD(h.b, 86); + j = RD(h.a, 194); + c2 = j.c; + switch (e.g) { + case 2: + case 1: + d.g.d += c2; + break; + case 4: + case 3: + d.g.c += c2; + } + } + } + } + function idc(a, b) { + var c2, d, e, f2, g; + c2 = new Zrb(ZW); + for (e = (btc(), cD(WC(ZW, 1), jwe, 232, 0, [Zsc, _sc, Ysc, $sc, atc, Xsc])), f2 = 0, g = e.length; f2 < g; ++f2) { + d = e[f2]; + Xrb(c2, d, new bnb()); + } + FDb(GDb(CDb(EDb(new SDb(null, new Swb(a.b, 16)), new ydc()), new Adc()), new Cdc(b)), new Edc(c2)); + return c2; + } + function n3c(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m; + for (f2 = b.Kc(); f2.Ob(); ) { + e = RD(f2.Pb(), 27); + k = e.i + e.g / 2; + m = e.j + e.f / 2; + i2 = a.f; + g = i2.i + i2.g / 2; + h = i2.j + i2.f / 2; + j = k - g; + l = m - h; + d = $wnd.Math.sqrt(j * j + l * l); + j *= a.e / d; + l *= a.e / d; + if (c2) { + k -= j; + m -= l; + } else { + k += j; + m += l; + } + Dyd(e, k - e.g / 2); + Eyd(e, m - e.f / 2); + } + } + function vte(a) { + var b, c2, d; + if (a.c) + return; + if (a.b == null) + return; + for (b = a.b.length - 4; b >= 0; b -= 2) { + for (c2 = 0; c2 <= b; c2 += 2) { + if (a.b[c2] > a.b[c2 + 2] || a.b[c2] === a.b[c2 + 2] && a.b[c2 + 1] > a.b[c2 + 3]) { + d = a.b[c2 + 2]; + a.b[c2 + 2] = a.b[c2]; + a.b[c2] = d; + d = a.b[c2 + 3]; + a.b[c2 + 3] = a.b[c2 + 1]; + a.b[c2 + 1] = d; + } + } + } + a.c = true; + } + function nKc(a, b) { + var c2, d, e, f2, g, h, i2, j, k; + j = -1; + k = 0; + for (g = a, h = 0, i2 = g.length; h < i2; ++h) { + f2 = g[h]; + c2 = new hrc(j == -1 ? a[0] : a[j], b, (lDc(), kDc)); + for (d = 0; d < f2.length; d++) { + for (e = d + 1; e < f2.length; e++) { + nQb(f2[d], (Ywc(), zwc)) && nQb(f2[e], zwc) && crc(c2, f2[d], f2[e]) > 0 && ++k; + } + } + ++j; + } + return k; + } + function awd(a) { + var b, c2; + c2 = new dib(nfb(a.Rm)); + c2.a += "@"; + Zhb(c2, (b = tb(a) >>> 0, b.toString(16))); + if (a.Vh()) { + c2.a += " (eProxyURI: "; + Yhb(c2, a._h()); + if (a.Kh()) { + c2.a += " eClass: "; + Yhb(c2, a.Kh()); + } + c2.a += ")"; + } else if (a.Kh()) { + c2.a += " (eClass: "; + Yhb(c2, a.Kh()); + c2.a += ")"; + } + return c2.a; + } + function KGb(a) { + var b, c2, d, e; + if (a.e) { + throw Adb(new dgb((lfb(lN), lye + lN.k + mye))); + } + a.d == (Cmd(), Amd) && JGb(a, ymd); + for (c2 = new Anb(a.a.a); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 316); + b.g = b.i; + } + for (e = new Anb(a.a.b); e.a < e.c.c.length; ) { + d = RD(ynb(e), 60); + d.i = pxe; + } + a.b.cf(a); + return a; + } + function rUc(a, b) { + var c2, d, e, f2, g; + if (b < 2 * a.b) { + throw Adb(new agb("The knot vector must have at least two time the dimension elements.")); + } + a.f = 1; + for (e = 0; e < a.b; e++) { + Rmb(a.e, 0); + } + g = b + 1 - 2 * a.b; + c2 = g; + for (f2 = 1; f2 < g; f2++) { + Rmb(a.e, f2 / c2); + } + if (a.d) { + for (d = 0; d < a.b; d++) { + Rmb(a.e, 1); + } + } + } + function AEd(a, b) { + var c2, d, e, f2, g, h, i2, j, k; + j = b; + k = RD(lp(Co(a.i), j), 27); + if (!k) { + e = zDd(j, uIe); + h = "Unable to find elk node for json object '" + e; + i2 = h + "' Panic!"; + throw Adb(new CDd(i2)); + } + f2 = wDd(j, "edges"); + c2 = new KEd(a, k); + MDd(c2.a, c2.b, f2); + g = wDd(j, iIe); + d = new VEd(a); + XDd(d.a, g); + } + function XNd(a, b, c2, d) { + var e, f2, g, h, i2; + if (d != null) { + e = a.d[b]; + if (e) { + f2 = e.g; + i2 = e.i; + for (h = 0; h < i2; ++h) { + g = RD(f2[h], 136); + if (g.Bi() == c2 && pb(d, g.ld())) { + return h; + } + } + } + } else { + e = a.d[b]; + if (e) { + f2 = e.g; + i2 = e.i; + for (h = 0; h < i2; ++h) { + g = RD(f2[h], 136); + if (dE(g.ld()) === dE(d)) { + return h; + } + } + } + } + return -1; + } + function N5d(a, b) { + var c2, d, e; + c2 = b == null ? Wd(qtb(a.f, null)) : Ktb(a.i, b); + if (ZD(c2, 241)) { + e = RD(c2, 241); + e.zi() == null && void 0; + return e; + } else if (ZD(c2, 507)) { + d = RD(c2, 2037); + e = d.a; + !!e && (e.yb == null ? void 0 : b == null ? rtb(a.f, null, e) : Ltb(a.i, b, e)); + return e; + } else { + return null; + } + } + function Hqe(a) { + Gqe(); + var b, c2, d, e, f2, g, h; + if (a == null) + return null; + e = a.length; + if (e % 2 != 0) + return null; + b = Ahb(a); + f2 = e / 2 | 0; + c2 = $C(gE, YHe, 28, f2, 15, 1); + for (d = 0; d < f2; d++) { + g = Eqe[b[d * 2]]; + if (g == -1) + return null; + h = Eqe[b[d * 2 + 1]]; + if (h == -1) + return null; + c2[d] = (g << 4 | h) << 24 >> 24; + } + return c2; + } + function cNb(a, b, c2) { + var d, e, f2; + e = RD(Vrb(a.i, b), 314); + if (!e) { + e = new UKb(a.d, b, c2); + Wrb(a.i, b, e); + if (jMb(b)) { + tKb(a.a, b.c, b.b, e); + } else { + f2 = iMb(b); + d = RD(Vrb(a.p, f2), 252); + switch (f2.g) { + case 1: + case 3: + e.j = true; + cLb(d, b.b, e); + break; + case 4: + case 2: + e.k = true; + cLb(d, b.c, e); + } + } + } + return e; + } + function Ndc(a, b) { + var c2, d, e, f2, g, h, i2, j, k; + i2 = ev(a.c - a.b & a.a.length - 1); + j = null; + k = null; + for (f2 = new Kmb(a); f2.a != f2.b; ) { + e = RD(Imb(f2), 10); + c2 = (h = RD(mQb(e, (Ywc(), vwc)), 12), !h ? null : h.i); + d = (g = RD(mQb(e, wwc), 12), !g ? null : g.i); + if (j != c2 || k != d) { + Rdc(i2, b); + j = c2; + k = d; + } + ZEb(i2.c, e); + } + Rdc(i2, b); + } + function Rge(a, b, c2, d) { + var e, f2, g, h, i2, j; + h = new YHd(); + i2 = pke(a.e.Dh(), b); + e = RD(a.g, 124); + nke(); + if (RD(b, 69).xk()) { + for (g = 0; g < a.i; ++g) { + f2 = e[g]; + i2.am(f2.Lk()) && WGd(h, f2); + } + } else { + for (g = 0; g < a.i; ++g) { + f2 = e[g]; + if (i2.am(f2.Lk())) { + j = f2.md(); + WGd(h, d ? Bge(a, b, g, h.i, j) : j); + } + } + } + return XHd(h, c2); + } + function oHc(a, b) { + var c2, d, e, f2, g, h, i2, j; + e = a.b[b.p]; + if (e >= 0) { + return e; + } else { + f2 = 1; + for (h = new Anb(b.j); h.a < h.c.c.length; ) { + g = RD(ynb(h), 12); + for (d = new Anb(g.g); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 18); + j = c2.d.i; + if (b != j) { + i2 = oHc(a, j); + f2 = $wnd.Math.max(f2, i2 + 1); + } + } + } + nHc(a, b, f2); + return f2; + } + } + function wHc(a, b) { + var c2, d, e, f2, g, h, i2, j; + e = a.b[b.p]; + if (e >= 0) { + return e; + } else { + f2 = 1; + for (h = new Anb(b.j); h.a < h.c.c.length; ) { + g = RD(ynb(h), 12); + for (d = new Anb(g.e); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 18); + j = c2.c.i; + if (b != j) { + i2 = wHc(a, j); + f2 = $wnd.Math.max(f2, i2 + 1); + } + } + } + vHc(a, b, f2); + return f2; + } + } + function wLc(a, b, c2) { + var d, e, f2; + for (d = 1; d < a.c.length; d++) { + f2 = (tFb(d, a.c.length), RD(a.c[d], 10)); + e = d; + while (e > 0 && b.Ne((tFb(e - 1, a.c.length), RD(a.c[e - 1], 10)), f2) > 0) { + $mb(a, e, (tFb(e - 1, a.c.length), RD(a.c[e - 1], 10))); + --e; + } + tFb(e, a.c.length); + a.c[e] = f2; + } + c2.a = new Tsb(); + c2.b = new Tsb(); + } + function yhd(a, b, c2) { + var d, e, f2, g, h, i2, j, k; + k = (d = RD(b.e && b.e(), 9), new Fsb(d, RD(WEb(d, d.length), 9), 0)); + i2 = vhb(c2, "[\\[\\]\\s,]+"); + for (f2 = i2, g = 0, h = f2.length; g < h; ++g) { + e = f2[g]; + if (Dhb(e).length == 0) { + continue; + } + j = xhd(a, e); + if (j == null) { + return null; + } else { + zsb(k, RD(j, 22)); + } + } + return k; + } + function tse(a) { + var b, c2, d, e; + e = a.length; + b = null; + for (d = 0; d < e; d++) { + c2 = (BFb(d, a.length), a.charCodeAt(d)); + if (qhb(".*+?{[()|\\^$", Fhb(c2)) >= 0) { + if (!b) { + b = new Rhb(); + d > 0 && Nhb(b, (AFb(0, d, a.length), a.substr(0, d))); + } + b.a += "\\"; + Jhb(b, c2 & Bwe); + } else + !!b && Jhb(b, c2 & Bwe); + } + return b ? b.a : a; + } + function MYb(a) { + var b, c2, d; + for (c2 = new Anb(a.a.a.b); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 86); + d = (uFb(0), 0); + if (d > 0) { + !(Dmd(a.a.c) && b.n.d) && !(Emd(a.a.c) && b.n.b) && (b.g.d -= $wnd.Math.max(0, d / 2 - 0.5)); + !(Dmd(a.a.c) && b.n.a) && !(Emd(a.a.c) && b.n.c) && (b.g.a += $wnd.Math.max(0, d - 1)); + } + } + } + function Ydc(a, b, c2) { + var d, e; + if ((a.c - a.b & a.a.length - 1) == 2) { + if (b == (qpd(), Yod) || b == Xod) { + Odc(RD(omb(a), 15), (Pnd(), Lnd)); + Odc(RD(omb(a), 15), Mnd); + } else { + Odc(RD(omb(a), 15), (Pnd(), Mnd)); + Odc(RD(omb(a), 15), Lnd); + } + } else { + for (e = new Kmb(a); e.a != e.b; ) { + d = RD(Imb(e), 15); + Odc(d, c2); + } + } + } + function HGd(a, b) { + var c2, d, e, f2, g, h, i2; + e = cv(new QGd(a)); + h = new Jkb(e, e.c.length); + f2 = cv(new QGd(b)); + i2 = new Jkb(f2, f2.c.length); + g = null; + while (h.b > 0 && i2.b > 0) { + c2 = (sFb(h.b > 0), RD(h.a.Xb(h.c = --h.b), 27)); + d = (sFb(i2.b > 0), RD(i2.a.Xb(i2.c = --i2.b), 27)); + if (c2 == d) { + g = c2; + } else { + break; + } + } + return g; + } + function Dmc(a, b, c2) { + var d, e, f2, g; + if (Hmc(a, b) > Hmc(a, c2)) { + d = b3b(c2, (qpd(), Xod)); + a.d = d.dc() ? 0 : L3b(RD(d.Xb(0), 12)); + g = b3b(b, ppd); + a.b = g.dc() ? 0 : L3b(RD(g.Xb(0), 12)); + } else { + e = b3b(c2, (qpd(), ppd)); + a.d = e.dc() ? 0 : L3b(RD(e.Xb(0), 12)); + f2 = b3b(b, Xod); + a.b = f2.dc() ? 0 : L3b(RD(f2.Xb(0), 12)); + } + } + function wNb(a, b) { + var c2, d, e, f2; + c2 = a.o.a; + for (f2 = RD(RD(Qc(a.r, b), 21), 87).Kc(); f2.Ob(); ) { + e = RD(f2.Pb(), 117); + e.e.a = c2 * Kfb(UD(e.b.of(sNb))); + e.e.b = (d = e.b, d.pf((umd(), Gld)) ? d.ag() == (qpd(), Yod) ? -d.Mf().b - Kfb(UD(d.of(Gld))) : Kfb(UD(d.of(Gld))) : d.ag() == (qpd(), Yod) ? -d.Mf().b : 0); + } + } + function Mhc(a, b) { + var c2, d, e, f2; + b.Ug("Self-Loop pre-processing", 1); + for (d = new Anb(a.a); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 10); + if (pnc(c2)) { + e = (f2 = new onc(c2), pQb(c2, (Ywc(), Pwc), f2), lnc(f2), f2); + FDb(GDb(EDb(new SDb(null, new Swb(e.d, 16)), new Phc()), new Rhc()), new Thc()); + Khc(e); + } + } + b.Vg(); + } + function xsc(a) { + var b, c2, d, e, f2, g, h, i2; + b = true; + e = null; + f2 = null; + j: + for (i2 = new Anb(a.a); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 10); + for (d = new is(Mr(Z2b(h).a.Kc(), new ir())); gs(d); ) { + c2 = RD(hs(d), 18); + if (!!e && e != h) { + b = false; + break j; + } + e = h; + g = c2.c.i; + if (!!f2 && f2 != g) { + b = false; + break j; + } + f2 = g; + } + } + return b; + } + function mTc(a, b, c2) { + var d, e, f2, g, h, i2; + f2 = -1; + h = -1; + for (g = 0; g < b.c.length; g++) { + e = (tFb(g, b.c.length), RD(b.c[g], 339)); + if (e.c > a.c) { + break; + } else if (e.a >= a.s) { + f2 < 0 && (f2 = g); + h = g; + } + } + i2 = (a.s + a.c) / 2; + if (f2 >= 0) { + d = lTc(a, b, f2, h); + i2 = yTc((tFb(d, b.c.length), RD(b.c[d], 339))); + wTc(b, d, c2); + } + return i2; + } + function _Ad(a, b, c2) { + var d, e, f2, g, h, i2, j; + g = (f2 = new pVd(), f2); + nVd(g, (uFb(b), b)); + j = (!g.b && (g.b = new SVd((JTd(), FTd), C8, g)), g.b); + for (i2 = 1; i2 < c2.length; i2 += 2) { + fOd(j, c2[i2 - 1], c2[i2]); + } + d = (!a.Ab && (a.Ab = new C5d(f7, a, 0, 3)), a.Ab); + for (h = 0; h < 0; ++h) { + e = jVd(RD(QHd(d, d.i - 1), 598)); + d = e; + } + WGd(d, g); + } + function DSb(a, b, c2) { + var d, e, f2; + jQb.call(this, new bnb()); + this.a = b; + this.b = c2; + this.e = a; + d = (a.b && CRb(a), a.a); + this.d = BSb(d.a, this.a); + this.c = BSb(d.b, this.b); + bQb(this, this.d, this.c); + CSb(this); + for (f2 = this.e.e.a.ec().Kc(); f2.Ob(); ) { + e = RD(f2.Pb(), 272); + e.c.c.length > 0 && ASb(this, e); + } + } + function zTb(a, b, c2, d, e, f2) { + var g, h, i2; + if (!e[b.a]) { + e[b.a] = true; + g = d; + !g && (g = new gUb()); + Rmb(g.e, b); + for (i2 = f2[b.a].Kc(); i2.Ob(); ) { + h = RD(i2.Pb(), 290); + if (h.d == c2 || h.c == c2) { + continue; + } + h.c != b && zTb(a, h.c, b, g, e, f2); + h.d != b && zTb(a, h.d, b, g, e, f2); + Rmb(g.c, h); + Tmb(g.d, h.b); + } + return g; + } + return null; + } + function v7b(a) { + var b, c2, d, e, f2, g, h; + b = 0; + for (e = new Anb(a.e); e.a < e.c.c.length; ) { + d = RD(ynb(e), 18); + c2 = yDb(new SDb(null, new Swb(d.b, 16)), new N7b()); + c2 && ++b; + } + for (g = new Anb(a.g); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 18); + h = yDb(new SDb(null, new Swb(f2.b, 16)), new P7b()); + h && ++b; + } + return b >= 2; + } + function _qc(a, b, c2, d, e) { + var f2, g, h, i2, j, k; + f2 = a.c.d.j; + g = RD(ju(c2, 0), 8); + for (k = 1; k < c2.b; k++) { + j = RD(ju(c2, k), 8); + Pub(d, g, d.c.b, d.c); + h = ijd($id(new sjd(g), j), 0.5); + i2 = ijd(new qjd(BVc(f2)), e); + $id(h, i2); + Pub(d, h, d.c.b, d.c); + g = j; + f2 = b == 0 ? tpd(f2) : rpd(f2); + } + Mub(d, (sFb(c2.b != 0), RD(c2.c.b.c, 8))); + } + function fod(a) { + dod(); + var b, c2, d; + c2 = ysb($nd, cD(WC(A3, 1), jwe, 95, 0, [_nd])); + if (dy(Tx(c2, a)) > 1) { + return false; + } + b = ysb(Xnd, cD(WC(A3, 1), jwe, 95, 0, [Wnd, Znd])); + if (dy(Tx(b, a)) > 1) { + return false; + } + d = ysb(cod, cD(WC(A3, 1), jwe, 95, 0, [bod, aod])); + if (dy(Tx(d, a)) > 1) { + return false; + } + return true; + } + function $Uc(a, b, c2) { + var d, e, f2; + for (f2 = new Anb(a.t); f2.a < f2.c.c.length; ) { + d = RD(ynb(f2), 274); + if (d.b.s < 0 && d.c > 0) { + d.b.n -= d.c; + d.b.n <= 0 && d.b.u > 0 && Mub(b, d.b); + } + } + for (e = new Anb(a.i); e.a < e.c.c.length; ) { + d = RD(ynb(e), 274); + if (d.a.s < 0 && d.c > 0) { + d.a.u -= d.c; + d.a.u <= 0 && d.a.n > 0 && Mub(c2, d.a); + } + } + } + function tId(a) { + var b, c2, d, e, f2; + if (a.g == null) { + a.d = a.bj(a.f); + WGd(a, a.d); + if (a.c) { + f2 = a.f; + return f2; + } + } + b = RD(a.g[a.i - 1], 51); + e = b.Pb(); + a.e = b; + c2 = a.bj(e); + if (c2.Ob()) { + a.d = c2; + WGd(a, c2); + } else { + a.d = null; + while (!b.Ob()) { + bD(a.g, --a.i, null); + if (a.i == 0) { + break; + } + d = RD(a.g[a.i - 1], 51); + b = d; + } + } + return e; + } + function Rfe(a, b) { + var c2, d, e, f2, g, h; + d = b; + e = d.Lk(); + if (qke(a.e, e)) { + if (e.Si() && cge(a, e, d.md())) { + return false; + } + } else { + h = pke(a.e.Dh(), e); + c2 = RD(a.g, 124); + for (f2 = 0; f2 < a.i; ++f2) { + g = c2[f2]; + if (h.am(g.Lk())) { + if (pb(g, d)) { + return false; + } else { + RD(eHd(a, f2, b), 76); + return true; + } + } + } + } + return WGd(a, b); + } + function Icc(a, b, c2, d) { + var e, f2, g, h; + e = new j3b(a); + h3b(e, (r3b(), n3b)); + pQb(e, (Ywc(), Awc), b); + pQb(e, Mwc, d); + pQb(e, (yCc(), BBc), (Bod(), wod)); + pQb(e, vwc, b.c); + pQb(e, wwc, b.d); + Oec(b, e); + h = $wnd.Math.floor(c2 / 2); + for (g = new Anb(e.j); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 12); + f2.n.b = h; + } + return e; + } + function fSc(a) { + var b, c2, d, e, f2, g, h; + b = 0; + for (d = new Anb(a.a); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 10); + for (f2 = new is(Mr(a3b(c2).a.Kc(), new ir())); gs(f2); ) { + e = RD(hs(f2), 18); + if (a == e.d.i.c && e.c.j == (qpd(), ppd)) { + g = K3b(e.c).b; + h = K3b(e.d).b; + b = $wnd.Math.max(b, $wnd.Math.abs(h - g)); + } + } + } + return b; + } + function QTb(a, b, c2) { + var d, e, f2, g, h; + c2.Ug("ELK Force", 1); + Heb(TD(Gxd(b, (yVb(), gVb)))) || RFb((d = new SFb((lud(), new zud(b))), d)); + h = KTb(b); + RTb(h); + STb(a, RD(mQb(h, bVb), 432)); + g = CTb(a.a, h); + for (f2 = g.Kc(); f2.Ob(); ) { + e = RD(f2.Pb(), 235); + pUb(a.b, e, c2.eh(1 / g.gc())); + } + h = BTb(g); + JTb(h); + c2.Vg(); + } + function d_b(a, b, c2) { + switch (c2.g) { + case 1: + return new rjd(b.a, $wnd.Math.min(a.d.b, b.b)); + case 2: + return new rjd($wnd.Math.max(a.c.a, b.a), b.b); + case 3: + return new rjd(b.a, $wnd.Math.max(a.c.b, b.b)); + case 4: + return new rjd($wnd.Math.min(b.a, a.d.a), b.b); + } + return new rjd(b.a, b.b); + } + function yGd(a) { + var b, c2, d; + b = ev(1 + (!a.c && (a.c = new C5d(K4, a, 9, 9)), a.c).i); + Rmb(b, (!a.d && (a.d = new Yie(G4, a, 8, 5)), a.d)); + for (d = new dMd((!a.c && (a.c = new C5d(K4, a, 9, 9)), a.c)); d.e != d.i.gc(); ) { + c2 = RD(bMd(d), 123); + Rmb(b, (!c2.d && (c2.d = new Yie(G4, c2, 8, 5)), c2.d)); + } + return Qb(b), new Dl(b); + } + function zGd(a) { + var b, c2, d; + b = ev(1 + (!a.c && (a.c = new C5d(K4, a, 9, 9)), a.c).i); + Rmb(b, (!a.e && (a.e = new Yie(G4, a, 7, 4)), a.e)); + for (d = new dMd((!a.c && (a.c = new C5d(K4, a, 9, 9)), a.c)); d.e != d.i.gc(); ) { + c2 = RD(bMd(d), 123); + Rmb(b, (!c2.e && (c2.e = new Yie(G4, c2, 7, 4)), c2.e)); + } + return Qb(b), new Dl(b); + } + function jne(a) { + var b, c2, d, e; + if (a == null) { + return null; + } else { + d = nue(a, true); + e = mLe.length; + if (lhb(d.substr(d.length - e, e), mLe)) { + c2 = d.length; + if (c2 == 4) { + b = (BFb(0, d.length), d.charCodeAt(0)); + if (b == 43) { + return Wme; + } else if (b == 45) { + return Vme; + } + } else if (c2 == 3) { + return Wme; + } + } + return Neb(d); + } + } + function _rc(a, b) { + var c2, d, e, f2, g; + b.Ug("Breaking Point Processor", 1); + $rc(a); + if (Heb(TD(mQb(a, (yCc(), uCc))))) { + for (e = new Anb(a.b); e.a < e.c.c.length; ) { + d = RD(ynb(e), 30); + c2 = 0; + for (g = new Anb(d.a); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 10); + f2.p = c2++; + } + } + Vrc(a); + Wrc(a, true); + Wrc(a, false); + } + b.Vg(); + } + function MJc(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m; + l = d ? (qpd(), ppd) : (qpd(), Xod); + e = false; + for (i2 = b[c2], j = 0, k = i2.length; j < k; ++j) { + h = i2[j]; + if (Cod(RD(mQb(h, (yCc(), BBc)), 101))) { + continue; + } + g = h.e; + m = !b3b(h, l).dc() && !!g; + if (m) { + f2 = c1b(g); + a.b = new Ylc(f2, d ? 0 : f2.length - 1); + } + e = e | NJc(a, h, l, m); + } + return e; + } + function gOc(a, b, c2, d) { + var e, f2, g; + g = T0b(b, c2); + ZEb(d.c, b); + if (a.j[g.p] == -1 || a.j[g.p] == 2 || a.a[b.p]) { + return d; + } + a.j[g.p] = -1; + for (f2 = new is(Mr(W2b(g).a.Kc(), new ir())); gs(f2); ) { + e = RD(hs(f2), 18); + if (!(!W0b(e) && !(!W0b(e) && e.c.i.c == e.d.i.c)) || e == b) { + continue; + } + return gOc(a, e, g, d); + } + return d; + } + function AOc(a) { + var b, c2, d, e; + b = 0; + c2 = 0; + for (e = new Anb(a.j); e.a < e.c.c.length; ) { + d = RD(ynb(e), 12); + b = Ydb(Bdb(b, ADb(CDb(new SDb(null, new Swb(d.e, 16)), new NPc())))); + c2 = Ydb(Bdb(c2, ADb(CDb(new SDb(null, new Swb(d.g, 16)), new PPc())))); + if (b > 1 || c2 > 1) { + return 2; + } + } + if (b + c2 == 1) { + return 2; + } + return 0; + } + function Kwb(a, b) { + var c2, d, e, f2, g, h; + f2 = a.a * Mxe + a.b * 1502; + h = a.b * Mxe + 11; + c2 = $wnd.Math.floor(h * Nxe); + f2 += c2; + h -= c2 * Oxe; + f2 %= Oxe; + a.a = f2; + a.b = h; + if (b <= 24) { + return $wnd.Math.floor(a.a * Ewb[b]); + } else { + e = a.a * (1 << b - 24); + g = $wnd.Math.floor(a.b * Fwb[b]); + d = e + g; + d >= 2147483648 && (d -= 4294967296); + return d; + } + } + function uSc(a, b, c2) { + var d, e, f2, g, h, i2, j; + f2 = new bnb(); + j = new Yub(); + g = new Yub(); + vSc(a, j, g, b); + tSc(a, j, g, b, c2); + for (i2 = new Anb(a); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 118); + for (e = new Anb(h.k); e.a < e.c.c.length; ) { + d = RD(ynb(e), 132); + (!b || d.c == (fTc(), dTc)) && h.g > d.b.g && (ZEb(f2.c, d), true); + } + } + return f2; + } + function jed(a, b, c2) { + var d, e, f2, g, h, i2; + h = a.c; + for (g = (!c2.q ? (yob(), yob(), wob) : c2.q).vc().Kc(); g.Ob(); ) { + f2 = RD(g.Pb(), 44); + d = !QDb(CDb(new SDb(null, new Swb(h, 16)), new PAb(new xed(b, f2)))).Bd((xDb(), wDb)); + if (d) { + i2 = f2.md(); + if (ZD(i2, 4)) { + e = FId(i2); + e != null && (i2 = e); + } + b.qf(RD(f2.ld(), 149), i2); + } + } + } + function mbd(a, b, c2) { + var d, e; + Sed(a.b); + Ved(a.b, (gbd(), dbd), (_cd(), $cd)); + Ved(a.b, ebd, b.g); + Ved(a.b, fbd, b.a); + a.a = Qed(a.b, b); + c2.Ug("Compaction by shrinking a tree", a.a.c.length); + if (b.i.c.length > 1) { + for (e = new Anb(a.a); e.a < e.c.c.length; ) { + d = RD(ynb(e), 47); + d.Kf(b, c2.eh(1)); + } + } + c2.Vg(); + } + function Svd(a, b, c2) { + var d, e, f2; + f2 = Eee((lke(), jke), a.Dh(), b); + if (f2) { + nke(); + if (!RD(f2, 69).xk()) { + f2 = zfe(Qee(jke, f2)); + if (!f2) { + throw Adb(new agb(KHe + b.xe() + LHe)); + } + } + e = (d = a.Ih(f2), RD(d >= 0 ? a.Lh(d, true, true) : Qvd(a, f2, true), 160)); + RD(e, 220).Xl(b, c2); + } else { + throw Adb(new agb(KHe + b.xe() + LHe)); + } + } + function k2d(a, b) { + var c2, d, e, f2, g; + if (!b) { + return null; + } else { + f2 = ZD(a.Cb, 90) || ZD(a.Cb, 102); + g = !f2 && ZD(a.Cb, 331); + for (d = new dMd((!b.a && (b.a = new iae(b, o7, b)), b.a)); d.e != d.i.gc(); ) { + c2 = RD(bMd(d), 89); + e = i2d(c2); + if (f2 ? ZD(e, 90) : g ? ZD(e, 156) : !!e) { + return e; + } + } + return f2 ? (JTd(), zTd) : (JTd(), wTd); + } + } + function W8b(a, b) { + var c2, d, e, f2; + b.Ug("Resize child graph to fit parent.", 1); + for (d = new Anb(a.b); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 30); + Tmb(a.a, c2.a); + c2.a.c.length = 0; + } + for (f2 = new Anb(a.a); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 10); + g3b(e, null); + } + a.b.c.length = 0; + X8b(a); + !!a.e && V8b(a.e, a); + b.Vg(); + } + function Fec(a, b) { + var c2, d, e, f2, g; + b.Ug("Edge joining", 1); + c2 = Heb(TD(mQb(a, (yCc(), mCc)))); + for (e = new Anb(a.b); e.a < e.c.c.length; ) { + d = RD(ynb(e), 30); + g = new Jkb(d.a, 0); + while (g.b < g.d.gc()) { + f2 = (sFb(g.b < g.d.gc()), RD(g.d.Xb(g.c = g.b++), 10)); + if (f2.k == (r3b(), o3b)) { + Hec(f2, c2); + Ckb(g); + } + } + } + b.Vg(); + } + function pTc(a, b) { + var c2, d, e, f2, g; + c2 = new bnb(); + e = EDb(new SDb(null, new Swb(a, 16)), new ITc()); + f2 = EDb(new SDb(null, new Swb(a, 16)), new KTc()); + g = VCb(UCb(HDb(Ly(cD(WC(RM, 1), rve, 848, 0, [e, f2])), new MTc()))); + for (d = 1; d < g.length; d++) { + g[d] - g[d - 1] >= 2 * b && Rmb(c2, new BTc(g[d - 1] + b, g[d] - b)); + } + return c2; + } + function dEd(a, b, c2) { + var d, e, f2, g, h, j, k, l; + if (c2) { + f2 = c2.a.length; + d = new vue(f2); + for (h = (d.b - d.a) * d.c < 0 ? (uue(), tue) : new Rue(d); h.Ob(); ) { + g = RD(h.Pb(), 17); + e = xDd(c2, g.a); + !!e && (j = sEd(a, (k = (bvd(), l = new PCd(), l), !!b && NCd(k, b), k), e), jyd(j, zDd(e, uIe)), GEd(e, j), HEd(e, j), CEd(a, e, j)); + } + } + } + function sYd(a) { + var b, c2, d, e, f2, g; + if (!a.j) { + g = new f1d(); + b = iYd; + f2 = b.a.zc(a, b); + if (f2 == null) { + for (d = new dMd(zYd(a)); d.e != d.i.gc(); ) { + c2 = RD(bMd(d), 29); + e = sYd(c2); + YGd(g, e); + WGd(g, c2); + } + b.a.Bc(a) != null; + } + VHd(g); + a.j = new N$d((RD(QHd(xYd((lTd(), kTd).o), 11), 19), g.i), g.g); + yYd(a).b &= -33; + } + return a.j; + } + function lne(a) { + var b, c2, d, e; + if (a == null) { + return null; + } else { + d = nue(a, true); + e = mLe.length; + if (lhb(d.substr(d.length - e, e), mLe)) { + c2 = d.length; + if (c2 == 4) { + b = (BFb(0, d.length), d.charCodeAt(0)); + if (b == 43) { + return Yme; + } else if (b == 45) { + return Xme; + } + } else if (c2 == 3) { + return Yme; + } + } + return new Ufb(d); + } + } + function pD(a) { + var b, c2, d; + c2 = a.l; + if ((c2 & c2 - 1) != 0) { + return -1; + } + d = a.m; + if ((d & d - 1) != 0) { + return -1; + } + b = a.h; + if ((b & b - 1) != 0) { + return -1; + } + if (b == 0 && d == 0 && c2 == 0) { + return -1; + } + if (b == 0 && d == 0 && c2 != 0) { + return ogb(c2); + } + if (b == 0 && d != 0 && c2 == 0) { + return ogb(d) + 22; + } + if (b != 0 && d == 0 && c2 == 0) { + return ogb(b) + 44; + } + return -1; + } + function yo(a, b) { + var c2, d, e, f2, g; + e = b.a & a.f; + f2 = null; + for (d = a.b[e]; true; d = d.b) { + if (d == b) { + !f2 ? a.b[e] = b.b : f2.b = b.b; + break; + } + f2 = d; + } + g = b.f & a.f; + f2 = null; + for (c2 = a.c[g]; true; c2 = c2.d) { + if (c2 == b) { + !f2 ? a.c[g] = b.d : f2.d = b.d; + break; + } + f2 = c2; + } + !b.e ? a.a = b.c : b.e.c = b.c; + !b.c ? a.e = b.e : b.c.e = b.e; + --a.i; + ++a.g; + } + function Dt(a, b) { + var c2; + b.d ? b.d.b = b.b : a.a = b.b; + b.b ? b.b.d = b.d : a.e = b.d; + if (!b.e && !b.c) { + c2 = RD(Hvb(RD(_jb(a.b, b.a), 260)), 260); + c2.a = 0; + ++a.c; + } else { + c2 = RD(Hvb(RD(Wjb(a.b, b.a), 260)), 260); + --c2.a; + !b.e ? c2.b = RD(Hvb(b.c), 511) : b.e.c = b.c; + !b.c ? c2.c = RD(Hvb(b.e), 511) : b.c.e = b.e; + } + --a.d; + } + function XPb(a) { + var b, c2, d, e, f2, g, h, i2, j, k; + c2 = a.o; + b = a.p; + g = lve; + e = qwe; + h = lve; + f2 = qwe; + for (j = 0; j < c2; ++j) { + for (k = 0; k < b; ++k) { + if (PPb(a, j, k)) { + g = $wnd.Math.min(g, j); + e = $wnd.Math.max(e, j); + h = $wnd.Math.min(h, k); + f2 = $wnd.Math.max(f2, k); + } + } + } + i2 = e - g + 1; + d = f2 - h + 1; + return new $td(sgb(g), sgb(h), sgb(i2), sgb(d)); + } + function FZb(a, b) { + var c2, d, e, f2; + f2 = new Jkb(a, 0); + c2 = (sFb(f2.b < f2.d.gc()), RD(f2.d.Xb(f2.c = f2.b++), 148)); + while (f2.b < f2.d.gc()) { + d = (sFb(f2.b < f2.d.gc()), RD(f2.d.Xb(f2.c = f2.b++), 148)); + e = new fZb(d.c, c2.d, b); + sFb(f2.b > 0); + f2.a.Xb(f2.c = --f2.b); + Ikb(f2, e); + sFb(f2.b < f2.d.gc()); + f2.d.Xb(f2.c = f2.b++); + e.a = false; + c2 = d; + } + } + function n6b(a) { + var b, c2, d, e, f2, g; + e = RD(mQb(a, (Ywc(), Xvc)), 12); + for (g = new Anb(a.j); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 12); + for (d = new Anb(f2.g); d.a < d.c.c.length; ) { + b = RD(ynb(d), 18); + Z0b(b, e); + return f2; + } + for (c2 = new Anb(f2.e); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 18); + Y0b(b, e); + return f2; + } + } + return null; + } + function Xec(a, b, c2) { + var d, e, f2, g, h, i2; + i2 = RD($5b(a.a, b), 17).a; + c2 ? c6b(a.a, sgb(i2 + 1), b) : c6b(a.a, sgb(i2 - 1), b); + g = new Iub(); + for (e = new is(Mr((c2 ? a3b(b) : Z2b(b)).a.Kc(), new ir())); gs(e); ) { + d = RD(hs(e), 18); + c2 ? f2 = d.d.i : f2 = d.c.i; + dE($5b(a.a, f2)) === dE($5b(a.a, b)) && (h = g.a.zc(f2, g), h == null); + } + return g; + } + function yA(a, b, c2) { + var d, e; + d = Hdb(c2.q.getTime()); + if (Ddb(d, 0) < 0) { + e = Awe - Ydb(Mdb(Odb(d), Awe)); + e == Awe && (e = 0); + } else { + e = Ydb(Mdb(d, Awe)); + } + if (b == 1) { + e = $wnd.Math.min((e + 50) / 100 | 0, 9); + Thb(a, 48 + e & Bwe); + } else if (b == 2) { + e = $wnd.Math.min((e + 5) / 10 | 0, 99); + UA(a, e, 2); + } else { + UA(a, e, 3); + b > 3 && UA(a, 0, b - 3); + } + } + function eXb(a) { + var b, c2, d, e; + if (dE(mQb(a, (yCc(), IAc))) === dE((Fnd(), Cnd))) { + return !a.e && dE(mQb(a, gAc)) !== dE((xvc(), uvc)); + } + d = RD(mQb(a, hAc), 299); + e = Heb(TD(mQb(a, nAc))) || dE(mQb(a, oAc)) === dE((stc(), ptc)); + b = RD(mQb(a, fAc), 17).a; + c2 = a.a.c.length; + return !e && d != (xvc(), uvc) && (b == 0 || b > c2); + } + function Rnc(a) { + var b, c2; + c2 = 0; + for (; c2 < a.c.length; c2++) { + if (snc((tFb(c2, a.c.length), RD(a.c[c2], 113))) > 0) { + break; + } + } + if (c2 > 0 && c2 < a.c.length - 1) { + return c2; + } + b = 0; + for (; b < a.c.length; b++) { + if (snc((tFb(b, a.c.length), RD(a.c[b], 113))) > 0) { + break; + } + } + if (b > 0 && c2 < a.c.length - 1) { + return b; + } + return a.c.length / 2 | 0; + } + function Mzd(a, b) { + var c2, d; + if (b != a.Cb || a.Db >> 16 != 6 && !!b) { + if (Oje(a, b)) + throw Adb(new agb(UHe + Qzd(a))); + d = null; + !!a.Cb && (d = (c2 = a.Db >> 16, c2 >= 0 ? Czd(a, d) : a.Cb.Th(a, -1 - c2, null, d))); + !!b && (d = Ivd(b, a, 6, d)); + d = Bzd(a, b, d); + !!d && d.oj(); + } else + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 6, b, b)); + } + function pzd(a, b) { + var c2, d; + if (b != a.Cb || a.Db >> 16 != 3 && !!b) { + if (Oje(a, b)) + throw Adb(new agb(UHe + qzd(a))); + d = null; + !!a.Cb && (d = (c2 = a.Db >> 16, c2 >= 0 ? jzd(a, d) : a.Cb.Th(a, -1 - c2, null, d))); + !!b && (d = Ivd(b, a, 12, d)); + d = izd(a, b, d); + !!d && d.oj(); + } else + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 3, b, b)); + } + function NCd(a, b) { + var c2, d; + if (b != a.Cb || a.Db >> 16 != 9 && !!b) { + if (Oje(a, b)) + throw Adb(new agb(UHe + OCd(a))); + d = null; + !!a.Cb && (d = (c2 = a.Db >> 16, c2 >= 0 ? LCd(a, d) : a.Cb.Th(a, -1 - c2, null, d))); + !!b && (d = Ivd(b, a, 9, d)); + d = KCd(a, b, d); + !!d && d.oj(); + } else + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 9, b, b)); + } + function tWd(b) { + var c2, d, e, f2, g; + e = WVd(b); + g = b.j; + if (g == null && !!e) { + return b.Jk() ? null : e.ik(); + } else if (ZD(e, 156)) { + d = e.jk(); + if (d) { + f2 = d.wi(); + if (f2 != b.i) { + c2 = RD(e, 156); + if (c2.nk()) { + try { + b.g = f2.ti(c2, g); + } catch (a) { + a = zdb(a); + if (ZD(a, 82)) { + b.g = null; + } else + throw Adb(a); + } + } + b.i = f2; + } + } + return b.g; + } + return null; + } + function nRb(a) { + var b; + b = new bnb(); + Rmb(b, new TFb(new rjd(a.c, a.d), new rjd(a.c + a.b, a.d))); + Rmb(b, new TFb(new rjd(a.c, a.d), new rjd(a.c, a.d + a.a))); + Rmb(b, new TFb(new rjd(a.c + a.b, a.d + a.a), new rjd(a.c + a.b, a.d))); + Rmb(b, new TFb(new rjd(a.c + a.b, a.d + a.a), new rjd(a.c, a.d + a.a))); + return b; + } + function ic(b) { + var c2, d, e; + if (b == null) { + return vve; + } + try { + return jeb(b); + } catch (a) { + a = zdb(a); + if (ZD(a, 103)) { + c2 = a; + e = nfb(rb(b)) + "@" + (d = (gib(), jFb(b)) >>> 0, d.toString(16)); + lBb(pBb(), (SAb(), "Exception during lenientFormat for " + e), c2); + return "<" + e + " threw " + nfb(c2.Rm) + ">"; + } else + throw Adb(a); + } + } + function mTb(a, b, c2) { + var d, e, f2; + for (f2 = b.a.ec().Kc(); f2.Ob(); ) { + e = RD(f2.Pb(), 74); + d = RD(Wjb(a.b, e), 272); + !d && (vCd(JGd(e)) == vCd(LGd(e)) ? lTb(a, e, c2) : JGd(e) == vCd(LGd(e)) ? Wjb(a.c, e) == null && Wjb(a.b, LGd(e)) != null && oTb(a, e, c2, false) : Wjb(a.d, e) == null && Wjb(a.b, JGd(e)) != null && oTb(a, e, c2, true)); + } + } + function Pfc(a, b) { + var c2, d, e, f2, g, h, i2; + for (e = a.Kc(); e.Ob(); ) { + d = RD(e.Pb(), 10); + h = new R3b(); + P3b(h, d); + Q3b(h, (qpd(), Xod)); + pQb(h, (Ywc(), Hwc), (Geb(), true)); + for (g = b.Kc(); g.Ob(); ) { + f2 = RD(g.Pb(), 10); + i2 = new R3b(); + P3b(i2, f2); + Q3b(i2, ppd); + pQb(i2, Hwc, true); + c2 = new a1b(); + pQb(c2, Hwc, true); + Y0b(c2, h); + Z0b(c2, i2); + } + } + } + function Pqc(a, b, c2, d) { + var e, f2, g, h; + e = Nqc(a, b, c2); + f2 = Nqc(a, c2, b); + g = RD(Wjb(a.c, b), 118); + h = RD(Wjb(a.c, c2), 118); + if (e < f2) { + new bTc((fTc(), eTc), g, h, f2 - e); + } else if (f2 < e) { + new bTc((fTc(), eTc), h, g, e - f2); + } else if (e != 0 || !(!b.i || !c2.i) && d[b.i.c][c2.i.c]) { + new bTc((fTc(), eTc), g, h, 0); + new bTc(eTc, h, g, 0); + } + } + function rsc(a, b) { + var c2, d, e, f2, g, h, i2; + e = 0; + for (g = new Anb(b.a); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 10); + e += f2.o.b + f2.d.a + f2.d.d + a.e; + for (d = new is(Mr(Z2b(f2).a.Kc(), new ir())); gs(d); ) { + c2 = RD(hs(d), 18); + if (c2.c.i.k == (r3b(), q3b)) { + i2 = c2.c.i; + h = RD(mQb(i2, (Ywc(), Awc)), 10); + e += h.o.b + h.d.a + h.d.d; + } + } + } + return e; + } + function sad() { + sad = geb; + oad = new tad("CANDIDATE_POSITION_LAST_PLACED_RIGHT", 0); + nad = new tad("CANDIDATE_POSITION_LAST_PLACED_BELOW", 1); + qad = new tad("CANDIDATE_POSITION_WHOLE_DRAWING_RIGHT", 2); + pad2 = new tad("CANDIDATE_POSITION_WHOLE_DRAWING_BELOW", 3); + rad = new tad("WHOLE_DRAWING", 4); + } + function vEd(a, b) { + if (ZD(b, 207)) { + return IDd(a, RD(b, 27)); + } else if (ZD(b, 193)) { + return JDd(a, RD(b, 123)); + } else if (ZD(b, 366)) { + return HDd(a, RD(b, 135)); + } else if (ZD(b, 326)) { + return GDd(a, RD(b, 74)); + } else if (b) { + return null; + } else { + throw Adb(new agb(wIe + Fe(new mob(cD(WC(jJ, 1), rve, 1, 5, [b]))))); + } + } + function Glc(a) { + var b, c2, d, e, f2, g, h; + f2 = new Yub(); + for (e = new Anb(a.d.a); e.a < e.c.c.length; ) { + d = RD(ynb(e), 125); + d.b.a.c.length == 0 && (Pub(f2, d, f2.c.b, f2.c), true); + } + if (f2.b > 1) { + b = eJb((c2 = new gJb(), ++a.b, c2), a.d); + for (h = Sub(f2, 0); h.b != h.d.c; ) { + g = RD(evb(h), 125); + rIb(uIb(tIb(vIb(sIb(new wIb(), 1), 0), b), g)); + } + } + } + function isc(a, b, c2) { + var d, e, f2, g, h; + c2.Ug("Breaking Point Removing", 1); + a.a = RD(mQb(b, (yCc(), yAc)), 223); + for (f2 = new Anb(b.b); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 30); + for (h = new Anb(bv(e.a)); h.a < h.c.c.length; ) { + g = RD(ynb(h), 10); + if (Krc(g)) { + d = RD(mQb(g, (Ywc(), Wvc)), 313); + !d.d && jsc(a, d); + } + } + } + c2.Vg(); + } + function yCd(a, b) { + var c2, d; + if (b != a.Cb || a.Db >> 16 != 11 && !!b) { + if (Oje(a, b)) + throw Adb(new agb(UHe + zCd(a))); + d = null; + !!a.Cb && (d = (c2 = a.Db >> 16, c2 >= 0 ? sCd(a, d) : a.Cb.Th(a, -1 - c2, null, d))); + !!b && (d = Ivd(b, a, 10, d)); + d = rCd(a, b, d); + !!d && d.oj(); + } else + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 11, b, b)); + } + function C0b(a) { + var b, c2, d, e; + for (d = new vkb(new mkb(a.b).a); d.b; ) { + c2 = tkb(d); + e = RD(c2.ld(), 12); + b = RD(c2.md(), 10); + pQb(b, (Ywc(), Awc), e); + pQb(e, Iwc, b); + pQb(e, nwc, (Geb(), true)); + Q3b(e, RD(mQb(b, hwc), 64)); + mQb(b, hwc); + pQb(e.i, (yCc(), BBc), (Bod(), yod)); + RD(mQb(Y2b(e.i), kwc), 21).Fc((ovc(), kvc)); + } + } + function X7b(a, b, c2) { + var d, e, f2, g, h, i2; + f2 = 0; + g = 0; + if (a.c) { + for (i2 = new Anb(a.d.i.j); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 12); + f2 += h.e.c.length; + } + } else { + f2 = 1; + } + if (a.d) { + for (i2 = new Anb(a.c.i.j); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 12); + g += h.g.c.length; + } + } else { + g = 1; + } + e = eE(Lgb(g - f2)); + d = (c2 + b) / 2 + (c2 - b) * (0.4 * e); + return d; + } + function Dnc(a) { + Bnc(); + var b, c2; + if (a.Hc((qpd(), opd))) { + throw Adb(new agb("Port sides must not contain UNDEFINED")); + } + switch (a.gc()) { + case 1: + return xnc; + case 2: + b = a.Hc(Xod) && a.Hc(ppd); + c2 = a.Hc(Yod) && a.Hc(npd); + return b || c2 ? Anc : znc; + case 3: + return ync; + case 4: + return wnc; + default: + return null; + } + } + function Did(a, b, c2) { + tid(); + if (xid(a, b) && xid(a, c2)) { + return false; + } + return Fid(new rjd(a.c, a.d), new rjd(a.c + a.b, a.d), b, c2) || Fid(new rjd(a.c + a.b, a.d), new rjd(a.c + a.b, a.d + a.a), b, c2) || Fid(new rjd(a.c + a.b, a.d + a.a), new rjd(a.c, a.d + a.a), b, c2) || Fid(new rjd(a.c, a.d + a.a), new rjd(a.c, a.d), b, c2); + } + function Xee(a, b) { + var c2, d, e, f2; + if (!a.dc()) { + for (c2 = 0, d = a.gc(); c2 < d; ++c2) { + f2 = WD(a.Xb(c2)); + if (f2 == null ? b == null : lhb(f2.substr(0, 3), "!##") ? b != null && (e = b.length, !lhb(f2.substr(f2.length - e, e), b) || f2.length != b.length + 3) && !lhb(dLe, b) : lhb(f2, eLe) && !lhb(dLe, b) || lhb(f2, b)) { + return true; + } + } + } + return false; + } + function $6b(a, b, c2, d) { + var e, f2, g, h, i2, j; + g = a.j.c.length; + i2 = $C(NN, Mye, 314, g, 0, 1); + for (h = 0; h < g; h++) { + f2 = RD(Vmb(a.j, h), 12); + f2.p = h; + i2[h] = U6b(c7b(f2), c2, d); + } + W6b(a, i2, c2, b, d); + j = new Tsb(); + for (e = 0; e < i2.length; e++) { + !!i2[e] && Zjb(j, RD(Vmb(a.j, e), 12), i2[e]); + } + if (j.f.c + j.i.c != 0) { + pQb(a, (Ywc(), cwc), j); + a7b(a, i2); + } + } + function Yfc(a, b) { + var c2, d, e, f2, g, h; + b.Ug("Partition postprocessing", 1); + for (d = new Anb(a.b); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 30); + for (f2 = new Anb(c2.a); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 10); + h = new Anb(e.j); + while (h.a < h.c.c.length) { + g = RD(ynb(h), 12); + Heb(TD(mQb(g, (Ywc(), Hwc)))) && znb(h); + } + } + } + b.Vg(); + } + function pkc(a, b, c2) { + var d, e, f2; + for (e = new Anb(a.a.b); e.a < e.c.c.length; ) { + d = RD(ynb(e), 60); + f2 = Zjc(d); + if (f2) { + if (f2.k == (r3b(), m3b)) { + switch (RD(mQb(f2, (Ywc(), hwc)), 64).g) { + case 4: + f2.n.a = b.a; + break; + case 2: + f2.n.a = c2.a - (f2.o.a + f2.d.c); + break; + case 1: + f2.n.b = b.b; + break; + case 3: + f2.n.b = c2.b - (f2.o.b + f2.d.a); + } + } + } + } + } + function eZc(a, b, c2) { + var d, e, f2; + c2.Ug("Processor determine the height for each level", 1); + a.a = b.b.b == 0 ? 1 : b.b.b; + e = null; + d = Sub(b.b, 0); + while (!e && d.b != d.d.c) { + f2 = RD(evb(d), 40); + Heb(TD(mQb(f2, (q$c(), n$c)))) && (e = f2); + } + !!e && fZc(a, dv(cD(WC(Z$, 1), NEe, 40, 0, [e])), c2, RD(mQb(b, (h_c(), H$c)), 88)); + c2.Vg(); + } + function N8c(a) { + var b, c2, d, e, f2, g; + d = (bvd(), f2 = new ACd(), f2); + zxd(d, a); + for (c2 = new dMd((!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a)); c2.e != c2.i.gc(); ) { + b = RD(bMd(c2), 27); + g = (e = new ACd(), e); + yCd(g, d); + zyd(g, b.g, b.f); + jyd(g, b.k); + Byd(g, b.i, b.j); + WGd((!d.a && (d.a = new C5d(J4, d, 10, 11)), d.a), g); + zxd(g, b); + } + return d; + } + function ord(a, b, c2) { + var d, e, f2, g, h; + e = RD(Gxd(b, (hkd(), fkd)), 17); + !e && (e = sgb(0)); + f2 = RD(Gxd(c2, fkd), 17); + !f2 && (f2 = sgb(0)); + if (e.a > f2.a) { + return -1; + } else if (e.a < f2.a) { + return 1; + } else { + if (a.a) { + d = Qfb(b.j, c2.j); + if (d != 0) { + return d; + } + d = Qfb(b.i, c2.i); + if (d != 0) { + return d; + } + } + g = b.g * b.f; + h = c2.g * c2.f; + return Qfb(g, h); + } + } + function _Nd(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l; + ++a.e; + i2 = a.d == null ? 0 : a.d.length; + if (b > i2) { + k = a.d; + a.d = $C(D6, KJe, 66, 2 * i2 + 4, 0, 1); + for (f2 = 0; f2 < i2; ++f2) { + j = k[f2]; + if (j) { + d = j.g; + l = j.i; + for (h = 0; h < l; ++h) { + e = RD(d[h], 136); + g = bOd(a, e.Bi()); + c2 = a.d[g]; + !c2 && (c2 = a.d[g] = a.dk()); + c2.Fc(e); + } + } + } + return true; + } else { + return false; + } + } + function Ofe(a, b, c2) { + var d, e, f2, g, h, i2; + e = c2; + f2 = e.Lk(); + if (qke(a.e, f2)) { + if (f2.Si()) { + d = RD(a.g, 124); + for (g = 0; g < a.i; ++g) { + h = d[g]; + if (pb(h, e) && g != b) { + throw Adb(new agb(LIe)); + } + } + } + } else { + i2 = pke(a.e.Dh(), f2); + d = RD(a.g, 124); + for (g = 0; g < a.i; ++g) { + h = d[g]; + if (i2.am(h.Lk())) { + throw Adb(new agb(gLe)); + } + } + } + VGd(a, b, c2); + } + function R_b(a, b) { + var c2, d, e, f2, g, h; + c2 = RD(mQb(b, (Ywc(), ewc)), 21); + g = RD(Qc((z$b(), y$b), c2), 21); + h = RD(Qc(O_b, c2), 21); + for (f2 = g.Kc(); f2.Ob(); ) { + d = RD(f2.Pb(), 21); + if (!RD(Qc(a.b, d), 15).dc()) { + return false; + } + } + for (e = h.Kc(); e.Ob(); ) { + d = RD(e.Pb(), 21); + if (!RD(Qc(a.b, d), 15).dc()) { + return false; + } + } + return true; + } + function dad(a, b) { + var c2, d, e, f2, g, h, i2, j, k; + if (a.a.c.length == 1) { + return P9c(RD(Vmb(a.a, 0), 172), b); + } + g = cad(a); + i2 = 0; + j = a.d; + f2 = g; + k = a.d; + h = (j - f2) / 2 + f2; + while (f2 + 1 < j) { + i2 = 0; + for (d = new Anb(a.a); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 172); + i2 += (e = S9c(c2, h, false), e.a); + } + if (i2 < b) { + k = h; + j = h; + } else { + f2 = h; + } + h = (j - f2) / 2 + f2; + } + return k; + } + function zxd(a, b) { + var c2, d, e, f2, g; + if (!b) { + return a; + } + if (ZD(b, 342)) { + e = RD(b, 342); + f2 = (!a.o && (a.o = new DVd((pvd(), mvd), X4, a, 0)), a.o); + for (d = e.gh().c.Kc(); d.e != d.i.gc(); ) { + c2 = RD(d.Yj(), 44); + g = c2.md(); + fOd(f2, RD(c2.ld(), 149), g); + } + } else { + !a.o && (a.o = new DVd((pvd(), mvd), X4, a, 0)); + gOd(a.o, b.nf()); + } + return a; + } + function vD(a) { + var b, c2, d, e, f2; + if (isNaN(a)) { + return MD(), LD; + } + if (a < -9223372036854776e3) { + return MD(), JD; + } + if (a >= 9223372036854776e3) { + return MD(), ID; + } + e = false; + if (a < 0) { + e = true; + a = -a; + } + d = 0; + if (a >= hxe) { + d = eE(a / hxe); + a -= d * hxe; + } + c2 = 0; + if (a >= gxe) { + c2 = eE(a / gxe); + a -= c2 * gxe; + } + b = eE(a); + f2 = hD(b, c2, d); + e && nD(f2); + return f2; + } + function KCb(a) { + var b, c2, d, e, f2; + f2 = new bnb(); + Umb(a.b, new SEb(f2)); + a.b.c.length = 0; + if (f2.c.length != 0) { + b = (tFb(0, f2.c.length), RD(f2.c[0], 82)); + for (c2 = 1, d = f2.c.length; c2 < d; ++c2) { + e = (tFb(c2, f2.c.length), RD(f2.c[c2], 82)); + e != b && fz(b, e); + } + if (ZD(b, 63)) { + throw Adb(RD(b, 63)); + } + if (ZD(b, 296)) { + throw Adb(RD(b, 296)); + } + } + } + function iNb(a, b) { + var c2, d, e, f2; + c2 = !b || !a.u.Hc((Pod(), Lod)); + f2 = 0; + for (e = new Anb(a.e.Xf()); e.a < e.c.c.length; ) { + d = RD(ynb(e), 852); + if (d.ag() == (qpd(), opd)) { + throw Adb(new agb("Label and node size calculator can only be used with ports that have port sides assigned.")); + } + d.Qf(f2++); + hNb(a, d, c2); + } + } + function IGb(a) { + var b, c2, d, e, f2; + for (c2 = new Anb(a.a.a); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 316); + b.j = null; + for (f2 = b.a.a.ec().Kc(); f2.Ob(); ) { + d = RD(f2.Pb(), 60); + hjd(d.b); + (!b.j || d.d.c < b.j.d.c) && (b.j = d); + } + for (e = b.a.a.ec().Kc(); e.Ob(); ) { + d = RD(e.Pb(), 60); + d.b.a = d.d.c - b.j.d.c; + d.b.b = d.d.d - b.j.d.d; + } + } + return a; + } + function uYb(a) { + var b, c2, d, e, f2; + for (c2 = new Anb(a.a.a); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 194); + b.f = null; + for (f2 = b.a.a.ec().Kc(); f2.Ob(); ) { + d = RD(f2.Pb(), 86); + hjd(d.e); + (!b.f || d.g.c < b.f.g.c) && (b.f = d); + } + for (e = b.a.a.ec().Kc(); e.Ob(); ) { + d = RD(e.Pb(), 86); + d.e.a = d.g.c - b.f.g.c; + d.e.b = d.g.d - b.f.g.d; + } + } + return a; + } + function vPb(a) { + var b, c2, d; + c2 = RD(a.a, 17).a; + d = RD(a.b, 17).a; + b = $wnd.Math.max($wnd.Math.abs(c2), $wnd.Math.abs(d)); + if (c2 < b && d == -b) { + return new Ptd(sgb(c2 + 1), sgb(d)); + } + if (c2 == b && d < b) { + return new Ptd(sgb(c2), sgb(d + 1)); + } + if (c2 >= -b && d == b) { + return new Ptd(sgb(c2 - 1), sgb(d)); + } + return new Ptd(sgb(c2), sgb(d - 1)); + } + function lcc() { + hcc(); + return cD(WC(YS, 1), jwe, 81, 0, [nbc, kbc, obc, Ebc, Xbc, Ibc, bcc, Nbc, Vbc, zbc, Rbc, Mbc, Wbc, vbc, dcc, ebc, Qbc, Zbc, Fbc, Ybc, fcc, Tbc, fbc, Ubc, gcc, _bc, ecc, Gbc, sbc, Hbc, Dbc, ccc, ibc, qbc, Kbc, hbc, Lbc, Bbc, wbc, Obc, ybc, lbc, jbc, Cbc, xbc, Pbc, acc, gbc, Sbc, Abc, Jbc, tbc, rbc, $bc, pbc, ubc, mbc]); + } + function Cmc(a, b, c2) { + a.d = 0; + a.b = 0; + b.k == (r3b(), q3b) && c2.k == q3b && RD(mQb(b, (Ywc(), Awc)), 10) == RD(mQb(c2, Awc), 10) && (Gmc(b).j == (qpd(), Yod) ? Dmc(a, b, c2) : Dmc(a, c2, b)); + b.k == q3b && c2.k == o3b ? Gmc(b).j == (qpd(), Yod) ? a.d = 1 : a.b = 1 : c2.k == q3b && b.k == o3b && (Gmc(c2).j == (qpd(), Yod) ? a.b = 1 : a.d = 1); + Imc(a, b, c2); + } + function EFd(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l; + l = HFd(a); + b = a.a; + i2 = b != null; + i2 && sDd(l, "category", a.a); + e = cve(new Xkb(a.d)); + g = !e; + if (g) { + j = new MB(); + sC(l, "knownOptions", j); + c2 = new MFd(j); + xgb(new Xkb(a.d), c2); + } + f2 = cve(a.g); + h = !f2; + if (h) { + k = new MB(); + sC(l, "supportedFeatures", k); + d = new OFd(k); + xgb(a.g, d); + } + return l; + } + function Ly(a) { + var b, c2, d, e, f2, g, h, i2, j; + d = false; + b = 336; + c2 = 0; + f2 = new hq(a.length); + for (h = a, i2 = 0, j = h.length; i2 < j; ++i2) { + g = h[i2]; + d = d | (MCb(g), false); + e = (LCb(g), g.a); + Rmb(f2.a, Qb(e)); + b &= e.yd(); + c2 = az(c2, e.zd()); + } + return RD(RD(JCb(new SDb(null, ek(new Swb((tm(), zm(f2.a)), 16), new My(), b, c2)), new Oy(a)), 687), 848); + } + function WZb(a, b) { + var c2; + if (!!a.d && (b.c != a.e.c || sZb(a.e.b, b.b))) { + Rmb(a.f, a.d); + a.a = a.d.c + a.d.b; + a.d = null; + a.e = null; + } + pZb(b.b) ? a.c = b : a.b = b; + if (b.b == (nZb(), jZb) && !b.a || b.b == kZb && b.a || b.b == lZb && b.a || b.b == mZb && !b.a) { + if (!!a.c && !!a.b) { + c2 = new Uid2(a.a, a.c.d, b.c - a.a, a.b.d - a.c.d); + a.d = c2; + a.e = b; + } + } + } + function Wed(a) { + var b; + Oed.call(this); + this.i = new ifd(); + this.g = a; + this.f = RD(a.e && a.e(), 9).length; + if (this.f == 0) { + throw Adb(new agb("There must be at least one phase in the phase enumeration.")); + } + this.c = (b = RD(mfb(this.g), 9), new Fsb(b, RD(WEb(b, b.length), 9), 0)); + this.a = new ufd(); + this.b = new Tsb(); + } + function eCd(a, b) { + var c2, d; + if (b != a.Cb || a.Db >> 16 != 7 && !!b) { + if (Oje(a, b)) + throw Adb(new agb(UHe + gCd(a))); + d = null; + !!a.Cb && (d = (c2 = a.Db >> 16, c2 >= 0 ? cCd(a, d) : a.Cb.Th(a, -1 - c2, null, d))); + !!b && (d = RD(b, 54).Rh(a, 1, H4, d)); + d = bCd(a, b, d); + !!d && d.oj(); + } else + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 7, b, b)); + } + function lVd(a, b) { + var c2, d; + if (b != a.Cb || a.Db >> 16 != 3 && !!b) { + if (Oje(a, b)) + throw Adb(new agb(UHe + oVd(a))); + d = null; + !!a.Cb && (d = (c2 = a.Db >> 16, c2 >= 0 ? iVd(a, d) : a.Cb.Th(a, -1 - c2, null, d))); + !!b && (d = RD(b, 54).Rh(a, 0, p7, d)); + d = hVd(a, b, d); + !!d && d.oj(); + } else + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 3, b, b)); + } + function Mjb(a, b) { + Ljb(); + var c2, d, e, f2, g, h, i2, j, k; + if (b.d > a.d) { + h = a; + a = b; + b = h; + } + if (b.d < 63) { + return Qjb(a, b); + } + g = (a.d & -2) << 4; + j = $ib(a, g); + k = $ib(b, g); + d = Gjb(a, Zib(j, g)); + e = Gjb(b, Zib(k, g)); + i2 = Mjb(j, k); + c2 = Mjb(d, e); + f2 = Mjb(Gjb(j, d), Gjb(e, k)); + f2 = Bjb(Bjb(f2, i2), c2); + f2 = Zib(f2, g); + i2 = Zib(i2, g << 1); + return Bjb(Bjb(i2, f2), c2); + } + function _Cc() { + _Cc = geb; + ZCc = new bDc(lEe, 0); + WCc = new bDc("LONGEST_PATH", 1); + XCc = new bDc("LONGEST_PATH_SOURCE", 2); + TCc = new bDc("COFFMAN_GRAHAM", 3); + VCc = new bDc(BBe, 4); + $Cc = new bDc("STRETCH_WIDTH", 5); + YCc = new bDc("MIN_WIDTH", 6); + SCc = new bDc("BF_MODEL_ORDER", 7); + UCc = new bDc("DF_MODEL_ORDER", 8); + } + function AKc(a, b, c2) { + var d, e, f2, g, h; + g = aMc(a, c2); + h = $C(jR, WAe, 10, b.length, 0, 1); + d = 0; + for (f2 = g.Kc(); f2.Ob(); ) { + e = RD(f2.Pb(), 12); + Heb(TD(mQb(e, (Ywc(), nwc)))) && (h[d++] = RD(mQb(e, Iwc), 10)); + } + if (d < b.length) { + throw Adb(new dgb("Expected " + b.length + " hierarchical ports, but found only " + d + ".")); + } + return h; + } + function sBd(a, b) { + var c2, d, e, f2, g, h; + if (!a.tb) { + f2 = (!a.rb && (a.rb = new J5d(a, i7, a)), a.rb); + h = new Usb(f2.i); + for (e = new dMd(f2); e.e != e.i.gc(); ) { + d = RD(bMd(e), 142); + g = d.xe(); + c2 = RD(g == null ? rtb(h.f, null, d) : Ltb(h.i, g, d), 142); + !!c2 && (g == null ? rtb(h.f, null, c2) : Ltb(h.i, g, c2)); + } + a.tb = h; + } + return RD(Xjb(a.tb, b), 142); + } + function wYd(a, b) { + var c2, d, e, f2, g; + (a.i == null && rYd(a), a.i).length; + if (!a.p) { + g = new Usb((3 * a.g.i / 2 | 0) + 1); + for (e = new yMd(a.g); e.e != e.i.gc(); ) { + d = RD(xMd(e), 179); + f2 = d.xe(); + c2 = RD(f2 == null ? rtb(g.f, null, d) : Ltb(g.i, f2, d), 179); + !!c2 && (f2 == null ? rtb(g.f, null, c2) : Ltb(g.i, f2, c2)); + } + a.p = g; + } + return RD(Xjb(a.p, b), 179); + } + function fFb(a, b, c2, d, e) { + var f2, g, h, i2, j; + dFb(d + lz(c2, c2.ie()), e); + eFb(b, hFb(c2)); + f2 = c2.f; + !!f2 && fFb(a, b, f2, "Caused by: ", false); + for (h = (c2.k == null && (c2.k = $C(rJ, Nve, 82, 0, 0, 1)), c2.k), i2 = 0, j = h.length; i2 < j; ++i2) { + g = h[i2]; + fFb(a, b, g, "Suppressed: ", false); + } + console.groupEnd != null && console.groupEnd.call(console); + } + function DKc(a, b, c2, d) { + var e, f2, g, h, i2; + i2 = b.e; + h = i2.length; + g = b.q.ug(i2, c2 ? 0 : h - 1, c2); + e = i2[c2 ? 0 : h - 1]; + g = g | CKc(a, e, c2, d); + for (f2 = c2 ? 1 : h - 2; c2 ? f2 < h : f2 >= 0; f2 += c2 ? 1 : -1) { + g = g | b.c.lg(i2, f2, c2, d && !Heb(TD(mQb(b.j, (Ywc(), jwc)))) && !Heb(TD(mQb(b.j, (Ywc(), Owc))))); + g = g | b.q.ug(i2, f2, c2); + g = g | CKc(a, i2[f2], c2, d); + } + Ysb(a.c, b); + return g; + } + function F6b(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m; + for (k = u2b(a.j), l = 0, m = k.length; l < m; ++l) { + j = k[l]; + if (c2 == (BEc(), yEc) || c2 == AEc) { + i2 = s2b(j.g); + for (e = i2, f2 = 0, g = e.length; f2 < g; ++f2) { + d = e[f2]; + B6b(b, d) && X0b(d, true); + } + } + if (c2 == zEc || c2 == AEc) { + h = s2b(j.e); + for (e = h, f2 = 0, g = e.length; f2 < g; ++f2) { + d = e[f2]; + A6b(b, d) && X0b(d, true); + } + } + } + } + function uqc(a) { + var b, c2; + b = null; + c2 = null; + switch (pqc(a).g) { + case 1: + b = (qpd(), Xod); + c2 = ppd; + break; + case 2: + b = (qpd(), npd); + c2 = Yod; + break; + case 3: + b = (qpd(), ppd); + c2 = Xod; + break; + case 4: + b = (qpd(), Yod); + c2 = npd; + } + Smc(a, RD(Lvb(KDb(RD(Qc(a.k, b), 15).Oc(), lqc)), 113)); + Tmc(a, RD(Lvb(JDb(RD(Qc(a.k, c2), 15).Oc(), lqc)), 113)); + } + function r9b(a) { + var b, c2, d, e, f2, g; + e = RD(Vmb(a.j, 0), 12); + if (e.e.c.length + e.g.c.length == 0) { + a.n.a = 0; + } else { + g = 0; + for (d = Fl(Al(cD(WC(cJ, 1), rve, 20, 0, [new T3b(e), new _3b(e)]))); gs(d); ) { + c2 = RD(hs(d), 12); + g += c2.i.n.a + c2.n.a + c2.a.a; + } + b = RD(mQb(a, (yCc(), zBc)), 8); + f2 = !b ? 0 : b.a; + a.n.a = g / (e.e.c.length + e.g.c.length) - f2; + } + } + function Qdd(a, b) { + var c2, d, e; + for (d = new Anb(b.a); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 225); + RQb(RD(c2.b, 68), ojd(ajd(RD(b.b, 68).c), RD(b.b, 68).a)); + e = oRb(RD(b.b, 68).b, RD(c2.b, 68).b); + e > 1 && (a.a = true); + QQb(RD(c2.b, 68), $id(ajd(RD(b.b, 68).c), ijd(ojd(ajd(RD(c2.b, 68).a), RD(b.b, 68).a), e))); + Odd(a, b); + Qdd(a, c2); + } + } + function tYb(a) { + var b, c2, d, e, f2, g, h; + for (f2 = new Anb(a.a.a); f2.a < f2.c.c.length; ) { + d = RD(ynb(f2), 194); + d.e = 0; + d.d.a.$b(); + } + for (e = new Anb(a.a.a); e.a < e.c.c.length; ) { + d = RD(ynb(e), 194); + for (c2 = d.a.a.ec().Kc(); c2.Ob(); ) { + b = RD(c2.Pb(), 86); + for (h = b.f.Kc(); h.Ob(); ) { + g = RD(h.Pb(), 86); + if (g.d != d) { + Ysb(d.d, g); + ++g.d.e; + } + } + } + } + } + function Hfc(a) { + var b, c2, d, e, f2, g, h, i2; + i2 = a.j.c.length; + c2 = 0; + b = i2; + e = 2 * i2; + for (h = new Anb(a.j); h.a < h.c.c.length; ) { + g = RD(ynb(h), 12); + switch (g.j.g) { + case 2: + case 4: + g.p = -1; + break; + case 1: + case 3: + d = g.e.c.length; + f2 = g.g.c.length; + d > 0 && f2 > 0 ? g.p = b++ : d > 0 ? g.p = c2++ : f2 > 0 ? g.p = e++ : g.p = c2++; + } + } + yob(); + _mb(a.j, new Lfc()); + } + function zic(a) { + var b, c2; + c2 = null; + b = RD(Vmb(a.g, 0), 18); + do { + c2 = b.d.i; + if (nQb(c2, (Ywc(), wwc))) { + return RD(mQb(c2, wwc), 12).i; + } + if (c2.k != (r3b(), p3b) && gs(new is(Mr(a3b(c2).a.Kc(), new ir())))) { + b = RD(hs(new is(Mr(a3b(c2).a.Kc(), new ir()))), 18); + } else if (c2.k != p3b) { + return null; + } + } while (!!c2 && c2.k != (r3b(), p3b)); + return c2; + } + function sqc(a, b) { + var c2, d, e, f2, g, h, i2, j, k; + h = b.j; + g = b.g; + i2 = RD(Vmb(h, h.c.length - 1), 113); + k = (tFb(0, h.c.length), RD(h.c[0], 113)); + j = oqc(a, g, i2, k); + for (f2 = 1; f2 < h.c.length; f2++) { + c2 = (tFb(f2 - 1, h.c.length), RD(h.c[f2 - 1], 113)); + e = (tFb(f2, h.c.length), RD(h.c[f2], 113)); + d = oqc(a, g, c2, e); + if (d > j) { + i2 = c2; + k = e; + j = d; + } + } + b.a = k; + b.c = i2; + } + function fMc(a, b, c2) { + var d, e, f2, g, h, i2, j; + j = new yAb(new TMc(a)); + for (g = cD(WC(xR, 1), XAe, 12, 0, [b, c2]), h = 0, i2 = g.length; h < i2; ++h) { + f2 = g[h]; + j.a.zc(f2, (Geb(), Eeb)) == null; + for (e = new l4b(f2.b); xnb(e.a) || xnb(e.b); ) { + d = RD(xnb(e.a) ? ynb(e.a) : ynb(e.b), 18); + d.c == d.d || rAb(j, f2 == d.c ? d.d : d.c); + } + } + return Qb(j), new dnb(j); + } + function rIb(a) { + if (!a.a.d || !a.a.e) { + throw Adb(new dgb((lfb(zN), zN.k + " must have a source and target " + (lfb(DN), DN.k) + " specified."))); + } + if (a.a.d == a.a.e) { + throw Adb(new dgb("Network simplex does not support self-loops: " + a.a + " " + a.a.d + " " + a.a.e)); + } + EIb(a.a.d.g, a.a); + EIb(a.a.e.b, a.a); + return a.a; + } + function x6b(a, b) { + var c2, d, e, f2, g, h, i2; + b.Ug("Constraints Postprocessor", 1); + g = 0; + for (f2 = new Anb(a.b); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 30); + i2 = 0; + h = false; + for (d = new Anb(e.a); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 10); + if (c2.k == (r3b(), p3b)) { + h = true; + pQb(c2, (yCc(), VAc), sgb(g)); + pQb(c2, mAc, sgb(i2)); + ++i2; + } + } + h && ++g; + } + b.Vg(); + } + function OTc(a, b, c2) { + var d, e, f2, g, h, i2; + d = 0; + if (b.b != 0 && c2.b != 0) { + f2 = Sub(b, 0); + g = Sub(c2, 0); + h = Kfb(UD(evb(f2))); + i2 = Kfb(UD(evb(g))); + e = true; + do { + if (h > i2 - a.b && h < i2 + a.b) { + return -1; + } else + h > i2 - a.a && h < i2 + a.a && ++d; + h <= i2 && f2.b != f2.d.c ? h = Kfb(UD(evb(f2))) : i2 <= h && g.b != g.d.c ? i2 = Kfb(UD(evb(g))) : e = false; + } while (e); + } + return d; + } + function G2c(a, b) { + var c2, d; + Sed(a.a); + Ved(a.a, (x2c(), v2c), v2c); + Ved(a.a, w2c, w2c); + d = new ufd(); + pfd(d, w2c, (g3c(), e3c)); + dE(Gxd(b, ($4c(), I4c))) !== dE((g4c(), d4c)) && pfd(d, w2c, b3c); + Heb(TD(Gxd(b, T4c))) && pfd(d, w2c, f3c); + pfd(d, w2c, c3c); + Heb(TD(Gxd(b, V4c))) && nfd(d, w2c, d3c); + Ped(a.a, d); + c2 = Qed(a.a, b); + return c2; + } + function W6b(a, b, c2, d, e) { + var f2, g, h, i2; + i2 = (f2 = RD(mfb(E3), 9), new Fsb(f2, RD(WEb(f2, f2.length), 9), 0)); + for (h = new Anb(a.j); h.a < h.c.c.length; ) { + g = RD(ynb(h), 12); + if (b[g.p]) { + X6b(g, b[g.p], d); + zsb(i2, g.j); + } + } + if (e) { + _6b(a, b, (qpd(), Xod), 2 * c2, d); + _6b(a, b, ppd, 2 * c2, d); + } else { + _6b(a, b, (qpd(), Yod), 2 * c2, d); + _6b(a, b, npd, 2 * c2, d); + } + } + function eec(a) { + var b, c2; + for (c2 = new is(Mr(a3b(a).a.Kc(), new ir())); gs(c2); ) { + b = RD(hs(c2), 18); + if (b.d.i.k != (r3b(), n3b)) { + throw Adb(new Jed(nBe + X2b(a) + "' has its layer constraint set to LAST, but has at least one outgoing edge that does not go to a LAST_SEPARATE node. That must not happen.")); + } + } + } + function mHc(a, b, c2) { + var d, e, f2, g, h; + c2.Ug("Longest path layering", 1); + a.a = b; + h = a.a.a; + a.b = $C(kE, Pwe, 28, h.c.length, 15, 1); + d = 0; + for (g = new Anb(h); g.a < g.c.c.length; ) { + e = RD(ynb(g), 10); + e.p = d; + a.b[d] = -1; + ++d; + } + for (f2 = new Anb(h); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 10); + oHc(a, e); + } + h.c.length = 0; + a.a = null; + a.b = null; + c2.Vg(); + } + function JUc(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m; + i2 = 0; + for (k = new Anb(a.a); k.a < k.c.c.length; ) { + j = RD(ynb(k), 10); + h = 0; + for (f2 = new is(Mr(Z2b(j).a.Kc(), new ir())); gs(f2); ) { + e = RD(hs(f2), 18); + l = K3b(e.c).b; + m = K3b(e.d).b; + h = $wnd.Math.max(h, $wnd.Math.abs(m - l)); + } + i2 = $wnd.Math.max(i2, h); + } + g = d * $wnd.Math.min(1, b / c2) * i2; + return g; + } + function J_c(a, b) { + var c2, d, e, f2, g; + g = RD(mQb(b, (h_c(), Y$c)), 433); + for (f2 = Sub(b.b, 0); f2.b != f2.d.c; ) { + e = RD(evb(f2), 40); + if (a.b[e.g] == 0) { + switch (g.g) { + case 0: + K_c(a, e); + break; + case 1: + I_c(a, e); + } + a.b[e.g] = 2; + } + } + for (d = Sub(a.a, 0); d.b != d.d.c; ) { + c2 = RD(evb(d), 65); + ze(c2.b.d, c2, true); + ze(c2.c.b, c2, true); + } + pQb(b, (q$c(), k$c), a.a); + } + function pse(a) { + var b; + b = new Rhb(); + (a & 256) != 0 && (b.a += "F", b); + (a & 128) != 0 && (b.a += "H", b); + (a & 512) != 0 && (b.a += "X", b); + (a & 2) != 0 && (b.a += "i", b); + (a & 8) != 0 && (b.a += "m", b); + (a & 4) != 0 && (b.a += "s", b); + (a & 32) != 0 && (b.a += "u", b); + (a & 64) != 0 && (b.a += "w", b); + (a & 16) != 0 && (b.a += "x", b); + (a & gwe) != 0 && (b.a += ",", b); + return shb(b.a); + } + function W8c(a, b) { + var c2, d, e, f2, g, h; + b.Ug(bGe, 1); + e = RD(Gxd(a, (X7c(), N7c)), 107); + f2 = (!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a); + g = yad(f2); + h = $wnd.Math.max(g.a, Kfb(UD(Gxd(a, (X6c(), U6c)))) - (e.b + e.c)); + d = $wnd.Math.max(g.b, Kfb(UD(Gxd(a, R6c))) - (e.d + e.a)); + c2 = d - g.b; + Ixd(a, M6c, c2); + Ixd(a, O6c, h); + Ixd(a, N6c, d + c2); + b.Vg(); + } + function pke(a, b) { + nke(); + var c2, d, e, f2; + if (!b) { + return mke; + } else if (b == (nme(), kme) || (b == Ule || b == Sle || b == Tle) && a != Rle) { + return new wke(a, b); + } else { + d = RD(b, 692); + c2 = d.$k(); + if (!c2) { + Afe(Qee((lke(), jke), b)); + c2 = d.$k(); + } + f2 = (!c2.i && (c2.i = new Tsb()), c2.i); + e = RD(Wd(qtb(f2.f, a)), 2041); + !e && Zjb(f2, a, e = new wke(a, b)); + return e; + } + } + function jHb(a, b) { + var c2, d; + d = rAb(a.b, b.b); + if (!d) { + throw Adb(new dgb("Invalid hitboxes for scanline constraint calculation.")); + } + (dHb(b.b, RD(tAb(a.b, b.b), 60)) || dHb(b.b, RD(sAb(a.b, b.b), 60))) && (gib(), String.fromCharCode(10)); + a.a[b.b.f] = RD(vAb(a.b, b.b), 60); + c2 = RD(uAb(a.b, b.b), 60); + !!c2 && (a.a[c2.f] = b.b); + } + function lTb(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l; + f2 = IGd(b, false, false); + j = ssd(f2); + l = Kfb(UD(Gxd(b, (tSb(), mSb)))); + e = jTb(j, l + a.a); + k = new ORb(e); + kQb(k, b); + Zjb(a.b, b, k); + ZEb(c2.c, k); + i2 = (!b.n && (b.n = new C5d(I4, b, 1, 7)), b.n); + for (h = new dMd(i2); h.e != h.i.gc(); ) { + g = RD(bMd(h), 135); + d = nTb(a, g, true, 0, 0); + ZEb(c2.c, d); + } + return k; + } + function Zec(a, b) { + var c2, d, e, f2, g, h, i2; + e = new bnb(); + for (c2 = 0; c2 <= a.j; c2++) { + d = new R4b(b); + d.p = a.j - c2; + ZEb(e.c, d); + } + for (h = new Anb(a.p); h.a < h.c.c.length; ) { + g = RD(ynb(h), 10); + g3b(g, RD(Vmb(e, a.j - a.g[g.p]), 30)); + } + f2 = new Anb(e); + while (f2.a < f2.c.c.length) { + i2 = RD(ynb(f2), 30); + i2.a.c.length == 0 && znb(f2); + } + b.b.c.length = 0; + Tmb(b.b, e); + } + function xfc(a, b) { + var c2, d, e, f2, g, h, i2, j, k; + i2 = RD(mQb(a, (Ywc(), Awc)), 12); + j = xjd(cD(WC(l3, 1), Nve, 8, 0, [i2.i.n, i2.n, i2.a])).a; + k = a.i.n.b; + c2 = s2b(a.e); + for (e = c2, f2 = 0, g = e.length; f2 < g; ++f2) { + d = e[f2]; + Z0b(d, i2); + Oub(d.a, new rjd(j, k)); + if (b) { + h = RD(mQb(d, (yCc(), RAc)), 75); + if (!h) { + h = new Ejd(); + pQb(d, RAc, h); + } + Mub(h, new rjd(j, k)); + } + } + } + function yfc(a, b) { + var c2, d, e, f2, g, h, i2, j, k; + e = RD(mQb(a, (Ywc(), Awc)), 12); + j = xjd(cD(WC(l3, 1), Nve, 8, 0, [e.i.n, e.n, e.a])).a; + k = a.i.n.b; + c2 = s2b(a.g); + for (g = c2, h = 0, i2 = g.length; h < i2; ++h) { + f2 = g[h]; + Y0b(f2, e); + Nub(f2.a, new rjd(j, k)); + if (b) { + d = RD(mQb(f2, (yCc(), RAc)), 75); + if (!d) { + d = new Ejd(); + pQb(f2, RAc, d); + } + Mub(d, new rjd(j, k)); + } + } + } + function Khc(a) { + var b, c2, d, e, f2, g, h, i2, j; + d = a.b; + f2 = d.e; + g = Cod(RD(mQb(d, (yCc(), BBc)), 101)); + c2 = !!f2 && RD(mQb(f2, (Ywc(), kwc)), 21).Hc((ovc(), hvc)); + if (g || c2) { + return; + } + for (j = (h = new glb(a.e).a.vc().Kc(), new llb(h)); j.a.Ob(); ) { + i2 = (b = RD(j.a.Pb(), 44), RD(b.md(), 113)); + if (i2.a) { + e = i2.d; + P3b(e, null); + i2.c = true; + a.a = true; + } + } + } + function iic(a, b) { + var c2, d, e, f2; + b.Ug("Semi-Interactive Crossing Minimization Processor", 1); + c2 = false; + for (e = new Anb(a.b); e.a < e.c.c.length; ) { + d = RD(ynb(e), 30); + f2 = MDb(PDb(CDb(CDb(new SDb(null, new Swb(d.a, 16)), new nic()), new pic()), new ric()), new vic()); + c2 = c2 | f2.a != null; + } + c2 && pQb(a, (Ywc(), rwc), (Geb(), true)); + b.Vg(); + } + function rKc(a, b) { + var c2, d, e, f2, g, h; + a.b = new bnb(); + a.d = RD(mQb(b, (Ywc(), Lwc)), 234); + a.e = Lwb(a.d); + f2 = new Yub(); + e = dv(cD(WC(eR, 1), OAe, 36, 0, [b])); + g = 0; + while (g < e.c.length) { + d = (tFb(g, e.c.length), RD(e.c[g], 36)); + d.p = g++; + c2 = new FJc(d, a.a, a.b); + Tmb(e, c2.b); + Rmb(a.b, c2); + c2.s && (h = Sub(f2, 0), cvb(h, c2)); + } + a.c = new _sb(); + return f2; + } + function yMb(a, b) { + var c2, d, e, f2, g, h; + for (g = RD(RD(Qc(a.r, b), 21), 87).Kc(); g.Ob(); ) { + f2 = RD(g.Pb(), 117); + c2 = f2.c ? QKb(f2.c) : 0; + if (c2 > 0) { + if (f2.a) { + h = f2.b.Mf().a; + if (c2 > h) { + e = (c2 - h) / 2; + f2.d.b = e; + f2.d.c = e; + } + } else { + f2.d.c = a.s + c2; + } + } else if (Rod(a.u)) { + d = wsd(f2.b); + d.c < 0 && (f2.d.b = -d.c); + d.c + d.b > f2.b.Mf().a && (f2.d.c = d.c + d.b - f2.b.Mf().a); + } + } + } + function RUc(a, b) { + var c2, d, e, f2, g; + g = new bnb(); + c2 = b; + do { + f2 = RD(Wjb(a.b, c2), 131); + f2.B = c2.c; + f2.D = c2.d; + ZEb(g.c, f2); + c2 = RD(Wjb(a.k, c2), 18); + } while (c2); + d = (tFb(0, g.c.length), RD(g.c[0], 131)); + d.j = true; + d.A = RD(d.d.a.ec().Kc().Pb(), 18).c.i; + e = RD(Vmb(g, g.c.length - 1), 131); + e.q = true; + e.C = RD(e.d.a.ec().Kc().Pb(), 18).d.i; + return g; + } + function pPb(a) { + var b, c2; + b = RD(a.a, 17).a; + c2 = RD(a.b, 17).a; + if (b >= 0) { + if (b == c2) { + return new Ptd(sgb(-b - 1), sgb(-b - 1)); + } + if (b == -c2) { + return new Ptd(sgb(-b), sgb(c2 + 1)); + } + } + if ($wnd.Math.abs(b) > $wnd.Math.abs(c2)) { + if (b < 0) { + return new Ptd(sgb(-b), sgb(c2)); + } + return new Ptd(sgb(-b), sgb(c2 + 1)); + } + return new Ptd(sgb(b + 1), sgb(c2)); + } + function H8b(a) { + var b, c2; + c2 = RD(mQb(a, (yCc(), UAc)), 171); + b = RD(mQb(a, (Ywc(), owc)), 311); + if (c2 == (cxc(), $wc)) { + pQb(a, UAc, bxc); + pQb(a, owc, (Gvc(), Fvc)); + } else if (c2 == axc) { + pQb(a, UAc, bxc); + pQb(a, owc, (Gvc(), Dvc)); + } else if (b == (Gvc(), Fvc)) { + pQb(a, UAc, $wc); + pQb(a, owc, Evc); + } else if (b == Dvc) { + pQb(a, UAc, axc); + pQb(a, owc, Evc); + } + } + function dSc() { + dSc = geb; + bSc = new pSc(); + ZRc = pfd(new ufd(), (sXb(), pXb), (hcc(), Fbc)); + aSc = nfd(pfd(new ufd(), pXb, Tbc), rXb, Sbc); + cSc = mfd(mfd(rfd(nfd(pfd(new ufd(), nXb, bcc), rXb, acc), qXb), _bc), ccc); + $Rc = nfd(pfd(pfd(pfd(new ufd(), oXb, Ibc), qXb, Kbc), qXb, Lbc), rXb, Jbc); + _Rc = nfd(pfd(pfd(new ufd(), qXb, Lbc), qXb, qbc), rXb, pbc); + } + function HUc() { + HUc = geb; + CUc = pfd(nfd(new ufd(), (sXb(), rXb), (hcc(), tbc)), pXb, Fbc); + GUc = mfd(mfd(rfd(nfd(pfd(new ufd(), nXb, bcc), rXb, acc), qXb), _bc), ccc); + DUc = nfd(pfd(pfd(pfd(new ufd(), oXb, Ibc), qXb, Kbc), qXb, Lbc), rXb, Jbc); + FUc = pfd(pfd(new ufd(), pXb, Tbc), rXb, Sbc); + EUc = nfd(pfd(pfd(new ufd(), qXb, Lbc), qXb, qbc), rXb, pbc); + } + function eSc(a, b, c2, d, e) { + var f2, g; + if ((!W0b(b) && b.c.i.c == b.d.i.c || !djd(xjd(cD(WC(l3, 1), Nve, 8, 0, [e.i.n, e.n, e.a])), c2)) && !W0b(b)) { + b.c == e ? hu(b.a, 0, new sjd(c2)) : Mub(b.a, new sjd(c2)); + if (d && !Zsb(a.a, c2)) { + g = RD(mQb(b, (yCc(), RAc)), 75); + if (!g) { + g = new Ejd(); + pQb(b, RAc, g); + } + f2 = new sjd(c2); + Pub(g, f2, g.c.b, g.c); + Ysb(a.a, f2); + } + } + } + function ht(a, b) { + var c2, d, e, f2; + f2 = Ydb(Ndb(cwe, qgb(Ydb(Ndb(b == null ? 0 : tb(b), dwe)), 15))); + c2 = f2 & a.b.length - 1; + e = null; + for (d = a.b[c2]; d; e = d, d = d.a) { + if (d.d == f2 && Hb(d.i, b)) { + !e ? a.b[c2] = d.a : e.a = d.a; + Ts(RD(Hvb(d.c), 604), RD(Hvb(d.f), 604)); + Ss(RD(Hvb(d.b), 227), RD(Hvb(d.e), 227)); + --a.f; + ++a.e; + return true; + } + } + return false; + } + function dec(a) { + var b, c2; + for (c2 = new is(Mr(Z2b(a).a.Kc(), new ir())); gs(c2); ) { + b = RD(hs(c2), 18); + if (b.c.i.k != (r3b(), n3b)) { + throw Adb(new Jed(nBe + X2b(a) + "' has its layer constraint set to FIRST, but has at least one incoming edge that does not come from a FIRST_SEPARATE node. That must not happen.")); + } + } + } + function Twd(a, b, c2) { + var d, e, f2, g, h, i2, j; + e = ggb(a.Db & 254); + if (e == 0) { + a.Eb = c2; + } else { + if (e == 1) { + h = $C(jJ, rve, 1, 2, 5, 1); + f2 = Xwd(a, b); + if (f2 == 0) { + h[0] = c2; + h[1] = a.Eb; + } else { + h[0] = a.Eb; + h[1] = c2; + } + } else { + h = $C(jJ, rve, 1, e + 1, 5, 1); + g = SD(a.Eb); + for (d = 2, i2 = 0, j = 0; d <= 128; d <<= 1) { + d == b ? h[j++] = c2 : (a.Db & d) != 0 && (h[j++] = g[i2++]); + } + } + a.Eb = h; + } + a.Db |= b; + } + function vQb(a, b, c2) { + var d, e, f2, g; + this.b = new bnb(); + e = 0; + d = 0; + for (g = new Anb(a); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 176); + c2 && iPb(f2); + Rmb(this.b, f2); + e += f2.o; + d += f2.p; + } + if (this.b.c.length > 0) { + f2 = RD(Vmb(this.b, 0), 176); + e += f2.o; + d += f2.p; + } + e *= 2; + d *= 2; + b > 1 ? e = eE($wnd.Math.ceil(e * b)) : d = eE($wnd.Math.ceil(d / b)); + this.a = new gQb(e, d); + } + function mkc(a, b, c2, d, e, f2) { + var g, h, i2, j, k, l, m, n, o2, p, q, r; + k = d; + if (b.j && b.o) { + n = RD(Wjb(a.f, b.A), 60); + p = n.d.c + n.d.b; + --k; + } else { + p = b.a.c + b.a.b; + } + l = e; + if (c2.q && c2.o) { + n = RD(Wjb(a.f, c2.C), 60); + j = n.d.c; + ++l; + } else { + j = c2.a.c; + } + q = j - p; + i2 = $wnd.Math.max(2, l - k); + h = q / i2; + o2 = p + h; + for (m = k; m < l; ++m) { + g = RD(f2.Xb(m), 131); + r = g.a.b; + g.a.c = o2 - r / 2; + o2 += h; + } + } + function Wrc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m; + e = b ? new dsc() : new fsc(); + f2 = false; + do { + f2 = false; + j = b ? hv(a.b) : a.b; + for (i2 = j.Kc(); i2.Ob(); ) { + h = RD(i2.Pb(), 30); + m = bv(h.a); + b || hv(m); + for (l = new Anb(m); l.a < l.c.c.length; ) { + k = RD(ynb(l), 10); + if (e.Mb(k)) { + d = k; + c2 = RD(mQb(k, (Ywc(), Wvc)), 313); + g = b ? c2.b : c2.k; + f2 = Urc(d, g, b, false); + } + } + } + } while (f2); + } + function sMc(a, b, c2, d, e, f2) { + var g, h, i2, j, k, l; + j = c2.c.length; + f2 && (a.c = $C(kE, Pwe, 28, b.length, 15, 1)); + for (g = e ? 0 : b.length - 1; e ? g < b.length : g >= 0; g += e ? 1 : -1) { + h = b[g]; + i2 = d == (qpd(), Xod) ? e ? b3b(h, d) : hv(b3b(h, d)) : e ? hv(b3b(h, d)) : b3b(h, d); + f2 && (a.c[h.p] = i2.gc()); + for (l = i2.Kc(); l.Ob(); ) { + k = RD(l.Pb(), 12); + a.d[k.p] = j++; + } + Tmb(c2, i2); + } + } + function AUc(a, b, c2) { + var d, e, f2, g, h, i2, j, k; + f2 = Kfb(UD(a.b.Kc().Pb())); + j = Kfb(UD(fr(b.b))); + d = ijd(ajd(a.a), j - c2); + e = ijd(ajd(b.a), c2 - f2); + k = $id(d, e); + ijd(k, 1 / (j - f2)); + this.a = k; + this.b = new bnb(); + h = true; + g = a.b.Kc(); + g.Pb(); + while (g.Ob()) { + i2 = Kfb(UD(g.Pb())); + if (h && i2 - c2 > AEe) { + this.b.Fc(c2); + h = false; + } + this.b.Fc(i2); + } + h && this.b.Fc(c2); + } + function mJb(a) { + var b, c2, d, e; + pJb(a, a.n); + if (a.d.c.length > 0) { + Nnb(a.c); + while (xJb(a, RD(ynb(new Anb(a.e.a)), 125)) < a.e.a.c.length) { + b = rJb(a); + e = b.e.e - b.d.e - b.a; + b.e.j && (e = -e); + for (d = new Anb(a.e.a); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 125); + c2.j && (c2.e += e); + } + Nnb(a.c); + } + Nnb(a.c); + uJb(a, RD(ynb(new Anb(a.e.a)), 125)); + iJb(a); + } + } + function ned(a, b) { + hed(); + var c2, d; + c2 = ugd(ygd(), b.Pg()); + if (c2) { + d = c2.j; + if (ZD(a, 207)) { + return xCd(RD(a, 27)) ? Csb(d, (Yhd(), Vhd)) || Csb(d, Whd) : Csb(d, (Yhd(), Vhd)); + } else if (ZD(a, 326)) { + return Csb(d, (Yhd(), Thd)); + } else if (ZD(a, 193)) { + return Csb(d, (Yhd(), Xhd)); + } else if (ZD(a, 366)) { + return Csb(d, (Yhd(), Uhd)); + } + } + return true; + } + function Cge(a, b, c2) { + var d, e, f2, g, h, i2; + e = c2; + f2 = e.Lk(); + if (qke(a.e, f2)) { + if (f2.Si()) { + d = RD(a.g, 124); + for (g = 0; g < a.i; ++g) { + h = d[g]; + if (pb(h, e) && g != b) { + throw Adb(new agb(LIe)); + } + } + } + } else { + i2 = pke(a.e.Dh(), f2); + d = RD(a.g, 124); + for (g = 0; g < a.i; ++g) { + h = d[g]; + if (i2.am(h.Lk()) && g != b) { + throw Adb(new agb(gLe)); + } + } + } + return RD(eHd(a, b, c2), 76); + } + function hz(d, b) { + if (b instanceof Object) { + try { + b.__java$exception = d; + if (navigator.userAgent.toLowerCase().indexOf("msie") != -1 && $doc.documentMode < 9) { + return; + } + var c2 = d; + Object.defineProperties(b, { cause: { get: function() { + var a = c2.he(); + return a && a.fe(); + } }, suppressed: { get: function() { + return c2.ge(); + } } }); + } catch (a) { + } + } + } + function tjb(a, b) { + var c2, d, e, f2, g; + d = b >> 5; + b &= 31; + if (d >= a.d) { + return a.e < 0 ? (Pib(), Jib) : (Pib(), Oib); + } + f2 = a.d - d; + e = $C(kE, Pwe, 28, f2 + 1, 15, 1); + ujb(e, f2, a.a, d, b); + if (a.e < 0) { + for (c2 = 0; c2 < d && a.a[c2] == 0; c2++) + ; + if (c2 < d || b > 0 && a.a[c2] << 32 - b != 0) { + for (c2 = 0; c2 < f2 && e[c2] == -1; c2++) { + e[c2] = 0; + } + c2 == f2 && ++f2; + ++e[c2]; + } + } + g = new cjb(a.e, f2, e); + Rib(g); + return g; + } + function LSb(a) { + var b, c2, d, e; + e = MCd(a); + c2 = new bTb(e); + d = new dTb(e); + b = new bnb(); + Tmb(b, (!a.d && (a.d = new Yie(G4, a, 8, 5)), a.d)); + Tmb(b, (!a.e && (a.e = new Yie(G4, a, 7, 4)), a.e)); + return RD(zDb(GDb(CDb(new SDb(null, new Swb(b, 16)), c2), d), sBb(new _Bb(), new bCb(), new yCb(), new ACb(), cD(WC(QL, 1), jwe, 108, 0, [(xBb(), wBb), vBb]))), 21); + } + function Tdc(a, b) { + var c2; + c2 = RD(mQb(a, (yCc(), xAc)), 283); + b.Ug("Label side selection (" + c2 + ")", 1); + switch (c2.g) { + case 0: + Udc(a, (Pnd(), Lnd)); + break; + case 1: + Udc(a, (Pnd(), Mnd)); + break; + case 2: + Sdc(a, (Pnd(), Lnd)); + break; + case 3: + Sdc(a, (Pnd(), Mnd)); + break; + case 4: + Vdc(a, (Pnd(), Lnd)); + break; + case 5: + Vdc(a, (Pnd(), Mnd)); + } + b.Vg(); + } + function qke(a, b) { + nke(); + var c2, d, e; + if (b.Jk()) { + return true; + } else if (b.Ik() == -2) { + if (b == (Lle(), Jle) || b == Gle || b == Hle || b == Ile) { + return true; + } else { + e = a.Dh(); + if (BYd(e, b) >= 0) { + return false; + } else { + c2 = Eee((lke(), jke), e, b); + if (!c2) { + return true; + } else { + d = c2.Ik(); + return (d > 1 || d == -1) && yfe(Qee(jke, c2)) != 3; + } + } + } + } else { + return false; + } + } + function _4b(a, b, c2, d) { + var e, f2, g, h, i2; + h = AGd(RD(QHd((!b.b && (b.b = new Yie(E4, b, 4, 7)), b.b), 0), 84)); + i2 = AGd(RD(QHd((!b.c && (b.c = new Yie(E4, b, 5, 8)), b.c), 0), 84)); + if (vCd(h) == vCd(i2)) { + return null; + } + if (NGd(i2, h)) { + return null; + } + g = kzd(b); + if (g == c2) { + return d; + } else { + f2 = RD(Wjb(a.a, g), 10); + if (f2) { + e = f2.e; + if (e) { + return e; + } + } + } + return null; + } + function uHc(a, b, c2) { + var d, e, f2, g, h; + c2.Ug("Longest path to source layering", 1); + a.a = b; + h = a.a.a; + a.b = $C(kE, Pwe, 28, h.c.length, 15, 1); + d = 0; + for (g = new Anb(h); g.a < g.c.c.length; ) { + e = RD(ynb(g), 10); + e.p = d; + a.b[d] = -1; + ++d; + } + for (f2 = new Anb(h); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 10); + wHc(a, e); + } + h.c.length = 0; + a.a = null; + a.b = null; + c2.Vg(); + } + function BKc(a, b, c2) { + var d, e, f2, g, h, i2; + d = pKc(c2, a.length); + g = a[d]; + f2 = qKc(c2, g.length); + if (g[f2].k != (r3b(), m3b)) { + return; + } + i2 = b.j; + for (e = 0; e < i2.c.length; e++) { + h = (tFb(e, i2.c.length), RD(i2.c[e], 12)); + if ((c2 ? h.j == (qpd(), Xod) : h.j == (qpd(), ppd)) && Heb(TD(mQb(h, (Ywc(), nwc))))) { + $mb(i2, e, RD(mQb(g[f2], (Ywc(), Awc)), 12)); + f2 += c2 ? 1 : -1; + } + } + } + function n8c(a, b) { + var c2, d, e, f2, g, h, i2, j; + b.Ug("Greedy Width Approximator", 1); + c2 = Kfb(UD(Gxd(a, (X7c(), x7c)))); + i2 = RD(Gxd(a, N7c), 107); + f2 = RD(Gxd(a, U7c), 394); + g = Heb(TD(Gxd(a, T7c))); + h = Kfb(UD(Gxd(a, Q7c))); + j = (!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a); + Bad(j); + e = new g8c(c2, f2, g); + d = c8c(e, j, h, i2); + Ixd(a, (X6c(), W6c), d.c); + b.Vg(); + } + function yKd(a) { + if (a.g == null) { + switch (a.p) { + case 0: + a.g = qKd(a) ? (Geb(), Feb) : (Geb(), Eeb); + break; + case 1: + a.g = $eb(rKd(a)); + break; + case 2: + a.g = hfb(sKd(a)); + break; + case 3: + a.g = tKd(a); + break; + case 4: + a.g = new Tfb(uKd(a)); + break; + case 6: + a.g = Hgb(wKd(a)); + break; + case 5: + a.g = sgb(vKd(a)); + break; + case 7: + a.g = bhb(xKd(a)); + } + } + return a.g; + } + function HKd(a) { + if (a.n == null) { + switch (a.p) { + case 0: + a.n = zKd(a) ? (Geb(), Feb) : (Geb(), Eeb); + break; + case 1: + a.n = $eb(AKd(a)); + break; + case 2: + a.n = hfb(BKd(a)); + break; + case 3: + a.n = CKd(a); + break; + case 4: + a.n = new Tfb(DKd(a)); + break; + case 6: + a.n = Hgb(FKd(a)); + break; + case 5: + a.n = sgb(EKd(a)); + break; + case 7: + a.n = bhb(GKd(a)); + } + } + return a.n; + } + function Pfe(a, b, c2, d) { + var e, f2, g, h, i2; + h = (nke(), RD(b, 69).xk()); + if (qke(a.e, b)) { + if (b.Si() && dge(a, b, d, ZD(b, 102) && (RD(b, 19).Bb & txe) != 0)) { + throw Adb(new agb(LIe)); + } + } else { + i2 = pke(a.e.Dh(), b); + e = RD(a.g, 124); + for (g = 0; g < a.i; ++g) { + f2 = e[g]; + if (i2.am(f2.Lk())) { + throw Adb(new agb(gLe)); + } + } + } + VGd(a, gge(a, b, c2), h ? RD(d, 76) : oke(b, d)); + } + function HGb(a) { + var b, c2, d, e, f2, g, h; + for (f2 = new Anb(a.a.a); f2.a < f2.c.c.length; ) { + d = RD(ynb(f2), 316); + d.g = 0; + d.i = 0; + d.e.a.$b(); + } + for (e = new Anb(a.a.a); e.a < e.c.c.length; ) { + d = RD(ynb(e), 316); + for (c2 = d.a.a.ec().Kc(); c2.Ob(); ) { + b = RD(c2.Pb(), 60); + for (h = b.c.Kc(); h.Ob(); ) { + g = RD(h.Pb(), 60); + if (g.a != d) { + Ysb(d.e, g); + ++g.a.g; + ++g.a.i; + } + } + } + } + } + function X8b(a) { + var b, c2, d, e, f2; + e = RD(mQb(a, (yCc(), lBc)), 21); + f2 = RD(mQb(a, oBc), 21); + c2 = new rjd(a.f.a + a.d.b + a.d.c, a.f.b + a.d.d + a.d.a); + b = new sjd(c2); + if (e.Hc((Qpd(), Mpd))) { + d = RD(mQb(a, nBc), 8); + if (f2.Hc((dqd(), Ypd))) { + d.a <= 0 && (d.a = 20); + d.b <= 0 && (d.b = 20); + } + b.a = $wnd.Math.max(c2.a, d.a); + b.b = $wnd.Math.max(c2.b, d.b); + } + Y8b(a, c2, b); + } + function SYb(a, b) { + var c2, d, e; + b.a ? (rAb(a.b, b.b), a.a[b.b.i] = RD(vAb(a.b, b.b), 86), c2 = RD(uAb(a.b, b.b), 86), !!c2 && (a.a[c2.i] = b.b), void 0) : (d = RD(vAb(a.b, b.b), 86), !!d && d == a.a[b.b.i] && !!d.d && d.d != b.b.d && d.f.Fc(b.b), e = RD(uAb(a.b, b.b), 86), !!e && a.a[e.i] == b.b && !!e.d && e.d != b.b.d && b.b.f.Fc(e), wAb(a.b, b.b), void 0); + } + function Oec(a, b) { + var c2, d, e, f2, g, h; + f2 = a.d; + h = Kfb(UD(mQb(a, (yCc(), FAc)))); + if (h < 0) { + h = 0; + pQb(a, FAc, h); + } + b.o.b = h; + g = $wnd.Math.floor(h / 2); + d = new R3b(); + Q3b(d, (qpd(), ppd)); + P3b(d, b); + d.n.b = g; + e = new R3b(); + Q3b(e, Xod); + P3b(e, b); + e.n.b = g; + Z0b(a, d); + c2 = new a1b(); + kQb(c2, a); + pQb(c2, RAc, null); + Y0b(c2, e); + Z0b(c2, f2); + Nec(b, a, c2); + Lec(a, c2); + return c2; + } + function URc(a) { + var b, c2; + c2 = RD(mQb(a, (Ywc(), kwc)), 21); + b = new ufd(); + if (c2.Hc((ovc(), ivc))) { + ofd(b, ORc); + ofd(b, QRc); + } + if (c2.Hc(kvc) || Heb(TD(mQb(a, (yCc(), GAc))))) { + ofd(b, QRc); + c2.Hc(lvc) && ofd(b, RRc); + } + c2.Hc(hvc) && ofd(b, NRc); + c2.Hc(nvc) && ofd(b, SRc); + c2.Hc(jvc) && ofd(b, PRc); + c2.Hc(evc) && ofd(b, LRc); + c2.Hc(gvc) && ofd(b, MRc); + return b; + } + function Qjb(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m; + d = a.d; + f2 = b.d; + h = d + f2; + i2 = a.e != b.e ? -1 : 1; + if (h == 2) { + k = Ndb(Cdb(a.a[0], yxe), Cdb(b.a[0], yxe)); + m = Ydb(k); + l = Ydb(Udb(k, 32)); + return l == 0 ? new ajb(i2, m) : new cjb(i2, 2, cD(WC(kE, 1), Pwe, 28, 15, [m, l])); + } + c2 = a.a; + e = b.a; + g = $C(kE, Pwe, 28, h, 15, 1); + Njb(c2, d, e, f2, g); + j = new cjb(i2, h, g); + Rib(j); + return j; + } + function Uyb(a, b, c2, d) { + var e, f2; + if (!b) { + return c2; + } else { + e = a.a.Ne(c2.d, b.d); + if (e == 0) { + d.d = qlb(b, c2.e); + d.b = true; + return b; + } + f2 = e < 0 ? 0 : 1; + b.a[f2] = Uyb(a, b.a[f2], c2, d); + if (Vyb(b.a[f2])) { + if (Vyb(b.a[1 - f2])) { + b.b = true; + b.a[0].b = false; + b.a[1].b = false; + } else { + Vyb(b.a[f2].a[f2]) ? b = azb(b, 1 - f2) : Vyb(b.a[f2].a[1 - f2]) && (b = _yb(b, 1 - f2)); + } + } + } + return b; + } + function nKb(a, b, c2) { + var d, e, f2, g; + e = a.i; + d = a.n; + mKb(a, (ZJb(), WJb), e.c + d.b, c2); + mKb(a, YJb, e.c + e.b - d.c - c2[2], c2); + g = e.b - d.b - d.c; + if (c2[0] > 0) { + c2[0] += a.d; + g -= c2[0]; + } + if (c2[2] > 0) { + c2[2] += a.d; + g -= c2[2]; + } + f2 = $wnd.Math.max(0, g); + c2[1] = $wnd.Math.max(c2[1], g); + mKb(a, XJb, e.c + d.b + c2[0] - (c2[1] - g) / 2, c2); + if (b == XJb) { + a.c.b = f2; + a.c.c = e.c + d.b + (f2 - g) / 2; + } + } + function D_b() { + this.c = $C(iE, vxe, 28, (qpd(), cD(WC(E3, 1), NAe, 64, 0, [opd, Yod, Xod, npd, ppd])).length, 15, 1); + this.b = $C(iE, vxe, 28, cD(WC(E3, 1), NAe, 64, 0, [opd, Yod, Xod, npd, ppd]).length, 15, 1); + this.a = $C(iE, vxe, 28, cD(WC(E3, 1), NAe, 64, 0, [opd, Yod, Xod, npd, ppd]).length, 15, 1); + Lnb(this.c, oxe); + Lnb(this.b, pxe); + Lnb(this.a, pxe); + } + function rte(a, b, c2) { + var d, e, f2, g; + if (b <= c2) { + e = b; + f2 = c2; + } else { + e = c2; + f2 = b; + } + d = 0; + if (a.b == null) { + a.b = $C(kE, Pwe, 28, 2, 15, 1); + a.b[0] = e; + a.b[1] = f2; + a.c = true; + } else { + d = a.b.length; + if (a.b[d - 1] + 1 == e) { + a.b[d - 1] = f2; + return; + } + g = $C(kE, Pwe, 28, d + 2, 15, 1); + hib(a.b, 0, g, 0, d); + a.b = g; + a.b[d - 1] >= e && (a.c = false, a.a = false); + a.b[d++] = e; + a.b[d] = f2; + a.c || vte(a); + } + } + function Oqc(a, b, c2) { + var d, e, f2, g, h, i2, j; + j = b.d; + a.a = new cnb(j.c.length); + a.c = new Tsb(); + for (h = new Anb(j); h.a < h.c.c.length; ) { + g = RD(ynb(h), 105); + f2 = new USc(null); + Rmb(a.a, f2); + Zjb(a.c, g, f2); + } + a.b = new Tsb(); + Mqc(a, b); + for (d = 0; d < j.c.length - 1; d++) { + i2 = RD(Vmb(b.d, d), 105); + for (e = d + 1; e < j.c.length; e++) { + Pqc(a, i2, RD(Vmb(b.d, e), 105), c2); + } + } + } + function Q2c(a) { + var b, c2, d, e, f2; + e = new bnb(); + b = new btb((!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a)); + for (d = new is(Mr(zGd(a).a.Kc(), new ir())); gs(d); ) { + c2 = RD(hs(d), 74); + if (!ZD(QHd((!c2.b && (c2.b = new Yie(E4, c2, 4, 7)), c2.b), 0), 193)) { + f2 = AGd(RD(QHd((!c2.c && (c2.c = new Yie(E4, c2, 5, 8)), c2.c), 0), 84)); + b.a._b(f2) || (ZEb(e.c, f2), true); + } + } + return e; + } + function Nqe(a, b, c2) { + var d, e, f2; + a.e = c2; + a.d = 0; + a.b = 0; + a.f = 1; + a.i = b; + (a.e & 16) == 16 && (a.i = use(a.i)); + a.j = a.i.length; + Mqe(a); + f2 = Qqe(a); + if (a.d != a.j) + throw Adb(new Lqe(TId((Hde(), TIe)))); + if (a.g) { + for (d = 0; d < a.g.a.c.length; d++) { + e = RD(eyb(a.g, d), 592); + if (a.f <= e.a) + throw Adb(new Lqe(TId((Hde(), UIe)))); + } + a.g.a.c.length = 0; + } + return f2; + } + function BNc(a, b) { + var c2, d, e, f2, g, h, i2; + c2 = pxe; + h = (r3b(), p3b); + for (e = new Anb(b.a); e.a < e.c.c.length; ) { + d = RD(ynb(e), 10); + f2 = d.k; + if (f2 != p3b) { + g = UD(mQb(d, (Ywc(), Cwc))); + if (g == null) { + c2 = $wnd.Math.max(c2, 0); + d.n.b = c2 + aFc(a.a, f2, h); + } else { + d.n.b = (uFb(g), g); + } + } + i2 = aFc(a.a, f2, h); + d.n.b < c2 + i2 + d.d.d && (d.n.b = c2 + i2 + d.d.d); + c2 = d.n.b + d.o.b + d.d.a; + h = f2; + } + } + function w3c(a, b, c2, d, e) { + var f2, g, h, i2, j, k; + !!a.d && a.d.Gg(e); + f2 = RD(e.Xb(0), 27); + if (u3c(a, c2, f2, false)) { + return true; + } + g = RD(e.Xb(e.gc() - 1), 27); + if (u3c(a, d, g, true)) { + return true; + } + if (p3c(a, e)) { + return true; + } + for (k = e.Kc(); k.Ob(); ) { + j = RD(k.Pb(), 27); + for (i2 = b.Kc(); i2.Ob(); ) { + h = RD(i2.Pb(), 27); + if (o3c(a, j, h)) { + return true; + } + } + } + return false; + } + function Ovd(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m; + m = b.c.length; + l = (j = a.Ih(c2), RD(j >= 0 ? a.Lh(j, false, true) : Qvd(a, c2, false), 61)); + n: + for (f2 = l.Kc(); f2.Ob(); ) { + e = RD(f2.Pb(), 58); + for (k = 0; k < m; ++k) { + g = (tFb(k, b.c.length), RD(b.c[k], 76)); + i2 = g.md(); + h = g.Lk(); + d = e.Nh(h, false); + if (i2 == null ? d != null : !pb(i2, d)) { + continue n; + } + } + return e; + } + return null; + } + function o6b(a, b) { + var c2, d, e, f2, g, h, i2; + b.Ug("Comment post-processing", 1); + for (f2 = new Anb(a.b); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 30); + d = new bnb(); + for (h = new Anb(e.a); h.a < h.c.c.length; ) { + g = RD(ynb(h), 10); + i2 = RD(mQb(g, (Ywc(), Xwc)), 15); + c2 = RD(mQb(g, Vvc), 15); + if (!!i2 || !!c2) { + p6b(g, i2, c2); + !!i2 && Tmb(d, i2); + !!c2 && Tmb(d, c2); + } + } + Tmb(e.a, d); + } + b.Vg(); + } + function kac(a, b, c2, d) { + var e, f2, g, h; + e = RD(e3b(b, (qpd(), ppd)).Kc().Pb(), 12); + f2 = RD(e3b(b, Xod).Kc().Pb(), 12); + for (h = new Anb(a.j); h.a < h.c.c.length; ) { + g = RD(ynb(h), 12); + while (g.e.c.length != 0) { + Z0b(RD(Vmb(g.e, 0), 18), e); + } + while (g.g.c.length != 0) { + Y0b(RD(Vmb(g.g, 0), 18), f2); + } + } + c2 || pQb(b, (Ywc(), vwc), null); + d || pQb(b, (Ywc(), wwc), null); + } + function IGd(a, b, c2) { + var d, e; + if ((!a.a && (a.a = new C5d(F4, a, 6, 6)), a.a).i == 0) { + return EGd(a); + } else { + d = RD(QHd((!a.a && (a.a = new C5d(F4, a, 6, 6)), a.a), 0), 166); + if (b) { + sLd((!d.a && (d.a = new XZd(D4, d, 5)), d.a)); + Ozd(d, 0); + Pzd(d, 0); + Hzd(d, 0); + Izd(d, 0); + } + if (c2) { + e = (!a.a && (a.a = new C5d(F4, a, 6, 6)), a.a); + while (e.i > 1) { + vLd(e, e.i - 1); + } + } + return d; + } + } + function Vdc(a, b) { + var c2, d, e, f2, g, h, i2; + c2 = new wmb(); + for (f2 = new Anb(a.b); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 30); + i2 = true; + d = 0; + for (h = new Anb(e.a); h.a < h.c.c.length; ) { + g = RD(ynb(h), 10); + switch (g.k.g) { + case 4: + ++d; + case 1: + imb(c2, g); + break; + case 0: + Xdc(g, b); + default: + c2.b == c2.c || Wdc(c2, d, i2, false, b); + i2 = false; + d = 0; + } + } + c2.b == c2.c || Wdc(c2, d, i2, true, b); + } + } + function iMc(a, b) { + var c2, d, e, f2, g, h; + c2 = 0; + for (h = new Anb(b); h.a < h.c.c.length; ) { + g = RD(ynb(h), 12); + $Lc(a.b, a.d[g.p]); + for (e = new l4b(g.b); xnb(e.a) || xnb(e.b); ) { + d = RD(xnb(e.a) ? ynb(e.a) : ynb(e.b), 18); + f2 = AMc(a, g == d.c ? d.d : d.c); + if (f2 > a.d[g.p]) { + c2 += ZLc(a.b, f2); + hmb(a.a, sgb(f2)); + } + } + while (!nmb(a.a)) { + XLc(a.b, RD(smb(a.a), 17).a); + } + } + return c2; + } + function Uec(a) { + var b, c2, d, e, f2, g, h, i2, j; + a.a = new e6b(); + j = 0; + e = 0; + for (d = new Anb(a.i.b); d.a < d.c.c.length; ) { + b = RD(ynb(d), 30); + b.p = e; + for (i2 = new Anb(b.a); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 10); + h.p = j; + ++j; + } + ++e; + } + f2 = a.r == (aEc(), TDc); + g = f2 ? Qec : Pec; + for (c2 = new Anb(a.i.b); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 30); + _mb(b.a, g); + d6b(a.a, sgb(b.p), b.a); + } + } + function zed(a, b, c2) { + var d, e, f2, g; + f2 = (!b.a && (b.a = new C5d(J4, b, 10, 11)), b.a).i; + for (e = new dMd((!b.a && (b.a = new C5d(J4, b, 10, 11)), b.a)); e.e != e.i.gc(); ) { + d = RD(bMd(e), 27); + (!d.a && (d.a = new C5d(J4, d, 10, 11)), d.a).i == 0 || (f2 += zed(a, d, false)); + } + if (c2) { + g = vCd(b); + while (g) { + f2 += (!g.a && (g.a = new C5d(J4, g, 10, 11)), g.a).i; + g = vCd(g); + } + } + return f2; + } + function vLd(a, b) { + var c2, d, e, f2; + if (a.Pj()) { + d = null; + e = a.Qj(); + a.Tj() && (d = a.Vj(a.$i(b), null)); + c2 = a.Ij(4, f2 = THd(a, b), null, b, e); + if (a.Mj() && f2 != null) { + d = a.Oj(f2, d); + if (!d) { + a.Jj(c2); + } else { + d.nj(c2); + d.oj(); + } + } else { + if (!d) { + a.Jj(c2); + } else { + d.nj(c2); + d.oj(); + } + } + return f2; + } else { + f2 = THd(a, b); + if (a.Mj() && f2 != null) { + d = a.Oj(f2, null); + !!d && d.oj(); + } + return f2; + } + } + function LNb(a) { + var b, c2, d, e, f2, g, h, i2, j, k; + j = a.a; + b = new _sb(); + i2 = 0; + for (d = new Anb(a.d); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 226); + k = 0; + tvb(c2.b, new ONb()); + for (g = Sub(c2.b, 0); g.b != g.d.c; ) { + f2 = RD(evb(g), 226); + if (b.a._b(f2)) { + e = c2.c; + h = f2.c; + k < h.d + h.a + j && k + e.a + j > h.d && (k = h.d + h.a + j); + } + } + c2.c.d = k; + b.a.zc(c2, b); + i2 = $wnd.Math.max(i2, c2.c.d + c2.c.a); + } + return i2; + } + function ovc() { + ovc = geb; + fvc = new pvc("COMMENTS", 0); + hvc = new pvc("EXTERNAL_PORTS", 1); + ivc = new pvc("HYPEREDGES", 2); + jvc = new pvc("HYPERNODES", 3); + kvc = new pvc("NON_FREE_PORTS", 4); + lvc = new pvc("NORTH_SOUTH_PORTS", 5); + nvc = new pvc(FBe, 6); + evc = new pvc("CENTER_LABELS", 7); + gvc = new pvc("END_LABELS", 8); + mvc = new pvc("PARTITIONS", 9); + } + function PA(a, b, c2, d, e) { + if (d < 0) { + d = EA(a, e, cD(WC(qJ, 1), Nve, 2, 6, [Cwe, Dwe, Ewe, Fwe, Gwe, Hwe, Iwe, Jwe, Kwe, Lwe, Mwe, Nwe]), b); + d < 0 && (d = EA(a, e, cD(WC(qJ, 1), Nve, 2, 6, ["Jan", "Feb", "Mar", "Apr", Gwe, "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"]), b)); + if (d < 0) { + return false; + } + c2.k = d; + return true; + } else if (d > 0) { + c2.k = d - 1; + return true; + } + return false; + } + function RA(a, b, c2, d, e) { + if (d < 0) { + d = EA(a, e, cD(WC(qJ, 1), Nve, 2, 6, [Cwe, Dwe, Ewe, Fwe, Gwe, Hwe, Iwe, Jwe, Kwe, Lwe, Mwe, Nwe]), b); + d < 0 && (d = EA(a, e, cD(WC(qJ, 1), Nve, 2, 6, ["Jan", "Feb", "Mar", "Apr", Gwe, "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"]), b)); + if (d < 0) { + return false; + } + c2.k = d; + return true; + } else if (d > 0) { + c2.k = d - 1; + return true; + } + return false; + } + function TA(a, b, c2, d, e, f2) { + var g, h, i2, j; + h = 32; + if (d < 0) { + if (b[0] >= a.length) { + return false; + } + h = ihb(a, b[0]); + if (h != 43 && h != 45) { + return false; + } + ++b[0]; + d = HA(a, b); + if (d < 0) { + return false; + } + h == 45 && (d = -d); + } + if (h == 32 && b[0] - c2 == 2 && e.b == 2) { + i2 = new uB(); + j = i2.q.getFullYear() - Owe + Owe - 80; + g = j % 100; + f2.a = d == g; + d += (j / 100 | 0) * 100 + (d < g ? 100 : 0); + } + f2.p = d; + return true; + } + function V4b(a, b) { + var c2, d, e, f2, g; + if (!vCd(a)) { + return; + } + g = RD(mQb(b, (yCc(), lBc)), 181); + dE(Gxd(a, BBc)) === dE((Bod(), Aod)) && Ixd(a, BBc, zod); + d = (lud(), new zud(vCd(a))); + f2 = new Fud(!vCd(a) ? null : new zud(vCd(a)), a); + e = GJb(d, f2, false, true); + zsb(g, (Qpd(), Mpd)); + c2 = RD(mQb(b, nBc), 8); + c2.a = $wnd.Math.max(e.a, c2.a); + c2.b = $wnd.Math.max(e.b, c2.b); + } + function cec(a, b, c2) { + var d, e, f2, g, h, i2; + for (g = RD(mQb(a, (Ywc(), lwc)), 15).Kc(); g.Ob(); ) { + f2 = RD(g.Pb(), 10); + switch (RD(mQb(f2, (yCc(), UAc)), 171).g) { + case 2: + g3b(f2, b); + break; + case 4: + g3b(f2, c2); + } + for (e = new is(Mr(W2b(f2).a.Kc(), new ir())); gs(e); ) { + d = RD(hs(e), 18); + if (!!d.c && !!d.d) { + continue; + } + h = !d.d; + i2 = RD(mQb(d, Ewc), 12); + h ? Z0b(d, i2) : Y0b(d, i2); + } + } + } + function epc() { + epc = geb; + Zoc = new fpc(_ye, 0, (qpd(), Yod), Yod); + apc = new fpc(bze, 1, npd, npd); + Yoc = new fpc(aze, 2, Xod, Xod); + dpc = new fpc(cze, 3, ppd, ppd); + _oc = new fpc("NORTH_WEST_CORNER", 4, ppd, Yod); + $oc = new fpc("NORTH_EAST_CORNER", 5, Yod, Xod); + cpc = new fpc("SOUTH_WEST_CORNER", 6, npd, ppd); + bpc = new fpc("SOUTH_EAST_CORNER", 7, Xod, npd); + } + function P2c(a) { + var b, c2, d, e, f2, g; + f2 = new _sb(); + b = new btb((!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a)); + for (e = new is(Mr(zGd(a).a.Kc(), new ir())); gs(e); ) { + d = RD(hs(e), 74); + if (!ZD(QHd((!d.b && (d.b = new Yie(E4, d, 4, 7)), d.b), 0), 193)) { + g = AGd(RD(QHd((!d.c && (d.c = new Yie(E4, d, 5, 8)), d.c), 0), 84)); + b.a._b(g) || (c2 = f2.a.zc(g, f2), c2 == null); + } + } + return f2; + } + function tid() { + tid = geb; + sid = cD(WC(lE, 1), rxe, 28, 14, [1, 1, 2, 6, 24, 120, 720, 5040, 40320, 362880, 3628800, 39916800, 479001600, 6227020800, 87178291200, 1307674368e3, { l: 3506176, m: 794077, h: 1 }, { l: 884736, m: 916411, h: 20 }, { l: 3342336, m: 3912489, h: 363 }, { l: 589824, m: 3034138, h: 6914 }, { l: 3407872, m: 1962506, h: 138294 }]); + $wnd.Math.pow(2, -65); + } + function Ljb() { + Ljb = geb; + var a, b; + Jjb = $C(uJ, Nve, 92, 32, 0, 1); + Kjb = $C(uJ, Nve, 92, 32, 0, 1); + a = 1; + for (b = 0; b <= 18; b++) { + Jjb[b] = (Pib(), Ddb(a, 0) >= 0 ? jjb(a) : Xib(jjb(Odb(a)))); + Kjb[b] = Jdb(Sdb(a, b), 0) ? jjb(Sdb(a, b)) : Xib(jjb(Odb(Sdb(a, b)))); + a = Ndb(a, 5); + } + for (; b < Kjb.length; b++) { + Jjb[b] = Wib(Jjb[b - 1], Jjb[1]); + Kjb[b] = Wib(Kjb[b - 1], (Pib(), Mib)); + } + } + function tgc(a, b) { + var c2, d, e, f2, g; + if (a.c.length == 0) { + return new Ptd(sgb(0), sgb(0)); + } + c2 = (tFb(0, a.c.length), RD(a.c[0], 12)).j; + g = 0; + f2 = b.g; + d = b.g + 1; + while (g < a.c.length - 1 && c2.g < f2) { + ++g; + c2 = (tFb(g, a.c.length), RD(a.c[g], 12)).j; + } + e = g; + while (e < a.c.length - 1 && c2.g < d) { + ++e; + c2 = (tFb(g, a.c.length), RD(a.c[g], 12)).j; + } + return new Ptd(sgb(g), sgb(e)); + } + function NJc(a, b, c2, d) { + var e, f2, g, h, i2, j, k; + i2 = b3b(b, c2); + (c2 == (qpd(), npd) || c2 == ppd) && (i2 = hv(i2)); + g = false; + do { + e = false; + for (f2 = 0; f2 < i2.gc() - 1; f2++) { + j = RD(i2.Xb(f2), 12); + h = RD(i2.Xb(f2 + 1), 12); + if (OJc(a, j, h, d)) { + g = true; + CMc(a.a, RD(i2.Xb(f2), 12), RD(i2.Xb(f2 + 1), 12)); + k = RD(i2.Xb(f2 + 1), 12); + i2.hd(f2 + 1, RD(i2.Xb(f2), 12)); + i2.hd(f2, k); + e = true; + } + } + } while (e); + return g; + } + function lZc(a, b, c2) { + var d, e, f2, g; + c2.Ug(MEe, 1); + e = RD(zDb(CDb(new SDb(null, new Swb(b.b, 16)), new pZc()), tBb(new ZBb(), new XBb(), new wCb(), cD(WC(QL, 1), jwe, 108, 0, [(xBb(), vBb)]))), 15); + mZc(a, e, 0); + for (g = Sub(b.b, 0); g.b != g.d.c; ) { + f2 = RD(evb(g), 40); + d = Wjb(a.a, sgb(f2.g)) != null ? RD(Wjb(a.a, sgb(f2.g)), 17).a : 0; + pQb(f2, (h_c(), f_c), sgb(d)); + } + c2.Vg(); + } + function o3c(a, b, c2) { + var d, e, f2, g, h, i2, j, k; + h = b.i - a.g / 2; + i2 = c2.i - a.g / 2; + j = b.j - a.g / 2; + k = c2.j - a.g / 2; + f2 = b.g + a.g; + g = c2.g + a.g; + d = b.f + a.g; + e = c2.f + a.g; + if (h < i2 + g && i2 < h && j < k + e && k < j) { + return true; + } else if (i2 < h + f2 && h < i2 && k < j + d && j < k) { + return true; + } else if (h < i2 + g && i2 < h && j < k && k < j + d) { + return true; + } else if (i2 < h + f2 && h < i2 && j < k + e && k < j) { + return true; + } + return false; + } + function gdc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m; + f2 = b.c.length; + g = (tFb(c2, b.c.length), RD(b.c[c2], 293)); + h = g.a.o.a; + l = g.c; + m = 0; + for (j = g.c; j <= g.f; j++) { + if (h <= a.a[j]) { + return j; + } + k = a.a[j]; + i2 = null; + for (e = c2 + 1; e < f2; e++) { + d = (tFb(e, b.c.length), RD(b.c[e], 293)); + d.c <= j && d.f >= j && (i2 = d); + } + !!i2 && (k = $wnd.Math.max(k, i2.a.o.a)); + if (k > m) { + l = j; + m = k; + } + } + return l; + } + function SNb(a) { + var b, c2, d, e, f2, g, h; + f2 = new yAb(RD(Qb(new eOb()), 50)); + h = pxe; + for (c2 = new Anb(a.d); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 226); + h = b.c.c; + while (f2.a.gc() != 0) { + g = RD(f2.a.Tc(), 226); + if (g.c.c + g.c.b < h) { + f2.a.Bc(g) != null; + } else { + break; + } + } + for (e = f2.a.ec().Kc(); e.Ob(); ) { + d = RD(e.Pb(), 226); + Mub(d.b, b); + Mub(b.b, d); + } + f2.a.zc(b, (Geb(), Eeb)) == null; + } + } + function sZc(a, b, c2) { + var d, e, f2, g, h; + if (!gr(b)) { + h = c2.eh((ZD(b, 16) ? RD(b, 16).gc() : Kr(b.Kc())) / a.a | 0); + h.Ug(OEe, 1); + g = new vZc(); + f2 = null; + for (e = b.Kc(); e.Ob(); ) { + d = RD(e.Pb(), 40); + g = Al(cD(WC(cJ, 1), rve, 20, 0, [g, new dXc(d)])); + if (f2) { + pQb(f2, (q$c(), l$c), d); + pQb(d, b$c, f2); + if (_Wc(d) == _Wc(f2)) { + pQb(f2, m$c, d); + pQb(d, c$c, f2); + } + } + f2 = d; + } + h.Vg(); + sZc(a, g, c2); + } + } + function z1d(a, b) { + var c2, d, e; + if (b == null) { + for (d = (!a.a && (a.a = new C5d(l7, a, 9, 5)), new dMd(a.a)); d.e != d.i.gc(); ) { + c2 = RD(bMd(d), 694); + e = c2.c; + if ((e == null ? c2.zb : e) == null) { + return c2; + } + } + } else { + for (d = (!a.a && (a.a = new C5d(l7, a, 9, 5)), new dMd(a.a)); d.e != d.i.gc(); ) { + c2 = RD(bMd(d), 694); + if (lhb(b, (e = c2.c, e == null ? c2.zb : e))) { + return c2; + } + } + } + return null; + } + function BLb(a, b) { + var c2; + c2 = null; + switch (b.g) { + case 1: + a.e.pf((umd(), Cld)) && (c2 = RD(a.e.of(Cld), 256)); + break; + case 3: + a.e.pf((umd(), Dld)) && (c2 = RD(a.e.of(Dld), 256)); + break; + case 2: + a.e.pf((umd(), Bld)) && (c2 = RD(a.e.of(Bld), 256)); + break; + case 4: + a.e.pf((umd(), Eld)) && (c2 = RD(a.e.of(Eld), 256)); + } + !c2 && (c2 = RD(a.e.of((umd(), zld)), 256)); + return c2; + } + function $5c(a, b, c2) { + var d, e, f2, g, h, i2; + e = c2; + f2 = 0; + for (h = new Anb(b); h.a < h.c.c.length; ) { + g = RD(ynb(h), 27); + Ixd(g, ($4c(), P4c), sgb(e++)); + i2 = Q2c(g); + d = $wnd.Math.atan2(g.j + g.f / 2, g.i + g.g / 2); + d += d < 0 ? dFe : 0; + d < 0.7853981633974483 || d > FFe ? _mb(i2, a.b) : d <= FFe && d > GFe ? _mb(i2, a.d) : d <= GFe && d > HFe ? _mb(i2, a.c) : d <= HFe && _mb(i2, a.a); + f2 = $5c(a, i2, f2); + } + return e; + } + function sTc(a, b, c2, d) { + var e, f2, g, h, i2, j; + e = (d.c + d.a) / 2; + Xub(b.j); + Mub(b.j, e); + Xub(c2.e); + Mub(c2.e, e); + j = new ATc(); + for (h = new Anb(a.f); h.a < h.c.c.length; ) { + f2 = RD(ynb(h), 132); + i2 = f2.a; + uTc(j, b, i2); + uTc(j, c2, i2); + } + for (g = new Anb(a.k); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 132); + i2 = f2.b; + uTc(j, b, i2); + uTc(j, c2, i2); + } + j.b += 2; + j.a += nTc(b, a.q); + j.a += nTc(a.q, c2); + return j; + } + function U_c(a, b, c2) { + var d; + c2.Ug("Processor arrange node", 1); + Heb(TD(mQb(b, (h_c(), G$c)))); + d = RD(Lvb(DDb(CDb(new SDb(null, new Swb(b.b, 16)), new c0c()))), 40); + a.a = RD(mQb(b, g_c), 353); + a.a == (s_c(), q_c) || a.a == p_c ? T_c(a, new mob(cD(WC(Z$, 1), NEe, 40, 0, [d])), c2.eh(1)) : a.a == o_c && S_c(a, new mob(cD(WC(Z$, 1), NEe, 40, 0, [d])), c2.eh(1)); + c2.Vg(); + } + function X7c() { + X7c = geb; + x7c = new mGd((umd(), Dkd), 1.3); + G7c = new mGd(mld, (Geb(), false)); + O7c = new A3b(15); + N7c = new mGd(tld, O7c); + Q7c = new mGd(fmd, 15); + y7c = Kkd; + F7c = kld; + H7c = nld; + I7c = pld; + E7c = ild; + J7c = sld; + P7c = Lld; + U7c = (u7c(), p7c); + T7c = o7c; + W7c = t7c; + V7c = r7c; + M7c = k7c; + L7c = j7c; + K7c = i7c; + S7c = n7c; + B7c = ald; + C7c = bld; + A7c = g7c; + z7c = f7c; + D7c = h7c; + R7c = m7c; + } + function MKb(a) { + var b, c2, d, e, f2, g, h; + c2 = a.i; + b = a.n; + h = c2.d; + a.f == (vLb(), tLb) ? h += (c2.a - a.e.b) / 2 : a.f == sLb && (h += c2.a - a.e.b); + for (e = new Anb(a.d); e.a < e.c.c.length; ) { + d = RD(ynb(e), 187); + g = d.Mf(); + f2 = new pjd(); + f2.b = h; + h += g.b + a.a; + switch (a.b.g) { + case 0: + f2.a = c2.c + b.b; + break; + case 1: + f2.a = c2.c + b.b + (c2.b - g.a) / 2; + break; + case 2: + f2.a = c2.c + c2.b - b.c - g.a; + } + d.Of(f2); + } + } + function OKb(a) { + var b, c2, d, e, f2, g, h; + c2 = a.i; + b = a.n; + h = c2.c; + a.b == (EKb(), BKb) ? h += (c2.b - a.e.a) / 2 : a.b == DKb && (h += c2.b - a.e.a); + for (e = new Anb(a.d); e.a < e.c.c.length; ) { + d = RD(ynb(e), 187); + g = d.Mf(); + f2 = new pjd(); + f2.a = h; + h += g.a + a.a; + switch (a.f.g) { + case 0: + f2.b = c2.d + b.d; + break; + case 1: + f2.b = c2.d + b.d + (c2.a - g.b) / 2; + break; + case 2: + f2.b = c2.d + c2.a - b.a - g.b; + } + d.Of(f2); + } + } + function U7b(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2; + k = c2.a.c; + g = c2.a.c + c2.a.b; + f2 = RD(Wjb(c2.c, b), 468); + n = f2.f; + o2 = f2.a; + i2 = new rjd(k, n); + l = new rjd(g, o2); + e = k; + c2.p || (e += a.c); + e += c2.F + c2.v * a.b; + j = new rjd(e, n); + m = new rjd(e, o2); + zjd(b.a, cD(WC(l3, 1), Nve, 8, 0, [i2, j])); + h = c2.d.a.gc() > 1; + if (h) { + d = new rjd(e, c2.b); + Mub(b.a, d); + } + zjd(b.a, cD(WC(l3, 1), Nve, 8, 0, [m, l])); + } + function TGc(a, b, c2) { + var d, e; + if (b < a.d.b.c.length) { + a.b = RD(Vmb(a.d.b, b), 30); + a.a = RD(Vmb(a.d.b, b - 1), 30); + a.c = b; + } else { + a.a = new R4b(a.d); + a.a.p = b - 1; + Rmb(a.d.b, a.a); + a.b = new R4b(a.d); + a.b.p = b; + Rmb(a.d.b, a.b); + a.c = b; + } + g3b(c2, a.b); + for (e = new is(Mr(Z2b(c2).a.Kc(), new ir())); gs(e); ) { + d = RD(hs(e), 18); + !d.c.i.c && d.c.i.k == (r3b(), n3b) && g3b(d.c.i, a.a); + } + } + function Gpd(a) { + Cgd(a, new Pfd($fd(Xfd(Zfd(Yfd(new agd(), qHe), "ELK Randomizer"), 'Distributes the nodes randomly on the plane, leading to very obfuscating layouts. Can be useful to demonstrate the power of "real" layout algorithms.'), new Jpd()))); + Agd(a, qHe, Eze, Cpd); + Agd(a, qHe, _ze, 15); + Agd(a, qHe, bAe, sgb(0)); + Agd(a, qHe, Dze, Yze); + } + function Gqe() { + Gqe = geb; + var a, b, c2, d, e, f2; + Eqe = $C(gE, YHe, 28, 255, 15, 1); + Fqe = $C(hE, zwe, 28, 16, 15, 1); + for (b = 0; b < 255; b++) { + Eqe[b] = -1; + } + for (c2 = 57; c2 >= 48; c2--) { + Eqe[c2] = c2 - 48 << 24 >> 24; + } + for (d = 70; d >= 65; d--) { + Eqe[d] = d - 65 + 10 << 24 >> 24; + } + for (e = 102; e >= 97; e--) { + Eqe[e] = e - 97 + 10 << 24 >> 24; + } + for (f2 = 0; f2 < 10; f2++) + Fqe[f2] = 48 + f2 & Bwe; + for (a = 10; a <= 15; a++) + Fqe[a] = 65 + a - 10 & Bwe; + } + function yYc(a, b) { + b.Ug("Process graph bounds", 1); + pQb(a, (q$c(), ZZc), Uvb(TCb(HDb(new SDb(null, new Swb(a.b, 16)), new DYc())))); + pQb(a, _Zc, Uvb(TCb(HDb(new SDb(null, new Swb(a.b, 16)), new FYc())))); + pQb(a, YZc, Uvb(SCb(HDb(new SDb(null, new Swb(a.b, 16)), new HYc())))); + pQb(a, $Zc, Uvb(SCb(HDb(new SDb(null, new Swb(a.b, 16)), new JYc())))); + b.Vg(); + } + function PWb(a) { + var b, c2, d, e, f2; + e = RD(mQb(a, (yCc(), lBc)), 21); + f2 = RD(mQb(a, oBc), 21); + c2 = new rjd(a.f.a + a.d.b + a.d.c, a.f.b + a.d.d + a.d.a); + b = new sjd(c2); + if (e.Hc((Qpd(), Mpd))) { + d = RD(mQb(a, nBc), 8); + if (f2.Hc((dqd(), Ypd))) { + d.a <= 0 && (d.a = 20); + d.b <= 0 && (d.b = 20); + } + b.a = $wnd.Math.max(c2.a, d.a); + b.b = $wnd.Math.max(c2.b, d.b); + } + Heb(TD(mQb(a, mBc))) || QWb(a, c2, b); + } + function lOc(a, b) { + var c2, d, e, f2; + for (f2 = b3b(b, (qpd(), npd)).Kc(); f2.Ob(); ) { + d = RD(f2.Pb(), 12); + c2 = RD(mQb(d, (Ywc(), Iwc)), 10); + !!c2 && rIb(uIb(tIb(vIb(sIb(new wIb(), 0), 0.1), a.i[b.p].d), a.i[c2.p].a)); + } + for (e = b3b(b, Yod).Kc(); e.Ob(); ) { + d = RD(e.Pb(), 12); + c2 = RD(mQb(d, (Ywc(), Iwc)), 10); + !!c2 && rIb(uIb(tIb(vIb(sIb(new wIb(), 0), 0.1), a.i[c2.p].d), a.i[b.p].a)); + } + } + function oYd(a) { + var b, c2, d, e, f2, g; + if (!a.c) { + g = new W$d(); + b = iYd; + f2 = b.a.zc(a, b); + if (f2 == null) { + for (d = new dMd(tYd(a)); d.e != d.i.gc(); ) { + c2 = RD(bMd(d), 89); + e = i2d(c2); + ZD(e, 90) && YGd(g, oYd(RD(e, 29))); + WGd(g, c2); + } + b.a.Bc(a) != null; + b.a.gc() == 0 && void 0; + } + T$d(g); + VHd(g); + a.c = new N$d((RD(QHd(xYd((lTd(), kTd).o), 15), 19), g.i), g.g); + yYd(a).b &= -33; + } + return a.c; + } + function Dre(a) { + var b; + if (a.c != 10) + throw Adb(new Lqe(TId((Hde(), VIe)))); + b = a.a; + switch (b) { + case 110: + b = 10; + break; + case 114: + b = 13; + break; + case 116: + b = 9; + break; + case 92: + case 124: + case 46: + case 94: + case 45: + case 63: + case 42: + case 43: + case 123: + case 125: + case 40: + case 41: + case 91: + case 93: + break; + default: + throw Adb(new Lqe(TId((Hde(), xJe)))); + } + return b; + } + function GD(a) { + var b, c2, d, e, f2; + if (a.l == 0 && a.m == 0 && a.h == 0) { + return "0"; + } + if (a.h == fxe && a.m == 0 && a.l == 0) { + return "-9223372036854775808"; + } + if (a.h >> 19 != 0) { + return "-" + GD(xD(a)); + } + c2 = a; + d = ""; + while (!(c2.l == 0 && c2.m == 0 && c2.h == 0)) { + e = fD(ixe); + c2 = iD(c2, e, true); + b = "" + FD(eD); + if (!(c2.l == 0 && c2.m == 0 && c2.h == 0)) { + f2 = 9 - b.length; + for (; f2 > 0; f2--) { + b = "0" + b; + } + } + d = b + d; + } + return d; + } + function tkc(a) { + var b, c2, d, e, f2, g, h; + b = false; + c2 = 0; + for (e = new Anb(a.d.b); e.a < e.c.c.length; ) { + d = RD(ynb(e), 30); + d.p = c2++; + for (g = new Anb(d.a); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 10); + !b && !gr(W2b(f2)) && (b = true); + } + } + h = ysb((Cmd(), Amd), cD(WC(s3, 1), jwe, 88, 0, [ymd, zmd])); + if (!b) { + zsb(h, Bmd); + zsb(h, xmd); + } + a.a = new dGb(h); + akb(a.f); + akb(a.b); + akb(a.e); + akb(a.g); + } + function Ftb() { + if (!Object.create || !Object.getOwnPropertyNames) { + return false; + } + var a = "__proto__"; + var b = /* @__PURE__ */ Object.create(null); + if (b[a] !== void 0) { + return false; + } + var c2 = Object.getOwnPropertyNames(b); + if (c2.length != 0) { + return false; + } + b[a] = 42; + if (b[a] !== 42) { + return false; + } + if (Object.getOwnPropertyNames(b).length == 0) { + return false; + } + return true; + } + function c_b(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l; + d = c2.c; + e = c2.d; + h = K3b(b.c); + i2 = K3b(b.d); + if (d == b.c) { + h = d_b(a, h, e); + i2 = e_b(b.d); + } else { + h = e_b(b.c); + i2 = d_b(a, i2, e); + } + j = new Fjd(b.a); + Pub(j, h, j.a, j.a.a); + Pub(j, i2, j.c.b, j.c); + g = b.c == d; + l = new E_b(); + for (f2 = 0; f2 < j.b - 1; ++f2) { + k = new Ptd(RD(ju(j, f2), 8), RD(ju(j, f2 + 1), 8)); + g && f2 == 0 || !g && f2 == j.b - 2 ? l.b = k : Rmb(l.a, k); + } + return l; + } + function W1b(a, b) { + var c2, d, e, f2; + f2 = a.j.g - b.j.g; + if (f2 != 0) { + return f2; + } + c2 = RD(mQb(a, (yCc(), CBc)), 17); + d = RD(mQb(b, CBc), 17); + if (!!c2 && !!d) { + e = c2.a - d.a; + if (e != 0) { + return e; + } + } + switch (a.j.g) { + case 1: + return Qfb(a.n.a, b.n.a); + case 2: + return Qfb(a.n.b, b.n.b); + case 3: + return Qfb(b.n.a, a.n.a); + case 4: + return Qfb(b.n.b, a.n.b); + default: + throw Adb(new dgb(UAe)); + } + } + function X9b(a, b, c2, d) { + var e, f2, g, h, i2; + if (Kr((U9b(), new is(Mr(W2b(b).a.Kc(), new ir())))) >= a.a) { + return -1; + } + if (!W9b(b, c2)) { + return -1; + } + if (gr(RD(d.Kb(b), 20))) { + return 1; + } + e = 0; + for (g = RD(d.Kb(b), 20).Kc(); g.Ob(); ) { + f2 = RD(g.Pb(), 18); + i2 = f2.c.i == b ? f2.d.i : f2.c.i; + h = X9b(a, i2, c2, d); + if (h == -1) { + return -1; + } + e = $wnd.Math.max(e, h); + if (e > a.c - 1) { + return -1; + } + } + return e + 1; + } + function _Gd(a, b) { + var c2, d, e, f2, g, h; + if (dE(b) === dE(a)) { + return true; + } + if (!ZD(b, 15)) { + return false; + } + d = RD(b, 15); + h = a.gc(); + if (d.gc() != h) { + return false; + } + g = d.Kc(); + if (a.Yi()) { + for (c2 = 0; c2 < h; ++c2) { + e = a.Vi(c2); + f2 = g.Pb(); + if (e == null ? f2 != null : !pb(e, f2)) { + return false; + } + } + } else { + for (c2 = 0; c2 < h; ++c2) { + e = a.Vi(c2); + f2 = g.Pb(); + if (dE(e) !== dE(f2)) { + return false; + } + } + } + return true; + } + function RNd(a, b) { + var c2, d, e, f2, g, h; + if (a.f > 0) { + a._j(); + if (b != null) { + for (f2 = 0; f2 < a.d.length; ++f2) { + c2 = a.d[f2]; + if (c2) { + d = RD(c2.g, 379); + h = c2.i; + for (g = 0; g < h; ++g) { + e = d[g]; + if (pb(b, e.md())) { + return true; + } + } + } + } + } else { + for (f2 = 0; f2 < a.d.length; ++f2) { + c2 = a.d[f2]; + if (c2) { + d = RD(c2.g, 379); + h = c2.i; + for (g = 0; g < h; ++g) { + e = d[g]; + if (dE(b) === dE(e.md())) { + return true; + } + } + } + } + } + } + return false; + } + function see(a, b) { + var c2, d, e; + c2 = b.qi(a.a); + if (c2) { + e = WD($Nd((!c2.b && (c2.b = new SVd((JTd(), FTd), C8, c2)), c2.b), "affiliation")); + if (e != null) { + d = thb(e, Fhb(35)); + return d == -1 ? Lee(a, Uee(a, BXd(b.qk())), e) : d == 0 ? Lee(a, null, (BFb(1, e.length + 1), e.substr(1))) : Lee(a, (AFb(0, d, e.length), e.substr(0, d)), (BFb(d + 1, e.length + 1), e.substr(d + 1))); + } + } + return null; + } + function v9b(a, b, c2) { + var d, e, f2, g; + c2.Ug("Orthogonally routing hierarchical port edges", 1); + a.a = 0; + d = y9b(b); + B9b(b, d); + A9b(a, b, d); + w9b(b); + e = RD(mQb(b, (yCc(), BBc)), 101); + f2 = b.b; + u9b((tFb(0, f2.c.length), RD(f2.c[0], 30)), e, b); + u9b(RD(Vmb(f2, f2.c.length - 1), 30), e, b); + g = b.b; + s9b((tFb(0, g.c.length), RD(g.c[0], 30))); + s9b(RD(Vmb(g, g.c.length - 1), 30)); + c2.Vg(); + } + function JAd(a) { + switch (a) { + case 48: + case 49: + case 50: + case 51: + case 52: + case 53: + case 54: + case 55: + case 56: + case 57: { + return a - 48 << 24 >> 24; + } + case 97: + case 98: + case 99: + case 100: + case 101: + case 102: { + return a - 97 + 10 << 24 >> 24; + } + case 65: + case 66: + case 67: + case 68: + case 69: + case 70: { + return a - 65 + 10 << 24 >> 24; + } + default: { + throw Adb(new Vgb("Invalid hexadecimal")); + } + } + } + function iIb() { + iIb = geb; + hIb = new jIb("SPIRAL", 0); + cIb = new jIb("LINE_BY_LINE", 1); + dIb = new jIb("MANHATTAN", 2); + bIb = new jIb("JITTER", 3); + fIb = new jIb("QUADRANTS_LINE_BY_LINE", 4); + gIb = new jIb("QUADRANTS_MANHATTAN", 5); + eIb = new jIb("QUADRANTS_JITTER", 6); + aIb = new jIb("COMBINE_LINE_BY_LINE_MANHATTAN", 7); + _Hb = new jIb("COMBINE_JITTER_MANHATTAN", 8); + } + function Urc(a, b, c2, d) { + var e, f2, g, h, i2, j; + i2 = Zrc(a, c2); + j = Zrc(b, c2); + e = false; + while (!!i2 && !!j) { + if (d || Xrc(i2, j, c2)) { + g = Zrc(i2, c2); + h = Zrc(j, c2); + asc(b); + asc(a); + f2 = i2.c; + Hec(i2, false); + Hec(j, false); + if (c2) { + f3b(b, j.p, f2); + b.p = j.p; + f3b(a, i2.p + 1, f2); + a.p = i2.p; + } else { + f3b(a, i2.p, f2); + a.p = i2.p; + f3b(b, j.p + 1, f2); + b.p = j.p; + } + g3b(i2, null); + g3b(j, null); + i2 = g; + j = h; + e = true; + } else { + break; + } + } + return e; + } + function aDc(a) { + switch (a.g) { + case 0: + return new XHc(); + case 1: + return new pHc(); + case 3: + return new GGc(); + case 4: + return new gHc(); + case 5: + return new jIc(); + case 6: + return new IHc(); + case 2: + return new xHc(); + case 7: + return new pGc(); + case 8: + return new YGc(); + default: + throw Adb(new agb("No implementation is available for the layerer " + (a.f != null ? a.f : "" + a.g))); + } + } + function tIc(a, b, c2, d) { + var e, f2, g, h, i2; + e = false; + f2 = false; + for (h = new Anb(d.j); h.a < h.c.c.length; ) { + g = RD(ynb(h), 12); + dE(mQb(g, (Ywc(), Awc))) === dE(c2) && (g.g.c.length == 0 ? g.e.c.length == 0 || (e = true) : f2 = true); + } + i2 = 0; + e && e ^ f2 ? i2 = c2.j == (qpd(), Yod) ? -a.e[d.c.p][d.p] : b - a.e[d.c.p][d.p] : f2 && e ^ f2 ? i2 = a.e[d.c.p][d.p] + 1 : e && f2 && (i2 = c2.j == (qpd(), Yod) ? 0 : b / 2); + return i2; + } + function lSd(a, b, c2, d, e, f2, g, h) { + var i2, j, k; + i2 = 0; + b != null && (i2 ^= ohb(b.toLowerCase())); + c2 != null && (i2 ^= ohb(c2)); + d != null && (i2 ^= ohb(d)); + g != null && (i2 ^= ohb(g)); + h != null && (i2 ^= ohb(h)); + for (j = 0, k = f2.length; j < k; j++) { + i2 ^= ohb(f2[j]); + } + a ? i2 |= 256 : i2 &= -257; + e ? i2 |= 16 : i2 &= -17; + this.f = i2; + this.i = b == null ? null : (uFb(b), b); + this.a = c2; + this.d = d; + this.j = f2; + this.g = g; + this.e = h; + } + function d3b(a, b, c2) { + var d, e; + e = null; + switch (b.g) { + case 1: + e = (J3b(), E3b); + break; + case 2: + e = (J3b(), G3b); + } + d = null; + switch (c2.g) { + case 1: + d = (J3b(), F3b); + break; + case 2: + d = (J3b(), D3b); + break; + case 3: + d = (J3b(), H3b); + break; + case 4: + d = (J3b(), I3b); + } + return !!e && !!d ? dr(a.j, new Yb(new mob(cD(WC(pE, 1), rve, 178, 0, [RD(Qb(e), 178), RD(Qb(d), 178)])))) : (yob(), yob(), vob); + } + function K8b(a) { + var b, c2, d; + b = RD(mQb(a, (yCc(), nBc)), 8); + pQb(a, nBc, new rjd(b.b, b.a)); + switch (RD(mQb(a, Rzc), 255).g) { + case 1: + pQb(a, Rzc, (Rjd(), Qjd)); + break; + case 2: + pQb(a, Rzc, (Rjd(), Mjd)); + break; + case 3: + pQb(a, Rzc, (Rjd(), Ojd)); + break; + case 4: + pQb(a, Rzc, (Rjd(), Pjd)); + } + if ((!a.q ? (yob(), yob(), wob) : a.q)._b(IBc)) { + c2 = RD(mQb(a, IBc), 8); + d = c2.a; + c2.a = c2.b; + c2.b = d; + } + } + function Pmc(a, b, c2, d, e, f2) { + this.b = c2; + this.d = e; + if (a >= b.length) { + throw Adb(new veb("Greedy SwitchDecider: Free layer not in graph.")); + } + this.c = b[a]; + this.e = new DMc(d); + rMc(this.e, this.c, (qpd(), ppd)); + this.i = new DMc(d); + rMc(this.i, this.c, Xod); + this.f = new Kmc(this.c); + this.a = !f2 && e.i && !e.s && this.c[0].k == (r3b(), m3b); + this.a && Nmc(this, a, b.length); + } + function $Mb(a, b) { + var c2, d, e, f2, g, h; + f2 = !a.B.Hc((dqd(), Wpd)); + g = a.B.Hc(Zpd); + a.a = new wKb(g, f2, a.c); + !!a.n && C2b(a.a.n, a.n); + cLb(a.g, (ZJb(), XJb), a.a); + if (!b) { + d = new dLb(1, f2, a.c); + d.n.a = a.k; + Wrb(a.p, (qpd(), Yod), d); + e = new dLb(1, f2, a.c); + e.n.d = a.k; + Wrb(a.p, npd, e); + h = new dLb(0, f2, a.c); + h.n.c = a.k; + Wrb(a.p, ppd, h); + c2 = new dLb(0, f2, a.c); + c2.n.b = a.k; + Wrb(a.p, Xod, c2); + } + } + function zkc(a) { + var b, c2, d; + b = RD(mQb(a.d, (yCc(), yAc)), 223); + switch (b.g) { + case 2: + c2 = rkc(a); + break; + case 3: + c2 = (d = new bnb(), FDb(CDb(GDb(EDb(EDb(new SDb(null, new Swb(a.d.b, 16)), new wlc()), new ylc()), new Alc()), new Kkc()), new Clc(d)), d); + break; + default: + throw Adb(new dgb("Compaction not supported for " + b + " edges.")); + } + ykc(a, c2); + xgb(new Xkb(a.g), new ilc(a)); + } + function qYc(a, b) { + var c2, d, e, f2, g, h, i2; + b.Ug("Process directions", 1); + c2 = RD(mQb(a, (h_c(), H$c)), 88); + if (c2 != (Cmd(), xmd)) { + for (e = Sub(a.b, 0); e.b != e.d.c; ) { + d = RD(evb(e), 40); + h = RD(mQb(d, (q$c(), o$c)), 17).a; + i2 = RD(mQb(d, p$c), 17).a; + switch (c2.g) { + case 4: + i2 *= -1; + break; + case 1: + f2 = h; + h = i2; + i2 = f2; + break; + case 2: + g = h; + h = -i2; + i2 = g; + } + pQb(d, o$c, sgb(h)); + pQb(d, p$c, sgb(i2)); + } + } + b.Vg(); + } + function led(a, b) { + var c2; + c2 = new qQb(); + !!b && kQb(c2, RD(Wjb(a.a, H4), 96)); + ZD(b, 422) && kQb(c2, RD(Wjb(a.a, L4), 96)); + if (ZD(b, 366)) { + kQb(c2, RD(Wjb(a.a, I4), 96)); + return c2; + } + ZD(b, 84) && kQb(c2, RD(Wjb(a.a, E4), 96)); + if (ZD(b, 207)) { + kQb(c2, RD(Wjb(a.a, J4), 96)); + return c2; + } + if (ZD(b, 193)) { + kQb(c2, RD(Wjb(a.a, K4), 96)); + return c2; + } + ZD(b, 326) && kQb(c2, RD(Wjb(a.a, G4), 96)); + return c2; + } + function a_b(a) { + var b, c2, d, e, f2, g, h, i2; + i2 = new m_b(); + for (h = new Anb(a.a); h.a < h.c.c.length; ) { + g = RD(ynb(h), 10); + if (g.k == (r3b(), m3b)) { + continue; + } + $$b(i2, g, new pjd()); + for (f2 = new is(Mr(a3b(g).a.Kc(), new ir())); gs(f2); ) { + e = RD(hs(f2), 18); + if (e.c.i.k == m3b || e.d.i.k == m3b) { + continue; + } + for (d = Sub(e.a, 0); d.b != d.d.c; ) { + c2 = RD(evb(d), 8); + b = c2; + k_b(i2, new eZb(b.a, b.b)); + } + } + } + return i2; + } + function Kcd() { + Kcd = geb; + Jcd = new jGd(iGe); + Icd = (_cd(), $cd); + Hcd = new lGd(nGe, Icd); + Gcd = (ldd(), kdd); + Fcd = new lGd(jGe, Gcd); + Ecd = (Xbd(), Tbd); + Dcd = new lGd(kGe, Ecd); + zcd = new lGd(lGe, null); + Ccd = (Mbd(), Kbd); + Bcd = new lGd(mGe, Ccd); + vcd = (sbd(), rbd); + ucd = new lGd(oGe, vcd); + wcd = new lGd(pGe, (Geb(), false)); + xcd = new lGd(qGe, sgb(64)); + ycd = new lGd(rGe, true); + Acd = Lbd; + } + function eHc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l; + a.p = 1; + e = a.c; + l = new Iub(); + for (k = c3b(a, (BEc(), zEc)).Kc(); k.Ob(); ) { + j = RD(k.Pb(), 12); + for (d = new Anb(j.g); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 18); + i2 = c2.d.i; + if (a != i2) { + f2 = i2.c; + if (f2.p <= e.p) { + g = e.p + 1; + if (g == b.b.c.length) { + h = new R4b(b); + h.p = g; + Rmb(b.b, h); + g3b(i2, h); + } else { + h = RD(Vmb(b.b, g), 30); + g3b(i2, h); + } + l.a.zc(i2, l); + } + } + } + } + return l; + } + function mXc(a, b) { + var c2, d; + c2 = RD(mQb(a, (q$c(), TZc)), 15); + if (!c2 || c2.gc() < 1) { + return null; + } else if (c2.gc() == 1) { + return RD(c2.Xb(0), 40); + } + d = null; + switch (b.g) { + case 2: + d = RD(Lvb(KDb(c2.Oc(), new mYc())), 40); + break; + case 1: + d = RD(Lvb(JDb(c2.Oc(), new KXc())), 40); + break; + case 4: + d = RD(Lvb(KDb(c2.Oc(), new OXc())), 40); + break; + case 3: + d = RD(Lvb(JDb(c2.Oc(), new SXc())), 40); + } + return d; + } + function usc(a) { + var b, c2, d, e, f2, g; + if (a.a != null) { + return; + } + a.a = $C(xdb, Hye, 28, a.c.b.c.length, 16, 1); + a.a[0] = false; + if (nQb(a.c, (yCc(), wCc))) { + d = RD(mQb(a.c, wCc), 15); + for (c2 = d.Kc(); c2.Ob(); ) { + b = RD(c2.Pb(), 17).a; + b > 0 && b < a.a.length && (a.a[b] = false); + } + } else { + g = new Anb(a.c.b); + g.a < g.c.c.length && ynb(g); + e = 1; + while (g.a < g.c.c.length) { + f2 = RD(ynb(g), 30); + a.a[e++] = xsc(f2); + } + } + } + function X6c() { + X6c = geb; + M6c = new jGd("additionalHeight"); + N6c = new jGd("drawingHeight"); + O6c = new jGd("drawingWidth"); + R6c = new jGd("minHeight"); + U6c = new jGd("minWidth"); + V6c = new jGd("rows"); + W6c = new jGd("targetWidth"); + T6c = new kGd("minRowIncrease", 0); + Q6c = new kGd("maxRowIncrease", 0); + S6c = new kGd("minRowDecrease", 0); + P6c = new kGd("maxRowDecrease", 0); + } + function r$d(a, b) { + var c2, d, e, f2; + e = a.b; + switch (b) { + case 1: { + a.b |= 1; + a.b |= 4; + a.b |= 8; + break; + } + case 2: { + a.b |= 2; + a.b |= 4; + a.b |= 8; + break; + } + case 4: { + a.b |= 1; + a.b |= 2; + a.b |= 4; + a.b |= 8; + break; + } + case 3: { + a.b |= 16; + a.b |= 8; + break; + } + case 0: { + a.b |= 32; + a.b |= 16; + a.b |= 8; + a.b |= 1; + a.b |= 2; + a.b |= 4; + break; + } + } + if (a.b != e && !!a.c) { + for (d = new dMd(a.c); d.e != d.i.gc(); ) { + f2 = RD(bMd(d), 482); + c2 = yYd(f2); + v$d(c2, b); + } + } + } + function CKc(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m, n, o2; + e = false; + for (g = b, h = 0, i2 = g.length; h < i2; ++h) { + f2 = g[h]; + Heb((Geb(), f2.e ? true : false)) && !RD(Vmb(a.b, f2.e.p), 219).s && (e = e | (j = f2.e, k = RD(Vmb(a.b, j.p), 219), l = k.e, m = qKc(c2, l.length), n = l[m][0], n.k == (r3b(), m3b) ? l[m] = AKc(f2, l[m], c2 ? (qpd(), ppd) : (qpd(), Xod)) : k.c.mg(l, c2), o2 = DKc(a, k, c2, d), BKc(k.e, k.o, c2), o2)); + } + return e; + } + function Aed(a, b) { + var c2, d, e, f2, g; + f2 = (!b.a && (b.a = new C5d(J4, b, 10, 11)), b.a).i; + for (e = new dMd((!b.a && (b.a = new C5d(J4, b, 10, 11)), b.a)); e.e != e.i.gc(); ) { + d = RD(bMd(e), 27); + if (dE(Gxd(d, (umd(), Xkd))) !== dE((Fnd(), End))) { + g = RD(Gxd(b, Tld), 143); + c2 = RD(Gxd(d, Tld), 143); + (g == c2 || !!g && Nfd(g, c2)) && (!d.a && (d.a = new C5d(J4, d, 10, 11)), d.a).i != 0 && (f2 += Aed(a, d)); + } + } + return f2; + } + function Toc(a) { + var b, c2, d, e, f2, g, h; + d = 0; + h = 0; + for (g = new Anb(a.d); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 105); + e = RD(zDb(CDb(new SDb(null, new Swb(f2.j, 16)), new Cpc()), tBb(new ZBb(), new XBb(), new wCb(), cD(WC(QL, 1), jwe, 108, 0, [(xBb(), vBb)]))), 15); + c2 = null; + if (d <= h) { + c2 = (qpd(), Yod); + d += e.gc(); + } else if (h < d) { + c2 = (qpd(), npd); + h += e.gc(); + } + b = c2; + FDb(GDb(e.Oc(), new qpc()), new spc(b)); + } + } + function D6b(a) { + var b, c2, d, e, f2; + f2 = new cnb(a.a.c.length); + for (e = new Anb(a.a); e.a < e.c.c.length; ) { + d = RD(ynb(e), 10); + c2 = RD(mQb(d, (yCc(), UAc)), 171); + b = null; + switch (c2.g) { + case 1: + case 2: + b = (huc(), guc); + break; + case 3: + case 4: + b = (huc(), euc); + } + if (b) { + pQb(d, (Ywc(), bwc), (huc(), guc)); + b == euc ? F6b(d, c2, (BEc(), yEc)) : b == guc && F6b(d, c2, (BEc(), zEc)); + } else { + ZEb(f2.c, d); + } + } + return f2; + } + function Snc(a) { + var b, c2, d, e, f2, g, h, i2; + a.b = new hj(new mob((qpd(), cD(WC(E3, 1), NAe, 64, 0, [opd, Yod, Xod, npd, ppd]))), new mob((joc(), cD(WC(UV, 1), jwe, 372, 0, [ioc, hoc, goc])))); + for (g = cD(WC(E3, 1), NAe, 64, 0, [opd, Yod, Xod, npd, ppd]), h = 0, i2 = g.length; h < i2; ++h) { + f2 = g[h]; + for (c2 = cD(WC(UV, 1), jwe, 372, 0, [ioc, hoc, goc]), d = 0, e = c2.length; d < e; ++d) { + b = c2[d]; + aj(a.b, f2, b, new bnb()); + } + } + } + function BMb(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l; + g = RD(RD(Qc(a.r, b), 21), 87); + h = a.u.Hc((Pod(), Nod)); + c2 = a.u.Hc(Kod); + d = a.u.Hc(Jod); + j = a.u.Hc(Ood); + l = a.B.Hc((dqd(), cqd)); + k = !c2 && !d && (j || g.gc() == 2); + yMb(a, b); + e = null; + i2 = null; + if (h) { + f2 = g.Kc(); + e = RD(f2.Pb(), 117); + i2 = e; + while (f2.Ob()) { + i2 = RD(f2.Pb(), 117); + } + e.d.b = 0; + i2.d.c = 0; + k && !e.a && (e.d.c = 0); + } + if (l) { + CMb(g); + if (h) { + e.d.b = 0; + i2.d.c = 0; + } + } + } + function JNb(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l; + g = RD(RD(Qc(a.r, b), 21), 87); + h = a.u.Hc((Pod(), Nod)); + c2 = a.u.Hc(Kod); + d = a.u.Hc(Jod); + i2 = a.u.Hc(Ood); + l = a.B.Hc((dqd(), cqd)); + j = !c2 && !d && (i2 || g.gc() == 2); + HNb(a, b); + k = null; + e = null; + if (h) { + f2 = g.Kc(); + k = RD(f2.Pb(), 117); + e = k; + while (f2.Ob()) { + e = RD(f2.Pb(), 117); + } + k.d.d = 0; + e.d.a = 0; + j && !k.a && (k.d.a = 0); + } + if (l) { + KNb(g); + if (h) { + k.d.d = 0; + e.d.a = 0; + } + } + } + function ONc(a, b, c2) { + var d, e, f2, g, h, i2, j, k; + e = b.k; + if (b.p >= 0) { + return false; + } else { + b.p = c2.b; + Rmb(c2.e, b); + } + if (e == (r3b(), o3b) || e == q3b) { + for (g = new Anb(b.j); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 12); + for (k = (d = new Anb(new _3b(f2).a.g), new c4b(d)); xnb(k.a); ) { + j = RD(ynb(k.a), 18).d; + h = j.i; + i2 = h.k; + if (b.c != h.c) { + if (i2 == o3b || i2 == q3b) { + if (ONc(a, h, c2)) { + return true; + } + } + } + } + } + } + return true; + } + function GWd(a) { + var b; + if ((a.Db & 64) != 0) + return cWd(a); + b = new Shb(cWd(a)); + b.a += " (changeable: "; + Ohb(b, (a.Bb & gwe) != 0); + b.a += ", volatile: "; + Ohb(b, (a.Bb & cKe) != 0); + b.a += ", transient: "; + Ohb(b, (a.Bb & qxe) != 0); + b.a += ", defaultValueLiteral: "; + Nhb(b, a.j); + b.a += ", unsettable: "; + Ohb(b, (a.Bb & bKe) != 0); + b.a += ", derived: "; + Ohb(b, (a.Bb & Ove) != 0); + b.a += ")"; + return b.a; + } + function tee(a, b) { + var c2, d, e, f2, g; + e = b.qi(a.a); + if (e) { + d = (!e.b && (e.b = new SVd((JTd(), FTd), C8, e)), e.b); + c2 = WD($Nd(d, DKe)); + if (c2 != null) { + f2 = c2.lastIndexOf("#"); + g = f2 == -1 ? Wee(a, b.jk(), c2) : f2 == 0 ? Vee(a, null, (BFb(1, c2.length + 1), c2.substr(1))) : Vee(a, (AFb(0, f2, c2.length), c2.substr(0, f2)), (BFb(f2 + 1, c2.length + 1), c2.substr(f2 + 1))); + if (ZD(g, 156)) { + return RD(g, 156); + } + } + } + return null; + } + function xee(a, b) { + var c2, d, e, f2, g; + d = b.qi(a.a); + if (d) { + c2 = (!d.b && (d.b = new SVd((JTd(), FTd), C8, d)), d.b); + f2 = WD($Nd(c2, $Ke)); + if (f2 != null) { + e = f2.lastIndexOf("#"); + g = e == -1 ? Wee(a, b.jk(), f2) : e == 0 ? Vee(a, null, (BFb(1, f2.length + 1), f2.substr(1))) : Vee(a, (AFb(0, e, f2.length), f2.substr(0, e)), (BFb(e + 1, f2.length + 1), f2.substr(e + 1))); + if (ZD(g, 156)) { + return RD(g, 156); + } + } + } + return null; + } + function rRb(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m; + e = XPb(a.d); + g = RD(mQb(a.b, (tSb(), nSb)), 107); + h = g.b + g.c; + i2 = g.d + g.a; + k = e.d.a * a.e + h; + j = e.b.a * a.f + i2; + RRb(a.b, new rjd(k, j)); + for (m = new Anb(a.g); m.a < m.c.c.length; ) { + l = RD(ynb(m), 568); + b = l.g - e.a.a; + c2 = l.i - e.c.a; + d = $id(jjd(new rjd(b, c2), l.a, l.b), ijd(njd(ajd(yRb(l.e)), l.d * l.a, l.c * l.b), -0.5)); + f2 = zRb(l.e); + BRb(l.e, ojd(d, f2)); + } + } + function Xgc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m; + b.Ug("Restoring reversed edges", 1); + for (i2 = new Anb(a.b); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 30); + for (k = new Anb(h.a); k.a < k.c.c.length; ) { + j = RD(ynb(k), 10); + for (m = new Anb(j.j); m.a < m.c.c.length; ) { + l = RD(ynb(m), 12); + g = s2b(l.g); + for (d = g, e = 0, f2 = d.length; e < f2; ++e) { + c2 = d[e]; + Heb(TD(mQb(c2, (Ywc(), Nwc)))) && X0b(c2, false); + } + } + } + } + b.Vg(); + } + function Zpc(a, b, c2, d) { + var e, f2, g, h, i2; + i2 = $C(iE, Nve, 109, (qpd(), cD(WC(E3, 1), NAe, 64, 0, [opd, Yod, Xod, npd, ppd])).length, 0, 2); + for (f2 = cD(WC(E3, 1), NAe, 64, 0, [opd, Yod, Xod, npd, ppd]), g = 0, h = f2.length; g < h; ++g) { + e = f2[g]; + i2[e.g] = $C(iE, vxe, 28, a.c[e.g], 15, 1); + } + _pc(i2, a, Yod); + _pc(i2, a, npd); + Ypc(i2, a, Yod, b, c2, d); + Ypc(i2, a, Xod, b, c2, d); + Ypc(i2, a, npd, b, c2, d); + Ypc(i2, a, ppd, b, c2, d); + return i2; + } + function sLc(a, b, c2) { + if (Ujb(a.a, b)) { + if (Zsb(RD(Wjb(a.a, b), 49), c2)) { + return 1; + } + } else { + Zjb(a.a, b, new _sb()); + } + if (Ujb(a.a, c2)) { + if (Zsb(RD(Wjb(a.a, c2), 49), b)) { + return -1; + } + } else { + Zjb(a.a, c2, new _sb()); + } + if (Ujb(a.b, b)) { + if (Zsb(RD(Wjb(a.b, b), 49), c2)) { + return -1; + } + } else { + Zjb(a.b, b, new _sb()); + } + if (Ujb(a.b, c2)) { + if (Zsb(RD(Wjb(a.b, c2), 49), b)) { + return 1; + } + } else { + Zjb(a.b, c2, new _sb()); + } + return 0; + } + function tMb(a) { + var b, c2, d, e, f2, g; + if (a.q == (Bod(), xod) || a.q == wod) { + return; + } + e = a.f.n.d + SJb(RD(Vrb(a.b, (qpd(), Yod)), 127)) + a.c; + b = a.f.n.a + SJb(RD(Vrb(a.b, npd), 127)) + a.c; + d = RD(Vrb(a.b, Xod), 127); + g = RD(Vrb(a.b, ppd), 127); + f2 = $wnd.Math.max(0, d.n.d - e); + f2 = $wnd.Math.max(f2, g.n.d - e); + c2 = $wnd.Math.max(0, d.n.a - b); + c2 = $wnd.Math.max(c2, g.n.a - b); + d.n.d = f2; + g.n.d = f2; + d.n.a = c2; + g.n.a = c2; + } + function Xfe(a, b, c2, d) { + var e, f2, g, h, i2, j; + if (c2 == null) { + e = RD(a.g, 124); + for (h = 0; h < a.i; ++h) { + g = e[h]; + if (g.Lk() == b) { + return rLd(a, g, d); + } + } + } + f2 = (nke(), RD(b, 69).xk() ? RD(c2, 76) : oke(b, c2)); + if (Mvd(a.e)) { + j = !pge(a, b); + d = qLd(a, f2, d); + i2 = b.Jk() ? fge(a, 3, b, null, c2, kge(a, b, c2, ZD(b, 102) && (RD(b, 19).Bb & txe) != 0), j) : fge(a, 1, b, b.ik(), c2, -1, j); + d ? d.nj(i2) : d = i2; + } else { + d = qLd(a, f2, d); + } + return d; + } + function xgd() { + this.b = new gub(); + this.d = new gub(); + this.e = new gub(); + this.c = new gub(); + this.a = new Tsb(); + this.f = new Tsb(); + HId(l3, new Igd(), new Kgd()); + HId(k3, new ehd(), new ghd()); + HId(h3, new ihd(), new khd()); + HId(i3, new mhd(), new ohd()); + HId(l4, new qhd(), new shd()); + HId(VJ, new Mgd(), new Ogd()); + HId(PK, new Qgd(), new Sgd()); + HId(BK, new Ugd(), new Wgd()); + HId(MK, new Ygd(), new $gd()); + HId(DL, new ahd(), new chd()); + } + function hc(a, b) { + var c2, d, e, f2, g; + a = a == null ? vve : (uFb(a), a); + for (e = 0; e < b.length; e++) { + b[e] = ic(b[e]); + } + c2 = new cib(); + g = 0; + d = 0; + while (d < b.length) { + f2 = a.indexOf("%s", g); + if (f2 == -1) { + break; + } + c2.a += "" + zhb(a == null ? vve : (uFb(a), a), g, f2); + Yhb(c2, b[d++]); + g = f2 + 2; + } + Xhb(c2, a, g, a.length); + if (d < b.length) { + c2.a += " ["; + Yhb(c2, b[d++]); + while (d < b.length) { + c2.a += pve; + Yhb(c2, b[d++]); + } + c2.a += "]"; + } + return c2.a; + } + function kMc(a, b) { + var c2, d, e, f2, g, h, i2; + c2 = 0; + for (i2 = new Anb(b); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 12); + $Lc(a.b, a.d[h.p]); + g = 0; + for (e = new l4b(h.b); xnb(e.a) || xnb(e.b); ) { + d = RD(xnb(e.a) ? ynb(e.a) : ynb(e.b), 18); + if (uMc(d)) { + f2 = AMc(a, h == d.c ? d.d : d.c); + if (f2 > a.d[h.p]) { + c2 += ZLc(a.b, f2); + hmb(a.a, sgb(f2)); + } + } else { + ++g; + } + } + c2 += a.b.d * g; + while (!nmb(a.a)) { + XLc(a.b, RD(smb(a.a), 17).a); + } + } + return c2; + } + function pje(a) { + var b, c2, d, e, f2, g; + f2 = 0; + b = WVd(a); + !!b.kk() && (f2 |= 4); + (a.Bb & bKe) != 0 && (f2 |= 2); + if (ZD(a, 102)) { + c2 = RD(a, 19); + e = Z5d(c2); + (c2.Bb & QHe) != 0 && (f2 |= 32); + if (e) { + AYd(uWd(e)); + f2 |= 8; + g = e.t; + (g > 1 || g == -1) && (f2 |= 16); + (e.Bb & QHe) != 0 && (f2 |= 64); + } + (c2.Bb & txe) != 0 && (f2 |= cKe); + f2 |= gwe; + } else { + if (ZD(b, 469)) { + f2 |= 512; + } else { + d = b.kk(); + !!d && (d.i & 1) != 0 && (f2 |= 256); + } + } + (a.Bb & 512) != 0 && (f2 |= 128); + return f2; + } + function vke(a, b) { + var c2; + if (a.f == tke) { + c2 = yfe(Qee((lke(), jke), b)); + return a.e ? c2 == 4 && b != (Lle(), Jle) && b != (Lle(), Gle) && b != (Lle(), Hle) && b != (Lle(), Ile) : c2 == 2; + } + if (!!a.d && (a.d.Hc(b) || a.d.Hc(zfe(Qee((lke(), jke), b))) || a.d.Hc(Eee((lke(), jke), a.b, b)))) { + return true; + } + if (a.f) { + if (Xee((lke(), a.f), Bfe(Qee(jke, b)))) { + c2 = yfe(Qee(jke, b)); + return a.e ? c2 == 4 : c2 == 2; + } + } + return false; + } + function oKc(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n; + m = -1; + n = 0; + for (j = a, k = 0, l = j.length; k < l; ++k) { + i2 = j[k]; + for (f2 = i2, g = 0, h = f2.length; g < h; ++g) { + e = f2[g]; + b = new urc(m == -1 ? a[0] : a[m], RD(mQb(Y2b(e), (yCc(), cAc)), 284), Bic(e), Heb(TD(mQb(Y2b(e), bAc)))); + for (c2 = 0; c2 < e.j.c.length; c2++) { + for (d = c2 + 1; d < e.j.c.length; d++) { + prc(b, RD(Vmb(e.j, c2), 12), RD(Vmb(e.j, d), 12)) > 0 && ++n; + } + } + } + ++m; + } + return n; + } + function S2c(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l; + g = RD(Gxd(c2, (umd(), Qld)), 8); + i2 = g.a; + k = g.b + a; + e = $wnd.Math.atan2(k, i2); + e < 0 && (e += dFe); + e += b; + e > dFe && (e -= dFe); + h = RD(Gxd(d, Qld), 8); + j = h.a; + l = h.b + a; + f2 = $wnd.Math.atan2(l, j); + f2 < 0 && (f2 += dFe); + f2 += b; + f2 > dFe && (f2 -= dFe); + return Zy(), bz(1e-10), $wnd.Math.abs(e - f2) <= 1e-10 || e == f2 || isNaN(e) && isNaN(f2) ? 0 : e < f2 ? -1 : e > f2 ? 1 : cz(isNaN(e), isNaN(f2)); + } + function PGb(a) { + var b, c2, d, e, f2, g, h; + h = new Tsb(); + for (d = new Anb(a.a.b); d.a < d.c.c.length; ) { + b = RD(ynb(d), 60); + Zjb(h, b, new bnb()); + } + for (e = new Anb(a.a.b); e.a < e.c.c.length; ) { + b = RD(ynb(e), 60); + b.i = pxe; + for (g = b.c.Kc(); g.Ob(); ) { + f2 = RD(g.Pb(), 60); + RD(Wd(qtb(h.f, f2)), 15).Fc(b); + } + } + for (c2 = new Anb(a.a.b); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 60); + b.c.$b(); + b.c = RD(Wd(qtb(h.f, b)), 15); + } + HGb(a); + } + function AYb(a) { + var b, c2, d, e, f2, g, h; + h = new Tsb(); + for (d = new Anb(a.a.b); d.a < d.c.c.length; ) { + b = RD(ynb(d), 86); + Zjb(h, b, new bnb()); + } + for (e = new Anb(a.a.b); e.a < e.c.c.length; ) { + b = RD(ynb(e), 86); + b.o = pxe; + for (g = b.f.Kc(); g.Ob(); ) { + f2 = RD(g.Pb(), 86); + RD(Wd(qtb(h.f, f2)), 15).Fc(b); + } + } + for (c2 = new Anb(a.a.b); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 86); + b.f.$b(); + b.f = RD(Wd(qtb(h.f, b)), 15); + } + tYb(a); + } + function WPb(a, b, c2, d) { + var e, f2; + VPb(a, b, c2, d); + hQb(b, a.j - b.j + c2); + iQb(b, a.k - b.k + d); + for (f2 = new Anb(b.f); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 334); + switch (e.a.g) { + case 0: + eQb(a, b.g + e.b.a, 0, b.g + e.c.a, b.i - 1); + break; + case 1: + eQb(a, b.g + b.o, b.i + e.b.a, a.o - 1, b.i + e.c.a); + break; + case 2: + eQb(a, b.g + e.b.a, b.i + b.p, b.g + e.c.a, a.p - 1); + break; + default: + eQb(a, 0, b.i + e.b.a, b.g - 1, b.i + e.c.a); + } + } + } + function $ec(a, b) { + var c2, d, e, f2, g, h, i2, j; + f2 = new bnb(); + b.b.c.length = 0; + c2 = RD(zDb(ODb(new SDb(null, new Swb(new Xkb(a.a.b), 1))), tBb(new ZBb(), new XBb(), new wCb(), cD(WC(QL, 1), jwe, 108, 0, [(xBb(), vBb)]))), 15); + for (e = c2.Kc(); e.Ob(); ) { + d = RD(e.Pb(), 17); + g = _5b(a.a, d); + if (g.b != 0) { + h = new R4b(b); + ZEb(f2.c, h); + h.p = d.a; + for (j = Sub(g, 0); j.b != j.d.c; ) { + i2 = RD(evb(j), 10); + g3b(i2, h); + } + } + } + Tmb(b.b, f2); + } + function TPb(b, c2, d, e, f2) { + var g, h, i2; + try { + if (c2 >= b.o) { + throw Adb(new web()); + } + i2 = c2 >> 5; + h = c2 & 31; + g = Sdb(1, Ydb(Sdb(h, 1))); + f2 ? b.n[d][i2] = Rdb(b.n[d][i2], g) : b.n[d][i2] = Cdb(b.n[d][i2], Qdb(g)); + g = Sdb(g, 1); + e ? b.n[d][i2] = Rdb(b.n[d][i2], g) : b.n[d][i2] = Cdb(b.n[d][i2], Qdb(g)); + } catch (a) { + a = zdb(a); + if (ZD(a, 333)) { + throw Adb(new veb(fze + b.o + "*" + b.p + gze + c2 + pve + d + hze)); + } else + throw Adb(a); + } + } + function eMc(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m; + m = new yAb(new PMc(a)); + for (h = cD(WC(jR, 1), WAe, 10, 0, [b, c2]), i2 = 0, j = h.length; i2 < j; ++i2) { + g = h[i2]; + for (l = aMc(g, d).Kc(); l.Ob(); ) { + k = RD(l.Pb(), 12); + for (f2 = new l4b(k.b); xnb(f2.a) || xnb(f2.b); ) { + e = RD(xnb(f2.a) ? ynb(f2.a) : ynb(f2.b), 18); + if (!W0b(e)) { + m.a.zc(k, (Geb(), Eeb)) == null; + uMc(e) && rAb(m, k == e.c ? e.d : e.c); + } + } + } + } + return Qb(m), new dnb(m); + } + function w0c(a, b, c2, d) { + var e, f2, g; + if (b) { + f2 = Kfb(UD(mQb(b, (q$c(), j$c)))) + d; + g = c2 + Kfb(UD(mQb(b, d$c))) / 2; + pQb(b, o$c, sgb(Ydb(Hdb($wnd.Math.round(f2))))); + pQb(b, p$c, sgb(Ydb(Hdb($wnd.Math.round(g))))); + b.d.b == 0 || w0c(a, RD(Hr((e = Sub(new dXc(b).a.d, 0), new gXc(e))), 40), c2 + Kfb(UD(mQb(b, d$c))) + a.b, d + Kfb(UD(mQb(b, g$c)))); + mQb(b, m$c) != null && w0c(a, RD(mQb(b, m$c), 40), c2, d); + } + } + function cdc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m; + i2 = Y2b(b.a); + e = Kfb(UD(mQb(i2, (yCc(), XBc)))) * 2; + k = Kfb(UD(mQb(i2, cCc))); + j = $wnd.Math.max(e, k); + f2 = $C(iE, vxe, 28, b.f - b.c + 1, 15, 1); + d = -j; + c2 = 0; + for (h = b.b.Kc(); h.Ob(); ) { + g = RD(h.Pb(), 10); + d += a.a[g.c.p] + j; + f2[c2++] = d; + } + d += a.a[b.a.c.p] + j; + f2[c2++] = d; + for (m = new Anb(b.e); m.a < m.c.c.length; ) { + l = RD(ynb(m), 10); + d += a.a[l.c.p] + j; + f2[c2++] = d; + } + return f2; + } + function Xud(a, b) { + var c2, d, e, f2; + f2 = RD(Gxd(a, (umd(), Old)), 64).g - RD(Gxd(b, Old), 64).g; + if (f2 != 0) { + return f2; + } + c2 = RD(Gxd(a, Jld), 17); + d = RD(Gxd(b, Jld), 17); + if (!!c2 && !!d) { + e = c2.a - d.a; + if (e != 0) { + return e; + } + } + switch (RD(Gxd(a, Old), 64).g) { + case 1: + return Qfb(a.i, b.i); + case 2: + return Qfb(a.j, b.j); + case 3: + return Qfb(b.i, a.i); + case 4: + return Qfb(b.j, a.j); + default: + throw Adb(new dgb(UAe)); + } + } + function zCd(a) { + var b, c2, d; + if ((a.Db & 64) != 0) + return Fyd(a); + b = new dib(GHe); + c2 = a.k; + if (!c2) { + !a.n && (a.n = new C5d(I4, a, 1, 7)); + if (a.n.i > 0) { + d = (!a.n && (a.n = new C5d(I4, a, 1, 7)), RD(QHd(a.n, 0), 135)).a; + !d || Zhb(Zhb((b.a += ' "', b), d), '"'); + } + } else { + Zhb(Zhb((b.a += ' "', b), c2), '"'); + } + Zhb(Uhb(Zhb(Uhb(Zhb(Uhb(Zhb(Uhb((b.a += " (", b), a.i), ","), a.j), " | "), a.g), ","), a.f), ")"); + return b.a; + } + function OCd(a) { + var b, c2, d; + if ((a.Db & 64) != 0) + return Fyd(a); + b = new dib(HHe); + c2 = a.k; + if (!c2) { + !a.n && (a.n = new C5d(I4, a, 1, 7)); + if (a.n.i > 0) { + d = (!a.n && (a.n = new C5d(I4, a, 1, 7)), RD(QHd(a.n, 0), 135)).a; + !d || Zhb(Zhb((b.a += ' "', b), d), '"'); + } + } else { + Zhb(Zhb((b.a += ' "', b), c2), '"'); + } + Zhb(Uhb(Zhb(Uhb(Zhb(Uhb(Zhb(Uhb((b.a += " (", b), a.i), ","), a.j), " | "), a.g), ","), a.f), ")"); + return b.a; + } + function Xnc(a, b) { + var c2, d, e, f2, g; + b == (TEc(), QEc) && Eob(RD(Qc(a.a, (Bnc(), xnc)), 15)); + for (e = RD(Qc(a.a, (Bnc(), xnc)), 15).Kc(); e.Ob(); ) { + d = RD(e.Pb(), 105); + c2 = RD(Vmb(d.j, 0), 113).d.j; + f2 = new dnb(d.j); + _mb(f2, new Boc()); + switch (b.g) { + case 2: + Pnc(a, f2, c2, (joc(), hoc), 1); + break; + case 1: + case 0: + g = Rnc(f2); + Pnc(a, new Rkb(f2, 0, g), c2, (joc(), hoc), 0); + Pnc(a, new Rkb(f2, g, f2.c.length), c2, hoc, 1); + } + } + } + function sgd(a, b) { + var c2, d, e, f2, g, h, i2; + if (b == null || b.length == 0) { + return null; + } + e = RD(Xjb(a.a, b), 143); + if (!e) { + for (d = (h = new glb(a.b).a.vc().Kc(), new llb(h)); d.a.Ob(); ) { + c2 = (f2 = RD(d.a.Pb(), 44), RD(f2.md(), 143)); + g = c2.c; + i2 = b.length; + if (lhb(g.substr(g.length - i2, i2), b) && (b.length == g.length || ihb(g, g.length - b.length - 1) == 46)) { + if (e) { + return null; + } + e = c2; + } + } + !!e && $jb(a.a, b, e); + } + return e; + } + function HOb(a, b) { + var c2, d, e, f2; + c2 = new MOb(); + d = RD(zDb(GDb(new SDb(null, new Swb(a.f, 16)), c2), sBb(new _Bb(), new bCb(), new yCb(), new ACb(), cD(WC(QL, 1), jwe, 108, 0, [(xBb(), wBb), vBb]))), 21); + e = d.gc(); + d = RD(zDb(GDb(new SDb(null, new Swb(b.f, 16)), c2), sBb(new _Bb(), new bCb(), new yCb(), new ACb(), cD(WC(QL, 1), jwe, 108, 0, [wBb, vBb]))), 21); + f2 = d.gc(); + if (e < f2) { + return -1; + } + if (e == f2) { + return 0; + } + return 1; + } + function I8b(a) { + var b, c2, d; + if (!nQb(a, (yCc(), dBc))) { + return; + } + d = RD(mQb(a, dBc), 21); + if (d.dc()) { + return; + } + c2 = (b = RD(mfb(A3), 9), new Fsb(b, RD(WEb(b, b.length), 9), 0)); + d.Hc((dod(), $nd)) ? zsb(c2, $nd) : zsb(c2, _nd); + d.Hc(Ynd) || zsb(c2, Ynd); + d.Hc(Xnd) ? zsb(c2, cod) : d.Hc(Wnd) ? zsb(c2, bod) : d.Hc(Znd) && zsb(c2, aod); + d.Hc(cod) ? zsb(c2, Xnd) : d.Hc(bod) ? zsb(c2, Wnd) : d.Hc(aod) && zsb(c2, Znd); + pQb(a, dBc, c2); + } + function KLc(a) { + var b, c2, d, e, f2, g, h; + e = RD(mQb(a, (Ywc(), pwc)), 10); + d = a.j; + c2 = (tFb(0, d.c.length), RD(d.c[0], 12)); + for (g = new Anb(e.j); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 12); + if (dE(f2) === dE(mQb(c2, Awc))) { + if (f2.j == (qpd(), Yod) && a.p > e.p) { + Q3b(f2, npd); + if (f2.d) { + h = f2.o.b; + b = f2.a.b; + f2.a.b = h - b; + } + } else if (f2.j == npd && e.p > a.p) { + Q3b(f2, Yod); + if (f2.d) { + h = f2.o.b; + b = f2.a.b; + f2.a.b = -(h - b); + } + } + break; + } + } + return e; + } + function nTb(a, b, c2, d, e) { + var f2, g, h, i2, j, k, l; + if (!(ZD(b, 207) || ZD(b, 366) || ZD(b, 193))) { + throw Adb(new agb("Method only works for ElkNode-, ElkLabel and ElkPort-objects.")); + } + g = a.a / 2; + i2 = b.i + d - g; + k = b.j + e - g; + j = i2 + b.g + a.a; + l = k + b.f + a.a; + f2 = new Ejd(); + Mub(f2, new rjd(i2, k)); + Mub(f2, new rjd(i2, l)); + Mub(f2, new rjd(j, l)); + Mub(f2, new rjd(j, k)); + h = new ORb(f2); + kQb(h, b); + c2 && Zjb(a.b, b, h); + return h; + } + function w$b(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m; + f2 = new rjd(b, c2); + for (k = new Anb(a.a); k.a < k.c.c.length; ) { + j = RD(ynb(k), 10); + $id(j.n, f2); + for (m = new Anb(j.j); m.a < m.c.c.length; ) { + l = RD(ynb(m), 12); + for (e = new Anb(l.g); e.a < e.c.c.length; ) { + d = RD(ynb(e), 18); + Cjd(d.a, f2); + g = RD(mQb(d, (yCc(), RAc)), 75); + !!g && Cjd(g, f2); + for (i2 = new Anb(d.b); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 72); + $id(h.n, f2); + } + } + } + } + } + function o2b(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m; + f2 = new rjd(b, c2); + for (k = new Anb(a.a); k.a < k.c.c.length; ) { + j = RD(ynb(k), 10); + $id(j.n, f2); + for (m = new Anb(j.j); m.a < m.c.c.length; ) { + l = RD(ynb(m), 12); + for (e = new Anb(l.g); e.a < e.c.c.length; ) { + d = RD(ynb(e), 18); + Cjd(d.a, f2); + g = RD(mQb(d, (yCc(), RAc)), 75); + !!g && Cjd(g, f2); + for (i2 = new Anb(d.b); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 72); + $id(h.n, f2); + } + } + } + } + } + function X4b(a) { + if ((!a.b && (a.b = new Yie(E4, a, 4, 7)), a.b).i == 0) { + throw Adb(new Ked("Edges must have a source.")); + } else if ((!a.c && (a.c = new Yie(E4, a, 5, 8)), a.c).i == 0) { + throw Adb(new Ked("Edges must have a target.")); + } else { + !a.b && (a.b = new Yie(E4, a, 4, 7)); + if (!(a.b.i <= 1 && (!a.c && (a.c = new Yie(E4, a, 5, 8)), a.c.i <= 1))) { + throw Adb(new Ked("Hyperedges are not supported.")); + } + } + } + function mKc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l; + l = 0; + f2 = new wmb(); + hmb(f2, b); + while (f2.b != f2.c) { + i2 = RD(smb(f2), 219); + j = 0; + k = RD(mQb(b.j, (yCc(), cAc)), 284); + g = Kfb(UD(mQb(b.j, Zzc))); + h = Kfb(UD(mQb(b.j, $zc))); + if (k != (kEc(), hEc)) { + j += g * nKc(i2.e, k); + j += h * oKc(i2.e); + } + l += PLc(i2.d, i2.e) + j; + for (e = new Anb(i2.b); e.a < e.c.c.length; ) { + d = RD(ynb(e), 36); + c2 = RD(Vmb(a.b, d.p), 219); + c2.s || (l += lKc(a, c2)); + } + } + return l; + } + function Pib() { + Pib = geb; + var a; + Kib = new ajb(1, 1); + Mib = new ajb(1, 10); + Oib = new ajb(0, 0); + Jib = new ajb(-1, 1); + Lib = cD(WC(uJ, 1), Nve, 92, 0, [Oib, Kib, new ajb(1, 2), new ajb(1, 3), new ajb(1, 4), new ajb(1, 5), new ajb(1, 6), new ajb(1, 7), new ajb(1, 8), new ajb(1, 9), Mib]); + Nib = $C(uJ, Nve, 92, 32, 0, 1); + for (a = 0; a < Nib.length; a++) { + Nib[a] = Jdb(Sdb(1, a), 0) ? jjb(Sdb(1, a)) : Xib(jjb(Odb(Sdb(1, a)))); + } + } + function JJb(a, b, c2, d, e, f2, g) { + a.c = d.Lf().a; + a.d = d.Lf().b; + if (e) { + a.c += e.Lf().a; + a.d += e.Lf().b; + } + a.b = b.Mf().a; + a.a = b.Mf().b; + if (!e) { + c2 ? a.c -= g + b.Mf().a : a.c += d.Mf().a + g; + } else { + switch (e.ag().g) { + case 0: + case 2: + a.c += e.Mf().a + g + f2.a + g; + break; + case 4: + a.c -= g + f2.a + g + b.Mf().a; + break; + case 1: + a.c += e.Mf().a + g; + a.d -= g + f2.b + g + b.Mf().b; + break; + case 3: + a.c += e.Mf().a + g; + a.d += e.Mf().b + g + f2.b + g; + } + } + } + function xdc(a, b) { + var c2, d; + this.b = new bnb(); + this.e = new bnb(); + this.a = a; + this.d = b; + udc(this); + vdc(this); + this.b.dc() ? this.c = a.c.p : this.c = RD(this.b.Xb(0), 10).c.p; + this.e.c.length == 0 ? this.f = a.c.p : this.f = RD(Vmb(this.e, this.e.c.length - 1), 10).c.p; + for (d = RD(mQb(a, (Ywc(), Mwc)), 15).Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 72); + if (nQb(c2, (yCc(), uAc))) { + this.d = RD(mQb(c2, uAc), 232); + break; + } + } + } + function erc(a, b, c2) { + var d, e, f2, g, h, i2, j, k; + d = RD(Wjb(a.a, b), 49); + f2 = RD(Wjb(a.a, c2), 49); + e = RD(Wjb(a.e, b), 49); + g = RD(Wjb(a.e, c2), 49); + d.a.zc(c2, d); + g.a.zc(b, g); + for (k = f2.a.ec().Kc(); k.Ob(); ) { + j = RD(k.Pb(), 10); + d.a.zc(j, d); + Ysb(RD(Wjb(a.e, j), 49), b); + ye(RD(Wjb(a.e, j), 49), e); + } + for (i2 = e.a.ec().Kc(); i2.Ob(); ) { + h = RD(i2.Pb(), 10); + g.a.zc(h, g); + Ysb(RD(Wjb(a.a, h), 49), c2); + ye(RD(Wjb(a.a, h), 49), f2); + } + } + function uLc(a, b, c2) { + var d, e, f2, g, h, i2, j, k; + d = RD(Wjb(a.a, b), 49); + f2 = RD(Wjb(a.a, c2), 49); + e = RD(Wjb(a.b, b), 49); + g = RD(Wjb(a.b, c2), 49); + d.a.zc(c2, d); + g.a.zc(b, g); + for (k = f2.a.ec().Kc(); k.Ob(); ) { + j = RD(k.Pb(), 10); + d.a.zc(j, d); + Ysb(RD(Wjb(a.b, j), 49), b); + ye(RD(Wjb(a.b, j), 49), e); + } + for (i2 = e.a.ec().Kc(); i2.Ob(); ) { + h = RD(i2.Pb(), 10); + g.a.zc(h, g); + Ysb(RD(Wjb(a.a, h), 49), c2); + ye(RD(Wjb(a.a, h), 49), f2); + } + } + function rrc(a, b, c2) { + var d, e, f2, g, h, i2, j, k; + d = RD(Wjb(a.a, b), 49); + f2 = RD(Wjb(a.a, c2), 49); + e = RD(Wjb(a.d, b), 49); + g = RD(Wjb(a.d, c2), 49); + d.a.zc(c2, d); + g.a.zc(b, g); + for (k = f2.a.ec().Kc(); k.Ob(); ) { + j = RD(k.Pb(), 12); + d.a.zc(j, d); + Ysb(RD(Wjb(a.d, j), 49), b); + ye(RD(Wjb(a.d, j), 49), e); + } + for (i2 = e.a.ec().Kc(); i2.Ob(); ) { + h = RD(i2.Pb(), 12); + g.a.zc(h, g); + Ysb(RD(Wjb(a.a, h), 49), c2); + ye(RD(Wjb(a.a, h), 49), f2); + } + } + function lTc(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m, n, o2; + f2 = c2; + if (c2 < d) { + m = (n = new USc(a.p), o2 = new USc(a.p), ye(n.e, a.e), n.q = a.q, n.r = o2, LSc(n), ye(o2.j, a.j), o2.r = n, LSc(o2), new Ptd(n, o2)); + l = RD(m.a, 118); + k = RD(m.b, 118); + e = (tFb(f2, b.c.length), RD(b.c[f2], 339)); + g = sTc(a, l, k, e); + for (j = c2 + 1; j <= d; j++) { + h = (tFb(j, b.c.length), RD(b.c[j], 339)); + i2 = sTc(a, l, k, h); + if (qTc(h, i2, e, g)) { + e = h; + g = i2; + f2 = j; + } + } + } + return f2; + } + function c8c(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m, n, o2; + g = RD(QHd(b, 0), 27); + Dyd(g, 0); + Eyd(g, 0); + m = new bnb(); + ZEb(m.c, g); + h = g; + f2 = new lad(a.a, g.g, g.f, (sad(), rad)); + for (n = 1; n < b.i; n++) { + o2 = RD(QHd(b, n), 27); + i2 = d8c(a, oad, o2, h, f2, m, c2); + j = d8c(a, nad, o2, h, f2, m, c2); + k = d8c(a, qad, o2, h, f2, m, c2); + l = d8c(a, pad2, o2, h, f2, m, c2); + e = f8c(a, i2, j, k, l, o2, h, d); + Dyd(o2, e.d); + Eyd(o2, e.e); + kad(e, rad); + f2 = e; + h = o2; + ZEb(m.c, o2); + } + return f2; + } + function yEd(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m; + k = null; + m = b; + l = pEd(a, DGd(c2), m); + jyd(l, zDd(m, uIe)); + g = wDd(m, kIe); + d = new MEd(a, l); + ODd(d.a, d.b, g); + h = wDd(m, lIe); + e = new NEd(a, l); + PDd(e.a, e.b, h); + if ((!l.b && (l.b = new Yie(E4, l, 4, 7)), l.b).i == 0 || (!l.c && (l.c = new Yie(E4, l, 5, 8)), l.c).i == 0) { + f2 = zDd(m, uIe); + i2 = yIe + f2; + j = i2 + zIe; + throw Adb(new CDd(j)); + } + GEd(m, l); + zEd(a, m, l); + k = CEd(a, m, l); + return k; + } + function pJb(a, b) { + var c2, d, e, f2, g, h, i2; + e = $C(kE, Pwe, 28, a.e.a.c.length, 15, 1); + for (g = new Anb(a.e.a); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 125); + e[f2.d] += f2.b.a.c.length; + } + h = gv(b); + while (h.b != 0) { + f2 = RD(h.b == 0 ? null : (sFb(h.b != 0), Wub(h, h.a.a)), 125); + for (d = Nr(new Anb(f2.g.a)); d.Ob(); ) { + c2 = RD(d.Pb(), 218); + i2 = c2.e; + i2.e = $wnd.Math.max(i2.e, f2.e + c2.a); + --e[i2.d]; + e[i2.d] == 0 && (Pub(h, i2, h.c.b, h.c), true); + } + } + } + function tJb(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l; + c2 = qwe; + e = lve; + for (h = new Anb(a.e.a); h.a < h.c.c.length; ) { + f2 = RD(ynb(h), 125); + e = $wnd.Math.min(e, f2.e); + c2 = $wnd.Math.max(c2, f2.e); + } + b = $C(kE, Pwe, 28, c2 - e + 1, 15, 1); + for (g = new Anb(a.e.a); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 125); + f2.e -= e; + ++b[f2.e]; + } + d = 0; + if (a.k != null) { + for (j = a.k, k = 0, l = j.length; k < l; ++k) { + i2 = j[k]; + b[d++] += i2; + if (b.length == d) { + break; + } + } + } + return b; + } + function I0c(a, b) { + var c2, d, e, f2, g, h; + b.Ug("Edge routing", 1); + e = RD(mQb(a, (h_c(), K$c)), 392); + if (e == (LZc(), JZc)) { + G0c(a); + } else if (e == IZc) { + RD(Lvb(DDb(CDb(new SDb(null, new Swb(a.b, 16)), new AWc()))), 40); + f2 = Kfb(UD(mQb(a, $$c))); + g = Kfb(UD(mQb(a, J$c))); + h = RD(mQb(a, H$c), 88); + E0c(a, h, f2); + F0c(a, h, f2, g); + D0c(a, h, f2, g); + for (d = Sub(a.a, 0); d.b != d.d.c; ) { + c2 = RD(evb(d), 65); + c2.a.b < 2 && H0c(c2); + } + } + b.Vg(); + } + function IKd(a) { + switch (a.d) { + case 9: + case 8: { + return true; + } + case 3: + case 5: + case 4: + case 6: { + return false; + } + case 7: { + return RD(HKd(a), 17).a == a.o; + } + case 1: + case 2: { + if (a.o == -2) { + return false; + } else { + switch (a.p) { + case 0: + case 1: + case 2: + case 6: + case 5: + case 7: { + return Gdb(a.k, a.f); + } + case 3: + case 4: { + return a.j == a.e; + } + default: { + return a.n == null ? a.g == null : pb(a.n, a.g); + } + } + } + } + default: { + return false; + } + } + } + function Grc(a, b) { + var c2, d, e; + b.Ug("Breaking Point Insertion", 1); + d = new ysc(a); + switch (RD(mQb(a, (yCc(), rCc)), 351).g) { + case 2: + e = new Ksc(); + break; + case 0: + e = new zrc(); + break; + default: + e = new Nsc(); + } + c2 = e.og(a, d); + Heb(TD(mQb(a, tCc))) && (c2 = Frc(a, c2)); + if (!e.pg() && nQb(a, xCc)) { + switch (RD(mQb(a, xCc), 352).g) { + case 2: + c2 = Wsc(d, c2); + break; + case 1: + c2 = Usc(d, c2); + } + } + if (c2.dc()) { + b.Vg(); + return; + } + Drc(a, c2); + b.Vg(); + } + function oJc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l; + f2 = new cnb(b.c.length); + for (j = new Anb(b); j.a < j.c.c.length; ) { + g = RD(ynb(j), 10); + Rmb(f2, a.b[g.c.p][g.p]); + } + jJc(a, f2, c2); + l = null; + while (l = kJc(f2)) { + lJc(a, RD(l.a, 239), RD(l.b, 239), f2); + } + b.c.length = 0; + for (e = new Anb(f2); e.a < e.c.c.length; ) { + d = RD(ynb(e), 239); + for (h = d.d, i2 = 0, k = h.length; i2 < k; ++i2) { + g = h[i2]; + ZEb(b.c, g); + a.a[g.c.p][g.p].a = pJc(d.g, d.d[0]).a; + } + } + } + function wnd(a) { + Cgd(a, new Pfd($fd(Xfd(Zfd(Yfd(new agd(), pHe), "ELK Fixed"), "Keeps the current layout as it is, without any automatic modification. Optional coordinates can be given for nodes and edge bend points."), new znd()))); + Agd(a, pHe, Eze, tnd); + Agd(a, pHe, fEe, iGd(und)); + Agd(a, pHe, QGe, iGd(ond)); + Agd(a, pHe, jAe, iGd(pnd)); + Agd(a, pHe, CAe, iGd(rnd)); + Agd(a, pHe, hAe, iGd(qnd)); + } + function Do(a, b, c2) { + var d, e, f2, g, h; + d = Ydb(Ndb(cwe, qgb(Ydb(Ndb(b == null ? 0 : tb(b), dwe)), 15))); + h = Ydb(Ndb(cwe, qgb(Ydb(Ndb(c2 == null ? 0 : tb(c2), dwe)), 15))); + f2 = Go(a, b, d); + if (!!f2 && h == f2.f && Hb(c2, f2.i)) { + return c2; + } + g = Ho(a, c2, h); + if (g) { + throw Adb(new agb("value already present: " + c2)); + } + e = new kp(b, d, c2, h); + if (f2) { + yo(a, f2); + Bo(a, e, f2); + f2.e = null; + f2.c = null; + return f2.i; + } else { + Bo(a, e, null); + Fo(a); + return null; + } + } + function V7b(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2; + k = c2.a.c; + g = c2.a.c + c2.a.b; + f2 = RD(Wjb(c2.c, b), 468); + n = f2.f; + o2 = f2.a; + f2.b ? i2 = new rjd(g, n) : i2 = new rjd(k, n); + f2.c ? l = new rjd(k, o2) : l = new rjd(g, o2); + e = k; + c2.p || (e += a.c); + e += c2.F + c2.v * a.b; + j = new rjd(e, n); + m = new rjd(e, o2); + zjd(b.a, cD(WC(l3, 1), Nve, 8, 0, [i2, j])); + h = c2.d.a.gc() > 1; + if (h) { + d = new rjd(e, c2.b); + Mub(b.a, d); + } + zjd(b.a, cD(WC(l3, 1), Nve, 8, 0, [m, l])); + } + function aEc() { + aEc = geb; + $Dc = new bEc(LAe, 0); + VDc = new bEc("NIKOLOV", 1); + YDc = new bEc("NIKOLOV_PIXEL", 2); + WDc = new bEc("NIKOLOV_IMPROVED", 3); + XDc = new bEc("NIKOLOV_IMPROVED_PIXEL", 4); + SDc = new bEc("DUMMYNODE_PERCENTAGE", 5); + ZDc = new bEc("NODECOUNT_PERCENTAGE", 6); + _Dc = new bEc("NO_BOUNDARY", 7); + TDc = new bEc("MODEL_ORDER_LEFT_TO_RIGHT", 8); + UDc = new bEc("MODEL_ORDER_RIGHT_TO_LEFT", 9); + } + function use(a) { + var b, c2, d, e, f2; + d = a.length; + b = new Rhb(); + f2 = 0; + while (f2 < d) { + c2 = ihb(a, f2++); + if (c2 == 9 || c2 == 10 || c2 == 12 || c2 == 13 || c2 == 32) + continue; + if (c2 == 35) { + while (f2 < d) { + c2 = ihb(a, f2++); + if (c2 == 13 || c2 == 10) + break; + } + continue; + } + if (c2 == 92 && f2 < d) { + if ((e = (BFb(f2, a.length), a.charCodeAt(f2))) == 35 || e == 9 || e == 10 || e == 12 || e == 13 || e == 32) { + Jhb(b, e & Bwe); + ++f2; + } else { + b.a += "\\"; + Jhb(b, e & Bwe); + ++f2; + } + } else + Jhb(b, c2 & Bwe); + } + return b.a; + } + function D4c() { + D4c = geb; + n4c = new lGd(oFe, (Geb(), false)); + t4c = new lGd(pFe, sgb(0)); + u4c = new lGd(qFe, 0); + v4c = new lGd(rFe, false); + q4c = (g4c(), d4c); + p4c = new lGd(sFe, q4c); + sgb(0); + o4c = new lGd(tFe, sgb(1)); + A4c = (t5c(), r5c); + z4c = new lGd(uFe, A4c); + C4c = (Y3c(), X3c); + B4c = new lGd(vFe, C4c); + s4c = (j5c(), i5c); + r4c = new lGd(wFe, s4c); + y4c = new lGd(xFe, 0); + w4c = new lGd(yFe, false); + x4c = new lGd(zFe, false); + } + function t3c(a, b) { + var c2, d, e; + for (d = new Anb(b); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 27); + Rc(a.a, c2, c2); + Rc(a.b, c2, c2); + e = Q2c(c2); + if (e.c.length != 0) { + !!a.d && a.d.Gg(e); + Rc(a.a, c2, (tFb(0, e.c.length), RD(e.c[0], 27))); + Rc(a.b, c2, RD(Vmb(e, e.c.length - 1), 27)); + while (N2c(e).c.length != 0) { + e = N2c(e); + !!a.d && a.d.Gg(e); + Rc(a.a, c2, (tFb(0, e.c.length), RD(e.c[0], 27))); + Rc(a.b, c2, RD(Vmb(e, e.c.length - 1), 27)); + } + } + } + } + function jwd(a, b, c2) { + var d, e, f2, g, h, i2; + if (!b) { + return null; + } else { + if (c2 <= -1) { + d = vYd(b.Dh(), -1 - c2); + if (ZD(d, 102)) { + return RD(d, 19); + } else { + g = RD(b.Mh(d), 160); + for (h = 0, i2 = g.gc(); h < i2; ++h) { + if (dE(g.Ul(h)) === dE(a)) { + e = g.Tl(h); + if (ZD(e, 102)) { + f2 = RD(e, 19); + if ((f2.Bb & QHe) != 0) { + return f2; + } + } + } + } + throw Adb(new dgb("The containment feature could not be located")); + } + } else { + return Z5d(RD(vYd(a.Dh(), c2), 19)); + } + } + } + function Lqc(a) { + var b, c2, d, e, f2, g, h, i2, j, k; + c2 = 0; + for (h = new Anb(a.d); h.a < h.c.c.length; ) { + g = RD(ynb(h), 105); + !!g.i && (g.i.c = c2++); + } + b = YC(xdb, [Nve, Hye], [183, 28], 16, [c2, c2], 2); + k = a.d; + for (e = 0; e < k.c.length; e++) { + i2 = (tFb(e, k.c.length), RD(k.c[e], 105)); + if (i2.i) { + for (f2 = e + 1; f2 < k.c.length; f2++) { + j = (tFb(f2, k.c.length), RD(k.c[f2], 105)); + if (j.i) { + d = Qqc(i2, j); + b[i2.i.c][j.i.c] = d; + b[j.i.c][i2.i.c] = d; + } + } + } + } + return b; + } + function u7c() { + u7c = geb; + m7c = new lGd(LFe, (Geb(), false)); + sgb(-1); + f7c = new lGd(MFe, sgb(-1)); + sgb(-1); + g7c = new lGd(NFe, sgb(-1)); + h7c = new lGd(OFe, false); + s7c = (z8c(), x8c); + r7c = new lGd(PFe, s7c); + t7c = new lGd(QFe, -1); + q7c = (_6c(), $6c); + p7c = new lGd(RFe, q7c); + o7c = new lGd(SFe, true); + l7c = (b9c(), $8c); + k7c = new lGd(TFe, l7c); + j7c = new lGd(UFe, false); + sgb(1); + i7c = new lGd(VFe, sgb(1)); + n7c = new jGd(WFe); + } + function WYc() { + WYc = geb; + VYc = new XYc("ROOT_PROC", 0); + OYc = new XYc("FAN_PROC", 1); + SYc = new XYc("LEVEL_PROC", 2); + TYc = new XYc("NEIGHBORS_PROC", 3); + RYc = new XYc("LEVEL_HEIGHT", 4); + NYc = new XYc("DIRECTION_PROC", 5); + UYc = new XYc("NODE_POSITION_PROC", 6); + LYc = new XYc("COMPACTION_PROC", 7); + QYc = new XYc("LEVEL_COORDS", 8); + PYc = new XYc("GRAPH_BOUNDS_PROC", 9); + MYc = new XYc("DETREEIFYING_PROC", 10); + } + function Fee(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l; + l = zYd(b); + j = null; + e = false; + for (h = 0, k = tYd(l.a).i; h < k; ++h) { + g = RD(N_d(l, h, (f2 = RD(QHd(tYd(l.a), h), 89), i2 = f2.c, ZD(i2, 90) ? RD(i2, 29) : (JTd(), zTd))), 29); + c2 = Fee(a, g); + if (!c2.dc()) { + if (!j) { + j = c2; + } else { + if (!e) { + e = true; + j = new PSd(j); + } + j.Gc(c2); + } + } + } + d = Kee(a, b); + if (d.dc()) { + return !j ? (yob(), yob(), vob) : j; + } else { + if (!j) { + return d; + } else { + e || (j = new PSd(j)); + j.Gc(d); + return j; + } + } + } + function Gee(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l; + l = zYd(b); + j = null; + d = false; + for (h = 0, k = tYd(l.a).i; h < k; ++h) { + f2 = RD(N_d(l, h, (e = RD(QHd(tYd(l.a), h), 89), i2 = e.c, ZD(i2, 90) ? RD(i2, 29) : (JTd(), zTd))), 29); + c2 = Gee(a, f2); + if (!c2.dc()) { + if (!j) { + j = c2; + } else { + if (!d) { + d = true; + j = new PSd(j); + } + j.Gc(c2); + } + } + } + g = Nee(a, b); + if (g.dc()) { + return !j ? (yob(), yob(), vob) : j; + } else { + if (!j) { + return g; + } else { + d || (j = new PSd(j)); + j.Gc(g); + return j; + } + } + } + function gNb(a) { + var b, c2, d, e; + d = a.o; + RMb(); + if (a.A.dc() || pb(a.A, QMb)) { + e = d.a; + } else { + e = ZKb(a.f); + if (a.A.Hc((Qpd(), Npd)) && !a.B.Hc((dqd(), _pd))) { + e = $wnd.Math.max(e, ZKb(RD(Vrb(a.p, (qpd(), Yod)), 252))); + e = $wnd.Math.max(e, ZKb(RD(Vrb(a.p, npd), 252))); + } + b = TMb(a); + !!b && (e = $wnd.Math.max(e, b.a)); + } + Heb(TD(a.e.Tf().of((umd(), mld)))) ? d.a = $wnd.Math.max(d.a, e) : d.a = e; + c2 = a.f.i; + c2.c = 0; + c2.b = e; + $Kb(a.f); + } + function _fe(a, b, c2) { + var d, e, f2, g, h, i2; + if (ZD(b, 76)) { + return rLd(a, b, c2); + } else { + h = null; + f2 = null; + d = RD(a.g, 124); + for (g = 0; g < a.i; ++g) { + e = d[g]; + if (pb(b, e.md())) { + f2 = e.Lk(); + if (ZD(f2, 102) && (RD(f2, 19).Bb & QHe) != 0) { + h = e; + break; + } + } + } + if (h) { + if (Mvd(a.e)) { + i2 = f2.Jk() ? fge(a, 4, f2, b, null, kge(a, f2, b, ZD(f2, 102) && (RD(f2, 19).Bb & txe) != 0), true) : fge(a, f2.tk() ? 2 : 1, f2, b, f2.ik(), -1, true); + c2 ? c2.nj(i2) : c2 = i2; + } + c2 = _fe(a, h, c2); + } + return c2; + } + } + function yge(a, b, c2) { + var d, e, f2, g; + g = pke(a.e.Dh(), b); + d = RD(a.g, 124); + nke(); + if (RD(b, 69).xk()) { + for (f2 = 0; f2 < a.i; ++f2) { + e = d[f2]; + if (g.am(e.Lk())) { + if (pb(e, c2)) { + vLd(a, f2); + return true; + } + } + } + } else if (c2 != null) { + for (f2 = 0; f2 < a.i; ++f2) { + e = d[f2]; + if (g.am(e.Lk())) { + if (pb(c2, e.md())) { + vLd(a, f2); + return true; + } + } + } + } else { + for (f2 = 0; f2 < a.i; ++f2) { + e = d[f2]; + if (g.am(e.Lk())) { + if (e.md() == null) { + vLd(a, f2); + return true; + } + } + } + } + return false; + } + function xcc(a, b) { + var c2, d, e, f2, g; + b.Ug("Node and Port Label Placement and Node Sizing", 1); + DJb((i1b(), new t1b(a, true, true, new Acc()))); + if (RD(mQb(a, (Ywc(), kwc)), 21).Hc((ovc(), hvc))) { + f2 = RD(mQb(a, (yCc(), EBc)), 21); + e = f2.Hc((Pod(), Mod)); + g = Heb(TD(mQb(a, FBc))); + for (d = new Anb(a.b); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 30); + FDb(CDb(new SDb(null, new Swb(c2.a, 16)), new Ccc()), new Ecc(f2, e, g)); + } + } + b.Vg(); + } + function SHc(a, b) { + var c2, d, e, f2, g; + a.c == null || a.c.length < b.c.length ? a.c = $C(xdb, Hye, 28, b.c.length, 16, 1) : Nnb(a.c); + a.a = new bnb(); + d = 0; + for (g = new Anb(b); g.a < g.c.c.length; ) { + e = RD(ynb(g), 10); + e.p = d++; + } + c2 = new Yub(); + for (f2 = new Anb(b); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 10); + if (!a.c[e.p]) { + THc(a, e); + c2.b == 0 || (sFb(c2.b != 0), RD(c2.a.a.c, 15)).gc() < a.a.c.length ? Nub(c2, a.a) : Oub(c2, a.a); + a.a = new bnb(); + } + } + return c2; + } + function Ucd(a) { + Cgd(a, new Pfd($fd(Xfd(Zfd(Yfd(new agd(), uGe), "ELK SPOrE Overlap Removal"), 'A node overlap removal algorithm proposed by Nachmanson et al. in "Node overlap removal by growing a tree".'), new Xcd()))); + Agd(a, uGe, iGe, iGd(Scd)); + Agd(a, uGe, Eze, Qcd); + Agd(a, uGe, _ze, 8); + Agd(a, uGe, nGe, iGd(Rcd)); + Agd(a, uGe, qGe, iGd(Ocd)); + Agd(a, uGe, rGe, iGd(Pcd)); + Agd(a, uGe, LDe, (Geb(), false)); + } + function Dee(a, b) { + var c2, d, e, f2, g, h, i2; + c2 = b.qi(a.a); + if (c2) { + i2 = WD($Nd((!c2.b && (c2.b = new SVd((JTd(), FTd), C8, c2)), c2.b), cLe)); + if (i2 != null) { + d = new bnb(); + for (f2 = vhb(i2, "\\w"), g = 0, h = f2.length; g < h; ++g) { + e = f2[g]; + lhb(e, "##other") ? Rmb(d, "!##" + Uee(a, BXd(b.qk()))) : lhb(e, "##local") ? (d.c.push(null), true) : lhb(e, aLe) ? Rmb(d, Uee(a, BXd(b.qk()))) : (ZEb(d.c, e), true); + } + return d; + } + } + return yob(), yob(), vob; + } + function u$b(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m, n; + g = Zid(b.c, c2, d); + for (l = new Anb(b.a); l.a < l.c.c.length; ) { + k = RD(ynb(l), 10); + $id(k.n, g); + for (n = new Anb(k.j); n.a < n.c.c.length; ) { + m = RD(ynb(n), 12); + for (f2 = new Anb(m.g); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 18); + Cjd(e.a, g); + h = RD(mQb(e, (yCc(), RAc)), 75); + !!h && Cjd(h, g); + for (j = new Anb(e.b); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 72); + $id(i2.n, g); + } + } + } + Rmb(a.a, k); + k.a = a; + } + } + function wYb(a) { + var b, c2, d, e, f2, g, h, i2; + if (a.d) { + throw Adb(new dgb((lfb(eQ), lye + eQ.k + mye))); + } + a.c == (Cmd(), Amd) && vYb(a, ymd); + for (c2 = new Anb(a.a.a); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 194); + b.e = 0; + } + for (g = new Anb(a.a.b); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 86); + f2.o = pxe; + for (e = f2.f.Kc(); e.Ob(); ) { + d = RD(e.Pb(), 86); + ++d.d.e; + } + } + LYb(a); + for (i2 = new Anb(a.a.b); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 86); + h.k = true; + } + return a; + } + function mnc(a, b) { + var c2, d, e, f2, g, h, i2, j; + h = new Vmc(a); + c2 = new Yub(); + Pub(c2, b, c2.c.b, c2.c); + while (c2.b != 0) { + d = RD(c2.b == 0 ? null : (sFb(c2.b != 0), Wub(c2, c2.a.a)), 113); + d.d.p = 1; + for (g = new Anb(d.e); g.a < g.c.c.length; ) { + e = RD(ynb(g), 340); + Qmc(h, e); + j = e.d; + j.d.p == 0 && (Pub(c2, j, c2.c.b, c2.c), true); + } + for (f2 = new Anb(d.b); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 340); + Qmc(h, e); + i2 = e.c; + i2.d.p == 0 && (Pub(c2, i2, c2.c.b, c2.c), true); + } + } + return h; + } + function ksd(a) { + var b, c2, d, e, f2; + d = Kfb(UD(Gxd(a, (umd(), Uld)))); + if (d == 1) { + return; + } + zyd(a, d * a.g, d * a.f); + c2 = cr(hr((!a.c && (a.c = new C5d(K4, a, 9, 9)), a.c), new Lsd())); + for (f2 = Fl(Al(cD(WC(cJ, 1), rve, 20, 0, [(!a.n && (a.n = new C5d(I4, a, 1, 7)), a.n), (!a.c && (a.c = new C5d(K4, a, 9, 9)), a.c), c2]))); gs(f2); ) { + e = RD(hs(f2), 422); + e.qh(d * e.nh(), d * e.oh()); + e.ph(d * e.mh(), d * e.lh()); + b = RD(e.of(Fld), 8); + if (b) { + b.a *= d; + b.b *= d; + } + } + } + function Qfe(a, b, c2) { + var d, e, f2, g, h; + g = (nke(), RD(b, 69).xk()); + if (qke(a.e, b)) { + if (b.Si() && dge(a, b, c2, ZD(b, 102) && (RD(b, 19).Bb & txe) != 0)) { + return false; + } + } else { + h = pke(a.e.Dh(), b); + d = RD(a.g, 124); + for (f2 = 0; f2 < a.i; ++f2) { + e = d[f2]; + if (h.am(e.Lk())) { + if (g ? pb(e, c2) : c2 == null ? e.md() == null : pb(c2, e.md())) { + return false; + } else { + RD(eHd(a, f2, g ? RD(c2, 76) : oke(b, c2)), 76); + return true; + } + } + } + } + return WGd(a, g ? RD(c2, 76) : oke(b, c2)); + } + function _dc(a, b, c2, d, e) { + var f2, g, h, i2, j, k, l, m; + for (g = new Anb(a.b); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 30); + m = t2b(f2.a); + for (j = m, k = 0, l = j.length; k < l; ++k) { + i2 = j[k]; + switch (RD(mQb(i2, (yCc(), UAc)), 171).g) { + case 1: + dec(i2); + g3b(i2, b); + aec(i2, true, d); + break; + case 3: + eec(i2); + g3b(i2, c2); + aec(i2, false, e); + } + } + } + h = new Jkb(a.b, 0); + while (h.b < h.d.gc()) { + (sFb(h.b < h.d.gc()), RD(h.d.Xb(h.c = h.b++), 30)).a.c.length == 0 && Ckb(h); + } + } + function mjb(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q; + n = b.length; + i2 = n; + BFb(0, b.length); + if (b.charCodeAt(0) == 45) { + l = -1; + m = 1; + --n; + } else { + l = 1; + m = 0; + } + f2 = (xjb(), wjb)[10]; + e = n / f2 | 0; + q = n % f2; + q != 0 && ++e; + h = $C(kE, Pwe, 28, e, 15, 1); + c2 = vjb[8]; + g = 0; + o2 = m + (q == 0 ? f2 : q); + for (p = m; p < i2; p = o2, o2 = p + f2) { + d = Oeb((AFb(p, o2, b.length), b.substr(p, o2 - p)), qwe, lve); + j = (Ljb(), Pjb(h, h, g, c2)); + j += Fjb(h, g, d); + h[g++] = j; + } + k = g; + a.e = l; + a.d = k; + a.a = h; + Rib(a); + } + function bPb(a, b) { + var c2, d, e, f2; + c2 = new gPb(); + d = RD(zDb(GDb(new SDb(null, new Swb(a.f, 16)), c2), sBb(new _Bb(), new bCb(), new yCb(), new ACb(), cD(WC(QL, 1), jwe, 108, 0, [(xBb(), wBb), vBb]))), 21); + e = d.gc(); + d = RD(zDb(GDb(new SDb(null, new Swb(b.f, 16)), c2), sBb(new _Bb(), new bCb(), new yCb(), new ACb(), cD(WC(QL, 1), jwe, 108, 0, [wBb, vBb]))), 21); + f2 = d.gc(); + e = e == 1 ? 1 : 0; + f2 = f2 == 1 ? 1 : 0; + if (e < f2) { + return -1; + } + if (e == f2) { + return 0; + } + return 1; + } + function p0b(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m; + h = a.i; + e = Heb(TD(mQb(h, (yCc(), NAc)))); + k = 0; + d = 0; + for (j = new Anb(a.g); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 18); + g = W0b(i2); + f2 = g && e && Heb(TD(mQb(i2, OAc))); + m = i2.d.i; + g && f2 ? ++d : g && !f2 ? ++k : Y2b(m).e == h ? ++d : ++k; + } + for (c2 = new Anb(a.e); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 18); + g = W0b(b); + f2 = g && e && Heb(TD(mQb(b, OAc))); + l = b.c.i; + g && f2 ? ++k : g && !f2 ? ++d : Y2b(l).e == h ? ++k : ++d; + } + return k - d; + } + function sQc(a, b, c2, d) { + this.e = a; + this.k = RD(mQb(a, (Ywc(), Qwc)), 312); + this.g = $C(jR, WAe, 10, b, 0, 1); + this.b = $C(VI, Nve, 345, b, 7, 1); + this.a = $C(jR, WAe, 10, b, 0, 1); + this.d = $C(VI, Nve, 345, b, 7, 1); + this.j = $C(jR, WAe, 10, b, 0, 1); + this.i = $C(VI, Nve, 345, b, 7, 1); + this.p = $C(VI, Nve, 345, b, 7, 1); + this.n = $C(QI, Nve, 485, b, 8, 1); + Mnb(this.n, (Geb(), false)); + this.f = $C(QI, Nve, 485, b, 8, 1); + Mnb(this.f, true); + this.o = c2; + this.c = d; + } + function mdc(a, b) { + var c2, d, e, f2, g, h; + if (b.dc()) { + return; + } + if (RD(b.Xb(0), 293).d == (btc(), $sc)) { + ddc(a, b); + } else { + for (d = b.Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 293); + switch (c2.d.g) { + case 5: + _cc(a, c2, fdc(a, c2)); + break; + case 0: + _cc(a, c2, (g = c2.f - c2.c + 1, h = (g - 1) / 2 | 0, c2.c + h)); + break; + case 4: + _cc(a, c2, hdc(a, c2)); + break; + case 2: + ndc(c2); + _cc(a, c2, (f2 = jdc(c2), f2 ? c2.c : c2.f)); + break; + case 1: + ndc(c2); + _cc(a, c2, (e = jdc(c2), e ? c2.f : c2.c)); + } + edc(c2.a); + } + } + } + function zt(a, b, c2, d) { + var e, f2, g; + g = new Hu(b, c2); + if (!a.a) { + a.a = a.e = g; + Zjb(a.b, b, new Gu(g)); + ++a.c; + } else if (!d) { + RD(Hvb(a.e), 511).b = g; + g.d = a.e; + a.e = g; + e = RD(Wjb(a.b, b), 260); + if (!e) { + Zjb(a.b, b, e = new Gu(g)); + ++a.c; + } else { + ++e.a; + f2 = e.c; + f2.c = g; + g.e = f2; + e.c = g; + } + } else { + e = RD(Hvb(RD(Wjb(a.b, b), 260)), 260); + ++e.a; + g.d = d.d; + g.e = d.e; + g.b = d; + g.c = d; + !d.e ? e.b = g : d.e.c = g; + !d.d ? a.a = g : d.d.b = g; + d.d = g; + d.e = g; + } + ++a.d; + return g; + } + function lJb(a, b) { + var c2, d, e, f2, g; + b.Ug("Network simplex", 1); + if (a.e.a.c.length < 1) { + b.Vg(); + return; + } + for (f2 = new Anb(a.e.a); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 125); + e.e = 0; + } + g = a.e.a.c.length >= 40; + g && wJb(a); + nJb(a); + mJb(a); + c2 = qJb(a); + d = 0; + while (!!c2 && d < a.f) { + kJb(a, c2, jJb(a, c2)); + c2 = qJb(a); + ++d; + } + g && vJb(a); + a.a ? hJb(a, tJb(a)) : tJb(a); + a.b = null; + a.d = null; + a.p = null; + a.c = null; + a.g = null; + a.i = null; + a.n = null; + a.o = null; + b.Vg(); + } + function T7b(a, b) { + var c2, d, e, f2, g, h, i2; + if (b.e) { + return; + } + b.e = true; + for (d = b.d.a.ec().Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 18); + if (b.o && b.d.a.gc() <= 1) { + g = b.a.c; + h = b.a.c + b.a.b; + i2 = new rjd(g + (h - g) / 2, b.b); + Mub(RD(b.d.a.ec().Kc().Pb(), 18).a, i2); + continue; + } + e = RD(Wjb(b.c, c2), 468); + if (e.b || e.c) { + V7b(a, c2, b); + continue; + } + f2 = a.d == (lFc(), kFc) && (e.d || e.e) && _7b(a, b) && b.d.a.gc() <= 1; + f2 ? W7b(c2, b) : U7b(a, c2, b); + } + b.k && xgb(b.d, new m8b()); + } + function A5c(a, b, c2, d, e, f2) { + var g, h, i2, j, k, l, m, n, o2, p, q, r, s, t; + m = f2; + h = (d + e) / 2 + m; + q = c2 * $wnd.Math.cos(h); + r = c2 * $wnd.Math.sin(h); + s = q - b.g / 2; + t = r - b.f / 2; + Dyd(b, s); + Eyd(b, t); + l = a.a.Eg(b); + p = 2 * $wnd.Math.acos(c2 / c2 + a.c); + if (p < e - d) { + n = p / l; + g = (d + e - p) / 2; + } else { + n = (e - d) / l; + g = d; + } + o2 = Q2c(b); + if (a.e) { + a.e.Fg(a.d); + a.e.Gg(o2); + } + for (j = new Anb(o2); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 27); + k = a.a.Eg(i2); + A5c(a, i2, c2 + a.c, g, g + n * k, f2); + g += n * k; + } + } + function zA(a, b, c2) { + var d; + d = c2.q.getMonth(); + switch (b) { + case 5: + Zhb(a, cD(WC(qJ, 1), Nve, 2, 6, ["J", "F", "M", "A", "M", "J", "J", "A", "S", "O", "N", "D"])[d]); + break; + case 4: + Zhb(a, cD(WC(qJ, 1), Nve, 2, 6, [Cwe, Dwe, Ewe, Fwe, Gwe, Hwe, Iwe, Jwe, Kwe, Lwe, Mwe, Nwe])[d]); + break; + case 3: + Zhb(a, cD(WC(qJ, 1), Nve, 2, 6, ["Jan", "Feb", "Mar", "Apr", Gwe, "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"])[d]); + break; + default: + UA(a, d + 1, b); + } + } + function ATb(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m; + i2 = new rjd(c2, d); + ojd(i2, RD(mQb(b, (JVb(), GVb)), 8)); + for (m = new Anb(b.e); m.a < m.c.c.length; ) { + l = RD(ynb(m), 153); + $id(l.d, i2); + Rmb(a.e, l); + } + for (h = new Anb(b.c); h.a < h.c.c.length; ) { + g = RD(ynb(h), 290); + for (f2 = new Anb(g.a); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 250); + $id(e.d, i2); + } + Rmb(a.c, g); + } + for (k = new Anb(b.d); k.a < k.c.c.length; ) { + j = RD(ynb(k), 454); + $id(j.d, i2); + Rmb(a.d, j); + } + } + function TFc(a, b) { + var c2, d, e, f2, g, h, i2, j; + for (i2 = new Anb(b.j); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 12); + for (e = new l4b(h.b); xnb(e.a) || xnb(e.b); ) { + d = RD(xnb(e.a) ? ynb(e.a) : ynb(e.b), 18); + c2 = d.c == h ? d.d : d.c; + f2 = c2.i; + if (b == f2) { + continue; + } + j = RD(mQb(d, (yCc(), KBc)), 17).a; + j < 0 && (j = 0); + g = f2.p; + if (a.b[g] == 0) { + if (d.d == c2) { + a.a[g] -= j + 1; + a.a[g] <= 0 && a.c[g] > 0 && Mub(a.f, f2); + } else { + a.c[g] -= j + 1; + a.c[g] <= 0 && a.a[g] > 0 && Mub(a.e, f2); + } + } + } + } + } + function FVc(a, b, c2, d) { + var e, f2, g, h, i2, j, k; + i2 = new rjd(c2, d); + ojd(i2, RD(mQb(b, (q$c(), SZc)), 8)); + for (k = Sub(b.b, 0); k.b != k.d.c; ) { + j = RD(evb(k), 40); + $id(j.e, i2); + Mub(a.b, j); + } + for (h = RD(zDb(BDb(new SDb(null, new Swb(b.a, 16))), tBb(new ZBb(), new XBb(), new wCb(), cD(WC(QL, 1), jwe, 108, 0, [(xBb(), vBb)]))), 15).Kc(); h.Ob(); ) { + g = RD(h.Pb(), 65); + for (f2 = Sub(g.a, 0); f2.b != f2.d.c; ) { + e = RD(evb(f2), 8); + e.a += i2.a; + e.b += i2.b; + } + Mub(a.a, g); + } + } + function kWc(a, b) { + var c2, d, e, f2; + if (0 < (ZD(a, 16) ? RD(a, 16).gc() : Kr(a.Kc()))) { + e = b; + if (1 < e) { + --e; + f2 = new uWc(); + for (d = a.Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 40); + f2 = Al(cD(WC(cJ, 1), rve, 20, 0, [f2, new dXc(c2)])); + } + return kWc(f2, e); + } + if (e < 0) { + f2 = new xWc(); + for (d = a.Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 40); + f2 = Al(cD(WC(cJ, 1), rve, 20, 0, [f2, new dXc(c2)])); + } + if (0 < (ZD(f2, 16) ? RD(f2, 16).gc() : Kr(f2.Kc()))) { + return kWc(f2, e); + } + } + } + return RD(Hr(a.Kc()), 40); + } + function v0c(a, b, c2) { + var d, e, f2, g; + c2.Ug("Processor order nodes", 2); + a.b = Kfb(UD(mQb(b, (h_c(), _$c)))); + a.a = RD(mQb(b, H$c), 88); + if (a.a == (Cmd(), Amd)) { + a.a = xmd; + pQb(b, H$c, a.a); + } + e = new Yub(); + for (g = Sub(b.b, 0); g.b != g.d.c; ) { + f2 = RD(evb(g), 40); + Heb(TD(mQb(f2, (q$c(), n$c)))) && (Pub(e, f2, e.c.b, e.c), true); + } + d = (sFb(e.b != 0), RD(e.a.a.c, 40)); + t0c(a, d); + c2.fh(1); + w0c(a, d, 0 - Kfb(UD(mQb(d, (q$c(), d$c)))) / 2, 0); + c2.fh(1); + c2.Vg(); + } + function dqd() { + dqd = geb; + Ypd = new eqd("DEFAULT_MINIMUM_SIZE", 0); + $pd = new eqd("MINIMUM_SIZE_ACCOUNTS_FOR_PADDING", 1); + Xpd = new eqd("COMPUTE_PADDING", 2); + _pd = new eqd("OUTSIDE_NODE_LABELS_OVERHANG", 3); + aqd = new eqd("PORTS_OVERHANG", 4); + cqd = new eqd("UNIFORM_PORT_SPACING", 5); + bqd = new eqd("SPACE_EFFICIENT_PORT_LABELS", 6); + Zpd = new eqd("FORCE_TABULAR_NODE_LABELS", 7); + Wpd = new eqd("ASYMMETRICAL", 8); + } + function Rje(a, b) { + var c2, d, e, f2, g, h, i2, j; + if (!b) { + return null; + } else { + c2 = (f2 = b.Dh(), !f2 ? null : BXd(f2).wi().si(f2)); + if (c2) { + dub(a, b, c2); + e = b.Dh(); + for (i2 = 0, j = (e.i == null && rYd(e), e.i).length; i2 < j; ++i2) { + h = (d = (e.i == null && rYd(e), e.i), i2 >= 0 && i2 < d.length ? d[i2] : null); + if (h.rk() && !h.sk()) { + if (ZD(h, 331)) { + Tje(a, RD(h, 35), b, c2); + } else { + g = RD(h, 19); + (g.Bb & QHe) != 0 && Vje(a, g, b, c2); + } + } + } + b.Vh() && RD(c2, 54).ei(RD(b, 54)._h()); + } + return c2; + } + } + function kJb(a, b, c2) { + var d, e, f2; + if (!b.f) { + throw Adb(new agb("Given leave edge is no tree edge.")); + } + if (c2.f) { + throw Adb(new agb("Given enter edge is a tree edge already.")); + } + b.f = false; + $sb(a.p, b); + c2.f = true; + Ysb(a.p, c2); + d = c2.e.e - c2.d.e - c2.a; + oJb(a, c2.e, b) || (d = -d); + for (f2 = new Anb(a.e.a); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 125); + oJb(a, e, b) || (e.e += d); + } + a.j = 1; + Nnb(a.c); + uJb(a, RD(ynb(new Anb(a.e.a)), 125)); + iJb(a); + } + function wIc(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m, n; + BIc(a, b, c2); + f2 = b[c2]; + n = d ? (qpd(), ppd) : (qpd(), Xod); + if (xIc(b.length, c2, d)) { + e = b[d ? c2 - 1 : c2 + 1]; + sIc(a, e, d ? (BEc(), zEc) : (BEc(), yEc)); + for (i2 = f2, k = 0, m = i2.length; k < m; ++k) { + g = i2[k]; + vIc(a, g, n); + } + sIc(a, f2, d ? (BEc(), yEc) : (BEc(), zEc)); + for (h = e, j = 0, l = h.length; j < l; ++j) { + g = h[j]; + !!g.e || vIc(a, g, spd(n)); + } + } else { + for (h = f2, j = 0, l = h.length; j < l; ++j) { + g = h[j]; + vIc(a, g, n); + } + } + return false; + } + function erd(a, b, c2, d, e) { + var f2, g, h, i2, j, k, l; + yob(); + _mb(a, new Urd()); + h = new Jkb(a, 0); + l = new bnb(); + f2 = 0; + while (h.b < h.d.gc()) { + g = (sFb(h.b < h.d.gc()), RD(h.d.Xb(h.c = h.b++), 163)); + if (l.c.length != 0 && urd(g) * trd(g) > f2 * 2) { + k = new zrd(l); + j = urd(g) / trd(g); + i2 = ird(k, b, new z3b(), c2, d, e, j); + $id(hjd(k.e), i2); + l.c.length = 0; + f2 = 0; + ZEb(l.c, k); + ZEb(l.c, g); + f2 = urd(k) * trd(k) + urd(g) * trd(g); + } else { + ZEb(l.c, g); + f2 += urd(g) * trd(g); + } + } + return l; + } + function O9b(a, b) { + var c2, d, e, f2, g, h; + h = RD(mQb(b, (yCc(), BBc)), 101); + if (!(h == (Bod(), xod) || h == wod)) { + return; + } + e = new rjd(b.f.a + b.d.b + b.d.c, b.f.b + b.d.d + b.d.a).b; + for (g = new Anb(a.a); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 10); + if (f2.k != (r3b(), m3b)) { + continue; + } + c2 = RD(mQb(f2, (Ywc(), hwc)), 64); + if (c2 != (qpd(), Xod) && c2 != ppd) { + continue; + } + d = Kfb(UD(mQb(f2, Jwc))); + h == xod && (d *= e); + f2.n.b = d - RD(mQb(f2, zBc), 8).b; + U2b(f2, false, true); + } + } + function uge(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2; + if (Mvd(a.e)) { + if (b != c2) { + e = RD(a.g, 124); + n = e[c2]; + g = n.Lk(); + if (qke(a.e, g)) { + o2 = pke(a.e.Dh(), g); + i2 = -1; + h = -1; + d = 0; + for (j = 0, l = b > c2 ? b : c2; j <= l; ++j) { + if (j == c2) { + h = d++; + } else { + f2 = e[j]; + k = o2.am(f2.Lk()); + j == b && (i2 = j == l && !k ? d - 1 : d); + k && ++d; + } + } + m = RD(uLd(a, b, c2), 76); + h != i2 && eZd(a, new c4d(a.e, 7, g, sgb(h), n.md(), i2)); + return m; + } + } + } else { + return RD(SHd(a, b, c2), 76); + } + return RD(uLd(a, b, c2), 76); + } + function ugc(a, b) { + var c2, d, e, f2, g, h, i2; + b.Ug("Port order processing", 1); + i2 = RD(mQb(a, (yCc(), HBc)), 430); + for (d = new Anb(a.b); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 30); + for (f2 = new Anb(c2.a); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 10); + g = RD(mQb(e, BBc), 101); + h = e.j; + if (g == (Bod(), vod) || g == xod || g == wod) { + yob(); + _mb(h, mgc); + } else if (g != zod && g != Aod) { + yob(); + _mb(h, pgc); + wgc(h); + i2 == (sEc(), rEc) && _mb(h, ogc); + } + e.i = true; + V2b(e); + } + } + b.Vg(); + } + function VHc(a) { + var b, c2, d, e, f2, g, h, i2; + i2 = new Tsb(); + b = new BIb(); + for (g = a.Kc(); g.Ob(); ) { + e = RD(g.Pb(), 10); + h = eJb(fJb(new gJb(), e), b); + rtb(i2.f, e, h); + } + for (f2 = a.Kc(); f2.Ob(); ) { + e = RD(f2.Pb(), 10); + for (d = new is(Mr(a3b(e).a.Kc(), new ir())); gs(d); ) { + c2 = RD(hs(d), 18); + if (W0b(c2)) { + continue; + } + rIb(uIb(tIb(sIb(vIb(new wIb(), $wnd.Math.max(1, RD(mQb(c2, (yCc(), LBc)), 17).a)), 1), RD(Wjb(i2, c2.c.i), 125)), RD(Wjb(i2, c2.d.i), 125))); + } + } + return b; + } + function TRc() { + TRc = geb; + ORc = pfd(new ufd(), (sXb(), qXb), (hcc(), Bbc)); + QRc = pfd(new ufd(), pXb, Fbc); + RRc = nfd(pfd(new ufd(), pXb, Tbc), rXb, Sbc); + NRc = nfd(pfd(pfd(new ufd(), pXb, vbc), qXb, wbc), rXb, xbc); + SRc = mfd(mfd(rfd(nfd(pfd(new ufd(), nXb, bcc), rXb, acc), qXb), _bc), ccc); + PRc = nfd(new ufd(), rXb, Cbc); + LRc = nfd(pfd(pfd(pfd(new ufd(), oXb, Ibc), qXb, Kbc), qXb, Lbc), rXb, Jbc); + MRc = nfd(pfd(pfd(new ufd(), qXb, Lbc), qXb, qbc), rXb, pbc); + } + function lD(a, b, c2, d, e, f2) { + var g, h, i2, j, k, l, m; + j = oD(b) - oD(a); + g = AD(b, j); + i2 = hD(0, 0, 0); + while (j >= 0) { + h = rD(a, g); + if (h) { + j < 22 ? (i2.l |= 1 << j, void 0) : j < 44 ? (i2.m |= 1 << j - 22, void 0) : (i2.h |= 1 << j - 44, void 0); + if (a.l == 0 && a.m == 0 && a.h == 0) { + break; + } + } + k = g.m; + l = g.h; + m = g.l; + g.h = l >>> 1; + g.m = k >>> 1 | (l & 1) << 21; + g.l = m >>> 1 | (k & 1) << 21; + --j; + } + c2 && nD(i2); + if (f2) { + if (d) { + eD = xD(a); + e && (eD = DD(eD, (MD(), KD))); + } else { + eD = hD(a.l, a.m, a.h); + } + } + return i2; + } + function rIc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l; + j = a.e[b.c.p][b.p] + 1; + i2 = b.c.a.c.length + 1; + for (h = new Anb(a.a); h.a < h.c.c.length; ) { + g = RD(ynb(h), 12); + l = 0; + f2 = 0; + for (e = Fl(Al(cD(WC(cJ, 1), rve, 20, 0, [new T3b(g), new _3b(g)]))); gs(e); ) { + d = RD(hs(e), 12); + if (d.i.c == b.c) { + l += AIc(a, d.i) + 1; + ++f2; + } + } + c2 = l / f2; + k = g.j; + k == (qpd(), Xod) ? c2 < j ? a.f[g.p] = a.c - c2 : a.f[g.p] = a.b + (i2 - c2) : k == ppd && (c2 < j ? a.f[g.p] = a.b + c2 : a.f[g.p] = a.c - (i2 - c2)); + } + } + function Oeb(a, b, c2) { + var d, e, f2, g, h; + if (a == null) { + throw Adb(new Vgb(vve)); + } + f2 = a.length; + g = f2 > 0 && (BFb(0, a.length), a.charCodeAt(0) == 45 || (BFb(0, a.length), a.charCodeAt(0) == 43)) ? 1 : 0; + for (d = g; d < f2; d++) { + if (dfb((BFb(d, a.length), a.charCodeAt(d))) == -1) { + throw Adb(new Vgb(nxe + a + '"')); + } + } + h = parseInt(a, 10); + e = h < b; + if (isNaN(h)) { + throw Adb(new Vgb(nxe + a + '"')); + } else if (e || h > c2) { + throw Adb(new Vgb(nxe + a + '"')); + } + return h; + } + function Jqc(a) { + var b, c2, d, e, f2, g, h; + g = new Yub(); + for (f2 = new Anb(a.a); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 118); + PSc(e, e.f.c.length); + QSc(e, e.k.c.length); + if (e.i == 0) { + e.o = 0; + Pub(g, e, g.c.b, g.c); + } + } + while (g.b != 0) { + e = RD(g.b == 0 ? null : (sFb(g.b != 0), Wub(g, g.a.a)), 118); + d = e.o + 1; + for (c2 = new Anb(e.f); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 132); + h = b.a; + RSc(h, $wnd.Math.max(h.o, d)); + QSc(h, h.i - 1); + h.i == 0 && (Pub(g, h, g.c.b, g.c), true); + } + } + } + function Ged(a) { + var b, c2, d, e, f2, g, h, i2; + for (g = new Anb(a); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 74); + d = AGd(RD(QHd((!f2.b && (f2.b = new Yie(E4, f2, 4, 7)), f2.b), 0), 84)); + h = d.i; + i2 = d.j; + e = RD(QHd((!f2.a && (f2.a = new C5d(F4, f2, 6, 6)), f2.a), 0), 166); + Nzd(e, e.j + h, e.k + i2); + Gzd(e, e.b + h, e.c + i2); + for (c2 = new dMd((!e.a && (e.a = new XZd(D4, e, 5)), e.a)); c2.e != c2.i.gc(); ) { + b = RD(bMd(c2), 377); + Uxd(b, b.a + h, b.b + i2); + } + Bjd(RD(Gxd(f2, (umd(), cld)), 75), h, i2); + } + } + function Ere(a) { + var b; + switch (a) { + case 100: + return Jre(OLe, true); + case 68: + return Jre(OLe, false); + case 119: + return Jre(PLe, true); + case 87: + return Jre(PLe, false); + case 115: + return Jre(QLe, true); + case 83: + return Jre(QLe, false); + case 99: + return Jre(RLe, true); + case 67: + return Jre(RLe, false); + case 105: + return Jre(SLe, true); + case 73: + return Jre(SLe, false); + default: + throw Adb(new yz((b = a, NLe + b.toString(16)))); + } + } + function b_b(a) { + var b, c2, d, e, f2; + e = RD(Vmb(a.a, 0), 10); + b = new j3b(a); + Rmb(a.a, b); + b.o.a = $wnd.Math.max(1, e.o.a); + b.o.b = $wnd.Math.max(1, e.o.b); + b.n.a = e.n.a; + b.n.b = e.n.b; + switch (RD(mQb(e, (Ywc(), hwc)), 64).g) { + case 4: + b.n.a += 2; + break; + case 1: + b.n.b += 2; + break; + case 2: + b.n.a -= 2; + break; + case 3: + b.n.b -= 2; + } + d = new R3b(); + P3b(d, b); + c2 = new a1b(); + f2 = RD(Vmb(e.j, 0), 12); + Y0b(c2, f2); + Z0b(c2, d); + $id(hjd(d.n), f2.n); + $id(hjd(d.a), f2.a); + return b; + } + function Wdc(a, b, c2, d, e) { + if (c2 && (!d || (a.c - a.b & a.a.length - 1) > 1) && b == 1 && RD(a.a[a.b], 10).k == (r3b(), n3b)) { + Qdc(RD(a.a[a.b], 10), (Pnd(), Lnd)); + } else if (d && (!c2 || (a.c - a.b & a.a.length - 1) > 1) && b == 1 && RD(a.a[a.c - 1 & a.a.length - 1], 10).k == (r3b(), n3b)) { + Qdc(RD(a.a[a.c - 1 & a.a.length - 1], 10), (Pnd(), Mnd)); + } else if ((a.c - a.b & a.a.length - 1) == 2) { + Qdc(RD(omb(a), 10), (Pnd(), Lnd)); + Qdc(RD(omb(a), 10), Mnd); + } else { + Ndc(a, e); + } + jmb(a); + } + function QVc(a, b, c2) { + var d, e, f2, g, h; + f2 = 0; + for (e = new dMd((!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a)); e.e != e.i.gc(); ) { + d = RD(bMd(e), 27); + g = ""; + (!d.n && (d.n = new C5d(I4, d, 1, 7)), d.n).i == 0 || (g = RD(QHd((!d.n && (d.n = new C5d(I4, d, 1, 7)), d.n), 0), 135).a); + h = new bXc(f2++, b, g); + kQb(h, d); + pQb(h, (q$c(), h$c), d); + h.e.b = d.j + d.f / 2; + h.f.a = $wnd.Math.max(d.g, 1); + h.e.a = d.i + d.g / 2; + h.f.b = $wnd.Math.max(d.f, 1); + Mub(b.b, h); + rtb(c2.f, d, h); + } + } + function L5b(a) { + var b, c2, d, e, f2; + d = RD(mQb(a, (Ywc(), Awc)), 27); + f2 = RD(Gxd(d, (yCc(), lBc)), 181).Hc((Qpd(), Ppd)); + if (!a.e) { + e = RD(mQb(a, kwc), 21); + b = new rjd(a.f.a + a.d.b + a.d.c, a.f.b + a.d.d + a.d.a); + if (e.Hc((ovc(), hvc))) { + Ixd(d, BBc, (Bod(), wod)); + Esd(d, b.a, b.b, false, true); + } else { + Heb(TD(Gxd(d, mBc))) || Esd(d, b.a, b.b, true, true); + } + } + f2 ? Ixd(d, lBc, xsb(Ppd)) : Ixd(d, lBc, (c2 = RD(mfb(H3), 9), new Fsb(c2, RD(WEb(c2, c2.length), 9), 0))); + } + function JA(a, b, c2) { + var d, e, f2, g; + if (b[0] >= a.length) { + c2.o = 0; + return true; + } + switch (ihb(a, b[0])) { + case 43: + e = 1; + break; + case 45: + e = -1; + break; + default: + c2.o = 0; + return true; + } + ++b[0]; + f2 = b[0]; + g = HA(a, b); + if (g == 0 && b[0] == f2) { + return false; + } + if (b[0] < a.length && ihb(a, b[0]) == 58) { + d = g * 60; + ++b[0]; + f2 = b[0]; + g = HA(a, b); + if (g == 0 && b[0] == f2) { + return false; + } + d += g; + } else { + d = g; + d < 24 && b[0] - f2 <= 2 ? d *= 60 : d = d % 100 + (d / 100 | 0) * 60; + } + d *= e; + c2.o = -d; + return true; + } + function lnc(a) { + var b, c2, d, e, f2, g, h, i2, j; + g = new bnb(); + for (d = new is(Mr(a3b(a.b).a.Kc(), new ir())); gs(d); ) { + c2 = RD(hs(d), 18); + W0b(c2) && Rmb(g, new knc(c2, nnc(a, c2.c), nnc(a, c2.d))); + } + for (j = (f2 = new glb(a.e).a.vc().Kc(), new llb(f2)); j.a.Ob(); ) { + h = (b = RD(j.a.Pb(), 44), RD(b.md(), 113)); + h.d.p = 0; + } + for (i2 = (e = new glb(a.e).a.vc().Kc(), new llb(e)); i2.a.Ob(); ) { + h = (b = RD(i2.a.Pb(), 44), RD(b.md(), 113)); + h.d.p == 0 && Rmb(a.d, mnc(a, h)); + } + } + function e5b(a) { + var b, c2, d, e, f2, g, h; + f2 = MCd(a); + for (e = new dMd((!a.e && (a.e = new Yie(G4, a, 7, 4)), a.e)); e.e != e.i.gc(); ) { + d = RD(bMd(e), 74); + h = AGd(RD(QHd((!d.c && (d.c = new Yie(E4, d, 5, 8)), d.c), 0), 84)); + if (!NGd(h, f2)) { + return true; + } + } + for (c2 = new dMd((!a.d && (a.d = new Yie(G4, a, 8, 5)), a.d)); c2.e != c2.i.gc(); ) { + b = RD(bMd(c2), 74); + g = AGd(RD(QHd((!b.b && (b.b = new Yie(E4, b, 4, 7)), b.b), 0), 84)); + if (!NGd(g, f2)) { + return true; + } + } + return false; + } + function jRc(a, b) { + var c2, d, e, f2, g, h, i2, j, k; + for (g = new Anb(b.b); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 30); + for (j = new Anb(f2.a); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 10); + k = new bnb(); + h = 0; + for (d = new is(Mr(Z2b(i2).a.Kc(), new ir())); gs(d); ) { + c2 = RD(hs(d), 18); + if (W0b(c2) || !W0b(c2) && c2.c.i.c == c2.d.i.c) { + continue; + } + e = RD(mQb(c2, (yCc(), MBc)), 17).a; + if (e > h) { + h = e; + k.c.length = 0; + } + e == h && Rmb(k, new Ptd(c2.c.i, c2)); + } + yob(); + _mb(k, a.c); + Qmb(a.b, i2.p, k); + } + } + } + function kRc(a, b) { + var c2, d, e, f2, g, h, i2, j, k; + for (g = new Anb(b.b); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 30); + for (j = new Anb(f2.a); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 10); + k = new bnb(); + h = 0; + for (d = new is(Mr(a3b(i2).a.Kc(), new ir())); gs(d); ) { + c2 = RD(hs(d), 18); + if (W0b(c2) || !W0b(c2) && c2.c.i.c == c2.d.i.c) { + continue; + } + e = RD(mQb(c2, (yCc(), MBc)), 17).a; + if (e > h) { + h = e; + k.c.length = 0; + } + e == h && Rmb(k, new Ptd(c2.d.i, c2)); + } + yob(); + _mb(k, a.c); + Qmb(a.f, i2.p, k); + } + } + } + function HVc(a, b) { + var c2, d, e, f2, g, h, i2, j; + j = TD(mQb(b, (h_c(), Z$c))); + if (j == null || (uFb(j), j)) { + EVc(a, b); + e = new bnb(); + for (i2 = Sub(b.b, 0); i2.b != i2.d.c; ) { + g = RD(evb(i2), 40); + c2 = DVc(a, g, null); + if (c2) { + kQb(c2, b); + ZEb(e.c, c2); + } + } + a.a = null; + a.b = null; + if (e.c.length > 1) { + for (d = new Anb(e); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 121); + f2 = 0; + for (h = Sub(c2.b, 0); h.b != h.d.c; ) { + g = RD(evb(h), 40); + g.g = f2++; + } + } + } + return e; + } + return dv(cD(WC(W$, 1), Jze, 121, 0, [b])); + } + function hqc(a) { + var b, c2, d, e, f2, g, h, i2; + i2 = new Ejd(); + b = Sub(a, 0); + h = null; + c2 = RD(evb(b), 8); + e = RD(evb(b), 8); + while (b.b != b.d.c) { + h = c2; + c2 = e; + e = RD(evb(b), 8); + f2 = iqc(ojd(new rjd(h.a, h.b), c2)); + g = iqc(ojd(new rjd(e.a, e.b), c2)); + d = 10; + d = $wnd.Math.min(d, $wnd.Math.abs(f2.a + f2.b) / 2); + d = $wnd.Math.min(d, $wnd.Math.abs(g.a + g.b) / 2); + f2.a = Lgb(f2.a) * d; + f2.b = Lgb(f2.b) * d; + g.a = Lgb(g.a) * d; + g.b = Lgb(g.b) * d; + Mub(i2, $id(f2, c2)); + Mub(i2, $id(g, c2)); + } + return i2; + } + function wKc(a, b, c2) { + var d, e, f2, g, h, i2; + c2.Ug("Minimize Crossings " + a.a, 1); + d = b.b.c.length == 0 || !QDb(CDb(new SDb(null, new Swb(b.b, 16)), new PAb(new XKc()))).Bd((xDb(), wDb)); + i2 = b.b.c.length == 1 && RD(Vmb(b.b, 0), 30).a.c.length == 1; + f2 = dE(mQb(b, (yCc(), IAc))) === dE((Fnd(), Cnd)); + if (d || i2 && !f2) { + c2.Vg(); + return; + } + e = rKc(a, b); + g = (h = RD(ju(e, 0), 219), h.c.kg() ? h.c.eg() ? new KKc(a) : new MKc(a) : new IKc(a)); + sKc(e, g); + EKc(a); + c2.Vg(); + } + function xvd(a, b, c2, d) { + var e, f2, g, h, i2; + g = a.Ph(); + i2 = a.Jh(); + e = null; + if (i2) { + if (!!b && (jwd(a, b, c2).Bb & txe) == 0) { + d = rLd(i2.El(), a, d); + a.di(null); + e = b.Qh(); + } else { + i2 = null; + } + } else { + !!g && (i2 = g.Qh()); + !!b && (e = b.Qh()); + } + i2 != e && !!i2 && i2.Il(a); + h = a.Fh(); + a.Bh(b, c2); + i2 != e && !!e && e.Hl(a); + if (a.vh() && a.wh()) { + if (!!g && h >= 0 && h != c2) { + f2 = new N3d(a, 1, h, g, null); + !d ? d = f2 : d.nj(f2); + } + if (c2 >= 0) { + f2 = new N3d(a, 1, c2, h == c2 ? g : null, b); + !d ? d = f2 : d.nj(f2); + } + } + return d; + } + function jSd(a) { + var b, c2, d; + if (a.b == null) { + d = new Qhb(); + if (a.i != null) { + Nhb(d, a.i); + d.a += ":"; + } + if ((a.f & 256) != 0) { + if ((a.f & 256) != 0 && a.a != null) { + wSd(a.i) || (d.a += "//", d); + Nhb(d, a.a); + } + if (a.d != null) { + d.a += "/"; + Nhb(d, a.d); + } + (a.f & 16) != 0 && (d.a += "/", d); + for (b = 0, c2 = a.j.length; b < c2; b++) { + b != 0 && (d.a += "/", d); + Nhb(d, a.j[b]); + } + if (a.g != null) { + d.a += "?"; + Nhb(d, a.g); + } + } else { + Nhb(d, a.a); + } + if (a.e != null) { + d.a += "#"; + Nhb(d, a.e); + } + a.b = d.a; + } + return a.b; + } + function V8b(a, b) { + var c2, d, e, f2, g, h; + for (e = new Anb(b.a); e.a < e.c.c.length; ) { + d = RD(ynb(e), 10); + f2 = mQb(d, (Ywc(), Awc)); + if (ZD(f2, 12)) { + g = RD(f2, 12); + h = j2b(b, d, g.o.a, g.o.b); + g.n.a = h.a; + g.n.b = h.b; + Q3b(g, RD(mQb(d, hwc), 64)); + } + } + c2 = new rjd(b.f.a + b.d.b + b.d.c, b.f.b + b.d.d + b.d.a); + if (RD(mQb(b, (Ywc(), kwc)), 21).Hc((ovc(), hvc))) { + pQb(a, (yCc(), BBc), (Bod(), wod)); + RD(mQb(Y2b(a), kwc), 21).Fc(kvc); + r2b(a, c2, false); + } else { + r2b(a, c2, true); + } + } + function Ffc(a, b, c2, d, e) { + var f2, g, h, i2; + f2 = new j3b(a); + h3b(f2, (r3b(), q3b)); + pQb(f2, (yCc(), BBc), (Bod(), wod)); + pQb(f2, (Ywc(), Awc), b.c.i); + g = new R3b(); + pQb(g, Awc, b.c); + Q3b(g, e); + P3b(g, f2); + pQb(b.c, Iwc, f2); + h = new j3b(a); + h3b(h, q3b); + pQb(h, BBc, wod); + pQb(h, Awc, b.d.i); + i2 = new R3b(); + pQb(i2, Awc, b.d); + Q3b(i2, e); + P3b(i2, h); + pQb(b.d, Iwc, h); + Y0b(b, g); + Z0b(b, i2); + wFb(0, c2.c.length); + XEb(c2.c, 0, f2); + ZEb(d.c, h); + pQb(f2, $vc, sgb(1)); + pQb(h, $vc, sgb(1)); + } + function Eo(a, b, c2, d) { + var e, f2, g, h, i2; + i2 = Ydb(Ndb(cwe, qgb(Ydb(Ndb(b == null ? 0 : tb(b), dwe)), 15))); + e = Ydb(Ndb(cwe, qgb(Ydb(Ndb(c2 == null ? 0 : tb(c2), dwe)), 15))); + h = Ho(a, b, i2); + g = Go(a, c2, e); + if (!!h && e == h.a && Hb(c2, h.g)) { + return c2; + } else if (!!g && !d) { + throw Adb(new agb("key already present: " + c2)); + } + !!h && yo(a, h); + !!g && yo(a, g); + f2 = new kp(c2, e, b, i2); + Bo(a, f2, g); + if (g) { + g.e = null; + g.c = null; + } + if (h) { + h.e = null; + h.c = null; + } + Fo(a); + return !h ? null : h.g; + } + function Tjb(a, b, c2) { + var d, e, f2, g, h; + for (f2 = 0; f2 < b; f2++) { + d = 0; + for (h = f2 + 1; h < b; h++) { + d = Bdb(Bdb(Ndb(Cdb(a[f2], yxe), Cdb(a[h], yxe)), Cdb(c2[f2 + h], yxe)), Cdb(Ydb(d), yxe)); + c2[f2 + h] = Ydb(d); + d = Udb(d, 32); + } + c2[f2 + b] = Ydb(d); + } + sjb(c2, c2, b << 1); + d = 0; + for (e = 0, g = 0; e < b; ++e, g++) { + d = Bdb(Bdb(Ndb(Cdb(a[e], yxe), Cdb(a[e], yxe)), Cdb(c2[g], yxe)), Cdb(Ydb(d), yxe)); + c2[g] = Ydb(d); + d = Udb(d, 32); + ++g; + d = Bdb(d, Cdb(c2[g], yxe)); + c2[g] = Ydb(d); + d = Udb(d, 32); + } + return c2; + } + function xOc(a, b, c2) { + var d, e, f2, g, h, i2, j, k; + if (gr(b)) { + return; + } + i2 = Kfb(UD(hFc(c2.c, (yCc(), fCc)))); + j = RD(hFc(c2.c, eCc), 140); + !j && (j = new P2b()); + d = c2.a; + e = null; + for (h = b.Kc(); h.Ob(); ) { + g = RD(h.Pb(), 12); + k = 0; + if (!e) { + k = j.d; + } else { + k = i2; + k += e.o.b; + } + f2 = eJb(fJb(new gJb(), g), a.f); + Zjb(a.k, g, f2); + rIb(uIb(tIb(sIb(vIb(new wIb(), 0), eE($wnd.Math.ceil(k))), d), f2)); + e = g; + d = f2; + } + rIb(uIb(tIb(sIb(vIb(new wIb(), 0), eE($wnd.Math.ceil(j.a + e.o.b))), d), c2.d)); + } + function K8c(a, b, c2, d, e, f2, g, h) { + var i2, j, k, l, m, n; + n = false; + m = f2 - c2.s; + k = c2.t - b.f + (j = S9c(c2, m, false), j.a); + if (d.g + h > m) { + return false; + } + l = (i2 = S9c(d, m, false), i2.a); + if (k + h + l <= b.b) { + Q9c(c2, f2 - c2.s); + c2.c = true; + Q9c(d, f2 - c2.s); + U9c(d, c2.s, c2.t + c2.d + h); + d.k = true; + aad(c2.q, d); + n = true; + if (e) { + Cad(b, d); + d.j = b; + if (a.c.length > g) { + Fad((tFb(g, a.c.length), RD(a.c[g], 186)), d); + (tFb(g, a.c.length), RD(a.c[g], 186)).a.c.length == 0 && Xmb(a, g); + } + } + } + return n; + } + function Qfc(a, b) { + var c2, d, e, f2, g, h; + b.Ug("Partition midprocessing", 1); + e = new Tp(); + FDb(CDb(new SDb(null, new Swb(a.a, 16)), new Ufc()), new Wfc(e)); + if (e.d == 0) { + return; + } + h = RD(zDb(ODb((f2 = e.i, new SDb(null, (!f2 ? e.i = new zf(e, e.c) : f2).Nc()))), tBb(new ZBb(), new XBb(), new wCb(), cD(WC(QL, 1), jwe, 108, 0, [(xBb(), vBb)]))), 15); + d = h.Kc(); + c2 = RD(d.Pb(), 17); + while (d.Ob()) { + g = RD(d.Pb(), 17); + Pfc(RD(Qc(e, c2), 21), RD(Qc(e, g), 21)); + c2 = g; + } + b.Vg(); + } + function G_b(a, b, c2) { + var d, e, f2, g, h, i2, j, k; + if (b.p == 0) { + b.p = 1; + g = c2; + if (!g) { + e = new bnb(); + f2 = (d = RD(mfb(E3), 9), new Fsb(d, RD(WEb(d, d.length), 9), 0)); + g = new Ptd(e, f2); + } + RD(g.a, 15).Fc(b); + b.k == (r3b(), m3b) && RD(g.b, 21).Fc(RD(mQb(b, (Ywc(), hwc)), 64)); + for (i2 = new Anb(b.j); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 12); + for (k = Fl(Al(cD(WC(cJ, 1), rve, 20, 0, [new T3b(h), new _3b(h)]))); gs(k); ) { + j = RD(hs(k), 12); + G_b(a, j.i, g); + } + } + return g; + } + return null; + } + function bAd(a, b) { + var c2, d, e, f2, g; + if (a.Ab) { + if (a.Ab) { + g = a.Ab.i; + if (g > 0) { + e = RD(a.Ab.g, 2033); + if (b == null) { + for (f2 = 0; f2 < g; ++f2) { + c2 = e[f2]; + if (c2.d == null) { + return c2; + } + } + } else { + for (f2 = 0; f2 < g; ++f2) { + c2 = e[f2]; + if (lhb(b, c2.d)) { + return c2; + } + } + } + } + } else { + if (b == null) { + for (d = new dMd(a.Ab); d.e != d.i.gc(); ) { + c2 = RD(bMd(d), 598); + if (c2.d == null) { + return c2; + } + } + } else { + for (d = new dMd(a.Ab); d.e != d.i.gc(); ) { + c2 = RD(bMd(d), 598); + if (lhb(b, c2.d)) { + return c2; + } + } + } + } + } + return null; + } + function RDd(a, b, c2, d, e) { + var f2, g, h, i2, j, k, l, m, n, p, q, r, s, t, u, v; + n = qEd(a, EGd(b), e); + Jzd(n, zDd(e, uIe)); + o = null; + p = e; + q = yDd(p, xIe); + r = new UEd(n); + WDd(r.a, q); + s = yDd(p, "endPoint"); + t = new YEd(n); + YDd(t.a, s); + u = wDd(p, nIe); + v = new _Ed(n); + ZDd(v.a, u); + l = zDd(e, pIe); + f2 = new QEd(a, n); + SDd(f2.a, f2.b, l); + m = zDd(e, oIe); + g = new REd(a, n); + TDd(g.a, g.b, m); + j = wDd(e, rIe); + h = new SEd(c2, n); + UDd(h.b, h.a, j); + k = wDd(e, qIe); + i2 = new TEd(d, n); + VDd(i2.b, i2.a, k); + } + function q2b(a, b, c2) { + var d, e, f2, g, h; + h = null; + switch (b.g) { + case 1: + for (e = new Anb(a.j); e.a < e.c.c.length; ) { + d = RD(ynb(e), 12); + if (Heb(TD(mQb(d, (Ywc(), mwc))))) { + return d; + } + } + h = new R3b(); + pQb(h, (Ywc(), mwc), (Geb(), true)); + break; + case 2: + for (g = new Anb(a.j); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 12); + if (Heb(TD(mQb(f2, (Ywc(), Gwc))))) { + return f2; + } + } + h = new R3b(); + pQb(h, (Ywc(), Gwc), (Geb(), true)); + } + if (h) { + P3b(h, a); + Q3b(h, c2); + d2b(h.n, a.o, c2); + } + return h; + } + function d7b(a, b) { + var c2, d, e, f2, g, h; + h = -1; + g = new Yub(); + for (d = new l4b(a.b); xnb(d.a) || xnb(d.b); ) { + c2 = RD(xnb(d.a) ? ynb(d.a) : ynb(d.b), 18); + h = $wnd.Math.max(h, Kfb(UD(mQb(c2, (yCc(), FAc))))); + c2.c == a ? FDb(CDb(new SDb(null, new Swb(c2.b, 16)), new j7b()), new l7b(g)) : FDb(CDb(new SDb(null, new Swb(c2.b, 16)), new n7b()), new p7b(g)); + for (f2 = Sub(g, 0); f2.b != f2.d.c; ) { + e = RD(evb(f2), 72); + nQb(e, (Ywc(), dwc)) || pQb(e, dwc, c2); + } + Tmb(b, g); + Xub(g); + } + return h; + } + function _Tc(a, b, c2, d, e) { + var f2, g, h, i2, j; + h = e ? d.b : d.a; + if (Zsb(a.a, d)) { + return; + } + j = h > c2.s && h < c2.c; + i2 = false; + if (c2.e.b != 0 && c2.j.b != 0) { + i2 = i2 | ($wnd.Math.abs(h - Kfb(UD(Qub(c2.e)))) < Vze && $wnd.Math.abs(h - Kfb(UD(Qub(c2.j)))) < Vze); + i2 = i2 | ($wnd.Math.abs(h - Kfb(UD(Rub(c2.e)))) < Vze && $wnd.Math.abs(h - Kfb(UD(Rub(c2.j)))) < Vze); + } + if (j || i2) { + g = RD(mQb(b, (yCc(), RAc)), 75); + if (!g) { + g = new Ejd(); + pQb(b, RAc, g); + } + f2 = new sjd(d); + Pub(g, f2, g.c.b, g.c); + Ysb(a.a, f2); + } + } + function ZPb(a, b, c2, d) { + var e, f2, g, h, i2, j, k; + if (YPb(a, b, c2, d)) { + return true; + } else { + for (g = new Anb(b.f); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 334); + h = false; + i2 = a.j - b.j + c2; + j = i2 + b.o; + k = a.k - b.k + d; + e = k + b.p; + switch (f2.a.g) { + case 0: + h = fQb(a, i2 + f2.b.a, 0, i2 + f2.c.a, k - 1); + break; + case 1: + h = fQb(a, j, k + f2.b.a, a.o - 1, k + f2.c.a); + break; + case 2: + h = fQb(a, i2 + f2.b.a, e, i2 + f2.c.a, a.p - 1); + break; + default: + h = fQb(a, 0, k + f2.b.a, i2 - 1, k + f2.c.a); + } + if (h) { + return true; + } + } + } + return false; + } + function yZc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l; + c2.Ug("Processor set coordinates", 1); + a.a = b.b.b == 0 ? 1 : b.b.b; + j = null; + d = Sub(b.b, 0); + while (!j && d.b != d.d.c) { + l = RD(evb(d), 40); + if (Heb(TD(mQb(l, (q$c(), n$c))))) { + j = l; + i2 = l.e; + i2.a = RD(mQb(l, o$c), 17).a; + i2.b = RD(mQb(l, p$c), 17).a; + } + } + h = $Wc(j); + k = 1; + do { + h = zZc((e = h, c2.eh(k), e)); + k = h.b / a.a | 0; + } while (h.b != 0); + for (g = Sub(b.b, 0); g.b != g.d.c; ) { + f2 = RD(evb(g), 40); + ojd(f2.e, new rjd(f2.f.a / 2, f2.f.b / 2)); + } + c2.Vg(); + } + function uYc(a, b, c2) { + var d, e, f2, g, h, i2, j, k; + c2.Ug(MEe, 1); + akb(a.b); + akb(a.a); + h = null; + f2 = Sub(b.b, 0); + while (!h && f2.b != f2.d.c) { + j = RD(evb(f2), 40); + Heb(TD(mQb(j, (q$c(), n$c)))) && (h = j); + } + i2 = new Yub(); + Pub(i2, h, i2.c.b, i2.c); + tYc(a, i2); + for (k = Sub(b.b, 0); k.b != k.d.c; ) { + j = RD(evb(k), 40); + g = WD(mQb(j, (q$c(), a$c))); + e = Xjb(a.b, g) != null ? RD(Xjb(a.b, g), 17).a : 0; + pQb(j, XZc, sgb(e)); + d = 1 + (Xjb(a.a, g) != null ? RD(Xjb(a.a, g), 17).a : 0); + pQb(j, VZc, sgb(d)); + } + c2.Vg(); + } + function ikd(a) { + Cgd(a, new Pfd($fd(Xfd(Zfd(Yfd(new agd(), LGe), "ELK Box"), "Algorithm for packing of unconnected boxes, i.e. graphs without edges."), new lkd()))); + Agd(a, LGe, Eze, ekd); + Agd(a, LGe, _ze, 15); + Agd(a, LGe, $ze, sgb(0)); + Agd(a, LGe, MGe, iGd($jd)); + Agd(a, LGe, jAe, iGd(akd)); + Agd(a, LGe, iAe, iGd(ckd)); + Agd(a, LGe, Dze, KGe); + Agd(a, LGe, dAe, iGd(_jd)); + Agd(a, LGe, CAe, iGd(bkd)); + Agd(a, LGe, NGe, iGd(Yjd)); + Agd(a, LGe, YDe, iGd(Zjd)); + } + function c2b(a, b) { + var c2, d, e, f2, g, h, i2, j, k; + e = a.i; + g = e.o.a; + f2 = e.o.b; + if (g <= 0 && f2 <= 0) { + return qpd(), opd; + } + j = a.n.a; + k = a.n.b; + h = a.o.a; + c2 = a.o.b; + switch (b.g) { + case 2: + case 1: + if (j < 0) { + return qpd(), ppd; + } else if (j + h > g) { + return qpd(), Xod; + } + break; + case 4: + case 3: + if (k < 0) { + return qpd(), Yod; + } else if (k + c2 > f2) { + return qpd(), npd; + } + } + i2 = (j + h / 2) / g; + d = (k + c2 / 2) / f2; + return i2 + d <= 1 && i2 - d <= 0 ? (qpd(), ppd) : i2 + d >= 1 && i2 - d >= 0 ? (qpd(), Xod) : d < 0.5 ? (qpd(), Yod) : (qpd(), npd); + } + function PNc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p; + c2 = false; + k = Kfb(UD(mQb(b, (yCc(), bCc)))); + o2 = pwe * k; + for (e = new Anb(b.b); e.a < e.c.c.length; ) { + d = RD(ynb(e), 30); + j = new Anb(d.a); + f2 = RD(ynb(j), 10); + l = XNc(a.a[f2.p]); + while (j.a < j.c.c.length) { + h = RD(ynb(j), 10); + m = XNc(a.a[h.p]); + if (l != m) { + n = bFc(a.b, f2, h); + g = f2.n.b + f2.o.b + f2.d.a + l.a + n; + i2 = h.n.b - h.d.d + m.a; + if (g > i2 + o2) { + p = l.g + m.g; + m.a = (m.g * m.a + l.g * l.a) / p; + m.g = p; + l.f = m; + c2 = true; + } + } + f2 = h; + l = m; + } + } + return c2; + } + function MJb(a, b, c2, d, e, f2, g) { + var h, i2, j, k, l, m; + m = new Tid(); + for (j = b.Kc(); j.Ob(); ) { + h = RD(j.Pb(), 853); + for (l = new Anb(h.Rf()); l.a < l.c.c.length; ) { + k = RD(ynb(l), 187); + if (dE(k.of((umd(), Qkd))) === dE((Omd(), Nmd))) { + JJb(m, k, false, d, e, f2, g); + Sid(a, m); + } + } + } + for (i2 = c2.Kc(); i2.Ob(); ) { + h = RD(i2.Pb(), 853); + for (l = new Anb(h.Rf()); l.a < l.c.c.length; ) { + k = RD(ynb(l), 187); + if (dE(k.of((umd(), Qkd))) === dE((Omd(), Mmd))) { + JJb(m, k, true, d, e, f2, g); + Sid(a, m); + } + } + } + } + function PVc(a, b, c2) { + var d, e, f2, g, h, i2, j; + for (g = new dMd((!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a)); g.e != g.i.gc(); ) { + f2 = RD(bMd(g), 27); + for (e = new is(Mr(zGd(f2).a.Kc(), new ir())); gs(e); ) { + d = RD(hs(e), 74); + if (!nzd(d) && !nzd(d) && !ozd(d)) { + i2 = RD(Wd(qtb(c2.f, f2)), 40); + j = RD(Wjb(c2, AGd(RD(QHd((!d.c && (d.c = new Yie(E4, d, 5, 8)), d.c), 0), 84))), 40); + if (!!i2 && !!j) { + h = new WWc(i2, j); + pQb(h, (q$c(), h$c), d); + kQb(h, d); + Mub(i2.d, h); + Mub(j.b, h); + Mub(b.a, h); + } + } + } + } + } + function HNb(a, b) { + var c2, d, e, f2, g, h, i2, j; + for (i2 = RD(RD(Qc(a.r, b), 21), 87).Kc(); i2.Ob(); ) { + h = RD(i2.Pb(), 117); + e = h.c ? PKb(h.c) : 0; + if (e > 0) { + if (h.a) { + j = h.b.Mf().b; + if (e > j) { + if (a.v || h.c.d.c.length == 1) { + g = (e - j) / 2; + h.d.d = g; + h.d.a = g; + } else { + c2 = RD(Vmb(h.c.d, 0), 187).Mf().b; + d = (c2 - j) / 2; + h.d.d = $wnd.Math.max(0, d); + h.d.a = e - d - j; + } + } + } else { + h.d.a = a.t + e; + } + } else if (Rod(a.u)) { + f2 = wsd(h.b); + f2.d < 0 && (h.d.d = -f2.d); + f2.d + f2.a > h.b.Mf().b && (h.d.a = f2.d + f2.a - h.b.Mf().b); + } + } + } + function yVb() { + yVb = geb; + lVb = new mGd((umd(), Rld), sgb(1)); + rVb = new mGd(fmd, 80); + qVb = new mGd($ld, 5); + ZUb = new mGd(Dkd, Yze); + mVb = new mGd(Sld, sgb(1)); + pVb = new mGd(Vld, (Geb(), true)); + iVb = new A3b(50); + hVb = new mGd(tld, iVb); + _Ub = ald; + jVb = Hld; + $Ub = new mGd(Pkd, false); + gVb = sld; + eVb = mld; + fVb = pld; + dVb = kld; + cVb = ild; + kVb = Lld; + bVb = (OUb(), HUb); + sVb = MUb; + aVb = GUb; + nVb = JUb; + oVb = LUb; + vVb = mmd; + xVb = qmd; + uVb = lmd; + tVb = kmd; + wVb = (mqd(), jqd); + new mGd(nmd, wVb); + } + function VC(a, b) { + var c2; + switch (XC(a)) { + case 6: + return bE(b); + case 7: + return _D(b); + case 8: + return $D(b); + case 3: + return Array.isArray(b) && (c2 = XC(b), !(c2 >= 14 && c2 <= 16)); + case 11: + return b != null && typeof b === kve; + case 12: + return b != null && (typeof b === gve || typeof b == kve); + case 0: + return QD(b, a.__elementTypeId$); + case 2: + return cE(b) && !(b.Tm === keb); + case 1: + return cE(b) && !(b.Tm === keb) || QD(b, a.__elementTypeId$); + default: + return true; + } + } + function oRb(a, b) { + var c2, d, e, f2; + d = $wnd.Math.min($wnd.Math.abs(a.c - (b.c + b.b)), $wnd.Math.abs(a.c + a.b - b.c)); + f2 = $wnd.Math.min($wnd.Math.abs(a.d - (b.d + b.a)), $wnd.Math.abs(a.d + a.a - b.d)); + c2 = $wnd.Math.abs(a.c + a.b / 2 - (b.c + b.b / 2)); + if (c2 > a.b / 2 + b.b / 2) { + return 1; + } + e = $wnd.Math.abs(a.d + a.a / 2 - (b.d + b.a / 2)); + if (e > a.a / 2 + b.a / 2) { + return 1; + } + if (c2 == 0 && e == 0) { + return 0; + } + if (c2 == 0) { + return f2 / e + 1; + } + if (e == 0) { + return d / c2 + 1; + } + return $wnd.Math.min(d / c2, f2 / e) + 1; + } + function oWb(a, b) { + var c2, d, e, f2, g, h, i2; + f2 = 0; + h = 0; + i2 = 0; + for (e = new Anb(a.f.e); e.a < e.c.c.length; ) { + d = RD(ynb(e), 153); + if (b == d) { + continue; + } + g = a.i[b.a][d.a]; + f2 += g; + c2 = bjd(b.d, d.d); + c2 > 0 && a.d != (AWb(), zWb) && (h += g * (d.d.a + a.a[b.a][d.a] * (b.d.a - d.d.a) / c2)); + c2 > 0 && a.d != (AWb(), xWb) && (i2 += g * (d.d.b + a.a[b.a][d.a] * (b.d.b - d.d.b) / c2)); + } + switch (a.d.g) { + case 1: + return new rjd(h / f2, b.d.b); + case 2: + return new rjd(b.d.a, i2 / f2); + default: + return new rjd(h / f2, i2 / f2); + } + } + function xsd(a) { + var b, c2, d, e, f2, g; + c2 = (!a.a && (a.a = new XZd(D4, a, 5)), a.a).i + 2; + g = new cnb(c2); + Rmb(g, new rjd(a.j, a.k)); + FDb(new SDb(null, (!a.a && (a.a = new XZd(D4, a, 5)), new Swb(a.a, 16))), new Usd(g)); + Rmb(g, new rjd(a.b, a.c)); + b = 1; + while (b < g.c.length - 1) { + d = (tFb(b - 1, g.c.length), RD(g.c[b - 1], 8)); + e = (tFb(b, g.c.length), RD(g.c[b], 8)); + f2 = (tFb(b + 1, g.c.length), RD(g.c[b + 1], 8)); + d.a == e.a && e.a == f2.a || d.b == e.b && e.b == f2.b ? Xmb(g, b) : ++b; + } + return g; + } + function zgc(a, b) { + sgc(); + var c2, d, e, f2, g; + g = RD(mQb(a.i, (yCc(), BBc)), 101); + f2 = a.j.g - b.j.g; + if (f2 != 0 || !(g == (Bod(), vod) || g == xod || g == wod)) { + return 0; + } + if (g == (Bod(), vod)) { + c2 = RD(mQb(a, CBc), 17); + d = RD(mQb(b, CBc), 17); + if (!!c2 && !!d) { + e = c2.a - d.a; + if (e != 0) { + return e; + } + } + } + switch (a.j.g) { + case 1: + return Qfb(a.n.a, b.n.a); + case 2: + return Qfb(a.n.b, b.n.b); + case 3: + return Qfb(b.n.a, a.n.a); + case 4: + return Qfb(b.n.b, a.n.b); + default: + throw Adb(new dgb(UAe)); + } + } + function Bkc(a, b) { + var c2, d, e, f2, g, h, i2; + c2 = mGb(pGb(nGb(oGb(new qGb(), b), new Vid(b.e)), kkc), a.a); + b.j.c.length == 0 || eGb(RD(Vmb(b.j, 0), 60).a, c2); + i2 = new cHb(); + Zjb(a.e, c2, i2); + g = new _sb(); + h = new _sb(); + for (f2 = new Anb(b.k); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 18); + Ysb(g, e.c); + Ysb(h, e.d); + } + d = g.a.gc() - h.a.gc(); + if (d < 0) { + aHb(i2, true, (Cmd(), ymd)); + aHb(i2, false, zmd); + } else if (d > 0) { + aHb(i2, false, (Cmd(), ymd)); + aHb(i2, true, zmd); + } + Umb(b.g, new Elc(a, c2)); + Zjb(a.g, b, c2); + } + function Ugb() { + Ugb = geb; + var a; + Qgb = cD(WC(kE, 1), Pwe, 28, 15, [-1, -1, 30, 19, 15, 13, 11, 11, 10, 9, 9, 8, 8, 8, 8, 7, 7, 7, 7, 7, 7, 7, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 5]); + Rgb2 = $C(kE, Pwe, 28, 37, 15, 1); + Sgb = cD(WC(kE, 1), Pwe, 28, 15, [-1, -1, 63, 40, 32, 28, 25, 23, 21, 20, 19, 19, 18, 18, 17, 17, 16, 16, 16, 15, 15, 15, 15, 14, 14, 14, 14, 14, 14, 13, 13, 13, 13, 13, 13, 13, 13]); + Tgb = $C(lE, rxe, 28, 37, 14, 1); + for (a = 2; a <= 36; a++) { + Rgb2[a] = eE($wnd.Math.pow(a, Qgb[a])); + Tgb[a] = Fdb(Sve, Rgb2[a]); + } + } + function tsd(a) { + var b; + if ((!a.a && (a.a = new C5d(F4, a, 6, 6)), a.a).i != 1) { + throw Adb(new agb(tHe + (!a.a && (a.a = new C5d(F4, a, 6, 6)), a.a).i)); + } + b = new Ejd(); + !!BGd(RD(QHd((!a.b && (a.b = new Yie(E4, a, 4, 7)), a.b), 0), 84)) && ye(b, usd(a, BGd(RD(QHd((!a.b && (a.b = new Yie(E4, a, 4, 7)), a.b), 0), 84)), false)); + !!BGd(RD(QHd((!a.c && (a.c = new Yie(E4, a, 5, 8)), a.c), 0), 84)) && ye(b, usd(a, BGd(RD(QHd((!a.c && (a.c = new Yie(E4, a, 5, 8)), a.c), 0), 84)), true)); + return b; + } + function zRc(a, b) { + var c2, d, e, f2, g; + b.d ? e = a.a.c == (wQc(), vQc) ? Z2b(b.b) : a3b(b.b) : e = a.a.c == (wQc(), uQc) ? Z2b(b.b) : a3b(b.b); + f2 = false; + for (d = new is(Mr(e.a.Kc(), new ir())); gs(d); ) { + c2 = RD(hs(d), 18); + g = Heb(a.a.f[a.a.g[b.b.p].p]); + if (!g && !W0b(c2) && c2.c.i.c == c2.d.i.c) { + continue; + } + if (Heb(a.a.n[a.a.g[b.b.p].p]) || Heb(a.a.n[a.a.g[b.b.p].p])) { + continue; + } + f2 = true; + if (Zsb(a.b, a.a.g[rRc(c2, b.b).p])) { + b.c = true; + b.a = c2; + return b; + } + } + b.c = f2; + b.a = null; + return b; + } + function QJd(a, b, c2) { + var d, e, f2, g, h, i2, j; + d = c2.gc(); + if (d == 0) { + return false; + } else { + if (a.Pj()) { + i2 = a.Qj(); + ZId(a, b, c2); + g = d == 1 ? a.Ij(3, null, c2.Kc().Pb(), b, i2) : a.Ij(5, null, c2, b, i2); + if (a.Mj()) { + h = d < 100 ? null : new gLd(d); + f2 = b + d; + for (e = b; e < f2; ++e) { + j = a.xj(e); + h = a.Nj(j, h); + h = h; + } + if (!h) { + a.Jj(g); + } else { + h.nj(g); + h.oj(); + } + } else { + a.Jj(g); + } + } else { + ZId(a, b, c2); + if (a.Mj()) { + h = d < 100 ? null : new gLd(d); + f2 = b + d; + for (e = b; e < f2; ++e) { + h = a.Nj(a.xj(e), h); + } + !!h && h.oj(); + } + } + return true; + } + } + function WJd(a, b, c2) { + var d, e, f2, g, h; + if (a.Pj()) { + e = null; + f2 = a.Qj(); + d = a.Ij(1, h = (g = a.Dj(b, a.Zi(b, c2)), g), c2, b, f2); + if (a.Mj() && !(a.Yi() && !!h ? pb(h, c2) : dE(h) === dE(c2))) { + !!h && (e = a.Oj(h, e)); + e = a.Nj(c2, e); + if (!e) { + a.Jj(d); + } else { + e.nj(d); + e.oj(); + } + } else { + if (!e) { + a.Jj(d); + } else { + e.nj(d); + e.oj(); + } + } + return h; + } else { + h = (g = a.Dj(b, a.Zi(b, c2)), g); + if (a.Mj() && !(a.Yi() && !!h ? pb(h, c2) : dE(h) === dE(c2))) { + e = null; + !!h && (e = a.Oj(h, null)); + e = a.Nj(c2, e); + !!e && e.oj(); + } + return h; + } + } + function nUb(a, b) { + var c2, d, e, f2, g, h, i2, j, k; + a.e = b; + a.f = RD(mQb(b, (JVb(), IVb)), 234); + eUb(b); + a.d = $wnd.Math.max(b.e.c.length * 16 + b.c.c.length, 256); + if (!Heb(TD(mQb(b, (yVb(), _Ub))))) { + k = a.e.e.c.length; + for (i2 = new Anb(b.e); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 153); + j = h.d; + j.a = Iwb(a.f) * k; + j.b = Iwb(a.f) * k; + } + } + c2 = b.b; + for (f2 = new Anb(b.c); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 290); + d = RD(mQb(e, oVb), 17).a; + if (d > 0) { + for (g = 0; g < d; g++) { + Rmb(c2, new WTb(e)); + } + YTb(e); + } + } + } + function NId(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m, n, o2; + m = new OC(a.Zg()); + sC(b, GIe, m); + if (c2 && !a.Xg().a.dc()) { + k = new MB(); + sC(b, "logs", k); + h = 0; + for (o2 = new Ppb(a.Xg().b.Kc()); o2.b.Ob(); ) { + n = WD(o2.b.Pb()); + l = new OC(n); + JB(k, h); + LB(k, h, l); + ++h; + } + } + if (d) { + j = new hC(a.Wg()); + sC(b, "executionTime", j); + } + if (!a.Yg().a.dc()) { + g = new MB(); + sC(b, iIe, g); + h = 0; + for (f2 = new Ppb(a.Yg().b.Kc()); f2.b.Ob(); ) { + e = RD(f2.b.Pb(), 871); + i2 = new uC(); + JB(g, h); + LB(g, h, i2); + NId(e, i2, c2, d); + ++h; + } + } + } + function rue() { + rue = geb; + Gie(); + que = new sue(); + cD(WC(B7, 2), Nve, 381, 0, [cD(WC(B7, 1), _Le, 600, 0, [new oue(wLe)])]); + cD(WC(B7, 2), Nve, 381, 0, [cD(WC(B7, 1), _Le, 600, 0, [new oue(xLe)])]); + cD(WC(B7, 2), Nve, 381, 0, [cD(WC(B7, 1), _Le, 600, 0, [new oue(yLe)]), cD(WC(B7, 1), _Le, 600, 0, [new oue(xLe)])]); + new ejb("-1"); + cD(WC(B7, 2), Nve, 381, 0, [cD(WC(B7, 1), _Le, 600, 0, [new oue("\\c+")])]); + new ejb("0"); + new ejb("0"); + new ejb("1"); + new ejb("0"); + new ejb(ILe); + } + function wac(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l; + b.Ug("Hypernodes processing", 1); + for (e = new Anb(a.b); e.a < e.c.c.length; ) { + d = RD(ynb(e), 30); + for (h = new Anb(d.a); h.a < h.c.c.length; ) { + g = RD(ynb(h), 10); + if (Heb(TD(mQb(g, (yCc(), MAc)))) && g.j.c.length <= 2) { + l = 0; + k = 0; + c2 = 0; + f2 = 0; + for (j = new Anb(g.j); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 12); + switch (i2.j.g) { + case 1: + ++l; + break; + case 2: + ++k; + break; + case 3: + ++c2; + break; + case 4: + ++f2; + } + } + l == 0 && c2 == 0 && vac(a, g, f2 <= k); + } + } + } + b.Vg(); + } + function MUc(a, b, c2, d, e) { + var f2, g, h, i2, j, k, l; + for (g = new Anb(b); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 18); + i2 = f2.c; + if (c2.a._b(i2)) { + j = (dVc(), bVc); + } else if (d.a._b(i2)) { + j = (dVc(), cVc); + } else { + throw Adb(new agb("Source port must be in one of the port sets.")); + } + k = f2.d; + if (c2.a._b(k)) { + l = (dVc(), bVc); + } else if (d.a._b(k)) { + l = (dVc(), cVc); + } else { + throw Adb(new agb("Target port must be in one of the port sets.")); + } + h = new wVc(f2, j, l); + Zjb(a.b, f2, h); + ZEb(e.c, h); + } + } + function i2d(a) { + var b, c2; + if (!!a.c && a.c.Vh()) { + c2 = RD(a.c, 54); + a.c = RD(Vvd(a, c2), 142); + if (a.c != c2) { + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 9, 2, c2, a.c)); + if (ZD(a.Cb, 411)) { + a.Db >> 16 == -15 && a.Cb.Yh() && pKd(new O3d(a.Cb, 9, 13, c2, a.c, fZd(o4d(RD(a.Cb, 62)), a))); + } else if (ZD(a.Cb, 90)) { + if (a.Db >> 16 == -23 && a.Cb.Yh()) { + b = a.c; + ZD(b, 90) || (b = (JTd(), zTd)); + ZD(c2, 90) || (c2 = (JTd(), zTd)); + pKd(new O3d(a.Cb, 9, 10, c2, b, fZd(tYd(RD(a.Cb, 29)), a))); + } + } + } + } + return a.c; + } + function lac(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l; + c2.Ug("Hyperedge merging", 1); + jac(a, b); + i2 = new Jkb(b.b, 0); + while (i2.b < i2.d.gc()) { + h = (sFb(i2.b < i2.d.gc()), RD(i2.d.Xb(i2.c = i2.b++), 30)); + k = h.a; + if (k.c.length == 0) { + continue; + } + d = null; + e = null; + f2 = null; + g = null; + for (j = 0; j < k.c.length; j++) { + d = (tFb(j, k.c.length), RD(k.c[j], 10)); + e = d.k; + if (e == (r3b(), o3b) && g == o3b) { + l = hac(d, f2); + if (l.a) { + kac(d, f2, l.b, l.c); + tFb(j, k.c.length); + $Eb(k.c, j, 1); + --j; + d = f2; + e = g; + } + } + f2 = d; + g = e; + } + } + c2.Vg(); + } + function U$d(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2; + if (b == c2) { + return true; + } else { + b = V$d(a, b); + c2 = V$d(a, c2); + d = h2d(b); + if (d) { + k = h2d(c2); + if (k != d) { + if (!k) { + return false; + } else { + i2 = d.mk(); + o2 = k.mk(); + return i2 == o2 && i2 != null; + } + } else { + g = (!b.d && (b.d = new XZd(o7, b, 1)), b.d); + f2 = g.i; + m = (!c2.d && (c2.d = new XZd(o7, c2, 1)), c2.d); + if (f2 == m.i) { + for (j = 0; j < f2; ++j) { + e = RD(QHd(g, j), 89); + l = RD(QHd(m, j), 89); + if (!U$d(a, e, l)) { + return false; + } + } + } + return true; + } + } else { + h = b.e; + n = c2.e; + return h == n; + } + } + } + function vge(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l; + if (qke(a.e, b)) { + l = pke(a.e.Dh(), b); + f2 = RD(a.g, 124); + k = null; + i2 = -1; + h = -1; + e = 0; + for (j = 0; j < a.i; ++j) { + g = f2[j]; + if (l.am(g.Lk())) { + e == c2 && (i2 = j); + if (e == d) { + h = j; + k = g.md(); + } + ++e; + } + } + if (i2 == -1) { + throw Adb(new veb(MIe + c2 + NIe + e)); + } + if (h == -1) { + throw Adb(new veb(OIe + d + NIe + e)); + } + uLd(a, i2, h); + Mvd(a.e) && eZd(a, fge(a, 7, b, sgb(d), k, c2, true)); + return k; + } else { + throw Adb(new agb("The feature must be many-valued to support move")); + } + } + function j2b(a, b, c2, d) { + var e, f2, g, h, i2; + i2 = new sjd(b.n); + i2.a += b.o.a / 2; + i2.b += b.o.b / 2; + h = Kfb(UD(mQb(b, (yCc(), ABc)))); + f2 = a.f; + g = a.d; + e = a.c; + switch (RD(mQb(b, (Ywc(), hwc)), 64).g) { + case 1: + i2.a += g.b + e.a - c2 / 2; + i2.b = -d - h; + b.n.b = -(g.d + h + e.b); + break; + case 2: + i2.a = f2.a + g.b + g.c + h; + i2.b += g.d + e.b - d / 2; + b.n.a = f2.a + g.c + h - e.a; + break; + case 3: + i2.a += g.b + e.a - c2 / 2; + i2.b = f2.b + g.d + g.a + h; + b.n.b = f2.b + g.a + h - e.b; + break; + case 4: + i2.a = -c2 - h; + i2.b += g.d + e.b - d / 2; + b.n.a = -(g.b + h + e.a); + } + return i2; + } + function Z4b(a) { + var b, c2, d, e, f2, g; + d = new d1b(); + kQb(d, a); + dE(mQb(d, (yCc(), rAc))) === dE((Cmd(), Amd)) && pQb(d, rAc, i2b(d)); + if (mQb(d, (rid(), qid)) == null) { + g = RD(Lje(a), 167); + pQb(d, qid, fE(g.of(qid))); + } + pQb(d, (Ywc(), Awc), a); + pQb(d, kwc, (b = RD(mfb(iX), 9), new Fsb(b, RD(WEb(b, b.length), 9), 0))); + e = FJb((!vCd(a) ? null : (lud(), new zud(vCd(a))), lud(), new Fud(!vCd(a) ? null : new zud(vCd(a)), a)), zmd); + f2 = RD(mQb(d, qBc), 107); + c2 = d.d; + B2b(c2, f2); + B2b(c2, e); + return d; + } + function Nec(a, b, c2) { + var d, e; + d = b.c.i; + e = c2.d.i; + if (d.k == (r3b(), o3b)) { + pQb(a, (Ywc(), vwc), RD(mQb(d, vwc), 12)); + pQb(a, wwc, RD(mQb(d, wwc), 12)); + pQb(a, uwc, TD(mQb(d, uwc))); + } else if (d.k == n3b) { + pQb(a, (Ywc(), vwc), RD(mQb(d, vwc), 12)); + pQb(a, wwc, RD(mQb(d, wwc), 12)); + pQb(a, uwc, (Geb(), true)); + } else if (e.k == n3b) { + pQb(a, (Ywc(), vwc), RD(mQb(e, vwc), 12)); + pQb(a, wwc, RD(mQb(e, wwc), 12)); + pQb(a, uwc, (Geb(), true)); + } else { + pQb(a, (Ywc(), vwc), b.c); + pQb(a, wwc, c2.d); + } + } + function wJb(a) { + var b, c2, d, e, f2, g, h; + a.o = new wmb(); + d = new Yub(); + for (g = new Anb(a.e.a); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 125); + CIb(f2).c.length == 1 && (Pub(d, f2, d.c.b, d.c), true); + } + while (d.b != 0) { + f2 = RD(d.b == 0 ? null : (sFb(d.b != 0), Wub(d, d.a.a)), 125); + if (CIb(f2).c.length == 0) { + continue; + } + b = RD(Vmb(CIb(f2), 0), 218); + c2 = f2.g.a.c.length > 0; + h = oIb(b, f2); + c2 ? FIb(h.b, b) : FIb(h.g, b); + CIb(h).c.length == 1 && (Pub(d, h, d.c.b, d.c), true); + e = new Ptd(f2, b); + hmb(a.o, e); + Ymb(a.e.a, f2); + } + } + function SQb(a, b) { + var c2, d, e, f2, g, h, i2; + d = $wnd.Math.abs(Oid(a.b).a - Oid(b.b).a); + h = $wnd.Math.abs(Oid(a.b).b - Oid(b.b).b); + e = 0; + i2 = 0; + c2 = 1; + g = 1; + if (d > a.b.b / 2 + b.b.b / 2) { + e = $wnd.Math.min($wnd.Math.abs(a.b.c - (b.b.c + b.b.b)), $wnd.Math.abs(a.b.c + a.b.b - b.b.c)); + c2 = 1 - e / d; + } + if (h > a.b.a / 2 + b.b.a / 2) { + i2 = $wnd.Math.min($wnd.Math.abs(a.b.d - (b.b.d + b.b.a)), $wnd.Math.abs(a.b.d + a.b.a - b.b.d)); + g = 1 - i2 / h; + } + f2 = $wnd.Math.min(c2, g); + return (1 - f2) * $wnd.Math.sqrt(d * d + h * h); + } + function LUc(a) { + var b, c2, d, e; + NUc(a, a.e, a.f, (dVc(), bVc), true, a.c, a.i); + NUc(a, a.e, a.f, bVc, false, a.c, a.i); + NUc(a, a.e, a.f, cVc, true, a.c, a.i); + NUc(a, a.e, a.f, cVc, false, a.c, a.i); + MUc(a, a.c, a.e, a.f, a.i); + d = new Jkb(a.i, 0); + while (d.b < d.d.gc()) { + b = (sFb(d.b < d.d.gc()), RD(d.d.Xb(d.c = d.b++), 131)); + e = new Jkb(a.i, d.b); + while (e.b < e.d.gc()) { + c2 = (sFb(e.b < e.d.gc()), RD(e.d.Xb(e.c = e.b++), 131)); + KUc(b, c2); + } + } + WUc(a.i, RD(mQb(a.d, (Ywc(), Lwc)), 234)); + ZUc(a.i); + } + function FXd(a, b) { + var c2, d; + if (b != null) { + d = DXd(a); + if (d) { + if ((d.i & 1) != 0) { + if (d == xdb) { + return $D(b); + } else if (d == kE) { + return ZD(b, 17); + } else if (d == jE) { + return ZD(b, 161); + } else if (d == gE) { + return ZD(b, 222); + } else if (d == hE) { + return ZD(b, 180); + } else if (d == iE) { + return _D(b); + } else if (d == wdb) { + return ZD(b, 191); + } else if (d == lE) { + return ZD(b, 168); + } + } else { + return PRd(), c2 = RD(Wjb(ORd, d), 57), !c2 || c2.fk(b); + } + } else if (ZD(b, 58)) { + return a.dl(RD(b, 58)); + } + } + return false; + } + function zqe() { + zqe = geb; + var a, b, c2, d, e, f2, g, h, i2; + xqe = $C(gE, YHe, 28, 255, 15, 1); + yqe = $C(hE, zwe, 28, 64, 15, 1); + for (b = 0; b < 255; b++) { + xqe[b] = -1; + } + for (c2 = 90; c2 >= 65; c2--) { + xqe[c2] = c2 - 65 << 24 >> 24; + } + for (d = 122; d >= 97; d--) { + xqe[d] = d - 97 + 26 << 24 >> 24; + } + for (e = 57; e >= 48; e--) { + xqe[e] = e - 48 + 52 << 24 >> 24; + } + xqe[43] = 62; + xqe[47] = 63; + for (f2 = 0; f2 <= 25; f2++) + yqe[f2] = 65 + f2 & Bwe; + for (g = 26, i2 = 0; g <= 51; ++g, i2++) + yqe[g] = 97 + i2 & Bwe; + for (a = 52, h = 0; a <= 61; ++a, h++) + yqe[a] = 48 + h & Bwe; + yqe[62] = 43; + yqe[63] = 47; + } + function uib(a, b) { + var c2, d, e, f2, g, h; + e = xib(a); + h = xib(b); + if (e == h) { + if (a.e == b.e && a.a < 54 && b.a < 54) { + return a.f < b.f ? -1 : a.f > b.f ? 1 : 0; + } + d = a.e - b.e; + c2 = (a.d > 0 ? a.d : $wnd.Math.floor((a.a - 1) * xxe) + 1) - (b.d > 0 ? b.d : $wnd.Math.floor((b.a - 1) * xxe) + 1); + if (c2 > d + 1) { + return e; + } else if (c2 < d - 1) { + return -e; + } else { + f2 = (!a.c && (a.c = ojb(Hdb(a.f))), a.c); + g = (!b.c && (b.c = ojb(Hdb(b.f))), b.c); + d < 0 ? f2 = Wib(f2, Sjb(-d)) : d > 0 && (g = Wib(g, Sjb(d))); + return Qib(f2, g); + } + } else + return e < h ? -1 : 1; + } + function pUb(a, b, c2) { + var d, e, f2, g, h, i2, j, k; + c2.Ug(Pze, 1); + a.vf(b); + f2 = 0; + while (a.xf(f2) && !c2.$g()) { + a.wf(); + for (k = Fl(Al(cD(WC(cJ, 1), rve, 20, 0, [b.e, b.d, b.b]))); gs(k); ) { + i2 = RD(hs(k), 309); + for (h = Fl(Al(cD(WC(cJ, 1), rve, 20, 0, [b.e, b.d, b.b]))); gs(h); ) { + g = RD(hs(h), 309); + if (g != i2) { + e = a.uf(g, i2); + !!e && $id(i2.c, e); + } + } + } + for (j = Fl(Al(cD(WC(cJ, 1), rve, 20, 0, [b.e, b.d, b.b]))); gs(j); ) { + i2 = RD(hs(j), 309); + d = i2.c; + _id(d, -a.d, -a.d, a.d, a.d); + $id(i2.d, d); + d.a = 0; + d.b = 0; + } + ++f2; + } + c2.Vg(); + } + function H$b(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n; + if (a.dc()) { + return new pjd(); + } + j = 0; + l = 0; + for (e = a.Kc(); e.Ob(); ) { + d = RD(e.Pb(), 36); + f2 = d.f; + j = $wnd.Math.max(j, f2.a); + l += f2.a * f2.b; + } + j = $wnd.Math.max(j, $wnd.Math.sqrt(l) * Kfb(UD(mQb(RD(a.Kc().Pb(), 36), (yCc(), Tzc))))); + m = 0; + n = 0; + i2 = 0; + c2 = b; + for (h = a.Kc(); h.Ob(); ) { + g = RD(h.Pb(), 36); + k = g.f; + if (m + k.a > j) { + m = 0; + n += i2 + b; + i2 = 0; + } + w$b(g, m, n); + c2 = $wnd.Math.max(c2, m + k.a); + i2 = $wnd.Math.max(i2, k.b); + m += k.a + b; + } + return new rjd(c2 + b, n + i2 + b); + } + function osd(a, b) { + var c2, d, e, f2, g, h, i2; + if (!MCd(a)) { + throw Adb(new dgb(sHe)); + } + d = MCd(a); + f2 = d.g; + e = d.f; + if (f2 <= 0 && e <= 0) { + return qpd(), opd; + } + h = a.i; + i2 = a.j; + switch (b.g) { + case 2: + case 1: + if (h < 0) { + return qpd(), ppd; + } else if (h + a.g > f2) { + return qpd(), Xod; + } + break; + case 4: + case 3: + if (i2 < 0) { + return qpd(), Yod; + } else if (i2 + a.f > e) { + return qpd(), npd; + } + } + g = (h + a.g / 2) / f2; + c2 = (i2 + a.f / 2) / e; + return g + c2 <= 1 && g - c2 <= 0 ? (qpd(), ppd) : g + c2 >= 1 && g - c2 >= 0 ? (qpd(), Xod) : c2 < 0.5 ? (qpd(), Yod) : (qpd(), npd); + } + function Djb(a, b, c2, d, e) { + var f2, g; + f2 = Bdb(Cdb(b[0], yxe), Cdb(d[0], yxe)); + a[0] = Ydb(f2); + f2 = Tdb(f2, 32); + if (c2 >= e) { + for (g = 1; g < e; g++) { + f2 = Bdb(f2, Bdb(Cdb(b[g], yxe), Cdb(d[g], yxe))); + a[g] = Ydb(f2); + f2 = Tdb(f2, 32); + } + for (; g < c2; g++) { + f2 = Bdb(f2, Cdb(b[g], yxe)); + a[g] = Ydb(f2); + f2 = Tdb(f2, 32); + } + } else { + for (g = 1; g < c2; g++) { + f2 = Bdb(f2, Bdb(Cdb(b[g], yxe), Cdb(d[g], yxe))); + a[g] = Ydb(f2); + f2 = Tdb(f2, 32); + } + for (; g < e; g++) { + f2 = Bdb(f2, Cdb(d[g], yxe)); + a[g] = Ydb(f2); + f2 = Tdb(f2, 32); + } + } + Ddb(f2, 0) != 0 && (a[g] = Ydb(f2)); + } + function yte(a) { + Vse(); + var b, c2, d, e, f2, g; + if (a.e != 4 && a.e != 5) + throw Adb(new agb("Token#complementRanges(): must be RANGE: " + a.e)); + f2 = a; + vte(f2); + ste(f2); + d = f2.b.length + 2; + f2.b[0] == 0 && (d -= 2); + c2 = f2.b[f2.b.length - 1]; + c2 == MLe && (d -= 2); + e = new xte(4); + e.b = $C(kE, Pwe, 28, d, 15, 1); + g = 0; + if (f2.b[0] > 0) { + e.b[g++] = 0; + e.b[g++] = f2.b[0] - 1; + } + for (b = 1; b < f2.b.length - 2; b += 2) { + e.b[g++] = f2.b[b] + 1; + e.b[g++] = f2.b[b + 1] - 1; + } + if (c2 != MLe) { + e.b[g++] = c2 + 1; + e.b[g] = MLe; + } + e.a = true; + return e; + } + function zac(a, b) { + var c2, d, e, f2, g, h, i2, j, k; + b.Ug("Layer constraint edge reversal", 1); + for (g = new Anb(a.b); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 30); + k = -1; + c2 = new bnb(); + j = t2b(f2.a); + for (e = 0; e < j.length; e++) { + d = RD(mQb(j[e], (Ywc(), owc)), 311); + if (k == -1) { + d != (Gvc(), Fvc) && (k = e); + } else { + if (d == (Gvc(), Fvc)) { + g3b(j[e], null); + f3b(j[e], k++, f2); + } + } + d == (Gvc(), Dvc) && (ZEb(c2.c, j[e]), true); + } + for (i2 = new Anb(c2); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 10); + g3b(h, null); + g3b(h, f2); + } + } + b.Vg(); + } + function nLd(a, b, c2) { + var d, e, f2, g, h, i2, j, k; + d = c2.gc(); + if (d == 0) { + return false; + } else { + if (a.Pj()) { + j = a.Qj(); + IHd(a, b, c2); + g = d == 1 ? a.Ij(3, null, c2.Kc().Pb(), b, j) : a.Ij(5, null, c2, b, j); + if (a.Mj()) { + h = d < 100 ? null : new gLd(d); + f2 = b + d; + for (e = b; e < f2; ++e) { + k = a.g[e]; + h = a.Nj(k, h); + h = a.Uj(k, h); + } + if (!h) { + a.Jj(g); + } else { + h.nj(g); + h.oj(); + } + } else { + a.Jj(g); + } + } else { + IHd(a, b, c2); + if (a.Mj()) { + h = d < 100 ? null : new gLd(d); + f2 = b + d; + for (e = b; e < f2; ++e) { + i2 = a.g[e]; + h = a.Nj(i2, h); + } + !!h && h.oj(); + } + } + return true; + } + } + function m9b(a, b) { + var c2, d, e, f2, g, h, i2, j, k; + b.Ug("Hierarchical port dummy size processing", 1); + i2 = new bnb(); + k = new bnb(); + d = Kfb(UD(mQb(a, (yCc(), UBc)))); + c2 = d * 2; + for (f2 = new Anb(a.b); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 30); + i2.c.length = 0; + k.c.length = 0; + for (h = new Anb(e.a); h.a < h.c.c.length; ) { + g = RD(ynb(h), 10); + if (g.k == (r3b(), m3b)) { + j = RD(mQb(g, (Ywc(), hwc)), 64); + j == (qpd(), Yod) ? (ZEb(i2.c, g), true) : j == npd && (ZEb(k.c, g), true); + } + } + n9b(i2, true, c2); + n9b(k, false, c2); + } + b.Vg(); + } + function wSc(a, b, c2, d) { + var e, f2, g, h, i2; + for (g = new Anb(a.k); g.a < g.c.c.length; ) { + e = RD(ynb(g), 132); + if (!d || e.c == (fTc(), dTc)) { + i2 = e.b; + if (i2.g < 0 && e.d > 0) { + PSc(i2, i2.d - e.d); + e.c == (fTc(), dTc) && NSc(i2, i2.a - e.d); + i2.d <= 0 && i2.i > 0 && (Pub(b, i2, b.c.b, b.c), true); + } + } + } + for (f2 = new Anb(a.f); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 132); + if (!d || e.c == (fTc(), dTc)) { + h = e.a; + if (h.g < 0 && e.d > 0) { + QSc(h, h.i - e.d); + e.c == (fTc(), dTc) && OSc(h, h.b - e.d); + h.i <= 0 && h.d > 0 && (Pub(c2, h, c2.c.b, c2.c), true); + } + } + } + } + function drd(a, b, c2, d, e) { + var f2, g, h, i2, j, k, l, m, n; + yob(); + _mb(a, new Mrd()); + g = gv(a); + n = new bnb(); + m = new bnb(); + h = null; + i2 = 0; + while (g.b != 0) { + f2 = RD(g.b == 0 ? null : (sFb(g.b != 0), Wub(g, g.a.a)), 163); + if (!h || urd(h) * trd(h) / 2 < urd(f2) * trd(f2)) { + h = f2; + ZEb(n.c, f2); + } else { + i2 += urd(f2) * trd(f2); + ZEb(m.c, f2); + if (m.c.length > 1 && (i2 > urd(h) * trd(h) / 2 || g.b == 0)) { + l = new zrd(m); + k = urd(h) / trd(h); + j = ird(l, b, new z3b(), c2, d, e, k); + $id(hjd(l.e), j); + h = l; + ZEb(n.c, l); + i2 = 0; + m.c.length = 0; + } + } + } + Tmb(n, m); + return n; + } + function hib(a, b, c2, d, e) { + gib(); + var f2, g, h, i2, j, k, l; + vFb(a, "src"); + vFb(c2, "dest"); + l = rb(a); + i2 = rb(c2); + qFb((l.i & 4) != 0, "srcType is not an array"); + qFb((i2.i & 4) != 0, "destType is not an array"); + k = l.c; + g = i2.c; + qFb((k.i & 1) != 0 ? k == g : (g.i & 1) == 0, "Array types don't match"); + iib(a, b, c2, d, e); + if ((k.i & 1) == 0 && l != i2) { + j = SD(a); + f2 = SD(c2); + if (dE(a) === dE(c2) && b < d) { + b += e; + for (h = d + e; h-- > d; ) { + bD(f2, h, j[--b]); + } + } else { + for (h = d + e; d < h; ) { + bD(f2, d++, j[b++]); + } + } + } else { + VEb(a, b, c2, d, e, true); + } + } + function crd(a, b) { + var c2, d, e, f2, g, h, i2, j, k; + b.Ug("Box layout", 2); + e = Mfb(UD(Gxd(a, (hkd(), gkd)))); + f2 = RD(Gxd(a, dkd), 107); + c2 = Heb(TD(Gxd(a, $jd))); + d = Heb(TD(Gxd(a, _jd))); + switch (RD(Gxd(a, Yjd), 320).g) { + case 0: + g = (k = new dnb((!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a)), yob(), _mb(k, new prd(d)), k); + h = vsd(a); + i2 = UD(Gxd(a, Xjd)); + (i2 == null || (uFb(i2), i2) <= 0) && (i2 = 1.3); + j = grd(g, e, f2, h.a, h.b, c2, (uFb(i2), i2)); + Esd(a, j.a, j.b, false, true); + break; + default: + hrd(a, e, f2, c2); + } + b.Vg(); + } + function uUc(a, b, c2, d, e) { + var f2, g, h, i2, j, k, l, m, n, o2; + m = tUc(a, c2); + for (i2 = 0; i2 < b; i2++) { + Ikb(e, c2); + n = new bnb(); + o2 = (sFb(d.b < d.d.gc()), RD(d.d.Xb(d.c = d.b++), 418)); + for (k = m + i2; k < a.b; k++) { + h = o2; + o2 = (sFb(d.b < d.d.gc()), RD(d.d.Xb(d.c = d.b++), 418)); + Rmb(n, new AUc(h, o2, c2)); + } + for (l = m + i2; l < a.b; l++) { + sFb(d.b > 0); + d.a.Xb(d.c = --d.b); + l > m + i2 && Ckb(d); + } + for (g = new Anb(n); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 418); + Ikb(d, f2); + } + if (i2 < b - 1) { + for (j = m + i2; j < a.b; j++) { + sFb(d.b > 0); + d.a.Xb(d.c = --d.b); + } + } + } + } + function gte() { + Vse(); + var a, b, c2, d, e, f2; + if (Fse) + return Fse; + a = new xte(4); + ute(a, hte(WLe, true)); + wte(a, hte("M", true)); + wte(a, hte("C", true)); + f2 = new xte(4); + for (d = 0; d < 11; d++) { + rte(f2, d, d); + } + b = new xte(4); + ute(b, hte("M", true)); + rte(b, 4448, 4607); + rte(b, 65438, 65439); + e = new iue(2); + hue2(e, a); + hue2(e, Ese); + c2 = new iue(2); + c2.Jm($se(f2, hte("L", true))); + c2.Jm(b); + c2 = new Kte(3, c2); + c2 = new Qte(e, c2); + Fse = c2; + return Fse; + } + function vhb(a, b) { + var c2, d, e, f2, g, h, i2, j; + c2 = new RegExp(b, "g"); + i2 = $C(qJ, Nve, 2, 0, 6, 1); + d = 0; + j = a; + f2 = null; + while (true) { + h = c2.exec(j); + if (h == null || j == "") { + i2[d] = j; + break; + } else { + g = h.index; + i2[d] = (AFb(0, g, j.length), j.substr(0, g)); + j = zhb(j, g + h[0].length, j.length); + c2.lastIndex = 0; + if (f2 == j) { + i2[d] = (AFb(0, 1, j.length), j.substr(0, 1)); + j = (BFb(1, j.length + 1), j.substr(1)); + } + f2 = j; + ++d; + } + } + if (a.length > 0) { + e = i2.length; + while (e > 0 && i2[e - 1] == "") { + --e; + } + e < i2.length && (i2.length = e); + } + return i2; + } + function h_c() { + h_c = geb; + U$c = new A3b(20); + T$c = new mGd((umd(), tld), U$c); + _$c = new mGd(fmd, 20); + $$c = new mGd(_ld, 3); + E$c = new mGd(Dkd, Yze); + X$c = new mGd(Rld, sgb(1)); + Z$c = new mGd(Vld, (Geb(), true)); + G$c = Mkd; + I$c = (Cmd(), Amd); + H$c = new mGd(Nkd, I$c); + L$c = ald; + M$c = bld; + O$c = kld; + P$c = mld; + Q$c = nld; + R$c = pld; + N$c = ild; + S$c = sld; + V$c = Lld; + g_c = (B$c(), z$c); + Y$c = w$c; + c_c = mmd; + e_c = qmd; + b_c = lmd; + a_c = kmd; + d_c = (mqd(), jqd); + new mGd(nmd, d_c); + W$c = v$c; + K$c = t$c; + f_c = y$c; + F$c = r$c; + J$c = s$c; + } + function bgd(a) { + var b, c2; + b = WD(Gxd(a, (umd(), Akd))); + if (cgd(b, a)) { + return; + } + if (!Hxd(a, Tld) && ((!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a).i != 0 || Heb(TD(Gxd(a, $kd))))) { + if (b == null || Dhb(b).length == 0) { + if (!cgd(sxe, a)) { + c2 = Zhb(Zhb(new dib("Unable to load default layout algorithm "), sxe), " for unconfigured node "); + Csd(a, c2); + throw Adb(new Jed(c2.a)); + } + } else { + c2 = Zhb(Zhb(new dib("Layout algorithm '"), b), "' not found for "); + Csd(a, c2); + throw Adb(new Jed(c2.a)); + } + } + } + function $Kb(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n; + c2 = a.i; + b = a.n; + if (a.b == 0) { + n = c2.c + b.b; + m = c2.b - b.b - b.c; + for (g = a.a, i2 = 0, k = g.length; i2 < k; ++i2) { + e = g[i2]; + dKb(e, n, m); + } + } else { + d = bLb(a, false); + dKb(a.a[0], c2.c + b.b, d[0]); + dKb(a.a[2], c2.c + c2.b - b.c - d[2], d[2]); + l = c2.b - b.b - b.c; + if (d[0] > 0) { + l -= d[0] + a.c; + d[0] += a.c; + } + d[2] > 0 && (l -= d[2] + a.c); + d[1] = $wnd.Math.max(d[1], l); + dKb(a.a[1], c2.c + b.b + d[0] - (d[1] - l) / 2, d[1]); + } + for (f2 = a.a, h = 0, j = f2.length; h < j; ++h) { + e = f2[h]; + ZD(e, 336) && RD(e, 336).lf(); + } + } + function iRc(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l; + l = new hRc(); + l.d = 0; + for (g = new Anb(a.b); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 30); + l.d += f2.a.c.length; + } + d = 0; + e = 0; + l.a = $C(kE, Pwe, 28, a.b.c.length, 15, 1); + j = 0; + k = 0; + l.e = $C(kE, Pwe, 28, l.d, 15, 1); + for (c2 = new Anb(a.b); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 30); + b.p = d++; + l.a[b.p] = e++; + k = 0; + for (i2 = new Anb(b.a); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 10); + h.p = j++; + l.e[h.p] = k++; + } + } + l.c = new mRc(l); + l.b = ev(l.d); + jRc(l, a); + l.f = ev(l.d); + kRc(l, a); + return l; + } + function M9c(a, b) { + var c2, d, e, f2; + f2 = RD(Vmb(a.n, a.n.c.length - 1), 209).d; + a.p = $wnd.Math.min(a.p, b.g); + a.r = $wnd.Math.max(a.r, f2); + a.g = $wnd.Math.max(a.g, b.g + (a.b.c.length == 1 ? 0 : a.i)); + a.o = $wnd.Math.min(a.o, b.f); + a.e += b.f + (a.b.c.length == 1 ? 0 : a.i); + a.f = $wnd.Math.max(a.f, b.f); + e = a.n.c.length > 0 ? (a.n.c.length - 1) * a.i : 0; + for (d = new Anb(a.n); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 209); + e += c2.a; + } + a.d = e; + a.a = a.e / a.b.c.length - a.i * ((a.b.c.length - 1) / a.b.c.length); + Ead(a.j); + } + function CTb(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l; + k = TD(mQb(b, (yVb(), pVb))); + if (k == null || (uFb(k), k)) { + l = $C(xdb, Hye, 28, b.e.c.length, 16, 1); + g = yTb(b); + e = new Yub(); + for (j = new Anb(b.e); j.a < j.c.c.length; ) { + h = RD(ynb(j), 153); + c2 = zTb(a, h, null, null, l, g); + if (c2) { + kQb(c2, b); + Pub(e, c2, e.c.b, e.c); + } + } + if (e.b > 1) { + for (d = Sub(e, 0); d.b != d.d.c; ) { + c2 = RD(evb(d), 235); + f2 = 0; + for (i2 = new Anb(c2.e); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 153); + h.a = f2++; + } + } + } + return e; + } + return dv(cD(WC(tP, 1), Jze, 235, 0, [b])); + } + function rYd(a) { + var b, c2, d, e, f2, g, h; + if (!a.g) { + h = new Z$d(); + b = iYd; + g = b.a.zc(a, b); + if (g == null) { + for (d = new dMd(zYd(a)); d.e != d.i.gc(); ) { + c2 = RD(bMd(d), 29); + YGd(h, rYd(c2)); + } + b.a.Bc(a) != null; + b.a.gc() == 0 && void 0; + } + e = h.i; + for (f2 = (!a.s && (a.s = new C5d(y7, a, 21, 17)), new dMd(a.s)); f2.e != f2.i.gc(); ++e) { + BWd(RD(bMd(f2), 462), e); + } + YGd(h, (!a.s && (a.s = new C5d(y7, a, 21, 17)), a.s)); + VHd(h); + a.g = new R$d(a, h); + a.i = RD(h.g, 254); + a.i == null && (a.i = kYd); + a.p = null; + yYd(a).b &= -5; + } + return a.g; + } + function yee(a, b) { + var c2, d, e, f2, g, h, i2, j, k; + c2 = b.qi(a.a); + if (c2) { + i2 = WD($Nd((!c2.b && (c2.b = new SVd((JTd(), FTd), C8, c2)), c2.b), "memberTypes")); + if (i2 != null) { + j = new bnb(); + for (f2 = vhb(i2, "\\w"), g = 0, h = f2.length; g < h; ++g) { + e = f2[g]; + d = e.lastIndexOf("#"); + k = d == -1 ? Wee(a, b.jk(), e) : d == 0 ? Vee(a, null, (BFb(1, e.length + 1), e.substr(1))) : Vee(a, (AFb(0, d, e.length), e.substr(0, d)), (BFb(d + 1, e.length + 1), e.substr(d + 1))); + ZD(k, 156) && Rmb(j, RD(k, 156)); + } + return j; + } + } + return yob(), yob(), vob; + } + function _Kb(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n, o2; + d = a.i; + c2 = a.n; + if (a.b == 0) { + b = aLb(a, false); + eKb(a.a[0], d.d + c2.d, b[0]); + eKb(a.a[2], d.d + d.a - c2.a - b[2], b[2]); + m = d.a - c2.d - c2.a; + l = m; + if (b[0] > 0) { + b[0] += a.c; + l -= b[0]; + } + b[2] > 0 && (l -= b[2] + a.c); + b[1] = $wnd.Math.max(b[1], l); + eKb(a.a[1], d.d + c2.d + b[0] - (b[1] - l) / 2, b[1]); + } else { + o2 = d.d + c2.d; + n = d.a - c2.d - c2.a; + for (g = a.a, i2 = 0, k = g.length; i2 < k; ++i2) { + e = g[i2]; + eKb(e, o2, n); + } + } + for (f2 = a.a, h = 0, j = f2.length; h < j; ++h) { + e = f2[h]; + ZD(e, 336) && RD(e, 336).mf(); + } + } + function Erc(a) { + var b, c2, d, e, f2, g, h, i2, j, k; + k = $C(kE, Pwe, 28, a.b.c.length + 1, 15, 1); + j = new _sb(); + d = 0; + for (f2 = new Anb(a.b); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 30); + k[d++] = j.a.gc(); + for (i2 = new Anb(e.a); i2.a < i2.c.c.length; ) { + g = RD(ynb(i2), 10); + for (c2 = new is(Mr(a3b(g).a.Kc(), new ir())); gs(c2); ) { + b = RD(hs(c2), 18); + j.a.zc(b, j); + } + } + for (h = new Anb(e.a); h.a < h.c.c.length; ) { + g = RD(ynb(h), 10); + for (c2 = new is(Mr(Z2b(g).a.Kc(), new ir())); gs(c2); ) { + b = RD(hs(c2), 18); + j.a.Bc(b) != null; + } + } + } + return k; + } + function dge(a, b, c2, d) { + var e, f2, g, h, i2; + i2 = pke(a.e.Dh(), b); + e = RD(a.g, 124); + nke(); + if (RD(b, 69).xk()) { + for (g = 0; g < a.i; ++g) { + f2 = e[g]; + if (i2.am(f2.Lk()) && pb(f2, c2)) { + return true; + } + } + } else if (c2 != null) { + for (h = 0; h < a.i; ++h) { + f2 = e[h]; + if (i2.am(f2.Lk()) && pb(c2, f2.md())) { + return true; + } + } + if (d) { + for (g = 0; g < a.i; ++g) { + f2 = e[g]; + if (i2.am(f2.Lk()) && dE(c2) === dE(Age(a, RD(f2.md(), 58)))) { + return true; + } + } + } + } else { + for (g = 0; g < a.i; ++g) { + f2 = e[g]; + if (i2.am(f2.Lk()) && f2.md() == null) { + return false; + } + } + } + return false; + } + function wee(a, b) { + var c2, d, e, f2, g, h; + c2 = b.qi(a.a); + if (c2) { + h = WD($Nd((!c2.b && (c2.b = new SVd((JTd(), FTd), C8, c2)), c2.b), FIe)); + if (h != null) { + e = thb(h, Fhb(35)); + d = b.qk(); + if (e == -1) { + g = Uee(a, BXd(d)); + f2 = h; + } else if (e == 0) { + g = null; + f2 = (BFb(1, h.length + 1), h.substr(1)); + } else { + g = (AFb(0, e, h.length), h.substr(0, e)); + f2 = (BFb(e + 1, h.length + 1), h.substr(e + 1)); + } + switch (yfe(Qee(a, b))) { + case 2: + case 3: { + return Jee(a, d, g, f2); + } + case 0: + case 4: + case 5: + case 6: { + return Mee(a, d, g, f2); + } + } + } + } + return null; + } + function FQb(a, b, c2, d) { + var e, f2, g, h; + h = c2; + for (g = new Anb(b.a); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 225); + e = RD(f2.b, 68); + if ($y(a.b.c, e.b.c + e.b.b) <= 0 && $y(e.b.c, a.b.c + a.b.b) <= 0 && $y(a.b.d, e.b.d + e.b.a) <= 0 && $y(e.b.d, a.b.d + a.b.a) <= 0) { + if ($y(e.b.c, a.b.c + a.b.b) == 0 && d.a < 0 || $y(e.b.c + e.b.b, a.b.c) == 0 && d.a > 0 || $y(e.b.d, a.b.d + a.b.a) == 0 && d.b < 0 || $y(e.b.d + e.b.a, a.b.d) == 0 && d.b > 0) { + h = 0; + break; + } + } else { + h = $wnd.Math.min(h, PQb(a, e, d)); + } + h = $wnd.Math.min(h, FQb(a, f2, h, d)); + } + return h; + } + function lsd(a, b) { + var c2, d, e, f2, g, h, i2; + if (a.b < 2) { + throw Adb(new agb("The vector chain must contain at least a source and a target point.")); + } + e = (sFb(a.b != 0), RD(a.a.a.c, 8)); + Nzd(b, e.a, e.b); + i2 = new mMd((!b.a && (b.a = new XZd(D4, b, 5)), b.a)); + g = Sub(a, 1); + while (g.a < a.b - 1) { + h = RD(evb(g), 8); + if (i2.e != i2.i.gc()) { + c2 = RD(bMd(i2), 377); + } else { + c2 = (bvd(), d = new Xxd(), d); + kMd(i2, c2); + } + Uxd(c2, h.a, h.b); + } + while (i2.e != i2.i.gc()) { + bMd(i2); + cMd(i2); + } + f2 = (sFb(a.b != 0), RD(a.c.b.c, 8)); + Gzd(b, f2.a, f2.b); + } + function Ege(a, b, c2, d) { + var e, f2, g, h, i2, j; + j = pke(a.e.Dh(), b); + g = RD(a.g, 124); + if (qke(a.e, b)) { + if (b.Si()) { + f2 = kge(a, b, d, ZD(b, 102) && (RD(b, 19).Bb & txe) != 0); + if (f2 >= 0 && f2 != c2) { + throw Adb(new agb(LIe)); + } + } + e = 0; + for (i2 = 0; i2 < a.i; ++i2) { + h = g[i2]; + if (j.am(h.Lk())) { + if (e == c2) { + return RD(eHd(a, i2, (nke(), RD(b, 69).xk() ? RD(d, 76) : oke(b, d))), 76); + } + ++e; + } + } + throw Adb(new veb(HJe + c2 + NIe + e)); + } else { + for (i2 = 0; i2 < a.i; ++i2) { + h = g[i2]; + if (j.am(h.Lk())) { + return nke(), RD(b, 69).xk() ? h : h.md(); + } + } + return null; + } + } + function Epc(a, b) { + var c2, d, e, f2, g, h, i2, j, k; + c2 = 0; + for (e = new Anb((tFb(0, a.c.length), RD(a.c[0], 105)).g.b.j); e.a < e.c.c.length; ) { + d = RD(ynb(e), 12); + d.p = c2++; + } + b == (qpd(), Yod) ? _mb(a, new Mpc()) : _mb(a, new Qpc()); + h = 0; + k = a.c.length - 1; + while (h < k) { + g = (tFb(h, a.c.length), RD(a.c[h], 105)); + j = (tFb(k, a.c.length), RD(a.c[k], 105)); + f2 = b == Yod ? g.c : g.a; + i2 = b == Yod ? j.a : j.c; + Gpc(g, b, (enc(), cnc), f2); + Gpc(j, b, bnc, i2); + ++h; + --k; + } + h == k && Gpc((tFb(h, a.c.length), RD(a.c[h], 105)), b, (enc(), anc), null); + } + function lJc(a, b, c2, d) { + var e, f2, g, h, i2, j; + g = new zJc(a, b, c2); + i2 = new Jkb(d, 0); + e = false; + while (i2.b < i2.d.gc()) { + h = (sFb(i2.b < i2.d.gc()), RD(i2.d.Xb(i2.c = i2.b++), 239)); + if (h == b || h == c2) { + Ckb(i2); + } else if (!e && Kfb(pJc(h.g, h.d[0]).a) > Kfb(pJc(g.g, g.d[0]).a)) { + sFb(i2.b > 0); + i2.a.Xb(i2.c = --i2.b); + Ikb(i2, g); + e = true; + } else if (!!h.e && h.e.gc() > 0) { + f2 = (!h.e && (h.e = new bnb()), h.e).Mc(b); + j = (!h.e && (h.e = new bnb()), h.e).Mc(c2); + if (f2 || j) { + (!h.e && (h.e = new bnb()), h.e).Fc(g); + ++g.c; + } + } + } + e || (ZEb(d.c, g), true); + } + function H3c(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r; + l = a.a.i + a.a.g / 2; + m = a.a.i + a.a.g / 2; + o2 = b.i + b.g / 2; + q = b.j + b.f / 2; + h = new rjd(o2, q); + j = RD(Gxd(b, (umd(), Qld)), 8); + j.a = j.a + l; + j.b = j.b + m; + f2 = (h.b - j.b) / (h.a - j.a); + d = h.b - f2 * h.a; + p = c2.i + c2.g / 2; + r = c2.j + c2.f / 2; + i2 = new rjd(p, r); + k = RD(Gxd(c2, Qld), 8); + k.a = k.a + l; + k.b = k.b + m; + g = (i2.b - k.b) / (i2.a - k.a); + e = i2.b - g * i2.a; + n = (d - e) / (g - f2); + if (j.a < n && h.a < n || n < j.a && n < h.a) { + return false; + } else if (k.a < n && i2.a < n || n < k.a && n < i2.a) { + return false; + } + return true; + } + function GDd(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n; + m = RD(Wjb(a.c, b), 190); + if (!m) { + throw Adb(new CDd("Edge did not exist in input.")); + } + j = uDd(m); + f2 = cve((!b.a && (b.a = new C5d(F4, b, 6, 6)), b.a)); + h = !f2; + if (h) { + n = new MB(); + c2 = new pFd(a, j, n); + ave((!b.a && (b.a = new C5d(F4, b, 6, 6)), b.a), c2); + sC(m, mIe, n); + } + e = Hxd(b, (umd(), cld)); + if (e) { + k = RD(Gxd(b, cld), 75); + g = !k || bve(k); + i2 = !g; + if (i2) { + l = new MB(); + d = new xFd(l); + xgb(k, d); + sC(m, "junctionPoints", l); + } + } + sDd(m, "container", kzd(b).k); + return null; + } + function fZc(a, b, c2, d) { + var e, f2, g, h, i2, j; + if (!gr(b)) { + j = c2.eh((ZD(b, 16) ? RD(b, 16).gc() : Kr(b.Kc())) / a.a | 0); + j.Ug(OEe, 1); + i2 = new iZc(); + h = 0; + if (d == (Cmd(), ymd) || d == zmd) { + for (g = b.Kc(); g.Ob(); ) { + e = RD(g.Pb(), 40); + i2 = Al(cD(WC(cJ, 1), rve, 20, 0, [i2, new dXc(e)])); + h < e.f.a && (h = e.f.a); + } + } else { + for (g = b.Kc(); g.Ob(); ) { + e = RD(g.Pb(), 40); + i2 = Al(cD(WC(cJ, 1), rve, 20, 0, [i2, new dXc(e)])); + h < e.f.b && (h = e.f.b); + } + } + for (f2 = b.Kc(); f2.Ob(); ) { + e = RD(f2.Pb(), 40); + pQb(e, (q$c(), d$c), h); + } + j.Vg(); + fZc(a, i2, c2, d); + } + } + function XFb(a, b, c2) { + var d, e, f2, g, h, i2, j, k; + this.a = a; + this.b = b; + this.c = c2; + this.e = dv(cD(WC($M, 1), rve, 177, 0, [new TFb(a, b), new TFb(b, c2), new TFb(c2, a)])); + this.f = dv(cD(WC(l3, 1), Nve, 8, 0, [a, b, c2])); + this.d = (d = ojd(ajd(this.b), this.a), e = ojd(ajd(this.c), this.a), f2 = ojd(ajd(this.c), this.b), g = d.a * (this.a.a + this.b.a) + d.b * (this.a.b + this.b.b), h = e.a * (this.a.a + this.c.a) + e.b * (this.a.b + this.c.b), i2 = 2 * (d.a * f2.b - d.b * f2.a), j = (e.b * g - d.b * h) / i2, k = (d.a * h - e.a * g) / i2, new rjd(j, k)); + } + function X0b(a, b) { + var c2, d, e, f2, g, h; + f2 = a.c; + g = a.d; + Y0b(a, null); + Z0b(a, null); + b && Heb(TD(mQb(g, (Ywc(), mwc)))) ? Y0b(a, q2b(g.i, (BEc(), zEc), (qpd(), Xod))) : Y0b(a, g); + b && Heb(TD(mQb(f2, (Ywc(), Gwc)))) ? Z0b(a, q2b(f2.i, (BEc(), yEc), (qpd(), ppd))) : Z0b(a, f2); + for (d = new Anb(a.b); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 72); + e = RD(mQb(c2, (yCc(), wAc)), 278); + e == (Omd(), Nmd) ? pQb(c2, wAc, Mmd) : e == Mmd && pQb(c2, wAc, Nmd); + } + h = Heb(TD(mQb(a, (Ywc(), Nwc)))); + pQb(a, Nwc, (Geb(), h ? false : true)); + a.a = Ijd(a.a); + } + function lWc(a, b) { + var c2, d, e, f2, g; + c2 = jWc(RD(mQb(b, (h_c(), H$c)), 88)); + if (a.b.b == 0) { + return null; + } + g = RD(zDb(GDb(new SDb(null, new Swb(a.b, 16)), new UWc()), tBb(new ZBb(), new XBb(), new wCb(), cD(WC(QL, 1), jwe, 108, 0, [(xBb(), vBb)]))), 15); + f2 = RD(zDb(CDb(new SDb(null, new Swb(b.b, 16)), new CWc(g)), tBb(new ZBb(), new XBb(), new wCb(), cD(WC(QL, 1), jwe, 108, 0, [vBb]))), 15); + e = UD(Lvb(JDb(GDb(f2.Oc(), new EWc(c2)), (urb(), urb(), srb)))); + d = RD(Lvb(DDb(CDb(f2.Oc(), new GWc(c2, e)))), 40); + return d; + } + function vOc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q; + c2 = eJb(new gJb(), a.f); + j = a.i[b.c.i.p]; + n = a.i[b.d.i.p]; + i2 = b.c; + m = b.d; + h = i2.a.b; + l = m.a.b; + j.b || (h += i2.n.b); + n.b || (l += m.n.b); + k = eE($wnd.Math.max(0, h - l)); + g = eE($wnd.Math.max(0, l - h)); + o2 = (p = $wnd.Math.max(1, RD(mQb(b, (yCc(), MBc)), 17).a), q = hOc(b.c.i.k, b.d.i.k), p * q); + e = rIb(uIb(tIb(sIb(vIb(new wIb(), o2), g), c2), RD(Wjb(a.k, b.c), 125))); + f2 = rIb(uIb(tIb(sIb(vIb(new wIb(), o2), k), c2), RD(Wjb(a.k, b.d), 125))); + d = new QOc(e, f2); + a.c[b.p] = d; + } + function MTb(a, b, c2) { + var d, e, f2, g, h, i2; + d = 0; + for (f2 = new dMd((!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a)); f2.e != f2.i.gc(); ) { + e = RD(bMd(f2), 27); + g = ""; + (!e.n && (e.n = new C5d(I4, e, 1, 7)), e.n).i == 0 || (g = RD(QHd((!e.n && (e.n = new C5d(I4, e, 1, 7)), e.n), 0), 135).a); + h = new lUb(g); + kQb(h, e); + pQb(h, (JVb(), HVb), e); + h.a = d++; + h.d.a = e.i + e.g / 2; + h.d.b = e.j + e.f / 2; + h.e.a = $wnd.Math.max(e.g, 1); + h.e.b = $wnd.Math.max(e.f, 1); + Rmb(b.e, h); + rtb(c2.f, e, h); + i2 = RD(Gxd(e, (yVb(), jVb)), 101); + i2 == (Bod(), Aod) && (i2 = zod); + } + } + function bec(a, b) { + var c2, d, e, f2, g, h, i2; + b.Ug("Layer constraint postprocessing", 1); + i2 = a.b; + if (i2.c.length != 0) { + d = (tFb(0, i2.c.length), RD(i2.c[0], 30)); + g = RD(Vmb(i2, i2.c.length - 1), 30); + c2 = new R4b(a); + f2 = new R4b(a); + _dc(a, d, g, c2, f2); + c2.a.c.length == 0 || (wFb(0, i2.c.length), XEb(i2.c, 0, c2)); + f2.a.c.length == 0 || (ZEb(i2.c, f2), true); + } + if (nQb(a, (Ywc(), lwc))) { + e = new R4b(a); + h = new R4b(a); + cec(a, e, h); + e.a.c.length == 0 || (wFb(0, i2.c.length), XEb(i2.c, 0, e)); + h.a.c.length == 0 || (ZEb(i2.c, h), true); + } + b.Vg(); + } + function zte(a) { + var b, c2, d; + switch (a) { + case 91: + case 93: + case 45: + case 94: + case 44: + case 92: + d = "\\" + String.fromCharCode(a & Bwe); + break; + case 12: + d = "\\f"; + break; + case 10: + d = "\\n"; + break; + case 13: + d = "\\r"; + break; + case 9: + d = "\\t"; + break; + case 27: + d = "\\e"; + break; + default: + if (a < 32) { + c2 = (b = a >>> 0, "0" + b.toString(16)); + d = "\\x" + zhb(c2, c2.length - 2, c2.length); + } else if (a >= txe) { + c2 = (b = a >>> 0, "0" + b.toString(16)); + d = "\\v" + zhb(c2, c2.length - 6, c2.length); + } else + d = "" + String.fromCharCode(a & Bwe); + } + return d; + } + function Ugc(a) { + var b, c2, d; + if (Dod(RD(mQb(a, (yCc(), BBc)), 101))) { + for (c2 = new Anb(a.j); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 12); + b.j == (qpd(), opd) && (d = RD(mQb(b, (Ywc(), Iwc)), 10), d ? Q3b(b, RD(mQb(d, hwc), 64)) : b.e.c.length - b.g.c.length < 0 ? Q3b(b, Xod) : Q3b(b, ppd)); + } + } else { + for (c2 = new Anb(a.j); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 12); + d = RD(mQb(b, (Ywc(), Iwc)), 10); + d ? Q3b(b, RD(mQb(d, hwc), 64)) : b.e.c.length - b.g.c.length < 0 ? Q3b(b, (qpd(), Xod)) : Q3b(b, (qpd(), ppd)); + } + pQb(a, BBc, (Bod(), yod)); + } + } + function wUc(a) { + var b, c2, d, e, f2, g; + this.e = new bnb(); + this.a = new bnb(); + for (c2 = a.b - 1; c2 < 3; c2++) { + hu(a, 0, RD(ju(a, 0), 8)); + } + if (a.b < 4) { + throw Adb(new agb("At (least dimension + 1) control points are necessary!")); + } else { + this.b = 3; + this.d = true; + this.c = false; + rUc(this, a.b + this.b - 1); + g = new bnb(); + f2 = new Anb(this.e); + for (b = 0; b < this.b - 1; b++) { + Rmb(g, UD(ynb(f2))); + } + for (e = Sub(a, 0); e.b != e.d.c; ) { + d = RD(evb(e), 8); + Rmb(g, UD(ynb(f2))); + Rmb(this.a, new BUc(d, g)); + tFb(0, g.c.length); + g.c.splice(0, 1); + } + } + } + function Sdc(a, b) { + var c2, d, e, f2, g, h, i2, j, k; + for (f2 = new Anb(a.b); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 30); + for (h = new Anb(e.a); h.a < h.c.c.length; ) { + g = RD(ynb(h), 10); + if (g.k == (r3b(), n3b)) { + i2 = (j = RD(hs(new is(Mr(Z2b(g).a.Kc(), new ir()))), 18), k = RD(hs(new is(Mr(a3b(g).a.Kc(), new ir()))), 18), !Heb(TD(mQb(j, (Ywc(), Nwc)))) || !Heb(TD(mQb(k, Nwc)))) ? b : Qnd(b); + Qdc(g, i2); + } + for (d = new is(Mr(a3b(g).a.Kc(), new ir())); gs(d); ) { + c2 = RD(hs(d), 18); + i2 = Heb(TD(mQb(c2, (Ywc(), Nwc)))) ? Qnd(b) : b; + Pdc(c2, i2); + } + } + } + } + function V8c(a, b, c2, d, e) { + var f2, g, h; + if (c2.f >= b.o && c2.f <= b.f || b.a * 0.5 <= c2.f && b.a * 1.5 >= c2.f) { + g = RD(Vmb(b.n, b.n.c.length - 1), 209); + if (g.e + g.d + c2.g + e <= d && (f2 = RD(Vmb(b.n, b.n.c.length - 1), 209), f2.f - a.f + c2.f <= a.b || a.a.c.length == 1)) { + K9c(b, c2); + return true; + } else if (b.s + c2.g <= d && (b.t + b.d + c2.f + e <= a.b || a.a.c.length == 1)) { + Rmb(b.b, c2); + h = RD(Vmb(b.n, b.n.c.length - 1), 209); + Rmb(b.n, new _9c(b.s, h.f + h.a + b.i, b.i)); + W9c(RD(Vmb(b.n, b.n.c.length - 1), 209), c2); + M9c(b, c2); + return true; + } + } + return false; + } + function xLd(a, b, c2) { + var d, e, f2, g; + if (a.Pj()) { + e = null; + f2 = a.Qj(); + d = a.Ij(1, g = UHd(a, b, c2), c2, b, f2); + if (a.Mj() && !(a.Yi() && g != null ? pb(g, c2) : dE(g) === dE(c2))) { + g != null && (e = a.Oj(g, e)); + e = a.Nj(c2, e); + a.Tj() && (e = a.Wj(g, c2, e)); + if (!e) { + a.Jj(d); + } else { + e.nj(d); + e.oj(); + } + } else { + a.Tj() && (e = a.Wj(g, c2, e)); + if (!e) { + a.Jj(d); + } else { + e.nj(d); + e.oj(); + } + } + return g; + } else { + g = UHd(a, b, c2); + if (a.Mj() && !(a.Yi() && g != null ? pb(g, c2) : dE(g) === dE(c2))) { + e = null; + g != null && (e = a.Oj(g, null)); + e = a.Nj(c2, e); + !!e && e.oj(); + } + return g; + } + } + function Rsc(a, b) { + var c2, d, e, f2, g; + b.Ug("Path-Like Graph Wrapping", 1); + if (a.b.c.length == 0) { + b.Vg(); + return; + } + e = new ysc(a); + g = (e.i == null && (e.i = tsc(e, new Asc())), Kfb(e.i) * e.f); + c2 = g / (e.i == null && (e.i = tsc(e, new Asc())), Kfb(e.i)); + if (e.b > c2) { + b.Vg(); + return; + } + switch (RD(mQb(a, (yCc(), rCc)), 351).g) { + case 2: + f2 = new Ksc(); + break; + case 0: + f2 = new zrc(); + break; + default: + f2 = new Nsc(); + } + d = f2.og(a, e); + if (!f2.pg()) { + switch (RD(mQb(a, xCc), 352).g) { + case 2: + d = Wsc(e, d); + break; + case 1: + d = Usc(e, d); + } + } + Qsc(a, e, d); + b.Vg(); + } + function mB(a, b) { + var c2, d, e, f2, g, h, i2, j; + b %= 24; + if (a.q.getHours() != b) { + d = new $wnd.Date(a.q.getTime()); + d.setDate(d.getDate() + 1); + h = a.q.getTimezoneOffset() - d.getTimezoneOffset(); + if (h > 0) { + i2 = h / 60 | 0; + j = h % 60; + e = a.q.getDate(); + c2 = a.q.getHours(); + c2 + i2 >= 24 && ++e; + f2 = new $wnd.Date(a.q.getFullYear(), a.q.getMonth(), e, b + i2, a.q.getMinutes() + j, a.q.getSeconds(), a.q.getMilliseconds()); + a.q.setTime(f2.getTime()); + } + } + g = a.q.getTime(); + a.q.setTime(g + 36e5); + a.q.getHours() != b && a.q.setTime(g); + } + function kKc(a, b) { + var c2, d, e, f2; + Nwb(a.d, a.e); + a.c.a.$b(); + if (Kfb(UD(mQb(b.j, (yCc(), Zzc)))) != 0 || Kfb(UD(mQb(b.j, Zzc))) != 0) { + c2 = Hze; + dE(mQb(b.j, cAc)) !== dE((kEc(), hEc)) && pQb(b.j, (Ywc(), jwc), (Geb(), true)); + f2 = RD(mQb(b.j, gCc), 17).a; + for (e = 0; e < f2; e++) { + d = uKc(a, b); + if (d < c2) { + c2 = d; + xKc(a); + if (c2 == 0) { + break; + } + } + } + } else { + c2 = lve; + dE(mQb(b.j, cAc)) !== dE((kEc(), hEc)) && pQb(b.j, (Ywc(), jwc), (Geb(), true)); + f2 = RD(mQb(b.j, gCc), 17).a; + for (e = 0; e < f2; e++) { + d = vKc(a, b); + if (d < c2) { + c2 = d; + xKc(a); + if (c2 == 0) { + break; + } + } + } + } + } + function Vsc(a, b) { + var c2, d, e, f2, g, h, i2, j; + g = new bnb(); + h = 0; + c2 = 0; + i2 = 0; + while (h < b.c.length - 1 && c2 < a.gc()) { + d = RD(a.Xb(c2), 17).a + i2; + while ((tFb(h + 1, b.c.length), RD(b.c[h + 1], 17)).a < d) { + ++h; + } + j = 0; + f2 = d - (tFb(h, b.c.length), RD(b.c[h], 17)).a; + e = (tFb(h + 1, b.c.length), RD(b.c[h + 1], 17)).a - d; + f2 > e && ++j; + Rmb(g, (tFb(h + j, b.c.length), RD(b.c[h + j], 17))); + i2 += (tFb(h + j, b.c.length), RD(b.c[h + j], 17)).a - d; + ++c2; + while (c2 < a.gc() && RD(a.Xb(c2), 17).a + i2 <= (tFb(h + j, b.c.length), RD(b.c[h + j], 17)).a) { + ++c2; + } + h += 1 + j; + } + return g; + } + function VGc(a, b) { + var c2, d, e, f2, g; + for (g = new is(Mr(Z2b(b).a.Kc(), new ir())); gs(g); ) { + f2 = RD(hs(g), 18); + if (a.f.b == 0) { + e = f2.c.i.k == (r3b(), p3b) && !!f2.c.i.c && f2.c.i.c.p == a.c; + if (gs(new is(Mr(Z2b(f2.c.i).a.Kc(), new ir())))) { + c2 = RD(hs(new is(Mr(Z2b(f2.c.i).a.Kc(), new ir()))), 18).c.i.c; + d = f2.c.i.k == n3b && !!c2 && c2.p == a.c; + } else { + d = false; + } + } else { + e = f2.c.i.k == (r3b(), p3b) && f2.c.i.p == a.c; + d = f2.c.i.k == n3b && RD(hs(new is(Mr(Z2b(f2.c.i).a.Kc(), new ir()))), 18).c.i.p == a.c; + } + if (e || d) { + return true; + } + } + return false; + } + function DHc(a, b, c2, d, e) { + var f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t; + m = new bnb(); + r = Xx(d); + q = b * a.a; + l = 0; + o2 = 0; + f2 = new _sb(); + g = new _sb(); + h = new bnb(); + s = 0; + t = 0; + n = 0; + p = 0; + j = 0; + k = 0; + while (r.a.gc() != 0) { + i2 = HHc(r, e, g); + if (i2) { + r.a.Bc(i2) != null; + ZEb(h.c, i2); + f2.a.zc(i2, f2); + o2 = a.f[i2.p]; + s += a.e[i2.p] - o2 * a.b; + l = a.c[i2.p]; + t += l * a.b; + k += o2 * a.b; + p += a.e[i2.p]; + } + if (!i2 || r.a.gc() == 0 || s >= q && a.e[i2.p] > o2 * a.b || t >= c2 * q) { + ZEb(m.c, h); + h = new bnb(); + ye(g, f2); + f2.a.$b(); + j -= k; + n = $wnd.Math.max(n, j * a.b + p); + j += t; + s = t; + t = 0; + k = 0; + p = 0; + } + } + return new Ptd(n, m); + } + function pYd(a) { + var b, c2, d, e, f2, g, h; + if (!a.d) { + h = new v_d(); + b = iYd; + f2 = b.a.zc(a, b); + if (f2 == null) { + for (d = new dMd(zYd(a)); d.e != d.i.gc(); ) { + c2 = RD(bMd(d), 29); + YGd(h, pYd(c2)); + } + b.a.Bc(a) != null; + b.a.gc() == 0 && void 0; + } + g = h.i; + for (e = (!a.q && (a.q = new C5d(s7, a, 11, 10)), new dMd(a.q)); e.e != e.i.gc(); ++g) { + RD(bMd(e), 411); + } + YGd(h, (!a.q && (a.q = new C5d(s7, a, 11, 10)), a.q)); + VHd(h); + a.d = new N$d((RD(QHd(xYd((lTd(), kTd).o), 9), 19), h.i), h.g); + a.e = RD(h.g, 688); + a.e == null && (a.e = jYd); + yYd(a).b &= -17; + } + return a.d; + } + function kge(a, b, c2, d) { + var e, f2, g, h, i2, j; + j = pke(a.e.Dh(), b); + i2 = 0; + e = RD(a.g, 124); + nke(); + if (RD(b, 69).xk()) { + for (g = 0; g < a.i; ++g) { + f2 = e[g]; + if (j.am(f2.Lk())) { + if (pb(f2, c2)) { + return i2; + } + ++i2; + } + } + } else if (c2 != null) { + for (h = 0; h < a.i; ++h) { + f2 = e[h]; + if (j.am(f2.Lk())) { + if (pb(c2, f2.md())) { + return i2; + } + ++i2; + } + } + if (d) { + i2 = 0; + for (g = 0; g < a.i; ++g) { + f2 = e[g]; + if (j.am(f2.Lk())) { + if (dE(c2) === dE(Age(a, RD(f2.md(), 58)))) { + return i2; + } + ++i2; + } + } + } + } else { + for (g = 0; g < a.i; ++g) { + f2 = e[g]; + if (j.am(f2.Lk())) { + if (f2.md() == null) { + return i2; + } + ++i2; + } + } + } + return -1; + } + function Xje(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m, n, o2, p; + if (c2.Xh(b)) { + k = (n = b, !n ? null : RD(d, 54).gi(n)); + if (k) { + p = c2.Nh(b, a.a); + o2 = b.t; + if (o2 > 1 || o2 == -1) { + l = RD(p, 71); + m = RD(k, 71); + if (l.dc()) { + m.$b(); + } else { + g = !!Z5d(b); + f2 = 0; + for (h = a.a ? l.Kc() : l.Ii(); h.Ob(); ) { + j = RD(h.Pb(), 58); + e = RD(cub(a, j), 58); + if (!e) { + if (a.b && !g) { + m.Gi(f2, j); + ++f2; + } + } else { + if (g) { + i2 = m.dd(e); + i2 == -1 ? m.Gi(f2, e) : f2 != i2 && m.Ui(f2, e); + } else { + m.Gi(f2, e); + } + ++f2; + } + } + } + } else { + if (p == null) { + k.Wb(null); + } else { + e = cub(a, p); + e == null ? a.b && !Z5d(b) && k.Wb(p) : k.Wb(e); + } + } + } + } + } + function V9b(a, b) { + var c2, d, e, f2, g, h, i2, j; + c2 = new aac(); + for (e = new is(Mr(Z2b(b).a.Kc(), new ir())); gs(e); ) { + d = RD(hs(e), 18); + if (W0b(d)) { + continue; + } + h = d.c.i; + if (W9b(h, T9b)) { + j = X9b(a, h, T9b, S9b); + if (j == -1) { + continue; + } + c2.b = $wnd.Math.max(c2.b, j); + !c2.a && (c2.a = new bnb()); + Rmb(c2.a, h); + } + } + for (g = new is(Mr(a3b(b).a.Kc(), new ir())); gs(g); ) { + f2 = RD(hs(g), 18); + if (W0b(f2)) { + continue; + } + i2 = f2.d.i; + if (W9b(i2, S9b)) { + j = X9b(a, i2, S9b, T9b); + if (j == -1) { + continue; + } + c2.d = $wnd.Math.max(c2.d, j); + !c2.c && (c2.c = new bnb()); + Rmb(c2.c, i2); + } + } + return c2; + } + function pcc(a, b, c2, d) { + var e, f2, g, h, i2, j, k; + if (c2.d.i == b.i) { + return; + } + e = new j3b(a); + h3b(e, (r3b(), o3b)); + pQb(e, (Ywc(), Awc), c2); + pQb(e, (yCc(), BBc), (Bod(), wod)); + ZEb(d.c, e); + g = new R3b(); + P3b(g, e); + Q3b(g, (qpd(), ppd)); + h = new R3b(); + P3b(h, e); + Q3b(h, Xod); + k = c2.d; + Z0b(c2, g); + f2 = new a1b(); + kQb(f2, c2); + pQb(f2, RAc, null); + Y0b(f2, h); + Z0b(f2, k); + j = new Jkb(c2.b, 0); + while (j.b < j.d.gc()) { + i2 = (sFb(j.b < j.d.gc()), RD(j.d.Xb(j.c = j.b++), 72)); + if (dE(mQb(i2, wAc)) === dE((Omd(), Mmd))) { + pQb(i2, dwc, c2); + Ckb(j); + Rmb(f2.b, i2); + } + } + rcc(e, g, h); + } + function occ(a, b, c2, d) { + var e, f2, g, h, i2, j, k; + if (c2.c.i == b.i) { + return; + } + e = new j3b(a); + h3b(e, (r3b(), o3b)); + pQb(e, (Ywc(), Awc), c2); + pQb(e, (yCc(), BBc), (Bod(), wod)); + ZEb(d.c, e); + g = new R3b(); + P3b(g, e); + Q3b(g, (qpd(), ppd)); + h = new R3b(); + P3b(h, e); + Q3b(h, Xod); + Z0b(c2, g); + f2 = new a1b(); + kQb(f2, c2); + pQb(f2, RAc, null); + Y0b(f2, h); + Z0b(f2, b); + rcc(e, g, h); + j = new Jkb(c2.b, 0); + while (j.b < j.d.gc()) { + i2 = (sFb(j.b < j.d.gc()), RD(j.d.Xb(j.c = j.b++), 72)); + k = RD(mQb(i2, wAc), 278); + if (k == (Omd(), Mmd)) { + nQb(i2, dwc) || pQb(i2, dwc, c2); + Ckb(j); + Rmb(f2.b, i2); + } + } + } + function Sjb(a) { + Ljb(); + var b, c2, d, e; + b = eE(a); + if (a < Kjb.length) { + return Kjb[b]; + } else if (a <= 50) { + return Yib((Pib(), Mib), b); + } else if (a <= Awe) { + return Zib(Yib(Jjb[1], b), b); + } + if (a > 1e6) { + throw Adb(new teb("power of ten too big")); + } + if (a <= lve) { + return Zib(Yib(Jjb[1], b), b); + } + d = Yib(Jjb[1], lve); + e = d; + c2 = Hdb(a - lve); + b = eE(a % lve); + while (Ddb(c2, lve) > 0) { + e = Wib(e, d); + c2 = Vdb(c2, lve); + } + e = Wib(e, Yib(Jjb[1], b)); + e = Zib(e, lve); + c2 = Hdb(a - lve); + while (Ddb(c2, lve) > 0) { + e = Zib(e, lve); + c2 = Vdb(c2, lve); + } + e = Zib(e, b); + return e; + } + function s9b(a) { + var b, c2, d, e, f2, g, h, i2, j, k; + for (i2 = new Anb(a.a); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 10); + if (h.k != (r3b(), m3b)) { + continue; + } + e = RD(mQb(h, (Ywc(), hwc)), 64); + if (e == (qpd(), Xod) || e == ppd) { + for (d = new is(Mr(W2b(h).a.Kc(), new ir())); gs(d); ) { + c2 = RD(hs(d), 18); + b = c2.a; + if (b.b == 0) { + continue; + } + j = c2.c; + if (j.i == h) { + f2 = (sFb(b.b != 0), RD(b.a.a.c, 8)); + f2.b = xjd(cD(WC(l3, 1), Nve, 8, 0, [j.i.n, j.n, j.a])).b; + } + k = c2.d; + if (k.i == h) { + g = (sFb(b.b != 0), RD(b.c.b.c, 8)); + g.b = xjd(cD(WC(l3, 1), Nve, 8, 0, [k.i.n, k.n, k.a])).b; + } + } + } + } + } + function Nlc(a, b, c2, d) { + var e, f2, g; + this.j = new bnb(); + this.k = new bnb(); + this.b = new bnb(); + this.c = new bnb(); + this.e = new Tid(); + this.i = new Ejd(); + this.f = new cHb(); + this.d = new bnb(); + this.g = new bnb(); + Rmb(this.b, a); + Rmb(this.b, b); + this.e.c = $wnd.Math.min(a.a, b.a); + this.e.d = $wnd.Math.min(a.b, b.b); + this.e.b = $wnd.Math.abs(a.a - b.a); + this.e.a = $wnd.Math.abs(a.b - b.b); + e = RD(mQb(d, (yCc(), RAc)), 75); + if (e) { + for (g = Sub(e, 0); g.b != g.d.c; ) { + f2 = RD(evb(g), 8); + rGb(f2.a, a.a) && Mub(this.i, f2); + } + } + !!c2 && Rmb(this.j, c2); + Rmb(this.k, d); + } + function vSc(a, b, c2, d) { + var e, f2, g, h, i2, j, k; + h = -1; + for (k = new Anb(a); k.a < k.c.c.length; ) { + j = RD(ynb(k), 118); + j.g = h--; + e = Ydb(mDb(IDb(CDb(new SDb(null, new Swb(j.f, 16)), new xSc()), new zSc())).d); + f2 = Ydb(mDb(IDb(CDb(new SDb(null, new Swb(j.k, 16)), new BSc()), new DSc())).d); + g = e; + i2 = f2; + if (!d) { + g = Ydb(mDb(IDb(new SDb(null, new Swb(j.f, 16)), new FSc())).d); + i2 = Ydb(mDb(IDb(new SDb(null, new Swb(j.k, 16)), new HSc())).d); + } + j.d = g; + j.a = e; + j.i = i2; + j.b = f2; + i2 == 0 ? (Pub(c2, j, c2.c.b, c2.c), true) : g == 0 && (Pub(b, j, b.c.b, b.c), true); + } + } + function Qdc(a, b) { + var c2, d, e, f2, g, h; + if (a.k == (r3b(), n3b)) { + c2 = a.k == n3b && !QDb(CDb(RD(mQb(a, (Ywc(), Mwc)), 15).Oc(), new PAb(new x3b()))).Bd((xDb(), wDb)) ? (Pnd(), Nnd) : b; + pQb(a, (Ywc(), swc), c2); + if (c2 != (Pnd(), Mnd)) { + d = RD(mQb(a, Awc), 18); + h = Kfb(UD(mQb(d, (yCc(), FAc)))); + g = 0; + if (c2 == Lnd) { + g = a.o.b - $wnd.Math.ceil(h / 2); + } else if (c2 == Nnd) { + g = $wnd.Math.ceil(a.o.b - Kfb(UD(mQb(Y2b(a), VBc))) - h) / 2; + a.o.b -= Kfb(UD(mQb(Y2b(a), VBc))); + a.o.b -= h; + } + for (f2 = new Anb(a.j); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 12); + e.n.b = g; + } + } + } + } + function XQc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l; + e = true; + for (g = new Anb(a.b); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 30); + j = pxe; + k = null; + for (i2 = new Anb(f2.a); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 10); + l = Kfb(b.p[h.p]) + Kfb(b.d[h.p]) - h.d.d; + d = Kfb(b.p[h.p]) + Kfb(b.d[h.p]) + h.o.b + h.d.a; + if (l > j && d > j) { + k = h; + j = Kfb(b.p[h.p]) + Kfb(b.d[h.p]) + h.o.b + h.d.a; + } else { + e = false; + c2._g() && c2.bh("bk node placement breaks on " + h + " which should have been after " + k); + break; + } + } + if (!e) { + break; + } + } + c2._g() && c2.bh(b + " is feasible: " + e); + return e; + } + function Dfc(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m; + f2 = new j3b(a); + h3b(f2, (r3b(), q3b)); + pQb(f2, (yCc(), BBc), (Bod(), wod)); + e = 0; + if (b) { + g = new R3b(); + pQb(g, (Ywc(), Awc), b); + pQb(f2, Awc, b.i); + Q3b(g, (qpd(), ppd)); + P3b(g, f2); + m = s2b(b.e); + for (j = m, k = 0, l = j.length; k < l; ++k) { + i2 = j[k]; + Z0b(i2, g); + } + pQb(b, Iwc, f2); + ++e; + } + if (c2) { + h = new R3b(); + pQb(f2, (Ywc(), Awc), c2.i); + pQb(h, Awc, c2); + Q3b(h, (qpd(), Xod)); + P3b(h, f2); + m = s2b(c2.g); + for (j = m, k = 0, l = j.length; k < l; ++k) { + i2 = j[k]; + Y0b(i2, h); + } + pQb(c2, Iwc, f2); + ++e; + } + pQb(f2, (Ywc(), $vc), sgb(e)); + ZEb(d.c, f2); + return f2; + } + function Bgd(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n; + for (c2 = (j = new glb(a.c.b).a.vc().Kc(), new llb(j)); c2.a.Ob(); ) { + b = (h = RD(c2.a.Pb(), 44), RD(h.md(), 143)); + e = b.a; + e == null && (e = ""); + d = tgd(a.c, e); + !d && e.length == 0 && (d = Fgd(a)); + !!d && !ze(d.c, b, false) && Mub(d.c, b); + } + for (g = Sub(a.a, 0); g.b != g.d.c; ) { + f2 = RD(evb(g), 487); + k = ugd(a.c, f2.a); + n = ugd(a.c, f2.b); + !!k && !!n && Mub(k.c, new Ptd(n, f2.c)); + } + Xub(a.a); + for (m = Sub(a.b, 0); m.b != m.d.c; ) { + l = RD(evb(m), 487); + b = rgd(a.c, l.a); + i2 = ugd(a.c, l.b); + !!b && !!i2 && Mfd(b, i2, l.c); + } + Xub(a.b); + } + function QId(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n; + f2 = new vC(a); + g = new IEd(); + e = (wo(g.g), wo(g.j), akb(g.b), wo(g.d), wo(g.i), akb(g.k), akb(g.c), akb(g.e), n = DEd(g, f2, null), AEd(g, f2), n); + if (b) { + j = new vC(b); + h = RId(j); + msd(e, cD(WC(j4, 1), rve, 536, 0, [h])); + } + m = false; + l = false; + if (c2) { + j = new vC(c2); + RIe in j.a && (m = qC(j, RIe).qe().a); + SIe in j.a && (l = qC(j, SIe).qe().a); + } + k = Kqd(Mqd(new Oqd(), m), l); + Eed(new Hed(), e, k); + RIe in f2.a && sC(f2, RIe, null); + if (m || l) { + i2 = new uC(); + NId(k, i2, m, l); + sC(f2, RIe, i2); + } + d = new nFd(g); + dve(new zId(e), d); + } + function FA(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l; + g = new DB(); + j = cD(WC(kE, 1), Pwe, 28, 15, [0]); + e = -1; + f2 = 0; + d = 0; + for (i2 = 0; i2 < a.b.c.length; ++i2) { + k = RD(Vmb(a.b, i2), 443); + if (k.b > 0) { + if (e < 0 && k.a) { + e = i2; + f2 = j[0]; + d = 0; + } + if (e >= 0) { + h = k.b; + if (i2 == e) { + h -= d++; + if (h == 0) { + return 0; + } + } + if (!MA(b, j, k, h, g)) { + i2 = e - 1; + j[0] = f2; + continue; + } + } else { + e = -1; + if (!MA(b, j, k, 0, g)) { + return 0; + } + } + } else { + e = -1; + if (ihb(k.c, 0) == 32) { + l = j[0]; + KA(b, j); + if (j[0] > l) { + continue; + } + } else if (xhb(b, k.c, j[0])) { + j[0] += k.c.length; + continue; + } + return 0; + } + } + if (!CB(g, c2)) { + return 0; + } + return j[0]; + } + function qWb(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m; + k = new pwb(new GWb(c2)); + h = $C(xdb, Hye, 28, a.f.e.c.length, 16, 1); + Snb(h, h.length); + c2[b.a] = 0; + for (j = new Anb(a.f.e); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 153); + i2.a != b.a && (c2[i2.a] = lve); + zFb(lwb(k, i2), Bxe); + } + while (k.b.c.length != 0) { + l = RD(mwb(k), 153); + h[l.a] = true; + for (f2 = ru(new su(a.b, l), 0); f2.c; ) { + e = RD(Lu(f2), 290); + m = tWb(e, l); + if (h[m.a]) { + continue; + } + nQb(e, (dWb(), TVb)) ? g = Kfb(UD(mQb(e, TVb))) : g = a.c; + d = c2[l.a] + g; + if (d < c2[m.a]) { + c2[m.a] = d; + nwb(k, m); + zFb(lwb(k, m), Bxe); + } + } + } + } + function iPb(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n, o2; + g = a.o; + d = $C(kE, Pwe, 28, g, 15, 1); + e = $C(kE, Pwe, 28, g, 15, 1); + c2 = a.p; + b = $C(kE, Pwe, 28, c2, 15, 1); + f2 = $C(kE, Pwe, 28, c2, 15, 1); + for (j = 0; j < g; j++) { + l = 0; + while (l < c2 && !PPb(a, j, l)) { + ++l; + } + d[j] = l; + } + for (k = 0; k < g; k++) { + l = c2 - 1; + while (l >= 0 && !PPb(a, k, l)) { + --l; + } + e[k] = l; + } + for (n = 0; n < c2; n++) { + h = 0; + while (h < g && !PPb(a, h, n)) { + ++h; + } + b[n] = h; + } + for (o2 = 0; o2 < c2; o2++) { + h = g - 1; + while (h >= 0 && !PPb(a, h, o2)) { + --h; + } + f2[o2] = h; + } + for (i2 = 0; i2 < g; i2++) { + for (m = 0; m < c2; m++) { + i2 < f2[m] && i2 > b[m] && m < e[i2] && m > d[i2] && TPb(a, i2, m, false, true); + } + } + } + function hUb(a) { + var b, c2, d, e, f2, g, h, i2; + c2 = Heb(TD(mQb(a, (yVb(), $Ub)))); + f2 = a.a.c.d; + h = a.a.d.d; + if (c2) { + g = ijd(ojd(new rjd(h.a, h.b), f2), 0.5); + i2 = ijd(ajd(a.e), 0.5); + b = ojd($id(new rjd(f2.a, f2.b), g), i2); + mjd(a.d, b); + } else { + e = Kfb(UD(mQb(a.a, qVb))); + d = a.d; + if (f2.a >= h.a) { + if (f2.b >= h.b) { + d.a = h.a + (f2.a - h.a) / 2 + e; + d.b = h.b + (f2.b - h.b) / 2 - e - a.e.b; + } else { + d.a = h.a + (f2.a - h.a) / 2 + e; + d.b = f2.b + (h.b - f2.b) / 2 + e; + } + } else { + if (f2.b >= h.b) { + d.a = f2.a + (h.a - f2.a) / 2 + e; + d.b = h.b + (f2.b - h.b) / 2 + e; + } else { + d.a = f2.a + (h.a - f2.a) / 2 + e; + d.b = f2.b + (h.b - f2.b) / 2 - e - a.e.b; + } + } + } + } + function qYd(a) { + var b, c2, d, e, f2, g, h, i2; + if (!a.f) { + i2 = new a_d(); + h = new a_d(); + b = iYd; + g = b.a.zc(a, b); + if (g == null) { + for (f2 = new dMd(zYd(a)); f2.e != f2.i.gc(); ) { + e = RD(bMd(f2), 29); + YGd(i2, qYd(e)); + } + b.a.Bc(a) != null; + b.a.gc() == 0 && void 0; + } + for (d = (!a.s && (a.s = new C5d(y7, a, 21, 17)), new dMd(a.s)); d.e != d.i.gc(); ) { + c2 = RD(bMd(d), 179); + ZD(c2, 102) && WGd(h, RD(c2, 19)); + } + VHd(h); + a.r = new s_d(a, (RD(QHd(xYd((lTd(), kTd).o), 6), 19), h.i), h.g); + YGd(i2, a.r); + VHd(i2); + a.f = new N$d((RD(QHd(xYd(kTd.o), 5), 19), i2.i), i2.g); + yYd(a).b &= -3; + } + return a.f; + } + function uSb(a) { + Cgd(a, new Pfd($fd(Xfd(Zfd(Yfd(new agd(), Aze), "ELK DisCo"), "Layouter for arranging unconnected subgraphs. The subgraphs themselves are, by default, not laid out."), new xSb()))); + Agd(a, Aze, Bze, iGd(sSb)); + Agd(a, Aze, Cze, iGd(mSb)); + Agd(a, Aze, Dze, iGd(hSb)); + Agd(a, Aze, Eze, iGd(nSb)); + Agd(a, Aze, Bye, iGd(qSb)); + Agd(a, Aze, Cye, iGd(pSb)); + Agd(a, Aze, Aye, iGd(rSb)); + Agd(a, Aze, Dye, iGd(oSb)); + Agd(a, Aze, vze, iGd(jSb)); + Agd(a, Aze, wze, iGd(iSb)); + Agd(a, Aze, xze, iGd(kSb)); + Agd(a, Aze, yze, iGd(lSb)); + } + function qAd() { + qAd = geb; + oAd = cD(WC(hE, 1), zwe, 28, 15, [48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 65, 66, 67, 68, 69, 70]); + pAd = new RegExp("[ \n\r\f]+"); + try { + nAd = cD(WC(h8, 1), rve, 2114, 0, [new c2d((WA(), YA("yyyy-MM-dd'T'HH:mm:ss'.'SSSZ", _A(($A(), $A(), ZA))))), new c2d(YA("yyyy-MM-dd'T'HH:mm:ss'.'SSS", _A((null, ZA)))), new c2d(YA("yyyy-MM-dd'T'HH:mm:ss", _A((null, ZA)))), new c2d(YA("yyyy-MM-dd'T'HH:mm", _A((null, ZA)))), new c2d(YA("yyyy-MM-dd", _A((null, ZA))))]); + } catch (a) { + a = zdb(a); + if (!ZD(a, 82)) + throw Adb(a); + } + } + function uKc(a, b) { + var c2, d, e, f2; + e = Kwb(a.d, 1) != 0; + d = mKc(a, b); + if (d == 0 && Heb(TD(mQb(b.j, (Ywc(), jwc))))) { + return 0; + } + !Heb(TD(mQb(b.j, (Ywc(), jwc)))) && !Heb(TD(mQb(b.j, Owc))) || dE(mQb(b.j, (yCc(), cAc))) === dE((kEc(), hEc)) ? b.c.mg(b.e, e) : e = Heb(TD(mQb(b.j, jwc))); + DKc(a, b, e, true); + Heb(TD(mQb(b.j, Owc))) && pQb(b.j, Owc, (Geb(), false)); + if (Heb(TD(mQb(b.j, jwc)))) { + pQb(b.j, jwc, (Geb(), false)); + pQb(b.j, Owc, true); + } + c2 = mKc(a, b); + do { + yKc(a); + if (c2 == 0) { + return 0; + } + e = !e; + f2 = c2; + DKc(a, b, e, false); + c2 = mKc(a, b); + } while (f2 > c2); + return f2; + } + function vKc(a, b) { + var c2, d, e, f2; + e = Kwb(a.d, 1) != 0; + d = lKc(a, b); + if (d == 0 && Heb(TD(mQb(b.j, (Ywc(), jwc))))) { + return 0; + } + !Heb(TD(mQb(b.j, (Ywc(), jwc)))) && !Heb(TD(mQb(b.j, Owc))) || dE(mQb(b.j, (yCc(), cAc))) === dE((kEc(), hEc)) ? b.c.mg(b.e, e) : e = Heb(TD(mQb(b.j, jwc))); + DKc(a, b, e, true); + Heb(TD(mQb(b.j, Owc))) && pQb(b.j, Owc, (Geb(), false)); + if (Heb(TD(mQb(b.j, jwc)))) { + pQb(b.j, jwc, (Geb(), false)); + pQb(b.j, Owc, true); + } + c2 = lKc(a, b); + do { + yKc(a); + if (c2 == 0) { + return 0; + } + e = !e; + f2 = c2; + DKc(a, b, e, false); + c2 = lKc(a, b); + } while (f2 > c2); + return f2; + } + function Gid(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m; + i2 = ojd(new rjd(c2.a, c2.b), a); + j = i2.a * b.b - i2.b * b.a; + k = b.a * d.b - b.b * d.a; + l = (i2.a * d.b - i2.b * d.a) / k; + m = j / k; + if (k == 0) { + if (j == 0) { + e = $id(new rjd(c2.a, c2.b), ijd(new rjd(d.a, d.b), 0.5)); + f2 = bjd(a, e); + g = bjd($id(new rjd(a.a, a.b), b), e); + h = $wnd.Math.sqrt(d.a * d.a + d.b * d.b) * 0.5; + if (f2 < g && f2 <= h) { + return new rjd(a.a, a.b); + } + if (g <= h) { + return $id(new rjd(a.a, a.b), b); + } + return null; + } else { + return null; + } + } else { + return l >= 0 && l <= 1 && m >= 0 && m <= 1 ? $id(new rjd(a.a, a.b), ijd(new rjd(b.a, b.b), l)) : null; + } + } + function QWb(a, b, c2) { + var d, e, f2, g, h; + d = RD(mQb(a, (yCc(), dAc)), 21); + c2.a > b.a && (d.Hc((ukd(), okd)) ? a.c.a += (c2.a - b.a) / 2 : d.Hc(qkd) && (a.c.a += c2.a - b.a)); + c2.b > b.b && (d.Hc((ukd(), skd)) ? a.c.b += (c2.b - b.b) / 2 : d.Hc(rkd) && (a.c.b += c2.b - b.b)); + if (RD(mQb(a, (Ywc(), kwc)), 21).Hc((ovc(), hvc)) && (c2.a > b.a || c2.b > b.b)) { + for (h = new Anb(a.a); h.a < h.c.c.length; ) { + g = RD(ynb(h), 10); + if (g.k == (r3b(), m3b)) { + e = RD(mQb(g, hwc), 64); + e == (qpd(), Xod) ? g.n.a += c2.a - b.a : e == npd && (g.n.b += c2.b - b.b); + } + } + } + f2 = a.d; + a.f.a = c2.a - f2.b - f2.c; + a.f.b = c2.b - f2.d - f2.a; + } + function Y8b(a, b, c2) { + var d, e, f2, g, h; + d = RD(mQb(a, (yCc(), dAc)), 21); + c2.a > b.a && (d.Hc((ukd(), okd)) ? a.c.a += (c2.a - b.a) / 2 : d.Hc(qkd) && (a.c.a += c2.a - b.a)); + c2.b > b.b && (d.Hc((ukd(), skd)) ? a.c.b += (c2.b - b.b) / 2 : d.Hc(rkd) && (a.c.b += c2.b - b.b)); + if (RD(mQb(a, (Ywc(), kwc)), 21).Hc((ovc(), hvc)) && (c2.a > b.a || c2.b > b.b)) { + for (g = new Anb(a.a); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 10); + if (f2.k == (r3b(), m3b)) { + e = RD(mQb(f2, hwc), 64); + e == (qpd(), Xod) ? f2.n.a += c2.a - b.a : e == npd && (f2.n.b += c2.b - b.b); + } + } + } + h = a.d; + a.f.a = c2.a - h.b - h.c; + a.f.b = c2.b - h.d - h.a; + } + function KQc(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m; + b = bRc(a); + for (k = (h = new Xkb(b).a.vc().Kc(), new blb(h)); k.a.Ob(); ) { + j = (e = RD(k.a.Pb(), 44), RD(e.ld(), 10)); + l = 0; + m = 0; + l = j.d.d; + m = j.o.b + j.d.a; + a.d[j.p] = 0; + c2 = j; + while ((f2 = a.a[c2.p]) != j) { + d = dRc(c2, f2); + i2 = 0; + a.c == (wQc(), uQc) ? i2 = d.d.n.b + d.d.a.b - d.c.n.b - d.c.a.b : i2 = d.c.n.b + d.c.a.b - d.d.n.b - d.d.a.b; + g = Kfb(a.d[c2.p]) + i2; + a.d[f2.p] = g; + l = $wnd.Math.max(l, f2.d.d - g); + m = $wnd.Math.max(m, g + f2.o.b + f2.d.a); + c2 = f2; + } + c2 = j; + do { + a.d[c2.p] = Kfb(a.d[c2.p]) + l; + c2 = a.a[c2.p]; + } while (c2 != j); + a.b[j.p] = l + m; + } + } + function S9c(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m; + f2 = 0; + g = a.t; + e = 0; + d = 0; + i2 = 0; + m = 0; + l = 0; + if (c2) { + a.n.c.length = 0; + Rmb(a.n, new _9c(a.s, a.t, a.i)); + } + h = 0; + for (k = new Anb(a.b); k.a < k.c.c.length; ) { + j = RD(ynb(k), 27); + if (f2 + j.g + (h > 0 ? a.i : 0) > b && i2 > 0) { + f2 = 0; + g += i2 + a.i; + e = $wnd.Math.max(e, m); + d += i2 + a.i; + i2 = 0; + m = 0; + if (c2) { + ++l; + Rmb(a.n, new _9c(a.s, g, a.i)); + } + h = 0; + } + m += j.g + (h > 0 ? a.i : 0); + i2 = $wnd.Math.max(i2, j.f); + c2 && W9c(RD(Vmb(a.n, l), 209), j); + f2 += j.g + (h > 0 ? a.i : 0); + ++h; + } + e = $wnd.Math.max(e, m); + d += i2; + if (c2) { + a.r = e; + a.d = d; + Ead(a.j); + } + return new Uid2(a.s, a.t, e, d); + } + function CRb(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m; + a.b = false; + l = oxe; + i2 = pxe; + m = oxe; + j = pxe; + for (d = a.e.a.ec().Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 272); + e = c2.a; + l = $wnd.Math.min(l, e.c); + i2 = $wnd.Math.max(i2, e.c + e.b); + m = $wnd.Math.min(m, e.d); + j = $wnd.Math.max(j, e.d + e.a); + for (g = new Anb(c2.c); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 407); + b = f2.a; + if (b.a) { + k = e.d + f2.b.b; + h = k + f2.c; + m = $wnd.Math.min(m, k); + j = $wnd.Math.max(j, h); + } else { + k = e.c + f2.b.a; + h = k + f2.c; + l = $wnd.Math.min(l, k); + i2 = $wnd.Math.max(i2, h); + } + } + } + a.a = new rjd(i2 - l, j - m); + a.c = new rjd(l + a.d.a, m + a.d.b); + } + function mYd(a) { + var b, c2, d, e, f2, g, h, i2; + if (!a.a) { + a.o = null; + i2 = new e_d(a); + b = new i_d(); + c2 = iYd; + h = c2.a.zc(a, c2); + if (h == null) { + for (g = new dMd(zYd(a)); g.e != g.i.gc(); ) { + f2 = RD(bMd(g), 29); + YGd(i2, mYd(f2)); + } + c2.a.Bc(a) != null; + c2.a.gc() == 0 && void 0; + } + for (e = (!a.s && (a.s = new C5d(y7, a, 21, 17)), new dMd(a.s)); e.e != e.i.gc(); ) { + d = RD(bMd(e), 179); + ZD(d, 331) && WGd(b, RD(d, 35)); + } + VHd(b); + a.k = new n_d(a, (RD(QHd(xYd((lTd(), kTd).o), 7), 19), b.i), b.g); + YGd(i2, a.k); + VHd(i2); + a.a = new N$d((RD(QHd(xYd(kTd.o), 4), 19), i2.i), i2.g); + yYd(a).b &= -2; + } + return a.a; + } + function age(a, b, c2, d) { + var e, f2, g, h, i2, j, k; + k = pke(a.e.Dh(), b); + e = 0; + f2 = RD(a.g, 124); + i2 = null; + nke(); + if (RD(b, 69).xk()) { + for (h = 0; h < a.i; ++h) { + g = f2[h]; + if (k.am(g.Lk())) { + if (pb(g, c2)) { + i2 = g; + break; + } + ++e; + } + } + } else if (c2 != null) { + for (h = 0; h < a.i; ++h) { + g = f2[h]; + if (k.am(g.Lk())) { + if (pb(c2, g.md())) { + i2 = g; + break; + } + ++e; + } + } + } else { + for (h = 0; h < a.i; ++h) { + g = f2[h]; + if (k.am(g.Lk())) { + if (g.md() == null) { + i2 = g; + break; + } + ++e; + } + } + } + if (i2) { + if (Mvd(a.e)) { + j = b.Jk() ? new lle(a.e, 4, b, c2, null, e, true) : fge(a, b.tk() ? 2 : 1, b, c2, b.ik(), -1, true); + d ? d.nj(j) : d = j; + } + d = _fe(a, i2, d); + } + return d; + } + function d8c(a, b, c2, d, e, f2, g) { + var h, i2, j, k, l, m, n, o2, p; + o2 = 0; + p = 0; + i2 = e.c; + h = e.b; + k = c2.f; + n = c2.g; + switch (b.g) { + case 0: + o2 = d.i + d.g + g; + a.c ? p = m8c(o2, f2, d, g) : p = d.j; + m = $wnd.Math.max(i2, o2 + n); + j = $wnd.Math.max(h, p + k); + break; + case 1: + p = d.j + d.f + g; + a.c ? o2 = l8c(p, f2, d, g) : o2 = d.i; + m = $wnd.Math.max(i2, o2 + n); + j = $wnd.Math.max(h, p + k); + break; + case 2: + o2 = i2 + g; + p = 0; + m = i2 + g + n; + j = $wnd.Math.max(h, k); + break; + case 3: + o2 = 0; + p = h + g; + m = $wnd.Math.max(i2, n); + j = h + g + k; + break; + default: + throw Adb(new agb("IllegalPlacementOption.")); + } + l = new mad(a.a, m, j, b, o2, p); + return l; + } + function g6b(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m; + h = a.d; + l = RD(mQb(a, (Ywc(), Xwc)), 15); + b = RD(mQb(a, Vvc), 15); + if (!l && !b) { + return; + } + f2 = Kfb(UD(hFc(a, (yCc(), QBc)))); + g = Kfb(UD(hFc(a, RBc))); + m = 0; + if (l) { + j = 0; + for (e = l.Kc(); e.Ob(); ) { + d = RD(e.Pb(), 10); + j = $wnd.Math.max(j, d.o.b); + m += d.o.a; + } + m += f2 * (l.gc() - 1); + h.d += j + g; + } + c2 = 0; + if (b) { + j = 0; + for (e = b.Kc(); e.Ob(); ) { + d = RD(e.Pb(), 10); + j = $wnd.Math.max(j, d.o.b); + c2 += d.o.a; + } + c2 += f2 * (b.gc() - 1); + h.a += j + g; + } + i2 = $wnd.Math.max(m, c2); + if (i2 > a.o.a) { + k = (i2 - a.o.a) / 2; + h.b = $wnd.Math.max(h.b, k); + h.c = $wnd.Math.max(h.c, k); + } + } + function RId(a) { + var b, c2, d, e, f2, g, h, i2; + f2 = new med(); + ied(f2, (hed(), eed)); + for (d = (e = oC(a, $C(qJ, Nve, 2, 0, 6, 1)), new Dkb(new mob(new CC(a, e).b))); d.b < d.d.gc(); ) { + c2 = (sFb(d.b < d.d.gc()), WD(d.d.Xb(d.c = d.b++))); + g = vgd(LId, c2); + if (g) { + b = qC(a, c2); + b.te() ? h = b.te().a : b.qe() ? h = "" + b.qe().a : b.re() ? h = "" + b.re().a : h = b.Ib(); + i2 = zhd(g, h); + if (i2 != null) { + (Csb(g.j, (Yhd(), Vhd)) || Csb(g.j, Whd)) && oQb(ked(f2, J4), g, i2); + Csb(g.j, Thd) && oQb(ked(f2, G4), g, i2); + Csb(g.j, Xhd) && oQb(ked(f2, K4), g, i2); + Csb(g.j, Uhd) && oQb(ked(f2, I4), g, i2); + } + } + } + return f2; + } + function ige(a, b, c2) { + var d, e, f2, g, h, i2, j, k; + e = RD(a.g, 124); + if (qke(a.e, b)) { + return nke(), RD(b, 69).xk() ? new ole(b, a) : new Eke(b, a); + } else { + j = pke(a.e.Dh(), b); + d = 0; + for (h = 0; h < a.i; ++h) { + f2 = e[h]; + g = f2.Lk(); + if (j.am(g)) { + nke(); + if (RD(b, 69).xk()) { + return f2; + } else if (g == (Lle(), Jle) || g == Gle) { + i2 = new dib(jeb(f2.md())); + while (++h < a.i) { + f2 = e[h]; + g = f2.Lk(); + (g == Jle || g == Gle) && Zhb(i2, jeb(f2.md())); + } + return Ije(RD(b.Hk(), 156), i2.a); + } else { + k = f2.md(); + k != null && c2 && ZD(b, 102) && (RD(b, 19).Bb & txe) != 0 && (k = Bge(a, b, h, d, k)); + return k; + } + } + ++d; + } + return b.ik(); + } + } + function hge(a, b, c2, d) { + var e, f2, g, h, i2, j; + i2 = pke(a.e.Dh(), b); + f2 = RD(a.g, 124); + if (qke(a.e, b)) { + e = 0; + for (h = 0; h < a.i; ++h) { + g = f2[h]; + if (i2.am(g.Lk())) { + if (e == c2) { + nke(); + if (RD(b, 69).xk()) { + return g; + } else { + j = g.md(); + j != null && d && ZD(b, 102) && (RD(b, 19).Bb & txe) != 0 && (j = Bge(a, b, h, e, j)); + return j; + } + } + ++e; + } + } + throw Adb(new veb(HJe + c2 + NIe + e)); + } else { + e = 0; + for (h = 0; h < a.i; ++h) { + g = f2[h]; + if (i2.am(g.Lk())) { + nke(); + if (RD(b, 69).xk()) { + return g; + } else { + j = g.md(); + j != null && d && ZD(b, 102) && (RD(b, 19).Bb & txe) != 0 && (j = Bge(a, b, h, e, j)); + return j; + } + } + ++e; + } + return b.ik(); + } + } + function xjb() { + xjb = geb; + vjb = cD(WC(kE, 1), Pwe, 28, 15, [qwe, 1162261467, hwe, 1220703125, 362797056, 1977326743, hwe, 387420489, ixe, 214358881, 429981696, 815730721, 1475789056, 170859375, 268435456, 410338673, 612220032, 893871739, 128e7, 1801088541, 113379904, 148035889, 191102976, 244140625, 308915776, 387420489, 481890304, 594823321, 729e6, 887503681, hwe, 1291467969, 1544804416, 1838265625, 60466176]); + wjb = cD(WC(kE, 1), Pwe, 28, 15, [-1, -1, 31, 19, 15, 13, 11, 11, 10, 9, 9, 8, 8, 8, 8, 7, 7, 7, 7, 7, 7, 7, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 5]); + } + function Gjb(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l; + g = a.e; + i2 = b.e; + if (i2 == 0) { + return a; + } + if (g == 0) { + return b.e == 0 ? b : new cjb(-b.e, b.d, b.a); + } + f2 = a.d; + h = b.d; + if (f2 + h == 2) { + c2 = Cdb(a.a[0], yxe); + d = Cdb(b.a[0], yxe); + g < 0 && (c2 = Odb(c2)); + i2 < 0 && (d = Odb(d)); + return Pib(), Jdb(Vdb(c2, d), 0) ? jjb(Vdb(c2, d)) : Xib(jjb(Odb(Vdb(c2, d)))); + } + e = f2 != h ? f2 > h ? 1 : -1 : Ejb(a.a, b.a, f2); + if (e == -1) { + l = -i2; + k = g == i2 ? Hjb(b.a, h, a.a, f2) : Cjb(b.a, h, a.a, f2); + } else { + l = g; + if (g == i2) { + if (e == 0) { + return Pib(), Oib; + } + k = Hjb(a.a, f2, b.a, h); + } else { + k = Cjb(a.a, f2, b.a, h); + } + } + j = new cjb(l, k.length, k); + Rib(j); + return j; + } + function c5b(a, b) { + var c2, d, e, f2; + f2 = Z4b(b); + !b.c && (b.c = new C5d(K4, b, 9, 9)); + FDb(new SDb(null, (!b.c && (b.c = new C5d(K4, b, 9, 9)), new Swb(b.c, 16))), new s5b(f2)); + e = RD(mQb(f2, (Ywc(), kwc)), 21); + Y4b(b, e); + if (e.Hc((ovc(), hvc))) { + for (d = new dMd((!b.c && (b.c = new C5d(K4, b, 9, 9)), b.c)); d.e != d.i.gc(); ) { + c2 = RD(bMd(d), 123); + g5b(a, b, f2, c2); + } + } + RD(Gxd(b, (yCc(), lBc)), 181).gc() != 0 && V4b(b, f2); + Heb(TD(mQb(f2, sBc))) && e.Fc(mvc); + nQb(f2, PBc) && HCc(new RCc(Kfb(UD(mQb(f2, PBc)))), f2); + dE(Gxd(b, IAc)) === dE((Fnd(), Cnd)) ? d5b(a, b, f2) : b5b(a, b, f2); + return f2; + } + function Vrc(a) { + var b, c2, d, e, f2, g, h, i2; + for (e = new Anb(a.b); e.a < e.c.c.length; ) { + d = RD(ynb(e), 30); + for (g = new Anb(bv(d.a)); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 10); + if (Lrc(f2)) { + c2 = RD(mQb(f2, (Ywc(), Wvc)), 313); + if (!c2.g && !!c2.d) { + b = c2; + i2 = c2.d; + while (i2) { + Urc(i2.i, i2.k, false, true); + asc(b.a); + asc(i2.i); + asc(i2.k); + asc(i2.b); + Z0b(i2.c, b.c.d); + Z0b(b.c, null); + g3b(b.a, null); + g3b(i2.i, null); + g3b(i2.k, null); + g3b(i2.b, null); + h = new Jrc(b.i, i2.a, b.e, i2.j, i2.f); + h.k = b.k; + h.n = b.n; + h.b = b.b; + h.c = i2.c; + h.g = b.g; + h.d = i2.d; + pQb(b.i, Wvc, h); + pQb(i2.a, Wvc, h); + i2 = i2.d; + b = h; + } + } + } + } + } + } + function nue(a, b) { + var c2, d, e, f2, g, h, i2; + if (a == null) { + return null; + } + f2 = a.length; + if (f2 == 0) { + return ""; + } + i2 = $C(hE, zwe, 28, f2, 15, 1); + AFb(0, f2, a.length); + AFb(0, f2, i2.length); + nhb(a, 0, f2, i2, 0); + c2 = null; + h = b; + for (e = 0, g = 0; e < f2; e++) { + d = i2[e]; + Kqe(); + if (d <= 32 && (Jqe[d] & 2) != 0) { + if (h) { + !c2 && (c2 = new Shb(a)); + Phb(c2, e - g++); + } else { + h = b; + if (d != 32) { + !c2 && (c2 = new Shb(a)); + peb(c2, e - g, e - g + 1, String.fromCharCode(32)); + } + } + } else { + h = false; + } + } + if (h) { + if (!c2) { + return AFb(0, f2 - 1, a.length), a.substr(0, f2 - 1); + } else { + f2 = c2.a.length; + return f2 > 0 ? zhb(c2.a, 0, f2 - 1) : ""; + } + } else { + return !c2 ? a : c2.a; + } + } + function xic(a, b) { + var c2, d, e, f2, g, h, i2; + b.Ug("Sort By Input Model " + mQb(a, (yCc(), cAc)), 1); + e = 0; + for (d = new Anb(a.b); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 30); + i2 = e == 0 ? 0 : e - 1; + h = RD(Vmb(a.b, i2), 30); + for (g = new Anb(c2.a); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 10); + if (dE(mQb(f2, BBc)) !== dE((Bod(), vod)) && dE(mQb(f2, BBc)) !== dE(wod)) { + yob(); + _mb(f2.j, new trc(h, RD(mQb(a, cAc), 284), Bic(f2), Heb(TD(mQb(a, bAc))))); + b.bh("Node " + f2 + " ports: " + f2.j); + } + } + yob(); + _mb(c2.a, new frc(h, RD(mQb(a, cAc), 284), RD(mQb(a, _zc), 390))); + b.bh("Layer " + e + ": " + c2); + ++e; + } + b.Vg(); + } + function ute(a, b) { + var c2, d, e, f2, g; + g = RD(b, 138); + vte(a); + vte(g); + if (g.b == null) + return; + a.c = true; + if (a.b == null) { + a.b = $C(kE, Pwe, 28, g.b.length, 15, 1); + hib(g.b, 0, a.b, 0, g.b.length); + return; + } + f2 = $C(kE, Pwe, 28, a.b.length + g.b.length, 15, 1); + for (c2 = 0, d = 0, e = 0; c2 < a.b.length || d < g.b.length; ) { + if (c2 >= a.b.length) { + f2[e++] = g.b[d++]; + f2[e++] = g.b[d++]; + } else if (d >= g.b.length) { + f2[e++] = a.b[c2++]; + f2[e++] = a.b[c2++]; + } else if (g.b[d] < a.b[c2] || g.b[d] === a.b[c2] && g.b[d + 1] < a.b[c2 + 1]) { + f2[e++] = g.b[d++]; + f2[e++] = g.b[d++]; + } else { + f2[e++] = a.b[c2++]; + f2[e++] = a.b[c2++]; + } + } + a.b = f2; + } + function hac(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l; + c2 = Heb(TD(mQb(a, (Ywc(), uwc)))); + h = Heb(TD(mQb(b, uwc))); + d = RD(mQb(a, vwc), 12); + i2 = RD(mQb(b, vwc), 12); + e = RD(mQb(a, wwc), 12); + j = RD(mQb(b, wwc), 12); + k = !!d && d == i2; + l = !!e && e == j; + if (!c2 && !h) { + return new oac(RD(ynb(new Anb(a.j)), 12).p == RD(ynb(new Anb(b.j)), 12).p, k, l); + } + f2 = (!Heb(TD(mQb(a, uwc))) || Heb(TD(mQb(a, twc)))) && (!Heb(TD(mQb(b, uwc))) || Heb(TD(mQb(b, twc)))); + g = (!Heb(TD(mQb(a, uwc))) || !Heb(TD(mQb(a, twc)))) && (!Heb(TD(mQb(b, uwc))) || !Heb(TD(mQb(b, twc)))); + return new oac(k && f2 || l && g, k, l); + } + function N9c(a) { + var b, c2, d, e, f2, g, h, i2; + d = 0; + c2 = 0; + i2 = new Yub(); + b = 0; + for (h = new Anb(a.n); h.a < h.c.c.length; ) { + g = RD(ynb(h), 209); + if (g.c.c.length == 0) { + Pub(i2, g, i2.c.b, i2.c); + } else { + d = $wnd.Math.max(d, g.d); + c2 += g.a + (b > 0 ? a.i : 0); + } + ++b; + } + Ce(a.n, i2); + a.d = c2; + a.r = d; + a.g = 0; + a.f = 0; + a.e = 0; + a.o = oxe; + a.p = oxe; + for (f2 = new Anb(a.b); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 27); + a.p = $wnd.Math.min(a.p, e.g); + a.g = $wnd.Math.max(a.g, e.g); + a.f = $wnd.Math.max(a.f, e.f); + a.o = $wnd.Math.min(a.o, e.f); + a.e += e.f + a.i; + } + a.a = a.e / a.b.c.length - a.i * ((a.b.c.length - 1) / a.b.c.length); + Ead(a.j); + } + function qzd(a) { + var b, c2, d, e; + if ((a.Db & 64) != 0) + return kyd(a); + b = new dib(BHe); + d = a.k; + if (!d) { + !a.n && (a.n = new C5d(I4, a, 1, 7)); + if (a.n.i > 0) { + e = (!a.n && (a.n = new C5d(I4, a, 1, 7)), RD(QHd(a.n, 0), 135)).a; + !e || Zhb(Zhb((b.a += ' "', b), e), '"'); + } + } else { + Zhb(Zhb((b.a += ' "', b), d), '"'); + } + c2 = (!a.b && (a.b = new Yie(E4, a, 4, 7)), !(a.b.i <= 1 && (!a.c && (a.c = new Yie(E4, a, 5, 8)), a.c.i <= 1))); + c2 ? (b.a += " [", b) : (b.a += " ", b); + Zhb(b, Eb(new Gb(), new dMd(a.b))); + c2 && (b.a += "]", b); + b.a += SAe; + c2 && (b.a += "[", b); + Zhb(b, Eb(new Gb(), new dMd(a.c))); + c2 && (b.a += "]", b); + return b.a; + } + function odc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5; + v = a.c; + w2 = b.c; + c2 = Wmb(v.a, a, 0); + d = Wmb(w2.a, b, 0); + t = RD(c3b(a, (BEc(), yEc)).Kc().Pb(), 12); + C = RD(c3b(a, zEc).Kc().Pb(), 12); + u = RD(c3b(b, yEc).Kc().Pb(), 12); + D5 = RD(c3b(b, zEc).Kc().Pb(), 12); + r = s2b(t.e); + A = s2b(C.g); + s = s2b(u.e); + B = s2b(D5.g); + f3b(a, d, w2); + for (g = s, k = 0, o2 = g.length; k < o2; ++k) { + e = g[k]; + Z0b(e, t); + } + for (h = B, l = 0, p = h.length; l < p; ++l) { + e = h[l]; + Y0b(e, C); + } + f3b(b, c2, v); + for (i2 = r, m = 0, q = i2.length; m < q; ++m) { + e = i2[m]; + Z0b(e, u); + } + for (f2 = A, j = 0, n = f2.length; j < n; ++j) { + e = f2[j]; + Y0b(e, D5); + } + } + function $2c(a) { + var b, c2, d, e, f2, g, h; + g = RD(Gxd(a, (u2c(), t2c)), 27); + for (d = new dMd((!g.e && (g.e = new Yie(G4, g, 7, 4)), g.e)); d.e != d.i.gc(); ) { + c2 = RD(bMd(d), 74); + h = new rjd(RD(QHd((!c2.a && (c2.a = new C5d(F4, c2, 6, 6)), c2.a), 0), 166).j, RD(QHd((!c2.a && (c2.a = new C5d(F4, c2, 6, 6)), c2.a), 0), 166).k); + f2 = new rjd(RD(QHd((!c2.a && (c2.a = new C5d(F4, c2, 6, 6)), c2.a), 0), 166).b, RD(QHd((!c2.a && (c2.a = new C5d(F4, c2, 6, 6)), c2.a), 0), 166).c); + e = new rjd(f2.a - h.a, f2.b - h.b); + b = $wnd.Math.atan2(e.b, e.a); + RD(QHd((!c2.c && (c2.c = new Yie(E4, c2, 5, 8)), c2.c), 0), 84).qf(($4c(), W4c), b); + } + } + function o6c(a, b) { + var c2, d, e, f2, g, h, i2, j, k; + b.Ug("Interactive Node Reorderer", 1); + k = (!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a); + h = new bnb(); + for (e = new dMd(k); e.e != e.i.gc(); ) { + c2 = RD(bMd(e), 27); + Hxd(c2, (X7c(), A7c)) && (ZEb(h.c, c2), true); + } + for (f2 = new Anb(h); f2.a < f2.c.c.length; ) { + c2 = RD(ynb(f2), 27); + dHd(k, c2); + } + yob(); + _mb(h, new s6c()); + for (g = new Anb(h); g.a < g.c.c.length; ) { + c2 = RD(ynb(g), 27); + j = RD(Gxd(c2, (X7c(), A7c)), 17).a; + j = $wnd.Math.min(j, k.i); + VGd(k, j, c2); + } + i2 = 0; + for (d = new dMd(k); d.e != d.i.gc(); ) { + c2 = RD(bMd(d), 27); + Ixd(c2, (X7c(), z7c), sgb(i2)); + ++i2; + } + b.Vg(); + } + function PTc(a, b, c2) { + var d, e, f2, g, h, i2, j, k; + if ($wnd.Math.abs(b.s - b.c) < Vze || $wnd.Math.abs(c2.s - c2.c) < Vze) { + return 0; + } + d = OTc(a, b.j, c2.e); + e = OTc(a, c2.j, b.e); + f2 = d == -1 || e == -1; + g = 0; + if (f2) { + if (d == -1) { + new bTc((fTc(), dTc), c2, b, 1); + ++g; + } + if (e == -1) { + new bTc((fTc(), dTc), b, c2, 1); + ++g; + } + } else { + h = VTc(b.j, c2.s, c2.c); + h += VTc(c2.e, b.s, b.c); + i2 = VTc(c2.j, b.s, b.c); + i2 += VTc(b.e, c2.s, c2.c); + j = d + 16 * h; + k = e + 16 * i2; + if (j < k) { + new bTc((fTc(), eTc), b, c2, k - j); + } else if (j > k) { + new bTc((fTc(), eTc), c2, b, j - k); + } else if (j > 0 && k > 0) { + new bTc((fTc(), eTc), b, c2, 0); + new bTc(eTc, c2, b, 0); + } + } + return g; + } + function pXc(a, b, c2) { + var d, e, f2; + a.a = new bnb(); + for (f2 = Sub(b.b, 0); f2.b != f2.d.c; ) { + e = RD(evb(f2), 40); + while (RD(mQb(e, (h_c(), f_c)), 17).a > a.a.c.length - 1) { + Rmb(a.a, new Ptd(Hze, KEe)); + } + d = RD(mQb(e, f_c), 17).a; + if (c2 == (Cmd(), ymd) || c2 == zmd) { + e.e.a < Kfb(UD(RD(Vmb(a.a, d), 42).a)) && Ntd(RD(Vmb(a.a, d), 42), e.e.a); + e.e.a + e.f.a > Kfb(UD(RD(Vmb(a.a, d), 42).b)) && Otd(RD(Vmb(a.a, d), 42), e.e.a + e.f.a); + } else { + e.e.b < Kfb(UD(RD(Vmb(a.a, d), 42).a)) && Ntd(RD(Vmb(a.a, d), 42), e.e.b); + e.e.b + e.f.b > Kfb(UD(RD(Vmb(a.a, d), 42).b)) && Otd(RD(Vmb(a.a, d), 42), e.e.b + e.f.b); + } + } + } + function g2b(a, b, c2, d) { + var e, f2, g, h, i2, j, k; + f2 = i2b(d); + h = Heb(TD(mQb(d, (yCc(), aBc)))); + if ((h || Heb(TD(mQb(a, MAc)))) && !Dod(RD(mQb(a, BBc), 101))) { + e = vpd(f2); + i2 = q2b(a, c2, c2 == (BEc(), zEc) ? e : spd(e)); + } else { + i2 = new R3b(); + P3b(i2, a); + if (b) { + k = i2.n; + k.a = b.a - a.n.a; + k.b = b.b - a.n.b; + _id(k, 0, 0, a.o.a, a.o.b); + Q3b(i2, c2b(i2, f2)); + } else { + e = vpd(f2); + Q3b(i2, c2 == (BEc(), zEc) ? e : spd(e)); + } + g = RD(mQb(d, (Ywc(), kwc)), 21); + j = i2.j; + switch (f2.g) { + case 2: + case 1: + (j == (qpd(), Yod) || j == npd) && g.Fc((ovc(), lvc)); + break; + case 4: + case 3: + (j == (qpd(), Xod) || j == ppd) && g.Fc((ovc(), lvc)); + } + } + return i2; + } + function VXb(a, b) { + var c2, d, e, f2, g, h; + for (g = new vkb(new mkb(a.f.b).a); g.b; ) { + f2 = tkb(g); + e = RD(f2.ld(), 602); + if (b == 1) { + if (e.Af() != (Cmd(), Bmd) && e.Af() != xmd) { + continue; + } + } else { + if (e.Af() != (Cmd(), ymd) && e.Af() != zmd) { + continue; + } + } + d = RD(RD(f2.md(), 42).b, 86); + h = RD(RD(f2.md(), 42).a, 194); + c2 = h.c; + switch (e.Af().g) { + case 2: + d.g.c = a.e.a; + d.g.b = $wnd.Math.max(1, d.g.b + c2); + break; + case 1: + d.g.c = d.g.c + c2; + d.g.b = $wnd.Math.max(1, d.g.b - c2); + break; + case 4: + d.g.d = a.e.b; + d.g.a = $wnd.Math.max(1, d.g.a + c2); + break; + case 3: + d.g.d = d.g.d + c2; + d.g.a = $wnd.Math.max(1, d.g.a - c2); + } + } + } + function NNc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p; + h = $C(kE, Pwe, 28, b.b.c.length, 15, 1); + j = $C(hR, jwe, 273, b.b.c.length, 0, 1); + i2 = $C(jR, WAe, 10, b.b.c.length, 0, 1); + for (l = a.a, m = 0, n = l.length; m < n; ++m) { + k = l[m]; + p = 0; + for (g = new Anb(k.e); g.a < g.c.c.length; ) { + e = RD(ynb(g), 10); + d = Q4b(e.c); + ++h[d]; + o2 = Kfb(UD(mQb(b, (yCc(), TBc)))); + h[d] > 0 && !!i2[d] && (o2 = bFc(a.b, i2[d], e)); + p = $wnd.Math.max(p, e.c.c.b + o2); + } + for (f2 = new Anb(k.e); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 10); + e.n.b = p + e.d.d; + c2 = e.c; + c2.c.b = p + e.d.d + e.o.b + e.d.a; + j[Wmb(c2.b.b, c2, 0)] = e.k; + i2[Wmb(c2.b.b, c2, 0)] = e; + } + } + } + function M5c(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m; + for (d = new is(Mr(zGd(b).a.Kc(), new ir())); gs(d); ) { + c2 = RD(hs(d), 74); + if (!ZD(QHd((!c2.b && (c2.b = new Yie(E4, c2, 4, 7)), c2.b), 0), 193)) { + i2 = AGd(RD(QHd((!c2.c && (c2.c = new Yie(E4, c2, 5, 8)), c2.c), 0), 84)); + if (!nzd(c2)) { + g = b.i + b.g / 2; + h = b.j + b.f / 2; + k = i2.i + i2.g / 2; + l = i2.j + i2.f / 2; + m = new pjd(); + m.a = k - g; + m.b = l - h; + f2 = new rjd(m.a, m.b); + wid(f2, b.g, b.f); + m.a -= f2.a; + m.b -= f2.b; + g = k - m.a; + h = l - m.b; + j = new rjd(m.a, m.b); + wid(j, i2.g, i2.f); + m.a -= j.a; + m.b -= j.b; + k = g + m.a; + l = h + m.b; + e = IGd(c2, true, true); + Ozd(e, g); + Pzd(e, h); + Hzd(e, k); + Izd(e, l); + M5c(a, i2); + } + } + } + } + function ocd(a) { + Cgd(a, new Pfd($fd(Xfd(Zfd(Yfd(new agd(), hGe), "ELK SPOrE Compaction"), "ShrinkTree is a compaction algorithm that maintains the topology of a layout. The relocation of diagram elements is based on contracting a spanning tree."), new rcd()))); + Agd(a, hGe, iGe, iGd(mcd)); + Agd(a, hGe, jGe, iGd(jcd)); + Agd(a, hGe, kGe, iGd(icd)); + Agd(a, hGe, lGe, iGd(gcd)); + Agd(a, hGe, mGe, iGd(hcd)); + Agd(a, hGe, Eze, fcd); + Agd(a, hGe, _ze, 8); + Agd(a, hGe, nGe, iGd(lcd)); + Agd(a, hGe, oGe, iGd(bcd)); + Agd(a, hGe, pGe, iGd(ccd)); + Agd(a, hGe, LDe, (Geb(), false)); + } + function hQc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l; + b.Ug("Simple node placement", 1); + l = RD(mQb(a, (Ywc(), Qwc)), 312); + h = 0; + for (f2 = new Anb(a.b); f2.a < f2.c.c.length; ) { + d = RD(ynb(f2), 30); + g = d.c; + g.b = 0; + c2 = null; + for (j = new Anb(d.a); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 10); + !!c2 && (g.b += _Ec(i2, c2, l.c)); + g.b += i2.d.d + i2.o.b + i2.d.a; + c2 = i2; + } + h = $wnd.Math.max(h, g.b); + } + for (e = new Anb(a.b); e.a < e.c.c.length; ) { + d = RD(ynb(e), 30); + g = d.c; + k = (h - g.b) / 2; + c2 = null; + for (j = new Anb(d.a); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 10); + !!c2 && (k += _Ec(i2, c2, l.c)); + k += i2.d.d; + i2.n.b = k; + k += i2.o.b + i2.d.a; + c2 = i2; + } + } + b.Vg(); + } + function tqc(a, b) { + var c2, d, e, f2; + nqc(b.b.j); + FDb(GDb(new SDb(null, new Swb(b.d, 16)), new Eqc()), new Gqc()); + for (f2 = new Anb(b.d); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 105); + switch (e.e.g) { + case 0: + c2 = RD(Vmb(e.j, 0), 113).d.j; + Smc(e, RD(Lvb(KDb(RD(Qc(e.k, c2), 15).Oc(), lqc)), 113)); + Tmc(e, RD(Lvb(JDb(RD(Qc(e.k, c2), 15).Oc(), lqc)), 113)); + break; + case 1: + d = foc(e); + Smc(e, RD(Lvb(KDb(RD(Qc(e.k, d[0]), 15).Oc(), lqc)), 113)); + Tmc(e, RD(Lvb(JDb(RD(Qc(e.k, d[1]), 15).Oc(), lqc)), 113)); + break; + case 2: + vqc(a, e); + break; + case 3: + uqc(e); + break; + case 4: + sqc(a, e); + } + qqc(e); + } + a.a = null; + } + function yRc(a, b, c2) { + var d, e, f2, g, h, i2, j, k; + d = a.a.o == (EQc(), DQc) ? oxe : pxe; + h = zRc(a, new xRc(b, c2)); + if (!h.a && h.c) { + Mub(a.d, h); + return d; + } else if (h.a) { + e = h.a.c; + i2 = h.a.d; + if (c2) { + j = a.a.c == (wQc(), vQc) ? i2 : e; + f2 = a.a.c == vQc ? e : i2; + g = a.a.g[f2.i.p]; + k = Kfb(a.a.p[g.p]) + Kfb(a.a.d[f2.i.p]) + f2.n.b + f2.a.b - Kfb(a.a.d[j.i.p]) - j.n.b - j.a.b; + } else { + j = a.a.c == (wQc(), uQc) ? i2 : e; + f2 = a.a.c == uQc ? e : i2; + k = Kfb(a.a.p[a.a.g[f2.i.p].p]) + Kfb(a.a.d[f2.i.p]) + f2.n.b + f2.a.b - Kfb(a.a.d[j.i.p]) - j.n.b - j.a.b; + } + a.a.n[a.a.g[e.i.p].p] = (Geb(), true); + a.a.n[a.a.g[i2.i.p].p] = true; + return k; + } + return d; + } + function Sfe(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l; + if (d.gc() == 0) { + return false; + } + i2 = (nke(), RD(b, 69).xk()); + g = i2 ? d : new ZHd(d.gc()); + if (qke(a.e, b)) { + if (b.Si()) { + for (k = d.Kc(); k.Ob(); ) { + j = k.Pb(); + if (!dge(a, b, j, ZD(b, 102) && (RD(b, 19).Bb & txe) != 0)) { + f2 = oke(b, j); + g.Fc(f2); + } + } + } else if (!i2) { + for (k = d.Kc(); k.Ob(); ) { + j = k.Pb(); + f2 = oke(b, j); + g.Fc(f2); + } + } + } else { + l = pke(a.e.Dh(), b); + e = RD(a.g, 124); + for (h = 0; h < a.i; ++h) { + f2 = e[h]; + if (l.am(f2.Lk())) { + throw Adb(new agb(gLe)); + } + } + if (d.gc() > 1) { + throw Adb(new agb(gLe)); + } + if (!i2) { + f2 = oke(b, d.Kc().Pb()); + g.Fc(f2); + } + } + return XGd(a, gge(a, b, c2), g); + } + function Fge(a, b, c2) { + var d, e, f2, g, h, i2, j, k; + if (qke(a.e, b)) { + i2 = (nke(), RD(b, 69).xk() ? new ole(b, a) : new Eke(b, a)); + bge(i2.c, i2.b); + Ake(i2, RD(c2, 16)); + } else { + k = pke(a.e.Dh(), b); + d = RD(a.g, 124); + for (g = 0; g < a.i; ++g) { + e = d[g]; + f2 = e.Lk(); + if (k.am(f2)) { + if (f2 == (Lle(), Jle) || f2 == Gle) { + j = Mge(a, b, c2); + h = g; + j ? vLd(a, g) : ++g; + while (g < a.i) { + e = d[g]; + f2 = e.Lk(); + f2 == Jle || f2 == Gle ? vLd(a, g) : ++g; + } + j || RD(eHd(a, h, oke(b, c2)), 76); + } else + Mge(a, b, c2) ? vLd(a, g) : RD(eHd(a, g, (nke(), RD(b, 69).xk() ? RD(c2, 76) : oke(b, c2))), 76); + return; + } + } + Mge(a, b, c2) || WGd(a, (nke(), RD(b, 69).xk() ? RD(c2, 76) : oke(b, c2))); + } + } + function zPb(a, b, c2) { + var d, e, f2, g, h, i2, j, k; + if (!pb(c2, a.b)) { + a.b = c2; + f2 = new CPb(); + g = RD(zDb(GDb(new SDb(null, new Swb(c2.f, 16)), f2), sBb(new _Bb(), new bCb(), new yCb(), new ACb(), cD(WC(QL, 1), jwe, 108, 0, [(xBb(), wBb), vBb]))), 21); + a.e = true; + a.f = true; + a.c = true; + a.d = true; + e = g.Hc((IPb(), FPb)); + d = g.Hc(GPb); + e && !d && (a.f = false); + !e && d && (a.d = false); + e = g.Hc(EPb); + d = g.Hc(HPb); + e && !d && (a.c = false); + !e && d && (a.e = false); + } + k = RD(a.a.Ve(b, c2), 42); + i2 = RD(k.a, 17).a; + j = RD(k.b, 17).a; + h = false; + i2 < 0 ? a.c || (h = true) : a.e || (h = true); + j < 0 ? a.d || (h = true) : a.f || (h = true); + return h ? zPb(a, k, c2) : k; + } + function fNb(a) { + var b, c2, d, e; + e = a.o; + RMb(); + if (a.A.dc() || pb(a.A, QMb)) { + b = e.b; + } else { + b = YKb(a.f); + if (a.A.Hc((Qpd(), Npd)) && !a.B.Hc((dqd(), _pd))) { + b = $wnd.Math.max(b, YKb(RD(Vrb(a.p, (qpd(), Xod)), 252))); + b = $wnd.Math.max(b, YKb(RD(Vrb(a.p, ppd), 252))); + } + c2 = TMb(a); + !!c2 && (b = $wnd.Math.max(b, c2.b)); + if (a.A.Hc(Opd)) { + if (a.q == (Bod(), xod) || a.q == wod) { + b = $wnd.Math.max(b, SJb(RD(Vrb(a.b, (qpd(), Xod)), 127))); + b = $wnd.Math.max(b, SJb(RD(Vrb(a.b, ppd), 127))); + } + } + } + Heb(TD(a.e.Tf().of((umd(), mld)))) ? e.b = $wnd.Math.max(e.b, b) : e.b = b; + d = a.f.i; + d.d = 0; + d.a = b; + _Kb(a.f); + } + function yNc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p; + for (l = 0; l < b.length; l++) { + for (h = a.Kc(); h.Ob(); ) { + f2 = RD(h.Pb(), 230); + f2.hg(l, b); + } + for (m = 0; m < b[l].length; m++) { + for (i2 = a.Kc(); i2.Ob(); ) { + f2 = RD(i2.Pb(), 230); + f2.ig(l, m, b); + } + p = b[l][m].j; + for (n = 0; n < p.c.length; n++) { + for (j = a.Kc(); j.Ob(); ) { + f2 = RD(j.Pb(), 230); + f2.jg(l, m, n, b); + } + o2 = (tFb(n, p.c.length), RD(p.c[n], 12)); + c2 = 0; + for (e = new l4b(o2.b); xnb(e.a) || xnb(e.b); ) { + d = RD(xnb(e.a) ? ynb(e.a) : ynb(e.b), 18); + for (k = a.Kc(); k.Ob(); ) { + f2 = RD(k.Pb(), 230); + f2.gg(l, m, n, c2++, d, b); + } + } + } + } + } + for (g = a.Kc(); g.Ob(); ) { + f2 = RD(g.Pb(), 230); + f2.fg(); + } + } + function $7b(a, b) { + var c2, d, e, f2, g, h, i2; + a.b = Kfb(UD(mQb(b, (yCc(), UBc)))); + a.c = Kfb(UD(mQb(b, XBc))); + a.d = RD(mQb(b, DAc), 350); + a.a = RD(mQb(b, Xzc), 282); + Y7b(b); + h = RD(zDb(CDb(CDb(EDb(EDb(new SDb(null, new Swb(b.b, 16)), new c8b()), new e8b()), new g8b()), new i8b()), tBb(new ZBb(), new XBb(), new wCb(), cD(WC(QL, 1), jwe, 108, 0, [(xBb(), vBb)]))), 15); + for (e = h.Kc(); e.Ob(); ) { + c2 = RD(e.Pb(), 18); + g = RD(mQb(c2, (Ywc(), Twc)), 15); + g.Jc(new k8b(a)); + pQb(c2, Twc, null); + } + for (d = h.Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 18); + i2 = RD(mQb(c2, (Ywc(), Uwc)), 18); + f2 = RD(mQb(c2, Rwc), 15); + S7b(a, f2, i2); + pQb(c2, Rwc, null); + } + } + function r2d(a, b) { + var c2, d, e, f2, g, h, i2; + if (a.a) { + h = a.a.xe(); + i2 = null; + if (h != null) { + b.a += "" + h; + } else { + g = a.a.mk(); + if (g != null) { + f2 = qhb(g, Fhb(91)); + if (f2 != -1) { + i2 = (BFb(f2, g.length + 1), g.substr(f2)); + b.a += "" + zhb(g == null ? vve : (uFb(g), g), 0, f2); + } else { + b.a += "" + g; + } + } + } + if (!!a.d && a.d.i != 0) { + e = true; + b.a += "<"; + for (d = new dMd(a.d); d.e != d.i.gc(); ) { + c2 = RD(bMd(d), 89); + e ? e = false : (b.a += pve, b); + r2d(c2, b); + } + b.a += ">"; + } + i2 != null && (b.a += "" + i2, b); + } else if (a.e) { + h = a.e.zb; + h != null && (b.a += "" + h, b); + } else { + b.a += "?"; + if (a.b) { + b.a += " super "; + r2d(a.b, b); + } else { + if (a.f) { + b.a += " extends "; + r2d(a.f, b); + } + } + } + } + function Uae(a) { + a.b = null; + a.a = null; + a.o = null; + a.q = null; + a.v = null; + a.w = null; + a.B = null; + a.p = null; + a.Q = null; + a.R = null; + a.S = null; + a.T = null; + a.U = null; + a.V = null; + a.W = null; + a.bb = null; + a.eb = null; + a.ab = null; + a.H = null; + a.db = null; + a.c = null; + a.d = null; + a.f = null; + a.n = null; + a.r = null; + a.s = null; + a.u = null; + a.G = null; + a.J = null; + a.e = null; + a.j = null; + a.i = null; + a.g = null; + a.k = null; + a.t = null; + a.F = null; + a.I = null; + a.L = null; + a.M = null; + a.O = null; + a.P = null; + a.$ = null; + a.N = null; + a.Z = null; + a.cb = null; + a.K = null; + a.D = null; + a.A = null; + a.C = null; + a._ = null; + a.fb = null; + a.X = null; + a.Y = null; + a.gb = false; + a.hb = false; + } + function yib(a) { + var b, c2, d, e; + d = Ajb((!a.c && (a.c = ojb(Hdb(a.f))), a.c), 0); + if (a.e == 0 || a.a == 0 && a.f != -1 && a.e < 0) { + return d; + } + b = xib(a) < 0 ? 1 : 0; + c2 = a.e; + e = (d.length + 1 + $wnd.Math.abs(eE(a.e)), new cib()); + b == 1 && (e.a += "-", e); + if (a.e > 0) { + c2 -= d.length - b; + if (c2 >= 0) { + e.a += "0."; + for (; c2 > mib.length; c2 -= mib.length) { + $hb(e, mib); + } + _hb(e, mib, eE(c2)); + Zhb(e, (BFb(b, d.length + 1), d.substr(b))); + } else { + c2 = b - c2; + Zhb(e, zhb(d, b, eE(c2))); + e.a += "."; + Zhb(e, yhb(d, eE(c2))); + } + } else { + Zhb(e, (BFb(b, d.length + 1), d.substr(b))); + for (; c2 < -mib.length; c2 += mib.length) { + $hb(e, mib); + } + _hb(e, mib, eE(-c2)); + } + return e.a; + } + function BOc(a) { + var b, c2, d, e, f2, g, h, i2, j; + if (a.k != (r3b(), p3b)) { + return false; + } + if (a.j.c.length <= 1) { + return false; + } + f2 = RD(mQb(a, (yCc(), BBc)), 101); + if (f2 == (Bod(), wod)) { + return false; + } + e = (wDc(), (!a.q ? (yob(), yob(), wob) : a.q)._b(iBc) ? d = RD(mQb(a, iBc), 203) : d = RD(mQb(Y2b(a), jBc), 203), d); + if (e == uDc) { + return false; + } + if (!(e == tDc || e == sDc)) { + g = Kfb(UD(hFc(a, fCc))); + b = RD(mQb(a, eCc), 140); + !b && (b = new R2b(g, g, g, g)); + j = b3b(a, (qpd(), ppd)); + i2 = b.d + b.a + (j.gc() - 1) * g; + if (i2 > a.o.b) { + return false; + } + c2 = b3b(a, Xod); + h = b.d + b.a + (c2.gc() - 1) * g; + if (h > a.o.b) { + return false; + } + } + return true; + } + function VRc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q; + b.Ug("Orthogonal edge routing", 1); + j = Kfb(UD(mQb(a, (yCc(), cCc)))); + c2 = Kfb(UD(mQb(a, UBc))); + d = Kfb(UD(mQb(a, XBc))); + m = new TTc(0, c2); + q = 0; + g = new Jkb(a.b, 0); + h = null; + k = null; + i2 = null; + l = null; + do { + k = g.b < g.d.gc() ? (sFb(g.b < g.d.gc()), RD(g.d.Xb(g.c = g.b++), 30)) : null; + l = !k ? null : k.a; + if (h) { + p2b(h, q); + q += h.c.a; + } + p = !h ? q : q + d; + o2 = STc(m, a, i2, l, p); + e = !h || ar(i2, (dSc(), bSc)); + f2 = !k || ar(l, (dSc(), bSc)); + if (o2 > 0) { + n = (o2 - 1) * c2; + !!h && (n += d); + !!k && (n += d); + n < j && !e && !f2 && (n = j); + q += n; + } else + !e && !f2 && (q += j); + h = k; + i2 = l; + } while (k); + a.f.a = q; + b.Vg(); + } + function tfe(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l; + k = null; + !!a.d && (k = RD(Xjb(a.d, b), 142)); + if (!k) { + f2 = a.a.vi(); + l = f2.i; + if (!a.d || bkb(a.d) != l) { + i2 = new Tsb(); + !!a.d && Ld(i2, a.d); + j = i2.f.c + i2.i.c; + for (h = j; h < l; ++h) { + d = RD(QHd(f2, h), 142); + e = Oee(a.e, d).xe(); + c2 = RD(e == null ? rtb(i2.f, null, d) : Ltb(i2.i, e, d), 142); + !!c2 && c2 != d && (e == null ? rtb(i2.f, null, c2) : Ltb(i2.i, e, c2)); + } + if (i2.f.c + i2.i.c != l) { + for (g = 0; g < j; ++g) { + d = RD(QHd(f2, g), 142); + e = Oee(a.e, d).xe(); + c2 = RD(e == null ? rtb(i2.f, null, d) : Ltb(i2.i, e, d), 142); + !!c2 && c2 != d && (e == null ? rtb(i2.f, null, c2) : Ltb(i2.i, e, c2)); + } + } + a.d = i2; + } + k = RD(Xjb(a.d, b), 142); + } + return k; + } + function w0b(a, b, c2, d, e, f2, g) { + var h, i2, j, k, l, m, n; + l = Heb(TD(mQb(b, (yCc(), bBc)))); + m = null; + f2 == (BEc(), yEc) && d.c.i == c2 ? m = d.c : f2 == zEc && d.d.i == c2 && (m = d.d); + j = g; + if (!j || !l || !!m) { + k = (qpd(), opd); + m ? k = m.j : Dod(RD(mQb(c2, BBc), 101)) && (k = f2 == yEc ? ppd : Xod); + i2 = t0b(a, b, c2, f2, k, d); + h = s0b((Y2b(c2), d)); + if (f2 == yEc) { + Y0b(h, RD(Vmb(i2.j, 0), 12)); + Z0b(h, e); + } else { + Y0b(h, e); + Z0b(h, RD(Vmb(i2.j, 0), 12)); + } + j = new G0b(d, h, i2, RD(mQb(i2, (Ywc(), Awc)), 12), f2, !m); + } else { + Rmb(j.e, d); + n = $wnd.Math.max(Kfb(UD(mQb(j.d, FAc))), Kfb(UD(mQb(d, FAc)))); + pQb(j.d, FAc, n); + } + Rc(a.a, d, new J0b(j.d, b, f2)); + return j; + } + function gSd() { + gSd = geb; + var a; + fSd = new MSd(); + _Rd = $C(qJ, Nve, 2, 0, 6, 1); + URd = Rdb(xSd(33, 58), xSd(1, 26)); + VRd = Rdb(xSd(97, 122), xSd(65, 90)); + WRd = xSd(48, 57); + SRd = Rdb(URd, 0); + TRd = Rdb(VRd, WRd); + XRd = Rdb(Rdb(0, xSd(1, 6)), xSd(33, 38)); + YRd = Rdb(Rdb(WRd, xSd(65, 70)), xSd(97, 102)); + cSd = Rdb(SRd, vSd("-_.!~*'()")); + dSd = Rdb(TRd, ySd("-_.!~*'()")); + vSd(MJe); + ySd(MJe); + Rdb(cSd, vSd(";:@&=+$,")); + Rdb(dSd, ySd(";:@&=+$,")); + ZRd = vSd(":/?#"); + $Rd = ySd(":/?#"); + aSd = vSd("/?#"); + bSd = ySd("/?#"); + a = new _sb(); + a.a.zc("jar", a); + a.a.zc("zip", a); + a.a.zc("archive", a); + eSd = (yob(), new Lqb(a)); + } + function t0b(a, b, c2, d, e, f2) { + var g, h, i2, j, k, l; + g = null; + j = d == (BEc(), yEc) ? f2.c : f2.d; + i2 = i2b(b); + if (j.i == c2) { + g = RD(Wjb(a.b, j), 10); + if (!g) { + g = f2b(j, RD(mQb(c2, (yCc(), BBc)), 101), e, p0b(j), null, j.n, j.o, i2, b); + pQb(g, (Ywc(), Awc), j); + Zjb(a.b, j, g); + } + } else { + g = f2b((k = new qQb(), l = Kfb(UD(mQb(b, (yCc(), TBc)))) / 2, oQb(k, ABc, l), k), RD(mQb(c2, BBc), 101), e, d == yEc ? -1 : 1, null, new pjd(), new rjd(0, 0), i2, b); + h = u0b(g, c2, d); + pQb(g, (Ywc(), Awc), h); + Zjb(a.b, h, g); + } + RD(mQb(b, (Ywc(), kwc)), 21).Fc((ovc(), hvc)); + Dod(RD(mQb(b, (yCc(), BBc)), 101)) ? pQb(b, BBc, (Bod(), yod)) : pQb(b, BBc, (Bod(), zod)); + return g; + } + function Yec(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2; + h = 0; + o2 = 0; + i2 = Fnb(a.g, a.g.length); + f2 = a.e; + g = a.j; + d = a.b; + e = a.c; + do { + n = 0; + for (k = new Anb(a.q); k.a < k.c.c.length; ) { + j = RD(ynb(k), 10); + m = Wec(a, j); + c2 = true; + (a.r == (aEc(), VDc) || a.r == YDc) && (c2 = Heb(TD(m.b))); + if (RD(m.a, 17).a < 0 && c2) { + ++n; + i2 = Fnb(a.g, a.g.length); + a.e = a.e + RD(m.a, 17).a; + o2 += f2 - a.e; + f2 = a.e + RD(m.a, 17).a; + g = a.j; + d = bv(a.b); + e = bv(a.c); + } else { + a.g = Fnb(i2, i2.length); + a.e = f2; + a.b = (Qb(d), d ? new dnb(d) : cv(new Anb(d))); + a.c = (Qb(e), e ? new dnb(e) : cv(new Anb(e))); + a.j = g; + } + } + ++h; + l = n != 0 && Heb(TD(b.Kb(new Ptd(sgb(o2), sgb(h))))); + } while (l); + } + function e8c(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C; + g = a.f; + m = b.f; + h = g == (sad(), nad) || g == pad2; + n = m == nad || m == pad2; + i2 = g == oad || g == qad; + o2 = m == oad || m == qad; + j = g == oad || g == nad; + p = m == oad || m == nad; + if (h && n) { + return a.f == pad2 ? a : b; + } else if (i2 && o2) { + return a.f == qad ? a : b; + } else if (j && p) { + if (g == oad) { + l = a; + k = b; + } else { + l = b; + k = a; + } + f2 = (q = c2.j + c2.f, r = l.e + d.f, s = $wnd.Math.max(q, r), t = s - $wnd.Math.min(c2.j, l.e), u = l.d + d.g - c2.i, u * t); + e = (v = c2.i + c2.g, w2 = k.d + d.g, A = $wnd.Math.max(v, w2), B = A - $wnd.Math.min(c2.i, k.d), C = k.e + d.f - c2.j, B * C); + return f2 <= e ? a.f == oad ? a : b : a.f == nad ? a : b; + } + return a; + } + function t0c(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l; + pQb(b, (q$c(), g$c), 0); + i2 = RD(mQb(b, c$c), 40); + if (b.d.b == 0) { + if (i2) { + k = Kfb(UD(mQb(i2, j$c))) + a.b + u0c(a, i2, b); + pQb(b, j$c, k); + } else { + pQb(b, j$c, 0); + } + } else { + for (d = (f2 = Sub(new dXc(b).a.d, 0), new gXc(f2)); dvb(d.a); ) { + c2 = RD(evb(d.a), 65).c; + t0c(a, c2); + } + h = RD(Hr((g = Sub(new dXc(b).a.d, 0), new gXc(g))), 40); + l = RD(Gr((e = Sub(new dXc(b).a.d, 0), new gXc(e))), 40); + j = (Kfb(UD(mQb(l, j$c))) + Kfb(UD(mQb(h, j$c)))) / 2; + if (i2) { + k = Kfb(UD(mQb(i2, j$c))) + a.b + u0c(a, i2, b); + pQb(b, j$c, k); + pQb(b, g$c, Kfb(UD(mQb(b, j$c))) - j); + s0c(a, b); + } else { + pQb(b, j$c, j); + } + } + } + function nJb(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l; + k = a.e.a.c.length; + for (g = new Anb(a.e.a); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 125); + f2.j = false; + } + a.i = $C(kE, Pwe, 28, k, 15, 1); + a.g = $C(kE, Pwe, 28, k, 15, 1); + a.n = new bnb(); + e = 0; + l = new bnb(); + for (i2 = new Anb(a.e.a); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 125); + h.d = e++; + h.b.a.c.length == 0 && Rmb(a.n, h); + Tmb(l, h.g); + } + b = 0; + for (d = new Anb(l); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 218); + c2.c = b++; + c2.f = false; + } + j = l.c.length; + if (a.b == null || a.b.length < j) { + a.b = $C(iE, vxe, 28, j, 15, 1); + a.c = $C(xdb, Hye, 28, j, 16, 1); + } else { + Nnb(a.c); + } + a.d = l; + a.p = new Jub(Sv(a.d.c.length)); + a.j = 1; + } + function uWb(a, b) { + var c2, d, e, f2, g, h, i2, j, k; + if (b.e.c.length <= 1) { + return; + } + a.f = b; + a.d = RD(mQb(a.f, (dWb(), UVb)), 391); + a.g = RD(mQb(a.f, YVb), 17).a; + a.e = Kfb(UD(mQb(a.f, VVb))); + a.c = Kfb(UD(mQb(a.f, TVb))); + At(a.b); + for (e = new Anb(a.f.c); e.a < e.c.c.length; ) { + d = RD(ynb(e), 290); + zt(a.b, d.c, d, null); + zt(a.b, d.d, d, null); + } + h = a.f.e.c.length; + a.a = YC(iE, [Nve, vxe], [109, 28], 15, [h, h], 2); + for (j = new Anb(a.f.e); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 153); + qWb(a, i2, a.a[i2.a]); + } + a.i = YC(iE, [Nve, vxe], [109, 28], 15, [h, h], 2); + for (f2 = 0; f2 < h; ++f2) { + for (g = 0; g < h; ++g) { + c2 = a.a[f2][g]; + k = 1 / (c2 * c2); + a.i[f2][g] = k; + } + } + } + function OWb(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n; + h = b.ah(); + h || b.Ug(Pze, 1); + c2 = RD(mQb(a, (Ywc(), Kwc)), 15); + g = 1 / c2.gc(); + if (b._g()) { + b.bh("ELK Layered uses the following " + c2.gc() + " modules:"); + n = 0; + for (m = c2.Kc(); m.Ob(); ) { + k = RD(m.Pb(), 47); + d = (n < 10 ? "0" : "") + n++; + b.bh(" Slot " + d + ": " + nfb(rb(k))); + } + } + for (l = c2.Kc(); l.Ob(); ) { + k = RD(l.Pb(), 47); + if (b.$g()) { + return; + } + k.Kf(a, b.eh(g)); + } + for (f2 = new Anb(a.b); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 30); + Tmb(a.a, e.a); + e.a.c.length = 0; + } + for (j = new Anb(a.a); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 10); + g3b(i2, null); + } + a.b.c.length = 0; + h || b.Vg(); + } + function y9b(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n; + j = new bnb(); + if (!nQb(a, (Ywc(), fwc))) { + return j; + } + for (d = RD(mQb(a, fwc), 15).Kc(); d.Ob(); ) { + b = RD(d.Pb(), 10); + x9b(b, a); + ZEb(j.c, b); + } + for (f2 = new Anb(a.b); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 30); + for (h = new Anb(e.a); h.a < h.c.c.length; ) { + g = RD(ynb(h), 10); + if (g.k != (r3b(), m3b)) { + continue; + } + i2 = RD(mQb(g, gwc), 10); + !!i2 && (k = new R3b(), P3b(k, g), l = RD(mQb(g, hwc), 64), Q3b(k, l), m = RD(Vmb(i2.j, 0), 12), n = new a1b(), Y0b(n, k), Z0b(n, m), void 0); + } + } + for (c2 = new Anb(j); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 10); + g3b(b, RD(Vmb(a.b, a.b.c.length - 1), 30)); + } + return j; + } + function U8c(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l; + l = new bnb(); + k = new Had(0, c2); + f2 = 0; + Cad(k, new V9c(0, 0, k, c2)); + e = 0; + for (j = new dMd(a); j.e != j.i.gc(); ) { + i2 = RD(bMd(j), 27); + d = RD(Vmb(k.a, k.a.c.length - 1), 172); + h = e + i2.g + (RD(Vmb(k.a, 0), 172).b.c.length == 0 ? 0 : c2); + if (h > b || Heb(TD(Gxd(i2, (X7c(), D7c))))) { + e = 0; + f2 += k.b + c2; + ZEb(l.c, k); + k = new Had(f2, c2); + d = new V9c(0, k.f, k, c2); + Cad(k, d); + e = 0; + } + if (d.b.c.length == 0 || !Heb(TD(Gxd(vCd(i2), (X7c(), L7c)))) && (i2.f >= d.o && i2.f <= d.f || d.a * 0.5 <= i2.f && d.a * 1.5 >= i2.f)) { + K9c(d, i2); + } else { + g = new V9c(d.s + d.r + c2, k.f, k, c2); + Cad(k, g); + K9c(g, i2); + } + e = i2.i + i2.g; + } + ZEb(l.c, k); + return l; + } + function ste(a) { + var b, c2, d, e; + if (a.b == null || a.b.length <= 2) + return; + if (a.a) + return; + b = 0; + e = 0; + while (e < a.b.length) { + if (b != e) { + a.b[b] = a.b[e++]; + a.b[b + 1] = a.b[e++]; + } else + e += 2; + c2 = a.b[b + 1]; + while (e < a.b.length) { + if (c2 + 1 < a.b[e]) + break; + if (c2 + 1 == a.b[e]) { + a.b[b + 1] = a.b[e + 1]; + c2 = a.b[b + 1]; + e += 2; + } else if (c2 >= a.b[e + 1]) { + e += 2; + } else if (c2 < a.b[e + 1]) { + a.b[b + 1] = a.b[e + 1]; + c2 = a.b[b + 1]; + e += 2; + } else { + throw Adb(new yz("Token#compactRanges(): Internel Error: [" + a.b[b] + "," + a.b[b + 1] + "] [" + a.b[e] + "," + a.b[e + 1] + "]")); + } + } + b += 2; + } + if (b != a.b.length) { + d = $C(kE, Pwe, 28, b, 15, 1); + hib(a.b, 0, d, 0, b); + a.b = d; + } + a.a = true; + } + function x0b(a, b) { + var c2, d, e, f2, g, h, i2; + for (g = Ec(a.a).Kc(); g.Ob(); ) { + f2 = RD(g.Pb(), 18); + if (f2.b.c.length > 0) { + d = new dnb(RD(Qc(a.a, f2), 21)); + yob(); + _mb(d, new M0b(b)); + e = new Jkb(f2.b, 0); + while (e.b < e.d.gc()) { + c2 = (sFb(e.b < e.d.gc()), RD(e.d.Xb(e.c = e.b++), 72)); + h = -1; + switch (RD(mQb(c2, (yCc(), wAc)), 278).g) { + case 1: + h = d.c.length - 1; + break; + case 0: + h = v0b(d); + break; + case 2: + h = 0; + } + if (h != -1) { + i2 = (tFb(h, d.c.length), RD(d.c[h], 249)); + Rmb(i2.b.b, c2); + RD(mQb(Y2b(i2.b.c.i), (Ywc(), kwc)), 21).Fc((ovc(), gvc)); + RD(mQb(Y2b(i2.b.c.i), kwc), 21).Fc(evc); + Ckb(e); + pQb(c2, Dwc, f2); + } + } + } + Y0b(f2, null); + Z0b(f2, null); + } + } + function wOb(a, b) { + var c2, d, e, f2; + c2 = new BOb(); + d = RD(zDb(GDb(new SDb(null, new Swb(a.f, 16)), c2), sBb(new _Bb(), new bCb(), new yCb(), new ACb(), cD(WC(QL, 1), jwe, 108, 0, [(xBb(), wBb), vBb]))), 21); + e = d.gc(); + e = e == 2 ? 1 : 0; + e == 1 && Gdb(Mdb(RD(zDb(CDb(d.Lc(), new DOb()), PBb(Hgb(0), new uCb())), 168).a, 2), 0) && (e = 0); + d = RD(zDb(GDb(new SDb(null, new Swb(b.f, 16)), c2), sBb(new _Bb(), new bCb(), new yCb(), new ACb(), cD(WC(QL, 1), jwe, 108, 0, [wBb, vBb]))), 21); + f2 = d.gc(); + f2 = f2 == 2 ? 1 : 0; + f2 == 1 && Gdb(Mdb(RD(zDb(CDb(d.Lc(), new FOb()), PBb(Hgb(0), new uCb())), 168).a, 2), 0) && (f2 = 0); + if (e < f2) { + return -1; + } + if (e == f2) { + return 0; + } + return 1; + } + function W4b(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m; + b = MCd(a); + f2 = Heb(TD(Gxd(b, (yCc(), NAc)))); + k = 0; + e = 0; + for (j = new dMd((!a.e && (a.e = new Yie(G4, a, 7, 4)), a.e)); j.e != j.i.gc(); ) { + i2 = RD(bMd(j), 74); + h = ozd(i2); + g = h && f2 && Heb(TD(Gxd(i2, OAc))); + m = AGd(RD(QHd((!i2.c && (i2.c = new Yie(E4, i2, 5, 8)), i2.c), 0), 84)); + h && g ? ++e : h && !g ? ++k : vCd(m) == b || m == b ? ++e : ++k; + } + for (d = new dMd((!a.d && (a.d = new Yie(G4, a, 8, 5)), a.d)); d.e != d.i.gc(); ) { + c2 = RD(bMd(d), 74); + h = ozd(c2); + g = h && f2 && Heb(TD(Gxd(c2, OAc))); + l = AGd(RD(QHd((!c2.b && (c2.b = new Yie(E4, c2, 4, 7)), c2.b), 0), 84)); + h && g ? ++k : h && !g ? ++e : vCd(l) == b || l == b ? ++k : ++e; + } + return k - e; + } + function Jec(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n; + b.Ug("Edge splitting", 1); + if (a.b.c.length <= 2) { + b.Vg(); + return; + } + f2 = new Jkb(a.b, 0); + g = (sFb(f2.b < f2.d.gc()), RD(f2.d.Xb(f2.c = f2.b++), 30)); + while (f2.b < f2.d.gc()) { + e = g; + g = (sFb(f2.b < f2.d.gc()), RD(f2.d.Xb(f2.c = f2.b++), 30)); + for (i2 = new Anb(e.a); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 10); + for (k = new Anb(h.j); k.a < k.c.c.length; ) { + j = RD(ynb(k), 12); + for (d = new Anb(j.g); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 18); + m = c2.d; + l = m.i.c; + l != e && l != g && Oec(c2, (n = new j3b(a), h3b(n, (r3b(), o3b)), pQb(n, (Ywc(), Awc), c2), pQb(n, (yCc(), BBc), (Bod(), wod)), g3b(n, g), n)); + } + } + } + } + b.Vg(); + } + function MLc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m; + k = new bnb(); + m = new _sb(); + g = b.b; + for (e = 0; e < g.c.length; e++) { + j = (tFb(e, g.c.length), RD(g.c[e], 30)).a; + k.c.length = 0; + for (f2 = 0; f2 < j.c.length; f2++) { + h = a.a[e][f2]; + h.p = f2; + h.k == (r3b(), q3b) && (ZEb(k.c, h), true); + $mb(RD(Vmb(b.b, e), 30).a, f2, h); + h.j.c.length = 0; + Tmb(h.j, RD(RD(Vmb(a.b, e), 15).Xb(f2), 16)); + Cod(RD(mQb(h, (yCc(), BBc)), 101)) || pQb(h, BBc, (Bod(), vod)); + } + for (d = new Anb(k); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 10); + l = KLc(c2); + m.a.zc(l, m); + m.a.zc(c2, m); + } + } + for (i2 = m.a.ec().Kc(); i2.Ob(); ) { + h = RD(i2.Pb(), 10); + yob(); + _mb(h.j, (sgc(), mgc)); + h.i = true; + V2b(h); + } + } + function zib(a) { + var b, c2, d, e, f2; + if (a.g != null) { + return a.g; + } + if (a.a < 32) { + a.g = zjb(Hdb(a.f), eE(a.e)); + return a.g; + } + e = Ajb((!a.c && (a.c = ojb(Hdb(a.f))), a.c), 0); + if (a.e == 0) { + return e; + } + b = (!a.c && (a.c = ojb(Hdb(a.f))), a.c).e < 0 ? 2 : 1; + c2 = e.length; + d = -a.e + c2 - b; + f2 = new bib(); + f2.a += "" + e; + if (a.e > 0 && d >= -6) { + if (d >= 0) { + aib(f2, c2 - eE(a.e), String.fromCharCode(46)); + } else { + peb(f2, b - 1, b - 1, "0."); + aib(f2, b + 1, Ihb(mib, 0, -eE(d) - 1)); + } + } else { + if (c2 - b >= 1) { + aib(f2, b, String.fromCharCode(46)); + ++c2; + } + aib(f2, c2, String.fromCharCode(69)); + d > 0 && aib(f2, ++c2, String.fromCharCode(43)); + aib(f2, ++c2, "" + Zdb(Hdb(d))); + } + a.g = f2.a; + return a.g; + } + function KNc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A; + d = Kfb(UD(mQb(b, (yCc(), hBc)))); + v = RD(mQb(b, gCc), 17).a; + m = 4; + e = 3; + w2 = 20 / v; + n = false; + i2 = 0; + g = lve; + do { + f2 = i2 != 1; + l = i2 != 0; + A = 0; + for (q = a.a, s = 0, u = q.length; s < u; ++s) { + o2 = q[s]; + o2.f = null; + LNc(a, o2, f2, l, d); + A += $wnd.Math.abs(o2.a); + } + do { + h = PNc(a, b); + } while (h); + for (p = a.a, r = 0, t = p.length; r < t; ++r) { + o2 = p[r]; + c2 = XNc(o2).a; + if (c2 != 0) { + for (k = new Anb(o2.e); k.a < k.c.c.length; ) { + j = RD(ynb(k), 10); + j.n.b += c2; + } + } + } + if (i2 == 0 || i2 == 1) { + --m; + if (m <= 0 && (A < g || -m > v)) { + i2 = 2; + g = lve; + } else if (i2 == 0) { + i2 = 1; + g = A; + } else { + i2 = 0; + g = A; + } + } else { + n = A >= g || g - A < w2; + g = A; + n && --e; + } + } while (!(n && e <= 0)); + } + function LFb(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2; + o2 = new Tsb(); + for (f2 = a.a.ec().Kc(); f2.Ob(); ) { + d = RD(f2.Pb(), 177); + Zjb(o2, d, c2.af(d)); + } + g = (Qb(a), a ? new dnb(a) : cv(a.a.ec().Kc())); + _mb(g, new NFb(o2)); + h = Xx(g); + i2 = new $Fb(b); + n = new Tsb(); + rtb(n.f, b, i2); + while (h.a.gc() != 0) { + j = null; + k = null; + l = null; + for (e = h.a.ec().Kc(); e.Ob(); ) { + d = RD(e.Pb(), 177); + if (Kfb(UD(Wd(qtb(o2.f, d)))) <= oxe) { + if (Ujb(n, d.a) && !Ujb(n, d.b)) { + k = d.b; + l = d.a; + j = d; + break; + } + if (Ujb(n, d.b)) { + if (!Ujb(n, d.a)) { + k = d.a; + l = d.b; + j = d; + break; + } + } + } + } + if (!j) { + break; + } + m = new $Fb(k); + Rmb(RD(Wd(qtb(n.f, l)), 225).a, m); + rtb(n.f, k, m); + h.a.Bc(j) != null; + } + return i2; + } + function MFc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n; + c2.Ug("Depth-first cycle removal", 1); + l = b.a; + k = l.c.length; + a.c = new bnb(); + a.d = $C(xdb, Hye, 28, k, 16, 1); + a.a = $C(xdb, Hye, 28, k, 16, 1); + a.b = new bnb(); + g = 0; + for (j = new Anb(l); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 10); + i2.p = g; + gr(Z2b(i2)) && Rmb(a.c, i2); + ++g; + } + for (n = new Anb(a.c); n.a < n.c.c.length; ) { + m = RD(ynb(n), 10); + LFc(a, m); + } + for (f2 = 0; f2 < k; f2++) { + if (!a.d[f2]) { + h = (tFb(f2, l.c.length), RD(l.c[f2], 10)); + LFc(a, h); + } + } + for (e = new Anb(a.b); e.a < e.c.c.length; ) { + d = RD(ynb(e), 18); + X0b(d, true); + pQb(b, (Ywc(), awc), (Geb(), true)); + } + a.c = null; + a.d = null; + a.a = null; + a.b = null; + c2.Vg(); + } + function Kid(a, b) { + tid(); + var c2, d, e, f2, g, h; + f2 = b.c - (a.c + a.b); + e = a.c - (b.c + b.b); + g = a.d - (b.d + b.a); + c2 = b.d - (a.d + a.a); + d = $wnd.Math.max(e, f2); + h = $wnd.Math.max(g, c2); + Zy(); + bz(vEe); + if (($wnd.Math.abs(d) <= vEe || d == 0 || isNaN(d) && isNaN(0) ? 0 : d < 0 ? -1 : d > 0 ? 1 : cz(isNaN(d), isNaN(0))) >= 0 ^ (bz(vEe), ($wnd.Math.abs(h) <= vEe || h == 0 || isNaN(h) && isNaN(0) ? 0 : h < 0 ? -1 : h > 0 ? 1 : cz(isNaN(h), isNaN(0))) >= 0)) { + return $wnd.Math.max(h, d); + } + bz(vEe); + if (($wnd.Math.abs(d) <= vEe || d == 0 || isNaN(d) && isNaN(0) ? 0 : d < 0 ? -1 : d > 0 ? 1 : cz(isNaN(d), isNaN(0))) > 0) { + return $wnd.Math.sqrt(h * h + d * d); + } + return -$wnd.Math.sqrt(h * h + d * d); + } + function hue2(a, b) { + var c2, d, e, f2, g, h; + if (!b) + return; + !a.a && (a.a = new gyb()); + if (a.e == 2) { + dyb(a.a, b); + return; + } + if (b.e == 1) { + for (e = 0; e < b.Pm(); e++) + hue2(a, b.Lm(e)); + return; + } + h = a.a.a.c.length; + if (h == 0) { + dyb(a.a, b); + return; + } + g = RD(eyb(a.a, h - 1), 122); + if (!((g.e == 0 || g.e == 10) && (b.e == 0 || b.e == 10))) { + dyb(a.a, b); + return; + } + f2 = b.e == 0 ? 2 : b.Mm().length; + if (g.e == 0) { + c2 = new Rhb(); + d = g.Km(); + d >= txe ? Nhb(c2, qse(d)) : Jhb(c2, d & Bwe); + g = new eue(10, null, 0); + fyb(a.a, g, h - 1); + } else { + c2 = (g.Mm().length + f2, new Rhb()); + Nhb(c2, g.Mm()); + } + if (b.e == 0) { + d = b.Km(); + d >= txe ? Nhb(c2, qse(d)) : Jhb(c2, d & Bwe); + } else { + Nhb(c2, b.Mm()); + } + RD(g, 530).b = c2.a; + } + function Qsc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q; + if (c2.dc()) { + return; + } + h = 0; + m = 0; + d = c2.Kc(); + o2 = RD(d.Pb(), 17).a; + while (h < b.f) { + if (h == o2) { + m = 0; + d.Ob() ? o2 = RD(d.Pb(), 17).a : o2 = b.f + 1; + } + if (h != m) { + q = RD(Vmb(a.b, h), 30); + n = RD(Vmb(a.b, m), 30); + p = bv(q.a); + for (l = new Anb(p); l.a < l.c.c.length; ) { + k = RD(ynb(l), 10); + f3b(k, n.a.c.length, n); + if (m == 0) { + g = bv(Z2b(k)); + for (f2 = new Anb(g); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 18); + X0b(e, true); + pQb(a, (Ywc(), awc), (Geb(), true)); + osc(a, e, 1); + } + } + } + } + ++m; + ++h; + } + i2 = new Jkb(a.b, 0); + while (i2.b < i2.d.gc()) { + j = (sFb(i2.b < i2.d.gc()), RD(i2.d.Xb(i2.c = i2.b++), 30)); + j.a.c.length == 0 && Ckb(i2); + } + } + function Xjc(a, b, c2) { + var d, e, f2; + e = RD(mQb(b, (yCc(), Xzc)), 282); + if (e == ($uc(), Yuc)) { + return; + } + c2.Ug("Horizontal Compaction", 1); + a.a = b; + f2 = new Ckc(); + d = new VGb((f2.d = b, f2.c = RD(mQb(f2.d, yAc), 223), tkc(f2), Akc(f2), zkc(f2), f2.a)); + TGb(d, a.b); + switch (RD(mQb(b, Wzc), 431).g) { + case 1: + RGb(d, new Pic(a.a)); + break; + default: + RGb(d, (FGb(), DGb)); + } + switch (e.g) { + case 1: + KGb(d); + break; + case 2: + KGb(JGb(d, (Cmd(), zmd))); + break; + case 3: + KGb(SGb(JGb(KGb(d), (Cmd(), zmd)), new fkc())); + break; + case 4: + KGb(SGb(JGb(KGb(d), (Cmd(), zmd)), new hkc(f2))); + break; + case 5: + KGb(QGb(d, Vjc)); + } + JGb(d, (Cmd(), ymd)); + d.e = true; + qkc(f2); + c2.Vg(); + } + function bqc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t; + g = b.b; + k = g.o; + i2 = g.d; + d = Kfb(UD(k2b(g, (yCc(), TBc)))); + e = Kfb(UD(k2b(g, VBc))); + j = Kfb(UD(k2b(g, dCc))); + h = new T2b(); + D2b(h, i2.d, i2.c, i2.a, i2.b); + m = Zpc(b, d, e, j); + for (r = new Anb(b.d); r.a < r.c.c.length; ) { + q = RD(ynb(r), 105); + for (o2 = q.f.a.ec().Kc(); o2.Ob(); ) { + n = RD(o2.Pb(), 340); + f2 = n.a; + l = Xpc(n); + c2 = (s = new Ejd(), Vpc(n, n.c, m, s), Upc(n, l, m, s), Vpc(n, n.d, m, s), s); + c2 = a.ng(n, l, c2); + Xub(f2.a); + ye(f2.a, c2); + FDb(new SDb(null, new Swb(c2, 16)), new fqc(k, h)); + } + p = q.i; + if (p) { + aqc(q, p, m, e); + t = new sjd(p.g); + cqc(k, h, t); + $id(t, p.j); + cqc(k, h, t); + } + } + D2b(i2, h.d, h.c, h.a, h.b); + } + function f8c(a, b, c2, d, e, f2, g, h) { + var i2, j, k, l; + i2 = dv(cD(WC(y1, 1), rve, 238, 0, [b, c2, d, e])); + l = null; + switch (a.b.g) { + case 1: + l = dv(cD(WC(h1, 1), rve, 535, 0, [new r8c(), new h8c(), new j8c()])); + break; + case 0: + l = dv(cD(WC(h1, 1), rve, 535, 0, [new j8c(), new h8c(), new r8c()])); + break; + case 2: + l = dv(cD(WC(h1, 1), rve, 535, 0, [new h8c(), new r8c(), new j8c()])); + } + for (k = new Anb(l); k.a < k.c.c.length; ) { + j = RD(ynb(k), 535); + i2.c.length > 1 && (i2 = j.Hg(i2, a.a, h)); + } + if (i2.c.length == 1) { + return RD(Vmb(i2, i2.c.length - 1), 238); + } + if (i2.c.length == 2) { + return e8c((tFb(0, i2.c.length), RD(i2.c[0], 238)), (tFb(1, i2.c.length), RD(i2.c[1], 238)), g, f2); + } + return null; + } + function CZc(a, b, c2) { + var d, e, f2, g, h, i2, j; + c2.Ug("Find roots", 1); + a.a.c.length = 0; + for (e = Sub(b.b, 0); e.b != e.d.c; ) { + d = RD(evb(e), 40); + if (d.b.b == 0) { + pQb(d, (q$c(), n$c), (Geb(), true)); + Rmb(a.a, d); + } + } + switch (a.a.c.length) { + case 0: + f2 = new bXc(0, b, "DUMMY_ROOT"); + pQb(f2, (q$c(), n$c), (Geb(), true)); + pQb(f2, WZc, true); + Mub(b.b, f2); + break; + case 1: + break; + default: + g = new bXc(0, b, IEe); + for (i2 = new Anb(a.a); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 40); + j = new WWc(g, h); + pQb(j, (q$c(), WZc), (Geb(), true)); + Mub(g.a.a, j); + Mub(g.d, j); + Mub(h.b, j); + pQb(h, n$c, false); + } + pQb(g, (q$c(), n$c), (Geb(), true)); + pQb(g, WZc, true); + Mub(b.b, g); + } + c2.Vg(); + } + function AQb(a) { + var b, c2, d, e, f2, g; + Umb(a.a, new GQb()); + for (c2 = new Anb(a.a); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 225); + d = ojd(ajd(RD(a.b, 68).c), RD(b.b, 68).c); + if (wQb) { + g = RD(a.b, 68).b; + f2 = RD(b.b, 68).b; + if ($wnd.Math.abs(d.a) >= $wnd.Math.abs(d.b)) { + d.b = 0; + f2.d + f2.a > g.d && f2.d < g.d + g.a && kjd(d, $wnd.Math.max(g.c - (f2.c + f2.b), f2.c - (g.c + g.b))); + } else { + d.a = 0; + f2.c + f2.b > g.c && f2.c < g.c + g.b && kjd(d, $wnd.Math.max(g.d - (f2.d + f2.a), f2.d - (g.d + g.a))); + } + } else { + kjd(d, SQb(RD(a.b, 68), RD(b.b, 68))); + } + e = $wnd.Math.sqrt(d.a * d.a + d.b * d.b); + e = CQb(xQb, b, e, d); + kjd(d, e); + RQb(RD(b.b, 68), d); + Umb(b.a, new IQb(d)); + RD(xQb.b, 68); + BQb(xQb, yQb, b); + } + } + function tOc(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n, o2; + a.f = new BIb(); + j = 0; + e = 0; + for (g = new Anb(a.e.b); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 30); + for (i2 = new Anb(f2.a); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 10); + h.p = j++; + for (d = new is(Mr(a3b(h).a.Kc(), new ir())); gs(d); ) { + c2 = RD(hs(d), 18); + c2.p = e++; + } + b = BOc(h); + for (m = new Anb(h.j); m.a < m.c.c.length; ) { + l = RD(ynb(m), 12); + if (b) { + o2 = l.a.b; + if (o2 != $wnd.Math.floor(o2)) { + k = o2 - Xdb(Hdb($wnd.Math.round(o2))); + l.a.b -= k; + } + } + n = l.n.b + l.a.b; + if (n != $wnd.Math.floor(n)) { + k = n - Xdb(Hdb($wnd.Math.round(n))); + l.n.b -= k; + } + } + } + } + a.g = j; + a.b = e; + a.i = $C(XY, rve, 412, j, 0, 1); + a.c = $C(WY, rve, 655, e, 0, 1); + a.d.a.$b(); + } + function sLd(a) { + var b, c2, d, e, f2, g, h, i2, j; + if (a.Pj()) { + i2 = a.Qj(); + if (a.i > 0) { + b = new zNd(a.i, a.g); + c2 = a.i; + f2 = c2 < 100 ? null : new gLd(c2); + if (a.Tj()) { + for (d = 0; d < a.i; ++d) { + g = a.g[d]; + f2 = a.Vj(g, f2); + } + } + OHd(a); + e = c2 == 1 ? a.Ij(4, QHd(b, 0), null, 0, i2) : a.Ij(6, b, null, -1, i2); + if (a.Mj()) { + for (d = new yMd(b); d.e != d.i.gc(); ) { + f2 = a.Oj(xMd(d), f2); + } + if (!f2) { + a.Jj(e); + } else { + f2.nj(e); + f2.oj(); + } + } else { + if (!f2) { + a.Jj(e); + } else { + f2.nj(e); + f2.oj(); + } + } + } else { + OHd(a); + a.Jj(a.Ij(6, (yob(), vob), null, -1, i2)); + } + } else if (a.Mj()) { + if (a.i > 0) { + h = a.g; + j = a.i; + OHd(a); + f2 = j < 100 ? null : new gLd(j); + for (d = 0; d < j; ++d) { + g = h[d]; + f2 = a.Oj(g, f2); + } + !!f2 && f2.oj(); + } else { + OHd(a); + } + } else { + OHd(a); + } + } + function xVc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m; + rVc(this); + c2 == (dVc(), bVc) ? Ysb(this.r, a) : Ysb(this.w, a); + k = oxe; + j = pxe; + for (g = b.a.ec().Kc(); g.Ob(); ) { + e = RD(g.Pb(), 42); + h = RD(e.a, 465); + d = RD(e.b, 18); + i2 = d.c; + i2 == a && (i2 = d.d); + h == bVc ? Ysb(this.r, i2) : Ysb(this.w, i2); + m = (qpd(), hpd).Hc(i2.j) ? Kfb(UD(mQb(i2, (Ywc(), Swc)))) : xjd(cD(WC(l3, 1), Nve, 8, 0, [i2.i.n, i2.n, i2.a])).b; + k = $wnd.Math.min(k, m); + j = $wnd.Math.max(j, m); + } + l = (qpd(), hpd).Hc(a.j) ? Kfb(UD(mQb(a, (Ywc(), Swc)))) : xjd(cD(WC(l3, 1), Nve, 8, 0, [a.i.n, a.n, a.a])).b; + vVc(this, l, k, j); + for (f2 = b.a.ec().Kc(); f2.Ob(); ) { + e = RD(f2.Pb(), 42); + sVc(this, RD(e.b, 18)); + } + this.o = false; + } + function wD(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5, F, G; + c2 = a.l & 8191; + d = a.l >> 13 | (a.m & 15) << 9; + e = a.m >> 4 & 8191; + f2 = a.m >> 17 | (a.h & 255) << 5; + g = (a.h & 1048320) >> 8; + h = b.l & 8191; + i2 = b.l >> 13 | (b.m & 15) << 9; + j = b.m >> 4 & 8191; + k = b.m >> 17 | (b.h & 255) << 5; + l = (b.h & 1048320) >> 8; + B = c2 * h; + C = d * h; + D5 = e * h; + F = f2 * h; + G = g * h; + if (i2 != 0) { + C += c2 * i2; + D5 += d * i2; + F += e * i2; + G += f2 * i2; + } + if (j != 0) { + D5 += c2 * j; + F += d * j; + G += e * j; + } + if (k != 0) { + F += c2 * k; + G += d * k; + } + l != 0 && (G += c2 * l); + n = B & dxe; + o2 = (C & 511) << 13; + m = n + o2; + q = B >> 22; + r = C >> 9; + s = (D5 & 262143) << 4; + t = (F & 31) << 17; + p = q + r + s + t; + v = D5 >> 18; + w2 = F >> 5; + A = (G & 4095) << 8; + u = v + w2 + A; + p += m >> 22; + m &= dxe; + u += p >> 22; + p &= dxe; + u &= exe; + return hD(m, p, u); + } + function Fac(a) { + var b, c2, d, e, f2, g, h; + h = RD(Vmb(a.j, 0), 12); + if (h.g.c.length != 0 && h.e.c.length != 0) { + throw Adb(new dgb("Interactive layout does not support NORTH/SOUTH ports with incoming _and_ outgoing edges.")); + } + if (h.g.c.length != 0) { + f2 = oxe; + for (c2 = new Anb(h.g); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 18); + g = b.d.i; + d = RD(mQb(g, (yCc(), _Ac)), 140); + f2 = $wnd.Math.min(f2, g.n.a - d.b); + } + return new cc(Qb(f2)); + } + if (h.e.c.length != 0) { + e = pxe; + for (c2 = new Anb(h.e); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 18); + g = b.c.i; + d = RD(mQb(g, (yCc(), _Ac)), 140); + e = $wnd.Math.max(e, g.n.a + g.o.a + d.c); + } + return new cc(Qb(e)); + } + return wb(), wb(), vb; + } + function cZd(a, b) { + var c2, d, e, f2, g, h, i2; + if (a.ol()) { + if (a.i > 4) { + if (a.fk(b)) { + if (a.al()) { + e = RD(b, 54); + d = e.Eh(); + i2 = d == a.e && (a.ml() ? e.yh(e.Fh(), a.il()) == a.jl() : -1 - e.Fh() == a.Lj()); + if (a.nl() && !i2 && !d && !!e.Jh()) { + for (f2 = 0; f2 < a.i; ++f2) { + c2 = a.pl(RD(a.g[f2], 58)); + if (dE(c2) === dE(b)) { + return true; + } + } + } + return i2; + } else if (a.ml() && !a.ll()) { + g = RD(b, 58).Mh(Z5d(RD(a.Lk(), 19))); + if (dE(g) === dE(a.e)) { + return true; + } else if (g == null || !RD(g, 58).Vh()) { + return false; + } + } + } else { + return false; + } + } + h = PHd(a, b); + if (a.nl() && !h) { + for (f2 = 0; f2 < a.i; ++f2) { + e = a.pl(RD(a.g[f2], 58)); + if (dE(e) === dE(b)) { + return true; + } + } + } + return h; + } else { + return PHd(a, b); + } + } + function bGc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q; + c2.Ug("Interactive cycle breaking", 1); + l = new bnb(); + for (n = new Anb(b.a); n.a < n.c.c.length; ) { + m = RD(ynb(n), 10); + m.p = 1; + o2 = _2b(m).a; + for (k = c3b(m, (BEc(), zEc)).Kc(); k.Ob(); ) { + j = RD(k.Pb(), 12); + for (f2 = new Anb(j.g); f2.a < f2.c.c.length; ) { + d = RD(ynb(f2), 18); + p = d.d.i; + if (p != m) { + q = _2b(p).a; + q < o2 && (ZEb(l.c, d), true); + } + } + } + } + for (g = new Anb(l); g.a < g.c.c.length; ) { + d = RD(ynb(g), 18); + X0b(d, true); + } + l.c.length = 0; + for (i2 = new Anb(b.a); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 10); + h.p > 0 && aGc(a, h, l); + } + for (e = new Anb(l); e.a < e.c.c.length; ) { + d = RD(ynb(e), 18); + X0b(d, true); + } + l.c.length = 0; + c2.Vg(); + } + function mMc(a, b) { + var c2, d, e, f2, g, h, i2, j, k; + c2 = 0; + k = new bnb(); + for (h = new Anb(b); h.a < h.c.c.length; ) { + g = RD(ynb(h), 12); + $Lc(a.b, a.d[g.p]); + k.c.length = 0; + switch (g.i.k.g) { + case 0: + d = RD(mQb(g, (Ywc(), Iwc)), 10); + Umb(d.j, new XMc(k)); + break; + case 1: + Mvb(DDb(CDb(new SDb(null, new Swb(g.i.j, 16)), new ZMc(g))), new aNc(k)); + break; + case 3: + e = RD(mQb(g, (Ywc(), Awc)), 12); + Rmb(k, new Ptd(e, sgb(g.e.c.length + g.g.c.length))); + } + for (j = new Anb(k); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 42); + f2 = AMc(a, RD(i2.a, 12)); + if (f2 > a.d[g.p]) { + c2 += ZLc(a.b, f2) * RD(i2.b, 17).a; + hmb(a.a, sgb(f2)); + } + } + while (!nmb(a.a)) { + XLc(a.b, RD(smb(a.a), 17).a); + } + } + return c2; + } + function x9b(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l; + k = RD(mQb(a, (Ywc(), hwc)), 64); + d = RD(Vmb(a.j, 0), 12); + k == (qpd(), Yod) ? Q3b(d, npd) : k == npd && Q3b(d, Yod); + if (RD(mQb(b, (yCc(), lBc)), 181).Hc((Qpd(), Ppd))) { + i2 = Kfb(UD(mQb(a, _Bc))); + j = Kfb(UD(mQb(a, aCc))); + g = Kfb(UD(mQb(a, ZBc))); + h = RD(mQb(b, EBc), 21); + if (h.Hc((Pod(), Lod))) { + c2 = j; + l = a.o.a / 2 - d.n.a; + for (f2 = new Anb(d.f); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 72); + e.n.b = c2; + e.n.a = l - e.o.a / 2; + c2 += e.o.b + g; + } + } else if (h.Hc(Nod)) { + for (f2 = new Anb(d.f); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 72); + e.n.a = i2 + a.o.a - d.n.a; + } + } + NJb(new PJb((i1b(), new t1b(b, false, false, new _1b()))), new F1b(null, a, false)); + } + } + function ykc(a, b) { + var c2, d, e, f2, g, h, i2, j, k; + if (b.c.length == 0) { + return; + } + yob(); + Ynb(b.c, b.c.length, null); + e = new Anb(b); + d = RD(ynb(e), 154); + while (e.a < e.c.c.length) { + c2 = RD(ynb(e), 154); + if (rGb(d.e.c, c2.e.c) && !(uGb(Mid(d.e).b, c2.e.d) || uGb(Mid(c2.e).b, d.e.d))) { + d = (Tmb(d.k, c2.k), Tmb(d.b, c2.b), Tmb(d.c, c2.c), ye(d.i, c2.i), Tmb(d.d, c2.d), Tmb(d.j, c2.j), f2 = $wnd.Math.min(d.e.c, c2.e.c), g = $wnd.Math.min(d.e.d, c2.e.d), h = $wnd.Math.max(d.e.c + d.e.b, c2.e.c + c2.e.b), i2 = h - f2, j = $wnd.Math.max(d.e.d + d.e.a, c2.e.d + c2.e.a), k = j - g, Rid(d.e, f2, g, i2, k), $Gb(d.f, c2.f), !d.a && (d.a = c2.a), Tmb(d.g, c2.g), Rmb(d.g, c2), d); + } else { + Bkc(a, d); + d = c2; + } + } + Bkc(a, d); + } + function B0b(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v; + i2 = new bnb(); + for (f2 = new Anb(b.a); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 10); + for (h = new Anb(e.j); h.a < h.c.c.length; ) { + g = RD(ynb(h), 12); + k = null; + for (t = s2b(g.g), u = 0, v = t.length; u < v; ++u) { + s = t[u]; + if (!n2b(s.d.i, c2)) { + r = w0b(a, b, c2, s, s.c, (BEc(), zEc), k); + r != k && (ZEb(i2.c, r), true); + r.c && (k = r); + } + } + j = null; + for (o2 = s2b(g.e), p = 0, q = o2.length; p < q; ++p) { + n = o2[p]; + if (!n2b(n.c.i, c2)) { + r = w0b(a, b, c2, n, n.d, (BEc(), yEc), j); + r != j && (ZEb(i2.c, r), true); + r.c && (j = r); + } + } + } + } + for (m = new Anb(i2); m.a < m.c.c.length; ) { + l = RD(ynb(m), 453); + Wmb(b.a, l.a, 0) != -1 || Rmb(b.a, l.a); + l.c && (ZEb(d.c, l), true); + } + } + function hrd(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m, n, o2, p, q; + l = new sjd(RD(Gxd(a, (hkd(), bkd)), 8)); + l.a = $wnd.Math.max(l.a - c2.b - c2.c, 0); + l.b = $wnd.Math.max(l.b - c2.d - c2.a, 0); + e = UD(Gxd(a, Xjd)); + (e == null || (uFb(e), e) <= 0) && (e = 1.3); + h = new bnb(); + for (o2 = new dMd((!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a)); o2.e != o2.i.gc(); ) { + n = RD(bMd(o2), 27); + g = new Ard(n); + ZEb(h.c, g); + } + m = RD(Gxd(a, Yjd), 320); + switch (m.g) { + case 3: + q = erd(h, b, l.a, l.b, (j = d, uFb(e), j)); + break; + case 1: + q = drd(h, b, l.a, l.b, (k = d, uFb(e), k)); + break; + default: + q = frd(h, b, l.a, l.b, (i2 = d, uFb(e), i2)); + } + f2 = new zrd(q); + p = ird(f2, b, c2, l.a, l.b, d, (uFb(e), e)); + Esd(a, p.a, p.b, false, true); + } + function m2b(a, b, c2, d) { + var e, f2, g, h, i2, j; + h = a.j; + if (h == (qpd(), opd) && b != (Bod(), zod) && b != (Bod(), Aod)) { + h = c2b(a, c2); + Q3b(a, h); + !(!a.q ? (yob(), yob(), wob) : a.q)._b((yCc(), ABc)) && h != opd && (a.n.a != 0 || a.n.b != 0) && pQb(a, ABc, b2b(a, h)); + } + if (b == (Bod(), xod)) { + j = 0; + switch (h.g) { + case 1: + case 3: + f2 = a.i.o.a; + f2 > 0 && (j = a.n.a / f2); + break; + case 2: + case 4: + e = a.i.o.b; + e > 0 && (j = a.n.b / e); + } + pQb(a, (Ywc(), Jwc), j); + } + i2 = a.o; + g = a.a; + if (d) { + g.a = d.a; + g.b = d.b; + a.d = true; + } else if (b != zod && b != Aod && h != opd) { + switch (h.g) { + case 1: + g.a = i2.a / 2; + break; + case 2: + g.a = i2.a; + g.b = i2.b / 2; + break; + case 3: + g.a = i2.a / 2; + g.b = i2.b; + break; + case 4: + g.b = i2.b / 2; + } + } else { + g.a = i2.a / 2; + g.b = i2.b / 2; + } + } + function VJd(a) { + var b, c2, d, e, f2, g, h, i2, j, k; + if (a.Pj()) { + k = a.Ej(); + i2 = a.Qj(); + if (k > 0) { + b = new $Hd(a.pj()); + c2 = k; + f2 = c2 < 100 ? null : new gLd(c2); + aJd(a, c2, b.g); + e = c2 == 1 ? a.Ij(4, QHd(b, 0), null, 0, i2) : a.Ij(6, b, null, -1, i2); + if (a.Mj()) { + for (d = new dMd(b); d.e != d.i.gc(); ) { + f2 = a.Oj(bMd(d), f2); + } + if (!f2) { + a.Jj(e); + } else { + f2.nj(e); + f2.oj(); + } + } else { + if (!f2) { + a.Jj(e); + } else { + f2.nj(e); + f2.oj(); + } + } + } else { + aJd(a, a.Ej(), a.Fj()); + a.Jj(a.Ij(6, (yob(), vob), null, -1, i2)); + } + } else if (a.Mj()) { + k = a.Ej(); + if (k > 0) { + h = a.Fj(); + j = k; + aJd(a, k, h); + f2 = j < 100 ? null : new gLd(j); + for (d = 0; d < j; ++d) { + g = h[d]; + f2 = a.Oj(g, f2); + } + !!f2 && f2.oj(); + } else { + aJd(a, a.Ej(), a.Fj()); + } + } else { + aJd(a, a.Ej(), a.Fj()); + } + } + function frd(a, b, c2, d, e) { + var f2, g, h, i2, j, k, l, m, n, o2, p, q; + h = $C(iE, vxe, 28, a.c.length, 15, 1); + m = new pwb(new Qrd()); + iwb(m, a); + j = 0; + p = new bnb(); + while (m.b.c.length != 0) { + g = RD(m.b.c.length == 0 ? null : Vmb(m.b, 0), 163); + if (j > 1 && urd(g) * trd(g) / 2 > h[0]) { + f2 = 0; + while (f2 < p.c.length - 1 && urd(g) * trd(g) / 2 > h[f2]) { + ++f2; + } + o2 = new Rkb(p, 0, f2 + 1); + l = new zrd(o2); + k = urd(g) / trd(g); + i2 = ird(l, b, new z3b(), c2, d, e, k); + $id(hjd(l.e), i2); + zFb(lwb(m, l), Bxe); + n = new Rkb(p, f2 + 1, p.c.length); + iwb(m, n); + p.c.length = 0; + j = 0; + Pnb(h, h.length, 0); + } else { + q = m.b.c.length == 0 ? null : Vmb(m.b, 0); + q != null && owb(m, 0); + j > 0 && (h[j] = h[j - 1]); + h[j] += urd(g) * trd(g); + ++j; + ZEb(p.c, g); + } + } + return p; + } + function _nc(a, b) { + var c2, d, e, f2; + c2 = b.b; + f2 = new dnb(c2.j); + e = 0; + d = c2.j; + d.c.length = 0; + Nnc(RD($i(a.b, (qpd(), Yod), (joc(), ioc)), 15), c2); + e = Onc(f2, e, new Hoc(), d); + Nnc(RD($i(a.b, Yod, hoc), 15), c2); + e = Onc(f2, e, new Joc(), d); + Nnc(RD($i(a.b, Yod, goc), 15), c2); + Nnc(RD($i(a.b, Xod, ioc), 15), c2); + Nnc(RD($i(a.b, Xod, hoc), 15), c2); + e = Onc(f2, e, new Loc(), d); + Nnc(RD($i(a.b, Xod, goc), 15), c2); + Nnc(RD($i(a.b, npd, ioc), 15), c2); + e = Onc(f2, e, new Noc(), d); + Nnc(RD($i(a.b, npd, hoc), 15), c2); + e = Onc(f2, e, new Poc(), d); + Nnc(RD($i(a.b, npd, goc), 15), c2); + Nnc(RD($i(a.b, ppd, ioc), 15), c2); + e = Onc(f2, e, new toc(), d); + Nnc(RD($i(a.b, ppd, hoc), 15), c2); + Nnc(RD($i(a.b, ppd, goc), 15), c2); + } + function jJc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n; + for (h = new Anb(b); h.a < h.c.c.length; ) { + f2 = RD(ynb(h), 239); + f2.e = null; + f2.c = 0; + } + i2 = null; + for (g = new Anb(b); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 239); + l = f2.d[0]; + if (c2 && l.k != (r3b(), p3b)) { + continue; + } + for (n = RD(mQb(l, (Ywc(), qwc)), 15).Kc(); n.Ob(); ) { + m = RD(n.Pb(), 10); + if (!c2 || m.k == (r3b(), p3b)) { + (!f2.e && (f2.e = new bnb()), f2.e).Fc(a.b[m.c.p][m.p]); + ++a.b[m.c.p][m.p].c; + } + } + if (!c2 && l.k == (r3b(), p3b)) { + if (i2) { + for (k = RD(Qc(a.d, i2), 21).Kc(); k.Ob(); ) { + j = RD(k.Pb(), 10); + for (e = RD(Qc(a.d, l), 21).Kc(); e.Ob(); ) { + d = RD(e.Pb(), 10); + wJc(a.b[j.c.p][j.p]).Fc(a.b[d.c.p][d.p]); + ++a.b[d.c.p][d.p].c; + } + } + } + i2 = l; + } + } + } + function iGc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q; + c2.Ug("Model order cycle breaking", 1); + a.a = 0; + a.b = 0; + n = new bnb(); + k = b.a.c.length; + for (j = new Anb(b.a); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 10); + nQb(i2, (Ywc(), zwc)) && (k = $wnd.Math.max(k, RD(mQb(i2, zwc), 17).a + 1)); + } + for (p = new Anb(b.a); p.a < p.c.c.length; ) { + o2 = RD(ynb(p), 10); + g = hGc(a, o2, k); + for (m = c3b(o2, (BEc(), zEc)).Kc(); m.Ob(); ) { + l = RD(m.Pb(), 12); + for (f2 = new Anb(l.g); f2.a < f2.c.c.length; ) { + d = RD(ynb(f2), 18); + q = d.d.i; + h = hGc(a, q, k); + h < g && (ZEb(n.c, d), true); + } + } + } + for (e = new Anb(n); e.a < e.c.c.length; ) { + d = RD(ynb(e), 18); + X0b(d, true); + pQb(b, (Ywc(), awc), (Geb(), true)); + } + n.c.length = 0; + c2.Vg(); + } + function qUb(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m; + g = b.d; + h = c2.d; + while (g.a - h.a == 0 && g.b - h.b == 0) { + i2 = false; + if (ZD(b, 250) && ZD(c2, 250) && !i2) { + j = RD(b, 250).a; + k = ojd(new sjd($Tb(j)), ZTb(j)); + d = 2; + e = new rjd(k.a / $wnd.Math.sqrt(k.a * k.a + k.b * k.b) * d, -k.b / $wnd.Math.sqrt(k.a * k.a + k.b * k.b) * d); + $id(g, e); + l = RD(c2, 250).a; + m = ojd(new sjd($Tb(l)), ZTb(l)); + d = k == m ? -2 : 2; + f2 = new rjd(m.a / $wnd.Math.sqrt(m.a * m.a + m.b * m.b) * d, -(m.b / $wnd.Math.sqrt(m.a * m.a + m.b * m.b)) * d); + $id(g, f2); + i2 = true; + } else { + g.a += Kwb(a, 26) * Kxe + Kwb(a, 27) * Lxe - 0.5; + g.b += Kwb(a, 26) * Kxe + Kwb(a, 27) * Lxe - 0.5; + h.a += Kwb(a, 26) * Kxe + Kwb(a, 27) * Lxe - 0.5; + h.b += Kwb(a, 26) * Kxe + Kwb(a, 27) * Lxe - 0.5; + } + } + } + function NWb(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, p, q, r; + j = KWb(b); + q = RD(mQb(b, (yCc(), oAc)), 322); + xgb(j, new UWb(q)); + r = RD(mQb(b, gAc), 299); + xgb(j, new WWb(r)); + p = 0; + k = new bnb(); + for (f2 = new Kmb(j); f2.a != f2.b; ) { + e = RD(Imb(f2), 36); + cXb(a.c, e); + m = RD(mQb(e, (Ywc(), Kwc)), 15); + p += m.gc(); + d = m.Kc(); + Rmb(k, new Ptd(e, d)); + } + c2.Ug("Recursive hierarchical layout", p); + n = RD(RD(Vmb(k, k.c.length - 1), 42).b, 51); + while (n.Ob()) { + for (i2 = new Anb(k); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 42); + m = RD(h.b, 51); + g = RD(h.a, 36); + while (m.Ob()) { + l = RD(m.Pb(), 47); + if (ZD(l, 514)) { + if (!g.e) { + l.Kf(g, c2.eh(1)); + break; + } else { + break; + } + } else { + l.Kf(g, c2.eh(1)); + } + } + } + } + c2.Vg(); + } + function Cec(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p; + b.Ug("Layer size calculation", 1); + k = oxe; + j = pxe; + e = false; + for (h = new Anb(a.b); h.a < h.c.c.length; ) { + g = RD(ynb(h), 30); + i2 = g.c; + i2.a = 0; + i2.b = 0; + if (g.a.c.length == 0) { + continue; + } + e = true; + for (m = new Anb(g.a); m.a < m.c.c.length; ) { + l = RD(ynb(m), 10); + o2 = l.o; + n = l.d; + i2.a = $wnd.Math.max(i2.a, o2.a + n.b + n.c); + } + d = RD(Vmb(g.a, 0), 10); + p = d.n.b - d.d.d; + d.k == (r3b(), m3b) && (p -= RD(mQb(a, (yCc(), eCc)), 140).d); + f2 = RD(Vmb(g.a, g.a.c.length - 1), 10); + c2 = f2.n.b + f2.o.b + f2.d.a; + f2.k == m3b && (c2 += RD(mQb(a, (yCc(), eCc)), 140).a); + i2.b = c2 - p; + k = $wnd.Math.min(k, p); + j = $wnd.Math.max(j, c2); + } + if (!e) { + k = 0; + j = 0; + } + a.f.b = j - k; + a.c.b -= k; + b.Vg(); + } + function p2b(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r; + f2 = 0; + g = 0; + for (j = new Anb(a.a); j.a < j.c.c.length; ) { + h = RD(ynb(j), 10); + f2 = $wnd.Math.max(f2, h.d.b); + g = $wnd.Math.max(g, h.d.c); + } + for (i2 = new Anb(a.a); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 10); + c2 = RD(mQb(h, (yCc(), Rzc)), 255); + switch (c2.g) { + case 1: + o2 = 0; + break; + case 2: + o2 = 1; + break; + case 5: + o2 = 0.5; + break; + default: + d = 0; + l = 0; + for (n = new Anb(h.j); n.a < n.c.c.length; ) { + m = RD(ynb(n), 12); + m.e.c.length == 0 || ++d; + m.g.c.length == 0 || ++l; + } + d + l == 0 ? o2 = 0.5 : o2 = l / (d + l); + } + q = a.c; + k = h.o.a; + r = (q.a - k) * o2; + o2 > 0.5 ? r -= g * 2 * (o2 - 0.5) : o2 < 0.5 && (r += f2 * 2 * (0.5 - o2)); + e = h.d.b; + r < e && (r = e); + p = h.d.c; + r > q.a - p - k && (r = q.a - p - k); + h.n.a = b + r; + } + } + function jec(a) { + var b, c2, d, e, f2; + d = RD(mQb(a, (yCc(), UAc)), 171); + if (d == (cxc(), $wc)) { + for (c2 = new is(Mr(Z2b(a).a.Kc(), new ir())); gs(c2); ) { + b = RD(hs(c2), 18); + if (!lec(b)) { + throw Adb(new Jed(nBe + X2b(a) + "' has its layer constraint set to FIRST_SEPARATE, but has at least one incoming edge. FIRST_SEPARATE nodes must not have incoming edges.")); + } + } + } else if (d == axc) { + for (f2 = new is(Mr(a3b(a).a.Kc(), new ir())); gs(f2); ) { + e = RD(hs(f2), 18); + if (!lec(e)) { + throw Adb(new Jed(nBe + X2b(a) + "' has its layer constraint set to LAST_SEPARATE, but has at least one outgoing edge. LAST_SEPARATE nodes must not have outgoing edges.")); + } + } + } + } + function Qed(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2; + if (a.e && a.c.c < a.f) { + throw Adb(new dgb("Expected " + a.f + " phases to be configured; only found " + a.c.c)); + } + k = RD(mfb(a.g), 9); + n = ev(a.f); + for (f2 = k, h = 0, j = f2.length; h < j; ++h) { + d = f2[h]; + l = RD(Med(a, d.g), 188); + l ? Rmb(n, RD(Ted(a, l), 106)) : (n.c.push(null), true); + } + o2 = new ufd(); + FDb(CDb(GDb(CDb(new SDb(null, new Swb(n, 16)), new Zed()), new _ed(b)), new bfd()), new dfd(o2)); + ofd(o2, a.a); + c2 = new bnb(); + for (e = k, g = 0, i2 = e.length; g < i2; ++g) { + d = e[g]; + Tmb(c2, Ued(a, Ux(RD(Med(o2, d.g), 20)))); + m = RD(Vmb(n, d.g), 106); + !!m && (ZEb(c2.c, m), true); + } + Tmb(c2, Ued(a, Ux(RD(Med(o2, k[k.length - 1].g + 1), 20)))); + return c2; + } + function Frc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u; + m = new bnb(); + e = new bnb(); + p = null; + for (h = b.Kc(); h.Ob(); ) { + g = RD(h.Pb(), 17); + f2 = new Trc(g.a); + ZEb(e.c, f2); + if (p) { + f2.d = p; + p.e = f2; + } + p = f2; + } + t = Erc(a); + for (k = 0; k < e.c.length; ++k) { + n = null; + q = Src((tFb(0, e.c.length), RD(e.c[0], 661))); + c2 = null; + d = oxe; + for (l = 1; l < a.b.c.length; ++l) { + r = q ? $wnd.Math.abs(q.b - l) : $wnd.Math.abs(l - n.b) + 1; + o2 = n ? $wnd.Math.abs(l - n.b) : r + 1; + if (o2 < r) { + j = n; + i2 = o2; + } else { + j = q; + i2 = r; + } + s = (u = Kfb(UD(mQb(a, (yCc(), sCc)))), t[l] + $wnd.Math.pow(i2, u)); + if (s < d) { + d = s; + c2 = j; + c2.c = l; + } + if (!!q && l == q.b) { + n = q; + q = Nrc(q); + } + } + if (c2) { + Rmb(m, sgb(c2.c)); + c2.a = true; + Orc(c2); + } + } + yob(); + Ynb(m.c, m.c.length, null); + return m; + } + function iD(a, b, c2) { + var d, e, f2, g, h, i2; + if (b.l == 0 && b.m == 0 && b.h == 0) { + throw Adb(new teb("divide by zero")); + } + if (a.l == 0 && a.m == 0 && a.h == 0) { + c2 && (eD = hD(0, 0, 0)); + return hD(0, 0, 0); + } + if (b.h == fxe && b.m == 0 && b.l == 0) { + return jD(a, c2); + } + i2 = false; + if (b.h >> 19 != 0) { + b = xD(b); + i2 = !i2; + } + g = pD(b); + f2 = false; + e = false; + d = false; + if (a.h == fxe && a.m == 0 && a.l == 0) { + e = true; + f2 = true; + if (g == -1) { + a = gD((MD(), ID)); + d = true; + i2 = !i2; + } else { + h = BD(a, g); + i2 && nD(h); + c2 && (eD = hD(0, 0, 0)); + return h; + } + } else if (a.h >> 19 != 0) { + f2 = true; + a = xD(a); + d = true; + i2 = !i2; + } + if (g != -1) { + return kD(a, g, i2, f2, c2); + } + if (uD(a, b) < 0) { + c2 && (f2 ? eD = xD(a) : eD = hD(a.l, a.m, a.h)); + return hD(0, 0, 0); + } + return lD(d ? a : hD(a.l, a.m, a.h), b, i2, f2, e, c2); + } + function Bjb(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2; + g = a.e; + i2 = b.e; + if (g == 0) { + return b; + } + if (i2 == 0) { + return a; + } + f2 = a.d; + h = b.d; + if (f2 + h == 2) { + c2 = Cdb(a.a[0], yxe); + d = Cdb(b.a[0], yxe); + if (g == i2) { + k = Bdb(c2, d); + o2 = Ydb(k); + n = Ydb(Udb(k, 32)); + return n == 0 ? new ajb(g, o2) : new cjb(g, 2, cD(WC(kE, 1), Pwe, 28, 15, [o2, n])); + } + return Pib(), Jdb(g < 0 ? Vdb(d, c2) : Vdb(c2, d), 0) ? jjb(g < 0 ? Vdb(d, c2) : Vdb(c2, d)) : Xib(jjb(Odb(g < 0 ? Vdb(d, c2) : Vdb(c2, d)))); + } else if (g == i2) { + m = g; + l = f2 >= h ? Cjb(a.a, f2, b.a, h) : Cjb(b.a, h, a.a, f2); + } else { + e = f2 != h ? f2 > h ? 1 : -1 : Ejb(a.a, b.a, f2); + if (e == 0) { + return Pib(), Oib; + } + if (e == 1) { + m = g; + l = Hjb(a.a, f2, b.a, h); + } else { + m = i2; + l = Hjb(b.a, h, a.a, f2); + } + } + j = new cjb(m, l.length, l); + Rib(j); + return j; + } + function KUc(a, b) { + var c2, d, e, f2, g, h, i2; + if (a.g > b.f || b.g > a.f) { + return; + } + c2 = 0; + d = 0; + for (g = a.w.a.ec().Kc(); g.Ob(); ) { + e = RD(g.Pb(), 12); + AVc(xjd(cD(WC(l3, 1), Nve, 8, 0, [e.i.n, e.n, e.a])).b, b.g, b.f) && ++c2; + } + for (h = a.r.a.ec().Kc(); h.Ob(); ) { + e = RD(h.Pb(), 12); + AVc(xjd(cD(WC(l3, 1), Nve, 8, 0, [e.i.n, e.n, e.a])).b, b.g, b.f) && --c2; + } + for (i2 = b.w.a.ec().Kc(); i2.Ob(); ) { + e = RD(i2.Pb(), 12); + AVc(xjd(cD(WC(l3, 1), Nve, 8, 0, [e.i.n, e.n, e.a])).b, a.g, a.f) && ++d; + } + for (f2 = b.r.a.ec().Kc(); f2.Ob(); ) { + e = RD(f2.Pb(), 12); + AVc(xjd(cD(WC(l3, 1), Nve, 8, 0, [e.i.n, e.n, e.a])).b, a.g, a.f) && --d; + } + if (c2 < d) { + new _Uc(a, b, d - c2); + } else if (d < c2) { + new _Uc(b, a, c2 - d); + } else { + new _Uc(b, a, 0); + new _Uc(a, b, 0); + } + } + function ASb(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s; + j = b.c; + e = zRb(a.e); + l = ijd(njd(ajd(yRb(a.e)), a.d * a.a, a.c * a.b), -0.5); + c2 = e.a - l.a; + d = e.b - l.b; + g = b.a; + c2 = g.c - c2; + d = g.d - d; + for (i2 = new Anb(j); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 407); + m = h.b; + n = c2 + m.a; + q = d + m.b; + o2 = eE(n / a.a); + r = eE(q / a.b); + f2 = h.a; + switch (f2.g) { + case 0: + k = (IPb(), FPb); + break; + case 1: + k = (IPb(), EPb); + break; + case 2: + k = (IPb(), GPb); + break; + default: + k = (IPb(), HPb); + } + if (f2.a) { + s = eE((q + h.c) / a.b); + Rmb(a.f, new lRb(k, sgb(r), sgb(s))); + f2 == (IRb(), HRb) ? eQb(a, 0, r, o2, s) : eQb(a, o2, r, a.d - 1, s); + } else { + p = eE((n + h.c) / a.a); + Rmb(a.f, new lRb(k, sgb(o2), sgb(p))); + f2 == (IRb(), FRb) ? eQb(a, o2, 0, p, r) : eQb(a, o2, r, p, a.c - 1); + } + } + } + function Q$d(a) { + var b, c2, d, e, f2, g, h, i2, j, k; + b = new Z$d(); + c2 = new Z$d(); + j = lhb(pKe, (e = bAd(a.b, qKe), !e ? null : WD($Nd((!e.b && (e.b = new SVd((JTd(), FTd), C8, e)), e.b), rKe)))); + for (i2 = 0; i2 < a.i; ++i2) { + h = RD(a.g[i2], 179); + if (ZD(h, 102)) { + g = RD(h, 19); + (g.Bb & QHe) != 0 ? ((g.Bb & Ove) == 0 || !j && (f2 = bAd(g, qKe), (!f2 ? null : WD($Nd((!f2.b && (f2.b = new SVd((JTd(), FTd), C8, f2)), f2.b), FIe))) == null)) && WGd(b, g) : (k = Z5d(g), !!k && (k.Bb & QHe) != 0 || ((g.Bb & Ove) == 0 || !j && (d = bAd(g, qKe), (!d ? null : WD($Nd((!d.b && (d.b = new SVd((JTd(), FTd), C8, d)), d.b), FIe))) == null)) && WGd(c2, g)); + } else { + nke(); + if (RD(h, 69).xk()) { + if (!h.sk()) { + WGd(b, h); + WGd(c2, h); + } + } + } + } + VHd(b); + VHd(c2); + a.a = RD(b.g, 254); + RD(c2.g, 254); + } + function Eee(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l; + if (BYd(b, c2) >= 0) { + return c2; + } + switch (yfe(Qee(a, c2))) { + case 2: { + if (lhb("", Oee(a, c2.qk()).xe())) { + i2 = Bfe(Qee(a, c2)); + h = Afe(Qee(a, c2)); + k = Ree(a, b, i2, h); + if (k) { + return k; + } + e = Fee(a, b); + for (g = 0, l = e.gc(); g < l; ++g) { + k = RD(e.Xb(g), 179); + if (Xee(Cfe(Qee(a, k)), i2)) { + return k; + } + } + } + return null; + } + case 4: { + if (lhb("", Oee(a, c2.qk()).xe())) { + for (d = c2; d; d = xfe(Qee(a, d))) { + j = Bfe(Qee(a, d)); + h = Afe(Qee(a, d)); + k = See(a, b, j, h); + if (k) { + return k; + } + } + i2 = Bfe(Qee(a, c2)); + if (lhb(dLe, i2)) { + return Tee(a, b); + } else { + f2 = Gee(a, b); + for (g = 0, l = f2.gc(); g < l; ++g) { + k = RD(f2.Xb(g), 179); + if (Xee(Cfe(Qee(a, k)), i2)) { + return k; + } + } + } + } + return null; + } + default: { + return null; + } + } + } + function Tfe(a, b, c2) { + var d, e, f2, g, h, i2, j, k; + if (c2.gc() == 0) { + return false; + } + h = (nke(), RD(b, 69).xk()); + f2 = h ? c2 : new ZHd(c2.gc()); + if (qke(a.e, b)) { + if (b.Si()) { + for (j = c2.Kc(); j.Ob(); ) { + i2 = j.Pb(); + if (!dge(a, b, i2, ZD(b, 102) && (RD(b, 19).Bb & txe) != 0)) { + e = oke(b, i2); + f2.Hc(e) || f2.Fc(e); + } + } + } else if (!h) { + for (j = c2.Kc(); j.Ob(); ) { + i2 = j.Pb(); + e = oke(b, i2); + f2.Fc(e); + } + } + } else { + if (c2.gc() > 1) { + throw Adb(new agb(gLe)); + } + k = pke(a.e.Dh(), b); + d = RD(a.g, 124); + for (g = 0; g < a.i; ++g) { + e = d[g]; + if (k.am(e.Lk())) { + if (c2.Hc(h ? e : e.md())) { + return false; + } else { + for (j = c2.Kc(); j.Ob(); ) { + i2 = j.Pb(); + RD(eHd(a, g, h ? RD(i2, 76) : oke(b, i2)), 76); + } + return true; + } + } + } + if (!h) { + e = oke(b, c2.Kc().Pb()); + f2.Fc(e); + } + } + return YGd(a, f2); + } + function QQc(a, b) { + var c2, d, e, f2, g, h, i2, j, k; + k = new Yub(); + for (h = (j = new glb(a.c).a.vc().Kc(), new llb(j)); h.a.Ob(); ) { + f2 = (e = RD(h.a.Pb(), 44), RD(e.md(), 467)); + f2.b == 0 && (Pub(k, f2, k.c.b, k.c), true); + } + while (k.b != 0) { + f2 = RD(k.b == 0 ? null : (sFb(k.b != 0), Wub(k, k.a.a)), 467); + f2.a == null && (f2.a = 0); + for (d = new Anb(f2.d); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 663); + c2.b.a == null ? c2.b.a = Kfb(f2.a) + c2.a : b.o == (EQc(), CQc) ? c2.b.a = $wnd.Math.min(Kfb(c2.b.a), Kfb(f2.a) + c2.a) : c2.b.a = $wnd.Math.max(Kfb(c2.b.a), Kfb(f2.a) + c2.a); + --c2.b.b; + c2.b.b == 0 && Mub(k, c2.b); + } + } + for (g = (i2 = new glb(a.c).a.vc().Kc(), new llb(i2)); g.a.Ob(); ) { + f2 = (e = RD(g.a.Pb(), 44), RD(e.md(), 467)); + b.i[f2.c.p] = f2.a; + } + } + function kSc(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m, n, o2; + k = c2 + b.c.c.a; + for (n = new Anb(b.j); n.a < n.c.c.length; ) { + m = RD(ynb(n), 12); + e = xjd(cD(WC(l3, 1), Nve, 8, 0, [m.i.n, m.n, m.a])); + if (b.k == (r3b(), q3b)) { + h = RD(mQb(m, (Ywc(), Awc)), 12); + e.a = xjd(cD(WC(l3, 1), Nve, 8, 0, [h.i.n, h.n, h.a])).a; + b.n.a = e.a; + } + g = new rjd(0, e.b); + if (m.j == (qpd(), Xod)) { + g.a = k; + } else if (m.j == ppd) { + g.a = c2; + } else { + continue; + } + o2 = $wnd.Math.abs(e.a - g.a); + if (o2 <= d && !hSc(b)) { + continue; + } + f2 = m.g.c.length + m.e.c.length > 1; + for (j = new l4b(m.b); xnb(j.a) || xnb(j.b); ) { + i2 = RD(xnb(j.a) ? ynb(j.a) : ynb(j.b), 18); + l = i2.c == m ? i2.d : i2.c; + $wnd.Math.abs(xjd(cD(WC(l3, 1), Nve, 8, 0, [l.i.n, l.n, l.a])).b - g.b) > 1 && eSc(a, i2, g, f2, m); + } + } + } + function vUc(a) { + var b, c2, d, e, f2, g; + e = new Jkb(a.e, 0); + d = new Jkb(a.a, 0); + if (a.d) { + for (c2 = 0; c2 < a.b; c2++) { + sFb(e.b < e.d.gc()); + e.d.Xb(e.c = e.b++); + } + } else { + for (c2 = 0; c2 < a.b - 1; c2++) { + sFb(e.b < e.d.gc()); + e.d.Xb(e.c = e.b++); + Ckb(e); + } + } + b = Kfb((sFb(e.b < e.d.gc()), UD(e.d.Xb(e.c = e.b++)))); + while (a.f - b > AEe) { + f2 = b; + g = 0; + while ($wnd.Math.abs(b - f2) < AEe) { + ++g; + b = Kfb((sFb(e.b < e.d.gc()), UD(e.d.Xb(e.c = e.b++)))); + sFb(d.b < d.d.gc()); + d.d.Xb(d.c = d.b++); + } + if (g < a.b) { + sFb(e.b > 0); + e.a.Xb(e.c = --e.b); + uUc(a, a.b - g, f2, d, e); + sFb(e.b < e.d.gc()); + e.d.Xb(e.c = e.b++); + } + sFb(d.b > 0); + d.a.Xb(d.c = --d.b); + } + if (!a.d) { + for (c2 = 0; c2 < a.b - 1; c2++) { + sFb(e.b < e.d.gc()); + e.d.Xb(e.c = e.b++); + Ckb(e); + } + } + a.d = true; + a.c = true; + } + function nme() { + nme = geb; + Rle = (Qle(), Ple).b; + Ule = RD(QHd(xYd(Ple.b), 0), 35); + Sle = RD(QHd(xYd(Ple.b), 1), 35); + Tle = RD(QHd(xYd(Ple.b), 2), 35); + cme = Ple.bb; + RD(QHd(xYd(Ple.bb), 0), 35); + RD(QHd(xYd(Ple.bb), 1), 35); + eme = Ple.fb; + fme = RD(QHd(xYd(Ple.fb), 0), 35); + RD(QHd(xYd(Ple.fb), 1), 35); + RD(QHd(xYd(Ple.fb), 2), 19); + hme = Ple.qb; + kme = RD(QHd(xYd(Ple.qb), 0), 35); + RD(QHd(xYd(Ple.qb), 1), 19); + RD(QHd(xYd(Ple.qb), 2), 19); + ime = RD(QHd(xYd(Ple.qb), 3), 35); + jme = RD(QHd(xYd(Ple.qb), 4), 35); + mme = RD(QHd(xYd(Ple.qb), 6), 35); + lme = RD(QHd(xYd(Ple.qb), 5), 19); + Vle = Ple.j; + Wle = Ple.k; + Xle = Ple.q; + Yle = Ple.w; + Zle = Ple.B; + $le = Ple.A; + _le = Ple.C; + ame = Ple.D; + bme = Ple._; + dme = Ple.cb; + gme = Ple.hb; + } + function yIc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n; + a.c = 0; + a.b = 0; + d = 2 * b.c.a.c.length + 1; + o: + for (l = c2.Kc(); l.Ob(); ) { + k = RD(l.Pb(), 12); + h = k.j == (qpd(), Yod) || k.j == npd; + n = 0; + if (h) { + m = RD(mQb(k, (Ywc(), Iwc)), 10); + if (!m) { + continue; + } + n += tIc(a, d, k, m); + } else { + for (j = new Anb(k.g); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 18); + e = i2.d; + if (e.i.c == b.c) { + Rmb(a.a, k); + continue o; + } else { + n += a.g[e.p]; + } + } + for (g = new Anb(k.e); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 18); + e = f2.c; + if (e.i.c == b.c) { + Rmb(a.a, k); + continue o; + } else { + n -= a.g[e.p]; + } + } + } + if (k.e.c.length + k.g.c.length > 0) { + a.f[k.p] = n / (k.e.c.length + k.g.c.length); + a.c = $wnd.Math.min(a.c, a.f[k.p]); + a.b = $wnd.Math.max(a.b, a.f[k.p]); + } else + h && (a.f[k.p] = n); + } + } + function xne(a) { + a.b = null; + a.bb = null; + a.fb = null; + a.qb = null; + a.a = null; + a.c = null; + a.d = null; + a.e = null; + a.f = null; + a.n = null; + a.M = null; + a.L = null; + a.Q = null; + a.R = null; + a.K = null; + a.db = null; + a.eb = null; + a.g = null; + a.i = null; + a.j = null; + a.k = null; + a.gb = null; + a.o = null; + a.p = null; + a.q = null; + a.r = null; + a.$ = null; + a.ib = null; + a.S = null; + a.T = null; + a.t = null; + a.s = null; + a.u = null; + a.v = null; + a.w = null; + a.B = null; + a.A = null; + a.C = null; + a.D = null; + a.F = null; + a.G = null; + a.H = null; + a.I = null; + a.J = null; + a.P = null; + a.Z = null; + a.U = null; + a.V = null; + a.W = null; + a.X = null; + a.Y = null; + a._ = null; + a.ab = null; + a.cb = null; + a.hb = null; + a.nb = null; + a.lb = null; + a.mb = null; + a.ob = null; + a.pb = null; + a.jb = null; + a.kb = null; + a.N = false; + a.O = false; + } + function C8b(a, b, c2) { + var d, e, f2, g; + c2.Ug("Graph transformation (" + a.a + ")", 1); + g = bv(b.a); + for (f2 = new Anb(b.b); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 30); + Tmb(g, e.a); + } + d = RD(mQb(b, (yCc(), sAc)), 428); + if (d == ($tc(), Ytc)) { + switch (RD(mQb(b, rAc), 88).g) { + case 2: + q8b(b, g); + break; + case 3: + G8b(b, g); + break; + case 4: + if (a.a == (P8b(), O8b)) { + G8b(b, g); + r8b(b, g); + } else { + r8b(b, g); + G8b(b, g); + } + } + } else { + if (a.a == (P8b(), O8b)) { + switch (RD(mQb(b, rAc), 88).g) { + case 2: + q8b(b, g); + r8b(b, g); + break; + case 3: + G8b(b, g); + q8b(b, g); + break; + case 4: + q8b(b, g); + G8b(b, g); + } + } else { + switch (RD(mQb(b, rAc), 88).g) { + case 2: + q8b(b, g); + r8b(b, g); + break; + case 3: + q8b(b, g); + G8b(b, g); + break; + case 4: + G8b(b, g); + q8b(b, g); + } + } + } + c2.Vg(); + } + function AXb(a) { + var b, c2, d, e, f2, g, h, i2; + for (f2 = new Anb(a.a.b); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 86); + e.b.c = e.g.c; + e.b.d = e.g.d; + } + i2 = new rjd(oxe, oxe); + b = new rjd(pxe, pxe); + for (d = new Anb(a.a.b); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 86); + i2.a = $wnd.Math.min(i2.a, c2.g.c); + i2.b = $wnd.Math.min(i2.b, c2.g.d); + b.a = $wnd.Math.max(b.a, c2.g.c + c2.g.b); + b.b = $wnd.Math.max(b.b, c2.g.d + c2.g.a); + } + for (h = Uc(a.c).a.nc(); h.Ob(); ) { + g = RD(h.Pb(), 42); + c2 = RD(g.b, 86); + i2.a = $wnd.Math.min(i2.a, c2.g.c); + i2.b = $wnd.Math.min(i2.b, c2.g.d); + b.a = $wnd.Math.max(b.a, c2.g.c + c2.g.b); + b.b = $wnd.Math.max(b.b, c2.g.d + c2.g.a); + } + a.d = fjd(new rjd(i2.a, i2.b)); + a.e = ojd(new rjd(b.a, b.b), i2); + a.a.a.c.length = 0; + a.a.b.c.length = 0; + } + function LZb(a) { + CZb(); + var b, c2, d, e, f2, g, h; + h = new EZb(); + for (c2 = new Anb(a); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 148); + (!h.b || b.c >= h.b.c) && (h.b = b); + if (!h.c || b.c <= h.c.c) { + h.d = h.c; + h.c = b; + } + (!h.e || b.d >= h.e.d) && (h.e = b); + (!h.f || b.d <= h.f.d) && (h.f = b); + } + d = new PZb((nZb(), jZb)); + t$b(a, AZb, new mob(cD(WC(wQ, 1), rve, 382, 0, [d]))); + g = new PZb(mZb); + t$b(a, zZb, new mob(cD(WC(wQ, 1), rve, 382, 0, [g]))); + e = new PZb(kZb); + t$b(a, yZb, new mob(cD(WC(wQ, 1), rve, 382, 0, [e]))); + f2 = new PZb(lZb); + t$b(a, xZb, new mob(cD(WC(wQ, 1), rve, 382, 0, [f2]))); + FZb(d.c, jZb); + FZb(e.c, kZb); + FZb(f2.c, lZb); + FZb(g.c, mZb); + h.a.c.length = 0; + Tmb(h.a, d.c); + Tmb(h.a, hv(e.c)); + Tmb(h.a, f2.c); + Tmb(h.a, hv(g.c)); + return h; + } + function n9c(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2; + b.Ug(bGe, 1); + n = Kfb(UD(Gxd(a, (X6c(), W6c)))); + g = Kfb(UD(Gxd(a, (X7c(), Q7c)))); + h = RD(Gxd(a, N7c), 107); + Bad((!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a)); + k = U8c((!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a), n, g); + !a.a && (a.a = new C5d(J4, a, 10, 11)); + for (j = new Anb(k); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 186); + for (e = new Anb(i2.a); e.a < e.c.c.length; ) { + d = RD(ynb(e), 172); + m = new had(d.s, d.t, Kfb(UD(Gxd(a, Q7c)))); + aad(m, d); + Rmb(i2.d, m); + } + } + l = zad(k, g); + o2 = $wnd.Math.max(l.a, Kfb(UD(Gxd(a, U6c))) - (h.b + h.c)); + f2 = $wnd.Math.max(l.b, Kfb(UD(Gxd(a, R6c))) - (h.d + h.a)); + c2 = f2 - l.b; + Ixd(a, M6c, c2); + Ixd(a, O6c, o2); + Ixd(a, N6c, f2 + c2); + Ixd(a, V6c, k); + b.Vg(); + } + function A9b(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p; + j = new Iub(); + k = new Iub(); + o2 = new Iub(); + p = new Iub(); + i2 = Kfb(UD(mQb(b, (yCc(), bCc)))); + f2 = Kfb(UD(mQb(b, TBc))); + for (h = new Anb(c2); h.a < h.c.c.length; ) { + g = RD(ynb(h), 10); + l = RD(mQb(g, (Ywc(), hwc)), 64); + if (l == (qpd(), Yod)) { + k.a.zc(g, k); + for (e = new is(Mr(Z2b(g).a.Kc(), new ir())); gs(e); ) { + d = RD(hs(e), 18); + Ysb(j, d.c.i); + } + } else if (l == npd) { + p.a.zc(g, p); + for (e = new is(Mr(Z2b(g).a.Kc(), new ir())); gs(e); ) { + d = RD(hs(e), 18); + Ysb(o2, d.c.i); + } + } + } + if (j.a.gc() != 0) { + m = new TTc(2, f2); + n = STc(m, b, j, k, -i2 - b.c.b); + if (n > 0) { + a.a = i2 + (n - 1) * f2; + b.c.b += a.a; + b.f.b += a.a; + } + } + if (o2.a.gc() != 0) { + m = new TTc(1, f2); + n = STc(m, b, o2, p, b.f.b + i2 - b.c.b); + n > 0 && (b.f.b += i2 + (n - 1) * f2); + } + } + function osc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u; + k = Kfb(UD(mQb(a, (yCc(), WBc)))); + d = Kfb(UD(mQb(a, nCc))); + m = new dtd(); + pQb(m, WBc, k + d); + j = b; + r = j.d; + p = j.c.i; + s = j.d.i; + q = Q4b(p.c); + t = Q4b(s.c); + e = new bnb(); + for (l = q; l <= t; l++) { + h = new j3b(a); + h3b(h, (r3b(), o3b)); + pQb(h, (Ywc(), Awc), j); + pQb(h, BBc, (Bod(), wod)); + pQb(h, YBc, m); + n = RD(Vmb(a.b, l), 30); + l == q ? f3b(h, n.a.c.length - c2, n) : g3b(h, n); + u = Kfb(UD(mQb(j, FAc))); + if (u < 0) { + u = 0; + pQb(j, FAc, u); + } + h.o.b = u; + o2 = $wnd.Math.floor(u / 2); + g = new R3b(); + Q3b(g, (qpd(), ppd)); + P3b(g, h); + g.n.b = o2; + i2 = new R3b(); + Q3b(i2, Xod); + P3b(i2, h); + i2.n.b = o2; + Z0b(j, g); + f2 = new a1b(); + kQb(f2, j); + pQb(f2, RAc, null); + Y0b(f2, i2); + Z0b(f2, r); + psc(h, j, f2); + ZEb(e.c, f2); + j = f2; + } + return e; + } + function Hec(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t; + i2 = RD(e3b(a, (qpd(), ppd)).Kc().Pb(), 12).e; + n = RD(e3b(a, Xod).Kc().Pb(), 12).g; + h = i2.c.length; + t = K3b(RD(Vmb(a.j, 0), 12)); + while (h-- > 0) { + p = (tFb(0, i2.c.length), RD(i2.c[0], 18)); + e = (tFb(0, n.c.length), RD(n.c[0], 18)); + s = e.d.e; + f2 = Wmb(s, e, 0); + $0b(p, e.d, f2); + Y0b(e, null); + Z0b(e, null); + o2 = p.a; + b && Mub(o2, new sjd(t)); + for (d = Sub(e.a, 0); d.b != d.d.c; ) { + c2 = RD(evb(d), 8); + Mub(o2, new sjd(c2)); + } + r = p.b; + for (m = new Anb(e.b); m.a < m.c.c.length; ) { + l = RD(ynb(m), 72); + ZEb(r.c, l); + } + q = RD(mQb(p, (yCc(), RAc)), 75); + g = RD(mQb(e, RAc), 75); + if (g) { + if (!q) { + q = new Ejd(); + pQb(p, RAc, q); + } + for (k = Sub(g, 0); k.b != k.d.c; ) { + j = RD(evb(k), 8); + Mub(q, new sjd(j)); + } + } + } + } + function $Qc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t; + p = b.b.c.length; + if (p < 3) { + return; + } + n = $C(kE, Pwe, 28, p, 15, 1); + l = 0; + for (k = new Anb(b.b); k.a < k.c.c.length; ) { + j = RD(ynb(k), 30); + n[l++] = j.a.c.length; + } + m = new Jkb(b.b, 2); + for (d = 1; d < p - 1; d++) { + c2 = (sFb(m.b < m.d.gc()), RD(m.d.Xb(m.c = m.b++), 30)); + o2 = new Anb(c2.a); + f2 = 0; + h = 0; + for (i2 = 0; i2 < n[d + 1]; i2++) { + t = RD(ynb(o2), 10); + if (i2 == n[d + 1] - 1 || ZQc(a, t, d + 1, d)) { + g = n[d] - 1; + ZQc(a, t, d + 1, d) && (g = a.c.e[RD(RD(RD(Vmb(a.c.b, t.p), 15).Xb(0), 42).a, 10).p]); + while (h <= i2) { + s = RD(Vmb(c2.a, h), 10); + if (!ZQc(a, s, d + 1, d)) { + for (r = RD(Vmb(a.c.b, s.p), 15).Kc(); r.Ob(); ) { + q = RD(r.Pb(), 42); + e = a.c.e[RD(q.a, 10).p]; + (e < f2 || e > g) && Ysb(a.b, RD(q.b, 18)); + } + } + ++h; + } + f2 = g; + } + } + } + } + function zhd(b, c2) { + var d; + if (c2 == null || lhb(c2, vve)) { + return null; + } + if (c2.length == 0 && b.k != (kid(), fid)) { + return null; + } + switch (b.k.g) { + case 1: + return mhb(c2, FGe) ? (Geb(), Feb) : mhb(c2, GGe) ? (Geb(), Eeb) : null; + case 2: + try { + return sgb(Oeb(c2, qwe, lve)); + } catch (a) { + a = zdb(a); + if (ZD(a, 130)) { + return null; + } else + throw Adb(a); + } + case 4: + try { + return Neb(c2); + } catch (a) { + a = zdb(a); + if (ZD(a, 130)) { + return null; + } else + throw Adb(a); + } + case 3: + return c2; + case 5: + uhd(b); + return xhd(b, c2); + case 6: + uhd(b); + return yhd(b, b.a, c2); + case 7: + try { + d = whd(b); + d.cg(c2); + return d; + } catch (a) { + a = zdb(a); + if (ZD(a, 33)) { + return null; + } else + throw Adb(a); + } + default: + throw Adb(new dgb("Invalid type set for this layout option.")); + } + } + function JKd(a) { + var b; + switch (a.d) { + case 1: { + if (a.Sj()) { + return a.o != -2; + } + break; + } + case 2: { + if (a.Sj()) { + return a.o == -2; + } + break; + } + case 3: + case 5: + case 4: + case 6: + case 7: { + return a.o > -2; + } + default: { + return false; + } + } + b = a.Rj(); + switch (a.p) { + case 0: + return b != null && Heb(TD(b)) != Pdb(a.k, 0); + case 1: + return b != null && RD(b, 222).a != Ydb(a.k) << 24 >> 24; + case 2: + return b != null && RD(b, 180).a != (Ydb(a.k) & Bwe); + case 6: + return b != null && Pdb(RD(b, 168).a, a.k); + case 5: + return b != null && RD(b, 17).a != Ydb(a.k); + case 7: + return b != null && RD(b, 191).a != Ydb(a.k) << 16 >> 16; + case 3: + return b != null && Kfb(UD(b)) != a.j; + case 4: + return b != null && RD(b, 161).a != a.j; + default: + return b == null ? a.n != null : !pb(b, a.n); + } + } + function N_d(a, b, c2) { + var d, e, f2, g; + if (a.ol() && a.nl()) { + g = O_d(a, RD(c2, 58)); + if (dE(g) !== dE(c2)) { + a.xj(b); + a.Dj(b, P_d(a, b, g)); + if (a.al()) { + f2 = (e = RD(c2, 54), a.ml() ? a.kl() ? e.Th(a.b, Z5d(RD(vYd(Uwd(a.b), a.Lj()), 19)).n, RD(vYd(Uwd(a.b), a.Lj()).Hk(), 29).kk(), null) : e.Th(a.b, BYd(e.Dh(), Z5d(RD(vYd(Uwd(a.b), a.Lj()), 19))), null, null) : e.Th(a.b, -1 - a.Lj(), null, null)); + !RD(g, 54).Ph() && (f2 = (d = RD(g, 54), a.ml() ? a.kl() ? d.Rh(a.b, Z5d(RD(vYd(Uwd(a.b), a.Lj()), 19)).n, RD(vYd(Uwd(a.b), a.Lj()).Hk(), 29).kk(), f2) : d.Rh(a.b, BYd(d.Dh(), Z5d(RD(vYd(Uwd(a.b), a.Lj()), 19))), null, f2) : d.Rh(a.b, -1 - a.Lj(), null, f2))); + !!f2 && f2.oj(); + } + Mvd(a.b) && a.Jj(a.Ij(9, c2, g, b, false)); + return g; + } + } + return c2; + } + function iJb(a) { + var b, c2, d, e, f2, g, h, i2, j, k; + d = new bnb(); + for (g = new Anb(a.e.a); g.a < g.c.c.length; ) { + e = RD(ynb(g), 125); + k = 0; + e.k.c.length = 0; + for (c2 = new Anb(CIb(e)); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 218); + if (b.f) { + Rmb(e.k, b); + ++k; + } + } + k == 1 && (ZEb(d.c, e), true); + } + for (f2 = new Anb(d); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 125); + while (e.k.c.length == 1) { + j = RD(ynb(new Anb(e.k)), 218); + a.b[j.c] = j.g; + h = j.d; + i2 = j.e; + for (c2 = new Anb(CIb(e)); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 218); + pb(b, j) || (b.f ? h == b.d || i2 == b.e ? a.b[j.c] -= a.b[b.c] - b.g : a.b[j.c] += a.b[b.c] - b.g : e == h ? b.d == e ? a.b[j.c] += b.g : a.b[j.c] -= b.g : b.d == e ? a.b[j.c] -= b.g : a.b[j.c] += b.g); + } + Ymb(h.k, j); + Ymb(i2.k, j); + h == e ? e = j.e : e = j.d; + } + } + } + function vMb(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n; + c2 = RD(Vrb(a.b, b), 127); + i2 = RD(RD(Qc(a.r, b), 21), 87); + if (i2.dc()) { + c2.n.b = 0; + c2.n.c = 0; + return; + } + j = a.u.Hc((Pod(), Lod)); + g = 0; + h = i2.Kc(); + k = null; + l = 0; + m = 0; + while (h.Ob()) { + d = RD(h.Pb(), 117); + e = Kfb(UD(d.b.of((tNb(), sNb)))); + f2 = d.b.Mf().a; + a.A.Hc((Qpd(), Ppd)) && BMb(a, b); + if (!k) { + !!a.C && a.C.b > 0 && (g = $wnd.Math.max(g, zMb(a.C.b + d.d.b, e))); + } else { + n = m + k.d.c + a.w + d.d.b; + g = $wnd.Math.max(g, (Zy(), bz(Tye), $wnd.Math.abs(l - e) <= Tye || l == e || isNaN(l) && isNaN(e) ? 0 : n / (e - l))); + } + k = d; + l = e; + m = f2; + } + if (!!a.C && a.C.c > 0) { + n = m + a.C.c; + j && (n += k.d.c); + g = $wnd.Math.max(g, (Zy(), bz(Tye), $wnd.Math.abs(l - 1) <= Tye || l == 1 || isNaN(l) && isNaN(1) ? 0 : n / (1 - l))); + } + c2.n.b = 0; + c2.a.a = g; + } + function ENb(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n; + c2 = RD(Vrb(a.b, b), 127); + i2 = RD(RD(Qc(a.r, b), 21), 87); + if (i2.dc()) { + c2.n.d = 0; + c2.n.a = 0; + return; + } + j = a.u.Hc((Pod(), Lod)); + g = 0; + a.A.Hc((Qpd(), Ppd)) && JNb(a, b); + h = i2.Kc(); + k = null; + m = 0; + l = 0; + while (h.Ob()) { + d = RD(h.Pb(), 117); + f2 = Kfb(UD(d.b.of((tNb(), sNb)))); + e = d.b.Mf().b; + if (!k) { + !!a.C && a.C.d > 0 && (g = $wnd.Math.max(g, zMb(a.C.d + d.d.d, f2))); + } else { + n = l + k.d.a + a.w + d.d.d; + g = $wnd.Math.max(g, (Zy(), bz(Tye), $wnd.Math.abs(m - f2) <= Tye || m == f2 || isNaN(m) && isNaN(f2) ? 0 : n / (f2 - m))); + } + k = d; + m = f2; + l = e; + } + if (!!a.C && a.C.a > 0) { + n = l + a.C.a; + j && (n += k.d.a); + g = $wnd.Math.max(g, (Zy(), bz(Tye), $wnd.Math.abs(m - 1) <= Tye || m == 1 || isNaN(m) && isNaN(1) ? 0 : n / (1 - m))); + } + c2.n.d = 0; + c2.a.b = g; + } + function L8c(a, b, c2, d, e, f2, g, h) { + var i2, j, k, l, m, n, o2, p, q, r; + o2 = false; + j = dad(c2.q, b.f + b.b - c2.q.f); + n = d.f > b.b && h; + r = e - (c2.q.e + j - g); + l = (i2 = S9c(d, r, false), i2.a); + if (n && l > d.f) { + return false; + } + if (n) { + m = 0; + for (q = new Anb(b.d); q.a < q.c.c.length; ) { + p = RD(ynb(q), 315); + m += dad(p, d.f) + g; + } + r = e - m; + } + if (r < d.g) { + return false; + } + k = f2 == a.c.length - 1 && r >= (tFb(f2, a.c.length), RD(a.c[f2], 186)).e; + if (!n && l > b.b && !k) { + return false; + } + if (k || n || l <= b.b) { + if (k && l > b.b) { + c2.d = l; + Q9c(c2, P9c(c2, l)); + } else { + ead(c2.q, j); + c2.c = true; + } + Q9c(d, e - (c2.s + c2.r)); + U9c(d, c2.q.e + c2.q.d, b.f); + Cad(b, d); + if (a.c.length > f2) { + Fad((tFb(f2, a.c.length), RD(a.c[f2], 186)), d); + (tFb(f2, a.c.length), RD(a.c[f2], 186)).a.c.length == 0 && Xmb(a, f2); + } + o2 = true; + } + return o2; + } + function zJc(a, b, c2) { + var d, e, f2, g, h, i2; + this.g = a; + h = b.d.length; + i2 = c2.d.length; + this.d = $C(jR, WAe, 10, h + i2, 0, 1); + for (g = 0; g < h; g++) { + this.d[g] = b.d[g]; + } + for (f2 = 0; f2 < i2; f2++) { + this.d[h + f2] = c2.d[f2]; + } + if (b.e) { + this.e = gv(b.e); + this.e.Mc(c2); + if (c2.e) { + for (e = c2.e.Kc(); e.Ob(); ) { + d = RD(e.Pb(), 239); + if (d == b) { + continue; + } else + this.e.Hc(d) ? --d.c : this.e.Fc(d); + } + } + } else if (c2.e) { + this.e = gv(c2.e); + this.e.Mc(b); + } + this.f = b.f + c2.f; + this.a = b.a + c2.a; + this.a > 0 ? xJc(this, this.f / this.a) : pJc(b.g, b.d[0]).a != null && pJc(c2.g, c2.d[0]).a != null ? xJc(this, (Kfb(pJc(b.g, b.d[0]).a) + Kfb(pJc(c2.g, c2.d[0]).a)) / 2) : pJc(b.g, b.d[0]).a != null ? xJc(this, pJc(b.g, b.d[0]).a) : pJc(c2.g, c2.d[0]).a != null && xJc(this, pJc(c2.g, c2.d[0]).a); + } + function DXb(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l; + a.a = new fYb(wsb(s3)); + for (d = new Anb(b.a); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 855); + h = new iYb(cD(WC(bQ, 1), rve, 86, 0, [])); + Rmb(a.a.a, h); + for (j = new Anb(c2.d); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 116); + k = new IXb(a, i2); + CXb(k, RD(mQb(c2.c, (Ywc(), ewc)), 21)); + if (!Ujb(a.g, c2)) { + Zjb(a.g, c2, new rjd(i2.c, i2.d)); + Zjb(a.f, c2, k); + } + Rmb(a.a.b, k); + gYb(h, k); + } + for (g = new Anb(c2.b); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 602); + k = new IXb(a, f2.Df()); + Zjb(a.b, f2, new Ptd(h, k)); + CXb(k, RD(mQb(c2.c, (Ywc(), ewc)), 21)); + if (f2.Bf()) { + l = new JXb(a, f2.Bf(), 1); + CXb(l, RD(mQb(c2.c, ewc), 21)); + e = new iYb(cD(WC(bQ, 1), rve, 86, 0, [])); + gYb(e, l); + Rc(a.c, f2.Af(), new Ptd(h, l)); + } + } + } + return a.a; + } + function gFc(a) { + var b; + this.a = a; + b = (r3b(), cD(WC(hR, 1), jwe, 273, 0, [p3b, o3b, m3b, q3b, n3b, l3b])).length; + this.b = YC(V5, [Nve, kEe], [601, 149], 0, [b, b], 2); + this.c = YC(V5, [Nve, kEe], [601, 149], 0, [b, b], 2); + fFc(this, p3b, (yCc(), bCc), cCc); + dFc(this, p3b, o3b, WBc, XBc); + cFc(this, p3b, q3b, WBc); + cFc(this, p3b, m3b, WBc); + dFc(this, p3b, n3b, bCc, cCc); + fFc(this, o3b, TBc, UBc); + cFc(this, o3b, q3b, TBc); + cFc(this, o3b, m3b, TBc); + dFc(this, o3b, n3b, WBc, XBc); + eFc(this, q3b, TBc); + cFc(this, q3b, m3b, TBc); + cFc(this, q3b, n3b, $Bc); + eFc(this, m3b, fCc); + dFc(this, m3b, n3b, aCc, _Bc); + fFc(this, n3b, TBc, TBc); + fFc(this, l3b, TBc, UBc); + dFc(this, l3b, p3b, WBc, XBc); + dFc(this, l3b, n3b, WBc, XBc); + dFc(this, l3b, o3b, WBc, XBc); + } + function zge(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q; + g = c2.Lk(); + if (ZD(g, 102) && (RD(g, 19).Bb & txe) != 0) { + m = RD(c2.md(), 54); + p = Vvd(a.e, m); + if (p != m) { + k = oke(g, p); + MHd(a, b, Tge(a, b, k)); + l = null; + if (Mvd(a.e)) { + d = Eee((lke(), jke), a.e.Dh(), g); + if (d != vYd(a.e.Dh(), a.c)) { + q = pke(a.e.Dh(), g); + h = 0; + f2 = RD(a.g, 124); + for (i2 = 0; i2 < b; ++i2) { + e = f2[i2]; + q.am(e.Lk()) && ++h; + } + l = new lle(a.e, 9, d, m, p, h, false); + l.nj(new P3d(a.e, 9, a.c, c2, k, b, false)); + } + } + o2 = RD(g, 19); + n = Z5d(o2); + if (n) { + l = m.Th(a.e, BYd(m.Dh(), n), null, l); + l = RD(p, 54).Rh(a.e, BYd(p.Dh(), n), null, l); + } else if ((o2.Bb & QHe) != 0) { + j = -1 - BYd(a.e.Dh(), o2); + l = m.Th(a.e, j, null, null); + !RD(p, 54).Ph() && (l = RD(p, 54).Rh(a.e, j, null, l)); + } + !!l && l.oj(); + return k; + } + } + return c2; + } + function SId(a) { + var b, c2, d; + wgd(LId, cD(WC(B2, 1), rve, 134, 0, [new vmd()])); + c2 = new NB(a); + for (d = 0; d < c2.a.length; ++d) { + b = JB(c2, d).te().a; + lhb(b, "layered") ? wgd(LId, cD(WC(B2, 1), rve, 134, 0, [new Pzc()])) : lhb(b, "force") ? wgd(LId, cD(WC(B2, 1), rve, 134, 0, [new PUb()])) : lhb(b, "stress") ? wgd(LId, cD(WC(B2, 1), rve, 134, 0, [new RVb()])) : lhb(b, "mrtree") ? wgd(LId, cD(WC(B2, 1), rve, 134, 0, [new C$c()])) : lhb(b, "radial") ? wgd(LId, cD(WC(B2, 1), rve, 134, 0, [new E4c()])) : lhb(b, "disco") ? wgd(LId, cD(WC(B2, 1), rve, 134, 0, [new ZHb(), new fSb()])) : lhb(b, "sporeOverlap") || lhb(b, "sporeCompaction") ? wgd(LId, cD(WC(B2, 1), rve, 134, 0, [new Lcd()])) : lhb(b, "rectpacking") && wgd(LId, cD(WC(B2, 1), rve, 134, 0, [new v7c()])); + } + } + function r2b(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r; + m = new sjd(a.o); + r = b.a / m.a; + h = b.b / m.b; + p = b.a - m.a; + f2 = b.b - m.b; + if (c2) { + e = dE(mQb(a, (yCc(), BBc))) === dE((Bod(), wod)); + for (o2 = new Anb(a.j); o2.a < o2.c.c.length; ) { + n = RD(ynb(o2), 12); + switch (n.j.g) { + case 1: + e || (n.n.a *= r); + break; + case 2: + n.n.a += p; + e || (n.n.b *= h); + break; + case 3: + e || (n.n.a *= r); + n.n.b += f2; + break; + case 4: + e || (n.n.b *= h); + } + } + } + for (j = new Anb(a.b); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 72); + k = i2.n.a + i2.o.a / 2; + l = i2.n.b + i2.o.b / 2; + q = k / m.a; + g = l / m.b; + if (q + g >= 1) { + if (q - g > 0 && l >= 0) { + i2.n.a += p; + i2.n.b += f2 * g; + } else if (q - g < 0 && k >= 0) { + i2.n.a += p * q; + i2.n.b += f2; + } + } + } + a.o.a = b.a; + a.o.b = b.b; + pQb(a, (yCc(), lBc), (Qpd(), d = RD(mfb(H3), 9), new Fsb(d, RD(WEb(d, d.length), 9), 0))); + } + function ISd(a, b, c2, d, e, f2) { + var g; + if (!(b == null || !mSd(b, ZRd, $Rd))) { + throw Adb(new agb("invalid scheme: " + b)); + } + if (!a && !(c2 != null && qhb(c2, Fhb(35)) == -1 && c2.length > 0 && (BFb(0, c2.length), c2.charCodeAt(0) != 47))) { + throw Adb(new agb("invalid opaquePart: " + c2)); + } + if (a && !(b != null && tpb(eSd, b.toLowerCase())) && !(c2 == null || !mSd(c2, aSd, bSd))) { + throw Adb(new agb(NJe + c2)); + } + if (a && b != null && tpb(eSd, b.toLowerCase()) && !ESd(c2)) { + throw Adb(new agb(NJe + c2)); + } + if (!FSd(d)) { + throw Adb(new agb("invalid device: " + d)); + } + if (!HSd(e)) { + g = e == null ? "invalid segments: null" : "invalid segment: " + tSd(e); + throw Adb(new agb(g)); + } + if (!(f2 == null || qhb(f2, Fhb(35)) == -1)) { + throw Adb(new agb("invalid query: " + f2)); + } + } + function WHc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r; + c2.Ug("Network simplex layering", 1); + a.b = b; + r = RD(mQb(b, (yCc(), gCc)), 17).a * 4; + q = a.b.a; + if (q.c.length < 1) { + c2.Vg(); + return; + } + f2 = SHc(a, q); + p = null; + for (e = Sub(f2, 0); e.b != e.d.c; ) { + d = RD(evb(e), 15); + h = r * eE($wnd.Math.sqrt(d.gc())); + g = VHc(d); + lJb(yJb(AJb(zJb(CJb(g), h), p), true), c2.eh(1)); + m = a.b.b; + for (o2 = new Anb(g.a); o2.a < o2.c.c.length; ) { + n = RD(ynb(o2), 125); + while (m.c.length <= n.e) { + Qmb(m, m.c.length, new R4b(a.b)); + } + k = RD(n.f, 10); + g3b(k, RD(Vmb(m, n.e), 30)); + } + if (f2.b > 1) { + p = $C(kE, Pwe, 28, a.b.b.c.length, 15, 1); + l = 0; + for (j = new Anb(a.b.b); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 30); + p[l++] = i2.a.c.length; + } + } + } + q.c.length = 0; + a.a = null; + a.b = null; + a.c = null; + c2.Vg(); + } + function tMc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l; + k = new bnb(); + l = new wmb(); + f2 = null; + e = 0; + for (d = 0; d < b.length; ++d) { + c2 = b[d]; + vMc(f2, c2) && (e = oMc(a, l, k, cMc, e)); + nQb(c2, (Ywc(), pwc)) && (f2 = RD(mQb(c2, pwc), 10)); + switch (c2.k.g) { + case 0: + for (i2 = lr(dr(b3b(c2, (qpd(), Yod)), new eNc())); xc(i2); ) { + g = RD(yc(i2), 12); + a.d[g.p] = e++; + ZEb(k.c, g); + } + e = oMc(a, l, k, cMc, e); + for (j = lr(dr(b3b(c2, npd), new eNc())); xc(j); ) { + g = RD(yc(j), 12); + a.d[g.p] = e++; + ZEb(k.c, g); + } + break; + case 3: + if (!b3b(c2, bMc).dc()) { + g = RD(b3b(c2, bMc).Xb(0), 12); + a.d[g.p] = e++; + ZEb(k.c, g); + } + b3b(c2, cMc).dc() || hmb(l, c2); + break; + case 1: + for (h = b3b(c2, (qpd(), ppd)).Kc(); h.Ob(); ) { + g = RD(h.Pb(), 12); + a.d[g.p] = e++; + ZEb(k.c, g); + } + b3b(c2, Xod).Jc(new cNc(l, c2)); + } + } + oMc(a, l, k, cMc, e); + return k; + } + function vgd(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2; + if (b == null || b.length == 0) { + return null; + } + f2 = RD(Xjb(a.f, b), 23); + if (!f2) { + for (e = (n = new glb(a.d).a.vc().Kc(), new llb(n)); e.a.Ob(); ) { + c2 = (g = RD(e.a.Pb(), 44), RD(g.md(), 23)); + h = c2.f; + o2 = b.length; + if (lhb(h.substr(h.length - o2, o2), b) && (b.length == h.length || ihb(h, h.length - b.length - 1) == 46)) { + if (f2) { + return null; + } + f2 = c2; + } + } + if (!f2) { + for (d = (m = new glb(a.d).a.vc().Kc(), new llb(m)); d.a.Ob(); ) { + c2 = (g = RD(d.a.Pb(), 44), RD(g.md(), 23)); + l = c2.g; + if (l != null) { + for (i2 = l, j = 0, k = i2.length; j < k; ++j) { + h = i2[j]; + o2 = b.length; + if (lhb(h.substr(h.length - o2, o2), b) && (b.length == h.length || ihb(h, h.length - b.length - 1) == 46)) { + if (f2) { + return null; + } + f2 = c2; + } + } + } + } + } + !!f2 && $jb(a.f, b, f2); + } + return f2; + } + function IA(a, b) { + var c2, d, e, f2, g; + c2 = new cib(); + g = false; + for (f2 = 0; f2 < b.length; f2++) { + d = (BFb(f2, b.length), b.charCodeAt(f2)); + if (d == 32) { + wA(a, c2, 0); + c2.a += " "; + wA(a, c2, 0); + while (f2 + 1 < b.length && (BFb(f2 + 1, b.length), b.charCodeAt(f2 + 1) == 32)) { + ++f2; + } + continue; + } + if (g) { + if (d == 39) { + if (f2 + 1 < b.length && (BFb(f2 + 1, b.length), b.charCodeAt(f2 + 1) == 39)) { + c2.a += String.fromCharCode(d); + ++f2; + } else { + g = false; + } + } else { + c2.a += String.fromCharCode(d); + } + continue; + } + if (qhb("GyMLdkHmsSEcDahKzZv", Fhb(d)) > 0) { + wA(a, c2, 0); + c2.a += String.fromCharCode(d); + e = BA(b, f2); + wA(a, c2, e); + f2 += e - 1; + continue; + } + if (d == 39) { + if (f2 + 1 < b.length && (BFb(f2 + 1, b.length), b.charCodeAt(f2 + 1) == 39)) { + c2.a += "'"; + ++f2; + } else { + g = true; + } + } else { + c2.a += String.fromCharCode(d); + } + } + wA(a, c2, 0); + CA(a); + } + function tSc(a, b, c2, d, e) { + var f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t; + t = Yx(a); + i2 = new bnb(); + f2 = a.c.length; + j = f2 - 1; + k = f2 + 1; + while (t.a.gc() != 0) { + while (c2.b != 0) { + r = (sFb(c2.b != 0), RD(Wub(c2, c2.a.a), 118)); + t.a.Bc(r) != null; + r.g = j--; + wSc(r, b, c2, d); + } + while (b.b != 0) { + s = (sFb(b.b != 0), RD(Wub(b, b.a.a), 118)); + t.a.Bc(s) != null; + s.g = k++; + wSc(s, b, c2, d); + } + h = qwe; + for (p = t.a.ec().Kc(); p.Ob(); ) { + o2 = RD(p.Pb(), 118); + if (!d && o2.b > 0 && o2.a <= 0) { + i2.c.length = 0; + ZEb(i2.c, o2); + break; + } + n = o2.i - o2.d; + if (n >= h) { + if (n > h) { + i2.c.length = 0; + h = n; + } + ZEb(i2.c, o2); + } + } + if (i2.c.length != 0) { + g = RD(Vmb(i2, Jwb(e, i2.c.length)), 118); + t.a.Bc(g) != null; + g.g = k++; + wSc(g, b, c2, d); + i2.c.length = 0; + } + } + q = a.c.length + 1; + for (m = new Anb(a); m.a < m.c.c.length; ) { + l = RD(ynb(m), 118); + l.g < f2 && (l.g = l.g + q); + } + } + function FJc(a, b, c2) { + var d, e, f2, g; + this.j = a; + this.e = c1b(a); + this.o = this.j.e; + this.i = !!this.o; + this.p = this.i ? RD(Vmb(c2, Y2b(this.o).p), 219) : null; + e = RD(mQb(a, (Ywc(), kwc)), 21); + this.g = e.Hc((ovc(), hvc)); + this.b = new bnb(); + this.d = new RLc(this.e); + g = RD(mQb(this.j, Lwc), 234); + this.q = WJc(b, g, this.e); + this.k = new _Kc(this); + f2 = dv(cD(WC(QY, 1), rve, 230, 0, [this, this.d, this.k, this.q])); + if (b == (RKc(), OKc) && !Heb(TD(mQb(a, (yCc(), eAc))))) { + d = new qJc(this.e); + ZEb(f2.c, d); + this.c = new UIc(d, g, RD(this.q, 413)); + } else if (b == OKc && Heb(TD(mQb(a, (yCc(), eAc))))) { + d = new qJc(this.e); + ZEb(f2.c, d); + this.c = new vLc(d, g, RD(this.q, 413)); + } else { + this.c = new smc(b, this); + } + Rmb(f2, this.c); + yNc(f2, this.e); + this.s = $Kc(this.k); + } + function z0b(a, b, c2, d, e) { + var f2, g, h, i2, j, k, l, m, n, o2, p, q; + f2 = new bnb(); + for (j = new Anb(d); j.a < j.c.c.length; ) { + h = RD(ynb(j), 453); + g = null; + if (h.f == (BEc(), zEc)) { + for (o2 = new Anb(h.e); o2.a < o2.c.c.length; ) { + n = RD(ynb(o2), 18); + q = n.d.i; + if (Y2b(q) == b) { + q0b(a, b, h, n, h.b, n.d); + } else if (!c2 || n2b(q, c2)) { + r0b(a, b, h, d, n); + } else { + m = w0b(a, b, c2, n, h.b, zEc, g); + m != g && (ZEb(f2.c, m), true); + m.c && (g = m); + } + } + } else { + for (l = new Anb(h.e); l.a < l.c.c.length; ) { + k = RD(ynb(l), 18); + p = k.c.i; + if (Y2b(p) == b) { + q0b(a, b, h, k, k.c, h.b); + } else if (!c2 || n2b(p, c2)) { + continue; + } else { + m = w0b(a, b, c2, k, h.b, yEc, g); + m != g && (ZEb(f2.c, m), true); + m.c && (g = m); + } + } + } + } + for (i2 = new Anb(f2); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 453); + Wmb(b.a, h.a, 0) != -1 || Rmb(b.a, h.a); + h.c && (ZEb(e.c, h), true); + } + } + function QXb(a) { + var b, c2, d, e, f2, g, h; + b = 0; + for (f2 = new Anb(a.b.a); f2.a < f2.c.c.length; ) { + d = RD(ynb(f2), 194); + d.b = 0; + d.c = 0; + } + PXb(a, 0); + OXb(a, a.g); + uYb(a.c); + yYb(a.c); + c2 = (Cmd(), ymd); + wYb(qYb(vYb(wYb(qYb(vYb(wYb(vYb(a.c, c2)), Fmd(c2)))), c2))); + vYb(a.c, ymd); + TXb(a, a.g); + UXb(a, 0); + VXb(a, 0); + WXb(a, 1); + PXb(a, 1); + OXb(a, a.d); + uYb(a.c); + for (g = new Anb(a.b.a); g.a < g.c.c.length; ) { + d = RD(ynb(g), 194); + b += $wnd.Math.abs(d.c); + } + for (h = new Anb(a.b.a); h.a < h.c.c.length; ) { + d = RD(ynb(h), 194); + d.b = 0; + d.c = 0; + } + c2 = Bmd; + wYb(qYb(vYb(wYb(qYb(vYb(wYb(yYb(vYb(a.c, c2))), Fmd(c2)))), c2))); + vYb(a.c, ymd); + TXb(a, a.d); + UXb(a, 1); + VXb(a, 1); + WXb(a, 0); + yYb(a.c); + for (e = new Anb(a.b.a); e.a < e.c.c.length; ) { + d = RD(ynb(e), 194); + b += $wnd.Math.abs(d.c); + } + return b; + } + function A0b(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q; + if (!Heb(TD(mQb(c2, (yCc(), NAc))))) { + return; + } + for (h = new Anb(c2.j); h.a < h.c.c.length; ) { + g = RD(ynb(h), 12); + m = s2b(g.g); + for (j = m, k = 0, l = j.length; k < l; ++k) { + i2 = j[k]; + f2 = i2.d.i == c2; + e = f2 && Heb(TD(mQb(i2, OAc))); + if (e) { + o2 = i2.c; + n = RD(Wjb(a.b, o2), 10); + if (!n) { + n = f2b(o2, (Bod(), zod), o2.j, -1, null, null, o2.o, RD(mQb(b, rAc), 88), b); + pQb(n, (Ywc(), Awc), o2); + Zjb(a.b, o2, n); + Rmb(b.a, n); + } + q = i2.d; + p = RD(Wjb(a.b, q), 10); + if (!p) { + p = f2b(q, (Bod(), zod), q.j, 1, null, null, q.o, RD(mQb(b, rAc), 88), b); + pQb(p, (Ywc(), Awc), q); + Zjb(a.b, q, p); + Rmb(b.a, p); + } + d = s0b(i2); + Y0b(d, RD(Vmb(n.j, 0), 12)); + Z0b(d, RD(Vmb(p.j, 0), 12)); + Rc(a.a, i2, new J0b(d, b, (BEc(), zEc))); + RD(mQb(b, (Ywc(), kwc)), 21).Fc((ovc(), hvc)); + } + } + } + } + function OQc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m; + for (e = new Anb(a.a.b); e.a < e.c.c.length; ) { + c2 = RD(ynb(e), 30); + for (i2 = new Anb(c2.a); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 10); + b.j[h.p] = h; + b.i[h.p] = b.o == (EQc(), DQc) ? pxe : oxe; + } + } + akb(a.c); + g = a.a.b; + b.c == (wQc(), uQc) && (g = hv(g)); + sRc(a.e, b, a.b); + Mnb(b.p, null); + for (f2 = g.Kc(); f2.Ob(); ) { + c2 = RD(f2.Pb(), 30); + j = c2.a; + b.o == (EQc(), DQc) && (j = hv(j)); + for (m = j.Kc(); m.Ob(); ) { + l = RD(m.Pb(), 10); + b.g[l.p] == l && PQc(a, l, b); + } + } + QQc(a, b); + for (d = g.Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 30); + for (m = new Anb(c2.a); m.a < m.c.c.length; ) { + l = RD(ynb(m), 10); + b.p[l.p] = b.p[b.g[l.p].p]; + if (l == b.g[l.p]) { + k = Kfb(b.i[b.j[l.p].p]); + (b.o == (EQc(), DQc) && k > pxe || b.o == CQc && k < oxe) && (b.p[l.p] = Kfb(b.p[l.p]) + k); + } + } + } + a.e.xg(); + } + function ldc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2; + c2.Ug("Label dummy switching", 1); + d = RD(mQb(b, (yCc(), uAc)), 232); + $cc(b); + e = idc(b, d); + a.a = $C(iE, vxe, 28, b.b.c.length, 15, 1); + for (h = (btc(), cD(WC(ZW, 1), jwe, 232, 0, [Zsc, _sc, Ysc, $sc, atc, Xsc])), k = 0, n = h.length; k < n; ++k) { + f2 = h[k]; + if ((f2 == atc || f2 == Xsc || f2 == $sc) && !RD(Csb(e.a, f2) ? e.b[f2.g] : null, 15).dc()) { + bdc(a, b); + break; + } + } + for (i2 = cD(WC(ZW, 1), jwe, 232, 0, [Zsc, _sc, Ysc, $sc, atc, Xsc]), l = 0, o2 = i2.length; l < o2; ++l) { + f2 = i2[l]; + f2 == atc || f2 == Xsc || f2 == $sc || mdc(a, RD(Csb(e.a, f2) ? e.b[f2.g] : null, 15)); + } + for (g = cD(WC(ZW, 1), jwe, 232, 0, [Zsc, _sc, Ysc, $sc, atc, Xsc]), j = 0, m = g.length; j < m; ++j) { + f2 = g[j]; + (f2 == atc || f2 == Xsc || f2 == $sc) && mdc(a, RD(Csb(e.a, f2) ? e.b[f2.g] : null, 15)); + } + a.a = null; + c2.Vg(); + } + function tte(a, b) { + var c2, d, e, f2, g, h, i2, j, k; + j = b; + if (j.b == null || a.b == null) + return; + vte(a); + ste(a); + vte(j); + ste(j); + c2 = $C(kE, Pwe, 28, a.b.length + j.b.length, 15, 1); + k = 0; + d = 0; + g = 0; + while (d < a.b.length && g < j.b.length) { + e = a.b[d]; + f2 = a.b[d + 1]; + h = j.b[g]; + i2 = j.b[g + 1]; + if (f2 < h) { + d += 2; + } else if (f2 >= h && e <= i2) { + if (h <= e && f2 <= i2) { + c2[k++] = e; + c2[k++] = f2; + d += 2; + } else if (h <= e) { + c2[k++] = e; + c2[k++] = i2; + a.b[d] = i2 + 1; + g += 2; + } else if (f2 <= i2) { + c2[k++] = h; + c2[k++] = f2; + d += 2; + } else { + c2[k++] = h; + c2[k++] = i2; + a.b[d] = i2 + 1; + } + } else if (i2 < e) { + g += 2; + } else { + throw Adb(new yz("Token#intersectRanges(): Internal Error: [" + a.b[d] + "," + a.b[d + 1] + "] & [" + j.b[g] + "," + j.b[g + 1] + "]")); + } + } + while (d < a.b.length) { + c2[k++] = a.b[d++]; + c2[k++] = a.b[d++]; + } + a.b = $C(kE, Pwe, 28, k, 15, 1); + hib(c2, 0, a.b, 0, k); + } + function RXb(a) { + var b, c2, d, e, f2, g, h; + b = new bnb(); + a.g = new bnb(); + a.d = new bnb(); + for (g = new vkb(new mkb(a.f.b).a); g.b; ) { + f2 = tkb(g); + Rmb(b, RD(RD(f2.md(), 42).b, 86)); + Dmd(RD(f2.ld(), 602).Af()) ? Rmb(a.d, RD(f2.md(), 42)) : Rmb(a.g, RD(f2.md(), 42)); + } + OXb(a, a.d); + OXb(a, a.g); + a.c = new EYb(a.b); + CYb(a.c, (zXb(), yXb)); + TXb(a, a.d); + TXb(a, a.g); + Tmb(b, a.c.a.b); + a.e = new rjd(oxe, oxe); + a.a = new rjd(pxe, pxe); + for (d = new Anb(b); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 86); + a.e.a = $wnd.Math.min(a.e.a, c2.g.c); + a.e.b = $wnd.Math.min(a.e.b, c2.g.d); + a.a.a = $wnd.Math.max(a.a.a, c2.g.c + c2.g.b); + a.a.b = $wnd.Math.max(a.a.b, c2.g.d + c2.g.a); + } + BYb(a.c, new $Xb()); + h = 0; + do { + e = QXb(a); + ++h; + } while ((h < 2 || e > pwe) && h < 10); + BYb(a.c, new bYb()); + QXb(a); + xYb(a.c); + AXb(a.f); + } + function B9b(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p; + c2 = RD(mQb(a, (yCc(), BBc)), 101); + g = a.f; + f2 = a.d; + h = g.a + f2.b + f2.c; + i2 = 0 - f2.d - a.c.b; + k = g.b + f2.d + f2.a - a.c.b; + j = new bnb(); + l = new bnb(); + for (e = new Anb(b); e.a < e.c.c.length; ) { + d = RD(ynb(e), 10); + switch (c2.g) { + case 1: + case 2: + case 3: + r9b(d); + break; + case 4: + m = RD(mQb(d, zBc), 8); + n = !m ? 0 : m.a; + d.n.a = h * Kfb(UD(mQb(d, (Ywc(), Jwc)))) - n; + U2b(d, true, false); + break; + case 5: + o2 = RD(mQb(d, zBc), 8); + p = !o2 ? 0 : o2.a; + d.n.a = Kfb(UD(mQb(d, (Ywc(), Jwc)))) - p; + U2b(d, true, false); + g.a = $wnd.Math.max(g.a, d.n.a + d.o.a / 2); + } + switch (RD(mQb(d, (Ywc(), hwc)), 64).g) { + case 1: + d.n.b = i2; + ZEb(j.c, d); + break; + case 3: + d.n.b = k; + ZEb(l.c, d); + } + } + switch (c2.g) { + case 1: + case 2: + t9b(j, a); + t9b(l, a); + break; + case 3: + z9b(j, a); + z9b(l, a); + } + } + function $Jc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m; + switch (a.k.g) { + case 1: + d = RD(mQb(a, (Ywc(), Awc)), 18); + c2 = RD(mQb(d, Bwc), 75); + !c2 ? c2 = new Ejd() : Heb(TD(mQb(d, Nwc))) && (c2 = Ijd(c2)); + j = RD(mQb(a, vwc), 12); + if (j) { + k = xjd(cD(WC(l3, 1), Nve, 8, 0, [j.i.n, j.n, j.a])); + if (b <= k.a) { + return k.b; + } + Pub(c2, k, c2.a, c2.a.a); + } + l = RD(mQb(a, wwc), 12); + if (l) { + m = xjd(cD(WC(l3, 1), Nve, 8, 0, [l.i.n, l.n, l.a])); + if (m.a <= b) { + return m.b; + } + Pub(c2, m, c2.c.b, c2.c); + } + if (c2.b >= 2) { + i2 = Sub(c2, 0); + g = RD(evb(i2), 8); + h = RD(evb(i2), 8); + while (h.a < b && i2.b != i2.d.c) { + g = h; + h = RD(evb(i2), 8); + } + return g.b + (b - g.a) / (h.a - g.a) * (h.b - g.b); + } + break; + case 3: + f2 = RD(mQb(RD(Vmb(a.j, 0), 12), (Ywc(), Awc)), 12); + e = f2.i; + switch (f2.j.g) { + case 1: + return e.n.b; + case 3: + return e.n.b + e.o.b; + } + } + return _2b(a).b; + } + function Akc(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l; + for (g = new Anb(a.d.b); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 30); + for (i2 = new Anb(f2.a); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 10); + if (Heb(TD(mQb(h, (yCc(), Uzc))))) { + if (!gr(W2b(h))) { + d = RD(er2(W2b(h)), 18); + k = d.c.i; + k == h && (k = d.d.i); + l = new Ptd(k, ojd(ajd(h.n), k.n)); + Zjb(a.b, h, l); + continue; + } + } + e = new Uid2(h.n.a - h.d.b, h.n.b - h.d.d, h.o.a + h.d.b + h.d.c, h.o.b + h.d.d + h.d.a); + b = mGb(pGb(nGb(oGb(new qGb(), h), e), jkc), a.a); + gGb(hGb(iGb(new jGb(), cD(WC(hN, 1), rve, 60, 0, [b])), b), a.a); + j = new cHb(); + Zjb(a.e, b, j); + c2 = Kr(new is(Mr(Z2b(h).a.Kc(), new ir()))) - Kr(new is(Mr(a3b(h).a.Kc(), new ir()))); + c2 < 0 ? aHb(j, true, (Cmd(), ymd)) : c2 > 0 && aHb(j, true, (Cmd(), zmd)); + h.k == (r3b(), m3b) && bHb(j); + Zjb(a.f, h, b); + } + } + } + function OVc(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u; + e = RD(mQb(a, (q$c(), h$c)), 27); + j = lve; + k = lve; + h = qwe; + i2 = qwe; + for (t = Sub(a.b, 0); t.b != t.d.c; ) { + r = RD(evb(t), 40); + n = r.e; + o2 = r.f; + j = $wnd.Math.min(j, n.a - o2.a / 2); + k = $wnd.Math.min(k, n.b - o2.b / 2); + h = $wnd.Math.max(h, n.a + o2.a / 2); + i2 = $wnd.Math.max(i2, n.b + o2.b / 2); + } + m = RD(Gxd(e, (h_c(), T$c)), 107); + for (s = Sub(a.b, 0); s.b != s.d.c; ) { + r = RD(evb(s), 40); + l = mQb(r, h$c); + if (ZD(l, 207)) { + f2 = RD(l, 27); + Byd(f2, r.e.a, r.e.b); + zxd(f2, r); + } + } + for (q = Sub(a.a, 0); q.b != q.d.c; ) { + p = RD(evb(q), 65); + d = RD(mQb(p, h$c), 74); + if (d) { + b = p.a; + c2 = IGd(d, true, true); + lsd(b, c2); + } + } + u = h - j + (m.b + m.c); + g = i2 - k + (m.d + m.a); + Heb(TD(Gxd(e, (umd(), mld)))) || Esd(e, u, g, false, false); + Ixd(e, Ikd, u - (m.b + m.c)); + Ixd(e, Hkd, g - (m.d + m.a)); + } + function Wec(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l; + i2 = true; + e = 0; + j = a.g[b.p]; + k = b.o.b + a.o; + c2 = a.d[b.p][2]; + $mb(a.b, j, sgb(RD(Vmb(a.b, j), 17).a - 1 + c2)); + $mb(a.c, j, Kfb(UD(Vmb(a.c, j))) - k + c2 * a.f); + ++j; + if (j >= a.j) { + ++a.j; + Rmb(a.b, sgb(1)); + Rmb(a.c, k); + } else { + d = a.d[b.p][1]; + $mb(a.b, j, sgb(RD(Vmb(a.b, j), 17).a + 1 - d)); + $mb(a.c, j, Kfb(UD(Vmb(a.c, j))) + k - d * a.f); + } + (a.r == (aEc(), VDc) && (RD(Vmb(a.b, j), 17).a > a.k || RD(Vmb(a.b, j - 1), 17).a > a.k) || a.r == YDc && (Kfb(UD(Vmb(a.c, j))) > a.n || Kfb(UD(Vmb(a.c, j - 1))) > a.n)) && (i2 = false); + for (g = new is(Mr(Z2b(b).a.Kc(), new ir())); gs(g); ) { + f2 = RD(hs(g), 18); + h = f2.c.i; + if (a.g[h.p] == j) { + l = Wec(a, h); + e = e + RD(l.a, 17).a; + i2 = i2 && Heb(TD(l.b)); + } + } + a.g[b.p] = j; + e = e + a.d[b.p][0]; + return new Ptd(sgb(e), (Geb(), i2 ? true : false)); + } + function cXb(a, b) { + var c2, d, e, f2, g; + c2 = Kfb(UD(mQb(b, (yCc(), TBc)))); + c2 < 2 && pQb(b, TBc, 2); + d = RD(mQb(b, rAc), 88); + d == (Cmd(), Amd) && pQb(b, rAc, i2b(b)); + e = RD(mQb(b, NBc), 17); + e.a == 0 ? pQb(b, (Ywc(), Lwc), new Owb()) : pQb(b, (Ywc(), Lwc), new Pwb(e.a)); + f2 = TD(mQb(b, gBc)); + f2 == null && pQb(b, gBc, (Geb(), dE(mQb(b, yAc)) === dE((Ymd(), Umd)) ? true : false)); + FDb(new SDb(null, new Swb(b.a, 16)), new fXb(a)); + FDb(EDb(new SDb(null, new Swb(b.b, 16)), new hXb()), new jXb(a)); + g = new gFc(b); + pQb(b, (Ywc(), Qwc), g); + Sed(a.a); + Ved(a.a, (sXb(), nXb), RD(mQb(b, pAc), 188)); + Ved(a.a, oXb, RD(mQb(b, $Ac), 188)); + Ved(a.a, pXb, RD(mQb(b, oAc), 188)); + Ved(a.a, qXb, RD(mQb(b, kBc), 188)); + Ved(a.a, rXb, KRc(RD(mQb(b, yAc), 223))); + Ped(a.a, bXb(b)); + pQb(b, Kwc, Qed(a.a, b)); + } + function STc(a, b, c2, d, e) { + var f2, g, h, i2, j, k, l, m, n, o2, p, q, r; + l = new Tsb(); + g = new bnb(); + QTc(a, c2, a.d.Ag(), g, l); + QTc(a, d, a.d.Bg(), g, l); + a.b = 0.2 * (p = RTc(EDb(new SDb(null, new Swb(g, 16)), new XTc())), q = RTc(EDb(new SDb(null, new Swb(g, 16)), new ZTc())), $wnd.Math.min(p, q)); + f2 = 0; + for (h = 0; h < g.c.length - 1; h++) { + i2 = (tFb(h, g.c.length), RD(g.c[h], 118)); + for (o2 = h + 1; o2 < g.c.length; o2++) { + f2 += PTc(a, i2, (tFb(o2, g.c.length), RD(g.c[o2], 118))); + } + } + m = RD(mQb(b, (Ywc(), Lwc)), 234); + f2 >= 2 && (r = uSc(g, true, m), !a.e && (a.e = new xTc(a)), tTc(a.e, r, g, a.b), void 0); + UTc(g, m); + WTc(g); + n = -1; + for (k = new Anb(g); k.a < k.c.c.length; ) { + j = RD(ynb(k), 118); + if ($wnd.Math.abs(j.s - j.c) < Vze) { + continue; + } + n = $wnd.Math.max(n, j.o); + a.d.yg(j, e, a.c); + } + a.d.a.a.$b(); + return n + 1; + } + function s0c(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u; + l = RD(Hr((g = Sub(new dXc(b).a.d, 0), new gXc(g))), 40); + o2 = l ? RD(mQb(l, (q$c(), b$c)), 40) : null; + e = 1; + while (!!l && !!o2) { + i2 = 0; + u = 0; + c2 = l; + d = o2; + for (h = 0; h < e; h++) { + c2 = _Wc(c2); + d = _Wc(d); + u += Kfb(UD(mQb(c2, (q$c(), g$c)))); + i2 += Kfb(UD(mQb(d, g$c))); + } + t = Kfb(UD(mQb(o2, (q$c(), j$c)))); + s = Kfb(UD(mQb(l, j$c))); + m = u0c(a, l, o2); + n = t + i2 + a.b + m - s - u; + if (0 < n) { + j = b; + k = 0; + while (!!j && j != d) { + ++k; + j = RD(mQb(j, c$c), 40); + } + if (j) { + r = n / k; + j = b; + while (j != d) { + q = Kfb(UD(mQb(j, j$c))) + n; + pQb(j, j$c, q); + p = Kfb(UD(mQb(j, g$c))) + n; + pQb(j, g$c, p); + n -= r; + j = RD(mQb(j, c$c), 40); + } + } else { + return; + } + } + ++e; + l.d.b == 0 ? l = kWc(new dXc(b), e) : l = RD(Hr((f2 = Sub(new dXc(l).a.d, 0), new gXc(f2))), 40); + o2 = l ? RD(mQb(l, b$c), 40) : null; + } + } + function Lmc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2; + if (m = a.c[b], n = a.c[c2], (o2 = RD(mQb(m, (Ywc(), qwc)), 15), !!o2 && o2.gc() != 0 && o2.Hc(n)) || (p = m.k != (r3b(), o3b) && n.k != o3b, q = RD(mQb(m, pwc), 10), r = RD(mQb(n, pwc), 10), s = q != r, t = !!q && q != m || !!r && r != n, u = Mmc(m, (qpd(), Yod)), v = Mmc(n, npd), t = t | (Mmc(m, npd) || Mmc(n, Yod)), w2 = t && s || u || v, p && w2) || m.k == (r3b(), q3b) && n.k == p3b || n.k == (r3b(), q3b) && m.k == p3b) { + return false; + } + k = a.c[b]; + f2 = a.c[c2]; + e = jMc(a.e, k, f2, (qpd(), ppd)); + i2 = jMc(a.i, k, f2, Xod); + Cmc(a.f, k, f2); + j = lmc(a.b, k, f2) + RD(e.a, 17).a + RD(i2.a, 17).a + a.f.d; + h = lmc(a.b, f2, k) + RD(e.b, 17).a + RD(i2.b, 17).a + a.f.b; + if (a.a) { + l = RD(mQb(k, Awc), 12); + g = RD(mQb(f2, Awc), 12); + d = hMc(a.g, l, g); + j += RD(d.a, 17).a; + h += RD(d.b, 17).a; + } + return j > h; + } + function Iad(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s; + j = oxe; + k = oxe; + h = pxe; + i2 = pxe; + for (m = new Anb(b.i); m.a < m.c.c.length; ) { + l = RD(ynb(m), 68); + e = RD(RD(Wjb(a.g, l.a), 42).b, 27); + Byd(e, l.b.c, l.b.d); + j = $wnd.Math.min(j, e.i); + k = $wnd.Math.min(k, e.j); + h = $wnd.Math.max(h, e.i + e.g); + i2 = $wnd.Math.max(i2, e.j + e.f); + } + n = RD(Gxd(a.c, (ncd(), ecd)), 107); + Esd(a.c, h - j + (n.b + n.c), i2 - k + (n.d + n.a), true, true); + Isd(a.c, -j + n.b, -k + n.d); + for (d = new dMd(uCd(a.c)); d.e != d.i.gc(); ) { + c2 = RD(bMd(d), 74); + g = IGd(c2, true, true); + o2 = JGd(c2); + q = LGd(c2); + p = new rjd(o2.i + o2.g / 2, o2.j + o2.f / 2); + f2 = new rjd(q.i + q.g / 2, q.j + q.f / 2); + r = ojd(new rjd(f2.a, f2.b), p); + wid(r, o2.g, o2.f); + $id(p, r); + s = ojd(new rjd(p.a, p.b), f2); + wid(s, q.g, q.f); + $id(f2, s); + Nzd(g, p.a, p.b); + Gzd(g, f2.a, f2.b); + } + } + function Tcc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2; + b.Ug("Label dummy removal", 1); + d = Kfb(UD(mQb(a, (yCc(), VBc)))); + e = Kfb(UD(mQb(a, ZBc))); + j = RD(mQb(a, rAc), 88); + for (i2 = new Anb(a.b); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 30); + l = new Jkb(h.a, 0); + while (l.b < l.d.gc()) { + k = (sFb(l.b < l.d.gc()), RD(l.d.Xb(l.c = l.b++), 10)); + if (k.k == (r3b(), n3b)) { + m = RD(mQb(k, (Ywc(), Awc)), 18); + o2 = Kfb(UD(mQb(m, FAc))); + g = dE(mQb(k, swc)) === dE((Pnd(), Mnd)); + c2 = new sjd(k.n); + g && (c2.b += o2 + d); + f2 = new rjd(k.o.a, k.o.b + (k.k == n3b && !QDb(CDb(RD(mQb(k, Mwc), 15).Oc(), new PAb(new x3b()))).Bd((xDb(), wDb)) ? 0 : -o2 - d)); + n = RD(mQb(k, Mwc), 15); + j == (Cmd(), Bmd) || j == xmd ? Scc(n, c2, e, f2, g, j) : Rcc(n, c2, e, f2); + Tmb(m.b, n); + Hec(k, dE(mQb(a, yAc)) === dE((Ymd(), Vmd))); + Ckb(l); + } + } + } + b.Vg(); + } + function ZBd(a) { + if (a.q) + return; + a.q = true; + a.p = jBd(a, 0); + a.a = jBd(a, 1); + oBd(a.a, 0); + a.f = jBd(a, 2); + oBd(a.f, 1); + iBd(a.f, 2); + a.n = jBd(a, 3); + iBd(a.n, 3); + iBd(a.n, 4); + iBd(a.n, 5); + iBd(a.n, 6); + a.g = jBd(a, 4); + oBd(a.g, 7); + iBd(a.g, 8); + a.c = jBd(a, 5); + oBd(a.c, 7); + oBd(a.c, 8); + a.i = jBd(a, 6); + oBd(a.i, 9); + oBd(a.i, 10); + oBd(a.i, 11); + oBd(a.i, 12); + iBd(a.i, 13); + a.j = jBd(a, 7); + oBd(a.j, 9); + a.d = jBd(a, 8); + oBd(a.d, 3); + oBd(a.d, 4); + oBd(a.d, 5); + oBd(a.d, 6); + iBd(a.d, 7); + iBd(a.d, 8); + iBd(a.d, 9); + iBd(a.d, 10); + a.b = jBd(a, 9); + iBd(a.b, 0); + iBd(a.b, 1); + a.e = jBd(a, 10); + iBd(a.e, 1); + iBd(a.e, 2); + iBd(a.e, 3); + iBd(a.e, 4); + oBd(a.e, 5); + oBd(a.e, 6); + oBd(a.e, 7); + oBd(a.e, 8); + oBd(a.e, 9); + oBd(a.e, 10); + iBd(a.e, 11); + a.k = jBd(a, 11); + iBd(a.k, 0); + iBd(a.k, 1); + a.o = kBd(a, 12); + a.s = kBd(a, 13); + } + function CXb(a, b) { + b.dc() && JYb(a.j, true, true, true, true); + pb(b, (qpd(), cpd)) && JYb(a.j, true, true, true, false); + pb(b, Zod) && JYb(a.j, false, true, true, true); + pb(b, kpd) && JYb(a.j, true, true, false, true); + pb(b, mpd) && JYb(a.j, true, false, true, true); + pb(b, dpd) && JYb(a.j, false, true, true, false); + pb(b, $od) && JYb(a.j, false, true, false, true); + pb(b, lpd) && JYb(a.j, true, false, false, true); + pb(b, jpd) && JYb(a.j, true, false, true, false); + pb(b, hpd) && JYb(a.j, true, true, true, true); + pb(b, apd) && JYb(a.j, true, true, true, true); + pb(b, hpd) && JYb(a.j, true, true, true, true); + pb(b, _od) && JYb(a.j, true, true, true, true); + pb(b, ipd) && JYb(a.j, true, true, true, true); + pb(b, gpd) && JYb(a.j, true, true, true, true); + pb(b, fpd) && JYb(a.j, true, true, true, true); + } + function tAd(b, c2, d) { + var e, f2, g, h, i2, j, k, l, m; + if (b.a != c2.jk()) { + throw Adb(new agb(VHe + c2.xe() + WHe)); + } + e = Oee((lke(), jke), c2).Jl(); + if (e) { + return e.jk().wi().ri(e, d); + } + h = Oee(jke, c2).Ll(); + if (h) { + if (d == null) { + return null; + } + i2 = RD(d, 15); + if (i2.dc()) { + return ""; + } + m = new Qhb(); + for (g = i2.Kc(); g.Ob(); ) { + f2 = g.Pb(); + Nhb(m, h.jk().wi().ri(h, f2)); + m.a += " "; + } + return qeb(m, m.a.length - 1); + } + l = Oee(jke, c2).Ml(); + if (!l.dc()) { + for (k = l.Kc(); k.Ob(); ) { + j = RD(k.Pb(), 156); + if (j.fk(d)) { + try { + m = j.jk().wi().ri(j, d); + if (m != null) { + return m; + } + } catch (a) { + a = zdb(a); + if (!ZD(a, 103)) + throw Adb(a); + } + } + } + throw Adb(new agb("Invalid value: '" + d + "' for datatype :" + c2.xe())); + } + RD(c2, 847).ok(); + return d == null ? null : ZD(d, 180) ? "" + RD(d, 180).a : rb(d) == qK ? a2d(nAd[0], RD(d, 206)) : jeb(d); + } + function ZUc(a) { + var b, c2, d, e, f2, g, h, i2, j, k; + j = new Yub(); + h = new Yub(); + for (f2 = new Anb(a); f2.a < f2.c.c.length; ) { + d = RD(ynb(f2), 131); + d.v = 0; + d.n = d.i.c.length; + d.u = d.t.c.length; + d.n == 0 && (Pub(j, d, j.c.b, j.c), true); + d.u == 0 && d.r.a.gc() == 0 && (Pub(h, d, h.c.b, h.c), true); + } + g = -1; + while (j.b != 0) { + d = RD(ku(j, 0), 131); + for (c2 = new Anb(d.t); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 274); + k = b.b; + k.v = $wnd.Math.max(k.v, d.v + 1); + g = $wnd.Math.max(g, k.v); + --k.n; + k.n == 0 && (Pub(j, k, j.c.b, j.c), true); + } + } + if (g > -1) { + for (e = Sub(h, 0); e.b != e.d.c; ) { + d = RD(evb(e), 131); + d.v = g; + } + while (h.b != 0) { + d = RD(ku(h, 0), 131); + for (c2 = new Anb(d.i); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 274); + i2 = b.a; + if (i2.r.a.gc() != 0) { + continue; + } + i2.v = $wnd.Math.min(i2.v, d.v - 1); + --i2.u; + i2.u == 0 && (Pub(h, i2, h.c.b, h.c), true); + } + } + } + } + function WTc(a) { + var b, c2, d, e, f2, g, h, i2, j, k; + j = new bnb(); + h = new bnb(); + for (g = new Anb(a); g.a < g.c.c.length; ) { + e = RD(ynb(g), 118); + PSc(e, e.f.c.length); + QSc(e, e.k.c.length); + e.d == 0 && (ZEb(j.c, e), true); + e.i == 0 && e.e.b == 0 && (ZEb(h.c, e), true); + } + d = -1; + while (j.c.length != 0) { + e = RD(Xmb(j, 0), 118); + for (c2 = new Anb(e.k); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 132); + k = b.b; + RSc(k, $wnd.Math.max(k.o, e.o + 1)); + d = $wnd.Math.max(d, k.o); + PSc(k, k.d - 1); + k.d == 0 && (ZEb(j.c, k), true); + } + } + if (d > -1) { + for (f2 = new Anb(h); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 118); + e.o = d; + } + while (h.c.length != 0) { + e = RD(Xmb(h, 0), 118); + for (c2 = new Anb(e.f); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 132); + i2 = b.a; + if (i2.e.b > 0) { + continue; + } + RSc(i2, $wnd.Math.min(i2.o, e.o - 1)); + QSc(i2, i2.i - 1); + i2.i == 0 && (ZEb(h.c, i2), true); + } + } + } + } + function Lid(a, b, c2, d, e) { + var f2, g, h, i2; + i2 = oxe; + g = false; + h = Gid(a, ojd(new rjd(b.a, b.b), a), $id(new rjd(c2.a, c2.b), e), ojd(new rjd(d.a, d.b), c2)); + f2 = !!h && !($wnd.Math.abs(h.a - a.a) <= IGe && $wnd.Math.abs(h.b - a.b) <= IGe || $wnd.Math.abs(h.a - b.a) <= IGe && $wnd.Math.abs(h.b - b.b) <= IGe); + h = Gid(a, ojd(new rjd(b.a, b.b), a), c2, e); + !!h && (($wnd.Math.abs(h.a - a.a) <= IGe && $wnd.Math.abs(h.b - a.b) <= IGe) == ($wnd.Math.abs(h.a - b.a) <= IGe && $wnd.Math.abs(h.b - b.b) <= IGe) || f2 ? i2 = $wnd.Math.min(i2, ejd(ojd(h, c2))) : g = true); + h = Gid(a, ojd(new rjd(b.a, b.b), a), d, e); + !!h && (g || ($wnd.Math.abs(h.a - a.a) <= IGe && $wnd.Math.abs(h.b - a.b) <= IGe) == ($wnd.Math.abs(h.a - b.a) <= IGe && $wnd.Math.abs(h.b - b.b) <= IGe) || f2) && (i2 = $wnd.Math.min(i2, ejd(ojd(h, d)))); + return i2; + } + function eWb(a) { + Cgd(a, new Pfd(Wfd($fd(Xfd(Zfd(Yfd(new agd(), AAe), BAe), "Minimizes the stress within a layout using stress majorization. Stress exists if the euclidean distance between a pair of nodes doesn't match their graph theoretic distance, that is, the shortest path between the two nodes. The method allows to specify individual edge lengths."), new hWb()), Zze))); + Agd(a, AAe, dAe, iGd(XVb)); + Agd(a, AAe, fAe, (Geb(), true)); + Agd(a, AAe, jAe, iGd($Vb)); + Agd(a, AAe, CAe, iGd(_Vb)); + Agd(a, AAe, iAe, iGd(aWb)); + Agd(a, AAe, kAe, iGd(ZVb)); + Agd(a, AAe, gAe, iGd(bWb)); + Agd(a, AAe, lAe, iGd(cWb)); + Agd(a, AAe, vAe, iGd(WVb)); + Agd(a, AAe, xAe, iGd(UVb)); + Agd(a, AAe, yAe, iGd(VVb)); + Agd(a, AAe, zAe, iGd(YVb)); + Agd(a, AAe, wAe, iGd(TVb)); + } + function kJc(a) { + var b, c2, d, e, f2, g, h, i2; + b = null; + for (d = new Anb(a); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 239); + Kfb(pJc(c2.g, c2.d[0]).a); + c2.b = null; + if (!!c2.e && c2.e.gc() > 0 && c2.c == 0) { + !b && (b = new bnb()); + ZEb(b.c, c2); + } + } + if (b) { + while (b.c.length != 0) { + c2 = RD(Xmb(b, 0), 239); + if (!!c2.b && c2.b.c.length > 0) { + for (f2 = (!c2.b && (c2.b = new bnb()), new Anb(c2.b)); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 239); + if (Mfb(pJc(e.g, e.d[0]).a) == Mfb(pJc(c2.g, c2.d[0]).a)) { + if (Wmb(a, e, 0) > Wmb(a, c2, 0)) { + return new Ptd(e, c2); + } + } else if (Kfb(pJc(e.g, e.d[0]).a) > Kfb(pJc(c2.g, c2.d[0]).a)) { + return new Ptd(e, c2); + } + } + } + for (h = (!c2.e && (c2.e = new bnb()), c2.e).Kc(); h.Ob(); ) { + g = RD(h.Pb(), 239); + i2 = (!g.b && (g.b = new bnb()), g.b); + wFb(0, i2.c.length); + XEb(i2.c, 0, c2); + g.c == i2.c.length && (ZEb(b.c, g), true); + } + } + } + return null; + } + function _Jc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r; + b.Ug("Interactive crossing minimization", 1); + g = 0; + for (f2 = new Anb(a.b); f2.a < f2.c.c.length; ) { + d = RD(ynb(f2), 30); + d.p = g++; + } + m = c1b(a); + q = new ILc(m.length); + yNc(new mob(cD(WC(QY, 1), rve, 230, 0, [q])), m); + p = 0; + g = 0; + for (e = new Anb(a.b); e.a < e.c.c.length; ) { + d = RD(ynb(e), 30); + c2 = 0; + l = 0; + for (k = new Anb(d.a); k.a < k.c.c.length; ) { + i2 = RD(ynb(k), 10); + if (i2.n.a > 0) { + c2 += i2.n.a + i2.o.a / 2; + ++l; + } + for (o2 = new Anb(i2.j); o2.a < o2.c.c.length; ) { + n = RD(ynb(o2), 12); + n.p = p++; + } + } + l > 0 && (c2 /= l); + r = $C(iE, vxe, 28, d.a.c.length, 15, 1); + h = 0; + for (j = new Anb(d.a); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 10); + i2.p = h++; + r[i2.p] = $Jc(i2, c2); + i2.k == (r3b(), o3b) && pQb(i2, (Ywc(), Cwc), r[i2.p]); + } + yob(); + _mb(d.a, new eKc(r)); + wIc(q, m, g, true); + ++g; + } + b.Vg(); + } + function wte(a, b) { + var c2, d, e, f2, g, h, i2, j, k; + if (b.e == 5) { + tte(a, b); + return; + } + j = b; + if (j.b == null || a.b == null) + return; + vte(a); + ste(a); + vte(j); + ste(j); + c2 = $C(kE, Pwe, 28, a.b.length + j.b.length, 15, 1); + k = 0; + d = 0; + g = 0; + while (d < a.b.length && g < j.b.length) { + e = a.b[d]; + f2 = a.b[d + 1]; + h = j.b[g]; + i2 = j.b[g + 1]; + if (f2 < h) { + c2[k++] = a.b[d++]; + c2[k++] = a.b[d++]; + } else if (f2 >= h && e <= i2) { + if (h <= e && f2 <= i2) { + d += 2; + } else if (h <= e) { + a.b[d] = i2 + 1; + g += 2; + } else if (f2 <= i2) { + c2[k++] = e; + c2[k++] = h - 1; + d += 2; + } else { + c2[k++] = e; + c2[k++] = h - 1; + a.b[d] = i2 + 1; + g += 2; + } + } else if (i2 < e) { + g += 2; + } else { + throw Adb(new yz("Token#subtractRanges(): Internal Error: [" + a.b[d] + "," + a.b[d + 1] + "] - [" + j.b[g] + "," + j.b[g + 1] + "]")); + } + } + while (d < a.b.length) { + c2[k++] = a.b[d++]; + c2[k++] = a.b[d++]; + } + a.b = $C(kE, Pwe, 28, k, 15, 1); + hib(c2, 0, a.b, 0, k); + } + function oTb(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t; + h = IGd(b, false, false); + r = ssd(h); + d && (r = Ijd(r)); + t = Kfb(UD(Gxd(b, (tSb(), mSb)))); + q = (sFb(r.b != 0), RD(r.a.a.c, 8)); + l = RD(ju(r, 1), 8); + if (r.b > 2) { + k = new bnb(); + Tmb(k, new Rkb(r, 1, r.b)); + f2 = jTb(k, t + a.a); + s = new ORb(f2); + kQb(s, b); + ZEb(c2.c, s); + } else { + d ? s = RD(Wjb(a.b, JGd(b)), 272) : s = RD(Wjb(a.b, LGd(b)), 272); + } + i2 = JGd(b); + d && (i2 = LGd(b)); + g = qTb(q, i2); + j = t + a.a; + if (g.a) { + j += $wnd.Math.abs(q.b - l.b); + p = new rjd(l.a, (l.b + q.b) / 2); + } else { + j += $wnd.Math.abs(q.a - l.a); + p = new rjd((l.a + q.a) / 2, l.b); + } + d ? Zjb(a.d, b, new QRb(s, g, p, j)) : Zjb(a.c, b, new QRb(s, g, p, j)); + Zjb(a.b, b, s); + o2 = (!b.n && (b.n = new C5d(I4, b, 1, 7)), b.n); + for (n = new dMd(o2); n.e != n.i.gc(); ) { + m = RD(bMd(n), 135); + e = nTb(a, m, true, 0, 0); + ZEb(c2.c, e); + } + } + function sMb(a) { + var b, c2, d, e, f2, g, h; + if (a.A.dc()) { + return; + } + if (a.A.Hc((Qpd(), Opd))) { + RD(Vrb(a.b, (qpd(), Yod)), 127).k = true; + RD(Vrb(a.b, npd), 127).k = true; + b = a.q != (Bod(), xod) && a.q != wod; + QJb(RD(Vrb(a.b, Xod), 127), b); + QJb(RD(Vrb(a.b, ppd), 127), b); + QJb(a.g, b); + if (a.A.Hc(Ppd)) { + RD(Vrb(a.b, Yod), 127).j = true; + RD(Vrb(a.b, npd), 127).j = true; + RD(Vrb(a.b, Xod), 127).k = true; + RD(Vrb(a.b, ppd), 127).k = true; + a.g.k = true; + } + } + if (a.A.Hc(Npd)) { + a.a.j = true; + a.a.k = true; + a.g.j = true; + a.g.k = true; + h = a.B.Hc((dqd(), _pd)); + for (e = nMb(), f2 = 0, g = e.length; f2 < g; ++f2) { + d = e[f2]; + c2 = RD(Vrb(a.i, d), 314); + if (c2) { + if (jMb(d)) { + c2.j = true; + c2.k = true; + } else { + c2.j = !h; + c2.k = !h; + } + } + } + } + if (a.A.Hc(Mpd) && a.B.Hc((dqd(), $pd))) { + a.g.j = true; + a.g.j = true; + if (!a.a.j) { + a.a.j = true; + a.a.k = true; + a.a.e = true; + } + } + } + function eOc(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r; + for (d = new Anb(a.e.b); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 30); + for (f2 = new Anb(c2.a); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 10); + n = a.i[e.p]; + j = n.a.e; + i2 = n.d.e; + e.n.b = j; + r = i2 - j - e.o.b; + b = BOc(e); + m = (wDc(), (!e.q ? (yob(), yob(), wob) : e.q)._b((yCc(), iBc)) ? l = RD(mQb(e, iBc), 203) : l = RD(mQb(Y2b(e), jBc), 203), l); + b && (m == tDc || m == sDc) && (e.o.b += r); + if (b && (m == vDc || m == tDc || m == sDc)) { + for (p = new Anb(e.j); p.a < p.c.c.length; ) { + o2 = RD(ynb(p), 12); + if ((qpd(), apd).Hc(o2.j)) { + k = RD(Wjb(a.k, o2), 125); + o2.n.b = k.e - j; + } + } + for (h = new Anb(e.b); h.a < h.c.c.length; ) { + g = RD(ynb(h), 72); + q = RD(mQb(e, dBc), 21); + q.Hc((dod(), aod)) ? g.n.b += r : q.Hc(bod) && (g.n.b += r / 2); + } + (m == tDc || m == sDc) && b3b(e, (qpd(), npd)).Jc(new yPc(r)); + } + } + } + } + function qOc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m; + j = new bnb(); + for (i2 = new Anb(b.a); i2.a < i2.c.c.length; ) { + g = RD(ynb(i2), 10); + for (m = b3b(g, (qpd(), Xod)).Kc(); m.Ob(); ) { + l = RD(m.Pb(), 12); + for (e = new Anb(l.g); e.a < e.c.c.length; ) { + d = RD(ynb(e), 18); + if (!W0b(d) && d.c.i.c == d.d.i.c || W0b(d) || d.d.i.c != c2) { + continue; + } + ZEb(j.c, d); + } + } + } + for (h = hv(c2.a).Kc(); h.Ob(); ) { + g = RD(h.Pb(), 10); + for (m = b3b(g, (qpd(), ppd)).Kc(); m.Ob(); ) { + l = RD(m.Pb(), 12); + for (e = new Anb(l.e); e.a < e.c.c.length; ) { + d = RD(ynb(e), 18); + if (!W0b(d) && d.c.i.c == d.d.i.c || W0b(d) || d.c.i.c != b) { + continue; + } + if (j.c.length != 0) { + k = new Jkb(j, j.c.length); + f2 = (sFb(k.b > 0), RD(k.a.Xb(k.c = --k.b), 18)); + while (f2 != d && k.b > 0) { + a.a[f2.p] = true; + a.a[d.p] = true; + f2 = (sFb(k.b > 0), RD(k.a.Xb(k.c = --k.b), 18)); + } + k.b > 0 && Ckb(k); + } + } + } + } + } + function Zyb(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n; + if (!a.b) { + return false; + } + g = null; + m = null; + i2 = new Fzb(null, null); + e = 1; + i2.a[1] = a.b; + l = i2; + while (l.a[e]) { + j = e; + h = m; + m = l; + l = l.a[e]; + d = a.a.Ne(b, l.d); + e = d < 0 ? 0 : 1; + d == 0 && (!c2.c || Fvb(l.e, c2.d)) && (g = l); + if (!(!!l && l.b) && !Vyb(l.a[e])) { + if (Vyb(l.a[1 - e])) { + m = m.a[j] = azb(l, e); + } else if (!Vyb(l.a[1 - e])) { + n = m.a[1 - j]; + if (n) { + if (!Vyb(n.a[1 - j]) && !Vyb(n.a[j])) { + m.b = false; + n.b = true; + l.b = true; + } else { + f2 = h.a[1] == m ? 1 : 0; + Vyb(n.a[j]) ? h.a[f2] = _yb(m, j) : Vyb(n.a[1 - j]) && (h.a[f2] = azb(m, j)); + l.b = h.a[f2].b = true; + h.a[f2].a[0].b = false; + h.a[f2].a[1].b = false; + } + } + } + } + } + if (g) { + c2.b = true; + c2.d = g.e; + if (l != g) { + k = new Fzb(l.d, l.e); + $yb(a, i2, g, k); + m == g && (m = k); + } + m.a[m.a[1] == l ? 1 : 0] = l.a[!l.a[0] ? 1 : 0]; + --a.c; + } + a.b = i2.a[1]; + !!a.b && (a.b.b = false); + return c2.b; + } + function Ilc(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m; + for (e = new Anb(a.a.a.b); e.a < e.c.c.length; ) { + d = RD(ynb(e), 60); + for (i2 = d.c.Kc(); i2.Ob(); ) { + h = RD(i2.Pb(), 60); + if (d.a == h.a) { + continue; + } + Dmd(a.a.d) ? l = a.a.g.ff(d, h) : l = a.a.g.gf(d, h); + f2 = d.b.a + d.d.b + l - h.b.a; + f2 = $wnd.Math.ceil(f2); + f2 = $wnd.Math.max(0, f2); + if (_jc(d, h)) { + g = eJb(new gJb(), a.d); + j = eE($wnd.Math.ceil(h.b.a - d.b.a)); + b = j - (h.b.a - d.b.a); + k = $jc(d).a; + c2 = d; + if (!k) { + k = $jc(h).a; + b = -b; + c2 = h; + } + if (k) { + c2.b.a -= b; + k.n.a -= b; + } + rIb(uIb(tIb(vIb(sIb(new wIb(), $wnd.Math.max(0, j)), 1), g), a.c[d.a.d])); + rIb(uIb(tIb(vIb(sIb(new wIb(), $wnd.Math.max(0, -j)), 1), g), a.c[h.a.d])); + } else { + m = 1; + (ZD(d.g, 154) && ZD(h.g, 10) || ZD(h.g, 154) && ZD(d.g, 10)) && (m = 2); + rIb(uIb(tIb(vIb(sIb(new wIb(), eE(f2)), m), a.c[d.a.d]), a.c[h.a.d])); + } + } + } + } + function PIc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m; + if (c2) { + d = -1; + k = new Jkb(b, 0); + while (k.b < k.d.gc()) { + h = (sFb(k.b < k.d.gc()), RD(k.d.Xb(k.c = k.b++), 10)); + l = a.c[h.c.p][h.p].a; + if (l == null) { + g = d + 1; + f2 = new Jkb(b, k.b); + while (f2.b < f2.d.gc()) { + m = TIc(a, (sFb(f2.b < f2.d.gc()), RD(f2.d.Xb(f2.c = f2.b++), 10))).a; + if (m != null) { + g = (uFb(m), m); + break; + } + } + l = (d + g) / 2; + a.c[h.c.p][h.p].a = l; + a.c[h.c.p][h.p].d = (uFb(l), l); + a.c[h.c.p][h.p].b = 1; + } + d = (uFb(l), l); + } + } else { + e = 0; + for (j = new Anb(b); j.a < j.c.c.length; ) { + h = RD(ynb(j), 10); + a.c[h.c.p][h.p].a != null && (e = $wnd.Math.max(e, Kfb(a.c[h.c.p][h.p].a))); + } + e += 2; + for (i2 = new Anb(b); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 10); + if (a.c[h.c.p][h.p].a == null) { + l = Kwb(a.i, 24) * Nxe * e - 1; + a.c[h.c.p][h.p].a = l; + a.c[h.c.p][h.p].d = l; + a.c[h.c.p][h.p].b = 1; + } + } + } + } + function xA(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l; + !c2 && (c2 = hB(b.q.getTimezoneOffset())); + e = (b.q.getTimezoneOffset() - c2.a) * 6e4; + h = new wB(Bdb(Hdb(b.q.getTime()), e)); + i2 = h; + if (h.q.getTimezoneOffset() != b.q.getTimezoneOffset()) { + e > 0 ? e -= 864e5 : e += 864e5; + i2 = new wB(Bdb(Hdb(b.q.getTime()), e)); + } + k = new cib(); + j = a.a.length; + for (f2 = 0; f2 < j; ) { + d = ihb(a.a, f2); + if (d >= 97 && d <= 122 || d >= 65 && d <= 90) { + for (g = f2 + 1; g < j && ihb(a.a, g) == d; ++g) + ; + LA(k, d, g - f2, h, i2, c2); + f2 = g; + } else if (d == 39) { + ++f2; + if (f2 < j && ihb(a.a, f2) == 39) { + k.a += "'"; + ++f2; + continue; + } + l = false; + while (!l) { + g = f2; + while (g < j && ihb(a.a, g) != 39) { + ++g; + } + if (g >= j) { + throw Adb(new agb("Missing trailing '")); + } + g + 1 < j && ihb(a.a, g + 1) == 39 ? ++g : l = true; + Zhb(k, zhb(a.a, f2, g)); + f2 = g + 1; + } + } else { + k.a += String.fromCharCode(d); + ++f2; + } + } + return k.a; + } + function abe() { + RRd(g7, new Ibe()); + RRd(f7, new nce()); + RRd(h7, new Uce()); + RRd(i7, new kde()); + RRd(k7, new nde()); + RRd(m7, new qde()); + RRd(l7, new tde()); + RRd(n7, new wde()); + RRd(p7, new ebe()); + RRd(q7, new hbe()); + RRd(r7, new kbe()); + RRd(s7, new nbe()); + RRd(t7, new qbe()); + RRd(u7, new tbe()); + RRd(v7, new wbe()); + RRd(y7, new zbe()); + RRd(A7, new Cbe()); + RRd(C8, new Fbe()); + RRd(o7, new Lbe()); + RRd(z7, new Obe()); + RRd(QI, new Rbe()); + RRd(WC(gE, 1), new Ube()); + RRd(RI, new Xbe()); + RRd(SI, new $be()); + RRd(qK, new bce()); + RRd(T6, new ece()); + RRd(VI, new hce()); + RRd(Y6, new kce()); + RRd(Z6, new qce()); + RRd(Tbb, new tce()); + RRd(Jbb, new wce()); + RRd(ZI, new zce()); + RRd(bJ, new Cce()); + RRd(UI, new Fce()); + RRd(eJ, new Ice()); + RRd(VK, new Lce()); + RRd(Aab, new Oce()); + RRd(zab, new Rce()); + RRd(lJ, new Xce()); + RRd(qJ, new $ce()); + RRd(a7, new bde()); + RRd($6, new ede()); + } + function Inb(a, b) { + var c2, d, e, f2, g, h, i2, j, k; + if (a == null) { + return vve; + } + i2 = b.a.zc(a, b); + if (i2 != null) { + return "[...]"; + } + c2 = new Jyb(pve, "[", "]"); + for (e = a, f2 = 0, g = e.length; f2 < g; ++f2) { + d = e[f2]; + if (d != null && (rb(d).i & 4) != 0) { + if (Array.isArray(d) && (k = XC(d), !(k >= 14 && k <= 16))) { + if (b.a._b(d)) { + !c2.a ? c2.a = new dib(c2.d) : Zhb(c2.a, c2.b); + Whb(c2.a, "[...]"); + } else { + h = SD(d); + j = new btb(b); + Gyb(c2, Inb(h, j)); + } + } else + ZD(d, 183) ? Gyb(c2, hob(RD(d, 183))) : ZD(d, 195) ? Gyb(c2, aob(RD(d, 195))) : ZD(d, 201) ? Gyb(c2, bob(RD(d, 201))) : ZD(d, 2111) ? Gyb(c2, gob(RD(d, 2111))) : ZD(d, 53) ? Gyb(c2, eob(RD(d, 53))) : ZD(d, 376) ? Gyb(c2, fob(RD(d, 376))) : ZD(d, 846) ? Gyb(c2, dob(RD(d, 846))) : ZD(d, 109) && Gyb(c2, cob(RD(d, 109))); + } else { + Gyb(c2, d == null ? vve : jeb(d)); + } + } + return !c2.a ? c2.c : c2.e.length == 0 ? c2.a.a : c2.a.a + ("" + c2.e); + } + function KXd(a, b) { + var c2, d, e, f2; + f2 = a.F; + if (b == null) { + a.F = null; + yXd(a, null); + } else { + a.F = (uFb(b), b); + d = qhb(b, Fhb(60)); + if (d != -1) { + e = (AFb(0, d, b.length), b.substr(0, d)); + qhb(b, Fhb(46)) == -1 && !lhb(e, hve) && !lhb(e, dKe) && !lhb(e, eKe) && !lhb(e, fKe) && !lhb(e, gKe) && !lhb(e, hKe) && !lhb(e, iKe) && !lhb(e, jKe) && (e = kKe); + c2 = thb(b, Fhb(62)); + c2 != -1 && (e += "" + (BFb(c2 + 1, b.length + 1), b.substr(c2 + 1))); + yXd(a, e); + } else { + e = b; + if (qhb(b, Fhb(46)) == -1) { + d = qhb(b, Fhb(91)); + d != -1 && (e = (AFb(0, d, b.length), b.substr(0, d))); + if (!lhb(e, hve) && !lhb(e, dKe) && !lhb(e, eKe) && !lhb(e, fKe) && !lhb(e, gKe) && !lhb(e, hKe) && !lhb(e, iKe) && !lhb(e, jKe)) { + e = kKe; + d != -1 && (e += "" + (BFb(d, b.length + 1), b.substr(d))); + } else { + e = b; + } + } + yXd(a, e); + e == b && (a.F = a.D); + } + } + (a.Db & 4) != 0 && (a.Db & 1) == 0 && qvd(a, new N3d(a, 1, 5, f2, b)); + } + function Pvd(b, c2) { + var d, e, f2, g, h, i2, j, k, l, m; + j = c2.length - 1; + i2 = (BFb(j, c2.length), c2.charCodeAt(j)); + if (i2 == 93) { + h = qhb(c2, Fhb(91)); + if (h >= 0) { + f2 = Uvd(b, (AFb(1, h, c2.length), c2.substr(1, h - 1))); + l = (AFb(h + 1, j, c2.length), c2.substr(h + 1, j - (h + 1))); + return Nvd(b, l, f2); + } + } else { + d = -1; + _eb == null && (_eb = new RegExp("\\d")); + if (_eb.test(String.fromCharCode(i2))) { + d = uhb(c2, Fhb(46), j - 1); + if (d >= 0) { + e = RD(Fvd(b, Zvd(b, (AFb(1, d, c2.length), c2.substr(1, d - 1))), false), 61); + k = 0; + try { + k = Oeb((BFb(d + 1, c2.length + 1), c2.substr(d + 1)), qwe, lve); + } catch (a) { + a = zdb(a); + if (ZD(a, 130)) { + g = a; + throw Adb(new RSd(g)); + } else + throw Adb(a); + } + if (k < e.gc()) { + m = e.Xb(k); + ZD(m, 76) && (m = RD(m, 76).md()); + return RD(m, 58); + } + } + } + if (d < 0) { + return RD(Fvd(b, Zvd(b, (BFb(1, c2.length + 1), c2.substr(1))), false), 58); + } + } + return null; + } + function Jcc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p; + b.Ug("Label dummy insertions", 1); + l = new bnb(); + g = Kfb(UD(mQb(a, (yCc(), VBc)))); + j = Kfb(UD(mQb(a, ZBc))); + k = RD(mQb(a, rAc), 88); + for (n = new Anb(a.a); n.a < n.c.c.length; ) { + m = RD(ynb(n), 10); + for (f2 = new is(Mr(a3b(m).a.Kc(), new ir())); gs(f2); ) { + e = RD(hs(f2), 18); + if (e.c.i != e.d.i && br(e.b, Gcc)) { + p = Kcc(e); + o2 = ev(e.b.c.length); + c2 = Icc(a, e, p, o2); + ZEb(l.c, c2); + d = c2.o; + h = new Jkb(e.b, 0); + while (h.b < h.d.gc()) { + i2 = (sFb(h.b < h.d.gc()), RD(h.d.Xb(h.c = h.b++), 72)); + if (dE(mQb(i2, wAc)) === dE((Omd(), Lmd))) { + if (k == (Cmd(), Bmd) || k == xmd) { + d.a += i2.o.a + j; + d.b = $wnd.Math.max(d.b, i2.o.b); + } else { + d.a = $wnd.Math.max(d.a, i2.o.a); + d.b += i2.o.b + j; + } + ZEb(o2.c, i2); + Ckb(h); + } + } + if (k == (Cmd(), Bmd) || k == xmd) { + d.a -= j; + d.b += g + p; + } else { + d.b += g - j + p; + } + } + } + } + Tmb(a.a, l); + b.Vg(); + } + function H_b(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2; + a.c = a.e; + o2 = TD(mQb(b, (yCc(), OBc))); + n = o2 == null || (uFb(o2), o2); + f2 = RD(mQb(b, (Ywc(), kwc)), 21).Hc((ovc(), hvc)); + e = RD(mQb(b, BBc), 101); + c2 = !(e == (Bod(), vod) || e == xod || e == wod); + if (n && (c2 || !f2)) { + for (l = new Anb(b.a); l.a < l.c.c.length; ) { + j = RD(ynb(l), 10); + j.p = 0; + } + m = new bnb(); + for (k = new Anb(b.a); k.a < k.c.c.length; ) { + j = RD(ynb(k), 10); + d = G_b(a, j, null); + if (d) { + i2 = new d1b(); + kQb(i2, b); + pQb(i2, ewc, RD(d.b, 21)); + C2b(i2.d, b.d); + pQb(i2, nBc, null); + for (h = RD(d.a, 15).Kc(); h.Ob(); ) { + g = RD(h.Pb(), 10); + Rmb(i2.a, g); + g.a = i2; + } + m.Fc(i2); + } + } + f2 && (dE(mQb(b, Yzc)) === dE((U$b(), Q$b)) ? a.c = a.b : dE(mQb(b, Yzc)) === dE(S$b) ? a.c = a.d : a.c = a.a); + } else { + m = new mob(cD(WC(eR, 1), OAe, 36, 0, [b])); + } + dE(mQb(b, Yzc)) !== dE((U$b(), T$b)) && (yob(), m.jd(new K_b())); + return m; + } + function o2d(a, b, c2) { + var d, e, f2, g, h, i2, j; + j = a.c; + !b && (b = d2d); + a.c = b; + if ((a.Db & 4) != 0 && (a.Db & 1) == 0) { + i2 = new N3d(a, 1, 2, j, a.c); + !c2 ? c2 = i2 : c2.nj(i2); + } + if (j != b) { + if (ZD(a.Cb, 292)) { + if (a.Db >> 16 == -10) { + c2 = RD(a.Cb, 292).Yk(b, c2); + } else if (a.Db >> 16 == -15) { + !b && (b = (JTd(), wTd)); + !j && (j = (JTd(), wTd)); + if (a.Cb.Yh()) { + i2 = new P3d(a.Cb, 1, 13, j, b, fZd(o4d(RD(a.Cb, 62)), a), false); + !c2 ? c2 = i2 : c2.nj(i2); + } + } + } else if (ZD(a.Cb, 90)) { + if (a.Db >> 16 == -23) { + ZD(b, 90) || (b = (JTd(), zTd)); + ZD(j, 90) || (j = (JTd(), zTd)); + if (a.Cb.Yh()) { + i2 = new P3d(a.Cb, 1, 10, j, b, fZd(tYd(RD(a.Cb, 29)), a), false); + !c2 ? c2 = i2 : c2.nj(i2); + } + } + } else if (ZD(a.Cb, 457)) { + h = RD(a.Cb, 850); + g = (!h.b && (h.b = new pae(new lae())), h.b); + for (f2 = (d = new vkb(new mkb(g.a).a), new xae(d)); f2.a.b; ) { + e = RD(tkb(f2.a).ld(), 89); + c2 = o2d(e, k2d(e, h), c2); + } + } + } + return c2; + } + function Y4b(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m; + g = Heb(TD(Gxd(a, (yCc(), NAc)))); + m = RD(Gxd(a, EBc), 21); + i2 = false; + j = false; + l = new dMd((!a.c && (a.c = new C5d(K4, a, 9, 9)), a.c)); + while (l.e != l.i.gc() && (!i2 || !j)) { + f2 = RD(bMd(l), 123); + h = 0; + for (e = Fl(Al(cD(WC(cJ, 1), rve, 20, 0, [(!f2.d && (f2.d = new Yie(G4, f2, 8, 5)), f2.d), (!f2.e && (f2.e = new Yie(G4, f2, 7, 4)), f2.e)]))); gs(e); ) { + d = RD(hs(e), 74); + k = g && ozd(d) && Heb(TD(Gxd(d, OAc))); + c2 = cZd((!d.b && (d.b = new Yie(E4, d, 4, 7)), d.b), f2) ? a == vCd(AGd(RD(QHd((!d.c && (d.c = new Yie(E4, d, 5, 8)), d.c), 0), 84))) : a == vCd(AGd(RD(QHd((!d.b && (d.b = new Yie(E4, d, 4, 7)), d.b), 0), 84))); + if (k || c2) { + ++h; + if (h > 1) { + break; + } + } + } + h > 0 ? i2 = true : m.Hc((Pod(), Lod)) && (!f2.n && (f2.n = new C5d(I4, f2, 1, 7)), f2.n).i > 0 && (i2 = true); + h > 1 && (j = true); + } + i2 && b.Fc((ovc(), hvc)); + j && b.Fc((ovc(), ivc)); + } + function Dsd(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m; + m = RD(Gxd(a, (umd(), kld)), 21); + if (m.dc()) { + return null; + } + h = 0; + g = 0; + if (m.Hc((Qpd(), Opd))) { + k = RD(Gxd(a, Hld), 101); + d = 2; + c2 = 2; + e = 2; + f2 = 2; + b = !vCd(a) ? RD(Gxd(a, Nkd), 88) : RD(Gxd(vCd(a), Nkd), 88); + for (j = new dMd((!a.c && (a.c = new C5d(K4, a, 9, 9)), a.c)); j.e != j.i.gc(); ) { + i2 = RD(bMd(j), 123); + l = RD(Gxd(i2, Old), 64); + if (l == (qpd(), opd)) { + l = osd(i2, b); + Ixd(i2, Old, l); + } + if (k == (Bod(), wod)) { + switch (l.g) { + case 1: + d = $wnd.Math.max(d, i2.i + i2.g); + break; + case 2: + c2 = $wnd.Math.max(c2, i2.j + i2.f); + break; + case 3: + e = $wnd.Math.max(e, i2.i + i2.g); + break; + case 4: + f2 = $wnd.Math.max(f2, i2.j + i2.f); + } + } else { + switch (l.g) { + case 1: + d += i2.g + 2; + break; + case 2: + c2 += i2.f + 2; + break; + case 3: + e += i2.g + 2; + break; + case 4: + f2 += i2.f + 2; + } + } + } + h = $wnd.Math.max(d, e); + g = $wnd.Math.max(c2, f2); + } + return Esd(a, h, g, true, true); + } + function Rqc(a, b, c2, d, e) { + var f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u; + s = RD(zDb(PDb(CDb(new SDb(null, new Swb(b.d, 16)), new Vqc(c2)), new Xqc(c2)), tBb(new ZBb(), new XBb(), new wCb(), cD(WC(QL, 1), jwe, 108, 0, [(xBb(), vBb)]))), 15); + l = lve; + k = qwe; + for (i2 = new Anb(b.b.j); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 12); + if (h.j == c2) { + l = $wnd.Math.min(l, h.p); + k = $wnd.Math.max(k, h.p); + } + } + if (l == lve) { + for (g = 0; g < s.gc(); g++) { + Umc(RD(s.Xb(g), 105), c2, g); + } + } else { + t = $C(kE, Pwe, 28, e.length, 15, 1); + Qnb(t, t.length); + for (r = s.Kc(); r.Ob(); ) { + q = RD(r.Pb(), 105); + f2 = RD(Wjb(a.b, q), 183); + j = 0; + for (p = l; p <= k; p++) { + f2[p] && (j = $wnd.Math.max(j, d[p])); + } + if (q.i) { + n = q.i.c; + u = new _sb(); + for (m = 0; m < e.length; m++) { + e[n][m] && Ysb(u, sgb(t[m])); + } + while (Zsb(u, sgb(j))) { + ++j; + } + } + Umc(q, c2, j); + for (o2 = l; o2 <= k; o2++) { + f2[o2] && (d[o2] = j + 1); + } + !!q.i && (t[q.i.c] = j); + } + } + } + function wOc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p; + e = null; + for (d = new Anb(b.a); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 10); + BOc(c2) ? f2 = (h = eJb(fJb(new gJb(), c2), a.f), i2 = eJb(fJb(new gJb(), c2), a.f), j = new ROc(c2, true, h, i2), k = c2.o.b, l = (wDc(), (!c2.q ? (yob(), yob(), wob) : c2.q)._b((yCc(), iBc)) ? m = RD(mQb(c2, iBc), 203) : m = RD(mQb(Y2b(c2), jBc), 203), m), n = 1e4, l == sDc && (n = 1), o2 = rIb(uIb(tIb(sIb(vIb(new wIb(), n), eE($wnd.Math.ceil(k))), h), i2)), l == tDc && Ysb(a.d, o2), xOc(a, hv(b3b(c2, (qpd(), ppd))), j), xOc(a, b3b(c2, Xod), j), j) : f2 = (p = eJb(fJb(new gJb(), c2), a.f), FDb(CDb(new SDb(null, new Swb(c2.j, 16)), new cPc()), new ePc(a, p)), new ROc(c2, false, p, p)); + a.i[c2.p] = f2; + if (e) { + g = e.c.d.a + bFc(a.n, e.c, c2) + c2.d.d; + e.b || (g += e.c.o.b); + rIb(uIb(tIb(vIb(sIb(new wIb(), eE($wnd.Math.ceil(g))), 0), e.d), f2.a)); + } + e = f2; + } + } + function h_b(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m, n; + f2 = new t_b(b); + l = c_b(a, b, f2); + n = $wnd.Math.max(Kfb(UD(mQb(b, (yCc(), FAc)))), 1); + for (k = new Anb(l.a); k.a < k.c.c.length; ) { + j = RD(ynb(k), 42); + i2 = g_b(RD(j.a, 8), RD(j.b, 8), n); + o = true; + o = o & l_b(c2, new rjd(i2.c, i2.d)); + o = o & l_b(c2, Zid(new rjd(i2.c, i2.d), i2.b, 0)); + o = o & l_b(c2, Zid(new rjd(i2.c, i2.d), 0, i2.a)); + o & l_b(c2, Zid(new rjd(i2.c, i2.d), i2.b, i2.a)); + } + m = f2.d; + h = g_b(RD(l.b.a, 8), RD(l.b.b, 8), n); + if (m == (qpd(), ppd) || m == Xod) { + d.c[m.g] = $wnd.Math.min(d.c[m.g], h.d); + d.b[m.g] = $wnd.Math.max(d.b[m.g], h.d + h.a); + } else { + d.c[m.g] = $wnd.Math.min(d.c[m.g], h.c); + d.b[m.g] = $wnd.Math.max(d.b[m.g], h.c + h.b); + } + e = pxe; + g = f2.c.i.d; + switch (m.g) { + case 4: + e = g.c; + break; + case 2: + e = g.b; + break; + case 1: + e = g.a; + break; + case 3: + e = g.d; + } + d.a[m.g] = $wnd.Math.max(d.a[m.g], e); + return f2; + } + function W7b(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5; + h = RD(Wjb(b.c, a), 468); + s = b.a.c; + i2 = b.a.c + b.a.b; + C = h.f; + D5 = h.a; + g = C < D5; + p = new rjd(s, C); + t = new rjd(i2, D5); + e = (s + i2) / 2; + q = new rjd(e, C); + u = new rjd(e, D5); + f2 = X7b(a, C, D5); + w2 = K3b(b.B); + A = new rjd(e, f2); + B = K3b(b.D); + c2 = uid(cD(WC(l3, 1), Nve, 8, 0, [w2, A, B])); + n = false; + r = b.B.i; + if (!!r && !!r.c && h.d) { + j = g && r.p < r.c.a.c.length - 1 || !g && r.p > 0; + if (j) { + if (j) { + m = r.p; + g ? ++m : --m; + l = RD(Vmb(r.c.a, m), 10); + d = Z7b(l); + n = !(Did(d, w2, c2[0]) || yid(d, w2, c2[0])); + } + } else { + n = true; + } + } + o2 = false; + v = b.D.i; + if (!!v && !!v.c && h.e) { + k = g && v.p > 0 || !g && v.p < v.c.a.c.length - 1; + if (k) { + m = v.p; + g ? --m : ++m; + l = RD(Vmb(v.c.a, m), 10); + d = Z7b(l); + o2 = !(Did(d, c2[0], B) || yid(d, c2[0], B)); + } else { + o2 = true; + } + } + n && o2 && Mub(a.a, A); + n || zjd(a.a, cD(WC(l3, 1), Nve, 8, 0, [p, q])); + o2 || zjd(a.a, cD(WC(l3, 1), Nve, 8, 0, [u, t])); + } + function MNc(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s; + n = b.c.length; + m = 0; + for (l = new Anb(a.b); l.a < l.c.c.length; ) { + k = RD(ynb(l), 30); + r = k.a; + if (r.c.length == 0) { + continue; + } + q = new Anb(r); + j = 0; + s = null; + e = RD(ynb(q), 10); + f2 = null; + while (e) { + f2 = RD(Vmb(b, e.p), 261); + if (f2.c >= 0) { + i2 = null; + h = new Jkb(k.a, j + 1); + while (h.b < h.d.gc()) { + g = (sFb(h.b < h.d.gc()), RD(h.d.Xb(h.c = h.b++), 10)); + i2 = RD(Vmb(b, g.p), 261); + if (i2.d == f2.d && i2.c < f2.c) { + break; + } else { + i2 = null; + } + } + if (i2) { + if (s) { + $mb(d, e.p, sgb(RD(Vmb(d, e.p), 17).a - 1)); + RD(Vmb(c2, s.p), 15).Mc(f2); + } + f2 = YNc(f2, e, n++); + ZEb(b.c, f2); + Rmb(c2, new bnb()); + if (s) { + RD(Vmb(c2, s.p), 15).Fc(f2); + Rmb(d, sgb(1)); + } else { + Rmb(d, sgb(0)); + } + } + } + o2 = null; + if (q.a < q.c.c.length) { + o2 = RD(ynb(q), 10); + p = RD(Vmb(b, o2.p), 261); + RD(Vmb(c2, e.p), 15).Fc(p); + $mb(d, o2.p, sgb(RD(Vmb(d, o2.p), 17).a + 1)); + } + f2.d = m; + f2.c = j++; + s = e; + e = o2; + } + ++m; + } + } + function I5b(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n; + f2 = RD(mQb(a, (Ywc(), Awc)), 74); + if (!f2) { + return; + } + d = a.a; + e = new sjd(c2); + $id(e, M5b(a)); + if (n2b(a.d.i, a.c.i)) { + m = a.c; + l = xjd(cD(WC(l3, 1), Nve, 8, 0, [m.n, m.a])); + ojd(l, c2); + } else { + l = K3b(a.c); + } + Pub(d, l, d.a, d.a.a); + n = K3b(a.d); + mQb(a, Wwc) != null && $id(n, RD(mQb(a, Wwc), 8)); + Pub(d, n, d.c.b, d.c); + Cjd(d, e); + g = IGd(f2, true, true); + Kzd(g, RD(QHd((!f2.b && (f2.b = new Yie(E4, f2, 4, 7)), f2.b), 0), 84)); + Lzd(g, RD(QHd((!f2.c && (f2.c = new Yie(E4, f2, 5, 8)), f2.c), 0), 84)); + lsd(d, g); + for (k = new Anb(a.b); k.a < k.c.c.length; ) { + j = RD(ynb(k), 72); + h = RD(mQb(j, Awc), 135); + Cyd(h, j.o.a); + Ayd(h, j.o.b); + Byd(h, j.n.a + e.a, j.n.b + e.b); + Ixd(h, (Zcc(), Ycc), TD(mQb(j, Ycc))); + } + i2 = RD(mQb(a, (yCc(), RAc)), 75); + if (i2) { + Cjd(i2, e); + Ixd(f2, RAc, i2); + } else { + Ixd(f2, RAc, null); + } + b == (Ymd(), Wmd) ? Ixd(f2, yAc, Wmd) : Ixd(f2, yAc, null); + } + function O3c(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B; + if (c2.c.length != 0) { + o2 = new bnb(); + for (n = new Anb(c2); n.a < n.c.c.length; ) { + m = RD(ynb(n), 27); + Rmb(o2, new rjd(m.i, m.j)); + } + d.dh(b, "Before removing overlaps"); + while (p3c(a, c2)) { + n3c(a, c2, false); + } + d.dh(b, "After removing overlaps"); + h = 0; + i2 = 0; + e = null; + if (c2.c.length != 0) { + e = (tFb(0, c2.c.length), RD(c2.c[0], 27)); + h = e.i - (tFb(0, o2.c.length), RD(o2.c[0], 8)).a; + i2 = e.j - (tFb(0, o2.c.length), RD(o2.c[0], 8)).b; + } + g = $wnd.Math.sqrt(h * h + i2 * i2); + l = M2c(c2); + f2 = 1; + if (l.a.gc() != 0) { + for (k = l.a.ec().Kc(); k.Ob(); ) { + j = RD(k.Pb(), 27); + p = a.f; + q = p.i + p.g / 2; + r = p.j + p.f / 2; + s = j.i + j.g / 2; + t = j.j + j.f / 2; + u = s - q; + v = t - r; + w2 = $wnd.Math.sqrt(u * u + v * v); + A = u / w2; + B = v / w2; + Dyd(j, j.i + A * g); + Eyd(j, j.j + B * g); + } + d.dh(b, "Child movement " + f2); + ++f2; + } + !!a.a && a.a.Gg(new dnb(l)); + O3c(a, b, new dnb(l), d); + } + } + function Fid(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t; + i2 = a; + k = ojd(new rjd(b.a, b.b), a); + j = c2; + l = ojd(new rjd(d.a, d.b), c2); + m = i2.a; + q = i2.b; + o2 = j.a; + s = j.b; + n = k.a; + r = k.b; + p = l.a; + t = l.b; + e = p * r - n * t; + Zy(); + bz(vEe); + if ($wnd.Math.abs(0 - e) <= vEe || 0 == e || isNaN(0) && isNaN(e)) { + return false; + } + g = 1 / e * ((m - o2) * r - (q - s) * n); + h = 1 / e * -(-(m - o2) * t + (q - s) * p); + f2 = (bz(vEe), ($wnd.Math.abs(0 - g) <= vEe || 0 == g || isNaN(0) && isNaN(g) ? 0 : 0 < g ? -1 : 0 > g ? 1 : cz(isNaN(0), isNaN(g))) < 0 && (bz(vEe), ($wnd.Math.abs(g - 1) <= vEe || g == 1 || isNaN(g) && isNaN(1) ? 0 : g < 1 ? -1 : g > 1 ? 1 : cz(isNaN(g), isNaN(1))) < 0) && (bz(vEe), ($wnd.Math.abs(0 - h) <= vEe || 0 == h || isNaN(0) && isNaN(h) ? 0 : 0 < h ? -1 : 0 > h ? 1 : cz(isNaN(0), isNaN(h))) < 0) && (bz(vEe), ($wnd.Math.abs(h - 1) <= vEe || h == 1 || isNaN(h) && isNaN(1) ? 0 : h < 1 ? -1 : h > 1 ? 1 : cz(isNaN(h), isNaN(1))) < 0)); + return f2; + } + function EXd(b) { + var c2, d, e, f2; + d = b.D != null ? b.D : b.B; + c2 = qhb(d, Fhb(91)); + if (c2 != -1) { + e = (AFb(0, c2, d.length), d.substr(0, c2)); + f2 = new Qhb(); + do + f2.a += "["; + while ((c2 = phb(d, 91, ++c2)) != -1); + if (lhb(e, hve)) + f2.a += "Z"; + else if (lhb(e, dKe)) + f2.a += "B"; + else if (lhb(e, eKe)) + f2.a += "C"; + else if (lhb(e, fKe)) + f2.a += "D"; + else if (lhb(e, gKe)) + f2.a += "F"; + else if (lhb(e, hKe)) + f2.a += "I"; + else if (lhb(e, iKe)) + f2.a += "J"; + else if (lhb(e, jKe)) + f2.a += "S"; + else { + f2.a += "L"; + f2.a += "" + e; + f2.a += ";"; + } + try { + return null; + } catch (a) { + a = zdb(a); + if (!ZD(a, 63)) + throw Adb(a); + } + } else if (qhb(d, Fhb(46)) == -1) { + if (lhb(d, hve)) + return xdb; + else if (lhb(d, dKe)) + return gE; + else if (lhb(d, eKe)) + return hE; + else if (lhb(d, fKe)) + return iE; + else if (lhb(d, gKe)) + return jE; + else if (lhb(d, hKe)) + return kE; + else if (lhb(d, iKe)) + return lE; + else if (lhb(d, jKe)) + return wdb; + } + return null; + } + function pTb(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A; + a.e = b; + h = RSb(b); + w2 = new bnb(); + for (d = new Anb(h); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 15); + A = new bnb(); + ZEb(w2.c, A); + i2 = new _sb(); + for (o2 = c2.Kc(); o2.Ob(); ) { + n = RD(o2.Pb(), 27); + f2 = nTb(a, n, true, 0, 0); + ZEb(A.c, f2); + p = n.i; + q = n.j; + m = (!n.n && (n.n = new C5d(I4, n, 1, 7)), n.n); + for (l = new dMd(m); l.e != l.i.gc(); ) { + j = RD(bMd(l), 135); + e = nTb(a, j, false, p, q); + ZEb(A.c, e); + } + v = (!n.c && (n.c = new C5d(K4, n, 9, 9)), n.c); + for (s = new dMd(v); s.e != s.i.gc(); ) { + r = RD(bMd(s), 123); + g = nTb(a, r, false, p, q); + ZEb(A.c, g); + t = r.i + p; + u = r.j + q; + m = (!r.n && (r.n = new C5d(I4, r, 1, 7)), r.n); + for (k = new dMd(m); k.e != k.i.gc(); ) { + j = RD(bMd(k), 135); + e = nTb(a, j, false, t, u); + ZEb(A.c, e); + } + } + ye(i2, Ux(Al(cD(WC(cJ, 1), rve, 20, 0, [zGd(n), yGd(n)])))); + } + mTb(a, i2, A); + } + a.f = new TRb(w2); + kQb(a.f, b); + return a.f; + } + function Yje(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2; + for (l = new Dub(new wub(a)); l.c != l.d.a.d; ) { + k = Cub(l); + h = RD(k.d, 58); + b = RD(k.e, 58); + g = h.Dh(); + for (p = 0, u = (g.i == null && rYd(g), g.i).length; p < u; ++p) { + j = (f2 = (g.i == null && rYd(g), g.i), p >= 0 && p < f2.length ? f2[p] : null); + if (j.rk() && !j.sk()) { + if (ZD(j, 102)) { + i2 = RD(j, 19); + (i2.Bb & QHe) == 0 && (w2 = Z5d(i2), !(!!w2 && (w2.Bb & QHe) != 0)) && Xje(a, i2, h, b); + } else { + nke(); + if (RD(j, 69).xk()) { + c2 = (v = j, RD(!v ? null : RD(b, 54).gi(v), 160)); + if (c2) { + n = RD(h.Mh(j), 160); + d = c2.gc(); + for (q = 0, o2 = n.gc(); q < o2; ++q) { + m = n.Tl(q); + if (ZD(m, 102)) { + t = n.Ul(q); + e = cub(a, t); + if (e == null && t != null) { + s = RD(m, 19); + if (!a.b || (s.Bb & QHe) != 0 || !!Z5d(s)) { + continue; + } + e = t; + } + if (!c2.Ol(m, e)) { + for (r = 0; r < d; ++r) { + if (c2.Tl(r) == m && dE(c2.Ul(r)) === dE(e)) { + c2.Ti(c2.gc() - 1, r); + --d; + break; + } + } + } + } else { + c2.Ol(n.Tl(q), n.Ul(q)); + } + } + } + } + } + } + } + } + } + function gIc(a, b, c2) { + var d; + c2.Ug("StretchWidth layering", 1); + if (b.a.c.length == 0) { + c2.Vg(); + return; + } + a.c = b; + a.t = 0; + a.u = 0; + a.i = oxe; + a.g = pxe; + a.d = Kfb(UD(mQb(b, (yCc(), TBc)))); + aIc(a); + bIc(a); + $Hc(a); + fIc(a); + _Hc(a); + a.i = $wnd.Math.max(1, a.i); + a.g = $wnd.Math.max(1, a.g); + a.d = a.d / a.i; + a.f = a.g / a.i; + a.s = dIc(a); + d = new R4b(a.c); + Rmb(a.c.b, d); + a.r = bv(a.p); + a.n = Fnb(a.k, a.k.length); + while (a.r.c.length != 0) { + a.o = hIc(a); + if (!a.o || cIc(a) && a.b.a.gc() != 0) { + iIc(a, d); + d = new R4b(a.c); + Rmb(a.c.b, d); + ye(a.a, a.b); + a.b.a.$b(); + a.t = a.u; + a.u = 0; + } else { + if (cIc(a)) { + a.c.b.c.length = 0; + d = new R4b(a.c); + Rmb(a.c.b, d); + a.t = 0; + a.u = 0; + a.b.a.$b(); + a.a.a.$b(); + ++a.f; + a.r = bv(a.p); + a.n = Fnb(a.k, a.k.length); + } else { + g3b(a.o, d); + Ymb(a.r, a.o); + Ysb(a.b, a.o); + a.t = a.t - a.k[a.o.p] * a.d + a.j[a.o.p]; + a.u += a.e[a.o.p] * a.d; + } + } + } + b.a.c.length = 0; + Eob(b.b); + c2.Vg(); + } + function sOc(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l; + a.j = $C(kE, Pwe, 28, a.g, 15, 1); + a.o = new bnb(); + FDb(EDb(new SDb(null, new Swb(a.e.b, 16)), new APc()), new CPc(a)); + a.a = $C(xdb, Hye, 28, a.b, 16, 1); + MDb(new SDb(null, new Swb(a.e.b, 16)), new RPc(a)); + d = (l = new bnb(), FDb(CDb(EDb(new SDb(null, new Swb(a.e.b, 16)), new HPc()), new JPc(a)), new LPc(a, l)), l); + for (i2 = new Anb(d); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 515); + if (h.c.length <= 1) { + continue; + } + if (h.c.length == 2) { + UOc(h); + BOc((tFb(0, h.c.length), RD(h.c[0], 18)).d.i) || Rmb(a.o, h); + continue; + } + if (TOc(h) || SOc(h, new FPc())) { + continue; + } + j = new Anb(h); + e = null; + while (j.a < j.c.c.length) { + b = RD(ynb(j), 18); + c2 = a.c[b.p]; + !e || j.a >= j.c.c.length ? k = hOc((r3b(), p3b), o3b) : k = hOc((r3b(), o3b), o3b); + k *= 2; + f2 = c2.a.g; + c2.a.g = $wnd.Math.max(f2, f2 + (k - f2)); + g = c2.b.g; + c2.b.g = $wnd.Math.max(g, g + (k - g)); + e = b; + } + } + } + function qkc(a) { + var b, c2, d, e; + FDb(CDb(new SDb(null, new Swb(a.a.b, 16)), new Qkc()), new Skc()); + okc(a); + FDb(CDb(new SDb(null, new Swb(a.a.b, 16)), new Ukc()), new Wkc()); + if (a.c == (Ymd(), Wmd)) { + FDb(CDb(EDb(new SDb(null, new Swb(new Xkb(a.f), 1)), new clc()), new elc()), new glc(a)); + FDb(CDb(GDb(EDb(EDb(new SDb(null, new Swb(a.d.b, 16)), new klc()), new mlc()), new olc()), new qlc()), new slc(a)); + } + e = new rjd(oxe, oxe); + b = new rjd(pxe, pxe); + for (d = new Anb(a.a.b); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 60); + e.a = $wnd.Math.min(e.a, c2.d.c); + e.b = $wnd.Math.min(e.b, c2.d.d); + b.a = $wnd.Math.max(b.a, c2.d.c + c2.d.b); + b.b = $wnd.Math.max(b.b, c2.d.d + c2.d.a); + } + $id(hjd(a.d.c), fjd(new rjd(e.a, e.b))); + $id(hjd(a.d.f), ojd(new rjd(b.a, b.b), e)); + pkc(a, e, b); + akb(a.f); + akb(a.b); + akb(a.g); + akb(a.e); + a.a.a.c.length = 0; + a.a.b.c.length = 0; + a.a = null; + a.d = null; + } + function JGb(a, b) { + var c2; + if (a.e) { + throw Adb(new dgb((lfb(lN), lye + lN.k + mye))); + } + if (!cGb(a.a, b)) { + throw Adb(new yz(nye + b + oye)); + } + if (b == a.d) { + return a; + } + c2 = a.d; + a.d = b; + switch (c2.g) { + case 0: + switch (b.g) { + case 2: + GGb(a); + break; + case 1: + OGb(a); + GGb(a); + break; + case 4: + UGb(a); + GGb(a); + break; + case 3: + UGb(a); + OGb(a); + GGb(a); + } + break; + case 2: + switch (b.g) { + case 1: + OGb(a); + PGb(a); + break; + case 4: + UGb(a); + GGb(a); + break; + case 3: + UGb(a); + OGb(a); + GGb(a); + } + break; + case 1: + switch (b.g) { + case 2: + OGb(a); + PGb(a); + break; + case 4: + OGb(a); + UGb(a); + GGb(a); + break; + case 3: + OGb(a); + UGb(a); + OGb(a); + GGb(a); + } + break; + case 4: + switch (b.g) { + case 2: + UGb(a); + GGb(a); + break; + case 1: + UGb(a); + OGb(a); + GGb(a); + break; + case 3: + OGb(a); + PGb(a); + } + break; + case 3: + switch (b.g) { + case 2: + OGb(a); + UGb(a); + GGb(a); + break; + case 1: + OGb(a); + UGb(a); + OGb(a); + GGb(a); + break; + case 4: + OGb(a); + PGb(a); + } + } + return a; + } + function vYb(a, b) { + var c2; + if (a.d) { + throw Adb(new dgb((lfb(eQ), lye + eQ.k + mye))); + } + if (!eYb(a.a, b)) { + throw Adb(new yz(nye + b + oye)); + } + if (b == a.c) { + return a; + } + c2 = a.c; + a.c = b; + switch (c2.g) { + case 0: + switch (b.g) { + case 2: + sYb(a); + break; + case 1: + zYb(a); + sYb(a); + break; + case 4: + DYb(a); + sYb(a); + break; + case 3: + DYb(a); + zYb(a); + sYb(a); + } + break; + case 2: + switch (b.g) { + case 1: + zYb(a); + AYb(a); + break; + case 4: + DYb(a); + sYb(a); + break; + case 3: + DYb(a); + zYb(a); + sYb(a); + } + break; + case 1: + switch (b.g) { + case 2: + zYb(a); + AYb(a); + break; + case 4: + zYb(a); + DYb(a); + sYb(a); + break; + case 3: + zYb(a); + DYb(a); + zYb(a); + sYb(a); + } + break; + case 4: + switch (b.g) { + case 2: + DYb(a); + sYb(a); + break; + case 1: + DYb(a); + zYb(a); + sYb(a); + break; + case 3: + zYb(a); + AYb(a); + } + break; + case 3: + switch (b.g) { + case 2: + zYb(a); + DYb(a); + sYb(a); + break; + case 1: + zYb(a); + DYb(a); + zYb(a); + sYb(a); + break; + case 4: + zYb(a); + AYb(a); + } + } + return a; + } + function Csd(a, b) { + var c2, d, e, f2, g, h, i2, j; + if (ZD(a.Eh(), 167)) { + Csd(RD(a.Eh(), 167), b); + b.a += " > "; + } else { + b.a += "Root "; + } + c2 = a.Dh().zb; + lhb(c2.substr(0, 3), "Elk") ? Zhb(b, (BFb(3, c2.length + 1), c2.substr(3))) : (b.a += "" + c2, b); + e = a.jh(); + if (e) { + Zhb((b.a += " ", b), e); + return; + } + if (ZD(a, 366)) { + j = RD(a, 135).a; + if (j) { + Zhb((b.a += " ", b), j); + return; + } + } + for (g = new dMd(a.kh()); g.e != g.i.gc(); ) { + f2 = RD(bMd(g), 135); + j = f2.a; + if (j) { + Zhb((b.a += " ", b), j); + return; + } + } + if (ZD(a, 326)) { + d = RD(a, 74); + !d.b && (d.b = new Yie(E4, d, 4, 7)); + if (d.b.i != 0 && (!d.c && (d.c = new Yie(E4, d, 5, 8)), d.c.i != 0)) { + b.a += " ("; + h = new mMd((!d.b && (d.b = new Yie(E4, d, 4, 7)), d.b)); + while (h.e != h.i.gc()) { + h.e > 0 && (b.a += pve, b); + Csd(RD(bMd(h), 167), b); + } + b.a += SAe; + i2 = new mMd((!d.c && (d.c = new Yie(E4, d, 5, 8)), d.c)); + while (i2.e != i2.i.gc()) { + i2.e > 0 && (b.a += pve, b); + Csd(RD(bMd(i2), 167), b); + } + b.a += ")"; + } + } + } + function LTb(a, b, c2) { + var d, e, f2, g, h, i2, j, k; + for (i2 = new dMd((!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a)); i2.e != i2.i.gc(); ) { + h = RD(bMd(i2), 27); + for (e = new is(Mr(zGd(h).a.Kc(), new ir())); gs(e); ) { + d = RD(hs(e), 74); + !d.b && (d.b = new Yie(E4, d, 4, 7)); + if (!(d.b.i <= 1 && (!d.c && (d.c = new Yie(E4, d, 5, 8)), d.c.i <= 1))) { + throw Adb(new Ked("Graph must not contain hyperedges.")); + } + if (!nzd(d) && h != AGd(RD(QHd((!d.c && (d.c = new Yie(E4, d, 5, 8)), d.c), 0), 84))) { + j = new cUb(); + kQb(j, d); + pQb(j, (JVb(), HVb), d); + _Tb(j, RD(Wd(qtb(c2.f, h)), 153)); + aUb(j, RD(Wjb(c2, AGd(RD(QHd((!d.c && (d.c = new Yie(E4, d, 5, 8)), d.c), 0), 84))), 153)); + Rmb(b.c, j); + for (g = new dMd((!d.n && (d.n = new C5d(I4, d, 1, 7)), d.n)); g.e != g.i.gc(); ) { + f2 = RD(bMd(g), 135); + k = new iUb(j, f2.a); + kQb(k, f2); + pQb(k, HVb, f2); + k.e.a = $wnd.Math.max(f2.g, 1); + k.e.b = $wnd.Math.max(f2.f, 1); + hUb(k); + Rmb(b.d, k); + } + } + } + } + } + function Vec(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m; + c2.Ug("Node promotion heuristic", 1); + a.i = b; + a.r = RD(mQb(b, (yCc(), ZAc)), 243); + a.r != (aEc(), TDc) && a.r != UDc ? Tec(a) : Uec(a); + k = RD(mQb(a.i, YAc), 17).a; + f2 = new nfc(); + switch (a.r.g) { + case 2: + case 1: + Yec(a, f2); + break; + case 3: + a.r = _Dc; + Yec(a, f2); + i2 = 0; + for (h = new Anb(a.b); h.a < h.c.c.length; ) { + g = RD(ynb(h), 17); + i2 = $wnd.Math.max(i2, g.a); + } + if (i2 > a.k) { + a.r = VDc; + Yec(a, f2); + } + break; + case 4: + a.r = _Dc; + Yec(a, f2); + j = 0; + for (e = new Anb(a.c); e.a < e.c.c.length; ) { + d = UD(ynb(e)); + j = $wnd.Math.max(j, (uFb(d), d)); + } + if (j > a.n) { + a.r = YDc; + Yec(a, f2); + } + break; + case 6: + m = eE($wnd.Math.ceil(a.g.length * k / 100)); + Yec(a, new qfc(m)); + break; + case 5: + l = eE($wnd.Math.ceil(a.e * k / 100)); + Yec(a, new tfc(l)); + break; + case 8: + Sec(a, true); + break; + case 9: + Sec(a, false); + break; + default: + Yec(a, f2); + } + a.r != TDc && a.r != UDc ? Zec(a, b) : $ec(a, b); + c2.Vg(); + } + function $rc(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t; + l = a.b; + k = new Jkb(l, 0); + Ikb(k, new R4b(a)); + s = false; + g = 1; + while (k.b < k.d.gc()) { + j = (sFb(k.b < k.d.gc()), RD(k.d.Xb(k.c = k.b++), 30)); + p = (tFb(g, l.c.length), RD(l.c[g], 30)); + q = bv(j.a); + r = q.c.length; + for (o2 = new Anb(q); o2.a < o2.c.c.length; ) { + m = RD(ynb(o2), 10); + g3b(m, p); + } + if (s) { + for (n = hv(q).Kc(); n.Ob(); ) { + m = RD(n.Pb(), 10); + for (f2 = new Anb(bv(Z2b(m))); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 18); + X0b(e, true); + pQb(a, (Ywc(), awc), (Geb(), true)); + d = osc(a, e, r); + c2 = RD(mQb(m, Wvc), 313); + t = RD(Vmb(d, d.c.length - 1), 18); + c2.k = t.c.i; + c2.n = t; + c2.b = e.d.i; + c2.c = e; + } + } + s = false; + } else { + if (q.c.length != 0) { + b = (tFb(0, q.c.length), RD(q.c[0], 10)); + if (b.k == (r3b(), l3b)) { + s = true; + g = -1; + } + } + } + ++g; + } + h = new Jkb(a.b, 0); + while (h.b < h.d.gc()) { + i2 = (sFb(h.b < h.d.gc()), RD(h.d.Xb(h.c = h.b++), 30)); + i2.a.c.length == 0 && Ckb(h); + } + } + function FJb(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t; + l = new CLb(a); + _Mb(l, !(b == (Cmd(), Bmd) || b == xmd)); + k = l.a; + m = new z3b(); + for (e = (ZJb(), cD(WC(JN, 1), jwe, 237, 0, [WJb, XJb, YJb])), g = 0, i2 = e.length; g < i2; ++g) { + c2 = e[g]; + j = oKb(k, WJb, c2); + !!j && (m.d = $wnd.Math.max(m.d, j.jf())); + } + for (d = cD(WC(JN, 1), jwe, 237, 0, [WJb, XJb, YJb]), f2 = 0, h = d.length; f2 < h; ++f2) { + c2 = d[f2]; + j = oKb(k, YJb, c2); + !!j && (m.a = $wnd.Math.max(m.a, j.jf())); + } + for (p = cD(WC(JN, 1), jwe, 237, 0, [WJb, XJb, YJb]), r = 0, t = p.length; r < t; ++r) { + n = p[r]; + j = oKb(k, n, WJb); + !!j && (m.b = $wnd.Math.max(m.b, j.kf())); + } + for (o2 = cD(WC(JN, 1), jwe, 237, 0, [WJb, XJb, YJb]), q = 0, s = o2.length; q < s; ++q) { + n = o2[q]; + j = oKb(k, n, YJb); + !!j && (m.c = $wnd.Math.max(m.c, j.kf())); + } + if (m.d > 0) { + m.d += k.n.d; + m.d += k.d; + } + if (m.a > 0) { + m.a += k.n.a; + m.a += k.d; + } + if (m.b > 0) { + m.b += k.n.b; + m.b += k.d; + } + if (m.c > 0) { + m.c += k.n.c; + m.c += k.d; + } + return m; + } + function u9b(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2; + m = c2.d; + l = c2.c; + f2 = new rjd(c2.f.a + c2.d.b + c2.d.c, c2.f.b + c2.d.d + c2.d.a); + g = f2.b; + for (j = new Anb(a.a); j.a < j.c.c.length; ) { + h = RD(ynb(j), 10); + if (h.k != (r3b(), m3b)) { + continue; + } + d = RD(mQb(h, (Ywc(), hwc)), 64); + e = RD(mQb(h, iwc), 8); + k = h.n; + switch (d.g) { + case 2: + k.a = c2.f.a + m.c - l.a; + break; + case 4: + k.a = -l.a - m.b; + } + o2 = 0; + switch (d.g) { + case 2: + case 4: + if (b == (Bod(), xod)) { + n = Kfb(UD(mQb(h, Jwc))); + k.b = f2.b * n - RD(mQb(h, (yCc(), zBc)), 8).b; + o2 = k.b + e.b; + U2b(h, false, true); + } else if (b == wod) { + k.b = Kfb(UD(mQb(h, Jwc))) - RD(mQb(h, (yCc(), zBc)), 8).b; + o2 = k.b + e.b; + U2b(h, false, true); + } + } + g = $wnd.Math.max(g, o2); + } + c2.f.b += g - f2.b; + for (i2 = new Anb(a.a); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 10); + if (h.k != (r3b(), m3b)) { + continue; + } + d = RD(mQb(h, (Ywc(), hwc)), 64); + k = h.n; + switch (d.g) { + case 1: + k.b = -l.b - m.d; + break; + case 3: + k.b = c2.f.b + m.a - l.b; + } + } + } + function nNb(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r; + k = RD(RD(Qc(a.r, b), 21), 87); + if (k.gc() <= 2 || b == (qpd(), Xod) || b == (qpd(), ppd)) { + rNb(a, b); + return; + } + p = a.u.Hc((Pod(), Ood)); + c2 = b == (qpd(), Yod) ? (mOb(), lOb) : (mOb(), iOb); + r = b == Yod ? (vLb(), sLb) : (vLb(), uLb); + d = WNb(_Nb(c2), a.s); + q = b == Yod ? oxe : pxe; + for (j = k.Kc(); j.Ob(); ) { + h = RD(j.Pb(), 117); + if (!h.c || h.c.d.c.length <= 0) { + continue; + } + o2 = h.b.Mf(); + n = h.e; + l = h.c; + m = l.i; + m.b = (f2 = l.n, l.e.a + f2.b + f2.c); + m.a = (g = l.n, l.e.b + g.d + g.a); + if (p) { + m.c = n.a - (e = l.n, l.e.a + e.b + e.c) - a.s; + p = false; + } else { + m.c = n.a + o2.a + a.s; + } + Ivb(r, Pye); + l.f = r; + RKb(l, (EKb(), DKb)); + Rmb(d.d, new sOb(m, UNb(d, m))); + q = b == Yod ? $wnd.Math.min(q, n.b) : $wnd.Math.max(q, n.b + h.b.Mf().b); + } + q += b == Yod ? -a.t : a.t; + VNb((d.e = q, d)); + for (i2 = k.Kc(); i2.Ob(); ) { + h = RD(i2.Pb(), 117); + if (!h.c || h.c.d.c.length <= 0) { + continue; + } + m = h.c.i; + m.c -= h.e.a; + m.d -= h.e.b; + } + } + function D0b(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t; + e = new bnb(); + for (p = new Anb(b.a); p.a < p.c.c.length; ) { + o2 = RD(ynb(p), 10); + n = o2.e; + if (n) { + d = D0b(a, n, o2); + Tmb(e, d); + A0b(a, n, o2); + if (RD(mQb(n, (Ywc(), kwc)), 21).Hc((ovc(), hvc))) { + s = RD(mQb(o2, (yCc(), BBc)), 101); + m = RD(mQb(o2, EBc), 181).Hc((Pod(), Lod)); + for (r = new Anb(o2.j); r.a < r.c.c.length; ) { + q = RD(ynb(r), 12); + f2 = RD(Wjb(a.b, q), 10); + if (!f2) { + f2 = f2b(q, s, q.j, -(q.e.c.length - q.g.c.length), null, new pjd(), q.o, RD(mQb(n, rAc), 88), n); + pQb(f2, Awc, q); + Zjb(a.b, q, f2); + Rmb(n.a, f2); + } + g = RD(Vmb(f2.j, 0), 12); + for (k = new Anb(q.f); k.a < k.c.c.length; ) { + j = RD(ynb(k), 72); + h = new x2b(); + h.o.a = j.o.a; + h.o.b = j.o.b; + Rmb(g.f, h); + if (!m) { + t = q.j; + l = 0; + Rod(RD(mQb(o2, EBc), 21)) && (l = qsd(j.n, j.o, q.o, 0, t)); + s == (Bod(), zod) || (qpd(), apd).Hc(t) ? h.o.a = l : h.o.b = l; + } + } + } + } + } + } + i2 = new bnb(); + z0b(a, b, c2, e, i2); + !!c2 && B0b(a, b, c2, i2); + return i2; + } + function NIc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l; + if (a.c[b.c.p][b.p].e) { + return; + } else { + a.c[b.c.p][b.p].e = true; + } + a.c[b.c.p][b.p].b = 0; + a.c[b.c.p][b.p].d = 0; + a.c[b.c.p][b.p].a = null; + for (k = new Anb(b.j); k.a < k.c.c.length; ) { + j = RD(ynb(k), 12); + l = c2 ? new T3b(j) : new _3b(j); + for (i2 = l.Kc(); i2.Ob(); ) { + h = RD(i2.Pb(), 12); + g = h.i; + if (g.c == b.c) { + if (g != b) { + NIc(a, g, c2); + a.c[b.c.p][b.p].b += a.c[g.c.p][g.p].b; + a.c[b.c.p][b.p].d += a.c[g.c.p][g.p].d; + } + } else { + a.c[b.c.p][b.p].d += a.g[h.p]; + ++a.c[b.c.p][b.p].b; + } + } + } + f2 = RD(mQb(b, (Ywc(), Uvc)), 15); + if (f2) { + for (e = f2.Kc(); e.Ob(); ) { + d = RD(e.Pb(), 10); + if (b.c == d.c) { + NIc(a, d, c2); + a.c[b.c.p][b.p].b += a.c[d.c.p][d.p].b; + a.c[b.c.p][b.p].d += a.c[d.c.p][d.p].d; + } + } + } + if (a.c[b.c.p][b.p].b > 0) { + a.c[b.c.p][b.p].d += Kwb(a.i, 24) * Nxe * 0.07000000029802322 - 0.03500000014901161; + a.c[b.c.p][b.p].a = a.c[b.c.p][b.p].d / a.c[b.c.p][b.p].b; + } + } + function D8b(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q; + for (o2 = new Anb(a); o2.a < o2.c.c.length; ) { + n = RD(ynb(o2), 10); + E8b(n.n); + E8b(n.o); + F8b(n.f); + I8b(n); + K8b(n); + for (q = new Anb(n.j); q.a < q.c.c.length; ) { + p = RD(ynb(q), 12); + E8b(p.n); + E8b(p.a); + E8b(p.o); + Q3b(p, J8b(p.j)); + f2 = RD(mQb(p, (yCc(), CBc)), 17); + !!f2 && pQb(p, CBc, sgb(-f2.a)); + for (e = new Anb(p.g); e.a < e.c.c.length; ) { + d = RD(ynb(e), 18); + for (c2 = Sub(d.a, 0); c2.b != c2.d.c; ) { + b = RD(evb(c2), 8); + E8b(b); + } + i2 = RD(mQb(d, RAc), 75); + if (i2) { + for (h = Sub(i2, 0); h.b != h.d.c; ) { + g = RD(evb(h), 8); + E8b(g); + } + } + for (l = new Anb(d.b); l.a < l.c.c.length; ) { + j = RD(ynb(l), 72); + E8b(j.n); + E8b(j.o); + } + } + for (m = new Anb(p.f); m.a < m.c.c.length; ) { + j = RD(ynb(m), 72); + E8b(j.n); + E8b(j.o); + } + } + if (n.k == (r3b(), m3b)) { + pQb(n, (Ywc(), hwc), J8b(RD(mQb(n, hwc), 64))); + H8b(n); + } + for (k = new Anb(n.b); k.a < k.c.c.length; ) { + j = RD(ynb(k), 72); + I8b(j); + E8b(j.o); + E8b(j.n); + } + } + } + function iEd(a, b, c2, d, e) { + var f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5, F, G; + D5 = Wjb(a.e, d); + if (D5 == null) { + D5 = new uC(); + n = RD(D5, 190); + s = b + "_s"; + t = s + e; + m = new OC(t); + sC(n, uIe, m); + } + C = RD(D5, 190); + oDd(c2, C); + G = new uC(); + qDd(G, "x", d.j); + qDd(G, "y", d.k); + sC(C, xIe, G); + A = new uC(); + qDd(A, "x", d.b); + qDd(A, "y", d.c); + sC(C, "endPoint", A); + l = cve((!d.a && (d.a = new XZd(D4, d, 5)), d.a)); + o2 = !l; + if (o2) { + w2 = new MB(); + f2 = new qFd(w2); + xgb((!d.a && (d.a = new XZd(D4, d, 5)), d.a), f2); + sC(C, nIe, w2); + } + i2 = Dzd(d); + u = !!i2; + u && rDd(a.a, C, pIe, KDd(a, Dzd(d))); + r = Ezd(d); + v = !!r; + v && rDd(a.a, C, oIe, KDd(a, Ezd(d))); + j = (!d.e && (d.e = new Yie(F4, d, 10, 9)), d.e).i == 0; + p = !j; + if (p) { + B = new MB(); + g = new sFd(a, B); + xgb((!d.e && (d.e = new Yie(F4, d, 10, 9)), d.e), g); + sC(C, rIe, B); + } + k = (!d.g && (d.g = new Yie(F4, d, 9, 10)), d.g).i == 0; + q = !k; + if (q) { + F = new MB(); + h = new uFd(a, F); + xgb((!d.g && (d.g = new Yie(F4, d, 9, 10)), d.g), h); + sC(C, qIe, F); + } + } + function XMb(a) { + RMb(); + var b, c2, d, e, f2, g, h; + d = a.f.n; + for (g = ki(a.r).a.nc(); g.Ob(); ) { + f2 = RD(g.Pb(), 117); + e = 0; + if (f2.b.pf((umd(), Gld))) { + e = Kfb(UD(f2.b.of(Gld))); + if (e < 0) { + switch (f2.b.ag().g) { + case 1: + d.d = $wnd.Math.max(d.d, -e); + break; + case 3: + d.a = $wnd.Math.max(d.a, -e); + break; + case 2: + d.c = $wnd.Math.max(d.c, -e); + break; + case 4: + d.b = $wnd.Math.max(d.b, -e); + } + } + } + if (Rod(a.u)) { + b = rsd(f2.b, e); + h = !RD(a.e.of(pld), 181).Hc((dqd(), Wpd)); + c2 = false; + switch (f2.b.ag().g) { + case 1: + c2 = b > d.d; + d.d = $wnd.Math.max(d.d, b); + if (h && c2) { + d.d = $wnd.Math.max(d.d, d.a); + d.a = d.d + e; + } + break; + case 3: + c2 = b > d.a; + d.a = $wnd.Math.max(d.a, b); + if (h && c2) { + d.a = $wnd.Math.max(d.a, d.d); + d.d = d.a + e; + } + break; + case 2: + c2 = b > d.c; + d.c = $wnd.Math.max(d.c, b); + if (h && c2) { + d.c = $wnd.Math.max(d.b, d.c); + d.b = d.c + e; + } + break; + case 4: + c2 = b > d.b; + d.b = $wnd.Math.max(d.b, b); + if (h && c2) { + d.b = $wnd.Math.max(d.b, d.c); + d.c = d.b + e; + } + } + } + } + } + function pA(a, b) { + var c2, d, e, f2, g, h, i2, j, k; + j = ""; + if (b.length == 0) { + return a.ne(ywe, wwe, -1, -1); + } + k = Dhb(b); + lhb(k.substr(0, 3), "at ") && (k = (BFb(3, k.length + 1), k.substr(3))); + k = k.replace(/\[.*?\]/g, ""); + g = k.indexOf("("); + if (g == -1) { + g = k.indexOf("@"); + if (g == -1) { + j = k; + k = ""; + } else { + j = Dhb((BFb(g + 1, k.length + 1), k.substr(g + 1))); + k = Dhb((AFb(0, g, k.length), k.substr(0, g))); + } + } else { + c2 = k.indexOf(")", g); + j = (AFb(g + 1, c2, k.length), k.substr(g + 1, c2 - (g + 1))); + k = Dhb((AFb(0, g, k.length), k.substr(0, g))); + } + g = qhb(k, Fhb(46)); + g != -1 && (k = (BFb(g + 1, k.length + 1), k.substr(g + 1))); + (k.length == 0 || lhb(k, "Anonymous function")) && (k = wwe); + h = thb(j, Fhb(58)); + e = uhb(j, Fhb(58), h - 1); + i2 = -1; + d = -1; + f2 = ywe; + if (h != -1 && e != -1) { + f2 = (AFb(0, e, j.length), j.substr(0, e)); + i2 = jA((AFb(e + 1, h, j.length), j.substr(e + 1, h - (e + 1)))); + d = jA((BFb(h + 1, j.length + 1), j.substr(h + 1))); + } + return a.ne(f2, k, i2, d); + } + function C6b(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l; + for (j = new Anb(a); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 10); + g = RD(mQb(i2, (yCc(), UAc)), 171); + f2 = null; + switch (g.g) { + case 1: + case 2: + f2 = (huc(), guc); + break; + case 3: + case 4: + f2 = (huc(), euc); + } + if (f2) { + pQb(i2, (Ywc(), bwc), (huc(), guc)); + f2 == euc ? F6b(i2, g, (BEc(), yEc)) : f2 == guc && F6b(i2, g, (BEc(), zEc)); + } else { + if (Dod(RD(mQb(i2, BBc), 101)) && i2.j.c.length != 0) { + b = true; + for (l = new Anb(i2.j); l.a < l.c.c.length; ) { + k = RD(ynb(l), 12); + if (!(k.j == (qpd(), Xod) && k.e.c.length - k.g.c.length > 0 || k.j == ppd && k.e.c.length - k.g.c.length < 0)) { + b = false; + break; + } + for (e = new Anb(k.g); e.a < e.c.c.length; ) { + c2 = RD(ynb(e), 18); + h = RD(mQb(c2.d.i, UAc), 171); + if (h == (cxc(), _wc) || h == axc) { + b = false; + break; + } + } + for (d = new Anb(k.e); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 18); + h = RD(mQb(c2.c.i, UAc), 171); + if (h == (cxc(), Zwc) || h == $wc) { + b = false; + break; + } + } + } + b && F6b(i2, g, (BEc(), AEc)); + } + } + } + } + function LNc(a, b, c2, d, e) { + var f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2; + w2 = 0; + n = 0; + for (l = new Anb(b.e); l.a < l.c.c.length; ) { + k = RD(ynb(l), 10); + m = 0; + h = 0; + i2 = c2 ? RD(mQb(k, HNc), 17).a : qwe; + r = d ? RD(mQb(k, INc), 17).a : qwe; + j = $wnd.Math.max(i2, r); + for (t = new Anb(k.j); t.a < t.c.c.length; ) { + s = RD(ynb(t), 12); + u = k.n.b + s.n.b + s.a.b; + if (d) { + for (g = new Anb(s.g); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 18); + p = f2.d; + o2 = p.i; + if (b != a.a[o2.p]) { + q = $wnd.Math.max(RD(mQb(o2, HNc), 17).a, RD(mQb(o2, INc), 17).a); + v = RD(mQb(f2, (yCc(), MBc)), 17).a; + if (v >= j && v >= q) { + m += o2.n.b + p.n.b + p.a.b - u; + ++h; + } + } + } + } + if (c2) { + for (g = new Anb(s.e); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 18); + p = f2.c; + o2 = p.i; + if (b != a.a[o2.p]) { + q = $wnd.Math.max(RD(mQb(o2, HNc), 17).a, RD(mQb(o2, INc), 17).a); + v = RD(mQb(f2, (yCc(), MBc)), 17).a; + if (v >= j && v >= q) { + m += o2.n.b + p.n.b + p.a.b - u; + ++h; + } + } + } + } + } + if (h > 0) { + w2 += m / h; + ++n; + } + } + if (n > 0) { + b.a = e * w2 / n; + b.g = n; + } else { + b.a = 0; + b.g = 0; + } + } + function hTb(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A; + f2 = a.f.b; + m = f2.a; + k = f2.b; + o2 = a.e.g; + n = a.e.f; + zyd(a.e, f2.a, f2.b); + w2 = m / o2; + A = k / n; + for (j = new dMd(iyd(a.e)); j.e != j.i.gc(); ) { + i2 = RD(bMd(j), 135); + Dyd(i2, i2.i * w2); + Eyd(i2, i2.j * A); + } + for (s = new dMd(wCd(a.e)); s.e != s.i.gc(); ) { + r = RD(bMd(s), 123); + u = r.i; + v = r.j; + u > 0 && Dyd(r, u * w2); + v > 0 && Eyd(r, v * A); + } + Bvb(a.b, new tTb()); + b = new bnb(); + for (h = new vkb(new mkb(a.c).a); h.b; ) { + g = tkb(h); + d = RD(g.ld(), 74); + c2 = RD(g.md(), 407).a; + e = IGd(d, false, false); + l = fTb(JGd(d), ssd(e), c2); + lsd(l, e); + t = KGd(d); + if (!!t && Wmb(b, t, 0) == -1) { + ZEb(b.c, t); + gTb(t, (sFb(l.b != 0), RD(l.a.a.c, 8)), c2); + } + } + for (q = new vkb(new mkb(a.d).a); q.b; ) { + p = tkb(q); + d = RD(p.ld(), 74); + c2 = RD(p.md(), 407).a; + e = IGd(d, false, false); + l = fTb(LGd(d), Ijd(ssd(e)), c2); + l = Ijd(l); + lsd(l, e); + t = MGd(d); + if (!!t && Wmb(b, t, 0) == -1) { + ZEb(b.c, t); + gTb(t, (sFb(l.b != 0), RD(l.c.b.c, 8)), c2); + } + } + } + function GJb(a, b, c2, d) { + var e, f2, g, h, i2; + h = new CLb(b); + iNb(h, d); + e = true; + if (!!a && a.pf((umd(), Nkd))) { + f2 = RD(a.of((umd(), Nkd)), 88); + e = f2 == (Cmd(), Amd) || f2 == ymd || f2 == zmd; + } + $Mb(h, false); + Umb(h.e.Rf(), new dNb(h, false, e)); + EMb(h, h.f, (ZJb(), WJb), (qpd(), Yod)); + EMb(h, h.f, YJb, npd); + EMb(h, h.g, WJb, ppd); + EMb(h, h.g, YJb, Xod); + GMb(h, Yod); + GMb(h, npd); + FMb(h, Xod); + FMb(h, ppd); + RMb(); + g = h.A.Hc((Qpd(), Mpd)) && h.B.Hc((dqd(), $pd)) ? SMb(h) : null; + !!g && uKb(h.a, g); + XMb(h); + xMb(h); + GNb(h); + sMb(h); + gNb(h); + yNb(h); + oNb(h, Yod); + oNb(h, npd); + tMb(h); + fNb(h); + if (!c2) { + return h.o; + } + VMb(h); + CNb(h); + oNb(h, Xod); + oNb(h, ppd); + i2 = h.B.Hc((dqd(), _pd)); + IMb(h, i2, Yod); + IMb(h, i2, npd); + JMb(h, i2, Xod); + JMb(h, i2, ppd); + FDb(new SDb(null, new Swb(new glb(h.i), 0)), new KMb()); + FDb(CDb(new SDb(null, ki(h.r).a.oc()), new MMb()), new OMb()); + WMb(h); + h.e.Pf(h.o); + FDb(new SDb(null, ki(h.r).a.oc()), new YMb()); + return h.o; + } + function LYb(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p; + j = oxe; + for (d = new Anb(a.a.b); d.a < d.c.c.length; ) { + b = RD(ynb(d), 86); + j = $wnd.Math.min(j, b.d.f.g.c + b.e.a); + } + n = new Yub(); + for (g = new Anb(a.a.a); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 194); + f2.i = j; + f2.e == 0 && (Pub(n, f2, n.c.b, n.c), true); + } + while (n.b != 0) { + f2 = RD(n.b == 0 ? null : (sFb(n.b != 0), Wub(n, n.a.a)), 194); + e = f2.f.g.c; + for (m = f2.a.a.ec().Kc(); m.Ob(); ) { + k = RD(m.Pb(), 86); + p = f2.i + k.e.a; + k.d.g || k.g.c < p ? k.o = p : k.o = k.g.c; + } + e -= f2.f.o; + f2.b += e; + a.c == (Cmd(), zmd) || a.c == xmd ? f2.c += e : f2.c -= e; + for (l = f2.a.a.ec().Kc(); l.Ob(); ) { + k = RD(l.Pb(), 86); + for (i2 = k.f.Kc(); i2.Ob(); ) { + h = RD(i2.Pb(), 86); + Dmd(a.c) ? o2 = a.f.yf(k, h) : o2 = a.f.zf(k, h); + h.d.i = $wnd.Math.max(h.d.i, k.o + k.g.b + o2 - h.e.a); + h.k || (h.d.i = $wnd.Math.max(h.d.i, h.g.c - h.e.a)); + --h.d.e; + h.d.e == 0 && Mub(n, h.d); + } + } + } + for (c2 = new Anb(a.a.b); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 86); + b.g.c = b.o; + } + } + function vOb(a) { + var b, c2, d, e, f2, g, h, i2; + h = a.b; + b = a.a; + switch (RD(mQb(a, (YHb(), UHb)), 435).g) { + case 0: + _mb(h, new Frb(new UOb())); + break; + case 1: + default: + _mb(h, new Frb(new ZOb())); + } + switch (RD(mQb(a, SHb), 436).g) { + case 1: + _mb(h, new POb()); + _mb(h, new cPb()); + _mb(h, new xOb()); + break; + case 0: + default: + _mb(h, new POb()); + _mb(h, new IOb()); + } + switch (RD(mQb(a, WHb), 257).g) { + case 0: + i2 = new wPb(); + break; + case 1: + i2 = new qPb(); + break; + case 2: + i2 = new tPb(); + break; + case 3: + i2 = new nPb(); + break; + case 5: + i2 = new APb(new tPb()); + break; + case 4: + i2 = new APb(new qPb()); + break; + case 7: + i2 = new kPb(new APb(new qPb()), new APb(new tPb())); + break; + case 8: + i2 = new kPb(new APb(new nPb()), new APb(new tPb())); + break; + case 6: + default: + i2 = new APb(new nPb()); + } + for (g = new Anb(h); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 176); + d = 0; + e = 0; + c2 = new Ptd(sgb(d), sgb(e)); + while (ZPb(b, f2, d, e)) { + c2 = RD(i2.Ve(c2, f2), 42); + d = RD(c2.a, 17).a; + e = RD(c2.b, 17).a; + } + WPb(b, f2, d, e); + } + } + function T_c(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2; + c2.Ug(_Ee, 1); + m = (q$c(), XZc); + a.a == (s_c(), p_c) && (m = VZc); + k = 0; + yob(); + b.jd(new uGd(m)); + f2 = b.gc(); + h = b.fd(b.gc()); + j = true; + while (j && h.Sb()) { + s = RD(h.Ub(), 40); + RD(mQb(s, m), 17).a == 0 ? --f2 : j = false; + } + w2 = b.kd(0, f2); + g = new Zub(w2); + w2 = b.kd(f2, b.gc()); + i2 = new Zub(w2); + if (g.b == 0) { + for (p = Sub(i2, 0); p.b != p.d.c; ) { + o2 = RD(evb(p), 40); + pQb(o2, i$c, sgb(k++)); + } + } else { + l = g.b; + for (v = Sub(g, 0); v.b != v.d.c; ) { + u = RD(evb(v), 40); + pQb(u, i$c, sgb(k++)); + d = $Wc(u); + T_c(a, d, c2.eh(1 / l | 0)); + tvb(d, Fob(new uGd(i$c))); + n = new Yub(); + for (t = Sub(d, 0); t.b != t.d.c; ) { + s = RD(evb(t), 40); + for (r = Sub(u.d, 0); r.b != r.d.c; ) { + q = RD(evb(r), 65); + q.c == s && (Pub(n, q, n.c.b, n.c), true); + } + } + Xub(u.d); + ye(u.d, n); + h = Sub(i2, i2.b); + e = u.d.b; + j = true; + while (0 < e && j && h.Sb()) { + s = RD(h.Ub(), 40); + if (RD(mQb(s, m), 17).a == 0) { + pQb(s, i$c, sgb(k++)); + --e; + h.Qb(); + } else { + j = false; + } + } + } + } + c2.Vg(); + } + function S3c(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n; + l = Kfb(UD(Gxd(a, ($4c(), W4c)))); + if (Heb(TD(Gxd(a, U4c)))) { + k = RD(Gxd(a, (u2c(), t2c)), 27); + f2 = RD(QHd(mzd(RD(QHd((!k.e && (k.e = new Yie(G4, k, 7, 4)), k.e), (!k.e && (k.e = new Yie(G4, k, 7, 4)), k.e).i - 1), 74)), 0), 27); + d = RD(QHd(mzd(RD(QHd((!k.e && (k.e = new Yie(G4, k, 7, 4)), k.e), 0), 74)), 0), 27); + g = new rjd(f2.i + f2.g / 2, f2.j + f2.f / 2); + e = new rjd(d.i + d.g / 2, d.j + d.f / 2); + c2 = l; + c2 <= 0 && (c2 += dFe); + m = $wnd.Math.acos((g.a * e.a + g.b * e.b) / ($wnd.Math.sqrt(g.a * g.a + g.b * g.b) * $wnd.Math.sqrt(e.a * e.a + e.b * e.b))); + m <= 0 && (m += dFe); + b = $wnd.Math.atan2(g.b, g.a); + b <= 0 && (b += dFe); + l = FEe - (b - c2 + m / 2); + } + for (i2 = new dMd((!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a)); i2.e != i2.i.gc(); ) { + h = RD(bMd(i2), 27); + j = new rjd(h.i + h.g / 2, h.j + h.f / 2); + n = j.a * $wnd.Math.cos(l) - j.b * $wnd.Math.sin(l); + j.b = j.a * $wnd.Math.sin(l) + j.b * $wnd.Math.cos(l); + j.a = n; + Byd(h, j.a - h.g / 2, j.b - h.f / 2); + } + } + function qcc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t; + b.Ug("Inverted port preprocessing", 1); + k = a.b; + j = new Jkb(k, 0); + c2 = null; + t = new bnb(); + while (j.b < j.d.gc()) { + s = c2; + c2 = (sFb(j.b < j.d.gc()), RD(j.d.Xb(j.c = j.b++), 30)); + for (n = new Anb(t); n.a < n.c.c.length; ) { + l = RD(ynb(n), 10); + g3b(l, s); + } + t.c.length = 0; + for (o2 = new Anb(c2.a); o2.a < o2.c.c.length; ) { + l = RD(ynb(o2), 10); + if (l.k != (r3b(), p3b)) { + continue; + } + if (!Dod(RD(mQb(l, (yCc(), BBc)), 101))) { + continue; + } + for (r = d3b(l, (BEc(), yEc), (qpd(), Xod)).Kc(); r.Ob(); ) { + p = RD(r.Pb(), 12); + i2 = p.e; + h = RD(anb(i2, $C(WQ, VAe, 18, i2.c.length, 0, 1)), 483); + for (e = h, f2 = 0, g = e.length; f2 < g; ++f2) { + d = e[f2]; + occ(a, p, d, t); + } + } + for (q = d3b(l, zEc, ppd).Kc(); q.Ob(); ) { + p = RD(q.Pb(), 12); + i2 = p.g; + h = RD(anb(i2, $C(WQ, VAe, 18, i2.c.length, 0, 1)), 483); + for (e = h, f2 = 0, g = e.length; f2 < g; ++f2) { + d = e[f2]; + pcc(a, p, d, t); + } + } + } + } + for (m = new Anb(t); m.a < m.c.c.length; ) { + l = RD(ynb(m), 10); + g3b(l, c2); + } + b.Vg(); + } + function NUc(a, b, c2, d, e, f2, g) { + var h, i2, j, k, l, m, n, o2, p, q, r, s, t; + m = null; + d == (dVc(), bVc) ? m = b : d == cVc && (m = c2); + for (p = m.a.ec().Kc(); p.Ob(); ) { + o2 = RD(p.Pb(), 12); + q = xjd(cD(WC(l3, 1), Nve, 8, 0, [o2.i.n, o2.n, o2.a])).b; + t = new _sb(); + h = new _sb(); + for (j = new l4b(o2.b); xnb(j.a) || xnb(j.b); ) { + i2 = RD(xnb(j.a) ? ynb(j.a) : ynb(j.b), 18); + if (Heb(TD(mQb(i2, (Ywc(), Nwc)))) != e) { + continue; + } + if (Wmb(f2, i2, 0) != -1) { + i2.d == o2 ? r = i2.c : r = i2.d; + s = xjd(cD(WC(l3, 1), Nve, 8, 0, [r.i.n, r.n, r.a])).b; + if ($wnd.Math.abs(s - q) < 0.2) { + continue; + } + s < q ? b.a._b(r) ? Ysb(t, new Ptd(bVc, i2)) : Ysb(t, new Ptd(cVc, i2)) : b.a._b(r) ? Ysb(h, new Ptd(bVc, i2)) : Ysb(h, new Ptd(cVc, i2)); + } + } + if (t.a.gc() > 1) { + n = new xVc(o2, t, d); + xgb(t, new nVc(a, n)); + ZEb(g.c, n); + for (l = t.a.ec().Kc(); l.Ob(); ) { + k = RD(l.Pb(), 42); + Ymb(f2, k.b); + } + } + if (h.a.gc() > 1) { + n = new xVc(o2, h, d); + xgb(h, new pVc(a, n)); + ZEb(g.c, n); + for (l = h.a.ec().Kc(); l.Ob(); ) { + k = RD(l.Pb(), 42); + Ymb(f2, k.b); + } + } + } + } + function p6b(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r; + p = a.n; + q = a.o; + m = a.d; + l = Kfb(UD(hFc(a, (yCc(), QBc)))); + if (b) { + k = l * (b.gc() - 1); + n = 0; + for (i2 = b.Kc(); i2.Ob(); ) { + g = RD(i2.Pb(), 10); + k += g.o.a; + n = $wnd.Math.max(n, g.o.b); + } + r = p.a - (k - q.a) / 2; + f2 = p.b - m.d + n; + d = q.a / (b.gc() + 1); + e = d; + for (h = b.Kc(); h.Ob(); ) { + g = RD(h.Pb(), 10); + g.n.a = r; + g.n.b = f2 - g.o.b; + r += g.o.a + l; + j = n6b(g); + j.n.a = g.o.a / 2 - j.a.a; + j.n.b = g.o.b; + o2 = RD(mQb(g, (Ywc(), Xvc)), 12); + if (o2.e.c.length + o2.g.c.length == 1) { + o2.n.a = e - o2.a.a; + o2.n.b = 0; + P3b(o2, a); + } + e += d; + } + } + if (c2) { + k = l * (c2.gc() - 1); + n = 0; + for (i2 = c2.Kc(); i2.Ob(); ) { + g = RD(i2.Pb(), 10); + k += g.o.a; + n = $wnd.Math.max(n, g.o.b); + } + r = p.a - (k - q.a) / 2; + f2 = p.b + q.b + m.a - n; + d = q.a / (c2.gc() + 1); + e = d; + for (h = c2.Kc(); h.Ob(); ) { + g = RD(h.Pb(), 10); + g.n.a = r; + g.n.b = f2; + r += g.o.a + l; + j = n6b(g); + j.n.a = g.o.a / 2 - j.a.a; + j.n.b = 0; + o2 = RD(mQb(g, (Ywc(), Xvc)), 12); + if (o2.e.c.length + o2.g.c.length == 1) { + o2.n.a = e - o2.a.a; + o2.n.b = q.b; + P3b(o2, a); + } + e += d; + } + } + } + function Hac(a, b) { + var c2, d, e, f2, g, h; + if (!RD(mQb(b, (Ywc(), kwc)), 21).Hc((ovc(), hvc))) { + return; + } + for (h = new Anb(b.a); h.a < h.c.c.length; ) { + f2 = RD(ynb(h), 10); + if (f2.k == (r3b(), p3b)) { + e = RD(mQb(f2, (yCc(), _Ac)), 140); + a.c = $wnd.Math.min(a.c, f2.n.a - e.b); + a.a = $wnd.Math.max(a.a, f2.n.a + f2.o.a + e.c); + a.d = $wnd.Math.min(a.d, f2.n.b - e.d); + a.b = $wnd.Math.max(a.b, f2.n.b + f2.o.b + e.a); + } + } + for (g = new Anb(b.a); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 10); + if (f2.k != (r3b(), p3b)) { + switch (f2.k.g) { + case 2: + d = RD(mQb(f2, (yCc(), UAc)), 171); + if (d == (cxc(), $wc)) { + f2.n.a = a.c - 10; + Gac(f2, new Oac()).Jb(new Rac(f2)); + break; + } + if (d == axc) { + f2.n.a = a.a + 10; + Gac(f2, new Uac()).Jb(new Xac(f2)); + break; + } + c2 = RD(mQb(f2, owc), 311); + if (c2 == (Gvc(), Fvc)) { + Fac(f2).Jb(new $ac(f2)); + f2.n.b = a.d - 10; + break; + } + if (c2 == Dvc) { + Fac(f2).Jb(new bbc(f2)); + f2.n.b = a.b + 10; + break; + } + break; + default: + throw Adb(new agb("The node type " + f2.k + " is not supported by the " + XS)); + } + } + } + } + function g5b(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m, n, o2, p, q; + i2 = new rjd(d.i + d.g / 2, d.j + d.f / 2); + n = W4b(d); + o2 = RD(Gxd(b, (yCc(), BBc)), 101); + q = RD(Gxd(d, GBc), 64); + if (!HPd(Fxd(d), ABc)) { + d.i == 0 && d.j == 0 ? p = 0 : p = nsd(d, q); + Ixd(d, ABc, p); + } + j = new rjd(b.g, b.f); + e = f2b(d, o2, q, n, j, i2, new rjd(d.g, d.f), RD(mQb(c2, rAc), 88), c2); + pQb(e, (Ywc(), Awc), d); + f2 = RD(Vmb(e.j, 0), 12); + O3b(f2, e5b(d)); + pQb(e, EBc, (Pod(), xsb(Nod))); + l = RD(Gxd(b, EBc), 181).Hc(Lod); + for (h = new dMd((!d.n && (d.n = new C5d(I4, d, 1, 7)), d.n)); h.e != h.i.gc(); ) { + g = RD(bMd(h), 135); + if (!Heb(TD(Gxd(g, pBc))) && !!g.a) { + m = h5b(g); + Rmb(f2.f, m); + if (!l) { + k = 0; + Rod(RD(Gxd(b, EBc), 21)) && (k = qsd(new rjd(g.i, g.j), new rjd(g.g, g.f), new rjd(d.g, d.f), 0, q)); + switch (q.g) { + case 2: + case 4: + m.o.a = k; + break; + case 1: + case 3: + m.o.b = k; + } + } + } + } + pQb(e, _Bc, UD(Gxd(vCd(b), _Bc))); + pQb(e, aCc, UD(Gxd(vCd(b), aCc))); + pQb(e, ZBc, UD(Gxd(vCd(b), ZBc))); + Rmb(c2.a, e); + Zjb(a.a, d, e); + } + function j5b(a, b, c2, d, e, f2) { + var g, h, i2, j, k, l; + j = new R3b(); + kQb(j, b); + Q3b(j, RD(Gxd(b, (yCc(), GBc)), 64)); + pQb(j, (Ywc(), Awc), b); + P3b(j, c2); + l = j.o; + l.a = b.g; + l.b = b.f; + k = j.n; + k.a = b.i; + k.b = b.j; + Zjb(a.a, b, j); + g = yDb(GDb(EDb(new SDb(null, (!b.e && (b.e = new Yie(G4, b, 7, 4)), new Swb(b.e, 16))), new w5b()), new o5b()), new y5b(b)); + g || (g = yDb(GDb(EDb(new SDb(null, (!b.d && (b.d = new Yie(G4, b, 8, 5)), new Swb(b.d, 16))), new A5b()), new q5b()), new C5b(b))); + g || (g = yDb(new SDb(null, (!b.e && (b.e = new Yie(G4, b, 7, 4)), new Swb(b.e, 16))), new E5b())); + pQb(j, nwc, (Geb(), g ? true : false)); + m2b(j, f2, e, RD(Gxd(b, zBc), 8)); + for (i2 = new dMd((!b.n && (b.n = new C5d(I4, b, 1, 7)), b.n)); i2.e != i2.i.gc(); ) { + h = RD(bMd(i2), 135); + !Heb(TD(Gxd(h, pBc))) && !!h.a && Rmb(j.f, h5b(h)); + } + switch (e.g) { + case 2: + case 1: + (j.j == (qpd(), Yod) || j.j == npd) && d.Fc((ovc(), lvc)); + break; + case 4: + case 3: + (j.j == (qpd(), Xod) || j.j == ppd) && d.Fc((ovc(), lvc)); + } + return j; + } + function dud(a, b, c2, d, e) { + var f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5; + t = 0; + o2 = 0; + n = 0; + m = 1; + for (s = new dMd((!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a)); s.e != s.i.gc(); ) { + q = RD(bMd(s), 27); + m += Kr(new is(Mr(zGd(q).a.Kc(), new ir()))); + B = q.g; + o2 = $wnd.Math.max(o2, B); + l = q.f; + n = $wnd.Math.max(n, l); + t += B * l; + } + p = (!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a).i; + g = t + 2 * d * d * m * p; + f2 = $wnd.Math.sqrt(g); + i2 = $wnd.Math.max(f2 * c2, o2); + h = $wnd.Math.max(f2 / c2, n); + for (r = new dMd((!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a)); r.e != r.i.gc(); ) { + q = RD(bMd(r), 27); + C = e.b + (Kwb(b, 26) * Kxe + Kwb(b, 27) * Lxe) * (i2 - q.g); + D5 = e.b + (Kwb(b, 26) * Kxe + Kwb(b, 27) * Lxe) * (h - q.f); + Dyd(q, C); + Eyd(q, D5); + } + A = i2 + (e.b + e.c); + w2 = h + (e.d + e.a); + for (v = new dMd((!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a)); v.e != v.i.gc(); ) { + u = RD(bMd(v), 27); + for (k = new is(Mr(zGd(u).a.Kc(), new ir())); gs(k); ) { + j = RD(hs(k), 74); + nzd(j) || cud(j, b, A, w2); + } + } + A += e.b + e.c; + w2 += e.d + e.a; + Esd(a, A, w2, false, true); + } + function CLb(a) { + var b; + this.r = Ty(new FLb(), new JLb()); + this.b = new Zrb(RD(Qb(E3), 297)); + this.p = new Zrb(RD(Qb(E3), 297)); + this.i = new Zrb(RD(Qb(XN), 297)); + this.e = a; + this.o = new sjd(a.Mf()); + this.D = a.Yf() || Heb(TD(a.of((umd(), $kd)))); + this.A = RD(a.of((umd(), kld)), 21); + this.B = RD(a.of(pld), 21); + this.q = RD(a.of(Hld), 101); + this.u = RD(a.of(Lld), 21); + if (!Sod(this.u)) { + throw Adb(new Jed("Invalid port label placement: " + this.u)); + } + this.v = Heb(TD(a.of(Nld))); + this.j = RD(a.of(ild), 21); + if (!fod(this.j)) { + throw Adb(new Jed("Invalid node label placement: " + this.j)); + } + this.n = RD(ftd(a, gld), 107); + this.k = Kfb(UD(ftd(a, cmd))); + this.d = Kfb(UD(ftd(a, bmd))); + this.w = Kfb(UD(ftd(a, jmd))); + this.s = Kfb(UD(ftd(a, dmd))); + this.t = Kfb(UD(ftd(a, emd))); + this.C = RD(ftd(a, hmd), 140); + this.c = 2 * this.d; + b = !this.B.Hc((dqd(), Wpd)); + this.f = new dLb(0, b, 0); + this.g = new dLb(1, b, 0); + cLb(this.f, (ZJb(), XJb), this.g); + } + function s6b(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r; + b.Ug("Comment pre-processing", 1); + c2 = 0; + i2 = new Anb(a.a); + while (i2.a < i2.c.c.length) { + h = RD(ynb(i2), 10); + if (Heb(TD(mQb(h, (yCc(), Uzc))))) { + ++c2; + e = 0; + d = null; + j = null; + for (o2 = new Anb(h.j); o2.a < o2.c.c.length; ) { + m = RD(ynb(o2), 12); + e += m.e.c.length + m.g.c.length; + if (m.e.c.length == 1) { + d = RD(Vmb(m.e, 0), 18); + j = d.c; + } + if (m.g.c.length == 1) { + d = RD(Vmb(m.g, 0), 18); + j = d.d; + } + } + if (e == 1 && j.e.c.length + j.g.c.length == 1 && !Heb(TD(mQb(j.i, Uzc)))) { + t6b(h, d, j, j.i); + znb(i2); + } else { + r = new bnb(); + for (n = new Anb(h.j); n.a < n.c.c.length; ) { + m = RD(ynb(n), 12); + for (l = new Anb(m.g); l.a < l.c.c.length; ) { + k = RD(ynb(l), 18); + k.d.g.c.length == 0 || (ZEb(r.c, k), true); + } + for (g = new Anb(m.e); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 18); + f2.c.e.c.length == 0 || (ZEb(r.c, f2), true); + } + } + for (q = new Anb(r); q.a < q.c.c.length; ) { + p = RD(ynb(q), 18); + X0b(p, true); + } + } + } + } + b._g() && b.bh("Found " + c2 + " comment boxes"); + b.Vg(); + } + function wke(a, b) { + uke(); + var c2, d, e, f2, g, h, i2; + this.a = new zke(this); + this.b = a; + this.c = b; + this.f = Cfe(Qee((lke(), jke), b)); + if (this.f.dc()) { + if ((h = Tee(jke, a)) == b) { + this.e = true; + this.d = new bnb(); + this.f = new OSd(); + this.f.Fc(dLe); + RD(tfe(Pee(jke, BXd(a)), ""), 29) == a && this.f.Fc(Uee(jke, BXd(a))); + for (e = Gee(jke, a).Kc(); e.Ob(); ) { + d = RD(e.Pb(), 179); + switch (yfe(Qee(jke, d))) { + case 4: { + this.d.Fc(d); + break; + } + case 5: { + this.f.Gc(Cfe(Qee(jke, d))); + break; + } + } + } + } else { + nke(); + if (RD(b, 69).xk()) { + this.e = true; + this.f = null; + this.d = new bnb(); + for (g = 0, i2 = (a.i == null && rYd(a), a.i).length; g < i2; ++g) { + d = (c2 = (a.i == null && rYd(a), a.i), g >= 0 && g < c2.length ? c2[g] : null); + for (f2 = zfe(Qee(jke, d)); f2; f2 = zfe(Qee(jke, f2))) { + f2 == b && this.d.Fc(d); + } + } + } else if (yfe(Qee(jke, b)) == 1 && !!h) { + this.f = null; + this.d = (Lle(), Kle); + } else { + this.f = null; + this.e = true; + this.d = (yob(), new mpb(b)); + } + } + } else { + this.e = yfe(Qee(jke, b)) == 5; + this.f.Fb(tke) && (this.f = tke); + } + } + function qNb(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2; + c2 = 0; + d = pNb(a, b); + m = a.s; + n = a.t; + for (j = RD(RD(Qc(a.r, b), 21), 87).Kc(); j.Ob(); ) { + i2 = RD(j.Pb(), 117); + if (!i2.c || i2.c.d.c.length <= 0) { + continue; + } + o2 = i2.b.Mf(); + h = i2.b.pf((umd(), Gld)) ? Kfb(UD(i2.b.of(Gld))) : 0; + k = i2.c; + l = k.i; + l.b = (g = k.n, k.e.a + g.b + g.c); + l.a = (f2 = k.n, k.e.b + f2.d + f2.a); + switch (b.g) { + case 1: + l.c = i2.a ? (o2.a - l.b) / 2 : o2.a + m; + l.d = o2.b + h + d; + RKb(k, (EKb(), BKb)); + SKb(k, (vLb(), uLb)); + break; + case 3: + l.c = i2.a ? (o2.a - l.b) / 2 : o2.a + m; + l.d = -h - d - l.a; + RKb(k, (EKb(), BKb)); + SKb(k, (vLb(), sLb)); + break; + case 2: + l.c = -h - d - l.b; + if (i2.a) { + e = a.v ? l.a : RD(Vmb(k.d, 0), 187).Mf().b; + l.d = (o2.b - e) / 2; + } else { + l.d = o2.b + n; + } + RKb(k, (EKb(), DKb)); + SKb(k, (vLb(), tLb)); + break; + case 4: + l.c = o2.a + h + d; + if (i2.a) { + e = a.v ? l.a : RD(Vmb(k.d, 0), 187).Mf().b; + l.d = (o2.b - e) / 2; + } else { + l.d = o2.b + n; + } + RKb(k, (EKb(), CKb)); + SKb(k, (vLb(), tLb)); + } + (b == (qpd(), Yod) || b == npd) && (c2 = $wnd.Math.max(c2, l.a)); + } + c2 > 0 && (RD(Vrb(a.b, b), 127).a.b = c2); + } + function wcc(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m, n, o2, p; + m = Kfb(UD(mQb(a, (yCc(), _Bc)))); + n = Kfb(UD(mQb(a, aCc))); + l = Kfb(UD(mQb(a, ZBc))); + h = a.o; + f2 = RD(Vmb(a.j, 0), 12); + g = f2.n; + p = ucc(f2, l); + if (!p) { + return; + } + if (b.Hc((Pod(), Lod))) { + switch (RD(mQb(a, (Ywc(), hwc)), 64).g) { + case 1: + p.c = (h.a - p.b) / 2 - g.a; + p.d = n; + break; + case 3: + p.c = (h.a - p.b) / 2 - g.a; + p.d = -n - p.a; + break; + case 2: + if (c2 && f2.e.c.length == 0 && f2.g.c.length == 0) { + k = d ? p.a : RD(Vmb(f2.f, 0), 72).o.b; + p.d = (h.b - k) / 2 - g.b; + } else { + p.d = h.b + n - g.b; + } + p.c = -m - p.b; + break; + case 4: + if (c2 && f2.e.c.length == 0 && f2.g.c.length == 0) { + k = d ? p.a : RD(Vmb(f2.f, 0), 72).o.b; + p.d = (h.b - k) / 2 - g.b; + } else { + p.d = h.b + n - g.b; + } + p.c = m; + } + } else if (b.Hc(Nod)) { + switch (RD(mQb(a, (Ywc(), hwc)), 64).g) { + case 1: + case 3: + p.c = g.a + m; + break; + case 2: + case 4: + if (c2 && !f2.c) { + k = d ? p.a : RD(Vmb(f2.f, 0), 72).o.b; + p.d = (h.b - k) / 2 - g.b; + } else { + p.d = g.b + n; + } + } + } + e = p.d; + for (j = new Anb(f2.f); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 72); + o2 = i2.n; + o2.a = p.c; + o2.b = e; + e += i2.o.b + l; + } + } + function w9b(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5, F; + w2 = new bnb(); + for (o2 = new Anb(a.b); o2.a < o2.c.c.length; ) { + n = RD(ynb(o2), 30); + for (r = new Anb(n.a); r.a < r.c.c.length; ) { + p = RD(ynb(r), 10); + if (p.k != (r3b(), m3b)) { + continue; + } + if (!nQb(p, (Ywc(), gwc))) { + continue; + } + s = null; + u = null; + t = null; + for (C = new Anb(p.j); C.a < C.c.c.length; ) { + B = RD(ynb(C), 12); + switch (B.j.g) { + case 4: + s = B; + break; + case 2: + u = B; + break; + default: + t = B; + } + } + v = RD(Vmb(t.g, 0), 18); + k = new Fjd(v.a); + j = new sjd(t.n); + $id(j, p.n); + l = Sub(k, 0); + cvb(l, j); + A = Ijd(v.a); + m = new sjd(t.n); + $id(m, p.n); + Pub(A, m, A.c.b, A.c); + D5 = RD(mQb(p, gwc), 10); + F = RD(Vmb(D5.j, 0), 12); + i2 = RD(anb(s.e, $C(WQ, VAe, 18, 0, 0, 1)), 483); + for (d = i2, f2 = 0, h = d.length; f2 < h; ++f2) { + b = d[f2]; + Z0b(b, F); + Ajd(b.a, b.a.b, k); + } + i2 = s2b(u.g); + for (c2 = i2, e = 0, g = c2.length; e < g; ++e) { + b = c2[e]; + Y0b(b, F); + Ajd(b.a, 0, A); + } + Y0b(v, null); + Z0b(v, null); + ZEb(w2.c, p); + } + } + for (q = new Anb(w2); q.a < q.c.c.length; ) { + p = RD(ynb(q), 10); + g3b(p, null); + } + } + function Dne() { + RRd(Vbb, new ioe()); + RRd(Xbb, new Poe()); + RRd(Ybb, new upe()); + RRd(Zbb, new _pe()); + RRd(qJ, new lqe()); + RRd(WC(gE, 1), new oqe()); + RRd(QI, new rqe()); + RRd(RI, new uqe()); + RRd(qJ, new Gne()); + RRd(qJ, new Jne()); + RRd(qJ, new Mne()); + RRd(VI, new Pne()); + RRd(qJ, new Sne()); + RRd(QK, new Vne()); + RRd(QK, new Yne()); + RRd(qJ, new _ne()); + RRd(ZI, new coe()); + RRd(qJ, new foe()); + RRd(qJ, new loe()); + RRd(qJ, new ooe()); + RRd(qJ, new roe()); + RRd(qJ, new uoe()); + RRd(WC(gE, 1), new xoe()); + RRd(qJ, new Aoe()); + RRd(qJ, new Doe()); + RRd(QK, new Goe()); + RRd(QK, new Joe()); + RRd(qJ, new Moe()); + RRd(bJ, new Soe()); + RRd(qJ, new Voe()); + RRd(eJ, new Yoe()); + RRd(qJ, new _oe()); + RRd(qJ, new cpe()); + RRd(qJ, new fpe()); + RRd(qJ, new ipe()); + RRd(QK, new lpe()); + RRd(QK, new ope()); + RRd(qJ, new rpe()); + RRd(qJ, new xpe()); + RRd(qJ, new Ape()); + RRd(qJ, new Dpe()); + RRd(qJ, new Gpe()); + RRd(qJ, new Jpe()); + RRd(lJ, new Mpe()); + RRd(qJ, new Ppe()); + RRd(qJ, new Spe()); + RRd(qJ, new Vpe()); + RRd(lJ, new Ype()); + RRd(eJ, new cqe()); + RRd(qJ, new fqe()); + RRd(bJ, new iqe()); + } + function jsc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2; + k = new Ejd(); + switch (a.a.g) { + case 3: + m = RD(mQb(b.e, (Ywc(), Twc)), 15); + n = RD(mQb(b.j, Twc), 15); + o2 = RD(mQb(b.f, Twc), 15); + c2 = RD(mQb(b.e, Rwc), 15); + d = RD(mQb(b.j, Rwc), 15); + e = RD(mQb(b.f, Rwc), 15); + g = new bnb(); + Tmb(g, m); + n.Jc(new msc()); + Tmb(g, hv(n)); + Tmb(g, o2); + f2 = new bnb(); + Tmb(f2, c2); + Tmb(f2, hv(d)); + Tmb(f2, e); + pQb(b.f, Twc, g); + pQb(b.f, Rwc, f2); + pQb(b.f, Uwc, b.f); + pQb(b.e, Twc, null); + pQb(b.e, Rwc, null); + pQb(b.j, Twc, null); + pQb(b.j, Rwc, null); + break; + case 1: + ye(k, b.e.a); + Mub(k, b.i.n); + ye(k, hv(b.j.a)); + Mub(k, b.a.n); + ye(k, b.f.a); + break; + default: + ye(k, b.e.a); + ye(k, hv(b.j.a)); + ye(k, b.f.a); + } + Xub(b.f.a); + ye(b.f.a, k); + Y0b(b.f, b.e.c); + h = RD(mQb(b.e, (yCc(), RAc)), 75); + j = RD(mQb(b.j, RAc), 75); + i2 = RD(mQb(b.f, RAc), 75); + if (!!h || !!j || !!i2) { + l = new Ejd(); + hsc(l, i2); + hsc(l, j); + hsc(l, h); + pQb(b.f, RAc, l); + } + Y0b(b.j, null); + Z0b(b.j, null); + Y0b(b.e, null); + Z0b(b.e, null); + g3b(b.a, null); + g3b(b.i, null); + !!b.g && jsc(a, b.g); + } + function tib() { + tib = geb; + var a, b, c2; + new Aib(1, 0); + new Aib(10, 0); + new Aib(0, 0); + lib = $C(tJ, Nve, 247, 11, 0, 1); + mib = $C(hE, zwe, 28, 100, 15, 1); + nib = cD(WC(iE, 1), vxe, 28, 15, [1, 5, 25, 125, 625, 3125, 15625, 78125, 390625, 1953125, 9765625, 48828125, 244140625, 1220703125, 6103515625, 30517578125, 152587890625, 762939453125, 3814697265625, 19073486328125, 95367431640625, 476837158203125, 2384185791015625]); + oib = $C(kE, Pwe, 28, nib.length, 15, 1); + pib = cD(WC(iE, 1), vxe, 28, 15, [1, 10, 100, Awe, 1e4, wxe, 1e6, 1e7, 1e8, ixe, 1e10, 1e11, 1e12, 1e13, 1e14, 1e15, 1e16]); + qib = $C(kE, Pwe, 28, pib.length, 15, 1); + rib = $C(tJ, Nve, 247, 11, 0, 1); + a = 0; + for (; a < rib.length; a++) { + lib[a] = new Aib(a, 0); + rib[a] = new Aib(0, a); + mib[a] = 48; + } + for (; a < mib.length; a++) { + mib[a] = 48; + } + for (c2 = 0; c2 < oib.length; c2++) { + oib[c2] = Cib(nib[c2]); + } + for (b = 0; b < qib.length; b++) { + qib[b] = Cib(pib[b]); + } + Ljb(); + } + function Htb() { + function e() { + this.obj = this.createObject(); + } + e.prototype.createObject = function(a) { + return /* @__PURE__ */ Object.create(null); + }; + e.prototype.get = function(a) { + return this.obj[a]; + }; + e.prototype.set = function(a, b) { + this.obj[a] = b; + }; + e.prototype[Jxe] = function(a) { + delete this.obj[a]; + }; + e.prototype.keys = function() { + return Object.getOwnPropertyNames(this.obj); + }; + e.prototype.entries = function() { + var b = this.keys(); + var c2 = this; + var d = 0; + return { next: function() { + if (d >= b.length) + return { done: true }; + var a = b[d++]; + return { value: [a, c2.get(a)], done: false }; + } }; + }; + if (!Ftb()) { + e.prototype.createObject = function() { + return {}; + }; + e.prototype.get = function(a) { + return this.obj[":" + a]; + }; + e.prototype.set = function(a, b) { + this.obj[":" + a] = b; + }; + e.prototype[Jxe] = function(a) { + delete this.obj[":" + a]; + }; + e.prototype.keys = function() { + var a = []; + for (var b in this.obj) { + b.charCodeAt(0) == 58 && a.push(b.substring(1)); + } + return a; + }; + } + return e; + } + function q$c() { + q$c = geb; + h$c = new jGd(rAe); + new kGd("DEPTH", sgb(0)); + XZc = new kGd("FAN", sgb(0)); + VZc = new kGd(QEe, sgb(0)); + n$c = new kGd("ROOT", (Geb(), false)); + b$c = new kGd("LEFTNEIGHBOR", null); + l$c = new kGd("RIGHTNEIGHBOR", null); + c$c = new kGd("LEFTSIBLING", null); + m$c = new kGd("RIGHTSIBLING", null); + WZc = new kGd("DUMMY", false); + new kGd("LEVEL", sgb(0)); + k$c = new kGd("REMOVABLE_EDGES", new Yub()); + o$c = new kGd("XCOOR", sgb(0)); + p$c = new kGd("YCOOR", sgb(0)); + d$c = new kGd("LEVELHEIGHT", 0); + f$c = new kGd("LEVELMIN", 0); + e$c = new kGd("LEVELMAX", 0); + ZZc = new kGd("GRAPH_XMIN", 0); + _Zc = new kGd("GRAPH_YMIN", 0); + YZc = new kGd("GRAPH_XMAX", 0); + $Zc = new kGd("GRAPH_YMAX", 0); + UZc = new kGd("COMPACT_LEVEL_ASCENSION", false); + TZc = new kGd("COMPACT_CONSTRAINTS", new bnb()); + a$c = new kGd("ID", ""); + i$c = new kGd("POSITION", sgb(0)); + j$c = new kGd("PRELIM", 0); + g$c = new kGd("MODIFIER", 0); + SZc = new jGd(tAe); + RZc = new jGd(uAe); + } + function Bqe(a) { + zqe(); + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q; + if (a == null) + return null; + l = a.length * 8; + if (l == 0) { + return ""; + } + h = l % 24; + n = l / 24 | 0; + m = h != 0 ? n + 1 : n; + f2 = null; + f2 = $C(hE, zwe, 28, m * 4, 15, 1); + j = 0; + k = 0; + b = 0; + c2 = 0; + d = 0; + g = 0; + e = 0; + for (i2 = 0; i2 < n; i2++) { + b = a[e++]; + c2 = a[e++]; + d = a[e++]; + k = (c2 & 15) << 24 >> 24; + j = (b & 3) << 24 >> 24; + o2 = (b & -128) == 0 ? b >> 2 << 24 >> 24 : (b >> 2 ^ 192) << 24 >> 24; + p = (c2 & -128) == 0 ? c2 >> 4 << 24 >> 24 : (c2 >> 4 ^ 240) << 24 >> 24; + q = (d & -128) == 0 ? d >> 6 << 24 >> 24 : (d >> 6 ^ 252) << 24 >> 24; + f2[g++] = yqe[o2]; + f2[g++] = yqe[p | j << 4]; + f2[g++] = yqe[k << 2 | q]; + f2[g++] = yqe[d & 63]; + } + if (h == 8) { + b = a[e]; + j = (b & 3) << 24 >> 24; + o2 = (b & -128) == 0 ? b >> 2 << 24 >> 24 : (b >> 2 ^ 192) << 24 >> 24; + f2[g++] = yqe[o2]; + f2[g++] = yqe[j << 4]; + f2[g++] = 61; + f2[g++] = 61; + } else if (h == 16) { + b = a[e]; + c2 = a[e + 1]; + k = (c2 & 15) << 24 >> 24; + j = (b & 3) << 24 >> 24; + o2 = (b & -128) == 0 ? b >> 2 << 24 >> 24 : (b >> 2 ^ 192) << 24 >> 24; + p = (c2 & -128) == 0 ? c2 >> 4 << 24 >> 24 : (c2 >> 4 ^ 240) << 24 >> 24; + f2[g++] = yqe[o2]; + f2[g++] = yqe[p | j << 4]; + f2[g++] = yqe[k << 2]; + f2[g++] = 61; + } + return Ihb(f2, 0, f2.length); + } + function CB(a, b) { + var c2, d, e, f2, g, h, i2; + a.e == 0 && a.p > 0 && (a.p = -(a.p - 1)); + a.p > qwe && tB(b, a.p - Owe); + g = b.q.getDate(); + nB(b, 1); + a.k >= 0 && qB(b, a.k); + if (a.c >= 0) { + nB(b, a.c); + } else if (a.k >= 0) { + i2 = new vB(b.q.getFullYear() - Owe, b.q.getMonth(), 35); + d = 35 - i2.q.getDate(); + nB(b, $wnd.Math.min(d, g)); + } else { + nB(b, g); + } + a.f < 0 && (a.f = b.q.getHours()); + a.b > 0 && a.f < 12 && (a.f += 12); + oB(b, a.f == 24 && a.g ? 0 : a.f); + a.j >= 0 && pB(b, a.j); + a.n >= 0 && rB(b, a.n); + a.i >= 0 && sB(b, Bdb(Ndb(Fdb(Hdb(b.q.getTime()), Awe), Awe), a.i)); + if (a.a) { + e = new uB(); + tB(e, e.q.getFullYear() - Owe - 80); + Ldb(Hdb(b.q.getTime()), Hdb(e.q.getTime())) && tB(b, e.q.getFullYear() - Owe + 100); + } + if (a.d >= 0) { + if (a.c == -1) { + c2 = (7 + a.d - b.q.getDay()) % 7; + c2 > 3 && (c2 -= 7); + h = b.q.getMonth(); + nB(b, b.q.getDate() + c2); + b.q.getMonth() != h && nB(b, b.q.getDate() + (c2 > 0 ? -7 : 7)); + } else { + if (b.q.getDay() != a.d) { + return false; + } + } + } + if (a.o > qwe) { + f2 = b.q.getTimezoneOffset(); + sB(b, Bdb(Hdb(b.q.getTime()), (a.o - f2) * 60 * Awe)); + } + return true; + } + function J5b(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u; + e = mQb(b, (Ywc(), Awc)); + if (!ZD(e, 207)) { + return; + } + o2 = RD(e, 27); + p = b.e; + m = new sjd(b.c); + f2 = b.d; + m.a += f2.b; + m.b += f2.d; + u = RD(Gxd(o2, (yCc(), oBc)), 181); + if (Csb(u, (dqd(), Xpd))) { + n = RD(Gxd(o2, qBc), 107); + E2b(n, f2.a); + H2b(n, f2.d); + F2b(n, f2.b); + G2b(n, f2.c); + } + c2 = new bnb(); + for (k = new Anb(b.a); k.a < k.c.c.length; ) { + i2 = RD(ynb(k), 10); + if (ZD(mQb(i2, Awc), 207)) { + K5b(i2, m); + } else if (ZD(mQb(i2, Awc), 193) && !p) { + d = RD(mQb(i2, Awc), 123); + s = j2b(b, i2, d.g, d.f); + Byd(d, s.a, s.b); + } + for (r = new Anb(i2.j); r.a < r.c.c.length; ) { + q = RD(ynb(r), 12); + FDb(CDb(new SDb(null, new Swb(q.g, 16)), new Q5b(i2)), new S5b(c2)); + } + } + if (p) { + for (r = new Anb(p.j); r.a < r.c.c.length; ) { + q = RD(ynb(r), 12); + FDb(CDb(new SDb(null, new Swb(q.g, 16)), new U5b(p)), new W5b(c2)); + } + } + t = RD(Gxd(o2, yAc), 223); + for (h = new Anb(c2); h.a < h.c.c.length; ) { + g = RD(ynb(h), 18); + I5b(g, t, m); + } + L5b(b); + for (j = new Anb(b.a); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 10); + l = i2.e; + !!l && J5b(a, l); + } + } + function xNb(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n; + if (RD(RD(Qc(a.r, b), 21), 87).dc()) { + return; + } + g = RD(Vrb(a.b, b), 127); + i2 = g.i; + h = g.n; + k = BLb(a, b); + d = i2.b - h.b - h.c; + e = g.a.a; + f2 = i2.c + h.b; + n = a.w; + if ((k == (pod(), mod) || k == ood) && RD(RD(Qc(a.r, b), 21), 87).gc() == 1) { + e = k == mod ? e - 2 * a.w : e; + k = lod; + } + if (d < e && !a.B.Hc((dqd(), aqd))) { + if (k == mod) { + n += (d - e) / (RD(RD(Qc(a.r, b), 21), 87).gc() + 1); + f2 += n; + } else { + n += (d - e) / (RD(RD(Qc(a.r, b), 21), 87).gc() - 1); + } + } else { + if (d < e) { + e = k == mod ? e - 2 * a.w : e; + k = lod; + } + switch (k.g) { + case 3: + f2 += (d - e) / 2; + break; + case 4: + f2 += d - e; + break; + case 0: + c2 = (d - e) / (RD(RD(Qc(a.r, b), 21), 87).gc() + 1); + n += $wnd.Math.max(0, c2); + f2 += n; + break; + case 1: + c2 = (d - e) / (RD(RD(Qc(a.r, b), 21), 87).gc() - 1); + n += $wnd.Math.max(0, c2); + } + } + for (m = RD(RD(Qc(a.r, b), 21), 87).Kc(); m.Ob(); ) { + l = RD(m.Pb(), 117); + l.e.a = f2 + l.d.b; + l.e.b = (j = l.b, j.pf((umd(), Gld)) ? j.ag() == (qpd(), Yod) ? -j.Mf().b - Kfb(UD(j.of(Gld))) : Kfb(UD(j.of(Gld))) : j.ag() == (qpd(), Yod) ? -j.Mf().b : 0); + f2 += l.d.b + l.b.Mf().a + l.d.c + n; + } + } + function BNb(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2; + if (RD(RD(Qc(a.r, b), 21), 87).dc()) { + return; + } + g = RD(Vrb(a.b, b), 127); + i2 = g.i; + h = g.n; + l = BLb(a, b); + d = i2.a - h.d - h.a; + e = g.a.b; + f2 = i2.d + h.d; + o2 = a.w; + j = a.o.a; + if ((l == (pod(), mod) || l == ood) && RD(RD(Qc(a.r, b), 21), 87).gc() == 1) { + e = l == mod ? e - 2 * a.w : e; + l = lod; + } + if (d < e && !a.B.Hc((dqd(), aqd))) { + if (l == mod) { + o2 += (d - e) / (RD(RD(Qc(a.r, b), 21), 87).gc() + 1); + f2 += o2; + } else { + o2 += (d - e) / (RD(RD(Qc(a.r, b), 21), 87).gc() - 1); + } + } else { + if (d < e) { + e = l == mod ? e - 2 * a.w : e; + l = lod; + } + switch (l.g) { + case 3: + f2 += (d - e) / 2; + break; + case 4: + f2 += d - e; + break; + case 0: + c2 = (d - e) / (RD(RD(Qc(a.r, b), 21), 87).gc() + 1); + o2 += $wnd.Math.max(0, c2); + f2 += o2; + break; + case 1: + c2 = (d - e) / (RD(RD(Qc(a.r, b), 21), 87).gc() - 1); + o2 += $wnd.Math.max(0, c2); + } + } + for (n = RD(RD(Qc(a.r, b), 21), 87).Kc(); n.Ob(); ) { + m = RD(n.Pb(), 117); + m.e.a = (k = m.b, k.pf((umd(), Gld)) ? k.ag() == (qpd(), ppd) ? -k.Mf().a - Kfb(UD(k.of(Gld))) : j + Kfb(UD(k.of(Gld))) : k.ag() == (qpd(), ppd) ? -k.Mf().a : j); + m.e.b = f2 + m.d.d; + f2 += m.d.d + m.b.Mf().b + m.d.a + o2; + } + } + function bZc(a, b) { + var c2, d, e, f2, g; + b.Ug("Processor determine the coords for each level", 1); + d = new bnb(); + for (g = Sub(a.b, 0); g.b != g.d.c; ) { + e = RD(evb(g), 40); + while (RD(mQb(e, (h_c(), f_c)), 17).a > d.c.length - 1) { + Rmb(d, new Ptd(Hze, KEe)); + } + c2 = RD(mQb(e, f_c), 17).a; + if (Dmd(RD(mQb(a, H$c), 88))) { + e.e.a < Kfb(UD((tFb(c2, d.c.length), RD(d.c[c2], 42)).a)) && Ntd((tFb(c2, d.c.length), RD(d.c[c2], 42)), e.e.a); + e.e.a + e.f.a > Kfb(UD((tFb(c2, d.c.length), RD(d.c[c2], 42)).b)) && Otd((tFb(c2, d.c.length), RD(d.c[c2], 42)), e.e.a + e.f.a); + } else { + e.e.b < Kfb(UD((tFb(c2, d.c.length), RD(d.c[c2], 42)).a)) && Ntd((tFb(c2, d.c.length), RD(d.c[c2], 42)), e.e.b); + e.e.b + e.f.b > Kfb(UD((tFb(c2, d.c.length), RD(d.c[c2], 42)).b)) && Otd((tFb(c2, d.c.length), RD(d.c[c2], 42)), e.e.b + e.f.b); + } + } + for (f2 = Sub(a.b, 0); f2.b != f2.d.c; ) { + e = RD(evb(f2), 40); + c2 = RD(mQb(e, (h_c(), f_c)), 17).a; + pQb(e, (q$c(), f$c), UD((tFb(c2, d.c.length), RD(d.c[c2], 42)).a)); + pQb(e, e$c, UD((tFb(c2, d.c.length), RD(d.c[c2], 42)).b)); + } + b.Vg(); + } + function Tec(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p; + a.o = Kfb(UD(mQb(a.i, (yCc(), bCc)))); + a.f = Kfb(UD(mQb(a.i, XBc))); + a.j = a.i.b.c.length; + h = a.j - 1; + m = 0; + a.k = 0; + a.n = 0; + a.b = dv($C(bJ, Nve, 17, a.j, 0, 1)); + a.c = dv($C(VI, Nve, 345, a.j, 7, 1)); + for (g = new Anb(a.i.b); g.a < g.c.c.length; ) { + e = RD(ynb(g), 30); + e.p = h; + for (l = new Anb(e.a); l.a < l.c.c.length; ) { + k = RD(ynb(l), 10); + k.p = m; + ++m; + } + --h; + } + a.g = $C(kE, Pwe, 28, m, 15, 1); + a.d = YC(kE, [Nve, Pwe], [53, 28], 15, [m, 3], 2); + a.p = new bnb(); + a.q = new bnb(); + b = 0; + a.e = 0; + for (f2 = new Anb(a.i.b); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 30); + h = e.p; + d = 0; + p = 0; + i2 = e.a.c.length; + j = 0; + for (l = new Anb(e.a); l.a < l.c.c.length; ) { + k = RD(ynb(l), 10); + m = k.p; + a.g[m] = k.c.p; + j += k.o.b + a.o; + c2 = Kr(new is(Mr(Z2b(k).a.Kc(), new ir()))); + o2 = Kr(new is(Mr(a3b(k).a.Kc(), new ir()))); + a.d[m][0] = o2 - c2; + a.d[m][1] = c2; + a.d[m][2] = o2; + d += c2; + p += o2; + c2 > 0 && Rmb(a.q, k); + Rmb(a.p, k); + } + b -= d; + n = i2 + b; + j += b * a.f; + $mb(a.b, h, sgb(n)); + $mb(a.c, h, j); + a.k = $wnd.Math.max(a.k, n); + a.n = $wnd.Math.max(a.n, j); + a.e += b; + b += p; + } + } + function qpd() { + qpd = geb; + var a; + opd = new upd(Sye, 0); + Yod = new upd(_ye, 1); + Xod = new upd(aze, 2); + npd = new upd(bze, 3); + ppd = new upd(cze, 4); + bpd = (yob(), new Lqb((a = RD(mfb(E3), 9), new Fsb(a, RD(WEb(a, a.length), 9), 0)))); + cpd = eq2(ysb(Yod, cD(WC(E3, 1), NAe, 64, 0, []))); + Zod = eq2(ysb(Xod, cD(WC(E3, 1), NAe, 64, 0, []))); + kpd = eq2(ysb(npd, cD(WC(E3, 1), NAe, 64, 0, []))); + mpd = eq2(ysb(ppd, cD(WC(E3, 1), NAe, 64, 0, []))); + hpd = eq2(ysb(Yod, cD(WC(E3, 1), NAe, 64, 0, [npd]))); + apd = eq2(ysb(Xod, cD(WC(E3, 1), NAe, 64, 0, [ppd]))); + jpd = eq2(ysb(Yod, cD(WC(E3, 1), NAe, 64, 0, [ppd]))); + dpd = eq2(ysb(Yod, cD(WC(E3, 1), NAe, 64, 0, [Xod]))); + lpd = eq2(ysb(npd, cD(WC(E3, 1), NAe, 64, 0, [ppd]))); + $od = eq2(ysb(Xod, cD(WC(E3, 1), NAe, 64, 0, [npd]))); + gpd = eq2(ysb(Yod, cD(WC(E3, 1), NAe, 64, 0, [Xod, ppd]))); + _od = eq2(ysb(Xod, cD(WC(E3, 1), NAe, 64, 0, [npd, ppd]))); + ipd = eq2(ysb(Yod, cD(WC(E3, 1), NAe, 64, 0, [npd, ppd]))); + epd = eq2(ysb(Yod, cD(WC(E3, 1), NAe, 64, 0, [Xod, npd]))); + fpd = eq2(ysb(Yod, cD(WC(E3, 1), NAe, 64, 0, [Xod, npd, ppd]))); + } + function Gfc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A; + b.Ug(qBe, 1); + p = new bnb(); + w2 = new bnb(); + for (j = new Anb(a.b); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 30); + r = -1; + o2 = t2b(i2.a); + for (l = o2, m = 0, n = l.length; m < n; ++m) { + k = l[m]; + ++r; + if (!(k.k == (r3b(), p3b) && Dod(RD(mQb(k, (yCc(), BBc)), 101)))) { + continue; + } + Cod(RD(mQb(k, (yCc(), BBc)), 101)) || Hfc(k); + pQb(k, (Ywc(), pwc), k); + p.c.length = 0; + w2.c.length = 0; + c2 = new bnb(); + u = new Yub(); + _q(u, e3b(k, (qpd(), Yod))); + Efc(a, u, p, w2, c2); + h = r; + A = k; + for (f2 = new Anb(p); f2.a < f2.c.c.length; ) { + d = RD(ynb(f2), 10); + f3b(d, h, i2); + ++r; + pQb(d, pwc, k); + g = RD(Vmb(d.j, 0), 12); + q = RD(mQb(g, Awc), 12); + Heb(TD(mQb(q, Szc))) || RD(mQb(d, qwc), 15).Fc(A); + } + Xub(u); + for (t = e3b(k, npd).Kc(); t.Ob(); ) { + s = RD(t.Pb(), 12); + Pub(u, s, u.a, u.a.a); + } + Efc(a, u, w2, null, c2); + v = k; + for (e = new Anb(w2); e.a < e.c.c.length; ) { + d = RD(ynb(e), 10); + f3b(d, ++r, i2); + pQb(d, pwc, k); + g = RD(Vmb(d.j, 0), 12); + q = RD(mQb(g, Awc), 12); + Heb(TD(mQb(q, Szc))) || RD(mQb(v, qwc), 15).Fc(d); + } + c2.c.length == 0 || pQb(k, Uvc, c2); + } + } + b.Vg(); + } + function tYc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t; + if (b.b != 0) { + n = new Yub(); + h = null; + o2 = null; + d = eE($wnd.Math.floor($wnd.Math.log(b.b) * $wnd.Math.LOG10E) + 1); + i2 = 0; + for (t = Sub(b, 0); t.b != t.d.c; ) { + r = RD(evb(t), 40); + if (dE(o2) !== dE(mQb(r, (q$c(), a$c)))) { + o2 = WD(mQb(r, a$c)); + i2 = 0; + } + o2 != null ? h = o2 + wYc(i2++, d) : h = wYc(i2++, d); + pQb(r, a$c, h); + for (q = (e = Sub(new dXc(r).a.d, 0), new gXc(e)); dvb(q.a); ) { + p = RD(evb(q.a), 65).c; + Pub(n, p, n.c.b, n.c); + pQb(p, a$c, h); + } + } + m = new Tsb(); + for (g = 0; g < h.length - d; g++) { + for (s = Sub(b, 0); s.b != s.d.c; ) { + r = RD(evb(s), 40); + j = zhb(WD(mQb(r, (q$c(), a$c))), 0, g + 1); + c2 = (j == null ? Wd(qtb(m.f, null)) : Ktb(m.i, j)) != null ? RD(j == null ? Wd(qtb(m.f, null)) : Ktb(m.i, j), 17).a + 1 : 1; + $jb(m, j, sgb(c2)); + } + } + for (l = new vkb(new mkb(m).a); l.b; ) { + k = tkb(l); + f2 = sgb(Wjb(a.a, k.ld()) != null ? RD(Wjb(a.a, k.ld()), 17).a : 0); + $jb(a.a, WD(k.ld()), sgb(RD(k.md(), 17).a + f2.a)); + f2 = RD(Wjb(a.b, k.ld()), 17); + (!f2 || f2.a < RD(k.md(), 17).a) && $jb(a.b, WD(k.ld()), RD(k.md(), 17)); + } + tYc(a, n); + } + } + function Hpc(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m; + c2 = null; + i2 = null; + e = RD(mQb(a.b, (yCc(), CAc)), 349); + if (e == (TEc(), REc)) { + c2 = new bnb(); + i2 = new bnb(); + } + for (h = new Anb(a.d); h.a < h.c.c.length; ) { + g = RD(ynb(h), 105); + f2 = g.i; + if (!f2) { + continue; + } + switch (g.e.g) { + case 0: + b = RD(Nsb(new Osb(g.b)), 64); + e == REc && b == (qpd(), Yod) ? (ZEb(c2.c, g), true) : e == REc && b == (qpd(), npd) ? (ZEb(i2.c, g), true) : Fpc(g, b); + break; + case 1: + j = g.a.d.j; + k = g.c.d.j; + j == (qpd(), Yod) ? Gpc(g, Yod, (enc(), bnc), g.a) : k == Yod ? Gpc(g, Yod, (enc(), cnc), g.c) : j == npd ? Gpc(g, npd, (enc(), cnc), g.a) : k == npd && Gpc(g, npd, (enc(), bnc), g.c); + break; + case 2: + case 3: + d = g.b; + Csb(d, (qpd(), Yod)) ? Csb(d, npd) ? Csb(d, ppd) ? Csb(d, Xod) || Gpc(g, Yod, (enc(), cnc), g.c) : Gpc(g, Yod, (enc(), bnc), g.a) : Gpc(g, Yod, (enc(), anc), null) : Gpc(g, npd, (enc(), anc), null); + break; + case 4: + l = g.a.d.j; + m = g.a.d.j; + l == (qpd(), Yod) || m == Yod ? Gpc(g, npd, (enc(), anc), null) : Gpc(g, Yod, (enc(), anc), null); + } + } + if (c2) { + c2.c.length == 0 || Epc(c2, (qpd(), Yod)); + i2.c.length == 0 || Epc(i2, (qpd(), npd)); + } + } + function oGc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r; + c2.Ug("Breadth first model order layering", 1); + a.a = b; + q = new bnb(); + for (p = new Anb(a.a.a); p.a < p.c.c.length; ) { + n = RD(ynb(p), 10); + n.k == (r3b(), p3b) && (ZEb(q.c, n), true); + } + yob(); + _mb(q, new tGc()); + i2 = true; + e = new R4b(a.a); + d = null; + Rmb(a.a.b, e); + for (o2 = new Anb(q); o2.a < o2.c.c.length; ) { + n = RD(ynb(o2), 10); + if (i2) { + g3b(n, e); + i2 = false; + } else { + for (h = new is(Mr(Z2b(n).a.Kc(), new ir())); gs(h); ) { + f2 = RD(hs(h), 18); + if (f2.c.i.k == (r3b(), p3b) && f2.c.i.c == e || f2.c.i.k == n3b && RD(hs(new is(Mr(Z2b(f2.c.i).a.Kc(), new ir()))), 18).c.i.c == e) { + d = new R4b(a.a); + Rmb(a.a.b, d); + e = new R4b(a.a); + Rmb(a.a.b, e); + } + } + for (g = new is(Mr(Z2b(n).a.Kc(), new ir())); gs(g); ) { + f2 = RD(hs(g), 18); + f2.c.i.k == (r3b(), n3b) && !f2.c.i.c && g3b(f2.c.i, d); + } + g3b(n, e); + } + } + a.a.a.c.length = 0; + r = new bnb(); + for (l = new Anb(a.a.b); l.a < l.c.c.length; ) { + j = RD(ynb(l), 30); + j.a.c.length == 0 && (ZEb(r.c, j), true); + } + Ce(a.a.b, r); + m = 0; + for (k = new Anb(a.a.b); k.a < k.c.c.length; ) { + j = RD(ynb(k), 30); + j.p = m; + ++m; + } + c2.Vg(); + } + function K5b(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p; + d = RD(mQb(a, (Ywc(), Awc)), 27); + o2 = RD(mQb(a, (yCc(), mAc)), 17).a; + f2 = RD(mQb(a, VAc), 17).a; + Ixd(d, mAc, sgb(o2)); + Ixd(d, VAc, sgb(f2)); + Dyd(d, a.n.a + b.a); + Eyd(d, a.n.b + b.b); + if (RD(Gxd(d, lBc), 181).gc() != 0 || !!a.e || dE(mQb(Y2b(a), kBc)) === dE((JDc(), HDc)) && xDc((wDc(), (!a.q ? (yob(), yob(), wob) : a.q)._b(iBc) ? m = RD(mQb(a, iBc), 203) : m = RD(mQb(Y2b(a), jBc), 203), m))) { + Cyd(d, a.o.a); + Ayd(d, a.o.b); + } + for (l = new Anb(a.j); l.a < l.c.c.length; ) { + j = RD(ynb(l), 12); + p = mQb(j, Awc); + if (ZD(p, 193)) { + e = RD(p, 123); + Byd(e, j.n.a, j.n.b); + Ixd(e, GBc, j.j); + } + } + n = RD(mQb(a, dBc), 181).gc() != 0; + for (i2 = new Anb(a.b); i2.a < i2.c.c.length; ) { + g = RD(ynb(i2), 72); + if (n || RD(mQb(g, dBc), 181).gc() != 0) { + c2 = RD(mQb(g, Awc), 135); + zyd(c2, g.o.a, g.o.b); + Byd(c2, g.n.a, g.n.b); + } + } + if (!Rod(RD(mQb(a, EBc), 21))) { + for (k = new Anb(a.j); k.a < k.c.c.length; ) { + j = RD(ynb(k), 12); + for (h = new Anb(j.f); h.a < h.c.c.length; ) { + g = RD(ynb(h), 72); + c2 = RD(mQb(g, Awc), 135); + Cyd(c2, g.o.a); + Ayd(c2, g.o.b); + Byd(c2, g.n.a, g.n.b); + } + } + } + } + function X2c(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C; + b.Ug("Calculate Graph Size", 1); + b.dh(a, eFe); + l = Hze; + m = Hze; + j = fFe; + k = fFe; + for (p = new dMd((!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a)); p.e != p.i.gc(); ) { + n = RD(bMd(p), 27); + s = n.i; + t = n.j; + C = n.g; + h = n.f; + i2 = RD(Gxd(n, (umd(), eld)), 140); + l = $wnd.Math.min(l, s - i2.b); + m = $wnd.Math.min(m, t - i2.d); + j = $wnd.Math.max(j, s + C + i2.c); + k = $wnd.Math.max(k, t + h + i2.a); + } + r = RD(Gxd(a, (umd(), tld)), 107); + q = new rjd(l - r.b, m - r.d); + B = j - l + (r.b + r.c); + g = k - m + (r.d + r.a); + if (Heb(TD(Gxd(a, ($4c(), G4c))))) { + u = RD(Gxd(a, (u2c(), t2c)), 27); + v = RD(Gxd(u, eld), 140); + w2 = u.i + u.g / 2 + (v.b + v.c) / 2 - q.a; + A = u.j + u.f / 2 + (v.d + v.a) / 2 - q.b; + e = B - w2; + f2 = g - A; + if (e < B / 2) { + c2 = e - w2; + B += c2; + q.a -= c2; + } else { + c2 = w2 - e; + B += c2; + } + if (f2 < g / 2) { + d = f2 - A; + g += d; + q.b -= d; + } else { + d = A - f2; + g += d; + } + } + for (o2 = new dMd((!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a)); o2.e != o2.i.gc(); ) { + n = RD(bMd(o2), 27); + Dyd(n, n.i - q.a); + Eyd(n, n.j - q.b); + } + if (!Heb(TD(Gxd(a, mld)))) { + Cyd(a, B); + Ayd(a, g); + } + Ixd(a, Ikd, B - (r.b + r.c)); + Ixd(a, Hkd, g - (r.d + r.a)); + b.dh(a, gFe); + } + function IUc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n; + a.e.a.$b(); + a.f.a.$b(); + a.c.c.length = 0; + a.i.c.length = 0; + a.g.a.$b(); + if (b) { + for (g = new Anb(b.a); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 10); + for (l = e3b(f2, (qpd(), Xod)).Kc(); l.Ob(); ) { + k = RD(l.Pb(), 12); + Ysb(a.e, k); + for (e = new Anb(k.g); e.a < e.c.c.length; ) { + d = RD(ynb(e), 18); + if (W0b(d)) { + continue; + } + Rmb(a.c, d); + OUc(a, d); + h = d.c.i.k; + (h == (r3b(), p3b) || h == q3b || h == m3b || h == l3b) && Rmb(a.j, d); + n = d.d; + m = n.i.c; + m == c2 ? Ysb(a.f, n) : m == b ? Ysb(a.e, n) : Ymb(a.c, d); + } + } + } + } + if (c2) { + for (g = new Anb(c2.a); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 10); + for (j = new Anb(f2.j); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 12); + for (e = new Anb(i2.g); e.a < e.c.c.length; ) { + d = RD(ynb(e), 18); + W0b(d) && Ysb(a.g, d); + } + } + for (l = e3b(f2, (qpd(), ppd)).Kc(); l.Ob(); ) { + k = RD(l.Pb(), 12); + Ysb(a.f, k); + for (e = new Anb(k.g); e.a < e.c.c.length; ) { + d = RD(ynb(e), 18); + if (W0b(d)) { + continue; + } + Rmb(a.c, d); + OUc(a, d); + h = d.c.i.k; + (h == (r3b(), p3b) || h == q3b || h == m3b || h == l3b) && Rmb(a.j, d); + n = d.d; + m = n.i.c; + m == c2 ? Ysb(a.f, n) : m == b ? Ysb(a.e, n) : Ymb(a.c, d); + } + } + } + } + } + function iSc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u; + c2.Ug("Polyline edge routing", 1); + q = Kfb(UD(mQb(b, (yCc(), AAc)))); + n = Kfb(UD(mQb(b, cCc))); + e = Kfb(UD(mQb(b, UBc))); + d = $wnd.Math.min(1, e / n); + t = 0; + i2 = 0; + if (b.b.c.length != 0) { + u = fSc(RD(Vmb(b.b, 0), 30)); + t = 0.4 * d * u; + } + h = new Jkb(b.b, 0); + while (h.b < h.d.gc()) { + g = (sFb(h.b < h.d.gc()), RD(h.d.Xb(h.c = h.b++), 30)); + f2 = ar(g, bSc); + f2 && t > 0 && (t -= n); + p2b(g, t); + k = 0; + for (m = new Anb(g.a); m.a < m.c.c.length; ) { + l = RD(ynb(m), 10); + j = 0; + for (p = new is(Mr(a3b(l).a.Kc(), new ir())); gs(p); ) { + o2 = RD(hs(p), 18); + r = K3b(o2.c).b; + s = K3b(o2.d).b; + if (g == o2.d.i.c && !W0b(o2)) { + jSc(o2, t, 0.4 * d * $wnd.Math.abs(r - s)); + if (o2.c.j == (qpd(), ppd)) { + r = 0; + s = 0; + } + } + j = $wnd.Math.max(j, $wnd.Math.abs(s - r)); + } + switch (l.k.g) { + case 0: + case 4: + case 1: + case 3: + case 5: + kSc(a, l, t, q); + } + k = $wnd.Math.max(k, j); + } + if (h.b < h.d.gc()) { + u = fSc((sFb(h.b < h.d.gc()), RD(h.d.Xb(h.c = h.b++), 30))); + k = $wnd.Math.max(k, u); + sFb(h.b > 0); + h.a.Xb(h.c = --h.b); + } + i2 = 0.4 * d * k; + !f2 && h.b < h.d.gc() && (i2 += n); + t += g.c.a + i2; + } + a.a.a.$b(); + b.f.a = t; + c2.Vg(); + } + function GGd(a) { + var b, c2, d, e, f2; + Ivb(a, IIe); + switch ((!a.b && (a.b = new Yie(E4, a, 4, 7)), a.b).i + (!a.c && (a.c = new Yie(E4, a, 5, 8)), a.c).i) { + case 0: + throw Adb(new agb("The edge must have at least one source or target.")); + case 1: + return (!a.b && (a.b = new Yie(E4, a, 4, 7)), a.b).i == 0 ? vCd(AGd(RD(QHd((!a.c && (a.c = new Yie(E4, a, 5, 8)), a.c), 0), 84))) : vCd(AGd(RD(QHd((!a.b && (a.b = new Yie(E4, a, 4, 7)), a.b), 0), 84))); + } + if ((!a.b && (a.b = new Yie(E4, a, 4, 7)), a.b).i == 1 && (!a.c && (a.c = new Yie(E4, a, 5, 8)), a.c).i == 1) { + e = AGd(RD(QHd((!a.b && (a.b = new Yie(E4, a, 4, 7)), a.b), 0), 84)); + f2 = AGd(RD(QHd((!a.c && (a.c = new Yie(E4, a, 5, 8)), a.c), 0), 84)); + if (vCd(e) == vCd(f2)) { + return vCd(e); + } else if (e == vCd(f2)) { + return e; + } else if (f2 == vCd(e)) { + return f2; + } + } + d = Fl(Al(cD(WC(cJ, 1), rve, 20, 0, [(!a.b && (a.b = new Yie(E4, a, 4, 7)), a.b), (!a.c && (a.c = new Yie(E4, a, 5, 8)), a.c)]))); + b = AGd(RD(hs(d), 84)); + while (gs(d)) { + c2 = AGd(RD(hs(d), 84)); + if (c2 != b && !NGd(c2, b)) { + if (vCd(c2) == vCd(b)) { + b = vCd(c2); + } else { + b = HGd(b, c2); + if (!b) { + return null; + } + } + } + } + return b; + } + function _zd(b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u; + n = c2.length; + if (n > 0) { + j = (BFb(0, c2.length), c2.charCodeAt(0)); + if (j != 64) { + if (j == 37) { + m = c2.lastIndexOf("%"); + k = false; + if (m != 0 && (m == n - 1 || (k = (BFb(m + 1, c2.length), c2.charCodeAt(m + 1) == 46)))) { + h = (AFb(1, m, c2.length), c2.substr(1, m - 1)); + u = lhb("%", h) ? null : oSd(h); + e = 0; + if (k) { + try { + e = Oeb((BFb(m + 2, c2.length + 1), c2.substr(m + 2)), qwe, lve); + } catch (a) { + a = zdb(a); + if (ZD(a, 130)) { + i2 = a; + throw Adb(new RSd(i2)); + } else + throw Adb(a); + } + } + for (r = P2d(b.Gh()); r.Ob(); ) { + p = k3d(r); + if (ZD(p, 519)) { + f2 = RD(p, 598); + t = f2.d; + if ((u == null ? t == null : lhb(u, t)) && e-- == 0) { + return f2; + } + } + } + return null; + } + } + l = c2.lastIndexOf("."); + o2 = l == -1 ? c2 : (AFb(0, l, c2.length), c2.substr(0, l)); + d = 0; + if (l != -1) { + try { + d = Oeb((BFb(l + 1, c2.length + 1), c2.substr(l + 1)), qwe, lve); + } catch (a) { + a = zdb(a); + if (ZD(a, 130)) { + o2 = c2; + } else + throw Adb(a); + } + } + o2 = lhb("%", o2) ? null : oSd(o2); + for (q = P2d(b.Gh()); q.Ob(); ) { + p = k3d(q); + if (ZD(p, 197)) { + g = RD(p, 197); + s = g.xe(); + if ((o2 == null ? s == null : lhb(o2, s)) && d-- == 0) { + return g; + } + } + } + return null; + } + } + return Pvd(b, c2); + } + function Hlc(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s; + k = new Tsb(); + i2 = new Tp(); + for (d = new Anb(a.a.a.b); d.a < d.c.c.length; ) { + b = RD(ynb(d), 60); + j = Zjc(b); + if (j) { + rtb(k.f, j, b); + } else { + s = $jc(b); + if (s) { + for (f2 = new Anb(s.k); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 18); + Rc(i2, e, b); + } + } + } + } + for (c2 = new Anb(a.a.a.b); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 60); + j = Zjc(b); + if (j) { + for (h = new is(Mr(a3b(j).a.Kc(), new ir())); gs(h); ) { + g = RD(hs(h), 18); + if (W0b(g)) { + continue; + } + o2 = g.c; + r = g.d; + if ((qpd(), hpd).Hc(g.c.j) && hpd.Hc(g.d.j)) { + continue; + } + p = RD(Wjb(k, g.d.i), 60); + rIb(uIb(tIb(vIb(sIb(new wIb(), 0), 100), a.c[b.a.d]), a.c[p.a.d])); + if (o2.j == ppd && q4b((J3b(), o2))) { + for (m = RD(Qc(i2, g), 21).Kc(); m.Ob(); ) { + l = RD(m.Pb(), 60); + if (l.d.c < b.d.c) { + n = a.c[l.a.d]; + q = a.c[b.a.d]; + if (n == q) { + continue; + } + rIb(uIb(tIb(vIb(sIb(new wIb(), 1), 100), n), q)); + } + } + } + if (r.j == Xod && v4b((J3b(), r))) { + for (m = RD(Qc(i2, g), 21).Kc(); m.Ob(); ) { + l = RD(m.Pb(), 60); + if (l.d.c > b.d.c) { + n = a.c[b.a.d]; + q = a.c[l.a.d]; + if (n == q) { + continue; + } + rIb(uIb(tIb(vIb(sIb(new wIb(), 1), 100), n), q)); + } + } + } + } + } + } + } + function mNb(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2; + m = RD(RD(Qc(a.r, b), 21), 87); + if (b == (qpd(), Xod) || b == ppd) { + qNb(a, b); + return; + } + f2 = b == Yod ? (mOb(), iOb) : (mOb(), lOb); + u = b == Yod ? (vLb(), uLb) : (vLb(), sLb); + c2 = RD(Vrb(a.b, b), 127); + d = c2.i; + e = d.c + Hid(cD(WC(iE, 1), vxe, 28, 15, [c2.n.b, a.C.b, a.k])); + r = d.c + d.b - Hid(cD(WC(iE, 1), vxe, 28, 15, [c2.n.c, a.C.c, a.k])); + g = WNb(_Nb(f2), a.t); + s = b == Yod ? pxe : oxe; + for (l = m.Kc(); l.Ob(); ) { + j = RD(l.Pb(), 117); + if (!j.c || j.c.d.c.length <= 0) { + continue; + } + q = j.b.Mf(); + p = j.e; + n = j.c; + o2 = n.i; + o2.b = (i2 = n.n, n.e.a + i2.b + i2.c); + o2.a = (h = n.n, n.e.b + h.d + h.a); + Ivb(u, Pye); + n.f = u; + RKb(n, (EKb(), DKb)); + o2.c = p.a - (o2.b - q.a) / 2; + v = $wnd.Math.min(e, p.a); + w2 = $wnd.Math.max(r, p.a + q.a); + o2.c < v ? o2.c = v : o2.c + o2.b > w2 && (o2.c = w2 - o2.b); + Rmb(g.d, new sOb(o2, UNb(g, o2))); + s = b == Yod ? $wnd.Math.max(s, p.b + j.b.Mf().b) : $wnd.Math.min(s, p.b); + } + s += b == Yod ? a.t : -a.t; + t = VNb((g.e = s, g)); + t > 0 && (RD(Vrb(a.b, b), 127).a.b = t); + for (k = m.Kc(); k.Ob(); ) { + j = RD(k.Pb(), 117); + if (!j.c || j.c.d.c.length <= 0) { + continue; + } + o2 = j.c.i; + o2.c -= j.e.a; + o2.d -= j.e.b; + } + } + function JSb(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n; + b = new Tsb(); + for (i2 = new dMd(a); i2.e != i2.i.gc(); ) { + h = RD(bMd(i2), 27); + c2 = new _sb(); + Zjb(FSb, h, c2); + n = new TSb(); + e = RD(zDb(new SDb(null, new Twb(new is(Mr(yGd(h).a.Kc(), new ir())))), OBb(n, tBb(new ZBb(), new XBb(), new wCb(), cD(WC(QL, 1), jwe, 108, 0, [(xBb(), vBb)])))), 85); + ISb(c2, RD(e.xc((Geb(), true)), 16), new VSb()); + d = RD(zDb(CDb(RD(e.xc(false), 15).Lc(), new XSb()), tBb(new ZBb(), new XBb(), new wCb(), cD(WC(QL, 1), jwe, 108, 0, [vBb]))), 15); + for (g = d.Kc(); g.Ob(); ) { + f2 = RD(g.Pb(), 74); + m = KGd(f2); + if (m) { + j = RD(Wd(qtb(b.f, m)), 21); + if (!j) { + j = LSb(m); + rtb(b.f, m, j); + } + ye(c2, j); + } + } + e = RD(zDb(new SDb(null, new Twb(new is(Mr(zGd(h).a.Kc(), new ir())))), OBb(n, tBb(new ZBb(), new XBb(), new wCb(), cD(WC(QL, 1), jwe, 108, 0, [vBb])))), 85); + ISb(c2, RD(e.xc(true), 16), new ZSb()); + d = RD(zDb(CDb(RD(e.xc(false), 15).Lc(), new _Sb()), tBb(new ZBb(), new XBb(), new wCb(), cD(WC(QL, 1), jwe, 108, 0, [vBb]))), 15); + for (l = d.Kc(); l.Ob(); ) { + k = RD(l.Pb(), 74); + m = MGd(k); + if (m) { + j = RD(Wd(qtb(b.f, m)), 21); + if (!j) { + j = LSb(m); + rtb(b.f, m, j); + } + ye(c2, j); + } + } + } + } + function zjb(a, b) { + xjb(); + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p; + i2 = Ddb(a, 0) < 0; + i2 && (a = Odb(a)); + if (Ddb(a, 0) == 0) { + switch (b) { + case 0: + return "0"; + case 1: + return zxe; + case 2: + return "0.00"; + case 3: + return "0.000"; + case 4: + return "0.0000"; + case 5: + return "0.00000"; + case 6: + return "0.000000"; + default: + n = new bib(); + b < 0 ? (n.a += "0E+", n) : (n.a += "0E", n); + n.a += b == qwe ? "2147483648" : "" + -b; + return n.a; + } + } + k = 18; + l = $C(hE, zwe, 28, k + 1, 15, 1); + c2 = k; + p = a; + do { + j = p; + p = Fdb(p, 10); + l[--c2] = Ydb(Bdb(48, Vdb(j, Ndb(p, 10)))) & Bwe; + } while (Ddb(p, 0) != 0); + e = Vdb(Vdb(Vdb(k, c2), b), 1); + if (b == 0) { + i2 && (l[--c2] = 45); + return Ihb(l, c2, k - c2); + } + if (b > 0 && Ddb(e, -6) >= 0) { + if (Ddb(e, 0) >= 0) { + f2 = c2 + Ydb(e); + for (h = k - 1; h >= f2; h--) { + l[h + 1] = l[h]; + } + l[++f2] = 46; + i2 && (l[--c2] = 45); + return Ihb(l, c2, k - c2 + 1); + } + for (g = 2; Ldb(g, Bdb(Odb(e), 1)); g++) { + l[--c2] = 48; + } + l[--c2] = 46; + l[--c2] = 48; + i2 && (l[--c2] = 45); + return Ihb(l, c2, k - c2); + } + o2 = c2 + 1; + d = k; + m = new cib(); + i2 && (m.a += "-", m); + if (d - o2 >= 1) { + Thb(m, l[c2]); + m.a += "."; + m.a += Ihb(l, c2 + 1, k - c2 - 1); + } else { + m.a += Ihb(l, c2, k - c2); + } + m.a += "E"; + Ddb(e, 0) > 0 && (m.a += "+", m); + m.a += "" + Zdb(e); + return m.a; + } + function Esd(a, b, c2, d, e) { + var f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2; + q = new rjd(a.g, a.f); + p = vsd(a); + p.a = $wnd.Math.max(p.a, b); + p.b = $wnd.Math.max(p.b, c2); + w2 = p.a / q.a; + k = p.b / q.b; + u = p.a - q.a; + i2 = p.b - q.b; + if (d) { + g = !vCd(a) ? RD(Gxd(a, (umd(), Nkd)), 88) : RD(Gxd(vCd(a), (umd(), Nkd)), 88); + h = dE(Gxd(a, (umd(), Hld))) === dE((Bod(), wod)); + for (s = new dMd((!a.c && (a.c = new C5d(K4, a, 9, 9)), a.c)); s.e != s.i.gc(); ) { + r = RD(bMd(s), 123); + t = RD(Gxd(r, Old), 64); + if (t == (qpd(), opd)) { + t = osd(r, g); + Ixd(r, Old, t); + } + switch (t.g) { + case 1: + h || Dyd(r, r.i * w2); + break; + case 2: + Dyd(r, r.i + u); + h || Eyd(r, r.j * k); + break; + case 3: + h || Dyd(r, r.i * w2); + Eyd(r, r.j + i2); + break; + case 4: + h || Eyd(r, r.j * k); + } + } + } + zyd(a, p.a, p.b); + if (e) { + for (m = new dMd((!a.n && (a.n = new C5d(I4, a, 1, 7)), a.n)); m.e != m.i.gc(); ) { + l = RD(bMd(m), 135); + n = l.i + l.g / 2; + o2 = l.j + l.f / 2; + v = n / q.a; + j = o2 / q.b; + if (v + j >= 1) { + if (v - j > 0 && o2 >= 0) { + Dyd(l, l.i + u); + Eyd(l, l.j + i2 * j); + } else if (v - j < 0 && n >= 0) { + Dyd(l, l.i + u * v); + Eyd(l, l.j + i2); + } + } + } + } + Ixd(a, (umd(), kld), (Qpd(), f2 = RD(mfb(H3), 9), new Fsb(f2, RD(WEb(f2, f2.length), 9), 0))); + return new rjd(w2, k); + } + function _4c(a) { + Cgd(a, new Pfd(Wfd($fd(Xfd(Zfd(Yfd(new agd(), CFe), "ELK Radial"), 'A radial layout provider which is based on the algorithm of Peter Eades published in "Drawing free trees.", published by International Institute for Advanced Study of Social Information Science, Fujitsu Limited in 1991. The radial layouter takes a tree and places the nodes in radial order around the root. The nodes of the same tree level are placed on the same radius.'), new c5c()), CFe))); + Agd(a, CFe, fEe, iGd(R4c)); + Agd(a, CFe, _ze, iGd(Y4c)); + Agd(a, CFe, jAe, iGd(K4c)); + Agd(a, CFe, CAe, iGd(L4c)); + Agd(a, CFe, iAe, iGd(M4c)); + Agd(a, CFe, kAe, iGd(J4c)); + Agd(a, CFe, gAe, iGd(N4c)); + Agd(a, CFe, lAe, iGd(Q4c)); + Agd(a, CFe, tFe, iGd(H4c)); + Agd(a, CFe, sFe, iGd(I4c)); + Agd(a, CFe, rFe, iGd(T4c)); + Agd(a, CFe, xFe, iGd(W4c)); + Agd(a, CFe, yFe, iGd(U4c)); + Agd(a, CFe, zFe, iGd(V4c)); + Agd(a, CFe, wFe, iGd(O4c)); + Agd(a, CFe, pFe, iGd(P4c)); + Agd(a, CFe, qFe, iGd(S4c)); + Agd(a, CFe, uFe, iGd(X4c)); + Agd(a, CFe, vFe, iGd(Z4c)); + Agd(a, CFe, oFe, iGd(G4c)); + } + function Peb(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l; + if (a == null) { + throw Adb(new Vgb(vve)); + } + j = a; + f2 = a.length; + i2 = false; + if (f2 > 0) { + b = (BFb(0, a.length), a.charCodeAt(0)); + if (b == 45 || b == 43) { + a = (BFb(1, a.length + 1), a.substr(1)); + --f2; + i2 = b == 45; + } + } + if (f2 == 0) { + throw Adb(new Vgb(nxe + j + '"')); + } + while (a.length > 0 && (BFb(0, a.length), a.charCodeAt(0) == 48)) { + a = (BFb(1, a.length + 1), a.substr(1)); + --f2; + } + if (f2 > (Ugb(), Sgb)[10]) { + throw Adb(new Vgb(nxe + j + '"')); + } + for (e = 0; e < f2; e++) { + if (dfb((BFb(e, a.length), a.charCodeAt(e))) == -1) { + throw Adb(new Vgb(nxe + j + '"')); + } + } + l = 0; + g = Qgb[10]; + k = Rgb2[10]; + h = Odb(Tgb[10]); + c2 = true; + d = f2 % g; + if (d > 0) { + l = -parseInt((AFb(0, d, a.length), a.substr(0, d)), 10); + a = (BFb(d, a.length + 1), a.substr(d)); + f2 -= d; + c2 = false; + } + while (f2 >= g) { + d = parseInt((AFb(0, g, a.length), a.substr(0, g)), 10); + a = (BFb(g, a.length + 1), a.substr(g)); + f2 -= g; + if (c2) { + c2 = false; + } else { + if (Ddb(l, h) < 0) { + throw Adb(new Vgb(nxe + j + '"')); + } + l = Ndb(l, k); + } + l = Vdb(l, d); + } + if (Ddb(l, 0) > 0) { + throw Adb(new Vgb(nxe + j + '"')); + } + if (!i2) { + l = Odb(l); + if (Ddb(l, 0) < 0) { + throw Adb(new Vgb(nxe + j + '"')); + } + } + return l; + } + function oSd(a) { + gSd(); + var b, c2, d, e, f2, g, h, i2; + if (a == null) + return null; + e = qhb(a, Fhb(37)); + if (e < 0) { + return a; + } else { + i2 = new dib((AFb(0, e, a.length), a.substr(0, e))); + b = $C(gE, YHe, 28, 4, 15, 1); + h = 0; + d = 0; + for (g = a.length; e < g; e++) { + BFb(e, a.length); + if (a.charCodeAt(e) == 37 && a.length > e + 2 && zSd((BFb(e + 1, a.length), a.charCodeAt(e + 1)), XRd, YRd) && zSd((BFb(e + 2, a.length), a.charCodeAt(e + 2)), XRd, YRd)) { + c2 = DSd((BFb(e + 1, a.length), a.charCodeAt(e + 1)), (BFb(e + 2, a.length), a.charCodeAt(e + 2))); + e += 2; + if (d > 0) { + (c2 & 192) == 128 ? b[h++] = c2 << 24 >> 24 : d = 0; + } else if (c2 >= 128) { + if ((c2 & 224) == 192) { + b[h++] = c2 << 24 >> 24; + d = 2; + } else if ((c2 & 240) == 224) { + b[h++] = c2 << 24 >> 24; + d = 3; + } else if ((c2 & 248) == 240) { + b[h++] = c2 << 24 >> 24; + d = 4; + } + } + if (d > 0) { + if (h == d) { + switch (h) { + case 2: { + Thb(i2, ((b[0] & 31) << 6 | b[1] & 63) & Bwe); + break; + } + case 3: { + Thb(i2, ((b[0] & 15) << 12 | (b[1] & 63) << 6 | b[2] & 63) & Bwe); + break; + } + } + h = 0; + d = 0; + } + } else { + for (f2 = 0; f2 < h; ++f2) { + Thb(i2, b[f2] & Bwe); + } + h = 0; + i2.a += String.fromCharCode(c2); + } + } else { + for (f2 = 0; f2 < h; ++f2) { + Thb(i2, b[f2] & Bwe); + } + h = 0; + Thb(i2, (BFb(e, a.length), a.charCodeAt(e))); + } + } + return i2.a; + } + } + function atd(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n, o2; + n = vCd(AGd(RD(QHd((!a.b && (a.b = new Yie(E4, a, 4, 7)), a.b), 0), 84))); + o2 = vCd(AGd(RD(QHd((!a.c && (a.c = new Yie(E4, a, 5, 8)), a.c), 0), 84))); + l = n == o2; + h = new pjd(); + b = RD(Gxd(a, (vnd(), ond)), 75); + if (!!b && b.b >= 2) { + if ((!a.a && (a.a = new C5d(F4, a, 6, 6)), a.a).i == 0) { + c2 = (bvd(), e = new Rzd(), e); + WGd((!a.a && (a.a = new C5d(F4, a, 6, 6)), a.a), c2); + } else if ((!a.a && (a.a = new C5d(F4, a, 6, 6)), a.a).i > 1) { + m = new mMd((!a.a && (a.a = new C5d(F4, a, 6, 6)), a.a)); + while (m.e != m.i.gc()) { + cMd(m); + } + } + lsd(b, RD(QHd((!a.a && (a.a = new C5d(F4, a, 6, 6)), a.a), 0), 166)); + } + if (l) { + for (d = new dMd((!a.a && (a.a = new C5d(F4, a, 6, 6)), a.a)); d.e != d.i.gc(); ) { + c2 = RD(bMd(d), 166); + for (j = new dMd((!c2.a && (c2.a = new XZd(D4, c2, 5)), c2.a)); j.e != j.i.gc(); ) { + i2 = RD(bMd(j), 377); + h.a = $wnd.Math.max(h.a, i2.a); + h.b = $wnd.Math.max(h.b, i2.b); + } + } + } + for (g = new dMd((!a.n && (a.n = new C5d(I4, a, 1, 7)), a.n)); g.e != g.i.gc(); ) { + f2 = RD(bMd(g), 135); + k = RD(Gxd(f2, und), 8); + !!k && Byd(f2, k.a, k.b); + if (l) { + h.a = $wnd.Math.max(h.a, f2.i + f2.g); + h.b = $wnd.Math.max(h.b, f2.j + f2.f); + } + } + return h; + } + function MA(a, b, c2, d, e) { + var f2, g, h; + KA(a, b); + g = b[0]; + f2 = ihb(c2.c, 0); + h = -1; + if (DA(c2)) { + if (d > 0) { + if (g + d > a.length) { + return false; + } + h = HA((AFb(0, g + d, a.length), a.substr(0, g + d)), b); + } else { + h = HA(a, b); + } + } + switch (f2) { + case 71: + h = EA(a, g, cD(WC(qJ, 1), Nve, 2, 6, [Qwe, Rwe]), b); + e.e = h; + return true; + case 77: + return PA(a, b, e, h, g); + case 76: + return RA(a, b, e, h, g); + case 69: + return NA(a, b, g, e); + case 99: + return QA(a, b, g, e); + case 97: + h = EA(a, g, cD(WC(qJ, 1), Nve, 2, 6, ["AM", "PM"]), b); + e.b = h; + return true; + case 121: + return TA(a, b, g, h, c2, e); + case 100: + if (h <= 0) { + return false; + } + e.c = h; + return true; + case 83: + if (h < 0) { + return false; + } + return OA(h, g, b[0], e); + case 104: + h == 12 && (h = 0); + case 75: + case 72: + if (h < 0) { + return false; + } + e.f = h; + e.g = false; + return true; + case 107: + if (h < 0) { + return false; + } + e.f = h; + e.g = true; + return true; + case 109: + if (h < 0) { + return false; + } + e.j = h; + return true; + case 115: + if (h < 0) { + return false; + } + e.n = h; + return true; + case 90: + if (g < a.length && (BFb(g, a.length), a.charCodeAt(g) == 90)) { + ++b[0]; + e.o = 0; + return true; + } + case 122: + case 118: + return SA(a, g, b, e); + default: + return false; + } + } + function YQc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B; + t = b.c.length; + e = new sQc(a.a, c2, null, null); + B = $C(iE, vxe, 28, t, 15, 1); + p = $C(iE, vxe, 28, t, 15, 1); + o2 = $C(iE, vxe, 28, t, 15, 1); + q = 0; + for (h = 0; h < t; h++) { + p[h] = lve; + o2[h] = qwe; + } + for (i2 = 0; i2 < t; i2++) { + d = (tFb(i2, b.c.length), RD(b.c[i2], 185)); + B[i2] = qQc(d); + B[q] > B[i2] && (q = i2); + for (l = new Anb(a.a.b); l.a < l.c.c.length; ) { + k = RD(ynb(l), 30); + for (s = new Anb(k.a); s.a < s.c.c.length; ) { + r = RD(ynb(s), 10); + w2 = Kfb(d.p[r.p]) + Kfb(d.d[r.p]); + p[i2] = $wnd.Math.min(p[i2], w2); + o2[i2] = $wnd.Math.max(o2[i2], w2 + r.o.b); + } + } + } + A = $C(iE, vxe, 28, t, 15, 1); + for (j = 0; j < t; j++) { + (tFb(j, b.c.length), RD(b.c[j], 185)).o == (EQc(), CQc) ? A[j] = p[q] - p[j] : A[j] = o2[q] - o2[j]; + } + f2 = $C(iE, vxe, 28, t, 15, 1); + for (n = new Anb(a.a.b); n.a < n.c.c.length; ) { + m = RD(ynb(n), 30); + for (v = new Anb(m.a); v.a < v.c.c.length; ) { + u = RD(ynb(v), 10); + for (g = 0; g < t; g++) { + f2[g] = Kfb((tFb(g, b.c.length), RD(b.c[g], 185)).p[u.p]) + Kfb((tFb(g, b.c.length), RD(b.c[g], 185)).d[u.p]) + A[g]; + } + bFb(f2, heb(iob.prototype.Me, iob, [])); + e.p[u.p] = (f2[1] + f2[2]) / 2; + e.d[u.p] = 0; + } + } + return e; + } + function X6b(a, b, c2) { + var d, e, f2, g, h; + d = b.i; + f2 = a.i.o; + e = a.i.d; + h = a.n; + g = xjd(cD(WC(l3, 1), Nve, 8, 0, [h, a.a])); + switch (a.j.g) { + case 1: + SKb(b, (vLb(), sLb)); + d.d = -e.d - c2 - d.a; + if (RD(RD(Vmb(b.d, 0), 187).of((Ywc(), swc)), 291) == (Pnd(), Lnd)) { + RKb(b, (EKb(), DKb)); + d.c = g.a - Kfb(UD(mQb(a, ywc))) - c2 - d.b; + } else { + RKb(b, (EKb(), CKb)); + d.c = g.a + Kfb(UD(mQb(a, ywc))) + c2; + } + break; + case 2: + RKb(b, (EKb(), CKb)); + d.c = f2.a + e.c + c2; + if (RD(RD(Vmb(b.d, 0), 187).of((Ywc(), swc)), 291) == (Pnd(), Lnd)) { + SKb(b, (vLb(), sLb)); + d.d = g.b - Kfb(UD(mQb(a, ywc))) - c2 - d.a; + } else { + SKb(b, (vLb(), uLb)); + d.d = g.b + Kfb(UD(mQb(a, ywc))) + c2; + } + break; + case 3: + SKb(b, (vLb(), uLb)); + d.d = f2.b + e.a + c2; + if (RD(RD(Vmb(b.d, 0), 187).of((Ywc(), swc)), 291) == (Pnd(), Lnd)) { + RKb(b, (EKb(), DKb)); + d.c = g.a - Kfb(UD(mQb(a, ywc))) - c2 - d.b; + } else { + RKb(b, (EKb(), CKb)); + d.c = g.a + Kfb(UD(mQb(a, ywc))) + c2; + } + break; + case 4: + RKb(b, (EKb(), DKb)); + d.c = -e.b - c2 - d.b; + if (RD(RD(Vmb(b.d, 0), 187).of((Ywc(), swc)), 291) == (Pnd(), Lnd)) { + SKb(b, (vLb(), sLb)); + d.d = g.b - Kfb(UD(mQb(a, ywc))) - c2 - d.a; + } else { + SKb(b, (vLb(), uLb)); + d.d = g.b + Kfb(UD(mQb(a, ywc))) + c2; + } + } + } + function Q8c(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p; + c2.Ug(AFe, 1); + !b.a && (b.a = new C5d(J4, b, 10, 11)); + d = Kfb(UD(Gxd(b, (X7c(), x7c)))); + k = Kfb(UD(Gxd(b, Q7c))); + m = RD(Gxd(b, N7c), 107); + n = new m9c(d, k); + f2 = l9c(n, b, m); + P8c(b, n); + h = RD(Gxd(b, K7c), 17).a; + while (h > 1) { + e = N8c(b); + l = f2.g; + o2 = RD(Gxd(b, N7c), 107); + p = Kfb(UD(Gxd(b, x7c))); + (!b.a && (b.a = new C5d(J4, b, 10, 11)), b.a).i > 1 && Kfb(UD(Gxd(b, (X6c(), T6c)))) != oxe && (f2.c + (o2.b + o2.c)) / (f2.b + (o2.d + o2.a)) < p ? Ixd(e, (X6c(), W6c), Kfb(UD(Gxd(b, W6c))) + Kfb(UD(Gxd(b, T6c)))) : (!b.a && (b.a = new C5d(J4, b, 10, 11)), b.a).i > 1 && Kfb(UD(Gxd(b, (X6c(), S6c)))) != oxe && (f2.c + (o2.b + o2.c)) / (f2.b + (o2.d + o2.a)) > p && Ixd(e, (X6c(), W6c), $wnd.Math.max(Kfb(UD(Gxd(b, U6c))), Kfb(UD(Gxd(e, W6c))) - Kfb(UD(Gxd(b, S6c))))); + n = new m9c(d, k); + i2 = l9c(n, e, m); + j = i2.g; + if (j >= l && j == j) { + for (g = 0; g < (!e.a && (e.a = new C5d(J4, e, 10, 11)), e.a).i; g++) { + O8c(a, RD(QHd((!e.a && (e.a = new C5d(J4, e, 10, 11)), e.a), g), 27), RD(QHd((!b.a && (b.a = new C5d(J4, b, 10, 11)), b.a), g), 27)); + } + P8c(b, n); + jad(f2, i2.c); + iad(f2, i2.b); + } + --h; + } + Ixd(b, (X6c(), N6c), f2.b); + Ixd(b, O6c, f2.c); + c2.Vg(); + } + function fHc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s; + b.Ug("Interactive node layering", 1); + c2 = new bnb(); + for (m = new Anb(a.a); m.a < m.c.c.length; ) { + k = RD(ynb(m), 10); + i2 = k.n.a; + h = i2 + k.o.a; + h = $wnd.Math.max(i2 + 1, h); + s = new Jkb(c2, 0); + d = null; + while (s.b < s.d.gc()) { + q = (sFb(s.b < s.d.gc()), RD(s.d.Xb(s.c = s.b++), 578)); + if (q.c >= h) { + sFb(s.b > 0); + s.a.Xb(s.c = --s.b); + break; + } else if (q.a > i2) { + if (!d) { + Rmb(q.b, k); + q.c = $wnd.Math.min(q.c, i2); + q.a = $wnd.Math.max(q.a, h); + d = q; + } else { + Tmb(d.b, q.b); + d.a = $wnd.Math.max(d.a, q.a); + Ckb(s); + } + } + } + if (!d) { + d = new jHc(); + d.c = i2; + d.a = h; + Ikb(s, d); + Rmb(d.b, k); + } + } + g = a.b; + j = 0; + for (r = new Anb(c2); r.a < r.c.c.length; ) { + q = RD(ynb(r), 578); + e = new R4b(a); + e.p = j++; + ZEb(g.c, e); + for (n = new Anb(q.b); n.a < n.c.c.length; ) { + k = RD(ynb(n), 10); + g3b(k, e); + k.p = 0; + } + } + for (l = new Anb(a.a); l.a < l.c.c.length; ) { + k = RD(ynb(l), 10); + if (k.p == 0) { + p = eHc(k, a); + while (p.a.gc() != 0) { + o2 = RD(p.a.ec().Kc().Pb(), 10); + p.a.Bc(o2) != null; + ye(p, eHc(o2, a)); + } + } + } + f2 = new Jkb(g, 0); + while (f2.b < f2.d.gc()) { + (sFb(f2.b < f2.d.gc()), RD(f2.d.Xb(f2.c = f2.b++), 30)).a.c.length == 0 && Ckb(f2); + } + a.a.c.length = 0; + b.Vg(); + } + function grd(a, b, c2, d, e, f2, g) { + var h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5, F, G, H, I; + n = 0; + D5 = 0; + for (i2 = new Anb(a); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 27); + Dsd(h); + n = $wnd.Math.max(n, h.g); + D5 += h.g * h.f; + } + o2 = D5 / a.c.length; + C = ard(a, o2); + D5 += a.c.length * C; + n = $wnd.Math.max(n, $wnd.Math.sqrt(D5 * g)) + c2.b; + H = c2.b; + I = c2.d; + m = 0; + k = c2.b + c2.c; + B = new Yub(); + Mub(B, sgb(0)); + w2 = new Yub(); + j = new Jkb(a, 0); + while (j.b < j.d.gc()) { + h = (sFb(j.b < j.d.gc()), RD(j.d.Xb(j.c = j.b++), 27)); + G = h.g; + l = h.f; + if (H + G > n) { + if (f2) { + Oub(w2, m); + Oub(B, sgb(j.b - 1)); + } + H = c2.b; + I += m + b; + m = 0; + k = $wnd.Math.max(k, c2.b + c2.c + G); + } + Dyd(h, H); + Eyd(h, I); + k = $wnd.Math.max(k, H + G + c2.c); + m = $wnd.Math.max(m, l); + H += G + b; + } + k = $wnd.Math.max(k, d); + F = I + m + c2.a; + if (F < e) { + m += e - F; + F = e; + } + if (f2) { + H = c2.b; + j = new Jkb(a, 0); + Oub(B, sgb(a.c.length)); + A = Sub(B, 0); + r = RD(evb(A), 17).a; + Oub(w2, m); + v = Sub(w2, 0); + u = 0; + while (j.b < j.d.gc()) { + if (j.b == r) { + H = c2.b; + u = Kfb(UD(evb(v))); + r = RD(evb(A), 17).a; + } + h = (sFb(j.b < j.d.gc()), RD(j.d.Xb(j.c = j.b++), 27)); + s = h.f; + Ayd(h, u); + p = u; + if (j.b == r) { + q = k - H - c2.c; + t = h.g; + Cyd(h, q); + Jsd(h, new rjd(q, p), new rjd(t, s)); + } + H += h.g + b; + } + } + return new rjd(k, F); + } + function h0b(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C; + b.Ug("Compound graph postprocessor", 1); + c2 = Heb(TD(mQb(a, (yCc(), mCc)))); + h = RD(mQb(a, (Ywc(), _vc)), 229); + k = new _sb(); + for (r = h.ec().Kc(); r.Ob(); ) { + q = RD(r.Pb(), 18); + g = new dnb(h.cc(q)); + yob(); + _mb(g, new M0b(a)); + v = H0b((tFb(0, g.c.length), RD(g.c[0], 249))); + A = I0b(RD(Vmb(g, g.c.length - 1), 249)); + t = v.i; + n2b(A.i, t) ? s = t.e : s = Y2b(t); + l = i0b(q, g); + Xub(q.a); + m = null; + for (f2 = new Anb(g); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 249); + p = new pjd(); + e2b(p, e.a, s); + n = e.b; + d = new Ejd(); + Ajd(d, 0, n.a); + Cjd(d, p); + u = new sjd(K3b(n.c)); + w2 = new sjd(K3b(n.d)); + $id(u, p); + $id(w2, p); + if (m) { + d.b == 0 ? o2 = w2 : o2 = (sFb(d.b != 0), RD(d.a.a.c, 8)); + B = $wnd.Math.abs(m.a - o2.a) > Vze; + C = $wnd.Math.abs(m.b - o2.b) > Vze; + (!c2 && B && C || c2 && (B || C)) && Mub(q.a, u); + } + ye(q.a, d); + d.b == 0 ? m = u : m = (sFb(d.b != 0), RD(d.c.b.c, 8)); + j0b(n, l, p); + if (I0b(e) == A) { + if (Y2b(A.i) != e.a) { + p = new pjd(); + e2b(p, Y2b(A.i), s); + } + pQb(q, Wwc, p); + } + k0b(n, q, s); + k.a.zc(n, k); + } + Y0b(q, v); + Z0b(q, A); + } + for (j = k.a.ec().Kc(); j.Ob(); ) { + i2 = RD(j.Pb(), 18); + Y0b(i2, null); + Z0b(i2, null); + } + b.Vg(); + } + function lXc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m; + e = RD(mQb(a, (h_c(), H$c)), 88); + k = e == (Cmd(), ymd) || e == zmd ? xmd : zmd; + c2 = RD(zDb(CDb(new SDb(null, new Swb(a.b, 16)), new $Xc()), tBb(new ZBb(), new XBb(), new wCb(), cD(WC(QL, 1), jwe, 108, 0, [(xBb(), vBb)]))), 15); + i2 = RD(zDb(GDb(c2.Oc(), new aYc(b)), tBb(new ZBb(), new XBb(), new wCb(), cD(WC(QL, 1), jwe, 108, 0, [vBb]))), 15); + i2.Gc(RD(zDb(GDb(c2.Oc(), new cYc(b)), tBb(new ZBb(), new XBb(), new wCb(), cD(WC(QL, 1), jwe, 108, 0, [vBb]))), 16)); + i2.jd(new eYc(k)); + m = new yAb(new iYc(e)); + d = new Tsb(); + for (h = i2.Kc(); h.Ob(); ) { + g = RD(h.Pb(), 240); + j = RD(g.a, 40); + if (Heb(TD(g.c))) { + m.a.zc(j, (Geb(), Eeb)) == null; + new zAb(m.a.Zc(j, false)).a.gc() > 0 && Zjb(d, j, RD(new zAb(m.a.Zc(j, false)).a.Vc(), 40)); + new zAb(m.a.ad(j, true)).a.gc() > 1 && Zjb(d, nXc(m, j), j); + } else { + if (new zAb(m.a.Zc(j, false)).a.gc() > 0) { + f2 = RD(new zAb(m.a.Zc(j, false)).a.Vc(), 40); + dE(f2) === dE(Wd(qtb(d.f, j))) && RD(mQb(j, (q$c(), TZc)), 15).Fc(f2); + } + if (new zAb(m.a.ad(j, true)).a.gc() > 1) { + l = nXc(m, j); + dE(Wd(qtb(d.f, l))) === dE(j) && RD(mQb(l, (q$c(), TZc)), 15).Fc(j); + } + m.a.Bc(j) != null; + } + } + } + function BTb(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u; + if (a.gc() == 1) { + return RD(a.Xb(0), 235); + } else if (a.gc() <= 0) { + return new gUb(); + } + for (e = a.Kc(); e.Ob(); ) { + c2 = RD(e.Pb(), 235); + o2 = 0; + k = lve; + l = lve; + i2 = qwe; + j = qwe; + for (n = new Anb(c2.e); n.a < n.c.c.length; ) { + m = RD(ynb(n), 153); + o2 += RD(mQb(m, (yVb(), lVb)), 17).a; + k = $wnd.Math.min(k, m.d.a - m.e.a / 2); + l = $wnd.Math.min(l, m.d.b - m.e.b / 2); + i2 = $wnd.Math.max(i2, m.d.a + m.e.a / 2); + j = $wnd.Math.max(j, m.d.b + m.e.b / 2); + } + pQb(c2, (yVb(), lVb), sgb(o2)); + pQb(c2, (JVb(), GVb), new rjd(k, l)); + pQb(c2, FVb, new rjd(i2, j)); + } + yob(); + a.jd(new FTb()); + p = new gUb(); + kQb(p, RD(a.Xb(0), 96)); + h = 0; + s = 0; + for (f2 = a.Kc(); f2.Ob(); ) { + c2 = RD(f2.Pb(), 235); + q = ojd(ajd(RD(mQb(c2, (JVb(), FVb)), 8)), RD(mQb(c2, GVb), 8)); + h = $wnd.Math.max(h, q.a); + s += q.a * q.b; + } + h = $wnd.Math.max(h, $wnd.Math.sqrt(s) * Kfb(UD(mQb(p, (yVb(), ZUb))))); + r = Kfb(UD(mQb(p, rVb))); + t = 0; + u = 0; + g = 0; + b = r; + for (d = a.Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 235); + q = ojd(ajd(RD(mQb(c2, (JVb(), FVb)), 8)), RD(mQb(c2, GVb), 8)); + if (t + q.a > h) { + t = 0; + u += g + r; + g = 0; + } + ATb(p, c2, t, u); + b = $wnd.Math.max(b, t + q.a); + g = $wnd.Math.max(g, q.b); + t += q.a + r; + } + return p; + } + function Aqe(a) { + zqe(); + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q; + if (a == null) + return null; + f2 = Ahb(a); + o2 = Dqe(f2); + if (o2 % 4 != 0) { + return null; + } + p = o2 / 4 | 0; + if (p == 0) + return $C(gE, YHe, 28, 0, 15, 1); + l = null; + b = 0; + c2 = 0; + d = 0; + e = 0; + g = 0; + h = 0; + i2 = 0; + j = 0; + n = 0; + m = 0; + k = 0; + l = $C(gE, YHe, 28, p * 3, 15, 1); + for (; n < p - 1; n++) { + if (!Cqe(g = f2[k++]) || !Cqe(h = f2[k++]) || !Cqe(i2 = f2[k++]) || !Cqe(j = f2[k++])) + return null; + b = xqe[g]; + c2 = xqe[h]; + d = xqe[i2]; + e = xqe[j]; + l[m++] = (b << 2 | c2 >> 4) << 24 >> 24; + l[m++] = ((c2 & 15) << 4 | d >> 2 & 15) << 24 >> 24; + l[m++] = (d << 6 | e) << 24 >> 24; + } + if (!Cqe(g = f2[k++]) || !Cqe(h = f2[k++])) { + return null; + } + b = xqe[g]; + c2 = xqe[h]; + i2 = f2[k++]; + j = f2[k++]; + if (xqe[i2] == -1 || xqe[j] == -1) { + if (i2 == 61 && j == 61) { + if ((c2 & 15) != 0) + return null; + q = $C(gE, YHe, 28, n * 3 + 1, 15, 1); + hib(l, 0, q, 0, n * 3); + q[m] = (b << 2 | c2 >> 4) << 24 >> 24; + return q; + } else if (i2 != 61 && j == 61) { + d = xqe[i2]; + if ((d & 3) != 0) + return null; + q = $C(gE, YHe, 28, n * 3 + 2, 15, 1); + hib(l, 0, q, 0, n * 3); + q[m++] = (b << 2 | c2 >> 4) << 24 >> 24; + q[m] = ((c2 & 15) << 4 | d >> 2 & 15) << 24 >> 24; + return q; + } else { + return null; + } + } else { + d = xqe[i2]; + e = xqe[j]; + l[m++] = (b << 2 | c2 >> 4) << 24 >> 24; + l[m++] = ((c2 & 15) << 4 | d >> 2 & 15) << 24 >> 24; + l[m++] = (d << 6 | e) << 24 >> 24; + } + return l; + } + function wfc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v; + b.Ug(qBe, 1); + o2 = RD(mQb(a, (yCc(), yAc)), 223); + for (e = new Anb(a.b); e.a < e.c.c.length; ) { + d = RD(ynb(e), 30); + j = t2b(d.a); + for (g = j, h = 0, i2 = g.length; h < i2; ++h) { + f2 = g[h]; + if (f2.k != (r3b(), q3b)) { + continue; + } + if (o2 == (Ymd(), Wmd)) { + for (l = new Anb(f2.j); l.a < l.c.c.length; ) { + k = RD(ynb(l), 12); + k.e.c.length == 0 || zfc(k); + k.g.c.length == 0 || Afc(k); + } + } else if (ZD(mQb(f2, (Ywc(), Awc)), 18)) { + q = RD(mQb(f2, Awc), 18); + r = RD(e3b(f2, (qpd(), ppd)).Kc().Pb(), 12); + s = RD(e3b(f2, Xod).Kc().Pb(), 12); + t = RD(mQb(r, Awc), 12); + u = RD(mQb(s, Awc), 12); + Y0b(q, u); + Z0b(q, t); + v = new sjd(s.i.n); + v.a = xjd(cD(WC(l3, 1), Nve, 8, 0, [u.i.n, u.n, u.a])).a; + Mub(q.a, v); + v = new sjd(r.i.n); + v.a = xjd(cD(WC(l3, 1), Nve, 8, 0, [t.i.n, t.n, t.a])).a; + Mub(q.a, v); + } else { + if (f2.j.c.length >= 2) { + p = true; + m = new Anb(f2.j); + c2 = RD(ynb(m), 12); + n = null; + while (m.a < m.c.c.length) { + n = c2; + c2 = RD(ynb(m), 12); + if (!pb(mQb(n, Awc), mQb(c2, Awc))) { + p = false; + break; + } + } + } else { + p = false; + } + for (l = new Anb(f2.j); l.a < l.c.c.length; ) { + k = RD(ynb(l), 12); + k.e.c.length == 0 || xfc(k, p); + k.g.c.length == 0 || yfc(k, p); + } + } + g3b(f2, null); + } + } + b.Vg(); + } + function LQc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v; + for (h = new Anb(a.a.b); h.a < h.c.c.length; ) { + f2 = RD(ynb(h), 30); + for (t = new Anb(f2.a); t.a < t.c.c.length; ) { + s = RD(ynb(t), 10); + b.g[s.p] = s; + b.a[s.p] = s; + b.d[s.p] = 0; + } + } + i2 = a.a.b; + b.c == (wQc(), uQc) && (i2 = hv(i2)); + for (g = i2.Kc(); g.Ob(); ) { + f2 = RD(g.Pb(), 30); + n = -1; + m = f2.a; + if (b.o == (EQc(), DQc)) { + n = lve; + m = hv(m); + } + for (v = m.Kc(); v.Ob(); ) { + u = RD(v.Pb(), 10); + l = null; + b.c == uQc ? l = RD(Vmb(a.b.f, u.p), 15) : l = RD(Vmb(a.b.b, u.p), 15); + if (l.gc() > 0) { + d = l.gc(); + j = eE($wnd.Math.floor((d + 1) / 2)) - 1; + e = eE($wnd.Math.ceil((d + 1) / 2)) - 1; + if (b.o == DQc) { + for (k = e; k >= j; k--) { + if (b.a[u.p] == u) { + p = RD(l.Xb(k), 42); + o2 = RD(p.a, 10); + if (!Zsb(c2, p.b) && n > a.b.e[o2.p]) { + b.a[o2.p] = u; + b.g[u.p] = b.g[o2.p]; + b.a[u.p] = b.g[u.p]; + b.f[b.g[u.p].p] = (Geb(), Heb(b.f[b.g[u.p].p]) & u.k == (r3b(), o3b) ? true : false); + n = a.b.e[o2.p]; + } + } + } + } else { + for (k = j; k <= e; k++) { + if (b.a[u.p] == u) { + r = RD(l.Xb(k), 42); + q = RD(r.a, 10); + if (!Zsb(c2, r.b) && n < a.b.e[q.p]) { + b.a[q.p] = u; + b.g[u.p] = b.g[q.p]; + b.a[u.p] = b.g[u.p]; + b.f[b.g[u.p].p] = (Geb(), Heb(b.f[b.g[u.p].p]) & u.k == (r3b(), o3b) ? true : false); + n = a.b.e[q.p]; + } + } + } + } + } + } + } + } + function iOc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B; + t = a.c[(tFb(0, b.c.length), RD(b.c[0], 18)).p]; + A = a.c[(tFb(1, b.c.length), RD(b.c[1], 18)).p]; + if (t.a.e.e - t.a.a - (t.b.e.e - t.b.a) == 0 && A.a.e.e - A.a.a - (A.b.e.e - A.b.a) == 0) { + return false; + } + r = t.b.e.f; + if (!ZD(r, 10)) { + return false; + } + q = RD(r, 10); + v = a.i[q.p]; + w2 = !q.c ? -1 : Wmb(q.c.a, q, 0); + f2 = oxe; + if (w2 > 0) { + e = RD(Vmb(q.c.a, w2 - 1), 10); + g = a.i[e.p]; + B = $wnd.Math.ceil(bFc(a.n, e, q)); + f2 = v.a.e - q.d.d - (g.a.e + e.o.b + e.d.a) - B; + } + j = oxe; + if (w2 < q.c.a.c.length - 1) { + i2 = RD(Vmb(q.c.a, w2 + 1), 10); + k = a.i[i2.p]; + B = $wnd.Math.ceil(bFc(a.n, i2, q)); + j = k.a.e - i2.d.d - (v.a.e + q.o.b + q.d.a) - B; + } + if (c2 && (Zy(), bz(vEe), $wnd.Math.abs(f2 - j) <= vEe || f2 == j || isNaN(f2) && isNaN(j))) { + return true; + } + d = GOc(t.a); + h = -GOc(t.b); + l = -GOc(A.a); + s = GOc(A.b); + p = t.a.e.e - t.a.a - (t.b.e.e - t.b.a) > 0 && A.a.e.e - A.a.a - (A.b.e.e - A.b.a) < 0; + o2 = t.a.e.e - t.a.a - (t.b.e.e - t.b.a) < 0 && A.a.e.e - A.a.a - (A.b.e.e - A.b.a) > 0; + n = t.a.e.e + t.b.a < A.b.e.e + A.a.a; + m = t.a.e.e + t.b.a > A.b.e.e + A.a.a; + u = 0; + !p && !o2 && (m ? f2 + l > 0 ? u = l : j - d > 0 && (u = d) : n && (f2 + h > 0 ? u = h : j - s > 0 && (u = s))); + v.a.e += u; + v.b && (v.d.e += u); + return false; + } + function OJb(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m; + d = new Uid2(b.Lf().a, b.Lf().b, b.Mf().a, b.Mf().b); + e = new Tid(); + if (a.c) { + for (g = new Anb(b.Rf()); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 187); + e.c = f2.Lf().a + b.Lf().a; + e.d = f2.Lf().b + b.Lf().b; + e.b = f2.Mf().a; + e.a = f2.Mf().b; + Sid(d, e); + } + } + for (j = new Anb(b.Xf()); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 852); + k = i2.Lf().a + b.Lf().a; + l = i2.Lf().b + b.Lf().b; + if (a.e) { + e.c = k; + e.d = l; + e.b = i2.Mf().a; + e.a = i2.Mf().b; + Sid(d, e); + } + if (a.d) { + for (g = new Anb(i2.Rf()); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 187); + e.c = f2.Lf().a + k; + e.d = f2.Lf().b + l; + e.b = f2.Mf().a; + e.a = f2.Mf().b; + Sid(d, e); + } + } + if (a.b) { + m = new rjd(-c2, -c2); + if (RD(b.of((umd(), Lld)), 181).Hc((Pod(), Nod))) { + for (g = new Anb(i2.Rf()); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 187); + m.a += f2.Mf().a + c2; + m.b += f2.Mf().b + c2; + } + } + m.a = $wnd.Math.max(m.a, 0); + m.b = $wnd.Math.max(m.b, 0); + MJb(d, i2.Wf(), i2.Uf(), b, i2, m, c2); + } + } + a.b && MJb(d, b.Wf(), b.Uf(), b, null, null, c2); + h = new S2b(b.Vf()); + h.d = $wnd.Math.max(0, b.Lf().b - d.d); + h.a = $wnd.Math.max(0, d.d + d.a - (b.Lf().b + b.Mf().b)); + h.b = $wnd.Math.max(0, b.Lf().a - d.c); + h.c = $wnd.Math.max(0, d.c + d.b - (b.Lf().a + b.Mf().a)); + b.Zf(h); + } + function Mz() { + var a = ["\\u0000", "\\u0001", "\\u0002", "\\u0003", "\\u0004", "\\u0005", "\\u0006", "\\u0007", "\\b", "\\t", "\\n", "\\u000B", "\\f", "\\r", "\\u000E", "\\u000F", "\\u0010", "\\u0011", "\\u0012", "\\u0013", "\\u0014", "\\u0015", "\\u0016", "\\u0017", "\\u0018", "\\u0019", "\\u001A", "\\u001B", "\\u001C", "\\u001D", "\\u001E", "\\u001F"]; + a[34] = '\\"'; + a[92] = "\\\\"; + a[173] = "\\u00ad"; + a[1536] = "\\u0600"; + a[1537] = "\\u0601"; + a[1538] = "\\u0602"; + a[1539] = "\\u0603"; + a[1757] = "\\u06dd"; + a[1807] = "\\u070f"; + a[6068] = "\\u17b4"; + a[6069] = "\\u17b5"; + a[8203] = "\\u200b"; + a[8204] = "\\u200c"; + a[8205] = "\\u200d"; + a[8206] = "\\u200e"; + a[8207] = "\\u200f"; + a[8232] = "\\u2028"; + a[8233] = "\\u2029"; + a[8234] = "\\u202a"; + a[8235] = "\\u202b"; + a[8236] = "\\u202c"; + a[8237] = "\\u202d"; + a[8238] = "\\u202e"; + a[8288] = "\\u2060"; + a[8289] = "\\u2061"; + a[8290] = "\\u2062"; + a[8291] = "\\u2063"; + a[8292] = "\\u2064"; + a[8298] = "\\u206a"; + a[8299] = "\\u206b"; + a[8300] = "\\u206c"; + a[8301] = "\\u206d"; + a[8302] = "\\u206e"; + a[8303] = "\\u206f"; + a[65279] = "\\ufeff"; + a[65529] = "\\ufff9"; + a[65530] = "\\ufffa"; + a[65531] = "\\ufffb"; + return a; + } + function zVb(a) { + Cgd(a, new Pfd(_fd(Wfd($fd(Xfd(Zfd(Yfd(new agd(), Zze), "ELK Force"), "Force-based algorithm provided by the Eclipse Layout Kernel. Implements methods that follow physical analogies by simulating forces that move the nodes into a balanced distribution. Currently the original Eades model and the Fruchterman - Reingold model are supported."), new CVb()), Zze), ysb((aGd(), ZFd), cD(WC(T5, 1), jwe, 245, 0, [XFd]))))); + Agd(a, Zze, $ze, sgb(1)); + Agd(a, Zze, _ze, 80); + Agd(a, Zze, aAe, 5); + Agd(a, Zze, Dze, Yze); + Agd(a, Zze, bAe, sgb(1)); + Agd(a, Zze, cAe, (Geb(), true)); + Agd(a, Zze, Eze, iVb); + Agd(a, Zze, dAe, iGd(_Ub)); + Agd(a, Zze, eAe, iGd(jVb)); + Agd(a, Zze, fAe, false); + Agd(a, Zze, gAe, iGd(gVb)); + Agd(a, Zze, hAe, iGd(eVb)); + Agd(a, Zze, iAe, iGd(fVb)); + Agd(a, Zze, jAe, iGd(dVb)); + Agd(a, Zze, kAe, iGd(cVb)); + Agd(a, Zze, lAe, iGd(kVb)); + Agd(a, Zze, Rze, iGd(bVb)); + Agd(a, Zze, Uze, iGd(sVb)); + Agd(a, Zze, Sze, iGd(aVb)); + Agd(a, Zze, Wze, iGd(nVb)); + Agd(a, Zze, Tze, iGd(oVb)); + Agd(a, Zze, mAe, iGd(vVb)); + Agd(a, Zze, nAe, iGd(xVb)); + Agd(a, Zze, oAe, iGd(uVb)); + Agd(a, Zze, pAe, iGd(tVb)); + Agd(a, Zze, qAe, wVb); + } + function hte(a, b) { + Vse(); + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2; + if (bkb(wse) == 0) { + l = $C(qdb, Nve, 122, yse.length, 0, 1); + for (g = 0; g < l.length; g++) { + l[g] = new xte(4); + } + d = new Rhb(); + for (f2 = 0; f2 < vse.length; f2++) { + k = new xte(4); + if (f2 < 84) { + h = f2 * 2; + n = (BFb(h, XLe.length), XLe.charCodeAt(h)); + m = (BFb(h + 1, XLe.length), XLe.charCodeAt(h + 1)); + rte(k, n, m); + } else { + h = (f2 - 84) * 2; + rte(k, zse[h], zse[h + 1]); + } + i2 = vse[f2]; + lhb(i2, "Specials") && rte(k, 65520, 65533); + if (lhb(i2, VLe)) { + rte(k, 983040, 1048573); + rte(k, 1048576, 1114109); + } + $jb(wse, i2, k); + $jb(xse, i2, yte(k)); + j = d.a.length; + 0 < j ? d.a = zhb(d.a, 0, 0) : 0 > j && (d.a += Hhb($C(hE, zwe, 28, -j, 15, 1))); + d.a += "Is"; + if (qhb(i2, Fhb(32)) >= 0) { + for (e = 0; e < i2.length; e++) { + BFb(e, i2.length); + i2.charCodeAt(e) != 32 && Jhb(d, (BFb(e, i2.length), i2.charCodeAt(e))); + } + } else { + d.a += "" + i2; + } + lte(d.a, i2, true); + } + lte(WLe, "Cn", false); + lte(YLe, "Cn", true); + c2 = new xte(4); + rte(c2, 0, MLe); + $jb(wse, "ALL", c2); + $jb(xse, "ALL", yte(c2)); + !Ase && (Ase = new Tsb()); + $jb(Ase, WLe, WLe); + !Ase && (Ase = new Tsb()); + $jb(Ase, YLe, YLe); + !Ase && (Ase = new Tsb()); + $jb(Ase, "ALL", "ALL"); + } + o2 = b ? RD(Xjb(wse, a), 138) : RD(Xjb(xse, a), 138); + return o2; + } + function i_c(a) { + Cgd(a, new Pfd(_fd(Wfd($fd(Xfd(Zfd(Yfd(new agd(), ZEe), "ELK Mr. Tree"), "Tree-based algorithm provided by the Eclipse Layout Kernel. Computes a spanning tree of the input graph and arranges all nodes according to the resulting parent-children hierarchy. I pity the fool who doesn't use Mr. Tree Layout."), new l_c()), $Ee), xsb((aGd(), WFd))))); + Agd(a, ZEe, Eze, U$c); + Agd(a, ZEe, _ze, 20); + Agd(a, ZEe, ADe, 3); + Agd(a, ZEe, Dze, Yze); + Agd(a, ZEe, $ze, sgb(1)); + Agd(a, ZEe, cAe, (Geb(), true)); + Agd(a, ZEe, LDe, iGd(G$c)); + Agd(a, ZEe, PDe, I$c); + Agd(a, ZEe, dAe, iGd(L$c)); + Agd(a, ZEe, iEe, iGd(M$c)); + Agd(a, ZEe, jAe, iGd(O$c)); + Agd(a, ZEe, hAe, iGd(P$c)); + Agd(a, ZEe, CAe, iGd(Q$c)); + Agd(a, ZEe, iAe, iGd(R$c)); + Agd(a, ZEe, kAe, iGd(N$c)); + Agd(a, ZEe, gAe, iGd(S$c)); + Agd(a, ZEe, lAe, iGd(V$c)); + Agd(a, ZEe, VEe, iGd(g_c)); + Agd(a, ZEe, XEe, iGd(Y$c)); + Agd(a, ZEe, mAe, iGd(c_c)); + Agd(a, ZEe, nAe, iGd(e_c)); + Agd(a, ZEe, oAe, iGd(b_c)); + Agd(a, ZEe, pAe, iGd(a_c)); + Agd(a, ZEe, qAe, d_c); + Agd(a, ZEe, UEe, iGd(W$c)); + Agd(a, ZEe, WEe, iGd(K$c)); + Agd(a, ZEe, TEe, iGd(f_c)); + Agd(a, ZEe, REe, iGd(F$c)); + Agd(a, ZEe, SEe, iGd(J$c)); + } + function rNb(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m; + j = RD(RD(Qc(a.r, b), 21), 87); + g = UMb(a, b); + c2 = a.u.Hc((Pod(), Jod)); + for (i2 = j.Kc(); i2.Ob(); ) { + h = RD(i2.Pb(), 117); + if (!h.c || h.c.d.c.length <= 0) { + continue; + } + m = h.b.Mf(); + k = h.c; + l = k.i; + l.b = (f2 = k.n, k.e.a + f2.b + f2.c); + l.a = (e = k.n, k.e.b + e.d + e.a); + switch (b.g) { + case 1: + if (h.a) { + l.c = (m.a - l.b) / 2; + RKb(k, (EKb(), BKb)); + } else if (g || c2) { + l.c = -l.b - a.s; + RKb(k, (EKb(), DKb)); + } else { + l.c = m.a + a.s; + RKb(k, (EKb(), CKb)); + } + l.d = -l.a - a.t; + SKb(k, (vLb(), sLb)); + break; + case 3: + if (h.a) { + l.c = (m.a - l.b) / 2; + RKb(k, (EKb(), BKb)); + } else if (g || c2) { + l.c = -l.b - a.s; + RKb(k, (EKb(), DKb)); + } else { + l.c = m.a + a.s; + RKb(k, (EKb(), CKb)); + } + l.d = m.b + a.t; + SKb(k, (vLb(), uLb)); + break; + case 2: + if (h.a) { + d = a.v ? l.a : RD(Vmb(k.d, 0), 187).Mf().b; + l.d = (m.b - d) / 2; + SKb(k, (vLb(), tLb)); + } else if (g || c2) { + l.d = -l.a - a.t; + SKb(k, (vLb(), sLb)); + } else { + l.d = m.b + a.t; + SKb(k, (vLb(), uLb)); + } + l.c = m.a + a.s; + RKb(k, (EKb(), CKb)); + break; + case 4: + if (h.a) { + d = a.v ? l.a : RD(Vmb(k.d, 0), 187).Mf().b; + l.d = (m.b - d) / 2; + SKb(k, (vLb(), tLb)); + } else if (g || c2) { + l.d = -l.a - a.t; + SKb(k, (vLb(), sLb)); + } else { + l.d = m.b + a.t; + SKb(k, (vLb(), uLb)); + } + l.c = -l.b - a.s; + RKb(k, (EKb(), DKb)); + } + g = false; + } + } + function t6b(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s; + m = false; + l = false; + if (Dod(RD(mQb(d, (yCc(), BBc)), 101))) { + g = false; + h = false; + t: + for (o2 = new Anb(d.j); o2.a < o2.c.c.length; ) { + n = RD(ynb(o2), 12); + for (q = Fl(Al(cD(WC(cJ, 1), rve, 20, 0, [new T3b(n), new _3b(n)]))); gs(q); ) { + p = RD(hs(q), 12); + if (!Heb(TD(mQb(p.i, Uzc)))) { + if (n.j == (qpd(), Yod)) { + g = true; + break t; + } + if (n.j == npd) { + h = true; + break t; + } + } + } + } + m = h && !g; + l = g && !h; + } + if (!m && !l && d.b.c.length != 0) { + k = 0; + for (j = new Anb(d.b); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 72); + k += i2.n.b + i2.o.b / 2; + } + k /= d.b.c.length; + s = k >= d.o.b / 2; + } else { + s = !l; + } + if (s) { + r = RD(mQb(d, (Ywc(), Xwc)), 15); + if (!r) { + f2 = new bnb(); + pQb(d, Xwc, f2); + } else if (m) { + f2 = r; + } else { + e = RD(mQb(d, Vvc), 15); + if (!e) { + f2 = new bnb(); + pQb(d, Vvc, f2); + } else { + r.gc() <= e.gc() ? f2 = r : f2 = e; + } + } + } else { + e = RD(mQb(d, (Ywc(), Vvc)), 15); + if (!e) { + f2 = new bnb(); + pQb(d, Vvc, f2); + } else if (l) { + f2 = e; + } else { + r = RD(mQb(d, Xwc), 15); + if (!r) { + f2 = new bnb(); + pQb(d, Xwc, f2); + } else { + e.gc() <= r.gc() ? f2 = e : f2 = r; + } + } + } + f2.Fc(a); + pQb(a, (Ywc(), Xvc), c2); + if (b.d == c2) { + Z0b(b, null); + c2.e.c.length + c2.g.c.length == 0 && P3b(c2, null); + u6b(c2); + } else { + Y0b(b, null); + c2.e.c.length + c2.g.c.length == 0 && P3b(c2, null); + } + Xub(b.a); + } + function GHc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5, F, G, H, I; + c2.Ug("MinWidth layering", 1); + n = b.b; + A = b.a; + I = RD(mQb(b, (yCc(), WAc)), 17).a; + h = RD(mQb(b, XAc), 17).a; + a.b = Kfb(UD(mQb(b, TBc))); + a.d = oxe; + for (u = new Anb(A); u.a < u.c.c.length; ) { + s = RD(ynb(u), 10); + if (s.k != (r3b(), p3b)) { + continue; + } + D5 = s.o.b; + a.d = $wnd.Math.min(a.d, D5); + } + a.d = $wnd.Math.max(1, a.d); + B = A.c.length; + a.c = $C(kE, Pwe, 28, B, 15, 1); + a.f = $C(kE, Pwe, 28, B, 15, 1); + a.e = $C(iE, vxe, 28, B, 15, 1); + j = 0; + a.a = 0; + for (v = new Anb(A); v.a < v.c.c.length; ) { + s = RD(ynb(v), 10); + s.p = j++; + a.c[s.p] = EHc(Z2b(s)); + a.f[s.p] = EHc(a3b(s)); + a.e[s.p] = s.o.b / a.d; + a.a += a.e[s.p]; + } + a.b /= a.d; + a.a /= B; + w2 = FHc(A); + _mb(A, Fob(new MHc(a))); + p = oxe; + o2 = lve; + g = null; + H = I; + G = I; + f2 = h; + e = h; + if (I < 0) { + H = RD(BHc.a.Id(), 17).a; + G = RD(BHc.b.Id(), 17).a; + } + if (h < 0) { + f2 = RD(AHc.a.Id(), 17).a; + e = RD(AHc.b.Id(), 17).a; + } + for (F = H; F <= G; F++) { + for (d = f2; d <= e; d++) { + C = DHc(a, F, d, A, w2); + r = Kfb(UD(C.a)); + m = RD(C.b, 15); + q = m.gc(); + if (r < p || r == p && q < o2) { + p = r; + o2 = q; + g = m; + } + } + } + for (l = g.Kc(); l.Ob(); ) { + k = RD(l.Pb(), 15); + i2 = new R4b(b); + for (t = k.Kc(); t.Ob(); ) { + s = RD(t.Pb(), 10); + g3b(s, i2); + } + ZEb(n.c, i2); + } + Eob(n); + A.c.length = 0; + c2.Vg(); + } + function UUc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5, F, G; + c2.Ug("Spline edge routing", 1); + if (b.b.c.length == 0) { + b.f.a = 0; + c2.Vg(); + return; + } + s = Kfb(UD(mQb(b, (yCc(), cCc)))); + h = Kfb(UD(mQb(b, XBc))); + g = Kfb(UD(mQb(b, UBc))); + r = RD(mQb(b, DAc), 350); + B = r == (lFc(), kFc); + A = Kfb(UD(mQb(b, EAc))); + a.d = b; + a.j.c.length = 0; + a.a.c.length = 0; + akb(a.k); + i2 = RD(Vmb(b.b, 0), 30); + k = ar(i2.a, (dSc(), bSc)); + o2 = RD(Vmb(b.b, b.b.c.length - 1), 30); + l = ar(o2.a, bSc); + p = new Anb(b.b); + q = null; + G = 0; + do { + t = p.a < p.c.c.length ? RD(ynb(p), 30) : null; + IUc(a, q, t); + LUc(a); + C = cwb(nDb(IDb(CDb(new SDb(null, new Swb(a.i, 16)), new jVc()), new lVc()))); + F = 0; + u = G; + m = !q || k && q == i2; + n = !t || l && t == o2; + if (C > 0) { + j = 0; + !!q && (j += h); + j += (C - 1) * g; + !!t && (j += h); + B && !!t && (j = $wnd.Math.max(j, JUc(t, g, s, A))); + if (j < s && !m && !n) { + F = (s - j) / 2; + j = s; + } + u += j; + } else + !m && !n && (u += s); + !!t && p2b(t, u); + for (w2 = new Anb(a.i); w2.a < w2.c.c.length; ) { + v = RD(ynb(w2), 131); + v.a.c = G; + v.a.b = u - G; + v.F = F; + v.p = !q; + } + Tmb(a.a, a.i); + G = u; + !!t && (G += t.c.a); + q = t; + m = n; + } while (t); + for (e = new Anb(a.j); e.a < e.c.c.length; ) { + d = RD(ynb(e), 18); + f2 = PUc(a, d); + pQb(d, (Ywc(), Rwc), f2); + D5 = RUc(a, d); + pQb(d, Twc, D5); + } + b.f.a = G; + a.d = null; + c2.Vg(); + } + function Z9b(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5; + a.b = b; + a.a = RD(mQb(b, (yCc(), JAc)), 17).a; + a.c = RD(mQb(b, LAc), 17).a; + a.c == 0 && (a.c = lve); + q = new Jkb(b.b, 0); + while (q.b < q.d.gc()) { + p = (sFb(q.b < q.d.gc()), RD(q.d.Xb(q.c = q.b++), 30)); + h = new bnb(); + k = -1; + u = -1; + for (t = new Anb(p.a); t.a < t.c.c.length; ) { + s = RD(ynb(t), 10); + if (Kr((U9b(), new is(Mr(W2b(s).a.Kc(), new ir())))) >= a.a) { + d = V9b(a, s); + k = $wnd.Math.max(k, d.b); + u = $wnd.Math.max(u, d.d); + Rmb(h, new Ptd(s, d)); + } + } + B = new bnb(); + for (j = 0; j < k; ++j) { + Qmb(B, 0, (sFb(q.b > 0), q.a.Xb(q.c = --q.b), C = new R4b(a.b), Ikb(q, C), sFb(q.b < q.d.gc()), q.d.Xb(q.c = q.b++), C)); + } + for (g = new Anb(h); g.a < g.c.c.length; ) { + e = RD(ynb(g), 42); + n = RD(e.b, 580).a; + if (!n) { + continue; + } + for (m = new Anb(n); m.a < m.c.c.length; ) { + l = RD(ynb(m), 10); + Y9b(a, l, S9b, B); + } + } + c2 = new bnb(); + for (i2 = 0; i2 < u; ++i2) { + Rmb(c2, (D5 = new R4b(a.b), Ikb(q, D5), D5)); + } + for (f2 = new Anb(h); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 42); + A = RD(e.b, 580).c; + if (!A) { + continue; + } + for (w2 = new Anb(A); w2.a < w2.c.c.length; ) { + v = RD(ynb(w2), 10); + Y9b(a, v, T9b, c2); + } + } + } + r = new Jkb(b.b, 0); + while (r.b < r.d.gc()) { + o2 = (sFb(r.b < r.d.gc()), RD(r.d.Xb(r.c = r.b++), 30)); + o2.a.c.length == 0 && Ckb(r); + } + } + function wLd(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u; + p = a.i != 0; + t = false; + r = null; + if (Mvd(a.e)) { + k = b.gc(); + if (k > 0) { + m = k < 100 ? null : new gLd(k); + j = new $Hd(b); + o2 = j.g; + r = $C(kE, Pwe, 28, k, 15, 1); + d = 0; + u = new ZHd(k); + for (e = 0; e < a.i; ++e) { + h = a.g[e]; + n = h; + v: + for (s = 0; s < 2; ++s) { + for (i2 = k; --i2 >= 0; ) { + if (n != null ? pb(n, o2[i2]) : dE(n) === dE(o2[i2])) { + if (r.length <= d) { + q = r; + r = $C(kE, Pwe, 28, 2 * r.length, 15, 1); + hib(q, 0, r, 0, d); + } + r[d++] = e; + WGd(u, o2[i2]); + break v; + } + } + n = n; + if (dE(n) === dE(h)) { + break; + } + } + } + j = u; + o2 = u.g; + k = d; + if (d > r.length) { + q = r; + r = $C(kE, Pwe, 28, d, 15, 1); + hib(q, 0, r, 0, d); + } + if (d > 0) { + t = true; + for (f2 = 0; f2 < d; ++f2) { + n = o2[f2]; + m = Kge(a, RD(n, 76), m); + } + for (g = d; --g >= 0; ) { + THd(a, r[g]); + } + if (d != k) { + for (e = k; --e >= d; ) { + THd(j, e); + } + q = r; + r = $C(kE, Pwe, 28, d, 15, 1); + hib(q, 0, r, 0, d); + } + b = j; + } + } + } else { + b = aHd(a, b); + for (e = a.i; --e >= 0; ) { + if (b.Hc(a.g[e])) { + THd(a, e); + t = true; + } + } + } + if (t) { + if (r != null) { + c2 = b.gc(); + l = c2 == 1 ? dZd(a, 4, b.Kc().Pb(), null, r[0], p) : dZd(a, 6, b, r, r[0], p); + m = c2 < 100 ? null : new gLd(c2); + for (e = b.Kc(); e.Ob(); ) { + n = e.Pb(); + m = oge(a, RD(n, 76), m); + } + if (!m) { + qvd(a.e, l); + } else { + m.nj(l); + m.oj(); + } + } else { + m = tLd(b.gc()); + for (e = b.Kc(); e.Ob(); ) { + n = e.Pb(); + m = oge(a, RD(n, 76), m); + } + !!m && m.oj(); + } + return true; + } else { + return false; + } + } + function i_b(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t; + c2 = new p_b(b); + c2.a || b_b(b); + j = a_b(b); + i2 = new Tp(); + q = new D_b(); + for (p = new Anb(b.a); p.a < p.c.c.length; ) { + o2 = RD(ynb(p), 10); + for (e = new is(Mr(a3b(o2).a.Kc(), new ir())); gs(e); ) { + d = RD(hs(e), 18); + if (d.c.i.k == (r3b(), m3b) || d.d.i.k == m3b) { + k = h_b(a, d, j, q); + Rc(i2, f_b(k.d), k.a); + } + } + } + g = new bnb(); + for (t = RD(mQb(c2.c, (Ywc(), ewc)), 21).Kc(); t.Ob(); ) { + s = RD(t.Pb(), 64); + n = q.c[s.g]; + m = q.b[s.g]; + h = q.a[s.g]; + f2 = null; + r = null; + switch (s.g) { + case 4: + f2 = new Uid2(a.d.a, n, j.b.a - a.d.a, m - n); + r = new Uid2(a.d.a, n, h, m - n); + l_b(j, new rjd(f2.c + f2.b, f2.d)); + l_b(j, new rjd(f2.c + f2.b, f2.d + f2.a)); + break; + case 2: + f2 = new Uid2(j.a.a, n, a.c.a - j.a.a, m - n); + r = new Uid2(a.c.a - h, n, h, m - n); + l_b(j, new rjd(f2.c, f2.d)); + l_b(j, new rjd(f2.c, f2.d + f2.a)); + break; + case 1: + f2 = new Uid2(n, a.d.b, m - n, j.b.b - a.d.b); + r = new Uid2(n, a.d.b, m - n, h); + l_b(j, new rjd(f2.c, f2.d + f2.a)); + l_b(j, new rjd(f2.c + f2.b, f2.d + f2.a)); + break; + case 3: + f2 = new Uid2(n, j.a.b, m - n, a.c.b - j.a.b); + r = new Uid2(n, a.c.b - h, m - n, h); + l_b(j, new rjd(f2.c, f2.d)); + l_b(j, new rjd(f2.c + f2.b, f2.d)); + } + if (f2) { + l = new y_b(); + l.d = s; + l.b = f2; + l.c = r; + l.a = Ux(RD(Qc(i2, f_b(s)), 21)); + ZEb(g.c, l); + } + } + Tmb(c2.b, g); + c2.d = DZb(LZb(j)); + return c2; + } + function PQc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p; + if (c2.p[b.p] != null) { + return; + } + h = true; + c2.p[b.p] = 0; + g = b; + p = c2.o == (EQc(), CQc) ? pxe : oxe; + do { + e = a.b.e[g.p]; + f2 = g.c.a.c.length; + if (c2.o == CQc && e > 0 || c2.o == DQc && e < f2 - 1) { + i2 = null; + j = null; + c2.o == DQc ? i2 = RD(Vmb(g.c.a, e + 1), 10) : i2 = RD(Vmb(g.c.a, e - 1), 10); + j = c2.g[i2.p]; + PQc(a, j, c2); + p = a.e.wg(p, b, g); + c2.j[b.p] == b && (c2.j[b.p] = c2.j[j.p]); + if (c2.j[b.p] == c2.j[j.p]) { + o2 = bFc(a.d, g, i2); + if (c2.o == DQc) { + d = Kfb(c2.p[b.p]); + l = Kfb(c2.p[j.p]) + Kfb(c2.d[i2.p]) - i2.d.d - o2 - g.d.a - g.o.b - Kfb(c2.d[g.p]); + if (h) { + h = false; + c2.p[b.p] = $wnd.Math.min(l, p); + } else { + c2.p[b.p] = $wnd.Math.min(d, $wnd.Math.min(l, p)); + } + } else { + d = Kfb(c2.p[b.p]); + l = Kfb(c2.p[j.p]) + Kfb(c2.d[i2.p]) + i2.o.b + i2.d.a + o2 + g.d.d - Kfb(c2.d[g.p]); + if (h) { + h = false; + c2.p[b.p] = $wnd.Math.max(l, p); + } else { + c2.p[b.p] = $wnd.Math.max(d, $wnd.Math.max(l, p)); + } + } + } else { + o2 = Kfb(UD(mQb(a.a, (yCc(), bCc)))); + n = NQc(a, c2.j[b.p]); + k = NQc(a, c2.j[j.p]); + if (c2.o == DQc) { + m = Kfb(c2.p[b.p]) + Kfb(c2.d[g.p]) + g.o.b + g.d.a + o2 - (Kfb(c2.p[j.p]) + Kfb(c2.d[i2.p]) - i2.d.d); + TQc(n, k, m); + } else { + m = Kfb(c2.p[b.p]) + Kfb(c2.d[g.p]) - g.d.d - Kfb(c2.p[j.p]) - Kfb(c2.d[i2.p]) - i2.o.b - i2.d.a - o2; + TQc(n, k, m); + } + } + } else { + p = a.e.wg(p, b, g); + } + g = c2.a[g.p]; + } while (g != b); + qRc(a.e, b); + } + function $Kc(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C; + c2 = Kfb(UD(mQb(a.a.j, (yCc(), iAc)))); + if (c2 < -1 || !a.a.i || Cod(RD(mQb(a.a.o, BBc), 101)) || b3b(a.a.o, (qpd(), Xod)).gc() < 2 && b3b(a.a.o, ppd).gc() < 2) { + return true; + } + if (a.a.c.kg()) { + return false; + } + v = 0; + u = 0; + t = new bnb(); + for (i2 = a.a.e, j = 0, k = i2.length; j < k; ++j) { + h = i2[j]; + for (m = h, n = 0, p = m.length; n < p; ++n) { + l = m[n]; + if (l.k == (r3b(), q3b)) { + ZEb(t.c, l); + continue; + } + d = a.b[l.c.p][l.p]; + if (l.k == m3b) { + d.b = 1; + RD(mQb(l, (Ywc(), Awc)), 12).j == (qpd(), Xod) && (u += d.a); + } else { + C = b3b(l, (qpd(), ppd)); + C.dc() || !br(C, new lLc()) ? d.c = 1 : (e = b3b(l, Xod), (e.dc() || !br(e, new hLc())) && (v += d.a)); + } + for (g = new is(Mr(a3b(l).a.Kc(), new ir())); gs(g); ) { + f2 = RD(hs(g), 18); + v += d.c; + u += d.b; + B = f2.d.i; + ZKc(a, d, B); + } + r = Al(cD(WC(cJ, 1), rve, 20, 0, [b3b(l, (qpd(), Yod)), b3b(l, npd)])); + for (A = new is(new Il(r.a.length, r.a)); gs(A); ) { + w2 = RD(hs(A), 12); + s = RD(mQb(w2, (Ywc(), Iwc)), 10); + if (s) { + v += d.c; + u += d.b; + ZKc(a, d, s); + } + } + } + for (o2 = new Anb(t); o2.a < o2.c.c.length; ) { + l = RD(ynb(o2), 10); + d = a.b[l.c.p][l.p]; + for (g = new is(Mr(a3b(l).a.Kc(), new ir())); gs(g); ) { + f2 = RD(hs(g), 18); + v += d.c; + u += d.b; + B = f2.d.i; + ZKc(a, d, B); + } + } + t.c.length = 0; + } + b = v + u; + q = b == 0 ? oxe : (v - u) / b; + return q >= c2; + } + function zEd(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5, F, G; + t = b; + s = new Tp(); + u = new Tp(); + k = wDd(t, mIe); + d = new OEd(a, c2, s, u); + QDd(d.a, d.b, d.c, d.d, k); + i2 = (A = s.i, !A ? s.i = new zf(s, s.c) : A); + for (C = i2.Kc(); C.Ob(); ) { + B = RD(C.Pb(), 166); + e = RD(Qc(s, B), 21); + for (p = e.Kc(); p.Ob(); ) { + o2 = p.Pb(); + v = RD(Ao(a.d, o2), 166); + if (v) { + h = (!B.e && (B.e = new Yie(F4, B, 10, 9)), B.e); + WGd(h, v); + } else { + g = zDd(t, uIe); + m = AIe + o2 + BIe + g; + n = m + zIe; + throw Adb(new CDd(n)); + } + } + } + j = (w2 = u.i, !w2 ? u.i = new zf(u, u.c) : w2); + for (F = j.Kc(); F.Ob(); ) { + D5 = RD(F.Pb(), 166); + f2 = RD(Qc(u, D5), 21); + for (r = f2.Kc(); r.Ob(); ) { + q = r.Pb(); + v = RD(Ao(a.d, q), 166); + if (v) { + l = (!D5.g && (D5.g = new Yie(F4, D5, 9, 10)), D5.g); + WGd(l, v); + } else { + g = zDd(t, uIe); + m = AIe + q + BIe + g; + n = m + zIe; + throw Adb(new CDd(n)); + } + } + } + !c2.b && (c2.b = new Yie(E4, c2, 4, 7)); + if (c2.b.i != 0 && (!c2.c && (c2.c = new Yie(E4, c2, 5, 8)), c2.c.i != 0) && (!c2.b && (c2.b = new Yie(E4, c2, 4, 7)), c2.b.i <= 1 && (!c2.c && (c2.c = new Yie(E4, c2, 5, 8)), c2.c.i <= 1)) && (!c2.a && (c2.a = new C5d(F4, c2, 6, 6)), c2.a).i == 1) { + G = RD(QHd((!c2.a && (c2.a = new C5d(F4, c2, 6, 6)), c2.a), 0), 166); + if (!Dzd(G) && !Ezd(G)) { + Kzd(G, RD(QHd((!c2.b && (c2.b = new Yie(E4, c2, 4, 7)), c2.b), 0), 84)); + Lzd(G, RD(QHd((!c2.c && (c2.c = new Yie(E4, c2, 5, 8)), c2.c), 0), 84)); + } + } + } + function QNc(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5; + for (t = a.a, u = 0, v = t.length; u < v; ++u) { + s = t[u]; + j = lve; + k = lve; + for (o2 = new Anb(s.e); o2.a < o2.c.c.length; ) { + m = RD(ynb(o2), 10); + g = !m.c ? -1 : Wmb(m.c.a, m, 0); + if (g > 0) { + l = RD(Vmb(m.c.a, g - 1), 10); + B = bFc(a.b, m, l); + q = m.n.b - m.d.d - (l.n.b + l.o.b + l.d.a + B); + } else { + q = m.n.b - m.d.d; + } + j = $wnd.Math.min(q, j); + if (g < m.c.a.c.length - 1) { + l = RD(Vmb(m.c.a, g + 1), 10); + B = bFc(a.b, m, l); + r = l.n.b - l.d.d - (m.n.b + m.o.b + m.d.a + B); + } else { + r = 2 * m.n.b; + } + k = $wnd.Math.min(r, k); + } + i2 = lve; + f2 = false; + e = RD(Vmb(s.e, 0), 10); + for (D5 = new Anb(e.j); D5.a < D5.c.c.length; ) { + C = RD(ynb(D5), 12); + p = e.n.b + C.n.b + C.a.b; + for (d = new Anb(C.e); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 18); + w2 = c2.c; + b = w2.i.n.b + w2.n.b + w2.a.b - p; + if ($wnd.Math.abs(b) < $wnd.Math.abs(i2) && $wnd.Math.abs(b) < (b < 0 ? j : k)) { + i2 = b; + f2 = true; + } + } + } + h = RD(Vmb(s.e, s.e.c.length - 1), 10); + for (A = new Anb(h.j); A.a < A.c.c.length; ) { + w2 = RD(ynb(A), 12); + p = h.n.b + w2.n.b + w2.a.b; + for (d = new Anb(w2.g); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 18); + C = c2.d; + b = C.i.n.b + C.n.b + C.a.b - p; + if ($wnd.Math.abs(b) < $wnd.Math.abs(i2) && $wnd.Math.abs(b) < (b < 0 ? j : k)) { + i2 = b; + f2 = true; + } + } + } + if (f2 && i2 != 0) { + for (n = new Anb(s.e); n.a < n.c.c.length; ) { + m = RD(ynb(n), 10); + m.n.b += i2; + } + } + } + } + function vac(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r; + d = new bnb(); + e = lve; + f2 = lve; + g = lve; + if (c2) { + e = a.f.a; + for (p = new Anb(b.j); p.a < p.c.c.length; ) { + o2 = RD(ynb(p), 12); + for (i2 = new Anb(o2.g); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 18); + if (h.a.b != 0) { + k = RD(Qub(h.a), 8); + if (k.a < e) { + f2 = e - k.a; + g = lve; + d.c.length = 0; + e = k.a; + } + if (k.a <= e) { + ZEb(d.c, h); + h.a.b > 1 && (g = $wnd.Math.min(g, $wnd.Math.abs(RD(ju(h.a, 1), 8).b - k.b))); + } + } + } + } + } else { + for (p = new Anb(b.j); p.a < p.c.c.length; ) { + o2 = RD(ynb(p), 12); + for (i2 = new Anb(o2.e); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 18); + if (h.a.b != 0) { + m = RD(Rub(h.a), 8); + if (m.a > e) { + f2 = m.a - e; + g = lve; + d.c.length = 0; + e = m.a; + } + if (m.a >= e) { + ZEb(d.c, h); + h.a.b > 1 && (g = $wnd.Math.min(g, $wnd.Math.abs(RD(ju(h.a, h.a.b - 2), 8).b - m.b))); + } + } + } + } + } + if (d.c.length != 0 && f2 > b.o.a / 2 && g > b.o.b / 2) { + n = new R3b(); + P3b(n, b); + Q3b(n, (qpd(), Yod)); + n.n.a = b.o.a / 2; + r = new R3b(); + P3b(r, b); + Q3b(r, npd); + r.n.a = b.o.a / 2; + r.n.b = b.o.b; + for (i2 = new Anb(d); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 18); + if (c2) { + j = RD(Uub(h.a), 8); + q = h.a.b == 0 ? K3b(h.d) : RD(Qub(h.a), 8); + q.b >= j.b ? Y0b(h, r) : Y0b(h, n); + } else { + j = RD(Vub(h.a), 8); + q = h.a.b == 0 ? K3b(h.c) : RD(Rub(h.a), 8); + q.b >= j.b ? Z0b(h, r) : Z0b(h, n); + } + l = RD(mQb(h, (yCc(), RAc)), 75); + !!l && ze(l, j, true); + } + b.n.a = e - b.o.a / 2; + } + } + function E0c(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m; + for (h = Sub(a.b, 0); h.b != h.d.c; ) { + g = RD(evb(h), 40); + if (lhb(g.c, IEe)) { + continue; + } + j = iWc(g, a); + b == (Cmd(), ymd) || b == zmd ? _mb(j, new D1c()) : _mb(j, new H1c()); + i2 = j.c.length; + for (d = 0; d < i2; d++) { + k = (tFb(d, j.c.length), RD(j.c[d], 65)).c; + lhb(k.c, "n11") && o0; + if (Heb(TD(mQb(g, (q$c(), UZc)))) && !mWc((tFb(d, j.c.length), RD(j.c[d], 65)), a)) { + continue; + } + e = i2 == 1 ? 0.5 : (d + 1) / (i2 + 1); + if (b == ymd) { + f2 = Kfb(UD(mQb(g, f$c))); + m = g.e.b + g.f.b * e; + Nub((tFb(d, j.c.length), RD(j.c[d], 65)).a, new rjd($wnd.Math.min(f2, g.e.a - c2), m)); + Nub((tFb(d, j.c.length), RD(j.c[d], 65)).a, new rjd(g.e.a, m)); + } else if (b == zmd) { + f2 = Kfb(UD(mQb(g, e$c))) + c2; + m = g.e.b + g.f.b * e; + Nub((tFb(d, j.c.length), RD(j.c[d], 65)).a, new rjd(f2, m)); + Nub((tFb(d, j.c.length), RD(j.c[d], 65)).a, new rjd(g.e.a + g.f.a, m)); + } else if (b == Bmd) { + f2 = Kfb(UD(mQb(g, f$c))); + l = g.e.a + g.f.a * e; + Nub((tFb(d, j.c.length), RD(j.c[d], 65)).a, new rjd(l, $wnd.Math.min(g.e.b - c2, f2))); + Nub((tFb(d, j.c.length), RD(j.c[d], 65)).a, new rjd(l, g.e.b)); + } else { + f2 = Kfb(UD(mQb(g, e$c))) + c2; + l = g.e.a + g.f.a * e; + Nub((tFb(d, j.c.length), RD(j.c[d], 65)).a, new rjd(l, f2)); + Nub((tFb(d, j.c.length), RD(j.c[d], 65)).a, new rjd(l, g.e.b + g.f.b)); + } + } + } + } + function f2b(a, b, c2, d, e, f2, g, h, i2) { + var j, k, l, m, n, o2, p; + n = c2; + k = new j3b(i2); + h3b(k, (r3b(), m3b)); + pQb(k, (Ywc(), iwc), g); + pQb(k, (yCc(), BBc), (Bod(), wod)); + p = Kfb(UD(a.of(ABc))); + pQb(k, ABc, p); + l = new R3b(); + P3b(l, k); + if (!(b != zod && b != Aod)) { + d >= 0 ? n = vpd(h) : n = spd(vpd(h)); + a.qf(GBc, n); + } + j = new pjd(); + m = false; + if (a.pf(zBc)) { + mjd(j, RD(a.of(zBc), 8)); + m = true; + } else { + ljd(j, g.a / 2, g.b / 2); + } + switch (n.g) { + case 4: + pQb(k, UAc, (cxc(), $wc)); + pQb(k, bwc, (huc(), guc)); + k.o.b = g.b; + p < 0 && (k.o.a = -p); + Q3b(l, (qpd(), Xod)); + m || (j.a = g.a); + j.a -= g.a; + break; + case 2: + pQb(k, UAc, (cxc(), axc)); + pQb(k, bwc, (huc(), euc)); + k.o.b = g.b; + p < 0 && (k.o.a = -p); + Q3b(l, (qpd(), ppd)); + m || (j.a = 0); + break; + case 1: + pQb(k, owc, (Gvc(), Fvc)); + k.o.a = g.a; + p < 0 && (k.o.b = -p); + Q3b(l, (qpd(), npd)); + m || (j.b = g.b); + j.b -= g.b; + break; + case 3: + pQb(k, owc, (Gvc(), Dvc)); + k.o.a = g.a; + p < 0 && (k.o.b = -p); + Q3b(l, (qpd(), Yod)); + m || (j.b = 0); + } + mjd(l.n, j); + pQb(k, zBc, j); + if (b == vod || b == xod || b == wod) { + o2 = 0; + if (b == vod && a.pf(CBc)) { + switch (n.g) { + case 1: + case 2: + o2 = RD(a.of(CBc), 17).a; + break; + case 3: + case 4: + o2 = -RD(a.of(CBc), 17).a; + } + } else { + switch (n.g) { + case 4: + case 2: + o2 = f2.b; + b == xod && (o2 /= e.b); + break; + case 1: + case 3: + o2 = f2.a; + b == xod && (o2 /= e.a); + } + } + pQb(k, Jwc, o2); + } + pQb(k, hwc, n); + return k; + } + function OId() { + MId(); + function h(f2) { + var g = this; + this.dispatch = function(a) { + var b = a.data; + switch (b.cmd) { + case "algorithms": + var c2 = PId((yob(), new xpb(new glb(LId.b)))); + f2.postMessage({ id: b.id, data: c2 }); + break; + case "categories": + var d = PId((yob(), new xpb(new glb(LId.c)))); + f2.postMessage({ id: b.id, data: d }); + break; + case "options": + var e = PId((yob(), new xpb(new glb(LId.d)))); + f2.postMessage({ id: b.id, data: e }); + break; + case "register": + SId(b.algorithms); + f2.postMessage({ id: b.id }); + break; + case "layout": + QId(b.graph, b.layoutOptions || {}, b.options || {}); + f2.postMessage({ id: b.id, data: b.graph }); + break; + } + }; + this.saveDispatch = function(b) { + try { + g.dispatch(b); + } catch (a) { + f2.postMessage({ id: b.data.id, error: a }); + } + }; + } + function j(b) { + var c2 = this; + this.dispatcher = new h({ postMessage: function(a) { + c2.onmessage({ data: a }); + } }); + this.postMessage = function(a) { + setTimeout(function() { + c2.dispatcher.saveDispatch({ data: a }); + }, 0); + }; + } + if (typeof document === Yxe && typeof self !== Yxe) { + var i2 = new h(self); + self.onmessage = i2.saveDispatch; + } else if (typeof module3 !== Yxe && module3.exports) { + Object.defineProperty(exports3, "__esModule", { value: true }); + module3.exports = { "default": j, Worker: j }; + } + } + function i5b(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m; + k = new j3b(c2); + kQb(k, b); + pQb(k, (Ywc(), Awc), b); + k.o.a = b.g; + k.o.b = b.f; + k.n.a = b.i; + k.n.b = b.j; + Rmb(c2.a, k); + Zjb(a.a, b, k); + ((!b.a && (b.a = new C5d(J4, b, 10, 11)), b.a).i != 0 || Heb(TD(Gxd(b, (yCc(), NAc))))) && pQb(k, Yvc, (Geb(), true)); + j = RD(mQb(c2, kwc), 21); + l = RD(mQb(k, (yCc(), BBc)), 101); + l == (Bod(), Aod) ? pQb(k, BBc, zod) : l != zod && j.Fc((ovc(), kvc)); + m = 0; + d = RD(mQb(c2, rAc), 88); + for (i2 = new dMd((!b.c && (b.c = new C5d(K4, b, 9, 9)), b.c)); i2.e != i2.i.gc(); ) { + h = RD(bMd(i2), 123); + e = vCd(b); + (dE(Gxd(e, cAc)) !== dE((kEc(), hEc)) || dE(Gxd(e, pAc)) === dE((Ptc(), Otc)) || dE(Gxd(e, pAc)) === dE((Ptc(), Mtc)) || Heb(TD(Gxd(e, eAc))) || dE(Gxd(e, Yzc)) !== dE((U$b(), T$b)) || dE(Gxd(e, ZAc)) === dE((aEc(), TDc)) || dE(Gxd(e, ZAc)) === dE((aEc(), UDc)) || dE(Gxd(e, $Ac)) === dE((_Cc(), SCc)) || dE(Gxd(e, $Ac)) === dE((_Cc(), UCc))) && !Heb(TD(Gxd(b, aAc))) && Ixd(h, zwc, sgb(m++)); + Heb(TD(Gxd(h, pBc))) || j5b(a, h, k, j, d, l); + } + for (g = new dMd((!b.n && (b.n = new C5d(I4, b, 1, 7)), b.n)); g.e != g.i.gc(); ) { + f2 = RD(bMd(g), 135); + !Heb(TD(Gxd(f2, pBc))) && !!f2.a && Rmb(k.b, h5b(f2)); + } + Heb(TD(mQb(k, Uzc))) && j.Fc((ovc(), fvc)); + if (Heb(TD(mQb(k, MAc)))) { + j.Fc((ovc(), jvc)); + j.Fc(ivc); + pQb(k, BBc, zod); + } + return k; + } + function ird(a, b, c2, d, e, f2, g) { + var h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5, F, G, H, I; + p = 0; + D5 = 0; + for (j = new Anb(a.b); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 163); + !!i2.c && Dsd(i2.c); + p = $wnd.Math.max(p, urd(i2)); + D5 += urd(i2) * trd(i2); + } + q = D5 / a.b.c.length; + C = brd(a.b, q); + D5 += a.b.c.length * C; + p = $wnd.Math.max(p, $wnd.Math.sqrt(D5 * g)) + c2.b; + H = c2.b; + I = c2.d; + n = 0; + l = c2.b + c2.c; + B = new Yub(); + Mub(B, sgb(0)); + w2 = new Yub(); + k = new Jkb(a.b, 0); + o2 = null; + h = new bnb(); + while (k.b < k.d.gc()) { + i2 = (sFb(k.b < k.d.gc()), RD(k.d.Xb(k.c = k.b++), 163)); + G = urd(i2); + m = trd(i2); + if (H + G > p) { + if (f2) { + Oub(w2, n); + Oub(B, sgb(k.b - 1)); + Rmb(a.d, o2); + h.c.length = 0; + } + H = c2.b; + I += n + b; + n = 0; + l = $wnd.Math.max(l, c2.b + c2.c + G); + } + ZEb(h.c, i2); + xrd(i2, H, I); + l = $wnd.Math.max(l, H + G + c2.c); + n = $wnd.Math.max(n, m); + H += G + b; + o2 = i2; + } + Tmb(a.a, h); + Rmb(a.d, RD(Vmb(h, h.c.length - 1), 163)); + l = $wnd.Math.max(l, d); + F = I + n + c2.a; + if (F < e) { + n += e - F; + F = e; + } + if (f2) { + H = c2.b; + k = new Jkb(a.b, 0); + Oub(B, sgb(a.b.c.length)); + A = Sub(B, 0); + s = RD(evb(A), 17).a; + Oub(w2, n); + v = Sub(w2, 0); + u = 0; + while (k.b < k.d.gc()) { + if (k.b == s) { + H = c2.b; + u = Kfb(UD(evb(v))); + s = RD(evb(A), 17).a; + } + i2 = (sFb(k.b < k.d.gc()), RD(k.d.Xb(k.c = k.b++), 163)); + vrd(i2, u); + if (k.b == s) { + r = l - H - c2.c; + t = urd(i2); + wrd(i2, r); + yrd(i2, (r - t) / 2, 0); + } + H += urd(i2) + b; + } + } + return new rjd(l, F); + } + function zne(a) { + if (a.N) + return; + a.N = true; + a.b = jBd(a, 0); + iBd(a.b, 0); + iBd(a.b, 1); + iBd(a.b, 2); + a.bb = jBd(a, 1); + iBd(a.bb, 0); + iBd(a.bb, 1); + a.fb = jBd(a, 2); + iBd(a.fb, 3); + iBd(a.fb, 4); + oBd(a.fb, 5); + a.qb = jBd(a, 3); + iBd(a.qb, 0); + oBd(a.qb, 1); + oBd(a.qb, 2); + iBd(a.qb, 3); + iBd(a.qb, 4); + oBd(a.qb, 5); + iBd(a.qb, 6); + a.a = kBd(a, 4); + a.c = kBd(a, 5); + a.d = kBd(a, 6); + a.e = kBd(a, 7); + a.f = kBd(a, 8); + a.g = kBd(a, 9); + a.i = kBd(a, 10); + a.j = kBd(a, 11); + a.k = kBd(a, 12); + a.n = kBd(a, 13); + a.o = kBd(a, 14); + a.p = kBd(a, 15); + a.q = kBd(a, 16); + a.s = kBd(a, 17); + a.r = kBd(a, 18); + a.t = kBd(a, 19); + a.u = kBd(a, 20); + a.v = kBd(a, 21); + a.w = kBd(a, 22); + a.B = kBd(a, 23); + a.A = kBd(a, 24); + a.C = kBd(a, 25); + a.D = kBd(a, 26); + a.F = kBd(a, 27); + a.G = kBd(a, 28); + a.H = kBd(a, 29); + a.J = kBd(a, 30); + a.I = kBd(a, 31); + a.K = kBd(a, 32); + a.M = kBd(a, 33); + a.L = kBd(a, 34); + a.P = kBd(a, 35); + a.Q = kBd(a, 36); + a.R = kBd(a, 37); + a.S = kBd(a, 38); + a.T = kBd(a, 39); + a.U = kBd(a, 40); + a.V = kBd(a, 41); + a.X = kBd(a, 42); + a.W = kBd(a, 43); + a.Y = kBd(a, 44); + a.Z = kBd(a, 45); + a.$ = kBd(a, 46); + a._ = kBd(a, 47); + a.ab = kBd(a, 48); + a.cb = kBd(a, 49); + a.db = kBd(a, 50); + a.eb = kBd(a, 51); + a.gb = kBd(a, 52); + a.hb = kBd(a, 53); + a.ib = kBd(a, 54); + a.jb = kBd(a, 55); + a.kb = kBd(a, 56); + a.lb = kBd(a, 57); + a.mb = kBd(a, 58); + a.nb = kBd(a, 59); + a.ob = kBd(a, 60); + a.pb = kBd(a, 61); + } + function w8b(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u; + s = 0; + if (b.f.a == 0) { + for (q = new Anb(a); q.a < q.c.c.length; ) { + o2 = RD(ynb(q), 10); + s = $wnd.Math.max(s, o2.n.a + o2.o.a + o2.d.c); + } + } else { + s = b.f.a - b.c.a; + } + s -= b.c.a; + for (p = new Anb(a); p.a < p.c.c.length; ) { + o2 = RD(ynb(p), 10); + x8b(o2.n, s - o2.o.a); + y8b(o2.f); + u8b(o2); + (!o2.q ? (yob(), yob(), wob) : o2.q)._b((yCc(), IBc)) && x8b(RD(mQb(o2, IBc), 8), s - o2.o.a); + switch (RD(mQb(o2, Rzc), 255).g) { + case 1: + pQb(o2, Rzc, (Rjd(), Pjd)); + break; + case 2: + pQb(o2, Rzc, (Rjd(), Ojd)); + } + r = o2.o; + for (u = new Anb(o2.j); u.a < u.c.c.length; ) { + t = RD(ynb(u), 12); + x8b(t.n, r.a - t.o.a); + x8b(t.a, t.o.a); + Q3b(t, o8b(t.j)); + g = RD(mQb(t, CBc), 17); + !!g && pQb(t, CBc, sgb(-g.a)); + for (f2 = new Anb(t.g); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 18); + for (d = Sub(e.a, 0); d.b != d.d.c; ) { + c2 = RD(evb(d), 8); + c2.a = s - c2.a; + } + j = RD(mQb(e, RAc), 75); + if (j) { + for (i2 = Sub(j, 0); i2.b != i2.d.c; ) { + h = RD(evb(i2), 8); + h.a = s - h.a; + } + } + for (m = new Anb(e.b); m.a < m.c.c.length; ) { + k = RD(ynb(m), 72); + x8b(k.n, s - k.o.a); + } + } + for (n = new Anb(t.f); n.a < n.c.c.length; ) { + k = RD(ynb(n), 72); + x8b(k.n, t.o.a - k.o.a); + } + } + if (o2.k == (r3b(), m3b)) { + pQb(o2, (Ywc(), hwc), o8b(RD(mQb(o2, hwc), 64))); + t8b(o2); + } + for (l = new Anb(o2.b); l.a < l.c.c.length; ) { + k = RD(ynb(l), 72); + u8b(k); + x8b(k.n, r.a - k.o.a); + } + } + } + function z8b(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u; + s = 0; + if (b.f.b == 0) { + for (q = new Anb(a); q.a < q.c.c.length; ) { + o2 = RD(ynb(q), 10); + s = $wnd.Math.max(s, o2.n.b + o2.o.b + o2.d.a); + } + } else { + s = b.f.b - b.c.b; + } + s -= b.c.b; + for (p = new Anb(a); p.a < p.c.c.length; ) { + o2 = RD(ynb(p), 10); + A8b(o2.n, s - o2.o.b); + B8b(o2.f); + v8b(o2); + (!o2.q ? (yob(), yob(), wob) : o2.q)._b((yCc(), IBc)) && A8b(RD(mQb(o2, IBc), 8), s - o2.o.b); + switch (RD(mQb(o2, Rzc), 255).g) { + case 3: + pQb(o2, Rzc, (Rjd(), Mjd)); + break; + case 4: + pQb(o2, Rzc, (Rjd(), Qjd)); + } + r = o2.o; + for (u = new Anb(o2.j); u.a < u.c.c.length; ) { + t = RD(ynb(u), 12); + A8b(t.n, r.b - t.o.b); + A8b(t.a, t.o.b); + Q3b(t, p8b(t.j)); + g = RD(mQb(t, CBc), 17); + !!g && pQb(t, CBc, sgb(-g.a)); + for (f2 = new Anb(t.g); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 18); + for (d = Sub(e.a, 0); d.b != d.d.c; ) { + c2 = RD(evb(d), 8); + c2.b = s - c2.b; + } + j = RD(mQb(e, RAc), 75); + if (j) { + for (i2 = Sub(j, 0); i2.b != i2.d.c; ) { + h = RD(evb(i2), 8); + h.b = s - h.b; + } + } + for (m = new Anb(e.b); m.a < m.c.c.length; ) { + k = RD(ynb(m), 72); + A8b(k.n, s - k.o.b); + } + } + for (n = new Anb(t.f); n.a < n.c.c.length; ) { + k = RD(ynb(n), 72); + A8b(k.n, t.o.b - k.o.b); + } + } + if (o2.k == (r3b(), m3b)) { + pQb(o2, (Ywc(), hwc), p8b(RD(mQb(o2, hwc), 64))); + s8b(o2); + } + for (l = new Anb(o2.b); l.a < l.c.c.length; ) { + k = RD(ynb(l), 72); + v8b(k); + A8b(k.n, r.b - k.o.b); + } + } + } + function Drc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5, F, G, H; + s = new Jkb(a.b, 0); + k = b.Kc(); + o2 = 0; + j = RD(k.Pb(), 17).a; + v = 0; + c2 = new _sb(); + A = new Iub(); + while (s.b < s.d.gc()) { + r = (sFb(s.b < s.d.gc()), RD(s.d.Xb(s.c = s.b++), 30)); + for (u = new Anb(r.a); u.a < u.c.c.length; ) { + t = RD(ynb(u), 10); + for (n = new is(Mr(a3b(t).a.Kc(), new ir())); gs(n); ) { + l = RD(hs(n), 18); + A.a.zc(l, A); + } + for (m = new is(Mr(Z2b(t).a.Kc(), new ir())); gs(m); ) { + l = RD(hs(m), 18); + A.a.Bc(l) != null; + } + } + if (o2 + 1 == j) { + e = new R4b(a); + Ikb(s, e); + f2 = new R4b(a); + Ikb(s, f2); + for (C = A.a.ec().Kc(); C.Ob(); ) { + B = RD(C.Pb(), 18); + if (!c2.a._b(B)) { + ++v; + c2.a.zc(B, c2); + } + g = new j3b(a); + pQb(g, (yCc(), BBc), (Bod(), yod)); + g3b(g, e); + h3b(g, (r3b(), l3b)); + p = new R3b(); + P3b(p, g); + Q3b(p, (qpd(), ppd)); + D5 = new R3b(); + P3b(D5, g); + Q3b(D5, Xod); + d = new j3b(a); + pQb(d, BBc, yod); + g3b(d, f2); + h3b(d, l3b); + q = new R3b(); + P3b(q, d); + Q3b(q, ppd); + F = new R3b(); + P3b(F, d); + Q3b(F, Xod); + w2 = new a1b(); + Y0b(w2, B.c); + Z0b(w2, p); + pQb(w2, (Ywc(), zwc), RD(mQb(B, zwc), 17)); + H = new a1b(); + Y0b(H, D5); + Z0b(H, q); + pQb(H, zwc, RD(mQb(B, zwc), 17)); + Y0b(B, F); + h = new Jrc(g, d, w2, H, B); + pQb(g, Wvc, h); + pQb(d, Wvc, h); + G = w2.c.i; + if (G.k == l3b) { + i2 = RD(mQb(G, Wvc), 313); + i2.d = h; + h.g = i2; + } + } + if (k.Ob()) { + j = RD(k.Pb(), 17).a; + } else { + break; + } + } + ++o2; + } + return sgb(v); + } + function rkc(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q; + p = new bnb(); + for (m = new Anb(a.d.b); m.a < m.c.c.length; ) { + l = RD(ynb(m), 30); + for (o2 = new Anb(l.a); o2.a < o2.c.c.length; ) { + n = RD(ynb(o2), 10); + e = RD(Wjb(a.f, n), 60); + for (i2 = new is(Mr(a3b(n).a.Kc(), new ir())); gs(i2); ) { + g = RD(hs(i2), 18); + d = Sub(g.a, 0); + j = true; + k = null; + if (d.b != d.d.c) { + b = RD(evb(d), 8); + c2 = null; + if (g.c.j == (qpd(), Yod)) { + q = new Nlc(b, new rjd(b.a, e.d.d), e, g); + q.f.a = true; + q.a = g.c; + ZEb(p.c, q); + } + if (g.c.j == npd) { + q = new Nlc(b, new rjd(b.a, e.d.d + e.d.a), e, g); + q.f.d = true; + q.a = g.c; + ZEb(p.c, q); + } + while (d.b != d.d.c) { + c2 = RD(evb(d), 8); + if (!rGb(b.b, c2.b)) { + k = new Nlc(b, c2, null, g); + ZEb(p.c, k); + if (j) { + j = false; + if (c2.b < e.d.d) { + k.f.a = true; + } else if (c2.b > e.d.d + e.d.a) { + k.f.d = true; + } else { + k.f.d = true; + k.f.a = true; + } + } + } + d.b != d.d.c && (b = c2); + } + if (k) { + f2 = RD(Wjb(a.f, g.d.i), 60); + if (b.b < f2.d.d) { + k.f.a = true; + } else if (b.b > f2.d.d + f2.d.a) { + k.f.d = true; + } else { + k.f.d = true; + k.f.a = true; + } + } + } + } + for (h = new is(Mr(Z2b(n).a.Kc(), new ir())); gs(h); ) { + g = RD(hs(h), 18); + if (g.a.b != 0) { + b = RD(Rub(g.a), 8); + if (g.d.j == (qpd(), Yod)) { + q = new Nlc(b, new rjd(b.a, e.d.d), e, g); + q.f.a = true; + q.a = g.d; + ZEb(p.c, q); + } + if (g.d.j == npd) { + q = new Nlc(b, new rjd(b.a, e.d.d + e.d.a), e, g); + q.f.d = true; + q.a = g.d; + ZEb(p.c, q); + } + } + } + } + } + return p; + } + function Nvd(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m; + i2 = new bnb(); + l = b.length; + g = $5d(c2); + for (j = 0; j < l; ++j) { + k = rhb(b, Fhb(61), j); + d = wvd(g, (AFb(j, k, b.length), b.substr(j, k - j))); + e = iXd(d); + f2 = e.jk().wi(); + switch (ihb(b, ++k)) { + case 39: { + h = phb(b, 39, ++k); + Rmb(i2, new KTd(d, lwd((AFb(k, h, b.length), b.substr(k, h - k)), f2, e))); + j = h + 1; + break; + } + case 34: { + h = phb(b, 34, ++k); + Rmb(i2, new KTd(d, lwd((AFb(k, h, b.length), b.substr(k, h - k)), f2, e))); + j = h + 1; + break; + } + case 91: { + m = new bnb(); + Rmb(i2, new KTd(d, m)); + n: + for (; ; ) { + switch (ihb(b, ++k)) { + case 39: { + h = phb(b, 39, ++k); + Rmb(m, lwd((AFb(k, h, b.length), b.substr(k, h - k)), f2, e)); + k = h + 1; + break; + } + case 34: { + h = phb(b, 34, ++k); + Rmb(m, lwd((AFb(k, h, b.length), b.substr(k, h - k)), f2, e)); + k = h + 1; + break; + } + case 110: { + ++k; + if (b.indexOf("ull", k) == k) { + m.c.push(null); + } else { + throw Adb(new yz(MHe)); + } + k += 3; + break; + } + } + if (k < l) { + switch (BFb(k, b.length), b.charCodeAt(k)) { + case 44: { + break; + } + case 93: { + break n; + } + default: { + throw Adb(new yz("Expecting , or ]")); + } + } + } else { + break; + } + } + j = k + 1; + break; + } + case 110: { + ++k; + if (b.indexOf("ull", k) == k) { + Rmb(i2, new KTd(d, null)); + } else { + throw Adb(new yz(MHe)); + } + j = k + 3; + break; + } + } + if (j < l) { + BFb(j, b.length); + if (b.charCodeAt(j) != 44) { + throw Adb(new yz("Expecting ,")); + } + } else { + break; + } + } + return Ovd(a, i2, c2); + } + function Oqe(a) { + var b, c2, d, e, f2; + b = a.c; + f2 = null; + switch (b) { + case 6: + return a.Em(); + case 13: + return a.Fm(); + case 23: + return a.wm(); + case 22: + return a.Bm(); + case 18: + return a.ym(); + case 8: + Mqe(a); + f2 = (Vse(), Dse); + break; + case 9: + return a.em(true); + case 19: + return a.fm(); + case 10: + switch (a.a) { + case 100: + case 68: + case 119: + case 87: + case 115: + case 83: + f2 = a.dm(a.a); + Mqe(a); + return f2; + case 101: + case 102: + case 110: + case 114: + case 116: + case 117: + case 118: + case 120: + { + c2 = a.cm(); + c2 < txe ? f2 = (Vse(), Vse(), new Hte(0, c2)) : f2 = cte(qse(c2)); + } + break; + case 99: + return a.om(); + case 67: + return a.jm(); + case 105: + return a.rm(); + case 73: + return a.km(); + case 103: + return a.pm(); + case 88: + return a.lm(); + case 49: + case 50: + case 51: + case 52: + case 53: + case 54: + case 55: + case 56: + case 57: + return a.gm(); + case 80: + case 112: + f2 = Sqe(a, a.a); + if (!f2) + throw Adb(new Lqe(TId((Hde(), hJe)))); + break; + default: + f2 = Yse(a.a); + } + Mqe(a); + break; + case 0: + if (a.a == 93 || a.a == 123 || a.a == 125) + throw Adb(new Lqe(TId((Hde(), gJe)))); + f2 = Yse(a.a); + d = a.a; + Mqe(a); + if ((d & 64512) == uxe && a.c == 0 && (a.a & 64512) == 56320) { + e = $C(hE, zwe, 28, 2, 15, 1); + e[0] = d & Bwe; + e[1] = a.a & Bwe; + f2 = bte(cte(Ihb(e, 0, e.length)), 0); + Mqe(a); + } + break; + default: + throw Adb(new Lqe(TId((Hde(), gJe)))); + } + return f2; + } + function WUc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5, F; + C = new Yub(); + w2 = new Yub(); + q = -1; + for (i2 = new Anb(a); i2.a < i2.c.c.length; ) { + g = RD(ynb(i2), 131); + g.s = q--; + k = 0; + t = 0; + for (f2 = new Anb(g.t); f2.a < f2.c.c.length; ) { + d = RD(ynb(f2), 274); + t += d.c; + } + for (e = new Anb(g.i); e.a < e.c.c.length; ) { + d = RD(ynb(e), 274); + k += d.c; + } + g.n = k; + g.u = t; + t == 0 ? (Pub(w2, g, w2.c.b, w2.c), true) : k == 0 && (Pub(C, g, C.c.b, C.c), true); + } + F = Xx(a); + l = a.c.length; + p = l + 1; + r = l - 1; + n = new bnb(); + while (F.a.gc() != 0) { + while (w2.b != 0) { + v = (sFb(w2.b != 0), RD(Wub(w2, w2.a.a), 131)); + F.a.Bc(v) != null; + v.s = r--; + $Uc(v, C, w2); + } + while (C.b != 0) { + A = (sFb(C.b != 0), RD(Wub(C, C.a.a), 131)); + F.a.Bc(A) != null; + A.s = p++; + $Uc(A, C, w2); + } + o2 = qwe; + for (j = F.a.ec().Kc(); j.Ob(); ) { + g = RD(j.Pb(), 131); + s = g.u - g.n; + if (s >= o2) { + if (s > o2) { + n.c.length = 0; + o2 = s; + } + ZEb(n.c, g); + } + } + if (n.c.length != 0) { + m = RD(Vmb(n, Jwb(b, n.c.length)), 131); + F.a.Bc(m) != null; + m.s = p++; + $Uc(m, C, w2); + n.c.length = 0; + } + } + u = a.c.length + 1; + for (h = new Anb(a); h.a < h.c.c.length; ) { + g = RD(ynb(h), 131); + g.s < l && (g.s += u); + } + for (B = new Anb(a); B.a < B.c.c.length; ) { + A = RD(ynb(B), 131); + c2 = new Jkb(A.t, 0); + while (c2.b < c2.d.gc()) { + d = (sFb(c2.b < c2.d.gc()), RD(c2.d.Xb(c2.c = c2.b++), 274)); + D5 = d.b; + if (A.s > D5.s) { + Ckb(c2); + Ymb(D5.i, d); + if (d.c > 0) { + d.a = D5; + Rmb(D5.t, d); + d.b = A; + Rmb(A.i, d); + } + } + } + } + } + function Efc(a, b, c2, d, e) { + var f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5, F; + p = new cnb(b.b); + u = new cnb(b.b); + m = new cnb(b.b); + B = new cnb(b.b); + q = new cnb(b.b); + for (A = Sub(b, 0); A.b != A.d.c; ) { + v = RD(evb(A), 12); + for (h = new Anb(v.g); h.a < h.c.c.length; ) { + f2 = RD(ynb(h), 18); + if (f2.c.i == f2.d.i) { + if (v.j == f2.d.j) { + ZEb(B.c, f2); + continue; + } else if (v.j == (qpd(), Yod) && f2.d.j == npd) { + ZEb(q.c, f2); + continue; + } + } + } + } + for (i2 = new Anb(q); i2.a < i2.c.c.length; ) { + f2 = RD(ynb(i2), 18); + Ffc(a, f2, c2, d, (qpd(), Xod)); + } + for (g = new Anb(B); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 18); + C = new j3b(a); + h3b(C, (r3b(), q3b)); + pQb(C, (yCc(), BBc), (Bod(), wod)); + pQb(C, (Ywc(), Awc), f2); + D5 = new R3b(); + pQb(D5, Awc, f2.d); + Q3b(D5, (qpd(), ppd)); + P3b(D5, C); + F = new R3b(); + pQb(F, Awc, f2.c); + Q3b(F, Xod); + P3b(F, C); + pQb(f2.c, Iwc, C); + pQb(f2.d, Iwc, C); + Y0b(f2, null); + Z0b(f2, null); + ZEb(c2.c, C); + pQb(C, $vc, sgb(2)); + } + for (w2 = Sub(b, 0); w2.b != w2.d.c; ) { + v = RD(evb(w2), 12); + j = v.e.c.length > 0; + r = v.g.c.length > 0; + j && r ? (ZEb(m.c, v), true) : j ? (ZEb(p.c, v), true) : r && (ZEb(u.c, v), true); + } + for (o2 = new Anb(p); o2.a < o2.c.c.length; ) { + n = RD(ynb(o2), 12); + Rmb(e, Dfc(a, n, null, c2)); + } + for (t = new Anb(u); t.a < t.c.c.length; ) { + s = RD(ynb(t), 12); + Rmb(e, Dfc(a, null, s, c2)); + } + for (l = new Anb(m); l.a < l.c.c.length; ) { + k = RD(ynb(l), 12); + Rmb(e, Dfc(a, k, k, c2)); + } + } + function psd(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t; + m = oxe; + n = oxe; + k = 0; + l = 0; + i2 = new bnb(); + for (h = new dMd((!a.b && (a.b = new C5d(G4, a, 12, 3)), a.b)); h.e != h.i.gc(); ) { + f2 = RD(bMd(h), 74); + i2 = Al(cD(WC(cJ, 1), rve, 20, 0, [i2, (!f2.n && (f2.n = new C5d(I4, f2, 1, 7)), f2.n)])); + } + for (t = Fl(Al(cD(WC(cJ, 1), rve, 20, 0, [(!a.n && (a.n = new C5d(I4, a, 1, 7)), a.n), (!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a), i2]))); gs(t); ) { + s = RD(hs(t), 422); + j = RD(s.of((umd(), eld)), 140); + m > s.nh() - j.b && (m = s.nh() - j.b); + n > s.oh() - j.d && (n = s.oh() - j.d); + k < s.nh() + s.mh() + j.c && (k = s.nh() + s.mh() + j.c); + l < s.oh() + s.lh() + j.a && (l = s.oh() + s.lh() + j.a); + } + for (g = new dMd((!a.b && (a.b = new C5d(G4, a, 12, 3)), a.b)); g.e != g.i.gc(); ) { + f2 = RD(bMd(g), 74); + for (r = new dMd((!f2.a && (f2.a = new C5d(F4, f2, 6, 6)), f2.a)); r.e != r.i.gc(); ) { + q = RD(bMd(r), 166); + o2 = q.j; + d = q.b; + p = q.k; + e = q.c; + m = $wnd.Math.min(m, o2); + m = $wnd.Math.min(m, d); + k = $wnd.Math.max(k, o2); + k = $wnd.Math.max(k, d); + n = $wnd.Math.min(n, p); + n = $wnd.Math.min(n, e); + l = $wnd.Math.max(l, p); + l = $wnd.Math.max(l, e); + for (c2 = new dMd((!q.a && (q.a = new XZd(D4, q, 5)), q.a)); c2.e != c2.i.gc(); ) { + b = RD(bMd(c2), 377); + m = $wnd.Math.min(m, b.a); + k = $wnd.Math.max(k, b.a); + n = $wnd.Math.min(n, b.b); + l = $wnd.Math.max(l, b.b); + } + } + } + Ixd(a, (umd(), Ikd), k - m); + Ixd(a, Hkd, l - n); + } + function uOc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l; + c2.Ug("Network simplex node placement", 1); + a.e = b; + a.n = RD(mQb(b, (Ywc(), Qwc)), 312); + tOc(a); + fOc(a); + FDb(EDb(new SDb(null, new Swb(a.e.b, 16)), new iPc()), new kPc(a)); + FDb(CDb(EDb(CDb(EDb(new SDb(null, new Swb(a.e.b, 16)), new ZPc()), new _Pc()), new bQc()), new dQc()), new gPc(a)); + if (Heb(TD(mQb(a.e, (yCc(), gBc))))) { + g = c2.eh(1); + g.Ug("Straight Edges Pre-Processing", 1); + sOc(a); + g.Vg(); + } + AIb(a.f); + f2 = RD(mQb(b, gCc), 17).a * a.f.a.c.length; + lJb(yJb(zJb(CJb(a.f), f2), false), c2.eh(1)); + if (a.d.a.gc() != 0) { + g = c2.eh(1); + g.Ug("Flexible Where Space Processing", 1); + h = RD(Lvb(KDb(GDb(new SDb(null, new Swb(a.f.a, 16)), new mPc()), new IOc())), 17).a; + i2 = RD(Lvb(JDb(GDb(new SDb(null, new Swb(a.f.a, 16)), new oPc()), new MOc())), 17).a; + j = i2 - h; + k = eJb(new gJb(), a.f); + l = eJb(new gJb(), a.f); + rIb(uIb(tIb(sIb(vIb(new wIb(), 2e4), j), k), l)); + FDb(CDb(CDb(_nb(a.i), new qPc()), new sPc()), new uPc(h, k, j, l)); + for (e = a.d.a.ec().Kc(); e.Ob(); ) { + d = RD(e.Pb(), 218); + d.g = 1; + } + lJb(yJb(zJb(CJb(a.f), f2), false), g.eh(1)); + g.Vg(); + } + if (Heb(TD(mQb(b, gBc)))) { + g = c2.eh(1); + g.Ug("Straight Edges Post-Processing", 1); + rOc(a); + g.Vg(); + } + eOc(a); + a.e = null; + a.f = null; + a.i = null; + a.c = null; + akb(a.k); + a.j = null; + a.a = null; + a.o = null; + a.d.a.$b(); + c2.Vg(); + } + function XGc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t; + c2.Ug("Depth first model order layering", 1); + a.d = b; + q = new bnb(); + for (p = new Anb(a.d.a); p.a < p.c.c.length; ) { + n = RD(ynb(p), 10); + n.k == (r3b(), p3b) && (ZEb(q.c, n), true); + } + yob(); + _mb(q, new aHc()); + g = true; + a.b = new R4b(a.d); + a.a = null; + Rmb(a.d.b, a.b); + a.b.p = 0; + a.c = 0; + a.f = new Yub(); + for (o2 = new Anb(q); o2.a < o2.c.c.length; ) { + n = RD(ynb(o2), 10); + if (g) { + g3b(n, a.b); + g = false; + } else { + if (VGc(a, n)) { + m = a.c; + m = UGc(m, n); + d = m + 2; + k = m - a.c; + if (a.f.b == 0) { + TGc(a, d, n); + } else { + if (k > 0) { + for (t = Sub(a.f, 0); t.b != t.d.c; ) { + s = RD(evb(t), 10); + s.p += m - a.e; + } + WGc(a); + Xub(a.f); + TGc(a, d, n); + } else { + Mub(a.f, n); + n.p = d; + a.e = $wnd.Math.max(a.e, d); + for (f2 = new is(Mr(Z2b(n).a.Kc(), new ir())); gs(f2); ) { + e = RD(hs(f2), 18); + if (!e.c.i.c && e.c.i.k == (r3b(), n3b)) { + Mub(a.f, e.c.i); + e.c.i.p = d - 1; + } + } + a.c = d; + } + } + } else { + WGc(a); + Xub(a.f); + d = 0; + if (gs(new is(Mr(Z2b(n).a.Kc(), new ir())))) { + m = 0; + m = UGc(m, n); + d = m + 2; + TGc(a, d, n); + } else { + Mub(a.f, n); + n.p = 0; + a.e = $wnd.Math.max(a.e, 0); + a.b = RD(Vmb(a.d.b, 0), 30); + a.c = 0; + } + } + } + } + a.f.b == 0 || WGc(a); + a.d.a.c.length = 0; + r = new bnb(); + for (j = new Anb(a.d.b); j.a < j.c.c.length; ) { + h = RD(ynb(j), 30); + h.a.c.length == 0 && (ZEb(r.c, h), true); + } + Ce(a.d.b, r); + l = 0; + for (i2 = new Anb(a.d.b); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 30); + h.p = l; + ++l; + } + c2.Vg(); + } + function EEd(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5, F, G, H, I, J, K2; + D5 = null; + G = b; + F = pEd(a, DGd(c2), G); + jyd(F, zDd(G, uIe)); + H = RD(Ao(a.g, tDd(qC(G, bIe))), 27); + m = qC(G, "sourcePort"); + d = null; + !!m && (d = tDd(m)); + I = RD(Ao(a.j, d), 123); + if (!H) { + h = uDd(G); + o2 = "An edge must have a source node (edge id: '" + h; + p = o2 + zIe; + throw Adb(new CDd(p)); + } + if (!!I && !Hb(MCd(I), H)) { + i2 = zDd(G, uIe); + q = "The source port of an edge must be a port of the edge's source node (edge id: '" + i2; + r = q + zIe; + throw Adb(new CDd(r)); + } + B = (!F.b && (F.b = new Yie(E4, F, 4, 7)), F.b); + f2 = null; + I ? f2 = I : f2 = H; + WGd(B, f2); + J = RD(Ao(a.g, tDd(qC(G, CIe))), 27); + n = qC(G, "targetPort"); + e = null; + !!n && (e = tDd(n)); + K2 = RD(Ao(a.j, e), 123); + if (!J) { + l = uDd(G); + s = "An edge must have a target node (edge id: '" + l; + t = s + zIe; + throw Adb(new CDd(t)); + } + if (!!K2 && !Hb(MCd(K2), J)) { + j = zDd(G, uIe); + u = "The target port of an edge must be a port of the edge's target node (edge id: '" + j; + v = u + zIe; + throw Adb(new CDd(v)); + } + C = (!F.c && (F.c = new Yie(E4, F, 5, 8)), F.c); + g = null; + K2 ? g = K2 : g = J; + WGd(C, g); + if ((!F.b && (F.b = new Yie(E4, F, 4, 7)), F.b).i == 0 || (!F.c && (F.c = new Yie(E4, F, 5, 8)), F.c).i == 0) { + k = zDd(G, uIe); + w2 = yIe + k; + A = w2 + zIe; + throw Adb(new CDd(A)); + } + GEd(G, F); + FEd(G, F); + D5 = CEd(a, G, F); + return D5; + } + function JTb(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5, F, G, H, I; + n = RD(mQb(a, (JVb(), HVb)), 27); + t = lve; + u = lve; + r = qwe; + s = qwe; + for (w2 = new Anb(a.e); w2.a < w2.c.c.length; ) { + v = RD(ynb(w2), 153); + F = v.d; + G = v.e; + t = $wnd.Math.min(t, F.a - G.a / 2); + u = $wnd.Math.min(u, F.b - G.b / 2); + r = $wnd.Math.max(r, F.a + G.a / 2); + s = $wnd.Math.max(s, F.b + G.b / 2); + } + for (c2 = new Anb(a.b); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 250); + F = b.d; + G = b.e; + t = $wnd.Math.min(t, F.a - G.a / 2); + u = $wnd.Math.min(u, F.b - G.b / 2); + r = $wnd.Math.max(r, F.a + G.a / 2); + s = $wnd.Math.max(s, F.b + G.b / 2); + } + D5 = RD(Gxd(n, (yVb(), hVb)), 107); + C = new rjd(D5.b - t, D5.d - u); + for (j = new Anb(a.e); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 153); + B = mQb(i2, HVb); + if (ZD(B, 207)) { + p = RD(B, 27); + A = $id(new sjd(i2.d), C); + Byd(p, A.a - p.g / 2, A.b - p.f / 2); + } + } + for (f2 = new Anb(a.c); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 290); + l = RD(mQb(e, HVb), 74); + m = IGd(l, true, true); + H = new sjd(ZTb(e)); + $id(H, C); + Nzd(m, H.a, H.b); + Umb(e.a, new OTb(C, m)); + d = new sjd($Tb(e)); + $id(d, C); + Gzd(m, d.a, d.b); + } + for (h = new Anb(a.d); h.a < h.c.c.length; ) { + g = RD(ynb(h), 454); + o2 = RD(mQb(g, HVb), 135); + q = $id(new sjd(g.d), C); + Byd(o2, q.a, q.b); + } + I = r - t + (D5.b + D5.c); + k = s - u + (D5.d + D5.a); + Heb(TD(Gxd(n, (umd(), mld)))) || Esd(n, I, k, false, true); + Ixd(n, Ikd, I - (D5.b + D5.c)); + Ixd(n, Hkd, k - (D5.d + D5.a)); + } + function F$b(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5; + l = H$b(B$b(a, (qpd(), bpd)), b); + o2 = G$b(B$b(a, cpd), b); + u = G$b(B$b(a, kpd), b); + B = I$b(B$b(a, mpd), b); + m = I$b(B$b(a, Zod), b); + s = G$b(B$b(a, jpd), b); + p = G$b(B$b(a, dpd), b); + w2 = G$b(B$b(a, lpd), b); + v = G$b(B$b(a, $od), b); + C = I$b(B$b(a, apd), b); + r = G$b(B$b(a, hpd), b); + t = G$b(B$b(a, gpd), b); + A = G$b(B$b(a, _od), b); + D5 = I$b(B$b(a, ipd), b); + n = I$b(B$b(a, epd), b); + q = G$b(B$b(a, fpd), b); + c2 = Hid(cD(WC(iE, 1), vxe, 28, 15, [s.a, B.a, w2.a, D5.a])); + d = Hid(cD(WC(iE, 1), vxe, 28, 15, [o2.a, l.a, u.a, q.a])); + e = r.a; + f2 = Hid(cD(WC(iE, 1), vxe, 28, 15, [p.a, m.a, v.a, n.a])); + j = Hid(cD(WC(iE, 1), vxe, 28, 15, [s.b, o2.b, p.b, t.b])); + i2 = Hid(cD(WC(iE, 1), vxe, 28, 15, [B.b, l.b, m.b, q.b])); + k = C.b; + h = Hid(cD(WC(iE, 1), vxe, 28, 15, [w2.b, u.b, v.b, A.b])); + x$b(B$b(a, bpd), c2 + e, j + k); + x$b(B$b(a, fpd), c2 + e, j + k); + x$b(B$b(a, cpd), c2 + e, 0); + x$b(B$b(a, kpd), c2 + e, j + k + i2); + x$b(B$b(a, mpd), 0, j + k); + x$b(B$b(a, Zod), c2 + e + d, j + k); + x$b(B$b(a, dpd), c2 + e + d, 0); + x$b(B$b(a, lpd), 0, j + k + i2); + x$b(B$b(a, $od), c2 + e + d, j + k + i2); + x$b(B$b(a, apd), 0, j); + x$b(B$b(a, hpd), c2, 0); + x$b(B$b(a, _od), 0, j + k + i2); + x$b(B$b(a, epd), c2 + e + d, 0); + g = new pjd(); + g.a = Hid(cD(WC(iE, 1), vxe, 28, 15, [c2 + d + e + f2, C.a, t.a, A.a])); + g.b = Hid(cD(WC(iE, 1), vxe, 28, 15, [j + i2 + k + h, r.b, D5.b, n.b])); + return g; + } + function EFb(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5; + s = new rjd(oxe, oxe); + b = new rjd(pxe, pxe); + for (B = new Anb(a); B.a < B.c.c.length; ) { + A = RD(ynb(B), 8); + s.a = $wnd.Math.min(s.a, A.a); + s.b = $wnd.Math.min(s.b, A.b); + b.a = $wnd.Math.max(b.a, A.a); + b.b = $wnd.Math.max(b.b, A.b); + } + m = new rjd(b.a - s.a, b.b - s.b); + j = new rjd(s.a - 50, s.b - m.a - 50); + k = new rjd(s.a - 50, b.b + m.a + 50); + l = new rjd(b.a + m.b / 2 + 50, s.b + m.b / 2); + n = new XFb(j, k, l); + w2 = new _sb(); + f2 = new bnb(); + c2 = new bnb(); + w2.a.zc(n, w2); + for (D5 = new Anb(a); D5.a < D5.c.c.length; ) { + C = RD(ynb(D5), 8); + f2.c.length = 0; + for (v = w2.a.ec().Kc(); v.Ob(); ) { + t = RD(v.Pb(), 317); + d = t.d; + bjd(d, t.a); + $y(bjd(t.d, C), bjd(t.d, t.a)) < 0 && (ZEb(f2.c, t), true); + } + c2.c.length = 0; + for (u = new Anb(f2); u.a < u.c.c.length; ) { + t = RD(ynb(u), 317); + for (q = new Anb(t.e); q.a < q.c.c.length; ) { + o2 = RD(ynb(q), 177); + g = true; + for (i2 = new Anb(f2); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 317); + h != t && (Fvb(o2, Vmb(h.e, 0)) || Fvb(o2, Vmb(h.e, 1)) || Fvb(o2, Vmb(h.e, 2))) && (g = false); + } + g && (ZEb(c2.c, o2), true); + } + } + Ve(w2, f2); + xgb(w2, new FFb()); + for (p = new Anb(c2); p.a < p.c.c.length; ) { + o2 = RD(ynb(p), 177); + Ysb(w2, new XFb(C, o2.a, o2.b)); + } + } + r = new _sb(); + xgb(w2, new HFb(r)); + e = r.a.ec().Kc(); + while (e.Ob()) { + o2 = RD(e.Pb(), 177); + (WFb(n, o2.a) || WFb(n, o2.b)) && e.Qb(); + } + xgb(r, new JFb()); + return r; + } + function pvd() { + pvd = geb; + dvd(); + ovd = cvd.a; + RD(QHd(xYd(cvd.a), 0), 19); + ivd = cvd.f; + RD(QHd(xYd(cvd.f), 0), 19); + RD(QHd(xYd(cvd.f), 1), 35); + nvd = cvd.n; + RD(QHd(xYd(cvd.n), 0), 35); + RD(QHd(xYd(cvd.n), 1), 35); + RD(QHd(xYd(cvd.n), 2), 35); + RD(QHd(xYd(cvd.n), 3), 35); + jvd = cvd.g; + RD(QHd(xYd(cvd.g), 0), 19); + RD(QHd(xYd(cvd.g), 1), 35); + fvd = cvd.c; + RD(QHd(xYd(cvd.c), 0), 19); + RD(QHd(xYd(cvd.c), 1), 19); + kvd = cvd.i; + RD(QHd(xYd(cvd.i), 0), 19); + RD(QHd(xYd(cvd.i), 1), 19); + RD(QHd(xYd(cvd.i), 2), 19); + RD(QHd(xYd(cvd.i), 3), 19); + RD(QHd(xYd(cvd.i), 4), 35); + lvd = cvd.j; + RD(QHd(xYd(cvd.j), 0), 19); + gvd = cvd.d; + RD(QHd(xYd(cvd.d), 0), 19); + RD(QHd(xYd(cvd.d), 1), 19); + RD(QHd(xYd(cvd.d), 2), 19); + RD(QHd(xYd(cvd.d), 3), 19); + RD(QHd(xYd(cvd.d), 4), 35); + RD(QHd(xYd(cvd.d), 5), 35); + RD(QHd(xYd(cvd.d), 6), 35); + RD(QHd(xYd(cvd.d), 7), 35); + evd = cvd.b; + RD(QHd(xYd(cvd.b), 0), 35); + RD(QHd(xYd(cvd.b), 1), 35); + hvd = cvd.e; + RD(QHd(xYd(cvd.e), 0), 35); + RD(QHd(xYd(cvd.e), 1), 35); + RD(QHd(xYd(cvd.e), 2), 35); + RD(QHd(xYd(cvd.e), 3), 35); + RD(QHd(xYd(cvd.e), 4), 19); + RD(QHd(xYd(cvd.e), 5), 19); + RD(QHd(xYd(cvd.e), 6), 19); + RD(QHd(xYd(cvd.e), 7), 19); + RD(QHd(xYd(cvd.e), 8), 19); + RD(QHd(xYd(cvd.e), 9), 19); + RD(QHd(xYd(cvd.e), 10), 35); + mvd = cvd.k; + RD(QHd(xYd(cvd.k), 0), 35); + RD(QHd(xYd(cvd.k), 1), 35); + } + function Pqe(a) { + var b, c2, d, e, f2; + b = a.c; + switch (b) { + case 11: + return a.vm(); + case 12: + return a.xm(); + case 14: + return a.zm(); + case 15: + return a.Cm(); + case 16: + return a.Am(); + case 17: + return a.Dm(); + case 21: + Mqe(a); + return Vse(), Vse(), Ese; + case 10: + switch (a.a) { + case 65: + return a.hm(); + case 90: + return a.mm(); + case 122: + return a.tm(); + case 98: + return a.nm(); + case 66: + return a.im(); + case 60: + return a.sm(); + case 62: + return a.qm(); + } + } + f2 = Oqe(a); + b = a.c; + switch (b) { + case 3: + return a.Im(f2); + case 4: + return a.Gm(f2); + case 5: + return a.Hm(f2); + case 0: + if (a.a == 123 && a.d < a.j) { + e = a.d; + d = 0; + c2 = -1; + if ((b = ihb(a.i, e++)) >= 48 && b <= 57) { + d = b - 48; + while (e < a.j && (b = ihb(a.i, e++)) >= 48 && b <= 57) { + d = d * 10 + b - 48; + if (d < 0) + throw Adb(new Lqe(TId((Hde(), CJe)))); + } + } else { + throw Adb(new Lqe(TId((Hde(), yJe)))); + } + c2 = d; + if (b == 44) { + if (e >= a.j) { + throw Adb(new Lqe(TId((Hde(), AJe)))); + } else if ((b = ihb(a.i, e++)) >= 48 && b <= 57) { + c2 = b - 48; + while (e < a.j && (b = ihb(a.i, e++)) >= 48 && b <= 57) { + c2 = c2 * 10 + b - 48; + if (c2 < 0) + throw Adb(new Lqe(TId((Hde(), CJe)))); + } + if (d > c2) + throw Adb(new Lqe(TId((Hde(), BJe)))); + } else { + c2 = -1; + } + } + if (b != 125) + throw Adb(new Lqe(TId((Hde(), zJe)))); + if (a.bm(e)) { + f2 = (Vse(), Vse(), new Kte(9, f2)); + a.d = e + 1; + } else { + f2 = (Vse(), Vse(), new Kte(3, f2)); + a.d = e; + } + f2.Om(d); + f2.Nm(c2); + Mqe(a); + } + } + return f2; + } + function bXb(a) { + var b, c2, d, e, f2; + c2 = RD(mQb(a, (Ywc(), kwc)), 21); + b = vfd(YWb); + e = RD(mQb(a, (yCc(), IAc)), 346); + e == (Fnd(), Cnd) && ofd(b, ZWb); + Heb(TD(mQb(a, GAc))) ? pfd(b, (sXb(), nXb), (hcc(), Zbc)) : pfd(b, (sXb(), pXb), (hcc(), Zbc)); + mQb(a, (rid(), qid)) != null && ofd(b, $Wb); + (Heb(TD(mQb(a, PAc))) || Heb(TD(mQb(a, HAc)))) && nfd(b, (sXb(), rXb), (hcc(), lbc)); + switch (RD(mQb(a, rAc), 88).g) { + case 2: + case 3: + case 4: + nfd(pfd(b, (sXb(), nXb), (hcc(), nbc)), rXb, mbc); + } + c2.Hc((ovc(), fvc)) && nfd(pfd(pfd(b, (sXb(), nXb), (hcc(), kbc)), qXb, ibc), rXb, jbc); + dE(mQb(a, ZAc)) !== dE((aEc(), $Dc)) && pfd(b, (sXb(), pXb), (hcc(), Rbc)); + if (c2.Hc(mvc)) { + pfd(b, (sXb(), nXb), (hcc(), Xbc)); + pfd(b, oXb, Vbc); + pfd(b, pXb, Wbc); + } + dE(mQb(a, Xzc)) !== dE(($uc(), Yuc)) && dE(mQb(a, yAc)) !== dE((Ymd(), Vmd)) && nfd(b, (sXb(), rXb), (hcc(), Abc)); + Heb(TD(mQb(a, KAc))) && pfd(b, (sXb(), pXb), (hcc(), zbc)); + Heb(TD(mQb(a, nAc))) && pfd(b, (sXb(), pXb), (hcc(), dcc)); + if (eXb(a)) { + dE(mQb(a, IAc)) === dE(Cnd) ? d = RD(mQb(a, gAc), 299) : d = RD(mQb(a, hAc), 299); + f2 = d == (xvc(), vvc) ? (hcc(), Ubc) : (hcc(), gcc); + pfd(b, (sXb(), qXb), f2); + } + switch (RD(mQb(a, vCc), 388).g) { + case 1: + pfd(b, (sXb(), qXb), (hcc(), ecc)); + break; + case 2: + nfd(pfd(pfd(b, (sXb(), pXb), (hcc(), ebc)), qXb, fbc), rXb, gbc); + } + dE(mQb(a, cAc)) !== dE((kEc(), hEc)) && pfd(b, (sXb(), pXb), (hcc(), fcc)); + return b; + } + function crc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t; + if (Ujb(a.a, b)) { + if (Zsb(RD(Wjb(a.a, b), 49), c2)) { + return 1; + } + } else { + Zjb(a.a, b, new _sb()); + } + if (Ujb(a.a, c2)) { + if (Zsb(RD(Wjb(a.a, c2), 49), b)) { + return -1; + } + } else { + Zjb(a.a, c2, new _sb()); + } + if (Ujb(a.e, b)) { + if (Zsb(RD(Wjb(a.e, b), 49), c2)) { + return -1; + } + } else { + Zjb(a.e, b, new _sb()); + } + if (Ujb(a.e, c2)) { + if (Zsb(RD(Wjb(a.a, c2), 49), b)) { + return 1; + } + } else { + Zjb(a.e, c2, new _sb()); + } + if (a.c == (kEc(), iEc) || !nQb(b, (Ywc(), zwc)) || !nQb(c2, (Ywc(), zwc))) { + l = null; + for (j = new Anb(b.j); j.a < j.c.c.length; ) { + h = RD(ynb(j), 12); + h.e.c.length == 0 || RD(Vmb(h.e, 0), 18).c.i.c != b.c && (l = RD(Vmb(h.e, 0), 18).c); + } + n = null; + for (i2 = new Anb(c2.j); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 12); + h.e.c.length == 0 || RD(Vmb(h.e, 0), 18).c.i.c != c2.c && (n = RD(Vmb(h.e, 0), 18).c); + } + if (!!l && !!n) { + k = l.i; + m = n.i; + if (!!k && k == m) { + for (p = new Anb(k.j); p.a < p.c.c.length; ) { + o2 = RD(ynb(p), 12); + if (o2 == l) { + erc(a, c2, b); + return -1; + } else if (o2 == n) { + erc(a, b, c2); + return 1; + } + } + return hgb(drc(a, b), drc(a, c2)); + } + for (r = a.d, s = 0, t = r.length; s < t; ++s) { + q = r[s]; + if (q == k) { + erc(a, c2, b); + return -1; + } else if (q == m) { + erc(a, b, c2); + return 1; + } + } + } + if (!nQb(b, (Ywc(), zwc)) || !nQb(c2, zwc)) { + e = drc(a, b); + g = drc(a, c2); + e > g ? erc(a, b, c2) : erc(a, c2, b); + return e < g ? -1 : e > g ? 1 : 0; + } + } + d = RD(mQb(b, (Ywc(), zwc)), 17).a; + f2 = RD(mQb(c2, zwc), 17).a; + d > f2 ? erc(a, b, c2) : erc(a, c2, b); + return d < f2 ? -1 : d > f2 ? 1 : 0; + } + function uAd(b, c2, d) { + var e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r; + if (d == null) { + return null; + } + if (b.a != c2.jk()) { + throw Adb(new agb(VHe + c2.xe() + WHe)); + } + if (ZD(c2, 469)) { + r = z1d(RD(c2, 685), d); + if (!r) { + throw Adb(new agb(XHe + d + "' is not a valid enumerator of '" + c2.xe() + "'")); + } + return r; + } + switch (Oee((lke(), jke), c2).Nl()) { + case 2: { + d = nue(d, false); + break; + } + case 3: { + d = nue(d, true); + break; + } + } + e = Oee(jke, c2).Jl(); + if (e) { + return e.jk().wi().ti(e, d); + } + n = Oee(jke, c2).Ll(); + if (n) { + r = new bnb(); + for (k = xAd(d), l = 0, m = k.length; l < m; ++l) { + j = k[l]; + Rmb(r, n.jk().wi().ti(n, j)); + } + return r; + } + q = Oee(jke, c2).Ml(); + if (!q.dc()) { + for (p = q.Kc(); p.Ob(); ) { + o2 = RD(p.Pb(), 156); + try { + r = o2.jk().wi().ti(o2, d); + if (r != null) { + return r; + } + } catch (a) { + a = zdb(a); + if (!ZD(a, 63)) + throw Adb(a); + } + } + throw Adb(new agb(XHe + d + "' does not match any member types of the union datatype '" + c2.xe() + "'")); + } + RD(c2, 847).ok(); + f2 = Qje(c2.kk()); + if (!f2) + return null; + if (f2 == SI) { + h = 0; + try { + h = Oeb(d, qwe, lve) & Bwe; + } catch (a) { + a = zdb(a); + if (ZD(a, 130)) { + g = Ahb(d); + h = g[0]; + } else + throw Adb(a); + } + return hfb(h); + } + if (f2 == qK) { + for (i2 = 0; i2 < nAd.length; ++i2) { + try { + return b2d(nAd[i2], d); + } catch (a) { + a = zdb(a); + if (!ZD(a, 33)) + throw Adb(a); + } + } + throw Adb(new agb(XHe + d + "' is not a date formatted string of the form yyyy-MM-dd'T'HH:mm:ss'.'SSSZ or a valid subset thereof")); + } + throw Adb(new agb(XHe + d + "' is invalid. ")); + } + function z$b() { + z$b = geb; + y$b = new Tp(); + Rc(y$b, (qpd(), bpd), fpd); + Rc(y$b, mpd, fpd); + Rc(y$b, mpd, ipd); + Rc(y$b, Zod, epd); + Rc(y$b, Zod, fpd); + Rc(y$b, cpd, fpd); + Rc(y$b, cpd, gpd); + Rc(y$b, kpd, _od); + Rc(y$b, kpd, fpd); + Rc(y$b, hpd, apd); + Rc(y$b, hpd, fpd); + Rc(y$b, hpd, gpd); + Rc(y$b, hpd, _od); + Rc(y$b, apd, hpd); + Rc(y$b, apd, ipd); + Rc(y$b, apd, epd); + Rc(y$b, apd, fpd); + Rc(y$b, jpd, jpd); + Rc(y$b, jpd, gpd); + Rc(y$b, jpd, ipd); + Rc(y$b, dpd, dpd); + Rc(y$b, dpd, gpd); + Rc(y$b, dpd, epd); + Rc(y$b, lpd, lpd); + Rc(y$b, lpd, _od); + Rc(y$b, lpd, ipd); + Rc(y$b, $od, $od); + Rc(y$b, $od, _od); + Rc(y$b, $od, epd); + Rc(y$b, gpd, cpd); + Rc(y$b, gpd, hpd); + Rc(y$b, gpd, jpd); + Rc(y$b, gpd, dpd); + Rc(y$b, gpd, fpd); + Rc(y$b, gpd, gpd); + Rc(y$b, gpd, ipd); + Rc(y$b, gpd, epd); + Rc(y$b, _od, kpd); + Rc(y$b, _od, hpd); + Rc(y$b, _od, lpd); + Rc(y$b, _od, $od); + Rc(y$b, _od, _od); + Rc(y$b, _od, ipd); + Rc(y$b, _od, epd); + Rc(y$b, _od, fpd); + Rc(y$b, ipd, mpd); + Rc(y$b, ipd, apd); + Rc(y$b, ipd, jpd); + Rc(y$b, ipd, lpd); + Rc(y$b, ipd, gpd); + Rc(y$b, ipd, _od); + Rc(y$b, ipd, ipd); + Rc(y$b, ipd, fpd); + Rc(y$b, epd, Zod); + Rc(y$b, epd, apd); + Rc(y$b, epd, dpd); + Rc(y$b, epd, $od); + Rc(y$b, epd, gpd); + Rc(y$b, epd, _od); + Rc(y$b, epd, epd); + Rc(y$b, epd, fpd); + Rc(y$b, fpd, bpd); + Rc(y$b, fpd, mpd); + Rc(y$b, fpd, Zod); + Rc(y$b, fpd, cpd); + Rc(y$b, fpd, kpd); + Rc(y$b, fpd, hpd); + Rc(y$b, fpd, apd); + Rc(y$b, fpd, gpd); + Rc(y$b, fpd, _od); + Rc(y$b, fpd, ipd); + Rc(y$b, fpd, epd); + Rc(y$b, fpd, fpd); + } + function _$b(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B; + a.d = new rjd(oxe, oxe); + a.c = new rjd(pxe, pxe); + for (m = b.Kc(); m.Ob(); ) { + k = RD(m.Pb(), 36); + for (t = new Anb(k.a); t.a < t.c.c.length; ) { + s = RD(ynb(t), 10); + a.d.a = $wnd.Math.min(a.d.a, s.n.a - s.d.b); + a.d.b = $wnd.Math.min(a.d.b, s.n.b - s.d.d); + a.c.a = $wnd.Math.max(a.c.a, s.n.a + s.o.a + s.d.c); + a.c.b = $wnd.Math.max(a.c.b, s.n.b + s.o.b + s.d.a); + } + } + h = new q_b(); + for (l = b.Kc(); l.Ob(); ) { + k = RD(l.Pb(), 36); + d = i_b(a, k); + Rmb(h.a, d); + d.a = d.a | !RD(mQb(d.c, (Ywc(), ewc)), 21).dc(); + } + a.b = (NXb(), B = new XXb(), B.f = new EXb(c2), B.b = DXb(B.f, h), B); + RXb((o2 = a.b, new Oqd(), o2)); + a.e = new pjd(); + a.a = a.b.f.e; + for (g = new Anb(h.a); g.a < g.c.c.length; ) { + e = RD(ynb(g), 855); + u = SXb(a.b, e); + o2b(e.c, u.a, u.b); + for (q = new Anb(e.c.a); q.a < q.c.c.length; ) { + p = RD(ynb(q), 10); + if (p.k == (r3b(), m3b)) { + r = d_b(a, p.n, RD(mQb(p, (Ywc(), hwc)), 64)); + $id(hjd(p.n), r); + } + } + } + for (f2 = new Anb(h.a); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 855); + for (j = new Anb(o_b(e)); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 18); + A = new Fjd(i2.a); + hu(A, 0, K3b(i2.c)); + Mub(A, K3b(i2.d)); + n = null; + for (w2 = Sub(A, 0); w2.b != w2.d.c; ) { + v = RD(evb(w2), 8); + if (!n) { + n = v; + continue; + } + if (_y(n.a, v.a)) { + a.e.a = $wnd.Math.min(a.e.a, n.a); + a.a.a = $wnd.Math.max(a.a.a, n.a); + } else if (_y(n.b, v.b)) { + a.e.b = $wnd.Math.min(a.e.b, n.b); + a.a.b = $wnd.Math.max(a.a.b, n.b); + } + n = v; + } + } + } + fjd(a.e); + $id(a.a, a.e); + } + function vib(a, b) { + var c2, d, e, f2, g, h, i2, j; + c2 = 0; + g = 0; + f2 = b.length; + h = null; + j = new cib(); + if (g < f2 && (BFb(g, b.length), b.charCodeAt(g) == 43)) { + ++g; + ++c2; + if (g < f2 && (BFb(g, b.length), b.charCodeAt(g) == 43 || (BFb(g, b.length), b.charCodeAt(g) == 45))) { + throw Adb(new Vgb(nxe + b + '"')); + } + } + while (g < f2 && (BFb(g, b.length), b.charCodeAt(g) != 46) && (BFb(g, b.length), b.charCodeAt(g) != 101) && (BFb(g, b.length), b.charCodeAt(g) != 69)) { + ++g; + } + j.a += "" + zhb(b == null ? vve : (uFb(b), b), c2, g); + if (g < f2 && (BFb(g, b.length), b.charCodeAt(g) == 46)) { + ++g; + c2 = g; + while (g < f2 && (BFb(g, b.length), b.charCodeAt(g) != 101) && (BFb(g, b.length), b.charCodeAt(g) != 69)) { + ++g; + } + a.e = g - c2; + j.a += "" + zhb(b == null ? vve : (uFb(b), b), c2, g); + } else { + a.e = 0; + } + if (g < f2 && (BFb(g, b.length), b.charCodeAt(g) == 101 || (BFb(g, b.length), b.charCodeAt(g) == 69))) { + ++g; + c2 = g; + if (g < f2 && (BFb(g, b.length), b.charCodeAt(g) == 43)) { + ++g; + g < f2 && (BFb(g, b.length), b.charCodeAt(g) != 45) && ++c2; + } + h = (AFb(c2, f2, b.length), b.substr(c2, f2 - c2)); + a.e = a.e - Oeb(h, qwe, lve); + if (a.e != eE(a.e)) { + throw Adb(new Vgb("Scale out of range.")); + } + } + i2 = j.a; + if (i2.length < 16) { + a.f = (sib == null && (sib = new RegExp("^[+-]?\\d*$", "i")), sib.test(i2) ? parseInt(i2, 10) : NaN); + if (isNaN(a.f)) { + throw Adb(new Vgb(nxe + b + '"')); + } + a.a = Cib(a.f); + } else { + wib(a, new ejb(i2)); + } + a.d = j.a.length; + for (e = 0; e < j.a.length; ++e) { + d = ihb(j.a, e); + if (d != 45 && d != 48) { + break; + } + --a.d; + } + a.d == 0 && (a.d = 1); + } + function Wae(a) { + _Ad(a.b, AKe, cD(WC(qJ, 1), Nve, 2, 6, [CKe, "ConsistentTransient"])); + _Ad(a.a, AKe, cD(WC(qJ, 1), Nve, 2, 6, [CKe, "WellFormedSourceURI"])); + _Ad(a.o, AKe, cD(WC(qJ, 1), Nve, 2, 6, [CKe, "InterfaceIsAbstract AtMostOneID UniqueFeatureNames UniqueOperationSignatures NoCircularSuperTypes WellFormedMapEntryClass ConsistentSuperTypes DisjointFeatureAndOperationSignatures"])); + _Ad(a.p, AKe, cD(WC(qJ, 1), Nve, 2, 6, [CKe, "WellFormedInstanceTypeName UniqueTypeParameterNames"])); + _Ad(a.v, AKe, cD(WC(qJ, 1), Nve, 2, 6, [CKe, "UniqueEnumeratorNames UniqueEnumeratorLiterals"])); + _Ad(a.R, AKe, cD(WC(qJ, 1), Nve, 2, 6, [CKe, "WellFormedName"])); + _Ad(a.T, AKe, cD(WC(qJ, 1), Nve, 2, 6, [CKe, "UniqueParameterNames UniqueTypeParameterNames NoRepeatingVoid"])); + _Ad(a.U, AKe, cD(WC(qJ, 1), Nve, 2, 6, [CKe, "WellFormedNsURI WellFormedNsPrefix UniqueSubpackageNames UniqueClassifierNames UniqueNsURIs"])); + _Ad(a.W, AKe, cD(WC(qJ, 1), Nve, 2, 6, [CKe, "ConsistentOpposite SingleContainer ConsistentKeys ConsistentUnique ConsistentContainer"])); + _Ad(a.bb, AKe, cD(WC(qJ, 1), Nve, 2, 6, [CKe, "ValidDefaultValueLiteral"])); + _Ad(a.eb, AKe, cD(WC(qJ, 1), Nve, 2, 6, [CKe, "ValidLowerBound ValidUpperBound ConsistentBounds ValidType"])); + _Ad(a.H, AKe, cD(WC(qJ, 1), Nve, 2, 6, [CKe, "ConsistentType ConsistentBounds ConsistentArguments"])); + } + function S7b(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C; + if (b.dc()) { + return; + } + e = new Ejd(); + h = c2 ? c2 : RD(b.Xb(0), 18); + o2 = h.c; + HUc(); + m = o2.i.k; + if (!(m == (r3b(), p3b) || m == q3b || m == m3b || m == l3b)) { + throw Adb(new agb("The target node of the edge must be a normal node or a northSouthPort.")); + } + Oub(e, xjd(cD(WC(l3, 1), Nve, 8, 0, [o2.i.n, o2.n, o2.a]))); + if ((qpd(), hpd).Hc(o2.j)) { + q = Kfb(UD(mQb(o2, (Ywc(), Swc)))); + l = new rjd(xjd(cD(WC(l3, 1), Nve, 8, 0, [o2.i.n, o2.n, o2.a])).a, q); + Pub(e, l, e.c.b, e.c); + } + k = null; + d = false; + i2 = b.Kc(); + while (i2.Ob()) { + g = RD(i2.Pb(), 18); + f2 = g.a; + if (f2.b != 0) { + if (d) { + j = ijd($id(k, (sFb(f2.b != 0), RD(f2.a.a.c, 8))), 0.5); + Pub(e, j, e.c.b, e.c); + d = false; + } else { + d = true; + } + k = ajd((sFb(f2.b != 0), RD(f2.c.b.c, 8))); + ye(e, f2); + Xub(f2); + } + } + p = h.d; + if (hpd.Hc(p.j)) { + q = Kfb(UD(mQb(p, (Ywc(), Swc)))); + l = new rjd(xjd(cD(WC(l3, 1), Nve, 8, 0, [p.i.n, p.n, p.a])).a, q); + Pub(e, l, e.c.b, e.c); + } + Oub(e, xjd(cD(WC(l3, 1), Nve, 8, 0, [p.i.n, p.n, p.a]))); + a.d == (lFc(), iFc) && (r = (sFb(e.b != 0), RD(e.a.a.c, 8)), s = RD(ju(e, 1), 8), t = new qjd(BVc(o2.j)), t.a *= 5, t.b *= 5, u = ojd(new rjd(s.a, s.b), r), v = new rjd(R7b(t.a, u.a), R7b(t.b, u.b)), $id(v, r), w2 = Sub(e, 1), cvb(w2, v), A = (sFb(e.b != 0), RD(e.c.b.c, 8)), B = RD(ju(e, e.b - 2), 8), t = new qjd(BVc(p.j)), t.a *= 5, t.b *= 5, u = ojd(new rjd(B.a, B.b), A), C = new rjd(R7b(t.a, u.a), R7b(t.b, u.b)), $id(C, A), hu(e, e.b - 1, C), void 0); + n = new wUc(e); + ye(h.a, sUc(n)); + } + function cud(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5, F, G, H, I, J, K2, L, M, N, O, P; + t = RD(QHd((!a.b && (a.b = new Yie(E4, a, 4, 7)), a.b), 0), 84); + v = t.nh(); + w2 = t.oh(); + u = t.mh() / 2; + p = t.lh() / 2; + if (ZD(t, 193)) { + s = RD(t, 123); + v += MCd(s).i; + v += MCd(s).i; + } + v += u; + w2 += p; + F = RD(QHd((!a.b && (a.b = new Yie(E4, a, 4, 7)), a.b), 0), 84); + H = F.nh(); + I = F.oh(); + G = F.mh() / 2; + A = F.lh() / 2; + if (ZD(F, 193)) { + D5 = RD(F, 123); + H += MCd(D5).i; + H += MCd(D5).i; + } + H += G; + I += A; + if ((!a.a && (a.a = new C5d(F4, a, 6, 6)), a.a).i == 0) { + h = (bvd(), j = new Rzd(), j); + WGd((!a.a && (a.a = new C5d(F4, a, 6, 6)), a.a), h); + } else if ((!a.a && (a.a = new C5d(F4, a, 6, 6)), a.a).i > 1) { + o2 = new mMd((!a.a && (a.a = new C5d(F4, a, 6, 6)), a.a)); + while (o2.e != o2.i.gc()) { + cMd(o2); + } + } + g = RD(QHd((!a.a && (a.a = new C5d(F4, a, 6, 6)), a.a), 0), 166); + q = H; + H > v + u ? q = v + u : H < v - u && (q = v - u); + r = I; + I > w2 + p ? r = w2 + p : I < w2 - p && (r = w2 - p); + q > v - u && q < v + u && r > w2 - p && r < w2 + p && (q = v + u); + Ozd(g, q); + Pzd(g, r); + B = v; + v > H + G ? B = H + G : v < H - G && (B = H - G); + C = w2; + w2 > I + A ? C = I + A : w2 < I - A && (C = I - A); + B > H - G && B < H + G && C > I - A && C < I + A && (C = I + A); + Hzd(g, B); + Izd(g, C); + sLd((!g.a && (g.a = new XZd(D4, g, 5)), g.a)); + f2 = Jwb(b, 5); + t == F && ++f2; + L = B - q; + O = C - r; + J = $wnd.Math.sqrt(L * L + O * O); + l = J * 0.20000000298023224; + M = L / (f2 + 1); + P = O / (f2 + 1); + K2 = q; + N = r; + for (k = 0; k < f2; k++) { + K2 += M; + N += P; + m = K2 + Kwb(b, 24) * Nxe * l - l / 2; + m < 0 ? m = 1 : m > c2 && (m = c2 - 1); + n = N + Kwb(b, 24) * Nxe * l - l / 2; + n < 0 ? n = 1 : n > d && (n = d - 1); + e = (bvd(), i2 = new Xxd(), i2); + Vxd(e, m); + Wxd(e, n); + WGd((!g.a && (g.a = new XZd(D4, g, 5)), g.a), e); + } + } + function Y7c(a) { + Cgd(a, new Pfd($fd(Xfd(Zfd(Yfd(new agd(), $Fe), "ELK Rectangle Packing"), "Algorithm for packing of unconnected boxes, i.e. graphs without edges. The given order of the boxes is always preserved and the main reading direction of the boxes is left to right. The algorithm is divided into two phases. One phase approximates the width in which the rectangles can be placed. The next phase places the rectangles in rows using the previously calculated width as bounding width and bundles rectangles with a similar height in blocks. A compaction step reduces the size of the drawing. Finally, the rectangles are expanded to fill their bounding box and eliminate empty unused spaces."), new _7c()))); + Agd(a, $Fe, Dze, 1.3); + Agd(a, $Fe, hAe, (Geb(), false)); + Agd(a, $Fe, Eze, O7c); + Agd(a, $Fe, _ze, 15); + Agd(a, $Fe, YDe, iGd(y7c)); + Agd(a, $Fe, jAe, iGd(F7c)); + Agd(a, $Fe, CAe, iGd(H7c)); + Agd(a, $Fe, iAe, iGd(I7c)); + Agd(a, $Fe, kAe, iGd(E7c)); + Agd(a, $Fe, gAe, iGd(J7c)); + Agd(a, $Fe, lAe, iGd(P7c)); + Agd(a, $Fe, RFe, iGd(U7c)); + Agd(a, $Fe, SFe, iGd(T7c)); + Agd(a, $Fe, QFe, iGd(W7c)); + Agd(a, $Fe, PFe, iGd(V7c)); + Agd(a, $Fe, TFe, iGd(M7c)); + Agd(a, $Fe, UFe, iGd(L7c)); + Agd(a, $Fe, VFe, iGd(K7c)); + Agd(a, $Fe, WFe, iGd(S7c)); + Agd(a, $Fe, dAe, iGd(B7c)); + Agd(a, $Fe, iEe, iGd(C7c)); + Agd(a, $Fe, NFe, iGd(A7c)); + Agd(a, $Fe, MFe, iGd(z7c)); + Agd(a, $Fe, OFe, iGd(D7c)); + Agd(a, $Fe, LFe, iGd(R7c)); + } + function Ajb(a, b) { + xjb(); + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5, F, G, H; + B = a.e; + o2 = a.d; + e = a.a; + if (B == 0) { + switch (b) { + case 0: + return "0"; + case 1: + return zxe; + case 2: + return "0.00"; + case 3: + return "0.000"; + case 4: + return "0.0000"; + case 5: + return "0.00000"; + case 6: + return "0.000000"; + default: + w2 = new bib(); + b < 0 ? (w2.a += "0E+", w2) : (w2.a += "0E", w2); + w2.a += -b; + return w2.a; + } + } + t = o2 * 10 + 1 + 7; + u = $C(hE, zwe, 28, t + 1, 15, 1); + c2 = t; + if (o2 == 1) { + h = e[0]; + if (h < 0) { + H = Cdb(h, yxe); + do { + p = H; + H = Fdb(H, 10); + u[--c2] = 48 + Ydb(Vdb(p, Ndb(H, 10))) & Bwe; + } while (Ddb(H, 0) != 0); + } else { + H = h; + do { + p = H; + H = H / 10 | 0; + u[--c2] = 48 + (p - H * 10) & Bwe; + } while (H != 0); + } + } else { + D5 = $C(kE, Pwe, 28, o2, 15, 1); + G = o2; + hib(e, 0, D5, 0, G); + I: + while (true) { + A = 0; + for (j = G - 1; j >= 0; j--) { + F = Bdb(Sdb(A, 32), Cdb(D5[j], yxe)); + r = yjb(F); + D5[j] = Ydb(r); + A = Ydb(Tdb(r, 32)); + } + s = Ydb(A); + q = c2; + do { + u[--c2] = 48 + s % 10 & Bwe; + } while ((s = s / 10 | 0) != 0 && c2 != 0); + d = 9 - q + c2; + for (i2 = 0; i2 < d && c2 > 0; i2++) { + u[--c2] = 48; + } + l = G - 1; + for (; D5[l] == 0; l--) { + if (l == 0) { + break I; + } + } + G = l + 1; + } + while (u[c2] == 48) { + ++c2; + } + } + n = B < 0; + g = t - c2 - b - 1; + if (b == 0) { + n && (u[--c2] = 45); + return Ihb(u, c2, t - c2); + } + if (b > 0 && g >= -6) { + if (g >= 0) { + k = c2 + g; + for (m = t - 1; m >= k; m--) { + u[m + 1] = u[m]; + } + u[++k] = 46; + n && (u[--c2] = 45); + return Ihb(u, c2, t - c2 + 1); + } + for (l = 2; l < -g + 1; l++) { + u[--c2] = 48; + } + u[--c2] = 46; + u[--c2] = 48; + n && (u[--c2] = 45); + return Ihb(u, c2, t - c2); + } + C = c2 + 1; + f2 = t; + v = new cib(); + n && (v.a += "-", v); + if (f2 - C >= 1) { + Thb(v, u[c2]); + v.a += "."; + v.a += Ihb(u, c2 + 1, t - c2 - 1); + } else { + v.a += Ihb(u, c2, t - c2); + } + v.a += "E"; + g > 0 && (v.a += "+", v); + v.a += "" + g; + return v.a; + } + function Jad(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2; + a.c = b; + a.g = new Tsb(); + c2 = (lud(), new zud(a.c)); + d = new PJb(c2); + LJb(d); + t = WD(Gxd(a.c, (ncd(), gcd))); + i2 = RD(Gxd(a.c, icd), 324); + v = RD(Gxd(a.c, jcd), 437); + g = RD(Gxd(a.c, bcd), 490); + u = RD(Gxd(a.c, hcd), 438); + a.j = Kfb(UD(Gxd(a.c, kcd))); + h = a.a; + switch (i2.g) { + case 0: + h = a.a; + break; + case 1: + h = a.b; + break; + case 2: + h = a.i; + break; + case 3: + h = a.e; + break; + case 4: + h = a.f; + break; + default: + throw Adb(new agb(eGe + (i2.f != null ? i2.f : "" + i2.g))); + } + a.d = new qbd(h, v, g); + pQb(a.d, (OQb(), MQb), TD(Gxd(a.c, dcd))); + a.d.c = Heb(TD(Gxd(a.c, ccd))); + if (tCd(a.c).i == 0) { + return a.d; + } + for (l = new dMd(tCd(a.c)); l.e != l.i.gc(); ) { + k = RD(bMd(l), 27); + n = k.g / 2; + m = k.f / 2; + w2 = new rjd(k.i + n, k.j + m); + while (Ujb(a.g, w2)) { + Zid(w2, ($wnd.Math.random() - 0.5) * Vze, ($wnd.Math.random() - 0.5) * Vze); + } + p = RD(Gxd(k, (umd(), eld)), 140); + q = new TQb(w2, new Uid2(w2.a - n - a.j / 2 - p.b, w2.b - m - a.j / 2 - p.d, k.g + a.j + (p.b + p.c), k.f + a.j + (p.d + p.a))); + Rmb(a.d.i, q); + Zjb(a.g, w2, new Ptd(q, k)); + } + switch (u.g) { + case 0: + if (t == null) { + a.d.d = RD(Vmb(a.d.i, 0), 68); + } else { + for (s = new Anb(a.d.i); s.a < s.c.c.length; ) { + q = RD(ynb(s), 68); + o2 = RD(RD(Wjb(a.g, q.a), 42).b, 27).jh(); + o2 != null && lhb(o2, t) && (a.d.d = q); + } + } + break; + case 1: + e = new rjd(a.c.g, a.c.f); + e.a *= 0.5; + e.b *= 0.5; + Zid(e, a.c.i, a.c.j); + f2 = oxe; + for (r = new Anb(a.d.i); r.a < r.c.c.length; ) { + q = RD(ynb(r), 68); + j = bjd(q.a, e); + if (j < f2) { + f2 = j; + a.d.d = q; + } + } + break; + default: + throw Adb(new agb(eGe + (u.f != null ? u.f : "" + u.g))); + } + return a.d; + } + function b5b(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q; + m = 0; + for (e = new dMd((!b.a && (b.a = new C5d(J4, b, 10, 11)), b.a)); e.e != e.i.gc(); ) { + d = RD(bMd(e), 27); + if (!Heb(TD(Gxd(d, (yCc(), pBc))))) { + k = vCd(d); + if ((dE(Gxd(k, cAc)) !== dE((kEc(), hEc)) || dE(Gxd(k, pAc)) === dE((Ptc(), Otc)) || dE(Gxd(k, pAc)) === dE((Ptc(), Mtc)) || Heb(TD(Gxd(k, eAc))) || dE(Gxd(k, Yzc)) !== dE((U$b(), T$b)) || dE(Gxd(k, ZAc)) === dE((aEc(), TDc)) || dE(Gxd(k, ZAc)) === dE((aEc(), UDc)) || dE(Gxd(k, $Ac)) === dE((_Cc(), SCc)) || dE(Gxd(k, $Ac)) === dE((_Cc(), UCc))) && !Heb(TD(Gxd(d, aAc)))) { + Ixd(d, (Ywc(), zwc), sgb(m)); + ++m; + } + i5b(a, d, c2); + } + } + m = 0; + for (j = new dMd((!b.b && (b.b = new C5d(G4, b, 12, 3)), b.b)); j.e != j.i.gc(); ) { + h = RD(bMd(j), 74); + if (dE(Gxd(b, (yCc(), cAc))) !== dE((kEc(), hEc)) || dE(Gxd(b, pAc)) === dE((Ptc(), Otc)) || dE(Gxd(b, pAc)) === dE((Ptc(), Mtc)) || Heb(TD(Gxd(b, eAc))) || dE(Gxd(b, Yzc)) !== dE((U$b(), T$b)) || dE(Gxd(b, ZAc)) === dE((aEc(), TDc)) || dE(Gxd(b, ZAc)) === dE((aEc(), UDc)) || dE(Gxd(b, $Ac)) === dE((_Cc(), SCc)) || dE(Gxd(b, $Ac)) === dE((_Cc(), UCc))) { + Ixd(h, (Ywc(), zwc), sgb(m)); + ++m; + } + p = JGd(h); + q = LGd(h); + l = Heb(TD(Gxd(p, NAc))); + o2 = !Heb(TD(Gxd(h, pBc))); + n = l && ozd(h) && Heb(TD(Gxd(h, OAc))); + f2 = vCd(p) == b && vCd(p) == vCd(q); + g = (vCd(p) == b && q == b) ^ (vCd(q) == b && p == b); + o2 && !n && (g || f2) && f5b(a, h, b, c2); + } + if (vCd(b)) { + for (i2 = new dMd(uCd(vCd(b))); i2.e != i2.i.gc(); ) { + h = RD(bMd(i2), 74); + p = JGd(h); + if (p == b && ozd(h)) { + n = Heb(TD(Gxd(p, (yCc(), NAc)))) && Heb(TD(Gxd(h, OAc))); + n && f5b(a, h, b, c2); + } + } + } + } + function SFc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5, F, G, H, I, J, K2, L; + c2.Ug("Greedy cycle removal", 1); + t = b.a; + L = t.c.length; + a.a = $C(kE, Pwe, 28, L, 15, 1); + a.c = $C(kE, Pwe, 28, L, 15, 1); + a.b = $C(kE, Pwe, 28, L, 15, 1); + j = 0; + for (r = new Anb(t); r.a < r.c.c.length; ) { + p = RD(ynb(r), 10); + p.p = j; + for (C = new Anb(p.j); C.a < C.c.c.length; ) { + w2 = RD(ynb(C), 12); + for (h = new Anb(w2.e); h.a < h.c.c.length; ) { + d = RD(ynb(h), 18); + if (d.c.i == p) { + continue; + } + G = RD(mQb(d, (yCc(), KBc)), 17).a; + a.a[j] += G > 0 ? G + 1 : 1; + } + for (g = new Anb(w2.g); g.a < g.c.c.length; ) { + d = RD(ynb(g), 18); + if (d.d.i == p) { + continue; + } + G = RD(mQb(d, (yCc(), KBc)), 17).a; + a.c[j] += G > 0 ? G + 1 : 1; + } + } + a.c[j] == 0 ? Mub(a.e, p) : a.a[j] == 0 && Mub(a.f, p); + ++j; + } + o2 = -1; + n = 1; + l = new bnb(); + a.d = RD(mQb(b, (Ywc(), Lwc)), 234); + while (L > 0) { + while (a.e.b != 0) { + I = RD(Uub(a.e), 10); + a.b[I.p] = o2--; + TFc(a, I); + --L; + } + while (a.f.b != 0) { + J = RD(Uub(a.f), 10); + a.b[J.p] = n++; + TFc(a, J); + --L; + } + if (L > 0) { + m = qwe; + for (s = new Anb(t); s.a < s.c.c.length; ) { + p = RD(ynb(s), 10); + if (a.b[p.p] == 0) { + u = a.c[p.p] - a.a[p.p]; + if (u >= m) { + if (u > m) { + l.c.length = 0; + m = u; + } + ZEb(l.c, p); + } + } + } + k = a.sg(l); + a.b[k.p] = n++; + TFc(a, k); + --L; + } + } + H = t.c.length + 1; + for (j = 0; j < t.c.length; j++) { + a.b[j] < 0 && (a.b[j] += H); + } + for (q = new Anb(t); q.a < q.c.c.length; ) { + p = RD(ynb(q), 10); + F = u2b(p.j); + for (A = F, B = 0, D5 = A.length; B < D5; ++B) { + w2 = A[B]; + v = s2b(w2.g); + for (e = v, f2 = 0, i2 = e.length; f2 < i2; ++f2) { + d = e[f2]; + K2 = d.d.i.p; + if (a.b[p.p] > a.b[K2]) { + X0b(d, true); + pQb(b, awc, (Geb(), true)); + } + } + } + } + a.a = null; + a.c = null; + a.b = null; + Xub(a.f); + Xub(a.e); + c2.Vg(); + } + function usd(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2; + v = RD(QHd((!a.a && (a.a = new C5d(F4, a, 6, 6)), a.a), 0), 166); + k = new Ejd(); + u = new Tsb(); + w2 = xsd(v); + rtb(u.f, v, w2); + m = new Tsb(); + d = new Yub(); + for (o2 = Fl(Al(cD(WC(cJ, 1), rve, 20, 0, [(!b.d && (b.d = new Yie(G4, b, 8, 5)), b.d), (!b.e && (b.e = new Yie(G4, b, 7, 4)), b.e)]))); gs(o2); ) { + n = RD(hs(o2), 74); + if ((!a.a && (a.a = new C5d(F4, a, 6, 6)), a.a).i != 1) { + throw Adb(new agb(tHe + (!a.a && (a.a = new C5d(F4, a, 6, 6)), a.a).i)); + } + if (n != a) { + q = RD(QHd((!n.a && (n.a = new C5d(F4, n, 6, 6)), n.a), 0), 166); + Pub(d, q, d.c.b, d.c); + p = RD(Wd(qtb(u.f, q)), 13); + if (!p) { + p = xsd(q); + rtb(u.f, q, p); + } + l = c2 ? ojd(new sjd(RD(Vmb(w2, w2.c.length - 1), 8)), RD(Vmb(p, p.c.length - 1), 8)) : ojd(new sjd((tFb(0, w2.c.length), RD(w2.c[0], 8))), (tFb(0, p.c.length), RD(p.c[0], 8))); + rtb(m.f, q, l); + } + } + if (d.b != 0) { + r = RD(Vmb(w2, c2 ? w2.c.length - 1 : 0), 8); + for (j = 1; j < w2.c.length; j++) { + s = RD(Vmb(w2, c2 ? w2.c.length - 1 - j : j), 8); + e = Sub(d, 0); + while (e.b != e.d.c) { + q = RD(evb(e), 166); + p = RD(Wd(qtb(u.f, q)), 13); + if (p.c.length <= j) { + gvb(e); + } else { + t = $id(new sjd(RD(Vmb(p, c2 ? p.c.length - 1 - j : j), 8)), RD(Wd(qtb(m.f, q)), 8)); + if (s.a != t.a || s.b != t.b) { + f2 = s.a - r.a; + h = s.b - r.b; + g = t.a - r.a; + i2 = t.b - r.b; + g * h == i2 * f2 && (f2 == 0 || isNaN(f2) ? f2 : f2 < 0 ? -1 : 1) == (g == 0 || isNaN(g) ? g : g < 0 ? -1 : 1) && (h == 0 || isNaN(h) ? h : h < 0 ? -1 : 1) == (i2 == 0 || isNaN(i2) ? i2 : i2 < 0 ? -1 : 1) ? ($wnd.Math.abs(f2) < $wnd.Math.abs(g) || $wnd.Math.abs(h) < $wnd.Math.abs(i2)) && (Pub(k, s, k.c.b, k.c), true) : j > 1 && (Pub(k, r, k.c.b, k.c), true); + gvb(e); + } + } + } + r = s; + } + } + return k; + } + function S_c(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5; + c2.Ug(_Ee, 1); + D5 = RD(zDb(CDb(new SDb(null, new Swb(b, 16)), new e0c()), tBb(new ZBb(), new XBb(), new wCb(), cD(WC(QL, 1), jwe, 108, 0, [(xBb(), vBb)]))), 15); + k = RD(zDb(CDb(new SDb(null, new Swb(b, 16)), new g0c(b)), tBb(new ZBb(), new XBb(), new wCb(), cD(WC(QL, 1), jwe, 108, 0, [vBb]))), 15); + o2 = RD(zDb(CDb(new SDb(null, new Swb(b, 16)), new i0c(b)), tBb(new ZBb(), new XBb(), new wCb(), cD(WC(QL, 1), jwe, 108, 0, [vBb]))), 15); + p = $C(Z$, NEe, 40, b.gc(), 0, 1); + for (g = 0; g < k.gc(); g++) { + e = RD(k.Xb(g), 40); + C = RD(mQb(e, (h_c(), W$c)), 17).a; + if (C >= 0 && C < k.gc() && !p[C]) { + p[C] = e; + k.gd(g); + --g; + } + } + for (h = 0; h < k.gc(); h++) { + e = RD(k.Xb(h), 40); + C = RD(mQb(e, (h_c(), W$c)), 17).a; + for (m = 0; ; m++) { + n = C + m; + if (n < p.length && n >= 0 && !p[n]) { + p[n] = e; + k.gd(h); + --h; + break; + } + n = C - m; + if (n < p.length && n >= 0 && !p[n]) { + p[n] = e; + k.gd(h); + --h; + break; + } + } + } + o2.jd(new k0c()); + for (i2 = p.length - 1; i2 >= 0; i2--) { + if (!p[i2] && !o2.dc()) { + p[i2] = RD(o2.Xb(0), 40); + o2.gd(0); + } + } + for (j = 0; j < p.length; j++) { + if (!p[j] && !D5.dc()) { + p[j] = RD(D5.Xb(0), 40); + D5.gd(0); + } + } + for (f2 = 0; f2 < p.length; f2++) { + pQb(p[f2], (q$c(), i$c), sgb(f2)); + } + l = RD(RDb(CDb(new SDb(null, new Swb(b, 16)), new o0c())), 534); + for (w2 = l, A = 0, B = w2.length; A < B; ++A) { + v = w2[A]; + d = $Wc(v); + S_c(a, d, c2.eh(1 / l.length | 0)); + yob(); + tvb(d, new uGd((q$c(), i$c))); + q = new Yub(); + for (u = Sub(d, 0); u.b != u.d.c; ) { + t = RD(evb(u), 40); + for (s = Sub(v.d, 0); s.b != s.d.c; ) { + r = RD(evb(s), 65); + r.c == t && (Pub(q, r, q.c.b, q.c), true); + } + } + Xub(v.d); + ye(v.d, q); + } + c2.Vg(); + } + function jTb(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r; + d = new bnb(); + h = new bnb(); + q = b / 2; + n = a.gc(); + e = RD(a.Xb(0), 8); + r = RD(a.Xb(1), 8); + o2 = kTb(e.a, e.b, r.a, r.b, q); + Rmb(d, (tFb(0, o2.c.length), RD(o2.c[0], 8))); + Rmb(h, (tFb(1, o2.c.length), RD(o2.c[1], 8))); + for (j = 2; j < n; j++) { + p = e; + e = r; + r = RD(a.Xb(j), 8); + o2 = kTb(e.a, e.b, p.a, p.b, q); + Rmb(d, (tFb(1, o2.c.length), RD(o2.c[1], 8))); + Rmb(h, (tFb(0, o2.c.length), RD(o2.c[0], 8))); + o2 = kTb(e.a, e.b, r.a, r.b, q); + Rmb(d, (tFb(0, o2.c.length), RD(o2.c[0], 8))); + Rmb(h, (tFb(1, o2.c.length), RD(o2.c[1], 8))); + } + o2 = kTb(r.a, r.b, e.a, e.b, q); + Rmb(d, (tFb(1, o2.c.length), RD(o2.c[1], 8))); + Rmb(h, (tFb(0, o2.c.length), RD(o2.c[0], 8))); + c2 = new Ejd(); + g = new bnb(); + Mub(c2, (tFb(0, d.c.length), RD(d.c[0], 8))); + for (k = 1; k < d.c.length - 2; k += 2) { + f2 = (tFb(k, d.c.length), RD(d.c[k], 8)); + m = iTb((tFb(k - 1, d.c.length), RD(d.c[k - 1], 8)), f2, (tFb(k + 1, d.c.length), RD(d.c[k + 1], 8)), (tFb(k + 2, d.c.length), RD(d.c[k + 2], 8))); + !isFinite(m.a) || !isFinite(m.b) ? (Pub(c2, f2, c2.c.b, c2.c), true) : (Pub(c2, m, c2.c.b, c2.c), true); + } + Mub(c2, RD(Vmb(d, d.c.length - 1), 8)); + Rmb(g, (tFb(0, h.c.length), RD(h.c[0], 8))); + for (l = 1; l < h.c.length - 2; l += 2) { + f2 = (tFb(l, h.c.length), RD(h.c[l], 8)); + m = iTb((tFb(l - 1, h.c.length), RD(h.c[l - 1], 8)), f2, (tFb(l + 1, h.c.length), RD(h.c[l + 1], 8)), (tFb(l + 2, h.c.length), RD(h.c[l + 2], 8))); + !isFinite(m.a) || !isFinite(m.b) ? (ZEb(g.c, f2), true) : (ZEb(g.c, m), true); + } + Rmb(g, RD(Vmb(h, h.c.length - 1), 8)); + for (i2 = g.c.length - 1; i2 >= 0; i2--) { + Mub(c2, (tFb(i2, g.c.length), RD(g.c[i2], 8))); + } + return c2; + } + function l9c(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u; + t = Kfb(UD(Gxd(b, (X6c(), W6c)))); + n = Kfb(UD(Gxd(b, U6c))); + m = Kfb(UD(Gxd(b, R6c))); + Bad((!b.a && (b.a = new C5d(J4, b, 10, 11)), b.a)); + r = U8c((!b.a && (b.a = new C5d(J4, b, 10, 11)), b.a), t, a.b); + for (q = 0; q < r.c.length; q++) { + i2 = (tFb(q, r.c.length), RD(r.c[q], 186)); + if (q != 0) { + o2 = (tFb(q - 1, r.c.length), RD(r.c[q - 1], 186)); + Gad(i2, o2.f + o2.b + a.b); + } + p = J8c(q, r, t, a.b, Heb(TD(Gxd(b, (X7c(), L7c))))); + if (Heb(TD(p.b))) { + for (f2 = new Anb(i2.a); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 172); + e.c = false; + e.k = false; + N9c(e); + } + i2.d = new bnb(); + i2.e = t; + --q; + } else { + k9c(a, i2); + if (q + 1 < r.c.length) { + a.e = $wnd.Math.max(i2.e + a.b + RD(Vmb((tFb(q + 1, r.c.length), RD(r.c[q + 1], 186)).a, 0), 172).r - t, a.c); + a.f = $wnd.Math.min(i2.e + a.b + RD(Vmb((tFb(q + 1, r.c.length), RD(r.c[q + 1], 186)).a, 0), 172).r - t, a.d); + if (i2.d.c.length != 0) { + a.c = $wnd.Math.max(a.c, RD(Vmb(i2.d, i2.d.c.length - 1), 315).d + (i2.d.c.length <= 1 ? 0 : a.b)); + a.d = $wnd.Math.min(a.c, RD(Vmb(i2.d, i2.d.c.length - 1), 315).d + (i2.d.c.length <= 1 ? 0 : a.b)); + } + } + if (r.c.length == 1) { + l = RD(Vmb(i2.d, i2.d.c.length - 1), 315); + k = RD(Vmb(l.a, l.a.c.length - 1), 172); + for (h = new Anb(k.n); h.a < h.c.c.length; ) { + g = RD(ynb(h), 209); + a.c = $wnd.Math.max(a.c, k.r - g.d); + a.d = $wnd.Math.min(a.d, k.r - g.d); + a.e = $wnd.Math.max(a.e, g.d + a.b); + a.f = $wnd.Math.min(a.f, g.d + a.b); + } + } + } + } + s = zad(r, a.b); + u = $wnd.Math.max(s.a, n - (c2.b + c2.c)); + j = $wnd.Math.max(s.b, m - (c2.d + c2.a)); + d = j - s.b; + Ixd(b, M6c, d); + Ixd(b, V6c, r); + return new lad(a.a, u, s.b + d, (sad(), rad)); + } + function e9b(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5, F, G; + A = RD(mQb(a, (yCc(), BBc)), 101); + if (!(A != (Bod(), zod) && A != Aod)) { + return; + } + o2 = a.b; + n = o2.c.length; + k = new cnb((dk(n + 2, lwe), dz(Bdb(Bdb(5, n + 2), (n + 2) / 10 | 0)))); + p = new cnb((dk(n + 2, lwe), dz(Bdb(Bdb(5, n + 2), (n + 2) / 10 | 0)))); + Rmb(k, new Tsb()); + Rmb(k, new Tsb()); + Rmb(p, new bnb()); + Rmb(p, new bnb()); + w2 = new bnb(); + for (b = 0; b < n; b++) { + c2 = (tFb(b, o2.c.length), RD(o2.c[b], 30)); + B = (tFb(b, k.c.length), RD(k.c[b], 85)); + q = new Tsb(); + ZEb(k.c, q); + D5 = (tFb(b, p.c.length), RD(p.c[b], 15)); + s = new bnb(); + ZEb(p.c, s); + for (e = new Anb(c2.a); e.a < e.c.c.length; ) { + d = RD(ynb(e), 10); + if (a9b(d)) { + ZEb(w2.c, d); + continue; + } + for (j = new is(Mr(Z2b(d).a.Kc(), new ir())); gs(j); ) { + h = RD(hs(j), 18); + F = h.c.i; + if (!a9b(F)) { + continue; + } + C = RD(B.xc(mQb(F, (Ywc(), Awc))), 10); + if (!C) { + C = _8b(a, F); + B.zc(mQb(F, Awc), C); + D5.Fc(C); + } + Y0b(h, RD(Vmb(C.j, 1), 12)); + } + for (i2 = new is(Mr(a3b(d).a.Kc(), new ir())); gs(i2); ) { + h = RD(hs(i2), 18); + G = h.d.i; + if (!a9b(G)) { + continue; + } + r = RD(Wjb(q, mQb(G, (Ywc(), Awc))), 10); + if (!r) { + r = _8b(a, G); + Zjb(q, mQb(G, Awc), r); + ZEb(s.c, r); + } + Z0b(h, RD(Vmb(r.j, 0), 12)); + } + } + } + for (l = 0; l < p.c.length; l++) { + t = (tFb(l, p.c.length), RD(p.c[l], 15)); + if (t.dc()) { + continue; + } + m = null; + if (l == 0) { + m = new R4b(a); + wFb(0, o2.c.length); + XEb(o2.c, 0, m); + } else if (l == k.c.length - 1) { + m = new R4b(a); + ZEb(o2.c, m); + } else { + m = (tFb(l - 1, o2.c.length), RD(o2.c[l - 1], 30)); + } + for (g = t.Kc(); g.Ob(); ) { + f2 = RD(g.Pb(), 10); + g3b(f2, m); + } + } + for (v = new Anb(w2); v.a < v.c.c.length; ) { + u = RD(ynb(v), 10); + g3b(u, null); + } + pQb(a, (Ywc(), fwc), w2); + } + function SNc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5, F, G, H, I, J, K2; + I = new bnb(); + for (o2 = new Anb(b.b); o2.a < o2.c.c.length; ) { + m = RD(ynb(o2), 30); + for (v = new Anb(m.a); v.a < v.c.c.length; ) { + u = RD(ynb(v), 10); + u.p = -1; + l = qwe; + B = qwe; + for (D5 = new Anb(u.j); D5.a < D5.c.c.length; ) { + C = RD(ynb(D5), 12); + for (e = new Anb(C.e); e.a < e.c.c.length; ) { + c2 = RD(ynb(e), 18); + F = RD(mQb(c2, (yCc(), MBc)), 17).a; + l = $wnd.Math.max(l, F); + } + for (d = new Anb(C.g); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 18); + F = RD(mQb(c2, (yCc(), MBc)), 17).a; + B = $wnd.Math.max(B, F); + } + } + pQb(u, HNc, sgb(l)); + pQb(u, INc, sgb(B)); + } + } + r = 0; + for (n = new Anb(b.b); n.a < n.c.c.length; ) { + m = RD(ynb(n), 30); + for (v = new Anb(m.a); v.a < v.c.c.length; ) { + u = RD(ynb(v), 10); + if (u.p < 0) { + H = new ZNc(); + H.b = r++; + ONc(a, u, H); + ZEb(I.c, H); + } + } + } + A = ev(I.c.length); + k = ev(I.c.length); + for (g = 0; g < I.c.length; g++) { + Rmb(A, new bnb()); + Rmb(k, sgb(0)); + } + MNc(b, I, A, k); + J = RD(anb(I, $C(SY, uEe, 261, I.c.length, 0, 1)), 854); + w2 = RD(anb(A, $C(QK, Ize, 15, A.c.length, 0, 1)), 198); + j = $C(kE, Pwe, 28, k.c.length, 15, 1); + for (h = 0; h < j.length; h++) { + j[h] = (tFb(h, k.c.length), RD(k.c[h], 17)).a; + } + s = 0; + t = new bnb(); + for (i2 = 0; i2 < J.length; i2++) { + j[i2] == 0 && (ZEb(t.c, J[i2]), true); + } + q = $C(kE, Pwe, 28, J.length, 15, 1); + while (t.c.length != 0) { + H = RD(Xmb(t, 0), 261); + q[H.b] = s++; + while (!w2[H.b].dc()) { + K2 = RD(w2[H.b].gd(0), 261); + --j[K2.b]; + j[K2.b] == 0 && (ZEb(t.c, K2), true); + } + } + a.a = $C(SY, uEe, 261, J.length, 0, 1); + for (f2 = 0; f2 < J.length; f2++) { + p = J[f2]; + G = q[f2]; + a.a[G] = p; + p.b = G; + for (v = new Anb(p.e); v.a < v.c.c.length; ) { + u = RD(ynb(v), 10); + u.p = G; + } + } + return a.a; + } + function J8c(a, b, c2, d, e) { + var f2, g, h, i2, j, k, l, m, n, o2, p, q, r; + p = false; + i2 = false; + m = a + 1; + o2 = (tFb(a, b.c.length), RD(b.c[a], 186)); + h = o2.a; + j = null; + for (g = 0; g < o2.a.c.length; g++) { + f2 = (tFb(g, h.c.length), RD(h.c[g], 172)); + if (f2.c) { + continue; + } + if (f2.b.c.length == 0) { + gib(); + Fad(o2, f2); + --g; + p = true; + continue; + } + if (!f2.k) { + !!j && gad(j); + j = new had(!j ? 0 : j.e + j.d + d, o2.f, d); + U9c(f2, j.e + j.d, o2.f); + Rmb(o2.d, j); + aad(j, f2); + f2.k = true; + } + k = null; + k = (r = null, g < o2.a.c.length - 1 ? r = RD(Vmb(o2.a, g + 1), 172) : m < b.c.length && (tFb(m, b.c.length), RD(b.c[m], 186)).a.c.length != 0 && (r = RD(Vmb((tFb(m, b.c.length), RD(b.c[m], 186)).a, 0), 172)), r); + q = false; + !!k && (q = !pb(k.j, o2)); + if (k) { + if (k.b.c.length != 0 && !Heb(TD(RD(Vmb(k.b, 0), 27).of((X7c(), D7c))))) { + Q9c(f2, c2 - f2.s); + gad(f2.q); + p = p | I8c(o2, f2, k, c2, d); + } else { + Fad(o2, k); + break; + } + if (k.b.c.length == 0) { + b.c.length > m && Fad((tFb(m, b.c.length), RD(b.c[m], 186)), k); + k = null; + while (b.c.length > m && (tFb(m, b.c.length), RD(b.c[m], 186)).a.c.length == 0) { + Ymb(b, (tFb(m, b.c.length), b.c[m])); + } + } + if (!k) { + --g; + continue; + } + if (!Heb(TD(RD(Vmb(k.b, 0), 27).of((X7c(), D7c)))) && K8c(b, o2, f2, k, q, c2, m, d)) { + p = true; + continue; + } + if (q) { + n = o2.b; + l = k.f; + if (!Heb(TD(RD(Vmb(k.b, 0), 27).of(D7c))) && L8c(b, o2, f2, k, c2, m, d, e)) { + p = true; + if (n < l) { + i2 = true; + k.j = o2; + break; + } + continue; + } else if (M8c(o2, f2)) { + f2.c = true; + p = true; + continue; + } + } else if (M8c(o2, f2)) { + f2.c = true; + p = true; + continue; + } + if (p) { + continue; + } + } + if (M8c(o2, f2)) { + f2.c = true; + p = true; + !!k && (k.k = false); + continue; + } else { + gad(f2.q); + } + } + return new Ptd((Geb(), p ? true : false), i2 ? true : false); + } + function yCc() { + yCc = geb; + QBc = (umd(), Wld); + RBc = Xld; + SBc = Yld; + TBc = Zld; + VBc = $ld; + WBc = _ld; + ZBc = bmd; + _Bc = dmd; + aCc = emd; + $Bc = cmd; + bCc = fmd; + dCc = gmd; + fCc = jmd; + YBc = amd; + PBc = (Ozc(), ezc); + UBc = fzc; + XBc = gzc; + cCc = hzc; + JBc = new mGd(Rld, sgb(0)); + KBc = bzc; + LBc = czc; + MBc = dzc; + vCc = Fzc; + nCc = kzc; + oCc = nzc; + rCc = vzc; + pCc = qzc; + qCc = szc; + xCc = Kzc; + wCc = Hzc; + tCc = Bzc; + sCc = zzc; + uCc = Dzc; + iBc = Uyc; + jBc = Vyc; + DAc = dyc; + EAc = gyc; + jCc = mmd; + lCc = qmd; + iCc = lmd; + hCc = kmd; + kCc = (mqd(), jqd); + new mGd(nmd, kCc); + rBc = new A3b(12); + qBc = new mGd(tld, rBc); + zAc = (Ymd(), Umd); + yAc = new mGd(Skd, zAc); + ABc = new mGd(Gld, 0); + NBc = new mGd(Sld, sgb(1)); + Tzc = new mGd(Dkd, Yze); + pBc = rld; + BBc = Hld; + GBc = Old; + qAc = Mkd; + Rzc = Bkd; + IAc = Xkd; + OBc = new mGd(Vld, (Geb(), true)); + NAc = $kd; + OAc = _kd; + lBc = kld; + oBc = pld; + mBc = mld; + tAc = (Cmd(), Amd); + rAc = new mGd(Nkd, tAc); + dBc = ild; + cBc = gld; + EBc = Lld; + DBc = Kld; + FBc = Nld; + uBc = (pod(), ood); + new mGd(zld, uBc); + wBc = Cld; + xBc = Dld; + yBc = Eld; + vBc = Bld; + mCc = jzc; + $Ac = Fyc; + ZAc = Dyc; + gCc = izc; + UAc = vyc; + pAc = Rxc; + oAc = Pxc; + eAc = yxc; + fAc = zxc; + hAc = Exc; + gAc = Axc; + nAc = Nxc; + aBc = Hyc; + bBc = Iyc; + QAc = oyc; + kBc = Zyc; + fBc = Myc; + GAc = jyc; + hBc = Syc; + BAc = _xc; + CAc = byc; + dAc = Kkd; + eBc = Jyc; + Xzc = mxc; + Wzc = kxc; + Vzc = jxc; + KAc = myc; + JAc = lyc; + LAc = nyc; + nBc = nld; + RAc = cld; + FAc = Ukd; + wAc = Qkd; + vAc = Pkd; + iAc = Hxc; + CBc = Jld; + Uzc = Jkd; + MAc = Zkd; + zBc = Fld; + sBc = vld; + tBc = xld; + WAc = yyc; + XAc = Ayc; + IBc = Qld; + Szc = ixc; + YAc = Cyc; + xAc = Xxc; + uAc = Vxc; + _Ac = eld; + SAc = syc; + gBc = Pyc; + eCc = hmd; + sAc = Txc; + HBc = _yc; + AAc = Zxc; + jAc = Jxc; + kAc = Kxc; + TAc = uyc; + lAc = Lxc; + PAc = bld; + VAc = xyc; + mAc = Mxc; + cAc = wxc; + _zc = sxc; + Zzc = qxc; + $zc = rxc; + aAc = uxc; + Yzc = oxc; + bAc = vxc; + HAc = kyc; + } + function Mqe(a) { + var b, c2, d; + if (a.d >= a.j) { + a.a = -1; + a.c = 1; + return; + } + b = ihb(a.i, a.d++); + a.a = b; + if (a.b == 1) { + switch (b) { + case 92: + d = 10; + if (a.d >= a.j) + throw Adb(new Lqe(TId((Hde(), VIe)))); + a.a = ihb(a.i, a.d++); + break; + case 45: + if ((a.e & 512) == 512 && a.d < a.j && ihb(a.i, a.d) == 91) { + ++a.d; + d = 24; + } else + d = 0; + break; + case 91: + if ((a.e & 512) != 512 && a.d < a.j && ihb(a.i, a.d) == 58) { + ++a.d; + d = 20; + break; + } + default: + if ((b & 64512) == uxe && a.d < a.j) { + c2 = ihb(a.i, a.d); + if ((c2 & 64512) == 56320) { + a.a = txe + (b - uxe << 10) + c2 - 56320; + ++a.d; + } + } + d = 0; + } + a.c = d; + return; + } + switch (b) { + case 124: + d = 2; + break; + case 42: + d = 3; + break; + case 43: + d = 4; + break; + case 63: + d = 5; + break; + case 41: + d = 7; + break; + case 46: + d = 8; + break; + case 91: + d = 9; + break; + case 94: + d = 11; + break; + case 36: + d = 12; + break; + case 40: + d = 6; + if (a.d >= a.j) + break; + if (ihb(a.i, a.d) != 63) + break; + if (++a.d >= a.j) + throw Adb(new Lqe(TId((Hde(), WIe)))); + b = ihb(a.i, a.d++); + switch (b) { + case 58: + d = 13; + break; + case 61: + d = 14; + break; + case 33: + d = 15; + break; + case 91: + d = 19; + break; + case 62: + d = 18; + break; + case 60: + if (a.d >= a.j) + throw Adb(new Lqe(TId((Hde(), WIe)))); + b = ihb(a.i, a.d++); + if (b == 61) { + d = 16; + } else if (b == 33) { + d = 17; + } else + throw Adb(new Lqe(TId((Hde(), XIe)))); + break; + case 35: + while (a.d < a.j) { + b = ihb(a.i, a.d++); + if (b == 41) + break; + } + if (b != 41) + throw Adb(new Lqe(TId((Hde(), YIe)))); + d = 21; + break; + default: + if (b == 45 || 97 <= b && b <= 122 || 65 <= b && b <= 90) { + --a.d; + d = 22; + break; + } else if (b == 40) { + d = 23; + break; + } + throw Adb(new Lqe(TId((Hde(), WIe)))); + } + break; + case 92: + d = 10; + if (a.d >= a.j) + throw Adb(new Lqe(TId((Hde(), VIe)))); + a.a = ihb(a.i, a.d++); + break; + default: + d = 0; + } + a.c = d; + } + function oXc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q; + c2.Ug("Process compaction", 1); + if (!Heb(TD(mQb(b, (h_c(), F$c))))) { + return; + } + e = RD(mQb(b, H$c), 88); + n = Kfb(UD(mQb(b, _$c))); + pXc(a, b, e); + lXc(b, n / 2 / 2); + o2 = b.b; + tvb(o2, new EXc(e)); + for (j = Sub(o2, 0); j.b != j.d.c; ) { + i2 = RD(evb(j), 40); + if (!Heb(TD(mQb(i2, (q$c(), n$c))))) { + d = mXc(i2, e); + p = lWc(i2, b); + l = 0; + m = 0; + if (d) { + q = d.e; + switch (e.g) { + case 2: + l = q.a - n - i2.f.a; + p.e.a - n - i2.f.a < l && (l = p.e.a - n - i2.f.a); + m = l + i2.f.a; + break; + case 1: + l = q.a + d.f.a + n; + p.e.a + n > l && (l = p.e.a + p.f.a + n); + m = l + i2.f.a; + break; + case 4: + l = q.b - n - i2.f.b; + p.e.b - n - i2.f.b < l && (l = p.e.b - n - i2.f.b); + m = l + i2.f.b; + break; + case 3: + l = q.b + d.f.b + n; + p.e.b + n > l && (l = p.e.b + p.f.b + n); + m = l + i2.f.b; + } + } else if (p) { + switch (e.g) { + case 2: + l = p.e.a - n - i2.f.a; + m = l + i2.f.a; + break; + case 1: + l = p.e.a + p.f.a + n; + m = l + i2.f.a; + break; + case 4: + l = p.e.b - n - i2.f.b; + m = l + i2.f.b; + break; + case 3: + l = p.e.b + p.f.b + n; + m = l + i2.f.b; + } + } + if (dE(mQb(b, K$c)) === dE((LZc(), IZc))) { + f2 = l; + g = m; + h = DDb(CDb(new SDb(null, new Swb(a.a, 16)), new IXc(f2, g))); + if (h.a != null) { + e == (Cmd(), ymd) || e == zmd ? i2.e.a = l : i2.e.b = l; + } else { + e == (Cmd(), ymd) || e == Bmd ? h = DDb(CDb(NDb(new SDb(null, new Swb(a.a, 16))), new WXc(f2))) : h = DDb(CDb(NDb(new SDb(null, new Swb(a.a, 16))), new YXc(f2))); + h.a != null && (e == ymd || e == zmd ? i2.e.a = Kfb(UD((sFb(h.a != null), RD(h.a, 42)).a)) : i2.e.b = Kfb(UD((sFb(h.a != null), RD(h.a, 42)).a))); + } + if (h.a != null) { + k = Wmb(a.a, (sFb(h.a != null), h.a), 0); + if (k > 0 && k != RD(mQb(i2, f_c), 17).a) { + pQb(i2, UZc, (Geb(), true)); + pQb(i2, f_c, sgb(k)); + } + } + } else { + e == (Cmd(), ymd) || e == zmd ? i2.e.a = l : i2.e.b = l; + } + } + } + c2.Vg(); + } + function Fre(a) { + var b, c2, d, e, f2, g, h, i2, j; + a.b = 1; + Mqe(a); + b = null; + if (a.c == 0 && a.a == 94) { + Mqe(a); + b = (Vse(), Vse(), new xte(4)); + rte(b, 0, MLe); + h = new xte(4); + } else { + h = (Vse(), Vse(), new xte(4)); + } + e = true; + while ((j = a.c) != 1) { + if (j == 0 && a.a == 93 && !e) { + if (b) { + wte(b, h); + h = b; + } + break; + } + c2 = a.a; + d = false; + if (j == 10) { + switch (c2) { + case 100: + case 68: + case 119: + case 87: + case 115: + case 83: + ute(h, Ere(c2)); + d = true; + break; + case 105: + case 73: + case 99: + case 67: + c2 = (ute(h, Ere(c2)), -1); + c2 < 0 && (d = true); + break; + case 112: + case 80: + i2 = Sqe(a, c2); + if (!i2) + throw Adb(new Lqe(TId((Hde(), hJe)))); + ute(h, i2); + d = true; + break; + default: + c2 = Dre(a); + } + } else if (j == 24 && !e) { + if (b) { + wte(b, h); + h = b; + } + f2 = Fre(a); + wte(h, f2); + if (a.c != 0 || a.a != 93) + throw Adb(new Lqe(TId((Hde(), lJe)))); + break; + } + Mqe(a); + if (!d) { + if (j == 0) { + if (c2 == 91) + throw Adb(new Lqe(TId((Hde(), mJe)))); + if (c2 == 93) + throw Adb(new Lqe(TId((Hde(), nJe)))); + if (c2 == 45 && !e && a.a != 93) + throw Adb(new Lqe(TId((Hde(), oJe)))); + } + if (a.c != 0 || a.a != 45 || c2 == 45 && e) { + rte(h, c2, c2); + } else { + Mqe(a); + if ((j = a.c) == 1) + throw Adb(new Lqe(TId((Hde(), jJe)))); + if (j == 0 && a.a == 93) { + rte(h, c2, c2); + rte(h, 45, 45); + } else if (j == 0 && a.a == 93 || j == 24) { + throw Adb(new Lqe(TId((Hde(), oJe)))); + } else { + g = a.a; + if (j == 0) { + if (g == 91) + throw Adb(new Lqe(TId((Hde(), mJe)))); + if (g == 93) + throw Adb(new Lqe(TId((Hde(), nJe)))); + if (g == 45) + throw Adb(new Lqe(TId((Hde(), oJe)))); + } else + j == 10 && (g = Dre(a)); + Mqe(a); + if (c2 > g) + throw Adb(new Lqe(TId((Hde(), rJe)))); + rte(h, c2, g); + } + } + } + e = false; + } + if (a.c == 1) + throw Adb(new Lqe(TId((Hde(), jJe)))); + vte(h); + ste(h); + a.b = 0; + Mqe(a); + return h; + } + function EGc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v; + c2.Ug("Coffman-Graham Layering", 1); + if (b.a.c.length == 0) { + c2.Vg(); + return; + } + v = RD(mQb(b, (yCc(), SAc)), 17).a; + i2 = 0; + g = 0; + for (m = new Anb(b.a); m.a < m.c.c.length; ) { + l = RD(ynb(m), 10); + l.p = i2++; + for (f2 = new is(Mr(a3b(l).a.Kc(), new ir())); gs(f2); ) { + e = RD(hs(f2), 18); + e.p = g++; + } + } + a.d = $C(xdb, Hye, 28, i2, 16, 1); + a.a = $C(xdb, Hye, 28, g, 16, 1); + a.b = $C(kE, Pwe, 28, i2, 15, 1); + a.e = $C(kE, Pwe, 28, i2, 15, 1); + a.f = $C(kE, Pwe, 28, i2, 15, 1); + Nc(a.c); + FGc(a, b); + o2 = new pwb(new JGc(a)); + for (u = new Anb(b.a); u.a < u.c.c.length; ) { + s = RD(ynb(u), 10); + for (f2 = new is(Mr(Z2b(s).a.Kc(), new ir())); gs(f2); ) { + e = RD(hs(f2), 18); + a.a[e.p] || ++a.b[s.p]; + } + a.b[s.p] == 0 && (zFb(lwb(o2, s), Bxe), true); + } + h = 0; + while (o2.b.c.length != 0) { + s = RD(mwb(o2), 10); + a.f[s.p] = h++; + for (f2 = new is(Mr(a3b(s).a.Kc(), new ir())); gs(f2); ) { + e = RD(hs(f2), 18); + if (a.a[e.p]) { + continue; + } + q = e.d.i; + --a.b[q.p]; + Rc(a.c, q, sgb(a.f[s.p])); + a.b[q.p] == 0 && (zFb(lwb(o2, q), Bxe), true); + } + } + n = new pwb(new NGc(a)); + for (t = new Anb(b.a); t.a < t.c.c.length; ) { + s = RD(ynb(t), 10); + for (f2 = new is(Mr(a3b(s).a.Kc(), new ir())); gs(f2); ) { + e = RD(hs(f2), 18); + a.a[e.p] || ++a.e[s.p]; + } + a.e[s.p] == 0 && (zFb(lwb(n, s), Bxe), true); + } + k = new bnb(); + d = BGc(b, k); + while (n.b.c.length != 0) { + r = RD(mwb(n), 10); + (d.a.c.length >= v || !zGc(r, d)) && (d = BGc(b, k)); + g3b(r, d); + for (f2 = new is(Mr(Z2b(r).a.Kc(), new ir())); gs(f2); ) { + e = RD(hs(f2), 18); + if (a.a[e.p]) { + continue; + } + p = e.c.i; + --a.e[p.p]; + a.e[p.p] == 0 && (zFb(lwb(n, p), Bxe), true); + } + } + for (j = k.c.length - 1; j >= 0; --j) { + Rmb(b.b, (tFb(j, k.c.length), RD(k.c[j], 30))); + } + b.a.c.length = 0; + c2.Vg(); + } + function Sec(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u; + u = false; + do { + u = false; + for (f2 = b ? new Xkb(a.a.b).a.gc() - 2 : 1; b ? f2 >= 0 : f2 < new Xkb(a.a.b).a.gc(); f2 += b ? -1 : 1) { + e = _5b(a.a, sgb(f2)); + for (n = 0; n < e.b; n++) { + l = RD(ju(e, n), 10); + if (!nQb(l, (Ywc(), zwc))) { + continue; + } + if (a6b(a.a, sgb(f2)) && a.r == (aEc(), TDc) || b6b(a.a, sgb(f2)) && a.r == (aEc(), UDc)) { + continue; + } + t = true; + for (r = 0; r < e.b; r++) { + q = RD(ju(e, r), 10); + nQb(q, zwc) && (b && RD(mQb(l, zwc), 17).a < RD(mQb(q, zwc), 17).a || !b && RD(mQb(l, zwc), 17).a > RD(mQb(q, zwc), 17).a) && (t = false); + } + if (!t) { + continue; + } + i2 = b ? f2 + 1 : f2 - 1; + h = _5b(a.a, sgb(i2)); + g = false; + s = true; + d = false; + for (k = Sub(h, 0); k.b != k.d.c; ) { + j = RD(evb(k), 10); + if (nQb(j, zwc)) { + if (j.p != l.p) { + g = g | (b ? RD(mQb(j, zwc), 17).a < RD(mQb(l, zwc), 17).a : RD(mQb(j, zwc), 17).a > RD(mQb(l, zwc), 17).a); + s = false; + } + } else if (!g && s) { + if (j.k == (r3b(), n3b)) { + d = true; + b ? m = RD(hs(new is(Mr(Z2b(j).a.Kc(), new ir()))), 18).c.i : m = RD(hs(new is(Mr(a3b(j).a.Kc(), new ir()))), 18).d.i; + if (m == l) { + b ? c2 = RD(hs(new is(Mr(a3b(j).a.Kc(), new ir()))), 18).d.i : c2 = RD(hs(new is(Mr(Z2b(j).a.Kc(), new ir()))), 18).c.i; + (b ? RD($5b(a.a, c2), 17).a - RD($5b(a.a, m), 17).a : RD($5b(a.a, m), 17).a - RD($5b(a.a, c2), 17).a) <= 2 && (s = false); + } + } + } + } + if (d && s) { + b ? c2 = RD(hs(new is(Mr(a3b(l).a.Kc(), new ir()))), 18).d.i : c2 = RD(hs(new is(Mr(Z2b(l).a.Kc(), new ir()))), 18).c.i; + (b ? RD($5b(a.a, c2), 17).a - RD($5b(a.a, l), 17).a : RD($5b(a.a, l), 17).a - RD($5b(a.a, c2), 17).a) <= 2 && c2.k == (r3b(), p3b) && (s = false); + } + if (g || s) { + p = Xec(a, l, b); + while (p.a.gc() != 0) { + o2 = RD(p.a.ec().Kc().Pb(), 10); + p.a.Bc(o2) != null; + ye(p, Xec(a, o2, b)); + } + --n; + u = true; + } + } + } + } while (u); + } + function Xae(a) { + _Ad(a.c, qKe, cD(WC(qJ, 1), Nve, 2, 6, [DKe, "http://www.w3.org/2001/XMLSchema#decimal"])); + _Ad(a.d, qKe, cD(WC(qJ, 1), Nve, 2, 6, [DKe, "http://www.w3.org/2001/XMLSchema#integer"])); + _Ad(a.e, qKe, cD(WC(qJ, 1), Nve, 2, 6, [DKe, "http://www.w3.org/2001/XMLSchema#boolean"])); + _Ad(a.f, qKe, cD(WC(qJ, 1), Nve, 2, 6, [DKe, "EBoolean", GIe, "EBoolean:Object"])); + _Ad(a.i, qKe, cD(WC(qJ, 1), Nve, 2, 6, [DKe, "http://www.w3.org/2001/XMLSchema#byte"])); + _Ad(a.g, qKe, cD(WC(qJ, 1), Nve, 2, 6, [DKe, "http://www.w3.org/2001/XMLSchema#hexBinary"])); + _Ad(a.j, qKe, cD(WC(qJ, 1), Nve, 2, 6, [DKe, "EByte", GIe, "EByte:Object"])); + _Ad(a.n, qKe, cD(WC(qJ, 1), Nve, 2, 6, [DKe, "EChar", GIe, "EChar:Object"])); + _Ad(a.t, qKe, cD(WC(qJ, 1), Nve, 2, 6, [DKe, "http://www.w3.org/2001/XMLSchema#double"])); + _Ad(a.u, qKe, cD(WC(qJ, 1), Nve, 2, 6, [DKe, "EDouble", GIe, "EDouble:Object"])); + _Ad(a.F, qKe, cD(WC(qJ, 1), Nve, 2, 6, [DKe, "http://www.w3.org/2001/XMLSchema#float"])); + _Ad(a.G, qKe, cD(WC(qJ, 1), Nve, 2, 6, [DKe, "EFloat", GIe, "EFloat:Object"])); + _Ad(a.I, qKe, cD(WC(qJ, 1), Nve, 2, 6, [DKe, "http://www.w3.org/2001/XMLSchema#int"])); + _Ad(a.J, qKe, cD(WC(qJ, 1), Nve, 2, 6, [DKe, "EInt", GIe, "EInt:Object"])); + _Ad(a.N, qKe, cD(WC(qJ, 1), Nve, 2, 6, [DKe, "http://www.w3.org/2001/XMLSchema#long"])); + _Ad(a.O, qKe, cD(WC(qJ, 1), Nve, 2, 6, [DKe, "ELong", GIe, "ELong:Object"])); + _Ad(a.Z, qKe, cD(WC(qJ, 1), Nve, 2, 6, [DKe, "http://www.w3.org/2001/XMLSchema#short"])); + _Ad(a.$, qKe, cD(WC(qJ, 1), Nve, 2, 6, [DKe, "EShort", GIe, "EShort:Object"])); + _Ad(a._, qKe, cD(WC(qJ, 1), Nve, 2, 6, [DKe, "http://www.w3.org/2001/XMLSchema#string"])); + } + function C0c(a, b, c2, d, e, f2, g) { + var h, i2, j, k, l, m, n, o2; + m = RD(d.a, 17).a; + n = RD(d.b, 17).a; + l = a.b; + o2 = a.c; + h = 0; + k = 0; + if (b == (Cmd(), ymd) || b == zmd) { + k = Uvb(QCb(HDb(GDb(new SDb(null, new Swb(c2.b, 16)), new b2c()), new b1c()))); + if (l.e.b + l.f.b / 2 > k) { + j = ++n; + h = Kfb(UD(Lvb(JDb(GDb(new SDb(null, new Swb(c2.b, 16)), new d2c(e, j)), new d1c())))); + } else { + i2 = ++m; + h = Kfb(UD(Lvb(KDb(GDb(new SDb(null, new Swb(c2.b, 16)), new f2c(e, i2)), new h1c())))); + } + } else { + k = Uvb(QCb(HDb(GDb(new SDb(null, new Swb(c2.b, 16)), new x1c()), new l1c()))); + if (l.e.a + l.f.a / 2 > k) { + j = ++n; + h = Kfb(UD(Lvb(JDb(GDb(new SDb(null, new Swb(c2.b, 16)), new z1c(e, j)), new n1c())))); + } else { + i2 = ++m; + h = Kfb(UD(Lvb(KDb(GDb(new SDb(null, new Swb(c2.b, 16)), new B1c(e, i2)), new r1c())))); + } + } + if (b == ymd) { + Oub(a.a, new rjd(Kfb(UD(mQb(l, (q$c(), f$c)))) - e, h)); + Oub(a.a, new rjd(o2.e.a + o2.f.a + e + f2, h)); + Oub(a.a, new rjd(o2.e.a + o2.f.a + e + f2, o2.e.b + o2.f.b / 2)); + Oub(a.a, new rjd(o2.e.a + o2.f.a, o2.e.b + o2.f.b / 2)); + } else if (b == zmd) { + Oub(a.a, new rjd(Kfb(UD(mQb(l, (q$c(), e$c)))) + e, l.e.b + l.f.b / 2)); + Oub(a.a, new rjd(l.e.a + l.f.a + e, h)); + Oub(a.a, new rjd(o2.e.a - e - f2, h)); + Oub(a.a, new rjd(o2.e.a - e - f2, o2.e.b + o2.f.b / 2)); + Oub(a.a, new rjd(o2.e.a, o2.e.b + o2.f.b / 2)); + } else if (b == Bmd) { + Oub(a.a, new rjd(h, Kfb(UD(mQb(l, (q$c(), f$c)))) - e)); + Oub(a.a, new rjd(h, o2.e.b + o2.f.b + e + f2)); + Oub(a.a, new rjd(o2.e.a + o2.f.a / 2, o2.e.b + o2.f.b + e + f2)); + Oub(a.a, new rjd(o2.e.a + o2.f.a / 2, o2.e.b + o2.f.b + e)); + } else { + a.a.b == 0 || (RD(Rub(a.a), 8).b = Kfb(UD(mQb(l, (q$c(), e$c)))) + e * RD(g.b, 17).a); + Oub(a.a, new rjd(h, Kfb(UD(mQb(l, (q$c(), e$c)))) + e * RD(g.b, 17).a)); + Oub(a.a, new rjd(h, o2.e.b - e * RD(g.a, 17).a - f2)); + } + return new Ptd(sgb(m), sgb(n)); + } + function ASd(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n; + g = true; + l = null; + d = null; + e = null; + b = false; + n = _Rd; + j = null; + f2 = null; + h = 0; + i2 = sSd(a, h, ZRd, $Rd); + if (i2 < a.length && (BFb(i2, a.length), a.charCodeAt(i2) == 58)) { + l = (AFb(h, i2, a.length), a.substr(h, i2 - h)); + h = i2 + 1; + } + c2 = l != null && tpb(eSd, l.toLowerCase()); + if (c2) { + i2 = a.lastIndexOf("!/"); + if (i2 == -1) { + throw Adb(new agb("no archive separator")); + } + g = true; + d = zhb(a, h, ++i2); + h = i2; + } else if (h >= 0 && lhb(a.substr(h, "//".length), "//")) { + h += 2; + i2 = sSd(a, h, aSd, bSd); + d = (AFb(h, i2, a.length), a.substr(h, i2 - h)); + h = i2; + } else if (l != null && (h == a.length || (BFb(h, a.length), a.charCodeAt(h) != 47))) { + g = false; + i2 = rhb(a, Fhb(35), h); + i2 == -1 && (i2 = a.length); + d = (AFb(h, i2, a.length), a.substr(h, i2 - h)); + h = i2; + } + if (!c2 && h < a.length && (BFb(h, a.length), a.charCodeAt(h) == 47)) { + i2 = sSd(a, h + 1, aSd, bSd); + k = (AFb(h + 1, i2, a.length), a.substr(h + 1, i2 - (h + 1))); + if (k.length > 0 && ihb(k, k.length - 1) == 58) { + e = k; + h = i2; + } + } + if (h < a.length && (BFb(h, a.length), a.charCodeAt(h) == 47)) { + ++h; + b = true; + } + if (h < a.length && (BFb(h, a.length), a.charCodeAt(h) != 63) && (BFb(h, a.length), a.charCodeAt(h) != 35)) { + m = new bnb(); + while (h < a.length && (BFb(h, a.length), a.charCodeAt(h) != 63) && (BFb(h, a.length), a.charCodeAt(h) != 35)) { + i2 = sSd(a, h, aSd, bSd); + Rmb(m, (AFb(h, i2, a.length), a.substr(h, i2 - h))); + h = i2; + h < a.length && (BFb(h, a.length), a.charCodeAt(h) == 47) && (BSd(a, ++h) || (m.c.push(""), true)); + } + n = $C(qJ, Nve, 2, m.c.length, 6, 1); + anb(m, n); + } + if (h < a.length && (BFb(h, a.length), a.charCodeAt(h) == 63)) { + i2 = phb(a, 35, ++h); + i2 == -1 && (i2 = a.length); + j = (AFb(h, i2, a.length), a.substr(h, i2 - h)); + h = i2; + } + h < a.length && (f2 = yhb(a, ++h)); + ISd(g, l, d, e, n, j); + return new lSd(g, l, d, e, b, n, j, f2); + } + function P_b() { + P_b = geb; + z$b(); + O_b = new Tp(); + Rc(O_b, (qpd(), cpd), bpd); + Rc(O_b, mpd, bpd); + Rc(O_b, dpd, bpd); + Rc(O_b, jpd, bpd); + Rc(O_b, ipd, bpd); + Rc(O_b, gpd, bpd); + Rc(O_b, jpd, cpd); + Rc(O_b, bpd, Zod); + Rc(O_b, cpd, Zod); + Rc(O_b, mpd, Zod); + Rc(O_b, dpd, Zod); + Rc(O_b, hpd, Zod); + Rc(O_b, jpd, Zod); + Rc(O_b, ipd, Zod); + Rc(O_b, gpd, Zod); + Rc(O_b, apd, Zod); + Rc(O_b, bpd, kpd); + Rc(O_b, cpd, kpd); + Rc(O_b, Zod, kpd); + Rc(O_b, mpd, kpd); + Rc(O_b, dpd, kpd); + Rc(O_b, hpd, kpd); + Rc(O_b, jpd, kpd); + Rc(O_b, apd, kpd); + Rc(O_b, lpd, kpd); + Rc(O_b, ipd, kpd); + Rc(O_b, epd, kpd); + Rc(O_b, gpd, kpd); + Rc(O_b, cpd, mpd); + Rc(O_b, dpd, mpd); + Rc(O_b, jpd, mpd); + Rc(O_b, gpd, mpd); + Rc(O_b, cpd, dpd); + Rc(O_b, mpd, dpd); + Rc(O_b, jpd, dpd); + Rc(O_b, dpd, dpd); + Rc(O_b, ipd, dpd); + Rc(O_b, bpd, $od); + Rc(O_b, cpd, $od); + Rc(O_b, Zod, $od); + Rc(O_b, kpd, $od); + Rc(O_b, mpd, $od); + Rc(O_b, dpd, $od); + Rc(O_b, hpd, $od); + Rc(O_b, jpd, $od); + Rc(O_b, lpd, $od); + Rc(O_b, apd, $od); + Rc(O_b, gpd, $od); + Rc(O_b, ipd, $od); + Rc(O_b, fpd, $od); + Rc(O_b, bpd, lpd); + Rc(O_b, cpd, lpd); + Rc(O_b, Zod, lpd); + Rc(O_b, mpd, lpd); + Rc(O_b, dpd, lpd); + Rc(O_b, hpd, lpd); + Rc(O_b, jpd, lpd); + Rc(O_b, apd, lpd); + Rc(O_b, gpd, lpd); + Rc(O_b, epd, lpd); + Rc(O_b, fpd, lpd); + Rc(O_b, cpd, apd); + Rc(O_b, mpd, apd); + Rc(O_b, dpd, apd); + Rc(O_b, jpd, apd); + Rc(O_b, lpd, apd); + Rc(O_b, gpd, apd); + Rc(O_b, ipd, apd); + Rc(O_b, bpd, _od); + Rc(O_b, cpd, _od); + Rc(O_b, Zod, _od); + Rc(O_b, mpd, _od); + Rc(O_b, dpd, _od); + Rc(O_b, hpd, _od); + Rc(O_b, jpd, _od); + Rc(O_b, apd, _od); + Rc(O_b, gpd, _od); + Rc(O_b, cpd, ipd); + Rc(O_b, Zod, ipd); + Rc(O_b, kpd, ipd); + Rc(O_b, dpd, ipd); + Rc(O_b, bpd, epd); + Rc(O_b, cpd, epd); + Rc(O_b, kpd, epd); + Rc(O_b, mpd, epd); + Rc(O_b, dpd, epd); + Rc(O_b, hpd, epd); + Rc(O_b, jpd, epd); + Rc(O_b, jpd, fpd); + Rc(O_b, dpd, fpd); + Rc(O_b, apd, bpd); + Rc(O_b, apd, mpd); + Rc(O_b, apd, Zod); + Rc(O_b, hpd, bpd); + Rc(O_b, hpd, cpd); + Rc(O_b, hpd, kpd); + } + function _Qc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2; + c2.Ug("Brandes & Koepf node placement", 1); + a.a = b; + a.c = iRc(b); + d = RD(mQb(b, (yCc(), fBc)), 281); + n = Heb(TD(mQb(b, gBc))); + a.d = d == (Ouc(), Luc) && !n || d == Iuc; + $Qc(a, b); + v = null; + w2 = null; + r = null; + s = null; + q = (dk(4, iwe), new cnb(4)); + switch (RD(mQb(b, fBc), 281).g) { + case 3: + r = new sQc(b, a.c.d, (EQc(), CQc), (wQc(), uQc)); + ZEb(q.c, r); + break; + case 1: + s = new sQc(b, a.c.d, (EQc(), DQc), (wQc(), uQc)); + ZEb(q.c, s); + break; + case 4: + v = new sQc(b, a.c.d, (EQc(), CQc), (wQc(), vQc)); + ZEb(q.c, v); + break; + case 2: + w2 = new sQc(b, a.c.d, (EQc(), DQc), (wQc(), vQc)); + ZEb(q.c, w2); + break; + default: + r = new sQc(b, a.c.d, (EQc(), CQc), (wQc(), uQc)); + s = new sQc(b, a.c.d, DQc, uQc); + v = new sQc(b, a.c.d, CQc, vQc); + w2 = new sQc(b, a.c.d, DQc, vQc); + ZEb(q.c, v); + ZEb(q.c, w2); + ZEb(q.c, r); + ZEb(q.c, s); + } + e = new MQc(b, a.c); + for (h = new Anb(q); h.a < h.c.c.length; ) { + f2 = RD(ynb(h), 185); + LQc(e, f2, a.b); + KQc(f2); + } + m = new RQc(b, a.c); + for (i2 = new Anb(q); i2.a < i2.c.c.length; ) { + f2 = RD(ynb(i2), 185); + OQc(m, f2); + } + if (c2._g()) { + for (j = new Anb(q); j.a < j.c.c.length; ) { + f2 = RD(ynb(j), 185); + c2.bh(f2 + " size is " + qQc(f2)); + } + } + l = null; + if (a.d) { + k = YQc(a, q, a.c.d); + XQc(b, k, c2) && (l = k); + } + if (!l) { + for (j = new Anb(q); j.a < j.c.c.length; ) { + f2 = RD(ynb(j), 185); + XQc(b, f2, c2) && (!l || qQc(l) > qQc(f2)) && (l = f2); + } + } + !l && (l = (tFb(0, q.c.length), RD(q.c[0], 185))); + for (p = new Anb(b.b); p.a < p.c.c.length; ) { + o2 = RD(ynb(p), 30); + for (u = new Anb(o2.a); u.a < u.c.c.length; ) { + t = RD(ynb(u), 10); + t.n.b = Kfb(l.p[t.p]) + Kfb(l.d[t.p]); + } + } + if (c2._g()) { + c2.bh("Chosen node placement: " + l); + c2.bh("Blocks: " + bRc(l)); + c2.bh("Classes: " + cRc(l, c2)); + c2.bh("Marked edges: " + a.b); + } + for (g = new Anb(q); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 185); + f2.g = null; + f2.b = null; + f2.a = null; + f2.d = null; + f2.j = null; + f2.i = null; + f2.p = null; + } + gRc(a.c); + a.b.a.$b(); + c2.Vg(); + } + function GVc(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5, F, G; + if (a.c.length == 1) { + CVc((tFb(0, a.c.length), RD(a.c[0], 121))); + return tFb(0, a.c.length), RD(a.c[0], 121); + } else if (a.c.length <= 0) { + return new YWc(); + } + for (i2 = new Anb(a); i2.a < i2.c.c.length; ) { + g = RD(ynb(i2), 121); + s = 0; + o2 = lve; + p = lve; + m = qwe; + n = qwe; + for (r = Sub(g.b, 0); r.b != r.d.c; ) { + q = RD(evb(r), 40); + s += RD(mQb(q, (h_c(), X$c)), 17).a; + o2 = $wnd.Math.min(o2, q.e.a); + p = $wnd.Math.min(p, q.e.b); + m = $wnd.Math.max(m, q.e.a + q.f.a); + n = $wnd.Math.max(n, q.e.b + q.f.b); + } + pQb(g, (h_c(), X$c), sgb(s)); + pQb(g, (q$c(), SZc), new rjd(o2, p)); + pQb(g, RZc, new rjd(m, n)); + } + yob(); + _mb(a, new KVc()); + v = new YWc(); + kQb(v, (tFb(0, a.c.length), RD(a.c[0], 96))); + l = 0; + D5 = 0; + for (j = new Anb(a); j.a < j.c.c.length; ) { + g = RD(ynb(j), 121); + w2 = ojd(ajd(RD(mQb(g, (q$c(), RZc)), 8)), RD(mQb(g, SZc), 8)); + l = $wnd.Math.max(l, w2.a); + D5 += w2.a * w2.b; + } + l = $wnd.Math.max(l, $wnd.Math.sqrt(D5) * Kfb(UD(mQb(v, (h_c(), E$c))))); + A = Kfb(UD(mQb(v, _$c))); + F = 0; + G = 0; + k = 0; + b = A; + for (h = new Anb(a); h.a < h.c.c.length; ) { + g = RD(ynb(h), 121); + w2 = ojd(ajd(RD(mQb(g, (q$c(), RZc)), 8)), RD(mQb(g, SZc), 8)); + if (F + w2.a > l) { + F = 0; + G += k + A; + k = 0; + } + FVc(v, g, F, G); + b = $wnd.Math.max(b, F + w2.a); + k = $wnd.Math.max(k, w2.b); + F += w2.a + A; + } + u = new Tsb(); + c2 = new Tsb(); + for (C = new Anb(a); C.a < C.c.c.length; ) { + B = RD(ynb(C), 121); + d = Heb(TD(mQb(B, (umd(), Mkd)))); + t = !B.q ? wob : B.q; + for (f2 = t.vc().Kc(); f2.Ob(); ) { + e = RD(f2.Pb(), 44); + if (Ujb(u, e.ld())) { + if (dE(RD(e.ld(), 149).Sg()) !== dE(e.md())) { + if (d && Ujb(c2, e.ld())) { + gib(); + "Found different values for property " + RD(e.ld(), 149).Pg() + " in components."; + } else { + Zjb(u, RD(e.ld(), 149), e.md()); + pQb(v, RD(e.ld(), 149), e.md()); + d && Zjb(c2, RD(e.ld(), 149), e.md()); + } + } + } else { + Zjb(u, RD(e.ld(), 149), e.md()); + pQb(v, RD(e.ld(), 149), e.md()); + } + } + } + CVc(v); + return v; + } + function f7d(a, b) { + switch (a.e) { + case 0: + case 2: + case 4: + case 6: + case 42: + case 44: + case 46: + case 48: + case 8: + case 10: + case 12: + case 14: + case 16: + case 18: + case 20: + case 22: + case 24: + case 26: + case 28: + case 30: + case 32: + case 34: + case 36: + case 38: + return new sje(a.b, a.a, b, a.c); + case 1: + return new _Zd(a.a, b, BYd(b.Dh(), a.c)); + case 43: + return new lie(a.a, b, BYd(b.Dh(), a.c)); + case 3: + return new XZd(a.a, b, BYd(b.Dh(), a.c)); + case 45: + return new iie(a.a, b, BYd(b.Dh(), a.c)); + case 41: + return new DVd(RD(WVd(a.c), 29), a.a, b, BYd(b.Dh(), a.c)); + case 50: + return new Cje(RD(WVd(a.c), 29), a.a, b, BYd(b.Dh(), a.c)); + case 5: + return new oie(a.a, b, BYd(b.Dh(), a.c), a.d.n); + case 47: + return new sie(a.a, b, BYd(b.Dh(), a.c), a.d.n); + case 7: + return new C5d(a.a, b, BYd(b.Dh(), a.c), a.d.n); + case 49: + return new G5d(a.a, b, BYd(b.Dh(), a.c), a.d.n); + case 9: + return new gie(a.a, b, BYd(b.Dh(), a.c)); + case 11: + return new eie(a.a, b, BYd(b.Dh(), a.c)); + case 13: + return new aie(a.a, b, BYd(b.Dh(), a.c)); + case 15: + return new Kfe(a.a, b, BYd(b.Dh(), a.c)); + case 17: + return new Cie(a.a, b, BYd(b.Dh(), a.c)); + case 19: + return new zie(a.a, b, BYd(b.Dh(), a.c)); + case 21: + return new vie(a.a, b, BYd(b.Dh(), a.c)); + case 23: + return new PZd(a.a, b, BYd(b.Dh(), a.c)); + case 25: + return new bje(a.a, b, BYd(b.Dh(), a.c), a.d.n); + case 27: + return new Yie(a.a, b, BYd(b.Dh(), a.c), a.d.n); + case 29: + return new Tie(a.a, b, BYd(b.Dh(), a.c), a.d.n); + case 31: + return new Nie(a.a, b, BYd(b.Dh(), a.c), a.d.n); + case 33: + return new $ie(a.a, b, BYd(b.Dh(), a.c), a.d.n); + case 35: + return new Vie(a.a, b, BYd(b.Dh(), a.c), a.d.n); + case 37: + return new Pie(a.a, b, BYd(b.Dh(), a.c), a.d.n); + case 39: + return new Iie(a.a, b, BYd(b.Dh(), a.c), a.d.n); + case 40: + return new Uge(b, BYd(b.Dh(), a.c)); + default: + throw Adb(new yz("Unknown feature style: " + a.e)); + } + } + function h2c(a) { + var b, c2, d, e, f2, g, h, i2; + f2 = 0; + e = a.a.b; + for (i2 = Sub(a.a, 0); i2.b != i2.d.c; ) { + h = RD(evb(i2), 240); + g = (f2 + 1) / (e + 1); + if (!a.c && !a.d) { + return; + } else if (!!a.c && !a.d) { + a.g = true; + if (a.b == (Cmd(), ymd)) { + d = a.c.e.b + a.c.f.b + a.e * (f2 + 1); + b = new rjd(Kfb(UD(mQb(a.c, (q$c(), e$c)))) + a.e, d); + c2 = new rjd(Kfb(UD(mQb(a.c, f$c))) - a.e, d); + } else if (a.b == zmd) { + d = a.c.e.b + a.c.f.b + a.e * (f2 + 1); + b = new rjd(Kfb(UD(mQb(a.c, (q$c(), f$c)))) - a.e, d); + c2 = new rjd(Kfb(UD(mQb(a.c, e$c))) + a.e, d); + } else if (a.b == Bmd) { + d = a.c.e.a + a.c.f.a + a.e * (f2 + 1); + b = new rjd(d, Kfb(UD(mQb(a.c, (q$c(), e$c)))) + a.e); + c2 = new rjd(d, Kfb(UD(mQb(a.c, f$c))) - a.e); + } else { + d = a.c.e.a + a.c.f.a + a.e * (f2 + 1); + b = new rjd(d, Kfb(UD(mQb(a.c, (q$c(), f$c)))) - a.e); + c2 = new rjd(d, Kfb(UD(mQb(a.c, e$c))) + a.e); + } + } else if (!!a.c && !!a.d) { + if (a.b == (Cmd(), ymd)) { + d = a.d.e.b * g + (a.c.e.b + a.c.f.b) * (1 - g); + b = new rjd(Kfb(UD(mQb(a.c, (q$c(), e$c)))) + a.e, d); + c2 = new rjd(Kfb(UD(mQb(a.c, f$c))) - a.e, d); + } else if (a.b == zmd) { + d = a.d.e.b * g + (a.c.e.b + a.c.f.b) * (1 - g); + b = new rjd(Kfb(UD(mQb(a.c, (q$c(), f$c)))) - a.e, d); + c2 = new rjd(Kfb(UD(mQb(a.c, e$c))) + a.e, d); + } else if (a.b == Bmd) { + d = a.d.e.a * g + (a.c.e.a + a.c.f.a) * (1 - g); + b = new rjd(d, Kfb(UD(mQb(a.c, (q$c(), e$c)))) + a.e); + c2 = new rjd(d, Kfb(UD(mQb(a.c, f$c))) - a.e); + } else { + d = a.d.e.a * g + (a.c.e.a + a.c.f.a) * (1 - g); + b = new rjd(d, Kfb(UD(mQb(a.c, (q$c(), f$c)))) - a.e); + c2 = new rjd(d, Kfb(UD(mQb(a.c, e$c))) + a.e); + } + } else { + a.f = true; + if (a.b == (Cmd(), ymd)) { + d = a.d.e.b - a.e * (f2 + 1); + b = new rjd(Kfb(UD(mQb(a.d, (q$c(), e$c)))) + a.e, d); + c2 = new rjd(Kfb(UD(mQb(a.d, f$c))) - a.e, d); + } else if (a.b == zmd) { + d = a.d.e.b - a.e * (f2 + 1); + b = new rjd(Kfb(UD(mQb(a.d, (q$c(), f$c)))) - a.e, d); + c2 = new rjd(Kfb(UD(mQb(a.d, e$c))) + a.e, d); + } else if (a.b == Bmd) { + d = a.d.e.a - a.e * (f2 + 1); + b = new rjd(d, Kfb(UD(mQb(a.d, (q$c(), e$c)))) + a.e); + c2 = new rjd(d, Kfb(UD(mQb(a.d, f$c))) - a.e); + } else { + d = a.d.e.a - a.e * (f2 + 1); + b = new rjd(d, Kfb(UD(mQb(a.d, (q$c(), f$c)))) - a.e); + c2 = new rjd(d, Kfb(UD(mQb(a.d, e$c))) + a.e); + } + } + RD(h.a, 8).a = b.a; + RD(h.a, 8).b = b.b; + h.b.a = c2.a; + h.b.b = c2.b; + ++f2; + } + } + function LA(a, b, c2, d, e, f2) { + var g, h, i2, j, k, l, m, n, o2, p, q, r; + switch (b) { + case 71: + h = d.q.getFullYear() - Owe >= -1900 ? 1 : 0; + c2 >= 4 ? Zhb(a, cD(WC(qJ, 1), Nve, 2, 6, [Qwe, Rwe])[h]) : Zhb(a, cD(WC(qJ, 1), Nve, 2, 6, ["BC", "AD"])[h]); + break; + case 121: + AA(a, c2, d); + break; + case 77: + zA(a, c2, d); + break; + case 107: + i2 = e.q.getHours(); + i2 == 0 ? UA(a, 24, c2) : UA(a, i2, c2); + break; + case 83: + yA(a, c2, e); + break; + case 69: + k = d.q.getDay(); + c2 == 5 ? Zhb(a, cD(WC(qJ, 1), Nve, 2, 6, ["S", "M", "T", "W", "T", "F", "S"])[k]) : c2 == 4 ? Zhb(a, cD(WC(qJ, 1), Nve, 2, 6, [Swe, Twe, Uwe, Vwe, Wwe, Xwe, Ywe])[k]) : Zhb(a, cD(WC(qJ, 1), Nve, 2, 6, ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"])[k]); + break; + case 97: + e.q.getHours() >= 12 && e.q.getHours() < 24 ? Zhb(a, cD(WC(qJ, 1), Nve, 2, 6, ["AM", "PM"])[1]) : Zhb(a, cD(WC(qJ, 1), Nve, 2, 6, ["AM", "PM"])[0]); + break; + case 104: + l = e.q.getHours() % 12; + l == 0 ? UA(a, 12, c2) : UA(a, l, c2); + break; + case 75: + m = e.q.getHours() % 12; + UA(a, m, c2); + break; + case 72: + n = e.q.getHours(); + UA(a, n, c2); + break; + case 99: + o2 = d.q.getDay(); + c2 == 5 ? Zhb(a, cD(WC(qJ, 1), Nve, 2, 6, ["S", "M", "T", "W", "T", "F", "S"])[o2]) : c2 == 4 ? Zhb(a, cD(WC(qJ, 1), Nve, 2, 6, [Swe, Twe, Uwe, Vwe, Wwe, Xwe, Ywe])[o2]) : c2 == 3 ? Zhb(a, cD(WC(qJ, 1), Nve, 2, 6, ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"])[o2]) : UA(a, o2, 1); + break; + case 76: + p = d.q.getMonth(); + c2 == 5 ? Zhb(a, cD(WC(qJ, 1), Nve, 2, 6, ["J", "F", "M", "A", "M", "J", "J", "A", "S", "O", "N", "D"])[p]) : c2 == 4 ? Zhb(a, cD(WC(qJ, 1), Nve, 2, 6, [Cwe, Dwe, Ewe, Fwe, Gwe, Hwe, Iwe, Jwe, Kwe, Lwe, Mwe, Nwe])[p]) : c2 == 3 ? Zhb(a, cD(WC(qJ, 1), Nve, 2, 6, ["Jan", "Feb", "Mar", "Apr", Gwe, "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"])[p]) : UA(a, p + 1, c2); + break; + case 81: + q = d.q.getMonth() / 3 | 0; + c2 < 4 ? Zhb(a, cD(WC(qJ, 1), Nve, 2, 6, ["Q1", "Q2", "Q3", "Q4"])[q]) : Zhb(a, cD(WC(qJ, 1), Nve, 2, 6, ["1st quarter", "2nd quarter", "3rd quarter", "4th quarter"])[q]); + break; + case 100: + r = d.q.getDate(); + UA(a, r, c2); + break; + case 109: + j = e.q.getMinutes(); + UA(a, j, c2); + break; + case 115: + g = e.q.getSeconds(); + UA(a, g, c2); + break; + case 122: + c2 < 4 ? Zhb(a, f2.c[0]) : Zhb(a, f2.c[1]); + break; + case 118: + Zhb(a, f2.b); + break; + case 90: + c2 < 3 ? Zhb(a, cB(f2)) : c2 == 3 ? Zhb(a, bB(f2)) : Zhb(a, eB(f2.a)); + break; + default: + return false; + } + return true; + } + function f5b(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5, F, G, H; + X4b(b); + i2 = RD(QHd((!b.b && (b.b = new Yie(E4, b, 4, 7)), b.b), 0), 84); + k = RD(QHd((!b.c && (b.c = new Yie(E4, b, 5, 8)), b.c), 0), 84); + h = AGd(i2); + j = AGd(k); + g = (!b.a && (b.a = new C5d(F4, b, 6, 6)), b.a).i == 0 ? null : RD(QHd((!b.a && (b.a = new C5d(F4, b, 6, 6)), b.a), 0), 166); + A = RD(Wjb(a.a, h), 10); + F = RD(Wjb(a.a, j), 10); + B = null; + G = null; + if (ZD(i2, 193)) { + w2 = RD(Wjb(a.a, i2), 305); + if (ZD(w2, 12)) { + B = RD(w2, 12); + } else if (ZD(w2, 10)) { + A = RD(w2, 10); + B = RD(Vmb(A.j, 0), 12); + } + } + if (ZD(k, 193)) { + D5 = RD(Wjb(a.a, k), 305); + if (ZD(D5, 12)) { + G = RD(D5, 12); + } else if (ZD(D5, 10)) { + F = RD(D5, 10); + G = RD(Vmb(F.j, 0), 12); + } + } + if (!A || !F) { + throw Adb(new Ked("The source or the target of edge " + b + " could not be found. This usually happens when an edge connects a node laid out by ELK Layered to a node in another level of hierarchy laid out by either another instance of ELK Layered or another layout algorithm alltogether. The former can be solved by setting the hierarchyHandling option to INCLUDE_CHILDREN.")); + } + p = new a1b(); + kQb(p, b); + pQb(p, (Ywc(), Awc), b); + pQb(p, (yCc(), RAc), null); + n = RD(mQb(d, kwc), 21); + A == F && n.Fc((ovc(), nvc)); + if (!B) { + v = (BEc(), zEc); + C = null; + if (!!g && Dod(RD(mQb(A, BBc), 101))) { + C = new rjd(g.j, g.k); + Fsd(C, kzd(b)); + Gsd(C, c2); + if (NGd(j, h)) { + v = yEc; + $id(C, A.n); + } + } + B = g2b(A, C, v, d); + } + if (!G) { + v = (BEc(), yEc); + H = null; + if (!!g && Dod(RD(mQb(F, BBc), 101))) { + H = new rjd(g.b, g.c); + Fsd(H, kzd(b)); + Gsd(H, c2); + } + G = g2b(F, H, v, Y2b(F)); + } + Y0b(p, B); + Z0b(p, G); + (B.e.c.length > 1 || B.g.c.length > 1 || G.e.c.length > 1 || G.g.c.length > 1) && n.Fc((ovc(), ivc)); + for (m = new dMd((!b.n && (b.n = new C5d(I4, b, 1, 7)), b.n)); m.e != m.i.gc(); ) { + l = RD(bMd(m), 135); + if (!Heb(TD(Gxd(l, pBc))) && !!l.a) { + q = h5b(l); + Rmb(p.b, q); + switch (RD(mQb(q, wAc), 278).g) { + case 1: + case 2: + n.Fc((ovc(), gvc)); + break; + case 0: + n.Fc((ovc(), evc)); + pQb(q, wAc, (Omd(), Lmd)); + } + } + } + f2 = RD(mQb(d, oAc), 322); + r = RD(mQb(d, kBc), 323); + e = f2 == (stc(), ptc) || r == (JDc(), FDc); + if (!!g && (!g.a && (g.a = new XZd(D4, g, 5)), g.a).i != 0 && e) { + s = ssd(g); + o2 = new Ejd(); + for (u = Sub(s, 0); u.b != u.d.c; ) { + t = RD(evb(u), 8); + Mub(o2, new sjd(t)); + } + pQb(p, Bwc, o2); + } + return p; + } + function F0c(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5, F, G, H, I; + C = 0; + D5 = 0; + A = new Tsb(); + v = RD(Lvb(JDb(GDb(new SDb(null, new Swb(a.b, 16)), new v1c()), new Z0c())), 17).a + 1; + B = $C(kE, Pwe, 28, v, 15, 1); + q = $C(kE, Pwe, 28, v, 15, 1); + for (p = 0; p < v; p++) { + B[p] = 0; + q[p] = 0; + } + i2 = RD(zDb(BDb(new SDb(null, new Swb(a.a, 16))), tBb(new ZBb(), new XBb(), new wCb(), cD(WC(QL, 1), jwe, 108, 0, [(xBb(), vBb)]))), 15); + for (k = i2.Kc(); k.Ob(); ) { + j = RD(k.Pb(), 65); + G = RD(mQb(j.b, (h_c(), f_c)), 17).a; + I = RD(mQb(j.c, f_c), 17).a; + u = I - G; + if (u > 1) { + for (h = G + 1; h < I; h++) { + l = h; + w2 = RD(zDb(CDb(new SDb(null, new Swb(a.b, 16)), new P1c(l)), tBb(new ZBb(), new XBb(), new wCb(), cD(WC(QL, 1), jwe, 108, 0, [vBb]))), 15); + o2 = 0; + if (b == (Cmd(), ymd) || b == zmd) { + w2.jd(new V1c()); + for (o2 = 0; o2 < w2.gc(); o2++) { + r = (h - G) / (I - G); + if (RD(w2.Xb(o2), 40).e.b > j.b.e.b * (1 - r) + j.c.e.b * r) { + break; + } + } + if (w2.gc() > 0) { + H = j.a.b == 0 ? ajd(j.b.e) : RD(Rub(j.a), 8); + t = $id(ajd(RD(w2.Xb(w2.gc() - 1), 40).e), RD(w2.Xb(w2.gc() - 1), 40).f); + m = $id(ajd(RD(w2.Xb(0), 40).e), RD(w2.Xb(0), 40).f); + if (o2 >= w2.gc() - 1 && H.b > t.b && j.c.e.b > t.b) { + continue; + } + if (o2 <= 0 && H.b < m.a && j.c.e.b < m.b) { + continue; + } + } + } else { + w2.jd(new Z1c()); + for (o2 = 0; o2 < w2.gc(); o2++) { + r = (h - G) / (I - G); + if (RD(w2.Xb(o2), 40).e.a > j.b.e.a * (1 - r) + j.c.e.a * r) { + break; + } + } + if (w2.gc() > 0) { + H = j.a.b == 0 ? ajd(j.b.e) : RD(Rub(j.a), 8); + t = $id(ajd(RD(w2.Xb(w2.gc() - 1), 40).e), RD(w2.Xb(w2.gc() - 1), 40).f); + m = $id(ajd(RD(w2.Xb(0), 40).e), RD(w2.Xb(0), 40).f); + if (o2 >= w2.gc() - 1 && H.a > t.a && j.c.e.a > t.a) { + continue; + } + if (o2 <= 0 && H.a < m.a && j.c.e.a < m.a) { + continue; + } + } + } + e = new pjd(); + f2 = new pjd(); + Mub(j.a, e); + Mub(j.a, f2); + g = new gud(e, f2, j); + s = Rdb(Sdb(h, 32), Cdb(o2, yxe)); + if (Ujb(A, Hgb(s))) { + n = RD(Wjb(A, Hgb(s)), 675); + Mub(n.a, g); + Dmd(n.b) ? tvb(n.a, new l2c()) : tvb(n.a, new p2c()); + h2c(n); + } else { + n = new i2c(o2 == 0 ? null : RD(w2.Xb(o2 - 1), 40), o2 == w2.gc() ? null : RD(w2.Xb(o2), 40), g, a); + Zjb(A, Hgb(s), n); + } + if (b == ymd || b == zmd) { + n.f && n.d.e.b <= Kfb(UD(mQb(a, (q$c(), _Zc)))) && ++C; + n.g && n.c.e.b + n.c.f.b >= Kfb(UD(mQb(a, (q$c(), $Zc)))) && ++D5; + } else { + n.f && n.d.e.a <= Kfb(UD(mQb(a, (q$c(), ZZc)))) && ++C; + n.g && n.c.e.a + n.c.f.a >= Kfb(UD(mQb(a, (q$c(), YZc)))) && ++D5; + } + } + } else if (u == 0) { + H0c(j); + } else if (u < 0) { + ++B[G]; + ++q[I]; + F = C0c(j, b, a, new Ptd(sgb(C), sgb(D5)), c2, d, new Ptd(sgb(q[I]), sgb(B[G]))); + C = RD(F.a, 17).a; + D5 = RD(F.b, 17).a; + } + } + } + function qrc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s; + d = b; + i2 = c2; + if (a.b && d.j == (qpd(), ppd) && i2.j == (qpd(), ppd)) { + s = d; + d = i2; + i2 = s; + } + if (Ujb(a.a, d)) { + if (Zsb(RD(Wjb(a.a, d), 49), i2)) { + return 1; + } + } else { + Zjb(a.a, d, new _sb()); + } + if (Ujb(a.a, i2)) { + if (Zsb(RD(Wjb(a.a, i2), 49), d)) { + return -1; + } + } else { + Zjb(a.a, i2, new _sb()); + } + if (Ujb(a.d, d)) { + if (Zsb(RD(Wjb(a.d, d), 49), i2)) { + return -1; + } + } else { + Zjb(a.d, d, new _sb()); + } + if (Ujb(a.d, i2)) { + if (Zsb(RD(Wjb(a.a, i2), 49), d)) { + return 1; + } + } else { + Zjb(a.d, i2, new _sb()); + } + if (d.j != i2.j) { + r = yrc(d.j, i2.j); + r == -1 ? rrc(a, i2, d) : rrc(a, d, i2); + return r; + } + if (d.e.c.length != 0 && i2.e.c.length != 0) { + if (a.b) { + r = orc(d, i2); + if (r != 0) { + r == -1 ? rrc(a, i2, d) : r == 1 && rrc(a, d, i2); + return r; + } + } + f2 = RD(Vmb(d.e, 0), 18).c.i; + k = RD(Vmb(i2.e, 0), 18).c.i; + if (f2 == k) { + e = RD(mQb(RD(Vmb(d.e, 0), 18), (Ywc(), zwc)), 17).a; + j = RD(mQb(RD(Vmb(i2.e, 0), 18), zwc), 17).a; + e > j ? rrc(a, d, i2) : rrc(a, i2, d); + return e < j ? -1 : e > j ? 1 : 0; + } + for (o2 = a.c, p = 0, q = o2.length; p < q; ++p) { + n = o2[p]; + if (n == f2) { + rrc(a, d, i2); + return 1; + } else if (n == k) { + rrc(a, i2, d); + return -1; + } + } + } + if (d.g.c.length != 0 && i2.g.c.length != 0) { + h = RD(mQb(d, (Ywc(), xwc)), 10); + m = RD(mQb(i2, xwc), 10); + if (a.e == (kEc(), jEc) && !!h && !!m && nQb(h, zwc) && nQb(m, zwc)) { + e = RD(mQb(h, zwc), 17).a; + j = RD(mQb(m, zwc), 17).a; + e > j ? rrc(a, d, i2) : rrc(a, i2, d); + return e < j ? -1 : e > j ? 1 : 0; + } + if (a.b) { + r = orc(d, i2); + if (r != 0) { + r == -1 ? rrc(a, i2, d) : r == 1 && rrc(a, d, i2); + return r; + } + } + g = 0; + l = 0; + nQb(RD(Vmb(d.g, 0), 18), zwc) && (g = RD(mQb(RD(Vmb(d.g, 0), 18), zwc), 17).a); + nQb(RD(Vmb(i2.g, 0), 18), zwc) && (l = RD(mQb(RD(Vmb(d.g, 0), 18), zwc), 17).a); + if (!!h && h == m) { + if (Heb(TD(mQb(RD(Vmb(d.g, 0), 18), Nwc))) && !Heb(TD(mQb(RD(Vmb(i2.g, 0), 18), Nwc)))) { + rrc(a, d, i2); + return 1; + } else if (!Heb(TD(mQb(RD(Vmb(d.g, 0), 18), Nwc))) && Heb(TD(mQb(RD(Vmb(i2.g, 0), 18), Nwc)))) { + rrc(a, i2, d); + return -1; + } + g > l ? rrc(a, d, i2) : rrc(a, i2, d); + return g < l ? -1 : g > l ? 1 : 0; + } + if (a.f) { + a.f._b(h) && (g = RD(a.f.xc(h), 17).a); + a.f._b(m) && (l = RD(a.f.xc(m), 17).a); + } + g > l ? rrc(a, d, i2) : rrc(a, i2, d); + return g < l ? -1 : g > l ? 1 : 0; + } + if (d.e.c.length != 0 && i2.g.c.length != 0) { + rrc(a, d, i2); + return 1; + } else if (d.g.c.length != 0 && i2.e.c.length != 0) { + rrc(a, i2, d); + return -1; + } else if (nQb(d, (Ywc(), zwc)) && nQb(i2, zwc)) { + e = RD(mQb(d, zwc), 17).a; + j = RD(mQb(i2, zwc), 17).a; + e > j ? rrc(a, d, i2) : rrc(a, i2, d); + return e < j ? -1 : e > j ? 1 : 0; + } else { + rrc(a, i2, d); + return -1; + } + } + function Yae(a) { + if (a.gb) + return; + a.gb = true; + a.b = jBd(a, 0); + iBd(a.b, 18); + oBd(a.b, 19); + a.a = jBd(a, 1); + iBd(a.a, 1); + oBd(a.a, 2); + oBd(a.a, 3); + oBd(a.a, 4); + oBd(a.a, 5); + a.o = jBd(a, 2); + iBd(a.o, 8); + iBd(a.o, 9); + oBd(a.o, 10); + oBd(a.o, 11); + oBd(a.o, 12); + oBd(a.o, 13); + oBd(a.o, 14); + oBd(a.o, 15); + oBd(a.o, 16); + oBd(a.o, 17); + oBd(a.o, 18); + oBd(a.o, 19); + oBd(a.o, 20); + oBd(a.o, 21); + oBd(a.o, 22); + oBd(a.o, 23); + nBd(a.o); + nBd(a.o); + nBd(a.o); + nBd(a.o); + nBd(a.o); + nBd(a.o); + nBd(a.o); + nBd(a.o); + nBd(a.o); + nBd(a.o); + a.p = jBd(a, 3); + iBd(a.p, 2); + iBd(a.p, 3); + iBd(a.p, 4); + iBd(a.p, 5); + oBd(a.p, 6); + oBd(a.p, 7); + nBd(a.p); + nBd(a.p); + a.q = jBd(a, 4); + iBd(a.q, 8); + a.v = jBd(a, 5); + oBd(a.v, 9); + nBd(a.v); + nBd(a.v); + nBd(a.v); + a.w = jBd(a, 6); + iBd(a.w, 2); + iBd(a.w, 3); + iBd(a.w, 4); + oBd(a.w, 5); + a.B = jBd(a, 7); + oBd(a.B, 1); + nBd(a.B); + nBd(a.B); + nBd(a.B); + a.Q = jBd(a, 8); + oBd(a.Q, 0); + nBd(a.Q); + a.R = jBd(a, 9); + iBd(a.R, 1); + a.S = jBd(a, 10); + nBd(a.S); + nBd(a.S); + nBd(a.S); + nBd(a.S); + nBd(a.S); + nBd(a.S); + nBd(a.S); + nBd(a.S); + nBd(a.S); + nBd(a.S); + nBd(a.S); + nBd(a.S); + nBd(a.S); + nBd(a.S); + nBd(a.S); + a.T = jBd(a, 11); + oBd(a.T, 10); + oBd(a.T, 11); + oBd(a.T, 12); + oBd(a.T, 13); + oBd(a.T, 14); + nBd(a.T); + nBd(a.T); + a.U = jBd(a, 12); + iBd(a.U, 2); + iBd(a.U, 3); + oBd(a.U, 4); + oBd(a.U, 5); + oBd(a.U, 6); + oBd(a.U, 7); + nBd(a.U); + a.V = jBd(a, 13); + oBd(a.V, 10); + a.W = jBd(a, 14); + iBd(a.W, 18); + iBd(a.W, 19); + iBd(a.W, 20); + oBd(a.W, 21); + oBd(a.W, 22); + oBd(a.W, 23); + a.bb = jBd(a, 15); + iBd(a.bb, 10); + iBd(a.bb, 11); + iBd(a.bb, 12); + iBd(a.bb, 13); + iBd(a.bb, 14); + iBd(a.bb, 15); + iBd(a.bb, 16); + oBd(a.bb, 17); + nBd(a.bb); + nBd(a.bb); + a.eb = jBd(a, 16); + iBd(a.eb, 2); + iBd(a.eb, 3); + iBd(a.eb, 4); + iBd(a.eb, 5); + iBd(a.eb, 6); + iBd(a.eb, 7); + oBd(a.eb, 8); + oBd(a.eb, 9); + a.ab = jBd(a, 17); + iBd(a.ab, 0); + iBd(a.ab, 1); + a.H = jBd(a, 18); + oBd(a.H, 0); + oBd(a.H, 1); + oBd(a.H, 2); + oBd(a.H, 3); + oBd(a.H, 4); + oBd(a.H, 5); + nBd(a.H); + a.db = jBd(a, 19); + oBd(a.db, 2); + a.c = kBd(a, 20); + a.d = kBd(a, 21); + a.e = kBd(a, 22); + a.f = kBd(a, 23); + a.i = kBd(a, 24); + a.g = kBd(a, 25); + a.j = kBd(a, 26); + a.k = kBd(a, 27); + a.n = kBd(a, 28); + a.r = kBd(a, 29); + a.s = kBd(a, 30); + a.t = kBd(a, 31); + a.u = kBd(a, 32); + a.fb = kBd(a, 33); + a.A = kBd(a, 34); + a.C = kBd(a, 35); + a.D = kBd(a, 36); + a.F = kBd(a, 37); + a.G = kBd(a, 38); + a.I = kBd(a, 39); + a.J = kBd(a, 40); + a.L = kBd(a, 41); + a.M = kBd(a, 42); + a.N = kBd(a, 43); + a.O = kBd(a, 44); + a.P = kBd(a, 45); + a.X = kBd(a, 46); + a.Y = kBd(a, 47); + a.Z = kBd(a, 48); + a.$ = kBd(a, 49); + a._ = kBd(a, 50); + a.cb = kBd(a, 51); + a.K = kBd(a, 52); + } + function d5b(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5, F, G; + g = new Yub(); + w2 = RD(mQb(c2, (yCc(), rAc)), 88); + p = 0; + ye(g, (!b.a && (b.a = new C5d(J4, b, 10, 11)), b.a)); + while (g.b != 0) { + k = RD(g.b == 0 ? null : (sFb(g.b != 0), Wub(g, g.a.a)), 27); + j = vCd(k); + (dE(Gxd(j, cAc)) !== dE((kEc(), hEc)) || dE(Gxd(j, pAc)) === dE((Ptc(), Otc)) || dE(Gxd(j, pAc)) === dE((Ptc(), Mtc)) || Heb(TD(Gxd(j, eAc))) || dE(Gxd(j, Yzc)) !== dE((U$b(), T$b)) || dE(Gxd(j, ZAc)) === dE((aEc(), TDc)) || dE(Gxd(j, ZAc)) === dE((aEc(), UDc)) || dE(Gxd(j, $Ac)) === dE((_Cc(), SCc)) || dE(Gxd(j, $Ac)) === dE((_Cc(), UCc))) && !Heb(TD(Gxd(k, aAc))) && Ixd(k, (Ywc(), zwc), sgb(p++)); + r = !Heb(TD(Gxd(k, pBc))); + if (r) { + m = (!k.a && (k.a = new C5d(J4, k, 10, 11)), k.a).i != 0; + o2 = a5b(k); + n = dE(Gxd(k, IAc)) === dE((Fnd(), Cnd)); + G = !Hxd(k, (umd(), Akd)) || khb(WD(Gxd(k, Akd))); + u = null; + if (G && n && (m || o2)) { + u = Z4b(k); + pQb(u, rAc, w2); + nQb(u, PBc) && HCc(new RCc(Kfb(UD(mQb(u, PBc)))), u); + if (RD(Gxd(k, lBc), 181).gc() != 0) { + l = u; + FDb(new SDb(null, (!k.c && (k.c = new C5d(K4, k, 9, 9)), new Swb(k.c, 16))), new u5b(l)); + V4b(k, u); + } + } + A = c2; + B = RD(Wjb(a.a, vCd(k)), 10); + !!B && (A = B.e); + t = i5b(a, k, A); + if (u) { + t.e = u; + u.e = t; + ye(g, (!k.a && (k.a = new C5d(J4, k, 10, 11)), k.a)); + } + } + } + p = 0; + Pub(g, b, g.c.b, g.c); + while (g.b != 0) { + f2 = RD(g.b == 0 ? null : (sFb(g.b != 0), Wub(g, g.a.a)), 27); + for (i2 = new dMd((!f2.b && (f2.b = new C5d(G4, f2, 12, 3)), f2.b)); i2.e != i2.i.gc(); ) { + h = RD(bMd(i2), 74); + X4b(h); + (dE(Gxd(b, cAc)) !== dE((kEc(), hEc)) || dE(Gxd(b, pAc)) === dE((Ptc(), Otc)) || dE(Gxd(b, pAc)) === dE((Ptc(), Mtc)) || Heb(TD(Gxd(b, eAc))) || dE(Gxd(b, Yzc)) !== dE((U$b(), T$b)) || dE(Gxd(b, ZAc)) === dE((aEc(), TDc)) || dE(Gxd(b, ZAc)) === dE((aEc(), UDc)) || dE(Gxd(b, $Ac)) === dE((_Cc(), SCc)) || dE(Gxd(b, $Ac)) === dE((_Cc(), UCc))) && Ixd(h, (Ywc(), zwc), sgb(p++)); + D5 = AGd(RD(QHd((!h.b && (h.b = new Yie(E4, h, 4, 7)), h.b), 0), 84)); + F = AGd(RD(QHd((!h.c && (h.c = new Yie(E4, h, 5, 8)), h.c), 0), 84)); + if (Heb(TD(Gxd(h, pBc))) || Heb(TD(Gxd(D5, pBc))) || Heb(TD(Gxd(F, pBc)))) { + continue; + } + q = ozd(h) && Heb(TD(Gxd(D5, NAc))) && Heb(TD(Gxd(h, OAc))); + v = f2; + q || NGd(F, D5) ? v = D5 : NGd(D5, F) && (v = F); + A = c2; + B = RD(Wjb(a.a, v), 10); + !!B && (A = B.e); + s = f5b(a, h, v, A); + pQb(s, (Ywc(), Zvc), _4b(a, h, b, c2)); + } + n = dE(Gxd(f2, IAc)) === dE((Fnd(), Cnd)); + if (n) { + for (e = new dMd((!f2.a && (f2.a = new C5d(J4, f2, 10, 11)), f2.a)); e.e != e.i.gc(); ) { + d = RD(bMd(e), 27); + G = !Hxd(d, (umd(), Akd)) || khb(WD(Gxd(d, Akd))); + C = dE(Gxd(d, IAc)) === dE(Cnd); + G && C && (Pub(g, d, g.c.b, g.c), true); + } + } + } + } + function Ywc() { + Ywc = geb; + var a, b; + Awc = new jGd(rAe); + Zvc = new jGd("coordinateOrigin"); + Kwc = new jGd("processors"); + Yvc = new kGd("compoundNode", (Geb(), false)); + nwc = new kGd("insideConnections", false); + Bwc = new jGd("originalBendpoints"); + Cwc = new jGd("originalDummyNodePosition"); + Dwc = new jGd("originalLabelEdge"); + Mwc = new jGd("representedLabels"); + cwc = new jGd("endLabels"); + dwc = new jGd("endLabel.origin"); + swc = new kGd("labelSide", (Pnd(), Ond)); + ywc = new kGd("maxEdgeThickness", 0); + Nwc = new kGd("reversed", false); + Lwc = new jGd(sAe); + vwc = new kGd("longEdgeSource", null); + wwc = new kGd("longEdgeTarget", null); + uwc = new kGd("longEdgeHasLabelDummies", false); + twc = new kGd("longEdgeBeforeLabelDummy", false); + bwc = new kGd("edgeConstraint", (huc(), fuc)); + pwc = new jGd("inLayerLayoutUnit"); + owc = new kGd("inLayerConstraint", (Gvc(), Evc)); + qwc = new kGd("inLayerSuccessorConstraint", new bnb()); + rwc = new kGd("inLayerSuccessorConstraintBetweenNonDummies", false); + Iwc = new jGd("portDummy"); + $vc = new kGd("crossingHint", sgb(0)); + kwc = new kGd("graphProperties", (b = RD(mfb(iX), 9), new Fsb(b, RD(WEb(b, b.length), 9), 0))); + hwc = new kGd("externalPortSide", (qpd(), opd)); + iwc = new kGd("externalPortSize", new pjd()); + fwc = new jGd("externalPortReplacedDummies"); + gwc = new jGd("externalPortReplacedDummy"); + ewc = new kGd("externalPortConnections", (a = RD(mfb(E3), 9), new Fsb(a, RD(WEb(a, a.length), 9), 0))); + Jwc = new kGd(Xye, 0); + Uvc = new jGd("barycenterAssociates"); + Xwc = new jGd("TopSideComments"); + Vvc = new jGd("BottomSideComments"); + Xvc = new jGd("CommentConnectionPort"); + mwc = new kGd("inputCollect", false); + Gwc = new kGd("outputCollect", false); + awc = new kGd("cyclic", false); + _vc = new jGd("crossHierarchyMap"); + Wwc = new jGd("targetOffset"); + new kGd("splineLabelSize", new pjd()); + Qwc = new jGd("spacings"); + Hwc = new kGd("partitionConstraint", false); + Wvc = new jGd("breakingPoint.info"); + Uwc = new jGd("splines.survivingEdge"); + Twc = new jGd("splines.route.start"); + Rwc = new jGd("splines.edgeChain"); + Fwc = new jGd("originalPortConstraints"); + Pwc = new jGd("selfLoopHolder"); + Swc = new jGd("splines.nsPortY"); + zwc = new jGd("modelOrder"); + xwc = new jGd("longEdgeTargetNode"); + jwc = new kGd(GBe, false); + Owc = new kGd(GBe, false); + lwc = new jGd("layerConstraints.hiddenNodes"); + Ewc = new jGd("layerConstraints.opposidePort"); + Vwc = new jGd("targetNode.modelOrder"); + } + function D0c(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m, n, o2; + for (l = Sub(a.b, 0); l.b != l.d.c; ) { + k = RD(evb(l), 40); + if (lhb(k.c, IEe)) { + continue; + } + f2 = RD(zDb(new SDb(null, new Swb(hWc(k, a), 16)), tBb(new ZBb(), new XBb(), new wCb(), cD(WC(QL, 1), jwe, 108, 0, [(xBb(), vBb)]))), 15); + b == (Cmd(), ymd) || b == zmd ? f2.jd(new L1c()) : f2.jd(new R1c()); + o2 = f2.gc(); + for (e = 0; e < o2; e++) { + g = o2 == 1 ? 0.5 : (1 + e) / (o2 + 1); + if (b == ymd) { + j = Kfb(UD(mQb(k, (q$c(), e$c)))); + if (k.e.a + k.f.a + d < j) { + Oub(RD(f2.Xb(e), 65).a, new rjd(j + c2, k.e.b + k.f.b * g)); + } else if (RD(f2.Xb(e), 65).a.b > 0) { + h = RD(Rub(RD(f2.Xb(e), 65).a), 8).a; + m = k.e.a + k.f.a / 2; + i2 = RD(Rub(RD(f2.Xb(e), 65).a), 8).b; + n = k.e.b + k.f.b / 2; + d > 0 && $wnd.Math.abs(i2 - n) / ($wnd.Math.abs(h - m) / 40) > 50 && (n > i2 ? Oub(RD(f2.Xb(e), 65).a, new rjd(k.e.a + k.f.a + d / 5.3, k.e.b + k.f.b * g - d / 2)) : Oub(RD(f2.Xb(e), 65).a, new rjd(k.e.a + k.f.a + d / 5.3, k.e.b + k.f.b * g + d / 2))); + } + Oub(RD(f2.Xb(e), 65).a, new rjd(k.e.a + k.f.a, k.e.b + k.f.b * g)); + } else if (b == zmd) { + j = Kfb(UD(mQb(k, (q$c(), f$c)))); + if (k.e.a - d > j) { + Oub(RD(f2.Xb(e), 65).a, new rjd(j - c2, k.e.b + k.f.b * g)); + } else if (RD(f2.Xb(e), 65).a.b > 0) { + h = RD(Rub(RD(f2.Xb(e), 65).a), 8).a; + m = k.e.a + k.f.a / 2; + i2 = RD(Rub(RD(f2.Xb(e), 65).a), 8).b; + n = k.e.b + k.f.b / 2; + d > 0 && $wnd.Math.abs(i2 - n) / ($wnd.Math.abs(h - m) / 40) > 50 && (n > i2 ? Oub(RD(f2.Xb(e), 65).a, new rjd(k.e.a - d / 5.3, k.e.b + k.f.b * g - d / 2)) : Oub(RD(f2.Xb(e), 65).a, new rjd(k.e.a - d / 5.3, k.e.b + k.f.b * g + d / 2))); + } + Oub(RD(f2.Xb(e), 65).a, new rjd(k.e.a, k.e.b + k.f.b * g)); + } else if (b == Bmd) { + j = Kfb(UD(mQb(k, (q$c(), e$c)))); + if (k.e.b + k.f.b + d < j) { + Oub(RD(f2.Xb(e), 65).a, new rjd(k.e.a + k.f.a * g, j + c2)); + } else if (RD(f2.Xb(e), 65).a.b > 0) { + h = RD(Rub(RD(f2.Xb(e), 65).a), 8).a; + m = k.e.a + k.f.a / 2; + i2 = RD(Rub(RD(f2.Xb(e), 65).a), 8).b; + n = k.e.b + k.f.b / 2; + d > 0 && $wnd.Math.abs(h - m) / ($wnd.Math.abs(i2 - n) / 40) > 50 && (m > h ? Oub(RD(f2.Xb(e), 65).a, new rjd(k.e.a + k.f.a * g - d / 2, k.e.b + d / 5.3 + k.f.b)) : Oub(RD(f2.Xb(e), 65).a, new rjd(k.e.a + k.f.a * g + d / 2, k.e.b + d / 5.3 + k.f.b))); + } + Oub(RD(f2.Xb(e), 65).a, new rjd(k.e.a + k.f.a * g, k.e.b + k.f.b)); + } else { + j = Kfb(UD(mQb(k, (q$c(), f$c)))); + if (mWc(RD(f2.Xb(e), 65), a)) { + Oub(RD(f2.Xb(e), 65).a, new rjd(k.e.a + k.f.a * g, RD(Rub(RD(f2.Xb(e), 65).a), 8).b)); + } else if (k.e.b - d > j) { + Oub(RD(f2.Xb(e), 65).a, new rjd(k.e.a + k.f.a * g, j - c2)); + } else if (RD(f2.Xb(e), 65).a.b > 0) { + h = RD(Rub(RD(f2.Xb(e), 65).a), 8).a; + m = k.e.a + k.f.a / 2; + i2 = RD(Rub(RD(f2.Xb(e), 65).a), 8).b; + n = k.e.b + k.f.b / 2; + d > 0 && $wnd.Math.abs(h - m) / ($wnd.Math.abs(i2 - n) / 40) > 50 && (m > h ? Oub(RD(f2.Xb(e), 65).a, new rjd(k.e.a + k.f.a * g - d / 2, k.e.b - d / 5.3)) : Oub(RD(f2.Xb(e), 65).a, new rjd(k.e.a + k.f.a * g + d / 2, k.e.b - d / 5.3))); + } + Oub(RD(f2.Xb(e), 65).a, new rjd(k.e.a + k.f.a * g, k.e.b)); + } + } + } + } + function umd() { + umd = geb; + var a, b; + Akd = new jGd(OGe); + Tld = new jGd(PGe); + Ckd = (Rjd(), Ljd); + Bkd = new lGd(MDe, Ckd); + Dkd = new lGd(Dze, null); + Ekd = new jGd(QGe); + Lkd = (ukd(), ysb(tkd, cD(WC(q3, 1), jwe, 298, 0, [pkd]))); + Kkd = new lGd(YDe, Lkd); + Mkd = new lGd(LDe, (Geb(), false)); + Okd = (Cmd(), Amd); + Nkd = new lGd(PDe, Okd); + Tkd = (Ymd(), Xmd); + Skd = new lGd(kDe, Tkd); + Wkd = new lGd(MGe, false); + Ykd = (Fnd(), Dnd); + Xkd = new lGd(fDe, Ykd); + uld = new A3b(12); + tld = new lGd(Eze, uld); + ald = new lGd(dAe, false); + bld = new lGd(iEe, false); + sld = new lGd(gAe, false); + Ild = (Bod(), Aod); + Hld = new lGd(eAe, Ild); + Qld = new jGd(fEe); + Rld = new jGd($ze); + Sld = new jGd(bAe); + Vld = new jGd(cAe); + dld = new Ejd(); + cld = new lGd(ZDe, dld); + Jkd = new lGd(aEe, false); + Zkd = new lGd(bEe, false); + fld = new P2b(); + eld = new lGd(gEe, fld); + rld = new lGd(JDe, false); + Uld = new lGd(SGe, 1); + Ikd = new jGd(TGe); + Hkd = new jGd(UGe); + mmd = new lGd(mAe, false); + new lGd(VGe, true); + sgb(0); + new lGd(WGe, sgb(100)); + new lGd(XGe, false); + sgb(0); + new lGd(YGe, sgb(4e3)); + sgb(0); + new lGd(ZGe, sgb(400)); + new lGd($Ge, false); + new lGd(_Ge, false); + new lGd(aHe, true); + new lGd(bHe, false); + Gkd = (Grd(), Frd); + Fkd = new lGd(NGe, Gkd); + Wld = new lGd(xDe, 10); + Xld = new lGd(yDe, 10); + Yld = new lGd(Bze, 20); + Zld = new lGd(zDe, 10); + $ld = new lGd(aAe, 2); + _ld = new lGd(ADe, 10); + bmd = new lGd(BDe, 0); + cmd = new lGd(EDe, 5); + dmd = new lGd(CDe, 1); + emd = new lGd(DDe, 1); + fmd = new lGd(_ze, 20); + gmd = new lGd(FDe, 10); + jmd = new lGd(GDe, 10); + amd = new jGd(HDe); + imd = new Q2b(); + hmd = new lGd(hEe, imd); + xld = new jGd(eEe); + wld = false; + vld = new lGd(dEe, wld); + hld = new A3b(5); + gld = new lGd(QDe, hld); + jld = (dod(), b = RD(mfb(A3), 9), new Fsb(b, RD(WEb(b, b.length), 9), 0)); + ild = new lGd(kAe, jld); + Ald = (pod(), mod); + zld = new lGd(TDe, Ald); + Cld = new jGd(UDe); + Dld = new jGd(VDe); + Eld = new jGd(WDe); + Bld = new jGd(XDe); + lld = (a = RD(mfb(H3), 9), new Fsb(a, RD(WEb(a, a.length), 9), 0)); + kld = new lGd(jAe, lld); + qld = xsb((dqd(), Ypd)); + pld = new lGd(iAe, qld); + old = new rjd(0, 0); + nld = new lGd(CAe, old); + mld = new lGd(hAe, false); + Rkd = (Omd(), Lmd); + Qkd = new lGd($De, Rkd); + Pkd = new lGd(fAe, false); + sgb(1); + new lGd(dHe, null); + Fld = new jGd(cEe); + Jld = new jGd(_De); + Pld = (qpd(), opd); + Old = new lGd(KDe, Pld); + Gld = new jGd(IDe); + Mld = (Pod(), xsb(Nod)); + Lld = new lGd(lAe, Mld); + Kld = new lGd(RDe, false); + Nld = new lGd(SDe, true); + qmd = new lGd(nAe, 1); + smd = new lGd(eHe, null); + lmd = new lGd(oAe, 150); + kmd = new lGd(pAe, 1.414); + nmd = new lGd(qAe, null); + omd = new lGd(fHe, 1); + $kd = new lGd(NDe, false); + _kd = new lGd(ODe, false); + Ukd = new lGd(Cze, 1); + Vkd = (ind(), gnd); + new lGd(gHe, Vkd); + yld = true; + rmd = (mqd(), jqd); + tmd = jqd; + pmd = jqd; + } + function hcc() { + hcc = geb; + nbc = new icc("DIRECTION_PREPROCESSOR", 0); + kbc = new icc("COMMENT_PREPROCESSOR", 1); + obc = new icc("EDGE_AND_LAYER_CONSTRAINT_EDGE_REVERSER", 2); + Ebc = new icc("INTERACTIVE_EXTERNAL_PORT_POSITIONER", 3); + Xbc = new icc("PARTITION_PREPROCESSOR", 4); + Ibc = new icc("LABEL_DUMMY_INSERTER", 5); + bcc = new icc("SELF_LOOP_PREPROCESSOR", 6); + Nbc = new icc("LAYER_CONSTRAINT_PREPROCESSOR", 7); + Vbc = new icc("PARTITION_MIDPROCESSOR", 8); + zbc = new icc("HIGH_DEGREE_NODE_LAYER_PROCESSOR", 9); + Rbc = new icc("NODE_PROMOTION", 10); + Mbc = new icc("LAYER_CONSTRAINT_POSTPROCESSOR", 11); + Wbc = new icc("PARTITION_POSTPROCESSOR", 12); + vbc = new icc("HIERARCHICAL_PORT_CONSTRAINT_PROCESSOR", 13); + dcc = new icc("SEMI_INTERACTIVE_CROSSMIN_PROCESSOR", 14); + ebc = new icc("BREAKING_POINT_INSERTER", 15); + Qbc = new icc("LONG_EDGE_SPLITTER", 16); + Zbc = new icc("PORT_SIDE_PROCESSOR", 17); + Fbc = new icc("INVERTED_PORT_PROCESSOR", 18); + Ybc = new icc("PORT_LIST_SORTER", 19); + fcc = new icc("SORT_BY_INPUT_ORDER_OF_MODEL", 20); + Tbc = new icc("NORTH_SOUTH_PORT_PREPROCESSOR", 21); + fbc = new icc("BREAKING_POINT_PROCESSOR", 22); + Ubc = new icc(jBe, 23); + gcc = new icc(kBe, 24); + _bc = new icc("SELF_LOOP_PORT_RESTORER", 25); + ecc = new icc("SINGLE_EDGE_GRAPH_WRAPPER", 26); + Gbc = new icc("IN_LAYER_CONSTRAINT_PROCESSOR", 27); + sbc = new icc("END_NODE_PORT_LABEL_MANAGEMENT_PROCESSOR", 28); + Hbc = new icc("LABEL_AND_NODE_SIZE_PROCESSOR", 29); + Dbc = new icc("INNERMOST_NODE_MARGIN_CALCULATOR", 30); + ccc = new icc("SELF_LOOP_ROUTER", 31); + ibc = new icc("COMMENT_NODE_MARGIN_CALCULATOR", 32); + qbc = new icc("END_LABEL_PREPROCESSOR", 33); + Kbc = new icc("LABEL_DUMMY_SWITCHER", 34); + hbc = new icc("CENTER_LABEL_MANAGEMENT_PROCESSOR", 35); + Lbc = new icc("LABEL_SIDE_SELECTOR", 36); + Bbc = new icc("HYPEREDGE_DUMMY_MERGER", 37); + wbc = new icc("HIERARCHICAL_PORT_DUMMY_SIZE_PROCESSOR", 38); + Obc = new icc("LAYER_SIZE_AND_GRAPH_HEIGHT_CALCULATOR", 39); + ybc = new icc("HIERARCHICAL_PORT_POSITION_PROCESSOR", 40); + lbc = new icc("CONSTRAINTS_POSTPROCESSOR", 41); + jbc = new icc("COMMENT_POSTPROCESSOR", 42); + Cbc = new icc("HYPERNODE_PROCESSOR", 43); + xbc = new icc("HIERARCHICAL_PORT_ORTHOGONAL_EDGE_ROUTER", 44); + Pbc = new icc("LONG_EDGE_JOINER", 45); + acc = new icc("SELF_LOOP_POSTPROCESSOR", 46); + gbc = new icc("BREAKING_POINT_REMOVER", 47); + Sbc = new icc("NORTH_SOUTH_PORT_POSTPROCESSOR", 48); + Abc = new icc("HORIZONTAL_COMPACTOR", 49); + Jbc = new icc("LABEL_DUMMY_REMOVER", 50); + tbc = new icc("FINAL_SPLINE_BENDPOINTS_CALCULATOR", 51); + rbc = new icc("END_LABEL_SORTER", 52); + $bc = new icc("REVERSED_EDGE_RESTORER", 53); + pbc = new icc("END_LABEL_POSTPROCESSOR", 54); + ubc = new icc("HIERARCHICAL_NODE_RESIZER", 55); + mbc = new icc("DIRECTION_POSTPROCESSOR", 56); + } + function Ozc() { + Ozc = geb; + Uxc = ($tc(), Ytc); + Txc = new lGd(HBe, Uxc); + jyc = new lGd(IBe, (Geb(), false)); + pyc = (Ovc(), Mvc); + oyc = new lGd(JBe, pyc); + Hyc = new lGd(KBe, false); + Iyc = new lGd(LBe, true); + ixc = new lGd(MBe, false); + azc = (sEc(), qEc); + _yc = new lGd(NBe, azc); + sgb(1); + izc = new lGd(OBe, sgb(7)); + jzc = new lGd(PBe, false); + kyc = new lGd(QBe, false); + Sxc = (Ptc(), Ltc); + Rxc = new lGd(RBe, Sxc); + Gyc = (_Cc(), ZCc); + Fyc = new lGd(SBe, Gyc); + wyc = (cxc(), bxc); + vyc = new lGd(TBe, wyc); + sgb(-1); + uyc = new lGd(UBe, null); + sgb(-1); + xyc = new lGd(VBe, sgb(-1)); + sgb(-1); + yyc = new lGd(WBe, sgb(4)); + sgb(-1); + Ayc = new lGd(XBe, sgb(2)); + Eyc = (aEc(), $Dc); + Dyc = new lGd(YBe, Eyc); + sgb(0); + Cyc = new lGd(ZBe, sgb(0)); + syc = new lGd($Be, sgb(lve)); + Qxc = (stc(), qtc); + Pxc = new lGd(_Be, Qxc); + yxc = new lGd(aCe, false); + Hxc = new lGd(bCe, 0.1); + Nxc = new lGd(cCe, false); + Jxc = new lGd(dCe, null); + Kxc = new lGd(eCe, null); + sgb(-1); + Lxc = new lGd(fCe, null); + sgb(-1); + Mxc = new lGd(gCe, sgb(-1)); + sgb(0); + zxc = new lGd(hCe, sgb(40)); + Fxc = (xvc(), wvc); + Exc = new lGd(iCe, Fxc); + Bxc = uvc; + Axc = new lGd(jCe, Bxc); + $yc = (JDc(), EDc); + Zyc = new lGd(kCe, $yc); + Pyc = new jGd(lCe); + Kyc = (Cuc(), Auc); + Jyc = new lGd(mCe, Kyc); + Nyc = (Ouc(), Luc); + Myc = new lGd(nCe, Nyc); + Syc = new lGd(oCe, 0.3); + Uyc = new jGd(pCe); + Wyc = (wDc(), uDc); + Vyc = new lGd(qCe, Wyc); + ayc = (KEc(), IEc); + _xc = new lGd(rCe, ayc); + cyc = (TEc(), SEc); + byc = new lGd(sCe, cyc); + eyc = (lFc(), kFc); + dyc = new lGd(tCe, eyc); + gyc = new lGd(uCe, 0.2); + Zxc = new lGd(vCe, 2); + ezc = new lGd(wCe, null); + gzc = new lGd(xCe, 10); + fzc = new lGd(yCe, 10); + hzc = new lGd(zCe, 20); + sgb(0); + bzc = new lGd(ACe, sgb(0)); + sgb(0); + czc = new lGd(BCe, sgb(0)); + sgb(0); + dzc = new lGd(CCe, sgb(0)); + jxc = new lGd(DCe, false); + nxc = ($uc(), Yuc); + mxc = new lGd(ECe, nxc); + lxc = (jtc(), itc); + kxc = new lGd(FCe, lxc); + myc = new lGd(GCe, false); + sgb(0); + lyc = new lGd(HCe, sgb(16)); + sgb(0); + nyc = new lGd(ICe, sgb(5)); + Gzc = (DFc(), BFc); + Fzc = new lGd(JCe, Gzc); + kzc = new lGd(KCe, 10); + nzc = new lGd(LCe, 1); + wzc = (Etc(), Dtc); + vzc = new lGd(MCe, wzc); + qzc = new jGd(NCe); + tzc = sgb(1); + sgb(0); + szc = new lGd(OCe, tzc); + Lzc = (uFc(), rFc); + Kzc = new lGd(PCe, Lzc); + Hzc = new jGd(QCe); + Bzc = new lGd(RCe, true); + zzc = new lGd(SCe, 2); + Dzc = new lGd(TCe, true); + Yxc = (tuc(), ruc); + Xxc = new lGd(UCe, Yxc); + Wxc = (btc(), Zsc); + Vxc = new lGd(VCe, Wxc); + xxc = (kEc(), hEc); + wxc = new lGd(WCe, xxc); + vxc = new lGd(XCe, false); + uxc = new lGd(YCe, false); + pxc = (U$b(), T$b); + oxc = new lGd(ZCe, pxc); + txc = (lDc(), iDc); + sxc = new lGd($Ce, txc); + qxc = new lGd(_Ce, 0); + rxc = new lGd(aDe, 0); + ryc = Ntc; + qyc = ptc; + zyc = YCc; + Byc = YCc; + tyc = TCc; + Ixc = (Fnd(), Cnd); + Oxc = qtc; + Gxc = qtc; + Cxc = qtc; + Dxc = Cnd; + Qyc = HDc; + Ryc = EDc; + Lyc = EDc; + Oyc = EDc; + Tyc = GDc; + Yyc = HDc; + Xyc = HDc; + fyc = (Ymd(), Wmd); + hyc = Wmd; + iyc = kFc; + $xc = Vmd; + lzc = CFc; + mzc = AFc; + ozc = CFc; + pzc = AFc; + xzc = CFc; + yzc = AFc; + rzc = Ctc; + uzc = Dtc; + Mzc = CFc; + Nzc = AFc; + Izc = CFc; + Jzc = AFc; + Czc = AFc; + Azc = AFc; + Ezc = AFc; + } + function iNc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5, F, G, H, I, J, K2, L, M, N, O, P, Q, R, S2, T2, U, V, W, X, Y, Z, $, ab, bb, cb, db2, eb, fb, gb, hb, ib, jb, kb, lb; + cb = 0; + for (H = b, K2 = 0, N = H.length; K2 < N; ++K2) { + F = H[K2]; + for (V = new Anb(F.j); V.a < V.c.c.length; ) { + U = RD(ynb(V), 12); + X = 0; + for (h = new Anb(U.g); h.a < h.c.c.length; ) { + g = RD(ynb(h), 18); + F.c != g.d.i.c && ++X; + } + X > 0 && (a.a[U.p] = cb++); + } + } + hb = 0; + for (I = c2, L = 0, O = I.length; L < O; ++L) { + F = I[L]; + P = 0; + for (V = new Anb(F.j); V.a < V.c.c.length; ) { + U = RD(ynb(V), 12); + if (U.j == (qpd(), Yod)) { + for (h = new Anb(U.e); h.a < h.c.c.length; ) { + g = RD(ynb(h), 18); + if (F.c != g.c.i.c) { + ++P; + break; + } + } + } else { + break; + } + } + R = 0; + Y = new Jkb(F.j, F.j.c.length); + while (Y.b > 0) { + U = (sFb(Y.b > 0), RD(Y.a.Xb(Y.c = --Y.b), 12)); + X = 0; + for (h = new Anb(U.e); h.a < h.c.c.length; ) { + g = RD(ynb(h), 18); + F.c != g.c.i.c && ++X; + } + if (X > 0) { + if (U.j == (qpd(), Yod)) { + a.a[U.p] = hb; + ++hb; + } else { + a.a[U.p] = hb + P + R; + ++R; + } + } + } + hb += R; + } + W = new Tsb(); + o2 = new Iub(); + for (G = b, J = 0, M = G.length; J < M; ++J) { + F = G[J]; + for (fb = new Anb(F.j); fb.a < fb.c.c.length; ) { + eb = RD(ynb(fb), 12); + for (h = new Anb(eb.g); h.a < h.c.c.length; ) { + g = RD(ynb(h), 18); + jb = g.d; + if (F.c != jb.i.c) { + db2 = RD(Wd(qtb(W.f, eb)), 478); + ib = RD(Wd(qtb(W.f, jb)), 478); + if (!db2 && !ib) { + n = new lNc(); + o2.a.zc(n, o2); + Rmb(n.a, g); + Rmb(n.d, eb); + rtb(W.f, eb, n); + Rmb(n.d, jb); + rtb(W.f, jb, n); + } else if (!db2) { + Rmb(ib.a, g); + Rmb(ib.d, eb); + rtb(W.f, eb, ib); + } else if (!ib) { + Rmb(db2.a, g); + Rmb(db2.d, jb); + rtb(W.f, jb, db2); + } else if (db2 == ib) { + Rmb(db2.a, g); + } else { + Rmb(db2.a, g); + for (T2 = new Anb(ib.d); T2.a < T2.c.c.length; ) { + S2 = RD(ynb(T2), 12); + rtb(W.f, S2, db2); + } + Tmb(db2.a, ib.a); + Tmb(db2.d, ib.d); + o2.a.Bc(ib) != null; + } + } + } + } + } + p = RD(Ee(o2, $C(OY, { 3: 1, 4: 1, 5: 1, 2045: 1 }, 478, o2.a.gc(), 0, 1)), 2045); + D5 = b[0].c; + bb = c2[0].c; + for (k = p, l = 0, m = k.length; l < m; ++l) { + j = k[l]; + j.e = cb; + j.f = hb; + for (V = new Anb(j.d); V.a < V.c.c.length; ) { + U = RD(ynb(V), 12); + Z = a.a[U.p]; + if (U.i.c == D5) { + Z < j.e && (j.e = Z); + Z > j.b && (j.b = Z); + } else if (U.i.c == bb) { + Z < j.f && (j.f = Z); + Z > j.c && (j.c = Z); + } + } + } + Wnb(p, 0, p.length, null); + gb = $C(kE, Pwe, 28, p.length, 15, 1); + d = $C(kE, Pwe, 28, hb + 1, 15, 1); + for (r = 0; r < p.length; r++) { + gb[r] = p[r].f; + d[gb[r]] = 1; + } + f2 = 0; + for (s = 0; s < d.length; s++) { + d[s] == 1 ? d[s] = f2 : --f2; + } + $ = 0; + for (t = 0; t < gb.length; t++) { + gb[t] += d[gb[t]]; + $ = $wnd.Math.max($, gb[t] + 1); + } + i2 = 1; + while (i2 < $) { + i2 *= 2; + } + lb = 2 * i2 - 1; + i2 -= 1; + kb = $C(kE, Pwe, 28, lb, 15, 1); + e = 0; + for (B = 0; B < gb.length; B++) { + A = gb[B] + i2; + ++kb[A]; + while (A > 0) { + A % 2 > 0 && (e += kb[A + 1]); + A = (A - 1) / 2 | 0; + ++kb[A]; + } + } + C = $C(NY, rve, 374, p.length * 2, 0, 1); + for (u = 0; u < p.length; u++) { + C[2 * u] = new oNc(p[u], p[u].e, p[u].b, (sNc(), rNc)); + C[2 * u + 1] = new oNc(p[u], p[u].b, p[u].e, qNc); + } + Wnb(C, 0, C.length, null); + Q = 0; + for (v = 0; v < C.length; v++) { + switch (C[v].d.g) { + case 0: + ++Q; + break; + case 1: + --Q; + e += Q; + } + } + ab = $C(NY, rve, 374, p.length * 2, 0, 1); + for (w2 = 0; w2 < p.length; w2++) { + ab[2 * w2] = new oNc(p[w2], p[w2].f, p[w2].c, (sNc(), rNc)); + ab[2 * w2 + 1] = new oNc(p[w2], p[w2].c, p[w2].f, qNc); + } + Wnb(ab, 0, ab.length, null); + Q = 0; + for (q = 0; q < ab.length; q++) { + switch (ab[q].d.g) { + case 0: + ++Q; + break; + case 1: + --Q; + e += Q; + } + } + return e; + } + function Vse() { + Vse = geb; + Ese = new Wse(7); + Gse = new Hte(8, 94); + new Hte(8, 64); + Hse = new Hte(8, 36); + Nse = new Hte(8, 65); + Ose = new Hte(8, 122); + Pse = new Hte(8, 90); + Sse = new Hte(8, 98); + Lse = new Hte(8, 66); + Qse = new Hte(8, 60); + Tse = new Hte(8, 62); + Dse = new Wse(11); + Bse = new xte(4); + rte(Bse, 48, 57); + Rse = new xte(4); + rte(Rse, 48, 57); + rte(Rse, 65, 90); + rte(Rse, 95, 95); + rte(Rse, 97, 122); + Mse = new xte(4); + rte(Mse, 9, 9); + rte(Mse, 10, 10); + rte(Mse, 12, 12); + rte(Mse, 13, 13); + rte(Mse, 32, 32); + Ise = yte(Bse); + Kse = yte(Rse); + Jse = yte(Mse); + wse = new Tsb(); + xse = new Tsb(); + yse = cD(WC(qJ, 1), Nve, 2, 6, ["Cn", "Lu", "Ll", "Lt", "Lm", "Lo", "Mn", "Me", "Mc", "Nd", "Nl", "No", "Zs", "Zl", "Zp", "Cc", "Cf", null, "Co", "Cs", "Pd", "Ps", "Pe", "Pc", "Po", "Sm", "Sc", "Sk", "So", "Pi", "Pf", "L", "M", "N", "Z", "C", "P", "S"]); + vse = cD(WC(qJ, 1), Nve, 2, 6, ["Basic Latin", "Latin-1 Supplement", "Latin Extended-A", "Latin Extended-B", "IPA Extensions", "Spacing Modifier Letters", "Combining Diacritical Marks", "Greek", "Cyrillic", "Armenian", "Hebrew", "Arabic", "Syriac", "Thaana", "Devanagari", "Bengali", "Gurmukhi", "Gujarati", "Oriya", "Tamil", "Telugu", "Kannada", "Malayalam", "Sinhala", "Thai", "Lao", "Tibetan", "Myanmar", "Georgian", "Hangul Jamo", "Ethiopic", "Cherokee", "Unified Canadian Aboriginal Syllabics", "Ogham", "Runic", "Khmer", "Mongolian", "Latin Extended Additional", "Greek Extended", "General Punctuation", "Superscripts and Subscripts", "Currency Symbols", "Combining Marks for Symbols", "Letterlike Symbols", "Number Forms", "Arrows", "Mathematical Operators", "Miscellaneous Technical", "Control Pictures", "Optical Character Recognition", "Enclosed Alphanumerics", "Box Drawing", "Block Elements", "Geometric Shapes", "Miscellaneous Symbols", "Dingbats", "Braille Patterns", "CJK Radicals Supplement", "Kangxi Radicals", "Ideographic Description Characters", "CJK Symbols and Punctuation", "Hiragana", "Katakana", "Bopomofo", "Hangul Compatibility Jamo", "Kanbun", "Bopomofo Extended", "Enclosed CJK Letters and Months", "CJK Compatibility", "CJK Unified Ideographs Extension A", "CJK Unified Ideographs", "Yi Syllables", "Yi Radicals", "Hangul Syllables", VLe, "CJK Compatibility Ideographs", "Alphabetic Presentation Forms", "Arabic Presentation Forms-A", "Combining Half Marks", "CJK Compatibility Forms", "Small Form Variants", "Arabic Presentation Forms-B", "Specials", "Halfwidth and Fullwidth Forms", "Old Italic", "Gothic", "Deseret", "Byzantine Musical Symbols", "Musical Symbols", "Mathematical Alphanumeric Symbols", "CJK Unified Ideographs Extension B", "CJK Compatibility Ideographs Supplement", "Tags"]); + zse = cD(WC(kE, 1), Pwe, 28, 15, [66304, 66351, 66352, 66383, 66560, 66639, 118784, 119039, 119040, 119295, 119808, 120831, 131072, 173782, 194560, 195103, 917504, 917631]); + } + function hMb() { + hMb = geb; + eMb = new kMb("OUT_T_L", 0, (EKb(), CKb), (vLb(), sLb), (ZJb(), WJb), WJb, cD(WC(bL, 1), rve, 21, 0, [ysb((dod(), _nd), cD(WC(A3, 1), jwe, 95, 0, [cod, Xnd]))])); + dMb = new kMb("OUT_T_C", 1, BKb, sLb, WJb, XJb, cD(WC(bL, 1), rve, 21, 0, [ysb(_nd, cD(WC(A3, 1), jwe, 95, 0, [cod, Wnd])), ysb(_nd, cD(WC(A3, 1), jwe, 95, 0, [cod, Wnd, Ynd]))])); + fMb = new kMb("OUT_T_R", 2, DKb, sLb, WJb, YJb, cD(WC(bL, 1), rve, 21, 0, [ysb(_nd, cD(WC(A3, 1), jwe, 95, 0, [cod, Znd]))])); + XLb = new kMb("OUT_B_L", 3, CKb, uLb, YJb, WJb, cD(WC(bL, 1), rve, 21, 0, [ysb(_nd, cD(WC(A3, 1), jwe, 95, 0, [aod, Xnd]))])); + WLb = new kMb("OUT_B_C", 4, BKb, uLb, YJb, XJb, cD(WC(bL, 1), rve, 21, 0, [ysb(_nd, cD(WC(A3, 1), jwe, 95, 0, [aod, Wnd])), ysb(_nd, cD(WC(A3, 1), jwe, 95, 0, [aod, Wnd, Ynd]))])); + YLb = new kMb("OUT_B_R", 5, DKb, uLb, YJb, YJb, cD(WC(bL, 1), rve, 21, 0, [ysb(_nd, cD(WC(A3, 1), jwe, 95, 0, [aod, Znd]))])); + _Lb = new kMb("OUT_L_T", 6, DKb, uLb, WJb, WJb, cD(WC(bL, 1), rve, 21, 0, [ysb(_nd, cD(WC(A3, 1), jwe, 95, 0, [Xnd, cod, Ynd]))])); + $Lb = new kMb("OUT_L_C", 7, DKb, tLb, XJb, WJb, cD(WC(bL, 1), rve, 21, 0, [ysb(_nd, cD(WC(A3, 1), jwe, 95, 0, [Xnd, bod])), ysb(_nd, cD(WC(A3, 1), jwe, 95, 0, [Xnd, bod, Ynd]))])); + ZLb = new kMb("OUT_L_B", 8, DKb, sLb, YJb, WJb, cD(WC(bL, 1), rve, 21, 0, [ysb(_nd, cD(WC(A3, 1), jwe, 95, 0, [Xnd, aod, Ynd]))])); + cMb = new kMb("OUT_R_T", 9, CKb, uLb, WJb, YJb, cD(WC(bL, 1), rve, 21, 0, [ysb(_nd, cD(WC(A3, 1), jwe, 95, 0, [Znd, cod, Ynd]))])); + bMb = new kMb("OUT_R_C", 10, CKb, tLb, XJb, YJb, cD(WC(bL, 1), rve, 21, 0, [ysb(_nd, cD(WC(A3, 1), jwe, 95, 0, [Znd, bod])), ysb(_nd, cD(WC(A3, 1), jwe, 95, 0, [Znd, bod, Ynd]))])); + aMb = new kMb("OUT_R_B", 11, CKb, sLb, YJb, YJb, cD(WC(bL, 1), rve, 21, 0, [ysb(_nd, cD(WC(A3, 1), jwe, 95, 0, [Znd, aod, Ynd]))])); + ULb = new kMb("IN_T_L", 12, CKb, uLb, WJb, WJb, cD(WC(bL, 1), rve, 21, 0, [ysb($nd, cD(WC(A3, 1), jwe, 95, 0, [cod, Xnd])), ysb($nd, cD(WC(A3, 1), jwe, 95, 0, [cod, Xnd, Ynd]))])); + TLb = new kMb("IN_T_C", 13, BKb, uLb, WJb, XJb, cD(WC(bL, 1), rve, 21, 0, [ysb($nd, cD(WC(A3, 1), jwe, 95, 0, [cod, Wnd])), ysb($nd, cD(WC(A3, 1), jwe, 95, 0, [cod, Wnd, Ynd]))])); + VLb = new kMb("IN_T_R", 14, DKb, uLb, WJb, YJb, cD(WC(bL, 1), rve, 21, 0, [ysb($nd, cD(WC(A3, 1), jwe, 95, 0, [cod, Znd])), ysb($nd, cD(WC(A3, 1), jwe, 95, 0, [cod, Znd, Ynd]))])); + RLb = new kMb("IN_C_L", 15, CKb, tLb, XJb, WJb, cD(WC(bL, 1), rve, 21, 0, [ysb($nd, cD(WC(A3, 1), jwe, 95, 0, [bod, Xnd])), ysb($nd, cD(WC(A3, 1), jwe, 95, 0, [bod, Xnd, Ynd]))])); + QLb = new kMb("IN_C_C", 16, BKb, tLb, XJb, XJb, cD(WC(bL, 1), rve, 21, 0, [ysb($nd, cD(WC(A3, 1), jwe, 95, 0, [bod, Wnd])), ysb($nd, cD(WC(A3, 1), jwe, 95, 0, [bod, Wnd, Ynd]))])); + SLb = new kMb("IN_C_R", 17, DKb, tLb, XJb, YJb, cD(WC(bL, 1), rve, 21, 0, [ysb($nd, cD(WC(A3, 1), jwe, 95, 0, [bod, Znd])), ysb($nd, cD(WC(A3, 1), jwe, 95, 0, [bod, Znd, Ynd]))])); + OLb = new kMb("IN_B_L", 18, CKb, sLb, YJb, WJb, cD(WC(bL, 1), rve, 21, 0, [ysb($nd, cD(WC(A3, 1), jwe, 95, 0, [aod, Xnd])), ysb($nd, cD(WC(A3, 1), jwe, 95, 0, [aod, Xnd, Ynd]))])); + NLb = new kMb("IN_B_C", 19, BKb, sLb, YJb, XJb, cD(WC(bL, 1), rve, 21, 0, [ysb($nd, cD(WC(A3, 1), jwe, 95, 0, [aod, Wnd])), ysb($nd, cD(WC(A3, 1), jwe, 95, 0, [aod, Wnd, Ynd]))])); + PLb = new kMb("IN_B_R", 20, DKb, sLb, YJb, YJb, cD(WC(bL, 1), rve, 21, 0, [ysb($nd, cD(WC(A3, 1), jwe, 95, 0, [aod, Znd])), ysb($nd, cD(WC(A3, 1), jwe, 95, 0, [aod, Znd, Ynd]))])); + gMb = new kMb(Sye, 21, null, null, null, null, cD(WC(bL, 1), rve, 21, 0, [])); + } + function JTd() { + JTd = geb; + nTd = (lTd(), kTd).b; + RD(QHd(xYd(kTd.b), 0), 35); + RD(QHd(xYd(kTd.b), 1), 19); + mTd = kTd.a; + RD(QHd(xYd(kTd.a), 0), 35); + RD(QHd(xYd(kTd.a), 1), 19); + RD(QHd(xYd(kTd.a), 2), 19); + RD(QHd(xYd(kTd.a), 3), 19); + RD(QHd(xYd(kTd.a), 4), 19); + oTd = kTd.o; + RD(QHd(xYd(kTd.o), 0), 35); + RD(QHd(xYd(kTd.o), 1), 35); + qTd = RD(QHd(xYd(kTd.o), 2), 19); + RD(QHd(xYd(kTd.o), 3), 19); + RD(QHd(xYd(kTd.o), 4), 19); + RD(QHd(xYd(kTd.o), 5), 19); + RD(QHd(xYd(kTd.o), 6), 19); + RD(QHd(xYd(kTd.o), 7), 19); + RD(QHd(xYd(kTd.o), 8), 19); + RD(QHd(xYd(kTd.o), 9), 19); + RD(QHd(xYd(kTd.o), 10), 19); + RD(QHd(xYd(kTd.o), 11), 19); + RD(QHd(xYd(kTd.o), 12), 19); + RD(QHd(xYd(kTd.o), 13), 19); + RD(QHd(xYd(kTd.o), 14), 19); + RD(QHd(xYd(kTd.o), 15), 19); + RD(QHd(uYd(kTd.o), 0), 62); + RD(QHd(uYd(kTd.o), 1), 62); + RD(QHd(uYd(kTd.o), 2), 62); + RD(QHd(uYd(kTd.o), 3), 62); + RD(QHd(uYd(kTd.o), 4), 62); + RD(QHd(uYd(kTd.o), 5), 62); + RD(QHd(uYd(kTd.o), 6), 62); + RD(QHd(uYd(kTd.o), 7), 62); + RD(QHd(uYd(kTd.o), 8), 62); + RD(QHd(uYd(kTd.o), 9), 62); + pTd = kTd.p; + RD(QHd(xYd(kTd.p), 0), 35); + RD(QHd(xYd(kTd.p), 1), 35); + RD(QHd(xYd(kTd.p), 2), 35); + RD(QHd(xYd(kTd.p), 3), 35); + RD(QHd(xYd(kTd.p), 4), 19); + RD(QHd(xYd(kTd.p), 5), 19); + RD(QHd(uYd(kTd.p), 0), 62); + RD(QHd(uYd(kTd.p), 1), 62); + rTd = kTd.q; + RD(QHd(xYd(kTd.q), 0), 35); + sTd = kTd.v; + RD(QHd(xYd(kTd.v), 0), 19); + RD(QHd(uYd(kTd.v), 0), 62); + RD(QHd(uYd(kTd.v), 1), 62); + RD(QHd(uYd(kTd.v), 2), 62); + tTd = kTd.w; + RD(QHd(xYd(kTd.w), 0), 35); + RD(QHd(xYd(kTd.w), 1), 35); + RD(QHd(xYd(kTd.w), 2), 35); + RD(QHd(xYd(kTd.w), 3), 19); + uTd = kTd.B; + RD(QHd(xYd(kTd.B), 0), 19); + RD(QHd(uYd(kTd.B), 0), 62); + RD(QHd(uYd(kTd.B), 1), 62); + RD(QHd(uYd(kTd.B), 2), 62); + xTd = kTd.Q; + RD(QHd(xYd(kTd.Q), 0), 19); + RD(QHd(uYd(kTd.Q), 0), 62); + yTd = kTd.R; + RD(QHd(xYd(kTd.R), 0), 35); + zTd = kTd.S; + RD(QHd(uYd(kTd.S), 0), 62); + RD(QHd(uYd(kTd.S), 1), 62); + RD(QHd(uYd(kTd.S), 2), 62); + RD(QHd(uYd(kTd.S), 3), 62); + RD(QHd(uYd(kTd.S), 4), 62); + RD(QHd(uYd(kTd.S), 5), 62); + RD(QHd(uYd(kTd.S), 6), 62); + RD(QHd(uYd(kTd.S), 7), 62); + RD(QHd(uYd(kTd.S), 8), 62); + RD(QHd(uYd(kTd.S), 9), 62); + RD(QHd(uYd(kTd.S), 10), 62); + RD(QHd(uYd(kTd.S), 11), 62); + RD(QHd(uYd(kTd.S), 12), 62); + RD(QHd(uYd(kTd.S), 13), 62); + RD(QHd(uYd(kTd.S), 14), 62); + ATd = kTd.T; + RD(QHd(xYd(kTd.T), 0), 19); + RD(QHd(xYd(kTd.T), 2), 19); + BTd = RD(QHd(xYd(kTd.T), 3), 19); + RD(QHd(xYd(kTd.T), 4), 19); + RD(QHd(uYd(kTd.T), 0), 62); + RD(QHd(uYd(kTd.T), 1), 62); + RD(QHd(xYd(kTd.T), 1), 19); + CTd = kTd.U; + RD(QHd(xYd(kTd.U), 0), 35); + RD(QHd(xYd(kTd.U), 1), 35); + RD(QHd(xYd(kTd.U), 2), 19); + RD(QHd(xYd(kTd.U), 3), 19); + RD(QHd(xYd(kTd.U), 4), 19); + RD(QHd(xYd(kTd.U), 5), 19); + RD(QHd(uYd(kTd.U), 0), 62); + DTd = kTd.V; + RD(QHd(xYd(kTd.V), 0), 19); + ETd = kTd.W; + RD(QHd(xYd(kTd.W), 0), 35); + RD(QHd(xYd(kTd.W), 1), 35); + RD(QHd(xYd(kTd.W), 2), 35); + RD(QHd(xYd(kTd.W), 3), 19); + RD(QHd(xYd(kTd.W), 4), 19); + RD(QHd(xYd(kTd.W), 5), 19); + GTd = kTd.bb; + RD(QHd(xYd(kTd.bb), 0), 35); + RD(QHd(xYd(kTd.bb), 1), 35); + RD(QHd(xYd(kTd.bb), 2), 35); + RD(QHd(xYd(kTd.bb), 3), 35); + RD(QHd(xYd(kTd.bb), 4), 35); + RD(QHd(xYd(kTd.bb), 5), 35); + RD(QHd(xYd(kTd.bb), 6), 35); + RD(QHd(xYd(kTd.bb), 7), 19); + RD(QHd(uYd(kTd.bb), 0), 62); + RD(QHd(uYd(kTd.bb), 1), 62); + HTd = kTd.eb; + RD(QHd(xYd(kTd.eb), 0), 35); + RD(QHd(xYd(kTd.eb), 1), 35); + RD(QHd(xYd(kTd.eb), 2), 35); + RD(QHd(xYd(kTd.eb), 3), 35); + RD(QHd(xYd(kTd.eb), 4), 35); + RD(QHd(xYd(kTd.eb), 5), 35); + RD(QHd(xYd(kTd.eb), 6), 19); + RD(QHd(xYd(kTd.eb), 7), 19); + FTd = kTd.ab; + RD(QHd(xYd(kTd.ab), 0), 35); + RD(QHd(xYd(kTd.ab), 1), 35); + vTd = kTd.H; + RD(QHd(xYd(kTd.H), 0), 19); + RD(QHd(xYd(kTd.H), 1), 19); + RD(QHd(xYd(kTd.H), 2), 19); + RD(QHd(xYd(kTd.H), 3), 19); + RD(QHd(xYd(kTd.H), 4), 19); + RD(QHd(xYd(kTd.H), 5), 19); + RD(QHd(uYd(kTd.H), 0), 62); + ITd = kTd.db; + RD(QHd(xYd(kTd.db), 0), 19); + wTd = kTd.M; + } + function Ane(a) { + var b; + if (a.O) + return; + a.O = true; + PAd(a, "type"); + CBd(a, "ecore.xml.type"); + DBd(a, dLe); + b = RD(N5d((YSd(), XSd), dLe), 2044); + WGd(zYd(a.fb), a.b); + vBd(a.b, Vbb, "AnyType", false, false, true); + tBd(RD(QHd(xYd(a.b), 0), 35), a.wb.D, pKe, null, 0, -1, Vbb, false, false, true, false, false, false); + tBd(RD(QHd(xYd(a.b), 1), 35), a.wb.D, "any", null, 0, -1, Vbb, true, true, true, false, false, true); + tBd(RD(QHd(xYd(a.b), 2), 35), a.wb.D, "anyAttribute", null, 0, -1, Vbb, false, false, true, false, false, false); + vBd(a.bb, Xbb, iLe, false, false, true); + tBd(RD(QHd(xYd(a.bb), 0), 35), a.gb, "data", null, 0, 1, Xbb, false, false, true, false, true, false); + tBd(RD(QHd(xYd(a.bb), 1), 35), a.gb, CIe, null, 1, 1, Xbb, false, false, true, false, true, false); + vBd(a.fb, Ybb, jLe, false, false, true); + tBd(RD(QHd(xYd(a.fb), 0), 35), b.gb, "rawValue", null, 0, 1, Ybb, true, true, true, false, true, true); + tBd(RD(QHd(xYd(a.fb), 1), 35), b.a, aIe, null, 0, 1, Ybb, true, true, true, false, true, true); + zBd(RD(QHd(xYd(a.fb), 2), 19), a.wb.q, null, "instanceType", 1, 1, Ybb, false, false, true, false, false, false, false); + vBd(a.qb, Zbb, kLe, false, false, true); + tBd(RD(QHd(xYd(a.qb), 0), 35), a.wb.D, pKe, null, 0, -1, null, false, false, true, false, false, false); + zBd(RD(QHd(xYd(a.qb), 1), 19), a.wb.ab, null, "xMLNSPrefixMap", 0, -1, null, true, false, true, true, false, false, false); + zBd(RD(QHd(xYd(a.qb), 2), 19), a.wb.ab, null, "xSISchemaLocation", 0, -1, null, true, false, true, true, false, false, false); + tBd(RD(QHd(xYd(a.qb), 3), 35), a.gb, "cDATA", null, 0, -2, null, true, true, true, false, false, true); + tBd(RD(QHd(xYd(a.qb), 4), 35), a.gb, "comment", null, 0, -2, null, true, true, true, false, false, true); + zBd(RD(QHd(xYd(a.qb), 5), 19), a.bb, null, KLe, 0, -2, null, true, true, true, true, false, false, true); + tBd(RD(QHd(xYd(a.qb), 6), 35), a.gb, hIe, null, 0, -2, null, true, true, true, false, false, true); + xBd(a.a, jJ, "AnySimpleType", true); + xBd(a.c, qJ, "AnyURI", true); + xBd(a.d, WC(gE, 1), "Base64Binary", true); + xBd(a.e, xdb, "Boolean", true); + xBd(a.f, QI, "BooleanObject", true); + xBd(a.g, gE, "Byte", true); + xBd(a.i, RI, "ByteObject", true); + xBd(a.j, qJ, "Date", true); + xBd(a.k, qJ, "DateTime", true); + xBd(a.n, tJ, "Decimal", true); + xBd(a.o, iE, "Double", true); + xBd(a.p, VI, "DoubleObject", true); + xBd(a.q, qJ, "Duration", true); + xBd(a.s, QK, "ENTITIES", true); + xBd(a.r, QK, "ENTITIESBase", true); + xBd(a.t, qJ, qLe, true); + xBd(a.u, jE, "Float", true); + xBd(a.v, ZI, "FloatObject", true); + xBd(a.w, qJ, "GDay", true); + xBd(a.B, qJ, "GMonth", true); + xBd(a.A, qJ, "GMonthDay", true); + xBd(a.C, qJ, "GYear", true); + xBd(a.D, qJ, "GYearMonth", true); + xBd(a.F, WC(gE, 1), "HexBinary", true); + xBd(a.G, qJ, "ID", true); + xBd(a.H, qJ, "IDREF", true); + xBd(a.J, QK, "IDREFS", true); + xBd(a.I, QK, "IDREFSBase", true); + xBd(a.K, kE, "Int", true); + xBd(a.M, uJ, "Integer", true); + xBd(a.L, bJ, "IntObject", true); + xBd(a.P, qJ, "Language", true); + xBd(a.Q, lE, "Long", true); + xBd(a.R, eJ, "LongObject", true); + xBd(a.S, qJ, "Name", true); + xBd(a.T, qJ, rLe, true); + xBd(a.U, uJ, "NegativeInteger", true); + xBd(a.V, qJ, BLe, true); + xBd(a.X, QK, "NMTOKENS", true); + xBd(a.W, QK, "NMTOKENSBase", true); + xBd(a.Y, uJ, "NonNegativeInteger", true); + xBd(a.Z, uJ, "NonPositiveInteger", true); + xBd(a.$, qJ, "NormalizedString", true); + xBd(a._, qJ, "NOTATION", true); + xBd(a.ab, qJ, "PositiveInteger", true); + xBd(a.cb, qJ, "QName", true); + xBd(a.db, wdb, "Short", true); + xBd(a.eb, lJ, "ShortObject", true); + xBd(a.gb, qJ, uwe, true); + xBd(a.hb, qJ, "Time", true); + xBd(a.ib, qJ, "Token", true); + xBd(a.jb, wdb, "UnsignedByte", true); + xBd(a.kb, lJ, "UnsignedByteObject", true); + xBd(a.lb, lE, "UnsignedInt", true); + xBd(a.mb, eJ, "UnsignedIntObject", true); + xBd(a.nb, uJ, "UnsignedLong", true); + xBd(a.ob, kE, "UnsignedShort", true); + xBd(a.pb, bJ, "UnsignedShortObject", true); + pBd(a, dLe); + yne(a); + } + function Fed(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5, F, G, H, I, J, K2, L, M, N, O, P, Q, R, S2, T2, U, V, W, X, Y, Z, $, ab; + if (d.$g()) { + return yob(), yob(), vob; + } + if (Heb(TD(Gxd(b, (umd(), rld))))) { + return yob(), yob(), vob; + } + A = (!b.a && (b.a = new C5d(J4, b, 10, 11)), b.a).i != 0; + C = Ded(b); + B = !C.dc(); + if (A || B) { + e = RD(Gxd(b, Tld), 143); + if (!e) { + throw Adb(new Jed("Resolved algorithm is not set; apply a LayoutAlgorithmResolver before computing layout.")); + } + Y = Ofd(e, (aGd(), YFd)); + Bed(b); + if (!A && B && !Y) { + return yob(), yob(), vob; + } + t = new bnb(); + if (dE(Gxd(b, Xkd)) === dE((Fnd(), Cnd)) && (Ofd(e, VFd) || Ofd(e, UFd))) { + if (Heb(TD(Gxd(b, mmd)))) { + throw Adb(new Jed("Topdown layout cannot be used together with hierarchy handling.")); + } + M = Aed(a, b); + N = new Yub(); + ye(N, (!b.a && (b.a = new C5d(J4, b, 10, 11)), b.a)); + while (N.b != 0) { + K2 = RD(N.b == 0 ? null : (sFb(N.b != 0), Wub(N, N.a.a)), 27); + Bed(K2); + X = dE(Gxd(K2, Xkd)) === dE(End); + if (X || Hxd(K2, Akd) && !Nfd(e, Gxd(K2, Tld))) { + q = Fed(a, K2, c2, d); + Tmb(t, q); + Ixd(K2, Xkd, End); + ksd(K2); + } else { + ye(N, (!K2.a && (K2.a = new C5d(J4, K2, 10, 11)), K2.a)); + } + } + } else { + M = (!b.a && (b.a = new C5d(J4, b, 10, 11)), b.a).i; + if (Heb(TD(Gxd(b, mmd)))) { + Z = d.eh(1); + Z.Ug(yGe, 1); + if (Gxd(b, nmd) == null) { + throw Adb(new Jed(b.k + " has not been assigned a top-down node type.")); + } + if (RD(Gxd(b, nmd), 280) == (mqd(), jqd) || RD(Gxd(b, nmd), 280) == lqd) { + for (s = new dMd((!b.a && (b.a = new C5d(J4, b, 10, 11)), b.a)); s.e != s.i.gc(); ) { + r = RD(bMd(s), 27); + J = RD(Gxd(r, Tld), 143); + if ((!r.a && (r.a = new C5d(J4, r, 10, 11)), r.a).i > 0 && (ltd(J.f), false)) { + if (RD(Gxd(r, nmd), 280) == jqd) { + throw Adb(new Jed("Topdown Layout Providers should only be used on parallel nodes.")); + } + fE(ltd(J.f)); + null.Um(); + zyd(r, $wnd.Math.max(r.g, null.Vm), $wnd.Math.max(r.f, null.Vm)); + } else if (Gxd(r, smd) != null) { + h = RD(Gxd(r, smd), 347); + W = h.Tg(r); + zyd(r, $wnd.Math.max(r.g, W.a), $wnd.Math.max(r.f, W.b)); + } + } + } + O = RD(Gxd(b, tld), 107); + n = b.g - (O.b + O.c); + m = b.f - (O.d + O.a); + Z.bh("Available Child Area: (" + n + "|" + m + ")"); + Ixd(b, Dkd, n / m); + Ced(b, e, d.eh(M)); + if (RD(Gxd(b, nmd), 280) == lqd) { + psd(b); + zyd(b, O.b + Kfb(UD(Gxd(b, Ikd))) + O.c, O.d + Kfb(UD(Gxd(b, Hkd))) + O.a); + } + Z.bh("Executed layout algorithm: " + WD(Gxd(b, Akd)) + " on node " + b.k); + if (RD(Gxd(b, nmd), 280) == jqd) { + if (n < 0 || m < 0) { + throw Adb(new Jed("The size defined by the parent parallel node is too small for the space provided by the paddings of the child hierarchical node. " + b.k)); + } + Hxd(b, Ikd) || Hxd(b, Hkd) || psd(b); + p = Kfb(UD(Gxd(b, Ikd))); + o2 = Kfb(UD(Gxd(b, Hkd))); + Z.bh("Desired Child Area: (" + p + "|" + o2 + ")"); + Q = n / p; + R = m / o2; + P = $wnd.Math.min(Q, $wnd.Math.min(R, Kfb(UD(Gxd(b, omd))))); + Ixd(b, qmd, P); + Z.bh(b.k + " -- Local Scale Factor (X|Y): (" + Q + "|" + R + ")"); + u = RD(Gxd(b, Kkd), 21); + f2 = 0; + g = 0; + P < Q && (u.Hc((ukd(), okd)) ? f2 = (n / 2 - p * P / 2) / P : u.Hc(qkd) && (f2 = (n - p * P) / P)); + P < R && (u.Hc((ukd(), skd)) ? g = (m / 2 - o2 * P / 2) / P : u.Hc(rkd) && (g = (m - o2 * P) / P)); + $ = f2 + (O.b / P - O.b); + ab = g + (O.d / P - O.d); + Z.bh("Shift: (" + $ + "|" + ab + ")"); + for (L = new dMd((!b.a && (b.a = new C5d(J4, b, 10, 11)), b.a)); L.e != L.i.gc(); ) { + K2 = RD(bMd(L), 27); + Dyd(K2, K2.i + $); + Eyd(K2, K2.j + ab); + } + for (w2 = new dMd((!b.b && (b.b = new C5d(G4, b, 12, 3)), b.b)); w2.e != w2.i.gc(); ) { + v = RD(bMd(w2), 74); + for (T2 = new dMd((!v.a && (v.a = new C5d(F4, v, 6, 6)), v.a)); T2.e != T2.i.gc(); ) { + S2 = RD(bMd(T2), 166); + Nzd(S2, S2.j + $, S2.k + ab); + Gzd(S2, S2.b + $, S2.c + ab); + for (j = new dMd((!S2.a && (S2.a = new XZd(D4, S2, 5)), S2.a)); j.e != j.i.gc(); ) { + i2 = RD(bMd(j), 377); + Uxd(i2, i2.a + $, i2.b + ab); + } + } + for (I = new dMd((!v.n && (v.n = new C5d(I4, v, 1, 7)), v.n)); I.e != I.i.gc(); ) { + H = RD(bMd(I), 135); + Byd(H, H.i + $, H.j + ab); + } + G = RD(Gxd(v, cld), 75); + for (F = Sub(G, 0); F.b != F.d.c; ) { + D5 = RD(evb(F), 8); + D5.a += $; + D5.b += ab; + } + Ixd(v, cld, G); + } + } + Z.Vg(); + } + for (l = new dMd((!b.a && (b.a = new C5d(J4, b, 10, 11)), b.a)); l.e != l.i.gc(); ) { + k = RD(bMd(l), 27); + q = Fed(a, k, c2, d); + Tmb(t, q); + ksd(k); + } + } + if (d.$g()) { + return yob(), yob(), vob; + } + for (V = new Anb(t); V.a < V.c.c.length; ) { + U = RD(ynb(V), 74); + Ixd(U, rld, (Geb(), true)); + } + Heb(TD(Gxd(b, mmd))) || Ced(b, e, d.eh(M)); + Ged(t); + return B && Y ? C : (yob(), yob(), vob); + } else { + return yob(), yob(), vob; + } + } + function Jre(a, b) { + var c2, d; + if (!Bre) { + Bre = new Tsb(); + Cre = new Tsb(); + d = (Vse(), Vse(), new xte(4)); + ose(d, " \n\r\r "); + $jb(Bre, QLe, d); + $jb(Cre, QLe, yte(d)); + d = new xte(4); + ose(d, TLe); + $jb(Bre, OLe, d); + $jb(Cre, OLe, yte(d)); + d = new xte(4); + ose(d, TLe); + $jb(Bre, OLe, d); + $jb(Cre, OLe, yte(d)); + d = new xte(4); + ose(d, ULe); + ute(d, RD(Xjb(Bre, OLe), 122)); + $jb(Bre, PLe, d); + $jb(Cre, PLe, yte(d)); + d = new xte(4); + ose(d, "-.0:AZ__az··ÀÖØöøıĴľŁňŊžƀǃǍǰǴǵǺȗɐʨʻˁːˑ̀͠͡ͅΆΊΌΌΎΡΣώϐϖϚϚϜϜϞϞϠϠϢϳЁЌЎяёќўҁ҃҆ҐӄӇӈӋӌӐӫӮӵӸӹԱՖՙՙաֆֹֻֽֿֿׁׂ֑֣֡ׄׄאתװײءغـْ٠٩ٰڷںھۀێېۓە۪ۭۨ۰۹ँःअह़्॑॔क़ॣ०९ঁঃঅঌএঐওনপরললশহ়়াৄেৈো্ৗৗড়ঢ়য়ৣ০ৱਂਂਅਊਏਐਓਨਪਰਲਲ਼ਵਸ਼ਸਹ਼਼ਾੂੇੈੋ੍ਖ਼ੜਫ਼ਫ਼੦ੴઁઃઅઋઍઍએઑઓનપરલળવહ઼ૅેૉો્ૠૠ૦૯ଁଃଅଌଏଐଓନପରଲଳଶହ଼ୃେୈୋ୍ୖୗଡ଼ଢ଼ୟୡ୦୯ஂஃஅஊஎஐஒகஙசஜஜஞடணதநபமவஷஹாூெைொ்ௗௗ௧௯ఁఃఅఌఎఐఒనపళవహాౄెైొ్ౕౖౠౡ౦౯ಂಃಅಌಎಐಒನಪಳವಹಾೄೆೈೊ್ೕೖೞೞೠೡ೦೯ംഃഅഌഎഐഒനപഹാൃെൈൊ്ൗൗൠൡ൦൯กฮะฺเ๎๐๙ກຂຄຄງຈຊຊຍຍດທນຟມຣລລວວສຫອຮະູົຽເໄໆໆ່ໍ໐໙༘༙༠༩༹༹༵༵༷༷༾ཇཉཀྵ྄ཱ྆ྋྐྕྗྗྙྭྱྷྐྵྐྵႠჅაჶᄀᄀᄂᄃᄅᄇᄉᄉᄋᄌᄎᄒᄼᄼᄾᄾᅀᅀᅌᅌᅎᅎᅐᅐᅔᅕᅙᅙᅟᅡᅣᅣᅥᅥᅧᅧᅩᅩᅭᅮᅲᅳᅵᅵᆞᆞᆨᆨᆫᆫᆮᆯᆷᆸᆺᆺᆼᇂᇫᇫᇰᇰᇹᇹḀẛẠỹἀἕἘἝἠὅὈὍὐὗὙὙὛὛὝὝὟώᾀᾴᾶᾼιιῂῄῆῌῐΐῖΊῠῬῲῴῶῼ⃐⃜⃡⃡ΩΩKÅ℮℮ↀↂ々々〇〇〡〯〱〵ぁゔ゙゚ゝゞァヺーヾㄅㄬ一龥가힣"); + $jb(Bre, RLe, d); + $jb(Cre, RLe, yte(d)); + d = new xte(4); + ose(d, ULe); + rte(d, 95, 95); + rte(d, 58, 58); + $jb(Bre, SLe, d); + $jb(Cre, SLe, yte(d)); + } + c2 = b ? RD(Xjb(Bre, a), 138) : RD(Xjb(Cre, a), 138); + return c2; + } + function zCc(a) { + Cgd(a, new Pfd(_fd(Wfd($fd(Xfd(Zfd(Yfd(new agd(), sxe), "ELK Layered"), "Layer-based algorithm provided by the Eclipse Layout Kernel. Arranges as many edges as possible into one direction by placing nodes into subsequent layers. This implementation supports different routing styles (straight, orthogonal, splines); if orthogonal routing is selected, arbitrary port constraints are respected, thus enabling the layout of block diagrams such as actor-oriented models or circuit schematics. Furthermore, full layout of compound graphs with cross-hierarchy edges is supported when the respective option is activated on the top level."), new CCc()), sxe), ysb((aGd(), _Fd), cD(WC(T5, 1), jwe, 245, 0, [YFd, ZFd, XFd, $Fd, VFd, UFd]))))); + Agd(a, sxe, xDe, iGd(QBc)); + Agd(a, sxe, yDe, iGd(RBc)); + Agd(a, sxe, Bze, iGd(SBc)); + Agd(a, sxe, zDe, iGd(TBc)); + Agd(a, sxe, aAe, iGd(VBc)); + Agd(a, sxe, ADe, iGd(WBc)); + Agd(a, sxe, BDe, iGd(ZBc)); + Agd(a, sxe, CDe, iGd(_Bc)); + Agd(a, sxe, DDe, iGd(aCc)); + Agd(a, sxe, EDe, iGd($Bc)); + Agd(a, sxe, _ze, iGd(bCc)); + Agd(a, sxe, FDe, iGd(dCc)); + Agd(a, sxe, GDe, iGd(fCc)); + Agd(a, sxe, HDe, iGd(YBc)); + Agd(a, sxe, wCe, iGd(PBc)); + Agd(a, sxe, yCe, iGd(UBc)); + Agd(a, sxe, xCe, iGd(XBc)); + Agd(a, sxe, zCe, iGd(cCc)); + Agd(a, sxe, $ze, sgb(0)); + Agd(a, sxe, ACe, iGd(KBc)); + Agd(a, sxe, BCe, iGd(LBc)); + Agd(a, sxe, CCe, iGd(MBc)); + Agd(a, sxe, JCe, iGd(vCc)); + Agd(a, sxe, KCe, iGd(nCc)); + Agd(a, sxe, LCe, iGd(oCc)); + Agd(a, sxe, MCe, iGd(rCc)); + Agd(a, sxe, NCe, iGd(pCc)); + Agd(a, sxe, OCe, iGd(qCc)); + Agd(a, sxe, PCe, iGd(xCc)); + Agd(a, sxe, QCe, iGd(wCc)); + Agd(a, sxe, RCe, iGd(tCc)); + Agd(a, sxe, SCe, iGd(sCc)); + Agd(a, sxe, TCe, iGd(uCc)); + Agd(a, sxe, pCe, iGd(iBc)); + Agd(a, sxe, qCe, iGd(jBc)); + Agd(a, sxe, tCe, iGd(DAc)); + Agd(a, sxe, uCe, iGd(EAc)); + Agd(a, sxe, mAe, iGd(jCc)); + Agd(a, sxe, nAe, iGd(lCc)); + Agd(a, sxe, oAe, iGd(iCc)); + Agd(a, sxe, pAe, iGd(hCc)); + Agd(a, sxe, qAe, kCc); + Agd(a, sxe, Eze, rBc); + Agd(a, sxe, kDe, zAc); + Agd(a, sxe, IDe, 0); + Agd(a, sxe, bAe, sgb(1)); + Agd(a, sxe, Dze, Yze); + Agd(a, sxe, JDe, iGd(pBc)); + Agd(a, sxe, eAe, iGd(BBc)); + Agd(a, sxe, KDe, iGd(GBc)); + Agd(a, sxe, LDe, iGd(qAc)); + Agd(a, sxe, MDe, iGd(Rzc)); + Agd(a, sxe, fDe, iGd(IAc)); + Agd(a, sxe, cAe, (Geb(), true)); + Agd(a, sxe, NDe, iGd(NAc)); + Agd(a, sxe, ODe, iGd(OAc)); + Agd(a, sxe, jAe, iGd(lBc)); + Agd(a, sxe, iAe, iGd(oBc)); + Agd(a, sxe, hAe, iGd(mBc)); + Agd(a, sxe, PDe, tAc); + Agd(a, sxe, kAe, iGd(dBc)); + Agd(a, sxe, QDe, iGd(cBc)); + Agd(a, sxe, lAe, iGd(EBc)); + Agd(a, sxe, RDe, iGd(DBc)); + Agd(a, sxe, SDe, iGd(FBc)); + Agd(a, sxe, TDe, uBc); + Agd(a, sxe, UDe, iGd(wBc)); + Agd(a, sxe, VDe, iGd(xBc)); + Agd(a, sxe, WDe, iGd(yBc)); + Agd(a, sxe, XDe, iGd(vBc)); + Agd(a, sxe, PBe, iGd(mCc)); + Agd(a, sxe, SBe, iGd($Ac)); + Agd(a, sxe, YBe, iGd(ZAc)); + Agd(a, sxe, OBe, iGd(gCc)); + Agd(a, sxe, TBe, iGd(UAc)); + Agd(a, sxe, RBe, iGd(pAc)); + Agd(a, sxe, _Be, iGd(oAc)); + Agd(a, sxe, aCe, iGd(eAc)); + Agd(a, sxe, hCe, iGd(fAc)); + Agd(a, sxe, iCe, iGd(hAc)); + Agd(a, sxe, jCe, iGd(gAc)); + Agd(a, sxe, cCe, iGd(nAc)); + Agd(a, sxe, KBe, iGd(aBc)); + Agd(a, sxe, LBe, iGd(bBc)); + Agd(a, sxe, JBe, iGd(QAc)); + Agd(a, sxe, kCe, iGd(kBc)); + Agd(a, sxe, nCe, iGd(fBc)); + Agd(a, sxe, IBe, iGd(GAc)); + Agd(a, sxe, oCe, iGd(hBc)); + Agd(a, sxe, rCe, iGd(BAc)); + Agd(a, sxe, sCe, iGd(CAc)); + Agd(a, sxe, YDe, iGd(dAc)); + Agd(a, sxe, mCe, iGd(eBc)); + Agd(a, sxe, ECe, iGd(Xzc)); + Agd(a, sxe, FCe, iGd(Wzc)); + Agd(a, sxe, DCe, iGd(Vzc)); + Agd(a, sxe, GCe, iGd(KAc)); + Agd(a, sxe, HCe, iGd(JAc)); + Agd(a, sxe, ICe, iGd(LAc)); + Agd(a, sxe, CAe, iGd(nBc)); + Agd(a, sxe, ZDe, iGd(RAc)); + Agd(a, sxe, Cze, iGd(FAc)); + Agd(a, sxe, $De, iGd(wAc)); + Agd(a, sxe, fAe, iGd(vAc)); + Agd(a, sxe, bCe, iGd(iAc)); + Agd(a, sxe, _De, iGd(CBc)); + Agd(a, sxe, aEe, iGd(Uzc)); + Agd(a, sxe, bEe, iGd(MAc)); + Agd(a, sxe, cEe, iGd(zBc)); + Agd(a, sxe, dEe, iGd(sBc)); + Agd(a, sxe, eEe, iGd(tBc)); + Agd(a, sxe, WBe, iGd(WAc)); + Agd(a, sxe, XBe, iGd(XAc)); + Agd(a, sxe, fEe, iGd(IBc)); + Agd(a, sxe, MBe, iGd(Szc)); + Agd(a, sxe, ZBe, iGd(YAc)); + Agd(a, sxe, UCe, iGd(xAc)); + Agd(a, sxe, VCe, iGd(uAc)); + Agd(a, sxe, gEe, iGd(_Ac)); + Agd(a, sxe, $Be, iGd(SAc)); + Agd(a, sxe, lCe, iGd(gBc)); + Agd(a, sxe, hEe, iGd(eCc)); + Agd(a, sxe, HBe, iGd(sAc)); + Agd(a, sxe, NBe, iGd(HBc)); + Agd(a, sxe, vCe, iGd(AAc)); + Agd(a, sxe, dCe, iGd(jAc)); + Agd(a, sxe, eCe, iGd(kAc)); + Agd(a, sxe, UBe, iGd(TAc)); + Agd(a, sxe, fCe, iGd(lAc)); + Agd(a, sxe, iEe, iGd(PAc)); + Agd(a, sxe, VBe, iGd(VAc)); + Agd(a, sxe, gCe, iGd(mAc)); + Agd(a, sxe, WCe, iGd(cAc)); + Agd(a, sxe, $Ce, iGd(_zc)); + Agd(a, sxe, _Ce, iGd(Zzc)); + Agd(a, sxe, aDe, iGd($zc)); + Agd(a, sxe, YCe, iGd(aAc)); + Agd(a, sxe, ZCe, iGd(Yzc)); + Agd(a, sxe, XCe, iGd(bAc)); + Agd(a, sxe, QBe, iGd(HAc)); + } + function yne(a) { + _Ad(a.a, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "anySimpleType"])); + _Ad(a.b, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "anyType", rKe, pKe])); + _Ad(RD(QHd(xYd(a.b), 0), 35), qKe, cD(WC(qJ, 1), Nve, 2, 6, [rKe, YKe, GIe, ":mixed"])); + _Ad(RD(QHd(xYd(a.b), 1), 35), qKe, cD(WC(qJ, 1), Nve, 2, 6, [rKe, YKe, cLe, eLe, GIe, ":1", nLe, "lax"])); + _Ad(RD(QHd(xYd(a.b), 2), 35), qKe, cD(WC(qJ, 1), Nve, 2, 6, [rKe, WKe, cLe, eLe, GIe, ":2", nLe, "lax"])); + _Ad(a.c, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "anyURI", bLe, ZKe])); + _Ad(a.d, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "base64Binary", bLe, ZKe])); + _Ad(a.e, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, hve, bLe, ZKe])); + _Ad(a.f, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "boolean:Object", DKe, hve])); + _Ad(a.g, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, dKe])); + _Ad(a.i, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "byte:Object", DKe, dKe])); + _Ad(a.j, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "date", bLe, ZKe])); + _Ad(a.k, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "dateTime", bLe, ZKe])); + _Ad(a.n, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "decimal", bLe, ZKe])); + _Ad(a.o, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, fKe, bLe, ZKe])); + _Ad(a.p, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "double:Object", DKe, fKe])); + _Ad(a.q, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "duration", bLe, ZKe])); + _Ad(a.s, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "ENTITIES", DKe, oLe, pLe, "1"])); + _Ad(a.r, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, oLe, $Ke, qLe])); + _Ad(a.t, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, qLe, DKe, rLe])); + _Ad(a.u, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, gKe, bLe, ZKe])); + _Ad(a.v, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "float:Object", DKe, gKe])); + _Ad(a.w, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "gDay", bLe, ZKe])); + _Ad(a.B, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "gMonth", bLe, ZKe])); + _Ad(a.A, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "gMonthDay", bLe, ZKe])); + _Ad(a.C, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "gYear", bLe, ZKe])); + _Ad(a.D, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "gYearMonth", bLe, ZKe])); + _Ad(a.F, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "hexBinary", bLe, ZKe])); + _Ad(a.G, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "ID", DKe, rLe])); + _Ad(a.H, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "IDREF", DKe, rLe])); + _Ad(a.J, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "IDREFS", DKe, sLe, pLe, "1"])); + _Ad(a.I, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, sLe, $Ke, "IDREF"])); + _Ad(a.K, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, hKe])); + _Ad(a.M, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, tLe])); + _Ad(a.L, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "int:Object", DKe, hKe])); + _Ad(a.P, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "language", DKe, uLe, vLe, wLe])); + _Ad(a.Q, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, iKe])); + _Ad(a.R, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "long:Object", DKe, iKe])); + _Ad(a.S, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "Name", DKe, uLe, vLe, xLe])); + _Ad(a.T, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, rLe, DKe, "Name", vLe, yLe])); + _Ad(a.U, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "negativeInteger", DKe, zLe, ALe, "-1"])); + _Ad(a.V, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, BLe, DKe, uLe, vLe, "\\c+"])); + _Ad(a.X, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "NMTOKENS", DKe, CLe, pLe, "1"])); + _Ad(a.W, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, CLe, $Ke, BLe])); + _Ad(a.Y, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, DLe, DKe, tLe, ELe, "0"])); + _Ad(a.Z, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, zLe, DKe, tLe, ALe, "0"])); + _Ad(a.$, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, FLe, DKe, jve, bLe, "replace"])); + _Ad(a._, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "NOTATION", bLe, ZKe])); + _Ad(a.ab, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "positiveInteger", DKe, DLe, ELe, "1"])); + _Ad(a.bb, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "processingInstruction_._type", rKe, "empty"])); + _Ad(RD(QHd(xYd(a.bb), 0), 35), qKe, cD(WC(qJ, 1), Nve, 2, 6, [rKe, VKe, GIe, "data"])); + _Ad(RD(QHd(xYd(a.bb), 1), 35), qKe, cD(WC(qJ, 1), Nve, 2, 6, [rKe, VKe, GIe, CIe])); + _Ad(a.cb, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "QName", bLe, ZKe])); + _Ad(a.db, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, jKe])); + _Ad(a.eb, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "short:Object", DKe, jKe])); + _Ad(a.fb, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "simpleAnyType", rKe, UKe])); + _Ad(RD(QHd(xYd(a.fb), 0), 35), qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, ":3", rKe, UKe])); + _Ad(RD(QHd(xYd(a.fb), 1), 35), qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, ":4", rKe, UKe])); + _Ad(RD(QHd(xYd(a.fb), 2), 19), qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, ":5", rKe, UKe])); + _Ad(a.gb, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, jve, bLe, "preserve"])); + _Ad(a.hb, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "time", bLe, ZKe])); + _Ad(a.ib, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, uLe, DKe, FLe, bLe, ZKe])); + _Ad(a.jb, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, GLe, ALe, "255", ELe, "0"])); + _Ad(a.kb, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "unsignedByte:Object", DKe, GLe])); + _Ad(a.lb, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, HLe, ALe, "4294967295", ELe, "0"])); + _Ad(a.mb, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "unsignedInt:Object", DKe, HLe])); + _Ad(a.nb, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "unsignedLong", DKe, DLe, ALe, ILe, ELe, "0"])); + _Ad(a.ob, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, JLe, ALe, "65535", ELe, "0"])); + _Ad(a.pb, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "unsignedShort:Object", DKe, JLe])); + _Ad(a.qb, qKe, cD(WC(qJ, 1), Nve, 2, 6, [GIe, "", rKe, pKe])); + _Ad(RD(QHd(xYd(a.qb), 0), 35), qKe, cD(WC(qJ, 1), Nve, 2, 6, [rKe, YKe, GIe, ":mixed"])); + _Ad(RD(QHd(xYd(a.qb), 1), 19), qKe, cD(WC(qJ, 1), Nve, 2, 6, [rKe, VKe, GIe, "xmlns:prefix"])); + _Ad(RD(QHd(xYd(a.qb), 2), 19), qKe, cD(WC(qJ, 1), Nve, 2, 6, [rKe, VKe, GIe, "xsi:schemaLocation"])); + _Ad(RD(QHd(xYd(a.qb), 3), 35), qKe, cD(WC(qJ, 1), Nve, 2, 6, [rKe, XKe, GIe, "cDATA", _Ke, aLe])); + _Ad(RD(QHd(xYd(a.qb), 4), 35), qKe, cD(WC(qJ, 1), Nve, 2, 6, [rKe, XKe, GIe, "comment", _Ke, aLe])); + _Ad(RD(QHd(xYd(a.qb), 5), 19), qKe, cD(WC(qJ, 1), Nve, 2, 6, [rKe, XKe, GIe, KLe, _Ke, aLe])); + _Ad(RD(QHd(xYd(a.qb), 6), 35), qKe, cD(WC(qJ, 1), Nve, 2, 6, [rKe, XKe, GIe, hIe, _Ke, aLe])); + } + function TId(a) { + return lhb("_UI_EMFDiagnostic_marker", a) ? "EMF Problem" : lhb("_UI_CircularContainment_diagnostic", a) ? "An object may not circularly contain itself" : lhb(TIe, a) ? "Wrong character." : lhb(UIe, a) ? "Invalid reference number." : lhb(VIe, a) ? "A character is required after \\." : lhb(WIe, a) ? "'?' is not expected. '(?:' or '(?=' or '(?!' or '(?<' or '(?#' or '(?>'?" : lhb(XIe, a) ? "'(?<' or '(? toIndex: ", bye = ", toIndex: ", cye = "Index: ", dye = ", Size: ", eye = "org.eclipse.elk.alg.common", fye = { 50: 1 }, gye = "org.eclipse.elk.alg.common.compaction", hye = "Scanline/EventHandler", iye = "org.eclipse.elk.alg.common.compaction.oned", jye = "CNode belongs to another CGroup.", kye = "ISpacingsHandler/1", lye = "The ", mye = " instance has been finished already.", nye = "The direction ", oye = " is not supported by the CGraph instance.", pye = "OneDimensionalCompactor", qye = "OneDimensionalCompactor/lambda$0$Type", rye = "Quadruplet", sye = "ScanlineConstraintCalculator", tye = "ScanlineConstraintCalculator/ConstraintsScanlineHandler", uye = "ScanlineConstraintCalculator/ConstraintsScanlineHandler/lambda$0$Type", vye = "ScanlineConstraintCalculator/Timestamp", wye = "ScanlineConstraintCalculator/lambda$0$Type", xye = { 178: 1, 46: 1 }, yye = "org.eclipse.elk.alg.common.compaction.options", zye = "org.eclipse.elk.core.data", Aye = "org.eclipse.elk.polyomino.traversalStrategy", Bye = "org.eclipse.elk.polyomino.lowLevelSort", Cye = "org.eclipse.elk.polyomino.highLevelSort", Dye = "org.eclipse.elk.polyomino.fill", Eye = { 134: 1 }, Fye = "polyomino", Gye = "org.eclipse.elk.alg.common.networksimplex", Hye = { 183: 1, 3: 1, 4: 1 }, Iye = "org.eclipse.elk.alg.common.nodespacing", Jye = "org.eclipse.elk.alg.common.nodespacing.cellsystem", Kye = "CENTER", Lye = { 217: 1, 336: 1 }, Mye = { 3: 1, 4: 1, 5: 1, 603: 1 }, Nye = "LEFT", Oye = "RIGHT", Pye = "Vertical alignment cannot be null", Qye = "BOTTOM", Rye = "org.eclipse.elk.alg.common.nodespacing.internal", Sye = "UNDEFINED", Tye = 0.01, Uye = "org.eclipse.elk.alg.common.nodespacing.internal.algorithm", Vye = "LabelPlacer/lambda$0$Type", Wye = "LabelPlacer/lambda$1$Type", Xye = "portRatioOrPosition", Yye = "org.eclipse.elk.alg.common.overlaps", Zye = "DOWN", $ye = "org.eclipse.elk.alg.common.polyomino", _ye = "NORTH", aze = "EAST", bze = "SOUTH", cze = "WEST", dze = "org.eclipse.elk.alg.common.polyomino.structures", eze = "Direction", fze = "Grid is only of size ", gze = ". Requested point (", hze = ") is out of bounds.", ize = " Given center based coordinates were (", jze = "org.eclipse.elk.graph.properties", kze = "IPropertyHolder", lze = { 3: 1, 96: 1, 137: 1 }, mze = "org.eclipse.elk.alg.common.spore", nze = "org.eclipse.elk.alg.common.utils", oze = { 205: 1 }, pze = "org.eclipse.elk.core", qze = "Connected Components Compaction", rze = "org.eclipse.elk.alg.disco", sze = "org.eclipse.elk.alg.disco.graph", tze = "org.eclipse.elk.alg.disco.options", uze = "CompactionStrategy", vze = "org.eclipse.elk.disco.componentCompaction.strategy", wze = "org.eclipse.elk.disco.componentCompaction.componentLayoutAlgorithm", xze = "org.eclipse.elk.disco.debug.discoGraph", yze = "org.eclipse.elk.disco.debug.discoPolys", zze = "componentCompaction", Aze = "org.eclipse.elk.disco", Bze = "org.eclipse.elk.spacing.componentComponent", Cze = "org.eclipse.elk.edge.thickness", Dze = "org.eclipse.elk.aspectRatio", Eze = "org.eclipse.elk.padding", Fze = "org.eclipse.elk.alg.disco.transform", Gze = 1.5707963267948966, Hze = 17976931348623157e292, Ize = { 3: 1, 4: 1, 5: 1, 198: 1 }, Jze = { 3: 1, 6: 1, 4: 1, 5: 1, 100: 1, 115: 1 }, Kze = "org.eclipse.elk.alg.force", Lze = "ComponentsProcessor", Mze = "ComponentsProcessor/1", Nze = "ElkGraphImporter/lambda$0$Type", Oze = "org.eclipse.elk.alg.force.graph", Pze = "Component Layout", Qze = "org.eclipse.elk.alg.force.model", Rze = "org.eclipse.elk.force.model", Sze = "org.eclipse.elk.force.iterations", Tze = "org.eclipse.elk.force.repulsivePower", Uze = "org.eclipse.elk.force.temperature", Vze = 1e-3, Wze = "org.eclipse.elk.force.repulsion", Xze = "org.eclipse.elk.alg.force.options", Yze = 1.600000023841858, Zze = "org.eclipse.elk.force", $ze = "org.eclipse.elk.priority", _ze = "org.eclipse.elk.spacing.nodeNode", aAe = "org.eclipse.elk.spacing.edgeLabel", bAe = "org.eclipse.elk.randomSeed", cAe = "org.eclipse.elk.separateConnectedComponents", dAe = "org.eclipse.elk.interactive", eAe = "org.eclipse.elk.portConstraints", fAe = "org.eclipse.elk.edgeLabels.inline", gAe = "org.eclipse.elk.omitNodeMicroLayout", hAe = "org.eclipse.elk.nodeSize.fixedGraphSize", iAe = "org.eclipse.elk.nodeSize.options", jAe = "org.eclipse.elk.nodeSize.constraints", kAe = "org.eclipse.elk.nodeLabels.placement", lAe = "org.eclipse.elk.portLabels.placement", mAe = "org.eclipse.elk.topdownLayout", nAe = "org.eclipse.elk.topdown.scaleFactor", oAe = "org.eclipse.elk.topdown.hierarchicalNodeWidth", pAe = "org.eclipse.elk.topdown.hierarchicalNodeAspectRatio", qAe = "org.eclipse.elk.topdown.nodeType", rAe = "origin", sAe = "random", tAe = "boundingBox.upLeft", uAe = "boundingBox.lowRight", vAe = "org.eclipse.elk.stress.fixed", wAe = "org.eclipse.elk.stress.desiredEdgeLength", xAe = "org.eclipse.elk.stress.dimension", yAe = "org.eclipse.elk.stress.epsilon", zAe = "org.eclipse.elk.stress.iterationLimit", AAe = "org.eclipse.elk.stress", BAe = "ELK Stress", CAe = "org.eclipse.elk.nodeSize.minimum", DAe = "org.eclipse.elk.alg.force.stress", EAe = "Layered layout", FAe = "org.eclipse.elk.alg.layered", GAe = "org.eclipse.elk.alg.layered.compaction.components", HAe = "org.eclipse.elk.alg.layered.compaction.oned", IAe = "org.eclipse.elk.alg.layered.compaction.oned.algs", JAe = "org.eclipse.elk.alg.layered.compaction.recthull", KAe = "org.eclipse.elk.alg.layered.components", LAe = "NONE", MAe = "MODEL_ORDER", NAe = { 3: 1, 6: 1, 4: 1, 9: 1, 5: 1, 126: 1 }, OAe = { 3: 1, 6: 1, 4: 1, 5: 1, 150: 1, 100: 1, 115: 1 }, PAe = "org.eclipse.elk.alg.layered.compound", QAe = { 47: 1 }, RAe = "org.eclipse.elk.alg.layered.graph", SAe = " -> ", TAe = "Not supported by LGraph", UAe = "Port side is undefined", VAe = { 3: 1, 6: 1, 4: 1, 5: 1, 483: 1, 150: 1, 100: 1, 115: 1 }, WAe = { 3: 1, 6: 1, 4: 1, 5: 1, 150: 1, 199: 1, 210: 1, 100: 1, 115: 1 }, XAe = { 3: 1, 6: 1, 4: 1, 5: 1, 150: 1, 2042: 1, 210: 1, 100: 1, 115: 1 }, YAe = `([{"' \r +`, ZAe = `)]}"' \r +`, $Ae = "The given string contains parts that cannot be parsed as numbers.", _Ae = "org.eclipse.elk.core.math", aBe = { 3: 1, 4: 1, 140: 1, 214: 1, 423: 1 }, bBe = { 3: 1, 4: 1, 107: 1, 214: 1, 423: 1 }, cBe = "org.eclipse.elk.alg.layered.graph.transform", dBe = "ElkGraphImporter", eBe = "ElkGraphImporter/lambda$1$Type", fBe = "ElkGraphImporter/lambda$2$Type", gBe = "ElkGraphImporter/lambda$4$Type", hBe = "org.eclipse.elk.alg.layered.intermediate", iBe = "Node margin calculation", jBe = "ONE_SIDED_GREEDY_SWITCH", kBe = "TWO_SIDED_GREEDY_SWITCH", lBe = "No implementation is available for the layout processor ", mBe = "IntermediateProcessorStrategy", nBe = "Node '", oBe = "FIRST_SEPARATE", pBe = "LAST_SEPARATE", qBe = "Odd port side processing", rBe = "org.eclipse.elk.alg.layered.intermediate.compaction", sBe = "org.eclipse.elk.alg.layered.intermediate.greedyswitch", tBe = "org.eclipse.elk.alg.layered.p3order.counting", uBe = { 230: 1 }, vBe = "org.eclipse.elk.alg.layered.intermediate.loops", wBe = "org.eclipse.elk.alg.layered.intermediate.loops.ordering", xBe = "org.eclipse.elk.alg.layered.intermediate.loops.routing", yBe = "org.eclipse.elk.alg.layered.intermediate.preserveorder", zBe = "org.eclipse.elk.alg.layered.intermediate.wrapping", ABe = "org.eclipse.elk.alg.layered.options", BBe = "INTERACTIVE", CBe = "GREEDY", DBe = "DEPTH_FIRST", EBe = "EDGE_LENGTH", FBe = "SELF_LOOPS", GBe = "firstTryWithInitialOrder", HBe = "org.eclipse.elk.layered.directionCongruency", IBe = "org.eclipse.elk.layered.feedbackEdges", JBe = "org.eclipse.elk.layered.interactiveReferencePoint", KBe = "org.eclipse.elk.layered.mergeEdges", LBe = "org.eclipse.elk.layered.mergeHierarchyEdges", MBe = "org.eclipse.elk.layered.allowNonFlowPortsToSwitchSides", NBe = "org.eclipse.elk.layered.portSortingStrategy", OBe = "org.eclipse.elk.layered.thoroughness", PBe = "org.eclipse.elk.layered.unnecessaryBendpoints", QBe = "org.eclipse.elk.layered.generatePositionAndLayerIds", RBe = "org.eclipse.elk.layered.cycleBreaking.strategy", SBe = "org.eclipse.elk.layered.layering.strategy", TBe = "org.eclipse.elk.layered.layering.layerConstraint", UBe = "org.eclipse.elk.layered.layering.layerChoiceConstraint", VBe = "org.eclipse.elk.layered.layering.layerId", WBe = "org.eclipse.elk.layered.layering.minWidth.upperBoundOnWidth", XBe = "org.eclipse.elk.layered.layering.minWidth.upperLayerEstimationScalingFactor", YBe = "org.eclipse.elk.layered.layering.nodePromotion.strategy", ZBe = "org.eclipse.elk.layered.layering.nodePromotion.maxIterations", $Be = "org.eclipse.elk.layered.layering.coffmanGraham.layerBound", _Be = "org.eclipse.elk.layered.crossingMinimization.strategy", aCe = "org.eclipse.elk.layered.crossingMinimization.forceNodeModelOrder", bCe = "org.eclipse.elk.layered.crossingMinimization.hierarchicalSweepiness", cCe = "org.eclipse.elk.layered.crossingMinimization.semiInteractive", dCe = "org.eclipse.elk.layered.crossingMinimization.inLayerPredOf", eCe = "org.eclipse.elk.layered.crossingMinimization.inLayerSuccOf", fCe = "org.eclipse.elk.layered.crossingMinimization.positionChoiceConstraint", gCe = "org.eclipse.elk.layered.crossingMinimization.positionId", hCe = "org.eclipse.elk.layered.crossingMinimization.greedySwitch.activationThreshold", iCe = "org.eclipse.elk.layered.crossingMinimization.greedySwitch.type", jCe = "org.eclipse.elk.layered.crossingMinimization.greedySwitchHierarchical.type", kCe = "org.eclipse.elk.layered.nodePlacement.strategy", lCe = "org.eclipse.elk.layered.nodePlacement.favorStraightEdges", mCe = "org.eclipse.elk.layered.nodePlacement.bk.edgeStraightening", nCe = "org.eclipse.elk.layered.nodePlacement.bk.fixedAlignment", oCe = "org.eclipse.elk.layered.nodePlacement.linearSegments.deflectionDampening", pCe = "org.eclipse.elk.layered.nodePlacement.networkSimplex.nodeFlexibility", qCe = "org.eclipse.elk.layered.nodePlacement.networkSimplex.nodeFlexibility.default", rCe = "org.eclipse.elk.layered.edgeRouting.selfLoopDistribution", sCe = "org.eclipse.elk.layered.edgeRouting.selfLoopOrdering", tCe = "org.eclipse.elk.layered.edgeRouting.splines.mode", uCe = "org.eclipse.elk.layered.edgeRouting.splines.sloppy.layerSpacingFactor", vCe = "org.eclipse.elk.layered.edgeRouting.polyline.slopedEdgeZoneWidth", wCe = "org.eclipse.elk.layered.spacing.baseValue", xCe = "org.eclipse.elk.layered.spacing.edgeNodeBetweenLayers", yCe = "org.eclipse.elk.layered.spacing.edgeEdgeBetweenLayers", zCe = "org.eclipse.elk.layered.spacing.nodeNodeBetweenLayers", ACe = "org.eclipse.elk.layered.priority.direction", BCe = "org.eclipse.elk.layered.priority.shortness", CCe = "org.eclipse.elk.layered.priority.straightness", DCe = "org.eclipse.elk.layered.compaction.connectedComponents", ECe = "org.eclipse.elk.layered.compaction.postCompaction.strategy", FCe = "org.eclipse.elk.layered.compaction.postCompaction.constraints", GCe = "org.eclipse.elk.layered.highDegreeNodes.treatment", HCe = "org.eclipse.elk.layered.highDegreeNodes.threshold", ICe = "org.eclipse.elk.layered.highDegreeNodes.treeHeight", JCe = "org.eclipse.elk.layered.wrapping.strategy", KCe = "org.eclipse.elk.layered.wrapping.additionalEdgeSpacing", LCe = "org.eclipse.elk.layered.wrapping.correctionFactor", MCe = "org.eclipse.elk.layered.wrapping.cutting.strategy", NCe = "org.eclipse.elk.layered.wrapping.cutting.cuts", OCe = "org.eclipse.elk.layered.wrapping.cutting.msd.freedom", PCe = "org.eclipse.elk.layered.wrapping.validify.strategy", QCe = "org.eclipse.elk.layered.wrapping.validify.forbiddenIndices", RCe = "org.eclipse.elk.layered.wrapping.multiEdge.improveCuts", SCe = "org.eclipse.elk.layered.wrapping.multiEdge.distancePenalty", TCe = "org.eclipse.elk.layered.wrapping.multiEdge.improveWrappedEdges", UCe = "org.eclipse.elk.layered.edgeLabels.sideSelection", VCe = "org.eclipse.elk.layered.edgeLabels.centerLabelPlacementStrategy", WCe = "org.eclipse.elk.layered.considerModelOrder.strategy", XCe = "org.eclipse.elk.layered.considerModelOrder.portModelOrder", YCe = "org.eclipse.elk.layered.considerModelOrder.noModelOrder", ZCe = "org.eclipse.elk.layered.considerModelOrder.components", $Ce = "org.eclipse.elk.layered.considerModelOrder.longEdgeStrategy", _Ce = "org.eclipse.elk.layered.considerModelOrder.crossingCounterNodeInfluence", aDe = "org.eclipse.elk.layered.considerModelOrder.crossingCounterPortInfluence", bDe = "layering", cDe = "layering.minWidth", dDe = "layering.nodePromotion", eDe = "crossingMinimization", fDe = "org.eclipse.elk.hierarchyHandling", gDe = "crossingMinimization.greedySwitch", hDe = "nodePlacement", iDe = "nodePlacement.bk", jDe = "edgeRouting", kDe = "org.eclipse.elk.edgeRouting", lDe = "spacing", mDe = "priority", nDe = "compaction", oDe = "compaction.postCompaction", pDe = "Specifies whether and how post-process compaction is applied.", qDe = "highDegreeNodes", rDe = "wrapping", sDe = "wrapping.cutting", tDe = "wrapping.validify", uDe = "wrapping.multiEdge", vDe = "edgeLabels", wDe = "considerModelOrder", xDe = "org.eclipse.elk.spacing.commentComment", yDe = "org.eclipse.elk.spacing.commentNode", zDe = "org.eclipse.elk.spacing.edgeEdge", ADe = "org.eclipse.elk.spacing.edgeNode", BDe = "org.eclipse.elk.spacing.labelLabel", CDe = "org.eclipse.elk.spacing.labelPortHorizontal", DDe = "org.eclipse.elk.spacing.labelPortVertical", EDe = "org.eclipse.elk.spacing.labelNode", FDe = "org.eclipse.elk.spacing.nodeSelfLoop", GDe = "org.eclipse.elk.spacing.portPort", HDe = "org.eclipse.elk.spacing.individual", IDe = "org.eclipse.elk.port.borderOffset", JDe = "org.eclipse.elk.noLayout", KDe = "org.eclipse.elk.port.side", LDe = "org.eclipse.elk.debugMode", MDe = "org.eclipse.elk.alignment", NDe = "org.eclipse.elk.insideSelfLoops.activate", ODe = "org.eclipse.elk.insideSelfLoops.yo", PDe = "org.eclipse.elk.direction", QDe = "org.eclipse.elk.nodeLabels.padding", RDe = "org.eclipse.elk.portLabels.nextToPortIfPossible", SDe = "org.eclipse.elk.portLabels.treatAsGroup", TDe = "org.eclipse.elk.portAlignment.default", UDe = "org.eclipse.elk.portAlignment.north", VDe = "org.eclipse.elk.portAlignment.south", WDe = "org.eclipse.elk.portAlignment.west", XDe = "org.eclipse.elk.portAlignment.east", YDe = "org.eclipse.elk.contentAlignment", ZDe = "org.eclipse.elk.junctionPoints", $De = "org.eclipse.elk.edgeLabels.placement", _De = "org.eclipse.elk.port.index", aEe = "org.eclipse.elk.commentBox", bEe = "org.eclipse.elk.hypernode", cEe = "org.eclipse.elk.port.anchor", dEe = "org.eclipse.elk.partitioning.activate", eEe = "org.eclipse.elk.partitioning.partition", fEe = "org.eclipse.elk.position", gEe = "org.eclipse.elk.margins", hEe = "org.eclipse.elk.spacing.portsSurrounding", iEe = "org.eclipse.elk.interactiveLayout", jEe = "org.eclipse.elk.core.util", kEe = { 3: 1, 4: 1, 5: 1, 601: 1 }, lEe = "NETWORK_SIMPLEX", mEe = "SIMPLE", nEe = { 106: 1, 47: 1 }, oEe = "org.eclipse.elk.alg.layered.p1cycles", pEe = "org.eclipse.elk.alg.layered.p2layers", qEe = { 413: 1, 230: 1 }, rEe = { 846: 1, 3: 1, 4: 1 }, sEe = "org.eclipse.elk.alg.layered.p3order", tEe = "org.eclipse.elk.alg.layered.p4nodes", uEe = { 3: 1, 4: 1, 5: 1, 854: 1 }, vEe = 1e-5, wEe = "org.eclipse.elk.alg.layered.p4nodes.bk", xEe = "org.eclipse.elk.alg.layered.p5edges", yEe = "org.eclipse.elk.alg.layered.p5edges.orthogonal", zEe = "org.eclipse.elk.alg.layered.p5edges.orthogonal.direction", AEe = 1e-6, BEe = "org.eclipse.elk.alg.layered.p5edges.splines", CEe = 0.09999999999999998, DEe = 1e-8, EEe = 4.71238898038469, FEe = 3.141592653589793, GEe = "org.eclipse.elk.alg.mrtree", HEe = 0.10000000149011612, IEe = "SUPER_ROOT", JEe = "org.eclipse.elk.alg.mrtree.graph", KEe = -17976931348623157e292, LEe = "org.eclipse.elk.alg.mrtree.intermediate", MEe = "Processor compute fanout", NEe = { 3: 1, 6: 1, 4: 1, 5: 1, 534: 1, 100: 1, 115: 1 }, OEe = "Set neighbors in level", PEe = "org.eclipse.elk.alg.mrtree.options", QEe = "DESCENDANTS", REe = "org.eclipse.elk.mrtree.compaction", SEe = "org.eclipse.elk.mrtree.edgeEndTextureLength", TEe = "org.eclipse.elk.mrtree.treeLevel", UEe = "org.eclipse.elk.mrtree.positionConstraint", VEe = "org.eclipse.elk.mrtree.weighting", WEe = "org.eclipse.elk.mrtree.edgeRoutingMode", XEe = "org.eclipse.elk.mrtree.searchOrder", YEe = "Position Constraint", ZEe = "org.eclipse.elk.mrtree", $Ee = "org.eclipse.elk.tree", _Ee = "Processor arrange level", aFe = "org.eclipse.elk.alg.mrtree.p2order", bFe = "org.eclipse.elk.alg.mrtree.p4route", cFe = "org.eclipse.elk.alg.radial", dFe = 6.283185307179586, eFe = "Before", fFe = 5e-324, gFe = "After", hFe = "org.eclipse.elk.alg.radial.intermediate", iFe = "COMPACTION", jFe = "org.eclipse.elk.alg.radial.intermediate.compaction", kFe = { 3: 1, 4: 1, 5: 1, 100: 1 }, lFe = "org.eclipse.elk.alg.radial.intermediate.optimization", mFe = "No implementation is available for the layout option ", nFe = "org.eclipse.elk.alg.radial.options", oFe = "org.eclipse.elk.radial.centerOnRoot", pFe = "org.eclipse.elk.radial.orderId", qFe = "org.eclipse.elk.radial.radius", rFe = "org.eclipse.elk.radial.rotate", sFe = "org.eclipse.elk.radial.compactor", tFe = "org.eclipse.elk.radial.compactionStepSize", uFe = "org.eclipse.elk.radial.sorter", vFe = "org.eclipse.elk.radial.wedgeCriteria", wFe = "org.eclipse.elk.radial.optimizationCriteria", xFe = "org.eclipse.elk.radial.rotation.targetAngle", yFe = "org.eclipse.elk.radial.rotation.computeAdditionalWedgeSpace", zFe = "org.eclipse.elk.radial.rotation.outgoingEdgeAngles", AFe = "Compaction", BFe = "rotation", CFe = "org.eclipse.elk.radial", DFe = "org.eclipse.elk.alg.radial.p1position.wedge", EFe = "org.eclipse.elk.alg.radial.sorting", FFe = 5.497787143782138, GFe = 3.9269908169872414, HFe = 2.356194490192345, IFe = "org.eclipse.elk.alg.rectpacking", JFe = "org.eclipse.elk.alg.rectpacking.intermediate", KFe = "org.eclipse.elk.alg.rectpacking.options", LFe = "org.eclipse.elk.rectpacking.trybox", MFe = "org.eclipse.elk.rectpacking.currentPosition", NFe = "org.eclipse.elk.rectpacking.desiredPosition", OFe = "org.eclipse.elk.rectpacking.inNewRow", PFe = "org.eclipse.elk.rectpacking.widthApproximation.strategy", QFe = "org.eclipse.elk.rectpacking.widthApproximation.targetWidth", RFe = "org.eclipse.elk.rectpacking.widthApproximation.optimizationGoal", SFe = "org.eclipse.elk.rectpacking.widthApproximation.lastPlaceShift", TFe = "org.eclipse.elk.rectpacking.packing.strategy", UFe = "org.eclipse.elk.rectpacking.packing.compaction.rowHeightReevaluation", VFe = "org.eclipse.elk.rectpacking.packing.compaction.iterations", WFe = "org.eclipse.elk.rectpacking.whiteSpaceElimination.strategy", XFe = "widthApproximation", YFe = "Compaction Strategy", ZFe = "packing.compaction", $Fe = "org.eclipse.elk.rectpacking", _Fe = "org.eclipse.elk.alg.rectpacking.p1widthapproximation", aGe = "org.eclipse.elk.alg.rectpacking.p2packing", bGe = "No Compaction", cGe = "org.eclipse.elk.alg.rectpacking.p3whitespaceelimination", dGe = "org.eclipse.elk.alg.rectpacking.util", eGe = "No implementation available for ", fGe = "org.eclipse.elk.alg.spore", gGe = "org.eclipse.elk.alg.spore.options", hGe = "org.eclipse.elk.sporeCompaction", iGe = "org.eclipse.elk.underlyingLayoutAlgorithm", jGe = "org.eclipse.elk.processingOrder.treeConstruction", kGe = "org.eclipse.elk.processingOrder.spanningTreeCostFunction", lGe = "org.eclipse.elk.processingOrder.preferredRoot", mGe = "org.eclipse.elk.processingOrder.rootSelection", nGe = "org.eclipse.elk.structure.structureExtractionStrategy", oGe = "org.eclipse.elk.compaction.compactionStrategy", pGe = "org.eclipse.elk.compaction.orthogonal", qGe = "org.eclipse.elk.overlapRemoval.maxIterations", rGe = "org.eclipse.elk.overlapRemoval.runScanline", sGe = "processingOrder", tGe = "overlapRemoval", uGe = "org.eclipse.elk.sporeOverlap", vGe = "org.eclipse.elk.alg.spore.p1structure", wGe = "org.eclipse.elk.alg.spore.p2processingorder", xGe = "org.eclipse.elk.alg.spore.p3execution", yGe = "Topdown Layout", zGe = "Invalid index: ", AGe = "org.eclipse.elk.core.alg", BGe = { 341: 1 }, CGe = { 295: 1 }, DGe = "Make sure its type is registered with the ", EGe = " utility class.", FGe = "true", GGe = "false", HGe = "Couldn't clone property '", IGe = 0.05, JGe = "org.eclipse.elk.core.options", KGe = 1.2999999523162842, LGe = "org.eclipse.elk.box", MGe = "org.eclipse.elk.expandNodes", NGe = "org.eclipse.elk.box.packingMode", OGe = "org.eclipse.elk.algorithm", PGe = "org.eclipse.elk.resolvedAlgorithm", QGe = "org.eclipse.elk.bendPoints", RGe = "org.eclipse.elk.labelManager", SGe = "org.eclipse.elk.scaleFactor", TGe = "org.eclipse.elk.childAreaWidth", UGe = "org.eclipse.elk.childAreaHeight", VGe = "org.eclipse.elk.animate", WGe = "org.eclipse.elk.animTimeFactor", XGe = "org.eclipse.elk.layoutAncestors", YGe = "org.eclipse.elk.maxAnimTime", ZGe = "org.eclipse.elk.minAnimTime", $Ge = "org.eclipse.elk.progressBar", _Ge = "org.eclipse.elk.validateGraph", aHe = "org.eclipse.elk.validateOptions", bHe = "org.eclipse.elk.zoomToFit", cHe = "org.eclipse.elk.font.name", dHe = "org.eclipse.elk.font.size", eHe = "org.eclipse.elk.topdown.sizeApproximator", fHe = "org.eclipse.elk.topdown.scaleCap", gHe = "org.eclipse.elk.edge.type", hHe = "partitioning", iHe = "nodeLabels", jHe = "portAlignment", kHe = "nodeSize", lHe = "port", mHe = "portLabels", nHe = "topdown", oHe = "insideSelfLoops", pHe = "org.eclipse.elk.fixed", qHe = "org.eclipse.elk.random", rHe = { 3: 1, 34: 1, 22: 1, 347: 1 }, sHe = "port must have a parent node to calculate the port side", tHe = "The edge needs to have exactly one edge section. Found: ", uHe = "org.eclipse.elk.core.util.adapters", vHe = "org.eclipse.emf.ecore", wHe = "org.eclipse.elk.graph", xHe = "EMapPropertyHolder", yHe = "ElkBendPoint", zHe = "ElkGraphElement", AHe = "ElkConnectableShape", BHe = "ElkEdge", CHe = "ElkEdgeSection", DHe = "EModelElement", EHe = "ENamedElement", FHe = "ElkLabel", GHe = "ElkNode", HHe = "ElkPort", IHe = { 94: 1, 93: 1 }, JHe = "org.eclipse.emf.common.notify.impl", KHe = "The feature '", LHe = "' is not a valid changeable feature", MHe = "Expecting null", NHe = "' is not a valid feature", OHe = "The feature ID", PHe = " is not a valid feature ID", QHe = 32768, RHe = { 110: 1, 94: 1, 93: 1, 58: 1, 54: 1, 99: 1 }, SHe = "org.eclipse.emf.ecore.impl", THe = "org.eclipse.elk.graph.impl", UHe = "Recursive containment not allowed for ", VHe = "The datatype '", WHe = "' is not a valid classifier", XHe = "The value '", YHe = { 195: 1, 3: 1, 4: 1 }, ZHe = "The class '", $He = "http://www.eclipse.org/elk/ElkGraph", _He = "property", aIe = "value", bIe = "source", cIe = "properties", dIe = "identifier", eIe = "height", fIe = "width", gIe = "parent", hIe = "text", iIe = "children", jIe = "hierarchical", kIe = "sources", lIe = "targets", mIe = "sections", nIe = "bendPoints", oIe = "outgoingShape", pIe = "incomingShape", qIe = "outgoingSections", rIe = "incomingSections", sIe = "org.eclipse.emf.common.util", tIe = "Severe implementation error in the Json to ElkGraph importer.", uIe = "id", vIe = "org.eclipse.elk.graph.json", wIe = "Unhandled parameter types: ", xIe = "startPoint", yIe = "An edge must have at least one source and one target (edge id: '", zIe = "').", AIe = "Referenced edge section does not exist: ", BIe = " (edge id: '", CIe = "target", DIe = "sourcePoint", EIe = "targetPoint", FIe = "group", GIe = "name", HIe = "connectableShape cannot be null", IIe = "edge cannot be null", JIe = "Passed edge is not 'simple'.", KIe = "org.eclipse.elk.graph.util", LIe = "The 'no duplicates' constraint is violated", MIe = "targetIndex=", NIe = ", size=", OIe = "sourceIndex=", PIe = { 3: 1, 4: 1, 20: 1, 31: 1, 56: 1, 16: 1, 15: 1, 59: 1, 70: 1, 66: 1, 61: 1 }, QIe = { 3: 1, 4: 1, 20: 1, 31: 1, 56: 1, 16: 1, 51: 1, 15: 1, 59: 1, 70: 1, 66: 1, 61: 1, 596: 1 }, RIe = "logging", SIe = "measureExecutionTime", TIe = "parser.parse.1", UIe = "parser.parse.2", VIe = "parser.next.1", WIe = "parser.next.2", XIe = "parser.next.3", YIe = "parser.next.4", ZIe = "parser.factor.1", $Ie = "parser.factor.2", _Ie = "parser.factor.3", aJe = "parser.factor.4", bJe = "parser.factor.5", cJe = "parser.factor.6", dJe = "parser.atom.1", eJe = "parser.atom.2", fJe = "parser.atom.3", gJe = "parser.atom.4", hJe = "parser.atom.5", iJe = "parser.cc.1", jJe = "parser.cc.2", kJe = "parser.cc.3", lJe = "parser.cc.5", mJe = "parser.cc.6", nJe = "parser.cc.7", oJe = "parser.cc.8", pJe = "parser.ope.1", qJe = "parser.ope.2", rJe = "parser.ope.3", sJe = "parser.descape.1", tJe = "parser.descape.2", uJe = "parser.descape.3", vJe = "parser.descape.4", wJe = "parser.descape.5", xJe = "parser.process.1", yJe = "parser.quantifier.1", zJe = "parser.quantifier.2", AJe = "parser.quantifier.3", BJe = "parser.quantifier.4", CJe = "parser.quantifier.5", DJe = "org.eclipse.emf.common.notify", EJe = { 424: 1, 686: 1 }, FJe = { 3: 1, 4: 1, 20: 1, 31: 1, 56: 1, 16: 1, 15: 1, 70: 1, 61: 1 }, GJe = { 378: 1, 152: 1 }, HJe = "index=", IJe = { 3: 1, 4: 1, 5: 1, 129: 1 }, JJe = { 3: 1, 4: 1, 20: 1, 31: 1, 56: 1, 16: 1, 15: 1, 59: 1, 70: 1, 61: 1 }, KJe = { 3: 1, 6: 1, 4: 1, 5: 1, 198: 1 }, LJe = { 3: 1, 4: 1, 5: 1, 173: 1, 379: 1 }, MJe = ";/?:@&=+$,", NJe = "invalid authority: ", OJe = "EAnnotation", PJe = "ETypedElement", QJe = "EStructuralFeature", RJe = "EAttribute", SJe = "EClassifier", TJe = "EEnumLiteral", UJe = "EGenericType", VJe = "EOperation", WJe = "EParameter", XJe = "EReference", YJe = "ETypeParameter", ZJe = "org.eclipse.emf.ecore.util", $Je = { 79: 1 }, _Je = { 3: 1, 20: 1, 16: 1, 15: 1, 61: 1, 597: 1, 79: 1, 71: 1, 97: 1 }, aKe = "org.eclipse.emf.ecore.util.FeatureMap$Entry", bKe = 8192, cKe = 2048, dKe = "byte", eKe = "char", fKe = "double", gKe = "float", hKe = "int", iKe = "long", jKe = "short", kKe = "java.lang.Object", lKe = { 3: 1, 4: 1, 5: 1, 254: 1 }, mKe = { 3: 1, 4: 1, 5: 1, 688: 1 }, nKe = { 3: 1, 4: 1, 20: 1, 31: 1, 56: 1, 16: 1, 15: 1, 59: 1, 70: 1, 66: 1, 61: 1, 71: 1 }, oKe = { 3: 1, 4: 1, 20: 1, 31: 1, 56: 1, 16: 1, 15: 1, 59: 1, 70: 1, 66: 1, 61: 1, 79: 1, 71: 1, 97: 1 }, pKe = "mixed", qKe = "http:///org/eclipse/emf/ecore/util/ExtendedMetaData", rKe = "kind", sKe = { 3: 1, 4: 1, 5: 1, 689: 1 }, tKe = { 3: 1, 4: 1, 20: 1, 31: 1, 56: 1, 16: 1, 15: 1, 70: 1, 61: 1, 79: 1, 71: 1, 97: 1 }, uKe = { 20: 1, 31: 1, 56: 1, 16: 1, 15: 1, 61: 1, 71: 1 }, vKe = { 51: 1, 128: 1, 287: 1 }, wKe = { 76: 1, 343: 1 }, xKe = "The value of type '", yKe = "' must be of type '", zKe = 1352, AKe = "http://www.eclipse.org/emf/2002/Ecore", BKe = -32768, CKe = "constraints", DKe = "baseType", EKe = "getEStructuralFeature", FKe = "getFeatureID", GKe = "feature", HKe = "getOperationID", IKe = "operation", JKe = "defaultValue", KKe = "eTypeParameters", LKe = "isInstance", MKe = "getEEnumLiteral", NKe = "eContainingClass", OKe = { 57: 1 }, PKe = { 3: 1, 4: 1, 5: 1, 124: 1 }, QKe = "org.eclipse.emf.ecore.resource", RKe = { 94: 1, 93: 1, 599: 1, 2034: 1 }, SKe = "org.eclipse.emf.ecore.resource.impl", TKe = "unspecified", UKe = "simple", VKe = "attribute", WKe = "attributeWildcard", XKe = "element", YKe = "elementWildcard", ZKe = "collapse", $Ke = "itemType", _Ke = "namespace", aLe = "##targetNamespace", bLe = "whiteSpace", cLe = "wildcards", dLe = "http://www.eclipse.org/emf/2003/XMLType", eLe = "##any", fLe = "uninitialized", gLe = "The multiplicity constraint is violated", hLe = "org.eclipse.emf.ecore.xml.type", iLe = "ProcessingInstruction", jLe = "SimpleAnyType", kLe = "XMLTypeDocumentRoot", lLe = "org.eclipse.emf.ecore.xml.type.impl", mLe = "INF", nLe = "processing", oLe = "ENTITIES_._base", pLe = "minLength", qLe = "ENTITY", rLe = "NCName", sLe = "IDREFS_._base", tLe = "integer", uLe = "token", vLe = "pattern", wLe = "[a-zA-Z]{1,8}(-[a-zA-Z0-9]{1,8})*", xLe = "\\i\\c*", yLe = "[\\i-[:]][\\c-[:]]*", zLe = "nonPositiveInteger", ALe = "maxInclusive", BLe = "NMTOKEN", CLe = "NMTOKENS_._base", DLe = "nonNegativeInteger", ELe = "minInclusive", FLe = "normalizedString", GLe = "unsignedByte", HLe = "unsignedInt", ILe = "18446744073709551615", JLe = "unsignedShort", KLe = "processingInstruction", LLe = "org.eclipse.emf.ecore.xml.type.internal", MLe = 1114111, NLe = "Internal Error: shorthands: \\u", OLe = "xml:isDigit", PLe = "xml:isWord", QLe = "xml:isSpace", RLe = "xml:isNameChar", SLe = "xml:isInitialNameChar", TLe = "09٠٩۰۹०९০৯੦੯૦૯୦୯௧௯౦౯೦೯൦൯๐๙໐໙༠༩", ULe = "AZazÀÖØöøıĴľŁňŊžƀǃǍǰǴǵǺȗɐʨʻˁΆΆΈΊΌΌΎΡΣώϐϖϚϚϜϜϞϞϠϠϢϳЁЌЎяёќўҁҐӄӇӈӋӌӐӫӮӵӸӹԱՖՙՙաֆאתװײءغفيٱڷںھۀێېۓەەۥۦअहऽऽक़ॡঅঌএঐওনপরললশহড়ঢ়য়ৡৰৱਅਊਏਐਓਨਪਰਲਲ਼ਵਸ਼ਸਹਖ਼ੜਫ਼ਫ਼ੲੴઅઋઍઍએઑઓનપરલળવહઽઽૠૠଅଌଏଐଓନପରଲଳଶହଽଽଡ଼ଢ଼ୟୡஅஊஎஐஒகஙசஜஜஞடணதநபமவஷஹఅఌఎఐఒనపళవహౠౡಅಌಎಐಒನಪಳವಹೞೞೠೡഅഌഎഐഒനപഹൠൡกฮะะาำเๅກຂຄຄງຈຊຊຍຍດທນຟມຣລລວວສຫອຮະະາຳຽຽເໄཀཇཉཀྵႠჅაჶᄀᄀᄂᄃᄅᄇᄉᄉᄋᄌᄎᄒᄼᄼᄾᄾᅀᅀᅌᅌᅎᅎᅐᅐᅔᅕᅙᅙᅟᅡᅣᅣᅥᅥᅧᅧᅩᅩᅭᅮᅲᅳᅵᅵᆞᆞᆨᆨᆫᆫᆮᆯᆷᆸᆺᆺᆼᇂᇫᇫᇰᇰᇹᇹḀẛẠỹἀἕἘἝἠὅὈὍὐὗὙὙὛὛὝὝὟώᾀᾴᾶᾼιιῂῄῆῌῐΐῖΊῠῬῲῴῶῼΩΩKÅ℮℮ↀↂ〇〇〡〩ぁゔァヺㄅㄬ一龥가힣", VLe = "Private Use", WLe = "ASSIGNED", XLe = "\0€ÿĀſƀɏɐʯʰ˿̀ͯͰϿЀӿ԰֏֐׿؀ۿ܀ݏހ޿ऀॿঀ৿਀੿઀૿଀୿஀௿ఀ౿ಀ೿ഀൿ඀෿฀๿຀໿ༀ࿿က႟Ⴀჿᄀᇿሀ፿Ꭰ᏿᐀ᙿ ᚟ᚠ᛿ក៿᠀᢯Ḁỿἀ῿ ⁰₟₠⃏⃐⃿℀⅏⅐↏←⇿∀⋿⌀⏿␀␿⑀⑟①⓿─╿▀▟■◿☀⛿✀➿⠀⣿⺀⻿⼀⿟⿰⿿ 〿぀ゟ゠ヿ㄀ㄯ㄰㆏㆐㆟ㆠㆿ㈀㋿㌀㏿㐀䶵一鿿ꀀ꒏꒐꓏가힣豈﫿ffﭏﭐ﷿︠︯︰﹏﹐﹯ﹰ﻾\uFEFF\uFEFF＀￯", YLe = "UNASSIGNED", ZLe = { 3: 1, 122: 1 }, $Le = "org.eclipse.emf.ecore.xml.type.util", _Le = { 3: 1, 4: 1, 5: 1, 381: 1 }, aMe = "org.eclipse.xtext.xbase.lib", bMe = "Cannot add elements to a Range", cMe = "Cannot set elements in a Range", dMe = "Cannot remove elements from a Range", eMe = "user.agent"; + var _2, eeb, _db; + $wnd.goog = $wnd.goog || {}; + $wnd.goog.global = $wnd.goog.global || $wnd; + eeb = {}; + feb(1, null, {}, nb); + _2.Fb = function ob(a) { + return mb(this, a); + }; + _2.Gb = function qb() { + return this.Rm; + }; + _2.Hb = function sb() { + return kFb(this); + }; + _2.Ib = function ub() { + var a; + return nfb(rb(this)) + "@" + (a = tb(this) >>> 0, a.toString(16)); + }; + _2.equals = function(a) { + return this.Fb(a); + }; + _2.hashCode = function() { + return this.Hb(); + }; + _2.toString = function() { + return this.Ib(); + }; + var ND, OD, PD; + feb(297, 1, { 297: 1, 2124: 1 }, pfb); + _2.ve = function qfb(a) { + var b; + b = new pfb(); + b.i = 4; + a > 1 ? b.c = xfb(this, a - 1) : b.c = this; + return b; + }; + _2.we = function wfb() { + lfb(this); + return this.b; + }; + _2.xe = function yfb() { + return nfb(this); + }; + _2.ye = function Afb() { + return lfb(this), this.k; + }; + _2.ze = function Cfb() { + return (this.i & 4) != 0; + }; + _2.Ae = function Dfb() { + return (this.i & 1) != 0; + }; + _2.Ib = function Gfb() { + return ofb(this); + }; + _2.i = 0; + var jJ = sfb(mve, "Object", 1); + var UI = sfb(mve, "Class", 297); + feb(2096, 1, nve); + sfb(ove, "Optional", 2096); + feb(1191, 2096, nve, xb); + _2.Fb = function yb(a) { + return a === this; + }; + _2.Hb = function zb() { + return 2040732332; + }; + _2.Ib = function Ab() { + return "Optional.absent()"; + }; + _2.Jb = function Bb(a) { + Qb(a); + return wb(), vb; + }; + var vb; + sfb(ove, "Absent", 1191); + feb(636, 1, {}, Gb); + sfb(ove, "Joiner", 636); + var pE = ufb(ove, "Predicate"); + feb(589, 1, { 178: 1, 589: 1, 3: 1, 46: 1 }, Yb); + _2.Mb = function ac(a) { + return Xb(this, a); + }; + _2.Lb = function Zb(a) { + return Xb(this, a); + }; + _2.Fb = function $b(a) { + var b; + if (ZD(a, 589)) { + b = RD(a, 589); + return Rt(this.a, b.a); + } + return false; + }; + _2.Hb = function _b2() { + return Cob(this.a) + 306654252; + }; + _2.Ib = function bc() { + return Wb(this.a); + }; + sfb(ove, "Predicates/AndPredicate", 589); + feb(419, 2096, { 419: 1, 3: 1 }, cc); + _2.Fb = function dc(a) { + var b; + if (ZD(a, 419)) { + b = RD(a, 419); + return pb(this.a, b.a); + } + return false; + }; + _2.Hb = function ec() { + return 1502476572 + tb(this.a); + }; + _2.Ib = function fc() { + return uve + this.a + ")"; + }; + _2.Jb = function gc(a) { + return new cc(Rb(a.Kb(this.a), "the Function passed to Optional.transform() must not return null.")); + }; + sfb(ove, "Present", 419); + feb(204, 1, wve); + _2.Nb = function kc(a) { + Ztb(this, a); + }; + _2.Qb = function lc() { + jc(); + }; + sfb(xve, "UnmodifiableIterator", 204); + feb(2076, 204, yve); + _2.Qb = function nc() { + jc(); + }; + _2.Rb = function mc(a) { + throw Adb(new jib()); + }; + _2.Wb = function oc(a) { + throw Adb(new jib()); + }; + sfb(xve, "UnmodifiableListIterator", 2076); + feb(399, 2076, yve); + _2.Ob = function rc() { + return this.c < this.d; + }; + _2.Sb = function sc() { + return this.c > 0; + }; + _2.Pb = function tc() { + if (this.c >= this.d) { + throw Adb(new Dvb()); + } + return this.Xb(this.c++); + }; + _2.Tb = function uc() { + return this.c; + }; + _2.Ub = function vc() { + if (this.c <= 0) { + throw Adb(new Dvb()); + } + return this.Xb(--this.c); + }; + _2.Vb = function wc() { + return this.c - 1; + }; + _2.c = 0; + _2.d = 0; + sfb(xve, "AbstractIndexedListIterator", 399); + feb(713, 204, wve); + _2.Ob = function Ac() { + return xc(this); + }; + _2.Pb = function Bc() { + return yc(this); + }; + _2.e = 1; + sfb(xve, "AbstractIterator", 713); + feb(2084, 1, { 229: 1 }); + _2.Zb = function Hc() { + var a; + return a = this.f, !a ? this.f = this.ac() : a; + }; + _2.Fb = function Ic(a) { + return xw(this, a); + }; + _2.Hb = function Jc() { + return tb(this.Zb()); + }; + _2.dc = function Kc() { + return this.gc() == 0; + }; + _2.ec = function Lc() { + return Ec(this); + }; + _2.Ib = function Mc() { + return jeb(this.Zb()); + }; + sfb(xve, "AbstractMultimap", 2084); + feb(742, 2084, zve); + _2.$b = function Xc() { + Nc(this); + }; + _2._b = function Yc(a) { + return Oc(this, a); + }; + _2.ac = function Zc() { + return new ne(this, this.c); + }; + _2.ic = function $c(a) { + return this.hc(); + }; + _2.bc = function _c() { + return new zf(this, this.c); + }; + _2.jc = function ad() { + return this.mc(this.hc()); + }; + _2.kc = function bd() { + return new Hd(this); + }; + _2.lc = function cd() { + return ek(this.c.vc().Nc(), new hh(), 64, this.d); + }; + _2.cc = function dd(a) { + return Qc(this, a); + }; + _2.fc = function gd(a) { + return Sc2(this, a); + }; + _2.gc = function hd() { + return this.d; + }; + _2.mc = function jd(a) { + return yob(), new xpb(a); + }; + _2.nc = function kd() { + return new Dd(this); + }; + _2.oc = function ld() { + return ek(this.c.Cc().Nc(), new Fd(), 64, this.d); + }; + _2.pc = function md(a, b) { + return new lg(this, a, b, null); + }; + _2.d = 0; + sfb(xve, "AbstractMapBasedMultimap", 742); + feb(1696, 742, zve); + _2.hc = function pd() { + return new cnb(this.a); + }; + _2.jc = function qd() { + return yob(), yob(), vob; + }; + _2.cc = function sd(a) { + return RD(Qc(this, a), 15); + }; + _2.fc = function ud(a) { + return RD(Sc2(this, a), 15); + }; + _2.Zb = function od() { + return nd(this); + }; + _2.Fb = function rd(a) { + return xw(this, a); + }; + _2.qc = function td(a) { + return RD(Qc(this, a), 15); + }; + _2.rc = function vd(a) { + return RD(Sc2(this, a), 15); + }; + _2.mc = function wd(a) { + return Hob(RD(a, 15)); + }; + _2.pc = function xd(a, b) { + return Vc(this, a, RD(b, 15), null); + }; + sfb(xve, "AbstractListMultimap", 1696); + feb(748, 1, Ave); + _2.Nb = function zd(a) { + Ztb(this, a); + }; + _2.Ob = function Ad() { + return this.c.Ob() || this.e.Ob(); + }; + _2.Pb = function Bd() { + var a; + if (!this.e.Ob()) { + a = RD(this.c.Pb(), 44); + this.b = a.ld(); + this.a = RD(a.md(), 16); + this.e = this.a.Kc(); + } + return this.sc(this.b, this.e.Pb()); + }; + _2.Qb = function Cd() { + this.e.Qb(); + RD(Hvb(this.a), 16).dc() && this.c.Qb(); + --this.d.d; + }; + sfb(xve, "AbstractMapBasedMultimap/Itr", 748); + feb(1129, 748, Ave, Dd); + _2.sc = function Ed(a, b) { + return b; + }; + sfb(xve, "AbstractMapBasedMultimap/1", 1129); + feb(1130, 1, {}, Fd); + _2.Kb = function Gd(a) { + return RD(a, 16).Nc(); + }; + sfb(xve, "AbstractMapBasedMultimap/1methodref$spliterator$Type", 1130); + feb(1131, 748, Ave, Hd); + _2.sc = function Id(a, b) { + return new gp(a, b); + }; + sfb(xve, "AbstractMapBasedMultimap/2", 1131); + var VK = ufb(Bve, "Map"); + feb(2065, 1, Cve); + _2.wc = function Td(a) { + Bvb(this, a); + }; + _2.yc = function $d(a, b, c2) { + return Cvb(this, a, b, c2); + }; + _2.$b = function Od() { + this.vc().$b(); + }; + _2.tc = function Pd(a) { + return Jd(this, a); + }; + _2._b = function Qd(a) { + return !!Kd(this, a, false); + }; + _2.uc = function Rd(a) { + var b, c2, d; + for (c2 = this.vc().Kc(); c2.Ob(); ) { + b = RD(c2.Pb(), 44); + d = b.md(); + if (dE(a) === dE(d) || a != null && pb(a, d)) { + return true; + } + } + return false; + }; + _2.Fb = function Sd(a) { + var b, c2, d; + if (a === this) { + return true; + } + if (!ZD(a, 85)) { + return false; + } + d = RD(a, 85); + if (this.gc() != d.gc()) { + return false; + } + for (c2 = d.vc().Kc(); c2.Ob(); ) { + b = RD(c2.Pb(), 44); + if (!this.tc(b)) { + return false; + } + } + return true; + }; + _2.xc = function Ud(a) { + return Wd(Kd(this, a, false)); + }; + _2.Hb = function Xd() { + return Bob(this.vc()); + }; + _2.dc = function Yd() { + return this.gc() == 0; + }; + _2.ec = function Zd() { + return new Xkb(this); + }; + _2.zc = function _d(a, b) { + throw Adb(new kib("Put not supported on this map")); + }; + _2.Ac = function ae(a) { + Ld(this, a); + }; + _2.Bc = function be(a) { + return Wd(Kd(this, a, true)); + }; + _2.gc = function ce() { + return this.vc().gc(); + }; + _2.Ib = function de() { + return Md(this); + }; + _2.Cc = function ee() { + return new glb(this); + }; + sfb(Bve, "AbstractMap", 2065); + feb(2085, 2065, Cve); + _2.bc = function ge() { + return new rf(this); + }; + _2.vc = function he() { + return fe(this); + }; + _2.ec = function ie() { + var a; + a = this.g; + return !a ? this.g = this.bc() : a; + }; + _2.Cc = function je() { + var a; + a = this.i; + return !a ? this.i = new nw(this) : a; + }; + sfb(xve, "Maps/ViewCachingAbstractMap", 2085); + feb(402, 2085, Cve, ne); + _2.xc = function se(a) { + return ke(this, a); + }; + _2.Bc = function ve(a) { + return le(this, a); + }; + _2.$b = function oe() { + this.d == this.e.c ? this.e.$b() : Ar(new mf(this)); + }; + _2._b = function pe(a) { + return Wv(this.d, a); + }; + _2.Ec = function qe() { + return new df(this); + }; + _2.Dc = function() { + return this.Ec(); + }; + _2.Fb = function re2(a) { + return this === a || pb(this.d, a); + }; + _2.Hb = function te() { + return tb(this.d); + }; + _2.ec = function ue() { + return this.e.ec(); + }; + _2.gc = function we() { + return this.d.gc(); + }; + _2.Ib = function xe() { + return jeb(this.d); + }; + sfb(xve, "AbstractMapBasedMultimap/AsMap", 402); + var cJ = ufb(mve, "Iterable"); + feb(31, 1, Dve); + _2.Jc = function Le(a) { + xgb(this, a); + }; + _2.Lc = function Ne() { + return this.Oc(); + }; + _2.Nc = function Pe() { + return new Swb(this, 0); + }; + _2.Oc = function Qe() { + return new SDb(null, this.Nc()); + }; + _2.Fc = function Ge(a) { + throw Adb(new kib("Add not supported on this collection")); + }; + _2.Gc = function He(a) { + return ye(this, a); + }; + _2.$b = function Ie() { + Ae(this); + }; + _2.Hc = function Je(a) { + return ze(this, a, false); + }; + _2.Ic = function Ke(a) { + return Be(this, a); + }; + _2.dc = function Me() { + return this.gc() == 0; + }; + _2.Mc = function Oe(a) { + return ze(this, a, true); + }; + _2.Pc = function Re() { + return De(this); + }; + _2.Qc = function Se(a) { + return Ee(this, a); + }; + _2.Ib = function Te() { + return Fe(this); + }; + sfb(Bve, "AbstractCollection", 31); + var bL = ufb(Bve, "Set"); + feb(Eve, 31, Fve); + _2.Nc = function Ye() { + return new Swb(this, 1); + }; + _2.Fb = function We(a) { + return Ue(this, a); + }; + _2.Hb = function Xe() { + return Bob(this); + }; + sfb(Bve, "AbstractSet", Eve); + feb(2068, Eve, Fve); + sfb(xve, "Sets/ImprovedAbstractSet", 2068); + feb(2069, 2068, Fve); + _2.$b = function $e() { + this.Rc().$b(); + }; + _2.Hc = function _e(a) { + return Ze(this, a); + }; + _2.dc = function af() { + return this.Rc().dc(); + }; + _2.Mc = function bf(a) { + var b; + if (this.Hc(a) && ZD(a, 44)) { + b = RD(a, 44); + return this.Rc().ec().Mc(b.ld()); + } + return false; + }; + _2.gc = function cf() { + return this.Rc().gc(); + }; + sfb(xve, "Maps/EntrySet", 2069); + feb(1127, 2069, Fve, df); + _2.Hc = function ef(a) { + return Nk(this.a.d.vc(), a); + }; + _2.Kc = function ff() { + return new mf(this.a); + }; + _2.Rc = function gf() { + return this.a; + }; + _2.Mc = function hf(a) { + var b; + if (!Nk(this.a.d.vc(), a)) { + return false; + } + b = RD(Hvb(RD(a, 44)), 44); + Tc2(this.a.e, b.ld()); + return true; + }; + _2.Nc = function jf() { + return gk(this.a.d.vc().Nc(), new kf(this.a)); + }; + sfb(xve, "AbstractMapBasedMultimap/AsMap/AsMapEntries", 1127); + feb(1128, 1, {}, kf); + _2.Kb = function lf(a) { + return me(this.a, RD(a, 44)); + }; + sfb(xve, "AbstractMapBasedMultimap/AsMap/AsMapEntries/0methodref$wrapEntry$Type", 1128); + feb(746, 1, Ave, mf); + _2.Nb = function nf(a) { + Ztb(this, a); + }; + _2.Pb = function pf() { + var a; + return a = RD(this.b.Pb(), 44), this.a = RD(a.md(), 16), me(this.c, a); + }; + _2.Ob = function of() { + return this.b.Ob(); + }; + _2.Qb = function qf() { + Vb(!!this.a); + this.b.Qb(); + this.c.e.d -= this.a.gc(); + this.a.$b(); + this.a = null; + }; + sfb(xve, "AbstractMapBasedMultimap/AsMap/AsMapIterator", 746); + feb(542, 2068, Fve, rf); + _2.$b = function sf() { + this.b.$b(); + }; + _2.Hc = function tf(a) { + return this.b._b(a); + }; + _2.Jc = function uf(a) { + Qb(a); + this.b.wc(new lw(a)); + }; + _2.dc = function vf() { + return this.b.dc(); + }; + _2.Kc = function wf() { + return new aw(this.b.vc().Kc()); + }; + _2.Mc = function xf(a) { + if (this.b._b(a)) { + this.b.Bc(a); + return true; + } + return false; + }; + _2.gc = function yf() { + return this.b.gc(); + }; + sfb(xve, "Maps/KeySet", 542); + feb(327, 542, Fve, zf); + _2.$b = function Af() { + var a; + Ar((a = this.b.vc().Kc(), new Hf(this, a))); + }; + _2.Ic = function Bf(a) { + return this.b.ec().Ic(a); + }; + _2.Fb = function Cf(a) { + return this === a || pb(this.b.ec(), a); + }; + _2.Hb = function Df() { + return tb(this.b.ec()); + }; + _2.Kc = function Ef() { + var a; + return a = this.b.vc().Kc(), new Hf(this, a); + }; + _2.Mc = function Ff(a) { + var b, c2; + c2 = 0; + b = RD(this.b.Bc(a), 16); + if (b) { + c2 = b.gc(); + b.$b(); + this.a.d -= c2; + } + return c2 > 0; + }; + _2.Nc = function Gf() { + return this.b.ec().Nc(); + }; + sfb(xve, "AbstractMapBasedMultimap/KeySet", 327); + feb(747, 1, Ave, Hf); + _2.Nb = function If(a) { + Ztb(this, a); + }; + _2.Ob = function Jf() { + return this.c.Ob(); + }; + _2.Pb = function Kf() { + this.a = RD(this.c.Pb(), 44); + return this.a.ld(); + }; + _2.Qb = function Lf() { + var a; + Vb(!!this.a); + a = RD(this.a.md(), 16); + this.c.Qb(); + this.b.a.d -= a.gc(); + a.$b(); + this.a = null; + }; + sfb(xve, "AbstractMapBasedMultimap/KeySet/1", 747); + feb(503, 402, { 85: 1, 133: 1 }, Mf); + _2.bc = function Nf() { + return this.Sc(); + }; + _2.ec = function Qf() { + return this.Uc(); + }; + _2.Sc = function Of() { + return new eg(this.c, this.Wc()); + }; + _2.Tc = function Pf() { + return this.Wc().Tc(); + }; + _2.Uc = function Rf() { + var a; + return a = this.b, !a ? this.b = this.Sc() : a; + }; + _2.Vc = function Sf() { + return this.Wc().Vc(); + }; + _2.Wc = function Tf() { + return RD(this.d, 133); + }; + sfb(xve, "AbstractMapBasedMultimap/SortedAsMap", 503); + feb(446, 503, Gve, Uf); + _2.bc = function Wf() { + return new gg(this.a, RD(RD(this.d, 133), 139)); + }; + _2.Sc = function Xf() { + return new gg(this.a, RD(RD(this.d, 133), 139)); + }; + _2.ec = function _f() { + var a; + return a = this.b, RD(!a ? this.b = new gg(this.a, RD(RD(this.d, 133), 139)) : a, 277); + }; + _2.Uc = function ag() { + var a; + return a = this.b, RD(!a ? this.b = new gg(this.a, RD(RD(this.d, 133), 139)) : a, 277); + }; + _2.Wc = function cg() { + return RD(RD(this.d, 133), 139); + }; + _2.Xc = function Vf(a) { + return RD(RD(this.d, 133), 139).Xc(a); + }; + _2.Yc = function Yf(a) { + return RD(RD(this.d, 133), 139).Yc(a); + }; + _2.Zc = function Zf(a, b) { + return new Uf(this.a, RD(RD(this.d, 133), 139).Zc(a, b)); + }; + _2.$c = function $f(a) { + return RD(RD(this.d, 133), 139).$c(a); + }; + _2._c = function bg(a) { + return RD(RD(this.d, 133), 139)._c(a); + }; + _2.ad = function dg(a, b) { + return new Uf(this.a, RD(RD(this.d, 133), 139).ad(a, b)); + }; + sfb(xve, "AbstractMapBasedMultimap/NavigableAsMap", 446); + feb(502, 327, Hve, eg); + _2.Nc = function fg() { + return this.b.ec().Nc(); + }; + sfb(xve, "AbstractMapBasedMultimap/SortedKeySet", 502); + feb(401, 502, Ive, gg); + sfb(xve, "AbstractMapBasedMultimap/NavigableKeySet", 401); + feb(551, 31, Dve, lg); + _2.Fc = function mg(a) { + var b, c2; + ig(this); + c2 = this.d.dc(); + b = this.d.Fc(a); + if (b) { + ++this.f.d; + c2 && hg(this); + } + return b; + }; + _2.Gc = function ng(a) { + var b, c2, d; + if (a.dc()) { + return false; + } + d = (ig(this), this.d.gc()); + b = this.d.Gc(a); + if (b) { + c2 = this.d.gc(); + this.f.d += c2 - d; + d == 0 && hg(this); + } + return b; + }; + _2.$b = function og() { + var a; + a = (ig(this), this.d.gc()); + if (a == 0) { + return; + } + this.d.$b(); + this.f.d -= a; + jg(this); + }; + _2.Hc = function pg(a) { + ig(this); + return this.d.Hc(a); + }; + _2.Ic = function qg(a) { + ig(this); + return this.d.Ic(a); + }; + _2.Fb = function rg(a) { + if (a === this) { + return true; + } + ig(this); + return pb(this.d, a); + }; + _2.Hb = function sg() { + ig(this); + return tb(this.d); + }; + _2.Kc = function tg() { + ig(this); + return new Og(this); + }; + _2.Mc = function ug(a) { + var b; + ig(this); + b = this.d.Mc(a); + if (b) { + --this.f.d; + jg(this); + } + return b; + }; + _2.gc = function vg() { + return kg(this); + }; + _2.Nc = function wg() { + return ig(this), this.d.Nc(); + }; + _2.Ib = function xg() { + ig(this); + return jeb(this.d); + }; + sfb(xve, "AbstractMapBasedMultimap/WrappedCollection", 551); + var QK = ufb(Bve, "List"); + feb(744, 551, { 20: 1, 31: 1, 16: 1, 15: 1 }, yg); + _2.jd = function Hg(a) { + tvb(this, a); + }; + _2.Nc = function Ig() { + return ig(this), this.d.Nc(); + }; + _2.bd = function zg(a, b) { + var c2; + ig(this); + c2 = this.d.dc(); + RD(this.d, 15).bd(a, b); + ++this.a.d; + c2 && hg(this); + }; + _2.cd = function Ag(a, b) { + var c2, d, e; + if (b.dc()) { + return false; + } + e = (ig(this), this.d.gc()); + c2 = RD(this.d, 15).cd(a, b); + if (c2) { + d = this.d.gc(); + this.a.d += d - e; + e == 0 && hg(this); + } + return c2; + }; + _2.Xb = function Bg(a) { + ig(this); + return RD(this.d, 15).Xb(a); + }; + _2.dd = function Cg(a) { + ig(this); + return RD(this.d, 15).dd(a); + }; + _2.ed = function Dg() { + ig(this); + return new Ug(this); + }; + _2.fd = function Eg(a) { + ig(this); + return new Vg(this, a); + }; + _2.gd = function Fg(a) { + var b; + ig(this); + b = RD(this.d, 15).gd(a); + --this.a.d; + jg(this); + return b; + }; + _2.hd = function Gg(a, b) { + ig(this); + return RD(this.d, 15).hd(a, b); + }; + _2.kd = function Jg(a, b) { + ig(this); + return Vc(this.a, this.e, RD(this.d, 15).kd(a, b), !this.b ? this : this.b); + }; + sfb(xve, "AbstractMapBasedMultimap/WrappedList", 744); + feb(1126, 744, { 20: 1, 31: 1, 16: 1, 15: 1, 59: 1 }, Kg); + sfb(xve, "AbstractMapBasedMultimap/RandomAccessWrappedList", 1126); + feb(628, 1, Ave, Og); + _2.Nb = function Qg(a) { + Ztb(this, a); + }; + _2.Ob = function Rg() { + Ng(this); + return this.b.Ob(); + }; + _2.Pb = function Sg() { + Ng(this); + return this.b.Pb(); + }; + _2.Qb = function Tg() { + Mg(this); + }; + sfb(xve, "AbstractMapBasedMultimap/WrappedCollection/WrappedIterator", 628); + feb(745, 628, Jve, Ug, Vg); + _2.Qb = function _g() { + Mg(this); + }; + _2.Rb = function Wg(a) { + var b; + b = kg(this.a) == 0; + (Ng(this), RD(this.b, 128)).Rb(a); + ++this.a.a.d; + b && hg(this.a); + }; + _2.Sb = function Xg() { + return (Ng(this), RD(this.b, 128)).Sb(); + }; + _2.Tb = function Yg() { + return (Ng(this), RD(this.b, 128)).Tb(); + }; + _2.Ub = function Zg() { + return (Ng(this), RD(this.b, 128)).Ub(); + }; + _2.Vb = function $g() { + return (Ng(this), RD(this.b, 128)).Vb(); + }; + _2.Wb = function ah(a) { + (Ng(this), RD(this.b, 128)).Wb(a); + }; + sfb(xve, "AbstractMapBasedMultimap/WrappedList/WrappedListIterator", 745); + feb(743, 551, Hve, bh); + _2.Nc = function dh() { + return ig(this), this.d.Nc(); + }; + sfb(xve, "AbstractMapBasedMultimap/WrappedSortedSet", 743); + feb(1125, 743, Ive, eh); + sfb(xve, "AbstractMapBasedMultimap/WrappedNavigableSet", 1125); + feb(1124, 551, Fve, fh); + _2.Nc = function gh() { + return ig(this), this.d.Nc(); + }; + sfb(xve, "AbstractMapBasedMultimap/WrappedSet", 1124); + feb(1133, 1, {}, hh); + _2.Kb = function ih(a) { + return fd(RD(a, 44)); + }; + sfb(xve, "AbstractMapBasedMultimap/lambda$1$Type", 1133); + feb(1132, 1, {}, jh); + _2.Kb = function kh(a) { + return new gp(this.a, a); + }; + sfb(xve, "AbstractMapBasedMultimap/lambda$2$Type", 1132); + var UK = ufb(Bve, "Map/Entry"); + feb(358, 1, Kve); + _2.Fb = function lh(a) { + var b; + if (ZD(a, 44)) { + b = RD(a, 44); + return Hb(this.ld(), b.ld()) && Hb(this.md(), b.md()); + } + return false; + }; + _2.Hb = function mh() { + var a, b; + a = this.ld(); + b = this.md(); + return (a == null ? 0 : tb(a)) ^ (b == null ? 0 : tb(b)); + }; + _2.nd = function nh(a) { + throw Adb(new jib()); + }; + _2.Ib = function oh() { + return this.ld() + "=" + this.md(); + }; + sfb(xve, Lve, 358); + feb(2086, 31, Dve); + _2.$b = function ph() { + this.od().$b(); + }; + _2.Hc = function qh(a) { + var b; + if (ZD(a, 44)) { + b = RD(a, 44); + return Cc(this.od(), b.ld(), b.md()); + } + return false; + }; + _2.Mc = function rh(a) { + var b; + if (ZD(a, 44)) { + b = RD(a, 44); + return Gc(this.od(), b.ld(), b.md()); + } + return false; + }; + _2.gc = function sh() { + return this.od().d; + }; + sfb(xve, "Multimaps/Entries", 2086); + feb(749, 2086, Dve, th); + _2.Kc = function uh() { + return this.a.kc(); + }; + _2.od = function vh() { + return this.a; + }; + _2.Nc = function wh() { + return this.a.lc(); + }; + sfb(xve, "AbstractMultimap/Entries", 749); + feb(750, 749, Fve, xh); + _2.Nc = function Ah() { + return this.a.lc(); + }; + _2.Fb = function yh(a) { + return Rx(this, a); + }; + _2.Hb = function zh() { + return Sx(this); + }; + sfb(xve, "AbstractMultimap/EntrySet", 750); + feb(751, 31, Dve, Bh); + _2.$b = function Ch() { + this.a.$b(); + }; + _2.Hc = function Dh(a) { + return Dc2(this.a, a); + }; + _2.Kc = function Eh() { + return this.a.nc(); + }; + _2.gc = function Fh() { + return this.a.d; + }; + _2.Nc = function Gh() { + return this.a.oc(); + }; + sfb(xve, "AbstractMultimap/Values", 751); + feb(2087, 31, { 849: 1, 20: 1, 31: 1, 16: 1 }); + _2.Jc = function Oh(a) { + Qb(a); + Ih(this).Jc(new lx(a)); + }; + _2.Nc = function Sh() { + var a; + return a = Ih(this).Nc(), ek(a, new sx(), 64 | a.yd() & 1296, this.a.d); + }; + _2.Fc = function Kh(a) { + Hh(); + return true; + }; + _2.Gc = function Lh(a) { + return Qb(this), Qb(a), ZD(a, 552) ? nx(RD(a, 849)) : !a.dc() && xr(this, a.Kc()); + }; + _2.Hc = function Mh(a) { + var b; + return b = RD(Xv(nd(this.a), a), 16), (!b ? 0 : b.gc()) > 0; + }; + _2.Fb = function Nh(a) { + return ox(this, a); + }; + _2.Hb = function Ph() { + return tb(Ih(this)); + }; + _2.dc = function Qh() { + return Ih(this).dc(); + }; + _2.Mc = function Rh(a) { + return Rw(this, a, 1) > 0; + }; + _2.Ib = function Th() { + return jeb(Ih(this)); + }; + sfb(xve, "AbstractMultiset", 2087); + feb(2089, 2068, Fve); + _2.$b = function Uh() { + Nc(this.a.a); + }; + _2.Hc = function Vh(a) { + var b, c2; + if (ZD(a, 504)) { + c2 = RD(a, 425); + if (RD(c2.a.md(), 16).gc() <= 0) { + return false; + } + b = Qw(this.a, c2.a.ld()); + return b == RD(c2.a.md(), 16).gc(); + } + return false; + }; + _2.Mc = function Wh(a) { + var b, c2, d, e; + if (ZD(a, 504)) { + c2 = RD(a, 425); + b = c2.a.ld(); + d = RD(c2.a.md(), 16).gc(); + if (d != 0) { + e = this.a; + return qx(e, b, d); + } + } + return false; + }; + sfb(xve, "Multisets/EntrySet", 2089); + feb(1139, 2089, Fve, Xh); + _2.Kc = function Yh() { + return new _w(fe(nd(this.a.a)).Kc()); + }; + _2.gc = function Zh() { + return nd(this.a.a).gc(); + }; + sfb(xve, "AbstractMultiset/EntrySet", 1139); + feb(627, 742, zve); + _2.hc = function ai() { + return this.pd(); + }; + _2.jc = function bi() { + return this.qd(); + }; + _2.cc = function ei(a) { + return this.rd(a); + }; + _2.fc = function gi(a) { + return this.sd(a); + }; + _2.Zb = function _h() { + var a; + return a = this.f, !a ? this.f = this.ac() : a; + }; + _2.qd = function ci() { + return yob(), yob(), xob; + }; + _2.Fb = function di(a) { + return xw(this, a); + }; + _2.rd = function fi(a) { + return RD(Qc(this, a), 21); + }; + _2.sd = function hi(a) { + return RD(Sc2(this, a), 21); + }; + _2.mc = function ii(a) { + return yob(), new Lqb(RD(a, 21)); + }; + _2.pc = function ji(a, b) { + return new fh(this, a, RD(b, 21)); + }; + sfb(xve, "AbstractSetMultimap", 627); + feb(1723, 627, zve); + _2.hc = function mi() { + return new yAb(this.b); + }; + _2.pd = function ni() { + return new yAb(this.b); + }; + _2.jc = function oi() { + return Zx(new yAb(this.b)); + }; + _2.qd = function pi2() { + return Zx(new yAb(this.b)); + }; + _2.cc = function qi(a) { + return RD(RD(Qc(this, a), 21), 87); + }; + _2.rd = function ri(a) { + return RD(RD(Qc(this, a), 21), 87); + }; + _2.fc = function si(a) { + return RD(RD(Sc2(this, a), 21), 87); + }; + _2.sd = function ti(a) { + return RD(RD(Sc2(this, a), 21), 87); + }; + _2.mc = function ui(a) { + return ZD(a, 277) ? Zx(RD(a, 277)) : (yob(), new jrb(RD(a, 87))); + }; + _2.Zb = function li() { + var a; + return a = this.f, !a ? this.f = ZD(this.c, 139) ? new Uf(this, RD(this.c, 139)) : ZD(this.c, 133) ? new Mf(this, RD(this.c, 133)) : new ne(this, this.c) : a; + }; + _2.pc = function vi(a, b) { + return ZD(b, 277) ? new eh(this, a, RD(b, 277)) : new bh(this, a, RD(b, 87)); + }; + sfb(xve, "AbstractSortedSetMultimap", 1723); + feb(1724, 1723, zve); + _2.Zb = function xi() { + var a; + return a = this.f, RD(RD(!a ? this.f = ZD(this.c, 139) ? new Uf(this, RD(this.c, 139)) : ZD(this.c, 133) ? new Mf(this, RD(this.c, 133)) : new ne(this, this.c) : a, 133), 139); + }; + _2.ec = function zi() { + var a; + return a = this.i, RD(RD(!a ? this.i = ZD(this.c, 139) ? new gg(this, RD(this.c, 139)) : ZD(this.c, 133) ? new eg(this, RD(this.c, 133)) : new zf(this, this.c) : a, 87), 277); + }; + _2.bc = function yi() { + return ZD(this.c, 139) ? new gg(this, RD(this.c, 139)) : ZD(this.c, 133) ? new eg(this, RD(this.c, 133)) : new zf(this, this.c); + }; + sfb(xve, "AbstractSortedKeySortedSetMultimap", 1724); + feb(2109, 1, { 2046: 1 }); + _2.Fb = function Ai(a) { + return Qy(this, a); + }; + _2.Hb = function Bi() { + var a; + return Bob((a = this.g, !a ? this.g = new Di(this) : a)); + }; + _2.Ib = function Ci() { + var a; + return Md((a = this.f, !a ? this.f = new Zj(this) : a)); + }; + sfb(xve, "AbstractTable", 2109); + feb(679, Eve, Fve, Di); + _2.$b = function Ei() { + Xi(); + }; + _2.Hc = function Fi(a) { + var b, c2; + if (ZD(a, 479)) { + b = RD(a, 697); + c2 = RD(Xv(bj(this.a), Qm(b.c.e, b.b)), 85); + return !!c2 && Nk(c2.vc(), new gp(Qm(b.c.c, b.a), Ui(b.c, b.b, b.a))); + } + return false; + }; + _2.Kc = function Gi() { + return Vi(this.a); + }; + _2.Mc = function Hi(a) { + var b, c2; + if (ZD(a, 479)) { + b = RD(a, 697); + c2 = RD(Xv(bj(this.a), Qm(b.c.e, b.b)), 85); + return !!c2 && Ok(c2.vc(), new gp(Qm(b.c.c, b.a), Ui(b.c, b.b, b.a))); + } + return false; + }; + _2.gc = function Ii() { + return dj(this.a); + }; + _2.Nc = function Ji() { + return Wi(this.a); + }; + sfb(xve, "AbstractTable/CellSet", 679); + feb(2025, 31, Dve, Ki); + _2.$b = function Li() { + Xi(); + }; + _2.Hc = function Mi(a) { + return Yi(this.a, a); + }; + _2.Kc = function Ni() { + return fj(this.a); + }; + _2.gc = function Oi() { + return dj(this.a); + }; + _2.Nc = function Pi() { + return gj(this.a); + }; + sfb(xve, "AbstractTable/Values", 2025); + feb(1697, 1696, zve); + sfb(xve, "ArrayListMultimapGwtSerializationDependencies", 1697); + feb(520, 1697, zve, Ri, Si); + _2.hc = function Ti() { + return new cnb(this.a); + }; + _2.a = 0; + sfb(xve, "ArrayListMultimap", 520); + feb(678, 2109, { 678: 1, 2046: 1, 3: 1 }, hj); + sfb(xve, "ArrayTable", 678); + feb(2021, 399, yve, ij); + _2.Xb = function jj(a) { + return new pj(this.a, a); + }; + sfb(xve, "ArrayTable/1", 2021); + feb(2022, 1, {}, kj); + _2.td = function lj(a) { + return new pj(this.a, a); + }; + sfb(xve, "ArrayTable/1methodref$getCell$Type", 2022); + feb(2110, 1, { 697: 1 }); + _2.Fb = function mj(a) { + var b; + if (a === this) { + return true; + } + if (ZD(a, 479)) { + b = RD(a, 697); + return Hb(Qm(this.c.e, this.b), Qm(b.c.e, b.b)) && Hb(Qm(this.c.c, this.a), Qm(b.c.c, b.a)) && Hb(Ui(this.c, this.b, this.a), Ui(b.c, b.b, b.a)); + } + return false; + }; + _2.Hb = function nj() { + return Tnb(cD(WC(jJ, 1), rve, 1, 5, [Qm(this.c.e, this.b), Qm(this.c.c, this.a), Ui(this.c, this.b, this.a)])); + }; + _2.Ib = function oj() { + return "(" + Qm(this.c.e, this.b) + "," + Qm(this.c.c, this.a) + ")=" + Ui(this.c, this.b, this.a); + }; + sfb(xve, "Tables/AbstractCell", 2110); + feb(479, 2110, { 479: 1, 697: 1 }, pj); + _2.a = 0; + _2.b = 0; + _2.d = 0; + sfb(xve, "ArrayTable/2", 479); + feb(2024, 1, {}, qj); + _2.td = function rj(a) { + return _i6(this.a, a); + }; + sfb(xve, "ArrayTable/2methodref$getValue$Type", 2024); + feb(2023, 399, yve, sj); + _2.Xb = function tj(a) { + return _i6(this.a, a); + }; + sfb(xve, "ArrayTable/3", 2023); + feb(2077, 2065, Cve); + _2.$b = function vj() { + Ar(this.kc()); + }; + _2.vc = function wj() { + return new gw(this); + }; + _2.lc = function xj() { + return new Uwb(this.kc(), this.gc()); + }; + sfb(xve, "Maps/IteratorBasedAbstractMap", 2077); + feb(842, 2077, Cve); + _2.$b = function Bj() { + throw Adb(new jib()); + }; + _2._b = function Cj(a) { + return En(this.c, a); + }; + _2.kc = function Dj() { + return new Rj(this, this.c.b.c.gc()); + }; + _2.lc = function Ej() { + return fk(this.c.b.c.gc(), 16, new Lj(this)); + }; + _2.xc = function Fj(a) { + var b; + b = RD(Fn(this.c, a), 17); + return !b ? null : this.vd(b.a); + }; + _2.dc = function Gj() { + return this.c.b.c.dc(); + }; + _2.ec = function Hj() { + return hn(this.c); + }; + _2.zc = function Ij(a, b) { + var c2; + c2 = RD(Fn(this.c, a), 17); + if (!c2) { + throw Adb(new agb(this.ud() + " " + a + " not in " + hn(this.c))); + } + return this.wd(c2.a, b); + }; + _2.Bc = function Jj(a) { + throw Adb(new jib()); + }; + _2.gc = function Kj() { + return this.c.b.c.gc(); + }; + sfb(xve, "ArrayTable/ArrayMap", 842); + feb(2020, 1, {}, Lj); + _2.td = function Mj(a) { + return yj(this.a, a); + }; + sfb(xve, "ArrayTable/ArrayMap/0methodref$getEntry$Type", 2020); + feb(2018, 358, Kve, Nj); + _2.ld = function Oj() { + return zj(this.a, this.b); + }; + _2.md = function Pj() { + return this.a.vd(this.b); + }; + _2.nd = function Qj(a) { + return this.a.wd(this.b, a); + }; + _2.b = 0; + sfb(xve, "ArrayTable/ArrayMap/1", 2018); + feb(2019, 399, yve, Rj); + _2.Xb = function Sj(a) { + return yj(this.a, a); + }; + sfb(xve, "ArrayTable/ArrayMap/2", 2019); + feb(2017, 842, Cve, Tj); + _2.ud = function Uj() { + return "Column"; + }; + _2.vd = function Vj(a) { + return Ui(this.b, this.a, a); + }; + _2.wd = function Wj(a, b) { + return cj(this.b, this.a, a, b); + }; + _2.a = 0; + sfb(xve, "ArrayTable/Row", 2017); + feb(843, 842, Cve, Zj); + _2.vd = function _j(a) { + return new Tj(this.a, a); + }; + _2.zc = function ak(a, b) { + return RD(b, 85), Xj(); + }; + _2.wd = function bk(a, b) { + return RD(b, 85), Yj(); + }; + _2.ud = function $j() { + return "Row"; + }; + sfb(xve, "ArrayTable/RowMap", 843); + feb(1157, 1, Pve, hk); + _2.Ad = function lk(a) { + return (this.a.yd() & -262 & a) != 0; + }; + _2.yd = function ik() { + return this.a.yd() & -262; + }; + _2.zd = function jk() { + return this.a.zd(); + }; + _2.Nb = function kk(a) { + this.a.Nb(new pk(a, this.b)); + }; + _2.Bd = function mk(a) { + return this.a.Bd(new nk(a, this.b)); + }; + sfb(xve, "CollectSpliterators/1", 1157); + feb(1158, 1, Qve, nk); + _2.Cd = function ok(a) { + this.a.Cd(this.b.Kb(a)); + }; + sfb(xve, "CollectSpliterators/1/lambda$0$Type", 1158); + feb(1159, 1, Qve, pk); + _2.Cd = function qk(a) { + this.a.Cd(this.b.Kb(a)); + }; + sfb(xve, "CollectSpliterators/1/lambda$1$Type", 1159); + feb(1154, 1, Pve, rk); + _2.Ad = function vk(a) { + return ((16464 | this.b) & a) != 0; + }; + _2.yd = function sk() { + return 16464 | this.b; + }; + _2.zd = function tk() { + return this.a.zd(); + }; + _2.Nb = function uk(a) { + this.a.Qe(new zk(a, this.c)); + }; + _2.Bd = function wk(a) { + return this.a.Re(new xk(a, this.c)); + }; + _2.b = 0; + sfb(xve, "CollectSpliterators/1WithCharacteristics", 1154); + feb(1155, 1, Rve, xk); + _2.Dd = function yk(a) { + this.a.Cd(this.b.td(a)); + }; + sfb(xve, "CollectSpliterators/1WithCharacteristics/lambda$0$Type", 1155); + feb(1156, 1, Rve, zk); + _2.Dd = function Ak(a) { + this.a.Cd(this.b.td(a)); + }; + sfb(xve, "CollectSpliterators/1WithCharacteristics/lambda$1$Type", 1156); + feb(1150, 1, Pve); + _2.Ad = function Gk(a) { + return (this.a & a) != 0; + }; + _2.yd = function Dk() { + return this.a; + }; + _2.zd = function Ek() { + !!this.e && (this.b = Kgb(this.b, this.e.zd())); + return Kgb(this.b, 0); + }; + _2.Nb = function Fk(a) { + if (this.e) { + this.e.Nb(a); + this.e = null; + } + this.c.Nb(new Kk(this, a)); + this.b = 0; + }; + _2.Bd = function Hk(a) { + while (true) { + if (!!this.e && this.e.Bd(a)) { + Pdb(this.b, Sve) && (this.b = Vdb(this.b, 1)); + return true; + } else { + this.e = null; + } + if (!this.c.Bd(new Ik(this))) { + return false; + } + } + }; + _2.a = 0; + _2.b = 0; + sfb(xve, "CollectSpliterators/FlatMapSpliterator", 1150); + feb(1152, 1, Qve, Ik); + _2.Cd = function Jk(a) { + Bk(this.a, a); + }; + sfb(xve, "CollectSpliterators/FlatMapSpliterator/lambda$0$Type", 1152); + feb(1153, 1, Qve, Kk); + _2.Cd = function Lk(a) { + Ck(this.a, this.b, a); + }; + sfb(xve, "CollectSpliterators/FlatMapSpliterator/lambda$1$Type", 1153); + feb(1151, 1150, Pve, Mk); + sfb(xve, "CollectSpliterators/FlatMapSpliteratorOfObject", 1151); + feb(253, 1, Tve); + _2.Fd = function Sk(a) { + return this.Ed(RD(a, 253)); + }; + _2.Ed = function Rk(a) { + var b; + if (a == (kl(), jl)) { + return 1; + } + if (a == (Wk(), Vk)) { + return -1; + } + b = (ux(), Leb(this.a, a.a)); + if (b != 0) { + return b; + } + return ZD(this, 526) == ZD(a, 526) ? 0 : ZD(this, 526) ? 1 : -1; + }; + _2.Id = function Tk() { + return this.a; + }; + _2.Fb = function Uk(a) { + return Pk(this, a); + }; + sfb(xve, "Cut", 253); + feb(1823, 253, Tve, Xk); + _2.Ed = function Yk(a) { + return a == this ? 0 : 1; + }; + _2.Gd = function Zk(a) { + throw Adb(new Ceb()); + }; + _2.Hd = function $k(a) { + a.a += "+∞)"; + }; + _2.Id = function _k() { + throw Adb(new dgb(Uve)); + }; + _2.Hb = function al() { + return gib(), jFb(this); + }; + _2.Jd = function bl(a) { + return false; + }; + _2.Ib = function cl() { + return "+∞"; + }; + var Vk; + sfb(xve, "Cut/AboveAll", 1823); + feb(526, 253, { 253: 1, 526: 1, 3: 1, 34: 1 }, dl); + _2.Gd = function el(a) { + Yhb((a.a += "(", a), this.a); + }; + _2.Hd = function fl(a) { + Thb(Yhb(a, this.a), 93); + }; + _2.Hb = function gl() { + return ~tb(this.a); + }; + _2.Jd = function hl(a) { + return ux(), Leb(this.a, a) < 0; + }; + _2.Ib = function il() { + return "/" + this.a + "\\"; + }; + sfb(xve, "Cut/AboveValue", 526); + feb(1822, 253, Tve, ll); + _2.Ed = function ml(a) { + return a == this ? 0 : -1; + }; + _2.Gd = function nl(a) { + a.a += "(-∞"; + }; + _2.Hd = function ol(a) { + throw Adb(new Ceb()); + }; + _2.Id = function pl() { + throw Adb(new dgb(Uve)); + }; + _2.Hb = function ql() { + return gib(), jFb(this); + }; + _2.Jd = function rl(a) { + return true; + }; + _2.Ib = function sl() { + return "-∞"; + }; + var jl; + sfb(xve, "Cut/BelowAll", 1822); + feb(1824, 253, Tve, tl); + _2.Gd = function ul(a) { + Yhb((a.a += "[", a), this.a); + }; + _2.Hd = function vl(a) { + Thb(Yhb(a, this.a), 41); + }; + _2.Hb = function wl() { + return tb(this.a); + }; + _2.Jd = function xl(a) { + return ux(), Leb(this.a, a) <= 0; + }; + _2.Ib = function yl() { + return "\\" + this.a + "/"; + }; + sfb(xve, "Cut/BelowValue", 1824); + feb(547, 1, Vve); + _2.Jc = function Bl(a) { + xgb(this, a); + }; + _2.Ib = function Cl() { + return Lr(RD(Rb(this, "use Optional.orNull() instead of Optional.or(null)"), 20).Kc()); + }; + sfb(xve, "FluentIterable", 547); + feb(442, 547, Vve, Dl); + _2.Kc = function El() { + return new is(Mr(this.a.Kc(), new ir())); + }; + sfb(xve, "FluentIterable/2", 442); + feb(1059, 547, Vve, Gl); + _2.Kc = function Hl() { + return Fl(this); + }; + sfb(xve, "FluentIterable/3", 1059); + feb(724, 399, yve, Il); + _2.Xb = function Jl(a) { + return this.a[a].Kc(); + }; + sfb(xve, "FluentIterable/3/1", 724); + feb(2070, 1, {}); + _2.Ib = function Kl() { + return jeb(this.Kd().b); + }; + sfb(xve, "ForwardingObject", 2070); + feb(2071, 2070, Wve); + _2.Kd = function Ql() { + return this.Ld(); + }; + _2.Jc = function Rl(a) { + xgb(this, a); + }; + _2.Lc = function Ul() { + return this.Oc(); + }; + _2.Nc = function Xl() { + return new Swb(this, 0); + }; + _2.Oc = function Yl() { + return new SDb(null, this.Nc()); + }; + _2.Fc = function Ll(a) { + return this.Ld(), qpb(); + }; + _2.Gc = function Ml(a) { + return this.Ld(), rpb(); + }; + _2.$b = function Nl() { + this.Ld(), spb(); + }; + _2.Hc = function Ol(a) { + return this.Ld().Hc(a); + }; + _2.Ic = function Pl(a) { + return this.Ld().Ic(a); + }; + _2.dc = function Sl() { + return this.Ld().b.dc(); + }; + _2.Kc = function Tl() { + return this.Ld().Kc(); + }; + _2.Mc = function Vl(a) { + return this.Ld(), vpb(); + }; + _2.gc = function Wl() { + return this.Ld().b.gc(); + }; + _2.Pc = function Zl() { + return this.Ld().Pc(); + }; + _2.Qc = function $l(a) { + return this.Ld().Qc(a); + }; + sfb(xve, "ForwardingCollection", 2071); + feb(2078, 31, Xve); + _2.Kc = function gm() { + return this.Od(); + }; + _2.Fc = function am(a) { + throw Adb(new jib()); + }; + _2.Gc = function bm(a) { + throw Adb(new jib()); + }; + _2.Md = function cm() { + var a; + a = this.c; + return !a ? this.c = this.Nd() : a; + }; + _2.$b = function dm() { + throw Adb(new jib()); + }; + _2.Hc = function em(a) { + return a != null && ze(this, a, false); + }; + _2.Nd = function fm() { + switch (this.gc()) { + case 0: + return tm(), tm(), sm; + case 1: + return tm(), new Dy(Qb(this.Od().Pb())); + default: + return new Fx(this, this.Pc()); + } + }; + _2.Mc = function hm(a) { + throw Adb(new jib()); + }; + sfb(xve, "ImmutableCollection", 2078); + feb(727, 2078, Xve, im); + _2.Kc = function nm() { + return Nr(this.a.Kc()); + }; + _2.Hc = function jm(a) { + return a != null && this.a.Hc(a); + }; + _2.Ic = function km(a) { + return this.a.Ic(a); + }; + _2.dc = function lm() { + return this.a.dc(); + }; + _2.Od = function mm() { + return Nr(this.a.Kc()); + }; + _2.gc = function om() { + return this.a.gc(); + }; + _2.Pc = function pm() { + return this.a.Pc(); + }; + _2.Qc = function qm(a) { + return this.a.Qc(a); + }; + _2.Ib = function rm() { + return jeb(this.a); + }; + sfb(xve, "ForwardingImmutableCollection", 727); + feb(307, 2078, Yve); + _2.Kc = function Em() { + return this.Od(); + }; + _2.ed = function Fm() { + return this.Pd(0); + }; + _2.fd = function Hm(a) { + return this.Pd(a); + }; + _2.jd = function Lm(a) { + tvb(this, a); + }; + _2.Nc = function Mm() { + return new Swb(this, 16); + }; + _2.kd = function Om(a, b) { + return this.Qd(a, b); + }; + _2.bd = function wm(a, b) { + throw Adb(new jib()); + }; + _2.cd = function xm(a, b) { + throw Adb(new jib()); + }; + _2.Md = function ym() { + return this; + }; + _2.Fb = function Am(a) { + return $u(this, a); + }; + _2.Hb = function Bm() { + return _u(this); + }; + _2.dd = function Cm(a) { + return a == null ? -1 : av(this, a); + }; + _2.Od = function Dm() { + return this.Pd(0); + }; + _2.Pd = function Gm(a) { + return um(this, a); + }; + _2.gd = function Jm(a) { + throw Adb(new jib()); + }; + _2.hd = function Km(a, b) { + throw Adb(new jib()); + }; + _2.Qd = function Nm(a, b) { + var c2; + return Pm((c2 = new pv(this), new Rkb(c2, a, b))); + }; + var sm; + sfb(xve, "ImmutableList", 307); + feb(2105, 307, Yve); + _2.Kc = function Zm() { + return Nr(this.Rd().Kc()); + }; + _2.kd = function an(a, b) { + return Pm(this.Rd().kd(a, b)); + }; + _2.Hc = function Rm(a) { + return a != null && this.Rd().Hc(a); + }; + _2.Ic = function Sm(a) { + return this.Rd().Ic(a); + }; + _2.Fb = function Tm(a) { + return pb(this.Rd(), a); + }; + _2.Xb = function Um(a) { + return Qm(this, a); + }; + _2.Hb = function Vm() { + return tb(this.Rd()); + }; + _2.dd = function Wm(a) { + return this.Rd().dd(a); + }; + _2.dc = function Xm() { + return this.Rd().dc(); + }; + _2.Od = function Ym() { + return Nr(this.Rd().Kc()); + }; + _2.gc = function $m() { + return this.Rd().gc(); + }; + _2.Qd = function _m(a, b) { + return Pm(this.Rd().kd(a, b)); + }; + _2.Pc = function bn() { + return this.Rd().Qc($C(jJ, rve, 1, this.Rd().gc(), 5, 1)); + }; + _2.Qc = function cn(a) { + return this.Rd().Qc(a); + }; + _2.Ib = function dn() { + return jeb(this.Rd()); + }; + sfb(xve, "ForwardingImmutableList", 2105); + feb(729, 1, $ve); + _2.vc = function pn() { + return gn(this); + }; + _2.wc = function rn(a) { + Bvb(this, a); + }; + _2.ec = function vn() { + return hn(this); + }; + _2.yc = function wn(a, b, c2) { + return Cvb(this, a, b, c2); + }; + _2.Cc = function Dn() { + return this.Vd(); + }; + _2.$b = function kn() { + throw Adb(new jib()); + }; + _2._b = function ln(a) { + return this.xc(a) != null; + }; + _2.uc = function mn(a) { + return this.Vd().Hc(a); + }; + _2.Td = function nn() { + return new xq(this); + }; + _2.Ud = function on() { + return new Gq(this); + }; + _2.Fb = function qn(a) { + return Tv(this, a); + }; + _2.Hb = function tn() { + return gn(this).Hb(); + }; + _2.dc = function un() { + return this.gc() == 0; + }; + _2.zc = function zn(a, b) { + return jn(); + }; + _2.Bc = function An(a) { + throw Adb(new jib()); + }; + _2.Ib = function Bn() { + return Zv(this); + }; + _2.Vd = function Cn() { + if (this.e) { + return this.e; + } + return this.e = this.Ud(); + }; + _2.c = null; + _2.d = null; + _2.e = null; + var en; + sfb(xve, "ImmutableMap", 729); + feb(730, 729, $ve); + _2._b = function Hn(a) { + return En(this, a); + }; + _2.uc = function In(a) { + return pqb(this.b, a); + }; + _2.Sd = function Jn() { + return go(new Xn2(this)); + }; + _2.Td = function Kn() { + return go(sqb(this.b)); + }; + _2.Ud = function Ln() { + return _l(), new im(tqb(this.b)); + }; + _2.Fb = function Mn(a) { + return rqb(this.b, a); + }; + _2.xc = function Nn(a) { + return Fn(this, a); + }; + _2.Hb = function On() { + return tb(this.b.c); + }; + _2.dc = function Pn() { + return this.b.c.dc(); + }; + _2.gc = function Qn() { + return this.b.c.gc(); + }; + _2.Ib = function Rn() { + return jeb(this.b.c); + }; + sfb(xve, "ForwardingImmutableMap", 730); + feb(2072, 2071, _ve); + _2.Kd = function Sn() { + return this.Wd(); + }; + _2.Ld = function Tn() { + return this.Wd(); + }; + _2.Nc = function Wn() { + return new Swb(this, 1); + }; + _2.Fb = function Un(a) { + return a === this || this.Wd().Fb(a); + }; + _2.Hb = function Vn() { + return this.Wd().Hb(); + }; + sfb(xve, "ForwardingSet", 2072); + feb(1085, 2072, _ve, Xn2); + _2.Kd = function Zn2() { + return qqb(this.a.b); + }; + _2.Ld = function $n() { + return qqb(this.a.b); + }; + _2.Hc = function Yn2(b) { + if (ZD(b, 44) && RD(b, 44).ld() == null) { + return false; + } + try { + return Pqb(qqb(this.a.b), b); + } catch (a) { + a = zdb(a); + if (ZD(a, 212)) { + return false; + } else + throw Adb(a); + } + }; + _2.Wd = function _n() { + return qqb(this.a.b); + }; + _2.Qc = function ao(a) { + var b; + b = Qqb(qqb(this.a.b), a); + qqb(this.a.b).b.gc() < b.length && bD(b, qqb(this.a.b).b.gc(), null); + return b; + }; + sfb(xve, "ForwardingImmutableMap/1", 1085); + feb(2079, 2078, awe); + _2.Kc = function eo() { + return this.Od(); + }; + _2.Nc = function fo() { + return new Swb(this, 1); + }; + _2.Fb = function bo(a) { + return Rx(this, a); + }; + _2.Hb = function co() { + return Sx(this); + }; + sfb(xve, "ImmutableSet", 2079); + feb(719, 2079, awe); + _2.Kc = function no() { + return Nr(new Ppb(this.a.b.Kc())); + }; + _2.Hc = function io(a) { + return a != null && tpb(this.a, a); + }; + _2.Ic = function jo(a) { + return upb(this.a, a); + }; + _2.Hb = function ko() { + return tb(this.a.b); + }; + _2.dc = function lo() { + return this.a.b.dc(); + }; + _2.Od = function mo() { + return Nr(new Ppb(this.a.b.Kc())); + }; + _2.gc = function oo() { + return this.a.b.gc(); + }; + _2.Pc = function po() { + return this.a.b.Pc(); + }; + _2.Qc = function qo(a) { + return wpb(this.a, a); + }; + _2.Ib = function ro() { + return jeb(this.a.b); + }; + sfb(xve, "ForwardingImmutableSet", 719); + feb(2073, 2072, bwe); + _2.Kd = function so() { + return this.b; + }; + _2.Ld = function to() { + return this.b; + }; + _2.Wd = function uo() { + return this.b; + }; + _2.Nc = function vo() { + return new $wb(this); + }; + sfb(xve, "ForwardingSortedSet", 2073); + feb(543, 2077, $ve, Io); + _2.Ac = function Ro(a) { + Ld(this, a); + }; + _2.Cc = function Uo() { + var a; + return a = this.d, new Gp(!a ? this.d = new mp(this) : a); + }; + _2.$b = function Jo() { + wo(this); + }; + _2._b = function Ko(a) { + return !!Go(this, a, Ydb(Ndb(cwe, qgb(Ydb(Ndb(a == null ? 0 : tb(a), dwe)), 15)))); + }; + _2.uc = function Lo(a) { + return xo(this, a); + }; + _2.kc = function Mo() { + return new ap(this, this); + }; + _2.wc = function No(a) { + zo(this, a); + }; + _2.xc = function Oo(a) { + return Ao(this, a); + }; + _2.ec = function Po() { + return new Np(this); + }; + _2.zc = function Qo(a, b) { + return Do(this, a, b); + }; + _2.Bc = function So(a) { + var b; + b = Go(this, a, Ydb(Ndb(cwe, qgb(Ydb(Ndb(a == null ? 0 : tb(a), dwe)), 15)))); + if (!b) { + return null; + } else { + yo(this, b); + b.e = null; + b.c = null; + return b.i; + } + }; + _2.gc = function To() { + return this.i; + }; + _2.xd = function Vo() { + var a; + return a = this.d, new Gp(!a ? this.d = new mp(this) : a); + }; + _2.f = 0; + _2.g = 0; + _2.i = 0; + sfb(xve, "HashBiMap", 543); + feb(544, 1, Ave); + _2.Nb = function Yo(a) { + Ztb(this, a); + }; + _2.Ob = function Zo() { + return Wo(this); + }; + _2.Pb = function $o() { + var a; + if (!Wo(this)) { + throw Adb(new Dvb()); + } + a = RD(Hvb(this.c), 303); + this.c = a.c; + this.f = a; + --this.d; + return this.Xd(a); + }; + _2.Qb = function _o() { + if (this.e.g != this.b) { + throw Adb(new Jrb()); + } + if (!this.f) { + throw Adb(new dgb(tve)); + } + yo(this.e, this.f); + this.b = this.e.g; + this.f = null; + }; + _2.b = 0; + _2.d = 0; + _2.f = null; + sfb(xve, "HashBiMap/Itr", 544); + feb(1023, 544, Ave, ap); + _2.Xd = function bp(a) { + return new cp(this, a); + }; + sfb(xve, "HashBiMap/1", 1023); + feb(gwe, 358, Kve, cp); + _2.ld = function dp() { + return this.a.g; + }; + _2.md = function ep() { + return this.a.i; + }; + _2.nd = function fp(a) { + var b, c2, d; + c2 = this.a.i; + d = Ydb(Ndb(cwe, qgb(Ydb(Ndb(a == null ? 0 : tb(a), dwe)), 15))); + if (d == this.a.f && (dE(a) === dE(c2) || a != null && pb(a, c2))) { + return a; + } + Nb(!Ho(this.b.a, a, d), a); + yo(this.b.a, this.a); + b = new kp(this.a.g, this.a.a, a, d); + Bo(this.b.a, b, this.a); + this.a.e = null; + this.a.c = null; + this.b.b = this.b.a.g; + this.b.f == this.a && (this.b.f = b); + this.a = b; + return c2; + }; + sfb(xve, "HashBiMap/1/MapEntry", gwe); + feb(246, 358, { 358: 1, 246: 1, 3: 1, 44: 1 }, gp); + _2.ld = function hp() { + return this.g; + }; + _2.md = function ip() { + return this.i; + }; + _2.nd = function jp(a) { + throw Adb(new jib()); + }; + sfb(xve, "ImmutableEntry", 246); + feb(303, 246, { 358: 1, 303: 1, 246: 1, 3: 1, 44: 1 }, kp); + _2.a = 0; + _2.f = 0; + var XF = sfb(xve, "HashBiMap/BiEntry", 303); + feb(619, 2077, $ve, mp); + _2.Ac = function vp(a) { + Ld(this, a); + }; + _2.Cc = function yp() { + return new Np(this.a); + }; + _2.$b = function np() { + wo(this.a); + }; + _2._b = function op2(a) { + return xo(this.a, a); + }; + _2.kc = function pp() { + return new Ap(this, this.a); + }; + _2.wc = function qp(a) { + Qb(a); + zo(this.a, new Lp(a)); + }; + _2.xc = function rp(a) { + return lp(this, a); + }; + _2.ec = function sp() { + return new Gp(this); + }; + _2.zc = function up(a, b) { + return Eo(this.a, a, b, false); + }; + _2.Bc = function wp(a) { + var b; + b = Ho(this.a, a, Ydb(Ndb(cwe, qgb(Ydb(Ndb(a == null ? 0 : tb(a), dwe)), 15)))); + if (!b) { + return null; + } else { + yo(this.a, b); + b.e = null; + b.c = null; + return b.g; + } + }; + _2.gc = function xp() { + return this.a.i; + }; + _2.xd = function zp() { + return new Np(this.a); + }; + sfb(xve, "HashBiMap/Inverse", 619); + feb(1020, 544, Ave, Ap); + _2.Xd = function Bp(a) { + return new Cp(this, a); + }; + sfb(xve, "HashBiMap/Inverse/1", 1020); + feb(1021, 358, Kve, Cp); + _2.ld = function Dp() { + return this.a.i; + }; + _2.md = function Ep() { + return this.a.g; + }; + _2.nd = function Fp(a) { + var b, c2, d; + d = this.a.g; + b = Ydb(Ndb(cwe, qgb(Ydb(Ndb(a == null ? 0 : tb(a), dwe)), 15))); + if (b == this.a.a && (dE(a) === dE(d) || a != null && pb(a, d))) { + return a; + } + Nb(!Go(this.b.a.a, a, b), a); + yo(this.b.a.a, this.a); + c2 = new kp(a, b, this.a.i, this.a.f); + this.a = c2; + Bo(this.b.a.a, c2, null); + this.b.b = this.b.a.a.g; + return d; + }; + sfb(xve, "HashBiMap/Inverse/1/InverseEntry", 1021); + feb(620, 542, Fve, Gp); + _2.Kc = function Hp() { + return new Jp(this.a.a); + }; + _2.Mc = function Ip(a) { + var b; + b = Ho(this.a.a, a, Ydb(Ndb(cwe, qgb(Ydb(Ndb(a == null ? 0 : tb(a), dwe)), 15)))); + if (!b) { + return false; + } else { + yo(this.a.a, b); + return true; + } + }; + sfb(xve, "HashBiMap/Inverse/InverseKeySet", 620); + feb(1019, 544, Ave, Jp); + _2.Xd = function Kp(a) { + return a.i; + }; + sfb(xve, "HashBiMap/Inverse/InverseKeySet/1", 1019); + feb(1022, 1, {}, Lp); + _2.Yd = function Mp(a, b) { + tp(this.a, a, b); + }; + sfb(xve, "HashBiMap/Inverse/lambda$0$Type", 1022); + feb(618, 542, Fve, Np); + _2.Kc = function Op() { + return new Qp(this.a); + }; + _2.Mc = function Pp(a) { + var b; + b = Go(this.a, a, Ydb(Ndb(cwe, qgb(Ydb(Ndb(a == null ? 0 : tb(a), dwe)), 15)))); + if (!b) { + return false; + } else { + yo(this.a, b); + b.e = null; + b.c = null; + return true; + } + }; + sfb(xve, "HashBiMap/KeySet", 618); + feb(1018, 544, Ave, Qp); + _2.Xd = function Rp(a) { + return a.g; + }; + sfb(xve, "HashBiMap/KeySet/1", 1018); + feb(1123, 627, zve); + sfb(xve, "HashMultimapGwtSerializationDependencies", 1123); + feb(271, 1123, zve, Tp); + _2.hc = function Up() { + return new atb(Sv(this.a)); + }; + _2.pd = function Vp() { + return new atb(Sv(this.a)); + }; + _2.a = 2; + sfb(xve, "HashMultimap", 271); + feb(2097, 307, Yve); + _2.Hc = function Yp(a) { + return this.Zd().Hc(a); + }; + _2.dc = function Zp() { + return this.Zd().dc(); + }; + _2.gc = function $p() { + return this.Zd().gc(); + }; + sfb(xve, "ImmutableAsList", 2097); + feb(2030, 730, $ve); + _2.Vd = function aq() { + return _l(), new Fy(this.a); + }; + _2.Cc = function bq() { + return _l(), new Fy(this.a); + }; + _2.xd = function cq() { + return _l(), new Fy(this.a); + }; + sfb(xve, "ImmutableBiMap", 2030); + feb(2075, 1, {}); + sfb(xve, "ImmutableCollection/Builder", 2075); + feb(1035, 719, awe, dq); + sfb(xve, "ImmutableEnumSet", 1035); + feb(980, 399, yve, fq); + _2.Xb = function gq(a) { + return this.a.Xb(a); + }; + sfb(xve, "ImmutableList/1", 980); + feb(979, 2075, {}, hq); + sfb(xve, "ImmutableList/Builder", 979); + feb(623, 204, wve, iq); + _2.Ob = function jq() { + return this.a.Ob(); + }; + _2.Pb = function kq() { + return RD(this.a.Pb(), 44).ld(); + }; + sfb(xve, "ImmutableMap/1", 623); + feb(1054, 1, {}, lq); + _2.Kb = function mq(a) { + return RD(a, 44).ld(); + }; + sfb(xve, "ImmutableMap/2methodref$getKey$Type", 1054); + feb(1053, 1, {}, oq); + sfb(xve, "ImmutableMap/Builder", 1053); + feb(2098, 2079, awe); + _2.Md = function pq() { + var a; + return a = this.b, !a ? this.b = new Xq(this) : a; + }; + _2.Nd = function qq() { + return new Fx(this, Ee(this, $C(jJ, rve, 1, this.gc(), 5, 1))); + }; + sfb(xve, "ImmutableSet/CachingAsList", 2098); + feb(2099, 2098, awe); + _2.Kc = function uq() { + var a; + return a = gn(this.a).Od(), new iq(a); + }; + _2.Nd = function rq() { + return new Xq(this); + }; + _2.Jc = function sq(a) { + var b, c2; + Qb(a); + c2 = this.gc(); + for (b = 0; b < c2; b++) { + a.Cd(RD(gn(this.a).Md().Xb(b), 44).ld()); + } + }; + _2.Od = function tq() { + var a; + return a = this.b, um(!a ? this.b = new Xq(this) : a, 0); + }; + _2.Nc = function vq() { + return fk(this.gc(), 1296, new Vq(this)); + }; + sfb(xve, "IndexedImmutableSet", 2099); + feb(1230, 2099, awe, xq); + _2.Kc = function Bq() { + var a; + return a = gn(this.a).Od(), new iq(a); + }; + _2.Hc = function yq(a) { + return this.a._b(a); + }; + _2.Jc = function zq(a) { + Qb(a); + Bvb(this.a, new Eq(a)); + }; + _2.Od = function Aq() { + var a; + return a = gn(this.a).Od(), new iq(a); + }; + _2.gc = function Cq() { + return this.a.gc(); + }; + _2.Nc = function Dq() { + return gk(gn(this.a).Nc(), new lq()); + }; + sfb(xve, "ImmutableMapKeySet", 1230); + feb(1231, 1, {}, Eq); + _2.Yd = function Fq(a, b) { + _l(); + this.a.Cd(a); + }; + sfb(xve, "ImmutableMapKeySet/lambda$0$Type", 1231); + feb(1227, 2078, Xve, Gq); + _2.Kc = function Kq() { + return new Pq(this); + }; + _2.Md = function Hq() { + var a; + a = gn(this.a).Md(); + return new Sq(this, a); + }; + _2.Hc = function Iq(a) { + return a != null && Br(new Pq(this), a); + }; + _2.Od = function Jq() { + return new Pq(this); + }; + _2.gc = function Lq() { + return this.a.gc(); + }; + _2.Nc = function Mq() { + return gk(gn(this.a).Nc(), new Nq()); + }; + sfb(xve, "ImmutableMapValues", 1227); + feb(1228, 1, {}, Nq); + _2.Kb = function Oq(a) { + return RD(a, 44).md(); + }; + sfb(xve, "ImmutableMapValues/0methodref$getValue$Type", 1228); + feb(637, 204, wve, Pq); + _2.Ob = function Qq() { + return this.a.Ob(); + }; + _2.Pb = function Rq() { + return RD(this.a.Pb(), 44).md(); + }; + sfb(xve, "ImmutableMapValues/1", 637); + feb(1229, 2097, Yve, Sq); + _2.Zd = function Tq() { + return this.a; + }; + _2.Xb = function Uq(a) { + return RD(this.b.Xb(a), 44).md(); + }; + sfb(xve, "ImmutableMapValues/2", 1229); + feb(1232, 1, {}, Vq); + _2.td = function Wq(a) { + return wq(this.a, a); + }; + sfb(xve, "IndexedImmutableSet/0methodref$get$Type", 1232); + feb(638, 2097, Yve, Xq); + _2.Zd = function Yq() { + return this.a; + }; + _2.Xb = function Zq(a) { + return wq(this.a, a); + }; + _2.gc = function $q() { + return this.a.a.gc(); + }; + sfb(xve, "IndexedImmutableSet/1", 638); + feb(43, 1, {}, ir); + _2.Kb = function jr(a) { + return RD(a, 20).Kc(); + }; + _2.Fb = function kr(a) { + return this === a; + }; + sfb(xve, "Iterables/10", 43); + feb(1055, 547, Vve, mr); + _2.Jc = function nr(a) { + Qb(a); + this.b.Jc(new qr(this.a, a)); + }; + _2.Kc = function or() { + return lr(this); + }; + sfb(xve, "Iterables/4", 1055); + feb(1056, 1, Qve, qr); + _2.Cd = function rr(a) { + pr(this.b, this.a, a); + }; + sfb(xve, "Iterables/4/lambda$0$Type", 1056); + feb(1057, 547, Vve, sr); + _2.Jc = function tr(a) { + Qb(a); + xgb(this.a, new vr(a, this.b)); + }; + _2.Kc = function ur() { + return Mr(new dMd(this.a), this.b); + }; + sfb(xve, "Iterables/5", 1057); + feb(1058, 1, Qve, vr); + _2.Cd = function wr(a) { + this.a.Cd(Ksd(a)); + }; + sfb(xve, "Iterables/5/lambda$0$Type", 1058); + feb(1087, 204, wve, Or); + _2.Ob = function Pr() { + return this.a.Ob(); + }; + _2.Pb = function Qr() { + return this.a.Pb(); + }; + sfb(xve, "Iterators/1", 1087); + feb(1088, 713, wve, Rr); + _2.Yb = function Sr() { + var a; + while (this.b.Ob()) { + a = this.b.Pb(); + if (this.a.Lb(a)) { + return a; + } + } + return this.e = 2, null; + }; + sfb(xve, "Iterators/5", 1088); + feb(497, 1, Ave); + _2.Nb = function Ur(a) { + Ztb(this, a); + }; + _2.Ob = function Vr() { + return this.b.Ob(); + }; + _2.Pb = function Wr() { + return this.$d(this.b.Pb()); + }; + _2.Qb = function Xr() { + this.b.Qb(); + }; + sfb(xve, "TransformedIterator", 497); + feb(1089, 497, Ave, Yr); + _2.$d = function Zr(a) { + return this.a.Kb(a); + }; + sfb(xve, "Iterators/6", 1089); + feb(732, 204, wve, $r); + _2.Ob = function _r() { + return !this.a; + }; + _2.Pb = function as() { + if (this.a) { + throw Adb(new Dvb()); + } + this.a = true; + return this.b; + }; + _2.a = false; + sfb(xve, "Iterators/9", 732); + feb(1086, 399, yve, ds); + _2.Xb = function es(a) { + return this.a[this.b + a]; + }; + _2.b = 0; + var bs; + sfb(xve, "Iterators/ArrayItr", 1086); + feb(38, 1, { 38: 1, 51: 1 }, is); + _2.Nb = function js(a) { + Ztb(this, a); + }; + _2.Ob = function ks() { + return gs(this); + }; + _2.Pb = function ls() { + return hs(this); + }; + _2.Qb = function ms() { + if (!this.c) { + throw Adb(new dgb(tve)); + } + this.c.Qb(); + this.c = null; + }; + sfb(xve, "Iterators/ConcatenatedIterator", 38); + feb(22, 1, { 3: 1, 34: 1, 22: 1 }); + _2.Fd = function rs(a) { + return ns(this, RD(a, 22)); + }; + _2.Fb = function ts(a) { + return this === a; + }; + _2.Hb = function us() { + return kFb(this); + }; + _2.Ib = function vs() { + return ps(this); + }; + _2.g = 0; + var WI = sfb(mve, "Enum", 22); + feb(549, 22, { 549: 1, 3: 1, 34: 1, 22: 1, 51: 1 }, As); + _2.Nb = function Bs(a) { + Ztb(this, a); + }; + _2.Ob = function Cs() { + return false; + }; + _2.Pb = function Ds() { + throw Adb(new Dvb()); + }; + _2.Qb = function Es() { + Vb(false); + }; + var ys; + var RG = tfb(xve, "Iterators/EmptyModifiableIterator", 549, WI, Gs, Fs); + var Hs; + feb(1907, 627, zve); + sfb(xve, "LinkedHashMultimapGwtSerializationDependencies", 1907); + feb(1908, 1907, zve, Ks); + _2.hc = function Ms() { + return new Jub(Sv(this.b)); + }; + _2.$b = function Ls() { + Nc(this); + Ss(this.a, this.a); + }; + _2.pd = function Ns() { + return new Jub(Sv(this.b)); + }; + _2.ic = function Os(a) { + return new it(this, a, this.b); + }; + _2.kc = function Ps() { + return new Zs(this); + }; + _2.lc = function Qs() { + var a; + return new Swb((a = this.g, RD(!a ? this.g = new xh(this) : a, 21)), 17); + }; + _2.ec = function Rs() { + var a; + return a = this.i, !a ? this.i = new zf(this, this.c) : a; + }; + _2.nc = function Us() { + return new cw(new Zs(this)); + }; + _2.oc = function Vs() { + var a; + return gk(new Swb((a = this.g, RD(!a ? this.g = new xh(this) : a, 21)), 17), new Ws()); + }; + _2.b = 2; + sfb(xve, "LinkedHashMultimap", 1908); + feb(1911, 1, {}, Ws); + _2.Kb = function Xs(a) { + return RD(a, 44).md(); + }; + sfb(xve, "LinkedHashMultimap/0methodref$getValue$Type", 1911); + feb(834, 1, Ave, Zs); + _2.Nb = function $s(a) { + Ztb(this, a); + }; + _2.Pb = function at() { + return Ys(this); + }; + _2.Ob = function _s() { + return this.a != this.b.a; + }; + _2.Qb = function bt() { + Vb(!!this.c); + Gc(this.b, this.c.g, this.c.i); + this.c = null; + }; + sfb(xve, "LinkedHashMultimap/1", 834); + feb(227, 246, { 358: 1, 246: 1, 227: 1, 604: 1, 3: 1, 44: 1 }, ct); + _2._d = function dt() { + return RD(Hvb(this.f), 604); + }; + _2.ae = function et(a) { + this.c = a; + }; + _2.be = function ft(a) { + this.f = a; + }; + _2.d = 0; + var UG = sfb(xve, "LinkedHashMultimap/ValueEntry", 227); + feb(1909, 2068, { 604: 1, 20: 1, 31: 1, 16: 1, 21: 1 }, it); + _2.Fc = function jt(a) { + var b, c2, d, e, f2; + f2 = Ydb(Ndb(cwe, qgb(Ydb(Ndb(a == null ? 0 : tb(a), dwe)), 15))); + b = f2 & this.b.length - 1; + e = this.b[b]; + for (c2 = e; c2; c2 = c2.a) { + if (c2.d == f2 && Hb(c2.i, a)) { + return false; + } + } + d = new ct(this.c, a, f2, e); + Ts(this.d, d); + d.f = this; + this.d = d; + Ss(RD(Hvb(this.g.a.b), 227), d); + Ss(d, this.g.a); + this.b[b] = d; + ++this.f; + ++this.e; + gt(this); + return true; + }; + _2.$b = function kt() { + var a, b; + Mnb(this.b, null); + this.f = 0; + for (a = this.a; a != this; a = a._d()) { + b = RD(a, 227); + Ss(RD(Hvb(b.b), 227), RD(Hvb(b.e), 227)); + } + this.a = this; + this.d = this; + ++this.e; + }; + _2.Hc = function lt(a) { + var b, c2; + c2 = Ydb(Ndb(cwe, qgb(Ydb(Ndb(a == null ? 0 : tb(a), dwe)), 15))); + for (b = this.b[c2 & this.b.length - 1]; b; b = b.a) { + if (b.d == c2 && Hb(b.i, a)) { + return true; + } + } + return false; + }; + _2.Jc = function mt(a) { + var b; + Qb(a); + for (b = this.a; b != this; b = b._d()) { + a.Cd(RD(b, 227).i); + } + }; + _2._d = function nt() { + return this.a; + }; + _2.Kc = function ot() { + return new ut(this); + }; + _2.Mc = function pt(a) { + return ht(this, a); + }; + _2.ae = function qt(a) { + this.d = a; + }; + _2.be = function rt(a) { + this.a = a; + }; + _2.gc = function st() { + return this.f; + }; + _2.e = 0; + _2.f = 0; + sfb(xve, "LinkedHashMultimap/ValueSet", 1909); + feb(1910, 1, Ave, ut); + _2.Nb = function vt(a) { + Ztb(this, a); + }; + _2.Ob = function wt() { + return tt(this), this.b != this.c; + }; + _2.Pb = function xt() { + var a, b; + tt(this); + if (this.b == this.c) { + throw Adb(new Dvb()); + } + a = RD(this.b, 227); + b = a.i; + this.d = a; + this.b = RD(Hvb(a.f), 604); + return b; + }; + _2.Qb = function yt() { + tt(this); + Vb(!!this.d); + ht(this.c, this.d.i); + this.a = this.c.e; + this.d = null; + }; + _2.a = 0; + sfb(xve, "LinkedHashMultimap/ValueSet/1", 1910); + feb(780, 2084, zve, Et); + _2.Zb = function Ft() { + var a; + return a = this.f, !a ? this.f = new zw(this) : a; + }; + _2.Fb = function Kt(a) { + return xw(this, a); + }; + _2.cc = function Lt(a) { + return new su(this, a); + }; + _2.fc = function Ot(a) { + return Ct(this, a); + }; + _2.$b = function Gt() { + At(this); + }; + _2._b = function Ht(a) { + return Bt(this, a); + }; + _2.ac = function It() { + return new zw(this); + }; + _2.bc = function Jt() { + return new vu(this); + }; + _2.qc = function Mt(a) { + return new su(this, a); + }; + _2.dc = function Nt() { + return !this.a; + }; + _2.rc = function Pt(a) { + return Ct(this, a); + }; + _2.gc = function Qt() { + return this.d; + }; + _2.c = 0; + _2.d = 0; + sfb(xve, "LinkedListMultimap", 780); + feb(56, 31, kwe); + _2.jd = function eu(a) { + tvb(this, a); + }; + _2.Nc = function fu() { + return new Swb(this, 16); + }; + _2.bd = function Tt(a, b) { + throw Adb(new kib("Add not supported on this list")); + }; + _2.Fc = function Ut(a) { + this.bd(this.gc(), a); + return true; + }; + _2.cd = function Vt(a, b) { + var c2, d, e; + uFb(b); + c2 = false; + for (e = b.Kc(); e.Ob(); ) { + d = e.Pb(); + this.bd(a++, d); + c2 = true; + } + return c2; + }; + _2.$b = function Wt() { + this.ce(0, this.gc()); + }; + _2.Fb = function Xt(a) { + return Rt(this, a); + }; + _2.Hb = function Yt() { + return Cob(this); + }; + _2.dd = function Zt(a) { + return St(this, a); + }; + _2.Kc = function $t() { + return new Dkb(this); + }; + _2.ed = function _t() { + return this.fd(0); + }; + _2.fd = function au(a) { + return new Jkb(this, a); + }; + _2.gd = function bu(a) { + throw Adb(new kib("Remove not supported on this list")); + }; + _2.ce = function cu(a, b) { + var c2, d; + d = this.fd(a); + for (c2 = a; c2 < b; ++c2) { + d.Pb(); + d.Qb(); + } + }; + _2.hd = function du(a, b) { + throw Adb(new kib("Set not supported on this list")); + }; + _2.kd = function gu(a, b) { + return new Rkb(this, a, b); + }; + _2.j = 0; + sfb(Bve, "AbstractList", 56); + feb(2062, 56, kwe); + _2.bd = function lu(a, b) { + hu(this, a, b); + }; + _2.cd = function mu(a, b) { + return iu(this, a, b); + }; + _2.Xb = function nu(a) { + return ju(this, a); + }; + _2.Kc = function ou() { + return this.fd(0); + }; + _2.gd = function pu(a) { + return ku(this, a); + }; + _2.hd = function qu(b, c2) { + var d, e; + d = this.fd(b); + try { + e = d.Pb(); + d.Wb(c2); + return e; + } catch (a) { + a = zdb(a); + if (ZD(a, 112)) { + throw Adb(new veb("Can't set element " + b)); + } else + throw Adb(a); + } + }; + sfb(Bve, "AbstractSequentialList", 2062); + feb(646, 2062, kwe, su); + _2.fd = function tu(a) { + return ru(this, a); + }; + _2.gc = function uu() { + var a; + a = RD(Wjb(this.a.b, this.b), 260); + return !a ? 0 : a.a; + }; + sfb(xve, "LinkedListMultimap/1", 646); + feb(1316, 2068, Fve, vu); + _2.Hc = function wu(a) { + return Bt(this.a, a); + }; + _2.Kc = function xu() { + return new Bu(this.a); + }; + _2.Mc = function yu(a) { + return !Ct(this.a, a).a.dc(); + }; + _2.gc = function zu() { + return bkb(this.a.b); + }; + sfb(xve, "LinkedListMultimap/1KeySetImpl", 1316); + feb(1315, 1, Ave, Bu); + _2.Nb = function Cu(a) { + Ztb(this, a); + }; + _2.Ob = function Du() { + Au(this); + return !!this.c; + }; + _2.Pb = function Eu() { + Au(this); + if (!this.c) { + throw Adb(new Dvb()); + } + this.a = this.c; + Ysb(this.d, this.a.a); + do { + this.c = this.c.b; + } while (!!this.c && !Ysb(this.d, this.c.a)); + return this.a.a; + }; + _2.Qb = function Fu() { + Au(this); + Vb(!!this.a); + Ar(new Nu(this.e, this.a.a)); + this.a = null; + this.b = this.e.c; + }; + _2.b = 0; + sfb(xve, "LinkedListMultimap/DistinctKeyIterator", 1315); + feb(260, 1, { 260: 1 }, Gu); + _2.a = 0; + sfb(xve, "LinkedListMultimap/KeyList", 260); + feb(511, 358, { 358: 1, 511: 1, 44: 1 }, Hu); + _2.ld = function Iu() { + return this.a; + }; + _2.md = function Ju() { + return this.f; + }; + _2.nd = function Ku(a) { + var b; + b = this.f; + this.f = a; + return b; + }; + sfb(xve, "LinkedListMultimap/Node", 511); + feb(566, 1, Jve, Nu, Ou); + _2.Nb = function Qu(a) { + Ztb(this, a); + }; + _2.Rb = function Pu(a) { + this.e = zt(this.f, this.b, a, this.c); + ++this.d; + this.a = null; + }; + _2.Ob = function Ru() { + return !!this.c; + }; + _2.Sb = function Su() { + return !!this.e; + }; + _2.Pb = function Tu() { + return Lu(this); + }; + _2.Tb = function Uu() { + return this.d; + }; + _2.Ub = function Vu() { + return Mu(this); + }; + _2.Vb = function Wu() { + return this.d - 1; + }; + _2.Qb = function Xu() { + Vb(!!this.a); + if (this.a != this.c) { + this.e = this.a.e; + --this.d; + } else { + this.c = this.a.c; + } + Dt(this.f, this.a); + this.a = null; + }; + _2.Wb = function Yu(a) { + Ub(!!this.a); + this.a.f = a; + }; + _2.d = 0; + sfb(xve, "LinkedListMultimap/ValueForKeyIterator", 566); + feb(1031, 56, kwe); + _2.bd = function iv(a, b) { + this.a.bd(a, b); + }; + _2.cd = function jv(a, b) { + return this.a.cd(a, b); + }; + _2.Hc = function kv(a) { + return this.a.Hc(a); + }; + _2.Xb = function lv(a) { + return this.a.Xb(a); + }; + _2.gd = function mv(a) { + return this.a.gd(a); + }; + _2.hd = function nv(a, b) { + return this.a.hd(a, b); + }; + _2.gc = function ov() { + return this.a.gc(); + }; + sfb(xve, "Lists/AbstractListWrapper", 1031); + feb(1032, 1031, mwe); + sfb(xve, "Lists/RandomAccessListWrapper", 1032); + feb(1034, 1032, mwe, pv); + _2.fd = function qv(a) { + return this.a.fd(a); + }; + sfb(xve, "Lists/1", 1034); + feb(441, 56, { 441: 1, 20: 1, 31: 1, 56: 1, 16: 1, 15: 1 }, uv); + _2.bd = function vv(a, b) { + this.a.bd(tv(this, a), b); + }; + _2.$b = function wv() { + this.a.$b(); + }; + _2.Xb = function xv(a) { + return this.a.Xb(sv(this, a)); + }; + _2.Kc = function yv() { + return rv(this, 0); + }; + _2.fd = function zv(a) { + return rv(this, a); + }; + _2.gd = function Av(a) { + return this.a.gd(sv(this, a)); + }; + _2.ce = function Bv(a, b) { + (Tb(a, b, this.a.gc()), hv(this.a.kd(tv(this, b), tv(this, a)))).$b(); + }; + _2.hd = function Cv(a, b) { + return this.a.hd(sv(this, a), b); + }; + _2.gc = function Dv() { + return this.a.gc(); + }; + _2.kd = function Ev(a, b) { + return Tb(a, b, this.a.gc()), hv(this.a.kd(tv(this, b), tv(this, a))); + }; + sfb(xve, "Lists/ReverseList", 441); + feb(1030, 441, { 441: 1, 20: 1, 31: 1, 56: 1, 16: 1, 15: 1, 59: 1 }, Fv); + sfb(xve, "Lists/RandomAccessReverseList", 1030); + feb(1033, 1, Jve, Gv); + _2.Nb = function Iv(a) { + Ztb(this, a); + }; + _2.Rb = function Hv(a) { + this.c.Rb(a); + this.c.Ub(); + this.a = false; + }; + _2.Ob = function Jv() { + return this.c.Sb(); + }; + _2.Sb = function Kv() { + return this.c.Ob(); + }; + _2.Pb = function Lv() { + if (!this.c.Sb()) { + throw Adb(new Dvb()); + } + this.a = true; + return this.c.Ub(); + }; + _2.Tb = function Mv() { + return tv(this.b, this.c.Tb()); + }; + _2.Ub = function Nv() { + if (!this.c.Ob()) { + throw Adb(new Dvb()); + } + this.a = true; + return this.c.Pb(); + }; + _2.Vb = function Ov() { + return tv(this.b, this.c.Tb()) - 1; + }; + _2.Qb = function Pv() { + Vb(this.a); + this.c.Qb(); + this.a = false; + }; + _2.Wb = function Qv(a) { + Ub(this.a); + this.c.Wb(a); + }; + _2.a = false; + sfb(xve, "Lists/ReverseList/1", 1033); + feb(440, 497, Ave, aw); + _2.$d = function bw(a) { + return _v(a); + }; + sfb(xve, "Maps/1", 440); + feb(712, 497, Ave, cw); + _2.$d = function dw(a) { + return RD(a, 44).md(); + }; + sfb(xve, "Maps/2", 712); + feb(975, 497, Ave, ew); + _2.$d = function fw(a) { + return new gp(a, Mw(this.a, a)); + }; + sfb(xve, "Maps/3", 975); + feb(972, 2069, Fve, gw); + _2.Jc = function hw(a) { + uj(this.a, a); + }; + _2.Kc = function iw() { + return this.a.kc(); + }; + _2.Rc = function jw() { + return this.a; + }; + _2.Nc = function kw() { + return this.a.lc(); + }; + sfb(xve, "Maps/IteratorBasedAbstractMap/1", 972); + feb(973, 1, {}, lw); + _2.Yd = function mw(a, b) { + this.a.Cd(a); + }; + sfb(xve, "Maps/KeySet/lambda$0$Type", 973); + feb(971, 31, Dve, nw); + _2.$b = function ow() { + this.a.$b(); + }; + _2.Hc = function pw(a) { + return this.a.uc(a); + }; + _2.Jc = function qw(a) { + Qb(a); + this.a.wc(new vw(a)); + }; + _2.dc = function rw() { + return this.a.dc(); + }; + _2.Kc = function sw() { + return new cw(this.a.vc().Kc()); + }; + _2.Mc = function tw(b) { + var c2, d; + try { + return ze(this, b, true); + } catch (a) { + a = zdb(a); + if (ZD(a, 48)) { + for (d = this.a.vc().Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 44); + if (Hb(b, c2.md())) { + this.a.Bc(c2.ld()); + return true; + } + } + return false; + } else + throw Adb(a); + } + }; + _2.gc = function uw() { + return this.a.gc(); + }; + sfb(xve, "Maps/Values", 971); + feb(974, 1, {}, vw); + _2.Yd = function ww(a, b) { + this.a.Cd(b); + }; + sfb(xve, "Maps/Values/lambda$0$Type", 974); + feb(752, 2085, Cve, zw); + _2.xc = function Dw(a) { + return this.a._b(a) ? this.a.cc(a) : null; + }; + _2.Bc = function Gw(a) { + return this.a._b(a) ? this.a.fc(a) : null; + }; + _2.$b = function Aw() { + this.a.$b(); + }; + _2._b = function Bw(a) { + return this.a._b(a); + }; + _2.Ec = function Cw() { + return new Iw(this); + }; + _2.Dc = function() { + return this.Ec(); + }; + _2.dc = function Ew() { + return this.a.dc(); + }; + _2.ec = function Fw() { + return this.a.ec(); + }; + _2.gc = function Hw() { + return this.a.ec().gc(); + }; + sfb(xve, "Multimaps/AsMap", 752); + feb(1134, 2069, Fve, Iw); + _2.Kc = function Jw() { + return Rv(this.a.a.ec(), new Nw(this)); + }; + _2.Rc = function Kw() { + return this.a; + }; + _2.Mc = function Lw(a) { + var b; + if (!Ze(this, a)) { + return false; + } + b = RD(Hvb(RD(a, 44)), 44); + yw(this.a, b.ld()); + return true; + }; + sfb(xve, "Multimaps/AsMap/EntrySet", 1134); + feb(1138, 1, {}, Nw); + _2.Kb = function Ow(a) { + return Mw(this, a); + }; + _2.Fb = function Pw(a) { + return this === a; + }; + sfb(xve, "Multimaps/AsMap/EntrySet/1", 1138); + feb(552, 2087, { 552: 1, 849: 1, 20: 1, 31: 1, 16: 1 }, Sw); + _2.$b = function Tw() { + Nc(this.a); + }; + _2.Hc = function Uw(a) { + return Oc(this.a, a); + }; + _2.Jc = function Vw(a) { + Qb(a); + xgb(Pc(this.a), new fx(a)); + }; + _2.Kc = function Ww() { + return new aw(Pc(this.a).a.kc()); + }; + _2.gc = function Xw() { + return this.a.d; + }; + _2.Nc = function Yw() { + return gk(Pc(this.a).Nc(), new Zw()); + }; + sfb(xve, "Multimaps/Keys", 552); + feb(1136, 1, {}, Zw); + _2.Kb = function $w(a) { + return RD(a, 44).ld(); + }; + sfb(xve, "Multimaps/Keys/0methodref$getKey$Type", 1136); + feb(1135, 497, Ave, _w); + _2.$d = function ax(a) { + return new ex(RD(a, 44)); + }; + sfb(xve, "Multimaps/Keys/1", 1135); + feb(2088, 1, { 425: 1 }); + _2.Fb = function bx(a) { + var b; + if (ZD(a, 504)) { + b = RD(a, 425); + return RD(this.a.md(), 16).gc() == RD(b.a.md(), 16).gc() && Hb(this.a.ld(), b.a.ld()); + } + return false; + }; + _2.Hb = function cx() { + var a; + a = this.a.ld(); + return (a == null ? 0 : tb(a)) ^ RD(this.a.md(), 16).gc(); + }; + _2.Ib = function dx() { + var a, b; + b = Ghb(this.a.ld()); + a = RD(this.a.md(), 16).gc(); + return a == 1 ? b : b + " x " + a; + }; + sfb(xve, "Multisets/AbstractEntry", 2088); + feb(504, 2088, { 504: 1, 425: 1 }, ex); + sfb(xve, "Multimaps/Keys/1/1", 504); + feb(1137, 1, Qve, fx); + _2.Cd = function gx(a) { + this.a.Cd(RD(a, 44).ld()); + }; + sfb(xve, "Multimaps/Keys/lambda$1$Type", 1137); + feb(1140, 1, Qve, jx); + _2.Cd = function kx(a) { + hx(RD(a, 425)); + }; + sfb(xve, "Multiset/lambda$0$Type", 1140); + feb(753, 1, Qve, lx); + _2.Cd = function mx(a) { + ix(this.a, RD(a, 425)); + }; + sfb(xve, "Multiset/lambda$1$Type", 753); + feb(1141, 1, {}, rx); + sfb(xve, "Multisets/0methodref$add$Type", 1141); + feb(754, 1, {}, sx); + _2.Kb = function tx(a) { + return px(RD(a, 425)); + }; + sfb(xve, "Multisets/lambda$1$Type", 754); + feb(2106, 1, nve); + sfb(xve, "RangeGwtSerializationDependencies", 2106); + feb(521, 2106, { 178: 1, 521: 1, 3: 1, 46: 1 }, wx); + _2.Lb = function xx(a) { + return vx(this, RD(a, 34)); + }; + _2.Mb = function Bx(a) { + return vx(this, RD(a, 34)); + }; + _2.Fb = function zx(a) { + var b; + if (ZD(a, 521)) { + b = RD(a, 521); + return Pk(this.a, b.a) && Pk(this.b, b.b); + } + return false; + }; + _2.Hb = function Ax() { + return this.a.Hb() * 31 + this.b.Hb(); + }; + _2.Ib = function Cx() { + return Dx(this.a, this.b); + }; + sfb(xve, "Range", 521); + feb(654, 2097, Yve, Fx); + _2.fd = function Jx(a) { + return um(this.b, a); + }; + _2.Zd = function Gx() { + return this.a; + }; + _2.Xb = function Hx(a) { + return Qm(this.b, a); + }; + _2.Pd = function Ix(a) { + return um(this.b, a); + }; + sfb(xve, "RegularImmutableAsList", 654); + feb(656, 2105, Yve, Kx); + _2.Rd = function Lx() { + return this.a; + }; + sfb(xve, "RegularImmutableList", 656); + feb(548, 730, $ve, Mx, Nx); + sfb(xve, "RegularImmutableMap", 548); + feb(731, 719, awe, Qx); + var Ox; + sfb(xve, "RegularImmutableSet", 731); + feb(2074, Eve, Fve); + _2.Kc = function by() { + return new oy(this.a, this.b); + }; + _2.Fc = function $x(a) { + throw Adb(new jib()); + }; + _2.Gc = function _x(a) { + throw Adb(new jib()); + }; + _2.$b = function ay() { + throw Adb(new jib()); + }; + _2.Mc = function cy(a) { + throw Adb(new jib()); + }; + sfb(xve, "Sets/SetView", 2074); + feb(976, 2074, Fve, ey); + _2.Kc = function iy() { + return new oy(this.a, this.b); + }; + _2.Hc = function fy(a) { + return Bsb(this.a, a) && this.b.Hc(a); + }; + _2.Ic = function gy(a) { + return Be(this.a, a) && this.b.Ic(a); + }; + _2.dc = function hy() { + return Aob(this.b, this.a); + }; + _2.Lc = function jy() { + return CDb(new SDb(null, new Swb(this.a, 1)), new qy(this.b)); + }; + _2.gc = function ky() { + return dy(this); + }; + _2.Oc = function ly() { + return CDb(new SDb(null, new Swb(this.a, 1)), new my(this.b)); + }; + sfb(xve, "Sets/2", 976); + feb(977, 1, nwe, my); + _2.Mb = function ny(a) { + return this.a.Hc(a); + }; + sfb(xve, "Sets/2/0methodref$contains$Type", 977); + feb(714, 713, wve, oy); + _2.Yb = function py() { + var a; + while (Msb(this.a)) { + a = Nsb(this.a); + if (this.c.Hc(a)) { + return a; + } + } + return this.e = 2, null; + }; + sfb(xve, "Sets/2/1", 714); + feb(978, 1, nwe, qy); + _2.Mb = function ry(a) { + return this.a.Hc(a); + }; + sfb(xve, "Sets/2/1methodref$contains$Type", 978); + feb(616, 2073, { 616: 1, 3: 1, 20: 1, 16: 1, 277: 1, 21: 1, 87: 1 }, sy); + _2.Kd = function ty() { + return this.b; + }; + _2.Ld = function uy() { + return this.b; + }; + _2.Wd = function vy() { + return this.b; + }; + _2.Jc = function wy(a) { + this.a.Jc(a); + }; + _2.Lc = function xy() { + return this.a.Lc(); + }; + _2.Oc = function yy() { + return this.a.Oc(); + }; + sfb(xve, "Sets/UnmodifiableNavigableSet", 616); + feb(2031, 2030, $ve, zy); + _2.Vd = function Ay() { + return _l(), new Fy(this.a); + }; + _2.Cc = function By() { + return _l(), new Fy(this.a); + }; + _2.xd = function Cy() { + return _l(), new Fy(this.a); + }; + sfb(xve, "SingletonImmutableBiMap", 2031); + feb(657, 2105, Yve, Dy); + _2.Rd = function Ey() { + return this.a; + }; + sfb(xve, "SingletonImmutableList", 657); + feb(363, 2079, awe, Fy); + _2.Kc = function Iy() { + return new $r(this.a); + }; + _2.Hc = function Gy(a) { + return pb(this.a, a); + }; + _2.Od = function Hy() { + return new $r(this.a); + }; + _2.gc = function Jy() { + return 1; + }; + sfb(xve, "SingletonImmutableSet", 363); + feb(1148, 1, {}, My); + _2.Kb = function Ny(a) { + return RD(a, 159); + }; + sfb(xve, "Streams/lambda$0$Type", 1148); + feb(1149, 1, owe, Oy); + _2.de = function Py() { + Ky(this.a); + }; + sfb(xve, "Streams/lambda$1$Type", 1149); + feb(1725, 1724, zve, Ry); + _2.Zb = function Sy() { + var a; + return a = this.f, RD(RD(!a ? this.f = ZD(this.c, 139) ? new Uf(this, RD(this.c, 139)) : ZD(this.c, 133) ? new Mf(this, RD(this.c, 133)) : new ne(this, this.c) : a, 133), 139); + }; + _2.hc = function Vy() { + return new yAb(this.b); + }; + _2.pd = function Wy() { + return new yAb(this.b); + }; + _2.ec = function Yy() { + var a; + return a = this.i, RD(RD(!a ? this.i = ZD(this.c, 139) ? new gg(this, RD(this.c, 139)) : ZD(this.c, 133) ? new eg(this, RD(this.c, 133)) : new zf(this, this.c) : a, 87), 277); + }; + _2.ac = function Uy() { + return ZD(this.c, 139) ? new Uf(this, RD(this.c, 139)) : ZD(this.c, 133) ? new Mf(this, RD(this.c, 133)) : new ne(this, this.c); + }; + _2.ic = function Xy(a) { + a == null && this.a.Ne(a, a); + return new yAb(this.b); + }; + sfb(xve, "TreeMultimap", 1725); + feb(82, 1, { 3: 1, 82: 1 }); + _2.ee = function pz(a) { + return new Error(a); + }; + _2.fe = function rz() { + return this.e; + }; + _2.ge = function sz() { + var a, b, c2; + c2 = (this.k == null && (this.k = $C(rJ, Nve, 82, 0, 0, 1)), this.k); + b = $C(jJ, rve, 1, c2.length, 5, 1); + for (a = 0; a < c2.length; a++) { + b[a] = c2[a].e; + } + return b; + }; + _2.he = function tz() { + return this.f; + }; + _2.ie = function uz() { + return this.g; + }; + _2.je = function vz() { + kz(this, qz(this.ee(lz(this, this.g)))); + gA(this); + }; + _2.Ib = function wz() { + return lz(this, this.ie()); + }; + _2.e = rwe; + _2.i = false; + _2.n = true; + var rJ = sfb(mve, "Throwable", 82); + feb(103, 82, { 3: 1, 103: 1, 82: 1 }); + sfb(mve, "Exception", 103); + feb(63, 103, swe, xz, yz); + sfb(mve, "RuntimeException", 63); + feb(607, 63, swe); + sfb(mve, "JsException", 607); + feb(875, 607, swe); + sfb(twe, "JavaScriptExceptionBase", 875); + feb(486, 875, { 486: 1, 3: 1, 103: 1, 63: 1, 82: 1 }, Cz); + _2.ie = function Fz() { + Bz(this); + return this.c; + }; + _2.ke = function Gz() { + return dE(this.b) === dE(zz) ? null : this.b; + }; + var zz; + sfb(vwe, "JavaScriptException", 486); + var hI = sfb(vwe, "JavaScriptObject$", 0); + var Jz; + feb(2047, 1, {}); + sfb(vwe, "Scheduler", 2047); + var Nz = 0, Oz = 0, Pz = -1; + feb(902, 2047, {}, bA); + var Zz; + sfb(twe, "SchedulerImpl", 902); + var eA; + feb(2058, 1, {}); + sfb(twe, "StackTraceCreator/Collector", 2058); + feb(876, 2058, {}, mA); + _2.le = function nA(a) { + var b = {}; + var c2 = []; + a[xwe] = c2; + var d = arguments.callee.caller; + while (d) { + var e = (fA(), d.name || (d.name = iA(d.toString()))); + c2.push(e); + var f2 = ":" + e; + var g = b[f2]; + if (g) { + var h, i2; + for (h = 0, i2 = g.length; h < i2; h++) { + if (g[h] === d) { + return; + } + } + } + (g || (b[f2] = [])).push(d); + d = d.caller; + } + }; + _2.me = function oA(a) { + var b, c2, d, e; + d = (fA(), a && a[xwe] ? a[xwe] : []); + c2 = d.length; + e = $C(mJ, Nve, 319, c2, 0, 1); + for (b = 0; b < c2; b++) { + e[b] = new ehb(d[b], null, -1); + } + return e; + }; + sfb(twe, "StackTraceCreator/CollectorLegacy", 876); + feb(2059, 2058, {}); + _2.le = function qA(a) { + }; + _2.ne = function rA(a, b, c2, d) { + return new ehb(b, a + "@" + d, c2 < 0 ? -1 : c2); + }; + _2.me = function sA(a) { + var b, c2, d, e, f2, g; + e = kA(a); + f2 = $C(mJ, Nve, 319, 0, 0, 1); + b = 0; + d = e.length; + if (d == 0) { + return f2; + } + g = pA(this, e[0]); + lhb(g.d, wwe) || (f2[b++] = g); + for (c2 = 1; c2 < d; c2++) { + f2[b++] = pA(this, e[c2]); + } + return f2; + }; + sfb(twe, "StackTraceCreator/CollectorModern", 2059); + feb(877, 2059, {}, tA); + _2.ne = function uA(a, b, c2, d) { + return new ehb(b, a, -1); + }; + sfb(twe, "StackTraceCreator/CollectorModernNoSourceMap", 877); + feb(1064, 1, {}); + sfb(Zwe, $we, 1064); + feb(624, 1064, { 624: 1 }, XA); + var VA; + sfb(_we, $we, 624); + feb(2101, 1, {}); + sfb(Zwe, axe, 2101); + feb(2102, 2101, {}); + sfb(_we, axe, 2102); + feb(1120, 1, {}, aB); + var ZA; + sfb(_we, "LocaleInfo", 1120); + feb(2027, 1, {}, dB); + _2.a = 0; + sfb(_we, "TimeZone", 2027); + feb(1293, 2102, {}, jB); + sfb("com.google.gwt.i18n.client.impl.cldr", "DateTimeFormatInfoImpl", 1293); + feb(443, 1, { 443: 1 }, kB); + _2.a = false; + _2.b = 0; + sfb(Zwe, "DateTimeFormat/PatternPart", 443); + feb(206, 1, bxe, uB, vB, wB); + _2.Fd = function xB(a) { + return lB(this, RD(a, 206)); + }; + _2.Fb = function yB(a) { + return ZD(a, 206) && Gdb(Hdb(this.q.getTime()), Hdb(RD(a, 206).q.getTime())); + }; + _2.Hb = function zB() { + var a; + a = Hdb(this.q.getTime()); + return Ydb($db(a, Udb(a, 32))); + }; + _2.Ib = function BB() { + var a, b, c2; + c2 = -this.q.getTimezoneOffset(); + a = (c2 >= 0 ? "+" : "") + (c2 / 60 | 0); + b = AB($wnd.Math.abs(c2) % 60); + return (Mrb(), Krb)[this.q.getDay()] + " " + Lrb[this.q.getMonth()] + " " + AB(this.q.getDate()) + " " + AB(this.q.getHours()) + ":" + AB(this.q.getMinutes()) + ":" + AB(this.q.getSeconds()) + " GMT" + a + b + " " + this.q.getFullYear(); + }; + var qK = sfb(Bve, "Date", 206); + feb(2015, 206, bxe, DB); + _2.a = false; + _2.b = 0; + _2.c = 0; + _2.d = 0; + _2.e = 0; + _2.f = 0; + _2.g = false; + _2.i = 0; + _2.j = 0; + _2.k = 0; + _2.n = 0; + _2.o = 0; + _2.p = 0; + sfb("com.google.gwt.i18n.shared.impl", "DateRecord", 2015); + feb(2064, 1, {}); + _2.pe = function EB() { + return null; + }; + _2.qe = function FB() { + return null; + }; + _2.re = function GB() { + return null; + }; + _2.se = function HB() { + return null; + }; + _2.te = function IB() { + return null; + }; + sfb(cxe, "JSONValue", 2064); + feb(221, 2064, { 221: 1 }, MB, NB); + _2.Fb = function OB(a) { + if (!ZD(a, 221)) { + return false; + } + return Hz(this.a, RD(a, 221).a); + }; + _2.oe = function PB() { + return TB; + }; + _2.Hb = function QB() { + return Iz(this.a); + }; + _2.pe = function RB() { + return this; + }; + _2.Ib = function SB() { + var a, b, c2; + c2 = new dib("["); + for (b = 0, a = this.a.length; b < a; b++) { + b > 0 && (c2.a += ",", c2); + Yhb(c2, JB(this, b)); + } + c2.a += "]"; + return c2.a; + }; + sfb(cxe, "JSONArray", 221); + feb(493, 2064, { 493: 1 }, XB); + _2.oe = function YB() { + return _B; + }; + _2.qe = function ZB() { + return this; + }; + _2.Ib = function $B() { + return Geb(), "" + this.a; + }; + _2.a = false; + var UB, VB; + sfb(cxe, "JSONBoolean", 493); + feb(997, 63, swe, aC); + sfb(cxe, "JSONException", 997); + feb(1036, 2064, {}, dC); + _2.oe = function eC() { + return gC; + }; + _2.Ib = function fC() { + return vve; + }; + var bC; + sfb(cxe, "JSONNull", 1036); + feb(263, 2064, { 263: 1 }, hC); + _2.Fb = function iC(a) { + if (!ZD(a, 263)) { + return false; + } + return this.a == RD(a, 263).a; + }; + _2.oe = function jC() { + return nC; + }; + _2.Hb = function kC() { + return Nfb(this.a); + }; + _2.re = function lC() { + return this; + }; + _2.Ib = function mC() { + return this.a + ""; + }; + _2.a = 0; + sfb(cxe, "JSONNumber", 263); + feb(190, 2064, { 190: 1 }, uC, vC); + _2.Fb = function wC(a) { + if (!ZD(a, 190)) { + return false; + } + return Hz(this.a, RD(a, 190).a); + }; + _2.oe = function xC() { + return BC; + }; + _2.Hb = function yC() { + return Iz(this.a); + }; + _2.se = function zC() { + return this; + }; + _2.Ib = function AC() { + var a, b, c2, d, e, f2, g; + g = new dib("{"); + a = true; + f2 = oC(this, $C(qJ, Nve, 2, 0, 6, 1)); + for (c2 = f2, d = 0, e = c2.length; d < e; ++d) { + b = c2[d]; + a ? a = false : (g.a += pve, g); + Zhb(g, Lz(b)); + g.a += ":"; + Yhb(g, qC(this, b)); + } + g.a += "}"; + return g.a; + }; + sfb(cxe, "JSONObject", 190); + feb(605, Eve, Fve, CC); + _2.Hc = function DC(a) { + return bE(a) && pC(this.a, WD(a)); + }; + _2.Kc = function EC() { + return new Dkb(new mob(this.b)); + }; + _2.gc = function FC() { + return this.b.length; + }; + sfb(cxe, "JSONObject/1", 605); + var GC; + feb(211, 2064, { 211: 1 }, OC); + _2.Fb = function PC(a) { + if (!ZD(a, 211)) { + return false; + } + return lhb(this.a, RD(a, 211).a); + }; + _2.oe = function QC() { + return UC; + }; + _2.Hb = function RC() { + return ohb(this.a); + }; + _2.te = function SC() { + return this; + }; + _2.Ib = function TC() { + return Lz(this.a); + }; + sfb(cxe, "JSONString", 211); + var eD; + var ID, JD, KD, LD; + feb(2060, 1, { 533: 1 }); + sfb(kxe, "OutputStream", 2060); + feb(2061, 2060, { 533: 1 }); + sfb(kxe, "FilterOutputStream", 2061); + feb(878, 2061, { 533: 1 }, oeb); + sfb(kxe, "PrintStream", 878); + feb(427, 1, { 484: 1 }); + _2.Ib = function seb() { + return this.a; + }; + sfb(mve, "AbstractStringBuilder", 427); + feb(538, 63, swe, teb); + sfb(mve, "ArithmeticException", 538); + feb(77, 63, lxe, ueb, veb); + sfb(mve, "IndexOutOfBoundsException", 77); + feb(333, 77, { 3: 1, 333: 1, 103: 1, 77: 1, 63: 1, 82: 1 }, web, xeb); + sfb(mve, "ArrayIndexOutOfBoundsException", 333); + feb(537, 63, swe, yeb, zeb); + sfb(mve, "ArrayStoreException", 537); + feb(296, 82, mxe, Aeb); + sfb(mve, "Error", 296); + feb(200, 296, mxe, Ceb, Deb); + sfb(mve, "AssertionError", 200); + ND = { 3: 1, 485: 1, 34: 1 }; + var Eeb, Feb; + var QI = sfb(mve, "Boolean", 485); + feb(242, 1, { 3: 1, 242: 1 }); + var Meb; + sfb(mve, "Number", 242); + feb(222, 242, { 3: 1, 222: 1, 34: 1, 242: 1 }, Seb); + _2.Fd = function Teb(a) { + return Reb(this, RD(a, 222)); + }; + _2.ue = function Ueb() { + return this.a; + }; + _2.Fb = function Veb(a) { + return ZD(a, 222) && RD(a, 222).a == this.a; + }; + _2.Hb = function Web() { + return this.a; + }; + _2.Ib = function Xeb() { + return "" + this.a; + }; + _2.a = 0; + var RI = sfb(mve, "Byte", 222); + var Yeb; + feb(180, 1, { 3: 1, 180: 1, 34: 1 }, bfb); + _2.Fd = function cfb(a) { + return afb(this, RD(a, 180)); + }; + _2.Fb = function efb(a) { + return ZD(a, 180) && RD(a, 180).a == this.a; + }; + _2.Hb = function ffb() { + return this.a; + }; + _2.Ib = function gfb() { + return String.fromCharCode(this.a); + }; + _2.a = 0; + var _eb; + var SI = sfb(mve, "Character", 180); + var ifb; + feb(212, 63, { 3: 1, 212: 1, 103: 1, 63: 1, 82: 1 }, Hfb, Ifb); + sfb(mve, "ClassCastException", 212); + OD = { 3: 1, 34: 1, 345: 1, 242: 1 }; + var VI = sfb(mve, "Double", 345); + feb(161, 242, { 3: 1, 34: 1, 161: 1, 242: 1 }, Tfb, Ufb); + _2.Fd = function Vfb(a) { + return Sfb(this, RD(a, 161)); + }; + _2.ue = function Wfb() { + return this.a; + }; + _2.Fb = function Xfb(a) { + return ZD(a, 161) && Lfb(this.a, RD(a, 161).a); + }; + _2.Hb = function Yfb() { + return eE(this.a); + }; + _2.Ib = function $fb() { + return "" + this.a; + }; + _2.a = 0; + var ZI = sfb(mve, "Float", 161); + feb(33, 63, { 3: 1, 103: 1, 33: 1, 63: 1, 82: 1 }, _fb, agb, bgb); + sfb(mve, "IllegalArgumentException", 33); + feb(73, 63, swe, cgb, dgb); + sfb(mve, "IllegalStateException", 73); + feb(17, 242, { 3: 1, 34: 1, 17: 1, 242: 1 }, fgb); + _2.Fd = function igb(a) { + return egb(this, RD(a, 17)); + }; + _2.ue = function jgb() { + return this.a; + }; + _2.Fb = function kgb(a) { + return ZD(a, 17) && RD(a, 17).a == this.a; + }; + _2.Hb = function lgb() { + return this.a; + }; + _2.Ib = function rgb2() { + return "" + this.a; + }; + _2.a = 0; + var bJ = sfb(mve, "Integer", 17); + var tgb; + var vgb; + feb(168, 242, { 3: 1, 34: 1, 168: 1, 242: 1 }, zgb); + _2.Fd = function Bgb(a) { + return ygb(this, RD(a, 168)); + }; + _2.ue = function Cgb() { + return Xdb(this.a); + }; + _2.Fb = function Dgb(a) { + return ZD(a, 168) && Gdb(RD(a, 168).a, this.a); + }; + _2.Hb = function Egb() { + return Fgb(this.a); + }; + _2.Ib = function Ggb() { + return "" + Zdb(this.a); + }; + _2.a = 0; + var eJ = sfb(mve, "Long", 168); + var Igb; + feb(2140, 1, {}); + feb(1904, 63, swe, Mgb); + sfb(mve, "NegativeArraySizeException", 1904); + feb(169, 607, { 3: 1, 103: 1, 169: 1, 63: 1, 82: 1 }, Ngb, Ogb); + _2.ee = function Pgb(a) { + return new TypeError(a); + }; + sfb(mve, "NullPointerException", 169); + var Qgb, Rgb2, Sgb, Tgb; + feb(130, 33, { 3: 1, 103: 1, 33: 1, 130: 1, 63: 1, 82: 1 }, Vgb); + sfb(mve, "NumberFormatException", 130); + feb(191, 242, { 3: 1, 34: 1, 242: 1, 191: 1 }, Xgb); + _2.Fd = function Ygb(a) { + return Wgb(this, RD(a, 191)); + }; + _2.ue = function Zgb() { + return this.a; + }; + _2.Fb = function $gb(a) { + return ZD(a, 191) && RD(a, 191).a == this.a; + }; + _2.Hb = function _gb() { + return this.a; + }; + _2.Ib = function ahb() { + return "" + this.a; + }; + _2.a = 0; + var lJ = sfb(mve, "Short", 191); + var chb; + feb(319, 1, { 3: 1, 319: 1 }, ehb); + _2.Fb = function fhb(a) { + var b; + if (ZD(a, 319)) { + b = RD(a, 319); + return this.c == b.c && this.d == b.d && this.a == b.a && this.b == b.b; + } + return false; + }; + _2.Hb = function ghb() { + return Tnb(cD(WC(jJ, 1), rve, 1, 5, [sgb(this.c), this.a, this.d, this.b])); + }; + _2.Ib = function hhb() { + return this.a + "." + this.d + "(" + (this.b != null ? this.b : "Unknown Source") + (this.c >= 0 ? ":" + this.c : "") + ")"; + }; + _2.c = 0; + var mJ = sfb(mve, "StackTraceElement", 319); + PD = { 3: 1, 484: 1, 34: 1, 2: 1 }; + var qJ = sfb(mve, uwe, 2); + feb(111, 427, { 484: 1 }, Qhb, Rhb, Shb); + sfb(mve, "StringBuffer", 111); + feb(104, 427, { 484: 1 }, bib, cib, dib); + sfb(mve, "StringBuilder", 104); + feb(702, 77, lxe, eib); + sfb(mve, "StringIndexOutOfBoundsException", 702); + feb(2145, 1, {}); + var fib; + feb(48, 63, { 3: 1, 103: 1, 63: 1, 82: 1, 48: 1 }, jib, kib); + sfb(mve, "UnsupportedOperationException", 48); + feb(247, 242, { 3: 1, 34: 1, 242: 1, 247: 1 }, Aib, Bib); + _2.Fd = function Eib(a) { + return uib(this, RD(a, 247)); + }; + _2.ue = function Fib() { + return Neb(zib(this)); + }; + _2.Fb = function Gib(a) { + var b; + if (this === a) { + return true; + } + if (ZD(a, 247)) { + b = RD(a, 247); + return this.e == b.e && uib(this, b) == 0; + } + return false; + }; + _2.Hb = function Hib() { + var a; + if (this.b != 0) { + return this.b; + } + if (this.a < 54) { + a = Hdb(this.f); + this.b = Ydb(Cdb(a, -1)); + this.b = 33 * this.b + Ydb(Cdb(Tdb(a, 32), -1)); + this.b = 17 * this.b + eE(this.e); + return this.b; + } + this.b = 17 * Vib(this.c) + eE(this.e); + return this.b; + }; + _2.Ib = function Iib() { + return zib(this); + }; + _2.a = 0; + _2.b = 0; + _2.d = 0; + _2.e = 0; + _2.f = 0; + var lib, mib, nib, oib, pib, qib, rib, sib; + var tJ = sfb("java.math", "BigDecimal", 247); + feb(92, 242, { 3: 1, 34: 1, 242: 1, 92: 1 }, ajb, bjb, cjb, djb, ejb); + _2.Fd = function gjb(a) { + return Qib(this, RD(a, 92)); + }; + _2.ue = function hjb() { + return Neb(Ajb(this, 0)); + }; + _2.Fb = function ijb(a) { + return Sib(this, a); + }; + _2.Hb = function ljb() { + return Vib(this); + }; + _2.Ib = function njb() { + return Ajb(this, 0); + }; + _2.b = -2; + _2.c = 0; + _2.d = 0; + _2.e = 0; + var Jib, Kib, Lib, Mib, Nib, Oib; + var uJ = sfb("java.math", "BigInteger", 92); + var vjb, wjb; + var Jjb, Kjb; + feb(498, 2065, Cve); + _2.$b = function dkb() { + akb(this); + }; + _2._b = function ekb(a) { + return Ujb(this, a); + }; + _2.uc = function fkb(a) { + return Vjb(this, a, this.i) || Vjb(this, a, this.f); + }; + _2.vc = function gkb() { + return new mkb(this); + }; + _2.xc = function hkb(a) { + return Wjb(this, a); + }; + _2.zc = function ikb(a, b) { + return Zjb(this, a, b); + }; + _2.Bc = function jkb(a) { + return _jb(this, a); + }; + _2.gc = function kkb() { + return bkb(this); + }; + _2.g = 0; + sfb(Bve, "AbstractHashMap", 498); + feb(267, Eve, Fve, mkb); + _2.$b = function nkb() { + this.a.$b(); + }; + _2.Hc = function okb(a) { + return lkb(this, a); + }; + _2.Kc = function pkb() { + return new vkb(this.a); + }; + _2.Mc = function qkb(a) { + var b; + if (lkb(this, a)) { + b = RD(a, 44).ld(); + this.a.Bc(b); + return true; + } + return false; + }; + _2.gc = function rkb() { + return this.a.gc(); + }; + sfb(Bve, "AbstractHashMap/EntrySet", 267); + feb(268, 1, Ave, vkb); + _2.Nb = function wkb(a) { + Ztb(this, a); + }; + _2.Pb = function ykb() { + return tkb(this); + }; + _2.Ob = function xkb() { + return this.b; + }; + _2.Qb = function zkb() { + ukb(this); + }; + _2.b = false; + _2.d = 0; + sfb(Bve, "AbstractHashMap/EntrySetIterator", 268); + feb(426, 1, Ave, Dkb); + _2.Nb = function Ekb(a) { + Ztb(this, a); + }; + _2.Ob = function Fkb() { + return Akb(this); + }; + _2.Pb = function Gkb() { + return Bkb(this); + }; + _2.Qb = function Hkb() { + Ckb(this); + }; + _2.b = 0; + _2.c = -1; + sfb(Bve, "AbstractList/IteratorImpl", 426); + feb(98, 426, Jve, Jkb); + _2.Qb = function Pkb() { + Ckb(this); + }; + _2.Rb = function Kkb(a) { + Ikb(this, a); + }; + _2.Sb = function Lkb() { + return this.b > 0; + }; + _2.Tb = function Mkb() { + return this.b; + }; + _2.Ub = function Nkb() { + return sFb(this.b > 0), this.a.Xb(this.c = --this.b); + }; + _2.Vb = function Okb() { + return this.b - 1; + }; + _2.Wb = function Qkb(a) { + yFb(this.c != -1); + this.a.hd(this.c, a); + }; + sfb(Bve, "AbstractList/ListIteratorImpl", 98); + feb(244, 56, kwe, Rkb); + _2.bd = function Skb(a, b) { + wFb(a, this.b); + this.c.bd(this.a + a, b); + ++this.b; + }; + _2.Xb = function Tkb(a) { + tFb(a, this.b); + return this.c.Xb(this.a + a); + }; + _2.gd = function Ukb(a) { + var b; + tFb(a, this.b); + b = this.c.gd(this.a + a); + --this.b; + return b; + }; + _2.hd = function Vkb(a, b) { + tFb(a, this.b); + return this.c.hd(this.a + a, b); + }; + _2.gc = function Wkb() { + return this.b; + }; + _2.a = 0; + _2.b = 0; + sfb(Bve, "AbstractList/SubList", 244); + feb(266, Eve, Fve, Xkb); + _2.$b = function Ykb() { + this.a.$b(); + }; + _2.Hc = function Zkb(a) { + return this.a._b(a); + }; + _2.Kc = function $kb() { + var a; + return a = this.a.vc().Kc(), new blb(a); + }; + _2.Mc = function _kb(a) { + if (this.a._b(a)) { + this.a.Bc(a); + return true; + } + return false; + }; + _2.gc = function alb() { + return this.a.gc(); + }; + sfb(Bve, "AbstractMap/1", 266); + feb(541, 1, Ave, blb); + _2.Nb = function clb(a) { + Ztb(this, a); + }; + _2.Ob = function dlb() { + return this.a.Ob(); + }; + _2.Pb = function elb() { + var a; + return a = RD(this.a.Pb(), 44), a.ld(); + }; + _2.Qb = function flb() { + this.a.Qb(); + }; + sfb(Bve, "AbstractMap/1/1", 541); + feb(231, 31, Dve, glb); + _2.$b = function hlb() { + this.a.$b(); + }; + _2.Hc = function ilb(a) { + return this.a.uc(a); + }; + _2.Kc = function jlb() { + var a; + return a = this.a.vc().Kc(), new llb(a); + }; + _2.gc = function klb() { + return this.a.gc(); + }; + sfb(Bve, "AbstractMap/2", 231); + feb(301, 1, Ave, llb); + _2.Nb = function mlb(a) { + Ztb(this, a); + }; + _2.Ob = function nlb() { + return this.a.Ob(); + }; + _2.Pb = function olb() { + var a; + return a = RD(this.a.Pb(), 44), a.md(); + }; + _2.Qb = function plb() { + this.a.Qb(); + }; + sfb(Bve, "AbstractMap/2/1", 301); + feb(494, 1, { 494: 1, 44: 1 }); + _2.Fb = function rlb(a) { + var b; + if (!ZD(a, 44)) { + return false; + } + b = RD(a, 44); + return Fvb(this.d, b.ld()) && Fvb(this.e, b.md()); + }; + _2.ld = function slb() { + return this.d; + }; + _2.md = function tlb() { + return this.e; + }; + _2.Hb = function ulb() { + return Gvb(this.d) ^ Gvb(this.e); + }; + _2.nd = function vlb(a) { + return qlb(this, a); + }; + _2.Ib = function wlb() { + return this.d + "=" + this.e; + }; + sfb(Bve, "AbstractMap/AbstractEntry", 494); + feb(397, 494, { 494: 1, 397: 1, 44: 1 }, xlb); + sfb(Bve, "AbstractMap/SimpleEntry", 397); + feb(2082, 1, Axe); + _2.Fb = function ylb(a) { + var b; + if (!ZD(a, 44)) { + return false; + } + b = RD(a, 44); + return Fvb(this.ld(), b.ld()) && Fvb(this.md(), b.md()); + }; + _2.Hb = function zlb() { + return Gvb(this.ld()) ^ Gvb(this.md()); + }; + _2.Ib = function Alb() { + return this.ld() + "=" + this.md(); + }; + sfb(Bve, Lve, 2082); + feb(2090, 2065, Gve); + _2.Xc = function Dlb(a) { + return Vd(this.Ee(a)); + }; + _2.tc = function Elb(a) { + return Blb(this, a); + }; + _2._b = function Flb(a) { + return Clb(this, a); + }; + _2.vc = function Glb() { + return new Plb(this); + }; + _2.Tc = function Hlb() { + return Klb(this.Ge()); + }; + _2.Yc = function Ilb(a) { + return Vd(this.He(a)); + }; + _2.xc = function Jlb(a) { + var b; + b = a; + return Wd(this.Fe(b)); + }; + _2.$c = function Llb(a) { + return Vd(this.Ie(a)); + }; + _2.ec = function Mlb() { + return new Ulb(this); + }; + _2.Vc = function Nlb() { + return Klb(this.Je()); + }; + _2._c = function Olb(a) { + return Vd(this.Ke(a)); + }; + sfb(Bve, "AbstractNavigableMap", 2090); + feb(629, Eve, Fve, Plb); + _2.Hc = function Qlb(a) { + return ZD(a, 44) && Blb(this.b, RD(a, 44)); + }; + _2.Kc = function Rlb() { + return this.b.De(); + }; + _2.Mc = function Slb(a) { + var b; + if (ZD(a, 44)) { + b = RD(a, 44); + return this.b.Le(b); + } + return false; + }; + _2.gc = function Tlb() { + return this.b.gc(); + }; + sfb(Bve, "AbstractNavigableMap/EntrySet", 629); + feb(1146, Eve, Ive, Ulb); + _2.Nc = function $lb() { + return new $wb(this); + }; + _2.$b = function Vlb() { + this.a.$b(); + }; + _2.Hc = function Wlb(a) { + return Clb(this.a, a); + }; + _2.Kc = function Xlb() { + var a; + a = this.a.vc().b.De(); + return new _lb(a); + }; + _2.Mc = function Ylb(a) { + if (Clb(this.a, a)) { + this.a.Bc(a); + return true; + } + return false; + }; + _2.gc = function Zlb() { + return this.a.gc(); + }; + sfb(Bve, "AbstractNavigableMap/NavigableKeySet", 1146); + feb(1147, 1, Ave, _lb); + _2.Nb = function amb(a) { + Ztb(this, a); + }; + _2.Ob = function bmb() { + return Akb(this.a.a); + }; + _2.Pb = function cmb() { + var a; + a = vzb(this.a); + return a.ld(); + }; + _2.Qb = function dmb() { + wzb(this.a); + }; + sfb(Bve, "AbstractNavigableMap/NavigableKeySet/1", 1147); + feb(2103, 31, Dve); + _2.Fc = function emb(a) { + return zFb(lwb(this, a), Bxe), true; + }; + _2.Gc = function fmb(a) { + uFb(a); + mFb(a != this, "Can't add a queue to itself"); + return ye(this, a); + }; + _2.$b = function gmb() { + while (mwb(this) != null) + ; + }; + sfb(Bve, "AbstractQueue", 2103); + feb(310, 31, { 4: 1, 20: 1, 31: 1, 16: 1 }, wmb, xmb); + _2.Fc = function ymb(a) { + return imb(this, a), true; + }; + _2.$b = function Amb() { + jmb(this); + }; + _2.Hc = function Bmb(a) { + return kmb(new Kmb(this), a); + }; + _2.dc = function Cmb() { + return nmb(this); + }; + _2.Kc = function Dmb() { + return new Kmb(this); + }; + _2.Mc = function Emb(a) { + return qmb(new Kmb(this), a); + }; + _2.gc = function Fmb() { + return this.c - this.b & this.a.length - 1; + }; + _2.Nc = function Gmb() { + return new Swb(this, 272); + }; + _2.Qc = function Hmb(a) { + var b; + b = this.c - this.b & this.a.length - 1; + a.length < b && (a = cFb(new Array(b), a)); + lmb(this, a, b); + a.length > b && bD(a, b, null); + return a; + }; + _2.b = 0; + _2.c = 0; + sfb(Bve, "ArrayDeque", 310); + feb(459, 1, Ave, Kmb); + _2.Nb = function Lmb(a) { + Ztb(this, a); + }; + _2.Ob = function Mmb() { + return this.a != this.b; + }; + _2.Pb = function Nmb() { + return Imb(this); + }; + _2.Qb = function Omb() { + Jmb(this); + }; + _2.a = 0; + _2.b = 0; + _2.c = -1; + sfb(Bve, "ArrayDeque/IteratorImpl", 459); + feb(13, 56, Cxe, bnb, cnb, dnb); + _2.bd = function enb(a, b) { + Qmb(this, a, b); + }; + _2.Fc = function fnb(a) { + return Rmb(this, a); + }; + _2.cd = function gnb(a, b) { + return Smb(this, a, b); + }; + _2.Gc = function hnb(a) { + return Tmb(this, a); + }; + _2.$b = function inb() { + aFb(this.c, 0); + }; + _2.Hc = function jnb(a) { + return Wmb(this, a, 0) != -1; + }; + _2.Jc = function knb(a) { + Umb(this, a); + }; + _2.Xb = function lnb(a) { + return Vmb(this, a); + }; + _2.dd = function mnb(a) { + return Wmb(this, a, 0); + }; + _2.dc = function nnb() { + return this.c.length == 0; + }; + _2.Kc = function onb() { + return new Anb(this); + }; + _2.gd = function pnb(a) { + return Xmb(this, a); + }; + _2.Mc = function qnb(a) { + return Ymb(this, a); + }; + _2.ce = function rnb(a, b) { + Zmb(this, a, b); + }; + _2.hd = function snb(a, b) { + return $mb(this, a, b); + }; + _2.gc = function tnb() { + return this.c.length; + }; + _2.jd = function unb(a) { + _mb(this, a); + }; + _2.Pc = function vnb() { + return UEb(this.c); + }; + _2.Qc = function wnb(a) { + return anb(this, a); + }; + var VJ = sfb(Bve, "ArrayList", 13); + feb(7, 1, Ave, Anb); + _2.Nb = function Bnb(a) { + Ztb(this, a); + }; + _2.Ob = function Cnb() { + return xnb(this); + }; + _2.Pb = function Dnb() { + return ynb(this); + }; + _2.Qb = function Enb() { + znb(this); + }; + _2.a = 0; + _2.b = -1; + sfb(Bve, "ArrayList/1", 7); + feb(2112, $wnd.Function, {}, iob); + _2.Me = function job(a, b) { + return Qfb(a, b); + }; + feb(151, 56, Dxe, mob); + _2.Hc = function nob(a) { + return St(this, a) != -1; + }; + _2.Jc = function oob(a) { + var b, c2, d, e; + uFb(a); + for (c2 = this.a, d = 0, e = c2.length; d < e; ++d) { + b = c2[d]; + a.Cd(b); + } + }; + _2.Xb = function pob(a) { + return kob(this, a); + }; + _2.hd = function qob(a, b) { + var c2; + c2 = (tFb(a, this.a.length), this.a[a]); + bD(this.a, a, b); + return c2; + }; + _2.gc = function rob() { + return this.a.length; + }; + _2.jd = function sob(a) { + Ynb(this.a, this.a.length, a); + }; + _2.Pc = function tob() { + return lob(this, $C(jJ, rve, 1, this.a.length, 5, 1)); + }; + _2.Qc = function uob(a) { + return lob(this, a); + }; + sfb(Bve, "Arrays/ArrayList", 151); + var vob, wob, xob; + feb(953, 56, Dxe, Job); + _2.Hc = function Kob(a) { + return false; + }; + _2.Xb = function Lob(a) { + return Iob(a); + }; + _2.Kc = function Mob() { + return yob(), Qob(), Pob; + }; + _2.ed = function Nob() { + return yob(), Qob(), Pob; + }; + _2.gc = function Oob() { + return 0; + }; + sfb(Bve, "Collections/EmptyList", 953); + feb(954, 1, Jve, Rob); + _2.Nb = function Tob(a) { + Ztb(this, a); + }; + _2.Rb = function Sob(a) { + throw Adb(new jib()); + }; + _2.Ob = function Uob() { + return false; + }; + _2.Sb = function Vob() { + return false; + }; + _2.Pb = function Wob() { + throw Adb(new Dvb()); + }; + _2.Tb = function Xob() { + return 0; + }; + _2.Ub = function Yob() { + throw Adb(new Dvb()); + }; + _2.Vb = function Zob() { + return -1; + }; + _2.Qb = function $ob() { + throw Adb(new cgb()); + }; + _2.Wb = function _ob(a) { + throw Adb(new cgb()); + }; + var Pob; + sfb(Bve, "Collections/EmptyListIterator", 954); + feb(956, 2065, $ve, apb); + _2._b = function bpb(a) { + return false; + }; + _2.uc = function cpb(a) { + return false; + }; + _2.vc = function dpb() { + return yob(), xob; + }; + _2.xc = function epb(a) { + return null; + }; + _2.ec = function fpb() { + return yob(), xob; + }; + _2.gc = function gpb() { + return 0; + }; + _2.Cc = function hpb() { + return yob(), vob; + }; + sfb(Bve, "Collections/EmptyMap", 956); + feb(955, Eve, awe, ipb); + _2.Hc = function jpb(a) { + return false; + }; + _2.Kc = function kpb() { + return yob(), Qob(), Pob; + }; + _2.gc = function lpb() { + return 0; + }; + sfb(Bve, "Collections/EmptySet", 955); + feb(608, 56, { 3: 1, 20: 1, 31: 1, 56: 1, 16: 1, 15: 1 }, mpb); + _2.Hc = function npb(a) { + return Fvb(this.a, a); + }; + _2.Xb = function opb(a) { + tFb(a, 1); + return this.a; + }; + _2.gc = function ppb() { + return 1; + }; + sfb(Bve, "Collections/SingletonList", 608); + feb(384, 1, Wve, xpb); + _2.Jc = function Dpb(a) { + xgb(this, a); + }; + _2.Lc = function Gpb() { + return new SDb(null, this.Nc()); + }; + _2.Nc = function Jpb() { + return new Swb(this, 0); + }; + _2.Oc = function Kpb() { + return new SDb(null, this.Nc()); + }; + _2.Fc = function ypb(a) { + return qpb(); + }; + _2.Gc = function zpb(a) { + return rpb(); + }; + _2.$b = function Apb() { + spb(); + }; + _2.Hc = function Bpb(a) { + return tpb(this, a); + }; + _2.Ic = function Cpb(a) { + return upb(this, a); + }; + _2.dc = function Epb() { + return this.b.dc(); + }; + _2.Kc = function Fpb() { + return new Ppb(this.b.Kc()); + }; + _2.Mc = function Hpb(a) { + return vpb(); + }; + _2.gc = function Ipb() { + return this.b.gc(); + }; + _2.Pc = function Lpb() { + return this.b.Pc(); + }; + _2.Qc = function Mpb(a) { + return wpb(this, a); + }; + _2.Ib = function Npb() { + return jeb(this.b); + }; + sfb(Bve, "Collections/UnmodifiableCollection", 384); + feb(383, 1, Ave, Ppb); + _2.Nb = function Qpb(a) { + Ztb(this, a); + }; + _2.Ob = function Rpb() { + return this.b.Ob(); + }; + _2.Pb = function Spb() { + return this.b.Pb(); + }; + _2.Qb = function Tpb() { + Opb(); + }; + sfb(Bve, "Collections/UnmodifiableCollectionIterator", 383); + feb(540, 384, Exe, Upb); + _2.Nc = function fqb() { + return new Swb(this, 16); + }; + _2.bd = function Vpb(a, b) { + throw Adb(new jib()); + }; + _2.cd = function Wpb(a, b) { + throw Adb(new jib()); + }; + _2.Fb = function Xpb(a) { + return pb(this.a, a); + }; + _2.Xb = function Ypb(a) { + return this.a.Xb(a); + }; + _2.Hb = function Zpb() { + return tb(this.a); + }; + _2.dd = function $pb(a) { + return this.a.dd(a); + }; + _2.dc = function _pb() { + return this.a.dc(); + }; + _2.ed = function aqb() { + return new hqb(this.a.fd(0)); + }; + _2.fd = function bqb(a) { + return new hqb(this.a.fd(a)); + }; + _2.gd = function cqb(a) { + throw Adb(new jib()); + }; + _2.hd = function dqb(a, b) { + throw Adb(new jib()); + }; + _2.jd = function eqb(a) { + throw Adb(new jib()); + }; + _2.kd = function gqb(a, b) { + return new Upb(this.a.kd(a, b)); + }; + sfb(Bve, "Collections/UnmodifiableList", 540); + feb(705, 383, Jve, hqb); + _2.Qb = function nqb() { + Opb(); + }; + _2.Rb = function iqb(a) { + throw Adb(new jib()); + }; + _2.Sb = function jqb() { + return this.a.Sb(); + }; + _2.Tb = function kqb() { + return this.a.Tb(); + }; + _2.Ub = function lqb() { + return this.a.Ub(); + }; + _2.Vb = function mqb() { + return this.a.Vb(); + }; + _2.Wb = function oqb(a) { + throw Adb(new jib()); + }; + sfb(Bve, "Collections/UnmodifiableListIterator", 705); + feb(609, 1, Cve, uqb); + _2.wc = function Aqb(a) { + Bvb(this, a); + }; + _2.yc = function Fqb(a, b, c2) { + return Cvb(this, a, b, c2); + }; + _2.$b = function vqb() { + throw Adb(new jib()); + }; + _2._b = function wqb(a) { + return this.c._b(a); + }; + _2.uc = function xqb(a) { + return pqb(this, a); + }; + _2.vc = function yqb() { + return qqb(this); + }; + _2.Fb = function zqb(a) { + return rqb(this, a); + }; + _2.xc = function Bqb(a) { + return this.c.xc(a); + }; + _2.Hb = function Cqb() { + return tb(this.c); + }; + _2.dc = function Dqb() { + return this.c.dc(); + }; + _2.ec = function Eqb() { + return sqb(this); + }; + _2.zc = function Gqb(a, b) { + throw Adb(new jib()); + }; + _2.Bc = function Hqb(a) { + throw Adb(new jib()); + }; + _2.gc = function Iqb() { + return this.c.gc(); + }; + _2.Ib = function Jqb() { + return jeb(this.c); + }; + _2.Cc = function Kqb() { + return tqb(this); + }; + sfb(Bve, "Collections/UnmodifiableMap", 609); + feb(396, 384, _ve, Lqb); + _2.Nc = function Oqb() { + return new Swb(this, 1); + }; + _2.Fb = function Mqb(a) { + return pb(this.b, a); + }; + _2.Hb = function Nqb() { + return tb(this.b); + }; + sfb(Bve, "Collections/UnmodifiableSet", 396); + feb(957, 396, _ve, Sqb); + _2.Hc = function Tqb(a) { + return Pqb(this, a); + }; + _2.Ic = function Uqb(a) { + return this.b.Ic(a); + }; + _2.Kc = function Vqb() { + var a; + a = this.b.Kc(); + return new Yqb(a); + }; + _2.Pc = function Wqb() { + var a; + a = this.b.Pc(); + Rqb(a, a.length); + return a; + }; + _2.Qc = function Xqb(a) { + return Qqb(this, a); + }; + sfb(Bve, "Collections/UnmodifiableMap/UnmodifiableEntrySet", 957); + feb(958, 1, Ave, Yqb); + _2.Nb = function Zqb(a) { + Ztb(this, a); + }; + _2.Pb = function _qb() { + return new brb(RD(this.a.Pb(), 44)); + }; + _2.Ob = function $qb() { + return this.a.Ob(); + }; + _2.Qb = function arb() { + throw Adb(new jib()); + }; + sfb(Bve, "Collections/UnmodifiableMap/UnmodifiableEntrySet/1", 958); + feb(703, 1, Axe, brb); + _2.Fb = function crb(a) { + return this.a.Fb(a); + }; + _2.ld = function drb() { + return this.a.ld(); + }; + _2.md = function erb() { + return this.a.md(); + }; + _2.Hb = function frb() { + return this.a.Hb(); + }; + _2.nd = function grb(a) { + throw Adb(new jib()); + }; + _2.Ib = function hrb() { + return jeb(this.a); + }; + sfb(Bve, "Collections/UnmodifiableMap/UnmodifiableEntrySet/UnmodifiableEntry", 703); + feb(610, 540, { 20: 1, 16: 1, 15: 1, 59: 1 }, irb); + sfb(Bve, "Collections/UnmodifiableRandomAccessList", 610); + feb(704, 396, bwe, jrb); + _2.Nc = function mrb() { + return new $wb(this); + }; + _2.Fb = function krb(a) { + return pb(this.a, a); + }; + _2.Hb = function lrb() { + return tb(this.a); + }; + sfb(Bve, "Collections/UnmodifiableSortedSet", 704); + feb(858, 1, Fxe, nrb); + _2.Ne = function orb(a, b) { + var c2; + return c2 = ygc(RD(a, 12), RD(b, 12)), c2 != 0 ? c2 : zgc(RD(a, 12), RD(b, 12)); + }; + _2.Fb = function prb(a) { + return this === a; + }; + _2.Oe = function qrb() { + return new Frb(this); + }; + sfb(Bve, "Comparator/lambda$0$Type", 858); + var rrb, srb, trb; + feb(769, 1, Fxe, wrb); + _2.Ne = function xrb(a, b) { + return vrb(RD(a, 34), RD(b, 34)); + }; + _2.Fb = function yrb(a) { + return this === a; + }; + _2.Oe = function zrb() { + return urb(), trb; + }; + sfb(Bve, "Comparators/NaturalOrderComparator", 769); + feb(1226, 1, Fxe, Brb); + _2.Ne = function Crb(a, b) { + return Arb(RD(a, 34), RD(b, 34)); + }; + _2.Fb = function Drb(a) { + return this === a; + }; + _2.Oe = function Erb() { + return urb(), srb; + }; + sfb(Bve, "Comparators/ReverseNaturalOrderComparator", 1226); + feb(52, 1, Fxe, Frb); + _2.Fb = function Hrb(a) { + return this === a; + }; + _2.Ne = function Grb(a, b) { + return this.a.Ne(b, a); + }; + _2.Oe = function Irb() { + return this.a; + }; + sfb(Bve, "Comparators/ReversedComparator", 52); + feb(175, 63, swe, Jrb); + sfb(Bve, "ConcurrentModificationException", 175); + var Krb, Lrb; + feb(1948, 1, Gxe, Prb); + _2.Pe = function Qrb(a) { + Nrb(this, a); + }; + _2.Ib = function Rrb() { + return "DoubleSummaryStatistics[count = " + Zdb(this.a) + ", avg = " + (Idb(this.a, 0) ? Orb(this) / Xdb(this.a) : 0) + ", min = " + this.c + ", max = " + this.b + ", sum = " + Orb(this) + "]"; + }; + _2.a = 0; + _2.b = pxe; + _2.c = oxe; + _2.d = 0; + _2.e = 0; + _2.f = 0; + sfb(Bve, "DoubleSummaryStatistics", 1948); + feb(1868, 63, swe, Srb); + sfb(Bve, "EmptyStackException", 1868); + feb(461, 2065, Cve, Zrb); + _2.zc = function dsb(a, b) { + return Xrb(this, a, b); + }; + _2.$b = function $rb() { + Trb(this); + }; + _2._b = function _rb(a) { + return Urb(this, a); + }; + _2.uc = function asb(a) { + var b, c2; + for (c2 = new Osb(this.a); c2.a < c2.c.a.length; ) { + b = Nsb(c2); + if (Fvb(a, this.b[b.g])) { + return true; + } + } + return false; + }; + _2.vc = function bsb() { + return new hsb(this); + }; + _2.xc = function csb(a) { + return Vrb(this, a); + }; + _2.Bc = function esb(a) { + return Yrb(this, a); + }; + _2.gc = function fsb() { + return this.a.c; + }; + sfb(Bve, "EnumMap", 461); + feb(1340, Eve, Fve, hsb); + _2.$b = function isb() { + Trb(this.a); + }; + _2.Hc = function jsb(a) { + return gsb(this, a); + }; + _2.Kc = function ksb() { + return new nsb(this.a); + }; + _2.Mc = function lsb(a) { + var b; + if (gsb(this, a)) { + b = RD(a, 44).ld(); + Yrb(this.a, b); + return true; + } + return false; + }; + _2.gc = function msb() { + return this.a.a.c; + }; + sfb(Bve, "EnumMap/EntrySet", 1340); + feb(1341, 1, Ave, nsb); + _2.Nb = function osb(a) { + Ztb(this, a); + }; + _2.Pb = function qsb() { + return this.b = Nsb(this.a), new ssb(this.c, this.b); + }; + _2.Ob = function psb() { + return Msb(this.a); + }; + _2.Qb = function rsb() { + yFb(!!this.b); + Yrb(this.c, this.b); + this.b = null; + }; + sfb(Bve, "EnumMap/EntrySetIterator", 1341); + feb(1342, 2082, Axe, ssb); + _2.ld = function tsb() { + return this.a; + }; + _2.md = function usb() { + return this.b.b[this.a.g]; + }; + _2.nd = function vsb(a) { + return _Eb(this.b.b, this.a.g, a); + }; + sfb(Bve, "EnumMap/MapEntry", 1342); + feb(181, Eve, { 20: 1, 31: 1, 16: 1, 181: 1, 21: 1 }); + var zK = sfb(Bve, "EnumSet", 181); + feb(162, 181, { 20: 1, 31: 1, 16: 1, 181: 1, 162: 1, 21: 1 }, Fsb); + _2.Fc = function Gsb(a) { + return zsb(this, RD(a, 22)); + }; + _2.Hc = function Hsb(a) { + return Bsb(this, a); + }; + _2.Kc = function Isb() { + return new Osb(this); + }; + _2.Mc = function Jsb(a) { + return Dsb(this, a); + }; + _2.gc = function Ksb() { + return this.c; + }; + _2.c = 0; + sfb(Bve, "EnumSet/EnumSetImpl", 162); + feb(356, 1, Ave, Osb); + _2.Nb = function Psb(a) { + Ztb(this, a); + }; + _2.Pb = function Rsb() { + return Nsb(this); + }; + _2.Ob = function Qsb() { + return Msb(this); + }; + _2.Qb = function Ssb() { + yFb(this.b != -1); + bD(this.c.b, this.b, null); + --this.c.c; + this.b = -1; + }; + _2.a = -1; + _2.b = -1; + sfb(Bve, "EnumSet/EnumSetImpl/IteratorImpl", 356); + feb(45, 498, Hxe, Tsb, Usb, Vsb); + _2.Be = function Wsb(a, b) { + return dE(a) === dE(b) || a != null && pb(a, b); + }; + _2.Ce = function Xsb(a) { + var b; + if (a == null) { + return 0; + } + b = tb(a); + return b | 0; + }; + sfb(Bve, "HashMap", 45); + feb(49, Eve, Ixe, _sb, atb, btb); + _2.Fc = function dtb(a) { + return Ysb(this, a); + }; + _2.$b = function etb() { + this.a.$b(); + }; + _2.Hc = function ftb(a) { + return Zsb(this, a); + }; + _2.dc = function gtb() { + return this.a.gc() == 0; + }; + _2.Kc = function htb() { + return this.a.ec().Kc(); + }; + _2.Mc = function itb(a) { + return $sb(this, a); + }; + _2.gc = function jtb() { + return this.a.gc(); + }; + var BK = sfb(Bve, "HashSet", 49); + feb(1897, 1, Rve, ltb); + _2.Dd = function mtb(a) { + ktb(this, a); + }; + _2.Ib = function ntb() { + return "IntSummaryStatistics[count = " + Zdb(this.a) + ", avg = " + (Idb(this.a, 0) ? Xdb(this.d) / Xdb(this.a) : 0) + ", min = " + this.c + ", max = " + this.b + ", sum = " + Zdb(this.d) + "]"; + }; + _2.a = 0; + _2.b = qwe; + _2.c = lve; + _2.d = 0; + sfb(Bve, "IntSummaryStatistics", 1897); + feb(1062, 1, Vve, ttb); + _2.Jc = function utb(a) { + xgb(this, a); + }; + _2.Kc = function vtb() { + return new wtb(this); + }; + _2.c = 0; + sfb(Bve, "InternalHashCodeMap", 1062); + feb(726, 1, Ave, wtb); + _2.Nb = function xtb(a) { + Ztb(this, a); + }; + _2.Pb = function ztb() { + return this.d = this.a[this.c++], this.d; + }; + _2.Ob = function ytb() { + var a; + if (this.c < this.a.length) { + return true; + } + a = this.b.next(); + if (!a.done) { + this.a = a.value[1]; + this.c = 0; + return true; + } + return false; + }; + _2.Qb = function Atb() { + stb(this.e, this.d.ld()); + this.c != 0 && --this.c; + }; + _2.c = 0; + _2.d = null; + sfb(Bve, "InternalHashCodeMap/1", 726); + var Dtb; + feb(1060, 1, Vve, Ntb); + _2.Jc = function Otb(a) { + xgb(this, a); + }; + _2.Kc = function Ptb() { + return new Qtb(this); + }; + _2.c = 0; + _2.d = 0; + sfb(Bve, "InternalStringMap", 1060); + feb(725, 1, Ave, Qtb); + _2.Nb = function Rtb(a) { + Ztb(this, a); + }; + _2.Pb = function Ttb() { + return this.c = this.a, this.a = this.b.next(), new Vtb(this.d, this.c, this.d.d); + }; + _2.Ob = function Stb() { + return !this.a.done; + }; + _2.Qb = function Utb() { + Mtb(this.d, this.c.value[0]); + }; + sfb(Bve, "InternalStringMap/1", 725); + feb(1061, 2082, Axe, Vtb); + _2.ld = function Wtb() { + return this.b.value[0]; + }; + _2.md = function Xtb() { + if (this.a.d != this.c) { + return Ktb(this.a, this.b.value[0]); + } + return this.b.value[1]; + }; + _2.nd = function Ytb(a) { + return Ltb(this.a, this.b.value[0], a); + }; + _2.c = 0; + sfb(Bve, "InternalStringMap/2", 1061); + feb(215, 45, Hxe, gub, hub); + _2.$b = function iub() { + aub(this); + }; + _2._b = function jub(a) { + return bub(this, a); + }; + _2.uc = function kub(a) { + var b; + b = this.d.a; + while (b != this.d) { + if (Fvb(b.e, a)) { + return true; + } + b = b.a; + } + return false; + }; + _2.vc = function lub() { + return new wub(this); + }; + _2.xc = function mub(a) { + return cub(this, a); + }; + _2.zc = function nub(a, b) { + return dub(this, a, b); + }; + _2.Bc = function oub(a) { + return fub(this, a); + }; + _2.gc = function pub() { + return bkb(this.e); + }; + _2.c = false; + sfb(Bve, "LinkedHashMap", 215); + feb(400, 397, { 494: 1, 397: 1, 400: 1, 44: 1 }, tub, uub); + sfb(Bve, "LinkedHashMap/ChainEntry", 400); + feb(715, Eve, Fve, wub); + _2.$b = function xub() { + aub(this.a); + }; + _2.Hc = function yub(a) { + return vub(this, a); + }; + _2.Kc = function zub() { + return new Dub(this); + }; + _2.Mc = function Aub(a) { + var b; + if (vub(this, a)) { + b = RD(a, 44).ld(); + fub(this.a, b); + return true; + } + return false; + }; + _2.gc = function Bub() { + return bkb(this.a.e); + }; + sfb(Bve, "LinkedHashMap/EntrySet", 715); + feb(716, 1, Ave, Dub); + _2.Nb = function Eub(a) { + Ztb(this, a); + }; + _2.Pb = function Gub() { + return Cub(this); + }; + _2.Ob = function Fub() { + return this.c != this.d.a.d; + }; + _2.Qb = function Hub() { + yFb(!!this.a); + rFb(this.d.a.e.g, this.b); + rub(this.a); + _jb(this.d.a.e, this.a.d); + this.b = this.d.a.e.g; + this.a = null; + }; + _2.b = 0; + sfb(Bve, "LinkedHashMap/EntrySet/EntryIterator", 716); + feb(174, 49, Ixe, Iub, Jub, Kub); + var MK = sfb(Bve, "LinkedHashSet", 174); + feb(67, 2062, { 3: 1, 4: 1, 20: 1, 31: 1, 56: 1, 16: 1, 67: 1, 15: 1 }, Yub, Zub); + _2.Fc = function $ub(a) { + return Mub(this, a); + }; + _2.$b = function _ub() { + Xub(this); + }; + _2.fd = function avb(a) { + return Sub(this, a); + }; + _2.gc = function bvb() { + return this.b; + }; + _2.b = 0; + var PK = sfb(Bve, "LinkedList", 67); + feb(981, 1, Jve, hvb); + _2.Nb = function jvb(a) { + Ztb(this, a); + }; + _2.Rb = function ivb(a) { + cvb(this, a); + }; + _2.Ob = function kvb() { + return dvb(this); + }; + _2.Sb = function lvb() { + return this.b.b != this.d.a; + }; + _2.Pb = function mvb() { + return evb(this); + }; + _2.Tb = function nvb() { + return this.a; + }; + _2.Ub = function ovb() { + return fvb(this); + }; + _2.Vb = function pvb() { + return this.a - 1; + }; + _2.Qb = function qvb() { + gvb(this); + }; + _2.Wb = function rvb(a) { + yFb(!!this.c); + this.c.c = a; + }; + _2.a = 0; + _2.c = null; + sfb(Bve, "LinkedList/ListIteratorImpl", 981); + feb(617, 1, {}, svb); + sfb(Bve, "LinkedList/Node", 617); + feb(2057, 1, {}); + var uvb, vvb; + sfb(Bve, "Locale", 2057); + feb(873, 2057, {}, xvb); + _2.Ib = function yvb() { + return ""; + }; + sfb(Bve, "Locale/1", 873); + feb(874, 2057, {}, zvb); + _2.Ib = function Avb() { + return "unknown"; + }; + sfb(Bve, "Locale/4", 874); + feb(112, 63, { 3: 1, 103: 1, 63: 1, 82: 1, 112: 1 }, Dvb, Evb); + sfb(Bve, "NoSuchElementException", 112); + feb(475, 1, { 475: 1 }, Ovb); + _2.Fb = function Pvb(a) { + var b; + if (a === this) { + return true; + } + if (!ZD(a, 475)) { + return false; + } + b = RD(a, 475); + return Fvb(this.a, b.a); + }; + _2.Hb = function Qvb() { + return Gvb(this.a); + }; + _2.Ib = function Rvb() { + return this.a != null ? uve + Ghb(this.a) + ")" : "Optional.empty()"; + }; + var Jvb; + sfb(Bve, "Optional", 475); + feb(414, 1, { 414: 1 }, Xvb, Yvb); + _2.Fb = function Zvb(a) { + var b; + if (a === this) { + return true; + } + if (!ZD(a, 414)) { + return false; + } + b = RD(a, 414); + return this.a == b.a && Qfb(this.b, b.b) == 0; + }; + _2.Hb = function $vb() { + return this.a ? eE(this.b) : 0; + }; + _2.Ib = function _vb() { + return this.a ? "OptionalDouble.of(" + ("" + this.b) + ")" : "OptionalDouble.empty()"; + }; + _2.a = false; + _2.b = 0; + var Svb; + sfb(Bve, "OptionalDouble", 414); + feb(524, 1, { 524: 1 }, dwb, ewb); + _2.Fb = function fwb(a) { + var b; + if (a === this) { + return true; + } + if (!ZD(a, 524)) { + return false; + } + b = RD(a, 524); + return this.a == b.a && hgb(this.b, b.b) == 0; + }; + _2.Hb = function gwb() { + return this.a ? this.b : 0; + }; + _2.Ib = function hwb() { + return this.a ? "OptionalInt.of(" + ("" + this.b) + ")" : "OptionalInt.empty()"; + }; + _2.a = false; + _2.b = 0; + var awb; + sfb(Bve, "OptionalInt", 524); + feb(510, 2103, Dve, pwb); + _2.Gc = function qwb(a) { + return iwb(this, a); + }; + _2.$b = function rwb() { + aFb(this.b.c, 0); + }; + _2.Hc = function swb(a) { + return (a == null ? -1 : Wmb(this.b, a, 0)) != -1; + }; + _2.Kc = function twb() { + return new zwb(this); + }; + _2.Mc = function uwb(a) { + return nwb(this, a); + }; + _2.gc = function vwb() { + return this.b.c.length; + }; + _2.Nc = function wwb() { + return new Swb(this, 256); + }; + _2.Pc = function xwb() { + return UEb(this.b.c); + }; + _2.Qc = function ywb(a) { + return anb(this.b, a); + }; + sfb(Bve, "PriorityQueue", 510); + feb(1296, 1, Ave, zwb); + _2.Nb = function Awb(a) { + Ztb(this, a); + }; + _2.Ob = function Bwb() { + return this.a < this.c.b.c.length; + }; + _2.Pb = function Cwb() { + sFb(this.a < this.c.b.c.length); + this.b = this.a++; + return Vmb(this.c.b, this.b); + }; + _2.Qb = function Dwb() { + yFb(this.b != -1); + owb(this.c, this.a = this.b); + this.b = -1; + }; + _2.a = 0; + _2.b = -1; + sfb(Bve, "PriorityQueue/1", 1296); + feb(234, 1, { 234: 1 }, Owb, Pwb); + _2.a = 0; + _2.b = 0; + var Ewb, Fwb, Gwb = 0; + sfb(Bve, "Random", 234); + feb(25, 1, Pve, Swb, Twb, Uwb); + _2.Ad = function Ywb(a) { + return (this.a & a) != 0; + }; + _2.yd = function Vwb() { + return this.a; + }; + _2.zd = function Wwb() { + Qwb(this); + return this.c; + }; + _2.Nb = function Xwb(a) { + Qwb(this); + this.d.Nb(a); + }; + _2.Bd = function Zwb(a) { + return Rwb(this, a); + }; + _2.a = 0; + _2.c = 0; + sfb(Bve, "Spliterators/IteratorSpliterator", 25); + feb(495, 25, Pve, $wb); + sfb(Bve, "SortedSet/1", 495); + feb(611, 1, Gxe, axb); + _2.Pe = function bxb(a) { + this.a.Cd(a); + }; + sfb(Bve, "Spliterator/OfDouble/0methodref$accept$Type", 611); + feb(612, 1, Gxe, cxb); + _2.Pe = function dxb(a) { + this.a.Cd(a); + }; + sfb(Bve, "Spliterator/OfDouble/1methodref$accept$Type", 612); + feb(613, 1, Rve, exb); + _2.Dd = function fxb(a) { + this.a.Cd(sgb(a)); + }; + sfb(Bve, "Spliterator/OfInt/2methodref$accept$Type", 613); + feb(614, 1, Rve, gxb); + _2.Dd = function hxb(a) { + this.a.Cd(sgb(a)); + }; + sfb(Bve, "Spliterator/OfInt/3methodref$accept$Type", 614); + feb(625, 1, Pve); + _2.Nb = function nxb(a) { + _wb(this, a); + }; + _2.Ad = function oxb(a) { + return (this.d & a) != 0; + }; + _2.yd = function lxb() { + return this.d; + }; + _2.zd = function mxb() { + return this.e; + }; + _2.d = 0; + _2.e = 0; + sfb(Bve, "Spliterators/BaseSpliterator", 625); + feb(736, 625, Pve); + _2.Qe = function qxb(a) { + ixb(this, a); + }; + _2.Nb = function rxb(a) { + ZD(a, 189) ? ixb(this, RD(a, 189)) : ixb(this, new cxb(a)); + }; + _2.Bd = function sxb(a) { + return ZD(a, 189) ? this.Re(RD(a, 189)) : this.Re(new axb(a)); + }; + sfb(Bve, "Spliterators/AbstractDoubleSpliterator", 736); + feb(735, 625, Pve); + _2.Qe = function uxb(a) { + ixb(this, a); + }; + _2.Nb = function vxb(a) { + ZD(a, 202) ? ixb(this, RD(a, 202)) : ixb(this, new gxb(a)); + }; + _2.Bd = function wxb(a) { + return ZD(a, 202) ? this.Re(RD(a, 202)) : this.Re(new exb(a)); + }; + sfb(Bve, "Spliterators/AbstractIntSpliterator", 735); + feb(500, 625, Pve); + sfb(Bve, "Spliterators/AbstractSpliterator", 500); + feb(706, 1, Pve); + _2.Nb = function Dxb(a) { + _wb(this, a); + }; + _2.Ad = function Exb(a) { + return (this.b & a) != 0; + }; + _2.yd = function Bxb() { + return this.b; + }; + _2.zd = function Cxb() { + return this.d - this.c; + }; + _2.b = 0; + _2.c = 0; + _2.d = 0; + sfb(Bve, "Spliterators/BaseArraySpliterator", 706); + feb(960, 706, Pve, Gxb); + _2.Se = function Hxb(a, b) { + Fxb(this, RD(a, 41), b); + }; + _2.Nb = function Ixb(a) { + yxb(this, a); + }; + _2.Bd = function Jxb(a) { + return zxb(this, a); + }; + sfb(Bve, "Spliterators/ArraySpliterator", 960); + feb(707, 706, Pve, Lxb); + _2.Se = function Nxb(a, b) { + Kxb(this, RD(a, 189), b); + }; + _2.Qe = function Oxb(a) { + yxb(this, a); + }; + _2.Nb = function Pxb(a) { + ZD(a, 189) ? yxb(this, RD(a, 189)) : yxb(this, new cxb(a)); + }; + _2.Re = function Qxb(a) { + return zxb(this, a); + }; + _2.Bd = function Rxb(a) { + return ZD(a, 189) ? zxb(this, RD(a, 189)) : zxb(this, new axb(a)); + }; + sfb(Bve, "Spliterators/DoubleArraySpliterator", 707); + feb(2066, 1, Pve); + _2.Nb = function Wxb(a) { + _wb(this, a); + }; + _2.Ad = function Xxb(a) { + return (16448 & a) != 0; + }; + _2.yd = function Uxb() { + return 16448; + }; + _2.zd = function Vxb() { + return 0; + }; + var Sxb; + sfb(Bve, "Spliterators/EmptySpliterator", 2066); + feb(959, 2066, Pve, $xb); + _2.Qe = function _xb(a) { + Yxb(a); + }; + _2.Nb = function ayb(a) { + ZD(a, 202) ? Yxb(RD(a, 202)) : Yxb(new gxb(a)); + }; + _2.Re = function byb(a) { + return Zxb(a); + }; + _2.Bd = function cyb(a) { + return ZD(a, 202) ? Zxb(RD(a, 202)) : Zxb(new exb(a)); + }; + sfb(Bve, "Spliterators/EmptySpliterator/OfInt", 959); + feb(588, 56, Rxe, gyb); + _2.bd = function hyb(a, b) { + lyb(a, this.a.c.length + 1); + Qmb(this.a, a, b); + }; + _2.Fc = function iyb(a) { + return Rmb(this.a, a); + }; + _2.cd = function jyb(a, b) { + lyb(a, this.a.c.length + 1); + return Smb(this.a, a, b); + }; + _2.Gc = function kyb(a) { + return Tmb(this.a, a); + }; + _2.$b = function myb() { + aFb(this.a.c, 0); + }; + _2.Hc = function nyb(a) { + return Wmb(this.a, a, 0) != -1; + }; + _2.Ic = function oyb(a) { + return Be(this.a, a); + }; + _2.Jc = function pyb(a) { + Umb(this.a, a); + }; + _2.Xb = function qyb(a) { + return lyb(a, this.a.c.length), Vmb(this.a, a); + }; + _2.dd = function ryb(a) { + return Wmb(this.a, a, 0); + }; + _2.dc = function syb() { + return this.a.c.length == 0; + }; + _2.Kc = function tyb() { + return new Anb(this.a); + }; + _2.gd = function uyb(a) { + return lyb(a, this.a.c.length), Xmb(this.a, a); + }; + _2.ce = function vyb(a, b) { + Zmb(this.a, a, b); + }; + _2.hd = function wyb(a, b) { + return lyb(a, this.a.c.length), $mb(this.a, a, b); + }; + _2.gc = function xyb() { + return this.a.c.length; + }; + _2.jd = function yyb(a) { + _mb(this.a, a); + }; + _2.kd = function zyb(a, b) { + return new Rkb(this.a, a, b); + }; + _2.Pc = function Ayb() { + return UEb(this.a.c); + }; + _2.Qc = function Byb(a) { + return anb(this.a, a); + }; + _2.Ib = function Cyb() { + return Fe(this.a); + }; + sfb(Bve, "Vector", 588); + feb(824, 588, Rxe, Fyb); + sfb(Bve, "Stack", 824); + feb(213, 1, { 213: 1 }, Jyb); + _2.Ib = function Kyb() { + return Iyb(this); + }; + sfb(Bve, "StringJoiner", 213); + feb(553, 2090, { 3: 1, 85: 1, 139: 1, 133: 1 }, dzb, ezb); + _2.$b = function fzb() { + Lyb(this); + }; + _2.De = function gzb() { + return new xzb(this); + }; + _2.vc = function hzb() { + return new Dzb(this); + }; + _2.Ee = function izb(a) { + return Pyb(this, a, true); + }; + _2.Fe = function jzb(a) { + return Myb(this, a); + }; + _2.Ge = function kzb() { + return Nyb(this); + }; + _2.He = function lzb(a) { + return Qyb(this, a, true); + }; + _2.Ie = function mzb(a) { + return Pyb(this, a, false); + }; + _2.Je = function nzb() { + return Oyb(this); + }; + _2.Ke = function ozb(a) { + return Qyb(this, a, false); + }; + _2.Zc = function pzb(a, b) { + return Ryb(this, a, b); + }; + _2.zc = function qzb(a, b) { + return Wyb(this, a, b); + }; + _2.Bc = function rzb(a) { + return Xyb(this, a); + }; + _2.Le = function szb(a) { + return Yyb(this, a); + }; + _2.gc = function tzb() { + return this.c; + }; + _2.ad = function uzb(a, b) { + return czb(this, a, b); + }; + _2.c = 0; + sfb(Bve, "TreeMap", 553); + feb(554, 1, Ave, xzb, yzb); + _2.Nb = function zzb(a) { + Ztb(this, a); + }; + _2.Pb = function Bzb() { + return vzb(this); + }; + _2.Ob = function Azb() { + return Akb(this.a); + }; + _2.Qb = function Czb() { + wzb(this); + }; + sfb(Bve, "TreeMap/EntryIterator", 554); + feb(1142, 629, Fve, Dzb); + _2.$b = function Ezb() { + Lyb(this.a); + }; + sfb(Bve, "TreeMap/EntrySet", 1142); + feb(447, 397, { 494: 1, 397: 1, 44: 1, 447: 1 }, Fzb); + _2.b = false; + var vL = sfb(Bve, "TreeMap/Node", 447); + feb(630, 1, {}, Gzb); + _2.Ib = function Hzb() { + return "State: mv=" + this.c + " value=" + this.d + " done=" + this.a + " found=" + this.b; + }; + _2.a = false; + _2.b = false; + _2.c = false; + sfb(Bve, "TreeMap/State", 630); + feb(631, 2090, Gve, Kzb); + _2.De = function Lzb() { + return new yzb(this.c, this.f, this.b, this.a, this.e, this.d); + }; + _2.vc = function Mzb() { + return new Plb(this); + }; + _2.Ee = function Nzb(a) { + return Izb(this, Pyb(this.c, a, true)); + }; + _2.Fe = function Ozb(a) { + return Izb(this, Myb(this.c, a)); + }; + _2.Ge = function Pzb() { + var a; + return this.f.Te() ? this.a ? a = Pyb(this.c, this.b, true) : a = Pyb(this.c, this.b, false) : a = Nyb(this.c), !!a && Jzb(this, a.d) ? a : null; + }; + _2.He = function Qzb(a) { + return Izb(this, Qyb(this.c, a, true)); + }; + _2.Ie = function Rzb(a) { + return Izb(this, Pyb(this.c, a, false)); + }; + _2.Je = function Szb() { + var a; + this.f.Ue() ? this.d ? a = Qyb(this.c, this.e, true) : a = Qyb(this.c, this.e, false) : a = Oyb(this.c); + return !!a && Jzb(this, a.d) ? a : null; + }; + _2.Ke = function Tzb(a) { + return Izb(this, Qyb(this.c, a, false)); + }; + _2.Zc = function Uzb(a, b) { + if (this.f.Ue() && this.c.a.Ne(a, this.e) > 0) { + throw Adb(new agb(Sxe + a + " greater than " + this.e)); + } + return this.f.Te() ? bzb(this.c, this.b, this.a, a, b) : Ryb(this.c, a, b); + }; + _2.zc = function Vzb(a, b) { + if (!Tyb(this.c, this.f, a, this.b, this.a, this.e, this.d)) { + throw Adb(new agb(a + " outside the range " + this.b + " to " + this.e)); + } + return Wyb(this.c, a, b); + }; + _2.Bc = function Wzb(a) { + var b; + b = a; + if (!Tyb(this.c, this.f, b, this.b, this.a, this.e, this.d)) { + return null; + } + return Xyb(this.c, b); + }; + _2.Le = function Xzb(a) { + return Jzb(this, a.ld()) && Yyb(this.c, a); + }; + _2.gc = function Yzb() { + var a, b, c2; + this.f.Te() ? this.a ? b = Pyb(this.c, this.b, true) : b = Pyb(this.c, this.b, false) : b = Nyb(this.c); + if (!(!!b && Jzb(this, b.d) ? b : null)) { + return 0; + } + a = 0; + for (c2 = new yzb(this.c, this.f, this.b, this.a, this.e, this.d); Akb(c2.a); c2.b = RD(Bkb(c2.a), 44)) { + ++a; + } + return a; + }; + _2.ad = function Zzb(a, b) { + if (this.f.Te() && this.c.a.Ne(a, this.b) < 0) { + throw Adb(new agb(Sxe + a + Txe + this.b)); + } + return this.f.Ue() ? bzb(this.c, a, b, this.e, this.d) : czb(this.c, a, b); + }; + _2.a = false; + _2.d = false; + sfb(Bve, "TreeMap/SubMap", 631); + feb(304, 22, Uxe, dAb); + _2.Te = function eAb() { + return false; + }; + _2.Ue = function fAb() { + return false; + }; + var $zb, _zb, aAb, bAb; + var AL = tfb(Bve, "TreeMap/SubMapType", 304, WI, hAb, gAb); + feb(1143, 304, Uxe, iAb); + _2.Ue = function jAb() { + return true; + }; + tfb(Bve, "TreeMap/SubMapType/1", 1143, AL, null, null); + feb(1144, 304, Uxe, kAb); + _2.Te = function lAb() { + return true; + }; + _2.Ue = function mAb() { + return true; + }; + tfb(Bve, "TreeMap/SubMapType/2", 1144, AL, null, null); + feb(1145, 304, Uxe, nAb); + _2.Te = function oAb() { + return true; + }; + tfb(Bve, "TreeMap/SubMapType/3", 1145, AL, null, null); + var pAb; + feb(157, Eve, { 3: 1, 20: 1, 31: 1, 16: 1, 277: 1, 21: 1, 87: 1, 157: 1 }, xAb, yAb, zAb); + _2.Nc = function GAb() { + return new $wb(this); + }; + _2.Fc = function AAb(a) { + return rAb(this, a); + }; + _2.$b = function BAb() { + this.a.$b(); + }; + _2.Hc = function CAb(a) { + return this.a._b(a); + }; + _2.Kc = function DAb() { + return this.a.ec().Kc(); + }; + _2.Mc = function EAb(a) { + return wAb(this, a); + }; + _2.gc = function FAb() { + return this.a.gc(); + }; + var DL = sfb(Bve, "TreeSet", 157); + feb(1082, 1, {}, JAb); + _2.Ve = function KAb(a, b) { + return HAb(this.a, a, b); + }; + sfb(Vxe, "BinaryOperator/lambda$0$Type", 1082); + feb(1083, 1, {}, LAb); + _2.Ve = function MAb(a, b) { + return IAb(this.a, a, b); + }; + sfb(Vxe, "BinaryOperator/lambda$1$Type", 1083); + feb(952, 1, {}, NAb); + _2.Kb = function OAb(a) { + return a; + }; + sfb(Vxe, "Function/lambda$0$Type", 952); + feb(395, 1, nwe, PAb); + _2.Mb = function QAb(a) { + return !this.a.Mb(a); + }; + sfb(Vxe, "Predicate/lambda$2$Type", 395); + feb(581, 1, { 581: 1 }); + var JL = sfb(Wxe, "Handler", 581); + feb(2107, 1, nve); + _2.xe = function TAb() { + return "DUMMY"; + }; + _2.Ib = function UAb() { + return this.xe(); + }; + var RAb; + sfb(Wxe, "Level", 2107); + feb(1706, 2107, nve, VAb); + _2.xe = function WAb() { + return "INFO"; + }; + sfb(Wxe, "Level/LevelInfo", 1706); + feb(1843, 1, {}, $Ab); + var XAb; + sfb(Wxe, "LogManager", 1843); + feb(1896, 1, nve, aBb); + _2.b = null; + sfb(Wxe, "LogRecord", 1896); + feb(525, 1, { 525: 1 }, oBb); + _2.e = false; + var bBb = false, cBb = false, dBb = false, eBb = false, fBb = false; + sfb(Wxe, "Logger", 525); + feb(835, 581, { 581: 1 }, rBb); + sfb(Wxe, "SimpleConsoleLogHandler", 835); + feb(108, 22, { 3: 1, 34: 1, 22: 1, 108: 1 }, yBb); + var uBb, vBb, wBb; + var QL = tfb(Zxe, "Collector/Characteristics", 108, WI, ABb, zBb); + var BBb; + feb(758, 1, {}, DBb); + sfb(Zxe, "CollectorImpl", 758); + feb(1074, 1, {}, RBb); + _2.Ve = function SBb(a, b) { + return Hyb(RD(a, 213), RD(b, 213)); + }; + sfb(Zxe, "Collectors/10methodref$merge$Type", 1074); + feb(1075, 1, {}, TBb); + _2.Kb = function UBb(a) { + return Iyb(RD(a, 213)); + }; + sfb(Zxe, "Collectors/11methodref$toString$Type", 1075); + feb(1076, 1, {}, VBb); + _2.Kb = function WBb(a) { + return Geb(), SSb(a) ? true : false; + }; + sfb(Zxe, "Collectors/12methodref$test$Type", 1076); + feb(144, 1, {}, XBb); + _2.Yd = function YBb(a, b) { + RD(a, 16).Fc(b); + }; + sfb(Zxe, "Collectors/20methodref$add$Type", 144); + feb(146, 1, {}, ZBb); + _2.Xe = function $Bb() { + return new bnb(); + }; + sfb(Zxe, "Collectors/21methodref$ctor$Type", 146); + feb(359, 1, {}, _Bb); + _2.Xe = function aCb() { + return new _sb(); + }; + sfb(Zxe, "Collectors/23methodref$ctor$Type", 359); + feb(360, 1, {}, bCb); + _2.Yd = function cCb(a, b) { + Ysb(RD(a, 49), b); + }; + sfb(Zxe, "Collectors/24methodref$add$Type", 360); + feb(1069, 1, {}, dCb); + _2.Ve = function eCb(a, b) { + return EBb(RD(a, 15), RD(b, 16)); + }; + sfb(Zxe, "Collectors/4methodref$addAll$Type", 1069); + feb(1073, 1, {}, fCb); + _2.Yd = function gCb(a, b) { + Gyb(RD(a, 213), RD(b, 484)); + }; + sfb(Zxe, "Collectors/9methodref$add$Type", 1073); + feb(1072, 1, {}, hCb); + _2.Xe = function iCb() { + return new Jyb(this.a, this.b, this.c); + }; + sfb(Zxe, "Collectors/lambda$15$Type", 1072); + feb(1077, 1, {}, jCb); + _2.Xe = function kCb() { + var a; + return a = new gub(), dub(a, (Geb(), false), new bnb()), dub(a, true, new bnb()), a; + }; + sfb(Zxe, "Collectors/lambda$22$Type", 1077); + feb(1078, 1, {}, lCb); + _2.Xe = function mCb() { + return cD(WC(jJ, 1), rve, 1, 5, [this.a]); + }; + sfb(Zxe, "Collectors/lambda$25$Type", 1078); + feb(1079, 1, {}, nCb); + _2.Yd = function oCb(a, b) { + GBb(this.a, SD(a)); + }; + sfb(Zxe, "Collectors/lambda$26$Type", 1079); + feb(1080, 1, {}, pCb); + _2.Ve = function qCb(a, b) { + return HBb(this.a, SD(a), SD(b)); + }; + sfb(Zxe, "Collectors/lambda$27$Type", 1080); + feb(1081, 1, {}, rCb); + _2.Kb = function sCb(a) { + return SD(a)[0]; + }; + sfb(Zxe, "Collectors/lambda$28$Type", 1081); + feb(728, 1, {}, uCb); + _2.Ve = function vCb(a, b) { + return tCb(a, b); + }; + sfb(Zxe, "Collectors/lambda$4$Type", 728); + feb(145, 1, {}, wCb); + _2.Ve = function xCb(a, b) { + return JBb(RD(a, 16), RD(b, 16)); + }; + sfb(Zxe, "Collectors/lambda$42$Type", 145); + feb(361, 1, {}, yCb); + _2.Ve = function zCb(a, b) { + return KBb(RD(a, 49), RD(b, 49)); + }; + sfb(Zxe, "Collectors/lambda$50$Type", 361); + feb(362, 1, {}, ACb); + _2.Kb = function BCb(a) { + return RD(a, 49); + }; + sfb(Zxe, "Collectors/lambda$51$Type", 362); + feb(1068, 1, {}, CCb); + _2.Yd = function DCb(a, b) { + LBb(this.a, RD(a, 85), b); + }; + sfb(Zxe, "Collectors/lambda$7$Type", 1068); + feb(1070, 1, {}, ECb); + _2.Ve = function FCb(a, b) { + return NBb(RD(a, 85), RD(b, 85), new dCb()); + }; + sfb(Zxe, "Collectors/lambda$8$Type", 1070); + feb(1071, 1, {}, GCb); + _2.Kb = function HCb(a) { + return MBb(this.a, RD(a, 85)); + }; + sfb(Zxe, "Collectors/lambda$9$Type", 1071); + feb(550, 1, {}); + _2.$e = function OCb() { + ICb(this); + }; + _2.d = false; + sfb(Zxe, "TerminatableStream", 550); + feb(827, 550, $xe, WCb); + _2.$e = function XCb() { + ICb(this); + }; + sfb(Zxe, "DoubleStreamImpl", 827); + feb(1847, 736, Pve, $Cb); + _2.Re = function aDb(a) { + return ZCb(this, RD(a, 189)); + }; + _2.a = null; + sfb(Zxe, "DoubleStreamImpl/2", 1847); + feb(1848, 1, Gxe, bDb); + _2.Pe = function cDb(a) { + _Cb(this.a, a); + }; + sfb(Zxe, "DoubleStreamImpl/2/lambda$0$Type", 1848); + feb(1845, 1, Gxe, dDb); + _2.Pe = function eDb(a) { + YCb(this.a, a); + }; + sfb(Zxe, "DoubleStreamImpl/lambda$0$Type", 1845); + feb(1846, 1, Gxe, fDb); + _2.Pe = function gDb(a) { + Nrb(this.a, a); + }; + sfb(Zxe, "DoubleStreamImpl/lambda$2$Type", 1846); + feb(1397, 735, Pve, kDb); + _2.Re = function lDb(a) { + return jDb(this, RD(a, 202)); + }; + _2.a = 0; + _2.b = 0; + _2.c = 0; + sfb(Zxe, "IntStream/5", 1397); + feb(806, 550, $xe, oDb); + _2.$e = function pDb() { + ICb(this); + }; + _2._e = function qDb() { + return LCb(this), this.a; + }; + sfb(Zxe, "IntStreamImpl", 806); + feb(807, 550, $xe, rDb); + _2.$e = function sDb() { + ICb(this); + }; + _2._e = function tDb() { + return LCb(this), Txb(), Sxb; + }; + sfb(Zxe, "IntStreamImpl/Empty", 807); + feb(1687, 1, Rve, uDb); + _2.Dd = function vDb(a) { + ktb(this.a, a); + }; + sfb(Zxe, "IntStreamImpl/lambda$4$Type", 1687); + var RM = ufb(Zxe, "Stream"); + feb(26, 550, { 533: 1, 687: 1, 848: 1 }, SDb); + _2.$e = function TDb() { + ICb(this); + }; + var wDb; + sfb(Zxe, "StreamImpl", 26); + feb(1102, 500, Pve, YDb); + _2.Bd = function ZDb(a) { + while (WDb(this)) { + if (this.a.Bd(a)) { + return true; + } else { + ICb(this.b); + this.b = null; + this.a = null; + } + } + return false; + }; + sfb(Zxe, "StreamImpl/1", 1102); + feb(1103, 1, Qve, $Db); + _2.Cd = function _Db(a) { + XDb(this.a, RD(a, 848)); + }; + sfb(Zxe, "StreamImpl/1/lambda$0$Type", 1103); + feb(1104, 1, nwe, aEb); + _2.Mb = function bEb(a) { + return Ysb(this.a, a); + }; + sfb(Zxe, "StreamImpl/1methodref$add$Type", 1104); + feb(1105, 500, Pve, cEb); + _2.Bd = function dEb(a) { + var b; + if (!this.a) { + b = new bnb(); + this.b.a.Nb(new eEb(b)); + yob(); + _mb(b, this.c); + this.a = new Swb(b, 16); + } + return Rwb(this.a, a); + }; + _2.a = null; + sfb(Zxe, "StreamImpl/5", 1105); + feb(1106, 1, Qve, eEb); + _2.Cd = function fEb(a) { + Rmb(this.a, a); + }; + sfb(Zxe, "StreamImpl/5/2methodref$add$Type", 1106); + feb(737, 500, Pve, hEb); + _2.Bd = function iEb(a) { + this.b = false; + while (!this.b && this.c.Bd(new jEb(this, a))) + ; + return this.b; + }; + _2.b = false; + sfb(Zxe, "StreamImpl/FilterSpliterator", 737); + feb(1096, 1, Qve, jEb); + _2.Cd = function kEb(a) { + gEb(this.a, this.b, a); + }; + sfb(Zxe, "StreamImpl/FilterSpliterator/lambda$0$Type", 1096); + feb(1091, 736, Pve, nEb); + _2.Re = function oEb(a) { + return mEb(this, RD(a, 189)); + }; + sfb(Zxe, "StreamImpl/MapToDoubleSpliterator", 1091); + feb(1095, 1, Qve, pEb); + _2.Cd = function qEb(a) { + lEb(this.a, this.b, a); + }; + sfb(Zxe, "StreamImpl/MapToDoubleSpliterator/lambda$0$Type", 1095); + feb(1090, 735, Pve, tEb); + _2.Re = function uEb(a) { + return sEb(this, RD(a, 202)); + }; + sfb(Zxe, "StreamImpl/MapToIntSpliterator", 1090); + feb(1094, 1, Qve, vEb); + _2.Cd = function wEb(a) { + rEb(this.a, this.b, a); + }; + sfb(Zxe, "StreamImpl/MapToIntSpliterator/lambda$0$Type", 1094); + feb(734, 500, Pve, zEb); + _2.Bd = function AEb(a) { + return yEb(this, a); + }; + sfb(Zxe, "StreamImpl/MapToObjSpliterator", 734); + feb(1093, 1, Qve, BEb); + _2.Cd = function CEb(a) { + xEb(this.a, this.b, a); + }; + sfb(Zxe, "StreamImpl/MapToObjSpliterator/lambda$0$Type", 1093); + feb(1092, 500, Pve, DEb); + _2.Bd = function EEb(a) { + while (Idb(this.b, 0)) { + if (!this.a.Bd(new FEb())) { + return false; + } + this.b = Vdb(this.b, 1); + } + return this.a.Bd(a); + }; + _2.b = 0; + sfb(Zxe, "StreamImpl/SkipSpliterator", 1092); + feb(1097, 1, Qve, FEb); + _2.Cd = function GEb(a) { + }; + sfb(Zxe, "StreamImpl/SkipSpliterator/lambda$0$Type", 1097); + feb(626, 1, Qve, IEb); + _2.Cd = function JEb(a) { + HEb(this, a); + }; + sfb(Zxe, "StreamImpl/ValueConsumer", 626); + feb(1098, 1, Qve, KEb); + _2.Cd = function LEb(a) { + xDb(); + }; + sfb(Zxe, "StreamImpl/lambda$0$Type", 1098); + feb(1099, 1, Qve, MEb); + _2.Cd = function NEb(a) { + xDb(); + }; + sfb(Zxe, "StreamImpl/lambda$1$Type", 1099); + feb(1100, 1, {}, OEb); + _2.Ve = function PEb(a, b) { + return UDb(this.a, a, b); + }; + sfb(Zxe, "StreamImpl/lambda$4$Type", 1100); + feb(1101, 1, Qve, QEb); + _2.Cd = function REb(a) { + VDb(this.b, this.a, a); + }; + sfb(Zxe, "StreamImpl/lambda$5$Type", 1101); + feb(1107, 1, Qve, SEb); + _2.Cd = function TEb(a) { + PCb(this.a, RD(a, 380)); + }; + sfb(Zxe, "TerminatableStream/lambda$0$Type", 1107); + feb(2142, 1, {}); + feb(2014, 1, {}, gFb); + sfb("javaemul.internal", "ConsoleLogger", 2014); + var iFb = 0; + feb(2134, 1, {}); + feb(1830, 1, Qve, FFb); + _2.Cd = function GFb(a) { + RD(a, 317); + }; + sfb(eye, "BowyerWatsonTriangulation/lambda$0$Type", 1830); + feb(1831, 1, Qve, HFb); + _2.Cd = function IFb(a) { + ye(this.a, RD(a, 317).e); + }; + sfb(eye, "BowyerWatsonTriangulation/lambda$1$Type", 1831); + feb(1832, 1, Qve, JFb); + _2.Cd = function KFb(a) { + RD(a, 177); + }; + sfb(eye, "BowyerWatsonTriangulation/lambda$2$Type", 1832); + feb(1827, 1, fye, NFb); + _2.Ne = function OFb(a, b) { + return MFb(this.a, RD(a, 177), RD(b, 177)); + }; + _2.Fb = function PFb(a) { + return this === a; + }; + _2.Oe = function QFb() { + return new Frb(this); + }; + sfb(eye, "NaiveMinST/lambda$0$Type", 1827); + feb(449, 1, {}, SFb); + sfb(eye, "NodeMicroLayout", 449); + feb(177, 1, { 177: 1 }, TFb); + _2.Fb = function UFb(a) { + var b; + if (ZD(a, 177)) { + b = RD(a, 177); + return Fvb(this.a, b.a) && Fvb(this.b, b.b) || Fvb(this.a, b.b) && Fvb(this.b, b.a); + } else { + return false; + } + }; + _2.Hb = function VFb() { + return Gvb(this.a) + Gvb(this.b); + }; + var $M = sfb(eye, "TEdge", 177); + feb(317, 1, { 317: 1 }, XFb); + _2.Fb = function YFb(a) { + var b; + if (ZD(a, 317)) { + b = RD(a, 317); + return WFb(this, b.a) && WFb(this, b.b) && WFb(this, b.c); + } else { + return false; + } + }; + _2.Hb = function ZFb() { + return Gvb(this.a) + Gvb(this.b) + Gvb(this.c); + }; + sfb(eye, "TTriangle", 317); + feb(225, 1, { 225: 1 }, $Fb); + sfb(eye, "Tree", 225); + feb(1218, 1, {}, aGb); + sfb(gye, "Scanline", 1218); + var bN = ufb(gye, hye); + feb(1758, 1, {}, dGb); + sfb(iye, "CGraph", 1758); + feb(316, 1, { 316: 1 }, fGb); + _2.b = 0; + _2.c = 0; + _2.d = 0; + _2.g = 0; + _2.i = 0; + _2.k = pxe; + sfb(iye, "CGroup", 316); + feb(830, 1, {}, jGb); + sfb(iye, "CGroup/CGroupBuilder", 830); + feb(60, 1, { 60: 1 }, kGb); + _2.Ib = function lGb() { + var a; + if (this.j) { + return WD(this.j.Kb(this)); + } + return lfb(hN), hN.o + "@" + (a = kFb(this) >>> 0, a.toString(16)); + }; + _2.f = 0; + _2.i = pxe; + var hN = sfb(iye, "CNode", 60); + feb(829, 1, {}, qGb); + sfb(iye, "CNode/CNodeBuilder", 829); + var vGb; + feb(1590, 1, {}, xGb); + _2.ff = function yGb(a, b) { + return 0; + }; + _2.gf = function zGb(a, b) { + return 0; + }; + sfb(iye, kye, 1590); + feb(1853, 1, {}, AGb); + _2.cf = function BGb(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p; + j = oxe; + for (d = new Anb(a.a.b); d.a < d.c.c.length; ) { + b = RD(ynb(d), 60); + j = $wnd.Math.min(j, b.a.j.d.c + b.b.a); + } + n = new Yub(); + for (g = new Anb(a.a.a); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 316); + f2.k = j; + f2.g == 0 && (Pub(n, f2, n.c.b, n.c), true); + } + while (n.b != 0) { + f2 = RD(n.b == 0 ? null : (sFb(n.b != 0), Wub(n, n.a.a)), 316); + e = f2.j.d.c; + for (m = f2.a.a.ec().Kc(); m.Ob(); ) { + k = RD(m.Pb(), 60); + p = f2.k + k.b.a; + !LGb(a, f2, a.d) || k.d.c < p ? k.i = p : k.i = k.d.c; + } + e -= f2.j.i; + f2.b += e; + a.d == (Cmd(), zmd) || a.d == xmd ? f2.c += e : f2.c -= e; + for (l = f2.a.a.ec().Kc(); l.Ob(); ) { + k = RD(l.Pb(), 60); + for (i2 = k.c.Kc(); i2.Ob(); ) { + h = RD(i2.Pb(), 60); + Dmd(a.d) ? o2 = a.g.ff(k, h) : o2 = a.g.gf(k, h); + h.a.k = $wnd.Math.max(h.a.k, k.i + k.d.b + o2 - h.b.a); + MGb(a, h, a.d) && (h.a.k = $wnd.Math.max(h.a.k, h.d.c - h.b.a)); + --h.a.g; + h.a.g == 0 && Mub(n, h.a); + } + } + } + for (c2 = new Anb(a.a.b); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 60); + b.d.c = b.i; + } + }; + sfb(iye, "LongestPathCompaction", 1853); + feb(1756, 1, {}, VGb); + _2.e = false; + var CGb, DGb, EGb; + var lN = sfb(iye, pye, 1756); + feb(1757, 1, Qve, WGb); + _2.Cd = function XGb(a) { + NGb(this.a, RD(a, 42)); + }; + sfb(iye, qye, 1757); + feb(1854, 1, {}, YGb); + _2.df = function ZGb(a) { + var b, c2, d, e, f2, g, h; + for (c2 = new Anb(a.a.b); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 60); + b.c.$b(); + } + for (e = new Anb(a.a.b); e.a < e.c.c.length; ) { + d = RD(ynb(e), 60); + for (g = new Anb(a.a.b); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 60); + if (d == f2) { + continue; + } + if (!!d.a && d.a == f2.a) { + continue; + } + Dmd(a.d) ? h = a.g.gf(d, f2) : h = a.g.ff(d, f2); + (f2.d.c > d.d.c || d.d.c == f2.d.c && d.d.b < f2.d.b) && sGb(f2.d.d + f2.d.a + h, d.d.d) && uGb(f2.d.d, d.d.d + d.d.a + h) && d.c.Fc(f2); + } + } + }; + sfb(iye, "QuadraticConstraintCalculation", 1854); + feb(529, 1, { 529: 1 }, cHb); + _2.a = false; + _2.b = false; + _2.c = false; + _2.d = false; + sfb(iye, rye, 529); + feb(817, 1, {}, fHb); + _2.df = function gHb(a) { + this.c = a; + eHb(this, new xHb()); + }; + sfb(iye, sye, 817); + feb(1784, 1, { 693: 1 }, lHb); + _2.bf = function mHb(a) { + iHb(this, RD(a, 473)); + }; + sfb(iye, tye, 1784); + feb(1785, 1, fye, oHb); + _2.Ne = function pHb(a, b) { + return nHb(RD(a, 60), RD(b, 60)); + }; + _2.Fb = function qHb(a) { + return this === a; + }; + _2.Oe = function rHb() { + return new Frb(this); + }; + sfb(iye, uye, 1785); + feb(473, 1, { 473: 1 }, sHb); + _2.a = false; + sfb(iye, vye, 473); + feb(1786, 1, fye, tHb); + _2.Ne = function uHb(a, b) { + return hHb(RD(a, 473), RD(b, 473)); + }; + _2.Fb = function vHb(a) { + return this === a; + }; + _2.Oe = function wHb() { + return new Frb(this); + }; + sfb(iye, wye, 1786); + feb(1787, 1, xye, xHb); + _2.Lb = function yHb(a) { + return RD(a, 60), true; + }; + _2.Fb = function zHb(a) { + return this === a; + }; + _2.Mb = function AHb(a) { + return RD(a, 60), true; + }; + sfb(iye, "ScanlineConstraintCalculator/lambda$1$Type", 1787); + feb(436, 22, { 3: 1, 34: 1, 22: 1, 436: 1 }, EHb); + var BHb, CHb; + var uN = tfb(yye, "HighLevelSortingCriterion", 436, WI, GHb, FHb); + var HHb; + feb(435, 22, { 3: 1, 34: 1, 22: 1, 435: 1 }, MHb); + var JHb, KHb; + var vN = tfb(yye, "LowLevelSortingCriterion", 435, WI, OHb, NHb); + var PHb; + var B2 = ufb(zye, "ILayoutMetaDataProvider"); + feb(864, 1, Eye, ZHb); + _2.hf = function $Hb(a) { + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), Aye), Fye), "Polyomino Traversal Strategy"), "Traversal strategy for trying different candidate positions for polyominoes."), XHb), (kid(), eid)), xN), xsb((Yhd(), Whd))))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), Bye), Fye), "Polyomino Secondary Sorting Criterion"), "Possible secondary sorting criteria for the processing order of polyominoes. They are used when polyominoes are equal according to the primary sorting criterion HighLevelSortingCriterion."), VHb), eid), vN), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), Cye), Fye), "Polyomino Primary Sorting Criterion"), "Possible primary sorting criteria for the processing order of polyominoes."), THb), eid), uN), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), Dye), Fye), "Fill Polyominoes"), "Use the Profile Fill algorithm to fill polyominoes to prevent small polyominoes from being placed inside of big polyominoes with large holes. Might increase packing area."), (Geb(), true)), cid), QI), xsb(Whd)))); + }; + var RHb, SHb, THb, UHb, VHb, WHb, XHb; + sfb(yye, "PolyominoOptions", 864); + feb(257, 22, { 3: 1, 34: 1, 22: 1, 257: 1 }, jIb); + var _Hb, aIb, bIb, cIb, dIb, eIb, fIb, gIb, hIb; + var xN = tfb(yye, "TraversalStrategy", 257, WI, lIb, kIb); + var mIb; + feb(218, 1, { 218: 1 }, pIb); + _2.Ib = function qIb() { + return "NEdge[id=" + this.b + " w=" + this.g + " d=" + this.a + "]"; + }; + _2.a = 1; + _2.b = 0; + _2.c = 0; + _2.f = false; + _2.g = 0; + var zN = sfb(Gye, "NEdge", 218); + feb(182, 1, {}, wIb); + sfb(Gye, "NEdge/NEdgeBuilder", 182); + feb(662, 1, {}, BIb); + sfb(Gye, "NGraph", 662); + feb(125, 1, { 125: 1 }, DIb); + _2.c = -1; + _2.d = 0; + _2.e = 0; + _2.i = -1; + _2.j = false; + var DN = sfb(Gye, "NNode", 125); + feb(808, 1, Exe, GIb); + _2.Jc = function OIb(a) { + xgb(this, a); + }; + _2.Lc = function VIb() { + return new SDb(null, new Swb(this, 16)); + }; + _2.jd = function $Ib(a) { + tvb(this, a); + }; + _2.Nc = function _Ib() { + return new Swb(this, 16); + }; + _2.Oc = function aJb() { + return new SDb(null, new Swb(this, 16)); + }; + _2.bd = function HIb(a, b) { + ++this.b; + Qmb(this.a, a, b); + }; + _2.Fc = function IIb(a) { + return EIb(this, a); + }; + _2.cd = function JIb(a, b) { + ++this.b; + return Smb(this.a, a, b); + }; + _2.Gc = function KIb(a) { + ++this.b; + return Tmb(this.a, a); + }; + _2.$b = function LIb() { + ++this.b; + aFb(this.a.c, 0); + }; + _2.Hc = function MIb(a) { + return Wmb(this.a, a, 0) != -1; + }; + _2.Ic = function NIb(a) { + return Be(this.a, a); + }; + _2.Xb = function PIb(a) { + return Vmb(this.a, a); + }; + _2.dd = function QIb(a) { + return Wmb(this.a, a, 0); + }; + _2.dc = function RIb() { + return this.a.c.length == 0; + }; + _2.Kc = function SIb() { + return Nr(new Anb(this.a)); + }; + _2.ed = function TIb() { + throw Adb(new jib()); + }; + _2.fd = function UIb(a) { + throw Adb(new jib()); + }; + _2.gd = function WIb(a) { + ++this.b; + return Xmb(this.a, a); + }; + _2.Mc = function XIb(a) { + return FIb(this, a); + }; + _2.hd = function YIb(a, b) { + ++this.b; + return $mb(this.a, a, b); + }; + _2.gc = function ZIb() { + return this.a.c.length; + }; + _2.kd = function bJb(a, b) { + return new Rkb(this.a, a, b); + }; + _2.Pc = function cJb() { + return UEb(this.a.c); + }; + _2.Qc = function dJb(a) { + return anb(this.a, a); + }; + _2.b = 0; + sfb(Gye, "NNode/ChangeAwareArrayList", 808); + feb(275, 1, {}, gJb); + sfb(Gye, "NNode/NNodeBuilder", 275); + feb(1695, 1, {}, BJb); + _2.a = false; + _2.f = lve; + _2.j = 0; + sfb(Gye, "NetworkSimplex", 1695); + feb(1314, 1, Qve, HJb); + _2.Cd = function IJb(a) { + GJb(this.a, RD(a, 695), true, false); + }; + sfb(Iye, "NodeLabelAndSizeCalculator/lambda$0$Type", 1314); + feb(565, 1, {}, PJb); + _2.b = true; + _2.c = true; + _2.d = true; + _2.e = true; + sfb(Iye, "NodeMarginCalculator", 565); + feb(217, 1, { 217: 1 }); + _2.j = false; + _2.k = false; + var IN = sfb(Jye, "Cell", 217); + feb(127, 217, { 127: 1, 217: 1 }, TJb); + _2.jf = function UJb() { + return SJb(this); + }; + _2.kf = function VJb() { + var a; + a = this.n; + return this.a.a + a.b + a.c; + }; + sfb(Jye, "AtomicCell", 127); + feb(237, 22, { 3: 1, 34: 1, 22: 1, 237: 1 }, $Jb); + var WJb, XJb, YJb; + var JN = tfb(Jye, "ContainerArea", 237, WI, aKb, _Jb); + var bKb; + feb(336, 217, Lye); + sfb(Jye, "ContainerCell", 336); + feb(1538, 336, Lye, wKb); + _2.jf = function xKb() { + var a; + a = 0; + this.e ? this.b ? a = this.b.b : !!this.a[1][1] && (a = this.a[1][1].jf()) : a = vKb(this, rKb(this, true)); + return a > 0 ? a + this.n.d + this.n.a : 0; + }; + _2.kf = function yKb() { + var a, b, c2, d, e; + e = 0; + if (this.e) { + this.b ? e = this.b.a : !!this.a[1][1] && (e = this.a[1][1].kf()); + } else if (this.g) { + e = vKb(this, pKb(this, null, true)); + } else { + for (b = (ZJb(), cD(WC(JN, 1), jwe, 237, 0, [WJb, XJb, YJb])), c2 = 0, d = b.length; c2 < d; ++c2) { + a = b[c2]; + e = $wnd.Math.max(e, vKb(this, pKb(this, a, true))); + } + } + return e > 0 ? e + this.n.b + this.n.c : 0; + }; + _2.lf = function zKb() { + var a, b, c2, d, e; + if (this.g) { + a = pKb(this, null, false); + for (c2 = (ZJb(), cD(WC(JN, 1), jwe, 237, 0, [WJb, XJb, YJb])), d = 0, e = c2.length; d < e; ++d) { + b = c2[d]; + nKb(this, b, a); + } + } else { + for (c2 = (ZJb(), cD(WC(JN, 1), jwe, 237, 0, [WJb, XJb, YJb])), d = 0, e = c2.length; d < e; ++d) { + b = c2[d]; + a = pKb(this, b, false); + nKb(this, b, a); + } + } + }; + _2.mf = function AKb() { + var a, b, c2, d; + b = this.i; + a = this.n; + d = rKb(this, false); + lKb(this, (ZJb(), WJb), b.d + a.d, d); + lKb(this, YJb, b.d + b.a - a.a - d[2], d); + c2 = b.a - a.d - a.a; + if (d[0] > 0) { + d[0] += this.d; + c2 -= d[0]; + } + if (d[2] > 0) { + d[2] += this.d; + c2 -= d[2]; + } + this.c.a = $wnd.Math.max(0, c2); + this.c.d = b.d + a.d + (this.c.a - c2) / 2; + d[1] = $wnd.Math.max(d[1], c2); + lKb(this, XJb, b.d + a.d + d[0] - (d[1] - c2) / 2, d); + }; + _2.b = null; + _2.d = 0; + _2.e = false; + _2.f = false; + _2.g = false; + var iKb = 0, jKb = 0; + sfb(Jye, "GridContainerCell", 1538); + feb(471, 22, { 3: 1, 34: 1, 22: 1, 471: 1 }, FKb); + var BKb, CKb, DKb; + var MN = tfb(Jye, "HorizontalLabelAlignment", 471, WI, HKb, GKb); + var IKb; + feb(314, 217, { 217: 1, 314: 1 }, TKb, UKb, VKb); + _2.jf = function WKb() { + return PKb(this); + }; + _2.kf = function XKb() { + return QKb(this); + }; + _2.a = 0; + _2.c = false; + var NN = sfb(Jye, "LabelCell", 314); + feb(252, 336, { 217: 1, 336: 1, 252: 1 }, dLb); + _2.jf = function eLb() { + return YKb(this); + }; + _2.kf = function fLb() { + return ZKb(this); + }; + _2.lf = function iLb() { + $Kb(this); + }; + _2.mf = function jLb() { + _Kb(this); + }; + _2.b = 0; + _2.c = 0; + _2.d = false; + sfb(Jye, "StripContainerCell", 252); + feb(1691, 1, nwe, kLb); + _2.Mb = function lLb(a) { + return gLb(RD(a, 217)); + }; + sfb(Jye, "StripContainerCell/lambda$0$Type", 1691); + feb(1692, 1, {}, mLb); + _2.Ye = function nLb(a) { + return RD(a, 217).kf(); + }; + sfb(Jye, "StripContainerCell/lambda$1$Type", 1692); + feb(1693, 1, nwe, oLb); + _2.Mb = function pLb(a) { + return hLb(RD(a, 217)); + }; + sfb(Jye, "StripContainerCell/lambda$2$Type", 1693); + feb(1694, 1, {}, qLb); + _2.Ye = function rLb(a) { + return RD(a, 217).jf(); + }; + sfb(Jye, "StripContainerCell/lambda$3$Type", 1694); + feb(472, 22, { 3: 1, 34: 1, 22: 1, 472: 1 }, wLb); + var sLb, tLb, uLb; + var TN = tfb(Jye, "VerticalLabelAlignment", 472, WI, yLb, xLb); + var zLb; + feb(800, 1, {}, CLb); + _2.c = 0; + _2.d = 0; + _2.k = 0; + _2.s = 0; + _2.t = 0; + _2.v = false; + _2.w = 0; + _2.D = false; + sfb(Rye, "NodeContext", 800); + feb(1536, 1, fye, FLb); + _2.Ne = function GLb(a, b) { + return ELb(RD(a, 64), RD(b, 64)); + }; + _2.Fb = function HLb(a) { + return this === a; + }; + _2.Oe = function ILb() { + return new Frb(this); + }; + sfb(Rye, "NodeContext/0methodref$comparePortSides$Type", 1536); + feb(1537, 1, fye, JLb); + _2.Ne = function KLb(a, b) { + return DLb(RD(a, 117), RD(b, 117)); + }; + _2.Fb = function LLb(a) { + return this === a; + }; + _2.Oe = function MLb() { + return new Frb(this); + }; + sfb(Rye, "NodeContext/1methodref$comparePortContexts$Type", 1537); + feb(164, 22, { 3: 1, 34: 1, 22: 1, 164: 1 }, kMb); + var NLb, OLb, PLb, QLb, RLb, SLb, TLb, ULb, VLb, WLb, XLb, YLb, ZLb, $Lb, _Lb, aMb, bMb, cMb, dMb, eMb, fMb, gMb; + var XN = tfb(Rye, "NodeLabelLocation", 164, WI, nMb, mMb); + var oMb; + feb(117, 1, { 117: 1 }, rMb); + _2.a = false; + sfb(Rye, "PortContext", 117); + feb(1541, 1, Qve, KMb); + _2.Cd = function LMb(a) { + NKb(RD(a, 314)); + }; + sfb(Uye, Vye, 1541); + feb(1542, 1, nwe, MMb); + _2.Mb = function NMb(a) { + return !!RD(a, 117).c; + }; + sfb(Uye, Wye, 1542); + feb(1543, 1, Qve, OMb); + _2.Cd = function PMb(a) { + NKb(RD(a, 117).c); + }; + sfb(Uye, "LabelPlacer/lambda$2$Type", 1543); + var QMb; + feb(1540, 1, Qve, YMb); + _2.Cd = function ZMb(a) { + RMb(); + qMb(RD(a, 117)); + }; + sfb(Uye, "NodeLabelAndSizeUtilities/lambda$0$Type", 1540); + feb(801, 1, Qve, dNb); + _2.Cd = function eNb(a) { + bNb(this.b, this.c, this.a, RD(a, 187)); + }; + _2.a = false; + _2.c = false; + sfb(Uye, "NodeLabelCellCreator/lambda$0$Type", 801); + feb(1539, 1, Qve, kNb); + _2.Cd = function lNb(a) { + jNb(this.a, RD(a, 187)); + }; + sfb(Uye, "PortContextCreator/lambda$0$Type", 1539); + var sNb; + feb(1902, 1, {}, MNb); + sfb(Yye, "GreedyRectangleStripOverlapRemover", 1902); + feb(1903, 1, fye, ONb); + _2.Ne = function PNb(a, b) { + return NNb(RD(a, 226), RD(b, 226)); + }; + _2.Fb = function QNb(a) { + return this === a; + }; + _2.Oe = function RNb() { + return new Frb(this); + }; + sfb(Yye, "GreedyRectangleStripOverlapRemover/0methodref$compareByYCoordinate$Type", 1903); + feb(1849, 1, {}, YNb); + _2.a = 5; + _2.e = 0; + sfb(Yye, "RectangleStripOverlapRemover", 1849); + feb(1850, 1, fye, aOb); + _2.Ne = function bOb(a, b) { + return ZNb(RD(a, 226), RD(b, 226)); + }; + _2.Fb = function cOb(a) { + return this === a; + }; + _2.Oe = function dOb() { + return new Frb(this); + }; + sfb(Yye, "RectangleStripOverlapRemover/0methodref$compareLeftRectangleBorders$Type", 1850); + feb(1852, 1, fye, eOb); + _2.Ne = function fOb(a, b) { + return $Nb(RD(a, 226), RD(b, 226)); + }; + _2.Fb = function gOb(a) { + return this === a; + }; + _2.Oe = function hOb() { + return new Frb(this); + }; + sfb(Yye, "RectangleStripOverlapRemover/1methodref$compareRightRectangleBorders$Type", 1852); + feb(417, 22, { 3: 1, 34: 1, 22: 1, 417: 1 }, nOb); + var iOb, jOb, kOb, lOb; + var hO = tfb(Yye, "RectangleStripOverlapRemover/OverlapRemovalDirection", 417, WI, pOb, oOb); + var qOb; + feb(226, 1, { 226: 1 }, sOb); + sfb(Yye, "RectangleStripOverlapRemover/RectangleNode", 226); + feb(1851, 1, Qve, tOb); + _2.Cd = function uOb(a) { + TNb(this.a, RD(a, 226)); + }; + sfb(Yye, "RectangleStripOverlapRemover/lambda$1$Type", 1851); + feb(1323, 1, fye, xOb); + _2.Ne = function yOb(a, b) { + return wOb(RD(a, 176), RD(b, 176)); + }; + _2.Fb = function zOb(a) { + return this === a; + }; + _2.Oe = function AOb() { + return new Frb(this); + }; + sfb($ye, "PolyominoCompactor/CornerCasesGreaterThanRestComparator", 1323); + feb(1326, 1, {}, BOb); + _2.Kb = function COb(a) { + return RD(a, 334).a; + }; + sfb($ye, "PolyominoCompactor/CornerCasesGreaterThanRestComparator/lambda$0$Type", 1326); + feb(1327, 1, nwe, DOb); + _2.Mb = function EOb(a) { + return RD(a, 332).a; + }; + sfb($ye, "PolyominoCompactor/CornerCasesGreaterThanRestComparator/lambda$1$Type", 1327); + feb(1328, 1, nwe, FOb); + _2.Mb = function GOb(a) { + return RD(a, 332).a; + }; + sfb($ye, "PolyominoCompactor/CornerCasesGreaterThanRestComparator/lambda$2$Type", 1328); + feb(1321, 1, fye, IOb); + _2.Ne = function JOb(a, b) { + return HOb(RD(a, 176), RD(b, 176)); + }; + _2.Fb = function KOb(a) { + return this === a; + }; + _2.Oe = function LOb() { + return new Frb(this); + }; + sfb($ye, "PolyominoCompactor/MinNumOfExtensionDirectionsComparator", 1321); + feb(1324, 1, {}, MOb); + _2.Kb = function NOb(a) { + return RD(a, 334).a; + }; + sfb($ye, "PolyominoCompactor/MinNumOfExtensionDirectionsComparator/lambda$0$Type", 1324); + feb(781, 1, fye, POb); + _2.Ne = function QOb(a, b) { + return OOb(RD(a, 176), RD(b, 176)); + }; + _2.Fb = function ROb(a) { + return this === a; + }; + _2.Oe = function SOb() { + return new Frb(this); + }; + sfb($ye, "PolyominoCompactor/MinNumOfExtensionsComparator", 781); + feb(1319, 1, fye, UOb); + _2.Ne = function VOb(a, b) { + return TOb(RD(a, 330), RD(b, 330)); + }; + _2.Fb = function WOb(a) { + return this === a; + }; + _2.Oe = function XOb() { + return new Frb(this); + }; + sfb($ye, "PolyominoCompactor/MinPerimeterComparator", 1319); + feb(1320, 1, fye, ZOb); + _2.Ne = function $Ob(a, b) { + return YOb(RD(a, 330), RD(b, 330)); + }; + _2.Fb = function _Ob(a) { + return this === a; + }; + _2.Oe = function aPb() { + return new Frb(this); + }; + sfb($ye, "PolyominoCompactor/MinPerimeterComparatorWithShape", 1320); + feb(1322, 1, fye, cPb); + _2.Ne = function dPb(a, b) { + return bPb(RD(a, 176), RD(b, 176)); + }; + _2.Fb = function ePb(a) { + return this === a; + }; + _2.Oe = function fPb() { + return new Frb(this); + }; + sfb($ye, "PolyominoCompactor/SingleExtensionSideGreaterThanRestComparator", 1322); + feb(1325, 1, {}, gPb); + _2.Kb = function hPb(a) { + return RD(a, 334).a; + }; + sfb($ye, "PolyominoCompactor/SingleExtensionSideGreaterThanRestComparator/lambda$0$Type", 1325); + feb(782, 1, {}, kPb); + _2.Ve = function lPb(a, b) { + return jPb(this, RD(a, 42), RD(b, 176)); + }; + sfb($ye, "SuccessorCombination", 782); + feb(649, 1, {}, nPb); + _2.Ve = function oPb(a, b) { + var c2; + return mPb((c2 = RD(a, 42), RD(b, 176), c2)); + }; + sfb($ye, "SuccessorJitter", 649); + feb(648, 1, {}, qPb); + _2.Ve = function rPb(a, b) { + var c2; + return pPb((c2 = RD(a, 42), RD(b, 176), c2)); + }; + sfb($ye, "SuccessorLineByLine", 648); + feb(573, 1, {}, tPb); + _2.Ve = function uPb(a, b) { + var c2; + return sPb((c2 = RD(a, 42), RD(b, 176), c2)); + }; + sfb($ye, "SuccessorManhattan", 573); + feb(1344, 1, {}, wPb); + _2.Ve = function xPb(a, b) { + var c2; + return vPb((c2 = RD(a, 42), RD(b, 176), c2)); + }; + sfb($ye, "SuccessorMaxNormWindingInMathPosSense", 1344); + feb(409, 1, {}, APb); + _2.Ve = function BPb(a, b) { + return yPb(this, a, b); + }; + _2.c = false; + _2.d = false; + _2.e = false; + _2.f = false; + sfb($ye, "SuccessorQuadrantsGeneric", 409); + feb(1345, 1, {}, CPb); + _2.Kb = function DPb(a) { + return RD(a, 334).a; + }; + sfb($ye, "SuccessorQuadrantsGeneric/lambda$0$Type", 1345); + feb(332, 22, { 3: 1, 34: 1, 22: 1, 332: 1 }, JPb); + _2.a = false; + var EPb, FPb, GPb, HPb; + var DO = tfb(dze, eze, 332, WI, LPb, KPb); + var MPb; + feb(1317, 1, {}); + _2.Ib = function UPb() { + var a, b, c2, d, e, f2; + c2 = " "; + a = sgb(0); + for (e = 0; e < this.o; e++) { + c2 += "" + a.a; + a = sgb(OPb(a.a)); + } + c2 += "\n"; + a = sgb(0); + for (f2 = 0; f2 < this.p; f2++) { + c2 += "" + a.a; + a = sgb(OPb(a.a)); + for (d = 0; d < this.o; d++) { + b = SPb(this, d, f2); + Ddb(b, 0) == 0 ? c2 += "_" : Ddb(b, 1) == 0 ? c2 += "X" : c2 += "0"; + } + c2 += "\n"; + } + return zhb(c2, 0, c2.length - 1); + }; + _2.o = 0; + _2.p = 0; + sfb(dze, "TwoBitGrid", 1317); + feb(330, 1317, { 330: 1 }, gQb); + _2.j = 0; + _2.k = 0; + sfb(dze, "PlanarGrid", 330); + feb(176, 330, { 330: 1, 176: 1 }); + _2.g = 0; + _2.i = 0; + sfb(dze, "Polyomino", 176); + var U5 = ufb(jze, kze); + feb(137, 1, lze, qQb); + _2.qf = function uQb(a, b) { + return oQb(this, a, b); + }; + _2.nf = function rQb() { + return lQb(this); + }; + _2.of = function sQb(a) { + return mQb(this, a); + }; + _2.pf = function tQb(a) { + return nQb(this, a); + }; + sfb(jze, "MapPropertyHolder", 137); + feb(1318, 137, lze, vQb); + sfb(dze, "Polyominoes", 1318); + var wQb = false, xQb, yQb; + feb(1828, 1, Qve, GQb); + _2.Cd = function HQb(a) { + AQb(RD(a, 225)); + }; + sfb(mze, "DepthFirstCompaction/0methodref$compactTree$Type", 1828); + feb(825, 1, Qve, IQb); + _2.Cd = function JQb(a) { + DQb(this.a, RD(a, 225)); + }; + sfb(mze, "DepthFirstCompaction/lambda$1$Type", 825); + feb(1829, 1, Qve, KQb); + _2.Cd = function LQb(a) { + EQb(this.a, this.b, this.c, RD(a, 225)); + }; + sfb(mze, "DepthFirstCompaction/lambda$2$Type", 1829); + var MQb, NQb; + feb(68, 1, { 68: 1 }, TQb); + sfb(mze, "Node", 68); + feb(1214, 1, {}, WQb); + sfb(mze, "ScanlineOverlapCheck", 1214); + feb(1215, 1, { 693: 1 }, $Qb); + _2.bf = function _Qb(a) { + YQb(this, RD(a, 451)); + }; + sfb(mze, "ScanlineOverlapCheck/OverlapsScanlineHandler", 1215); + feb(1216, 1, fye, bRb); + _2.Ne = function cRb(a, b) { + return aRb(RD(a, 68), RD(b, 68)); + }; + _2.Fb = function dRb(a) { + return this === a; + }; + _2.Oe = function eRb() { + return new Frb(this); + }; + sfb(mze, "ScanlineOverlapCheck/OverlapsScanlineHandler/lambda$0$Type", 1216); + feb(451, 1, { 451: 1 }, fRb); + _2.a = false; + sfb(mze, "ScanlineOverlapCheck/Timestamp", 451); + feb(1217, 1, fye, gRb); + _2.Ne = function hRb(a, b) { + return XQb(RD(a, 451), RD(b, 451)); + }; + _2.Fb = function iRb(a) { + return this === a; + }; + _2.Oe = function jRb() { + return new Frb(this); + }; + sfb(mze, "ScanlineOverlapCheck/lambda$0$Type", 1217); + feb(557, 1, {}, kRb); + sfb(nze, "SVGImage", 557); + feb(334, 1, { 334: 1 }, lRb); + _2.Ib = function mRb() { + return "(" + this.a + pve + this.b + pve + this.c + ")"; + }; + sfb(nze, "UniqueTriple", 334); + feb(205, 1, oze); + sfb(pze, "AbstractLayoutProvider", 205); + feb(1114, 205, oze, pRb); + _2.rf = function qRb(a, b) { + var c2, d, e, f2; + b.Ug(qze, 1); + this.a = Kfb(UD(Gxd(a, (tSb(), sSb)))); + if (Hxd(a, iSb)) { + e = WD(Gxd(a, iSb)); + c2 = sgd(ygd(), e); + if (c2) { + d = RD(ltd(c2.f), 205); + d.rf(a, b.eh(1)); + } + } + f2 = new rTb(this.a); + this.b = pTb(f2, a); + switch (RD(Gxd(a, (eSb(), aSb)), 489).g) { + case 0: + sRb(new wRb(), this.b); + Ixd(a, lSb, mQb(this.b, lSb)); + break; + default: + gib(); + } + hTb(f2); + Ixd(a, kSb, this.b); + b.Vg(); + }; + _2.a = 0; + sfb(rze, "DisCoLayoutProvider", 1114); + feb(1208, 1, {}, wRb); + _2.c = false; + _2.e = 0; + _2.f = 0; + sfb(rze, "DisCoPolyominoCompactor", 1208); + feb(567, 1, { 567: 1 }, DRb); + _2.b = true; + sfb(sze, "DCComponent", 567); + feb(406, 22, { 3: 1, 34: 1, 22: 1, 406: 1 }, JRb); + _2.a = false; + var ERb, FRb, GRb, HRb; + var WO = tfb(sze, "DCDirection", 406, WI, LRb, KRb); + var MRb; + feb(272, 137, { 3: 1, 272: 1, 96: 1, 137: 1 }, ORb); + sfb(sze, "DCElement", 272); + feb(407, 1, { 407: 1 }, QRb); + _2.c = 0; + sfb(sze, "DCExtension", 407); + feb(762, 137, lze, TRb); + sfb(sze, "DCGraph", 762); + feb(489, 22, { 3: 1, 34: 1, 22: 1, 489: 1 }, WRb); + var URb; + var $O = tfb(tze, uze, 489, WI, YRb, XRb); + var ZRb; + feb(865, 1, Eye, fSb); + _2.hf = function gSb(a) { + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), vze), zze), "Connected Components Compaction Strategy"), "Strategy for packing different connected components in order to save space and enhance readability of a graph."), bSb), (kid(), eid)), $O), xsb((Yhd(), Whd))))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), wze), zze), "Connected Components Layout Algorithm"), "A layout algorithm that is to be applied to each connected component before the components themselves are compacted. If unspecified, the positions of the components' nodes are not altered."), iid), qJ), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), xze), "debug"), "DCGraph"), "Access to the DCGraph is intended for the debug view,"), hid), jJ), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), yze), "debug"), "List of Polyominoes"), "Access to the polyominoes is intended for the debug view,"), hid), jJ), xsb(Whd)))); + uSb((new vSb(), a)); + }; + var _Rb, aSb, bSb, cSb, dSb; + sfb(tze, "DisCoMetaDataProvider", 865); + feb(1010, 1, Eye, vSb); + _2.hf = function wSb(a) { + uSb(a); + }; + var hSb, iSb, jSb, kSb, lSb, mSb, nSb, oSb, pSb, qSb, rSb, sSb; + sfb(tze, "DisCoOptions", 1010); + feb(1011, 1, {}, xSb); + _2.sf = function ySb() { + var a; + return a = new pRb(), a; + }; + _2.tf = function zSb(a) { + }; + sfb(tze, "DisCoOptions/DiscoFactory", 1011); + feb(568, 176, { 330: 1, 176: 1, 568: 1 }, DSb); + _2.a = 0; + _2.b = 0; + _2.c = 0; + _2.d = 0; + sfb("org.eclipse.elk.alg.disco.structures", "DCPolyomino", 568); + var ESb, FSb, GSb; + feb(1286, 1, nwe, TSb); + _2.Mb = function USb(a) { + return SSb(a); + }; + sfb(Fze, "ElkGraphComponentsProcessor/lambda$0$Type", 1286); + feb(1287, 1, {}, VSb); + _2.Kb = function WSb(a) { + return HSb(), JGd(RD(a, 74)); + }; + sfb(Fze, "ElkGraphComponentsProcessor/lambda$1$Type", 1287); + feb(1288, 1, nwe, XSb); + _2.Mb = function YSb(a) { + return NSb(RD(a, 74)); + }; + sfb(Fze, "ElkGraphComponentsProcessor/lambda$2$Type", 1288); + feb(1289, 1, {}, ZSb); + _2.Kb = function $Sb(a) { + return HSb(), LGd(RD(a, 74)); + }; + sfb(Fze, "ElkGraphComponentsProcessor/lambda$3$Type", 1289); + feb(1290, 1, nwe, _Sb); + _2.Mb = function aTb(a) { + return OSb(RD(a, 74)); + }; + sfb(Fze, "ElkGraphComponentsProcessor/lambda$4$Type", 1290); + feb(1291, 1, nwe, bTb); + _2.Mb = function cTb(a) { + return PSb(this.a, RD(a, 74)); + }; + sfb(Fze, "ElkGraphComponentsProcessor/lambda$5$Type", 1291); + feb(1292, 1, {}, dTb); + _2.Kb = function eTb(a) { + return QSb(this.a, RD(a, 74)); + }; + sfb(Fze, "ElkGraphComponentsProcessor/lambda$6$Type", 1292); + feb(1205, 1, {}, rTb); + _2.a = 0; + sfb(Fze, "ElkGraphTransformer", 1205); + feb(1206, 1, {}, tTb); + _2.Yd = function uTb(a, b) { + sTb(this, RD(a, 167), RD(b, 272)); + }; + sfb(Fze, "ElkGraphTransformer/OffsetApplier", 1206); + feb(1207, 1, Qve, wTb); + _2.Cd = function xTb(a) { + vTb(this, RD(a, 8)); + }; + sfb(Fze, "ElkGraphTransformer/OffsetApplier/OffSetToChainApplier", 1207); + feb(760, 1, {}, DTb); + sfb(Kze, Lze, 760); + feb(1195, 1, fye, FTb); + _2.Ne = function GTb(a, b) { + return ETb(RD(a, 235), RD(b, 235)); + }; + _2.Fb = function HTb(a) { + return this === a; + }; + _2.Oe = function ITb() { + return new Frb(this); + }; + sfb(Kze, Mze, 1195); + feb(1196, 1, Qve, OTb); + _2.Cd = function PTb(a) { + NTb(this.b, this.a, RD(a, 250)); + }; + sfb(Kze, Nze, 1196); + feb(738, 205, oze, TTb); + _2.rf = function UTb(a, b) { + QTb(this, a, b); + }; + sfb(Kze, "ForceLayoutProvider", 738); + feb(309, 137, { 3: 1, 309: 1, 96: 1, 137: 1 }); + sfb(Oze, "FParticle", 309); + feb(250, 309, { 3: 1, 250: 1, 309: 1, 96: 1, 137: 1 }, WTb); + _2.Ib = function XTb() { + var a; + if (this.a) { + a = Wmb(this.a.a, this, 0); + return a >= 0 ? "b" + a + "[" + bUb(this.a) + "]" : "b[" + bUb(this.a) + "]"; + } + return "b_" + kFb(this); + }; + sfb(Oze, "FBendpoint", 250); + feb(290, 137, { 3: 1, 290: 1, 96: 1, 137: 1 }, cUb); + _2.Ib = function dUb() { + return bUb(this); + }; + sfb(Oze, "FEdge", 290); + feb(235, 137, { 3: 1, 235: 1, 96: 1, 137: 1 }, gUb); + var tP = sfb(Oze, "FGraph", 235); + feb(454, 309, { 3: 1, 454: 1, 309: 1, 96: 1, 137: 1 }, iUb); + _2.Ib = function jUb() { + return this.b == null || this.b.length == 0 ? "l[" + bUb(this.a) + "]" : "l_" + this.b; + }; + sfb(Oze, "FLabel", 454); + feb(153, 309, { 3: 1, 153: 1, 309: 1, 96: 1, 137: 1 }, lUb); + _2.Ib = function mUb() { + return kUb(this); + }; + _2.a = 0; + sfb(Oze, "FNode", 153); + feb(2100, 1, {}); + _2.vf = function rUb(a) { + nUb(this, a); + }; + _2.wf = function sUb() { + oUb(this); + }; + _2.d = 0; + sfb(Qze, "AbstractForceModel", 2100); + feb(641, 2100, { 641: 1 }, tUb); + _2.uf = function vUb(a, b) { + var c2, d, e, f2, g; + qUb(this.f, a, b); + e = ojd(ajd(b.d), a.d); + g = $wnd.Math.sqrt(e.a * e.a + e.b * e.b); + d = $wnd.Math.max(0, g - ejd(a.e) / 2 - ejd(b.e) / 2); + c2 = fUb(this.e, a, b); + c2 > 0 ? f2 = -uUb(d, this.c) * c2 : f2 = yUb(d, this.b) * RD(mQb(a, (yVb(), lVb)), 17).a; + ijd(e, f2 / g); + return e; + }; + _2.vf = function wUb(a) { + nUb(this, a); + this.a = RD(mQb(a, (yVb(), aVb)), 17).a; + this.c = Kfb(UD(mQb(a, rVb))); + this.b = Kfb(UD(mQb(a, nVb))); + }; + _2.xf = function xUb(a) { + return a < this.a; + }; + _2.a = 0; + _2.b = 0; + _2.c = 0; + sfb(Qze, "EadesModel", 641); + feb(642, 2100, { 642: 1 }, zUb); + _2.uf = function BUb(a, b) { + var c2, d, e, f2, g; + qUb(this.f, a, b); + e = ojd(ajd(b.d), a.d); + g = $wnd.Math.sqrt(e.a * e.a + e.b * e.b); + d = $wnd.Math.max(0, g - ejd(a.e) / 2 - ejd(b.e) / 2); + f2 = FUb(d, this.a) * RD(mQb(a, (yVb(), lVb)), 17).a; + c2 = fUb(this.e, a, b); + c2 > 0 && (f2 -= AUb(d, this.a) * c2); + ijd(e, f2 * this.b / g); + return e; + }; + _2.vf = function CUb(a) { + var b, c2, d, e, f2, g, h; + nUb(this, a); + this.b = Kfb(UD(mQb(a, (yVb(), sVb)))); + this.c = this.b / RD(mQb(a, aVb), 17).a; + d = a.e.c.length; + f2 = 0; + e = 0; + for (h = new Anb(a.e); h.a < h.c.c.length; ) { + g = RD(ynb(h), 153); + f2 += g.e.a; + e += g.e.b; + } + b = f2 * e; + c2 = Kfb(UD(mQb(a, rVb))) * Tye; + this.a = $wnd.Math.sqrt(b / (2 * d)) * c2; + }; + _2.wf = function DUb() { + oUb(this); + this.b -= this.c; + }; + _2.xf = function EUb(a) { + return this.b > 0; + }; + _2.a = 0; + _2.b = 0; + _2.c = 0; + sfb(Qze, "FruchtermanReingoldModel", 642); + feb(860, 1, Eye, PUb); + _2.hf = function QUb(a) { + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), Rze), ""), "Force Model"), "Determines the model for force calculation."), IUb), (kid(), eid)), BP), xsb((Yhd(), Whd))))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), Sze), ""), "Iterations"), "The number of iterations on the force model."), sgb(300)), gid), bJ), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), Tze), ""), "Repulsive Power"), "Determines how many bend points are added to the edge; such bend points are regarded as repelling particles in the force model"), sgb(0)), gid), bJ), xsb(Thd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), Uze), ""), "FR Temperature"), "The temperature is used as a scaling factor for particle displacements."), Vze), did), VI), xsb(Whd)))); + zgd(a, Uze, Rze, NUb); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), Wze), ""), "Eades Repulsion"), "Factor for repulsive forces in Eades' model."), 5), did), VI), xsb(Whd)))); + zgd(a, Wze, Rze, KUb); + zVb((new AVb(), a)); + }; + var GUb, HUb, IUb, JUb, KUb, LUb, MUb, NUb; + sfb(Xze, "ForceMetaDataProvider", 860); + feb(432, 22, { 3: 1, 34: 1, 22: 1, 432: 1 }, UUb); + var RUb, SUb; + var BP = tfb(Xze, "ForceModelStrategy", 432, WI, WUb, VUb); + var XUb; + feb(Awe, 1, Eye, AVb); + _2.hf = function BVb(a) { + zVb(a); + }; + var ZUb, $Ub, _Ub, aVb, bVb, cVb, dVb, eVb, fVb, gVb, hVb, iVb, jVb, kVb, lVb, mVb, nVb, oVb, pVb, qVb, rVb, sVb, tVb, uVb, vVb, wVb, xVb; + sfb(Xze, "ForceOptions", Awe); + feb(1001, 1, {}, CVb); + _2.sf = function DVb() { + var a; + return a = new TTb(), a; + }; + _2.tf = function EVb(a) { + }; + sfb(Xze, "ForceOptions/ForceFactory", 1001); + var FVb, GVb, HVb, IVb; + feb(861, 1, Eye, RVb); + _2.hf = function SVb(a) { + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), vAe), ""), "Fixed Position"), "Prevent that the node is moved by the layout algorithm."), (Geb(), false)), (kid(), cid)), QI), xsb((Yhd(), Vhd))))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), wAe), ""), "Desired Edge Length"), "Either specified for parent nodes or for individual edges, where the latter takes higher precedence."), 100), did), VI), ysb(Whd, cD(WC(d3, 1), jwe, 170, 0, [Thd]))))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), xAe), ""), "Layout Dimension"), "Dimensions that are permitted to be altered during layout."), MVb), eid), JP), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), yAe), ""), "Stress Epsilon"), "Termination criterion for the iterative process."), Vze), did), VI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), zAe), ""), "Iteration Limit"), "Maximum number of performed iterations. Takes higher precedence than 'epsilon'."), sgb(lve)), gid), bJ), xsb(Whd)))); + eWb((new fWb(), a)); + }; + var KVb, LVb, MVb, NVb, OVb, PVb; + sfb(Xze, "StressMetaDataProvider", 861); + feb(1004, 1, Eye, fWb); + _2.hf = function gWb(a) { + eWb(a); + }; + var TVb, UVb, VVb, WVb, XVb, YVb, ZVb, $Vb, _Vb, aWb, bWb, cWb; + sfb(Xze, "StressOptions", 1004); + feb(1005, 1, {}, hWb); + _2.sf = function iWb() { + var a; + return a = new kWb(), a; + }; + _2.tf = function jWb(a) { + }; + sfb(Xze, "StressOptions/StressFactory", 1005); + feb(1110, 205, oze, kWb); + _2.rf = function lWb(a, b) { + var c2, d, e, f2, g; + b.Ug(BAe, 1); + Heb(TD(Gxd(a, (dWb(), XVb)))) ? Heb(TD(Gxd(a, bWb))) || RFb((c2 = new SFb((lud(), new zud(a))), c2)) : QTb(new TTb(), a, b.eh(1)); + e = KTb(a); + d = CTb(this.a, e); + for (g = d.Kc(); g.Ob(); ) { + f2 = RD(g.Pb(), 235); + if (f2.e.c.length <= 1) { + continue; + } + uWb(this.b, f2); + sWb(this.b); + Umb(f2.d, new mWb()); + } + e = BTb(d); + JTb(e); + b.Vg(); + }; + sfb(DAe, "StressLayoutProvider", 1110); + feb(1111, 1, Qve, mWb); + _2.Cd = function nWb(a) { + hUb(RD(a, 454)); + }; + sfb(DAe, "StressLayoutProvider/lambda$0$Type", 1111); + feb(1002, 1, {}, vWb); + _2.c = 0; + _2.e = 0; + _2.g = 0; + sfb(DAe, "StressMajorization", 1002); + feb(391, 22, { 3: 1, 34: 1, 22: 1, 391: 1 }, BWb); + var xWb, yWb, zWb; + var JP = tfb(DAe, "StressMajorization/Dimension", 391, WI, DWb, CWb); + var EWb; + feb(1003, 1, fye, GWb); + _2.Ne = function HWb(a, b) { + return wWb(this.a, RD(a, 153), RD(b, 153)); + }; + _2.Fb = function IWb(a) { + return this === a; + }; + _2.Oe = function JWb() { + return new Frb(this); + }; + sfb(DAe, "StressMajorization/lambda$0$Type", 1003); + feb(1192, 1, {}, RWb); + sfb(FAe, "ElkLayered", 1192); + feb(1193, 1, Qve, UWb); + _2.Cd = function VWb(a) { + SWb(this.a, RD(a, 36)); + }; + sfb(FAe, "ElkLayered/lambda$0$Type", 1193); + feb(1194, 1, Qve, WWb); + _2.Cd = function XWb(a) { + TWb(this.a, RD(a, 36)); + }; + sfb(FAe, "ElkLayered/lambda$1$Type", 1194); + feb(1281, 1, {}, dXb); + var YWb, ZWb, $Wb; + sfb(FAe, "GraphConfigurator", 1281); + feb(770, 1, Qve, fXb); + _2.Cd = function gXb(a) { + aXb(this.a, RD(a, 10)); + }; + sfb(FAe, "GraphConfigurator/lambda$0$Type", 770); + feb(771, 1, {}, hXb); + _2.Kb = function iXb(a) { + return _Wb(), new SDb(null, new Swb(RD(a, 30).a, 16)); + }; + sfb(FAe, "GraphConfigurator/lambda$1$Type", 771); + feb(772, 1, Qve, jXb); + _2.Cd = function kXb(a) { + aXb(this.a, RD(a, 10)); + }; + sfb(FAe, "GraphConfigurator/lambda$2$Type", 772); + feb(1109, 205, oze, lXb); + _2.rf = function mXb(a, b) { + var c2; + c2 = c5b(new k5b(), a); + dE(Gxd(a, (yCc(), IAc))) === dE((Fnd(), Cnd)) ? LWb(this.a, c2, b) : MWb(this.a, c2, b); + b.$g() || J5b(new N5b(), c2); + }; + sfb(FAe, "LayeredLayoutProvider", 1109); + feb(367, 22, { 3: 1, 34: 1, 22: 1, 367: 1 }, tXb); + var nXb, oXb, pXb, qXb, rXb; + var UP = tfb(FAe, "LayeredPhases", 367, WI, vXb, uXb); + var wXb; + feb(1717, 1, {}, EXb); + _2.i = 0; + var yXb; + sfb(GAe, "ComponentsToCGraphTransformer", 1717); + var jYb; + feb(1718, 1, {}, FXb); + _2.yf = function GXb(a, b) { + return $wnd.Math.min(a.a != null ? Kfb(a.a) : a.c.i, b.a != null ? Kfb(b.a) : b.c.i); + }; + _2.zf = function HXb(a, b) { + return $wnd.Math.min(a.a != null ? Kfb(a.a) : a.c.i, b.a != null ? Kfb(b.a) : b.c.i); + }; + sfb(GAe, "ComponentsToCGraphTransformer/1", 1718); + feb(86, 1, { 86: 1 }); + _2.i = 0; + _2.k = true; + _2.o = pxe; + var bQ = sfb(HAe, "CNode", 86); + feb(470, 86, { 470: 1, 86: 1 }, IXb, JXb); + _2.Ib = function KXb() { + return ""; + }; + sfb(GAe, "ComponentsToCGraphTransformer/CRectNode", 470); + feb(1688, 1, {}, XXb); + var LXb, MXb; + sfb(GAe, "OneDimensionalComponentsCompaction", 1688); + feb(1689, 1, {}, $Xb); + _2.Kb = function _Xb(a) { + return YXb(RD(a, 42)); + }; + _2.Fb = function aYb(a) { + return this === a; + }; + sfb(GAe, "OneDimensionalComponentsCompaction/lambda$0$Type", 1689); + feb(1690, 1, {}, bYb); + _2.Kb = function cYb(a) { + return ZXb(RD(a, 42)); + }; + _2.Fb = function dYb(a) { + return this === a; + }; + sfb(GAe, "OneDimensionalComponentsCompaction/lambda$1$Type", 1690); + feb(1720, 1, {}, fYb); + sfb(HAe, "CGraph", 1720); + feb(194, 1, { 194: 1 }, iYb); + _2.b = 0; + _2.c = 0; + _2.e = 0; + _2.g = true; + _2.i = pxe; + sfb(HAe, "CGroup", 194); + feb(1719, 1, {}, lYb); + _2.yf = function mYb(a, b) { + return $wnd.Math.max(a.a != null ? Kfb(a.a) : a.c.i, b.a != null ? Kfb(b.a) : b.c.i); + }; + _2.zf = function nYb(a, b) { + return $wnd.Math.max(a.a != null ? Kfb(a.a) : a.c.i, b.a != null ? Kfb(b.a) : b.c.i); + }; + sfb(HAe, kye, 1719); + feb(1721, 1, {}, EYb); + _2.d = false; + var oYb; + var eQ = sfb(HAe, pye, 1721); + feb(1722, 1, {}, FYb); + _2.Kb = function GYb(a) { + return pYb(), Geb(), RD(RD(a, 42).a, 86).d.e != 0 ? true : false; + }; + _2.Fb = function HYb(a) { + return this === a; + }; + sfb(HAe, qye, 1722); + feb(833, 1, {}, KYb); + _2.a = false; + _2.b = false; + _2.c = false; + _2.d = false; + sfb(HAe, rye, 833); + feb(1898, 1, {}, QYb); + sfb(IAe, sye, 1898); + var wQ = ufb(JAe, hye); + feb(1899, 1, { 382: 1 }, UYb); + _2.bf = function VYb(a) { + SYb(this, RD(a, 476)); + }; + sfb(IAe, tye, 1899); + feb(Owe, 1, fye, XYb); + _2.Ne = function YYb(a, b) { + return WYb(RD(a, 86), RD(b, 86)); + }; + _2.Fb = function ZYb(a) { + return this === a; + }; + _2.Oe = function $Yb() { + return new Frb(this); + }; + sfb(IAe, uye, Owe); + feb(476, 1, { 476: 1 }, _Yb); + _2.a = false; + sfb(IAe, vye, 476); + feb(1901, 1, fye, aZb); + _2.Ne = function bZb(a, b) { + return RYb(RD(a, 476), RD(b, 476)); + }; + _2.Fb = function cZb(a) { + return this === a; + }; + _2.Oe = function dZb() { + return new Frb(this); + }; + sfb(IAe, wye, 1901); + feb(148, 1, { 148: 1 }, eZb, fZb); + _2.Fb = function gZb(a) { + var b; + if (a == null) { + return false; + } + if (mQ != rb(a)) { + return false; + } + b = RD(a, 148); + return Fvb(this.c, b.c) && Fvb(this.d, b.d); + }; + _2.Hb = function hZb() { + return Tnb(cD(WC(jJ, 1), rve, 1, 5, [this.c, this.d])); + }; + _2.Ib = function iZb() { + return "(" + this.c + pve + this.d + (this.a ? "cx" : "") + this.b + ")"; + }; + _2.a = true; + _2.c = 0; + _2.d = 0; + var mQ = sfb(JAe, "Point", 148); + feb(416, 22, { 3: 1, 34: 1, 22: 1, 416: 1 }, qZb); + var jZb, kZb, lZb, mZb; + var lQ = tfb(JAe, "Point/Quadrant", 416, WI, uZb, tZb); + var vZb; + feb(1708, 1, {}, EZb); + _2.b = null; + _2.c = null; + _2.d = null; + _2.e = null; + _2.f = null; + var xZb, yZb, zZb, AZb, BZb; + sfb(JAe, "RectilinearConvexHull", 1708); + feb(583, 1, { 382: 1 }, PZb); + _2.bf = function QZb(a) { + OZb(this, RD(a, 148)); + }; + _2.b = 0; + var MZb; + sfb(JAe, "RectilinearConvexHull/MaximalElementsEventHandler", 583); + feb(1710, 1, fye, SZb); + _2.Ne = function TZb(a, b) { + return RZb(UD(a), UD(b)); + }; + _2.Fb = function UZb(a) { + return this === a; + }; + _2.Oe = function VZb() { + return new Frb(this); + }; + sfb(JAe, "RectilinearConvexHull/MaximalElementsEventHandler/lambda$0$Type", 1710); + feb(1709, 1, { 382: 1 }, XZb); + _2.bf = function YZb(a) { + WZb(this, RD(a, 148)); + }; + _2.a = 0; + _2.b = null; + _2.c = null; + _2.d = null; + _2.e = null; + sfb(JAe, "RectilinearConvexHull/RectangleEventHandler", 1709); + feb(1711, 1, fye, ZZb); + _2.Ne = function $Zb(a, b) { + return GZb(RD(a, 148), RD(b, 148)); + }; + _2.Fb = function _Zb(a) { + return this === a; + }; + _2.Oe = function a$b() { + return new Frb(this); + }; + sfb(JAe, "RectilinearConvexHull/lambda$0$Type", 1711); + feb(1712, 1, fye, b$b); + _2.Ne = function c$b(a, b) { + return HZb(RD(a, 148), RD(b, 148)); + }; + _2.Fb = function d$b(a) { + return this === a; + }; + _2.Oe = function e$b() { + return new Frb(this); + }; + sfb(JAe, "RectilinearConvexHull/lambda$1$Type", 1712); + feb(1713, 1, fye, f$b); + _2.Ne = function g$b(a, b) { + return IZb(RD(a, 148), RD(b, 148)); + }; + _2.Fb = function h$b(a) { + return this === a; + }; + _2.Oe = function i$b() { + return new Frb(this); + }; + sfb(JAe, "RectilinearConvexHull/lambda$2$Type", 1713); + feb(1714, 1, fye, j$b); + _2.Ne = function k$b(a, b) { + return JZb(RD(a, 148), RD(b, 148)); + }; + _2.Fb = function l$b(a) { + return this === a; + }; + _2.Oe = function m$b() { + return new Frb(this); + }; + sfb(JAe, "RectilinearConvexHull/lambda$3$Type", 1714); + feb(1715, 1, fye, n$b); + _2.Ne = function o$b(a, b) { + return KZb(RD(a, 148), RD(b, 148)); + }; + _2.Fb = function p$b(a) { + return this === a; + }; + _2.Oe = function q$b() { + return new Frb(this); + }; + sfb(JAe, "RectilinearConvexHull/lambda$4$Type", 1715); + feb(1716, 1, {}, s$b); + sfb(JAe, "Scanline", 1716); + feb(2104, 1, {}); + sfb(KAe, "AbstractGraphPlacer", 2104); + feb(335, 1, { 335: 1 }, C$b); + _2.Ff = function D$b(a) { + if (this.Gf(a)) { + Rc(this.b, RD(mQb(a, (Ywc(), ewc)), 21), a); + return true; + } else { + return false; + } + }; + _2.Gf = function E$b(a) { + var b, c2, d, e; + b = RD(mQb(a, (Ywc(), ewc)), 21); + e = RD(Qc(y$b, b), 21); + for (d = e.Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 21); + if (!RD(Qc(this.b, c2), 15).dc()) { + return false; + } + } + return true; + }; + var y$b; + sfb(KAe, "ComponentGroup", 335); + feb(779, 2104, {}, J$b); + _2.Hf = function K$b(a) { + var b, c2; + for (c2 = new Anb(this.a); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 335); + if (b.Ff(a)) { + return; + } + } + Rmb(this.a, new C$b(a)); + }; + _2.Ef = function L$b(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2; + this.a.c.length = 0; + b.a.c.length = 0; + if (a.dc()) { + b.f.a = 0; + b.f.b = 0; + return; + } + g = RD(a.Xb(0), 36); + kQb(b, g); + for (e = a.Kc(); e.Ob(); ) { + d = RD(e.Pb(), 36); + this.Hf(d); + } + o2 = new pjd(); + f2 = Kfb(UD(mQb(g, (yCc(), SBc)))); + for (j = new Anb(this.a); j.a < j.c.c.length; ) { + h = RD(ynb(j), 335); + k = F$b(h, f2); + x$b(Uc(h.b), o2.a, o2.b); + o2.a += k.a; + o2.b += k.b; + } + b.f.a = o2.a - f2; + b.f.b = o2.b - f2; + if (Heb(TD(mQb(g, Vzc))) && dE(mQb(g, yAc)) === dE((Ymd(), Umd))) { + for (n = a.Kc(); n.Ob(); ) { + l = RD(n.Pb(), 36); + w$b(l, l.c.a, l.c.b); + } + c2 = new j_b(); + _$b(c2, a, f2); + for (m = a.Kc(); m.Ob(); ) { + l = RD(m.Pb(), 36); + $id(hjd(l.c), c2.e); + } + $id(hjd(b.f), c2.a); + } + for (i2 = new Anb(this.a); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 335); + v$b(b, Uc(h.b)); + } + }; + sfb(KAe, "ComponentGroupGraphPlacer", 779); + feb(1312, 779, {}, N$b); + _2.Hf = function O$b(a) { + M$b(this, a); + }; + _2.Ef = function P$b(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t; + this.a.c.length = 0; + b.a.c.length = 0; + if (a.dc()) { + b.f.a = 0; + b.f.b = 0; + return; + } + g = RD(a.Xb(0), 36); + kQb(b, g); + for (e = a.Kc(); e.Ob(); ) { + d = RD(e.Pb(), 36); + M$b(this, d); + } + t = new pjd(); + s = new pjd(); + p = new pjd(); + o2 = new pjd(); + f2 = Kfb(UD(mQb(g, (yCc(), SBc)))); + for (j = new Anb(this.a); j.a < j.c.c.length; ) { + h = RD(ynb(j), 335); + if (Dmd(RD(mQb(b, (umd(), Nkd)), 88))) { + p.a = t.a; + for (r = new aw(Pc(Fc(h.b).a).a.kc()); r.b.Ob(); ) { + q = RD(_v(r.b.Pb()), 21); + if (q.Hc((qpd(), Yod))) { + p.a = s.a; + break; + } + } + } else if (Emd(RD(mQb(b, Nkd), 88))) { + p.b = t.b; + for (r = new aw(Pc(Fc(h.b).a).a.kc()); r.b.Ob(); ) { + q = RD(_v(r.b.Pb()), 21); + if (q.Hc((qpd(), ppd))) { + p.b = s.b; + break; + } + } + } + k = F$b(RD(h, 579), f2); + x$b(Uc(h.b), p.a, p.b); + if (Dmd(RD(mQb(b, Nkd), 88))) { + s.a = p.a + k.a; + o2.a = $wnd.Math.max(o2.a, s.a); + for (r = new aw(Pc(Fc(h.b).a).a.kc()); r.b.Ob(); ) { + q = RD(_v(r.b.Pb()), 21); + if (q.Hc((qpd(), npd))) { + t.a = p.a + k.a; + break; + } + } + s.b = p.b + k.b; + p.b = s.b; + o2.b = $wnd.Math.max(o2.b, p.b); + } else if (Emd(RD(mQb(b, Nkd), 88))) { + s.b = p.b + k.b; + o2.b = $wnd.Math.max(o2.b, s.b); + for (r = new aw(Pc(Fc(h.b).a).a.kc()); r.b.Ob(); ) { + q = RD(_v(r.b.Pb()), 21); + if (q.Hc((qpd(), Xod))) { + t.b = p.b + k.b; + break; + } + } + s.a = p.a + k.a; + p.a = s.a; + o2.a = $wnd.Math.max(o2.a, p.a); + } + } + b.f.a = o2.a - f2; + b.f.b = o2.b - f2; + if (Heb(TD(mQb(g, Vzc))) && dE(mQb(g, yAc)) === dE((Ymd(), Umd))) { + for (n = a.Kc(); n.Ob(); ) { + l = RD(n.Pb(), 36); + w$b(l, l.c.a, l.c.b); + } + c2 = new j_b(); + _$b(c2, a, f2); + for (m = a.Kc(); m.Ob(); ) { + l = RD(m.Pb(), 36); + $id(hjd(l.c), c2.e); + } + $id(hjd(b.f), c2.a); + } + for (i2 = new Anb(this.a); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 335); + v$b(b, Uc(h.b)); + } + }; + sfb(KAe, "ComponentGroupModelOrderGraphPlacer", 1312); + feb(389, 22, { 3: 1, 34: 1, 22: 1, 389: 1 }, V$b); + var Q$b, R$b, S$b, T$b; + var CQ = tfb(KAe, "ComponentOrderingStrategy", 389, WI, X$b, W$b); + var Y$b; + feb(659, 1, {}, j_b); + sfb(KAe, "ComponentsCompactor", 659); + feb(1533, 13, Cxe, m_b); + _2.Fc = function n_b(a) { + return k_b(this, RD(a, 148)); + }; + sfb(KAe, "ComponentsCompactor/Hullpoints", 1533); + feb(1530, 1, { 855: 1 }, p_b); + _2.a = false; + sfb(KAe, "ComponentsCompactor/InternalComponent", 1530); + feb(1529, 1, Vve, q_b); + _2.Jc = function r_b(a) { + xgb(this, a); + }; + _2.Kc = function s_b() { + return new Anb(this.a); + }; + sfb(KAe, "ComponentsCompactor/InternalConnectedComponents", 1529); + feb(1532, 1, { 602: 1 }, t_b); + _2.Bf = function v_b() { + return null; + }; + _2.Cf = function w_b() { + return this.a; + }; + _2.Af = function u_b() { + return f_b(this.d); + }; + _2.Df = function x_b() { + return this.b; + }; + sfb(KAe, "ComponentsCompactor/InternalExternalExtension", 1532); + feb(1531, 1, { 602: 1 }, y_b); + _2.Cf = function B_b() { + return this.a; + }; + _2.Af = function z_b() { + return f_b(this.d); + }; + _2.Bf = function A_b() { + return this.c; + }; + _2.Df = function C_b() { + return this.b; + }; + sfb(KAe, "ComponentsCompactor/InternalUnionExternalExtension", 1531); + feb(1535, 1, {}, D_b); + sfb(KAe, "ComponentsCompactor/OuterSegments", 1535); + feb(1534, 1, {}, E_b); + sfb(KAe, "ComponentsCompactor/Segments", 1534); + feb(1282, 1, {}, I_b); + sfb(KAe, Lze, 1282); + feb(1283, 1, fye, K_b); + _2.Ne = function L_b(a, b) { + return J_b(RD(a, 36), RD(b, 36)); + }; + _2.Fb = function M_b(a) { + return this === a; + }; + _2.Oe = function N_b() { + return new Frb(this); + }; + sfb(KAe, "ComponentsProcessor/lambda$0$Type", 1283); + feb(579, 335, { 335: 1, 579: 1 }, S_b); + _2.Ff = function T_b(a) { + return Q_b(this, a); + }; + _2.Gf = function U_b(a) { + return R_b(this, a); + }; + var O_b; + sfb(KAe, "ModelOrderComponentGroup", 579); + feb(1310, 2104, {}, V_b); + _2.Ef = function W_b(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m; + if (a.gc() == 1) { + l = RD(a.Xb(0), 36); + if (l != b) { + b.a.c.length = 0; + u$b(b, l, 0, 0); + kQb(b, l); + C2b(b.d, l.d); + b.f.a = l.f.a; + b.f.b = l.f.b; + } + return; + } else if (a.dc()) { + b.a.c.length = 0; + b.f.a = 0; + b.f.b = 0; + return; + } + this.Jf(a, b); + e = RD(a.Xb(0), 36); + b.a.c.length = 0; + kQb(b, e); + j = 0; + m = 0; + for (g = a.Kc(); g.Ob(); ) { + f2 = RD(g.Pb(), 36); + k = f2.f; + j = $wnd.Math.max(j, k.a); + m += k.a * k.b; + } + j = $wnd.Math.max(j, $wnd.Math.sqrt(m) * Kfb(UD(mQb(b, (yCc(), Tzc))))); + d = Kfb(UD(mQb(b, SBc))); + this.If(a, b, j, d); + if (Heb(TD(mQb(e, Vzc)))) { + c2 = new j_b(); + _$b(c2, a, d); + for (i2 = a.Kc(); i2.Ob(); ) { + h = RD(i2.Pb(), 36); + $id(hjd(h.c), c2.e); + } + $id(hjd(b.f), c2.a); + } + v$b(b, a); + }; + _2.If = function X_b(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l; + k = 0; + l = 0; + h = 0; + e = d; + for (g = a.Kc(); g.Ob(); ) { + f2 = RD(g.Pb(), 36); + j = f2.f; + if (k + j.a > c2) { + k = 0; + l += h + d; + h = 0; + } + i2 = f2.c; + w$b(f2, k + i2.a, l + i2.b); + hjd(i2); + e = $wnd.Math.max(e, k + j.a); + h = $wnd.Math.max(h, j.b); + k += j.a + d; + } + b.f.a = e; + b.f.b = l + h; + }; + _2.Jf = function Y_b(a, b) { + var c2, d, e, f2, g; + if (dE(mQb(b, (yCc(), Yzc))) === dE((U$b(), T$b))) { + for (d = a.Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 36); + g = 0; + for (f2 = new Anb(c2.a); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 10); + g += RD(mQb(e, JBc), 17).a; + } + c2.p = g; + } + yob(); + a.jd(new b0b()); + } + }; + sfb(KAe, "SimpleRowGraphPlacer", 1310); + feb(1313, 1310, {}, Z_b); + _2.If = function $_b(a, b, c2, d) { + var e, f2, g, h, i2, j, k, l, m, n; + m = 0; + n = 0; + h = 0; + e = d; + i2 = null; + l = 0; + for (g = a.Kc(); g.Ob(); ) { + f2 = RD(g.Pb(), 36); + k = f2.f; + if (m + k.a > c2 && !RD(mQb(f2, (Ywc(), ewc)), 21).Hc((qpd(), Yod)) || !!i2 && RD(mQb(i2, (Ywc(), ewc)), 21).Hc((qpd(), Xod)) || RD(mQb(f2, (Ywc(), ewc)), 21).Hc((qpd(), ppd))) { + m = l; + n += h + d; + h = 0; + } + j = f2.c; + RD(mQb(f2, (Ywc(), ewc)), 21).Hc((qpd(), Yod)) && (m = e + d); + w$b(f2, m + j.a, n + j.b); + e = $wnd.Math.max(e, m + k.a); + RD(mQb(f2, ewc), 21).Hc(npd) && (l = $wnd.Math.max(l, m + k.a + d)); + hjd(j); + h = $wnd.Math.max(h, k.b); + m += k.a + d; + i2 = f2; + } + b.f.a = e; + b.f.b = n + h; + }; + _2.Jf = function __b(a, b) { + }; + sfb(KAe, "ModelOrderRowGraphPlacer", 1313); + feb(1311, 1, fye, b0b); + _2.Ne = function c0b(a, b) { + return a0b(RD(a, 36), RD(b, 36)); + }; + _2.Fb = function d0b(a) { + return this === a; + }; + _2.Oe = function e0b() { + return new Frb(this); + }; + sfb(KAe, "SimpleRowGraphPlacer/1", 1311); + var f0b; + feb(1280, 1, xye, l0b); + _2.Lb = function m0b(a) { + var b; + return b = RD(mQb(RD(a, 249).b, (yCc(), RAc)), 75), !!b && b.b != 0; + }; + _2.Fb = function n0b(a) { + return this === a; + }; + _2.Mb = function o0b(a) { + var b; + return b = RD(mQb(RD(a, 249).b, (yCc(), RAc)), 75), !!b && b.b != 0; + }; + sfb(PAe, "CompoundGraphPostprocessor/1", 1280); + feb(1279, 1, QAe, E0b); + _2.Kf = function F0b(a, b) { + y0b(this, RD(a, 36), b); + }; + sfb(PAe, "CompoundGraphPreprocessor", 1279); + feb(453, 1, { 453: 1 }, G0b); + _2.c = false; + sfb(PAe, "CompoundGraphPreprocessor/ExternalPort", 453); + feb(249, 1, { 249: 1 }, J0b); + _2.Ib = function K0b() { + return ps(this.c) + ":" + _0b(this.b); + }; + sfb(PAe, "CrossHierarchyEdge", 249); + feb(777, 1, fye, M0b); + _2.Ne = function N0b(a, b) { + return L0b(this, RD(a, 249), RD(b, 249)); + }; + _2.Fb = function O0b(a) { + return this === a; + }; + _2.Oe = function Q0b() { + return new Frb(this); + }; + sfb(PAe, "CrossHierarchyEdgeComparator", 777); + feb(305, 137, { 3: 1, 305: 1, 96: 1, 137: 1 }); + _2.p = 0; + sfb(RAe, "LGraphElement", 305); + feb(18, 305, { 3: 1, 18: 1, 305: 1, 96: 1, 137: 1 }, a1b); + _2.Ib = function b1b() { + return _0b(this); + }; + var WQ = sfb(RAe, "LEdge", 18); + feb(36, 305, { 3: 1, 20: 1, 36: 1, 305: 1, 96: 1, 137: 1 }, d1b); + _2.Jc = function e1b(a) { + xgb(this, a); + }; + _2.Kc = function f1b() { + return new Anb(this.b); + }; + _2.Ib = function g1b() { + if (this.b.c.length == 0) { + return "G-unlayered" + Fe(this.a); + } else if (this.a.c.length == 0) { + return "G-layered" + Fe(this.b); + } + return "G[layerless" + Fe(this.a) + ", layers" + Fe(this.b) + "]"; + }; + var eR = sfb(RAe, "LGraph", 36); + var h1b; + feb(666, 1, {}); + _2.Lf = function j1b() { + return this.e.n; + }; + _2.of = function k1b(a) { + return mQb(this.e, a); + }; + _2.Mf = function l1b() { + return this.e.o; + }; + _2.Nf = function m1b() { + return this.e.p; + }; + _2.pf = function n1b(a) { + return nQb(this.e, a); + }; + _2.Of = function o1b(a) { + this.e.n.a = a.a; + this.e.n.b = a.b; + }; + _2.Pf = function p1b(a) { + this.e.o.a = a.a; + this.e.o.b = a.b; + }; + _2.Qf = function q1b(a) { + this.e.p = a; + }; + sfb(RAe, "LGraphAdapters/AbstractLShapeAdapter", 666); + feb(474, 1, { 853: 1 }, r1b); + _2.Rf = function s1b() { + var a, b; + if (!this.b) { + this.b = ev(this.a.b.c.length); + for (b = new Anb(this.a.b); b.a < b.c.c.length; ) { + a = RD(ynb(b), 72); + Rmb(this.b, new D1b(a)); + } + } + return this.b; + }; + _2.b = null; + sfb(RAe, "LGraphAdapters/LEdgeAdapter", 474); + feb(665, 1, {}, t1b); + _2.Sf = function u1b() { + var a, b, c2, d, e, f2; + if (!this.b) { + this.b = new bnb(); + for (d = new Anb(this.a.b); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 30); + for (f2 = new Anb(c2.a); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 10); + if (this.c.Mb(e)) { + Rmb(this.b, new F1b(this, e, this.e)); + if (this.d) { + if (nQb(e, (Ywc(), Xwc))) { + for (b = RD(mQb(e, Xwc), 15).Kc(); b.Ob(); ) { + a = RD(b.Pb(), 10); + Rmb(this.b, new F1b(this, a, false)); + } + } + if (nQb(e, Vvc)) { + for (b = RD(mQb(e, Vvc), 15).Kc(); b.Ob(); ) { + a = RD(b.Pb(), 10); + Rmb(this.b, new F1b(this, a, false)); + } + } + } + } + } + } + } + return this.b; + }; + _2.Lf = function v1b() { + throw Adb(new kib(TAe)); + }; + _2.of = function w1b(a) { + return mQb(this.a, a); + }; + _2.Mf = function x1b() { + return this.a.f; + }; + _2.Nf = function y1b() { + return this.a.p; + }; + _2.pf = function z1b(a) { + return nQb(this.a, a); + }; + _2.Of = function A1b(a) { + throw Adb(new kib(TAe)); + }; + _2.Pf = function B1b(a) { + this.a.f.a = a.a; + this.a.f.b = a.b; + }; + _2.Qf = function C1b(a) { + this.a.p = a; + }; + _2.b = null; + _2.d = false; + _2.e = false; + sfb(RAe, "LGraphAdapters/LGraphAdapter", 665); + feb(585, 666, { 187: 1 }, D1b); + sfb(RAe, "LGraphAdapters/LLabelAdapter", 585); + feb(584, 666, { 695: 1 }, F1b); + _2.Tf = function G1b() { + return this.b; + }; + _2.Uf = function H1b() { + return yob(), yob(), vob; + }; + _2.Rf = function I1b() { + var a, b; + if (!this.a) { + this.a = ev(RD(this.e, 10).b.c.length); + for (b = new Anb(RD(this.e, 10).b); b.a < b.c.c.length; ) { + a = RD(ynb(b), 72); + Rmb(this.a, new D1b(a)); + } + } + return this.a; + }; + _2.Vf = function J1b() { + var a; + a = RD(this.e, 10).d; + return new R2b(a.d, a.c, a.a, a.b); + }; + _2.Wf = function K1b() { + return yob(), yob(), vob; + }; + _2.Xf = function L1b() { + var a, b; + if (!this.c) { + this.c = ev(RD(this.e, 10).j.c.length); + for (b = new Anb(RD(this.e, 10).j); b.a < b.c.c.length; ) { + a = RD(ynb(b), 12); + Rmb(this.c, new Q1b(a, this.d)); + } + } + return this.c; + }; + _2.Yf = function M1b() { + return Heb(TD(mQb(RD(this.e, 10), (Ywc(), Yvc)))); + }; + _2.Zf = function N1b(a) { + RD(this.e, 10).d.b = a.b; + RD(this.e, 10).d.d = a.d; + RD(this.e, 10).d.c = a.c; + RD(this.e, 10).d.a = a.a; + }; + _2.$f = function O1b(a) { + RD(this.e, 10).f.b = a.b; + RD(this.e, 10).f.d = a.d; + RD(this.e, 10).f.c = a.c; + RD(this.e, 10).f.a = a.a; + }; + _2._f = function P1b() { + E1b(this, (i1b(), h1b)); + }; + _2.a = null; + _2.b = null; + _2.c = null; + _2.d = false; + sfb(RAe, "LGraphAdapters/LNodeAdapter", 584); + feb(1788, 666, { 852: 1 }, Q1b); + _2.Uf = function R1b() { + var a, b, c2, d, e, f2, g, h; + if (this.d && RD(this.e, 12).i.k == (r3b(), q3b)) { + return yob(), yob(), vob; + } else if (!this.a) { + this.a = new bnb(); + for (c2 = new Anb(RD(this.e, 12).e); c2.a < c2.c.c.length; ) { + a = RD(ynb(c2), 18); + Rmb(this.a, new r1b(a)); + } + if (this.d) { + d = RD(mQb(RD(this.e, 12), (Ywc(), Iwc)), 10); + if (d) { + for (b = new is(Mr(Z2b(d).a.Kc(), new ir())); gs(b); ) { + a = RD(hs(b), 18); + Rmb(this.a, new r1b(a)); + } + } + } + if (nQb(RD(this.e, 12).i, (Ywc(), Pwc))) { + g = RD(mQb(RD(this.e, 12).i, Pwc), 337); + h = RD(cub(g.e, this.e), 113); + if (h) { + for (f2 = new Anb(h.b); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 340); + Rmb(this.a, new r1b(e.a)); + } + } + } + } + return this.a; + }; + _2.Rf = function S1b() { + var a, b; + if (!this.b) { + this.b = ev(RD(this.e, 12).f.c.length); + for (b = new Anb(RD(this.e, 12).f); b.a < b.c.c.length; ) { + a = RD(ynb(b), 72); + Rmb(this.b, new D1b(a)); + } + } + return this.b; + }; + _2.Wf = function T1b() { + var a, b, c2, d, e, f2, g, h; + if (this.d && RD(this.e, 12).i.k == (r3b(), q3b)) { + return yob(), yob(), vob; + } else if (!this.c) { + this.c = new bnb(); + for (c2 = new Anb(RD(this.e, 12).g); c2.a < c2.c.c.length; ) { + a = RD(ynb(c2), 18); + Rmb(this.c, new r1b(a)); + } + if (this.d) { + d = RD(mQb(RD(this.e, 12), (Ywc(), Iwc)), 10); + if (d) { + for (b = new is(Mr(a3b(d).a.Kc(), new ir())); gs(b); ) { + a = RD(hs(b), 18); + Rmb(this.c, new r1b(a)); + } + } + } + if (nQb(RD(this.e, 12).i, (Ywc(), Pwc))) { + g = RD(mQb(RD(this.e, 12).i, Pwc), 337); + h = RD(cub(g.e, this.e), 113); + if (h) { + for (f2 = new Anb(h.e); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 340); + Rmb(this.c, new r1b(e.a)); + } + } + } + } + return this.c; + }; + _2.ag = function U1b() { + return RD(this.e, 12).j; + }; + _2.bg = function V1b() { + return Heb(TD(mQb(RD(this.e, 12), (Ywc(), nwc)))); + }; + _2.a = null; + _2.b = null; + _2.c = null; + _2.d = false; + sfb(RAe, "LGraphAdapters/LPortAdapter", 1788); + feb(1789, 1, fye, X1b); + _2.Ne = function Y1b(a, b) { + return W1b(RD(a, 12), RD(b, 12)); + }; + _2.Fb = function Z1b(a) { + return this === a; + }; + _2.Oe = function $1b() { + return new Frb(this); + }; + sfb(RAe, "LGraphAdapters/PortComparator", 1789); + feb(818, 1, nwe, _1b); + _2.Mb = function a2b(a) { + return RD(a, 10), i1b(), true; + }; + sfb(RAe, "LGraphAdapters/lambda$0$Type", 818); + feb(404, 305, { 3: 1, 305: 1, 404: 1, 96: 1, 137: 1 }); + sfb(RAe, "LShape", 404); + feb(72, 404, { 3: 1, 305: 1, 72: 1, 404: 1, 96: 1, 137: 1 }, x2b, y2b); + _2.Ib = function z2b() { + var a; + a = w2b(this); + return a == null ? "label" : "l_" + a; + }; + sfb(RAe, "LLabel", 72); + feb(214, 1, { 3: 1, 4: 1, 214: 1, 423: 1 }); + _2.Fb = function K2b(a) { + var b; + if (ZD(a, 214)) { + b = RD(a, 214); + return this.d == b.d && this.a == b.a && this.b == b.b && this.c == b.c; + } else { + return false; + } + }; + _2.Hb = function L2b() { + var a, b; + a = Nfb(this.b) << 16; + a |= Nfb(this.a) & Bwe; + b = Nfb(this.c) << 16; + b |= Nfb(this.d) & Bwe; + return a ^ b; + }; + _2.cg = function N2b(b) { + var c2, d, e, f2, g, h, i2, j, k, l, m; + g = 0; + while (g < b.length && M2b((BFb(g, b.length), b.charCodeAt(g)), YAe)) { + ++g; + } + c2 = b.length; + while (c2 > 0 && M2b((BFb(c2 - 1, b.length), b.charCodeAt(c2 - 1)), ZAe)) { + --c2; + } + if (g < c2) { + l = vhb((AFb(g, c2, b.length), b.substr(g, c2 - g)), ",|;"); + try { + for (i2 = l, j = 0, k = i2.length; j < k; ++j) { + h = i2[j]; + f2 = vhb(h, "="); + if (f2.length != 2) { + throw Adb(new agb("Expecting a list of key-value pairs.")); + } + e = Dhb(f2[0]); + m = Neb(Dhb(f2[1])); + lhb(e, "top") ? this.d = m : lhb(e, "left") ? this.b = m : lhb(e, "bottom") ? this.a = m : lhb(e, "right") && (this.c = m); + } + } catch (a) { + a = zdb(a); + if (ZD(a, 130)) { + d = a; + throw Adb(new agb($Ae + d)); + } else + throw Adb(a); + } + } + }; + _2.Ib = function O2b() { + return "[top=" + this.d + ",left=" + this.b + ",bottom=" + this.a + ",right=" + this.c + "]"; + }; + _2.a = 0; + _2.b = 0; + _2.c = 0; + _2.d = 0; + sfb(_Ae, "Spacing", 214); + feb(140, 214, aBe, P2b, Q2b, R2b, S2b); + var h3 = sfb(_Ae, "ElkMargin", 140); + feb(660, 140, aBe, T2b); + sfb(RAe, "LMargin", 660); + feb(10, 404, { 3: 1, 305: 1, 10: 1, 404: 1, 96: 1, 137: 1 }, j3b); + _2.Ib = function k3b() { + return i3b(this); + }; + _2.i = false; + var jR = sfb(RAe, "LNode", 10); + feb(273, 22, { 3: 1, 34: 1, 22: 1, 273: 1 }, s3b); + var l3b, m3b, n3b, o3b, p3b, q3b; + var hR = tfb(RAe, "LNode/NodeType", 273, WI, u3b, t3b); + var v3b; + feb(775, 1, nwe, x3b); + _2.Mb = function y3b(a) { + return Heb(TD(mQb(RD(a, 72), (yCc(), vAc)))); + }; + sfb(RAe, "LNode/lambda$0$Type", 775); + feb(107, 214, bBe, z3b, A3b, B3b); + var i3 = sfb(_Ae, "ElkPadding", 107); + feb(778, 107, bBe, C3b); + sfb(RAe, "LPadding", 778); + feb(12, 404, { 3: 1, 305: 1, 12: 1, 404: 1, 96: 1, 137: 1 }, R3b); + _2.Ib = function S3b() { + var a, b, c2; + a = new bib(); + Zhb((a.a += "p_", a), M3b(this)); + !!this.i && Zhb(Yhb((a.a += "[", a), this.i), "]"); + if (this.e.c.length == 1 && this.g.c.length == 0 && RD(Vmb(this.e, 0), 18).c != this) { + b = RD(Vmb(this.e, 0), 18).c; + Zhb((a.a += " << ", a), M3b(b)); + Zhb(Yhb((a.a += "[", a), b.i), "]"); + } + if (this.e.c.length == 0 && this.g.c.length == 1 && RD(Vmb(this.g, 0), 18).d != this) { + c2 = RD(Vmb(this.g, 0), 18).d; + Zhb((a.a += " >> ", a), M3b(c2)); + Zhb(Yhb((a.a += "[", a), c2.i), "]"); + } + return a.a; + }; + _2.c = true; + _2.d = false; + var D3b, E3b, F3b, G3b, H3b, I3b; + var xR = sfb(RAe, "LPort", 12); + feb(408, 1, Vve, T3b); + _2.Jc = function U3b(a) { + xgb(this, a); + }; + _2.Kc = function V3b() { + var a; + a = new Anb(this.a.e); + return new W3b(a); + }; + sfb(RAe, "LPort/1", 408); + feb(1309, 1, Ave, W3b); + _2.Nb = function X3b(a) { + Ztb(this, a); + }; + _2.Pb = function Z3b() { + return RD(ynb(this.a), 18).c; + }; + _2.Ob = function Y3b() { + return xnb(this.a); + }; + _2.Qb = function $3b() { + znb(this.a); + }; + sfb(RAe, "LPort/1/1", 1309); + feb(369, 1, Vve, _3b); + _2.Jc = function a4b(a) { + xgb(this, a); + }; + _2.Kc = function b4b() { + var a; + return a = new Anb(this.a.g), new c4b(a); + }; + sfb(RAe, "LPort/2", 369); + feb(776, 1, Ave, c4b); + _2.Nb = function d4b(a) { + Ztb(this, a); + }; + _2.Pb = function f4b() { + return RD(ynb(this.a), 18).d; + }; + _2.Ob = function e4b() { + return xnb(this.a); + }; + _2.Qb = function g4b() { + znb(this.a); + }; + sfb(RAe, "LPort/2/1", 776); + feb(1302, 1, Vve, h4b); + _2.Jc = function i4b(a) { + xgb(this, a); + }; + _2.Kc = function j4b() { + return new l4b(this); + }; + sfb(RAe, "LPort/CombineIter", 1302); + feb(208, 1, Ave, l4b); + _2.Nb = function m4b(a) { + Ztb(this, a); + }; + _2.Qb = function p4b() { + $tb(); + }; + _2.Ob = function n4b() { + return k4b(this); + }; + _2.Pb = function o4b() { + return xnb(this.a) ? ynb(this.a) : ynb(this.b); + }; + sfb(RAe, "LPort/CombineIter/1", 208); + feb(1303, 1, xye, r4b); + _2.Lb = function s4b(a) { + return q4b(a); + }; + _2.Fb = function t4b(a) { + return this === a; + }; + _2.Mb = function u4b(a) { + return J3b(), RD(a, 12).g.c.length != 0; + }; + sfb(RAe, "LPort/lambda$0$Type", 1303); + feb(1304, 1, xye, w4b); + _2.Lb = function x4b(a) { + return v4b(a); + }; + _2.Fb = function y4b(a) { + return this === a; + }; + _2.Mb = function z4b(a) { + return J3b(), RD(a, 12).e.c.length != 0; + }; + sfb(RAe, "LPort/lambda$1$Type", 1304); + feb(1305, 1, xye, A4b); + _2.Lb = function B4b(a) { + return J3b(), RD(a, 12).j == (qpd(), Yod); + }; + _2.Fb = function C4b(a) { + return this === a; + }; + _2.Mb = function D4b(a) { + return J3b(), RD(a, 12).j == (qpd(), Yod); + }; + sfb(RAe, "LPort/lambda$2$Type", 1305); + feb(1306, 1, xye, E4b); + _2.Lb = function F4b(a) { + return J3b(), RD(a, 12).j == (qpd(), Xod); + }; + _2.Fb = function G4b(a) { + return this === a; + }; + _2.Mb = function H4b(a) { + return J3b(), RD(a, 12).j == (qpd(), Xod); + }; + sfb(RAe, "LPort/lambda$3$Type", 1306); + feb(1307, 1, xye, I4b); + _2.Lb = function J4b(a) { + return J3b(), RD(a, 12).j == (qpd(), npd); + }; + _2.Fb = function K4b(a) { + return this === a; + }; + _2.Mb = function L4b(a) { + return J3b(), RD(a, 12).j == (qpd(), npd); + }; + sfb(RAe, "LPort/lambda$4$Type", 1307); + feb(1308, 1, xye, M4b); + _2.Lb = function N4b(a) { + return J3b(), RD(a, 12).j == (qpd(), ppd); + }; + _2.Fb = function O4b(a) { + return this === a; + }; + _2.Mb = function P4b(a) { + return J3b(), RD(a, 12).j == (qpd(), ppd); + }; + sfb(RAe, "LPort/lambda$5$Type", 1308); + feb(30, 305, { 3: 1, 20: 1, 305: 1, 30: 1, 96: 1, 137: 1 }, R4b); + _2.Jc = function S4b(a) { + xgb(this, a); + }; + _2.Kc = function T4b() { + return new Anb(this.a); + }; + _2.Ib = function U4b() { + return "L_" + Wmb(this.b.b, this, 0) + Fe(this.a); + }; + sfb(RAe, "Layer", 30); + feb(1330, 1, {}, k5b); + sfb(cBe, dBe, 1330); + feb(1334, 1, {}, o5b); + _2.Kb = function p5b(a) { + return AGd(RD(a, 84)); + }; + sfb(cBe, "ElkGraphImporter/0methodref$connectableShapeToNode$Type", 1334); + feb(1337, 1, {}, q5b); + _2.Kb = function r5b(a) { + return AGd(RD(a, 84)); + }; + sfb(cBe, "ElkGraphImporter/1methodref$connectableShapeToNode$Type", 1337); + feb(1331, 1, Qve, s5b); + _2.Cd = function t5b(a) { + $4b(this.a, RD(a, 123)); + }; + sfb(cBe, Nze, 1331); + feb(1332, 1, Qve, u5b); + _2.Cd = function v5b(a) { + $4b(this.a, RD(a, 123)); + }; + sfb(cBe, eBe, 1332); + feb(1333, 1, {}, w5b); + _2.Kb = function x5b(a) { + return new SDb(null, new Swb(mzd(RD(a, 74)), 16)); + }; + sfb(cBe, fBe, 1333); + feb(1335, 1, nwe, y5b); + _2.Mb = function z5b(a) { + return l5b(this.a, RD(a, 27)); + }; + sfb(cBe, gBe, 1335); + feb(1336, 1, {}, A5b); + _2.Kb = function B5b(a) { + return new SDb(null, new Swb(lzd(RD(a, 74)), 16)); + }; + sfb(cBe, "ElkGraphImporter/lambda$5$Type", 1336); + feb(1338, 1, nwe, C5b); + _2.Mb = function D5b(a) { + return m5b(this.a, RD(a, 27)); + }; + sfb(cBe, "ElkGraphImporter/lambda$7$Type", 1338); + feb(1339, 1, nwe, E5b); + _2.Mb = function F5b(a) { + return n5b(RD(a, 74)); + }; + sfb(cBe, "ElkGraphImporter/lambda$8$Type", 1339); + feb(1297, 1, {}, N5b); + var G5b; + sfb(cBe, "ElkGraphLayoutTransferrer", 1297); + feb(1298, 1, nwe, Q5b); + _2.Mb = function R5b(a) { + return O5b(this.a, RD(a, 18)); + }; + sfb(cBe, "ElkGraphLayoutTransferrer/lambda$0$Type", 1298); + feb(1299, 1, Qve, S5b); + _2.Cd = function T5b(a) { + H5b(); + Rmb(this.a, RD(a, 18)); + }; + sfb(cBe, "ElkGraphLayoutTransferrer/lambda$1$Type", 1299); + feb(1300, 1, nwe, U5b); + _2.Mb = function V5b(a) { + return P5b(this.a, RD(a, 18)); + }; + sfb(cBe, "ElkGraphLayoutTransferrer/lambda$2$Type", 1300); + feb(1301, 1, Qve, W5b); + _2.Cd = function X5b(a) { + H5b(); + Rmb(this.a, RD(a, 18)); + }; + sfb(cBe, "ElkGraphLayoutTransferrer/lambda$3$Type", 1301); + feb(819, 1, {}, e6b); + sfb(hBe, "BiLinkedHashMultiMap", 819); + feb(1550, 1, QAe, h6b); + _2.Kf = function i6b(a, b) { + f6b(RD(a, 36), b); + }; + sfb(hBe, "CommentNodeMarginCalculator", 1550); + feb(1551, 1, {}, j6b); + _2.Kb = function k6b(a) { + return new SDb(null, new Swb(RD(a, 30).a, 16)); + }; + sfb(hBe, "CommentNodeMarginCalculator/lambda$0$Type", 1551); + feb(1552, 1, Qve, l6b); + _2.Cd = function m6b(a) { + g6b(RD(a, 10)); + }; + sfb(hBe, "CommentNodeMarginCalculator/lambda$1$Type", 1552); + feb(1553, 1, QAe, q6b); + _2.Kf = function r6b(a, b) { + o6b(RD(a, 36), b); + }; + sfb(hBe, "CommentPostprocessor", 1553); + feb(1554, 1, QAe, v6b); + _2.Kf = function w6b(a, b) { + s6b(RD(a, 36), b); + }; + sfb(hBe, "CommentPreprocessor", 1554); + feb(1555, 1, QAe, y6b); + _2.Kf = function z6b(a, b) { + x6b(RD(a, 36), b); + }; + sfb(hBe, "ConstraintsPostprocessor", 1555); + feb(1556, 1, QAe, G6b); + _2.Kf = function H6b(a, b) { + E6b(RD(a, 36), b); + }; + sfb(hBe, "EdgeAndLayerConstraintEdgeReverser", 1556); + feb(1557, 1, QAe, K6b); + _2.Kf = function M6b(a, b) { + I6b(RD(a, 36), b); + }; + sfb(hBe, "EndLabelPostprocessor", 1557); + feb(1558, 1, {}, N6b); + _2.Kb = function O6b(a) { + return new SDb(null, new Swb(RD(a, 30).a, 16)); + }; + sfb(hBe, "EndLabelPostprocessor/lambda$0$Type", 1558); + feb(1559, 1, nwe, P6b); + _2.Mb = function Q6b(a) { + return L6b(RD(a, 10)); + }; + sfb(hBe, "EndLabelPostprocessor/lambda$1$Type", 1559); + feb(1560, 1, Qve, R6b); + _2.Cd = function S6b(a) { + J6b(RD(a, 10)); + }; + sfb(hBe, "EndLabelPostprocessor/lambda$2$Type", 1560); + feb(1561, 1, QAe, b7b); + _2.Kf = function e7b(a, b) { + Z6b(RD(a, 36), b); + }; + sfb(hBe, "EndLabelPreprocessor", 1561); + feb(1562, 1, {}, f7b); + _2.Kb = function g7b(a) { + return new SDb(null, new Swb(RD(a, 30).a, 16)); + }; + sfb(hBe, "EndLabelPreprocessor/lambda$0$Type", 1562); + feb(1563, 1, Qve, h7b); + _2.Cd = function i7b(a) { + V6b(this.a, this.b, this.c, RD(a, 10)); + }; + _2.a = 0; + _2.b = 0; + _2.c = false; + sfb(hBe, "EndLabelPreprocessor/lambda$1$Type", 1563); + feb(1564, 1, nwe, j7b); + _2.Mb = function k7b(a) { + return dE(mQb(RD(a, 72), (yCc(), wAc))) === dE((Omd(), Nmd)); + }; + sfb(hBe, "EndLabelPreprocessor/lambda$2$Type", 1564); + feb(1565, 1, Qve, l7b); + _2.Cd = function m7b(a) { + Mub(this.a, RD(a, 72)); + }; + sfb(hBe, "EndLabelPreprocessor/lambda$3$Type", 1565); + feb(1566, 1, nwe, n7b); + _2.Mb = function o7b(a) { + return dE(mQb(RD(a, 72), (yCc(), wAc))) === dE((Omd(), Mmd)); + }; + sfb(hBe, "EndLabelPreprocessor/lambda$4$Type", 1566); + feb(1567, 1, Qve, p7b); + _2.Cd = function q7b(a) { + Mub(this.a, RD(a, 72)); + }; + sfb(hBe, "EndLabelPreprocessor/lambda$5$Type", 1567); + feb(1615, 1, QAe, z7b); + _2.Kf = function A7b(a, b) { + w7b(RD(a, 36), b); + }; + var r7b; + sfb(hBe, "EndLabelSorter", 1615); + feb(1616, 1, fye, C7b); + _2.Ne = function D7b(a, b) { + return B7b(RD(a, 466), RD(b, 466)); + }; + _2.Fb = function E7b(a) { + return this === a; + }; + _2.Oe = function F7b() { + return new Frb(this); + }; + sfb(hBe, "EndLabelSorter/1", 1616); + feb(466, 1, { 466: 1 }, G7b); + sfb(hBe, "EndLabelSorter/LabelGroup", 466); + feb(1617, 1, {}, H7b); + _2.Kb = function I7b(a) { + return s7b(), new SDb(null, new Swb(RD(a, 30).a, 16)); + }; + sfb(hBe, "EndLabelSorter/lambda$0$Type", 1617); + feb(1618, 1, nwe, J7b); + _2.Mb = function K7b(a) { + return s7b(), RD(a, 10).k == (r3b(), p3b); + }; + sfb(hBe, "EndLabelSorter/lambda$1$Type", 1618); + feb(1619, 1, Qve, L7b); + _2.Cd = function M7b(a) { + x7b(RD(a, 10)); + }; + sfb(hBe, "EndLabelSorter/lambda$2$Type", 1619); + feb(1620, 1, nwe, N7b); + _2.Mb = function O7b(a) { + return s7b(), dE(mQb(RD(a, 72), (yCc(), wAc))) === dE((Omd(), Mmd)); + }; + sfb(hBe, "EndLabelSorter/lambda$3$Type", 1620); + feb(1621, 1, nwe, P7b); + _2.Mb = function Q7b(a) { + return s7b(), dE(mQb(RD(a, 72), (yCc(), wAc))) === dE((Omd(), Nmd)); + }; + sfb(hBe, "EndLabelSorter/lambda$4$Type", 1621); + feb(1568, 1, QAe, a8b); + _2.Kf = function b8b(a, b) { + $7b(this, RD(a, 36)); + }; + _2.b = 0; + _2.c = 0; + sfb(hBe, "FinalSplineBendpointsCalculator", 1568); + feb(1569, 1, {}, c8b); + _2.Kb = function d8b(a) { + return new SDb(null, new Swb(RD(a, 30).a, 16)); + }; + sfb(hBe, "FinalSplineBendpointsCalculator/lambda$0$Type", 1569); + feb(1570, 1, {}, e8b); + _2.Kb = function f8b(a) { + return new SDb(null, new Twb(new is(Mr(a3b(RD(a, 10)).a.Kc(), new ir())))); + }; + sfb(hBe, "FinalSplineBendpointsCalculator/lambda$1$Type", 1570); + feb(1571, 1, nwe, g8b); + _2.Mb = function h8b(a) { + return !W0b(RD(a, 18)); + }; + sfb(hBe, "FinalSplineBendpointsCalculator/lambda$2$Type", 1571); + feb(1572, 1, nwe, i8b); + _2.Mb = function j8b(a) { + return nQb(RD(a, 18), (Ywc(), Twc)); + }; + sfb(hBe, "FinalSplineBendpointsCalculator/lambda$3$Type", 1572); + feb(1573, 1, Qve, k8b); + _2.Cd = function l8b(a) { + T7b(this.a, RD(a, 131)); + }; + sfb(hBe, "FinalSplineBendpointsCalculator/lambda$4$Type", 1573); + feb(1574, 1, Qve, m8b); + _2.Cd = function n8b(a) { + Eob(RD(a, 18).a); + }; + sfb(hBe, "FinalSplineBendpointsCalculator/lambda$5$Type", 1574); + feb(803, 1, QAe, L8b); + _2.Kf = function M8b(a, b) { + C8b(this, RD(a, 36), b); + }; + sfb(hBe, "GraphTransformer", 803); + feb(517, 22, { 3: 1, 34: 1, 22: 1, 517: 1 }, Q8b); + var N8b, O8b; + var vS = tfb(hBe, "GraphTransformer/Mode", 517, WI, S8b, R8b); + var T8b; + feb(1575, 1, QAe, Z8b); + _2.Kf = function $8b(a, b) { + W8b(RD(a, 36), b); + }; + sfb(hBe, "HierarchicalNodeResizingProcessor", 1575); + feb(1576, 1, QAe, f9b); + _2.Kf = function g9b(a, b) { + b9b(RD(a, 36), b); + }; + sfb(hBe, "HierarchicalPortConstraintProcessor", 1576); + feb(1577, 1, fye, i9b); + _2.Ne = function j9b(a, b) { + return h9b(RD(a, 10), RD(b, 10)); + }; + _2.Fb = function k9b(a) { + return this === a; + }; + _2.Oe = function l9b() { + return new Frb(this); + }; + sfb(hBe, "HierarchicalPortConstraintProcessor/NodeComparator", 1577); + feb(1578, 1, QAe, o9b); + _2.Kf = function p9b(a, b) { + m9b(RD(a, 36), b); + }; + sfb(hBe, "HierarchicalPortDummySizeProcessor", 1578); + feb(1579, 1, QAe, C9b); + _2.Kf = function D9b(a, b) { + v9b(this, RD(a, 36), b); + }; + _2.a = 0; + sfb(hBe, "HierarchicalPortOrthogonalEdgeRouter", 1579); + feb(1580, 1, fye, F9b); + _2.Ne = function G9b(a, b) { + return E9b(RD(a, 10), RD(b, 10)); + }; + _2.Fb = function H9b(a) { + return this === a; + }; + _2.Oe = function I9b() { + return new Frb(this); + }; + sfb(hBe, "HierarchicalPortOrthogonalEdgeRouter/1", 1580); + feb(1581, 1, fye, K9b); + _2.Ne = function L9b(a, b) { + return J9b(RD(a, 10), RD(b, 10)); + }; + _2.Fb = function M9b(a) { + return this === a; + }; + _2.Oe = function N9b() { + return new Frb(this); + }; + sfb(hBe, "HierarchicalPortOrthogonalEdgeRouter/2", 1581); + feb(1582, 1, QAe, Q9b); + _2.Kf = function R9b(a, b) { + P9b(RD(a, 36), b); + }; + sfb(hBe, "HierarchicalPortPositionProcessor", 1582); + feb(1583, 1, QAe, $9b); + _2.Kf = function _9b(a, b) { + Z9b(this, RD(a, 36)); + }; + _2.a = 0; + _2.c = 0; + var S9b, T9b; + sfb(hBe, "HighDegreeNodeLayeringProcessor", 1583); + feb(580, 1, { 580: 1 }, aac); + _2.b = -1; + _2.d = -1; + sfb(hBe, "HighDegreeNodeLayeringProcessor/HighDegreeNodeInformation", 580); + feb(1584, 1, {}, bac); + _2.Kb = function cac(a) { + return U9b(), Z2b(RD(a, 10)); + }; + _2.Fb = function dac(a) { + return this === a; + }; + sfb(hBe, "HighDegreeNodeLayeringProcessor/lambda$0$Type", 1584); + feb(1585, 1, {}, eac); + _2.Kb = function fac(a) { + return U9b(), a3b(RD(a, 10)); + }; + _2.Fb = function gac(a) { + return this === a; + }; + sfb(hBe, "HighDegreeNodeLayeringProcessor/lambda$1$Type", 1585); + feb(1591, 1, QAe, mac); + _2.Kf = function nac(a, b) { + lac(this, RD(a, 36), b); + }; + sfb(hBe, "HyperedgeDummyMerger", 1591); + feb(804, 1, {}, oac); + _2.a = false; + _2.b = false; + _2.c = false; + sfb(hBe, "HyperedgeDummyMerger/MergeState", 804); + feb(1592, 1, {}, pac); + _2.Kb = function qac(a) { + return new SDb(null, new Swb(RD(a, 30).a, 16)); + }; + sfb(hBe, "HyperedgeDummyMerger/lambda$0$Type", 1592); + feb(1593, 1, {}, rac); + _2.Kb = function sac(a) { + return new SDb(null, new Swb(RD(a, 10).j, 16)); + }; + sfb(hBe, "HyperedgeDummyMerger/lambda$1$Type", 1593); + feb(1594, 1, Qve, tac); + _2.Cd = function uac(a) { + RD(a, 12).p = -1; + }; + sfb(hBe, "HyperedgeDummyMerger/lambda$2$Type", 1594); + feb(1595, 1, QAe, xac); + _2.Kf = function yac(a, b) { + wac(RD(a, 36), b); + }; + sfb(hBe, "HypernodesProcessor", 1595); + feb(1596, 1, QAe, Aac); + _2.Kf = function Bac(a, b) { + zac(RD(a, 36), b); + }; + sfb(hBe, "InLayerConstraintProcessor", 1596); + feb(1597, 1, QAe, Dac); + _2.Kf = function Eac(a, b) { + Cac(RD(a, 36), b); + }; + sfb(hBe, "InnermostNodeMarginCalculator", 1597); + feb(1598, 1, QAe, Iac); + _2.Kf = function Nac(a, b) { + Hac(this, RD(a, 36)); + }; + _2.a = pxe; + _2.b = pxe; + _2.c = oxe; + _2.d = oxe; + var XS = sfb(hBe, "InteractiveExternalPortPositioner", 1598); + feb(1599, 1, {}, Oac); + _2.Kb = function Pac(a) { + return RD(a, 18).d.i; + }; + _2.Fb = function Qac(a) { + return this === a; + }; + sfb(hBe, "InteractiveExternalPortPositioner/lambda$0$Type", 1599); + feb(1600, 1, {}, Rac); + _2.Kb = function Sac(a) { + return Jac(this.a, UD(a)); + }; + _2.Fb = function Tac(a) { + return this === a; + }; + sfb(hBe, "InteractiveExternalPortPositioner/lambda$1$Type", 1600); + feb(1601, 1, {}, Uac); + _2.Kb = function Vac(a) { + return RD(a, 18).c.i; + }; + _2.Fb = function Wac(a) { + return this === a; + }; + sfb(hBe, "InteractiveExternalPortPositioner/lambda$2$Type", 1601); + feb(1602, 1, {}, Xac); + _2.Kb = function Yac(a) { + return Kac(this.a, UD(a)); + }; + _2.Fb = function Zac(a) { + return this === a; + }; + sfb(hBe, "InteractiveExternalPortPositioner/lambda$3$Type", 1602); + feb(1603, 1, {}, $ac); + _2.Kb = function _ac(a) { + return Lac(this.a, UD(a)); + }; + _2.Fb = function abc(a) { + return this === a; + }; + sfb(hBe, "InteractiveExternalPortPositioner/lambda$4$Type", 1603); + feb(1604, 1, {}, bbc); + _2.Kb = function cbc(a) { + return Mac(this.a, UD(a)); + }; + _2.Fb = function dbc(a) { + return this === a; + }; + sfb(hBe, "InteractiveExternalPortPositioner/lambda$5$Type", 1604); + feb(81, 22, { 3: 1, 34: 1, 22: 1, 81: 1, 196: 1 }, icc); + _2.dg = function jcc() { + switch (this.g) { + case 15: + return new Hrc(); + case 22: + return new bsc(); + case 47: + return new ksc(); + case 28: + case 35: + return new Ldc(); + case 32: + return new h6b(); + case 42: + return new q6b(); + case 1: + return new v6b(); + case 41: + return new y6b(); + case 56: + return new L8b((P8b(), O8b)); + case 0: + return new L8b((P8b(), N8b)); + case 2: + return new G6b(); + case 54: + return new K6b(); + case 33: + return new b7b(); + case 51: + return new a8b(); + case 55: + return new Z8b(); + case 13: + return new f9b(); + case 38: + return new o9b(); + case 44: + return new C9b(); + case 40: + return new Q9b(); + case 9: + return new $9b(); + case 49: + return new Yjc(); + case 37: + return new mac(); + case 43: + return new xac(); + case 27: + return new Aac(); + case 30: + return new Dac(); + case 3: + return new Iac(); + case 18: + return new scc(); + case 29: + return new ycc(); + case 5: + return new Lcc(); + case 50: + return new Ucc(); + case 34: + return new pdc(); + case 36: + return new Zdc(); + case 52: + return new z7b(); + case 11: + return new fec(); + case 7: + return new pec(); + case 39: + return new Dec(); + case 45: + return new Gec(); + case 16: + return new Kec(); + case 10: + return new _ec(); + case 48: + return new Bfc(); + case 21: + return new Ifc(); + case 23: + return new FKc((RKc(), PKc)); + case 8: + return new Rfc(); + case 12: + return new Zfc(); + case 4: + return new cgc(); + case 19: + return new xgc(); + case 17: + return new Vgc(); + case 53: + return new Ygc(); + case 6: + return new Nhc(); + case 25: + return new ahc(); + case 46: + return new rhc(); + case 31: + return new Yhc(); + case 14: + return new jic(); + case 26: + return new Ssc(); + case 20: + return new yic(); + case 24: + return new FKc((RKc(), QKc)); + default: + throw Adb(new agb(lBe + (this.f != null ? this.f : "" + this.g))); + } + }; + var ebc, fbc, gbc, hbc, ibc, jbc, kbc, lbc, mbc, nbc, obc, pbc, qbc, rbc, sbc, tbc, ubc, vbc, wbc, xbc, ybc, zbc, Abc, Bbc, Cbc, Dbc, Ebc, Fbc, Gbc, Hbc, Ibc, Jbc, Kbc, Lbc, Mbc, Nbc, Obc, Pbc, Qbc, Rbc, Sbc, Tbc, Ubc, Vbc, Wbc, Xbc, Ybc, Zbc, $bc, _bc, acc, bcc, ccc, dcc, ecc, fcc, gcc; + var YS = tfb(hBe, mBe, 81, WI, lcc, kcc); + var mcc; + feb(1605, 1, QAe, scc); + _2.Kf = function tcc(a, b) { + qcc(RD(a, 36), b); + }; + sfb(hBe, "InvertedPortProcessor", 1605); + feb(1606, 1, QAe, ycc); + _2.Kf = function zcc(a, b) { + xcc(RD(a, 36), b); + }; + sfb(hBe, "LabelAndNodeSizeProcessor", 1606); + feb(1607, 1, nwe, Acc); + _2.Mb = function Bcc(a) { + return RD(a, 10).k == (r3b(), p3b); + }; + sfb(hBe, "LabelAndNodeSizeProcessor/lambda$0$Type", 1607); + feb(1608, 1, nwe, Ccc); + _2.Mb = function Dcc(a) { + return RD(a, 10).k == (r3b(), m3b); + }; + sfb(hBe, "LabelAndNodeSizeProcessor/lambda$1$Type", 1608); + feb(1609, 1, Qve, Ecc); + _2.Cd = function Fcc(a) { + vcc(this.b, this.a, this.c, RD(a, 10)); + }; + _2.a = false; + _2.c = false; + sfb(hBe, "LabelAndNodeSizeProcessor/lambda$2$Type", 1609); + feb(1610, 1, QAe, Lcc); + _2.Kf = function Mcc(a, b) { + Jcc(RD(a, 36), b); + }; + var Gcc; + sfb(hBe, "LabelDummyInserter", 1610); + feb(1611, 1, xye, Ncc); + _2.Lb = function Occ(a) { + return dE(mQb(RD(a, 72), (yCc(), wAc))) === dE((Omd(), Lmd)); + }; + _2.Fb = function Pcc(a) { + return this === a; + }; + _2.Mb = function Qcc(a) { + return dE(mQb(RD(a, 72), (yCc(), wAc))) === dE((Omd(), Lmd)); + }; + sfb(hBe, "LabelDummyInserter/1", 1611); + feb(1612, 1, QAe, Ucc); + _2.Kf = function Vcc(a, b) { + Tcc(RD(a, 36), b); + }; + sfb(hBe, "LabelDummyRemover", 1612); + feb(1613, 1, nwe, Wcc); + _2.Mb = function Xcc(a) { + return Heb(TD(mQb(RD(a, 72), (yCc(), vAc)))); + }; + sfb(hBe, "LabelDummyRemover/lambda$0$Type", 1613); + feb(1378, 1, QAe, pdc); + _2.Kf = function tdc(a, b) { + ldc(this, RD(a, 36), b); + }; + _2.a = null; + var Ycc; + sfb(hBe, "LabelDummySwitcher", 1378); + feb(293, 1, { 293: 1 }, xdc); + _2.c = 0; + _2.d = null; + _2.f = 0; + sfb(hBe, "LabelDummySwitcher/LabelDummyInfo", 293); + feb(1379, 1, {}, ydc); + _2.Kb = function zdc(a) { + return Zcc(), new SDb(null, new Swb(RD(a, 30).a, 16)); + }; + sfb(hBe, "LabelDummySwitcher/lambda$0$Type", 1379); + feb(1380, 1, nwe, Adc); + _2.Mb = function Bdc(a) { + return Zcc(), RD(a, 10).k == (r3b(), n3b); + }; + sfb(hBe, "LabelDummySwitcher/lambda$1$Type", 1380); + feb(1381, 1, {}, Cdc); + _2.Kb = function Ddc(a) { + return qdc(this.a, RD(a, 10)); + }; + sfb(hBe, "LabelDummySwitcher/lambda$2$Type", 1381); + feb(1382, 1, Qve, Edc); + _2.Cd = function Fdc(a) { + rdc(this.a, RD(a, 293)); + }; + sfb(hBe, "LabelDummySwitcher/lambda$3$Type", 1382); + feb(1383, 1, fye, Gdc); + _2.Ne = function Hdc(a, b) { + return sdc(RD(a, 293), RD(b, 293)); + }; + _2.Fb = function Idc(a) { + return this === a; + }; + _2.Oe = function Jdc() { + return new Frb(this); + }; + sfb(hBe, "LabelDummySwitcher/lambda$4$Type", 1383); + feb(802, 1, QAe, Ldc); + _2.Kf = function Mdc(a, b) { + Kdc(RD(a, 36), b); + }; + sfb(hBe, "LabelManagementProcessor", 802); + feb(1614, 1, QAe, Zdc); + _2.Kf = function $dc(a, b) { + Tdc(RD(a, 36), b); + }; + sfb(hBe, "LabelSideSelector", 1614); + feb(1622, 1, QAe, fec); + _2.Kf = function gec(a, b) { + bec(RD(a, 36), b); + }; + sfb(hBe, "LayerConstraintPostprocessor", 1622); + feb(1623, 1, QAe, pec); + _2.Kf = function qec(a, b) { + nec(RD(a, 36), b); + }; + var hec; + sfb(hBe, "LayerConstraintPreprocessor", 1623); + feb(371, 22, { 3: 1, 34: 1, 22: 1, 371: 1 }, xec); + var rec, sec, tec, uec; + var qT = tfb(hBe, "LayerConstraintPreprocessor/HiddenNodeConnections", 371, WI, zec, yec); + var Aec; + feb(1624, 1, QAe, Dec); + _2.Kf = function Eec(a, b) { + Cec(RD(a, 36), b); + }; + sfb(hBe, "LayerSizeAndGraphHeightCalculator", 1624); + feb(1625, 1, QAe, Gec); + _2.Kf = function Iec(a, b) { + Fec(RD(a, 36), b); + }; + sfb(hBe, "LongEdgeJoiner", 1625); + feb(1626, 1, QAe, Kec); + _2.Kf = function Mec(a, b) { + Jec(RD(a, 36), b); + }; + sfb(hBe, "LongEdgeSplitter", 1626); + feb(1627, 1, QAe, _ec); + _2.Kf = function cfc(a, b) { + Vec(this, RD(a, 36), b); + }; + _2.e = 0; + _2.f = 0; + _2.j = 0; + _2.k = 0; + _2.n = 0; + _2.o = 0; + var Pec, Qec; + sfb(hBe, "NodePromotion", 1627); + feb(1628, 1, fye, efc); + _2.Ne = function ffc(a, b) { + return dfc(RD(a, 10), RD(b, 10)); + }; + _2.Fb = function gfc(a) { + return this === a; + }; + _2.Oe = function hfc() { + return new Frb(this); + }; + sfb(hBe, "NodePromotion/1", 1628); + feb(1629, 1, fye, jfc); + _2.Ne = function kfc(a, b) { + return ifc(RD(a, 10), RD(b, 10)); + }; + _2.Fb = function lfc(a) { + return this === a; + }; + _2.Oe = function mfc() { + return new Frb(this); + }; + sfb(hBe, "NodePromotion/2", 1629); + feb(1630, 1, {}, nfc); + _2.Kb = function ofc(a) { + return RD(a, 42), Rec(), Geb(), true; + }; + _2.Fb = function pfc(a) { + return this === a; + }; + sfb(hBe, "NodePromotion/lambda$0$Type", 1630); + feb(1631, 1, {}, qfc); + _2.Kb = function rfc(a) { + return afc(this.a, RD(a, 42)); + }; + _2.Fb = function sfc(a) { + return this === a; + }; + _2.a = 0; + sfb(hBe, "NodePromotion/lambda$1$Type", 1631); + feb(1632, 1, {}, tfc); + _2.Kb = function ufc(a) { + return bfc(this.a, RD(a, 42)); + }; + _2.Fb = function vfc(a) { + return this === a; + }; + _2.a = 0; + sfb(hBe, "NodePromotion/lambda$2$Type", 1632); + feb(1633, 1, QAe, Bfc); + _2.Kf = function Cfc(a, b) { + wfc(RD(a, 36), b); + }; + sfb(hBe, "NorthSouthPortPostprocessor", 1633); + feb(1634, 1, QAe, Ifc); + _2.Kf = function Kfc(a, b) { + Gfc(RD(a, 36), b); + }; + sfb(hBe, "NorthSouthPortPreprocessor", 1634); + feb(1635, 1, fye, Lfc); + _2.Ne = function Mfc(a, b) { + return Jfc(RD(a, 12), RD(b, 12)); + }; + _2.Fb = function Nfc(a) { + return this === a; + }; + _2.Oe = function Ofc() { + return new Frb(this); + }; + sfb(hBe, "NorthSouthPortPreprocessor/lambda$0$Type", 1635); + feb(1636, 1, QAe, Rfc); + _2.Kf = function Tfc(a, b) { + Qfc(RD(a, 36), b); + }; + sfb(hBe, "PartitionMidprocessor", 1636); + feb(1637, 1, nwe, Ufc); + _2.Mb = function Vfc(a) { + return nQb(RD(a, 10), (yCc(), tBc)); + }; + sfb(hBe, "PartitionMidprocessor/lambda$0$Type", 1637); + feb(1638, 1, Qve, Wfc); + _2.Cd = function Xfc(a) { + Sfc(this.a, RD(a, 10)); + }; + sfb(hBe, "PartitionMidprocessor/lambda$1$Type", 1638); + feb(1639, 1, QAe, Zfc); + _2.Kf = function $fc(a, b) { + Yfc(RD(a, 36), b); + }; + sfb(hBe, "PartitionPostprocessor", 1639); + feb(1640, 1, QAe, cgc); + _2.Kf = function dgc(a, b) { + agc(RD(a, 36), b); + }; + sfb(hBe, "PartitionPreprocessor", 1640); + feb(1641, 1, nwe, egc); + _2.Mb = function fgc(a) { + return nQb(RD(a, 10), (yCc(), tBc)); + }; + sfb(hBe, "PartitionPreprocessor/lambda$0$Type", 1641); + feb(1642, 1, {}, ggc); + _2.Kb = function hgc(a) { + return new SDb(null, new Twb(new is(Mr(a3b(RD(a, 10)).a.Kc(), new ir())))); + }; + sfb(hBe, "PartitionPreprocessor/lambda$1$Type", 1642); + feb(1643, 1, nwe, igc); + _2.Mb = function jgc(a) { + return _fc(RD(a, 18)); + }; + sfb(hBe, "PartitionPreprocessor/lambda$2$Type", 1643); + feb(1644, 1, Qve, kgc); + _2.Cd = function lgc(a) { + bgc(RD(a, 18)); + }; + sfb(hBe, "PartitionPreprocessor/lambda$3$Type", 1644); + feb(1645, 1, QAe, xgc); + _2.Kf = function Bgc(a, b) { + ugc(RD(a, 36), b); + }; + var mgc, ngc, ogc, pgc, qgc, rgc; + sfb(hBe, "PortListSorter", 1645); + feb(1648, 1, fye, Dgc); + _2.Ne = function Egc(a, b) { + return ygc(RD(a, 12), RD(b, 12)); + }; + _2.Fb = function Fgc(a) { + return this === a; + }; + _2.Oe = function Ggc() { + return new Frb(this); + }; + sfb(hBe, "PortListSorter/lambda$0$Type", 1648); + feb(1650, 1, fye, Hgc); + _2.Ne = function Igc(a, b) { + return zgc(RD(a, 12), RD(b, 12)); + }; + _2.Fb = function Jgc(a) { + return this === a; + }; + _2.Oe = function Kgc() { + return new Frb(this); + }; + sfb(hBe, "PortListSorter/lambda$1$Type", 1650); + feb(1646, 1, {}, Lgc); + _2.Kb = function Mgc(a) { + return sgc(), RD(a, 12).e; + }; + sfb(hBe, "PortListSorter/lambda$2$Type", 1646); + feb(1647, 1, {}, Ngc); + _2.Kb = function Ogc(a) { + return sgc(), RD(a, 12).g; + }; + sfb(hBe, "PortListSorter/lambda$3$Type", 1647); + feb(1649, 1, fye, Pgc); + _2.Ne = function Qgc(a, b) { + return Agc(RD(a, 12), RD(b, 12)); + }; + _2.Fb = function Rgc(a) { + return this === a; + }; + _2.Oe = function Sgc() { + return new Frb(this); + }; + sfb(hBe, "PortListSorter/lambda$4$Type", 1649); + feb(1651, 1, QAe, Vgc); + _2.Kf = function Wgc(a, b) { + Tgc(RD(a, 36), b); + }; + sfb(hBe, "PortSideProcessor", 1651); + feb(1652, 1, QAe, Ygc); + _2.Kf = function Zgc(a, b) { + Xgc(RD(a, 36), b); + }; + sfb(hBe, "ReversedEdgeRestorer", 1652); + feb(1657, 1, QAe, ahc); + _2.Kf = function bhc(a, b) { + $gc(this, RD(a, 36), b); + }; + sfb(hBe, "SelfLoopPortRestorer", 1657); + feb(1658, 1, {}, chc); + _2.Kb = function dhc(a) { + return new SDb(null, new Swb(RD(a, 30).a, 16)); + }; + sfb(hBe, "SelfLoopPortRestorer/lambda$0$Type", 1658); + feb(1659, 1, nwe, ehc); + _2.Mb = function fhc(a) { + return RD(a, 10).k == (r3b(), p3b); + }; + sfb(hBe, "SelfLoopPortRestorer/lambda$1$Type", 1659); + feb(1660, 1, nwe, ghc); + _2.Mb = function hhc(a) { + return nQb(RD(a, 10), (Ywc(), Pwc)); + }; + sfb(hBe, "SelfLoopPortRestorer/lambda$2$Type", 1660); + feb(1661, 1, {}, ihc); + _2.Kb = function jhc(a) { + return RD(mQb(RD(a, 10), (Ywc(), Pwc)), 337); + }; + sfb(hBe, "SelfLoopPortRestorer/lambda$3$Type", 1661); + feb(1662, 1, Qve, khc); + _2.Cd = function lhc(a) { + _gc(this.a, RD(a, 337)); + }; + sfb(hBe, "SelfLoopPortRestorer/lambda$4$Type", 1662); + feb(805, 1, Qve, mhc); + _2.Cd = function nhc(a) { + Rmc(RD(a, 105)); + }; + sfb(hBe, "SelfLoopPortRestorer/lambda$5$Type", 805); + feb(1663, 1, QAe, rhc); + _2.Kf = function thc(a, b) { + ohc(RD(a, 36), b); + }; + sfb(hBe, "SelfLoopPostProcessor", 1663); + feb(1664, 1, {}, uhc); + _2.Kb = function vhc(a) { + return new SDb(null, new Swb(RD(a, 30).a, 16)); + }; + sfb(hBe, "SelfLoopPostProcessor/lambda$0$Type", 1664); + feb(1665, 1, nwe, whc); + _2.Mb = function xhc(a) { + return RD(a, 10).k == (r3b(), p3b); + }; + sfb(hBe, "SelfLoopPostProcessor/lambda$1$Type", 1665); + feb(1666, 1, nwe, yhc); + _2.Mb = function zhc(a) { + return nQb(RD(a, 10), (Ywc(), Pwc)); + }; + sfb(hBe, "SelfLoopPostProcessor/lambda$2$Type", 1666); + feb(1667, 1, Qve, Ahc); + _2.Cd = function Bhc(a) { + phc(RD(a, 10)); + }; + sfb(hBe, "SelfLoopPostProcessor/lambda$3$Type", 1667); + feb(1668, 1, {}, Chc); + _2.Kb = function Dhc(a) { + return new SDb(null, new Swb(RD(a, 105).f, 1)); + }; + sfb(hBe, "SelfLoopPostProcessor/lambda$4$Type", 1668); + feb(1669, 1, Qve, Ehc); + _2.Cd = function Fhc(a) { + qhc(this.a, RD(a, 340)); + }; + sfb(hBe, "SelfLoopPostProcessor/lambda$5$Type", 1669); + feb(1670, 1, nwe, Ghc); + _2.Mb = function Hhc(a) { + return !!RD(a, 105).i; + }; + sfb(hBe, "SelfLoopPostProcessor/lambda$6$Type", 1670); + feb(1671, 1, Qve, Ihc); + _2.Cd = function Jhc(a) { + shc(this.a, RD(a, 105)); + }; + sfb(hBe, "SelfLoopPostProcessor/lambda$7$Type", 1671); + feb(1653, 1, QAe, Nhc); + _2.Kf = function Ohc(a, b) { + Mhc(RD(a, 36), b); + }; + sfb(hBe, "SelfLoopPreProcessor", 1653); + feb(1654, 1, {}, Phc); + _2.Kb = function Qhc(a) { + return new SDb(null, new Swb(RD(a, 105).f, 1)); + }; + sfb(hBe, "SelfLoopPreProcessor/lambda$0$Type", 1654); + feb(1655, 1, {}, Rhc); + _2.Kb = function Shc(a) { + return RD(a, 340).a; + }; + sfb(hBe, "SelfLoopPreProcessor/lambda$1$Type", 1655); + feb(1656, 1, Qve, Thc); + _2.Cd = function Uhc(a) { + Lhc(RD(a, 18)); + }; + sfb(hBe, "SelfLoopPreProcessor/lambda$2$Type", 1656); + feb(1672, 1, QAe, Yhc); + _2.Kf = function Zhc(a, b) { + Whc(this, RD(a, 36), b); + }; + sfb(hBe, "SelfLoopRouter", 1672); + feb(1673, 1, {}, $hc); + _2.Kb = function _hc(a) { + return new SDb(null, new Swb(RD(a, 30).a, 16)); + }; + sfb(hBe, "SelfLoopRouter/lambda$0$Type", 1673); + feb(1674, 1, nwe, aic); + _2.Mb = function bic(a) { + return RD(a, 10).k == (r3b(), p3b); + }; + sfb(hBe, "SelfLoopRouter/lambda$1$Type", 1674); + feb(1675, 1, nwe, cic); + _2.Mb = function dic(a) { + return nQb(RD(a, 10), (Ywc(), Pwc)); + }; + sfb(hBe, "SelfLoopRouter/lambda$2$Type", 1675); + feb(1676, 1, {}, eic); + _2.Kb = function fic(a) { + return RD(mQb(RD(a, 10), (Ywc(), Pwc)), 337); + }; + sfb(hBe, "SelfLoopRouter/lambda$3$Type", 1676); + feb(1677, 1, Qve, gic); + _2.Cd = function hic(a) { + Vhc(this.a, this.b, RD(a, 337)); + }; + sfb(hBe, "SelfLoopRouter/lambda$4$Type", 1677); + feb(1678, 1, QAe, jic); + _2.Kf = function mic(a, b) { + iic(RD(a, 36), b); + }; + sfb(hBe, "SemiInteractiveCrossMinProcessor", 1678); + feb(1679, 1, nwe, nic); + _2.Mb = function oic(a) { + return RD(a, 10).k == (r3b(), p3b); + }; + sfb(hBe, "SemiInteractiveCrossMinProcessor/lambda$0$Type", 1679); + feb(1680, 1, nwe, pic); + _2.Mb = function qic(a) { + return lQb(RD(a, 10))._b((yCc(), IBc)); + }; + sfb(hBe, "SemiInteractiveCrossMinProcessor/lambda$1$Type", 1680); + feb(1681, 1, fye, ric); + _2.Ne = function sic(a, b) { + return kic(RD(a, 10), RD(b, 10)); + }; + _2.Fb = function tic(a) { + return this === a; + }; + _2.Oe = function uic() { + return new Frb(this); + }; + sfb(hBe, "SemiInteractiveCrossMinProcessor/lambda$2$Type", 1681); + feb(1682, 1, {}, vic); + _2.Ve = function wic(a, b) { + return lic(RD(a, 10), RD(b, 10)); + }; + sfb(hBe, "SemiInteractiveCrossMinProcessor/lambda$3$Type", 1682); + feb(1684, 1, QAe, yic); + _2.Kf = function Cic(a, b) { + xic(RD(a, 36), b); + }; + sfb(hBe, "SortByInputModelProcessor", 1684); + feb(1685, 1, nwe, Dic); + _2.Mb = function Eic(a) { + return RD(a, 12).g.c.length != 0; + }; + sfb(hBe, "SortByInputModelProcessor/lambda$0$Type", 1685); + feb(1686, 1, Qve, Fic); + _2.Cd = function Gic(a) { + Aic(this.a, RD(a, 12)); + }; + sfb(hBe, "SortByInputModelProcessor/lambda$1$Type", 1686); + feb(1759, 817, {}, Pic); + _2.df = function Qic(a) { + var b, c2, d, e; + this.c = a; + switch (this.a.g) { + case 2: + b = new bnb(); + FDb(CDb(new SDb(null, new Swb(this.c.a.b, 16)), new Rjc()), new Tjc(this, b)); + eHb(this, new Zic()); + Umb(b, new bjc()); + b.c.length = 0; + FDb(CDb(new SDb(null, new Swb(this.c.a.b, 16)), new djc()), new fjc(b)); + eHb(this, new jjc()); + Umb(b, new njc()); + b.c.length = 0; + c2 = Wvb(TCb(HDb(new SDb(null, new Swb(this.c.a.b, 16)), new pjc(this))), new rjc()); + FDb(new SDb(null, new Swb(this.c.a.a, 16)), new vjc(c2, b)); + eHb(this, new zjc()); + Umb(b, new Djc()); + b.c.length = 0; + break; + case 3: + d = new bnb(); + eHb(this, new Ric()); + e = Wvb(TCb(HDb(new SDb(null, new Swb(this.c.a.b, 16)), new Vic(this))), new tjc()); + FDb(CDb(new SDb(null, new Swb(this.c.a.b, 16)), new Fjc()), new Hjc(e, d)); + eHb(this, new Ljc()); + Umb(d, new Pjc()); + d.c.length = 0; + break; + default: + throw Adb(new Ied()); + } + }; + _2.b = 0; + sfb(rBe, "EdgeAwareScanlineConstraintCalculation", 1759); + feb(1760, 1, xye, Ric); + _2.Lb = function Sic(a) { + return ZD(RD(a, 60).g, 154); + }; + _2.Fb = function Tic(a) { + return this === a; + }; + _2.Mb = function Uic(a) { + return ZD(RD(a, 60).g, 154); + }; + sfb(rBe, "EdgeAwareScanlineConstraintCalculation/lambda$0$Type", 1760); + feb(1761, 1, {}, Vic); + _2.Ye = function Wic(a) { + return Jic(this.a, RD(a, 60)); + }; + sfb(rBe, "EdgeAwareScanlineConstraintCalculation/lambda$1$Type", 1761); + feb(1769, 1, owe, Xic); + _2.de = function Yic() { + Iic(this.a, this.b, -1); + }; + _2.b = 0; + sfb(rBe, "EdgeAwareScanlineConstraintCalculation/lambda$10$Type", 1769); + feb(1771, 1, xye, Zic); + _2.Lb = function $ic(a) { + return ZD(RD(a, 60).g, 154); + }; + _2.Fb = function _ic(a) { + return this === a; + }; + _2.Mb = function ajc(a) { + return ZD(RD(a, 60).g, 154); + }; + sfb(rBe, "EdgeAwareScanlineConstraintCalculation/lambda$11$Type", 1771); + feb(1772, 1, Qve, bjc); + _2.Cd = function cjc(a) { + RD(a, 380).de(); + }; + sfb(rBe, "EdgeAwareScanlineConstraintCalculation/lambda$12$Type", 1772); + feb(1773, 1, nwe, djc); + _2.Mb = function ejc(a) { + return ZD(RD(a, 60).g, 10); + }; + sfb(rBe, "EdgeAwareScanlineConstraintCalculation/lambda$13$Type", 1773); + feb(1775, 1, Qve, fjc); + _2.Cd = function gjc(a) { + Kic(this.a, RD(a, 60)); + }; + sfb(rBe, "EdgeAwareScanlineConstraintCalculation/lambda$14$Type", 1775); + feb(1774, 1, owe, hjc); + _2.de = function ijc() { + Iic(this.b, this.a, -1); + }; + _2.a = 0; + sfb(rBe, "EdgeAwareScanlineConstraintCalculation/lambda$15$Type", 1774); + feb(1776, 1, xye, jjc); + _2.Lb = function kjc(a) { + return ZD(RD(a, 60).g, 10); + }; + _2.Fb = function ljc(a) { + return this === a; + }; + _2.Mb = function mjc(a) { + return ZD(RD(a, 60).g, 10); + }; + sfb(rBe, "EdgeAwareScanlineConstraintCalculation/lambda$16$Type", 1776); + feb(1777, 1, Qve, njc); + _2.Cd = function ojc(a) { + RD(a, 380).de(); + }; + sfb(rBe, "EdgeAwareScanlineConstraintCalculation/lambda$17$Type", 1777); + feb(1778, 1, {}, pjc); + _2.Ye = function qjc(a) { + return Lic(this.a, RD(a, 60)); + }; + sfb(rBe, "EdgeAwareScanlineConstraintCalculation/lambda$18$Type", 1778); + feb(1779, 1, {}, rjc); + _2.We = function sjc() { + return 0; + }; + sfb(rBe, "EdgeAwareScanlineConstraintCalculation/lambda$19$Type", 1779); + feb(1762, 1, {}, tjc); + _2.We = function ujc() { + return 0; + }; + sfb(rBe, "EdgeAwareScanlineConstraintCalculation/lambda$2$Type", 1762); + feb(1781, 1, Qve, vjc); + _2.Cd = function wjc(a) { + Mic(this.a, this.b, RD(a, 316)); + }; + _2.a = 0; + sfb(rBe, "EdgeAwareScanlineConstraintCalculation/lambda$20$Type", 1781); + feb(1780, 1, owe, xjc); + _2.de = function yjc() { + Hic(this.a, this.b, -1); + }; + _2.b = 0; + sfb(rBe, "EdgeAwareScanlineConstraintCalculation/lambda$21$Type", 1780); + feb(1782, 1, xye, zjc); + _2.Lb = function Ajc(a) { + return RD(a, 60), true; + }; + _2.Fb = function Bjc(a) { + return this === a; + }; + _2.Mb = function Cjc(a) { + return RD(a, 60), true; + }; + sfb(rBe, "EdgeAwareScanlineConstraintCalculation/lambda$22$Type", 1782); + feb(1783, 1, Qve, Djc); + _2.Cd = function Ejc(a) { + RD(a, 380).de(); + }; + sfb(rBe, "EdgeAwareScanlineConstraintCalculation/lambda$23$Type", 1783); + feb(1763, 1, nwe, Fjc); + _2.Mb = function Gjc(a) { + return ZD(RD(a, 60).g, 10); + }; + sfb(rBe, "EdgeAwareScanlineConstraintCalculation/lambda$3$Type", 1763); + feb(1765, 1, Qve, Hjc); + _2.Cd = function Ijc(a) { + Nic(this.a, this.b, RD(a, 60)); + }; + _2.a = 0; + sfb(rBe, "EdgeAwareScanlineConstraintCalculation/lambda$4$Type", 1765); + feb(1764, 1, owe, Jjc); + _2.de = function Kjc() { + Iic(this.b, this.a, -1); + }; + _2.a = 0; + sfb(rBe, "EdgeAwareScanlineConstraintCalculation/lambda$5$Type", 1764); + feb(1766, 1, xye, Ljc); + _2.Lb = function Mjc(a) { + return RD(a, 60), true; + }; + _2.Fb = function Njc(a) { + return this === a; + }; + _2.Mb = function Ojc(a) { + return RD(a, 60), true; + }; + sfb(rBe, "EdgeAwareScanlineConstraintCalculation/lambda$6$Type", 1766); + feb(1767, 1, Qve, Pjc); + _2.Cd = function Qjc(a) { + RD(a, 380).de(); + }; + sfb(rBe, "EdgeAwareScanlineConstraintCalculation/lambda$7$Type", 1767); + feb(1768, 1, nwe, Rjc); + _2.Mb = function Sjc(a) { + return ZD(RD(a, 60).g, 154); + }; + sfb(rBe, "EdgeAwareScanlineConstraintCalculation/lambda$8$Type", 1768); + feb(1770, 1, Qve, Tjc); + _2.Cd = function Ujc(a) { + Oic(this.a, this.b, RD(a, 60)); + }; + sfb(rBe, "EdgeAwareScanlineConstraintCalculation/lambda$9$Type", 1770); + feb(1586, 1, QAe, Yjc); + _2.Kf = function bkc(a, b) { + Xjc(this, RD(a, 36), b); + }; + var Vjc; + sfb(rBe, "HorizontalGraphCompactor", 1586); + feb(1587, 1, {}, ckc); + _2.ff = function dkc(a, b) { + var c2, d, e; + if (_jc(a, b)) { + return 0; + } + c2 = Zjc(a); + d = Zjc(b); + if (!!c2 && c2.k == (r3b(), m3b) || !!d && d.k == (r3b(), m3b)) { + return 0; + } + e = RD(mQb(this.a.a, (Ywc(), Qwc)), 312); + return ZEc(e, c2 ? c2.k : (r3b(), o3b), d ? d.k : (r3b(), o3b)); + }; + _2.gf = function ekc(a, b) { + var c2, d, e; + if (_jc(a, b)) { + return 1; + } + c2 = Zjc(a); + d = Zjc(b); + e = RD(mQb(this.a.a, (Ywc(), Qwc)), 312); + return aFc(e, c2 ? c2.k : (r3b(), o3b), d ? d.k : (r3b(), o3b)); + }; + sfb(rBe, "HorizontalGraphCompactor/1", 1587); + feb(1588, 1, {}, fkc); + _2.ef = function gkc(a, b) { + return Wjc(), a.a.i == 0; + }; + sfb(rBe, "HorizontalGraphCompactor/lambda$0$Type", 1588); + feb(1589, 1, {}, hkc); + _2.ef = function ikc(a, b) { + return akc(this.a, a, b); + }; + sfb(rBe, "HorizontalGraphCompactor/lambda$1$Type", 1589); + feb(1730, 1, {}, Ckc); + var jkc, kkc; + sfb(rBe, "LGraphToCGraphTransformer", 1730); + feb(1738, 1, nwe, Kkc); + _2.Mb = function Lkc(a) { + return a != null; + }; + sfb(rBe, "LGraphToCGraphTransformer/0methodref$nonNull$Type", 1738); + feb(1731, 1, {}, Mkc); + _2.Kb = function Nkc(a) { + return lkc(), jeb(mQb(RD(RD(a, 60).g, 10), (Ywc(), Awc))); + }; + sfb(rBe, "LGraphToCGraphTransformer/lambda$0$Type", 1731); + feb(1732, 1, {}, Okc); + _2.Kb = function Pkc(a) { + return lkc(), Mlc(RD(RD(a, 60).g, 154)); + }; + sfb(rBe, "LGraphToCGraphTransformer/lambda$1$Type", 1732); + feb(1741, 1, nwe, Qkc); + _2.Mb = function Rkc(a) { + return lkc(), ZD(RD(a, 60).g, 10); + }; + sfb(rBe, "LGraphToCGraphTransformer/lambda$10$Type", 1741); + feb(1742, 1, Qve, Skc); + _2.Cd = function Tkc(a) { + Dkc(RD(a, 60)); + }; + sfb(rBe, "LGraphToCGraphTransformer/lambda$11$Type", 1742); + feb(1743, 1, nwe, Ukc); + _2.Mb = function Vkc(a) { + return lkc(), ZD(RD(a, 60).g, 154); + }; + sfb(rBe, "LGraphToCGraphTransformer/lambda$12$Type", 1743); + feb(1747, 1, Qve, Wkc); + _2.Cd = function Xkc(a) { + Ekc(RD(a, 60)); + }; + sfb(rBe, "LGraphToCGraphTransformer/lambda$13$Type", 1747); + feb(1744, 1, Qve, Ykc); + _2.Cd = function Zkc(a) { + Fkc(this.a, RD(a, 8)); + }; + _2.a = 0; + sfb(rBe, "LGraphToCGraphTransformer/lambda$14$Type", 1744); + feb(1745, 1, Qve, $kc); + _2.Cd = function _kc(a) { + Gkc(this.a, RD(a, 116)); + }; + _2.a = 0; + sfb(rBe, "LGraphToCGraphTransformer/lambda$15$Type", 1745); + feb(1746, 1, Qve, alc); + _2.Cd = function blc(a) { + Hkc(this.a, RD(a, 8)); + }; + _2.a = 0; + sfb(rBe, "LGraphToCGraphTransformer/lambda$16$Type", 1746); + feb(1748, 1, {}, clc); + _2.Kb = function dlc(a) { + return lkc(), new SDb(null, new Twb(new is(Mr(a3b(RD(a, 10)).a.Kc(), new ir())))); + }; + sfb(rBe, "LGraphToCGraphTransformer/lambda$17$Type", 1748); + feb(1749, 1, nwe, elc); + _2.Mb = function flc(a) { + return lkc(), W0b(RD(a, 18)); + }; + sfb(rBe, "LGraphToCGraphTransformer/lambda$18$Type", 1749); + feb(1750, 1, Qve, glc); + _2.Cd = function hlc(a) { + ukc(this.a, RD(a, 18)); + }; + sfb(rBe, "LGraphToCGraphTransformer/lambda$19$Type", 1750); + feb(1734, 1, Qve, ilc); + _2.Cd = function jlc(a) { + vkc(this.a, RD(a, 154)); + }; + sfb(rBe, "LGraphToCGraphTransformer/lambda$2$Type", 1734); + feb(1751, 1, {}, klc); + _2.Kb = function llc(a) { + return lkc(), new SDb(null, new Swb(RD(a, 30).a, 16)); + }; + sfb(rBe, "LGraphToCGraphTransformer/lambda$20$Type", 1751); + feb(1752, 1, {}, mlc); + _2.Kb = function nlc(a) { + return lkc(), new SDb(null, new Twb(new is(Mr(a3b(RD(a, 10)).a.Kc(), new ir())))); + }; + sfb(rBe, "LGraphToCGraphTransformer/lambda$21$Type", 1752); + feb(1753, 1, {}, olc); + _2.Kb = function plc(a) { + return lkc(), RD(mQb(RD(a, 18), (Ywc(), Twc)), 15); + }; + sfb(rBe, "LGraphToCGraphTransformer/lambda$22$Type", 1753); + feb(1754, 1, nwe, qlc); + _2.Mb = function rlc(a) { + return Ikc(RD(a, 15)); + }; + sfb(rBe, "LGraphToCGraphTransformer/lambda$23$Type", 1754); + feb(1755, 1, Qve, slc); + _2.Cd = function tlc(a) { + nkc(this.a, RD(a, 15)); + }; + sfb(rBe, "LGraphToCGraphTransformer/lambda$24$Type", 1755); + feb(1733, 1, Qve, ulc); + _2.Cd = function vlc(a) { + wkc(this.a, this.b, RD(a, 154)); + }; + sfb(rBe, "LGraphToCGraphTransformer/lambda$3$Type", 1733); + feb(1735, 1, {}, wlc); + _2.Kb = function xlc(a) { + return lkc(), new SDb(null, new Swb(RD(a, 30).a, 16)); + }; + sfb(rBe, "LGraphToCGraphTransformer/lambda$4$Type", 1735); + feb(1736, 1, {}, ylc); + _2.Kb = function zlc(a) { + return lkc(), new SDb(null, new Twb(new is(Mr(a3b(RD(a, 10)).a.Kc(), new ir())))); + }; + sfb(rBe, "LGraphToCGraphTransformer/lambda$5$Type", 1736); + feb(1737, 1, {}, Alc); + _2.Kb = function Blc(a) { + return lkc(), RD(mQb(RD(a, 18), (Ywc(), Twc)), 15); + }; + sfb(rBe, "LGraphToCGraphTransformer/lambda$6$Type", 1737); + feb(1739, 1, Qve, Clc); + _2.Cd = function Dlc(a) { + Jkc(this.a, RD(a, 15)); + }; + sfb(rBe, "LGraphToCGraphTransformer/lambda$8$Type", 1739); + feb(1740, 1, Qve, Elc); + _2.Cd = function Flc(a) { + xkc(this.a, this.b, RD(a, 154)); + }; + sfb(rBe, "LGraphToCGraphTransformer/lambda$9$Type", 1740); + feb(1729, 1, {}, Jlc); + _2.cf = function Klc(a) { + var b, c2, d, e, f2; + this.a = a; + this.d = new BIb(); + this.c = $C(DN, rve, 125, this.a.a.a.c.length, 0, 1); + this.b = 0; + for (c2 = new Anb(this.a.a.a); c2.a < c2.c.c.length; ) { + b = RD(ynb(c2), 316); + b.d = this.b; + f2 = eJb(fJb(new gJb(), b), this.d); + this.c[this.b] = f2; + ++this.b; + } + Ilc(this); + Hlc(this); + Glc(this); + lJb(CJb(this.d), new Oqd()); + for (e = new Anb(this.a.a.b); e.a < e.c.c.length; ) { + d = RD(ynb(e), 60); + d.d.c = this.c[d.a.d].e + d.b.a; + } + }; + _2.b = 0; + sfb(rBe, "NetworkSimplexCompaction", 1729); + feb(154, 1, { 34: 1, 154: 1 }, Nlc); + _2.Fd = function Olc(a) { + return Llc(this, RD(a, 154)); + }; + _2.Ib = function Plc() { + return Mlc(this); + }; + sfb(rBe, "VerticalSegment", 154); + feb(841, 1, {}, Ylc); + _2.c = 0; + _2.e = 0; + _2.i = 0; + sfb(sBe, "BetweenLayerEdgeTwoNodeCrossingsCounter", 841); + feb(677, 1, { 677: 1 }, dmc); + _2.Ib = function emc() { + return "AdjacencyList [node=" + this.d + ", adjacencies= " + this.a + "]"; + }; + _2.b = 0; + _2.c = 0; + _2.f = 0; + sfb(sBe, "BetweenLayerEdgeTwoNodeCrossingsCounter/AdjacencyList", 677); + feb(294, 1, { 34: 1, 294: 1 }, hmc); + _2.Fd = function imc(a) { + return fmc(this, RD(a, 294)); + }; + _2.Ib = function jmc() { + return "Adjacency [position=" + this.c + ", cardinality=" + this.a + ", currentCardinality=" + this.b + "]"; + }; + _2.a = 0; + _2.b = 0; + _2.c = 0; + sfb(sBe, "BetweenLayerEdgeTwoNodeCrossingsCounter/AdjacencyList/Adjacency", 294); + feb(2026, 1, {}, mmc); + _2.b = 0; + _2.e = false; + sfb(sBe, "CrossingMatrixFiller", 2026); + var QY = ufb(tBe, "IInitializable"); + feb(1867, 1, uBe, smc); + _2.gg = function vmc(a, b, c2, d, e, f2) { + }; + _2.ig = function xmc(a, b, c2) { + }; + _2.eg = function tmc() { + return this.c != (RKc(), PKc); + }; + _2.fg = function umc() { + this.e = $C(kE, Pwe, 28, this.d, 15, 1); + }; + _2.hg = function wmc(a, b) { + b[a][0].c.p = a; + }; + _2.jg = function ymc(a, b, c2, d) { + ++this.d; + }; + _2.kg = function zmc() { + return true; + }; + _2.lg = function Amc(a, b, c2, d) { + omc(this, a, b, c2); + return nmc(this, b); + }; + _2.mg = function Bmc(a, b) { + var c2; + c2 = pmc(b, a.length); + omc(this, a, c2, b); + return qmc(this, c2); + }; + _2.d = 0; + sfb(sBe, "GreedySwitchHeuristic", 1867); + feb(2029, 1, {}, Kmc); + _2.b = 0; + _2.d = 0; + sfb(sBe, "NorthSouthEdgeNeighbouringNodeCrossingsCounter", 2029); + feb(2016, 1, {}, Pmc); + _2.a = false; + sfb(sBe, "SwitchDecider", 2016); + feb(105, 1, { 105: 1 }, Vmc); + _2.a = null; + _2.c = null; + _2.i = null; + sfb(vBe, "SelfHyperLoop", 105); + feb(2013, 1, {}, _mc); + _2.c = 0; + _2.e = 0; + sfb(vBe, "SelfHyperLoopLabels", 2013); + feb(421, 22, { 3: 1, 34: 1, 22: 1, 421: 1 }, fnc); + var anc, bnc, cnc, dnc; + var LV = tfb(vBe, "SelfHyperLoopLabels/Alignment", 421, WI, hnc, gnc); + var inc; + feb(340, 1, { 340: 1 }, knc); + sfb(vBe, "SelfLoopEdge", 340); + feb(337, 1, { 337: 1 }, onc); + _2.a = false; + sfb(vBe, "SelfLoopHolder", 337); + feb(1790, 1, nwe, qnc); + _2.Mb = function rnc(a) { + return W0b(RD(a, 18)); + }; + sfb(vBe, "SelfLoopHolder/lambda$0$Type", 1790); + feb(113, 1, { 113: 1 }, tnc); + _2.a = false; + _2.c = false; + sfb(vBe, "SelfLoopPort", 113); + feb(1855, 1, nwe, unc); + _2.Mb = function vnc(a) { + return W0b(RD(a, 18)); + }; + sfb(vBe, "SelfLoopPort/lambda$0$Type", 1855); + feb(375, 22, { 3: 1, 34: 1, 22: 1, 375: 1 }, Cnc); + var wnc, xnc, ync, znc, Anc; + var TV = tfb(vBe, "SelfLoopType", 375, WI, Fnc, Enc); + var Gnc; + feb(1798, 1, {}, boc); + var Inc, Jnc, Knc, Lnc; + sfb(wBe, "PortRestorer", 1798); + feb(372, 22, { 3: 1, 34: 1, 22: 1, 372: 1 }, koc); + var goc, hoc, ioc; + var UV = tfb(wBe, "PortRestorer/PortSideArea", 372, WI, moc, loc); + var noc; + feb(1799, 1, {}, poc); + _2.Kb = function qoc(a) { + return Mnc(), RD(a, 15).Oc(); + }; + sfb(wBe, "PortRestorer/lambda$0$Type", 1799); + feb(1800, 1, Qve, roc); + _2.Cd = function soc(a) { + Mnc(); + RD(a, 113).c = false; + }; + sfb(wBe, "PortRestorer/lambda$1$Type", 1800); + feb(1809, 1, nwe, toc); + _2.Mb = function uoc(a) { + return Mnc(), RD(a, 12).j == (qpd(), ppd); + }; + sfb(wBe, "PortRestorer/lambda$10$Type", 1809); + feb(1810, 1, {}, voc); + _2.Kb = function woc(a) { + return Mnc(), RD(a, 113).d; + }; + sfb(wBe, "PortRestorer/lambda$11$Type", 1810); + feb(1811, 1, Qve, xoc); + _2.Cd = function yoc(a) { + coc(this.a, RD(a, 12)); + }; + sfb(wBe, "PortRestorer/lambda$12$Type", 1811); + feb(1801, 1, Qve, zoc); + _2.Cd = function Aoc(a) { + doc(this.a, RD(a, 105)); + }; + sfb(wBe, "PortRestorer/lambda$2$Type", 1801); + feb(1802, 1, fye, Boc); + _2.Ne = function Coc(a, b) { + return eoc(RD(a, 113), RD(b, 113)); + }; + _2.Fb = function Doc(a) { + return this === a; + }; + _2.Oe = function Eoc() { + return new Frb(this); + }; + sfb(wBe, "PortRestorer/lambda$3$Type", 1802); + feb(1803, 1, nwe, Foc); + _2.Mb = function Goc(a) { + return Mnc(), RD(a, 113).c; + }; + sfb(wBe, "PortRestorer/lambda$4$Type", 1803); + feb(1804, 1, nwe, Hoc); + _2.Mb = function Ioc(a) { + return Tnc(RD(a, 12)); + }; + sfb(wBe, "PortRestorer/lambda$5$Type", 1804); + feb(1805, 1, nwe, Joc); + _2.Mb = function Koc(a) { + return Mnc(), RD(a, 12).j == (qpd(), Yod); + }; + sfb(wBe, "PortRestorer/lambda$6$Type", 1805); + feb(1806, 1, nwe, Loc); + _2.Mb = function Moc(a) { + return Mnc(), RD(a, 12).j == (qpd(), Xod); + }; + sfb(wBe, "PortRestorer/lambda$7$Type", 1806); + feb(1807, 1, nwe, Noc); + _2.Mb = function Ooc(a) { + return Unc(RD(a, 12)); + }; + sfb(wBe, "PortRestorer/lambda$8$Type", 1807); + feb(1808, 1, nwe, Poc); + _2.Mb = function Qoc(a) { + return Mnc(), RD(a, 12).j == (qpd(), npd); + }; + sfb(wBe, "PortRestorer/lambda$9$Type", 1808); + feb(276, 22, { 3: 1, 34: 1, 22: 1, 276: 1 }, fpc); + var Yoc, Zoc, $oc, _oc, apc, bpc, cpc, dpc; + var hW = tfb(wBe, "PortSideAssigner/Target", 276, WI, hpc, gpc); + var ipc; + feb(1791, 1, {}, kpc); + _2.Kb = function lpc(a) { + return CDb(new SDb(null, new Swb(RD(a, 105).j, 16)), new Cpc()); + }; + sfb(wBe, "PortSideAssigner/lambda$1$Type", 1791); + feb(1792, 1, {}, mpc); + _2.Kb = function npc(a) { + return RD(a, 113).d; + }; + sfb(wBe, "PortSideAssigner/lambda$2$Type", 1792); + feb(1793, 1, Qve, opc); + _2.Cd = function ppc(a) { + Q3b(RD(a, 12), (qpd(), Yod)); + }; + sfb(wBe, "PortSideAssigner/lambda$3$Type", 1793); + feb(1794, 1, {}, qpc); + _2.Kb = function rpc(a) { + return RD(a, 113).d; + }; + sfb(wBe, "PortSideAssigner/lambda$4$Type", 1794); + feb(1795, 1, Qve, spc); + _2.Cd = function tpc(a) { + Voc(this.a, RD(a, 12)); + }; + sfb(wBe, "PortSideAssigner/lambda$5$Type", 1795); + feb(1796, 1, fye, upc); + _2.Ne = function vpc(a, b) { + return Woc(RD(a, 105), RD(b, 105)); + }; + _2.Fb = function wpc(a) { + return this === a; + }; + _2.Oe = function xpc() { + return new Frb(this); + }; + sfb(wBe, "PortSideAssigner/lambda$6$Type", 1796); + feb(1797, 1, fye, ypc); + _2.Ne = function zpc(a, b) { + return Xoc(RD(a, 113), RD(b, 113)); + }; + _2.Fb = function Apc(a) { + return this === a; + }; + _2.Oe = function Bpc() { + return new Frb(this); + }; + sfb(wBe, "PortSideAssigner/lambda$7$Type", 1797); + feb(820, 1, nwe, Cpc); + _2.Mb = function Dpc(a) { + return RD(a, 113).c; + }; + sfb(wBe, "PortSideAssigner/lambda$8$Type", 820); + feb(2108, 1, {}); + sfb(xBe, "AbstractSelfLoopRouter", 2108); + feb(1816, 1, fye, Mpc); + _2.Ne = function Npc(a, b) { + return Kpc(RD(a, 105), RD(b, 105)); + }; + _2.Fb = function Opc(a) { + return this === a; + }; + _2.Oe = function Ppc() { + return new Frb(this); + }; + sfb(xBe, Vye, 1816); + feb(1817, 1, fye, Qpc); + _2.Ne = function Rpc(a, b) { + return Lpc(RD(a, 105), RD(b, 105)); + }; + _2.Fb = function Spc(a) { + return this === a; + }; + _2.Oe = function Tpc() { + return new Frb(this); + }; + sfb(xBe, Wye, 1817); + feb(1856, 2108, {}, dqc); + _2.ng = function eqc(a, b, c2) { + return c2; + }; + sfb(xBe, "OrthogonalSelfLoopRouter", 1856); + feb(1858, 1, Qve, fqc); + _2.Cd = function gqc(a) { + cqc(this.b, this.a, RD(a, 8)); + }; + sfb(xBe, "OrthogonalSelfLoopRouter/lambda$0$Type", 1858); + feb(1857, 1856, {}, jqc); + _2.ng = function kqc(a, b, c2) { + var d, e; + d = a.c.d; + hu(c2, 0, $id(ajd(d.n), d.a)); + e = a.d.d; + Mub(c2, $id(ajd(e.n), e.a)); + return hqc(c2); + }; + sfb(xBe, "PolylineSelfLoopRouter", 1857); + feb(1812, 1, {}, yqc); + _2.a = null; + var lqc; + sfb(xBe, "RoutingDirector", 1812); + feb(1813, 1, fye, Aqc); + _2.Ne = function Bqc(a, b) { + return zqc(RD(a, 113), RD(b, 113)); + }; + _2.Fb = function Cqc(a) { + return this === a; + }; + _2.Oe = function Dqc() { + return new Frb(this); + }; + sfb(xBe, "RoutingDirector/lambda$0$Type", 1813); + feb(1814, 1, {}, Eqc); + _2.Kb = function Fqc(a) { + return mqc(), RD(a, 105).j; + }; + sfb(xBe, "RoutingDirector/lambda$1$Type", 1814); + feb(1815, 1, Qve, Gqc); + _2.Cd = function Hqc(a) { + mqc(); + RD(a, 15).jd(lqc); + }; + sfb(xBe, "RoutingDirector/lambda$2$Type", 1815); + feb(1818, 1, {}, Sqc); + sfb(xBe, "RoutingSlotAssigner", 1818); + feb(1819, 1, nwe, Vqc); + _2.Mb = function Wqc(a) { + return Tqc(this.a, RD(a, 105)); + }; + sfb(xBe, "RoutingSlotAssigner/lambda$0$Type", 1819); + feb(1820, 1, fye, Xqc); + _2.Ne = function Yqc(a, b) { + return Uqc(this.a, RD(a, 105), RD(b, 105)); + }; + _2.Fb = function Zqc(a) { + return this === a; + }; + _2.Oe = function $qc() { + return new Frb(this); + }; + sfb(xBe, "RoutingSlotAssigner/lambda$1$Type", 1820); + feb(1859, 1856, {}, arc); + _2.ng = function brc(a, b, c2) { + var d, e, f2, g; + d = Kfb(UD(k2b(a.b.g.b, (yCc(), VBc)))); + g = new Gjd(cD(WC(l3, 1), Nve, 8, 0, [(f2 = a.c.d, $id(new sjd(f2.n), f2.a))])); + _qc(a, b, c2, g, d); + Mub(g, (e = a.d.d, $id(new sjd(e.n), e.a))); + return sUc(new wUc(g)); + }; + sfb(xBe, "SplineSelfLoopRouter", 1859); + feb(586, 1, fye, frc, hrc); + _2.Ne = function irc(a, b) { + return crc(this, RD(a, 10), RD(b, 10)); + }; + _2.Fb = function jrc(a) { + return this === a; + }; + _2.Oe = function krc() { + return new Frb(this); + }; + sfb(yBe, "ModelOrderNodeComparator", 586); + feb(1821, 1, nwe, lrc); + _2.Mb = function mrc(a) { + return RD(a, 12).e.c.length != 0; + }; + sfb(yBe, "ModelOrderNodeComparator/lambda$0$Type", 1821); + feb(821, 1, fye, trc, urc); + _2.Ne = function vrc(a, b) { + return prc(this, a, b); + }; + _2.Fb = function wrc(a) { + return this === a; + }; + _2.Oe = function xrc() { + return new Frb(this); + }; + _2.b = false; + sfb(yBe, "ModelOrderPortComparator", 821); + feb(815, 1, {}, zrc); + _2.og = function Brc(a, b) { + var c2, d, e, f2; + e = Arc(b); + c2 = new bnb(); + f2 = b.f / e; + for (d = 1; d < e; ++d) { + Rmb(c2, sgb(Ydb(Hdb($wnd.Math.round(d * f2))))); + } + return c2; + }; + _2.pg = function Crc() { + return false; + }; + sfb(zBe, "ARDCutIndexHeuristic", 815); + feb(1544, 1, QAe, Hrc); + _2.Kf = function Irc(a, b) { + Grc(RD(a, 36), b); + }; + sfb(zBe, "BreakingPointInserter", 1544); + feb(313, 1, { 313: 1 }, Jrc); + _2.Ib = function Mrc() { + var a; + a = new bib(); + a.a += "BPInfo["; + a.a += "\n start="; + Yhb(a, this.i); + a.a += "\n end="; + Yhb(a, this.a); + a.a += "\n nodeStartEdge="; + Yhb(a, this.e); + a.a += "\n startEndEdge="; + Yhb(a, this.j); + a.a += "\n originalEdge="; + Yhb(a, this.f); + a.a += "\n startInLayerDummy="; + Yhb(a, this.k); + a.a += "\n startInLayerEdge="; + Yhb(a, this.n); + a.a += "\n endInLayerDummy="; + Yhb(a, this.b); + a.a += "\n endInLayerEdge="; + Yhb(a, this.c); + return a.a; + }; + sfb(zBe, "BreakingPointInserter/BPInfo", 313); + feb(661, 1, { 661: 1 }, Trc); + _2.a = false; + _2.b = 0; + _2.c = 0; + sfb(zBe, "BreakingPointInserter/Cut", 661); + feb(1545, 1, QAe, bsc); + _2.Kf = function csc(a, b) { + _rc(RD(a, 36), b); + }; + sfb(zBe, "BreakingPointProcessor", 1545); + feb(1546, 1, nwe, dsc); + _2.Mb = function esc(a) { + return Krc(RD(a, 10)); + }; + sfb(zBe, "BreakingPointProcessor/0methodref$isEnd$Type", 1546); + feb(1547, 1, nwe, fsc); + _2.Mb = function gsc(a) { + return Lrc(RD(a, 10)); + }; + sfb(zBe, "BreakingPointProcessor/1methodref$isStart$Type", 1547); + feb(1548, 1, QAe, ksc); + _2.Kf = function lsc(a, b) { + isc(this, RD(a, 36), b); + }; + sfb(zBe, "BreakingPointRemover", 1548); + feb(1549, 1, Qve, msc); + _2.Cd = function nsc(a) { + RD(a, 131).k = true; + }; + sfb(zBe, "BreakingPointRemover/lambda$0$Type", 1549); + feb(811, 1, {}, ysc); + _2.b = 0; + _2.e = 0; + _2.f = 0; + _2.j = 0; + sfb(zBe, "GraphStats", 811); + feb(812, 1, {}, Asc); + _2.Ve = function Bsc(a, b) { + return $wnd.Math.max(Kfb(UD(a)), Kfb(UD(b))); + }; + sfb(zBe, "GraphStats/0methodref$max$Type", 812); + feb(813, 1, {}, Csc); + _2.Ve = function Dsc(a, b) { + return $wnd.Math.max(Kfb(UD(a)), Kfb(UD(b))); + }; + sfb(zBe, "GraphStats/2methodref$max$Type", 813); + feb(1726, 1, {}, Esc); + _2.Ve = function Fsc(a, b) { + return zsc(UD(a), UD(b)); + }; + sfb(zBe, "GraphStats/lambda$1$Type", 1726); + feb(1727, 1, {}, Gsc); + _2.Kb = function Hsc(a) { + return ssc(this.a, RD(a, 30)); + }; + sfb(zBe, "GraphStats/lambda$2$Type", 1727); + feb(1728, 1, {}, Isc); + _2.Kb = function Jsc(a) { + return rsc(this.a, RD(a, 30)); + }; + sfb(zBe, "GraphStats/lambda$6$Type", 1728); + feb(814, 1, {}, Ksc); + _2.og = function Lsc(a, b) { + var c2; + c2 = RD(mQb(a, (yCc(), pCc)), 15); + return c2 ? c2 : (yob(), yob(), vob); + }; + _2.pg = function Msc() { + return false; + }; + sfb(zBe, "ICutIndexCalculator/ManualCutIndexCalculator", 814); + feb(816, 1, {}, Nsc); + _2.og = function Osc(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u; + u = (b.n == null && vsc(b), b.n); + i2 = (b.d == null && vsc(b), b.d); + t = $C(iE, vxe, 28, u.length, 15, 1); + t[0] = u[0]; + r = u[0]; + for (j = 1; j < u.length; j++) { + t[j] = t[j - 1] + u[j]; + r += u[j]; + } + e = Arc(b) - 1; + g = RD(mQb(a, (yCc(), qCc)), 17).a; + d = pxe; + c2 = new bnb(); + for (m = $wnd.Math.max(0, e - g); m <= $wnd.Math.min(b.f - 1, e + g); m++) { + p = r / (m + 1); + q = 0; + k = 1; + f2 = new bnb(); + s = pxe; + l = 0; + h = 0; + o2 = i2[0]; + if (m == 0) { + s = r; + h = (b.g == null && (b.g = qsc(b, new Csc())), Kfb(b.g)); + } else { + while (k < b.f) { + if (t[k - 1] - q >= p) { + Rmb(f2, sgb(k)); + s = $wnd.Math.max(s, t[k - 1] - l); + h += o2; + q += t[k - 1] - q; + l = t[k - 1]; + o2 = i2[k]; + } + o2 = $wnd.Math.max(o2, i2[k]); + ++k; + } + h += o2; + } + n = $wnd.Math.min(1 / s, 1 / b.b / h); + if (n > d) { + d = n; + c2 = f2; + } + } + return c2; + }; + _2.pg = function Psc() { + return false; + }; + sfb(zBe, "MSDCutIndexHeuristic", 816); + feb(1683, 1, QAe, Ssc); + _2.Kf = function Tsc(a, b) { + Rsc(RD(a, 36), b); + }; + sfb(zBe, "SingleEdgeGraphWrapper", 1683); + feb(232, 22, { 3: 1, 34: 1, 22: 1, 232: 1 }, ctc); + var Xsc, Ysc, Zsc, $sc, _sc, atc; + var ZW = tfb(ABe, "CenterEdgeLabelPlacementStrategy", 232, WI, etc, dtc); + var ftc; + feb(431, 22, { 3: 1, 34: 1, 22: 1, 431: 1 }, ktc); + var htc, itc; + var $W = tfb(ABe, "ConstraintCalculationStrategy", 431, WI, mtc, ltc); + var ntc; + feb(322, 22, { 3: 1, 34: 1, 22: 1, 322: 1, 188: 1, 196: 1 }, utc); + _2.dg = function wtc() { + return ttc(this); + }; + _2.qg = function vtc() { + return ttc(this); + }; + var ptc, qtc, rtc; + var _W = tfb(ABe, "CrossingMinimizationStrategy", 322, WI, ytc, xtc); + var ztc; + feb(351, 22, { 3: 1, 34: 1, 22: 1, 351: 1 }, Ftc); + var Btc, Ctc, Dtc; + var aX = tfb(ABe, "CuttingStrategy", 351, WI, Htc, Gtc); + var Itc; + feb(348, 22, { 3: 1, 34: 1, 22: 1, 348: 1, 188: 1, 196: 1 }, Rtc); + _2.dg = function Ttc() { + return Qtc(this); + }; + _2.qg = function Stc() { + return Qtc(this); + }; + var Ktc, Ltc, Mtc, Ntc, Otc; + var bX = tfb(ABe, "CycleBreakingStrategy", 348, WI, Vtc, Utc); + var Wtc; + feb(428, 22, { 3: 1, 34: 1, 22: 1, 428: 1 }, _tc); + var Ytc, Ztc; + var cX = tfb(ABe, "DirectionCongruency", 428, WI, buc, auc); + var cuc; + feb(460, 22, { 3: 1, 34: 1, 22: 1, 460: 1 }, iuc); + var euc, fuc, guc; + var dX = tfb(ABe, "EdgeConstraint", 460, WI, kuc, juc); + var luc; + feb(283, 22, { 3: 1, 34: 1, 22: 1, 283: 1 }, vuc); + var nuc, ouc, puc, quc, ruc, suc; + var eX = tfb(ABe, "EdgeLabelSideSelection", 283, WI, xuc, wuc); + var yuc; + feb(488, 22, { 3: 1, 34: 1, 22: 1, 488: 1 }, Duc); + var Auc, Buc; + var fX = tfb(ABe, "EdgeStraighteningStrategy", 488, WI, Fuc, Euc); + var Guc; + feb(281, 22, { 3: 1, 34: 1, 22: 1, 281: 1 }, Puc); + var Iuc, Juc, Kuc, Luc, Muc, Nuc; + var gX = tfb(ABe, "FixedAlignment", 281, WI, Ruc, Quc); + var Suc; + feb(282, 22, { 3: 1, 34: 1, 22: 1, 282: 1 }, _uc); + var Uuc, Vuc, Wuc, Xuc, Yuc, Zuc; + var hX = tfb(ABe, "GraphCompactionStrategy", 282, WI, bvc, avc); + var cvc; + feb(259, 22, { 3: 1, 34: 1, 22: 1, 259: 1 }, pvc); + var evc, fvc, gvc, hvc, ivc, jvc, kvc, lvc, mvc, nvc; + var iX = tfb(ABe, "GraphProperties", 259, WI, rvc, qvc); + var svc; + feb(299, 22, { 3: 1, 34: 1, 22: 1, 299: 1 }, yvc); + var uvc, vvc, wvc; + var jX = tfb(ABe, "GreedySwitchType", 299, WI, Avc, zvc); + var Bvc; + feb(311, 22, { 3: 1, 34: 1, 22: 1, 311: 1 }, Hvc); + var Dvc, Evc, Fvc; + var kX = tfb(ABe, "InLayerConstraint", 311, WI, Jvc, Ivc); + var Kvc; + feb(429, 22, { 3: 1, 34: 1, 22: 1, 429: 1 }, Pvc); + var Mvc, Nvc; + var lX = tfb(ABe, "InteractiveReferencePoint", 429, WI, Rvc, Qvc); + var Svc; + var Uvc, Vvc, Wvc, Xvc, Yvc, Zvc, $vc, _vc, awc, bwc, cwc, dwc, ewc, fwc, gwc, hwc, iwc, jwc, kwc, lwc, mwc, nwc, owc, pwc, qwc, rwc, swc, twc, uwc, vwc, wwc, xwc, ywc, zwc, Awc, Bwc, Cwc, Dwc, Ewc, Fwc, Gwc, Hwc, Iwc, Jwc, Kwc, Lwc, Mwc, Nwc, Owc, Pwc, Qwc, Rwc, Swc, Twc, Uwc, Vwc, Wwc, Xwc; + feb(171, 22, { 3: 1, 34: 1, 22: 1, 171: 1 }, dxc); + var Zwc, $wc, _wc, axc, bxc; + var mX = tfb(ABe, "LayerConstraint", 171, WI, fxc, exc); + var gxc; + feb(859, 1, Eye, Pzc); + _2.hf = function Qzc(a) { + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), HBe), ""), "Direction Congruency"), "Specifies how drawings of the same graph with different layout directions compare to each other: either a natural reading direction is preserved or the drawings are rotated versions of each other."), Uxc), (kid(), eid)), cX), xsb((Yhd(), Whd))))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), IBe), ""), "Feedback Edges"), "Whether feedback edges should be highlighted by routing around the nodes."), (Geb(), false)), cid), QI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), JBe), ""), "Interactive Reference Point"), "Determines which point of a node is considered by interactive layout phases."), pyc), eid), lX), xsb(Whd)))); + zgd(a, JBe, RBe, ryc); + zgd(a, JBe, _Be, qyc); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), KBe), ""), "Merge Edges"), "Edges that have no ports are merged so they touch the connected nodes at the same points. When this option is disabled, one port is created for each edge directly connected to a node. When it is enabled, all such incoming edges share an input port, and all outgoing edges share an output port."), false), cid), QI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), LBe), ""), "Merge Hierarchy-Crossing Edges"), "If hierarchical layout is active, hierarchy-crossing edges use as few hierarchical ports as possible. They are broken by the algorithm, with hierarchical ports inserted as required. Usually, one such port is created for each edge at each hierarchy crossing point. With this option set to true, we try to create as few hierarchical ports as possible in the process. In particular, all edges that form a hyperedge can share a port."), true), cid), QI), xsb(Whd)))); + Egd(a, new Ahd(Nhd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), MBe), ""), "Allow Non-Flow Ports To Switch Sides"), "Specifies whether non-flow ports may switch sides if their node's port constraints are either FIXED_SIDE or FIXED_ORDER. A non-flow port is a port on a side that is not part of the currently configured layout flow. For instance, given a left-to-right layout direction, north and south ports would be considered non-flow ports. Further note that the underlying criterium whether to switch sides or not solely relies on the minimization of edge crossings. Hence, edge length and other aesthetics criteria are not addressed."), false), cid), QI), xsb(Xhd)), cD(WC(qJ, 1), Nve, 2, 6, ["org.eclipse.elk.layered.northOrSouthPort"])))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), NBe), ""), "Port Sorting Strategy"), "Only relevant for nodes with FIXED_SIDE port constraints. Determines the way a node's ports are distributed on the sides of a node if their order is not prescribed. The option is set on parent nodes."), azc), eid), xX), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), OBe), ""), "Thoroughness"), "How much effort should be spent to produce a nice layout."), sgb(7)), gid), bJ), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), PBe), ""), "Add Unnecessary Bendpoints"), "Adds bend points even if an edge does not change direction. If true, each long edge dummy will contribute a bend point to its edges and hierarchy-crossing edges will always get a bend point where they cross hierarchy boundaries. By default, bend points are only added where an edge changes direction."), false), cid), QI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), QBe), ""), "Generate Position and Layer IDs"), "If enabled position id and layer id are generated, which are usually only used internally when setting the interactiveLayout option. This option should be specified on the root node."), false), cid), QI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), RBe), "cycleBreaking"), "Cycle Breaking Strategy"), "Strategy for cycle breaking. Cycle breaking looks for cycles in the graph and determines which edges to reverse to break the cycles. Reversed edges will end up pointing to the opposite direction of regular edges (that is, reversed edges will point left if edges usually point right)."), Sxc), eid), bX), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), SBe), bDe), "Node Layering Strategy"), "Strategy for node layering."), Gyc), eid), rX), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), TBe), bDe), "Layer Constraint"), "Determines a constraint on the placement of the node regarding the layering."), wyc), eid), mX), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), UBe), bDe), "Layer Choice Constraint"), "Allows to set a constraint regarding the layer placement of a node. Let i be the value of teh constraint. Assumed the drawing has n layers and i < n. If set to i, it expresses that the node should be placed in i-th layer. Should i>=n be true then the node is placed in the last layer of the drawing. Note that this option is not part of any of ELK Layered's default configurations but is only evaluated as part of the `InteractiveLayeredGraphVisitor`, which must be applied manually or used via the `DiagramLayoutEngine."), null), gid), bJ), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), VBe), bDe), "Layer ID"), "Layer identifier that was calculated by ELK Layered for a node. This is only generated if interactiveLayot or generatePositionAndLayerIds is set."), sgb(-1)), gid), bJ), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), WBe), cDe), "Upper Bound On Width [MinWidth Layerer]"), "Defines a loose upper bound on the width of the MinWidth layerer. If set to '-1' multiple values are tested and the best result is selected."), sgb(4)), gid), bJ), xsb(Whd)))); + zgd(a, WBe, SBe, zyc); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), XBe), cDe), "Upper Layer Estimation Scaling Factor [MinWidth Layerer]"), "Multiplied with Upper Bound On Width for defining an upper bound on the width of layers which haven't been determined yet, but whose maximum width had been (roughly) estimated by the MinWidth algorithm. Compensates for too high estimations. If set to '-1' multiple values are tested and the best result is selected."), sgb(2)), gid), bJ), xsb(Whd)))); + zgd(a, XBe, SBe, Byc); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), YBe), dDe), "Node Promotion Strategy"), "Reduces number of dummy nodes after layering phase (if possible)."), Eyc), eid), vX), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), ZBe), dDe), "Max Node Promotion Iterations"), "Limits the number of iterations for node promotion."), sgb(0)), gid), bJ), xsb(Whd)))); + zgd(a, ZBe, YBe, null); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), $Be), "layering.coffmanGraham"), "Layer Bound"), "The maximum number of nodes allowed per layer."), sgb(lve)), gid), bJ), xsb(Whd)))); + zgd(a, $Be, SBe, tyc); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), _Be), eDe), "Crossing Minimization Strategy"), "Strategy for crossing minimization."), Qxc), eid), _W), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), aCe), eDe), "Force Node Model Order"), "The node order given by the model does not change to produce a better layout. E.g. if node A is before node B in the model this is not changed during crossing minimization. This assumes that the node model order is already respected before crossing minimization. This can be achieved by setting considerModelOrder.strategy to NODES_AND_EDGES."), false), cid), QI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), bCe), eDe), "Hierarchical Sweepiness"), "How likely it is to use cross-hierarchy (1) vs bottom-up (-1)."), 0.1), did), VI), xsb(Whd)))); + zgd(a, bCe, fDe, Ixc); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), cCe), eDe), "Semi-Interactive Crossing Minimization"), "Preserves the order of nodes within a layer but still minimizes crossings between edges connecting long edge dummies. Derives the desired order from positions specified by the 'org.eclipse.elk.position' layout option. Requires a crossing minimization strategy that is able to process 'in-layer' constraints."), false), cid), QI), xsb(Whd)))); + zgd(a, cCe, _Be, Oxc); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), dCe), eDe), "In Layer Predecessor of"), "Allows to set a constraint which specifies of which node the current node is the predecessor. If set to 's' then the node is the predecessor of 's' and is in the same layer"), null), iid), qJ), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), eCe), eDe), "In Layer Successor of"), "Allows to set a constraint which specifies of which node the current node is the successor. If set to 's' then the node is the successor of 's' and is in the same layer"), null), iid), qJ), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), fCe), eDe), "Position Choice Constraint"), "Allows to set a constraint regarding the position placement of a node in a layer. Assumed the layer in which the node placed includes n other nodes and i < n. If set to i, it expresses that the node should be placed at the i-th position. Should i>=n be true then the node is placed at the last position in the layer. Note that this option is not part of any of ELK Layered's default configurations but is only evaluated as part of the `InteractiveLayeredGraphVisitor`, which must be applied manually or used via the `DiagramLayoutEngine."), null), gid), bJ), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), gCe), eDe), "Position ID"), "Position within a layer that was determined by ELK Layered for a node. This is only generated if interactiveLayot or generatePositionAndLayerIds is set."), sgb(-1)), gid), bJ), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), hCe), gDe), "Greedy Switch Activation Threshold"), "By default it is decided automatically if the greedy switch is activated or not. The decision is based on whether the size of the input graph (without dummy nodes) is smaller than the value of this option. A '0' enforces the activation."), sgb(40)), gid), bJ), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), iCe), gDe), "Greedy Switch Crossing Minimization"), "Greedy Switch strategy for crossing minimization. The greedy switch heuristic is executed after the regular crossing minimization as a post-processor. Note that if 'hierarchyHandling' is set to 'INCLUDE_CHILDREN', the 'greedySwitchHierarchical.type' option must be used."), Fxc), eid), jX), xsb(Whd)))); + zgd(a, iCe, _Be, Gxc); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), jCe), "crossingMinimization.greedySwitchHierarchical"), "Greedy Switch Crossing Minimization (hierarchical)"), "Activates the greedy switch heuristic in case hierarchical layout is used. The differences to the non-hierarchical case (see 'greedySwitch.type') are: 1) greedy switch is inactive by default, 3) only the option value set on the node at which hierarchical layout starts is relevant, and 2) if it's activated by the user, it properly addresses hierarchy-crossing edges."), Bxc), eid), jX), xsb(Whd)))); + zgd(a, jCe, _Be, Cxc); + zgd(a, jCe, fDe, Dxc); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), kCe), hDe), "Node Placement Strategy"), "Strategy for node placement."), $yc), eid), uX), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), lCe), hDe), "Favor Straight Edges Over Balancing"), "Favor straight edges over a balanced node placement. The default behavior is determined automatically based on the used 'edgeRouting'. For an orthogonal style it is set to true, for all other styles to false."), cid), QI), xsb(Whd)))); + zgd(a, lCe, kCe, Qyc); + zgd(a, lCe, kCe, Ryc); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), mCe), iDe), "BK Edge Straightening"), "Specifies whether the Brandes Koepf node placer tries to increase the number of straight edges at the expense of diagram size. There is a subtle difference to the 'favorStraightEdges' option, which decides whether a balanced placement of the nodes is desired, or not. In bk terms this means combining the four alignments into a single balanced one, or not. This option on the other hand tries to straighten additional edges during the creation of each of the four alignments."), Kyc), eid), fX), xsb(Whd)))); + zgd(a, mCe, kCe, Lyc); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), nCe), iDe), "BK Fixed Alignment"), "Tells the BK node placer to use a certain alignment (out of its four) instead of the one producing the smallest height, or the combination of all four."), Nyc), eid), gX), xsb(Whd)))); + zgd(a, nCe, kCe, Oyc); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), oCe), "nodePlacement.linearSegments"), "Linear Segments Deflection Dampening"), "Dampens the movement of nodes to keep the diagram from getting too large."), 0.3), did), VI), xsb(Whd)))); + zgd(a, oCe, kCe, Tyc); + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), pCe), "nodePlacement.networkSimplex"), "Node Flexibility"), "Aims at shorter and straighter edges. Two configurations are possible: (a) allow ports to move freely on the side they are assigned to (the order is always defined beforehand), (b) additionally allow to enlarge a node wherever it helps. If this option is not configured for a node, the 'nodeFlexibility.default' value is used, which is specified for the node's parent."), eid), tX), xsb(Vhd)))); + zgd(a, pCe, kCe, Yyc); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), qCe), "nodePlacement.networkSimplex.nodeFlexibility"), "Node Flexibility Default"), "Default value of the 'nodeFlexibility' option for the children of a hierarchical node."), Wyc), eid), tX), xsb(Whd)))); + zgd(a, qCe, kCe, Xyc); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), rCe), jDe), "Self-Loop Distribution"), "Alter the distribution of the loops around the node. It only takes effect for PortConstraints.FREE."), ayc), eid), zX), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), sCe), jDe), "Self-Loop Ordering"), "Alter the ordering of the loops they can either be stacked or sequenced. It only takes effect for PortConstraints.FREE."), cyc), eid), AX), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), tCe), "edgeRouting.splines"), "Spline Routing Mode"), "Specifies the way control points are assembled for each individual edge. CONSERVATIVE ensures that edges are properly routed around the nodes but feels rather orthogonal at times. SLOPPY uses fewer control points to obtain curvier edge routes but may result in edges overlapping nodes."), eyc), eid), CX), xsb(Whd)))); + zgd(a, tCe, kDe, fyc); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), uCe), "edgeRouting.splines.sloppy"), "Sloppy Spline Layer Spacing Factor"), "Spacing factor for routing area between layers when using sloppy spline routing."), 0.2), did), VI), xsb(Whd)))); + zgd(a, uCe, kDe, hyc); + zgd(a, uCe, tCe, iyc); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), vCe), "edgeRouting.polyline"), "Sloped Edge Zone Width"), "Width of the strip to the left and to the right of each layer where the polyline edge router is allowed to refrain from ensuring that edges are routed horizontally. This prevents awkward bend points for nodes that extent almost to the edge of their layer."), 2), did), VI), xsb(Whd)))); + zgd(a, vCe, kDe, $xc); + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), wCe), lDe), "Spacing Base Value"), "An optional base value for all other layout options of the 'spacing' group. It can be used to conveniently alter the overall 'spaciousness' of the drawing. Whenever an explicit value is set for the other layout options, this base value will have no effect. The base value is not inherited, i.e. it must be set for each hierarchical node."), did), VI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), xCe), lDe), "Edge Node Between Layers Spacing"), "The spacing to be preserved between nodes and edges that are routed next to the node's layer. For the spacing between nodes and edges that cross the node's layer 'spacing.edgeNode' is used."), 10), did), VI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), yCe), lDe), "Edge Edge Between Layer Spacing"), "Spacing to be preserved between pairs of edges that are routed between the same pair of layers. Note that 'spacing.edgeEdge' is used for the spacing between pairs of edges crossing the same layer."), 10), did), VI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), zCe), lDe), "Node Node Between Layers Spacing"), "The spacing to be preserved between any pair of nodes of two adjacent layers. Note that 'spacing.nodeNode' is used for the spacing between nodes within the layer itself."), 20), did), VI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), ACe), mDe), "Direction Priority"), "Defines how important it is to have a certain edge point into the direction of the overall layout. This option is evaluated during the cycle breaking phase."), sgb(0)), gid), bJ), xsb(Thd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), BCe), mDe), "Shortness Priority"), "Defines how important it is to keep an edge as short as possible. This option is evaluated during the layering phase."), sgb(0)), gid), bJ), xsb(Thd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), CCe), mDe), "Straightness Priority"), "Defines how important it is to keep an edge straight, i.e. aligned with one of the two axes. This option is evaluated during node placement."), sgb(0)), gid), bJ), xsb(Thd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), DCe), nDe), qze), "Tries to further compact components (disconnected sub-graphs)."), false), cid), QI), xsb(Whd)))); + zgd(a, DCe, cAe, true); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), ECe), oDe), "Post Compaction Strategy"), pDe), nxc), eid), hX), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), FCe), oDe), "Post Compaction Constraint Calculation"), pDe), lxc), eid), $W), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), GCe), qDe), "High Degree Node Treatment"), "Makes room around high degree nodes to place leafs and trees."), false), cid), QI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), HCe), qDe), "High Degree Node Threshold"), "Whether a node is considered to have a high degree."), sgb(16)), gid), bJ), xsb(Whd)))); + zgd(a, HCe, GCe, true); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), ICe), qDe), "High Degree Node Maximum Tree Height"), "Maximum height of a subtree connected to a high degree node to be moved to separate layers."), sgb(5)), gid), bJ), xsb(Whd)))); + zgd(a, ICe, GCe, true); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), JCe), rDe), "Graph Wrapping Strategy"), "For certain graphs and certain prescribed drawing areas it may be desirable to split the laid out graph into chunks that are placed side by side. The edges that connect different chunks are 'wrapped' around from the end of one chunk to the start of the other chunk. The points between the chunks are referred to as 'cuts'."), Gzc), eid), EX), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), KCe), rDe), "Additional Wrapped Edges Spacing"), "To visually separate edges that are wrapped from regularly routed edges an additional spacing value can be specified in form of this layout option. The spacing is added to the regular edgeNode spacing."), 10), did), VI), xsb(Whd)))); + zgd(a, KCe, JCe, lzc); + zgd(a, KCe, JCe, mzc); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), LCe), rDe), "Correction Factor for Wrapping"), "At times and for certain types of graphs the executed wrapping may produce results that are consistently biased in the same fashion: either wrapping to often or to rarely. This factor can be used to correct the bias. Internally, it is simply multiplied with the 'aspect ratio' layout option."), 1), did), VI), xsb(Whd)))); + zgd(a, LCe, JCe, ozc); + zgd(a, LCe, JCe, pzc); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), MCe), sDe), "Cutting Strategy"), "The strategy by which the layer indexes are determined at which the layering crumbles into chunks."), wzc), eid), aX), xsb(Whd)))); + zgd(a, MCe, JCe, xzc); + zgd(a, MCe, JCe, yzc); + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), NCe), sDe), "Manually Specified Cuts"), "Allows the user to specify her own cuts for a certain graph."), hid), QK), xsb(Whd)))); + zgd(a, NCe, MCe, rzc); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), OCe), "wrapping.cutting.msd"), "MSD Freedom"), "The MSD cutting strategy starts with an initial guess on the number of chunks the graph should be split into. The freedom specifies how much the strategy may deviate from this guess. E.g. if an initial number of 3 is computed, a freedom of 1 allows 2, 3, and 4 cuts."), tzc), gid), bJ), xsb(Whd)))); + zgd(a, OCe, MCe, uzc); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), PCe), tDe), "Validification Strategy"), "When wrapping graphs, one can specify indices that are not allowed as split points. The validification strategy makes sure every computed split point is allowed."), Lzc), eid), DX), xsb(Whd)))); + zgd(a, PCe, JCe, Mzc); + zgd(a, PCe, JCe, Nzc); + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), QCe), tDe), "Valid Indices for Wrapping"), null), hid), QK), xsb(Whd)))); + zgd(a, QCe, JCe, Izc); + zgd(a, QCe, JCe, Jzc); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), RCe), uDe), "Improve Cuts"), "For general graphs it is important that not too many edges wrap backwards. Thus a compromise between evenly-distributed cuts and the total number of cut edges is sought."), true), cid), QI), xsb(Whd)))); + zgd(a, RCe, JCe, Czc); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), SCe), uDe), "Distance Penalty When Improving Cuts"), null), 2), did), VI), xsb(Whd)))); + zgd(a, SCe, JCe, Azc); + zgd(a, SCe, RCe, true); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), TCe), uDe), "Improve Wrapped Edges"), "The initial wrapping is performed in a very simple way. As a consequence, edges that wrap from one chunk to another may be unnecessarily long. Activating this option tries to shorten such edges."), true), cid), QI), xsb(Whd)))); + zgd(a, TCe, JCe, Ezc); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), UCe), vDe), "Edge Label Side Selection"), "Method to decide on edge label sides."), Yxc), eid), eX), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), VCe), vDe), "Edge Center Label Placement Strategy"), "Determines in which layer center labels of long edges should be placed."), Wxc), eid), ZW), ysb(Whd, cD(WC(d3, 1), jwe, 170, 0, [Uhd]))))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), WCe), wDe), "Consider Model Order"), "Preserves the order of nodes and edges in the model file if this does not lead to additional edge crossings. Depending on the strategy this is not always possible since the node and edge order might be conflicting."), xxc), eid), wX), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), XCe), wDe), "Consider Port Order"), "If disabled the port order of output ports is derived from the edge order and input ports are ordered by their incoming connections. If enabled all ports are ordered by the port model order."), false), cid), QI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), YCe), wDe), "No Model Order"), "Set on a node to not set a model order for this node even though it is a real node."), false), cid), QI), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), ZCe), wDe), "Consider Model Order for Components"), "If set to NONE the usual ordering strategy (by cumulative node priority and size of nodes) is used. INSIDE_PORT_SIDES orders the components with external ports only inside the groups with the same port side. FORCE_MODEL_ORDER enforces the mode order on components. This option might produce bad alignments and sub optimal drawings in terms of used area since the ordering should be respected."), pxc), eid), CQ), xsb(Whd)))); + zgd(a, ZCe, cAe, null); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), $Ce), wDe), "Long Edge Ordering Strategy"), "Indicates whether long edges are sorted under, over, or equal to nodes that have no connection to a previous layer in a left-to-right or right-to-left layout. Under and over changes to right and left in a vertical layout."), txc), eid), sX), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), _Ce), wDe), "Crossing Counter Node Order Influence"), "Indicates with what percentage (1 for 100%) violations of the node model order are weighted against the crossings e.g. a value of 0.5 means two model order violations are as important as on edge crossing. This allows some edge crossings in favor of preserving the model order. It is advised to set this value to a very small positive value (e.g. 0.001) to have minimal crossing and a optimal node order. Defaults to no influence (0)."), 0), did), VI), xsb(Whd)))); + zgd(a, _Ce, WCe, null); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), aDe), wDe), "Crossing Counter Port Order Influence"), "Indicates with what percentage (1 for 100%) violations of the port model order are weighted against the crossings e.g. a value of 0.5 means two model order violations are as important as on edge crossing. This allows some edge crossings in favor of preserving the model order. It is advised to set this value to a very small positive value (e.g. 0.001) to have minimal crossing and a optimal port order. Defaults to no influence (0)."), 0), did), VI), xsb(Whd)))); + zgd(a, aDe, WCe, null); + zCc((new ACc(), a)); + }; + var ixc, jxc, kxc, lxc, mxc, nxc, oxc, pxc, qxc, rxc, sxc, txc, uxc, vxc, wxc, xxc, yxc, zxc, Axc, Bxc, Cxc, Dxc, Exc, Fxc, Gxc, Hxc, Ixc, Jxc, Kxc, Lxc, Mxc, Nxc, Oxc, Pxc, Qxc, Rxc, Sxc, Txc, Uxc, Vxc, Wxc, Xxc, Yxc, Zxc, $xc, _xc, ayc, byc, cyc, dyc, eyc, fyc, gyc, hyc, iyc, jyc, kyc, lyc, myc, nyc, oyc, pyc, qyc, ryc, syc, tyc, uyc, vyc, wyc, xyc, yyc, zyc, Ayc, Byc, Cyc, Dyc, Eyc, Fyc, Gyc, Hyc, Iyc, Jyc, Kyc, Lyc, Myc, Nyc, Oyc, Pyc, Qyc, Ryc, Syc, Tyc, Uyc, Vyc, Wyc, Xyc, Yyc, Zyc, $yc, _yc, azc, bzc, czc, dzc, ezc, fzc, gzc, hzc, izc, jzc, kzc, lzc, mzc, nzc, ozc, pzc, qzc, rzc, szc, tzc, uzc, vzc, wzc, xzc, yzc, zzc, Azc, Bzc, Czc, Dzc, Ezc, Fzc, Gzc, Hzc, Izc, Jzc, Kzc, Lzc, Mzc, Nzc; + sfb(ABe, "LayeredMetaDataProvider", 859); + feb(998, 1, Eye, ACc); + _2.hf = function BCc(a) { + zCc(a); + }; + var Rzc, Szc, Tzc, Uzc, Vzc, Wzc, Xzc, Yzc, Zzc, $zc, _zc, aAc, bAc, cAc, dAc, eAc, fAc, gAc, hAc, iAc, jAc, kAc, lAc, mAc, nAc, oAc, pAc, qAc, rAc, sAc, tAc, uAc, vAc, wAc, xAc, yAc, zAc, AAc, BAc, CAc, DAc, EAc, FAc, GAc, HAc, IAc, JAc, KAc, LAc, MAc, NAc, OAc, PAc, QAc, RAc, SAc, TAc, UAc, VAc, WAc, XAc, YAc, ZAc, $Ac, _Ac, aBc, bBc, cBc, dBc, eBc, fBc, gBc, hBc, iBc, jBc, kBc, lBc, mBc, nBc, oBc, pBc, qBc, rBc, sBc, tBc, uBc, vBc, wBc, xBc, yBc, zBc, ABc, BBc, CBc, DBc, EBc, FBc, GBc, HBc, IBc, JBc, KBc, LBc, MBc, NBc, OBc, PBc, QBc, RBc, SBc, TBc, UBc, VBc, WBc, XBc, YBc, ZBc, $Bc, _Bc, aCc, bCc, cCc, dCc, eCc, fCc, gCc, hCc, iCc, jCc, kCc, lCc, mCc, nCc, oCc, pCc, qCc, rCc, sCc, tCc, uCc, vCc, wCc, xCc; + sfb(ABe, "LayeredOptions", 998); + feb(999, 1, {}, CCc); + _2.sf = function DCc() { + var a; + return a = new lXb(), a; + }; + _2.tf = function ECc(a) { + }; + sfb(ABe, "LayeredOptions/LayeredFactory", 999); + feb(1391, 1, {}); + _2.a = 0; + var FCc; + sfb(jEe, "ElkSpacings/AbstractSpacingsBuilder", 1391); + feb(792, 1391, {}, RCc); + var OCc, PCc; + sfb(ABe, "LayeredSpacings/LayeredSpacingsBuilder", 792); + feb(265, 22, { 3: 1, 34: 1, 22: 1, 265: 1, 188: 1, 196: 1 }, bDc); + _2.dg = function dDc() { + return aDc(this); + }; + _2.qg = function cDc() { + return aDc(this); + }; + var SCc, TCc, UCc, VCc, WCc, XCc, YCc, ZCc, $Cc; + var rX = tfb(ABe, "LayeringStrategy", 265, WI, fDc, eDc); + var gDc; + feb(390, 22, { 3: 1, 34: 1, 22: 1, 390: 1 }, nDc); + var iDc, jDc, kDc; + var sX = tfb(ABe, "LongEdgeOrderingStrategy", 390, WI, pDc, oDc); + var qDc; + feb(203, 22, { 3: 1, 34: 1, 22: 1, 203: 1 }, yDc); + var sDc, tDc, uDc, vDc; + var tX = tfb(ABe, "NodeFlexibility", 203, WI, BDc, ADc); + var CDc; + feb(323, 22, { 3: 1, 34: 1, 22: 1, 323: 1, 188: 1, 196: 1 }, LDc); + _2.dg = function NDc() { + return KDc(this); + }; + _2.qg = function MDc() { + return KDc(this); + }; + var EDc, FDc, GDc, HDc, IDc; + var uX = tfb(ABe, "NodePlacementStrategy", 323, WI, PDc, ODc); + var QDc; + feb(243, 22, { 3: 1, 34: 1, 22: 1, 243: 1 }, bEc); + var SDc, TDc, UDc, VDc, WDc, XDc, YDc, ZDc, $Dc, _Dc; + var vX = tfb(ABe, "NodePromotionStrategy", 243, WI, dEc, cEc); + var eEc; + feb(284, 22, { 3: 1, 34: 1, 22: 1, 284: 1 }, lEc); + var gEc, hEc, iEc, jEc; + var wX = tfb(ABe, "OrderingStrategy", 284, WI, nEc, mEc); + var oEc; + feb(430, 22, { 3: 1, 34: 1, 22: 1, 430: 1 }, tEc); + var qEc, rEc; + var xX = tfb(ABe, "PortSortingStrategy", 430, WI, vEc, uEc); + var wEc; + feb(463, 22, { 3: 1, 34: 1, 22: 1, 463: 1 }, CEc); + var yEc, zEc, AEc; + var yX = tfb(ABe, "PortType", 463, WI, EEc, DEc); + var FEc; + feb(387, 22, { 3: 1, 34: 1, 22: 1, 387: 1 }, LEc); + var HEc, IEc, JEc; + var zX = tfb(ABe, "SelfLoopDistributionStrategy", 387, WI, NEc, MEc); + var OEc; + feb(349, 22, { 3: 1, 34: 1, 22: 1, 349: 1 }, UEc); + var QEc, REc, SEc; + var AX = tfb(ABe, "SelfLoopOrderingStrategy", 349, WI, WEc, VEc); + var XEc; + feb(312, 1, { 312: 1 }, gFc); + sfb(ABe, "Spacings", 312); + feb(350, 22, { 3: 1, 34: 1, 22: 1, 350: 1 }, mFc); + var iFc, jFc, kFc; + var CX = tfb(ABe, "SplineRoutingMode", 350, WI, oFc, nFc); + var pFc; + feb(352, 22, { 3: 1, 34: 1, 22: 1, 352: 1 }, vFc); + var rFc, sFc, tFc; + var DX = tfb(ABe, "ValidifyStrategy", 352, WI, xFc, wFc); + var yFc; + feb(388, 22, { 3: 1, 34: 1, 22: 1, 388: 1 }, EFc); + var AFc, BFc, CFc; + var EX = tfb(ABe, "WrappingStrategy", 388, WI, GFc, FFc); + var HFc; + feb(1398, 1, nEe, NFc); + _2.rg = function OFc(a) { + return RD(a, 36), JFc; + }; + _2.Kf = function PFc(a, b) { + MFc(this, RD(a, 36), b); + }; + var JFc; + sfb(oEe, "DepthFirstCycleBreaker", 1398); + feb(793, 1, nEe, UFc); + _2.rg = function WFc(a) { + return RD(a, 36), QFc; + }; + _2.Kf = function XFc(a, b) { + SFc(this, RD(a, 36), b); + }; + _2.sg = function VFc(a) { + return RD(Vmb(a, Jwb(this.d, a.c.length)), 10); + }; + var QFc; + sfb(oEe, "GreedyCycleBreaker", 793); + feb(1401, 793, nEe, YFc); + _2.sg = function ZFc(a) { + var b, c2, d, e; + e = null; + b = lve; + for (d = new Anb(a); d.a < d.c.c.length; ) { + c2 = RD(ynb(d), 10); + if (nQb(c2, (Ywc(), zwc)) && RD(mQb(c2, zwc), 17).a < b) { + b = RD(mQb(c2, zwc), 17).a; + e = c2; + } + } + if (!e) { + return RD(Vmb(a, Jwb(this.d, a.c.length)), 10); + } + return e; + }; + sfb(oEe, "GreedyModelOrderCycleBreaker", 1401); + feb(1399, 1, nEe, cGc); + _2.rg = function dGc(a) { + return RD(a, 36), $Fc; + }; + _2.Kf = function eGc(a, b) { + bGc(this, RD(a, 36), b); + }; + var $Fc; + sfb(oEe, "InteractiveCycleBreaker", 1399); + feb(1400, 1, nEe, jGc); + _2.rg = function kGc(a) { + return RD(a, 36), fGc; + }; + _2.Kf = function lGc(a, b) { + iGc(this, RD(a, 36), b); + }; + _2.a = 0; + _2.b = 0; + var fGc; + sfb(oEe, "ModelOrderCycleBreaker", 1400); + feb(1413, 1, nEe, pGc); + _2.rg = function qGc(a) { + return RD(a, 36), mGc; + }; + _2.Kf = function sGc(a, b) { + oGc(this, RD(a, 36), b); + }; + var mGc; + sfb(pEe, "BreadthFirstModelOrderLayerer", 1413); + feb(1414, 1, fye, tGc); + _2.Ne = function uGc(a, b) { + return rGc(RD(a, 10), RD(b, 10)); + }; + _2.Fb = function vGc(a) { + return this === a; + }; + _2.Oe = function wGc() { + return new Frb(this); + }; + sfb(pEe, "BreadthFirstModelOrderLayerer/lambda$0$Type", 1414); + feb(1404, 1, nEe, GGc); + _2.rg = function HGc(a) { + return RD(a, 36), xGc; + }; + _2.Kf = function IGc(a, b) { + EGc(this, RD(a, 36), b); + }; + var xGc; + sfb(pEe, "CoffmanGrahamLayerer", 1404); + feb(1405, 1, fye, JGc); + _2.Ne = function KGc(a, b) { + return AGc(this.a, RD(a, 10), RD(b, 10)); + }; + _2.Fb = function LGc(a) { + return this === a; + }; + _2.Oe = function MGc() { + return new Frb(this); + }; + sfb(pEe, "CoffmanGrahamLayerer/0methodref$compareNodesInTopo$Type", 1405); + feb(1406, 1, fye, NGc); + _2.Ne = function OGc(a, b) { + return DGc(this.a, RD(a, 10), RD(b, 10)); + }; + _2.Fb = function PGc(a) { + return this === a; + }; + _2.Oe = function QGc() { + return new Frb(this); + }; + sfb(pEe, "CoffmanGrahamLayerer/lambda$1$Type", 1406); + feb(1415, 1, nEe, YGc); + _2.rg = function ZGc(a) { + return RD(a, 36), RGc; + }; + _2.Kf = function _Gc(a, b) { + XGc(this, RD(a, 36), b); + }; + _2.c = 0; + _2.e = 0; + var RGc; + sfb(pEe, "DepthFirstModelOrderLayerer", 1415); + feb(1416, 1, fye, aHc); + _2.Ne = function bHc(a, b) { + return $Gc(RD(a, 10), RD(b, 10)); + }; + _2.Fb = function cHc(a) { + return this === a; + }; + _2.Oe = function dHc() { + return new Frb(this); + }; + sfb(pEe, "DepthFirstModelOrderLayerer/lambda$0$Type", 1416); + feb(1407, 1, nEe, gHc); + _2.rg = function hHc(a) { + return RD(a, 36), pfd(pfd(pfd(new ufd(), (sXb(), nXb), (hcc(), Ebc)), oXb, Nbc), pXb, Mbc); + }; + _2.Kf = function iHc(a, b) { + fHc(RD(a, 36), b); + }; + sfb(pEe, "InteractiveLayerer", 1407); + feb(578, 1, { 578: 1 }, jHc); + _2.a = 0; + _2.c = 0; + sfb(pEe, "InteractiveLayerer/LayerSpan", 578); + feb(1403, 1, nEe, pHc); + _2.rg = function qHc(a) { + return RD(a, 36), kHc; + }; + _2.Kf = function rHc(a, b) { + mHc(this, RD(a, 36), b); + }; + var kHc; + sfb(pEe, "LongestPathLayerer", 1403); + feb(1412, 1, nEe, xHc); + _2.rg = function yHc(a) { + return RD(a, 36), sHc; + }; + _2.Kf = function zHc(a, b) { + uHc(this, RD(a, 36), b); + }; + var sHc; + sfb(pEe, "LongestPathSourceLayerer", 1412); + feb(1410, 1, nEe, IHc); + _2.rg = function JHc(a) { + return RD(a, 36), pfd(pfd(pfd(new ufd(), (sXb(), nXb), (hcc(), obc)), oXb, Nbc), pXb, Mbc); + }; + _2.Kf = function KHc(a, b) { + GHc(this, RD(a, 36), b); + }; + _2.a = 0; + _2.b = 0; + _2.d = 0; + var AHc, BHc; + sfb(pEe, "MinWidthLayerer", 1410); + feb(1411, 1, fye, MHc); + _2.Ne = function NHc(a, b) { + return LHc(this, RD(a, 10), RD(b, 10)); + }; + _2.Fb = function OHc(a) { + return this === a; + }; + _2.Oe = function PHc() { + return new Frb(this); + }; + sfb(pEe, "MinWidthLayerer/MinOutgoingEdgesComparator", 1411); + feb(1402, 1, nEe, XHc); + _2.rg = function YHc(a) { + return RD(a, 36), QHc; + }; + _2.Kf = function ZHc(a, b) { + WHc(this, RD(a, 36), b); + }; + var QHc; + sfb(pEe, "NetworkSimplexLayerer", 1402); + feb(1408, 1, nEe, jIc); + _2.rg = function kIc(a) { + return RD(a, 36), pfd(pfd(pfd(new ufd(), (sXb(), nXb), (hcc(), obc)), oXb, Nbc), pXb, Mbc); + }; + _2.Kf = function lIc(a, b) { + gIc(this, RD(a, 36), b); + }; + _2.d = 0; + _2.f = 0; + _2.g = 0; + _2.i = 0; + _2.s = 0; + _2.t = 0; + _2.u = 0; + sfb(pEe, "StretchWidthLayerer", 1408); + feb(1409, 1, fye, nIc); + _2.Ne = function oIc(a, b) { + return mIc(RD(a, 10), RD(b, 10)); + }; + _2.Fb = function pIc(a) { + return this === a; + }; + _2.Oe = function qIc() { + return new Frb(this); + }; + sfb(pEe, "StretchWidthLayerer/1", 1409); + feb(413, 1, qEe); + _2.gg = function FIc(a, b, c2, d, e, f2) { + }; + _2.ug = function DIc(a, b, c2) { + return wIc(this, a, b, c2); + }; + _2.fg = function EIc() { + this.g = $C(jE, rEe, 28, this.d, 15, 1); + this.f = $C(jE, rEe, 28, this.d, 15, 1); + }; + _2.hg = function GIc(a, b) { + this.e[a] = $C(kE, Pwe, 28, b[a].length, 15, 1); + }; + _2.ig = function HIc(a, b, c2) { + var d; + d = c2[a][b]; + d.p = b; + this.e[a][b] = b; + }; + _2.jg = function IIc(a, b, c2, d) { + RD(Vmb(d[a][b].j, c2), 12).p = this.d++; + }; + _2.b = 0; + _2.c = 0; + _2.d = 0; + sfb(sEe, "AbstractBarycenterPortDistributor", 413); + feb(1698, 1, fye, JIc); + _2.Ne = function KIc(a, b) { + return zIc(this.a, RD(a, 12), RD(b, 12)); + }; + _2.Fb = function LIc(a) { + return this === a; + }; + _2.Oe = function MIc() { + return new Frb(this); + }; + sfb(sEe, "AbstractBarycenterPortDistributor/lambda$0$Type", 1698); + feb(832, 1, uBe, UIc); + _2.gg = function XIc(a, b, c2, d, e, f2) { + }; + _2.ig = function ZIc(a, b, c2) { + }; + _2.jg = function $Ic(a, b, c2, d) { + }; + _2.eg = function VIc() { + return false; + }; + _2.fg = function WIc() { + this.c = this.e.a; + this.g = this.f.g; + }; + _2.hg = function YIc(a, b) { + b[a][0].c.p = a; + }; + _2.kg = function _Ic() { + return false; + }; + _2.vg = function aJc(a, b, c2, d) { + if (c2) { + RIc(this, a); + } else { + OIc(this, a, d); + PIc(this, a, b); + } + if (a.c.length > 1) { + Heb(TD(mQb(Y2b((tFb(0, a.c.length), RD(a.c[0], 10))), (yCc(), eAc)))) ? wLc(a, this.d, RD(this, 669)) : (yob(), _mb(a, this.d)); + nJc(this.e, a); + } + }; + _2.lg = function bJc(a, b, c2, d) { + var e, f2, g, h, i2, j, k; + if (b != SIc(c2, a.length)) { + f2 = a[b - (c2 ? 1 : -1)]; + sIc(this.f, f2, c2 ? (BEc(), zEc) : (BEc(), yEc)); + } + e = a[b][0]; + k = !d || e.k == (r3b(), m3b); + j = dv(a[b]); + this.vg(j, k, false, c2); + g = 0; + for (i2 = new Anb(j); i2.a < i2.c.c.length; ) { + h = RD(ynb(i2), 10); + a[b][g++] = h; + } + return false; + }; + _2.mg = function cJc(a, b) { + var c2, d, e, f2, g; + g = SIc(b, a.length); + f2 = dv(a[g]); + this.vg(f2, false, true, b); + c2 = 0; + for (e = new Anb(f2); e.a < e.c.c.length; ) { + d = RD(ynb(e), 10); + a[g][c2++] = d; + } + return false; + }; + sfb(sEe, "BarycenterHeuristic", 832); + feb(667, 1, { 667: 1 }, dJc); + _2.Ib = function eJc() { + return "BarycenterState [node=" + this.c + ", summedWeight=" + this.d + ", degree=" + this.b + ", barycenter=" + this.a + ", visited=" + this.e + "]"; + }; + _2.b = 0; + _2.d = 0; + _2.e = false; + var aY = sfb(sEe, "BarycenterHeuristic/BarycenterState", 667); + feb(1865, 1, fye, fJc); + _2.Ne = function gJc(a, b) { + return QIc(this.a, RD(a, 10), RD(b, 10)); + }; + _2.Fb = function hJc(a) { + return this === a; + }; + _2.Oe = function iJc() { + return new Frb(this); + }; + sfb(sEe, "BarycenterHeuristic/lambda$0$Type", 1865); + feb(831, 1, uBe, qJc); + _2.fg = function rJc() { + }; + _2.gg = function sJc(a, b, c2, d, e, f2) { + }; + _2.jg = function vJc(a, b, c2, d) { + }; + _2.hg = function tJc(a, b) { + this.a[a] = $C(aY, { 3: 1, 4: 1, 5: 1, 2117: 1 }, 667, b[a].length, 0, 1); + this.b[a] = $C(dY, { 3: 1, 4: 1, 5: 1, 2118: 1 }, 239, b[a].length, 0, 1); + }; + _2.ig = function uJc(a, b, c2) { + mJc(this, c2[a][b], true); + }; + _2.c = false; + sfb(sEe, "ForsterConstraintResolver", 831); + feb(239, 1, { 239: 1 }, yJc, zJc); + _2.Ib = function AJc() { + var a, b; + b = new bib(); + b.a += "["; + for (a = 0; a < this.d.length; a++) { + Zhb(b, i3b(this.d[a])); + pJc(this.g, this.d[0]).a != null && Zhb(Zhb((b.a += "<", b), Pfb(pJc(this.g, this.d[0]).a)), ">"); + a < this.d.length - 1 && (b.a += pve, b); + } + return (b.a += "]", b).a; + }; + _2.a = 0; + _2.c = 0; + _2.f = 0; + var dY = sfb(sEe, "ForsterConstraintResolver/ConstraintGroup", 239); + feb(1860, 1, Qve, BJc); + _2.Cd = function CJc(a) { + mJc(this.a, RD(a, 10), false); + }; + sfb(sEe, "ForsterConstraintResolver/lambda$0$Type", 1860); + feb(219, 1, { 219: 1, 230: 1 }, FJc); + _2.gg = function HJc(a, b, c2, d, e, f2) { + }; + _2.hg = function IJc(a, b) { + }; + _2.fg = function GJc() { + this.r = $C(kE, Pwe, 28, this.n, 15, 1); + }; + _2.ig = function JJc(a, b, c2) { + var d, e; + e = c2[a][b]; + d = e.e; + !!d && Rmb(this.b, d); + }; + _2.jg = function KJc(a, b, c2, d) { + ++this.n; + }; + _2.Ib = function LJc() { + return Inb(this.e, new _sb()); + }; + _2.g = false; + _2.i = false; + _2.n = 0; + _2.s = false; + sfb(sEe, "GraphInfoHolder", 219); + feb(1905, 1, uBe, PJc); + _2.gg = function SJc(a, b, c2, d, e, f2) { + }; + _2.hg = function TJc(a, b) { + }; + _2.jg = function VJc(a, b, c2, d) { + }; + _2.ug = function QJc(a, b, c2) { + c2 && b > 0 ? (pMc(this.a, a[b - 1], a[b]), void 0) : !c2 && b < a.length - 1 ? (pMc(this.a, a[b], a[b + 1]), void 0) : rMc(this.a, a[b], c2 ? (qpd(), ppd) : (qpd(), Xod)); + return MJc(this, a, b, c2); + }; + _2.fg = function RJc() { + this.d = $C(kE, Pwe, 28, this.c, 15, 1); + this.a = new DMc(this.d); + }; + _2.ig = function UJc(a, b, c2) { + var d; + d = c2[a][b]; + this.c += d.j.c.length; + }; + _2.c = 0; + sfb(sEe, "GreedyPortDistributor", 1905); + feb(1421, 1, nEe, aKc); + _2.rg = function bKc(a) { + return ZJc(RD(a, 36)); + }; + _2.Kf = function cKc(a, b) { + _Jc(RD(a, 36), b); + }; + var XJc; + sfb(sEe, "InteractiveCrossingMinimizer", 1421); + feb(1422, 1, fye, eKc); + _2.Ne = function fKc(a, b) { + return dKc(this, RD(a, 10), RD(b, 10)); + }; + _2.Fb = function gKc(a) { + return this === a; + }; + _2.Oe = function hKc() { + return new Frb(this); + }; + sfb(sEe, "InteractiveCrossingMinimizer/1", 1422); + feb(514, 1, { 514: 1, 106: 1, 47: 1 }, FKc); + _2.rg = function GKc(a) { + var b; + return RD(a, 36), b = vfd(iKc), pfd(b, (sXb(), pXb), (hcc(), Ybc)), b; + }; + _2.Kf = function HKc(a, b) { + wKc(this, RD(a, 36), b); + }; + _2.e = 0; + var iKc; + sfb(sEe, "LayerSweepCrossingMinimizer", 514); + feb(1418, 1, Qve, IKc); + _2.Cd = function JKc(a) { + kKc(this.a, RD(a, 219)); + }; + sfb(sEe, "LayerSweepCrossingMinimizer/0methodref$compareDifferentRandomizedLayouts$Type", 1418); + feb(1419, 1, Qve, KKc); + _2.Cd = function LKc(a) { + tKc(this.a, RD(a, 219)); + }; + sfb(sEe, "LayerSweepCrossingMinimizer/1methodref$minimizeCrossingsNoCounter$Type", 1419); + feb(1420, 1, Qve, MKc); + _2.Cd = function NKc(a) { + vKc(this.a, RD(a, 219)); + }; + sfb(sEe, "LayerSweepCrossingMinimizer/2methodref$minimizeCrossingsWithCounter$Type", 1420); + feb(464, 22, { 3: 1, 34: 1, 22: 1, 464: 1 }, SKc); + var OKc, PKc, QKc; + var nY = tfb(sEe, "LayerSweepCrossingMinimizer/CrossMinType", 464, WI, UKc, TKc); + var VKc; + feb(1417, 1, nwe, XKc); + _2.Mb = function YKc(a) { + return jKc(), RD(a, 30).a.c.length == 0; + }; + sfb(sEe, "LayerSweepCrossingMinimizer/lambda$0$Type", 1417); + feb(1862, 1, uBe, _Kc); + _2.fg = function aLc() { + }; + _2.gg = function bLc(a, b, c2, d, e, f2) { + }; + _2.jg = function eLc(a, b, c2, d) { + }; + _2.hg = function cLc(a, b) { + b[a][0].c.p = a; + this.b[a] = $C(qY, { 3: 1, 4: 1, 5: 1, 2043: 1 }, 668, b[a].length, 0, 1); + }; + _2.ig = function dLc(a, b, c2) { + var d; + d = c2[a][b]; + d.p = b; + bD(this.b[a], b, new fLc()); + }; + sfb(sEe, "LayerSweepTypeDecider", 1862); + feb(668, 1, { 668: 1 }, fLc); + _2.Ib = function gLc() { + return "NodeInfo [connectedEdges=" + this.a + ", hierarchicalInfluence=" + this.b + ", randomInfluence=" + this.c + "]"; + }; + _2.a = 0; + _2.b = 0; + _2.c = 0; + var qY = sfb(sEe, "LayerSweepTypeDecider/NodeInfo", 668); + feb(1863, 1, xye, hLc); + _2.Lb = function iLc(a) { + return k4b(new l4b(RD(a, 12).b)); + }; + _2.Fb = function jLc(a) { + return this === a; + }; + _2.Mb = function kLc(a) { + return k4b(new l4b(RD(a, 12).b)); + }; + sfb(sEe, "LayerSweepTypeDecider/lambda$0$Type", 1863); + feb(1864, 1, xye, lLc); + _2.Lb = function mLc(a) { + return k4b(new l4b(RD(a, 12).b)); + }; + _2.Fb = function nLc(a) { + return this === a; + }; + _2.Mb = function oLc(a) { + return k4b(new l4b(RD(a, 12).b)); + }; + sfb(sEe, "LayerSweepTypeDecider/lambda$1$Type", 1864); + feb(1906, 413, qEe, pLc); + _2.tg = function qLc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l; + j = this.g; + switch (c2.g) { + case 1: { + d = 0; + e = 0; + for (i2 = new Anb(a.j); i2.a < i2.c.c.length; ) { + g = RD(ynb(i2), 12); + if (g.e.c.length != 0) { + ++d; + g.j == (qpd(), Yod) && ++e; + } + } + f2 = b + e; + l = b + d; + for (h = c3b(a, (BEc(), yEc)).Kc(); h.Ob(); ) { + g = RD(h.Pb(), 12); + if (g.j == (qpd(), Yod)) { + j[g.p] = f2; + --f2; + } else { + j[g.p] = l; + --l; + } + } + return d; + } + case 2: { + k = 0; + for (h = c3b(a, (BEc(), zEc)).Kc(); h.Ob(); ) { + g = RD(h.Pb(), 12); + ++k; + j[g.p] = b + k; + } + return k; + } + default: + throw Adb(new _fb()); + } + }; + sfb(sEe, "LayerTotalPortDistributor", 1906); + feb(669, 832, { 669: 1, 230: 1 }, vLc); + _2.vg = function xLc(a, b, c2, d) { + if (c2) { + RIc(this, a); + } else { + OIc(this, a, d); + PIc(this, a, b); + } + if (a.c.length > 1) { + Heb(TD(mQb(Y2b((tFb(0, a.c.length), RD(a.c[0], 10))), (yCc(), eAc)))) ? wLc(a, this.d, this) : (yob(), _mb(a, this.d)); + Heb(TD(mQb(Y2b((tFb(0, a.c.length), RD(a.c[0], 10))), eAc))) || nJc(this.e, a); + } + }; + sfb(sEe, "ModelOrderBarycenterHeuristic", 669); + feb(1866, 1, fye, yLc); + _2.Ne = function zLc(a, b) { + return tLc(this.a, RD(a, 10), RD(b, 10)); + }; + _2.Fb = function ALc(a) { + return this === a; + }; + _2.Oe = function BLc() { + return new Frb(this); + }; + sfb(sEe, "ModelOrderBarycenterHeuristic/lambda$0$Type", 1866); + feb(1423, 1, nEe, FLc); + _2.rg = function GLc(a) { + var b; + return RD(a, 36), b = vfd(CLc), pfd(b, (sXb(), pXb), (hcc(), Ybc)), b; + }; + _2.Kf = function HLc(a, b) { + ELc((RD(a, 36), b)); + }; + var CLc; + sfb(sEe, "NoCrossingMinimizer", 1423); + feb(809, 413, qEe, ILc); + _2.tg = function JLc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n; + l = this.g; + switch (c2.g) { + case 1: { + e = 0; + f2 = 0; + for (k = new Anb(a.j); k.a < k.c.c.length; ) { + i2 = RD(ynb(k), 12); + if (i2.e.c.length != 0) { + ++e; + i2.j == (qpd(), Yod) && ++f2; + } + } + d = 1 / (e + 1); + g = b + f2 * d; + n = b + 1 - d; + for (j = c3b(a, (BEc(), yEc)).Kc(); j.Ob(); ) { + i2 = RD(j.Pb(), 12); + if (i2.j == (qpd(), Yod)) { + l[i2.p] = g; + g -= d; + } else { + l[i2.p] = n; + n -= d; + } + } + break; + } + case 2: { + h = 0; + for (k = new Anb(a.j); k.a < k.c.c.length; ) { + i2 = RD(ynb(k), 12); + i2.g.c.length == 0 || ++h; + } + d = 1 / (h + 1); + m = b + d; + for (j = c3b(a, (BEc(), zEc)).Kc(); j.Ob(); ) { + i2 = RD(j.Pb(), 12); + l[i2.p] = m; + m += d; + } + break; + } + default: + throw Adb(new agb("Port type is undefined")); + } + return 1; + }; + sfb(sEe, "NodeRelativePortDistributor", 809); + feb(822, 1, {}, NLc, OLc); + sfb(sEe, "SweepCopy", 822); + feb(1861, 1, uBe, RLc); + _2.hg = function ULc(a, b) { + }; + _2.fg = function SLc() { + var a; + a = $C(kE, Pwe, 28, this.f, 15, 1); + this.d = new jNc(a); + this.a = new DMc(a); + }; + _2.gg = function TLc(a, b, c2, d, e, f2) { + var g; + g = RD(Vmb(f2[a][b].j, c2), 12); + e.c == g && e.c.i.c == e.d.i.c && ++this.e[a]; + }; + _2.ig = function VLc(a, b, c2) { + var d; + d = c2[a][b]; + this.c[a] = this.c[a] | d.k == (r3b(), q3b); + }; + _2.jg = function WLc(a, b, c2, d) { + var e; + e = RD(Vmb(d[a][b].j, c2), 12); + e.p = this.f++; + e.g.c.length + e.e.c.length > 1 && (e.j == (qpd(), Xod) ? this.b[a] = true : e.j == ppd && a > 0 && (this.b[a - 1] = true)); + }; + _2.f = 0; + sfb(tBe, "AllCrossingsCounter", 1861); + feb(595, 1, {}, _Lc); + _2.b = 0; + _2.d = 0; + sfb(tBe, "BinaryIndexedTree", 595); + feb(532, 1, {}, DMc); + var bMc, cMc; + sfb(tBe, "CrossingsCounter", 532); + feb(1950, 1, fye, HMc); + _2.Ne = function IMc(a, b) { + return wMc(this.a, RD(a, 12), RD(b, 12)); + }; + _2.Fb = function JMc(a) { + return this === a; + }; + _2.Oe = function KMc() { + return new Frb(this); + }; + sfb(tBe, "CrossingsCounter/lambda$0$Type", 1950); + feb(1951, 1, fye, LMc); + _2.Ne = function MMc(a, b) { + return xMc(this.a, RD(a, 12), RD(b, 12)); + }; + _2.Fb = function NMc(a) { + return this === a; + }; + _2.Oe = function OMc() { + return new Frb(this); + }; + sfb(tBe, "CrossingsCounter/lambda$1$Type", 1951); + feb(1952, 1, fye, PMc); + _2.Ne = function QMc(a, b) { + return yMc(this.a, RD(a, 12), RD(b, 12)); + }; + _2.Fb = function RMc(a) { + return this === a; + }; + _2.Oe = function SMc() { + return new Frb(this); + }; + sfb(tBe, "CrossingsCounter/lambda$2$Type", 1952); + feb(1953, 1, fye, TMc); + _2.Ne = function UMc(a, b) { + return zMc(this.a, RD(a, 12), RD(b, 12)); + }; + _2.Fb = function VMc(a) { + return this === a; + }; + _2.Oe = function WMc() { + return new Frb(this); + }; + sfb(tBe, "CrossingsCounter/lambda$3$Type", 1953); + feb(1954, 1, Qve, XMc); + _2.Cd = function YMc(a) { + EMc(this.a, RD(a, 12)); + }; + sfb(tBe, "CrossingsCounter/lambda$4$Type", 1954); + feb(1955, 1, nwe, ZMc); + _2.Mb = function $Mc(a) { + return FMc(this.a, RD(a, 12)); + }; + sfb(tBe, "CrossingsCounter/lambda$5$Type", 1955); + feb(1956, 1, Qve, aNc); + _2.Cd = function bNc(a) { + _Mc(this, a); + }; + sfb(tBe, "CrossingsCounter/lambda$6$Type", 1956); + feb(1957, 1, Qve, cNc); + _2.Cd = function dNc(a) { + var b; + dMc(); + hmb(this.b, (b = this.a, RD(a, 12), b)); + }; + sfb(tBe, "CrossingsCounter/lambda$7$Type", 1957); + feb(839, 1, xye, eNc); + _2.Lb = function fNc(a) { + return dMc(), nQb(RD(a, 12), (Ywc(), Iwc)); + }; + _2.Fb = function gNc(a) { + return this === a; + }; + _2.Mb = function hNc(a) { + return dMc(), nQb(RD(a, 12), (Ywc(), Iwc)); + }; + sfb(tBe, "CrossingsCounter/lambda$8$Type", 839); + feb(1949, 1, {}, jNc); + sfb(tBe, "HyperedgeCrossingsCounter", 1949); + feb(478, 1, { 34: 1, 478: 1 }, lNc); + _2.Fd = function mNc(a) { + return kNc(this, RD(a, 478)); + }; + _2.b = 0; + _2.c = 0; + _2.e = 0; + _2.f = 0; + var OY = sfb(tBe, "HyperedgeCrossingsCounter/Hyperedge", 478); + feb(374, 1, { 34: 1, 374: 1 }, oNc); + _2.Fd = function pNc(a) { + return nNc(this, RD(a, 374)); + }; + _2.b = 0; + _2.c = 0; + var NY = sfb(tBe, "HyperedgeCrossingsCounter/HyperedgeCorner", 374); + feb(531, 22, { 3: 1, 34: 1, 22: 1, 531: 1 }, tNc); + var qNc, rNc; + var MY = tfb(tBe, "HyperedgeCrossingsCounter/HyperedgeCorner/Type", 531, WI, vNc, uNc); + var wNc; + feb(1425, 1, nEe, DNc); + _2.rg = function ENc(a) { + return RD(mQb(RD(a, 36), (Ywc(), kwc)), 21).Hc((ovc(), hvc)) ? zNc : null; + }; + _2.Kf = function FNc(a, b) { + CNc(this, RD(a, 36), b); + }; + var zNc; + sfb(tEe, "InteractiveNodePlacer", 1425); + feb(1426, 1, nEe, TNc); + _2.rg = function UNc(a) { + return RD(mQb(RD(a, 36), (Ywc(), kwc)), 21).Hc((ovc(), hvc)) ? GNc : null; + }; + _2.Kf = function VNc(a, b) { + RNc(this, RD(a, 36), b); + }; + var GNc, HNc, INc; + sfb(tEe, "LinearSegmentsNodePlacer", 1426); + feb(261, 1, { 34: 1, 261: 1 }, ZNc); + _2.Fd = function $Nc(a) { + return WNc(this, RD(a, 261)); + }; + _2.Fb = function _Nc(a) { + var b; + if (ZD(a, 261)) { + b = RD(a, 261); + return this.b == b.b; + } + return false; + }; + _2.Hb = function aOc() { + return this.b; + }; + _2.Ib = function bOc() { + return "ls" + Fe(this.e); + }; + _2.a = 0; + _2.b = 0; + _2.c = -1; + _2.d = -1; + _2.g = 0; + var SY = sfb(tEe, "LinearSegmentsNodePlacer/LinearSegment", 261); + feb(1428, 1, nEe, yOc); + _2.rg = function zOc(a) { + return RD(mQb(RD(a, 36), (Ywc(), kwc)), 21).Hc((ovc(), hvc)) ? cOc : null; + }; + _2.Kf = function HOc(a, b) { + uOc(this, RD(a, 36), b); + }; + _2.b = 0; + _2.g = 0; + var cOc; + sfb(tEe, "NetworkSimplexPlacer", 1428); + feb(1447, 1, fye, IOc); + _2.Ne = function JOc(a, b) { + return hgb(RD(a, 17).a, RD(b, 17).a); + }; + _2.Fb = function KOc(a) { + return this === a; + }; + _2.Oe = function LOc() { + return new Frb(this); + }; + sfb(tEe, "NetworkSimplexPlacer/0methodref$compare$Type", 1447); + feb(1449, 1, fye, MOc); + _2.Ne = function NOc(a, b) { + return hgb(RD(a, 17).a, RD(b, 17).a); + }; + _2.Fb = function OOc(a) { + return this === a; + }; + _2.Oe = function POc() { + return new Frb(this); + }; + sfb(tEe, "NetworkSimplexPlacer/1methodref$compare$Type", 1449); + feb(655, 1, { 655: 1 }, QOc); + var WY = sfb(tEe, "NetworkSimplexPlacer/EdgeRep", 655); + feb(412, 1, { 412: 1 }, ROc); + _2.b = false; + var XY = sfb(tEe, "NetworkSimplexPlacer/NodeRep", 412); + feb(515, 13, { 3: 1, 4: 1, 20: 1, 31: 1, 56: 1, 13: 1, 16: 1, 15: 1, 59: 1, 515: 1 }, VOc); + sfb(tEe, "NetworkSimplexPlacer/Path", 515); + feb(1429, 1, {}, WOc); + _2.Kb = function XOc(a) { + return RD(a, 18).d.i.k; + }; + sfb(tEe, "NetworkSimplexPlacer/Path/lambda$0$Type", 1429); + feb(1430, 1, nwe, YOc); + _2.Mb = function ZOc(a) { + return RD(a, 273) == (r3b(), o3b); + }; + sfb(tEe, "NetworkSimplexPlacer/Path/lambda$1$Type", 1430); + feb(1431, 1, {}, $Oc); + _2.Kb = function _Oc(a) { + return RD(a, 18).d.i; + }; + sfb(tEe, "NetworkSimplexPlacer/Path/lambda$2$Type", 1431); + feb(1432, 1, nwe, aPc); + _2.Mb = function bPc(a) { + return EPc(zDc(RD(a, 10))); + }; + sfb(tEe, "NetworkSimplexPlacer/Path/lambda$3$Type", 1432); + feb(1433, 1, nwe, cPc); + _2.Mb = function dPc(a) { + return DOc(RD(a, 12)); + }; + sfb(tEe, "NetworkSimplexPlacer/lambda$0$Type", 1433); + feb(1434, 1, Qve, ePc); + _2.Cd = function fPc(a) { + jOc(this.a, this.b, RD(a, 12)); + }; + sfb(tEe, "NetworkSimplexPlacer/lambda$1$Type", 1434); + feb(1443, 1, Qve, gPc); + _2.Cd = function hPc(a) { + kOc(this.a, RD(a, 18)); + }; + sfb(tEe, "NetworkSimplexPlacer/lambda$10$Type", 1443); + feb(1444, 1, {}, iPc); + _2.Kb = function jPc(a) { + return dOc(), new SDb(null, new Swb(RD(a, 30).a, 16)); + }; + sfb(tEe, "NetworkSimplexPlacer/lambda$11$Type", 1444); + feb(1445, 1, Qve, kPc); + _2.Cd = function lPc(a) { + lOc(this.a, RD(a, 10)); + }; + sfb(tEe, "NetworkSimplexPlacer/lambda$12$Type", 1445); + feb(1446, 1, {}, mPc); + _2.Kb = function nPc(a) { + return dOc(), sgb(RD(a, 125).e); + }; + sfb(tEe, "NetworkSimplexPlacer/lambda$13$Type", 1446); + feb(1448, 1, {}, oPc); + _2.Kb = function pPc(a) { + return dOc(), sgb(RD(a, 125).e); + }; + sfb(tEe, "NetworkSimplexPlacer/lambda$15$Type", 1448); + feb(1450, 1, nwe, qPc); + _2.Mb = function rPc(a) { + return dOc(), RD(a, 412).c.k == (r3b(), p3b); + }; + sfb(tEe, "NetworkSimplexPlacer/lambda$17$Type", 1450); + feb(1451, 1, nwe, sPc); + _2.Mb = function tPc(a) { + return dOc(), RD(a, 412).c.j.c.length > 1; + }; + sfb(tEe, "NetworkSimplexPlacer/lambda$18$Type", 1451); + feb(1452, 1, Qve, uPc); + _2.Cd = function vPc(a) { + EOc(this.c, this.b, this.d, this.a, RD(a, 412)); + }; + _2.c = 0; + _2.d = 0; + sfb(tEe, "NetworkSimplexPlacer/lambda$19$Type", 1452); + feb(1435, 1, {}, wPc); + _2.Kb = function xPc(a) { + return dOc(), new SDb(null, new Swb(RD(a, 30).a, 16)); + }; + sfb(tEe, "NetworkSimplexPlacer/lambda$2$Type", 1435); + feb(1453, 1, Qve, yPc); + _2.Cd = function zPc(a) { + FOc(this.a, RD(a, 12)); + }; + _2.a = 0; + sfb(tEe, "NetworkSimplexPlacer/lambda$20$Type", 1453); + feb(1454, 1, {}, APc); + _2.Kb = function BPc(a) { + return dOc(), new SDb(null, new Swb(RD(a, 30).a, 16)); + }; + sfb(tEe, "NetworkSimplexPlacer/lambda$21$Type", 1454); + feb(1455, 1, Qve, CPc); + _2.Cd = function DPc(a) { + mOc(this.a, RD(a, 10)); + }; + sfb(tEe, "NetworkSimplexPlacer/lambda$22$Type", 1455); + feb(1456, 1, nwe, FPc); + _2.Mb = function GPc(a) { + return EPc(a); + }; + sfb(tEe, "NetworkSimplexPlacer/lambda$23$Type", 1456); + feb(1457, 1, {}, HPc); + _2.Kb = function IPc(a) { + return dOc(), new SDb(null, new Swb(RD(a, 30).a, 16)); + }; + sfb(tEe, "NetworkSimplexPlacer/lambda$24$Type", 1457); + feb(1458, 1, nwe, JPc); + _2.Mb = function KPc(a) { + return nOc(this.a, RD(a, 10)); + }; + sfb(tEe, "NetworkSimplexPlacer/lambda$25$Type", 1458); + feb(1459, 1, Qve, LPc); + _2.Cd = function MPc(a) { + oOc(this.a, this.b, RD(a, 10)); + }; + sfb(tEe, "NetworkSimplexPlacer/lambda$26$Type", 1459); + feb(1460, 1, nwe, NPc); + _2.Mb = function OPc(a) { + return dOc(), !W0b(RD(a, 18)); + }; + sfb(tEe, "NetworkSimplexPlacer/lambda$27$Type", 1460); + feb(1461, 1, nwe, PPc); + _2.Mb = function QPc(a) { + return dOc(), !W0b(RD(a, 18)); + }; + sfb(tEe, "NetworkSimplexPlacer/lambda$28$Type", 1461); + feb(1462, 1, {}, RPc); + _2.Ve = function SPc(a, b) { + return pOc(this.a, RD(a, 30), RD(b, 30)); + }; + sfb(tEe, "NetworkSimplexPlacer/lambda$29$Type", 1462); + feb(1436, 1, {}, TPc); + _2.Kb = function UPc(a) { + return dOc(), new SDb(null, new Twb(new is(Mr(a3b(RD(a, 10)).a.Kc(), new ir())))); + }; + sfb(tEe, "NetworkSimplexPlacer/lambda$3$Type", 1436); + feb(1437, 1, nwe, VPc); + _2.Mb = function WPc(a) { + return dOc(), COc(RD(a, 18)); + }; + sfb(tEe, "NetworkSimplexPlacer/lambda$4$Type", 1437); + feb(1438, 1, Qve, XPc); + _2.Cd = function YPc(a) { + vOc(this.a, RD(a, 18)); + }; + sfb(tEe, "NetworkSimplexPlacer/lambda$5$Type", 1438); + feb(1439, 1, {}, ZPc); + _2.Kb = function $Pc(a) { + return dOc(), new SDb(null, new Swb(RD(a, 30).a, 16)); + }; + sfb(tEe, "NetworkSimplexPlacer/lambda$6$Type", 1439); + feb(1440, 1, nwe, _Pc); + _2.Mb = function aQc(a) { + return dOc(), RD(a, 10).k == (r3b(), p3b); + }; + sfb(tEe, "NetworkSimplexPlacer/lambda$7$Type", 1440); + feb(1441, 1, {}, bQc); + _2.Kb = function cQc(a) { + return dOc(), new SDb(null, new Twb(new is(Mr(W2b(RD(a, 10)).a.Kc(), new ir())))); + }; + sfb(tEe, "NetworkSimplexPlacer/lambda$8$Type", 1441); + feb(1442, 1, nwe, dQc); + _2.Mb = function eQc(a) { + return dOc(), V0b(RD(a, 18)); + }; + sfb(tEe, "NetworkSimplexPlacer/lambda$9$Type", 1442); + feb(1424, 1, nEe, iQc); + _2.rg = function jQc(a) { + return RD(mQb(RD(a, 36), (Ywc(), kwc)), 21).Hc((ovc(), hvc)) ? fQc : null; + }; + _2.Kf = function kQc(a, b) { + hQc(RD(a, 36), b); + }; + var fQc; + sfb(tEe, "SimpleNodePlacer", 1424); + feb(185, 1, { 185: 1 }, sQc); + _2.Ib = function tQc() { + var a; + a = ""; + this.c == (wQc(), vQc) ? a += Oye : this.c == uQc && (a += Nye); + this.o == (EQc(), CQc) ? a += Zye : this.o == DQc ? a += "UP" : a += "BALANCED"; + return a; + }; + sfb(wEe, "BKAlignedLayout", 185); + feb(523, 22, { 3: 1, 34: 1, 22: 1, 523: 1 }, xQc); + var uQc, vQc; + var FZ = tfb(wEe, "BKAlignedLayout/HDirection", 523, WI, zQc, yQc); + var AQc; + feb(522, 22, { 3: 1, 34: 1, 22: 1, 522: 1 }, FQc); + var CQc, DQc; + var GZ = tfb(wEe, "BKAlignedLayout/VDirection", 522, WI, HQc, GQc); + var IQc; + feb(1699, 1, {}, MQc); + sfb(wEe, "BKAligner", 1699); + feb(1702, 1, {}, RQc); + sfb(wEe, "BKCompactor", 1702); + feb(663, 1, { 663: 1 }, SQc); + _2.a = 0; + sfb(wEe, "BKCompactor/ClassEdge", 663); + feb(467, 1, { 467: 1 }, UQc); + _2.a = null; + _2.b = 0; + sfb(wEe, "BKCompactor/ClassNode", 467); + feb(1427, 1, nEe, aRc); + _2.rg = function eRc(a) { + return RD(mQb(RD(a, 36), (Ywc(), kwc)), 21).Hc((ovc(), hvc)) ? VQc : null; + }; + _2.Kf = function fRc(a, b) { + _Qc(this, RD(a, 36), b); + }; + _2.d = false; + var VQc; + sfb(wEe, "BKNodePlacer", 1427); + feb(1700, 1, {}, hRc); + _2.d = 0; + sfb(wEe, "NeighborhoodInformation", 1700); + feb(1701, 1, fye, mRc); + _2.Ne = function nRc(a, b) { + return lRc(this, RD(a, 42), RD(b, 42)); + }; + _2.Fb = function oRc(a) { + return this === a; + }; + _2.Oe = function pRc() { + return new Frb(this); + }; + sfb(wEe, "NeighborhoodInformation/NeighborComparator", 1701); + feb(823, 1, {}); + sfb(wEe, "ThresholdStrategy", 823); + feb(1825, 823, {}, uRc); + _2.wg = function vRc(a, b, c2) { + return this.a.o == (EQc(), DQc) ? oxe : pxe; + }; + _2.xg = function wRc() { + }; + sfb(wEe, "ThresholdStrategy/NullThresholdStrategy", 1825); + feb(587, 1, { 587: 1 }, xRc); + _2.c = false; + _2.d = false; + sfb(wEe, "ThresholdStrategy/Postprocessable", 587); + feb(1826, 823, {}, BRc); + _2.wg = function CRc(a, b, c2) { + var d, e, f2; + e = b == c2; + d = this.a.a[c2.p] == b; + if (!(e || d)) { + return a; + } + f2 = a; + if (this.a.c == (wQc(), vQc)) { + e && (f2 = yRc(this, b, true)); + !isNaN(f2) && !isFinite(f2) && d && (f2 = yRc(this, c2, false)); + } else { + e && (f2 = yRc(this, b, true)); + !isNaN(f2) && !isFinite(f2) && d && (f2 = yRc(this, c2, false)); + } + return f2; + }; + _2.xg = function DRc() { + var a, b, c2, d, e; + while (this.d.b != 0) { + e = RD(Tub(this.d), 587); + d = zRc(this, e); + if (!d.a) { + continue; + } + a = d.a; + c2 = Heb(this.a.f[this.a.g[e.b.p].p]); + if (!c2 && !W0b(a) && a.c.i.c == a.d.i.c) { + continue; + } + b = ARc(this, e); + b || Eyb(this.e, e); + } + while (this.e.a.c.length != 0) { + ARc(this, RD(Dyb(this.e), 587)); + } + }; + sfb(wEe, "ThresholdStrategy/SimpleThresholdStrategy", 1826); + feb(645, 1, { 645: 1, 188: 1, 196: 1 }, HRc); + _2.dg = function JRc() { + return GRc(this); + }; + _2.qg = function IRc() { + return GRc(this); + }; + var ERc; + sfb(xEe, "EdgeRouterFactory", 645); + feb(1485, 1, nEe, WRc); + _2.rg = function XRc(a) { + return URc(RD(a, 36)); + }; + _2.Kf = function YRc(a, b) { + VRc(RD(a, 36), b); + }; + var LRc, MRc, NRc, ORc, PRc, QRc, RRc, SRc; + sfb(xEe, "OrthogonalEdgeRouter", 1485); + feb(1478, 1, nEe, lSc); + _2.rg = function mSc(a) { + return gSc(RD(a, 36)); + }; + _2.Kf = function nSc(a, b) { + iSc(this, RD(a, 36), b); + }; + var ZRc, $Rc, _Rc, aSc, bSc, cSc; + sfb(xEe, "PolylineEdgeRouter", 1478); + feb(1479, 1, xye, pSc); + _2.Lb = function qSc(a) { + return oSc(RD(a, 10)); + }; + _2.Fb = function rSc(a) { + return this === a; + }; + _2.Mb = function sSc(a) { + return oSc(RD(a, 10)); + }; + sfb(xEe, "PolylineEdgeRouter/1", 1479); + feb(1872, 1, nwe, xSc); + _2.Mb = function ySc(a) { + return RD(a, 132).c == (fTc(), dTc); + }; + sfb(yEe, "HyperEdgeCycleDetector/lambda$0$Type", 1872); + feb(1873, 1, {}, zSc); + _2.Ze = function ASc(a) { + return RD(a, 132).d; + }; + sfb(yEe, "HyperEdgeCycleDetector/lambda$1$Type", 1873); + feb(1874, 1, nwe, BSc); + _2.Mb = function CSc(a) { + return RD(a, 132).c == (fTc(), dTc); + }; + sfb(yEe, "HyperEdgeCycleDetector/lambda$2$Type", 1874); + feb(1875, 1, {}, DSc); + _2.Ze = function ESc(a) { + return RD(a, 132).d; + }; + sfb(yEe, "HyperEdgeCycleDetector/lambda$3$Type", 1875); + feb(1876, 1, {}, FSc); + _2.Ze = function GSc(a) { + return RD(a, 132).d; + }; + sfb(yEe, "HyperEdgeCycleDetector/lambda$4$Type", 1876); + feb(1877, 1, {}, HSc); + _2.Ze = function ISc(a) { + return RD(a, 132).d; + }; + sfb(yEe, "HyperEdgeCycleDetector/lambda$5$Type", 1877); + feb(118, 1, { 34: 1, 118: 1 }, USc); + _2.Fd = function VSc(a) { + return KSc(this, RD(a, 118)); + }; + _2.Fb = function WSc(a) { + var b; + if (ZD(a, 118)) { + b = RD(a, 118); + return this.g == b.g; + } + return false; + }; + _2.Hb = function XSc() { + return this.g; + }; + _2.Ib = function ZSc() { + var a, b, c2, d; + a = new dib("{"); + d = new Anb(this.n); + while (d.a < d.c.c.length) { + c2 = RD(ynb(d), 12); + b = X2b(c2.i); + b == null && (b = "n" + $2b(c2.i)); + a.a += "" + b; + d.a < d.c.c.length && (a.a += ",", a); + } + a.a += "}"; + return a.a; + }; + _2.a = 0; + _2.b = 0; + _2.c = NaN; + _2.d = 0; + _2.g = 0; + _2.i = 0; + _2.o = 0; + _2.s = NaN; + sfb(yEe, "HyperEdgeSegment", 118); + feb(132, 1, { 132: 1 }, bTc); + _2.Ib = function cTc() { + return this.a + "->" + this.b + " (" + os(this.c) + ")"; + }; + _2.d = 0; + sfb(yEe, "HyperEdgeSegmentDependency", 132); + feb(528, 22, { 3: 1, 34: 1, 22: 1, 528: 1 }, gTc); + var dTc, eTc; + var b$ = tfb(yEe, "HyperEdgeSegmentDependency/DependencyType", 528, WI, iTc, hTc); + var jTc; + feb(1878, 1, {}, xTc); + sfb(yEe, "HyperEdgeSegmentSplitter", 1878); + feb(1879, 1, {}, ATc); + _2.a = 0; + _2.b = 0; + sfb(yEe, "HyperEdgeSegmentSplitter/AreaRating", 1879); + feb(339, 1, { 339: 1 }, BTc); + _2.a = 0; + _2.b = 0; + _2.c = 0; + sfb(yEe, "HyperEdgeSegmentSplitter/FreeArea", 339); + feb(1880, 1, fye, CTc); + _2.Ne = function DTc(a, b) { + return zTc(RD(a, 118), RD(b, 118)); + }; + _2.Fb = function ETc(a) { + return this === a; + }; + _2.Oe = function FTc() { + return new Frb(this); + }; + sfb(yEe, "HyperEdgeSegmentSplitter/lambda$0$Type", 1880); + feb(1881, 1, Qve, GTc); + _2.Cd = function HTc(a) { + rTc(this.a, this.d, this.c, this.b, RD(a, 118)); + }; + _2.b = 0; + sfb(yEe, "HyperEdgeSegmentSplitter/lambda$1$Type", 1881); + feb(1882, 1, {}, ITc); + _2.Kb = function JTc(a) { + return new SDb(null, new Swb(RD(a, 118).e, 16)); + }; + sfb(yEe, "HyperEdgeSegmentSplitter/lambda$2$Type", 1882); + feb(1883, 1, {}, KTc); + _2.Kb = function LTc(a) { + return new SDb(null, new Swb(RD(a, 118).j, 16)); + }; + sfb(yEe, "HyperEdgeSegmentSplitter/lambda$3$Type", 1883); + feb(1884, 1, {}, MTc); + _2.Ye = function NTc(a) { + return Kfb(UD(a)); + }; + sfb(yEe, "HyperEdgeSegmentSplitter/lambda$4$Type", 1884); + feb(664, 1, {}, TTc); + _2.a = 0; + _2.b = 0; + _2.c = 0; + sfb(yEe, "OrthogonalRoutingGenerator", 664); + feb(1703, 1, {}, XTc); + _2.Kb = function YTc(a) { + return new SDb(null, new Swb(RD(a, 118).e, 16)); + }; + sfb(yEe, "OrthogonalRoutingGenerator/lambda$0$Type", 1703); + feb(1704, 1, {}, ZTc); + _2.Kb = function $Tc(a) { + return new SDb(null, new Swb(RD(a, 118).j, 16)); + }; + sfb(yEe, "OrthogonalRoutingGenerator/lambda$1$Type", 1704); + feb(670, 1, {}); + sfb(zEe, "BaseRoutingDirectionStrategy", 670); + feb(1870, 670, {}, cUc); + _2.yg = function dUc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p; + if (!!a.r && !a.q) { + return; + } + k = b + a.o * c2; + for (j = new Anb(a.n); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 12); + l = xjd(cD(WC(l3, 1), Nve, 8, 0, [i2.i.n, i2.n, i2.a])).a; + for (h = new Anb(i2.g); h.a < h.c.c.length; ) { + g = RD(ynb(h), 18); + if (!W0b(g)) { + o2 = g.d; + p = xjd(cD(WC(l3, 1), Nve, 8, 0, [o2.i.n, o2.n, o2.a])).a; + if ($wnd.Math.abs(l - p) > Vze) { + f2 = k; + e = a; + d = new rjd(l, f2); + Mub(g.a, d); + _Tc(this, g, e, d, false); + m = a.r; + if (m) { + n = Kfb(UD(ju(m.e, 0))); + d = new rjd(n, f2); + Mub(g.a, d); + _Tc(this, g, e, d, false); + f2 = b + m.o * c2; + e = m; + d = new rjd(n, f2); + Mub(g.a, d); + _Tc(this, g, e, d, false); + } + d = new rjd(p, f2); + Mub(g.a, d); + _Tc(this, g, e, d, false); + } + } + } + } + }; + _2.zg = function eUc(a) { + return a.i.n.a + a.n.a + a.a.a; + }; + _2.Ag = function fUc() { + return qpd(), npd; + }; + _2.Bg = function gUc() { + return qpd(), Yod; + }; + sfb(zEe, "NorthToSouthRoutingStrategy", 1870); + feb(1871, 670, {}, hUc); + _2.yg = function iUc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p; + if (!!a.r && !a.q) { + return; + } + k = b - a.o * c2; + for (j = new Anb(a.n); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 12); + l = xjd(cD(WC(l3, 1), Nve, 8, 0, [i2.i.n, i2.n, i2.a])).a; + for (h = new Anb(i2.g); h.a < h.c.c.length; ) { + g = RD(ynb(h), 18); + if (!W0b(g)) { + o2 = g.d; + p = xjd(cD(WC(l3, 1), Nve, 8, 0, [o2.i.n, o2.n, o2.a])).a; + if ($wnd.Math.abs(l - p) > Vze) { + f2 = k; + e = a; + d = new rjd(l, f2); + Mub(g.a, d); + _Tc(this, g, e, d, false); + m = a.r; + if (m) { + n = Kfb(UD(ju(m.e, 0))); + d = new rjd(n, f2); + Mub(g.a, d); + _Tc(this, g, e, d, false); + f2 = b - m.o * c2; + e = m; + d = new rjd(n, f2); + Mub(g.a, d); + _Tc(this, g, e, d, false); + } + d = new rjd(p, f2); + Mub(g.a, d); + _Tc(this, g, e, d, false); + } + } + } + } + }; + _2.zg = function jUc(a) { + return a.i.n.a + a.n.a + a.a.a; + }; + _2.Ag = function kUc() { + return qpd(), Yod; + }; + _2.Bg = function lUc() { + return qpd(), npd; + }; + sfb(zEe, "SouthToNorthRoutingStrategy", 1871); + feb(1869, 670, {}, mUc); + _2.yg = function nUc(a, b, c2) { + var d, e, f2, g, h, i2, j, k, l, m, n, o2, p; + if (!!a.r && !a.q) { + return; + } + k = b + a.o * c2; + for (j = new Anb(a.n); j.a < j.c.c.length; ) { + i2 = RD(ynb(j), 12); + l = xjd(cD(WC(l3, 1), Nve, 8, 0, [i2.i.n, i2.n, i2.a])).b; + for (h = new Anb(i2.g); h.a < h.c.c.length; ) { + g = RD(ynb(h), 18); + if (!W0b(g)) { + o2 = g.d; + p = xjd(cD(WC(l3, 1), Nve, 8, 0, [o2.i.n, o2.n, o2.a])).b; + if ($wnd.Math.abs(l - p) > Vze) { + f2 = k; + e = a; + d = new rjd(f2, l); + Mub(g.a, d); + _Tc(this, g, e, d, true); + m = a.r; + if (m) { + n = Kfb(UD(ju(m.e, 0))); + d = new rjd(f2, n); + Mub(g.a, d); + _Tc(this, g, e, d, true); + f2 = b + m.o * c2; + e = m; + d = new rjd(f2, n); + Mub(g.a, d); + _Tc(this, g, e, d, true); + } + d = new rjd(f2, p); + Mub(g.a, d); + _Tc(this, g, e, d, true); + } + } + } + } + }; + _2.zg = function oUc(a) { + return a.i.n.b + a.n.b + a.a.b; + }; + _2.Ag = function pUc() { + return qpd(), Xod; + }; + _2.Bg = function qUc() { + return qpd(), ppd; + }; + sfb(zEe, "WestToEastRoutingStrategy", 1869); + feb(828, 1, {}, wUc); + _2.Ib = function xUc() { + return Fe(this.a); + }; + _2.b = 0; + _2.c = false; + _2.d = false; + _2.f = 0; + sfb(BEe, "NubSpline", 828); + feb(418, 1, { 418: 1 }, AUc, BUc); + sfb(BEe, "NubSpline/PolarCP", 418); + feb(1480, 1, nEe, VUc); + _2.rg = function XUc(a) { + return QUc(RD(a, 36)); + }; + _2.Kf = function YUc(a, b) { + UUc(this, RD(a, 36), b); + }; + var CUc, DUc, EUc, FUc, GUc; + sfb(BEe, "SplineEdgeRouter", 1480); + feb(274, 1, { 274: 1 }, _Uc); + _2.Ib = function aVc() { + return this.a + " ->(" + this.c + ") " + this.b; + }; + _2.c = 0; + sfb(BEe, "SplineEdgeRouter/Dependency", 274); + feb(465, 22, { 3: 1, 34: 1, 22: 1, 465: 1 }, eVc); + var bVc, cVc; + var w$ = tfb(BEe, "SplineEdgeRouter/SideToProcess", 465, WI, gVc, fVc); + var hVc; + feb(1481, 1, nwe, jVc); + _2.Mb = function kVc(a) { + return HUc(), !RD(a, 131).o; + }; + sfb(BEe, "SplineEdgeRouter/lambda$0$Type", 1481); + feb(1482, 1, {}, lVc); + _2.Ze = function mVc(a) { + return HUc(), RD(a, 131).v + 1; + }; + sfb(BEe, "SplineEdgeRouter/lambda$1$Type", 1482); + feb(1483, 1, Qve, nVc); + _2.Cd = function oVc(a) { + SUc(this.a, this.b, RD(a, 42)); + }; + sfb(BEe, "SplineEdgeRouter/lambda$2$Type", 1483); + feb(1484, 1, Qve, pVc); + _2.Cd = function qVc(a) { + TUc(this.a, this.b, RD(a, 42)); + }; + sfb(BEe, "SplineEdgeRouter/lambda$3$Type", 1484); + feb(131, 1, { 34: 1, 131: 1 }, wVc, xVc); + _2.Fd = function yVc(a) { + return uVc(this, RD(a, 131)); + }; + _2.b = 0; + _2.e = false; + _2.f = 0; + _2.g = 0; + _2.j = false; + _2.k = false; + _2.n = 0; + _2.o = false; + _2.p = false; + _2.q = false; + _2.s = 0; + _2.u = 0; + _2.v = 0; + _2.F = 0; + sfb(BEe, "SplineSegment", 131); + feb(468, 1, { 468: 1 }, zVc); + _2.a = 0; + _2.b = false; + _2.c = false; + _2.d = false; + _2.e = false; + _2.f = 0; + sfb(BEe, "SplineSegment/EdgeInformation", 468); + feb(1198, 1, {}, IVc); + sfb(GEe, Lze, 1198); + feb(1199, 1, fye, KVc); + _2.Ne = function LVc(a, b) { + return JVc(RD(a, 121), RD(b, 121)); + }; + _2.Fb = function MVc(a) { + return this === a; + }; + _2.Oe = function NVc() { + return new Frb(this); + }; + sfb(GEe, Mze, 1199); + feb(1197, 1, {}, TVc); + sfb(GEe, "MrTree", 1197); + feb(405, 22, { 3: 1, 34: 1, 22: 1, 405: 1, 188: 1, 196: 1 }, $Vc); + _2.dg = function aWc() { + return ZVc(this); + }; + _2.qg = function _Vc() { + return ZVc(this); + }; + var UVc, VVc, WVc, XVc; + var H$ = tfb(GEe, "TreeLayoutPhases", 405, WI, cWc, bWc); + var dWc; + feb(1112, 205, oze, fWc); + _2.rf = function gWc(a, b) { + var c2, d, e, f2, g, h, i2, j; + Heb(TD(Gxd(a, (h_c(), S$c)))) || RFb((c2 = new SFb((lud(), new zud(a))), c2)); + g = b.eh(HEe); + g.Ug("build tGraph", 1); + h = (i2 = new YWc(), kQb(i2, a), pQb(i2, (q$c(), h$c), a), j = new Tsb(), QVc(a, i2, j), PVc(a, i2, j), i2); + g.Vg(); + g = b.eh(HEe); + g.Ug("Split graph", 1); + f2 = HVc(this.a, h); + g.Vg(); + for (e = new Anb(f2); e.a < e.c.c.length; ) { + d = RD(ynb(e), 121); + RVc(this.b, d, b.eh(0.5999999940395355 / f2.c.length)); + } + g = b.eh(HEe); + g.Ug("Pack components", 1); + h = GVc(f2); + g.Vg(); + g = b.eh(HEe); + g.Ug("Apply layout results", 1); + OVc(h); + g.Vg(); + }; + sfb(GEe, "TreeLayoutProvider", 1112); + feb(1894, 1, Vve, uWc); + _2.Jc = function vWc(a) { + xgb(this, a); + }; + _2.Kc = function wWc() { + return yob(), Qob(), Pob; + }; + sfb(GEe, "TreeUtil/1", 1894); + feb(1895, 1, Vve, xWc); + _2.Jc = function yWc(a) { + xgb(this, a); + }; + _2.Kc = function zWc() { + return yob(), Qob(), Pob; + }; + sfb(GEe, "TreeUtil/2", 1895); + feb(1885, 1, nwe, AWc); + _2.Mb = function BWc(a) { + return Heb(TD(mQb(RD(a, 40), (q$c(), n$c)))); + }; + sfb(GEe, "TreeUtil/lambda$0$Type", 1885); + feb(1891, 1, nwe, CWc); + _2.Mb = function DWc(a) { + return this.a.Hc(RD(a, 40)); + }; + sfb(GEe, "TreeUtil/lambda$10$Type", 1891); + feb(1892, 1, {}, EWc); + _2.Kb = function FWc(a) { + return nWc(this.a, RD(a, 40)); + }; + sfb(GEe, "TreeUtil/lambda$11$Type", 1892); + feb(1893, 1, nwe, GWc); + _2.Mb = function HWc(a) { + return oWc(this.a, this.b, RD(a, 40)); + }; + sfb(GEe, "TreeUtil/lambda$12$Type", 1893); + feb(1886, 1, nwe, IWc); + _2.Mb = function JWc(a) { + return pWc(this.a, RD(a, 65)); + }; + sfb(GEe, "TreeUtil/lambda$3$Type", 1886); + feb(1887, 1, fye, KWc); + _2.Ne = function LWc(a, b) { + return qWc(RD(a, 65), RD(b, 65)); + }; + _2.Fb = function MWc(a) { + return this === a; + }; + _2.Oe = function NWc() { + return new Frb(this); + }; + sfb(GEe, "TreeUtil/lambda$4$Type", 1887); + feb(1888, 1, nwe, OWc); + _2.Mb = function PWc(a) { + return rWc(this.a, RD(a, 65)); + }; + sfb(GEe, "TreeUtil/lambda$7$Type", 1888); + feb(1889, 1, fye, QWc); + _2.Ne = function RWc(a, b) { + return sWc(RD(a, 65), RD(b, 65)); + }; + _2.Fb = function SWc(a) { + return this === a; + }; + _2.Oe = function TWc() { + return new Frb(this); + }; + sfb(GEe, "TreeUtil/lambda$8$Type", 1889); + feb(1890, 1, {}, UWc); + _2.Kb = function VWc(a) { + return RD(a, 65).b; + }; + sfb(GEe, "TreeUtil/lambda$9$Type", 1890); + feb(508, 137, { 3: 1, 508: 1, 96: 1, 137: 1 }); + _2.g = 0; + sfb(JEe, "TGraphElement", 508); + feb(65, 508, { 3: 1, 65: 1, 508: 1, 96: 1, 137: 1 }, WWc); + _2.Ib = function XWc() { + return !!this.b && !!this.c ? aXc(this.b) + "->" + aXc(this.c) : "e_" + tb(this); + }; + sfb(JEe, "TEdge", 65); + feb(121, 137, { 3: 1, 121: 1, 96: 1, 137: 1 }, YWc); + _2.Ib = function ZWc() { + var a, b, c2, d, e; + e = null; + for (d = Sub(this.b, 0); d.b != d.d.c; ) { + c2 = RD(evb(d), 40); + e += (c2.c == null || c2.c.length == 0 ? "n_" + c2.g : "n_" + c2.c) + "\n"; + } + for (b = Sub(this.a, 0); b.b != b.d.c; ) { + a = RD(evb(b), 65); + e += (!!a.b && !!a.c ? aXc(a.b) + "->" + aXc(a.c) : "e_" + tb(a)) + "\n"; + } + return e; + }; + var W$ = sfb(JEe, "TGraph", 121); + feb(643, 508, { 3: 1, 508: 1, 643: 1, 96: 1, 137: 1 }); + sfb(JEe, "TShape", 643); + feb(40, 643, { 3: 1, 508: 1, 40: 1, 643: 1, 96: 1, 137: 1 }, bXc); + _2.Ib = function cXc() { + return aXc(this); + }; + var Z$ = sfb(JEe, "TNode", 40); + feb(236, 1, Vve, dXc); + _2.Jc = function eXc(a) { + xgb(this, a); + }; + _2.Kc = function fXc() { + var a; + return a = Sub(this.a.d, 0), new gXc(a); + }; + sfb(JEe, "TNode/2", 236); + feb(329, 1, Ave, gXc); + _2.Nb = function hXc(a) { + Ztb(this, a); + }; + _2.Pb = function jXc() { + return RD(evb(this.a), 65).c; + }; + _2.Ob = function iXc() { + return dvb(this.a); + }; + _2.Qb = function kXc() { + gvb(this.a); + }; + sfb(JEe, "TNode/2/1", 329); + feb(1923, 1, QAe, qXc); + _2.Kf = function DXc(a, b) { + oXc(this, RD(a, 121), b); + }; + sfb(LEe, "CompactionProcessor", 1923); + feb(1924, 1, fye, EXc); + _2.Ne = function FXc(a, b) { + return rXc(this.a, RD(a, 40), RD(b, 40)); + }; + _2.Fb = function GXc(a) { + return this === a; + }; + _2.Oe = function HXc() { + return new Frb(this); + }; + sfb(LEe, "CompactionProcessor/lambda$0$Type", 1924); + feb(1925, 1, nwe, IXc); + _2.Mb = function JXc(a) { + return sXc(this.b, this.a, RD(a, 42)); + }; + _2.a = 0; + _2.b = 0; + sfb(LEe, "CompactionProcessor/lambda$1$Type", 1925); + feb(1934, 1, fye, KXc); + _2.Ne = function LXc(a, b) { + return tXc(RD(a, 40), RD(b, 40)); + }; + _2.Fb = function MXc(a) { + return this === a; + }; + _2.Oe = function NXc() { + return new Frb(this); + }; + sfb(LEe, "CompactionProcessor/lambda$10$Type", 1934); + feb(1935, 1, fye, OXc); + _2.Ne = function PXc(a, b) { + return uXc(RD(a, 40), RD(b, 40)); + }; + _2.Fb = function QXc(a) { + return this === a; + }; + _2.Oe = function RXc() { + return new Frb(this); + }; + sfb(LEe, "CompactionProcessor/lambda$11$Type", 1935); + feb(1936, 1, fye, SXc); + _2.Ne = function TXc(a, b) { + return vXc(RD(a, 40), RD(b, 40)); + }; + _2.Fb = function UXc(a) { + return this === a; + }; + _2.Oe = function VXc() { + return new Frb(this); + }; + sfb(LEe, "CompactionProcessor/lambda$12$Type", 1936); + feb(1926, 1, nwe, WXc); + _2.Mb = function XXc(a) { + return wXc(this.a, RD(a, 42)); + }; + _2.a = 0; + sfb(LEe, "CompactionProcessor/lambda$2$Type", 1926); + feb(1927, 1, nwe, YXc); + _2.Mb = function ZXc(a) { + return xXc(this.a, RD(a, 42)); + }; + _2.a = 0; + sfb(LEe, "CompactionProcessor/lambda$3$Type", 1927); + feb(1928, 1, nwe, $Xc); + _2.Mb = function _Xc(a) { + return RD(a, 40).c.indexOf(IEe) == -1; + }; + sfb(LEe, "CompactionProcessor/lambda$4$Type", 1928); + feb(1929, 1, {}, aYc); + _2.Kb = function bYc(a) { + return yXc(this.a, RD(a, 40)); + }; + _2.a = 0; + sfb(LEe, "CompactionProcessor/lambda$5$Type", 1929); + feb(1930, 1, {}, cYc); + _2.Kb = function dYc(a) { + return zXc(this.a, RD(a, 40)); + }; + _2.a = 0; + sfb(LEe, "CompactionProcessor/lambda$6$Type", 1930); + feb(1931, 1, fye, eYc); + _2.Ne = function fYc(a, b) { + return AXc(this.a, RD(a, 240), RD(b, 240)); + }; + _2.Fb = function gYc(a) { + return this === a; + }; + _2.Oe = function hYc() { + return new Frb(this); + }; + sfb(LEe, "CompactionProcessor/lambda$7$Type", 1931); + feb(1932, 1, fye, iYc); + _2.Ne = function jYc(a, b) { + return BXc(this.a, RD(a, 40), RD(b, 40)); + }; + _2.Fb = function kYc(a) { + return this === a; + }; + _2.Oe = function lYc() { + return new Frb(this); + }; + sfb(LEe, "CompactionProcessor/lambda$8$Type", 1932); + feb(1933, 1, fye, mYc); + _2.Ne = function nYc(a, b) { + return CXc(RD(a, 40), RD(b, 40)); + }; + _2.Fb = function oYc(a) { + return this === a; + }; + _2.Oe = function pYc() { + return new Frb(this); + }; + sfb(LEe, "CompactionProcessor/lambda$9$Type", 1933); + feb(1921, 1, QAe, rYc); + _2.Kf = function sYc(a, b) { + qYc(RD(a, 121), b); + }; + sfb(LEe, "DirectionProcessor", 1921); + feb(1913, 1, QAe, vYc); + _2.Kf = function xYc(a, b) { + uYc(this, RD(a, 121), b); + }; + sfb(LEe, "FanProcessor", 1913); + feb(1937, 1, QAe, zYc); + _2.Kf = function CYc(a, b) { + yYc(RD(a, 121), b); + }; + sfb(LEe, "GraphBoundsProcessor", 1937); + feb(1938, 1, {}, DYc); + _2.Ye = function EYc(a) { + return RD(a, 40).e.a; + }; + sfb(LEe, "GraphBoundsProcessor/lambda$0$Type", 1938); + feb(1939, 1, {}, FYc); + _2.Ye = function GYc(a) { + return RD(a, 40).e.b; + }; + sfb(LEe, "GraphBoundsProcessor/lambda$1$Type", 1939); + feb(1940, 1, {}, HYc); + _2.Ye = function IYc(a) { + return AYc(RD(a, 40)); + }; + sfb(LEe, "GraphBoundsProcessor/lambda$2$Type", 1940); + feb(1941, 1, {}, JYc); + _2.Ye = function KYc(a) { + return BYc(RD(a, 40)); + }; + sfb(LEe, "GraphBoundsProcessor/lambda$3$Type", 1941); + feb(262, 22, { 3: 1, 34: 1, 22: 1, 262: 1, 196: 1 }, XYc); + _2.dg = function YYc() { + switch (this.g) { + case 0: + return new DZc(); + case 1: + return new vYc(); + case 2: + return new nZc(); + case 3: + return new tZc(); + case 4: + return new gZc(); + case 8: + return new cZc(); + case 5: + return new rYc(); + case 6: + return new AZc(); + case 7: + return new qXc(); + case 9: + return new zYc(); + case 10: + return new GZc(); + default: + throw Adb(new agb(lBe + (this.f != null ? this.f : "" + this.g))); + } + }; + var LYc, MYc, NYc, OYc, PYc, QYc, RYc, SYc, TYc, UYc, VYc; + var u_ = tfb(LEe, mBe, 262, WI, $Yc, ZYc); + var _Yc; + feb(1920, 1, QAe, cZc); + _2.Kf = function dZc(a, b) { + bZc(RD(a, 121), b); + }; + sfb(LEe, "LevelCoordinatesProcessor", 1920); + feb(1918, 1, QAe, gZc); + _2.Kf = function hZc(a, b) { + eZc(this, RD(a, 121), b); + }; + _2.a = 0; + sfb(LEe, "LevelHeightProcessor", 1918); + feb(1919, 1, Vve, iZc); + _2.Jc = function jZc(a) { + xgb(this, a); + }; + _2.Kc = function kZc() { + return yob(), Qob(), Pob; + }; + sfb(LEe, "LevelHeightProcessor/1", 1919); + feb(1914, 1, QAe, nZc); + _2.Kf = function oZc(a, b) { + lZc(this, RD(a, 121), b); + }; + sfb(LEe, "LevelProcessor", 1914); + feb(1915, 1, nwe, pZc); + _2.Mb = function qZc(a) { + return Heb(TD(mQb(RD(a, 40), (q$c(), n$c)))); + }; + sfb(LEe, "LevelProcessor/lambda$0$Type", 1915); + feb(1916, 1, QAe, tZc); + _2.Kf = function uZc(a, b) { + rZc(this, RD(a, 121), b); + }; + _2.a = 0; + sfb(LEe, "NeighborsProcessor", 1916); + feb(1917, 1, Vve, vZc); + _2.Jc = function wZc(a) { + xgb(this, a); + }; + _2.Kc = function xZc() { + return yob(), Qob(), Pob; + }; + sfb(LEe, "NeighborsProcessor/1", 1917); + feb(1922, 1, QAe, AZc); + _2.Kf = function BZc(a, b) { + yZc(this, RD(a, 121), b); + }; + _2.a = 0; + sfb(LEe, "NodePositionProcessor", 1922); + feb(1912, 1, QAe, DZc); + _2.Kf = function EZc(a, b) { + CZc(this, RD(a, 121), b); + }; + sfb(LEe, "RootProcessor", 1912); + feb(1942, 1, QAe, GZc); + _2.Kf = function HZc(a, b) { + FZc(RD(a, 121), b); + }; + sfb(LEe, "Untreeifyer", 1942); + feb(392, 22, { 3: 1, 34: 1, 22: 1, 392: 1 }, MZc); + var IZc, JZc, KZc; + var F_ = tfb(PEe, "EdgeRoutingMode", 392, WI, OZc, NZc); + var PZc; + var RZc, SZc, TZc, UZc, VZc, WZc, XZc, YZc, ZZc, $Zc, _Zc, a$c, b$c, c$c, d$c, e$c, f$c, g$c, h$c, i$c, j$c, k$c, l$c, m$c, n$c, o$c, p$c; + feb(862, 1, Eye, C$c); + _2.hf = function D$c(a) { + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), REe), ""), YEe), "Turns on Tree compaction which decreases the size of the whole tree by placing nodes of multiple levels in one large level"), (Geb(), false)), (kid(), cid)), QI), xsb((Yhd(), Whd))))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), SEe), ""), "Edge End Texture Length"), "Should be set to the length of the texture at the end of an edge. This value can be used to improve the Edge Routing."), 7), did), VI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), TEe), ""), "Tree Level"), "The index for the tree level the node is in"), sgb(0)), gid), bJ), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), UEe), ""), YEe), "When set to a positive number this option will force the algorithm to place the node to the specified position within the trees layer if weighting is set to constraint"), sgb(-1)), gid), bJ), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), VEe), ""), "Weighting of Nodes"), "Which weighting to use when computing a node order."), A$c), eid), J_), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), WEe), ""), "Edge Routing Mode"), "Chooses an Edge Routing algorithm."), u$c), eid), F_), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), XEe), ""), "Search Order"), "Which search order to use when computing a spanning tree."), x$c), eid), K_), xsb(Whd)))); + i_c((new j_c(), a)); + }; + var r$c, s$c, t$c, u$c, v$c, w$c, x$c, y$c, z$c, A$c; + sfb(PEe, "MrTreeMetaDataProvider", 862); + feb(1006, 1, Eye, j_c); + _2.hf = function k_c(a) { + i_c(a); + }; + var E$c, F$c, G$c, H$c, I$c, J$c, K$c, L$c, M$c, N$c, O$c, P$c, Q$c, R$c, S$c, T$c, U$c, V$c, W$c, X$c, Y$c, Z$c, $$c, _$c, a_c, b_c, c_c, d_c, e_c, f_c, g_c; + sfb(PEe, "MrTreeOptions", 1006); + feb(1007, 1, {}, l_c); + _2.sf = function m_c() { + var a; + return a = new fWc(), a; + }; + _2.tf = function n_c(a) { + }; + sfb(PEe, "MrTreeOptions/MrtreeFactory", 1007); + feb(353, 22, { 3: 1, 34: 1, 22: 1, 353: 1 }, t_c); + var o_c, p_c, q_c, r_c; + var J_ = tfb(PEe, "OrderWeighting", 353, WI, v_c, u_c); + var w_c; + feb(433, 22, { 3: 1, 34: 1, 22: 1, 433: 1 }, B_c); + var y_c, z_c; + var K_ = tfb(PEe, "TreeifyingOrder", 433, WI, D_c, C_c); + var E_c; + feb(1486, 1, nEe, N_c); + _2.rg = function O_c(a) { + return RD(a, 121), G_c; + }; + _2.Kf = function P_c(a, b) { + M_c(this, RD(a, 121), b); + }; + var G_c; + sfb("org.eclipse.elk.alg.mrtree.p1treeify", "DFSTreeifyer", 1486); + feb(1487, 1, nEe, V_c); + _2.rg = function W_c(a) { + return RD(a, 121), Q_c; + }; + _2.Kf = function $_c(a, b) { + U_c(this, RD(a, 121), b); + }; + var Q_c; + sfb(aFe, "NodeOrderer", 1487); + feb(1494, 1, {}, a0c); + _2.td = function b0c(a) { + return __c(a); + }; + sfb(aFe, "NodeOrderer/0methodref$lambda$6$Type", 1494); + feb(1488, 1, nwe, c0c); + _2.Mb = function d0c(a) { + return R_c(), Heb(TD(mQb(RD(a, 40), (q$c(), n$c)))); + }; + sfb(aFe, "NodeOrderer/lambda$0$Type", 1488); + feb(1489, 1, nwe, e0c); + _2.Mb = function f0c(a) { + return R_c(), RD(mQb(RD(a, 40), (h_c(), W$c)), 17).a < 0; + }; + sfb(aFe, "NodeOrderer/lambda$1$Type", 1489); + feb(1490, 1, nwe, g0c); + _2.Mb = function h0c(a) { + return X_c(this.a, RD(a, 40)); + }; + sfb(aFe, "NodeOrderer/lambda$2$Type", 1490); + feb(1491, 1, nwe, i0c); + _2.Mb = function j0c(a) { + return Y_c(this.a, RD(a, 40)); + }; + sfb(aFe, "NodeOrderer/lambda$3$Type", 1491); + feb(1492, 1, fye, k0c); + _2.Ne = function l0c(a, b) { + return Z_c(RD(a, 40), RD(b, 40)); + }; + _2.Fb = function m0c(a) { + return this === a; + }; + _2.Oe = function n0c() { + return new Frb(this); + }; + sfb(aFe, "NodeOrderer/lambda$4$Type", 1492); + feb(1493, 1, nwe, o0c); + _2.Mb = function p0c(a) { + return R_c(), RD(mQb(RD(a, 40), (q$c(), XZc)), 17).a != 0; + }; + sfb(aFe, "NodeOrderer/lambda$5$Type", 1493); + feb(1495, 1, nEe, x0c); + _2.rg = function y0c(a) { + return RD(a, 121), q0c; + }; + _2.Kf = function z0c(a, b) { + v0c(this, RD(a, 121), b); + }; + _2.b = 0; + var q0c; + sfb("org.eclipse.elk.alg.mrtree.p3place", "NodePlacer", 1495); + feb(1496, 1, nEe, J0c); + _2.rg = function K0c(a) { + return RD(a, 121), A0c; + }; + _2.Kf = function Y0c(a, b) { + I0c(RD(a, 121), b); + }; + var A0c; + var o0 = sfb(bFe, "EdgeRouter", 1496); + feb(1498, 1, fye, Z0c); + _2.Ne = function $0c(a, b) { + return hgb(RD(a, 17).a, RD(b, 17).a); + }; + _2.Fb = function _0c(a) { + return this === a; + }; + _2.Oe = function a1c() { + return new Frb(this); + }; + sfb(bFe, "EdgeRouter/0methodref$compare$Type", 1498); + feb(1503, 1, {}, b1c); + _2.Ye = function c1c(a) { + return Kfb(UD(a)); + }; + sfb(bFe, "EdgeRouter/1methodref$doubleValue$Type", 1503); + feb(1505, 1, fye, d1c); + _2.Ne = function e1c(a, b) { + return Qfb(Kfb(UD(a)), Kfb(UD(b))); + }; + _2.Fb = function f1c(a) { + return this === a; + }; + _2.Oe = function g1c() { + return new Frb(this); + }; + sfb(bFe, "EdgeRouter/2methodref$compare$Type", 1505); + feb(1507, 1, fye, h1c); + _2.Ne = function i1c(a, b) { + return Qfb(Kfb(UD(a)), Kfb(UD(b))); + }; + _2.Fb = function j1c(a) { + return this === a; + }; + _2.Oe = function k1c() { + return new Frb(this); + }; + sfb(bFe, "EdgeRouter/3methodref$compare$Type", 1507); + feb(1509, 1, {}, l1c); + _2.Ye = function m1c(a) { + return Kfb(UD(a)); + }; + sfb(bFe, "EdgeRouter/4methodref$doubleValue$Type", 1509); + feb(1511, 1, fye, n1c); + _2.Ne = function o1c(a, b) { + return Qfb(Kfb(UD(a)), Kfb(UD(b))); + }; + _2.Fb = function p1c(a) { + return this === a; + }; + _2.Oe = function q1c() { + return new Frb(this); + }; + sfb(bFe, "EdgeRouter/5methodref$compare$Type", 1511); + feb(1513, 1, fye, r1c); + _2.Ne = function s1c(a, b) { + return Qfb(Kfb(UD(a)), Kfb(UD(b))); + }; + _2.Fb = function t1c(a) { + return this === a; + }; + _2.Oe = function u1c() { + return new Frb(this); + }; + sfb(bFe, "EdgeRouter/6methodref$compare$Type", 1513); + feb(1497, 1, {}, v1c); + _2.Kb = function w1c(a) { + return B0c(), RD(mQb(RD(a, 40), (h_c(), f_c)), 17); + }; + sfb(bFe, "EdgeRouter/lambda$0$Type", 1497); + feb(1508, 1, {}, x1c); + _2.Kb = function y1c(a) { + return L0c(RD(a, 40)); + }; + sfb(bFe, "EdgeRouter/lambda$11$Type", 1508); + feb(1510, 1, {}, z1c); + _2.Kb = function A1c(a) { + return M0c(this.b, this.a, RD(a, 40)); + }; + _2.a = 0; + _2.b = 0; + sfb(bFe, "EdgeRouter/lambda$13$Type", 1510); + feb(1512, 1, {}, B1c); + _2.Kb = function C1c(a) { + return N0c(this.b, this.a, RD(a, 40)); + }; + _2.a = 0; + _2.b = 0; + sfb(bFe, "EdgeRouter/lambda$15$Type", 1512); + feb(1514, 1, fye, D1c); + _2.Ne = function E1c(a, b) { + return O0c(RD(a, 65), RD(b, 65)); + }; + _2.Fb = function F1c(a) { + return this === a; + }; + _2.Oe = function G1c() { + return new Frb(this); + }; + sfb(bFe, "EdgeRouter/lambda$17$Type", 1514); + feb(1515, 1, fye, H1c); + _2.Ne = function I1c(a, b) { + return P0c(RD(a, 65), RD(b, 65)); + }; + _2.Fb = function J1c(a) { + return this === a; + }; + _2.Oe = function K1c() { + return new Frb(this); + }; + sfb(bFe, "EdgeRouter/lambda$18$Type", 1515); + feb(1516, 1, fye, L1c); + _2.Ne = function M1c(a, b) { + return Q0c(RD(a, 65), RD(b, 65)); + }; + _2.Fb = function N1c(a) { + return this === a; + }; + _2.Oe = function O1c() { + return new Frb(this); + }; + sfb(bFe, "EdgeRouter/lambda$19$Type", 1516); + feb(1499, 1, nwe, P1c); + _2.Mb = function Q1c(a) { + return R0c(this.a, RD(a, 40)); + }; + _2.a = 0; + sfb(bFe, "EdgeRouter/lambda$2$Type", 1499); + feb(1517, 1, fye, R1c); + _2.Ne = function S1c(a, b) { + return S0c(RD(a, 65), RD(b, 65)); + }; + _2.Fb = function T1c(a) { + return this === a; + }; + _2.Oe = function U1c() { + return new Frb(this); + }; + sfb(bFe, "EdgeRouter/lambda$20$Type", 1517); + feb(1500, 1, fye, V1c); + _2.Ne = function W1c(a, b) { + return T0c(RD(a, 40), RD(b, 40)); + }; + _2.Fb = function X1c(a) { + return this === a; + }; + _2.Oe = function Y1c() { + return new Frb(this); + }; + sfb(bFe, "EdgeRouter/lambda$3$Type", 1500); + feb(1501, 1, fye, Z1c); + _2.Ne = function $1c(a, b) { + return U0c(RD(a, 40), RD(b, 40)); + }; + _2.Fb = function _1c(a) { + return this === a; + }; + _2.Oe = function a2c() { + return new Frb(this); + }; + sfb(bFe, "EdgeRouter/lambda$4$Type", 1501); + feb(1502, 1, {}, b2c); + _2.Kb = function c2c(a) { + return V0c(RD(a, 40)); + }; + sfb(bFe, "EdgeRouter/lambda$5$Type", 1502); + feb(1504, 1, {}, d2c); + _2.Kb = function e2c(a) { + return W0c(this.b, this.a, RD(a, 40)); + }; + _2.a = 0; + _2.b = 0; + sfb(bFe, "EdgeRouter/lambda$7$Type", 1504); + feb(1506, 1, {}, f2c); + _2.Kb = function g2c(a) { + return X0c(this.b, this.a, RD(a, 40)); + }; + _2.a = 0; + _2.b = 0; + sfb(bFe, "EdgeRouter/lambda$9$Type", 1506); + feb(675, 1, { 675: 1 }, i2c); + _2.e = 0; + _2.f = false; + _2.g = false; + sfb(bFe, "MultiLevelEdgeNodeNodeGap", 675); + feb(1943, 1, fye, l2c); + _2.Ne = function m2c(a, b) { + return j2c(RD(a, 240), RD(b, 240)); + }; + _2.Fb = function n2c(a) { + return this === a; + }; + _2.Oe = function o2c() { + return new Frb(this); + }; + sfb(bFe, "MultiLevelEdgeNodeNodeGap/lambda$0$Type", 1943); + feb(1944, 1, fye, p2c); + _2.Ne = function q2c(a, b) { + return k2c(RD(a, 240), RD(b, 240)); + }; + _2.Fb = function r2c(a) { + return this === a; + }; + _2.Oe = function s2c() { + return new Frb(this); + }; + sfb(bFe, "MultiLevelEdgeNodeNodeGap/lambda$1$Type", 1944); + var t2c; + feb(501, 22, { 3: 1, 34: 1, 22: 1, 501: 1, 188: 1, 196: 1 }, z2c); + _2.dg = function B2c() { + return y2c(this); + }; + _2.qg = function A2c() { + return y2c(this); + }; + var v2c, w2c; + var s0 = tfb(cFe, "RadialLayoutPhases", 501, WI, D2c, C2c); + var E2c; + feb(1113, 205, oze, H2c); + _2.rf = function I2c(a, b) { + var c2, d, e, f2, g, h; + c2 = G2c(this, a); + b.Ug("Radial layout", c2.c.length); + Heb(TD(Gxd(a, ($4c(), N4c)))) || RFb((d = new SFb((lud(), new zud(a))), d)); + h = K2c(a); + Ixd(a, (u2c(), t2c), h); + if (!h) { + throw Adb(new agb("The given graph is not a tree!")); + } + e = Kfb(UD(Gxd(a, S4c))); + e == 0 && (e = J2c(a)); + Ixd(a, S4c, e); + for (g = new Anb(G2c(this, a)); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 47); + f2.Kf(a, b.eh(1)); + } + b.Vg(); + }; + sfb(cFe, "RadialLayoutProvider", 1113); + feb(556, 1, fye, T2c); + _2.Ne = function U2c(a, b) { + return S2c(this.a, this.b, RD(a, 27), RD(b, 27)); + }; + _2.Fb = function V2c(a) { + return this === a; + }; + _2.Oe = function W2c() { + return new Frb(this); + }; + _2.a = 0; + _2.b = 0; + sfb(cFe, "RadialUtil/lambda$0$Type", 556); + feb(1395, 1, QAe, Y2c); + _2.Kf = function Z2c(a, b) { + X2c(RD(a, 27), b); + }; + sfb(hFe, "CalculateGraphSize", 1395); + feb(1396, 1, QAe, _2c); + _2.Kf = function a3c(a, b) { + $2c(RD(a, 27)); + }; + sfb(hFe, "EdgeAngleCalculator", 1396); + feb(368, 22, { 3: 1, 34: 1, 22: 1, 368: 1, 196: 1 }, h3c); + _2.dg = function i3c() { + switch (this.g) { + case 0: + return new Q3c(); + case 1: + return new A3c(); + case 2: + return new U3c(); + case 3: + return new Y2c(); + case 4: + return new _2c(); + default: + throw Adb(new agb(lBe + (this.f != null ? this.f : "" + this.g))); + } + }; + var b3c, c3c, d3c, e3c, f3c; + var x0 = tfb(hFe, mBe, 368, WI, k3c, j3c); + var l3c; + feb(653, 1, {}); + _2.e = 1; + _2.g = 0; + sfb(jFe, "AbstractRadiusExtensionCompaction", 653); + feb(1834, 653, {}, x3c); + _2.Cg = function y3c(a) { + var b, c2, d, e, f2, g, h, i2, j; + this.c = RD(Gxd(a, (u2c(), t2c)), 27); + r3c(this, this.c); + this.d = u5c(RD(Gxd(a, ($4c(), X4c)), 300)); + i2 = RD(Gxd(a, H4c), 17); + !!i2 && q3c(this, i2.a); + h = UD(Gxd(a, (umd(), fmd))); + s3c(this, (uFb(h), h)); + j = Q2c(this.c); + !!this.d && this.d.Gg(j); + t3c(this, j); + g = new mob(cD(WC(J4, 1), kFe, 27, 0, [this.c])); + for (c2 = 0; c2 < 2; c2++) { + for (b = 0; b < j.c.length; b++) { + e = new mob(cD(WC(J4, 1), kFe, 27, 0, [(tFb(b, j.c.length), RD(j.c[b], 27))])); + f2 = b < j.c.length - 1 ? (tFb(b + 1, j.c.length), RD(j.c[b + 1], 27)) : (tFb(0, j.c.length), RD(j.c[0], 27)); + d = b == 0 ? RD(Vmb(j, j.c.length - 1), 27) : (tFb(b - 1, j.c.length), RD(j.c[b - 1], 27)); + v3c(this, (tFb(b, j.c.length), RD(j.c[b], 27), g), d, f2, e); + } + } + }; + sfb(jFe, "AnnulusWedgeCompaction", 1834); + feb(1393, 1, QAe, A3c); + _2.Kf = function B3c(a, b) { + z3c(RD(a, 27), b); + }; + sfb(jFe, "GeneralCompactor", 1393); + feb(1833, 653, {}, F3c); + _2.Cg = function G3c(a) { + var b, c2, d, e; + c2 = RD(Gxd(a, (u2c(), t2c)), 27); + this.f = c2; + this.b = u5c(RD(Gxd(a, ($4c(), X4c)), 300)); + e = RD(Gxd(a, H4c), 17); + !!e && q3c(this, e.a); + d = UD(Gxd(a, (umd(), fmd))); + s3c(this, (uFb(d), d)); + b = Q2c(c2); + !!this.b && this.b.Gg(b); + D3c(this, b); + }; + _2.a = 0; + sfb(jFe, "RadialCompaction", 1833); + feb(1842, 1, {}, I3c); + _2.Dg = function J3c(a) { + var b, c2, d, e, f2, g; + this.a = a; + b = 0; + g = Q2c(a); + d = 0; + for (f2 = new Anb(g); f2.a < f2.c.c.length; ) { + e = RD(ynb(f2), 27); + ++d; + for (c2 = d; c2 < g.c.length; c2++) { + H3c(this, e, (tFb(c2, g.c.length), RD(g.c[c2], 27))) && (b += 1); + } + } + return b; + }; + sfb(lFe, "CrossingMinimizationPosition", 1842); + feb(1840, 1, {}, K3c); + _2.Dg = function L3c(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n; + d = 0; + for (c2 = new is(Mr(zGd(a).a.Kc(), new ir())); gs(c2); ) { + b = RD(hs(c2), 74); + h = AGd(RD(QHd((!b.c && (b.c = new Yie(E4, b, 5, 8)), b.c), 0), 84)); + j = h.i + h.g / 2; + k = h.j + h.f / 2; + e = a.i + a.g / 2; + f2 = a.j + a.f / 2; + l = new pjd(); + l.a = j - e; + l.b = k - f2; + g = new rjd(l.a, l.b); + wid(g, a.g, a.f); + l.a -= g.a; + l.b -= g.b; + e = j - l.a; + f2 = k - l.b; + i2 = new rjd(l.a, l.b); + wid(i2, h.g, h.f); + l.a -= i2.a; + l.b -= i2.b; + j = e + l.a; + k = f2 + l.b; + m = j - e; + n = k - f2; + d += $wnd.Math.sqrt(m * m + n * n); + } + return d; + }; + sfb(lFe, "EdgeLengthOptimization", 1840); + feb(1841, 1, {}, M3c); + _2.Dg = function N3c(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l; + d = 0; + for (c2 = new is(Mr(zGd(a).a.Kc(), new ir())); gs(c2); ) { + b = RD(hs(c2), 74); + h = AGd(RD(QHd((!b.c && (b.c = new Yie(E4, b, 5, 8)), b.c), 0), 84)); + i2 = h.i + h.g / 2; + j = h.j + h.f / 2; + e = RD(Gxd(h, (umd(), Qld)), 8); + f2 = a.i + e.a + a.g / 2; + g = a.j + e.b + a.f; + k = i2 - f2; + l = j - g; + d += $wnd.Math.sqrt(k * k + l * l); + } + return d; + }; + sfb(lFe, "EdgeLengthPositionOptimization", 1841); + feb(1392, 653, QAe, Q3c); + _2.Kf = function R3c(a, b) { + P3c(this, RD(a, 27), b); + }; + sfb("org.eclipse.elk.alg.radial.intermediate.overlaps", "RadiusExtensionOverlapRemoval", 1392); + feb(1394, 1, QAe, U3c); + _2.Kf = function V3c(a, b) { + T3c(RD(a, 27), b); + }; + sfb("org.eclipse.elk.alg.radial.intermediate.rotation", "GeneralRotator", 1394); + feb(434, 22, { 3: 1, 34: 1, 22: 1, 434: 1 }, $3c); + var W3c, X3c; + var H0 = tfb(nFe, "AnnulusWedgeCriteria", 434, WI, a4c, _3c); + var b4c; + feb(393, 22, { 3: 1, 34: 1, 22: 1, 393: 1 }, i4c); + var d4c, e4c, f4c; + var I0 = tfb(nFe, uze, 393, WI, k4c, j4c); + var l4c; + feb(863, 1, Eye, E4c); + _2.hf = function F4c(a) { + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), oFe), ""), "Center On Root"), "Centers the layout on the root of the tree i.e. so that the central node is also the center node of the final layout. This introduces additional whitespace."), (Geb(), false)), (kid(), cid)), QI), xsb((Yhd(), Whd))))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), pFe), ""), "Order ID"), "The id can be used to define an order for nodes of one radius. This can be used to sort them in the layer accordingly."), sgb(0)), gid), bJ), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), qFe), ""), "Radius"), "The radius option can be used to set the initial radius for the radial layouter."), 0), did), VI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), rFe), ""), "Rotate"), "The rotate option determines whether a rotation of the layout should be performed."), false), cid), QI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), sFe), ""), AFe), "With the compacter option it can be determined how compaction on the graph is done. It can be chosen between none, the radial compaction or the compaction of wedges separately."), q4c), eid), I0), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), tFe), ""), "Compaction Step Size"), "Determine the size of steps with which the compaction is done. Step size 1 correlates to a compaction of 1 pixel per Iteration."), sgb(1)), gid), bJ), xsb(Whd)))); + zgd(a, tFe, sFe, null); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), uFe), ""), "Sorter"), "Sort the nodes per radius according to the sorting algorithm. The strategies are none, by the given order id, or sorting them by polar coordinates."), A4c), eid), N0), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), vFe), ""), "Annulus Wedge Criteria"), "Determine how the wedge for the node placement is calculated. It can be chosen between wedge determination by the number of leaves or by the maximum sum of diagonals."), C4c), eid), H0), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), wFe), ""), "Translation Optimization"), "Find the optimal translation of the nodes of the first radii according to this criteria. For example edge crossings can be minimized."), s4c), eid), M0), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), xFe), BFe), "Target Angle"), "The angle in radians that the layout should be rotated to after layout."), 0), did), VI), xsb(Whd)))); + zgd(a, xFe, rFe, null); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), yFe), BFe), "Additional Wedge Space"), "If set to true, modifies the target angle by rotating further such that space is left for an edge to pass in between the nodes. This option should only be used in conjunction with top-down layout."), false), cid), QI), xsb(Whd)))); + zgd(a, yFe, rFe, null); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), zFe), BFe), "Outgoing Edge Angles"), "Calculate the required angle of connected nodes to leave space for an incoming edge. This option should only be used in conjunction with top-down layout."), false), cid), QI), xsb(Whd)))); + _4c((new a5c(), a)); + }; + var n4c, o4c, p4c, q4c, r4c, s4c, t4c, u4c, v4c, w4c, x4c, y4c, z4c, A4c, B4c, C4c; + sfb(nFe, "RadialMetaDataProvider", 863); + feb(1008, 1, Eye, a5c); + _2.hf = function b5c(a) { + _4c(a); + }; + var G4c, H4c, I4c, J4c, K4c, L4c, M4c, N4c, O4c, P4c, Q4c, R4c, S4c, T4c, U4c, V4c, W4c, X4c, Y4c, Z4c; + sfb(nFe, "RadialOptions", 1008); + feb(1009, 1, {}, c5c); + _2.sf = function d5c() { + var a; + return a = new H2c(), a; + }; + _2.tf = function e5c(a) { + }; + sfb(nFe, "RadialOptions/RadialFactory", 1009); + feb(354, 22, { 3: 1, 34: 1, 22: 1, 354: 1 }, l5c); + var f5c, g5c, h5c, i5c; + var M0 = tfb(nFe, "RadialTranslationStrategy", 354, WI, n5c, m5c); + var o5c; + feb(300, 22, { 3: 1, 34: 1, 22: 1, 300: 1 }, v5c); + var q5c, r5c, s5c; + var N0 = tfb(nFe, "SortingStrategy", 300, WI, x5c, w5c); + var y5c; + feb(1476, 1, nEe, D5c); + _2.rg = function E5c(a) { + return RD(a, 27), null; + }; + _2.Kf = function F5c(a, b) { + B5c(this, RD(a, 27), b); + }; + _2.c = 0; + sfb("org.eclipse.elk.alg.radial.p1position", "EadesRadial", 1476); + feb(1838, 1, {}, G5c); + _2.Eg = function H5c(a) { + return O2c(a); + }; + sfb(DFe, "AnnulusWedgeByLeafs", 1838); + feb(1839, 1, {}, J5c); + _2.Eg = function K5c(a) { + return I5c(this, a); + }; + sfb(DFe, "AnnulusWedgeByNodeSpace", 1839); + feb(1477, 1, nEe, N5c); + _2.rg = function O5c(a) { + return RD(a, 27), null; + }; + _2.Kf = function P5c(a, b) { + L5c(this, RD(a, 27), b); + }; + sfb("org.eclipse.elk.alg.radial.p2routing", "StraightLineEdgeRouter", 1477); + feb(826, 1, {}, R5c); + _2.Fg = function S5c(a) { + }; + _2.Gg = function U5c(a) { + Q5c(this, a); + }; + sfb(EFe, "IDSorter", 826); + feb(1837, 1, fye, V5c); + _2.Ne = function W5c(a, b) { + return T5c(RD(a, 27), RD(b, 27)); + }; + _2.Fb = function X5c(a) { + return this === a; + }; + _2.Oe = function Y5c() { + return new Frb(this); + }; + sfb(EFe, "IDSorter/lambda$0$Type", 1837); + feb(1836, 1, {}, _5c); + _2.Fg = function a6c(a) { + Z5c(this, a); + }; + _2.Gg = function b6c(a) { + var b; + if (!a.dc()) { + if (!this.e) { + b = L2c(RD(a.Xb(0), 27)); + Z5c(this, b); + } + Q5c(this.e, a); + } + }; + sfb(EFe, "PolarCoordinateSorter", 1836); + feb(445, 22, { 3: 1, 34: 1, 22: 1, 445: 1 }, g6c); + var c6c, d6c, e6c; + var V0 = tfb(IFe, "RectPackingLayoutPhases", 445, WI, i6c, h6c); + var j6c; + feb(1118, 205, oze, l6c); + _2.rf = function n6c(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, B, C, D5; + b.Ug("Rectangle Packing", 1); + l = RD(Gxd(a, (X7c(), N7c)), 107); + i2 = Heb(TD(Gxd(a, G7c))); + k = Kfb(UD(Gxd(a, Q7c))); + C = Heb(TD(Gxd(a, R7c))); + t = (!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a); + Heb(TD(Gxd(a, J7c))) || RFb((e = new SFb((lud(), new zud(a))), e)); + B = false; + if (C && t.i >= 3) { + v = RD(QHd(t, 0), 27); + w2 = RD(QHd(t, 1), 27); + f2 = 0; + while (f2 + 2 < t.i) { + u = v; + v = w2; + w2 = RD(QHd(t, f2 + 2), 27); + if (u.f >= v.f + w2.f + k || w2.f >= u.f + v.f + k) { + B = true; + break; + } else { + ++f2; + } + } + } else { + B = true; + } + if (!B) { + m = t.i; + for (h = new dMd(t); h.e != h.i.gc(); ) { + g = RD(bMd(h), 27); + Ixd(g, (umd(), Rld), sgb(m)); + --m; + } + crd(a, new Oqd()); + b.Vg(); + return; + } + c2 = (Sed(this.a), Ved(this.a, (f6c(), c6c), RD(Gxd(a, V7c), 188)), Ved(this.a, d6c, RD(Gxd(a, M7c), 188)), Ved(this.a, e6c, RD(Gxd(a, S7c), 188)), Ped(this.a, (D5 = new ufd(), pfd(D5, c6c, (z6c(), y6c)), pfd(D5, d6c, x6c), Heb(TD(Gxd(a, B7c))) && pfd(D5, c6c, w6c), D5)), Qed(this.a, a)); + j = 1 / c2.c.length; + for (o2 = new Anb(c2); o2.a < o2.c.c.length; ) { + n = RD(ynb(o2), 47); + if (b.$g()) { + return; + } + n.Kf(a, b.eh(j)); + } + q = 0; + p = 0; + for (s = new dMd(t); s.e != s.i.gc(); ) { + r = RD(bMd(s), 27); + q = $wnd.Math.max(q, r.i + r.g); + p = $wnd.Math.max(p, r.j + r.f); + } + Jsd(a, new rjd(Kfb(UD(Gxd(a, (X6c(), O6c)))), Kfb(UD(Gxd(a, N6c)))), new rjd(q, p)); + m6c(t, l); + i2 || Esd(a, Kfb(UD(Gxd(a, O6c))) + (l.b + l.c), Kfb(UD(Gxd(a, N6c))) + (l.d + l.a), false, true); + Heb(TD(Gxd(a, J7c))) || RFb((d = new SFb((lud(), new zud(a))), d)); + b.Vg(); + }; + sfb(IFe, "RectPackingLayoutProvider", 1118); + feb(1518, 1, QAe, p6c); + _2.Kf = function r6c(a, b) { + o6c(RD(a, 27), b); + }; + sfb(JFe, "InteractiveNodeReorderer", 1518); + feb(1519, 1, fye, s6c); + _2.Ne = function t6c(a, b) { + return q6c(RD(a, 27), RD(b, 27)); + }; + _2.Fb = function u6c(a) { + return this === a; + }; + _2.Oe = function v6c() { + return new Frb(this); + }; + sfb(JFe, "InteractiveNodeReorderer/lambda$0$Type", 1519); + feb(456, 22, { 3: 1, 34: 1, 22: 1, 456: 1, 196: 1 }, A6c); + _2.dg = function B6c() { + switch (this.g) { + case 0: + return new p6c(); + case 1: + return new K6c(); + case 2: + return new H6c(); + } + return null; + }; + var w6c, x6c, y6c; + var Z0 = tfb(JFe, mBe, 456, WI, D6c, C6c); + var E6c; + feb(1521, 1, QAe, H6c); + _2.Kf = function I6c(a, b) { + G6c(RD(a, 27), b); + }; + sfb(JFe, "MinSizePostProcessor", 1521); + feb(1520, 1, QAe, K6c); + _2.Kf = function L6c(a, b) { + J6c(RD(a, 27), b); + }; + sfb(JFe, "MinSizePreProcessor", 1520); + var M6c, N6c, O6c, P6c, Q6c, R6c, S6c, T6c, U6c, V6c, W6c; + feb(394, 22, { 3: 1, 34: 1, 22: 1, 394: 1 }, a7c); + var Y6c, Z6c, $6c; + var a1 = tfb(KFe, "OptimizationGoal", 394, WI, c7c, b7c); + var d7c; + feb(867, 1, Eye, v7c); + _2.hf = function w7c(a) { + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), LFe), ""), "Try box layout first"), "Whether one should check whether the regions are stackable to see whether box layout would do the job. For example, nodes with the same height are not stackable inside a row. Therefore, box layout will perform better and faster."), (Geb(), false)), (kid(), cid)), QI), xsb((Yhd(), Whd))))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), MFe), ""), "Current position of a node in the order of nodes"), "The rectangles are ordered. Normally according to their definition the the model. This option specifies the current position of a node."), sgb(-1)), gid), bJ), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), NFe), ""), "Desired index of node"), "The rectangles are ordered. Normally according to their definition the the model. This option allows to specify a desired position that has preference over the original position."), sgb(-1)), gid), bJ), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), OFe), ""), "In new Row"), "If set to true this node begins in a new row. Consequently this node cannot be moved in a previous layer during compaction. Width approximation does does not take this into account."), false), cid), QI), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), PFe), XFe), "Width Approximation Strategy"), "Strategy for finding an initial width of the drawing."), s7c), eid), l1), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), QFe), XFe), "Target Width"), "Option to place the rectangles in the given target width instead of approximating the width using the desired aspect ratio. The padding is not included in this. Meaning a drawing will have width of targetwidth + horizontal padding."), -1), did), VI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), RFe), XFe), "Optimization Goal"), "Optimization goal for approximation of the bounding box given by the first iteration. Determines whether layout is sorted by the maximum scaling, aspect ratio, or area. Depending on the strategy the aspect ratio might be nearly ignored."), q7c), eid), a1), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), SFe), XFe), "Shift Last Placed."), "When placing a rectangle behind or below the last placed rectangle in the first iteration, it is sometimes possible to shift the rectangle further to the left or right, resulting in less whitespace. True (default) enables the shift and false disables it. Disabling the shift produces a greater approximated area by the first iteration and a layout, when using ONLY the first iteration (default not the case), where it is sometimes impossible to implement a size transformation of rectangles that will fill the bounding box and eliminate empty spaces."), true), cid), QI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), TFe), "packing"), YFe), "Strategy for finding an initial placement on nodes."), l7c), eid), o1), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), UFe), ZFe), "Row Height Reevaluation"), "During the compaction step the height of a row is normally not changed. If this options is set, the blocks of other rows might be added if they exceed the row height. If this is the case the whole row has to be packed again to be optimal regarding the new row height. This option should, therefore, be used with care since it might be computation heavy."), false), cid), QI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), VFe), ZFe), "Compaction iterations"), "Defines the number of compaction iterations. E.g. if set to 2 the width is initially approximated, then the drawing is compacted and based on the resulting drawing the target width is decreased or increased and a second compaction step is executed and the result compared to the first one. The best run is used based on the scale measure."), sgb(1)), gid), bJ), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), WFe), "whiteSpaceElimination"), "White Space Approximation Strategy"), "Strategy for expanding nodes such that whitespace in the parent is eliminated."), eid), t12), xsb(Whd)))); + Y7c((new Z7c(), a)); + }; + var f7c, g7c, h7c, i7c, j7c, k7c, l7c, m7c, n7c, o7c, p7c, q7c, r7c, s7c, t7c; + sfb(KFe, "RectPackingMetaDataProvider", 867); + feb(1016, 1, Eye, Z7c); + _2.hf = function $7c(a) { + Y7c(a); + }; + var x7c, y7c, z7c, A7c, B7c, C7c, D7c, E7c, F7c, G7c, H7c, I7c, J7c, K7c, L7c, M7c, N7c, O7c, P7c, Q7c, R7c, S7c, T7c, U7c, V7c, W7c; + sfb(KFe, "RectPackingOptions", 1016); + feb(1017, 1, {}, _7c); + _2.sf = function a8c() { + var a; + return a = new l6c(), a; + }; + _2.tf = function b8c(a) { + }; + sfb(KFe, "RectPackingOptions/RectpackingFactory", 1017); + feb(1705, 1, {}, g8c); + _2.a = 0; + _2.c = false; + sfb(_Fe, "AreaApproximation", 1705); + var h1 = ufb(_Fe, "BestCandidateFilter"); + feb(673, 1, { 535: 1 }, h8c); + _2.Hg = function i8c(a, b, c2) { + var d, e, f2, g, h, i2; + i2 = new bnb(); + f2 = oxe; + for (h = new Anb(a); h.a < h.c.c.length; ) { + g = RD(ynb(h), 238); + f2 = $wnd.Math.min(f2, (g.c + (c2.b + c2.c)) * (g.b + (c2.d + c2.a))); + } + for (e = new Anb(a); e.a < e.c.c.length; ) { + d = RD(ynb(e), 238); + (d.c + (c2.b + c2.c)) * (d.b + (c2.d + c2.a)) == f2 && (ZEb(i2.c, d), true); + } + return i2; + }; + sfb(_Fe, "AreaFilter", 673); + feb(674, 1, { 535: 1 }, j8c); + _2.Hg = function k8c(a, b, c2) { + var d, e, f2, g, h, i2; + h = new bnb(); + i2 = oxe; + for (g = new Anb(a); g.a < g.c.c.length; ) { + f2 = RD(ynb(g), 238); + i2 = $wnd.Math.min(i2, $wnd.Math.abs((f2.c + (c2.b + c2.c)) / (f2.b + (c2.d + c2.a)) - b)); + } + for (e = new Anb(a); e.a < e.c.c.length; ) { + d = RD(ynb(e), 238); + $wnd.Math.abs((d.c + (c2.b + c2.c)) / (d.b + (c2.d + c2.a)) - b) == i2 && (ZEb(h.c, d), true); + } + return h; + }; + sfb(_Fe, "AspectRatioFilter", 674); + feb(1469, 1, nEe, o8c); + _2.rg = function p8c(a) { + return RD(a, 27), null; + }; + _2.Kf = function q8c(a, b) { + n8c(RD(a, 27), b); + }; + sfb(_Fe, "GreedyWidthApproximator", 1469); + feb(672, 1, { 535: 1 }, r8c); + _2.Hg = function s8c(a, b, c2) { + var d, e, f2, g, h, i2; + i2 = new bnb(); + f2 = pxe; + for (h = new Anb(a); h.a < h.c.c.length; ) { + g = RD(ynb(h), 238); + f2 = $wnd.Math.max(f2, Aad(g.c + (c2.b + c2.c), g.b + (c2.d + c2.a), g.a)); + } + for (e = new Anb(a); e.a < e.c.c.length; ) { + d = RD(ynb(e), 238); + Aad(d.c + (c2.b + c2.c), d.b + (c2.d + c2.a), d.a) == f2 && (ZEb(i2.c, d), true); + } + return i2; + }; + sfb(_Fe, "ScaleMeasureFilter", 672); + feb(1470, 1, nEe, u8c); + _2.rg = function v8c(a) { + return RD(a, 27), null; + }; + _2.Kf = function w8c(a, b) { + t8c(RD(a, 27), b); + }; + sfb(_Fe, "TargetWidthWidthApproximator", 1470); + feb(491, 22, { 3: 1, 34: 1, 22: 1, 491: 1, 188: 1, 196: 1 }, B8c); + _2.dg = function D8c() { + return A8c(this); + }; + _2.qg = function C8c() { + return A8c(this); + }; + var x8c, y8c; + var l1 = tfb(_Fe, "WidthApproximationStrategy", 491, WI, F8c, E8c); + var G8c; + feb(1471, 1, nEe, R8c); + _2.rg = function S8c(a) { + return RD(a, 27), null; + }; + _2.Kf = function T8c(a, b) { + Q8c(this, RD(a, 27), b); + }; + sfb(aGe, "Compactor", 1471); + feb(1473, 1, nEe, X8c); + _2.rg = function Y8c(a) { + return RD(a, 27), null; + }; + _2.Kf = function Z8c(a, b) { + W8c(RD(a, 27), b); + }; + sfb(aGe, "NoPlacement", 1473); + feb(439, 22, { 3: 1, 34: 1, 22: 1, 439: 1, 188: 1, 196: 1 }, d9c); + _2.dg = function f9c() { + return c9c(this); + }; + _2.qg = function e9c() { + return c9c(this); + }; + var $8c, _8c, a9c; + var o1 = tfb(aGe, "PackingStrategy", 439, WI, h9c, g9c); + var i9c; + feb(810, 1, {}, m9c); + _2.a = 0; + _2.b = 0; + _2.c = 0; + _2.d = oxe; + _2.e = 0; + _2.f = oxe; + sfb(aGe, "RowFillingAndCompaction", 810); + feb(1472, 1, nEe, o9c); + _2.rg = function p9c(a) { + return RD(a, 27), null; + }; + _2.Kf = function q9c(a, b) { + n9c(RD(a, 27), b); + }; + sfb(aGe, "SimplePlacement", 1472); + feb(1474, 1, nEe, s9c); + _2.rg = function t9c(a) { + return RD(a, 27), null; + }; + _2.Kf = function u9c(a, b) { + this.Ig(RD(a, 27), b); + }; + _2.Ig = function v9c(a, b) { + r9c(a, b); + }; + sfb(cGe, "EqualWhitespaceEliminator", 1474); + feb(1475, 1474, nEe, x9c); + _2.Ig = function y9c(a, b) { + var c2, d, e, f2, g; + b.Ug("To Aspect Ratio Whitesapce Eliminator", 1); + g = Kfb(UD(Gxd(a, (X6c(), O6c)))); + f2 = Kfb(UD(Gxd(a, N6c))); + e = Kfb(UD(Gxd(a, (X7c(), x7c)))); + c2 = Kfb(UD(Gxd(a, M6c))); + d = g / f2; + if (d < e) { + g = f2 * e; + Ixd(a, O6c, g); + } else { + c2 += g / e - f2; + Ixd(a, M6c, c2); + Ixd(a, N6c, f2 + c2); + } + r9c(a, b); + b.Vg(); + }; + sfb(cGe, "ToAspectratioNodeExpander", 1475); + feb(492, 22, { 3: 1, 34: 1, 22: 1, 492: 1, 188: 1, 196: 1 }, D9c); + _2.dg = function F9c() { + return C9c(this); + }; + _2.qg = function E9c() { + return C9c(this); + }; + var z9c, A9c; + var t12 = tfb(cGe, "WhiteSpaceEliminationStrategy", 492, WI, H9c, G9c); + var I9c; + feb(172, 1, { 172: 1 }, V9c); + _2.a = 0; + _2.c = false; + _2.d = 0; + _2.e = 0; + _2.f = 0; + _2.g = 0; + _2.i = 0; + _2.k = false; + _2.o = oxe; + _2.p = oxe; + _2.r = 0; + _2.s = 0; + _2.t = 0; + sfb(dGe, "Block", 172); + feb(209, 1, { 209: 1 }, _9c); + _2.a = 0; + _2.b = 0; + _2.d = 0; + _2.e = 0; + _2.f = 0; + sfb(dGe, "BlockRow", 209); + feb(315, 1, { 315: 1 }, had); + _2.b = 0; + _2.c = 0; + _2.d = 0; + _2.e = 0; + _2.f = 0; + sfb(dGe, "BlockStack", 315); + feb(238, 1, { 238: 1 }, lad, mad); + _2.a = 0; + _2.b = 0; + _2.c = 0; + _2.d = 0; + _2.e = 0; + _2.g = 0; + var y1 = sfb(dGe, "DrawingData", 238); + feb(373, 22, { 3: 1, 34: 1, 22: 1, 373: 1 }, tad); + var nad, oad, pad2, qad, rad; + var x1 = tfb(dGe, "DrawingDataDescriptor", 373, WI, vad, uad); + var wad; + feb(186, 1, { 186: 1 }, Had); + _2.b = 0; + _2.c = 0; + _2.e = 0; + _2.f = 0; + sfb(dGe, "RectRow", 186); + feb(763, 1, {}, Pad); + _2.j = 0; + sfb(fGe, dBe, 763); + feb(1209, 1, {}, Qad); + _2.af = function Rad(a) { + return bjd(a.a, a.b); + }; + sfb(fGe, Nze, 1209); + feb(1210, 1, {}, Sad); + _2.af = function Tad(a) { + return Kad(this.a, a); + }; + sfb(fGe, eBe, 1210); + feb(1211, 1, {}, Uad); + _2.af = function Vad(a) { + return Lad(this.a, a); + }; + sfb(fGe, fBe, 1211); + feb(1212, 1, {}, Wad); + _2.af = function Xad(a) { + return Mad(this.a, a); + }; + sfb(fGe, "ElkGraphImporter/lambda$3$Type", 1212); + feb(1213, 1, {}, Yad); + _2.af = function Zad(a) { + return Nad(this.a, a); + }; + sfb(fGe, gBe, 1213); + feb(1115, 205, oze, $ad); + _2.rf = function abd(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n; + if (Hxd(a, (ncd(), mcd))) { + n = WD(Gxd(a, (Tcd(), Scd))); + f2 = sgd(ygd(), n); + if (f2) { + g = RD(ltd(f2.f), 205); + g.rf(a, b.eh(1)); + } + } + Ixd(a, hcd, (Mbd(), Kbd)); + Ixd(a, icd, (Xbd(), Ubd)); + Ixd(a, jcd, (ldd(), kdd)); + h = RD(Gxd(a, (Tcd(), Ocd)), 17).a; + b.Ug("Overlap removal", 1); + Heb(TD(Gxd(a, Ncd))) && "null45scanlineOverlaps"; + i2 = new _sb(); + j = new cbd(i2); + d = new Pad(); + c2 = Jad(d, a); + k = true; + e = 0; + while (e < h && k) { + if (Heb(TD(Gxd(a, Pcd)))) { + i2.a.$b(); + VQb(new WQb(j), c2.i); + if (i2.a.gc() == 0) { + break; + } + c2.e = i2; + } + Sed(this.b); + Ved(this.b, (gbd(), dbd), (_cd(), $cd)); + Ved(this.b, ebd, c2.g); + Ved(this.b, fbd, (Cbd(), Bbd)); + this.a = Qed(this.b, c2); + for (m = new Anb(this.a); m.a < m.c.c.length; ) { + l = RD(ynb(m), 47); + l.Kf(c2, b.eh(1)); + } + Oad(d, c2); + k = Heb(TD(mQb(c2, (OQb(), NQb)))); + ++e; + } + Iad(d, c2); + b.Vg(); + }; + sfb(fGe, "OverlapRemovalLayoutProvider", 1115); + feb(1116, 1, {}, cbd); + sfb(fGe, "OverlapRemovalLayoutProvider/lambda$0$Type", 1116); + feb(444, 22, { 3: 1, 34: 1, 22: 1, 444: 1 }, hbd); + var dbd, ebd, fbd; + var I1 = tfb(fGe, "SPOrEPhases", 444, WI, jbd, ibd); + var kbd; + feb(1219, 1, {}, nbd); + sfb(fGe, "ShrinkTree", 1219); + feb(1117, 205, oze, obd); + _2.rf = function pbd(a, b) { + var c2, d, e, f2, g; + if (Hxd(a, (ncd(), mcd))) { + g = WD(Gxd(a, mcd)); + e = sgd(ygd(), g); + if (e) { + f2 = RD(ltd(e.f), 205); + f2.rf(a, b.eh(1)); + } + } + d = new Pad(); + c2 = Jad(d, a); + mbd(this.a, c2, b.eh(1)); + Iad(d, c2); + }; + sfb(fGe, "ShrinkTreeLayoutProvider", 1117); + feb(306, 137, { 3: 1, 306: 1, 96: 1, 137: 1 }, qbd); + _2.c = false; + sfb("org.eclipse.elk.alg.spore.graph", "Graph", 306); + feb(490, 22, { 3: 1, 34: 1, 22: 1, 490: 1, 188: 1, 196: 1 }, ubd); + _2.dg = function wbd() { + return tbd(this); + }; + _2.qg = function vbd() { + return tbd(this); + }; + var rbd; + var M1 = tfb(gGe, uze, 490, WI, ybd, xbd); + var zbd; + feb(558, 22, { 3: 1, 34: 1, 22: 1, 558: 1, 188: 1, 196: 1 }, Dbd); + _2.dg = function Fbd() { + return new Tdd(); + }; + _2.qg = function Ebd() { + return new Tdd(); + }; + var Bbd; + var N1 = tfb(gGe, "OverlapRemovalStrategy", 558, WI, Hbd, Gbd); + var Ibd; + feb(438, 22, { 3: 1, 34: 1, 22: 1, 438: 1 }, Nbd); + var Kbd, Lbd; + var O1 = tfb(gGe, "RootSelection", 438, WI, Pbd, Obd); + var Qbd; + feb(324, 22, { 3: 1, 34: 1, 22: 1, 324: 1 }, Ybd); + var Sbd, Tbd, Ubd, Vbd, Wbd; + var P1 = tfb(gGe, "SpanningTreeCostFunction", 324, WI, $bd, Zbd); + var _bd; + feb(1014, 1, Eye, pcd); + _2.hf = function qcd(a) { + ocd(a); + }; + var bcd, ccd, dcd, ecd, fcd, gcd, hcd, icd, jcd, kcd, lcd, mcd; + sfb(gGe, "SporeCompactionOptions", 1014); + feb(1015, 1, {}, rcd); + _2.sf = function scd() { + var a; + return a = new obd(), a; + }; + _2.tf = function tcd(a) { + }; + sfb(gGe, "SporeCompactionOptions/SporeCompactionFactory", 1015); + feb(866, 1, Eye, Lcd); + _2.hf = function Mcd(a) { + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), iGe), ""), "Underlying Layout Algorithm"), "A layout algorithm that is applied to the graph before it is compacted. If this is null, nothing is applied before compaction."), (kid(), iid)), qJ), xsb((Yhd(), Whd))))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), nGe), "structure"), "Structure Extraction Strategy"), "This option defines what kind of triangulation or other partitioning of the plane is applied to the vertices."), Icd), eid), V1), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), jGe), sGe), "Tree Construction Strategy"), "Whether a minimum spanning tree or a maximum spanning tree should be constructed."), Gcd), eid), W1), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), kGe), sGe), "Cost Function for Spanning Tree"), "The cost function is used in the creation of the spanning tree."), Ecd), eid), P1), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), lGe), sGe), "Root node for spanning tree construction"), "The identifier of the node that is preferred as the root of the spanning tree. If this is null, the first node is chosen."), null), iid), qJ), xsb(Whd)))); + zgd(a, lGe, mGe, Acd); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), mGe), sGe), "Root selection for spanning tree"), "This sets the method used to select a root node for the construction of a spanning tree"), Ccd), eid), O1), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), oGe), nDe), YFe), "This option defines how the compaction is applied."), vcd), eid), M1), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), pGe), nDe), "Orthogonal Compaction"), "Restricts the translation of nodes to orthogonal directions in the compaction phase."), (Geb(), false)), cid), QI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), qGe), tGe), "Upper limit for iterations of overlap removal"), null), sgb(64)), gid), bJ), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), rGe), tGe), "Whether to run a supplementary scanline overlap check."), null), true), cid), QI), xsb(Whd)))); + Ucd((new Vcd(), a)); + ocd((new pcd(), a)); + }; + var ucd, vcd, wcd, xcd, ycd, zcd, Acd, Bcd, Ccd, Dcd, Ecd, Fcd, Gcd, Hcd, Icd, Jcd; + sfb(gGe, "SporeMetaDataProvider", 866); + feb(1012, 1, Eye, Vcd); + _2.hf = function Wcd(a) { + Ucd(a); + }; + var Ncd, Ocd, Pcd, Qcd, Rcd, Scd; + sfb(gGe, "SporeOverlapRemovalOptions", 1012); + feb(1013, 1, {}, Xcd); + _2.sf = function Ycd() { + var a; + return a = new $ad(), a; + }; + _2.tf = function Zcd(a) { + }; + sfb(gGe, "SporeOverlapRemovalOptions/SporeOverlapFactory", 1013); + feb(539, 22, { 3: 1, 34: 1, 22: 1, 539: 1, 188: 1, 196: 1 }, cdd); + _2.dg = function edd() { + return bdd(this); + }; + _2.qg = function ddd() { + return bdd(this); + }; + var $cd; + var V1 = tfb(gGe, "StructureExtractionStrategy", 539, WI, gdd, fdd); + var hdd; + feb(437, 22, { 3: 1, 34: 1, 22: 1, 437: 1, 188: 1, 196: 1 }, ndd); + _2.dg = function pdd() { + return mdd(this); + }; + _2.qg = function odd() { + return mdd(this); + }; + var jdd, kdd; + var W1 = tfb(gGe, "TreeConstructionStrategy", 437, WI, rdd, qdd); + var sdd; + feb(1463, 1, nEe, vdd); + _2.rg = function wdd(a) { + return RD(a, 306), new ufd(); + }; + _2.Kf = function xdd(a, b) { + udd(RD(a, 306), b); + }; + sfb(vGe, "DelaunayTriangulationPhase", 1463); + feb(1464, 1, Qve, ydd); + _2.Cd = function zdd(a) { + Rmb(this.a, RD(a, 68).a); + }; + sfb(vGe, "DelaunayTriangulationPhase/lambda$0$Type", 1464); + feb(794, 1, nEe, Ddd); + _2.rg = function Edd(a) { + return RD(a, 306), new ufd(); + }; + _2.Kf = function Fdd(a, b) { + this.Jg(RD(a, 306), b); + }; + _2.Jg = function Gdd(a, b) { + var c2, d, e; + b.Ug("Minimum spanning tree construction", 1); + a.d ? d = a.d.a : d = RD(Vmb(a.i, 0), 68).a; + Heb(TD(mQb(a, (OQb(), MQb)))) ? e = LFb(a.e, d, (c2 = a.b, c2)) : e = LFb(a.e, d, a.b); + Bdd(this, e, a); + b.Vg(); + }; + sfb(wGe, "MinSTPhase", 794); + feb(1466, 794, nEe, Hdd); + _2.Jg = function Jdd(a, b) { + var c2, d, e, f2; + b.Ug("Maximum spanning tree construction", 1); + c2 = new Kdd(a); + a.d ? e = a.d.c : e = RD(Vmb(a.i, 0), 68).c; + Heb(TD(mQb(a, (OQb(), MQb)))) ? f2 = LFb(a.e, e, (d = c2, d)) : f2 = LFb(a.e, e, c2); + Bdd(this, f2, a); + b.Vg(); + }; + sfb(wGe, "MaxSTPhase", 1466); + feb(1467, 1, {}, Kdd); + _2.af = function Ldd(a) { + return Idd(this.a, a); + }; + sfb(wGe, "MaxSTPhase/lambda$0$Type", 1467); + feb(1465, 1, Qve, Mdd); + _2.Cd = function Ndd(a) { + Cdd(this.a, RD(a, 68)); + }; + sfb(wGe, "MinSTPhase/lambda$0$Type", 1465); + feb(796, 1, nEe, Tdd); + _2.rg = function Udd(a) { + return RD(a, 306), new ufd(); + }; + _2.Kf = function Vdd(a, b) { + Sdd(this, RD(a, 306), b); + }; + _2.a = false; + sfb(xGe, "GrowTreePhase", 796); + feb(797, 1, Qve, Wdd); + _2.Cd = function Xdd(a) { + Rdd(this.a, this.b, this.c, RD(a, 225)); + }; + sfb(xGe, "GrowTreePhase/lambda$0$Type", 797); + feb(1468, 1, nEe, _dd); + _2.rg = function aed(a) { + return RD(a, 306), new ufd(); + }; + _2.Kf = function bed(a, b) { + $dd(this, RD(a, 306), b); + }; + sfb(xGe, "ShrinkTreeCompactionPhase", 1468); + feb(795, 1, Qve, ced); + _2.Cd = function ded(a) { + Zdd(this.a, this.b, this.c, RD(a, 225)); + }; + sfb(xGe, "ShrinkTreeCompactionPhase/lambda$0$Type", 795); + var j4 = ufb(jEe, "IGraphElementVisitor"); + feb(872, 1, { 536: 1 }, med); + _2.Kg = function ped(a) { + var b; + b = led(this, a); + kQb(b, RD(Wjb(this.b, a), 96)); + jed(this, a, b); + }; + var eed, fed; + sfb(pze, "LayoutConfigurator", 872); + var g2 = ufb(pze, "LayoutConfigurator/IPropertyHolderOptionFilter"); + feb(944, 1, { 2032: 1 }, qed); + _2.Lg = function red(a, b) { + return hed(), !a.pf(b); + }; + sfb(pze, "LayoutConfigurator/lambda$0$Type", 944); + feb(943, 1, { 845: 1 }, sed); + _2.Mg = function ted(a, b) { + return hed(), !a.pf(b); + }; + sfb(pze, "LayoutConfigurator/lambda$1$Type", 943); + feb(945, 1, { 2032: 1 }, ved); + _2.Lg = function wed(a, b) { + return ued(a, b); + }; + sfb(pze, "LayoutConfigurator/lambda$2$Type", 945); + feb(946, 1, nwe, xed); + _2.Mb = function yed(a) { + return oed(this.a, this.b, RD(a, 2032)); + }; + sfb(pze, "LayoutConfigurator/lambda$3$Type", 946); + feb(869, 1, {}, Hed); + sfb(pze, "RecursiveGraphLayoutEngine", 869); + feb(224, 63, swe, Ied, Jed); + sfb(pze, "UnsupportedConfigurationException", 224); + feb(370, 63, swe, Ked); + sfb(pze, "UnsupportedGraphException", 370); + feb(761, 1, {}); + sfb(jEe, "AbstractRandomListAccessor", 761); + feb(450, 761, {}, Wed); + _2.Ng = function Yed() { + return null; + }; + _2.d = true; + _2.e = true; + _2.f = 0; + sfb(AGe, "AlgorithmAssembler", 450); + feb(1200, 1, nwe, Zed); + _2.Mb = function $ed(a) { + return !!RD(a, 106); + }; + sfb(AGe, "AlgorithmAssembler/lambda$0$Type", 1200); + feb(1201, 1, {}, _ed); + _2.Kb = function afd(a) { + return Xed(this.a, RD(a, 106)); + }; + sfb(AGe, "AlgorithmAssembler/lambda$1$Type", 1201); + feb(1202, 1, nwe, bfd); + _2.Mb = function cfd(a) { + return !!RD(a, 80); + }; + sfb(AGe, "AlgorithmAssembler/lambda$2$Type", 1202); + feb(1203, 1, Qve, dfd); + _2.Cd = function efd(a) { + ofd(this.a, RD(a, 80)); + }; + sfb(AGe, "AlgorithmAssembler/lambda$3$Type", 1203); + feb(1204, 1, Qve, ffd); + _2.Cd = function gfd(a) { + Red(this.a, this.b, RD(a, 196)); + }; + sfb(AGe, "AlgorithmAssembler/lambda$4$Type", 1204); + feb(1343, 1, fye, ifd); + _2.Ne = function jfd(a, b) { + return hfd(RD(a, 196), RD(b, 196)); + }; + _2.Fb = function kfd(a) { + return this === a; + }; + _2.Oe = function lfd() { + return new Frb(this); + }; + sfb(AGe, "EnumBasedFactoryComparator", 1343); + feb(80, 761, { 80: 1 }, ufd); + _2.Ng = function wfd() { + return new _sb(); + }; + _2.a = 0; + sfb(AGe, "LayoutProcessorConfiguration", 80); + feb(1025, 1, { 536: 1 }, Bfd); + _2.Kg = function Ffd(a) { + Bvb(yfd, new Kfd(a)); + }; + var xfd, yfd, zfd; + sfb(zye, "DeprecatedLayoutOptionReplacer", 1025); + feb(1026, 1, Qve, Gfd); + _2.Cd = function Hfd(a) { + Cfd(RD(a, 167)); + }; + sfb(zye, "DeprecatedLayoutOptionReplacer/lambda$0$Type", 1026); + feb(1027, 1, Qve, Ifd); + _2.Cd = function Jfd(a) { + Dfd(RD(a, 167)); + }; + sfb(zye, "DeprecatedLayoutOptionReplacer/lambda$1$Type", 1027); + feb(1028, 1, {}, Kfd); + _2.Yd = function Lfd(a, b) { + Efd(this.a, RD(a, 149), RD(b, 41)); + }; + sfb(zye, "DeprecatedLayoutOptionReplacer/lambda$2$Type", 1028); + feb(143, 1, { 701: 1, 143: 1 }, Pfd); + _2.Fb = function Qfd(a) { + return Nfd(this, a); + }; + _2.Og = function Rfd() { + return this.b; + }; + _2.Pg = function Sfd() { + return this.c; + }; + _2.xe = function Tfd() { + return this.e; + }; + _2.Hb = function Ufd() { + return ohb(this.c); + }; + _2.Ib = function Vfd() { + return "Layout Algorithm: " + this.c; + }; + var D2 = sfb(zye, "LayoutAlgorithmData", 143); + feb(269, 1, {}, agd); + sfb(zye, "LayoutAlgorithmData/Builder", 269); + feb(1029, 1, { 536: 1 }, dgd); + _2.Kg = function egd(a) { + ZD(a, 207) && !Heb(TD(a.of((umd(), rld)))) && bgd(RD(a, 27)); + }; + sfb(zye, "LayoutAlgorithmResolver", 1029); + feb(233, 1, { 701: 1, 233: 1 }, fgd); + _2.Fb = function ggd(a) { + if (ZD(a, 233)) { + return lhb(this.b, RD(a, 233).b); + } + return false; + }; + _2.Og = function hgd() { + return this.a; + }; + _2.Pg = function igd() { + return this.b; + }; + _2.xe = function jgd() { + return this.d; + }; + _2.Hb = function kgd() { + return ohb(this.b); + }; + _2.Ib = function lgd() { + return "Layout Type: " + this.b; + }; + sfb(zye, "LayoutCategoryData", 233); + feb(357, 1, {}, pgd); + sfb(zye, "LayoutCategoryData/Builder", 357); + feb(879, 1, {}, xgd); + var qgd; + sfb(zye, "LayoutMetaDataService", 879); + feb(880, 1, {}, Ggd); + sfb(zye, "LayoutMetaDataService/Registry", 880); + feb(487, 1, { 487: 1 }, Hgd); + sfb(zye, "LayoutMetaDataService/Registry/Triple", 487); + feb(881, 1, BGe, Igd); + _2.Qg = function Jgd() { + return new pjd(); + }; + sfb(zye, "LayoutMetaDataService/lambda$0$Type", 881); + feb(882, 1, CGe, Kgd); + _2.Rg = function Lgd(a) { + return ajd(RD(a, 8)); + }; + sfb(zye, "LayoutMetaDataService/lambda$1$Type", 882); + feb(891, 1, BGe, Mgd); + _2.Qg = function Ngd() { + return new bnb(); + }; + sfb(zye, "LayoutMetaDataService/lambda$10$Type", 891); + feb(892, 1, CGe, Ogd); + _2.Rg = function Pgd(a) { + return new dnb(RD(a, 13)); + }; + sfb(zye, "LayoutMetaDataService/lambda$11$Type", 892); + feb(893, 1, BGe, Qgd); + _2.Qg = function Rgd() { + return new Yub(); + }; + sfb(zye, "LayoutMetaDataService/lambda$12$Type", 893); + feb(894, 1, CGe, Sgd); + _2.Rg = function Tgd(a) { + return gv(RD(a, 67)); + }; + sfb(zye, "LayoutMetaDataService/lambda$13$Type", 894); + feb(895, 1, BGe, Ugd); + _2.Qg = function Vgd() { + return new _sb(); + }; + sfb(zye, "LayoutMetaDataService/lambda$14$Type", 895); + feb(896, 1, CGe, Wgd); + _2.Rg = function Xgd(a) { + return Ux(RD(a, 49)); + }; + sfb(zye, "LayoutMetaDataService/lambda$15$Type", 896); + feb(897, 1, BGe, Ygd); + _2.Qg = function Zgd() { + return new Iub(); + }; + sfb(zye, "LayoutMetaDataService/lambda$16$Type", 897); + feb(898, 1, CGe, $gd); + _2.Rg = function _gd(a) { + return Xx(RD(a, 49)); + }; + sfb(zye, "LayoutMetaDataService/lambda$17$Type", 898); + feb(899, 1, BGe, ahd); + _2.Qg = function bhd() { + return new xAb(); + }; + sfb(zye, "LayoutMetaDataService/lambda$18$Type", 899); + feb(900, 1, CGe, chd); + _2.Rg = function dhd(a) { + return Yx(RD(a, 157)); + }; + sfb(zye, "LayoutMetaDataService/lambda$19$Type", 900); + feb(883, 1, BGe, ehd); + _2.Qg = function fhd() { + return new Ejd(); + }; + sfb(zye, "LayoutMetaDataService/lambda$2$Type", 883); + feb(884, 1, CGe, ghd); + _2.Rg = function hhd(a) { + return new Fjd(RD(a, 75)); + }; + sfb(zye, "LayoutMetaDataService/lambda$3$Type", 884); + feb(885, 1, BGe, ihd); + _2.Qg = function jhd() { + return new P2b(); + }; + sfb(zye, "LayoutMetaDataService/lambda$4$Type", 885); + feb(886, 1, CGe, khd); + _2.Rg = function lhd(a) { + return new S2b(RD(a, 140)); + }; + sfb(zye, "LayoutMetaDataService/lambda$5$Type", 886); + feb(887, 1, BGe, mhd); + _2.Qg = function nhd() { + return new z3b(); + }; + sfb(zye, "LayoutMetaDataService/lambda$6$Type", 887); + feb(888, 1, CGe, ohd); + _2.Rg = function phd(a) { + return new B3b(RD(a, 107)); + }; + sfb(zye, "LayoutMetaDataService/lambda$7$Type", 888); + feb(889, 1, BGe, qhd); + _2.Qg = function rhd() { + return new dtd(); + }; + sfb(zye, "LayoutMetaDataService/lambda$8$Type", 889); + feb(890, 1, CGe, shd); + _2.Rg = function thd(a) { + return new etd(RD(a, 385)); + }; + sfb(zye, "LayoutMetaDataService/lambda$9$Type", 890); + var V5 = ufb(jze, "IProperty"); + feb(23, 1, { 34: 1, 701: 1, 23: 1, 149: 1 }, Ahd); + _2.Fd = function Bhd(a) { + return vhd(this, RD(a, 149)); + }; + _2.Fb = function Chd(a) { + return ZD(a, 23) ? lhb(this.f, RD(a, 23).f) : ZD(a, 149) && lhb(this.f, RD(a, 149).Pg()); + }; + _2.Sg = function Dhd() { + var a; + if (ZD(this.b, 4)) { + a = FId(this.b); + if (a == null) { + throw Adb(new dgb(HGe + this.f + "'. Make sure it's type is registered with the " + (lfb(b6), b6.k) + EGe)); + } + return a; + } else { + return this.b; + } + }; + _2.Og = function Ehd() { + return this.d; + }; + _2.Pg = function Fhd() { + return this.f; + }; + _2.xe = function Ghd() { + return this.i; + }; + _2.Hb = function Hhd() { + return ohb(this.f); + }; + _2.Ib = function Ihd() { + return "Layout Option: " + this.f; + }; + sfb(zye, "LayoutOptionData", 23); + feb(24, 1, {}, Shd); + sfb(zye, "LayoutOptionData/Builder", 24); + feb(170, 22, { 3: 1, 34: 1, 22: 1, 170: 1 }, Zhd); + var Thd, Uhd, Vhd, Whd, Xhd; + var d3 = tfb(zye, "LayoutOptionData/Target", 170, WI, _hd, $hd); + var aid; + feb(285, 22, { 3: 1, 34: 1, 22: 1, 285: 1 }, lid); + var cid, did, eid, fid, gid, hid, iid, jid; + var e3 = tfb(zye, "LayoutOptionData/Type", 285, WI, nid, mid); + var oid; + var qid; + var sid; + feb(116, 1, { 116: 1 }, Tid, Uid2, Vid); + _2.Fb = function Wid(a) { + var b; + if (a == null || !ZD(a, 116)) { + return false; + } + b = RD(a, 116); + return Fvb(this.c, b.c) && Fvb(this.d, b.d) && Fvb(this.b, b.b) && Fvb(this.a, b.a); + }; + _2.Hb = function Xid() { + return Tnb(cD(WC(jJ, 1), rve, 1, 5, [this.c, this.d, this.b, this.a])); + }; + _2.Ib = function Yid() { + return "Rect[x=" + this.c + ",y=" + this.d + ",w=" + this.b + ",h=" + this.a + "]"; + }; + _2.a = 0; + _2.b = 0; + _2.c = 0; + _2.d = 0; + sfb(_Ae, "ElkRectangle", 116); + feb(8, 1, { 3: 1, 4: 1, 8: 1, 423: 1 }, pjd, qjd, rjd, sjd); + _2.Fb = function tjd(a) { + return djd(this, a); + }; + _2.Hb = function ujd() { + return Nfb(this.a) + pgb(Nfb(this.b)); + }; + _2.cg = function wjd(b) { + var c2, d, e, f2; + e = 0; + while (e < b.length && vjd((BFb(e, b.length), b.charCodeAt(e)), YAe)) { + ++e; + } + c2 = b.length; + while (c2 > 0 && vjd((BFb(c2 - 1, b.length), b.charCodeAt(c2 - 1)), ZAe)) { + --c2; + } + if (e >= c2) { + throw Adb(new agb("The given string does not contain any numbers.")); + } + f2 = vhb((AFb(e, c2, b.length), b.substr(e, c2 - e)), ",|;|\r|\n"); + if (f2.length != 2) { + throw Adb(new agb("Exactly two numbers are expected, " + f2.length + " were found.")); + } + try { + this.a = Neb(Dhb(f2[0])); + this.b = Neb(Dhb(f2[1])); + } catch (a) { + a = zdb(a); + if (ZD(a, 130)) { + d = a; + throw Adb(new agb($Ae + d)); + } else + throw Adb(a); + } + }; + _2.Ib = function yjd() { + return "(" + this.a + "," + this.b + ")"; + }; + _2.a = 0; + _2.b = 0; + var l3 = sfb(_Ae, "KVector", 8); + feb(75, 67, { 3: 1, 4: 1, 20: 1, 31: 1, 56: 1, 16: 1, 67: 1, 15: 1, 75: 1, 423: 1 }, Ejd, Fjd, Gjd); + _2.Pc = function Jjd() { + return Djd(this); + }; + _2.cg = function Hjd(b) { + var c2, d, e, f2, g, h; + e = vhb(b, ",|;|\\(|\\)|\\[|\\]|\\{|\\}| | |\n"); + Xub(this); + try { + d = 0; + g = 0; + f2 = 0; + h = 0; + while (d < e.length) { + if (e[d] != null && Dhb(e[d]).length > 0) { + g % 2 == 0 ? f2 = Neb(e[d]) : h = Neb(e[d]); + g > 0 && g % 2 != 0 && Mub(this, new rjd(f2, h)); + ++g; + } + ++d; + } + } catch (a) { + a = zdb(a); + if (ZD(a, 130)) { + c2 = a; + throw Adb(new agb("The given string does not match the expected format for vectors." + c2)); + } else + throw Adb(a); + } + }; + _2.Ib = function Kjd() { + var a, b, c2; + a = new dib("("); + b = Sub(this, 0); + while (b.b != b.d.c) { + c2 = RD(evb(b), 8); + Zhb(a, c2.a + "," + c2.b); + b.b != b.d.c && (a.a += "; ", a); + } + return (a.a += ")", a).a; + }; + var k3 = sfb(_Ae, "KVectorChain", 75); + feb(255, 22, { 3: 1, 34: 1, 22: 1, 255: 1 }, Sjd); + var Ljd, Mjd, Njd, Ojd, Pjd, Qjd; + var n3 = tfb(JGe, "Alignment", 255, WI, Ujd, Tjd); + var Vjd; + feb(991, 1, Eye, jkd); + _2.hf = function kkd(a) { + ikd(a); + }; + var Xjd, Yjd, Zjd, $jd, _jd, akd, bkd, ckd, dkd, ekd, fkd, gkd; + sfb(JGe, "BoxLayouterOptions", 991); + feb(992, 1, {}, lkd); + _2.sf = function mkd() { + var a; + return a = new jrd(), a; + }; + _2.tf = function nkd(a) { + }; + sfb(JGe, "BoxLayouterOptions/BoxFactory", 992); + feb(298, 22, { 3: 1, 34: 1, 22: 1, 298: 1 }, vkd); + var okd, pkd, qkd, rkd, skd, tkd; + var q3 = tfb(JGe, "ContentAlignment", 298, WI, xkd, wkd); + var ykd; + feb(699, 1, Eye, vmd); + _2.hf = function wmd(a) { + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), OGe), ""), "Layout Algorithm"), "Select a specific layout algorithm."), (kid(), iid)), qJ), xsb((Yhd(), Whd))))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), PGe), ""), "Resolved Layout Algorithm"), "Meta data associated with the selected algorithm."), hid), D2), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), MDe), ""), "Alignment"), "Alignment of the selected node relative to other nodes; the exact meaning depends on the used algorithm."), Ckd), eid), n3), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), Dze), ""), "Aspect Ratio"), "The desired aspect ratio of the drawing, that is the quotient of width by height."), did), VI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), QGe), ""), "Bend Points"), "A fixed list of bend points for the edge. This is used by the 'Fixed Layout' algorithm to specify a pre-defined routing for an edge. The vector chain must include the source point, any bend points, and the target point, so it must have at least two points."), hid), k3), xsb(Thd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), YDe), ""), "Content Alignment"), "Specifies how the content of a node are aligned. Each node can individually control the alignment of its contents. I.e. if a node should be aligned top left in its parent node, the parent node should specify that option."), Lkd), fid), q3), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), LDe), ""), "Debug Mode"), "Whether additional debug information shall be generated."), (Geb(), false)), cid), QI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), PDe), ""), eze), "Overall direction of edges: horizontal (right / left) or vertical (down / up)."), Okd), eid), s3), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), kDe), ""), "Edge Routing"), "What kind of edge routing style should be applied for the content of a parent node. Algorithms may also set this option to single edges in order to mark them as splines. The bend point list of edges with this option set to SPLINES must be interpreted as control points for a piecewise cubic spline."), Tkd), eid), u3), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), MGe), ""), "Expand Nodes"), "If active, nodes are expanded to fill the area of their parent."), false), cid), QI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), fDe), ""), "Hierarchy Handling"), "Determines whether separate layout runs are triggered for different compound nodes in a hierarchical graph. Setting a node's hierarchy handling to `INCLUDE_CHILDREN` will lay out that node and all of its descendants in a single layout run, until a descendant is encountered which has its hierarchy handling set to `SEPARATE_CHILDREN`. In general, `SEPARATE_CHILDREN` will ensure that a new layout run is triggered for a node with that setting. Including multiple levels of hierarchy in a single layout run may allow cross-hierarchical edges to be laid out properly. If the root node is set to `INHERIT` (or not set at all), the default behavior is `SEPARATE_CHILDREN`."), Ykd), eid), y3), ysb(Whd, cD(WC(d3, 1), jwe, 170, 0, [Vhd]))))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), Eze), ""), "Padding"), "The padding to be left to a parent element's border when placing child elements. This can also serve as an output option of a layout algorithm if node size calculation is setup appropriately."), uld), hid), i3), ysb(Whd, cD(WC(d3, 1), jwe, 170, 0, [Vhd]))))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), dAe), ""), "Interactive"), "Whether the algorithm should be run in interactive mode for the content of a parent node. What this means exactly depends on how the specific algorithm interprets this option. Usually in the interactive mode algorithms try to modify the current layout as little as possible."), false), cid), QI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), iEe), ""), "interactive Layout"), "Whether the graph should be changeable interactively and by setting constraints"), false), cid), QI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), gAe), ""), "Omit Node Micro Layout"), "Node micro layout comprises the computation of node dimensions (if requested), the placement of ports and their labels, and the placement of node labels. The functionality is implemented independent of any specific layout algorithm and shouldn't have any negative impact on the layout algorithm's performance itself. Yet, if any unforeseen behavior occurs, this option allows to deactivate the micro layout."), false), cid), QI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), eAe), ""), "Port Constraints"), "Defines constraints of the position of the ports of a node."), Ild), eid), C3), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), fEe), ""), "Position"), "The position of a node, port, or label. This is used by the 'Fixed Layout' algorithm to specify a pre-defined position."), hid), l3), ysb(Vhd, cD(WC(d3, 1), jwe, 170, 0, [Xhd, Uhd]))))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), $ze), ""), "Priority"), "Defines the priority of an object; its meaning depends on the specific layout algorithm and the context where it is used."), gid), bJ), ysb(Vhd, cD(WC(d3, 1), jwe, 170, 0, [Thd]))))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), bAe), ""), "Randomization Seed"), "Seed used for pseudo-random number generators to control the layout algorithm. If the value is 0, the seed shall be determined pseudo-randomly (e.g. from the system time)."), gid), bJ), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), cAe), ""), "Separate Connected Components"), "Whether each connected component should be processed separately."), cid), QI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), ZDe), ""), "Junction Points"), "This option is not used as option, but as output of the layout algorithms. It is attached to edges and determines the points where junction symbols should be drawn in order to represent hyperedges with orthogonal routing. Whether such points are computed depends on the chosen layout algorithm and edge routing style. The points are put into the vector chain with no specific order."), dld), hid), k3), xsb(Thd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), aEe), ""), "Comment Box"), "Whether the node should be regarded as a comment box instead of a regular node. In that case its placement should be similar to how labels are handled. Any edges incident to a comment box specify to which graph elements the comment is related."), false), cid), QI), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), bEe), ""), "Hypernode"), "Whether the node should be handled as a hypernode."), false), cid), QI), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), RGe), ""), "Label Manager"), "Label managers can shorten labels upon a layout algorithm's request."), hid), g3), ysb(Whd, cD(WC(d3, 1), jwe, 170, 0, [Uhd]))))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), gEe), ""), "Margins"), "Margins define additional space around the actual bounds of a graph element. For instance, ports or labels being placed on the outside of a node's border might introduce such a margin. The margin is used to guarantee non-overlap of other graph elements with those ports or labels."), fld), hid), h3), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), JDe), ""), "No Layout"), "No layout is done for the associated element. This is used to mark parts of a diagram to avoid their inclusion in the layout graph, or to mark parts of the layout graph to prevent layout engines from processing them. If you wish to exclude the contents of a compound node from automatic layout, while the node itself is still considered on its own layer, use the 'Fixed Layout' algorithm for that node."), false), cid), QI), ysb(Vhd, cD(WC(d3, 1), jwe, 170, 0, [Thd, Xhd, Uhd]))))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), SGe), ""), "Scale Factor"), "The scaling factor to be applied to the corresponding node in recursive layout. It causes the corresponding node's size to be adjusted, and its ports and labels to be sized and placed accordingly after the layout of that node has been determined (and before the node itself and its siblings are arranged). The scaling is not reverted afterwards, so the resulting layout graph contains the adjusted size and position data. This option is currently not supported if 'Layout Hierarchy' is set."), 1), did), VI), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), TGe), ""), "Child Area Width"), "The width of the area occupied by the laid out children of a node."), did), VI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), UGe), ""), "Child Area Height"), "The height of the area occupied by the laid out children of a node."), did), VI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), mAe), ""), yGe), "Turns topdown layout on and off. If this option is enabled, hierarchical layout will be computed first for the root node and then for its children recursively. Layouts are then scaled down to fit the area provided by their parents. Graphs must follow a certain structure for topdown layout to work properly. {@link TopdownNodeTypes.PARALLEL_NODE} nodes must have children of type {@link TopdownNodeTypes.HIERARCHICAL_NODE} and must define {@link topdown.hierarchicalNodeWidth} and {@link topdown.hierarchicalNodeAspectRatio} for their children. Furthermore they need to be laid out using an algorithm that is a {@link TopdownLayoutProvider}. Hierarchical nodes can also be parents of other hierarchical nodes and can optionally use a {@link TopdownSizeApproximator} to dynamically set sizes during topdown layout. In this case {@link topdown.hierarchicalNodeWidth} and {@link topdown.hierarchicalNodeAspectRatio} should be set on the node itself rather than the parent. The values are then used by the size approximator as base values. Hierarchical nodes require the layout option {@link nodeSize.fixedGraphSize} to be true to prevent the algorithm used there from resizing the hierarchical node. This option is not supported if 'Hierarchy Handling' is set to 'INCLUDE_CHILDREN'"), false), cid), QI), xsb(Whd)))); + zgd(a, mAe, qAe, null); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), VGe), ""), "Animate"), "Whether the shift from the old layout to the new computed layout shall be animated."), true), cid), QI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), WGe), ""), "Animation Time Factor"), "Factor for computation of animation time. The higher the value, the longer the animation time. If the value is 0, the resulting time is always equal to the minimum defined by 'Minimal Animation Time'."), sgb(100)), gid), bJ), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), XGe), ""), "Layout Ancestors"), "Whether the hierarchy levels on the path from the selected element to the root of the diagram shall be included in the layout process."), false), cid), QI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), YGe), ""), "Maximal Animation Time"), "The maximal time for animations, in milliseconds."), sgb(4e3)), gid), bJ), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), ZGe), ""), "Minimal Animation Time"), "The minimal time for animations, in milliseconds."), sgb(400)), gid), bJ), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), $Ge), ""), "Progress Bar"), "Whether a progress bar shall be displayed during layout computations."), false), cid), QI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), _Ge), ""), "Validate Graph"), "Whether the graph shall be validated before any layout algorithm is applied. If this option is enabled and at least one error is found, the layout process is aborted and a message is shown to the user."), false), cid), QI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), aHe), ""), "Validate Options"), "Whether layout options shall be validated before any layout algorithm is applied. If this option is enabled and at least one error is found, the layout process is aborted and a message is shown to the user."), true), cid), QI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), bHe), ""), "Zoom to Fit"), "Whether the zoom level shall be set to view the whole diagram after layout."), false), cid), QI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), NGe), "box"), "Box Layout Mode"), "Configures the packing mode used by the {@link BoxLayoutProvider}. If SIMPLE is not required (neither priorities are used nor the interactive mode), GROUP_DEC can improve the packing and decrease the area. GROUP_MIXED and GROUP_INC may, in very specific scenarios, work better."), Gkd), eid), R3), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), xDe), lDe), "Comment Comment Spacing"), "Spacing to be preserved between a comment box and other comment boxes connected to the same node. The space left between comment boxes of different nodes is controlled by the node-node spacing."), 10), did), VI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), yDe), lDe), "Comment Node Spacing"), "Spacing to be preserved between a node and its connected comment boxes. The space left between a node and the comments of another node is controlled by the node-node spacing."), 10), did), VI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), Bze), lDe), "Components Spacing"), "Spacing to be preserved between pairs of connected components. This option is only relevant if 'separateConnectedComponents' is activated."), 20), did), VI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), zDe), lDe), "Edge Spacing"), "Spacing to be preserved between any two edges. Note that while this can somewhat easily be satisfied for the segments of orthogonally drawn edges, it is harder for general polylines or splines."), 10), did), VI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), aAe), lDe), "Edge Label Spacing"), "The minimal distance to be preserved between a label and the edge it is associated with. Note that the placement of a label is influenced by the 'edgelabels.placement' option."), 2), did), VI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), ADe), lDe), "Edge Node Spacing"), "Spacing to be preserved between nodes and edges."), 10), did), VI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), BDe), lDe), "Label Spacing"), "Determines the amount of space to be left between two labels of the same graph element."), 0), did), VI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), EDe), lDe), "Label Node Spacing"), "Spacing to be preserved between labels and the border of node they are associated with. Note that the placement of a label is influenced by the 'nodelabels.placement' option."), 5), did), VI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), CDe), lDe), "Horizontal spacing between Label and Port"), "Horizontal spacing to be preserved between labels and the ports they are associated with. Note that the placement of a label is influenced by the 'portlabels.placement' option."), 1), did), VI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), DDe), lDe), "Vertical spacing between Label and Port"), "Vertical spacing to be preserved between labels and the ports they are associated with. Note that the placement of a label is influenced by the 'portlabels.placement' option."), 1), did), VI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), _ze), lDe), "Node Spacing"), "The minimal distance to be preserved between each two nodes."), 20), did), VI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), FDe), lDe), "Node Self Loop Spacing"), "Spacing to be preserved between a node and its self loops."), 10), did), VI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), GDe), lDe), "Port Spacing"), "Spacing between pairs of ports of the same node."), 10), did), VI), ysb(Whd, cD(WC(d3, 1), jwe, 170, 0, [Vhd]))))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), HDe), lDe), "Individual Spacing"), "Allows to specify individual spacing values for graph elements that shall be different from the value specified for the element's parent."), hid), l4), ysb(Vhd, cD(WC(d3, 1), jwe, 170, 0, [Thd, Xhd, Uhd]))))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), hEe), lDe), "Additional Port Space"), "Additional space around the sets of ports on each node side. For each side of a node, this option can reserve additional space before and after the ports on each side. For example, a top spacing of 20 makes sure that the first port on the western and eastern side is 20 units away from the northern border."), imd), hid), h3), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), eEe), hHe), "Layout Partition"), "Partition to which the node belongs. This requires Layout Partitioning to be active. Nodes with lower partition IDs will appear to the left of nodes with higher partition IDs (assuming a left-to-right layout direction)."), gid), bJ), ysb(Whd, cD(WC(d3, 1), jwe, 170, 0, [Vhd]))))); + zgd(a, eEe, dEe, yld); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), dEe), hHe), "Layout Partitioning"), "Whether to activate partitioned layout. This will allow to group nodes through the Layout Partition option. a pair of nodes with different partition indices is then placed such that the node with lower index is placed to the left of the other node (with left-to-right layout direction). Depending on the layout algorithm, this may only be guaranteed to work if all nodes have a layout partition configured, or at least if edges that cross partitions are not part of a partition-crossing cycle."), wld), cid), QI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), QDe), iHe), "Node Label Padding"), "Define padding for node labels that are placed inside of a node."), hld), hid), i3), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), kAe), iHe), "Node Label Placement"), "Hints for where node labels are to be placed; if empty, the node label's position is not modified."), jld), fid), A3), ysb(Vhd, cD(WC(d3, 1), jwe, 170, 0, [Uhd]))))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), TDe), jHe), "Port Alignment"), "Defines the default port distribution for a node. May be overridden for each side individually."), Ald), eid), B3), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), UDe), jHe), "Port Alignment (North)"), "Defines how ports on the northern side are placed, overriding the node's general port alignment."), eid), B3), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), VDe), jHe), "Port Alignment (South)"), "Defines how ports on the southern side are placed, overriding the node's general port alignment."), eid), B3), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), WDe), jHe), "Port Alignment (West)"), "Defines how ports on the western side are placed, overriding the node's general port alignment."), eid), B3), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), XDe), jHe), "Port Alignment (East)"), "Defines how ports on the eastern side are placed, overriding the node's general port alignment."), eid), B3), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), jAe), kHe), "Node Size Constraints"), "What should be taken into account when calculating a node's size. Empty size constraints specify that a node's size is already fixed and should not be changed."), lld), fid), H3), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), iAe), kHe), "Node Size Options"), "Options modifying the behavior of the size constraints set on a node. Each member of the set specifies something that should be taken into account when calculating node sizes. The empty set corresponds to no further modifications."), qld), fid), I3), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), CAe), kHe), "Node Size Minimum"), "The minimal size to which a node can be reduced."), old), hid), l3), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), hAe), kHe), "Fixed Graph Size"), "By default, the fixed layout provider will enlarge a graph until it is large enough to contain its children. If this option is set, it won't do so."), false), cid), QI), xsb(Whd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), $De), vDe), "Edge Label Placement"), "Gives a hint on where to put edge labels."), Rkd), eid), t32), xsb(Uhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), fAe), vDe), "Inline Edge Labels"), "If true, an edge label is placed directly on its edge. May only apply to center edge labels. This kind of label placement is only advisable if the label's rendering is such that it is not crossed by its edge and thus stays legible."), false), cid), QI), xsb(Uhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), cHe), "font"), "Font Name"), "Font name used for a label."), iid), qJ), xsb(Uhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), dHe), "font"), "Font Size"), "Font size used for a label."), gid), bJ), xsb(Uhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), cEe), lHe), "Port Anchor Offset"), "The offset to the port position where connections shall be attached."), hid), l3), xsb(Xhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), _De), lHe), "Port Index"), "The index of a port in the fixed order around a node. The order is assumed as clockwise, starting with the leftmost port on the top side. This option must be set if 'Port Constraints' is set to FIXED_ORDER and no specific positions are given for the ports. Additionally, the option 'Port Side' must be defined in this case."), gid), bJ), xsb(Xhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), KDe), lHe), "Port Side"), "The side of a node on which a port is situated. This option must be set if 'Port Constraints' is set to FIXED_SIDE or FIXED_ORDER and no specific positions are given for the ports."), Pld), eid), E3), xsb(Xhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Khd(Ohd(Lhd(Mhd(new Shd(), IDe), lHe), "Port Border Offset"), "The offset of ports on the node border. With a positive offset the port is moved outside of the node, while with a negative offset the port is moved towards the inside. An offset of 0 means that the port is placed directly on the node border, i.e. if the port side is north, the port's south border touches the nodes's north border; if the port side is east, the port's west border touches the nodes's east border; if the port side is south, the port's north border touches the node's south border; if the port side is west, the port's east border touches the node's west border."), did), VI), xsb(Xhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), lAe), mHe), "Port Label Placement"), "Decides on a placement method for port labels; if empty, the node label's position is not modified."), Mld), fid), D3), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), RDe), mHe), "Port Labels Next to Port"), "Use 'portLabels.placement': NEXT_TO_PORT_OF_POSSIBLE."), false), cid), QI), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), SDe), mHe), "Treat Port Labels as Group"), "If this option is true (default), the labels of a port will be treated as a group when it comes to centering them next to their port. If this option is false, only the first label will be centered next to the port, with the others being placed below. This only applies to labels of eastern and western ports and will have no effect if labels are not placed next to their port."), true), cid), QI), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), nAe), nHe), "Topdown Scale Factor"), "The scaling factor to be applied to the nodes laid out within the node in recursive topdown layout. The difference to 'Scale Factor' is that the node itself is not scaled. This value has to be set on hierarchical nodes."), 1), did), VI), xsb(Whd)))); + zgd(a, nAe, qAe, rmd); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), eHe), nHe), "Topdown Size Approximator"), "The size approximator to be used to set sizes of hierarchical nodes during topdown layout. The default value is null, which results in nodes keeping whatever size is defined for them e.g. through parent parallel node or by manually setting the size."), null), eid), M3), xsb(Vhd)))); + zgd(a, eHe, qAe, tmd); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), oAe), nHe), "Topdown Hierarchical Node Width"), "The fixed size of a hierarchical node when using topdown layout. If this value is set on a parallel node it applies to its children, when set on a hierarchical node it applies to the node itself."), 150), did), VI), ysb(Whd, cD(WC(d3, 1), jwe, 170, 0, [Vhd]))))); + zgd(a, oAe, qAe, null); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), pAe), nHe), "Topdown Hierarchical Node Aspect Ratio"), "The fixed aspect ratio of a hierarchical node when using topdown layout. Default is 1/sqrt(2). If this value is set on a parallel node it applies to its children, when set on a hierarchical node it applies to the node itself."), 1.414), did), VI), ysb(Whd, cD(WC(d3, 1), jwe, 170, 0, [Vhd]))))); + zgd(a, pAe, qAe, null); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), qAe), nHe), "Topdown Node Type"), "The different node types used for topdown layout. If the node type is set to {@link TopdownNodeTypes.PARALLEL_NODE} the algorithm must be set to a {@link TopdownLayoutProvider} such as {@link TopdownPacking}. The {@link nodeSize.fixedGraphSize} option is technically only required for hierarchical nodes."), null), eid), J3), xsb(Vhd)))); + zgd(a, qAe, hAe, null); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), fHe), nHe), "Topdown Scale Cap"), "Determines the upper limit for the topdown scale factor. The default value is 1.0 which ensures that nested children never end up appearing larger than their parents in terms of unit sizes such as the font size. If the limit is larger, nodes will fully utilize the available space, but it is counteriniuitive for inner nodes to have a larger scale than outer nodes."), 1), did), VI), xsb(Whd)))); + zgd(a, fHe, qAe, pmd); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), NDe), oHe), "Activate Inside Self Loops"), "Whether this node allows to route self loops inside of it instead of around it. If set to true, this will make the node a compound node if it isn't already, and will require the layout algorithm to support compound nodes with hierarchical ports."), false), cid), QI), xsb(Vhd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), ODe), oHe), "Inside Self Loop"), "Whether a self loop should be routed inside a node instead of around that node."), false), cid), QI), xsb(Thd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), Cze), "edge"), "Edge Thickness"), "The thickness of an edge. This is a hint on the line width used to draw an edge, possibly requiring more space to be reserved for it."), 1), did), VI), xsb(Thd)))); + Egd(a, new Ahd(Qhd(Phd(Rhd(Jhd(Khd(Ohd(Lhd(Mhd(new Shd(), gHe), "edge"), "Edge Type"), "The type of an edge. This is usually used for UML class diagrams, where associations must be handled differently from generalizations."), Vkd), eid), v3), xsb(Thd)))); + Dgd(a, new fgd(mgd(ogd(ngd(new pgd(), sxe), "Layered"), 'The layer-based method was introduced by Sugiyama, Tagawa and Toda in 1981. It emphasizes the direction of edges by pointing as many edges as possible into the same direction. The nodes are arranged in layers, which are sometimes called "hierarchies", and then reordered such that the number of edge crossings is minimized. Afterwards, concrete coordinates are computed for the nodes and edge bend points.'))); + Dgd(a, new fgd(mgd(ogd(ngd(new pgd(), "org.eclipse.elk.orthogonal"), "Orthogonal"), `Orthogonal methods that follow the "topology-shape-metrics" approach by Batini, Nardelli and Tamassia '86. The first phase determines the topology of the drawing by applying a planarization technique, which results in a planar representation of the graph. The orthogonal shape is computed in the second phase, which aims at minimizing the number of edge bends, and is called orthogonalization. The third phase leads to concrete coordinates for nodes and edge bend points by applying a compaction method, thus defining the metrics.`))); + Dgd(a, new fgd(mgd(ogd(ngd(new pgd(), Zze), "Force"), "Layout algorithms that follow physical analogies by simulating a system of attractive and repulsive forces. The first successful method of this kind was proposed by Eades in 1984."))); + Dgd(a, new fgd(mgd(ogd(ngd(new pgd(), "org.eclipse.elk.circle"), "Circle"), "Circular layout algorithms emphasize cycles or biconnected components of a graph by arranging them in circles. This is useful if a drawing is desired where such components are clearly grouped, or where cycles are shown as prominent OPTIONS of the graph."))); + Dgd(a, new fgd(mgd(ogd(ngd(new pgd(), $Ee), "Tree"), "Specialized layout methods for trees, i.e. acyclic graphs. The regular structure of graphs that have no undirected cycles can be emphasized using an algorithm of this type."))); + Dgd(a, new fgd(mgd(ogd(ngd(new pgd(), "org.eclipse.elk.planar"), "Planar"), "Algorithms that require a planar or upward planar graph. Most of these algorithms are theoretically interesting, but not practically usable."))); + Dgd(a, new fgd(mgd(ogd(ngd(new pgd(), CFe), "Radial"), "Radial layout algorithms usually position the nodes of the graph on concentric circles."))); + wnd((new xnd(), a)); + ikd((new jkd(), a)); + Gpd((new Hpd(), a)); + }; + var Akd, Bkd, Ckd, Dkd, Ekd, Fkd, Gkd, Hkd, Ikd, Jkd, Kkd, Lkd, Mkd, Nkd, Okd, Pkd, Qkd, Rkd, Skd, Tkd, Ukd, Vkd, Wkd, Xkd, Ykd, Zkd, $kd, _kd, ald, bld, cld, dld, eld, fld, gld, hld, ild, jld, kld, lld, mld, nld, old, pld, qld, rld, sld, tld, uld, vld, wld, xld, yld, zld, Ald, Bld, Cld, Dld, Eld, Fld, Gld, Hld, Ild, Jld, Kld, Lld, Mld, Nld, Old, Pld, Qld, Rld, Sld, Tld, Uld, Vld, Wld, Xld, Yld, Zld, $ld, _ld, amd, bmd, cmd, dmd, emd, fmd, gmd, hmd, imd, jmd, kmd, lmd, mmd, nmd, omd, pmd, qmd, rmd, smd, tmd; + sfb(JGe, "CoreOptions", 699); + feb(88, 22, { 3: 1, 34: 1, 22: 1, 88: 1 }, Gmd); + var xmd, ymd, zmd, Amd, Bmd; + var s3 = tfb(JGe, eze, 88, WI, Imd, Hmd); + var Jmd; + feb(278, 22, { 3: 1, 34: 1, 22: 1, 278: 1 }, Pmd); + var Lmd, Mmd, Nmd; + var t32 = tfb(JGe, "EdgeLabelPlacement", 278, WI, Rmd, Qmd); + var Smd; + feb(223, 22, { 3: 1, 34: 1, 22: 1, 223: 1 }, Zmd); + var Umd, Vmd, Wmd, Xmd; + var u3 = tfb(JGe, "EdgeRouting", 223, WI, _md, $md); + var and; + feb(321, 22, { 3: 1, 34: 1, 22: 1, 321: 1 }, jnd); + var cnd, dnd, end2, fnd, gnd, hnd; + var v3 = tfb(JGe, "EdgeType", 321, WI, lnd, knd); + var mnd; + feb(989, 1, Eye, xnd); + _2.hf = function ynd(a) { + wnd(a); + }; + var ond, pnd, qnd, rnd, snd, tnd, und; + sfb(JGe, "FixedLayouterOptions", 989); + feb(990, 1, {}, znd); + _2.sf = function And() { + var a; + return a = new btd(), a; + }; + _2.tf = function Bnd(a) { + }; + sfb(JGe, "FixedLayouterOptions/FixedFactory", 990); + feb(346, 22, { 3: 1, 34: 1, 22: 1, 346: 1 }, Gnd); + var Cnd, Dnd, End; + var y3 = tfb(JGe, "HierarchyHandling", 346, WI, Ind, Hnd); + var Jnd; + feb(291, 22, { 3: 1, 34: 1, 22: 1, 291: 1 }, Rnd); + var Lnd, Mnd, Nnd, Ond; + var z3 = tfb(JGe, "LabelSide", 291, WI, Tnd, Snd); + var Und; + feb(95, 22, { 3: 1, 34: 1, 22: 1, 95: 1 }, eod); + var Wnd, Xnd, Ynd, Znd, $nd, _nd, aod, bod, cod; + var A3 = tfb(JGe, "NodeLabelPlacement", 95, WI, hod, god); + var iod; + feb(256, 22, { 3: 1, 34: 1, 22: 1, 256: 1 }, qod); + var kod, lod, mod, nod, ood; + var B3 = tfb(JGe, "PortAlignment", 256, WI, sod, rod); + var tod; + feb(101, 22, { 3: 1, 34: 1, 22: 1, 101: 1 }, Eod); + var vod, wod, xod, yod, zod, Aod; + var C3 = tfb(JGe, "PortConstraints", 101, WI, God, Fod); + var Hod; + feb(279, 22, { 3: 1, 34: 1, 22: 1, 279: 1 }, Qod); + var Jod, Kod, Lod, Mod, Nod, Ood; + var D3 = tfb(JGe, "PortLabelPlacement", 279, WI, Uod, Tod); + var Vod; + feb(64, 22, { 3: 1, 34: 1, 22: 1, 64: 1 }, upd); + var Xod, Yod, Zod, $od, _od, apd, bpd, cpd, dpd, epd, fpd, gpd, hpd, ipd, jpd, kpd, lpd, mpd, npd, opd, ppd; + var E3 = tfb(JGe, "PortSide", 64, WI, xpd, wpd); + var ypd; + feb(993, 1, Eye, Hpd); + _2.hf = function Ipd(a) { + Gpd(a); + }; + var Apd, Bpd, Cpd, Dpd, Epd; + sfb(JGe, "RandomLayouterOptions", 993); + feb(994, 1, {}, Jpd); + _2.sf = function Kpd() { + var a; + return a = new eud(), a; + }; + _2.tf = function Lpd(a) { + }; + sfb(JGe, "RandomLayouterOptions/RandomFactory", 994); + feb(386, 22, { 3: 1, 34: 1, 22: 1, 386: 1 }, Rpd); + var Mpd, Npd, Opd, Ppd; + var H3 = tfb(JGe, "SizeConstraint", 386, WI, Tpd, Spd); + var Upd; + feb(264, 22, { 3: 1, 34: 1, 22: 1, 264: 1 }, eqd); + var Wpd, Xpd, Ypd, Zpd, $pd, _pd, aqd, bqd, cqd; + var I3 = tfb(JGe, "SizeOptions", 264, WI, gqd, fqd); + var hqd; + feb(280, 22, { 3: 1, 34: 1, 22: 1, 280: 1 }, nqd); + var jqd, kqd, lqd; + var J3 = tfb(JGe, "TopdownNodeTypes", 280, WI, pqd, oqd); + var qqd; + feb(347, 22, rHe); + var sqd, tqd; + var M3 = tfb(JGe, "TopdownSizeApproximator", 347, WI, xqd, wqd); + feb(987, 347, rHe, zqd); + _2.Tg = function Aqd(a) { + return yqd(a); + }; + tfb(JGe, "TopdownSizeApproximator/1", 987, M3, null, null); + feb(988, 347, rHe, Bqd); + _2.Tg = function Cqd(b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B, C, D5; + c2 = RD(Gxd(b, (umd(), Tld)), 143); + A = (bvd(), o2 = new ACd(), o2); + zxd(A, b); + B = new Tsb(); + for (g = new dMd((!b.a && (b.a = new C5d(J4, b, 10, 11)), b.a)); g.e != g.i.gc(); ) { + e = RD(bMd(g), 27); + t = (n = new ACd(), n); + yCd(t, A); + zxd(t, e); + D5 = yqd(e); + zyd(t, $wnd.Math.max(e.g, D5.a), $wnd.Math.max(e.f, D5.b)); + rtb(B.f, e, t); + } + for (f2 = new dMd((!b.a && (b.a = new C5d(J4, b, 10, 11)), b.a)); f2.e != f2.i.gc(); ) { + e = RD(bMd(f2), 27); + for (l = new dMd((!e.e && (e.e = new Yie(G4, e, 7, 4)), e.e)); l.e != l.i.gc(); ) { + k = RD(bMd(l), 74); + v = RD(Wd(qtb(B.f, e)), 27); + w2 = RD(Wjb(B, QHd((!k.c && (k.c = new Yie(E4, k, 5, 8)), k.c), 0)), 27); + u = (m = new rzd(), m); + WGd((!u.b && (u.b = new Yie(E4, u, 4, 7)), u.b), v); + WGd((!u.c && (u.c = new Yie(E4, u, 5, 8)), u.c), w2); + pzd(u, vCd(v)); + zxd(u, k); + } + } + q = RD(ltd(c2.f), 205); + try { + q.rf(A, new ztd()); + mtd(c2.f, q); + } catch (a) { + a = zdb(a); + if (ZD(a, 103)) { + p = a; + throw Adb(p); + } else + throw Adb(a); + } + Hxd(A, Ikd) || Hxd(A, Hkd) || psd(A); + j = Kfb(UD(Gxd(A, Ikd))); + i2 = Kfb(UD(Gxd(A, Hkd))); + h = j / i2; + d = Kfb(UD(Gxd(A, lmd))) * $wnd.Math.sqrt((!A.a && (A.a = new C5d(J4, A, 10, 11)), A.a).i); + C = RD(Gxd(A, tld), 107); + s = C.b + C.c + 1; + r = C.d + C.a + 1; + return new rjd($wnd.Math.max(s, d), $wnd.Math.max(r, d / h)); + }; + tfb(JGe, "TopdownSizeApproximator/2", 988, M3, null, null); + var Dqd; + feb(344, 1, { 871: 1 }, Oqd); + _2.Ug = function Pqd(a, b) { + return Fqd(this, a, b); + }; + _2.Vg = function Qqd() { + Hqd(this); + }; + _2.Wg = function Rqd() { + return this.q; + }; + _2.Xg = function Sqd() { + return !this.f ? null : Hob(this.f); + }; + _2.Yg = function Tqd() { + return Hob(this.a); + }; + _2.Zg = function Uqd() { + return this.p; + }; + _2.$g = function Vqd() { + return false; + }; + _2._g = function Wqd() { + return this.n; + }; + _2.ah = function Xqd() { + return this.p != null && !this.b; + }; + _2.bh = function Yqd(a) { + var b; + if (this.n) { + b = a; + Rmb(this.f, b); + } + }; + _2.dh = function Zqd(a, b) { + var c2, d; + this.n && !!a && Jqd(this, (c2 = new Zje(), d = Rje(c2, a), Yje(c2), d), (ttd(), qtd)); + }; + _2.eh = function $qd(a) { + var b; + if (this.b) { + return null; + } else { + b = Gqd(this, this.g); + Mub(this.a, b); + b.i = this; + this.d = a; + return b; + } + }; + _2.fh = function _qd(a) { + a > 0 && !this.b && Iqd(this, a); + }; + _2.b = false; + _2.c = 0; + _2.d = -1; + _2.e = null; + _2.f = null; + _2.g = -1; + _2.j = false; + _2.k = false; + _2.n = false; + _2.o = 0; + _2.q = 0; + _2.r = 0; + sfb(jEe, "BasicProgressMonitor", 344); + feb(717, 205, oze, jrd); + _2.rf = function nrd(a, b) { + crd(a, b); + }; + sfb(jEe, "BoxLayoutProvider", 717); + feb(983, 1, fye, prd); + _2.Ne = function qrd(a, b) { + return ord(this, RD(a, 27), RD(b, 27)); + }; + _2.Fb = function rrd(a) { + return this === a; + }; + _2.Oe = function srd() { + return new Frb(this); + }; + _2.a = false; + sfb(jEe, "BoxLayoutProvider/1", 983); + feb(163, 1, { 163: 1 }, zrd, Ard); + _2.Ib = function Brd() { + return this.c ? zCd(this.c) : Fe(this.b); + }; + sfb(jEe, "BoxLayoutProvider/Group", 163); + feb(320, 22, { 3: 1, 34: 1, 22: 1, 320: 1 }, Hrd); + var Crd, Drd, Erd, Frd; + var R3 = tfb(jEe, "BoxLayoutProvider/PackingMode", 320, WI, Jrd, Ird); + var Krd; + feb(984, 1, fye, Mrd); + _2.Ne = function Nrd(a, b) { + return krd(RD(a, 163), RD(b, 163)); + }; + _2.Fb = function Ord(a) { + return this === a; + }; + _2.Oe = function Prd() { + return new Frb(this); + }; + sfb(jEe, "BoxLayoutProvider/lambda$0$Type", 984); + feb(985, 1, fye, Qrd); + _2.Ne = function Rrd(a, b) { + return lrd(RD(a, 163), RD(b, 163)); + }; + _2.Fb = function Srd(a) { + return this === a; + }; + _2.Oe = function Trd() { + return new Frb(this); + }; + sfb(jEe, "BoxLayoutProvider/lambda$1$Type", 985); + feb(986, 1, fye, Urd); + _2.Ne = function Vrd(a, b) { + return mrd(RD(a, 163), RD(b, 163)); + }; + _2.Fb = function Wrd(a) { + return this === a; + }; + _2.Oe = function Xrd() { + return new Frb(this); + }; + sfb(jEe, "BoxLayoutProvider/lambda$2$Type", 986); + feb(1384, 1, { 845: 1 }, Yrd); + _2.Mg = function Zrd(a, b) { + return GCc(), !ZD(b, 167) || ued((hed(), RD(a, 167)), b); + }; + sfb(jEe, "ElkSpacings/AbstractSpacingsBuilder/lambda$0$Type", 1384); + feb(1385, 1, Qve, $rd); + _2.Cd = function _rd(a) { + JCc(this.a, RD(a, 149)); + }; + sfb(jEe, "ElkSpacings/AbstractSpacingsBuilder/lambda$1$Type", 1385); + feb(1386, 1, Qve, asd); + _2.Cd = function bsd(a) { + RD(a, 96); + GCc(); + }; + sfb(jEe, "ElkSpacings/AbstractSpacingsBuilder/lambda$2$Type", 1386); + feb(1390, 1, Qve, csd); + _2.Cd = function dsd(a) { + KCc(this.a, RD(a, 96)); + }; + sfb(jEe, "ElkSpacings/AbstractSpacingsBuilder/lambda$3$Type", 1390); + feb(1388, 1, nwe, esd); + _2.Mb = function fsd(a) { + return LCc(this.a, this.b, RD(a, 149)); + }; + sfb(jEe, "ElkSpacings/AbstractSpacingsBuilder/lambda$4$Type", 1388); + feb(1387, 1, nwe, gsd); + _2.Mb = function hsd(a) { + return NCc(this.a, this.b, RD(a, 845)); + }; + sfb(jEe, "ElkSpacings/AbstractSpacingsBuilder/lambda$5$Type", 1387); + feb(1389, 1, Qve, isd); + _2.Cd = function jsd(a) { + MCc(this.a, this.b, RD(a, 149)); + }; + sfb(jEe, "ElkSpacings/AbstractSpacingsBuilder/lambda$6$Type", 1389); + feb(947, 1, {}, Lsd); + _2.Kb = function Msd(a) { + return Ksd(a); + }; + _2.Fb = function Nsd(a) { + return this === a; + }; + sfb(jEe, "ElkUtil/lambda$0$Type", 947); + feb(948, 1, Qve, Osd); + _2.Cd = function Psd(a) { + ysd(this.a, this.b, RD(a, 74)); + }; + _2.a = 0; + _2.b = 0; + sfb(jEe, "ElkUtil/lambda$1$Type", 948); + feb(949, 1, Qve, Qsd); + _2.Cd = function Rsd(a) { + zsd(this.a, this.b, RD(a, 166)); + }; + _2.a = 0; + _2.b = 0; + sfb(jEe, "ElkUtil/lambda$2$Type", 949); + feb(950, 1, Qve, Ssd); + _2.Cd = function Tsd(a) { + Asd(this.a, this.b, RD(a, 135)); + }; + _2.a = 0; + _2.b = 0; + sfb(jEe, "ElkUtil/lambda$3$Type", 950); + feb(951, 1, Qve, Usd); + _2.Cd = function Vsd(a) { + Bsd(this.a, RD(a, 377)); + }; + sfb(jEe, "ElkUtil/lambda$4$Type", 951); + feb(325, 1, { 34: 1, 325: 1 }, Xsd); + _2.Fd = function Ysd(a) { + return Wsd(this, RD(a, 242)); + }; + _2.Fb = function Zsd(a) { + var b; + if (ZD(a, 325)) { + b = RD(a, 325); + return this.a == b.a; + } + return false; + }; + _2.Hb = function $sd() { + return eE(this.a); + }; + _2.Ib = function _sd() { + return this.a + " (exclusive)"; + }; + _2.a = 0; + sfb(jEe, "ExclusiveBounds/ExclusiveLowerBound", 325); + feb(1119, 205, oze, btd); + _2.rf = function ctd(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r, s, t, u, v, w2, A, B; + b.Ug("Fixed Layout", 1); + f2 = RD(Gxd(a, (umd(), Skd)), 223); + l = 0; + m = 0; + for (s = new dMd((!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a)); s.e != s.i.gc(); ) { + q = RD(bMd(s), 27); + B = RD(Gxd(q, (vnd(), und)), 8); + if (B) { + Byd(q, B.a, B.b); + if (RD(Gxd(q, pnd), 181).Hc((Qpd(), Mpd))) { + n = RD(Gxd(q, rnd), 8); + n.a > 0 && n.b > 0 && Esd(q, n.a, n.b, true, true); + } + } + l = $wnd.Math.max(l, q.i + q.g); + m = $wnd.Math.max(m, q.j + q.f); + for (j = new dMd((!q.n && (q.n = new C5d(I4, q, 1, 7)), q.n)); j.e != j.i.gc(); ) { + h = RD(bMd(j), 135); + B = RD(Gxd(h, und), 8); + !!B && Byd(h, B.a, B.b); + l = $wnd.Math.max(l, q.i + h.i + h.g); + m = $wnd.Math.max(m, q.j + h.j + h.f); + } + for (v = new dMd((!q.c && (q.c = new C5d(K4, q, 9, 9)), q.c)); v.e != v.i.gc(); ) { + u = RD(bMd(v), 123); + B = RD(Gxd(u, und), 8); + !!B && Byd(u, B.a, B.b); + w2 = q.i + u.i; + A = q.j + u.j; + l = $wnd.Math.max(l, w2 + u.g); + m = $wnd.Math.max(m, A + u.f); + for (i2 = new dMd((!u.n && (u.n = new C5d(I4, u, 1, 7)), u.n)); i2.e != i2.i.gc(); ) { + h = RD(bMd(i2), 135); + B = RD(Gxd(h, und), 8); + !!B && Byd(h, B.a, B.b); + l = $wnd.Math.max(l, w2 + h.i + h.g); + m = $wnd.Math.max(m, A + h.j + h.f); + } + } + for (e = new is(Mr(zGd(q).a.Kc(), new ir())); gs(e); ) { + c2 = RD(hs(e), 74); + k = atd(c2); + l = $wnd.Math.max(l, k.a); + m = $wnd.Math.max(m, k.b); + } + for (d = new is(Mr(yGd(q).a.Kc(), new ir())); gs(d); ) { + c2 = RD(hs(d), 74); + if (vCd(JGd(c2)) != a) { + k = atd(c2); + l = $wnd.Math.max(l, k.a); + m = $wnd.Math.max(m, k.b); + } + } + } + if (f2 == (Ymd(), Umd)) { + for (r = new dMd((!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a)); r.e != r.i.gc(); ) { + q = RD(bMd(r), 27); + for (d = new is(Mr(zGd(q).a.Kc(), new ir())); gs(d); ) { + c2 = RD(hs(d), 74); + g = tsd(c2); + g.b == 0 ? Ixd(c2, cld, null) : Ixd(c2, cld, g); + } + } + } + if (!Heb(TD(Gxd(a, (vnd(), qnd))))) { + t = RD(Gxd(a, snd), 107); + p = l + t.b + t.c; + o2 = m + t.d + t.a; + Esd(a, p, o2, true, true); + } + b.Vg(); + }; + sfb(jEe, "FixedLayoutProvider", 1119); + feb(385, 137, { 3: 1, 423: 1, 385: 1, 96: 1, 137: 1 }, dtd, etd); + _2.cg = function htd(b) { + var c2, d, e, f2, g, h, i2, j, k; + if (!b) { + return; + } + try { + j = vhb(b, ";,;"); + for (g = j, h = 0, i2 = g.length; h < i2; ++h) { + f2 = g[h]; + d = vhb(f2, "\\:"); + e = vgd(ygd(), d[0]); + if (!e) { + throw Adb(new agb("Invalid option id: " + d[0])); + } + k = zhd(e, d[1]); + if (k == null) { + throw Adb(new agb("Invalid option value: " + d[1])); + } + k == null ? (!this.q && (this.q = new Tsb()), _jb(this.q, e)) : (!this.q && (this.q = new Tsb()), Zjb(this.q, e, k)); + } + } catch (a) { + a = zdb(a); + if (ZD(a, 103)) { + c2 = a; + throw Adb(new bgb(c2)); + } else + throw Adb(a); + } + }; + _2.Ib = function itd() { + var a; + a = WD(zDb(GDb((!this.q ? (yob(), yob(), wob) : this.q).vc().Oc(), new jtd()), sBb(new hCb(), new fCb(), new RBb(), new TBb(), cD(WC(QL, 1), jwe, 108, 0, [])))); + return a; + }; + var l4 = sfb(jEe, "IndividualSpacings", 385); + feb(982, 1, {}, jtd); + _2.Kb = function ktd(a) { + return gtd(RD(a, 44)); + }; + sfb(jEe, "IndividualSpacings/lambda$0$Type", 982); + feb(718, 1, {}, ntd); + _2.c = 0; + sfb(jEe, "InstancePool", 718); + feb(1835, 1, {}, otd); + sfb(jEe, "LoggedGraph", 1835); + feb(415, 22, { 3: 1, 34: 1, 22: 1, 415: 1 }, utd); + var ptd, qtd, rtd, std; + var n4 = tfb(jEe, "LoggedGraph/Type", 415, WI, wtd, vtd); + var xtd; + feb(1063, 1, { 871: 1 }, ztd); + _2.Ug = function Atd(a, b) { + return false; + }; + _2.Vg = function Btd() { + }; + _2.Wg = function Ctd() { + return 0; + }; + _2.Xg = function Dtd() { + return null; + }; + _2.Yg = function Etd() { + return null; + }; + _2.Zg = function Ftd() { + return null; + }; + _2.$g = function Gtd() { + return false; + }; + _2._g = function Htd() { + return false; + }; + _2.ah = function Itd() { + return false; + }; + _2.bh = function Jtd(a) { + }; + _2.dh = function Ktd(a, b) { + }; + _2.eh = function Ltd(a) { + return this; + }; + _2.fh = function Mtd(a) { + }; + sfb(jEe, "NullElkProgressMonitor", 1063); + feb(42, 1, { 20: 1, 42: 1 }, Ptd); + _2.Jc = function Rtd(a) { + xgb(this, a); + }; + _2.Fb = function Qtd(a) { + var b, c2, d; + if (ZD(a, 42)) { + c2 = RD(a, 42); + b = this.a == null ? c2.a == null : pb(this.a, c2.a); + d = this.b == null ? c2.b == null : pb(this.b, c2.b); + return b && d; + } else { + return false; + } + }; + _2.Hb = function Std() { + var a, b, c2, d, e, f2; + c2 = this.a == null ? 0 : tb(this.a); + a = c2 & Bwe; + b = c2 & -65536; + f2 = this.b == null ? 0 : tb(this.b); + d = f2 & Bwe; + e = f2 & -65536; + return a ^ e >> 16 & Bwe | b ^ d << 16; + }; + _2.Kc = function Ttd() { + return new Vtd(this); + }; + _2.Ib = function Utd() { + return this.a == null && this.b == null ? "pair(null,null)" : this.a == null ? "pair(null," + jeb(this.b) + ")" : this.b == null ? "pair(" + jeb(this.a) + ",null)" : "pair(" + jeb(this.a) + "," + jeb(this.b) + ")"; + }; + sfb(jEe, "Pair", 42); + feb(995, 1, Ave, Vtd); + _2.Nb = function Wtd(a) { + Ztb(this, a); + }; + _2.Ob = function Xtd() { + return !this.c && (!this.b && this.a.a != null || this.a.b != null); + }; + _2.Pb = function Ytd() { + if (!this.c && !this.b && this.a.a != null) { + this.b = true; + return this.a.a; + } else if (!this.c && this.a.b != null) { + this.c = true; + return this.a.b; + } + throw Adb(new Dvb()); + }; + _2.Qb = function Ztd() { + this.c && this.a.b != null ? this.a.b = null : this.b && this.a.a != null && (this.a.a = null); + throw Adb(new cgb()); + }; + _2.b = false; + _2.c = false; + sfb(jEe, "Pair/1", 995); + feb(455, 1, { 455: 1 }, $td); + _2.Fb = function _td(a) { + return Fvb(this.a, RD(a, 455).a) && Fvb(this.c, RD(a, 455).c) && Fvb(this.d, RD(a, 455).d) && Fvb(this.b, RD(a, 455).b); + }; + _2.Hb = function aud() { + return Tnb(cD(WC(jJ, 1), rve, 1, 5, [this.a, this.c, this.d, this.b])); + }; + _2.Ib = function bud() { + return "(" + this.a + pve + this.c + pve + this.d + pve + this.b + ")"; + }; + sfb(jEe, "Quadruple", 455); + feb(1108, 205, oze, eud); + _2.rf = function fud(a, b) { + var c2, d, e, f2, g; + b.Ug("Random Layout", 1); + if ((!a.a && (a.a = new C5d(J4, a, 10, 11)), a.a).i == 0) { + b.Vg(); + return; + } + f2 = RD(Gxd(a, (Fpd(), Dpd)), 17); + !!f2 && f2.a != 0 ? e = new Pwb(f2.a) : e = new Owb(); + c2 = Mfb(UD(Gxd(a, Apd))); + g = Mfb(UD(Gxd(a, Epd))); + d = RD(Gxd(a, Bpd), 107); + dud(a, e, c2, g, d); + b.Vg(); + }; + sfb(jEe, "RandomLayoutProvider", 1108); + feb(240, 1, { 240: 1 }, gud); + _2.Fb = function hud(a) { + return Fvb(this.a, RD(a, 240).a) && Fvb(this.b, RD(a, 240).b) && Fvb(this.c, RD(a, 240).c); + }; + _2.Hb = function iud() { + return Tnb(cD(WC(jJ, 1), rve, 1, 5, [this.a, this.b, this.c])); + }; + _2.Ib = function jud() { + return "(" + this.a + pve + this.b + pve + this.c + ")"; + }; + sfb(jEe, "Triple", 240); + var kud; + feb(562, 1, {}); + _2.Lf = function oud() { + return new rjd(this.f.i, this.f.j); + }; + _2.of = function pud(a) { + if (hGd(a, (umd(), Gld))) { + return Gxd(this.f, mud); + } + return Gxd(this.f, a); + }; + _2.Mf = function qud() { + return new rjd(this.f.g, this.f.f); + }; + _2.Nf = function rud() { + return this.g; + }; + _2.pf = function sud(a) { + return Hxd(this.f, a); + }; + _2.Of = function tud(a) { + Dyd(this.f, a.a); + Eyd(this.f, a.b); + }; + _2.Pf = function uud(a) { + Cyd(this.f, a.a); + Ayd(this.f, a.b); + }; + _2.Qf = function vud(a) { + this.g = a; + }; + _2.g = 0; + var mud; + sfb(uHe, "ElkGraphAdapters/AbstractElkGraphElementAdapter", 562); + feb(563, 1, { 853: 1 }, wud); + _2.Rf = function xud() { + var a, b; + if (!this.b) { + this.b = fv(iyd(this.a).i); + for (b = new dMd(iyd(this.a)); b.e != b.i.gc(); ) { + a = RD(bMd(b), 135); + Rmb(this.b, new Bud(a)); + } + } + return this.b; + }; + _2.b = null; + sfb(uHe, "ElkGraphAdapters/ElkEdgeAdapter", 563); + feb(289, 562, {}, zud); + _2.Sf = function Aud() { + return yud(this); + }; + _2.a = null; + sfb(uHe, "ElkGraphAdapters/ElkGraphAdapter", 289); + feb(640, 562, { 187: 1 }, Bud); + sfb(uHe, "ElkGraphAdapters/ElkLabelAdapter", 640); + feb(639, 562, { 695: 1 }, Fud); + _2.Rf = function Iud() { + return Cud(this); + }; + _2.Vf = function Jud() { + var a; + return a = RD(Gxd(this.f, (umd(), eld)), 140), !a && (a = new P2b()), a; + }; + _2.Xf = function Lud() { + return Dud(this); + }; + _2.Zf = function Nud(a) { + var b; + b = new S2b(a); + Ixd(this.f, (umd(), eld), b); + }; + _2.$f = function Oud(a) { + Ixd(this.f, (umd(), tld), new B3b(a)); + }; + _2.Tf = function Gud() { + return this.d; + }; + _2.Uf = function Hud() { + var a, b; + if (!this.a) { + this.a = new bnb(); + for (b = new is(Mr(yGd(RD(this.f, 27)).a.Kc(), new ir())); gs(b); ) { + a = RD(hs(b), 74); + Rmb(this.a, new wud(a)); + } + } + return this.a; + }; + _2.Wf = function Kud() { + var a, b; + if (!this.c) { + this.c = new bnb(); + for (b = new is(Mr(zGd(RD(this.f, 27)).a.Kc(), new ir())); gs(b); ) { + a = RD(hs(b), 74); + Rmb(this.c, new wud(a)); + } + } + return this.c; + }; + _2.Yf = function Mud() { + return tCd(RD(this.f, 27)).i != 0 || Heb(TD(RD(this.f, 27).of((umd(), $kd)))); + }; + _2._f = function Pud() { + Eud(this, (lud(), kud)); + }; + _2.a = null; + _2.b = null; + _2.c = null; + _2.d = null; + _2.e = null; + sfb(uHe, "ElkGraphAdapters/ElkNodeAdapter", 639); + feb(1284, 562, { 852: 1 }, Rud); + _2.Rf = function Tud() { + return Qud(this); + }; + _2.Uf = function Sud() { + var a, b; + if (!this.a) { + this.a = ev(RD(this.f, 123).hh().i); + for (b = new dMd(RD(this.f, 123).hh()); b.e != b.i.gc(); ) { + a = RD(bMd(b), 74); + Rmb(this.a, new wud(a)); + } + } + return this.a; + }; + _2.Wf = function Uud() { + var a, b; + if (!this.c) { + this.c = ev(RD(this.f, 123).ih().i); + for (b = new dMd(RD(this.f, 123).ih()); b.e != b.i.gc(); ) { + a = RD(bMd(b), 74); + Rmb(this.c, new wud(a)); + } + } + return this.c; + }; + _2.ag = function Vud() { + return RD(RD(this.f, 123).of((umd(), Old)), 64); + }; + _2.bg = function Wud() { + var a, b, c2, d, e, f2, g, h; + d = MCd(RD(this.f, 123)); + for (c2 = new dMd(RD(this.f, 123).ih()); c2.e != c2.i.gc(); ) { + a = RD(bMd(c2), 74); + for (h = new dMd((!a.c && (a.c = new Yie(E4, a, 5, 8)), a.c)); h.e != h.i.gc(); ) { + g = RD(bMd(h), 84); + if (NGd(AGd(g), d)) { + return true; + } else if (AGd(g) == d && Heb(TD(Gxd(a, (umd(), _kd))))) { + return true; + } + } + } + for (b = new dMd(RD(this.f, 123).hh()); b.e != b.i.gc(); ) { + a = RD(bMd(b), 74); + for (f2 = new dMd((!a.b && (a.b = new Yie(E4, a, 4, 7)), a.b)); f2.e != f2.i.gc(); ) { + e = RD(bMd(f2), 84); + if (NGd(AGd(e), d)) { + return true; + } + } + } + return false; + }; + _2.a = null; + _2.b = null; + _2.c = null; + sfb(uHe, "ElkGraphAdapters/ElkPortAdapter", 1284); + feb(1285, 1, fye, Yud); + _2.Ne = function Zud(a, b) { + return Xud(RD(a, 123), RD(b, 123)); + }; + _2.Fb = function $ud(a) { + return this === a; + }; + _2.Oe = function _ud() { + return new Frb(this); + }; + sfb(uHe, "ElkGraphAdapters/PortComparator", 1285); + var r7 = ufb(vHe, "EObject"); + var C4 = ufb(wHe, xHe); + var D4 = ufb(wHe, yHe); + var H4 = ufb(wHe, zHe); + var L4 = ufb(wHe, "ElkShape"); + var E4 = ufb(wHe, AHe); + var G4 = ufb(wHe, BHe); + var F4 = ufb(wHe, CHe); + var p7 = ufb(vHe, DHe); + var n7 = ufb(vHe, "EFactory"); + var avd; + var q7 = ufb(vHe, EHe); + var t7 = ufb(vHe, "EPackage"); + var cvd; + var evd, fvd, gvd, hvd, ivd, jvd, kvd, lvd, mvd, nvd, ovd; + var I4 = ufb(wHe, FHe); + var J4 = ufb(wHe, GHe); + var K4 = ufb(wHe, HHe); + feb(93, 1, IHe); + _2.th = function rvd() { + this.uh(); + return null; + }; + _2.uh = function svd() { + return null; + }; + _2.vh = function tvd() { + return this.uh(), false; + }; + _2.wh = function uvd() { + return false; + }; + _2.xh = function vvd(a) { + qvd(this, a); + }; + sfb(JHe, "BasicNotifierImpl", 93); + feb(99, 93, RHe); + _2.Yh = function Dwd() { + return Mvd(this); + }; + _2.yh = function bwd(a, b) { + return a; + }; + _2.zh = function cwd() { + throw Adb(new jib()); + }; + _2.Ah = function dwd(a) { + var b; + return b = Z5d(RD(vYd(this.Dh(), this.Fh()), 19)), this.Ph().Th(this, b.n, b.f, a); + }; + _2.Bh = function ewd(a, b) { + throw Adb(new jib()); + }; + _2.Ch = function fwd(a, b, c2) { + return xvd(this, a, b, c2); + }; + _2.Dh = function gwd() { + var a; + if (this.zh()) { + a = this.zh().Nk(); + if (a) { + return a; + } + } + return this.ii(); + }; + _2.Eh = function hwd() { + return yvd(this); + }; + _2.Fh = function iwd() { + throw Adb(new jib()); + }; + _2.Gh = function kwd() { + var a, b; + b = this.$h().Ok(); + !b && this.zh().Tk(b = (N2d(), a = P$d(rYd(this.Dh())), a == null ? M2d : new Q2d(this, a))); + return b; + }; + _2.Hh = function mwd(a, b) { + return a; + }; + _2.Ih = function nwd(a) { + var b; + b = a.pk(); + return !b ? BYd(this.Dh(), a) : a.Lj(); + }; + _2.Jh = function owd() { + var a; + a = this.zh(); + return !a ? null : a.Qk(); + }; + _2.Kh = function pwd() { + return !this.zh() ? null : this.zh().Nk(); + }; + _2.Lh = function qwd(a, b, c2) { + return Dvd(this, a, b, c2); + }; + _2.Mh = function rwd(a) { + return Evd(this, a); + }; + _2.Nh = function swd(a, b) { + return Fvd(this, a, b); + }; + _2.Oh = function twd() { + var a; + a = this.zh(); + return !!a && a.Rk(); + }; + _2.Ph = function uwd() { + throw Adb(new jib()); + }; + _2.Qh = function vwd() { + return Hvd(this); + }; + _2.Rh = function wwd(a, b, c2, d) { + return Ivd(this, a, b, d); + }; + _2.Sh = function xwd(a, b, c2) { + var d; + return d = RD(vYd(this.Dh(), b), 69), d.wk().zk(this, this.hi(), b - this.ji(), a, c2); + }; + _2.Th = function ywd(a, b, c2, d) { + return Jvd(this, a, b, d); + }; + _2.Uh = function zwd(a, b, c2) { + var d; + return d = RD(vYd(this.Dh(), b), 69), d.wk().Ak(this, this.hi(), b - this.ji(), a, c2); + }; + _2.Vh = function Awd() { + return !!this.zh() && !!this.zh().Pk(); + }; + _2.Wh = function Bwd(a) { + return Kvd(this, a); + }; + _2.Xh = function Cwd(a) { + return Lvd(this, a); + }; + _2.Zh = function Ewd(a) { + return Pvd(this, a); + }; + _2.$h = function Fwd() { + throw Adb(new jib()); + }; + _2._h = function Gwd() { + return !this.zh() ? null : this.zh().Pk(); + }; + _2.ai = function Hwd() { + return Hvd(this); + }; + _2.bi = function Iwd(a, b) { + Wvd(this, a, b); + }; + _2.ci = function Jwd(a) { + this.$h().Sk(a); + }; + _2.di = function Kwd(a) { + this.$h().Vk(a); + }; + _2.ei = function Lwd(a) { + this.$h().Uk(a); + }; + _2.fi = function Mwd(a, b) { + var c2, d, e, f2; + f2 = this.Jh(); + if (!!f2 && !!a) { + b = rLd(f2.El(), this, b); + f2.Il(this); + } + d = this.Ph(); + if (d) { + if ((jwd(this, this.Ph(), this.Fh()).Bb & txe) != 0) { + e = d.Qh(); + !!e && (!a ? e.Hl(this) : !f2 && e.Il(this)); + } else { + b = (c2 = this.Fh(), c2 >= 0 ? this.Ah(b) : this.Ph().Th(this, -1 - c2, null, b)); + b = this.Ch(null, -1, b); + } + } + this.di(a); + return b; + }; + _2.gi = function Nwd(a) { + var b, c2, d, e, f2, g, h, i2; + c2 = this.Dh(); + f2 = BYd(c2, a); + b = this.ji(); + if (f2 >= b) { + return RD(a, 69).wk().Dk(this, this.hi(), f2 - b); + } else if (f2 <= -1) { + g = Eee((lke(), jke), c2, a); + if (g) { + nke(); + RD(g, 69).xk() || (g = zfe(Qee(jke, g))); + e = (d = this.Ih(g), RD(d >= 0 ? this.Lh(d, true, true) : Qvd(this, g, true), 160)); + i2 = g.Ik(); + if (i2 > 1 || i2 == -1) { + return RD(RD(e, 220).Sl(a, false), 79); + } + } else { + throw Adb(new agb(KHe + a.xe() + NHe)); + } + } else if (a.Jk()) { + return d = this.Ih(a), RD(d >= 0 ? this.Lh(d, false, true) : Qvd(this, a, false), 79); + } + h = new NTd(this, a); + return h; + }; + _2.hi = function Owd() { + return Yvd(this); + }; + _2.ii = function Pwd() { + return (lTd(), kTd).S; + }; + _2.ji = function Qwd() { + return AYd(this.ii()); + }; + _2.ki = function Rwd(a) { + $vd(this, a); + }; + _2.Ib = function Swd() { + return awd(this); + }; + sfb(SHe, "BasicEObjectImpl", 99); + var ZSd; + feb(119, 99, { 110: 1, 94: 1, 93: 1, 58: 1, 114: 1, 54: 1, 99: 1, 119: 1 }); + _2.li = function _wd(a) { + var b; + b = Vwd(this); + return b[a]; + }; + _2.mi = function axd(a, b) { + var c2; + c2 = Vwd(this); + bD(c2, a, b); + }; + _2.ni = function bxd(a) { + var b; + b = Vwd(this); + bD(b, a, null); + }; + _2.th = function cxd() { + return RD(Ywd(this, 4), 129); + }; + _2.uh = function dxd() { + throw Adb(new jib()); + }; + _2.vh = function exd() { + return (this.Db & 4) != 0; + }; + _2.zh = function fxd() { + throw Adb(new jib()); + }; + _2.oi = function gxd(a) { + $wd(this, 2, a); + }; + _2.Bh = function hxd(a, b) { + this.Db = b << 16 | this.Db & 255; + this.oi(a); + }; + _2.Dh = function ixd() { + return Uwd(this); + }; + _2.Fh = function jxd() { + return this.Db >> 16; + }; + _2.Gh = function kxd() { + var a, b; + return N2d(), b = P$d(rYd((a = RD(Ywd(this, 16), 29), !a ? this.ii() : a))), b == null ? M2d : new Q2d(this, b); + }; + _2.wh = function lxd() { + return (this.Db & 1) == 0; + }; + _2.Jh = function mxd() { + return RD(Ywd(this, 128), 2034); + }; + _2.Kh = function nxd() { + return RD(Ywd(this, 16), 29); + }; + _2.Oh = function oxd() { + return (this.Db & 32) != 0; + }; + _2.Ph = function pxd() { + return RD(Ywd(this, 2), 54); + }; + _2.Vh = function qxd() { + return (this.Db & 64) != 0; + }; + _2.$h = function rxd() { + throw Adb(new jib()); + }; + _2._h = function sxd() { + return RD(Ywd(this, 64), 288); + }; + _2.ci = function txd(a) { + $wd(this, 16, a); + }; + _2.di = function uxd(a) { + $wd(this, 128, a); + }; + _2.ei = function vxd(a) { + $wd(this, 64, a); + }; + _2.hi = function wxd() { + return Wwd(this); + }; + _2.Db = 0; + sfb(SHe, "MinimalEObjectImpl", 119); + feb(120, 119, { 110: 1, 94: 1, 93: 1, 58: 1, 114: 1, 54: 1, 99: 1, 119: 1, 120: 1 }); + _2.oi = function xxd(a) { + this.Cb = a; + }; + _2.Ph = function yxd() { + return this.Cb; + }; + sfb(SHe, "MinimalEObjectImpl/Container", 120); + feb(2083, 120, { 110: 1, 342: 1, 96: 1, 94: 1, 93: 1, 58: 1, 114: 1, 54: 1, 99: 1, 119: 1, 120: 1 }); + _2.Lh = function Jxd(a, b, c2) { + return Axd(this, a, b, c2); + }; + _2.Uh = function Kxd(a, b, c2) { + return Bxd(this, a, b, c2); + }; + _2.Wh = function Lxd(a) { + return Cxd(this, a); + }; + _2.bi = function Mxd(a, b) { + Dxd(this, a, b); + }; + _2.ii = function Nxd() { + return pvd(), ovd; + }; + _2.ki = function Oxd(a) { + Exd(this, a); + }; + _2.nf = function Pxd() { + return Fxd(this); + }; + _2.gh = function Qxd() { + return !this.o && (this.o = new DVd((pvd(), mvd), X4, this, 0)), this.o; + }; + _2.of = function Rxd(a) { + return Gxd(this, a); + }; + _2.pf = function Sxd(a) { + return Hxd(this, a); + }; + _2.qf = function Txd(a, b) { + return Ixd(this, a, b); + }; + sfb(THe, "EMapPropertyHolderImpl", 2083); + feb(572, 120, { 110: 1, 377: 1, 94: 1, 93: 1, 58: 1, 114: 1, 54: 1, 99: 1, 119: 1, 120: 1 }, Xxd); + _2.Lh = function Yxd(a, b, c2) { + switch (a) { + case 0: + return this.a; + case 1: + return this.b; + } + return Dvd(this, a, b, c2); + }; + _2.Wh = function Zxd(a) { + switch (a) { + case 0: + return this.a != 0; + case 1: + return this.b != 0; + } + return Kvd(this, a); + }; + _2.bi = function $xd(a, b) { + switch (a) { + case 0: + Vxd(this, Kfb(UD(b))); + return; + case 1: + Wxd(this, Kfb(UD(b))); + return; + } + Wvd(this, a, b); + }; + _2.ii = function _xd() { + return pvd(), evd; + }; + _2.ki = function ayd(a) { + switch (a) { + case 0: + Vxd(this, 0); + return; + case 1: + Wxd(this, 0); + return; + } + $vd(this, a); + }; + _2.Ib = function byd() { + var a; + if ((this.Db & 64) != 0) + return awd(this); + a = new Shb(awd(this)); + a.a += " (x: "; + Khb(a, this.a); + a.a += ", y: "; + Khb(a, this.b); + a.a += ")"; + return a.a; + }; + _2.a = 0; + _2.b = 0; + sfb(THe, "ElkBendPointImpl", 572); + feb(739, 2083, { 110: 1, 342: 1, 167: 1, 96: 1, 94: 1, 93: 1, 58: 1, 114: 1, 54: 1, 99: 1, 119: 1, 120: 1 }); + _2.Lh = function lyd(a, b, c2) { + return cyd(this, a, b, c2); + }; + _2.Sh = function myd(a, b, c2) { + return dyd(this, a, b, c2); + }; + _2.Uh = function nyd(a, b, c2) { + return eyd(this, a, b, c2); + }; + _2.Wh = function oyd(a) { + return fyd(this, a); + }; + _2.bi = function pyd(a, b) { + gyd(this, a, b); + }; + _2.ii = function qyd() { + return pvd(), ivd; + }; + _2.ki = function ryd(a) { + hyd(this, a); + }; + _2.jh = function syd() { + return this.k; + }; + _2.kh = function tyd() { + return iyd(this); + }; + _2.Ib = function uyd() { + return kyd(this); + }; + _2.k = null; + sfb(THe, "ElkGraphElementImpl", 739); + feb(740, 739, { 110: 1, 342: 1, 167: 1, 422: 1, 96: 1, 94: 1, 93: 1, 58: 1, 114: 1, 54: 1, 99: 1, 119: 1, 120: 1 }); + _2.Lh = function Gyd(a, b, c2) { + return vyd(this, a, b, c2); + }; + _2.Wh = function Hyd(a) { + return wyd(this, a); + }; + _2.bi = function Iyd(a, b) { + xyd(this, a, b); + }; + _2.ii = function Jyd() { + return pvd(), nvd; + }; + _2.ki = function Kyd(a) { + yyd(this, a); + }; + _2.lh = function Lyd() { + return this.f; + }; + _2.mh = function Myd() { + return this.g; + }; + _2.nh = function Nyd() { + return this.i; + }; + _2.oh = function Oyd() { + return this.j; + }; + _2.ph = function Pyd(a, b) { + zyd(this, a, b); + }; + _2.qh = function Qyd(a, b) { + Byd(this, a, b); + }; + _2.rh = function Ryd(a) { + Dyd(this, a); + }; + _2.sh = function Syd(a) { + Eyd(this, a); + }; + _2.Ib = function Tyd() { + return Fyd(this); + }; + _2.f = 0; + _2.g = 0; + _2.i = 0; + _2.j = 0; + sfb(THe, "ElkShapeImpl", 740); + feb(741, 740, { 110: 1, 342: 1, 84: 1, 167: 1, 422: 1, 96: 1, 94: 1, 93: 1, 58: 1, 114: 1, 54: 1, 99: 1, 119: 1, 120: 1 }); + _2.Lh = function _yd(a, b, c2) { + return Uyd(this, a, b, c2); + }; + _2.Sh = function azd(a, b, c2) { + return Vyd(this, a, b, c2); + }; + _2.Uh = function bzd(a, b, c2) { + return Wyd(this, a, b, c2); + }; + _2.Wh = function czd(a) { + return Xyd(this, a); + }; + _2.bi = function dzd(a, b) { + Yyd(this, a, b); + }; + _2.ii = function ezd() { + return pvd(), fvd; + }; + _2.ki = function fzd(a) { + Zyd(this, a); + }; + _2.hh = function gzd() { + return !this.d && (this.d = new Yie(G4, this, 8, 5)), this.d; + }; + _2.ih = function hzd() { + return !this.e && (this.e = new Yie(G4, this, 7, 4)), this.e; + }; + sfb(THe, "ElkConnectableShapeImpl", 741); + feb(326, 739, { 110: 1, 342: 1, 74: 1, 167: 1, 326: 1, 96: 1, 94: 1, 93: 1, 58: 1, 114: 1, 54: 1, 99: 1, 119: 1, 120: 1 }, rzd); + _2.Ah = function szd(a) { + return jzd(this, a); + }; + _2.Lh = function tzd(a, b, c2) { + switch (a) { + case 3: + return kzd(this); + case 4: + return !this.b && (this.b = new Yie(E4, this, 4, 7)), this.b; + case 5: + return !this.c && (this.c = new Yie(E4, this, 5, 8)), this.c; + case 6: + return !this.a && (this.a = new C5d(F4, this, 6, 6)), this.a; + case 7: + return Geb(), !this.b && (this.b = new Yie(E4, this, 4, 7)), this.b.i <= 1 && (!this.c && (this.c = new Yie(E4, this, 5, 8)), this.c.i <= 1) ? false : true; + case 8: + return Geb(), nzd(this) ? true : false; + case 9: + return Geb(), ozd(this) ? true : false; + case 10: + return Geb(), !this.b && (this.b = new Yie(E4, this, 4, 7)), this.b.i != 0 && (!this.c && (this.c = new Yie(E4, this, 5, 8)), this.c.i != 0) ? true : false; + } + return cyd(this, a, b, c2); + }; + _2.Sh = function uzd(a, b, c2) { + var d; + switch (b) { + case 3: + !!this.Cb && (c2 = (d = this.Db >> 16, d >= 0 ? jzd(this, c2) : this.Cb.Th(this, -1 - d, null, c2))); + return izd(this, RD(a, 27), c2); + case 4: + return !this.b && (this.b = new Yie(E4, this, 4, 7)), qLd(this.b, a, c2); + case 5: + return !this.c && (this.c = new Yie(E4, this, 5, 8)), qLd(this.c, a, c2); + case 6: + return !this.a && (this.a = new C5d(F4, this, 6, 6)), qLd(this.a, a, c2); + } + return dyd(this, a, b, c2); + }; + _2.Uh = function vzd(a, b, c2) { + switch (b) { + case 3: + return izd(this, null, c2); + case 4: + return !this.b && (this.b = new Yie(E4, this, 4, 7)), rLd(this.b, a, c2); + case 5: + return !this.c && (this.c = new Yie(E4, this, 5, 8)), rLd(this.c, a, c2); + case 6: + return !this.a && (this.a = new C5d(F4, this, 6, 6)), rLd(this.a, a, c2); + } + return eyd(this, a, b, c2); + }; + _2.Wh = function wzd(a) { + switch (a) { + case 3: + return !!kzd(this); + case 4: + return !!this.b && this.b.i != 0; + case 5: + return !!this.c && this.c.i != 0; + case 6: + return !!this.a && this.a.i != 0; + case 7: + return !this.b && (this.b = new Yie(E4, this, 4, 7)), !(this.b.i <= 1 && (!this.c && (this.c = new Yie(E4, this, 5, 8)), this.c.i <= 1)); + case 8: + return nzd(this); + case 9: + return ozd(this); + case 10: + return !this.b && (this.b = new Yie(E4, this, 4, 7)), this.b.i != 0 && (!this.c && (this.c = new Yie(E4, this, 5, 8)), this.c.i != 0); + } + return fyd(this, a); + }; + _2.bi = function xzd(a, b) { + switch (a) { + case 3: + pzd(this, RD(b, 27)); + return; + case 4: + !this.b && (this.b = new Yie(E4, this, 4, 7)); + sLd(this.b); + !this.b && (this.b = new Yie(E4, this, 4, 7)); + YGd(this.b, RD(b, 16)); + return; + case 5: + !this.c && (this.c = new Yie(E4, this, 5, 8)); + sLd(this.c); + !this.c && (this.c = new Yie(E4, this, 5, 8)); + YGd(this.c, RD(b, 16)); + return; + case 6: + !this.a && (this.a = new C5d(F4, this, 6, 6)); + sLd(this.a); + !this.a && (this.a = new C5d(F4, this, 6, 6)); + YGd(this.a, RD(b, 16)); + return; + } + gyd(this, a, b); + }; + _2.ii = function yzd() { + return pvd(), gvd; + }; + _2.ki = function zzd(a) { + switch (a) { + case 3: + pzd(this, null); + return; + case 4: + !this.b && (this.b = new Yie(E4, this, 4, 7)); + sLd(this.b); + return; + case 5: + !this.c && (this.c = new Yie(E4, this, 5, 8)); + sLd(this.c); + return; + case 6: + !this.a && (this.a = new C5d(F4, this, 6, 6)); + sLd(this.a); + return; + } + hyd(this, a); + }; + _2.Ib = function Azd() { + return qzd(this); + }; + sfb(THe, "ElkEdgeImpl", 326); + feb(452, 2083, { 110: 1, 342: 1, 166: 1, 452: 1, 96: 1, 94: 1, 93: 1, 58: 1, 114: 1, 54: 1, 99: 1, 119: 1, 120: 1 }, Rzd); + _2.Ah = function Szd(a) { + return Czd(this, a); + }; + _2.Lh = function Tzd(a, b, c2) { + switch (a) { + case 1: + return this.j; + case 2: + return this.k; + case 3: + return this.b; + case 4: + return this.c; + case 5: + return !this.a && (this.a = new XZd(D4, this, 5)), this.a; + case 6: + return Fzd(this); + case 7: + if (b) + return Ezd(this); + return this.i; + case 8: + if (b) + return Dzd(this); + return this.f; + case 9: + return !this.g && (this.g = new Yie(F4, this, 9, 10)), this.g; + case 10: + return !this.e && (this.e = new Yie(F4, this, 10, 9)), this.e; + case 11: + return this.d; + } + return Axd(this, a, b, c2); + }; + _2.Sh = function Uzd(a, b, c2) { + var d, e, f2; + switch (b) { + case 6: + !!this.Cb && (c2 = (e = this.Db >> 16, e >= 0 ? Czd(this, c2) : this.Cb.Th(this, -1 - e, null, c2))); + return Bzd(this, RD(a, 74), c2); + case 9: + return !this.g && (this.g = new Yie(F4, this, 9, 10)), qLd(this.g, a, c2); + case 10: + return !this.e && (this.e = new Yie(F4, this, 10, 9)), qLd(this.e, a, c2); + } + return f2 = RD(vYd((d = RD(Ywd(this, 16), 29), !d ? (pvd(), hvd) : d), b), 69), f2.wk().zk(this, Wwd(this), b - AYd((pvd(), hvd)), a, c2); + }; + _2.Uh = function Vzd(a, b, c2) { + switch (b) { + case 5: + return !this.a && (this.a = new XZd(D4, this, 5)), rLd(this.a, a, c2); + case 6: + return Bzd(this, null, c2); + case 9: + return !this.g && (this.g = new Yie(F4, this, 9, 10)), rLd(this.g, a, c2); + case 10: + return !this.e && (this.e = new Yie(F4, this, 10, 9)), rLd(this.e, a, c2); + } + return Bxd(this, a, b, c2); + }; + _2.Wh = function Wzd(a) { + switch (a) { + case 1: + return this.j != 0; + case 2: + return this.k != 0; + case 3: + return this.b != 0; + case 4: + return this.c != 0; + case 5: + return !!this.a && this.a.i != 0; + case 6: + return !!Fzd(this); + case 7: + return !!this.i; + case 8: + return !!this.f; + case 9: + return !!this.g && this.g.i != 0; + case 10: + return !!this.e && this.e.i != 0; + case 11: + return this.d != null; + } + return Cxd(this, a); + }; + _2.bi = function Xzd(a, b) { + switch (a) { + case 1: + Ozd(this, Kfb(UD(b))); + return; + case 2: + Pzd(this, Kfb(UD(b))); + return; + case 3: + Hzd(this, Kfb(UD(b))); + return; + case 4: + Izd(this, Kfb(UD(b))); + return; + case 5: + !this.a && (this.a = new XZd(D4, this, 5)); + sLd(this.a); + !this.a && (this.a = new XZd(D4, this, 5)); + YGd(this.a, RD(b, 16)); + return; + case 6: + Mzd(this, RD(b, 74)); + return; + case 7: + Lzd(this, RD(b, 84)); + return; + case 8: + Kzd(this, RD(b, 84)); + return; + case 9: + !this.g && (this.g = new Yie(F4, this, 9, 10)); + sLd(this.g); + !this.g && (this.g = new Yie(F4, this, 9, 10)); + YGd(this.g, RD(b, 16)); + return; + case 10: + !this.e && (this.e = new Yie(F4, this, 10, 9)); + sLd(this.e); + !this.e && (this.e = new Yie(F4, this, 10, 9)); + YGd(this.e, RD(b, 16)); + return; + case 11: + Jzd(this, WD(b)); + return; + } + Dxd(this, a, b); + }; + _2.ii = function Yzd() { + return pvd(), hvd; + }; + _2.ki = function Zzd(a) { + switch (a) { + case 1: + Ozd(this, 0); + return; + case 2: + Pzd(this, 0); + return; + case 3: + Hzd(this, 0); + return; + case 4: + Izd(this, 0); + return; + case 5: + !this.a && (this.a = new XZd(D4, this, 5)); + sLd(this.a); + return; + case 6: + Mzd(this, null); + return; + case 7: + Lzd(this, null); + return; + case 8: + Kzd(this, null); + return; + case 9: + !this.g && (this.g = new Yie(F4, this, 9, 10)); + sLd(this.g); + return; + case 10: + !this.e && (this.e = new Yie(F4, this, 10, 9)); + sLd(this.e); + return; + case 11: + Jzd(this, null); + return; + } + Exd(this, a); + }; + _2.Ib = function $zd() { + return Qzd(this); + }; + _2.b = 0; + _2.c = 0; + _2.d = null; + _2.j = 0; + _2.k = 0; + sfb(THe, "ElkEdgeSectionImpl", 452); + feb(158, 120, { 110: 1, 94: 1, 93: 1, 155: 1, 58: 1, 114: 1, 54: 1, 99: 1, 158: 1, 119: 1, 120: 1 }); + _2.Lh = function cAd(a, b, c2) { + var d; + if (a == 0) { + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), this.Ab; + } + return zvd(this, a - AYd(this.ii()), vYd((d = RD(Ywd(this, 16), 29), !d ? this.ii() : d), a), b, c2); + }; + _2.Sh = function dAd(a, b, c2) { + var d, e; + if (b == 0) { + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), qLd(this.Ab, a, c2); + } + return e = RD(vYd((d = RD(Ywd(this, 16), 29), !d ? this.ii() : d), b), 69), e.wk().zk(this, Wwd(this), b - AYd(this.ii()), a, c2); + }; + _2.Uh = function eAd(a, b, c2) { + var d, e; + if (b == 0) { + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), rLd(this.Ab, a, c2); + } + return e = RD(vYd((d = RD(Ywd(this, 16), 29), !d ? this.ii() : d), b), 69), e.wk().Ak(this, Wwd(this), b - AYd(this.ii()), a, c2); + }; + _2.Wh = function fAd(a) { + var b; + if (a == 0) { + return !!this.Ab && this.Ab.i != 0; + } + return Avd(this, a - AYd(this.ii()), vYd((b = RD(Ywd(this, 16), 29), !b ? this.ii() : b), a)); + }; + _2.Zh = function gAd(a) { + return _zd(this, a); + }; + _2.bi = function hAd(a, b) { + var c2; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + YGd(this.Ab, RD(b, 16)); + return; + } + Bvd(this, a - AYd(this.ii()), vYd((c2 = RD(Ywd(this, 16), 29), !c2 ? this.ii() : c2), a), b); + }; + _2.di = function iAd(a) { + $wd(this, 128, a); + }; + _2.ii = function jAd() { + return JTd(), xTd; + }; + _2.ki = function kAd(a) { + var b; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + return; + } + Cvd(this, a - AYd(this.ii()), vYd((b = RD(Ywd(this, 16), 29), !b ? this.ii() : b), a)); + }; + _2.pi = function lAd() { + this.Bb |= 1; + }; + _2.qi = function mAd(a) { + return bAd(this, a); + }; + _2.Bb = 0; + sfb(SHe, "EModelElementImpl", 158); + feb(720, 158, { 110: 1, 94: 1, 93: 1, 480: 1, 155: 1, 58: 1, 114: 1, 54: 1, 99: 1, 158: 1, 119: 1, 120: 1 }, yAd); + _2.ri = function zAd(a, b) { + return tAd(this, a, b); + }; + _2.si = function AAd(a) { + var b, c2, d, e, f2; + if (this.a != BXd(a) || (a.Bb & 256) != 0) { + throw Adb(new agb(ZHe + a.zb + WHe)); + } + for (d = zYd(a); tYd(d.a).i != 0; ) { + c2 = RD(N_d(d, 0, (b = RD(QHd(tYd(d.a), 0), 89), f2 = b.c, ZD(f2, 90) ? RD(f2, 29) : (JTd(), zTd))), 29); + if (DXd(c2)) { + e = BXd(c2).wi().si(c2); + RD(e, 54).ci(a); + return e; + } + d = zYd(c2); + } + return (a.D != null ? a.D : a.B) == "java.util.Map$Entry" ? new LUd(a) : new zUd(a); + }; + _2.ti = function BAd(a, b) { + return uAd(this, a, b); + }; + _2.Lh = function CAd(a, b, c2) { + var d; + switch (a) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), this.Ab; + case 1: + return this.a; + } + return zvd(this, a - AYd((JTd(), uTd)), vYd((d = RD(Ywd(this, 16), 29), !d ? uTd : d), a), b, c2); + }; + _2.Sh = function DAd(a, b, c2) { + var d, e; + switch (b) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), qLd(this.Ab, a, c2); + case 1: + !!this.a && (c2 = RD(this.a, 54).Th(this, 4, t7, c2)); + return rAd(this, RD(a, 241), c2); + } + return e = RD(vYd((d = RD(Ywd(this, 16), 29), !d ? (JTd(), uTd) : d), b), 69), e.wk().zk(this, Wwd(this), b - AYd((JTd(), uTd)), a, c2); + }; + _2.Uh = function EAd(a, b, c2) { + var d, e; + switch (b) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), rLd(this.Ab, a, c2); + case 1: + return rAd(this, null, c2); + } + return e = RD(vYd((d = RD(Ywd(this, 16), 29), !d ? (JTd(), uTd) : d), b), 69), e.wk().Ak(this, Wwd(this), b - AYd((JTd(), uTd)), a, c2); + }; + _2.Wh = function FAd(a) { + var b; + switch (a) { + case 0: + return !!this.Ab && this.Ab.i != 0; + case 1: + return !!this.a; + } + return Avd(this, a - AYd((JTd(), uTd)), vYd((b = RD(Ywd(this, 16), 29), !b ? uTd : b), a)); + }; + _2.bi = function GAd(a, b) { + var c2; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + YGd(this.Ab, RD(b, 16)); + return; + case 1: + wAd(this, RD(b, 241)); + return; + } + Bvd(this, a - AYd((JTd(), uTd)), vYd((c2 = RD(Ywd(this, 16), 29), !c2 ? uTd : c2), a), b); + }; + _2.ii = function HAd() { + return JTd(), uTd; + }; + _2.ki = function IAd(a) { + var b; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + return; + case 1: + wAd(this, null); + return; + } + Cvd(this, a - AYd((JTd(), uTd)), vYd((b = RD(Ywd(this, 16), 29), !b ? uTd : b), a)); + }; + var nAd, oAd, pAd; + sfb(SHe, "EFactoryImpl", 720); + feb(1037, 720, { 110: 1, 2113: 1, 94: 1, 93: 1, 480: 1, 155: 1, 58: 1, 114: 1, 54: 1, 99: 1, 158: 1, 119: 1, 120: 1 }, KAd); + _2.ri = function LAd(a, b) { + switch (a.hk()) { + case 12: + return RD(b, 149).Pg(); + case 13: + return jeb(b); + default: + throw Adb(new agb(VHe + a.xe() + WHe)); + } + }; + _2.si = function MAd(a) { + var b, c2, d, e, f2, g, h, i2; + switch (a.G == -1 && (a.G = (b = BXd(a), b ? fZd(b.vi(), a) : -1)), a.G) { + case 4: + return f2 = new hCd(), f2; + case 6: + return g = new ACd(), g; + case 7: + return h = new PCd(), h; + case 8: + return d = new rzd(), d; + case 9: + return c2 = new Xxd(), c2; + case 10: + return e = new Rzd(), e; + case 11: + return i2 = new _Cd(), i2; + default: + throw Adb(new agb(ZHe + a.zb + WHe)); + } + }; + _2.ti = function NAd(a, b) { + switch (a.hk()) { + case 13: + case 12: + return null; + default: + throw Adb(new agb(VHe + a.xe() + WHe)); + } + }; + sfb(THe, "ElkGraphFactoryImpl", 1037); + feb(448, 158, { 110: 1, 94: 1, 93: 1, 155: 1, 197: 1, 58: 1, 114: 1, 54: 1, 99: 1, 158: 1, 119: 1, 120: 1 }); + _2.Gh = function RAd() { + var a, b; + b = (a = RD(Ywd(this, 16), 29), P$d(rYd(!a ? this.ii() : a))); + return b == null ? (N2d(), N2d(), M2d) : new e3d(this, b); + }; + _2.Lh = function SAd(a, b, c2) { + var d; + switch (a) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), this.Ab; + case 1: + return this.xe(); + } + return zvd(this, a - AYd(this.ii()), vYd((d = RD(Ywd(this, 16), 29), !d ? this.ii() : d), a), b, c2); + }; + _2.Wh = function TAd(a) { + var b; + switch (a) { + case 0: + return !!this.Ab && this.Ab.i != 0; + case 1: + return this.zb != null; + } + return Avd(this, a - AYd(this.ii()), vYd((b = RD(Ywd(this, 16), 29), !b ? this.ii() : b), a)); + }; + _2.bi = function UAd(a, b) { + var c2; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + YGd(this.Ab, RD(b, 16)); + return; + case 1: + this.ui(WD(b)); + return; + } + Bvd(this, a - AYd(this.ii()), vYd((c2 = RD(Ywd(this, 16), 29), !c2 ? this.ii() : c2), a), b); + }; + _2.ii = function VAd() { + return JTd(), yTd; + }; + _2.ki = function WAd(a) { + var b; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + return; + case 1: + this.ui(null); + return; + } + Cvd(this, a - AYd(this.ii()), vYd((b = RD(Ywd(this, 16), 29), !b ? this.ii() : b), a)); + }; + _2.xe = function XAd() { + return this.zb; + }; + _2.ui = function YAd(a) { + PAd(this, a); + }; + _2.Ib = function ZAd() { + return QAd(this); + }; + _2.zb = null; + sfb(SHe, "ENamedElementImpl", 448); + feb(184, 448, { 110: 1, 94: 1, 93: 1, 155: 1, 197: 1, 58: 1, 241: 1, 114: 1, 54: 1, 99: 1, 158: 1, 184: 1, 119: 1, 120: 1, 690: 1 }, EBd); + _2.Ah = function GBd(a) { + return qBd(this, a); + }; + _2.Lh = function HBd(a, b, c2) { + var d; + switch (a) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), this.Ab; + case 1: + return this.zb; + case 2: + return this.yb; + case 3: + return this.xb; + case 4: + return this.sb; + case 5: + return !this.rb && (this.rb = new J5d(this, i7, this)), this.rb; + case 6: + return !this.vb && (this.vb = new G5d(t7, this, 6, 7)), this.vb; + case 7: + if (b) + return this.Db >> 16 == 7 ? RD(this.Cb, 241) : null; + return gBd(this); + } + return zvd(this, a - AYd((JTd(), CTd)), vYd((d = RD(Ywd(this, 16), 29), !d ? CTd : d), a), b, c2); + }; + _2.Sh = function IBd(a, b, c2) { + var d, e, f2; + switch (b) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), qLd(this.Ab, a, c2); + case 4: + !!this.sb && (c2 = RD(this.sb, 54).Th(this, 1, n7, c2)); + return hBd(this, RD(a, 480), c2); + case 5: + return !this.rb && (this.rb = new J5d(this, i7, this)), qLd(this.rb, a, c2); + case 6: + return !this.vb && (this.vb = new G5d(t7, this, 6, 7)), qLd(this.vb, a, c2); + case 7: + !!this.Cb && (c2 = (e = this.Db >> 16, e >= 0 ? qBd(this, c2) : this.Cb.Th(this, -1 - e, null, c2))); + return xvd(this, a, 7, c2); + } + return f2 = RD(vYd((d = RD(Ywd(this, 16), 29), !d ? (JTd(), CTd) : d), b), 69), f2.wk().zk(this, Wwd(this), b - AYd((JTd(), CTd)), a, c2); + }; + _2.Uh = function JBd(a, b, c2) { + var d, e; + switch (b) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), rLd(this.Ab, a, c2); + case 4: + return hBd(this, null, c2); + case 5: + return !this.rb && (this.rb = new J5d(this, i7, this)), rLd(this.rb, a, c2); + case 6: + return !this.vb && (this.vb = new G5d(t7, this, 6, 7)), rLd(this.vb, a, c2); + case 7: + return xvd(this, null, 7, c2); + } + return e = RD(vYd((d = RD(Ywd(this, 16), 29), !d ? (JTd(), CTd) : d), b), 69), e.wk().Ak(this, Wwd(this), b - AYd((JTd(), CTd)), a, c2); + }; + _2.Wh = function KBd(a) { + var b; + switch (a) { + case 0: + return !!this.Ab && this.Ab.i != 0; + case 1: + return this.zb != null; + case 2: + return this.yb != null; + case 3: + return this.xb != null; + case 4: + return !!this.sb; + case 5: + return !!this.rb && this.rb.i != 0; + case 6: + return !!this.vb && this.vb.i != 0; + case 7: + return !!gBd(this); + } + return Avd(this, a - AYd((JTd(), CTd)), vYd((b = RD(Ywd(this, 16), 29), !b ? CTd : b), a)); + }; + _2.Zh = function LBd(a) { + var b; + b = sBd(this, a); + return b ? b : _zd(this, a); + }; + _2.bi = function MBd(a, b) { + var c2; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + YGd(this.Ab, RD(b, 16)); + return; + case 1: + PAd(this, WD(b)); + return; + case 2: + DBd(this, WD(b)); + return; + case 3: + CBd(this, WD(b)); + return; + case 4: + BBd(this, RD(b, 480)); + return; + case 5: + !this.rb && (this.rb = new J5d(this, i7, this)); + sLd(this.rb); + !this.rb && (this.rb = new J5d(this, i7, this)); + YGd(this.rb, RD(b, 16)); + return; + case 6: + !this.vb && (this.vb = new G5d(t7, this, 6, 7)); + sLd(this.vb); + !this.vb && (this.vb = new G5d(t7, this, 6, 7)); + YGd(this.vb, RD(b, 16)); + return; + } + Bvd(this, a - AYd((JTd(), CTd)), vYd((c2 = RD(Ywd(this, 16), 29), !c2 ? CTd : c2), a), b); + }; + _2.ei = function NBd(a) { + var b, c2; + if (!!a && !!this.rb) { + for (c2 = new dMd(this.rb); c2.e != c2.i.gc(); ) { + b = bMd(c2); + ZD(b, 364) && (RD(b, 364).w = null); + } + } + $wd(this, 64, a); + }; + _2.ii = function OBd() { + return JTd(), CTd; + }; + _2.ki = function PBd(a) { + var b; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + return; + case 1: + PAd(this, null); + return; + case 2: + DBd(this, null); + return; + case 3: + CBd(this, null); + return; + case 4: + BBd(this, null); + return; + case 5: + !this.rb && (this.rb = new J5d(this, i7, this)); + sLd(this.rb); + return; + case 6: + !this.vb && (this.vb = new G5d(t7, this, 6, 7)); + sLd(this.vb); + return; + } + Cvd(this, a - AYd((JTd(), CTd)), vYd((b = RD(Ywd(this, 16), 29), !b ? CTd : b), a)); + }; + _2.pi = function QBd() { + rBd(this); + }; + _2.vi = function RBd() { + return !this.rb && (this.rb = new J5d(this, i7, this)), this.rb; + }; + _2.wi = function SBd() { + return this.sb; + }; + _2.xi = function TBd() { + return this.ub; + }; + _2.yi = function UBd() { + return this.xb; + }; + _2.zi = function VBd() { + return this.yb; + }; + _2.Ai = function WBd(a) { + this.ub = a; + }; + _2.Ib = function XBd() { + var a; + if ((this.Db & 64) != 0) + return QAd(this); + a = new Shb(QAd(this)); + a.a += " (nsURI: "; + Nhb(a, this.yb); + a.a += ", nsPrefix: "; + Nhb(a, this.xb); + a.a += ")"; + return a.a; + }; + _2.xb = null; + _2.yb = null; + sfb(SHe, "EPackageImpl", 184); + feb(569, 184, { 110: 1, 2115: 1, 569: 1, 94: 1, 93: 1, 155: 1, 197: 1, 58: 1, 241: 1, 114: 1, 54: 1, 99: 1, 158: 1, 184: 1, 119: 1, 120: 1, 690: 1 }, _Bd); + _2.q = false; + _2.r = false; + var YBd = false; + sfb(THe, "ElkGraphPackageImpl", 569); + feb(366, 740, { 110: 1, 342: 1, 167: 1, 135: 1, 422: 1, 366: 1, 96: 1, 94: 1, 93: 1, 58: 1, 114: 1, 54: 1, 99: 1, 119: 1, 120: 1 }, hCd); + _2.Ah = function iCd(a) { + return cCd(this, a); + }; + _2.Lh = function jCd(a, b, c2) { + switch (a) { + case 7: + return dCd(this); + case 8: + return this.a; + } + return vyd(this, a, b, c2); + }; + _2.Sh = function kCd(a, b, c2) { + var d; + switch (b) { + case 7: + !!this.Cb && (c2 = (d = this.Db >> 16, d >= 0 ? cCd(this, c2) : this.Cb.Th(this, -1 - d, null, c2))); + return bCd(this, RD(a, 167), c2); + } + return dyd(this, a, b, c2); + }; + _2.Uh = function lCd(a, b, c2) { + if (b == 7) { + return bCd(this, null, c2); + } + return eyd(this, a, b, c2); + }; + _2.Wh = function mCd(a) { + switch (a) { + case 7: + return !!dCd(this); + case 8: + return !lhb("", this.a); + } + return wyd(this, a); + }; + _2.bi = function nCd(a, b) { + switch (a) { + case 7: + eCd(this, RD(b, 167)); + return; + case 8: + fCd(this, WD(b)); + return; + } + xyd(this, a, b); + }; + _2.ii = function oCd() { + return pvd(), jvd; + }; + _2.ki = function pCd(a) { + switch (a) { + case 7: + eCd(this, null); + return; + case 8: + fCd(this, ""); + return; + } + yyd(this, a); + }; + _2.Ib = function qCd() { + return gCd(this); + }; + _2.a = ""; + sfb(THe, "ElkLabelImpl", 366); + feb(207, 741, { 110: 1, 342: 1, 84: 1, 167: 1, 27: 1, 422: 1, 207: 1, 96: 1, 94: 1, 93: 1, 58: 1, 114: 1, 54: 1, 99: 1, 119: 1, 120: 1 }, ACd); + _2.Ah = function BCd(a) { + return sCd(this, a); + }; + _2.Lh = function CCd(a, b, c2) { + switch (a) { + case 9: + return !this.c && (this.c = new C5d(K4, this, 9, 9)), this.c; + case 10: + return !this.a && (this.a = new C5d(J4, this, 10, 11)), this.a; + case 11: + return vCd(this); + case 12: + return !this.b && (this.b = new C5d(G4, this, 12, 3)), this.b; + case 13: + return Geb(), !this.a && (this.a = new C5d(J4, this, 10, 11)), this.a.i > 0 ? true : false; + } + return Uyd(this, a, b, c2); + }; + _2.Sh = function DCd(a, b, c2) { + var d; + switch (b) { + case 9: + return !this.c && (this.c = new C5d(K4, this, 9, 9)), qLd(this.c, a, c2); + case 10: + return !this.a && (this.a = new C5d(J4, this, 10, 11)), qLd(this.a, a, c2); + case 11: + !!this.Cb && (c2 = (d = this.Db >> 16, d >= 0 ? sCd(this, c2) : this.Cb.Th(this, -1 - d, null, c2))); + return rCd(this, RD(a, 27), c2); + case 12: + return !this.b && (this.b = new C5d(G4, this, 12, 3)), qLd(this.b, a, c2); + } + return Vyd(this, a, b, c2); + }; + _2.Uh = function ECd(a, b, c2) { + switch (b) { + case 9: + return !this.c && (this.c = new C5d(K4, this, 9, 9)), rLd(this.c, a, c2); + case 10: + return !this.a && (this.a = new C5d(J4, this, 10, 11)), rLd(this.a, a, c2); + case 11: + return rCd(this, null, c2); + case 12: + return !this.b && (this.b = new C5d(G4, this, 12, 3)), rLd(this.b, a, c2); + } + return Wyd(this, a, b, c2); + }; + _2.Wh = function FCd(a) { + switch (a) { + case 9: + return !!this.c && this.c.i != 0; + case 10: + return !!this.a && this.a.i != 0; + case 11: + return !!vCd(this); + case 12: + return !!this.b && this.b.i != 0; + case 13: + return !this.a && (this.a = new C5d(J4, this, 10, 11)), this.a.i > 0; + } + return Xyd(this, a); + }; + _2.bi = function GCd(a, b) { + switch (a) { + case 9: + !this.c && (this.c = new C5d(K4, this, 9, 9)); + sLd(this.c); + !this.c && (this.c = new C5d(K4, this, 9, 9)); + YGd(this.c, RD(b, 16)); + return; + case 10: + !this.a && (this.a = new C5d(J4, this, 10, 11)); + sLd(this.a); + !this.a && (this.a = new C5d(J4, this, 10, 11)); + YGd(this.a, RD(b, 16)); + return; + case 11: + yCd(this, RD(b, 27)); + return; + case 12: + !this.b && (this.b = new C5d(G4, this, 12, 3)); + sLd(this.b); + !this.b && (this.b = new C5d(G4, this, 12, 3)); + YGd(this.b, RD(b, 16)); + return; + } + Yyd(this, a, b); + }; + _2.ii = function HCd() { + return pvd(), kvd; + }; + _2.ki = function ICd(a) { + switch (a) { + case 9: + !this.c && (this.c = new C5d(K4, this, 9, 9)); + sLd(this.c); + return; + case 10: + !this.a && (this.a = new C5d(J4, this, 10, 11)); + sLd(this.a); + return; + case 11: + yCd(this, null); + return; + case 12: + !this.b && (this.b = new C5d(G4, this, 12, 3)); + sLd(this.b); + return; + } + Zyd(this, a); + }; + _2.Ib = function JCd() { + return zCd(this); + }; + sfb(THe, "ElkNodeImpl", 207); + feb(193, 741, { 110: 1, 342: 1, 84: 1, 167: 1, 123: 1, 422: 1, 193: 1, 96: 1, 94: 1, 93: 1, 58: 1, 114: 1, 54: 1, 99: 1, 119: 1, 120: 1 }, PCd); + _2.Ah = function QCd(a) { + return LCd(this, a); + }; + _2.Lh = function RCd(a, b, c2) { + if (a == 9) { + return MCd(this); + } + return Uyd(this, a, b, c2); + }; + _2.Sh = function SCd(a, b, c2) { + var d; + switch (b) { + case 9: + !!this.Cb && (c2 = (d = this.Db >> 16, d >= 0 ? LCd(this, c2) : this.Cb.Th(this, -1 - d, null, c2))); + return KCd(this, RD(a, 27), c2); + } + return Vyd(this, a, b, c2); + }; + _2.Uh = function TCd(a, b, c2) { + if (b == 9) { + return KCd(this, null, c2); + } + return Wyd(this, a, b, c2); + }; + _2.Wh = function UCd(a) { + if (a == 9) { + return !!MCd(this); + } + return Xyd(this, a); + }; + _2.bi = function VCd(a, b) { + switch (a) { + case 9: + NCd(this, RD(b, 27)); + return; + } + Yyd(this, a, b); + }; + _2.ii = function WCd() { + return pvd(), lvd; + }; + _2.ki = function XCd(a) { + switch (a) { + case 9: + NCd(this, null); + return; + } + Zyd(this, a); + }; + _2.Ib = function YCd() { + return OCd(this); + }; + sfb(THe, "ElkPortImpl", 193); + var O6 = ufb(sIe, "BasicEMap/Entry"); + feb(1122, 120, { 110: 1, 44: 1, 94: 1, 93: 1, 136: 1, 58: 1, 114: 1, 54: 1, 99: 1, 119: 1, 120: 1 }, _Cd); + _2.Fb = function fDd(a) { + return this === a; + }; + _2.ld = function hDd() { + return this.b; + }; + _2.Hb = function jDd() { + return kFb(this); + }; + _2.Di = function lDd(a) { + ZCd(this, RD(a, 149)); + }; + _2.Lh = function aDd(a, b, c2) { + switch (a) { + case 0: + return this.b; + case 1: + return this.c; + } + return Dvd(this, a, b, c2); + }; + _2.Wh = function bDd(a) { + switch (a) { + case 0: + return !!this.b; + case 1: + return this.c != null; + } + return Kvd(this, a); + }; + _2.bi = function cDd(a, b) { + switch (a) { + case 0: + ZCd(this, RD(b, 149)); + return; + case 1: + $Cd(this, b); + return; + } + Wvd(this, a, b); + }; + _2.ii = function dDd() { + return pvd(), mvd; + }; + _2.ki = function eDd(a) { + switch (a) { + case 0: + ZCd(this, null); + return; + case 1: + $Cd(this, null); + return; + } + $vd(this, a); + }; + _2.Bi = function gDd() { + var a; + if (this.a == -1) { + a = this.b; + this.a = !a ? 0 : tb(a); + } + return this.a; + }; + _2.md = function iDd() { + return this.c; + }; + _2.Ci = function kDd(a) { + this.a = a; + }; + _2.nd = function mDd(a) { + var b; + b = this.c; + $Cd(this, a); + return b; + }; + _2.Ib = function nDd() { + var a; + if ((this.Db & 64) != 0) + return awd(this); + a = new bib(); + Zhb(Zhb(Zhb(a, this.b ? this.b.Pg() : vve), SAe), Ghb(this.c)); + return a.a; + }; + _2.a = -1; + _2.c = null; + var X4 = sfb(THe, "ElkPropertyToValueMapEntryImpl", 1122); + feb(996, 1, {}, BDd); + sfb(vIe, "JsonAdapter", 996); + feb(216, 63, swe, CDd); + sfb(vIe, "JsonImportException", 216); + feb(868, 1, {}, IEd); + sfb(vIe, "JsonImporter", 868); + feb(903, 1, {}, JEd); + sfb(vIe, "JsonImporter/lambda$0$Type", 903); + feb(904, 1, {}, KEd); + sfb(vIe, "JsonImporter/lambda$1$Type", 904); + feb(912, 1, {}, LEd); + sfb(vIe, "JsonImporter/lambda$10$Type", 912); + feb(914, 1, {}, MEd); + sfb(vIe, "JsonImporter/lambda$11$Type", 914); + feb(915, 1, {}, NEd); + sfb(vIe, "JsonImporter/lambda$12$Type", 915); + feb(921, 1, {}, OEd); + sfb(vIe, "JsonImporter/lambda$13$Type", 921); + feb(920, 1, {}, PEd); + sfb(vIe, "JsonImporter/lambda$14$Type", 920); + feb(916, 1, {}, QEd); + sfb(vIe, "JsonImporter/lambda$15$Type", 916); + feb(917, 1, {}, REd); + sfb(vIe, "JsonImporter/lambda$16$Type", 917); + feb(918, 1, {}, SEd); + sfb(vIe, "JsonImporter/lambda$17$Type", 918); + feb(919, 1, {}, TEd); + sfb(vIe, "JsonImporter/lambda$18$Type", 919); + feb(924, 1, {}, UEd); + sfb(vIe, "JsonImporter/lambda$19$Type", 924); + feb(905, 1, {}, VEd); + sfb(vIe, "JsonImporter/lambda$2$Type", 905); + feb(922, 1, {}, WEd); + sfb(vIe, "JsonImporter/lambda$20$Type", 922); + feb(923, 1, {}, XEd); + sfb(vIe, "JsonImporter/lambda$21$Type", 923); + feb(927, 1, {}, YEd); + sfb(vIe, "JsonImporter/lambda$22$Type", 927); + feb(925, 1, {}, ZEd); + sfb(vIe, "JsonImporter/lambda$23$Type", 925); + feb(926, 1, {}, $Ed); + sfb(vIe, "JsonImporter/lambda$24$Type", 926); + feb(929, 1, {}, _Ed); + sfb(vIe, "JsonImporter/lambda$25$Type", 929); + feb(928, 1, {}, aFd); + sfb(vIe, "JsonImporter/lambda$26$Type", 928); + feb(930, 1, Qve, bFd); + _2.Cd = function cFd(a) { + _Dd(this.b, this.a, WD(a)); + }; + sfb(vIe, "JsonImporter/lambda$27$Type", 930); + feb(931, 1, Qve, dFd); + _2.Cd = function eFd(a) { + aEd(this.b, this.a, WD(a)); + }; + sfb(vIe, "JsonImporter/lambda$28$Type", 931); + feb(932, 1, {}, fFd); + sfb(vIe, "JsonImporter/lambda$29$Type", 932); + feb(908, 1, {}, gFd); + sfb(vIe, "JsonImporter/lambda$3$Type", 908); + feb(933, 1, {}, hFd); + sfb(vIe, "JsonImporter/lambda$30$Type", 933); + feb(934, 1, {}, iFd); + sfb(vIe, "JsonImporter/lambda$31$Type", 934); + feb(935, 1, {}, jFd); + sfb(vIe, "JsonImporter/lambda$32$Type", 935); + feb(936, 1, {}, kFd); + sfb(vIe, "JsonImporter/lambda$33$Type", 936); + feb(937, 1, {}, lFd); + sfb(vIe, "JsonImporter/lambda$34$Type", 937); + feb(870, 1, {}, nFd); + sfb(vIe, "JsonImporter/lambda$35$Type", 870); + feb(941, 1, {}, pFd); + sfb(vIe, "JsonImporter/lambda$36$Type", 941); + feb(938, 1, Qve, qFd); + _2.Cd = function rFd(a) { + jEd(this.a, RD(a, 377)); + }; + sfb(vIe, "JsonImporter/lambda$37$Type", 938); + feb(939, 1, Qve, sFd); + _2.Cd = function tFd(a) { + kEd(this.a, this.b, RD(a, 166)); + }; + sfb(vIe, "JsonImporter/lambda$38$Type", 939); + feb(940, 1, Qve, uFd); + _2.Cd = function vFd(a) { + lEd(this.a, this.b, RD(a, 166)); + }; + sfb(vIe, "JsonImporter/lambda$39$Type", 940); + feb(906, 1, {}, wFd); + sfb(vIe, "JsonImporter/lambda$4$Type", 906); + feb(942, 1, Qve, xFd); + _2.Cd = function yFd(a) { + mEd(this.a, RD(a, 8)); + }; + sfb(vIe, "JsonImporter/lambda$40$Type", 942); + feb(907, 1, {}, zFd); + sfb(vIe, "JsonImporter/lambda$5$Type", 907); + feb(911, 1, {}, AFd); + sfb(vIe, "JsonImporter/lambda$6$Type", 911); + feb(909, 1, {}, BFd); + sfb(vIe, "JsonImporter/lambda$7$Type", 909); + feb(910, 1, {}, CFd); + sfb(vIe, "JsonImporter/lambda$8$Type", 910); + feb(913, 1, {}, DFd); + sfb(vIe, "JsonImporter/lambda$9$Type", 913); + feb(961, 1, Qve, MFd); + _2.Cd = function NFd(a) { + oDd(this.a, new OC(WD(a))); + }; + sfb(vIe, "JsonMetaDataConverter/lambda$0$Type", 961); + feb(962, 1, Qve, OFd); + _2.Cd = function PFd(a) { + IFd(this.a, RD(a, 245)); + }; + sfb(vIe, "JsonMetaDataConverter/lambda$1$Type", 962); + feb(963, 1, Qve, QFd); + _2.Cd = function RFd(a) { + JFd(this.a, RD(a, 143)); + }; + sfb(vIe, "JsonMetaDataConverter/lambda$2$Type", 963); + feb(964, 1, Qve, SFd); + _2.Cd = function TFd(a) { + KFd(this.a, RD(a, 170)); + }; + sfb(vIe, "JsonMetaDataConverter/lambda$3$Type", 964); + feb(245, 22, { 3: 1, 34: 1, 22: 1, 245: 1 }, bGd); + var UFd, VFd, WFd, XFd, YFd, ZFd, $Fd, _Fd; + var T5 = tfb(jze, "GraphFeature", 245, WI, dGd, cGd); + var eGd; + feb(11, 1, { 34: 1, 149: 1 }, jGd, kGd, lGd, mGd); + _2.Fd = function nGd(a) { + return gGd(this, RD(a, 149)); + }; + _2.Fb = function oGd(a) { + return hGd(this, a); + }; + _2.Sg = function pGd() { + return iGd(this); + }; + _2.Pg = function qGd() { + return this.b; + }; + _2.Hb = function rGd() { + return ohb(this.b); + }; + _2.Ib = function sGd() { + return this.b; + }; + sfb(jze, "Property", 11); + feb(671, 1, fye, uGd); + _2.Ne = function vGd(a, b) { + return tGd(this, RD(a, 96), RD(b, 96)); + }; + _2.Fb = function wGd(a) { + return this === a; + }; + _2.Oe = function xGd() { + return new Frb(this); + }; + sfb(jze, "PropertyHolderComparator", 671); + feb(709, 1, Ave, QGd); + _2.Nb = function RGd(a) { + Ztb(this, a); + }; + _2.Pb = function TGd() { + return PGd(this); + }; + _2.Qb = function UGd() { + $tb(); + }; + _2.Ob = function SGd() { + return !!this.a; + }; + sfb(KIe, "ElkGraphUtil/AncestorIterator", 709); + var Y6 = ufb(sIe, "EList"); + feb(70, 56, { 20: 1, 31: 1, 56: 1, 16: 1, 15: 1, 70: 1, 61: 1 }); + _2.bd = function hHd(a, b) { + VGd(this, a, b); + }; + _2.Fc = function iHd(a) { + return WGd(this, a); + }; + _2.cd = function jHd(a, b) { + return XGd(this, a, b); + }; + _2.Gc = function kHd(a) { + return YGd(this, a); + }; + _2.Ii = function lHd() { + return new yMd(this); + }; + _2.Ji = function mHd() { + return new BMd(this); + }; + _2.Ki = function nHd(a) { + return ZGd(this, a); + }; + _2.Li = function oHd() { + return true; + }; + _2.Mi = function pHd(a, b) { + }; + _2.Ni = function qHd() { + }; + _2.Oi = function rHd(a, b) { + $Gd(this, a, b); + }; + _2.Pi = function sHd(a, b, c2) { + }; + _2.Qi = function tHd(a, b) { + }; + _2.Ri = function uHd(a, b, c2) { + }; + _2.Fb = function vHd(a) { + return _Gd(this, a); + }; + _2.Hb = function wHd() { + return cHd(this); + }; + _2.Si = function xHd() { + return false; + }; + _2.Kc = function yHd() { + return new dMd(this); + }; + _2.ed = function zHd() { + return new mMd(this); + }; + _2.fd = function AHd(a) { + var b; + b = this.gc(); + if (a < 0 || a > b) + throw Adb(new aMd(a, b)); + return new nMd(this, a); + }; + _2.Ui = function BHd(a, b) { + this.Ti(a, this.dd(b)); + }; + _2.Mc = function CHd(a) { + return dHd(this, a); + }; + _2.Wi = function DHd(a, b) { + return b; + }; + _2.hd = function EHd(a, b) { + return eHd(this, a, b); + }; + _2.Ib = function FHd() { + return fHd(this); + }; + _2.Yi = function GHd() { + return true; + }; + _2.Zi = function HHd(a, b) { + return gHd(this, b); + }; + sfb(sIe, "AbstractEList", 70); + feb(66, 70, PIe, YHd, ZHd, $Hd); + _2.Ei = function _Hd(a, b) { + return IHd(this, a, b); + }; + _2.Fi = function aId(a) { + return JHd(this, a); + }; + _2.Gi = function bId(a, b) { + KHd(this, a, b); + }; + _2.Hi = function cId(a) { + LHd(this, a); + }; + _2.$i = function dId(a) { + return NHd(this, a); + }; + _2.$b = function eId() { + OHd(this); + }; + _2.Hc = function fId(a) { + return PHd(this, a); + }; + _2.Xb = function gId(a) { + return QHd(this, a); + }; + _2._i = function hId(a) { + var b, c2, d; + ++this.j; + c2 = this.g == null ? 0 : this.g.length; + if (a > c2) { + d = this.g; + b = c2 + (c2 / 2 | 0) + 4; + b < a && (b = a); + this.g = this.aj(b); + d != null && hib(d, 0, this.g, 0, this.i); + } + }; + _2.dd = function iId(a) { + return RHd(this, a); + }; + _2.dc = function jId() { + return this.i == 0; + }; + _2.Ti = function kId(a, b) { + return SHd(this, a, b); + }; + _2.aj = function lId(a) { + return $C(jJ, rve, 1, a, 5, 1); + }; + _2.Vi = function mId(a) { + return this.g[a]; + }; + _2.gd = function nId(a) { + return THd(this, a); + }; + _2.Xi = function oId(a, b) { + return UHd(this, a, b); + }; + _2.gc = function pId() { + return this.i; + }; + _2.Pc = function qId() { + return WHd(this); + }; + _2.Qc = function rId(a) { + return XHd(this, a); + }; + _2.i = 0; + var D6 = sfb(sIe, "BasicEList", 66); + var a7 = ufb(sIe, "TreeIterator"); + feb(708, 66, QIe); + _2.Nb = function vId(a) { + Ztb(this, a); + }; + _2.Ob = function wId() { + return this.g == null && !this.c ? sId(this) : this.g == null || this.i != 0 && RD(this.g[this.i - 1], 51).Ob(); + }; + _2.Pb = function xId() { + return tId(this); + }; + _2.Qb = function yId() { + if (!this.e) { + throw Adb(new dgb("There is no valid object to remove.")); + } + this.e.Qb(); + }; + _2.c = false; + sfb(sIe, "AbstractTreeIterator", 708); + feb(700, 708, QIe, zId); + _2.bj = function AId(a) { + var b; + b = RD(a, 58).Gh().Kc(); + ZD(b, 287) && RD(b, 287).wl(new BId()); + return b; + }; + sfb(KIe, "ElkGraphUtil/PropertiesSkippingTreeIterator", 700); + feb(965, 1, {}, BId); + sfb(KIe, "ElkGraphUtil/PropertiesSkippingTreeIterator/1", 965); + var CId, DId; + var b6 = sfb(KIe, "ElkReflect", null); + feb(901, 1, CGe, JId); + _2.Rg = function KId(a) { + return EId(), Asb(RD(a, 181)); + }; + sfb(KIe, "ElkReflect/lambda$0$Type", 901); + var LId; + ufb(sIe, "ResourceLocator"); + feb(1065, 1, {}); + sfb(sIe, "DelegatingResourceLocator", 1065); + feb(1066, 1065, {}); + sfb("org.eclipse.emf.common", "EMFPlugin", 1066); + var d6 = ufb(DJe, "Adapter"); + var e6 = ufb(DJe, "Notification"); + feb(1174, 1, EJe); + _2.cj = function VId() { + return this.d; + }; + _2.dj = function WId(a) { + }; + _2.ej = function XId(a) { + this.d = a; + }; + _2.fj = function YId(a) { + this.d == a && (this.d = null); + }; + _2.d = null; + sfb(JHe, "AdapterImpl", 1174); + feb(2093, 70, FJe); + _2.Ei = function dJd(a, b) { + return ZId(this, a, b); + }; + _2.Fi = function eJd(a) { + var b, c2, d; + ++this.j; + if (a.dc()) { + return false; + } else { + b = this.Ej(); + for (d = a.Kc(); d.Ob(); ) { + c2 = d.Pb(); + this.rj(this.Zi(b, c2)); + ++b; + } + return true; + } + }; + _2.Gi = function fJd(a, b) { + $Id(this, a, b); + }; + _2.Hi = function gJd(a) { + _Id(this, a); + }; + _2.pj = function hJd() { + return this.sj(); + }; + _2.$b = function iJd() { + aJd(this, this.Ej(), this.Fj()); + }; + _2.Hc = function jJd(a) { + return this.uj(a); + }; + _2.Ic = function kJd(a) { + return this.vj(a); + }; + _2.qj = function lJd(a, b) { + this.Bj().Um(); + }; + _2.rj = function mJd(a) { + this.Bj().Um(); + }; + _2.sj = function nJd() { + return this.Bj(); + }; + _2.tj = function oJd() { + this.Bj().Um(); + }; + _2.uj = function pJd(a) { + return this.Bj().Um(); + }; + _2.vj = function qJd(a) { + return this.Bj().Um(); + }; + _2.wj = function rJd(a) { + return this.Bj().Um(); + }; + _2.xj = function sJd(a) { + return this.Bj().Um(); + }; + _2.yj = function tJd() { + return this.Bj().Um(); + }; + _2.zj = function uJd(a) { + return this.Bj().Um(); + }; + _2.Aj = function vJd() { + return this.Bj().Um(); + }; + _2.Cj = function wJd(a) { + return this.Bj().Um(); + }; + _2.Dj = function xJd(a, b) { + return this.Bj().Um(); + }; + _2.Ej = function yJd() { + return this.Bj().Um(); + }; + _2.Fj = function zJd() { + return this.Bj().Um(); + }; + _2.Gj = function AJd(a) { + return this.Bj().Um(); + }; + _2.Hj = function BJd() { + return this.Bj().Um(); + }; + _2.Fb = function CJd(a) { + return this.wj(a); + }; + _2.Xb = function DJd(a) { + return this.Wi(a, this.xj(a)); + }; + _2.Hb = function EJd() { + return this.yj(); + }; + _2.dd = function FJd(a) { + return this.zj(a); + }; + _2.dc = function GJd() { + return this.Aj(); + }; + _2.Ti = function HJd(a, b) { + return bJd(this, a, b); + }; + _2.Vi = function IJd(a) { + return this.xj(a); + }; + _2.gd = function JJd(a) { + return cJd(this, a); + }; + _2.Mc = function KJd(a) { + var b; + b = this.dd(a); + if (b >= 0) { + this.gd(b); + return true; + } else { + return false; + } + }; + _2.Xi = function LJd(a, b) { + return this.Dj(a, this.Zi(a, b)); + }; + _2.gc = function MJd() { + return this.Ej(); + }; + _2.Pc = function NJd() { + return this.Fj(); + }; + _2.Qc = function OJd(a) { + return this.Gj(a); + }; + _2.Ib = function PJd() { + return this.Hj(); + }; + sfb(sIe, "DelegatingEList", 2093); + feb(2094, 2093, FJe); + _2.Ei = function XJd(a, b) { + return QJd(this, a, b); + }; + _2.Fi = function YJd(a) { + return this.Ei(this.Ej(), a); + }; + _2.Gi = function ZJd(a, b) { + RJd(this, a, b); + }; + _2.Hi = function $Jd(a) { + SJd(this, a); + }; + _2.Li = function _Jd() { + return !this.Mj(); + }; + _2.$b = function aKd() { + VJd(this); + }; + _2.Ij = function bKd(a, b, c2, d, e) { + return new aLd(this, a, b, c2, d, e); + }; + _2.Jj = function cKd(a) { + qvd(this.jj(), a); + }; + _2.Kj = function dKd() { + return null; + }; + _2.Lj = function eKd() { + return -1; + }; + _2.jj = function fKd() { + return null; + }; + _2.Mj = function gKd() { + return false; + }; + _2.Nj = function hKd(a, b) { + return b; + }; + _2.Oj = function iKd(a, b) { + return b; + }; + _2.Pj = function jKd() { + return false; + }; + _2.Qj = function kKd() { + return !this.Aj(); + }; + _2.Ti = function lKd(a, b) { + var c2, d; + if (this.Pj()) { + d = this.Qj(); + c2 = bJd(this, a, b); + this.Jj(this.Ij(7, sgb(b), c2, a, d)); + return c2; + } else { + return bJd(this, a, b); + } + }; + _2.gd = function mKd(a) { + var b, c2, d, e; + if (this.Pj()) { + c2 = null; + d = this.Qj(); + b = this.Ij(4, e = cJd(this, a), null, a, d); + if (this.Mj() && !!e) { + c2 = this.Oj(e, c2); + if (!c2) { + this.Jj(b); + } else { + c2.nj(b); + c2.oj(); + } + } else { + if (!c2) { + this.Jj(b); + } else { + c2.nj(b); + c2.oj(); + } + } + return e; + } else { + e = cJd(this, a); + if (this.Mj() && !!e) { + c2 = this.Oj(e, null); + !!c2 && c2.oj(); + } + return e; + } + }; + _2.Xi = function nKd(a, b) { + return WJd(this, a, b); + }; + sfb(JHe, "DelegatingNotifyingListImpl", 2094); + feb(152, 1, GJe); + _2.nj = function PKd(a) { + return oKd(this, a); + }; + _2.oj = function QKd() { + pKd(this); + }; + _2.gj = function RKd() { + return this.d; + }; + _2.Kj = function SKd() { + return null; + }; + _2.Rj = function TKd() { + return null; + }; + _2.hj = function UKd(a) { + return -1; + }; + _2.ij = function VKd() { + return yKd(this); + }; + _2.jj = function WKd() { + return null; + }; + _2.kj = function XKd() { + return HKd(this); + }; + _2.lj = function YKd() { + return this.o < 0 ? this.o < -2 ? -2 - this.o - 1 : -1 : this.o; + }; + _2.Sj = function ZKd() { + return false; + }; + _2.mj = function $Kd(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l; + switch (this.d) { + case 1: + case 2: { + e = a.gj(); + switch (e) { + case 1: + case 2: { + f2 = a.jj(); + if (dE(f2) === dE(this.jj()) && this.hj(null) == a.hj(null)) { + this.g = a.ij(); + a.gj() == 1 && (this.d = 1); + return true; + } + } + } + } + case 4: { + e = a.gj(); + switch (e) { + case 4: { + f2 = a.jj(); + if (dE(f2) === dE(this.jj()) && this.hj(null) == a.hj(null)) { + j = JKd(this); + i2 = this.o < 0 ? this.o < -2 ? -2 - this.o - 1 : -1 : this.o; + g = a.lj(); + this.d = 6; + l = new ZHd(2); + if (i2 <= g) { + WGd(l, this.n); + WGd(l, a.kj()); + this.g = cD(WC(kE, 1), Pwe, 28, 15, [this.o = i2, g + 1]); + } else { + WGd(l, a.kj()); + WGd(l, this.n); + this.g = cD(WC(kE, 1), Pwe, 28, 15, [this.o = g, i2]); + } + this.n = l; + j || (this.o = -2 - this.o - 1); + return true; + } + break; + } + } + break; + } + case 6: { + e = a.gj(); + switch (e) { + case 4: { + f2 = a.jj(); + if (dE(f2) === dE(this.jj()) && this.hj(null) == a.hj(null)) { + j = JKd(this); + g = a.lj(); + k = RD(this.g, 53); + d = $C(kE, Pwe, 28, k.length + 1, 15, 1); + b = 0; + while (b < k.length) { + h = k[b]; + if (h <= g) { + d[b++] = h; + ++g; + } else { + break; + } + } + c2 = RD(this.n, 15); + c2.bd(b, a.kj()); + d[b] = g; + while (++b < d.length) { + d[b] = k[b - 1]; + } + this.g = d; + j || (this.o = -2 - d[0]); + return true; + } + break; + } + } + break; + } + } + return false; + }; + _2.Ib = function _Kd() { + var a, b, c2, d; + d = new Shb(nfb(this.Rm) + "@" + (b = tb(this) >>> 0, b.toString(16))); + d.a += " (eventType: "; + switch (this.d) { + case 1: { + d.a += "SET"; + break; + } + case 2: { + d.a += "UNSET"; + break; + } + case 3: { + d.a += "ADD"; + break; + } + case 5: { + d.a += "ADD_MANY"; + break; + } + case 4: { + d.a += "REMOVE"; + break; + } + case 6: { + d.a += "REMOVE_MANY"; + break; + } + case 7: { + d.a += "MOVE"; + break; + } + case 8: { + d.a += "REMOVING_ADAPTER"; + break; + } + case 9: { + d.a += "RESOLVE"; + break; + } + default: { + Lhb(d, this.d); + break; + } + } + IKd(this) && (d.a += ", touch: true", d); + d.a += ", position: "; + Lhb(d, this.o < 0 ? this.o < -2 ? -2 - this.o - 1 : -1 : this.o); + d.a += ", notifier: "; + Mhb(d, this.jj()); + d.a += ", feature: "; + Mhb(d, this.Kj()); + d.a += ", oldValue: "; + Mhb(d, HKd(this)); + d.a += ", newValue: "; + if (this.d == 6 && ZD(this.g, 53)) { + c2 = RD(this.g, 53); + d.a += "["; + for (a = 0; a < c2.length; ) { + d.a += c2[a]; + ++a < c2.length && (d.a += pve, d); + } + d.a += "]"; + } else { + Mhb(d, yKd(this)); + } + d.a += ", isTouch: "; + Ohb(d, IKd(this)); + d.a += ", wasSet: "; + Ohb(d, JKd(this)); + d.a += ")"; + return d.a; + }; + _2.d = 0; + _2.e = 0; + _2.f = 0; + _2.j = 0; + _2.k = 0; + _2.o = 0; + _2.p = 0; + sfb(JHe, "NotificationImpl", 152); + feb(1188, 152, GJe, aLd); + _2.Kj = function bLd() { + return this.a.Kj(); + }; + _2.hj = function cLd(a) { + return this.a.Lj(); + }; + _2.jj = function dLd() { + return this.a.jj(); + }; + sfb(JHe, "DelegatingNotifyingListImpl/1", 1188); + feb(251, 66, PIe, fLd, gLd); + _2.Fc = function hLd(a) { + return eLd(this, RD(a, 378)); + }; + _2.nj = function iLd(a) { + return eLd(this, a); + }; + _2.oj = function jLd() { + var a, b, c2; + for (a = 0; a < this.i; ++a) { + b = RD(this.g[a], 378); + c2 = b.jj(); + c2 != null && b.gj() != -1 && RD(c2, 94).xh(b); + } + }; + _2.aj = function kLd(a) { + return $C(e6, rve, 378, a, 0, 1); + }; + sfb(JHe, "NotificationChainImpl", 251); + feb(1524, 93, IHe); + _2.uh = function lLd() { + return this.e; + }; + _2.wh = function mLd() { + return (this.f & 1) != 0; + }; + _2.f = 1; + sfb(JHe, "NotifierImpl", 1524); + feb(2091, 66, PIe); + _2.Ei = function yLd(a, b) { + return nLd(this, a, b); + }; + _2.Fi = function zLd(a) { + return this.Ei(this.i, a); + }; + _2.Gi = function ALd(a, b) { + oLd(this, a, b); + }; + _2.Hi = function BLd(a) { + pLd(this, a); + }; + _2.Li = function CLd() { + return !this.Mj(); + }; + _2.$b = function DLd() { + sLd(this); + }; + _2.Ij = function ELd(a, b, c2, d, e) { + return new VLd(this, a, b, c2, d, e); + }; + _2.Jj = function FLd(a) { + qvd(this.jj(), a); + }; + _2.Kj = function GLd() { + return null; + }; + _2.Lj = function HLd() { + return -1; + }; + _2.jj = function ILd() { + return null; + }; + _2.Mj = function JLd() { + return false; + }; + _2.Tj = function KLd() { + return false; + }; + _2.Nj = function LLd(a, b) { + return b; + }; + _2.Oj = function MLd(a, b) { + return b; + }; + _2.Pj = function NLd() { + return false; + }; + _2.Qj = function OLd() { + return this.i != 0; + }; + _2.Ti = function PLd(a, b) { + return uLd(this, a, b); + }; + _2.gd = function QLd(a) { + return vLd(this, a); + }; + _2.Xi = function RLd(a, b) { + return xLd(this, a, b); + }; + _2.Uj = function SLd(a, b) { + return b; + }; + _2.Vj = function TLd(a, b) { + return b; + }; + _2.Wj = function ULd(a, b, c2) { + return c2; + }; + sfb(JHe, "NotifyingListImpl", 2091); + feb(1187, 152, GJe, VLd); + _2.Kj = function WLd() { + return this.a.Kj(); + }; + _2.hj = function XLd(a) { + return this.a.Lj(); + }; + _2.jj = function YLd() { + return this.a.jj(); + }; + sfb(JHe, "NotifyingListImpl/1", 1187); + feb(966, 66, PIe, ZLd); + _2.Hc = function $Ld(a) { + if (this.i > 10) { + if (!this.b || this.c.j != this.a) { + this.b = new btb(this); + this.a = this.j; + } + return Zsb(this.b, a); + } else { + return PHd(this, a); + } + }; + _2.Yi = function _Ld() { + return true; + }; + _2.a = 0; + sfb(sIe, "AbstractEList/1", 966); + feb(302, 77, lxe, aMd); + sfb(sIe, "AbstractEList/BasicIndexOutOfBoundsException", 302); + feb(37, 1, Ave, dMd); + _2.Nb = function gMd(a) { + Ztb(this, a); + }; + _2.Xj = function eMd() { + if (this.i.j != this.f) { + throw Adb(new Jrb()); + } + }; + _2.Yj = function fMd() { + return bMd(this); + }; + _2.Ob = function hMd() { + return this.e != this.i.gc(); + }; + _2.Pb = function iMd() { + return this.Yj(); + }; + _2.Qb = function jMd() { + cMd(this); + }; + _2.e = 0; + _2.f = 0; + _2.g = -1; + sfb(sIe, "AbstractEList/EIterator", 37); + feb(286, 37, Jve, mMd, nMd); + _2.Qb = function vMd() { + cMd(this); + }; + _2.Rb = function oMd(a) { + kMd(this, a); + }; + _2.Zj = function pMd() { + var b; + try { + b = this.d.Xb(--this.e); + this.Xj(); + this.g = this.e; + return b; + } catch (a) { + a = zdb(a); + if (ZD(a, 77)) { + this.Xj(); + throw Adb(new Dvb()); + } else + throw Adb(a); + } + }; + _2.$j = function qMd(a) { + lMd(this, a); + }; + _2.Sb = function rMd() { + return this.e != 0; + }; + _2.Tb = function sMd() { + return this.e; + }; + _2.Ub = function tMd() { + return this.Zj(); + }; + _2.Vb = function uMd() { + return this.e - 1; + }; + _2.Wb = function wMd(a) { + this.$j(a); + }; + sfb(sIe, "AbstractEList/EListIterator", 286); + feb(355, 37, Ave, yMd); + _2.Yj = function zMd() { + return xMd(this); + }; + _2.Qb = function AMd() { + throw Adb(new jib()); + }; + sfb(sIe, "AbstractEList/NonResolvingEIterator", 355); + feb(398, 286, Jve, BMd, CMd); + _2.Rb = function DMd(a) { + throw Adb(new jib()); + }; + _2.Yj = function EMd() { + var b; + try { + b = this.c.Vi(this.e); + this.Xj(); + this.g = this.e++; + return b; + } catch (a) { + a = zdb(a); + if (ZD(a, 77)) { + this.Xj(); + throw Adb(new Dvb()); + } else + throw Adb(a); + } + }; + _2.Zj = function FMd() { + var b; + try { + b = this.c.Vi(--this.e); + this.Xj(); + this.g = this.e; + return b; + } catch (a) { + a = zdb(a); + if (ZD(a, 77)) { + this.Xj(); + throw Adb(new Dvb()); + } else + throw Adb(a); + } + }; + _2.Qb = function GMd() { + throw Adb(new jib()); + }; + _2.Wb = function HMd(a) { + throw Adb(new jib()); + }; + sfb(sIe, "AbstractEList/NonResolvingEListIterator", 398); + feb(2080, 70, JJe); + _2.Ei = function PMd(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m; + e = b.gc(); + if (e != 0) { + j = RD(Ywd(this.a, 4), 129); + k = j == null ? 0 : j.length; + m = k + e; + d = NMd(this, m); + l = k - a; + l > 0 && hib(j, a, d, a + e, l); + i2 = b.Kc(); + for (g = 0; g < e; ++g) { + h = i2.Pb(); + c2 = a + g; + LMd(d, c2, gHd(this, h)); + } + Bde(this, d); + for (f2 = 0; f2 < e; ++f2) { + h = d[a]; + this.Mi(a, h); + ++a; + } + return true; + } else { + ++this.j; + return false; + } + }; + _2.Fi = function QMd(a) { + var b, c2, d, e, f2, g, h, i2, j; + d = a.gc(); + if (d != 0) { + i2 = (c2 = RD(Ywd(this.a, 4), 129), c2 == null ? 0 : c2.length); + j = i2 + d; + b = NMd(this, j); + h = a.Kc(); + for (f2 = i2; f2 < j; ++f2) { + g = h.Pb(); + LMd(b, f2, gHd(this, g)); + } + Bde(this, b); + for (e = i2; e < j; ++e) { + g = b[e]; + this.Mi(e, g); + } + return true; + } else { + ++this.j; + return false; + } + }; + _2.Gi = function RMd(a, b) { + var c2, d, e, f2; + d = RD(Ywd(this.a, 4), 129); + e = d == null ? 0 : d.length; + c2 = NMd(this, e + 1); + f2 = gHd(this, b); + a != e && hib(d, a, c2, a + 1, e - a); + bD(c2, a, f2); + Bde(this, c2); + this.Mi(a, b); + }; + _2.Hi = function SMd(a) { + var b, c2, d; + d = (c2 = RD(Ywd(this.a, 4), 129), c2 == null ? 0 : c2.length); + b = NMd(this, d + 1); + LMd(b, d, gHd(this, a)); + Bde(this, b); + this.Mi(d, a); + }; + _2.Ii = function TMd() { + return new sNd(this); + }; + _2.Ji = function UMd() { + return new vNd(this); + }; + _2.Ki = function VMd(a) { + var b, c2; + c2 = (b = RD(Ywd(this.a, 4), 129), b == null ? 0 : b.length); + if (a < 0 || a > c2) + throw Adb(new aMd(a, c2)); + return new wNd(this, a); + }; + _2.$b = function WMd() { + var a, b; + ++this.j; + a = RD(Ywd(this.a, 4), 129); + b = a == null ? 0 : a.length; + Bde(this, null); + $Gd(this, b, a); + }; + _2.Hc = function XMd(a) { + var b, c2, d, e, f2; + b = RD(Ywd(this.a, 4), 129); + if (b != null) { + if (a != null) { + for (d = b, e = 0, f2 = d.length; e < f2; ++e) { + c2 = d[e]; + if (pb(a, c2)) { + return true; + } + } + } else { + for (d = b, e = 0, f2 = d.length; e < f2; ++e) { + c2 = d[e]; + if (dE(c2) === dE(a)) { + return true; + } + } + } + } + return false; + }; + _2.Xb = function YMd(a) { + var b, c2; + b = RD(Ywd(this.a, 4), 129); + c2 = b == null ? 0 : b.length; + if (a >= c2) + throw Adb(new aMd(a, c2)); + return b[a]; + }; + _2.dd = function ZMd(a) { + var b, c2, d; + b = RD(Ywd(this.a, 4), 129); + if (b != null) { + if (a != null) { + for (c2 = 0, d = b.length; c2 < d; ++c2) { + if (pb(a, b[c2])) { + return c2; + } + } + } else { + for (c2 = 0, d = b.length; c2 < d; ++c2) { + if (dE(b[c2]) === dE(a)) { + return c2; + } + } + } + } + return -1; + }; + _2.dc = function $Md() { + return RD(Ywd(this.a, 4), 129) == null; + }; + _2.Kc = function _Md() { + return new jNd(this); + }; + _2.ed = function aNd() { + return new nNd(this); + }; + _2.fd = function bNd(a) { + var b, c2; + c2 = (b = RD(Ywd(this.a, 4), 129), b == null ? 0 : b.length); + if (a < 0 || a > c2) + throw Adb(new aMd(a, c2)); + return new oNd(this, a); + }; + _2.Ti = function cNd(a, b) { + var c2, d, e; + c2 = MMd(this); + e = c2 == null ? 0 : c2.length; + if (a >= e) + throw Adb(new veb(MIe + a + NIe + e)); + if (b >= e) + throw Adb(new veb(OIe + b + NIe + e)); + d = c2[b]; + if (a != b) { + a < b ? hib(c2, a, c2, a + 1, b - a) : hib(c2, b + 1, c2, b, a - b); + bD(c2, a, d); + Bde(this, c2); + } + return d; + }; + _2.Vi = function dNd(a) { + return RD(Ywd(this.a, 4), 129)[a]; + }; + _2.gd = function eNd(a) { + return OMd(this, a); + }; + _2.Xi = function fNd(a, b) { + var c2, d; + c2 = MMd(this); + d = c2[a]; + LMd(c2, a, gHd(this, b)); + Bde(this, c2); + return d; + }; + _2.gc = function gNd() { + var a; + return a = RD(Ywd(this.a, 4), 129), a == null ? 0 : a.length; + }; + _2.Pc = function hNd() { + var a, b, c2; + a = RD(Ywd(this.a, 4), 129); + c2 = a == null ? 0 : a.length; + b = $C(d6, IJe, 424, c2, 0, 1); + c2 > 0 && hib(a, 0, b, 0, c2); + return b; + }; + _2.Qc = function iNd(a) { + var b, c2, d; + b = RD(Ywd(this.a, 4), 129); + d = b == null ? 0 : b.length; + if (d > 0) { + if (a.length < d) { + c2 = IMd(rb(a).c, d); + a = c2; + } + hib(b, 0, a, 0, d); + } + a.length > d && bD(a, d, null); + return a; + }; + var JMd; + sfb(sIe, "ArrayDelegatingEList", 2080); + feb(1051, 37, Ave, jNd); + _2.Xj = function kNd() { + if (this.b.j != this.f || dE(RD(Ywd(this.b.a, 4), 129)) !== dE(this.a)) { + throw Adb(new Jrb()); + } + }; + _2.Qb = function lNd() { + cMd(this); + this.a = RD(Ywd(this.b.a, 4), 129); + }; + sfb(sIe, "ArrayDelegatingEList/EIterator", 1051); + feb(722, 286, Jve, nNd, oNd); + _2.Xj = function pNd() { + if (this.b.j != this.f || dE(RD(Ywd(this.b.a, 4), 129)) !== dE(this.a)) { + throw Adb(new Jrb()); + } + }; + _2.$j = function qNd(a) { + lMd(this, a); + this.a = RD(Ywd(this.b.a, 4), 129); + }; + _2.Qb = function rNd() { + cMd(this); + this.a = RD(Ywd(this.b.a, 4), 129); + }; + sfb(sIe, "ArrayDelegatingEList/EListIterator", 722); + feb(1052, 355, Ave, sNd); + _2.Xj = function tNd() { + if (this.b.j != this.f || dE(RD(Ywd(this.b.a, 4), 129)) !== dE(this.a)) { + throw Adb(new Jrb()); + } + }; + sfb(sIe, "ArrayDelegatingEList/NonResolvingEIterator", 1052); + feb(723, 398, Jve, vNd, wNd); + _2.Xj = function xNd() { + if (this.b.j != this.f || dE(RD(Ywd(this.b.a, 4), 129)) !== dE(this.a)) { + throw Adb(new Jrb()); + } + }; + sfb(sIe, "ArrayDelegatingEList/NonResolvingEListIterator", 723); + feb(615, 302, lxe, yNd); + sfb(sIe, "BasicEList/BasicIndexOutOfBoundsException", 615); + feb(710, 66, PIe, zNd); + _2.bd = function ANd(a, b) { + throw Adb(new jib()); + }; + _2.Fc = function BNd(a) { + throw Adb(new jib()); + }; + _2.cd = function CNd(a, b) { + throw Adb(new jib()); + }; + _2.Gc = function DNd(a) { + throw Adb(new jib()); + }; + _2.$b = function ENd() { + throw Adb(new jib()); + }; + _2._i = function FNd(a) { + throw Adb(new jib()); + }; + _2.Kc = function GNd() { + return this.Ii(); + }; + _2.ed = function HNd() { + return this.Ji(); + }; + _2.fd = function INd(a) { + return this.Ki(a); + }; + _2.Ti = function JNd(a, b) { + throw Adb(new jib()); + }; + _2.Ui = function KNd(a, b) { + throw Adb(new jib()); + }; + _2.gd = function LNd(a) { + throw Adb(new jib()); + }; + _2.Mc = function MNd(a) { + throw Adb(new jib()); + }; + _2.hd = function NNd(a, b) { + throw Adb(new jib()); + }; + sfb(sIe, "BasicEList/UnmodifiableEList", 710); + feb(721, 1, { 3: 1, 20: 1, 16: 1, 15: 1, 61: 1, 597: 1 }); + _2.bd = function mOd(a, b) { + ONd(this, a, RD(b, 44)); + }; + _2.Fc = function nOd(a) { + return PNd(this, RD(a, 44)); + }; + _2.Jc = function vOd(a) { + xgb(this, a); + }; + _2.Xb = function wOd(a) { + return RD(QHd(this.c, a), 136); + }; + _2.Ti = function FOd(a, b) { + return RD(this.c.Ti(a, b), 44); + }; + _2.Ui = function GOd(a, b) { + eOd(this, a, RD(b, 44)); + }; + _2.Lc = function JOd() { + return new SDb(null, new Swb(this, 16)); + }; + _2.gd = function KOd(a) { + return RD(this.c.gd(a), 44); + }; + _2.hd = function MOd(a, b) { + return kOd(this, a, RD(b, 44)); + }; + _2.jd = function OOd(a) { + tvb(this, a); + }; + _2.Nc = function POd() { + return new Swb(this, 16); + }; + _2.Oc = function QOd() { + return new SDb(null, new Swb(this, 16)); + }; + _2.cd = function oOd(a, b) { + return this.c.cd(a, b); + }; + _2.Gc = function pOd(a) { + return this.c.Gc(a); + }; + _2.$b = function qOd() { + this.c.$b(); + }; + _2.Hc = function rOd(a) { + return this.c.Hc(a); + }; + _2.Ic = function sOd(a) { + return Be(this.c, a); + }; + _2._j = function tOd() { + var a, b, c2; + if (this.d == null) { + this.d = $C(D6, KJe, 66, 2 * this.f + 1, 0, 1); + c2 = this.e; + this.f = 0; + for (b = this.c.Kc(); b.e != b.i.gc(); ) { + a = RD(b.Yj(), 136); + UNd(this, a); + } + this.e = c2; + } + }; + _2.Fb = function uOd(a) { + return ZNd(this, a); + }; + _2.Hb = function xOd() { + return cHd(this.c); + }; + _2.dd = function yOd(a) { + return this.c.dd(a); + }; + _2.ak = function zOd() { + this.c = new YOd(this); + }; + _2.dc = function AOd() { + return this.f == 0; + }; + _2.Kc = function BOd() { + return this.c.Kc(); + }; + _2.ed = function COd() { + return this.c.ed(); + }; + _2.fd = function DOd(a) { + return this.c.fd(a); + }; + _2.bk = function EOd() { + return dOd(this); + }; + _2.ck = function HOd(a, b, c2) { + return new ZPd(a, b, c2); + }; + _2.dk = function IOd() { + return new cPd(); + }; + _2.Mc = function LOd(a) { + return hOd(this, a); + }; + _2.gc = function NOd() { + return this.f; + }; + _2.kd = function ROd(a, b) { + return new Rkb(this.c, a, b); + }; + _2.Pc = function SOd() { + return this.c.Pc(); + }; + _2.Qc = function TOd(a) { + return this.c.Qc(a); + }; + _2.Ib = function UOd() { + return fHd(this.c); + }; + _2.e = 0; + _2.f = 0; + sfb(sIe, "BasicEMap", 721); + feb(1046, 66, PIe, YOd); + _2.Mi = function ZOd(a, b) { + VOd(this, RD(b, 136)); + }; + _2.Pi = function _Od(a, b, c2) { + var d; + ++(d = this, RD(b, 136), d).a.e; + }; + _2.Qi = function aPd(a, b) { + WOd(this, RD(b, 136)); + }; + _2.Ri = function bPd(a, b, c2) { + XOd(this, RD(b, 136), RD(c2, 136)); + }; + _2.Oi = function $Od(a, b) { + TNd(this.a); + }; + sfb(sIe, "BasicEMap/1", 1046); + feb(1047, 66, PIe, cPd); + _2.aj = function dPd(a) { + return $C(N6, LJe, 621, a, 0, 1); + }; + sfb(sIe, "BasicEMap/2", 1047); + feb(1048, Eve, Fve, ePd); + _2.$b = function fPd() { + this.a.c.$b(); + }; + _2.Hc = function gPd(a) { + return QNd(this.a, a); + }; + _2.Kc = function hPd() { + return this.a.f == 0 ? (jQd(), iQd.a) : new DPd(this.a); + }; + _2.Mc = function iPd(a) { + var b; + b = this.a.f; + jOd(this.a, a); + return this.a.f != b; + }; + _2.gc = function jPd() { + return this.a.f; + }; + sfb(sIe, "BasicEMap/3", 1048); + feb(1049, 31, Dve, kPd); + _2.$b = function lPd() { + this.a.c.$b(); + }; + _2.Hc = function mPd(a) { + return RNd(this.a, a); + }; + _2.Kc = function nPd() { + return this.a.f == 0 ? (jQd(), iQd.a) : new FPd(this.a); + }; + _2.gc = function oPd() { + return this.a.f; + }; + sfb(sIe, "BasicEMap/4", 1049); + feb(1050, Eve, Fve, qPd); + _2.$b = function rPd() { + this.a.c.$b(); + }; + _2.Hc = function sPd(a) { + var b, c2, d, e, f2, g, h, i2, j; + if (this.a.f > 0 && ZD(a, 44)) { + this.a._j(); + i2 = RD(a, 44); + h = i2.ld(); + e = h == null ? 0 : tb(h); + f2 = bOd(this.a, e); + b = this.a.d[f2]; + if (b) { + c2 = RD(b.g, 379); + j = b.i; + for (g = 0; g < j; ++g) { + d = c2[g]; + if (d.Bi() == e && d.Fb(i2)) { + return true; + } + } + } + } + return false; + }; + _2.Kc = function tPd() { + return this.a.f == 0 ? (jQd(), iQd.a) : new xPd(this.a); + }; + _2.Mc = function uPd(a) { + return pPd(this, a); + }; + _2.gc = function vPd() { + return this.a.f; + }; + sfb(sIe, "BasicEMap/5", 1050); + feb(622, 1, Ave, xPd); + _2.Nb = function yPd(a) { + Ztb(this, a); + }; + _2.Ob = function zPd() { + return this.b != -1; + }; + _2.Pb = function APd() { + var a; + if (this.f.e != this.c) { + throw Adb(new Jrb()); + } + if (this.b == -1) { + throw Adb(new Dvb()); + } + this.d = this.a; + this.e = this.b; + wPd(this); + a = RD(this.f.d[this.d].g[this.e], 136); + return this.ek(a); + }; + _2.Qb = function BPd() { + if (this.f.e != this.c) { + throw Adb(new Jrb()); + } + if (this.e == -1) { + throw Adb(new cgb()); + } + this.f.c.Mc(QHd(this.f.d[this.d], this.e)); + this.c = this.f.e; + this.e = -1; + this.a == this.d && this.b != -1 && --this.b; + }; + _2.ek = function CPd(a) { + return a; + }; + _2.a = 0; + _2.b = -1; + _2.c = 0; + _2.d = 0; + _2.e = 0; + sfb(sIe, "BasicEMap/BasicEMapIterator", 622); + feb(1044, 622, Ave, DPd); + _2.ek = function EPd(a) { + return a.ld(); + }; + sfb(sIe, "BasicEMap/BasicEMapKeyIterator", 1044); + feb(1045, 622, Ave, FPd); + _2.ek = function GPd(a) { + return a.md(); + }; + sfb(sIe, "BasicEMap/BasicEMapValueIterator", 1045); + feb(1043, 1, Cve, IPd); + _2.wc = function OPd(a) { + Bvb(this, a); + }; + _2.yc = function TPd(a, b, c2) { + return Cvb(this, a, b, c2); + }; + _2.$b = function JPd() { + this.a.c.$b(); + }; + _2._b = function KPd(a) { + return HPd(this, a); + }; + _2.uc = function LPd(a) { + return RNd(this.a, a); + }; + _2.vc = function MPd() { + return YNd(this.a); + }; + _2.Fb = function NPd(a) { + return ZNd(this.a, a); + }; + _2.xc = function PPd(a) { + return $Nd(this.a, a); + }; + _2.Hb = function QPd() { + return cHd(this.a.c); + }; + _2.dc = function RPd() { + return this.a.f == 0; + }; + _2.ec = function SPd() { + return cOd(this.a); + }; + _2.zc = function UPd(a, b) { + return fOd(this.a, a, b); + }; + _2.Bc = function VPd(a) { + return jOd(this.a, a); + }; + _2.gc = function WPd() { + return this.a.f; + }; + _2.Ib = function XPd() { + return fHd(this.a.c); + }; + _2.Cc = function YPd() { + return lOd(this.a); + }; + sfb(sIe, "BasicEMap/DelegatingMap", 1043); + feb(621, 1, { 44: 1, 136: 1, 621: 1 }, ZPd); + _2.Fb = function $Pd(a) { + var b; + if (ZD(a, 44)) { + b = RD(a, 44); + return (this.b != null ? pb(this.b, b.ld()) : dE(this.b) === dE(b.ld())) && (this.c != null ? pb(this.c, b.md()) : dE(this.c) === dE(b.md())); + } else { + return false; + } + }; + _2.Bi = function _Pd() { + return this.a; + }; + _2.ld = function aQd() { + return this.b; + }; + _2.md = function bQd() { + return this.c; + }; + _2.Hb = function cQd() { + return this.a ^ (this.c == null ? 0 : tb(this.c)); + }; + _2.Ci = function dQd(a) { + this.a = a; + }; + _2.Di = function eQd(a) { + throw Adb(new xz()); + }; + _2.nd = function fQd(a) { + var b; + b = this.c; + this.c = a; + return b; + }; + _2.Ib = function gQd() { + return this.b + "->" + this.c; + }; + _2.a = 0; + var N6 = sfb(sIe, "BasicEMap/EntryImpl", 621); + feb(546, 1, {}, hQd); + sfb(sIe, "BasicEMap/View", 546); + var iQd; + feb(783, 1, {}); + _2.Fb = function xQd(a) { + return Rt((yob(), vob), a); + }; + _2.Hb = function yQd() { + return Cob((yob(), vob)); + }; + _2.Ib = function zQd() { + return Fe((yob(), vob)); + }; + sfb(sIe, "ECollections/BasicEmptyUnmodifiableEList", 783); + feb(1348, 1, Jve, AQd); + _2.Nb = function CQd(a) { + Ztb(this, a); + }; + _2.Rb = function BQd(a) { + throw Adb(new jib()); + }; + _2.Ob = function DQd() { + return false; + }; + _2.Sb = function EQd() { + return false; + }; + _2.Pb = function FQd() { + throw Adb(new Dvb()); + }; + _2.Tb = function GQd() { + return 0; + }; + _2.Ub = function HQd() { + throw Adb(new Dvb()); + }; + _2.Vb = function IQd() { + return -1; + }; + _2.Qb = function JQd() { + throw Adb(new jib()); + }; + _2.Wb = function KQd(a) { + throw Adb(new jib()); + }; + sfb(sIe, "ECollections/BasicEmptyUnmodifiableEList/1", 1348); + feb(1346, 783, { 20: 1, 16: 1, 15: 1, 61: 1 }, LQd); + _2.bd = function MQd(a, b) { + mQd(); + }; + _2.Fc = function NQd(a) { + return nQd(); + }; + _2.cd = function OQd(a, b) { + return oQd(); + }; + _2.Gc = function PQd(a) { + return pQd(); + }; + _2.$b = function QQd() { + qQd(); + }; + _2.Hc = function RQd(a) { + return false; + }; + _2.Ic = function SQd(a) { + return false; + }; + _2.Jc = function TQd(a) { + xgb(this, a); + }; + _2.Xb = function UQd(a) { + return Iob((yob(), a)), null; + }; + _2.dd = function VQd(a) { + return -1; + }; + _2.dc = function WQd() { + return true; + }; + _2.Kc = function XQd() { + return this.a; + }; + _2.ed = function YQd() { + return this.a; + }; + _2.fd = function ZQd(a) { + return this.a; + }; + _2.Ti = function $Qd(a, b) { + return rQd(); + }; + _2.Ui = function _Qd(a, b) { + sQd(); + }; + _2.Lc = function aRd() { + return new SDb(null, new Swb(this, 16)); + }; + _2.gd = function bRd(a) { + return tQd(); + }; + _2.Mc = function cRd(a) { + return uQd(); + }; + _2.hd = function dRd(a, b) { + return vQd(); + }; + _2.gc = function eRd() { + return 0; + }; + _2.jd = function fRd(a) { + tvb(this, a); + }; + _2.Nc = function gRd() { + return new Swb(this, 16); + }; + _2.Oc = function hRd() { + return new SDb(null, new Swb(this, 16)); + }; + _2.kd = function iRd(a, b) { + return yob(), new Rkb(vob, a, b); + }; + _2.Pc = function jRd() { + return De((yob(), vob)); + }; + _2.Qc = function kRd(a) { + return yob(), Ee(vob, a); + }; + sfb(sIe, "ECollections/EmptyUnmodifiableEList", 1346); + feb(1347, 783, { 20: 1, 16: 1, 15: 1, 61: 1, 597: 1 }, lRd); + _2.bd = function mRd(a, b) { + mQd(); + }; + _2.Fc = function nRd(a) { + return nQd(); + }; + _2.cd = function oRd(a, b) { + return oQd(); + }; + _2.Gc = function pRd(a) { + return pQd(); + }; + _2.$b = function qRd() { + qQd(); + }; + _2.Hc = function rRd(a) { + return false; + }; + _2.Ic = function sRd(a) { + return false; + }; + _2.Jc = function tRd(a) { + xgb(this, a); + }; + _2.Xb = function uRd(a) { + return Iob((yob(), a)), null; + }; + _2.dd = function vRd(a) { + return -1; + }; + _2.dc = function wRd() { + return true; + }; + _2.Kc = function xRd() { + return this.a; + }; + _2.ed = function yRd() { + return this.a; + }; + _2.fd = function zRd(a) { + return this.a; + }; + _2.Ti = function BRd(a, b) { + return rQd(); + }; + _2.Ui = function CRd(a, b) { + sQd(); + }; + _2.Lc = function DRd() { + return new SDb(null, new Swb(this, 16)); + }; + _2.gd = function ERd(a) { + return tQd(); + }; + _2.Mc = function FRd(a) { + return uQd(); + }; + _2.hd = function GRd(a, b) { + return vQd(); + }; + _2.gc = function HRd() { + return 0; + }; + _2.jd = function IRd(a) { + tvb(this, a); + }; + _2.Nc = function JRd() { + return new Swb(this, 16); + }; + _2.Oc = function KRd() { + return new SDb(null, new Swb(this, 16)); + }; + _2.kd = function LRd(a, b) { + return yob(), new Rkb(vob, a, b); + }; + _2.Pc = function MRd() { + return De((yob(), vob)); + }; + _2.Qc = function NRd(a) { + return yob(), Ee(vob, a); + }; + _2.bk = function ARd() { + return yob(), yob(), wob; + }; + sfb(sIe, "ECollections/EmptyUnmodifiableEMap", 1347); + var Z6 = ufb(sIe, "Enumerator"); + var ORd; + feb(288, 1, { 288: 1 }, lSd); + _2.Fb = function pSd(a) { + var b; + if (this === a) + return true; + if (!ZD(a, 288)) + return false; + b = RD(a, 288); + return this.f == b.f && rSd(this.i, b.i) && qSd(this.a, (this.f & 256) != 0 ? (b.f & 256) != 0 ? b.a : null : (b.f & 256) != 0 ? null : b.a) && qSd(this.d, b.d) && qSd(this.g, b.g) && qSd(this.e, b.e) && iSd(this, b); + }; + _2.Hb = function uSd() { + return this.f; + }; + _2.Ib = function CSd() { + return jSd(this); + }; + _2.f = 0; + var SRd = 0, TRd = 0, URd = 0, VRd = 0, WRd = 0, XRd = 0, YRd = 0, ZRd = 0, $Rd = 0, _Rd, aSd = 0, bSd = 0, cSd = 0, dSd = 0, eSd, fSd; + sfb(sIe, "URI", 288); + feb(1121, 45, Hxe, MSd); + _2.zc = function NSd(a, b) { + return RD($jb(this, WD(a), RD(b, 288)), 288); + }; + sfb(sIe, "URI/URICache", 1121); + feb(506, 66, PIe, OSd, PSd); + _2.Si = function QSd() { + return true; + }; + sfb(sIe, "UniqueEList", 506); + feb(590, 63, swe, RSd); + sfb(sIe, "WrappedException", 590); + var f7 = ufb(vHe, OJe); + var A7 = ufb(vHe, PJe); + var y7 = ufb(vHe, QJe); + var g7 = ufb(vHe, RJe); + var i7 = ufb(vHe, SJe); + var h7 = ufb(vHe, "EClass"); + var k7 = ufb(vHe, "EDataType"); + var SSd; + feb(1233, 45, Hxe, VSd); + _2.xc = function WSd(a) { + return bE(a) ? Xjb(this, a) : Wd(qtb(this.f, a)); + }; + sfb(vHe, "EDataType/Internal/ConversionDelegate/Factory/Registry/Impl", 1233); + var m7 = ufb(vHe, "EEnum"); + var l7 = ufb(vHe, TJe); + var o7 = ufb(vHe, UJe); + var s7 = ufb(vHe, VJe); + var XSd; + var u7 = ufb(vHe, WJe); + var v7 = ufb(vHe, XJe); + feb(1042, 1, {}, _Sd); + _2.Ib = function aTd() { + return "NIL"; + }; + sfb(vHe, "EStructuralFeature/Internal/DynamicValueHolder/1", 1042); + var bTd; + feb(1041, 45, Hxe, eTd); + _2.xc = function fTd(a) { + return bE(a) ? Xjb(this, a) : Wd(qtb(this.f, a)); + }; + sfb(vHe, "EStructuralFeature/Internal/SettingDelegate/Factory/Registry/Impl", 1041); + var z7 = ufb(vHe, YJe); + var B7 = ufb(vHe, "EValidator/PatternMatcher"); + var gTd; + var iTd; + var kTd; + var mTd, nTd, oTd, pTd, qTd, rTd, sTd, tTd, uTd, vTd, wTd, xTd, yTd, zTd, ATd, BTd, CTd, DTd, ETd, FTd, GTd, HTd, ITd; + var Jbb = ufb(ZJe, "FeatureMap/Entry"); + feb(545, 1, { 76: 1 }, KTd); + _2.Lk = function LTd() { + return this.a; + }; + _2.md = function MTd() { + return this.b; + }; + sfb(SHe, "BasicEObjectImpl/1", 545); + feb(1040, 1, $Je, NTd); + _2.Fk = function OTd(a) { + return Fvd(this.a, this.b, a); + }; + _2.Qj = function PTd() { + return Lvd(this.a, this.b); + }; + _2.Wb = function QTd(a) { + Xvd(this.a, this.b, a); + }; + _2.Gk = function RTd() { + _vd(this.a, this.b); + }; + sfb(SHe, "BasicEObjectImpl/4", 1040); + feb(2081, 1, { 114: 1 }); + _2.Mk = function UTd(a) { + this.e = a == 0 ? STd : $C(jJ, rve, 1, a, 5, 1); + }; + _2.li = function VTd(a) { + return this.e[a]; + }; + _2.mi = function WTd(a, b) { + this.e[a] = b; + }; + _2.ni = function XTd(a) { + this.e[a] = null; + }; + _2.Nk = function YTd() { + return this.c; + }; + _2.Ok = function ZTd() { + throw Adb(new jib()); + }; + _2.Pk = function $Td() { + throw Adb(new jib()); + }; + _2.Qk = function _Td() { + return this.d; + }; + _2.Rk = function aUd() { + return this.e != null; + }; + _2.Sk = function bUd(a) { + this.c = a; + }; + _2.Tk = function cUd(a) { + throw Adb(new jib()); + }; + _2.Uk = function dUd(a) { + throw Adb(new jib()); + }; + _2.Vk = function eUd(a) { + this.d = a; + }; + var STd; + sfb(SHe, "BasicEObjectImpl/EPropertiesHolderBaseImpl", 2081); + feb(192, 2081, { 114: 1 }, fUd); + _2.Ok = function gUd() { + return this.a; + }; + _2.Pk = function hUd() { + return this.b; + }; + _2.Tk = function iUd(a) { + this.a = a; + }; + _2.Uk = function jUd(a) { + this.b = a; + }; + sfb(SHe, "BasicEObjectImpl/EPropertiesHolderImpl", 192); + feb(516, 99, RHe, kUd); + _2.uh = function lUd() { + return this.f; + }; + _2.zh = function mUd() { + return this.k; + }; + _2.Bh = function nUd(a, b) { + this.g = a; + this.i = b; + }; + _2.Dh = function oUd() { + return (this.j & 2) == 0 ? this.ii() : this.$h().Nk(); + }; + _2.Fh = function pUd() { + return this.i; + }; + _2.wh = function qUd() { + return (this.j & 1) != 0; + }; + _2.Ph = function rUd() { + return this.g; + }; + _2.Vh = function sUd() { + return (this.j & 4) != 0; + }; + _2.$h = function tUd() { + return !this.k && (this.k = new fUd()), this.k; + }; + _2.ci = function uUd(a) { + this.$h().Sk(a); + a ? this.j |= 2 : this.j &= -3; + }; + _2.ei = function vUd(a) { + this.$h().Uk(a); + a ? this.j |= 4 : this.j &= -5; + }; + _2.ii = function wUd() { + return (lTd(), kTd).S; + }; + _2.i = 0; + _2.j = 1; + sfb(SHe, "EObjectImpl", 516); + feb(798, 516, { 110: 1, 94: 1, 93: 1, 58: 1, 114: 1, 54: 1, 99: 1 }, zUd); + _2.li = function AUd(a) { + return this.e[a]; + }; + _2.mi = function BUd(a, b) { + this.e[a] = b; + }; + _2.ni = function CUd(a) { + this.e[a] = null; + }; + _2.Dh = function DUd() { + return this.d; + }; + _2.Ih = function EUd(a) { + return BYd(this.d, a); + }; + _2.Kh = function FUd() { + return this.d; + }; + _2.Oh = function GUd() { + return this.e != null; + }; + _2.$h = function HUd() { + !this.k && (this.k = new VUd()); + return this.k; + }; + _2.ci = function IUd(a) { + this.d = a; + }; + _2.hi = function JUd() { + var a; + if (this.e == null) { + a = AYd(this.d); + this.e = a == 0 ? xUd : $C(jJ, rve, 1, a, 5, 1); + } + return this; + }; + _2.ji = function KUd() { + return 0; + }; + var xUd; + sfb(SHe, "DynamicEObjectImpl", 798); + feb(1522, 798, { 110: 1, 44: 1, 94: 1, 93: 1, 136: 1, 58: 1, 114: 1, 54: 1, 99: 1 }, LUd); + _2.Fb = function NUd(a) { + return this === a; + }; + _2.Hb = function RUd() { + return kFb(this); + }; + _2.ci = function MUd(a) { + this.d = a; + this.b = wYd(a, "key"); + this.c = wYd(a, aIe); + }; + _2.Bi = function OUd() { + var a; + if (this.a == -1) { + a = Gvd(this, this.b); + this.a = a == null ? 0 : tb(a); + } + return this.a; + }; + _2.ld = function PUd() { + return Gvd(this, this.b); + }; + _2.md = function QUd() { + return Gvd(this, this.c); + }; + _2.Ci = function SUd(a) { + this.a = a; + }; + _2.Di = function TUd(a) { + Xvd(this, this.b, a); + }; + _2.nd = function UUd(a) { + var b; + b = Gvd(this, this.c); + Xvd(this, this.c, a); + return b; + }; + _2.a = 0; + sfb(SHe, "DynamicEObjectImpl/BasicEMapEntry", 1522); + feb(1523, 1, { 114: 1 }, VUd); + _2.Mk = function WUd(a) { + throw Adb(new jib()); + }; + _2.li = function XUd(a) { + throw Adb(new jib()); + }; + _2.mi = function YUd(a, b) { + throw Adb(new jib()); + }; + _2.ni = function ZUd(a) { + throw Adb(new jib()); + }; + _2.Nk = function $Ud() { + throw Adb(new jib()); + }; + _2.Ok = function _Ud() { + return this.a; + }; + _2.Pk = function aVd() { + return this.b; + }; + _2.Qk = function bVd() { + return this.c; + }; + _2.Rk = function cVd() { + throw Adb(new jib()); + }; + _2.Sk = function dVd(a) { + throw Adb(new jib()); + }; + _2.Tk = function eVd(a) { + this.a = a; + }; + _2.Uk = function fVd(a) { + this.b = a; + }; + _2.Vk = function gVd(a) { + this.c = a; + }; + sfb(SHe, "DynamicEObjectImpl/DynamicEPropertiesHolderImpl", 1523); + feb(519, 158, { 110: 1, 94: 1, 93: 1, 598: 1, 155: 1, 58: 1, 114: 1, 54: 1, 99: 1, 519: 1, 158: 1, 119: 1, 120: 1 }, pVd); + _2.Ah = function qVd(a) { + return iVd(this, a); + }; + _2.Lh = function rVd(a, b, c2) { + var d; + switch (a) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), this.Ab; + case 1: + return this.d; + case 2: + return c2 ? (!this.b && (this.b = new SVd((JTd(), FTd), C8, this)), this.b) : (!this.b && (this.b = new SVd((JTd(), FTd), C8, this)), dOd(this.b)); + case 3: + return kVd(this); + case 4: + return !this.a && (this.a = new XZd(r7, this, 4)), this.a; + case 5: + return !this.c && (this.c = new zie(r7, this, 5)), this.c; + } + return zvd(this, a - AYd((JTd(), mTd)), vYd((d = RD(Ywd(this, 16), 29), !d ? mTd : d), a), b, c2); + }; + _2.Sh = function sVd(a, b, c2) { + var d, e, f2; + switch (b) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), qLd(this.Ab, a, c2); + case 3: + !!this.Cb && (c2 = (e = this.Db >> 16, e >= 0 ? iVd(this, c2) : this.Cb.Th(this, -1 - e, null, c2))); + return hVd(this, RD(a, 155), c2); + } + return f2 = RD(vYd((d = RD(Ywd(this, 16), 29), !d ? (JTd(), mTd) : d), b), 69), f2.wk().zk(this, Wwd(this), b - AYd((JTd(), mTd)), a, c2); + }; + _2.Uh = function tVd(a, b, c2) { + var d, e; + switch (b) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), rLd(this.Ab, a, c2); + case 2: + return !this.b && (this.b = new SVd((JTd(), FTd), C8, this)), BVd(this.b, a, c2); + case 3: + return hVd(this, null, c2); + case 4: + return !this.a && (this.a = new XZd(r7, this, 4)), rLd(this.a, a, c2); + } + return e = RD(vYd((d = RD(Ywd(this, 16), 29), !d ? (JTd(), mTd) : d), b), 69), e.wk().Ak(this, Wwd(this), b - AYd((JTd(), mTd)), a, c2); + }; + _2.Wh = function uVd(a) { + var b; + switch (a) { + case 0: + return !!this.Ab && this.Ab.i != 0; + case 1: + return this.d != null; + case 2: + return !!this.b && this.b.f != 0; + case 3: + return !!kVd(this); + case 4: + return !!this.a && this.a.i != 0; + case 5: + return !!this.c && this.c.i != 0; + } + return Avd(this, a - AYd((JTd(), mTd)), vYd((b = RD(Ywd(this, 16), 29), !b ? mTd : b), a)); + }; + _2.bi = function vVd(a, b) { + var c2; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + YGd(this.Ab, RD(b, 16)); + return; + case 1: + mVd(this, WD(b)); + return; + case 2: + !this.b && (this.b = new SVd((JTd(), FTd), C8, this)); + CVd(this.b, b); + return; + case 3: + lVd(this, RD(b, 155)); + return; + case 4: + !this.a && (this.a = new XZd(r7, this, 4)); + sLd(this.a); + !this.a && (this.a = new XZd(r7, this, 4)); + YGd(this.a, RD(b, 16)); + return; + case 5: + !this.c && (this.c = new zie(r7, this, 5)); + sLd(this.c); + !this.c && (this.c = new zie(r7, this, 5)); + YGd(this.c, RD(b, 16)); + return; + } + Bvd(this, a - AYd((JTd(), mTd)), vYd((c2 = RD(Ywd(this, 16), 29), !c2 ? mTd : c2), a), b); + }; + _2.ii = function wVd() { + return JTd(), mTd; + }; + _2.ki = function xVd(a) { + var b; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + return; + case 1: + nVd(this, null); + return; + case 2: + !this.b && (this.b = new SVd((JTd(), FTd), C8, this)); + this.b.c.$b(); + return; + case 3: + lVd(this, null); + return; + case 4: + !this.a && (this.a = new XZd(r7, this, 4)); + sLd(this.a); + return; + case 5: + !this.c && (this.c = new zie(r7, this, 5)); + sLd(this.c); + return; + } + Cvd(this, a - AYd((JTd(), mTd)), vYd((b = RD(Ywd(this, 16), 29), !b ? mTd : b), a)); + }; + _2.Ib = function yVd() { + return oVd(this); + }; + _2.d = null; + sfb(SHe, "EAnnotationImpl", 519); + feb(141, 721, _Je, DVd); + _2.Gi = function EVd(a, b) { + zVd(this, a, RD(b, 44)); + }; + _2.Wk = function FVd(a, b) { + return AVd(this, RD(a, 44), b); + }; + _2.$i = function GVd(a) { + return RD(RD(this.c, 71).$i(a), 136); + }; + _2.Ii = function HVd() { + return RD(this.c, 71).Ii(); + }; + _2.Ji = function IVd() { + return RD(this.c, 71).Ji(); + }; + _2.Ki = function JVd(a) { + return RD(this.c, 71).Ki(a); + }; + _2.Xk = function KVd(a, b) { + return BVd(this, a, b); + }; + _2.Fk = function LVd(a) { + return RD(this.c, 79).Fk(a); + }; + _2.ak = function MVd() { + }; + _2.Qj = function NVd() { + return RD(this.c, 79).Qj(); + }; + _2.ck = function OVd(a, b, c2) { + var d; + d = RD(BXd(this.b).wi().si(this.b), 136); + d.Ci(a); + d.Di(b); + d.nd(c2); + return d; + }; + _2.dk = function PVd() { + return new uje(this); + }; + _2.Wb = function QVd(a) { + CVd(this, a); + }; + _2.Gk = function RVd() { + RD(this.c, 79).Gk(); + }; + sfb(ZJe, "EcoreEMap", 141); + feb(165, 141, _Je, SVd); + _2._j = function TVd() { + var a, b, c2, d, e, f2; + if (this.d == null) { + f2 = $C(D6, KJe, 66, 2 * this.f + 1, 0, 1); + for (c2 = this.c.Kc(); c2.e != c2.i.gc(); ) { + b = RD(c2.Yj(), 136); + d = b.Bi(); + e = (d & lve) % f2.length; + a = f2[e]; + !a && (a = f2[e] = new uje(this)); + a.Fc(b); + } + this.d = f2; + } + }; + sfb(SHe, "EAnnotationImpl/1", 165); + feb(292, 448, { 110: 1, 94: 1, 93: 1, 155: 1, 197: 1, 58: 1, 114: 1, 481: 1, 54: 1, 99: 1, 158: 1, 292: 1, 119: 1, 120: 1 }); + _2.Lh = function eWd(a, b, c2) { + var d, e; + switch (a) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), this.Ab; + case 1: + return this.zb; + case 2: + return Geb(), (this.Bb & 256) != 0 ? true : false; + case 3: + return Geb(), (this.Bb & 512) != 0 ? true : false; + case 4: + return sgb(this.s); + case 5: + return sgb(this.t); + case 6: + return Geb(), this.Jk() ? true : false; + case 7: + return Geb(), e = this.s, e >= 1 ? true : false; + case 8: + if (b) + return WVd(this); + return this.r; + case 9: + return this.q; + } + return zvd(this, a - AYd(this.ii()), vYd((d = RD(Ywd(this, 16), 29), !d ? this.ii() : d), a), b, c2); + }; + _2.Uh = function fWd(a, b, c2) { + var d, e; + switch (b) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), rLd(this.Ab, a, c2); + case 9: + return VVd(this, c2); + } + return e = RD(vYd((d = RD(Ywd(this, 16), 29), !d ? this.ii() : d), b), 69), e.wk().Ak(this, Wwd(this), b - AYd(this.ii()), a, c2); + }; + _2.Wh = function gWd(a) { + var b, c2; + switch (a) { + case 0: + return !!this.Ab && this.Ab.i != 0; + case 1: + return this.zb != null; + case 2: + return (this.Bb & 256) == 0; + case 3: + return (this.Bb & 512) == 0; + case 4: + return this.s != 0; + case 5: + return this.t != 1; + case 6: + return this.Jk(); + case 7: + return c2 = this.s, c2 >= 1; + case 8: + return !!this.r && !this.q.e && j2d(this.q).i == 0; + case 9: + return !!this.q && !(!!this.r && !this.q.e && j2d(this.q).i == 0); + } + return Avd(this, a - AYd(this.ii()), vYd((b = RD(Ywd(this, 16), 29), !b ? this.ii() : b), a)); + }; + _2.bi = function hWd(a, b) { + var c2, d; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + YGd(this.Ab, RD(b, 16)); + return; + case 1: + this.ui(WD(b)); + return; + case 2: + _Vd(this, Heb(TD(b))); + return; + case 3: + aWd(this, Heb(TD(b))); + return; + case 4: + $Vd(this, RD(b, 17).a); + return; + case 5: + this.Zk(RD(b, 17).a); + return; + case 8: + YVd(this, RD(b, 142)); + return; + case 9: + d = XVd(this, RD(b, 89), null); + !!d && d.oj(); + return; + } + Bvd(this, a - AYd(this.ii()), vYd((c2 = RD(Ywd(this, 16), 29), !c2 ? this.ii() : c2), a), b); + }; + _2.ii = function iWd() { + return JTd(), HTd; + }; + _2.ki = function jWd(a) { + var b, c2; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + return; + case 1: + this.ui(null); + return; + case 2: + _Vd(this, true); + return; + case 3: + aWd(this, true); + return; + case 4: + $Vd(this, 0); + return; + case 5: + this.Zk(1); + return; + case 8: + YVd(this, null); + return; + case 9: + c2 = XVd(this, null, null); + !!c2 && c2.oj(); + return; + } + Cvd(this, a - AYd(this.ii()), vYd((b = RD(Ywd(this, 16), 29), !b ? this.ii() : b), a)); + }; + _2.pi = function kWd() { + WVd(this); + this.Bb |= 1; + }; + _2.Hk = function lWd() { + return WVd(this); + }; + _2.Ik = function mWd() { + return this.t; + }; + _2.Jk = function nWd() { + var a; + return a = this.t, a > 1 || a == -1; + }; + _2.Si = function oWd() { + return (this.Bb & 512) != 0; + }; + _2.Yk = function pWd(a, b) { + return ZVd(this, a, b); + }; + _2.Zk = function qWd(a) { + bWd(this, a); + }; + _2.Ib = function rWd() { + return cWd(this); + }; + _2.s = 0; + _2.t = 1; + sfb(SHe, "ETypedElementImpl", 292); + feb(462, 292, { 110: 1, 94: 1, 93: 1, 155: 1, 197: 1, 58: 1, 179: 1, 69: 1, 114: 1, 481: 1, 54: 1, 99: 1, 158: 1, 462: 1, 292: 1, 119: 1, 120: 1, 692: 1 }); + _2.Ah = function IWd(a) { + return sWd(this, a); + }; + _2.Lh = function JWd(a, b, c2) { + var d, e; + switch (a) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), this.Ab; + case 1: + return this.zb; + case 2: + return Geb(), (this.Bb & 256) != 0 ? true : false; + case 3: + return Geb(), (this.Bb & 512) != 0 ? true : false; + case 4: + return sgb(this.s); + case 5: + return sgb(this.t); + case 6: + return Geb(), this.Jk() ? true : false; + case 7: + return Geb(), e = this.s, e >= 1 ? true : false; + case 8: + if (b) + return WVd(this); + return this.r; + case 9: + return this.q; + case 10: + return Geb(), (this.Bb & gwe) != 0 ? true : false; + case 11: + return Geb(), (this.Bb & cKe) != 0 ? true : false; + case 12: + return Geb(), (this.Bb & qxe) != 0 ? true : false; + case 13: + return this.j; + case 14: + return tWd(this); + case 15: + return Geb(), (this.Bb & bKe) != 0 ? true : false; + case 16: + return Geb(), (this.Bb & Ove) != 0 ? true : false; + case 17: + return uWd(this); + } + return zvd(this, a - AYd(this.ii()), vYd((d = RD(Ywd(this, 16), 29), !d ? this.ii() : d), a), b, c2); + }; + _2.Sh = function KWd(a, b, c2) { + var d, e, f2; + switch (b) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), qLd(this.Ab, a, c2); + case 17: + !!this.Cb && (c2 = (e = this.Db >> 16, e >= 0 ? sWd(this, c2) : this.Cb.Th(this, -1 - e, null, c2))); + return xvd(this, a, 17, c2); + } + return f2 = RD(vYd((d = RD(Ywd(this, 16), 29), !d ? this.ii() : d), b), 69), f2.wk().zk(this, Wwd(this), b - AYd(this.ii()), a, c2); + }; + _2.Uh = function LWd(a, b, c2) { + var d, e; + switch (b) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), rLd(this.Ab, a, c2); + case 9: + return VVd(this, c2); + case 17: + return xvd(this, null, 17, c2); + } + return e = RD(vYd((d = RD(Ywd(this, 16), 29), !d ? this.ii() : d), b), 69), e.wk().Ak(this, Wwd(this), b - AYd(this.ii()), a, c2); + }; + _2.Wh = function MWd(a) { + var b, c2; + switch (a) { + case 0: + return !!this.Ab && this.Ab.i != 0; + case 1: + return this.zb != null; + case 2: + return (this.Bb & 256) == 0; + case 3: + return (this.Bb & 512) == 0; + case 4: + return this.s != 0; + case 5: + return this.t != 1; + case 6: + return this.Jk(); + case 7: + return c2 = this.s, c2 >= 1; + case 8: + return !!this.r && !this.q.e && j2d(this.q).i == 0; + case 9: + return !!this.q && !(!!this.r && !this.q.e && j2d(this.q).i == 0); + case 10: + return (this.Bb & gwe) == 0; + case 11: + return (this.Bb & cKe) != 0; + case 12: + return (this.Bb & qxe) != 0; + case 13: + return this.j != null; + case 14: + return tWd(this) != null; + case 15: + return (this.Bb & bKe) != 0; + case 16: + return (this.Bb & Ove) != 0; + case 17: + return !!uWd(this); + } + return Avd(this, a - AYd(this.ii()), vYd((b = RD(Ywd(this, 16), 29), !b ? this.ii() : b), a)); + }; + _2.bi = function NWd(a, b) { + var c2, d; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + YGd(this.Ab, RD(b, 16)); + return; + case 1: + CWd(this, WD(b)); + return; + case 2: + _Vd(this, Heb(TD(b))); + return; + case 3: + aWd(this, Heb(TD(b))); + return; + case 4: + $Vd(this, RD(b, 17).a); + return; + case 5: + this.Zk(RD(b, 17).a); + return; + case 8: + YVd(this, RD(b, 142)); + return; + case 9: + d = XVd(this, RD(b, 89), null); + !!d && d.oj(); + return; + case 10: + xWd(this, Heb(TD(b))); + return; + case 11: + FWd(this, Heb(TD(b))); + return; + case 12: + DWd(this, Heb(TD(b))); + return; + case 13: + yWd(this, WD(b)); + return; + case 15: + EWd(this, Heb(TD(b))); + return; + case 16: + AWd(this, Heb(TD(b))); + return; + } + Bvd(this, a - AYd(this.ii()), vYd((c2 = RD(Ywd(this, 16), 29), !c2 ? this.ii() : c2), a), b); + }; + _2.ii = function OWd() { + return JTd(), GTd; + }; + _2.ki = function PWd(a) { + var b, c2; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + return; + case 1: + ZD(this.Cb, 90) && v$d(yYd(RD(this.Cb, 90)), 4); + PAd(this, null); + return; + case 2: + _Vd(this, true); + return; + case 3: + aWd(this, true); + return; + case 4: + $Vd(this, 0); + return; + case 5: + this.Zk(1); + return; + case 8: + YVd(this, null); + return; + case 9: + c2 = XVd(this, null, null); + !!c2 && c2.oj(); + return; + case 10: + xWd(this, true); + return; + case 11: + FWd(this, false); + return; + case 12: + DWd(this, false); + return; + case 13: + this.i = null; + zWd(this, null); + return; + case 15: + EWd(this, false); + return; + case 16: + AWd(this, false); + return; + } + Cvd(this, a - AYd(this.ii()), vYd((b = RD(Ywd(this, 16), 29), !b ? this.ii() : b), a)); + }; + _2.pi = function QWd() { + Afe(Qee((lke(), jke), this)); + WVd(this); + this.Bb |= 1; + }; + _2.pk = function RWd() { + return this.f; + }; + _2.ik = function SWd() { + return tWd(this); + }; + _2.qk = function TWd() { + return uWd(this); + }; + _2.uk = function UWd() { + return null; + }; + _2.$k = function VWd() { + return this.k; + }; + _2.Lj = function WWd() { + return this.n; + }; + _2.vk = function XWd() { + return vWd(this); + }; + _2.wk = function YWd() { + var a, b, c2, d, e, f2, g, h, i2; + if (!this.p) { + c2 = uWd(this); + (c2.i == null && rYd(c2), c2.i).length; + d = this.uk(); + !!d && AYd(uWd(d)); + e = WVd(this); + g = e.kk(); + a = !g ? null : (g.i & 1) != 0 ? g == xdb ? QI : g == kE ? bJ : g == jE ? ZI : g == iE ? VI : g == lE ? eJ : g == wdb ? lJ : g == gE ? RI : SI : g; + b = tWd(this); + h = e.ik(); + Mje(this); + (this.Bb & Ove) != 0 && (!!(f2 = Tee((lke(), jke), c2)) && f2 != this || !!(f2 = zfe(Qee(jke, this)))) ? this.p = new Z6d(this, f2) : this.Jk() ? this.al() ? !d ? (this.Bb & bKe) != 0 ? !a ? this.bl() ? this.p = new i7d(42, this) : this.p = new i7d(0, this) : a == UK ? this.p = new g7d(50, O6, this) : this.bl() ? this.p = new g7d(43, a, this) : this.p = new g7d(1, a, this) : !a ? this.bl() ? this.p = new i7d(44, this) : this.p = new i7d(2, this) : a == UK ? this.p = new g7d(41, O6, this) : this.bl() ? this.p = new g7d(45, a, this) : this.p = new g7d(3, a, this) : (this.Bb & bKe) != 0 ? !a ? this.bl() ? this.p = new j7d(46, this, d) : this.p = new j7d(4, this, d) : this.bl() ? this.p = new h7d(47, a, this, d) : this.p = new h7d(5, a, this, d) : !a ? this.bl() ? this.p = new j7d(48, this, d) : this.p = new j7d(6, this, d) : this.bl() ? this.p = new h7d(49, a, this, d) : this.p = new h7d(7, a, this, d) : ZD(e, 156) ? a == Jbb ? this.p = new i7d(40, this) : (this.Bb & 512) != 0 ? (this.Bb & bKe) != 0 ? !a ? this.p = new i7d(8, this) : this.p = new g7d(9, a, this) : !a ? this.p = new i7d(10, this) : this.p = new g7d(11, a, this) : (this.Bb & bKe) != 0 ? !a ? this.p = new i7d(12, this) : this.p = new g7d(13, a, this) : !a ? this.p = new i7d(14, this) : this.p = new g7d(15, a, this) : !d ? this.bl() ? (this.Bb & bKe) != 0 ? !a ? this.p = new i7d(16, this) : this.p = new g7d(17, a, this) : !a ? this.p = new i7d(18, this) : this.p = new g7d(19, a, this) : (this.Bb & bKe) != 0 ? !a ? this.p = new i7d(20, this) : this.p = new g7d(21, a, this) : !a ? this.p = new i7d(22, this) : this.p = new g7d(23, a, this) : (i2 = d.t, i2 > 1 || i2 == -1 ? this.bl() ? (this.Bb & bKe) != 0 ? !a ? this.p = new j7d(24, this, d) : this.p = new h7d(25, a, this, d) : !a ? this.p = new j7d(26, this, d) : this.p = new h7d(27, a, this, d) : (this.Bb & bKe) != 0 ? !a ? this.p = new j7d(28, this, d) : this.p = new h7d(29, a, this, d) : !a ? this.p = new j7d(30, this, d) : this.p = new h7d(31, a, this, d) : this.bl() ? (this.Bb & bKe) != 0 ? !a ? this.p = new j7d(32, this, d) : this.p = new h7d(33, a, this, d) : !a ? this.p = new j7d(34, this, d) : this.p = new h7d(35, a, this, d) : (this.Bb & bKe) != 0 ? !a ? this.p = new j7d(36, this, d) : this.p = new h7d(37, a, this, d) : !a ? this.p = new j7d(38, this, d) : this.p = new h7d(39, a, this, d)) : this._k() ? this.bl() ? this.p = new K7d(RD(e, 29), this, d) : this.p = new C7d(RD(e, 29), this, d) : ZD(e, 156) ? a == Jbb ? this.p = new i7d(40, this) : (this.Bb & bKe) != 0 ? !a ? this.p = new J8d(RD(e, 156), b, h, this) : this.p = new L8d(b, h, this, (a8d(), g == kE ? Y7d : g == xdb ? T7d : g == lE ? Z7d : g == jE ? X7d : g == iE ? W7d : g == wdb ? _7d : g == gE ? U7d : g == hE ? V7d : $7d)) : !a ? this.p = new C8d(RD(e, 156), b, h, this) : this.p = new E8d(b, h, this, (a8d(), g == kE ? Y7d : g == xdb ? T7d : g == lE ? Z7d : g == jE ? X7d : g == iE ? W7d : g == wdb ? _7d : g == gE ? U7d : g == hE ? V7d : $7d)) : this.al() ? !d ? (this.Bb & bKe) != 0 ? this.bl() ? this.p = new d9d(RD(e, 29), this) : this.p = new b9d(RD(e, 29), this) : this.bl() ? this.p = new _8d(RD(e, 29), this) : this.p = new Z8d(RD(e, 29), this) : (this.Bb & bKe) != 0 ? this.bl() ? this.p = new l9d(RD(e, 29), this, d) : this.p = new j9d(RD(e, 29), this, d) : this.bl() ? this.p = new h9d(RD(e, 29), this, d) : this.p = new f9d(RD(e, 29), this, d) : this.bl() ? !d ? (this.Bb & bKe) != 0 ? this.p = new p9d(RD(e, 29), this) : this.p = new n9d(RD(e, 29), this) : (this.Bb & bKe) != 0 ? this.p = new t9d(RD(e, 29), this, d) : this.p = new r9d(RD(e, 29), this, d) : !d ? (this.Bb & bKe) != 0 ? this.p = new v9d(RD(e, 29), this) : this.p = new N8d(RD(e, 29), this) : (this.Bb & bKe) != 0 ? this.p = new z9d(RD(e, 29), this, d) : this.p = new x9d(RD(e, 29), this, d); + } + return this.p; + }; + _2.rk = function ZWd() { + return (this.Bb & gwe) != 0; + }; + _2._k = function $Wd() { + return false; + }; + _2.al = function _Wd() { + return false; + }; + _2.sk = function aXd() { + return (this.Bb & Ove) != 0; + }; + _2.xk = function bXd() { + return wWd(this); + }; + _2.bl = function cXd() { + return false; + }; + _2.tk = function dXd() { + return (this.Bb & bKe) != 0; + }; + _2.cl = function eXd(a) { + this.k = a; + }; + _2.ui = function fXd(a) { + CWd(this, a); + }; + _2.Ib = function gXd() { + return GWd(this); + }; + _2.e = false; + _2.n = 0; + sfb(SHe, "EStructuralFeatureImpl", 462); + feb(331, 462, { 110: 1, 94: 1, 93: 1, 35: 1, 155: 1, 197: 1, 58: 1, 179: 1, 69: 1, 114: 1, 481: 1, 54: 1, 99: 1, 331: 1, 158: 1, 462: 1, 292: 1, 119: 1, 120: 1, 692: 1 }, mXd); + _2.Lh = function nXd(a, b, c2) { + var d, e; + switch (a) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), this.Ab; + case 1: + return this.zb; + case 2: + return Geb(), (this.Bb & 256) != 0 ? true : false; + case 3: + return Geb(), (this.Bb & 512) != 0 ? true : false; + case 4: + return sgb(this.s); + case 5: + return sgb(this.t); + case 6: + return Geb(), jXd(this) ? true : false; + case 7: + return Geb(), e = this.s, e >= 1 ? true : false; + case 8: + if (b) + return WVd(this); + return this.r; + case 9: + return this.q; + case 10: + return Geb(), (this.Bb & gwe) != 0 ? true : false; + case 11: + return Geb(), (this.Bb & cKe) != 0 ? true : false; + case 12: + return Geb(), (this.Bb & qxe) != 0 ? true : false; + case 13: + return this.j; + case 14: + return tWd(this); + case 15: + return Geb(), (this.Bb & bKe) != 0 ? true : false; + case 16: + return Geb(), (this.Bb & Ove) != 0 ? true : false; + case 17: + return uWd(this); + case 18: + return Geb(), (this.Bb & QHe) != 0 ? true : false; + case 19: + if (b) + return iXd(this); + return hXd(this); + } + return zvd(this, a - AYd((JTd(), nTd)), vYd((d = RD(Ywd(this, 16), 29), !d ? nTd : d), a), b, c2); + }; + _2.Wh = function oXd(a) { + var b, c2; + switch (a) { + case 0: + return !!this.Ab && this.Ab.i != 0; + case 1: + return this.zb != null; + case 2: + return (this.Bb & 256) == 0; + case 3: + return (this.Bb & 512) == 0; + case 4: + return this.s != 0; + case 5: + return this.t != 1; + case 6: + return jXd(this); + case 7: + return c2 = this.s, c2 >= 1; + case 8: + return !!this.r && !this.q.e && j2d(this.q).i == 0; + case 9: + return !!this.q && !(!!this.r && !this.q.e && j2d(this.q).i == 0); + case 10: + return (this.Bb & gwe) == 0; + case 11: + return (this.Bb & cKe) != 0; + case 12: + return (this.Bb & qxe) != 0; + case 13: + return this.j != null; + case 14: + return tWd(this) != null; + case 15: + return (this.Bb & bKe) != 0; + case 16: + return (this.Bb & Ove) != 0; + case 17: + return !!uWd(this); + case 18: + return (this.Bb & QHe) != 0; + case 19: + return !!hXd(this); + } + return Avd(this, a - AYd((JTd(), nTd)), vYd((b = RD(Ywd(this, 16), 29), !b ? nTd : b), a)); + }; + _2.bi = function pXd(a, b) { + var c2, d; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + YGd(this.Ab, RD(b, 16)); + return; + case 1: + CWd(this, WD(b)); + return; + case 2: + _Vd(this, Heb(TD(b))); + return; + case 3: + aWd(this, Heb(TD(b))); + return; + case 4: + $Vd(this, RD(b, 17).a); + return; + case 5: + lXd(this, RD(b, 17).a); + return; + case 8: + YVd(this, RD(b, 142)); + return; + case 9: + d = XVd(this, RD(b, 89), null); + !!d && d.oj(); + return; + case 10: + xWd(this, Heb(TD(b))); + return; + case 11: + FWd(this, Heb(TD(b))); + return; + case 12: + DWd(this, Heb(TD(b))); + return; + case 13: + yWd(this, WD(b)); + return; + case 15: + EWd(this, Heb(TD(b))); + return; + case 16: + AWd(this, Heb(TD(b))); + return; + case 18: + kXd(this, Heb(TD(b))); + return; + } + Bvd(this, a - AYd((JTd(), nTd)), vYd((c2 = RD(Ywd(this, 16), 29), !c2 ? nTd : c2), a), b); + }; + _2.ii = function qXd() { + return JTd(), nTd; + }; + _2.ki = function rXd(a) { + var b, c2; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + return; + case 1: + ZD(this.Cb, 90) && v$d(yYd(RD(this.Cb, 90)), 4); + PAd(this, null); + return; + case 2: + _Vd(this, true); + return; + case 3: + aWd(this, true); + return; + case 4: + $Vd(this, 0); + return; + case 5: + this.b = 0; + bWd(this, 1); + return; + case 8: + YVd(this, null); + return; + case 9: + c2 = XVd(this, null, null); + !!c2 && c2.oj(); + return; + case 10: + xWd(this, true); + return; + case 11: + FWd(this, false); + return; + case 12: + DWd(this, false); + return; + case 13: + this.i = null; + zWd(this, null); + return; + case 15: + EWd(this, false); + return; + case 16: + AWd(this, false); + return; + case 18: + kXd(this, false); + return; + } + Cvd(this, a - AYd((JTd(), nTd)), vYd((b = RD(Ywd(this, 16), 29), !b ? nTd : b), a)); + }; + _2.pi = function sXd() { + iXd(this); + Afe(Qee((lke(), jke), this)); + WVd(this); + this.Bb |= 1; + }; + _2.Jk = function tXd() { + return jXd(this); + }; + _2.Yk = function uXd(a, b) { + this.b = 0; + this.a = null; + return ZVd(this, a, b); + }; + _2.Zk = function vXd(a) { + lXd(this, a); + }; + _2.Ib = function wXd() { + var a; + if ((this.Db & 64) != 0) + return GWd(this); + a = new Shb(GWd(this)); + a.a += " (iD: "; + Ohb(a, (this.Bb & QHe) != 0); + a.a += ")"; + return a.a; + }; + _2.b = 0; + sfb(SHe, "EAttributeImpl", 331); + feb(364, 448, { 110: 1, 94: 1, 93: 1, 142: 1, 155: 1, 197: 1, 58: 1, 114: 1, 54: 1, 99: 1, 364: 1, 158: 1, 119: 1, 120: 1, 691: 1 }); + _2.dl = function NXd(a) { + return a.Dh() == this; + }; + _2.Ah = function OXd(a) { + return AXd(this, a); + }; + _2.Bh = function PXd(a, b) { + this.w = null; + this.Db = b << 16 | this.Db & 255; + this.Cb = a; + }; + _2.Lh = function QXd(a, b, c2) { + var d; + switch (a) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), this.Ab; + case 1: + return this.zb; + case 2: + return this.D != null ? this.D : this.B; + case 3: + return DXd(this); + case 4: + return this.ik(); + case 5: + return this.F; + case 6: + if (b) + return BXd(this); + return xXd(this); + case 7: + return !this.A && (this.A = new iie(z7, this, 7)), this.A; + } + return zvd(this, a - AYd(this.ii()), vYd((d = RD(Ywd(this, 16), 29), !d ? this.ii() : d), a), b, c2); + }; + _2.Sh = function RXd(a, b, c2) { + var d, e, f2; + switch (b) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), qLd(this.Ab, a, c2); + case 6: + !!this.Cb && (c2 = (e = this.Db >> 16, e >= 0 ? AXd(this, c2) : this.Cb.Th(this, -1 - e, null, c2))); + return xvd(this, a, 6, c2); + } + return f2 = RD(vYd((d = RD(Ywd(this, 16), 29), !d ? this.ii() : d), b), 69), f2.wk().zk(this, Wwd(this), b - AYd(this.ii()), a, c2); + }; + _2.Uh = function SXd(a, b, c2) { + var d, e; + switch (b) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), rLd(this.Ab, a, c2); + case 6: + return xvd(this, null, 6, c2); + case 7: + return !this.A && (this.A = new iie(z7, this, 7)), rLd(this.A, a, c2); + } + return e = RD(vYd((d = RD(Ywd(this, 16), 29), !d ? this.ii() : d), b), 69), e.wk().Ak(this, Wwd(this), b - AYd(this.ii()), a, c2); + }; + _2.Wh = function TXd(a) { + var b; + switch (a) { + case 0: + return !!this.Ab && this.Ab.i != 0; + case 1: + return this.zb != null; + case 2: + return this.D != null && this.D == this.F; + case 3: + return !!DXd(this); + case 4: + return this.ik() != null; + case 5: + return this.F != null && this.F != this.D && this.F != this.B; + case 6: + return !!xXd(this); + case 7: + return !!this.A && this.A.i != 0; + } + return Avd(this, a - AYd(this.ii()), vYd((b = RD(Ywd(this, 16), 29), !b ? this.ii() : b), a)); + }; + _2.bi = function UXd(a, b) { + var c2; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + YGd(this.Ab, RD(b, 16)); + return; + case 1: + LXd(this, WD(b)); + return; + case 2: + IXd(this, WD(b)); + return; + case 5: + KXd(this, WD(b)); + return; + case 7: + !this.A && (this.A = new iie(z7, this, 7)); + sLd(this.A); + !this.A && (this.A = new iie(z7, this, 7)); + YGd(this.A, RD(b, 16)); + return; + } + Bvd(this, a - AYd(this.ii()), vYd((c2 = RD(Ywd(this, 16), 29), !c2 ? this.ii() : c2), a), b); + }; + _2.ii = function VXd() { + return JTd(), pTd; + }; + _2.ki = function WXd(a) { + var b; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + return; + case 1: + ZD(this.Cb, 184) && (RD(this.Cb, 184).tb = null); + PAd(this, null); + return; + case 2: + yXd(this, null); + zXd(this, this.D); + return; + case 5: + KXd(this, null); + return; + case 7: + !this.A && (this.A = new iie(z7, this, 7)); + sLd(this.A); + return; + } + Cvd(this, a - AYd(this.ii()), vYd((b = RD(Ywd(this, 16), 29), !b ? this.ii() : b), a)); + }; + _2.hk = function XXd() { + var a; + return this.G == -1 && (this.G = (a = BXd(this), a ? fZd(a.vi(), this) : -1)), this.G; + }; + _2.ik = function YXd() { + return null; + }; + _2.jk = function ZXd() { + return BXd(this); + }; + _2.el = function $Xd() { + return this.v; + }; + _2.kk = function _Xd() { + return DXd(this); + }; + _2.lk = function aYd() { + return this.D != null ? this.D : this.B; + }; + _2.mk = function bYd() { + return this.F; + }; + _2.fk = function cYd(a) { + return FXd(this, a); + }; + _2.fl = function dYd(a) { + this.v = a; + }; + _2.gl = function eYd(a) { + GXd(this, a); + }; + _2.hl = function fYd(a) { + this.C = a; + }; + _2.ui = function gYd(a) { + LXd(this, a); + }; + _2.Ib = function hYd() { + return MXd(this); + }; + _2.C = null; + _2.D = null; + _2.G = -1; + sfb(SHe, "EClassifierImpl", 364); + feb(90, 364, { 110: 1, 94: 1, 93: 1, 29: 1, 142: 1, 155: 1, 197: 1, 58: 1, 114: 1, 54: 1, 99: 1, 90: 1, 364: 1, 158: 1, 482: 1, 119: 1, 120: 1, 691: 1 }, HYd); + _2.dl = function IYd(a) { + return DYd(this, a.Dh()); + }; + _2.Lh = function JYd(a, b, c2) { + var d; + switch (a) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), this.Ab; + case 1: + return this.zb; + case 2: + return this.D != null ? this.D : this.B; + case 3: + return DXd(this); + case 4: + return null; + case 5: + return this.F; + case 6: + if (b) + return BXd(this); + return xXd(this); + case 7: + return !this.A && (this.A = new iie(z7, this, 7)), this.A; + case 8: + return Geb(), (this.Bb & 256) != 0 ? true : false; + case 9: + return Geb(), (this.Bb & 512) != 0 ? true : false; + case 10: + return zYd(this); + case 11: + return !this.q && (this.q = new C5d(s7, this, 11, 10)), this.q; + case 12: + return mYd(this); + case 13: + return qYd(this); + case 14: + return qYd(this), this.r; + case 15: + return mYd(this), this.k; + case 16: + return nYd(this); + case 17: + return pYd(this); + case 18: + return rYd(this); + case 19: + return sYd(this); + case 20: + return mYd(this), this.o; + case 21: + return !this.s && (this.s = new C5d(y7, this, 21, 17)), this.s; + case 22: + return tYd(this); + case 23: + return oYd(this); + } + return zvd(this, a - AYd((JTd(), oTd)), vYd((d = RD(Ywd(this, 16), 29), !d ? oTd : d), a), b, c2); + }; + _2.Sh = function KYd(a, b, c2) { + var d, e, f2; + switch (b) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), qLd(this.Ab, a, c2); + case 6: + !!this.Cb && (c2 = (e = this.Db >> 16, e >= 0 ? AXd(this, c2) : this.Cb.Th(this, -1 - e, null, c2))); + return xvd(this, a, 6, c2); + case 11: + return !this.q && (this.q = new C5d(s7, this, 11, 10)), qLd(this.q, a, c2); + case 21: + return !this.s && (this.s = new C5d(y7, this, 21, 17)), qLd(this.s, a, c2); + } + return f2 = RD(vYd((d = RD(Ywd(this, 16), 29), !d ? (JTd(), oTd) : d), b), 69), f2.wk().zk(this, Wwd(this), b - AYd((JTd(), oTd)), a, c2); + }; + _2.Uh = function LYd(a, b, c2) { + var d, e; + switch (b) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), rLd(this.Ab, a, c2); + case 6: + return xvd(this, null, 6, c2); + case 7: + return !this.A && (this.A = new iie(z7, this, 7)), rLd(this.A, a, c2); + case 11: + return !this.q && (this.q = new C5d(s7, this, 11, 10)), rLd(this.q, a, c2); + case 21: + return !this.s && (this.s = new C5d(y7, this, 21, 17)), rLd(this.s, a, c2); + case 22: + return rLd(tYd(this), a, c2); + } + return e = RD(vYd((d = RD(Ywd(this, 16), 29), !d ? (JTd(), oTd) : d), b), 69), e.wk().Ak(this, Wwd(this), b - AYd((JTd(), oTd)), a, c2); + }; + _2.Wh = function MYd(a) { + var b; + switch (a) { + case 0: + return !!this.Ab && this.Ab.i != 0; + case 1: + return this.zb != null; + case 2: + return this.D != null && this.D == this.F; + case 3: + return !!DXd(this); + case 4: + return false; + case 5: + return this.F != null && this.F != this.D && this.F != this.B; + case 6: + return !!xXd(this); + case 7: + return !!this.A && this.A.i != 0; + case 8: + return (this.Bb & 256) != 0; + case 9: + return (this.Bb & 512) != 0; + case 10: + return !!this.u && tYd(this.u.a).i != 0 && !(!!this.n && d$d(this.n)); + case 11: + return !!this.q && this.q.i != 0; + case 12: + return mYd(this).i != 0; + case 13: + return qYd(this).i != 0; + case 14: + return qYd(this), this.r.i != 0; + case 15: + return mYd(this), this.k.i != 0; + case 16: + return nYd(this).i != 0; + case 17: + return pYd(this).i != 0; + case 18: + return rYd(this).i != 0; + case 19: + return sYd(this).i != 0; + case 20: + return mYd(this), !!this.o; + case 21: + return !!this.s && this.s.i != 0; + case 22: + return !!this.n && d$d(this.n); + case 23: + return oYd(this).i != 0; + } + return Avd(this, a - AYd((JTd(), oTd)), vYd((b = RD(Ywd(this, 16), 29), !b ? oTd : b), a)); + }; + _2.Zh = function NYd(a) { + var b; + b = this.i == null || !!this.q && this.q.i != 0 ? null : wYd(this, a); + return b ? b : _zd(this, a); + }; + _2.bi = function OYd(a, b) { + var c2; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + YGd(this.Ab, RD(b, 16)); + return; + case 1: + LXd(this, WD(b)); + return; + case 2: + IXd(this, WD(b)); + return; + case 5: + KXd(this, WD(b)); + return; + case 7: + !this.A && (this.A = new iie(z7, this, 7)); + sLd(this.A); + !this.A && (this.A = new iie(z7, this, 7)); + YGd(this.A, RD(b, 16)); + return; + case 8: + EYd(this, Heb(TD(b))); + return; + case 9: + FYd(this, Heb(TD(b))); + return; + case 10: + VJd(zYd(this)); + YGd(zYd(this), RD(b, 16)); + return; + case 11: + !this.q && (this.q = new C5d(s7, this, 11, 10)); + sLd(this.q); + !this.q && (this.q = new C5d(s7, this, 11, 10)); + YGd(this.q, RD(b, 16)); + return; + case 21: + !this.s && (this.s = new C5d(y7, this, 21, 17)); + sLd(this.s); + !this.s && (this.s = new C5d(y7, this, 21, 17)); + YGd(this.s, RD(b, 16)); + return; + case 22: + sLd(tYd(this)); + YGd(tYd(this), RD(b, 16)); + return; + } + Bvd(this, a - AYd((JTd(), oTd)), vYd((c2 = RD(Ywd(this, 16), 29), !c2 ? oTd : c2), a), b); + }; + _2.ii = function PYd() { + return JTd(), oTd; + }; + _2.ki = function QYd(a) { + var b; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + return; + case 1: + ZD(this.Cb, 184) && (RD(this.Cb, 184).tb = null); + PAd(this, null); + return; + case 2: + yXd(this, null); + zXd(this, this.D); + return; + case 5: + KXd(this, null); + return; + case 7: + !this.A && (this.A = new iie(z7, this, 7)); + sLd(this.A); + return; + case 8: + EYd(this, false); + return; + case 9: + FYd(this, false); + return; + case 10: + !!this.u && VJd(this.u); + return; + case 11: + !this.q && (this.q = new C5d(s7, this, 11, 10)); + sLd(this.q); + return; + case 21: + !this.s && (this.s = new C5d(y7, this, 21, 17)); + sLd(this.s); + return; + case 22: + !!this.n && sLd(this.n); + return; + } + Cvd(this, a - AYd((JTd(), oTd)), vYd((b = RD(Ywd(this, 16), 29), !b ? oTd : b), a)); + }; + _2.pi = function RYd() { + var a, b; + mYd(this); + qYd(this); + nYd(this); + pYd(this); + rYd(this); + sYd(this); + oYd(this); + OHd(q$d(yYd(this))); + if (this.s) { + for (a = 0, b = this.s.i; a < b; ++a) { + aAd(QHd(this.s, a)); + } + } + if (this.q) { + for (a = 0, b = this.q.i; a < b; ++a) { + aAd(QHd(this.q, a)); + } + } + Oee((lke(), jke), this).xe(); + this.Bb |= 1; + }; + _2.Ib = function SYd() { + return GYd(this); + }; + _2.k = null; + _2.r = null; + var iYd, jYd, kYd; + sfb(SHe, "EClassImpl", 90); + feb(2092, 2091, nKe); + _2.Ei = function TYd(a, b) { + return nLd(this, a, b); + }; + _2.Fi = function UYd(a) { + return nLd(this, this.i, a); + }; + _2.Gi = function VYd(a, b) { + oLd(this, a, b); + }; + _2.Hi = function WYd(a) { + pLd(this, a); + }; + _2.Wk = function XYd(a, b) { + return qLd(this, a, b); + }; + _2.$i = function YYd(a) { + return NHd(this, a); + }; + _2.Xk = function aZd(a, b) { + return rLd(this, a, b); + }; + _2.Xi = function bZd(a, b) { + return xLd(this, a, b); + }; + _2.Ii = function ZYd() { + return new yMd(this); + }; + _2.Ji = function $Yd() { + return new BMd(this); + }; + _2.Ki = function _Yd(a) { + return ZGd(this, a); + }; + sfb(ZJe, "NotifyingInternalEListImpl", 2092); + feb(632, 2092, oKe); + _2.Hc = function lZd(a) { + return cZd(this, a); + }; + _2.Ij = function mZd(a, b, c2, d, e) { + return dZd(this, a, b, c2, d, e); + }; + _2.Jj = function nZd(a) { + eZd(this, a); + }; + _2.Fk = function oZd(a) { + return this; + }; + _2.Lk = function pZd() { + return vYd(this.e.Dh(), this.Lj()); + }; + _2.Kj = function qZd() { + return this.Lk(); + }; + _2.Lj = function rZd() { + return BYd(this.e.Dh(), this.Lk()); + }; + _2.il = function sZd() { + return RD(this.Lk().Hk(), 29).kk(); + }; + _2.jl = function tZd() { + return Z5d(RD(this.Lk(), 19)).n; + }; + _2.jj = function uZd() { + return this.e; + }; + _2.kl = function vZd() { + return true; + }; + _2.ll = function wZd() { + return false; + }; + _2.ml = function xZd() { + return false; + }; + _2.nl = function yZd() { + return false; + }; + _2.dd = function zZd(a) { + return fZd(this, a); + }; + _2.Nj = function AZd(a, b) { + var c2; + return c2 = RD(a, 54), this.ml() ? this.kl() ? c2.Rh(this.e, this.jl(), this.il(), b) : c2.Rh(this.e, BYd(c2.Dh(), Z5d(RD(this.Lk(), 19))), null, b) : c2.Rh(this.e, -1 - this.Lj(), null, b); + }; + _2.Oj = function BZd(a, b) { + var c2; + return c2 = RD(a, 54), this.ml() ? this.kl() ? c2.Th(this.e, this.jl(), this.il(), b) : c2.Th(this.e, BYd(c2.Dh(), Z5d(RD(this.Lk(), 19))), null, b) : c2.Th(this.e, -1 - this.Lj(), null, b); + }; + _2.al = function CZd() { + return false; + }; + _2.ol = function DZd() { + return true; + }; + _2.fk = function EZd(a) { + return QRd(this.d, a); + }; + _2.Pj = function FZd() { + return Mvd(this.e); + }; + _2.Qj = function GZd() { + return this.i != 0; + }; + _2.aj = function HZd(a) { + return IMd(this.d, a); + }; + _2.Wi = function IZd(a, b) { + return this.ol() && this.nl() ? gZd(this, a, RD(b, 58)) : b; + }; + _2.pl = function JZd(a) { + return a.Vh() ? Vvd(this.e, RD(a, 54)) : a; + }; + _2.Wb = function KZd(a) { + hZd(this, a); + }; + _2.Pc = function LZd() { + return iZd(this); + }; + _2.Qc = function MZd(a) { + var b; + if (this.nl()) { + for (b = this.i - 1; b >= 0; --b) { + QHd(this, b); + } + } + return XHd(this, a); + }; + _2.Gk = function NZd() { + sLd(this); + }; + _2.Zi = function OZd(a, b) { + return jZd(this, a, b); + }; + sfb(ZJe, "EcoreEList", 632); + feb(505, 632, oKe, PZd); + _2.Li = function QZd() { + return false; + }; + _2.Lj = function RZd() { + return this.c; + }; + _2.Mj = function SZd() { + return false; + }; + _2.ol = function TZd() { + return true; + }; + _2.Si = function UZd() { + return true; + }; + _2.Wi = function VZd(a, b) { + return b; + }; + _2.Yi = function WZd() { + return false; + }; + _2.c = 0; + sfb(ZJe, "EObjectEList", 505); + feb(83, 505, oKe, XZd); + _2.Mj = function YZd() { + return true; + }; + _2.ml = function ZZd() { + return false; + }; + _2.al = function $Zd() { + return true; + }; + sfb(ZJe, "EObjectContainmentEList", 83); + feb(555, 83, oKe, _Zd); + _2.Ni = function a$d() { + this.b = true; + }; + _2.Qj = function b$d() { + return this.b; + }; + _2.Gk = function c$d() { + var a; + sLd(this); + if (Mvd(this.e)) { + a = this.b; + this.b = false; + qvd(this.e, new Q3d(this.e, 2, this.c, a, false)); + } else { + this.b = false; + } + }; + _2.b = false; + sfb(ZJe, "EObjectContainmentEList/Unsettable", 555); + feb(1161, 555, oKe, h$d); + _2.Ti = function l$d(a, b) { + var c2, d; + return c2 = RD(uLd(this, a, b), 89), Mvd(this.e) && eZd(this, new c4d(this.a, 7, (JTd(), qTd), sgb(b), (d = c2.c, ZD(d, 90) ? RD(d, 29) : zTd), a)), c2; + }; + _2.Uj = function m$d(a, b) { + return e$d(this, RD(a, 89), b); + }; + _2.Vj = function n$d(a, b) { + return f$d(this, RD(a, 89), b); + }; + _2.Wj = function o$d(a, b, c2) { + return g$d(this, RD(a, 89), RD(b, 89), c2); + }; + _2.Ij = function i$d(a, b, c2, d, e) { + switch (a) { + case 3: { + return dZd(this, a, b, c2, d, this.i > 1); + } + case 5: { + return dZd(this, a, b, c2, d, this.i - RD(c2, 15).gc() > 0); + } + default: { + return new P3d(this.e, a, this.c, b, c2, d, true); + } + } + }; + _2.Tj = function j$d() { + return true; + }; + _2.Qj = function k$d() { + return d$d(this); + }; + _2.Gk = function p$d() { + sLd(this); + }; + sfb(SHe, "EClassImpl/1", 1161); + feb(1175, 1174, EJe); + _2.dj = function t$d(a) { + var b, c2, d, e, f2, g, h; + c2 = a.gj(); + if (c2 != 8) { + d = s$d(a); + if (d == 0) { + switch (c2) { + case 1: + case 9: { + h = a.kj(); + if (h != null) { + b = yYd(RD(h, 482)); + !b.c && (b.c = new X9d()); + dHd(b.c, a.jj()); + } + g = a.ij(); + if (g != null) { + e = RD(g, 482); + if ((e.Bb & 1) == 0) { + b = yYd(e); + !b.c && (b.c = new X9d()); + WGd(b.c, RD(a.jj(), 29)); + } + } + break; + } + case 3: { + g = a.ij(); + if (g != null) { + e = RD(g, 482); + if ((e.Bb & 1) == 0) { + b = yYd(e); + !b.c && (b.c = new X9d()); + WGd(b.c, RD(a.jj(), 29)); + } + } + break; + } + case 5: { + g = a.ij(); + if (g != null) { + for (f2 = RD(g, 16).Kc(); f2.Ob(); ) { + e = RD(f2.Pb(), 482); + if ((e.Bb & 1) == 0) { + b = yYd(e); + !b.c && (b.c = new X9d()); + WGd(b.c, RD(a.jj(), 29)); + } + } + } + break; + } + case 4: { + h = a.kj(); + if (h != null) { + e = RD(h, 482); + if ((e.Bb & 1) == 0) { + b = yYd(e); + !b.c && (b.c = new X9d()); + dHd(b.c, a.jj()); + } + } + break; + } + case 6: { + h = a.kj(); + if (h != null) { + for (f2 = RD(h, 16).Kc(); f2.Ob(); ) { + e = RD(f2.Pb(), 482); + if ((e.Bb & 1) == 0) { + b = yYd(e); + !b.c && (b.c = new X9d()); + dHd(b.c, a.jj()); + } + } + } + break; + } + } + } + this.ql(d); + } + }; + _2.ql = function u$d(a) { + r$d(this, a); + }; + _2.b = 63; + sfb(SHe, "ESuperAdapter", 1175); + feb(1176, 1175, EJe, w$d); + _2.ql = function x$d(a) { + v$d(this, a); + }; + sfb(SHe, "EClassImpl/10", 1176); + feb(1165, 710, oKe); + _2.Ei = function y$d(a, b) { + return IHd(this, a, b); + }; + _2.Fi = function z$d(a) { + return JHd(this, a); + }; + _2.Gi = function A$d(a, b) { + KHd(this, a, b); + }; + _2.Hi = function B$d(a) { + LHd(this, a); + }; + _2.$i = function D$d(a) { + return NHd(this, a); + }; + _2.Xi = function L$d(a, b) { + return UHd(this, a, b); + }; + _2.Wk = function C$d(a, b) { + throw Adb(new jib()); + }; + _2.Ii = function E$d() { + return new yMd(this); + }; + _2.Ji = function F$d() { + return new BMd(this); + }; + _2.Ki = function G$d(a) { + return ZGd(this, a); + }; + _2.Xk = function H$d(a, b) { + throw Adb(new jib()); + }; + _2.Fk = function I$d(a) { + return this; + }; + _2.Qj = function J$d() { + return this.i != 0; + }; + _2.Wb = function K$d(a) { + throw Adb(new jib()); + }; + _2.Gk = function M$d() { + throw Adb(new jib()); + }; + sfb(ZJe, "EcoreEList/UnmodifiableEList", 1165); + feb(328, 1165, oKe, N$d); + _2.Yi = function O$d() { + return false; + }; + sfb(ZJe, "EcoreEList/UnmodifiableEList/FastCompare", 328); + feb(1168, 328, oKe, R$d); + _2.dd = function S$d(a) { + var b, c2, d; + if (ZD(a, 179)) { + b = RD(a, 179); + c2 = b.Lj(); + if (c2 != -1) { + for (d = this.i; c2 < d; ++c2) { + if (dE(this.g[c2]) === dE(a)) { + return c2; + } + } + } + } + return -1; + }; + sfb(SHe, "EClassImpl/1EAllStructuralFeaturesList", 1168); + feb(1162, 506, PIe, W$d); + _2.aj = function X$d(a) { + return $C(o7, sKe, 89, a, 0, 1); + }; + _2.Yi = function Y$d() { + return false; + }; + sfb(SHe, "EClassImpl/1EGenericSuperTypeEList", 1162); + feb(633, 506, PIe, Z$d); + _2.aj = function $$d(a) { + return $C(y7, lKe, 179, a, 0, 1); + }; + _2.Yi = function _$d() { + return false; + }; + sfb(SHe, "EClassImpl/1EStructuralFeatureUniqueEList", 633); + feb(755, 506, PIe, a_d); + _2.aj = function b_d(a) { + return $C(v7, lKe, 19, a, 0, 1); + }; + _2.Yi = function c_d() { + return false; + }; + sfb(SHe, "EClassImpl/1ReferenceList", 755); + feb(1163, 506, PIe, e_d); + _2.Mi = function f_d(a, b) { + d_d(this, RD(b, 35)); + }; + _2.aj = function g_d(a) { + return $C(g7, lKe, 35, a, 0, 1); + }; + _2.Yi = function h_d() { + return false; + }; + sfb(SHe, "EClassImpl/2", 1163); + feb(1164, 506, PIe, i_d); + _2.aj = function j_d(a) { + return $C(g7, lKe, 35, a, 0, 1); + }; + _2.Yi = function k_d() { + return false; + }; + sfb(SHe, "EClassImpl/3", 1164); + feb(1166, 328, oKe, n_d); + _2.Fc = function o_d(a) { + return l_d(this, RD(a, 35)); + }; + _2.Hi = function p_d(a) { + m_d(this, RD(a, 35)); + }; + sfb(SHe, "EClassImpl/4", 1166); + feb(1167, 328, oKe, s_d); + _2.Fc = function t_d(a) { + return q_d(this, RD(a, 19)); + }; + _2.Hi = function u_d(a) { + r_d(this, RD(a, 19)); + }; + sfb(SHe, "EClassImpl/5", 1167); + feb(1169, 506, PIe, v_d); + _2.aj = function w_d(a) { + return $C(s7, mKe, 62, a, 0, 1); + }; + _2.Yi = function x_d() { + return false; + }; + sfb(SHe, "EClassImpl/6", 1169); + feb(1170, 506, PIe, y_d); + _2.aj = function z_d(a) { + return $C(v7, lKe, 19, a, 0, 1); + }; + _2.Yi = function A_d() { + return false; + }; + sfb(SHe, "EClassImpl/7", 1170); + feb(2095, 2094, { 3: 1, 4: 1, 20: 1, 31: 1, 56: 1, 16: 1, 15: 1, 70: 1, 61: 1, 71: 1 }); + _2.Ei = function B_d(a, b) { + return QJd(this, a, b); + }; + _2.Fi = function C_d(a) { + return QJd(this, this.Ej(), a); + }; + _2.Gi = function D_d(a, b) { + RJd(this, a, b); + }; + _2.Hi = function E_d(a) { + SJd(this, a); + }; + _2.Wk = function F_d(a, b) { + return TJd(this, a, b); + }; + _2.Xk = function L_d(a, b) { + return UJd(this, a, b); + }; + _2.Xi = function M_d(a, b) { + return WJd(this, a, b); + }; + _2.$i = function G_d(a) { + return this.xj(a); + }; + _2.Ii = function H_d() { + return new yMd(this); + }; + _2.pj = function I_d() { + return this.sj(); + }; + _2.Ji = function J_d() { + return new BMd(this); + }; + _2.Ki = function K_d(a) { + return ZGd(this, a); + }; + sfb(ZJe, "DelegatingNotifyingInternalEListImpl", 2095); + feb(756, 2095, tKe); + _2.Li = function R_d() { + var a; + a = vYd(Uwd(this.b), this.Lj()).Hk(); + return ZD(a, 156) && !ZD(a, 469) && (a.kk().i & 1) == 0; + }; + _2.Hc = function S_d(a) { + var b, c2, d, e, f2, g, h, i2; + if (this.ol()) { + i2 = this.Ej(); + if (i2 > 4) { + if (this.fk(a)) { + if (this.al()) { + d = RD(a, 54); + c2 = d.Eh(); + h = c2 == this.b && (this.ml() ? d.yh(d.Fh(), RD(vYd(Uwd(this.b), this.Lj()).Hk(), 29).kk()) == Z5d(RD(vYd(Uwd(this.b), this.Lj()), 19)).n : -1 - d.Fh() == this.Lj()); + if (this.nl() && !h && !c2 && !!d.Jh()) { + for (e = 0; e < i2; ++e) { + b = O_d(this, this.xj(e)); + if (dE(b) === dE(a)) { + return true; + } + } + } + return h; + } else if (this.ml() && !this.ll()) { + f2 = RD(a, 58).Mh(Z5d(RD(vYd(Uwd(this.b), this.Lj()), 19))); + if (dE(f2) === dE(this.b)) { + return true; + } else if (f2 == null || !RD(f2, 58).Vh()) { + return false; + } + } + } else { + return false; + } + } + g = this.uj(a); + if (this.nl() && !g) { + for (e = 0; e < i2; ++e) { + d = O_d(this, this.xj(e)); + if (dE(d) === dE(a)) { + return true; + } + } + } + return g; + } else { + return this.uj(a); + } + }; + _2.Ij = function T_d(a, b, c2, d, e) { + return new P3d(this.b, a, this.Lj(), b, c2, d, e); + }; + _2.Jj = function U_d(a) { + qvd(this.b, a); + }; + _2.Fk = function V_d(a) { + return this; + }; + _2.Kj = function W_d() { + return vYd(Uwd(this.b), this.Lj()); + }; + _2.Lj = function X_d() { + return BYd(Uwd(this.b), vYd(Uwd(this.b), this.Lj())); + }; + _2.jj = function Y_d() { + return this.b; + }; + _2.kl = function Z_d() { + return !!vYd(Uwd(this.b), this.Lj()).Hk().kk(); + }; + _2.Mj = function $_d() { + var a, b; + b = vYd(Uwd(this.b), this.Lj()); + if (ZD(b, 102)) { + a = RD(b, 19); + return (a.Bb & QHe) != 0 || !!Z5d(RD(b, 19)); + } else { + return false; + } + }; + _2.ll = function __d() { + var a, b, c2, d; + b = vYd(Uwd(this.b), this.Lj()); + if (ZD(b, 102)) { + a = RD(b, 19); + c2 = Z5d(a); + return !!c2 && (d = c2.t, d > 1 || d == -1); + } else { + return false; + } + }; + _2.ml = function a0d() { + var a, b, c2; + b = vYd(Uwd(this.b), this.Lj()); + if (ZD(b, 102)) { + a = RD(b, 19); + c2 = Z5d(a); + return !!c2; + } else { + return false; + } + }; + _2.nl = function b0d() { + var a, b; + b = vYd(Uwd(this.b), this.Lj()); + if (ZD(b, 102)) { + a = RD(b, 19); + return (a.Bb & txe) != 0; + } else { + return false; + } + }; + _2.dd = function c0d(a) { + var b, c2, d, e; + d = this.zj(a); + if (d >= 0) + return d; + if (this.ol()) { + for (c2 = 0, e = this.Ej(); c2 < e; ++c2) { + b = O_d(this, this.xj(c2)); + if (dE(b) === dE(a)) { + return c2; + } + } + } + return -1; + }; + _2.Nj = function d0d(a, b) { + var c2; + return c2 = RD(a, 54), this.ml() ? this.kl() ? c2.Rh(this.b, Z5d(RD(vYd(Uwd(this.b), this.Lj()), 19)).n, RD(vYd(Uwd(this.b), this.Lj()).Hk(), 29).kk(), b) : c2.Rh(this.b, BYd(c2.Dh(), Z5d(RD(vYd(Uwd(this.b), this.Lj()), 19))), null, b) : c2.Rh(this.b, -1 - this.Lj(), null, b); + }; + _2.Oj = function e0d(a, b) { + var c2; + return c2 = RD(a, 54), this.ml() ? this.kl() ? c2.Th(this.b, Z5d(RD(vYd(Uwd(this.b), this.Lj()), 19)).n, RD(vYd(Uwd(this.b), this.Lj()).Hk(), 29).kk(), b) : c2.Th(this.b, BYd(c2.Dh(), Z5d(RD(vYd(Uwd(this.b), this.Lj()), 19))), null, b) : c2.Th(this.b, -1 - this.Lj(), null, b); + }; + _2.al = function f0d() { + var a, b; + b = vYd(Uwd(this.b), this.Lj()); + if (ZD(b, 102)) { + a = RD(b, 19); + return (a.Bb & QHe) != 0; + } else { + return false; + } + }; + _2.ol = function g0d() { + return ZD(vYd(Uwd(this.b), this.Lj()).Hk(), 90); + }; + _2.fk = function h0d(a) { + return vYd(Uwd(this.b), this.Lj()).Hk().fk(a); + }; + _2.Pj = function i0d() { + return Mvd(this.b); + }; + _2.Qj = function j0d() { + return !this.Aj(); + }; + _2.Si = function k0d() { + return vYd(Uwd(this.b), this.Lj()).Si(); + }; + _2.Wi = function l0d(a, b) { + return N_d(this, a, b); + }; + _2.Wb = function m0d(a) { + VJd(this); + YGd(this, RD(a, 15)); + }; + _2.Pc = function n0d() { + var a; + if (this.nl()) { + for (a = this.Ej() - 1; a >= 0; --a) { + N_d(this, a, this.xj(a)); + } + } + return this.Fj(); + }; + _2.Qc = function o0d(a) { + var b; + if (this.nl()) { + for (b = this.Ej() - 1; b >= 0; --b) { + N_d(this, b, this.xj(b)); + } + } + return this.Gj(a); + }; + _2.Gk = function p0d() { + VJd(this); + }; + _2.Zi = function q0d(a, b) { + return P_d(this, a, b); + }; + sfb(ZJe, "DelegatingEcoreEList", 756); + feb(1171, 756, tKe, w0d); + _2.qj = function z0d(a, b) { + r0d(this, a, RD(b, 29)); + }; + _2.rj = function A0d(a) { + s0d(this, RD(a, 29)); + }; + _2.xj = function G0d(a) { + var b, c2; + return b = RD(QHd(tYd(this.a), a), 89), c2 = b.c, ZD(c2, 90) ? RD(c2, 29) : (JTd(), zTd); + }; + _2.Cj = function L0d(a) { + var b, c2; + return b = RD(vLd(tYd(this.a), a), 89), c2 = b.c, ZD(c2, 90) ? RD(c2, 29) : (JTd(), zTd); + }; + _2.Dj = function M0d(a, b) { + return u0d(this, a, RD(b, 29)); + }; + _2.Li = function x0d() { + return false; + }; + _2.Ij = function y0d(a, b, c2, d, e) { + return null; + }; + _2.sj = function B0d() { + return new c1d(this); + }; + _2.tj = function C0d() { + sLd(tYd(this.a)); + }; + _2.uj = function D0d(a) { + return t0d(this, a); + }; + _2.vj = function E0d(a) { + var b, c2; + for (c2 = a.Kc(); c2.Ob(); ) { + b = c2.Pb(); + if (!t0d(this, b)) { + return false; + } + } + return true; + }; + _2.wj = function F0d(a) { + var b, c2, d; + if (ZD(a, 15)) { + d = RD(a, 15); + if (d.gc() == tYd(this.a).i) { + for (b = d.Kc(), c2 = new dMd(this); b.Ob(); ) { + if (dE(b.Pb()) !== dE(bMd(c2))) { + return false; + } + } + return true; + } + } + return false; + }; + _2.yj = function H0d() { + var a, b, c2, d, e; + c2 = 1; + for (b = new dMd(tYd(this.a)); b.e != b.i.gc(); ) { + a = RD(bMd(b), 89); + d = (e = a.c, ZD(e, 90) ? RD(e, 29) : (JTd(), zTd)); + c2 = 31 * c2 + (!d ? 0 : kFb(d)); + } + return c2; + }; + _2.zj = function I0d(a) { + var b, c2, d, e; + d = 0; + for (c2 = new dMd(tYd(this.a)); c2.e != c2.i.gc(); ) { + b = RD(bMd(c2), 89); + if (dE(a) === dE((e = b.c, ZD(e, 90) ? RD(e, 29) : (JTd(), zTd)))) { + return d; + } + ++d; + } + return -1; + }; + _2.Aj = function J0d() { + return tYd(this.a).i == 0; + }; + _2.Bj = function K0d() { + return null; + }; + _2.Ej = function N0d() { + return tYd(this.a).i; + }; + _2.Fj = function O0d() { + var a, b, c2, d, e, f2; + f2 = tYd(this.a).i; + e = $C(jJ, rve, 1, f2, 5, 1); + c2 = 0; + for (b = new dMd(tYd(this.a)); b.e != b.i.gc(); ) { + a = RD(bMd(b), 89); + e[c2++] = (d = a.c, ZD(d, 90) ? RD(d, 29) : (JTd(), zTd)); + } + return e; + }; + _2.Gj = function P0d(a) { + var b, c2, d, e, f2, g, h; + h = tYd(this.a).i; + if (a.length < h) { + e = IMd(rb(a).c, h); + a = e; + } + a.length > h && bD(a, h, null); + d = 0; + for (c2 = new dMd(tYd(this.a)); c2.e != c2.i.gc(); ) { + b = RD(bMd(c2), 89); + f2 = (g = b.c, ZD(g, 90) ? RD(g, 29) : (JTd(), zTd)); + bD(a, d++, f2); + } + return a; + }; + _2.Hj = function Q0d() { + var a, b, c2, d, e; + e = new Qhb(); + e.a += "["; + a = tYd(this.a); + for (b = 0, d = tYd(this.a).i; b < d; ) { + Nhb(e, Ghb((c2 = RD(QHd(a, b), 89).c, ZD(c2, 90) ? RD(c2, 29) : (JTd(), zTd)))); + ++b < d && (e.a += pve, e); + } + e.a += "]"; + return e.a; + }; + _2.Jj = function R0d(a) { + }; + _2.Lj = function S0d() { + return 10; + }; + _2.kl = function T0d() { + return true; + }; + _2.Mj = function U0d() { + return false; + }; + _2.ll = function V0d() { + return false; + }; + _2.ml = function W0d() { + return false; + }; + _2.nl = function X0d() { + return true; + }; + _2.al = function Y0d() { + return false; + }; + _2.ol = function Z0d() { + return true; + }; + _2.fk = function $0d(a) { + return ZD(a, 90); + }; + _2.Qj = function _0d() { + return CYd(this.a); + }; + _2.Si = function a1d() { + return true; + }; + _2.Yi = function b1d() { + return true; + }; + sfb(SHe, "EClassImpl/8", 1171); + feb(1172, 2062, kwe, c1d); + _2.fd = function d1d(a) { + return ZGd(this.a, a); + }; + _2.gc = function e1d() { + return tYd(this.a.a).i; + }; + sfb(SHe, "EClassImpl/8/1", 1172); + feb(1173, 506, PIe, f1d); + _2.aj = function g1d(a) { + return $C(i7, rve, 142, a, 0, 1); + }; + _2.Yi = function h1d() { + return false; + }; + sfb(SHe, "EClassImpl/9", 1173); + feb(1160, 49, Ixe, i1d); + sfb(SHe, "EClassImpl/MyHashSet", 1160); + feb(577, 364, { 110: 1, 94: 1, 93: 1, 142: 1, 156: 1, 847: 1, 155: 1, 197: 1, 58: 1, 114: 1, 54: 1, 99: 1, 364: 1, 158: 1, 119: 1, 120: 1, 691: 1 }, k1d); + _2.Lh = function l1d(a, b, c2) { + var d; + switch (a) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), this.Ab; + case 1: + return this.zb; + case 2: + return this.D != null ? this.D : this.B; + case 3: + return DXd(this); + case 4: + return this.ik(); + case 5: + return this.F; + case 6: + if (b) + return BXd(this); + return xXd(this); + case 7: + return !this.A && (this.A = new iie(z7, this, 7)), this.A; + case 8: + return Geb(), (this.Bb & 256) != 0 ? true : false; + } + return zvd(this, a - AYd(this.ii()), vYd((d = RD(Ywd(this, 16), 29), !d ? this.ii() : d), a), b, c2); + }; + _2.Wh = function m1d(a) { + var b; + switch (a) { + case 0: + return !!this.Ab && this.Ab.i != 0; + case 1: + return this.zb != null; + case 2: + return this.D != null && this.D == this.F; + case 3: + return !!DXd(this); + case 4: + return this.ik() != null; + case 5: + return this.F != null && this.F != this.D && this.F != this.B; + case 6: + return !!xXd(this); + case 7: + return !!this.A && this.A.i != 0; + case 8: + return (this.Bb & 256) == 0; + } + return Avd(this, a - AYd(this.ii()), vYd((b = RD(Ywd(this, 16), 29), !b ? this.ii() : b), a)); + }; + _2.bi = function n1d(a, b) { + var c2; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + YGd(this.Ab, RD(b, 16)); + return; + case 1: + LXd(this, WD(b)); + return; + case 2: + IXd(this, WD(b)); + return; + case 5: + KXd(this, WD(b)); + return; + case 7: + !this.A && (this.A = new iie(z7, this, 7)); + sLd(this.A); + !this.A && (this.A = new iie(z7, this, 7)); + YGd(this.A, RD(b, 16)); + return; + case 8: + j1d(this, Heb(TD(b))); + return; + } + Bvd(this, a - AYd(this.ii()), vYd((c2 = RD(Ywd(this, 16), 29), !c2 ? this.ii() : c2), a), b); + }; + _2.ii = function o1d() { + return JTd(), rTd; + }; + _2.ki = function p1d(a) { + var b; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + return; + case 1: + ZD(this.Cb, 184) && (RD(this.Cb, 184).tb = null); + PAd(this, null); + return; + case 2: + yXd(this, null); + zXd(this, this.D); + return; + case 5: + KXd(this, null); + return; + case 7: + !this.A && (this.A = new iie(z7, this, 7)); + sLd(this.A); + return; + case 8: + j1d(this, true); + return; + } + Cvd(this, a - AYd(this.ii()), vYd((b = RD(Ywd(this, 16), 29), !b ? this.ii() : b), a)); + }; + _2.pi = function q1d() { + Oee((lke(), jke), this).xe(); + this.Bb |= 1; + }; + _2.ok = function r1d() { + var a, b, c2; + if (!this.c) { + a = Kje(BXd(this)); + if (!a.dc()) { + for (c2 = a.Kc(); c2.Ob(); ) { + b = WD(c2.Pb()); + !!bAd(this, b) && Jje(this); + } + } + } + return this.b; + }; + _2.ik = function s1d() { + var b; + if (!this.e) { + b = null; + try { + b = DXd(this); + } catch (a) { + a = zdb(a); + if (!ZD(a, 103)) + throw Adb(a); + } + this.d = null; + !!b && (b.i & 1) != 0 && (b == xdb ? this.d = (Geb(), Eeb) : b == kE ? this.d = sgb(0) : b == jE ? this.d = new Tfb(0) : b == iE ? this.d = 0 : b == lE ? this.d = Hgb(0) : b == wdb ? this.d = bhb(0) : b == gE ? this.d = $eb(0) : this.d = hfb(0)); + this.e = true; + } + return this.d; + }; + _2.nk = function t1d() { + return (this.Bb & 256) != 0; + }; + _2.rl = function u1d(a) { + a && (this.D = "org.eclipse.emf.common.util.AbstractEnumerator"); + }; + _2.gl = function v1d(a) { + GXd(this, a); + this.rl(a); + }; + _2.hl = function w1d(a) { + this.C = a; + this.e = false; + }; + _2.Ib = function x1d() { + var a; + if ((this.Db & 64) != 0) + return MXd(this); + a = new Shb(MXd(this)); + a.a += " (serializable: "; + Ohb(a, (this.Bb & 256) != 0); + a.a += ")"; + return a.a; + }; + _2.c = false; + _2.d = null; + _2.e = false; + sfb(SHe, "EDataTypeImpl", 577); + feb(469, 577, { 110: 1, 94: 1, 93: 1, 142: 1, 156: 1, 847: 1, 685: 1, 155: 1, 197: 1, 58: 1, 114: 1, 54: 1, 99: 1, 364: 1, 469: 1, 158: 1, 119: 1, 120: 1, 691: 1 }, A1d); + _2.Lh = function B1d(a, b, c2) { + var d; + switch (a) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), this.Ab; + case 1: + return this.zb; + case 2: + return this.D != null ? this.D : this.B; + case 3: + return DXd(this); + case 4: + return y1d(this); + case 5: + return this.F; + case 6: + if (b) + return BXd(this); + return xXd(this); + case 7: + return !this.A && (this.A = new iie(z7, this, 7)), this.A; + case 8: + return Geb(), (this.Bb & 256) != 0 ? true : false; + case 9: + return !this.a && (this.a = new C5d(l7, this, 9, 5)), this.a; + } + return zvd(this, a - AYd((JTd(), sTd)), vYd((d = RD(Ywd(this, 16), 29), !d ? sTd : d), a), b, c2); + }; + _2.Sh = function C1d(a, b, c2) { + var d, e, f2; + switch (b) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), qLd(this.Ab, a, c2); + case 6: + !!this.Cb && (c2 = (e = this.Db >> 16, e >= 0 ? AXd(this, c2) : this.Cb.Th(this, -1 - e, null, c2))); + return xvd(this, a, 6, c2); + case 9: + return !this.a && (this.a = new C5d(l7, this, 9, 5)), qLd(this.a, a, c2); + } + return f2 = RD(vYd((d = RD(Ywd(this, 16), 29), !d ? (JTd(), sTd) : d), b), 69), f2.wk().zk(this, Wwd(this), b - AYd((JTd(), sTd)), a, c2); + }; + _2.Uh = function D1d(a, b, c2) { + var d, e; + switch (b) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), rLd(this.Ab, a, c2); + case 6: + return xvd(this, null, 6, c2); + case 7: + return !this.A && (this.A = new iie(z7, this, 7)), rLd(this.A, a, c2); + case 9: + return !this.a && (this.a = new C5d(l7, this, 9, 5)), rLd(this.a, a, c2); + } + return e = RD(vYd((d = RD(Ywd(this, 16), 29), !d ? (JTd(), sTd) : d), b), 69), e.wk().Ak(this, Wwd(this), b - AYd((JTd(), sTd)), a, c2); + }; + _2.Wh = function E1d(a) { + var b; + switch (a) { + case 0: + return !!this.Ab && this.Ab.i != 0; + case 1: + return this.zb != null; + case 2: + return this.D != null && this.D == this.F; + case 3: + return !!DXd(this); + case 4: + return !!y1d(this); + case 5: + return this.F != null && this.F != this.D && this.F != this.B; + case 6: + return !!xXd(this); + case 7: + return !!this.A && this.A.i != 0; + case 8: + return (this.Bb & 256) == 0; + case 9: + return !!this.a && this.a.i != 0; + } + return Avd(this, a - AYd((JTd(), sTd)), vYd((b = RD(Ywd(this, 16), 29), !b ? sTd : b), a)); + }; + _2.bi = function F1d(a, b) { + var c2; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + YGd(this.Ab, RD(b, 16)); + return; + case 1: + LXd(this, WD(b)); + return; + case 2: + IXd(this, WD(b)); + return; + case 5: + KXd(this, WD(b)); + return; + case 7: + !this.A && (this.A = new iie(z7, this, 7)); + sLd(this.A); + !this.A && (this.A = new iie(z7, this, 7)); + YGd(this.A, RD(b, 16)); + return; + case 8: + j1d(this, Heb(TD(b))); + return; + case 9: + !this.a && (this.a = new C5d(l7, this, 9, 5)); + sLd(this.a); + !this.a && (this.a = new C5d(l7, this, 9, 5)); + YGd(this.a, RD(b, 16)); + return; + } + Bvd(this, a - AYd((JTd(), sTd)), vYd((c2 = RD(Ywd(this, 16), 29), !c2 ? sTd : c2), a), b); + }; + _2.ii = function G1d() { + return JTd(), sTd; + }; + _2.ki = function H1d(a) { + var b; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + return; + case 1: + ZD(this.Cb, 184) && (RD(this.Cb, 184).tb = null); + PAd(this, null); + return; + case 2: + yXd(this, null); + zXd(this, this.D); + return; + case 5: + KXd(this, null); + return; + case 7: + !this.A && (this.A = new iie(z7, this, 7)); + sLd(this.A); + return; + case 8: + j1d(this, true); + return; + case 9: + !this.a && (this.a = new C5d(l7, this, 9, 5)); + sLd(this.a); + return; + } + Cvd(this, a - AYd((JTd(), sTd)), vYd((b = RD(Ywd(this, 16), 29), !b ? sTd : b), a)); + }; + _2.pi = function I1d() { + var a, b; + if (this.a) { + for (a = 0, b = this.a.i; a < b; ++a) { + aAd(QHd(this.a, a)); + } + } + Oee((lke(), jke), this).xe(); + this.Bb |= 1; + }; + _2.ik = function J1d() { + return y1d(this); + }; + _2.fk = function K1d(a) { + if (a != null) { + return true; + } + return false; + }; + _2.rl = function L1d(a) { + }; + sfb(SHe, "EEnumImpl", 469); + feb(582, 448, { 110: 1, 94: 1, 93: 1, 2039: 1, 694: 1, 155: 1, 197: 1, 58: 1, 114: 1, 54: 1, 99: 1, 582: 1, 158: 1, 119: 1, 120: 1 }, R1d); + _2.xe = function $1d() { + return this.zb; + }; + _2.Ah = function S1d(a) { + return M1d(this, a); + }; + _2.Lh = function T1d(a, b, c2) { + var d, e; + switch (a) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), this.Ab; + case 1: + return this.zb; + case 2: + return sgb(this.d); + case 3: + return this.b ? this.b : this.a; + case 4: + return e = this.c, e == null ? this.zb : e; + case 5: + return this.Db >> 16 == 5 ? RD(this.Cb, 685) : null; + } + return zvd(this, a - AYd((JTd(), tTd)), vYd((d = RD(Ywd(this, 16), 29), !d ? tTd : d), a), b, c2); + }; + _2.Sh = function U1d(a, b, c2) { + var d, e, f2; + switch (b) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), qLd(this.Ab, a, c2); + case 5: + !!this.Cb && (c2 = (e = this.Db >> 16, e >= 0 ? M1d(this, c2) : this.Cb.Th(this, -1 - e, null, c2))); + return xvd(this, a, 5, c2); + } + return f2 = RD(vYd((d = RD(Ywd(this, 16), 29), !d ? (JTd(), tTd) : d), b), 69), f2.wk().zk(this, Wwd(this), b - AYd((JTd(), tTd)), a, c2); + }; + _2.Uh = function V1d(a, b, c2) { + var d, e; + switch (b) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), rLd(this.Ab, a, c2); + case 5: + return xvd(this, null, 5, c2); + } + return e = RD(vYd((d = RD(Ywd(this, 16), 29), !d ? (JTd(), tTd) : d), b), 69), e.wk().Ak(this, Wwd(this), b - AYd((JTd(), tTd)), a, c2); + }; + _2.Wh = function W1d(a) { + var b; + switch (a) { + case 0: + return !!this.Ab && this.Ab.i != 0; + case 1: + return this.zb != null; + case 2: + return this.d != 0; + case 3: + return !!this.b; + case 4: + return this.c != null; + case 5: + return !!(this.Db >> 16 == 5 ? RD(this.Cb, 685) : null); + } + return Avd(this, a - AYd((JTd(), tTd)), vYd((b = RD(Ywd(this, 16), 29), !b ? tTd : b), a)); + }; + _2.bi = function X1d(a, b) { + var c2; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + YGd(this.Ab, RD(b, 16)); + return; + case 1: + PAd(this, WD(b)); + return; + case 2: + Q1d(this, RD(b, 17).a); + return; + case 3: + O1d(this, RD(b, 2039)); + return; + case 4: + P1d(this, WD(b)); + return; + } + Bvd(this, a - AYd((JTd(), tTd)), vYd((c2 = RD(Ywd(this, 16), 29), !c2 ? tTd : c2), a), b); + }; + _2.ii = function Y1d() { + return JTd(), tTd; + }; + _2.ki = function Z1d(a) { + var b; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + return; + case 1: + PAd(this, null); + return; + case 2: + Q1d(this, 0); + return; + case 3: + O1d(this, null); + return; + case 4: + P1d(this, null); + return; + } + Cvd(this, a - AYd((JTd(), tTd)), vYd((b = RD(Ywd(this, 16), 29), !b ? tTd : b), a)); + }; + _2.Ib = function _1d() { + var a; + return a = this.c, a == null ? this.zb : a; + }; + _2.b = null; + _2.c = null; + _2.d = 0; + sfb(SHe, "EEnumLiteralImpl", 582); + var h8 = ufb(SHe, "EFactoryImpl/InternalEDateTimeFormat"); + feb(499, 1, { 2114: 1 }, c2d); + sfb(SHe, "EFactoryImpl/1ClientInternalEDateTimeFormat", 499); + feb(248, 120, { 110: 1, 94: 1, 93: 1, 89: 1, 58: 1, 114: 1, 54: 1, 99: 1, 248: 1, 119: 1, 120: 1 }, s2d); + _2.Ch = function t2d(a, b, c2) { + var d; + c2 = xvd(this, a, b, c2); + if (!!this.e && ZD(a, 179)) { + d = k2d(this, this.e); + d != this.c && (c2 = o2d(this, d, c2)); + } + return c2; + }; + _2.Lh = function u2d(a, b, c2) { + var d; + switch (a) { + case 0: + return this.f; + case 1: + return !this.d && (this.d = new XZd(o7, this, 1)), this.d; + case 2: + if (b) + return i2d(this); + return this.c; + case 3: + return this.b; + case 4: + return this.e; + case 5: + if (b) + return h2d(this); + return this.a; + } + return zvd(this, a - AYd((JTd(), vTd)), vYd((d = RD(Ywd(this, 16), 29), !d ? vTd : d), a), b, c2); + }; + _2.Uh = function v2d(a, b, c2) { + var d, e; + switch (b) { + case 0: + return g2d(this, null, c2); + case 1: + return !this.d && (this.d = new XZd(o7, this, 1)), rLd(this.d, a, c2); + case 3: + return e2d(this, null, c2); + } + return e = RD(vYd((d = RD(Ywd(this, 16), 29), !d ? (JTd(), vTd) : d), b), 69), e.wk().Ak(this, Wwd(this), b - AYd((JTd(), vTd)), a, c2); + }; + _2.Wh = function w2d(a) { + var b; + switch (a) { + case 0: + return !!this.f; + case 1: + return !!this.d && this.d.i != 0; + case 2: + return !!this.c; + case 3: + return !!this.b; + case 4: + return !!this.e; + case 5: + return !!this.a; + } + return Avd(this, a - AYd((JTd(), vTd)), vYd((b = RD(Ywd(this, 16), 29), !b ? vTd : b), a)); + }; + _2.bi = function x2d(a, b) { + var c2; + switch (a) { + case 0: + q2d(this, RD(b, 89)); + return; + case 1: + !this.d && (this.d = new XZd(o7, this, 1)); + sLd(this.d); + !this.d && (this.d = new XZd(o7, this, 1)); + YGd(this.d, RD(b, 16)); + return; + case 3: + n2d(this, RD(b, 89)); + return; + case 4: + p2d(this, RD(b, 850)); + return; + case 5: + l2d(this, RD(b, 142)); + return; + } + Bvd(this, a - AYd((JTd(), vTd)), vYd((c2 = RD(Ywd(this, 16), 29), !c2 ? vTd : c2), a), b); + }; + _2.ii = function y2d() { + return JTd(), vTd; + }; + _2.ki = function z2d(a) { + var b; + switch (a) { + case 0: + q2d(this, null); + return; + case 1: + !this.d && (this.d = new XZd(o7, this, 1)); + sLd(this.d); + return; + case 3: + n2d(this, null); + return; + case 4: + p2d(this, null); + return; + case 5: + l2d(this, null); + return; + } + Cvd(this, a - AYd((JTd(), vTd)), vYd((b = RD(Ywd(this, 16), 29), !b ? vTd : b), a)); + }; + _2.Ib = function A2d() { + var a; + a = new dib(awd(this)); + a.a += " (expression: "; + r2d(this, a); + a.a += ")"; + return a.a; + }; + var d2d; + sfb(SHe, "EGenericTypeImpl", 248); + feb(2067, 2062, uKe); + _2.Gi = function C2d(a, b) { + B2d(this, a, b); + }; + _2.Wk = function D2d(a, b) { + B2d(this, this.gc(), a); + return b; + }; + _2.$i = function E2d(a) { + return ju(this.pj(), a); + }; + _2.Ii = function F2d() { + return this.Ji(); + }; + _2.pj = function G2d() { + return new mee(this); + }; + _2.Ji = function H2d() { + return this.Ki(0); + }; + _2.Ki = function I2d(a) { + return this.pj().fd(a); + }; + _2.Xk = function J2d(a, b) { + ze(this, a, true); + return b; + }; + _2.Ti = function K2d(a, b) { + var c2, d; + d = ku(this, b); + c2 = this.fd(a); + c2.Rb(d); + return d; + }; + _2.Ui = function L2d(a, b) { + var c2; + ze(this, b, true); + c2 = this.fd(a); + c2.Rb(b); + }; + sfb(ZJe, "AbstractSequentialInternalEList", 2067); + feb(496, 2067, uKe, Q2d); + _2.$i = function R2d(a) { + return ju(this.pj(), a); + }; + _2.Ii = function S2d() { + if (this.b == null) { + return j3d(), j3d(), i3d; + } + return this.sl(); + }; + _2.pj = function T2d() { + return new Whe(this.a, this.b); + }; + _2.Ji = function U2d() { + if (this.b == null) { + return j3d(), j3d(), i3d; + } + return this.sl(); + }; + _2.Ki = function V2d(a) { + var b, c2; + if (this.b == null) { + if (a < 0 || a > 1) { + throw Adb(new veb(HJe + a + ", size=0")); + } + return j3d(), j3d(), i3d; + } + c2 = this.sl(); + for (b = 0; b < a; ++b) { + k3d(c2); + } + return c2; + }; + _2.dc = function W2d() { + var a, b, c2, d, e, f2; + if (this.b != null) { + for (c2 = 0; c2 < this.b.length; ++c2) { + a = this.b[c2]; + if (!this.vl() || this.a.Xh(a)) { + f2 = this.a.Nh(a, false); + nke(); + if (RD(a, 69).xk()) { + b = RD(f2, 160); + for (d = 0, e = b.gc(); d < e; ++d) { + if (O2d(b.Tl(d)) && b.Ul(d) != null) { + return false; + } + } + } else if (a.Jk()) { + if (!RD(f2, 16).dc()) { + return false; + } + } else if (f2 != null) { + return false; + } + } + } + } + return true; + }; + _2.Kc = function X2d() { + return P2d(this); + }; + _2.fd = function Y2d(a) { + var b, c2; + if (this.b == null) { + if (a != 0) { + throw Adb(new veb(HJe + a + ", size=0")); + } + return j3d(), j3d(), i3d; + } + c2 = this.ul() ? this.tl() : this.sl(); + for (b = 0; b < a; ++b) { + k3d(c2); + } + return c2; + }; + _2.Ti = function Z2d(a, b) { + throw Adb(new jib()); + }; + _2.Ui = function $2d(a, b) { + throw Adb(new jib()); + }; + _2.sl = function _2d() { + return new p3d(this.a, this.b); + }; + _2.tl = function a3d() { + return new D3d(this.a, this.b); + }; + _2.ul = function b3d() { + return true; + }; + _2.gc = function c3d() { + var a, b, c2, d, e, f2, g; + e = 0; + if (this.b != null) { + for (c2 = 0; c2 < this.b.length; ++c2) { + a = this.b[c2]; + if (!this.vl() || this.a.Xh(a)) { + g = this.a.Nh(a, false); + nke(); + if (RD(a, 69).xk()) { + b = RD(g, 160); + for (d = 0, f2 = b.gc(); d < f2; ++d) { + O2d(b.Tl(d)) && b.Ul(d) != null && ++e; + } + } else + a.Jk() ? e += RD(g, 16).gc() : g != null && ++e; + } + } + } + return e; + }; + _2.vl = function d3d() { + return true; + }; + var M2d; + sfb(ZJe, "EContentsEList", 496); + feb(1177, 496, uKe, e3d); + _2.sl = function f3d() { + return new H3d(this.a, this.b); + }; + _2.tl = function g3d() { + return new F3d(this.a, this.b); + }; + _2.vl = function h3d() { + return false; + }; + sfb(SHe, "ENamedElementImpl/1", 1177); + feb(287, 1, vKe, p3d); + _2.Nb = function s3d(a) { + Ztb(this, a); + }; + _2.Rb = function q3d(a) { + throw Adb(new jib()); + }; + _2.wl = function r3d(a) { + if (this.g != 0 || !!this.e) { + throw Adb(new dgb("Iterator already in use or already filtered")); + } + this.e = a; + }; + _2.Ob = function t3d() { + var a, b, c2, d, e, f2; + switch (this.g) { + case 3: + case 2: { + return true; + } + case 1: { + return false; + } + case -3: { + !this.p ? ++this.n : this.p.Pb(); + } + default: { + if (!this.k || (!this.p ? !l3d(this) : !m3d(this, this.p))) { + while (this.d < this.c.length) { + b = this.c[this.d++]; + if ((!this.e || b.pk() != C4 || b.Lj() != 0) && (!this.vl() || this.b.Xh(b))) { + f2 = this.b.Nh(b, this.ul()); + this.f = (nke(), RD(b, 69).xk()); + if (this.f || b.Jk()) { + if (this.ul()) { + d = RD(f2, 15); + this.k = d; + } else { + d = RD(f2, 71); + this.k = this.j = d; + } + if (ZD(this.k, 59)) { + this.p = null; + this.o = this.k.gc(); + this.n = 0; + } else { + this.p = !this.j ? this.k.ed() : this.j.Ji(); + } + if (!this.p ? l3d(this) : m3d(this, this.p)) { + e = !this.p ? !this.j ? this.k.Xb(this.n++) : this.j.$i(this.n++) : this.p.Pb(); + if (this.f) { + a = RD(e, 76); + a.Lk(); + c2 = a.md(); + this.i = c2; + } else { + c2 = e; + this.i = c2; + } + this.g = 3; + return true; + } + } else if (f2 != null) { + this.k = null; + this.p = null; + c2 = f2; + this.i = c2; + this.g = 2; + return true; + } + } + } + this.k = null; + this.p = null; + this.f = false; + this.g = 1; + return false; + } else { + e = !this.p ? !this.j ? this.k.Xb(this.n++) : this.j.$i(this.n++) : this.p.Pb(); + if (this.f) { + a = RD(e, 76); + a.Lk(); + c2 = a.md(); + this.i = c2; + } else { + c2 = e; + this.i = c2; + } + this.g = 3; + return true; + } + } + } + }; + _2.Sb = function u3d() { + var a, b, c2, d, e, f2; + switch (this.g) { + case -3: + case -2: { + return true; + } + case -1: { + return false; + } + case 3: { + !this.p ? --this.n : this.p.Ub(); + } + default: { + if (!this.k || (!this.p ? !n3d(this) : !o3d(this, this.p))) { + while (this.d > 0) { + b = this.c[--this.d]; + if ((!this.e || b.pk() != C4 || b.Lj() != 0) && (!this.vl() || this.b.Xh(b))) { + f2 = this.b.Nh(b, this.ul()); + this.f = (nke(), RD(b, 69).xk()); + if (this.f || b.Jk()) { + if (this.ul()) { + d = RD(f2, 15); + this.k = d; + } else { + d = RD(f2, 71); + this.k = this.j = d; + } + if (ZD(this.k, 59)) { + this.o = this.k.gc(); + this.n = this.o; + } else { + this.p = !this.j ? this.k.fd(this.k.gc()) : this.j.Ki(this.k.gc()); + } + if (!this.p ? n3d(this) : o3d(this, this.p)) { + e = !this.p ? !this.j ? this.k.Xb(--this.n) : this.j.$i(--this.n) : this.p.Ub(); + if (this.f) { + a = RD(e, 76); + a.Lk(); + c2 = a.md(); + this.i = c2; + } else { + c2 = e; + this.i = c2; + } + this.g = -3; + return true; + } + } else if (f2 != null) { + this.k = null; + this.p = null; + c2 = f2; + this.i = c2; + this.g = -2; + return true; + } + } + } + this.k = null; + this.p = null; + this.g = -1; + return false; + } else { + e = !this.p ? !this.j ? this.k.Xb(--this.n) : this.j.$i(--this.n) : this.p.Ub(); + if (this.f) { + a = RD(e, 76); + a.Lk(); + c2 = a.md(); + this.i = c2; + } else { + c2 = e; + this.i = c2; + } + this.g = -3; + return true; + } + } + } + }; + _2.Pb = function v3d() { + return k3d(this); + }; + _2.Tb = function w3d() { + return this.a; + }; + _2.Ub = function x3d() { + var a; + if (this.g < -1 || this.Sb()) { + --this.a; + this.g = 0; + a = this.i; + this.Sb(); + return a; + } else { + throw Adb(new Dvb()); + } + }; + _2.Vb = function y3d() { + return this.a - 1; + }; + _2.Qb = function z3d() { + throw Adb(new jib()); + }; + _2.ul = function A3d() { + return false; + }; + _2.Wb = function B3d(a) { + throw Adb(new jib()); + }; + _2.vl = function C3d() { + return true; + }; + _2.a = 0; + _2.d = 0; + _2.f = false; + _2.g = 0; + _2.n = 0; + _2.o = 0; + var i3d; + sfb(ZJe, "EContentsEList/FeatureIteratorImpl", 287); + feb(711, 287, vKe, D3d); + _2.ul = function E3d() { + return true; + }; + sfb(ZJe, "EContentsEList/ResolvingFeatureIteratorImpl", 711); + feb(1178, 711, vKe, F3d); + _2.vl = function G3d() { + return false; + }; + sfb(SHe, "ENamedElementImpl/1/1", 1178); + feb(1179, 287, vKe, H3d); + _2.vl = function I3d() { + return false; + }; + sfb(SHe, "ENamedElementImpl/1/2", 1179); + feb(39, 152, GJe, L3d, M3d, N3d, O3d, P3d, Q3d, R3d, S3d, T3d, U3d, V3d, W3d, X3d, Y3d, Z3d, $3d, _3d, a4d, b4d, c4d, d4d, e4d, f4d, g4d, h4d); + _2.Kj = function i4d() { + return K3d(this); + }; + _2.Rj = function j4d() { + var a; + a = K3d(this); + if (a) { + return a.ik(); + } + return null; + }; + _2.hj = function k4d(a) { + this.b == -1 && !!this.a && (this.b = this.c.Hh(this.a.Lj(), this.a.pk())); + return this.c.yh(this.b, a); + }; + _2.jj = function l4d() { + return this.c; + }; + _2.Sj = function m4d() { + var a; + a = K3d(this); + if (a) { + return a.tk(); + } + return false; + }; + _2.b = -1; + sfb(SHe, "ENotificationImpl", 39); + feb(411, 292, { 110: 1, 94: 1, 93: 1, 155: 1, 197: 1, 58: 1, 62: 1, 114: 1, 481: 1, 54: 1, 99: 1, 158: 1, 411: 1, 292: 1, 119: 1, 120: 1 }, q4d); + _2.Ah = function r4d(a) { + return n4d(this, a); + }; + _2.Lh = function s4d(a, b, c2) { + var d, e, f2; + switch (a) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), this.Ab; + case 1: + return this.zb; + case 2: + return Geb(), (this.Bb & 256) != 0 ? true : false; + case 3: + return Geb(), (this.Bb & 512) != 0 ? true : false; + case 4: + return sgb(this.s); + case 5: + return sgb(this.t); + case 6: + return Geb(), f2 = this.t, f2 > 1 || f2 == -1 ? true : false; + case 7: + return Geb(), e = this.s, e >= 1 ? true : false; + case 8: + if (b) + return WVd(this); + return this.r; + case 9: + return this.q; + case 10: + return this.Db >> 16 == 10 ? RD(this.Cb, 29) : null; + case 11: + return !this.d && (this.d = new iie(z7, this, 11)), this.d; + case 12: + return !this.c && (this.c = new C5d(u7, this, 12, 10)), this.c; + case 13: + return !this.a && (this.a = new F4d(this, this)), this.a; + case 14: + return o4d(this); + } + return zvd(this, a - AYd((JTd(), ATd)), vYd((d = RD(Ywd(this, 16), 29), !d ? ATd : d), a), b, c2); + }; + _2.Sh = function t4d(a, b, c2) { + var d, e, f2; + switch (b) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), qLd(this.Ab, a, c2); + case 10: + !!this.Cb && (c2 = (e = this.Db >> 16, e >= 0 ? n4d(this, c2) : this.Cb.Th(this, -1 - e, null, c2))); + return xvd(this, a, 10, c2); + case 12: + return !this.c && (this.c = new C5d(u7, this, 12, 10)), qLd(this.c, a, c2); + } + return f2 = RD(vYd((d = RD(Ywd(this, 16), 29), !d ? (JTd(), ATd) : d), b), 69), f2.wk().zk(this, Wwd(this), b - AYd((JTd(), ATd)), a, c2); + }; + _2.Uh = function u4d(a, b, c2) { + var d, e; + switch (b) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), rLd(this.Ab, a, c2); + case 9: + return VVd(this, c2); + case 10: + return xvd(this, null, 10, c2); + case 11: + return !this.d && (this.d = new iie(z7, this, 11)), rLd(this.d, a, c2); + case 12: + return !this.c && (this.c = new C5d(u7, this, 12, 10)), rLd(this.c, a, c2); + case 14: + return rLd(o4d(this), a, c2); + } + return e = RD(vYd((d = RD(Ywd(this, 16), 29), !d ? (JTd(), ATd) : d), b), 69), e.wk().Ak(this, Wwd(this), b - AYd((JTd(), ATd)), a, c2); + }; + _2.Wh = function v4d(a) { + var b, c2, d; + switch (a) { + case 0: + return !!this.Ab && this.Ab.i != 0; + case 1: + return this.zb != null; + case 2: + return (this.Bb & 256) == 0; + case 3: + return (this.Bb & 512) == 0; + case 4: + return this.s != 0; + case 5: + return this.t != 1; + case 6: + return d = this.t, d > 1 || d == -1; + case 7: + return c2 = this.s, c2 >= 1; + case 8: + return !!this.r && !this.q.e && j2d(this.q).i == 0; + case 9: + return !!this.q && !(!!this.r && !this.q.e && j2d(this.q).i == 0); + case 10: + return !!(this.Db >> 16 == 10 ? RD(this.Cb, 29) : null); + case 11: + return !!this.d && this.d.i != 0; + case 12: + return !!this.c && this.c.i != 0; + case 13: + return !!this.a && o4d(this.a.a).i != 0 && !(!!this.b && o5d(this.b)); + case 14: + return !!this.b && o5d(this.b); + } + return Avd(this, a - AYd((JTd(), ATd)), vYd((b = RD(Ywd(this, 16), 29), !b ? ATd : b), a)); + }; + _2.bi = function w4d(a, b) { + var c2, d; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + YGd(this.Ab, RD(b, 16)); + return; + case 1: + PAd(this, WD(b)); + return; + case 2: + _Vd(this, Heb(TD(b))); + return; + case 3: + aWd(this, Heb(TD(b))); + return; + case 4: + $Vd(this, RD(b, 17).a); + return; + case 5: + bWd(this, RD(b, 17).a); + return; + case 8: + YVd(this, RD(b, 142)); + return; + case 9: + d = XVd(this, RD(b, 89), null); + !!d && d.oj(); + return; + case 11: + !this.d && (this.d = new iie(z7, this, 11)); + sLd(this.d); + !this.d && (this.d = new iie(z7, this, 11)); + YGd(this.d, RD(b, 16)); + return; + case 12: + !this.c && (this.c = new C5d(u7, this, 12, 10)); + sLd(this.c); + !this.c && (this.c = new C5d(u7, this, 12, 10)); + YGd(this.c, RD(b, 16)); + return; + case 13: + !this.a && (this.a = new F4d(this, this)); + VJd(this.a); + !this.a && (this.a = new F4d(this, this)); + YGd(this.a, RD(b, 16)); + return; + case 14: + sLd(o4d(this)); + YGd(o4d(this), RD(b, 16)); + return; + } + Bvd(this, a - AYd((JTd(), ATd)), vYd((c2 = RD(Ywd(this, 16), 29), !c2 ? ATd : c2), a), b); + }; + _2.ii = function x4d() { + return JTd(), ATd; + }; + _2.ki = function y4d(a) { + var b, c2; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + return; + case 1: + PAd(this, null); + return; + case 2: + _Vd(this, true); + return; + case 3: + aWd(this, true); + return; + case 4: + $Vd(this, 0); + return; + case 5: + bWd(this, 1); + return; + case 8: + YVd(this, null); + return; + case 9: + c2 = XVd(this, null, null); + !!c2 && c2.oj(); + return; + case 11: + !this.d && (this.d = new iie(z7, this, 11)); + sLd(this.d); + return; + case 12: + !this.c && (this.c = new C5d(u7, this, 12, 10)); + sLd(this.c); + return; + case 13: + !!this.a && VJd(this.a); + return; + case 14: + !!this.b && sLd(this.b); + return; + } + Cvd(this, a - AYd((JTd(), ATd)), vYd((b = RD(Ywd(this, 16), 29), !b ? ATd : b), a)); + }; + _2.pi = function z4d() { + var a, b; + if (this.c) { + for (a = 0, b = this.c.i; a < b; ++a) { + aAd(QHd(this.c, a)); + } + } + WVd(this); + this.Bb |= 1; + }; + sfb(SHe, "EOperationImpl", 411); + feb(513, 756, tKe, F4d); + _2.qj = function I4d(a, b) { + A4d(this, a, RD(b, 142)); + }; + _2.rj = function J4d(a) { + B4d(this, RD(a, 142)); + }; + _2.xj = function P4d(a) { + var b, c2; + return b = RD(QHd(o4d(this.a), a), 89), c2 = b.c, c2 ? c2 : (JTd(), wTd); + }; + _2.Cj = function U4d(a) { + var b, c2; + return b = RD(vLd(o4d(this.a), a), 89), c2 = b.c, c2 ? c2 : (JTd(), wTd); + }; + _2.Dj = function V4d(a, b) { + return D4d(this, a, RD(b, 142)); + }; + _2.Li = function G4d() { + return false; + }; + _2.Ij = function H4d(a, b, c2, d, e) { + return null; + }; + _2.sj = function K4d() { + return new l5d(this); + }; + _2.tj = function L4d() { + sLd(o4d(this.a)); + }; + _2.uj = function M4d(a) { + return C4d(this, a); + }; + _2.vj = function N4d(a) { + var b, c2; + for (c2 = a.Kc(); c2.Ob(); ) { + b = c2.Pb(); + if (!C4d(this, b)) { + return false; + } + } + return true; + }; + _2.wj = function O4d(a) { + var b, c2, d; + if (ZD(a, 15)) { + d = RD(a, 15); + if (d.gc() == o4d(this.a).i) { + for (b = d.Kc(), c2 = new dMd(this); b.Ob(); ) { + if (dE(b.Pb()) !== dE(bMd(c2))) { + return false; + } + } + return true; + } + } + return false; + }; + _2.yj = function Q4d() { + var a, b, c2, d, e; + c2 = 1; + for (b = new dMd(o4d(this.a)); b.e != b.i.gc(); ) { + a = RD(bMd(b), 89); + d = (e = a.c, e ? e : (JTd(), wTd)); + c2 = 31 * c2 + (!d ? 0 : tb(d)); + } + return c2; + }; + _2.zj = function R4d(a) { + var b, c2, d, e; + d = 0; + for (c2 = new dMd(o4d(this.a)); c2.e != c2.i.gc(); ) { + b = RD(bMd(c2), 89); + if (dE(a) === dE((e = b.c, e ? e : (JTd(), wTd)))) { + return d; + } + ++d; + } + return -1; + }; + _2.Aj = function S4d() { + return o4d(this.a).i == 0; + }; + _2.Bj = function T4d() { + return null; + }; + _2.Ej = function W4d() { + return o4d(this.a).i; + }; + _2.Fj = function X4d() { + var a, b, c2, d, e, f2; + f2 = o4d(this.a).i; + e = $C(jJ, rve, 1, f2, 5, 1); + c2 = 0; + for (b = new dMd(o4d(this.a)); b.e != b.i.gc(); ) { + a = RD(bMd(b), 89); + e[c2++] = (d = a.c, d ? d : (JTd(), wTd)); + } + return e; + }; + _2.Gj = function Y4d(a) { + var b, c2, d, e, f2, g, h; + h = o4d(this.a).i; + if (a.length < h) { + e = IMd(rb(a).c, h); + a = e; + } + a.length > h && bD(a, h, null); + d = 0; + for (c2 = new dMd(o4d(this.a)); c2.e != c2.i.gc(); ) { + b = RD(bMd(c2), 89); + f2 = (g = b.c, g ? g : (JTd(), wTd)); + bD(a, d++, f2); + } + return a; + }; + _2.Hj = function Z4d() { + var a, b, c2, d, e; + e = new Qhb(); + e.a += "["; + a = o4d(this.a); + for (b = 0, d = o4d(this.a).i; b < d; ) { + Nhb(e, Ghb((c2 = RD(QHd(a, b), 89).c, c2 ? c2 : (JTd(), wTd)))); + ++b < d && (e.a += pve, e); + } + e.a += "]"; + return e.a; + }; + _2.Jj = function $4d(a) { + }; + _2.Lj = function _4d() { + return 13; + }; + _2.kl = function a5d() { + return true; + }; + _2.Mj = function b5d() { + return false; + }; + _2.ll = function c5d() { + return false; + }; + _2.ml = function d5d() { + return false; + }; + _2.nl = function e5d() { + return true; + }; + _2.al = function f5d() { + return false; + }; + _2.ol = function g5d() { + return true; + }; + _2.fk = function h5d(a) { + return ZD(a, 142); + }; + _2.Qj = function i5d() { + return p4d(this.a); + }; + _2.Si = function j5d() { + return true; + }; + _2.Yi = function k5d() { + return true; + }; + sfb(SHe, "EOperationImpl/1", 513); + feb(1376, 2062, kwe, l5d); + _2.fd = function m5d(a) { + return ZGd(this.a, a); + }; + _2.gc = function n5d() { + return o4d(this.a.a).i; + }; + sfb(SHe, "EOperationImpl/1/1", 1376); + feb(1377, 555, oKe, s5d); + _2.Ti = function w5d(a, b) { + var c2, d; + return c2 = RD(uLd(this, a, b), 89), Mvd(this.e) && eZd(this, new c4d(this.a, 7, (JTd(), BTd), sgb(b), (d = c2.c, d ? d : wTd), a)), c2; + }; + _2.Uj = function x5d(a, b) { + return p5d(this, RD(a, 89), b); + }; + _2.Vj = function y5d(a, b) { + return q5d(this, RD(a, 89), b); + }; + _2.Wj = function z5d(a, b, c2) { + return r5d(this, RD(a, 89), RD(b, 89), c2); + }; + _2.Ij = function t5d(a, b, c2, d, e) { + switch (a) { + case 3: { + return dZd(this, a, b, c2, d, this.i > 1); + } + case 5: { + return dZd(this, a, b, c2, d, this.i - RD(c2, 15).gc() > 0); + } + default: { + return new P3d(this.e, a, this.c, b, c2, d, true); + } + } + }; + _2.Tj = function u5d() { + return true; + }; + _2.Qj = function v5d() { + return o5d(this); + }; + _2.Gk = function A5d() { + sLd(this); + }; + sfb(SHe, "EOperationImpl/2", 1377); + feb(507, 1, { 2037: 1, 507: 1 }, B5d); + sfb(SHe, "EPackageImpl/1", 507); + feb(14, 83, oKe, C5d); + _2.il = function D5d() { + return this.d; + }; + _2.jl = function E5d() { + return this.b; + }; + _2.ml = function F5d() { + return true; + }; + _2.b = 0; + sfb(ZJe, "EObjectContainmentWithInverseEList", 14); + feb(365, 14, oKe, G5d); + _2.nl = function H5d() { + return true; + }; + _2.Wi = function I5d(a, b) { + return gZd(this, a, RD(b, 58)); + }; + sfb(ZJe, "EObjectContainmentWithInverseEList/Resolving", 365); + feb(308, 365, oKe, J5d); + _2.Ni = function K5d() { + this.a.tb = null; + }; + sfb(SHe, "EPackageImpl/2", 308); + feb(1278, 1, {}, L5d); + sfb(SHe, "EPackageImpl/3", 1278); + feb(733, 45, Hxe, O5d); + _2._b = function P5d(a) { + return bE(a) ? Yjb(this, a) : !!qtb(this.f, a); + }; + sfb(SHe, "EPackageRegistryImpl", 733); + feb(518, 292, { 110: 1, 94: 1, 93: 1, 155: 1, 197: 1, 58: 1, 2116: 1, 114: 1, 481: 1, 54: 1, 99: 1, 158: 1, 518: 1, 292: 1, 119: 1, 120: 1 }, R5d); + _2.Ah = function S5d(a) { + return Q5d(this, a); + }; + _2.Lh = function T5d(a, b, c2) { + var d, e, f2; + switch (a) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), this.Ab; + case 1: + return this.zb; + case 2: + return Geb(), (this.Bb & 256) != 0 ? true : false; + case 3: + return Geb(), (this.Bb & 512) != 0 ? true : false; + case 4: + return sgb(this.s); + case 5: + return sgb(this.t); + case 6: + return Geb(), f2 = this.t, f2 > 1 || f2 == -1 ? true : false; + case 7: + return Geb(), e = this.s, e >= 1 ? true : false; + case 8: + if (b) + return WVd(this); + return this.r; + case 9: + return this.q; + case 10: + return this.Db >> 16 == 10 ? RD(this.Cb, 62) : null; + } + return zvd(this, a - AYd((JTd(), DTd)), vYd((d = RD(Ywd(this, 16), 29), !d ? DTd : d), a), b, c2); + }; + _2.Sh = function U5d(a, b, c2) { + var d, e, f2; + switch (b) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), qLd(this.Ab, a, c2); + case 10: + !!this.Cb && (c2 = (e = this.Db >> 16, e >= 0 ? Q5d(this, c2) : this.Cb.Th(this, -1 - e, null, c2))); + return xvd(this, a, 10, c2); + } + return f2 = RD(vYd((d = RD(Ywd(this, 16), 29), !d ? (JTd(), DTd) : d), b), 69), f2.wk().zk(this, Wwd(this), b - AYd((JTd(), DTd)), a, c2); + }; + _2.Uh = function V5d(a, b, c2) { + var d, e; + switch (b) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), rLd(this.Ab, a, c2); + case 9: + return VVd(this, c2); + case 10: + return xvd(this, null, 10, c2); + } + return e = RD(vYd((d = RD(Ywd(this, 16), 29), !d ? (JTd(), DTd) : d), b), 69), e.wk().Ak(this, Wwd(this), b - AYd((JTd(), DTd)), a, c2); + }; + _2.Wh = function W5d(a) { + var b, c2, d; + switch (a) { + case 0: + return !!this.Ab && this.Ab.i != 0; + case 1: + return this.zb != null; + case 2: + return (this.Bb & 256) == 0; + case 3: + return (this.Bb & 512) == 0; + case 4: + return this.s != 0; + case 5: + return this.t != 1; + case 6: + return d = this.t, d > 1 || d == -1; + case 7: + return c2 = this.s, c2 >= 1; + case 8: + return !!this.r && !this.q.e && j2d(this.q).i == 0; + case 9: + return !!this.q && !(!!this.r && !this.q.e && j2d(this.q).i == 0); + case 10: + return !!(this.Db >> 16 == 10 ? RD(this.Cb, 62) : null); + } + return Avd(this, a - AYd((JTd(), DTd)), vYd((b = RD(Ywd(this, 16), 29), !b ? DTd : b), a)); + }; + _2.ii = function X5d() { + return JTd(), DTd; + }; + sfb(SHe, "EParameterImpl", 518); + feb(102, 462, { 110: 1, 94: 1, 93: 1, 155: 1, 197: 1, 58: 1, 19: 1, 179: 1, 69: 1, 114: 1, 481: 1, 54: 1, 99: 1, 158: 1, 102: 1, 462: 1, 292: 1, 119: 1, 120: 1, 692: 1 }, d6d); + _2.Lh = function e6d(a, b, c2) { + var d, e, f2, g; + switch (a) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), this.Ab; + case 1: + return this.zb; + case 2: + return Geb(), (this.Bb & 256) != 0 ? true : false; + case 3: + return Geb(), (this.Bb & 512) != 0 ? true : false; + case 4: + return sgb(this.s); + case 5: + return sgb(this.t); + case 6: + return Geb(), g = this.t, g > 1 || g == -1 ? true : false; + case 7: + return Geb(), e = this.s, e >= 1 ? true : false; + case 8: + if (b) + return WVd(this); + return this.r; + case 9: + return this.q; + case 10: + return Geb(), (this.Bb & gwe) != 0 ? true : false; + case 11: + return Geb(), (this.Bb & cKe) != 0 ? true : false; + case 12: + return Geb(), (this.Bb & qxe) != 0 ? true : false; + case 13: + return this.j; + case 14: + return tWd(this); + case 15: + return Geb(), (this.Bb & bKe) != 0 ? true : false; + case 16: + return Geb(), (this.Bb & Ove) != 0 ? true : false; + case 17: + return uWd(this); + case 18: + return Geb(), (this.Bb & QHe) != 0 ? true : false; + case 19: + return Geb(), f2 = Z5d(this), !!f2 && (f2.Bb & QHe) != 0 ? true : false; + case 20: + return Geb(), (this.Bb & txe) != 0 ? true : false; + case 21: + if (b) + return Z5d(this); + return this.b; + case 22: + if (b) + return $5d(this); + return Y5d(this); + case 23: + return !this.a && (this.a = new zie(g7, this, 23)), this.a; + } + return zvd(this, a - AYd((JTd(), ETd)), vYd((d = RD(Ywd(this, 16), 29), !d ? ETd : d), a), b, c2); + }; + _2.Wh = function f6d(a) { + var b, c2, d, e; + switch (a) { + case 0: + return !!this.Ab && this.Ab.i != 0; + case 1: + return this.zb != null; + case 2: + return (this.Bb & 256) == 0; + case 3: + return (this.Bb & 512) == 0; + case 4: + return this.s != 0; + case 5: + return this.t != 1; + case 6: + return e = this.t, e > 1 || e == -1; + case 7: + return c2 = this.s, c2 >= 1; + case 8: + return !!this.r && !this.q.e && j2d(this.q).i == 0; + case 9: + return !!this.q && !(!!this.r && !this.q.e && j2d(this.q).i == 0); + case 10: + return (this.Bb & gwe) == 0; + case 11: + return (this.Bb & cKe) != 0; + case 12: + return (this.Bb & qxe) != 0; + case 13: + return this.j != null; + case 14: + return tWd(this) != null; + case 15: + return (this.Bb & bKe) != 0; + case 16: + return (this.Bb & Ove) != 0; + case 17: + return !!uWd(this); + case 18: + return (this.Bb & QHe) != 0; + case 19: + return d = Z5d(this), !!d && (d.Bb & QHe) != 0; + case 20: + return (this.Bb & txe) == 0; + case 21: + return !!this.b; + case 22: + return !!Y5d(this); + case 23: + return !!this.a && this.a.i != 0; + } + return Avd(this, a - AYd((JTd(), ETd)), vYd((b = RD(Ywd(this, 16), 29), !b ? ETd : b), a)); + }; + _2.bi = function g6d(a, b) { + var c2, d; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + YGd(this.Ab, RD(b, 16)); + return; + case 1: + CWd(this, WD(b)); + return; + case 2: + _Vd(this, Heb(TD(b))); + return; + case 3: + aWd(this, Heb(TD(b))); + return; + case 4: + $Vd(this, RD(b, 17).a); + return; + case 5: + bWd(this, RD(b, 17).a); + return; + case 8: + YVd(this, RD(b, 142)); + return; + case 9: + d = XVd(this, RD(b, 89), null); + !!d && d.oj(); + return; + case 10: + xWd(this, Heb(TD(b))); + return; + case 11: + FWd(this, Heb(TD(b))); + return; + case 12: + DWd(this, Heb(TD(b))); + return; + case 13: + yWd(this, WD(b)); + return; + case 15: + EWd(this, Heb(TD(b))); + return; + case 16: + AWd(this, Heb(TD(b))); + return; + case 18: + _5d(this, Heb(TD(b))); + return; + case 20: + c6d(this, Heb(TD(b))); + return; + case 21: + b6d(this, RD(b, 19)); + return; + case 23: + !this.a && (this.a = new zie(g7, this, 23)); + sLd(this.a); + !this.a && (this.a = new zie(g7, this, 23)); + YGd(this.a, RD(b, 16)); + return; + } + Bvd(this, a - AYd((JTd(), ETd)), vYd((c2 = RD(Ywd(this, 16), 29), !c2 ? ETd : c2), a), b); + }; + _2.ii = function h6d() { + return JTd(), ETd; + }; + _2.ki = function i6d(a) { + var b, c2; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + return; + case 1: + ZD(this.Cb, 90) && v$d(yYd(RD(this.Cb, 90)), 4); + PAd(this, null); + return; + case 2: + _Vd(this, true); + return; + case 3: + aWd(this, true); + return; + case 4: + $Vd(this, 0); + return; + case 5: + bWd(this, 1); + return; + case 8: + YVd(this, null); + return; + case 9: + c2 = XVd(this, null, null); + !!c2 && c2.oj(); + return; + case 10: + xWd(this, true); + return; + case 11: + FWd(this, false); + return; + case 12: + DWd(this, false); + return; + case 13: + this.i = null; + zWd(this, null); + return; + case 15: + EWd(this, false); + return; + case 16: + AWd(this, false); + return; + case 18: + a6d(this, false); + ZD(this.Cb, 90) && v$d(yYd(RD(this.Cb, 90)), 2); + return; + case 20: + c6d(this, true); + return; + case 21: + b6d(this, null); + return; + case 23: + !this.a && (this.a = new zie(g7, this, 23)); + sLd(this.a); + return; + } + Cvd(this, a - AYd((JTd(), ETd)), vYd((b = RD(Ywd(this, 16), 29), !b ? ETd : b), a)); + }; + _2.pi = function j6d() { + $5d(this); + Afe(Qee((lke(), jke), this)); + WVd(this); + this.Bb |= 1; + }; + _2.uk = function k6d() { + return Z5d(this); + }; + _2._k = function l6d() { + var a; + return a = Z5d(this), !!a && (a.Bb & QHe) != 0; + }; + _2.al = function m6d() { + return (this.Bb & QHe) != 0; + }; + _2.bl = function n6d() { + return (this.Bb & txe) != 0; + }; + _2.Yk = function o6d(a, b) { + this.c = null; + return ZVd(this, a, b); + }; + _2.Ib = function p6d() { + var a; + if ((this.Db & 64) != 0) + return GWd(this); + a = new Shb(GWd(this)); + a.a += " (containment: "; + Ohb(a, (this.Bb & QHe) != 0); + a.a += ", resolveProxies: "; + Ohb(a, (this.Bb & txe) != 0); + a.a += ")"; + return a.a; + }; + sfb(SHe, "EReferenceImpl", 102); + feb(561, 120, { 110: 1, 44: 1, 94: 1, 93: 1, 136: 1, 58: 1, 114: 1, 54: 1, 99: 1, 561: 1, 119: 1, 120: 1 }, v6d); + _2.Fb = function B6d(a) { + return this === a; + }; + _2.ld = function D6d() { + return this.b; + }; + _2.md = function E6d() { + return this.c; + }; + _2.Hb = function F6d() { + return kFb(this); + }; + _2.Di = function H6d(a) { + q6d(this, WD(a)); + }; + _2.nd = function I6d(a) { + return u6d(this, WD(a)); + }; + _2.Lh = function w6d(a, b, c2) { + var d; + switch (a) { + case 0: + return this.b; + case 1: + return this.c; + } + return zvd(this, a - AYd((JTd(), FTd)), vYd((d = RD(Ywd(this, 16), 29), !d ? FTd : d), a), b, c2); + }; + _2.Wh = function x6d(a) { + var b; + switch (a) { + case 0: + return this.b != null; + case 1: + return this.c != null; + } + return Avd(this, a - AYd((JTd(), FTd)), vYd((b = RD(Ywd(this, 16), 29), !b ? FTd : b), a)); + }; + _2.bi = function y6d(a, b) { + var c2; + switch (a) { + case 0: + r6d(this, WD(b)); + return; + case 1: + t6d(this, WD(b)); + return; + } + Bvd(this, a - AYd((JTd(), FTd)), vYd((c2 = RD(Ywd(this, 16), 29), !c2 ? FTd : c2), a), b); + }; + _2.ii = function z6d() { + return JTd(), FTd; + }; + _2.ki = function A6d(a) { + var b; + switch (a) { + case 0: + s6d(this, null); + return; + case 1: + t6d(this, null); + return; + } + Cvd(this, a - AYd((JTd(), FTd)), vYd((b = RD(Ywd(this, 16), 29), !b ? FTd : b), a)); + }; + _2.Bi = function C6d() { + var a; + if (this.a == -1) { + a = this.b; + this.a = a == null ? 0 : ohb(a); + } + return this.a; + }; + _2.Ci = function G6d(a) { + this.a = a; + }; + _2.Ib = function J6d() { + var a; + if ((this.Db & 64) != 0) + return awd(this); + a = new Shb(awd(this)); + a.a += " (key: "; + Nhb(a, this.b); + a.a += ", value: "; + Nhb(a, this.c); + a.a += ")"; + return a.a; + }; + _2.a = -1; + _2.b = null; + _2.c = null; + var C8 = sfb(SHe, "EStringToStringMapEntryImpl", 561); + var Ibb = ufb(ZJe, "FeatureMap/Entry/Internal"); + feb(576, 1, wKe); + _2.xl = function M6d(a) { + return this.yl(RD(a, 54)); + }; + _2.yl = function N6d(a) { + return this.xl(a); + }; + _2.Fb = function O6d(a) { + var b, c2; + if (this === a) { + return true; + } else if (ZD(a, 76)) { + b = RD(a, 76); + if (b.Lk() == this.c) { + c2 = this.md(); + return c2 == null ? b.md() == null : pb(c2, b.md()); + } else { + return false; + } + } else { + return false; + } + }; + _2.Lk = function P6d() { + return this.c; + }; + _2.Hb = function Q6d() { + var a; + a = this.md(); + return tb(this.c) ^ (a == null ? 0 : tb(a)); + }; + _2.Ib = function R6d() { + var a, b; + a = this.c; + b = BXd(a.qk()).yi(); + a.xe(); + return (b != null && b.length != 0 ? b + ":" + a.xe() : a.xe()) + "=" + this.md(); + }; + sfb(SHe, "EStructuralFeatureImpl/BasicFeatureMapEntry", 576); + feb(791, 576, wKe, U6d); + _2.yl = function V6d(a) { + return new U6d(this.c, a); + }; + _2.md = function W6d() { + return this.a; + }; + _2.zl = function X6d(a, b, c2) { + return S6d(this, a, this.a, b, c2); + }; + _2.Al = function Y6d(a, b, c2) { + return T6d(this, a, this.a, b, c2); + }; + sfb(SHe, "EStructuralFeatureImpl/ContainmentUpdatingFeatureMapEntry", 791); + feb(1350, 1, {}, Z6d); + _2.yk = function $6d(a, b, c2, d, e) { + var f2; + f2 = RD(Evd(a, this.b), 220); + return f2.Yl(this.a).Fk(d); + }; + _2.zk = function _6d(a, b, c2, d, e) { + var f2; + f2 = RD(Evd(a, this.b), 220); + return f2.Pl(this.a, d, e); + }; + _2.Ak = function a7d(a, b, c2, d, e) { + var f2; + f2 = RD(Evd(a, this.b), 220); + return f2.Ql(this.a, d, e); + }; + _2.Bk = function b7d(a, b, c2) { + var d; + d = RD(Evd(a, this.b), 220); + return d.Yl(this.a).Qj(); + }; + _2.Ck = function c7d(a, b, c2, d) { + var e; + e = RD(Evd(a, this.b), 220); + e.Yl(this.a).Wb(d); + }; + _2.Dk = function d7d(a, b, c2) { + return RD(Evd(a, this.b), 220).Yl(this.a); + }; + _2.Ek = function e7d(a, b, c2) { + var d; + d = RD(Evd(a, this.b), 220); + d.Yl(this.a).Gk(); + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateFeatureMapDelegator", 1350); + feb(91, 1, {}, g7d, h7d, i7d, j7d); + _2.yk = function k7d(a, b, c2, d, e) { + var f2; + f2 = b.li(c2); + f2 == null && b.mi(c2, f2 = f7d(this, a)); + if (!e) { + switch (this.e) { + case 50: + case 41: + return RD(f2, 597).bk(); + case 40: + return RD(f2, 220).Vl(); + } + } + return f2; + }; + _2.zk = function l7d(a, b, c2, d, e) { + var f2, g; + g = b.li(c2); + g == null && b.mi(c2, g = f7d(this, a)); + f2 = RD(g, 71).Wk(d, e); + return f2; + }; + _2.Ak = function m7d(a, b, c2, d, e) { + var f2; + f2 = b.li(c2); + f2 != null && (e = RD(f2, 71).Xk(d, e)); + return e; + }; + _2.Bk = function n7d(a, b, c2) { + var d; + d = b.li(c2); + return d != null && RD(d, 79).Qj(); + }; + _2.Ck = function o7d(a, b, c2, d) { + var e; + e = RD(b.li(c2), 79); + !e && b.mi(c2, e = f7d(this, a)); + e.Wb(d); + }; + _2.Dk = function p7d(a, b, c2) { + var d, e; + e = b.li(c2); + e == null && b.mi(c2, e = f7d(this, a)); + if (ZD(e, 79)) { + return RD(e, 79); + } else { + d = RD(b.li(c2), 15); + return new I9d(d); + } + }; + _2.Ek = function q7d(a, b, c2) { + var d; + d = RD(b.li(c2), 79); + !d && b.mi(c2, d = f7d(this, a)); + d.Gk(); + }; + _2.b = 0; + _2.e = 0; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateMany", 91); + feb(512, 1, {}); + _2.zk = function u7d(a, b, c2, d, e) { + throw Adb(new jib()); + }; + _2.Ak = function v7d(a, b, c2, d, e) { + throw Adb(new jib()); + }; + _2.Dk = function w7d(a, b, c2) { + return new x7d(this, a, b, c2); + }; + var r7d; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingle", 512); + feb(1367, 1, $Je, x7d); + _2.Fk = function y7d(a) { + return this.a.yk(this.c, this.d, this.b, a, true); + }; + _2.Qj = function z7d() { + return this.a.Bk(this.c, this.d, this.b); + }; + _2.Wb = function A7d(a) { + this.a.Ck(this.c, this.d, this.b, a); + }; + _2.Gk = function B7d() { + this.a.Ek(this.c, this.d, this.b); + }; + _2.b = 0; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingle/1", 1367); + feb(784, 512, {}, C7d); + _2.yk = function D7d(a, b, c2, d, e) { + return jwd(a, a.Ph(), a.Fh()) == this.b ? this.bl() && d ? yvd(a) : a.Ph() : null; + }; + _2.zk = function E7d(a, b, c2, d, e) { + var f2, g; + !!a.Ph() && (e = (f2 = a.Fh(), f2 >= 0 ? a.Ah(e) : a.Ph().Th(a, -1 - f2, null, e))); + g = BYd(a.Dh(), this.e); + return a.Ch(d, g, e); + }; + _2.Ak = function F7d(a, b, c2, d, e) { + var f2; + f2 = BYd(a.Dh(), this.e); + return a.Ch(null, f2, e); + }; + _2.Bk = function G7d(a, b, c2) { + var d; + d = BYd(a.Dh(), this.e); + return !!a.Ph() && a.Fh() == d; + }; + _2.Ck = function H7d(a, b, c2, d) { + var e, f2, g, h, i2; + if (d != null && !FXd(this.a, d)) { + throw Adb(new Ifb(xKe + (ZD(d, 58) ? GYd(RD(d, 58).Dh()) : ofb(rb(d))) + yKe + this.a + "'")); + } + e = a.Ph(); + g = BYd(a.Dh(), this.e); + if (dE(d) !== dE(e) || a.Fh() != g && d != null) { + if (Oje(a, RD(d, 58))) + throw Adb(new agb(UHe + a.Ib())); + i2 = null; + !!e && (i2 = (f2 = a.Fh(), f2 >= 0 ? a.Ah(i2) : a.Ph().Th(a, -1 - f2, null, i2))); + h = RD(d, 54); + !!h && (i2 = h.Rh(a, BYd(h.Dh(), this.b), null, i2)); + i2 = a.Ch(h, g, i2); + !!i2 && i2.oj(); + } else { + a.vh() && a.wh() && qvd(a, new N3d(a, 1, g, d, d)); + } + }; + _2.Ek = function I7d(a, b, c2) { + var d, e, f2, g; + d = a.Ph(); + if (d) { + g = (e = a.Fh(), e >= 0 ? a.Ah(null) : a.Ph().Th(a, -1 - e, null, null)); + f2 = BYd(a.Dh(), this.e); + g = a.Ch(null, f2, g); + !!g && g.oj(); + } else { + a.vh() && a.wh() && qvd(a, new b4d(a, 1, this.e, null, null)); + } + }; + _2.bl = function J7d() { + return false; + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleContainer", 784); + feb(1351, 784, {}, K7d); + _2.bl = function L7d() { + return true; + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleContainerResolving", 1351); + feb(574, 512, {}); + _2.yk = function O7d(a, b, c2, d, e) { + var f2; + return f2 = b.li(c2), f2 == null ? this.b : dE(f2) === dE(r7d) ? null : f2; + }; + _2.Bk = function P7d(a, b, c2) { + var d; + d = b.li(c2); + return d != null && (dE(d) === dE(r7d) || !pb(d, this.b)); + }; + _2.Ck = function Q7d(a, b, c2, d) { + var e, f2; + if (a.vh() && a.wh()) { + e = (f2 = b.li(c2), f2 == null ? this.b : dE(f2) === dE(r7d) ? null : f2); + if (d == null) { + if (this.c != null) { + b.mi(c2, null); + d = this.b; + } else + this.b != null ? b.mi(c2, r7d) : b.mi(c2, null); + } else { + this.Bl(d); + b.mi(c2, d); + } + qvd(a, this.d.Cl(a, 1, this.e, e, d)); + } else { + if (d == null) { + this.c != null ? b.mi(c2, null) : this.b != null ? b.mi(c2, r7d) : b.mi(c2, null); + } else { + this.Bl(d); + b.mi(c2, d); + } + } + }; + _2.Ek = function R7d(a, b, c2) { + var d, e; + if (a.vh() && a.wh()) { + d = (e = b.li(c2), e == null ? this.b : dE(e) === dE(r7d) ? null : e); + b.ni(c2); + qvd(a, this.d.Cl(a, 1, this.e, d, this.b)); + } else { + b.ni(c2); + } + }; + _2.Bl = function S7d(a) { + throw Adb(new Hfb()); + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleData", 574); + feb(zKe, 1, {}, b8d); + _2.Cl = function c8d(a, b, c2, d, e) { + return new b4d(a, b, c2, d, e); + }; + _2.Dl = function d8d(a, b, c2, d, e, f2) { + return new d4d(a, b, c2, d, e, f2); + }; + var T7d, U7d, V7d, W7d, X7d, Y7d, Z7d, $7d, _7d; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleData/NotificationCreator", zKe); + feb(1368, zKe, {}, e8d); + _2.Cl = function f8d(a, b, c2, d, e) { + return new g4d(a, b, c2, Heb(TD(d)), Heb(TD(e))); + }; + _2.Dl = function g8d(a, b, c2, d, e, f2) { + return new h4d(a, b, c2, Heb(TD(d)), Heb(TD(e)), f2); + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleData/NotificationCreator/1", 1368); + feb(1369, zKe, {}, h8d); + _2.Cl = function i8d(a, b, c2, d, e) { + return new R3d(a, b, c2, RD(d, 222).a, RD(e, 222).a); + }; + _2.Dl = function j8d(a, b, c2, d, e, f2) { + return new S3d(a, b, c2, RD(d, 222).a, RD(e, 222).a, f2); + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleData/NotificationCreator/2", 1369); + feb(1370, zKe, {}, k8d); + _2.Cl = function l8d(a, b, c2, d, e) { + return new T3d(a, b, c2, RD(d, 180).a, RD(e, 180).a); + }; + _2.Dl = function m8d(a, b, c2, d, e, f2) { + return new U3d(a, b, c2, RD(d, 180).a, RD(e, 180).a, f2); + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleData/NotificationCreator/3", 1370); + feb(1371, zKe, {}, n8d); + _2.Cl = function o8d(a, b, c2, d, e) { + return new V3d(a, b, c2, Kfb(UD(d)), Kfb(UD(e))); + }; + _2.Dl = function p8d(a, b, c2, d, e, f2) { + return new W3d(a, b, c2, Kfb(UD(d)), Kfb(UD(e)), f2); + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleData/NotificationCreator/4", 1371); + feb(1372, zKe, {}, q8d); + _2.Cl = function r8d(a, b, c2, d, e) { + return new X3d(a, b, c2, RD(d, 161).a, RD(e, 161).a); + }; + _2.Dl = function s8d(a, b, c2, d, e, f2) { + return new Y3d(a, b, c2, RD(d, 161).a, RD(e, 161).a, f2); + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleData/NotificationCreator/5", 1372); + feb(1373, zKe, {}, t8d); + _2.Cl = function u8d(a, b, c2, d, e) { + return new Z3d(a, b, c2, RD(d, 17).a, RD(e, 17).a); + }; + _2.Dl = function v8d(a, b, c2, d, e, f2) { + return new $3d(a, b, c2, RD(d, 17).a, RD(e, 17).a, f2); + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleData/NotificationCreator/6", 1373); + feb(1374, zKe, {}, w8d); + _2.Cl = function x8d(a, b, c2, d, e) { + return new _3d(a, b, c2, RD(d, 168).a, RD(e, 168).a); + }; + _2.Dl = function y8d(a, b, c2, d, e, f2) { + return new a4d(a, b, c2, RD(d, 168).a, RD(e, 168).a, f2); + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleData/NotificationCreator/7", 1374); + feb(1375, zKe, {}, z8d); + _2.Cl = function A8d(a, b, c2, d, e) { + return new e4d(a, b, c2, RD(d, 191).a, RD(e, 191).a); + }; + _2.Dl = function B8d(a, b, c2, d, e, f2) { + return new f4d(a, b, c2, RD(d, 191).a, RD(e, 191).a, f2); + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleData/NotificationCreator/8", 1375); + feb(1353, 574, {}, C8d); + _2.Bl = function D8d(a) { + if (!this.a.fk(a)) { + throw Adb(new Ifb(xKe + rb(a) + yKe + this.a + "'")); + } + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleDataDynamic", 1353); + feb(1354, 574, {}, E8d); + _2.Bl = function F8d(a) { + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleDataStatic", 1354); + feb(785, 574, {}); + _2.Bk = function G8d(a, b, c2) { + var d; + d = b.li(c2); + return d != null; + }; + _2.Ck = function H8d(a, b, c2, d) { + var e, f2; + if (a.vh() && a.wh()) { + e = true; + f2 = b.li(c2); + if (f2 == null) { + e = false; + f2 = this.b; + } else + dE(f2) === dE(r7d) && (f2 = null); + if (d == null) { + if (this.c != null) { + b.mi(c2, null); + d = this.b; + } else { + b.mi(c2, r7d); + } + } else { + this.Bl(d); + b.mi(c2, d); + } + qvd(a, this.d.Dl(a, 1, this.e, f2, d, !e)); + } else { + if (d == null) { + this.c != null ? b.mi(c2, null) : b.mi(c2, r7d); + } else { + this.Bl(d); + b.mi(c2, d); + } + } + }; + _2.Ek = function I8d(a, b, c2) { + var d, e; + if (a.vh() && a.wh()) { + d = true; + e = b.li(c2); + if (e == null) { + d = false; + e = this.b; + } else + dE(e) === dE(r7d) && (e = null); + b.ni(c2); + qvd(a, this.d.Dl(a, 2, this.e, e, this.b, d)); + } else { + b.ni(c2); + } + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleDataUnsettable", 785); + feb(1355, 785, {}, J8d); + _2.Bl = function K8d(a) { + if (!this.a.fk(a)) { + throw Adb(new Ifb(xKe + rb(a) + yKe + this.a + "'")); + } + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleDataUnsettableDynamic", 1355); + feb(1356, 785, {}, L8d); + _2.Bl = function M8d(a) { + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleDataUnsettableStatic", 1356); + feb(410, 512, {}, N8d); + _2.yk = function P8d(a, b, c2, d, e) { + var f2, g, h, i2, j; + j = b.li(c2); + if (this.tk() && dE(j) === dE(r7d)) { + return null; + } else if (this.bl() && d && j != null) { + h = RD(j, 54); + if (h.Vh()) { + i2 = Vvd(a, h); + if (h != i2) { + if (!FXd(this.a, i2)) { + throw Adb(new Ifb(xKe + rb(i2) + yKe + this.a + "'")); + } + b.mi(c2, j = i2); + if (this.al()) { + f2 = RD(i2, 54); + g = h.Th(a, !this.b ? -1 - BYd(a.Dh(), this.e) : BYd(h.Dh(), this.b), null, null); + !f2.Ph() && (g = f2.Rh(a, !this.b ? -1 - BYd(a.Dh(), this.e) : BYd(f2.Dh(), this.b), null, g)); + !!g && g.oj(); + } + a.vh() && a.wh() && qvd(a, new b4d(a, 9, this.e, h, i2)); + } + } + return j; + } else { + return j; + } + }; + _2.zk = function Q8d(a, b, c2, d, e) { + var f2, g; + g = b.li(c2); + dE(g) === dE(r7d) && (g = null); + b.mi(c2, d); + if (this.Mj()) { + if (dE(g) !== dE(d) && g != null) { + f2 = RD(g, 54); + e = f2.Th(a, BYd(f2.Dh(), this.b), null, e); + } + } else + this.al() && g != null && (e = RD(g, 54).Th(a, -1 - BYd(a.Dh(), this.e), null, e)); + if (a.vh() && a.wh()) { + !e && (e = new gLd(4)); + e.nj(new b4d(a, 1, this.e, g, d)); + } + return e; + }; + _2.Ak = function R8d(a, b, c2, d, e) { + var f2; + f2 = b.li(c2); + dE(f2) === dE(r7d) && (f2 = null); + b.ni(c2); + if (a.vh() && a.wh()) { + !e && (e = new gLd(4)); + this.tk() ? e.nj(new b4d(a, 2, this.e, f2, null)) : e.nj(new b4d(a, 1, this.e, f2, null)); + } + return e; + }; + _2.Bk = function S8d(a, b, c2) { + var d; + d = b.li(c2); + return d != null; + }; + _2.Ck = function T8d(a, b, c2, d) { + var e, f2, g, h, i2; + if (d != null && !FXd(this.a, d)) { + throw Adb(new Ifb(xKe + (ZD(d, 58) ? GYd(RD(d, 58).Dh()) : ofb(rb(d))) + yKe + this.a + "'")); + } + i2 = b.li(c2); + h = i2 != null; + this.tk() && dE(i2) === dE(r7d) && (i2 = null); + g = null; + if (this.Mj()) { + if (dE(i2) !== dE(d)) { + if (i2 != null) { + e = RD(i2, 54); + g = e.Th(a, BYd(e.Dh(), this.b), null, g); + } + if (d != null) { + e = RD(d, 54); + g = e.Rh(a, BYd(e.Dh(), this.b), null, g); + } + } + } else if (this.al()) { + if (dE(i2) !== dE(d)) { + i2 != null && (g = RD(i2, 54).Th(a, -1 - BYd(a.Dh(), this.e), null, g)); + d != null && (g = RD(d, 54).Rh(a, -1 - BYd(a.Dh(), this.e), null, g)); + } + } + d == null && this.tk() ? b.mi(c2, r7d) : b.mi(c2, d); + if (a.vh() && a.wh()) { + f2 = new d4d(a, 1, this.e, i2, d, this.tk() && !h); + if (!g) { + qvd(a, f2); + } else { + g.nj(f2); + g.oj(); + } + } else + !!g && g.oj(); + }; + _2.Ek = function U8d(a, b, c2) { + var d, e, f2, g, h; + h = b.li(c2); + g = h != null; + this.tk() && dE(h) === dE(r7d) && (h = null); + f2 = null; + if (h != null) { + if (this.Mj()) { + d = RD(h, 54); + f2 = d.Th(a, BYd(d.Dh(), this.b), null, f2); + } else + this.al() && (f2 = RD(h, 54).Th(a, -1 - BYd(a.Dh(), this.e), null, f2)); + } + b.ni(c2); + if (a.vh() && a.wh()) { + e = new d4d(a, this.tk() ? 2 : 1, this.e, h, null, g); + if (!f2) { + qvd(a, e); + } else { + f2.nj(e); + f2.oj(); + } + } else + !!f2 && f2.oj(); + }; + _2.Mj = function V8d() { + return false; + }; + _2.al = function W8d() { + return false; + }; + _2.bl = function X8d() { + return false; + }; + _2.tk = function Y8d() { + return false; + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleEObject", 410); + feb(575, 410, {}, Z8d); + _2.al = function $8d() { + return true; + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleEObjectContainment", 575); + feb(1359, 575, {}, _8d); + _2.bl = function a9d() { + return true; + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleEObjectContainmentResolving", 1359); + feb(787, 575, {}, b9d); + _2.tk = function c9d() { + return true; + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleEObjectContainmentUnsettable", 787); + feb(1361, 787, {}, d9d); + _2.bl = function e9d() { + return true; + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleEObjectContainmentUnsettableResolving", 1361); + feb(650, 575, {}, f9d); + _2.Mj = function g9d() { + return true; + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleEObjectContainmentWithInverse", 650); + feb(1360, 650, {}, h9d); + _2.bl = function i9d() { + return true; + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleEObjectContainmentWithInverseResolving", 1360); + feb(788, 650, {}, j9d); + _2.tk = function k9d() { + return true; + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleEObjectContainmentWithInverseUnsettable", 788); + feb(1362, 788, {}, l9d); + _2.bl = function m9d() { + return true; + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleEObjectContainmentWithInverseUnsettableResolving", 1362); + feb(651, 410, {}, n9d); + _2.bl = function o9d() { + return true; + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleEObjectResolving", 651); + feb(1363, 651, {}, p9d); + _2.tk = function q9d() { + return true; + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleEObjectResolvingUnsettable", 1363); + feb(789, 651, {}, r9d); + _2.Mj = function s9d() { + return true; + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleEObjectResolvingWithInverse", 789); + feb(1364, 789, {}, t9d); + _2.tk = function u9d() { + return true; + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleEObjectResolvingWithInverseUnsettable", 1364); + feb(1357, 410, {}, v9d); + _2.tk = function w9d() { + return true; + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleEObjectUnsettable", 1357); + feb(786, 410, {}, x9d); + _2.Mj = function y9d() { + return true; + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleEObjectWithInverse", 786); + feb(1358, 786, {}, z9d); + _2.tk = function A9d() { + return true; + }; + sfb(SHe, "EStructuralFeatureImpl/InternalSettingDelegateSingleEObjectWithInverseUnsettable", 1358); + feb(790, 576, wKe, D9d); + _2.yl = function E9d(a) { + return new D9d(this.a, this.c, a); + }; + _2.md = function F9d() { + return this.b; + }; + _2.zl = function G9d(a, b, c2) { + return B9d(this, a, this.b, c2); + }; + _2.Al = function H9d(a, b, c2) { + return C9d(this, a, this.b, c2); + }; + sfb(SHe, "EStructuralFeatureImpl/InverseUpdatingFeatureMapEntry", 790); + feb(1365, 1, $Je, I9d); + _2.Fk = function J9d(a) { + return this.a; + }; + _2.Qj = function K9d() { + return ZD(this.a, 97) ? RD(this.a, 97).Qj() : !this.a.dc(); + }; + _2.Wb = function L9d(a) { + this.a.$b(); + this.a.Gc(RD(a, 15)); + }; + _2.Gk = function M9d() { + ZD(this.a, 97) ? RD(this.a, 97).Gk() : this.a.$b(); + }; + sfb(SHe, "EStructuralFeatureImpl/SettingMany", 1365); + feb(1366, 576, wKe, N9d); + _2.xl = function O9d(a) { + return new S9d((nme(), mme), this.b.ri(this.a, a)); + }; + _2.md = function P9d() { + return null; + }; + _2.zl = function Q9d(a, b, c2) { + return c2; + }; + _2.Al = function R9d(a, b, c2) { + return c2; + }; + sfb(SHe, "EStructuralFeatureImpl/SimpleContentFeatureMapEntry", 1366); + feb(652, 576, wKe, S9d); + _2.xl = function T9d(a) { + return new S9d(this.c, a); + }; + _2.md = function U9d() { + return this.a; + }; + _2.zl = function V9d(a, b, c2) { + return c2; + }; + _2.Al = function W9d(a, b, c2) { + return c2; + }; + sfb(SHe, "EStructuralFeatureImpl/SimpleFeatureMapEntry", 652); + feb(403, 506, PIe, X9d); + _2.aj = function Y9d(a) { + return $C(h7, rve, 29, a, 0, 1); + }; + _2.Yi = function Z9d() { + return false; + }; + sfb(SHe, "ESuperAdapter/1", 403); + feb(457, 448, { 110: 1, 94: 1, 93: 1, 155: 1, 197: 1, 58: 1, 114: 1, 850: 1, 54: 1, 99: 1, 158: 1, 457: 1, 119: 1, 120: 1 }, _9d); + _2.Lh = function aae(a, b, c2) { + var d; + switch (a) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), this.Ab; + case 1: + return this.zb; + case 2: + return !this.a && (this.a = new iae(this, o7, this)), this.a; + } + return zvd(this, a - AYd((JTd(), ITd)), vYd((d = RD(Ywd(this, 16), 29), !d ? ITd : d), a), b, c2); + }; + _2.Uh = function bae(a, b, c2) { + var d, e; + switch (b) { + case 0: + return !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)), rLd(this.Ab, a, c2); + case 2: + return !this.a && (this.a = new iae(this, o7, this)), rLd(this.a, a, c2); + } + return e = RD(vYd((d = RD(Ywd(this, 16), 29), !d ? (JTd(), ITd) : d), b), 69), e.wk().Ak(this, Wwd(this), b - AYd((JTd(), ITd)), a, c2); + }; + _2.Wh = function cae(a) { + var b; + switch (a) { + case 0: + return !!this.Ab && this.Ab.i != 0; + case 1: + return this.zb != null; + case 2: + return !!this.a && this.a.i != 0; + } + return Avd(this, a - AYd((JTd(), ITd)), vYd((b = RD(Ywd(this, 16), 29), !b ? ITd : b), a)); + }; + _2.bi = function dae(a, b) { + var c2; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + YGd(this.Ab, RD(b, 16)); + return; + case 1: + PAd(this, WD(b)); + return; + case 2: + !this.a && (this.a = new iae(this, o7, this)); + sLd(this.a); + !this.a && (this.a = new iae(this, o7, this)); + YGd(this.a, RD(b, 16)); + return; + } + Bvd(this, a - AYd((JTd(), ITd)), vYd((c2 = RD(Ywd(this, 16), 29), !c2 ? ITd : c2), a), b); + }; + _2.ii = function eae() { + return JTd(), ITd; + }; + _2.ki = function fae(a) { + var b; + switch (a) { + case 0: + !this.Ab && (this.Ab = new C5d(f7, this, 0, 3)); + sLd(this.Ab); + return; + case 1: + PAd(this, null); + return; + case 2: + !this.a && (this.a = new iae(this, o7, this)); + sLd(this.a); + return; + } + Cvd(this, a - AYd((JTd(), ITd)), vYd((b = RD(Ywd(this, 16), 29), !b ? ITd : b), a)); + }; + sfb(SHe, "ETypeParameterImpl", 457); + feb(458, 83, oKe, iae); + _2.Nj = function jae(a, b) { + return gae(this, RD(a, 89), b); + }; + _2.Oj = function kae(a, b) { + return hae(this, RD(a, 89), b); + }; + sfb(SHe, "ETypeParameterImpl/1", 458); + feb(647, 45, Hxe, lae); + _2.ec = function mae() { + return new pae(this); + }; + sfb(SHe, "ETypeParameterImpl/2", 647); + feb(570, Eve, Fve, pae); + _2.Fc = function qae(a) { + return nae(this, RD(a, 89)); + }; + _2.Gc = function rae(a) { + var b, c2, d; + d = false; + for (c2 = a.Kc(); c2.Ob(); ) { + b = RD(c2.Pb(), 89); + Zjb(this.a, b, "") == null && (d = true); + } + return d; + }; + _2.$b = function sae() { + akb(this.a); + }; + _2.Hc = function tae(a) { + return Ujb(this.a, a); + }; + _2.Kc = function uae() { + var a; + return a = new vkb(new mkb(this.a).a), new xae(a); + }; + _2.Mc = function vae(a) { + return oae(this, a); + }; + _2.gc = function wae() { + return bkb(this.a); + }; + sfb(SHe, "ETypeParameterImpl/2/1", 570); + feb(571, 1, Ave, xae); + _2.Nb = function yae(a) { + Ztb(this, a); + }; + _2.Pb = function Aae() { + return RD(tkb(this.a).ld(), 89); + }; + _2.Ob = function zae() { + return this.a.b; + }; + _2.Qb = function Bae() { + ukb(this.a); + }; + sfb(SHe, "ETypeParameterImpl/2/1/1", 571); + feb(1329, 45, Hxe, Cae); + _2._b = function Dae(a) { + return bE(a) ? Yjb(this, a) : !!qtb(this.f, a); + }; + _2.xc = function Eae(a) { + var b, c2; + b = bE(a) ? Xjb(this, a) : Wd(qtb(this.f, a)); + if (ZD(b, 851)) { + c2 = RD(b, 851); + b = c2.Kk(); + Zjb(this, RD(a, 241), b); + return b; + } else + return b != null ? b : a == null ? (Gie(), Fie) : null; + }; + sfb(SHe, "EValidatorRegistryImpl", 1329); + feb(1349, 720, { 110: 1, 94: 1, 93: 1, 480: 1, 155: 1, 58: 1, 114: 1, 2040: 1, 54: 1, 99: 1, 158: 1, 119: 1, 120: 1 }, Mae); + _2.ri = function Nae(a, b) { + switch (a.hk()) { + case 21: + case 22: + case 23: + case 24: + case 26: + case 31: + case 32: + case 37: + case 38: + case 39: + case 40: + case 43: + case 44: + case 48: + case 49: + case 20: + return b == null ? null : jeb(b); + case 25: + return Gae(b); + case 27: + return Hae(b); + case 28: + return Iae(b); + case 29: + return b == null ? null : a2d(nAd[0], RD(b, 206)); + case 41: + return b == null ? "" : nfb(RD(b, 297)); + case 42: + return jeb(b); + case 50: + return WD(b); + default: + throw Adb(new agb(VHe + a.xe() + WHe)); + } + }; + _2.si = function Oae(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q; + switch (a.G == -1 && (a.G = (m = BXd(a), m ? fZd(m.vi(), a) : -1)), a.G) { + case 0: + return c2 = new mXd(), c2; + case 1: + return b = new pVd(), b; + case 2: + return d = new HYd(), d; + case 4: + return e = new k1d(), e; + case 5: + return f2 = new A1d(), f2; + case 6: + return g = new R1d(), g; + case 7: + return h = new yAd(), h; + case 10: + return j = new kUd(), j; + case 11: + return k = new q4d(), k; + case 12: + return l = new EBd(), l; + case 13: + return n = new R5d(), n; + case 14: + return o2 = new d6d(), o2; + case 17: + return p = new v6d(), p; + case 18: + return i2 = new s2d(), i2; + case 19: + return q = new _9d(), q; + default: + throw Adb(new agb(ZHe + a.zb + WHe)); + } + }; + _2.ti = function Pae(a, b) { + switch (a.hk()) { + case 20: + return b == null ? null : new Bib(b); + case 21: + return b == null ? null : new ejb(b); + case 23: + case 22: + return b == null ? null : Fae(b); + case 26: + case 24: + return b == null ? null : $eb(Oeb(b, -128, 127) << 24 >> 24); + case 25: + return vAd(b); + case 27: + return Jae(b); + case 28: + return Kae(b); + case 29: + return Lae(b); + case 32: + case 31: + return b == null ? null : Neb(b); + case 38: + case 37: + return b == null ? null : new Ufb(b); + case 40: + case 39: + return b == null ? null : sgb(Oeb(b, qwe, lve)); + case 41: + return null; + case 42: + return b == null ? null : null; + case 44: + case 43: + return b == null ? null : Hgb(Peb(b)); + case 49: + case 48: + return b == null ? null : bhb(Oeb(b, BKe, 32767) << 16 >> 16); + case 50: + return b; + default: + throw Adb(new agb(VHe + a.xe() + WHe)); + } + }; + sfb(SHe, "EcoreFactoryImpl", 1349); + feb(560, 184, { 110: 1, 94: 1, 93: 1, 155: 1, 197: 1, 58: 1, 241: 1, 114: 1, 2038: 1, 54: 1, 99: 1, 158: 1, 184: 1, 560: 1, 119: 1, 120: 1, 690: 1 }, $ae); + _2.gb = false; + _2.hb = false; + var Rae, Sae = false; + sfb(SHe, "EcorePackageImpl", 560); + feb(1234, 1, { 851: 1 }, cbe); + _2.Kk = function dbe() { + return fke(), eke; + }; + sfb(SHe, "EcorePackageImpl/1", 1234); + feb(1243, 1, OKe, ebe); + _2.fk = function fbe(a) { + return ZD(a, 155); + }; + _2.gk = function gbe(a) { + return $C(p7, rve, 155, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/10", 1243); + feb(1244, 1, OKe, hbe); + _2.fk = function ibe(a) { + return ZD(a, 197); + }; + _2.gk = function jbe(a) { + return $C(q7, rve, 197, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/11", 1244); + feb(1245, 1, OKe, kbe); + _2.fk = function lbe(a) { + return ZD(a, 58); + }; + _2.gk = function mbe(a) { + return $C(r7, rve, 58, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/12", 1245); + feb(1246, 1, OKe, nbe); + _2.fk = function obe(a) { + return ZD(a, 411); + }; + _2.gk = function pbe(a) { + return $C(s7, mKe, 62, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/13", 1246); + feb(1247, 1, OKe, qbe); + _2.fk = function rbe(a) { + return ZD(a, 241); + }; + _2.gk = function sbe(a) { + return $C(t7, rve, 241, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/14", 1247); + feb(1248, 1, OKe, tbe); + _2.fk = function ube(a) { + return ZD(a, 518); + }; + _2.gk = function vbe(a) { + return $C(u7, rve, 2116, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/15", 1248); + feb(1249, 1, OKe, wbe); + _2.fk = function xbe(a) { + return ZD(a, 102); + }; + _2.gk = function ybe(a) { + return $C(v7, lKe, 19, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/16", 1249); + feb(1250, 1, OKe, zbe); + _2.fk = function Abe(a) { + return ZD(a, 179); + }; + _2.gk = function Bbe(a) { + return $C(y7, lKe, 179, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/17", 1250); + feb(1251, 1, OKe, Cbe); + _2.fk = function Dbe(a) { + return ZD(a, 481); + }; + _2.gk = function Ebe(a) { + return $C(A7, rve, 481, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/18", 1251); + feb(1252, 1, OKe, Fbe); + _2.fk = function Gbe(a) { + return ZD(a, 561); + }; + _2.gk = function Hbe(a) { + return $C(C8, LJe, 561, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/19", 1252); + feb(1235, 1, OKe, Ibe); + _2.fk = function Jbe(a) { + return ZD(a, 331); + }; + _2.gk = function Kbe(a) { + return $C(g7, lKe, 35, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/2", 1235); + feb(1253, 1, OKe, Lbe); + _2.fk = function Mbe(a) { + return ZD(a, 248); + }; + _2.gk = function Nbe(a) { + return $C(o7, sKe, 89, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/20", 1253); + feb(1254, 1, OKe, Obe); + _2.fk = function Pbe(a) { + return ZD(a, 457); + }; + _2.gk = function Qbe(a) { + return $C(z7, rve, 850, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/21", 1254); + feb(1255, 1, OKe, Rbe); + _2.fk = function Sbe(a) { + return $D(a); + }; + _2.gk = function Tbe(a) { + return $C(QI, Nve, 485, a, 8, 1); + }; + sfb(SHe, "EcorePackageImpl/22", 1255); + feb(1256, 1, OKe, Ube); + _2.fk = function Vbe(a) { + return ZD(a, 195); + }; + _2.gk = function Wbe(a) { + return $C(gE, Nve, 195, a, 0, 2); + }; + sfb(SHe, "EcorePackageImpl/23", 1256); + feb(1257, 1, OKe, Xbe); + _2.fk = function Ybe(a) { + return ZD(a, 222); + }; + _2.gk = function Zbe(a) { + return $C(RI, Nve, 222, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/24", 1257); + feb(1258, 1, OKe, $be); + _2.fk = function _be(a) { + return ZD(a, 180); + }; + _2.gk = function ace(a) { + return $C(SI, Nve, 180, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/25", 1258); + feb(1259, 1, OKe, bce); + _2.fk = function cce(a) { + return ZD(a, 206); + }; + _2.gk = function dce(a) { + return $C(qK, Nve, 206, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/26", 1259); + feb(1260, 1, OKe, ece); + _2.fk = function fce(a) { + return false; + }; + _2.gk = function gce(a) { + return $C(T6, rve, 2215, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/27", 1260); + feb(1261, 1, OKe, hce); + _2.fk = function ice(a) { + return _D(a); + }; + _2.gk = function jce(a) { + return $C(VI, Nve, 345, a, 7, 1); + }; + sfb(SHe, "EcorePackageImpl/28", 1261); + feb(1262, 1, OKe, kce); + _2.fk = function lce(a) { + return ZD(a, 61); + }; + _2.gk = function mce(a) { + return $C(Y6, Ize, 61, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/29", 1262); + feb(1236, 1, OKe, nce); + _2.fk = function oce(a) { + return ZD(a, 519); + }; + _2.gk = function pce(a) { + return $C(f7, { 3: 1, 4: 1, 5: 1, 2033: 1 }, 598, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/3", 1236); + feb(1263, 1, OKe, qce); + _2.fk = function rce(a) { + return ZD(a, 582); + }; + _2.gk = function sce(a) { + return $C(Z6, rve, 2039, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/30", 1263); + feb(1264, 1, OKe, tce); + _2.fk = function uce(a) { + return ZD(a, 160); + }; + _2.gk = function vce(a) { + return $C(Tbb, Ize, 160, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/31", 1264); + feb(1265, 1, OKe, wce); + _2.fk = function xce(a) { + return ZD(a, 76); + }; + _2.gk = function yce(a) { + return $C(Jbb, PKe, 76, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/32", 1265); + feb(1266, 1, OKe, zce); + _2.fk = function Ace(a) { + return ZD(a, 161); + }; + _2.gk = function Bce(a) { + return $C(ZI, Nve, 161, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/33", 1266); + feb(1267, 1, OKe, Cce); + _2.fk = function Dce(a) { + return ZD(a, 17); + }; + _2.gk = function Ece(a) { + return $C(bJ, Nve, 17, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/34", 1267); + feb(1268, 1, OKe, Fce); + _2.fk = function Gce(a) { + return ZD(a, 297); + }; + _2.gk = function Hce(a) { + return $C(UI, rve, 297, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/35", 1268); + feb(1269, 1, OKe, Ice); + _2.fk = function Jce(a) { + return ZD(a, 168); + }; + _2.gk = function Kce(a) { + return $C(eJ, Nve, 168, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/36", 1269); + feb(1270, 1, OKe, Lce); + _2.fk = function Mce(a) { + return ZD(a, 85); + }; + _2.gk = function Nce(a) { + return $C(VK, rve, 85, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/37", 1270); + feb(1271, 1, OKe, Oce); + _2.fk = function Pce(a) { + return ZD(a, 599); + }; + _2.gk = function Qce(a) { + return $C(Aab, rve, 599, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/38", 1271); + feb(1272, 1, OKe, Rce); + _2.fk = function Sce(a) { + return false; + }; + _2.gk = function Tce(a) { + return $C(zab, rve, 2216, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/39", 1272); + feb(1237, 1, OKe, Uce); + _2.fk = function Vce(a) { + return ZD(a, 90); + }; + _2.gk = function Wce(a) { + return $C(h7, rve, 29, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/4", 1237); + feb(1273, 1, OKe, Xce); + _2.fk = function Yce(a) { + return ZD(a, 191); + }; + _2.gk = function Zce(a) { + return $C(lJ, Nve, 191, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/40", 1273); + feb(1274, 1, OKe, $ce); + _2.fk = function _ce(a) { + return bE(a); + }; + _2.gk = function ade(a) { + return $C(qJ, Nve, 2, a, 6, 1); + }; + sfb(SHe, "EcorePackageImpl/41", 1274); + feb(1275, 1, OKe, bde); + _2.fk = function cde(a) { + return ZD(a, 596); + }; + _2.gk = function dde(a) { + return $C(a7, rve, 596, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/42", 1275); + feb(1276, 1, OKe, ede); + _2.fk = function fde(a) { + return false; + }; + _2.gk = function gde(a) { + return $C($6, Nve, 2217, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/43", 1276); + feb(1277, 1, OKe, hde); + _2.fk = function ide(a) { + return ZD(a, 44); + }; + _2.gk = function jde(a) { + return $C(UK, Zve, 44, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/44", 1277); + feb(1238, 1, OKe, kde); + _2.fk = function lde(a) { + return ZD(a, 142); + }; + _2.gk = function mde(a) { + return $C(i7, rve, 142, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/5", 1238); + feb(1239, 1, OKe, nde); + _2.fk = function ode(a) { + return ZD(a, 156); + }; + _2.gk = function pde(a) { + return $C(k7, rve, 156, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/6", 1239); + feb(1240, 1, OKe, qde); + _2.fk = function rde(a) { + return ZD(a, 469); + }; + _2.gk = function sde(a) { + return $C(m7, rve, 685, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/7", 1240); + feb(1241, 1, OKe, tde); + _2.fk = function ude(a) { + return ZD(a, 582); + }; + _2.gk = function vde(a) { + return $C(l7, rve, 694, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/8", 1241); + feb(1242, 1, OKe, wde); + _2.fk = function xde(a) { + return ZD(a, 480); + }; + _2.gk = function yde(a) { + return $C(n7, rve, 480, a, 0, 1); + }; + sfb(SHe, "EcorePackageImpl/9", 1242); + feb(1038, 2080, JJe, Cde); + _2.Mi = function Dde(a, b) { + zde(this, RD(b, 424)); + }; + _2.Qi = function Ede(a, b) { + Ade(this, a, RD(b, 424)); + }; + sfb(SHe, "MinimalEObjectImpl/1ArrayDelegatingAdapterList", 1038); + feb(1039, 152, GJe, Fde); + _2.jj = function Gde() { + return this.a.a; + }; + sfb(SHe, "MinimalEObjectImpl/1ArrayDelegatingAdapterList/1", 1039); + feb(1067, 1066, {}, Ide); + sfb("org.eclipse.emf.ecore.plugin", "EcorePlugin", 1067); + var Aab = ufb(QKe, "Resource"); + feb(799, 1524, RKe); + _2.Hl = function Mde(a) { + }; + _2.Il = function Nde(a) { + }; + _2.El = function Ode() { + return !this.a && (this.a = new Zde(this)), this.a; + }; + _2.Fl = function Pde(a) { + var b, c2, d, e, f2; + d = a.length; + if (d > 0) { + BFb(0, a.length); + if (a.charCodeAt(0) == 47) { + f2 = new cnb(4); + e = 1; + for (b = 1; b < d; ++b) { + BFb(b, a.length); + if (a.charCodeAt(b) == 47) { + Rmb(f2, e == b ? "" : (AFb(e, b, a.length), a.substr(e, b - e))); + e = b + 1; + } + } + Rmb(f2, (BFb(e, a.length + 1), a.substr(e))); + return Jde(this, f2); + } else { + BFb(d - 1, a.length); + if (a.charCodeAt(d - 1) == 63) { + c2 = uhb(a, Fhb(63), d - 2); + c2 > 0 && (a = (AFb(0, c2, a.length), a.substr(0, c2))); + } + } + } + return Kde(this, a); + }; + _2.Gl = function Qde() { + return this.c; + }; + _2.Ib = function Rde() { + var a; + return nfb(this.Rm) + "@" + (a = tb(this) >>> 0, a.toString(16)) + " uri='" + this.d + "'"; + }; + _2.b = false; + sfb(SKe, "ResourceImpl", 799); + feb(1525, 799, RKe, Sde); + sfb(SKe, "BinaryResourceImpl", 1525); + feb(1190, 708, QIe); + _2.bj = function Vde(a) { + return ZD(a, 58) ? Tde(this, RD(a, 58)) : ZD(a, 599) ? new dMd(RD(a, 599).El()) : dE(a) === dE(this.f) ? RD(a, 16).Kc() : (jQd(), iQd.a); + }; + _2.Ob = function Wde() { + return Ude(this); + }; + _2.a = false; + sfb(ZJe, "EcoreUtil/ContentTreeIterator", 1190); + feb(1526, 1190, QIe, Xde); + _2.bj = function Yde(a) { + return dE(a) === dE(this.f) ? RD(a, 15).Kc() : new _je(RD(a, 58)); + }; + sfb(SKe, "ResourceImpl/5", 1526); + feb(658, 2092, nKe, Zde); + _2.Hc = function $de(a) { + return this.i <= 4 ? PHd(this, a) : ZD(a, 54) && RD(a, 54).Jh() == this.a; + }; + _2.Mi = function _de(a, b) { + a == this.i - 1 && (this.a.b || (this.a.b = true, null)); + }; + _2.Oi = function aee(a, b) { + a == 0 ? this.a.b || (this.a.b = true, null) : $Gd(this, a, b); + }; + _2.Qi = function bee(a, b) { + }; + _2.Ri = function cee(a, b, c2) { + }; + _2.Lj = function dee() { + return 2; + }; + _2.jj = function eee() { + return this.a; + }; + _2.Mj = function fee() { + return true; + }; + _2.Nj = function gee(a, b) { + var c2; + c2 = RD(a, 54); + b = c2.fi(this.a, b); + return b; + }; + _2.Oj = function hee(a, b) { + var c2; + c2 = RD(a, 54); + return c2.fi(null, b); + }; + _2.Pj = function iee() { + return false; + }; + _2.Si = function jee() { + return true; + }; + _2.aj = function kee(a) { + return $C(r7, rve, 58, a, 0, 1); + }; + _2.Yi = function lee() { + return false; + }; + sfb(SKe, "ResourceImpl/ContentsEList", 658); + feb(970, 2062, kwe, mee); + _2.fd = function nee(a) { + return this.a.Ki(a); + }; + _2.gc = function oee() { + return this.a.gc(); + }; + sfb(ZJe, "AbstractSequentialInternalEList/1", 970); + var hke, ike, jke, kke; + feb(634, 1, {}, Yee); + var pee, qee; + sfb(ZJe, "BasicExtendedMetaData", 634); + feb(1181, 1, {}, afe); + _2.Jl = function bfe() { + return null; + }; + _2.Kl = function cfe() { + this.a == -2 && $ee(this, uee(this.d, this.b)); + return this.a; + }; + _2.Ll = function dfe() { + return null; + }; + _2.Ml = function efe() { + return yob(), yob(), vob; + }; + _2.xe = function ffe() { + this.c == fLe && _ee(this, zee(this.d, this.b)); + return this.c; + }; + _2.Nl = function gfe() { + return 0; + }; + _2.a = -2; + _2.c = fLe; + sfb(ZJe, "BasicExtendedMetaData/EClassExtendedMetaDataImpl", 1181); + feb(1182, 1, {}, mfe); + _2.Jl = function nfe() { + this.a == (ree(), pee) && hfe(this, tee(this.f, this.b)); + return this.a; + }; + _2.Kl = function ofe() { + return 0; + }; + _2.Ll = function pfe() { + this.c == (ree(), pee) && ife(this, xee(this.f, this.b)); + return this.c; + }; + _2.Ml = function qfe() { + !this.d && jfe(this, yee(this.f, this.b)); + return this.d; + }; + _2.xe = function rfe() { + this.e == fLe && kfe(this, zee(this.f, this.b)); + return this.e; + }; + _2.Nl = function sfe() { + this.g == -2 && lfe(this, Cee(this.f, this.b)); + return this.g; + }; + _2.e = fLe; + _2.g = -2; + sfb(ZJe, "BasicExtendedMetaData/EDataTypeExtendedMetaDataImpl", 1182); + feb(1180, 1, {}, wfe); + _2.b = false; + _2.c = false; + sfb(ZJe, "BasicExtendedMetaData/EPackageExtendedMetaDataImpl", 1180); + feb(1183, 1, {}, Jfe); + _2.c = -2; + _2.e = fLe; + _2.f = fLe; + sfb(ZJe, "BasicExtendedMetaData/EStructuralFeatureExtendedMetaDataImpl", 1183); + feb(593, 632, oKe, Kfe); + _2.Lj = function Lfe() { + return this.c; + }; + _2.ol = function Mfe() { + return false; + }; + _2.Wi = function Nfe(a, b) { + return b; + }; + _2.c = 0; + sfb(ZJe, "EDataTypeEList", 593); + var Tbb = ufb(ZJe, "FeatureMap"); + feb(78, 593, { 3: 1, 4: 1, 20: 1, 31: 1, 56: 1, 16: 1, 15: 1, 59: 1, 70: 1, 66: 1, 61: 1, 79: 1, 160: 1, 220: 1, 2036: 1, 71: 1, 97: 1 }, Uge); + _2.bd = function Vge(a, b) { + Ofe(this, a, RD(b, 76)); + }; + _2.Fc = function Wge(a) { + return Rfe(this, RD(a, 76)); + }; + _2.Hi = function _ge(a) { + Wfe(this, RD(a, 76)); + }; + _2.Nj = function khe(a, b) { + return mge(this, RD(a, 76), b); + }; + _2.Oj = function lhe(a, b) { + return oge(this, RD(a, 76), b); + }; + _2.Ti = function nhe(a, b) { + return uge(this, a, b); + }; + _2.Wi = function phe(a, b) { + return zge(this, a, RD(b, 76)); + }; + _2.hd = function rhe(a, b) { + return Cge(this, a, RD(b, 76)); + }; + _2.Uj = function vhe(a, b) { + return Ige(this, RD(a, 76), b); + }; + _2.Vj = function whe(a, b) { + return Kge(this, RD(a, 76), b); + }; + _2.Wj = function xhe(a, b, c2) { + return Lge(this, RD(a, 76), RD(b, 76), c2); + }; + _2.Zi = function zhe(a, b) { + return Tge(this, a, RD(b, 76)); + }; + _2.Ol = function Xge(a, b) { + return Qfe(this, a, b); + }; + _2.cd = function Yge(a, b) { + var c2, d, e, f2, g, h, i2, j, k; + j = new ZHd(b.gc()); + for (e = b.Kc(); e.Ob(); ) { + d = RD(e.Pb(), 76); + f2 = d.Lk(); + if (qke(this.e, f2)) { + (!f2.Si() || !cge(this, f2, d.md()) && !PHd(j, d)) && WGd(j, d); + } else { + k = pke(this.e.Dh(), f2); + c2 = RD(this.g, 124); + g = true; + for (h = 0; h < this.i; ++h) { + i2 = c2[h]; + if (k.am(i2.Lk())) { + RD(eHd(this, h, d), 76); + g = false; + break; + } + } + g && WGd(j, d); + } + } + return XGd(this, a, j); + }; + _2.Gc = function Zge(a) { + var b, c2, d, e, f2, g, h, i2, j; + i2 = new ZHd(a.gc()); + for (d = a.Kc(); d.Ob(); ) { + c2 = RD(d.Pb(), 76); + e = c2.Lk(); + if (qke(this.e, e)) { + (!e.Si() || !cge(this, e, c2.md()) && !PHd(i2, c2)) && WGd(i2, c2); + } else { + j = pke(this.e.Dh(), e); + b = RD(this.g, 124); + f2 = true; + for (g = 0; g < this.i; ++g) { + h = b[g]; + if (j.am(h.Lk())) { + RD(eHd(this, g, c2), 76); + f2 = false; + break; + } + } + f2 && WGd(i2, c2); + } + } + return YGd(this, i2); + }; + _2.Fi = function $ge(a) { + this.j = -1; + return nLd(this, this.i, a); + }; + _2.Pl = function ahe(a, b, c2) { + return Xfe(this, a, b, c2); + }; + _2.Xk = function bhe(a, b) { + return _fe(this, a, b); + }; + _2.Ql = function che(a, b, c2) { + return age(this, a, b, c2); + }; + _2.Rl = function dhe() { + return this; + }; + _2.Sl = function ehe(a, b) { + return ige(this, a, b); + }; + _2.Tl = function fhe(a) { + return RD(QHd(this, a), 76).Lk(); + }; + _2.Ul = function ghe(a) { + return RD(QHd(this, a), 76).md(); + }; + _2.Vl = function hhe() { + return this.b; + }; + _2.Mj = function ihe() { + return true; + }; + _2.Tj = function jhe() { + return true; + }; + _2.Wl = function mhe(a) { + return !pge(this, a); + }; + _2.aj = function ohe(a) { + return $C(Ibb, PKe, 343, a, 0, 1); + }; + _2.pl = function qhe(a) { + return Age(this, a); + }; + _2.Wb = function she(a) { + Dge(this, a); + }; + _2.Xl = function the(a, b) { + Fge(this, a, b); + }; + _2.Yl = function uhe(a) { + return Gge(this, a); + }; + _2.Zl = function yhe(a) { + Sge(this, a); + }; + sfb(ZJe, "BasicFeatureMap", 78); + feb(1960, 1, Jve); + _2.Nb = function Fhe(a) { + Ztb(this, a); + }; + _2.Rb = function Ehe(b) { + if (this.g == -1) { + throw Adb(new cgb()); + } + Ahe(this); + try { + Pfe(this.e, this.b, this.a, b); + this.d = this.e.j; + Dhe(this); + } catch (a) { + a = zdb(a); + if (ZD(a, 77)) { + throw Adb(new Jrb()); + } else + throw Adb(a); + } + }; + _2.Ob = function Ghe() { + return Bhe(this); + }; + _2.Sb = function Hhe() { + return Che(this); + }; + _2.Pb = function Ihe() { + return Dhe(this); + }; + _2.Tb = function Jhe() { + return this.a; + }; + _2.Ub = function Khe() { + var a; + if (Che(this)) { + Ahe(this); + this.g = --this.a; + if (this.ul()) { + a = Bge(this.e, this.b, this.c, this.a, this.j); + this.j = a; + } + this.i = 0; + return this.j; + } else { + throw Adb(new Dvb()); + } + }; + _2.Vb = function Lhe() { + return this.a - 1; + }; + _2.Qb = function Mhe() { + if (this.g == -1) { + throw Adb(new cgb()); + } + Ahe(this); + try { + xge(this.e, this.b, this.g); + this.d = this.e.j; + if (this.g < this.a) { + --this.a; + --this.c; + } + --this.g; + } catch (a) { + a = zdb(a); + if (ZD(a, 77)) { + throw Adb(new Jrb()); + } else + throw Adb(a); + } + }; + _2.ul = function Nhe() { + return false; + }; + _2.Wb = function Ohe(b) { + if (this.g == -1) { + throw Adb(new cgb()); + } + Ahe(this); + try { + Ege(this.e, this.b, this.g, b); + this.d = this.e.j; + } catch (a) { + a = zdb(a); + if (ZD(a, 77)) { + throw Adb(new Jrb()); + } else + throw Adb(a); + } + }; + _2.a = 0; + _2.c = 0; + _2.d = 0; + _2.f = false; + _2.g = 0; + _2.i = 0; + sfb(ZJe, "FeatureMapUtil/BasicFeatureEIterator", 1960); + feb(420, 1960, Jve, Phe); + _2.$l = function Qhe() { + var a, b, c2; + c2 = this.e.i; + a = RD(this.e.g, 124); + while (this.c < c2) { + b = a[this.c]; + if (this.k.am(b.Lk())) { + this.j = this.f ? b : b.md(); + this.i = 2; + return true; + } + ++this.c; + } + this.i = 1; + this.g = -1; + return false; + }; + _2._l = function Rhe() { + var a, b; + a = RD(this.e.g, 124); + while (--this.c >= 0) { + b = a[this.c]; + if (this.k.am(b.Lk())) { + this.j = this.f ? b : b.md(); + this.i = -2; + return true; + } + } + this.i = -1; + this.g = -1; + return false; + }; + sfb(ZJe, "BasicFeatureMap/FeatureEIterator", 420); + feb(676, 420, Jve, She); + _2.ul = function The() { + return true; + }; + sfb(ZJe, "BasicFeatureMap/ResolvingFeatureEIterator", 676); + feb(968, 496, uKe, Uhe); + _2.pj = function Vhe() { + return this; + }; + sfb(ZJe, "EContentsEList/1", 968); + feb(969, 496, uKe, Whe); + _2.ul = function Xhe() { + return false; + }; + sfb(ZJe, "EContentsEList/2", 969); + feb(967, 287, vKe, Yhe); + _2.wl = function Zhe(a) { + }; + _2.Ob = function $he() { + return false; + }; + _2.Sb = function _he() { + return false; + }; + sfb(ZJe, "EContentsEList/FeatureIteratorImpl/1", 967); + feb(840, 593, oKe, aie); + _2.Ni = function bie() { + this.a = true; + }; + _2.Qj = function cie() { + return this.a; + }; + _2.Gk = function die() { + var a; + sLd(this); + if (Mvd(this.e)) { + a = this.a; + this.a = false; + qvd(this.e, new Q3d(this.e, 2, this.c, a, false)); + } else { + this.a = false; + } + }; + _2.a = false; + sfb(ZJe, "EDataTypeEList/Unsettable", 840); + feb(1958, 593, oKe, eie); + _2.Si = function fie() { + return true; + }; + sfb(ZJe, "EDataTypeUniqueEList", 1958); + feb(1959, 840, oKe, gie); + _2.Si = function hie() { + return true; + }; + sfb(ZJe, "EDataTypeUniqueEList/Unsettable", 1959); + feb(147, 83, oKe, iie); + _2.nl = function jie() { + return true; + }; + _2.Wi = function kie(a, b) { + return gZd(this, a, RD(b, 58)); + }; + sfb(ZJe, "EObjectContainmentEList/Resolving", 147); + feb(1184, 555, oKe, lie); + _2.nl = function mie() { + return true; + }; + _2.Wi = function nie(a, b) { + return gZd(this, a, RD(b, 58)); + }; + sfb(ZJe, "EObjectContainmentEList/Unsettable/Resolving", 1184); + feb(766, 14, oKe, oie); + _2.Ni = function pie2() { + this.a = true; + }; + _2.Qj = function qie() { + return this.a; + }; + _2.Gk = function rie() { + var a; + sLd(this); + if (Mvd(this.e)) { + a = this.a; + this.a = false; + qvd(this.e, new Q3d(this.e, 2, this.c, a, false)); + } else { + this.a = false; + } + }; + _2.a = false; + sfb(ZJe, "EObjectContainmentWithInverseEList/Unsettable", 766); + feb(1222, 766, oKe, sie); + _2.nl = function tie() { + return true; + }; + _2.Wi = function uie(a, b) { + return gZd(this, a, RD(b, 58)); + }; + sfb(ZJe, "EObjectContainmentWithInverseEList/Unsettable/Resolving", 1222); + feb(757, 505, oKe, vie); + _2.Ni = function wie() { + this.a = true; + }; + _2.Qj = function xie() { + return this.a; + }; + _2.Gk = function yie() { + var a; + sLd(this); + if (Mvd(this.e)) { + a = this.a; + this.a = false; + qvd(this.e, new Q3d(this.e, 2, this.c, a, false)); + } else { + this.a = false; + } + }; + _2.a = false; + sfb(ZJe, "EObjectEList/Unsettable", 757); + feb(338, 505, oKe, zie); + _2.nl = function Aie() { + return true; + }; + _2.Wi = function Bie(a, b) { + return gZd(this, a, RD(b, 58)); + }; + sfb(ZJe, "EObjectResolvingEList", 338); + feb(1844, 757, oKe, Cie); + _2.nl = function Die() { + return true; + }; + _2.Wi = function Eie(a, b) { + return gZd(this, a, RD(b, 58)); + }; + sfb(ZJe, "EObjectResolvingEList/Unsettable", 1844); + feb(1527, 1, {}, Hie); + var Fie; + sfb(ZJe, "EObjectValidator", 1527); + feb(559, 505, oKe, Iie); + _2.il = function Jie() { + return this.d; + }; + _2.jl = function Kie() { + return this.b; + }; + _2.Mj = function Lie() { + return true; + }; + _2.ml = function Mie() { + return true; + }; + _2.b = 0; + sfb(ZJe, "EObjectWithInverseEList", 559); + feb(1225, 559, oKe, Nie); + _2.ll = function Oie() { + return true; + }; + sfb(ZJe, "EObjectWithInverseEList/ManyInverse", 1225); + feb(635, 559, oKe, Pie); + _2.Ni = function Qie() { + this.a = true; + }; + _2.Qj = function Rie() { + return this.a; + }; + _2.Gk = function Sie() { + var a; + sLd(this); + if (Mvd(this.e)) { + a = this.a; + this.a = false; + qvd(this.e, new Q3d(this.e, 2, this.c, a, false)); + } else { + this.a = false; + } + }; + _2.a = false; + sfb(ZJe, "EObjectWithInverseEList/Unsettable", 635); + feb(1224, 635, oKe, Tie); + _2.ll = function Uie() { + return true; + }; + sfb(ZJe, "EObjectWithInverseEList/Unsettable/ManyInverse", 1224); + feb(767, 559, oKe, Vie); + _2.nl = function Wie() { + return true; + }; + _2.Wi = function Xie(a, b) { + return gZd(this, a, RD(b, 58)); + }; + sfb(ZJe, "EObjectWithInverseResolvingEList", 767); + feb(32, 767, oKe, Yie); + _2.ll = function Zie() { + return true; + }; + sfb(ZJe, "EObjectWithInverseResolvingEList/ManyInverse", 32); + feb(768, 635, oKe, $ie); + _2.nl = function _ie() { + return true; + }; + _2.Wi = function aje(a, b) { + return gZd(this, a, RD(b, 58)); + }; + sfb(ZJe, "EObjectWithInverseResolvingEList/Unsettable", 768); + feb(1223, 768, oKe, bje); + _2.ll = function cje() { + return true; + }; + sfb(ZJe, "EObjectWithInverseResolvingEList/Unsettable/ManyInverse", 1223); + feb(1185, 632, oKe); + _2.Li = function dje() { + return (this.b & 1792) == 0; + }; + _2.Ni = function eje() { + this.b |= 1; + }; + _2.kl = function fje() { + return (this.b & 4) != 0; + }; + _2.Mj = function gje() { + return (this.b & 40) != 0; + }; + _2.ll = function hje() { + return (this.b & 16) != 0; + }; + _2.ml = function ije() { + return (this.b & 8) != 0; + }; + _2.nl = function jje() { + return (this.b & cKe) != 0; + }; + _2.al = function kje() { + return (this.b & 32) != 0; + }; + _2.ol = function lje() { + return (this.b & gwe) != 0; + }; + _2.fk = function mje(a) { + return !this.d ? this.Lk().Hk().fk(a) : QRd(this.d, a); + }; + _2.Qj = function nje() { + return (this.b & 2) != 0 ? (this.b & 1) != 0 : this.i != 0; + }; + _2.Si = function oje() { + return (this.b & 128) != 0; + }; + _2.Gk = function qje() { + var a; + sLd(this); + if ((this.b & 2) != 0) { + if (Mvd(this.e)) { + a = (this.b & 1) != 0; + this.b &= -2; + eZd(this, new Q3d(this.e, 2, BYd(this.e.Dh(), this.Lk()), a, false)); + } else { + this.b &= -2; + } + } + }; + _2.Yi = function rje() { + return (this.b & 1536) == 0; + }; + _2.b = 0; + sfb(ZJe, "EcoreEList/Generic", 1185); + feb(1186, 1185, oKe, sje); + _2.Lk = function tje() { + return this.a; + }; + sfb(ZJe, "EcoreEList/Dynamic", 1186); + feb(765, 66, PIe, uje); + _2.aj = function vje(a) { + return IMd(this.a.a, a); + }; + sfb(ZJe, "EcoreEMap/1", 765); + feb(764, 83, oKe, wje); + _2.Mi = function xje(a, b) { + UNd(this.b, RD(b, 136)); + }; + _2.Oi = function yje(a, b) { + TNd(this.b); + }; + _2.Pi = function zje(a, b, c2) { + var d; + ++(d = this.b, RD(b, 136), d).e; + }; + _2.Qi = function Aje(a, b) { + VNd(this.b, RD(b, 136)); + }; + _2.Ri = function Bje(a, b, c2) { + VNd(this.b, RD(c2, 136)); + dE(c2) === dE(b) && RD(c2, 136).Ci(aOd(RD(b, 136).ld())); + UNd(this.b, RD(b, 136)); + }; + sfb(ZJe, "EcoreEMap/DelegateEObjectContainmentEList", 764); + feb(1220, 141, _Je, Cje); + sfb(ZJe, "EcoreEMap/Unsettable", 1220); + feb(1221, 764, oKe, Dje); + _2.Ni = function Eje() { + this.a = true; + }; + _2.Qj = function Fje() { + return this.a; + }; + _2.Gk = function Gje() { + var a; + sLd(this); + if (Mvd(this.e)) { + a = this.a; + this.a = false; + qvd(this.e, new Q3d(this.e, 2, this.c, a, false)); + } else { + this.a = false; + } + }; + _2.a = false; + sfb(ZJe, "EcoreEMap/Unsettable/UnsettableDelegateEObjectContainmentEList", 1221); + feb(1189, 215, Hxe, Zje); + _2.a = false; + _2.b = false; + sfb(ZJe, "EcoreUtil/Copier", 1189); + feb(759, 1, Ave, _je); + _2.Nb = function ake(a) { + Ztb(this, a); + }; + _2.Ob = function bke() { + return $je(this); + }; + _2.Pb = function cke() { + var a; + $je(this); + a = this.b; + this.b = null; + return a; + }; + _2.Qb = function dke() { + this.a.Qb(); + }; + sfb(ZJe, "EcoreUtil/ProperContentIterator", 759); + feb(1528, 1527, {}, gke); + var eke; + sfb(ZJe, "EcoreValidator", 1528); + var mke; + ufb(ZJe, "FeatureMapUtil/Validator"); + feb(1295, 1, { 2041: 1 }, rke); + _2.am = function ske(a) { + return true; + }; + sfb(ZJe, "FeatureMapUtil/1", 1295); + feb(773, 1, { 2041: 1 }, wke); + _2.am = function xke(a) { + var b; + if (this.c == a) + return true; + b = TD(Wjb(this.a, a)); + if (b == null) { + if (vke(this, a)) { + yke(this.a, a, (Geb(), Feb)); + return true; + } else { + yke(this.a, a, (Geb(), Eeb)); + return false; + } + } else { + return b == (Geb(), Feb); + } + }; + _2.e = false; + var tke; + sfb(ZJe, "FeatureMapUtil/BasicValidator", 773); + feb(774, 45, Hxe, zke); + sfb(ZJe, "FeatureMapUtil/BasicValidator/Cache", 774); + feb(509, 56, { 20: 1, 31: 1, 56: 1, 16: 1, 15: 1, 61: 1, 79: 1, 71: 1, 97: 1 }, Eke); + _2.bd = function Fke(a, b) { + Pfe(this.c, this.b, a, b); + }; + _2.Fc = function Gke(a) { + return Qfe(this.c, this.b, a); + }; + _2.cd = function Hke(a, b) { + return Sfe(this.c, this.b, a, b); + }; + _2.Gc = function Ike(a) { + return Ake(this, a); + }; + _2.Gi = function Jke(a, b) { + Ufe(this.c, this.b, a, b); + }; + _2.Wk = function Kke(a, b) { + return Xfe(this.c, this.b, a, b); + }; + _2.$i = function Lke(a) { + return hge(this.c, this.b, a, false); + }; + _2.Ii = function Mke() { + return Yfe(this.c, this.b); + }; + _2.Ji = function Nke() { + return Zfe(this.c, this.b); + }; + _2.Ki = function Oke(a) { + return $fe(this.c, this.b, a); + }; + _2.Xk = function Pke(a, b) { + return Bke(this, a, b); + }; + _2.$b = function Qke() { + Cke(this); + }; + _2.Hc = function Rke(a) { + return cge(this.c, this.b, a); + }; + _2.Ic = function Ske(a) { + return ege(this.c, this.b, a); + }; + _2.Xb = function Tke(a) { + return hge(this.c, this.b, a, true); + }; + _2.Fk = function Uke(a) { + return this; + }; + _2.dd = function Vke(a) { + return jge(this.c, this.b, a); + }; + _2.dc = function Wke() { + return Dke(this); + }; + _2.Qj = function Xke() { + return !pge(this.c, this.b); + }; + _2.Kc = function Yke() { + return qge(this.c, this.b); + }; + _2.ed = function Zke() { + return sge(this.c, this.b); + }; + _2.fd = function $ke(a) { + return tge(this.c, this.b, a); + }; + _2.Ti = function _ke(a, b) { + return vge(this.c, this.b, a, b); + }; + _2.Ui = function ale(a, b) { + wge(this.c, this.b, a, b); + }; + _2.gd = function ble(a) { + return xge(this.c, this.b, a); + }; + _2.Mc = function cle(a) { + return yge(this.c, this.b, a); + }; + _2.hd = function dle(a, b) { + return Ege(this.c, this.b, a, b); + }; + _2.Wb = function ele(a) { + bge(this.c, this.b); + Ake(this, RD(a, 15)); + }; + _2.gc = function fle() { + return Nge(this.c, this.b); + }; + _2.Pc = function gle() { + return Oge(this.c, this.b); + }; + _2.Qc = function hle(a) { + return Qge(this.c, this.b, a); + }; + _2.Ib = function ile() { + var a, b; + b = new Qhb(); + b.a += "["; + for (a = Yfe(this.c, this.b); Bhe(a); ) { + Nhb(b, Ghb(Dhe(a))); + Bhe(a) && (b.a += pve, b); + } + b.a += "]"; + return b.a; + }; + _2.Gk = function jle() { + bge(this.c, this.b); + }; + sfb(ZJe, "FeatureMapUtil/FeatureEList", 509); + feb(644, 39, GJe, lle); + _2.hj = function mle(a) { + return kle(this, a); + }; + _2.mj = function nle(a) { + var b, c2, d, e, f2, g, h; + switch (this.d) { + case 1: + case 2: { + f2 = a.jj(); + if (dE(f2) === dE(this.c) && kle(this, null) == a.hj(null)) { + this.g = a.ij(); + a.gj() == 1 && (this.d = 1); + return true; + } + break; + } + case 3: { + e = a.gj(); + switch (e) { + case 3: { + f2 = a.jj(); + if (dE(f2) === dE(this.c) && kle(this, null) == a.hj(null)) { + this.d = 5; + b = new ZHd(2); + WGd(b, this.g); + WGd(b, a.ij()); + this.g = b; + return true; + } + break; + } + } + break; + } + case 5: { + e = a.gj(); + switch (e) { + case 3: { + f2 = a.jj(); + if (dE(f2) === dE(this.c) && kle(this, null) == a.hj(null)) { + c2 = RD(this.g, 16); + c2.Fc(a.ij()); + return true; + } + break; + } + } + break; + } + case 4: { + e = a.gj(); + switch (e) { + case 3: { + f2 = a.jj(); + if (dE(f2) === dE(this.c) && kle(this, null) == a.hj(null)) { + this.d = 1; + this.g = a.ij(); + return true; + } + break; + } + case 4: { + f2 = a.jj(); + if (dE(f2) === dE(this.c) && kle(this, null) == a.hj(null)) { + this.d = 6; + h = new ZHd(2); + WGd(h, this.n); + WGd(h, a.kj()); + this.n = h; + g = cD(WC(kE, 1), Pwe, 28, 15, [this.o, a.lj()]); + this.g = g; + return true; + } + break; + } + } + break; + } + case 6: { + e = a.gj(); + switch (e) { + case 4: { + f2 = a.jj(); + if (dE(f2) === dE(this.c) && kle(this, null) == a.hj(null)) { + c2 = RD(this.n, 16); + c2.Fc(a.kj()); + g = RD(this.g, 53); + d = $C(kE, Pwe, 28, g.length + 1, 15, 1); + hib(g, 0, d, 0, g.length); + d[g.length] = a.lj(); + this.g = d; + return true; + } + break; + } + } + break; + } + } + return false; + }; + sfb(ZJe, "FeatureMapUtil/FeatureENotificationImpl", 644); + feb(564, 509, { 20: 1, 31: 1, 56: 1, 16: 1, 15: 1, 61: 1, 79: 1, 160: 1, 220: 1, 2036: 1, 71: 1, 97: 1 }, ole); + _2.Ol = function ple(a, b) { + return Qfe(this.c, a, b); + }; + _2.Pl = function qle(a, b, c2) { + return Xfe(this.c, a, b, c2); + }; + _2.Ql = function rle(a, b, c2) { + return age(this.c, a, b, c2); + }; + _2.Rl = function sle() { + return this; + }; + _2.Sl = function tle(a, b) { + return ige(this.c, a, b); + }; + _2.Tl = function ule(a) { + return RD(hge(this.c, this.b, a, false), 76).Lk(); + }; + _2.Ul = function vle(a) { + return RD(hge(this.c, this.b, a, false), 76).md(); + }; + _2.Vl = function wle() { + return this.a; + }; + _2.Wl = function xle(a) { + return !pge(this.c, a); + }; + _2.Xl = function yle(a, b) { + Fge(this.c, a, b); + }; + _2.Yl = function zle(a) { + return Gge(this.c, a); + }; + _2.Zl = function Ale(a) { + Sge(this.c, a); + }; + sfb(ZJe, "FeatureMapUtil/FeatureFeatureMap", 564); + feb(1294, 1, $Je, Ble); + _2.Fk = function Cle(a) { + return hge(this.b, this.a, -1, a); + }; + _2.Qj = function Dle() { + return !pge(this.b, this.a); + }; + _2.Wb = function Ele(a) { + Fge(this.b, this.a, a); + }; + _2.Gk = function Fle() { + bge(this.b, this.a); + }; + sfb(ZJe, "FeatureMapUtil/FeatureValue", 1294); + var Gle, Hle, Ile, Jle, Kle; + var Vbb = ufb(hLe, "AnyType"); + feb(680, 63, swe, Mle); + sfb(hLe, "InvalidDatatypeValueException", 680); + var Xbb = ufb(hLe, iLe); + var Ybb = ufb(hLe, jLe); + var Zbb = ufb(hLe, kLe); + var Nle; + var Ple; + var Rle, Sle, Tle, Ule, Vle, Wle, Xle, Yle, Zle, $le, _le, ame, bme, cme, dme, eme, fme, gme, hme, ime, jme, kme, lme, mme; + feb(844, 516, { 110: 1, 94: 1, 93: 1, 58: 1, 54: 1, 99: 1, 857: 1 }, ome); + _2.Lh = function pme(a, b, c2) { + switch (a) { + case 0: + if (c2) + return !this.c && (this.c = new Uge(this, 0)), this.c; + return !this.c && (this.c = new Uge(this, 0)), this.c.b; + case 1: + if (c2) + return !this.c && (this.c = new Uge(this, 0)), RD(rge(this.c, (nme(), Sle)), 160); + return (!this.c && (this.c = new Uge(this, 0)), RD(RD(rge(this.c, (nme(), Sle)), 160), 220)).Vl(); + case 2: + if (c2) + return !this.b && (this.b = new Uge(this, 2)), this.b; + return !this.b && (this.b = new Uge(this, 2)), this.b.b; + } + return zvd(this, a - AYd(this.ii()), vYd((this.j & 2) == 0 ? this.ii() : (!this.k && (this.k = new fUd()), this.k).Nk(), a), b, c2); + }; + _2.Uh = function qme(a, b, c2) { + var d; + switch (b) { + case 0: + return !this.c && (this.c = new Uge(this, 0)), _fe(this.c, a, c2); + case 1: + return (!this.c && (this.c = new Uge(this, 0)), RD(RD(rge(this.c, (nme(), Sle)), 160), 71)).Xk(a, c2); + case 2: + return !this.b && (this.b = new Uge(this, 2)), _fe(this.b, a, c2); + } + return d = RD(vYd((this.j & 2) == 0 ? this.ii() : (!this.k && (this.k = new fUd()), this.k).Nk(), b), 69), d.wk().Ak(this, Yvd(this), b - AYd(this.ii()), a, c2); + }; + _2.Wh = function rme(a) { + switch (a) { + case 0: + return !!this.c && this.c.i != 0; + case 1: + return !(!this.c && (this.c = new Uge(this, 0)), RD(rge(this.c, (nme(), Sle)), 160)).dc(); + case 2: + return !!this.b && this.b.i != 0; + } + return Avd(this, a - AYd(this.ii()), vYd((this.j & 2) == 0 ? this.ii() : (!this.k && (this.k = new fUd()), this.k).Nk(), a)); + }; + _2.bi = function sme(a, b) { + switch (a) { + case 0: + !this.c && (this.c = new Uge(this, 0)); + Dge(this.c, b); + return; + case 1: + (!this.c && (this.c = new Uge(this, 0)), RD(RD(rge(this.c, (nme(), Sle)), 160), 220)).Wb(b); + return; + case 2: + !this.b && (this.b = new Uge(this, 2)); + Dge(this.b, b); + return; + } + Bvd(this, a - AYd(this.ii()), vYd((this.j & 2) == 0 ? this.ii() : (!this.k && (this.k = new fUd()), this.k).Nk(), a), b); + }; + _2.ii = function tme() { + return nme(), Rle; + }; + _2.ki = function ume(a) { + switch (a) { + case 0: + !this.c && (this.c = new Uge(this, 0)); + sLd(this.c); + return; + case 1: + (!this.c && (this.c = new Uge(this, 0)), RD(rge(this.c, (nme(), Sle)), 160)).$b(); + return; + case 2: + !this.b && (this.b = new Uge(this, 2)); + sLd(this.b); + return; + } + Cvd(this, a - AYd(this.ii()), vYd((this.j & 2) == 0 ? this.ii() : (!this.k && (this.k = new fUd()), this.k).Nk(), a)); + }; + _2.Ib = function vme() { + var a; + if ((this.j & 4) != 0) + return awd(this); + a = new Shb(awd(this)); + a.a += " (mixed: "; + Mhb(a, this.c); + a.a += ", anyAttribute: "; + Mhb(a, this.b); + a.a += ")"; + return a.a; + }; + sfb(lLe, "AnyTypeImpl", 844); + feb(681, 516, { 110: 1, 94: 1, 93: 1, 58: 1, 54: 1, 99: 1, 2119: 1, 681: 1 }, yme); + _2.Lh = function zme(a, b, c2) { + switch (a) { + case 0: + return this.a; + case 1: + return this.b; + } + return zvd(this, a - AYd((nme(), cme)), vYd((this.j & 2) == 0 ? cme : (!this.k && (this.k = new fUd()), this.k).Nk(), a), b, c2); + }; + _2.Wh = function Ame(a) { + switch (a) { + case 0: + return this.a != null; + case 1: + return this.b != null; + } + return Avd(this, a - AYd((nme(), cme)), vYd((this.j & 2) == 0 ? cme : (!this.k && (this.k = new fUd()), this.k).Nk(), a)); + }; + _2.bi = function Bme(a, b) { + switch (a) { + case 0: + wme(this, WD(b)); + return; + case 1: + xme(this, WD(b)); + return; + } + Bvd(this, a - AYd((nme(), cme)), vYd((this.j & 2) == 0 ? cme : (!this.k && (this.k = new fUd()), this.k).Nk(), a), b); + }; + _2.ii = function Cme() { + return nme(), cme; + }; + _2.ki = function Dme(a) { + switch (a) { + case 0: + this.a = null; + return; + case 1: + this.b = null; + return; + } + Cvd(this, a - AYd((nme(), cme)), vYd((this.j & 2) == 0 ? cme : (!this.k && (this.k = new fUd()), this.k).Nk(), a)); + }; + _2.Ib = function Eme() { + var a; + if ((this.j & 4) != 0) + return awd(this); + a = new Shb(awd(this)); + a.a += " (data: "; + Nhb(a, this.a); + a.a += ", target: "; + Nhb(a, this.b); + a.a += ")"; + return a.a; + }; + _2.a = null; + _2.b = null; + sfb(lLe, "ProcessingInstructionImpl", 681); + feb(682, 844, { 110: 1, 94: 1, 93: 1, 58: 1, 54: 1, 99: 1, 857: 1, 2120: 1, 682: 1 }, Hme); + _2.Lh = function Ime(a, b, c2) { + switch (a) { + case 0: + if (c2) + return !this.c && (this.c = new Uge(this, 0)), this.c; + return !this.c && (this.c = new Uge(this, 0)), this.c.b; + case 1: + if (c2) + return !this.c && (this.c = new Uge(this, 0)), RD(rge(this.c, (nme(), Sle)), 160); + return (!this.c && (this.c = new Uge(this, 0)), RD(RD(rge(this.c, (nme(), Sle)), 160), 220)).Vl(); + case 2: + if (c2) + return !this.b && (this.b = new Uge(this, 2)), this.b; + return !this.b && (this.b = new Uge(this, 2)), this.b.b; + case 3: + return !this.c && (this.c = new Uge(this, 0)), WD(ige(this.c, (nme(), fme), true)); + case 4: + return Ije(this.a, (!this.c && (this.c = new Uge(this, 0)), WD(ige(this.c, (nme(), fme), true)))); + case 5: + return this.a; + } + return zvd(this, a - AYd((nme(), eme)), vYd((this.j & 2) == 0 ? eme : (!this.k && (this.k = new fUd()), this.k).Nk(), a), b, c2); + }; + _2.Wh = function Jme(a) { + switch (a) { + case 0: + return !!this.c && this.c.i != 0; + case 1: + return !(!this.c && (this.c = new Uge(this, 0)), RD(rge(this.c, (nme(), Sle)), 160)).dc(); + case 2: + return !!this.b && this.b.i != 0; + case 3: + return !this.c && (this.c = new Uge(this, 0)), WD(ige(this.c, (nme(), fme), true)) != null; + case 4: + return Ije(this.a, (!this.c && (this.c = new Uge(this, 0)), WD(ige(this.c, (nme(), fme), true)))) != null; + case 5: + return !!this.a; + } + return Avd(this, a - AYd((nme(), eme)), vYd((this.j & 2) == 0 ? eme : (!this.k && (this.k = new fUd()), this.k).Nk(), a)); + }; + _2.bi = function Kme(a, b) { + switch (a) { + case 0: + !this.c && (this.c = new Uge(this, 0)); + Dge(this.c, b); + return; + case 1: + (!this.c && (this.c = new Uge(this, 0)), RD(RD(rge(this.c, (nme(), Sle)), 160), 220)).Wb(b); + return; + case 2: + !this.b && (this.b = new Uge(this, 2)); + Dge(this.b, b); + return; + case 3: + Gme(this, WD(b)); + return; + case 4: + Gme(this, Hje(this.a, b)); + return; + case 5: + Fme(this, RD(b, 156)); + return; + } + Bvd(this, a - AYd((nme(), eme)), vYd((this.j & 2) == 0 ? eme : (!this.k && (this.k = new fUd()), this.k).Nk(), a), b); + }; + _2.ii = function Lme() { + return nme(), eme; + }; + _2.ki = function Mme(a) { + switch (a) { + case 0: + !this.c && (this.c = new Uge(this, 0)); + sLd(this.c); + return; + case 1: + (!this.c && (this.c = new Uge(this, 0)), RD(rge(this.c, (nme(), Sle)), 160)).$b(); + return; + case 2: + !this.b && (this.b = new Uge(this, 2)); + sLd(this.b); + return; + case 3: + !this.c && (this.c = new Uge(this, 0)); + Fge(this.c, (nme(), fme), null); + return; + case 4: + Gme(this, Hje(this.a, null)); + return; + case 5: + this.a = null; + return; + } + Cvd(this, a - AYd((nme(), eme)), vYd((this.j & 2) == 0 ? eme : (!this.k && (this.k = new fUd()), this.k).Nk(), a)); + }; + sfb(lLe, "SimpleAnyTypeImpl", 682); + feb(683, 516, { 110: 1, 94: 1, 93: 1, 58: 1, 54: 1, 99: 1, 2121: 1, 683: 1 }, Nme); + _2.Lh = function Ome(a, b, c2) { + switch (a) { + case 0: + if (c2) + return !this.a && (this.a = new Uge(this, 0)), this.a; + return !this.a && (this.a = new Uge(this, 0)), this.a.b; + case 1: + return c2 ? (!this.b && (this.b = new DVd((JTd(), FTd), C8, this, 1)), this.b) : (!this.b && (this.b = new DVd((JTd(), FTd), C8, this, 1)), dOd(this.b)); + case 2: + return c2 ? (!this.c && (this.c = new DVd((JTd(), FTd), C8, this, 2)), this.c) : (!this.c && (this.c = new DVd((JTd(), FTd), C8, this, 2)), dOd(this.c)); + case 3: + return !this.a && (this.a = new Uge(this, 0)), rge(this.a, (nme(), ime)); + case 4: + return !this.a && (this.a = new Uge(this, 0)), rge(this.a, (nme(), jme)); + case 5: + return !this.a && (this.a = new Uge(this, 0)), rge(this.a, (nme(), lme)); + case 6: + return !this.a && (this.a = new Uge(this, 0)), rge(this.a, (nme(), mme)); + } + return zvd(this, a - AYd((nme(), hme)), vYd((this.j & 2) == 0 ? hme : (!this.k && (this.k = new fUd()), this.k).Nk(), a), b, c2); + }; + _2.Uh = function Pme(a, b, c2) { + var d; + switch (b) { + case 0: + return !this.a && (this.a = new Uge(this, 0)), _fe(this.a, a, c2); + case 1: + return !this.b && (this.b = new DVd((JTd(), FTd), C8, this, 1)), BVd(this.b, a, c2); + case 2: + return !this.c && (this.c = new DVd((JTd(), FTd), C8, this, 2)), BVd(this.c, a, c2); + case 5: + return !this.a && (this.a = new Uge(this, 0)), Bke(rge(this.a, (nme(), lme)), a, c2); + } + return d = RD(vYd((this.j & 2) == 0 ? (nme(), hme) : (!this.k && (this.k = new fUd()), this.k).Nk(), b), 69), d.wk().Ak(this, Yvd(this), b - AYd((nme(), hme)), a, c2); + }; + _2.Wh = function Qme(a) { + switch (a) { + case 0: + return !!this.a && this.a.i != 0; + case 1: + return !!this.b && this.b.f != 0; + case 2: + return !!this.c && this.c.f != 0; + case 3: + return !this.a && (this.a = new Uge(this, 0)), !Dke(rge(this.a, (nme(), ime))); + case 4: + return !this.a && (this.a = new Uge(this, 0)), !Dke(rge(this.a, (nme(), jme))); + case 5: + return !this.a && (this.a = new Uge(this, 0)), !Dke(rge(this.a, (nme(), lme))); + case 6: + return !this.a && (this.a = new Uge(this, 0)), !Dke(rge(this.a, (nme(), mme))); + } + return Avd(this, a - AYd((nme(), hme)), vYd((this.j & 2) == 0 ? hme : (!this.k && (this.k = new fUd()), this.k).Nk(), a)); + }; + _2.bi = function Rme(a, b) { + switch (a) { + case 0: + !this.a && (this.a = new Uge(this, 0)); + Dge(this.a, b); + return; + case 1: + !this.b && (this.b = new DVd((JTd(), FTd), C8, this, 1)); + CVd(this.b, b); + return; + case 2: + !this.c && (this.c = new DVd((JTd(), FTd), C8, this, 2)); + CVd(this.c, b); + return; + case 3: + !this.a && (this.a = new Uge(this, 0)); + Cke(rge(this.a, (nme(), ime))); + !this.a && (this.a = new Uge(this, 0)); + Ake(rge(this.a, ime), RD(b, 16)); + return; + case 4: + !this.a && (this.a = new Uge(this, 0)); + Cke(rge(this.a, (nme(), jme))); + !this.a && (this.a = new Uge(this, 0)); + Ake(rge(this.a, jme), RD(b, 16)); + return; + case 5: + !this.a && (this.a = new Uge(this, 0)); + Cke(rge(this.a, (nme(), lme))); + !this.a && (this.a = new Uge(this, 0)); + Ake(rge(this.a, lme), RD(b, 16)); + return; + case 6: + !this.a && (this.a = new Uge(this, 0)); + Cke(rge(this.a, (nme(), mme))); + !this.a && (this.a = new Uge(this, 0)); + Ake(rge(this.a, mme), RD(b, 16)); + return; + } + Bvd(this, a - AYd((nme(), hme)), vYd((this.j & 2) == 0 ? hme : (!this.k && (this.k = new fUd()), this.k).Nk(), a), b); + }; + _2.ii = function Sme() { + return nme(), hme; + }; + _2.ki = function Tme(a) { + switch (a) { + case 0: + !this.a && (this.a = new Uge(this, 0)); + sLd(this.a); + return; + case 1: + !this.b && (this.b = new DVd((JTd(), FTd), C8, this, 1)); + this.b.c.$b(); + return; + case 2: + !this.c && (this.c = new DVd((JTd(), FTd), C8, this, 2)); + this.c.c.$b(); + return; + case 3: + !this.a && (this.a = new Uge(this, 0)); + Cke(rge(this.a, (nme(), ime))); + return; + case 4: + !this.a && (this.a = new Uge(this, 0)); + Cke(rge(this.a, (nme(), jme))); + return; + case 5: + !this.a && (this.a = new Uge(this, 0)); + Cke(rge(this.a, (nme(), lme))); + return; + case 6: + !this.a && (this.a = new Uge(this, 0)); + Cke(rge(this.a, (nme(), mme))); + return; + } + Cvd(this, a - AYd((nme(), hme)), vYd((this.j & 2) == 0 ? hme : (!this.k && (this.k = new fUd()), this.k).Nk(), a)); + }; + _2.Ib = function Ume() { + var a; + if ((this.j & 4) != 0) + return awd(this); + a = new Shb(awd(this)); + a.a += " (mixed: "; + Mhb(a, this.a); + a.a += ")"; + return a.a; + }; + sfb(lLe, "XMLTypeDocumentRootImpl", 683); + feb(2028, 720, { 110: 1, 94: 1, 93: 1, 480: 1, 155: 1, 58: 1, 114: 1, 54: 1, 99: 1, 158: 1, 119: 1, 120: 1, 2122: 1 }, rne); + _2.ri = function sne(a, b) { + switch (a.hk()) { + case 7: + case 8: + case 9: + case 10: + case 16: + case 22: + case 23: + case 24: + case 25: + case 26: + case 32: + case 33: + case 34: + case 36: + case 37: + case 44: + case 45: + case 50: + case 51: + case 53: + case 55: + case 56: + case 57: + case 58: + case 60: + case 61: + case 4: + return b == null ? null : jeb(b); + case 19: + case 28: + case 29: + case 35: + case 38: + case 39: + case 41: + case 46: + case 52: + case 54: + case 5: + return WD(b); + case 6: + return _me(RD(b, 195)); + case 12: + case 47: + case 49: + case 11: + return tAd(this, a, b); + case 13: + return b == null ? null : yib(RD(b, 247)); + case 15: + case 14: + return b == null ? null : ane(Kfb(UD(b))); + case 17: + return bne((nme(), b)); + case 18: + return bne(b); + case 21: + case 20: + return b == null ? null : cne(RD(b, 161).a); + case 27: + return dne(RD(b, 195)); + case 30: + return ene((nme(), RD(b, 15))); + case 31: + return ene(RD(b, 15)); + case 40: + return hne((nme(), b)); + case 42: + return fne((nme(), b)); + case 43: + return fne(b); + case 59: + case 48: + return gne((nme(), b)); + default: + throw Adb(new agb(VHe + a.xe() + WHe)); + } + }; + _2.si = function tne(a) { + var b, c2, d, e, f2; + switch (a.G == -1 && (a.G = (c2 = BXd(a), c2 ? fZd(c2.vi(), a) : -1)), a.G) { + case 0: + return b = new ome(), b; + case 1: + return d = new yme(), d; + case 2: + return e = new Hme(), e; + case 3: + return f2 = new Nme(), f2; + default: + throw Adb(new agb(ZHe + a.zb + WHe)); + } + }; + _2.ti = function une(a, b) { + var c2, d, e, f2, g, h, i2, j, k, l, m, n, o2, p, q, r; + switch (a.hk()) { + case 5: + case 52: + case 4: + return b; + case 6: + return ine(b); + case 8: + case 7: + return b == null ? null : $me(b); + case 9: + return b == null ? null : $eb(Oeb((d = nue(b, true), d.length > 0 && (BFb(0, d.length), d.charCodeAt(0) == 43) ? (BFb(1, d.length + 1), d.substr(1)) : d), -128, 127) << 24 >> 24); + case 10: + return b == null ? null : $eb(Oeb((e = nue(b, true), e.length > 0 && (BFb(0, e.length), e.charCodeAt(0) == 43) ? (BFb(1, e.length + 1), e.substr(1)) : e), -128, 127) << 24 >> 24); + case 11: + return WD(uAd(this, (nme(), Vle), b)); + case 12: + return WD(uAd(this, (nme(), Wle), b)); + case 13: + return b == null ? null : new Bib(nue(b, true)); + case 15: + case 14: + return jne(b); + case 16: + return WD(uAd(this, (nme(), Xle), b)); + case 17: + return kne((nme(), b)); + case 18: + return kne(b); + case 28: + case 29: + case 35: + case 38: + case 39: + case 41: + case 54: + case 19: + return nue(b, true); + case 21: + case 20: + return lne(b); + case 22: + return WD(uAd(this, (nme(), Yle), b)); + case 23: + return WD(uAd(this, (nme(), Zle), b)); + case 24: + return WD(uAd(this, (nme(), $le), b)); + case 25: + return WD(uAd(this, (nme(), _le), b)); + case 26: + return WD(uAd(this, (nme(), ame), b)); + case 27: + return mne(b); + case 30: + return nne((nme(), b)); + case 31: + return nne(b); + case 32: + return b == null ? null : sgb(Oeb((k = nue(b, true), k.length > 0 && (BFb(0, k.length), k.charCodeAt(0) == 43) ? (BFb(1, k.length + 1), k.substr(1)) : k), qwe, lve)); + case 33: + return b == null ? null : new ejb((l = nue(b, true), l.length > 0 && (BFb(0, l.length), l.charCodeAt(0) == 43) ? (BFb(1, l.length + 1), l.substr(1)) : l)); + case 34: + return b == null ? null : sgb(Oeb((m = nue(b, true), m.length > 0 && (BFb(0, m.length), m.charCodeAt(0) == 43) ? (BFb(1, m.length + 1), m.substr(1)) : m), qwe, lve)); + case 36: + return b == null ? null : Hgb(Peb((n = nue(b, true), n.length > 0 && (BFb(0, n.length), n.charCodeAt(0) == 43) ? (BFb(1, n.length + 1), n.substr(1)) : n))); + case 37: + return b == null ? null : Hgb(Peb((o2 = nue(b, true), o2.length > 0 && (BFb(0, o2.length), o2.charCodeAt(0) == 43) ? (BFb(1, o2.length + 1), o2.substr(1)) : o2))); + case 40: + return qne((nme(), b)); + case 42: + return one2((nme(), b)); + case 43: + return one2(b); + case 44: + return b == null ? null : new ejb((p = nue(b, true), p.length > 0 && (BFb(0, p.length), p.charCodeAt(0) == 43) ? (BFb(1, p.length + 1), p.substr(1)) : p)); + case 45: + return b == null ? null : new ejb((q = nue(b, true), q.length > 0 && (BFb(0, q.length), q.charCodeAt(0) == 43) ? (BFb(1, q.length + 1), q.substr(1)) : q)); + case 46: + return nue(b, false); + case 47: + return WD(uAd(this, (nme(), bme), b)); + case 59: + case 48: + return pne((nme(), b)); + case 49: + return WD(uAd(this, (nme(), dme), b)); + case 50: + return b == null ? null : bhb(Oeb((r = nue(b, true), r.length > 0 && (BFb(0, r.length), r.charCodeAt(0) == 43) ? (BFb(1, r.length + 1), r.substr(1)) : r), BKe, 32767) << 16 >> 16); + case 51: + return b == null ? null : bhb(Oeb((f2 = nue(b, true), f2.length > 0 && (BFb(0, f2.length), f2.charCodeAt(0) == 43) ? (BFb(1, f2.length + 1), f2.substr(1)) : f2), BKe, 32767) << 16 >> 16); + case 53: + return WD(uAd(this, (nme(), gme), b)); + case 55: + return b == null ? null : bhb(Oeb((g = nue(b, true), g.length > 0 && (BFb(0, g.length), g.charCodeAt(0) == 43) ? (BFb(1, g.length + 1), g.substr(1)) : g), BKe, 32767) << 16 >> 16); + case 56: + return b == null ? null : bhb(Oeb((h = nue(b, true), h.length > 0 && (BFb(0, h.length), h.charCodeAt(0) == 43) ? (BFb(1, h.length + 1), h.substr(1)) : h), BKe, 32767) << 16 >> 16); + case 57: + return b == null ? null : Hgb(Peb((i2 = nue(b, true), i2.length > 0 && (BFb(0, i2.length), i2.charCodeAt(0) == 43) ? (BFb(1, i2.length + 1), i2.substr(1)) : i2))); + case 58: + return b == null ? null : Hgb(Peb((j = nue(b, true), j.length > 0 && (BFb(0, j.length), j.charCodeAt(0) == 43) ? (BFb(1, j.length + 1), j.substr(1)) : j))); + case 60: + return b == null ? null : sgb(Oeb((c2 = nue(b, true), c2.length > 0 && (BFb(0, c2.length), c2.charCodeAt(0) == 43) ? (BFb(1, c2.length + 1), c2.substr(1)) : c2), qwe, lve)); + case 61: + return b == null ? null : sgb(Oeb(nue(b, true), qwe, lve)); + default: + throw Adb(new agb(VHe + a.xe() + WHe)); + } + }; + var Vme, Wme, Xme, Yme; + sfb(lLe, "XMLTypeFactoryImpl", 2028); + feb(594, 184, { 110: 1, 94: 1, 93: 1, 155: 1, 197: 1, 58: 1, 241: 1, 114: 1, 54: 1, 99: 1, 158: 1, 184: 1, 119: 1, 120: 1, 690: 1, 2044: 1, 594: 1 }, Bne); + _2.N = false; + _2.O = false; + var wne = false; + sfb(lLe, "XMLTypePackageImpl", 594); + feb(1961, 1, { 851: 1 }, Ene); + _2.Kk = function Fne() { + return rue(), que; + }; + sfb(lLe, "XMLTypePackageImpl/1", 1961); + feb(1970, 1, OKe, Gne); + _2.fk = function Hne(a) { + return bE(a); + }; + _2.gk = function Ine(a) { + return $C(qJ, Nve, 2, a, 6, 1); + }; + sfb(lLe, "XMLTypePackageImpl/10", 1970); + feb(1971, 1, OKe, Jne); + _2.fk = function Kne(a) { + return bE(a); + }; + _2.gk = function Lne(a) { + return $C(qJ, Nve, 2, a, 6, 1); + }; + sfb(lLe, "XMLTypePackageImpl/11", 1971); + feb(1972, 1, OKe, Mne); + _2.fk = function Nne(a) { + return bE(a); + }; + _2.gk = function One(a) { + return $C(qJ, Nve, 2, a, 6, 1); + }; + sfb(lLe, "XMLTypePackageImpl/12", 1972); + feb(1973, 1, OKe, Pne); + _2.fk = function Qne(a) { + return _D(a); + }; + _2.gk = function Rne(a) { + return $C(VI, Nve, 345, a, 7, 1); + }; + sfb(lLe, "XMLTypePackageImpl/13", 1973); + feb(1974, 1, OKe, Sne); + _2.fk = function Tne(a) { + return bE(a); + }; + _2.gk = function Une(a) { + return $C(qJ, Nve, 2, a, 6, 1); + }; + sfb(lLe, "XMLTypePackageImpl/14", 1974); + feb(1975, 1, OKe, Vne); + _2.fk = function Wne(a) { + return ZD(a, 15); + }; + _2.gk = function Xne(a) { + return $C(QK, Ize, 15, a, 0, 1); + }; + sfb(lLe, "XMLTypePackageImpl/15", 1975); + feb(1976, 1, OKe, Yne); + _2.fk = function Zne(a) { + return ZD(a, 15); + }; + _2.gk = function $ne(a) { + return $C(QK, Ize, 15, a, 0, 1); + }; + sfb(lLe, "XMLTypePackageImpl/16", 1976); + feb(1977, 1, OKe, _ne); + _2.fk = function aoe(a) { + return bE(a); + }; + _2.gk = function boe(a) { + return $C(qJ, Nve, 2, a, 6, 1); + }; + sfb(lLe, "XMLTypePackageImpl/17", 1977); + feb(1978, 1, OKe, coe); + _2.fk = function doe(a) { + return ZD(a, 161); + }; + _2.gk = function eoe(a) { + return $C(ZI, Nve, 161, a, 0, 1); + }; + sfb(lLe, "XMLTypePackageImpl/18", 1978); + feb(1979, 1, OKe, foe); + _2.fk = function goe(a) { + return bE(a); + }; + _2.gk = function hoe(a) { + return $C(qJ, Nve, 2, a, 6, 1); + }; + sfb(lLe, "XMLTypePackageImpl/19", 1979); + feb(1962, 1, OKe, ioe); + _2.fk = function joe(a) { + return ZD(a, 857); + }; + _2.gk = function koe(a) { + return $C(Vbb, rve, 857, a, 0, 1); + }; + sfb(lLe, "XMLTypePackageImpl/2", 1962); + feb(1980, 1, OKe, loe); + _2.fk = function moe(a) { + return bE(a); + }; + _2.gk = function noe(a) { + return $C(qJ, Nve, 2, a, 6, 1); + }; + sfb(lLe, "XMLTypePackageImpl/20", 1980); + feb(1981, 1, OKe, ooe); + _2.fk = function poe(a) { + return bE(a); + }; + _2.gk = function qoe(a) { + return $C(qJ, Nve, 2, a, 6, 1); + }; + sfb(lLe, "XMLTypePackageImpl/21", 1981); + feb(1982, 1, OKe, roe); + _2.fk = function soe(a) { + return bE(a); + }; + _2.gk = function toe(a) { + return $C(qJ, Nve, 2, a, 6, 1); + }; + sfb(lLe, "XMLTypePackageImpl/22", 1982); + feb(1983, 1, OKe, uoe); + _2.fk = function voe(a) { + return bE(a); + }; + _2.gk = function woe(a) { + return $C(qJ, Nve, 2, a, 6, 1); + }; + sfb(lLe, "XMLTypePackageImpl/23", 1983); + feb(1984, 1, OKe, xoe); + _2.fk = function yoe(a) { + return ZD(a, 195); + }; + _2.gk = function zoe(a) { + return $C(gE, Nve, 195, a, 0, 2); + }; + sfb(lLe, "XMLTypePackageImpl/24", 1984); + feb(1985, 1, OKe, Aoe); + _2.fk = function Boe(a) { + return bE(a); + }; + _2.gk = function Coe(a) { + return $C(qJ, Nve, 2, a, 6, 1); + }; + sfb(lLe, "XMLTypePackageImpl/25", 1985); + feb(1986, 1, OKe, Doe); + _2.fk = function Eoe(a) { + return bE(a); + }; + _2.gk = function Foe(a) { + return $C(qJ, Nve, 2, a, 6, 1); + }; + sfb(lLe, "XMLTypePackageImpl/26", 1986); + feb(1987, 1, OKe, Goe); + _2.fk = function Hoe(a) { + return ZD(a, 15); + }; + _2.gk = function Ioe(a) { + return $C(QK, Ize, 15, a, 0, 1); + }; + sfb(lLe, "XMLTypePackageImpl/27", 1987); + feb(1988, 1, OKe, Joe); + _2.fk = function Koe(a) { + return ZD(a, 15); + }; + _2.gk = function Loe(a) { + return $C(QK, Ize, 15, a, 0, 1); + }; + sfb(lLe, "XMLTypePackageImpl/28", 1988); + feb(1989, 1, OKe, Moe); + _2.fk = function Noe(a) { + return bE(a); + }; + _2.gk = function Ooe(a) { + return $C(qJ, Nve, 2, a, 6, 1); + }; + sfb(lLe, "XMLTypePackageImpl/29", 1989); + feb(1963, 1, OKe, Poe); + _2.fk = function Qoe(a) { + return ZD(a, 681); + }; + _2.gk = function Roe(a) { + return $C(Xbb, rve, 2119, a, 0, 1); + }; + sfb(lLe, "XMLTypePackageImpl/3", 1963); + feb(1990, 1, OKe, Soe); + _2.fk = function Toe(a) { + return ZD(a, 17); + }; + _2.gk = function Uoe(a) { + return $C(bJ, Nve, 17, a, 0, 1); + }; + sfb(lLe, "XMLTypePackageImpl/30", 1990); + feb(1991, 1, OKe, Voe); + _2.fk = function Woe(a) { + return bE(a); + }; + _2.gk = function Xoe(a) { + return $C(qJ, Nve, 2, a, 6, 1); + }; + sfb(lLe, "XMLTypePackageImpl/31", 1991); + feb(1992, 1, OKe, Yoe); + _2.fk = function Zoe(a) { + return ZD(a, 168); + }; + _2.gk = function $oe(a) { + return $C(eJ, Nve, 168, a, 0, 1); + }; + sfb(lLe, "XMLTypePackageImpl/32", 1992); + feb(1993, 1, OKe, _oe); + _2.fk = function ape(a) { + return bE(a); + }; + _2.gk = function bpe(a) { + return $C(qJ, Nve, 2, a, 6, 1); + }; + sfb(lLe, "XMLTypePackageImpl/33", 1993); + feb(1994, 1, OKe, cpe); + _2.fk = function dpe(a) { + return bE(a); + }; + _2.gk = function epe(a) { + return $C(qJ, Nve, 2, a, 6, 1); + }; + sfb(lLe, "XMLTypePackageImpl/34", 1994); + feb(1995, 1, OKe, fpe); + _2.fk = function gpe(a) { + return bE(a); + }; + _2.gk = function hpe(a) { + return $C(qJ, Nve, 2, a, 6, 1); + }; + sfb(lLe, "XMLTypePackageImpl/35", 1995); + feb(1996, 1, OKe, ipe); + _2.fk = function jpe(a) { + return bE(a); + }; + _2.gk = function kpe(a) { + return $C(qJ, Nve, 2, a, 6, 1); + }; + sfb(lLe, "XMLTypePackageImpl/36", 1996); + feb(1997, 1, OKe, lpe); + _2.fk = function mpe(a) { + return ZD(a, 15); + }; + _2.gk = function npe(a) { + return $C(QK, Ize, 15, a, 0, 1); + }; + sfb(lLe, "XMLTypePackageImpl/37", 1997); + feb(1998, 1, OKe, ope); + _2.fk = function ppe(a) { + return ZD(a, 15); + }; + _2.gk = function qpe(a) { + return $C(QK, Ize, 15, a, 0, 1); + }; + sfb(lLe, "XMLTypePackageImpl/38", 1998); + feb(1999, 1, OKe, rpe); + _2.fk = function spe(a) { + return bE(a); + }; + _2.gk = function tpe(a) { + return $C(qJ, Nve, 2, a, 6, 1); + }; + sfb(lLe, "XMLTypePackageImpl/39", 1999); + feb(1964, 1, OKe, upe); + _2.fk = function vpe(a) { + return ZD(a, 682); + }; + _2.gk = function wpe(a) { + return $C(Ybb, rve, 2120, a, 0, 1); + }; + sfb(lLe, "XMLTypePackageImpl/4", 1964); + feb(2e3, 1, OKe, xpe); + _2.fk = function ype(a) { + return bE(a); + }; + _2.gk = function zpe(a) { + return $C(qJ, Nve, 2, a, 6, 1); + }; + sfb(lLe, "XMLTypePackageImpl/40", 2e3); + feb(2001, 1, OKe, Ape); + _2.fk = function Bpe(a) { + return bE(a); + }; + _2.gk = function Cpe(a) { + return $C(qJ, Nve, 2, a, 6, 1); + }; + sfb(lLe, "XMLTypePackageImpl/41", 2001); + feb(2002, 1, OKe, Dpe); + _2.fk = function Epe(a) { + return bE(a); + }; + _2.gk = function Fpe(a) { + return $C(qJ, Nve, 2, a, 6, 1); + }; + sfb(lLe, "XMLTypePackageImpl/42", 2002); + feb(2003, 1, OKe, Gpe); + _2.fk = function Hpe(a) { + return bE(a); + }; + _2.gk = function Ipe(a) { + return $C(qJ, Nve, 2, a, 6, 1); + }; + sfb(lLe, "XMLTypePackageImpl/43", 2003); + feb(2004, 1, OKe, Jpe); + _2.fk = function Kpe(a) { + return bE(a); + }; + _2.gk = function Lpe(a) { + return $C(qJ, Nve, 2, a, 6, 1); + }; + sfb(lLe, "XMLTypePackageImpl/44", 2004); + feb(2005, 1, OKe, Mpe); + _2.fk = function Npe(a) { + return ZD(a, 191); + }; + _2.gk = function Ope(a) { + return $C(lJ, Nve, 191, a, 0, 1); + }; + sfb(lLe, "XMLTypePackageImpl/45", 2005); + feb(2006, 1, OKe, Ppe); + _2.fk = function Qpe(a) { + return bE(a); + }; + _2.gk = function Rpe(a) { + return $C(qJ, Nve, 2, a, 6, 1); + }; + sfb(lLe, "XMLTypePackageImpl/46", 2006); + feb(2007, 1, OKe, Spe); + _2.fk = function Tpe(a) { + return bE(a); + }; + _2.gk = function Upe(a) { + return $C(qJ, Nve, 2, a, 6, 1); + }; + sfb(lLe, "XMLTypePackageImpl/47", 2007); + feb(2008, 1, OKe, Vpe); + _2.fk = function Wpe(a) { + return bE(a); + }; + _2.gk = function Xpe(a) { + return $C(qJ, Nve, 2, a, 6, 1); + }; + sfb(lLe, "XMLTypePackageImpl/48", 2008); + feb(2009, 1, OKe, Ype); + _2.fk = function Zpe(a) { + return ZD(a, 191); + }; + _2.gk = function $pe(a) { + return $C(lJ, Nve, 191, a, 0, 1); + }; + sfb(lLe, "XMLTypePackageImpl/49", 2009); + feb(1965, 1, OKe, _pe); + _2.fk = function aqe(a) { + return ZD(a, 683); + }; + _2.gk = function bqe(a) { + return $C(Zbb, rve, 2121, a, 0, 1); + }; + sfb(lLe, "XMLTypePackageImpl/5", 1965); + feb(2010, 1, OKe, cqe); + _2.fk = function dqe(a) { + return ZD(a, 168); + }; + _2.gk = function eqe(a) { + return $C(eJ, Nve, 168, a, 0, 1); + }; + sfb(lLe, "XMLTypePackageImpl/50", 2010); + feb(2011, 1, OKe, fqe); + _2.fk = function gqe(a) { + return bE(a); + }; + _2.gk = function hqe(a) { + return $C(qJ, Nve, 2, a, 6, 1); + }; + sfb(lLe, "XMLTypePackageImpl/51", 2011); + feb(2012, 1, OKe, iqe); + _2.fk = function jqe(a) { + return ZD(a, 17); + }; + _2.gk = function kqe(a) { + return $C(bJ, Nve, 17, a, 0, 1); + }; + sfb(lLe, "XMLTypePackageImpl/52", 2012); + feb(1966, 1, OKe, lqe); + _2.fk = function mqe(a) { + return bE(a); + }; + _2.gk = function nqe(a) { + return $C(qJ, Nve, 2, a, 6, 1); + }; + sfb(lLe, "XMLTypePackageImpl/6", 1966); + feb(1967, 1, OKe, oqe); + _2.fk = function pqe(a) { + return ZD(a, 195); + }; + _2.gk = function qqe(a) { + return $C(gE, Nve, 195, a, 0, 2); + }; + sfb(lLe, "XMLTypePackageImpl/7", 1967); + feb(1968, 1, OKe, rqe); + _2.fk = function sqe(a) { + return $D(a); + }; + _2.gk = function tqe(a) { + return $C(QI, Nve, 485, a, 8, 1); + }; + sfb(lLe, "XMLTypePackageImpl/8", 1968); + feb(1969, 1, OKe, uqe); + _2.fk = function vqe(a) { + return ZD(a, 222); + }; + _2.gk = function wqe(a) { + return $C(RI, Nve, 222, a, 0, 1); + }; + sfb(lLe, "XMLTypePackageImpl/9", 1969); + var xqe, yqe; + var Eqe, Fqe; + var Jqe; + feb(55, 63, swe, Lqe); + sfb(LLe, "RegEx/ParseException", 55); + feb(836, 1, {}, Tqe); + _2.bm = function Uqe(a) { + return a < this.j && ihb(this.i, a) == 63; + }; + _2.cm = function Vqe() { + var a, b, c2, d, e; + if (this.c != 10) + throw Adb(new Lqe(TId((Hde(), VIe)))); + a = this.a; + switch (a) { + case 101: + a = 27; + break; + case 102: + a = 12; + break; + case 110: + a = 10; + break; + case 114: + a = 13; + break; + case 116: + a = 9; + break; + case 120: + Mqe(this); + if (this.c != 0) + throw Adb(new Lqe(TId((Hde(), sJe)))); + if (this.a == 123) { + e = 0; + c2 = 0; + do { + Mqe(this); + if (this.c != 0) + throw Adb(new Lqe(TId((Hde(), sJe)))); + if ((e = Xqe(this.a)) < 0) + break; + if (c2 > c2 * 16) + throw Adb(new Lqe(TId((Hde(), tJe)))); + c2 = c2 * 16 + e; + } while (true); + if (this.a != 125) + throw Adb(new Lqe(TId((Hde(), uJe)))); + if (c2 > MLe) + throw Adb(new Lqe(TId((Hde(), vJe)))); + a = c2; + } else { + e = 0; + if (this.c != 0 || (e = Xqe(this.a)) < 0) + throw Adb(new Lqe(TId((Hde(), sJe)))); + c2 = e; + Mqe(this); + if (this.c != 0 || (e = Xqe(this.a)) < 0) + throw Adb(new Lqe(TId((Hde(), sJe)))); + c2 = c2 * 16 + e; + a = c2; + } + break; + case 117: + d = 0; + Mqe(this); + if (this.c != 0 || (d = Xqe(this.a)) < 0) + throw Adb(new Lqe(TId((Hde(), sJe)))); + b = d; + Mqe(this); + if (this.c != 0 || (d = Xqe(this.a)) < 0) + throw Adb(new Lqe(TId((Hde(), sJe)))); + b = b * 16 + d; + Mqe(this); + if (this.c != 0 || (d = Xqe(this.a)) < 0) + throw Adb(new Lqe(TId((Hde(), sJe)))); + b = b * 16 + d; + Mqe(this); + if (this.c != 0 || (d = Xqe(this.a)) < 0) + throw Adb(new Lqe(TId((Hde(), sJe)))); + b = b * 16 + d; + a = b; + break; + case 118: + Mqe(this); + if (this.c != 0 || (d = Xqe(this.a)) < 0) + throw Adb(new Lqe(TId((Hde(), sJe)))); + b = d; + Mqe(this); + if (this.c != 0 || (d = Xqe(this.a)) < 0) + throw Adb(new Lqe(TId((Hde(), sJe)))); + b = b * 16 + d; + Mqe(this); + if (this.c != 0 || (d = Xqe(this.a)) < 0) + throw Adb(new Lqe(TId((Hde(), sJe)))); + b = b * 16 + d; + Mqe(this); + if (this.c != 0 || (d = Xqe(this.a)) < 0) + throw Adb(new Lqe(TId((Hde(), sJe)))); + b = b * 16 + d; + Mqe(this); + if (this.c != 0 || (d = Xqe(this.a)) < 0) + throw Adb(new Lqe(TId((Hde(), sJe)))); + b = b * 16 + d; + Mqe(this); + if (this.c != 0 || (d = Xqe(this.a)) < 0) + throw Adb(new Lqe(TId((Hde(), sJe)))); + b = b * 16 + d; + if (b > MLe) + throw Adb(new Lqe(TId((Hde(), "parser.descappe.4")))); + a = b; + break; + case 65: + case 90: + case 122: + throw Adb(new Lqe(TId((Hde(), wJe)))); + } + return a; + }; + _2.dm = function Wqe(a) { + var b, c2; + switch (a) { + case 100: + c2 = (this.e & 32) == 32 ? hte("Nd", true) : (Vse(), Bse); + break; + case 68: + c2 = (this.e & 32) == 32 ? hte("Nd", false) : (Vse(), Ise); + break; + case 119: + c2 = (this.e & 32) == 32 ? hte("IsWord", true) : (Vse(), Rse); + break; + case 87: + c2 = (this.e & 32) == 32 ? hte("IsWord", false) : (Vse(), Kse); + break; + case 115: + c2 = (this.e & 32) == 32 ? hte("IsSpace", true) : (Vse(), Mse); + break; + case 83: + c2 = (this.e & 32) == 32 ? hte("IsSpace", false) : (Vse(), Jse); + break; + default: + throw Adb(new yz((b = a, NLe + b.toString(16)))); + } + return c2; + }; + _2.em = function Yqe(a) { + var b, c2, d, e, f2, g, h, i2, j, k, l, m; + this.b = 1; + Mqe(this); + b = null; + if (this.c == 0 && this.a == 94) { + Mqe(this); + if (a) { + k = (Vse(), Vse(), new xte(5)); + } else { + b = (Vse(), Vse(), new xte(4)); + rte(b, 0, MLe); + k = new xte(4); + } + } else { + k = (Vse(), Vse(), new xte(4)); + } + e = true; + while ((m = this.c) != 1) { + if (m == 0 && this.a == 93 && !e) + break; + e = false; + c2 = this.a; + d = false; + if (m == 10) { + switch (c2) { + case 100: + case 68: + case 119: + case 87: + case 115: + case 83: + ute(k, this.dm(c2)); + d = true; + break; + case 105: + case 73: + case 99: + case 67: + c2 = this.um(k, c2); + c2 < 0 && (d = true); + break; + case 112: + case 80: + l = Sqe(this, c2); + if (!l) + throw Adb(new Lqe(TId((Hde(), hJe)))); + ute(k, l); + d = true; + break; + default: + c2 = this.cm(); + } + } else if (m == 20) { + g = phb(this.i, 58, this.d); + if (g < 0) + throw Adb(new Lqe(TId((Hde(), iJe)))); + h = true; + if (ihb(this.i, this.d) == 94) { + ++this.d; + h = false; + } + f2 = zhb(this.i, this.d, g); + i2 = ite(f2, h, (this.e & 512) == 512); + if (!i2) + throw Adb(new Lqe(TId((Hde(), kJe)))); + ute(k, i2); + d = true; + if (g + 1 >= this.j || ihb(this.i, g + 1) != 93) + throw Adb(new Lqe(TId((Hde(), iJe)))); + this.d = g + 2; + } + Mqe(this); + if (!d) { + if (this.c != 0 || this.a != 45) { + rte(k, c2, c2); + } else { + Mqe(this); + if ((m = this.c) == 1) + throw Adb(new Lqe(TId((Hde(), jJe)))); + if (m == 0 && this.a == 93) { + rte(k, c2, c2); + rte(k, 45, 45); + } else { + j = this.a; + m == 10 && (j = this.cm()); + Mqe(this); + rte(k, c2, j); + } + } + } + (this.e & gwe) == gwe && this.c == 0 && this.a == 44 && Mqe(this); + } + if (this.c == 1) + throw Adb(new Lqe(TId((Hde(), jJe)))); + if (b) { + wte(b, k); + k = b; + } + vte(k); + ste(k); + this.b = 0; + Mqe(this); + return k; + }; + _2.fm = function Zqe() { + var a, b, c2, d; + c2 = this.em(false); + while ((d = this.c) != 7) { + a = this.a; + if (d == 0 && (a == 45 || a == 38) || d == 4) { + Mqe(this); + if (this.c != 9) + throw Adb(new Lqe(TId((Hde(), pJe)))); + b = this.em(false); + if (d == 4) + ute(c2, b); + else if (a == 45) + wte(c2, b); + else if (a == 38) + tte(c2, b); + else + throw Adb(new yz("ASSERT")); + } else { + throw Adb(new Lqe(TId((Hde(), qJe)))); + } + } + Mqe(this); + return c2; + }; + _2.gm = function $qe() { + var a, b; + a = this.a - 48; + b = (Vse(), Vse(), new eue(12, null, a)); + !this.g && (this.g = new gyb()); + dyb(this.g, new Bte(a)); + Mqe(this); + return b; + }; + _2.hm = function _qe() { + Mqe(this); + return Vse(), Nse; + }; + _2.im = function are() { + Mqe(this); + return Vse(), Lse; + }; + _2.jm = function bre() { + throw Adb(new Lqe(TId((Hde(), xJe)))); + }; + _2.km = function cre() { + throw Adb(new Lqe(TId((Hde(), xJe)))); + }; + _2.lm = function dre() { + Mqe(this); + return fte(); + }; + _2.mm = function ere() { + Mqe(this); + return Vse(), Pse; + }; + _2.nm = function fre() { + Mqe(this); + return Vse(), Sse; + }; + _2.om = function gre() { + var a; + if (this.d >= this.j || ((a = ihb(this.i, this.d++)) & 65504) != 64) + throw Adb(new Lqe(TId((Hde(), dJe)))); + Mqe(this); + return Vse(), Vse(), new Hte(0, a - 64); + }; + _2.pm = function hre() { + Mqe(this); + return gte(); + }; + _2.qm = function ire() { + Mqe(this); + return Vse(), Tse; + }; + _2.rm = function jre() { + var a; + a = (Vse(), Vse(), new Hte(0, 105)); + Mqe(this); + return a; + }; + _2.sm = function kre() { + Mqe(this); + return Vse(), Qse; + }; + _2.tm = function lre() { + Mqe(this); + return Vse(), Ose; + }; + _2.um = function mre(a, b) { + return this.cm(); + }; + _2.vm = function nre() { + Mqe(this); + return Vse(), Gse; + }; + _2.wm = function ore() { + var a, b, c2, d, e; + if (this.d + 1 >= this.j) + throw Adb(new Lqe(TId((Hde(), aJe)))); + d = -1; + b = null; + a = ihb(this.i, this.d); + if (49 <= a && a <= 57) { + d = a - 48; + !this.g && (this.g = new gyb()); + dyb(this.g, new Bte(d)); + ++this.d; + if (ihb(this.i, this.d) != 41) + throw Adb(new Lqe(TId((Hde(), ZIe)))); + ++this.d; + } else { + a == 63 && --this.d; + Mqe(this); + b = Pqe(this); + switch (b.e) { + case 20: + case 21: + case 22: + case 23: + break; + case 8: + if (this.c != 7) + throw Adb(new Lqe(TId((Hde(), ZIe)))); + break; + default: + throw Adb(new Lqe(TId((Hde(), bJe)))); + } + } + Mqe(this); + e = Qqe(this); + c2 = null; + if (e.e == 2) { + if (e.Pm() != 2) + throw Adb(new Lqe(TId((Hde(), cJe)))); + c2 = e.Lm(1); + e = e.Lm(0); + } + if (this.c != 7) + throw Adb(new Lqe(TId((Hde(), ZIe)))); + Mqe(this); + return Vse(), Vse(), new Ute(d, b, e, c2); + }; + _2.xm = function pre() { + Mqe(this); + return Vse(), Hse; + }; + _2.ym = function qre() { + var a; + Mqe(this); + a = _se(24, Qqe(this)); + if (this.c != 7) + throw Adb(new Lqe(TId((Hde(), ZIe)))); + Mqe(this); + return a; + }; + _2.zm = function rre() { + var a; + Mqe(this); + a = _se(20, Qqe(this)); + if (this.c != 7) + throw Adb(new Lqe(TId((Hde(), ZIe)))); + Mqe(this); + return a; + }; + _2.Am = function sre() { + var a; + Mqe(this); + a = _se(22, Qqe(this)); + if (this.c != 7) + throw Adb(new Lqe(TId((Hde(), ZIe)))); + Mqe(this); + return a; + }; + _2.Bm = function tre() { + var a, b, c2, d, e; + a = 0; + c2 = 0; + b = -1; + while (this.d < this.j) { + b = ihb(this.i, this.d); + e = rse(b); + if (e == 0) + break; + a |= e; + ++this.d; + } + if (this.d >= this.j) + throw Adb(new Lqe(TId((Hde(), $Ie)))); + if (b == 45) { + ++this.d; + while (this.d < this.j) { + b = ihb(this.i, this.d); + e = rse(b); + if (e == 0) + break; + c2 |= e; + ++this.d; + } + if (this.d >= this.j) + throw Adb(new Lqe(TId((Hde(), $Ie)))); + } + if (b == 58) { + ++this.d; + Mqe(this); + d = ate(Qqe(this), a, c2); + if (this.c != 7) + throw Adb(new Lqe(TId((Hde(), ZIe)))); + Mqe(this); + } else if (b == 41) { + ++this.d; + Mqe(this); + d = ate(Qqe(this), a, c2); + } else + throw Adb(new Lqe(TId((Hde(), _Ie)))); + return d; + }; + _2.Cm = function ure() { + var a; + Mqe(this); + a = _se(21, Qqe(this)); + if (this.c != 7) + throw Adb(new Lqe(TId((Hde(), ZIe)))); + Mqe(this); + return a; + }; + _2.Dm = function vre() { + var a; + Mqe(this); + a = _se(23, Qqe(this)); + if (this.c != 7) + throw Adb(new Lqe(TId((Hde(), ZIe)))); + Mqe(this); + return a; + }; + _2.Em = function wre() { + var a, b; + Mqe(this); + a = this.f++; + b = bte(Qqe(this), a); + if (this.c != 7) + throw Adb(new Lqe(TId((Hde(), ZIe)))); + Mqe(this); + return b; + }; + _2.Fm = function xre() { + var a; + Mqe(this); + a = bte(Qqe(this), 0); + if (this.c != 7) + throw Adb(new Lqe(TId((Hde(), ZIe)))); + Mqe(this); + return a; + }; + _2.Gm = function yre(a) { + Mqe(this); + if (this.c == 5) { + Mqe(this); + return $se(a, (Vse(), Vse(), new Kte(9, a))); + } else + return $se(a, (Vse(), Vse(), new Kte(3, a))); + }; + _2.Hm = function zre(a) { + var b; + Mqe(this); + b = (Vse(), Vse(), new iue(2)); + if (this.c == 5) { + Mqe(this); + hue2(b, Ese); + hue2(b, a); + } else { + hue2(b, a); + hue2(b, Ese); + } + return b; + }; + _2.Im = function Are(a) { + Mqe(this); + if (this.c == 5) { + Mqe(this); + return Vse(), Vse(), new Kte(9, a); + } else + return Vse(), Vse(), new Kte(3, a); + }; + _2.a = 0; + _2.b = 0; + _2.c = 0; + _2.d = 0; + _2.e = 0; + _2.f = 1; + _2.g = null; + _2.j = 0; + sfb(LLe, "RegEx/RegexParser", 836); + feb(1947, 836, {}, Gre); + _2.bm = function Hre(a) { + return false; + }; + _2.cm = function Ire() { + return Dre(this); + }; + _2.dm = function Kre(a) { + return Ere(a); + }; + _2.em = function Lre(a) { + return Fre(this); + }; + _2.fm = function Mre() { + throw Adb(new Lqe(TId((Hde(), xJe)))); + }; + _2.gm = function Nre() { + throw Adb(new Lqe(TId((Hde(), xJe)))); + }; + _2.hm = function Ore() { + throw Adb(new Lqe(TId((Hde(), xJe)))); + }; + _2.im = function Pre() { + throw Adb(new Lqe(TId((Hde(), xJe)))); + }; + _2.jm = function Qre() { + Mqe(this); + return Ere(67); + }; + _2.km = function Rre() { + Mqe(this); + return Ere(73); + }; + _2.lm = function Sre() { + throw Adb(new Lqe(TId((Hde(), xJe)))); + }; + _2.mm = function Tre() { + throw Adb(new Lqe(TId((Hde(), xJe)))); + }; + _2.nm = function Ure() { + throw Adb(new Lqe(TId((Hde(), xJe)))); + }; + _2.om = function Vre() { + Mqe(this); + return Ere(99); + }; + _2.pm = function Wre() { + throw Adb(new Lqe(TId((Hde(), xJe)))); + }; + _2.qm = function Xre() { + throw Adb(new Lqe(TId((Hde(), xJe)))); + }; + _2.rm = function Yre() { + Mqe(this); + return Ere(105); + }; + _2.sm = function Zre() { + throw Adb(new Lqe(TId((Hde(), xJe)))); + }; + _2.tm = function $re() { + throw Adb(new Lqe(TId((Hde(), xJe)))); + }; + _2.um = function _re(a, b) { + return ute(a, Ere(b)), -1; + }; + _2.vm = function ase() { + Mqe(this); + return Vse(), Vse(), new Hte(0, 94); + }; + _2.wm = function bse() { + throw Adb(new Lqe(TId((Hde(), xJe)))); + }; + _2.xm = function cse() { + Mqe(this); + return Vse(), Vse(), new Hte(0, 36); + }; + _2.ym = function dse() { + throw Adb(new Lqe(TId((Hde(), xJe)))); + }; + _2.zm = function ese() { + throw Adb(new Lqe(TId((Hde(), xJe)))); + }; + _2.Am = function fse() { + throw Adb(new Lqe(TId((Hde(), xJe)))); + }; + _2.Bm = function gse() { + throw Adb(new Lqe(TId((Hde(), xJe)))); + }; + _2.Cm = function hse() { + throw Adb(new Lqe(TId((Hde(), xJe)))); + }; + _2.Dm = function ise() { + throw Adb(new Lqe(TId((Hde(), xJe)))); + }; + _2.Em = function jse() { + var a; + Mqe(this); + a = bte(Qqe(this), 0); + if (this.c != 7) + throw Adb(new Lqe(TId((Hde(), ZIe)))); + Mqe(this); + return a; + }; + _2.Fm = function kse() { + throw Adb(new Lqe(TId((Hde(), xJe)))); + }; + _2.Gm = function lse(a) { + Mqe(this); + return $se(a, (Vse(), Vse(), new Kte(3, a))); + }; + _2.Hm = function mse(a) { + var b; + Mqe(this); + b = (Vse(), Vse(), new iue(2)); + hue2(b, a); + hue2(b, Ese); + return b; + }; + _2.Im = function nse(a) { + Mqe(this); + return Vse(), Vse(), new Kte(3, a); + }; + var Bre = null, Cre = null; + sfb(LLe, "RegEx/ParserForXMLSchema", 1947); + feb(122, 1, ZLe, Wse); + _2.Jm = function Xse(a) { + throw Adb(new yz("Not supported.")); + }; + _2.Km = function dte() { + return -1; + }; + _2.Lm = function ete(a) { + return null; + }; + _2.Mm = function jte() { + return null; + }; + _2.Nm = function mte(a) { + }; + _2.Om = function nte(a) { + }; + _2.Pm = function ote() { + return 0; + }; + _2.Ib = function pte() { + return this.Qm(0); + }; + _2.Qm = function qte(a) { + return this.e == 11 ? "." : ""; + }; + _2.e = 0; + var vse, wse, xse, yse, zse, Ase = null, Bse, Cse = null, Dse, Ese, Fse = null, Gse, Hse, Ise, Jse, Kse, Lse, Mse, Nse, Ose, Pse, Qse, Rse, Sse, Tse; + var qdb = sfb(LLe, "RegEx/Token", 122); + feb(138, 122, { 3: 1, 138: 1, 122: 1 }, xte); + _2.Qm = function Ate(a) { + var b, c2, d; + if (this.e == 4) { + if (this == Dse) + c2 = "."; + else if (this == Bse) + c2 = "\\d"; + else if (this == Rse) + c2 = "\\w"; + else if (this == Mse) + c2 = "\\s"; + else { + d = new Qhb(); + d.a += "["; + for (b = 0; b < this.b.length; b += 2) { + (a & gwe) != 0 && b > 0 && (d.a += ",", d); + if (this.b[b] === this.b[b + 1]) { + Nhb(d, zte(this.b[b])); + } else { + Nhb(d, zte(this.b[b])); + d.a += "-"; + Nhb(d, zte(this.b[b + 1])); + } + } + d.a += "]"; + c2 = d.a; + } + } else { + if (this == Ise) + c2 = "\\D"; + else if (this == Kse) + c2 = "\\W"; + else if (this == Jse) + c2 = "\\S"; + else { + d = new Qhb(); + d.a += "[^"; + for (b = 0; b < this.b.length; b += 2) { + (a & gwe) != 0 && b > 0 && (d.a += ",", d); + if (this.b[b] === this.b[b + 1]) { + Nhb(d, zte(this.b[b])); + } else { + Nhb(d, zte(this.b[b])); + d.a += "-"; + Nhb(d, zte(this.b[b + 1])); + } + } + d.a += "]"; + c2 = d.a; + } + } + return c2; + }; + _2.a = false; + _2.c = false; + sfb(LLe, "RegEx/RangeToken", 138); + feb(592, 1, { 592: 1 }, Bte); + _2.a = 0; + sfb(LLe, "RegEx/RegexParser/ReferencePosition", 592); + feb(591, 1, { 3: 1, 591: 1 }, Dte); + _2.Fb = function Ete(a) { + var b; + if (a == null) + return false; + if (!ZD(a, 591)) + return false; + b = RD(a, 591); + return lhb(this.b, b.b) && this.a == b.a; + }; + _2.Hb = function Fte() { + return ohb(this.b + "/" + pse(this.a)); + }; + _2.Ib = function Gte() { + return this.c.Qm(this.a); + }; + _2.a = 0; + sfb(LLe, "RegEx/RegularExpression", 591); + feb(228, 122, ZLe, Hte); + _2.Km = function Ite() { + return this.a; + }; + _2.Qm = function Jte(a) { + var b, c2, d; + switch (this.e) { + case 0: + switch (this.a) { + case 124: + case 42: + case 43: + case 63: + case 40: + case 41: + case 46: + case 91: + case 123: + case 92: + d = "\\" + XD(this.a & Bwe); + break; + case 12: + d = "\\f"; + break; + case 10: + d = "\\n"; + break; + case 13: + d = "\\r"; + break; + case 9: + d = "\\t"; + break; + case 27: + d = "\\e"; + break; + default: + if (this.a >= txe) { + c2 = (b = this.a >>> 0, "0" + b.toString(16)); + d = "\\v" + zhb(c2, c2.length - 6, c2.length); + } else + d = "" + XD(this.a & Bwe); + } + break; + case 8: + this == Gse || this == Hse ? d = "" + XD(this.a & Bwe) : d = "\\" + XD(this.a & Bwe); + break; + default: + d = null; + } + return d; + }; + _2.a = 0; + sfb(LLe, "RegEx/Token/CharToken", 228); + feb(318, 122, ZLe, Kte); + _2.Lm = function Lte(a) { + return this.a; + }; + _2.Nm = function Mte(a) { + this.b = a; + }; + _2.Om = function Nte(a) { + this.c = a; + }; + _2.Pm = function Ote() { + return 1; + }; + _2.Qm = function Pte(a) { + var b; + if (this.e == 3) { + if (this.c < 0 && this.b < 0) { + b = this.a.Qm(a) + "*"; + } else if (this.c == this.b) { + b = this.a.Qm(a) + "{" + this.c + "}"; + } else if (this.c >= 0 && this.b >= 0) { + b = this.a.Qm(a) + "{" + this.c + "," + this.b + "}"; + } else if (this.c >= 0 && this.b < 0) { + b = this.a.Qm(a) + "{" + this.c + ",}"; + } else + throw Adb(new yz("Token#toString(): CLOSURE " + this.c + pve + this.b)); + } else { + if (this.c < 0 && this.b < 0) { + b = this.a.Qm(a) + "*?"; + } else if (this.c == this.b) { + b = this.a.Qm(a) + "{" + this.c + "}?"; + } else if (this.c >= 0 && this.b >= 0) { + b = this.a.Qm(a) + "{" + this.c + "," + this.b + "}?"; + } else if (this.c >= 0 && this.b < 0) { + b = this.a.Qm(a) + "{" + this.c + ",}?"; + } else + throw Adb(new yz("Token#toString(): NONGREEDYCLOSURE " + this.c + pve + this.b)); + } + return b; + }; + _2.b = 0; + _2.c = 0; + sfb(LLe, "RegEx/Token/ClosureToken", 318); + feb(837, 122, ZLe, Qte); + _2.Lm = function Rte(a) { + return a == 0 ? this.a : this.b; + }; + _2.Pm = function Ste() { + return 2; + }; + _2.Qm = function Tte(a) { + var b; + this.b.e == 3 && this.b.Lm(0) == this.a ? b = this.a.Qm(a) + "+" : this.b.e == 9 && this.b.Lm(0) == this.a ? b = this.a.Qm(a) + "+?" : b = this.a.Qm(a) + ("" + this.b.Qm(a)); + return b; + }; + sfb(LLe, "RegEx/Token/ConcatToken", 837); + feb(1945, 122, ZLe, Ute); + _2.Lm = function Vte(a) { + if (a == 0) + return this.d; + if (a == 1) + return this.b; + throw Adb(new yz("Internal Error: " + a)); + }; + _2.Pm = function Wte() { + return !this.b ? 1 : 2; + }; + _2.Qm = function Xte(a) { + var b; + this.c > 0 ? b = "(?(" + this.c + ")" : this.a.e == 8 ? b = "(?(" + this.a + ")" : b = "(?" + this.a; + !this.b ? b += this.d + ")" : b += this.d + "|" + this.b + ")"; + return b; + }; + _2.c = 0; + sfb(LLe, "RegEx/Token/ConditionToken", 1945); + feb(1946, 122, ZLe, Yte); + _2.Lm = function Zte(a) { + return this.b; + }; + _2.Pm = function $te() { + return 1; + }; + _2.Qm = function _te(a) { + return "(?" + (this.a == 0 ? "" : pse(this.a)) + (this.c == 0 ? "" : pse(this.c)) + ":" + this.b.Qm(a) + ")"; + }; + _2.a = 0; + _2.c = 0; + sfb(LLe, "RegEx/Token/ModifierToken", 1946); + feb(838, 122, ZLe, aue); + _2.Lm = function bue(a) { + return this.a; + }; + _2.Pm = function cue() { + return 1; + }; + _2.Qm = function due(a) { + var b; + b = null; + switch (this.e) { + case 6: + this.b == 0 ? b = "(?:" + this.a.Qm(a) + ")" : b = "(" + this.a.Qm(a) + ")"; + break; + case 20: + b = "(?=" + this.a.Qm(a) + ")"; + break; + case 21: + b = "(?!" + this.a.Qm(a) + ")"; + break; + case 22: + b = "(?<=" + this.a.Qm(a) + ")"; + break; + case 23: + b = "(?" + this.a.Qm(a) + ")"; + } + return b; + }; + _2.b = 0; + sfb(LLe, "RegEx/Token/ParenToken", 838); + feb(530, 122, { 3: 1, 122: 1, 530: 1 }, eue); + _2.Mm = function fue() { + return this.b; + }; + _2.Qm = function gue(a) { + return this.e == 12 ? "\\" + this.a : tse(this.b); + }; + _2.a = 0; + sfb(LLe, "RegEx/Token/StringToken", 530); + feb(477, 122, ZLe, iue); + _2.Jm = function jue(a) { + hue2(this, a); + }; + _2.Lm = function kue(a) { + return RD(eyb(this.a, a), 122); + }; + _2.Pm = function lue() { + return !this.a ? 0 : this.a.a.c.length; + }; + _2.Qm = function mue(a) { + var b, c2, d, e, f2; + if (this.e == 1) { + if (this.a.a.c.length == 2) { + b = RD(eyb(this.a, 0), 122); + c2 = RD(eyb(this.a, 1), 122); + c2.e == 3 && c2.Lm(0) == b ? e = b.Qm(a) + "+" : c2.e == 9 && c2.Lm(0) == b ? e = b.Qm(a) + "+?" : e = b.Qm(a) + ("" + c2.Qm(a)); + } else { + f2 = new Qhb(); + for (d = 0; d < this.a.a.c.length; d++) { + Nhb(f2, RD(eyb(this.a, d), 122).Qm(a)); + } + e = f2.a; + } + return e; + } + if (this.a.a.c.length == 2 && RD(eyb(this.a, 1), 122).e == 7) { + e = RD(eyb(this.a, 0), 122).Qm(a) + "?"; + } else if (this.a.a.c.length == 2 && RD(eyb(this.a, 0), 122).e == 7) { + e = RD(eyb(this.a, 1), 122).Qm(a) + "??"; + } else { + f2 = new Qhb(); + Nhb(f2, RD(eyb(this.a, 0), 122).Qm(a)); + for (d = 1; d < this.a.a.c.length; d++) { + f2.a += "|"; + Nhb(f2, RD(eyb(this.a, d), 122).Qm(a)); + } + e = f2.a; + } + return e; + }; + sfb(LLe, "RegEx/Token/UnionToken", 477); + feb(527, 1, { 600: 1 }, oue); + _2.Ib = function pue() { + return this.a.b; + }; + sfb($Le, "XMLTypeUtil/PatternMatcherImpl", 527); + feb(1707, 1527, {}, sue); + var que; + sfb($Le, "XMLTypeValidator", 1707); + feb(270, 1, Vve, vue); + _2.Jc = function wue(a) { + xgb(this, a); + }; + _2.Kc = function xue() { + return (this.b - this.a) * this.c < 0 ? tue : new Rue(this); + }; + _2.a = 0; + _2.b = 0; + _2.c = 0; + var tue; + sfb(aMe, "ExclusiveRange", 270); + feb(1084, 1, Jve, Cue); + _2.Rb = function Due(a) { + RD(a, 17); + yue(); + }; + _2.Nb = function Eue(a) { + Ztb(this, a); + }; + _2.Pb = function Hue() { + return zue(); + }; + _2.Ub = function Jue() { + return Aue(); + }; + _2.Wb = function Mue(a) { + RD(a, 17); + Bue(); + }; + _2.Ob = function Fue() { + return false; + }; + _2.Sb = function Gue() { + return false; + }; + _2.Tb = function Iue() { + return -1; + }; + _2.Vb = function Kue() { + return -1; + }; + _2.Qb = function Lue() { + throw Adb(new kib(dMe)); + }; + sfb(aMe, "ExclusiveRange/1", 1084); + feb(258, 1, Jve, Rue); + _2.Rb = function Sue(a) { + RD(a, 17); + Nue(); + }; + _2.Nb = function Tue(a) { + Ztb(this, a); + }; + _2.Pb = function Wue() { + return Oue(this); + }; + _2.Ub = function Yue() { + return Pue(this); + }; + _2.Wb = function _ue(a) { + RD(a, 17); + Que(); + }; + _2.Ob = function Uue() { + return this.c.c < 0 ? this.a >= this.c.b : this.a <= this.c.b; + }; + _2.Sb = function Vue() { + return this.b > 0; + }; + _2.Tb = function Xue() { + return this.b; + }; + _2.Vb = function Zue() { + return this.b - 1; + }; + _2.Qb = function $ue() { + throw Adb(new kib(dMe)); + }; + _2.a = 0; + _2.b = 0; + sfb(aMe, "ExclusiveRange/RangeIterator", 258); + var hE = vfb(eKe, "C"); + var kE = vfb(hKe, "I"); + var xdb = vfb(hve, "Z"); + var lE = vfb(iKe, "J"); + var gE = vfb(dKe, "B"); + var iE = vfb(fKe, "D"); + var jE = vfb(gKe, "F"); + var wdb = vfb(jKe, "S"); + var g3 = ufb("org.eclipse.elk.core.labels", "ILabelManager"); + var T6 = ufb(sIe, "DiagnosticChain"); + var zab = ufb(QKe, "ResourceSet"); + var $6 = sfb(sIe, "InvocationTargetException", null); + var fve = (Qz(), Tz); + var gwtOnLoad = gwtOnLoad = ceb; + aeb(leb); + deb("permProps", [[["locale", "default"], [eMe, "gecko1_8"]], [["locale", "default"], [eMe, "safari"]]]); + gwtOnLoad(null, "elk", null); + }).call(this); + }).call(this, typeof commonjsGlobal !== "undefined" ? commonjsGlobal : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}); + }, {}], 3: [function(require, module3, exports3) { + function _classCallCheck(instance2, Constructor) { + if (!(instance2 instanceof Constructor)) { + throw new TypeError("Cannot call a class as a function"); + } + } + function _possibleConstructorReturn(self2, call) { + if (!self2) { + throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); + } + return call && (typeof call === "object" || typeof call === "function") ? call : self2; + } + function _inherits(subClass, superClass) { + if (typeof superClass !== "function" && superClass !== null) { + throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); + } + subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); + if (superClass) + Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; + } + var ELK2 = require("./elk-api.js").default; + var ELKNode = function(_ELK) { + _inherits(ELKNode2, _ELK); + function ELKNode2() { + var options2 = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}; + _classCallCheck(this, ELKNode2); + var optionsClone = Object.assign({}, options2); + var workerThreadsExist = false; + try { + require.resolve("web-worker"); + workerThreadsExist = true; + } catch (e) { + } + if (options2.workerUrl) { + if (workerThreadsExist) { + var Worker2 = require("web-worker"); + optionsClone.workerFactory = function(url) { + return new Worker2(url); + }; + } else { + console.warn("Web worker requested but 'web-worker' package not installed. \nConsider installing the package or pass your own 'workerFactory' to ELK's constructor.\n... Falling back to non-web worker version."); + } + } + if (!optionsClone.workerFactory) { + var _require = require("./elk-worker.min.js"), _Worker = _require.Worker; + optionsClone.workerFactory = function(url) { + return new _Worker(url); + }; + } + return _possibleConstructorReturn(this, (ELKNode2.__proto__ || Object.getPrototypeOf(ELKNode2)).call(this, optionsClone)); + } + return ELKNode2; + }(ELK2); + Object.defineProperty(module3.exports, "__esModule", { + value: true + }); + module3.exports = ELKNode; + ELKNode.default = ELKNode; + }, { "./elk-api.js": 1, "./elk-worker.min.js": 2, "web-worker": 4 }], 4: [function(require, module3, exports3) { + module3.exports = Worker; + }, {}] }, {}, [3])(3); + }); + })(elk_bundled); + var elk_bundledExports = elk_bundled.exports; + const ELK = /* @__PURE__ */ getDefaultExportFromCjs(elk_bundledExports); + const elk = new ELK(); + let portPos = {}; + const conf = {}; + let nodeDb = {}; + const addVertices = async function(vert, svgId, root2, doc, diagObj, parentLookupDb, graph) { + const svg2 = root2.select(`[id="${svgId}"]`); + const nodes2 = svg2.insert("g").attr("class", "nodes"); + const keys2 = Object.keys(vert); + await Promise.all( + keys2.map(async function(id2) { + const vertex = vert[id2]; + let classStr = "default"; + if (vertex.classes.length > 0) { + classStr = vertex.classes.join(" "); + } + classStr = classStr + " flowchart-label"; + const styles2 = getStylesFromArray(vertex.styles); + let vertexText = vertex.text !== void 0 ? vertex.text : vertex.id; + const labelData = { width: 0, height: 0 }; + const ports = [ + { + id: vertex.id + "-west", + layoutOptions: { + "port.side": "WEST" + } + }, + { + id: vertex.id + "-east", + layoutOptions: { + "port.side": "EAST" + } + }, + { + id: vertex.id + "-south", + layoutOptions: { + "port.side": "SOUTH" + } + }, + { + id: vertex.id + "-north", + layoutOptions: { + "port.side": "NORTH" + } + } + ]; + let radius = 0; + let _shape = ""; + let layoutOptions = {}; + switch (vertex.type) { + case "round": + radius = 5; + _shape = "rect"; + break; + case "square": + _shape = "rect"; + break; + case "diamond": + _shape = "question"; + layoutOptions = { + portConstraints: "FIXED_SIDE" + }; + break; + case "hexagon": + _shape = "hexagon"; + break; + case "odd": + _shape = "rect_left_inv_arrow"; + break; + case "lean_right": + _shape = "lean_right"; + break; + case "lean_left": + _shape = "lean_left"; + break; + case "trapezoid": + _shape = "trapezoid"; + break; + case "inv_trapezoid": + _shape = "inv_trapezoid"; + break; + case "odd_right": + _shape = "rect_left_inv_arrow"; + break; + case "circle": + _shape = "circle"; + break; + case "ellipse": + _shape = "ellipse"; + break; + case "stadium": + _shape = "stadium"; + break; + case "subroutine": + _shape = "subroutine"; + break; + case "cylinder": + _shape = "cylinder"; + break; + case "group": + _shape = "rect"; + break; + case "doublecircle": + _shape = "doublecircle"; + break; + default: + _shape = "rect"; + } + const node2 = { + labelStyle: styles2.labelStyle, + shape: _shape, + labelText: vertexText, + labelType: vertex.labelType, + rx: radius, + ry: radius, + class: classStr, + style: styles2.style, + id: vertex.id, + link: vertex.link, + linkTarget: vertex.linkTarget, + tooltip: diagObj.db.getTooltip(vertex.id) || "", + domId: diagObj.db.lookUpDomId(vertex.id), + haveCallback: vertex.haveCallback, + width: vertex.type === "group" ? 500 : void 0, + dir: vertex.dir, + type: vertex.type, + props: vertex.props, + padding: getConfig$2().flowchart.padding + }; + let boundingBox; + let nodeEl; + if (node2.type !== "group") { + nodeEl = await insertNode(nodes2, node2, vertex.dir); + boundingBox = nodeEl.node().getBBox(); + } else { + doc.createElementNS("http://www.w3.org/2000/svg", "text"); + const { shapeSvg, bbox } = await labelHelper(nodes2, node2, void 0, true); + labelData.width = bbox.width; + labelData.wrappingWidth = getConfig$2().flowchart.wrappingWidth; + labelData.height = bbox.height; + labelData.labelNode = shapeSvg.node(); + node2.labelData = labelData; + } + const data = { + id: vertex.id, + ports: vertex.type === "diamond" ? ports : [], + // labelStyle: styles.labelStyle, + // shape: _shape, + layoutOptions, + labelText: vertexText, + labelData, + // labels: [{ text: vertexText }], + // rx: radius, + // ry: radius, + // class: classStr, + // style: styles.style, + // link: vertex.link, + // linkTarget: vertex.linkTarget, + // tooltip: diagObj.db.getTooltip(vertex.id) || '', + domId: diagObj.db.lookUpDomId(vertex.id), + // haveCallback: vertex.haveCallback, + width: boundingBox == null ? void 0 : boundingBox.width, + height: boundingBox == null ? void 0 : boundingBox.height, + // dir: vertex.dir, + type: vertex.type, + // props: vertex.props, + // padding: getConfig().flowchart.padding, + // boundingBox, + el: nodeEl, + parent: parentLookupDb.parentById[vertex.id] + }; + nodeDb[node2.id] = data; + }) + ); + return graph; + }; + const getNextPosition = (position2, edgeDirection, graphDirection) => { + const portPos2 = { + TB: { + in: { + north: "north" + }, + out: { + south: "west", + west: "east", + east: "south" + } + }, + LR: { + in: { + west: "west" + }, + out: { + east: "south", + south: "north", + north: "east" + } + }, + RL: { + in: { + east: "east" + }, + out: { + west: "north", + north: "south", + south: "west" + } + }, + BT: { + in: { + south: "south" + }, + out: { + north: "east", + east: "west", + west: "north" + } + } + }; + portPos2.TD = portPos2.TB; + return portPos2[graphDirection][edgeDirection][position2]; + }; + const getNextPort = (node2, edgeDirection, graphDirection) => { + log$1.info("getNextPort", { node: node2, edgeDirection, graphDirection }); + if (!portPos[node2]) { + switch (graphDirection) { + case "TB": + case "TD": + portPos[node2] = { + inPosition: "north", + outPosition: "south" + }; + break; + case "BT": + portPos[node2] = { + inPosition: "south", + outPosition: "north" + }; + break; + case "RL": + portPos[node2] = { + inPosition: "east", + outPosition: "west" + }; + break; + case "LR": + portPos[node2] = { + inPosition: "west", + outPosition: "east" + }; + break; + } + } + const result = edgeDirection === "in" ? portPos[node2].inPosition : portPos[node2].outPosition; + if (edgeDirection === "in") { + portPos[node2].inPosition = getNextPosition( + portPos[node2].inPosition, + edgeDirection, + graphDirection + ); + } else { + portPos[node2].outPosition = getNextPosition( + portPos[node2].outPosition, + edgeDirection, + graphDirection + ); + } + return result; + }; + const getEdgeStartEndPoint = (edge, dir2) => { + let source = edge.start; + let target = edge.end; + const sourceId = source; + const targetId = target; + const startNode = nodeDb[source]; + const endNode = nodeDb[target]; + if (!startNode || !endNode) { + return { source, target }; + } + if (startNode.type === "diamond") { + source = `${source}-${getNextPort(source, "out", dir2)}`; + } + if (endNode.type === "diamond") { + target = `${target}-${getNextPort(target, "in", dir2)}`; + } + return { source, target, sourceId, targetId }; + }; + const addEdges = function(edges2, diagObj, graph, svg2) { + log$1.info("abc78 edges = ", edges2); + const labelsEl = svg2.insert("g").attr("class", "edgeLabels"); + let linkIdCnt = {}; + let dir2 = diagObj.db.getDirection(); + let defaultStyle2; + let defaultLabelStyle; + if (edges2.defaultStyle !== void 0) { + const defaultStyles = getStylesFromArray(edges2.defaultStyle); + defaultStyle2 = defaultStyles.style; + defaultLabelStyle = defaultStyles.labelStyle; + } + edges2.forEach(function(edge) { + const linkIdBase = "L-" + edge.start + "-" + edge.end; + if (linkIdCnt[linkIdBase] === void 0) { + linkIdCnt[linkIdBase] = 0; + log$1.info("abc78 new entry", linkIdBase, linkIdCnt[linkIdBase]); + } else { + linkIdCnt[linkIdBase]++; + log$1.info("abc78 new entry", linkIdBase, linkIdCnt[linkIdBase]); + } + let linkId = linkIdBase + "-" + linkIdCnt[linkIdBase]; + log$1.info("abc78 new link id to be used is", linkIdBase, linkId, linkIdCnt[linkIdBase]); + const linkNameStart = "LS-" + edge.start; + const linkNameEnd = "LE-" + edge.end; + const edgeData = { style: "", labelStyle: "" }; + edgeData.minlen = edge.length || 1; + if (edge.type === "arrow_open") { + edgeData.arrowhead = "none"; + } else { + edgeData.arrowhead = "normal"; + } + edgeData.arrowTypeStart = "arrow_open"; + edgeData.arrowTypeEnd = "arrow_open"; + switch (edge.type) { + case "double_arrow_cross": + edgeData.arrowTypeStart = "arrow_cross"; + case "arrow_cross": + edgeData.arrowTypeEnd = "arrow_cross"; + break; + case "double_arrow_point": + edgeData.arrowTypeStart = "arrow_point"; + case "arrow_point": + edgeData.arrowTypeEnd = "arrow_point"; + break; + case "double_arrow_circle": + edgeData.arrowTypeStart = "arrow_circle"; + case "arrow_circle": + edgeData.arrowTypeEnd = "arrow_circle"; + break; + } + let style = ""; + let labelStyle = ""; + switch (edge.stroke) { + case "normal": + style = "fill:none;"; + if (defaultStyle2 !== void 0) { + style = defaultStyle2; + } + if (defaultLabelStyle !== void 0) { + labelStyle = defaultLabelStyle; + } + edgeData.thickness = "normal"; + edgeData.pattern = "solid"; + break; + case "dotted": + edgeData.thickness = "normal"; + edgeData.pattern = "dotted"; + edgeData.style = "fill:none;stroke-width:2px;stroke-dasharray:3;"; + break; + case "thick": + edgeData.thickness = "thick"; + edgeData.pattern = "solid"; + edgeData.style = "stroke-width: 3.5px;fill:none;"; + break; + } + if (edge.style !== void 0) { + const styles2 = getStylesFromArray(edge.style); + style = styles2.style; + labelStyle = styles2.labelStyle; + } + edgeData.style = edgeData.style += style; + edgeData.labelStyle = edgeData.labelStyle += labelStyle; + if (edge.interpolate !== void 0) { + edgeData.curve = interpolateToCurve(edge.interpolate, curveLinear); + } else if (edges2.defaultInterpolate !== void 0) { + edgeData.curve = interpolateToCurve(edges2.defaultInterpolate, curveLinear); + } else { + edgeData.curve = interpolateToCurve(conf.curve, curveLinear); + } + if (edge.text === void 0) { + if (edge.style !== void 0) { + edgeData.arrowheadStyle = "fill: #333"; + } + } else { + edgeData.arrowheadStyle = "fill: #333"; + edgeData.labelpos = "c"; + } + edgeData.labelType = edge.labelType; + edgeData.label = edge.text.replace(common$1.lineBreakRegex, "\n"); + if (edge.style === void 0) { + edgeData.style = edgeData.style || "stroke: #333; stroke-width: 1.5px;fill:none;"; + } + edgeData.labelStyle = edgeData.labelStyle.replace("color:", "fill:"); + edgeData.id = linkId; + edgeData.classes = "flowchart-link " + linkNameStart + " " + linkNameEnd; + const labelEl = insertEdgeLabel(labelsEl, edgeData); + const { source, target, sourceId, targetId } = getEdgeStartEndPoint(edge, dir2); + log$1.debug("abc78 source and target", source, target); + graph.edges.push({ + id: "e" + edge.start + edge.end, + sources: [source], + targets: [target], + sourceId, + targetId, + labelEl, + labels: [ + { + width: edgeData.width, + height: edgeData.height, + orgWidth: edgeData.width, + orgHeight: edgeData.height, + text: edgeData.label, + layoutOptions: { + "edgeLabels.inline": "true", + "edgeLabels.placement": "CENTER" + } + } + ], + edgeData + }); + }); + return graph; + }; + const addMarkersToEdge = function(svgPath, edgeData, diagramType, arrowMarkerAbsolute, id2) { + let url = ""; + if (arrowMarkerAbsolute) { + url = window.location.protocol + "//" + window.location.host + window.location.pathname + window.location.search; + url = url.replace(/\(/g, "\\("); + url = url.replace(/\)/g, "\\)"); + } + addEdgeMarkers(svgPath, edgeData, url, id2, diagramType); + }; + const getClasses$2 = function(text2, diagObj) { + log$1.info("Extracting classes"); + return diagObj.db.getClasses(); + }; + const addSubGraphs = function(db2) { + const parentLookupDb = { parentById: {}, childrenById: {} }; + const subgraphs = db2.getSubGraphs(); + log$1.info("Subgraphs - ", subgraphs); + subgraphs.forEach(function(subgraph) { + subgraph.nodes.forEach(function(node2) { + parentLookupDb.parentById[node2] = subgraph.id; + if (parentLookupDb.childrenById[subgraph.id] === void 0) { + parentLookupDb.childrenById[subgraph.id] = []; + } + parentLookupDb.childrenById[subgraph.id].push(node2); + }); + }); + subgraphs.forEach(function(subgraph) { + ({ id: subgraph.id }); + if (parentLookupDb.parentById[subgraph.id] !== void 0) { + parentLookupDb.parentById[subgraph.id]; + } + }); + return parentLookupDb; + }; + const calcOffset = function(src, dest, parentLookupDb) { + const ancestor = findCommonAncestor(src, dest, parentLookupDb); + if (ancestor === void 0 || ancestor === "root") { + return { x: 0, y: 0 }; + } + const ancestorOffset = nodeDb[ancestor].offset; + return { x: ancestorOffset.posX, y: ancestorOffset.posY }; + }; + const insertEdge = function(edgesEl, edge, edgeData, diagObj, parentLookupDb, id2) { + const offset = calcOffset(edge.sourceId, edge.targetId, parentLookupDb); + const src = edge.sections[0].startPoint; + const dest = edge.sections[0].endPoint; + const segments = edge.sections[0].bendPoints ? edge.sections[0].bendPoints : []; + const segPoints = segments.map((segment) => [segment.x + offset.x, segment.y + offset.y]); + const points = [ + [src.x + offset.x, src.y + offset.y], + ...segPoints, + [dest.x + offset.x, dest.y + offset.y] + ]; + const { x: x2, y: y2 } = getLineFunctionsWithOffset(edge.edgeData); + const curve = line$1().x(x2).y(y2).curve(curveLinear); + const edgePath = edgesEl.insert("path").attr("d", curve(points)).attr("class", "path " + edgeData.classes).attr("fill", "none"); + const edgeG = edgesEl.insert("g").attr("class", "edgeLabel"); + const edgeWithLabel = d3select(edgeG.node().appendChild(edge.labelEl)); + const box = edgeWithLabel.node().firstChild.getBoundingClientRect(); + edgeWithLabel.attr("width", box.width); + edgeWithLabel.attr("height", box.height); + edgeG.attr( + "transform", + `translate(${edge.labels[0].x + offset.x}, ${edge.labels[0].y + offset.y})` + ); + addMarkersToEdge(edgePath, edgeData, diagObj.type, diagObj.arrowMarkerAbsolute, id2); + }; + const insertChildren = (nodeArray, parentLookupDb) => { + nodeArray.forEach((node2) => { + if (!node2.children) { + node2.children = []; + } + const childIds = parentLookupDb.childrenById[node2.id]; + if (childIds) { + childIds.forEach((childId) => { + node2.children.push(nodeDb[childId]); + }); + } + insertChildren(node2.children, parentLookupDb); + }); + }; + const draw$4 = async function(text2, id2, _version, diagObj) { + var _a2; + diagObj.db.clear(); + nodeDb = {}; + portPos = {}; + diagObj.db.setGen("gen-2"); + diagObj.parser.parse(text2); + const renderEl = d3select("body").append("div").attr("style", "height:400px").attr("id", "cy"); + let graph = { + id: "root", + layoutOptions: { + "elk.hierarchyHandling": "INCLUDE_CHILDREN", + "org.eclipse.elk.padding": "[top=100, left=100, bottom=110, right=110]", + "elk.layered.spacing.edgeNodeBetweenLayers": "30", + // 'elk.layered.mergeEdges': 'true', + "elk.direction": "DOWN" + // 'elk.ports.sameLayerEdges': true, + // 'nodePlacement.strategy': 'SIMPLE', + }, + children: [], + edges: [] + }; + log$1.info("Drawing flowchart using v3 renderer", elk); + let dir2 = diagObj.db.getDirection(); + switch (dir2) { + case "BT": + graph.layoutOptions["elk.direction"] = "UP"; + break; + case "TB": + graph.layoutOptions["elk.direction"] = "DOWN"; + break; + case "LR": + graph.layoutOptions["elk.direction"] = "RIGHT"; + break; + case "RL": + graph.layoutOptions["elk.direction"] = "LEFT"; + break; + } + const { securityLevel, flowchart: conf2 } = getConfig$2(); + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = d3select("#i" + id2); + } + const root2 = securityLevel === "sandbox" ? d3select(sandboxElement.nodes()[0].contentDocument.body) : d3select("body"); + const doc = securityLevel === "sandbox" ? sandboxElement.nodes()[0].contentDocument : document; + const svg2 = root2.select(`[id="${id2}"]`); + const markers2 = ["point", "circle", "cross"]; + insertMarkers$4(svg2, markers2, diagObj.type, id2); + const vert = diagObj.db.getVertices(); + let subG; + const subGraphs2 = diagObj.db.getSubGraphs(); + log$1.info("Subgraphs - ", subGraphs2); + for (let i2 = subGraphs2.length - 1; i2 >= 0; i2--) { + subG = subGraphs2[i2]; + diagObj.db.addVertex( + subG.id, + { text: subG.title, type: subG.labelType }, + "group", + void 0, + subG.classes, + subG.dir + ); + } + const subGraphsEl = svg2.insert("g").attr("class", "subgraphs"); + const parentLookupDb = addSubGraphs(diagObj.db); + graph = await addVertices(vert, id2, root2, doc, diagObj, parentLookupDb, graph); + const edgesEl = svg2.insert("g").attr("class", "edges edgePath"); + const edges2 = diagObj.db.getEdges(); + graph = addEdges(edges2, diagObj, graph, svg2); + const nodes2 = Object.keys(nodeDb); + nodes2.forEach((nodeId) => { + const node2 = nodeDb[nodeId]; + if (!node2.parent) { + graph.children.push(node2); + } + if (parentLookupDb.childrenById[nodeId] !== void 0) { + node2.labels = [ + { + text: node2.labelText, + layoutOptions: { + "nodeLabels.placement": "[H_CENTER, V_TOP, INSIDE]" + }, + width: node2.labelData.width, + height: node2.labelData.height + // width: 100, + // height: 100, + } + ]; + delete node2.x; + delete node2.y; + delete node2.width; + delete node2.height; + } + }); + insertChildren(graph.children, parentLookupDb); + log$1.info("after layout", JSON.stringify(graph, null, 2)); + const g = await elk.layout(graph); + drawNodes$1(0, 0, g.children, svg2, subGraphsEl, diagObj, 0); + log$1.info("after layout", g); + (_a2 = g.edges) == null ? void 0 : _a2.map((edge) => { + insertEdge(edgesEl, edge, edge.edgeData, diagObj, parentLookupDb, id2); + }); + setupGraphViewbox$1({}, svg2, conf2.diagramPadding, conf2.useMaxWidth); + renderEl.remove(); + }; + const drawNodes$1 = (relX, relY, nodeArray, svg2, subgraphsEl, diagObj, depth) => { + nodeArray.forEach(function(node2) { + if (node2) { + nodeDb[node2.id].offset = { + posX: node2.x + relX, + posY: node2.y + relY, + x: relX, + y: relY, + depth, + width: node2.width, + height: node2.height + }; + if (node2.type === "group") { + const subgraphEl = subgraphsEl.insert("g").attr("class", "subgraph"); + subgraphEl.insert("rect").attr("class", "subgraph subgraph-lvl-" + depth % 5 + " node").attr("x", node2.x + relX).attr("y", node2.y + relY).attr("width", node2.width).attr("height", node2.height); + const label = subgraphEl.insert("g").attr("class", "label"); + const labelCentering = getConfig$2().flowchart.htmlLabels ? node2.labelData.width / 2 : 0; + label.attr( + "transform", + `translate(${node2.labels[0].x + relX + node2.x + labelCentering}, ${node2.labels[0].y + relY + node2.y + 3})` + ); + label.node().appendChild(node2.labelData.labelNode); + log$1.info("Id (UGH)= ", node2.type, node2.labels); + } else { + log$1.info("Id (UGH)= ", node2.id); + node2.el.attr( + "transform", + `translate(${node2.x + relX + node2.width / 2}, ${node2.y + relY + node2.height / 2})` + ); + } + } + }); + nodeArray.forEach(function(node2) { + if (node2 && node2.type === "group") { + drawNodes$1(relX + node2.x, relY + node2.y, node2.children, svg2, subgraphsEl, diagObj, depth + 1); + } + }); + }; + const renderer$4 = { + getClasses: getClasses$2, + draw: draw$4 + }; + const genSections$2 = (options2) => { + let sections2 = ""; + for (let i2 = 0; i2 < 5; i2++) { + sections2 += ` + .subgraph-lvl-${i2} { + fill: ${options2[`surface${i2}`]}; + stroke: ${options2[`surfacePeer${i2}`]}; + } + `; + } + return sections2; + }; + const getStyles$3 = (options2) => `.label { + font-family: ${options2.fontFamily}; + color: ${options2.nodeTextColor || options2.textColor}; + } + .cluster-label text { + fill: ${options2.titleColor}; + } + .cluster-label span { + color: ${options2.titleColor}; + } + + .label text,span { + fill: ${options2.nodeTextColor || options2.textColor}; + color: ${options2.nodeTextColor || options2.textColor}; + } + + .node rect, + .node circle, + .node ellipse, + .node polygon, + .node path { + fill: ${options2.mainBkg}; + stroke: ${options2.nodeBorder}; + stroke-width: 1px; + } + + .node .label { + text-align: center; + } + .node.clickable { + cursor: pointer; + } + + .arrowheadPath { + fill: ${options2.arrowheadColor}; + } + + .edgePath .path { + stroke: ${options2.lineColor}; + stroke-width: 2.0px; + } + + .flowchart-link { + stroke: ${options2.lineColor}; + fill: none; + } + + .edgeLabel { + background-color: ${options2.edgeLabelBackground}; + rect { + opacity: 0.85; + background-color: ${options2.edgeLabelBackground}; + fill: ${options2.edgeLabelBackground}; + } + text-align: center; + } + + .cluster rect { + fill: ${options2.clusterBkg}; + stroke: ${options2.clusterBorder}; + stroke-width: 1px; + } + + .cluster text { + fill: ${options2.titleColor}; + } + + .cluster span { + color: ${options2.titleColor}; + } + /* .cluster div { + color: ${options2.titleColor}; + } */ + + div.mermaidTooltip { + position: absolute; + text-align: center; + max-width: 200px; + padding: 2px; + font-family: ${options2.fontFamily}; + font-size: 12px; + background: ${options2.tertiaryColor}; + border: 1px solid ${options2.border2}; + border-radius: 2px; + pointer-events: none; + z-index: 100; + } + + .flowchartTitleText { + text-anchor: middle; + font-size: 18px; + fill: ${options2.textColor}; + } + .subgraph { + stroke-width:2; + rx:3; + } + // .subgraph-lvl-1 { + // fill:#ccc; + // // stroke:black; + // } + + .flowchart-label text { + text-anchor: middle; + } + + ${genSections$2(options2)} +`; + const styles$2 = getStyles$3; + const diagram$4 = { + db: db$f, + renderer: renderer$4, + parser: parser$u, + styles: styles$2 + }; + const flowchartElkDefinition = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + diagram: diagram$4 + }, Symbol.toStringTag, { value: "Module" })); + var parser$6 = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [6, 8, 10, 11, 12, 14, 16, 17, 20, 21], $V1 = [1, 9], $V2 = [1, 10], $V3 = [1, 11], $V4 = [1, 12], $V5 = [1, 13], $V6 = [1, 16], $V7 = [1, 17]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "timeline": 4, "document": 5, "EOF": 6, "line": 7, "SPACE": 8, "statement": 9, "NEWLINE": 10, "title": 11, "acc_title": 12, "acc_title_value": 13, "acc_descr": 14, "acc_descr_value": 15, "acc_descr_multiline_value": 16, "section": 17, "period_statement": 18, "event_statement": 19, "period": 20, "event": 21, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 4: "timeline", 6: "EOF", 8: "SPACE", 10: "NEWLINE", 11: "title", 12: "acc_title", 13: "acc_title_value", 14: "acc_descr", 15: "acc_descr_value", 16: "acc_descr_multiline_value", 17: "section", 20: "period", 21: "event" }, + productions_: [0, [3, 3], [5, 0], [5, 2], [7, 2], [7, 1], [7, 1], [7, 1], [9, 1], [9, 2], [9, 2], [9, 1], [9, 1], [9, 1], [9, 1], [18, 1], [19, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 1: + return $$[$0 - 1]; + case 2: + this.$ = []; + break; + case 3: + $$[$0 - 1].push($$[$0]); + this.$ = $$[$0 - 1]; + break; + case 4: + case 5: + this.$ = $$[$0]; + break; + case 6: + case 7: + this.$ = []; + break; + case 8: + yy.getCommonDb().setDiagramTitle($$[$0].substr(6)); + this.$ = $$[$0].substr(6); + break; + case 9: + this.$ = $$[$0].trim(); + yy.getCommonDb().setAccTitle(this.$); + break; + case 10: + case 11: + this.$ = $$[$0].trim(); + yy.getCommonDb().setAccDescription(this.$); + break; + case 12: + yy.addSection($$[$0].substr(8)); + this.$ = $$[$0].substr(8); + break; + case 15: + yy.addTask($$[$0], 0, ""); + this.$ = $$[$0]; + break; + case 16: + yy.addEvent($$[$0].substr(2)); + this.$ = $$[$0]; + break; + } + }, + table: [{ 3: 1, 4: [1, 2] }, { 1: [3] }, o($V0, [2, 2], { 5: 3 }), { 6: [1, 4], 7: 5, 8: [1, 6], 9: 7, 10: [1, 8], 11: $V1, 12: $V2, 14: $V3, 16: $V4, 17: $V5, 18: 14, 19: 15, 20: $V6, 21: $V7 }, o($V0, [2, 7], { 1: [2, 1] }), o($V0, [2, 3]), { 9: 18, 11: $V1, 12: $V2, 14: $V3, 16: $V4, 17: $V5, 18: 14, 19: 15, 20: $V6, 21: $V7 }, o($V0, [2, 5]), o($V0, [2, 6]), o($V0, [2, 8]), { 13: [1, 19] }, { 15: [1, 20] }, o($V0, [2, 11]), o($V0, [2, 12]), o($V0, [2, 13]), o($V0, [2, 14]), o($V0, [2, 15]), o($V0, [2, 16]), o($V0, [2, 4]), o($V0, [2, 9]), o($V0, [2, 10])], + defaultActions: {}, + parseError: function parseError(str2, hash) { + if (hash.recoverable) { + this.trace(str2); + } else { + var error = new Error(str2); + error.hash = hash; + throw error; + } + }, + parse: function parse2(input) { + var self2 = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex2() { + var token2; + token2 = tstack.pop() || lexer2.lex() || EOF; + if (typeof token2 !== "number") { + if (token2 instanceof Array) { + tstack = token2; + token2 = tstack.pop(); + } + token2 = self2.symbols_[token2] || token2; + } + return token2; + } + var symbol, state2, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state2 = stack[stack.length - 1]; + if (this.defaultActions[state2]) { + action = this.defaultActions[state2]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex2(); + } + action = table[state2] && table[state2][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state2]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state2 + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str2, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str2, hash); + } else { + throw new Error(str2); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch2 = this._input[0]; + this.yytext += ch2; + this.yyleng++; + this.offset++; + this.match += ch2; + this.matched += ch2; + var lines = ch2.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch2; + }, + // unshifts one char (or a string) into the input + unput: function(ch2) { + var len = ch2.length; + var lines = ch2.split(/(?:\r\n?|\n)/g); + this._input = ch2 + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next2 = this.match; + if (next2.length < 20) { + next2 += this._input.substr(0, 20 - next2.length); + } + return (next2.substr(0, 20) + (next2.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c2 = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c2 + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token2, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token2 = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token2) { + return token2; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token2, match, tempMatch, index2; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i2 = 0; i2 < rules.length; i2++) { + tempMatch = this._input.match(this.rules[rules[i2]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index2 = i2; + if (this.options.backtrack_lexer) { + token2 = this.test_match(tempMatch, rules[i2]); + if (token2 !== false) { + return token2; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token2 = this.test_match(match, rules[index2]); + if (token2 !== false) { + return token2; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex2() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + break; + case 1: + break; + case 2: + return 10; + case 3: + break; + case 4: + break; + case 5: + return 4; + case 6: + return 11; + case 7: + this.begin("acc_title"); + return 12; + case 8: + this.popState(); + return "acc_title_value"; + case 9: + this.begin("acc_descr"); + return 14; + case 10: + this.popState(); + return "acc_descr_value"; + case 11: + this.begin("acc_descr_multiline"); + break; + case 12: + this.popState(); + break; + case 13: + return "acc_descr_multiline_value"; + case 14: + return 17; + case 15: + return 21; + case 16: + return 20; + case 17: + return 6; + case 18: + return "INVALID"; + } + }, + rules: [/^(?:%(?!\{)[^\n]*)/i, /^(?:[^\}]%%[^\n]*)/i, /^(?:[\n]+)/i, /^(?:\s+)/i, /^(?:#[^\n]*)/i, /^(?:timeline\b)/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, /^(?:section\s[^#:\n;]+)/i, /^(?::\s[^#:\n;]+)/i, /^(?:[^#:\n;]+)/i, /^(?:$)/i, /^(?:.)/i], + conditions: { "acc_descr_multiline": { "rules": [12, 13], "inclusive": false }, "acc_descr": { "rules": [10], "inclusive": false }, "acc_title": { "rules": [8], "inclusive": false }, "INITIAL": { "rules": [0, 1, 2, 3, 4, 5, 6, 7, 9, 11, 14, 15, 16, 17, 18], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser2() { + this.yy = {}; + } + Parser2.prototype = parser2; + parser2.Parser = Parser2; + return new Parser2(); + }(); + parser$6.parser = parser$6; + const parser$7 = parser$6; + let currentSection = ""; + let currentTaskId = 0; + const sections = []; + const tasks = []; + const rawTasks = []; + const getCommonDb = () => commonDb; + const clear$3 = function() { + sections.length = 0; + tasks.length = 0; + currentSection = ""; + rawTasks.length = 0; + clear$n(); + }; + const addSection = function(txt) { + currentSection = txt; + sections.push(txt); + }; + const getSections = function() { + return sections; + }; + const getTasks = function() { + let allItemsProcessed = compileTasks(); + const maxDepth = 100; + let iterationCount = 0; + while (!allItemsProcessed && iterationCount < maxDepth) { + allItemsProcessed = compileTasks(); + iterationCount++; + } + tasks.push(...rawTasks); + return tasks; + }; + const addTask = function(period, length2, event) { + const rawTask = { + id: currentTaskId++, + section: currentSection, + type: currentSection, + task: period, + score: length2 ? length2 : 0, + //if event is defined, then add it the events array + events: event ? [event] : [] + }; + rawTasks.push(rawTask); + }; + const addEvent = function(event) { + const currentTask = rawTasks.find((task) => task.id === currentTaskId - 1); + currentTask.events.push(event); + }; + const addTaskOrg = function(descr) { + const newTask = { + section: currentSection, + type: currentSection, + description: descr, + task: descr, + classes: [] + }; + tasks.push(newTask); + }; + const compileTasks = function() { + const compileTask = function(pos) { + return rawTasks[pos].processed; + }; + let allProcessed = true; + for (const [i2, rawTask] of rawTasks.entries()) { + compileTask(i2); + allProcessed = allProcessed && rawTask.processed; + } + return allProcessed; + }; + const timelineDb = { + clear: clear$3, + getCommonDb, + addSection, + getSections, + getTasks, + addTask, + addTaskOrg, + addEvent + }; + const db$5 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + addEvent, + addSection, + addTask, + addTaskOrg, + clear: clear$3, + default: timelineDb, + getCommonDb, + getSections, + getTasks + }, Symbol.toStringTag, { value: "Module" })); + const MAX_SECTIONS$1 = 12; + const drawRect = function(elem, rectData) { + const rectElem = elem.append("rect"); + rectElem.attr("x", rectData.x); + rectElem.attr("y", rectData.y); + rectElem.attr("fill", rectData.fill); + rectElem.attr("stroke", rectData.stroke); + rectElem.attr("width", rectData.width); + rectElem.attr("height", rectData.height); + rectElem.attr("rx", rectData.rx); + rectElem.attr("ry", rectData.ry); + if (rectData.class !== void 0) { + rectElem.attr("class", rectData.class); + } + return rectElem; + }; + const drawFace = function(element2, faceData) { + const radius = 15; + const circleElement = element2.append("circle").attr("cx", faceData.cx).attr("cy", faceData.cy).attr("class", "face").attr("r", radius).attr("stroke-width", 2).attr("overflow", "visible"); + const face = element2.append("g"); + face.append("circle").attr("cx", faceData.cx - radius / 3).attr("cy", faceData.cy - radius / 3).attr("r", 1.5).attr("stroke-width", 2).attr("fill", "#666").attr("stroke", "#666"); + face.append("circle").attr("cx", faceData.cx + radius / 3).attr("cy", faceData.cy - radius / 3).attr("r", 1.5).attr("stroke-width", 2).attr("fill", "#666").attr("stroke", "#666"); + function smile(face2) { + const arc = d3arc().startAngle(Math.PI / 2).endAngle(3 * (Math.PI / 2)).innerRadius(radius / 2).outerRadius(radius / 2.2); + face2.append("path").attr("class", "mouth").attr("d", arc).attr("transform", "translate(" + faceData.cx + "," + (faceData.cy + 2) + ")"); + } + function sad(face2) { + const arc = d3arc().startAngle(3 * Math.PI / 2).endAngle(5 * (Math.PI / 2)).innerRadius(radius / 2).outerRadius(radius / 2.2); + face2.append("path").attr("class", "mouth").attr("d", arc).attr("transform", "translate(" + faceData.cx + "," + (faceData.cy + 7) + ")"); + } + function ambivalent(face2) { + face2.append("line").attr("class", "mouth").attr("stroke", 2).attr("x1", faceData.cx - 5).attr("y1", faceData.cy + 7).attr("x2", faceData.cx + 5).attr("y2", faceData.cy + 7).attr("class", "mouth").attr("stroke-width", "1px").attr("stroke", "#666"); + } + if (faceData.score > 3) { + smile(face); + } else if (faceData.score < 3) { + sad(face); + } else { + ambivalent(face); + } + return circleElement; + }; + const drawCircle = function(element2, circleData) { + const circleElement = element2.append("circle"); + circleElement.attr("cx", circleData.cx); + circleElement.attr("cy", circleData.cy); + circleElement.attr("class", "actor-" + circleData.pos); + circleElement.attr("fill", circleData.fill); + circleElement.attr("stroke", circleData.stroke); + circleElement.attr("r", circleData.r); + if (circleElement.class !== void 0) { + circleElement.attr("class", circleElement.class); + } + if (circleData.title !== void 0) { + circleElement.append("title").text(circleData.title); + } + return circleElement; + }; + const drawText = function(elem, textData) { + const nText = textData.text.replace(//gi, " "); + const textElem = elem.append("text"); + textElem.attr("x", textData.x); + textElem.attr("y", textData.y); + textElem.attr("class", "legend"); + textElem.style("text-anchor", textData.anchor); + if (textData.class !== void 0) { + textElem.attr("class", textData.class); + } + const span = textElem.append("tspan"); + span.attr("x", textData.x + textData.textMargin * 2); + span.text(nText); + return textElem; + }; + const drawLabel = function(elem, txtObject) { + function genPoints(x2, y2, width2, height, cut) { + return x2 + "," + y2 + " " + (x2 + width2) + "," + y2 + " " + (x2 + width2) + "," + (y2 + height - cut) + " " + (x2 + width2 - cut * 1.2) + "," + (y2 + height) + " " + x2 + "," + (y2 + height); + } + const polygon = elem.append("polygon"); + polygon.attr("points", genPoints(txtObject.x, txtObject.y, 50, 20, 7)); + polygon.attr("class", "labelBox"); + txtObject.y = txtObject.y + txtObject.labelMargin; + txtObject.x = txtObject.x + 0.5 * txtObject.labelMargin; + drawText(elem, txtObject); + }; + const drawSection = function(elem, section, conf2) { + const g = elem.append("g"); + const rect2 = getNoteRect(); + rect2.x = section.x; + rect2.y = section.y; + rect2.fill = section.fill; + rect2.width = conf2.width; + rect2.height = conf2.height; + rect2.class = "journey-section section-type-" + section.num; + rect2.rx = 3; + rect2.ry = 3; + drawRect(g, rect2); + _drawTextCandidateFunc(conf2)( + section.text, + g, + rect2.x, + rect2.y, + rect2.width, + rect2.height, + { class: "journey-section section-type-" + section.num }, + conf2, + section.colour + ); + }; + let taskCount = -1; + const drawTask = function(elem, task, conf2) { + const center2 = task.x + conf2.width / 2; + const g = elem.append("g"); + taskCount++; + const maxHeight = 300 + 5 * 30; + g.append("line").attr("id", "task" + taskCount).attr("x1", center2).attr("y1", task.y).attr("x2", center2).attr("y2", maxHeight).attr("class", "task-line").attr("stroke-width", "1px").attr("stroke-dasharray", "4 2").attr("stroke", "#666"); + drawFace(g, { + cx: center2, + cy: 300 + (5 - task.score) * 30, + score: task.score + }); + const rect2 = getNoteRect(); + rect2.x = task.x; + rect2.y = task.y; + rect2.fill = task.fill; + rect2.width = conf2.width; + rect2.height = conf2.height; + rect2.class = "task task-type-" + task.num; + rect2.rx = 3; + rect2.ry = 3; + drawRect(g, rect2); + task.x + 14; + _drawTextCandidateFunc(conf2)( + task.task, + g, + rect2.x, + rect2.y, + rect2.width, + rect2.height, + { class: "task" }, + conf2, + task.colour + ); + }; + const drawBackgroundRect = function(elem, bounds2) { + const rectElem = drawRect(elem, { + x: bounds2.startx, + y: bounds2.starty, + width: bounds2.stopx - bounds2.startx, + height: bounds2.stopy - bounds2.starty, + fill: bounds2.fill, + class: "rect" + }); + rectElem.lower(); + }; + const getTextObj = function() { + return { + x: 0, + y: 0, + fill: void 0, + "text-anchor": "start", + width: 100, + height: 100, + textMargin: 0, + rx: 0, + ry: 0 + }; + }; + const getNoteRect = function() { + return { + x: 0, + y: 0, + width: 100, + anchor: "start", + height: 100, + rx: 0, + ry: 0 + }; + }; + const _drawTextCandidateFunc = function() { + function byText(content2, g, x2, y2, width2, height, textAttrs, colour) { + const text2 = g.append("text").attr("x", x2 + width2 / 2).attr("y", y2 + height / 2 + 5).style("font-color", colour).style("text-anchor", "middle").text(content2); + _setTextAttrs(text2, textAttrs); + } + function byTspan(content2, g, x2, y2, width2, height, textAttrs, conf2, colour) { + const { taskFontSize, taskFontFamily } = conf2; + const lines = content2.split(//gi); + for (let i2 = 0; i2 < lines.length; i2++) { + const dy = i2 * taskFontSize - taskFontSize * (lines.length - 1) / 2; + const text2 = g.append("text").attr("x", x2 + width2 / 2).attr("y", y2).attr("fill", colour).style("text-anchor", "middle").style("font-size", taskFontSize).style("font-family", taskFontFamily); + text2.append("tspan").attr("x", x2 + width2 / 2).attr("dy", dy).text(lines[i2]); + text2.attr("y", y2 + height / 2).attr("dominant-baseline", "central").attr("alignment-baseline", "central"); + _setTextAttrs(text2, textAttrs); + } + } + function byFo(content2, g, x2, y2, width2, height, textAttrs, conf2) { + const body = g.append("switch"); + const f2 = body.append("foreignObject").attr("x", x2).attr("y", y2).attr("width", width2).attr("height", height).attr("position", "fixed"); + const text2 = f2.append("xhtml:div").style("display", "table").style("height", "100%").style("width", "100%"); + text2.append("div").attr("class", "label").style("display", "table-cell").style("text-align", "center").style("vertical-align", "middle").text(content2); + byTspan(content2, body, x2, y2, width2, height, textAttrs, conf2); + _setTextAttrs(text2, textAttrs); + } + function _setTextAttrs(toText, fromTextAttrsDict) { + for (const key in fromTextAttrsDict) { + if (key in fromTextAttrsDict) { + toText.attr(key, fromTextAttrsDict[key]); + } + } + } + return function(conf2) { + return conf2.textPlacement === "fo" ? byFo : conf2.textPlacement === "old" ? byText : byTspan; + }; + }(); + const initGraphics = function(graphics) { + graphics.append("defs").append("marker").attr("id", "arrowhead").attr("refX", 5).attr("refY", 2).attr("markerWidth", 6).attr("markerHeight", 4).attr("orient", "auto").append("path").attr("d", "M 0,0 V 4 L6,2 Z"); + }; + function wrap(text2, width2) { + text2.each(function() { + var text3 = d3select(this), words = text3.text().split(/(\s+|
    )/).reverse(), word, line2 = [], lineHeight = 1.1, y2 = text3.attr("y"), dy = parseFloat(text3.attr("dy")), tspan = text3.text(null).append("tspan").attr("x", 0).attr("y", y2).attr("dy", dy + "em"); + for (let j = 0; j < words.length; j++) { + word = words[words.length - 1 - j]; + line2.push(word); + tspan.text(line2.join(" ").trim()); + if (tspan.node().getComputedTextLength() > width2 || word === "
    ") { + line2.pop(); + tspan.text(line2.join(" ").trim()); + if (word === "
    ") { + line2 = [""]; + } else { + line2 = [word]; + } + tspan = text3.append("tspan").attr("x", 0).attr("y", y2).attr("dy", lineHeight + "em").text(word); + } + } + }); + } + const drawNode$1 = function(elem, node2, fullSection, conf2) { + const section = fullSection % MAX_SECTIONS$1 - 1; + const nodeElem = elem.append("g"); + node2.section = section; + nodeElem.attr( + "class", + (node2.class ? node2.class + " " : "") + "timeline-node " + ("section-" + section) + ); + const bkgElem = nodeElem.append("g"); + const textElem = nodeElem.append("g"); + const txt = textElem.append("text").text(node2.descr).attr("dy", "1em").attr("alignment-baseline", "middle").attr("dominant-baseline", "middle").attr("text-anchor", "middle").call(wrap, node2.width); + const bbox = txt.node().getBBox(); + const fontSize = conf2.fontSize && conf2.fontSize.replace ? conf2.fontSize.replace("px", "") : conf2.fontSize; + node2.height = bbox.height + fontSize * 1.1 * 0.5 + node2.padding; + node2.height = Math.max(node2.height, node2.maxHeight); + node2.width = node2.width + 2 * node2.padding; + textElem.attr("transform", "translate(" + node2.width / 2 + ", " + node2.padding / 2 + ")"); + defaultBkg$1(bkgElem, node2, section); + return node2; + }; + const getVirtualNodeHeight = function(elem, node2, conf2) { + const textElem = elem.append("g"); + const txt = textElem.append("text").text(node2.descr).attr("dy", "1em").attr("alignment-baseline", "middle").attr("dominant-baseline", "middle").attr("text-anchor", "middle").call(wrap, node2.width); + const bbox = txt.node().getBBox(); + const fontSize = conf2.fontSize && conf2.fontSize.replace ? conf2.fontSize.replace("px", "") : conf2.fontSize; + textElem.remove(); + return bbox.height + fontSize * 1.1 * 0.5 + node2.padding; + }; + const defaultBkg$1 = function(elem, node2, section) { + const rd = 5; + elem.append("path").attr("id", "node-" + node2.id).attr("class", "node-bkg node-" + node2.type).attr( + "d", + `M0 ${node2.height - rd} v${-node2.height + 2 * rd} q0,-5 5,-5 h${node2.width - 2 * rd} q5,0 5,5 v${node2.height - rd} H0 Z` + ); + elem.append("line").attr("class", "node-line-" + section).attr("x1", 0).attr("y1", node2.height).attr("x2", node2.width).attr("y2", node2.height); + }; + const svgDraw = { + drawRect, + drawCircle, + drawSection, + drawText, + drawLabel, + drawTask, + drawBackgroundRect, + getTextObj, + getNoteRect, + initGraphics, + drawNode: drawNode$1, + getVirtualNodeHeight + }; + const draw$3 = function(text2, id2, version2, diagObj) { + var _a2, _b2; + const conf2 = getConfig$1(); + const LEFT_MARGIN2 = conf2.leftMargin ?? 50; + log$1.debug("timeline", diagObj.db); + const securityLevel = conf2.securityLevel; + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = d3select("#i" + id2); + } + const root2 = securityLevel === "sandbox" ? d3select(sandboxElement.nodes()[0].contentDocument.body) : d3select("body"); + const svg2 = root2.select("#" + id2); + svg2.append("g"); + const tasks2 = diagObj.db.getTasks(); + const title2 = diagObj.db.getCommonDb().getDiagramTitle(); + log$1.debug("task", tasks2); + svgDraw.initGraphics(svg2); + const sections2 = diagObj.db.getSections(); + log$1.debug("sections", sections2); + let maxSectionHeight = 0; + let maxTaskHeight = 0; + let depthY = 0; + let sectionBeginY = 0; + let masterX = 50 + LEFT_MARGIN2; + let masterY = 50; + sectionBeginY = 50; + let sectionNumber = 0; + let hasSections = true; + sections2.forEach(function(section) { + const sectionNode = { + number: sectionNumber, + descr: section, + section: sectionNumber, + width: 150, + padding: 20, + maxHeight: maxSectionHeight + }; + const sectionHeight = svgDraw.getVirtualNodeHeight(svg2, sectionNode, conf2); + log$1.debug("sectionHeight before draw", sectionHeight); + maxSectionHeight = Math.max(maxSectionHeight, sectionHeight + 20); + }); + let maxEventCount = 0; + let maxEventLineLength = 0; + log$1.debug("tasks.length", tasks2.length); + for (const [i2, task] of tasks2.entries()) { + const taskNode = { + number: i2, + descr: task, + section: task.section, + width: 150, + padding: 20, + maxHeight: maxTaskHeight + }; + const taskHeight = svgDraw.getVirtualNodeHeight(svg2, taskNode, conf2); + log$1.debug("taskHeight before draw", taskHeight); + maxTaskHeight = Math.max(maxTaskHeight, taskHeight + 20); + maxEventCount = Math.max(maxEventCount, task.events.length); + let maxEventLineLengthTemp = 0; + for (let j = 0; j < task.events.length; j++) { + const event = task.events[j]; + const eventNode = { + descr: event, + section: task.section, + number: task.section, + width: 150, + padding: 20, + maxHeight: 50 + }; + maxEventLineLengthTemp += svgDraw.getVirtualNodeHeight(svg2, eventNode, conf2); + } + maxEventLineLength = Math.max(maxEventLineLength, maxEventLineLengthTemp); + } + log$1.debug("maxSectionHeight before draw", maxSectionHeight); + log$1.debug("maxTaskHeight before draw", maxTaskHeight); + if (sections2 && sections2.length > 0) { + sections2.forEach((section) => { + const tasksForSection = tasks2.filter((task) => task.section === section); + const sectionNode = { + number: sectionNumber, + descr: section, + section: sectionNumber, + width: 200 * Math.max(tasksForSection.length, 1) - 50, + padding: 20, + maxHeight: maxSectionHeight + }; + log$1.debug("sectionNode", sectionNode); + const sectionNodeWrapper = svg2.append("g"); + const node2 = svgDraw.drawNode(sectionNodeWrapper, sectionNode, sectionNumber, conf2); + log$1.debug("sectionNode output", node2); + sectionNodeWrapper.attr("transform", `translate(${masterX}, ${sectionBeginY})`); + masterY += maxSectionHeight + 50; + if (tasksForSection.length > 0) { + drawTasks( + svg2, + tasksForSection, + sectionNumber, + masterX, + masterY, + maxTaskHeight, + conf2, + maxEventCount, + maxEventLineLength, + maxSectionHeight, + false + ); + } + masterX += 200 * Math.max(tasksForSection.length, 1); + masterY = sectionBeginY; + sectionNumber++; + }); + } else { + hasSections = false; + drawTasks( + svg2, + tasks2, + sectionNumber, + masterX, + masterY, + maxTaskHeight, + conf2, + maxEventCount, + maxEventLineLength, + maxSectionHeight, + true + ); + } + const box = svg2.node().getBBox(); + log$1.debug("bounds", box); + if (title2) { + svg2.append("text").text(title2).attr("x", box.width / 2 - LEFT_MARGIN2).attr("font-size", "4ex").attr("font-weight", "bold").attr("y", 20); + } + depthY = hasSections ? maxSectionHeight + maxTaskHeight + 150 : maxTaskHeight + 100; + const lineWrapper = svg2.append("g").attr("class", "lineWrapper"); + lineWrapper.append("line").attr("x1", LEFT_MARGIN2).attr("y1", depthY).attr("x2", box.width + 3 * LEFT_MARGIN2).attr("y2", depthY).attr("stroke-width", 4).attr("stroke", "black").attr("marker-end", "url(#arrowhead)"); + setupGraphViewbox$1( + void 0, + svg2, + ((_a2 = conf2.timeline) == null ? void 0 : _a2.padding) ?? 50, + ((_b2 = conf2.timeline) == null ? void 0 : _b2.useMaxWidth) ?? false + ); + }; + const drawTasks = function(diagram2, tasks2, sectionColor, masterX, masterY, maxTaskHeight, conf2, maxEventCount, maxEventLineLength, maxSectionHeight, isWithoutSections) { + var _a2; + for (const task of tasks2) { + const taskNode = { + descr: task.task, + section: sectionColor, + number: sectionColor, + width: 150, + padding: 20, + maxHeight: maxTaskHeight + }; + log$1.debug("taskNode", taskNode); + const taskWrapper = diagram2.append("g").attr("class", "taskWrapper"); + const node2 = svgDraw.drawNode(taskWrapper, taskNode, sectionColor, conf2); + const taskHeight = node2.height; + log$1.debug("taskHeight after draw", taskHeight); + taskWrapper.attr("transform", `translate(${masterX}, ${masterY})`); + maxTaskHeight = Math.max(maxTaskHeight, taskHeight); + if (task.events) { + const lineWrapper = diagram2.append("g").attr("class", "lineWrapper"); + let lineLength = maxTaskHeight; + masterY += 100; + lineLength = lineLength + drawEvents(diagram2, task.events, sectionColor, masterX, masterY, conf2); + masterY -= 100; + lineWrapper.append("line").attr("x1", masterX + 190 / 2).attr("y1", masterY + maxTaskHeight).attr("x2", masterX + 190 / 2).attr( + "y2", + masterY + maxTaskHeight + (isWithoutSections ? maxTaskHeight : maxSectionHeight) + maxEventLineLength + 120 + ).attr("stroke-width", 2).attr("stroke", "black").attr("marker-end", "url(#arrowhead)").attr("stroke-dasharray", "5,5"); + } + masterX = masterX + 200; + if (isWithoutSections && !((_a2 = conf2.timeline) == null ? void 0 : _a2.disableMulticolor)) { + sectionColor++; + } + } + masterY = masterY - 10; + }; + const drawEvents = function(diagram2, events, sectionColor, masterX, masterY, conf2) { + let maxEventHeight = 0; + const eventBeginY = masterY; + masterY = masterY + 100; + for (const event of events) { + const eventNode = { + descr: event, + section: sectionColor, + number: sectionColor, + width: 150, + padding: 20, + maxHeight: 50 + }; + log$1.debug("eventNode", eventNode); + const eventWrapper = diagram2.append("g").attr("class", "eventWrapper"); + const node2 = svgDraw.drawNode(eventWrapper, eventNode, sectionColor, conf2); + const eventHeight = node2.height; + maxEventHeight = maxEventHeight + eventHeight; + eventWrapper.attr("transform", `translate(${masterX}, ${masterY})`); + masterY = masterY + 10 + eventHeight; + } + masterY = eventBeginY; + return maxEventHeight; + }; + const renderer$3 = { + setConf: () => { + }, + draw: draw$3 + }; + const genSections$1 = (options2) => { + let sections2 = ""; + for (let i2 = 0; i2 < options2.THEME_COLOR_LIMIT; i2++) { + options2["lineColor" + i2] = options2["lineColor" + i2] || options2["cScaleInv" + i2]; + if (isDark$1(options2["lineColor" + i2])) { + options2["lineColor" + i2] = lighten$1(options2["lineColor" + i2], 20); + } else { + options2["lineColor" + i2] = darken$1(options2["lineColor" + i2], 20); + } + } + for (let i2 = 0; i2 < options2.THEME_COLOR_LIMIT; i2++) { + const sw = "" + (17 - 3 * i2); + sections2 += ` + .section-${i2 - 1} rect, .section-${i2 - 1} path, .section-${i2 - 1} circle, .section-${i2 - 1} path { + fill: ${options2["cScale" + i2]}; + } + .section-${i2 - 1} text { + fill: ${options2["cScaleLabel" + i2]}; + } + .node-icon-${i2 - 1} { + font-size: 40px; + color: ${options2["cScaleLabel" + i2]}; + } + .section-edge-${i2 - 1}{ + stroke: ${options2["cScale" + i2]}; + } + .edge-depth-${i2 - 1}{ + stroke-width: ${sw}; + } + .section-${i2 - 1} line { + stroke: ${options2["cScaleInv" + i2]} ; + stroke-width: 3; + } + + .lineWrapper line{ + stroke: ${options2["cScaleLabel" + i2]} ; + } + + .disabled, .disabled circle, .disabled text { + fill: lightgray; + } + .disabled text { + fill: #efefef; + } + `; + } + return sections2; + }; + const getStyles$2 = (options2) => ` + .edge { + stroke-width: 3; + } + ${genSections$1(options2)} + .section-root rect, .section-root path, .section-root circle { + fill: ${options2.git0}; + } + .section-root text { + fill: ${options2.gitBranchLabel0}; + } + .icon-container { + height:100%; + display: flex; + justify-content: center; + align-items: center; + } + .edge { + fill: none; + } + .eventWrapper { + filter: brightness(120%); + } +`; + const styles$1 = getStyles$2; + const diagram$3 = { + db: db$5, + renderer: renderer$3, + parser: parser$7, + styles: styles$1 + }; + const timelineDefinition = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + diagram: diagram$3 + }, Symbol.toStringTag, { value: "Module" })); + var parser$4 = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 4], $V1 = [1, 13], $V2 = [1, 12], $V3 = [1, 15], $V4 = [1, 16], $V5 = [1, 20], $V6 = [1, 19], $V7 = [6, 7, 8], $V8 = [1, 26], $V9 = [1, 24], $Va = [1, 25], $Vb = [6, 7, 11], $Vc = [1, 6, 13, 15, 16, 19, 22], $Vd = [1, 33], $Ve = [1, 34], $Vf = [1, 6, 7, 11, 13, 15, 16, 19, 22]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "mindMap": 4, "spaceLines": 5, "SPACELINE": 6, "NL": 7, "MINDMAP": 8, "document": 9, "stop": 10, "EOF": 11, "statement": 12, "SPACELIST": 13, "node": 14, "ICON": 15, "CLASS": 16, "nodeWithId": 17, "nodeWithoutId": 18, "NODE_DSTART": 19, "NODE_DESCR": 20, "NODE_DEND": 21, "NODE_ID": 22, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 6: "SPACELINE", 7: "NL", 8: "MINDMAP", 11: "EOF", 13: "SPACELIST", 15: "ICON", 16: "CLASS", 19: "NODE_DSTART", 20: "NODE_DESCR", 21: "NODE_DEND", 22: "NODE_ID" }, + productions_: [0, [3, 1], [3, 2], [5, 1], [5, 2], [5, 2], [4, 2], [4, 3], [10, 1], [10, 1], [10, 1], [10, 2], [10, 2], [9, 3], [9, 2], [12, 2], [12, 2], [12, 2], [12, 1], [12, 1], [12, 1], [12, 1], [12, 1], [14, 1], [14, 1], [18, 3], [17, 1], [17, 4]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 6: + case 7: + return yy; + case 8: + yy.getLogger().trace("Stop NL "); + break; + case 9: + yy.getLogger().trace("Stop EOF "); + break; + case 11: + yy.getLogger().trace("Stop NL2 "); + break; + case 12: + yy.getLogger().trace("Stop EOF2 "); + break; + case 15: + yy.getLogger().info("Node: ", $$[$0].id); + yy.addNode($$[$0 - 1].length, $$[$0].id, $$[$0].descr, $$[$0].type); + break; + case 16: + yy.getLogger().trace("Icon: ", $$[$0]); + yy.decorateNode({ icon: $$[$0] }); + break; + case 17: + case 21: + yy.decorateNode({ class: $$[$0] }); + break; + case 18: + yy.getLogger().trace("SPACELIST"); + break; + case 19: + yy.getLogger().trace("Node: ", $$[$0].id); + yy.addNode(0, $$[$0].id, $$[$0].descr, $$[$0].type); + break; + case 20: + yy.decorateNode({ icon: $$[$0] }); + break; + case 25: + yy.getLogger().trace("node found ..", $$[$0 - 2]); + this.$ = { id: $$[$0 - 1], descr: $$[$0 - 1], type: yy.getType($$[$0 - 2], $$[$0]) }; + break; + case 26: + this.$ = { id: $$[$0], descr: $$[$0], type: yy.nodeType.DEFAULT }; + break; + case 27: + yy.getLogger().trace("node found ..", $$[$0 - 3]); + this.$ = { id: $$[$0 - 3], descr: $$[$0 - 1], type: yy.getType($$[$0 - 2], $$[$0]) }; + break; + } + }, + table: [{ 3: 1, 4: 2, 5: 3, 6: [1, 5], 8: $V0 }, { 1: [3] }, { 1: [2, 1] }, { 4: 6, 6: [1, 7], 7: [1, 8], 8: $V0 }, { 6: $V1, 7: [1, 10], 9: 9, 12: 11, 13: $V2, 14: 14, 15: $V3, 16: $V4, 17: 17, 18: 18, 19: $V5, 22: $V6 }, o($V7, [2, 3]), { 1: [2, 2] }, o($V7, [2, 4]), o($V7, [2, 5]), { 1: [2, 6], 6: $V1, 12: 21, 13: $V2, 14: 14, 15: $V3, 16: $V4, 17: 17, 18: 18, 19: $V5, 22: $V6 }, { 6: $V1, 9: 22, 12: 11, 13: $V2, 14: 14, 15: $V3, 16: $V4, 17: 17, 18: 18, 19: $V5, 22: $V6 }, { 6: $V8, 7: $V9, 10: 23, 11: $Va }, o($Vb, [2, 22], { 17: 17, 18: 18, 14: 27, 15: [1, 28], 16: [1, 29], 19: $V5, 22: $V6 }), o($Vb, [2, 18]), o($Vb, [2, 19]), o($Vb, [2, 20]), o($Vb, [2, 21]), o($Vb, [2, 23]), o($Vb, [2, 24]), o($Vb, [2, 26], { 19: [1, 30] }), { 20: [1, 31] }, { 6: $V8, 7: $V9, 10: 32, 11: $Va }, { 1: [2, 7], 6: $V1, 12: 21, 13: $V2, 14: 14, 15: $V3, 16: $V4, 17: 17, 18: 18, 19: $V5, 22: $V6 }, o($Vc, [2, 14], { 7: $Vd, 11: $Ve }), o($Vf, [2, 8]), o($Vf, [2, 9]), o($Vf, [2, 10]), o($Vb, [2, 15]), o($Vb, [2, 16]), o($Vb, [2, 17]), { 20: [1, 35] }, { 21: [1, 36] }, o($Vc, [2, 13], { 7: $Vd, 11: $Ve }), o($Vf, [2, 11]), o($Vf, [2, 12]), { 21: [1, 37] }, o($Vb, [2, 25]), o($Vb, [2, 27])], + defaultActions: { 2: [2, 1], 6: [2, 2] }, + parseError: function parseError(str2, hash) { + if (hash.recoverable) { + this.trace(str2); + } else { + var error = new Error(str2); + error.hash = hash; + throw error; + } + }, + parse: function parse2(input) { + var self2 = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex2() { + var token2; + token2 = tstack.pop() || lexer2.lex() || EOF; + if (typeof token2 !== "number") { + if (token2 instanceof Array) { + tstack = token2; + token2 = tstack.pop(); + } + token2 = self2.symbols_[token2] || token2; + } + return token2; + } + var symbol, state2, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state2 = stack[stack.length - 1]; + if (this.defaultActions[state2]) { + action = this.defaultActions[state2]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex2(); + } + action = table[state2] && table[state2][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state2]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state2 + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str2, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str2, hash); + } else { + throw new Error(str2); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch2 = this._input[0]; + this.yytext += ch2; + this.yyleng++; + this.offset++; + this.match += ch2; + this.matched += ch2; + var lines = ch2.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch2; + }, + // unshifts one char (or a string) into the input + unput: function(ch2) { + var len = ch2.length; + var lines = ch2.split(/(?:\r\n?|\n)/g); + this._input = ch2 + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next2 = this.match; + if (next2.length < 20) { + next2 += this._input.substr(0, 20 - next2.length); + } + return (next2.substr(0, 20) + (next2.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c2 = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c2 + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token2, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token2 = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token2) { + return token2; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token2, match, tempMatch, index2; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i2 = 0; i2 < rules.length; i2++) { + tempMatch = this._input.match(this.rules[rules[i2]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index2 = i2; + if (this.options.backtrack_lexer) { + token2 = this.test_match(tempMatch, rules[i2]); + if (token2 !== false) { + return token2; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token2 = this.test_match(match, rules[index2]); + if (token2 !== false) { + return token2; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex2() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + yy.getLogger().trace("Found comment", yy_.yytext); + return 6; + case 1: + return 8; + case 2: + this.begin("CLASS"); + break; + case 3: + this.popState(); + return 16; + case 4: + this.popState(); + break; + case 5: + yy.getLogger().trace("Begin icon"); + this.begin("ICON"); + break; + case 6: + yy.getLogger().trace("SPACELINE"); + return 6; + case 7: + return 7; + case 8: + return 15; + case 9: + yy.getLogger().trace("end icon"); + this.popState(); + break; + case 10: + yy.getLogger().trace("Exploding node"); + this.begin("NODE"); + return 19; + case 11: + yy.getLogger().trace("Cloud"); + this.begin("NODE"); + return 19; + case 12: + yy.getLogger().trace("Explosion Bang"); + this.begin("NODE"); + return 19; + case 13: + yy.getLogger().trace("Cloud Bang"); + this.begin("NODE"); + return 19; + case 14: + this.begin("NODE"); + return 19; + case 15: + this.begin("NODE"); + return 19; + case 16: + this.begin("NODE"); + return 19; + case 17: + this.begin("NODE"); + return 19; + case 18: + return 13; + case 19: + return 22; + case 20: + return 11; + case 21: + this.begin("NSTR2"); + break; + case 22: + return "NODE_DESCR"; + case 23: + this.popState(); + break; + case 24: + yy.getLogger().trace("Starting NSTR"); + this.begin("NSTR"); + break; + case 25: + yy.getLogger().trace("description:", yy_.yytext); + return "NODE_DESCR"; + case 26: + this.popState(); + break; + case 27: + this.popState(); + yy.getLogger().trace("node end ))"); + return "NODE_DEND"; + case 28: + this.popState(); + yy.getLogger().trace("node end )"); + return "NODE_DEND"; + case 29: + this.popState(); + yy.getLogger().trace("node end ...", yy_.yytext); + return "NODE_DEND"; + case 30: + this.popState(); + yy.getLogger().trace("node end (("); + return "NODE_DEND"; + case 31: + this.popState(); + yy.getLogger().trace("node end (-"); + return "NODE_DEND"; + case 32: + this.popState(); + yy.getLogger().trace("node end (-"); + return "NODE_DEND"; + case 33: + this.popState(); + yy.getLogger().trace("node end (("); + return "NODE_DEND"; + case 34: + this.popState(); + yy.getLogger().trace("node end (("); + return "NODE_DEND"; + case 35: + yy.getLogger().trace("Long description:", yy_.yytext); + return 20; + case 36: + yy.getLogger().trace("Long description:", yy_.yytext); + return 20; + } + }, + rules: [/^(?:\s*%%.*)/i, /^(?:mindmap\b)/i, /^(?::::)/i, /^(?:.+)/i, /^(?:\n)/i, /^(?:::icon\()/i, /^(?:[\s]+[\n])/i, /^(?:[\n]+)/i, /^(?:[^\)]+)/i, /^(?:\))/i, /^(?:-\))/i, /^(?:\(-)/i, /^(?:\)\))/i, /^(?:\))/i, /^(?:\(\()/i, /^(?:\{\{)/i, /^(?:\()/i, /^(?:\[)/i, /^(?:[\s]+)/i, /^(?:[^\(\[\n\)\{\}]+)/i, /^(?:$)/i, /^(?:["][`])/i, /^(?:[^`"]+)/i, /^(?:[`]["])/i, /^(?:["])/i, /^(?:[^"]+)/i, /^(?:["])/i, /^(?:[\)]\))/i, /^(?:[\)])/i, /^(?:[\]])/i, /^(?:\}\})/i, /^(?:\(-)/i, /^(?:-\))/i, /^(?:\(\()/i, /^(?:\()/i, /^(?:[^\)\]\(\}]+)/i, /^(?:.+(?!\(\())/i], + conditions: { "CLASS": { "rules": [3, 4], "inclusive": false }, "ICON": { "rules": [8, 9], "inclusive": false }, "NSTR2": { "rules": [22, 23], "inclusive": false }, "NSTR": { "rules": [25, 26], "inclusive": false }, "NODE": { "rules": [21, 24, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36], "inclusive": false }, "INITIAL": { "rules": [0, 1, 2, 5, 6, 7, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser2() { + this.yy = {}; + } + Parser2.prototype = parser2; + parser2.Parser = Parser2; + return new Parser2(); + }(); + parser$4.parser = parser$4; + const parser$5 = parser$4; + let nodes$1 = []; + let cnt$1 = 0; + let elements = {}; + const clear$2 = () => { + nodes$1 = []; + cnt$1 = 0; + elements = {}; + }; + const getParent = function(level) { + for (let i2 = nodes$1.length - 1; i2 >= 0; i2--) { + if (nodes$1[i2].level < level) { + return nodes$1[i2]; + } + } + return null; + }; + const getMindmap = () => { + return nodes$1.length > 0 ? nodes$1[0] : null; + }; + const addNode = (level, id2, descr, type2) => { + var _a2, _b2; + log$1.info("addNode", level, id2, descr, type2); + const conf2 = getConfig$1(); + let padding2 = ((_a2 = conf2.mindmap) == null ? void 0 : _a2.padding) ?? defaultConfig$2.mindmap.padding; + switch (type2) { + case nodeType.ROUNDED_RECT: + case nodeType.RECT: + case nodeType.HEXAGON: + padding2 *= 2; + } + const node2 = { + id: cnt$1++, + nodeId: sanitizeText$6(id2, conf2), + level, + descr: sanitizeText$6(descr, conf2), + type: type2, + children: [], + width: ((_b2 = conf2.mindmap) == null ? void 0 : _b2.maxNodeWidth) ?? defaultConfig$2.mindmap.maxNodeWidth, + padding: padding2 + }; + const parent = getParent(level); + if (parent) { + parent.children.push(node2); + nodes$1.push(node2); + } else { + if (nodes$1.length === 0) { + nodes$1.push(node2); + } else { + throw new Error( + 'There can be only one root. No parent could be found for ("' + node2.descr + '")' + ); + } + } + }; + const nodeType = { + DEFAULT: 0, + NO_BORDER: 0, + ROUNDED_RECT: 1, + RECT: 2, + CIRCLE: 3, + CLOUD: 4, + BANG: 5, + HEXAGON: 6 + }; + const getType = (startStr, endStr) => { + log$1.debug("In get type", startStr, endStr); + switch (startStr) { + case "[": + return nodeType.RECT; + case "(": + return endStr === ")" ? nodeType.ROUNDED_RECT : nodeType.CLOUD; + case "((": + return nodeType.CIRCLE; + case ")": + return nodeType.CLOUD; + case "))": + return nodeType.BANG; + case "{{": + return nodeType.HEXAGON; + default: + return nodeType.DEFAULT; + } + }; + const setElementForId = (id2, element2) => { + elements[id2] = element2; + }; + const decorateNode = (decoration) => { + if (!decoration) { + return; + } + const config2 = getConfig$1(); + const node2 = nodes$1[nodes$1.length - 1]; + if (decoration.icon) { + node2.icon = sanitizeText$6(decoration.icon, config2); + } + if (decoration.class) { + node2.class = sanitizeText$6(decoration.class, config2); + } + }; + const type2Str = (type2) => { + switch (type2) { + case nodeType.DEFAULT: + return "no-border"; + case nodeType.RECT: + return "rect"; + case nodeType.ROUNDED_RECT: + return "rounded-rect"; + case nodeType.CIRCLE: + return "circle"; + case nodeType.CLOUD: + return "cloud"; + case nodeType.BANG: + return "bang"; + case nodeType.HEXAGON: + return "hexgon"; + default: + return "no-border"; + } + }; + const getLogger$1 = () => log$1; + const getElementById = (id2) => elements[id2]; + const db$3 = { + clear: clear$2, + addNode, + getMindmap, + nodeType, + getType, + setElementForId, + decorateNode, + type2Str, + getLogger: getLogger$1, + getElementById + }; + const db$4 = db$3; + var cytoscape_umd = { exports: {} }; + (function(module2, exports2) { + (function(global2, factory) { + module2.exports = factory(); + })(commonjsGlobal, function() { + function _typeof(obj) { + "@babel/helpers - typeof"; + return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function(obj2) { + return typeof obj2; + } : function(obj2) { + return obj2 && "function" == typeof Symbol && obj2.constructor === Symbol && obj2 !== Symbol.prototype ? "symbol" : typeof obj2; + }, _typeof(obj); + } + function _classCallCheck(instance2, Constructor) { + if (!(instance2 instanceof Constructor)) { + throw new TypeError("Cannot call a class as a function"); + } + } + function _defineProperties(target, props) { + for (var i3 = 0; i3 < props.length; i3++) { + var descriptor = props[i3]; + descriptor.enumerable = descriptor.enumerable || false; + descriptor.configurable = true; + if ("value" in descriptor) + descriptor.writable = true; + Object.defineProperty(target, descriptor.key, descriptor); + } + } + function _createClass(Constructor, protoProps, staticProps) { + if (protoProps) + _defineProperties(Constructor.prototype, protoProps); + if (staticProps) + _defineProperties(Constructor, staticProps); + Object.defineProperty(Constructor, "prototype", { + writable: false + }); + return Constructor; + } + function _defineProperty$1(obj, key, value2) { + if (key in obj) { + Object.defineProperty(obj, key, { + value: value2, + enumerable: true, + configurable: true, + writable: true + }); + } else { + obj[key] = value2; + } + return obj; + } + function _slicedToArray(arr, i3) { + return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i3) || _unsupportedIterableToArray(arr, i3) || _nonIterableRest(); + } + function _arrayWithHoles(arr) { + if (Array.isArray(arr)) + return arr; + } + function _iterableToArrayLimit(arr, i3) { + var _i6 = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; + if (_i6 == null) + return; + var _arr = []; + var _n = true; + var _d = false; + var _s, _e; + try { + for (_i6 = _i6.call(arr); !(_n = (_s = _i6.next()).done); _n = true) { + _arr.push(_s.value); + if (i3 && _arr.length === i3) + break; + } + } catch (err) { + _d = true; + _e = err; + } finally { + try { + if (!_n && _i6["return"] != null) + _i6["return"](); + } finally { + if (_d) + throw _e; + } + } + return _arr; + } + function _unsupportedIterableToArray(o, minLen) { + if (!o) + return; + if (typeof o === "string") + return _arrayLikeToArray(o, minLen); + var n = Object.prototype.toString.call(o).slice(8, -1); + if (n === "Object" && o.constructor) + n = o.constructor.name; + if (n === "Map" || n === "Set") + return Array.from(o); + if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) + return _arrayLikeToArray(o, minLen); + } + function _arrayLikeToArray(arr, len) { + if (len == null || len > arr.length) + len = arr.length; + for (var i3 = 0, arr2 = new Array(len); i3 < len; i3++) + arr2[i3] = arr[i3]; + return arr2; + } + function _nonIterableRest() { + throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); + } + var _window = typeof window === "undefined" ? null : window; + var navigator2 = _window ? _window.navigator : null; + _window ? _window.document : null; + var typeofstr = _typeof(""); + var typeofobj = _typeof({}); + var typeoffn = _typeof(function() { + }); + var typeofhtmlele = typeof HTMLElement === "undefined" ? "undefined" : _typeof(HTMLElement); + var instanceStr = function instanceStr2(obj) { + return obj && obj.instanceString && fn$6(obj.instanceString) ? obj.instanceString() : null; + }; + var string2 = function string3(obj) { + return obj != null && _typeof(obj) == typeofstr; + }; + var fn$6 = function fn2(obj) { + return obj != null && _typeof(obj) === typeoffn; + }; + var array2 = function array3(obj) { + return !elementOrCollection(obj) && (Array.isArray ? Array.isArray(obj) : obj != null && obj instanceof Array); + }; + var plainObject = function plainObject2(obj) { + return obj != null && _typeof(obj) === typeofobj && !array2(obj) && obj.constructor === Object; + }; + var object2 = function object3(obj) { + return obj != null && _typeof(obj) === typeofobj; + }; + var number$12 = function number3(obj) { + return obj != null && _typeof(obj) === _typeof(1) && !isNaN(obj); + }; + var integer = function integer2(obj) { + return number$12(obj) && Math.floor(obj) === obj; + }; + var htmlElement = function htmlElement2(obj) { + if ("undefined" === typeofhtmlele) { + return void 0; + } else { + return null != obj && obj instanceof HTMLElement; + } + }; + var elementOrCollection = function elementOrCollection2(obj) { + return element2(obj) || collection(obj); + }; + var element2 = function element3(obj) { + return instanceStr(obj) === "collection" && obj._private.single; + }; + var collection = function collection2(obj) { + return instanceStr(obj) === "collection" && !obj._private.single; + }; + var core2 = function core3(obj) { + return instanceStr(obj) === "core"; + }; + var stylesheet = function stylesheet2(obj) { + return instanceStr(obj) === "stylesheet"; + }; + var event = function event2(obj) { + return instanceStr(obj) === "event"; + }; + var emptyString = function emptyString2(obj) { + if (obj === void 0 || obj === null) { + return true; + } else if (obj === "" || obj.match(/^\s+$/)) { + return true; + } + return false; + }; + var domElement = function domElement2(obj) { + if (typeof HTMLElement === "undefined") { + return false; + } else { + return obj instanceof HTMLElement; + } + }; + var boundingBox = function boundingBox2(obj) { + return plainObject(obj) && number$12(obj.x1) && number$12(obj.x2) && number$12(obj.y1) && number$12(obj.y2); + }; + var promise = function promise2(obj) { + return object2(obj) && fn$6(obj.then); + }; + var ms = function ms2() { + return navigator2 && navigator2.userAgent.match(/msie|trident|edge/i); + }; + var memoize$1 = function memoize3(fn2, keyFn) { + if (!keyFn) { + keyFn = function keyFn2() { + if (arguments.length === 1) { + return arguments[0]; + } else if (arguments.length === 0) { + return "undefined"; + } + var args = []; + for (var i3 = 0; i3 < arguments.length; i3++) { + args.push(arguments[i3]); + } + return args.join("$"); + }; + } + var memoizedFn = function memoizedFn2() { + var self2 = this; + var args = arguments; + var ret; + var k = keyFn.apply(self2, args); + var cache2 = memoizedFn2.cache; + if (!(ret = cache2[k])) { + ret = cache2[k] = fn2.apply(self2, args); + } + return ret; + }; + memoizedFn.cache = {}; + return memoizedFn; + }; + var camel2dash = memoize$1(function(str2) { + return str2.replace(/([A-Z])/g, function(v) { + return "-" + v.toLowerCase(); + }); + }); + var dash2camel = memoize$1(function(str2) { + return str2.replace(/(-\w)/g, function(v) { + return v[1].toUpperCase(); + }); + }); + var prependCamel = memoize$1(function(prefix, str2) { + return prefix + str2[0].toUpperCase() + str2.substring(1); + }, function(prefix, str2) { + return prefix + "$" + str2; + }); + var capitalize = function capitalize2(str2) { + if (emptyString(str2)) { + return str2; + } + return str2.charAt(0).toUpperCase() + str2.substring(1); + }; + var number2 = "(?:[-+]?(?:(?:\\d+|\\d*\\.\\d+)(?:[Ee][+-]?\\d+)?))"; + var rgba2 = "rgb[a]?\\((" + number2 + "[%]?)\\s*,\\s*(" + number2 + "[%]?)\\s*,\\s*(" + number2 + "[%]?)(?:\\s*,\\s*(" + number2 + "))?\\)"; + var rgbaNoBackRefs = "rgb[a]?\\((?:" + number2 + "[%]?)\\s*,\\s*(?:" + number2 + "[%]?)\\s*,\\s*(?:" + number2 + "[%]?)(?:\\s*,\\s*(?:" + number2 + "))?\\)"; + var hsla2 = "hsl[a]?\\((" + number2 + ")\\s*,\\s*(" + number2 + "[%])\\s*,\\s*(" + number2 + "[%])(?:\\s*,\\s*(" + number2 + "))?\\)"; + var hslaNoBackRefs = "hsl[a]?\\((?:" + number2 + ")\\s*,\\s*(?:" + number2 + "[%])\\s*,\\s*(?:" + number2 + "[%])(?:\\s*,\\s*(?:" + number2 + "))?\\)"; + var hex3 = "\\#[0-9a-fA-F]{3}"; + var hex6 = "\\#[0-9a-fA-F]{6}"; + var ascending2 = function ascending3(a, b) { + if (a < b) { + return -1; + } else if (a > b) { + return 1; + } else { + return 0; + } + }; + var descending2 = function descending3(a, b) { + return -1 * ascending2(a, b); + }; + var extend2 = Object.assign != null ? Object.assign.bind(Object) : function(tgt) { + var args = arguments; + for (var i3 = 1; i3 < args.length; i3++) { + var obj = args[i3]; + if (obj == null) { + continue; + } + var keys2 = Object.keys(obj); + for (var j = 0; j < keys2.length; j++) { + var k = keys2[j]; + tgt[k] = obj[k]; + } + } + return tgt; + }; + var hex2tuple = function hex2tuple2(hex2) { + if (!(hex2.length === 4 || hex2.length === 7) || hex2[0] !== "#") { + return; + } + var shortHex = hex2.length === 4; + var r, g, b; + var base = 16; + if (shortHex) { + r = parseInt(hex2[1] + hex2[1], base); + g = parseInt(hex2[2] + hex2[2], base); + b = parseInt(hex2[3] + hex2[3], base); + } else { + r = parseInt(hex2[1] + hex2[2], base); + g = parseInt(hex2[3] + hex2[4], base); + b = parseInt(hex2[5] + hex2[6], base); + } + return [r, g, b]; + }; + var hsl2tuple = function hsl2tuple2(hsl2) { + var ret; + var h, s, l, a, r, g, b; + function hue2rgb(p3, q2, t) { + if (t < 0) + t += 1; + if (t > 1) + t -= 1; + if (t < 1 / 6) + return p3 + (q2 - p3) * 6 * t; + if (t < 1 / 2) + return q2; + if (t < 2 / 3) + return p3 + (q2 - p3) * (2 / 3 - t) * 6; + return p3; + } + var m = new RegExp("^" + hsla2 + "$").exec(hsl2); + if (m) { + h = parseInt(m[1]); + if (h < 0) { + h = (360 - -1 * h % 360) % 360; + } else if (h > 360) { + h = h % 360; + } + h /= 360; + s = parseFloat(m[2]); + if (s < 0 || s > 100) { + return; + } + s = s / 100; + l = parseFloat(m[3]); + if (l < 0 || l > 100) { + return; + } + l = l / 100; + a = m[4]; + if (a !== void 0) { + a = parseFloat(a); + if (a < 0 || a > 1) { + return; + } + } + if (s === 0) { + r = g = b = Math.round(l * 255); + } else { + var q = l < 0.5 ? l * (1 + s) : l + s - l * s; + var p2 = 2 * l - q; + r = Math.round(255 * hue2rgb(p2, q, h + 1 / 3)); + g = Math.round(255 * hue2rgb(p2, q, h)); + b = Math.round(255 * hue2rgb(p2, q, h - 1 / 3)); + } + ret = [r, g, b, a]; + } + return ret; + }; + var rgb2tuple = function rgb2tuple2(rgb2) { + var ret; + var m = new RegExp("^" + rgba2 + "$").exec(rgb2); + if (m) { + ret = []; + var isPct = []; + for (var i3 = 1; i3 <= 3; i3++) { + var channel2 = m[i3]; + if (channel2[channel2.length - 1] === "%") { + isPct[i3] = true; + } + channel2 = parseFloat(channel2); + if (isPct[i3]) { + channel2 = channel2 / 100 * 255; + } + if (channel2 < 0 || channel2 > 255) { + return; + } + ret.push(Math.floor(channel2)); + } + var atLeastOneIsPct = isPct[1] || isPct[2] || isPct[3]; + var allArePct = isPct[1] && isPct[2] && isPct[3]; + if (atLeastOneIsPct && !allArePct) { + return; + } + var alpha = m[4]; + if (alpha !== void 0) { + alpha = parseFloat(alpha); + if (alpha < 0 || alpha > 1) { + return; + } + ret.push(alpha); + } + } + return ret; + }; + var colorname2tuple = function colorname2tuple2(color2) { + return colors2[color2.toLowerCase()]; + }; + var color2tuple = function color2tuple2(color2) { + return (array2(color2) ? color2 : null) || colorname2tuple(color2) || hex2tuple(color2) || rgb2tuple(color2) || hsl2tuple(color2); + }; + var colors2 = { + // special colour names + transparent: [0, 0, 0, 0], + // NB alpha === 0 + // regular colours + aliceblue: [240, 248, 255], + antiquewhite: [250, 235, 215], + aqua: [0, 255, 255], + aquamarine: [127, 255, 212], + azure: [240, 255, 255], + beige: [245, 245, 220], + bisque: [255, 228, 196], + black: [0, 0, 0], + blanchedalmond: [255, 235, 205], + blue: [0, 0, 255], + blueviolet: [138, 43, 226], + brown: [165, 42, 42], + burlywood: [222, 184, 135], + cadetblue: [95, 158, 160], + chartreuse: [127, 255, 0], + chocolate: [210, 105, 30], + coral: [255, 127, 80], + cornflowerblue: [100, 149, 237], + cornsilk: [255, 248, 220], + crimson: [220, 20, 60], + cyan: [0, 255, 255], + darkblue: [0, 0, 139], + darkcyan: [0, 139, 139], + darkgoldenrod: [184, 134, 11], + darkgray: [169, 169, 169], + darkgreen: [0, 100, 0], + darkgrey: [169, 169, 169], + darkkhaki: [189, 183, 107], + darkmagenta: [139, 0, 139], + darkolivegreen: [85, 107, 47], + darkorange: [255, 140, 0], + darkorchid: [153, 50, 204], + darkred: [139, 0, 0], + darksalmon: [233, 150, 122], + darkseagreen: [143, 188, 143], + darkslateblue: [72, 61, 139], + darkslategray: [47, 79, 79], + darkslategrey: [47, 79, 79], + darkturquoise: [0, 206, 209], + darkviolet: [148, 0, 211], + deeppink: [255, 20, 147], + deepskyblue: [0, 191, 255], + dimgray: [105, 105, 105], + dimgrey: [105, 105, 105], + dodgerblue: [30, 144, 255], + firebrick: [178, 34, 34], + floralwhite: [255, 250, 240], + forestgreen: [34, 139, 34], + fuchsia: [255, 0, 255], + gainsboro: [220, 220, 220], + ghostwhite: [248, 248, 255], + gold: [255, 215, 0], + goldenrod: [218, 165, 32], + gray: [128, 128, 128], + grey: [128, 128, 128], + green: [0, 128, 0], + greenyellow: [173, 255, 47], + honeydew: [240, 255, 240], + hotpink: [255, 105, 180], + indianred: [205, 92, 92], + indigo: [75, 0, 130], + ivory: [255, 255, 240], + khaki: [240, 230, 140], + lavender: [230, 230, 250], + lavenderblush: [255, 240, 245], + lawngreen: [124, 252, 0], + lemonchiffon: [255, 250, 205], + lightblue: [173, 216, 230], + lightcoral: [240, 128, 128], + lightcyan: [224, 255, 255], + lightgoldenrodyellow: [250, 250, 210], + lightgray: [211, 211, 211], + lightgreen: [144, 238, 144], + lightgrey: [211, 211, 211], + lightpink: [255, 182, 193], + lightsalmon: [255, 160, 122], + lightseagreen: [32, 178, 170], + lightskyblue: [135, 206, 250], + lightslategray: [119, 136, 153], + lightslategrey: [119, 136, 153], + lightsteelblue: [176, 196, 222], + lightyellow: [255, 255, 224], + lime: [0, 255, 0], + limegreen: [50, 205, 50], + linen: [250, 240, 230], + magenta: [255, 0, 255], + maroon: [128, 0, 0], + mediumaquamarine: [102, 205, 170], + mediumblue: [0, 0, 205], + mediumorchid: [186, 85, 211], + mediumpurple: [147, 112, 219], + mediumseagreen: [60, 179, 113], + mediumslateblue: [123, 104, 238], + mediumspringgreen: [0, 250, 154], + mediumturquoise: [72, 209, 204], + mediumvioletred: [199, 21, 133], + midnightblue: [25, 25, 112], + mintcream: [245, 255, 250], + mistyrose: [255, 228, 225], + moccasin: [255, 228, 181], + navajowhite: [255, 222, 173], + navy: [0, 0, 128], + oldlace: [253, 245, 230], + olive: [128, 128, 0], + olivedrab: [107, 142, 35], + orange: [255, 165, 0], + orangered: [255, 69, 0], + orchid: [218, 112, 214], + palegoldenrod: [238, 232, 170], + palegreen: [152, 251, 152], + paleturquoise: [175, 238, 238], + palevioletred: [219, 112, 147], + papayawhip: [255, 239, 213], + peachpuff: [255, 218, 185], + peru: [205, 133, 63], + pink: [255, 192, 203], + plum: [221, 160, 221], + powderblue: [176, 224, 230], + purple: [128, 0, 128], + red: [255, 0, 0], + rosybrown: [188, 143, 143], + royalblue: [65, 105, 225], + saddlebrown: [139, 69, 19], + salmon: [250, 128, 114], + sandybrown: [244, 164, 96], + seagreen: [46, 139, 87], + seashell: [255, 245, 238], + sienna: [160, 82, 45], + silver: [192, 192, 192], + skyblue: [135, 206, 235], + slateblue: [106, 90, 205], + slategray: [112, 128, 144], + slategrey: [112, 128, 144], + snow: [255, 250, 250], + springgreen: [0, 255, 127], + steelblue: [70, 130, 180], + tan: [210, 180, 140], + teal: [0, 128, 128], + thistle: [216, 191, 216], + tomato: [255, 99, 71], + turquoise: [64, 224, 208], + violet: [238, 130, 238], + wheat: [245, 222, 179], + white: [255, 255, 255], + whitesmoke: [245, 245, 245], + yellow: [255, 255, 0], + yellowgreen: [154, 205, 50] + }; + var setMap = function setMap2(options2) { + var obj = options2.map; + var keys2 = options2.keys; + var l = keys2.length; + for (var i3 = 0; i3 < l; i3++) { + var key = keys2[i3]; + if (plainObject(key)) { + throw Error("Tried to set map with object key"); + } + if (i3 < keys2.length - 1) { + if (obj[key] == null) { + obj[key] = {}; + } + obj = obj[key]; + } else { + obj[key] = options2.value; + } + } + }; + var getMap = function getMap2(options2) { + var obj = options2.map; + var keys2 = options2.keys; + var l = keys2.length; + for (var i3 = 0; i3 < l; i3++) { + var key = keys2[i3]; + if (plainObject(key)) { + throw Error("Tried to get map with object key"); + } + obj = obj[key]; + if (obj == null) { + return obj; + } + } + return obj; + }; + function isObject2(value2) { + var type2 = typeof value2; + return value2 != null && (type2 == "object" || type2 == "function"); + } + var isObject_12 = isObject2; + var commonjsGlobal$1 = typeof globalThis !== "undefined" ? globalThis : typeof window !== "undefined" ? window : typeof commonjsGlobal !== "undefined" ? commonjsGlobal : typeof self !== "undefined" ? self : {}; + function createCommonjsModule(fn2, module3) { + return module3 = { exports: {} }, fn2(module3, module3.exports), module3.exports; + } + var freeGlobal2 = typeof commonjsGlobal$1 == "object" && commonjsGlobal$1 && commonjsGlobal$1.Object === Object && commonjsGlobal$1; + var _freeGlobal = freeGlobal2; + var freeSelf2 = typeof self == "object" && self && self.Object === Object && self; + var root2 = _freeGlobal || freeSelf2 || Function("return this")(); + var _root = root2; + var now2 = function() { + return _root.Date.now(); + }; + var now_1 = now2; + var reWhitespace2 = /\s/; + function trimmedEndIndex2(string3) { + var index2 = string3.length; + while (index2-- && reWhitespace2.test(string3.charAt(index2))) { + } + return index2; + } + var _trimmedEndIndex = trimmedEndIndex2; + var reTrimStart2 = /^\s+/; + function baseTrim2(string3) { + return string3 ? string3.slice(0, _trimmedEndIndex(string3) + 1).replace(reTrimStart2, "") : string3; + } + var _baseTrim = baseTrim2; + var Symbol$12 = _root.Symbol; + var _Symbol = Symbol$12; + var objectProto$52 = Object.prototype; + var hasOwnProperty$42 = objectProto$52.hasOwnProperty; + var nativeObjectToString$12 = objectProto$52.toString; + var symToStringTag$12 = _Symbol ? _Symbol.toStringTag : void 0; + function getRawTag2(value2) { + var isOwn = hasOwnProperty$42.call(value2, symToStringTag$12), tag = value2[symToStringTag$12]; + try { + value2[symToStringTag$12] = void 0; + var unmasked = true; + } catch (e) { + } + var result = nativeObjectToString$12.call(value2); + if (unmasked) { + if (isOwn) { + value2[symToStringTag$12] = tag; + } else { + delete value2[symToStringTag$12]; + } + } + return result; + } + var _getRawTag = getRawTag2; + var objectProto$42 = Object.prototype; + var nativeObjectToString2 = objectProto$42.toString; + function objectToString2(value2) { + return nativeObjectToString2.call(value2); + } + var _objectToString = objectToString2; + var nullTag2 = "[object Null]", undefinedTag2 = "[object Undefined]"; + var symToStringTag2 = _Symbol ? _Symbol.toStringTag : void 0; + function baseGetTag2(value2) { + if (value2 == null) { + return value2 === void 0 ? undefinedTag2 : nullTag2; + } + return symToStringTag2 && symToStringTag2 in Object(value2) ? _getRawTag(value2) : _objectToString(value2); + } + var _baseGetTag = baseGetTag2; + function isObjectLike2(value2) { + return value2 != null && typeof value2 == "object"; + } + var isObjectLike_1 = isObjectLike2; + var symbolTag2 = "[object Symbol]"; + function isSymbol2(value2) { + return typeof value2 == "symbol" || isObjectLike_1(value2) && _baseGetTag(value2) == symbolTag2; + } + var isSymbol_1 = isSymbol2; + var NAN2 = 0 / 0; + var reIsBadHex2 = /^[-+]0x[0-9a-f]+$/i; + var reIsBinary2 = /^0b[01]+$/i; + var reIsOctal2 = /^0o[0-7]+$/i; + var freeParseInt2 = parseInt; + function toNumber2(value2) { + if (typeof value2 == "number") { + return value2; + } + if (isSymbol_1(value2)) { + return NAN2; + } + if (isObject_12(value2)) { + var other = typeof value2.valueOf == "function" ? value2.valueOf() : value2; + value2 = isObject_12(other) ? other + "" : other; + } + if (typeof value2 != "string") { + return value2 === 0 ? value2 : +value2; + } + value2 = _baseTrim(value2); + var isBinary2 = reIsBinary2.test(value2); + return isBinary2 || reIsOctal2.test(value2) ? freeParseInt2(value2.slice(2), isBinary2 ? 2 : 8) : reIsBadHex2.test(value2) ? NAN2 : +value2; + } + var toNumber_1 = toNumber2; + var FUNC_ERROR_TEXT$1 = "Expected a function"; + var nativeMax2 = Math.max, nativeMin = Math.min; + function debounce(func, wait, options2) { + var lastArgs, lastThis, maxWait, result, timerId, lastCallTime, lastInvokeTime = 0, leading = false, maxing = false, trailing = true; + if (typeof func != "function") { + throw new TypeError(FUNC_ERROR_TEXT$1); + } + wait = toNumber_1(wait) || 0; + if (isObject_12(options2)) { + leading = !!options2.leading; + maxing = "maxWait" in options2; + maxWait = maxing ? nativeMax2(toNumber_1(options2.maxWait) || 0, wait) : maxWait; + trailing = "trailing" in options2 ? !!options2.trailing : trailing; + } + function invokeFunc(time2) { + var args = lastArgs, thisArg = lastThis; + lastArgs = lastThis = void 0; + lastInvokeTime = time2; + result = func.apply(thisArg, args); + return result; + } + function leadingEdge(time2) { + lastInvokeTime = time2; + timerId = setTimeout(timerExpired, wait); + return leading ? invokeFunc(time2) : result; + } + function remainingWait(time2) { + var timeSinceLastCall = time2 - lastCallTime, timeSinceLastInvoke = time2 - lastInvokeTime, timeWaiting = wait - timeSinceLastCall; + return maxing ? nativeMin(timeWaiting, maxWait - timeSinceLastInvoke) : timeWaiting; + } + function shouldInvoke(time2) { + var timeSinceLastCall = time2 - lastCallTime, timeSinceLastInvoke = time2 - lastInvokeTime; + return lastCallTime === void 0 || timeSinceLastCall >= wait || timeSinceLastCall < 0 || maxing && timeSinceLastInvoke >= maxWait; + } + function timerExpired() { + var time2 = now_1(); + if (shouldInvoke(time2)) { + return trailingEdge(time2); + } + timerId = setTimeout(timerExpired, remainingWait(time2)); + } + function trailingEdge(time2) { + timerId = void 0; + if (trailing && lastArgs) { + return invokeFunc(time2); + } + lastArgs = lastThis = void 0; + return result; + } + function cancel() { + if (timerId !== void 0) { + clearTimeout(timerId); + } + lastInvokeTime = 0; + lastArgs = lastCallTime = lastThis = timerId = void 0; + } + function flush() { + return timerId === void 0 ? result : trailingEdge(now_1()); + } + function debounced() { + var time2 = now_1(), isInvoking = shouldInvoke(time2); + lastArgs = arguments; + lastThis = this; + lastCallTime = time2; + if (isInvoking) { + if (timerId === void 0) { + return leadingEdge(lastCallTime); + } + if (maxing) { + clearTimeout(timerId); + timerId = setTimeout(timerExpired, wait); + return invokeFunc(lastCallTime); + } + } + if (timerId === void 0) { + timerId = setTimeout(timerExpired, wait); + } + return result; + } + debounced.cancel = cancel; + debounced.flush = flush; + return debounced; + } + var debounce_1 = debounce; + var performance2 = _window ? _window.performance : null; + var pnow = performance2 && performance2.now ? function() { + return performance2.now(); + } : function() { + return Date.now(); + }; + var raf = function() { + if (_window) { + if (_window.requestAnimationFrame) { + return function(fn2) { + _window.requestAnimationFrame(fn2); + }; + } else if (_window.mozRequestAnimationFrame) { + return function(fn2) { + _window.mozRequestAnimationFrame(fn2); + }; + } else if (_window.webkitRequestAnimationFrame) { + return function(fn2) { + _window.webkitRequestAnimationFrame(fn2); + }; + } else if (_window.msRequestAnimationFrame) { + return function(fn2) { + _window.msRequestAnimationFrame(fn2); + }; + } + } + return function(fn2) { + if (fn2) { + setTimeout(function() { + fn2(pnow()); + }, 1e3 / 60); + } + }; + }(); + var requestAnimationFrame2 = function requestAnimationFrame3(fn2) { + return raf(fn2); + }; + var performanceNow = pnow; + var DEFAULT_HASH_SEED = 9261; + var K2 = 65599; + var DEFAULT_HASH_SEED_ALT = 5381; + var hashIterableInts = function hashIterableInts2(iterator) { + var seed = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : DEFAULT_HASH_SEED; + var hash = seed; + var entry; + for (; ; ) { + entry = iterator.next(); + if (entry.done) { + break; + } + hash = hash * K2 + entry.value | 0; + } + return hash; + }; + var hashInt = function hashInt2(num) { + var seed = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : DEFAULT_HASH_SEED; + return seed * K2 + num | 0; + }; + var hashIntAlt = function hashIntAlt2(num) { + var seed = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : DEFAULT_HASH_SEED_ALT; + return (seed << 5) + seed + num | 0; + }; + var combineHashes = function combineHashes2(hash1, hash2) { + return hash1 * 2097152 + hash2; + }; + var combineHashesArray = function combineHashesArray2(hashes) { + return hashes[0] * 2097152 + hashes[1]; + }; + var hashArrays = function hashArrays2(hashes1, hashes2) { + return [hashInt(hashes1[0], hashes2[0]), hashIntAlt(hashes1[1], hashes2[1])]; + }; + var hashIntsArray = function hashIntsArray2(ints, seed) { + var entry = { + value: 0, + done: false + }; + var i3 = 0; + var length2 = ints.length; + var iterator = { + next: function next2() { + if (i3 < length2) { + entry.value = ints[i3++]; + } else { + entry.done = true; + } + return entry; + } + }; + return hashIterableInts(iterator, seed); + }; + var hashString = function hashString2(str2, seed) { + var entry = { + value: 0, + done: false + }; + var i3 = 0; + var length2 = str2.length; + var iterator = { + next: function next2() { + if (i3 < length2) { + entry.value = str2.charCodeAt(i3++); + } else { + entry.done = true; + } + return entry; + } + }; + return hashIterableInts(iterator, seed); + }; + var hashStrings = function hashStrings2() { + return hashStringsArray(arguments); + }; + var hashStringsArray = function hashStringsArray2(strs) { + var hash; + for (var i3 = 0; i3 < strs.length; i3++) { + var str2 = strs[i3]; + if (i3 === 0) { + hash = hashString(str2); + } else { + hash = hashString(str2, hash); + } + } + return hash; + }; + var warningsEnabled = true; + var warnSupported = console.warn != null; + var traceSupported = console.trace != null; + var MAX_INT$1 = Number.MAX_SAFE_INTEGER || 9007199254740991; + var trueify = function trueify2() { + return true; + }; + var falsify = function falsify2() { + return false; + }; + var zeroify = function zeroify2() { + return 0; + }; + var noop$12 = function noop3() { + }; + var error = function error2(msg) { + throw new Error(msg); + }; + var warnings = function warnings2(enabled) { + if (enabled !== void 0) { + warningsEnabled = !!enabled; + } else { + return warningsEnabled; + } + }; + var warn = function warn2(msg) { + if (!warnings()) { + return; + } + if (warnSupported) { + console.warn(msg); + } else { + console.log(msg); + if (traceSupported) { + console.trace(); + } + } + }; + var clone2 = function clone3(obj) { + return extend2({}, obj); + }; + var copy2 = function copy3(obj) { + if (obj == null) { + return obj; + } + if (array2(obj)) { + return obj.slice(); + } else if (plainObject(obj)) { + return clone2(obj); + } else { + return obj; + } + }; + var copyArray$1 = function copyArray3(arr) { + return arr.slice(); + }; + var uuid = function uuid2(a, b) { + for ( + // loop :) + b = a = ""; + // b - result , a - numeric letiable + a++ < 36; + // + b += a * 51 & 52 ? ( + // return a random number or 4 + (a ^ 15 ? ( + // generate a random number from 0 to 15 + 8 ^ Math.random() * (a ^ 20 ? 16 : 4) + ) : 4).toString(16) + ) : "-" + ) { + } + return b; + }; + var _staticEmptyObject = {}; + var staticEmptyObject = function staticEmptyObject2() { + return _staticEmptyObject; + }; + var defaults$g = function defaults3(_defaults) { + var keys2 = Object.keys(_defaults); + return function(opts) { + var filledOpts = {}; + for (var i3 = 0; i3 < keys2.length; i3++) { + var key = keys2[i3]; + var optVal = opts == null ? void 0 : opts[key]; + filledOpts[key] = optVal === void 0 ? _defaults[key] : optVal; + } + return filledOpts; + }; + }; + var removeFromArray = function removeFromArray2(arr, ele, oneCopy) { + for (var i3 = arr.length - 1; i3 >= 0; i3--) { + if (arr[i3] === ele) { + arr.splice(i3, 1); + if (oneCopy) { + break; + } + } + } + }; + var clearArray = function clearArray2(arr) { + arr.splice(0, arr.length); + }; + var push2 = function push3(arr, otherArr) { + for (var i3 = 0; i3 < otherArr.length; i3++) { + var el = otherArr[i3]; + arr.push(el); + } + }; + var getPrefixedProperty = function getPrefixedProperty2(obj, propName, prefix) { + if (prefix) { + propName = prependCamel(prefix, propName); + } + return obj[propName]; + }; + var setPrefixedProperty = function setPrefixedProperty2(obj, propName, prefix, value2) { + if (prefix) { + propName = prependCamel(prefix, propName); + } + obj[propName] = value2; + }; + var ObjectMap = /* @__PURE__ */ function() { + function ObjectMap2() { + _classCallCheck(this, ObjectMap2); + this._obj = {}; + } + _createClass(ObjectMap2, [{ + key: "set", + value: function set3(key, val) { + this._obj[key] = val; + return this; + } + }, { + key: "delete", + value: function _delete(key) { + this._obj[key] = void 0; + return this; + } + }, { + key: "clear", + value: function clear2() { + this._obj = {}; + } + }, { + key: "has", + value: function has2(key) { + return this._obj[key] !== void 0; + } + }, { + key: "get", + value: function get3(key) { + return this._obj[key]; + } + }]); + return ObjectMap2; + }(); + var Map$22 = typeof Map !== "undefined" ? Map : ObjectMap; + var undef = "undefined"; + var ObjectSet = /* @__PURE__ */ function() { + function ObjectSet2(arrayOrObjectSet) { + _classCallCheck(this, ObjectSet2); + this._obj = /* @__PURE__ */ Object.create(null); + this.size = 0; + if (arrayOrObjectSet != null) { + var arr; + if (arrayOrObjectSet.instanceString != null && arrayOrObjectSet.instanceString() === this.instanceString()) { + arr = arrayOrObjectSet.toArray(); + } else { + arr = arrayOrObjectSet; + } + for (var i3 = 0; i3 < arr.length; i3++) { + this.add(arr[i3]); + } + } + } + _createClass(ObjectSet2, [{ + key: "instanceString", + value: function instanceString() { + return "set"; + } + }, { + key: "add", + value: function add(val) { + var o = this._obj; + if (o[val] !== 1) { + o[val] = 1; + this.size++; + } + } + }, { + key: "delete", + value: function _delete(val) { + var o = this._obj; + if (o[val] === 1) { + o[val] = 0; + this.size--; + } + } + }, { + key: "clear", + value: function clear2() { + this._obj = /* @__PURE__ */ Object.create(null); + } + }, { + key: "has", + value: function has2(val) { + return this._obj[val] === 1; + } + }, { + key: "toArray", + value: function toArray2() { + var _this = this; + return Object.keys(this._obj).filter(function(key) { + return _this.has(key); + }); + } + }, { + key: "forEach", + value: function forEach2(callback, thisArg) { + return this.toArray().forEach(callback, thisArg); + } + }]); + return ObjectSet2; + }(); + var Set$12 = (typeof Set === "undefined" ? "undefined" : _typeof(Set)) !== undef ? Set : ObjectSet; + var Element = function Element2(cy, params) { + var restore = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : true; + if (cy === void 0 || params === void 0 || !core2(cy)) { + error("An element must have a core reference and parameters set"); + return; + } + var group = params.group; + if (group == null) { + if (params.data && params.data.source != null && params.data.target != null) { + group = "edges"; + } else { + group = "nodes"; + } + } + if (group !== "nodes" && group !== "edges") { + error("An element must be of type `nodes` or `edges`; you specified `" + group + "`"); + return; + } + this.length = 1; + this[0] = this; + var _p = this._private = { + cy, + single: true, + // indicates this is an element + data: params.data || {}, + // data object + position: params.position || { + x: 0, + y: 0 + }, + // (x, y) position pair + autoWidth: void 0, + // width and height of nodes calculated by the renderer when set to special 'auto' value + autoHeight: void 0, + autoPadding: void 0, + compoundBoundsClean: false, + // whether the compound dimensions need to be recalculated the next time dimensions are read + listeners: [], + // array of bound listeners + group, + // string; 'nodes' or 'edges' + style: {}, + // properties as set by the style + rstyle: {}, + // properties for style sent from the renderer to the core + styleCxts: [], + // applied style contexts from the styler + styleKeys: {}, + // per-group keys of style property values + removed: true, + // whether it's inside the vis; true if removed (set true here since we call restore) + selected: params.selected ? true : false, + // whether it's selected + selectable: params.selectable === void 0 ? true : params.selectable ? true : false, + // whether it's selectable + locked: params.locked ? true : false, + // whether the element is locked (cannot be moved) + grabbed: false, + // whether the element is grabbed by the mouse; renderer sets this privately + grabbable: params.grabbable === void 0 ? true : params.grabbable ? true : false, + // whether the element can be grabbed + pannable: params.pannable === void 0 ? group === "edges" ? true : false : params.pannable ? true : false, + // whether the element has passthrough panning enabled + active: false, + // whether the element is active from user interaction + classes: new Set$12(), + // map ( className => true ) + animation: { + // object for currently-running animations + current: [], + queue: [] + }, + rscratch: {}, + // object in which the renderer can store information + scratch: params.scratch || {}, + // scratch objects + edges: [], + // array of connected edges + children: [], + // array of children + parent: params.parent && params.parent.isNode() ? params.parent : null, + // parent ref + traversalCache: {}, + // cache of output of traversal functions + backgrounding: false, + // whether background images are loading + bbCache: null, + // cache of the current bounding box + bbCacheShift: { + x: 0, + y: 0 + }, + // shift applied to cached bb to be applied on next get + bodyBounds: null, + // bounds cache of element body, w/o overlay + overlayBounds: null, + // bounds cache of element body, including overlay + labelBounds: { + // bounds cache of labels + all: null, + source: null, + target: null, + main: null + }, + arrowBounds: { + // bounds cache of edge arrows + source: null, + target: null, + "mid-source": null, + "mid-target": null + } + }; + if (_p.position.x == null) { + _p.position.x = 0; + } + if (_p.position.y == null) { + _p.position.y = 0; + } + if (params.renderedPosition) { + var rpos = params.renderedPosition; + var pan = cy.pan(); + var zoom = cy.zoom(); + _p.position = { + x: (rpos.x - pan.x) / zoom, + y: (rpos.y - pan.y) / zoom + }; + } + var classes2 = []; + if (array2(params.classes)) { + classes2 = params.classes; + } else if (string2(params.classes)) { + classes2 = params.classes.split(/\s+/); + } + for (var i3 = 0, l = classes2.length; i3 < l; i3++) { + var cls = classes2[i3]; + if (!cls || cls === "") { + continue; + } + _p.classes.add(cls); + } + this.createEmitter(); + var bypass = params.style || params.css; + if (bypass) { + warn("Setting a `style` bypass at element creation should be done only when absolutely necessary. Try to use the stylesheet instead."); + this.style(bypass); + } + if (restore === void 0 || restore) { + this.restore(); + } + }; + var defineSearch = function defineSearch2(params) { + params = { + bfs: params.bfs || !params.dfs, + dfs: params.dfs || !params.bfs + }; + return function searchFn(roots, fn2, directed) { + var options2; + if (plainObject(roots) && !elementOrCollection(roots)) { + options2 = roots; + roots = options2.roots || options2.root; + fn2 = options2.visit; + directed = options2.directed; + } + directed = arguments.length === 2 && !fn$6(fn2) ? fn2 : directed; + fn2 = fn$6(fn2) ? fn2 : function() { + }; + var cy = this._private.cy; + var v = roots = string2(roots) ? this.filter(roots) : roots; + var Q = []; + var connectedNodes = []; + var connectedBy = {}; + var id2depth = {}; + var V = {}; + var j = 0; + var found; + var _this$byGroup = this.byGroup(), nodes2 = _this$byGroup.nodes, edges2 = _this$byGroup.edges; + for (var i3 = 0; i3 < v.length; i3++) { + var vi = v[i3]; + var viId = vi.id(); + if (vi.isNode()) { + Q.unshift(vi); + if (params.bfs) { + V[viId] = true; + connectedNodes.push(vi); + } + id2depth[viId] = 0; + } + } + var _loop = function _loop2() { + var v2 = params.bfs ? Q.shift() : Q.pop(); + var vId = v2.id(); + if (params.dfs) { + if (V[vId]) { + return "continue"; + } + V[vId] = true; + connectedNodes.push(v2); + } + var depth = id2depth[vId]; + var prevEdge = connectedBy[vId]; + var src = prevEdge != null ? prevEdge.source() : null; + var tgt = prevEdge != null ? prevEdge.target() : null; + var prevNode = prevEdge == null ? void 0 : v2.same(src) ? tgt[0] : src[0]; + var ret = void 0; + ret = fn2(v2, prevEdge, prevNode, j++, depth); + if (ret === true) { + found = v2; + return "break"; + } + if (ret === false) { + return "break"; + } + var vwEdges = v2.connectedEdges().filter(function(e3) { + return (!directed || e3.source().same(v2)) && edges2.has(e3); + }); + for (var _i22 = 0; _i22 < vwEdges.length; _i22++) { + var e = vwEdges[_i22]; + var w2 = e.connectedNodes().filter(function(n) { + return !n.same(v2) && nodes2.has(n); + }); + var wId = w2.id(); + if (w2.length !== 0 && !V[wId]) { + w2 = w2[0]; + Q.push(w2); + if (params.bfs) { + V[wId] = true; + connectedNodes.push(w2); + } + connectedBy[wId] = e; + id2depth[wId] = id2depth[vId] + 1; + } + } + }; + while (Q.length !== 0) { + var _ret = _loop(); + if (_ret === "continue") + continue; + if (_ret === "break") + break; + } + var connectedEles = cy.collection(); + for (var _i6 = 0; _i6 < connectedNodes.length; _i6++) { + var node2 = connectedNodes[_i6]; + var edge = connectedBy[node2.id()]; + if (edge != null) { + connectedEles.push(edge); + } + connectedEles.push(node2); + } + return { + path: cy.collection(connectedEles), + found: cy.collection(found) + }; + }; + }; + var elesfn$v = { + breadthFirstSearch: defineSearch({ + bfs: true + }), + depthFirstSearch: defineSearch({ + dfs: true + }) + }; + elesfn$v.bfs = elesfn$v.breadthFirstSearch; + elesfn$v.dfs = elesfn$v.depthFirstSearch; + var heap$1 = createCommonjsModule(function(module3, exports3) { + (function() { + var Heap, defaultCmp, floor, heapify, heappop, heappush, heappushpop, heapreplace, insort, min3, nlargest, nsmallest, updateItem, _siftdown, _siftup; + floor = Math.floor, min3 = Math.min; + defaultCmp = function(x2, y2) { + if (x2 < y2) { + return -1; + } + if (x2 > y2) { + return 1; + } + return 0; + }; + insort = function(a, x2, lo, hi, cmp) { + var mid; + if (lo == null) { + lo = 0; + } + if (cmp == null) { + cmp = defaultCmp; + } + if (lo < 0) { + throw new Error("lo must be non-negative"); + } + if (hi == null) { + hi = a.length; + } + while (lo < hi) { + mid = floor((lo + hi) / 2); + if (cmp(x2, a[mid]) < 0) { + hi = mid; + } else { + lo = mid + 1; + } + } + return [].splice.apply(a, [lo, lo - lo].concat(x2)), x2; + }; + heappush = function(array3, item, cmp) { + if (cmp == null) { + cmp = defaultCmp; + } + array3.push(item); + return _siftdown(array3, 0, array3.length - 1, cmp); + }; + heappop = function(array3, cmp) { + var lastelt, returnitem; + if (cmp == null) { + cmp = defaultCmp; + } + lastelt = array3.pop(); + if (array3.length) { + returnitem = array3[0]; + array3[0] = lastelt; + _siftup(array3, 0, cmp); + } else { + returnitem = lastelt; + } + return returnitem; + }; + heapreplace = function(array3, item, cmp) { + var returnitem; + if (cmp == null) { + cmp = defaultCmp; + } + returnitem = array3[0]; + array3[0] = item; + _siftup(array3, 0, cmp); + return returnitem; + }; + heappushpop = function(array3, item, cmp) { + var _ref; + if (cmp == null) { + cmp = defaultCmp; + } + if (array3.length && cmp(array3[0], item) < 0) { + _ref = [array3[0], item], item = _ref[0], array3[0] = _ref[1]; + _siftup(array3, 0, cmp); + } + return item; + }; + heapify = function(array3, cmp) { + var i3, _i6, _len, _ref1, _results, _results1; + if (cmp == null) { + cmp = defaultCmp; + } + _ref1 = (function() { + _results1 = []; + for (var _j = 0, _ref = floor(array3.length / 2); 0 <= _ref ? _j < _ref : _j > _ref; 0 <= _ref ? _j++ : _j--) { + _results1.push(_j); + } + return _results1; + }).apply(this).reverse(); + _results = []; + for (_i6 = 0, _len = _ref1.length; _i6 < _len; _i6++) { + i3 = _ref1[_i6]; + _results.push(_siftup(array3, i3, cmp)); + } + return _results; + }; + updateItem = function(array3, item, cmp) { + var pos; + if (cmp == null) { + cmp = defaultCmp; + } + pos = array3.indexOf(item); + if (pos === -1) { + return; + } + _siftdown(array3, 0, pos, cmp); + return _siftup(array3, pos, cmp); + }; + nlargest = function(array3, n, cmp) { + var elem, result, _i6, _len, _ref; + if (cmp == null) { + cmp = defaultCmp; + } + result = array3.slice(0, n); + if (!result.length) { + return result; + } + heapify(result, cmp); + _ref = array3.slice(n); + for (_i6 = 0, _len = _ref.length; _i6 < _len; _i6++) { + elem = _ref[_i6]; + heappushpop(result, elem, cmp); + } + return result.sort(cmp).reverse(); + }; + nsmallest = function(array3, n, cmp) { + var elem, los, result, _i6, _j, _len, _ref, _ref1, _results; + if (cmp == null) { + cmp = defaultCmp; + } + if (n * 10 <= array3.length) { + result = array3.slice(0, n).sort(cmp); + if (!result.length) { + return result; + } + los = result[result.length - 1]; + _ref = array3.slice(n); + for (_i6 = 0, _len = _ref.length; _i6 < _len; _i6++) { + elem = _ref[_i6]; + if (cmp(elem, los) < 0) { + insort(result, elem, 0, null, cmp); + result.pop(); + los = result[result.length - 1]; + } + } + return result; + } + heapify(array3, cmp); + _results = []; + for (_j = 0, _ref1 = min3(n, array3.length); 0 <= _ref1 ? _j < _ref1 : _j > _ref1; 0 <= _ref1 ? ++_j : --_j) { + _results.push(heappop(array3, cmp)); + } + return _results; + }; + _siftdown = function(array3, startpos, pos, cmp) { + var newitem, parent, parentpos; + if (cmp == null) { + cmp = defaultCmp; + } + newitem = array3[pos]; + while (pos > startpos) { + parentpos = pos - 1 >> 1; + parent = array3[parentpos]; + if (cmp(newitem, parent) < 0) { + array3[pos] = parent; + pos = parentpos; + continue; + } + break; + } + return array3[pos] = newitem; + }; + _siftup = function(array3, pos, cmp) { + var childpos, endpos, newitem, rightpos, startpos; + if (cmp == null) { + cmp = defaultCmp; + } + endpos = array3.length; + startpos = pos; + newitem = array3[pos]; + childpos = 2 * pos + 1; + while (childpos < endpos) { + rightpos = childpos + 1; + if (rightpos < endpos && !(cmp(array3[childpos], array3[rightpos]) < 0)) { + childpos = rightpos; + } + array3[pos] = array3[childpos]; + pos = childpos; + childpos = 2 * pos + 1; + } + array3[pos] = newitem; + return _siftdown(array3, startpos, pos, cmp); + }; + Heap = function() { + Heap2.push = heappush; + Heap2.pop = heappop; + Heap2.replace = heapreplace; + Heap2.pushpop = heappushpop; + Heap2.heapify = heapify; + Heap2.updateItem = updateItem; + Heap2.nlargest = nlargest; + Heap2.nsmallest = nsmallest; + function Heap2(cmp) { + this.cmp = cmp != null ? cmp : defaultCmp; + this.nodes = []; + } + Heap2.prototype.push = function(x2) { + return heappush(this.nodes, x2, this.cmp); + }; + Heap2.prototype.pop = function() { + return heappop(this.nodes, this.cmp); + }; + Heap2.prototype.peek = function() { + return this.nodes[0]; + }; + Heap2.prototype.contains = function(x2) { + return this.nodes.indexOf(x2) !== -1; + }; + Heap2.prototype.replace = function(x2) { + return heapreplace(this.nodes, x2, this.cmp); + }; + Heap2.prototype.pushpop = function(x2) { + return heappushpop(this.nodes, x2, this.cmp); + }; + Heap2.prototype.heapify = function() { + return heapify(this.nodes, this.cmp); + }; + Heap2.prototype.updateItem = function(x2) { + return updateItem(this.nodes, x2, this.cmp); + }; + Heap2.prototype.clear = function() { + return this.nodes = []; + }; + Heap2.prototype.empty = function() { + return this.nodes.length === 0; + }; + Heap2.prototype.size = function() { + return this.nodes.length; + }; + Heap2.prototype.clone = function() { + var heap2; + heap2 = new Heap2(); + heap2.nodes = this.nodes.slice(0); + return heap2; + }; + Heap2.prototype.toArray = function() { + return this.nodes.slice(0); + }; + Heap2.prototype.insert = Heap2.prototype.push; + Heap2.prototype.top = Heap2.prototype.peek; + Heap2.prototype.front = Heap2.prototype.peek; + Heap2.prototype.has = Heap2.prototype.contains; + Heap2.prototype.copy = Heap2.prototype.clone; + return Heap2; + }(); + (function(root3, factory) { + { + return module3.exports = factory(); + } + })(this, function() { + return Heap; + }); + }).call(commonjsGlobal$1); + }); + var heap = heap$1; + var dijkstraDefaults = defaults$g({ + root: null, + weight: function weight(edge) { + return 1; + }, + directed: false + }); + var elesfn$u = { + dijkstra: function dijkstra(options2) { + if (!plainObject(options2)) { + var args = arguments; + options2 = { + root: args[0], + weight: args[1], + directed: args[2] + }; + } + var _dijkstraDefaults = dijkstraDefaults(options2), root3 = _dijkstraDefaults.root, weight = _dijkstraDefaults.weight, directed = _dijkstraDefaults.directed; + var eles = this; + var weightFn = weight; + var source = string2(root3) ? this.filter(root3)[0] : root3[0]; + var dist3 = {}; + var prev2 = {}; + var knownDist = {}; + var _this$byGroup = this.byGroup(), nodes2 = _this$byGroup.nodes, edges2 = _this$byGroup.edges; + edges2.unmergeBy(function(ele) { + return ele.isLoop(); + }); + var getDist2 = function getDist3(node3) { + return dist3[node3.id()]; + }; + var setDist = function setDist2(node3, d) { + dist3[node3.id()] = d; + Q.updateItem(node3); + }; + var Q = new heap(function(a, b) { + return getDist2(a) - getDist2(b); + }); + for (var i3 = 0; i3 < nodes2.length; i3++) { + var node2 = nodes2[i3]; + dist3[node2.id()] = node2.same(source) ? 0 : Infinity; + Q.push(node2); + } + var distBetween = function distBetween2(u2, v2) { + var uvs = (directed ? u2.edgesTo(v2) : u2.edgesWith(v2)).intersect(edges2); + var smallestDistance = Infinity; + var smallestEdge; + for (var _i6 = 0; _i6 < uvs.length; _i6++) { + var edge = uvs[_i6]; + var _weight = weightFn(edge); + if (_weight < smallestDistance || !smallestEdge) { + smallestDistance = _weight; + smallestEdge = edge; + } + } + return { + edge: smallestEdge, + dist: smallestDistance + }; + }; + while (Q.size() > 0) { + var u = Q.pop(); + var smalletsDist = getDist2(u); + var uid = u.id(); + knownDist[uid] = smalletsDist; + if (smalletsDist === Infinity) { + continue; + } + var neighbors = u.neighborhood().intersect(nodes2); + for (var _i22 = 0; _i22 < neighbors.length; _i22++) { + var v = neighbors[_i22]; + var vid = v.id(); + var vDist = distBetween(u, v); + var alt = smalletsDist + vDist.dist; + if (alt < getDist2(v)) { + setDist(v, alt); + prev2[vid] = { + node: u, + edge: vDist.edge + }; + } + } + } + return { + distanceTo: function distanceTo(node3) { + var target = string2(node3) ? nodes2.filter(node3)[0] : node3[0]; + return knownDist[target.id()]; + }, + pathTo: function pathTo(node3) { + var target = string2(node3) ? nodes2.filter(node3)[0] : node3[0]; + var S2 = []; + var u2 = target; + var uid2 = u2.id(); + if (target.length > 0) { + S2.unshift(target); + while (prev2[uid2]) { + var p2 = prev2[uid2]; + S2.unshift(p2.edge); + S2.unshift(p2.node); + u2 = p2.node; + uid2 = u2.id(); + } + } + return eles.spawn(S2); + } + }; + } + }; + var elesfn$t = { + // kruskal's algorithm (finds min spanning tree, assuming undirected graph) + // implemented from pseudocode from wikipedia + kruskal: function kruskal(weightFn) { + weightFn = weightFn || function(edge2) { + return 1; + }; + var _this$byGroup = this.byGroup(), nodes2 = _this$byGroup.nodes, edges2 = _this$byGroup.edges; + var numNodes = nodes2.length; + var forest = new Array(numNodes); + var A = nodes2; + var findSetIndex = function findSetIndex2(ele) { + for (var i4 = 0; i4 < forest.length; i4++) { + var eles = forest[i4]; + if (eles.has(ele)) { + return i4; + } + } + }; + for (var i3 = 0; i3 < numNodes; i3++) { + forest[i3] = this.spawn(nodes2[i3]); + } + var S2 = edges2.sort(function(a, b) { + return weightFn(a) - weightFn(b); + }); + for (var _i6 = 0; _i6 < S2.length; _i6++) { + var edge = S2[_i6]; + var u = edge.source()[0]; + var v = edge.target()[0]; + var setUIndex = findSetIndex(u); + var setVIndex = findSetIndex(v); + var setU = forest[setUIndex]; + var setV = forest[setVIndex]; + if (setUIndex !== setVIndex) { + A.merge(edge); + setU.merge(setV); + forest.splice(setVIndex, 1); + } + } + return A; + } + }; + var aStarDefaults = defaults$g({ + root: null, + goal: null, + weight: function weight(edge) { + return 1; + }, + heuristic: function heuristic(edge) { + return 0; + }, + directed: false + }); + var elesfn$s = { + // Implemented from pseudocode from wikipedia + aStar: function aStar(options2) { + var cy = this.cy(); + var _aStarDefaults = aStarDefaults(options2), root3 = _aStarDefaults.root, goal = _aStarDefaults.goal, heuristic = _aStarDefaults.heuristic, directed = _aStarDefaults.directed, weight = _aStarDefaults.weight; + root3 = cy.collection(root3)[0]; + goal = cy.collection(goal)[0]; + var sid = root3.id(); + var tid = goal.id(); + var gScore = {}; + var fScore = {}; + var closedSetIds = {}; + var openSet = new heap(function(a, b) { + return fScore[a.id()] - fScore[b.id()]; + }); + var openSetIds = new Set$12(); + var cameFrom = {}; + var cameFromEdge = {}; + var addToOpenSet = function addToOpenSet2(ele, id2) { + openSet.push(ele); + openSetIds.add(id2); + }; + var cMin, cMinId; + var popFromOpenSet = function popFromOpenSet2() { + cMin = openSet.pop(); + cMinId = cMin.id(); + openSetIds["delete"](cMinId); + }; + var isInOpenSet = function isInOpenSet2(id2) { + return openSetIds.has(id2); + }; + addToOpenSet(root3, sid); + gScore[sid] = 0; + fScore[sid] = heuristic(root3); + var steps = 0; + while (openSet.size() > 0) { + popFromOpenSet(); + steps++; + if (cMinId === tid) { + var path2 = []; + var pathNode = goal; + var pathNodeId = tid; + var pathEdge = cameFromEdge[pathNodeId]; + for (; ; ) { + path2.unshift(pathNode); + if (pathEdge != null) { + path2.unshift(pathEdge); + } + pathNode = cameFrom[pathNodeId]; + if (pathNode == null) { + break; + } + pathNodeId = pathNode.id(); + pathEdge = cameFromEdge[pathNodeId]; + } + return { + found: true, + distance: gScore[cMinId], + path: this.spawn(path2), + steps + }; + } + closedSetIds[cMinId] = true; + var vwEdges = cMin._private.edges; + for (var i3 = 0; i3 < vwEdges.length; i3++) { + var e = vwEdges[i3]; + if (!this.hasElementWithId(e.id())) { + continue; + } + if (directed && e.data("source") !== cMinId) { + continue; + } + var wSrc = e.source(); + var wTgt = e.target(); + var w2 = wSrc.id() !== cMinId ? wSrc : wTgt; + var wid = w2.id(); + if (!this.hasElementWithId(wid)) { + continue; + } + if (closedSetIds[wid]) { + continue; + } + var tempScore = gScore[cMinId] + weight(e); + if (!isInOpenSet(wid)) { + gScore[wid] = tempScore; + fScore[wid] = tempScore + heuristic(w2); + addToOpenSet(w2, wid); + cameFrom[wid] = cMin; + cameFromEdge[wid] = e; + continue; + } + if (tempScore < gScore[wid]) { + gScore[wid] = tempScore; + fScore[wid] = tempScore + heuristic(w2); + cameFrom[wid] = cMin; + cameFromEdge[wid] = e; + } + } + } + return { + found: false, + distance: void 0, + path: void 0, + steps + }; + } + }; + var floydWarshallDefaults = defaults$g({ + weight: function weight(edge) { + return 1; + }, + directed: false + }); + var elesfn$r = { + // Implemented from pseudocode from wikipedia + floydWarshall: function floydWarshall(options2) { + var cy = this.cy(); + var _floydWarshallDefault = floydWarshallDefaults(options2), weight = _floydWarshallDefault.weight, directed = _floydWarshallDefault.directed; + var weightFn = weight; + var _this$byGroup = this.byGroup(), nodes2 = _this$byGroup.nodes, edges2 = _this$byGroup.edges; + var N = nodes2.length; + var Nsq = N * N; + var indexOf = function indexOf2(node2) { + return nodes2.indexOf(node2); + }; + var atIndex = function atIndex2(i4) { + return nodes2[i4]; + }; + var dist3 = new Array(Nsq); + for (var n = 0; n < Nsq; n++) { + var j = n % N; + var i3 = (n - j) / N; + if (i3 === j) { + dist3[n] = 0; + } else { + dist3[n] = Infinity; + } + } + var next2 = new Array(Nsq); + var edgeNext = new Array(Nsq); + for (var _i6 = 0; _i6 < edges2.length; _i6++) { + var edge = edges2[_i6]; + var src = edge.source()[0]; + var tgt = edge.target()[0]; + if (src === tgt) { + continue; + } + var s = indexOf(src); + var t = indexOf(tgt); + var st = s * N + t; + var _weight = weightFn(edge); + if (dist3[st] > _weight) { + dist3[st] = _weight; + next2[st] = t; + edgeNext[st] = edge; + } + if (!directed) { + var ts = t * N + s; + if (!directed && dist3[ts] > _weight) { + dist3[ts] = _weight; + next2[ts] = s; + edgeNext[ts] = edge; + } + } + } + for (var k = 0; k < N; k++) { + for (var _i22 = 0; _i22 < N; _i22++) { + var ik = _i22 * N + k; + for (var _j = 0; _j < N; _j++) { + var ij = _i22 * N + _j; + var kj = k * N + _j; + if (dist3[ik] + dist3[kj] < dist3[ij]) { + dist3[ij] = dist3[ik] + dist3[kj]; + next2[ij] = next2[ik]; + } + } + } + } + var getArgEle = function getArgEle2(ele) { + return (string2(ele) ? cy.filter(ele) : ele)[0]; + }; + var indexOfArgEle = function indexOfArgEle2(ele) { + return indexOf(getArgEle(ele)); + }; + var res = { + distance: function distance2(from2, to) { + var i4 = indexOfArgEle(from2); + var j2 = indexOfArgEle(to); + return dist3[i4 * N + j2]; + }, + path: function path2(from2, to) { + var i4 = indexOfArgEle(from2); + var j2 = indexOfArgEle(to); + var fromNode = atIndex(i4); + if (i4 === j2) { + return fromNode.collection(); + } + if (next2[i4 * N + j2] == null) { + return cy.collection(); + } + var path3 = cy.collection(); + var prev2 = i4; + var edge2; + path3.merge(fromNode); + while (i4 !== j2) { + prev2 = i4; + i4 = next2[i4 * N + j2]; + edge2 = edgeNext[prev2 * N + i4]; + path3.merge(edge2); + path3.merge(atIndex(i4)); + } + return path3; + } + }; + return res; + } + // floydWarshall + }; + var bellmanFordDefaults = defaults$g({ + weight: function weight(edge) { + return 1; + }, + directed: false, + root: null + }); + var elesfn$q = { + // Implemented from pseudocode from wikipedia + bellmanFord: function bellmanFord(options2) { + var _this = this; + var _bellmanFordDefaults = bellmanFordDefaults(options2), weight = _bellmanFordDefaults.weight, directed = _bellmanFordDefaults.directed, root3 = _bellmanFordDefaults.root; + var weightFn = weight; + var eles = this; + var cy = this.cy(); + var _this$byGroup = this.byGroup(), edges2 = _this$byGroup.edges, nodes2 = _this$byGroup.nodes; + var numNodes = nodes2.length; + var infoMap = new Map$22(); + var hasNegativeWeightCycle = false; + var negativeWeightCycles = []; + root3 = cy.collection(root3)[0]; + edges2.unmergeBy(function(edge2) { + return edge2.isLoop(); + }); + var numEdges = edges2.length; + var getInfo3 = function getInfo4(node3) { + var obj = infoMap.get(node3.id()); + if (!obj) { + obj = {}; + infoMap.set(node3.id(), obj); + } + return obj; + }; + var getNodeFromTo = function getNodeFromTo2(to) { + return (string2(to) ? cy.$(to) : to)[0]; + }; + var distanceTo = function distanceTo2(to) { + return getInfo3(getNodeFromTo(to)).dist; + }; + var pathTo = function pathTo2(to) { + var thisStart = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : root3; + var end2 = getNodeFromTo(to); + var path2 = []; + var node3 = end2; + for (; ; ) { + if (node3 == null) { + return _this.spawn(); + } + var _getInfo = getInfo3(node3), edge2 = _getInfo.edge, pred = _getInfo.pred; + path2.unshift(node3[0]); + if (node3.same(thisStart) && path2.length > 0) { + break; + } + if (edge2 != null) { + path2.unshift(edge2); + } + node3 = pred; + } + return eles.spawn(path2); + }; + for (var i3 = 0; i3 < numNodes; i3++) { + var node2 = nodes2[i3]; + var info2 = getInfo3(node2); + if (node2.same(root3)) { + info2.dist = 0; + } else { + info2.dist = Infinity; + } + info2.pred = null; + info2.edge = null; + } + var replacedEdge = false; + var checkForEdgeReplacement = function checkForEdgeReplacement2(node1, node22, edge2, info1, info22, weight2) { + var dist3 = info1.dist + weight2; + if (dist3 < info22.dist && !edge2.same(info1.edge)) { + info22.dist = dist3; + info22.pred = node1; + info22.edge = edge2; + replacedEdge = true; + } + }; + for (var _i6 = 1; _i6 < numNodes; _i6++) { + replacedEdge = false; + for (var e = 0; e < numEdges; e++) { + var edge = edges2[e]; + var src = edge.source(); + var tgt = edge.target(); + var _weight = weightFn(edge); + var srcInfo = getInfo3(src); + var tgtInfo = getInfo3(tgt); + checkForEdgeReplacement(src, tgt, edge, srcInfo, tgtInfo, _weight); + if (!directed) { + checkForEdgeReplacement(tgt, src, edge, tgtInfo, srcInfo, _weight); + } + } + if (!replacedEdge) { + break; + } + } + if (replacedEdge) { + var negativeWeightCycleIds = []; + for (var _e = 0; _e < numEdges; _e++) { + var _edge = edges2[_e]; + var _src = _edge.source(); + var _tgt = _edge.target(); + var _weight2 = weightFn(_edge); + var srcDist = getInfo3(_src).dist; + var tgtDist = getInfo3(_tgt).dist; + if (srcDist + _weight2 < tgtDist || !directed && tgtDist + _weight2 < srcDist) { + if (!hasNegativeWeightCycle) { + warn("Graph contains a negative weight cycle for Bellman-Ford"); + hasNegativeWeightCycle = true; + } + if (options2.findNegativeWeightCycles !== false) { + var negativeNodes = []; + if (srcDist + _weight2 < tgtDist) { + negativeNodes.push(_src); + } + if (!directed && tgtDist + _weight2 < srcDist) { + negativeNodes.push(_tgt); + } + var numNegativeNodes = negativeNodes.length; + for (var n = 0; n < numNegativeNodes; n++) { + var start2 = negativeNodes[n]; + var cycle = [start2]; + cycle.push(getInfo3(start2).edge); + var _node = getInfo3(start2).pred; + while (cycle.indexOf(_node) === -1) { + cycle.push(_node); + cycle.push(getInfo3(_node).edge); + _node = getInfo3(_node).pred; + } + cycle = cycle.slice(cycle.indexOf(_node)); + var smallestId = cycle[0].id(); + var smallestIndex = 0; + for (var c2 = 2; c2 < cycle.length; c2 += 2) { + if (cycle[c2].id() < smallestId) { + smallestId = cycle[c2].id(); + smallestIndex = c2; + } + } + cycle = cycle.slice(smallestIndex).concat(cycle.slice(0, smallestIndex)); + cycle.push(cycle[0]); + var cycleId = cycle.map(function(el) { + return el.id(); + }).join(","); + if (negativeWeightCycleIds.indexOf(cycleId) === -1) { + negativeWeightCycles.push(eles.spawn(cycle)); + negativeWeightCycleIds.push(cycleId); + } + } + } else { + break; + } + } + } + } + return { + distanceTo, + pathTo, + hasNegativeWeightCycle, + negativeWeightCycles + }; + } + // bellmanFord + }; + var sqrt2 = Math.sqrt(2); + var collapse = function collapse2(edgeIndex, nodeMap, remainingEdges) { + if (remainingEdges.length === 0) { + error("Karger-Stein must be run on a connected (sub)graph"); + } + var edgeInfo = remainingEdges[edgeIndex]; + var sourceIn = edgeInfo[1]; + var targetIn = edgeInfo[2]; + var partition1 = nodeMap[sourceIn]; + var partition2 = nodeMap[targetIn]; + var newEdges = remainingEdges; + for (var i3 = newEdges.length - 1; i3 >= 0; i3--) { + var edge = newEdges[i3]; + var src = edge[1]; + var tgt = edge[2]; + if (nodeMap[src] === partition1 && nodeMap[tgt] === partition2 || nodeMap[src] === partition2 && nodeMap[tgt] === partition1) { + newEdges.splice(i3, 1); + } + } + for (var _i6 = 0; _i6 < newEdges.length; _i6++) { + var _edge = newEdges[_i6]; + if (_edge[1] === partition2) { + newEdges[_i6] = _edge.slice(); + newEdges[_i6][1] = partition1; + } else if (_edge[2] === partition2) { + newEdges[_i6] = _edge.slice(); + newEdges[_i6][2] = partition1; + } + } + for (var _i22 = 0; _i22 < nodeMap.length; _i22++) { + if (nodeMap[_i22] === partition2) { + nodeMap[_i22] = partition1; + } + } + return newEdges; + }; + var contractUntil = function contractUntil2(metaNodeMap, remainingEdges, size2, sizeLimit) { + while (size2 > sizeLimit) { + var edgeIndex = Math.floor(Math.random() * remainingEdges.length); + remainingEdges = collapse(edgeIndex, metaNodeMap, remainingEdges); + size2--; + } + return remainingEdges; + }; + var elesfn$p = { + // Computes the minimum cut of an undirected graph + // Returns the correct answer with high probability + kargerStein: function kargerStein() { + var _this = this; + var _this$byGroup = this.byGroup(), nodes2 = _this$byGroup.nodes, edges2 = _this$byGroup.edges; + edges2.unmergeBy(function(edge) { + return edge.isLoop(); + }); + var numNodes = nodes2.length; + var numEdges = edges2.length; + var numIter = Math.ceil(Math.pow(Math.log(numNodes) / Math.LN2, 2)); + var stopSize = Math.floor(numNodes / sqrt2); + if (numNodes < 2) { + error("At least 2 nodes are required for Karger-Stein algorithm"); + return void 0; + } + var edgeIndexes = []; + for (var i3 = 0; i3 < numEdges; i3++) { + var e = edges2[i3]; + edgeIndexes.push([i3, nodes2.indexOf(e.source()), nodes2.indexOf(e.target())]); + } + var minCutSize = Infinity; + var minCutEdgeIndexes = []; + var minCutNodeMap = new Array(numNodes); + var metaNodeMap = new Array(numNodes); + var metaNodeMap2 = new Array(numNodes); + var copyNodesMap = function copyNodesMap2(from2, to) { + for (var _i32 = 0; _i32 < numNodes; _i32++) { + to[_i32] = from2[_i32]; + } + }; + for (var iter = 0; iter <= numIter; iter++) { + for (var _i42 = 0; _i42 < numNodes; _i42++) { + metaNodeMap[_i42] = _i42; + } + var edgesState = contractUntil(metaNodeMap, edgeIndexes.slice(), numNodes, stopSize); + var edgesState2 = edgesState.slice(); + copyNodesMap(metaNodeMap, metaNodeMap2); + var res1 = contractUntil(metaNodeMap, edgesState, stopSize, 2); + var res2 = contractUntil(metaNodeMap2, edgesState2, stopSize, 2); + if (res1.length <= res2.length && res1.length < minCutSize) { + minCutSize = res1.length; + minCutEdgeIndexes = res1; + copyNodesMap(metaNodeMap, minCutNodeMap); + } else if (res2.length <= res1.length && res2.length < minCutSize) { + minCutSize = res2.length; + minCutEdgeIndexes = res2; + copyNodesMap(metaNodeMap2, minCutNodeMap); + } + } + var cut = this.spawn(minCutEdgeIndexes.map(function(e3) { + return edges2[e3[0]]; + })); + var partition1 = this.spawn(); + var partition2 = this.spawn(); + var witnessNodePartition = minCutNodeMap[0]; + for (var _i52 = 0; _i52 < minCutNodeMap.length; _i52++) { + var partitionId = minCutNodeMap[_i52]; + var node2 = nodes2[_i52]; + if (partitionId === witnessNodePartition) { + partition1.merge(node2); + } else { + partition2.merge(node2); + } + } + var constructComponent = function constructComponent2(subset) { + var component = _this.spawn(); + subset.forEach(function(node3) { + component.merge(node3); + node3.connectedEdges().forEach(function(edge) { + if (_this.contains(edge) && !cut.contains(edge)) { + component.merge(edge); + } + }); + }); + return component; + }; + var components = [constructComponent(partition1), constructComponent(partition2)]; + var ret = { + cut, + components, + // n.b. partitions are included to be compatible with the old api spec + // (could be removed in a future major version) + partition1, + partition2 + }; + return ret; + } + }; + var copyPosition = function copyPosition2(p2) { + return { + x: p2.x, + y: p2.y + }; + }; + var modelToRenderedPosition = function modelToRenderedPosition2(p2, zoom, pan) { + return { + x: p2.x * zoom + pan.x, + y: p2.y * zoom + pan.y + }; + }; + var renderedToModelPosition = function renderedToModelPosition2(p2, zoom, pan) { + return { + x: (p2.x - pan.x) / zoom, + y: (p2.y - pan.y) / zoom + }; + }; + var array2point = function array2point2(arr) { + return { + x: arr[0], + y: arr[1] + }; + }; + var min2 = function min3(arr) { + var begin = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : 0; + var end2 = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : arr.length; + var min4 = Infinity; + for (var i3 = begin; i3 < end2; i3++) { + var val = arr[i3]; + if (isFinite(val)) { + min4 = Math.min(val, min4); + } + } + return min4; + }; + var max2 = function max3(arr) { + var begin = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : 0; + var end2 = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : arr.length; + var max4 = -Infinity; + for (var i3 = begin; i3 < end2; i3++) { + var val = arr[i3]; + if (isFinite(val)) { + max4 = Math.max(val, max4); + } + } + return max4; + }; + var mean = function mean2(arr) { + var begin = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : 0; + var end2 = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : arr.length; + var total = 0; + var n = 0; + for (var i3 = begin; i3 < end2; i3++) { + var val = arr[i3]; + if (isFinite(val)) { + total += val; + n++; + } + } + return total / n; + }; + var median = function median2(arr) { + var begin = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : 0; + var end2 = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : arr.length; + var copy3 = arguments.length > 3 && arguments[3] !== void 0 ? arguments[3] : true; + var sort2 = arguments.length > 4 && arguments[4] !== void 0 ? arguments[4] : true; + var includeHoles = arguments.length > 5 && arguments[5] !== void 0 ? arguments[5] : true; + if (copy3) { + arr = arr.slice(begin, end2); + } else { + if (end2 < arr.length) { + arr.splice(end2, arr.length - end2); + } + if (begin > 0) { + arr.splice(0, begin); + } + } + var off = 0; + for (var i3 = arr.length - 1; i3 >= 0; i3--) { + var v = arr[i3]; + if (includeHoles) { + if (!isFinite(v)) { + arr[i3] = -Infinity; + off++; + } + } else { + arr.splice(i3, 1); + } + } + if (sort2) { + arr.sort(function(a, b) { + return a - b; + }); + } + var len = arr.length; + var mid = Math.floor(len / 2); + if (len % 2 !== 0) { + return arr[mid + 1 + off]; + } else { + return (arr[mid - 1 + off] + arr[mid + off]) / 2; + } + }; + var deg2rad = function deg2rad2(deg) { + return Math.PI * deg / 180; + }; + var getAngleFromDisp = function getAngleFromDisp2(dispX, dispY) { + return Math.atan2(dispY, dispX) - Math.PI / 2; + }; + var log2 = Math.log2 || function(n) { + return Math.log(n) / Math.log(2); + }; + var signum = function signum2(x2) { + if (x2 > 0) { + return 1; + } else if (x2 < 0) { + return -1; + } else { + return 0; + } + }; + var dist2 = function dist3(p1, p2) { + return Math.sqrt(sqdist(p1, p2)); + }; + var sqdist = function sqdist2(p1, p2) { + var dx = p2.x - p1.x; + var dy = p2.y - p1.y; + return dx * dx + dy * dy; + }; + var inPlaceSumNormalize = function inPlaceSumNormalize2(v) { + var length2 = v.length; + var total = 0; + for (var i3 = 0; i3 < length2; i3++) { + total += v[i3]; + } + for (var _i6 = 0; _i6 < length2; _i6++) { + v[_i6] = v[_i6] / total; + } + return v; + }; + var qbezierAt = function qbezierAt2(p0, p1, p2, t) { + return (1 - t) * (1 - t) * p0 + 2 * (1 - t) * t * p1 + t * t * p2; + }; + var qbezierPtAt = function qbezierPtAt2(p0, p1, p2, t) { + return { + x: qbezierAt(p0.x, p1.x, p2.x, t), + y: qbezierAt(p0.y, p1.y, p2.y, t) + }; + }; + var lineAt = function lineAt2(p0, p1, t, d) { + var vec = { + x: p1.x - p0.x, + y: p1.y - p0.y + }; + var vecDist = dist2(p0, p1); + var normVec = { + x: vec.x / vecDist, + y: vec.y / vecDist + }; + t = t == null ? 0 : t; + d = d != null ? d : t * vecDist; + return { + x: p0.x + normVec.x * d, + y: p0.y + normVec.y * d + }; + }; + var bound = function bound2(min3, val, max3) { + return Math.max(min3, Math.min(max3, val)); + }; + var makeBoundingBox = function makeBoundingBox2(bb) { + if (bb == null) { + return { + x1: Infinity, + y1: Infinity, + x2: -Infinity, + y2: -Infinity, + w: 0, + h: 0 + }; + } else if (bb.x1 != null && bb.y1 != null) { + if (bb.x2 != null && bb.y2 != null && bb.x2 >= bb.x1 && bb.y2 >= bb.y1) { + return { + x1: bb.x1, + y1: bb.y1, + x2: bb.x2, + y2: bb.y2, + w: bb.x2 - bb.x1, + h: bb.y2 - bb.y1 + }; + } else if (bb.w != null && bb.h != null && bb.w >= 0 && bb.h >= 0) { + return { + x1: bb.x1, + y1: bb.y1, + x2: bb.x1 + bb.w, + y2: bb.y1 + bb.h, + w: bb.w, + h: bb.h + }; + } + } + }; + var copyBoundingBox = function copyBoundingBox2(bb) { + return { + x1: bb.x1, + x2: bb.x2, + w: bb.w, + y1: bb.y1, + y2: bb.y2, + h: bb.h + }; + }; + var clearBoundingBox = function clearBoundingBox2(bb) { + bb.x1 = Infinity; + bb.y1 = Infinity; + bb.x2 = -Infinity; + bb.y2 = -Infinity; + bb.w = 0; + bb.h = 0; + }; + var shiftBoundingBox = function shiftBoundingBox2(bb, dx, dy) { + return { + x1: bb.x1 + dx, + x2: bb.x2 + dx, + y1: bb.y1 + dy, + y2: bb.y2 + dy, + w: bb.w, + h: bb.h + }; + }; + var updateBoundingBox = function updateBoundingBox2(bb1, bb2) { + bb1.x1 = Math.min(bb1.x1, bb2.x1); + bb1.x2 = Math.max(bb1.x2, bb2.x2); + bb1.w = bb1.x2 - bb1.x1; + bb1.y1 = Math.min(bb1.y1, bb2.y1); + bb1.y2 = Math.max(bb1.y2, bb2.y2); + bb1.h = bb1.y2 - bb1.y1; + }; + var expandBoundingBoxByPoint = function expandBoundingBoxByPoint2(bb, x2, y2) { + bb.x1 = Math.min(bb.x1, x2); + bb.x2 = Math.max(bb.x2, x2); + bb.w = bb.x2 - bb.x1; + bb.y1 = Math.min(bb.y1, y2); + bb.y2 = Math.max(bb.y2, y2); + bb.h = bb.y2 - bb.y1; + }; + var expandBoundingBox = function expandBoundingBox2(bb) { + var padding2 = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : 0; + bb.x1 -= padding2; + bb.x2 += padding2; + bb.y1 -= padding2; + bb.y2 += padding2; + bb.w = bb.x2 - bb.x1; + bb.h = bb.y2 - bb.y1; + return bb; + }; + var expandBoundingBoxSides = function expandBoundingBoxSides2(bb) { + var padding2 = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : [0]; + var top2, right2, bottom2, left2; + if (padding2.length === 1) { + top2 = right2 = bottom2 = left2 = padding2[0]; + } else if (padding2.length === 2) { + top2 = bottom2 = padding2[0]; + left2 = right2 = padding2[1]; + } else if (padding2.length === 4) { + var _padding = _slicedToArray(padding2, 4); + top2 = _padding[0]; + right2 = _padding[1]; + bottom2 = _padding[2]; + left2 = _padding[3]; + } + bb.x1 -= left2; + bb.x2 += right2; + bb.y1 -= top2; + bb.y2 += bottom2; + bb.w = bb.x2 - bb.x1; + bb.h = bb.y2 - bb.y1; + return bb; + }; + var assignBoundingBox = function assignBoundingBox2(bb1, bb2) { + bb1.x1 = bb2.x1; + bb1.y1 = bb2.y1; + bb1.x2 = bb2.x2; + bb1.y2 = bb2.y2; + bb1.w = bb1.x2 - bb1.x1; + bb1.h = bb1.y2 - bb1.y1; + }; + var boundingBoxesIntersect = function boundingBoxesIntersect2(bb1, bb2) { + if (bb1.x1 > bb2.x2) { + return false; + } + if (bb2.x1 > bb1.x2) { + return false; + } + if (bb1.x2 < bb2.x1) { + return false; + } + if (bb2.x2 < bb1.x1) { + return false; + } + if (bb1.y2 < bb2.y1) { + return false; + } + if (bb2.y2 < bb1.y1) { + return false; + } + if (bb1.y1 > bb2.y2) { + return false; + } + if (bb2.y1 > bb1.y2) { + return false; + } + return true; + }; + var inBoundingBox = function inBoundingBox2(bb, x2, y2) { + return bb.x1 <= x2 && x2 <= bb.x2 && bb.y1 <= y2 && y2 <= bb.y2; + }; + var pointInBoundingBox = function pointInBoundingBox2(bb, pt) { + return inBoundingBox(bb, pt.x, pt.y); + }; + var boundingBoxInBoundingBox = function boundingBoxInBoundingBox2(bb1, bb2) { + return inBoundingBox(bb1, bb2.x1, bb2.y1) && inBoundingBox(bb1, bb2.x2, bb2.y2); + }; + var roundRectangleIntersectLine = function roundRectangleIntersectLine2(x2, y2, nodeX, nodeY, width2, height, padding2) { + var cornerRadius = getRoundRectangleRadius(width2, height); + var halfWidth = width2 / 2; + var halfHeight = height / 2; + var straightLineIntersections; + { + var topStartX = nodeX - halfWidth + cornerRadius - padding2; + var topStartY = nodeY - halfHeight - padding2; + var topEndX = nodeX + halfWidth - cornerRadius + padding2; + var topEndY = topStartY; + straightLineIntersections = finiteLinesIntersect(x2, y2, nodeX, nodeY, topStartX, topStartY, topEndX, topEndY, false); + if (straightLineIntersections.length > 0) { + return straightLineIntersections; + } + } + { + var rightStartX = nodeX + halfWidth + padding2; + var rightStartY = nodeY - halfHeight + cornerRadius - padding2; + var rightEndX = rightStartX; + var rightEndY = nodeY + halfHeight - cornerRadius + padding2; + straightLineIntersections = finiteLinesIntersect(x2, y2, nodeX, nodeY, rightStartX, rightStartY, rightEndX, rightEndY, false); + if (straightLineIntersections.length > 0) { + return straightLineIntersections; + } + } + { + var bottomStartX = nodeX - halfWidth + cornerRadius - padding2; + var bottomStartY = nodeY + halfHeight + padding2; + var bottomEndX = nodeX + halfWidth - cornerRadius + padding2; + var bottomEndY = bottomStartY; + straightLineIntersections = finiteLinesIntersect(x2, y2, nodeX, nodeY, bottomStartX, bottomStartY, bottomEndX, bottomEndY, false); + if (straightLineIntersections.length > 0) { + return straightLineIntersections; + } + } + { + var leftStartX = nodeX - halfWidth - padding2; + var leftStartY = nodeY - halfHeight + cornerRadius - padding2; + var leftEndX = leftStartX; + var leftEndY = nodeY + halfHeight - cornerRadius + padding2; + straightLineIntersections = finiteLinesIntersect(x2, y2, nodeX, nodeY, leftStartX, leftStartY, leftEndX, leftEndY, false); + if (straightLineIntersections.length > 0) { + return straightLineIntersections; + } + } + var arcIntersections; + { + var topLeftCenterX = nodeX - halfWidth + cornerRadius; + var topLeftCenterY = nodeY - halfHeight + cornerRadius; + arcIntersections = intersectLineCircle(x2, y2, nodeX, nodeY, topLeftCenterX, topLeftCenterY, cornerRadius + padding2); + if (arcIntersections.length > 0 && arcIntersections[0] <= topLeftCenterX && arcIntersections[1] <= topLeftCenterY) { + return [arcIntersections[0], arcIntersections[1]]; + } + } + { + var topRightCenterX = nodeX + halfWidth - cornerRadius; + var topRightCenterY = nodeY - halfHeight + cornerRadius; + arcIntersections = intersectLineCircle(x2, y2, nodeX, nodeY, topRightCenterX, topRightCenterY, cornerRadius + padding2); + if (arcIntersections.length > 0 && arcIntersections[0] >= topRightCenterX && arcIntersections[1] <= topRightCenterY) { + return [arcIntersections[0], arcIntersections[1]]; + } + } + { + var bottomRightCenterX = nodeX + halfWidth - cornerRadius; + var bottomRightCenterY = nodeY + halfHeight - cornerRadius; + arcIntersections = intersectLineCircle(x2, y2, nodeX, nodeY, bottomRightCenterX, bottomRightCenterY, cornerRadius + padding2); + if (arcIntersections.length > 0 && arcIntersections[0] >= bottomRightCenterX && arcIntersections[1] >= bottomRightCenterY) { + return [arcIntersections[0], arcIntersections[1]]; + } + } + { + var bottomLeftCenterX = nodeX - halfWidth + cornerRadius; + var bottomLeftCenterY = nodeY + halfHeight - cornerRadius; + arcIntersections = intersectLineCircle(x2, y2, nodeX, nodeY, bottomLeftCenterX, bottomLeftCenterY, cornerRadius + padding2); + if (arcIntersections.length > 0 && arcIntersections[0] <= bottomLeftCenterX && arcIntersections[1] >= bottomLeftCenterY) { + return [arcIntersections[0], arcIntersections[1]]; + } + } + return []; + }; + var inLineVicinity = function inLineVicinity2(x2, y2, lx1, ly1, lx2, ly2, tolerance) { + var t = tolerance; + var x1 = Math.min(lx1, lx2); + var x22 = Math.max(lx1, lx2); + var y1 = Math.min(ly1, ly2); + var y22 = Math.max(ly1, ly2); + return x1 - t <= x2 && x2 <= x22 + t && y1 - t <= y2 && y2 <= y22 + t; + }; + var inBezierVicinity = function inBezierVicinity2(x2, y2, x1, y1, x22, y22, x3, y3, tolerance) { + var bb = { + x1: Math.min(x1, x3, x22) - tolerance, + x2: Math.max(x1, x3, x22) + tolerance, + y1: Math.min(y1, y3, y22) - tolerance, + y2: Math.max(y1, y3, y22) + tolerance + }; + if (x2 < bb.x1 || x2 > bb.x2 || y2 < bb.y1 || y2 > bb.y2) { + return false; + } else { + return true; + } + }; + var solveQuadratic = function solveQuadratic2(a, b, c2, val) { + c2 -= val; + var r = b * b - 4 * a * c2; + if (r < 0) { + return []; + } + var sqrtR = Math.sqrt(r); + var denom = 2 * a; + var root1 = (-b + sqrtR) / denom; + var root22 = (-b - sqrtR) / denom; + return [root1, root22]; + }; + var solveCubic = function solveCubic2(a, b, c2, d, result) { + var epsilon2 = 1e-5; + if (a === 0) { + a = epsilon2; + } + b /= a; + c2 /= a; + d /= a; + var discriminant, q, r, dum1, s, t, term1, r13; + q = (3 * c2 - b * b) / 9; + r = -(27 * d) + b * (9 * c2 - 2 * (b * b)); + r /= 54; + discriminant = q * q * q + r * r; + result[1] = 0; + term1 = b / 3; + if (discriminant > 0) { + s = r + Math.sqrt(discriminant); + s = s < 0 ? -Math.pow(-s, 1 / 3) : Math.pow(s, 1 / 3); + t = r - Math.sqrt(discriminant); + t = t < 0 ? -Math.pow(-t, 1 / 3) : Math.pow(t, 1 / 3); + result[0] = -term1 + s + t; + term1 += (s + t) / 2; + result[4] = result[2] = -term1; + term1 = Math.sqrt(3) * (-t + s) / 2; + result[3] = term1; + result[5] = -term1; + return; + } + result[5] = result[3] = 0; + if (discriminant === 0) { + r13 = r < 0 ? -Math.pow(-r, 1 / 3) : Math.pow(r, 1 / 3); + result[0] = -term1 + 2 * r13; + result[4] = result[2] = -(r13 + term1); + return; + } + q = -q; + dum1 = q * q * q; + dum1 = Math.acos(r / Math.sqrt(dum1)); + r13 = 2 * Math.sqrt(q); + result[0] = -term1 + r13 * Math.cos(dum1 / 3); + result[2] = -term1 + r13 * Math.cos((dum1 + 2 * Math.PI) / 3); + result[4] = -term1 + r13 * Math.cos((dum1 + 4 * Math.PI) / 3); + return; + }; + var sqdistToQuadraticBezier = function sqdistToQuadraticBezier2(x2, y2, x1, y1, x22, y22, x3, y3) { + var a = 1 * x1 * x1 - 4 * x1 * x22 + 2 * x1 * x3 + 4 * x22 * x22 - 4 * x22 * x3 + x3 * x3 + y1 * y1 - 4 * y1 * y22 + 2 * y1 * y3 + 4 * y22 * y22 - 4 * y22 * y3 + y3 * y3; + var b = 1 * 9 * x1 * x22 - 3 * x1 * x1 - 3 * x1 * x3 - 6 * x22 * x22 + 3 * x22 * x3 + 9 * y1 * y22 - 3 * y1 * y1 - 3 * y1 * y3 - 6 * y22 * y22 + 3 * y22 * y3; + var c2 = 1 * 3 * x1 * x1 - 6 * x1 * x22 + x1 * x3 - x1 * x2 + 2 * x22 * x22 + 2 * x22 * x2 - x3 * x2 + 3 * y1 * y1 - 6 * y1 * y22 + y1 * y3 - y1 * y2 + 2 * y22 * y22 + 2 * y22 * y2 - y3 * y2; + var d = 1 * x1 * x22 - x1 * x1 + x1 * x2 - x22 * x2 + y1 * y22 - y1 * y1 + y1 * y2 - y22 * y2; + var roots = []; + solveCubic(a, b, c2, d, roots); + var zeroThreshold = 1e-7; + var params = []; + for (var index2 = 0; index2 < 6; index2 += 2) { + if (Math.abs(roots[index2 + 1]) < zeroThreshold && roots[index2] >= 0 && roots[index2] <= 1) { + params.push(roots[index2]); + } + } + params.push(1); + params.push(0); + var minDistanceSquared = -1; + var curX, curY, distSquared; + for (var i3 = 0; i3 < params.length; i3++) { + curX = Math.pow(1 - params[i3], 2) * x1 + 2 * (1 - params[i3]) * params[i3] * x22 + params[i3] * params[i3] * x3; + curY = Math.pow(1 - params[i3], 2) * y1 + 2 * (1 - params[i3]) * params[i3] * y22 + params[i3] * params[i3] * y3; + distSquared = Math.pow(curX - x2, 2) + Math.pow(curY - y2, 2); + if (minDistanceSquared >= 0) { + if (distSquared < minDistanceSquared) { + minDistanceSquared = distSquared; + } + } else { + minDistanceSquared = distSquared; + } + } + return minDistanceSquared; + }; + var sqdistToFiniteLine = function sqdistToFiniteLine2(x2, y2, x1, y1, x22, y22) { + var offset = [x2 - x1, y2 - y1]; + var line2 = [x22 - x1, y22 - y1]; + var lineSq = line2[0] * line2[0] + line2[1] * line2[1]; + var hypSq = offset[0] * offset[0] + offset[1] * offset[1]; + var dotProduct = offset[0] * line2[0] + offset[1] * line2[1]; + var adjSq = dotProduct * dotProduct / lineSq; + if (dotProduct < 0) { + return hypSq; + } + if (adjSq > lineSq) { + return (x2 - x22) * (x2 - x22) + (y2 - y22) * (y2 - y22); + } + return hypSq - adjSq; + }; + var pointInsidePolygonPoints = function pointInsidePolygonPoints2(x2, y2, points) { + var x1, y1, x22, y22; + var y3; + var up = 0; + for (var i3 = 0; i3 < points.length / 2; i3++) { + x1 = points[i3 * 2]; + y1 = points[i3 * 2 + 1]; + if (i3 + 1 < points.length / 2) { + x22 = points[(i3 + 1) * 2]; + y22 = points[(i3 + 1) * 2 + 1]; + } else { + x22 = points[(i3 + 1 - points.length / 2) * 2]; + y22 = points[(i3 + 1 - points.length / 2) * 2 + 1]; + } + if (x1 == x2 && x22 == x2) + ; + else if (x1 >= x2 && x2 >= x22 || x1 <= x2 && x2 <= x22) { + y3 = (x2 - x1) / (x22 - x1) * (y22 - y1) + y1; + if (y3 > y2) { + up++; + } + } else { + continue; + } + } + if (up % 2 === 0) { + return false; + } else { + return true; + } + }; + var pointInsidePolygon = function pointInsidePolygon2(x2, y2, basePoints, centerX, centerY, width2, height, direction2, padding2) { + var transformedPoints = new Array(basePoints.length); + var angle; + if (direction2[0] != null) { + angle = Math.atan(direction2[1] / direction2[0]); + if (direction2[0] < 0) { + angle = angle + Math.PI / 2; + } else { + angle = -angle - Math.PI / 2; + } + } else { + angle = direction2; + } + var cos3 = Math.cos(-angle); + var sin3 = Math.sin(-angle); + for (var i3 = 0; i3 < transformedPoints.length / 2; i3++) { + transformedPoints[i3 * 2] = width2 / 2 * (basePoints[i3 * 2] * cos3 - basePoints[i3 * 2 + 1] * sin3); + transformedPoints[i3 * 2 + 1] = height / 2 * (basePoints[i3 * 2 + 1] * cos3 + basePoints[i3 * 2] * sin3); + transformedPoints[i3 * 2] += centerX; + transformedPoints[i3 * 2 + 1] += centerY; + } + var points; + if (padding2 > 0) { + var expandedLineSet = expandPolygon(transformedPoints, -padding2); + points = joinLines(expandedLineSet); + } else { + points = transformedPoints; + } + return pointInsidePolygonPoints(x2, y2, points); + }; + var pointInsideRoundPolygon = function pointInsideRoundPolygon2(x2, y2, basePoints, centerX, centerY, width2, height) { + var cutPolygonPoints = new Array(basePoints.length); + var halfW = width2 / 2; + var halfH = height / 2; + var cornerRadius = getRoundPolygonRadius(width2, height); + var squaredCornerRadius = cornerRadius * cornerRadius; + for (var i3 = 0; i3 < basePoints.length / 4; i3++) { + var sourceUv = void 0, destUv = void 0; + if (i3 === 0) { + sourceUv = basePoints.length - 2; + } else { + sourceUv = i3 * 4 - 2; + } + destUv = i3 * 4 + 2; + var px = centerX + halfW * basePoints[i3 * 4]; + var py = centerY + halfH * basePoints[i3 * 4 + 1]; + var cosTheta = -basePoints[sourceUv] * basePoints[destUv] - basePoints[sourceUv + 1] * basePoints[destUv + 1]; + var offset = cornerRadius / Math.tan(Math.acos(cosTheta) / 2); + var cp0x = px - offset * basePoints[sourceUv]; + var cp0y = py - offset * basePoints[sourceUv + 1]; + var cp1x = px + offset * basePoints[destUv]; + var cp1y = py + offset * basePoints[destUv + 1]; + cutPolygonPoints[i3 * 4] = cp0x; + cutPolygonPoints[i3 * 4 + 1] = cp0y; + cutPolygonPoints[i3 * 4 + 2] = cp1x; + cutPolygonPoints[i3 * 4 + 3] = cp1y; + var orthx = basePoints[sourceUv + 1]; + var orthy = -basePoints[sourceUv]; + var cosAlpha = orthx * basePoints[destUv] + orthy * basePoints[destUv + 1]; + if (cosAlpha < 0) { + orthx *= -1; + orthy *= -1; + } + var cx = cp0x + orthx * cornerRadius; + var cy = cp0y + orthy * cornerRadius; + var squaredDistance = Math.pow(cx - x2, 2) + Math.pow(cy - y2, 2); + if (squaredDistance <= squaredCornerRadius) { + return true; + } + } + return pointInsidePolygonPoints(x2, y2, cutPolygonPoints); + }; + var joinLines = function joinLines2(lineSet) { + var vertices2 = new Array(lineSet.length / 2); + var currentLineStartX, currentLineStartY, currentLineEndX, currentLineEndY; + var nextLineStartX, nextLineStartY, nextLineEndX, nextLineEndY; + for (var i3 = 0; i3 < lineSet.length / 4; i3++) { + currentLineStartX = lineSet[i3 * 4]; + currentLineStartY = lineSet[i3 * 4 + 1]; + currentLineEndX = lineSet[i3 * 4 + 2]; + currentLineEndY = lineSet[i3 * 4 + 3]; + if (i3 < lineSet.length / 4 - 1) { + nextLineStartX = lineSet[(i3 + 1) * 4]; + nextLineStartY = lineSet[(i3 + 1) * 4 + 1]; + nextLineEndX = lineSet[(i3 + 1) * 4 + 2]; + nextLineEndY = lineSet[(i3 + 1) * 4 + 3]; + } else { + nextLineStartX = lineSet[0]; + nextLineStartY = lineSet[1]; + nextLineEndX = lineSet[2]; + nextLineEndY = lineSet[3]; + } + var intersection2 = finiteLinesIntersect(currentLineStartX, currentLineStartY, currentLineEndX, currentLineEndY, nextLineStartX, nextLineStartY, nextLineEndX, nextLineEndY, true); + vertices2[i3 * 2] = intersection2[0]; + vertices2[i3 * 2 + 1] = intersection2[1]; + } + return vertices2; + }; + var expandPolygon = function expandPolygon2(points, pad2) { + var expandedLineSet = new Array(points.length * 2); + var currentPointX, currentPointY, nextPointX, nextPointY; + for (var i3 = 0; i3 < points.length / 2; i3++) { + currentPointX = points[i3 * 2]; + currentPointY = points[i3 * 2 + 1]; + if (i3 < points.length / 2 - 1) { + nextPointX = points[(i3 + 1) * 2]; + nextPointY = points[(i3 + 1) * 2 + 1]; + } else { + nextPointX = points[0]; + nextPointY = points[1]; + } + var offsetX = nextPointY - currentPointY; + var offsetY = -(nextPointX - currentPointX); + var offsetLength = Math.sqrt(offsetX * offsetX + offsetY * offsetY); + var normalizedOffsetX = offsetX / offsetLength; + var normalizedOffsetY = offsetY / offsetLength; + expandedLineSet[i3 * 4] = currentPointX + normalizedOffsetX * pad2; + expandedLineSet[i3 * 4 + 1] = currentPointY + normalizedOffsetY * pad2; + expandedLineSet[i3 * 4 + 2] = nextPointX + normalizedOffsetX * pad2; + expandedLineSet[i3 * 4 + 3] = nextPointY + normalizedOffsetY * pad2; + } + return expandedLineSet; + }; + var intersectLineEllipse = function intersectLineEllipse2(x2, y2, centerX, centerY, ellipseWradius, ellipseHradius) { + var dispX = centerX - x2; + var dispY = centerY - y2; + dispX /= ellipseWradius; + dispY /= ellipseHradius; + var len = Math.sqrt(dispX * dispX + dispY * dispY); + var newLength = len - 1; + if (newLength < 0) { + return []; + } + var lenProportion = newLength / len; + return [(centerX - x2) * lenProportion + x2, (centerY - y2) * lenProportion + y2]; + }; + var checkInEllipse = function checkInEllipse2(x2, y2, width2, height, centerX, centerY, padding2) { + x2 -= centerX; + y2 -= centerY; + x2 /= width2 / 2 + padding2; + y2 /= height / 2 + padding2; + return x2 * x2 + y2 * y2 <= 1; + }; + var intersectLineCircle = function intersectLineCircle2(x1, y1, x2, y2, centerX, centerY, radius) { + var d = [x2 - x1, y2 - y1]; + var f2 = [x1 - centerX, y1 - centerY]; + var a = d[0] * d[0] + d[1] * d[1]; + var b = 2 * (f2[0] * d[0] + f2[1] * d[1]); + var c2 = f2[0] * f2[0] + f2[1] * f2[1] - radius * radius; + var discriminant = b * b - 4 * a * c2; + if (discriminant < 0) { + return []; + } + var t12 = (-b + Math.sqrt(discriminant)) / (2 * a); + var t22 = (-b - Math.sqrt(discriminant)) / (2 * a); + var tMin = Math.min(t12, t22); + var tMax = Math.max(t12, t22); + var inRangeParams = []; + if (tMin >= 0 && tMin <= 1) { + inRangeParams.push(tMin); + } + if (tMax >= 0 && tMax <= 1) { + inRangeParams.push(tMax); + } + if (inRangeParams.length === 0) { + return []; + } + var nearIntersectionX = inRangeParams[0] * d[0] + x1; + var nearIntersectionY = inRangeParams[0] * d[1] + y1; + if (inRangeParams.length > 1) { + if (inRangeParams[0] == inRangeParams[1]) { + return [nearIntersectionX, nearIntersectionY]; + } else { + var farIntersectionX = inRangeParams[1] * d[0] + x1; + var farIntersectionY = inRangeParams[1] * d[1] + y1; + return [nearIntersectionX, nearIntersectionY, farIntersectionX, farIntersectionY]; + } + } else { + return [nearIntersectionX, nearIntersectionY]; + } + }; + var midOfThree = function midOfThree2(a, b, c2) { + if (b <= a && a <= c2 || c2 <= a && a <= b) { + return a; + } else if (a <= b && b <= c2 || c2 <= b && b <= a) { + return b; + } else { + return c2; + } + }; + var finiteLinesIntersect = function finiteLinesIntersect2(x1, y1, x2, y2, x3, y3, x4, y4, infiniteLines) { + var dx13 = x1 - x3; + var dx21 = x2 - x1; + var dx43 = x4 - x3; + var dy13 = y1 - y3; + var dy21 = y2 - y1; + var dy43 = y4 - y3; + var ua_t = dx43 * dy13 - dy43 * dx13; + var ub_t = dx21 * dy13 - dy21 * dx13; + var u_b = dy43 * dx21 - dx43 * dy21; + if (u_b !== 0) { + var ua = ua_t / u_b; + var ub = ub_t / u_b; + var flptThreshold = 1e-3; + var _min = 0 - flptThreshold; + var _max = 1 + flptThreshold; + if (_min <= ua && ua <= _max && _min <= ub && ub <= _max) { + return [x1 + ua * dx21, y1 + ua * dy21]; + } else { + if (!infiniteLines) { + return []; + } else { + return [x1 + ua * dx21, y1 + ua * dy21]; + } + } + } else { + if (ua_t === 0 || ub_t === 0) { + if (midOfThree(x1, x2, x4) === x4) { + return [x4, y4]; + } + if (midOfThree(x1, x2, x3) === x3) { + return [x3, y3]; + } + if (midOfThree(x3, x4, x2) === x2) { + return [x2, y2]; + } + return []; + } else { + return []; + } + } + }; + var polygonIntersectLine = function polygonIntersectLine2(x2, y2, basePoints, centerX, centerY, width2, height, padding2) { + var intersections = []; + var intersection2; + var transformedPoints = new Array(basePoints.length); + var doTransform = true; + if (width2 == null) { + doTransform = false; + } + var points; + if (doTransform) { + for (var i3 = 0; i3 < transformedPoints.length / 2; i3++) { + transformedPoints[i3 * 2] = basePoints[i3 * 2] * width2 + centerX; + transformedPoints[i3 * 2 + 1] = basePoints[i3 * 2 + 1] * height + centerY; + } + if (padding2 > 0) { + var expandedLineSet = expandPolygon(transformedPoints, -padding2); + points = joinLines(expandedLineSet); + } else { + points = transformedPoints; + } + } else { + points = basePoints; + } + var currentX, currentY, nextX, nextY; + for (var _i22 = 0; _i22 < points.length / 2; _i22++) { + currentX = points[_i22 * 2]; + currentY = points[_i22 * 2 + 1]; + if (_i22 < points.length / 2 - 1) { + nextX = points[(_i22 + 1) * 2]; + nextY = points[(_i22 + 1) * 2 + 1]; + } else { + nextX = points[0]; + nextY = points[1]; + } + intersection2 = finiteLinesIntersect(x2, y2, centerX, centerY, currentX, currentY, nextX, nextY); + if (intersection2.length !== 0) { + intersections.push(intersection2[0], intersection2[1]); + } + } + return intersections; + }; + var roundPolygonIntersectLine = function roundPolygonIntersectLine2(x2, y2, basePoints, centerX, centerY, width2, height, padding2) { + var intersections = []; + var intersection2; + var lines = new Array(basePoints.length); + var halfW = width2 / 2; + var halfH = height / 2; + var cornerRadius = getRoundPolygonRadius(width2, height); + for (var i3 = 0; i3 < basePoints.length / 4; i3++) { + var sourceUv = void 0, destUv = void 0; + if (i3 === 0) { + sourceUv = basePoints.length - 2; + } else { + sourceUv = i3 * 4 - 2; + } + destUv = i3 * 4 + 2; + var px = centerX + halfW * basePoints[i3 * 4]; + var py = centerY + halfH * basePoints[i3 * 4 + 1]; + var cosTheta = -basePoints[sourceUv] * basePoints[destUv] - basePoints[sourceUv + 1] * basePoints[destUv + 1]; + var offset = cornerRadius / Math.tan(Math.acos(cosTheta) / 2); + var cp0x = px - offset * basePoints[sourceUv]; + var cp0y = py - offset * basePoints[sourceUv + 1]; + var cp1x = px + offset * basePoints[destUv]; + var cp1y = py + offset * basePoints[destUv + 1]; + if (i3 === 0) { + lines[basePoints.length - 2] = cp0x; + lines[basePoints.length - 1] = cp0y; + } else { + lines[i3 * 4 - 2] = cp0x; + lines[i3 * 4 - 1] = cp0y; + } + lines[i3 * 4] = cp1x; + lines[i3 * 4 + 1] = cp1y; + var orthx = basePoints[sourceUv + 1]; + var orthy = -basePoints[sourceUv]; + var cosAlpha = orthx * basePoints[destUv] + orthy * basePoints[destUv + 1]; + if (cosAlpha < 0) { + orthx *= -1; + orthy *= -1; + } + var cx = cp0x + orthx * cornerRadius; + var cy = cp0y + orthy * cornerRadius; + intersection2 = intersectLineCircle(x2, y2, centerX, centerY, cx, cy, cornerRadius); + if (intersection2.length !== 0) { + intersections.push(intersection2[0], intersection2[1]); + } + } + for (var _i32 = 0; _i32 < lines.length / 4; _i32++) { + intersection2 = finiteLinesIntersect(x2, y2, centerX, centerY, lines[_i32 * 4], lines[_i32 * 4 + 1], lines[_i32 * 4 + 2], lines[_i32 * 4 + 3], false); + if (intersection2.length !== 0) { + intersections.push(intersection2[0], intersection2[1]); + } + } + if (intersections.length > 2) { + var lowestIntersection = [intersections[0], intersections[1]]; + var lowestSquaredDistance = Math.pow(lowestIntersection[0] - x2, 2) + Math.pow(lowestIntersection[1] - y2, 2); + for (var _i42 = 1; _i42 < intersections.length / 2; _i42++) { + var squaredDistance = Math.pow(intersections[_i42 * 2] - x2, 2) + Math.pow(intersections[_i42 * 2 + 1] - y2, 2); + if (squaredDistance <= lowestSquaredDistance) { + lowestIntersection[0] = intersections[_i42 * 2]; + lowestIntersection[1] = intersections[_i42 * 2 + 1]; + lowestSquaredDistance = squaredDistance; + } + } + return lowestIntersection; + } + return intersections; + }; + var shortenIntersection = function shortenIntersection2(intersection2, offset, amount) { + var disp = [intersection2[0] - offset[0], intersection2[1] - offset[1]]; + var length2 = Math.sqrt(disp[0] * disp[0] + disp[1] * disp[1]); + var lenRatio = (length2 - amount) / length2; + if (lenRatio < 0) { + lenRatio = 1e-5; + } + return [offset[0] + lenRatio * disp[0], offset[1] + lenRatio * disp[1]]; + }; + var generateUnitNgonPointsFitToSquare = function generateUnitNgonPointsFitToSquare2(sides, rotationRadians) { + var points = generateUnitNgonPoints(sides, rotationRadians); + points = fitPolygonToSquare(points); + return points; + }; + var fitPolygonToSquare = function fitPolygonToSquare2(points) { + var x2, y2; + var sides = points.length / 2; + var minX = Infinity, minY = Infinity, maxX = -Infinity, maxY = -Infinity; + for (var i3 = 0; i3 < sides; i3++) { + x2 = points[2 * i3]; + y2 = points[2 * i3 + 1]; + minX = Math.min(minX, x2); + maxX = Math.max(maxX, x2); + minY = Math.min(minY, y2); + maxY = Math.max(maxY, y2); + } + var sx = 2 / (maxX - minX); + var sy = 2 / (maxY - minY); + for (var _i52 = 0; _i52 < sides; _i52++) { + x2 = points[2 * _i52] = points[2 * _i52] * sx; + y2 = points[2 * _i52 + 1] = points[2 * _i52 + 1] * sy; + minX = Math.min(minX, x2); + maxX = Math.max(maxX, x2); + minY = Math.min(minY, y2); + maxY = Math.max(maxY, y2); + } + if (minY < -1) { + for (var _i6 = 0; _i6 < sides; _i6++) { + y2 = points[2 * _i6 + 1] = points[2 * _i6 + 1] + (-1 - minY); + } + } + return points; + }; + var generateUnitNgonPoints = function generateUnitNgonPoints2(sides, rotationRadians) { + var increment = 1 / sides * 2 * Math.PI; + var startAngle = sides % 2 === 0 ? Math.PI / 2 + increment / 2 : Math.PI / 2; + startAngle += rotationRadians; + var points = new Array(sides * 2); + var currentAngle; + for (var i3 = 0; i3 < sides; i3++) { + currentAngle = i3 * increment + startAngle; + points[2 * i3] = Math.cos(currentAngle); + points[2 * i3 + 1] = Math.sin(-currentAngle); + } + return points; + }; + var getRoundRectangleRadius = function getRoundRectangleRadius2(width2, height) { + return Math.min(width2 / 4, height / 4, 8); + }; + var getRoundPolygonRadius = function getRoundPolygonRadius2(width2, height) { + return Math.min(width2 / 10, height / 10, 8); + }; + var getCutRectangleCornerLength = function getCutRectangleCornerLength2() { + return 8; + }; + var bezierPtsToQuadCoeff = function bezierPtsToQuadCoeff2(p0, p1, p2) { + return [p0 - 2 * p1 + p2, 2 * (p1 - p0), p0]; + }; + var getBarrelCurveConstants = function getBarrelCurveConstants2(width2, height) { + return { + heightOffset: Math.min(15, 0.05 * height), + widthOffset: Math.min(100, 0.25 * width2), + ctrlPtOffsetPct: 0.05 + }; + }; + var pageRankDefaults = defaults$g({ + dampingFactor: 0.8, + precision: 1e-6, + iterations: 200, + weight: function weight(edge) { + return 1; + } + }); + var elesfn$o = { + pageRank: function pageRank(options2) { + var _pageRankDefaults = pageRankDefaults(options2), dampingFactor = _pageRankDefaults.dampingFactor, precision = _pageRankDefaults.precision, iterations = _pageRankDefaults.iterations, weight = _pageRankDefaults.weight; + var cy = this._private.cy; + var _this$byGroup = this.byGroup(), nodes2 = _this$byGroup.nodes, edges2 = _this$byGroup.edges; + var numNodes = nodes2.length; + var numNodesSqd = numNodes * numNodes; + var numEdges = edges2.length; + var matrix = new Array(numNodesSqd); + var columnSum = new Array(numNodes); + var additionalProb = (1 - dampingFactor) / numNodes; + for (var i3 = 0; i3 < numNodes; i3++) { + for (var j = 0; j < numNodes; j++) { + var n = i3 * numNodes + j; + matrix[n] = 0; + } + columnSum[i3] = 0; + } + for (var _i6 = 0; _i6 < numEdges; _i6++) { + var edge = edges2[_i6]; + var srcId = edge.data("source"); + var tgtId = edge.data("target"); + if (srcId === tgtId) { + continue; + } + var s = nodes2.indexOfId(srcId); + var t = nodes2.indexOfId(tgtId); + var w2 = weight(edge); + var _n = t * numNodes + s; + matrix[_n] += w2; + columnSum[s] += w2; + } + var p2 = 1 / numNodes + additionalProb; + for (var _j = 0; _j < numNodes; _j++) { + if (columnSum[_j] === 0) { + for (var _i22 = 0; _i22 < numNodes; _i22++) { + var _n2 = _i22 * numNodes + _j; + matrix[_n2] = p2; + } + } else { + for (var _i32 = 0; _i32 < numNodes; _i32++) { + var _n3 = _i32 * numNodes + _j; + matrix[_n3] = matrix[_n3] / columnSum[_j] + additionalProb; + } + } + } + var eigenvector = new Array(numNodes); + var temp = new Array(numNodes); + var previous2; + for (var _i42 = 0; _i42 < numNodes; _i42++) { + eigenvector[_i42] = 1; + } + for (var iter = 0; iter < iterations; iter++) { + for (var _i52 = 0; _i52 < numNodes; _i52++) { + temp[_i52] = 0; + } + for (var _i62 = 0; _i62 < numNodes; _i62++) { + for (var _j2 = 0; _j2 < numNodes; _j2++) { + var _n4 = _i62 * numNodes + _j2; + temp[_i62] += matrix[_n4] * eigenvector[_j2]; + } + } + inPlaceSumNormalize(temp); + previous2 = eigenvector; + eigenvector = temp; + temp = previous2; + var diff = 0; + for (var _i7 = 0; _i7 < numNodes; _i7++) { + var delta = previous2[_i7] - eigenvector[_i7]; + diff += delta * delta; + } + if (diff < precision) { + break; + } + } + var res = { + rank: function rank2(node2) { + node2 = cy.collection(node2)[0]; + return eigenvector[nodes2.indexOf(node2)]; + } + }; + return res; + } + // pageRank + }; + var defaults$f = defaults$g({ + root: null, + weight: function weight(edge) { + return 1; + }, + directed: false, + alpha: 0 + }); + var elesfn$n = { + degreeCentralityNormalized: function degreeCentralityNormalized(options2) { + options2 = defaults$f(options2); + var cy = this.cy(); + var nodes2 = this.nodes(); + var numNodes = nodes2.length; + if (!options2.directed) { + var degrees2 = {}; + var maxDegree = 0; + for (var i3 = 0; i3 < numNodes; i3++) { + var node2 = nodes2[i3]; + options2.root = node2; + var currDegree = this.degreeCentrality(options2); + if (maxDegree < currDegree.degree) { + maxDegree = currDegree.degree; + } + degrees2[node2.id()] = currDegree.degree; + } + return { + degree: function degree(node3) { + if (maxDegree === 0) { + return 0; + } + if (string2(node3)) { + node3 = cy.filter(node3); + } + return degrees2[node3.id()] / maxDegree; + } + }; + } else { + var indegrees = {}; + var outdegrees = {}; + var maxIndegree = 0; + var maxOutdegree = 0; + for (var _i6 = 0; _i6 < numNodes; _i6++) { + var _node = nodes2[_i6]; + var id2 = _node.id(); + options2.root = _node; + var _currDegree = this.degreeCentrality(options2); + if (maxIndegree < _currDegree.indegree) + maxIndegree = _currDegree.indegree; + if (maxOutdegree < _currDegree.outdegree) + maxOutdegree = _currDegree.outdegree; + indegrees[id2] = _currDegree.indegree; + outdegrees[id2] = _currDegree.outdegree; + } + return { + indegree: function indegree(node3) { + if (maxIndegree == 0) { + return 0; + } + if (string2(node3)) { + node3 = cy.filter(node3); + } + return indegrees[node3.id()] / maxIndegree; + }, + outdegree: function outdegree(node3) { + if (maxOutdegree === 0) { + return 0; + } + if (string2(node3)) { + node3 = cy.filter(node3); + } + return outdegrees[node3.id()] / maxOutdegree; + } + }; + } + }, + // degreeCentralityNormalized + // Implemented from the algorithm in Opsahl's paper + // "Node centrality in weighted networks: Generalizing degree and shortest paths" + // check the heading 2 "Degree" + degreeCentrality: function degreeCentrality(options2) { + options2 = defaults$f(options2); + var cy = this.cy(); + var callingEles = this; + var _options = options2, root3 = _options.root, weight = _options.weight, directed = _options.directed, alpha = _options.alpha; + root3 = cy.collection(root3)[0]; + if (!directed) { + var connEdges = root3.connectedEdges().intersection(callingEles); + var k = connEdges.length; + var s = 0; + for (var i3 = 0; i3 < connEdges.length; i3++) { + s += weight(connEdges[i3]); + } + return { + degree: Math.pow(k, 1 - alpha) * Math.pow(s, alpha) + }; + } else { + var edges2 = root3.connectedEdges(); + var incoming = edges2.filter(function(edge) { + return edge.target().same(root3) && callingEles.has(edge); + }); + var outgoing = edges2.filter(function(edge) { + return edge.source().same(root3) && callingEles.has(edge); + }); + var k_in = incoming.length; + var k_out = outgoing.length; + var s_in = 0; + var s_out = 0; + for (var _i22 = 0; _i22 < incoming.length; _i22++) { + s_in += weight(incoming[_i22]); + } + for (var _i32 = 0; _i32 < outgoing.length; _i32++) { + s_out += weight(outgoing[_i32]); + } + return { + indegree: Math.pow(k_in, 1 - alpha) * Math.pow(s_in, alpha), + outdegree: Math.pow(k_out, 1 - alpha) * Math.pow(s_out, alpha) + }; + } + } + // degreeCentrality + }; + elesfn$n.dc = elesfn$n.degreeCentrality; + elesfn$n.dcn = elesfn$n.degreeCentralityNormalised = elesfn$n.degreeCentralityNormalized; + var defaults$e = defaults$g({ + harmonic: true, + weight: function weight() { + return 1; + }, + directed: false, + root: null + }); + var elesfn$m = { + closenessCentralityNormalized: function closenessCentralityNormalized(options2) { + var _defaults = defaults$e(options2), harmonic = _defaults.harmonic, weight = _defaults.weight, directed = _defaults.directed; + var cy = this.cy(); + var closenesses = {}; + var maxCloseness = 0; + var nodes2 = this.nodes(); + var fw = this.floydWarshall({ + weight, + directed + }); + for (var i3 = 0; i3 < nodes2.length; i3++) { + var currCloseness = 0; + var node_i = nodes2[i3]; + for (var j = 0; j < nodes2.length; j++) { + if (i3 !== j) { + var d = fw.distance(node_i, nodes2[j]); + if (harmonic) { + currCloseness += 1 / d; + } else { + currCloseness += d; + } + } + } + if (!harmonic) { + currCloseness = 1 / currCloseness; + } + if (maxCloseness < currCloseness) { + maxCloseness = currCloseness; + } + closenesses[node_i.id()] = currCloseness; + } + return { + closeness: function closeness(node2) { + if (maxCloseness == 0) { + return 0; + } + if (string2(node2)) { + node2 = cy.filter(node2)[0].id(); + } else { + node2 = node2.id(); + } + return closenesses[node2] / maxCloseness; + } + }; + }, + // Implemented from pseudocode from wikipedia + closenessCentrality: function closenessCentrality(options2) { + var _defaults2 = defaults$e(options2), root3 = _defaults2.root, weight = _defaults2.weight, directed = _defaults2.directed, harmonic = _defaults2.harmonic; + root3 = this.filter(root3)[0]; + var dijkstra = this.dijkstra({ + root: root3, + weight, + directed + }); + var totalDistance = 0; + var nodes2 = this.nodes(); + for (var i3 = 0; i3 < nodes2.length; i3++) { + var n = nodes2[i3]; + if (!n.same(root3)) { + var d = dijkstra.distanceTo(n); + if (harmonic) { + totalDistance += 1 / d; + } else { + totalDistance += d; + } + } + } + return harmonic ? totalDistance : 1 / totalDistance; + } + // closenessCentrality + }; + elesfn$m.cc = elesfn$m.closenessCentrality; + elesfn$m.ccn = elesfn$m.closenessCentralityNormalised = elesfn$m.closenessCentralityNormalized; + var defaults$d = defaults$g({ + weight: null, + directed: false + }); + var elesfn$l = { + // Implemented from the algorithm in the paper "On Variants of Shortest-Path Betweenness Centrality and their Generic Computation" by Ulrik Brandes + betweennessCentrality: function betweennessCentrality(options2) { + var _defaults = defaults$d(options2), directed = _defaults.directed, weight = _defaults.weight; + var weighted = weight != null; + var cy = this.cy(); + var V = this.nodes(); + var A = {}; + var _C = {}; + var max3 = 0; + var C = { + set: function set3(key, val) { + _C[key] = val; + if (val > max3) { + max3 = val; + } + }, + get: function get3(key) { + return _C[key]; + } + }; + for (var i3 = 0; i3 < V.length; i3++) { + var v = V[i3]; + var vid = v.id(); + if (directed) { + A[vid] = v.outgoers().nodes(); + } else { + A[vid] = v.openNeighborhood().nodes(); + } + C.set(vid, 0); + } + var _loop = function _loop2(s2) { + var sid = V[s2].id(); + var S2 = []; + var P = {}; + var g = {}; + var d = {}; + var Q = new heap(function(a, b) { + return d[a] - d[b]; + }); + for (var _i6 = 0; _i6 < V.length; _i6++) { + var _vid = V[_i6].id(); + P[_vid] = []; + g[_vid] = 0; + d[_vid] = Infinity; + } + g[sid] = 1; + d[sid] = 0; + Q.push(sid); + while (!Q.empty()) { + var _v = Q.pop(); + S2.push(_v); + if (weighted) { + for (var j = 0; j < A[_v].length; j++) { + var w2 = A[_v][j]; + var vEle = cy.getElementById(_v); + var edge = void 0; + if (vEle.edgesTo(w2).length > 0) { + edge = vEle.edgesTo(w2)[0]; + } else { + edge = w2.edgesTo(vEle)[0]; + } + var edgeWeight = weight(edge); + w2 = w2.id(); + if (d[w2] > d[_v] + edgeWeight) { + d[w2] = d[_v] + edgeWeight; + if (Q.nodes.indexOf(w2) < 0) { + Q.push(w2); + } else { + Q.updateItem(w2); + } + g[w2] = 0; + P[w2] = []; + } + if (d[w2] == d[_v] + edgeWeight) { + g[w2] = g[w2] + g[_v]; + P[w2].push(_v); + } + } + } else { + for (var _j = 0; _j < A[_v].length; _j++) { + var _w = A[_v][_j].id(); + if (d[_w] == Infinity) { + Q.push(_w); + d[_w] = d[_v] + 1; + } + if (d[_w] == d[_v] + 1) { + g[_w] = g[_w] + g[_v]; + P[_w].push(_v); + } + } + } + } + var e = {}; + for (var _i22 = 0; _i22 < V.length; _i22++) { + e[V[_i22].id()] = 0; + } + while (S2.length > 0) { + var _w2 = S2.pop(); + for (var _j2 = 0; _j2 < P[_w2].length; _j2++) { + var _v2 = P[_w2][_j2]; + e[_v2] = e[_v2] + g[_v2] / g[_w2] * (1 + e[_w2]); + } + if (_w2 != V[s2].id()) { + C.set(_w2, C.get(_w2) + e[_w2]); + } + } + }; + for (var s = 0; s < V.length; s++) { + _loop(s); + } + var ret = { + betweenness: function betweenness(node2) { + var id2 = cy.collection(node2).id(); + return C.get(id2); + }, + betweennessNormalized: function betweennessNormalized(node2) { + if (max3 == 0) { + return 0; + } + var id2 = cy.collection(node2).id(); + return C.get(id2) / max3; + } + }; + ret.betweennessNormalised = ret.betweennessNormalized; + return ret; + } + // betweennessCentrality + }; + elesfn$l.bc = elesfn$l.betweennessCentrality; + var defaults$c = defaults$g({ + expandFactor: 2, + // affects time of computation and cluster granularity to some extent: M * M + inflateFactor: 2, + // affects cluster granularity (the greater the value, the more clusters): M(i,j) / E(j) + multFactor: 1, + // optional self loops for each node. Use a neutral value to improve cluster computations. + maxIterations: 20, + // maximum number of iterations of the MCL algorithm in a single run + attributes: [ + // attributes/features used to group nodes, ie. similarity values between nodes + function(edge) { + return 1; + } + ] + }); + var setOptions$3 = function setOptions3(options2) { + return defaults$c(options2); + }; + var getSimilarity$1 = function getSimilarity2(edge, attributes) { + var total = 0; + for (var i3 = 0; i3 < attributes.length; i3++) { + total += attributes[i3](edge); + } + return total; + }; + var addLoops = function addLoops2(M, n, val) { + for (var i3 = 0; i3 < n; i3++) { + M[i3 * n + i3] = val; + } + }; + var normalize2 = function normalize3(M, n) { + var sum2; + for (var col = 0; col < n; col++) { + sum2 = 0; + for (var row = 0; row < n; row++) { + sum2 += M[row * n + col]; + } + for (var _row = 0; _row < n; _row++) { + M[_row * n + col] = M[_row * n + col] / sum2; + } + } + }; + var mmult = function mmult2(A, B, n) { + var C = new Array(n * n); + for (var i3 = 0; i3 < n; i3++) { + for (var j = 0; j < n; j++) { + C[i3 * n + j] = 0; + } + for (var k = 0; k < n; k++) { + for (var _j = 0; _j < n; _j++) { + C[i3 * n + _j] += A[i3 * n + k] * B[k * n + _j]; + } + } + } + return C; + }; + var expand = function expand2(M, n, expandFactor) { + var _M = M.slice(0); + for (var p2 = 1; p2 < expandFactor; p2++) { + M = mmult(M, _M, n); + } + return M; + }; + var inflate = function inflate2(M, n, inflateFactor) { + var _M = new Array(n * n); + for (var i3 = 0; i3 < n * n; i3++) { + _M[i3] = Math.pow(M[i3], inflateFactor); + } + normalize2(_M, n); + return _M; + }; + var hasConverged = function hasConverged2(M, _M, n2, roundFactor) { + for (var i3 = 0; i3 < n2; i3++) { + var v1 = Math.round(M[i3] * Math.pow(10, roundFactor)) / Math.pow(10, roundFactor); + var v2 = Math.round(_M[i3] * Math.pow(10, roundFactor)) / Math.pow(10, roundFactor); + if (v1 !== v2) { + return false; + } + } + return true; + }; + var assign$2 = function assign2(M, n, nodes2, cy) { + var clusters = []; + for (var i3 = 0; i3 < n; i3++) { + var cluster = []; + for (var j = 0; j < n; j++) { + if (Math.round(M[i3 * n + j] * 1e3) / 1e3 > 0) { + cluster.push(nodes2[j]); + } + } + if (cluster.length !== 0) { + clusters.push(cy.collection(cluster)); + } + } + return clusters; + }; + var isDuplicate = function isDuplicate2(c1, c2) { + for (var i3 = 0; i3 < c1.length; i3++) { + if (!c2[i3] || c1[i3].id() !== c2[i3].id()) { + return false; + } + } + return true; + }; + var removeDuplicates = function removeDuplicates2(clusters) { + for (var i3 = 0; i3 < clusters.length; i3++) { + for (var j = 0; j < clusters.length; j++) { + if (i3 != j && isDuplicate(clusters[i3], clusters[j])) { + clusters.splice(j, 1); + } + } + } + return clusters; + }; + var markovClustering = function markovClustering2(options2) { + var nodes2 = this.nodes(); + var edges2 = this.edges(); + var cy = this.cy(); + var opts = setOptions$3(options2); + var id2position = {}; + for (var i3 = 0; i3 < nodes2.length; i3++) { + id2position[nodes2[i3].id()] = i3; + } + var n = nodes2.length, n2 = n * n; + var M = new Array(n2), _M; + for (var _i6 = 0; _i6 < n2; _i6++) { + M[_i6] = 0; + } + for (var e = 0; e < edges2.length; e++) { + var edge = edges2[e]; + var _i22 = id2position[edge.source().id()]; + var j = id2position[edge.target().id()]; + var sim = getSimilarity$1(edge, opts.attributes); + M[_i22 * n + j] += sim; + M[j * n + _i22] += sim; + } + addLoops(M, n, opts.multFactor); + normalize2(M, n); + var isStillMoving = true; + var iterations = 0; + while (isStillMoving && iterations < opts.maxIterations) { + isStillMoving = false; + _M = expand(M, n, opts.expandFactor); + M = inflate(_M, n, opts.inflateFactor); + if (!hasConverged(M, _M, n2, 4)) { + isStillMoving = true; + } + iterations++; + } + var clusters = assign$2(M, n, nodes2, cy); + clusters = removeDuplicates(clusters); + return clusters; + }; + var markovClustering$1 = { + markovClustering, + mcl: markovClustering + }; + var identity2 = function identity3(x2) { + return x2; + }; + var absDiff = function absDiff2(p2, q) { + return Math.abs(q - p2); + }; + var addAbsDiff = function addAbsDiff2(total, p2, q) { + return total + absDiff(p2, q); + }; + var addSquaredDiff = function addSquaredDiff2(total, p2, q) { + return total + Math.pow(q - p2, 2); + }; + var sqrt3 = function sqrt4(x2) { + return Math.sqrt(x2); + }; + var maxAbsDiff = function maxAbsDiff2(currentMax, p2, q) { + return Math.max(currentMax, absDiff(p2, q)); + }; + var getDistance = function getDistance2(length2, getP, getQ, init2, visit) { + var post = arguments.length > 5 && arguments[5] !== void 0 ? arguments[5] : identity2; + var ret = init2; + var p2, q; + for (var dim = 0; dim < length2; dim++) { + p2 = getP(dim); + q = getQ(dim); + ret = visit(ret, p2, q); + } + return post(ret); + }; + var distances = { + euclidean: function euclidean(length2, getP, getQ) { + if (length2 >= 2) { + return getDistance(length2, getP, getQ, 0, addSquaredDiff, sqrt3); + } else { + return getDistance(length2, getP, getQ, 0, addAbsDiff); + } + }, + squaredEuclidean: function squaredEuclidean(length2, getP, getQ) { + return getDistance(length2, getP, getQ, 0, addSquaredDiff); + }, + manhattan: function manhattan(length2, getP, getQ) { + return getDistance(length2, getP, getQ, 0, addAbsDiff); + }, + max: function max3(length2, getP, getQ) { + return getDistance(length2, getP, getQ, -Infinity, maxAbsDiff); + } + }; + distances["squared-euclidean"] = distances["squaredEuclidean"]; + distances["squaredeuclidean"] = distances["squaredEuclidean"]; + function clusteringDistance(method, length2, getP, getQ, nodeP, nodeQ) { + var impl2; + if (fn$6(method)) { + impl2 = method; + } else { + impl2 = distances[method] || distances.euclidean; + } + if (length2 === 0 && fn$6(method)) { + return impl2(nodeP, nodeQ); + } else { + return impl2(length2, getP, getQ, nodeP, nodeQ); + } + } + var defaults$b = defaults$g({ + k: 2, + m: 2, + sensitivityThreshold: 1e-4, + distance: "euclidean", + maxIterations: 10, + attributes: [], + testMode: false, + testCentroids: null + }); + var setOptions$2 = function setOptions3(options2) { + return defaults$b(options2); + }; + var getDist = function getDist2(type2, node2, centroid, attributes, mode) { + var noNodeP = mode !== "kMedoids"; + var getP = noNodeP ? function(i3) { + return centroid[i3]; + } : function(i3) { + return attributes[i3](centroid); + }; + var getQ = function getQ2(i3) { + return attributes[i3](node2); + }; + var nodeP = centroid; + var nodeQ = node2; + return clusteringDistance(type2, attributes.length, getP, getQ, nodeP, nodeQ); + }; + var randomCentroids = function randomCentroids2(nodes2, k, attributes) { + var ndim = attributes.length; + var min3 = new Array(ndim); + var max3 = new Array(ndim); + var centroids = new Array(k); + var centroid = null; + for (var i3 = 0; i3 < ndim; i3++) { + min3[i3] = nodes2.min(attributes[i3]).value; + max3[i3] = nodes2.max(attributes[i3]).value; + } + for (var c2 = 0; c2 < k; c2++) { + centroid = []; + for (var _i6 = 0; _i6 < ndim; _i6++) { + centroid[_i6] = Math.random() * (max3[_i6] - min3[_i6]) + min3[_i6]; + } + centroids[c2] = centroid; + } + return centroids; + }; + var classify = function classify2(node2, centroids, distance2, attributes, type2) { + var min3 = Infinity; + var index2 = 0; + for (var i3 = 0; i3 < centroids.length; i3++) { + var dist3 = getDist(distance2, node2, centroids[i3], attributes, type2); + if (dist3 < min3) { + min3 = dist3; + index2 = i3; + } + } + return index2; + }; + var buildCluster = function buildCluster2(centroid, nodes2, assignment) { + var cluster = []; + var node2 = null; + for (var n = 0; n < nodes2.length; n++) { + node2 = nodes2[n]; + if (assignment[node2.id()] === centroid) { + cluster.push(node2); + } + } + return cluster; + }; + var haveValuesConverged = function haveValuesConverged2(v1, v2, sensitivityThreshold) { + return Math.abs(v2 - v1) <= sensitivityThreshold; + }; + var haveMatricesConverged = function haveMatricesConverged2(v1, v2, sensitivityThreshold) { + for (var i3 = 0; i3 < v1.length; i3++) { + for (var j = 0; j < v1[i3].length; j++) { + var diff = Math.abs(v1[i3][j] - v2[i3][j]); + if (diff > sensitivityThreshold) { + return false; + } + } + } + return true; + }; + var seenBefore = function seenBefore2(node2, medoids, n) { + for (var i3 = 0; i3 < n; i3++) { + if (node2 === medoids[i3]) + return true; + } + return false; + }; + var randomMedoids = function randomMedoids2(nodes2, k) { + var medoids = new Array(k); + if (nodes2.length < 50) { + for (var i3 = 0; i3 < k; i3++) { + var node2 = nodes2[Math.floor(Math.random() * nodes2.length)]; + while (seenBefore(node2, medoids, i3)) { + node2 = nodes2[Math.floor(Math.random() * nodes2.length)]; + } + medoids[i3] = node2; + } + } else { + for (var _i22 = 0; _i22 < k; _i22++) { + medoids[_i22] = nodes2[Math.floor(Math.random() * nodes2.length)]; + } + } + return medoids; + }; + var findCost = function findCost2(potentialNewMedoid, cluster, attributes) { + var cost = 0; + for (var n = 0; n < cluster.length; n++) { + cost += getDist("manhattan", cluster[n], potentialNewMedoid, attributes, "kMedoids"); + } + return cost; + }; + var kMeans = function kMeans2(options2) { + var cy = this.cy(); + var nodes2 = this.nodes(); + var node2 = null; + var opts = setOptions$2(options2); + var clusters = new Array(opts.k); + var assignment = {}; + var centroids; + if (opts.testMode) { + if (typeof opts.testCentroids === "number") { + opts.testCentroids; + centroids = randomCentroids(nodes2, opts.k, opts.attributes); + } else if (_typeof(opts.testCentroids) === "object") { + centroids = opts.testCentroids; + } else { + centroids = randomCentroids(nodes2, opts.k, opts.attributes); + } + } else { + centroids = randomCentroids(nodes2, opts.k, opts.attributes); + } + var isStillMoving = true; + var iterations = 0; + while (isStillMoving && iterations < opts.maxIterations) { + for (var n = 0; n < nodes2.length; n++) { + node2 = nodes2[n]; + assignment[node2.id()] = classify(node2, centroids, opts.distance, opts.attributes, "kMeans"); + } + isStillMoving = false; + for (var c2 = 0; c2 < opts.k; c2++) { + var cluster = buildCluster(c2, nodes2, assignment); + if (cluster.length === 0) { + continue; + } + var ndim = opts.attributes.length; + var centroid = centroids[c2]; + var newCentroid = new Array(ndim); + var sum2 = new Array(ndim); + for (var d = 0; d < ndim; d++) { + sum2[d] = 0; + for (var i3 = 0; i3 < cluster.length; i3++) { + node2 = cluster[i3]; + sum2[d] += opts.attributes[d](node2); + } + newCentroid[d] = sum2[d] / cluster.length; + if (!haveValuesConverged(newCentroid[d], centroid[d], opts.sensitivityThreshold)) { + isStillMoving = true; + } + } + centroids[c2] = newCentroid; + clusters[c2] = cy.collection(cluster); + } + iterations++; + } + return clusters; + }; + var kMedoids = function kMedoids2(options2) { + var cy = this.cy(); + var nodes2 = this.nodes(); + var node2 = null; + var opts = setOptions$2(options2); + var clusters = new Array(opts.k); + var medoids; + var assignment = {}; + var curCost; + var minCosts = new Array(opts.k); + if (opts.testMode) { + if (typeof opts.testCentroids === "number") + ; + else if (_typeof(opts.testCentroids) === "object") { + medoids = opts.testCentroids; + } else { + medoids = randomMedoids(nodes2, opts.k); + } + } else { + medoids = randomMedoids(nodes2, opts.k); + } + var isStillMoving = true; + var iterations = 0; + while (isStillMoving && iterations < opts.maxIterations) { + for (var n = 0; n < nodes2.length; n++) { + node2 = nodes2[n]; + assignment[node2.id()] = classify(node2, medoids, opts.distance, opts.attributes, "kMedoids"); + } + isStillMoving = false; + for (var m = 0; m < medoids.length; m++) { + var cluster = buildCluster(m, nodes2, assignment); + if (cluster.length === 0) { + continue; + } + minCosts[m] = findCost(medoids[m], cluster, opts.attributes); + for (var _n = 0; _n < cluster.length; _n++) { + curCost = findCost(cluster[_n], cluster, opts.attributes); + if (curCost < minCosts[m]) { + minCosts[m] = curCost; + medoids[m] = cluster[_n]; + isStillMoving = true; + } + } + clusters[m] = cy.collection(cluster); + } + iterations++; + } + return clusters; + }; + var updateCentroids = function updateCentroids2(centroids, nodes2, U, weight, opts) { + var numerator, denominator; + for (var n = 0; n < nodes2.length; n++) { + for (var c2 = 0; c2 < centroids.length; c2++) { + weight[n][c2] = Math.pow(U[n][c2], opts.m); + } + } + for (var _c = 0; _c < centroids.length; _c++) { + for (var dim = 0; dim < opts.attributes.length; dim++) { + numerator = 0; + denominator = 0; + for (var _n2 = 0; _n2 < nodes2.length; _n2++) { + numerator += weight[_n2][_c] * opts.attributes[dim](nodes2[_n2]); + denominator += weight[_n2][_c]; + } + centroids[_c][dim] = numerator / denominator; + } + } + }; + var updateMembership = function updateMembership2(U, _U, centroids, nodes2, opts) { + for (var i3 = 0; i3 < U.length; i3++) { + _U[i3] = U[i3].slice(); + } + var sum2, numerator, denominator; + var pow = 2 / (opts.m - 1); + for (var c2 = 0; c2 < centroids.length; c2++) { + for (var n = 0; n < nodes2.length; n++) { + sum2 = 0; + for (var k = 0; k < centroids.length; k++) { + numerator = getDist(opts.distance, nodes2[n], centroids[c2], opts.attributes, "cmeans"); + denominator = getDist(opts.distance, nodes2[n], centroids[k], opts.attributes, "cmeans"); + sum2 += Math.pow(numerator / denominator, pow); + } + U[n][c2] = 1 / sum2; + } + } + }; + var assign$1 = function assign2(nodes2, U, opts, cy) { + var clusters = new Array(opts.k); + for (var c2 = 0; c2 < clusters.length; c2++) { + clusters[c2] = []; + } + var max3; + var index2; + for (var n = 0; n < U.length; n++) { + max3 = -Infinity; + index2 = -1; + for (var _c2 = 0; _c2 < U[0].length; _c2++) { + if (U[n][_c2] > max3) { + max3 = U[n][_c2]; + index2 = _c2; + } + } + clusters[index2].push(nodes2[n]); + } + for (var _c3 = 0; _c3 < clusters.length; _c3++) { + clusters[_c3] = cy.collection(clusters[_c3]); + } + return clusters; + }; + var fuzzyCMeans = function fuzzyCMeans2(options2) { + var cy = this.cy(); + var nodes2 = this.nodes(); + var opts = setOptions$2(options2); + var clusters; + var centroids; + var U; + var _U; + var weight; + _U = new Array(nodes2.length); + for (var i3 = 0; i3 < nodes2.length; i3++) { + _U[i3] = new Array(opts.k); + } + U = new Array(nodes2.length); + for (var _i32 = 0; _i32 < nodes2.length; _i32++) { + U[_i32] = new Array(opts.k); + } + for (var _i42 = 0; _i42 < nodes2.length; _i42++) { + var total = 0; + for (var j = 0; j < opts.k; j++) { + U[_i42][j] = Math.random(); + total += U[_i42][j]; + } + for (var _j = 0; _j < opts.k; _j++) { + U[_i42][_j] = U[_i42][_j] / total; + } + } + centroids = new Array(opts.k); + for (var _i52 = 0; _i52 < opts.k; _i52++) { + centroids[_i52] = new Array(opts.attributes.length); + } + weight = new Array(nodes2.length); + for (var _i6 = 0; _i6 < nodes2.length; _i6++) { + weight[_i6] = new Array(opts.k); + } + var isStillMoving = true; + var iterations = 0; + while (isStillMoving && iterations < opts.maxIterations) { + isStillMoving = false; + updateCentroids(centroids, nodes2, U, weight, opts); + updateMembership(U, _U, centroids, nodes2, opts); + if (!haveMatricesConverged(U, _U, opts.sensitivityThreshold)) { + isStillMoving = true; + } + iterations++; + } + clusters = assign$1(nodes2, U, opts, cy); + return { + clusters, + degreeOfMembership: U + }; + }; + var kClustering = { + kMeans, + kMedoids, + fuzzyCMeans, + fcm: fuzzyCMeans + }; + var defaults$a = defaults$g({ + distance: "euclidean", + // distance metric to compare nodes + linkage: "min", + // linkage criterion : how to determine the distance between clusters of nodes + mode: "threshold", + // mode:'threshold' => clusters must be threshold distance apart + threshold: Infinity, + // the distance threshold + // mode:'dendrogram' => the nodes are organised as leaves in a tree (siblings are close), merging makes clusters + addDendrogram: false, + // whether to add the dendrogram to the graph for viz + dendrogramDepth: 0, + // depth at which dendrogram branches are merged into the returned clusters + attributes: [] + // array of attr functions + }); + var linkageAliases = { + "single": "min", + "complete": "max" + }; + var setOptions$1 = function setOptions3(options2) { + var opts = defaults$a(options2); + var preferredAlias = linkageAliases[opts.linkage]; + if (preferredAlias != null) { + opts.linkage = preferredAlias; + } + return opts; + }; + var mergeClosest = function mergeClosest2(clusters, index2, dists, mins, opts) { + var minKey = 0; + var min3 = Infinity; + var dist3; + var attrs = opts.attributes; + var getDist2 = function getDist3(n1, n2) { + return clusteringDistance(opts.distance, attrs.length, function(i4) { + return attrs[i4](n1); + }, function(i4) { + return attrs[i4](n2); + }, n1, n2); + }; + for (var i3 = 0; i3 < clusters.length; i3++) { + var key = clusters[i3].key; + var _dist = dists[key][mins[key]]; + if (_dist < min3) { + minKey = key; + min3 = _dist; + } + } + if (opts.mode === "threshold" && min3 >= opts.threshold || opts.mode === "dendrogram" && clusters.length === 1) { + return false; + } + var c1 = index2[minKey]; + var c2 = index2[mins[minKey]]; + var merged; + if (opts.mode === "dendrogram") { + merged = { + left: c1, + right: c2, + key: c1.key + }; + } else { + merged = { + value: c1.value.concat(c2.value), + key: c1.key + }; + } + clusters[c1.index] = merged; + clusters.splice(c2.index, 1); + index2[c1.key] = merged; + for (var _i6 = 0; _i6 < clusters.length; _i6++) { + var cur = clusters[_i6]; + if (c1.key === cur.key) { + dist3 = Infinity; + } else if (opts.linkage === "min") { + dist3 = dists[c1.key][cur.key]; + if (dists[c1.key][cur.key] > dists[c2.key][cur.key]) { + dist3 = dists[c2.key][cur.key]; + } + } else if (opts.linkage === "max") { + dist3 = dists[c1.key][cur.key]; + if (dists[c1.key][cur.key] < dists[c2.key][cur.key]) { + dist3 = dists[c2.key][cur.key]; + } + } else if (opts.linkage === "mean") { + dist3 = (dists[c1.key][cur.key] * c1.size + dists[c2.key][cur.key] * c2.size) / (c1.size + c2.size); + } else { + if (opts.mode === "dendrogram") + dist3 = getDist2(cur.value, c1.value); + else + dist3 = getDist2(cur.value[0], c1.value[0]); + } + dists[c1.key][cur.key] = dists[cur.key][c1.key] = dist3; + } + for (var _i22 = 0; _i22 < clusters.length; _i22++) { + var key1 = clusters[_i22].key; + if (mins[key1] === c1.key || mins[key1] === c2.key) { + var _min = key1; + for (var j = 0; j < clusters.length; j++) { + var key2 = clusters[j].key; + if (dists[key1][key2] < dists[key1][_min]) { + _min = key2; + } + } + mins[key1] = _min; + } + clusters[_i22].index = _i22; + } + c1.key = c2.key = c1.index = c2.index = null; + return true; + }; + var getAllChildren = function getAllChildren2(root3, arr, cy) { + if (!root3) + return; + if (root3.value) { + arr.push(root3.value); + } else { + if (root3.left) + getAllChildren2(root3.left, arr); + if (root3.right) + getAllChildren2(root3.right, arr); + } + }; + var buildDendrogram = function buildDendrogram2(root3, cy) { + if (!root3) + return ""; + if (root3.left && root3.right) { + var leftStr = buildDendrogram2(root3.left, cy); + var rightStr = buildDendrogram2(root3.right, cy); + var node2 = cy.add({ + group: "nodes", + data: { + id: leftStr + "," + rightStr + } + }); + cy.add({ + group: "edges", + data: { + source: leftStr, + target: node2.id() + } + }); + cy.add({ + group: "edges", + data: { + source: rightStr, + target: node2.id() + } + }); + return node2.id(); + } else if (root3.value) { + return root3.value.id(); + } + }; + var buildClustersFromTree = function buildClustersFromTree2(root3, k, cy) { + if (!root3) + return []; + var left2 = [], right2 = [], leaves = []; + if (k === 0) { + if (root3.left) + getAllChildren(root3.left, left2); + if (root3.right) + getAllChildren(root3.right, right2); + leaves = left2.concat(right2); + return [cy.collection(leaves)]; + } else if (k === 1) { + if (root3.value) { + return [cy.collection(root3.value)]; + } else { + if (root3.left) + getAllChildren(root3.left, left2); + if (root3.right) + getAllChildren(root3.right, right2); + return [cy.collection(left2), cy.collection(right2)]; + } + } else { + if (root3.value) { + return [cy.collection(root3.value)]; + } else { + if (root3.left) + left2 = buildClustersFromTree2(root3.left, k - 1, cy); + if (root3.right) + right2 = buildClustersFromTree2(root3.right, k - 1, cy); + return left2.concat(right2); + } + } + }; + var hierarchicalClustering = function hierarchicalClustering2(options2) { + var cy = this.cy(); + var nodes2 = this.nodes(); + var opts = setOptions$1(options2); + var attrs = opts.attributes; + var getDist2 = function getDist3(n1, n2) { + return clusteringDistance(opts.distance, attrs.length, function(i4) { + return attrs[i4](n1); + }, function(i4) { + return attrs[i4](n2); + }, n1, n2); + }; + var clusters = []; + var dists = []; + var mins = []; + var index2 = []; + for (var n = 0; n < nodes2.length; n++) { + var cluster = { + value: opts.mode === "dendrogram" ? nodes2[n] : [nodes2[n]], + key: n, + index: n + }; + clusters[n] = cluster; + index2[n] = cluster; + dists[n] = []; + mins[n] = 0; + } + for (var i3 = 0; i3 < clusters.length; i3++) { + for (var j = 0; j <= i3; j++) { + var dist3 = void 0; + if (opts.mode === "dendrogram") { + dist3 = i3 === j ? Infinity : getDist2(clusters[i3].value, clusters[j].value); + } else { + dist3 = i3 === j ? Infinity : getDist2(clusters[i3].value[0], clusters[j].value[0]); + } + dists[i3][j] = dist3; + dists[j][i3] = dist3; + if (dist3 < dists[i3][mins[i3]]) { + mins[i3] = j; + } + } + } + var merged = mergeClosest(clusters, index2, dists, mins, opts); + while (merged) { + merged = mergeClosest(clusters, index2, dists, mins, opts); + } + var retClusters; + if (opts.mode === "dendrogram") { + retClusters = buildClustersFromTree(clusters[0], opts.dendrogramDepth, cy); + if (opts.addDendrogram) + buildDendrogram(clusters[0], cy); + } else { + retClusters = new Array(clusters.length); + clusters.forEach(function(cluster2, i4) { + cluster2.key = cluster2.index = null; + retClusters[i4] = cy.collection(cluster2.value); + }); + } + return retClusters; + }; + var hierarchicalClustering$1 = { + hierarchicalClustering, + hca: hierarchicalClustering + }; + var defaults$9 = defaults$g({ + distance: "euclidean", + // distance metric to compare attributes between two nodes + preference: "median", + // suitability of a data point to serve as an exemplar + damping: 0.8, + // damping factor between [0.5, 1) + maxIterations: 1e3, + // max number of iterations to run + minIterations: 100, + // min number of iterations to run in order for clustering to stop + attributes: [ + // functions to quantify the similarity between any two points + // e.g. node => node.data('weight') + ] + }); + var setOptions2 = function setOptions3(options2) { + var dmp = options2.damping; + var pref = options2.preference; + if (!(0.5 <= dmp && dmp < 1)) { + error("Damping must range on [0.5, 1). Got: ".concat(dmp)); + } + var validPrefs = ["median", "mean", "min", "max"]; + if (!(validPrefs.some(function(v) { + return v === pref; + }) || number$12(pref))) { + error("Preference must be one of [".concat(validPrefs.map(function(p2) { + return "'".concat(p2, "'"); + }).join(", "), "] or a number. Got: ").concat(pref)); + } + return defaults$9(options2); + }; + var getSimilarity = function getSimilarity2(type2, n1, n2, attributes) { + var attr = function attr2(n, i3) { + return attributes[i3](n); + }; + return -clusteringDistance(type2, attributes.length, function(i3) { + return attr(n1, i3); + }, function(i3) { + return attr(n2, i3); + }, n1, n2); + }; + var getPreference = function getPreference2(S2, preference) { + var p2 = null; + if (preference === "median") { + p2 = median(S2); + } else if (preference === "mean") { + p2 = mean(S2); + } else if (preference === "min") { + p2 = min2(S2); + } else if (preference === "max") { + p2 = max2(S2); + } else { + p2 = preference; + } + return p2; + }; + var findExemplars = function findExemplars2(n, R, A) { + var indices = []; + for (var i3 = 0; i3 < n; i3++) { + if (R[i3 * n + i3] + A[i3 * n + i3] > 0) { + indices.push(i3); + } + } + return indices; + }; + var assignClusters = function assignClusters2(n, S2, exemplars) { + var clusters = []; + for (var i3 = 0; i3 < n; i3++) { + var index2 = -1; + var max3 = -Infinity; + for (var ei = 0; ei < exemplars.length; ei++) { + var e = exemplars[ei]; + if (S2[i3 * n + e] > max3) { + index2 = e; + max3 = S2[i3 * n + e]; + } + } + if (index2 > 0) { + clusters.push(index2); + } + } + for (var _ei = 0; _ei < exemplars.length; _ei++) { + clusters[exemplars[_ei]] = exemplars[_ei]; + } + return clusters; + }; + var assign = function assign2(n, S2, exemplars) { + var clusters = assignClusters(n, S2, exemplars); + for (var ei = 0; ei < exemplars.length; ei++) { + var ii = []; + for (var c2 = 0; c2 < clusters.length; c2++) { + if (clusters[c2] === exemplars[ei]) { + ii.push(c2); + } + } + var maxI = -1; + var maxSum = -Infinity; + for (var i3 = 0; i3 < ii.length; i3++) { + var sum2 = 0; + for (var j = 0; j < ii.length; j++) { + sum2 += S2[ii[j] * n + ii[i3]]; + } + if (sum2 > maxSum) { + maxI = i3; + maxSum = sum2; + } + } + exemplars[ei] = ii[maxI]; + } + clusters = assignClusters(n, S2, exemplars); + return clusters; + }; + var affinityPropagation = function affinityPropagation2(options2) { + var cy = this.cy(); + var nodes2 = this.nodes(); + var opts = setOptions2(options2); + var id2position = {}; + for (var i3 = 0; i3 < nodes2.length; i3++) { + id2position[nodes2[i3].id()] = i3; + } + var n; + var n2; + var S2; + var p2; + var R; + var A; + n = nodes2.length; + n2 = n * n; + S2 = new Array(n2); + for (var _i6 = 0; _i6 < n2; _i6++) { + S2[_i6] = -Infinity; + } + for (var _i22 = 0; _i22 < n; _i22++) { + for (var j = 0; j < n; j++) { + if (_i22 !== j) { + S2[_i22 * n + j] = getSimilarity(opts.distance, nodes2[_i22], nodes2[j], opts.attributes); + } + } + } + p2 = getPreference(S2, opts.preference); + for (var _i32 = 0; _i32 < n; _i32++) { + S2[_i32 * n + _i32] = p2; + } + R = new Array(n2); + for (var _i42 = 0; _i42 < n2; _i42++) { + R[_i42] = 0; + } + A = new Array(n2); + for (var _i52 = 0; _i52 < n2; _i52++) { + A[_i52] = 0; + } + var old = new Array(n); + var Rp = new Array(n); + var se = new Array(n); + for (var _i62 = 0; _i62 < n; _i62++) { + old[_i62] = 0; + Rp[_i62] = 0; + se[_i62] = 0; + } + var e = new Array(n * opts.minIterations); + for (var _i7 = 0; _i7 < e.length; _i7++) { + e[_i7] = 0; + } + var iter; + for (iter = 0; iter < opts.maxIterations; iter++) { + for (var _i8 = 0; _i8 < n; _i8++) { + var max3 = -Infinity, max22 = -Infinity, maxI = -1, AS = 0; + for (var _j = 0; _j < n; _j++) { + old[_j] = R[_i8 * n + _j]; + AS = A[_i8 * n + _j] + S2[_i8 * n + _j]; + if (AS >= max3) { + max22 = max3; + max3 = AS; + maxI = _j; + } else if (AS > max22) { + max22 = AS; + } + } + for (var _j2 = 0; _j2 < n; _j2++) { + R[_i8 * n + _j2] = (1 - opts.damping) * (S2[_i8 * n + _j2] - max3) + opts.damping * old[_j2]; + } + R[_i8 * n + maxI] = (1 - opts.damping) * (S2[_i8 * n + maxI] - max22) + opts.damping * old[maxI]; + } + for (var _i9 = 0; _i9 < n; _i9++) { + var sum2 = 0; + for (var _j3 = 0; _j3 < n; _j3++) { + old[_j3] = A[_j3 * n + _i9]; + Rp[_j3] = Math.max(0, R[_j3 * n + _i9]); + sum2 += Rp[_j3]; + } + sum2 -= Rp[_i9]; + Rp[_i9] = R[_i9 * n + _i9]; + sum2 += Rp[_i9]; + for (var _j4 = 0; _j4 < n; _j4++) { + A[_j4 * n + _i9] = (1 - opts.damping) * Math.min(0, sum2 - Rp[_j4]) + opts.damping * old[_j4]; + } + A[_i9 * n + _i9] = (1 - opts.damping) * (sum2 - Rp[_i9]) + opts.damping * old[_i9]; + } + var K3 = 0; + for (var _i10 = 0; _i10 < n; _i10++) { + var E = A[_i10 * n + _i10] + R[_i10 * n + _i10] > 0 ? 1 : 0; + e[iter % opts.minIterations * n + _i10] = E; + K3 += E; + } + if (K3 > 0 && (iter >= opts.minIterations - 1 || iter == opts.maxIterations - 1)) { + var _sum = 0; + for (var _i11 = 0; _i11 < n; _i11++) { + se[_i11] = 0; + for (var _j5 = 0; _j5 < opts.minIterations; _j5++) { + se[_i11] += e[_j5 * n + _i11]; + } + if (se[_i11] === 0 || se[_i11] === opts.minIterations) { + _sum++; + } + } + if (_sum === n) { + break; + } + } + } + var exemplarsIndices = findExemplars(n, R, A); + var clusterIndices = assign(n, S2, exemplarsIndices); + var clusters = {}; + for (var c2 = 0; c2 < exemplarsIndices.length; c2++) { + clusters[exemplarsIndices[c2]] = []; + } + for (var _i12 = 0; _i12 < nodes2.length; _i12++) { + var pos = id2position[nodes2[_i12].id()]; + var clusterIndex = clusterIndices[pos]; + if (clusterIndex != null) { + clusters[clusterIndex].push(nodes2[_i12]); + } + } + var retClusters = new Array(exemplarsIndices.length); + for (var _c = 0; _c < exemplarsIndices.length; _c++) { + retClusters[_c] = cy.collection(clusters[exemplarsIndices[_c]]); + } + return retClusters; + }; + var affinityPropagation$1 = { + affinityPropagation, + ap: affinityPropagation + }; + var hierholzerDefaults = defaults$g({ + root: void 0, + directed: false + }); + var elesfn$k = { + hierholzer: function hierholzer(options2) { + if (!plainObject(options2)) { + var args = arguments; + options2 = { + root: args[0], + directed: args[1] + }; + } + var _hierholzerDefaults = hierholzerDefaults(options2), root3 = _hierholzerDefaults.root, directed = _hierholzerDefaults.directed; + var eles = this; + var dflag = false; + var oddIn; + var oddOut; + var startVertex; + if (root3) + startVertex = string2(root3) ? this.filter(root3)[0].id() : root3[0].id(); + var nodes2 = {}; + var edges2 = {}; + if (directed) { + eles.forEach(function(ele) { + var id2 = ele.id(); + if (ele.isNode()) { + var ind = ele.indegree(true); + var outd = ele.outdegree(true); + var d1 = ind - outd; + var d2 = outd - ind; + if (d1 == 1) { + if (oddIn) + dflag = true; + else + oddIn = id2; + } else if (d2 == 1) { + if (oddOut) + dflag = true; + else + oddOut = id2; + } else if (d2 > 1 || d1 > 1) { + dflag = true; + } + nodes2[id2] = []; + ele.outgoers().forEach(function(e) { + if (e.isEdge()) + nodes2[id2].push(e.id()); + }); + } else { + edges2[id2] = [void 0, ele.target().id()]; + } + }); + } else { + eles.forEach(function(ele) { + var id2 = ele.id(); + if (ele.isNode()) { + var d2 = ele.degree(true); + if (d2 % 2) { + if (!oddIn) + oddIn = id2; + else if (!oddOut) + oddOut = id2; + else + dflag = true; + } + nodes2[id2] = []; + ele.connectedEdges().forEach(function(e) { + return nodes2[id2].push(e.id()); + }); + } else { + edges2[id2] = [ele.source().id(), ele.target().id()]; + } + }); + } + var result = { + found: false, + trail: void 0 + }; + if (dflag) + return result; + else if (oddOut && oddIn) { + if (directed) { + if (startVertex && oddOut != startVertex) { + return result; + } + startVertex = oddOut; + } else { + if (startVertex && oddOut != startVertex && oddIn != startVertex) { + return result; + } else if (!startVertex) { + startVertex = oddOut; + } + } + } else { + if (!startVertex) + startVertex = eles[0].id(); + } + var walk = function walk2(v) { + var currentNode = v; + var subtour2 = [v]; + var adj, adjTail, adjHead; + while (nodes2[currentNode].length) { + adj = nodes2[currentNode].shift(); + adjTail = edges2[adj][0]; + adjHead = edges2[adj][1]; + if (currentNode != adjHead) { + nodes2[adjHead] = nodes2[adjHead].filter(function(e) { + return e != adj; + }); + currentNode = adjHead; + } else if (!directed && currentNode != adjTail) { + nodes2[adjTail] = nodes2[adjTail].filter(function(e) { + return e != adj; + }); + currentNode = adjTail; + } + subtour2.unshift(adj); + subtour2.unshift(currentNode); + } + return subtour2; + }; + var trail = []; + var subtour = []; + subtour = walk(startVertex); + while (subtour.length != 1) { + if (nodes2[subtour[0]].length == 0) { + trail.unshift(eles.getElementById(subtour.shift())); + trail.unshift(eles.getElementById(subtour.shift())); + } else { + subtour = walk(subtour.shift()).concat(subtour); + } + } + trail.unshift(eles.getElementById(subtour.shift())); + for (var d in nodes2) { + if (nodes2[d].length) { + return result; + } + } + result.found = true; + result.trail = this.spawn(trail, true); + return result; + } + }; + var hopcroftTarjanBiconnected = function hopcroftTarjanBiconnected2() { + var eles = this; + var nodes2 = {}; + var id2 = 0; + var edgeCount2 = 0; + var components = []; + var stack = []; + var visitedEdges = {}; + var buildComponent = function buildComponent2(x2, y2) { + var i3 = stack.length - 1; + var cutset = []; + var component = eles.spawn(); + while (stack[i3].x != x2 || stack[i3].y != y2) { + cutset.push(stack.pop().edge); + i3--; + } + cutset.push(stack.pop().edge); + cutset.forEach(function(edge) { + var connectedNodes = edge.connectedNodes().intersection(eles); + component.merge(edge); + connectedNodes.forEach(function(node2) { + var nodeId = node2.id(); + var connectedEdges = node2.connectedEdges().intersection(eles); + component.merge(node2); + if (!nodes2[nodeId].cutVertex) { + component.merge(connectedEdges); + } else { + component.merge(connectedEdges.filter(function(edge2) { + return edge2.isLoop(); + })); + } + }); + }); + components.push(component); + }; + var biconnectedSearch = function biconnectedSearch2(root3, currentNode, parent) { + if (root3 === parent) + edgeCount2 += 1; + nodes2[currentNode] = { + id: id2, + low: id2++, + cutVertex: false + }; + var edges2 = eles.getElementById(currentNode).connectedEdges().intersection(eles); + if (edges2.size() === 0) { + components.push(eles.spawn(eles.getElementById(currentNode))); + } else { + var sourceId, targetId, otherNodeId, edgeId; + edges2.forEach(function(edge) { + sourceId = edge.source().id(); + targetId = edge.target().id(); + otherNodeId = sourceId === currentNode ? targetId : sourceId; + if (otherNodeId !== parent) { + edgeId = edge.id(); + if (!visitedEdges[edgeId]) { + visitedEdges[edgeId] = true; + stack.push({ + x: currentNode, + y: otherNodeId, + edge + }); + } + if (!(otherNodeId in nodes2)) { + biconnectedSearch2(root3, otherNodeId, currentNode); + nodes2[currentNode].low = Math.min(nodes2[currentNode].low, nodes2[otherNodeId].low); + if (nodes2[currentNode].id <= nodes2[otherNodeId].low) { + nodes2[currentNode].cutVertex = true; + buildComponent(currentNode, otherNodeId); + } + } else { + nodes2[currentNode].low = Math.min(nodes2[currentNode].low, nodes2[otherNodeId].id); + } + } + }); + } + }; + eles.forEach(function(ele) { + if (ele.isNode()) { + var nodeId = ele.id(); + if (!(nodeId in nodes2)) { + edgeCount2 = 0; + biconnectedSearch(nodeId, nodeId); + nodes2[nodeId].cutVertex = edgeCount2 > 1; + } + } + }); + var cutVertices = Object.keys(nodes2).filter(function(id3) { + return nodes2[id3].cutVertex; + }).map(function(id3) { + return eles.getElementById(id3); + }); + return { + cut: eles.spawn(cutVertices), + components + }; + }; + var hopcroftTarjanBiconnected$1 = { + hopcroftTarjanBiconnected, + htbc: hopcroftTarjanBiconnected, + htb: hopcroftTarjanBiconnected, + hopcroftTarjanBiconnectedComponents: hopcroftTarjanBiconnected + }; + var tarjanStronglyConnected = function tarjanStronglyConnected2() { + var eles = this; + var nodes2 = {}; + var index2 = 0; + var components = []; + var stack = []; + var cut = eles.spawn(eles); + var stronglyConnectedSearch = function stronglyConnectedSearch2(sourceNodeId) { + stack.push(sourceNodeId); + nodes2[sourceNodeId] = { + index: index2, + low: index2++, + explored: false + }; + var connectedEdges = eles.getElementById(sourceNodeId).connectedEdges().intersection(eles); + connectedEdges.forEach(function(edge) { + var targetNodeId = edge.target().id(); + if (targetNodeId !== sourceNodeId) { + if (!(targetNodeId in nodes2)) { + stronglyConnectedSearch2(targetNodeId); + } + if (!nodes2[targetNodeId].explored) { + nodes2[sourceNodeId].low = Math.min(nodes2[sourceNodeId].low, nodes2[targetNodeId].low); + } + } + }); + if (nodes2[sourceNodeId].index === nodes2[sourceNodeId].low) { + var componentNodes = eles.spawn(); + for (; ; ) { + var nodeId = stack.pop(); + componentNodes.merge(eles.getElementById(nodeId)); + nodes2[nodeId].low = nodes2[sourceNodeId].index; + nodes2[nodeId].explored = true; + if (nodeId === sourceNodeId) { + break; + } + } + var componentEdges = componentNodes.edgesWith(componentNodes); + var component = componentNodes.merge(componentEdges); + components.push(component); + cut = cut.difference(component); + } + }; + eles.forEach(function(ele) { + if (ele.isNode()) { + var nodeId = ele.id(); + if (!(nodeId in nodes2)) { + stronglyConnectedSearch(nodeId); + } + } + }); + return { + cut, + components + }; + }; + var tarjanStronglyConnected$1 = { + tarjanStronglyConnected, + tsc: tarjanStronglyConnected, + tscc: tarjanStronglyConnected, + tarjanStronglyConnectedComponents: tarjanStronglyConnected + }; + var elesfn$j = {}; + [elesfn$v, elesfn$u, elesfn$t, elesfn$s, elesfn$r, elesfn$q, elesfn$p, elesfn$o, elesfn$n, elesfn$m, elesfn$l, markovClustering$1, kClustering, hierarchicalClustering$1, affinityPropagation$1, elesfn$k, hopcroftTarjanBiconnected$1, tarjanStronglyConnected$1].forEach(function(props) { + extend2(elesfn$j, props); + }); + /*! + Embeddable Minimum Strictly-Compliant Promises/A+ 1.1.1 Thenable + Copyright (c) 2013-2014 Ralf S. Engelschall (http://engelschall.com) + Licensed under The MIT License (http://opensource.org/licenses/MIT) + */ + var STATE_PENDING = 0; + var STATE_FULFILLED = 1; + var STATE_REJECTED = 2; + var api = function api2(executor) { + if (!(this instanceof api2)) + return new api2(executor); + this.id = "Thenable/1.0.7"; + this.state = STATE_PENDING; + this.fulfillValue = void 0; + this.rejectReason = void 0; + this.onFulfilled = []; + this.onRejected = []; + this.proxy = { + then: this.then.bind(this) + }; + if (typeof executor === "function") + executor.call(this, this.fulfill.bind(this), this.reject.bind(this)); + }; + api.prototype = { + /* promise resolving methods */ + fulfill: function fulfill(value2) { + return deliver(this, STATE_FULFILLED, "fulfillValue", value2); + }, + reject: function reject(value2) { + return deliver(this, STATE_REJECTED, "rejectReason", value2); + }, + /* "The then Method" [Promises/A+ 1.1, 1.2, 2.2] */ + then: function then(onFulfilled, onRejected) { + var curr = this; + var next2 = new api(); + curr.onFulfilled.push(resolver2(onFulfilled, next2, "fulfill")); + curr.onRejected.push(resolver2(onRejected, next2, "reject")); + execute(curr); + return next2.proxy; + } + }; + var deliver = function deliver2(curr, state2, name, value2) { + if (curr.state === STATE_PENDING) { + curr.state = state2; + curr[name] = value2; + execute(curr); + } + return curr; + }; + var execute = function execute2(curr) { + if (curr.state === STATE_FULFILLED) + execute_handlers(curr, "onFulfilled", curr.fulfillValue); + else if (curr.state === STATE_REJECTED) + execute_handlers(curr, "onRejected", curr.rejectReason); + }; + var execute_handlers = function execute_handlers2(curr, name, value2) { + if (curr[name].length === 0) + return; + var handlers = curr[name]; + curr[name] = []; + var func = function func2() { + for (var i3 = 0; i3 < handlers.length; i3++) { + handlers[i3](value2); + } + }; + if (typeof setImmediate === "function") + setImmediate(func); + else + setTimeout(func, 0); + }; + var resolver2 = function resolver3(cb, next2, method) { + return function(value2) { + if (typeof cb !== "function") + next2[method].call(next2, value2); + else { + var result; + try { + result = cb(value2); + } catch (e) { + next2.reject(e); + return; + } + resolve(next2, result); + } + }; + }; + var resolve = function resolve2(promise2, x2) { + if (promise2 === x2 || promise2.proxy === x2) { + promise2.reject(new TypeError("cannot resolve promise with itself")); + return; + } + var then; + if (_typeof(x2) === "object" && x2 !== null || typeof x2 === "function") { + try { + then = x2.then; + } catch (e) { + promise2.reject(e); + return; + } + } + if (typeof then === "function") { + var resolved = false; + try { + then.call( + x2, + /* resolvePromise */ + /* [Promises/A+ 2.3.3.3.1] */ + function(y2) { + if (resolved) + return; + resolved = true; + if (y2 === x2) + promise2.reject(new TypeError("circular thenable chain")); + else + resolve2(promise2, y2); + }, + /* rejectPromise */ + /* [Promises/A+ 2.3.3.3.2] */ + function(r) { + if (resolved) + return; + resolved = true; + promise2.reject(r); + } + ); + } catch (e) { + if (!resolved) + promise2.reject(e); + } + return; + } + promise2.fulfill(x2); + }; + api.all = function(ps) { + return new api(function(resolveAll2, rejectAll) { + var vals = new Array(ps.length); + var doneCount = 0; + var fulfill = function fulfill2(i4, val) { + vals[i4] = val; + doneCount++; + if (doneCount === ps.length) { + resolveAll2(vals); + } + }; + for (var i3 = 0; i3 < ps.length; i3++) { + (function(i4) { + var p2 = ps[i4]; + var isPromise = p2 != null && p2.then != null; + if (isPromise) { + p2.then(function(val2) { + fulfill(i4, val2); + }, function(err) { + rejectAll(err); + }); + } else { + var val = p2; + fulfill(i4, val); + } + })(i3); + } + }); + }; + api.resolve = function(val) { + return new api(function(resolve2, reject) { + resolve2(val); + }); + }; + api.reject = function(val) { + return new api(function(resolve2, reject) { + reject(val); + }); + }; + var Promise$12 = typeof Promise !== "undefined" ? Promise : api; + var Animation = function Animation2(target, opts, opts2) { + var isCore = core2(target); + var isEle = !isCore; + var _p = this._private = extend2({ + duration: 1e3 + }, opts, opts2); + _p.target = target; + _p.style = _p.style || _p.css; + _p.started = false; + _p.playing = false; + _p.hooked = false; + _p.applying = false; + _p.progress = 0; + _p.completes = []; + _p.frames = []; + if (_p.complete && fn$6(_p.complete)) { + _p.completes.push(_p.complete); + } + if (isEle) { + var pos = target.position(); + _p.startPosition = _p.startPosition || { + x: pos.x, + y: pos.y + }; + _p.startStyle = _p.startStyle || target.cy().style().getAnimationStartStyle(target, _p.style); + } + if (isCore) { + var pan = target.pan(); + _p.startPan = { + x: pan.x, + y: pan.y + }; + _p.startZoom = target.zoom(); + } + this.length = 1; + this[0] = this; + }; + var anifn = Animation.prototype; + extend2(anifn, { + instanceString: function instanceString() { + return "animation"; + }, + hook: function hook() { + var _p = this._private; + if (!_p.hooked) { + var q; + var tAni = _p.target._private.animation; + if (_p.queue) { + q = tAni.queue; + } else { + q = tAni.current; + } + q.push(this); + if (elementOrCollection(_p.target)) { + _p.target.cy().addToAnimationPool(_p.target); + } + _p.hooked = true; + } + return this; + }, + play: function play() { + var _p = this._private; + if (_p.progress === 1) { + _p.progress = 0; + } + _p.playing = true; + _p.started = false; + _p.stopped = false; + this.hook(); + return this; + }, + playing: function playing() { + return this._private.playing; + }, + apply: function apply2() { + var _p = this._private; + _p.applying = true; + _p.started = false; + _p.stopped = false; + this.hook(); + return this; + }, + applying: function applying() { + return this._private.applying; + }, + pause: function pause() { + var _p = this._private; + _p.playing = false; + _p.started = false; + return this; + }, + stop: function stop() { + var _p = this._private; + _p.playing = false; + _p.started = false; + _p.stopped = true; + return this; + }, + rewind: function rewind() { + return this.progress(0); + }, + fastforward: function fastforward() { + return this.progress(1); + }, + time: function time2(t) { + var _p = this._private; + if (t === void 0) { + return _p.progress * _p.duration; + } else { + return this.progress(t / _p.duration); + } + }, + progress: function progress(p2) { + var _p = this._private; + var wasPlaying = _p.playing; + if (p2 === void 0) { + return _p.progress; + } else { + if (wasPlaying) { + this.pause(); + } + _p.progress = p2; + _p.started = false; + if (wasPlaying) { + this.play(); + } + } + return this; + }, + completed: function completed() { + return this._private.progress === 1; + }, + reverse: function reverse() { + var _p = this._private; + var wasPlaying = _p.playing; + if (wasPlaying) { + this.pause(); + } + _p.progress = 1 - _p.progress; + _p.started = false; + var swap = function swap2(a, b) { + var _pa = _p[a]; + if (_pa == null) { + return; + } + _p[a] = _p[b]; + _p[b] = _pa; + }; + swap("zoom", "startZoom"); + swap("pan", "startPan"); + swap("position", "startPosition"); + if (_p.style) { + for (var i3 = 0; i3 < _p.style.length; i3++) { + var prop = _p.style[i3]; + var name = prop.name; + var startStyleProp = _p.startStyle[name]; + _p.startStyle[name] = prop; + _p.style[i3] = startStyleProp; + } + } + if (wasPlaying) { + this.play(); + } + return this; + }, + promise: function promise2(type2) { + var _p = this._private; + var arr; + switch (type2) { + case "frame": + arr = _p.frames; + break; + default: + case "complete": + case "completed": + arr = _p.completes; + } + return new Promise$12(function(resolve2, reject) { + arr.push(function() { + resolve2(); + }); + }); + } + }); + anifn.complete = anifn.completed; + anifn.run = anifn.play; + anifn.running = anifn.playing; + var define$3 = { + animated: function animated() { + return function animatedImpl() { + var self2 = this; + var selfIsArrayLike = self2.length !== void 0; + var all2 = selfIsArrayLike ? self2 : [self2]; + var cy = this._private.cy || this; + if (!cy.styleEnabled()) { + return false; + } + var ele = all2[0]; + if (ele) { + return ele._private.animation.current.length > 0; + } + }; + }, + // animated + clearQueue: function clearQueue() { + return function clearQueueImpl() { + var self2 = this; + var selfIsArrayLike = self2.length !== void 0; + var all2 = selfIsArrayLike ? self2 : [self2]; + var cy = this._private.cy || this; + if (!cy.styleEnabled()) { + return this; + } + for (var i3 = 0; i3 < all2.length; i3++) { + var ele = all2[i3]; + ele._private.animation.queue = []; + } + return this; + }; + }, + // clearQueue + delay: function delay() { + return function delayImpl(time2, complete) { + var cy = this._private.cy || this; + if (!cy.styleEnabled()) { + return this; + } + return this.animate({ + delay: time2, + duration: time2, + complete + }); + }; + }, + // delay + delayAnimation: function delayAnimation() { + return function delayAnimationImpl(time2, complete) { + var cy = this._private.cy || this; + if (!cy.styleEnabled()) { + return this; + } + return this.animation({ + delay: time2, + duration: time2, + complete + }); + }; + }, + // delay + animation: function animation() { + return function animationImpl(properties, params) { + var self2 = this; + var selfIsArrayLike = self2.length !== void 0; + var all2 = selfIsArrayLike ? self2 : [self2]; + var cy = this._private.cy || this; + var isCore = !selfIsArrayLike; + var isEles = !isCore; + if (!cy.styleEnabled()) { + return this; + } + var style = cy.style(); + properties = extend2({}, properties, params); + var propertiesEmpty = Object.keys(properties).length === 0; + if (propertiesEmpty) { + return new Animation(all2[0], properties); + } + if (properties.duration === void 0) { + properties.duration = 400; + } + switch (properties.duration) { + case "slow": + properties.duration = 600; + break; + case "fast": + properties.duration = 200; + break; + } + if (isEles) { + properties.style = style.getPropsList(properties.style || properties.css); + properties.css = void 0; + } + if (isEles && properties.renderedPosition != null) { + var rpos = properties.renderedPosition; + var pan = cy.pan(); + var zoom = cy.zoom(); + properties.position = renderedToModelPosition(rpos, zoom, pan); + } + if (isCore && properties.panBy != null) { + var panBy = properties.panBy; + var cyPan = cy.pan(); + properties.pan = { + x: cyPan.x + panBy.x, + y: cyPan.y + panBy.y + }; + } + var center2 = properties.center || properties.centre; + if (isCore && center2 != null) { + var centerPan = cy.getCenterPan(center2.eles, properties.zoom); + if (centerPan != null) { + properties.pan = centerPan; + } + } + if (isCore && properties.fit != null) { + var fit = properties.fit; + var fitVp = cy.getFitViewport(fit.eles || fit.boundingBox, fit.padding); + if (fitVp != null) { + properties.pan = fitVp.pan; + properties.zoom = fitVp.zoom; + } + } + if (isCore && plainObject(properties.zoom)) { + var vp = cy.getZoomedViewport(properties.zoom); + if (vp != null) { + if (vp.zoomed) { + properties.zoom = vp.zoom; + } + if (vp.panned) { + properties.pan = vp.pan; + } + } else { + properties.zoom = null; + } + } + return new Animation(all2[0], properties); + }; + }, + // animate + animate: function animate() { + return function animateImpl(properties, params) { + var self2 = this; + var selfIsArrayLike = self2.length !== void 0; + var all2 = selfIsArrayLike ? self2 : [self2]; + var cy = this._private.cy || this; + if (!cy.styleEnabled()) { + return this; + } + if (params) { + properties = extend2({}, properties, params); + } + for (var i3 = 0; i3 < all2.length; i3++) { + var ele = all2[i3]; + var queue = ele.animated() && (properties.queue === void 0 || properties.queue); + var ani = ele.animation(properties, queue ? { + queue: true + } : void 0); + ani.play(); + } + return this; + }; + }, + // animate + stop: function stop() { + return function stopImpl(clearQueue, jumpToEnd) { + var self2 = this; + var selfIsArrayLike = self2.length !== void 0; + var all2 = selfIsArrayLike ? self2 : [self2]; + var cy = this._private.cy || this; + if (!cy.styleEnabled()) { + return this; + } + for (var i3 = 0; i3 < all2.length; i3++) { + var ele = all2[i3]; + var _p = ele._private; + var anis = _p.animation.current; + for (var j = 0; j < anis.length; j++) { + var ani = anis[j]; + var ani_p = ani._private; + if (jumpToEnd) { + ani_p.duration = 0; + } + } + if (clearQueue) { + _p.animation.queue = []; + } + if (!jumpToEnd) { + _p.animation.current = []; + } + } + cy.notify("draw"); + return this; + }; + } + // stop + }; + var isArray2 = Array.isArray; + var isArray_1 = isArray2; + var reIsDeepProp2 = /\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/, reIsPlainProp2 = /^\w*$/; + function isKey2(value2, object3) { + if (isArray_1(value2)) { + return false; + } + var type2 = typeof value2; + if (type2 == "number" || type2 == "symbol" || type2 == "boolean" || value2 == null || isSymbol_1(value2)) { + return true; + } + return reIsPlainProp2.test(value2) || !reIsDeepProp2.test(value2) || object3 != null && value2 in Object(object3); + } + var _isKey = isKey2; + var asyncTag2 = "[object AsyncFunction]", funcTag2 = "[object Function]", genTag2 = "[object GeneratorFunction]", proxyTag2 = "[object Proxy]"; + function isFunction2(value2) { + if (!isObject_12(value2)) { + return false; + } + var tag = _baseGetTag(value2); + return tag == funcTag2 || tag == genTag2 || tag == asyncTag2 || tag == proxyTag2; + } + var isFunction_1 = isFunction2; + var coreJsData2 = _root["__core-js_shared__"]; + var _coreJsData = coreJsData2; + var maskSrcKey2 = function() { + var uid = /[^.]+$/.exec(_coreJsData && _coreJsData.keys && _coreJsData.keys.IE_PROTO || ""); + return uid ? "Symbol(src)_1." + uid : ""; + }(); + function isMasked2(func) { + return !!maskSrcKey2 && maskSrcKey2 in func; + } + var _isMasked = isMasked2; + var funcProto$12 = Function.prototype; + var funcToString$12 = funcProto$12.toString; + function toSource2(func) { + if (func != null) { + try { + return funcToString$12.call(func); + } catch (e) { + } + try { + return func + ""; + } catch (e) { + } + } + return ""; + } + var _toSource = toSource2; + var reRegExpChar2 = /[\\^$.*+?()[\]{}|]/g; + var reIsHostCtor2 = /^\[object .+?Constructor\]$/; + var funcProto2 = Function.prototype, objectProto$32 = Object.prototype; + var funcToString2 = funcProto2.toString; + var hasOwnProperty$32 = objectProto$32.hasOwnProperty; + var reIsNative2 = RegExp( + "^" + funcToString2.call(hasOwnProperty$32).replace(reRegExpChar2, "\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g, "$1.*?") + "$" + ); + function baseIsNative2(value2) { + if (!isObject_12(value2) || _isMasked(value2)) { + return false; + } + var pattern = isFunction_1(value2) ? reIsNative2 : reIsHostCtor2; + return pattern.test(_toSource(value2)); + } + var _baseIsNative = baseIsNative2; + function getValue$1(object3, key) { + return object3 == null ? void 0 : object3[key]; + } + var _getValue = getValue$1; + function getNative2(object3, key) { + var value2 = _getValue(object3, key); + return _baseIsNative(value2) ? value2 : void 0; + } + var _getNative = getNative2; + var nativeCreate2 = _getNative(Object, "create"); + var _nativeCreate = nativeCreate2; + function hashClear2() { + this.__data__ = _nativeCreate ? _nativeCreate(null) : {}; + this.size = 0; + } + var _hashClear = hashClear2; + function hashDelete2(key) { + var result = this.has(key) && delete this.__data__[key]; + this.size -= result ? 1 : 0; + return result; + } + var _hashDelete = hashDelete2; + var HASH_UNDEFINED$12 = "__lodash_hash_undefined__"; + var objectProto$22 = Object.prototype; + var hasOwnProperty$22 = objectProto$22.hasOwnProperty; + function hashGet2(key) { + var data2 = this.__data__; + if (_nativeCreate) { + var result = data2[key]; + return result === HASH_UNDEFINED$12 ? void 0 : result; + } + return hasOwnProperty$22.call(data2, key) ? data2[key] : void 0; + } + var _hashGet = hashGet2; + var objectProto$12 = Object.prototype; + var hasOwnProperty$12 = objectProto$12.hasOwnProperty; + function hashHas2(key) { + var data2 = this.__data__; + return _nativeCreate ? data2[key] !== void 0 : hasOwnProperty$12.call(data2, key); + } + var _hashHas = hashHas2; + var HASH_UNDEFINED2 = "__lodash_hash_undefined__"; + function hashSet2(key, value2) { + var data2 = this.__data__; + this.size += this.has(key) ? 0 : 1; + data2[key] = _nativeCreate && value2 === void 0 ? HASH_UNDEFINED2 : value2; + return this; + } + var _hashSet = hashSet2; + function Hash2(entries2) { + var index2 = -1, length2 = entries2 == null ? 0 : entries2.length; + this.clear(); + while (++index2 < length2) { + var entry = entries2[index2]; + this.set(entry[0], entry[1]); + } + } + Hash2.prototype.clear = _hashClear; + Hash2.prototype["delete"] = _hashDelete; + Hash2.prototype.get = _hashGet; + Hash2.prototype.has = _hashHas; + Hash2.prototype.set = _hashSet; + var _Hash = Hash2; + function listCacheClear2() { + this.__data__ = []; + this.size = 0; + } + var _listCacheClear = listCacheClear2; + function eq2(value2, other) { + return value2 === other || value2 !== value2 && other !== other; + } + var eq_1 = eq2; + function assocIndexOf2(array3, key) { + var length2 = array3.length; + while (length2--) { + if (eq_1(array3[length2][0], key)) { + return length2; + } + } + return -1; + } + var _assocIndexOf = assocIndexOf2; + var arrayProto2 = Array.prototype; + var splice2 = arrayProto2.splice; + function listCacheDelete2(key) { + var data2 = this.__data__, index2 = _assocIndexOf(data2, key); + if (index2 < 0) { + return false; + } + var lastIndex = data2.length - 1; + if (index2 == lastIndex) { + data2.pop(); + } else { + splice2.call(data2, index2, 1); + } + --this.size; + return true; + } + var _listCacheDelete = listCacheDelete2; + function listCacheGet2(key) { + var data2 = this.__data__, index2 = _assocIndexOf(data2, key); + return index2 < 0 ? void 0 : data2[index2][1]; + } + var _listCacheGet = listCacheGet2; + function listCacheHas2(key) { + return _assocIndexOf(this.__data__, key) > -1; + } + var _listCacheHas = listCacheHas2; + function listCacheSet2(key, value2) { + var data2 = this.__data__, index2 = _assocIndexOf(data2, key); + if (index2 < 0) { + ++this.size; + data2.push([key, value2]); + } else { + data2[index2][1] = value2; + } + return this; + } + var _listCacheSet = listCacheSet2; + function ListCache2(entries2) { + var index2 = -1, length2 = entries2 == null ? 0 : entries2.length; + this.clear(); + while (++index2 < length2) { + var entry = entries2[index2]; + this.set(entry[0], entry[1]); + } + } + ListCache2.prototype.clear = _listCacheClear; + ListCache2.prototype["delete"] = _listCacheDelete; + ListCache2.prototype.get = _listCacheGet; + ListCache2.prototype.has = _listCacheHas; + ListCache2.prototype.set = _listCacheSet; + var _ListCache = ListCache2; + var Map$12 = _getNative(_root, "Map"); + var _Map = Map$12; + function mapCacheClear2() { + this.size = 0; + this.__data__ = { + "hash": new _Hash(), + "map": new (_Map || _ListCache)(), + "string": new _Hash() + }; + } + var _mapCacheClear = mapCacheClear2; + function isKeyable2(value2) { + var type2 = typeof value2; + return type2 == "string" || type2 == "number" || type2 == "symbol" || type2 == "boolean" ? value2 !== "__proto__" : value2 === null; + } + var _isKeyable = isKeyable2; + function getMapData2(map2, key) { + var data2 = map2.__data__; + return _isKeyable(key) ? data2[typeof key == "string" ? "string" : "hash"] : data2.map; + } + var _getMapData = getMapData2; + function mapCacheDelete2(key) { + var result = _getMapData(this, key)["delete"](key); + this.size -= result ? 1 : 0; + return result; + } + var _mapCacheDelete = mapCacheDelete2; + function mapCacheGet2(key) { + return _getMapData(this, key).get(key); + } + var _mapCacheGet = mapCacheGet2; + function mapCacheHas2(key) { + return _getMapData(this, key).has(key); + } + var _mapCacheHas = mapCacheHas2; + function mapCacheSet2(key, value2) { + var data2 = _getMapData(this, key), size2 = data2.size; + data2.set(key, value2); + this.size += data2.size == size2 ? 0 : 1; + return this; + } + var _mapCacheSet = mapCacheSet2; + function MapCache2(entries2) { + var index2 = -1, length2 = entries2 == null ? 0 : entries2.length; + this.clear(); + while (++index2 < length2) { + var entry = entries2[index2]; + this.set(entry[0], entry[1]); + } + } + MapCache2.prototype.clear = _mapCacheClear; + MapCache2.prototype["delete"] = _mapCacheDelete; + MapCache2.prototype.get = _mapCacheGet; + MapCache2.prototype.has = _mapCacheHas; + MapCache2.prototype.set = _mapCacheSet; + var _MapCache = MapCache2; + var FUNC_ERROR_TEXT2 = "Expected a function"; + function memoize2(func, resolver3) { + if (typeof func != "function" || resolver3 != null && typeof resolver3 != "function") { + throw new TypeError(FUNC_ERROR_TEXT2); + } + var memoized = function() { + var args = arguments, key = resolver3 ? resolver3.apply(this, args) : args[0], cache2 = memoized.cache; + if (cache2.has(key)) { + return cache2.get(key); + } + var result = func.apply(this, args); + memoized.cache = cache2.set(key, result) || cache2; + return result; + }; + memoized.cache = new (memoize2.Cache || _MapCache)(); + return memoized; + } + memoize2.Cache = _MapCache; + var memoize_1 = memoize2; + var MAX_MEMOIZE_SIZE2 = 500; + function memoizeCapped2(func) { + var result = memoize_1(func, function(key) { + if (cache2.size === MAX_MEMOIZE_SIZE2) { + cache2.clear(); + } + return key; + }); + var cache2 = result.cache; + return result; + } + var _memoizeCapped = memoizeCapped2; + var rePropName2 = /[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g; + var reEscapeChar2 = /\\(\\)?/g; + var stringToPath2 = _memoizeCapped(function(string3) { + var result = []; + if (string3.charCodeAt(0) === 46) { + result.push(""); + } + string3.replace(rePropName2, function(match2, number3, quote, subString) { + result.push(quote ? subString.replace(reEscapeChar2, "$1") : number3 || match2); + }); + return result; + }); + var _stringToPath = stringToPath2; + function arrayMap2(array3, iteratee) { + var index2 = -1, length2 = array3 == null ? 0 : array3.length, result = Array(length2); + while (++index2 < length2) { + result[index2] = iteratee(array3[index2], index2, array3); + } + return result; + } + var _arrayMap = arrayMap2; + var INFINITY$12 = 1 / 0; + var symbolProto2 = _Symbol ? _Symbol.prototype : void 0, symbolToString2 = symbolProto2 ? symbolProto2.toString : void 0; + function baseToString2(value2) { + if (typeof value2 == "string") { + return value2; + } + if (isArray_1(value2)) { + return _arrayMap(value2, baseToString2) + ""; + } + if (isSymbol_1(value2)) { + return symbolToString2 ? symbolToString2.call(value2) : ""; + } + var result = value2 + ""; + return result == "0" && 1 / value2 == -INFINITY$12 ? "-0" : result; + } + var _baseToString = baseToString2; + function toString$12(value2) { + return value2 == null ? "" : _baseToString(value2); + } + var toString_1 = toString$12; + function castPath2(value2, object3) { + if (isArray_1(value2)) { + return value2; + } + return _isKey(value2, object3) ? [value2] : _stringToPath(toString_1(value2)); + } + var _castPath = castPath2; + var INFINITY2 = 1 / 0; + function toKey2(value2) { + if (typeof value2 == "string" || isSymbol_1(value2)) { + return value2; + } + var result = value2 + ""; + return result == "0" && 1 / value2 == -INFINITY2 ? "-0" : result; + } + var _toKey = toKey2; + function baseGet2(object3, path2) { + path2 = _castPath(path2, object3); + var index2 = 0, length2 = path2.length; + while (object3 != null && index2 < length2) { + object3 = object3[_toKey(path2[index2++])]; + } + return index2 && index2 == length2 ? object3 : void 0; + } + var _baseGet = baseGet2; + function get2(object3, path2, defaultValue) { + var result = object3 == null ? void 0 : _baseGet(object3, path2); + return result === void 0 ? defaultValue : result; + } + var get_1 = get2; + var defineProperty2 = function() { + try { + var func = _getNative(Object, "defineProperty"); + func({}, "", {}); + return func; + } catch (e) { + } + }(); + var _defineProperty = defineProperty2; + function baseAssignValue2(object3, key, value2) { + if (key == "__proto__" && _defineProperty) { + _defineProperty(object3, key, { + "configurable": true, + "enumerable": true, + "value": value2, + "writable": true + }); + } else { + object3[key] = value2; + } + } + var _baseAssignValue = baseAssignValue2; + var objectProto2 = Object.prototype; + var hasOwnProperty2 = objectProto2.hasOwnProperty; + function assignValue2(object3, key, value2) { + var objValue = object3[key]; + if (!(hasOwnProperty2.call(object3, key) && eq_1(objValue, value2)) || value2 === void 0 && !(key in object3)) { + _baseAssignValue(object3, key, value2); + } + } + var _assignValue = assignValue2; + var MAX_SAFE_INTEGER2 = 9007199254740991; + var reIsUint2 = /^(?:0|[1-9]\d*)$/; + function isIndex2(value2, length2) { + var type2 = typeof value2; + length2 = length2 == null ? MAX_SAFE_INTEGER2 : length2; + return !!length2 && (type2 == "number" || type2 != "symbol" && reIsUint2.test(value2)) && (value2 > -1 && value2 % 1 == 0 && value2 < length2); + } + var _isIndex = isIndex2; + function baseSet2(object3, path2, value2, customizer) { + if (!isObject_12(object3)) { + return object3; + } + path2 = _castPath(path2, object3); + var index2 = -1, length2 = path2.length, lastIndex = length2 - 1, nested = object3; + while (nested != null && ++index2 < length2) { + var key = _toKey(path2[index2]), newValue = value2; + if (key === "__proto__" || key === "constructor" || key === "prototype") { + return object3; + } + if (index2 != lastIndex) { + var objValue = nested[key]; + newValue = customizer ? customizer(objValue, key, nested) : void 0; + if (newValue === void 0) { + newValue = isObject_12(objValue) ? objValue : _isIndex(path2[index2 + 1]) ? [] : {}; + } + } + _assignValue(nested, key, newValue); + nested = nested[key]; + } + return object3; + } + var _baseSet = baseSet2; + function set2(object3, path2, value2) { + return object3 == null ? object3 : _baseSet(object3, path2, value2); + } + var set_1 = set2; + function copyArray2(source, array3) { + var index2 = -1, length2 = source.length; + array3 || (array3 = Array(length2)); + while (++index2 < length2) { + array3[index2] = source[index2]; + } + return array3; + } + var _copyArray = copyArray2; + function toPath(value2) { + if (isArray_1(value2)) { + return _arrayMap(value2, _toKey); + } + return isSymbol_1(value2) ? [value2] : _copyArray(_stringToPath(toString_1(value2))); + } + var toPath_1 = toPath; + var define$2 = { + // access data field + data: function data2(params) { + var defaults3 = { + field: "data", + bindingEvent: "data", + allowBinding: false, + allowSetting: false, + allowGetting: false, + settingEvent: "data", + settingTriggersEvent: false, + triggerFnName: "trigger", + immutableKeys: {}, + // key => true if immutable + updateStyle: false, + beforeGet: function beforeGet(self2) { + }, + beforeSet: function beforeSet(self2, obj) { + }, + onSet: function onSet(self2) { + }, + canSet: function canSet(self2) { + return true; + } + }; + params = extend2({}, defaults3, params); + return function dataImpl(name, value2) { + var p2 = params; + var self2 = this; + var selfIsArrayLike = self2.length !== void 0; + var all2 = selfIsArrayLike ? self2 : [self2]; + var single = selfIsArrayLike ? self2[0] : self2; + if (string2(name)) { + var isPathLike = name.indexOf(".") !== -1; + var path2 = isPathLike && toPath_1(name); + if (p2.allowGetting && value2 === void 0) { + var ret; + if (single) { + p2.beforeGet(single); + if (path2 && single._private[p2.field][name] === void 0) { + ret = get_1(single._private[p2.field], path2); + } else { + ret = single._private[p2.field][name]; + } + } + return ret; + } else if (p2.allowSetting && value2 !== void 0) { + var valid2 = !p2.immutableKeys[name]; + if (valid2) { + var change2 = _defineProperty$1({}, name, value2); + p2.beforeSet(self2, change2); + for (var i3 = 0, l = all2.length; i3 < l; i3++) { + var ele = all2[i3]; + if (p2.canSet(ele)) { + if (path2 && single._private[p2.field][name] === void 0) { + set_1(ele._private[p2.field], path2, value2); + } else { + ele._private[p2.field][name] = value2; + } + } + } + if (p2.updateStyle) { + self2.updateStyle(); + } + p2.onSet(self2); + if (p2.settingTriggersEvent) { + self2[p2.triggerFnName](p2.settingEvent); + } + } + } + } else if (p2.allowSetting && plainObject(name)) { + var obj = name; + var k, v; + var keys2 = Object.keys(obj); + p2.beforeSet(self2, obj); + for (var _i6 = 0; _i6 < keys2.length; _i6++) { + k = keys2[_i6]; + v = obj[k]; + var _valid = !p2.immutableKeys[k]; + if (_valid) { + for (var j = 0; j < all2.length; j++) { + var _ele = all2[j]; + if (p2.canSet(_ele)) { + _ele._private[p2.field][k] = v; + } + } + } + } + if (p2.updateStyle) { + self2.updateStyle(); + } + p2.onSet(self2); + if (p2.settingTriggersEvent) { + self2[p2.triggerFnName](p2.settingEvent); + } + } else if (p2.allowBinding && fn$6(name)) { + var fn2 = name; + self2.on(p2.bindingEvent, fn2); + } else if (p2.allowGetting && name === void 0) { + var _ret; + if (single) { + p2.beforeGet(single); + _ret = single._private[p2.field]; + } + return _ret; + } + return self2; + }; + }, + // data + // remove data field + removeData: function removeData(params) { + var defaults3 = { + field: "data", + event: "data", + triggerFnName: "trigger", + triggerEvent: false, + immutableKeys: {} + // key => true if immutable + }; + params = extend2({}, defaults3, params); + return function removeDataImpl(names) { + var p2 = params; + var self2 = this; + var selfIsArrayLike = self2.length !== void 0; + var all2 = selfIsArrayLike ? self2 : [self2]; + if (string2(names)) { + var keys2 = names.split(/\s+/); + var l = keys2.length; + for (var i3 = 0; i3 < l; i3++) { + var key = keys2[i3]; + if (emptyString(key)) { + continue; + } + var valid2 = !p2.immutableKeys[key]; + if (valid2) { + for (var i_a = 0, l_a = all2.length; i_a < l_a; i_a++) { + all2[i_a]._private[p2.field][key] = void 0; + } + } + } + if (p2.triggerEvent) { + self2[p2.triggerFnName](p2.event); + } + } else if (names === void 0) { + for (var _i_a = 0, _l_a = all2.length; _i_a < _l_a; _i_a++) { + var _privateFields = all2[_i_a]._private[p2.field]; + var _keys = Object.keys(_privateFields); + for (var _i22 = 0; _i22 < _keys.length; _i22++) { + var _key = _keys[_i22]; + var validKeyToDelete = !p2.immutableKeys[_key]; + if (validKeyToDelete) { + _privateFields[_key] = void 0; + } + } + } + if (p2.triggerEvent) { + self2[p2.triggerFnName](p2.event); + } + } + return self2; + }; + } + // removeData + }; + var define$1 = { + eventAliasesOn: function eventAliasesOn(proto) { + var p2 = proto; + p2.addListener = p2.listen = p2.bind = p2.on; + p2.unlisten = p2.unbind = p2.off = p2.removeListener; + p2.trigger = p2.emit; + p2.pon = p2.promiseOn = function(events, selector2) { + var self2 = this; + var args = Array.prototype.slice.call(arguments, 0); + return new Promise$12(function(resolve2, reject) { + var callback = function callback2(e) { + self2.off.apply(self2, offArgs); + resolve2(e); + }; + var onArgs = args.concat([callback]); + var offArgs = onArgs.concat([]); + self2.on.apply(self2, onArgs); + }); + }; + } + }; + var define3 = {}; + [define$3, define$2, define$1].forEach(function(m) { + extend2(define3, m); + }); + var elesfn$i = { + animate: define3.animate(), + animation: define3.animation(), + animated: define3.animated(), + clearQueue: define3.clearQueue(), + delay: define3.delay(), + delayAnimation: define3.delayAnimation(), + stop: define3.stop() + }; + var elesfn$h = { + classes: function classes2(_classes) { + var self2 = this; + if (_classes === void 0) { + var ret = []; + self2[0]._private.classes.forEach(function(cls2) { + return ret.push(cls2); + }); + return ret; + } else if (!array2(_classes)) { + _classes = (_classes || "").match(/\S+/g) || []; + } + var changed = []; + var classesSet = new Set$12(_classes); + for (var j = 0; j < self2.length; j++) { + var ele = self2[j]; + var _p = ele._private; + var eleClasses = _p.classes; + var changedEle = false; + for (var i3 = 0; i3 < _classes.length; i3++) { + var cls = _classes[i3]; + var eleHasClass = eleClasses.has(cls); + if (!eleHasClass) { + changedEle = true; + break; + } + } + if (!changedEle) { + changedEle = eleClasses.size !== _classes.length; + } + if (changedEle) { + _p.classes = classesSet; + changed.push(ele); + } + } + if (changed.length > 0) { + this.spawn(changed).updateStyle().emit("class"); + } + return self2; + }, + addClass: function addClass2(classes2) { + return this.toggleClass(classes2, true); + }, + hasClass: function hasClass(className) { + var ele = this[0]; + return ele != null && ele._private.classes.has(className); + }, + toggleClass: function toggleClass(classes2, toggle) { + if (!array2(classes2)) { + classes2 = classes2.match(/\S+/g) || []; + } + var self2 = this; + var toggleUndefd = toggle === void 0; + var changed = []; + for (var i3 = 0, il = self2.length; i3 < il; i3++) { + var ele = self2[i3]; + var eleClasses = ele._private.classes; + var changedEle = false; + for (var j = 0; j < classes2.length; j++) { + var cls = classes2[j]; + var hasClass = eleClasses.has(cls); + var changedNow = false; + if (toggle || toggleUndefd && !hasClass) { + eleClasses.add(cls); + changedNow = true; + } else if (!toggle || toggleUndefd && hasClass) { + eleClasses["delete"](cls); + changedNow = true; + } + if (!changedEle && changedNow) { + changed.push(ele); + changedEle = true; + } + } + } + if (changed.length > 0) { + this.spawn(changed).updateStyle().emit("class"); + } + return self2; + }, + removeClass: function removeClass(classes2) { + return this.toggleClass(classes2, false); + }, + flashClass: function flashClass(classes2, duration) { + var self2 = this; + if (duration == null) { + duration = 250; + } else if (duration === 0) { + return self2; + } + self2.addClass(classes2); + setTimeout(function() { + self2.removeClass(classes2); + }, duration); + return self2; + } + }; + elesfn$h.className = elesfn$h.classNames = elesfn$h.classes; + var tokens = { + metaChar: "[\\!\\\"\\#\\$\\%\\&\\'\\(\\)\\*\\+\\,\\.\\/\\:\\;\\<\\=\\>\\?\\@\\[\\]\\^\\`\\{\\|\\}\\~]", + // chars we need to escape in let names, etc + comparatorOp: "=|\\!=|>|>=|<|<=|\\$=|\\^=|\\*=", + // binary comparison op (used in data selectors) + boolOp: "\\?|\\!|\\^", + // boolean (unary) operators (used in data selectors) + string: `"(?:\\\\"|[^"])*"|'(?:\\\\'|[^'])*'`, + // string literals (used in data selectors) -- doublequotes | singlequotes + number: number2, + // number literal (used in data selectors) --- e.g. 0.1234, 1234, 12e123 + meta: "degree|indegree|outdegree", + // allowed metadata fields (i.e. allowed functions to use from Collection) + separator: "\\s*,\\s*", + // queries are separated by commas, e.g. edge[foo = 'bar'], node.someClass + descendant: "\\s+", + child: "\\s+>\\s+", + subject: "\\$", + group: "node|edge|\\*", + directedEdge: "\\s+->\\s+", + undirectedEdge: "\\s+<->\\s+" + }; + tokens.variable = "(?:[\\w-.]|(?:\\\\" + tokens.metaChar + "))+"; + tokens.className = "(?:[\\w-]|(?:\\\\" + tokens.metaChar + "))+"; + tokens.value = tokens.string + "|" + tokens.number; + tokens.id = tokens.variable; + (function() { + var ops, op2, i3; + ops = tokens.comparatorOp.split("|"); + for (i3 = 0; i3 < ops.length; i3++) { + op2 = ops[i3]; + tokens.comparatorOp += "|@" + op2; + } + ops = tokens.comparatorOp.split("|"); + for (i3 = 0; i3 < ops.length; i3++) { + op2 = ops[i3]; + if (op2.indexOf("!") >= 0) { + continue; + } + if (op2 === "=") { + continue; + } + tokens.comparatorOp += "|\\!" + op2; + } + })(); + var newQuery = function newQuery2() { + return { + checks: [] + }; + }; + var Type2 = { + /** E.g. node */ + GROUP: 0, + /** A collection of elements */ + COLLECTION: 1, + /** A filter(ele) function */ + FILTER: 2, + /** E.g. [foo > 1] */ + DATA_COMPARE: 3, + /** E.g. [foo] */ + DATA_EXIST: 4, + /** E.g. [?foo] */ + DATA_BOOL: 5, + /** E.g. [[degree > 2]] */ + META_COMPARE: 6, + /** E.g. :selected */ + STATE: 7, + /** E.g. #foo */ + ID: 8, + /** E.g. .foo */ + CLASS: 9, + /** E.g. #foo <-> #bar */ + UNDIRECTED_EDGE: 10, + /** E.g. #foo -> #bar */ + DIRECTED_EDGE: 11, + /** E.g. $#foo -> #bar */ + NODE_SOURCE: 12, + /** E.g. #foo -> $#bar */ + NODE_TARGET: 13, + /** E.g. $#foo <-> #bar */ + NODE_NEIGHBOR: 14, + /** E.g. #foo > #bar */ + CHILD: 15, + /** E.g. #foo #bar */ + DESCENDANT: 16, + /** E.g. $#foo > #bar */ + PARENT: 17, + /** E.g. $#foo #bar */ + ANCESTOR: 18, + /** E.g. #foo > $bar > #baz */ + COMPOUND_SPLIT: 19, + /** Always matches, useful placeholder for subject in `COMPOUND_SPLIT` */ + TRUE: 20 + }; + var stateSelectors = [{ + selector: ":selected", + matches: function matches2(ele) { + return ele.selected(); + } + }, { + selector: ":unselected", + matches: function matches2(ele) { + return !ele.selected(); + } + }, { + selector: ":selectable", + matches: function matches2(ele) { + return ele.selectable(); + } + }, { + selector: ":unselectable", + matches: function matches2(ele) { + return !ele.selectable(); + } + }, { + selector: ":locked", + matches: function matches2(ele) { + return ele.locked(); + } + }, { + selector: ":unlocked", + matches: function matches2(ele) { + return !ele.locked(); + } + }, { + selector: ":visible", + matches: function matches2(ele) { + return ele.visible(); + } + }, { + selector: ":hidden", + matches: function matches2(ele) { + return !ele.visible(); + } + }, { + selector: ":transparent", + matches: function matches2(ele) { + return ele.transparent(); + } + }, { + selector: ":grabbed", + matches: function matches2(ele) { + return ele.grabbed(); + } + }, { + selector: ":free", + matches: function matches2(ele) { + return !ele.grabbed(); + } + }, { + selector: ":removed", + matches: function matches2(ele) { + return ele.removed(); + } + }, { + selector: ":inside", + matches: function matches2(ele) { + return !ele.removed(); + } + }, { + selector: ":grabbable", + matches: function matches2(ele) { + return ele.grabbable(); + } + }, { + selector: ":ungrabbable", + matches: function matches2(ele) { + return !ele.grabbable(); + } + }, { + selector: ":animated", + matches: function matches2(ele) { + return ele.animated(); + } + }, { + selector: ":unanimated", + matches: function matches2(ele) { + return !ele.animated(); + } + }, { + selector: ":parent", + matches: function matches2(ele) { + return ele.isParent(); + } + }, { + selector: ":childless", + matches: function matches2(ele) { + return ele.isChildless(); + } + }, { + selector: ":child", + matches: function matches2(ele) { + return ele.isChild(); + } + }, { + selector: ":orphan", + matches: function matches2(ele) { + return ele.isOrphan(); + } + }, { + selector: ":nonorphan", + matches: function matches2(ele) { + return ele.isChild(); + } + }, { + selector: ":compound", + matches: function matches2(ele) { + if (ele.isNode()) { + return ele.isParent(); + } else { + return ele.source().isParent() || ele.target().isParent(); + } + } + }, { + selector: ":loop", + matches: function matches2(ele) { + return ele.isLoop(); + } + }, { + selector: ":simple", + matches: function matches2(ele) { + return ele.isSimple(); + } + }, { + selector: ":active", + matches: function matches2(ele) { + return ele.active(); + } + }, { + selector: ":inactive", + matches: function matches2(ele) { + return !ele.active(); + } + }, { + selector: ":backgrounding", + matches: function matches2(ele) { + return ele.backgrounding(); + } + }, { + selector: ":nonbackgrounding", + matches: function matches2(ele) { + return !ele.backgrounding(); + } + }].sort(function(a, b) { + return descending2(a.selector, b.selector); + }); + var lookup = function() { + var selToFn = {}; + var s; + for (var i3 = 0; i3 < stateSelectors.length; i3++) { + s = stateSelectors[i3]; + selToFn[s.selector] = s.matches; + } + return selToFn; + }(); + var stateSelectorMatches = function stateSelectorMatches2(sel, ele) { + return lookup[sel](ele); + }; + var stateSelectorRegex = "(" + stateSelectors.map(function(s) { + return s.selector; + }).join("|") + ")"; + var cleanMetaChars = function cleanMetaChars2(str2) { + return str2.replace(new RegExp("\\\\(" + tokens.metaChar + ")", "g"), function(match2, $1) { + return $1; + }); + }; + var replaceLastQuery = function replaceLastQuery2(selector2, examiningQuery, replacementQuery) { + selector2[selector2.length - 1] = replacementQuery; + }; + var exprs = [{ + name: "group", + // just used for identifying when debugging + query: true, + regex: "(" + tokens.group + ")", + populate: function populate(selector2, query, _ref) { + var _ref2 = _slicedToArray(_ref, 1), group = _ref2[0]; + query.checks.push({ + type: Type2.GROUP, + value: group === "*" ? group : group + "s" + }); + } + }, { + name: "state", + query: true, + regex: stateSelectorRegex, + populate: function populate(selector2, query, _ref3) { + var _ref4 = _slicedToArray(_ref3, 1), state2 = _ref4[0]; + query.checks.push({ + type: Type2.STATE, + value: state2 + }); + } + }, { + name: "id", + query: true, + regex: "\\#(" + tokens.id + ")", + populate: function populate(selector2, query, _ref5) { + var _ref6 = _slicedToArray(_ref5, 1), id2 = _ref6[0]; + query.checks.push({ + type: Type2.ID, + value: cleanMetaChars(id2) + }); + } + }, { + name: "className", + query: true, + regex: "\\.(" + tokens.className + ")", + populate: function populate(selector2, query, _ref7) { + var _ref8 = _slicedToArray(_ref7, 1), className = _ref8[0]; + query.checks.push({ + type: Type2.CLASS, + value: cleanMetaChars(className) + }); + } + }, { + name: "dataExists", + query: true, + regex: "\\[\\s*(" + tokens.variable + ")\\s*\\]", + populate: function populate(selector2, query, _ref9) { + var _ref10 = _slicedToArray(_ref9, 1), variable = _ref10[0]; + query.checks.push({ + type: Type2.DATA_EXIST, + field: cleanMetaChars(variable) + }); + } + }, { + name: "dataCompare", + query: true, + regex: "\\[\\s*(" + tokens.variable + ")\\s*(" + tokens.comparatorOp + ")\\s*(" + tokens.value + ")\\s*\\]", + populate: function populate(selector2, query, _ref11) { + var _ref12 = _slicedToArray(_ref11, 3), variable = _ref12[0], comparatorOp = _ref12[1], value2 = _ref12[2]; + var valueIsString = new RegExp("^" + tokens.string + "$").exec(value2) != null; + if (valueIsString) { + value2 = value2.substring(1, value2.length - 1); + } else { + value2 = parseFloat(value2); + } + query.checks.push({ + type: Type2.DATA_COMPARE, + field: cleanMetaChars(variable), + operator: comparatorOp, + value: value2 + }); + } + }, { + name: "dataBool", + query: true, + regex: "\\[\\s*(" + tokens.boolOp + ")\\s*(" + tokens.variable + ")\\s*\\]", + populate: function populate(selector2, query, _ref13) { + var _ref14 = _slicedToArray(_ref13, 2), boolOp = _ref14[0], variable = _ref14[1]; + query.checks.push({ + type: Type2.DATA_BOOL, + field: cleanMetaChars(variable), + operator: boolOp + }); + } + }, { + name: "metaCompare", + query: true, + regex: "\\[\\[\\s*(" + tokens.meta + ")\\s*(" + tokens.comparatorOp + ")\\s*(" + tokens.number + ")\\s*\\]\\]", + populate: function populate(selector2, query, _ref15) { + var _ref16 = _slicedToArray(_ref15, 3), meta2 = _ref16[0], comparatorOp = _ref16[1], number3 = _ref16[2]; + query.checks.push({ + type: Type2.META_COMPARE, + field: cleanMetaChars(meta2), + operator: comparatorOp, + value: parseFloat(number3) + }); + } + }, { + name: "nextQuery", + separator: true, + regex: tokens.separator, + populate: function populate(selector2, query) { + var currentSubject = selector2.currentSubject; + var edgeCount2 = selector2.edgeCount; + var compoundCount = selector2.compoundCount; + var lastQ = selector2[selector2.length - 1]; + if (currentSubject != null) { + lastQ.subject = currentSubject; + selector2.currentSubject = null; + } + lastQ.edgeCount = edgeCount2; + lastQ.compoundCount = compoundCount; + selector2.edgeCount = 0; + selector2.compoundCount = 0; + var nextQuery = selector2[selector2.length++] = newQuery(); + return nextQuery; + } + }, { + name: "directedEdge", + separator: true, + regex: tokens.directedEdge, + populate: function populate(selector2, query) { + if (selector2.currentSubject == null) { + var edgeQuery = newQuery(); + var source = query; + var target = newQuery(); + edgeQuery.checks.push({ + type: Type2.DIRECTED_EDGE, + source, + target + }); + replaceLastQuery(selector2, query, edgeQuery); + selector2.edgeCount++; + return target; + } else { + var srcTgtQ = newQuery(); + var _source = query; + var _target = newQuery(); + srcTgtQ.checks.push({ + type: Type2.NODE_SOURCE, + source: _source, + target: _target + }); + replaceLastQuery(selector2, query, srcTgtQ); + selector2.edgeCount++; + return _target; + } + } + }, { + name: "undirectedEdge", + separator: true, + regex: tokens.undirectedEdge, + populate: function populate(selector2, query) { + if (selector2.currentSubject == null) { + var edgeQuery = newQuery(); + var source = query; + var target = newQuery(); + edgeQuery.checks.push({ + type: Type2.UNDIRECTED_EDGE, + nodes: [source, target] + }); + replaceLastQuery(selector2, query, edgeQuery); + selector2.edgeCount++; + return target; + } else { + var nhoodQ = newQuery(); + var node2 = query; + var neighbor = newQuery(); + nhoodQ.checks.push({ + type: Type2.NODE_NEIGHBOR, + node: node2, + neighbor + }); + replaceLastQuery(selector2, query, nhoodQ); + return neighbor; + } + } + }, { + name: "child", + separator: true, + regex: tokens.child, + populate: function populate(selector2, query) { + if (selector2.currentSubject == null) { + var parentChildQuery = newQuery(); + var child = newQuery(); + var parent = selector2[selector2.length - 1]; + parentChildQuery.checks.push({ + type: Type2.CHILD, + parent, + child + }); + replaceLastQuery(selector2, query, parentChildQuery); + selector2.compoundCount++; + return child; + } else if (selector2.currentSubject === query) { + var compound = newQuery(); + var left2 = selector2[selector2.length - 1]; + var right2 = newQuery(); + var subject = newQuery(); + var _child = newQuery(); + var _parent = newQuery(); + compound.checks.push({ + type: Type2.COMPOUND_SPLIT, + left: left2, + right: right2, + subject + }); + subject.checks = query.checks; + query.checks = [{ + type: Type2.TRUE + }]; + _parent.checks.push({ + type: Type2.TRUE + }); + right2.checks.push({ + type: Type2.PARENT, + // type is swapped on right side queries + parent: _parent, + child: _child + // empty for now + }); + replaceLastQuery(selector2, left2, compound); + selector2.currentSubject = subject; + selector2.compoundCount++; + return _child; + } else { + var _parent2 = newQuery(); + var _child2 = newQuery(); + var pcQChecks = [{ + type: Type2.PARENT, + parent: _parent2, + child: _child2 + }]; + _parent2.checks = query.checks; + query.checks = pcQChecks; + selector2.compoundCount++; + return _child2; + } + } + }, { + name: "descendant", + separator: true, + regex: tokens.descendant, + populate: function populate(selector2, query) { + if (selector2.currentSubject == null) { + var ancChQuery = newQuery(); + var descendant = newQuery(); + var ancestor = selector2[selector2.length - 1]; + ancChQuery.checks.push({ + type: Type2.DESCENDANT, + ancestor, + descendant + }); + replaceLastQuery(selector2, query, ancChQuery); + selector2.compoundCount++; + return descendant; + } else if (selector2.currentSubject === query) { + var compound = newQuery(); + var left2 = selector2[selector2.length - 1]; + var right2 = newQuery(); + var subject = newQuery(); + var _descendant = newQuery(); + var _ancestor = newQuery(); + compound.checks.push({ + type: Type2.COMPOUND_SPLIT, + left: left2, + right: right2, + subject + }); + subject.checks = query.checks; + query.checks = [{ + type: Type2.TRUE + }]; + _ancestor.checks.push({ + type: Type2.TRUE + }); + right2.checks.push({ + type: Type2.ANCESTOR, + // type is swapped on right side queries + ancestor: _ancestor, + descendant: _descendant + // empty for now + }); + replaceLastQuery(selector2, left2, compound); + selector2.currentSubject = subject; + selector2.compoundCount++; + return _descendant; + } else { + var _ancestor2 = newQuery(); + var _descendant2 = newQuery(); + var adQChecks = [{ + type: Type2.ANCESTOR, + ancestor: _ancestor2, + descendant: _descendant2 + }]; + _ancestor2.checks = query.checks; + query.checks = adQChecks; + selector2.compoundCount++; + return _descendant2; + } + } + }, { + name: "subject", + modifier: true, + regex: tokens.subject, + populate: function populate(selector2, query) { + if (selector2.currentSubject != null && selector2.currentSubject !== query) { + warn("Redefinition of subject in selector `" + selector2.toString() + "`"); + return false; + } + selector2.currentSubject = query; + var topQ = selector2[selector2.length - 1]; + var topChk = topQ.checks[0]; + var topType = topChk == null ? null : topChk.type; + if (topType === Type2.DIRECTED_EDGE) { + topChk.type = Type2.NODE_TARGET; + } else if (topType === Type2.UNDIRECTED_EDGE) { + topChk.type = Type2.NODE_NEIGHBOR; + topChk.node = topChk.nodes[1]; + topChk.neighbor = topChk.nodes[0]; + topChk.nodes = null; + } + } + }]; + exprs.forEach(function(e) { + return e.regexObj = new RegExp("^" + e.regex); + }); + var consumeExpr = function consumeExpr2(remaining) { + var expr; + var match2; + var name; + for (var j = 0; j < exprs.length; j++) { + var e = exprs[j]; + var n = e.name; + var m = remaining.match(e.regexObj); + if (m != null) { + match2 = m; + expr = e; + name = n; + var consumed = m[0]; + remaining = remaining.substring(consumed.length); + break; + } + } + return { + expr, + match: match2, + name, + remaining + }; + }; + var consumeWhitespace = function consumeWhitespace2(remaining) { + var match2 = remaining.match(/^\s+/); + if (match2) { + var consumed = match2[0]; + remaining = remaining.substring(consumed.length); + } + return remaining; + }; + var parse2 = function parse3(selector2) { + var self2 = this; + var remaining = self2.inputText = selector2; + var currentQuery = self2[0] = newQuery(); + self2.length = 1; + remaining = consumeWhitespace(remaining); + for (; ; ) { + var exprInfo = consumeExpr(remaining); + if (exprInfo.expr == null) { + warn("The selector `" + selector2 + "`is invalid"); + return false; + } else { + var args = exprInfo.match.slice(1); + var ret = exprInfo.expr.populate(self2, currentQuery, args); + if (ret === false) { + return false; + } else if (ret != null) { + currentQuery = ret; + } + } + remaining = exprInfo.remaining; + if (remaining.match(/^\s*$/)) { + break; + } + } + var lastQ = self2[self2.length - 1]; + if (self2.currentSubject != null) { + lastQ.subject = self2.currentSubject; + } + lastQ.edgeCount = self2.edgeCount; + lastQ.compoundCount = self2.compoundCount; + for (var i3 = 0; i3 < self2.length; i3++) { + var q = self2[i3]; + if (q.compoundCount > 0 && q.edgeCount > 0) { + warn("The selector `" + selector2 + "` is invalid because it uses both a compound selector and an edge selector"); + return false; + } + if (q.edgeCount > 1) { + warn("The selector `" + selector2 + "` is invalid because it uses multiple edge selectors"); + return false; + } else if (q.edgeCount === 1) { + warn("The selector `" + selector2 + "` is deprecated. Edge selectors do not take effect on changes to source and target nodes after an edge is added, for performance reasons. Use a class or data selector on edges instead, updating the class or data of an edge when your app detects a change in source or target nodes."); + } + } + return true; + }; + var toString2 = function toString3() { + if (this.toStringCache != null) { + return this.toStringCache; + } + var clean = function clean2(obj) { + if (obj == null) { + return ""; + } else { + return obj; + } + }; + var cleanVal = function cleanVal2(val) { + if (string2(val)) { + return '"' + val + '"'; + } else { + return clean(val); + } + }; + var space = function space2(val) { + return " " + val + " "; + }; + var checkToString = function checkToString2(check, subject) { + var type2 = check.type, value2 = check.value; + switch (type2) { + case Type2.GROUP: { + var group = clean(value2); + return group.substring(0, group.length - 1); + } + case Type2.DATA_COMPARE: { + var field = check.field, operator = check.operator; + return "[" + field + space(clean(operator)) + cleanVal(value2) + "]"; + } + case Type2.DATA_BOOL: { + var _operator = check.operator, _field = check.field; + return "[" + clean(_operator) + _field + "]"; + } + case Type2.DATA_EXIST: { + var _field2 = check.field; + return "[" + _field2 + "]"; + } + case Type2.META_COMPARE: { + var _operator2 = check.operator, _field3 = check.field; + return "[[" + _field3 + space(clean(_operator2)) + cleanVal(value2) + "]]"; + } + case Type2.STATE: { + return value2; + } + case Type2.ID: { + return "#" + value2; + } + case Type2.CLASS: { + return "." + value2; + } + case Type2.PARENT: + case Type2.CHILD: { + return queryToString(check.parent, subject) + space(">") + queryToString(check.child, subject); + } + case Type2.ANCESTOR: + case Type2.DESCENDANT: { + return queryToString(check.ancestor, subject) + " " + queryToString(check.descendant, subject); + } + case Type2.COMPOUND_SPLIT: { + var lhs = queryToString(check.left, subject); + var sub2 = queryToString(check.subject, subject); + var rhs = queryToString(check.right, subject); + return lhs + (lhs.length > 0 ? " " : "") + sub2 + rhs; + } + case Type2.TRUE: { + return ""; + } + } + }; + var queryToString = function queryToString2(query2, subject) { + return query2.checks.reduce(function(str3, chk, i4) { + return str3 + (subject === query2 && i4 === 0 ? "$" : "") + checkToString(chk, subject); + }, ""); + }; + var str2 = ""; + for (var i3 = 0; i3 < this.length; i3++) { + var query = this[i3]; + str2 += queryToString(query, query.subject); + if (this.length > 1 && i3 < this.length - 1) { + str2 += ", "; + } + } + this.toStringCache = str2; + return str2; + }; + var parse$12 = { + parse: parse2, + toString: toString2 + }; + var valCmp = function valCmp2(fieldVal, operator, value2) { + var matches2; + var isFieldStr = string2(fieldVal); + var isFieldNum = number$12(fieldVal); + var isValStr = string2(value2); + var fieldStr, valStr; + var caseInsensitive = false; + var notExpr = false; + var isIneqCmp = false; + if (operator.indexOf("!") >= 0) { + operator = operator.replace("!", ""); + notExpr = true; + } + if (operator.indexOf("@") >= 0) { + operator = operator.replace("@", ""); + caseInsensitive = true; + } + if (isFieldStr || isValStr || caseInsensitive) { + fieldStr = !isFieldStr && !isFieldNum ? "" : "" + fieldVal; + valStr = "" + value2; + } + if (caseInsensitive) { + fieldVal = fieldStr = fieldStr.toLowerCase(); + value2 = valStr = valStr.toLowerCase(); + } + switch (operator) { + case "*=": + matches2 = fieldStr.indexOf(valStr) >= 0; + break; + case "$=": + matches2 = fieldStr.indexOf(valStr, fieldStr.length - valStr.length) >= 0; + break; + case "^=": + matches2 = fieldStr.indexOf(valStr) === 0; + break; + case "=": + matches2 = fieldVal === value2; + break; + case ">": + isIneqCmp = true; + matches2 = fieldVal > value2; + break; + case ">=": + isIneqCmp = true; + matches2 = fieldVal >= value2; + break; + case "<": + isIneqCmp = true; + matches2 = fieldVal < value2; + break; + case "<=": + isIneqCmp = true; + matches2 = fieldVal <= value2; + break; + default: + matches2 = false; + break; + } + if (notExpr && (fieldVal != null || !isIneqCmp)) { + matches2 = !matches2; + } + return matches2; + }; + var boolCmp = function boolCmp2(fieldVal, operator) { + switch (operator) { + case "?": + return fieldVal ? true : false; + case "!": + return fieldVal ? false : true; + case "^": + return fieldVal === void 0; + } + }; + var existCmp = function existCmp2(fieldVal) { + return fieldVal !== void 0; + }; + var data$1 = function data2(ele, field) { + return ele.data(field); + }; + var meta = function meta2(ele, field) { + return ele[field](); + }; + var match = []; + var matches$1 = function matches2(query, ele) { + return query.checks.every(function(chk) { + return match[chk.type](chk, ele); + }); + }; + match[Type2.GROUP] = function(check, ele) { + var group = check.value; + return group === "*" || group === ele.group(); + }; + match[Type2.STATE] = function(check, ele) { + var stateSelector = check.value; + return stateSelectorMatches(stateSelector, ele); + }; + match[Type2.ID] = function(check, ele) { + var id2 = check.value; + return ele.id() === id2; + }; + match[Type2.CLASS] = function(check, ele) { + var cls = check.value; + return ele.hasClass(cls); + }; + match[Type2.META_COMPARE] = function(check, ele) { + var field = check.field, operator = check.operator, value2 = check.value; + return valCmp(meta(ele, field), operator, value2); + }; + match[Type2.DATA_COMPARE] = function(check, ele) { + var field = check.field, operator = check.operator, value2 = check.value; + return valCmp(data$1(ele, field), operator, value2); + }; + match[Type2.DATA_BOOL] = function(check, ele) { + var field = check.field, operator = check.operator; + return boolCmp(data$1(ele, field), operator); + }; + match[Type2.DATA_EXIST] = function(check, ele) { + var field = check.field; + check.operator; + return existCmp(data$1(ele, field)); + }; + match[Type2.UNDIRECTED_EDGE] = function(check, ele) { + var qA = check.nodes[0]; + var qB = check.nodes[1]; + var src = ele.source(); + var tgt = ele.target(); + return matches$1(qA, src) && matches$1(qB, tgt) || matches$1(qB, src) && matches$1(qA, tgt); + }; + match[Type2.NODE_NEIGHBOR] = function(check, ele) { + return matches$1(check.node, ele) && ele.neighborhood().some(function(n) { + return n.isNode() && matches$1(check.neighbor, n); + }); + }; + match[Type2.DIRECTED_EDGE] = function(check, ele) { + return matches$1(check.source, ele.source()) && matches$1(check.target, ele.target()); + }; + match[Type2.NODE_SOURCE] = function(check, ele) { + return matches$1(check.source, ele) && ele.outgoers().some(function(n) { + return n.isNode() && matches$1(check.target, n); + }); + }; + match[Type2.NODE_TARGET] = function(check, ele) { + return matches$1(check.target, ele) && ele.incomers().some(function(n) { + return n.isNode() && matches$1(check.source, n); + }); + }; + match[Type2.CHILD] = function(check, ele) { + return matches$1(check.child, ele) && matches$1(check.parent, ele.parent()); + }; + match[Type2.PARENT] = function(check, ele) { + return matches$1(check.parent, ele) && ele.children().some(function(c2) { + return matches$1(check.child, c2); + }); + }; + match[Type2.DESCENDANT] = function(check, ele) { + return matches$1(check.descendant, ele) && ele.ancestors().some(function(a) { + return matches$1(check.ancestor, a); + }); + }; + match[Type2.ANCESTOR] = function(check, ele) { + return matches$1(check.ancestor, ele) && ele.descendants().some(function(d) { + return matches$1(check.descendant, d); + }); + }; + match[Type2.COMPOUND_SPLIT] = function(check, ele) { + return matches$1(check.subject, ele) && matches$1(check.left, ele) && matches$1(check.right, ele); + }; + match[Type2.TRUE] = function() { + return true; + }; + match[Type2.COLLECTION] = function(check, ele) { + var collection2 = check.value; + return collection2.has(ele); + }; + match[Type2.FILTER] = function(check, ele) { + var filter3 = check.value; + return filter3(ele); + }; + var filter2 = function filter3(collection2) { + var self2 = this; + if (self2.length === 1 && self2[0].checks.length === 1 && self2[0].checks[0].type === Type2.ID) { + return collection2.getElementById(self2[0].checks[0].value).collection(); + } + var selectorFunction = function selectorFunction2(element3) { + for (var j = 0; j < self2.length; j++) { + var query = self2[j]; + if (matches$1(query, element3)) { + return true; + } + } + return false; + }; + if (self2.text() == null) { + selectorFunction = function selectorFunction2() { + return true; + }; + } + return collection2.filter(selectorFunction); + }; + var matches = function matches2(ele) { + var self2 = this; + for (var j = 0; j < self2.length; j++) { + var query = self2[j]; + if (matches$1(query, ele)) { + return true; + } + } + return false; + }; + var matching = { + matches, + filter: filter2 + }; + var Selector = function Selector2(selector2) { + this.inputText = selector2; + this.currentSubject = null; + this.compoundCount = 0; + this.edgeCount = 0; + this.length = 0; + if (selector2 == null || string2(selector2) && selector2.match(/^\s*$/)) + ; + else if (elementOrCollection(selector2)) { + this.addQuery({ + checks: [{ + type: Type2.COLLECTION, + value: selector2.collection() + }] + }); + } else if (fn$6(selector2)) { + this.addQuery({ + checks: [{ + type: Type2.FILTER, + value: selector2 + }] + }); + } else if (string2(selector2)) { + if (!this.parse(selector2)) { + this.invalid = true; + } + } else { + error("A selector must be created from a string; found "); + } + }; + var selfn = Selector.prototype; + [parse$12, matching].forEach(function(p2) { + return extend2(selfn, p2); + }); + selfn.text = function() { + return this.inputText; + }; + selfn.size = function() { + return this.length; + }; + selfn.eq = function(i3) { + return this[i3]; + }; + selfn.sameText = function(otherSel) { + return !this.invalid && !otherSel.invalid && this.text() === otherSel.text(); + }; + selfn.addQuery = function(q) { + this[this.length++] = q; + }; + selfn.selector = selfn.toString; + var elesfn$g = { + allAre: function allAre(selector2) { + var selObj = new Selector(selector2); + return this.every(function(ele) { + return selObj.matches(ele); + }); + }, + is: function is(selector2) { + var selObj = new Selector(selector2); + return this.some(function(ele) { + return selObj.matches(ele); + }); + }, + some: function some(fn2, thisArg) { + for (var i3 = 0; i3 < this.length; i3++) { + var ret = !thisArg ? fn2(this[i3], i3, this) : fn2.apply(thisArg, [this[i3], i3, this]); + if (ret) { + return true; + } + } + return false; + }, + every: function every(fn2, thisArg) { + for (var i3 = 0; i3 < this.length; i3++) { + var ret = !thisArg ? fn2(this[i3], i3, this) : fn2.apply(thisArg, [this[i3], i3, this]); + if (!ret) { + return false; + } + } + return true; + }, + same: function same(collection2) { + if (this === collection2) { + return true; + } + collection2 = this.cy().collection(collection2); + var thisLength = this.length; + var collectionLength = collection2.length; + if (thisLength !== collectionLength) { + return false; + } + if (thisLength === 1) { + return this[0] === collection2[0]; + } + return this.every(function(ele) { + return collection2.hasElementWithId(ele.id()); + }); + }, + anySame: function anySame(collection2) { + collection2 = this.cy().collection(collection2); + return this.some(function(ele) { + return collection2.hasElementWithId(ele.id()); + }); + }, + allAreNeighbors: function allAreNeighbors(collection2) { + collection2 = this.cy().collection(collection2); + var nhood = this.neighborhood(); + return collection2.every(function(ele) { + return nhood.hasElementWithId(ele.id()); + }); + }, + contains: function contains2(collection2) { + collection2 = this.cy().collection(collection2); + var self2 = this; + return collection2.every(function(ele) { + return self2.hasElementWithId(ele.id()); + }); + } + }; + elesfn$g.allAreNeighbours = elesfn$g.allAreNeighbors; + elesfn$g.has = elesfn$g.contains; + elesfn$g.equal = elesfn$g.equals = elesfn$g.same; + var cache = function cache2(fn2, name) { + return function traversalCache(arg1, arg2, arg3, arg4) { + var selectorOrEles = arg1; + var eles = this; + var key; + if (selectorOrEles == null) { + key = ""; + } else if (elementOrCollection(selectorOrEles) && selectorOrEles.length === 1) { + key = selectorOrEles.id(); + } + if (eles.length === 1 && key) { + var _p = eles[0]._private; + var tch = _p.traversalCache = _p.traversalCache || {}; + var ch2 = tch[name] = tch[name] || []; + var hash = hashString(key); + var cacheHit = ch2[hash]; + if (cacheHit) { + return cacheHit; + } else { + return ch2[hash] = fn2.call(eles, arg1, arg2, arg3, arg4); + } + } else { + return fn2.call(eles, arg1, arg2, arg3, arg4); + } + }; + }; + var elesfn$f = { + parent: function parent(selector2) { + var parents2 = []; + if (this.length === 1) { + var parent2 = this[0]._private.parent; + if (parent2) { + return parent2; + } + } + for (var i3 = 0; i3 < this.length; i3++) { + var ele = this[i3]; + var _parent = ele._private.parent; + if (_parent) { + parents2.push(_parent); + } + } + return this.spawn(parents2, true).filter(selector2); + }, + parents: function parents2(selector2) { + var parents3 = []; + var eles = this.parent(); + while (eles.nonempty()) { + for (var i3 = 0; i3 < eles.length; i3++) { + var ele = eles[i3]; + parents3.push(ele); + } + eles = eles.parent(); + } + return this.spawn(parents3, true).filter(selector2); + }, + commonAncestors: function commonAncestors(selector2) { + var ancestors; + for (var i3 = 0; i3 < this.length; i3++) { + var ele = this[i3]; + var parents2 = ele.parents(); + ancestors = ancestors || parents2; + ancestors = ancestors.intersect(parents2); + } + return ancestors.filter(selector2); + }, + orphans: function orphans(selector2) { + return this.stdFilter(function(ele) { + return ele.isOrphan(); + }).filter(selector2); + }, + nonorphans: function nonorphans(selector2) { + return this.stdFilter(function(ele) { + return ele.isChild(); + }).filter(selector2); + }, + children: cache(function(selector2) { + var children2 = []; + for (var i3 = 0; i3 < this.length; i3++) { + var ele = this[i3]; + var eleChildren = ele._private.children; + for (var j = 0; j < eleChildren.length; j++) { + children2.push(eleChildren[j]); + } + } + return this.spawn(children2, true).filter(selector2); + }, "children"), + siblings: function siblings(selector2) { + return this.parent().children().not(this).filter(selector2); + }, + isParent: function isParent() { + var ele = this[0]; + if (ele) { + return ele.isNode() && ele._private.children.length !== 0; + } + }, + isChildless: function isChildless() { + var ele = this[0]; + if (ele) { + return ele.isNode() && ele._private.children.length === 0; + } + }, + isChild: function isChild() { + var ele = this[0]; + if (ele) { + return ele.isNode() && ele._private.parent != null; + } + }, + isOrphan: function isOrphan() { + var ele = this[0]; + if (ele) { + return ele.isNode() && ele._private.parent == null; + } + }, + descendants: function descendants2(selector2) { + var elements2 = []; + function add(eles) { + for (var i3 = 0; i3 < eles.length; i3++) { + var ele = eles[i3]; + elements2.push(ele); + if (ele.children().nonempty()) { + add(ele.children()); + } + } + } + add(this.children()); + return this.spawn(elements2, true).filter(selector2); + } + }; + function forEachCompound(eles, fn2, includeSelf, recursiveStep) { + var q = []; + var did = new Set$12(); + var cy = eles.cy(); + var hasCompounds = cy.hasCompoundNodes(); + for (var i3 = 0; i3 < eles.length; i3++) { + var ele = eles[i3]; + if (includeSelf) { + q.push(ele); + } else if (hasCompounds) { + recursiveStep(q, did, ele); + } + } + while (q.length > 0) { + var _ele = q.shift(); + fn2(_ele); + did.add(_ele.id()); + if (hasCompounds) { + recursiveStep(q, did, _ele); + } + } + return eles; + } + function addChildren(q, did, ele) { + if (ele.isParent()) { + var children2 = ele._private.children; + for (var i3 = 0; i3 < children2.length; i3++) { + var child = children2[i3]; + if (!did.has(child.id())) { + q.push(child); + } + } + } + } + elesfn$f.forEachDown = function(fn2) { + var includeSelf = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : true; + return forEachCompound(this, fn2, includeSelf, addChildren); + }; + function addParent(q, did, ele) { + if (ele.isChild()) { + var parent = ele._private.parent; + if (!did.has(parent.id())) { + q.push(parent); + } + } + } + elesfn$f.forEachUp = function(fn2) { + var includeSelf = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : true; + return forEachCompound(this, fn2, includeSelf, addParent); + }; + function addParentAndChildren(q, did, ele) { + addParent(q, did, ele); + addChildren(q, did, ele); + } + elesfn$f.forEachUpAndDown = function(fn2) { + var includeSelf = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : true; + return forEachCompound(this, fn2, includeSelf, addParentAndChildren); + }; + elesfn$f.ancestors = elesfn$f.parents; + var fn$5, elesfn$e; + fn$5 = elesfn$e = { + data: define3.data({ + field: "data", + bindingEvent: "data", + allowBinding: true, + allowSetting: true, + settingEvent: "data", + settingTriggersEvent: true, + triggerFnName: "trigger", + allowGetting: true, + immutableKeys: { + "id": true, + "source": true, + "target": true, + "parent": true + }, + updateStyle: true + }), + removeData: define3.removeData({ + field: "data", + event: "data", + triggerFnName: "trigger", + triggerEvent: true, + immutableKeys: { + "id": true, + "source": true, + "target": true, + "parent": true + }, + updateStyle: true + }), + scratch: define3.data({ + field: "scratch", + bindingEvent: "scratch", + allowBinding: true, + allowSetting: true, + settingEvent: "scratch", + settingTriggersEvent: true, + triggerFnName: "trigger", + allowGetting: true, + updateStyle: true + }), + removeScratch: define3.removeData({ + field: "scratch", + event: "scratch", + triggerFnName: "trigger", + triggerEvent: true, + updateStyle: true + }), + rscratch: define3.data({ + field: "rscratch", + allowBinding: false, + allowSetting: true, + settingTriggersEvent: false, + allowGetting: true + }), + removeRscratch: define3.removeData({ + field: "rscratch", + triggerEvent: false + }), + id: function id2() { + var ele = this[0]; + if (ele) { + return ele._private.data.id; + } + } + }; + fn$5.attr = fn$5.data; + fn$5.removeAttr = fn$5.removeData; + var data = elesfn$e; + var elesfn$d = {}; + function defineDegreeFunction(callback) { + return function(includeLoops) { + var self2 = this; + if (includeLoops === void 0) { + includeLoops = true; + } + if (self2.length === 0) { + return; + } + if (self2.isNode() && !self2.removed()) { + var degree = 0; + var node2 = self2[0]; + var connectedEdges = node2._private.edges; + for (var i3 = 0; i3 < connectedEdges.length; i3++) { + var edge = connectedEdges[i3]; + if (!includeLoops && edge.isLoop()) { + continue; + } + degree += callback(node2, edge); + } + return degree; + } else { + return; + } + }; + } + extend2(elesfn$d, { + degree: defineDegreeFunction(function(node2, edge) { + if (edge.source().same(edge.target())) { + return 2; + } else { + return 1; + } + }), + indegree: defineDegreeFunction(function(node2, edge) { + if (edge.target().same(node2)) { + return 1; + } else { + return 0; + } + }), + outdegree: defineDegreeFunction(function(node2, edge) { + if (edge.source().same(node2)) { + return 1; + } else { + return 0; + } + }) + }); + function defineDegreeBoundsFunction(degreeFn, callback) { + return function(includeLoops) { + var ret; + var nodes2 = this.nodes(); + for (var i3 = 0; i3 < nodes2.length; i3++) { + var ele = nodes2[i3]; + var degree = ele[degreeFn](includeLoops); + if (degree !== void 0 && (ret === void 0 || callback(degree, ret))) { + ret = degree; + } + } + return ret; + }; + } + extend2(elesfn$d, { + minDegree: defineDegreeBoundsFunction("degree", function(degree, min3) { + return degree < min3; + }), + maxDegree: defineDegreeBoundsFunction("degree", function(degree, max3) { + return degree > max3; + }), + minIndegree: defineDegreeBoundsFunction("indegree", function(degree, min3) { + return degree < min3; + }), + maxIndegree: defineDegreeBoundsFunction("indegree", function(degree, max3) { + return degree > max3; + }), + minOutdegree: defineDegreeBoundsFunction("outdegree", function(degree, min3) { + return degree < min3; + }), + maxOutdegree: defineDegreeBoundsFunction("outdegree", function(degree, max3) { + return degree > max3; + }) + }); + extend2(elesfn$d, { + totalDegree: function totalDegree(includeLoops) { + var total = 0; + var nodes2 = this.nodes(); + for (var i3 = 0; i3 < nodes2.length; i3++) { + total += nodes2[i3].degree(includeLoops); + } + return total; + } + }); + var fn$4, elesfn$c; + var beforePositionSet = function beforePositionSet2(eles, newPos, silent) { + for (var i3 = 0; i3 < eles.length; i3++) { + var ele = eles[i3]; + if (!ele.locked()) { + var oldPos = ele._private.position; + var delta = { + x: newPos.x != null ? newPos.x - oldPos.x : 0, + y: newPos.y != null ? newPos.y - oldPos.y : 0 + }; + if (ele.isParent() && !(delta.x === 0 && delta.y === 0)) { + ele.children().shift(delta, silent); + } + ele.dirtyBoundingBoxCache(); + } + } + }; + var positionDef = { + field: "position", + bindingEvent: "position", + allowBinding: true, + allowSetting: true, + settingEvent: "position", + settingTriggersEvent: true, + triggerFnName: "emitAndNotify", + allowGetting: true, + validKeys: ["x", "y"], + beforeGet: function beforeGet(ele) { + ele.updateCompoundBounds(); + }, + beforeSet: function beforeSet(eles, newPos) { + beforePositionSet(eles, newPos, false); + }, + onSet: function onSet(eles) { + eles.dirtyCompoundBoundsCache(); + }, + canSet: function canSet(ele) { + return !ele.locked(); + } + }; + fn$4 = elesfn$c = { + position: define3.data(positionDef), + // position but no notification to renderer + silentPosition: define3.data(extend2({}, positionDef, { + allowBinding: false, + allowSetting: true, + settingTriggersEvent: false, + allowGetting: false, + beforeSet: function beforeSet(eles, newPos) { + beforePositionSet(eles, newPos, true); + }, + onSet: function onSet(eles) { + eles.dirtyCompoundBoundsCache(); + } + })), + positions: function positions(pos, silent) { + if (plainObject(pos)) { + if (silent) { + this.silentPosition(pos); + } else { + this.position(pos); + } + } else if (fn$6(pos)) { + var _fn = pos; + var cy = this.cy(); + cy.startBatch(); + for (var i3 = 0; i3 < this.length; i3++) { + var ele = this[i3]; + var _pos = void 0; + if (_pos = _fn(ele, i3)) { + if (silent) { + ele.silentPosition(_pos); + } else { + ele.position(_pos); + } + } + } + cy.endBatch(); + } + return this; + }, + silentPositions: function silentPositions(pos) { + return this.positions(pos, true); + }, + shift: function shift(dim, val, silent) { + var delta; + if (plainObject(dim)) { + delta = { + x: number$12(dim.x) ? dim.x : 0, + y: number$12(dim.y) ? dim.y : 0 + }; + silent = val; + } else if (string2(dim) && number$12(val)) { + delta = { + x: 0, + y: 0 + }; + delta[dim] = val; + } + if (delta != null) { + var cy = this.cy(); + cy.startBatch(); + for (var i3 = 0; i3 < this.length; i3++) { + var ele = this[i3]; + if (cy.hasCompoundNodes() && ele.isChild() && ele.ancestors().anySame(this)) { + continue; + } + var pos = ele.position(); + var newPos = { + x: pos.x + delta.x, + y: pos.y + delta.y + }; + if (silent) { + ele.silentPosition(newPos); + } else { + ele.position(newPos); + } + } + cy.endBatch(); + } + return this; + }, + silentShift: function silentShift(dim, val) { + if (plainObject(dim)) { + this.shift(dim, true); + } else if (string2(dim) && number$12(val)) { + this.shift(dim, val, true); + } + return this; + }, + // get/set the rendered (i.e. on screen) positon of the element + renderedPosition: function renderedPosition(dim, val) { + var ele = this[0]; + var cy = this.cy(); + var zoom = cy.zoom(); + var pan = cy.pan(); + var rpos = plainObject(dim) ? dim : void 0; + var setting = rpos !== void 0 || val !== void 0 && string2(dim); + if (ele && ele.isNode()) { + if (setting) { + for (var i3 = 0; i3 < this.length; i3++) { + var _ele = this[i3]; + if (val !== void 0) { + _ele.position(dim, (val - pan[dim]) / zoom); + } else if (rpos !== void 0) { + _ele.position(renderedToModelPosition(rpos, zoom, pan)); + } + } + } else { + var pos = ele.position(); + rpos = modelToRenderedPosition(pos, zoom, pan); + if (dim === void 0) { + return rpos; + } else { + return rpos[dim]; + } + } + } else if (!setting) { + return void 0; + } + return this; + }, + // get/set the position relative to the parent + relativePosition: function relativePosition(dim, val) { + var ele = this[0]; + var cy = this.cy(); + var ppos = plainObject(dim) ? dim : void 0; + var setting = ppos !== void 0 || val !== void 0 && string2(dim); + var hasCompoundNodes = cy.hasCompoundNodes(); + if (ele && ele.isNode()) { + if (setting) { + for (var i3 = 0; i3 < this.length; i3++) { + var _ele2 = this[i3]; + var parent = hasCompoundNodes ? _ele2.parent() : null; + var hasParent = parent && parent.length > 0; + var relativeToParent = hasParent; + if (hasParent) { + parent = parent[0]; + } + var origin = relativeToParent ? parent.position() : { + x: 0, + y: 0 + }; + if (val !== void 0) { + _ele2.position(dim, val + origin[dim]); + } else if (ppos !== void 0) { + _ele2.position({ + x: ppos.x + origin.x, + y: ppos.y + origin.y + }); + } + } + } else { + var pos = ele.position(); + var _parent = hasCompoundNodes ? ele.parent() : null; + var _hasParent = _parent && _parent.length > 0; + var _relativeToParent = _hasParent; + if (_hasParent) { + _parent = _parent[0]; + } + var _origin = _relativeToParent ? _parent.position() : { + x: 0, + y: 0 + }; + ppos = { + x: pos.x - _origin.x, + y: pos.y - _origin.y + }; + if (dim === void 0) { + return ppos; + } else { + return ppos[dim]; + } + } + } else if (!setting) { + return void 0; + } + return this; + } + }; + fn$4.modelPosition = fn$4.point = fn$4.position; + fn$4.modelPositions = fn$4.points = fn$4.positions; + fn$4.renderedPoint = fn$4.renderedPosition; + fn$4.relativePoint = fn$4.relativePosition; + var position2 = elesfn$c; + var fn$3, elesfn$b; + fn$3 = elesfn$b = {}; + elesfn$b.renderedBoundingBox = function(options2) { + var bb = this.boundingBox(options2); + var cy = this.cy(); + var zoom = cy.zoom(); + var pan = cy.pan(); + var x1 = bb.x1 * zoom + pan.x; + var x2 = bb.x2 * zoom + pan.x; + var y1 = bb.y1 * zoom + pan.y; + var y2 = bb.y2 * zoom + pan.y; + return { + x1, + x2, + y1, + y2, + w: x2 - x1, + h: y2 - y1 + }; + }; + elesfn$b.dirtyCompoundBoundsCache = function() { + var silent = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : false; + var cy = this.cy(); + if (!cy.styleEnabled() || !cy.hasCompoundNodes()) { + return this; + } + this.forEachUp(function(ele) { + if (ele.isParent()) { + var _p = ele._private; + _p.compoundBoundsClean = false; + _p.bbCache = null; + if (!silent) { + ele.emitAndNotify("bounds"); + } + } + }); + return this; + }; + elesfn$b.updateCompoundBounds = function() { + var force = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : false; + var cy = this.cy(); + if (!cy.styleEnabled() || !cy.hasCompoundNodes()) { + return this; + } + if (!force && cy.batching()) { + return this; + } + function update2(parent) { + if (!parent.isParent()) { + return; + } + var _p2 = parent._private; + var children2 = parent.children(); + var includeLabels = parent.pstyle("compound-sizing-wrt-labels").value === "include"; + var min3 = { + width: { + val: parent.pstyle("min-width").pfValue, + left: parent.pstyle("min-width-bias-left"), + right: parent.pstyle("min-width-bias-right") + }, + height: { + val: parent.pstyle("min-height").pfValue, + top: parent.pstyle("min-height-bias-top"), + bottom: parent.pstyle("min-height-bias-bottom") + } + }; + var bb = children2.boundingBox({ + includeLabels, + includeOverlays: false, + // updating the compound bounds happens outside of the regular + // cache cycle (i.e. before fired events) + useCache: false + }); + var pos = _p2.position; + if (bb.w === 0 || bb.h === 0) { + bb = { + w: parent.pstyle("width").pfValue, + h: parent.pstyle("height").pfValue + }; + bb.x1 = pos.x - bb.w / 2; + bb.x2 = pos.x + bb.w / 2; + bb.y1 = pos.y - bb.h / 2; + bb.y2 = pos.y + bb.h / 2; + } + function computeBiasValues(propDiff, propBias, propBiasComplement) { + var biasDiff = 0; + var biasComplementDiff = 0; + var biasTotal = propBias + propBiasComplement; + if (propDiff > 0 && biasTotal > 0) { + biasDiff = propBias / biasTotal * propDiff; + biasComplementDiff = propBiasComplement / biasTotal * propDiff; + } + return { + biasDiff, + biasComplementDiff + }; + } + function computePaddingValues(width2, height, paddingObject, relativeTo) { + if (paddingObject.units === "%") { + switch (relativeTo) { + case "width": + return width2 > 0 ? paddingObject.pfValue * width2 : 0; + case "height": + return height > 0 ? paddingObject.pfValue * height : 0; + case "average": + return width2 > 0 && height > 0 ? paddingObject.pfValue * (width2 + height) / 2 : 0; + case "min": + return width2 > 0 && height > 0 ? width2 > height ? paddingObject.pfValue * height : paddingObject.pfValue * width2 : 0; + case "max": + return width2 > 0 && height > 0 ? width2 > height ? paddingObject.pfValue * width2 : paddingObject.pfValue * height : 0; + default: + return 0; + } + } else if (paddingObject.units === "px") { + return paddingObject.pfValue; + } else { + return 0; + } + } + var leftVal = min3.width.left.value; + if (min3.width.left.units === "px" && min3.width.val > 0) { + leftVal = leftVal * 100 / min3.width.val; + } + var rightVal = min3.width.right.value; + if (min3.width.right.units === "px" && min3.width.val > 0) { + rightVal = rightVal * 100 / min3.width.val; + } + var topVal = min3.height.top.value; + if (min3.height.top.units === "px" && min3.height.val > 0) { + topVal = topVal * 100 / min3.height.val; + } + var bottomVal = min3.height.bottom.value; + if (min3.height.bottom.units === "px" && min3.height.val > 0) { + bottomVal = bottomVal * 100 / min3.height.val; + } + var widthBiasDiffs = computeBiasValues(min3.width.val - bb.w, leftVal, rightVal); + var diffLeft = widthBiasDiffs.biasDiff; + var diffRight = widthBiasDiffs.biasComplementDiff; + var heightBiasDiffs = computeBiasValues(min3.height.val - bb.h, topVal, bottomVal); + var diffTop = heightBiasDiffs.biasDiff; + var diffBottom = heightBiasDiffs.biasComplementDiff; + _p2.autoPadding = computePaddingValues(bb.w, bb.h, parent.pstyle("padding"), parent.pstyle("padding-relative-to").value); + _p2.autoWidth = Math.max(bb.w, min3.width.val); + pos.x = (-diffLeft + bb.x1 + bb.x2 + diffRight) / 2; + _p2.autoHeight = Math.max(bb.h, min3.height.val); + pos.y = (-diffTop + bb.y1 + bb.y2 + diffBottom) / 2; + } + for (var i3 = 0; i3 < this.length; i3++) { + var ele = this[i3]; + var _p = ele._private; + if (!_p.compoundBoundsClean || force) { + update2(ele); + if (!cy.batching()) { + _p.compoundBoundsClean = true; + } + } + } + return this; + }; + var noninf = function noninf2(x2) { + if (x2 === Infinity || x2 === -Infinity) { + return 0; + } + return x2; + }; + var updateBounds = function updateBounds2(b, x1, y1, x2, y2) { + if (x2 - x1 === 0 || y2 - y1 === 0) { + return; + } + if (x1 == null || y1 == null || x2 == null || y2 == null) { + return; + } + b.x1 = x1 < b.x1 ? x1 : b.x1; + b.x2 = x2 > b.x2 ? x2 : b.x2; + b.y1 = y1 < b.y1 ? y1 : b.y1; + b.y2 = y2 > b.y2 ? y2 : b.y2; + b.w = b.x2 - b.x1; + b.h = b.y2 - b.y1; + }; + var updateBoundsFromBox = function updateBoundsFromBox2(b, b2) { + if (b2 == null) { + return b; + } + return updateBounds(b, b2.x1, b2.y1, b2.x2, b2.y2); + }; + var prefixedProperty = function prefixedProperty2(obj, field, prefix) { + return getPrefixedProperty(obj, field, prefix); + }; + var updateBoundsFromArrow = function updateBoundsFromArrow2(bounds3, ele, prefix) { + if (ele.cy().headless()) { + return; + } + var _p = ele._private; + var rstyle = _p.rstyle; + var halfArW = rstyle.arrowWidth / 2; + var arrowType = ele.pstyle(prefix + "-arrow-shape").value; + var x2; + var y2; + if (arrowType !== "none") { + if (prefix === "source") { + x2 = rstyle.srcX; + y2 = rstyle.srcY; + } else if (prefix === "target") { + x2 = rstyle.tgtX; + y2 = rstyle.tgtY; + } else { + x2 = rstyle.midX; + y2 = rstyle.midY; + } + var bbs = _p.arrowBounds = _p.arrowBounds || {}; + var bb = bbs[prefix] = bbs[prefix] || {}; + bb.x1 = x2 - halfArW; + bb.y1 = y2 - halfArW; + bb.x2 = x2 + halfArW; + bb.y2 = y2 + halfArW; + bb.w = bb.x2 - bb.x1; + bb.h = bb.y2 - bb.y1; + expandBoundingBox(bb, 1); + updateBounds(bounds3, bb.x1, bb.y1, bb.x2, bb.y2); + } + }; + var updateBoundsFromLabel = function updateBoundsFromLabel2(bounds3, ele, prefix) { + if (ele.cy().headless()) { + return; + } + var prefixDash; + if (prefix) { + prefixDash = prefix + "-"; + } else { + prefixDash = ""; + } + var _p = ele._private; + var rstyle = _p.rstyle; + var label = ele.pstyle(prefixDash + "label").strValue; + if (label) { + var halign = ele.pstyle("text-halign"); + var valign = ele.pstyle("text-valign"); + var labelWidth = prefixedProperty(rstyle, "labelWidth", prefix); + var labelHeight = prefixedProperty(rstyle, "labelHeight", prefix); + var labelX = prefixedProperty(rstyle, "labelX", prefix); + var labelY = prefixedProperty(rstyle, "labelY", prefix); + var marginX = ele.pstyle(prefixDash + "text-margin-x").pfValue; + var marginY = ele.pstyle(prefixDash + "text-margin-y").pfValue; + var isEdge = ele.isEdge(); + var rotation = ele.pstyle(prefixDash + "text-rotation"); + var outlineWidth = ele.pstyle("text-outline-width").pfValue; + var borderWidth = ele.pstyle("text-border-width").pfValue; + var halfBorderWidth = borderWidth / 2; + var padding2 = ele.pstyle("text-background-padding").pfValue; + var marginOfError = 2; + var lh = labelHeight; + var lw = labelWidth; + var lw_2 = lw / 2; + var lh_2 = lh / 2; + var lx1, lx2, ly1, ly2; + if (isEdge) { + lx1 = labelX - lw_2; + lx2 = labelX + lw_2; + ly1 = labelY - lh_2; + ly2 = labelY + lh_2; + } else { + switch (halign.value) { + case "left": + lx1 = labelX - lw; + lx2 = labelX; + break; + case "center": + lx1 = labelX - lw_2; + lx2 = labelX + lw_2; + break; + case "right": + lx1 = labelX; + lx2 = labelX + lw; + break; + } + switch (valign.value) { + case "top": + ly1 = labelY - lh; + ly2 = labelY; + break; + case "center": + ly1 = labelY - lh_2; + ly2 = labelY + lh_2; + break; + case "bottom": + ly1 = labelY; + ly2 = labelY + lh; + break; + } + } + lx1 += marginX - Math.max(outlineWidth, halfBorderWidth) - padding2 - marginOfError; + lx2 += marginX + Math.max(outlineWidth, halfBorderWidth) + padding2 + marginOfError; + ly1 += marginY - Math.max(outlineWidth, halfBorderWidth) - padding2 - marginOfError; + ly2 += marginY + Math.max(outlineWidth, halfBorderWidth) + padding2 + marginOfError; + var bbPrefix = prefix || "main"; + var bbs = _p.labelBounds; + var bb = bbs[bbPrefix] = bbs[bbPrefix] || {}; + bb.x1 = lx1; + bb.y1 = ly1; + bb.x2 = lx2; + bb.y2 = ly2; + bb.w = lx2 - lx1; + bb.h = ly2 - ly1; + var isAutorotate = isEdge && rotation.strValue === "autorotate"; + var isPfValue = rotation.pfValue != null && rotation.pfValue !== 0; + if (isAutorotate || isPfValue) { + var theta = isAutorotate ? prefixedProperty(_p.rstyle, "labelAngle", prefix) : rotation.pfValue; + var cos3 = Math.cos(theta); + var sin3 = Math.sin(theta); + var xo = (lx1 + lx2) / 2; + var yo = (ly1 + ly2) / 2; + if (!isEdge) { + switch (halign.value) { + case "left": + xo = lx2; + break; + case "right": + xo = lx1; + break; + } + switch (valign.value) { + case "top": + yo = ly2; + break; + case "bottom": + yo = ly1; + break; + } + } + var rotate = function rotate2(x2, y2) { + x2 = x2 - xo; + y2 = y2 - yo; + return { + x: x2 * cos3 - y2 * sin3 + xo, + y: x2 * sin3 + y2 * cos3 + yo + }; + }; + var px1y1 = rotate(lx1, ly1); + var px1y2 = rotate(lx1, ly2); + var px2y1 = rotate(lx2, ly1); + var px2y2 = rotate(lx2, ly2); + lx1 = Math.min(px1y1.x, px1y2.x, px2y1.x, px2y2.x); + lx2 = Math.max(px1y1.x, px1y2.x, px2y1.x, px2y2.x); + ly1 = Math.min(px1y1.y, px1y2.y, px2y1.y, px2y2.y); + ly2 = Math.max(px1y1.y, px1y2.y, px2y1.y, px2y2.y); + } + var bbPrefixRot = bbPrefix + "Rot"; + var bbRot = bbs[bbPrefixRot] = bbs[bbPrefixRot] || {}; + bbRot.x1 = lx1; + bbRot.y1 = ly1; + bbRot.x2 = lx2; + bbRot.y2 = ly2; + bbRot.w = lx2 - lx1; + bbRot.h = ly2 - ly1; + updateBounds(bounds3, lx1, ly1, lx2, ly2); + updateBounds(_p.labelBounds.all, lx1, ly1, lx2, ly2); + } + return bounds3; + }; + var updateBoundsFromOutline = function updateBoundsFromOutline2(bounds3, ele) { + if (ele.cy().headless()) { + return; + } + var outlineOpacity = ele.pstyle("outline-opacity").value; + var outlineWidth = ele.pstyle("outline-width").value; + if (outlineOpacity > 0 && outlineWidth > 0) { + var outlineOffset = ele.pstyle("outline-offset").value; + var nodeShape = ele.pstyle("shape").value; + var outlineSize = outlineWidth + outlineOffset; + var scaleX = (bounds3.w + outlineSize * 2) / bounds3.w; + var scaleY = (bounds3.h + outlineSize * 2) / bounds3.h; + var xOffset = 0; + var yOffset = 0; + if (["diamond", "pentagon", "round-triangle"].includes(nodeShape)) { + scaleX = (bounds3.w + outlineSize * 2.4) / bounds3.w; + yOffset = -outlineSize / 3.6; + } else if (["concave-hexagon", "rhomboid", "right-rhomboid"].includes(nodeShape)) { + scaleX = (bounds3.w + outlineSize * 2.4) / bounds3.w; + } else if (nodeShape === "star") { + scaleX = (bounds3.w + outlineSize * 2.8) / bounds3.w; + scaleY = (bounds3.h + outlineSize * 2.6) / bounds3.h; + yOffset = -outlineSize / 3.8; + } else if (nodeShape === "triangle") { + scaleX = (bounds3.w + outlineSize * 2.8) / bounds3.w; + scaleY = (bounds3.h + outlineSize * 2.4) / bounds3.h; + yOffset = -outlineSize / 1.4; + } else if (nodeShape === "vee") { + scaleX = (bounds3.w + outlineSize * 4.4) / bounds3.w; + scaleY = (bounds3.h + outlineSize * 3.8) / bounds3.h; + yOffset = -outlineSize * 0.5; + } + var hDelta = bounds3.h * scaleY - bounds3.h; + var wDelta = bounds3.w * scaleX - bounds3.w; + expandBoundingBoxSides(bounds3, [Math.ceil(hDelta / 2), Math.ceil(wDelta / 2)]); + if (xOffset != 0 || yOffset !== 0) { + var oBounds = shiftBoundingBox(bounds3, xOffset, yOffset); + updateBoundingBox(bounds3, oBounds); + } + } + }; + var boundingBoxImpl = function boundingBoxImpl2(ele, options2) { + var cy = ele._private.cy; + var styleEnabled = cy.styleEnabled(); + var headless = cy.headless(); + var bounds3 = makeBoundingBox(); + var _p = ele._private; + var isNode = ele.isNode(); + var isEdge = ele.isEdge(); + var ex1, ex2, ey1, ey2; + var x2, y2; + var rstyle = _p.rstyle; + var manualExpansion = isNode && styleEnabled ? ele.pstyle("bounds-expansion").pfValue : [0]; + var isDisplayed = function isDisplayed2(ele2) { + return ele2.pstyle("display").value !== "none"; + }; + var displayed = !styleEnabled || isDisplayed(ele) && (!isEdge || isDisplayed(ele.source()) && isDisplayed(ele.target())); + if (displayed) { + var overlayOpacity = 0; + var overlayPadding = 0; + if (styleEnabled && options2.includeOverlays) { + overlayOpacity = ele.pstyle("overlay-opacity").value; + if (overlayOpacity !== 0) { + overlayPadding = ele.pstyle("overlay-padding").value; + } + } + var underlayOpacity = 0; + var underlayPadding = 0; + if (styleEnabled && options2.includeUnderlays) { + underlayOpacity = ele.pstyle("underlay-opacity").value; + if (underlayOpacity !== 0) { + underlayPadding = ele.pstyle("underlay-padding").value; + } + } + var padding2 = Math.max(overlayPadding, underlayPadding); + var w2 = 0; + var wHalf = 0; + if (styleEnabled) { + w2 = ele.pstyle("width").pfValue; + wHalf = w2 / 2; + } + if (isNode && options2.includeNodes) { + var pos = ele.position(); + x2 = pos.x; + y2 = pos.y; + var _w = ele.outerWidth(); + var halfW = _w / 2; + var h = ele.outerHeight(); + var halfH = h / 2; + ex1 = x2 - halfW; + ex2 = x2 + halfW; + ey1 = y2 - halfH; + ey2 = y2 + halfH; + updateBounds(bounds3, ex1, ey1, ex2, ey2); + if (styleEnabled && options2.includeOutlines) { + updateBoundsFromOutline(bounds3, ele); + } + } else if (isEdge && options2.includeEdges) { + if (styleEnabled && !headless) { + var curveStyle = ele.pstyle("curve-style").strValue; + ex1 = Math.min(rstyle.srcX, rstyle.midX, rstyle.tgtX); + ex2 = Math.max(rstyle.srcX, rstyle.midX, rstyle.tgtX); + ey1 = Math.min(rstyle.srcY, rstyle.midY, rstyle.tgtY); + ey2 = Math.max(rstyle.srcY, rstyle.midY, rstyle.tgtY); + ex1 -= wHalf; + ex2 += wHalf; + ey1 -= wHalf; + ey2 += wHalf; + updateBounds(bounds3, ex1, ey1, ex2, ey2); + if (curveStyle === "haystack") { + var hpts = rstyle.haystackPts; + if (hpts && hpts.length === 2) { + ex1 = hpts[0].x; + ey1 = hpts[0].y; + ex2 = hpts[1].x; + ey2 = hpts[1].y; + if (ex1 > ex2) { + var temp = ex1; + ex1 = ex2; + ex2 = temp; + } + if (ey1 > ey2) { + var _temp = ey1; + ey1 = ey2; + ey2 = _temp; + } + updateBounds(bounds3, ex1 - wHalf, ey1 - wHalf, ex2 + wHalf, ey2 + wHalf); + } + } else if (curveStyle === "bezier" || curveStyle === "unbundled-bezier" || curveStyle === "segments" || curveStyle === "taxi") { + var pts2; + switch (curveStyle) { + case "bezier": + case "unbundled-bezier": + pts2 = rstyle.bezierPts; + break; + case "segments": + case "taxi": + pts2 = rstyle.linePts; + break; + } + if (pts2 != null) { + for (var j = 0; j < pts2.length; j++) { + var pt = pts2[j]; + ex1 = pt.x - wHalf; + ex2 = pt.x + wHalf; + ey1 = pt.y - wHalf; + ey2 = pt.y + wHalf; + updateBounds(bounds3, ex1, ey1, ex2, ey2); + } + } + } + } else { + var n1 = ele.source(); + var n1pos = n1.position(); + var n2 = ele.target(); + var n2pos = n2.position(); + ex1 = n1pos.x; + ex2 = n2pos.x; + ey1 = n1pos.y; + ey2 = n2pos.y; + if (ex1 > ex2) { + var _temp2 = ex1; + ex1 = ex2; + ex2 = _temp2; + } + if (ey1 > ey2) { + var _temp3 = ey1; + ey1 = ey2; + ey2 = _temp3; + } + ex1 -= wHalf; + ex2 += wHalf; + ey1 -= wHalf; + ey2 += wHalf; + updateBounds(bounds3, ex1, ey1, ex2, ey2); + } + } + if (styleEnabled && options2.includeEdges && isEdge) { + updateBoundsFromArrow(bounds3, ele, "mid-source"); + updateBoundsFromArrow(bounds3, ele, "mid-target"); + updateBoundsFromArrow(bounds3, ele, "source"); + updateBoundsFromArrow(bounds3, ele, "target"); + } + if (styleEnabled) { + var ghost = ele.pstyle("ghost").value === "yes"; + if (ghost) { + var gx = ele.pstyle("ghost-offset-x").pfValue; + var gy = ele.pstyle("ghost-offset-y").pfValue; + updateBounds(bounds3, bounds3.x1 + gx, bounds3.y1 + gy, bounds3.x2 + gx, bounds3.y2 + gy); + } + } + var bbBody = _p.bodyBounds = _p.bodyBounds || {}; + assignBoundingBox(bbBody, bounds3); + expandBoundingBoxSides(bbBody, manualExpansion); + expandBoundingBox(bbBody, 1); + if (styleEnabled) { + ex1 = bounds3.x1; + ex2 = bounds3.x2; + ey1 = bounds3.y1; + ey2 = bounds3.y2; + updateBounds(bounds3, ex1 - padding2, ey1 - padding2, ex2 + padding2, ey2 + padding2); + } + var bbOverlay = _p.overlayBounds = _p.overlayBounds || {}; + assignBoundingBox(bbOverlay, bounds3); + expandBoundingBoxSides(bbOverlay, manualExpansion); + expandBoundingBox(bbOverlay, 1); + var bbLabels = _p.labelBounds = _p.labelBounds || {}; + if (bbLabels.all != null) { + clearBoundingBox(bbLabels.all); + } else { + bbLabels.all = makeBoundingBox(); + } + if (styleEnabled && options2.includeLabels) { + if (options2.includeMainLabels) { + updateBoundsFromLabel(bounds3, ele, null); + } + if (isEdge) { + if (options2.includeSourceLabels) { + updateBoundsFromLabel(bounds3, ele, "source"); + } + if (options2.includeTargetLabels) { + updateBoundsFromLabel(bounds3, ele, "target"); + } + } + } + } + bounds3.x1 = noninf(bounds3.x1); + bounds3.y1 = noninf(bounds3.y1); + bounds3.x2 = noninf(bounds3.x2); + bounds3.y2 = noninf(bounds3.y2); + bounds3.w = noninf(bounds3.x2 - bounds3.x1); + bounds3.h = noninf(bounds3.y2 - bounds3.y1); + if (bounds3.w > 0 && bounds3.h > 0 && displayed) { + expandBoundingBoxSides(bounds3, manualExpansion); + expandBoundingBox(bounds3, 1); + } + return bounds3; + }; + var getKey = function getKey2(opts) { + var i3 = 0; + var tf = function tf2(val) { + return (val ? 1 : 0) << i3++; + }; + var key = 0; + key += tf(opts.incudeNodes); + key += tf(opts.includeEdges); + key += tf(opts.includeLabels); + key += tf(opts.includeMainLabels); + key += tf(opts.includeSourceLabels); + key += tf(opts.includeTargetLabels); + key += tf(opts.includeOverlays); + key += tf(opts.includeOutlines); + return key; + }; + var getBoundingBoxPosKey = function getBoundingBoxPosKey2(ele) { + if (ele.isEdge()) { + var p1 = ele.source().position(); + var p2 = ele.target().position(); + var r = function r2(x2) { + return Math.round(x2); + }; + return hashIntsArray([r(p1.x), r(p1.y), r(p2.x), r(p2.y)]); + } else { + return 0; + } + }; + var cachedBoundingBoxImpl = function cachedBoundingBoxImpl2(ele, opts) { + var _p = ele._private; + var bb; + var isEdge = ele.isEdge(); + var key = opts == null ? defBbOptsKey : getKey(opts); + var usingDefOpts = key === defBbOptsKey; + var currPosKey = getBoundingBoxPosKey(ele); + var isPosKeySame = _p.bbCachePosKey === currPosKey; + var useCache = opts.useCache && isPosKeySame; + var isDirty = function isDirty2(ele2) { + return ele2._private.bbCache == null || ele2._private.styleDirty; + }; + var needRecalc = !useCache || isDirty(ele) || isEdge && isDirty(ele.source()) || isDirty(ele.target()); + if (needRecalc) { + if (!isPosKeySame) { + ele.recalculateRenderedStyle(useCache); + } + bb = boundingBoxImpl(ele, defBbOpts); + _p.bbCache = bb; + _p.bbCachePosKey = currPosKey; + } else { + bb = _p.bbCache; + } + if (!usingDefOpts) { + var isNode = ele.isNode(); + bb = makeBoundingBox(); + if (opts.includeNodes && isNode || opts.includeEdges && !isNode) { + if (opts.includeOverlays) { + updateBoundsFromBox(bb, _p.overlayBounds); + } else { + updateBoundsFromBox(bb, _p.bodyBounds); + } + } + if (opts.includeLabels) { + if (opts.includeMainLabels && (!isEdge || opts.includeSourceLabels && opts.includeTargetLabels)) { + updateBoundsFromBox(bb, _p.labelBounds.all); + } else { + if (opts.includeMainLabels) { + updateBoundsFromBox(bb, _p.labelBounds.mainRot); + } + if (opts.includeSourceLabels) { + updateBoundsFromBox(bb, _p.labelBounds.sourceRot); + } + if (opts.includeTargetLabels) { + updateBoundsFromBox(bb, _p.labelBounds.targetRot); + } + } + } + bb.w = bb.x2 - bb.x1; + bb.h = bb.y2 - bb.y1; + } + return bb; + }; + var defBbOpts = { + includeNodes: true, + includeEdges: true, + includeLabels: true, + includeMainLabels: true, + includeSourceLabels: true, + includeTargetLabels: true, + includeOverlays: true, + includeUnderlays: true, + includeOutlines: true, + useCache: true + }; + var defBbOptsKey = getKey(defBbOpts); + var filledBbOpts = defaults$g(defBbOpts); + elesfn$b.boundingBox = function(options2) { + var bounds3; + if (this.length === 1 && this[0]._private.bbCache != null && !this[0]._private.styleDirty && (options2 === void 0 || options2.useCache === void 0 || options2.useCache === true)) { + if (options2 === void 0) { + options2 = defBbOpts; + } else { + options2 = filledBbOpts(options2); + } + bounds3 = cachedBoundingBoxImpl(this[0], options2); + } else { + bounds3 = makeBoundingBox(); + options2 = options2 || defBbOpts; + var opts = filledBbOpts(options2); + var eles = this; + var cy = eles.cy(); + var styleEnabled = cy.styleEnabled(); + if (styleEnabled) { + for (var i3 = 0; i3 < eles.length; i3++) { + var ele = eles[i3]; + var _p = ele._private; + var currPosKey = getBoundingBoxPosKey(ele); + var isPosKeySame = _p.bbCachePosKey === currPosKey; + var useCache = opts.useCache && isPosKeySame && !_p.styleDirty; + ele.recalculateRenderedStyle(useCache); + } + } + this.updateCompoundBounds(!options2.useCache); + for (var _i6 = 0; _i6 < eles.length; _i6++) { + var _ele = eles[_i6]; + updateBoundsFromBox(bounds3, cachedBoundingBoxImpl(_ele, opts)); + } + } + bounds3.x1 = noninf(bounds3.x1); + bounds3.y1 = noninf(bounds3.y1); + bounds3.x2 = noninf(bounds3.x2); + bounds3.y2 = noninf(bounds3.y2); + bounds3.w = noninf(bounds3.x2 - bounds3.x1); + bounds3.h = noninf(bounds3.y2 - bounds3.y1); + return bounds3; + }; + elesfn$b.dirtyBoundingBoxCache = function() { + for (var i3 = 0; i3 < this.length; i3++) { + var _p = this[i3]._private; + _p.bbCache = null; + _p.bbCachePosKey = null; + _p.bodyBounds = null; + _p.overlayBounds = null; + _p.labelBounds.all = null; + _p.labelBounds.source = null; + _p.labelBounds.target = null; + _p.labelBounds.main = null; + _p.labelBounds.sourceRot = null; + _p.labelBounds.targetRot = null; + _p.labelBounds.mainRot = null; + _p.arrowBounds.source = null; + _p.arrowBounds.target = null; + _p.arrowBounds["mid-source"] = null; + _p.arrowBounds["mid-target"] = null; + } + this.emitAndNotify("bounds"); + return this; + }; + elesfn$b.boundingBoxAt = function(fn2) { + var nodes2 = this.nodes(); + var cy = this.cy(); + var hasCompoundNodes = cy.hasCompoundNodes(); + var parents2 = cy.collection(); + if (hasCompoundNodes) { + parents2 = nodes2.filter(function(node2) { + return node2.isParent(); + }); + nodes2 = nodes2.not(parents2); + } + if (plainObject(fn2)) { + var obj = fn2; + fn2 = function fn3() { + return obj; + }; + } + var storeOldPos = function storeOldPos2(node2, i3) { + return node2._private.bbAtOldPos = fn2(node2, i3); + }; + var getOldPos = function getOldPos2(node2) { + return node2._private.bbAtOldPos; + }; + cy.startBatch(); + nodes2.forEach(storeOldPos).silentPositions(fn2); + if (hasCompoundNodes) { + parents2.dirtyCompoundBoundsCache(); + parents2.dirtyBoundingBoxCache(); + parents2.updateCompoundBounds(true); + } + var bb = copyBoundingBox(this.boundingBox({ + useCache: false + })); + nodes2.silentPositions(getOldPos); + if (hasCompoundNodes) { + parents2.dirtyCompoundBoundsCache(); + parents2.dirtyBoundingBoxCache(); + parents2.updateCompoundBounds(true); + } + cy.endBatch(); + return bb; + }; + fn$3.boundingbox = fn$3.bb = fn$3.boundingBox; + fn$3.renderedBoundingbox = fn$3.renderedBoundingBox; + var bounds2 = elesfn$b; + var fn$2, elesfn$a; + fn$2 = elesfn$a = {}; + var defineDimFns = function defineDimFns2(opts) { + opts.uppercaseName = capitalize(opts.name); + opts.autoName = "auto" + opts.uppercaseName; + opts.labelName = "label" + opts.uppercaseName; + opts.outerName = "outer" + opts.uppercaseName; + opts.uppercaseOuterName = capitalize(opts.outerName); + fn$2[opts.name] = function dimImpl() { + var ele = this[0]; + var _p = ele._private; + var cy = _p.cy; + var styleEnabled = cy._private.styleEnabled; + if (ele) { + if (styleEnabled) { + if (ele.isParent()) { + ele.updateCompoundBounds(); + return _p[opts.autoName] || 0; + } + var d = ele.pstyle(opts.name); + switch (d.strValue) { + case "label": + ele.recalculateRenderedStyle(); + return _p.rstyle[opts.labelName] || 0; + default: + return d.pfValue; + } + } else { + return 1; + } + } + }; + fn$2["outer" + opts.uppercaseName] = function outerDimImpl() { + var ele = this[0]; + var _p = ele._private; + var cy = _p.cy; + var styleEnabled = cy._private.styleEnabled; + if (ele) { + if (styleEnabled) { + var dim = ele[opts.name](); + var border = ele.pstyle("border-width").pfValue; + var padding2 = 2 * ele.padding(); + return dim + border + padding2; + } else { + return 1; + } + } + }; + fn$2["rendered" + opts.uppercaseName] = function renderedDimImpl() { + var ele = this[0]; + if (ele) { + var d = ele[opts.name](); + return d * this.cy().zoom(); + } + }; + fn$2["rendered" + opts.uppercaseOuterName] = function renderedOuterDimImpl() { + var ele = this[0]; + if (ele) { + var od = ele[opts.outerName](); + return od * this.cy().zoom(); + } + }; + }; + defineDimFns({ + name: "width" + }); + defineDimFns({ + name: "height" + }); + elesfn$a.padding = function() { + var ele = this[0]; + var _p = ele._private; + if (ele.isParent()) { + ele.updateCompoundBounds(); + if (_p.autoPadding !== void 0) { + return _p.autoPadding; + } else { + return ele.pstyle("padding").pfValue; + } + } else { + return ele.pstyle("padding").pfValue; + } + }; + elesfn$a.paddedHeight = function() { + var ele = this[0]; + return ele.height() + 2 * ele.padding(); + }; + elesfn$a.paddedWidth = function() { + var ele = this[0]; + return ele.width() + 2 * ele.padding(); + }; + var widthHeight = elesfn$a; + var ifEdge = function ifEdge2(ele, getValue3) { + if (ele.isEdge()) { + return getValue3(ele); + } + }; + var ifEdgeRenderedPosition = function ifEdgeRenderedPosition2(ele, getPoint) { + if (ele.isEdge()) { + var cy = ele.cy(); + return modelToRenderedPosition(getPoint(ele), cy.zoom(), cy.pan()); + } + }; + var ifEdgeRenderedPositions = function ifEdgeRenderedPositions2(ele, getPoints) { + if (ele.isEdge()) { + var cy = ele.cy(); + var pan = cy.pan(); + var zoom = cy.zoom(); + return getPoints(ele).map(function(p2) { + return modelToRenderedPosition(p2, zoom, pan); + }); + } + }; + var controlPoints2 = function controlPoints3(ele) { + return ele.renderer().getControlPoints(ele); + }; + var segmentPoints = function segmentPoints2(ele) { + return ele.renderer().getSegmentPoints(ele); + }; + var sourceEndpoint = function sourceEndpoint2(ele) { + return ele.renderer().getSourceEndpoint(ele); + }; + var targetEndpoint = function targetEndpoint2(ele) { + return ele.renderer().getTargetEndpoint(ele); + }; + var midpoint = function midpoint2(ele) { + return ele.renderer().getEdgeMidpoint(ele); + }; + var pts = { + controlPoints: { + get: controlPoints2, + mult: true + }, + segmentPoints: { + get: segmentPoints, + mult: true + }, + sourceEndpoint: { + get: sourceEndpoint + }, + targetEndpoint: { + get: targetEndpoint + }, + midpoint: { + get: midpoint + } + }; + var renderedName = function renderedName2(name) { + return "rendered" + name[0].toUpperCase() + name.substr(1); + }; + var edgePoints = Object.keys(pts).reduce(function(obj, name) { + var spec = pts[name]; + var rName = renderedName(name); + obj[name] = function() { + return ifEdge(this, spec.get); + }; + if (spec.mult) { + obj[rName] = function() { + return ifEdgeRenderedPositions(this, spec.get); + }; + } else { + obj[rName] = function() { + return ifEdgeRenderedPosition(this, spec.get); + }; + } + return obj; + }, {}); + var dimensions = extend2({}, position2, bounds2, widthHeight, edgePoints); + /*! + Event object based on jQuery events, MIT license + + https://jquery.org/license/ + https://tldrlegal.com/license/mit-license + https://github.com/jquery/jquery/blob/master/src/event.js + */ + var Event = function Event2(src, props) { + this.recycle(src, props); + }; + function returnFalse() { + return false; + } + function returnTrue() { + return true; + } + Event.prototype = { + instanceString: function instanceString() { + return "event"; + }, + recycle: function recycle(src, props) { + this.isImmediatePropagationStopped = this.isPropagationStopped = this.isDefaultPrevented = returnFalse; + if (src != null && src.preventDefault) { + this.type = src.type; + this.isDefaultPrevented = src.defaultPrevented ? returnTrue : returnFalse; + } else if (src != null && src.type) { + props = src; + } else { + this.type = src; + } + if (props != null) { + this.originalEvent = props.originalEvent; + this.type = props.type != null ? props.type : this.type; + this.cy = props.cy; + this.target = props.target; + this.position = props.position; + this.renderedPosition = props.renderedPosition; + this.namespace = props.namespace; + this.layout = props.layout; + } + if (this.cy != null && this.position != null && this.renderedPosition == null) { + var pos = this.position; + var zoom = this.cy.zoom(); + var pan = this.cy.pan(); + this.renderedPosition = { + x: pos.x * zoom + pan.x, + y: pos.y * zoom + pan.y + }; + } + this.timeStamp = src && src.timeStamp || Date.now(); + }, + preventDefault: function preventDefault() { + this.isDefaultPrevented = returnTrue; + var e = this.originalEvent; + if (!e) { + return; + } + if (e.preventDefault) { + e.preventDefault(); + } + }, + stopPropagation: function stopPropagation() { + this.isPropagationStopped = returnTrue; + var e = this.originalEvent; + if (!e) { + return; + } + if (e.stopPropagation) { + e.stopPropagation(); + } + }, + stopImmediatePropagation: function stopImmediatePropagation() { + this.isImmediatePropagationStopped = returnTrue; + this.stopPropagation(); + }, + isDefaultPrevented: returnFalse, + isPropagationStopped: returnFalse, + isImmediatePropagationStopped: returnFalse + }; + var eventRegex = /^([^.]+)(\.(?:[^.]+))?$/; + var universalNamespace = ".*"; + var defaults$8 = { + qualifierCompare: function qualifierCompare(q1, q2) { + return q1 === q2; + }, + eventMatches: function eventMatches() { + return true; + }, + addEventFields: function addEventFields() { + }, + callbackContext: function callbackContext(context) { + return context; + }, + beforeEmit: function beforeEmit() { + }, + afterEmit: function afterEmit() { + }, + bubble: function bubble() { + return false; + }, + parent: function parent() { + return null; + }, + context: null + }; + var defaultsKeys = Object.keys(defaults$8); + var emptyOpts = {}; + function Emitter() { + var opts = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : emptyOpts; + var context = arguments.length > 1 ? arguments[1] : void 0; + for (var i3 = 0; i3 < defaultsKeys.length; i3++) { + var key = defaultsKeys[i3]; + this[key] = opts[key] || defaults$8[key]; + } + this.context = context || this.context; + this.listeners = []; + this.emitting = 0; + } + var p = Emitter.prototype; + var forEachEvent = function forEachEvent2(self2, handler, events, qualifier, callback, conf2, confOverrides) { + if (fn$6(qualifier)) { + callback = qualifier; + qualifier = null; + } + if (confOverrides) { + if (conf2 == null) { + conf2 = confOverrides; + } else { + conf2 = extend2({}, conf2, confOverrides); + } + } + var eventList = array2(events) ? events : events.split(/\s+/); + for (var i3 = 0; i3 < eventList.length; i3++) { + var evt = eventList[i3]; + if (emptyString(evt)) { + continue; + } + var match2 = evt.match(eventRegex); + if (match2) { + var type2 = match2[1]; + var namespace2 = match2[2] ? match2[2] : null; + var ret = handler(self2, evt, type2, namespace2, qualifier, callback, conf2); + if (ret === false) { + break; + } + } + } + }; + var makeEventObj = function makeEventObj2(self2, obj) { + self2.addEventFields(self2.context, obj); + return new Event(obj.type, obj); + }; + var forEachEventObj = function forEachEventObj2(self2, handler, events) { + if (event(events)) { + handler(self2, events); + return; + } else if (plainObject(events)) { + handler(self2, makeEventObj(self2, events)); + return; + } + var eventList = array2(events) ? events : events.split(/\s+/); + for (var i3 = 0; i3 < eventList.length; i3++) { + var evt = eventList[i3]; + if (emptyString(evt)) { + continue; + } + var match2 = evt.match(eventRegex); + if (match2) { + var type2 = match2[1]; + var namespace2 = match2[2] ? match2[2] : null; + var eventObj = makeEventObj(self2, { + type: type2, + namespace: namespace2, + target: self2.context + }); + handler(self2, eventObj); + } + } + }; + p.on = p.addListener = function(events, qualifier, callback, conf2, confOverrides) { + forEachEvent(this, function(self2, event2, type2, namespace2, qualifier2, callback2, conf3) { + if (fn$6(callback2)) { + self2.listeners.push({ + event: event2, + // full event string + callback: callback2, + // callback to run + type: type2, + // the event type (e.g. 'click') + namespace: namespace2, + // the event namespace (e.g. ".foo") + qualifier: qualifier2, + // a restriction on whether to match this emitter + conf: conf3 + // additional configuration + }); + } + }, events, qualifier, callback, conf2, confOverrides); + return this; + }; + p.one = function(events, qualifier, callback, conf2) { + return this.on(events, qualifier, callback, conf2, { + one: true + }); + }; + p.removeListener = p.off = function(events, qualifier, callback, conf2) { + var _this = this; + if (this.emitting !== 0) { + this.listeners = copyArray$1(this.listeners); + } + var listeners = this.listeners; + var _loop = function _loop2(i4) { + var listener = listeners[i4]; + forEachEvent(_this, function(self2, event2, type2, namespace2, qualifier2, callback2) { + if ((listener.type === type2 || events === "*") && (!namespace2 && listener.namespace !== ".*" || listener.namespace === namespace2) && (!qualifier2 || self2.qualifierCompare(listener.qualifier, qualifier2)) && (!callback2 || listener.callback === callback2)) { + listeners.splice(i4, 1); + return false; + } + }, events, qualifier, callback, conf2); + }; + for (var i3 = listeners.length - 1; i3 >= 0; i3--) { + _loop(i3); + } + return this; + }; + p.removeAllListeners = function() { + return this.removeListener("*"); + }; + p.emit = p.trigger = function(events, extraParams, manualCallback) { + var listeners = this.listeners; + var numListenersBeforeEmit = listeners.length; + this.emitting++; + if (!array2(extraParams)) { + extraParams = [extraParams]; + } + forEachEventObj(this, function(self2, eventObj) { + if (manualCallback != null) { + listeners = [{ + event: eventObj.event, + type: eventObj.type, + namespace: eventObj.namespace, + callback: manualCallback + }]; + numListenersBeforeEmit = listeners.length; + } + var _loop2 = function _loop22(i4) { + var listener = listeners[i4]; + if (listener.type === eventObj.type && (!listener.namespace || listener.namespace === eventObj.namespace || listener.namespace === universalNamespace) && self2.eventMatches(self2.context, listener, eventObj)) { + var args = [eventObj]; + if (extraParams != null) { + push2(args, extraParams); + } + self2.beforeEmit(self2.context, listener, eventObj); + if (listener.conf && listener.conf.one) { + self2.listeners = self2.listeners.filter(function(l) { + return l !== listener; + }); + } + var context = self2.callbackContext(self2.context, listener, eventObj); + var ret = listener.callback.apply(context, args); + self2.afterEmit(self2.context, listener, eventObj); + if (ret === false) { + eventObj.stopPropagation(); + eventObj.preventDefault(); + } + } + }; + for (var i3 = 0; i3 < numListenersBeforeEmit; i3++) { + _loop2(i3); + } + if (self2.bubble(self2.context) && !eventObj.isPropagationStopped()) { + self2.parent(self2.context).emit(eventObj, extraParams); + } + }, events); + this.emitting--; + return this; + }; + var emitterOptions$1 = { + qualifierCompare: function qualifierCompare(selector1, selector2) { + if (selector1 == null || selector2 == null) { + return selector1 == null && selector2 == null; + } else { + return selector1.sameText(selector2); + } + }, + eventMatches: function eventMatches(ele, listener, eventObj) { + var selector2 = listener.qualifier; + if (selector2 != null) { + return ele !== eventObj.target && element2(eventObj.target) && selector2.matches(eventObj.target); + } + return true; + }, + addEventFields: function addEventFields(ele, evt) { + evt.cy = ele.cy(); + evt.target = ele; + }, + callbackContext: function callbackContext(ele, listener, eventObj) { + return listener.qualifier != null ? eventObj.target : ele; + }, + beforeEmit: function beforeEmit(context, listener) { + if (listener.conf && listener.conf.once) { + listener.conf.onceCollection.removeListener(listener.event, listener.qualifier, listener.callback); + } + }, + bubble: function bubble() { + return true; + }, + parent: function parent(ele) { + return ele.isChild() ? ele.parent() : ele.cy(); + } + }; + var argSelector$1 = function argSelector2(arg) { + if (string2(arg)) { + return new Selector(arg); + } else { + return arg; + } + }; + var elesfn$9 = { + createEmitter: function createEmitter() { + for (var i3 = 0; i3 < this.length; i3++) { + var ele = this[i3]; + var _p = ele._private; + if (!_p.emitter) { + _p.emitter = new Emitter(emitterOptions$1, ele); + } + } + return this; + }, + emitter: function emitter() { + return this._private.emitter; + }, + on: function on(events, selector2, callback) { + var argSel = argSelector$1(selector2); + for (var i3 = 0; i3 < this.length; i3++) { + var ele = this[i3]; + ele.emitter().on(events, argSel, callback); + } + return this; + }, + removeListener: function removeListener(events, selector2, callback) { + var argSel = argSelector$1(selector2); + for (var i3 = 0; i3 < this.length; i3++) { + var ele = this[i3]; + ele.emitter().removeListener(events, argSel, callback); + } + return this; + }, + removeAllListeners: function removeAllListeners() { + for (var i3 = 0; i3 < this.length; i3++) { + var ele = this[i3]; + ele.emitter().removeAllListeners(); + } + return this; + }, + one: function one2(events, selector2, callback) { + var argSel = argSelector$1(selector2); + for (var i3 = 0; i3 < this.length; i3++) { + var ele = this[i3]; + ele.emitter().one(events, argSel, callback); + } + return this; + }, + once: function once(events, selector2, callback) { + var argSel = argSelector$1(selector2); + for (var i3 = 0; i3 < this.length; i3++) { + var ele = this[i3]; + ele.emitter().on(events, argSel, callback, { + once: true, + onceCollection: this + }); + } + }, + emit: function emit(events, extraParams) { + for (var i3 = 0; i3 < this.length; i3++) { + var ele = this[i3]; + ele.emitter().emit(events, extraParams); + } + return this; + }, + emitAndNotify: function emitAndNotify(event2, extraParams) { + if (this.length === 0) { + return; + } + this.cy().notify(event2, this); + this.emit(event2, extraParams); + return this; + } + }; + define3.eventAliasesOn(elesfn$9); + var elesfn$8 = { + nodes: function nodes2(selector2) { + return this.filter(function(ele) { + return ele.isNode(); + }).filter(selector2); + }, + edges: function edges2(selector2) { + return this.filter(function(ele) { + return ele.isEdge(); + }).filter(selector2); + }, + // internal helper to get nodes and edges as separate collections with single iteration over elements + byGroup: function byGroup() { + var nodes2 = this.spawn(); + var edges2 = this.spawn(); + for (var i3 = 0; i3 < this.length; i3++) { + var ele = this[i3]; + if (ele.isNode()) { + nodes2.push(ele); + } else { + edges2.push(ele); + } + } + return { + nodes: nodes2, + edges: edges2 + }; + }, + filter: function filter3(_filter, thisArg) { + if (_filter === void 0) { + return this; + } else if (string2(_filter) || elementOrCollection(_filter)) { + return new Selector(_filter).filter(this); + } else if (fn$6(_filter)) { + var filterEles = this.spawn(); + var eles = this; + for (var i3 = 0; i3 < eles.length; i3++) { + var ele = eles[i3]; + var include = thisArg ? _filter.apply(thisArg, [ele, i3, eles]) : _filter(ele, i3, eles); + if (include) { + filterEles.push(ele); + } + } + return filterEles; + } + return this.spawn(); + }, + not: function not(toRemove) { + if (!toRemove) { + return this; + } else { + if (string2(toRemove)) { + toRemove = this.filter(toRemove); + } + var elements2 = this.spawn(); + for (var i3 = 0; i3 < this.length; i3++) { + var element3 = this[i3]; + var remove2 = toRemove.has(element3); + if (!remove2) { + elements2.push(element3); + } + } + return elements2; + } + }, + absoluteComplement: function absoluteComplement() { + var cy = this.cy(); + return cy.mutableElements().not(this); + }, + intersect: function intersect2(other) { + if (string2(other)) { + var selector2 = other; + return this.filter(selector2); + } + var elements2 = this.spawn(); + var col1 = this; + var col2 = other; + var col1Smaller = this.length < other.length; + var colS = col1Smaller ? col1 : col2; + var colL = col1Smaller ? col2 : col1; + for (var i3 = 0; i3 < colS.length; i3++) { + var ele = colS[i3]; + if (colL.has(ele)) { + elements2.push(ele); + } + } + return elements2; + }, + xor: function xor(other) { + var cy = this._private.cy; + if (string2(other)) { + other = cy.$(other); + } + var elements2 = this.spawn(); + var col1 = this; + var col2 = other; + var add = function add2(col, other2) { + for (var i3 = 0; i3 < col.length; i3++) { + var ele = col[i3]; + var id2 = ele._private.data.id; + var inOther = other2.hasElementWithId(id2); + if (!inOther) { + elements2.push(ele); + } + } + }; + add(col1, col2); + add(col2, col1); + return elements2; + }, + diff: function diff(other) { + var cy = this._private.cy; + if (string2(other)) { + other = cy.$(other); + } + var left2 = this.spawn(); + var right2 = this.spawn(); + var both = this.spawn(); + var col1 = this; + var col2 = other; + var add = function add2(col, other2, retEles) { + for (var i3 = 0; i3 < col.length; i3++) { + var ele = col[i3]; + var id2 = ele._private.data.id; + var inOther = other2.hasElementWithId(id2); + if (inOther) { + both.merge(ele); + } else { + retEles.push(ele); + } + } + }; + add(col1, col2, left2); + add(col2, col1, right2); + return { + left: left2, + right: right2, + both + }; + }, + add: function add(toAdd) { + var cy = this._private.cy; + if (!toAdd) { + return this; + } + if (string2(toAdd)) { + var selector2 = toAdd; + toAdd = cy.mutableElements().filter(selector2); + } + var elements2 = this.spawnSelf(); + for (var i3 = 0; i3 < toAdd.length; i3++) { + var ele = toAdd[i3]; + var add2 = !this.has(ele); + if (add2) { + elements2.push(ele); + } + } + return elements2; + }, + // in place merge on calling collection + merge: function merge2(toAdd) { + var _p = this._private; + var cy = _p.cy; + if (!toAdd) { + return this; + } + if (toAdd && string2(toAdd)) { + var selector2 = toAdd; + toAdd = cy.mutableElements().filter(selector2); + } + var map2 = _p.map; + for (var i3 = 0; i3 < toAdd.length; i3++) { + var toAddEle = toAdd[i3]; + var id2 = toAddEle._private.data.id; + var add = !map2.has(id2); + if (add) { + var index2 = this.length++; + this[index2] = toAddEle; + map2.set(id2, { + ele: toAddEle, + index: index2 + }); + } + } + return this; + }, + unmergeAt: function unmergeAt(i3) { + var ele = this[i3]; + var id2 = ele.id(); + var _p = this._private; + var map2 = _p.map; + this[i3] = void 0; + map2["delete"](id2); + var unmergedLastEle = i3 === this.length - 1; + if (this.length > 1 && !unmergedLastEle) { + var lastEleI = this.length - 1; + var lastEle = this[lastEleI]; + var lastEleId = lastEle._private.data.id; + this[lastEleI] = void 0; + this[i3] = lastEle; + map2.set(lastEleId, { + ele: lastEle, + index: i3 + }); + } + this.length--; + return this; + }, + // remove single ele in place in calling collection + unmergeOne: function unmergeOne(ele) { + ele = ele[0]; + var _p = this._private; + var id2 = ele._private.data.id; + var map2 = _p.map; + var entry = map2.get(id2); + if (!entry) { + return this; + } + var i3 = entry.index; + this.unmergeAt(i3); + return this; + }, + // remove eles in place on calling collection + unmerge: function unmerge(toRemove) { + var cy = this._private.cy; + if (!toRemove) { + return this; + } + if (toRemove && string2(toRemove)) { + var selector2 = toRemove; + toRemove = cy.mutableElements().filter(selector2); + } + for (var i3 = 0; i3 < toRemove.length; i3++) { + this.unmergeOne(toRemove[i3]); + } + return this; + }, + unmergeBy: function unmergeBy(toRmFn) { + for (var i3 = this.length - 1; i3 >= 0; i3--) { + var ele = this[i3]; + if (toRmFn(ele)) { + this.unmergeAt(i3); + } + } + return this; + }, + map: function map2(mapFn, thisArg) { + var arr = []; + var eles = this; + for (var i3 = 0; i3 < eles.length; i3++) { + var ele = eles[i3]; + var ret = thisArg ? mapFn.apply(thisArg, [ele, i3, eles]) : mapFn(ele, i3, eles); + arr.push(ret); + } + return arr; + }, + reduce: function reduce2(fn2, initialValue) { + var val = initialValue; + var eles = this; + for (var i3 = 0; i3 < eles.length; i3++) { + val = fn2(val, eles[i3], i3, eles); + } + return val; + }, + max: function max3(valFn, thisArg) { + var max4 = -Infinity; + var maxEle; + var eles = this; + for (var i3 = 0; i3 < eles.length; i3++) { + var ele = eles[i3]; + var val = thisArg ? valFn.apply(thisArg, [ele, i3, eles]) : valFn(ele, i3, eles); + if (val > max4) { + max4 = val; + maxEle = ele; + } + } + return { + value: max4, + ele: maxEle + }; + }, + min: function min3(valFn, thisArg) { + var min4 = Infinity; + var minEle; + var eles = this; + for (var i3 = 0; i3 < eles.length; i3++) { + var ele = eles[i3]; + var val = thisArg ? valFn.apply(thisArg, [ele, i3, eles]) : valFn(ele, i3, eles); + if (val < min4) { + min4 = val; + minEle = ele; + } + } + return { + value: min4, + ele: minEle + }; + } + }; + var fn$1 = elesfn$8; + fn$1["u"] = fn$1["|"] = fn$1["+"] = fn$1.union = fn$1.or = fn$1.add; + fn$1["\\"] = fn$1["!"] = fn$1["-"] = fn$1.difference = fn$1.relativeComplement = fn$1.subtract = fn$1.not; + fn$1["n"] = fn$1["&"] = fn$1["."] = fn$1.and = fn$1.intersection = fn$1.intersect; + fn$1["^"] = fn$1["(+)"] = fn$1["(-)"] = fn$1.symmetricDifference = fn$1.symdiff = fn$1.xor; + fn$1.fnFilter = fn$1.filterFn = fn$1.stdFilter = fn$1.filter; + fn$1.complement = fn$1.abscomp = fn$1.absoluteComplement; + var elesfn$7 = { + isNode: function isNode() { + return this.group() === "nodes"; + }, + isEdge: function isEdge() { + return this.group() === "edges"; + }, + isLoop: function isLoop() { + return this.isEdge() && this.source()[0] === this.target()[0]; + }, + isSimple: function isSimple() { + return this.isEdge() && this.source()[0] !== this.target()[0]; + }, + group: function group() { + var ele = this[0]; + if (ele) { + return ele._private.group; + } + } + }; + var zIndexSort = function zIndexSort2(a, b) { + var cy = a.cy(); + var hasCompoundNodes = cy.hasCompoundNodes(); + function getDepth(ele) { + var style = ele.pstyle("z-compound-depth"); + if (style.value === "auto") { + return hasCompoundNodes ? ele.zDepth() : 0; + } else if (style.value === "bottom") { + return -1; + } else if (style.value === "top") { + return MAX_INT$1; + } + return 0; + } + var depthDiff = getDepth(a) - getDepth(b); + if (depthDiff !== 0) { + return depthDiff; + } + function getEleDepth(ele) { + var style = ele.pstyle("z-index-compare"); + if (style.value === "auto") { + return ele.isNode() ? 1 : 0; + } + return 0; + } + var eleDiff = getEleDepth(a) - getEleDepth(b); + if (eleDiff !== 0) { + return eleDiff; + } + var zDiff = a.pstyle("z-index").value - b.pstyle("z-index").value; + if (zDiff !== 0) { + return zDiff; + } + return a.poolIndex() - b.poolIndex(); + }; + var elesfn$6 = { + forEach: function forEach2(fn2, thisArg) { + if (fn$6(fn2)) { + var N = this.length; + for (var i3 = 0; i3 < N; i3++) { + var ele = this[i3]; + var ret = thisArg ? fn2.apply(thisArg, [ele, i3, this]) : fn2(ele, i3, this); + if (ret === false) { + break; + } + } + } + return this; + }, + toArray: function toArray2() { + var array3 = []; + for (var i3 = 0; i3 < this.length; i3++) { + array3.push(this[i3]); + } + return array3; + }, + slice: function slice2(start2, end2) { + var array3 = []; + var thisSize = this.length; + if (end2 == null) { + end2 = thisSize; + } + if (start2 == null) { + start2 = 0; + } + if (start2 < 0) { + start2 = thisSize + start2; + } + if (end2 < 0) { + end2 = thisSize + end2; + } + for (var i3 = start2; i3 >= 0 && i3 < end2 && i3 < thisSize; i3++) { + array3.push(this[i3]); + } + return this.spawn(array3); + }, + size: function size2() { + return this.length; + }, + eq: function eq3(i3) { + return this[i3] || this.spawn(); + }, + first: function first() { + return this[0] || this.spawn(); + }, + last: function last2() { + return this[this.length - 1] || this.spawn(); + }, + empty: function empty2() { + return this.length === 0; + }, + nonempty: function nonempty() { + return !this.empty(); + }, + sort: function sort2(sortFn) { + if (!fn$6(sortFn)) { + return this; + } + var sorted = this.toArray().sort(sortFn); + return this.spawn(sorted); + }, + sortByZIndex: function sortByZIndex() { + return this.sort(zIndexSort); + }, + zDepth: function zDepth() { + var ele = this[0]; + if (!ele) { + return void 0; + } + var _p = ele._private; + var group = _p.group; + if (group === "nodes") { + var depth = _p.data.parent ? ele.parents().size() : 0; + if (!ele.isParent()) { + return MAX_INT$1 - 1; + } + return depth; + } else { + var src = _p.source; + var tgt = _p.target; + var srcDepth = src.zDepth(); + var tgtDepth = tgt.zDepth(); + return Math.max(srcDepth, tgtDepth, 0); + } + } + }; + elesfn$6.each = elesfn$6.forEach; + var defineSymbolIterator = function defineSymbolIterator2() { + var typeofUndef = "undefined"; + var isIteratorSupported = (typeof Symbol === "undefined" ? "undefined" : _typeof(Symbol)) != typeofUndef && _typeof(Symbol.iterator) != typeofUndef; + if (isIteratorSupported) { + elesfn$6[Symbol.iterator] = function() { + var _this = this; + var entry = { + value: void 0, + done: false + }; + var i3 = 0; + var length2 = this.length; + return _defineProperty$1({ + next: function next2() { + if (i3 < length2) { + entry.value = _this[i3++]; + } else { + entry.value = void 0; + entry.done = true; + } + return entry; + } + }, Symbol.iterator, function() { + return this; + }); + }; + } + }; + defineSymbolIterator(); + var getLayoutDimensionOptions = defaults$g({ + nodeDimensionsIncludeLabels: false + }); + var elesfn$5 = { + // Calculates and returns node dimensions { x, y } based on options given + layoutDimensions: function layoutDimensions(options2) { + options2 = getLayoutDimensionOptions(options2); + var dims; + if (!this.takesUpSpace()) { + dims = { + w: 0, + h: 0 + }; + } else if (options2.nodeDimensionsIncludeLabels) { + var bbDim = this.boundingBox(); + dims = { + w: bbDim.w, + h: bbDim.h + }; + } else { + dims = { + w: this.outerWidth(), + h: this.outerHeight() + }; + } + if (dims.w === 0 || dims.h === 0) { + dims.w = dims.h = 1; + } + return dims; + }, + // using standard layout options, apply position function (w/ or w/o animation) + layoutPositions: function layoutPositions(layout3, options2, fn2) { + var nodes2 = this.nodes().filter(function(n) { + return !n.isParent(); + }); + var cy = this.cy(); + var layoutEles = options2.eles; + var getMemoizeKey = function getMemoizeKey2(node3) { + return node3.id(); + }; + var fnMem = memoize$1(fn2, getMemoizeKey); + layout3.emit({ + type: "layoutstart", + layout: layout3 + }); + layout3.animations = []; + var calculateSpacing = function calculateSpacing2(spacing2, nodesBb, pos) { + var center2 = { + x: nodesBb.x1 + nodesBb.w / 2, + y: nodesBb.y1 + nodesBb.h / 2 + }; + var spacingVector = { + // scale from center of bounding box (not necessarily 0,0) + x: (pos.x - center2.x) * spacing2, + y: (pos.y - center2.y) * spacing2 + }; + return { + x: center2.x + spacingVector.x, + y: center2.y + spacingVector.y + }; + }; + var useSpacingFactor = options2.spacingFactor && options2.spacingFactor !== 1; + var spacingBb = function spacingBb2() { + if (!useSpacingFactor) { + return null; + } + var bb2 = makeBoundingBox(); + for (var i4 = 0; i4 < nodes2.length; i4++) { + var node3 = nodes2[i4]; + var pos = fnMem(node3, i4); + expandBoundingBoxByPoint(bb2, pos.x, pos.y); + } + return bb2; + }; + var bb = spacingBb(); + var getFinalPos = memoize$1(function(node3, i4) { + var newPos2 = fnMem(node3, i4); + if (useSpacingFactor) { + var spacing2 = Math.abs(options2.spacingFactor); + newPos2 = calculateSpacing(spacing2, bb, newPos2); + } + if (options2.transform != null) { + newPos2 = options2.transform(node3, newPos2); + } + return newPos2; + }, getMemoizeKey); + if (options2.animate) { + for (var i3 = 0; i3 < nodes2.length; i3++) { + var node2 = nodes2[i3]; + var newPos = getFinalPos(node2, i3); + var animateNode = options2.animateFilter == null || options2.animateFilter(node2, i3); + if (animateNode) { + var ani = node2.animation({ + position: newPos, + duration: options2.animationDuration, + easing: options2.animationEasing + }); + layout3.animations.push(ani); + } else { + node2.position(newPos); + } + } + if (options2.fit) { + var fitAni = cy.animation({ + fit: { + boundingBox: layoutEles.boundingBoxAt(getFinalPos), + padding: options2.padding + }, + duration: options2.animationDuration, + easing: options2.animationEasing + }); + layout3.animations.push(fitAni); + } else if (options2.zoom !== void 0 && options2.pan !== void 0) { + var zoomPanAni = cy.animation({ + zoom: options2.zoom, + pan: options2.pan, + duration: options2.animationDuration, + easing: options2.animationEasing + }); + layout3.animations.push(zoomPanAni); + } + layout3.animations.forEach(function(ani2) { + return ani2.play(); + }); + layout3.one("layoutready", options2.ready); + layout3.emit({ + type: "layoutready", + layout: layout3 + }); + Promise$12.all(layout3.animations.map(function(ani2) { + return ani2.promise(); + })).then(function() { + layout3.one("layoutstop", options2.stop); + layout3.emit({ + type: "layoutstop", + layout: layout3 + }); + }); + } else { + nodes2.positions(getFinalPos); + if (options2.fit) { + cy.fit(options2.eles, options2.padding); + } + if (options2.zoom != null) { + cy.zoom(options2.zoom); + } + if (options2.pan) { + cy.pan(options2.pan); + } + layout3.one("layoutready", options2.ready); + layout3.emit({ + type: "layoutready", + layout: layout3 + }); + layout3.one("layoutstop", options2.stop); + layout3.emit({ + type: "layoutstop", + layout: layout3 + }); + } + return this; + }, + layout: function layout3(options2) { + var cy = this.cy(); + return cy.makeLayout(extend2({}, options2, { + eles: this + })); + } + }; + elesfn$5.createLayout = elesfn$5.makeLayout = elesfn$5.layout; + function styleCache(key, fn2, ele) { + var _p = ele._private; + var cache2 = _p.styleCache = _p.styleCache || []; + var val; + if ((val = cache2[key]) != null) { + return val; + } else { + val = cache2[key] = fn2(ele); + return val; + } + } + function cacheStyleFunction(key, fn2) { + key = hashString(key); + return function cachedStyleFunction(ele) { + return styleCache(key, fn2, ele); + }; + } + function cachePrototypeStyleFunction(key, fn2) { + key = hashString(key); + var selfFn = function selfFn2(ele) { + return fn2.call(ele); + }; + return function cachedPrototypeStyleFunction() { + var ele = this[0]; + if (ele) { + return styleCache(key, selfFn, ele); + } + }; + } + var elesfn$4 = { + recalculateRenderedStyle: function recalculateRenderedStyle(useCache) { + var cy = this.cy(); + var renderer3 = cy.renderer(); + var styleEnabled = cy.styleEnabled(); + if (renderer3 && styleEnabled) { + renderer3.recalculateRenderedStyle(this, useCache); + } + return this; + }, + dirtyStyleCache: function dirtyStyleCache() { + var cy = this.cy(); + var dirty = function dirty2(ele) { + return ele._private.styleCache = null; + }; + if (cy.hasCompoundNodes()) { + var eles; + eles = this.spawnSelf().merge(this.descendants()).merge(this.parents()); + eles.merge(eles.connectedEdges()); + eles.forEach(dirty); + } else { + this.forEach(function(ele) { + dirty(ele); + ele.connectedEdges().forEach(dirty); + }); + } + return this; + }, + // fully updates (recalculates) the style for the elements + updateStyle: function updateStyle(notifyRenderer) { + var cy = this._private.cy; + if (!cy.styleEnabled()) { + return this; + } + if (cy.batching()) { + var bEles = cy._private.batchStyleEles; + bEles.merge(this); + return this; + } + var hasCompounds = cy.hasCompoundNodes(); + var updatedEles = this; + notifyRenderer = notifyRenderer || notifyRenderer === void 0 ? true : false; + if (hasCompounds) { + updatedEles = this.spawnSelf().merge(this.descendants()).merge(this.parents()); + } + var changedEles = updatedEles; + if (notifyRenderer) { + changedEles.emitAndNotify("style"); + } else { + changedEles.emit("style"); + } + updatedEles.forEach(function(ele) { + return ele._private.styleDirty = true; + }); + return this; + }, + // private: clears dirty flag and recalculates style + cleanStyle: function cleanStyle() { + var cy = this.cy(); + if (!cy.styleEnabled()) { + return; + } + for (var i3 = 0; i3 < this.length; i3++) { + var ele = this[i3]; + if (ele._private.styleDirty) { + ele._private.styleDirty = false; + cy.style().apply(ele); + } + } + }, + // get the internal parsed style object for the specified property + parsedStyle: function parsedStyle(property2) { + var includeNonDefault = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : true; + var ele = this[0]; + var cy = ele.cy(); + if (!cy.styleEnabled()) { + return; + } + if (ele) { + this.cleanStyle(); + var overriddenStyle = ele._private.style[property2]; + if (overriddenStyle != null) { + return overriddenStyle; + } else if (includeNonDefault) { + return cy.style().getDefaultProperty(property2); + } else { + return null; + } + } + }, + numericStyle: function numericStyle(property2) { + var ele = this[0]; + if (!ele.cy().styleEnabled()) { + return; + } + if (ele) { + var pstyle = ele.pstyle(property2); + return pstyle.pfValue !== void 0 ? pstyle.pfValue : pstyle.value; + } + }, + numericStyleUnits: function numericStyleUnits(property2) { + var ele = this[0]; + if (!ele.cy().styleEnabled()) { + return; + } + if (ele) { + return ele.pstyle(property2).units; + } + }, + // get the specified css property as a rendered value (i.e. on-screen value) + // or get the whole rendered style if no property specified (NB doesn't allow setting) + renderedStyle: function renderedStyle(property2) { + var cy = this.cy(); + if (!cy.styleEnabled()) { + return this; + } + var ele = this[0]; + if (ele) { + return cy.style().getRenderedStyle(ele, property2); + } + }, + // read the calculated css style of the element or override the style (via a bypass) + style: function style(name, value2) { + var cy = this.cy(); + if (!cy.styleEnabled()) { + return this; + } + var updateTransitions = false; + var style2 = cy.style(); + if (plainObject(name)) { + var props = name; + style2.applyBypass(this, props, updateTransitions); + this.emitAndNotify("style"); + } else if (string2(name)) { + if (value2 === void 0) { + var ele = this[0]; + if (ele) { + return style2.getStylePropertyValue(ele, name); + } else { + return; + } + } else { + style2.applyBypass(this, name, value2, updateTransitions); + this.emitAndNotify("style"); + } + } else if (name === void 0) { + var _ele = this[0]; + if (_ele) { + return style2.getRawStyle(_ele); + } else { + return; + } + } + return this; + }, + removeStyle: function removeStyle(names) { + var cy = this.cy(); + if (!cy.styleEnabled()) { + return this; + } + var updateTransitions = false; + var style = cy.style(); + var eles = this; + if (names === void 0) { + for (var i3 = 0; i3 < eles.length; i3++) { + var ele = eles[i3]; + style.removeAllBypasses(ele, updateTransitions); + } + } else { + names = names.split(/\s+/); + for (var _i6 = 0; _i6 < eles.length; _i6++) { + var _ele2 = eles[_i6]; + style.removeBypasses(_ele2, names, updateTransitions); + } + } + this.emitAndNotify("style"); + return this; + }, + show: function show() { + this.css("display", "element"); + return this; + }, + hide: function hide() { + this.css("display", "none"); + return this; + }, + effectiveOpacity: function effectiveOpacity() { + var cy = this.cy(); + if (!cy.styleEnabled()) { + return 1; + } + var hasCompoundNodes = cy.hasCompoundNodes(); + var ele = this[0]; + if (ele) { + var _p = ele._private; + var parentOpacity = ele.pstyle("opacity").value; + if (!hasCompoundNodes) { + return parentOpacity; + } + var parents2 = !_p.data.parent ? null : ele.parents(); + if (parents2) { + for (var i3 = 0; i3 < parents2.length; i3++) { + var parent = parents2[i3]; + var opacity = parent.pstyle("opacity").value; + parentOpacity = opacity * parentOpacity; + } + } + return parentOpacity; + } + }, + transparent: function transparent() { + var cy = this.cy(); + if (!cy.styleEnabled()) { + return false; + } + var ele = this[0]; + var hasCompoundNodes = ele.cy().hasCompoundNodes(); + if (ele) { + if (!hasCompoundNodes) { + return ele.pstyle("opacity").value === 0; + } else { + return ele.effectiveOpacity() === 0; + } + } + }, + backgrounding: function backgrounding() { + var cy = this.cy(); + if (!cy.styleEnabled()) { + return false; + } + var ele = this[0]; + return ele._private.backgrounding ? true : false; + } + }; + function checkCompound(ele, parentOk) { + var _p = ele._private; + var parents2 = _p.data.parent ? ele.parents() : null; + if (parents2) { + for (var i3 = 0; i3 < parents2.length; i3++) { + var parent = parents2[i3]; + if (!parentOk(parent)) { + return false; + } + } + } + return true; + } + function defineDerivedStateFunction(specs) { + var ok = specs.ok; + var edgeOkViaNode = specs.edgeOkViaNode || specs.ok; + var parentOk = specs.parentOk || specs.ok; + return function() { + var cy = this.cy(); + if (!cy.styleEnabled()) { + return true; + } + var ele = this[0]; + var hasCompoundNodes = cy.hasCompoundNodes(); + if (ele) { + var _p = ele._private; + if (!ok(ele)) { + return false; + } + if (ele.isNode()) { + return !hasCompoundNodes || checkCompound(ele, parentOk); + } else { + var src = _p.source; + var tgt = _p.target; + return edgeOkViaNode(src) && (!hasCompoundNodes || checkCompound(src, edgeOkViaNode)) && (src === tgt || edgeOkViaNode(tgt) && (!hasCompoundNodes || checkCompound(tgt, edgeOkViaNode))); + } + } + }; + } + var eleTakesUpSpace = cacheStyleFunction("eleTakesUpSpace", function(ele) { + return ele.pstyle("display").value === "element" && ele.width() !== 0 && (ele.isNode() ? ele.height() !== 0 : true); + }); + elesfn$4.takesUpSpace = cachePrototypeStyleFunction("takesUpSpace", defineDerivedStateFunction({ + ok: eleTakesUpSpace + })); + var eleInteractive = cacheStyleFunction("eleInteractive", function(ele) { + return ele.pstyle("events").value === "yes" && ele.pstyle("visibility").value === "visible" && eleTakesUpSpace(ele); + }); + var parentInteractive = cacheStyleFunction("parentInteractive", function(parent) { + return parent.pstyle("visibility").value === "visible" && eleTakesUpSpace(parent); + }); + elesfn$4.interactive = cachePrototypeStyleFunction("interactive", defineDerivedStateFunction({ + ok: eleInteractive, + parentOk: parentInteractive, + edgeOkViaNode: eleTakesUpSpace + })); + elesfn$4.noninteractive = function() { + var ele = this[0]; + if (ele) { + return !ele.interactive(); + } + }; + var eleVisible = cacheStyleFunction("eleVisible", function(ele) { + return ele.pstyle("visibility").value === "visible" && ele.pstyle("opacity").pfValue !== 0 && eleTakesUpSpace(ele); + }); + var edgeVisibleViaNode = eleTakesUpSpace; + elesfn$4.visible = cachePrototypeStyleFunction("visible", defineDerivedStateFunction({ + ok: eleVisible, + edgeOkViaNode: edgeVisibleViaNode + })); + elesfn$4.hidden = function() { + var ele = this[0]; + if (ele) { + return !ele.visible(); + } + }; + elesfn$4.isBundledBezier = cachePrototypeStyleFunction("isBundledBezier", function() { + if (!this.cy().styleEnabled()) { + return false; + } + return !this.removed() && this.pstyle("curve-style").value === "bezier" && this.takesUpSpace(); + }); + elesfn$4.bypass = elesfn$4.css = elesfn$4.style; + elesfn$4.renderedCss = elesfn$4.renderedStyle; + elesfn$4.removeBypass = elesfn$4.removeCss = elesfn$4.removeStyle; + elesfn$4.pstyle = elesfn$4.parsedStyle; + var elesfn$3 = {}; + function defineSwitchFunction(params) { + return function() { + var args = arguments; + var changedEles = []; + if (args.length === 2) { + var data2 = args[0]; + var handler = args[1]; + this.on(params.event, data2, handler); + } else if (args.length === 1 && fn$6(args[0])) { + var _handler = args[0]; + this.on(params.event, _handler); + } else if (args.length === 0 || args.length === 1 && array2(args[0])) { + var addlEvents = args.length === 1 ? args[0] : null; + for (var i3 = 0; i3 < this.length; i3++) { + var ele = this[i3]; + var able = !params.ableField || ele._private[params.ableField]; + var changed = ele._private[params.field] != params.value; + if (params.overrideAble) { + var overrideAble = params.overrideAble(ele); + if (overrideAble !== void 0) { + able = overrideAble; + if (!overrideAble) { + return this; + } + } + } + if (able) { + ele._private[params.field] = params.value; + if (changed) { + changedEles.push(ele); + } + } + } + var changedColl = this.spawn(changedEles); + changedColl.updateStyle(); + changedColl.emit(params.event); + if (addlEvents) { + changedColl.emit(addlEvents); + } + } + return this; + }; + } + function defineSwitchSet(params) { + elesfn$3[params.field] = function() { + var ele = this[0]; + if (ele) { + if (params.overrideField) { + var val = params.overrideField(ele); + if (val !== void 0) { + return val; + } + } + return ele._private[params.field]; + } + }; + elesfn$3[params.on] = defineSwitchFunction({ + event: params.on, + field: params.field, + ableField: params.ableField, + overrideAble: params.overrideAble, + value: true + }); + elesfn$3[params.off] = defineSwitchFunction({ + event: params.off, + field: params.field, + ableField: params.ableField, + overrideAble: params.overrideAble, + value: false + }); + } + defineSwitchSet({ + field: "locked", + overrideField: function overrideField(ele) { + return ele.cy().autolock() ? true : void 0; + }, + on: "lock", + off: "unlock" + }); + defineSwitchSet({ + field: "grabbable", + overrideField: function overrideField(ele) { + return ele.cy().autoungrabify() || ele.pannable() ? false : void 0; + }, + on: "grabify", + off: "ungrabify" + }); + defineSwitchSet({ + field: "selected", + ableField: "selectable", + overrideAble: function overrideAble(ele) { + return ele.cy().autounselectify() ? false : void 0; + }, + on: "select", + off: "unselect" + }); + defineSwitchSet({ + field: "selectable", + overrideField: function overrideField(ele) { + return ele.cy().autounselectify() ? false : void 0; + }, + on: "selectify", + off: "unselectify" + }); + elesfn$3.deselect = elesfn$3.unselect; + elesfn$3.grabbed = function() { + var ele = this[0]; + if (ele) { + return ele._private.grabbed; + } + }; + defineSwitchSet({ + field: "active", + on: "activate", + off: "unactivate" + }); + defineSwitchSet({ + field: "pannable", + on: "panify", + off: "unpanify" + }); + elesfn$3.inactive = function() { + var ele = this[0]; + if (ele) { + return !ele._private.active; + } + }; + var elesfn$2 = {}; + var defineDagExtremity = function defineDagExtremity2(params) { + return function dagExtremityImpl(selector2) { + var eles = this; + var ret = []; + for (var i3 = 0; i3 < eles.length; i3++) { + var ele = eles[i3]; + if (!ele.isNode()) { + continue; + } + var disqualified = false; + var edges2 = ele.connectedEdges(); + for (var j = 0; j < edges2.length; j++) { + var edge = edges2[j]; + var src = edge.source(); + var tgt = edge.target(); + if (params.noIncomingEdges && tgt === ele && src !== ele || params.noOutgoingEdges && src === ele && tgt !== ele) { + disqualified = true; + break; + } + } + if (!disqualified) { + ret.push(ele); + } + } + return this.spawn(ret, true).filter(selector2); + }; + }; + var defineDagOneHop = function defineDagOneHop2(params) { + return function(selector2) { + var eles = this; + var oEles = []; + for (var i3 = 0; i3 < eles.length; i3++) { + var ele = eles[i3]; + if (!ele.isNode()) { + continue; + } + var edges2 = ele.connectedEdges(); + for (var j = 0; j < edges2.length; j++) { + var edge = edges2[j]; + var src = edge.source(); + var tgt = edge.target(); + if (params.outgoing && src === ele) { + oEles.push(edge); + oEles.push(tgt); + } else if (params.incoming && tgt === ele) { + oEles.push(edge); + oEles.push(src); + } + } + } + return this.spawn(oEles, true).filter(selector2); + }; + }; + var defineDagAllHops = function defineDagAllHops2(params) { + return function(selector2) { + var eles = this; + var sEles = []; + var sElesIds = {}; + for (; ; ) { + var next2 = params.outgoing ? eles.outgoers() : eles.incomers(); + if (next2.length === 0) { + break; + } + var newNext = false; + for (var i3 = 0; i3 < next2.length; i3++) { + var n = next2[i3]; + var nid = n.id(); + if (!sElesIds[nid]) { + sElesIds[nid] = true; + sEles.push(n); + newNext = true; + } + } + if (!newNext) { + break; + } + eles = next2; + } + return this.spawn(sEles, true).filter(selector2); + }; + }; + elesfn$2.clearTraversalCache = function() { + for (var i3 = 0; i3 < this.length; i3++) { + this[i3]._private.traversalCache = null; + } + }; + extend2(elesfn$2, { + // get the root nodes in the DAG + roots: defineDagExtremity({ + noIncomingEdges: true + }), + // get the leaf nodes in the DAG + leaves: defineDagExtremity({ + noOutgoingEdges: true + }), + // normally called children in graph theory + // these nodes =edges=> outgoing nodes + outgoers: cache(defineDagOneHop({ + outgoing: true + }), "outgoers"), + // aka DAG descendants + successors: defineDagAllHops({ + outgoing: true + }), + // normally called parents in graph theory + // these nodes <=edges= incoming nodes + incomers: cache(defineDagOneHop({ + incoming: true + }), "incomers"), + // aka DAG ancestors + predecessors: defineDagAllHops({ + incoming: true + }) + }); + extend2(elesfn$2, { + neighborhood: cache(function(selector2) { + var elements2 = []; + var nodes2 = this.nodes(); + for (var i3 = 0; i3 < nodes2.length; i3++) { + var node2 = nodes2[i3]; + var connectedEdges = node2.connectedEdges(); + for (var j = 0; j < connectedEdges.length; j++) { + var edge = connectedEdges[j]; + var src = edge.source(); + var tgt = edge.target(); + var otherNode = node2 === src ? tgt : src; + if (otherNode.length > 0) { + elements2.push(otherNode[0]); + } + elements2.push(edge[0]); + } + } + return this.spawn(elements2, true).filter(selector2); + }, "neighborhood"), + closedNeighborhood: function closedNeighborhood(selector2) { + return this.neighborhood().add(this).filter(selector2); + }, + openNeighborhood: function openNeighborhood(selector2) { + return this.neighborhood(selector2); + } + }); + elesfn$2.neighbourhood = elesfn$2.neighborhood; + elesfn$2.closedNeighbourhood = elesfn$2.closedNeighborhood; + elesfn$2.openNeighbourhood = elesfn$2.openNeighborhood; + extend2(elesfn$2, { + source: cache(function sourceImpl(selector2) { + var ele = this[0]; + var src; + if (ele) { + src = ele._private.source || ele.cy().collection(); + } + return src && selector2 ? src.filter(selector2) : src; + }, "source"), + target: cache(function targetImpl(selector2) { + var ele = this[0]; + var tgt; + if (ele) { + tgt = ele._private.target || ele.cy().collection(); + } + return tgt && selector2 ? tgt.filter(selector2) : tgt; + }, "target"), + sources: defineSourceFunction({ + attr: "source" + }), + targets: defineSourceFunction({ + attr: "target" + }) + }); + function defineSourceFunction(params) { + return function sourceImpl(selector2) { + var sources = []; + for (var i3 = 0; i3 < this.length; i3++) { + var ele = this[i3]; + var src = ele._private[params.attr]; + if (src) { + sources.push(src); + } + } + return this.spawn(sources, true).filter(selector2); + }; + } + extend2(elesfn$2, { + edgesWith: cache(defineEdgesWithFunction(), "edgesWith"), + edgesTo: cache(defineEdgesWithFunction({ + thisIsSrc: true + }), "edgesTo") + }); + function defineEdgesWithFunction(params) { + return function edgesWithImpl(otherNodes) { + var elements2 = []; + var cy = this._private.cy; + var p2 = params || {}; + if (string2(otherNodes)) { + otherNodes = cy.$(otherNodes); + } + for (var h = 0; h < otherNodes.length; h++) { + var edges2 = otherNodes[h]._private.edges; + for (var i3 = 0; i3 < edges2.length; i3++) { + var edge = edges2[i3]; + var edgeData = edge._private.data; + var thisToOther = this.hasElementWithId(edgeData.source) && otherNodes.hasElementWithId(edgeData.target); + var otherToThis = otherNodes.hasElementWithId(edgeData.source) && this.hasElementWithId(edgeData.target); + var edgeConnectsThisAndOther = thisToOther || otherToThis; + if (!edgeConnectsThisAndOther) { + continue; + } + if (p2.thisIsSrc || p2.thisIsTgt) { + if (p2.thisIsSrc && !thisToOther) { + continue; + } + if (p2.thisIsTgt && !otherToThis) { + continue; + } + } + elements2.push(edge); + } + } + return this.spawn(elements2, true); + }; + } + extend2(elesfn$2, { + connectedEdges: cache(function(selector2) { + var retEles = []; + var eles = this; + for (var i3 = 0; i3 < eles.length; i3++) { + var node2 = eles[i3]; + if (!node2.isNode()) { + continue; + } + var edges2 = node2._private.edges; + for (var j = 0; j < edges2.length; j++) { + var edge = edges2[j]; + retEles.push(edge); + } + } + return this.spawn(retEles, true).filter(selector2); + }, "connectedEdges"), + connectedNodes: cache(function(selector2) { + var retEles = []; + var eles = this; + for (var i3 = 0; i3 < eles.length; i3++) { + var edge = eles[i3]; + if (!edge.isEdge()) { + continue; + } + retEles.push(edge.source()[0]); + retEles.push(edge.target()[0]); + } + return this.spawn(retEles, true).filter(selector2); + }, "connectedNodes"), + parallelEdges: cache(defineParallelEdgesFunction(), "parallelEdges"), + codirectedEdges: cache(defineParallelEdgesFunction({ + codirected: true + }), "codirectedEdges") + }); + function defineParallelEdgesFunction(params) { + var defaults3 = { + codirected: false + }; + params = extend2({}, defaults3, params); + return function parallelEdgesImpl(selector2) { + var elements2 = []; + var edges2 = this.edges(); + var p2 = params; + for (var i3 = 0; i3 < edges2.length; i3++) { + var edge1 = edges2[i3]; + var edge1_p = edge1._private; + var src1 = edge1_p.source; + var srcid1 = src1._private.data.id; + var tgtid1 = edge1_p.data.target; + var srcEdges1 = src1._private.edges; + for (var j = 0; j < srcEdges1.length; j++) { + var edge2 = srcEdges1[j]; + var edge2data = edge2._private.data; + var tgtid2 = edge2data.target; + var srcid2 = edge2data.source; + var codirected = tgtid2 === tgtid1 && srcid2 === srcid1; + var oppdirected = srcid1 === tgtid2 && tgtid1 === srcid2; + if (p2.codirected && codirected || !p2.codirected && (codirected || oppdirected)) { + elements2.push(edge2); + } + } + } + return this.spawn(elements2, true).filter(selector2); + }; + } + extend2(elesfn$2, { + components: function components(root3) { + var self2 = this; + var cy = self2.cy(); + var visited = cy.collection(); + var unvisited = root3 == null ? self2.nodes() : root3.nodes(); + var components2 = []; + if (root3 != null && unvisited.empty()) { + unvisited = root3.sources(); + } + var visitInComponent = function visitInComponent2(node2, component) { + visited.merge(node2); + unvisited.unmerge(node2); + component.merge(node2); + }; + if (unvisited.empty()) { + return self2.spawn(); + } + var _loop = function _loop2() { + var cmpt = cy.collection(); + components2.push(cmpt); + var root4 = unvisited[0]; + visitInComponent(root4, cmpt); + self2.bfs({ + directed: false, + roots: root4, + visit: function visit(v) { + return visitInComponent(v, cmpt); + } + }); + cmpt.forEach(function(node2) { + node2.connectedEdges().forEach(function(e) { + if (self2.has(e) && cmpt.has(e.source()) && cmpt.has(e.target())) { + cmpt.merge(e); + } + }); + }); + }; + do { + _loop(); + } while (unvisited.length > 0); + return components2; + }, + component: function component() { + var ele = this[0]; + return ele.cy().mutableElements().components(ele)[0]; + } + }); + elesfn$2.componentsOf = elesfn$2.components; + var Collection = function Collection2(cy, elements2) { + var unique = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : false; + var removed = arguments.length > 3 && arguments[3] !== void 0 ? arguments[3] : false; + if (cy === void 0) { + error("A collection must have a reference to the core"); + return; + } + var map2 = new Map$22(); + var createdElements = false; + if (!elements2) { + elements2 = []; + } else if (elements2.length > 0 && plainObject(elements2[0]) && !element2(elements2[0])) { + createdElements = true; + var eles = []; + var elesIds = new Set$12(); + for (var i3 = 0, l = elements2.length; i3 < l; i3++) { + var json2 = elements2[i3]; + if (json2.data == null) { + json2.data = {}; + } + var _data = json2.data; + if (_data.id == null) { + _data.id = uuid(); + } else if (cy.hasElementWithId(_data.id) || elesIds.has(_data.id)) { + continue; + } + var ele = new Element(cy, json2, false); + eles.push(ele); + elesIds.add(_data.id); + } + elements2 = eles; + } + this.length = 0; + for (var _i6 = 0, _l = elements2.length; _i6 < _l; _i6++) { + var element$1 = elements2[_i6][0]; + if (element$1 == null) { + continue; + } + var id2 = element$1._private.data.id; + if (!unique || !map2.has(id2)) { + if (unique) { + map2.set(id2, { + index: this.length, + ele: element$1 + }); + } + this[this.length] = element$1; + this.length++; + } + } + this._private = { + eles: this, + cy, + get map() { + if (this.lazyMap == null) { + this.rebuildMap(); + } + return this.lazyMap; + }, + set map(m) { + this.lazyMap = m; + }, + rebuildMap: function rebuildMap() { + var m = this.lazyMap = new Map$22(); + var eles2 = this.eles; + for (var _i22 = 0; _i22 < eles2.length; _i22++) { + var _ele = eles2[_i22]; + m.set(_ele.id(), { + index: _i22, + ele: _ele + }); + } + } + }; + if (unique) { + this._private.map = map2; + } + if (createdElements && !removed) { + this.restore(); + } + }; + var elesfn$1 = Element.prototype = Collection.prototype = Object.create(Array.prototype); + elesfn$1.instanceString = function() { + return "collection"; + }; + elesfn$1.spawn = function(eles, unique) { + return new Collection(this.cy(), eles, unique); + }; + elesfn$1.spawnSelf = function() { + return this.spawn(this); + }; + elesfn$1.cy = function() { + return this._private.cy; + }; + elesfn$1.renderer = function() { + return this._private.cy.renderer(); + }; + elesfn$1.element = function() { + return this[0]; + }; + elesfn$1.collection = function() { + if (collection(this)) { + return this; + } else { + return new Collection(this._private.cy, [this]); + } + }; + elesfn$1.unique = function() { + return new Collection(this._private.cy, this, true); + }; + elesfn$1.hasElementWithId = function(id2) { + id2 = "" + id2; + return this._private.map.has(id2); + }; + elesfn$1.getElementById = function(id2) { + id2 = "" + id2; + var cy = this._private.cy; + var entry = this._private.map.get(id2); + return entry ? entry.ele : new Collection(cy); + }; + elesfn$1.$id = elesfn$1.getElementById; + elesfn$1.poolIndex = function() { + var cy = this._private.cy; + var eles = cy._private.elements; + var id2 = this[0]._private.data.id; + return eles._private.map.get(id2).index; + }; + elesfn$1.indexOf = function(ele) { + var id2 = ele[0]._private.data.id; + return this._private.map.get(id2).index; + }; + elesfn$1.indexOfId = function(id2) { + id2 = "" + id2; + return this._private.map.get(id2).index; + }; + elesfn$1.json = function(obj) { + var ele = this.element(); + var cy = this.cy(); + if (ele == null && obj) { + return this; + } + if (ele == null) { + return void 0; + } + var p2 = ele._private; + if (plainObject(obj)) { + cy.startBatch(); + if (obj.data) { + ele.data(obj.data); + var _data2 = p2.data; + if (ele.isEdge()) { + var move = false; + var spec = {}; + var src = obj.data.source; + var tgt = obj.data.target; + if (src != null && src != _data2.source) { + spec.source = "" + src; + move = true; + } + if (tgt != null && tgt != _data2.target) { + spec.target = "" + tgt; + move = true; + } + if (move) { + ele = ele.move(spec); + } + } else { + var newParentValSpecd = "parent" in obj.data; + var parent = obj.data.parent; + if (newParentValSpecd && (parent != null || _data2.parent != null) && parent != _data2.parent) { + if (parent === void 0) { + parent = null; + } + if (parent != null) { + parent = "" + parent; + } + ele = ele.move({ + parent + }); + } + } + } + if (obj.position) { + ele.position(obj.position); + } + var checkSwitch = function checkSwitch2(k, trueFnName, falseFnName) { + var obj_k = obj[k]; + if (obj_k != null && obj_k !== p2[k]) { + if (obj_k) { + ele[trueFnName](); + } else { + ele[falseFnName](); + } + } + }; + checkSwitch("removed", "remove", "restore"); + checkSwitch("selected", "select", "unselect"); + checkSwitch("selectable", "selectify", "unselectify"); + checkSwitch("locked", "lock", "unlock"); + checkSwitch("grabbable", "grabify", "ungrabify"); + checkSwitch("pannable", "panify", "unpanify"); + if (obj.classes != null) { + ele.classes(obj.classes); + } + cy.endBatch(); + return this; + } else if (obj === void 0) { + var json2 = { + data: copy2(p2.data), + position: copy2(p2.position), + group: p2.group, + removed: p2.removed, + selected: p2.selected, + selectable: p2.selectable, + locked: p2.locked, + grabbable: p2.grabbable, + pannable: p2.pannable, + classes: null + }; + json2.classes = ""; + var i3 = 0; + p2.classes.forEach(function(cls) { + return json2.classes += i3++ === 0 ? cls : " " + cls; + }); + return json2; + } + }; + elesfn$1.jsons = function() { + var jsons = []; + for (var i3 = 0; i3 < this.length; i3++) { + var ele = this[i3]; + var json2 = ele.json(); + jsons.push(json2); + } + return jsons; + }; + elesfn$1.clone = function() { + var cy = this.cy(); + var elesArr = []; + for (var i3 = 0; i3 < this.length; i3++) { + var ele = this[i3]; + var json2 = ele.json(); + var clone3 = new Element(cy, json2, false); + elesArr.push(clone3); + } + return new Collection(cy, elesArr); + }; + elesfn$1.copy = elesfn$1.clone; + elesfn$1.restore = function() { + var notifyRenderer = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : true; + var addToPool = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : true; + var self2 = this; + var cy = self2.cy(); + var cy_p = cy._private; + var nodes2 = []; + var edges2 = []; + var elements2; + for (var _i32 = 0, l = self2.length; _i32 < l; _i32++) { + var ele = self2[_i32]; + if (addToPool && !ele.removed()) { + continue; + } + if (ele.isNode()) { + nodes2.push(ele); + } else { + edges2.push(ele); + } + } + elements2 = nodes2.concat(edges2); + var i3; + var removeFromElements = function removeFromElements2() { + elements2.splice(i3, 1); + i3--; + }; + for (i3 = 0; i3 < elements2.length; i3++) { + var _ele2 = elements2[i3]; + var _private = _ele2._private; + var _data3 = _private.data; + _ele2.clearTraversalCache(); + if (!addToPool && !_private.removed) + ; + else if (_data3.id === void 0) { + _data3.id = uuid(); + } else if (number$12(_data3.id)) { + _data3.id = "" + _data3.id; + } else if (emptyString(_data3.id) || !string2(_data3.id)) { + error("Can not create element with invalid string ID `" + _data3.id + "`"); + removeFromElements(); + continue; + } else if (cy.hasElementWithId(_data3.id)) { + error("Can not create second element with ID `" + _data3.id + "`"); + removeFromElements(); + continue; + } + var id2 = _data3.id; + if (_ele2.isNode()) { + var pos = _private.position; + if (pos.x == null) { + pos.x = 0; + } + if (pos.y == null) { + pos.y = 0; + } + } + if (_ele2.isEdge()) { + var edge = _ele2; + var fields = ["source", "target"]; + var fieldsLength = fields.length; + var badSourceOrTarget = false; + for (var j = 0; j < fieldsLength; j++) { + var field = fields[j]; + var val = _data3[field]; + if (number$12(val)) { + val = _data3[field] = "" + _data3[field]; + } + if (val == null || val === "") { + error("Can not create edge `" + id2 + "` with unspecified " + field); + badSourceOrTarget = true; + } else if (!cy.hasElementWithId(val)) { + error("Can not create edge `" + id2 + "` with nonexistant " + field + " `" + val + "`"); + badSourceOrTarget = true; + } + } + if (badSourceOrTarget) { + removeFromElements(); + continue; + } + var src = cy.getElementById(_data3.source); + var tgt = cy.getElementById(_data3.target); + if (src.same(tgt)) { + src._private.edges.push(edge); + } else { + src._private.edges.push(edge); + tgt._private.edges.push(edge); + } + edge._private.source = src; + edge._private.target = tgt; + } + _private.map = new Map$22(); + _private.map.set(id2, { + ele: _ele2, + index: 0 + }); + _private.removed = false; + if (addToPool) { + cy.addToPool(_ele2); + } + } + for (var _i42 = 0; _i42 < nodes2.length; _i42++) { + var node2 = nodes2[_i42]; + var _data4 = node2._private.data; + if (number$12(_data4.parent)) { + _data4.parent = "" + _data4.parent; + } + var parentId = _data4.parent; + var specifiedParent = parentId != null; + if (specifiedParent || node2._private.parent) { + var parent = node2._private.parent ? cy.collection().merge(node2._private.parent) : cy.getElementById(parentId); + if (parent.empty()) { + _data4.parent = void 0; + } else if (parent[0].removed()) { + warn("Node added with missing parent, reference to parent removed"); + _data4.parent = void 0; + node2._private.parent = null; + } else { + var selfAsParent = false; + var ancestor = parent; + while (!ancestor.empty()) { + if (node2.same(ancestor)) { + selfAsParent = true; + _data4.parent = void 0; + break; + } + ancestor = ancestor.parent(); + } + if (!selfAsParent) { + parent[0]._private.children.push(node2); + node2._private.parent = parent[0]; + cy_p.hasCompoundNodes = true; + } + } + } + } + if (elements2.length > 0) { + var restored = elements2.length === self2.length ? self2 : new Collection(cy, elements2); + for (var _i52 = 0; _i52 < restored.length; _i52++) { + var _ele3 = restored[_i52]; + if (_ele3.isNode()) { + continue; + } + _ele3.parallelEdges().clearTraversalCache(); + _ele3.source().clearTraversalCache(); + _ele3.target().clearTraversalCache(); + } + var toUpdateStyle; + if (cy_p.hasCompoundNodes) { + toUpdateStyle = cy.collection().merge(restored).merge(restored.connectedNodes()).merge(restored.parent()); + } else { + toUpdateStyle = restored; + } + toUpdateStyle.dirtyCompoundBoundsCache().dirtyBoundingBoxCache().updateStyle(notifyRenderer); + if (notifyRenderer) { + restored.emitAndNotify("add"); + } else if (addToPool) { + restored.emit("add"); + } + } + return self2; + }; + elesfn$1.removed = function() { + var ele = this[0]; + return ele && ele._private.removed; + }; + elesfn$1.inside = function() { + var ele = this[0]; + return ele && !ele._private.removed; + }; + elesfn$1.remove = function() { + var notifyRenderer = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : true; + var removeFromPool = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : true; + var self2 = this; + var elesToRemove = []; + var elesToRemoveIds = {}; + var cy = self2._private.cy; + function addConnectedEdges(node2) { + var edges2 = node2._private.edges; + for (var i4 = 0; i4 < edges2.length; i4++) { + add(edges2[i4]); + } + } + function addChildren2(node2) { + var children2 = node2._private.children; + for (var i4 = 0; i4 < children2.length; i4++) { + add(children2[i4]); + } + } + function add(ele2) { + var alreadyAdded = elesToRemoveIds[ele2.id()]; + if (removeFromPool && ele2.removed() || alreadyAdded) { + return; + } else { + elesToRemoveIds[ele2.id()] = true; + } + if (ele2.isNode()) { + elesToRemove.push(ele2); + addConnectedEdges(ele2); + addChildren2(ele2); + } else { + elesToRemove.unshift(ele2); + } + } + for (var i3 = 0, l = self2.length; i3 < l; i3++) { + var ele = self2[i3]; + add(ele); + } + function removeEdgeRef(node2, edge) { + var connectedEdges = node2._private.edges; + removeFromArray(connectedEdges, edge); + node2.clearTraversalCache(); + } + function removeParallelRef(pllEdge2) { + pllEdge2.clearTraversalCache(); + } + var alteredParents = []; + alteredParents.ids = {}; + function removeChildRef(parent2, ele2) { + ele2 = ele2[0]; + parent2 = parent2[0]; + var children2 = parent2._private.children; + var pid = parent2.id(); + removeFromArray(children2, ele2); + ele2._private.parent = null; + if (!alteredParents.ids[pid]) { + alteredParents.ids[pid] = true; + alteredParents.push(parent2); + } + } + self2.dirtyCompoundBoundsCache(); + if (removeFromPool) { + cy.removeFromPool(elesToRemove); + } + for (var _i6 = 0; _i6 < elesToRemove.length; _i6++) { + var _ele4 = elesToRemove[_i6]; + if (_ele4.isEdge()) { + var src = _ele4.source()[0]; + var tgt = _ele4.target()[0]; + removeEdgeRef(src, _ele4); + removeEdgeRef(tgt, _ele4); + var pllEdges = _ele4.parallelEdges(); + for (var j = 0; j < pllEdges.length; j++) { + var pllEdge = pllEdges[j]; + removeParallelRef(pllEdge); + if (pllEdge.isBundledBezier()) { + pllEdge.dirtyBoundingBoxCache(); + } + } + } else { + var parent = _ele4.parent(); + if (parent.length !== 0) { + removeChildRef(parent, _ele4); + } + } + if (removeFromPool) { + _ele4._private.removed = true; + } + } + var elesStillInside = cy._private.elements; + cy._private.hasCompoundNodes = false; + for (var _i7 = 0; _i7 < elesStillInside.length; _i7++) { + var _ele5 = elesStillInside[_i7]; + if (_ele5.isParent()) { + cy._private.hasCompoundNodes = true; + break; + } + } + var removedElements = new Collection(this.cy(), elesToRemove); + if (removedElements.size() > 0) { + if (notifyRenderer) { + removedElements.emitAndNotify("remove"); + } else if (removeFromPool) { + removedElements.emit("remove"); + } + } + for (var _i8 = 0; _i8 < alteredParents.length; _i8++) { + var _ele6 = alteredParents[_i8]; + if (!removeFromPool || !_ele6.removed()) { + _ele6.updateStyle(); + } + } + return removedElements; + }; + elesfn$1.move = function(struct) { + var cy = this._private.cy; + var eles = this; + var notifyRenderer = false; + var modifyPool = false; + var toString3 = function toString4(id2) { + return id2 == null ? id2 : "" + id2; + }; + if (struct.source !== void 0 || struct.target !== void 0) { + var srcId = toString3(struct.source); + var tgtId = toString3(struct.target); + var srcExists = srcId != null && cy.hasElementWithId(srcId); + var tgtExists = tgtId != null && cy.hasElementWithId(tgtId); + if (srcExists || tgtExists) { + cy.batch(function() { + eles.remove(notifyRenderer, modifyPool); + eles.emitAndNotify("moveout"); + for (var i3 = 0; i3 < eles.length; i3++) { + var ele = eles[i3]; + var _data5 = ele._private.data; + if (ele.isEdge()) { + if (srcExists) { + _data5.source = srcId; + } + if (tgtExists) { + _data5.target = tgtId; + } + } + } + eles.restore(notifyRenderer, modifyPool); + }); + eles.emitAndNotify("move"); + } + } else if (struct.parent !== void 0) { + var parentId = toString3(struct.parent); + var parentExists = parentId === null || cy.hasElementWithId(parentId); + if (parentExists) { + var pidToAssign = parentId === null ? void 0 : parentId; + cy.batch(function() { + var updated = eles.remove(notifyRenderer, modifyPool); + updated.emitAndNotify("moveout"); + for (var i3 = 0; i3 < eles.length; i3++) { + var ele = eles[i3]; + var _data6 = ele._private.data; + if (ele.isNode()) { + _data6.parent = pidToAssign; + } + } + updated.restore(notifyRenderer, modifyPool); + }); + eles.emitAndNotify("move"); + } + } + return this; + }; + [elesfn$j, elesfn$i, elesfn$h, elesfn$g, elesfn$f, data, elesfn$d, dimensions, elesfn$9, elesfn$8, elesfn$7, elesfn$6, elesfn$5, elesfn$4, elesfn$3, elesfn$2].forEach(function(props) { + extend2(elesfn$1, props); + }); + var corefn$9 = { + add: function add(opts) { + var elements2; + var cy = this; + if (elementOrCollection(opts)) { + var eles = opts; + if (eles._private.cy === cy) { + elements2 = eles.restore(); + } else { + var jsons = []; + for (var i3 = 0; i3 < eles.length; i3++) { + var ele = eles[i3]; + jsons.push(ele.json()); + } + elements2 = new Collection(cy, jsons); + } + } else if (array2(opts)) { + var _jsons = opts; + elements2 = new Collection(cy, _jsons); + } else if (plainObject(opts) && (array2(opts.nodes) || array2(opts.edges))) { + var elesByGroup = opts; + var _jsons2 = []; + var grs = ["nodes", "edges"]; + for (var _i6 = 0, il = grs.length; _i6 < il; _i6++) { + var group = grs[_i6]; + var elesArray = elesByGroup[group]; + if (array2(elesArray)) { + for (var j = 0, jl = elesArray.length; j < jl; j++) { + var json2 = extend2({ + group + }, elesArray[j]); + _jsons2.push(json2); + } + } + } + elements2 = new Collection(cy, _jsons2); + } else { + var _json = opts; + elements2 = new Element(cy, _json).collection(); + } + return elements2; + }, + remove: function remove2(collection2) { + if (elementOrCollection(collection2)) + ; + else if (string2(collection2)) { + var selector2 = collection2; + collection2 = this.$(selector2); + } + return collection2.remove(); + } + }; + /*! Bezier curve function generator. Copyright Gaetan Renaudeau. MIT License: http://en.wikipedia.org/wiki/MIT_License */ + function generateCubicBezier(mX1, mY1, mX2, mY2) { + var NEWTON_ITERATIONS = 4, NEWTON_MIN_SLOPE = 1e-3, SUBDIVISION_PRECISION = 1e-7, SUBDIVISION_MAX_ITERATIONS = 10, kSplineTableSize = 11, kSampleStepSize = 1 / (kSplineTableSize - 1), float32ArraySupported = typeof Float32Array !== "undefined"; + if (arguments.length !== 4) { + return false; + } + for (var i3 = 0; i3 < 4; ++i3) { + if (typeof arguments[i3] !== "number" || isNaN(arguments[i3]) || !isFinite(arguments[i3])) { + return false; + } + } + mX1 = Math.min(mX1, 1); + mX2 = Math.min(mX2, 1); + mX1 = Math.max(mX1, 0); + mX2 = Math.max(mX2, 0); + var mSampleValues = float32ArraySupported ? new Float32Array(kSplineTableSize) : new Array(kSplineTableSize); + function A(aA1, aA2) { + return 1 - 3 * aA2 + 3 * aA1; + } + function B(aA1, aA2) { + return 3 * aA2 - 6 * aA1; + } + function C(aA1) { + return 3 * aA1; + } + function calcBezier(aT, aA1, aA2) { + return ((A(aA1, aA2) * aT + B(aA1, aA2)) * aT + C(aA1)) * aT; + } + function getSlope(aT, aA1, aA2) { + return 3 * A(aA1, aA2) * aT * aT + 2 * B(aA1, aA2) * aT + C(aA1); + } + function newtonRaphsonIterate(aX, aGuessT) { + for (var _i6 = 0; _i6 < NEWTON_ITERATIONS; ++_i6) { + var currentSlope = getSlope(aGuessT, mX1, mX2); + if (currentSlope === 0) { + return aGuessT; + } + var currentX = calcBezier(aGuessT, mX1, mX2) - aX; + aGuessT -= currentX / currentSlope; + } + return aGuessT; + } + function calcSampleValues() { + for (var _i22 = 0; _i22 < kSplineTableSize; ++_i22) { + mSampleValues[_i22] = calcBezier(_i22 * kSampleStepSize, mX1, mX2); + } + } + function binarySubdivide(aX, aA, aB) { + var currentX, currentT, i4 = 0; + do { + currentT = aA + (aB - aA) / 2; + currentX = calcBezier(currentT, mX1, mX2) - aX; + if (currentX > 0) { + aB = currentT; + } else { + aA = currentT; + } + } while (Math.abs(currentX) > SUBDIVISION_PRECISION && ++i4 < SUBDIVISION_MAX_ITERATIONS); + return currentT; + } + function getTForX(aX) { + var intervalStart = 0, currentSample = 1, lastSample = kSplineTableSize - 1; + for (; currentSample !== lastSample && mSampleValues[currentSample] <= aX; ++currentSample) { + intervalStart += kSampleStepSize; + } + --currentSample; + var dist3 = (aX - mSampleValues[currentSample]) / (mSampleValues[currentSample + 1] - mSampleValues[currentSample]), guessForT = intervalStart + dist3 * kSampleStepSize, initialSlope = getSlope(guessForT, mX1, mX2); + if (initialSlope >= NEWTON_MIN_SLOPE) { + return newtonRaphsonIterate(aX, guessForT); + } else if (initialSlope === 0) { + return guessForT; + } else { + return binarySubdivide(aX, intervalStart, intervalStart + kSampleStepSize); + } + } + var _precomputed = false; + function precompute() { + _precomputed = true; + if (mX1 !== mY1 || mX2 !== mY2) { + calcSampleValues(); + } + } + var f2 = function f3(aX) { + if (!_precomputed) { + precompute(); + } + if (mX1 === mY1 && mX2 === mY2) { + return aX; + } + if (aX === 0) { + return 0; + } + if (aX === 1) { + return 1; + } + return calcBezier(getTForX(aX), mY1, mY2); + }; + f2.getControlPoints = function() { + return [{ + x: mX1, + y: mY1 + }, { + x: mX2, + y: mY2 + }]; + }; + var str2 = "generateBezier(" + [mX1, mY1, mX2, mY2] + ")"; + f2.toString = function() { + return str2; + }; + return f2; + } + /*! Runge-Kutta spring physics function generator. Adapted from Framer.js, copyright Koen Bok. MIT License: http://en.wikipedia.org/wiki/MIT_License */ + var generateSpringRK4 = function() { + function springAccelerationForState(state2) { + return -state2.tension * state2.x - state2.friction * state2.v; + } + function springEvaluateStateWithDerivative(initialState, dt, derivative) { + var state2 = { + x: initialState.x + derivative.dx * dt, + v: initialState.v + derivative.dv * dt, + tension: initialState.tension, + friction: initialState.friction + }; + return { + dx: state2.v, + dv: springAccelerationForState(state2) + }; + } + function springIntegrateState(state2, dt) { + var a = { + dx: state2.v, + dv: springAccelerationForState(state2) + }, b = springEvaluateStateWithDerivative(state2, dt * 0.5, a), c2 = springEvaluateStateWithDerivative(state2, dt * 0.5, b), d = springEvaluateStateWithDerivative(state2, dt, c2), dxdt = 1 / 6 * (a.dx + 2 * (b.dx + c2.dx) + d.dx), dvdt = 1 / 6 * (a.dv + 2 * (b.dv + c2.dv) + d.dv); + state2.x = state2.x + dxdt * dt; + state2.v = state2.v + dvdt * dt; + return state2; + } + return function springRK4Factory(tension, friction, duration) { + var initState = { + x: -1, + v: 0, + tension: null, + friction: null + }, path2 = [0], time_lapsed = 0, tolerance = 1 / 1e4, DT = 16 / 1e3, have_duration, dt, last_state; + tension = parseFloat(tension) || 500; + friction = parseFloat(friction) || 20; + duration = duration || null; + initState.tension = tension; + initState.friction = friction; + have_duration = duration !== null; + if (have_duration) { + time_lapsed = springRK4Factory(tension, friction); + dt = time_lapsed / duration * DT; + } else { + dt = DT; + } + for (; ; ) { + last_state = springIntegrateState(last_state || initState, dt); + path2.push(1 + last_state.x); + time_lapsed += 16; + if (!(Math.abs(last_state.x) > tolerance && Math.abs(last_state.v) > tolerance)) { + break; + } + } + return !have_duration ? time_lapsed : function(percentComplete) { + return path2[percentComplete * (path2.length - 1) | 0]; + }; + }; + }(); + var cubicBezier = function cubicBezier2(t12, p1, t22, p2) { + var bezier = generateCubicBezier(t12, p1, t22, p2); + return function(start2, end2, percent) { + return start2 + (end2 - start2) * bezier(percent); + }; + }; + var easings = { + "linear": function linear2(start2, end2, percent) { + return start2 + (end2 - start2) * percent; + }, + // default easings + "ease": cubicBezier(0.25, 0.1, 0.25, 1), + "ease-in": cubicBezier(0.42, 0, 1, 1), + "ease-out": cubicBezier(0, 0, 0.58, 1), + "ease-in-out": cubicBezier(0.42, 0, 0.58, 1), + // sine + "ease-in-sine": cubicBezier(0.47, 0, 0.745, 0.715), + "ease-out-sine": cubicBezier(0.39, 0.575, 0.565, 1), + "ease-in-out-sine": cubicBezier(0.445, 0.05, 0.55, 0.95), + // quad + "ease-in-quad": cubicBezier(0.55, 0.085, 0.68, 0.53), + "ease-out-quad": cubicBezier(0.25, 0.46, 0.45, 0.94), + "ease-in-out-quad": cubicBezier(0.455, 0.03, 0.515, 0.955), + // cubic + "ease-in-cubic": cubicBezier(0.55, 0.055, 0.675, 0.19), + "ease-out-cubic": cubicBezier(0.215, 0.61, 0.355, 1), + "ease-in-out-cubic": cubicBezier(0.645, 0.045, 0.355, 1), + // quart + "ease-in-quart": cubicBezier(0.895, 0.03, 0.685, 0.22), + "ease-out-quart": cubicBezier(0.165, 0.84, 0.44, 1), + "ease-in-out-quart": cubicBezier(0.77, 0, 0.175, 1), + // quint + "ease-in-quint": cubicBezier(0.755, 0.05, 0.855, 0.06), + "ease-out-quint": cubicBezier(0.23, 1, 0.32, 1), + "ease-in-out-quint": cubicBezier(0.86, 0, 0.07, 1), + // expo + "ease-in-expo": cubicBezier(0.95, 0.05, 0.795, 0.035), + "ease-out-expo": cubicBezier(0.19, 1, 0.22, 1), + "ease-in-out-expo": cubicBezier(1, 0, 0, 1), + // circ + "ease-in-circ": cubicBezier(0.6, 0.04, 0.98, 0.335), + "ease-out-circ": cubicBezier(0.075, 0.82, 0.165, 1), + "ease-in-out-circ": cubicBezier(0.785, 0.135, 0.15, 0.86), + // user param easings... + "spring": function spring(tension, friction, duration) { + if (duration === 0) { + return easings.linear; + } + var spring2 = generateSpringRK4(tension, friction, duration); + return function(start2, end2, percent) { + return start2 + (end2 - start2) * spring2(percent); + }; + }, + "cubic-bezier": cubicBezier + }; + function getEasedValue(type2, start2, end2, percent, easingFn) { + if (percent === 1) { + return end2; + } + if (start2 === end2) { + return end2; + } + var val = easingFn(start2, end2, percent); + if (type2 == null) { + return val; + } + if (type2.roundValue || type2.color) { + val = Math.round(val); + } + if (type2.min !== void 0) { + val = Math.max(val, type2.min); + } + if (type2.max !== void 0) { + val = Math.min(val, type2.max); + } + return val; + } + function getValue2(prop, spec) { + if (prop.pfValue != null || prop.value != null) { + if (prop.pfValue != null && (spec == null || spec.type.units !== "%")) { + return prop.pfValue; + } else { + return prop.value; + } + } else { + return prop; + } + } + function ease(startProp, endProp, percent, easingFn, propSpec) { + var type2 = propSpec != null ? propSpec.type : null; + if (percent < 0) { + percent = 0; + } else if (percent > 1) { + percent = 1; + } + var start2 = getValue2(startProp, propSpec); + var end2 = getValue2(endProp, propSpec); + if (number$12(start2) && number$12(end2)) { + return getEasedValue(type2, start2, end2, percent, easingFn); + } else if (array2(start2) && array2(end2)) { + var easedArr = []; + for (var i3 = 0; i3 < end2.length; i3++) { + var si = start2[i3]; + var ei = end2[i3]; + if (si != null && ei != null) { + var val = getEasedValue(type2, si, ei, percent, easingFn); + easedArr.push(val); + } else { + easedArr.push(ei); + } + } + return easedArr; + } + return void 0; + } + function step$1(self2, ani, now3, isCore) { + var isEles = !isCore; + var _p = self2._private; + var ani_p = ani._private; + var pEasing = ani_p.easing; + var startTime = ani_p.startTime; + var cy = isCore ? self2 : self2.cy(); + var style = cy.style(); + if (!ani_p.easingImpl) { + if (pEasing == null) { + ani_p.easingImpl = easings["linear"]; + } else { + var easingVals; + if (string2(pEasing)) { + var easingProp = style.parse("transition-timing-function", pEasing); + easingVals = easingProp.value; + } else { + easingVals = pEasing; + } + var name, args; + if (string2(easingVals)) { + name = easingVals; + args = []; + } else { + name = easingVals[1]; + args = easingVals.slice(2).map(function(n) { + return +n; + }); + } + if (args.length > 0) { + if (name === "spring") { + args.push(ani_p.duration); + } + ani_p.easingImpl = easings[name].apply(null, args); + } else { + ani_p.easingImpl = easings[name]; + } + } + } + var easing = ani_p.easingImpl; + var percent; + if (ani_p.duration === 0) { + percent = 1; + } else { + percent = (now3 - startTime) / ani_p.duration; + } + if (ani_p.applying) { + percent = ani_p.progress; + } + if (percent < 0) { + percent = 0; + } else if (percent > 1) { + percent = 1; + } + if (ani_p.delay == null) { + var startPos = ani_p.startPosition; + var endPos = ani_p.position; + if (endPos && isEles && !self2.locked()) { + var newPos = {}; + if (valid(startPos.x, endPos.x)) { + newPos.x = ease(startPos.x, endPos.x, percent, easing); + } + if (valid(startPos.y, endPos.y)) { + newPos.y = ease(startPos.y, endPos.y, percent, easing); + } + self2.position(newPos); + } + var startPan = ani_p.startPan; + var endPan = ani_p.pan; + var pan = _p.pan; + var animatingPan = endPan != null && isCore; + if (animatingPan) { + if (valid(startPan.x, endPan.x)) { + pan.x = ease(startPan.x, endPan.x, percent, easing); + } + if (valid(startPan.y, endPan.y)) { + pan.y = ease(startPan.y, endPan.y, percent, easing); + } + self2.emit("pan"); + } + var startZoom = ani_p.startZoom; + var endZoom = ani_p.zoom; + var animatingZoom = endZoom != null && isCore; + if (animatingZoom) { + if (valid(startZoom, endZoom)) { + _p.zoom = bound(_p.minZoom, ease(startZoom, endZoom, percent, easing), _p.maxZoom); + } + self2.emit("zoom"); + } + if (animatingPan || animatingZoom) { + self2.emit("viewport"); + } + var props = ani_p.style; + if (props && props.length > 0 && isEles) { + for (var i3 = 0; i3 < props.length; i3++) { + var prop = props[i3]; + var _name = prop.name; + var end2 = prop; + var start2 = ani_p.startStyle[_name]; + var propSpec = style.properties[start2.name]; + var easedVal = ease(start2, end2, percent, easing, propSpec); + style.overrideBypass(self2, _name, easedVal); + } + self2.emit("style"); + } + } + ani_p.progress = percent; + return percent; + } + function valid(start2, end2) { + if (start2 == null || end2 == null) { + return false; + } + if (number$12(start2) && number$12(end2)) { + return true; + } else if (start2 && end2) { + return true; + } + return false; + } + function startAnimation(self2, ani, now3, isCore) { + var ani_p = ani._private; + ani_p.started = true; + ani_p.startTime = now3 - ani_p.progress * ani_p.duration; + } + function stepAll(now3, cy) { + var eles = cy._private.aniEles; + var doneEles = []; + function stepOne(ele2, isCore) { + var _p = ele2._private; + var current = _p.animation.current; + var queue = _p.animation.queue; + var ranAnis = false; + if (current.length === 0) { + var next2 = queue.shift(); + if (next2) { + current.push(next2); + } + } + var callbacks = function callbacks2(_callbacks) { + for (var j = _callbacks.length - 1; j >= 0; j--) { + var cb = _callbacks[j]; + cb(); + } + _callbacks.splice(0, _callbacks.length); + }; + for (var i3 = current.length - 1; i3 >= 0; i3--) { + var ani = current[i3]; + var ani_p = ani._private; + if (ani_p.stopped) { + current.splice(i3, 1); + ani_p.hooked = false; + ani_p.playing = false; + ani_p.started = false; + callbacks(ani_p.frames); + continue; + } + if (!ani_p.playing && !ani_p.applying) { + continue; + } + if (ani_p.playing && ani_p.applying) { + ani_p.applying = false; + } + if (!ani_p.started) { + startAnimation(ele2, ani, now3); + } + step$1(ele2, ani, now3, isCore); + if (ani_p.applying) { + ani_p.applying = false; + } + callbacks(ani_p.frames); + if (ani_p.step != null) { + ani_p.step(now3); + } + if (ani.completed()) { + current.splice(i3, 1); + ani_p.hooked = false; + ani_p.playing = false; + ani_p.started = false; + callbacks(ani_p.completes); + } + ranAnis = true; + } + if (!isCore && current.length === 0 && queue.length === 0) { + doneEles.push(ele2); + } + return ranAnis; + } + var ranEleAni = false; + for (var e = 0; e < eles.length; e++) { + var ele = eles[e]; + var handledThisEle = stepOne(ele); + ranEleAni = ranEleAni || handledThisEle; + } + var ranCoreAni = stepOne(cy, true); + if (ranEleAni || ranCoreAni) { + if (eles.length > 0) { + cy.notify("draw", eles); + } else { + cy.notify("draw"); + } + } + eles.unmerge(doneEles); + cy.emit("step"); + } + var corefn$8 = { + // pull in animation functions + animate: define3.animate(), + animation: define3.animation(), + animated: define3.animated(), + clearQueue: define3.clearQueue(), + delay: define3.delay(), + delayAnimation: define3.delayAnimation(), + stop: define3.stop(), + addToAnimationPool: function addToAnimationPool(eles) { + var cy = this; + if (!cy.styleEnabled()) { + return; + } + cy._private.aniEles.merge(eles); + }, + stopAnimationLoop: function stopAnimationLoop() { + this._private.animationsRunning = false; + }, + startAnimationLoop: function startAnimationLoop() { + var cy = this; + cy._private.animationsRunning = true; + if (!cy.styleEnabled()) { + return; + } + function headlessStep() { + if (!cy._private.animationsRunning) { + return; + } + requestAnimationFrame2(function animationStep(now3) { + stepAll(now3, cy); + headlessStep(); + }); + } + var renderer3 = cy.renderer(); + if (renderer3 && renderer3.beforeRender) { + renderer3.beforeRender(function rendererAnimationStep(willDraw, now3) { + stepAll(now3, cy); + }, renderer3.beforeRenderPriorities.animations); + } else { + headlessStep(); + } + } + }; + var emitterOptions = { + qualifierCompare: function qualifierCompare(selector1, selector2) { + if (selector1 == null || selector2 == null) { + return selector1 == null && selector2 == null; + } else { + return selector1.sameText(selector2); + } + }, + eventMatches: function eventMatches(cy, listener, eventObj) { + var selector2 = listener.qualifier; + if (selector2 != null) { + return cy !== eventObj.target && element2(eventObj.target) && selector2.matches(eventObj.target); + } + return true; + }, + addEventFields: function addEventFields(cy, evt) { + evt.cy = cy; + evt.target = cy; + }, + callbackContext: function callbackContext(cy, listener, eventObj) { + return listener.qualifier != null ? eventObj.target : cy; + } + }; + var argSelector = function argSelector2(arg) { + if (string2(arg)) { + return new Selector(arg); + } else { + return arg; + } + }; + var elesfn = { + createEmitter: function createEmitter() { + var _p = this._private; + if (!_p.emitter) { + _p.emitter = new Emitter(emitterOptions, this); + } + return this; + }, + emitter: function emitter() { + return this._private.emitter; + }, + on: function on(events, selector2, callback) { + this.emitter().on(events, argSelector(selector2), callback); + return this; + }, + removeListener: function removeListener(events, selector2, callback) { + this.emitter().removeListener(events, argSelector(selector2), callback); + return this; + }, + removeAllListeners: function removeAllListeners() { + this.emitter().removeAllListeners(); + return this; + }, + one: function one2(events, selector2, callback) { + this.emitter().one(events, argSelector(selector2), callback); + return this; + }, + once: function once(events, selector2, callback) { + this.emitter().one(events, argSelector(selector2), callback); + return this; + }, + emit: function emit(events, extraParams) { + this.emitter().emit(events, extraParams); + return this; + }, + emitAndNotify: function emitAndNotify(event2, eles) { + this.emit(event2); + this.notify(event2, eles); + return this; + } + }; + define3.eventAliasesOn(elesfn); + var corefn$7 = { + png: function png(options2) { + var renderer3 = this._private.renderer; + options2 = options2 || {}; + return renderer3.png(options2); + }, + jpg: function jpg(options2) { + var renderer3 = this._private.renderer; + options2 = options2 || {}; + options2.bg = options2.bg || "#fff"; + return renderer3.jpg(options2); + } + }; + corefn$7.jpeg = corefn$7.jpg; + var corefn$6 = { + layout: function layout3(options2) { + var cy = this; + if (options2 == null) { + error("Layout options must be specified to make a layout"); + return; + } + if (options2.name == null) { + error("A `name` must be specified to make a layout"); + return; + } + var name = options2.name; + var Layout2 = cy.extension("layout", name); + if (Layout2 == null) { + error("No such layout `" + name + "` found. Did you forget to import it and `cytoscape.use()` it?"); + return; + } + var eles; + if (string2(options2.eles)) { + eles = cy.$(options2.eles); + } else { + eles = options2.eles != null ? options2.eles : cy.$(); + } + var layout4 = new Layout2(extend2({}, options2, { + cy, + eles + })); + return layout4; + } + }; + corefn$6.createLayout = corefn$6.makeLayout = corefn$6.layout; + var corefn$5 = { + notify: function notify(eventName, eventEles) { + var _p = this._private; + if (this.batching()) { + _p.batchNotifications = _p.batchNotifications || {}; + var eles = _p.batchNotifications[eventName] = _p.batchNotifications[eventName] || this.collection(); + if (eventEles != null) { + eles.merge(eventEles); + } + return; + } + if (!_p.notificationsEnabled) { + return; + } + var renderer3 = this.renderer(); + if (this.destroyed() || !renderer3) { + return; + } + renderer3.notify(eventName, eventEles); + }, + notifications: function notifications(bool2) { + var p2 = this._private; + if (bool2 === void 0) { + return p2.notificationsEnabled; + } else { + p2.notificationsEnabled = bool2 ? true : false; + } + return this; + }, + noNotifications: function noNotifications(callback) { + this.notifications(false); + callback(); + this.notifications(true); + }, + batching: function batching() { + return this._private.batchCount > 0; + }, + startBatch: function startBatch() { + var _p = this._private; + if (_p.batchCount == null) { + _p.batchCount = 0; + } + if (_p.batchCount === 0) { + _p.batchStyleEles = this.collection(); + _p.batchNotifications = {}; + } + _p.batchCount++; + return this; + }, + endBatch: function endBatch() { + var _p = this._private; + if (_p.batchCount === 0) { + return this; + } + _p.batchCount--; + if (_p.batchCount === 0) { + _p.batchStyleEles.updateStyle(); + var renderer3 = this.renderer(); + Object.keys(_p.batchNotifications).forEach(function(eventName) { + var eles = _p.batchNotifications[eventName]; + if (eles.empty()) { + renderer3.notify(eventName); + } else { + renderer3.notify(eventName, eles); + } + }); + } + return this; + }, + batch: function batch(callback) { + this.startBatch(); + callback(); + this.endBatch(); + return this; + }, + // for backwards compatibility + batchData: function batchData(map2) { + var cy = this; + return this.batch(function() { + var ids = Object.keys(map2); + for (var i3 = 0; i3 < ids.length; i3++) { + var id2 = ids[i3]; + var data2 = map2[id2]; + var ele = cy.getElementById(id2); + ele.data(data2); + } + }); + } + }; + var rendererDefaults = defaults$g({ + hideEdgesOnViewport: false, + textureOnViewport: false, + motionBlur: false, + motionBlurOpacity: 0.05, + pixelRatio: void 0, + desktopTapThreshold: 4, + touchTapThreshold: 8, + wheelSensitivity: 1, + debug: false, + showFps: false + }); + var corefn$4 = { + renderTo: function renderTo(context, zoom, pan, pxRatio) { + var r = this._private.renderer; + r.renderTo(context, zoom, pan, pxRatio); + return this; + }, + renderer: function renderer3() { + return this._private.renderer; + }, + forceRender: function forceRender() { + this.notify("draw"); + return this; + }, + resize: function resize() { + this.invalidateSize(); + this.emitAndNotify("resize"); + return this; + }, + initRenderer: function initRenderer(options2) { + var cy = this; + var RendererProto = cy.extension("renderer", options2.name); + if (RendererProto == null) { + error("Can not initialise: No such renderer `".concat(options2.name, "` found. Did you forget to import it and `cytoscape.use()` it?")); + return; + } + if (options2.wheelSensitivity !== void 0) { + warn("You have set a custom wheel sensitivity. This will make your app zoom unnaturally when using mainstream mice. You should change this value from the default only if you can guarantee that all your users will use the same hardware and OS configuration as your current machine."); + } + var rOpts = rendererDefaults(options2); + rOpts.cy = cy; + cy._private.renderer = new RendererProto(rOpts); + this.notify("init"); + }, + destroyRenderer: function destroyRenderer() { + var cy = this; + cy.notify("destroy"); + var domEle = cy.container(); + if (domEle) { + domEle._cyreg = null; + while (domEle.childNodes.length > 0) { + domEle.removeChild(domEle.childNodes[0]); + } + } + cy._private.renderer = null; + cy.mutableElements().forEach(function(ele) { + var _p = ele._private; + _p.rscratch = {}; + _p.rstyle = {}; + _p.animation.current = []; + _p.animation.queue = []; + }); + }, + onRender: function onRender(fn2) { + return this.on("render", fn2); + }, + offRender: function offRender(fn2) { + return this.off("render", fn2); + } + }; + corefn$4.invalidateDimensions = corefn$4.resize; + var corefn$3 = { + // get a collection + // - empty collection on no args + // - collection of elements in the graph on selector arg + // - guarantee a returned collection when elements or collection specified + collection: function collection2(eles, opts) { + if (string2(eles)) { + return this.$(eles); + } else if (elementOrCollection(eles)) { + return eles.collection(); + } else if (array2(eles)) { + if (!opts) { + opts = {}; + } + return new Collection(this, eles, opts.unique, opts.removed); + } + return new Collection(this); + }, + nodes: function nodes2(selector2) { + var nodes3 = this.$(function(ele) { + return ele.isNode(); + }); + if (selector2) { + return nodes3.filter(selector2); + } + return nodes3; + }, + edges: function edges2(selector2) { + var edges3 = this.$(function(ele) { + return ele.isEdge(); + }); + if (selector2) { + return edges3.filter(selector2); + } + return edges3; + }, + // search the graph like jQuery + $: function $(selector2) { + var eles = this._private.elements; + if (selector2) { + return eles.filter(selector2); + } else { + return eles.spawnSelf(); + } + }, + mutableElements: function mutableElements() { + return this._private.elements; + } + }; + corefn$3.elements = corefn$3.filter = corefn$3.$; + var styfn$8 = {}; + var TRUE = "t"; + var FALSE = "f"; + styfn$8.apply = function(eles) { + var self2 = this; + var _p = self2._private; + var cy = _p.cy; + var updatedEles = cy.collection(); + for (var ie = 0; ie < eles.length; ie++) { + var ele = eles[ie]; + var cxtMeta = self2.getContextMeta(ele); + if (cxtMeta.empty) { + continue; + } + var cxtStyle = self2.getContextStyle(cxtMeta); + var app = self2.applyContextStyle(cxtMeta, cxtStyle, ele); + if (ele._private.appliedInitStyle) { + self2.updateTransitions(ele, app.diffProps); + } else { + ele._private.appliedInitStyle = true; + } + var hintsDiff = self2.updateStyleHints(ele); + if (hintsDiff) { + updatedEles.push(ele); + } + } + return updatedEles; + }; + styfn$8.getPropertiesDiff = function(oldCxtKey, newCxtKey) { + var self2 = this; + var cache2 = self2._private.propDiffs = self2._private.propDiffs || {}; + var dualCxtKey = oldCxtKey + "-" + newCxtKey; + var cachedVal = cache2[dualCxtKey]; + if (cachedVal) { + return cachedVal; + } + var diffProps = []; + var addedProp = {}; + for (var i3 = 0; i3 < self2.length; i3++) { + var cxt = self2[i3]; + var oldHasCxt = oldCxtKey[i3] === TRUE; + var newHasCxt = newCxtKey[i3] === TRUE; + var cxtHasDiffed = oldHasCxt !== newHasCxt; + var cxtHasMappedProps = cxt.mappedProperties.length > 0; + if (cxtHasDiffed || newHasCxt && cxtHasMappedProps) { + var props = void 0; + if (cxtHasDiffed && cxtHasMappedProps) { + props = cxt.properties; + } else if (cxtHasDiffed) { + props = cxt.properties; + } else if (cxtHasMappedProps) { + props = cxt.mappedProperties; + } + for (var j = 0; j < props.length; j++) { + var prop = props[j]; + var name = prop.name; + var laterCxtOverrides = false; + for (var k = i3 + 1; k < self2.length; k++) { + var laterCxt = self2[k]; + var hasLaterCxt = newCxtKey[k] === TRUE; + if (!hasLaterCxt) { + continue; + } + laterCxtOverrides = laterCxt.properties[prop.name] != null; + if (laterCxtOverrides) { + break; + } + } + if (!addedProp[name] && !laterCxtOverrides) { + addedProp[name] = true; + diffProps.push(name); + } + } + } + } + cache2[dualCxtKey] = diffProps; + return diffProps; + }; + styfn$8.getContextMeta = function(ele) { + var self2 = this; + var cxtKey = ""; + var diffProps; + var prevKey = ele._private.styleCxtKey || ""; + for (var i3 = 0; i3 < self2.length; i3++) { + var context = self2[i3]; + var contextSelectorMatches = context.selector && context.selector.matches(ele); + if (contextSelectorMatches) { + cxtKey += TRUE; + } else { + cxtKey += FALSE; + } + } + diffProps = self2.getPropertiesDiff(prevKey, cxtKey); + ele._private.styleCxtKey = cxtKey; + return { + key: cxtKey, + diffPropNames: diffProps, + empty: diffProps.length === 0 + }; + }; + styfn$8.getContextStyle = function(cxtMeta) { + var cxtKey = cxtMeta.key; + var self2 = this; + var cxtStyles = this._private.contextStyles = this._private.contextStyles || {}; + if (cxtStyles[cxtKey]) { + return cxtStyles[cxtKey]; + } + var style = { + _private: { + key: cxtKey + } + }; + for (var i3 = 0; i3 < self2.length; i3++) { + var cxt = self2[i3]; + var hasCxt = cxtKey[i3] === TRUE; + if (!hasCxt) { + continue; + } + for (var j = 0; j < cxt.properties.length; j++) { + var prop = cxt.properties[j]; + style[prop.name] = prop; + } + } + cxtStyles[cxtKey] = style; + return style; + }; + styfn$8.applyContextStyle = function(cxtMeta, cxtStyle, ele) { + var self2 = this; + var diffProps = cxtMeta.diffPropNames; + var retDiffProps = {}; + var types = self2.types; + for (var i3 = 0; i3 < diffProps.length; i3++) { + var diffPropName = diffProps[i3]; + var cxtProp = cxtStyle[diffPropName]; + var eleProp = ele.pstyle(diffPropName); + if (!cxtProp) { + if (!eleProp) { + continue; + } else if (eleProp.bypass) { + cxtProp = { + name: diffPropName, + deleteBypassed: true + }; + } else { + cxtProp = { + name: diffPropName, + "delete": true + }; + } + } + if (eleProp === cxtProp) { + continue; + } + if (cxtProp.mapped === types.fn && eleProp != null && eleProp.mapping != null && eleProp.mapping.value === cxtProp.value) { + var mapping = eleProp.mapping; + var fnValue = mapping.fnValue = cxtProp.value(ele); + if (fnValue === mapping.prevFnValue) { + continue; + } + } + var retDiffProp = retDiffProps[diffPropName] = { + prev: eleProp + }; + self2.applyParsedProperty(ele, cxtProp); + retDiffProp.next = ele.pstyle(diffPropName); + if (retDiffProp.next && retDiffProp.next.bypass) { + retDiffProp.next = retDiffProp.next.bypassed; + } + } + return { + diffProps: retDiffProps + }; + }; + styfn$8.updateStyleHints = function(ele) { + var _p = ele._private; + var self2 = this; + var propNames = self2.propertyGroupNames; + var propGrKeys = self2.propertyGroupKeys; + var propHash = function propHash2(ele2, propNames2, seedKey) { + return self2.getPropertiesHash(ele2, propNames2, seedKey); + }; + var oldStyleKey = _p.styleKey; + if (ele.removed()) { + return false; + } + var isNode = _p.group === "nodes"; + var overriddenStyles = ele._private.style; + propNames = Object.keys(overriddenStyles); + for (var i3 = 0; i3 < propGrKeys.length; i3++) { + var grKey = propGrKeys[i3]; + _p.styleKeys[grKey] = [DEFAULT_HASH_SEED, DEFAULT_HASH_SEED_ALT]; + } + var updateGrKey1 = function updateGrKey12(val, grKey2) { + return _p.styleKeys[grKey2][0] = hashInt(val, _p.styleKeys[grKey2][0]); + }; + var updateGrKey2 = function updateGrKey22(val, grKey2) { + return _p.styleKeys[grKey2][1] = hashIntAlt(val, _p.styleKeys[grKey2][1]); + }; + var updateGrKey = function updateGrKey3(val, grKey2) { + updateGrKey1(val, grKey2); + updateGrKey2(val, grKey2); + }; + var updateGrKeyWStr = function updateGrKeyWStr2(strVal, grKey2) { + for (var j = 0; j < strVal.length; j++) { + var ch2 = strVal.charCodeAt(j); + updateGrKey1(ch2, grKey2); + updateGrKey2(ch2, grKey2); + } + }; + var N = 2e9; + var cleanNum = function cleanNum2(val) { + return -128 < val && val < 128 && Math.floor(val) !== val ? N - (val * 1024 | 0) : val; + }; + for (var _i6 = 0; _i6 < propNames.length; _i6++) { + var name = propNames[_i6]; + var parsedProp = overriddenStyles[name]; + if (parsedProp == null) { + continue; + } + var propInfo = this.properties[name]; + var type2 = propInfo.type; + var _grKey = propInfo.groupKey; + var normalizedNumberVal = void 0; + if (propInfo.hashOverride != null) { + normalizedNumberVal = propInfo.hashOverride(ele, parsedProp); + } else if (parsedProp.pfValue != null) { + normalizedNumberVal = parsedProp.pfValue; + } + var numberVal = propInfo.enums == null ? parsedProp.value : null; + var haveNormNum = normalizedNumberVal != null; + var haveUnitedNum = numberVal != null; + var haveNum = haveNormNum || haveUnitedNum; + var units = parsedProp.units; + if (type2.number && haveNum && !type2.multiple) { + var v = haveNormNum ? normalizedNumberVal : numberVal; + updateGrKey(cleanNum(v), _grKey); + if (!haveNormNum && units != null) { + updateGrKeyWStr(units, _grKey); + } + } else { + updateGrKeyWStr(parsedProp.strValue, _grKey); + } + } + var hash = [DEFAULT_HASH_SEED, DEFAULT_HASH_SEED_ALT]; + for (var _i22 = 0; _i22 < propGrKeys.length; _i22++) { + var _grKey2 = propGrKeys[_i22]; + var grHash = _p.styleKeys[_grKey2]; + hash[0] = hashInt(grHash[0], hash[0]); + hash[1] = hashIntAlt(grHash[1], hash[1]); + } + _p.styleKey = combineHashes(hash[0], hash[1]); + var sk = _p.styleKeys; + _p.labelDimsKey = combineHashesArray(sk.labelDimensions); + var labelKeys = propHash(ele, ["label"], sk.labelDimensions); + _p.labelKey = combineHashesArray(labelKeys); + _p.labelStyleKey = combineHashesArray(hashArrays(sk.commonLabel, labelKeys)); + if (!isNode) { + var sourceLabelKeys = propHash(ele, ["source-label"], sk.labelDimensions); + _p.sourceLabelKey = combineHashesArray(sourceLabelKeys); + _p.sourceLabelStyleKey = combineHashesArray(hashArrays(sk.commonLabel, sourceLabelKeys)); + var targetLabelKeys = propHash(ele, ["target-label"], sk.labelDimensions); + _p.targetLabelKey = combineHashesArray(targetLabelKeys); + _p.targetLabelStyleKey = combineHashesArray(hashArrays(sk.commonLabel, targetLabelKeys)); + } + if (isNode) { + var _p$styleKeys = _p.styleKeys, nodeBody = _p$styleKeys.nodeBody, nodeBorder = _p$styleKeys.nodeBorder, nodeOutline = _p$styleKeys.nodeOutline, backgroundImage = _p$styleKeys.backgroundImage, compound = _p$styleKeys.compound, pie2 = _p$styleKeys.pie; + var nodeKeys = [nodeBody, nodeBorder, nodeOutline, backgroundImage, compound, pie2].filter(function(k) { + return k != null; + }).reduce(hashArrays, [DEFAULT_HASH_SEED, DEFAULT_HASH_SEED_ALT]); + _p.nodeKey = combineHashesArray(nodeKeys); + _p.hasPie = pie2 != null && pie2[0] !== DEFAULT_HASH_SEED && pie2[1] !== DEFAULT_HASH_SEED_ALT; + } + return oldStyleKey !== _p.styleKey; + }; + styfn$8.clearStyleHints = function(ele) { + var _p = ele._private; + _p.styleCxtKey = ""; + _p.styleKeys = {}; + _p.styleKey = null; + _p.labelKey = null; + _p.labelStyleKey = null; + _p.sourceLabelKey = null; + _p.sourceLabelStyleKey = null; + _p.targetLabelKey = null; + _p.targetLabelStyleKey = null; + _p.nodeKey = null; + _p.hasPie = null; + }; + styfn$8.applyParsedProperty = function(ele, parsedProp) { + var self2 = this; + var prop = parsedProp; + var style = ele._private.style; + var flatProp; + var types = self2.types; + var type2 = self2.properties[prop.name].type; + var propIsBypass = prop.bypass; + var origProp = style[prop.name]; + var origPropIsBypass = origProp && origProp.bypass; + var _p = ele._private; + var flatPropMapping = "mapping"; + var getVal = function getVal2(p2) { + if (p2 == null) { + return null; + } else if (p2.pfValue != null) { + return p2.pfValue; + } else { + return p2.value; + } + }; + var checkTriggers = function checkTriggers2() { + var fromVal = getVal(origProp); + var toVal = getVal(prop); + self2.checkTriggers(ele, prop.name, fromVal, toVal); + }; + if (parsedProp.name === "curve-style" && ele.isEdge() && // loops must be bundled beziers + (parsedProp.value !== "bezier" && ele.isLoop() || // edges connected to compound nodes can not be haystacks + parsedProp.value === "haystack" && (ele.source().isParent() || ele.target().isParent()))) { + prop = parsedProp = this.parse(parsedProp.name, "bezier", propIsBypass); + } + if (prop["delete"]) { + style[prop.name] = void 0; + checkTriggers(); + return true; + } + if (prop.deleteBypassed) { + if (!origProp) { + checkTriggers(); + return true; + } else if (origProp.bypass) { + origProp.bypassed = void 0; + checkTriggers(); + return true; + } else { + return false; + } + } + if (prop.deleteBypass) { + if (!origProp) { + checkTriggers(); + return true; + } else if (origProp.bypass) { + style[prop.name] = origProp.bypassed; + checkTriggers(); + return true; + } else { + return false; + } + } + var printMappingErr = function printMappingErr2() { + warn("Do not assign mappings to elements without corresponding data (i.e. ele `" + ele.id() + "` has no mapping for property `" + prop.name + "` with data field `" + prop.field + "`); try a `[" + prop.field + "]` selector to limit scope to elements with `" + prop.field + "` defined"); + }; + switch (prop.mapped) { + case types.mapData: { + var fields = prop.field.split("."); + var fieldVal = _p.data; + for (var i3 = 0; i3 < fields.length && fieldVal; i3++) { + var field = fields[i3]; + fieldVal = fieldVal[field]; + } + if (fieldVal == null) { + printMappingErr(); + return false; + } + var percent; + if (!number$12(fieldVal)) { + warn("Do not use continuous mappers without specifying numeric data (i.e. `" + prop.field + ": " + fieldVal + "` for `" + ele.id() + "` is non-numeric)"); + return false; + } else { + var fieldWidth = prop.fieldMax - prop.fieldMin; + if (fieldWidth === 0) { + percent = 0; + } else { + percent = (fieldVal - prop.fieldMin) / fieldWidth; + } + } + if (percent < 0) { + percent = 0; + } else if (percent > 1) { + percent = 1; + } + if (type2.color) { + var r1 = prop.valueMin[0]; + var r2 = prop.valueMax[0]; + var g1 = prop.valueMin[1]; + var g2 = prop.valueMax[1]; + var b1 = prop.valueMin[2]; + var b2 = prop.valueMax[2]; + var a1 = prop.valueMin[3] == null ? 1 : prop.valueMin[3]; + var a2 = prop.valueMax[3] == null ? 1 : prop.valueMax[3]; + var clr = [Math.round(r1 + (r2 - r1) * percent), Math.round(g1 + (g2 - g1) * percent), Math.round(b1 + (b2 - b1) * percent), Math.round(a1 + (a2 - a1) * percent)]; + flatProp = { + // colours are simple, so just create the flat property instead of expensive string parsing + bypass: prop.bypass, + // we're a bypass if the mapping property is a bypass + name: prop.name, + value: clr, + strValue: "rgb(" + clr[0] + ", " + clr[1] + ", " + clr[2] + ")" + }; + } else if (type2.number) { + var calcValue = prop.valueMin + (prop.valueMax - prop.valueMin) * percent; + flatProp = this.parse(prop.name, calcValue, prop.bypass, flatPropMapping); + } else { + return false; + } + if (!flatProp) { + printMappingErr(); + return false; + } + flatProp.mapping = prop; + prop = flatProp; + break; + } + case types.data: { + var _fields = prop.field.split("."); + var _fieldVal = _p.data; + for (var _i32 = 0; _i32 < _fields.length && _fieldVal; _i32++) { + var _field = _fields[_i32]; + _fieldVal = _fieldVal[_field]; + } + if (_fieldVal != null) { + flatProp = this.parse(prop.name, _fieldVal, prop.bypass, flatPropMapping); + } + if (!flatProp) { + printMappingErr(); + return false; + } + flatProp.mapping = prop; + prop = flatProp; + break; + } + case types.fn: { + var fn2 = prop.value; + var fnRetVal = prop.fnValue != null ? prop.fnValue : fn2(ele); + prop.prevFnValue = fnRetVal; + if (fnRetVal == null) { + warn("Custom function mappers may not return null (i.e. `" + prop.name + "` for ele `" + ele.id() + "` is null)"); + return false; + } + flatProp = this.parse(prop.name, fnRetVal, prop.bypass, flatPropMapping); + if (!flatProp) { + warn("Custom function mappers may not return invalid values for the property type (i.e. `" + prop.name + "` for ele `" + ele.id() + "` is invalid)"); + return false; + } + flatProp.mapping = copy2(prop); + prop = flatProp; + break; + } + case void 0: + break; + default: + return false; + } + if (propIsBypass) { + if (origPropIsBypass) { + prop.bypassed = origProp.bypassed; + } else { + prop.bypassed = origProp; + } + style[prop.name] = prop; + } else { + if (origPropIsBypass) { + origProp.bypassed = prop; + } else { + style[prop.name] = prop; + } + } + checkTriggers(); + return true; + }; + styfn$8.cleanElements = function(eles, keepBypasses) { + for (var i3 = 0; i3 < eles.length; i3++) { + var ele = eles[i3]; + this.clearStyleHints(ele); + ele.dirtyCompoundBoundsCache(); + ele.dirtyBoundingBoxCache(); + if (!keepBypasses) { + ele._private.style = {}; + } else { + var style = ele._private.style; + var propNames = Object.keys(style); + for (var j = 0; j < propNames.length; j++) { + var propName = propNames[j]; + var eleProp = style[propName]; + if (eleProp != null) { + if (eleProp.bypass) { + eleProp.bypassed = null; + } else { + style[propName] = null; + } + } + } + } + } + }; + styfn$8.update = function() { + var cy = this._private.cy; + var eles = cy.mutableElements(); + eles.updateStyle(); + }; + styfn$8.updateTransitions = function(ele, diffProps) { + var self2 = this; + var _p = ele._private; + var props = ele.pstyle("transition-property").value; + var duration = ele.pstyle("transition-duration").pfValue; + var delay = ele.pstyle("transition-delay").pfValue; + if (props.length > 0 && duration > 0) { + var style = {}; + var anyPrev = false; + for (var i3 = 0; i3 < props.length; i3++) { + var prop = props[i3]; + var styProp = ele.pstyle(prop); + var diffProp = diffProps[prop]; + if (!diffProp) { + continue; + } + var prevProp = diffProp.prev; + var fromProp = prevProp; + var toProp = diffProp.next != null ? diffProp.next : styProp; + var diff = false; + var initVal = void 0; + var initDt = 1e-6; + if (!fromProp) { + continue; + } + if (number$12(fromProp.pfValue) && number$12(toProp.pfValue)) { + diff = toProp.pfValue - fromProp.pfValue; + initVal = fromProp.pfValue + initDt * diff; + } else if (number$12(fromProp.value) && number$12(toProp.value)) { + diff = toProp.value - fromProp.value; + initVal = fromProp.value + initDt * diff; + } else if (array2(fromProp.value) && array2(toProp.value)) { + diff = fromProp.value[0] !== toProp.value[0] || fromProp.value[1] !== toProp.value[1] || fromProp.value[2] !== toProp.value[2]; + initVal = fromProp.strValue; + } + if (diff) { + style[prop] = toProp.strValue; + this.applyBypass(ele, prop, initVal); + anyPrev = true; + } + } + if (!anyPrev) { + return; + } + _p.transitioning = true; + new Promise$12(function(resolve2) { + if (delay > 0) { + ele.delayAnimation(delay).play().promise().then(resolve2); + } else { + resolve2(); + } + }).then(function() { + return ele.animation({ + style, + duration, + easing: ele.pstyle("transition-timing-function").value, + queue: false + }).play().promise(); + }).then(function() { + self2.removeBypasses(ele, props); + ele.emitAndNotify("style"); + _p.transitioning = false; + }); + } else if (_p.transitioning) { + this.removeBypasses(ele, props); + ele.emitAndNotify("style"); + _p.transitioning = false; + } + }; + styfn$8.checkTrigger = function(ele, name, fromValue, toValue, getTrigger, onTrigger) { + var prop = this.properties[name]; + var triggerCheck = getTrigger(prop); + if (triggerCheck != null && triggerCheck(fromValue, toValue)) { + onTrigger(prop); + } + }; + styfn$8.checkZOrderTrigger = function(ele, name, fromValue, toValue) { + var _this = this; + this.checkTrigger(ele, name, fromValue, toValue, function(prop) { + return prop.triggersZOrder; + }, function() { + _this._private.cy.notify("zorder", ele); + }); + }; + styfn$8.checkBoundsTrigger = function(ele, name, fromValue, toValue) { + this.checkTrigger(ele, name, fromValue, toValue, function(prop) { + return prop.triggersBounds; + }, function(prop) { + ele.dirtyCompoundBoundsCache(); + ele.dirtyBoundingBoxCache(); + if ( + // only for beziers -- so performance of other edges isn't affected + prop.triggersBoundsOfParallelBeziers && name === "curve-style" && (fromValue === "bezier" || toValue === "bezier") + ) { + ele.parallelEdges().forEach(function(pllEdge) { + if (pllEdge.isBundledBezier()) { + pllEdge.dirtyBoundingBoxCache(); + } + }); + } + if (prop.triggersBoundsOfConnectedEdges && name === "display" && (fromValue === "none" || toValue === "none")) { + ele.connectedEdges().forEach(function(edge) { + edge.dirtyBoundingBoxCache(); + }); + } + }); + }; + styfn$8.checkTriggers = function(ele, name, fromValue, toValue) { + ele.dirtyStyleCache(); + this.checkZOrderTrigger(ele, name, fromValue, toValue); + this.checkBoundsTrigger(ele, name, fromValue, toValue); + }; + var styfn$7 = {}; + styfn$7.applyBypass = function(eles, name, value2, updateTransitions) { + var self2 = this; + var props = []; + var isBypass = true; + if (name === "*" || name === "**") { + if (value2 !== void 0) { + for (var i3 = 0; i3 < self2.properties.length; i3++) { + var prop = self2.properties[i3]; + var _name = prop.name; + var parsedProp = this.parse(_name, value2, true); + if (parsedProp) { + props.push(parsedProp); + } + } + } + } else if (string2(name)) { + var _parsedProp = this.parse(name, value2, true); + if (_parsedProp) { + props.push(_parsedProp); + } + } else if (plainObject(name)) { + var specifiedProps = name; + updateTransitions = value2; + var names = Object.keys(specifiedProps); + for (var _i6 = 0; _i6 < names.length; _i6++) { + var _name2 = names[_i6]; + var _value = specifiedProps[_name2]; + if (_value === void 0) { + _value = specifiedProps[dash2camel(_name2)]; + } + if (_value !== void 0) { + var _parsedProp2 = this.parse(_name2, _value, true); + if (_parsedProp2) { + props.push(_parsedProp2); + } + } + } + } else { + return false; + } + if (props.length === 0) { + return false; + } + var ret = false; + for (var _i22 = 0; _i22 < eles.length; _i22++) { + var ele = eles[_i22]; + var diffProps = {}; + var diffProp = void 0; + for (var j = 0; j < props.length; j++) { + var _prop = props[j]; + if (updateTransitions) { + var prevProp = ele.pstyle(_prop.name); + diffProp = diffProps[_prop.name] = { + prev: prevProp + }; + } + ret = this.applyParsedProperty(ele, copy2(_prop)) || ret; + if (updateTransitions) { + diffProp.next = ele.pstyle(_prop.name); + } + } + if (ret) { + this.updateStyleHints(ele); + } + if (updateTransitions) { + this.updateTransitions(ele, diffProps, isBypass); + } + } + return ret; + }; + styfn$7.overrideBypass = function(eles, name, value2) { + name = camel2dash(name); + for (var i3 = 0; i3 < eles.length; i3++) { + var ele = eles[i3]; + var prop = ele._private.style[name]; + var type2 = this.properties[name].type; + var isColor = type2.color; + var isMulti = type2.mutiple; + var oldValue = !prop ? null : prop.pfValue != null ? prop.pfValue : prop.value; + if (!prop || !prop.bypass) { + this.applyBypass(ele, name, value2); + } else { + prop.value = value2; + if (prop.pfValue != null) { + prop.pfValue = value2; + } + if (isColor) { + prop.strValue = "rgb(" + value2.join(",") + ")"; + } else if (isMulti) { + prop.strValue = value2.join(" "); + } else { + prop.strValue = "" + value2; + } + this.updateStyleHints(ele); + } + this.checkTriggers(ele, name, oldValue, value2); + } + }; + styfn$7.removeAllBypasses = function(eles, updateTransitions) { + return this.removeBypasses(eles, this.propertyNames, updateTransitions); + }; + styfn$7.removeBypasses = function(eles, props, updateTransitions) { + var isBypass = true; + for (var j = 0; j < eles.length; j++) { + var ele = eles[j]; + var diffProps = {}; + for (var i3 = 0; i3 < props.length; i3++) { + var name = props[i3]; + var prop = this.properties[name]; + var prevProp = ele.pstyle(prop.name); + if (!prevProp || !prevProp.bypass) { + continue; + } + var value2 = ""; + var parsedProp = this.parse(name, value2, true); + var diffProp = diffProps[prop.name] = { + prev: prevProp + }; + this.applyParsedProperty(ele, parsedProp); + diffProp.next = ele.pstyle(prop.name); + } + this.updateStyleHints(ele); + if (updateTransitions) { + this.updateTransitions(ele, diffProps, isBypass); + } + } + }; + var styfn$6 = {}; + styfn$6.getEmSizeInPixels = function() { + var px = this.containerCss("font-size"); + if (px != null) { + return parseFloat(px); + } else { + return 1; + } + }; + styfn$6.containerCss = function(propName) { + var cy = this._private.cy; + var domElement2 = cy.container(); + var containerWindow = cy.window(); + if (containerWindow && domElement2 && containerWindow.getComputedStyle) { + return containerWindow.getComputedStyle(domElement2).getPropertyValue(propName); + } + }; + var styfn$5 = {}; + styfn$5.getRenderedStyle = function(ele, prop) { + if (prop) { + return this.getStylePropertyValue(ele, prop, true); + } else { + return this.getRawStyle(ele, true); + } + }; + styfn$5.getRawStyle = function(ele, isRenderedVal) { + var self2 = this; + ele = ele[0]; + if (ele) { + var rstyle = {}; + for (var i3 = 0; i3 < self2.properties.length; i3++) { + var prop = self2.properties[i3]; + var val = self2.getStylePropertyValue(ele, prop.name, isRenderedVal); + if (val != null) { + rstyle[prop.name] = val; + rstyle[dash2camel(prop.name)] = val; + } + } + return rstyle; + } + }; + styfn$5.getIndexedStyle = function(ele, property2, subproperty, index2) { + var pstyle = ele.pstyle(property2)[subproperty][index2]; + return pstyle != null ? pstyle : ele.cy().style().getDefaultProperty(property2)[subproperty][0]; + }; + styfn$5.getStylePropertyValue = function(ele, propName, isRenderedVal) { + var self2 = this; + ele = ele[0]; + if (ele) { + var prop = self2.properties[propName]; + if (prop.alias) { + prop = prop.pointsTo; + } + var type2 = prop.type; + var styleProp = ele.pstyle(prop.name); + if (styleProp) { + var value2 = styleProp.value, units = styleProp.units, strValue = styleProp.strValue; + if (isRenderedVal && type2.number && value2 != null && number$12(value2)) { + var zoom = ele.cy().zoom(); + var getRenderedValue = function getRenderedValue2(val) { + return val * zoom; + }; + var getValueStringWithUnits = function getValueStringWithUnits2(val, units2) { + return getRenderedValue(val) + units2; + }; + var isArrayValue = array2(value2); + var haveUnits = isArrayValue ? units.every(function(u) { + return u != null; + }) : units != null; + if (haveUnits) { + if (isArrayValue) { + return value2.map(function(v, i3) { + return getValueStringWithUnits(v, units[i3]); + }).join(" "); + } else { + return getValueStringWithUnits(value2, units); + } + } else { + if (isArrayValue) { + return value2.map(function(v) { + return string2(v) ? v : "" + getRenderedValue(v); + }).join(" "); + } else { + return "" + getRenderedValue(value2); + } + } + } else if (strValue != null) { + return strValue; + } + } + return null; + } + }; + styfn$5.getAnimationStartStyle = function(ele, aniProps) { + var rstyle = {}; + for (var i3 = 0; i3 < aniProps.length; i3++) { + var aniProp = aniProps[i3]; + var name = aniProp.name; + var styleProp = ele.pstyle(name); + if (styleProp !== void 0) { + if (plainObject(styleProp)) { + styleProp = this.parse(name, styleProp.strValue); + } else { + styleProp = this.parse(name, styleProp); + } + } + if (styleProp) { + rstyle[name] = styleProp; + } + } + return rstyle; + }; + styfn$5.getPropsList = function(propsObj) { + var self2 = this; + var rstyle = []; + var style = propsObj; + var props = self2.properties; + if (style) { + var names = Object.keys(style); + for (var i3 = 0; i3 < names.length; i3++) { + var name = names[i3]; + var val = style[name]; + var prop = props[name] || props[camel2dash(name)]; + var styleProp = this.parse(prop.name, val); + if (styleProp) { + rstyle.push(styleProp); + } + } + } + return rstyle; + }; + styfn$5.getNonDefaultPropertiesHash = function(ele, propNames, seed) { + var hash = seed.slice(); + var name, val, strVal, chVal; + var i3, j; + for (i3 = 0; i3 < propNames.length; i3++) { + name = propNames[i3]; + val = ele.pstyle(name, false); + if (val == null) { + continue; + } else if (val.pfValue != null) { + hash[0] = hashInt(chVal, hash[0]); + hash[1] = hashIntAlt(chVal, hash[1]); + } else { + strVal = val.strValue; + for (j = 0; j < strVal.length; j++) { + chVal = strVal.charCodeAt(j); + hash[0] = hashInt(chVal, hash[0]); + hash[1] = hashIntAlt(chVal, hash[1]); + } + } + } + return hash; + }; + styfn$5.getPropertiesHash = styfn$5.getNonDefaultPropertiesHash; + var styfn$4 = {}; + styfn$4.appendFromJson = function(json2) { + var style = this; + for (var i3 = 0; i3 < json2.length; i3++) { + var context = json2[i3]; + var selector2 = context.selector; + var props = context.style || context.css; + var names = Object.keys(props); + style.selector(selector2); + for (var j = 0; j < names.length; j++) { + var name = names[j]; + var value2 = props[name]; + style.css(name, value2); + } + } + return style; + }; + styfn$4.fromJson = function(json2) { + var style = this; + style.resetToDefault(); + style.appendFromJson(json2); + return style; + }; + styfn$4.json = function() { + var json2 = []; + for (var i3 = this.defaultLength; i3 < this.length; i3++) { + var cxt = this[i3]; + var selector2 = cxt.selector; + var props = cxt.properties; + var css = {}; + for (var j = 0; j < props.length; j++) { + var prop = props[j]; + css[prop.name] = prop.strValue; + } + json2.push({ + selector: !selector2 ? "core" : selector2.toString(), + style: css + }); + } + return json2; + }; + var styfn$3 = {}; + styfn$3.appendFromString = function(string3) { + var self2 = this; + var style = this; + var remaining = "" + string3; + var selAndBlockStr; + var blockRem; + var propAndValStr; + remaining = remaining.replace(/[/][*](\s|.)+?[*][/]/g, ""); + function removeSelAndBlockFromRemaining() { + if (remaining.length > selAndBlockStr.length) { + remaining = remaining.substr(selAndBlockStr.length); + } else { + remaining = ""; + } + } + function removePropAndValFromRem() { + if (blockRem.length > propAndValStr.length) { + blockRem = blockRem.substr(propAndValStr.length); + } else { + blockRem = ""; + } + } + for (; ; ) { + var nothingLeftToParse = remaining.match(/^\s*$/); + if (nothingLeftToParse) { + break; + } + var selAndBlock = remaining.match(/^\s*((?:.|\s)+?)\s*\{((?:.|\s)+?)\}/); + if (!selAndBlock) { + warn("Halting stylesheet parsing: String stylesheet contains more to parse but no selector and block found in: " + remaining); + break; + } + selAndBlockStr = selAndBlock[0]; + var selectorStr = selAndBlock[1]; + if (selectorStr !== "core") { + var selector2 = new Selector(selectorStr); + if (selector2.invalid) { + warn("Skipping parsing of block: Invalid selector found in string stylesheet: " + selectorStr); + removeSelAndBlockFromRemaining(); + continue; + } + } + var blockStr = selAndBlock[2]; + var invalidBlock = false; + blockRem = blockStr; + var props = []; + for (; ; ) { + var _nothingLeftToParse = blockRem.match(/^\s*$/); + if (_nothingLeftToParse) { + break; + } + var propAndVal = blockRem.match(/^\s*(.+?)\s*:\s*(.+?)(?:\s*;|\s*$)/); + if (!propAndVal) { + warn("Skipping parsing of block: Invalid formatting of style property and value definitions found in:" + blockStr); + invalidBlock = true; + break; + } + propAndValStr = propAndVal[0]; + var propStr = propAndVal[1]; + var valStr = propAndVal[2]; + var prop = self2.properties[propStr]; + if (!prop) { + warn("Skipping property: Invalid property name in: " + propAndValStr); + removePropAndValFromRem(); + continue; + } + var parsedProp = style.parse(propStr, valStr); + if (!parsedProp) { + warn("Skipping property: Invalid property definition in: " + propAndValStr); + removePropAndValFromRem(); + continue; + } + props.push({ + name: propStr, + val: valStr + }); + removePropAndValFromRem(); + } + if (invalidBlock) { + removeSelAndBlockFromRemaining(); + break; + } + style.selector(selectorStr); + for (var i3 = 0; i3 < props.length; i3++) { + var _prop = props[i3]; + style.css(_prop.name, _prop.val); + } + removeSelAndBlockFromRemaining(); + } + return style; + }; + styfn$3.fromString = function(string3) { + var style = this; + style.resetToDefault(); + style.appendFromString(string3); + return style; + }; + var styfn$2 = {}; + (function() { + var number$13 = number2; + var rgba3 = rgbaNoBackRefs; + var hsla3 = hslaNoBackRefs; + var hex3$1 = hex3; + var hex6$1 = hex6; + var data2 = function data3(prefix) { + return "^" + prefix + "\\s*\\(\\s*([\\w\\.]+)\\s*\\)$"; + }; + var mapData = function mapData2(prefix) { + var mapArg = number$13 + "|\\w+|" + rgba3 + "|" + hsla3 + "|" + hex3$1 + "|" + hex6$1; + return "^" + prefix + "\\s*\\(([\\w\\.]+)\\s*\\,\\s*(" + number$13 + ")\\s*\\,\\s*(" + number$13 + ")\\s*,\\s*(" + mapArg + ")\\s*\\,\\s*(" + mapArg + ")\\)$"; + }; + var urlRegexes = [`^url\\s*\\(\\s*['"]?(.+?)['"]?\\s*\\)$`, "^(none)$", "^(.+)$"]; + styfn$2.types = { + time: { + number: true, + min: 0, + units: "s|ms", + implicitUnits: "ms" + }, + percent: { + number: true, + min: 0, + max: 100, + units: "%", + implicitUnits: "%" + }, + percentages: { + number: true, + min: 0, + max: 100, + units: "%", + implicitUnits: "%", + multiple: true + }, + zeroOneNumber: { + number: true, + min: 0, + max: 1, + unitless: true + }, + zeroOneNumbers: { + number: true, + min: 0, + max: 1, + unitless: true, + multiple: true + }, + nOneOneNumber: { + number: true, + min: -1, + max: 1, + unitless: true + }, + nonNegativeInt: { + number: true, + min: 0, + integer: true, + unitless: true + }, + nonNegativeNumber: { + number: true, + min: 0, + unitless: true + }, + position: { + enums: ["parent", "origin"] + }, + nodeSize: { + number: true, + min: 0, + enums: ["label"] + }, + number: { + number: true, + unitless: true + }, + numbers: { + number: true, + unitless: true, + multiple: true + }, + positiveNumber: { + number: true, + unitless: true, + min: 0, + strictMin: true + }, + size: { + number: true, + min: 0 + }, + bidirectionalSize: { + number: true + }, + // allows negative + bidirectionalSizeMaybePercent: { + number: true, + allowPercent: true + }, + // allows negative + bidirectionalSizes: { + number: true, + multiple: true + }, + // allows negative + sizeMaybePercent: { + number: true, + min: 0, + allowPercent: true + }, + axisDirection: { + enums: ["horizontal", "leftward", "rightward", "vertical", "upward", "downward", "auto"] + }, + paddingRelativeTo: { + enums: ["width", "height", "average", "min", "max"] + }, + bgWH: { + number: true, + min: 0, + allowPercent: true, + enums: ["auto"], + multiple: true + }, + bgPos: { + number: true, + allowPercent: true, + multiple: true + }, + bgRelativeTo: { + enums: ["inner", "include-padding"], + multiple: true + }, + bgRepeat: { + enums: ["repeat", "repeat-x", "repeat-y", "no-repeat"], + multiple: true + }, + bgFit: { + enums: ["none", "contain", "cover"], + multiple: true + }, + bgCrossOrigin: { + enums: ["anonymous", "use-credentials", "null"], + multiple: true + }, + bgClip: { + enums: ["none", "node"], + multiple: true + }, + bgContainment: { + enums: ["inside", "over"], + multiple: true + }, + color: { + color: true + }, + colors: { + color: true, + multiple: true + }, + fill: { + enums: ["solid", "linear-gradient", "radial-gradient"] + }, + bool: { + enums: ["yes", "no"] + }, + bools: { + enums: ["yes", "no"], + multiple: true + }, + lineStyle: { + enums: ["solid", "dotted", "dashed"] + }, + lineCap: { + enums: ["butt", "round", "square"] + }, + borderStyle: { + enums: ["solid", "dotted", "dashed", "double"] + }, + curveStyle: { + enums: ["bezier", "unbundled-bezier", "haystack", "segments", "straight", "straight-triangle", "taxi"] + }, + fontFamily: { + regex: '^([\\w- \\"]+(?:\\s*,\\s*[\\w- \\"]+)*)$' + }, + fontStyle: { + enums: ["italic", "normal", "oblique"] + }, + fontWeight: { + enums: ["normal", "bold", "bolder", "lighter", "100", "200", "300", "400", "500", "600", "800", "900", 100, 200, 300, 400, 500, 600, 700, 800, 900] + }, + textDecoration: { + enums: ["none", "underline", "overline", "line-through"] + }, + textTransform: { + enums: ["none", "uppercase", "lowercase"] + }, + textWrap: { + enums: ["none", "wrap", "ellipsis"] + }, + textOverflowWrap: { + enums: ["whitespace", "anywhere"] + }, + textBackgroundShape: { + enums: ["rectangle", "roundrectangle", "round-rectangle"] + }, + nodeShape: { + enums: ["rectangle", "roundrectangle", "round-rectangle", "cutrectangle", "cut-rectangle", "bottomroundrectangle", "bottom-round-rectangle", "barrel", "ellipse", "triangle", "round-triangle", "square", "pentagon", "round-pentagon", "hexagon", "round-hexagon", "concavehexagon", "concave-hexagon", "heptagon", "round-heptagon", "octagon", "round-octagon", "tag", "round-tag", "star", "diamond", "round-diamond", "vee", "rhomboid", "right-rhomboid", "polygon"] + }, + overlayShape: { + enums: ["roundrectangle", "round-rectangle", "ellipse"] + }, + compoundIncludeLabels: { + enums: ["include", "exclude"] + }, + arrowShape: { + enums: ["tee", "triangle", "triangle-tee", "circle-triangle", "triangle-cross", "triangle-backcurve", "vee", "square", "circle", "diamond", "chevron", "none"] + }, + arrowFill: { + enums: ["filled", "hollow"] + }, + arrowWidth: { + number: true, + units: "%|px|em", + implicitUnits: "px", + enums: ["match-line"] + }, + display: { + enums: ["element", "none"] + }, + visibility: { + enums: ["hidden", "visible"] + }, + zCompoundDepth: { + enums: ["bottom", "orphan", "auto", "top"] + }, + zIndexCompare: { + enums: ["auto", "manual"] + }, + valign: { + enums: ["top", "center", "bottom"] + }, + halign: { + enums: ["left", "center", "right"] + }, + justification: { + enums: ["left", "center", "right", "auto"] + }, + text: { + string: true + }, + data: { + mapping: true, + regex: data2("data") + }, + layoutData: { + mapping: true, + regex: data2("layoutData") + }, + scratch: { + mapping: true, + regex: data2("scratch") + }, + mapData: { + mapping: true, + regex: mapData("mapData") + }, + mapLayoutData: { + mapping: true, + regex: mapData("mapLayoutData") + }, + mapScratch: { + mapping: true, + regex: mapData("mapScratch") + }, + fn: { + mapping: true, + fn: true + }, + url: { + regexes: urlRegexes, + singleRegexMatchValue: true + }, + urls: { + regexes: urlRegexes, + singleRegexMatchValue: true, + multiple: true + }, + propList: { + propList: true + }, + angle: { + number: true, + units: "deg|rad", + implicitUnits: "rad" + }, + textRotation: { + number: true, + units: "deg|rad", + implicitUnits: "rad", + enums: ["none", "autorotate"] + }, + polygonPointList: { + number: true, + multiple: true, + evenMultiple: true, + min: -1, + max: 1, + unitless: true + }, + edgeDistances: { + enums: ["intersection", "node-position", "endpoints"] + }, + edgeEndpoint: { + number: true, + multiple: true, + units: "%|px|em|deg|rad", + implicitUnits: "px", + enums: ["inside-to-node", "outside-to-node", "outside-to-node-or-label", "outside-to-line", "outside-to-line-or-label"], + singleEnum: true, + validate: function validate2(valArr, unitsArr) { + switch (valArr.length) { + case 2: + return unitsArr[0] !== "deg" && unitsArr[0] !== "rad" && unitsArr[1] !== "deg" && unitsArr[1] !== "rad"; + case 1: + return string2(valArr[0]) || unitsArr[0] === "deg" || unitsArr[0] === "rad"; + default: + return false; + } + } + }, + easing: { + regexes: ["^(spring)\\s*\\(\\s*(" + number$13 + ")\\s*,\\s*(" + number$13 + ")\\s*\\)$", "^(cubic-bezier)\\s*\\(\\s*(" + number$13 + ")\\s*,\\s*(" + number$13 + ")\\s*,\\s*(" + number$13 + ")\\s*,\\s*(" + number$13 + ")\\s*\\)$"], + enums: ["linear", "ease", "ease-in", "ease-out", "ease-in-out", "ease-in-sine", "ease-out-sine", "ease-in-out-sine", "ease-in-quad", "ease-out-quad", "ease-in-out-quad", "ease-in-cubic", "ease-out-cubic", "ease-in-out-cubic", "ease-in-quart", "ease-out-quart", "ease-in-out-quart", "ease-in-quint", "ease-out-quint", "ease-in-out-quint", "ease-in-expo", "ease-out-expo", "ease-in-out-expo", "ease-in-circ", "ease-out-circ", "ease-in-out-circ"] + }, + gradientDirection: { + enums: [ + "to-bottom", + "to-top", + "to-left", + "to-right", + "to-bottom-right", + "to-bottom-left", + "to-top-right", + "to-top-left", + "to-right-bottom", + "to-left-bottom", + "to-right-top", + "to-left-top" + // different order + ] + }, + boundsExpansion: { + number: true, + multiple: true, + min: 0, + validate: function validate2(valArr) { + var length2 = valArr.length; + return length2 === 1 || length2 === 2 || length2 === 4; + } + } + }; + var diff = { + zeroNonZero: function zeroNonZero(val1, val2) { + if ((val1 == null || val2 == null) && val1 !== val2) { + return true; + } + if (val1 == 0 && val2 != 0) { + return true; + } else if (val1 != 0 && val2 == 0) { + return true; + } else { + return false; + } + }, + any: function any(val1, val2) { + return val1 != val2; + }, + emptyNonEmpty: function emptyNonEmpty(str1, str2) { + var empty1 = emptyString(str1); + var empty2 = emptyString(str2); + return empty1 && !empty2 || !empty1 && empty2; + } + }; + var t = styfn$2.types; + var mainLabel = [{ + name: "label", + type: t.text, + triggersBounds: diff.any, + triggersZOrder: diff.emptyNonEmpty + }, { + name: "text-rotation", + type: t.textRotation, + triggersBounds: diff.any + }, { + name: "text-margin-x", + type: t.bidirectionalSize, + triggersBounds: diff.any + }, { + name: "text-margin-y", + type: t.bidirectionalSize, + triggersBounds: diff.any + }]; + var sourceLabel = [{ + name: "source-label", + type: t.text, + triggersBounds: diff.any + }, { + name: "source-text-rotation", + type: t.textRotation, + triggersBounds: diff.any + }, { + name: "source-text-margin-x", + type: t.bidirectionalSize, + triggersBounds: diff.any + }, { + name: "source-text-margin-y", + type: t.bidirectionalSize, + triggersBounds: diff.any + }, { + name: "source-text-offset", + type: t.size, + triggersBounds: diff.any + }]; + var targetLabel = [{ + name: "target-label", + type: t.text, + triggersBounds: diff.any + }, { + name: "target-text-rotation", + type: t.textRotation, + triggersBounds: diff.any + }, { + name: "target-text-margin-x", + type: t.bidirectionalSize, + triggersBounds: diff.any + }, { + name: "target-text-margin-y", + type: t.bidirectionalSize, + triggersBounds: diff.any + }, { + name: "target-text-offset", + type: t.size, + triggersBounds: diff.any + }]; + var labelDimensions = [{ + name: "font-family", + type: t.fontFamily, + triggersBounds: diff.any + }, { + name: "font-style", + type: t.fontStyle, + triggersBounds: diff.any + }, { + name: "font-weight", + type: t.fontWeight, + triggersBounds: diff.any + }, { + name: "font-size", + type: t.size, + triggersBounds: diff.any + }, { + name: "text-transform", + type: t.textTransform, + triggersBounds: diff.any + }, { + name: "text-wrap", + type: t.textWrap, + triggersBounds: diff.any + }, { + name: "text-overflow-wrap", + type: t.textOverflowWrap, + triggersBounds: diff.any + }, { + name: "text-max-width", + type: t.size, + triggersBounds: diff.any + }, { + name: "text-outline-width", + type: t.size, + triggersBounds: diff.any + }, { + name: "line-height", + type: t.positiveNumber, + triggersBounds: diff.any + }]; + var commonLabel = [{ + name: "text-valign", + type: t.valign, + triggersBounds: diff.any + }, { + name: "text-halign", + type: t.halign, + triggersBounds: diff.any + }, { + name: "color", + type: t.color + }, { + name: "text-outline-color", + type: t.color + }, { + name: "text-outline-opacity", + type: t.zeroOneNumber + }, { + name: "text-background-color", + type: t.color + }, { + name: "text-background-opacity", + type: t.zeroOneNumber + }, { + name: "text-background-padding", + type: t.size, + triggersBounds: diff.any + }, { + name: "text-border-opacity", + type: t.zeroOneNumber + }, { + name: "text-border-color", + type: t.color + }, { + name: "text-border-width", + type: t.size, + triggersBounds: diff.any + }, { + name: "text-border-style", + type: t.borderStyle, + triggersBounds: diff.any + }, { + name: "text-background-shape", + type: t.textBackgroundShape, + triggersBounds: diff.any + }, { + name: "text-justification", + type: t.justification + }]; + var behavior = [{ + name: "events", + type: t.bool, + triggersZOrder: diff.any + }, { + name: "text-events", + type: t.bool, + triggersZOrder: diff.any + }]; + var visibility = [{ + name: "display", + type: t.display, + triggersZOrder: diff.any, + triggersBounds: diff.any, + triggersBoundsOfConnectedEdges: true + }, { + name: "visibility", + type: t.visibility, + triggersZOrder: diff.any + }, { + name: "opacity", + type: t.zeroOneNumber, + triggersZOrder: diff.zeroNonZero + }, { + name: "text-opacity", + type: t.zeroOneNumber + }, { + name: "min-zoomed-font-size", + type: t.size + }, { + name: "z-compound-depth", + type: t.zCompoundDepth, + triggersZOrder: diff.any + }, { + name: "z-index-compare", + type: t.zIndexCompare, + triggersZOrder: diff.any + }, { + name: "z-index", + type: t.number, + triggersZOrder: diff.any + }]; + var overlay = [{ + name: "overlay-padding", + type: t.size, + triggersBounds: diff.any + }, { + name: "overlay-color", + type: t.color + }, { + name: "overlay-opacity", + type: t.zeroOneNumber, + triggersBounds: diff.zeroNonZero + }, { + name: "overlay-shape", + type: t.overlayShape, + triggersBounds: diff.any + }]; + var underlay = [{ + name: "underlay-padding", + type: t.size, + triggersBounds: diff.any + }, { + name: "underlay-color", + type: t.color + }, { + name: "underlay-opacity", + type: t.zeroOneNumber, + triggersBounds: diff.zeroNonZero + }, { + name: "underlay-shape", + type: t.overlayShape, + triggersBounds: diff.any + }]; + var transition = [{ + name: "transition-property", + type: t.propList + }, { + name: "transition-duration", + type: t.time + }, { + name: "transition-delay", + type: t.time + }, { + name: "transition-timing-function", + type: t.easing + }]; + var nodeSizeHashOverride = function nodeSizeHashOverride2(ele, parsedProp) { + if (parsedProp.value === "label") { + return -ele.poolIndex(); + } else { + return parsedProp.pfValue; + } + }; + var nodeBody = [{ + name: "height", + type: t.nodeSize, + triggersBounds: diff.any, + hashOverride: nodeSizeHashOverride + }, { + name: "width", + type: t.nodeSize, + triggersBounds: diff.any, + hashOverride: nodeSizeHashOverride + }, { + name: "shape", + type: t.nodeShape, + triggersBounds: diff.any + }, { + name: "shape-polygon-points", + type: t.polygonPointList, + triggersBounds: diff.any + }, { + name: "background-color", + type: t.color + }, { + name: "background-fill", + type: t.fill + }, { + name: "background-opacity", + type: t.zeroOneNumber + }, { + name: "background-blacken", + type: t.nOneOneNumber + }, { + name: "background-gradient-stop-colors", + type: t.colors + }, { + name: "background-gradient-stop-positions", + type: t.percentages + }, { + name: "background-gradient-direction", + type: t.gradientDirection + }, { + name: "padding", + type: t.sizeMaybePercent, + triggersBounds: diff.any + }, { + name: "padding-relative-to", + type: t.paddingRelativeTo, + triggersBounds: diff.any + }, { + name: "bounds-expansion", + type: t.boundsExpansion, + triggersBounds: diff.any + }]; + var nodeBorder = [{ + name: "border-color", + type: t.color + }, { + name: "border-opacity", + type: t.zeroOneNumber + }, { + name: "border-width", + type: t.size, + triggersBounds: diff.any + }, { + name: "border-style", + type: t.borderStyle + }]; + var nodeOutline = [{ + name: "outline-color", + type: t.color + }, { + name: "outline-opacity", + type: t.zeroOneNumber + }, { + name: "outline-width", + type: t.size, + triggersBounds: diff.any + }, { + name: "outline-style", + type: t.borderStyle + }, { + name: "outline-offset", + type: t.size, + triggersBounds: diff.any + }]; + var backgroundImage = [{ + name: "background-image", + type: t.urls + }, { + name: "background-image-crossorigin", + type: t.bgCrossOrigin + }, { + name: "background-image-opacity", + type: t.zeroOneNumbers + }, { + name: "background-image-containment", + type: t.bgContainment + }, { + name: "background-image-smoothing", + type: t.bools + }, { + name: "background-position-x", + type: t.bgPos + }, { + name: "background-position-y", + type: t.bgPos + }, { + name: "background-width-relative-to", + type: t.bgRelativeTo + }, { + name: "background-height-relative-to", + type: t.bgRelativeTo + }, { + name: "background-repeat", + type: t.bgRepeat + }, { + name: "background-fit", + type: t.bgFit + }, { + name: "background-clip", + type: t.bgClip + }, { + name: "background-width", + type: t.bgWH + }, { + name: "background-height", + type: t.bgWH + }, { + name: "background-offset-x", + type: t.bgPos + }, { + name: "background-offset-y", + type: t.bgPos + }]; + var compound = [{ + name: "position", + type: t.position, + triggersBounds: diff.any + }, { + name: "compound-sizing-wrt-labels", + type: t.compoundIncludeLabels, + triggersBounds: diff.any + }, { + name: "min-width", + type: t.size, + triggersBounds: diff.any + }, { + name: "min-width-bias-left", + type: t.sizeMaybePercent, + triggersBounds: diff.any + }, { + name: "min-width-bias-right", + type: t.sizeMaybePercent, + triggersBounds: diff.any + }, { + name: "min-height", + type: t.size, + triggersBounds: diff.any + }, { + name: "min-height-bias-top", + type: t.sizeMaybePercent, + triggersBounds: diff.any + }, { + name: "min-height-bias-bottom", + type: t.sizeMaybePercent, + triggersBounds: diff.any + }]; + var edgeLine = [{ + name: "line-style", + type: t.lineStyle + }, { + name: "line-color", + type: t.color + }, { + name: "line-fill", + type: t.fill + }, { + name: "line-cap", + type: t.lineCap + }, { + name: "line-opacity", + type: t.zeroOneNumber + }, { + name: "line-dash-pattern", + type: t.numbers + }, { + name: "line-dash-offset", + type: t.number + }, { + name: "line-gradient-stop-colors", + type: t.colors + }, { + name: "line-gradient-stop-positions", + type: t.percentages + }, { + name: "curve-style", + type: t.curveStyle, + triggersBounds: diff.any, + triggersBoundsOfParallelBeziers: true + }, { + name: "haystack-radius", + type: t.zeroOneNumber, + triggersBounds: diff.any + }, { + name: "source-endpoint", + type: t.edgeEndpoint, + triggersBounds: diff.any + }, { + name: "target-endpoint", + type: t.edgeEndpoint, + triggersBounds: diff.any + }, { + name: "control-point-step-size", + type: t.size, + triggersBounds: diff.any + }, { + name: "control-point-distances", + type: t.bidirectionalSizes, + triggersBounds: diff.any + }, { + name: "control-point-weights", + type: t.numbers, + triggersBounds: diff.any + }, { + name: "segment-distances", + type: t.bidirectionalSizes, + triggersBounds: diff.any + }, { + name: "segment-weights", + type: t.numbers, + triggersBounds: diff.any + }, { + name: "taxi-turn", + type: t.bidirectionalSizeMaybePercent, + triggersBounds: diff.any + }, { + name: "taxi-turn-min-distance", + type: t.size, + triggersBounds: diff.any + }, { + name: "taxi-direction", + type: t.axisDirection, + triggersBounds: diff.any + }, { + name: "edge-distances", + type: t.edgeDistances, + triggersBounds: diff.any + }, { + name: "arrow-scale", + type: t.positiveNumber, + triggersBounds: diff.any + }, { + name: "loop-direction", + type: t.angle, + triggersBounds: diff.any + }, { + name: "loop-sweep", + type: t.angle, + triggersBounds: diff.any + }, { + name: "source-distance-from-node", + type: t.size, + triggersBounds: diff.any + }, { + name: "target-distance-from-node", + type: t.size, + triggersBounds: diff.any + }]; + var ghost = [{ + name: "ghost", + type: t.bool, + triggersBounds: diff.any + }, { + name: "ghost-offset-x", + type: t.bidirectionalSize, + triggersBounds: diff.any + }, { + name: "ghost-offset-y", + type: t.bidirectionalSize, + triggersBounds: diff.any + }, { + name: "ghost-opacity", + type: t.zeroOneNumber + }]; + var core3 = [{ + name: "selection-box-color", + type: t.color + }, { + name: "selection-box-opacity", + type: t.zeroOneNumber + }, { + name: "selection-box-border-color", + type: t.color + }, { + name: "selection-box-border-width", + type: t.size + }, { + name: "active-bg-color", + type: t.color + }, { + name: "active-bg-opacity", + type: t.zeroOneNumber + }, { + name: "active-bg-size", + type: t.size + }, { + name: "outside-texture-bg-color", + type: t.color + }, { + name: "outside-texture-bg-opacity", + type: t.zeroOneNumber + }]; + var pie2 = []; + styfn$2.pieBackgroundN = 16; + pie2.push({ + name: "pie-size", + type: t.sizeMaybePercent + }); + for (var i3 = 1; i3 <= styfn$2.pieBackgroundN; i3++) { + pie2.push({ + name: "pie-" + i3 + "-background-color", + type: t.color + }); + pie2.push({ + name: "pie-" + i3 + "-background-size", + type: t.percent + }); + pie2.push({ + name: "pie-" + i3 + "-background-opacity", + type: t.zeroOneNumber + }); + } + var edgeArrow = []; + var arrowPrefixes = styfn$2.arrowPrefixes = ["source", "mid-source", "target", "mid-target"]; + [{ + name: "arrow-shape", + type: t.arrowShape, + triggersBounds: diff.any + }, { + name: "arrow-color", + type: t.color + }, { + name: "arrow-fill", + type: t.arrowFill + }, { + name: "arrow-width", + type: t.arrowWidth + }].forEach(function(prop2) { + arrowPrefixes.forEach(function(prefix) { + var name = prefix + "-" + prop2.name; + var type2 = prop2.type, triggersBounds = prop2.triggersBounds; + edgeArrow.push({ + name, + type: type2, + triggersBounds + }); + }); + }, {}); + var props = styfn$2.properties = [].concat(behavior, transition, visibility, overlay, underlay, ghost, commonLabel, labelDimensions, mainLabel, sourceLabel, targetLabel, nodeBody, nodeBorder, nodeOutline, backgroundImage, pie2, compound, edgeLine, edgeArrow, core3); + var propGroups = styfn$2.propertyGroups = { + // common to all eles + behavior, + transition, + visibility, + overlay, + underlay, + ghost, + // labels + commonLabel, + labelDimensions, + mainLabel, + sourceLabel, + targetLabel, + // node props + nodeBody, + nodeBorder, + nodeOutline, + backgroundImage, + pie: pie2, + compound, + // edge props + edgeLine, + edgeArrow, + core: core3 + }; + var propGroupNames = styfn$2.propertyGroupNames = {}; + var propGroupKeys = styfn$2.propertyGroupKeys = Object.keys(propGroups); + propGroupKeys.forEach(function(key) { + propGroupNames[key] = propGroups[key].map(function(prop2) { + return prop2.name; + }); + propGroups[key].forEach(function(prop2) { + return prop2.groupKey = key; + }); + }); + var aliases = styfn$2.aliases = [{ + name: "content", + pointsTo: "label" + }, { + name: "control-point-distance", + pointsTo: "control-point-distances" + }, { + name: "control-point-weight", + pointsTo: "control-point-weights" + }, { + name: "edge-text-rotation", + pointsTo: "text-rotation" + }, { + name: "padding-left", + pointsTo: "padding" + }, { + name: "padding-right", + pointsTo: "padding" + }, { + name: "padding-top", + pointsTo: "padding" + }, { + name: "padding-bottom", + pointsTo: "padding" + }]; + styfn$2.propertyNames = props.map(function(p2) { + return p2.name; + }); + for (var _i6 = 0; _i6 < props.length; _i6++) { + var prop = props[_i6]; + props[prop.name] = prop; + } + for (var _i22 = 0; _i22 < aliases.length; _i22++) { + var alias = aliases[_i22]; + var pointsToProp = props[alias.pointsTo]; + var aliasProp = { + name: alias.name, + alias: true, + pointsTo: pointsToProp + }; + props.push(aliasProp); + props[alias.name] = aliasProp; + } + })(); + styfn$2.getDefaultProperty = function(name) { + return this.getDefaultProperties()[name]; + }; + styfn$2.getDefaultProperties = function() { + var _p = this._private; + if (_p.defaultProperties != null) { + return _p.defaultProperties; + } + var rawProps = extend2({ + // core props + "selection-box-color": "#ddd", + "selection-box-opacity": 0.65, + "selection-box-border-color": "#aaa", + "selection-box-border-width": 1, + "active-bg-color": "black", + "active-bg-opacity": 0.15, + "active-bg-size": 30, + "outside-texture-bg-color": "#000", + "outside-texture-bg-opacity": 0.125, + // common node/edge props + "events": "yes", + "text-events": "no", + "text-valign": "top", + "text-halign": "center", + "text-justification": "auto", + "line-height": 1, + "color": "#000", + "text-outline-color": "#000", + "text-outline-width": 0, + "text-outline-opacity": 1, + "text-opacity": 1, + "text-decoration": "none", + "text-transform": "none", + "text-wrap": "none", + "text-overflow-wrap": "whitespace", + "text-max-width": 9999, + "text-background-color": "#000", + "text-background-opacity": 0, + "text-background-shape": "rectangle", + "text-background-padding": 0, + "text-border-opacity": 0, + "text-border-width": 0, + "text-border-style": "solid", + "text-border-color": "#000", + "font-family": "Helvetica Neue, Helvetica, sans-serif", + "font-style": "normal", + "font-weight": "normal", + "font-size": 16, + "min-zoomed-font-size": 0, + "text-rotation": "none", + "source-text-rotation": "none", + "target-text-rotation": "none", + "visibility": "visible", + "display": "element", + "opacity": 1, + "z-compound-depth": "auto", + "z-index-compare": "auto", + "z-index": 0, + "label": "", + "text-margin-x": 0, + "text-margin-y": 0, + "source-label": "", + "source-text-offset": 0, + "source-text-margin-x": 0, + "source-text-margin-y": 0, + "target-label": "", + "target-text-offset": 0, + "target-text-margin-x": 0, + "target-text-margin-y": 0, + "overlay-opacity": 0, + "overlay-color": "#000", + "overlay-padding": 10, + "overlay-shape": "round-rectangle", + "underlay-opacity": 0, + "underlay-color": "#000", + "underlay-padding": 10, + "underlay-shape": "round-rectangle", + "transition-property": "none", + "transition-duration": 0, + "transition-delay": 0, + "transition-timing-function": "linear", + // node props + "background-blacken": 0, + "background-color": "#999", + "background-fill": "solid", + "background-opacity": 1, + "background-image": "none", + "background-image-crossorigin": "anonymous", + "background-image-opacity": 1, + "background-image-containment": "inside", + "background-image-smoothing": "yes", + "background-position-x": "50%", + "background-position-y": "50%", + "background-offset-x": 0, + "background-offset-y": 0, + "background-width-relative-to": "include-padding", + "background-height-relative-to": "include-padding", + "background-repeat": "no-repeat", + "background-fit": "none", + "background-clip": "node", + "background-width": "auto", + "background-height": "auto", + "border-color": "#000", + "border-opacity": 1, + "border-width": 0, + "border-style": "solid", + "outline-color": "#999", + "outline-opacity": 1, + "outline-width": 0, + "outline-offset": 0, + "outline-style": "solid", + "height": 30, + "width": 30, + "shape": "ellipse", + "shape-polygon-points": "-1, -1, 1, -1, 1, 1, -1, 1", + "bounds-expansion": 0, + // node gradient + "background-gradient-direction": "to-bottom", + "background-gradient-stop-colors": "#999", + "background-gradient-stop-positions": "0%", + // ghost props + "ghost": "no", + "ghost-offset-y": 0, + "ghost-offset-x": 0, + "ghost-opacity": 0, + // compound props + "padding": 0, + "padding-relative-to": "width", + "position": "origin", + "compound-sizing-wrt-labels": "include", + "min-width": 0, + "min-width-bias-left": 0, + "min-width-bias-right": 0, + "min-height": 0, + "min-height-bias-top": 0, + "min-height-bias-bottom": 0 + }, { + // node pie bg + "pie-size": "100%" + }, [{ + name: "pie-{{i}}-background-color", + value: "black" + }, { + name: "pie-{{i}}-background-size", + value: "0%" + }, { + name: "pie-{{i}}-background-opacity", + value: 1 + }].reduce(function(css, prop2) { + for (var i4 = 1; i4 <= styfn$2.pieBackgroundN; i4++) { + var name2 = prop2.name.replace("{{i}}", i4); + var val2 = prop2.value; + css[name2] = val2; + } + return css; + }, {}), { + // edge props + "line-style": "solid", + "line-color": "#999", + "line-fill": "solid", + "line-cap": "butt", + "line-opacity": 1, + "line-gradient-stop-colors": "#999", + "line-gradient-stop-positions": "0%", + "control-point-step-size": 40, + "control-point-weights": 0.5, + "segment-weights": 0.5, + "segment-distances": 20, + "taxi-turn": "50%", + "taxi-turn-min-distance": 10, + "taxi-direction": "auto", + "edge-distances": "intersection", + "curve-style": "haystack", + "haystack-radius": 0, + "arrow-scale": 1, + "loop-direction": "-45deg", + "loop-sweep": "-90deg", + "source-distance-from-node": 0, + "target-distance-from-node": 0, + "source-endpoint": "outside-to-node", + "target-endpoint": "outside-to-node", + "line-dash-pattern": [6, 3], + "line-dash-offset": 0 + }, [{ + name: "arrow-shape", + value: "none" + }, { + name: "arrow-color", + value: "#999" + }, { + name: "arrow-fill", + value: "filled" + }, { + name: "arrow-width", + value: 1 + }].reduce(function(css, prop2) { + styfn$2.arrowPrefixes.forEach(function(prefix) { + var name2 = prefix + "-" + prop2.name; + var val2 = prop2.value; + css[name2] = val2; + }); + return css; + }, {})); + var parsedProps = {}; + for (var i3 = 0; i3 < this.properties.length; i3++) { + var prop = this.properties[i3]; + if (prop.pointsTo) { + continue; + } + var name = prop.name; + var val = rawProps[name]; + var parsedProp = this.parse(name, val); + parsedProps[name] = parsedProp; + } + _p.defaultProperties = parsedProps; + return _p.defaultProperties; + }; + styfn$2.addDefaultStylesheet = function() { + this.selector(":parent").css({ + "shape": "rectangle", + "padding": 10, + "background-color": "#eee", + "border-color": "#ccc", + "border-width": 1 + }).selector("edge").css({ + "width": 3 + }).selector(":loop").css({ + "curve-style": "bezier" + }).selector("edge:compound").css({ + "curve-style": "bezier", + "source-endpoint": "outside-to-line", + "target-endpoint": "outside-to-line" + }).selector(":selected").css({ + "background-color": "#0169D9", + "line-color": "#0169D9", + "source-arrow-color": "#0169D9", + "target-arrow-color": "#0169D9", + "mid-source-arrow-color": "#0169D9", + "mid-target-arrow-color": "#0169D9" + }).selector(":parent:selected").css({ + "background-color": "#CCE1F9", + "border-color": "#aec8e5" + }).selector(":active").css({ + "overlay-color": "black", + "overlay-padding": 10, + "overlay-opacity": 0.25 + }); + this.defaultLength = this.length; + }; + var styfn$1 = {}; + styfn$1.parse = function(name, value2, propIsBypass, propIsFlat) { + var self2 = this; + if (fn$6(value2)) { + return self2.parseImplWarn(name, value2, propIsBypass, propIsFlat); + } + var flatKey = propIsFlat === "mapping" || propIsFlat === true || propIsFlat === false || propIsFlat == null ? "dontcare" : propIsFlat; + var bypassKey = propIsBypass ? "t" : "f"; + var valueKey = "" + value2; + var argHash = hashStrings(name, valueKey, bypassKey, flatKey); + var propCache = self2.propCache = self2.propCache || []; + var ret; + if (!(ret = propCache[argHash])) { + ret = propCache[argHash] = self2.parseImplWarn(name, value2, propIsBypass, propIsFlat); + } + if (propIsBypass || propIsFlat === "mapping") { + ret = copy2(ret); + if (ret) { + ret.value = copy2(ret.value); + } + } + return ret; + }; + styfn$1.parseImplWarn = function(name, value2, propIsBypass, propIsFlat) { + var prop = this.parseImpl(name, value2, propIsBypass, propIsFlat); + if (!prop && value2 != null) { + warn("The style property `".concat(name, ": ").concat(value2, "` is invalid")); + } + if (prop && (prop.name === "width" || prop.name === "height") && value2 === "label") { + warn("The style value of `label` is deprecated for `" + prop.name + "`"); + } + return prop; + }; + styfn$1.parseImpl = function(name, value2, propIsBypass, propIsFlat) { + var self2 = this; + name = camel2dash(name); + var property2 = self2.properties[name]; + var passedValue = value2; + var types = self2.types; + if (!property2) { + return null; + } + if (value2 === void 0) { + return null; + } + if (property2.alias) { + property2 = property2.pointsTo; + name = property2.name; + } + var valueIsString = string2(value2); + if (valueIsString) { + value2 = value2.trim(); + } + var type2 = property2.type; + if (!type2) { + return null; + } + if (propIsBypass && (value2 === "" || value2 === null)) { + return { + name, + value: value2, + bypass: true, + deleteBypass: true + }; + } + if (fn$6(value2)) { + return { + name, + value: value2, + strValue: "fn", + mapped: types.fn, + bypass: propIsBypass + }; + } + var data2, mapData; + if (!valueIsString || propIsFlat || value2.length < 7 || value2[1] !== "a") + ; + else if (value2.length >= 7 && value2[0] === "d" && (data2 = new RegExp(types.data.regex).exec(value2))) { + if (propIsBypass) { + return false; + } + var mapped = types.data; + return { + name, + value: data2, + strValue: "" + value2, + mapped, + field: data2[1], + bypass: propIsBypass + }; + } else if (value2.length >= 10 && value2[0] === "m" && (mapData = new RegExp(types.mapData.regex).exec(value2))) { + if (propIsBypass) { + return false; + } + if (type2.multiple) { + return false; + } + var _mapped = types.mapData; + if (!(type2.color || type2.number)) { + return false; + } + var valueMin = this.parse(name, mapData[4]); + if (!valueMin || valueMin.mapped) { + return false; + } + var valueMax = this.parse(name, mapData[5]); + if (!valueMax || valueMax.mapped) { + return false; + } + if (valueMin.pfValue === valueMax.pfValue || valueMin.strValue === valueMax.strValue) { + warn("`" + name + ": " + value2 + "` is not a valid mapper because the output range is zero; converting to `" + name + ": " + valueMin.strValue + "`"); + return this.parse(name, valueMin.strValue); + } else if (type2.color) { + var c1 = valueMin.value; + var c2 = valueMax.value; + var same = c1[0] === c2[0] && c1[1] === c2[1] && c1[2] === c2[2] && // optional alpha + (c1[3] === c2[3] || (c1[3] == null || c1[3] === 1) && (c2[3] == null || c2[3] === 1)); + if (same) { + return false; + } + } + return { + name, + value: mapData, + strValue: "" + value2, + mapped: _mapped, + field: mapData[1], + fieldMin: parseFloat(mapData[2]), + // min & max are numeric + fieldMax: parseFloat(mapData[3]), + valueMin: valueMin.value, + valueMax: valueMax.value, + bypass: propIsBypass + }; + } + if (type2.multiple && propIsFlat !== "multiple") { + var vals; + if (valueIsString) { + vals = value2.split(/\s+/); + } else if (array2(value2)) { + vals = value2; + } else { + vals = [value2]; + } + if (type2.evenMultiple && vals.length % 2 !== 0) { + return null; + } + var valArr = []; + var unitsArr = []; + var pfValArr = []; + var strVal = ""; + var hasEnum = false; + for (var i3 = 0; i3 < vals.length; i3++) { + var p2 = self2.parse(name, vals[i3], propIsBypass, "multiple"); + hasEnum = hasEnum || string2(p2.value); + valArr.push(p2.value); + pfValArr.push(p2.pfValue != null ? p2.pfValue : p2.value); + unitsArr.push(p2.units); + strVal += (i3 > 0 ? " " : "") + p2.strValue; + } + if (type2.validate && !type2.validate(valArr, unitsArr)) { + return null; + } + if (type2.singleEnum && hasEnum) { + if (valArr.length === 1 && string2(valArr[0])) { + return { + name, + value: valArr[0], + strValue: valArr[0], + bypass: propIsBypass + }; + } else { + return null; + } + } + return { + name, + value: valArr, + pfValue: pfValArr, + strValue: strVal, + bypass: propIsBypass, + units: unitsArr + }; + } + var checkEnums = function checkEnums2() { + for (var _i6 = 0; _i6 < type2.enums.length; _i6++) { + var en = type2.enums[_i6]; + if (en === value2) { + return { + name, + value: value2, + strValue: "" + value2, + bypass: propIsBypass + }; + } + } + return null; + }; + if (type2.number) { + var units; + var implicitUnits = "px"; + if (type2.units) { + units = type2.units; + } + if (type2.implicitUnits) { + implicitUnits = type2.implicitUnits; + } + if (!type2.unitless) { + if (valueIsString) { + var unitsRegex = "px|em" + (type2.allowPercent ? "|\\%" : ""); + if (units) { + unitsRegex = units; + } + var match2 = value2.match("^(" + number2 + ")(" + unitsRegex + ")?$"); + if (match2) { + value2 = match2[1]; + units = match2[2] || implicitUnits; + } + } else if (!units || type2.implicitUnits) { + units = implicitUnits; + } + } + value2 = parseFloat(value2); + if (isNaN(value2) && type2.enums === void 0) { + return null; + } + if (isNaN(value2) && type2.enums !== void 0) { + value2 = passedValue; + return checkEnums(); + } + if (type2.integer && !integer(value2)) { + return null; + } + if (type2.min !== void 0 && (value2 < type2.min || type2.strictMin && value2 === type2.min) || type2.max !== void 0 && (value2 > type2.max || type2.strictMax && value2 === type2.max)) { + return null; + } + var ret = { + name, + value: value2, + strValue: "" + value2 + (units ? units : ""), + units, + bypass: propIsBypass + }; + if (type2.unitless || units !== "px" && units !== "em") { + ret.pfValue = value2; + } else { + ret.pfValue = units === "px" || !units ? value2 : this.getEmSizeInPixels() * value2; + } + if (units === "ms" || units === "s") { + ret.pfValue = units === "ms" ? value2 : 1e3 * value2; + } + if (units === "deg" || units === "rad") { + ret.pfValue = units === "rad" ? value2 : deg2rad(value2); + } + if (units === "%") { + ret.pfValue = value2 / 100; + } + return ret; + } else if (type2.propList) { + var props = []; + var propsStr = "" + value2; + if (propsStr === "none") + ; + else { + var propsSplit = propsStr.split(/\s*,\s*|\s+/); + for (var _i22 = 0; _i22 < propsSplit.length; _i22++) { + var propName = propsSplit[_i22].trim(); + if (self2.properties[propName]) { + props.push(propName); + } else { + warn("`" + propName + "` is not a valid property name"); + } + } + if (props.length === 0) { + return null; + } + } + return { + name, + value: props, + strValue: props.length === 0 ? "none" : props.join(" "), + bypass: propIsBypass + }; + } else if (type2.color) { + var tuple = color2tuple(value2); + if (!tuple) { + return null; + } + return { + name, + value: tuple, + pfValue: tuple, + strValue: "rgb(" + tuple[0] + "," + tuple[1] + "," + tuple[2] + ")", + // n.b. no spaces b/c of multiple support + bypass: propIsBypass + }; + } else if (type2.regex || type2.regexes) { + if (type2.enums) { + var enumProp = checkEnums(); + if (enumProp) { + return enumProp; + } + } + var regexes = type2.regexes ? type2.regexes : [type2.regex]; + for (var _i32 = 0; _i32 < regexes.length; _i32++) { + var regex = new RegExp(regexes[_i32]); + var m = regex.exec(value2); + if (m) { + return { + name, + value: type2.singleRegexMatchValue ? m[1] : m, + strValue: "" + value2, + bypass: propIsBypass + }; + } + } + return null; + } else if (type2.string) { + return { + name, + value: "" + value2, + strValue: "" + value2, + bypass: propIsBypass + }; + } else if (type2.enums) { + return checkEnums(); + } else { + return null; + } + }; + var Style2 = function Style3(cy) { + if (!(this instanceof Style3)) { + return new Style3(cy); + } + if (!core2(cy)) { + error("A style must have a core reference"); + return; + } + this._private = { + cy, + coreStyle: {} + }; + this.length = 0; + this.resetToDefault(); + }; + var styfn = Style2.prototype; + styfn.instanceString = function() { + return "style"; + }; + styfn.clear = function() { + var _p = this._private; + var cy = _p.cy; + var eles = cy.elements(); + for (var i3 = 0; i3 < this.length; i3++) { + this[i3] = void 0; + } + this.length = 0; + _p.contextStyles = {}; + _p.propDiffs = {}; + this.cleanElements(eles, true); + eles.forEach(function(ele) { + var ele_p = ele[0]._private; + ele_p.styleDirty = true; + ele_p.appliedInitStyle = false; + }); + return this; + }; + styfn.resetToDefault = function() { + this.clear(); + this.addDefaultStylesheet(); + return this; + }; + styfn.core = function(propName) { + return this._private.coreStyle[propName] || this.getDefaultProperty(propName); + }; + styfn.selector = function(selectorStr) { + var selector2 = selectorStr === "core" ? null : new Selector(selectorStr); + var i3 = this.length++; + this[i3] = { + selector: selector2, + properties: [], + mappedProperties: [], + index: i3 + }; + return this; + }; + styfn.css = function() { + var self2 = this; + var args = arguments; + if (args.length === 1) { + var map2 = args[0]; + for (var i3 = 0; i3 < self2.properties.length; i3++) { + var prop = self2.properties[i3]; + var mapVal = map2[prop.name]; + if (mapVal === void 0) { + mapVal = map2[dash2camel(prop.name)]; + } + if (mapVal !== void 0) { + this.cssRule(prop.name, mapVal); + } + } + } else if (args.length === 2) { + this.cssRule(args[0], args[1]); + } + return this; + }; + styfn.style = styfn.css; + styfn.cssRule = function(name, value2) { + var property2 = this.parse(name, value2); + if (property2) { + var i3 = this.length - 1; + this[i3].properties.push(property2); + this[i3].properties[property2.name] = property2; + if (property2.name.match(/pie-(\d+)-background-size/) && property2.value) { + this._private.hasPie = true; + } + if (property2.mapped) { + this[i3].mappedProperties.push(property2); + } + var currentSelectorIsCore = !this[i3].selector; + if (currentSelectorIsCore) { + this._private.coreStyle[property2.name] = property2; + } + } + return this; + }; + styfn.append = function(style) { + if (stylesheet(style)) { + style.appendToStyle(this); + } else if (array2(style)) { + this.appendFromJson(style); + } else if (string2(style)) { + this.appendFromString(style); + } + return this; + }; + Style2.fromJson = function(cy, json2) { + var style = new Style2(cy); + style.fromJson(json2); + return style; + }; + Style2.fromString = function(cy, string3) { + return new Style2(cy).fromString(string3); + }; + [styfn$8, styfn$7, styfn$6, styfn$5, styfn$4, styfn$3, styfn$2, styfn$1].forEach(function(props) { + extend2(styfn, props); + }); + Style2.types = styfn.types; + Style2.properties = styfn.properties; + Style2.propertyGroups = styfn.propertyGroups; + Style2.propertyGroupNames = styfn.propertyGroupNames; + Style2.propertyGroupKeys = styfn.propertyGroupKeys; + var corefn$2 = { + style: function style(newStyle) { + if (newStyle) { + var s = this.setStyle(newStyle); + s.update(); + } + return this._private.style; + }, + setStyle: function setStyle2(style) { + var _p = this._private; + if (stylesheet(style)) { + _p.style = style.generateStyle(this); + } else if (array2(style)) { + _p.style = Style2.fromJson(this, style); + } else if (string2(style)) { + _p.style = Style2.fromString(this, style); + } else { + _p.style = Style2(this); + } + return _p.style; + }, + // e.g. cy.data() changed => recalc ele mappers + updateStyle: function updateStyle() { + this.mutableElements().updateStyle(); + } + }; + var defaultSelectionType = "single"; + var corefn$1 = { + autolock: function autolock(bool2) { + if (bool2 !== void 0) { + this._private.autolock = bool2 ? true : false; + } else { + return this._private.autolock; + } + return this; + }, + autoungrabify: function autoungrabify(bool2) { + if (bool2 !== void 0) { + this._private.autoungrabify = bool2 ? true : false; + } else { + return this._private.autoungrabify; + } + return this; + }, + autounselectify: function autounselectify(bool2) { + if (bool2 !== void 0) { + this._private.autounselectify = bool2 ? true : false; + } else { + return this._private.autounselectify; + } + return this; + }, + selectionType: function selectionType(selType) { + var _p = this._private; + if (_p.selectionType == null) { + _p.selectionType = defaultSelectionType; + } + if (selType !== void 0) { + if (selType === "additive" || selType === "single") { + _p.selectionType = selType; + } + } else { + return _p.selectionType; + } + return this; + }, + panningEnabled: function panningEnabled(bool2) { + if (bool2 !== void 0) { + this._private.panningEnabled = bool2 ? true : false; + } else { + return this._private.panningEnabled; + } + return this; + }, + userPanningEnabled: function userPanningEnabled(bool2) { + if (bool2 !== void 0) { + this._private.userPanningEnabled = bool2 ? true : false; + } else { + return this._private.userPanningEnabled; + } + return this; + }, + zoomingEnabled: function zoomingEnabled(bool2) { + if (bool2 !== void 0) { + this._private.zoomingEnabled = bool2 ? true : false; + } else { + return this._private.zoomingEnabled; + } + return this; + }, + userZoomingEnabled: function userZoomingEnabled(bool2) { + if (bool2 !== void 0) { + this._private.userZoomingEnabled = bool2 ? true : false; + } else { + return this._private.userZoomingEnabled; + } + return this; + }, + boxSelectionEnabled: function boxSelectionEnabled(bool2) { + if (bool2 !== void 0) { + this._private.boxSelectionEnabled = bool2 ? true : false; + } else { + return this._private.boxSelectionEnabled; + } + return this; + }, + pan: function pan() { + var args = arguments; + var pan2 = this._private.pan; + var dim, val, dims, x2, y2; + switch (args.length) { + case 0: + return pan2; + case 1: + if (string2(args[0])) { + dim = args[0]; + return pan2[dim]; + } else if (plainObject(args[0])) { + if (!this._private.panningEnabled) { + return this; + } + dims = args[0]; + x2 = dims.x; + y2 = dims.y; + if (number$12(x2)) { + pan2.x = x2; + } + if (number$12(y2)) { + pan2.y = y2; + } + this.emit("pan viewport"); + } + break; + case 2: + if (!this._private.panningEnabled) { + return this; + } + dim = args[0]; + val = args[1]; + if ((dim === "x" || dim === "y") && number$12(val)) { + pan2[dim] = val; + } + this.emit("pan viewport"); + break; + } + this.notify("viewport"); + return this; + }, + panBy: function panBy(arg0, arg1) { + var args = arguments; + var pan = this._private.pan; + var dim, val, dims, x2, y2; + if (!this._private.panningEnabled) { + return this; + } + switch (args.length) { + case 1: + if (plainObject(arg0)) { + dims = args[0]; + x2 = dims.x; + y2 = dims.y; + if (number$12(x2)) { + pan.x += x2; + } + if (number$12(y2)) { + pan.y += y2; + } + this.emit("pan viewport"); + } + break; + case 2: + dim = arg0; + val = arg1; + if ((dim === "x" || dim === "y") && number$12(val)) { + pan[dim] += val; + } + this.emit("pan viewport"); + break; + } + this.notify("viewport"); + return this; + }, + fit: function fit(elements2, padding2) { + var viewportState = this.getFitViewport(elements2, padding2); + if (viewportState) { + var _p = this._private; + _p.zoom = viewportState.zoom; + _p.pan = viewportState.pan; + this.emit("pan zoom viewport"); + this.notify("viewport"); + } + return this; + }, + getFitViewport: function getFitViewport(elements2, padding2) { + if (number$12(elements2) && padding2 === void 0) { + padding2 = elements2; + elements2 = void 0; + } + if (!this._private.panningEnabled || !this._private.zoomingEnabled) { + return; + } + var bb; + if (string2(elements2)) { + var sel = elements2; + elements2 = this.$(sel); + } else if (boundingBox(elements2)) { + var bbe = elements2; + bb = { + x1: bbe.x1, + y1: bbe.y1, + x2: bbe.x2, + y2: bbe.y2 + }; + bb.w = bb.x2 - bb.x1; + bb.h = bb.y2 - bb.y1; + } else if (!elementOrCollection(elements2)) { + elements2 = this.mutableElements(); + } + if (elementOrCollection(elements2) && elements2.empty()) { + return; + } + bb = bb || elements2.boundingBox(); + var w2 = this.width(); + var h = this.height(); + var zoom; + padding2 = number$12(padding2) ? padding2 : 0; + if (!isNaN(w2) && !isNaN(h) && w2 > 0 && h > 0 && !isNaN(bb.w) && !isNaN(bb.h) && bb.w > 0 && bb.h > 0) { + zoom = Math.min((w2 - 2 * padding2) / bb.w, (h - 2 * padding2) / bb.h); + zoom = zoom > this._private.maxZoom ? this._private.maxZoom : zoom; + zoom = zoom < this._private.minZoom ? this._private.minZoom : zoom; + var pan = { + // now pan to middle + x: (w2 - zoom * (bb.x1 + bb.x2)) / 2, + y: (h - zoom * (bb.y1 + bb.y2)) / 2 + }; + return { + zoom, + pan + }; + } + return; + }, + zoomRange: function zoomRange(min3, max3) { + var _p = this._private; + if (max3 == null) { + var opts = min3; + min3 = opts.min; + max3 = opts.max; + } + if (number$12(min3) && number$12(max3) && min3 <= max3) { + _p.minZoom = min3; + _p.maxZoom = max3; + } else if (number$12(min3) && max3 === void 0 && min3 <= _p.maxZoom) { + _p.minZoom = min3; + } else if (number$12(max3) && min3 === void 0 && max3 >= _p.minZoom) { + _p.maxZoom = max3; + } + return this; + }, + minZoom: function minZoom(zoom) { + if (zoom === void 0) { + return this._private.minZoom; + } else { + return this.zoomRange({ + min: zoom + }); + } + }, + maxZoom: function maxZoom2(zoom) { + if (zoom === void 0) { + return this._private.maxZoom; + } else { + return this.zoomRange({ + max: zoom + }); + } + }, + getZoomedViewport: function getZoomedViewport(params) { + var _p = this._private; + var currentPan = _p.pan; + var currentZoom = _p.zoom; + var pos; + var zoom; + var bail = false; + if (!_p.zoomingEnabled) { + bail = true; + } + if (number$12(params)) { + zoom = params; + } else if (plainObject(params)) { + zoom = params.level; + if (params.position != null) { + pos = modelToRenderedPosition(params.position, currentZoom, currentPan); + } else if (params.renderedPosition != null) { + pos = params.renderedPosition; + } + if (pos != null && !_p.panningEnabled) { + bail = true; + } + } + zoom = zoom > _p.maxZoom ? _p.maxZoom : zoom; + zoom = zoom < _p.minZoom ? _p.minZoom : zoom; + if (bail || !number$12(zoom) || zoom === currentZoom || pos != null && (!number$12(pos.x) || !number$12(pos.y))) { + return null; + } + if (pos != null) { + var pan1 = currentPan; + var zoom1 = currentZoom; + var zoom2 = zoom; + var pan2 = { + x: -zoom2 / zoom1 * (pos.x - pan1.x) + pos.x, + y: -zoom2 / zoom1 * (pos.y - pan1.y) + pos.y + }; + return { + zoomed: true, + panned: true, + zoom: zoom2, + pan: pan2 + }; + } else { + return { + zoomed: true, + panned: false, + zoom, + pan: currentPan + }; + } + }, + zoom: function zoom(params) { + if (params === void 0) { + return this._private.zoom; + } else { + var vp = this.getZoomedViewport(params); + var _p = this._private; + if (vp == null || !vp.zoomed) { + return this; + } + _p.zoom = vp.zoom; + if (vp.panned) { + _p.pan.x = vp.pan.x; + _p.pan.y = vp.pan.y; + } + this.emit("zoom" + (vp.panned ? " pan" : "") + " viewport"); + this.notify("viewport"); + return this; + } + }, + viewport: function viewport(opts) { + var _p = this._private; + var zoomDefd = true; + var panDefd = true; + var events = []; + var zoomFailed = false; + var panFailed = false; + if (!opts) { + return this; + } + if (!number$12(opts.zoom)) { + zoomDefd = false; + } + if (!plainObject(opts.pan)) { + panDefd = false; + } + if (!zoomDefd && !panDefd) { + return this; + } + if (zoomDefd) { + var z = opts.zoom; + if (z < _p.minZoom || z > _p.maxZoom || !_p.zoomingEnabled) { + zoomFailed = true; + } else { + _p.zoom = z; + events.push("zoom"); + } + } + if (panDefd && (!zoomFailed || !opts.cancelOnFailedZoom) && _p.panningEnabled) { + var p2 = opts.pan; + if (number$12(p2.x)) { + _p.pan.x = p2.x; + panFailed = false; + } + if (number$12(p2.y)) { + _p.pan.y = p2.y; + panFailed = false; + } + if (!panFailed) { + events.push("pan"); + } + } + if (events.length > 0) { + events.push("viewport"); + this.emit(events.join(" ")); + this.notify("viewport"); + } + return this; + }, + center: function center2(elements2) { + var pan = this.getCenterPan(elements2); + if (pan) { + this._private.pan = pan; + this.emit("pan viewport"); + this.notify("viewport"); + } + return this; + }, + getCenterPan: function getCenterPan(elements2, zoom) { + if (!this._private.panningEnabled) { + return; + } + if (string2(elements2)) { + var selector2 = elements2; + elements2 = this.mutableElements().filter(selector2); + } else if (!elementOrCollection(elements2)) { + elements2 = this.mutableElements(); + } + if (elements2.length === 0) { + return; + } + var bb = elements2.boundingBox(); + var w2 = this.width(); + var h = this.height(); + zoom = zoom === void 0 ? this._private.zoom : zoom; + var pan = { + // middle + x: (w2 - zoom * (bb.x1 + bb.x2)) / 2, + y: (h - zoom * (bb.y1 + bb.y2)) / 2 + }; + return pan; + }, + reset: function reset2() { + if (!this._private.panningEnabled || !this._private.zoomingEnabled) { + return this; + } + this.viewport({ + pan: { + x: 0, + y: 0 + }, + zoom: 1 + }); + return this; + }, + invalidateSize: function invalidateSize() { + this._private.sizeCache = null; + }, + size: function size2() { + var _p = this._private; + var container = _p.container; + var cy = this; + return _p.sizeCache = _p.sizeCache || (container ? function() { + var style = cy.window().getComputedStyle(container); + var val = function val2(name) { + return parseFloat(style.getPropertyValue(name)); + }; + return { + width: container.clientWidth - val("padding-left") - val("padding-right"), + height: container.clientHeight - val("padding-top") - val("padding-bottom") + }; + }() : { + // fallback if no container (not 0 b/c can be used for dividing etc) + width: 1, + height: 1 + }); + }, + width: function width2() { + return this.size().width; + }, + height: function height() { + return this.size().height; + }, + extent: function extent() { + var pan = this._private.pan; + var zoom = this._private.zoom; + var rb = this.renderedExtent(); + var b = { + x1: (rb.x1 - pan.x) / zoom, + x2: (rb.x2 - pan.x) / zoom, + y1: (rb.y1 - pan.y) / zoom, + y2: (rb.y2 - pan.y) / zoom + }; + b.w = b.x2 - b.x1; + b.h = b.y2 - b.y1; + return b; + }, + renderedExtent: function renderedExtent() { + var width2 = this.width(); + var height = this.height(); + return { + x1: 0, + y1: 0, + x2: width2, + y2: height, + w: width2, + h: height + }; + }, + multiClickDebounceTime: function multiClickDebounceTime(_int) { + if (_int) + this._private.multiClickDebounceTime = _int; + else + return this._private.multiClickDebounceTime; + return this; + } + }; + corefn$1.centre = corefn$1.center; + corefn$1.autolockNodes = corefn$1.autolock; + corefn$1.autoungrabifyNodes = corefn$1.autoungrabify; + var fn = { + data: define3.data({ + field: "data", + bindingEvent: "data", + allowBinding: true, + allowSetting: true, + settingEvent: "data", + settingTriggersEvent: true, + triggerFnName: "trigger", + allowGetting: true, + updateStyle: true + }), + removeData: define3.removeData({ + field: "data", + event: "data", + triggerFnName: "trigger", + triggerEvent: true, + updateStyle: true + }), + scratch: define3.data({ + field: "scratch", + bindingEvent: "scratch", + allowBinding: true, + allowSetting: true, + settingEvent: "scratch", + settingTriggersEvent: true, + triggerFnName: "trigger", + allowGetting: true, + updateStyle: true + }), + removeScratch: define3.removeData({ + field: "scratch", + event: "scratch", + triggerFnName: "trigger", + triggerEvent: true, + updateStyle: true + }) + }; + fn.attr = fn.data; + fn.removeAttr = fn.removeData; + var Core = function Core2(opts) { + var cy = this; + opts = extend2({}, opts); + var container = opts.container; + if (container && !htmlElement(container) && htmlElement(container[0])) { + container = container[0]; + } + var reg = container ? container._cyreg : null; + reg = reg || {}; + if (reg && reg.cy) { + reg.cy.destroy(); + reg = {}; + } + var readies = reg.readies = reg.readies || []; + if (container) { + container._cyreg = reg; + } + reg.cy = cy; + var head2 = _window !== void 0 && container !== void 0 && !opts.headless; + var options2 = opts; + options2.layout = extend2({ + name: head2 ? "grid" : "null" + }, options2.layout); + options2.renderer = extend2({ + name: head2 ? "canvas" : "null" + }, options2.renderer); + var defVal = function defVal2(def, val, altVal) { + if (val !== void 0) { + return val; + } else if (altVal !== void 0) { + return altVal; + } else { + return def; + } + }; + var _p = this._private = { + container, + // html dom ele container + ready: false, + // whether ready has been triggered + options: options2, + // cached options + elements: new Collection(this), + // elements in the graph + listeners: [], + // list of listeners + aniEles: new Collection(this), + // elements being animated + data: options2.data || {}, + // data for the core + scratch: {}, + // scratch object for core + layout: null, + renderer: null, + destroyed: false, + // whether destroy was called + notificationsEnabled: true, + // whether notifications are sent to the renderer + minZoom: 1e-50, + maxZoom: 1e50, + zoomingEnabled: defVal(true, options2.zoomingEnabled), + userZoomingEnabled: defVal(true, options2.userZoomingEnabled), + panningEnabled: defVal(true, options2.panningEnabled), + userPanningEnabled: defVal(true, options2.userPanningEnabled), + boxSelectionEnabled: defVal(true, options2.boxSelectionEnabled), + autolock: defVal(false, options2.autolock, options2.autolockNodes), + autoungrabify: defVal(false, options2.autoungrabify, options2.autoungrabifyNodes), + autounselectify: defVal(false, options2.autounselectify), + styleEnabled: options2.styleEnabled === void 0 ? head2 : options2.styleEnabled, + zoom: number$12(options2.zoom) ? options2.zoom : 1, + pan: { + x: plainObject(options2.pan) && number$12(options2.pan.x) ? options2.pan.x : 0, + y: plainObject(options2.pan) && number$12(options2.pan.y) ? options2.pan.y : 0 + }, + animation: { + // object for currently-running animations + current: [], + queue: [] + }, + hasCompoundNodes: false, + multiClickDebounceTime: defVal(250, options2.multiClickDebounceTime) + }; + this.createEmitter(); + this.selectionType(options2.selectionType); + this.zoomRange({ + min: options2.minZoom, + max: options2.maxZoom + }); + var loadExtData = function loadExtData2(extData, next2) { + var anyIsPromise = extData.some(promise); + if (anyIsPromise) { + return Promise$12.all(extData).then(next2); + } else { + next2(extData); + } + }; + if (_p.styleEnabled) { + cy.setStyle([]); + } + var rendererOptions = extend2({}, options2, options2.renderer); + cy.initRenderer(rendererOptions); + var setElesAndLayout = function setElesAndLayout2(elements2, onload, ondone) { + cy.notifications(false); + var oldEles = cy.mutableElements(); + if (oldEles.length > 0) { + oldEles.remove(); + } + if (elements2 != null) { + if (plainObject(elements2) || array2(elements2)) { + cy.add(elements2); + } + } + cy.one("layoutready", function(e) { + cy.notifications(true); + cy.emit(e); + cy.one("load", onload); + cy.emitAndNotify("load"); + }).one("layoutstop", function() { + cy.one("done", ondone); + cy.emit("done"); + }); + var layoutOpts = extend2({}, cy._private.options.layout); + layoutOpts.eles = cy.elements(); + cy.layout(layoutOpts).run(); + }; + loadExtData([options2.style, options2.elements], function(thens) { + var initStyle = thens[0]; + var initEles = thens[1]; + if (_p.styleEnabled) { + cy.style().append(initStyle); + } + setElesAndLayout(initEles, function() { + cy.startAnimationLoop(); + _p.ready = true; + if (fn$6(options2.ready)) { + cy.on("ready", options2.ready); + } + for (var i3 = 0; i3 < readies.length; i3++) { + var fn2 = readies[i3]; + cy.on("ready", fn2); + } + if (reg) { + reg.readies = []; + } + cy.emit("ready"); + }, options2.done); + }); + }; + var corefn = Core.prototype; + extend2(corefn, { + instanceString: function instanceString() { + return "core"; + }, + isReady: function isReady() { + return this._private.ready; + }, + destroyed: function destroyed() { + return this._private.destroyed; + }, + ready: function ready(fn2) { + if (this.isReady()) { + this.emitter().emit("ready", [], fn2); + } else { + this.on("ready", fn2); + } + return this; + }, + destroy: function destroy() { + var cy = this; + if (cy.destroyed()) + return; + cy.stopAnimationLoop(); + cy.destroyRenderer(); + this.emit("destroy"); + cy._private.destroyed = true; + return cy; + }, + hasElementWithId: function hasElementWithId(id2) { + return this._private.elements.hasElementWithId(id2); + }, + getElementById: function getElementById2(id2) { + return this._private.elements.getElementById(id2); + }, + hasCompoundNodes: function hasCompoundNodes() { + return this._private.hasCompoundNodes; + }, + headless: function headless() { + return this._private.renderer.isHeadless(); + }, + styleEnabled: function styleEnabled() { + return this._private.styleEnabled; + }, + addToPool: function addToPool(eles) { + this._private.elements.merge(eles); + return this; + }, + removeFromPool: function removeFromPool(eles) { + this._private.elements.unmerge(eles); + return this; + }, + container: function container() { + return this._private.container || null; + }, + window: function window2() { + var container = this._private.container; + if (container == null) + return _window; + var ownerDocument = this._private.container.ownerDocument; + if (ownerDocument === void 0 || ownerDocument == null) { + return _window; + } + return ownerDocument.defaultView || _window; + }, + mount: function mount(container) { + if (container == null) { + return; + } + var cy = this; + var _p = cy._private; + var options2 = _p.options; + if (!htmlElement(container) && htmlElement(container[0])) { + container = container[0]; + } + cy.stopAnimationLoop(); + cy.destroyRenderer(); + _p.container = container; + _p.styleEnabled = true; + cy.invalidateSize(); + cy.initRenderer(extend2({}, options2, options2.renderer, { + // allow custom renderer name to be re-used, otherwise use canvas + name: options2.renderer.name === "null" ? "canvas" : options2.renderer.name + })); + cy.startAnimationLoop(); + cy.style(options2.style); + cy.emit("mount"); + return cy; + }, + unmount: function unmount() { + var cy = this; + cy.stopAnimationLoop(); + cy.destroyRenderer(); + cy.initRenderer({ + name: "null" + }); + cy.emit("unmount"); + return cy; + }, + options: function options2() { + return copy2(this._private.options); + }, + json: function json2(obj) { + var cy = this; + var _p = cy._private; + var eles = cy.mutableElements(); + var getFreshRef = function getFreshRef2(ele) { + return cy.getElementById(ele.id()); + }; + if (plainObject(obj)) { + cy.startBatch(); + if (obj.elements) { + var idInJson = {}; + var updateEles = function updateEles2(jsons, gr2) { + var toAdd = []; + var toMod = []; + for (var i4 = 0; i4 < jsons.length; i4++) { + var json4 = jsons[i4]; + if (!json4.data.id) { + warn("cy.json() cannot handle elements without an ID attribute"); + continue; + } + var id2 = "" + json4.data.id; + var ele = cy.getElementById(id2); + idInJson[id2] = true; + if (ele.length !== 0) { + toMod.push({ + ele, + json: json4 + }); + } else { + if (gr2) { + json4.group = gr2; + toAdd.push(json4); + } else { + toAdd.push(json4); + } + } + } + cy.add(toAdd); + for (var _i6 = 0; _i6 < toMod.length; _i6++) { + var _toMod$_i = toMod[_i6], _ele = _toMod$_i.ele, _json = _toMod$_i.json; + _ele.json(_json); + } + }; + if (array2(obj.elements)) { + updateEles(obj.elements); + } else { + var grs = ["nodes", "edges"]; + for (var i3 = 0; i3 < grs.length; i3++) { + var gr = grs[i3]; + var elements2 = obj.elements[gr]; + if (array2(elements2)) { + updateEles(elements2, gr); + } + } + } + var parentsToRemove = cy.collection(); + eles.filter(function(ele) { + return !idInJson[ele.id()]; + }).forEach(function(ele) { + if (ele.isParent()) { + parentsToRemove.merge(ele); + } else { + ele.remove(); + } + }); + parentsToRemove.forEach(function(ele) { + return ele.children().move({ + parent: null + }); + }); + parentsToRemove.forEach(function(ele) { + return getFreshRef(ele).remove(); + }); + } + if (obj.style) { + cy.style(obj.style); + } + if (obj.zoom != null && obj.zoom !== _p.zoom) { + cy.zoom(obj.zoom); + } + if (obj.pan) { + if (obj.pan.x !== _p.pan.x || obj.pan.y !== _p.pan.y) { + cy.pan(obj.pan); + } + } + if (obj.data) { + cy.data(obj.data); + } + var fields = ["minZoom", "maxZoom", "zoomingEnabled", "userZoomingEnabled", "panningEnabled", "userPanningEnabled", "boxSelectionEnabled", "autolock", "autoungrabify", "autounselectify", "multiClickDebounceTime"]; + for (var _i22 = 0; _i22 < fields.length; _i22++) { + var f2 = fields[_i22]; + if (obj[f2] != null) { + cy[f2](obj[f2]); + } + } + cy.endBatch(); + return this; + } else { + var flat = !!obj; + var json3 = {}; + if (flat) { + json3.elements = this.elements().map(function(ele) { + return ele.json(); + }); + } else { + json3.elements = {}; + eles.forEach(function(ele) { + var group = ele.group(); + if (!json3.elements[group]) { + json3.elements[group] = []; + } + json3.elements[group].push(ele.json()); + }); + } + if (this._private.styleEnabled) { + json3.style = cy.style().json(); + } + json3.data = copy2(cy.data()); + var options2 = _p.options; + json3.zoomingEnabled = _p.zoomingEnabled; + json3.userZoomingEnabled = _p.userZoomingEnabled; + json3.zoom = _p.zoom; + json3.minZoom = _p.minZoom; + json3.maxZoom = _p.maxZoom; + json3.panningEnabled = _p.panningEnabled; + json3.userPanningEnabled = _p.userPanningEnabled; + json3.pan = copy2(_p.pan); + json3.boxSelectionEnabled = _p.boxSelectionEnabled; + json3.renderer = copy2(options2.renderer); + json3.hideEdgesOnViewport = options2.hideEdgesOnViewport; + json3.textureOnViewport = options2.textureOnViewport; + json3.wheelSensitivity = options2.wheelSensitivity; + json3.motionBlur = options2.motionBlur; + json3.multiClickDebounceTime = options2.multiClickDebounceTime; + return json3; + } + } + }); + corefn.$id = corefn.getElementById; + [corefn$9, corefn$8, elesfn, corefn$7, corefn$6, corefn$5, corefn$4, corefn$3, corefn$2, corefn$1, fn].forEach(function(props) { + extend2(corefn, props); + }); + var defaults$7 = { + fit: true, + // whether to fit the viewport to the graph + directed: false, + // whether the tree is directed downwards (or edges can point in any direction if false) + padding: 30, + // padding on fit + circle: false, + // put depths in concentric circles if true, put depths top down if false + grid: false, + // whether to create an even grid into which the DAG is placed (circle:false only) + spacingFactor: 1.75, + // positive spacing factor, larger => more space between nodes (N.B. n/a if causes overlap) + boundingBox: void 0, + // constrain layout bounds; { x1, y1, x2, y2 } or { x1, y1, w, h } + avoidOverlap: true, + // prevents node overlap, may overflow boundingBox if not enough space + nodeDimensionsIncludeLabels: false, + // Excludes the label when calculating node bounding boxes for the layout algorithm + roots: void 0, + // the roots of the trees + depthSort: void 0, + // a sorting function to order nodes at equal depth. e.g. function(a, b){ return a.data('weight') - b.data('weight') } + animate: false, + // whether to transition the node positions + animationDuration: 500, + // duration of animation in ms if enabled + animationEasing: void 0, + // easing of animation if enabled, + animateFilter: function animateFilter(node2, i3) { + return true; + }, + // a function that determines whether the node should be animated. All nodes animated by default on animate enabled. Non-animated nodes are positioned immediately when the layout starts + ready: void 0, + // callback on layoutready + stop: void 0, + // callback on layoutstop + transform: function transform(node2, position3) { + return position3; + } + // transform a given node position. Useful for changing flow direction in discrete layouts + }; + var deprecatedOptionDefaults = { + maximal: false, + // whether to shift nodes down their natural BFS depths in order to avoid upwards edges (DAGS only); setting acyclic to true sets maximal to true also + acyclic: false + // whether the tree is acyclic and thus a node could be shifted (due to the maximal option) multiple times without causing an infinite loop; setting to true sets maximal to true also; if you are uncertain whether a tree is acyclic, set to false to avoid potential infinite loops + }; + var getInfo2 = function getInfo3(ele) { + return ele.scratch("breadthfirst"); + }; + var setInfo2 = function setInfo3(ele, obj) { + return ele.scratch("breadthfirst", obj); + }; + function BreadthFirstLayout(options2) { + this.options = extend2({}, defaults$7, deprecatedOptionDefaults, options2); + } + BreadthFirstLayout.prototype.run = function() { + var params = this.options; + var options2 = params; + var cy = params.cy; + var eles = options2.eles; + var nodes2 = eles.nodes().filter(function(n2) { + return !n2.isParent(); + }); + var graph = eles; + var directed = options2.directed; + var maximal = options2.acyclic || options2.maximal || options2.maximalAdjustments > 0; + var bb = makeBoundingBox(options2.boundingBox ? options2.boundingBox : { + x1: 0, + y1: 0, + w: cy.width(), + h: cy.height() + }); + var roots; + if (elementOrCollection(options2.roots)) { + roots = options2.roots; + } else if (array2(options2.roots)) { + var rootsArray = []; + for (var i3 = 0; i3 < options2.roots.length; i3++) { + var id2 = options2.roots[i3]; + var ele = cy.getElementById(id2); + rootsArray.push(ele); + } + roots = cy.collection(rootsArray); + } else if (string2(options2.roots)) { + roots = cy.$(options2.roots); + } else { + if (directed) { + roots = nodes2.roots(); + } else { + var components = eles.components(); + roots = cy.collection(); + var _loop = function _loop2(_i9) { + var comp = components[_i9]; + var maxDegree = comp.maxDegree(false); + var compRoots = comp.filter(function(ele2) { + return ele2.degree(false) === maxDegree; + }); + roots = roots.add(compRoots); + }; + for (var _i6 = 0; _i6 < components.length; _i6++) { + _loop(_i6); + } + } + } + var depths = []; + var foundByBfs = {}; + var addToDepth = function addToDepth2(ele2, d) { + if (depths[d] == null) { + depths[d] = []; + } + var i4 = depths[d].length; + depths[d].push(ele2); + setInfo2(ele2, { + index: i4, + depth: d + }); + }; + var changeDepth = function changeDepth2(ele2, newDepth) { + var _getInfo = getInfo2(ele2), depth = _getInfo.depth, index2 = _getInfo.index; + depths[depth][index2] = null; + addToDepth(ele2, newDepth); + }; + graph.bfs({ + roots, + directed: options2.directed, + visit: function visit(node2, edge, pNode, i4, depth) { + var ele2 = node2[0]; + var id3 = ele2.id(); + addToDepth(ele2, depth); + foundByBfs[id3] = true; + } + }); + var orphanNodes = []; + for (var _i22 = 0; _i22 < nodes2.length; _i22++) { + var _ele = nodes2[_i22]; + if (foundByBfs[_ele.id()]) { + continue; + } else { + orphanNodes.push(_ele); + } + } + var assignDepthsAt = function assignDepthsAt2(i4) { + var eles2 = depths[i4]; + for (var j = 0; j < eles2.length; j++) { + var _ele2 = eles2[j]; + if (_ele2 == null) { + eles2.splice(j, 1); + j--; + continue; + } + setInfo2(_ele2, { + depth: i4, + index: j + }); + } + }; + var assignDepths = function assignDepths2() { + for (var _i32 = 0; _i32 < depths.length; _i32++) { + assignDepthsAt(_i32); + } + }; + var adjustMaximally = function adjustMaximally2(ele2, shifted2) { + var eInfo = getInfo2(ele2); + var incomers = ele2.incomers().filter(function(el) { + return el.isNode() && eles.has(el); + }); + var maxDepth = -1; + var id3 = ele2.id(); + for (var k = 0; k < incomers.length; k++) { + var incmr = incomers[k]; + var iInfo = getInfo2(incmr); + maxDepth = Math.max(maxDepth, iInfo.depth); + } + if (eInfo.depth <= maxDepth) { + if (!options2.acyclic && shifted2[id3]) { + return null; + } + var newDepth = maxDepth + 1; + changeDepth(ele2, newDepth); + shifted2[id3] = newDepth; + return true; + } + return false; + }; + if (directed && maximal) { + var Q = []; + var shifted = {}; + var enqueue = function enqueue2(n2) { + return Q.push(n2); + }; + var dequeue = function dequeue2() { + return Q.shift(); + }; + nodes2.forEach(function(n2) { + return Q.push(n2); + }); + while (Q.length > 0) { + var _ele3 = dequeue(); + var didShift = adjustMaximally(_ele3, shifted); + if (didShift) { + _ele3.outgoers().filter(function(el) { + return el.isNode() && eles.has(el); + }).forEach(enqueue); + } else if (didShift === null) { + warn("Detected double maximal shift for node `" + _ele3.id() + "`. Bailing maximal adjustment due to cycle. Use `options.maximal: true` only on DAGs."); + break; + } + } + } + assignDepths(); + var minDistance = 0; + if (options2.avoidOverlap) { + for (var _i42 = 0; _i42 < nodes2.length; _i42++) { + var n = nodes2[_i42]; + var nbb = n.layoutDimensions(options2); + var w2 = nbb.w; + var h = nbb.h; + minDistance = Math.max(minDistance, w2, h); + } + } + var cachedWeightedPercent = {}; + var getWeightedPercent = function getWeightedPercent2(ele2) { + if (cachedWeightedPercent[ele2.id()]) { + return cachedWeightedPercent[ele2.id()]; + } + var eleDepth = getInfo2(ele2).depth; + var neighbors = ele2.neighborhood(); + var percent = 0; + var samples = 0; + for (var _i52 = 0; _i52 < neighbors.length; _i52++) { + var neighbor = neighbors[_i52]; + if (neighbor.isEdge() || neighbor.isParent() || !nodes2.has(neighbor)) { + continue; + } + var bf = getInfo2(neighbor); + if (bf == null) { + continue; + } + var index2 = bf.index; + var depth = bf.depth; + if (index2 == null || depth == null) { + continue; + } + var nDepth = depths[depth].length; + if (depth < eleDepth) { + percent += index2 / nDepth; + samples++; + } + } + samples = Math.max(1, samples); + percent = percent / samples; + if (samples === 0) { + percent = 0; + } + cachedWeightedPercent[ele2.id()] = percent; + return percent; + }; + var sortFn = function sortFn2(a, b) { + var apct = getWeightedPercent(a); + var bpct = getWeightedPercent(b); + var diff = apct - bpct; + if (diff === 0) { + return ascending2(a.id(), b.id()); + } else { + return diff; + } + }; + if (options2.depthSort !== void 0) { + sortFn = options2.depthSort; + } + for (var _i62 = 0; _i62 < depths.length; _i62++) { + depths[_i62].sort(sortFn); + assignDepthsAt(_i62); + } + var orphanDepth = []; + for (var _i7 = 0; _i7 < orphanNodes.length; _i7++) { + orphanDepth.push(orphanNodes[_i7]); + } + depths.unshift(orphanDepth); + assignDepths(); + var biggestDepthSize = 0; + for (var _i8 = 0; _i8 < depths.length; _i8++) { + biggestDepthSize = Math.max(depths[_i8].length, biggestDepthSize); + } + var center2 = { + x: bb.x1 + bb.w / 2, + y: bb.x1 + bb.h / 2 + }; + var maxDepthSize = depths.reduce(function(max3, eles2) { + return Math.max(max3, eles2.length); + }, 0); + var getPosition = function getPosition2(ele2) { + var _getInfo2 = getInfo2(ele2), depth = _getInfo2.depth, index2 = _getInfo2.index; + var depthSize = depths[depth].length; + var distanceX = Math.max(bb.w / ((options2.grid ? maxDepthSize : depthSize) + 1), minDistance); + var distanceY = Math.max(bb.h / (depths.length + 1), minDistance); + var radiusStepSize = Math.min(bb.w / 2 / depths.length, bb.h / 2 / depths.length); + radiusStepSize = Math.max(radiusStepSize, minDistance); + if (!options2.circle) { + var epos = { + x: center2.x + (index2 + 1 - (depthSize + 1) / 2) * distanceX, + y: (depth + 1) * distanceY + }; + return epos; + } else { + var radius = radiusStepSize * depth + radiusStepSize - (depths.length > 0 && depths[0].length <= 3 ? radiusStepSize / 2 : 0); + var theta = 2 * Math.PI / depths[depth].length * index2; + if (depth === 0 && depths[0].length === 1) { + radius = 1; + } + return { + x: center2.x + radius * Math.cos(theta), + y: center2.y + radius * Math.sin(theta) + }; + } + }; + eles.nodes().layoutPositions(this, options2, getPosition); + return this; + }; + var defaults$6 = { + fit: true, + // whether to fit the viewport to the graph + padding: 30, + // the padding on fit + boundingBox: void 0, + // constrain layout bounds; { x1, y1, x2, y2 } or { x1, y1, w, h } + avoidOverlap: true, + // prevents node overlap, may overflow boundingBox and radius if not enough space + nodeDimensionsIncludeLabels: false, + // Excludes the label when calculating node bounding boxes for the layout algorithm + spacingFactor: void 0, + // Applies a multiplicative factor (>0) to expand or compress the overall area that the nodes take up + radius: void 0, + // the radius of the circle + startAngle: 3 / 2 * Math.PI, + // where nodes start in radians + sweep: void 0, + // how many radians should be between the first and last node (defaults to full circle) + clockwise: true, + // whether the layout should go clockwise (true) or counterclockwise/anticlockwise (false) + sort: void 0, + // a sorting function to order the nodes; e.g. function(a, b){ return a.data('weight') - b.data('weight') } + animate: false, + // whether to transition the node positions + animationDuration: 500, + // duration of animation in ms if enabled + animationEasing: void 0, + // easing of animation if enabled + animateFilter: function animateFilter(node2, i3) { + return true; + }, + // a function that determines whether the node should be animated. All nodes animated by default on animate enabled. Non-animated nodes are positioned immediately when the layout starts + ready: void 0, + // callback on layoutready + stop: void 0, + // callback on layoutstop + transform: function transform(node2, position3) { + return position3; + } + // transform a given node position. Useful for changing flow direction in discrete layouts + }; + function CircleLayout(options2) { + this.options = extend2({}, defaults$6, options2); + } + CircleLayout.prototype.run = function() { + var params = this.options; + var options2 = params; + var cy = params.cy; + var eles = options2.eles; + var clockwise = options2.counterclockwise !== void 0 ? !options2.counterclockwise : options2.clockwise; + var nodes2 = eles.nodes().not(":parent"); + if (options2.sort) { + nodes2 = nodes2.sort(options2.sort); + } + var bb = makeBoundingBox(options2.boundingBox ? options2.boundingBox : { + x1: 0, + y1: 0, + w: cy.width(), + h: cy.height() + }); + var center2 = { + x: bb.x1 + bb.w / 2, + y: bb.y1 + bb.h / 2 + }; + var sweep = options2.sweep === void 0 ? 2 * Math.PI - 2 * Math.PI / nodes2.length : options2.sweep; + var dTheta = sweep / Math.max(1, nodes2.length - 1); + var r; + var minDistance = 0; + for (var i3 = 0; i3 < nodes2.length; i3++) { + var n = nodes2[i3]; + var nbb = n.layoutDimensions(options2); + var w2 = nbb.w; + var h = nbb.h; + minDistance = Math.max(minDistance, w2, h); + } + if (number$12(options2.radius)) { + r = options2.radius; + } else if (nodes2.length <= 1) { + r = 0; + } else { + r = Math.min(bb.h, bb.w) / 2 - minDistance; + } + if (nodes2.length > 1 && options2.avoidOverlap) { + minDistance *= 1.75; + var dcos = Math.cos(dTheta) - Math.cos(0); + var dsin = Math.sin(dTheta) - Math.sin(0); + var rMin = Math.sqrt(minDistance * minDistance / (dcos * dcos + dsin * dsin)); + r = Math.max(rMin, r); + } + var getPos = function getPos2(ele, i4) { + var theta = options2.startAngle + i4 * dTheta * (clockwise ? 1 : -1); + var rx = r * Math.cos(theta); + var ry = r * Math.sin(theta); + var pos = { + x: center2.x + rx, + y: center2.y + ry + }; + return pos; + }; + eles.nodes().layoutPositions(this, options2, getPos); + return this; + }; + var defaults$5 = { + fit: true, + // whether to fit the viewport to the graph + padding: 30, + // the padding on fit + startAngle: 3 / 2 * Math.PI, + // where nodes start in radians + sweep: void 0, + // how many radians should be between the first and last node (defaults to full circle) + clockwise: true, + // whether the layout should go clockwise (true) or counterclockwise/anticlockwise (false) + equidistant: false, + // whether levels have an equal radial distance betwen them, may cause bounding box overflow + minNodeSpacing: 10, + // min spacing between outside of nodes (used for radius adjustment) + boundingBox: void 0, + // constrain layout bounds; { x1, y1, x2, y2 } or { x1, y1, w, h } + avoidOverlap: true, + // prevents node overlap, may overflow boundingBox if not enough space + nodeDimensionsIncludeLabels: false, + // Excludes the label when calculating node bounding boxes for the layout algorithm + height: void 0, + // height of layout area (overrides container height) + width: void 0, + // width of layout area (overrides container width) + spacingFactor: void 0, + // Applies a multiplicative factor (>0) to expand or compress the overall area that the nodes take up + concentric: function concentric(node2) { + return node2.degree(); + }, + levelWidth: function levelWidth(nodes2) { + return nodes2.maxDegree() / 4; + }, + animate: false, + // whether to transition the node positions + animationDuration: 500, + // duration of animation in ms if enabled + animationEasing: void 0, + // easing of animation if enabled + animateFilter: function animateFilter(node2, i3) { + return true; + }, + // a function that determines whether the node should be animated. All nodes animated by default on animate enabled. Non-animated nodes are positioned immediately when the layout starts + ready: void 0, + // callback on layoutready + stop: void 0, + // callback on layoutstop + transform: function transform(node2, position3) { + return position3; + } + // transform a given node position. Useful for changing flow direction in discrete layouts + }; + function ConcentricLayout(options2) { + this.options = extend2({}, defaults$5, options2); + } + ConcentricLayout.prototype.run = function() { + var params = this.options; + var options2 = params; + var clockwise = options2.counterclockwise !== void 0 ? !options2.counterclockwise : options2.clockwise; + var cy = params.cy; + var eles = options2.eles; + var nodes2 = eles.nodes().not(":parent"); + var bb = makeBoundingBox(options2.boundingBox ? options2.boundingBox : { + x1: 0, + y1: 0, + w: cy.width(), + h: cy.height() + }); + var center2 = { + x: bb.x1 + bb.w / 2, + y: bb.y1 + bb.h / 2 + }; + var nodeValues = []; + var maxNodeSize = 0; + for (var i3 = 0; i3 < nodes2.length; i3++) { + var node2 = nodes2[i3]; + var value2 = void 0; + value2 = options2.concentric(node2); + nodeValues.push({ + value: value2, + node: node2 + }); + node2._private.scratch.concentric = value2; + } + nodes2.updateStyle(); + for (var _i6 = 0; _i6 < nodes2.length; _i6++) { + var _node = nodes2[_i6]; + var nbb = _node.layoutDimensions(options2); + maxNodeSize = Math.max(maxNodeSize, nbb.w, nbb.h); + } + nodeValues.sort(function(a, b) { + return b.value - a.value; + }); + var levelWidth = options2.levelWidth(nodes2); + var levels = [[]]; + var currentLevel = levels[0]; + for (var _i22 = 0; _i22 < nodeValues.length; _i22++) { + var val = nodeValues[_i22]; + if (currentLevel.length > 0) { + var diff = Math.abs(currentLevel[0].value - val.value); + if (diff >= levelWidth) { + currentLevel = []; + levels.push(currentLevel); + } + } + currentLevel.push(val); + } + var minDist = maxNodeSize + options2.minNodeSpacing; + if (!options2.avoidOverlap) { + var firstLvlHasMulti = levels.length > 0 && levels[0].length > 1; + var maxR = Math.min(bb.w, bb.h) / 2 - minDist; + var rStep = maxR / (levels.length + firstLvlHasMulti ? 1 : 0); + minDist = Math.min(minDist, rStep); + } + var r = 0; + for (var _i32 = 0; _i32 < levels.length; _i32++) { + var level = levels[_i32]; + var sweep = options2.sweep === void 0 ? 2 * Math.PI - 2 * Math.PI / level.length : options2.sweep; + var dTheta = level.dTheta = sweep / Math.max(1, level.length - 1); + if (level.length > 1 && options2.avoidOverlap) { + var dcos = Math.cos(dTheta) - Math.cos(0); + var dsin = Math.sin(dTheta) - Math.sin(0); + var rMin = Math.sqrt(minDist * minDist / (dcos * dcos + dsin * dsin)); + r = Math.max(rMin, r); + } + level.r = r; + r += minDist; + } + if (options2.equidistant) { + var rDeltaMax = 0; + var _r = 0; + for (var _i42 = 0; _i42 < levels.length; _i42++) { + var _level = levels[_i42]; + var rDelta = _level.r - _r; + rDeltaMax = Math.max(rDeltaMax, rDelta); + } + _r = 0; + for (var _i52 = 0; _i52 < levels.length; _i52++) { + var _level2 = levels[_i52]; + if (_i52 === 0) { + _r = _level2.r; + } + _level2.r = _r; + _r += rDeltaMax; + } + } + var pos = {}; + for (var _i62 = 0; _i62 < levels.length; _i62++) { + var _level3 = levels[_i62]; + var _dTheta = _level3.dTheta; + var _r2 = _level3.r; + for (var j = 0; j < _level3.length; j++) { + var _val = _level3[j]; + var theta = options2.startAngle + (clockwise ? 1 : -1) * _dTheta * j; + var p2 = { + x: center2.x + _r2 * Math.cos(theta), + y: center2.y + _r2 * Math.sin(theta) + }; + pos[_val.node.id()] = p2; + } + } + eles.nodes().layoutPositions(this, options2, function(ele) { + var id2 = ele.id(); + return pos[id2]; + }); + return this; + }; + var DEBUG; + var defaults$4 = { + // Called on `layoutready` + ready: function ready() { + }, + // Called on `layoutstop` + stop: function stop() { + }, + // Whether to animate while running the layout + // true : Animate continuously as the layout is running + // false : Just show the end result + // 'end' : Animate with the end result, from the initial positions to the end positions + animate: true, + // Easing of the animation for animate:'end' + animationEasing: void 0, + // The duration of the animation for animate:'end' + animationDuration: void 0, + // A function that determines whether the node should be animated + // All nodes animated by default on animate enabled + // Non-animated nodes are positioned immediately when the layout starts + animateFilter: function animateFilter(node2, i3) { + return true; + }, + // The layout animates only after this many milliseconds for animate:true + // (prevents flashing on fast runs) + animationThreshold: 250, + // Number of iterations between consecutive screen positions update + refresh: 20, + // Whether to fit the network view after when done + fit: true, + // Padding on fit + padding: 30, + // Constrain layout bounds; { x1, y1, x2, y2 } or { x1, y1, w, h } + boundingBox: void 0, + // Excludes the label when calculating node bounding boxes for the layout algorithm + nodeDimensionsIncludeLabels: false, + // Randomize the initial positions of the nodes (true) or use existing positions (false) + randomize: false, + // Extra spacing between components in non-compound graphs + componentSpacing: 40, + // Node repulsion (non overlapping) multiplier + nodeRepulsion: function nodeRepulsion2(node2) { + return 2048; + }, + // Node repulsion (overlapping) multiplier + nodeOverlap: 4, + // Ideal edge (non nested) length + idealEdgeLength: function idealEdgeLength(edge) { + return 32; + }, + // Divisor to compute edge forces + edgeElasticity: function edgeElasticity(edge) { + return 32; + }, + // Nesting factor (multiplier) to compute ideal edge length for nested edges + nestingFactor: 1.2, + // Gravity force (constant) + gravity: 1, + // Maximum number of iterations to perform + numIter: 1e3, + // Initial temperature (maximum node displacement) + initialTemp: 1e3, + // Cooling factor (how the temperature is reduced between consecutive iterations + coolingFactor: 0.99, + // Lower temperature threshold (below this point the layout will end) + minTemp: 1 + }; + function CoseLayout(options2) { + this.options = extend2({}, defaults$4, options2); + this.options.layout = this; + var nodes2 = this.options.eles.nodes(); + var edges2 = this.options.eles.edges(); + var notEdges = edges2.filter(function(e) { + var sourceId = e.source().data("id"); + var targetId = e.target().data("id"); + var hasSource = nodes2.some(function(n) { + return n.data("id") === sourceId; + }); + var hasTarget = nodes2.some(function(n) { + return n.data("id") === targetId; + }); + return !hasSource || !hasTarget; + }); + this.options.eles = this.options.eles.not(notEdges); + } + CoseLayout.prototype.run = function() { + var options2 = this.options; + var cy = options2.cy; + var layout3 = this; + layout3.stopped = false; + if (options2.animate === true || options2.animate === false) { + layout3.emit({ + type: "layoutstart", + layout: layout3 + }); + } + if (true === options2.debug) { + DEBUG = true; + } else { + DEBUG = false; + } + var layoutInfo = createLayoutInfo(cy, layout3, options2); + if (DEBUG) { + printLayoutInfo(layoutInfo); + } + if (options2.randomize) { + randomizePositions(layoutInfo); + } + var startTime = performanceNow(); + var refresh = function refresh2() { + refreshPositions(layoutInfo, cy, options2); + if (true === options2.fit) { + cy.fit(options2.padding); + } + }; + var mainLoop = function mainLoop2(i4) { + if (layout3.stopped || i4 >= options2.numIter) { + return false; + } + step(layoutInfo, options2); + layoutInfo.temperature = layoutInfo.temperature * options2.coolingFactor; + if (layoutInfo.temperature < options2.minTemp) { + return false; + } + return true; + }; + var done = function done2() { + if (options2.animate === true || options2.animate === false) { + refresh(); + layout3.one("layoutstop", options2.stop); + layout3.emit({ + type: "layoutstop", + layout: layout3 + }); + } else { + var nodes2 = options2.eles.nodes(); + var getScaledPos = getScaleInBoundsFn(layoutInfo, options2, nodes2); + nodes2.layoutPositions(layout3, options2, getScaledPos); + } + }; + var i3 = 0; + var loopRet = true; + if (options2.animate === true) { + var frame2 = function frame3() { + var f2 = 0; + while (loopRet && f2 < options2.refresh) { + loopRet = mainLoop(i3); + i3++; + f2++; + } + if (!loopRet) { + separateComponents(layoutInfo, options2); + done(); + } else { + var now3 = performanceNow(); + if (now3 - startTime >= options2.animationThreshold) { + refresh(); + } + requestAnimationFrame2(frame3); + } + }; + frame2(); + } else { + while (loopRet) { + loopRet = mainLoop(i3); + i3++; + } + separateComponents(layoutInfo, options2); + done(); + } + return this; + }; + CoseLayout.prototype.stop = function() { + this.stopped = true; + if (this.thread) { + this.thread.stop(); + } + this.emit("layoutstop"); + return this; + }; + CoseLayout.prototype.destroy = function() { + if (this.thread) { + this.thread.stop(); + } + return this; + }; + var createLayoutInfo = function createLayoutInfo2(cy, layout3, options2) { + var edges2 = options2.eles.edges(); + var nodes2 = options2.eles.nodes(); + var bb = makeBoundingBox(options2.boundingBox ? options2.boundingBox : { + x1: 0, + y1: 0, + w: cy.width(), + h: cy.height() + }); + var layoutInfo = { + isCompound: cy.hasCompoundNodes(), + layoutNodes: [], + idToIndex: {}, + nodeSize: nodes2.size(), + graphSet: [], + indexToGraph: [], + layoutEdges: [], + edgeSize: edges2.size(), + temperature: options2.initialTemp, + clientWidth: bb.w, + clientHeight: bb.h, + boundingBox: bb + }; + var components = options2.eles.components(); + var id2cmptId = {}; + for (var i3 = 0; i3 < components.length; i3++) { + var component = components[i3]; + for (var j = 0; j < component.length; j++) { + var node2 = component[j]; + id2cmptId[node2.id()] = i3; + } + } + for (var i3 = 0; i3 < layoutInfo.nodeSize; i3++) { + var n = nodes2[i3]; + var nbb = n.layoutDimensions(options2); + var tempNode = {}; + tempNode.isLocked = n.locked(); + tempNode.id = n.data("id"); + tempNode.parentId = n.data("parent"); + tempNode.cmptId = id2cmptId[n.id()]; + tempNode.children = []; + tempNode.positionX = n.position("x"); + tempNode.positionY = n.position("y"); + tempNode.offsetX = 0; + tempNode.offsetY = 0; + tempNode.height = nbb.w; + tempNode.width = nbb.h; + tempNode.maxX = tempNode.positionX + tempNode.width / 2; + tempNode.minX = tempNode.positionX - tempNode.width / 2; + tempNode.maxY = tempNode.positionY + tempNode.height / 2; + tempNode.minY = tempNode.positionY - tempNode.height / 2; + tempNode.padLeft = parseFloat(n.style("padding")); + tempNode.padRight = parseFloat(n.style("padding")); + tempNode.padTop = parseFloat(n.style("padding")); + tempNode.padBottom = parseFloat(n.style("padding")); + tempNode.nodeRepulsion = fn$6(options2.nodeRepulsion) ? options2.nodeRepulsion(n) : options2.nodeRepulsion; + layoutInfo.layoutNodes.push(tempNode); + layoutInfo.idToIndex[tempNode.id] = i3; + } + var queue = []; + var start2 = 0; + var end2 = -1; + var tempGraph = []; + for (var i3 = 0; i3 < layoutInfo.nodeSize; i3++) { + var n = layoutInfo.layoutNodes[i3]; + var p_id = n.parentId; + if (null != p_id) { + layoutInfo.layoutNodes[layoutInfo.idToIndex[p_id]].children.push(n.id); + } else { + queue[++end2] = n.id; + tempGraph.push(n.id); + } + } + layoutInfo.graphSet.push(tempGraph); + while (start2 <= end2) { + var node_id = queue[start2++]; + var node_ix = layoutInfo.idToIndex[node_id]; + var node2 = layoutInfo.layoutNodes[node_ix]; + var children2 = node2.children; + if (children2.length > 0) { + layoutInfo.graphSet.push(children2); + for (var i3 = 0; i3 < children2.length; i3++) { + queue[++end2] = children2[i3]; + } + } + } + for (var i3 = 0; i3 < layoutInfo.graphSet.length; i3++) { + var graph = layoutInfo.graphSet[i3]; + for (var j = 0; j < graph.length; j++) { + var index2 = layoutInfo.idToIndex[graph[j]]; + layoutInfo.indexToGraph[index2] = i3; + } + } + for (var i3 = 0; i3 < layoutInfo.edgeSize; i3++) { + var e = edges2[i3]; + var tempEdge = {}; + tempEdge.id = e.data("id"); + tempEdge.sourceId = e.data("source"); + tempEdge.targetId = e.data("target"); + var idealLength = fn$6(options2.idealEdgeLength) ? options2.idealEdgeLength(e) : options2.idealEdgeLength; + var elasticity = fn$6(options2.edgeElasticity) ? options2.edgeElasticity(e) : options2.edgeElasticity; + var sourceIx = layoutInfo.idToIndex[tempEdge.sourceId]; + var targetIx = layoutInfo.idToIndex[tempEdge.targetId]; + var sourceGraph = layoutInfo.indexToGraph[sourceIx]; + var targetGraph = layoutInfo.indexToGraph[targetIx]; + if (sourceGraph != targetGraph) { + var lca = findLCA(tempEdge.sourceId, tempEdge.targetId, layoutInfo); + var lcaGraph = layoutInfo.graphSet[lca]; + var depth = 0; + var tempNode = layoutInfo.layoutNodes[sourceIx]; + while (-1 === lcaGraph.indexOf(tempNode.id)) { + tempNode = layoutInfo.layoutNodes[layoutInfo.idToIndex[tempNode.parentId]]; + depth++; + } + tempNode = layoutInfo.layoutNodes[targetIx]; + while (-1 === lcaGraph.indexOf(tempNode.id)) { + tempNode = layoutInfo.layoutNodes[layoutInfo.idToIndex[tempNode.parentId]]; + depth++; + } + idealLength *= depth * options2.nestingFactor; + } + tempEdge.idealLength = idealLength; + tempEdge.elasticity = elasticity; + layoutInfo.layoutEdges.push(tempEdge); + } + return layoutInfo; + }; + var findLCA = function findLCA2(node1, node2, layoutInfo) { + var res = findLCA_aux(node1, node2, 0, layoutInfo); + if (2 > res.count) { + return 0; + } else { + return res.graph; + } + }; + var findLCA_aux = function findLCA_aux2(node1, node2, graphIx, layoutInfo) { + var graph = layoutInfo.graphSet[graphIx]; + if (-1 < graph.indexOf(node1) && -1 < graph.indexOf(node2)) { + return { + count: 2, + graph: graphIx + }; + } + var c2 = 0; + for (var i3 = 0; i3 < graph.length; i3++) { + var nodeId = graph[i3]; + var nodeIx = layoutInfo.idToIndex[nodeId]; + var children2 = layoutInfo.layoutNodes[nodeIx].children; + if (0 === children2.length) { + continue; + } + var childGraphIx = layoutInfo.indexToGraph[layoutInfo.idToIndex[children2[0]]]; + var result = findLCA_aux2(node1, node2, childGraphIx, layoutInfo); + if (0 === result.count) { + continue; + } else if (1 === result.count) { + c2++; + if (2 === c2) { + break; + } + } else { + return result; + } + } + return { + count: c2, + graph: graphIx + }; + }; + var printLayoutInfo; + var randomizePositions = function randomizePositions2(layoutInfo, cy) { + var width2 = layoutInfo.clientWidth; + var height = layoutInfo.clientHeight; + for (var i3 = 0; i3 < layoutInfo.nodeSize; i3++) { + var n = layoutInfo.layoutNodes[i3]; + if (0 === n.children.length && !n.isLocked) { + n.positionX = Math.random() * width2; + n.positionY = Math.random() * height; + } + } + }; + var getScaleInBoundsFn = function getScaleInBoundsFn2(layoutInfo, options2, nodes2) { + var bb = layoutInfo.boundingBox; + var coseBB = { + x1: Infinity, + x2: -Infinity, + y1: Infinity, + y2: -Infinity + }; + if (options2.boundingBox) { + nodes2.forEach(function(node2) { + var lnode = layoutInfo.layoutNodes[layoutInfo.idToIndex[node2.data("id")]]; + coseBB.x1 = Math.min(coseBB.x1, lnode.positionX); + coseBB.x2 = Math.max(coseBB.x2, lnode.positionX); + coseBB.y1 = Math.min(coseBB.y1, lnode.positionY); + coseBB.y2 = Math.max(coseBB.y2, lnode.positionY); + }); + coseBB.w = coseBB.x2 - coseBB.x1; + coseBB.h = coseBB.y2 - coseBB.y1; + } + return function(ele, i3) { + var lnode = layoutInfo.layoutNodes[layoutInfo.idToIndex[ele.data("id")]]; + if (options2.boundingBox) { + var pctX = (lnode.positionX - coseBB.x1) / coseBB.w; + var pctY = (lnode.positionY - coseBB.y1) / coseBB.h; + return { + x: bb.x1 + pctX * bb.w, + y: bb.y1 + pctY * bb.h + }; + } else { + return { + x: lnode.positionX, + y: lnode.positionY + }; + } + }; + }; + var refreshPositions = function refreshPositions2(layoutInfo, cy, options2) { + var layout3 = options2.layout; + var nodes2 = options2.eles.nodes(); + var getScaledPos = getScaleInBoundsFn(layoutInfo, options2, nodes2); + nodes2.positions(getScaledPos); + if (true !== layoutInfo.ready) { + layoutInfo.ready = true; + layout3.one("layoutready", options2.ready); + layout3.emit({ + type: "layoutready", + layout: this + }); + } + }; + var step = function step2(layoutInfo, options2, _step) { + calculateNodeForces(layoutInfo, options2); + calculateEdgeForces(layoutInfo); + calculateGravityForces(layoutInfo, options2); + propagateForces(layoutInfo); + updatePositions(layoutInfo); + }; + var calculateNodeForces = function calculateNodeForces2(layoutInfo, options2) { + for (var i3 = 0; i3 < layoutInfo.graphSet.length; i3++) { + var graph = layoutInfo.graphSet[i3]; + var numNodes = graph.length; + for (var j = 0; j < numNodes; j++) { + var node1 = layoutInfo.layoutNodes[layoutInfo.idToIndex[graph[j]]]; + for (var k = j + 1; k < numNodes; k++) { + var node2 = layoutInfo.layoutNodes[layoutInfo.idToIndex[graph[k]]]; + nodeRepulsion(node1, node2, layoutInfo, options2); + } + } + } + }; + var randomDistance = function randomDistance2(max3) { + return -max3 + 2 * max3 * Math.random(); + }; + var nodeRepulsion = function nodeRepulsion2(node1, node2, layoutInfo, options2) { + var cmptId1 = node1.cmptId; + var cmptId2 = node2.cmptId; + if (cmptId1 !== cmptId2 && !layoutInfo.isCompound) { + return; + } + var directionX = node2.positionX - node1.positionX; + var directionY = node2.positionY - node1.positionY; + var maxRandDist = 1; + if (0 === directionX && 0 === directionY) { + directionX = randomDistance(maxRandDist); + directionY = randomDistance(maxRandDist); + } + var overlap = nodesOverlap(node1, node2, directionX, directionY); + if (overlap > 0) { + var force = options2.nodeOverlap * overlap; + var distance2 = Math.sqrt(directionX * directionX + directionY * directionY); + var forceX = force * directionX / distance2; + var forceY = force * directionY / distance2; + } else { + var point1 = findClippingPoint(node1, directionX, directionY); + var point2 = findClippingPoint(node2, -1 * directionX, -1 * directionY); + var distanceX = point2.x - point1.x; + var distanceY = point2.y - point1.y; + var distanceSqr = distanceX * distanceX + distanceY * distanceY; + var distance2 = Math.sqrt(distanceSqr); + var force = (node1.nodeRepulsion + node2.nodeRepulsion) / distanceSqr; + var forceX = force * distanceX / distance2; + var forceY = force * distanceY / distance2; + } + if (!node1.isLocked) { + node1.offsetX -= forceX; + node1.offsetY -= forceY; + } + if (!node2.isLocked) { + node2.offsetX += forceX; + node2.offsetY += forceY; + } + return; + }; + var nodesOverlap = function nodesOverlap2(node1, node2, dX, dY) { + if (dX > 0) { + var overlapX = node1.maxX - node2.minX; + } else { + var overlapX = node2.maxX - node1.minX; + } + if (dY > 0) { + var overlapY = node1.maxY - node2.minY; + } else { + var overlapY = node2.maxY - node1.minY; + } + if (overlapX >= 0 && overlapY >= 0) { + return Math.sqrt(overlapX * overlapX + overlapY * overlapY); + } else { + return 0; + } + }; + var findClippingPoint = function findClippingPoint2(node2, dX, dY) { + var X = node2.positionX; + var Y = node2.positionY; + var H = node2.height || 1; + var W = node2.width || 1; + var dirSlope = dY / dX; + var nodeSlope = H / W; + var res = {}; + if (0 === dX && 0 < dY) { + res.x = X; + res.y = Y + H / 2; + return res; + } + if (0 === dX && 0 > dY) { + res.x = X; + res.y = Y + H / 2; + return res; + } + if (0 < dX && -1 * nodeSlope <= dirSlope && dirSlope <= nodeSlope) { + res.x = X + W / 2; + res.y = Y + W * dY / 2 / dX; + return res; + } + if (0 > dX && -1 * nodeSlope <= dirSlope && dirSlope <= nodeSlope) { + res.x = X - W / 2; + res.y = Y - W * dY / 2 / dX; + return res; + } + if (0 < dY && (dirSlope <= -1 * nodeSlope || dirSlope >= nodeSlope)) { + res.x = X + H * dX / 2 / dY; + res.y = Y + H / 2; + return res; + } + if (0 > dY && (dirSlope <= -1 * nodeSlope || dirSlope >= nodeSlope)) { + res.x = X - H * dX / 2 / dY; + res.y = Y - H / 2; + return res; + } + return res; + }; + var calculateEdgeForces = function calculateEdgeForces2(layoutInfo, options2) { + for (var i3 = 0; i3 < layoutInfo.edgeSize; i3++) { + var edge = layoutInfo.layoutEdges[i3]; + var sourceIx = layoutInfo.idToIndex[edge.sourceId]; + var source = layoutInfo.layoutNodes[sourceIx]; + var targetIx = layoutInfo.idToIndex[edge.targetId]; + var target = layoutInfo.layoutNodes[targetIx]; + var directionX = target.positionX - source.positionX; + var directionY = target.positionY - source.positionY; + if (0 === directionX && 0 === directionY) { + continue; + } + var point1 = findClippingPoint(source, directionX, directionY); + var point2 = findClippingPoint(target, -1 * directionX, -1 * directionY); + var lx = point2.x - point1.x; + var ly = point2.y - point1.y; + var l = Math.sqrt(lx * lx + ly * ly); + var force = Math.pow(edge.idealLength - l, 2) / edge.elasticity; + if (0 !== l) { + var forceX = force * lx / l; + var forceY = force * ly / l; + } else { + var forceX = 0; + var forceY = 0; + } + if (!source.isLocked) { + source.offsetX += forceX; + source.offsetY += forceY; + } + if (!target.isLocked) { + target.offsetX -= forceX; + target.offsetY -= forceY; + } + } + }; + var calculateGravityForces = function calculateGravityForces2(layoutInfo, options2) { + if (options2.gravity === 0) { + return; + } + var distThreshold = 1; + for (var i3 = 0; i3 < layoutInfo.graphSet.length; i3++) { + var graph = layoutInfo.graphSet[i3]; + var numNodes = graph.length; + if (0 === i3) { + var centerX = layoutInfo.clientHeight / 2; + var centerY = layoutInfo.clientWidth / 2; + } else { + var temp = layoutInfo.layoutNodes[layoutInfo.idToIndex[graph[0]]]; + var parent = layoutInfo.layoutNodes[layoutInfo.idToIndex[temp.parentId]]; + var centerX = parent.positionX; + var centerY = parent.positionY; + } + for (var j = 0; j < numNodes; j++) { + var node2 = layoutInfo.layoutNodes[layoutInfo.idToIndex[graph[j]]]; + if (node2.isLocked) { + continue; + } + var dx = centerX - node2.positionX; + var dy = centerY - node2.positionY; + var d = Math.sqrt(dx * dx + dy * dy); + if (d > distThreshold) { + var fx = options2.gravity * dx / d; + var fy = options2.gravity * dy / d; + node2.offsetX += fx; + node2.offsetY += fy; + } + } + } + }; + var propagateForces = function propagateForces2(layoutInfo, options2) { + var queue = []; + var start2 = 0; + var end2 = -1; + queue.push.apply(queue, layoutInfo.graphSet[0]); + end2 += layoutInfo.graphSet[0].length; + while (start2 <= end2) { + var nodeId = queue[start2++]; + var nodeIndex = layoutInfo.idToIndex[nodeId]; + var node2 = layoutInfo.layoutNodes[nodeIndex]; + var children2 = node2.children; + if (0 < children2.length && !node2.isLocked) { + var offX = node2.offsetX; + var offY = node2.offsetY; + for (var i3 = 0; i3 < children2.length; i3++) { + var childNode = layoutInfo.layoutNodes[layoutInfo.idToIndex[children2[i3]]]; + childNode.offsetX += offX; + childNode.offsetY += offY; + queue[++end2] = children2[i3]; + } + node2.offsetX = 0; + node2.offsetY = 0; + } + } + }; + var updatePositions = function updatePositions2(layoutInfo, options2) { + for (var i3 = 0; i3 < layoutInfo.nodeSize; i3++) { + var n = layoutInfo.layoutNodes[i3]; + if (0 < n.children.length) { + n.maxX = void 0; + n.minX = void 0; + n.maxY = void 0; + n.minY = void 0; + } + } + for (var i3 = 0; i3 < layoutInfo.nodeSize; i3++) { + var n = layoutInfo.layoutNodes[i3]; + if (0 < n.children.length || n.isLocked) { + continue; + } + var tempForce = limitForce(n.offsetX, n.offsetY, layoutInfo.temperature); + n.positionX += tempForce.x; + n.positionY += tempForce.y; + n.offsetX = 0; + n.offsetY = 0; + n.minX = n.positionX - n.width; + n.maxX = n.positionX + n.width; + n.minY = n.positionY - n.height; + n.maxY = n.positionY + n.height; + updateAncestryBoundaries(n, layoutInfo); + } + for (var i3 = 0; i3 < layoutInfo.nodeSize; i3++) { + var n = layoutInfo.layoutNodes[i3]; + if (0 < n.children.length && !n.isLocked) { + n.positionX = (n.maxX + n.minX) / 2; + n.positionY = (n.maxY + n.minY) / 2; + n.width = n.maxX - n.minX; + n.height = n.maxY - n.minY; + } + } + }; + var limitForce = function limitForce2(forceX, forceY, max3) { + var force = Math.sqrt(forceX * forceX + forceY * forceY); + if (force > max3) { + var res = { + x: max3 * forceX / force, + y: max3 * forceY / force + }; + } else { + var res = { + x: forceX, + y: forceY + }; + } + return res; + }; + var updateAncestryBoundaries = function updateAncestryBoundaries2(node2, layoutInfo) { + var parentId = node2.parentId; + if (null == parentId) { + return; + } + var p2 = layoutInfo.layoutNodes[layoutInfo.idToIndex[parentId]]; + var flag = false; + if (null == p2.maxX || node2.maxX + p2.padRight > p2.maxX) { + p2.maxX = node2.maxX + p2.padRight; + flag = true; + } + if (null == p2.minX || node2.minX - p2.padLeft < p2.minX) { + p2.minX = node2.minX - p2.padLeft; + flag = true; + } + if (null == p2.maxY || node2.maxY + p2.padBottom > p2.maxY) { + p2.maxY = node2.maxY + p2.padBottom; + flag = true; + } + if (null == p2.minY || node2.minY - p2.padTop < p2.minY) { + p2.minY = node2.minY - p2.padTop; + flag = true; + } + if (flag) { + return updateAncestryBoundaries2(p2, layoutInfo); + } + return; + }; + var separateComponents = function separateComponents2(layoutInfo, options2) { + var nodes2 = layoutInfo.layoutNodes; + var components = []; + for (var i3 = 0; i3 < nodes2.length; i3++) { + var node2 = nodes2[i3]; + var cid = node2.cmptId; + var component = components[cid] = components[cid] || []; + component.push(node2); + } + var totalA = 0; + for (var i3 = 0; i3 < components.length; i3++) { + var c2 = components[i3]; + if (!c2) { + continue; + } + c2.x1 = Infinity; + c2.x2 = -Infinity; + c2.y1 = Infinity; + c2.y2 = -Infinity; + for (var j = 0; j < c2.length; j++) { + var n = c2[j]; + c2.x1 = Math.min(c2.x1, n.positionX - n.width / 2); + c2.x2 = Math.max(c2.x2, n.positionX + n.width / 2); + c2.y1 = Math.min(c2.y1, n.positionY - n.height / 2); + c2.y2 = Math.max(c2.y2, n.positionY + n.height / 2); + } + c2.w = c2.x2 - c2.x1; + c2.h = c2.y2 - c2.y1; + totalA += c2.w * c2.h; + } + components.sort(function(c1, c22) { + return c22.w * c22.h - c1.w * c1.h; + }); + var x2 = 0; + var y2 = 0; + var usedW = 0; + var rowH = 0; + var maxRowW = Math.sqrt(totalA) * layoutInfo.clientWidth / layoutInfo.clientHeight; + for (var i3 = 0; i3 < components.length; i3++) { + var c2 = components[i3]; + if (!c2) { + continue; + } + for (var j = 0; j < c2.length; j++) { + var n = c2[j]; + if (!n.isLocked) { + n.positionX += x2 - c2.x1; + n.positionY += y2 - c2.y1; + } + } + x2 += c2.w + options2.componentSpacing; + usedW += c2.w + options2.componentSpacing; + rowH = Math.max(rowH, c2.h); + if (usedW > maxRowW) { + y2 += rowH + options2.componentSpacing; + x2 = 0; + usedW = 0; + rowH = 0; + } + } + }; + var defaults$3 = { + fit: true, + // whether to fit the viewport to the graph + padding: 30, + // padding used on fit + boundingBox: void 0, + // constrain layout bounds; { x1, y1, x2, y2 } or { x1, y1, w, h } + avoidOverlap: true, + // prevents node overlap, may overflow boundingBox if not enough space + avoidOverlapPadding: 10, + // extra spacing around nodes when avoidOverlap: true + nodeDimensionsIncludeLabels: false, + // Excludes the label when calculating node bounding boxes for the layout algorithm + spacingFactor: void 0, + // Applies a multiplicative factor (>0) to expand or compress the overall area that the nodes take up + condense: false, + // uses all available space on false, uses minimal space on true + rows: void 0, + // force num of rows in the grid + cols: void 0, + // force num of columns in the grid + position: function position3(node2) { + }, + // returns { row, col } for element + sort: void 0, + // a sorting function to order the nodes; e.g. function(a, b){ return a.data('weight') - b.data('weight') } + animate: false, + // whether to transition the node positions + animationDuration: 500, + // duration of animation in ms if enabled + animationEasing: void 0, + // easing of animation if enabled + animateFilter: function animateFilter(node2, i3) { + return true; + }, + // a function that determines whether the node should be animated. All nodes animated by default on animate enabled. Non-animated nodes are positioned immediately when the layout starts + ready: void 0, + // callback on layoutready + stop: void 0, + // callback on layoutstop + transform: function transform(node2, position3) { + return position3; + } + // transform a given node position. Useful for changing flow direction in discrete layouts + }; + function GridLayout(options2) { + this.options = extend2({}, defaults$3, options2); + } + GridLayout.prototype.run = function() { + var params = this.options; + var options2 = params; + var cy = params.cy; + var eles = options2.eles; + var nodes2 = eles.nodes().not(":parent"); + if (options2.sort) { + nodes2 = nodes2.sort(options2.sort); + } + var bb = makeBoundingBox(options2.boundingBox ? options2.boundingBox : { + x1: 0, + y1: 0, + w: cy.width(), + h: cy.height() + }); + if (bb.h === 0 || bb.w === 0) { + eles.nodes().layoutPositions(this, options2, function(ele) { + return { + x: bb.x1, + y: bb.y1 + }; + }); + } else { + var cells = nodes2.size(); + var splits = Math.sqrt(cells * bb.h / bb.w); + var rows = Math.round(splits); + var cols = Math.round(bb.w / bb.h * splits); + var small = function small2(val) { + if (val == null) { + return Math.min(rows, cols); + } else { + var min3 = Math.min(rows, cols); + if (min3 == rows) { + rows = val; + } else { + cols = val; + } + } + }; + var large = function large2(val) { + if (val == null) { + return Math.max(rows, cols); + } else { + var max3 = Math.max(rows, cols); + if (max3 == rows) { + rows = val; + } else { + cols = val; + } + } + }; + var oRows = options2.rows; + var oCols = options2.cols != null ? options2.cols : options2.columns; + if (oRows != null && oCols != null) { + rows = oRows; + cols = oCols; + } else if (oRows != null && oCols == null) { + rows = oRows; + cols = Math.ceil(cells / rows); + } else if (oRows == null && oCols != null) { + cols = oCols; + rows = Math.ceil(cells / cols); + } else if (cols * rows > cells) { + var sm = small(); + var lg = large(); + if ((sm - 1) * lg >= cells) { + small(sm - 1); + } else if ((lg - 1) * sm >= cells) { + large(lg - 1); + } + } else { + while (cols * rows < cells) { + var _sm = small(); + var _lg = large(); + if ((_lg + 1) * _sm >= cells) { + large(_lg + 1); + } else { + small(_sm + 1); + } + } + } + var cellWidth = bb.w / cols; + var cellHeight = bb.h / rows; + if (options2.condense) { + cellWidth = 0; + cellHeight = 0; + } + if (options2.avoidOverlap) { + for (var i3 = 0; i3 < nodes2.length; i3++) { + var node2 = nodes2[i3]; + var pos = node2._private.position; + if (pos.x == null || pos.y == null) { + pos.x = 0; + pos.y = 0; + } + var nbb = node2.layoutDimensions(options2); + var p2 = options2.avoidOverlapPadding; + var w2 = nbb.w + p2; + var h = nbb.h + p2; + cellWidth = Math.max(cellWidth, w2); + cellHeight = Math.max(cellHeight, h); + } + } + var cellUsed = {}; + var used = function used2(row2, col2) { + return cellUsed["c-" + row2 + "-" + col2] ? true : false; + }; + var use = function use2(row2, col2) { + cellUsed["c-" + row2 + "-" + col2] = true; + }; + var row = 0; + var col = 0; + var moveToNextCell = function moveToNextCell2() { + col++; + if (col >= cols) { + col = 0; + row++; + } + }; + var id2manPos = {}; + for (var _i6 = 0; _i6 < nodes2.length; _i6++) { + var _node = nodes2[_i6]; + var rcPos = options2.position(_node); + if (rcPos && (rcPos.row !== void 0 || rcPos.col !== void 0)) { + var _pos = { + row: rcPos.row, + col: rcPos.col + }; + if (_pos.col === void 0) { + _pos.col = 0; + while (used(_pos.row, _pos.col)) { + _pos.col++; + } + } else if (_pos.row === void 0) { + _pos.row = 0; + while (used(_pos.row, _pos.col)) { + _pos.row++; + } + } + id2manPos[_node.id()] = _pos; + use(_pos.row, _pos.col); + } + } + var getPos = function getPos2(element3, i4) { + var x2, y2; + if (element3.locked() || element3.isParent()) { + return false; + } + var rcPos2 = id2manPos[element3.id()]; + if (rcPos2) { + x2 = rcPos2.col * cellWidth + cellWidth / 2 + bb.x1; + y2 = rcPos2.row * cellHeight + cellHeight / 2 + bb.y1; + } else { + while (used(row, col)) { + moveToNextCell(); + } + x2 = col * cellWidth + cellWidth / 2 + bb.x1; + y2 = row * cellHeight + cellHeight / 2 + bb.y1; + use(row, col); + moveToNextCell(); + } + return { + x: x2, + y: y2 + }; + }; + nodes2.layoutPositions(this, options2, getPos); + } + return this; + }; + var defaults$2 = { + ready: function ready() { + }, + // on layoutready + stop: function stop() { + } + // on layoutstop + }; + function NullLayout(options2) { + this.options = extend2({}, defaults$2, options2); + } + NullLayout.prototype.run = function() { + var options2 = this.options; + var eles = options2.eles; + var layout3 = this; + options2.cy; + layout3.emit("layoutstart"); + eles.nodes().positions(function() { + return { + x: 0, + y: 0 + }; + }); + layout3.one("layoutready", options2.ready); + layout3.emit("layoutready"); + layout3.one("layoutstop", options2.stop); + layout3.emit("layoutstop"); + return this; + }; + NullLayout.prototype.stop = function() { + return this; + }; + var defaults$12 = { + positions: void 0, + // map of (node id) => (position obj); or function(node){ return somPos; } + zoom: void 0, + // the zoom level to set (prob want fit = false if set) + pan: void 0, + // the pan level to set (prob want fit = false if set) + fit: true, + // whether to fit to viewport + padding: 30, + // padding on fit + spacingFactor: void 0, + // Applies a multiplicative factor (>0) to expand or compress the overall area that the nodes take up + animate: false, + // whether to transition the node positions + animationDuration: 500, + // duration of animation in ms if enabled + animationEasing: void 0, + // easing of animation if enabled + animateFilter: function animateFilter(node2, i3) { + return true; + }, + // a function that determines whether the node should be animated. All nodes animated by default on animate enabled. Non-animated nodes are positioned immediately when the layout starts + ready: void 0, + // callback on layoutready + stop: void 0, + // callback on layoutstop + transform: function transform(node2, position3) { + return position3; + } + // transform a given node position. Useful for changing flow direction in discrete layouts + }; + function PresetLayout(options2) { + this.options = extend2({}, defaults$12, options2); + } + PresetLayout.prototype.run = function() { + var options2 = this.options; + var eles = options2.eles; + var nodes2 = eles.nodes(); + var posIsFn = fn$6(options2.positions); + function getPosition(node2) { + if (options2.positions == null) { + return copyPosition(node2.position()); + } + if (posIsFn) { + return options2.positions(node2); + } + var pos = options2.positions[node2._private.data.id]; + if (pos == null) { + return null; + } + return pos; + } + nodes2.layoutPositions(this, options2, function(node2, i3) { + var position3 = getPosition(node2); + if (node2.locked() || position3 == null) { + return false; + } + return position3; + }); + return this; + }; + var defaults2 = { + fit: true, + // whether to fit to viewport + padding: 30, + // fit padding + boundingBox: void 0, + // constrain layout bounds; { x1, y1, x2, y2 } or { x1, y1, w, h } + animate: false, + // whether to transition the node positions + animationDuration: 500, + // duration of animation in ms if enabled + animationEasing: void 0, + // easing of animation if enabled + animateFilter: function animateFilter(node2, i3) { + return true; + }, + // a function that determines whether the node should be animated. All nodes animated by default on animate enabled. Non-animated nodes are positioned immediately when the layout starts + ready: void 0, + // callback on layoutready + stop: void 0, + // callback on layoutstop + transform: function transform(node2, position3) { + return position3; + } + // transform a given node position. Useful for changing flow direction in discrete layouts + }; + function RandomLayout(options2) { + this.options = extend2({}, defaults2, options2); + } + RandomLayout.prototype.run = function() { + var options2 = this.options; + var cy = options2.cy; + var eles = options2.eles; + var bb = makeBoundingBox(options2.boundingBox ? options2.boundingBox : { + x1: 0, + y1: 0, + w: cy.width(), + h: cy.height() + }); + var getPos = function getPos2(node2, i3) { + return { + x: bb.x1 + Math.round(Math.random() * bb.w), + y: bb.y1 + Math.round(Math.random() * bb.h) + }; + }; + eles.nodes().layoutPositions(this, options2, getPos); + return this; + }; + var layout2 = [{ + name: "breadthfirst", + impl: BreadthFirstLayout + }, { + name: "circle", + impl: CircleLayout + }, { + name: "concentric", + impl: ConcentricLayout + }, { + name: "cose", + impl: CoseLayout + }, { + name: "grid", + impl: GridLayout + }, { + name: "null", + impl: NullLayout + }, { + name: "preset", + impl: PresetLayout + }, { + name: "random", + impl: RandomLayout + }]; + function NullRenderer(options2) { + this.options = options2; + this.notifications = 0; + } + var noop2 = function noop3() { + }; + var throwImgErr = function throwImgErr2() { + throw new Error("A headless instance can not render images"); + }; + NullRenderer.prototype = { + recalculateRenderedStyle: noop2, + notify: function notify() { + this.notifications++; + }, + init: noop2, + isHeadless: function isHeadless() { + return true; + }, + png: throwImgErr, + jpg: throwImgErr + }; + var BRp$f = {}; + BRp$f.arrowShapeWidth = 0.3; + BRp$f.registerArrowShapes = function() { + var arrowShapes = this.arrowShapes = {}; + var renderer3 = this; + var bbCollide = function bbCollide2(x2, y2, size2, angle, translation, edgeWidth, padding2) { + var x1 = translation.x - size2 / 2 - padding2; + var x22 = translation.x + size2 / 2 + padding2; + var y1 = translation.y - size2 / 2 - padding2; + var y22 = translation.y + size2 / 2 + padding2; + var inside = x1 <= x2 && x2 <= x22 && y1 <= y2 && y2 <= y22; + return inside; + }; + var transform = function transform2(x2, y2, size2, angle, translation) { + var xRotated = x2 * Math.cos(angle) - y2 * Math.sin(angle); + var yRotated = x2 * Math.sin(angle) + y2 * Math.cos(angle); + var xScaled = xRotated * size2; + var yScaled = yRotated * size2; + var xTranslated = xScaled + translation.x; + var yTranslated = yScaled + translation.y; + return { + x: xTranslated, + y: yTranslated + }; + }; + var transformPoints = function transformPoints2(pts2, size2, angle, translation) { + var retPts = []; + for (var i3 = 0; i3 < pts2.length; i3 += 2) { + var x2 = pts2[i3]; + var y2 = pts2[i3 + 1]; + retPts.push(transform(x2, y2, size2, angle, translation)); + } + return retPts; + }; + var pointsToArr = function pointsToArr2(pts2) { + var ret = []; + for (var i3 = 0; i3 < pts2.length; i3++) { + var p2 = pts2[i3]; + ret.push(p2.x, p2.y); + } + return ret; + }; + var standardGap = function standardGap2(edge) { + return edge.pstyle("width").pfValue * edge.pstyle("arrow-scale").pfValue * 2; + }; + var defineArrowShape = function defineArrowShape2(name, defn) { + if (string2(defn)) { + defn = arrowShapes[defn]; + } + arrowShapes[name] = extend2({ + name, + points: [-0.15, -0.3, 0.15, -0.3, 0.15, 0.3, -0.15, 0.3], + collide: function collide(x2, y2, size2, angle, translation, padding2) { + var points = pointsToArr(transformPoints(this.points, size2 + 2 * padding2, angle, translation)); + var inside = pointInsidePolygonPoints(x2, y2, points); + return inside; + }, + roughCollide: bbCollide, + draw: function draw2(context, size2, angle, translation) { + var points = transformPoints(this.points, size2, angle, translation); + renderer3.arrowShapeImpl("polygon")(context, points); + }, + spacing: function spacing2(edge) { + return 0; + }, + gap: standardGap + }, defn); + }; + defineArrowShape("none", { + collide: falsify, + roughCollide: falsify, + draw: noop$12, + spacing: zeroify, + gap: zeroify + }); + defineArrowShape("triangle", { + points: [-0.15, -0.3, 0, 0, 0.15, -0.3] + }); + defineArrowShape("arrow", "triangle"); + defineArrowShape("triangle-backcurve", { + points: arrowShapes["triangle"].points, + controlPoint: [0, -0.15], + roughCollide: bbCollide, + draw: function draw2(context, size2, angle, translation, edgeWidth) { + var ptsTrans = transformPoints(this.points, size2, angle, translation); + var ctrlPt = this.controlPoint; + var ctrlPtTrans = transform(ctrlPt[0], ctrlPt[1], size2, angle, translation); + renderer3.arrowShapeImpl(this.name)(context, ptsTrans, ctrlPtTrans); + }, + gap: function gap(edge) { + return standardGap(edge) * 0.8; + } + }); + defineArrowShape("triangle-tee", { + points: [0, 0, 0.15, -0.3, -0.15, -0.3, 0, 0], + pointsTee: [-0.15, -0.4, -0.15, -0.5, 0.15, -0.5, 0.15, -0.4], + collide: function collide(x2, y2, size2, angle, translation, edgeWidth, padding2) { + var triPts = pointsToArr(transformPoints(this.points, size2 + 2 * padding2, angle, translation)); + var teePts = pointsToArr(transformPoints(this.pointsTee, size2 + 2 * padding2, angle, translation)); + var inside = pointInsidePolygonPoints(x2, y2, triPts) || pointInsidePolygonPoints(x2, y2, teePts); + return inside; + }, + draw: function draw2(context, size2, angle, translation, edgeWidth) { + var triPts = transformPoints(this.points, size2, angle, translation); + var teePts = transformPoints(this.pointsTee, size2, angle, translation); + renderer3.arrowShapeImpl(this.name)(context, triPts, teePts); + } + }); + defineArrowShape("circle-triangle", { + radius: 0.15, + pointsTr: [0, -0.15, 0.15, -0.45, -0.15, -0.45, 0, -0.15], + collide: function collide(x2, y2, size2, angle, translation, edgeWidth, padding2) { + var t = translation; + var circleInside = Math.pow(t.x - x2, 2) + Math.pow(t.y - y2, 2) <= Math.pow((size2 + 2 * padding2) * this.radius, 2); + var triPts = pointsToArr(transformPoints(this.points, size2 + 2 * padding2, angle, translation)); + return pointInsidePolygonPoints(x2, y2, triPts) || circleInside; + }, + draw: function draw2(context, size2, angle, translation, edgeWidth) { + var triPts = transformPoints(this.pointsTr, size2, angle, translation); + renderer3.arrowShapeImpl(this.name)(context, triPts, translation.x, translation.y, this.radius * size2); + }, + spacing: function spacing2(edge) { + return renderer3.getArrowWidth(edge.pstyle("width").pfValue, edge.pstyle("arrow-scale").value) * this.radius; + } + }); + defineArrowShape("triangle-cross", { + points: [0, 0, 0.15, -0.3, -0.15, -0.3, 0, 0], + baseCrossLinePts: [ + -0.15, + -0.4, + // first half of the rectangle + -0.15, + -0.4, + 0.15, + -0.4, + // second half of the rectangle + 0.15, + -0.4 + ], + crossLinePts: function crossLinePts(size2, edgeWidth) { + var p2 = this.baseCrossLinePts.slice(); + var shiftFactor = edgeWidth / size2; + var y0 = 3; + var y1 = 5; + p2[y0] = p2[y0] - shiftFactor; + p2[y1] = p2[y1] - shiftFactor; + return p2; + }, + collide: function collide(x2, y2, size2, angle, translation, edgeWidth, padding2) { + var triPts = pointsToArr(transformPoints(this.points, size2 + 2 * padding2, angle, translation)); + var teePts = pointsToArr(transformPoints(this.crossLinePts(size2, edgeWidth), size2 + 2 * padding2, angle, translation)); + var inside = pointInsidePolygonPoints(x2, y2, triPts) || pointInsidePolygonPoints(x2, y2, teePts); + return inside; + }, + draw: function draw2(context, size2, angle, translation, edgeWidth) { + var triPts = transformPoints(this.points, size2, angle, translation); + var crossLinePts = transformPoints(this.crossLinePts(size2, edgeWidth), size2, angle, translation); + renderer3.arrowShapeImpl(this.name)(context, triPts, crossLinePts); + } + }); + defineArrowShape("vee", { + points: [-0.15, -0.3, 0, 0, 0.15, -0.3, 0, -0.15], + gap: function gap(edge) { + return standardGap(edge) * 0.525; + } + }); + defineArrowShape("circle", { + radius: 0.15, + collide: function collide(x2, y2, size2, angle, translation, edgeWidth, padding2) { + var t = translation; + var inside = Math.pow(t.x - x2, 2) + Math.pow(t.y - y2, 2) <= Math.pow((size2 + 2 * padding2) * this.radius, 2); + return inside; + }, + draw: function draw2(context, size2, angle, translation, edgeWidth) { + renderer3.arrowShapeImpl(this.name)(context, translation.x, translation.y, this.radius * size2); + }, + spacing: function spacing2(edge) { + return renderer3.getArrowWidth(edge.pstyle("width").pfValue, edge.pstyle("arrow-scale").value) * this.radius; + } + }); + defineArrowShape("tee", { + points: [-0.15, 0, -0.15, -0.1, 0.15, -0.1, 0.15, 0], + spacing: function spacing2(edge) { + return 1; + }, + gap: function gap(edge) { + return 1; + } + }); + defineArrowShape("square", { + points: [-0.15, 0, 0.15, 0, 0.15, -0.3, -0.15, -0.3] + }); + defineArrowShape("diamond", { + points: [-0.15, -0.15, 0, -0.3, 0.15, -0.15, 0, 0], + gap: function gap(edge) { + return edge.pstyle("width").pfValue * edge.pstyle("arrow-scale").value; + } + }); + defineArrowShape("chevron", { + points: [0, 0, -0.15, -0.15, -0.1, -0.2, 0, -0.1, 0.1, -0.2, 0.15, -0.15], + gap: function gap(edge) { + return 0.95 * edge.pstyle("width").pfValue * edge.pstyle("arrow-scale").value; + } + }); + }; + var BRp$e = {}; + BRp$e.projectIntoViewport = function(clientX, clientY) { + var cy = this.cy; + var offsets = this.findContainerClientCoords(); + var offsetLeft = offsets[0]; + var offsetTop = offsets[1]; + var scale = offsets[4]; + var pan = cy.pan(); + var zoom = cy.zoom(); + var x2 = ((clientX - offsetLeft) / scale - pan.x) / zoom; + var y2 = ((clientY - offsetTop) / scale - pan.y) / zoom; + return [x2, y2]; + }; + BRp$e.findContainerClientCoords = function() { + if (this.containerBB) { + return this.containerBB; + } + var container = this.container; + var rect2 = container.getBoundingClientRect(); + var style = this.cy.window().getComputedStyle(container); + var styleValue2 = function styleValue3(name) { + return parseFloat(style.getPropertyValue(name)); + }; + var padding2 = { + left: styleValue2("padding-left"), + right: styleValue2("padding-right"), + top: styleValue2("padding-top"), + bottom: styleValue2("padding-bottom") + }; + var border = { + left: styleValue2("border-left-width"), + right: styleValue2("border-right-width"), + top: styleValue2("border-top-width"), + bottom: styleValue2("border-bottom-width") + }; + var clientWidth = container.clientWidth; + var clientHeight = container.clientHeight; + var paddingHor = padding2.left + padding2.right; + var paddingVer = padding2.top + padding2.bottom; + var borderHor = border.left + border.right; + var scale = rect2.width / (clientWidth + borderHor); + var unscaledW = clientWidth - paddingHor; + var unscaledH = clientHeight - paddingVer; + var left2 = rect2.left + padding2.left + border.left; + var top2 = rect2.top + padding2.top + border.top; + return this.containerBB = [left2, top2, unscaledW, unscaledH, scale]; + }; + BRp$e.invalidateContainerClientCoordsCache = function() { + this.containerBB = null; + }; + BRp$e.findNearestElement = function(x2, y2, interactiveElementsOnly, isTouch) { + return this.findNearestElements(x2, y2, interactiveElementsOnly, isTouch)[0]; + }; + BRp$e.findNearestElements = function(x2, y2, interactiveElementsOnly, isTouch) { + var self2 = this; + var r = this; + var eles = r.getCachedZSortedEles(); + var near = []; + var zoom = r.cy.zoom(); + var hasCompounds = r.cy.hasCompoundNodes(); + var edgeThreshold = (isTouch ? 24 : 8) / zoom; + var nodeThreshold = (isTouch ? 8 : 2) / zoom; + var labelThreshold = (isTouch ? 8 : 2) / zoom; + var minSqDist = Infinity; + var nearEdge; + var nearNode; + if (interactiveElementsOnly) { + eles = eles.interactive; + } + function addEle(ele2, sqDist) { + if (ele2.isNode()) { + if (nearNode) { + return; + } else { + nearNode = ele2; + near.push(ele2); + } + } + if (ele2.isEdge() && (sqDist == null || sqDist < minSqDist)) { + if (nearEdge) { + if (nearEdge.pstyle("z-compound-depth").value === ele2.pstyle("z-compound-depth").value && nearEdge.pstyle("z-compound-depth").value === ele2.pstyle("z-compound-depth").value) { + for (var i4 = 0; i4 < near.length; i4++) { + if (near[i4].isEdge()) { + near[i4] = ele2; + nearEdge = ele2; + minSqDist = sqDist != null ? sqDist : minSqDist; + break; + } + } + } + } else { + near.push(ele2); + nearEdge = ele2; + minSqDist = sqDist != null ? sqDist : minSqDist; + } + } + } + function checkNode(node2) { + var width2 = node2.outerWidth() + 2 * nodeThreshold; + var height = node2.outerHeight() + 2 * nodeThreshold; + var hw = width2 / 2; + var hh = height / 2; + var pos = node2.position(); + if (pos.x - hw <= x2 && x2 <= pos.x + hw && pos.y - hh <= y2 && y2 <= pos.y + hh) { + var shape = r.nodeShapes[self2.getNodeShape(node2)]; + if (shape.checkPoint(x2, y2, 0, width2, height, pos.x, pos.y)) { + addEle(node2, 0); + return true; + } + } + } + function checkEdge(edge) { + var _p = edge._private; + var rs = _p.rscratch; + var styleWidth = edge.pstyle("width").pfValue; + var scale = edge.pstyle("arrow-scale").value; + var width2 = styleWidth / 2 + edgeThreshold; + var widthSq = width2 * width2; + var width22 = width2 * 2; + var src = _p.source; + var tgt = _p.target; + var sqDist; + if (rs.edgeType === "segments" || rs.edgeType === "straight" || rs.edgeType === "haystack") { + var pts2 = rs.allpts; + for (var i4 = 0; i4 + 3 < pts2.length; i4 += 2) { + if (inLineVicinity(x2, y2, pts2[i4], pts2[i4 + 1], pts2[i4 + 2], pts2[i4 + 3], width22) && widthSq > (sqDist = sqdistToFiniteLine(x2, y2, pts2[i4], pts2[i4 + 1], pts2[i4 + 2], pts2[i4 + 3]))) { + addEle(edge, sqDist); + return true; + } + } + } else if (rs.edgeType === "bezier" || rs.edgeType === "multibezier" || rs.edgeType === "self" || rs.edgeType === "compound") { + var pts2 = rs.allpts; + for (var i4 = 0; i4 + 5 < rs.allpts.length; i4 += 4) { + if (inBezierVicinity(x2, y2, pts2[i4], pts2[i4 + 1], pts2[i4 + 2], pts2[i4 + 3], pts2[i4 + 4], pts2[i4 + 5], width22) && widthSq > (sqDist = sqdistToQuadraticBezier(x2, y2, pts2[i4], pts2[i4 + 1], pts2[i4 + 2], pts2[i4 + 3], pts2[i4 + 4], pts2[i4 + 5]))) { + addEle(edge, sqDist); + return true; + } + } + } + var src = src || _p.source; + var tgt = tgt || _p.target; + var arSize = self2.getArrowWidth(styleWidth, scale); + var arrows2 = [{ + name: "source", + x: rs.arrowStartX, + y: rs.arrowStartY, + angle: rs.srcArrowAngle + }, { + name: "target", + x: rs.arrowEndX, + y: rs.arrowEndY, + angle: rs.tgtArrowAngle + }, { + name: "mid-source", + x: rs.midX, + y: rs.midY, + angle: rs.midsrcArrowAngle + }, { + name: "mid-target", + x: rs.midX, + y: rs.midY, + angle: rs.midtgtArrowAngle + }]; + for (var i4 = 0; i4 < arrows2.length; i4++) { + var ar = arrows2[i4]; + var shape = r.arrowShapes[edge.pstyle(ar.name + "-arrow-shape").value]; + var edgeWidth = edge.pstyle("width").pfValue; + if (shape.roughCollide(x2, y2, arSize, ar.angle, { + x: ar.x, + y: ar.y + }, edgeWidth, edgeThreshold) && shape.collide(x2, y2, arSize, ar.angle, { + x: ar.x, + y: ar.y + }, edgeWidth, edgeThreshold)) { + addEle(edge); + return true; + } + } + if (hasCompounds && near.length > 0) { + checkNode(src); + checkNode(tgt); + } + } + function preprop(obj, name, pre) { + return getPrefixedProperty(obj, name, pre); + } + function checkLabel(ele2, prefix) { + var _p = ele2._private; + var th = labelThreshold; + var prefixDash; + if (prefix) { + prefixDash = prefix + "-"; + } else { + prefixDash = ""; + } + ele2.boundingBox(); + var bb = _p.labelBounds[prefix || "main"]; + var text2 = ele2.pstyle(prefixDash + "label").value; + var eventsEnabled = ele2.pstyle("text-events").strValue === "yes"; + if (!eventsEnabled || !text2) { + return; + } + var lx = preprop(_p.rscratch, "labelX", prefix); + var ly = preprop(_p.rscratch, "labelY", prefix); + var theta = preprop(_p.rscratch, "labelAngle", prefix); + var ox = ele2.pstyle(prefixDash + "text-margin-x").pfValue; + var oy = ele2.pstyle(prefixDash + "text-margin-y").pfValue; + var lx1 = bb.x1 - th - ox; + var lx2 = bb.x2 + th - ox; + var ly1 = bb.y1 - th - oy; + var ly2 = bb.y2 + th - oy; + if (theta) { + var cos3 = Math.cos(theta); + var sin3 = Math.sin(theta); + var rotate = function rotate2(x3, y3) { + x3 = x3 - lx; + y3 = y3 - ly; + return { + x: x3 * cos3 - y3 * sin3 + lx, + y: x3 * sin3 + y3 * cos3 + ly + }; + }; + var px1y1 = rotate(lx1, ly1); + var px1y2 = rotate(lx1, ly2); + var px2y1 = rotate(lx2, ly1); + var px2y2 = rotate(lx2, ly2); + var points = [ + // with the margin added after the rotation is applied + px1y1.x + ox, + px1y1.y + oy, + px2y1.x + ox, + px2y1.y + oy, + px2y2.x + ox, + px2y2.y + oy, + px1y2.x + ox, + px1y2.y + oy + ]; + if (pointInsidePolygonPoints(x2, y2, points)) { + addEle(ele2); + return true; + } + } else { + if (inBoundingBox(bb, x2, y2)) { + addEle(ele2); + return true; + } + } + } + for (var i3 = eles.length - 1; i3 >= 0; i3--) { + var ele = eles[i3]; + if (ele.isNode()) { + checkNode(ele) || checkLabel(ele); + } else { + checkEdge(ele) || checkLabel(ele) || checkLabel(ele, "source") || checkLabel(ele, "target"); + } + } + return near; + }; + BRp$e.getAllInBox = function(x1, y1, x2, y2) { + var eles = this.getCachedZSortedEles().interactive; + var box = []; + var x1c = Math.min(x1, x2); + var x2c = Math.max(x1, x2); + var y1c = Math.min(y1, y2); + var y2c = Math.max(y1, y2); + x1 = x1c; + x2 = x2c; + y1 = y1c; + y2 = y2c; + var boxBb = makeBoundingBox({ + x1, + y1, + x2, + y2 + }); + for (var e = 0; e < eles.length; e++) { + var ele = eles[e]; + if (ele.isNode()) { + var node2 = ele; + var nodeBb = node2.boundingBox({ + includeNodes: true, + includeEdges: false, + includeLabels: false + }); + if (boundingBoxesIntersect(boxBb, nodeBb) && !boundingBoxInBoundingBox(nodeBb, boxBb)) { + box.push(node2); + } + } else { + var edge = ele; + var _p = edge._private; + var rs = _p.rscratch; + if (rs.startX != null && rs.startY != null && !inBoundingBox(boxBb, rs.startX, rs.startY)) { + continue; + } + if (rs.endX != null && rs.endY != null && !inBoundingBox(boxBb, rs.endX, rs.endY)) { + continue; + } + if (rs.edgeType === "bezier" || rs.edgeType === "multibezier" || rs.edgeType === "self" || rs.edgeType === "compound" || rs.edgeType === "segments" || rs.edgeType === "haystack") { + var pts2 = _p.rstyle.bezierPts || _p.rstyle.linePts || _p.rstyle.haystackPts; + var allInside = true; + for (var i3 = 0; i3 < pts2.length; i3++) { + if (!pointInBoundingBox(boxBb, pts2[i3])) { + allInside = false; + break; + } + } + if (allInside) { + box.push(edge); + } + } else if (rs.edgeType === "haystack" || rs.edgeType === "straight") { + box.push(edge); + } + } + } + return box; + }; + var BRp$d = {}; + BRp$d.calculateArrowAngles = function(edge) { + var rs = edge._private.rscratch; + var isHaystack = rs.edgeType === "haystack"; + var isBezier = rs.edgeType === "bezier"; + var isMultibezier = rs.edgeType === "multibezier"; + var isSegments = rs.edgeType === "segments"; + var isCompound = rs.edgeType === "compound"; + var isSelf = rs.edgeType === "self"; + var dispX, dispY; + var startX, startY, endX, endY, midX, midY; + if (isHaystack) { + startX = rs.haystackPts[0]; + startY = rs.haystackPts[1]; + endX = rs.haystackPts[2]; + endY = rs.haystackPts[3]; + } else { + startX = rs.arrowStartX; + startY = rs.arrowStartY; + endX = rs.arrowEndX; + endY = rs.arrowEndY; + } + midX = rs.midX; + midY = rs.midY; + if (isSegments) { + dispX = startX - rs.segpts[0]; + dispY = startY - rs.segpts[1]; + } else if (isMultibezier || isCompound || isSelf || isBezier) { + var pts2 = rs.allpts; + var bX = qbezierAt(pts2[0], pts2[2], pts2[4], 0.1); + var bY = qbezierAt(pts2[1], pts2[3], pts2[5], 0.1); + dispX = startX - bX; + dispY = startY - bY; + } else { + dispX = startX - midX; + dispY = startY - midY; + } + rs.srcArrowAngle = getAngleFromDisp(dispX, dispY); + var midX = rs.midX; + var midY = rs.midY; + if (isHaystack) { + midX = (startX + endX) / 2; + midY = (startY + endY) / 2; + } + dispX = endX - startX; + dispY = endY - startY; + if (isSegments) { + var pts2 = rs.allpts; + if (pts2.length / 2 % 2 === 0) { + var i22 = pts2.length / 2; + var i1 = i22 - 2; + dispX = pts2[i22] - pts2[i1]; + dispY = pts2[i22 + 1] - pts2[i1 + 1]; + } else { + var i22 = pts2.length / 2 - 1; + var i1 = i22 - 2; + var i3 = i22 + 2; + dispX = pts2[i22] - pts2[i1]; + dispY = pts2[i22 + 1] - pts2[i1 + 1]; + } + } else if (isMultibezier || isCompound || isSelf) { + var pts2 = rs.allpts; + var cpts = rs.ctrlpts; + var bp0x, bp0y; + var bp1x, bp1y; + if (cpts.length / 2 % 2 === 0) { + var p0 = pts2.length / 2 - 1; + var ic = p0 + 2; + var p1 = ic + 2; + bp0x = qbezierAt(pts2[p0], pts2[ic], pts2[p1], 0); + bp0y = qbezierAt(pts2[p0 + 1], pts2[ic + 1], pts2[p1 + 1], 0); + bp1x = qbezierAt(pts2[p0], pts2[ic], pts2[p1], 1e-4); + bp1y = qbezierAt(pts2[p0 + 1], pts2[ic + 1], pts2[p1 + 1], 1e-4); + } else { + var ic = pts2.length / 2 - 1; + var p0 = ic - 2; + var p1 = ic + 2; + bp0x = qbezierAt(pts2[p0], pts2[ic], pts2[p1], 0.4999); + bp0y = qbezierAt(pts2[p0 + 1], pts2[ic + 1], pts2[p1 + 1], 0.4999); + bp1x = qbezierAt(pts2[p0], pts2[ic], pts2[p1], 0.5); + bp1y = qbezierAt(pts2[p0 + 1], pts2[ic + 1], pts2[p1 + 1], 0.5); + } + dispX = bp1x - bp0x; + dispY = bp1y - bp0y; + } + rs.midtgtArrowAngle = getAngleFromDisp(dispX, dispY); + rs.midDispX = dispX; + rs.midDispY = dispY; + dispX *= -1; + dispY *= -1; + if (isSegments) { + var pts2 = rs.allpts; + if (pts2.length / 2 % 2 === 0) + ; + else { + var i22 = pts2.length / 2 - 1; + var i3 = i22 + 2; + dispX = -(pts2[i3] - pts2[i22]); + dispY = -(pts2[i3 + 1] - pts2[i22 + 1]); + } + } + rs.midsrcArrowAngle = getAngleFromDisp(dispX, dispY); + if (isSegments) { + dispX = endX - rs.segpts[rs.segpts.length - 2]; + dispY = endY - rs.segpts[rs.segpts.length - 1]; + } else if (isMultibezier || isCompound || isSelf || isBezier) { + var pts2 = rs.allpts; + var l = pts2.length; + var bX = qbezierAt(pts2[l - 6], pts2[l - 4], pts2[l - 2], 0.9); + var bY = qbezierAt(pts2[l - 5], pts2[l - 3], pts2[l - 1], 0.9); + dispX = endX - bX; + dispY = endY - bY; + } else { + dispX = endX - midX; + dispY = endY - midY; + } + rs.tgtArrowAngle = getAngleFromDisp(dispX, dispY); + }; + BRp$d.getArrowWidth = BRp$d.getArrowHeight = function(edgeWidth, scale) { + var cache2 = this.arrowWidthCache = this.arrowWidthCache || {}; + var cachedVal = cache2[edgeWidth + ", " + scale]; + if (cachedVal) { + return cachedVal; + } + cachedVal = Math.max(Math.pow(edgeWidth * 13.37, 0.9), 29) * scale; + cache2[edgeWidth + ", " + scale] = cachedVal; + return cachedVal; + }; + var BRp$c = {}; + BRp$c.findMidptPtsEtc = function(edge, pairInfo) { + var posPts = pairInfo.posPts, intersectionPts = pairInfo.intersectionPts, vectorNormInverse = pairInfo.vectorNormInverse; + var midptPts; + var srcManEndpt = edge.pstyle("source-endpoint"); + var tgtManEndpt = edge.pstyle("target-endpoint"); + var haveManualEndPts = srcManEndpt.units != null && tgtManEndpt.units != null; + var recalcVectorNormInverse = function recalcVectorNormInverse2(x12, y12, x22, y22) { + var dy = y22 - y12; + var dx = x22 - x12; + var l = Math.sqrt(dx * dx + dy * dy); + return { + x: -dy / l, + y: dx / l + }; + }; + var edgeDistances = edge.pstyle("edge-distances").value; + switch (edgeDistances) { + case "node-position": + midptPts = posPts; + break; + case "intersection": + midptPts = intersectionPts; + break; + case "endpoints": { + if (haveManualEndPts) { + var _this$manualEndptToPx = this.manualEndptToPx(edge.source()[0], srcManEndpt), _this$manualEndptToPx2 = _slicedToArray(_this$manualEndptToPx, 2), x1 = _this$manualEndptToPx2[0], y1 = _this$manualEndptToPx2[1]; + var _this$manualEndptToPx3 = this.manualEndptToPx(edge.target()[0], tgtManEndpt), _this$manualEndptToPx4 = _slicedToArray(_this$manualEndptToPx3, 2), x2 = _this$manualEndptToPx4[0], y2 = _this$manualEndptToPx4[1]; + var endPts = { + x1, + y1, + x2, + y2 + }; + vectorNormInverse = recalcVectorNormInverse(x1, y1, x2, y2); + midptPts = endPts; + } else { + warn("Edge ".concat(edge.id(), " has edge-distances:endpoints specified without manual endpoints specified via source-endpoint and target-endpoint. Falling back on edge-distances:intersection (default).")); + midptPts = intersectionPts; + } + break; + } + } + return { + midptPts, + vectorNormInverse + }; + }; + BRp$c.findHaystackPoints = function(edges2) { + for (var i3 = 0; i3 < edges2.length; i3++) { + var edge = edges2[i3]; + var _p = edge._private; + var rs = _p.rscratch; + if (!rs.haystack) { + var angle = Math.random() * 2 * Math.PI; + rs.source = { + x: Math.cos(angle), + y: Math.sin(angle) + }; + angle = Math.random() * 2 * Math.PI; + rs.target = { + x: Math.cos(angle), + y: Math.sin(angle) + }; + } + var src = _p.source; + var tgt = _p.target; + var srcPos = src.position(); + var tgtPos = tgt.position(); + var srcW = src.width(); + var tgtW = tgt.width(); + var srcH = src.height(); + var tgtH = tgt.height(); + var radius = edge.pstyle("haystack-radius").value; + var halfRadius = radius / 2; + rs.haystackPts = rs.allpts = [rs.source.x * srcW * halfRadius + srcPos.x, rs.source.y * srcH * halfRadius + srcPos.y, rs.target.x * tgtW * halfRadius + tgtPos.x, rs.target.y * tgtH * halfRadius + tgtPos.y]; + rs.midX = (rs.allpts[0] + rs.allpts[2]) / 2; + rs.midY = (rs.allpts[1] + rs.allpts[3]) / 2; + rs.edgeType = "haystack"; + rs.haystack = true; + this.storeEdgeProjections(edge); + this.calculateArrowAngles(edge); + this.recalculateEdgeLabelProjections(edge); + this.calculateLabelAngles(edge); + } + }; + BRp$c.findSegmentsPoints = function(edge, pairInfo) { + var rs = edge._private.rscratch; + var segmentWs = edge.pstyle("segment-weights"); + var segmentDs = edge.pstyle("segment-distances"); + var segmentsN = Math.min(segmentWs.pfValue.length, segmentDs.pfValue.length); + rs.edgeType = "segments"; + rs.segpts = []; + for (var s = 0; s < segmentsN; s++) { + var w2 = segmentWs.pfValue[s]; + var d = segmentDs.pfValue[s]; + var w1 = 1 - w2; + var w22 = w2; + var _this$findMidptPtsEtc = this.findMidptPtsEtc(edge, pairInfo), midptPts = _this$findMidptPtsEtc.midptPts, vectorNormInverse = _this$findMidptPtsEtc.vectorNormInverse; + var adjustedMidpt = { + x: midptPts.x1 * w1 + midptPts.x2 * w22, + y: midptPts.y1 * w1 + midptPts.y2 * w22 + }; + rs.segpts.push(adjustedMidpt.x + vectorNormInverse.x * d, adjustedMidpt.y + vectorNormInverse.y * d); + } + }; + BRp$c.findLoopPoints = function(edge, pairInfo, i3, edgeIsUnbundled) { + var rs = edge._private.rscratch; + var dirCounts = pairInfo.dirCounts, srcPos = pairInfo.srcPos; + var ctrlptDists = edge.pstyle("control-point-distances"); + var ctrlptDist = ctrlptDists ? ctrlptDists.pfValue[0] : void 0; + var loopDir = edge.pstyle("loop-direction").pfValue; + var loopSwp = edge.pstyle("loop-sweep").pfValue; + var stepSize = edge.pstyle("control-point-step-size").pfValue; + rs.edgeType = "self"; + var j = i3; + var loopDist = stepSize; + if (edgeIsUnbundled) { + j = 0; + loopDist = ctrlptDist; + } + var loopAngle = loopDir - Math.PI / 2; + var outAngle = loopAngle - loopSwp / 2; + var inAngle = loopAngle + loopSwp / 2; + var dc = String(loopDir + "_" + loopSwp); + j = dirCounts[dc] === void 0 ? dirCounts[dc] = 0 : ++dirCounts[dc]; + rs.ctrlpts = [srcPos.x + Math.cos(outAngle) * 1.4 * loopDist * (j / 3 + 1), srcPos.y + Math.sin(outAngle) * 1.4 * loopDist * (j / 3 + 1), srcPos.x + Math.cos(inAngle) * 1.4 * loopDist * (j / 3 + 1), srcPos.y + Math.sin(inAngle) * 1.4 * loopDist * (j / 3 + 1)]; + }; + BRp$c.findCompoundLoopPoints = function(edge, pairInfo, i3, edgeIsUnbundled) { + var rs = edge._private.rscratch; + rs.edgeType = "compound"; + var srcPos = pairInfo.srcPos, tgtPos = pairInfo.tgtPos, srcW = pairInfo.srcW, srcH = pairInfo.srcH, tgtW = pairInfo.tgtW, tgtH = pairInfo.tgtH; + var stepSize = edge.pstyle("control-point-step-size").pfValue; + var ctrlptDists = edge.pstyle("control-point-distances"); + var ctrlptDist = ctrlptDists ? ctrlptDists.pfValue[0] : void 0; + var j = i3; + var loopDist = stepSize; + if (edgeIsUnbundled) { + j = 0; + loopDist = ctrlptDist; + } + var loopW = 50; + var loopaPos = { + x: srcPos.x - srcW / 2, + y: srcPos.y - srcH / 2 + }; + var loopbPos = { + x: tgtPos.x - tgtW / 2, + y: tgtPos.y - tgtH / 2 + }; + var loopPos = { + x: Math.min(loopaPos.x, loopbPos.x), + y: Math.min(loopaPos.y, loopbPos.y) + }; + var minCompoundStretch = 0.5; + var compoundStretchA = Math.max(minCompoundStretch, Math.log(srcW * 0.01)); + var compoundStretchB = Math.max(minCompoundStretch, Math.log(tgtW * 0.01)); + rs.ctrlpts = [loopPos.x, loopPos.y - (1 + Math.pow(loopW, 1.12) / 100) * loopDist * (j / 3 + 1) * compoundStretchA, loopPos.x - (1 + Math.pow(loopW, 1.12) / 100) * loopDist * (j / 3 + 1) * compoundStretchB, loopPos.y]; + }; + BRp$c.findStraightEdgePoints = function(edge) { + edge._private.rscratch.edgeType = "straight"; + }; + BRp$c.findBezierPoints = function(edge, pairInfo, i3, edgeIsUnbundled, edgeIsSwapped) { + var rs = edge._private.rscratch; + var stepSize = edge.pstyle("control-point-step-size").pfValue; + var ctrlptDists = edge.pstyle("control-point-distances"); + var ctrlptWs = edge.pstyle("control-point-weights"); + var bezierN = ctrlptDists && ctrlptWs ? Math.min(ctrlptDists.value.length, ctrlptWs.value.length) : 1; + var ctrlptDist = ctrlptDists ? ctrlptDists.pfValue[0] : void 0; + var ctrlptWeight = ctrlptWs.value[0]; + var multi = edgeIsUnbundled; + rs.edgeType = multi ? "multibezier" : "bezier"; + rs.ctrlpts = []; + for (var b = 0; b < bezierN; b++) { + var normctrlptDist = (0.5 - pairInfo.eles.length / 2 + i3) * stepSize * (edgeIsSwapped ? -1 : 1); + var manctrlptDist = void 0; + var sign2 = signum(normctrlptDist); + if (multi) { + ctrlptDist = ctrlptDists ? ctrlptDists.pfValue[b] : stepSize; + ctrlptWeight = ctrlptWs.value[b]; + } + if (edgeIsUnbundled) { + manctrlptDist = ctrlptDist; + } else { + manctrlptDist = ctrlptDist !== void 0 ? sign2 * ctrlptDist : void 0; + } + var distanceFromMidpoint = manctrlptDist !== void 0 ? manctrlptDist : normctrlptDist; + var w1 = 1 - ctrlptWeight; + var w2 = ctrlptWeight; + var _this$findMidptPtsEtc2 = this.findMidptPtsEtc(edge, pairInfo), midptPts = _this$findMidptPtsEtc2.midptPts, vectorNormInverse = _this$findMidptPtsEtc2.vectorNormInverse; + var adjustedMidpt = { + x: midptPts.x1 * w1 + midptPts.x2 * w2, + y: midptPts.y1 * w1 + midptPts.y2 * w2 + }; + rs.ctrlpts.push(adjustedMidpt.x + vectorNormInverse.x * distanceFromMidpoint, adjustedMidpt.y + vectorNormInverse.y * distanceFromMidpoint); + } + }; + BRp$c.findTaxiPoints = function(edge, pairInfo) { + var rs = edge._private.rscratch; + rs.edgeType = "segments"; + var VERTICAL = "vertical"; + var HORIZONTAL = "horizontal"; + var LEFTWARD = "leftward"; + var RIGHTWARD = "rightward"; + var DOWNWARD = "downward"; + var UPWARD = "upward"; + var AUTO = "auto"; + var posPts = pairInfo.posPts, srcW = pairInfo.srcW, srcH = pairInfo.srcH, tgtW = pairInfo.tgtW, tgtH = pairInfo.tgtH; + var edgeDistances = edge.pstyle("edge-distances").value; + var dIncludesNodeBody = edgeDistances !== "node-position"; + var taxiDir = edge.pstyle("taxi-direction").value; + var rawTaxiDir = taxiDir; + var taxiTurn = edge.pstyle("taxi-turn"); + var turnIsPercent = taxiTurn.units === "%"; + var taxiTurnPfVal = taxiTurn.pfValue; + var turnIsNegative = taxiTurnPfVal < 0; + var minD = edge.pstyle("taxi-turn-min-distance").pfValue; + var dw = dIncludesNodeBody ? (srcW + tgtW) / 2 : 0; + var dh = dIncludesNodeBody ? (srcH + tgtH) / 2 : 0; + var pdx = posPts.x2 - posPts.x1; + var pdy = posPts.y2 - posPts.y1; + var subDWH = function subDWH2(dxy, dwh) { + if (dxy > 0) { + return Math.max(dxy - dwh, 0); + } else { + return Math.min(dxy + dwh, 0); + } + }; + var dx = subDWH(pdx, dw); + var dy = subDWH(pdy, dh); + var isExplicitDir = false; + if (rawTaxiDir === AUTO) { + taxiDir = Math.abs(dx) > Math.abs(dy) ? HORIZONTAL : VERTICAL; + } else if (rawTaxiDir === UPWARD || rawTaxiDir === DOWNWARD) { + taxiDir = VERTICAL; + isExplicitDir = true; + } else if (rawTaxiDir === LEFTWARD || rawTaxiDir === RIGHTWARD) { + taxiDir = HORIZONTAL; + isExplicitDir = true; + } + var isVert = taxiDir === VERTICAL; + var l = isVert ? dy : dx; + var pl = isVert ? pdy : pdx; + var sgnL = signum(pl); + var forcedDir = false; + if (!(isExplicitDir && (turnIsPercent || turnIsNegative)) && (rawTaxiDir === DOWNWARD && pl < 0 || rawTaxiDir === UPWARD && pl > 0 || rawTaxiDir === LEFTWARD && pl > 0 || rawTaxiDir === RIGHTWARD && pl < 0)) { + sgnL *= -1; + l = sgnL * Math.abs(l); + forcedDir = true; + } + var d; + if (turnIsPercent) { + var p2 = taxiTurnPfVal < 0 ? 1 + taxiTurnPfVal : taxiTurnPfVal; + d = p2 * l; + } else { + var k = taxiTurnPfVal < 0 ? l : 0; + d = k + taxiTurnPfVal * sgnL; + } + var getIsTooClose = function getIsTooClose2(d2) { + return Math.abs(d2) < minD || Math.abs(d2) >= Math.abs(l); + }; + var isTooCloseSrc = getIsTooClose(d); + var isTooCloseTgt = getIsTooClose(Math.abs(l) - Math.abs(d)); + var isTooClose = isTooCloseSrc || isTooCloseTgt; + if (isTooClose && !forcedDir) { + if (isVert) { + var lShapeInsideSrc = Math.abs(pl) <= srcH / 2; + var lShapeInsideTgt = Math.abs(pdx) <= tgtW / 2; + if (lShapeInsideSrc) { + var x2 = (posPts.x1 + posPts.x2) / 2; + var y1 = posPts.y1, y2 = posPts.y2; + rs.segpts = [x2, y1, x2, y2]; + } else if (lShapeInsideTgt) { + var y3 = (posPts.y1 + posPts.y2) / 2; + var x1 = posPts.x1, x22 = posPts.x2; + rs.segpts = [x1, y3, x22, y3]; + } else { + rs.segpts = [posPts.x1, posPts.y2]; + } + } else { + var _lShapeInsideSrc = Math.abs(pl) <= srcW / 2; + var _lShapeInsideTgt = Math.abs(pdy) <= tgtH / 2; + if (_lShapeInsideSrc) { + var _y = (posPts.y1 + posPts.y2) / 2; + var _x = posPts.x1, _x2 = posPts.x2; + rs.segpts = [_x, _y, _x2, _y]; + } else if (_lShapeInsideTgt) { + var _x3 = (posPts.x1 + posPts.x2) / 2; + var _y2 = posPts.y1, _y3 = posPts.y2; + rs.segpts = [_x3, _y2, _x3, _y3]; + } else { + rs.segpts = [posPts.x2, posPts.y1]; + } + } + } else { + if (isVert) { + var _y4 = posPts.y1 + d + (dIncludesNodeBody ? srcH / 2 * sgnL : 0); + var _x4 = posPts.x1, _x5 = posPts.x2; + rs.segpts = [_x4, _y4, _x5, _y4]; + } else { + var _x6 = posPts.x1 + d + (dIncludesNodeBody ? srcW / 2 * sgnL : 0); + var _y5 = posPts.y1, _y6 = posPts.y2; + rs.segpts = [_x6, _y5, _x6, _y6]; + } + } + }; + BRp$c.tryToCorrectInvalidPoints = function(edge, pairInfo) { + var rs = edge._private.rscratch; + if (rs.edgeType === "bezier") { + var srcPos = pairInfo.srcPos, tgtPos = pairInfo.tgtPos, srcW = pairInfo.srcW, srcH = pairInfo.srcH, tgtW = pairInfo.tgtW, tgtH = pairInfo.tgtH, srcShape = pairInfo.srcShape, tgtShape = pairInfo.tgtShape; + var badStart = !number$12(rs.startX) || !number$12(rs.startY); + var badAStart = !number$12(rs.arrowStartX) || !number$12(rs.arrowStartY); + var badEnd = !number$12(rs.endX) || !number$12(rs.endY); + var badAEnd = !number$12(rs.arrowEndX) || !number$12(rs.arrowEndY); + var minCpADistFactor = 3; + var arrowW = this.getArrowWidth(edge.pstyle("width").pfValue, edge.pstyle("arrow-scale").value) * this.arrowShapeWidth; + var minCpADist = minCpADistFactor * arrowW; + var startACpDist = dist2({ + x: rs.ctrlpts[0], + y: rs.ctrlpts[1] + }, { + x: rs.startX, + y: rs.startY + }); + var closeStartACp = startACpDist < minCpADist; + var endACpDist = dist2({ + x: rs.ctrlpts[0], + y: rs.ctrlpts[1] + }, { + x: rs.endX, + y: rs.endY + }); + var closeEndACp = endACpDist < minCpADist; + var overlapping = false; + if (badStart || badAStart || closeStartACp) { + overlapping = true; + var cpD = { + // delta + x: rs.ctrlpts[0] - srcPos.x, + y: rs.ctrlpts[1] - srcPos.y + }; + var cpL = Math.sqrt(cpD.x * cpD.x + cpD.y * cpD.y); + var cpM = { + // normalised delta + x: cpD.x / cpL, + y: cpD.y / cpL + }; + var radius = Math.max(srcW, srcH); + var cpProj = { + // *2 radius guarantees outside shape + x: rs.ctrlpts[0] + cpM.x * 2 * radius, + y: rs.ctrlpts[1] + cpM.y * 2 * radius + }; + var srcCtrlPtIntn = srcShape.intersectLine(srcPos.x, srcPos.y, srcW, srcH, cpProj.x, cpProj.y, 0); + if (closeStartACp) { + rs.ctrlpts[0] = rs.ctrlpts[0] + cpM.x * (minCpADist - startACpDist); + rs.ctrlpts[1] = rs.ctrlpts[1] + cpM.y * (minCpADist - startACpDist); + } else { + rs.ctrlpts[0] = srcCtrlPtIntn[0] + cpM.x * minCpADist; + rs.ctrlpts[1] = srcCtrlPtIntn[1] + cpM.y * minCpADist; + } + } + if (badEnd || badAEnd || closeEndACp) { + overlapping = true; + var _cpD = { + // delta + x: rs.ctrlpts[0] - tgtPos.x, + y: rs.ctrlpts[1] - tgtPos.y + }; + var _cpL = Math.sqrt(_cpD.x * _cpD.x + _cpD.y * _cpD.y); + var _cpM = { + // normalised delta + x: _cpD.x / _cpL, + y: _cpD.y / _cpL + }; + var _radius = Math.max(srcW, srcH); + var _cpProj = { + // *2 radius guarantees outside shape + x: rs.ctrlpts[0] + _cpM.x * 2 * _radius, + y: rs.ctrlpts[1] + _cpM.y * 2 * _radius + }; + var tgtCtrlPtIntn = tgtShape.intersectLine(tgtPos.x, tgtPos.y, tgtW, tgtH, _cpProj.x, _cpProj.y, 0); + if (closeEndACp) { + rs.ctrlpts[0] = rs.ctrlpts[0] + _cpM.x * (minCpADist - endACpDist); + rs.ctrlpts[1] = rs.ctrlpts[1] + _cpM.y * (minCpADist - endACpDist); + } else { + rs.ctrlpts[0] = tgtCtrlPtIntn[0] + _cpM.x * minCpADist; + rs.ctrlpts[1] = tgtCtrlPtIntn[1] + _cpM.y * minCpADist; + } + } + if (overlapping) { + this.findEndpoints(edge); + } + } + }; + BRp$c.storeAllpts = function(edge) { + var rs = edge._private.rscratch; + if (rs.edgeType === "multibezier" || rs.edgeType === "bezier" || rs.edgeType === "self" || rs.edgeType === "compound") { + rs.allpts = []; + rs.allpts.push(rs.startX, rs.startY); + for (var b = 0; b + 1 < rs.ctrlpts.length; b += 2) { + rs.allpts.push(rs.ctrlpts[b], rs.ctrlpts[b + 1]); + if (b + 3 < rs.ctrlpts.length) { + rs.allpts.push((rs.ctrlpts[b] + rs.ctrlpts[b + 2]) / 2, (rs.ctrlpts[b + 1] + rs.ctrlpts[b + 3]) / 2); + } + } + rs.allpts.push(rs.endX, rs.endY); + var m, mt; + if (rs.ctrlpts.length / 2 % 2 === 0) { + m = rs.allpts.length / 2 - 1; + rs.midX = rs.allpts[m]; + rs.midY = rs.allpts[m + 1]; + } else { + m = rs.allpts.length / 2 - 3; + mt = 0.5; + rs.midX = qbezierAt(rs.allpts[m], rs.allpts[m + 2], rs.allpts[m + 4], mt); + rs.midY = qbezierAt(rs.allpts[m + 1], rs.allpts[m + 3], rs.allpts[m + 5], mt); + } + } else if (rs.edgeType === "straight") { + rs.allpts = [rs.startX, rs.startY, rs.endX, rs.endY]; + rs.midX = (rs.startX + rs.endX + rs.arrowStartX + rs.arrowEndX) / 4; + rs.midY = (rs.startY + rs.endY + rs.arrowStartY + rs.arrowEndY) / 4; + } else if (rs.edgeType === "segments") { + rs.allpts = []; + rs.allpts.push(rs.startX, rs.startY); + rs.allpts.push.apply(rs.allpts, rs.segpts); + rs.allpts.push(rs.endX, rs.endY); + if (rs.segpts.length % 4 === 0) { + var i22 = rs.segpts.length / 2; + var i1 = i22 - 2; + rs.midX = (rs.segpts[i1] + rs.segpts[i22]) / 2; + rs.midY = (rs.segpts[i1 + 1] + rs.segpts[i22 + 1]) / 2; + } else { + var _i6 = rs.segpts.length / 2 - 1; + rs.midX = rs.segpts[_i6]; + rs.midY = rs.segpts[_i6 + 1]; + } + } + }; + BRp$c.checkForInvalidEdgeWarning = function(edge) { + var rs = edge[0]._private.rscratch; + if (rs.nodesOverlap || number$12(rs.startX) && number$12(rs.startY) && number$12(rs.endX) && number$12(rs.endY)) { + rs.loggedErr = false; + } else { + if (!rs.loggedErr) { + rs.loggedErr = true; + warn("Edge `" + edge.id() + "` has invalid endpoints and so it is impossible to draw. Adjust your edge style (e.g. control points) accordingly or use an alternative edge type. This is expected behaviour when the source node and the target node overlap."); + } + } + }; + BRp$c.findEdgeControlPoints = function(edges2) { + var _this = this; + if (!edges2 || edges2.length === 0) { + return; + } + var r = this; + var cy = r.cy; + var hasCompounds = cy.hasCompoundNodes(); + var hashTable = { + map: new Map$22(), + get: function get3(pairId2) { + var map2 = this.map.get(pairId2[0]); + if (map2 != null) { + return map2.get(pairId2[1]); + } else { + return null; + } + }, + set: function set3(pairId2, val) { + var map2 = this.map.get(pairId2[0]); + if (map2 == null) { + map2 = new Map$22(); + this.map.set(pairId2[0], map2); + } + map2.set(pairId2[1], val); + } + }; + var pairIds = []; + var haystackEdges = []; + for (var i3 = 0; i3 < edges2.length; i3++) { + var edge = edges2[i3]; + var _p = edge._private; + var curveStyle = edge.pstyle("curve-style").value; + if (edge.removed() || !edge.takesUpSpace()) { + continue; + } + if (curveStyle === "haystack") { + haystackEdges.push(edge); + continue; + } + var edgeIsUnbundled = curveStyle === "unbundled-bezier" || curveStyle === "segments" || curveStyle === "straight" || curveStyle === "straight-triangle" || curveStyle === "taxi"; + var edgeIsBezier = curveStyle === "unbundled-bezier" || curveStyle === "bezier"; + var src = _p.source; + var tgt = _p.target; + var srcIndex = src.poolIndex(); + var tgtIndex = tgt.poolIndex(); + var pairId = [srcIndex, tgtIndex].sort(); + var tableEntry = hashTable.get(pairId); + if (tableEntry == null) { + tableEntry = { + eles: [] + }; + hashTable.set(pairId, tableEntry); + pairIds.push(pairId); + } + tableEntry.eles.push(edge); + if (edgeIsUnbundled) { + tableEntry.hasUnbundled = true; + } + if (edgeIsBezier) { + tableEntry.hasBezier = true; + } + } + var _loop = function _loop2(p3) { + var pairId2 = pairIds[p3]; + var pairInfo = hashTable.get(pairId2); + var swappedpairInfo = void 0; + if (!pairInfo.hasUnbundled) { + var pllEdges = pairInfo.eles[0].parallelEdges().filter(function(e) { + return e.isBundledBezier(); + }); + clearArray(pairInfo.eles); + pllEdges.forEach(function(edge2) { + return pairInfo.eles.push(edge2); + }); + pairInfo.eles.sort(function(edge1, edge2) { + return edge1.poolIndex() - edge2.poolIndex(); + }); + } + var firstEdge = pairInfo.eles[0]; + var src2 = firstEdge.source(); + var tgt2 = firstEdge.target(); + if (src2.poolIndex() > tgt2.poolIndex()) { + var temp = src2; + src2 = tgt2; + tgt2 = temp; + } + var srcPos = pairInfo.srcPos = src2.position(); + var tgtPos = pairInfo.tgtPos = tgt2.position(); + var srcW = pairInfo.srcW = src2.outerWidth(); + var srcH = pairInfo.srcH = src2.outerHeight(); + var tgtW = pairInfo.tgtW = tgt2.outerWidth(); + var tgtH = pairInfo.tgtH = tgt2.outerHeight(); + var srcShape = pairInfo.srcShape = r.nodeShapes[_this.getNodeShape(src2)]; + var tgtShape = pairInfo.tgtShape = r.nodeShapes[_this.getNodeShape(tgt2)]; + pairInfo.dirCounts = { + "north": 0, + "west": 0, + "south": 0, + "east": 0, + "northwest": 0, + "southwest": 0, + "northeast": 0, + "southeast": 0 + }; + for (var _i22 = 0; _i22 < pairInfo.eles.length; _i22++) { + var _edge = pairInfo.eles[_i22]; + var rs = _edge[0]._private.rscratch; + var _curveStyle = _edge.pstyle("curve-style").value; + var _edgeIsUnbundled = _curveStyle === "unbundled-bezier" || _curveStyle === "segments" || _curveStyle === "taxi"; + var edgeIsSwapped = !src2.same(_edge.source()); + if (!pairInfo.calculatedIntersection && src2 !== tgt2 && (pairInfo.hasBezier || pairInfo.hasUnbundled)) { + pairInfo.calculatedIntersection = true; + var srcOutside = srcShape.intersectLine(srcPos.x, srcPos.y, srcW, srcH, tgtPos.x, tgtPos.y, 0); + var srcIntn = pairInfo.srcIntn = srcOutside; + var tgtOutside = tgtShape.intersectLine(tgtPos.x, tgtPos.y, tgtW, tgtH, srcPos.x, srcPos.y, 0); + var tgtIntn = pairInfo.tgtIntn = tgtOutside; + var intersectionPts = pairInfo.intersectionPts = { + x1: srcOutside[0], + x2: tgtOutside[0], + y1: srcOutside[1], + y2: tgtOutside[1] + }; + var posPts = pairInfo.posPts = { + x1: srcPos.x, + x2: tgtPos.x, + y1: srcPos.y, + y2: tgtPos.y + }; + var dy = tgtOutside[1] - srcOutside[1]; + var dx = tgtOutside[0] - srcOutside[0]; + var l = Math.sqrt(dx * dx + dy * dy); + var vector = pairInfo.vector = { + x: dx, + y: dy + }; + var vectorNorm = pairInfo.vectorNorm = { + x: vector.x / l, + y: vector.y / l + }; + var vectorNormInverse = { + x: -vectorNorm.y, + y: vectorNorm.x + }; + pairInfo.nodesOverlap = !number$12(l) || tgtShape.checkPoint(srcOutside[0], srcOutside[1], 0, tgtW, tgtH, tgtPos.x, tgtPos.y) || srcShape.checkPoint(tgtOutside[0], tgtOutside[1], 0, srcW, srcH, srcPos.x, srcPos.y); + pairInfo.vectorNormInverse = vectorNormInverse; + swappedpairInfo = { + nodesOverlap: pairInfo.nodesOverlap, + dirCounts: pairInfo.dirCounts, + calculatedIntersection: true, + hasBezier: pairInfo.hasBezier, + hasUnbundled: pairInfo.hasUnbundled, + eles: pairInfo.eles, + srcPos: tgtPos, + tgtPos: srcPos, + srcW: tgtW, + srcH: tgtH, + tgtW: srcW, + tgtH: srcH, + srcIntn: tgtIntn, + tgtIntn: srcIntn, + srcShape: tgtShape, + tgtShape: srcShape, + posPts: { + x1: posPts.x2, + y1: posPts.y2, + x2: posPts.x1, + y2: posPts.y1 + }, + intersectionPts: { + x1: intersectionPts.x2, + y1: intersectionPts.y2, + x2: intersectionPts.x1, + y2: intersectionPts.y1 + }, + vector: { + x: -vector.x, + y: -vector.y + }, + vectorNorm: { + x: -vectorNorm.x, + y: -vectorNorm.y + }, + vectorNormInverse: { + x: -vectorNormInverse.x, + y: -vectorNormInverse.y + } + }; + } + var passedPairInfo = edgeIsSwapped ? swappedpairInfo : pairInfo; + rs.nodesOverlap = passedPairInfo.nodesOverlap; + rs.srcIntn = passedPairInfo.srcIntn; + rs.tgtIntn = passedPairInfo.tgtIntn; + if (hasCompounds && (src2.isParent() || src2.isChild() || tgt2.isParent() || tgt2.isChild()) && (src2.parents().anySame(tgt2) || tgt2.parents().anySame(src2) || src2.same(tgt2) && src2.isParent())) { + _this.findCompoundLoopPoints(_edge, passedPairInfo, _i22, _edgeIsUnbundled); + } else if (src2 === tgt2) { + _this.findLoopPoints(_edge, passedPairInfo, _i22, _edgeIsUnbundled); + } else if (_curveStyle === "segments") { + _this.findSegmentsPoints(_edge, passedPairInfo); + } else if (_curveStyle === "taxi") { + _this.findTaxiPoints(_edge, passedPairInfo); + } else if (_curveStyle === "straight" || !_edgeIsUnbundled && pairInfo.eles.length % 2 === 1 && _i22 === Math.floor(pairInfo.eles.length / 2)) { + _this.findStraightEdgePoints(_edge); + } else { + _this.findBezierPoints(_edge, passedPairInfo, _i22, _edgeIsUnbundled, edgeIsSwapped); + } + _this.findEndpoints(_edge); + _this.tryToCorrectInvalidPoints(_edge, passedPairInfo); + _this.checkForInvalidEdgeWarning(_edge); + _this.storeAllpts(_edge); + _this.storeEdgeProjections(_edge); + _this.calculateArrowAngles(_edge); + _this.recalculateEdgeLabelProjections(_edge); + _this.calculateLabelAngles(_edge); + } + }; + for (var p2 = 0; p2 < pairIds.length; p2++) { + _loop(p2); + } + this.findHaystackPoints(haystackEdges); + }; + function getPts(pts2) { + var retPts = []; + if (pts2 == null) { + return; + } + for (var i3 = 0; i3 < pts2.length; i3 += 2) { + var x2 = pts2[i3]; + var y2 = pts2[i3 + 1]; + retPts.push({ + x: x2, + y: y2 + }); + } + return retPts; + } + BRp$c.getSegmentPoints = function(edge) { + var rs = edge[0]._private.rscratch; + var type2 = rs.edgeType; + if (type2 === "segments") { + this.recalculateRenderedStyle(edge); + return getPts(rs.segpts); + } + }; + BRp$c.getControlPoints = function(edge) { + var rs = edge[0]._private.rscratch; + var type2 = rs.edgeType; + if (type2 === "bezier" || type2 === "multibezier" || type2 === "self" || type2 === "compound") { + this.recalculateRenderedStyle(edge); + return getPts(rs.ctrlpts); + } + }; + BRp$c.getEdgeMidpoint = function(edge) { + var rs = edge[0]._private.rscratch; + this.recalculateRenderedStyle(edge); + return { + x: rs.midX, + y: rs.midY + }; + }; + var BRp$b = {}; + BRp$b.manualEndptToPx = function(node2, prop) { + var r = this; + var npos = node2.position(); + var w2 = node2.outerWidth(); + var h = node2.outerHeight(); + if (prop.value.length === 2) { + var p2 = [prop.pfValue[0], prop.pfValue[1]]; + if (prop.units[0] === "%") { + p2[0] = p2[0] * w2; + } + if (prop.units[1] === "%") { + p2[1] = p2[1] * h; + } + p2[0] += npos.x; + p2[1] += npos.y; + return p2; + } else { + var angle = prop.pfValue[0]; + angle = -Math.PI / 2 + angle; + var l = 2 * Math.max(w2, h); + var _p = [npos.x + Math.cos(angle) * l, npos.y + Math.sin(angle) * l]; + return r.nodeShapes[this.getNodeShape(node2)].intersectLine(npos.x, npos.y, w2, h, _p[0], _p[1], 0); + } + }; + BRp$b.findEndpoints = function(edge) { + var r = this; + var intersect2; + var source = edge.source()[0]; + var target = edge.target()[0]; + var srcPos = source.position(); + var tgtPos = target.position(); + var tgtArShape = edge.pstyle("target-arrow-shape").value; + var srcArShape = edge.pstyle("source-arrow-shape").value; + var tgtDist = edge.pstyle("target-distance-from-node").pfValue; + var srcDist = edge.pstyle("source-distance-from-node").pfValue; + var curveStyle = edge.pstyle("curve-style").value; + var rs = edge._private.rscratch; + var et = rs.edgeType; + var taxi = curveStyle === "taxi"; + var self2 = et === "self" || et === "compound"; + var bezier = et === "bezier" || et === "multibezier" || self2; + var multi = et !== "bezier"; + var lines = et === "straight" || et === "segments"; + var segments = et === "segments"; + var hasEndpts = bezier || multi || lines; + var overrideEndpts = self2 || taxi; + var srcManEndpt = edge.pstyle("source-endpoint"); + var srcManEndptVal = overrideEndpts ? "outside-to-node" : srcManEndpt.value; + var tgtManEndpt = edge.pstyle("target-endpoint"); + var tgtManEndptVal = overrideEndpts ? "outside-to-node" : tgtManEndpt.value; + rs.srcManEndpt = srcManEndpt; + rs.tgtManEndpt = tgtManEndpt; + var p1; + var p2; + var p1_i; + var p2_i; + if (bezier) { + var cpStart = [rs.ctrlpts[0], rs.ctrlpts[1]]; + var cpEnd = multi ? [rs.ctrlpts[rs.ctrlpts.length - 2], rs.ctrlpts[rs.ctrlpts.length - 1]] : cpStart; + p1 = cpEnd; + p2 = cpStart; + } else if (lines) { + var srcArrowFromPt = !segments ? [tgtPos.x, tgtPos.y] : rs.segpts.slice(0, 2); + var tgtArrowFromPt = !segments ? [srcPos.x, srcPos.y] : rs.segpts.slice(rs.segpts.length - 2); + p1 = tgtArrowFromPt; + p2 = srcArrowFromPt; + } + if (tgtManEndptVal === "inside-to-node") { + intersect2 = [tgtPos.x, tgtPos.y]; + } else if (tgtManEndpt.units) { + intersect2 = this.manualEndptToPx(target, tgtManEndpt); + } else if (tgtManEndptVal === "outside-to-line") { + intersect2 = rs.tgtIntn; + } else { + if (tgtManEndptVal === "outside-to-node" || tgtManEndptVal === "outside-to-node-or-label") { + p1_i = p1; + } else if (tgtManEndptVal === "outside-to-line" || tgtManEndptVal === "outside-to-line-or-label") { + p1_i = [srcPos.x, srcPos.y]; + } + intersect2 = r.nodeShapes[this.getNodeShape(target)].intersectLine(tgtPos.x, tgtPos.y, target.outerWidth(), target.outerHeight(), p1_i[0], p1_i[1], 0); + if (tgtManEndptVal === "outside-to-node-or-label" || tgtManEndptVal === "outside-to-line-or-label") { + var trs = target._private.rscratch; + var lw = trs.labelWidth; + var lh = trs.labelHeight; + var lx = trs.labelX; + var ly = trs.labelY; + var lw2 = lw / 2; + var lh2 = lh / 2; + var va = target.pstyle("text-valign").value; + if (va === "top") { + ly -= lh2; + } else if (va === "bottom") { + ly += lh2; + } + var ha = target.pstyle("text-halign").value; + if (ha === "left") { + lx -= lw2; + } else if (ha === "right") { + lx += lw2; + } + var labelIntersect = polygonIntersectLine(p1_i[0], p1_i[1], [lx - lw2, ly - lh2, lx + lw2, ly - lh2, lx + lw2, ly + lh2, lx - lw2, ly + lh2], tgtPos.x, tgtPos.y); + if (labelIntersect.length > 0) { + var refPt = srcPos; + var intSqdist = sqdist(refPt, array2point(intersect2)); + var labIntSqdist = sqdist(refPt, array2point(labelIntersect)); + var minSqDist = intSqdist; + if (labIntSqdist < intSqdist) { + intersect2 = labelIntersect; + minSqDist = labIntSqdist; + } + if (labelIntersect.length > 2) { + var labInt2SqDist = sqdist(refPt, { + x: labelIntersect[2], + y: labelIntersect[3] + }); + if (labInt2SqDist < minSqDist) { + intersect2 = [labelIntersect[2], labelIntersect[3]]; + } + } + } + } + } + var arrowEnd = shortenIntersection(intersect2, p1, r.arrowShapes[tgtArShape].spacing(edge) + tgtDist); + var edgeEnd = shortenIntersection(intersect2, p1, r.arrowShapes[tgtArShape].gap(edge) + tgtDist); + rs.endX = edgeEnd[0]; + rs.endY = edgeEnd[1]; + rs.arrowEndX = arrowEnd[0]; + rs.arrowEndY = arrowEnd[1]; + if (srcManEndptVal === "inside-to-node") { + intersect2 = [srcPos.x, srcPos.y]; + } else if (srcManEndpt.units) { + intersect2 = this.manualEndptToPx(source, srcManEndpt); + } else if (srcManEndptVal === "outside-to-line") { + intersect2 = rs.srcIntn; + } else { + if (srcManEndptVal === "outside-to-node" || srcManEndptVal === "outside-to-node-or-label") { + p2_i = p2; + } else if (srcManEndptVal === "outside-to-line" || srcManEndptVal === "outside-to-line-or-label") { + p2_i = [tgtPos.x, tgtPos.y]; + } + intersect2 = r.nodeShapes[this.getNodeShape(source)].intersectLine(srcPos.x, srcPos.y, source.outerWidth(), source.outerHeight(), p2_i[0], p2_i[1], 0); + if (srcManEndptVal === "outside-to-node-or-label" || srcManEndptVal === "outside-to-line-or-label") { + var srs = source._private.rscratch; + var _lw = srs.labelWidth; + var _lh = srs.labelHeight; + var _lx = srs.labelX; + var _ly = srs.labelY; + var _lw2 = _lw / 2; + var _lh2 = _lh / 2; + var _va = source.pstyle("text-valign").value; + if (_va === "top") { + _ly -= _lh2; + } else if (_va === "bottom") { + _ly += _lh2; + } + var _ha = source.pstyle("text-halign").value; + if (_ha === "left") { + _lx -= _lw2; + } else if (_ha === "right") { + _lx += _lw2; + } + var _labelIntersect = polygonIntersectLine(p2_i[0], p2_i[1], [_lx - _lw2, _ly - _lh2, _lx + _lw2, _ly - _lh2, _lx + _lw2, _ly + _lh2, _lx - _lw2, _ly + _lh2], srcPos.x, srcPos.y); + if (_labelIntersect.length > 0) { + var _refPt = tgtPos; + var _intSqdist = sqdist(_refPt, array2point(intersect2)); + var _labIntSqdist = sqdist(_refPt, array2point(_labelIntersect)); + var _minSqDist = _intSqdist; + if (_labIntSqdist < _intSqdist) { + intersect2 = [_labelIntersect[0], _labelIntersect[1]]; + _minSqDist = _labIntSqdist; + } + if (_labelIntersect.length > 2) { + var _labInt2SqDist = sqdist(_refPt, { + x: _labelIntersect[2], + y: _labelIntersect[3] + }); + if (_labInt2SqDist < _minSqDist) { + intersect2 = [_labelIntersect[2], _labelIntersect[3]]; + } + } + } + } + } + var arrowStart = shortenIntersection(intersect2, p2, r.arrowShapes[srcArShape].spacing(edge) + srcDist); + var edgeStart = shortenIntersection(intersect2, p2, r.arrowShapes[srcArShape].gap(edge) + srcDist); + rs.startX = edgeStart[0]; + rs.startY = edgeStart[1]; + rs.arrowStartX = arrowStart[0]; + rs.arrowStartY = arrowStart[1]; + if (hasEndpts) { + if (!number$12(rs.startX) || !number$12(rs.startY) || !number$12(rs.endX) || !number$12(rs.endY)) { + rs.badLine = true; + } else { + rs.badLine = false; + } + } + }; + BRp$b.getSourceEndpoint = function(edge) { + var rs = edge[0]._private.rscratch; + this.recalculateRenderedStyle(edge); + switch (rs.edgeType) { + case "haystack": + return { + x: rs.haystackPts[0], + y: rs.haystackPts[1] + }; + default: + return { + x: rs.arrowStartX, + y: rs.arrowStartY + }; + } + }; + BRp$b.getTargetEndpoint = function(edge) { + var rs = edge[0]._private.rscratch; + this.recalculateRenderedStyle(edge); + switch (rs.edgeType) { + case "haystack": + return { + x: rs.haystackPts[2], + y: rs.haystackPts[3] + }; + default: + return { + x: rs.arrowEndX, + y: rs.arrowEndY + }; + } + }; + var BRp$a = {}; + function pushBezierPts(r, edge, pts2) { + var qbezierAt$1 = function qbezierAt$12(p1, p22, p3, t) { + return qbezierAt(p1, p22, p3, t); + }; + var _p = edge._private; + var bpts = _p.rstyle.bezierPts; + for (var i3 = 0; i3 < r.bezierProjPcts.length; i3++) { + var p2 = r.bezierProjPcts[i3]; + bpts.push({ + x: qbezierAt$1(pts2[0], pts2[2], pts2[4], p2), + y: qbezierAt$1(pts2[1], pts2[3], pts2[5], p2) + }); + } + } + BRp$a.storeEdgeProjections = function(edge) { + var _p = edge._private; + var rs = _p.rscratch; + var et = rs.edgeType; + _p.rstyle.bezierPts = null; + _p.rstyle.linePts = null; + _p.rstyle.haystackPts = null; + if (et === "multibezier" || et === "bezier" || et === "self" || et === "compound") { + _p.rstyle.bezierPts = []; + for (var i3 = 0; i3 + 5 < rs.allpts.length; i3 += 4) { + pushBezierPts(this, edge, rs.allpts.slice(i3, i3 + 6)); + } + } else if (et === "segments") { + var lpts = _p.rstyle.linePts = []; + for (var i3 = 0; i3 + 1 < rs.allpts.length; i3 += 2) { + lpts.push({ + x: rs.allpts[i3], + y: rs.allpts[i3 + 1] + }); + } + } else if (et === "haystack") { + var hpts = rs.haystackPts; + _p.rstyle.haystackPts = [{ + x: hpts[0], + y: hpts[1] + }, { + x: hpts[2], + y: hpts[3] + }]; + } + _p.rstyle.arrowWidth = this.getArrowWidth(edge.pstyle("width").pfValue, edge.pstyle("arrow-scale").value) * this.arrowShapeWidth; + }; + BRp$a.recalculateEdgeProjections = function(edges2) { + this.findEdgeControlPoints(edges2); + }; + var BRp$9 = {}; + BRp$9.recalculateNodeLabelProjection = function(node2) { + var content2 = node2.pstyle("label").strValue; + if (emptyString(content2)) { + return; + } + var textX, textY; + var _p = node2._private; + var nodeWidth = node2.width(); + var nodeHeight = node2.height(); + var padding2 = node2.padding(); + var nodePos = node2.position(); + var textHalign = node2.pstyle("text-halign").strValue; + var textValign = node2.pstyle("text-valign").strValue; + var rs = _p.rscratch; + var rstyle = _p.rstyle; + switch (textHalign) { + case "left": + textX = nodePos.x - nodeWidth / 2 - padding2; + break; + case "right": + textX = nodePos.x + nodeWidth / 2 + padding2; + break; + default: + textX = nodePos.x; + } + switch (textValign) { + case "top": + textY = nodePos.y - nodeHeight / 2 - padding2; + break; + case "bottom": + textY = nodePos.y + nodeHeight / 2 + padding2; + break; + default: + textY = nodePos.y; + } + rs.labelX = textX; + rs.labelY = textY; + rstyle.labelX = textX; + rstyle.labelY = textY; + this.calculateLabelAngles(node2); + this.applyLabelDimensions(node2); + }; + var lineAngleFromDelta = function lineAngleFromDelta2(dx, dy) { + var angle = Math.atan(dy / dx); + if (dx === 0 && angle < 0) { + angle = angle * -1; + } + return angle; + }; + var lineAngle = function lineAngle2(p0, p1) { + var dx = p1.x - p0.x; + var dy = p1.y - p0.y; + return lineAngleFromDelta(dx, dy); + }; + var bezierAngle = function bezierAngle2(p0, p1, p2, t) { + var t02 = bound(0, t - 1e-3, 1); + var t12 = bound(0, t + 1e-3, 1); + var lp0 = qbezierPtAt(p0, p1, p2, t02); + var lp1 = qbezierPtAt(p0, p1, p2, t12); + return lineAngle(lp0, lp1); + }; + BRp$9.recalculateEdgeLabelProjections = function(edge) { + var p2; + var _p = edge._private; + var rs = _p.rscratch; + var r = this; + var content2 = { + mid: edge.pstyle("label").strValue, + source: edge.pstyle("source-label").strValue, + target: edge.pstyle("target-label").strValue + }; + if (content2.mid || content2.source || content2.target) + ; + else { + return; + } + p2 = { + x: rs.midX, + y: rs.midY + }; + var setRs = function setRs2(propName, prefix, value2) { + setPrefixedProperty(_p.rscratch, propName, prefix, value2); + setPrefixedProperty(_p.rstyle, propName, prefix, value2); + }; + setRs("labelX", null, p2.x); + setRs("labelY", null, p2.y); + var midAngle = lineAngleFromDelta(rs.midDispX, rs.midDispY); + setRs("labelAutoAngle", null, midAngle); + var createControlPointInfo = function createControlPointInfo2() { + if (createControlPointInfo2.cache) { + return createControlPointInfo2.cache; + } + var ctrlpts = []; + for (var i3 = 0; i3 + 5 < rs.allpts.length; i3 += 4) { + var p0 = { + x: rs.allpts[i3], + y: rs.allpts[i3 + 1] + }; + var p1 = { + x: rs.allpts[i3 + 2], + y: rs.allpts[i3 + 3] + }; + var p22 = { + x: rs.allpts[i3 + 4], + y: rs.allpts[i3 + 5] + }; + ctrlpts.push({ + p0, + p1, + p2: p22, + startDist: 0, + length: 0, + segments: [] + }); + } + var bpts = _p.rstyle.bezierPts; + var nProjs = r.bezierProjPcts.length; + function addSegment(cp2, p02, p12, t02, t12) { + var length2 = dist2(p02, p12); + var prevSegment = cp2.segments[cp2.segments.length - 1]; + var segment = { + p0: p02, + p1: p12, + t0: t02, + t1: t12, + startDist: prevSegment ? prevSegment.startDist + prevSegment.length : 0, + length: length2 + }; + cp2.segments.push(segment); + cp2.length += length2; + } + for (var _i6 = 0; _i6 < ctrlpts.length; _i6++) { + var cp = ctrlpts[_i6]; + var prevCp = ctrlpts[_i6 - 1]; + if (prevCp) { + cp.startDist = prevCp.startDist + prevCp.length; + } + addSegment(cp, cp.p0, bpts[_i6 * nProjs], 0, r.bezierProjPcts[0]); + for (var j = 0; j < nProjs - 1; j++) { + addSegment(cp, bpts[_i6 * nProjs + j], bpts[_i6 * nProjs + j + 1], r.bezierProjPcts[j], r.bezierProjPcts[j + 1]); + } + addSegment(cp, bpts[_i6 * nProjs + nProjs - 1], cp.p2, r.bezierProjPcts[nProjs - 1], 1); + } + return createControlPointInfo2.cache = ctrlpts; + }; + var calculateEndProjection = function calculateEndProjection2(prefix) { + var angle; + var isSrc = prefix === "source"; + if (!content2[prefix]) { + return; + } + var offset = edge.pstyle(prefix + "-text-offset").pfValue; + switch (rs.edgeType) { + case "self": + case "compound": + case "bezier": + case "multibezier": { + var cps = createControlPointInfo(); + var selected; + var startDist = 0; + var totalDist = 0; + for (var i3 = 0; i3 < cps.length; i3++) { + var _cp = cps[isSrc ? i3 : cps.length - 1 - i3]; + for (var j = 0; j < _cp.segments.length; j++) { + var _seg = _cp.segments[isSrc ? j : _cp.segments.length - 1 - j]; + var lastSeg = i3 === cps.length - 1 && j === _cp.segments.length - 1; + startDist = totalDist; + totalDist += _seg.length; + if (totalDist >= offset || lastSeg) { + selected = { + cp: _cp, + segment: _seg + }; + break; + } + } + if (selected) { + break; + } + } + var cp = selected.cp; + var seg = selected.segment; + var tSegment = (offset - startDist) / seg.length; + var segDt = seg.t1 - seg.t0; + var t = isSrc ? seg.t0 + segDt * tSegment : seg.t1 - segDt * tSegment; + t = bound(0, t, 1); + p2 = qbezierPtAt(cp.p0, cp.p1, cp.p2, t); + angle = bezierAngle(cp.p0, cp.p1, cp.p2, t); + break; + } + case "straight": + case "segments": + case "haystack": { + var d = 0, di, d0; + var p0, p1; + var l = rs.allpts.length; + for (var _i22 = 0; _i22 + 3 < l; _i22 += 2) { + if (isSrc) { + p0 = { + x: rs.allpts[_i22], + y: rs.allpts[_i22 + 1] + }; + p1 = { + x: rs.allpts[_i22 + 2], + y: rs.allpts[_i22 + 3] + }; + } else { + p0 = { + x: rs.allpts[l - 2 - _i22], + y: rs.allpts[l - 1 - _i22] + }; + p1 = { + x: rs.allpts[l - 4 - _i22], + y: rs.allpts[l - 3 - _i22] + }; + } + di = dist2(p0, p1); + d0 = d; + d += di; + if (d >= offset) { + break; + } + } + var pD = offset - d0; + var _t = pD / di; + _t = bound(0, _t, 1); + p2 = lineAt(p0, p1, _t); + angle = lineAngle(p0, p1); + break; + } + } + setRs("labelX", prefix, p2.x); + setRs("labelY", prefix, p2.y); + setRs("labelAutoAngle", prefix, angle); + }; + calculateEndProjection("source"); + calculateEndProjection("target"); + this.applyLabelDimensions(edge); + }; + BRp$9.applyLabelDimensions = function(ele) { + this.applyPrefixedLabelDimensions(ele); + if (ele.isEdge()) { + this.applyPrefixedLabelDimensions(ele, "source"); + this.applyPrefixedLabelDimensions(ele, "target"); + } + }; + BRp$9.applyPrefixedLabelDimensions = function(ele, prefix) { + var _p = ele._private; + var text2 = this.getLabelText(ele, prefix); + var labelDims = this.calculateLabelDimensions(ele, text2); + var lineHeight = ele.pstyle("line-height").pfValue; + var textWrap = ele.pstyle("text-wrap").strValue; + var lines = getPrefixedProperty(_p.rscratch, "labelWrapCachedLines", prefix) || []; + var numLines = textWrap !== "wrap" ? 1 : Math.max(lines.length, 1); + var normPerLineHeight = labelDims.height / numLines; + var labelLineHeight = normPerLineHeight * lineHeight; + var width2 = labelDims.width; + var height = labelDims.height + (numLines - 1) * (lineHeight - 1) * normPerLineHeight; + setPrefixedProperty(_p.rstyle, "labelWidth", prefix, width2); + setPrefixedProperty(_p.rscratch, "labelWidth", prefix, width2); + setPrefixedProperty(_p.rstyle, "labelHeight", prefix, height); + setPrefixedProperty(_p.rscratch, "labelHeight", prefix, height); + setPrefixedProperty(_p.rscratch, "labelLineHeight", prefix, labelLineHeight); + }; + BRp$9.getLabelText = function(ele, prefix) { + var _p = ele._private; + var pfd = prefix ? prefix + "-" : ""; + var text2 = ele.pstyle(pfd + "label").strValue; + var textTransform = ele.pstyle("text-transform").value; + var rscratch = function rscratch2(propName, value2) { + if (value2) { + setPrefixedProperty(_p.rscratch, propName, prefix, value2); + return value2; + } else { + return getPrefixedProperty(_p.rscratch, propName, prefix); + } + }; + if (!text2) { + return ""; + } + if (textTransform == "none") + ; + else if (textTransform == "uppercase") { + text2 = text2.toUpperCase(); + } else if (textTransform == "lowercase") { + text2 = text2.toLowerCase(); + } + var wrapStyle = ele.pstyle("text-wrap").value; + if (wrapStyle === "wrap") { + var labelKey = rscratch("labelKey"); + if (labelKey != null && rscratch("labelWrapKey") === labelKey) { + return rscratch("labelWrapCachedText"); + } + var zwsp = "​"; + var lines = text2.split("\n"); + var maxW = ele.pstyle("text-max-width").pfValue; + var overflow = ele.pstyle("text-overflow-wrap").value; + var overflowAny = overflow === "anywhere"; + var wrappedLines = []; + var wordsRegex = /[\s\u200b]+/; + var wordSeparator = overflowAny ? "" : " "; + for (var l = 0; l < lines.length; l++) { + var line2 = lines[l]; + var lineDims = this.calculateLabelDimensions(ele, line2); + var lineW = lineDims.width; + if (overflowAny) { + var processedLine = line2.split("").join(zwsp); + line2 = processedLine; + } + if (lineW > maxW) { + var words = line2.split(wordsRegex); + var subline = ""; + for (var w2 = 0; w2 < words.length; w2++) { + var word = words[w2]; + var testLine = subline.length === 0 ? word : subline + wordSeparator + word; + var testDims = this.calculateLabelDimensions(ele, testLine); + var testW = testDims.width; + if (testW <= maxW) { + subline += word + wordSeparator; + } else { + if (subline) { + wrappedLines.push(subline); + } + subline = word + wordSeparator; + } + } + if (!subline.match(/^[\s\u200b]+$/)) { + wrappedLines.push(subline); + } + } else { + wrappedLines.push(line2); + } + } + rscratch("labelWrapCachedLines", wrappedLines); + text2 = rscratch("labelWrapCachedText", wrappedLines.join("\n")); + rscratch("labelWrapKey", labelKey); + } else if (wrapStyle === "ellipsis") { + var _maxW = ele.pstyle("text-max-width").pfValue; + var ellipsized = ""; + var ellipsis = "…"; + var incLastCh = false; + if (this.calculateLabelDimensions(ele, text2).width < _maxW) { + return text2; + } + for (var i3 = 0; i3 < text2.length; i3++) { + var widthWithNextCh = this.calculateLabelDimensions(ele, ellipsized + text2[i3] + ellipsis).width; + if (widthWithNextCh > _maxW) { + break; + } + ellipsized += text2[i3]; + if (i3 === text2.length - 1) { + incLastCh = true; + } + } + if (!incLastCh) { + ellipsized += ellipsis; + } + return ellipsized; + } + return text2; + }; + BRp$9.getLabelJustification = function(ele) { + var justification = ele.pstyle("text-justification").strValue; + var textHalign = ele.pstyle("text-halign").strValue; + if (justification === "auto") { + if (ele.isNode()) { + switch (textHalign) { + case "left": + return "right"; + case "right": + return "left"; + default: + return "center"; + } + } else { + return "center"; + } + } else { + return justification; + } + }; + BRp$9.calculateLabelDimensions = function(ele, text2) { + var r = this; + var cacheKey = hashString(text2, ele._private.labelDimsKey); + var cache2 = r.labelDimCache || (r.labelDimCache = []); + var existingVal = cache2[cacheKey]; + if (existingVal != null) { + return existingVal; + } + var padding2 = 0; + var fStyle = ele.pstyle("font-style").strValue; + var size2 = ele.pstyle("font-size").pfValue; + var family = ele.pstyle("font-family").strValue; + var weight = ele.pstyle("font-weight").strValue; + var canvas = this.labelCalcCanvas; + var c2d = this.labelCalcCanvasContext; + if (!canvas) { + canvas = this.labelCalcCanvas = document.createElement("canvas"); + c2d = this.labelCalcCanvasContext = canvas.getContext("2d"); + var ds = canvas.style; + ds.position = "absolute"; + ds.left = "-9999px"; + ds.top = "-9999px"; + ds.zIndex = "-1"; + ds.visibility = "hidden"; + ds.pointerEvents = "none"; + } + c2d.font = "".concat(fStyle, " ").concat(weight, " ").concat(size2, "px ").concat(family); + var width2 = 0; + var height = 0; + var lines = text2.split("\n"); + for (var i3 = 0; i3 < lines.length; i3++) { + var line2 = lines[i3]; + var metrics = c2d.measureText(line2); + var w2 = Math.ceil(metrics.width); + var h = size2; + width2 = Math.max(w2, width2); + height += h; + } + width2 += padding2; + height += padding2; + return cache2[cacheKey] = { + width: width2, + height + }; + }; + BRp$9.calculateLabelAngle = function(ele, prefix) { + var _p = ele._private; + var rs = _p.rscratch; + var isEdge = ele.isEdge(); + var prefixDash = prefix ? prefix + "-" : ""; + var rot = ele.pstyle(prefixDash + "text-rotation"); + var rotStr = rot.strValue; + if (rotStr === "none") { + return 0; + } else if (isEdge && rotStr === "autorotate") { + return rs.labelAutoAngle; + } else if (rotStr === "autorotate") { + return 0; + } else { + return rot.pfValue; + } + }; + BRp$9.calculateLabelAngles = function(ele) { + var r = this; + var isEdge = ele.isEdge(); + var _p = ele._private; + var rs = _p.rscratch; + rs.labelAngle = r.calculateLabelAngle(ele); + if (isEdge) { + rs.sourceLabelAngle = r.calculateLabelAngle(ele, "source"); + rs.targetLabelAngle = r.calculateLabelAngle(ele, "target"); + } + }; + var BRp$8 = {}; + var TOO_SMALL_CUT_RECT = 28; + var warnedCutRect = false; + BRp$8.getNodeShape = function(node2) { + var r = this; + var shape = node2.pstyle("shape").value; + if (shape === "cutrectangle" && (node2.width() < TOO_SMALL_CUT_RECT || node2.height() < TOO_SMALL_CUT_RECT)) { + if (!warnedCutRect) { + warn("The `cutrectangle` node shape can not be used at small sizes so `rectangle` is used instead"); + warnedCutRect = true; + } + return "rectangle"; + } + if (node2.isParent()) { + if (shape === "rectangle" || shape === "roundrectangle" || shape === "round-rectangle" || shape === "cutrectangle" || shape === "cut-rectangle" || shape === "barrel") { + return shape; + } else { + return "rectangle"; + } + } + if (shape === "polygon") { + var points = node2.pstyle("shape-polygon-points").value; + return r.nodeShapes.makePolygon(points).name; + } + return shape; + }; + var BRp$7 = {}; + BRp$7.registerCalculationListeners = function() { + var cy = this.cy; + var elesToUpdate = cy.collection(); + var r = this; + var enqueue = function enqueue2(eles) { + var dirtyStyleCaches = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : true; + elesToUpdate.merge(eles); + if (dirtyStyleCaches) { + for (var i3 = 0; i3 < eles.length; i3++) { + var ele = eles[i3]; + var _p = ele._private; + var rstyle = _p.rstyle; + rstyle.clean = false; + rstyle.cleanConnected = false; + } + } + }; + r.binder(cy).on("bounds.* dirty.*", function onDirtyBounds(e) { + var ele = e.target; + enqueue(ele); + }).on("style.* background.*", function onDirtyStyle(e) { + var ele = e.target; + enqueue(ele, false); + }); + var updateEleCalcs = function updateEleCalcs2(willDraw) { + if (willDraw) { + var fns = r.onUpdateEleCalcsFns; + elesToUpdate.cleanStyle(); + for (var i3 = 0; i3 < elesToUpdate.length; i3++) { + var ele = elesToUpdate[i3]; + var rstyle = ele._private.rstyle; + if (ele.isNode() && !rstyle.cleanConnected) { + enqueue(ele.connectedEdges()); + rstyle.cleanConnected = true; + } + } + if (fns) { + for (var _i6 = 0; _i6 < fns.length; _i6++) { + var fn2 = fns[_i6]; + fn2(willDraw, elesToUpdate); + } + } + r.recalculateRenderedStyle(elesToUpdate); + elesToUpdate = cy.collection(); + } + }; + r.flushRenderedStyleQueue = function() { + updateEleCalcs(true); + }; + r.beforeRender(updateEleCalcs, r.beforeRenderPriorities.eleCalcs); + }; + BRp$7.onUpdateEleCalcs = function(fn2) { + var fns = this.onUpdateEleCalcsFns = this.onUpdateEleCalcsFns || []; + fns.push(fn2); + }; + BRp$7.recalculateRenderedStyle = function(eles, useCache) { + var isCleanConnected = function isCleanConnected2(ele2) { + return ele2._private.rstyle.cleanConnected; + }; + var edges2 = []; + var nodes2 = []; + if (this.destroyed) { + return; + } + if (useCache === void 0) { + useCache = true; + } + for (var i3 = 0; i3 < eles.length; i3++) { + var ele = eles[i3]; + var _p = ele._private; + var rstyle = _p.rstyle; + if (ele.isEdge() && (!isCleanConnected(ele.source()) || !isCleanConnected(ele.target()))) { + rstyle.clean = false; + } + if (useCache && rstyle.clean || ele.removed()) { + continue; + } + if (ele.pstyle("display").value === "none") { + continue; + } + if (_p.group === "nodes") { + nodes2.push(ele); + } else { + edges2.push(ele); + } + rstyle.clean = true; + } + for (var _i22 = 0; _i22 < nodes2.length; _i22++) { + var _ele = nodes2[_i22]; + var _p2 = _ele._private; + var _rstyle = _p2.rstyle; + var pos = _ele.position(); + this.recalculateNodeLabelProjection(_ele); + _rstyle.nodeX = pos.x; + _rstyle.nodeY = pos.y; + _rstyle.nodeW = _ele.pstyle("width").pfValue; + _rstyle.nodeH = _ele.pstyle("height").pfValue; + } + this.recalculateEdgeProjections(edges2); + for (var _i32 = 0; _i32 < edges2.length; _i32++) { + var _ele2 = edges2[_i32]; + var _p3 = _ele2._private; + var _rstyle2 = _p3.rstyle; + var rs = _p3.rscratch; + _rstyle2.srcX = rs.arrowStartX; + _rstyle2.srcY = rs.arrowStartY; + _rstyle2.tgtX = rs.arrowEndX; + _rstyle2.tgtY = rs.arrowEndY; + _rstyle2.midX = rs.midX; + _rstyle2.midY = rs.midY; + _rstyle2.labelAngle = rs.labelAngle; + _rstyle2.sourceLabelAngle = rs.sourceLabelAngle; + _rstyle2.targetLabelAngle = rs.targetLabelAngle; + } + }; + var BRp$6 = {}; + BRp$6.updateCachedGrabbedEles = function() { + var eles = this.cachedZSortedEles; + if (!eles) { + return; + } + eles.drag = []; + eles.nondrag = []; + var grabTargets = []; + for (var i3 = 0; i3 < eles.length; i3++) { + var ele = eles[i3]; + var rs = ele._private.rscratch; + if (ele.grabbed() && !ele.isParent()) { + grabTargets.push(ele); + } else if (rs.inDragLayer) { + eles.drag.push(ele); + } else { + eles.nondrag.push(ele); + } + } + for (var i3 = 0; i3 < grabTargets.length; i3++) { + var ele = grabTargets[i3]; + eles.drag.push(ele); + } + }; + BRp$6.invalidateCachedZSortedEles = function() { + this.cachedZSortedEles = null; + }; + BRp$6.getCachedZSortedEles = function(forceRecalc) { + if (forceRecalc || !this.cachedZSortedEles) { + var eles = this.cy.mutableElements().toArray(); + eles.sort(zIndexSort); + eles.interactive = eles.filter(function(ele) { + return ele.interactive(); + }); + this.cachedZSortedEles = eles; + this.updateCachedGrabbedEles(); + } else { + eles = this.cachedZSortedEles; + } + return eles; + }; + var BRp$5 = {}; + [BRp$e, BRp$d, BRp$c, BRp$b, BRp$a, BRp$9, BRp$8, BRp$7, BRp$6].forEach(function(props) { + extend2(BRp$5, props); + }); + var BRp$4 = {}; + BRp$4.getCachedImage = function(url, crossOrigin, onLoad) { + var r = this; + var imageCache = r.imageCache = r.imageCache || {}; + var cache2 = imageCache[url]; + if (cache2) { + if (!cache2.image.complete) { + cache2.image.addEventListener("load", onLoad); + } + return cache2.image; + } else { + cache2 = imageCache[url] = imageCache[url] || {}; + var image = cache2.image = new Image(); + image.addEventListener("load", onLoad); + image.addEventListener("error", function() { + image.error = true; + }); + var dataUriPrefix = "data:"; + var isDataUri = url.substring(0, dataUriPrefix.length).toLowerCase() === dataUriPrefix; + if (!isDataUri) { + crossOrigin = crossOrigin === "null" ? null : crossOrigin; + image.crossOrigin = crossOrigin; + } + image.src = url; + return image; + } + }; + var BRp$3 = {}; + BRp$3.registerBinding = function(target, event2, handler, useCapture) { + var args = Array.prototype.slice.apply(arguments, [1]); + var b = this.binder(target); + return b.on.apply(b, args); + }; + BRp$3.binder = function(tgt) { + var r = this; + var containerWindow = r.cy.window(); + var tgtIsDom = tgt === containerWindow || tgt === containerWindow.document || tgt === containerWindow.document.body || domElement(tgt); + if (r.supportsPassiveEvents == null) { + var supportsPassive = false; + try { + var opts = Object.defineProperty({}, "passive", { + get: function get3() { + supportsPassive = true; + return true; + } + }); + containerWindow.addEventListener("test", null, opts); + } catch (err) { + } + r.supportsPassiveEvents = supportsPassive; + } + var on = function on2(event2, handler, useCapture) { + var args = Array.prototype.slice.call(arguments); + if (tgtIsDom && r.supportsPassiveEvents) { + args[2] = { + capture: useCapture != null ? useCapture : false, + passive: false, + once: false + }; + } + r.bindings.push({ + target: tgt, + args + }); + (tgt.addEventListener || tgt.on).apply(tgt, args); + return this; + }; + return { + on, + addEventListener: on, + addListener: on, + bind: on + }; + }; + BRp$3.nodeIsDraggable = function(node2) { + return node2 && node2.isNode() && !node2.locked() && node2.grabbable(); + }; + BRp$3.nodeIsGrabbable = function(node2) { + return this.nodeIsDraggable(node2) && node2.interactive(); + }; + BRp$3.load = function() { + var r = this; + var containerWindow = r.cy.window(); + var isSelected = function isSelected2(ele) { + return ele.selected(); + }; + var triggerEvents = function triggerEvents2(target, names, e, position3) { + if (target == null) { + target = r.cy; + } + for (var i3 = 0; i3 < names.length; i3++) { + var name = names[i3]; + target.emit({ + originalEvent: e, + type: name, + position: position3 + }); + } + }; + var isMultSelKeyDown = function isMultSelKeyDown2(e) { + return e.shiftKey || e.metaKey || e.ctrlKey; + }; + var allowPanningPassthrough = function allowPanningPassthrough2(down, downs) { + var allowPassthrough = true; + if (r.cy.hasCompoundNodes() && down && down.pannable()) { + for (var i3 = 0; downs && i3 < downs.length; i3++) { + var down = downs[i3]; + if (down.isNode() && down.isParent() && !down.pannable()) { + allowPassthrough = false; + break; + } + } + } else { + allowPassthrough = true; + } + return allowPassthrough; + }; + var setGrabbed = function setGrabbed2(ele) { + ele[0]._private.grabbed = true; + }; + var setFreed = function setFreed2(ele) { + ele[0]._private.grabbed = false; + }; + var setInDragLayer = function setInDragLayer2(ele) { + ele[0]._private.rscratch.inDragLayer = true; + }; + var setOutDragLayer = function setOutDragLayer2(ele) { + ele[0]._private.rscratch.inDragLayer = false; + }; + var setGrabTarget = function setGrabTarget2(ele) { + ele[0]._private.rscratch.isGrabTarget = true; + }; + var removeGrabTarget = function removeGrabTarget2(ele) { + ele[0]._private.rscratch.isGrabTarget = false; + }; + var addToDragList = function addToDragList2(ele, opts) { + var list2 = opts.addToList; + var listHasEle = list2.has(ele); + if (!listHasEle && ele.grabbable() && !ele.locked()) { + list2.merge(ele); + setGrabbed(ele); + } + }; + var addDescendantsToDrag = function addDescendantsToDrag2(node2, opts) { + if (!node2.cy().hasCompoundNodes()) { + return; + } + if (opts.inDragLayer == null && opts.addToList == null) { + return; + } + var innerNodes = node2.descendants(); + if (opts.inDragLayer) { + innerNodes.forEach(setInDragLayer); + innerNodes.connectedEdges().forEach(setInDragLayer); + } + if (opts.addToList) { + addToDragList(innerNodes, opts); + } + }; + var addNodesToDrag = function addNodesToDrag2(nodes2, opts) { + opts = opts || {}; + var hasCompoundNodes = nodes2.cy().hasCompoundNodes(); + if (opts.inDragLayer) { + nodes2.forEach(setInDragLayer); + nodes2.neighborhood().stdFilter(function(ele) { + return !hasCompoundNodes || ele.isEdge(); + }).forEach(setInDragLayer); + } + if (opts.addToList) { + nodes2.forEach(function(ele) { + addToDragList(ele, opts); + }); + } + addDescendantsToDrag(nodes2, opts); + updateAncestorsInDragLayer(nodes2, { + inDragLayer: opts.inDragLayer + }); + r.updateCachedGrabbedEles(); + }; + var addNodeToDrag = addNodesToDrag; + var freeDraggedElements = function freeDraggedElements2(grabbedEles) { + if (!grabbedEles) { + return; + } + r.getCachedZSortedEles().forEach(function(ele) { + setFreed(ele); + setOutDragLayer(ele); + removeGrabTarget(ele); + }); + r.updateCachedGrabbedEles(); + }; + var updateAncestorsInDragLayer = function updateAncestorsInDragLayer2(node2, opts) { + if (opts.inDragLayer == null && opts.addToList == null) { + return; + } + if (!node2.cy().hasCompoundNodes()) { + return; + } + var parent = node2.ancestors().orphans(); + if (parent.same(node2)) { + return; + } + var nodes2 = parent.descendants().spawnSelf().merge(parent).unmerge(node2).unmerge(node2.descendants()); + var edges2 = nodes2.connectedEdges(); + if (opts.inDragLayer) { + edges2.forEach(setInDragLayer); + nodes2.forEach(setInDragLayer); + } + if (opts.addToList) { + nodes2.forEach(function(ele) { + addToDragList(ele, opts); + }); + } + }; + var blurActiveDomElement = function blurActiveDomElement2() { + if (document.activeElement != null && document.activeElement.blur != null) { + document.activeElement.blur(); + } + }; + var haveMutationsApi = typeof MutationObserver !== "undefined"; + var haveResizeObserverApi = typeof ResizeObserver !== "undefined"; + if (haveMutationsApi) { + r.removeObserver = new MutationObserver(function(mutns) { + for (var i3 = 0; i3 < mutns.length; i3++) { + var mutn = mutns[i3]; + var rNodes = mutn.removedNodes; + if (rNodes) { + for (var j = 0; j < rNodes.length; j++) { + var rNode = rNodes[j]; + if (rNode === r.container) { + r.destroy(); + break; + } + } + } + } + }); + if (r.container.parentNode) { + r.removeObserver.observe(r.container.parentNode, { + childList: true + }); + } + } else { + r.registerBinding(r.container, "DOMNodeRemoved", function(e) { + r.destroy(); + }); + } + var onResize = debounce_1(function() { + r.cy.resize(); + }, 100); + if (haveMutationsApi) { + r.styleObserver = new MutationObserver(onResize); + r.styleObserver.observe(r.container, { + attributes: true + }); + } + r.registerBinding(containerWindow, "resize", onResize); + if (haveResizeObserverApi) { + r.resizeObserver = new ResizeObserver(onResize); + r.resizeObserver.observe(r.container); + } + var forEachUp = function forEachUp2(domEle, fn2) { + while (domEle != null) { + fn2(domEle); + domEle = domEle.parentNode; + } + }; + var invalidateCoords = function invalidateCoords2() { + r.invalidateContainerClientCoordsCache(); + }; + forEachUp(r.container, function(domEle) { + r.registerBinding(domEle, "transitionend", invalidateCoords); + r.registerBinding(domEle, "animationend", invalidateCoords); + r.registerBinding(domEle, "scroll", invalidateCoords); + }); + r.registerBinding(r.container, "contextmenu", function(e) { + e.preventDefault(); + }); + var inBoxSelection = function inBoxSelection2() { + return r.selection[4] !== 0; + }; + var eventInContainer = function eventInContainer2(e) { + var containerPageCoords = r.findContainerClientCoords(); + var x2 = containerPageCoords[0]; + var y2 = containerPageCoords[1]; + var width2 = containerPageCoords[2]; + var height = containerPageCoords[3]; + var positions = e.touches ? e.touches : [e]; + var atLeastOnePosInside = false; + for (var i3 = 0; i3 < positions.length; i3++) { + var p2 = positions[i3]; + if (x2 <= p2.clientX && p2.clientX <= x2 + width2 && y2 <= p2.clientY && p2.clientY <= y2 + height) { + atLeastOnePosInside = true; + break; + } + } + if (!atLeastOnePosInside) { + return false; + } + var container = r.container; + var target = e.target; + var tParent = target.parentNode; + var containerIsTarget = false; + while (tParent) { + if (tParent === container) { + containerIsTarget = true; + break; + } + tParent = tParent.parentNode; + } + if (!containerIsTarget) { + return false; + } + return true; + }; + r.registerBinding(r.container, "mousedown", function mousedownHandler(e) { + if (!eventInContainer(e)) { + return; + } + e.preventDefault(); + blurActiveDomElement(); + r.hoverData.capture = true; + r.hoverData.which = e.which; + var cy = r.cy; + var gpos = [e.clientX, e.clientY]; + var pos = r.projectIntoViewport(gpos[0], gpos[1]); + var select = r.selection; + var nears = r.findNearestElements(pos[0], pos[1], true, false); + var near = nears[0]; + var draggedElements = r.dragData.possibleDragElements; + r.hoverData.mdownPos = pos; + r.hoverData.mdownGPos = gpos; + var checkForTaphold = function checkForTaphold2() { + r.hoverData.tapholdCancelled = false; + clearTimeout(r.hoverData.tapholdTimeout); + r.hoverData.tapholdTimeout = setTimeout(function() { + if (r.hoverData.tapholdCancelled) { + return; + } else { + var ele = r.hoverData.down; + if (ele) { + ele.emit({ + originalEvent: e, + type: "taphold", + position: { + x: pos[0], + y: pos[1] + } + }); + } else { + cy.emit({ + originalEvent: e, + type: "taphold", + position: { + x: pos[0], + y: pos[1] + } + }); + } + } + }, r.tapholdDuration); + }; + if (e.which == 3) { + r.hoverData.cxtStarted = true; + var cxtEvt = { + originalEvent: e, + type: "cxttapstart", + position: { + x: pos[0], + y: pos[1] + } + }; + if (near) { + near.activate(); + near.emit(cxtEvt); + r.hoverData.down = near; + } else { + cy.emit(cxtEvt); + } + r.hoverData.downTime = (/* @__PURE__ */ new Date()).getTime(); + r.hoverData.cxtDragged = false; + } else if (e.which == 1) { + if (near) { + near.activate(); + } + { + if (near != null) { + if (r.nodeIsGrabbable(near)) { + var makeEvent = function makeEvent2(type2) { + return { + originalEvent: e, + type: type2, + position: { + x: pos[0], + y: pos[1] + } + }; + }; + var triggerGrab = function triggerGrab2(ele) { + ele.emit(makeEvent("grab")); + }; + setGrabTarget(near); + if (!near.selected()) { + draggedElements = r.dragData.possibleDragElements = cy.collection(); + addNodeToDrag(near, { + addToList: draggedElements + }); + near.emit(makeEvent("grabon")).emit(makeEvent("grab")); + } else { + draggedElements = r.dragData.possibleDragElements = cy.collection(); + var selectedNodes = cy.$(function(ele) { + return ele.isNode() && ele.selected() && r.nodeIsGrabbable(ele); + }); + addNodesToDrag(selectedNodes, { + addToList: draggedElements + }); + near.emit(makeEvent("grabon")); + selectedNodes.forEach(triggerGrab); + } + r.redrawHint("eles", true); + r.redrawHint("drag", true); + } + } + r.hoverData.down = near; + r.hoverData.downs = nears; + r.hoverData.downTime = (/* @__PURE__ */ new Date()).getTime(); + } + triggerEvents(near, ["mousedown", "tapstart", "vmousedown"], e, { + x: pos[0], + y: pos[1] + }); + if (near == null) { + select[4] = 1; + r.data.bgActivePosistion = { + x: pos[0], + y: pos[1] + }; + r.redrawHint("select", true); + r.redraw(); + } else if (near.pannable()) { + select[4] = 1; + } + checkForTaphold(); + } + select[0] = select[2] = pos[0]; + select[1] = select[3] = pos[1]; + }, false); + r.registerBinding(containerWindow, "mousemove", function mousemoveHandler(e) { + var capture = r.hoverData.capture; + if (!capture && !eventInContainer(e)) { + return; + } + var preventDefault = false; + var cy = r.cy; + var zoom = cy.zoom(); + var gpos = [e.clientX, e.clientY]; + var pos = r.projectIntoViewport(gpos[0], gpos[1]); + var mdownPos = r.hoverData.mdownPos; + var mdownGPos = r.hoverData.mdownGPos; + var select = r.selection; + var near = null; + if (!r.hoverData.draggingEles && !r.hoverData.dragging && !r.hoverData.selecting) { + near = r.findNearestElement(pos[0], pos[1], true, false); + } + var last2 = r.hoverData.last; + var down = r.hoverData.down; + var disp = [pos[0] - select[2], pos[1] - select[3]]; + var draggedElements = r.dragData.possibleDragElements; + var isOverThresholdDrag; + if (mdownGPos) { + var dx = gpos[0] - mdownGPos[0]; + var dx2 = dx * dx; + var dy = gpos[1] - mdownGPos[1]; + var dy2 = dy * dy; + var dist22 = dx2 + dy2; + r.hoverData.isOverThresholdDrag = isOverThresholdDrag = dist22 >= r.desktopTapThreshold2; + } + var multSelKeyDown = isMultSelKeyDown(e); + if (isOverThresholdDrag) { + r.hoverData.tapholdCancelled = true; + } + var updateDragDelta = function updateDragDelta2() { + var dragDelta2 = r.hoverData.dragDelta = r.hoverData.dragDelta || []; + if (dragDelta2.length === 0) { + dragDelta2.push(disp[0]); + dragDelta2.push(disp[1]); + } else { + dragDelta2[0] += disp[0]; + dragDelta2[1] += disp[1]; + } + }; + preventDefault = true; + triggerEvents(near, ["mousemove", "vmousemove", "tapdrag"], e, { + x: pos[0], + y: pos[1] + }); + var goIntoBoxMode = function goIntoBoxMode2() { + r.data.bgActivePosistion = void 0; + if (!r.hoverData.selecting) { + cy.emit({ + originalEvent: e, + type: "boxstart", + position: { + x: pos[0], + y: pos[1] + } + }); + } + select[4] = 1; + r.hoverData.selecting = true; + r.redrawHint("select", true); + r.redraw(); + }; + if (r.hoverData.which === 3) { + if (isOverThresholdDrag) { + var cxtEvt = { + originalEvent: e, + type: "cxtdrag", + position: { + x: pos[0], + y: pos[1] + } + }; + if (down) { + down.emit(cxtEvt); + } else { + cy.emit(cxtEvt); + } + r.hoverData.cxtDragged = true; + if (!r.hoverData.cxtOver || near !== r.hoverData.cxtOver) { + if (r.hoverData.cxtOver) { + r.hoverData.cxtOver.emit({ + originalEvent: e, + type: "cxtdragout", + position: { + x: pos[0], + y: pos[1] + } + }); + } + r.hoverData.cxtOver = near; + if (near) { + near.emit({ + originalEvent: e, + type: "cxtdragover", + position: { + x: pos[0], + y: pos[1] + } + }); + } + } + } + } else if (r.hoverData.dragging) { + preventDefault = true; + if (cy.panningEnabled() && cy.userPanningEnabled()) { + var deltaP; + if (r.hoverData.justStartedPan) { + var mdPos = r.hoverData.mdownPos; + deltaP = { + x: (pos[0] - mdPos[0]) * zoom, + y: (pos[1] - mdPos[1]) * zoom + }; + r.hoverData.justStartedPan = false; + } else { + deltaP = { + x: disp[0] * zoom, + y: disp[1] * zoom + }; + } + cy.panBy(deltaP); + cy.emit("dragpan"); + r.hoverData.dragged = true; + } + pos = r.projectIntoViewport(e.clientX, e.clientY); + } else if (select[4] == 1 && (down == null || down.pannable())) { + if (isOverThresholdDrag) { + if (!r.hoverData.dragging && cy.boxSelectionEnabled() && (multSelKeyDown || !cy.panningEnabled() || !cy.userPanningEnabled())) { + goIntoBoxMode(); + } else if (!r.hoverData.selecting && cy.panningEnabled() && cy.userPanningEnabled()) { + var allowPassthrough = allowPanningPassthrough(down, r.hoverData.downs); + if (allowPassthrough) { + r.hoverData.dragging = true; + r.hoverData.justStartedPan = true; + select[4] = 0; + r.data.bgActivePosistion = array2point(mdownPos); + r.redrawHint("select", true); + r.redraw(); + } + } + if (down && down.pannable() && down.active()) { + down.unactivate(); + } + } + } else { + if (down && down.pannable() && down.active()) { + down.unactivate(); + } + if ((!down || !down.grabbed()) && near != last2) { + if (last2) { + triggerEvents(last2, ["mouseout", "tapdragout"], e, { + x: pos[0], + y: pos[1] + }); + } + if (near) { + triggerEvents(near, ["mouseover", "tapdragover"], e, { + x: pos[0], + y: pos[1] + }); + } + r.hoverData.last = near; + } + if (down) { + if (isOverThresholdDrag) { + if (cy.boxSelectionEnabled() && multSelKeyDown) { + if (down && down.grabbed()) { + freeDraggedElements(draggedElements); + down.emit("freeon"); + draggedElements.emit("free"); + if (r.dragData.didDrag) { + down.emit("dragfreeon"); + draggedElements.emit("dragfree"); + } + } + goIntoBoxMode(); + } else if (down && down.grabbed() && r.nodeIsDraggable(down)) { + var justStartedDrag = !r.dragData.didDrag; + if (justStartedDrag) { + r.redrawHint("eles", true); + } + r.dragData.didDrag = true; + if (!r.hoverData.draggingEles) { + addNodesToDrag(draggedElements, { + inDragLayer: true + }); + } + var totalShift = { + x: 0, + y: 0 + }; + if (number$12(disp[0]) && number$12(disp[1])) { + totalShift.x += disp[0]; + totalShift.y += disp[1]; + if (justStartedDrag) { + var dragDelta = r.hoverData.dragDelta; + if (dragDelta && number$12(dragDelta[0]) && number$12(dragDelta[1])) { + totalShift.x += dragDelta[0]; + totalShift.y += dragDelta[1]; + } + } + } + r.hoverData.draggingEles = true; + draggedElements.silentShift(totalShift).emit("position drag"); + r.redrawHint("drag", true); + r.redraw(); + } + } else { + updateDragDelta(); + } + } + preventDefault = true; + } + select[2] = pos[0]; + select[3] = pos[1]; + if (preventDefault) { + if (e.stopPropagation) + e.stopPropagation(); + if (e.preventDefault) + e.preventDefault(); + return false; + } + }, false); + var clickTimeout, didDoubleClick, prevClickTimeStamp; + r.registerBinding(containerWindow, "mouseup", function mouseupHandler(e) { + var capture = r.hoverData.capture; + if (!capture) { + return; + } + r.hoverData.capture = false; + var cy = r.cy; + var pos = r.projectIntoViewport(e.clientX, e.clientY); + var select = r.selection; + var near = r.findNearestElement(pos[0], pos[1], true, false); + var draggedElements = r.dragData.possibleDragElements; + var down = r.hoverData.down; + var multSelKeyDown = isMultSelKeyDown(e); + if (r.data.bgActivePosistion) { + r.redrawHint("select", true); + r.redraw(); + } + r.hoverData.tapholdCancelled = true; + r.data.bgActivePosistion = void 0; + if (down) { + down.unactivate(); + } + if (r.hoverData.which === 3) { + var cxtEvt = { + originalEvent: e, + type: "cxttapend", + position: { + x: pos[0], + y: pos[1] + } + }; + if (down) { + down.emit(cxtEvt); + } else { + cy.emit(cxtEvt); + } + if (!r.hoverData.cxtDragged) { + var cxtTap = { + originalEvent: e, + type: "cxttap", + position: { + x: pos[0], + y: pos[1] + } + }; + if (down) { + down.emit(cxtTap); + } else { + cy.emit(cxtTap); + } + } + r.hoverData.cxtDragged = false; + r.hoverData.which = null; + } else if (r.hoverData.which === 1) { + triggerEvents(near, ["mouseup", "tapend", "vmouseup"], e, { + x: pos[0], + y: pos[1] + }); + if (!r.dragData.didDrag && // didn't move a node around + !r.hoverData.dragged && // didn't pan + !r.hoverData.selecting && // not box selection + !r.hoverData.isOverThresholdDrag) { + triggerEvents(down, ["click", "tap", "vclick"], e, { + x: pos[0], + y: pos[1] + }); + didDoubleClick = false; + if (e.timeStamp - prevClickTimeStamp <= cy.multiClickDebounceTime()) { + clickTimeout && clearTimeout(clickTimeout); + didDoubleClick = true; + prevClickTimeStamp = null; + triggerEvents(down, ["dblclick", "dbltap", "vdblclick"], e, { + x: pos[0], + y: pos[1] + }); + } else { + clickTimeout = setTimeout(function() { + if (didDoubleClick) + return; + triggerEvents(down, ["oneclick", "onetap", "voneclick"], e, { + x: pos[0], + y: pos[1] + }); + }, cy.multiClickDebounceTime()); + prevClickTimeStamp = e.timeStamp; + } + } + if (down == null && !r.dragData.didDrag && !r.hoverData.selecting && !r.hoverData.dragged && !isMultSelKeyDown(e)) { + cy.$(isSelected).unselect(["tapunselect"]); + if (draggedElements.length > 0) { + r.redrawHint("eles", true); + } + r.dragData.possibleDragElements = draggedElements = cy.collection(); + } + if (near == down && !r.dragData.didDrag && !r.hoverData.selecting) { + if (near != null && near._private.selectable) { + if (r.hoverData.dragging) + ; + else if (cy.selectionType() === "additive" || multSelKeyDown) { + if (near.selected()) { + near.unselect(["tapunselect"]); + } else { + near.select(["tapselect"]); + } + } else { + if (!multSelKeyDown) { + cy.$(isSelected).unmerge(near).unselect(["tapunselect"]); + near.select(["tapselect"]); + } + } + r.redrawHint("eles", true); + } + } + if (r.hoverData.selecting) { + var box = cy.collection(r.getAllInBox(select[0], select[1], select[2], select[3])); + r.redrawHint("select", true); + if (box.length > 0) { + r.redrawHint("eles", true); + } + cy.emit({ + type: "boxend", + originalEvent: e, + position: { + x: pos[0], + y: pos[1] + } + }); + var eleWouldBeSelected = function eleWouldBeSelected2(ele) { + return ele.selectable() && !ele.selected(); + }; + if (cy.selectionType() === "additive") { + box.emit("box").stdFilter(eleWouldBeSelected).select().emit("boxselect"); + } else { + if (!multSelKeyDown) { + cy.$(isSelected).unmerge(box).unselect(); + } + box.emit("box").stdFilter(eleWouldBeSelected).select().emit("boxselect"); + } + r.redraw(); + } + if (r.hoverData.dragging) { + r.hoverData.dragging = false; + r.redrawHint("select", true); + r.redrawHint("eles", true); + r.redraw(); + } + if (!select[4]) { + r.redrawHint("drag", true); + r.redrawHint("eles", true); + var downWasGrabbed = down && down.grabbed(); + freeDraggedElements(draggedElements); + if (downWasGrabbed) { + down.emit("freeon"); + draggedElements.emit("free"); + if (r.dragData.didDrag) { + down.emit("dragfreeon"); + draggedElements.emit("dragfree"); + } + } + } + } + select[4] = 0; + r.hoverData.down = null; + r.hoverData.cxtStarted = false; + r.hoverData.draggingEles = false; + r.hoverData.selecting = false; + r.hoverData.isOverThresholdDrag = false; + r.dragData.didDrag = false; + r.hoverData.dragged = false; + r.hoverData.dragDelta = []; + r.hoverData.mdownPos = null; + r.hoverData.mdownGPos = null; + }, false); + var wheelHandler = function wheelHandler2(e) { + if (r.scrollingPage) { + return; + } + var cy = r.cy; + var zoom = cy.zoom(); + var pan = cy.pan(); + var pos = r.projectIntoViewport(e.clientX, e.clientY); + var rpos = [pos[0] * zoom + pan.x, pos[1] * zoom + pan.y]; + if (r.hoverData.draggingEles || r.hoverData.dragging || r.hoverData.cxtStarted || inBoxSelection()) { + e.preventDefault(); + return; + } + if (cy.panningEnabled() && cy.userPanningEnabled() && cy.zoomingEnabled() && cy.userZoomingEnabled()) { + e.preventDefault(); + r.data.wheelZooming = true; + clearTimeout(r.data.wheelTimeout); + r.data.wheelTimeout = setTimeout(function() { + r.data.wheelZooming = false; + r.redrawHint("eles", true); + r.redraw(); + }, 150); + var diff; + if (e.deltaY != null) { + diff = e.deltaY / -250; + } else if (e.wheelDeltaY != null) { + diff = e.wheelDeltaY / 1e3; + } else { + diff = e.wheelDelta / 1e3; + } + diff = diff * r.wheelSensitivity; + var needsWheelFix = e.deltaMode === 1; + if (needsWheelFix) { + diff *= 33; + } + var newZoom = cy.zoom() * Math.pow(10, diff); + if (e.type === "gesturechange") { + newZoom = r.gestureStartZoom * e.scale; + } + cy.zoom({ + level: newZoom, + renderedPosition: { + x: rpos[0], + y: rpos[1] + } + }); + cy.emit(e.type === "gesturechange" ? "pinchzoom" : "scrollzoom"); + } + }; + r.registerBinding(r.container, "wheel", wheelHandler, true); + r.registerBinding(containerWindow, "scroll", function scrollHandler(e) { + r.scrollingPage = true; + clearTimeout(r.scrollingPageTimeout); + r.scrollingPageTimeout = setTimeout(function() { + r.scrollingPage = false; + }, 250); + }, true); + r.registerBinding(r.container, "gesturestart", function gestureStartHandler(e) { + r.gestureStartZoom = r.cy.zoom(); + if (!r.hasTouchStarted) { + e.preventDefault(); + } + }, true); + r.registerBinding(r.container, "gesturechange", function(e) { + if (!r.hasTouchStarted) { + wheelHandler(e); + } + }, true); + r.registerBinding(r.container, "mouseout", function mouseOutHandler(e) { + var pos = r.projectIntoViewport(e.clientX, e.clientY); + r.cy.emit({ + originalEvent: e, + type: "mouseout", + position: { + x: pos[0], + y: pos[1] + } + }); + }, false); + r.registerBinding(r.container, "mouseover", function mouseOverHandler(e) { + var pos = r.projectIntoViewport(e.clientX, e.clientY); + r.cy.emit({ + originalEvent: e, + type: "mouseover", + position: { + x: pos[0], + y: pos[1] + } + }); + }, false); + var f1x1, f1y1, f2x1, f2y1; + var distance1, distance1Sq; + var center1, modelCenter1; + var offsetLeft, offsetTop; + var containerWidth, containerHeight; + var twoFingersStartInside; + var distance2 = function distance3(x1, y1, x2, y2) { + return Math.sqrt((x2 - x1) * (x2 - x1) + (y2 - y1) * (y2 - y1)); + }; + var distanceSq = function distanceSq2(x1, y1, x2, y2) { + return (x2 - x1) * (x2 - x1) + (y2 - y1) * (y2 - y1); + }; + var touchstartHandler; + r.registerBinding(r.container, "touchstart", touchstartHandler = function touchstartHandler2(e) { + r.hasTouchStarted = true; + if (!eventInContainer(e)) { + return; + } + blurActiveDomElement(); + r.touchData.capture = true; + r.data.bgActivePosistion = void 0; + var cy = r.cy; + var now3 = r.touchData.now; + var earlier = r.touchData.earlier; + if (e.touches[0]) { + var pos = r.projectIntoViewport(e.touches[0].clientX, e.touches[0].clientY); + now3[0] = pos[0]; + now3[1] = pos[1]; + } + if (e.touches[1]) { + var pos = r.projectIntoViewport(e.touches[1].clientX, e.touches[1].clientY); + now3[2] = pos[0]; + now3[3] = pos[1]; + } + if (e.touches[2]) { + var pos = r.projectIntoViewport(e.touches[2].clientX, e.touches[2].clientY); + now3[4] = pos[0]; + now3[5] = pos[1]; + } + if (e.touches[1]) { + r.touchData.singleTouchMoved = true; + freeDraggedElements(r.dragData.touchDragEles); + var offsets = r.findContainerClientCoords(); + offsetLeft = offsets[0]; + offsetTop = offsets[1]; + containerWidth = offsets[2]; + containerHeight = offsets[3]; + f1x1 = e.touches[0].clientX - offsetLeft; + f1y1 = e.touches[0].clientY - offsetTop; + f2x1 = e.touches[1].clientX - offsetLeft; + f2y1 = e.touches[1].clientY - offsetTop; + twoFingersStartInside = 0 <= f1x1 && f1x1 <= containerWidth && 0 <= f2x1 && f2x1 <= containerWidth && 0 <= f1y1 && f1y1 <= containerHeight && 0 <= f2y1 && f2y1 <= containerHeight; + var pan = cy.pan(); + var zoom = cy.zoom(); + distance1 = distance2(f1x1, f1y1, f2x1, f2y1); + distance1Sq = distanceSq(f1x1, f1y1, f2x1, f2y1); + center1 = [(f1x1 + f2x1) / 2, (f1y1 + f2y1) / 2]; + modelCenter1 = [(center1[0] - pan.x) / zoom, (center1[1] - pan.y) / zoom]; + var cxtDistThreshold = 200; + var cxtDistThresholdSq = cxtDistThreshold * cxtDistThreshold; + if (distance1Sq < cxtDistThresholdSq && !e.touches[2]) { + var near1 = r.findNearestElement(now3[0], now3[1], true, true); + var near2 = r.findNearestElement(now3[2], now3[3], true, true); + if (near1 && near1.isNode()) { + near1.activate().emit({ + originalEvent: e, + type: "cxttapstart", + position: { + x: now3[0], + y: now3[1] + } + }); + r.touchData.start = near1; + } else if (near2 && near2.isNode()) { + near2.activate().emit({ + originalEvent: e, + type: "cxttapstart", + position: { + x: now3[0], + y: now3[1] + } + }); + r.touchData.start = near2; + } else { + cy.emit({ + originalEvent: e, + type: "cxttapstart", + position: { + x: now3[0], + y: now3[1] + } + }); + } + if (r.touchData.start) { + r.touchData.start._private.grabbed = false; + } + r.touchData.cxt = true; + r.touchData.cxtDragged = false; + r.data.bgActivePosistion = void 0; + r.redraw(); + return; + } + } + if (e.touches[2]) { + if (cy.boxSelectionEnabled()) { + e.preventDefault(); + } + } else if (e.touches[1]) + ; + else if (e.touches[0]) { + var nears = r.findNearestElements(now3[0], now3[1], true, true); + var near = nears[0]; + if (near != null) { + near.activate(); + r.touchData.start = near; + r.touchData.starts = nears; + if (r.nodeIsGrabbable(near)) { + var draggedEles = r.dragData.touchDragEles = cy.collection(); + var selectedNodes = null; + r.redrawHint("eles", true); + r.redrawHint("drag", true); + if (near.selected()) { + selectedNodes = cy.$(function(ele) { + return ele.selected() && r.nodeIsGrabbable(ele); + }); + addNodesToDrag(selectedNodes, { + addToList: draggedEles + }); + } else { + addNodeToDrag(near, { + addToList: draggedEles + }); + } + setGrabTarget(near); + var makeEvent = function makeEvent2(type2) { + return { + originalEvent: e, + type: type2, + position: { + x: now3[0], + y: now3[1] + } + }; + }; + near.emit(makeEvent("grabon")); + if (selectedNodes) { + selectedNodes.forEach(function(n) { + n.emit(makeEvent("grab")); + }); + } else { + near.emit(makeEvent("grab")); + } + } + } + triggerEvents(near, ["touchstart", "tapstart", "vmousedown"], e, { + x: now3[0], + y: now3[1] + }); + if (near == null) { + r.data.bgActivePosistion = { + x: pos[0], + y: pos[1] + }; + r.redrawHint("select", true); + r.redraw(); + } + r.touchData.singleTouchMoved = false; + r.touchData.singleTouchStartTime = +/* @__PURE__ */ new Date(); + clearTimeout(r.touchData.tapholdTimeout); + r.touchData.tapholdTimeout = setTimeout(function() { + if (r.touchData.singleTouchMoved === false && !r.pinching && !r.touchData.selecting) { + triggerEvents(r.touchData.start, ["taphold"], e, { + x: now3[0], + y: now3[1] + }); + } + }, r.tapholdDuration); + } + if (e.touches.length >= 1) { + var sPos = r.touchData.startPosition = [null, null, null, null, null, null]; + for (var i3 = 0; i3 < now3.length; i3++) { + sPos[i3] = earlier[i3] = now3[i3]; + } + var touch0 = e.touches[0]; + r.touchData.startGPosition = [touch0.clientX, touch0.clientY]; + } + }, false); + var touchmoveHandler; + r.registerBinding(window, "touchmove", touchmoveHandler = function touchmoveHandler2(e) { + var capture = r.touchData.capture; + if (!capture && !eventInContainer(e)) { + return; + } + var select = r.selection; + var cy = r.cy; + var now3 = r.touchData.now; + var earlier = r.touchData.earlier; + var zoom = cy.zoom(); + if (e.touches[0]) { + var pos = r.projectIntoViewport(e.touches[0].clientX, e.touches[0].clientY); + now3[0] = pos[0]; + now3[1] = pos[1]; + } + if (e.touches[1]) { + var pos = r.projectIntoViewport(e.touches[1].clientX, e.touches[1].clientY); + now3[2] = pos[0]; + now3[3] = pos[1]; + } + if (e.touches[2]) { + var pos = r.projectIntoViewport(e.touches[2].clientX, e.touches[2].clientY); + now3[4] = pos[0]; + now3[5] = pos[1]; + } + var startGPos = r.touchData.startGPosition; + var isOverThresholdDrag; + if (capture && e.touches[0] && startGPos) { + var disp = []; + for (var j = 0; j < now3.length; j++) { + disp[j] = now3[j] - earlier[j]; + } + var dx = e.touches[0].clientX - startGPos[0]; + var dx2 = dx * dx; + var dy = e.touches[0].clientY - startGPos[1]; + var dy2 = dy * dy; + var dist22 = dx2 + dy2; + isOverThresholdDrag = dist22 >= r.touchTapThreshold2; + } + if (capture && r.touchData.cxt) { + e.preventDefault(); + var f1x2 = e.touches[0].clientX - offsetLeft, f1y2 = e.touches[0].clientY - offsetTop; + var f2x2 = e.touches[1].clientX - offsetLeft, f2y2 = e.touches[1].clientY - offsetTop; + var distance2Sq = distanceSq(f1x2, f1y2, f2x2, f2y2); + var factorSq = distance2Sq / distance1Sq; + var distThreshold = 150; + var distThresholdSq = distThreshold * distThreshold; + var factorThreshold = 1.5; + var factorThresholdSq = factorThreshold * factorThreshold; + if (factorSq >= factorThresholdSq || distance2Sq >= distThresholdSq) { + r.touchData.cxt = false; + r.data.bgActivePosistion = void 0; + r.redrawHint("select", true); + var cxtEvt = { + originalEvent: e, + type: "cxttapend", + position: { + x: now3[0], + y: now3[1] + } + }; + if (r.touchData.start) { + r.touchData.start.unactivate().emit(cxtEvt); + r.touchData.start = null; + } else { + cy.emit(cxtEvt); + } + } + } + if (capture && r.touchData.cxt) { + var cxtEvt = { + originalEvent: e, + type: "cxtdrag", + position: { + x: now3[0], + y: now3[1] + } + }; + r.data.bgActivePosistion = void 0; + r.redrawHint("select", true); + if (r.touchData.start) { + r.touchData.start.emit(cxtEvt); + } else { + cy.emit(cxtEvt); + } + if (r.touchData.start) { + r.touchData.start._private.grabbed = false; + } + r.touchData.cxtDragged = true; + var near = r.findNearestElement(now3[0], now3[1], true, true); + if (!r.touchData.cxtOver || near !== r.touchData.cxtOver) { + if (r.touchData.cxtOver) { + r.touchData.cxtOver.emit({ + originalEvent: e, + type: "cxtdragout", + position: { + x: now3[0], + y: now3[1] + } + }); + } + r.touchData.cxtOver = near; + if (near) { + near.emit({ + originalEvent: e, + type: "cxtdragover", + position: { + x: now3[0], + y: now3[1] + } + }); + } + } + } else if (capture && e.touches[2] && cy.boxSelectionEnabled()) { + e.preventDefault(); + r.data.bgActivePosistion = void 0; + this.lastThreeTouch = +/* @__PURE__ */ new Date(); + if (!r.touchData.selecting) { + cy.emit({ + originalEvent: e, + type: "boxstart", + position: { + x: now3[0], + y: now3[1] + } + }); + } + r.touchData.selecting = true; + r.touchData.didSelect = true; + select[4] = 1; + if (!select || select.length === 0 || select[0] === void 0) { + select[0] = (now3[0] + now3[2] + now3[4]) / 3; + select[1] = (now3[1] + now3[3] + now3[5]) / 3; + select[2] = (now3[0] + now3[2] + now3[4]) / 3 + 1; + select[3] = (now3[1] + now3[3] + now3[5]) / 3 + 1; + } else { + select[2] = (now3[0] + now3[2] + now3[4]) / 3; + select[3] = (now3[1] + now3[3] + now3[5]) / 3; + } + r.redrawHint("select", true); + r.redraw(); + } else if (capture && e.touches[1] && !r.touchData.didSelect && cy.zoomingEnabled() && cy.panningEnabled() && cy.userZoomingEnabled() && cy.userPanningEnabled()) { + e.preventDefault(); + r.data.bgActivePosistion = void 0; + r.redrawHint("select", true); + var draggedEles = r.dragData.touchDragEles; + if (draggedEles) { + r.redrawHint("drag", true); + for (var i3 = 0; i3 < draggedEles.length; i3++) { + var de_p = draggedEles[i3]._private; + de_p.grabbed = false; + de_p.rscratch.inDragLayer = false; + } + } + var _start = r.touchData.start; + var f1x2 = e.touches[0].clientX - offsetLeft, f1y2 = e.touches[0].clientY - offsetTop; + var f2x2 = e.touches[1].clientX - offsetLeft, f2y2 = e.touches[1].clientY - offsetTop; + var distance22 = distance2(f1x2, f1y2, f2x2, f2y2); + var factor = distance22 / distance1; + if (twoFingersStartInside) { + var df1x = f1x2 - f1x1; + var df1y = f1y2 - f1y1; + var df2x = f2x2 - f2x1; + var df2y = f2y2 - f2y1; + var tx = (df1x + df2x) / 2; + var ty = (df1y + df2y) / 2; + var zoom1 = cy.zoom(); + var zoom2 = zoom1 * factor; + var pan1 = cy.pan(); + var ctrx = modelCenter1[0] * zoom1 + pan1.x; + var ctry = modelCenter1[1] * zoom1 + pan1.y; + var pan2 = { + x: -zoom2 / zoom1 * (ctrx - pan1.x - tx) + ctrx, + y: -zoom2 / zoom1 * (ctry - pan1.y - ty) + ctry + }; + if (_start && _start.active()) { + var draggedEles = r.dragData.touchDragEles; + freeDraggedElements(draggedEles); + r.redrawHint("drag", true); + r.redrawHint("eles", true); + _start.unactivate().emit("freeon"); + draggedEles.emit("free"); + if (r.dragData.didDrag) { + _start.emit("dragfreeon"); + draggedEles.emit("dragfree"); + } + } + cy.viewport({ + zoom: zoom2, + pan: pan2, + cancelOnFailedZoom: true + }); + cy.emit("pinchzoom"); + distance1 = distance22; + f1x1 = f1x2; + f1y1 = f1y2; + f2x1 = f2x2; + f2y1 = f2y2; + r.pinching = true; + } + if (e.touches[0]) { + var pos = r.projectIntoViewport(e.touches[0].clientX, e.touches[0].clientY); + now3[0] = pos[0]; + now3[1] = pos[1]; + } + if (e.touches[1]) { + var pos = r.projectIntoViewport(e.touches[1].clientX, e.touches[1].clientY); + now3[2] = pos[0]; + now3[3] = pos[1]; + } + if (e.touches[2]) { + var pos = r.projectIntoViewport(e.touches[2].clientX, e.touches[2].clientY); + now3[4] = pos[0]; + now3[5] = pos[1]; + } + } else if (e.touches[0] && !r.touchData.didSelect) { + var start2 = r.touchData.start; + var last2 = r.touchData.last; + var near; + if (!r.hoverData.draggingEles && !r.swipePanning) { + near = r.findNearestElement(now3[0], now3[1], true, true); + } + if (capture && start2 != null) { + e.preventDefault(); + } + if (capture && start2 != null && r.nodeIsDraggable(start2)) { + if (isOverThresholdDrag) { + var draggedEles = r.dragData.touchDragEles; + var justStartedDrag = !r.dragData.didDrag; + if (justStartedDrag) { + addNodesToDrag(draggedEles, { + inDragLayer: true + }); + } + r.dragData.didDrag = true; + var totalShift = { + x: 0, + y: 0 + }; + if (number$12(disp[0]) && number$12(disp[1])) { + totalShift.x += disp[0]; + totalShift.y += disp[1]; + if (justStartedDrag) { + r.redrawHint("eles", true); + var dragDelta = r.touchData.dragDelta; + if (dragDelta && number$12(dragDelta[0]) && number$12(dragDelta[1])) { + totalShift.x += dragDelta[0]; + totalShift.y += dragDelta[1]; + } + } + } + r.hoverData.draggingEles = true; + draggedEles.silentShift(totalShift).emit("position drag"); + r.redrawHint("drag", true); + if (r.touchData.startPosition[0] == earlier[0] && r.touchData.startPosition[1] == earlier[1]) { + r.redrawHint("eles", true); + } + r.redraw(); + } else { + var dragDelta = r.touchData.dragDelta = r.touchData.dragDelta || []; + if (dragDelta.length === 0) { + dragDelta.push(disp[0]); + dragDelta.push(disp[1]); + } else { + dragDelta[0] += disp[0]; + dragDelta[1] += disp[1]; + } + } + } + { + triggerEvents(start2 || near, ["touchmove", "tapdrag", "vmousemove"], e, { + x: now3[0], + y: now3[1] + }); + if ((!start2 || !start2.grabbed()) && near != last2) { + if (last2) { + last2.emit({ + originalEvent: e, + type: "tapdragout", + position: { + x: now3[0], + y: now3[1] + } + }); + } + if (near) { + near.emit({ + originalEvent: e, + type: "tapdragover", + position: { + x: now3[0], + y: now3[1] + } + }); + } + } + r.touchData.last = near; + } + if (capture) { + for (var i3 = 0; i3 < now3.length; i3++) { + if (now3[i3] && r.touchData.startPosition[i3] && isOverThresholdDrag) { + r.touchData.singleTouchMoved = true; + } + } + } + if (capture && (start2 == null || start2.pannable()) && cy.panningEnabled() && cy.userPanningEnabled()) { + var allowPassthrough = allowPanningPassthrough(start2, r.touchData.starts); + if (allowPassthrough) { + e.preventDefault(); + if (!r.data.bgActivePosistion) { + r.data.bgActivePosistion = array2point(r.touchData.startPosition); + } + if (r.swipePanning) { + cy.panBy({ + x: disp[0] * zoom, + y: disp[1] * zoom + }); + cy.emit("dragpan"); + } else if (isOverThresholdDrag) { + r.swipePanning = true; + cy.panBy({ + x: dx * zoom, + y: dy * zoom + }); + cy.emit("dragpan"); + if (start2) { + start2.unactivate(); + r.redrawHint("select", true); + r.touchData.start = null; + } + } + } + var pos = r.projectIntoViewport(e.touches[0].clientX, e.touches[0].clientY); + now3[0] = pos[0]; + now3[1] = pos[1]; + } + } + for (var j = 0; j < now3.length; j++) { + earlier[j] = now3[j]; + } + if (capture && e.touches.length > 0 && !r.hoverData.draggingEles && !r.swipePanning && r.data.bgActivePosistion != null) { + r.data.bgActivePosistion = void 0; + r.redrawHint("select", true); + r.redraw(); + } + }, false); + var touchcancelHandler; + r.registerBinding(containerWindow, "touchcancel", touchcancelHandler = function touchcancelHandler2(e) { + var start2 = r.touchData.start; + r.touchData.capture = false; + if (start2) { + start2.unactivate(); + } + }); + var touchendHandler, didDoubleTouch, touchTimeout, prevTouchTimeStamp; + r.registerBinding(containerWindow, "touchend", touchendHandler = function touchendHandler2(e) { + var start2 = r.touchData.start; + var capture = r.touchData.capture; + if (capture) { + if (e.touches.length === 0) { + r.touchData.capture = false; + } + e.preventDefault(); + } else { + return; + } + var select = r.selection; + r.swipePanning = false; + r.hoverData.draggingEles = false; + var cy = r.cy; + var zoom = cy.zoom(); + var now3 = r.touchData.now; + var earlier = r.touchData.earlier; + if (e.touches[0]) { + var pos = r.projectIntoViewport(e.touches[0].clientX, e.touches[0].clientY); + now3[0] = pos[0]; + now3[1] = pos[1]; + } + if (e.touches[1]) { + var pos = r.projectIntoViewport(e.touches[1].clientX, e.touches[1].clientY); + now3[2] = pos[0]; + now3[3] = pos[1]; + } + if (e.touches[2]) { + var pos = r.projectIntoViewport(e.touches[2].clientX, e.touches[2].clientY); + now3[4] = pos[0]; + now3[5] = pos[1]; + } + if (start2) { + start2.unactivate(); + } + var ctxTapend; + if (r.touchData.cxt) { + ctxTapend = { + originalEvent: e, + type: "cxttapend", + position: { + x: now3[0], + y: now3[1] + } + }; + if (start2) { + start2.emit(ctxTapend); + } else { + cy.emit(ctxTapend); + } + if (!r.touchData.cxtDragged) { + var ctxTap = { + originalEvent: e, + type: "cxttap", + position: { + x: now3[0], + y: now3[1] + } + }; + if (start2) { + start2.emit(ctxTap); + } else { + cy.emit(ctxTap); + } + } + if (r.touchData.start) { + r.touchData.start._private.grabbed = false; + } + r.touchData.cxt = false; + r.touchData.start = null; + r.redraw(); + return; + } + if (!e.touches[2] && cy.boxSelectionEnabled() && r.touchData.selecting) { + r.touchData.selecting = false; + var box = cy.collection(r.getAllInBox(select[0], select[1], select[2], select[3])); + select[0] = void 0; + select[1] = void 0; + select[2] = void 0; + select[3] = void 0; + select[4] = 0; + r.redrawHint("select", true); + cy.emit({ + type: "boxend", + originalEvent: e, + position: { + x: now3[0], + y: now3[1] + } + }); + var eleWouldBeSelected = function eleWouldBeSelected2(ele) { + return ele.selectable() && !ele.selected(); + }; + box.emit("box").stdFilter(eleWouldBeSelected).select().emit("boxselect"); + if (box.nonempty()) { + r.redrawHint("eles", true); + } + r.redraw(); + } + if (start2 != null) { + start2.unactivate(); + } + if (e.touches[2]) { + r.data.bgActivePosistion = void 0; + r.redrawHint("select", true); + } else if (e.touches[1]) + ; + else if (e.touches[0]) + ; + else if (!e.touches[0]) { + r.data.bgActivePosistion = void 0; + r.redrawHint("select", true); + var draggedEles = r.dragData.touchDragEles; + if (start2 != null) { + var startWasGrabbed = start2._private.grabbed; + freeDraggedElements(draggedEles); + r.redrawHint("drag", true); + r.redrawHint("eles", true); + if (startWasGrabbed) { + start2.emit("freeon"); + draggedEles.emit("free"); + if (r.dragData.didDrag) { + start2.emit("dragfreeon"); + draggedEles.emit("dragfree"); + } + } + triggerEvents(start2, ["touchend", "tapend", "vmouseup", "tapdragout"], e, { + x: now3[0], + y: now3[1] + }); + start2.unactivate(); + r.touchData.start = null; + } else { + var near = r.findNearestElement(now3[0], now3[1], true, true); + triggerEvents(near, ["touchend", "tapend", "vmouseup", "tapdragout"], e, { + x: now3[0], + y: now3[1] + }); + } + var dx = r.touchData.startPosition[0] - now3[0]; + var dx2 = dx * dx; + var dy = r.touchData.startPosition[1] - now3[1]; + var dy2 = dy * dy; + var dist22 = dx2 + dy2; + var rdist2 = dist22 * zoom * zoom; + if (!r.touchData.singleTouchMoved) { + if (!start2) { + cy.$(":selected").unselect(["tapunselect"]); + } + triggerEvents(start2, ["tap", "vclick"], e, { + x: now3[0], + y: now3[1] + }); + didDoubleTouch = false; + if (e.timeStamp - prevTouchTimeStamp <= cy.multiClickDebounceTime()) { + touchTimeout && clearTimeout(touchTimeout); + didDoubleTouch = true; + prevTouchTimeStamp = null; + triggerEvents(start2, ["dbltap", "vdblclick"], e, { + x: now3[0], + y: now3[1] + }); + } else { + touchTimeout = setTimeout(function() { + if (didDoubleTouch) + return; + triggerEvents(start2, ["onetap", "voneclick"], e, { + x: now3[0], + y: now3[1] + }); + }, cy.multiClickDebounceTime()); + prevTouchTimeStamp = e.timeStamp; + } + } + if (start2 != null && !r.dragData.didDrag && start2._private.selectable && rdist2 < r.touchTapThreshold2 && !r.pinching) { + if (cy.selectionType() === "single") { + cy.$(isSelected).unmerge(start2).unselect(["tapunselect"]); + start2.select(["tapselect"]); + } else { + if (start2.selected()) { + start2.unselect(["tapunselect"]); + } else { + start2.select(["tapselect"]); + } + } + r.redrawHint("eles", true); + } + r.touchData.singleTouchMoved = true; + } + for (var j = 0; j < now3.length; j++) { + earlier[j] = now3[j]; + } + r.dragData.didDrag = false; + if (e.touches.length === 0) { + r.touchData.dragDelta = []; + r.touchData.startPosition = [null, null, null, null, null, null]; + r.touchData.startGPosition = null; + r.touchData.didSelect = false; + } + if (e.touches.length < 2) { + if (e.touches.length === 1) { + r.touchData.startGPosition = [e.touches[0].clientX, e.touches[0].clientY]; + } + r.pinching = false; + r.redrawHint("eles", true); + r.redraw(); + } + }, false); + if (typeof TouchEvent === "undefined") { + var pointers = []; + var makeTouch = function makeTouch2(e) { + return { + clientX: e.clientX, + clientY: e.clientY, + force: 1, + identifier: e.pointerId, + pageX: e.pageX, + pageY: e.pageY, + radiusX: e.width / 2, + radiusY: e.height / 2, + screenX: e.screenX, + screenY: e.screenY, + target: e.target + }; + }; + var makePointer = function makePointer2(e) { + return { + event: e, + touch: makeTouch(e) + }; + }; + var addPointer = function addPointer2(e) { + pointers.push(makePointer(e)); + }; + var removePointer = function removePointer2(e) { + for (var i3 = 0; i3 < pointers.length; i3++) { + var p2 = pointers[i3]; + if (p2.event.pointerId === e.pointerId) { + pointers.splice(i3, 1); + return; + } + } + }; + var updatePointer = function updatePointer2(e) { + var p2 = pointers.filter(function(p3) { + return p3.event.pointerId === e.pointerId; + })[0]; + p2.event = e; + p2.touch = makeTouch(e); + }; + var addTouchesToEvent = function addTouchesToEvent2(e) { + e.touches = pointers.map(function(p2) { + return p2.touch; + }); + }; + var pointerIsMouse = function pointerIsMouse2(e) { + return e.pointerType === "mouse" || e.pointerType === 4; + }; + r.registerBinding(r.container, "pointerdown", function(e) { + if (pointerIsMouse(e)) { + return; + } + e.preventDefault(); + addPointer(e); + addTouchesToEvent(e); + touchstartHandler(e); + }); + r.registerBinding(r.container, "pointerup", function(e) { + if (pointerIsMouse(e)) { + return; + } + removePointer(e); + addTouchesToEvent(e); + touchendHandler(e); + }); + r.registerBinding(r.container, "pointercancel", function(e) { + if (pointerIsMouse(e)) { + return; + } + removePointer(e); + addTouchesToEvent(e); + touchcancelHandler(e); + }); + r.registerBinding(r.container, "pointermove", function(e) { + if (pointerIsMouse(e)) { + return; + } + e.preventDefault(); + updatePointer(e); + addTouchesToEvent(e); + touchmoveHandler(e); + }); + } + }; + var BRp$2 = {}; + BRp$2.generatePolygon = function(name, points) { + return this.nodeShapes[name] = { + renderer: this, + name, + points, + draw: function draw2(context, centerX, centerY, width2, height) { + this.renderer.nodeShapeImpl("polygon", context, centerX, centerY, width2, height, this.points); + }, + intersectLine: function intersectLine2(nodeX, nodeY, width2, height, x2, y2, padding2) { + return polygonIntersectLine(x2, y2, this.points, nodeX, nodeY, width2 / 2, height / 2, padding2); + }, + checkPoint: function checkPoint(x2, y2, padding2, width2, height, centerX, centerY) { + return pointInsidePolygon(x2, y2, this.points, centerX, centerY, width2, height, [0, -1], padding2); + } + }; + }; + BRp$2.generateEllipse = function() { + return this.nodeShapes["ellipse"] = { + renderer: this, + name: "ellipse", + draw: function draw2(context, centerX, centerY, width2, height) { + this.renderer.nodeShapeImpl(this.name, context, centerX, centerY, width2, height); + }, + intersectLine: function intersectLine2(nodeX, nodeY, width2, height, x2, y2, padding2) { + return intersectLineEllipse(x2, y2, nodeX, nodeY, width2 / 2 + padding2, height / 2 + padding2); + }, + checkPoint: function checkPoint(x2, y2, padding2, width2, height, centerX, centerY) { + return checkInEllipse(x2, y2, width2, height, centerX, centerY, padding2); + } + }; + }; + BRp$2.generateRoundPolygon = function(name, points) { + var allPoints = new Array(points.length * 2); + for (var i3 = 0; i3 < points.length / 2; i3++) { + var sourceIndex = i3 * 2; + var destIndex = void 0; + if (i3 < points.length / 2 - 1) { + destIndex = (i3 + 1) * 2; + } else { + destIndex = 0; + } + allPoints[i3 * 4] = points[sourceIndex]; + allPoints[i3 * 4 + 1] = points[sourceIndex + 1]; + var xDest = points[destIndex] - points[sourceIndex]; + var yDest = points[destIndex + 1] - points[sourceIndex + 1]; + var norm = Math.sqrt(xDest * xDest + yDest * yDest); + allPoints[i3 * 4 + 2] = xDest / norm; + allPoints[i3 * 4 + 3] = yDest / norm; + } + return this.nodeShapes[name] = { + renderer: this, + name, + points: allPoints, + draw: function draw2(context, centerX, centerY, width2, height) { + this.renderer.nodeShapeImpl("round-polygon", context, centerX, centerY, width2, height, this.points); + }, + intersectLine: function intersectLine2(nodeX, nodeY, width2, height, x2, y2, padding2) { + return roundPolygonIntersectLine(x2, y2, this.points, nodeX, nodeY, width2, height); + }, + checkPoint: function checkPoint(x2, y2, padding2, width2, height, centerX, centerY) { + return pointInsideRoundPolygon(x2, y2, this.points, centerX, centerY, width2, height); + } + }; + }; + BRp$2.generateRoundRectangle = function() { + return this.nodeShapes["round-rectangle"] = this.nodeShapes["roundrectangle"] = { + renderer: this, + name: "round-rectangle", + points: generateUnitNgonPointsFitToSquare(4, 0), + draw: function draw2(context, centerX, centerY, width2, height) { + this.renderer.nodeShapeImpl(this.name, context, centerX, centerY, width2, height); + }, + intersectLine: function intersectLine2(nodeX, nodeY, width2, height, x2, y2, padding2) { + return roundRectangleIntersectLine(x2, y2, nodeX, nodeY, width2, height, padding2); + }, + checkPoint: function checkPoint(x2, y2, padding2, width2, height, centerX, centerY) { + var cornerRadius = getRoundRectangleRadius(width2, height); + var diam = cornerRadius * 2; + if (pointInsidePolygon(x2, y2, this.points, centerX, centerY, width2, height - diam, [0, -1], padding2)) { + return true; + } + if (pointInsidePolygon(x2, y2, this.points, centerX, centerY, width2 - diam, height, [0, -1], padding2)) { + return true; + } + if (checkInEllipse(x2, y2, diam, diam, centerX - width2 / 2 + cornerRadius, centerY - height / 2 + cornerRadius, padding2)) { + return true; + } + if (checkInEllipse(x2, y2, diam, diam, centerX + width2 / 2 - cornerRadius, centerY - height / 2 + cornerRadius, padding2)) { + return true; + } + if (checkInEllipse(x2, y2, diam, diam, centerX + width2 / 2 - cornerRadius, centerY + height / 2 - cornerRadius, padding2)) { + return true; + } + if (checkInEllipse(x2, y2, diam, diam, centerX - width2 / 2 + cornerRadius, centerY + height / 2 - cornerRadius, padding2)) { + return true; + } + return false; + } + }; + }; + BRp$2.generateCutRectangle = function() { + return this.nodeShapes["cut-rectangle"] = this.nodeShapes["cutrectangle"] = { + renderer: this, + name: "cut-rectangle", + cornerLength: getCutRectangleCornerLength(), + points: generateUnitNgonPointsFitToSquare(4, 0), + draw: function draw2(context, centerX, centerY, width2, height) { + this.renderer.nodeShapeImpl(this.name, context, centerX, centerY, width2, height); + }, + generateCutTrianglePts: function generateCutTrianglePts(width2, height, centerX, centerY) { + var cl = this.cornerLength; + var hh = height / 2; + var hw = width2 / 2; + var xBegin = centerX - hw; + var xEnd = centerX + hw; + var yBegin = centerY - hh; + var yEnd = centerY + hh; + return { + topLeft: [xBegin, yBegin + cl, xBegin + cl, yBegin, xBegin + cl, yBegin + cl], + topRight: [xEnd - cl, yBegin, xEnd, yBegin + cl, xEnd - cl, yBegin + cl], + bottomRight: [xEnd, yEnd - cl, xEnd - cl, yEnd, xEnd - cl, yEnd - cl], + bottomLeft: [xBegin + cl, yEnd, xBegin, yEnd - cl, xBegin + cl, yEnd - cl] + }; + }, + intersectLine: function intersectLine2(nodeX, nodeY, width2, height, x2, y2, padding2) { + var cPts = this.generateCutTrianglePts(width2 + 2 * padding2, height + 2 * padding2, nodeX, nodeY); + var pts2 = [].concat.apply([], [cPts.topLeft.splice(0, 4), cPts.topRight.splice(0, 4), cPts.bottomRight.splice(0, 4), cPts.bottomLeft.splice(0, 4)]); + return polygonIntersectLine(x2, y2, pts2, nodeX, nodeY); + }, + checkPoint: function checkPoint(x2, y2, padding2, width2, height, centerX, centerY) { + if (pointInsidePolygon(x2, y2, this.points, centerX, centerY, width2, height - 2 * this.cornerLength, [0, -1], padding2)) { + return true; + } + if (pointInsidePolygon(x2, y2, this.points, centerX, centerY, width2 - 2 * this.cornerLength, height, [0, -1], padding2)) { + return true; + } + var cutTrianglePts = this.generateCutTrianglePts(width2, height, centerX, centerY); + return pointInsidePolygonPoints(x2, y2, cutTrianglePts.topLeft) || pointInsidePolygonPoints(x2, y2, cutTrianglePts.topRight) || pointInsidePolygonPoints(x2, y2, cutTrianglePts.bottomRight) || pointInsidePolygonPoints(x2, y2, cutTrianglePts.bottomLeft); + } + }; + }; + BRp$2.generateBarrel = function() { + return this.nodeShapes["barrel"] = { + renderer: this, + name: "barrel", + points: generateUnitNgonPointsFitToSquare(4, 0), + draw: function draw2(context, centerX, centerY, width2, height) { + this.renderer.nodeShapeImpl(this.name, context, centerX, centerY, width2, height); + }, + intersectLine: function intersectLine2(nodeX, nodeY, width2, height, x2, y2, padding2) { + var t02 = 0.15; + var t12 = 0.5; + var t22 = 0.85; + var bPts = this.generateBarrelBezierPts(width2 + 2 * padding2, height + 2 * padding2, nodeX, nodeY); + var approximateBarrelCurvePts = function approximateBarrelCurvePts2(pts3) { + var m0 = qbezierPtAt({ + x: pts3[0], + y: pts3[1] + }, { + x: pts3[2], + y: pts3[3] + }, { + x: pts3[4], + y: pts3[5] + }, t02); + var m1 = qbezierPtAt({ + x: pts3[0], + y: pts3[1] + }, { + x: pts3[2], + y: pts3[3] + }, { + x: pts3[4], + y: pts3[5] + }, t12); + var m2 = qbezierPtAt({ + x: pts3[0], + y: pts3[1] + }, { + x: pts3[2], + y: pts3[3] + }, { + x: pts3[4], + y: pts3[5] + }, t22); + return [pts3[0], pts3[1], m0.x, m0.y, m1.x, m1.y, m2.x, m2.y, pts3[4], pts3[5]]; + }; + var pts2 = [].concat(approximateBarrelCurvePts(bPts.topLeft), approximateBarrelCurvePts(bPts.topRight), approximateBarrelCurvePts(bPts.bottomRight), approximateBarrelCurvePts(bPts.bottomLeft)); + return polygonIntersectLine(x2, y2, pts2, nodeX, nodeY); + }, + generateBarrelBezierPts: function generateBarrelBezierPts(width2, height, centerX, centerY) { + var hh = height / 2; + var hw = width2 / 2; + var xBegin = centerX - hw; + var xEnd = centerX + hw; + var yBegin = centerY - hh; + var yEnd = centerY + hh; + var curveConstants = getBarrelCurveConstants(width2, height); + var hOffset = curveConstants.heightOffset; + var wOffset = curveConstants.widthOffset; + var ctrlPtXOffset = curveConstants.ctrlPtOffsetPct * width2; + var pts2 = { + topLeft: [xBegin, yBegin + hOffset, xBegin + ctrlPtXOffset, yBegin, xBegin + wOffset, yBegin], + topRight: [xEnd - wOffset, yBegin, xEnd - ctrlPtXOffset, yBegin, xEnd, yBegin + hOffset], + bottomRight: [xEnd, yEnd - hOffset, xEnd - ctrlPtXOffset, yEnd, xEnd - wOffset, yEnd], + bottomLeft: [xBegin + wOffset, yEnd, xBegin + ctrlPtXOffset, yEnd, xBegin, yEnd - hOffset] + }; + pts2.topLeft.isTop = true; + pts2.topRight.isTop = true; + pts2.bottomLeft.isBottom = true; + pts2.bottomRight.isBottom = true; + return pts2; + }, + checkPoint: function checkPoint(x2, y2, padding2, width2, height, centerX, centerY) { + var curveConstants = getBarrelCurveConstants(width2, height); + var hOffset = curveConstants.heightOffset; + var wOffset = curveConstants.widthOffset; + if (pointInsidePolygon(x2, y2, this.points, centerX, centerY, width2, height - 2 * hOffset, [0, -1], padding2)) { + return true; + } + if (pointInsidePolygon(x2, y2, this.points, centerX, centerY, width2 - 2 * wOffset, height, [0, -1], padding2)) { + return true; + } + var barrelCurvePts = this.generateBarrelBezierPts(width2, height, centerX, centerY); + var getCurveT = function getCurveT2(x3, y3, curvePts) { + var x0 = curvePts[4]; + var x1 = curvePts[2]; + var x22 = curvePts[0]; + var y02 = curvePts[5]; + var y23 = curvePts[1]; + var xMin = Math.min(x0, x22); + var xMax = Math.max(x0, x22); + var yMin = Math.min(y02, y23); + var yMax = Math.max(y02, y23); + if (xMin <= x3 && x3 <= xMax && yMin <= y3 && y3 <= yMax) { + var coeff = bezierPtsToQuadCoeff(x0, x1, x22); + var roots = solveQuadratic(coeff[0], coeff[1], coeff[2], x3); + var validRoots = roots.filter(function(r) { + return 0 <= r && r <= 1; + }); + if (validRoots.length > 0) { + return validRoots[0]; + } + } + return null; + }; + var curveRegions = Object.keys(barrelCurvePts); + for (var i3 = 0; i3 < curveRegions.length; i3++) { + var corner = curveRegions[i3]; + var cornerPts = barrelCurvePts[corner]; + var t = getCurveT(x2, y2, cornerPts); + if (t == null) { + continue; + } + var y0 = cornerPts[5]; + var y1 = cornerPts[3]; + var y22 = cornerPts[1]; + var bezY = qbezierAt(y0, y1, y22, t); + if (cornerPts.isTop && bezY <= y2) { + return true; + } + if (cornerPts.isBottom && y2 <= bezY) { + return true; + } + } + return false; + } + }; + }; + BRp$2.generateBottomRoundrectangle = function() { + return this.nodeShapes["bottom-round-rectangle"] = this.nodeShapes["bottomroundrectangle"] = { + renderer: this, + name: "bottom-round-rectangle", + points: generateUnitNgonPointsFitToSquare(4, 0), + draw: function draw2(context, centerX, centerY, width2, height) { + this.renderer.nodeShapeImpl(this.name, context, centerX, centerY, width2, height); + }, + intersectLine: function intersectLine2(nodeX, nodeY, width2, height, x2, y2, padding2) { + var topStartX = nodeX - (width2 / 2 + padding2); + var topStartY = nodeY - (height / 2 + padding2); + var topEndY = topStartY; + var topEndX = nodeX + (width2 / 2 + padding2); + var topIntersections = finiteLinesIntersect(x2, y2, nodeX, nodeY, topStartX, topStartY, topEndX, topEndY, false); + if (topIntersections.length > 0) { + return topIntersections; + } + return roundRectangleIntersectLine(x2, y2, nodeX, nodeY, width2, height, padding2); + }, + checkPoint: function checkPoint(x2, y2, padding2, width2, height, centerX, centerY) { + var cornerRadius = getRoundRectangleRadius(width2, height); + var diam = 2 * cornerRadius; + if (pointInsidePolygon(x2, y2, this.points, centerX, centerY, width2, height - diam, [0, -1], padding2)) { + return true; + } + if (pointInsidePolygon(x2, y2, this.points, centerX, centerY, width2 - diam, height, [0, -1], padding2)) { + return true; + } + var outerWidth = width2 / 2 + 2 * padding2; + var outerHeight = height / 2 + 2 * padding2; + var points = [centerX - outerWidth, centerY - outerHeight, centerX - outerWidth, centerY, centerX + outerWidth, centerY, centerX + outerWidth, centerY - outerHeight]; + if (pointInsidePolygonPoints(x2, y2, points)) { + return true; + } + if (checkInEllipse(x2, y2, diam, diam, centerX + width2 / 2 - cornerRadius, centerY + height / 2 - cornerRadius, padding2)) { + return true; + } + if (checkInEllipse(x2, y2, diam, diam, centerX - width2 / 2 + cornerRadius, centerY + height / 2 - cornerRadius, padding2)) { + return true; + } + return false; + } + }; + }; + BRp$2.registerNodeShapes = function() { + var nodeShapes = this.nodeShapes = {}; + var renderer3 = this; + this.generateEllipse(); + this.generatePolygon("triangle", generateUnitNgonPointsFitToSquare(3, 0)); + this.generateRoundPolygon("round-triangle", generateUnitNgonPointsFitToSquare(3, 0)); + this.generatePolygon("rectangle", generateUnitNgonPointsFitToSquare(4, 0)); + nodeShapes["square"] = nodeShapes["rectangle"]; + this.generateRoundRectangle(); + this.generateCutRectangle(); + this.generateBarrel(); + this.generateBottomRoundrectangle(); + { + var diamondPoints = [0, 1, 1, 0, 0, -1, -1, 0]; + this.generatePolygon("diamond", diamondPoints); + this.generateRoundPolygon("round-diamond", diamondPoints); + } + this.generatePolygon("pentagon", generateUnitNgonPointsFitToSquare(5, 0)); + this.generateRoundPolygon("round-pentagon", generateUnitNgonPointsFitToSquare(5, 0)); + this.generatePolygon("hexagon", generateUnitNgonPointsFitToSquare(6, 0)); + this.generateRoundPolygon("round-hexagon", generateUnitNgonPointsFitToSquare(6, 0)); + this.generatePolygon("heptagon", generateUnitNgonPointsFitToSquare(7, 0)); + this.generateRoundPolygon("round-heptagon", generateUnitNgonPointsFitToSquare(7, 0)); + this.generatePolygon("octagon", generateUnitNgonPointsFitToSquare(8, 0)); + this.generateRoundPolygon("round-octagon", generateUnitNgonPointsFitToSquare(8, 0)); + var star5Points = new Array(20); + { + var outerPoints = generateUnitNgonPoints(5, 0); + var innerPoints = generateUnitNgonPoints(5, Math.PI / 5); + var innerRadius = 0.5 * (3 - Math.sqrt(5)); + innerRadius *= 1.57; + for (var i3 = 0; i3 < innerPoints.length / 2; i3++) { + innerPoints[i3 * 2] *= innerRadius; + innerPoints[i3 * 2 + 1] *= innerRadius; + } + for (var i3 = 0; i3 < 20 / 4; i3++) { + star5Points[i3 * 4] = outerPoints[i3 * 2]; + star5Points[i3 * 4 + 1] = outerPoints[i3 * 2 + 1]; + star5Points[i3 * 4 + 2] = innerPoints[i3 * 2]; + star5Points[i3 * 4 + 3] = innerPoints[i3 * 2 + 1]; + } + } + star5Points = fitPolygonToSquare(star5Points); + this.generatePolygon("star", star5Points); + this.generatePolygon("vee", [-1, -1, 0, -0.333, 1, -1, 0, 1]); + this.generatePolygon("rhomboid", [-1, -1, 0.333, -1, 1, 1, -0.333, 1]); + this.generatePolygon("right-rhomboid", [-0.333, -1, 1, -1, 0.333, 1, -1, 1]); + this.nodeShapes["concavehexagon"] = this.generatePolygon("concave-hexagon", [-1, -0.95, -0.75, 0, -1, 0.95, 1, 0.95, 0.75, 0, 1, -0.95]); + { + var tagPoints = [-1, -1, 0.25, -1, 1, 0, 0.25, 1, -1, 1]; + this.generatePolygon("tag", tagPoints); + this.generateRoundPolygon("round-tag", tagPoints); + } + nodeShapes.makePolygon = function(points) { + var key = points.join("$"); + var name = "polygon-" + key; + var shape; + if (shape = this[name]) { + return shape; + } + return renderer3.generatePolygon(name, points); + }; + }; + var BRp$1 = {}; + BRp$1.timeToRender = function() { + return this.redrawTotalTime / this.redrawCount; + }; + BRp$1.redraw = function(options2) { + options2 = options2 || staticEmptyObject(); + var r = this; + if (r.averageRedrawTime === void 0) { + r.averageRedrawTime = 0; + } + if (r.lastRedrawTime === void 0) { + r.lastRedrawTime = 0; + } + if (r.lastDrawTime === void 0) { + r.lastDrawTime = 0; + } + r.requestedFrame = true; + r.renderOptions = options2; + }; + BRp$1.beforeRender = function(fn2, priority) { + if (this.destroyed) { + return; + } + if (priority == null) { + error("Priority is not optional for beforeRender"); + } + var cbs = this.beforeRenderCallbacks; + cbs.push({ + fn: fn2, + priority + }); + cbs.sort(function(a, b) { + return b.priority - a.priority; + }); + }; + var beforeRenderCallbacks = function beforeRenderCallbacks2(r, willDraw, startTime) { + var cbs = r.beforeRenderCallbacks; + for (var i3 = 0; i3 < cbs.length; i3++) { + cbs[i3].fn(willDraw, startTime); + } + }; + BRp$1.startRenderLoop = function() { + var r = this; + var cy = r.cy; + if (r.renderLoopStarted) { + return; + } else { + r.renderLoopStarted = true; + } + var renderFn = function renderFn2(requestTime) { + if (r.destroyed) { + return; + } + if (cy.batching()) + ; + else if (r.requestedFrame && !r.skipFrame) { + beforeRenderCallbacks(r, true, requestTime); + var startTime = performanceNow(); + r.render(r.renderOptions); + var endTime = r.lastDrawTime = performanceNow(); + if (r.averageRedrawTime === void 0) { + r.averageRedrawTime = endTime - startTime; + } + if (r.redrawCount === void 0) { + r.redrawCount = 0; + } + r.redrawCount++; + if (r.redrawTotalTime === void 0) { + r.redrawTotalTime = 0; + } + var duration = endTime - startTime; + r.redrawTotalTime += duration; + r.lastRedrawTime = duration; + r.averageRedrawTime = r.averageRedrawTime / 2 + duration / 2; + r.requestedFrame = false; + } else { + beforeRenderCallbacks(r, false, requestTime); + } + r.skipFrame = false; + requestAnimationFrame2(renderFn2); + }; + requestAnimationFrame2(renderFn); + }; + var BaseRenderer = function BaseRenderer2(options2) { + this.init(options2); + }; + var BR = BaseRenderer; + var BRp = BR.prototype; + BRp.clientFunctions = ["redrawHint", "render", "renderTo", "matchCanvasSize", "nodeShapeImpl", "arrowShapeImpl"]; + BRp.init = function(options2) { + var r = this; + r.options = options2; + r.cy = options2.cy; + var ctr = r.container = options2.cy.container(); + var containerWindow = r.cy.window(); + if (containerWindow) { + var document2 = containerWindow.document; + var head2 = document2.head; + var stylesheetId = "__________cytoscape_stylesheet"; + var className = "__________cytoscape_container"; + var stylesheetAlreadyExists = document2.getElementById(stylesheetId) != null; + if (ctr.className.indexOf(className) < 0) { + ctr.className = (ctr.className || "") + " " + className; + } + if (!stylesheetAlreadyExists) { + var stylesheet2 = document2.createElement("style"); + stylesheet2.id = stylesheetId; + stylesheet2.textContent = "." + className + " { position: relative; }"; + head2.insertBefore(stylesheet2, head2.children[0]); + } + var computedStyle = containerWindow.getComputedStyle(ctr); + var position3 = computedStyle.getPropertyValue("position"); + if (position3 === "static") { + warn("A Cytoscape container has style position:static and so can not use UI extensions properly"); + } + } + r.selection = [void 0, void 0, void 0, void 0, 0]; + r.bezierProjPcts = [0.05, 0.225, 0.4, 0.5, 0.6, 0.775, 0.95]; + r.hoverData = { + down: null, + last: null, + downTime: null, + triggerMode: null, + dragging: false, + initialPan: [null, null], + capture: false + }; + r.dragData = { + possibleDragElements: [] + }; + r.touchData = { + start: null, + capture: false, + // These 3 fields related to tap, taphold events + startPosition: [null, null, null, null, null, null], + singleTouchStartTime: null, + singleTouchMoved: true, + now: [null, null, null, null, null, null], + earlier: [null, null, null, null, null, null] + }; + r.redraws = 0; + r.showFps = options2.showFps; + r.debug = options2.debug; + r.hideEdgesOnViewport = options2.hideEdgesOnViewport; + r.textureOnViewport = options2.textureOnViewport; + r.wheelSensitivity = options2.wheelSensitivity; + r.motionBlurEnabled = options2.motionBlur; + r.forcedPixelRatio = number$12(options2.pixelRatio) ? options2.pixelRatio : null; + r.motionBlur = options2.motionBlur; + r.motionBlurOpacity = options2.motionBlurOpacity; + r.motionBlurTransparency = 1 - r.motionBlurOpacity; + r.motionBlurPxRatio = 1; + r.mbPxRBlurry = 1; + r.minMbLowQualFrames = 4; + r.fullQualityMb = false; + r.clearedForMotionBlur = []; + r.desktopTapThreshold = options2.desktopTapThreshold; + r.desktopTapThreshold2 = options2.desktopTapThreshold * options2.desktopTapThreshold; + r.touchTapThreshold = options2.touchTapThreshold; + r.touchTapThreshold2 = options2.touchTapThreshold * options2.touchTapThreshold; + r.tapholdDuration = 500; + r.bindings = []; + r.beforeRenderCallbacks = []; + r.beforeRenderPriorities = { + // higher priority execs before lower one + animations: 400, + eleCalcs: 300, + eleTxrDeq: 200, + lyrTxrDeq: 150, + lyrTxrSkip: 100 + }; + r.registerNodeShapes(); + r.registerArrowShapes(); + r.registerCalculationListeners(); + }; + BRp.notify = function(eventName, eles) { + var r = this; + var cy = r.cy; + if (this.destroyed) { + return; + } + if (eventName === "init") { + r.load(); + return; + } + if (eventName === "destroy") { + r.destroy(); + return; + } + if (eventName === "add" || eventName === "remove" || eventName === "move" && cy.hasCompoundNodes() || eventName === "load" || eventName === "zorder" || eventName === "mount") { + r.invalidateCachedZSortedEles(); + } + if (eventName === "viewport") { + r.redrawHint("select", true); + } + if (eventName === "load" || eventName === "resize" || eventName === "mount") { + r.invalidateContainerClientCoordsCache(); + r.matchCanvasSize(r.container); + } + r.redrawHint("eles", true); + r.redrawHint("drag", true); + this.startRenderLoop(); + this.redraw(); + }; + BRp.destroy = function() { + var r = this; + r.destroyed = true; + r.cy.stopAnimationLoop(); + for (var i3 = 0; i3 < r.bindings.length; i3++) { + var binding = r.bindings[i3]; + var b = binding; + var tgt = b.target; + (tgt.off || tgt.removeEventListener).apply(tgt, b.args); + } + r.bindings = []; + r.beforeRenderCallbacks = []; + r.onUpdateEleCalcsFns = []; + if (r.removeObserver) { + r.removeObserver.disconnect(); + } + if (r.styleObserver) { + r.styleObserver.disconnect(); + } + if (r.resizeObserver) { + r.resizeObserver.disconnect(); + } + if (r.labelCalcDiv) { + try { + document.body.removeChild(r.labelCalcDiv); + } catch (e) { + } + } + }; + BRp.isHeadless = function() { + return false; + }; + [BRp$f, BRp$5, BRp$4, BRp$3, BRp$2, BRp$1].forEach(function(props) { + extend2(BRp, props); + }); + var fullFpsTime = 1e3 / 60; + var defs = { + setupDequeueing: function setupDequeueing(opts) { + return function setupDequeueingImpl() { + var self2 = this; + var r = this.renderer; + if (self2.dequeueingSetup) { + return; + } else { + self2.dequeueingSetup = true; + } + var queueRedraw = debounce_1(function() { + r.redrawHint("eles", true); + r.redrawHint("drag", true); + r.redraw(); + }, opts.deqRedrawThreshold); + var dequeue = function dequeue2(willDraw, frameStartTime) { + var startTime = performanceNow(); + var avgRenderTime = r.averageRedrawTime; + var renderTime = r.lastRedrawTime; + var deqd = []; + var extent = r.cy.extent(); + var pixelRatio = r.getPixelRatio(); + if (!willDraw) { + r.flushRenderedStyleQueue(); + } + while (true) { + var now3 = performanceNow(); + var duration = now3 - startTime; + var frameDuration = now3 - frameStartTime; + if (renderTime < fullFpsTime) { + var timeAvailable = fullFpsTime - (willDraw ? avgRenderTime : 0); + if (frameDuration >= opts.deqFastCost * timeAvailable) { + break; + } + } else { + if (willDraw) { + if (duration >= opts.deqCost * renderTime || duration >= opts.deqAvgCost * avgRenderTime) { + break; + } + } else if (frameDuration >= opts.deqNoDrawCost * fullFpsTime) { + break; + } + } + var thisDeqd = opts.deq(self2, pixelRatio, extent); + if (thisDeqd.length > 0) { + for (var i3 = 0; i3 < thisDeqd.length; i3++) { + deqd.push(thisDeqd[i3]); + } + } else { + break; + } + } + if (deqd.length > 0) { + opts.onDeqd(self2, deqd); + if (!willDraw && opts.shouldRedraw(self2, deqd, pixelRatio, extent)) { + queueRedraw(); + } + } + }; + var priority = opts.priority || noop$12; + r.beforeRender(dequeue, priority(self2)); + }; + } + }; + var ElementTextureCacheLookup = /* @__PURE__ */ function() { + function ElementTextureCacheLookup2(getKey2) { + var doesEleInvalidateKey = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : falsify; + _classCallCheck(this, ElementTextureCacheLookup2); + this.idsByKey = new Map$22(); + this.keyForId = new Map$22(); + this.cachesByLvl = new Map$22(); + this.lvls = []; + this.getKey = getKey2; + this.doesEleInvalidateKey = doesEleInvalidateKey; + } + _createClass(ElementTextureCacheLookup2, [{ + key: "getIdsFor", + value: function getIdsFor(key) { + if (key == null) { + error("Can not get id list for null key"); + } + var idsByKey = this.idsByKey; + var ids = this.idsByKey.get(key); + if (!ids) { + ids = new Set$12(); + idsByKey.set(key, ids); + } + return ids; + } + }, { + key: "addIdForKey", + value: function addIdForKey(key, id2) { + if (key != null) { + this.getIdsFor(key).add(id2); + } + } + }, { + key: "deleteIdForKey", + value: function deleteIdForKey(key, id2) { + if (key != null) { + this.getIdsFor(key)["delete"](id2); + } + } + }, { + key: "getNumberOfIdsForKey", + value: function getNumberOfIdsForKey(key) { + if (key == null) { + return 0; + } else { + return this.getIdsFor(key).size; + } + } + }, { + key: "updateKeyMappingFor", + value: function updateKeyMappingFor(ele) { + var id2 = ele.id(); + var prevKey = this.keyForId.get(id2); + var currKey = this.getKey(ele); + this.deleteIdForKey(prevKey, id2); + this.addIdForKey(currKey, id2); + this.keyForId.set(id2, currKey); + } + }, { + key: "deleteKeyMappingFor", + value: function deleteKeyMappingFor(ele) { + var id2 = ele.id(); + var prevKey = this.keyForId.get(id2); + this.deleteIdForKey(prevKey, id2); + this.keyForId["delete"](id2); + } + }, { + key: "keyHasChangedFor", + value: function keyHasChangedFor(ele) { + var id2 = ele.id(); + var prevKey = this.keyForId.get(id2); + var newKey = this.getKey(ele); + return prevKey !== newKey; + } + }, { + key: "isInvalid", + value: function isInvalid(ele) { + return this.keyHasChangedFor(ele) || this.doesEleInvalidateKey(ele); + } + }, { + key: "getCachesAt", + value: function getCachesAt(lvl) { + var cachesByLvl = this.cachesByLvl, lvls = this.lvls; + var caches = cachesByLvl.get(lvl); + if (!caches) { + caches = new Map$22(); + cachesByLvl.set(lvl, caches); + lvls.push(lvl); + } + return caches; + } + }, { + key: "getCache", + value: function getCache(key, lvl) { + return this.getCachesAt(lvl).get(key); + } + }, { + key: "get", + value: function get3(ele, lvl) { + var key = this.getKey(ele); + var cache2 = this.getCache(key, lvl); + if (cache2 != null) { + this.updateKeyMappingFor(ele); + } + return cache2; + } + }, { + key: "getForCachedKey", + value: function getForCachedKey(ele, lvl) { + var key = this.keyForId.get(ele.id()); + var cache2 = this.getCache(key, lvl); + return cache2; + } + }, { + key: "hasCache", + value: function hasCache(key, lvl) { + return this.getCachesAt(lvl).has(key); + } + }, { + key: "has", + value: function has2(ele, lvl) { + var key = this.getKey(ele); + return this.hasCache(key, lvl); + } + }, { + key: "setCache", + value: function setCache(key, lvl, cache2) { + cache2.key = key; + this.getCachesAt(lvl).set(key, cache2); + } + }, { + key: "set", + value: function set3(ele, lvl, cache2) { + var key = this.getKey(ele); + this.setCache(key, lvl, cache2); + this.updateKeyMappingFor(ele); + } + }, { + key: "deleteCache", + value: function deleteCache(key, lvl) { + this.getCachesAt(lvl)["delete"](key); + } + }, { + key: "delete", + value: function _delete(ele, lvl) { + var key = this.getKey(ele); + this.deleteCache(key, lvl); + } + }, { + key: "invalidateKey", + value: function invalidateKey(key) { + var _this = this; + this.lvls.forEach(function(lvl) { + return _this.deleteCache(key, lvl); + }); + } + // returns true if no other eles reference the invalidated cache (n.b. other eles may need the cache with the same key) + }, { + key: "invalidate", + value: function invalidate(ele) { + var id2 = ele.id(); + var key = this.keyForId.get(id2); + this.deleteKeyMappingFor(ele); + var entireKeyInvalidated = this.doesEleInvalidateKey(ele); + if (entireKeyInvalidated) { + this.invalidateKey(key); + } + return entireKeyInvalidated || this.getNumberOfIdsForKey(key) === 0; + } + }]); + return ElementTextureCacheLookup2; + }(); + var minTxrH = 25; + var txrStepH = 50; + var minLvl$1 = -4; + var maxLvl$1 = 3; + var maxZoom$1 = 7.99; + var eleTxrSpacing = 8; + var defTxrWidth = 1024; + var maxTxrW = 1024; + var maxTxrH = 1024; + var minUtility = 0.2; + var maxFullness = 0.8; + var maxFullnessChecks = 10; + var deqCost$1 = 0.15; + var deqAvgCost$1 = 0.1; + var deqNoDrawCost$1 = 0.9; + var deqFastCost$1 = 0.9; + var deqRedrawThreshold$1 = 100; + var maxDeqSize$1 = 1; + var getTxrReasons = { + dequeue: "dequeue", + downscale: "downscale", + highQuality: "highQuality" + }; + var initDefaults = defaults$g({ + getKey: null, + doesEleInvalidateKey: falsify, + drawElement: null, + getBoundingBox: null, + getRotationPoint: null, + getRotationOffset: null, + isVisible: trueify, + allowEdgeTxrCaching: true, + allowParentTxrCaching: true + }); + var ElementTextureCache = function ElementTextureCache2(renderer3, initOptions) { + var self2 = this; + self2.renderer = renderer3; + self2.onDequeues = []; + var opts = initDefaults(initOptions); + extend2(self2, opts); + self2.lookup = new ElementTextureCacheLookup(opts.getKey, opts.doesEleInvalidateKey); + self2.setupDequeueing(); + }; + var ETCp = ElementTextureCache.prototype; + ETCp.reasons = getTxrReasons; + ETCp.getTextureQueue = function(txrH) { + var self2 = this; + self2.eleImgCaches = self2.eleImgCaches || {}; + return self2.eleImgCaches[txrH] = self2.eleImgCaches[txrH] || []; + }; + ETCp.getRetiredTextureQueue = function(txrH) { + var self2 = this; + var rtxtrQs = self2.eleImgCaches.retired = self2.eleImgCaches.retired || {}; + var rtxtrQ = rtxtrQs[txrH] = rtxtrQs[txrH] || []; + return rtxtrQ; + }; + ETCp.getElementQueue = function() { + var self2 = this; + var q = self2.eleCacheQueue = self2.eleCacheQueue || new heap(function(a, b) { + return b.reqs - a.reqs; + }); + return q; + }; + ETCp.getElementKeyToQueue = function() { + var self2 = this; + var k2q = self2.eleKeyToCacheQueue = self2.eleKeyToCacheQueue || {}; + return k2q; + }; + ETCp.getElement = function(ele, bb, pxRatio, lvl, reason) { + var self2 = this; + var r = this.renderer; + var zoom = r.cy.zoom(); + var lookup2 = this.lookup; + if (!bb || bb.w === 0 || bb.h === 0 || isNaN(bb.w) || isNaN(bb.h) || !ele.visible() || ele.removed()) { + return null; + } + if (!self2.allowEdgeTxrCaching && ele.isEdge() || !self2.allowParentTxrCaching && ele.isParent()) { + return null; + } + if (lvl == null) { + lvl = Math.ceil(log2(zoom * pxRatio)); + } + if (lvl < minLvl$1) { + lvl = minLvl$1; + } else if (zoom >= maxZoom$1 || lvl > maxLvl$1) { + return null; + } + var scale = Math.pow(2, lvl); + var eleScaledH = bb.h * scale; + var eleScaledW = bb.w * scale; + var scaledLabelShown = r.eleTextBiggerThanMin(ele, scale); + if (!this.isVisible(ele, scaledLabelShown)) { + return null; + } + var eleCache = lookup2.get(ele, lvl); + if (eleCache && eleCache.invalidated) { + eleCache.invalidated = false; + eleCache.texture.invalidatedWidth -= eleCache.width; + } + if (eleCache) { + return eleCache; + } + var txrH; + if (eleScaledH <= minTxrH) { + txrH = minTxrH; + } else if (eleScaledH <= txrStepH) { + txrH = txrStepH; + } else { + txrH = Math.ceil(eleScaledH / txrStepH) * txrStepH; + } + if (eleScaledH > maxTxrH || eleScaledW > maxTxrW) { + return null; + } + var txrQ = self2.getTextureQueue(txrH); + var txr = txrQ[txrQ.length - 2]; + var addNewTxr = function addNewTxr2() { + return self2.recycleTexture(txrH, eleScaledW) || self2.addTexture(txrH, eleScaledW); + }; + if (!txr) { + txr = txrQ[txrQ.length - 1]; + } + if (!txr) { + txr = addNewTxr(); + } + if (txr.width - txr.usedWidth < eleScaledW) { + txr = addNewTxr(); + } + var scalableFrom = function scalableFrom2(otherCache) { + return otherCache && otherCache.scaledLabelShown === scaledLabelShown; + }; + var deqing = reason && reason === getTxrReasons.dequeue; + var highQualityReq = reason && reason === getTxrReasons.highQuality; + var downscaleReq = reason && reason === getTxrReasons.downscale; + var higherCache; + for (var l = lvl + 1; l <= maxLvl$1; l++) { + var c2 = lookup2.get(ele, l); + if (c2) { + higherCache = c2; + break; + } + } + var oneUpCache = higherCache && higherCache.level === lvl + 1 ? higherCache : null; + var downscale = function downscale2() { + txr.context.drawImage(oneUpCache.texture.canvas, oneUpCache.x, 0, oneUpCache.width, oneUpCache.height, txr.usedWidth, 0, eleScaledW, eleScaledH); + }; + txr.context.setTransform(1, 0, 0, 1, 0, 0); + txr.context.clearRect(txr.usedWidth, 0, eleScaledW, txrH); + if (scalableFrom(oneUpCache)) { + downscale(); + } else if (scalableFrom(higherCache)) { + if (highQualityReq) { + for (var _l = higherCache.level; _l > lvl; _l--) { + oneUpCache = self2.getElement(ele, bb, pxRatio, _l, getTxrReasons.downscale); + } + downscale(); + } else { + self2.queueElement(ele, higherCache.level - 1); + return higherCache; + } + } else { + var lowerCache; + if (!deqing && !highQualityReq && !downscaleReq) { + for (var _l2 = lvl - 1; _l2 >= minLvl$1; _l2--) { + var _c = lookup2.get(ele, _l2); + if (_c) { + lowerCache = _c; + break; + } + } + } + if (scalableFrom(lowerCache)) { + self2.queueElement(ele, lvl); + return lowerCache; + } + txr.context.translate(txr.usedWidth, 0); + txr.context.scale(scale, scale); + this.drawElement(txr.context, ele, bb, scaledLabelShown, false); + txr.context.scale(1 / scale, 1 / scale); + txr.context.translate(-txr.usedWidth, 0); + } + eleCache = { + x: txr.usedWidth, + texture: txr, + level: lvl, + scale, + width: eleScaledW, + height: eleScaledH, + scaledLabelShown + }; + txr.usedWidth += Math.ceil(eleScaledW + eleTxrSpacing); + txr.eleCaches.push(eleCache); + lookup2.set(ele, lvl, eleCache); + self2.checkTextureFullness(txr); + return eleCache; + }; + ETCp.invalidateElements = function(eles) { + for (var i3 = 0; i3 < eles.length; i3++) { + this.invalidateElement(eles[i3]); + } + }; + ETCp.invalidateElement = function(ele) { + var self2 = this; + var lookup2 = self2.lookup; + var caches = []; + var invalid = lookup2.isInvalid(ele); + if (!invalid) { + return; + } + for (var lvl = minLvl$1; lvl <= maxLvl$1; lvl++) { + var cache2 = lookup2.getForCachedKey(ele, lvl); + if (cache2) { + caches.push(cache2); + } + } + var noOtherElesUseCache = lookup2.invalidate(ele); + if (noOtherElesUseCache) { + for (var i3 = 0; i3 < caches.length; i3++) { + var _cache = caches[i3]; + var txr = _cache.texture; + txr.invalidatedWidth += _cache.width; + _cache.invalidated = true; + self2.checkTextureUtility(txr); + } + } + self2.removeFromQueue(ele); + }; + ETCp.checkTextureUtility = function(txr) { + if (txr.invalidatedWidth >= minUtility * txr.width) { + this.retireTexture(txr); + } + }; + ETCp.checkTextureFullness = function(txr) { + var self2 = this; + var txrQ = self2.getTextureQueue(txr.height); + if (txr.usedWidth / txr.width > maxFullness && txr.fullnessChecks >= maxFullnessChecks) { + removeFromArray(txrQ, txr); + } else { + txr.fullnessChecks++; + } + }; + ETCp.retireTexture = function(txr) { + var self2 = this; + var txrH = txr.height; + var txrQ = self2.getTextureQueue(txrH); + var lookup2 = this.lookup; + removeFromArray(txrQ, txr); + txr.retired = true; + var eleCaches = txr.eleCaches; + for (var i3 = 0; i3 < eleCaches.length; i3++) { + var eleCache = eleCaches[i3]; + lookup2.deleteCache(eleCache.key, eleCache.level); + } + clearArray(eleCaches); + var rtxtrQ = self2.getRetiredTextureQueue(txrH); + rtxtrQ.push(txr); + }; + ETCp.addTexture = function(txrH, minW) { + var self2 = this; + var txrQ = self2.getTextureQueue(txrH); + var txr = {}; + txrQ.push(txr); + txr.eleCaches = []; + txr.height = txrH; + txr.width = Math.max(defTxrWidth, minW); + txr.usedWidth = 0; + txr.invalidatedWidth = 0; + txr.fullnessChecks = 0; + txr.canvas = self2.renderer.makeOffscreenCanvas(txr.width, txr.height); + txr.context = txr.canvas.getContext("2d"); + return txr; + }; + ETCp.recycleTexture = function(txrH, minW) { + var self2 = this; + var txrQ = self2.getTextureQueue(txrH); + var rtxtrQ = self2.getRetiredTextureQueue(txrH); + for (var i3 = 0; i3 < rtxtrQ.length; i3++) { + var txr = rtxtrQ[i3]; + if (txr.width >= minW) { + txr.retired = false; + txr.usedWidth = 0; + txr.invalidatedWidth = 0; + txr.fullnessChecks = 0; + clearArray(txr.eleCaches); + txr.context.setTransform(1, 0, 0, 1, 0, 0); + txr.context.clearRect(0, 0, txr.width, txr.height); + removeFromArray(rtxtrQ, txr); + txrQ.push(txr); + return txr; + } + } + }; + ETCp.queueElement = function(ele, lvl) { + var self2 = this; + var q = self2.getElementQueue(); + var k2q = self2.getElementKeyToQueue(); + var key = this.getKey(ele); + var existingReq = k2q[key]; + if (existingReq) { + existingReq.level = Math.max(existingReq.level, lvl); + existingReq.eles.merge(ele); + existingReq.reqs++; + q.updateItem(existingReq); + } else { + var req = { + eles: ele.spawn().merge(ele), + level: lvl, + reqs: 1, + key + }; + q.push(req); + k2q[key] = req; + } + }; + ETCp.dequeue = function(pxRatio) { + var self2 = this; + var q = self2.getElementQueue(); + var k2q = self2.getElementKeyToQueue(); + var dequeued = []; + var lookup2 = self2.lookup; + for (var i3 = 0; i3 < maxDeqSize$1; i3++) { + if (q.size() > 0) { + var req = q.pop(); + var key = req.key; + var ele = req.eles[0]; + var cacheExists = lookup2.hasCache(ele, req.level); + k2q[key] = null; + if (cacheExists) { + continue; + } + dequeued.push(req); + var bb = self2.getBoundingBox(ele); + self2.getElement(ele, bb, pxRatio, req.level, getTxrReasons.dequeue); + } else { + break; + } + } + return dequeued; + }; + ETCp.removeFromQueue = function(ele) { + var self2 = this; + var q = self2.getElementQueue(); + var k2q = self2.getElementKeyToQueue(); + var key = this.getKey(ele); + var req = k2q[key]; + if (req != null) { + if (req.eles.length === 1) { + req.reqs = MAX_INT$1; + q.updateItem(req); + q.pop(); + k2q[key] = null; + } else { + req.eles.unmerge(ele); + } + } + }; + ETCp.onDequeue = function(fn2) { + this.onDequeues.push(fn2); + }; + ETCp.offDequeue = function(fn2) { + removeFromArray(this.onDequeues, fn2); + }; + ETCp.setupDequeueing = defs.setupDequeueing({ + deqRedrawThreshold: deqRedrawThreshold$1, + deqCost: deqCost$1, + deqAvgCost: deqAvgCost$1, + deqNoDrawCost: deqNoDrawCost$1, + deqFastCost: deqFastCost$1, + deq: function deq(self2, pxRatio, extent) { + return self2.dequeue(pxRatio, extent); + }, + onDeqd: function onDeqd(self2, deqd) { + for (var i3 = 0; i3 < self2.onDequeues.length; i3++) { + var fn2 = self2.onDequeues[i3]; + fn2(deqd); + } + }, + shouldRedraw: function shouldRedraw(self2, deqd, pxRatio, extent) { + for (var i3 = 0; i3 < deqd.length; i3++) { + var eles = deqd[i3].eles; + for (var j = 0; j < eles.length; j++) { + var bb = eles[j].boundingBox(); + if (boundingBoxesIntersect(bb, extent)) { + return true; + } + } + } + return false; + }, + priority: function priority(self2) { + return self2.renderer.beforeRenderPriorities.eleTxrDeq; + } + }); + var defNumLayers = 1; + var minLvl = -4; + var maxLvl = 2; + var maxZoom = 3.99; + var deqRedrawThreshold = 50; + var refineEleDebounceTime = 50; + var deqCost = 0.15; + var deqAvgCost = 0.1; + var deqNoDrawCost = 0.9; + var deqFastCost = 0.9; + var maxDeqSize = 1; + var invalidThreshold = 250; + var maxLayerArea = 4e3 * 4e3; + var useHighQualityEleTxrReqs = true; + var LayeredTextureCache = function LayeredTextureCache2(renderer3) { + var self2 = this; + var r = self2.renderer = renderer3; + var cy = r.cy; + self2.layersByLevel = {}; + self2.firstGet = true; + self2.lastInvalidationTime = performanceNow() - 2 * invalidThreshold; + self2.skipping = false; + self2.eleTxrDeqs = cy.collection(); + self2.scheduleElementRefinement = debounce_1(function() { + self2.refineElementTextures(self2.eleTxrDeqs); + self2.eleTxrDeqs.unmerge(self2.eleTxrDeqs); + }, refineEleDebounceTime); + r.beforeRender(function(willDraw, now3) { + if (now3 - self2.lastInvalidationTime <= invalidThreshold) { + self2.skipping = true; + } else { + self2.skipping = false; + } + }, r.beforeRenderPriorities.lyrTxrSkip); + var qSort = function qSort2(a, b) { + return b.reqs - a.reqs; + }; + self2.layersQueue = new heap(qSort); + self2.setupDequeueing(); + }; + var LTCp = LayeredTextureCache.prototype; + var layerIdPool = 0; + var MAX_INT = Math.pow(2, 53) - 1; + LTCp.makeLayer = function(bb, lvl) { + var scale = Math.pow(2, lvl); + var w2 = Math.ceil(bb.w * scale); + var h = Math.ceil(bb.h * scale); + var canvas = this.renderer.makeOffscreenCanvas(w2, h); + var layer = { + id: layerIdPool = ++layerIdPool % MAX_INT, + bb, + level: lvl, + width: w2, + height: h, + canvas, + context: canvas.getContext("2d"), + eles: [], + elesQueue: [], + reqs: 0 + }; + var cxt = layer.context; + var dx = -layer.bb.x1; + var dy = -layer.bb.y1; + cxt.scale(scale, scale); + cxt.translate(dx, dy); + return layer; + }; + LTCp.getLayers = function(eles, pxRatio, lvl) { + var self2 = this; + var r = self2.renderer; + var cy = r.cy; + var zoom = cy.zoom(); + var firstGet = self2.firstGet; + self2.firstGet = false; + if (lvl == null) { + lvl = Math.ceil(log2(zoom * pxRatio)); + if (lvl < minLvl) { + lvl = minLvl; + } else if (zoom >= maxZoom || lvl > maxLvl) { + return null; + } + } + self2.validateLayersElesOrdering(lvl, eles); + var layersByLvl = self2.layersByLevel; + var scale = Math.pow(2, lvl); + var layers = layersByLvl[lvl] = layersByLvl[lvl] || []; + var bb; + var lvlComplete = self2.levelIsComplete(lvl, eles); + var tmpLayers; + var checkTempLevels = function checkTempLevels2() { + var canUseAsTmpLvl = function canUseAsTmpLvl2(l) { + self2.validateLayersElesOrdering(l, eles); + if (self2.levelIsComplete(l, eles)) { + tmpLayers = layersByLvl[l]; + return true; + } + }; + var checkLvls = function checkLvls2(dir2) { + if (tmpLayers) { + return; + } + for (var l = lvl + dir2; minLvl <= l && l <= maxLvl; l += dir2) { + if (canUseAsTmpLvl(l)) { + break; + } + } + }; + checkLvls(1); + checkLvls(-1); + for (var i4 = layers.length - 1; i4 >= 0; i4--) { + var layer2 = layers[i4]; + if (layer2.invalid) { + removeFromArray(layers, layer2); + } + } + }; + if (!lvlComplete) { + checkTempLevels(); + } else { + return layers; + } + var getBb = function getBb2() { + if (!bb) { + bb = makeBoundingBox(); + for (var i4 = 0; i4 < eles.length; i4++) { + updateBoundingBox(bb, eles[i4].boundingBox()); + } + } + return bb; + }; + var makeLayer = function makeLayer2(opts) { + opts = opts || {}; + var after = opts.after; + getBb(); + var area = bb.w * scale * (bb.h * scale); + if (area > maxLayerArea) { + return null; + } + var layer2 = self2.makeLayer(bb, lvl); + if (after != null) { + var index2 = layers.indexOf(after) + 1; + layers.splice(index2, 0, layer2); + } else if (opts.insert === void 0 || opts.insert) { + layers.unshift(layer2); + } + return layer2; + }; + if (self2.skipping && !firstGet) { + return null; + } + var layer = null; + var maxElesPerLayer = eles.length / defNumLayers; + var allowLazyQueueing = !firstGet; + for (var i3 = 0; i3 < eles.length; i3++) { + var ele = eles[i3]; + var rs = ele._private.rscratch; + var caches = rs.imgLayerCaches = rs.imgLayerCaches || {}; + var existingLayer = caches[lvl]; + if (existingLayer) { + layer = existingLayer; + continue; + } + if (!layer || layer.eles.length >= maxElesPerLayer || !boundingBoxInBoundingBox(layer.bb, ele.boundingBox())) { + layer = makeLayer({ + insert: true, + after: layer + }); + if (!layer) { + return null; + } + } + if (tmpLayers || allowLazyQueueing) { + self2.queueLayer(layer, ele); + } else { + self2.drawEleInLayer(layer, ele, lvl, pxRatio); + } + layer.eles.push(ele); + caches[lvl] = layer; + } + if (tmpLayers) { + return tmpLayers; + } + if (allowLazyQueueing) { + return null; + } + return layers; + }; + LTCp.getEleLevelForLayerLevel = function(lvl, pxRatio) { + return lvl; + }; + LTCp.drawEleInLayer = function(layer, ele, lvl, pxRatio) { + var self2 = this; + var r = this.renderer; + var context = layer.context; + var bb = ele.boundingBox(); + if (bb.w === 0 || bb.h === 0 || !ele.visible()) { + return; + } + lvl = self2.getEleLevelForLayerLevel(lvl, pxRatio); + { + r.setImgSmoothing(context, false); + } + { + r.drawCachedElement(context, ele, null, null, lvl, useHighQualityEleTxrReqs); + } + { + r.setImgSmoothing(context, true); + } + }; + LTCp.levelIsComplete = function(lvl, eles) { + var self2 = this; + var layers = self2.layersByLevel[lvl]; + if (!layers || layers.length === 0) { + return false; + } + var numElesInLayers = 0; + for (var i3 = 0; i3 < layers.length; i3++) { + var layer = layers[i3]; + if (layer.reqs > 0) { + return false; + } + if (layer.invalid) { + return false; + } + numElesInLayers += layer.eles.length; + } + if (numElesInLayers !== eles.length) { + return false; + } + return true; + }; + LTCp.validateLayersElesOrdering = function(lvl, eles) { + var layers = this.layersByLevel[lvl]; + if (!layers) { + return; + } + for (var i3 = 0; i3 < layers.length; i3++) { + var layer = layers[i3]; + var offset = -1; + for (var j = 0; j < eles.length; j++) { + if (layer.eles[0] === eles[j]) { + offset = j; + break; + } + } + if (offset < 0) { + this.invalidateLayer(layer); + continue; + } + var o = offset; + for (var j = 0; j < layer.eles.length; j++) { + if (layer.eles[j] !== eles[o + j]) { + this.invalidateLayer(layer); + break; + } + } + } + }; + LTCp.updateElementsInLayers = function(eles, update2) { + var self2 = this; + var isEles = element2(eles[0]); + for (var i3 = 0; i3 < eles.length; i3++) { + var req = isEles ? null : eles[i3]; + var ele = isEles ? eles[i3] : eles[i3].ele; + var rs = ele._private.rscratch; + var caches = rs.imgLayerCaches = rs.imgLayerCaches || {}; + for (var l = minLvl; l <= maxLvl; l++) { + var layer = caches[l]; + if (!layer) { + continue; + } + if (req && self2.getEleLevelForLayerLevel(layer.level) !== req.level) { + continue; + } + update2(layer, ele, req); + } + } + }; + LTCp.haveLayers = function() { + var self2 = this; + var haveLayers = false; + for (var l = minLvl; l <= maxLvl; l++) { + var layers = self2.layersByLevel[l]; + if (layers && layers.length > 0) { + haveLayers = true; + break; + } + } + return haveLayers; + }; + LTCp.invalidateElements = function(eles) { + var self2 = this; + if (eles.length === 0) { + return; + } + self2.lastInvalidationTime = performanceNow(); + if (eles.length === 0 || !self2.haveLayers()) { + return; + } + self2.updateElementsInLayers(eles, function invalAssocLayers(layer, ele, req) { + self2.invalidateLayer(layer); + }); + }; + LTCp.invalidateLayer = function(layer) { + this.lastInvalidationTime = performanceNow(); + if (layer.invalid) { + return; + } + var lvl = layer.level; + var eles = layer.eles; + var layers = this.layersByLevel[lvl]; + removeFromArray(layers, layer); + layer.elesQueue = []; + layer.invalid = true; + if (layer.replacement) { + layer.replacement.invalid = true; + } + for (var i3 = 0; i3 < eles.length; i3++) { + var caches = eles[i3]._private.rscratch.imgLayerCaches; + if (caches) { + caches[lvl] = null; + } + } + }; + LTCp.refineElementTextures = function(eles) { + var self2 = this; + self2.updateElementsInLayers(eles, function refineEachEle(layer, ele, req) { + var rLyr = layer.replacement; + if (!rLyr) { + rLyr = layer.replacement = self2.makeLayer(layer.bb, layer.level); + rLyr.replaces = layer; + rLyr.eles = layer.eles; + } + if (!rLyr.reqs) { + for (var i3 = 0; i3 < rLyr.eles.length; i3++) { + self2.queueLayer(rLyr, rLyr.eles[i3]); + } + } + }); + }; + LTCp.enqueueElementRefinement = function(ele) { + this.eleTxrDeqs.merge(ele); + this.scheduleElementRefinement(); + }; + LTCp.queueLayer = function(layer, ele) { + var self2 = this; + var q = self2.layersQueue; + var elesQ = layer.elesQueue; + var hasId = elesQ.hasId = elesQ.hasId || {}; + if (layer.replacement) { + return; + } + if (ele) { + if (hasId[ele.id()]) { + return; + } + elesQ.push(ele); + hasId[ele.id()] = true; + } + if (layer.reqs) { + layer.reqs++; + q.updateItem(layer); + } else { + layer.reqs = 1; + q.push(layer); + } + }; + LTCp.dequeue = function(pxRatio) { + var self2 = this; + var q = self2.layersQueue; + var deqd = []; + var eleDeqs = 0; + while (eleDeqs < maxDeqSize) { + if (q.size() === 0) { + break; + } + var layer = q.peek(); + if (layer.replacement) { + q.pop(); + continue; + } + if (layer.replaces && layer !== layer.replaces.replacement) { + q.pop(); + continue; + } + if (layer.invalid) { + q.pop(); + continue; + } + var ele = layer.elesQueue.shift(); + if (ele) { + self2.drawEleInLayer(layer, ele, layer.level, pxRatio); + eleDeqs++; + } + if (deqd.length === 0) { + deqd.push(true); + } + if (layer.elesQueue.length === 0) { + q.pop(); + layer.reqs = 0; + if (layer.replaces) { + self2.applyLayerReplacement(layer); + } + self2.requestRedraw(); + } + } + return deqd; + }; + LTCp.applyLayerReplacement = function(layer) { + var self2 = this; + var layersInLevel = self2.layersByLevel[layer.level]; + var replaced = layer.replaces; + var index2 = layersInLevel.indexOf(replaced); + if (index2 < 0 || replaced.invalid) { + return; + } + layersInLevel[index2] = layer; + for (var i3 = 0; i3 < layer.eles.length; i3++) { + var _p = layer.eles[i3]._private; + var cache2 = _p.imgLayerCaches = _p.imgLayerCaches || {}; + if (cache2) { + cache2[layer.level] = layer; + } + } + self2.requestRedraw(); + }; + LTCp.requestRedraw = debounce_1(function() { + var r = this.renderer; + r.redrawHint("eles", true); + r.redrawHint("drag", true); + r.redraw(); + }, 100); + LTCp.setupDequeueing = defs.setupDequeueing({ + deqRedrawThreshold, + deqCost, + deqAvgCost, + deqNoDrawCost, + deqFastCost, + deq: function deq(self2, pxRatio) { + return self2.dequeue(pxRatio); + }, + onDeqd: noop$12, + shouldRedraw: trueify, + priority: function priority(self2) { + return self2.renderer.beforeRenderPriorities.lyrTxrDeq; + } + }); + var CRp$a = {}; + var impl; + function polygon(context, points) { + for (var i3 = 0; i3 < points.length; i3++) { + var pt = points[i3]; + context.lineTo(pt.x, pt.y); + } + } + function triangleBackcurve(context, points, controlPoint) { + var firstPt; + for (var i3 = 0; i3 < points.length; i3++) { + var pt = points[i3]; + if (i3 === 0) { + firstPt = pt; + } + context.lineTo(pt.x, pt.y); + } + context.quadraticCurveTo(controlPoint.x, controlPoint.y, firstPt.x, firstPt.y); + } + function triangleTee(context, trianglePoints, teePoints) { + if (context.beginPath) { + context.beginPath(); + } + var triPts = trianglePoints; + for (var i3 = 0; i3 < triPts.length; i3++) { + var pt = triPts[i3]; + context.lineTo(pt.x, pt.y); + } + var teePts = teePoints; + var firstTeePt = teePoints[0]; + context.moveTo(firstTeePt.x, firstTeePt.y); + for (var i3 = 1; i3 < teePts.length; i3++) { + var pt = teePts[i3]; + context.lineTo(pt.x, pt.y); + } + if (context.closePath) { + context.closePath(); + } + } + function circleTriangle(context, trianglePoints, rx, ry, r) { + if (context.beginPath) { + context.beginPath(); + } + context.arc(rx, ry, r, 0, Math.PI * 2, false); + var triPts = trianglePoints; + var firstTrPt = triPts[0]; + context.moveTo(firstTrPt.x, firstTrPt.y); + for (var i3 = 0; i3 < triPts.length; i3++) { + var pt = triPts[i3]; + context.lineTo(pt.x, pt.y); + } + if (context.closePath) { + context.closePath(); + } + } + function circle2(context, rx, ry, r) { + context.arc(rx, ry, r, 0, Math.PI * 2, false); + } + CRp$a.arrowShapeImpl = function(name) { + return (impl || (impl = { + "polygon": polygon, + "triangle-backcurve": triangleBackcurve, + "triangle-tee": triangleTee, + "circle-triangle": circleTriangle, + "triangle-cross": triangleTee, + "circle": circle2 + }))[name]; + }; + var CRp$9 = {}; + CRp$9.drawElement = function(context, ele, shiftToOriginWithBb, showLabel, showOverlay, showOpacity) { + var r = this; + if (ele.isNode()) { + r.drawNode(context, ele, shiftToOriginWithBb, showLabel, showOverlay, showOpacity); + } else { + r.drawEdge(context, ele, shiftToOriginWithBb, showLabel, showOverlay, showOpacity); + } + }; + CRp$9.drawElementOverlay = function(context, ele) { + var r = this; + if (ele.isNode()) { + r.drawNodeOverlay(context, ele); + } else { + r.drawEdgeOverlay(context, ele); + } + }; + CRp$9.drawElementUnderlay = function(context, ele) { + var r = this; + if (ele.isNode()) { + r.drawNodeUnderlay(context, ele); + } else { + r.drawEdgeUnderlay(context, ele); + } + }; + CRp$9.drawCachedElementPortion = function(context, ele, eleTxrCache, pxRatio, lvl, reason, getRotation, getOpacity2) { + var r = this; + var bb = eleTxrCache.getBoundingBox(ele); + if (bb.w === 0 || bb.h === 0) { + return; + } + var eleCache = eleTxrCache.getElement(ele, bb, pxRatio, lvl, reason); + if (eleCache != null) { + var opacity = getOpacity2(r, ele); + if (opacity === 0) { + return; + } + var theta = getRotation(r, ele); + var x1 = bb.x1, y1 = bb.y1, w2 = bb.w, h = bb.h; + var x2, y2, sx, sy, smooth; + if (theta !== 0) { + var rotPt = eleTxrCache.getRotationPoint(ele); + sx = rotPt.x; + sy = rotPt.y; + context.translate(sx, sy); + context.rotate(theta); + smooth = r.getImgSmoothing(context); + if (!smooth) { + r.setImgSmoothing(context, true); + } + var off = eleTxrCache.getRotationOffset(ele); + x2 = off.x; + y2 = off.y; + } else { + x2 = x1; + y2 = y1; + } + var oldGlobalAlpha; + if (opacity !== 1) { + oldGlobalAlpha = context.globalAlpha; + context.globalAlpha = oldGlobalAlpha * opacity; + } + context.drawImage(eleCache.texture.canvas, eleCache.x, 0, eleCache.width, eleCache.height, x2, y2, w2, h); + if (opacity !== 1) { + context.globalAlpha = oldGlobalAlpha; + } + if (theta !== 0) { + context.rotate(-theta); + context.translate(-sx, -sy); + if (!smooth) { + r.setImgSmoothing(context, false); + } + } + } else { + eleTxrCache.drawElement(context, ele); + } + }; + var getZeroRotation = function getZeroRotation2() { + return 0; + }; + var getLabelRotation = function getLabelRotation2(r, ele) { + return r.getTextAngle(ele, null); + }; + var getSourceLabelRotation = function getSourceLabelRotation2(r, ele) { + return r.getTextAngle(ele, "source"); + }; + var getTargetLabelRotation = function getTargetLabelRotation2(r, ele) { + return r.getTextAngle(ele, "target"); + }; + var getOpacity = function getOpacity2(r, ele) { + return ele.effectiveOpacity(); + }; + var getTextOpacity = function getTextOpacity2(e, ele) { + return ele.pstyle("text-opacity").pfValue * ele.effectiveOpacity(); + }; + CRp$9.drawCachedElement = function(context, ele, pxRatio, extent, lvl, requestHighQuality) { + var r = this; + var _r$data = r.data, eleTxrCache = _r$data.eleTxrCache, lblTxrCache = _r$data.lblTxrCache, slbTxrCache = _r$data.slbTxrCache, tlbTxrCache = _r$data.tlbTxrCache; + var bb = ele.boundingBox(); + var reason = requestHighQuality === true ? eleTxrCache.reasons.highQuality : null; + if (bb.w === 0 || bb.h === 0 || !ele.visible()) { + return; + } + if (!extent || boundingBoxesIntersect(bb, extent)) { + var isEdge = ele.isEdge(); + var badLine = ele.element()._private.rscratch.badLine; + r.drawElementUnderlay(context, ele); + r.drawCachedElementPortion(context, ele, eleTxrCache, pxRatio, lvl, reason, getZeroRotation, getOpacity); + if (!isEdge || !badLine) { + r.drawCachedElementPortion(context, ele, lblTxrCache, pxRatio, lvl, reason, getLabelRotation, getTextOpacity); + } + if (isEdge && !badLine) { + r.drawCachedElementPortion(context, ele, slbTxrCache, pxRatio, lvl, reason, getSourceLabelRotation, getTextOpacity); + r.drawCachedElementPortion(context, ele, tlbTxrCache, pxRatio, lvl, reason, getTargetLabelRotation, getTextOpacity); + } + r.drawElementOverlay(context, ele); + } + }; + CRp$9.drawElements = function(context, eles) { + var r = this; + for (var i3 = 0; i3 < eles.length; i3++) { + var ele = eles[i3]; + r.drawElement(context, ele); + } + }; + CRp$9.drawCachedElements = function(context, eles, pxRatio, extent) { + var r = this; + for (var i3 = 0; i3 < eles.length; i3++) { + var ele = eles[i3]; + r.drawCachedElement(context, ele, pxRatio, extent); + } + }; + CRp$9.drawCachedNodes = function(context, eles, pxRatio, extent) { + var r = this; + for (var i3 = 0; i3 < eles.length; i3++) { + var ele = eles[i3]; + if (!ele.isNode()) { + continue; + } + r.drawCachedElement(context, ele, pxRatio, extent); + } + }; + CRp$9.drawLayeredElements = function(context, eles, pxRatio, extent) { + var r = this; + var layers = r.data.lyrTxrCache.getLayers(eles, pxRatio); + if (layers) { + for (var i3 = 0; i3 < layers.length; i3++) { + var layer = layers[i3]; + var bb = layer.bb; + if (bb.w === 0 || bb.h === 0) { + continue; + } + context.drawImage(layer.canvas, bb.x1, bb.y1, bb.w, bb.h); + } + } else { + r.drawCachedElements(context, eles, pxRatio, extent); + } + }; + var CRp$8 = {}; + CRp$8.drawEdge = function(context, edge, shiftToOriginWithBb) { + var drawLabel2 = arguments.length > 3 && arguments[3] !== void 0 ? arguments[3] : true; + var shouldDrawOverlay = arguments.length > 4 && arguments[4] !== void 0 ? arguments[4] : true; + var shouldDrawOpacity = arguments.length > 5 && arguments[5] !== void 0 ? arguments[5] : true; + var r = this; + var rs = edge._private.rscratch; + if (shouldDrawOpacity && !edge.visible()) { + return; + } + if (rs.badLine || rs.allpts == null || isNaN(rs.allpts[0])) { + return; + } + var bb; + if (shiftToOriginWithBb) { + bb = shiftToOriginWithBb; + context.translate(-bb.x1, -bb.y1); + } + var opacity = shouldDrawOpacity ? edge.pstyle("opacity").value : 1; + var lineOpacity = shouldDrawOpacity ? edge.pstyle("line-opacity").value : 1; + var curveStyle = edge.pstyle("curve-style").value; + var lineStyle = edge.pstyle("line-style").value; + var edgeWidth = edge.pstyle("width").pfValue; + var lineCap = edge.pstyle("line-cap").value; + var effectiveLineOpacity = opacity * lineOpacity; + var effectiveArrowOpacity = opacity * lineOpacity; + var drawLine = function drawLine2() { + var strokeOpacity = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : effectiveLineOpacity; + if (curveStyle === "straight-triangle") { + r.eleStrokeStyle(context, edge, strokeOpacity); + r.drawEdgeTrianglePath(edge, context, rs.allpts); + } else { + context.lineWidth = edgeWidth; + context.lineCap = lineCap; + r.eleStrokeStyle(context, edge, strokeOpacity); + r.drawEdgePath(edge, context, rs.allpts, lineStyle); + context.lineCap = "butt"; + } + }; + var drawOverlay = function drawOverlay2() { + if (!shouldDrawOverlay) { + return; + } + r.drawEdgeOverlay(context, edge); + }; + var drawUnderlay = function drawUnderlay2() { + if (!shouldDrawOverlay) { + return; + } + r.drawEdgeUnderlay(context, edge); + }; + var drawArrows2 = function drawArrows3() { + var arrowOpacity = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : effectiveArrowOpacity; + r.drawArrowheads(context, edge, arrowOpacity); + }; + var drawText2 = function drawText3() { + r.drawElementText(context, edge, null, drawLabel2); + }; + context.lineJoin = "round"; + var ghost = edge.pstyle("ghost").value === "yes"; + if (ghost) { + var gx = edge.pstyle("ghost-offset-x").pfValue; + var gy = edge.pstyle("ghost-offset-y").pfValue; + var ghostOpacity = edge.pstyle("ghost-opacity").value; + var effectiveGhostOpacity = effectiveLineOpacity * ghostOpacity; + context.translate(gx, gy); + drawLine(effectiveGhostOpacity); + drawArrows2(effectiveGhostOpacity); + context.translate(-gx, -gy); + } + drawUnderlay(); + drawLine(); + drawArrows2(); + drawOverlay(); + drawText2(); + if (shiftToOriginWithBb) { + context.translate(bb.x1, bb.y1); + } + }; + var drawEdgeOverlayUnderlay = function drawEdgeOverlayUnderlay2(overlayOrUnderlay) { + if (!["overlay", "underlay"].includes(overlayOrUnderlay)) { + throw new Error("Invalid state"); + } + return function(context, edge) { + if (!edge.visible()) { + return; + } + var opacity = edge.pstyle("".concat(overlayOrUnderlay, "-opacity")).value; + if (opacity === 0) { + return; + } + var r = this; + var usePaths = r.usePaths(); + var rs = edge._private.rscratch; + var padding2 = edge.pstyle("".concat(overlayOrUnderlay, "-padding")).pfValue; + var width2 = 2 * padding2; + var color2 = edge.pstyle("".concat(overlayOrUnderlay, "-color")).value; + context.lineWidth = width2; + if (rs.edgeType === "self" && !usePaths) { + context.lineCap = "butt"; + } else { + context.lineCap = "round"; + } + r.colorStrokeStyle(context, color2[0], color2[1], color2[2], opacity); + r.drawEdgePath(edge, context, rs.allpts, "solid"); + }; + }; + CRp$8.drawEdgeOverlay = drawEdgeOverlayUnderlay("overlay"); + CRp$8.drawEdgeUnderlay = drawEdgeOverlayUnderlay("underlay"); + CRp$8.drawEdgePath = function(edge, context, pts2, type2) { + var rs = edge._private.rscratch; + var canvasCxt = context; + var path2; + var pathCacheHit = false; + var usePaths = this.usePaths(); + var lineDashPattern = edge.pstyle("line-dash-pattern").pfValue; + var lineDashOffset = edge.pstyle("line-dash-offset").pfValue; + if (usePaths) { + var pathCacheKey = pts2.join("$"); + var keyMatches = rs.pathCacheKey && rs.pathCacheKey === pathCacheKey; + if (keyMatches) { + path2 = context = rs.pathCache; + pathCacheHit = true; + } else { + path2 = context = new Path2D(); + rs.pathCacheKey = pathCacheKey; + rs.pathCache = path2; + } + } + if (canvasCxt.setLineDash) { + switch (type2) { + case "dotted": + canvasCxt.setLineDash([1, 1]); + break; + case "dashed": + canvasCxt.setLineDash(lineDashPattern); + canvasCxt.lineDashOffset = lineDashOffset; + break; + case "solid": + canvasCxt.setLineDash([]); + break; + } + } + if (!pathCacheHit && !rs.badLine) { + if (context.beginPath) { + context.beginPath(); + } + context.moveTo(pts2[0], pts2[1]); + switch (rs.edgeType) { + case "bezier": + case "self": + case "compound": + case "multibezier": + for (var i3 = 2; i3 + 3 < pts2.length; i3 += 4) { + context.quadraticCurveTo(pts2[i3], pts2[i3 + 1], pts2[i3 + 2], pts2[i3 + 3]); + } + break; + case "straight": + case "segments": + case "haystack": + for (var _i6 = 2; _i6 + 1 < pts2.length; _i6 += 2) { + context.lineTo(pts2[_i6], pts2[_i6 + 1]); + } + break; + } + } + context = canvasCxt; + if (usePaths) { + context.stroke(path2); + } else { + context.stroke(); + } + if (context.setLineDash) { + context.setLineDash([]); + } + }; + CRp$8.drawEdgeTrianglePath = function(edge, context, pts2) { + context.fillStyle = context.strokeStyle; + var edgeWidth = edge.pstyle("width").pfValue; + for (var i3 = 0; i3 + 1 < pts2.length; i3 += 2) { + var vector = [pts2[i3 + 2] - pts2[i3], pts2[i3 + 3] - pts2[i3 + 1]]; + var length2 = Math.sqrt(vector[0] * vector[0] + vector[1] * vector[1]); + var normal2 = [vector[1] / length2, -vector[0] / length2]; + var triangleHead = [normal2[0] * edgeWidth / 2, normal2[1] * edgeWidth / 2]; + context.beginPath(); + context.moveTo(pts2[i3] - triangleHead[0], pts2[i3 + 1] - triangleHead[1]); + context.lineTo(pts2[i3] + triangleHead[0], pts2[i3 + 1] + triangleHead[1]); + context.lineTo(pts2[i3 + 2], pts2[i3 + 3]); + context.closePath(); + context.fill(); + } + }; + CRp$8.drawArrowheads = function(context, edge, opacity) { + var rs = edge._private.rscratch; + var isHaystack = rs.edgeType === "haystack"; + if (!isHaystack) { + this.drawArrowhead(context, edge, "source", rs.arrowStartX, rs.arrowStartY, rs.srcArrowAngle, opacity); + } + this.drawArrowhead(context, edge, "mid-target", rs.midX, rs.midY, rs.midtgtArrowAngle, opacity); + this.drawArrowhead(context, edge, "mid-source", rs.midX, rs.midY, rs.midsrcArrowAngle, opacity); + if (!isHaystack) { + this.drawArrowhead(context, edge, "target", rs.arrowEndX, rs.arrowEndY, rs.tgtArrowAngle, opacity); + } + }; + CRp$8.drawArrowhead = function(context, edge, prefix, x2, y2, angle, opacity) { + if (isNaN(x2) || x2 == null || isNaN(y2) || y2 == null || isNaN(angle) || angle == null) { + return; + } + var self2 = this; + var arrowShape = edge.pstyle(prefix + "-arrow-shape").value; + if (arrowShape === "none") { + return; + } + var arrowClearFill = edge.pstyle(prefix + "-arrow-fill").value === "hollow" ? "both" : "filled"; + var arrowFill = edge.pstyle(prefix + "-arrow-fill").value; + var edgeWidth = edge.pstyle("width").pfValue; + var pArrowWidth = edge.pstyle(prefix + "-arrow-width"); + var arrowWidth = pArrowWidth.value === "match-line" ? edgeWidth : pArrowWidth.pfValue; + if (pArrowWidth.units === "%") + arrowWidth *= edgeWidth; + var edgeOpacity = edge.pstyle("opacity").value; + if (opacity === void 0) { + opacity = edgeOpacity; + } + var gco = context.globalCompositeOperation; + if (opacity !== 1 || arrowFill === "hollow") { + context.globalCompositeOperation = "destination-out"; + self2.colorFillStyle(context, 255, 255, 255, 1); + self2.colorStrokeStyle(context, 255, 255, 255, 1); + self2.drawArrowShape(edge, context, arrowClearFill, edgeWidth, arrowShape, arrowWidth, x2, y2, angle); + context.globalCompositeOperation = gco; + } + var color2 = edge.pstyle(prefix + "-arrow-color").value; + self2.colorFillStyle(context, color2[0], color2[1], color2[2], opacity); + self2.colorStrokeStyle(context, color2[0], color2[1], color2[2], opacity); + self2.drawArrowShape(edge, context, arrowFill, edgeWidth, arrowShape, arrowWidth, x2, y2, angle); + }; + CRp$8.drawArrowShape = function(edge, context, fill, edgeWidth, shape, shapeWidth, x2, y2, angle) { + var r = this; + var usePaths = this.usePaths() && shape !== "triangle-cross"; + var pathCacheHit = false; + var path2; + var canvasContext = context; + var translation = { + x: x2, + y: y2 + }; + var scale = edge.pstyle("arrow-scale").value; + var size2 = this.getArrowWidth(edgeWidth, scale); + var shapeImpl = r.arrowShapes[shape]; + if (usePaths) { + var cache2 = r.arrowPathCache = r.arrowPathCache || []; + var key = hashString(shape); + var cachedPath = cache2[key]; + if (cachedPath != null) { + path2 = context = cachedPath; + pathCacheHit = true; + } else { + path2 = context = new Path2D(); + cache2[key] = path2; + } + } + if (!pathCacheHit) { + if (context.beginPath) { + context.beginPath(); + } + if (usePaths) { + shapeImpl.draw(context, 1, 0, { + x: 0, + y: 0 + }, 1); + } else { + shapeImpl.draw(context, size2, angle, translation, edgeWidth); + } + if (context.closePath) { + context.closePath(); + } + } + context = canvasContext; + if (usePaths) { + context.translate(x2, y2); + context.rotate(angle); + context.scale(size2, size2); + } + if (fill === "filled" || fill === "both") { + if (usePaths) { + context.fill(path2); + } else { + context.fill(); + } + } + if (fill === "hollow" || fill === "both") { + context.lineWidth = shapeWidth / (usePaths ? size2 : 1); + context.lineJoin = "miter"; + if (usePaths) { + context.stroke(path2); + } else { + context.stroke(); + } + } + if (usePaths) { + context.scale(1 / size2, 1 / size2); + context.rotate(-angle); + context.translate(-x2, -y2); + } + }; + var CRp$7 = {}; + CRp$7.safeDrawImage = function(context, img, ix, iy, iw, ih, x2, y2, w2, h) { + if (iw <= 0 || ih <= 0 || w2 <= 0 || h <= 0) { + return; + } + try { + context.drawImage(img, ix, iy, iw, ih, x2, y2, w2, h); + } catch (e) { + warn(e); + } + }; + CRp$7.drawInscribedImage = function(context, img, node2, index2, nodeOpacity) { + var r = this; + var pos = node2.position(); + var nodeX = pos.x; + var nodeY = pos.y; + var styleObj = node2.cy().style(); + var getIndexedStyle = styleObj.getIndexedStyle.bind(styleObj); + var fit = getIndexedStyle(node2, "background-fit", "value", index2); + var repeat2 = getIndexedStyle(node2, "background-repeat", "value", index2); + var nodeW = node2.width(); + var nodeH = node2.height(); + var paddingX2 = node2.padding() * 2; + var nodeTW = nodeW + (getIndexedStyle(node2, "background-width-relative-to", "value", index2) === "inner" ? 0 : paddingX2); + var nodeTH = nodeH + (getIndexedStyle(node2, "background-height-relative-to", "value", index2) === "inner" ? 0 : paddingX2); + var rs = node2._private.rscratch; + var clip = getIndexedStyle(node2, "background-clip", "value", index2); + var shouldClip = clip === "node"; + var imgOpacity = getIndexedStyle(node2, "background-image-opacity", "value", index2) * nodeOpacity; + var smooth = getIndexedStyle(node2, "background-image-smoothing", "value", index2); + var imgW = img.width || img.cachedW; + var imgH = img.height || img.cachedH; + if (null == imgW || null == imgH) { + document.body.appendChild(img); + imgW = img.cachedW = img.width || img.offsetWidth; + imgH = img.cachedH = img.height || img.offsetHeight; + document.body.removeChild(img); + } + var w2 = imgW; + var h = imgH; + if (getIndexedStyle(node2, "background-width", "value", index2) !== "auto") { + if (getIndexedStyle(node2, "background-width", "units", index2) === "%") { + w2 = getIndexedStyle(node2, "background-width", "pfValue", index2) * nodeTW; + } else { + w2 = getIndexedStyle(node2, "background-width", "pfValue", index2); + } + } + if (getIndexedStyle(node2, "background-height", "value", index2) !== "auto") { + if (getIndexedStyle(node2, "background-height", "units", index2) === "%") { + h = getIndexedStyle(node2, "background-height", "pfValue", index2) * nodeTH; + } else { + h = getIndexedStyle(node2, "background-height", "pfValue", index2); + } + } + if (w2 === 0 || h === 0) { + return; + } + if (fit === "contain") { + var scale = Math.min(nodeTW / w2, nodeTH / h); + w2 *= scale; + h *= scale; + } else if (fit === "cover") { + var scale = Math.max(nodeTW / w2, nodeTH / h); + w2 *= scale; + h *= scale; + } + var x2 = nodeX - nodeTW / 2; + var posXUnits = getIndexedStyle(node2, "background-position-x", "units", index2); + var posXPfVal = getIndexedStyle(node2, "background-position-x", "pfValue", index2); + if (posXUnits === "%") { + x2 += (nodeTW - w2) * posXPfVal; + } else { + x2 += posXPfVal; + } + var offXUnits = getIndexedStyle(node2, "background-offset-x", "units", index2); + var offXPfVal = getIndexedStyle(node2, "background-offset-x", "pfValue", index2); + if (offXUnits === "%") { + x2 += (nodeTW - w2) * offXPfVal; + } else { + x2 += offXPfVal; + } + var y2 = nodeY - nodeTH / 2; + var posYUnits = getIndexedStyle(node2, "background-position-y", "units", index2); + var posYPfVal = getIndexedStyle(node2, "background-position-y", "pfValue", index2); + if (posYUnits === "%") { + y2 += (nodeTH - h) * posYPfVal; + } else { + y2 += posYPfVal; + } + var offYUnits = getIndexedStyle(node2, "background-offset-y", "units", index2); + var offYPfVal = getIndexedStyle(node2, "background-offset-y", "pfValue", index2); + if (offYUnits === "%") { + y2 += (nodeTH - h) * offYPfVal; + } else { + y2 += offYPfVal; + } + if (rs.pathCache) { + x2 -= nodeX; + y2 -= nodeY; + nodeX = 0; + nodeY = 0; + } + var gAlpha = context.globalAlpha; + context.globalAlpha = imgOpacity; + var smoothingEnabled = r.getImgSmoothing(context); + var isSmoothingSwitched = false; + if (smooth === "no" && smoothingEnabled) { + r.setImgSmoothing(context, false); + isSmoothingSwitched = true; + } else if (smooth === "yes" && !smoothingEnabled) { + r.setImgSmoothing(context, true); + isSmoothingSwitched = true; + } + if (repeat2 === "no-repeat") { + if (shouldClip) { + context.save(); + if (rs.pathCache) { + context.clip(rs.pathCache); + } else { + r.nodeShapes[r.getNodeShape(node2)].draw(context, nodeX, nodeY, nodeTW, nodeTH); + context.clip(); + } + } + r.safeDrawImage(context, img, 0, 0, imgW, imgH, x2, y2, w2, h); + if (shouldClip) { + context.restore(); + } + } else { + var pattern = context.createPattern(img, repeat2); + context.fillStyle = pattern; + r.nodeShapes[r.getNodeShape(node2)].draw(context, nodeX, nodeY, nodeTW, nodeTH); + context.translate(x2, y2); + context.fill(); + context.translate(-x2, -y2); + } + context.globalAlpha = gAlpha; + if (isSmoothingSwitched) { + r.setImgSmoothing(context, smoothingEnabled); + } + }; + var CRp$6 = {}; + CRp$6.eleTextBiggerThanMin = function(ele, scale) { + if (!scale) { + var zoom = ele.cy().zoom(); + var pxRatio = this.getPixelRatio(); + var lvl = Math.ceil(log2(zoom * pxRatio)); + scale = Math.pow(2, lvl); + } + var computedSize = ele.pstyle("font-size").pfValue * scale; + var minSize = ele.pstyle("min-zoomed-font-size").pfValue; + if (computedSize < minSize) { + return false; + } + return true; + }; + CRp$6.drawElementText = function(context, ele, shiftToOriginWithBb, force, prefix) { + var useEleOpacity = arguments.length > 5 && arguments[5] !== void 0 ? arguments[5] : true; + var r = this; + if (force == null) { + if (useEleOpacity && !r.eleTextBiggerThanMin(ele)) { + return; + } + } else if (force === false) { + return; + } + if (ele.isNode()) { + var label = ele.pstyle("label"); + if (!label || !label.value) { + return; + } + var justification = r.getLabelJustification(ele); + context.textAlign = justification; + context.textBaseline = "bottom"; + } else { + var badLine = ele.element()._private.rscratch.badLine; + var _label = ele.pstyle("label"); + var srcLabel = ele.pstyle("source-label"); + var tgtLabel = ele.pstyle("target-label"); + if (badLine || (!_label || !_label.value) && (!srcLabel || !srcLabel.value) && (!tgtLabel || !tgtLabel.value)) { + return; + } + context.textAlign = "center"; + context.textBaseline = "bottom"; + } + var applyRotation = !shiftToOriginWithBb; + var bb; + if (shiftToOriginWithBb) { + bb = shiftToOriginWithBb; + context.translate(-bb.x1, -bb.y1); + } + if (prefix == null) { + r.drawText(context, ele, null, applyRotation, useEleOpacity); + if (ele.isEdge()) { + r.drawText(context, ele, "source", applyRotation, useEleOpacity); + r.drawText(context, ele, "target", applyRotation, useEleOpacity); + } + } else { + r.drawText(context, ele, prefix, applyRotation, useEleOpacity); + } + if (shiftToOriginWithBb) { + context.translate(bb.x1, bb.y1); + } + }; + CRp$6.getFontCache = function(context) { + var cache2; + this.fontCaches = this.fontCaches || []; + for (var i3 = 0; i3 < this.fontCaches.length; i3++) { + cache2 = this.fontCaches[i3]; + if (cache2.context === context) { + return cache2; + } + } + cache2 = { + context + }; + this.fontCaches.push(cache2); + return cache2; + }; + CRp$6.setupTextStyle = function(context, ele) { + var useEleOpacity = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : true; + var labelStyle = ele.pstyle("font-style").strValue; + var labelSize = ele.pstyle("font-size").pfValue + "px"; + var labelFamily = ele.pstyle("font-family").strValue; + var labelWeight = ele.pstyle("font-weight").strValue; + var opacity = useEleOpacity ? ele.effectiveOpacity() * ele.pstyle("text-opacity").value : 1; + var outlineOpacity = ele.pstyle("text-outline-opacity").value * opacity; + var color2 = ele.pstyle("color").value; + var outlineColor = ele.pstyle("text-outline-color").value; + context.font = labelStyle + " " + labelWeight + " " + labelSize + " " + labelFamily; + context.lineJoin = "round"; + this.colorFillStyle(context, color2[0], color2[1], color2[2], opacity); + this.colorStrokeStyle(context, outlineColor[0], outlineColor[1], outlineColor[2], outlineOpacity); + }; + function roundRect(ctx, x2, y2, width2, height) { + var radius = arguments.length > 5 && arguments[5] !== void 0 ? arguments[5] : 5; + var stroke = arguments.length > 6 ? arguments[6] : void 0; + ctx.beginPath(); + ctx.moveTo(x2 + radius, y2); + ctx.lineTo(x2 + width2 - radius, y2); + ctx.quadraticCurveTo(x2 + width2, y2, x2 + width2, y2 + radius); + ctx.lineTo(x2 + width2, y2 + height - radius); + ctx.quadraticCurveTo(x2 + width2, y2 + height, x2 + width2 - radius, y2 + height); + ctx.lineTo(x2 + radius, y2 + height); + ctx.quadraticCurveTo(x2, y2 + height, x2, y2 + height - radius); + ctx.lineTo(x2, y2 + radius); + ctx.quadraticCurveTo(x2, y2, x2 + radius, y2); + ctx.closePath(); + if (stroke) + ctx.stroke(); + else + ctx.fill(); + } + CRp$6.getTextAngle = function(ele, prefix) { + var theta; + var _p = ele._private; + var rscratch = _p.rscratch; + var pdash = prefix ? prefix + "-" : ""; + var rotation = ele.pstyle(pdash + "text-rotation"); + var textAngle = getPrefixedProperty(rscratch, "labelAngle", prefix); + if (rotation.strValue === "autorotate") { + theta = ele.isEdge() ? textAngle : 0; + } else if (rotation.strValue === "none") { + theta = 0; + } else { + theta = rotation.pfValue; + } + return theta; + }; + CRp$6.drawText = function(context, ele, prefix) { + var applyRotation = arguments.length > 3 && arguments[3] !== void 0 ? arguments[3] : true; + var useEleOpacity = arguments.length > 4 && arguments[4] !== void 0 ? arguments[4] : true; + var _p = ele._private; + var rscratch = _p.rscratch; + var parentOpacity = useEleOpacity ? ele.effectiveOpacity() : 1; + if (useEleOpacity && (parentOpacity === 0 || ele.pstyle("text-opacity").value === 0)) { + return; + } + if (prefix === "main") { + prefix = null; + } + var textX = getPrefixedProperty(rscratch, "labelX", prefix); + var textY = getPrefixedProperty(rscratch, "labelY", prefix); + var orgTextX, orgTextY; + var text2 = this.getLabelText(ele, prefix); + if (text2 != null && text2 !== "" && !isNaN(textX) && !isNaN(textY)) { + this.setupTextStyle(context, ele, useEleOpacity); + var pdash = prefix ? prefix + "-" : ""; + var textW = getPrefixedProperty(rscratch, "labelWidth", prefix); + var textH = getPrefixedProperty(rscratch, "labelHeight", prefix); + var marginX = ele.pstyle(pdash + "text-margin-x").pfValue; + var marginY = ele.pstyle(pdash + "text-margin-y").pfValue; + var isEdge = ele.isEdge(); + var halign = ele.pstyle("text-halign").value; + var valign = ele.pstyle("text-valign").value; + if (isEdge) { + halign = "center"; + valign = "center"; + } + textX += marginX; + textY += marginY; + var theta; + if (!applyRotation) { + theta = 0; + } else { + theta = this.getTextAngle(ele, prefix); + } + if (theta !== 0) { + orgTextX = textX; + orgTextY = textY; + context.translate(orgTextX, orgTextY); + context.rotate(theta); + textX = 0; + textY = 0; + } + switch (valign) { + case "top": + break; + case "center": + textY += textH / 2; + break; + case "bottom": + textY += textH; + break; + } + var backgroundOpacity = ele.pstyle("text-background-opacity").value; + var borderOpacity = ele.pstyle("text-border-opacity").value; + var textBorderWidth = ele.pstyle("text-border-width").pfValue; + var backgroundPadding = ele.pstyle("text-background-padding").pfValue; + var styleShape = ele.pstyle("text-background-shape").strValue; + var rounded = styleShape.indexOf("round") === 0; + var roundRadius = 2; + if (backgroundOpacity > 0 || textBorderWidth > 0 && borderOpacity > 0) { + var bgX = textX - backgroundPadding; + switch (halign) { + case "left": + bgX -= textW; + break; + case "center": + bgX -= textW / 2; + break; + } + var bgY = textY - textH - backgroundPadding; + var bgW = textW + 2 * backgroundPadding; + var bgH = textH + 2 * backgroundPadding; + if (backgroundOpacity > 0) { + var textFill = context.fillStyle; + var textBackgroundColor = ele.pstyle("text-background-color").value; + context.fillStyle = "rgba(" + textBackgroundColor[0] + "," + textBackgroundColor[1] + "," + textBackgroundColor[2] + "," + backgroundOpacity * parentOpacity + ")"; + if (rounded) { + roundRect(context, bgX, bgY, bgW, bgH, roundRadius); + } else { + context.fillRect(bgX, bgY, bgW, bgH); + } + context.fillStyle = textFill; + } + if (textBorderWidth > 0 && borderOpacity > 0) { + var textStroke = context.strokeStyle; + var textLineWidth = context.lineWidth; + var textBorderColor = ele.pstyle("text-border-color").value; + var textBorderStyle = ele.pstyle("text-border-style").value; + context.strokeStyle = "rgba(" + textBorderColor[0] + "," + textBorderColor[1] + "," + textBorderColor[2] + "," + borderOpacity * parentOpacity + ")"; + context.lineWidth = textBorderWidth; + if (context.setLineDash) { + switch (textBorderStyle) { + case "dotted": + context.setLineDash([1, 1]); + break; + case "dashed": + context.setLineDash([4, 2]); + break; + case "double": + context.lineWidth = textBorderWidth / 4; + context.setLineDash([]); + break; + case "solid": + context.setLineDash([]); + break; + } + } + if (rounded) { + roundRect(context, bgX, bgY, bgW, bgH, roundRadius, "stroke"); + } else { + context.strokeRect(bgX, bgY, bgW, bgH); + } + if (textBorderStyle === "double") { + var whiteWidth = textBorderWidth / 2; + if (rounded) { + roundRect(context, bgX + whiteWidth, bgY + whiteWidth, bgW - whiteWidth * 2, bgH - whiteWidth * 2, roundRadius, "stroke"); + } else { + context.strokeRect(bgX + whiteWidth, bgY + whiteWidth, bgW - whiteWidth * 2, bgH - whiteWidth * 2); + } + } + if (context.setLineDash) { + context.setLineDash([]); + } + context.lineWidth = textLineWidth; + context.strokeStyle = textStroke; + } + } + var lineWidth = 2 * ele.pstyle("text-outline-width").pfValue; + if (lineWidth > 0) { + context.lineWidth = lineWidth; + } + if (ele.pstyle("text-wrap").value === "wrap") { + var lines = getPrefixedProperty(rscratch, "labelWrapCachedLines", prefix); + var lineHeight = getPrefixedProperty(rscratch, "labelLineHeight", prefix); + var halfTextW = textW / 2; + var justification = this.getLabelJustification(ele); + if (justification === "auto") + ; + else if (halign === "left") { + if (justification === "left") { + textX += -textW; + } else if (justification === "center") { + textX += -halfTextW; + } + } else if (halign === "center") { + if (justification === "left") { + textX += -halfTextW; + } else if (justification === "right") { + textX += halfTextW; + } + } else if (halign === "right") { + if (justification === "center") { + textX += halfTextW; + } else if (justification === "right") { + textX += textW; + } + } + switch (valign) { + case "top": + textY -= (lines.length - 1) * lineHeight; + break; + case "center": + case "bottom": + textY -= (lines.length - 1) * lineHeight; + break; + } + for (var l = 0; l < lines.length; l++) { + if (lineWidth > 0) { + context.strokeText(lines[l], textX, textY); + } + context.fillText(lines[l], textX, textY); + textY += lineHeight; + } + } else { + if (lineWidth > 0) { + context.strokeText(text2, textX, textY); + } + context.fillText(text2, textX, textY); + } + if (theta !== 0) { + context.rotate(-theta); + context.translate(-orgTextX, -orgTextY); + } + } + }; + var CRp$5 = {}; + CRp$5.drawNode = function(context, node2, shiftToOriginWithBb) { + var drawLabel2 = arguments.length > 3 && arguments[3] !== void 0 ? arguments[3] : true; + var shouldDrawOverlay = arguments.length > 4 && arguments[4] !== void 0 ? arguments[4] : true; + var shouldDrawOpacity = arguments.length > 5 && arguments[5] !== void 0 ? arguments[5] : true; + var r = this; + var nodeWidth, nodeHeight; + var _p = node2._private; + var rs = _p.rscratch; + var pos = node2.position(); + if (!number$12(pos.x) || !number$12(pos.y)) { + return; + } + if (shouldDrawOpacity && !node2.visible()) { + return; + } + var eleOpacity = shouldDrawOpacity ? node2.effectiveOpacity() : 1; + var usePaths = r.usePaths(); + var path2; + var pathCacheHit = false; + var padding2 = node2.padding(); + nodeWidth = node2.width() + 2 * padding2; + nodeHeight = node2.height() + 2 * padding2; + var bb; + if (shiftToOriginWithBb) { + bb = shiftToOriginWithBb; + context.translate(-bb.x1, -bb.y1); + } + var bgImgProp = node2.pstyle("background-image"); + var urls = bgImgProp.value; + var urlDefined = new Array(urls.length); + var image = new Array(urls.length); + var numImages = 0; + for (var i3 = 0; i3 < urls.length; i3++) { + var url = urls[i3]; + var defd = urlDefined[i3] = url != null && url !== "none"; + if (defd) { + var bgImgCrossOrigin = node2.cy().style().getIndexedStyle(node2, "background-image-crossorigin", "value", i3); + numImages++; + image[i3] = r.getCachedImage(url, bgImgCrossOrigin, function() { + _p.backgroundTimestamp = Date.now(); + node2.emitAndNotify("background"); + }); + } + } + var darkness = node2.pstyle("background-blacken").value; + var borderWidth = node2.pstyle("border-width").pfValue; + var bgOpacity = node2.pstyle("background-opacity").value * eleOpacity; + var borderColor = node2.pstyle("border-color").value; + var borderStyle = node2.pstyle("border-style").value; + var borderOpacity = node2.pstyle("border-opacity").value * eleOpacity; + var outlineWidth = node2.pstyle("outline-width").pfValue; + var outlineColor = node2.pstyle("outline-color").value; + var outlineStyle = node2.pstyle("outline-style").value; + var outlineOpacity = node2.pstyle("outline-opacity").value * eleOpacity; + var outlineOffset = node2.pstyle("outline-offset").value; + context.lineJoin = "miter"; + var setupShapeColor = function setupShapeColor2() { + var bgOpy = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : bgOpacity; + r.eleFillStyle(context, node2, bgOpy); + }; + var setupBorderColor = function setupBorderColor2() { + var bdrOpy = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : borderOpacity; + r.colorStrokeStyle(context, borderColor[0], borderColor[1], borderColor[2], bdrOpy); + }; + var setupOutlineColor = function setupOutlineColor2() { + var otlnOpy = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : outlineOpacity; + r.colorStrokeStyle(context, outlineColor[0], outlineColor[1], outlineColor[2], otlnOpy); + }; + var getPath = function getPath2(width2, height, shape, points) { + var pathCache = r.nodePathCache = r.nodePathCache || []; + var key = hashStrings(shape === "polygon" ? shape + "," + points.join(",") : shape, "" + height, "" + width2); + var cachedPath = pathCache[key]; + var path3; + var cacheHit = false; + if (cachedPath != null) { + path3 = cachedPath; + cacheHit = true; + rs.pathCache = path3; + } else { + path3 = new Path2D(); + pathCache[key] = rs.pathCache = path3; + } + return { + path: path3, + cacheHit + }; + }; + var styleShape = node2.pstyle("shape").strValue; + var shapePts = node2.pstyle("shape-polygon-points").pfValue; + if (usePaths) { + context.translate(pos.x, pos.y); + var shapePath = getPath(nodeWidth, nodeHeight, styleShape, shapePts); + path2 = shapePath.path; + pathCacheHit = shapePath.cacheHit; + } + var drawShape = function drawShape2() { + if (!pathCacheHit) { + var npos = pos; + if (usePaths) { + npos = { + x: 0, + y: 0 + }; + } + r.nodeShapes[r.getNodeShape(node2)].draw(path2 || context, npos.x, npos.y, nodeWidth, nodeHeight); + } + if (usePaths) { + context.fill(path2); + } else { + context.fill(); + } + }; + var drawImages = function drawImages2() { + var nodeOpacity = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : eleOpacity; + var inside = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : true; + var prevBging = _p.backgrounding; + var totalCompleted = 0; + for (var _i6 = 0; _i6 < image.length; _i6++) { + var bgContainment = node2.cy().style().getIndexedStyle(node2, "background-image-containment", "value", _i6); + if (inside && bgContainment === "over" || !inside && bgContainment === "inside") { + totalCompleted++; + continue; + } + if (urlDefined[_i6] && image[_i6].complete && !image[_i6].error) { + totalCompleted++; + r.drawInscribedImage(context, image[_i6], node2, _i6, nodeOpacity); + } + } + _p.backgrounding = !(totalCompleted === numImages); + if (prevBging !== _p.backgrounding) { + node2.updateStyle(false); + } + }; + var drawPie = function drawPie2() { + var redrawShape = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : false; + var pieOpacity = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : eleOpacity; + if (r.hasPie(node2)) { + r.drawPie(context, node2, pieOpacity); + if (redrawShape) { + if (!usePaths) { + r.nodeShapes[r.getNodeShape(node2)].draw(context, pos.x, pos.y, nodeWidth, nodeHeight); + } + } + } + }; + var darken2 = function darken3() { + var darkenOpacity = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : eleOpacity; + var opacity = (darkness > 0 ? darkness : -darkness) * darkenOpacity; + var c2 = darkness > 0 ? 0 : 255; + if (darkness !== 0) { + r.colorFillStyle(context, c2, c2, c2, opacity); + if (usePaths) { + context.fill(path2); + } else { + context.fill(); + } + } + }; + var drawBorder = function drawBorder2() { + if (borderWidth > 0) { + context.lineWidth = borderWidth; + context.lineCap = "butt"; + if (context.setLineDash) { + switch (borderStyle) { + case "dotted": + context.setLineDash([1, 1]); + break; + case "dashed": + context.setLineDash([4, 2]); + break; + case "solid": + case "double": + context.setLineDash([]); + break; + } + } + if (usePaths) { + context.stroke(path2); + } else { + context.stroke(); + } + if (borderStyle === "double") { + context.lineWidth = borderWidth / 3; + var gco = context.globalCompositeOperation; + context.globalCompositeOperation = "destination-out"; + if (usePaths) { + context.stroke(path2); + } else { + context.stroke(); + } + context.globalCompositeOperation = gco; + } + if (context.setLineDash) { + context.setLineDash([]); + } + } + }; + var drawOutline = function drawOutline2() { + if (outlineWidth > 0) { + context.lineWidth = outlineWidth; + context.lineCap = "butt"; + if (context.setLineDash) { + switch (outlineStyle) { + case "dotted": + context.setLineDash([1, 1]); + break; + case "dashed": + context.setLineDash([4, 2]); + break; + case "solid": + case "double": + context.setLineDash([]); + break; + } + } + var npos = pos; + if (usePaths) { + npos = { + x: 0, + y: 0 + }; + } + var shape = r.getNodeShape(node2); + var scaleX = (nodeWidth + borderWidth + (outlineWidth + outlineOffset)) / nodeWidth; + var scaleY = (nodeHeight + borderWidth + (outlineWidth + outlineOffset)) / nodeHeight; + var sWidth = nodeWidth * scaleX; + var sHeight = nodeHeight * scaleY; + var points = r.nodeShapes[shape].points; + var _path; + if (usePaths) { + var outlinePath = getPath(sWidth, sHeight, shape, points); + _path = outlinePath.path; + } + if (shape === "ellipse") { + r.drawEllipsePath(_path || context, npos.x, npos.y, sWidth, sHeight); + } else if (["round-diamond", "round-heptagon", "round-hexagon", "round-octagon", "round-pentagon", "round-polygon", "round-triangle", "round-tag"].includes(shape)) { + var sMult = 0; + var offsetX = 0; + var offsetY = 0; + if (shape === "round-diamond") { + sMult = (borderWidth + outlineOffset + outlineWidth) * 1.4; + } else if (shape === "round-heptagon") { + sMult = (borderWidth + outlineOffset + outlineWidth) * 1.075; + offsetY = -(borderWidth / 2 + outlineOffset + outlineWidth) / 35; + } else if (shape === "round-hexagon") { + sMult = (borderWidth + outlineOffset + outlineWidth) * 1.12; + } else if (shape === "round-pentagon") { + sMult = (borderWidth + outlineOffset + outlineWidth) * 1.13; + offsetY = -(borderWidth / 2 + outlineOffset + outlineWidth) / 15; + } else if (shape === "round-tag") { + sMult = (borderWidth + outlineOffset + outlineWidth) * 1.12; + offsetX = (borderWidth / 2 + outlineWidth + outlineOffset) * 0.07; + } else if (shape === "round-triangle") { + sMult = (borderWidth + outlineOffset + outlineWidth) * (Math.PI / 2); + offsetY = -(borderWidth + outlineOffset / 2 + outlineWidth) / Math.PI; + } + if (sMult !== 0) { + scaleX = (nodeWidth + sMult) / nodeWidth; + scaleY = (nodeHeight + sMult) / nodeHeight; + } + r.drawRoundPolygonPath(_path || context, npos.x + offsetX, npos.y + offsetY, nodeWidth * scaleX, nodeHeight * scaleY, points); + } else if (["roundrectangle", "round-rectangle"].includes(shape)) { + r.drawRoundRectanglePath(_path || context, npos.x, npos.y, sWidth, sHeight); + } else if (["cutrectangle", "cut-rectangle"].includes(shape)) { + r.drawCutRectanglePath(_path || context, npos.x, npos.y, sWidth, sHeight); + } else if (["bottomroundrectangle", "bottom-round-rectangle"].includes(shape)) { + r.drawBottomRoundRectanglePath(_path || context, npos.x, npos.y, sWidth, sHeight); + } else if (shape === "barrel") { + r.drawBarrelPath(_path || context, npos.x, npos.y, sWidth, sHeight); + } else if (shape.startsWith("polygon") || ["rhomboid", "right-rhomboid", "round-tag", "tag", "vee"].includes(shape)) { + var pad2 = (borderWidth + outlineWidth + outlineOffset) / nodeWidth; + points = joinLines(expandPolygon(points, pad2)); + r.drawPolygonPath(_path || context, npos.x, npos.y, nodeWidth, nodeHeight, points); + } else { + var _pad = (borderWidth + outlineWidth + outlineOffset) / nodeWidth; + points = joinLines(expandPolygon(points, -_pad)); + r.drawPolygonPath(_path || context, npos.x, npos.y, nodeWidth, nodeHeight, points); + } + if (usePaths) { + context.stroke(_path); + } else { + context.stroke(); + } + if (outlineStyle === "double") { + context.lineWidth = borderWidth / 3; + var gco = context.globalCompositeOperation; + context.globalCompositeOperation = "destination-out"; + if (usePaths) { + context.stroke(_path); + } else { + context.stroke(); + } + context.globalCompositeOperation = gco; + } + if (context.setLineDash) { + context.setLineDash([]); + } + } + }; + var drawOverlay = function drawOverlay2() { + if (shouldDrawOverlay) { + r.drawNodeOverlay(context, node2, pos, nodeWidth, nodeHeight); + } + }; + var drawUnderlay = function drawUnderlay2() { + if (shouldDrawOverlay) { + r.drawNodeUnderlay(context, node2, pos, nodeWidth, nodeHeight); + } + }; + var drawText2 = function drawText3() { + r.drawElementText(context, node2, null, drawLabel2); + }; + var ghost = node2.pstyle("ghost").value === "yes"; + if (ghost) { + var gx = node2.pstyle("ghost-offset-x").pfValue; + var gy = node2.pstyle("ghost-offset-y").pfValue; + var ghostOpacity = node2.pstyle("ghost-opacity").value; + var effGhostOpacity = ghostOpacity * eleOpacity; + context.translate(gx, gy); + setupOutlineColor(); + drawOutline(); + setupShapeColor(ghostOpacity * bgOpacity); + drawShape(); + drawImages(effGhostOpacity, true); + setupBorderColor(ghostOpacity * borderOpacity); + drawBorder(); + drawPie(darkness !== 0 || borderWidth !== 0); + drawImages(effGhostOpacity, false); + darken2(effGhostOpacity); + context.translate(-gx, -gy); + } + if (usePaths) { + context.translate(-pos.x, -pos.y); + } + drawUnderlay(); + if (usePaths) { + context.translate(pos.x, pos.y); + } + setupOutlineColor(); + drawOutline(); + setupShapeColor(); + drawShape(); + drawImages(eleOpacity, true); + setupBorderColor(); + drawBorder(); + drawPie(darkness !== 0 || borderWidth !== 0); + drawImages(eleOpacity, false); + darken2(); + if (usePaths) { + context.translate(-pos.x, -pos.y); + } + drawText2(); + drawOverlay(); + if (shiftToOriginWithBb) { + context.translate(bb.x1, bb.y1); + } + }; + var drawNodeOverlayUnderlay = function drawNodeOverlayUnderlay2(overlayOrUnderlay) { + if (!["overlay", "underlay"].includes(overlayOrUnderlay)) { + throw new Error("Invalid state"); + } + return function(context, node2, pos, nodeWidth, nodeHeight) { + var r = this; + if (!node2.visible()) { + return; + } + var padding2 = node2.pstyle("".concat(overlayOrUnderlay, "-padding")).pfValue; + var opacity = node2.pstyle("".concat(overlayOrUnderlay, "-opacity")).value; + var color2 = node2.pstyle("".concat(overlayOrUnderlay, "-color")).value; + var shape = node2.pstyle("".concat(overlayOrUnderlay, "-shape")).value; + if (opacity > 0) { + pos = pos || node2.position(); + if (nodeWidth == null || nodeHeight == null) { + var _padding = node2.padding(); + nodeWidth = node2.width() + 2 * _padding; + nodeHeight = node2.height() + 2 * _padding; + } + r.colorFillStyle(context, color2[0], color2[1], color2[2], opacity); + r.nodeShapes[shape].draw(context, pos.x, pos.y, nodeWidth + padding2 * 2, nodeHeight + padding2 * 2); + context.fill(); + } + }; + }; + CRp$5.drawNodeOverlay = drawNodeOverlayUnderlay("overlay"); + CRp$5.drawNodeUnderlay = drawNodeOverlayUnderlay("underlay"); + CRp$5.hasPie = function(node2) { + node2 = node2[0]; + return node2._private.hasPie; + }; + CRp$5.drawPie = function(context, node2, nodeOpacity, pos) { + node2 = node2[0]; + pos = pos || node2.position(); + var cyStyle = node2.cy().style(); + var pieSize = node2.pstyle("pie-size"); + var x2 = pos.x; + var y2 = pos.y; + var nodeW = node2.width(); + var nodeH = node2.height(); + var radius = Math.min(nodeW, nodeH) / 2; + var lastPercent = 0; + var usePaths = this.usePaths(); + if (usePaths) { + x2 = 0; + y2 = 0; + } + if (pieSize.units === "%") { + radius = radius * pieSize.pfValue; + } else if (pieSize.pfValue !== void 0) { + radius = pieSize.pfValue / 2; + } + for (var i3 = 1; i3 <= cyStyle.pieBackgroundN; i3++) { + var size2 = node2.pstyle("pie-" + i3 + "-background-size").value; + var color2 = node2.pstyle("pie-" + i3 + "-background-color").value; + var opacity = node2.pstyle("pie-" + i3 + "-background-opacity").value * nodeOpacity; + var percent = size2 / 100; + if (percent + lastPercent > 1) { + percent = 1 - lastPercent; + } + var angleStart = 1.5 * Math.PI + 2 * Math.PI * lastPercent; + var angleDelta = 2 * Math.PI * percent; + var angleEnd = angleStart + angleDelta; + if (size2 === 0 || lastPercent >= 1 || lastPercent + percent > 1) { + continue; + } + context.beginPath(); + context.moveTo(x2, y2); + context.arc(x2, y2, radius, angleStart, angleEnd); + context.closePath(); + this.colorFillStyle(context, color2[0], color2[1], color2[2], opacity); + context.fill(); + lastPercent += percent; + } + }; + var CRp$4 = {}; + var motionBlurDelay = 100; + CRp$4.getPixelRatio = function() { + var context = this.data.contexts[0]; + if (this.forcedPixelRatio != null) { + return this.forcedPixelRatio; + } + var backingStore = context.backingStorePixelRatio || context.webkitBackingStorePixelRatio || context.mozBackingStorePixelRatio || context.msBackingStorePixelRatio || context.oBackingStorePixelRatio || context.backingStorePixelRatio || 1; + return (window.devicePixelRatio || 1) / backingStore; + }; + CRp$4.paintCache = function(context) { + var caches = this.paintCaches = this.paintCaches || []; + var needToCreateCache = true; + var cache2; + for (var i3 = 0; i3 < caches.length; i3++) { + cache2 = caches[i3]; + if (cache2.context === context) { + needToCreateCache = false; + break; + } + } + if (needToCreateCache) { + cache2 = { + context + }; + caches.push(cache2); + } + return cache2; + }; + CRp$4.createGradientStyleFor = function(context, shapeStyleName, ele, fill, opacity) { + var gradientStyle; + var usePaths = this.usePaths(); + var colors3 = ele.pstyle(shapeStyleName + "-gradient-stop-colors").value, positions = ele.pstyle(shapeStyleName + "-gradient-stop-positions").pfValue; + if (fill === "radial-gradient") { + if (ele.isEdge()) { + var start2 = ele.sourceEndpoint(), end2 = ele.targetEndpoint(), mid = ele.midpoint(); + var d1 = dist2(start2, mid); + var d2 = dist2(end2, mid); + gradientStyle = context.createRadialGradient(mid.x, mid.y, 0, mid.x, mid.y, Math.max(d1, d2)); + } else { + var pos = usePaths ? { + x: 0, + y: 0 + } : ele.position(), width2 = ele.paddedWidth(), height = ele.paddedHeight(); + gradientStyle = context.createRadialGradient(pos.x, pos.y, 0, pos.x, pos.y, Math.max(width2, height)); + } + } else { + if (ele.isEdge()) { + var _start = ele.sourceEndpoint(), _end = ele.targetEndpoint(); + gradientStyle = context.createLinearGradient(_start.x, _start.y, _end.x, _end.y); + } else { + var _pos = usePaths ? { + x: 0, + y: 0 + } : ele.position(), _width = ele.paddedWidth(), _height = ele.paddedHeight(), halfWidth = _width / 2, halfHeight = _height / 2; + var direction2 = ele.pstyle("background-gradient-direction").value; + switch (direction2) { + case "to-bottom": + gradientStyle = context.createLinearGradient(_pos.x, _pos.y - halfHeight, _pos.x, _pos.y + halfHeight); + break; + case "to-top": + gradientStyle = context.createLinearGradient(_pos.x, _pos.y + halfHeight, _pos.x, _pos.y - halfHeight); + break; + case "to-left": + gradientStyle = context.createLinearGradient(_pos.x + halfWidth, _pos.y, _pos.x - halfWidth, _pos.y); + break; + case "to-right": + gradientStyle = context.createLinearGradient(_pos.x - halfWidth, _pos.y, _pos.x + halfWidth, _pos.y); + break; + case "to-bottom-right": + case "to-right-bottom": + gradientStyle = context.createLinearGradient(_pos.x - halfWidth, _pos.y - halfHeight, _pos.x + halfWidth, _pos.y + halfHeight); + break; + case "to-top-right": + case "to-right-top": + gradientStyle = context.createLinearGradient(_pos.x - halfWidth, _pos.y + halfHeight, _pos.x + halfWidth, _pos.y - halfHeight); + break; + case "to-bottom-left": + case "to-left-bottom": + gradientStyle = context.createLinearGradient(_pos.x + halfWidth, _pos.y - halfHeight, _pos.x - halfWidth, _pos.y + halfHeight); + break; + case "to-top-left": + case "to-left-top": + gradientStyle = context.createLinearGradient(_pos.x + halfWidth, _pos.y + halfHeight, _pos.x - halfWidth, _pos.y - halfHeight); + break; + } + } + } + if (!gradientStyle) + return null; + var hasPositions = positions.length === colors3.length; + var length2 = colors3.length; + for (var i3 = 0; i3 < length2; i3++) { + gradientStyle.addColorStop(hasPositions ? positions[i3] : i3 / (length2 - 1), "rgba(" + colors3[i3][0] + "," + colors3[i3][1] + "," + colors3[i3][2] + "," + opacity + ")"); + } + return gradientStyle; + }; + CRp$4.gradientFillStyle = function(context, ele, fill, opacity) { + var gradientStyle = this.createGradientStyleFor(context, "background", ele, fill, opacity); + if (!gradientStyle) + return null; + context.fillStyle = gradientStyle; + }; + CRp$4.colorFillStyle = function(context, r, g, b, a) { + context.fillStyle = "rgba(" + r + "," + g + "," + b + "," + a + ")"; + }; + CRp$4.eleFillStyle = function(context, ele, opacity) { + var backgroundFill = ele.pstyle("background-fill").value; + if (backgroundFill === "linear-gradient" || backgroundFill === "radial-gradient") { + this.gradientFillStyle(context, ele, backgroundFill, opacity); + } else { + var backgroundColor = ele.pstyle("background-color").value; + this.colorFillStyle(context, backgroundColor[0], backgroundColor[1], backgroundColor[2], opacity); + } + }; + CRp$4.gradientStrokeStyle = function(context, ele, fill, opacity) { + var gradientStyle = this.createGradientStyleFor(context, "line", ele, fill, opacity); + if (!gradientStyle) + return null; + context.strokeStyle = gradientStyle; + }; + CRp$4.colorStrokeStyle = function(context, r, g, b, a) { + context.strokeStyle = "rgba(" + r + "," + g + "," + b + "," + a + ")"; + }; + CRp$4.eleStrokeStyle = function(context, ele, opacity) { + var lineFill = ele.pstyle("line-fill").value; + if (lineFill === "linear-gradient" || lineFill === "radial-gradient") { + this.gradientStrokeStyle(context, ele, lineFill, opacity); + } else { + var lineColor = ele.pstyle("line-color").value; + this.colorStrokeStyle(context, lineColor[0], lineColor[1], lineColor[2], opacity); + } + }; + CRp$4.matchCanvasSize = function(container) { + var r = this; + var data2 = r.data; + var bb = r.findContainerClientCoords(); + var width2 = bb[2]; + var height = bb[3]; + var pixelRatio = r.getPixelRatio(); + var mbPxRatio = r.motionBlurPxRatio; + if (container === r.data.bufferCanvases[r.MOTIONBLUR_BUFFER_NODE] || container === r.data.bufferCanvases[r.MOTIONBLUR_BUFFER_DRAG]) { + pixelRatio = mbPxRatio; + } + var canvasWidth = width2 * pixelRatio; + var canvasHeight = height * pixelRatio; + var canvas; + if (canvasWidth === r.canvasWidth && canvasHeight === r.canvasHeight) { + return; + } + r.fontCaches = null; + var canvasContainer = data2.canvasContainer; + canvasContainer.style.width = width2 + "px"; + canvasContainer.style.height = height + "px"; + for (var i3 = 0; i3 < r.CANVAS_LAYERS; i3++) { + canvas = data2.canvases[i3]; + canvas.width = canvasWidth; + canvas.height = canvasHeight; + canvas.style.width = width2 + "px"; + canvas.style.height = height + "px"; + } + for (var i3 = 0; i3 < r.BUFFER_COUNT; i3++) { + canvas = data2.bufferCanvases[i3]; + canvas.width = canvasWidth; + canvas.height = canvasHeight; + canvas.style.width = width2 + "px"; + canvas.style.height = height + "px"; + } + r.textureMult = 1; + if (pixelRatio <= 1) { + canvas = data2.bufferCanvases[r.TEXTURE_BUFFER]; + r.textureMult = 2; + canvas.width = canvasWidth * r.textureMult; + canvas.height = canvasHeight * r.textureMult; + } + r.canvasWidth = canvasWidth; + r.canvasHeight = canvasHeight; + }; + CRp$4.renderTo = function(cxt, zoom, pan, pxRatio) { + this.render({ + forcedContext: cxt, + forcedZoom: zoom, + forcedPan: pan, + drawAllLayers: true, + forcedPxRatio: pxRatio + }); + }; + CRp$4.render = function(options2) { + options2 = options2 || staticEmptyObject(); + var forcedContext = options2.forcedContext; + var drawAllLayers = options2.drawAllLayers; + var drawOnlyNodeLayer = options2.drawOnlyNodeLayer; + var forcedZoom = options2.forcedZoom; + var forcedPan = options2.forcedPan; + var r = this; + var pixelRatio = options2.forcedPxRatio === void 0 ? this.getPixelRatio() : options2.forcedPxRatio; + var cy = r.cy; + var data2 = r.data; + var needDraw = data2.canvasNeedsRedraw; + var textureDraw = r.textureOnViewport && !forcedContext && (r.pinching || r.hoverData.dragging || r.swipePanning || r.data.wheelZooming); + var motionBlur = options2.motionBlur !== void 0 ? options2.motionBlur : r.motionBlur; + var mbPxRatio = r.motionBlurPxRatio; + var hasCompoundNodes = cy.hasCompoundNodes(); + var inNodeDragGesture = r.hoverData.draggingEles; + var inBoxSelection = r.hoverData.selecting || r.touchData.selecting ? true : false; + motionBlur = motionBlur && !forcedContext && r.motionBlurEnabled && !inBoxSelection; + var motionBlurFadeEffect = motionBlur; + if (!forcedContext) { + if (r.prevPxRatio !== pixelRatio) { + r.invalidateContainerClientCoordsCache(); + r.matchCanvasSize(r.container); + r.redrawHint("eles", true); + r.redrawHint("drag", true); + } + r.prevPxRatio = pixelRatio; + } + if (!forcedContext && r.motionBlurTimeout) { + clearTimeout(r.motionBlurTimeout); + } + if (motionBlur) { + if (r.mbFrames == null) { + r.mbFrames = 0; + } + r.mbFrames++; + if (r.mbFrames < 3) { + motionBlurFadeEffect = false; + } + if (r.mbFrames > r.minMbLowQualFrames) { + r.motionBlurPxRatio = r.mbPxRBlurry; + } + } + if (r.clearingMotionBlur) { + r.motionBlurPxRatio = 1; + } + if (r.textureDrawLastFrame && !textureDraw) { + needDraw[r.NODE] = true; + needDraw[r.SELECT_BOX] = true; + } + var style = cy.style(); + var zoom = cy.zoom(); + var effectiveZoom = forcedZoom !== void 0 ? forcedZoom : zoom; + var pan = cy.pan(); + var effectivePan = { + x: pan.x, + y: pan.y + }; + var vp = { + zoom, + pan: { + x: pan.x, + y: pan.y + } + }; + var prevVp = r.prevViewport; + var viewportIsDiff = prevVp === void 0 || vp.zoom !== prevVp.zoom || vp.pan.x !== prevVp.pan.x || vp.pan.y !== prevVp.pan.y; + if (!viewportIsDiff && !(inNodeDragGesture && !hasCompoundNodes)) { + r.motionBlurPxRatio = 1; + } + if (forcedPan) { + effectivePan = forcedPan; + } + effectiveZoom *= pixelRatio; + effectivePan.x *= pixelRatio; + effectivePan.y *= pixelRatio; + var eles = r.getCachedZSortedEles(); + function mbclear(context2, x2, y2, w2, h) { + var gco = context2.globalCompositeOperation; + context2.globalCompositeOperation = "destination-out"; + r.colorFillStyle(context2, 255, 255, 255, r.motionBlurTransparency); + context2.fillRect(x2, y2, w2, h); + context2.globalCompositeOperation = gco; + } + function setContextTransform(context2, clear3) { + var ePan, eZoom, w2, h; + if (!r.clearingMotionBlur && (context2 === data2.bufferContexts[r.MOTIONBLUR_BUFFER_NODE] || context2 === data2.bufferContexts[r.MOTIONBLUR_BUFFER_DRAG])) { + ePan = { + x: pan.x * mbPxRatio, + y: pan.y * mbPxRatio + }; + eZoom = zoom * mbPxRatio; + w2 = r.canvasWidth * mbPxRatio; + h = r.canvasHeight * mbPxRatio; + } else { + ePan = effectivePan; + eZoom = effectiveZoom; + w2 = r.canvasWidth; + h = r.canvasHeight; + } + context2.setTransform(1, 0, 0, 1, 0, 0); + if (clear3 === "motionBlur") { + mbclear(context2, 0, 0, w2, h); + } else if (!forcedContext && (clear3 === void 0 || clear3)) { + context2.clearRect(0, 0, w2, h); + } + if (!drawAllLayers) { + context2.translate(ePan.x, ePan.y); + context2.scale(eZoom, eZoom); + } + if (forcedPan) { + context2.translate(forcedPan.x, forcedPan.y); + } + if (forcedZoom) { + context2.scale(forcedZoom, forcedZoom); + } + } + if (!textureDraw) { + r.textureDrawLastFrame = false; + } + if (textureDraw) { + r.textureDrawLastFrame = true; + if (!r.textureCache) { + r.textureCache = {}; + r.textureCache.bb = cy.mutableElements().boundingBox(); + r.textureCache.texture = r.data.bufferCanvases[r.TEXTURE_BUFFER]; + var cxt = r.data.bufferContexts[r.TEXTURE_BUFFER]; + cxt.setTransform(1, 0, 0, 1, 0, 0); + cxt.clearRect(0, 0, r.canvasWidth * r.textureMult, r.canvasHeight * r.textureMult); + r.render({ + forcedContext: cxt, + drawOnlyNodeLayer: true, + forcedPxRatio: pixelRatio * r.textureMult + }); + var vp = r.textureCache.viewport = { + zoom: cy.zoom(), + pan: cy.pan(), + width: r.canvasWidth, + height: r.canvasHeight + }; + vp.mpan = { + x: (0 - vp.pan.x) / vp.zoom, + y: (0 - vp.pan.y) / vp.zoom + }; + } + needDraw[r.DRAG] = false; + needDraw[r.NODE] = false; + var context = data2.contexts[r.NODE]; + var texture = r.textureCache.texture; + var vp = r.textureCache.viewport; + context.setTransform(1, 0, 0, 1, 0, 0); + if (motionBlur) { + mbclear(context, 0, 0, vp.width, vp.height); + } else { + context.clearRect(0, 0, vp.width, vp.height); + } + var outsideBgColor = style.core("outside-texture-bg-color").value; + var outsideBgOpacity = style.core("outside-texture-bg-opacity").value; + r.colorFillStyle(context, outsideBgColor[0], outsideBgColor[1], outsideBgColor[2], outsideBgOpacity); + context.fillRect(0, 0, vp.width, vp.height); + var zoom = cy.zoom(); + setContextTransform(context, false); + context.clearRect(vp.mpan.x, vp.mpan.y, vp.width / vp.zoom / pixelRatio, vp.height / vp.zoom / pixelRatio); + context.drawImage(texture, vp.mpan.x, vp.mpan.y, vp.width / vp.zoom / pixelRatio, vp.height / vp.zoom / pixelRatio); + } else if (r.textureOnViewport && !forcedContext) { + r.textureCache = null; + } + var extent = cy.extent(); + var vpManip = r.pinching || r.hoverData.dragging || r.swipePanning || r.data.wheelZooming || r.hoverData.draggingEles || r.cy.animated(); + var hideEdges = r.hideEdgesOnViewport && vpManip; + var needMbClear = []; + needMbClear[r.NODE] = !needDraw[r.NODE] && motionBlur && !r.clearedForMotionBlur[r.NODE] || r.clearingMotionBlur; + if (needMbClear[r.NODE]) { + r.clearedForMotionBlur[r.NODE] = true; + } + needMbClear[r.DRAG] = !needDraw[r.DRAG] && motionBlur && !r.clearedForMotionBlur[r.DRAG] || r.clearingMotionBlur; + if (needMbClear[r.DRAG]) { + r.clearedForMotionBlur[r.DRAG] = true; + } + if (needDraw[r.NODE] || drawAllLayers || drawOnlyNodeLayer || needMbClear[r.NODE]) { + var useBuffer = motionBlur && !needMbClear[r.NODE] && mbPxRatio !== 1; + var context = forcedContext || (useBuffer ? r.data.bufferContexts[r.MOTIONBLUR_BUFFER_NODE] : data2.contexts[r.NODE]); + var clear2 = motionBlur && !useBuffer ? "motionBlur" : void 0; + setContextTransform(context, clear2); + if (hideEdges) { + r.drawCachedNodes(context, eles.nondrag, pixelRatio, extent); + } else { + r.drawLayeredElements(context, eles.nondrag, pixelRatio, extent); + } + if (r.debug) { + r.drawDebugPoints(context, eles.nondrag); + } + if (!drawAllLayers && !motionBlur) { + needDraw[r.NODE] = false; + } + } + if (!drawOnlyNodeLayer && (needDraw[r.DRAG] || drawAllLayers || needMbClear[r.DRAG])) { + var useBuffer = motionBlur && !needMbClear[r.DRAG] && mbPxRatio !== 1; + var context = forcedContext || (useBuffer ? r.data.bufferContexts[r.MOTIONBLUR_BUFFER_DRAG] : data2.contexts[r.DRAG]); + setContextTransform(context, motionBlur && !useBuffer ? "motionBlur" : void 0); + if (hideEdges) { + r.drawCachedNodes(context, eles.drag, pixelRatio, extent); + } else { + r.drawCachedElements(context, eles.drag, pixelRatio, extent); + } + if (r.debug) { + r.drawDebugPoints(context, eles.drag); + } + if (!drawAllLayers && !motionBlur) { + needDraw[r.DRAG] = false; + } + } + if (r.showFps || !drawOnlyNodeLayer && needDraw[r.SELECT_BOX] && !drawAllLayers) { + var context = forcedContext || data2.contexts[r.SELECT_BOX]; + setContextTransform(context); + if (r.selection[4] == 1 && (r.hoverData.selecting || r.touchData.selecting)) { + var zoom = r.cy.zoom(); + var borderWidth = style.core("selection-box-border-width").value / zoom; + context.lineWidth = borderWidth; + context.fillStyle = "rgba(" + style.core("selection-box-color").value[0] + "," + style.core("selection-box-color").value[1] + "," + style.core("selection-box-color").value[2] + "," + style.core("selection-box-opacity").value + ")"; + context.fillRect(r.selection[0], r.selection[1], r.selection[2] - r.selection[0], r.selection[3] - r.selection[1]); + if (borderWidth > 0) { + context.strokeStyle = "rgba(" + style.core("selection-box-border-color").value[0] + "," + style.core("selection-box-border-color").value[1] + "," + style.core("selection-box-border-color").value[2] + "," + style.core("selection-box-opacity").value + ")"; + context.strokeRect(r.selection[0], r.selection[1], r.selection[2] - r.selection[0], r.selection[3] - r.selection[1]); + } + } + if (data2.bgActivePosistion && !r.hoverData.selecting) { + var zoom = r.cy.zoom(); + var pos = data2.bgActivePosistion; + context.fillStyle = "rgba(" + style.core("active-bg-color").value[0] + "," + style.core("active-bg-color").value[1] + "," + style.core("active-bg-color").value[2] + "," + style.core("active-bg-opacity").value + ")"; + context.beginPath(); + context.arc(pos.x, pos.y, style.core("active-bg-size").pfValue / zoom, 0, 2 * Math.PI); + context.fill(); + } + var timeToRender = r.lastRedrawTime; + if (r.showFps && timeToRender) { + timeToRender = Math.round(timeToRender); + var fps = Math.round(1e3 / timeToRender); + context.setTransform(1, 0, 0, 1, 0, 0); + context.fillStyle = "rgba(255, 0, 0, 0.75)"; + context.strokeStyle = "rgba(255, 0, 0, 0.75)"; + context.lineWidth = 1; + context.fillText("1 frame = " + timeToRender + " ms = " + fps + " fps", 0, 20); + var maxFps = 60; + context.strokeRect(0, 30, 250, 20); + context.fillRect(0, 30, 250 * Math.min(fps / maxFps, 1), 20); + } + if (!drawAllLayers) { + needDraw[r.SELECT_BOX] = false; + } + } + if (motionBlur && mbPxRatio !== 1) { + var cxtNode = data2.contexts[r.NODE]; + var txtNode = r.data.bufferCanvases[r.MOTIONBLUR_BUFFER_NODE]; + var cxtDrag = data2.contexts[r.DRAG]; + var txtDrag = r.data.bufferCanvases[r.MOTIONBLUR_BUFFER_DRAG]; + var drawMotionBlur = function drawMotionBlur2(cxt2, txt, needClear) { + cxt2.setTransform(1, 0, 0, 1, 0, 0); + if (needClear || !motionBlurFadeEffect) { + cxt2.clearRect(0, 0, r.canvasWidth, r.canvasHeight); + } else { + mbclear(cxt2, 0, 0, r.canvasWidth, r.canvasHeight); + } + var pxr = mbPxRatio; + cxt2.drawImage( + txt, + // img + 0, + 0, + // sx, sy + r.canvasWidth * pxr, + r.canvasHeight * pxr, + // sw, sh + 0, + 0, + // x, y + r.canvasWidth, + r.canvasHeight + // w, h + ); + }; + if (needDraw[r.NODE] || needMbClear[r.NODE]) { + drawMotionBlur(cxtNode, txtNode, needMbClear[r.NODE]); + needDraw[r.NODE] = false; + } + if (needDraw[r.DRAG] || needMbClear[r.DRAG]) { + drawMotionBlur(cxtDrag, txtDrag, needMbClear[r.DRAG]); + needDraw[r.DRAG] = false; + } + } + r.prevViewport = vp; + if (r.clearingMotionBlur) { + r.clearingMotionBlur = false; + r.motionBlurCleared = true; + r.motionBlur = true; + } + if (motionBlur) { + r.motionBlurTimeout = setTimeout(function() { + r.motionBlurTimeout = null; + r.clearedForMotionBlur[r.NODE] = false; + r.clearedForMotionBlur[r.DRAG] = false; + r.motionBlur = false; + r.clearingMotionBlur = !textureDraw; + r.mbFrames = 0; + needDraw[r.NODE] = true; + needDraw[r.DRAG] = true; + r.redraw(); + }, motionBlurDelay); + } + if (!forcedContext) { + cy.emit("render"); + } + }; + var CRp$3 = {}; + CRp$3.drawPolygonPath = function(context, x2, y2, width2, height, points) { + var halfW = width2 / 2; + var halfH = height / 2; + if (context.beginPath) { + context.beginPath(); + } + context.moveTo(x2 + halfW * points[0], y2 + halfH * points[1]); + for (var i3 = 1; i3 < points.length / 2; i3++) { + context.lineTo(x2 + halfW * points[i3 * 2], y2 + halfH * points[i3 * 2 + 1]); + } + context.closePath(); + }; + CRp$3.drawRoundPolygonPath = function(context, x2, y2, width2, height, points) { + var halfW = width2 / 2; + var halfH = height / 2; + var cornerRadius = getRoundPolygonRadius(width2, height); + if (context.beginPath) { + context.beginPath(); + } + for (var _i6 = 0; _i6 < points.length / 4; _i6++) { + var sourceUv = void 0, destUv = void 0; + if (_i6 === 0) { + sourceUv = points.length - 2; + } else { + sourceUv = _i6 * 4 - 2; + } + destUv = _i6 * 4 + 2; + var px = x2 + halfW * points[_i6 * 4]; + var py = y2 + halfH * points[_i6 * 4 + 1]; + var cosTheta = -points[sourceUv] * points[destUv] - points[sourceUv + 1] * points[destUv + 1]; + var offset = cornerRadius / Math.tan(Math.acos(cosTheta) / 2); + var cp0x = px - offset * points[sourceUv]; + var cp0y = py - offset * points[sourceUv + 1]; + var cp1x = px + offset * points[destUv]; + var cp1y = py + offset * points[destUv + 1]; + if (_i6 === 0) { + context.moveTo(cp0x, cp0y); + } else { + context.lineTo(cp0x, cp0y); + } + context.arcTo(px, py, cp1x, cp1y, cornerRadius); + } + context.closePath(); + }; + CRp$3.drawRoundRectanglePath = function(context, x2, y2, width2, height) { + var halfWidth = width2 / 2; + var halfHeight = height / 2; + var cornerRadius = getRoundRectangleRadius(width2, height); + if (context.beginPath) { + context.beginPath(); + } + context.moveTo(x2, y2 - halfHeight); + context.arcTo(x2 + halfWidth, y2 - halfHeight, x2 + halfWidth, y2, cornerRadius); + context.arcTo(x2 + halfWidth, y2 + halfHeight, x2, y2 + halfHeight, cornerRadius); + context.arcTo(x2 - halfWidth, y2 + halfHeight, x2 - halfWidth, y2, cornerRadius); + context.arcTo(x2 - halfWidth, y2 - halfHeight, x2, y2 - halfHeight, cornerRadius); + context.lineTo(x2, y2 - halfHeight); + context.closePath(); + }; + CRp$3.drawBottomRoundRectanglePath = function(context, x2, y2, width2, height) { + var halfWidth = width2 / 2; + var halfHeight = height / 2; + var cornerRadius = getRoundRectangleRadius(width2, height); + if (context.beginPath) { + context.beginPath(); + } + context.moveTo(x2, y2 - halfHeight); + context.lineTo(x2 + halfWidth, y2 - halfHeight); + context.lineTo(x2 + halfWidth, y2); + context.arcTo(x2 + halfWidth, y2 + halfHeight, x2, y2 + halfHeight, cornerRadius); + context.arcTo(x2 - halfWidth, y2 + halfHeight, x2 - halfWidth, y2, cornerRadius); + context.lineTo(x2 - halfWidth, y2 - halfHeight); + context.lineTo(x2, y2 - halfHeight); + context.closePath(); + }; + CRp$3.drawCutRectanglePath = function(context, x2, y2, width2, height) { + var halfWidth = width2 / 2; + var halfHeight = height / 2; + var cornerLength = getCutRectangleCornerLength(); + if (context.beginPath) { + context.beginPath(); + } + context.moveTo(x2 - halfWidth + cornerLength, y2 - halfHeight); + context.lineTo(x2 + halfWidth - cornerLength, y2 - halfHeight); + context.lineTo(x2 + halfWidth, y2 - halfHeight + cornerLength); + context.lineTo(x2 + halfWidth, y2 + halfHeight - cornerLength); + context.lineTo(x2 + halfWidth - cornerLength, y2 + halfHeight); + context.lineTo(x2 - halfWidth + cornerLength, y2 + halfHeight); + context.lineTo(x2 - halfWidth, y2 + halfHeight - cornerLength); + context.lineTo(x2 - halfWidth, y2 - halfHeight + cornerLength); + context.closePath(); + }; + CRp$3.drawBarrelPath = function(context, x2, y2, width2, height) { + var halfWidth = width2 / 2; + var halfHeight = height / 2; + var xBegin = x2 - halfWidth; + var xEnd = x2 + halfWidth; + var yBegin = y2 - halfHeight; + var yEnd = y2 + halfHeight; + var barrelCurveConstants = getBarrelCurveConstants(width2, height); + var wOffset = barrelCurveConstants.widthOffset; + var hOffset = barrelCurveConstants.heightOffset; + var ctrlPtXOffset = barrelCurveConstants.ctrlPtOffsetPct * wOffset; + if (context.beginPath) { + context.beginPath(); + } + context.moveTo(xBegin, yBegin + hOffset); + context.lineTo(xBegin, yEnd - hOffset); + context.quadraticCurveTo(xBegin + ctrlPtXOffset, yEnd, xBegin + wOffset, yEnd); + context.lineTo(xEnd - wOffset, yEnd); + context.quadraticCurveTo(xEnd - ctrlPtXOffset, yEnd, xEnd, yEnd - hOffset); + context.lineTo(xEnd, yBegin + hOffset); + context.quadraticCurveTo(xEnd - ctrlPtXOffset, yBegin, xEnd - wOffset, yBegin); + context.lineTo(xBegin + wOffset, yBegin); + context.quadraticCurveTo(xBegin + ctrlPtXOffset, yBegin, xBegin, yBegin + hOffset); + context.closePath(); + }; + var sin0 = Math.sin(0); + var cos0 = Math.cos(0); + var sin2 = {}; + var cos2 = {}; + var ellipseStepSize = Math.PI / 40; + for (var i2 = 0 * Math.PI; i2 < 2 * Math.PI; i2 += ellipseStepSize) { + sin2[i2] = Math.sin(i2); + cos2[i2] = Math.cos(i2); + } + CRp$3.drawEllipsePath = function(context, centerX, centerY, width2, height) { + if (context.beginPath) { + context.beginPath(); + } + if (context.ellipse) { + context.ellipse(centerX, centerY, width2 / 2, height / 2, 0, 0, 2 * Math.PI); + } else { + var xPos, yPos; + var rw = width2 / 2; + var rh = height / 2; + for (var i3 = 0 * Math.PI; i3 < 2 * Math.PI; i3 += ellipseStepSize) { + xPos = centerX - rw * sin2[i3] * sin0 + rw * cos2[i3] * cos0; + yPos = centerY + rh * cos2[i3] * sin0 + rh * sin2[i3] * cos0; + if (i3 === 0) { + context.moveTo(xPos, yPos); + } else { + context.lineTo(xPos, yPos); + } + } + } + context.closePath(); + }; + var CRp$2 = {}; + CRp$2.createBuffer = function(w2, h) { + var buffer = document.createElement("canvas"); + buffer.width = w2; + buffer.height = h; + return [buffer, buffer.getContext("2d")]; + }; + CRp$2.bufferCanvasImage = function(options2) { + var cy = this.cy; + var eles = cy.mutableElements(); + var bb = eles.boundingBox(); + var ctrRect = this.findContainerClientCoords(); + var width2 = options2.full ? Math.ceil(bb.w) : ctrRect[2]; + var height = options2.full ? Math.ceil(bb.h) : ctrRect[3]; + var specdMaxDims = number$12(options2.maxWidth) || number$12(options2.maxHeight); + var pxRatio = this.getPixelRatio(); + var scale = 1; + if (options2.scale !== void 0) { + width2 *= options2.scale; + height *= options2.scale; + scale = options2.scale; + } else if (specdMaxDims) { + var maxScaleW = Infinity; + var maxScaleH = Infinity; + if (number$12(options2.maxWidth)) { + maxScaleW = scale * options2.maxWidth / width2; + } + if (number$12(options2.maxHeight)) { + maxScaleH = scale * options2.maxHeight / height; + } + scale = Math.min(maxScaleW, maxScaleH); + width2 *= scale; + height *= scale; + } + if (!specdMaxDims) { + width2 *= pxRatio; + height *= pxRatio; + scale *= pxRatio; + } + var buffCanvas = document.createElement("canvas"); + buffCanvas.width = width2; + buffCanvas.height = height; + buffCanvas.style.width = width2 + "px"; + buffCanvas.style.height = height + "px"; + var buffCxt = buffCanvas.getContext("2d"); + if (width2 > 0 && height > 0) { + buffCxt.clearRect(0, 0, width2, height); + buffCxt.globalCompositeOperation = "source-over"; + var zsortedEles = this.getCachedZSortedEles(); + if (options2.full) { + buffCxt.translate(-bb.x1 * scale, -bb.y1 * scale); + buffCxt.scale(scale, scale); + this.drawElements(buffCxt, zsortedEles); + buffCxt.scale(1 / scale, 1 / scale); + buffCxt.translate(bb.x1 * scale, bb.y1 * scale); + } else { + var pan = cy.pan(); + var translation = { + x: pan.x * scale, + y: pan.y * scale + }; + scale *= cy.zoom(); + buffCxt.translate(translation.x, translation.y); + buffCxt.scale(scale, scale); + this.drawElements(buffCxt, zsortedEles); + buffCxt.scale(1 / scale, 1 / scale); + buffCxt.translate(-translation.x, -translation.y); + } + if (options2.bg) { + buffCxt.globalCompositeOperation = "destination-over"; + buffCxt.fillStyle = options2.bg; + buffCxt.rect(0, 0, width2, height); + buffCxt.fill(); + } + } + return buffCanvas; + }; + function b64ToBlob(b64, mimeType) { + var bytes = atob(b64); + var buff = new ArrayBuffer(bytes.length); + var buffUint8 = new Uint8Array(buff); + for (var i3 = 0; i3 < bytes.length; i3++) { + buffUint8[i3] = bytes.charCodeAt(i3); + } + return new Blob([buff], { + type: mimeType + }); + } + function b64UriToB64(b64uri) { + var i3 = b64uri.indexOf(","); + return b64uri.substr(i3 + 1); + } + function output(options2, canvas, mimeType) { + var getB64Uri = function getB64Uri2() { + return canvas.toDataURL(mimeType, options2.quality); + }; + switch (options2.output) { + case "blob-promise": + return new Promise$12(function(resolve2, reject) { + try { + canvas.toBlob(function(blob) { + if (blob != null) { + resolve2(blob); + } else { + reject(new Error("`canvas.toBlob()` sent a null value in its callback")); + } + }, mimeType, options2.quality); + } catch (err) { + reject(err); + } + }); + case "blob": + return b64ToBlob(b64UriToB64(getB64Uri()), mimeType); + case "base64": + return b64UriToB64(getB64Uri()); + case "base64uri": + default: + return getB64Uri(); + } + } + CRp$2.png = function(options2) { + return output(options2, this.bufferCanvasImage(options2), "image/png"); + }; + CRp$2.jpg = function(options2) { + return output(options2, this.bufferCanvasImage(options2), "image/jpeg"); + }; + var CRp$1 = {}; + CRp$1.nodeShapeImpl = function(name, context, centerX, centerY, width2, height, points) { + switch (name) { + case "ellipse": + return this.drawEllipsePath(context, centerX, centerY, width2, height); + case "polygon": + return this.drawPolygonPath(context, centerX, centerY, width2, height, points); + case "round-polygon": + return this.drawRoundPolygonPath(context, centerX, centerY, width2, height, points); + case "roundrectangle": + case "round-rectangle": + return this.drawRoundRectanglePath(context, centerX, centerY, width2, height); + case "cutrectangle": + case "cut-rectangle": + return this.drawCutRectanglePath(context, centerX, centerY, width2, height); + case "bottomroundrectangle": + case "bottom-round-rectangle": + return this.drawBottomRoundRectanglePath(context, centerX, centerY, width2, height); + case "barrel": + return this.drawBarrelPath(context, centerX, centerY, width2, height); + } + }; + var CR = CanvasRenderer; + var CRp = CanvasRenderer.prototype; + CRp.CANVAS_LAYERS = 3; + CRp.SELECT_BOX = 0; + CRp.DRAG = 1; + CRp.NODE = 2; + CRp.BUFFER_COUNT = 3; + CRp.TEXTURE_BUFFER = 0; + CRp.MOTIONBLUR_BUFFER_NODE = 1; + CRp.MOTIONBLUR_BUFFER_DRAG = 2; + function CanvasRenderer(options2) { + var r = this; + r.data = { + canvases: new Array(CRp.CANVAS_LAYERS), + contexts: new Array(CRp.CANVAS_LAYERS), + canvasNeedsRedraw: new Array(CRp.CANVAS_LAYERS), + bufferCanvases: new Array(CRp.BUFFER_COUNT), + bufferContexts: new Array(CRp.CANVAS_LAYERS) + }; + var tapHlOffAttr = "-webkit-tap-highlight-color"; + var tapHlOffStyle = "rgba(0,0,0,0)"; + r.data.canvasContainer = document.createElement("div"); + var containerStyle = r.data.canvasContainer.style; + r.data.canvasContainer.style[tapHlOffAttr] = tapHlOffStyle; + containerStyle.position = "relative"; + containerStyle.zIndex = "0"; + containerStyle.overflow = "hidden"; + var container = options2.cy.container(); + container.appendChild(r.data.canvasContainer); + container.style[tapHlOffAttr] = tapHlOffStyle; + var styleMap2 = { + "-webkit-user-select": "none", + "-moz-user-select": "-moz-none", + "user-select": "none", + "-webkit-tap-highlight-color": "rgba(0,0,0,0)", + "outline-style": "none" + }; + if (ms()) { + styleMap2["-ms-touch-action"] = "none"; + styleMap2["touch-action"] = "none"; + } + for (var i3 = 0; i3 < CRp.CANVAS_LAYERS; i3++) { + var canvas = r.data.canvases[i3] = document.createElement("canvas"); + r.data.contexts[i3] = canvas.getContext("2d"); + Object.keys(styleMap2).forEach(function(k) { + canvas.style[k] = styleMap2[k]; + }); + canvas.style.position = "absolute"; + canvas.setAttribute("data-id", "layer" + i3); + canvas.style.zIndex = String(CRp.CANVAS_LAYERS - i3); + r.data.canvasContainer.appendChild(canvas); + r.data.canvasNeedsRedraw[i3] = false; + } + r.data.topCanvas = r.data.canvases[0]; + r.data.canvases[CRp.NODE].setAttribute("data-id", "layer" + CRp.NODE + "-node"); + r.data.canvases[CRp.SELECT_BOX].setAttribute("data-id", "layer" + CRp.SELECT_BOX + "-selectbox"); + r.data.canvases[CRp.DRAG].setAttribute("data-id", "layer" + CRp.DRAG + "-drag"); + for (var i3 = 0; i3 < CRp.BUFFER_COUNT; i3++) { + r.data.bufferCanvases[i3] = document.createElement("canvas"); + r.data.bufferContexts[i3] = r.data.bufferCanvases[i3].getContext("2d"); + r.data.bufferCanvases[i3].style.position = "absolute"; + r.data.bufferCanvases[i3].setAttribute("data-id", "buffer" + i3); + r.data.bufferCanvases[i3].style.zIndex = String(-i3 - 1); + r.data.bufferCanvases[i3].style.visibility = "hidden"; + } + r.pathsEnabled = true; + var emptyBb = makeBoundingBox(); + var getBoxCenter = function getBoxCenter2(bb) { + return { + x: (bb.x1 + bb.x2) / 2, + y: (bb.y1 + bb.y2) / 2 + }; + }; + var getCenterOffset = function getCenterOffset2(bb) { + return { + x: -bb.w / 2, + y: -bb.h / 2 + }; + }; + var backgroundTimestampHasChanged = function backgroundTimestampHasChanged2(ele) { + var _p = ele[0]._private; + var same = _p.oldBackgroundTimestamp === _p.backgroundTimestamp; + return !same; + }; + var getStyleKey = function getStyleKey2(ele) { + return ele[0]._private.nodeKey; + }; + var getLabelKey = function getLabelKey2(ele) { + return ele[0]._private.labelStyleKey; + }; + var getSourceLabelKey = function getSourceLabelKey2(ele) { + return ele[0]._private.sourceLabelStyleKey; + }; + var getTargetLabelKey = function getTargetLabelKey2(ele) { + return ele[0]._private.targetLabelStyleKey; + }; + var drawElement = function drawElement2(context, ele, bb, scaledLabelShown, useEleOpacity) { + return r.drawElement(context, ele, bb, false, false, useEleOpacity); + }; + var drawLabel2 = function drawLabel3(context, ele, bb, scaledLabelShown, useEleOpacity) { + return r.drawElementText(context, ele, bb, scaledLabelShown, "main", useEleOpacity); + }; + var drawSourceLabel = function drawSourceLabel2(context, ele, bb, scaledLabelShown, useEleOpacity) { + return r.drawElementText(context, ele, bb, scaledLabelShown, "source", useEleOpacity); + }; + var drawTargetLabel = function drawTargetLabel2(context, ele, bb, scaledLabelShown, useEleOpacity) { + return r.drawElementText(context, ele, bb, scaledLabelShown, "target", useEleOpacity); + }; + var getElementBox = function getElementBox2(ele) { + ele.boundingBox(); + return ele[0]._private.bodyBounds; + }; + var getLabelBox = function getLabelBox2(ele) { + ele.boundingBox(); + return ele[0]._private.labelBounds.main || emptyBb; + }; + var getSourceLabelBox = function getSourceLabelBox2(ele) { + ele.boundingBox(); + return ele[0]._private.labelBounds.source || emptyBb; + }; + var getTargetLabelBox = function getTargetLabelBox2(ele) { + ele.boundingBox(); + return ele[0]._private.labelBounds.target || emptyBb; + }; + var isLabelVisibleAtScale = function isLabelVisibleAtScale2(ele, scaledLabelShown) { + return scaledLabelShown; + }; + var getElementRotationPoint = function getElementRotationPoint2(ele) { + return getBoxCenter(getElementBox(ele)); + }; + var addTextMargin = function addTextMargin2(prefix, pt, ele) { + var pre = prefix ? prefix + "-" : ""; + return { + x: pt.x + ele.pstyle(pre + "text-margin-x").pfValue, + y: pt.y + ele.pstyle(pre + "text-margin-y").pfValue + }; + }; + var getRsPt = function getRsPt2(ele, x2, y2) { + var rs = ele[0]._private.rscratch; + return { + x: rs[x2], + y: rs[y2] + }; + }; + var getLabelRotationPoint = function getLabelRotationPoint2(ele) { + return addTextMargin("", getRsPt(ele, "labelX", "labelY"), ele); + }; + var getSourceLabelRotationPoint = function getSourceLabelRotationPoint2(ele) { + return addTextMargin("source", getRsPt(ele, "sourceLabelX", "sourceLabelY"), ele); + }; + var getTargetLabelRotationPoint = function getTargetLabelRotationPoint2(ele) { + return addTextMargin("target", getRsPt(ele, "targetLabelX", "targetLabelY"), ele); + }; + var getElementRotationOffset = function getElementRotationOffset2(ele) { + return getCenterOffset(getElementBox(ele)); + }; + var getSourceLabelRotationOffset = function getSourceLabelRotationOffset2(ele) { + return getCenterOffset(getSourceLabelBox(ele)); + }; + var getTargetLabelRotationOffset = function getTargetLabelRotationOffset2(ele) { + return getCenterOffset(getTargetLabelBox(ele)); + }; + var getLabelRotationOffset = function getLabelRotationOffset2(ele) { + var bb = getLabelBox(ele); + var p2 = getCenterOffset(getLabelBox(ele)); + if (ele.isNode()) { + switch (ele.pstyle("text-halign").value) { + case "left": + p2.x = -bb.w; + break; + case "right": + p2.x = 0; + break; + } + switch (ele.pstyle("text-valign").value) { + case "top": + p2.y = -bb.h; + break; + case "bottom": + p2.y = 0; + break; + } + } + return p2; + }; + var eleTxrCache = r.data.eleTxrCache = new ElementTextureCache(r, { + getKey: getStyleKey, + doesEleInvalidateKey: backgroundTimestampHasChanged, + drawElement, + getBoundingBox: getElementBox, + getRotationPoint: getElementRotationPoint, + getRotationOffset: getElementRotationOffset, + allowEdgeTxrCaching: false, + allowParentTxrCaching: false + }); + var lblTxrCache = r.data.lblTxrCache = new ElementTextureCache(r, { + getKey: getLabelKey, + drawElement: drawLabel2, + getBoundingBox: getLabelBox, + getRotationPoint: getLabelRotationPoint, + getRotationOffset: getLabelRotationOffset, + isVisible: isLabelVisibleAtScale + }); + var slbTxrCache = r.data.slbTxrCache = new ElementTextureCache(r, { + getKey: getSourceLabelKey, + drawElement: drawSourceLabel, + getBoundingBox: getSourceLabelBox, + getRotationPoint: getSourceLabelRotationPoint, + getRotationOffset: getSourceLabelRotationOffset, + isVisible: isLabelVisibleAtScale + }); + var tlbTxrCache = r.data.tlbTxrCache = new ElementTextureCache(r, { + getKey: getTargetLabelKey, + drawElement: drawTargetLabel, + getBoundingBox: getTargetLabelBox, + getRotationPoint: getTargetLabelRotationPoint, + getRotationOffset: getTargetLabelRotationOffset, + isVisible: isLabelVisibleAtScale + }); + var lyrTxrCache = r.data.lyrTxrCache = new LayeredTextureCache(r); + r.onUpdateEleCalcs(function invalidateTextureCaches(willDraw, eles) { + eleTxrCache.invalidateElements(eles); + lblTxrCache.invalidateElements(eles); + slbTxrCache.invalidateElements(eles); + tlbTxrCache.invalidateElements(eles); + lyrTxrCache.invalidateElements(eles); + for (var _i6 = 0; _i6 < eles.length; _i6++) { + var _p = eles[_i6]._private; + _p.oldBackgroundTimestamp = _p.backgroundTimestamp; + } + }); + var refineInLayers = function refineInLayers2(reqs) { + for (var i4 = 0; i4 < reqs.length; i4++) { + lyrTxrCache.enqueueElementRefinement(reqs[i4].ele); + } + }; + eleTxrCache.onDequeue(refineInLayers); + lblTxrCache.onDequeue(refineInLayers); + slbTxrCache.onDequeue(refineInLayers); + tlbTxrCache.onDequeue(refineInLayers); + } + CRp.redrawHint = function(group, bool2) { + var r = this; + switch (group) { + case "eles": + r.data.canvasNeedsRedraw[CRp.NODE] = bool2; + break; + case "drag": + r.data.canvasNeedsRedraw[CRp.DRAG] = bool2; + break; + case "select": + r.data.canvasNeedsRedraw[CRp.SELECT_BOX] = bool2; + break; + } + }; + var pathsImpld = typeof Path2D !== "undefined"; + CRp.path2dEnabled = function(on) { + if (on === void 0) { + return this.pathsEnabled; + } + this.pathsEnabled = on ? true : false; + }; + CRp.usePaths = function() { + return pathsImpld && this.pathsEnabled; + }; + CRp.setImgSmoothing = function(context, bool2) { + if (context.imageSmoothingEnabled != null) { + context.imageSmoothingEnabled = bool2; + } else { + context.webkitImageSmoothingEnabled = bool2; + context.mozImageSmoothingEnabled = bool2; + context.msImageSmoothingEnabled = bool2; + } + }; + CRp.getImgSmoothing = function(context) { + if (context.imageSmoothingEnabled != null) { + return context.imageSmoothingEnabled; + } else { + return context.webkitImageSmoothingEnabled || context.mozImageSmoothingEnabled || context.msImageSmoothingEnabled; + } + }; + CRp.makeOffscreenCanvas = function(width2, height) { + var canvas; + if ((typeof OffscreenCanvas === "undefined" ? "undefined" : _typeof(OffscreenCanvas)) !== "undefined") { + canvas = new OffscreenCanvas(width2, height); + } else { + canvas = document.createElement("canvas"); + canvas.width = width2; + canvas.height = height; + } + return canvas; + }; + [CRp$a, CRp$9, CRp$8, CRp$7, CRp$6, CRp$5, CRp$4, CRp$3, CRp$2, CRp$1].forEach(function(props) { + extend2(CRp, props); + }); + var renderer2 = [{ + name: "null", + impl: NullRenderer + }, { + name: "base", + impl: BR + }, { + name: "canvas", + impl: CR + }]; + var incExts = [{ + type: "layout", + extensions: layout2 + }, { + type: "renderer", + extensions: renderer2 + }]; + var extensions = {}; + var modules = {}; + function setExtension(type2, name, registrant) { + var ext = registrant; + var overrideErr = function overrideErr2(field) { + warn("Can not register `" + name + "` for `" + type2 + "` since `" + field + "` already exists in the prototype and can not be overridden"); + }; + if (type2 === "core") { + if (Core.prototype[name]) { + return overrideErr(name); + } else { + Core.prototype[name] = registrant; + } + } else if (type2 === "collection") { + if (Collection.prototype[name]) { + return overrideErr(name); + } else { + Collection.prototype[name] = registrant; + } + } else if (type2 === "layout") { + var Layout2 = function Layout3(options2) { + this.options = options2; + registrant.call(this, options2); + if (!plainObject(this._private)) { + this._private = {}; + } + this._private.cy = options2.cy; + this._private.listeners = []; + this.createEmitter(); + }; + var layoutProto = Layout2.prototype = Object.create(registrant.prototype); + var optLayoutFns = []; + for (var i3 = 0; i3 < optLayoutFns.length; i3++) { + var fnName = optLayoutFns[i3]; + layoutProto[fnName] = layoutProto[fnName] || function() { + return this; + }; + } + if (layoutProto.start && !layoutProto.run) { + layoutProto.run = function() { + this.start(); + return this; + }; + } else if (!layoutProto.start && layoutProto.run) { + layoutProto.start = function() { + this.run(); + return this; + }; + } + var regStop = registrant.prototype.stop; + layoutProto.stop = function() { + var opts = this.options; + if (opts && opts.animate) { + var anis = this.animations; + if (anis) { + for (var _i6 = 0; _i6 < anis.length; _i6++) { + anis[_i6].stop(); + } + } + } + if (regStop) { + regStop.call(this); + } else { + this.emit("layoutstop"); + } + return this; + }; + if (!layoutProto.destroy) { + layoutProto.destroy = function() { + return this; + }; + } + layoutProto.cy = function() { + return this._private.cy; + }; + var getCy = function getCy2(layout3) { + return layout3._private.cy; + }; + var emitterOpts = { + addEventFields: function addEventFields(layout3, evt) { + evt.layout = layout3; + evt.cy = getCy(layout3); + evt.target = layout3; + }, + bubble: function bubble() { + return true; + }, + parent: function parent(layout3) { + return getCy(layout3); + } + }; + extend2(layoutProto, { + createEmitter: function createEmitter() { + this._private.emitter = new Emitter(emitterOpts, this); + return this; + }, + emitter: function emitter() { + return this._private.emitter; + }, + on: function on(evt, cb) { + this.emitter().on(evt, cb); + return this; + }, + one: function one2(evt, cb) { + this.emitter().one(evt, cb); + return this; + }, + once: function once(evt, cb) { + this.emitter().one(evt, cb); + return this; + }, + removeListener: function removeListener(evt, cb) { + this.emitter().removeListener(evt, cb); + return this; + }, + removeAllListeners: function removeAllListeners() { + this.emitter().removeAllListeners(); + return this; + }, + emit: function emit(evt, params) { + this.emitter().emit(evt, params); + return this; + } + }); + define3.eventAliasesOn(layoutProto); + ext = Layout2; + } else if (type2 === "renderer" && name !== "null" && name !== "base") { + var BaseRenderer2 = getExtension("renderer", "base"); + var bProto = BaseRenderer2.prototype; + var RegistrantRenderer = registrant; + var rProto = registrant.prototype; + var Renderer = function Renderer2() { + BaseRenderer2.apply(this, arguments); + RegistrantRenderer.apply(this, arguments); + }; + var proto = Renderer.prototype; + for (var pName in bProto) { + var pVal = bProto[pName]; + var existsInR = rProto[pName] != null; + if (existsInR) { + return overrideErr(pName); + } + proto[pName] = pVal; + } + for (var _pName in rProto) { + proto[_pName] = rProto[_pName]; + } + bProto.clientFunctions.forEach(function(name2) { + proto[name2] = proto[name2] || function() { + error("Renderer does not implement `renderer." + name2 + "()` on its prototype"); + }; + }); + ext = Renderer; + } else if (type2 === "__proto__" || type2 === "constructor" || type2 === "prototype") { + return error(type2 + " is an illegal type to be registered, possibly lead to prototype pollutions"); + } + return setMap({ + map: extensions, + keys: [type2, name], + value: ext + }); + } + function getExtension(type2, name) { + return getMap({ + map: extensions, + keys: [type2, name] + }); + } + function setModule(type2, name, moduleType, moduleName, registrant) { + return setMap({ + map: modules, + keys: [type2, name, moduleType, moduleName], + value: registrant + }); + } + function getModule(type2, name, moduleType, moduleName) { + return getMap({ + map: modules, + keys: [type2, name, moduleType, moduleName] + }); + } + var extension2 = function extension3() { + if (arguments.length === 2) { + return getExtension.apply(null, arguments); + } else if (arguments.length === 3) { + return setExtension.apply(null, arguments); + } else if (arguments.length === 4) { + return getModule.apply(null, arguments); + } else if (arguments.length === 5) { + return setModule.apply(null, arguments); + } else { + error("Invalid extension access syntax"); + } + }; + Core.prototype.extension = extension2; + incExts.forEach(function(group) { + group.extensions.forEach(function(ext) { + setExtension(group.type, ext.name, ext.impl); + }); + }); + var Stylesheet = function Stylesheet2() { + if (!(this instanceof Stylesheet2)) { + return new Stylesheet2(); + } + this.length = 0; + }; + var sheetfn = Stylesheet.prototype; + sheetfn.instanceString = function() { + return "stylesheet"; + }; + sheetfn.selector = function(selector2) { + var i3 = this.length++; + this[i3] = { + selector: selector2, + properties: [] + }; + return this; + }; + sheetfn.css = function(name, value2) { + var i3 = this.length - 1; + if (string2(name)) { + this[i3].properties.push({ + name, + value: value2 + }); + } else if (plainObject(name)) { + var map2 = name; + var propNames = Object.keys(map2); + for (var j = 0; j < propNames.length; j++) { + var key = propNames[j]; + var mapVal = map2[key]; + if (mapVal == null) { + continue; + } + var prop = Style2.properties[key] || Style2.properties[dash2camel(key)]; + if (prop == null) { + continue; + } + var _name = prop.name; + var _value = mapVal; + this[i3].properties.push({ + name: _name, + value: _value + }); + } + } + return this; + }; + sheetfn.style = sheetfn.css; + sheetfn.generateStyle = function(cy) { + var style = new Style2(cy); + return this.appendToStyle(style); + }; + sheetfn.appendToStyle = function(style) { + for (var i3 = 0; i3 < this.length; i3++) { + var context = this[i3]; + var selector2 = context.selector; + var props = context.properties; + style.selector(selector2); + for (var j = 0; j < props.length; j++) { + var prop = props[j]; + style.css(prop.name, prop.value); + } + } + return style; + }; + var version2 = "3.28.1"; + var cytoscape2 = function cytoscape3(options2) { + if (options2 === void 0) { + options2 = {}; + } + if (plainObject(options2)) { + return new Core(options2); + } else if (string2(options2)) { + return extension2.apply(extension2, arguments); + } + }; + cytoscape2.use = function(ext) { + var args = Array.prototype.slice.call(arguments, 1); + args.unshift(cytoscape2); + ext.apply(null, args); + return this; + }; + cytoscape2.warnings = function(bool2) { + return warnings(bool2); + }; + cytoscape2.version = version2; + cytoscape2.stylesheet = cytoscape2.Stylesheet = Stylesheet; + return cytoscape2; + }); + })(cytoscape_umd); + var cytoscape_umdExports = cytoscape_umd.exports; + const cytoscape$1 = /* @__PURE__ */ getDefaultExportFromCjs(cytoscape_umdExports); + var cytoscapeCoseBilkent = { exports: {} }; + var coseBase = { exports: {} }; + var layoutBase = { exports: {} }; + var hasRequiredLayoutBase; + function requireLayoutBase() { + if (hasRequiredLayoutBase) + return layoutBase.exports; + hasRequiredLayoutBase = 1; + (function(module2, exports2) { + (function webpackUniversalModuleDefinition(root2, factory) { + module2.exports = factory(); + })(commonjsGlobal, function() { + return ( + /******/ + function(modules) { + var installedModules = {}; + function __webpack_require__(moduleId) { + if (installedModules[moduleId]) { + return installedModules[moduleId].exports; + } + var module3 = installedModules[moduleId] = { + /******/ + i: moduleId, + /******/ + l: false, + /******/ + exports: {} + /******/ + }; + modules[moduleId].call(module3.exports, module3, module3.exports, __webpack_require__); + module3.l = true; + return module3.exports; + } + __webpack_require__.m = modules; + __webpack_require__.c = installedModules; + __webpack_require__.i = function(value2) { + return value2; + }; + __webpack_require__.d = function(exports3, name, getter) { + if (!__webpack_require__.o(exports3, name)) { + Object.defineProperty(exports3, name, { + /******/ + configurable: false, + /******/ + enumerable: true, + /******/ + get: getter + /******/ + }); + } + }; + __webpack_require__.n = function(module3) { + var getter = module3 && module3.__esModule ? ( + /******/ + function getDefault() { + return module3["default"]; + } + ) : ( + /******/ + function getModuleExports() { + return module3; + } + ); + __webpack_require__.d(getter, "a", getter); + return getter; + }; + __webpack_require__.o = function(object2, property2) { + return Object.prototype.hasOwnProperty.call(object2, property2); + }; + __webpack_require__.p = ""; + return __webpack_require__(__webpack_require__.s = 26); + }([ + /* 0 */ + /***/ + function(module3, exports3, __webpack_require__) { + function LayoutConstants() { + } + LayoutConstants.QUALITY = 1; + LayoutConstants.DEFAULT_CREATE_BENDS_AS_NEEDED = false; + LayoutConstants.DEFAULT_INCREMENTAL = false; + LayoutConstants.DEFAULT_ANIMATION_ON_LAYOUT = true; + LayoutConstants.DEFAULT_ANIMATION_DURING_LAYOUT = false; + LayoutConstants.DEFAULT_ANIMATION_PERIOD = 50; + LayoutConstants.DEFAULT_UNIFORM_LEAF_NODE_SIZES = false; + LayoutConstants.DEFAULT_GRAPH_MARGIN = 15; + LayoutConstants.NODE_DIMENSIONS_INCLUDE_LABELS = false; + LayoutConstants.SIMPLE_NODE_SIZE = 40; + LayoutConstants.SIMPLE_NODE_HALF_SIZE = LayoutConstants.SIMPLE_NODE_SIZE / 2; + LayoutConstants.EMPTY_COMPOUND_NODE_SIZE = 40; + LayoutConstants.MIN_EDGE_LENGTH = 1; + LayoutConstants.WORLD_BOUNDARY = 1e6; + LayoutConstants.INITIAL_WORLD_BOUNDARY = LayoutConstants.WORLD_BOUNDARY / 1e3; + LayoutConstants.WORLD_CENTER_X = 1200; + LayoutConstants.WORLD_CENTER_Y = 900; + module3.exports = LayoutConstants; + }, + /* 1 */ + /***/ + function(module3, exports3, __webpack_require__) { + var LGraphObject = __webpack_require__(2); + var IGeometry = __webpack_require__(8); + var IMath = __webpack_require__(9); + function LEdge(source, target, vEdge) { + LGraphObject.call(this, vEdge); + this.isOverlapingSourceAndTarget = false; + this.vGraphObject = vEdge; + this.bendpoints = []; + this.source = source; + this.target = target; + } + LEdge.prototype = Object.create(LGraphObject.prototype); + for (var prop in LGraphObject) { + LEdge[prop] = LGraphObject[prop]; + } + LEdge.prototype.getSource = function() { + return this.source; + }; + LEdge.prototype.getTarget = function() { + return this.target; + }; + LEdge.prototype.isInterGraph = function() { + return this.isInterGraph; + }; + LEdge.prototype.getLength = function() { + return this.length; + }; + LEdge.prototype.isOverlapingSourceAndTarget = function() { + return this.isOverlapingSourceAndTarget; + }; + LEdge.prototype.getBendpoints = function() { + return this.bendpoints; + }; + LEdge.prototype.getLca = function() { + return this.lca; + }; + LEdge.prototype.getSourceInLca = function() { + return this.sourceInLca; + }; + LEdge.prototype.getTargetInLca = function() { + return this.targetInLca; + }; + LEdge.prototype.getOtherEnd = function(node2) { + if (this.source === node2) { + return this.target; + } else if (this.target === node2) { + return this.source; + } else { + throw "Node is not incident with this edge"; + } + }; + LEdge.prototype.getOtherEndInGraph = function(node2, graph) { + var otherEnd = this.getOtherEnd(node2); + var root2 = graph.getGraphManager().getRoot(); + while (true) { + if (otherEnd.getOwner() == graph) { + return otherEnd; + } + if (otherEnd.getOwner() == root2) { + break; + } + otherEnd = otherEnd.getOwner().getParent(); + } + return null; + }; + LEdge.prototype.updateLength = function() { + var clipPointCoordinates = new Array(4); + this.isOverlapingSourceAndTarget = IGeometry.getIntersection(this.target.getRect(), this.source.getRect(), clipPointCoordinates); + if (!this.isOverlapingSourceAndTarget) { + this.lengthX = clipPointCoordinates[0] - clipPointCoordinates[2]; + this.lengthY = clipPointCoordinates[1] - clipPointCoordinates[3]; + if (Math.abs(this.lengthX) < 1) { + this.lengthX = IMath.sign(this.lengthX); + } + if (Math.abs(this.lengthY) < 1) { + this.lengthY = IMath.sign(this.lengthY); + } + this.length = Math.sqrt(this.lengthX * this.lengthX + this.lengthY * this.lengthY); + } + }; + LEdge.prototype.updateLengthSimple = function() { + this.lengthX = this.target.getCenterX() - this.source.getCenterX(); + this.lengthY = this.target.getCenterY() - this.source.getCenterY(); + if (Math.abs(this.lengthX) < 1) { + this.lengthX = IMath.sign(this.lengthX); + } + if (Math.abs(this.lengthY) < 1) { + this.lengthY = IMath.sign(this.lengthY); + } + this.length = Math.sqrt(this.lengthX * this.lengthX + this.lengthY * this.lengthY); + }; + module3.exports = LEdge; + }, + /* 2 */ + /***/ + function(module3, exports3, __webpack_require__) { + function LGraphObject(vGraphObject) { + this.vGraphObject = vGraphObject; + } + module3.exports = LGraphObject; + }, + /* 3 */ + /***/ + function(module3, exports3, __webpack_require__) { + var LGraphObject = __webpack_require__(2); + var Integer = __webpack_require__(10); + var RectangleD = __webpack_require__(13); + var LayoutConstants = __webpack_require__(0); + var RandomSeed = __webpack_require__(16); + var PointD = __webpack_require__(4); + function LNode(gm, loc, size2, vNode) { + if (size2 == null && vNode == null) { + vNode = loc; + } + LGraphObject.call(this, vNode); + if (gm.graphManager != null) + gm = gm.graphManager; + this.estimatedSize = Integer.MIN_VALUE; + this.inclusionTreeDepth = Integer.MAX_VALUE; + this.vGraphObject = vNode; + this.edges = []; + this.graphManager = gm; + if (size2 != null && loc != null) + this.rect = new RectangleD(loc.x, loc.y, size2.width, size2.height); + else + this.rect = new RectangleD(); + } + LNode.prototype = Object.create(LGraphObject.prototype); + for (var prop in LGraphObject) { + LNode[prop] = LGraphObject[prop]; + } + LNode.prototype.getEdges = function() { + return this.edges; + }; + LNode.prototype.getChild = function() { + return this.child; + }; + LNode.prototype.getOwner = function() { + return this.owner; + }; + LNode.prototype.getWidth = function() { + return this.rect.width; + }; + LNode.prototype.setWidth = function(width2) { + this.rect.width = width2; + }; + LNode.prototype.getHeight = function() { + return this.rect.height; + }; + LNode.prototype.setHeight = function(height) { + this.rect.height = height; + }; + LNode.prototype.getCenterX = function() { + return this.rect.x + this.rect.width / 2; + }; + LNode.prototype.getCenterY = function() { + return this.rect.y + this.rect.height / 2; + }; + LNode.prototype.getCenter = function() { + return new PointD(this.rect.x + this.rect.width / 2, this.rect.y + this.rect.height / 2); + }; + LNode.prototype.getLocation = function() { + return new PointD(this.rect.x, this.rect.y); + }; + LNode.prototype.getRect = function() { + return this.rect; + }; + LNode.prototype.getDiagonal = function() { + return Math.sqrt(this.rect.width * this.rect.width + this.rect.height * this.rect.height); + }; + LNode.prototype.getHalfTheDiagonal = function() { + return Math.sqrt(this.rect.height * this.rect.height + this.rect.width * this.rect.width) / 2; + }; + LNode.prototype.setRect = function(upperLeft, dimension) { + this.rect.x = upperLeft.x; + this.rect.y = upperLeft.y; + this.rect.width = dimension.width; + this.rect.height = dimension.height; + }; + LNode.prototype.setCenter = function(cx, cy) { + this.rect.x = cx - this.rect.width / 2; + this.rect.y = cy - this.rect.height / 2; + }; + LNode.prototype.setLocation = function(x2, y2) { + this.rect.x = x2; + this.rect.y = y2; + }; + LNode.prototype.moveBy = function(dx, dy) { + this.rect.x += dx; + this.rect.y += dy; + }; + LNode.prototype.getEdgeListToNode = function(to) { + var edgeList2 = []; + var self2 = this; + self2.edges.forEach(function(edge) { + if (edge.target == to) { + if (edge.source != self2) + throw "Incorrect edge source!"; + edgeList2.push(edge); + } + }); + return edgeList2; + }; + LNode.prototype.getEdgesBetween = function(other) { + var edgeList2 = []; + var self2 = this; + self2.edges.forEach(function(edge) { + if (!(edge.source == self2 || edge.target == self2)) + throw "Incorrect edge source and/or target"; + if (edge.target == other || edge.source == other) { + edgeList2.push(edge); + } + }); + return edgeList2; + }; + LNode.prototype.getNeighborsList = function() { + var neighbors = /* @__PURE__ */ new Set(); + var self2 = this; + self2.edges.forEach(function(edge) { + if (edge.source == self2) { + neighbors.add(edge.target); + } else { + if (edge.target != self2) { + throw "Incorrect incidency!"; + } + neighbors.add(edge.source); + } + }); + return neighbors; + }; + LNode.prototype.withChildren = function() { + var withNeighborsList = /* @__PURE__ */ new Set(); + var childNode; + var children2; + withNeighborsList.add(this); + if (this.child != null) { + var nodes2 = this.child.getNodes(); + for (var i2 = 0; i2 < nodes2.length; i2++) { + childNode = nodes2[i2]; + children2 = childNode.withChildren(); + children2.forEach(function(node2) { + withNeighborsList.add(node2); + }); + } + } + return withNeighborsList; + }; + LNode.prototype.getNoOfChildren = function() { + var noOfChildren = 0; + var childNode; + if (this.child == null) { + noOfChildren = 1; + } else { + var nodes2 = this.child.getNodes(); + for (var i2 = 0; i2 < nodes2.length; i2++) { + childNode = nodes2[i2]; + noOfChildren += childNode.getNoOfChildren(); + } + } + if (noOfChildren == 0) { + noOfChildren = 1; + } + return noOfChildren; + }; + LNode.prototype.getEstimatedSize = function() { + if (this.estimatedSize == Integer.MIN_VALUE) { + throw "assert failed"; + } + return this.estimatedSize; + }; + LNode.prototype.calcEstimatedSize = function() { + if (this.child == null) { + return this.estimatedSize = (this.rect.width + this.rect.height) / 2; + } else { + this.estimatedSize = this.child.calcEstimatedSize(); + this.rect.width = this.estimatedSize; + this.rect.height = this.estimatedSize; + return this.estimatedSize; + } + }; + LNode.prototype.scatter = function() { + var randomCenterX; + var randomCenterY; + var minX = -LayoutConstants.INITIAL_WORLD_BOUNDARY; + var maxX = LayoutConstants.INITIAL_WORLD_BOUNDARY; + randomCenterX = LayoutConstants.WORLD_CENTER_X + RandomSeed.nextDouble() * (maxX - minX) + minX; + var minY = -LayoutConstants.INITIAL_WORLD_BOUNDARY; + var maxY = LayoutConstants.INITIAL_WORLD_BOUNDARY; + randomCenterY = LayoutConstants.WORLD_CENTER_Y + RandomSeed.nextDouble() * (maxY - minY) + minY; + this.rect.x = randomCenterX; + this.rect.y = randomCenterY; + }; + LNode.prototype.updateBounds = function() { + if (this.getChild() == null) { + throw "assert failed"; + } + if (this.getChild().getNodes().length != 0) { + var childGraph = this.getChild(); + childGraph.updateBounds(true); + this.rect.x = childGraph.getLeft(); + this.rect.y = childGraph.getTop(); + this.setWidth(childGraph.getRight() - childGraph.getLeft()); + this.setHeight(childGraph.getBottom() - childGraph.getTop()); + if (LayoutConstants.NODE_DIMENSIONS_INCLUDE_LABELS) { + var width2 = childGraph.getRight() - childGraph.getLeft(); + var height = childGraph.getBottom() - childGraph.getTop(); + if (this.labelWidth > width2) { + this.rect.x -= (this.labelWidth - width2) / 2; + this.setWidth(this.labelWidth); + } + if (this.labelHeight > height) { + if (this.labelPos == "center") { + this.rect.y -= (this.labelHeight - height) / 2; + } else if (this.labelPos == "top") { + this.rect.y -= this.labelHeight - height; + } + this.setHeight(this.labelHeight); + } + } + } + }; + LNode.prototype.getInclusionTreeDepth = function() { + if (this.inclusionTreeDepth == Integer.MAX_VALUE) { + throw "assert failed"; + } + return this.inclusionTreeDepth; + }; + LNode.prototype.transform = function(trans) { + var left2 = this.rect.x; + if (left2 > LayoutConstants.WORLD_BOUNDARY) { + left2 = LayoutConstants.WORLD_BOUNDARY; + } else if (left2 < -LayoutConstants.WORLD_BOUNDARY) { + left2 = -LayoutConstants.WORLD_BOUNDARY; + } + var top2 = this.rect.y; + if (top2 > LayoutConstants.WORLD_BOUNDARY) { + top2 = LayoutConstants.WORLD_BOUNDARY; + } else if (top2 < -LayoutConstants.WORLD_BOUNDARY) { + top2 = -LayoutConstants.WORLD_BOUNDARY; + } + var leftTop = new PointD(left2, top2); + var vLeftTop = trans.inverseTransformPoint(leftTop); + this.setLocation(vLeftTop.x, vLeftTop.y); + }; + LNode.prototype.getLeft = function() { + return this.rect.x; + }; + LNode.prototype.getRight = function() { + return this.rect.x + this.rect.width; + }; + LNode.prototype.getTop = function() { + return this.rect.y; + }; + LNode.prototype.getBottom = function() { + return this.rect.y + this.rect.height; + }; + LNode.prototype.getParent = function() { + if (this.owner == null) { + return null; + } + return this.owner.getParent(); + }; + module3.exports = LNode; + }, + /* 4 */ + /***/ + function(module3, exports3, __webpack_require__) { + function PointD(x2, y2) { + if (x2 == null && y2 == null) { + this.x = 0; + this.y = 0; + } else { + this.x = x2; + this.y = y2; + } + } + PointD.prototype.getX = function() { + return this.x; + }; + PointD.prototype.getY = function() { + return this.y; + }; + PointD.prototype.setX = function(x2) { + this.x = x2; + }; + PointD.prototype.setY = function(y2) { + this.y = y2; + }; + PointD.prototype.getDifference = function(pt) { + return new DimensionD(this.x - pt.x, this.y - pt.y); + }; + PointD.prototype.getCopy = function() { + return new PointD(this.x, this.y); + }; + PointD.prototype.translate = function(dim) { + this.x += dim.width; + this.y += dim.height; + return this; + }; + module3.exports = PointD; + }, + /* 5 */ + /***/ + function(module3, exports3, __webpack_require__) { + var LGraphObject = __webpack_require__(2); + var Integer = __webpack_require__(10); + var LayoutConstants = __webpack_require__(0); + var LGraphManager = __webpack_require__(6); + var LNode = __webpack_require__(3); + var LEdge = __webpack_require__(1); + var RectangleD = __webpack_require__(13); + var Point2 = __webpack_require__(12); + var LinkedList = __webpack_require__(11); + function LGraph(parent, obj2, vGraph) { + LGraphObject.call(this, vGraph); + this.estimatedSize = Integer.MIN_VALUE; + this.margin = LayoutConstants.DEFAULT_GRAPH_MARGIN; + this.edges = []; + this.nodes = []; + this.isConnected = false; + this.parent = parent; + if (obj2 != null && obj2 instanceof LGraphManager) { + this.graphManager = obj2; + } else if (obj2 != null && obj2 instanceof Layout) { + this.graphManager = obj2.graphManager; + } + } + LGraph.prototype = Object.create(LGraphObject.prototype); + for (var prop in LGraphObject) { + LGraph[prop] = LGraphObject[prop]; + } + LGraph.prototype.getNodes = function() { + return this.nodes; + }; + LGraph.prototype.getEdges = function() { + return this.edges; + }; + LGraph.prototype.getGraphManager = function() { + return this.graphManager; + }; + LGraph.prototype.getParent = function() { + return this.parent; + }; + LGraph.prototype.getLeft = function() { + return this.left; + }; + LGraph.prototype.getRight = function() { + return this.right; + }; + LGraph.prototype.getTop = function() { + return this.top; + }; + LGraph.prototype.getBottom = function() { + return this.bottom; + }; + LGraph.prototype.isConnected = function() { + return this.isConnected; + }; + LGraph.prototype.add = function(obj1, sourceNode, targetNode) { + if (sourceNode == null && targetNode == null) { + var newNode = obj1; + if (this.graphManager == null) { + throw "Graph has no graph mgr!"; + } + if (this.getNodes().indexOf(newNode) > -1) { + throw "Node already in graph!"; + } + newNode.owner = this; + this.getNodes().push(newNode); + return newNode; + } else { + var newEdge = obj1; + if (!(this.getNodes().indexOf(sourceNode) > -1 && this.getNodes().indexOf(targetNode) > -1)) { + throw "Source or target not in graph!"; + } + if (!(sourceNode.owner == targetNode.owner && sourceNode.owner == this)) { + throw "Both owners must be this graph!"; + } + if (sourceNode.owner != targetNode.owner) { + return null; + } + newEdge.source = sourceNode; + newEdge.target = targetNode; + newEdge.isInterGraph = false; + this.getEdges().push(newEdge); + sourceNode.edges.push(newEdge); + if (targetNode != sourceNode) { + targetNode.edges.push(newEdge); + } + return newEdge; + } + }; + LGraph.prototype.remove = function(obj) { + var node2 = obj; + if (obj instanceof LNode) { + if (node2 == null) { + throw "Node is null!"; + } + if (!(node2.owner != null && node2.owner == this)) { + throw "Owner graph is invalid!"; + } + if (this.graphManager == null) { + throw "Owner graph manager is invalid!"; + } + var edgesToBeRemoved = node2.edges.slice(); + var edge; + var s = edgesToBeRemoved.length; + for (var i2 = 0; i2 < s; i2++) { + edge = edgesToBeRemoved[i2]; + if (edge.isInterGraph) { + this.graphManager.remove(edge); + } else { + edge.source.owner.remove(edge); + } + } + var index2 = this.nodes.indexOf(node2); + if (index2 == -1) { + throw "Node not in owner node list!"; + } + this.nodes.splice(index2, 1); + } else if (obj instanceof LEdge) { + var edge = obj; + if (edge == null) { + throw "Edge is null!"; + } + if (!(edge.source != null && edge.target != null)) { + throw "Source and/or target is null!"; + } + if (!(edge.source.owner != null && edge.target.owner != null && edge.source.owner == this && edge.target.owner == this)) { + throw "Source and/or target owner is invalid!"; + } + var sourceIndex = edge.source.edges.indexOf(edge); + var targetIndex = edge.target.edges.indexOf(edge); + if (!(sourceIndex > -1 && targetIndex > -1)) { + throw "Source and/or target doesn't know this edge!"; + } + edge.source.edges.splice(sourceIndex, 1); + if (edge.target != edge.source) { + edge.target.edges.splice(targetIndex, 1); + } + var index2 = edge.source.owner.getEdges().indexOf(edge); + if (index2 == -1) { + throw "Not in owner's edge list!"; + } + edge.source.owner.getEdges().splice(index2, 1); + } + }; + LGraph.prototype.updateLeftTop = function() { + var top2 = Integer.MAX_VALUE; + var left2 = Integer.MAX_VALUE; + var nodeTop; + var nodeLeft; + var margin; + var nodes2 = this.getNodes(); + var s = nodes2.length; + for (var i2 = 0; i2 < s; i2++) { + var lNode = nodes2[i2]; + nodeTop = lNode.getTop(); + nodeLeft = lNode.getLeft(); + if (top2 > nodeTop) { + top2 = nodeTop; + } + if (left2 > nodeLeft) { + left2 = nodeLeft; + } + } + if (top2 == Integer.MAX_VALUE) { + return null; + } + if (nodes2[0].getParent().paddingLeft != void 0) { + margin = nodes2[0].getParent().paddingLeft; + } else { + margin = this.margin; + } + this.left = left2 - margin; + this.top = top2 - margin; + return new Point2(this.left, this.top); + }; + LGraph.prototype.updateBounds = function(recursive) { + var left2 = Integer.MAX_VALUE; + var right2 = -Integer.MAX_VALUE; + var top2 = Integer.MAX_VALUE; + var bottom2 = -Integer.MAX_VALUE; + var nodeLeft; + var nodeRight; + var nodeTop; + var nodeBottom; + var margin; + var nodes2 = this.nodes; + var s = nodes2.length; + for (var i2 = 0; i2 < s; i2++) { + var lNode = nodes2[i2]; + if (recursive && lNode.child != null) { + lNode.updateBounds(); + } + nodeLeft = lNode.getLeft(); + nodeRight = lNode.getRight(); + nodeTop = lNode.getTop(); + nodeBottom = lNode.getBottom(); + if (left2 > nodeLeft) { + left2 = nodeLeft; + } + if (right2 < nodeRight) { + right2 = nodeRight; + } + if (top2 > nodeTop) { + top2 = nodeTop; + } + if (bottom2 < nodeBottom) { + bottom2 = nodeBottom; + } + } + var boundingRect = new RectangleD(left2, top2, right2 - left2, bottom2 - top2); + if (left2 == Integer.MAX_VALUE) { + this.left = this.parent.getLeft(); + this.right = this.parent.getRight(); + this.top = this.parent.getTop(); + this.bottom = this.parent.getBottom(); + } + if (nodes2[0].getParent().paddingLeft != void 0) { + margin = nodes2[0].getParent().paddingLeft; + } else { + margin = this.margin; + } + this.left = boundingRect.x - margin; + this.right = boundingRect.x + boundingRect.width + margin; + this.top = boundingRect.y - margin; + this.bottom = boundingRect.y + boundingRect.height + margin; + }; + LGraph.calculateBounds = function(nodes2) { + var left2 = Integer.MAX_VALUE; + var right2 = -Integer.MAX_VALUE; + var top2 = Integer.MAX_VALUE; + var bottom2 = -Integer.MAX_VALUE; + var nodeLeft; + var nodeRight; + var nodeTop; + var nodeBottom; + var s = nodes2.length; + for (var i2 = 0; i2 < s; i2++) { + var lNode = nodes2[i2]; + nodeLeft = lNode.getLeft(); + nodeRight = lNode.getRight(); + nodeTop = lNode.getTop(); + nodeBottom = lNode.getBottom(); + if (left2 > nodeLeft) { + left2 = nodeLeft; + } + if (right2 < nodeRight) { + right2 = nodeRight; + } + if (top2 > nodeTop) { + top2 = nodeTop; + } + if (bottom2 < nodeBottom) { + bottom2 = nodeBottom; + } + } + var boundingRect = new RectangleD(left2, top2, right2 - left2, bottom2 - top2); + return boundingRect; + }; + LGraph.prototype.getInclusionTreeDepth = function() { + if (this == this.graphManager.getRoot()) { + return 1; + } else { + return this.parent.getInclusionTreeDepth(); + } + }; + LGraph.prototype.getEstimatedSize = function() { + if (this.estimatedSize == Integer.MIN_VALUE) { + throw "assert failed"; + } + return this.estimatedSize; + }; + LGraph.prototype.calcEstimatedSize = function() { + var size2 = 0; + var nodes2 = this.nodes; + var s = nodes2.length; + for (var i2 = 0; i2 < s; i2++) { + var lNode = nodes2[i2]; + size2 += lNode.calcEstimatedSize(); + } + if (size2 == 0) { + this.estimatedSize = LayoutConstants.EMPTY_COMPOUND_NODE_SIZE; + } else { + this.estimatedSize = size2 / Math.sqrt(this.nodes.length); + } + return this.estimatedSize; + }; + LGraph.prototype.updateConnected = function() { + var self2 = this; + if (this.nodes.length == 0) { + this.isConnected = true; + return; + } + var queue = new LinkedList(); + var visited = /* @__PURE__ */ new Set(); + var currentNode = this.nodes[0]; + var neighborEdges; + var currentNeighbor; + var childrenOfNode = currentNode.withChildren(); + childrenOfNode.forEach(function(node2) { + queue.push(node2); + visited.add(node2); + }); + while (queue.length !== 0) { + currentNode = queue.shift(); + neighborEdges = currentNode.getEdges(); + var size2 = neighborEdges.length; + for (var i2 = 0; i2 < size2; i2++) { + var neighborEdge = neighborEdges[i2]; + currentNeighbor = neighborEdge.getOtherEndInGraph(currentNode, this); + if (currentNeighbor != null && !visited.has(currentNeighbor)) { + var childrenOfNeighbor = currentNeighbor.withChildren(); + childrenOfNeighbor.forEach(function(node2) { + queue.push(node2); + visited.add(node2); + }); + } + } + } + this.isConnected = false; + if (visited.size >= this.nodes.length) { + var noOfVisitedInThisGraph = 0; + visited.forEach(function(visitedNode) { + if (visitedNode.owner == self2) { + noOfVisitedInThisGraph++; + } + }); + if (noOfVisitedInThisGraph == this.nodes.length) { + this.isConnected = true; + } + } + }; + module3.exports = LGraph; + }, + /* 6 */ + /***/ + function(module3, exports3, __webpack_require__) { + var LGraph; + var LEdge = __webpack_require__(1); + function LGraphManager(layout2) { + LGraph = __webpack_require__(5); + this.layout = layout2; + this.graphs = []; + this.edges = []; + } + LGraphManager.prototype.addRoot = function() { + var ngraph = this.layout.newGraph(); + var nnode = this.layout.newNode(null); + var root2 = this.add(ngraph, nnode); + this.setRootGraph(root2); + return this.rootGraph; + }; + LGraphManager.prototype.add = function(newGraph, parentNode, newEdge, sourceNode, targetNode) { + if (newEdge == null && sourceNode == null && targetNode == null) { + if (newGraph == null) { + throw "Graph is null!"; + } + if (parentNode == null) { + throw "Parent node is null!"; + } + if (this.graphs.indexOf(newGraph) > -1) { + throw "Graph already in this graph mgr!"; + } + this.graphs.push(newGraph); + if (newGraph.parent != null) { + throw "Already has a parent!"; + } + if (parentNode.child != null) { + throw "Already has a child!"; + } + newGraph.parent = parentNode; + parentNode.child = newGraph; + return newGraph; + } else { + targetNode = newEdge; + sourceNode = parentNode; + newEdge = newGraph; + var sourceGraph = sourceNode.getOwner(); + var targetGraph = targetNode.getOwner(); + if (!(sourceGraph != null && sourceGraph.getGraphManager() == this)) { + throw "Source not in this graph mgr!"; + } + if (!(targetGraph != null && targetGraph.getGraphManager() == this)) { + throw "Target not in this graph mgr!"; + } + if (sourceGraph == targetGraph) { + newEdge.isInterGraph = false; + return sourceGraph.add(newEdge, sourceNode, targetNode); + } else { + newEdge.isInterGraph = true; + newEdge.source = sourceNode; + newEdge.target = targetNode; + if (this.edges.indexOf(newEdge) > -1) { + throw "Edge already in inter-graph edge list!"; + } + this.edges.push(newEdge); + if (!(newEdge.source != null && newEdge.target != null)) { + throw "Edge source and/or target is null!"; + } + if (!(newEdge.source.edges.indexOf(newEdge) == -1 && newEdge.target.edges.indexOf(newEdge) == -1)) { + throw "Edge already in source and/or target incidency list!"; + } + newEdge.source.edges.push(newEdge); + newEdge.target.edges.push(newEdge); + return newEdge; + } + } + }; + LGraphManager.prototype.remove = function(lObj) { + if (lObj instanceof LGraph) { + var graph = lObj; + if (graph.getGraphManager() != this) { + throw "Graph not in this graph mgr"; + } + if (!(graph == this.rootGraph || graph.parent != null && graph.parent.graphManager == this)) { + throw "Invalid parent node!"; + } + var edgesToBeRemoved = []; + edgesToBeRemoved = edgesToBeRemoved.concat(graph.getEdges()); + var edge; + var s = edgesToBeRemoved.length; + for (var i2 = 0; i2 < s; i2++) { + edge = edgesToBeRemoved[i2]; + graph.remove(edge); + } + var nodesToBeRemoved = []; + nodesToBeRemoved = nodesToBeRemoved.concat(graph.getNodes()); + var node2; + s = nodesToBeRemoved.length; + for (var i2 = 0; i2 < s; i2++) { + node2 = nodesToBeRemoved[i2]; + graph.remove(node2); + } + if (graph == this.rootGraph) { + this.setRootGraph(null); + } + var index2 = this.graphs.indexOf(graph); + this.graphs.splice(index2, 1); + graph.parent = null; + } else if (lObj instanceof LEdge) { + edge = lObj; + if (edge == null) { + throw "Edge is null!"; + } + if (!edge.isInterGraph) { + throw "Not an inter-graph edge!"; + } + if (!(edge.source != null && edge.target != null)) { + throw "Source and/or target is null!"; + } + if (!(edge.source.edges.indexOf(edge) != -1 && edge.target.edges.indexOf(edge) != -1)) { + throw "Source and/or target doesn't know this edge!"; + } + var index2 = edge.source.edges.indexOf(edge); + edge.source.edges.splice(index2, 1); + index2 = edge.target.edges.indexOf(edge); + edge.target.edges.splice(index2, 1); + if (!(edge.source.owner != null && edge.source.owner.getGraphManager() != null)) { + throw "Edge owner graph or owner graph manager is null!"; + } + if (edge.source.owner.getGraphManager().edges.indexOf(edge) == -1) { + throw "Not in owner graph manager's edge list!"; + } + var index2 = edge.source.owner.getGraphManager().edges.indexOf(edge); + edge.source.owner.getGraphManager().edges.splice(index2, 1); + } + }; + LGraphManager.prototype.updateBounds = function() { + this.rootGraph.updateBounds(true); + }; + LGraphManager.prototype.getGraphs = function() { + return this.graphs; + }; + LGraphManager.prototype.getAllNodes = function() { + if (this.allNodes == null) { + var nodeList = []; + var graphs = this.getGraphs(); + var s = graphs.length; + for (var i2 = 0; i2 < s; i2++) { + nodeList = nodeList.concat(graphs[i2].getNodes()); + } + this.allNodes = nodeList; + } + return this.allNodes; + }; + LGraphManager.prototype.resetAllNodes = function() { + this.allNodes = null; + }; + LGraphManager.prototype.resetAllEdges = function() { + this.allEdges = null; + }; + LGraphManager.prototype.resetAllNodesToApplyGravitation = function() { + this.allNodesToApplyGravitation = null; + }; + LGraphManager.prototype.getAllEdges = function() { + if (this.allEdges == null) { + var edgeList2 = []; + var graphs = this.getGraphs(); + graphs.length; + for (var i2 = 0; i2 < graphs.length; i2++) { + edgeList2 = edgeList2.concat(graphs[i2].getEdges()); + } + edgeList2 = edgeList2.concat(this.edges); + this.allEdges = edgeList2; + } + return this.allEdges; + }; + LGraphManager.prototype.getAllNodesToApplyGravitation = function() { + return this.allNodesToApplyGravitation; + }; + LGraphManager.prototype.setAllNodesToApplyGravitation = function(nodeList) { + if (this.allNodesToApplyGravitation != null) { + throw "assert failed"; + } + this.allNodesToApplyGravitation = nodeList; + }; + LGraphManager.prototype.getRoot = function() { + return this.rootGraph; + }; + LGraphManager.prototype.setRootGraph = function(graph) { + if (graph.getGraphManager() != this) { + throw "Root not in this graph mgr!"; + } + this.rootGraph = graph; + if (graph.parent == null) { + graph.parent = this.layout.newNode("Root node"); + } + }; + LGraphManager.prototype.getLayout = function() { + return this.layout; + }; + LGraphManager.prototype.isOneAncestorOfOther = function(firstNode, secondNode) { + if (!(firstNode != null && secondNode != null)) { + throw "assert failed"; + } + if (firstNode == secondNode) { + return true; + } + var ownerGraph = firstNode.getOwner(); + var parentNode; + do { + parentNode = ownerGraph.getParent(); + if (parentNode == null) { + break; + } + if (parentNode == secondNode) { + return true; + } + ownerGraph = parentNode.getOwner(); + if (ownerGraph == null) { + break; + } + } while (true); + ownerGraph = secondNode.getOwner(); + do { + parentNode = ownerGraph.getParent(); + if (parentNode == null) { + break; + } + if (parentNode == firstNode) { + return true; + } + ownerGraph = parentNode.getOwner(); + if (ownerGraph == null) { + break; + } + } while (true); + return false; + }; + LGraphManager.prototype.calcLowestCommonAncestors = function() { + var edge; + var sourceNode; + var targetNode; + var sourceAncestorGraph; + var targetAncestorGraph; + var edges2 = this.getAllEdges(); + var s = edges2.length; + for (var i2 = 0; i2 < s; i2++) { + edge = edges2[i2]; + sourceNode = edge.source; + targetNode = edge.target; + edge.lca = null; + edge.sourceInLca = sourceNode; + edge.targetInLca = targetNode; + if (sourceNode == targetNode) { + edge.lca = sourceNode.getOwner(); + continue; + } + sourceAncestorGraph = sourceNode.getOwner(); + while (edge.lca == null) { + edge.targetInLca = targetNode; + targetAncestorGraph = targetNode.getOwner(); + while (edge.lca == null) { + if (targetAncestorGraph == sourceAncestorGraph) { + edge.lca = targetAncestorGraph; + break; + } + if (targetAncestorGraph == this.rootGraph) { + break; + } + if (edge.lca != null) { + throw "assert failed"; + } + edge.targetInLca = targetAncestorGraph.getParent(); + targetAncestorGraph = edge.targetInLca.getOwner(); + } + if (sourceAncestorGraph == this.rootGraph) { + break; + } + if (edge.lca == null) { + edge.sourceInLca = sourceAncestorGraph.getParent(); + sourceAncestorGraph = edge.sourceInLca.getOwner(); + } + } + if (edge.lca == null) { + throw "assert failed"; + } + } + }; + LGraphManager.prototype.calcLowestCommonAncestor = function(firstNode, secondNode) { + if (firstNode == secondNode) { + return firstNode.getOwner(); + } + var firstOwnerGraph = firstNode.getOwner(); + do { + if (firstOwnerGraph == null) { + break; + } + var secondOwnerGraph = secondNode.getOwner(); + do { + if (secondOwnerGraph == null) { + break; + } + if (secondOwnerGraph == firstOwnerGraph) { + return secondOwnerGraph; + } + secondOwnerGraph = secondOwnerGraph.getParent().getOwner(); + } while (true); + firstOwnerGraph = firstOwnerGraph.getParent().getOwner(); + } while (true); + return firstOwnerGraph; + }; + LGraphManager.prototype.calcInclusionTreeDepths = function(graph, depth) { + if (graph == null && depth == null) { + graph = this.rootGraph; + depth = 1; + } + var node2; + var nodes2 = graph.getNodes(); + var s = nodes2.length; + for (var i2 = 0; i2 < s; i2++) { + node2 = nodes2[i2]; + node2.inclusionTreeDepth = depth; + if (node2.child != null) { + this.calcInclusionTreeDepths(node2.child, depth + 1); + } + } + }; + LGraphManager.prototype.includesInvalidEdge = function() { + var edge; + var s = this.edges.length; + for (var i2 = 0; i2 < s; i2++) { + edge = this.edges[i2]; + if (this.isOneAncestorOfOther(edge.source, edge.target)) { + return true; + } + } + return false; + }; + module3.exports = LGraphManager; + }, + /* 7 */ + /***/ + function(module3, exports3, __webpack_require__) { + var LayoutConstants = __webpack_require__(0); + function FDLayoutConstants() { + } + for (var prop in LayoutConstants) { + FDLayoutConstants[prop] = LayoutConstants[prop]; + } + FDLayoutConstants.MAX_ITERATIONS = 2500; + FDLayoutConstants.DEFAULT_EDGE_LENGTH = 50; + FDLayoutConstants.DEFAULT_SPRING_STRENGTH = 0.45; + FDLayoutConstants.DEFAULT_REPULSION_STRENGTH = 4500; + FDLayoutConstants.DEFAULT_GRAVITY_STRENGTH = 0.4; + FDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_STRENGTH = 1; + FDLayoutConstants.DEFAULT_GRAVITY_RANGE_FACTOR = 3.8; + FDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_RANGE_FACTOR = 1.5; + FDLayoutConstants.DEFAULT_USE_SMART_IDEAL_EDGE_LENGTH_CALCULATION = true; + FDLayoutConstants.DEFAULT_USE_SMART_REPULSION_RANGE_CALCULATION = true; + FDLayoutConstants.DEFAULT_COOLING_FACTOR_INCREMENTAL = 0.3; + FDLayoutConstants.COOLING_ADAPTATION_FACTOR = 0.33; + FDLayoutConstants.ADAPTATION_LOWER_NODE_LIMIT = 1e3; + FDLayoutConstants.ADAPTATION_UPPER_NODE_LIMIT = 5e3; + FDLayoutConstants.MAX_NODE_DISPLACEMENT_INCREMENTAL = 100; + FDLayoutConstants.MAX_NODE_DISPLACEMENT = FDLayoutConstants.MAX_NODE_DISPLACEMENT_INCREMENTAL * 3; + FDLayoutConstants.MIN_REPULSION_DIST = FDLayoutConstants.DEFAULT_EDGE_LENGTH / 10; + FDLayoutConstants.CONVERGENCE_CHECK_PERIOD = 100; + FDLayoutConstants.PER_LEVEL_IDEAL_EDGE_LENGTH_FACTOR = 0.1; + FDLayoutConstants.MIN_EDGE_LENGTH = 1; + FDLayoutConstants.GRID_CALCULATION_CHECK_PERIOD = 10; + module3.exports = FDLayoutConstants; + }, + /* 8 */ + /***/ + function(module3, exports3, __webpack_require__) { + var Point2 = __webpack_require__(12); + function IGeometry() { + } + IGeometry.calcSeparationAmount = function(rectA, rectB, overlapAmount, separationBuffer) { + if (!rectA.intersects(rectB)) { + throw "assert failed"; + } + var directions = new Array(2); + this.decideDirectionsForOverlappingNodes(rectA, rectB, directions); + overlapAmount[0] = Math.min(rectA.getRight(), rectB.getRight()) - Math.max(rectA.x, rectB.x); + overlapAmount[1] = Math.min(rectA.getBottom(), rectB.getBottom()) - Math.max(rectA.y, rectB.y); + if (rectA.getX() <= rectB.getX() && rectA.getRight() >= rectB.getRight()) { + overlapAmount[0] += Math.min(rectB.getX() - rectA.getX(), rectA.getRight() - rectB.getRight()); + } else if (rectB.getX() <= rectA.getX() && rectB.getRight() >= rectA.getRight()) { + overlapAmount[0] += Math.min(rectA.getX() - rectB.getX(), rectB.getRight() - rectA.getRight()); + } + if (rectA.getY() <= rectB.getY() && rectA.getBottom() >= rectB.getBottom()) { + overlapAmount[1] += Math.min(rectB.getY() - rectA.getY(), rectA.getBottom() - rectB.getBottom()); + } else if (rectB.getY() <= rectA.getY() && rectB.getBottom() >= rectA.getBottom()) { + overlapAmount[1] += Math.min(rectA.getY() - rectB.getY(), rectB.getBottom() - rectA.getBottom()); + } + var slope = Math.abs((rectB.getCenterY() - rectA.getCenterY()) / (rectB.getCenterX() - rectA.getCenterX())); + if (rectB.getCenterY() === rectA.getCenterY() && rectB.getCenterX() === rectA.getCenterX()) { + slope = 1; + } + var moveByY = slope * overlapAmount[0]; + var moveByX = overlapAmount[1] / slope; + if (overlapAmount[0] < moveByX) { + moveByX = overlapAmount[0]; + } else { + moveByY = overlapAmount[1]; + } + overlapAmount[0] = -1 * directions[0] * (moveByX / 2 + separationBuffer); + overlapAmount[1] = -1 * directions[1] * (moveByY / 2 + separationBuffer); + }; + IGeometry.decideDirectionsForOverlappingNodes = function(rectA, rectB, directions) { + if (rectA.getCenterX() < rectB.getCenterX()) { + directions[0] = -1; + } else { + directions[0] = 1; + } + if (rectA.getCenterY() < rectB.getCenterY()) { + directions[1] = -1; + } else { + directions[1] = 1; + } + }; + IGeometry.getIntersection2 = function(rectA, rectB, result) { + var p1x = rectA.getCenterX(); + var p1y = rectA.getCenterY(); + var p2x = rectB.getCenterX(); + var p2y = rectB.getCenterY(); + if (rectA.intersects(rectB)) { + result[0] = p1x; + result[1] = p1y; + result[2] = p2x; + result[3] = p2y; + return true; + } + var topLeftAx = rectA.getX(); + var topLeftAy = rectA.getY(); + var topRightAx = rectA.getRight(); + var bottomLeftAx = rectA.getX(); + var bottomLeftAy = rectA.getBottom(); + var bottomRightAx = rectA.getRight(); + var halfWidthA = rectA.getWidthHalf(); + var halfHeightA = rectA.getHeightHalf(); + var topLeftBx = rectB.getX(); + var topLeftBy = rectB.getY(); + var topRightBx = rectB.getRight(); + var bottomLeftBx = rectB.getX(); + var bottomLeftBy = rectB.getBottom(); + var bottomRightBx = rectB.getRight(); + var halfWidthB = rectB.getWidthHalf(); + var halfHeightB = rectB.getHeightHalf(); + var clipPointAFound = false; + var clipPointBFound = false; + if (p1x === p2x) { + if (p1y > p2y) { + result[0] = p1x; + result[1] = topLeftAy; + result[2] = p2x; + result[3] = bottomLeftBy; + return false; + } else if (p1y < p2y) { + result[0] = p1x; + result[1] = bottomLeftAy; + result[2] = p2x; + result[3] = topLeftBy; + return false; + } else + ; + } else if (p1y === p2y) { + if (p1x > p2x) { + result[0] = topLeftAx; + result[1] = p1y; + result[2] = topRightBx; + result[3] = p2y; + return false; + } else if (p1x < p2x) { + result[0] = topRightAx; + result[1] = p1y; + result[2] = topLeftBx; + result[3] = p2y; + return false; + } else + ; + } else { + var slopeA = rectA.height / rectA.width; + var slopeB = rectB.height / rectB.width; + var slopePrime = (p2y - p1y) / (p2x - p1x); + var cardinalDirectionA = void 0; + var cardinalDirectionB = void 0; + var tempPointAx = void 0; + var tempPointAy = void 0; + var tempPointBx = void 0; + var tempPointBy = void 0; + if (-slopeA === slopePrime) { + if (p1x > p2x) { + result[0] = bottomLeftAx; + result[1] = bottomLeftAy; + clipPointAFound = true; + } else { + result[0] = topRightAx; + result[1] = topLeftAy; + clipPointAFound = true; + } + } else if (slopeA === slopePrime) { + if (p1x > p2x) { + result[0] = topLeftAx; + result[1] = topLeftAy; + clipPointAFound = true; + } else { + result[0] = bottomRightAx; + result[1] = bottomLeftAy; + clipPointAFound = true; + } + } + if (-slopeB === slopePrime) { + if (p2x > p1x) { + result[2] = bottomLeftBx; + result[3] = bottomLeftBy; + clipPointBFound = true; + } else { + result[2] = topRightBx; + result[3] = topLeftBy; + clipPointBFound = true; + } + } else if (slopeB === slopePrime) { + if (p2x > p1x) { + result[2] = topLeftBx; + result[3] = topLeftBy; + clipPointBFound = true; + } else { + result[2] = bottomRightBx; + result[3] = bottomLeftBy; + clipPointBFound = true; + } + } + if (clipPointAFound && clipPointBFound) { + return false; + } + if (p1x > p2x) { + if (p1y > p2y) { + cardinalDirectionA = this.getCardinalDirection(slopeA, slopePrime, 4); + cardinalDirectionB = this.getCardinalDirection(slopeB, slopePrime, 2); + } else { + cardinalDirectionA = this.getCardinalDirection(-slopeA, slopePrime, 3); + cardinalDirectionB = this.getCardinalDirection(-slopeB, slopePrime, 1); + } + } else { + if (p1y > p2y) { + cardinalDirectionA = this.getCardinalDirection(-slopeA, slopePrime, 1); + cardinalDirectionB = this.getCardinalDirection(-slopeB, slopePrime, 3); + } else { + cardinalDirectionA = this.getCardinalDirection(slopeA, slopePrime, 2); + cardinalDirectionB = this.getCardinalDirection(slopeB, slopePrime, 4); + } + } + if (!clipPointAFound) { + switch (cardinalDirectionA) { + case 1: + tempPointAy = topLeftAy; + tempPointAx = p1x + -halfHeightA / slopePrime; + result[0] = tempPointAx; + result[1] = tempPointAy; + break; + case 2: + tempPointAx = bottomRightAx; + tempPointAy = p1y + halfWidthA * slopePrime; + result[0] = tempPointAx; + result[1] = tempPointAy; + break; + case 3: + tempPointAy = bottomLeftAy; + tempPointAx = p1x + halfHeightA / slopePrime; + result[0] = tempPointAx; + result[1] = tempPointAy; + break; + case 4: + tempPointAx = bottomLeftAx; + tempPointAy = p1y + -halfWidthA * slopePrime; + result[0] = tempPointAx; + result[1] = tempPointAy; + break; + } + } + if (!clipPointBFound) { + switch (cardinalDirectionB) { + case 1: + tempPointBy = topLeftBy; + tempPointBx = p2x + -halfHeightB / slopePrime; + result[2] = tempPointBx; + result[3] = tempPointBy; + break; + case 2: + tempPointBx = bottomRightBx; + tempPointBy = p2y + halfWidthB * slopePrime; + result[2] = tempPointBx; + result[3] = tempPointBy; + break; + case 3: + tempPointBy = bottomLeftBy; + tempPointBx = p2x + halfHeightB / slopePrime; + result[2] = tempPointBx; + result[3] = tempPointBy; + break; + case 4: + tempPointBx = bottomLeftBx; + tempPointBy = p2y + -halfWidthB * slopePrime; + result[2] = tempPointBx; + result[3] = tempPointBy; + break; + } + } + } + return false; + }; + IGeometry.getCardinalDirection = function(slope, slopePrime, line2) { + if (slope > slopePrime) { + return line2; + } else { + return 1 + line2 % 4; + } + }; + IGeometry.getIntersection = function(s1, s2, f1, f2) { + if (f2 == null) { + return this.getIntersection2(s1, s2, f1); + } + var x1 = s1.x; + var y1 = s1.y; + var x2 = s2.x; + var y2 = s2.y; + var x3 = f1.x; + var y3 = f1.y; + var x4 = f2.x; + var y4 = f2.y; + var x5 = void 0, y5 = void 0; + var a1 = void 0, a2 = void 0, b1 = void 0, b2 = void 0, c1 = void 0, c2 = void 0; + var denom = void 0; + a1 = y2 - y1; + b1 = x1 - x2; + c1 = x2 * y1 - x1 * y2; + a2 = y4 - y3; + b2 = x3 - x4; + c2 = x4 * y3 - x3 * y4; + denom = a1 * b2 - a2 * b1; + if (denom === 0) { + return null; + } + x5 = (b1 * c2 - b2 * c1) / denom; + y5 = (a2 * c1 - a1 * c2) / denom; + return new Point2(x5, y5); + }; + IGeometry.angleOfVector = function(Cx, Cy, Nx, Ny) { + var C_angle = void 0; + if (Cx !== Nx) { + C_angle = Math.atan((Ny - Cy) / (Nx - Cx)); + if (Nx < Cx) { + C_angle += Math.PI; + } else if (Ny < Cy) { + C_angle += this.TWO_PI; + } + } else if (Ny < Cy) { + C_angle = this.ONE_AND_HALF_PI; + } else { + C_angle = this.HALF_PI; + } + return C_angle; + }; + IGeometry.doIntersect = function(p1, p2, p3, p4) { + var a = p1.x; + var b = p1.y; + var c2 = p2.x; + var d = p2.y; + var p = p3.x; + var q = p3.y; + var r = p4.x; + var s = p4.y; + var det = (c2 - a) * (s - q) - (r - p) * (d - b); + if (det === 0) { + return false; + } else { + var lambda = ((s - q) * (r - a) + (p - r) * (s - b)) / det; + var gamma2 = ((b - d) * (r - a) + (c2 - a) * (s - b)) / det; + return 0 < lambda && lambda < 1 && 0 < gamma2 && gamma2 < 1; + } + }; + IGeometry.HALF_PI = 0.5 * Math.PI; + IGeometry.ONE_AND_HALF_PI = 1.5 * Math.PI; + IGeometry.TWO_PI = 2 * Math.PI; + IGeometry.THREE_PI = 3 * Math.PI; + module3.exports = IGeometry; + }, + /* 9 */ + /***/ + function(module3, exports3, __webpack_require__) { + function IMath() { + } + IMath.sign = function(value2) { + if (value2 > 0) { + return 1; + } else if (value2 < 0) { + return -1; + } else { + return 0; + } + }; + IMath.floor = function(value2) { + return value2 < 0 ? Math.ceil(value2) : Math.floor(value2); + }; + IMath.ceil = function(value2) { + return value2 < 0 ? Math.floor(value2) : Math.ceil(value2); + }; + module3.exports = IMath; + }, + /* 10 */ + /***/ + function(module3, exports3, __webpack_require__) { + function Integer() { + } + Integer.MAX_VALUE = 2147483647; + Integer.MIN_VALUE = -2147483648; + module3.exports = Integer; + }, + /* 11 */ + /***/ + function(module3, exports3, __webpack_require__) { + var _createClass = function() { + function defineProperties(target, props) { + for (var i2 = 0; i2 < props.length; i2++) { + var descriptor = props[i2]; + descriptor.enumerable = descriptor.enumerable || false; + descriptor.configurable = true; + if ("value" in descriptor) + descriptor.writable = true; + Object.defineProperty(target, descriptor.key, descriptor); + } + } + return function(Constructor, protoProps, staticProps) { + if (protoProps) + defineProperties(Constructor.prototype, protoProps); + if (staticProps) + defineProperties(Constructor, staticProps); + return Constructor; + }; + }(); + function _classCallCheck(instance2, Constructor) { + if (!(instance2 instanceof Constructor)) { + throw new TypeError("Cannot call a class as a function"); + } + } + var nodeFrom = function nodeFrom2(value2) { + return { value: value2, next: null, prev: null }; + }; + var add = function add2(prev2, node2, next2, list2) { + if (prev2 !== null) { + prev2.next = node2; + } else { + list2.head = node2; + } + if (next2 !== null) { + next2.prev = node2; + } else { + list2.tail = node2; + } + node2.prev = prev2; + node2.next = next2; + list2.length++; + return node2; + }; + var _remove = function _remove2(node2, list2) { + var prev2 = node2.prev, next2 = node2.next; + if (prev2 !== null) { + prev2.next = next2; + } else { + list2.head = next2; + } + if (next2 !== null) { + next2.prev = prev2; + } else { + list2.tail = prev2; + } + node2.prev = node2.next = null; + list2.length--; + return node2; + }; + var LinkedList = function() { + function LinkedList2(vals) { + var _this = this; + _classCallCheck(this, LinkedList2); + this.length = 0; + this.head = null; + this.tail = null; + if (vals != null) { + vals.forEach(function(v) { + return _this.push(v); + }); + } + } + _createClass(LinkedList2, [{ + key: "size", + value: function size2() { + return this.length; + } + }, { + key: "insertBefore", + value: function insertBefore(val, otherNode) { + return add(otherNode.prev, nodeFrom(val), otherNode, this); + } + }, { + key: "insertAfter", + value: function insertAfter(val, otherNode) { + return add(otherNode, nodeFrom(val), otherNode.next, this); + } + }, { + key: "insertNodeBefore", + value: function insertNodeBefore(newNode, otherNode) { + return add(otherNode.prev, newNode, otherNode, this); + } + }, { + key: "insertNodeAfter", + value: function insertNodeAfter(newNode, otherNode) { + return add(otherNode, newNode, otherNode.next, this); + } + }, { + key: "push", + value: function push2(val) { + return add(this.tail, nodeFrom(val), null, this); + } + }, { + key: "unshift", + value: function unshift(val) { + return add(null, nodeFrom(val), this.head, this); + } + }, { + key: "remove", + value: function remove2(node2) { + return _remove(node2, this); + } + }, { + key: "pop", + value: function pop() { + return _remove(this.tail, this).value; + } + }, { + key: "popNode", + value: function popNode() { + return _remove(this.tail, this); + } + }, { + key: "shift", + value: function shift() { + return _remove(this.head, this).value; + } + }, { + key: "shiftNode", + value: function shiftNode() { + return _remove(this.head, this); + } + }, { + key: "get_object_at", + value: function get_object_at(index2) { + if (index2 <= this.length()) { + var i2 = 1; + var current = this.head; + while (i2 < index2) { + current = current.next; + i2++; + } + return current.value; + } + } + }, { + key: "set_object_at", + value: function set_object_at(index2, value2) { + if (index2 <= this.length()) { + var i2 = 1; + var current = this.head; + while (i2 < index2) { + current = current.next; + i2++; + } + current.value = value2; + } + } + }]); + return LinkedList2; + }(); + module3.exports = LinkedList; + }, + /* 12 */ + /***/ + function(module3, exports3, __webpack_require__) { + function Point2(x2, y2, p) { + this.x = null; + this.y = null; + if (x2 == null && y2 == null && p == null) { + this.x = 0; + this.y = 0; + } else if (typeof x2 == "number" && typeof y2 == "number" && p == null) { + this.x = x2; + this.y = y2; + } else if (x2.constructor.name == "Point" && y2 == null && p == null) { + p = x2; + this.x = p.x; + this.y = p.y; + } + } + Point2.prototype.getX = function() { + return this.x; + }; + Point2.prototype.getY = function() { + return this.y; + }; + Point2.prototype.getLocation = function() { + return new Point2(this.x, this.y); + }; + Point2.prototype.setLocation = function(x2, y2, p) { + if (x2.constructor.name == "Point" && y2 == null && p == null) { + p = x2; + this.setLocation(p.x, p.y); + } else if (typeof x2 == "number" && typeof y2 == "number" && p == null) { + if (parseInt(x2) == x2 && parseInt(y2) == y2) { + this.move(x2, y2); + } else { + this.x = Math.floor(x2 + 0.5); + this.y = Math.floor(y2 + 0.5); + } + } + }; + Point2.prototype.move = function(x2, y2) { + this.x = x2; + this.y = y2; + }; + Point2.prototype.translate = function(dx, dy) { + this.x += dx; + this.y += dy; + }; + Point2.prototype.equals = function(obj) { + if (obj.constructor.name == "Point") { + var pt = obj; + return this.x == pt.x && this.y == pt.y; + } + return this == obj; + }; + Point2.prototype.toString = function() { + return new Point2().constructor.name + "[x=" + this.x + ",y=" + this.y + "]"; + }; + module3.exports = Point2; + }, + /* 13 */ + /***/ + function(module3, exports3, __webpack_require__) { + function RectangleD(x2, y2, width2, height) { + this.x = 0; + this.y = 0; + this.width = 0; + this.height = 0; + if (x2 != null && y2 != null && width2 != null && height != null) { + this.x = x2; + this.y = y2; + this.width = width2; + this.height = height; + } + } + RectangleD.prototype.getX = function() { + return this.x; + }; + RectangleD.prototype.setX = function(x2) { + this.x = x2; + }; + RectangleD.prototype.getY = function() { + return this.y; + }; + RectangleD.prototype.setY = function(y2) { + this.y = y2; + }; + RectangleD.prototype.getWidth = function() { + return this.width; + }; + RectangleD.prototype.setWidth = function(width2) { + this.width = width2; + }; + RectangleD.prototype.getHeight = function() { + return this.height; + }; + RectangleD.prototype.setHeight = function(height) { + this.height = height; + }; + RectangleD.prototype.getRight = function() { + return this.x + this.width; + }; + RectangleD.prototype.getBottom = function() { + return this.y + this.height; + }; + RectangleD.prototype.intersects = function(a) { + if (this.getRight() < a.x) { + return false; + } + if (this.getBottom() < a.y) { + return false; + } + if (a.getRight() < this.x) { + return false; + } + if (a.getBottom() < this.y) { + return false; + } + return true; + }; + RectangleD.prototype.getCenterX = function() { + return this.x + this.width / 2; + }; + RectangleD.prototype.getMinX = function() { + return this.getX(); + }; + RectangleD.prototype.getMaxX = function() { + return this.getX() + this.width; + }; + RectangleD.prototype.getCenterY = function() { + return this.y + this.height / 2; + }; + RectangleD.prototype.getMinY = function() { + return this.getY(); + }; + RectangleD.prototype.getMaxY = function() { + return this.getY() + this.height; + }; + RectangleD.prototype.getWidthHalf = function() { + return this.width / 2; + }; + RectangleD.prototype.getHeightHalf = function() { + return this.height / 2; + }; + module3.exports = RectangleD; + }, + /* 14 */ + /***/ + function(module3, exports3, __webpack_require__) { + var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function(obj) { + return typeof obj; + } : function(obj) { + return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; + }; + function UniqueIDGeneretor() { + } + UniqueIDGeneretor.lastID = 0; + UniqueIDGeneretor.createID = function(obj) { + if (UniqueIDGeneretor.isPrimitive(obj)) { + return obj; + } + if (obj.uniqueID != null) { + return obj.uniqueID; + } + obj.uniqueID = UniqueIDGeneretor.getString(); + UniqueIDGeneretor.lastID++; + return obj.uniqueID; + }; + UniqueIDGeneretor.getString = function(id2) { + if (id2 == null) + id2 = UniqueIDGeneretor.lastID; + return "Object#" + id2; + }; + UniqueIDGeneretor.isPrimitive = function(arg) { + var type2 = typeof arg === "undefined" ? "undefined" : _typeof(arg); + return arg == null || type2 != "object" && type2 != "function"; + }; + module3.exports = UniqueIDGeneretor; + }, + /* 15 */ + /***/ + function(module3, exports3, __webpack_require__) { + function _toConsumableArray(arr) { + if (Array.isArray(arr)) { + for (var i2 = 0, arr2 = Array(arr.length); i2 < arr.length; i2++) { + arr2[i2] = arr[i2]; + } + return arr2; + } else { + return Array.from(arr); + } + } + var LayoutConstants = __webpack_require__(0); + var LGraphManager = __webpack_require__(6); + var LNode = __webpack_require__(3); + var LEdge = __webpack_require__(1); + var LGraph = __webpack_require__(5); + var PointD = __webpack_require__(4); + var Transform2 = __webpack_require__(17); + var Emitter = __webpack_require__(27); + function Layout2(isRemoteUse) { + Emitter.call(this); + this.layoutQuality = LayoutConstants.QUALITY; + this.createBendsAsNeeded = LayoutConstants.DEFAULT_CREATE_BENDS_AS_NEEDED; + this.incremental = LayoutConstants.DEFAULT_INCREMENTAL; + this.animationOnLayout = LayoutConstants.DEFAULT_ANIMATION_ON_LAYOUT; + this.animationDuringLayout = LayoutConstants.DEFAULT_ANIMATION_DURING_LAYOUT; + this.animationPeriod = LayoutConstants.DEFAULT_ANIMATION_PERIOD; + this.uniformLeafNodeSizes = LayoutConstants.DEFAULT_UNIFORM_LEAF_NODE_SIZES; + this.edgeToDummyNodes = /* @__PURE__ */ new Map(); + this.graphManager = new LGraphManager(this); + this.isLayoutFinished = false; + this.isSubLayout = false; + this.isRemoteUse = false; + if (isRemoteUse != null) { + this.isRemoteUse = isRemoteUse; + } + } + Layout2.RANDOM_SEED = 1; + Layout2.prototype = Object.create(Emitter.prototype); + Layout2.prototype.getGraphManager = function() { + return this.graphManager; + }; + Layout2.prototype.getAllNodes = function() { + return this.graphManager.getAllNodes(); + }; + Layout2.prototype.getAllEdges = function() { + return this.graphManager.getAllEdges(); + }; + Layout2.prototype.getAllNodesToApplyGravitation = function() { + return this.graphManager.getAllNodesToApplyGravitation(); + }; + Layout2.prototype.newGraphManager = function() { + var gm = new LGraphManager(this); + this.graphManager = gm; + return gm; + }; + Layout2.prototype.newGraph = function(vGraph) { + return new LGraph(null, this.graphManager, vGraph); + }; + Layout2.prototype.newNode = function(vNode) { + return new LNode(this.graphManager, vNode); + }; + Layout2.prototype.newEdge = function(vEdge) { + return new LEdge(null, null, vEdge); + }; + Layout2.prototype.checkLayoutSuccess = function() { + return this.graphManager.getRoot() == null || this.graphManager.getRoot().getNodes().length == 0 || this.graphManager.includesInvalidEdge(); + }; + Layout2.prototype.runLayout = function() { + this.isLayoutFinished = false; + if (this.tilingPreLayout) { + this.tilingPreLayout(); + } + this.initParameters(); + var isLayoutSuccessfull; + if (this.checkLayoutSuccess()) { + isLayoutSuccessfull = false; + } else { + isLayoutSuccessfull = this.layout(); + } + if (LayoutConstants.ANIMATE === "during") { + return false; + } + if (isLayoutSuccessfull) { + if (!this.isSubLayout) { + this.doPostLayout(); + } + } + if (this.tilingPostLayout) { + this.tilingPostLayout(); + } + this.isLayoutFinished = true; + return isLayoutSuccessfull; + }; + Layout2.prototype.doPostLayout = function() { + if (!this.incremental) { + this.transform(); + } + this.update(); + }; + Layout2.prototype.update2 = function() { + if (this.createBendsAsNeeded) { + this.createBendpointsFromDummyNodes(); + this.graphManager.resetAllEdges(); + } + if (!this.isRemoteUse) { + var allEdges = this.graphManager.getAllEdges(); + for (var i2 = 0; i2 < allEdges.length; i2++) { + allEdges[i2]; + } + var nodes2 = this.graphManager.getRoot().getNodes(); + for (var i2 = 0; i2 < nodes2.length; i2++) { + nodes2[i2]; + } + this.update(this.graphManager.getRoot()); + } + }; + Layout2.prototype.update = function(obj) { + if (obj == null) { + this.update2(); + } else if (obj instanceof LNode) { + var node2 = obj; + if (node2.getChild() != null) { + var nodes2 = node2.getChild().getNodes(); + for (var i2 = 0; i2 < nodes2.length; i2++) { + update(nodes2[i2]); + } + } + if (node2.vGraphObject != null) { + var vNode = node2.vGraphObject; + vNode.update(node2); + } + } else if (obj instanceof LEdge) { + var edge = obj; + if (edge.vGraphObject != null) { + var vEdge = edge.vGraphObject; + vEdge.update(edge); + } + } else if (obj instanceof LGraph) { + var graph = obj; + if (graph.vGraphObject != null) { + var vGraph = graph.vGraphObject; + vGraph.update(graph); + } + } + }; + Layout2.prototype.initParameters = function() { + if (!this.isSubLayout) { + this.layoutQuality = LayoutConstants.QUALITY; + this.animationDuringLayout = LayoutConstants.DEFAULT_ANIMATION_DURING_LAYOUT; + this.animationPeriod = LayoutConstants.DEFAULT_ANIMATION_PERIOD; + this.animationOnLayout = LayoutConstants.DEFAULT_ANIMATION_ON_LAYOUT; + this.incremental = LayoutConstants.DEFAULT_INCREMENTAL; + this.createBendsAsNeeded = LayoutConstants.DEFAULT_CREATE_BENDS_AS_NEEDED; + this.uniformLeafNodeSizes = LayoutConstants.DEFAULT_UNIFORM_LEAF_NODE_SIZES; + } + if (this.animationDuringLayout) { + this.animationOnLayout = false; + } + }; + Layout2.prototype.transform = function(newLeftTop) { + if (newLeftTop == void 0) { + this.transform(new PointD(0, 0)); + } else { + var trans = new Transform2(); + var leftTop = this.graphManager.getRoot().updateLeftTop(); + if (leftTop != null) { + trans.setWorldOrgX(newLeftTop.x); + trans.setWorldOrgY(newLeftTop.y); + trans.setDeviceOrgX(leftTop.x); + trans.setDeviceOrgY(leftTop.y); + var nodes2 = this.getAllNodes(); + var node2; + for (var i2 = 0; i2 < nodes2.length; i2++) { + node2 = nodes2[i2]; + node2.transform(trans); + } + } + } + }; + Layout2.prototype.positionNodesRandomly = function(graph) { + if (graph == void 0) { + this.positionNodesRandomly(this.getGraphManager().getRoot()); + this.getGraphManager().getRoot().updateBounds(true); + } else { + var lNode; + var childGraph; + var nodes2 = graph.getNodes(); + for (var i2 = 0; i2 < nodes2.length; i2++) { + lNode = nodes2[i2]; + childGraph = lNode.getChild(); + if (childGraph == null) { + lNode.scatter(); + } else if (childGraph.getNodes().length == 0) { + lNode.scatter(); + } else { + this.positionNodesRandomly(childGraph); + lNode.updateBounds(); + } + } + } + }; + Layout2.prototype.getFlatForest = function() { + var flatForest = []; + var isForest = true; + var allNodes = this.graphManager.getRoot().getNodes(); + var isFlat = true; + for (var i2 = 0; i2 < allNodes.length; i2++) { + if (allNodes[i2].getChild() != null) { + isFlat = false; + } + } + if (!isFlat) { + return flatForest; + } + var visited = /* @__PURE__ */ new Set(); + var toBeVisited = []; + var parents2 = /* @__PURE__ */ new Map(); + var unProcessedNodes = []; + unProcessedNodes = unProcessedNodes.concat(allNodes); + while (unProcessedNodes.length > 0 && isForest) { + toBeVisited.push(unProcessedNodes[0]); + while (toBeVisited.length > 0 && isForest) { + var currentNode = toBeVisited[0]; + toBeVisited.splice(0, 1); + visited.add(currentNode); + var neighborEdges = currentNode.getEdges(); + for (var i2 = 0; i2 < neighborEdges.length; i2++) { + var currentNeighbor = neighborEdges[i2].getOtherEnd(currentNode); + if (parents2.get(currentNode) != currentNeighbor) { + if (!visited.has(currentNeighbor)) { + toBeVisited.push(currentNeighbor); + parents2.set(currentNeighbor, currentNode); + } else { + isForest = false; + break; + } + } + } + } + if (!isForest) { + flatForest = []; + } else { + var temp = [].concat(_toConsumableArray(visited)); + flatForest.push(temp); + for (var i2 = 0; i2 < temp.length; i2++) { + var value2 = temp[i2]; + var index2 = unProcessedNodes.indexOf(value2); + if (index2 > -1) { + unProcessedNodes.splice(index2, 1); + } + } + visited = /* @__PURE__ */ new Set(); + parents2 = /* @__PURE__ */ new Map(); + } + } + return flatForest; + }; + Layout2.prototype.createDummyNodesForBendpoints = function(edge) { + var dummyNodes = []; + var prev2 = edge.source; + var graph = this.graphManager.calcLowestCommonAncestor(edge.source, edge.target); + for (var i2 = 0; i2 < edge.bendpoints.length; i2++) { + var dummyNode = this.newNode(null); + dummyNode.setRect(new Point(0, 0), new Dimension(1, 1)); + graph.add(dummyNode); + var dummyEdge = this.newEdge(null); + this.graphManager.add(dummyEdge, prev2, dummyNode); + dummyNodes.add(dummyNode); + prev2 = dummyNode; + } + var dummyEdge = this.newEdge(null); + this.graphManager.add(dummyEdge, prev2, edge.target); + this.edgeToDummyNodes.set(edge, dummyNodes); + if (edge.isInterGraph()) { + this.graphManager.remove(edge); + } else { + graph.remove(edge); + } + return dummyNodes; + }; + Layout2.prototype.createBendpointsFromDummyNodes = function() { + var edges2 = []; + edges2 = edges2.concat(this.graphManager.getAllEdges()); + edges2 = [].concat(_toConsumableArray(this.edgeToDummyNodes.keys())).concat(edges2); + for (var k = 0; k < edges2.length; k++) { + var lEdge = edges2[k]; + if (lEdge.bendpoints.length > 0) { + var path2 = this.edgeToDummyNodes.get(lEdge); + for (var i2 = 0; i2 < path2.length; i2++) { + var dummyNode = path2[i2]; + var p = new PointD(dummyNode.getCenterX(), dummyNode.getCenterY()); + var ebp = lEdge.bendpoints.get(i2); + ebp.x = p.x; + ebp.y = p.y; + dummyNode.getOwner().remove(dummyNode); + } + this.graphManager.add(lEdge, lEdge.source, lEdge.target); + } + } + }; + Layout2.transform = function(sliderValue, defaultValue, minDiv, maxMul) { + if (minDiv != void 0 && maxMul != void 0) { + var value2 = defaultValue; + if (sliderValue <= 50) { + var minValue = defaultValue / minDiv; + value2 -= (defaultValue - minValue) / 50 * (50 - sliderValue); + } else { + var maxValue = defaultValue * maxMul; + value2 += (maxValue - defaultValue) / 50 * (sliderValue - 50); + } + return value2; + } else { + var a, b; + if (sliderValue <= 50) { + a = 9 * defaultValue / 500; + b = defaultValue / 10; + } else { + a = 9 * defaultValue / 50; + b = -8 * defaultValue; + } + return a * sliderValue + b; + } + }; + Layout2.findCenterOfTree = function(nodes2) { + var list2 = []; + list2 = list2.concat(nodes2); + var removedNodes = []; + var remainingDegrees = /* @__PURE__ */ new Map(); + var foundCenter = false; + var centerNode = null; + if (list2.length == 1 || list2.length == 2) { + foundCenter = true; + centerNode = list2[0]; + } + for (var i2 = 0; i2 < list2.length; i2++) { + var node2 = list2[i2]; + var degree = node2.getNeighborsList().size; + remainingDegrees.set(node2, node2.getNeighborsList().size); + if (degree == 1) { + removedNodes.push(node2); + } + } + var tempList = []; + tempList = tempList.concat(removedNodes); + while (!foundCenter) { + var tempList2 = []; + tempList2 = tempList2.concat(tempList); + tempList = []; + for (var i2 = 0; i2 < list2.length; i2++) { + var node2 = list2[i2]; + var index2 = list2.indexOf(node2); + if (index2 >= 0) { + list2.splice(index2, 1); + } + var neighbours = node2.getNeighborsList(); + neighbours.forEach(function(neighbour) { + if (removedNodes.indexOf(neighbour) < 0) { + var otherDegree = remainingDegrees.get(neighbour); + var newDegree = otherDegree - 1; + if (newDegree == 1) { + tempList.push(neighbour); + } + remainingDegrees.set(neighbour, newDegree); + } + }); + } + removedNodes = removedNodes.concat(tempList); + if (list2.length == 1 || list2.length == 2) { + foundCenter = true; + centerNode = list2[0]; + } + } + return centerNode; + }; + Layout2.prototype.setGraphManager = function(gm) { + this.graphManager = gm; + }; + module3.exports = Layout2; + }, + /* 16 */ + /***/ + function(module3, exports3, __webpack_require__) { + function RandomSeed() { + } + RandomSeed.seed = 1; + RandomSeed.x = 0; + RandomSeed.nextDouble = function() { + RandomSeed.x = Math.sin(RandomSeed.seed++) * 1e4; + return RandomSeed.x - Math.floor(RandomSeed.x); + }; + module3.exports = RandomSeed; + }, + /* 17 */ + /***/ + function(module3, exports3, __webpack_require__) { + var PointD = __webpack_require__(4); + function Transform2(x2, y2) { + this.lworldOrgX = 0; + this.lworldOrgY = 0; + this.ldeviceOrgX = 0; + this.ldeviceOrgY = 0; + this.lworldExtX = 1; + this.lworldExtY = 1; + this.ldeviceExtX = 1; + this.ldeviceExtY = 1; + } + Transform2.prototype.getWorldOrgX = function() { + return this.lworldOrgX; + }; + Transform2.prototype.setWorldOrgX = function(wox) { + this.lworldOrgX = wox; + }; + Transform2.prototype.getWorldOrgY = function() { + return this.lworldOrgY; + }; + Transform2.prototype.setWorldOrgY = function(woy) { + this.lworldOrgY = woy; + }; + Transform2.prototype.getWorldExtX = function() { + return this.lworldExtX; + }; + Transform2.prototype.setWorldExtX = function(wex) { + this.lworldExtX = wex; + }; + Transform2.prototype.getWorldExtY = function() { + return this.lworldExtY; + }; + Transform2.prototype.setWorldExtY = function(wey) { + this.lworldExtY = wey; + }; + Transform2.prototype.getDeviceOrgX = function() { + return this.ldeviceOrgX; + }; + Transform2.prototype.setDeviceOrgX = function(dox) { + this.ldeviceOrgX = dox; + }; + Transform2.prototype.getDeviceOrgY = function() { + return this.ldeviceOrgY; + }; + Transform2.prototype.setDeviceOrgY = function(doy) { + this.ldeviceOrgY = doy; + }; + Transform2.prototype.getDeviceExtX = function() { + return this.ldeviceExtX; + }; + Transform2.prototype.setDeviceExtX = function(dex) { + this.ldeviceExtX = dex; + }; + Transform2.prototype.getDeviceExtY = function() { + return this.ldeviceExtY; + }; + Transform2.prototype.setDeviceExtY = function(dey) { + this.ldeviceExtY = dey; + }; + Transform2.prototype.transformX = function(x2) { + var xDevice = 0; + var worldExtX = this.lworldExtX; + if (worldExtX != 0) { + xDevice = this.ldeviceOrgX + (x2 - this.lworldOrgX) * this.ldeviceExtX / worldExtX; + } + return xDevice; + }; + Transform2.prototype.transformY = function(y2) { + var yDevice = 0; + var worldExtY = this.lworldExtY; + if (worldExtY != 0) { + yDevice = this.ldeviceOrgY + (y2 - this.lworldOrgY) * this.ldeviceExtY / worldExtY; + } + return yDevice; + }; + Transform2.prototype.inverseTransformX = function(x2) { + var xWorld = 0; + var deviceExtX = this.ldeviceExtX; + if (deviceExtX != 0) { + xWorld = this.lworldOrgX + (x2 - this.ldeviceOrgX) * this.lworldExtX / deviceExtX; + } + return xWorld; + }; + Transform2.prototype.inverseTransformY = function(y2) { + var yWorld = 0; + var deviceExtY = this.ldeviceExtY; + if (deviceExtY != 0) { + yWorld = this.lworldOrgY + (y2 - this.ldeviceOrgY) * this.lworldExtY / deviceExtY; + } + return yWorld; + }; + Transform2.prototype.inverseTransformPoint = function(inPoint) { + var outPoint = new PointD(this.inverseTransformX(inPoint.x), this.inverseTransformY(inPoint.y)); + return outPoint; + }; + module3.exports = Transform2; + }, + /* 18 */ + /***/ + function(module3, exports3, __webpack_require__) { + function _toConsumableArray(arr) { + if (Array.isArray(arr)) { + for (var i2 = 0, arr2 = Array(arr.length); i2 < arr.length; i2++) { + arr2[i2] = arr[i2]; + } + return arr2; + } else { + return Array.from(arr); + } + } + var Layout2 = __webpack_require__(15); + var FDLayoutConstants = __webpack_require__(7); + var LayoutConstants = __webpack_require__(0); + var IGeometry = __webpack_require__(8); + var IMath = __webpack_require__(9); + function FDLayout() { + Layout2.call(this); + this.useSmartIdealEdgeLengthCalculation = FDLayoutConstants.DEFAULT_USE_SMART_IDEAL_EDGE_LENGTH_CALCULATION; + this.idealEdgeLength = FDLayoutConstants.DEFAULT_EDGE_LENGTH; + this.springConstant = FDLayoutConstants.DEFAULT_SPRING_STRENGTH; + this.repulsionConstant = FDLayoutConstants.DEFAULT_REPULSION_STRENGTH; + this.gravityConstant = FDLayoutConstants.DEFAULT_GRAVITY_STRENGTH; + this.compoundGravityConstant = FDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_STRENGTH; + this.gravityRangeFactor = FDLayoutConstants.DEFAULT_GRAVITY_RANGE_FACTOR; + this.compoundGravityRangeFactor = FDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_RANGE_FACTOR; + this.displacementThresholdPerNode = 3 * FDLayoutConstants.DEFAULT_EDGE_LENGTH / 100; + this.coolingFactor = FDLayoutConstants.DEFAULT_COOLING_FACTOR_INCREMENTAL; + this.initialCoolingFactor = FDLayoutConstants.DEFAULT_COOLING_FACTOR_INCREMENTAL; + this.totalDisplacement = 0; + this.oldTotalDisplacement = 0; + this.maxIterations = FDLayoutConstants.MAX_ITERATIONS; + } + FDLayout.prototype = Object.create(Layout2.prototype); + for (var prop in Layout2) { + FDLayout[prop] = Layout2[prop]; + } + FDLayout.prototype.initParameters = function() { + Layout2.prototype.initParameters.call(this, arguments); + this.totalIterations = 0; + this.notAnimatedIterations = 0; + this.useFRGridVariant = FDLayoutConstants.DEFAULT_USE_SMART_REPULSION_RANGE_CALCULATION; + this.grid = []; + }; + FDLayout.prototype.calcIdealEdgeLengths = function() { + var edge; + var lcaDepth; + var source; + var target; + var sizeOfSourceInLca; + var sizeOfTargetInLca; + var allEdges = this.getGraphManager().getAllEdges(); + for (var i2 = 0; i2 < allEdges.length; i2++) { + edge = allEdges[i2]; + edge.idealLength = this.idealEdgeLength; + if (edge.isInterGraph) { + source = edge.getSource(); + target = edge.getTarget(); + sizeOfSourceInLca = edge.getSourceInLca().getEstimatedSize(); + sizeOfTargetInLca = edge.getTargetInLca().getEstimatedSize(); + if (this.useSmartIdealEdgeLengthCalculation) { + edge.idealLength += sizeOfSourceInLca + sizeOfTargetInLca - 2 * LayoutConstants.SIMPLE_NODE_SIZE; + } + lcaDepth = edge.getLca().getInclusionTreeDepth(); + edge.idealLength += FDLayoutConstants.DEFAULT_EDGE_LENGTH * FDLayoutConstants.PER_LEVEL_IDEAL_EDGE_LENGTH_FACTOR * (source.getInclusionTreeDepth() + target.getInclusionTreeDepth() - 2 * lcaDepth); + } + } + }; + FDLayout.prototype.initSpringEmbedder = function() { + var s = this.getAllNodes().length; + if (this.incremental) { + if (s > FDLayoutConstants.ADAPTATION_LOWER_NODE_LIMIT) { + this.coolingFactor = Math.max(this.coolingFactor * FDLayoutConstants.COOLING_ADAPTATION_FACTOR, this.coolingFactor - (s - FDLayoutConstants.ADAPTATION_LOWER_NODE_LIMIT) / (FDLayoutConstants.ADAPTATION_UPPER_NODE_LIMIT - FDLayoutConstants.ADAPTATION_LOWER_NODE_LIMIT) * this.coolingFactor * (1 - FDLayoutConstants.COOLING_ADAPTATION_FACTOR)); + } + this.maxNodeDisplacement = FDLayoutConstants.MAX_NODE_DISPLACEMENT_INCREMENTAL; + } else { + if (s > FDLayoutConstants.ADAPTATION_LOWER_NODE_LIMIT) { + this.coolingFactor = Math.max(FDLayoutConstants.COOLING_ADAPTATION_FACTOR, 1 - (s - FDLayoutConstants.ADAPTATION_LOWER_NODE_LIMIT) / (FDLayoutConstants.ADAPTATION_UPPER_NODE_LIMIT - FDLayoutConstants.ADAPTATION_LOWER_NODE_LIMIT) * (1 - FDLayoutConstants.COOLING_ADAPTATION_FACTOR)); + } else { + this.coolingFactor = 1; + } + this.initialCoolingFactor = this.coolingFactor; + this.maxNodeDisplacement = FDLayoutConstants.MAX_NODE_DISPLACEMENT; + } + this.maxIterations = Math.max(this.getAllNodes().length * 5, this.maxIterations); + this.totalDisplacementThreshold = this.displacementThresholdPerNode * this.getAllNodes().length; + this.repulsionRange = this.calcRepulsionRange(); + }; + FDLayout.prototype.calcSpringForces = function() { + var lEdges = this.getAllEdges(); + var edge; + for (var i2 = 0; i2 < lEdges.length; i2++) { + edge = lEdges[i2]; + this.calcSpringForce(edge, edge.idealLength); + } + }; + FDLayout.prototype.calcRepulsionForces = function() { + var gridUpdateAllowed = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : true; + var forceToNodeSurroundingUpdate = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : false; + var i2, j; + var nodeA, nodeB; + var lNodes = this.getAllNodes(); + var processedNodeSet; + if (this.useFRGridVariant) { + if (this.totalIterations % FDLayoutConstants.GRID_CALCULATION_CHECK_PERIOD == 1 && gridUpdateAllowed) { + this.updateGrid(); + } + processedNodeSet = /* @__PURE__ */ new Set(); + for (i2 = 0; i2 < lNodes.length; i2++) { + nodeA = lNodes[i2]; + this.calculateRepulsionForceOfANode(nodeA, processedNodeSet, gridUpdateAllowed, forceToNodeSurroundingUpdate); + processedNodeSet.add(nodeA); + } + } else { + for (i2 = 0; i2 < lNodes.length; i2++) { + nodeA = lNodes[i2]; + for (j = i2 + 1; j < lNodes.length; j++) { + nodeB = lNodes[j]; + if (nodeA.getOwner() != nodeB.getOwner()) { + continue; + } + this.calcRepulsionForce(nodeA, nodeB); + } + } + } + }; + FDLayout.prototype.calcGravitationalForces = function() { + var node2; + var lNodes = this.getAllNodesToApplyGravitation(); + for (var i2 = 0; i2 < lNodes.length; i2++) { + node2 = lNodes[i2]; + this.calcGravitationalForce(node2); + } + }; + FDLayout.prototype.moveNodes = function() { + var lNodes = this.getAllNodes(); + var node2; + for (var i2 = 0; i2 < lNodes.length; i2++) { + node2 = lNodes[i2]; + node2.move(); + } + }; + FDLayout.prototype.calcSpringForce = function(edge, idealLength) { + var sourceNode = edge.getSource(); + var targetNode = edge.getTarget(); + var length2; + var springForce; + var springForceX; + var springForceY; + if (this.uniformLeafNodeSizes && sourceNode.getChild() == null && targetNode.getChild() == null) { + edge.updateLengthSimple(); + } else { + edge.updateLength(); + if (edge.isOverlapingSourceAndTarget) { + return; + } + } + length2 = edge.getLength(); + if (length2 == 0) + return; + springForce = this.springConstant * (length2 - idealLength); + springForceX = springForce * (edge.lengthX / length2); + springForceY = springForce * (edge.lengthY / length2); + sourceNode.springForceX += springForceX; + sourceNode.springForceY += springForceY; + targetNode.springForceX -= springForceX; + targetNode.springForceY -= springForceY; + }; + FDLayout.prototype.calcRepulsionForce = function(nodeA, nodeB) { + var rectA = nodeA.getRect(); + var rectB = nodeB.getRect(); + var overlapAmount = new Array(2); + var clipPoints = new Array(4); + var distanceX; + var distanceY; + var distanceSquared; + var distance2; + var repulsionForce; + var repulsionForceX; + var repulsionForceY; + if (rectA.intersects(rectB)) { + IGeometry.calcSeparationAmount(rectA, rectB, overlapAmount, FDLayoutConstants.DEFAULT_EDGE_LENGTH / 2); + repulsionForceX = 2 * overlapAmount[0]; + repulsionForceY = 2 * overlapAmount[1]; + var childrenConstant = nodeA.noOfChildren * nodeB.noOfChildren / (nodeA.noOfChildren + nodeB.noOfChildren); + nodeA.repulsionForceX -= childrenConstant * repulsionForceX; + nodeA.repulsionForceY -= childrenConstant * repulsionForceY; + nodeB.repulsionForceX += childrenConstant * repulsionForceX; + nodeB.repulsionForceY += childrenConstant * repulsionForceY; + } else { + if (this.uniformLeafNodeSizes && nodeA.getChild() == null && nodeB.getChild() == null) { + distanceX = rectB.getCenterX() - rectA.getCenterX(); + distanceY = rectB.getCenterY() - rectA.getCenterY(); + } else { + IGeometry.getIntersection(rectA, rectB, clipPoints); + distanceX = clipPoints[2] - clipPoints[0]; + distanceY = clipPoints[3] - clipPoints[1]; + } + if (Math.abs(distanceX) < FDLayoutConstants.MIN_REPULSION_DIST) { + distanceX = IMath.sign(distanceX) * FDLayoutConstants.MIN_REPULSION_DIST; + } + if (Math.abs(distanceY) < FDLayoutConstants.MIN_REPULSION_DIST) { + distanceY = IMath.sign(distanceY) * FDLayoutConstants.MIN_REPULSION_DIST; + } + distanceSquared = distanceX * distanceX + distanceY * distanceY; + distance2 = Math.sqrt(distanceSquared); + repulsionForce = this.repulsionConstant * nodeA.noOfChildren * nodeB.noOfChildren / distanceSquared; + repulsionForceX = repulsionForce * distanceX / distance2; + repulsionForceY = repulsionForce * distanceY / distance2; + nodeA.repulsionForceX -= repulsionForceX; + nodeA.repulsionForceY -= repulsionForceY; + nodeB.repulsionForceX += repulsionForceX; + nodeB.repulsionForceY += repulsionForceY; + } + }; + FDLayout.prototype.calcGravitationalForce = function(node2) { + var ownerGraph; + var ownerCenterX; + var ownerCenterY; + var distanceX; + var distanceY; + var absDistanceX; + var absDistanceY; + var estimatedSize; + ownerGraph = node2.getOwner(); + ownerCenterX = (ownerGraph.getRight() + ownerGraph.getLeft()) / 2; + ownerCenterY = (ownerGraph.getTop() + ownerGraph.getBottom()) / 2; + distanceX = node2.getCenterX() - ownerCenterX; + distanceY = node2.getCenterY() - ownerCenterY; + absDistanceX = Math.abs(distanceX) + node2.getWidth() / 2; + absDistanceY = Math.abs(distanceY) + node2.getHeight() / 2; + if (node2.getOwner() == this.graphManager.getRoot()) { + estimatedSize = ownerGraph.getEstimatedSize() * this.gravityRangeFactor; + if (absDistanceX > estimatedSize || absDistanceY > estimatedSize) { + node2.gravitationForceX = -this.gravityConstant * distanceX; + node2.gravitationForceY = -this.gravityConstant * distanceY; + } + } else { + estimatedSize = ownerGraph.getEstimatedSize() * this.compoundGravityRangeFactor; + if (absDistanceX > estimatedSize || absDistanceY > estimatedSize) { + node2.gravitationForceX = -this.gravityConstant * distanceX * this.compoundGravityConstant; + node2.gravitationForceY = -this.gravityConstant * distanceY * this.compoundGravityConstant; + } + } + }; + FDLayout.prototype.isConverged = function() { + var converged; + var oscilating = false; + if (this.totalIterations > this.maxIterations / 3) { + oscilating = Math.abs(this.totalDisplacement - this.oldTotalDisplacement) < 2; + } + converged = this.totalDisplacement < this.totalDisplacementThreshold; + this.oldTotalDisplacement = this.totalDisplacement; + return converged || oscilating; + }; + FDLayout.prototype.animate = function() { + if (this.animationDuringLayout && !this.isSubLayout) { + if (this.notAnimatedIterations == this.animationPeriod) { + this.update(); + this.notAnimatedIterations = 0; + } else { + this.notAnimatedIterations++; + } + } + }; + FDLayout.prototype.calcNoOfChildrenForAllNodes = function() { + var node2; + var allNodes = this.graphManager.getAllNodes(); + for (var i2 = 0; i2 < allNodes.length; i2++) { + node2 = allNodes[i2]; + node2.noOfChildren = node2.getNoOfChildren(); + } + }; + FDLayout.prototype.calcGrid = function(graph) { + var sizeX = 0; + var sizeY = 0; + sizeX = parseInt(Math.ceil((graph.getRight() - graph.getLeft()) / this.repulsionRange)); + sizeY = parseInt(Math.ceil((graph.getBottom() - graph.getTop()) / this.repulsionRange)); + var grid = new Array(sizeX); + for (var i2 = 0; i2 < sizeX; i2++) { + grid[i2] = new Array(sizeY); + } + for (var i2 = 0; i2 < sizeX; i2++) { + for (var j = 0; j < sizeY; j++) { + grid[i2][j] = new Array(); + } + } + return grid; + }; + FDLayout.prototype.addNodeToGrid = function(v, left2, top2) { + var startX = 0; + var finishX = 0; + var startY = 0; + var finishY = 0; + startX = parseInt(Math.floor((v.getRect().x - left2) / this.repulsionRange)); + finishX = parseInt(Math.floor((v.getRect().width + v.getRect().x - left2) / this.repulsionRange)); + startY = parseInt(Math.floor((v.getRect().y - top2) / this.repulsionRange)); + finishY = parseInt(Math.floor((v.getRect().height + v.getRect().y - top2) / this.repulsionRange)); + for (var i2 = startX; i2 <= finishX; i2++) { + for (var j = startY; j <= finishY; j++) { + this.grid[i2][j].push(v); + v.setGridCoordinates(startX, finishX, startY, finishY); + } + } + }; + FDLayout.prototype.updateGrid = function() { + var i2; + var nodeA; + var lNodes = this.getAllNodes(); + this.grid = this.calcGrid(this.graphManager.getRoot()); + for (i2 = 0; i2 < lNodes.length; i2++) { + nodeA = lNodes[i2]; + this.addNodeToGrid(nodeA, this.graphManager.getRoot().getLeft(), this.graphManager.getRoot().getTop()); + } + }; + FDLayout.prototype.calculateRepulsionForceOfANode = function(nodeA, processedNodeSet, gridUpdateAllowed, forceToNodeSurroundingUpdate) { + if (this.totalIterations % FDLayoutConstants.GRID_CALCULATION_CHECK_PERIOD == 1 && gridUpdateAllowed || forceToNodeSurroundingUpdate) { + var surrounding = /* @__PURE__ */ new Set(); + nodeA.surrounding = new Array(); + var nodeB; + var grid = this.grid; + for (var i2 = nodeA.startX - 1; i2 < nodeA.finishX + 2; i2++) { + for (var j = nodeA.startY - 1; j < nodeA.finishY + 2; j++) { + if (!(i2 < 0 || j < 0 || i2 >= grid.length || j >= grid[0].length)) { + for (var k = 0; k < grid[i2][j].length; k++) { + nodeB = grid[i2][j][k]; + if (nodeA.getOwner() != nodeB.getOwner() || nodeA == nodeB) { + continue; + } + if (!processedNodeSet.has(nodeB) && !surrounding.has(nodeB)) { + var distanceX = Math.abs(nodeA.getCenterX() - nodeB.getCenterX()) - (nodeA.getWidth() / 2 + nodeB.getWidth() / 2); + var distanceY = Math.abs(nodeA.getCenterY() - nodeB.getCenterY()) - (nodeA.getHeight() / 2 + nodeB.getHeight() / 2); + if (distanceX <= this.repulsionRange && distanceY <= this.repulsionRange) { + surrounding.add(nodeB); + } + } + } + } + } + } + nodeA.surrounding = [].concat(_toConsumableArray(surrounding)); + } + for (i2 = 0; i2 < nodeA.surrounding.length; i2++) { + this.calcRepulsionForce(nodeA, nodeA.surrounding[i2]); + } + }; + FDLayout.prototype.calcRepulsionRange = function() { + return 0; + }; + module3.exports = FDLayout; + }, + /* 19 */ + /***/ + function(module3, exports3, __webpack_require__) { + var LEdge = __webpack_require__(1); + var FDLayoutConstants = __webpack_require__(7); + function FDLayoutEdge(source, target, vEdge) { + LEdge.call(this, source, target, vEdge); + this.idealLength = FDLayoutConstants.DEFAULT_EDGE_LENGTH; + } + FDLayoutEdge.prototype = Object.create(LEdge.prototype); + for (var prop in LEdge) { + FDLayoutEdge[prop] = LEdge[prop]; + } + module3.exports = FDLayoutEdge; + }, + /* 20 */ + /***/ + function(module3, exports3, __webpack_require__) { + var LNode = __webpack_require__(3); + function FDLayoutNode(gm, loc, size2, vNode) { + LNode.call(this, gm, loc, size2, vNode); + this.springForceX = 0; + this.springForceY = 0; + this.repulsionForceX = 0; + this.repulsionForceY = 0; + this.gravitationForceX = 0; + this.gravitationForceY = 0; + this.displacementX = 0; + this.displacementY = 0; + this.startX = 0; + this.finishX = 0; + this.startY = 0; + this.finishY = 0; + this.surrounding = []; + } + FDLayoutNode.prototype = Object.create(LNode.prototype); + for (var prop in LNode) { + FDLayoutNode[prop] = LNode[prop]; + } + FDLayoutNode.prototype.setGridCoordinates = function(_startX, _finishX, _startY, _finishY) { + this.startX = _startX; + this.finishX = _finishX; + this.startY = _startY; + this.finishY = _finishY; + }; + module3.exports = FDLayoutNode; + }, + /* 21 */ + /***/ + function(module3, exports3, __webpack_require__) { + function DimensionD2(width2, height) { + this.width = 0; + this.height = 0; + if (width2 !== null && height !== null) { + this.height = height; + this.width = width2; + } + } + DimensionD2.prototype.getWidth = function() { + return this.width; + }; + DimensionD2.prototype.setWidth = function(width2) { + this.width = width2; + }; + DimensionD2.prototype.getHeight = function() { + return this.height; + }; + DimensionD2.prototype.setHeight = function(height) { + this.height = height; + }; + module3.exports = DimensionD2; + }, + /* 22 */ + /***/ + function(module3, exports3, __webpack_require__) { + var UniqueIDGeneretor = __webpack_require__(14); + function HashMap() { + this.map = {}; + this.keys = []; + } + HashMap.prototype.put = function(key, value2) { + var theId = UniqueIDGeneretor.createID(key); + if (!this.contains(theId)) { + this.map[theId] = value2; + this.keys.push(key); + } + }; + HashMap.prototype.contains = function(key) { + UniqueIDGeneretor.createID(key); + return this.map[key] != null; + }; + HashMap.prototype.get = function(key) { + var theId = UniqueIDGeneretor.createID(key); + return this.map[theId]; + }; + HashMap.prototype.keySet = function() { + return this.keys; + }; + module3.exports = HashMap; + }, + /* 23 */ + /***/ + function(module3, exports3, __webpack_require__) { + var UniqueIDGeneretor = __webpack_require__(14); + function HashSet() { + this.set = {}; + } + HashSet.prototype.add = function(obj) { + var theId = UniqueIDGeneretor.createID(obj); + if (!this.contains(theId)) + this.set[theId] = obj; + }; + HashSet.prototype.remove = function(obj) { + delete this.set[UniqueIDGeneretor.createID(obj)]; + }; + HashSet.prototype.clear = function() { + this.set = {}; + }; + HashSet.prototype.contains = function(obj) { + return this.set[UniqueIDGeneretor.createID(obj)] == obj; + }; + HashSet.prototype.isEmpty = function() { + return this.size() === 0; + }; + HashSet.prototype.size = function() { + return Object.keys(this.set).length; + }; + HashSet.prototype.addAllTo = function(list2) { + var keys2 = Object.keys(this.set); + var length2 = keys2.length; + for (var i2 = 0; i2 < length2; i2++) { + list2.push(this.set[keys2[i2]]); + } + }; + HashSet.prototype.size = function() { + return Object.keys(this.set).length; + }; + HashSet.prototype.addAll = function(list2) { + var s = list2.length; + for (var i2 = 0; i2 < s; i2++) { + var v = list2[i2]; + this.add(v); + } + }; + module3.exports = HashSet; + }, + /* 24 */ + /***/ + function(module3, exports3, __webpack_require__) { + var _createClass = function() { + function defineProperties(target, props) { + for (var i2 = 0; i2 < props.length; i2++) { + var descriptor = props[i2]; + descriptor.enumerable = descriptor.enumerable || false; + descriptor.configurable = true; + if ("value" in descriptor) + descriptor.writable = true; + Object.defineProperty(target, descriptor.key, descriptor); + } + } + return function(Constructor, protoProps, staticProps) { + if (protoProps) + defineProperties(Constructor.prototype, protoProps); + if (staticProps) + defineProperties(Constructor, staticProps); + return Constructor; + }; + }(); + function _classCallCheck(instance2, Constructor) { + if (!(instance2 instanceof Constructor)) { + throw new TypeError("Cannot call a class as a function"); + } + } + var LinkedList = __webpack_require__(11); + var Quicksort = function() { + function Quicksort2(A, compareFunction) { + _classCallCheck(this, Quicksort2); + if (compareFunction !== null || compareFunction !== void 0) + this.compareFunction = this._defaultCompareFunction; + var length2 = void 0; + if (A instanceof LinkedList) + length2 = A.size(); + else + length2 = A.length; + this._quicksort(A, 0, length2 - 1); + } + _createClass(Quicksort2, [{ + key: "_quicksort", + value: function _quicksort(A, p, r) { + if (p < r) { + var q = this._partition(A, p, r); + this._quicksort(A, p, q); + this._quicksort(A, q + 1, r); + } + } + }, { + key: "_partition", + value: function _partition(A, p, r) { + var x2 = this._get(A, p); + var i2 = p; + var j = r; + while (true) { + while (this.compareFunction(x2, this._get(A, j))) { + j--; + } + while (this.compareFunction(this._get(A, i2), x2)) { + i2++; + } + if (i2 < j) { + this._swap(A, i2, j); + i2++; + j--; + } else + return j; + } + } + }, { + key: "_get", + value: function _get(object2, index2) { + if (object2 instanceof LinkedList) + return object2.get_object_at(index2); + else + return object2[index2]; + } + }, { + key: "_set", + value: function _set(object2, index2, value2) { + if (object2 instanceof LinkedList) + object2.set_object_at(index2, value2); + else + object2[index2] = value2; + } + }, { + key: "_swap", + value: function _swap(A, i2, j) { + var temp = this._get(A, i2); + this._set(A, i2, this._get(A, j)); + this._set(A, j, temp); + } + }, { + key: "_defaultCompareFunction", + value: function _defaultCompareFunction(a, b) { + return b > a; + } + }]); + return Quicksort2; + }(); + module3.exports = Quicksort; + }, + /* 25 */ + /***/ + function(module3, exports3, __webpack_require__) { + var _createClass = function() { + function defineProperties(target, props) { + for (var i2 = 0; i2 < props.length; i2++) { + var descriptor = props[i2]; + descriptor.enumerable = descriptor.enumerable || false; + descriptor.configurable = true; + if ("value" in descriptor) + descriptor.writable = true; + Object.defineProperty(target, descriptor.key, descriptor); + } + } + return function(Constructor, protoProps, staticProps) { + if (protoProps) + defineProperties(Constructor.prototype, protoProps); + if (staticProps) + defineProperties(Constructor, staticProps); + return Constructor; + }; + }(); + function _classCallCheck(instance2, Constructor) { + if (!(instance2 instanceof Constructor)) { + throw new TypeError("Cannot call a class as a function"); + } + } + var NeedlemanWunsch = function() { + function NeedlemanWunsch2(sequence1, sequence2) { + var match_score = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : 1; + var mismatch_penalty = arguments.length > 3 && arguments[3] !== void 0 ? arguments[3] : -1; + var gap_penalty = arguments.length > 4 && arguments[4] !== void 0 ? arguments[4] : -1; + _classCallCheck(this, NeedlemanWunsch2); + this.sequence1 = sequence1; + this.sequence2 = sequence2; + this.match_score = match_score; + this.mismatch_penalty = mismatch_penalty; + this.gap_penalty = gap_penalty; + this.iMax = sequence1.length + 1; + this.jMax = sequence2.length + 1; + this.grid = new Array(this.iMax); + for (var i2 = 0; i2 < this.iMax; i2++) { + this.grid[i2] = new Array(this.jMax); + for (var j = 0; j < this.jMax; j++) { + this.grid[i2][j] = 0; + } + } + this.tracebackGrid = new Array(this.iMax); + for (var _i6 = 0; _i6 < this.iMax; _i6++) { + this.tracebackGrid[_i6] = new Array(this.jMax); + for (var _j = 0; _j < this.jMax; _j++) { + this.tracebackGrid[_i6][_j] = [null, null, null]; + } + } + this.alignments = []; + this.score = -1; + this.computeGrids(); + } + _createClass(NeedlemanWunsch2, [{ + key: "getScore", + value: function getScore() { + return this.score; + } + }, { + key: "getAlignments", + value: function getAlignments() { + return this.alignments; + } + // Main dynamic programming procedure + }, { + key: "computeGrids", + value: function computeGrids() { + for (var j = 1; j < this.jMax; j++) { + this.grid[0][j] = this.grid[0][j - 1] + this.gap_penalty; + this.tracebackGrid[0][j] = [false, false, true]; + } + for (var i2 = 1; i2 < this.iMax; i2++) { + this.grid[i2][0] = this.grid[i2 - 1][0] + this.gap_penalty; + this.tracebackGrid[i2][0] = [false, true, false]; + } + for (var _i22 = 1; _i22 < this.iMax; _i22++) { + for (var _j2 = 1; _j2 < this.jMax; _j2++) { + var diag = void 0; + if (this.sequence1[_i22 - 1] === this.sequence2[_j2 - 1]) + diag = this.grid[_i22 - 1][_j2 - 1] + this.match_score; + else + diag = this.grid[_i22 - 1][_j2 - 1] + this.mismatch_penalty; + var up = this.grid[_i22 - 1][_j2] + this.gap_penalty; + var left2 = this.grid[_i22][_j2 - 1] + this.gap_penalty; + var maxOf = [diag, up, left2]; + var indices = this.arrayAllMaxIndexes(maxOf); + this.grid[_i22][_j2] = maxOf[indices[0]]; + this.tracebackGrid[_i22][_j2] = [indices.includes(0), indices.includes(1), indices.includes(2)]; + } + } + this.score = this.grid[this.iMax - 1][this.jMax - 1]; + } + // Gets all possible valid sequence combinations + }, { + key: "alignmentTraceback", + value: function alignmentTraceback() { + var inProcessAlignments = []; + inProcessAlignments.push({ + pos: [this.sequence1.length, this.sequence2.length], + seq1: "", + seq2: "" + }); + while (inProcessAlignments[0]) { + var current = inProcessAlignments[0]; + var directions = this.tracebackGrid[current.pos[0]][current.pos[1]]; + if (directions[0]) { + inProcessAlignments.push({ + pos: [current.pos[0] - 1, current.pos[1] - 1], + seq1: this.sequence1[current.pos[0] - 1] + current.seq1, + seq2: this.sequence2[current.pos[1] - 1] + current.seq2 + }); + } + if (directions[1]) { + inProcessAlignments.push({ + pos: [current.pos[0] - 1, current.pos[1]], + seq1: this.sequence1[current.pos[0] - 1] + current.seq1, + seq2: "-" + current.seq2 + }); + } + if (directions[2]) { + inProcessAlignments.push({ + pos: [current.pos[0], current.pos[1] - 1], + seq1: "-" + current.seq1, + seq2: this.sequence2[current.pos[1] - 1] + current.seq2 + }); + } + if (current.pos[0] === 0 && current.pos[1] === 0) + this.alignments.push({ + sequence1: current.seq1, + sequence2: current.seq2 + }); + inProcessAlignments.shift(); + } + return this.alignments; + } + // Helper Functions + }, { + key: "getAllIndexes", + value: function getAllIndexes(arr, val) { + var indexes = [], i2 = -1; + while ((i2 = arr.indexOf(val, i2 + 1)) !== -1) { + indexes.push(i2); + } + return indexes; + } + }, { + key: "arrayAllMaxIndexes", + value: function arrayAllMaxIndexes(array2) { + return this.getAllIndexes(array2, Math.max.apply(null, array2)); + } + }]); + return NeedlemanWunsch2; + }(); + module3.exports = NeedlemanWunsch; + }, + /* 26 */ + /***/ + function(module3, exports3, __webpack_require__) { + var layoutBase2 = function layoutBase3() { + return; + }; + layoutBase2.FDLayout = __webpack_require__(18); + layoutBase2.FDLayoutConstants = __webpack_require__(7); + layoutBase2.FDLayoutEdge = __webpack_require__(19); + layoutBase2.FDLayoutNode = __webpack_require__(20); + layoutBase2.DimensionD = __webpack_require__(21); + layoutBase2.HashMap = __webpack_require__(22); + layoutBase2.HashSet = __webpack_require__(23); + layoutBase2.IGeometry = __webpack_require__(8); + layoutBase2.IMath = __webpack_require__(9); + layoutBase2.Integer = __webpack_require__(10); + layoutBase2.Point = __webpack_require__(12); + layoutBase2.PointD = __webpack_require__(4); + layoutBase2.RandomSeed = __webpack_require__(16); + layoutBase2.RectangleD = __webpack_require__(13); + layoutBase2.Transform = __webpack_require__(17); + layoutBase2.UniqueIDGeneretor = __webpack_require__(14); + layoutBase2.Quicksort = __webpack_require__(24); + layoutBase2.LinkedList = __webpack_require__(11); + layoutBase2.LGraphObject = __webpack_require__(2); + layoutBase2.LGraph = __webpack_require__(5); + layoutBase2.LEdge = __webpack_require__(1); + layoutBase2.LGraphManager = __webpack_require__(6); + layoutBase2.LNode = __webpack_require__(3); + layoutBase2.Layout = __webpack_require__(15); + layoutBase2.LayoutConstants = __webpack_require__(0); + layoutBase2.NeedlemanWunsch = __webpack_require__(25); + module3.exports = layoutBase2; + }, + /* 27 */ + /***/ + function(module3, exports3, __webpack_require__) { + function Emitter() { + this.listeners = []; + } + var p = Emitter.prototype; + p.addListener = function(event, callback) { + this.listeners.push({ + event, + callback + }); + }; + p.removeListener = function(event, callback) { + for (var i2 = this.listeners.length; i2 >= 0; i2--) { + var l = this.listeners[i2]; + if (l.event === event && l.callback === callback) { + this.listeners.splice(i2, 1); + } + } + }; + p.emit = function(event, data) { + for (var i2 = 0; i2 < this.listeners.length; i2++) { + var l = this.listeners[i2]; + if (event === l.event) { + l.callback(data); + } + } + }; + module3.exports = Emitter; + } + /******/ + ]) + ); + }); + })(layoutBase); + return layoutBase.exports; + } + var hasRequiredCoseBase; + function requireCoseBase() { + if (hasRequiredCoseBase) + return coseBase.exports; + hasRequiredCoseBase = 1; + (function(module2, exports2) { + (function webpackUniversalModuleDefinition(root2, factory) { + module2.exports = factory(requireLayoutBase()); + })(commonjsGlobal, function(__WEBPACK_EXTERNAL_MODULE_0__) { + return ( + /******/ + function(modules) { + var installedModules = {}; + function __webpack_require__(moduleId) { + if (installedModules[moduleId]) { + return installedModules[moduleId].exports; + } + var module3 = installedModules[moduleId] = { + /******/ + i: moduleId, + /******/ + l: false, + /******/ + exports: {} + /******/ + }; + modules[moduleId].call(module3.exports, module3, module3.exports, __webpack_require__); + module3.l = true; + return module3.exports; + } + __webpack_require__.m = modules; + __webpack_require__.c = installedModules; + __webpack_require__.i = function(value2) { + return value2; + }; + __webpack_require__.d = function(exports3, name, getter) { + if (!__webpack_require__.o(exports3, name)) { + Object.defineProperty(exports3, name, { + /******/ + configurable: false, + /******/ + enumerable: true, + /******/ + get: getter + /******/ + }); + } + }; + __webpack_require__.n = function(module3) { + var getter = module3 && module3.__esModule ? ( + /******/ + function getDefault() { + return module3["default"]; + } + ) : ( + /******/ + function getModuleExports() { + return module3; + } + ); + __webpack_require__.d(getter, "a", getter); + return getter; + }; + __webpack_require__.o = function(object2, property2) { + return Object.prototype.hasOwnProperty.call(object2, property2); + }; + __webpack_require__.p = ""; + return __webpack_require__(__webpack_require__.s = 7); + }([ + /* 0 */ + /***/ + function(module3, exports3) { + module3.exports = __WEBPACK_EXTERNAL_MODULE_0__; + }, + /* 1 */ + /***/ + function(module3, exports3, __webpack_require__) { + var FDLayoutConstants = __webpack_require__(0).FDLayoutConstants; + function CoSEConstants() { + } + for (var prop in FDLayoutConstants) { + CoSEConstants[prop] = FDLayoutConstants[prop]; + } + CoSEConstants.DEFAULT_USE_MULTI_LEVEL_SCALING = false; + CoSEConstants.DEFAULT_RADIAL_SEPARATION = FDLayoutConstants.DEFAULT_EDGE_LENGTH; + CoSEConstants.DEFAULT_COMPONENT_SEPERATION = 60; + CoSEConstants.TILE = true; + CoSEConstants.TILING_PADDING_VERTICAL = 10; + CoSEConstants.TILING_PADDING_HORIZONTAL = 10; + CoSEConstants.TREE_REDUCTION_ON_INCREMENTAL = false; + module3.exports = CoSEConstants; + }, + /* 2 */ + /***/ + function(module3, exports3, __webpack_require__) { + var FDLayoutEdge = __webpack_require__(0).FDLayoutEdge; + function CoSEEdge(source, target, vEdge) { + FDLayoutEdge.call(this, source, target, vEdge); + } + CoSEEdge.prototype = Object.create(FDLayoutEdge.prototype); + for (var prop in FDLayoutEdge) { + CoSEEdge[prop] = FDLayoutEdge[prop]; + } + module3.exports = CoSEEdge; + }, + /* 3 */ + /***/ + function(module3, exports3, __webpack_require__) { + var LGraph = __webpack_require__(0).LGraph; + function CoSEGraph(parent, graphMgr, vGraph) { + LGraph.call(this, parent, graphMgr, vGraph); + } + CoSEGraph.prototype = Object.create(LGraph.prototype); + for (var prop in LGraph) { + CoSEGraph[prop] = LGraph[prop]; + } + module3.exports = CoSEGraph; + }, + /* 4 */ + /***/ + function(module3, exports3, __webpack_require__) { + var LGraphManager = __webpack_require__(0).LGraphManager; + function CoSEGraphManager(layout2) { + LGraphManager.call(this, layout2); + } + CoSEGraphManager.prototype = Object.create(LGraphManager.prototype); + for (var prop in LGraphManager) { + CoSEGraphManager[prop] = LGraphManager[prop]; + } + module3.exports = CoSEGraphManager; + }, + /* 5 */ + /***/ + function(module3, exports3, __webpack_require__) { + var FDLayoutNode = __webpack_require__(0).FDLayoutNode; + var IMath = __webpack_require__(0).IMath; + function CoSENode(gm, loc, size2, vNode) { + FDLayoutNode.call(this, gm, loc, size2, vNode); + } + CoSENode.prototype = Object.create(FDLayoutNode.prototype); + for (var prop in FDLayoutNode) { + CoSENode[prop] = FDLayoutNode[prop]; + } + CoSENode.prototype.move = function() { + var layout2 = this.graphManager.getLayout(); + this.displacementX = layout2.coolingFactor * (this.springForceX + this.repulsionForceX + this.gravitationForceX) / this.noOfChildren; + this.displacementY = layout2.coolingFactor * (this.springForceY + this.repulsionForceY + this.gravitationForceY) / this.noOfChildren; + if (Math.abs(this.displacementX) > layout2.coolingFactor * layout2.maxNodeDisplacement) { + this.displacementX = layout2.coolingFactor * layout2.maxNodeDisplacement * IMath.sign(this.displacementX); + } + if (Math.abs(this.displacementY) > layout2.coolingFactor * layout2.maxNodeDisplacement) { + this.displacementY = layout2.coolingFactor * layout2.maxNodeDisplacement * IMath.sign(this.displacementY); + } + if (this.child == null) { + this.moveBy(this.displacementX, this.displacementY); + } else if (this.child.getNodes().length == 0) { + this.moveBy(this.displacementX, this.displacementY); + } else { + this.propogateDisplacementToChildren(this.displacementX, this.displacementY); + } + layout2.totalDisplacement += Math.abs(this.displacementX) + Math.abs(this.displacementY); + this.springForceX = 0; + this.springForceY = 0; + this.repulsionForceX = 0; + this.repulsionForceY = 0; + this.gravitationForceX = 0; + this.gravitationForceY = 0; + this.displacementX = 0; + this.displacementY = 0; + }; + CoSENode.prototype.propogateDisplacementToChildren = function(dX, dY) { + var nodes2 = this.getChild().getNodes(); + var node2; + for (var i2 = 0; i2 < nodes2.length; i2++) { + node2 = nodes2[i2]; + if (node2.getChild() == null) { + node2.moveBy(dX, dY); + node2.displacementX += dX; + node2.displacementY += dY; + } else { + node2.propogateDisplacementToChildren(dX, dY); + } + } + }; + CoSENode.prototype.setPred1 = function(pred12) { + this.pred1 = pred12; + }; + CoSENode.prototype.getPred1 = function() { + return pred1; + }; + CoSENode.prototype.getPred2 = function() { + return pred2; + }; + CoSENode.prototype.setNext = function(next2) { + this.next = next2; + }; + CoSENode.prototype.getNext = function() { + return next; + }; + CoSENode.prototype.setProcessed = function(processed2) { + this.processed = processed2; + }; + CoSENode.prototype.isProcessed = function() { + return processed; + }; + module3.exports = CoSENode; + }, + /* 6 */ + /***/ + function(module3, exports3, __webpack_require__) { + var FDLayout = __webpack_require__(0).FDLayout; + var CoSEGraphManager = __webpack_require__(4); + var CoSEGraph = __webpack_require__(3); + var CoSENode = __webpack_require__(5); + var CoSEEdge = __webpack_require__(2); + var CoSEConstants = __webpack_require__(1); + var FDLayoutConstants = __webpack_require__(0).FDLayoutConstants; + var LayoutConstants = __webpack_require__(0).LayoutConstants; + var Point2 = __webpack_require__(0).Point; + var PointD = __webpack_require__(0).PointD; + var Layout2 = __webpack_require__(0).Layout; + var Integer = __webpack_require__(0).Integer; + var IGeometry = __webpack_require__(0).IGeometry; + var LGraph = __webpack_require__(0).LGraph; + var Transform2 = __webpack_require__(0).Transform; + function CoSELayout() { + FDLayout.call(this); + this.toBeTiled = {}; + } + CoSELayout.prototype = Object.create(FDLayout.prototype); + for (var prop in FDLayout) { + CoSELayout[prop] = FDLayout[prop]; + } + CoSELayout.prototype.newGraphManager = function() { + var gm = new CoSEGraphManager(this); + this.graphManager = gm; + return gm; + }; + CoSELayout.prototype.newGraph = function(vGraph) { + return new CoSEGraph(null, this.graphManager, vGraph); + }; + CoSELayout.prototype.newNode = function(vNode) { + return new CoSENode(this.graphManager, vNode); + }; + CoSELayout.prototype.newEdge = function(vEdge) { + return new CoSEEdge(null, null, vEdge); + }; + CoSELayout.prototype.initParameters = function() { + FDLayout.prototype.initParameters.call(this, arguments); + if (!this.isSubLayout) { + if (CoSEConstants.DEFAULT_EDGE_LENGTH < 10) { + this.idealEdgeLength = 10; + } else { + this.idealEdgeLength = CoSEConstants.DEFAULT_EDGE_LENGTH; + } + this.useSmartIdealEdgeLengthCalculation = CoSEConstants.DEFAULT_USE_SMART_IDEAL_EDGE_LENGTH_CALCULATION; + this.springConstant = FDLayoutConstants.DEFAULT_SPRING_STRENGTH; + this.repulsionConstant = FDLayoutConstants.DEFAULT_REPULSION_STRENGTH; + this.gravityConstant = FDLayoutConstants.DEFAULT_GRAVITY_STRENGTH; + this.compoundGravityConstant = FDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_STRENGTH; + this.gravityRangeFactor = FDLayoutConstants.DEFAULT_GRAVITY_RANGE_FACTOR; + this.compoundGravityRangeFactor = FDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_RANGE_FACTOR; + this.prunedNodesAll = []; + this.growTreeIterations = 0; + this.afterGrowthIterations = 0; + this.isTreeGrowing = false; + this.isGrowthFinished = false; + this.coolingCycle = 0; + this.maxCoolingCycle = this.maxIterations / FDLayoutConstants.CONVERGENCE_CHECK_PERIOD; + this.finalTemperature = FDLayoutConstants.CONVERGENCE_CHECK_PERIOD / this.maxIterations; + this.coolingAdjuster = 1; + } + }; + CoSELayout.prototype.layout = function() { + var createBendsAsNeeded = LayoutConstants.DEFAULT_CREATE_BENDS_AS_NEEDED; + if (createBendsAsNeeded) { + this.createBendpoints(); + this.graphManager.resetAllEdges(); + } + this.level = 0; + return this.classicLayout(); + }; + CoSELayout.prototype.classicLayout = function() { + this.nodesWithGravity = this.calculateNodesToApplyGravitationTo(); + this.graphManager.setAllNodesToApplyGravitation(this.nodesWithGravity); + this.calcNoOfChildrenForAllNodes(); + this.graphManager.calcLowestCommonAncestors(); + this.graphManager.calcInclusionTreeDepths(); + this.graphManager.getRoot().calcEstimatedSize(); + this.calcIdealEdgeLengths(); + if (!this.incremental) { + var forest = this.getFlatForest(); + if (forest.length > 0) { + this.positionNodesRadially(forest); + } else { + this.reduceTrees(); + this.graphManager.resetAllNodesToApplyGravitation(); + var allNodes = new Set(this.getAllNodes()); + var intersection2 = this.nodesWithGravity.filter(function(x2) { + return allNodes.has(x2); + }); + this.graphManager.setAllNodesToApplyGravitation(intersection2); + this.positionNodesRandomly(); + } + } else { + if (CoSEConstants.TREE_REDUCTION_ON_INCREMENTAL) { + this.reduceTrees(); + this.graphManager.resetAllNodesToApplyGravitation(); + var allNodes = new Set(this.getAllNodes()); + var intersection2 = this.nodesWithGravity.filter(function(x2) { + return allNodes.has(x2); + }); + this.graphManager.setAllNodesToApplyGravitation(intersection2); + } + } + this.initSpringEmbedder(); + this.runSpringEmbedder(); + return true; + }; + CoSELayout.prototype.tick = function() { + this.totalIterations++; + if (this.totalIterations === this.maxIterations && !this.isTreeGrowing && !this.isGrowthFinished) { + if (this.prunedNodesAll.length > 0) { + this.isTreeGrowing = true; + } else { + return true; + } + } + if (this.totalIterations % FDLayoutConstants.CONVERGENCE_CHECK_PERIOD == 0 && !this.isTreeGrowing && !this.isGrowthFinished) { + if (this.isConverged()) { + if (this.prunedNodesAll.length > 0) { + this.isTreeGrowing = true; + } else { + return true; + } + } + this.coolingCycle++; + if (this.layoutQuality == 0) { + this.coolingAdjuster = this.coolingCycle; + } else if (this.layoutQuality == 1) { + this.coolingAdjuster = this.coolingCycle / 3; + } + this.coolingFactor = Math.max(this.initialCoolingFactor - Math.pow(this.coolingCycle, Math.log(100 * (this.initialCoolingFactor - this.finalTemperature)) / Math.log(this.maxCoolingCycle)) / 100 * this.coolingAdjuster, this.finalTemperature); + this.animationPeriod = Math.ceil(this.initialAnimationPeriod * Math.sqrt(this.coolingFactor)); + } + if (this.isTreeGrowing) { + if (this.growTreeIterations % 10 == 0) { + if (this.prunedNodesAll.length > 0) { + this.graphManager.updateBounds(); + this.updateGrid(); + this.growTree(this.prunedNodesAll); + this.graphManager.resetAllNodesToApplyGravitation(); + var allNodes = new Set(this.getAllNodes()); + var intersection2 = this.nodesWithGravity.filter(function(x2) { + return allNodes.has(x2); + }); + this.graphManager.setAllNodesToApplyGravitation(intersection2); + this.graphManager.updateBounds(); + this.updateGrid(); + this.coolingFactor = FDLayoutConstants.DEFAULT_COOLING_FACTOR_INCREMENTAL; + } else { + this.isTreeGrowing = false; + this.isGrowthFinished = true; + } + } + this.growTreeIterations++; + } + if (this.isGrowthFinished) { + if (this.isConverged()) { + return true; + } + if (this.afterGrowthIterations % 10 == 0) { + this.graphManager.updateBounds(); + this.updateGrid(); + } + this.coolingFactor = FDLayoutConstants.DEFAULT_COOLING_FACTOR_INCREMENTAL * ((100 - this.afterGrowthIterations) / 100); + this.afterGrowthIterations++; + } + var gridUpdateAllowed = !this.isTreeGrowing && !this.isGrowthFinished; + var forceToNodeSurroundingUpdate = this.growTreeIterations % 10 == 1 && this.isTreeGrowing || this.afterGrowthIterations % 10 == 1 && this.isGrowthFinished; + this.totalDisplacement = 0; + this.graphManager.updateBounds(); + this.calcSpringForces(); + this.calcRepulsionForces(gridUpdateAllowed, forceToNodeSurroundingUpdate); + this.calcGravitationalForces(); + this.moveNodes(); + this.animate(); + return false; + }; + CoSELayout.prototype.getPositionsData = function() { + var allNodes = this.graphManager.getAllNodes(); + var pData = {}; + for (var i2 = 0; i2 < allNodes.length; i2++) { + var rect2 = allNodes[i2].rect; + var id2 = allNodes[i2].id; + pData[id2] = { + id: id2, + x: rect2.getCenterX(), + y: rect2.getCenterY(), + w: rect2.width, + h: rect2.height + }; + } + return pData; + }; + CoSELayout.prototype.runSpringEmbedder = function() { + this.initialAnimationPeriod = 25; + this.animationPeriod = this.initialAnimationPeriod; + var layoutEnded = false; + if (FDLayoutConstants.ANIMATE === "during") { + this.emit("layoutstarted"); + } else { + while (!layoutEnded) { + layoutEnded = this.tick(); + } + this.graphManager.updateBounds(); + } + }; + CoSELayout.prototype.calculateNodesToApplyGravitationTo = function() { + var nodeList = []; + var graph; + var graphs = this.graphManager.getGraphs(); + var size2 = graphs.length; + var i2; + for (i2 = 0; i2 < size2; i2++) { + graph = graphs[i2]; + graph.updateConnected(); + if (!graph.isConnected) { + nodeList = nodeList.concat(graph.getNodes()); + } + } + return nodeList; + }; + CoSELayout.prototype.createBendpoints = function() { + var edges2 = []; + edges2 = edges2.concat(this.graphManager.getAllEdges()); + var visited = /* @__PURE__ */ new Set(); + var i2; + for (i2 = 0; i2 < edges2.length; i2++) { + var edge = edges2[i2]; + if (!visited.has(edge)) { + var source = edge.getSource(); + var target = edge.getTarget(); + if (source == target) { + edge.getBendpoints().push(new PointD()); + edge.getBendpoints().push(new PointD()); + this.createDummyNodesForBendpoints(edge); + visited.add(edge); + } else { + var edgeList2 = []; + edgeList2 = edgeList2.concat(source.getEdgeListToNode(target)); + edgeList2 = edgeList2.concat(target.getEdgeListToNode(source)); + if (!visited.has(edgeList2[0])) { + if (edgeList2.length > 1) { + var k; + for (k = 0; k < edgeList2.length; k++) { + var multiEdge = edgeList2[k]; + multiEdge.getBendpoints().push(new PointD()); + this.createDummyNodesForBendpoints(multiEdge); + } + } + edgeList2.forEach(function(edge2) { + visited.add(edge2); + }); + } + } + } + if (visited.size == edges2.length) { + break; + } + } + }; + CoSELayout.prototype.positionNodesRadially = function(forest) { + var currentStartingPoint = new Point2(0, 0); + var numberOfColumns = Math.ceil(Math.sqrt(forest.length)); + var height = 0; + var currentY = 0; + var currentX = 0; + var point2 = new PointD(0, 0); + for (var i2 = 0; i2 < forest.length; i2++) { + if (i2 % numberOfColumns == 0) { + currentX = 0; + currentY = height; + if (i2 != 0) { + currentY += CoSEConstants.DEFAULT_COMPONENT_SEPERATION; + } + height = 0; + } + var tree = forest[i2]; + var centerNode = Layout2.findCenterOfTree(tree); + currentStartingPoint.x = currentX; + currentStartingPoint.y = currentY; + point2 = CoSELayout.radialLayout(tree, centerNode, currentStartingPoint); + if (point2.y > height) { + height = Math.floor(point2.y); + } + currentX = Math.floor(point2.x + CoSEConstants.DEFAULT_COMPONENT_SEPERATION); + } + this.transform(new PointD(LayoutConstants.WORLD_CENTER_X - point2.x / 2, LayoutConstants.WORLD_CENTER_Y - point2.y / 2)); + }; + CoSELayout.radialLayout = function(tree, centerNode, startingPoint) { + var radialSep = Math.max(this.maxDiagonalInTree(tree), CoSEConstants.DEFAULT_RADIAL_SEPARATION); + CoSELayout.branchRadialLayout(centerNode, null, 0, 359, 0, radialSep); + var bounds2 = LGraph.calculateBounds(tree); + var transform = new Transform2(); + transform.setDeviceOrgX(bounds2.getMinX()); + transform.setDeviceOrgY(bounds2.getMinY()); + transform.setWorldOrgX(startingPoint.x); + transform.setWorldOrgY(startingPoint.y); + for (var i2 = 0; i2 < tree.length; i2++) { + var node2 = tree[i2]; + node2.transform(transform); + } + var bottomRight = new PointD(bounds2.getMaxX(), bounds2.getMaxY()); + return transform.inverseTransformPoint(bottomRight); + }; + CoSELayout.branchRadialLayout = function(node2, parentOfNode, startAngle, endAngle, distance2, radialSeparation) { + var halfInterval = (endAngle - startAngle + 1) / 2; + if (halfInterval < 0) { + halfInterval += 180; + } + var nodeAngle = (halfInterval + startAngle) % 360; + var teta = nodeAngle * IGeometry.TWO_PI / 360; + var x_ = distance2 * Math.cos(teta); + var y_ = distance2 * Math.sin(teta); + node2.setCenter(x_, y_); + var neighborEdges = []; + neighborEdges = neighborEdges.concat(node2.getEdges()); + var childCount = neighborEdges.length; + if (parentOfNode != null) { + childCount--; + } + var branchCount = 0; + var incEdgesCount = neighborEdges.length; + var startIndex; + var edges2 = node2.getEdgesBetween(parentOfNode); + while (edges2.length > 1) { + var temp = edges2[0]; + edges2.splice(0, 1); + var index2 = neighborEdges.indexOf(temp); + if (index2 >= 0) { + neighborEdges.splice(index2, 1); + } + incEdgesCount--; + childCount--; + } + if (parentOfNode != null) { + startIndex = (neighborEdges.indexOf(edges2[0]) + 1) % incEdgesCount; + } else { + startIndex = 0; + } + var stepAngle = Math.abs(endAngle - startAngle) / childCount; + for (var i2 = startIndex; branchCount != childCount; i2 = ++i2 % incEdgesCount) { + var currentNeighbor = neighborEdges[i2].getOtherEnd(node2); + if (currentNeighbor == parentOfNode) { + continue; + } + var childStartAngle = (startAngle + branchCount * stepAngle) % 360; + var childEndAngle = (childStartAngle + stepAngle) % 360; + CoSELayout.branchRadialLayout(currentNeighbor, node2, childStartAngle, childEndAngle, distance2 + radialSeparation, radialSeparation); + branchCount++; + } + }; + CoSELayout.maxDiagonalInTree = function(tree) { + var maxDiagonal = Integer.MIN_VALUE; + for (var i2 = 0; i2 < tree.length; i2++) { + var node2 = tree[i2]; + var diagonal = node2.getDiagonal(); + if (diagonal > maxDiagonal) { + maxDiagonal = diagonal; + } + } + return maxDiagonal; + }; + CoSELayout.prototype.calcRepulsionRange = function() { + return 2 * (this.level + 1) * this.idealEdgeLength; + }; + CoSELayout.prototype.groupZeroDegreeMembers = function() { + var self2 = this; + var tempMemberGroups = {}; + this.memberGroups = {}; + this.idToDummyNode = {}; + var zeroDegree = []; + var allNodes = this.graphManager.getAllNodes(); + for (var i2 = 0; i2 < allNodes.length; i2++) { + var node2 = allNodes[i2]; + var parent = node2.getParent(); + if (this.getNodeDegreeWithChildren(node2) === 0 && (parent.id == void 0 || !this.getToBeTiled(parent))) { + zeroDegree.push(node2); + } + } + for (var i2 = 0; i2 < zeroDegree.length; i2++) { + var node2 = zeroDegree[i2]; + var p_id = node2.getParent().id; + if (typeof tempMemberGroups[p_id] === "undefined") + tempMemberGroups[p_id] = []; + tempMemberGroups[p_id] = tempMemberGroups[p_id].concat(node2); + } + Object.keys(tempMemberGroups).forEach(function(p_id2) { + if (tempMemberGroups[p_id2].length > 1) { + var dummyCompoundId = "DummyCompound_" + p_id2; + self2.memberGroups[dummyCompoundId] = tempMemberGroups[p_id2]; + var parent2 = tempMemberGroups[p_id2][0].getParent(); + var dummyCompound = new CoSENode(self2.graphManager); + dummyCompound.id = dummyCompoundId; + dummyCompound.paddingLeft = parent2.paddingLeft || 0; + dummyCompound.paddingRight = parent2.paddingRight || 0; + dummyCompound.paddingBottom = parent2.paddingBottom || 0; + dummyCompound.paddingTop = parent2.paddingTop || 0; + self2.idToDummyNode[dummyCompoundId] = dummyCompound; + var dummyParentGraph = self2.getGraphManager().add(self2.newGraph(), dummyCompound); + var parentGraph = parent2.getChild(); + parentGraph.add(dummyCompound); + for (var i3 = 0; i3 < tempMemberGroups[p_id2].length; i3++) { + var node3 = tempMemberGroups[p_id2][i3]; + parentGraph.remove(node3); + dummyParentGraph.add(node3); + } + } + }); + }; + CoSELayout.prototype.clearCompounds = function() { + var childGraphMap = {}; + var idToNode = {}; + this.performDFSOnCompounds(); + for (var i2 = 0; i2 < this.compoundOrder.length; i2++) { + idToNode[this.compoundOrder[i2].id] = this.compoundOrder[i2]; + childGraphMap[this.compoundOrder[i2].id] = [].concat(this.compoundOrder[i2].getChild().getNodes()); + this.graphManager.remove(this.compoundOrder[i2].getChild()); + this.compoundOrder[i2].child = null; + } + this.graphManager.resetAllNodes(); + this.tileCompoundMembers(childGraphMap, idToNode); + }; + CoSELayout.prototype.clearZeroDegreeMembers = function() { + var self2 = this; + var tiledZeroDegreePack = this.tiledZeroDegreePack = []; + Object.keys(this.memberGroups).forEach(function(id2) { + var compoundNode = self2.idToDummyNode[id2]; + tiledZeroDegreePack[id2] = self2.tileNodes(self2.memberGroups[id2], compoundNode.paddingLeft + compoundNode.paddingRight); + compoundNode.rect.width = tiledZeroDegreePack[id2].width; + compoundNode.rect.height = tiledZeroDegreePack[id2].height; + }); + }; + CoSELayout.prototype.repopulateCompounds = function() { + for (var i2 = this.compoundOrder.length - 1; i2 >= 0; i2--) { + var lCompoundNode = this.compoundOrder[i2]; + var id2 = lCompoundNode.id; + var horizontalMargin = lCompoundNode.paddingLeft; + var verticalMargin = lCompoundNode.paddingTop; + this.adjustLocations(this.tiledMemberPack[id2], lCompoundNode.rect.x, lCompoundNode.rect.y, horizontalMargin, verticalMargin); + } + }; + CoSELayout.prototype.repopulateZeroDegreeMembers = function() { + var self2 = this; + var tiledPack = this.tiledZeroDegreePack; + Object.keys(tiledPack).forEach(function(id2) { + var compoundNode = self2.idToDummyNode[id2]; + var horizontalMargin = compoundNode.paddingLeft; + var verticalMargin = compoundNode.paddingTop; + self2.adjustLocations(tiledPack[id2], compoundNode.rect.x, compoundNode.rect.y, horizontalMargin, verticalMargin); + }); + }; + CoSELayout.prototype.getToBeTiled = function(node2) { + var id2 = node2.id; + if (this.toBeTiled[id2] != null) { + return this.toBeTiled[id2]; + } + var childGraph = node2.getChild(); + if (childGraph == null) { + this.toBeTiled[id2] = false; + return false; + } + var children2 = childGraph.getNodes(); + for (var i2 = 0; i2 < children2.length; i2++) { + var theChild = children2[i2]; + if (this.getNodeDegree(theChild) > 0) { + this.toBeTiled[id2] = false; + return false; + } + if (theChild.getChild() == null) { + this.toBeTiled[theChild.id] = false; + continue; + } + if (!this.getToBeTiled(theChild)) { + this.toBeTiled[id2] = false; + return false; + } + } + this.toBeTiled[id2] = true; + return true; + }; + CoSELayout.prototype.getNodeDegree = function(node2) { + node2.id; + var edges2 = node2.getEdges(); + var degree = 0; + for (var i2 = 0; i2 < edges2.length; i2++) { + var edge = edges2[i2]; + if (edge.getSource().id !== edge.getTarget().id) { + degree = degree + 1; + } + } + return degree; + }; + CoSELayout.prototype.getNodeDegreeWithChildren = function(node2) { + var degree = this.getNodeDegree(node2); + if (node2.getChild() == null) { + return degree; + } + var children2 = node2.getChild().getNodes(); + for (var i2 = 0; i2 < children2.length; i2++) { + var child = children2[i2]; + degree += this.getNodeDegreeWithChildren(child); + } + return degree; + }; + CoSELayout.prototype.performDFSOnCompounds = function() { + this.compoundOrder = []; + this.fillCompexOrderByDFS(this.graphManager.getRoot().getNodes()); + }; + CoSELayout.prototype.fillCompexOrderByDFS = function(children2) { + for (var i2 = 0; i2 < children2.length; i2++) { + var child = children2[i2]; + if (child.getChild() != null) { + this.fillCompexOrderByDFS(child.getChild().getNodes()); + } + if (this.getToBeTiled(child)) { + this.compoundOrder.push(child); + } + } + }; + CoSELayout.prototype.adjustLocations = function(organization, x2, y2, compoundHorizontalMargin, compoundVerticalMargin) { + x2 += compoundHorizontalMargin; + y2 += compoundVerticalMargin; + var left2 = x2; + for (var i2 = 0; i2 < organization.rows.length; i2++) { + var row = organization.rows[i2]; + x2 = left2; + var maxHeight = 0; + for (var j = 0; j < row.length; j++) { + var lnode = row[j]; + lnode.rect.x = x2; + lnode.rect.y = y2; + x2 += lnode.rect.width + organization.horizontalPadding; + if (lnode.rect.height > maxHeight) + maxHeight = lnode.rect.height; + } + y2 += maxHeight + organization.verticalPadding; + } + }; + CoSELayout.prototype.tileCompoundMembers = function(childGraphMap, idToNode) { + var self2 = this; + this.tiledMemberPack = []; + Object.keys(childGraphMap).forEach(function(id2) { + var compoundNode = idToNode[id2]; + self2.tiledMemberPack[id2] = self2.tileNodes(childGraphMap[id2], compoundNode.paddingLeft + compoundNode.paddingRight); + compoundNode.rect.width = self2.tiledMemberPack[id2].width; + compoundNode.rect.height = self2.tiledMemberPack[id2].height; + }); + }; + CoSELayout.prototype.tileNodes = function(nodes2, minWidth) { + var verticalPadding = CoSEConstants.TILING_PADDING_VERTICAL; + var horizontalPadding = CoSEConstants.TILING_PADDING_HORIZONTAL; + var organization = { + rows: [], + rowWidth: [], + rowHeight: [], + width: 0, + height: minWidth, + // assume minHeight equals to minWidth + verticalPadding, + horizontalPadding + }; + nodes2.sort(function(n1, n2) { + if (n1.rect.width * n1.rect.height > n2.rect.width * n2.rect.height) + return -1; + if (n1.rect.width * n1.rect.height < n2.rect.width * n2.rect.height) + return 1; + return 0; + }); + for (var i2 = 0; i2 < nodes2.length; i2++) { + var lNode = nodes2[i2]; + if (organization.rows.length == 0) { + this.insertNodeToRow(organization, lNode, 0, minWidth); + } else if (this.canAddHorizontal(organization, lNode.rect.width, lNode.rect.height)) { + this.insertNodeToRow(organization, lNode, this.getShortestRowIndex(organization), minWidth); + } else { + this.insertNodeToRow(organization, lNode, organization.rows.length, minWidth); + } + this.shiftToLastRow(organization); + } + return organization; + }; + CoSELayout.prototype.insertNodeToRow = function(organization, node2, rowIndex, minWidth) { + var minCompoundSize = minWidth; + if (rowIndex == organization.rows.length) { + var secondDimension = []; + organization.rows.push(secondDimension); + organization.rowWidth.push(minCompoundSize); + organization.rowHeight.push(0); + } + var w2 = organization.rowWidth[rowIndex] + node2.rect.width; + if (organization.rows[rowIndex].length > 0) { + w2 += organization.horizontalPadding; + } + organization.rowWidth[rowIndex] = w2; + if (organization.width < w2) { + organization.width = w2; + } + var h = node2.rect.height; + if (rowIndex > 0) + h += organization.verticalPadding; + var extraHeight = 0; + if (h > organization.rowHeight[rowIndex]) { + extraHeight = organization.rowHeight[rowIndex]; + organization.rowHeight[rowIndex] = h; + extraHeight = organization.rowHeight[rowIndex] - extraHeight; + } + organization.height += extraHeight; + organization.rows[rowIndex].push(node2); + }; + CoSELayout.prototype.getShortestRowIndex = function(organization) { + var r = -1; + var min2 = Number.MAX_VALUE; + for (var i2 = 0; i2 < organization.rows.length; i2++) { + if (organization.rowWidth[i2] < min2) { + r = i2; + min2 = organization.rowWidth[i2]; + } + } + return r; + }; + CoSELayout.prototype.getLongestRowIndex = function(organization) { + var r = -1; + var max2 = Number.MIN_VALUE; + for (var i2 = 0; i2 < organization.rows.length; i2++) { + if (organization.rowWidth[i2] > max2) { + r = i2; + max2 = organization.rowWidth[i2]; + } + } + return r; + }; + CoSELayout.prototype.canAddHorizontal = function(organization, extraWidth, extraHeight) { + var sri = this.getShortestRowIndex(organization); + if (sri < 0) { + return true; + } + var min2 = organization.rowWidth[sri]; + if (min2 + organization.horizontalPadding + extraWidth <= organization.width) + return true; + var hDiff = 0; + if (organization.rowHeight[sri] < extraHeight) { + if (sri > 0) + hDiff = extraHeight + organization.verticalPadding - organization.rowHeight[sri]; + } + var add_to_row_ratio; + if (organization.width - min2 >= extraWidth + organization.horizontalPadding) { + add_to_row_ratio = (organization.height + hDiff) / (min2 + extraWidth + organization.horizontalPadding); + } else { + add_to_row_ratio = (organization.height + hDiff) / organization.width; + } + hDiff = extraHeight + organization.verticalPadding; + var add_new_row_ratio; + if (organization.width < extraWidth) { + add_new_row_ratio = (organization.height + hDiff) / extraWidth; + } else { + add_new_row_ratio = (organization.height + hDiff) / organization.width; + } + if (add_new_row_ratio < 1) + add_new_row_ratio = 1 / add_new_row_ratio; + if (add_to_row_ratio < 1) + add_to_row_ratio = 1 / add_to_row_ratio; + return add_to_row_ratio < add_new_row_ratio; + }; + CoSELayout.prototype.shiftToLastRow = function(organization) { + var longest = this.getLongestRowIndex(organization); + var last2 = organization.rowWidth.length - 1; + var row = organization.rows[longest]; + var node2 = row[row.length - 1]; + var diff = node2.width + organization.horizontalPadding; + if (organization.width - organization.rowWidth[last2] > diff && longest != last2) { + row.splice(-1, 1); + organization.rows[last2].push(node2); + organization.rowWidth[longest] = organization.rowWidth[longest] - diff; + organization.rowWidth[last2] = organization.rowWidth[last2] + diff; + organization.width = organization.rowWidth[instance.getLongestRowIndex(organization)]; + var maxHeight = Number.MIN_VALUE; + for (var i2 = 0; i2 < row.length; i2++) { + if (row[i2].height > maxHeight) + maxHeight = row[i2].height; + } + if (longest > 0) + maxHeight += organization.verticalPadding; + var prevTotal = organization.rowHeight[longest] + organization.rowHeight[last2]; + organization.rowHeight[longest] = maxHeight; + if (organization.rowHeight[last2] < node2.height + organization.verticalPadding) + organization.rowHeight[last2] = node2.height + organization.verticalPadding; + var finalTotal = organization.rowHeight[longest] + organization.rowHeight[last2]; + organization.height += finalTotal - prevTotal; + this.shiftToLastRow(organization); + } + }; + CoSELayout.prototype.tilingPreLayout = function() { + if (CoSEConstants.TILE) { + this.groupZeroDegreeMembers(); + this.clearCompounds(); + this.clearZeroDegreeMembers(); + } + }; + CoSELayout.prototype.tilingPostLayout = function() { + if (CoSEConstants.TILE) { + this.repopulateZeroDegreeMembers(); + this.repopulateCompounds(); + } + }; + CoSELayout.prototype.reduceTrees = function() { + var prunedNodesAll = []; + var containsLeaf = true; + var node2; + while (containsLeaf) { + var allNodes = this.graphManager.getAllNodes(); + var prunedNodesInStepTemp = []; + containsLeaf = false; + for (var i2 = 0; i2 < allNodes.length; i2++) { + node2 = allNodes[i2]; + if (node2.getEdges().length == 1 && !node2.getEdges()[0].isInterGraph && node2.getChild() == null) { + prunedNodesInStepTemp.push([node2, node2.getEdges()[0], node2.getOwner()]); + containsLeaf = true; + } + } + if (containsLeaf == true) { + var prunedNodesInStep = []; + for (var j = 0; j < prunedNodesInStepTemp.length; j++) { + if (prunedNodesInStepTemp[j][0].getEdges().length == 1) { + prunedNodesInStep.push(prunedNodesInStepTemp[j]); + prunedNodesInStepTemp[j][0].getOwner().remove(prunedNodesInStepTemp[j][0]); + } + } + prunedNodesAll.push(prunedNodesInStep); + this.graphManager.resetAllNodes(); + this.graphManager.resetAllEdges(); + } + } + this.prunedNodesAll = prunedNodesAll; + }; + CoSELayout.prototype.growTree = function(prunedNodesAll) { + var lengthOfPrunedNodesInStep = prunedNodesAll.length; + var prunedNodesInStep = prunedNodesAll[lengthOfPrunedNodesInStep - 1]; + var nodeData; + for (var i2 = 0; i2 < prunedNodesInStep.length; i2++) { + nodeData = prunedNodesInStep[i2]; + this.findPlaceforPrunedNode(nodeData); + nodeData[2].add(nodeData[0]); + nodeData[2].add(nodeData[1], nodeData[1].source, nodeData[1].target); + } + prunedNodesAll.splice(prunedNodesAll.length - 1, 1); + this.graphManager.resetAllNodes(); + this.graphManager.resetAllEdges(); + }; + CoSELayout.prototype.findPlaceforPrunedNode = function(nodeData) { + var gridForPrunedNode; + var nodeToConnect; + var prunedNode = nodeData[0]; + if (prunedNode == nodeData[1].source) { + nodeToConnect = nodeData[1].target; + } else { + nodeToConnect = nodeData[1].source; + } + var startGridX = nodeToConnect.startX; + var finishGridX = nodeToConnect.finishX; + var startGridY = nodeToConnect.startY; + var finishGridY = nodeToConnect.finishY; + var upNodeCount = 0; + var downNodeCount = 0; + var rightNodeCount = 0; + var leftNodeCount = 0; + var controlRegions = [upNodeCount, rightNodeCount, downNodeCount, leftNodeCount]; + if (startGridY > 0) { + for (var i2 = startGridX; i2 <= finishGridX; i2++) { + controlRegions[0] += this.grid[i2][startGridY - 1].length + this.grid[i2][startGridY].length - 1; + } + } + if (finishGridX < this.grid.length - 1) { + for (var i2 = startGridY; i2 <= finishGridY; i2++) { + controlRegions[1] += this.grid[finishGridX + 1][i2].length + this.grid[finishGridX][i2].length - 1; + } + } + if (finishGridY < this.grid[0].length - 1) { + for (var i2 = startGridX; i2 <= finishGridX; i2++) { + controlRegions[2] += this.grid[i2][finishGridY + 1].length + this.grid[i2][finishGridY].length - 1; + } + } + if (startGridX > 0) { + for (var i2 = startGridY; i2 <= finishGridY; i2++) { + controlRegions[3] += this.grid[startGridX - 1][i2].length + this.grid[startGridX][i2].length - 1; + } + } + var min2 = Integer.MAX_VALUE; + var minCount; + var minIndex; + for (var j = 0; j < controlRegions.length; j++) { + if (controlRegions[j] < min2) { + min2 = controlRegions[j]; + minCount = 1; + minIndex = j; + } else if (controlRegions[j] == min2) { + minCount++; + } + } + if (minCount == 3 && min2 == 0) { + if (controlRegions[0] == 0 && controlRegions[1] == 0 && controlRegions[2] == 0) { + gridForPrunedNode = 1; + } else if (controlRegions[0] == 0 && controlRegions[1] == 0 && controlRegions[3] == 0) { + gridForPrunedNode = 0; + } else if (controlRegions[0] == 0 && controlRegions[2] == 0 && controlRegions[3] == 0) { + gridForPrunedNode = 3; + } else if (controlRegions[1] == 0 && controlRegions[2] == 0 && controlRegions[3] == 0) { + gridForPrunedNode = 2; + } + } else if (minCount == 2 && min2 == 0) { + var random2 = Math.floor(Math.random() * 2); + if (controlRegions[0] == 0 && controlRegions[1] == 0) { + if (random2 == 0) { + gridForPrunedNode = 0; + } else { + gridForPrunedNode = 1; + } + } else if (controlRegions[0] == 0 && controlRegions[2] == 0) { + if (random2 == 0) { + gridForPrunedNode = 0; + } else { + gridForPrunedNode = 2; + } + } else if (controlRegions[0] == 0 && controlRegions[3] == 0) { + if (random2 == 0) { + gridForPrunedNode = 0; + } else { + gridForPrunedNode = 3; + } + } else if (controlRegions[1] == 0 && controlRegions[2] == 0) { + if (random2 == 0) { + gridForPrunedNode = 1; + } else { + gridForPrunedNode = 2; + } + } else if (controlRegions[1] == 0 && controlRegions[3] == 0) { + if (random2 == 0) { + gridForPrunedNode = 1; + } else { + gridForPrunedNode = 3; + } + } else { + if (random2 == 0) { + gridForPrunedNode = 2; + } else { + gridForPrunedNode = 3; + } + } + } else if (minCount == 4 && min2 == 0) { + var random2 = Math.floor(Math.random() * 4); + gridForPrunedNode = random2; + } else { + gridForPrunedNode = minIndex; + } + if (gridForPrunedNode == 0) { + prunedNode.setCenter(nodeToConnect.getCenterX(), nodeToConnect.getCenterY() - nodeToConnect.getHeight() / 2 - FDLayoutConstants.DEFAULT_EDGE_LENGTH - prunedNode.getHeight() / 2); + } else if (gridForPrunedNode == 1) { + prunedNode.setCenter(nodeToConnect.getCenterX() + nodeToConnect.getWidth() / 2 + FDLayoutConstants.DEFAULT_EDGE_LENGTH + prunedNode.getWidth() / 2, nodeToConnect.getCenterY()); + } else if (gridForPrunedNode == 2) { + prunedNode.setCenter(nodeToConnect.getCenterX(), nodeToConnect.getCenterY() + nodeToConnect.getHeight() / 2 + FDLayoutConstants.DEFAULT_EDGE_LENGTH + prunedNode.getHeight() / 2); + } else { + prunedNode.setCenter(nodeToConnect.getCenterX() - nodeToConnect.getWidth() / 2 - FDLayoutConstants.DEFAULT_EDGE_LENGTH - prunedNode.getWidth() / 2, nodeToConnect.getCenterY()); + } + }; + module3.exports = CoSELayout; + }, + /* 7 */ + /***/ + function(module3, exports3, __webpack_require__) { + var coseBase2 = {}; + coseBase2.layoutBase = __webpack_require__(0); + coseBase2.CoSEConstants = __webpack_require__(1); + coseBase2.CoSEEdge = __webpack_require__(2); + coseBase2.CoSEGraph = __webpack_require__(3); + coseBase2.CoSEGraphManager = __webpack_require__(4); + coseBase2.CoSELayout = __webpack_require__(6); + coseBase2.CoSENode = __webpack_require__(5); + module3.exports = coseBase2; + } + /******/ + ]) + ); + }); + })(coseBase); + return coseBase.exports; + } + (function(module2, exports2) { + (function webpackUniversalModuleDefinition(root2, factory) { + module2.exports = factory(requireCoseBase()); + })(commonjsGlobal, function(__WEBPACK_EXTERNAL_MODULE_0__) { + return ( + /******/ + function(modules) { + var installedModules = {}; + function __webpack_require__(moduleId) { + if (installedModules[moduleId]) { + return installedModules[moduleId].exports; + } + var module3 = installedModules[moduleId] = { + /******/ + i: moduleId, + /******/ + l: false, + /******/ + exports: {} + /******/ + }; + modules[moduleId].call(module3.exports, module3, module3.exports, __webpack_require__); + module3.l = true; + return module3.exports; + } + __webpack_require__.m = modules; + __webpack_require__.c = installedModules; + __webpack_require__.i = function(value2) { + return value2; + }; + __webpack_require__.d = function(exports3, name, getter) { + if (!__webpack_require__.o(exports3, name)) { + Object.defineProperty(exports3, name, { + /******/ + configurable: false, + /******/ + enumerable: true, + /******/ + get: getter + /******/ + }); + } + }; + __webpack_require__.n = function(module3) { + var getter = module3 && module3.__esModule ? ( + /******/ + function getDefault() { + return module3["default"]; + } + ) : ( + /******/ + function getModuleExports() { + return module3; + } + ); + __webpack_require__.d(getter, "a", getter); + return getter; + }; + __webpack_require__.o = function(object2, property2) { + return Object.prototype.hasOwnProperty.call(object2, property2); + }; + __webpack_require__.p = ""; + return __webpack_require__(__webpack_require__.s = 1); + }([ + /* 0 */ + /***/ + function(module3, exports3) { + module3.exports = __WEBPACK_EXTERNAL_MODULE_0__; + }, + /* 1 */ + /***/ + function(module3, exports3, __webpack_require__) { + var LayoutConstants = __webpack_require__(0).layoutBase.LayoutConstants; + var FDLayoutConstants = __webpack_require__(0).layoutBase.FDLayoutConstants; + var CoSEConstants = __webpack_require__(0).CoSEConstants; + var CoSELayout = __webpack_require__(0).CoSELayout; + var CoSENode = __webpack_require__(0).CoSENode; + var PointD = __webpack_require__(0).layoutBase.PointD; + var DimensionD2 = __webpack_require__(0).layoutBase.DimensionD; + var defaults2 = { + // Called on `layoutready` + ready: function ready() { + }, + // Called on `layoutstop` + stop: function stop() { + }, + // 'draft', 'default' or 'proof" + // - 'draft' fast cooling rate + // - 'default' moderate cooling rate + // - "proof" slow cooling rate + quality: "default", + // include labels in node dimensions + nodeDimensionsIncludeLabels: false, + // number of ticks per frame; higher is faster but more jerky + refresh: 30, + // Whether to fit the network view after when done + fit: true, + // Padding on fit + padding: 10, + // Whether to enable incremental mode + randomize: true, + // Node repulsion (non overlapping) multiplier + nodeRepulsion: 4500, + // Ideal edge (non nested) length + idealEdgeLength: 50, + // Divisor to compute edge forces + edgeElasticity: 0.45, + // Nesting factor (multiplier) to compute ideal edge length for nested edges + nestingFactor: 0.1, + // Gravity force (constant) + gravity: 0.25, + // Maximum number of iterations to perform + numIter: 2500, + // For enabling tiling + tile: true, + // Type of layout animation. The option set is {'during', 'end', false} + animate: "end", + // Duration for animate:end + animationDuration: 500, + // Represents the amount of the vertical space to put between the zero degree members during the tiling operation(can also be a function) + tilingPaddingVertical: 10, + // Represents the amount of the horizontal space to put between the zero degree members during the tiling operation(can also be a function) + tilingPaddingHorizontal: 10, + // Gravity range (constant) for compounds + gravityRangeCompound: 1.5, + // Gravity force (constant) for compounds + gravityCompound: 1, + // Gravity range (constant) + gravityRange: 3.8, + // Initial cooling factor for incremental layout + initialEnergyOnIncremental: 0.5 + }; + function extend2(defaults3, options2) { + var obj = {}; + for (var i2 in defaults3) { + obj[i2] = defaults3[i2]; + } + for (var i2 in options2) { + obj[i2] = options2[i2]; + } + return obj; + } + function _CoSELayout(_options) { + this.options = extend2(defaults2, _options); + getUserOptions(this.options); + } + var getUserOptions = function getUserOptions2(options2) { + if (options2.nodeRepulsion != null) + CoSEConstants.DEFAULT_REPULSION_STRENGTH = FDLayoutConstants.DEFAULT_REPULSION_STRENGTH = options2.nodeRepulsion; + if (options2.idealEdgeLength != null) + CoSEConstants.DEFAULT_EDGE_LENGTH = FDLayoutConstants.DEFAULT_EDGE_LENGTH = options2.idealEdgeLength; + if (options2.edgeElasticity != null) + CoSEConstants.DEFAULT_SPRING_STRENGTH = FDLayoutConstants.DEFAULT_SPRING_STRENGTH = options2.edgeElasticity; + if (options2.nestingFactor != null) + CoSEConstants.PER_LEVEL_IDEAL_EDGE_LENGTH_FACTOR = FDLayoutConstants.PER_LEVEL_IDEAL_EDGE_LENGTH_FACTOR = options2.nestingFactor; + if (options2.gravity != null) + CoSEConstants.DEFAULT_GRAVITY_STRENGTH = FDLayoutConstants.DEFAULT_GRAVITY_STRENGTH = options2.gravity; + if (options2.numIter != null) + CoSEConstants.MAX_ITERATIONS = FDLayoutConstants.MAX_ITERATIONS = options2.numIter; + if (options2.gravityRange != null) + CoSEConstants.DEFAULT_GRAVITY_RANGE_FACTOR = FDLayoutConstants.DEFAULT_GRAVITY_RANGE_FACTOR = options2.gravityRange; + if (options2.gravityCompound != null) + CoSEConstants.DEFAULT_COMPOUND_GRAVITY_STRENGTH = FDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_STRENGTH = options2.gravityCompound; + if (options2.gravityRangeCompound != null) + CoSEConstants.DEFAULT_COMPOUND_GRAVITY_RANGE_FACTOR = FDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_RANGE_FACTOR = options2.gravityRangeCompound; + if (options2.initialEnergyOnIncremental != null) + CoSEConstants.DEFAULT_COOLING_FACTOR_INCREMENTAL = FDLayoutConstants.DEFAULT_COOLING_FACTOR_INCREMENTAL = options2.initialEnergyOnIncremental; + if (options2.quality == "draft") + LayoutConstants.QUALITY = 0; + else if (options2.quality == "proof") + LayoutConstants.QUALITY = 2; + else + LayoutConstants.QUALITY = 1; + CoSEConstants.NODE_DIMENSIONS_INCLUDE_LABELS = FDLayoutConstants.NODE_DIMENSIONS_INCLUDE_LABELS = LayoutConstants.NODE_DIMENSIONS_INCLUDE_LABELS = options2.nodeDimensionsIncludeLabels; + CoSEConstants.DEFAULT_INCREMENTAL = FDLayoutConstants.DEFAULT_INCREMENTAL = LayoutConstants.DEFAULT_INCREMENTAL = !options2.randomize; + CoSEConstants.ANIMATE = FDLayoutConstants.ANIMATE = LayoutConstants.ANIMATE = options2.animate; + CoSEConstants.TILE = options2.tile; + CoSEConstants.TILING_PADDING_VERTICAL = typeof options2.tilingPaddingVertical === "function" ? options2.tilingPaddingVertical.call() : options2.tilingPaddingVertical; + CoSEConstants.TILING_PADDING_HORIZONTAL = typeof options2.tilingPaddingHorizontal === "function" ? options2.tilingPaddingHorizontal.call() : options2.tilingPaddingHorizontal; + }; + _CoSELayout.prototype.run = function() { + var ready; + var frameId; + var options2 = this.options; + this.idToLNode = {}; + var layout2 = this.layout = new CoSELayout(); + var self2 = this; + self2.stopped = false; + this.cy = this.options.cy; + this.cy.trigger({ type: "layoutstart", layout: this }); + var gm = layout2.newGraphManager(); + this.gm = gm; + var nodes2 = this.options.eles.nodes(); + var edges2 = this.options.eles.edges(); + this.root = gm.addRoot(); + this.processChildrenList(this.root, this.getTopMostNodes(nodes2), layout2); + for (var i2 = 0; i2 < edges2.length; i2++) { + var edge = edges2[i2]; + var sourceNode = this.idToLNode[edge.data("source")]; + var targetNode = this.idToLNode[edge.data("target")]; + if (sourceNode !== targetNode && sourceNode.getEdgesBetween(targetNode).length == 0) { + var e1 = gm.add(layout2.newEdge(), sourceNode, targetNode); + e1.id = edge.id(); + } + } + var getPositions = function getPositions2(ele, i3) { + if (typeof ele === "number") { + ele = i3; + } + var theId = ele.data("id"); + var lNode = self2.idToLNode[theId]; + return { + x: lNode.getRect().getCenterX(), + y: lNode.getRect().getCenterY() + }; + }; + var iterateAnimated = function iterateAnimated2() { + var afterReposition = function afterReposition2() { + if (options2.fit) { + options2.cy.fit(options2.eles, options2.padding); + } + if (!ready) { + ready = true; + self2.cy.one("layoutready", options2.ready); + self2.cy.trigger({ type: "layoutready", layout: self2 }); + } + }; + var ticksPerFrame = self2.options.refresh; + var isDone; + for (var i3 = 0; i3 < ticksPerFrame && !isDone; i3++) { + isDone = self2.stopped || self2.layout.tick(); + } + if (isDone) { + if (layout2.checkLayoutSuccess() && !layout2.isSubLayout) { + layout2.doPostLayout(); + } + if (layout2.tilingPostLayout) { + layout2.tilingPostLayout(); + } + layout2.isLayoutFinished = true; + self2.options.eles.nodes().positions(getPositions); + afterReposition(); + self2.cy.one("layoutstop", self2.options.stop); + self2.cy.trigger({ type: "layoutstop", layout: self2 }); + if (frameId) { + cancelAnimationFrame(frameId); + } + ready = false; + return; + } + var animationData = self2.layout.getPositionsData(); + options2.eles.nodes().positions(function(ele, i4) { + if (typeof ele === "number") { + ele = i4; + } + if (!ele.isParent()) { + var theId = ele.id(); + var pNode = animationData[theId]; + var temp = ele; + while (pNode == null) { + pNode = animationData[temp.data("parent")] || animationData["DummyCompound_" + temp.data("parent")]; + animationData[theId] = pNode; + temp = temp.parent()[0]; + if (temp == void 0) { + break; + } + } + if (pNode != null) { + return { + x: pNode.x, + y: pNode.y + }; + } else { + return { + x: ele.position("x"), + y: ele.position("y") + }; + } + } + }); + afterReposition(); + frameId = requestAnimationFrame(iterateAnimated2); + }; + layout2.addListener("layoutstarted", function() { + if (self2.options.animate === "during") { + frameId = requestAnimationFrame(iterateAnimated); + } + }); + layout2.runLayout(); + if (this.options.animate !== "during") { + self2.options.eles.nodes().not(":parent").layoutPositions(self2, self2.options, getPositions); + ready = false; + } + return this; + }; + _CoSELayout.prototype.getTopMostNodes = function(nodes2) { + var nodesMap2 = {}; + for (var i2 = 0; i2 < nodes2.length; i2++) { + nodesMap2[nodes2[i2].id()] = true; + } + var roots = nodes2.filter(function(ele, i3) { + if (typeof ele === "number") { + ele = i3; + } + var parent = ele.parent()[0]; + while (parent != null) { + if (nodesMap2[parent.id()]) { + return false; + } + parent = parent.parent()[0]; + } + return true; + }); + return roots; + }; + _CoSELayout.prototype.processChildrenList = function(parent, children2, layout2) { + var size2 = children2.length; + for (var i2 = 0; i2 < size2; i2++) { + var theChild = children2[i2]; + var children_of_children = theChild.children(); + var theNode; + var dimensions = theChild.layoutDimensions({ + nodeDimensionsIncludeLabels: this.options.nodeDimensionsIncludeLabels + }); + if (theChild.outerWidth() != null && theChild.outerHeight() != null) { + theNode = parent.add(new CoSENode(layout2.graphManager, new PointD(theChild.position("x") - dimensions.w / 2, theChild.position("y") - dimensions.h / 2), new DimensionD2(parseFloat(dimensions.w), parseFloat(dimensions.h)))); + } else { + theNode = parent.add(new CoSENode(this.graphManager)); + } + theNode.id = theChild.data("id"); + theNode.paddingLeft = parseInt(theChild.css("padding")); + theNode.paddingTop = parseInt(theChild.css("padding")); + theNode.paddingRight = parseInt(theChild.css("padding")); + theNode.paddingBottom = parseInt(theChild.css("padding")); + if (this.options.nodeDimensionsIncludeLabels) { + if (theChild.isParent()) { + var labelWidth = theChild.boundingBox({ includeLabels: true, includeNodes: false }).w; + var labelHeight = theChild.boundingBox({ includeLabels: true, includeNodes: false }).h; + var labelPos = theChild.css("text-halign"); + theNode.labelWidth = labelWidth; + theNode.labelHeight = labelHeight; + theNode.labelPos = labelPos; + } + } + this.idToLNode[theChild.data("id")] = theNode; + if (isNaN(theNode.rect.x)) { + theNode.rect.x = 0; + } + if (isNaN(theNode.rect.y)) { + theNode.rect.y = 0; + } + if (children_of_children != null && children_of_children.length > 0) { + var theNewGraph; + theNewGraph = layout2.getGraphManager().add(layout2.newGraph(), theNode); + this.processChildrenList(theNewGraph, children_of_children, layout2); + } + } + }; + _CoSELayout.prototype.stop = function() { + this.stopped = true; + return this; + }; + var register = function register2(cytoscape2) { + cytoscape2("layout", "cose-bilkent", _CoSELayout); + }; + if (typeof cytoscape !== "undefined") { + register(cytoscape); + } + module3.exports = register; + } + /******/ + ]) + ); + }); + })(cytoscapeCoseBilkent); + var cytoscapeCoseBilkentExports = cytoscapeCoseBilkent.exports; + const coseBilkent = /* @__PURE__ */ getDefaultExportFromCjs(cytoscapeCoseBilkentExports); + const MAX_SECTIONS = 12; + const defaultBkg = function(db2, elem, node2, section) { + const rd = 5; + elem.append("path").attr("id", "node-" + node2.id).attr("class", "node-bkg node-" + db2.type2Str(node2.type)).attr( + "d", + `M0 ${node2.height - rd} v${-node2.height + 2 * rd} q0,-5 5,-5 h${node2.width - 2 * rd} q5,0 5,5 v${node2.height - rd} H0 Z` + ); + elem.append("line").attr("class", "node-line-" + section).attr("x1", 0).attr("y1", node2.height).attr("x2", node2.width).attr("y2", node2.height); + }; + const rectBkg = function(db2, elem, node2) { + elem.append("rect").attr("id", "node-" + node2.id).attr("class", "node-bkg node-" + db2.type2Str(node2.type)).attr("height", node2.height).attr("width", node2.width); + }; + const cloudBkg = function(db2, elem, node2) { + const w2 = node2.width; + const h = node2.height; + const r1 = 0.15 * w2; + const r2 = 0.25 * w2; + const r3 = 0.35 * w2; + const r4 = 0.2 * w2; + elem.append("path").attr("id", "node-" + node2.id).attr("class", "node-bkg node-" + db2.type2Str(node2.type)).attr( + "d", + `M0 0 a${r1},${r1} 0 0,1 ${w2 * 0.25},${-1 * w2 * 0.1} + a${r3},${r3} 1 0,1 ${w2 * 0.4},${-1 * w2 * 0.1} + a${r2},${r2} 1 0,1 ${w2 * 0.35},${1 * w2 * 0.2} + + a${r1},${r1} 1 0,1 ${w2 * 0.15},${1 * h * 0.35} + a${r4},${r4} 1 0,1 ${-1 * w2 * 0.15},${1 * h * 0.65} + + a${r2},${r1} 1 0,1 ${-1 * w2 * 0.25},${w2 * 0.15} + a${r3},${r3} 1 0,1 ${-1 * w2 * 0.5},${0} + a${r1},${r1} 1 0,1 ${-1 * w2 * 0.25},${-1 * w2 * 0.15} + + a${r1},${r1} 1 0,1 ${-1 * w2 * 0.1},${-1 * h * 0.35} + a${r4},${r4} 1 0,1 ${w2 * 0.1},${-1 * h * 0.65} + + H0 V0 Z` + ); + }; + const bangBkg = function(db2, elem, node2) { + const w2 = node2.width; + const h = node2.height; + const r = 0.15 * w2; + elem.append("path").attr("id", "node-" + node2.id).attr("class", "node-bkg node-" + db2.type2Str(node2.type)).attr( + "d", + `M0 0 a${r},${r} 1 0,0 ${w2 * 0.25},${-1 * h * 0.1} + a${r},${r} 1 0,0 ${w2 * 0.25},${0} + a${r},${r} 1 0,0 ${w2 * 0.25},${0} + a${r},${r} 1 0,0 ${w2 * 0.25},${1 * h * 0.1} + + a${r},${r} 1 0,0 ${w2 * 0.15},${1 * h * 0.33} + a${r * 0.8},${r * 0.8} 1 0,0 ${0},${1 * h * 0.34} + a${r},${r} 1 0,0 ${-1 * w2 * 0.15},${1 * h * 0.33} + + a${r},${r} 1 0,0 ${-1 * w2 * 0.25},${h * 0.15} + a${r},${r} 1 0,0 ${-1 * w2 * 0.25},${0} + a${r},${r} 1 0,0 ${-1 * w2 * 0.25},${0} + a${r},${r} 1 0,0 ${-1 * w2 * 0.25},${-1 * h * 0.15} + + a${r},${r} 1 0,0 ${-1 * w2 * 0.1},${-1 * h * 0.33} + a${r * 0.8},${r * 0.8} 1 0,0 ${0},${-1 * h * 0.34} + a${r},${r} 1 0,0 ${w2 * 0.1},${-1 * h * 0.33} + + H0 V0 Z` + ); + }; + const circleBkg = function(db2, elem, node2) { + elem.append("circle").attr("id", "node-" + node2.id).attr("class", "node-bkg node-" + db2.type2Str(node2.type)).attr("r", node2.width / 2); + }; + function insertPolygonShape(parent, w2, h, points, node2) { + return parent.insert("polygon", ":first-child").attr( + "points", + points.map(function(d) { + return d.x + "," + d.y; + }).join(" ") + ).attr("transform", "translate(" + (node2.width - w2) / 2 + ", " + h + ")"); + } + const hexagonBkg = function(_db, elem, node2) { + const h = node2.height; + const f2 = 4; + const m = h / f2; + const w2 = node2.width - node2.padding + 2 * m; + const points = [ + { x: m, y: 0 }, + { x: w2 - m, y: 0 }, + { x: w2, y: -h / 2 }, + { x: w2 - m, y: -h }, + { x: m, y: -h }, + { x: 0, y: -h / 2 } + ]; + insertPolygonShape(elem, w2, h, points, node2); + }; + const roundedRectBkg = function(db2, elem, node2) { + elem.append("rect").attr("id", "node-" + node2.id).attr("class", "node-bkg node-" + db2.type2Str(node2.type)).attr("height", node2.height).attr("rx", node2.padding).attr("ry", node2.padding).attr("width", node2.width); + }; + const drawNode = function(db2, elem, node2, fullSection, conf2) { + const htmlLabels = conf2.htmlLabels; + const section = fullSection % (MAX_SECTIONS - 1); + const nodeElem = elem.append("g"); + node2.section = section; + let sectionClass = "section-" + section; + if (section < 0) { + sectionClass += " section-root"; + } + nodeElem.attr("class", (node2.class ? node2.class + " " : "") + "mindmap-node " + sectionClass); + const bkgElem = nodeElem.append("g"); + const textElem = nodeElem.append("g"); + const description = node2.descr.replace(/()/g, "\n"); + createText(textElem, description, { + useHtmlLabels: htmlLabels, + width: node2.width, + classes: "mindmap-node-label" + }); + if (!htmlLabels) { + textElem.attr("dy", "1em").attr("alignment-baseline", "middle").attr("dominant-baseline", "middle").attr("text-anchor", "middle"); + } + const bbox = textElem.node().getBBox(); + const [fontSize] = parseFontSize(conf2.fontSize); + node2.height = bbox.height + fontSize * 1.1 * 0.5 + node2.padding; + node2.width = bbox.width + 2 * node2.padding; + if (node2.icon) { + if (node2.type === db2.nodeType.CIRCLE) { + node2.height += 50; + node2.width += 50; + const icon = nodeElem.append("foreignObject").attr("height", "50px").attr("width", node2.width).attr("style", "text-align: center;"); + icon.append("div").attr("class", "icon-container").append("i").attr("class", "node-icon-" + section + " " + node2.icon); + textElem.attr( + "transform", + "translate(" + node2.width / 2 + ", " + (node2.height / 2 - 1.5 * node2.padding) + ")" + ); + } else { + node2.width += 50; + const orgHeight = node2.height; + node2.height = Math.max(orgHeight, 60); + const heightDiff = Math.abs(node2.height - orgHeight); + const icon = nodeElem.append("foreignObject").attr("width", "60px").attr("height", node2.height).attr("style", "text-align: center;margin-top:" + heightDiff / 2 + "px;"); + icon.append("div").attr("class", "icon-container").append("i").attr("class", "node-icon-" + section + " " + node2.icon); + textElem.attr( + "transform", + "translate(" + (25 + node2.width / 2) + ", " + (heightDiff / 2 + node2.padding / 2) + ")" + ); + } + } else { + if (!htmlLabels) { + const dx = node2.width / 2; + const dy = node2.padding / 2; + textElem.attr("transform", "translate(" + dx + ", " + dy + ")"); + } else { + const dx = (node2.width - bbox.width) / 2; + const dy = (node2.height - bbox.height) / 2; + textElem.attr("transform", "translate(" + dx + ", " + dy + ")"); + } + } + switch (node2.type) { + case db2.nodeType.DEFAULT: + defaultBkg(db2, bkgElem, node2, section); + break; + case db2.nodeType.ROUNDED_RECT: + roundedRectBkg(db2, bkgElem, node2); + break; + case db2.nodeType.RECT: + rectBkg(db2, bkgElem, node2); + break; + case db2.nodeType.CIRCLE: + bkgElem.attr("transform", "translate(" + node2.width / 2 + ", " + +node2.height / 2 + ")"); + circleBkg(db2, bkgElem, node2); + break; + case db2.nodeType.CLOUD: + cloudBkg(db2, bkgElem, node2); + break; + case db2.nodeType.BANG: + bangBkg(db2, bkgElem, node2); + break; + case db2.nodeType.HEXAGON: + hexagonBkg(db2, bkgElem, node2); + break; + } + db2.setElementForId(node2.id, nodeElem); + return node2.height; + }; + const positionNode = function(db2, node2) { + const nodeElem = db2.getElementById(node2.id); + const x2 = node2.x || 0; + const y2 = node2.y || 0; + nodeElem.attr("transform", "translate(" + x2 + "," + y2 + ")"); + }; + cytoscape$1.use(coseBilkent); + function drawNodes(db2, svg2, mindmap2, section, conf2) { + drawNode(db2, svg2, mindmap2, section, conf2); + if (mindmap2.children) { + mindmap2.children.forEach((child, index2) => { + drawNodes(db2, svg2, child, section < 0 ? index2 : section, conf2); + }); + } + } + function drawEdges(edgesEl, cy) { + cy.edges().map((edge, id2) => { + const data = edge.data(); + if (edge[0]._private.bodyBounds) { + const bounds2 = edge[0]._private.rscratch; + log$1.trace("Edge: ", id2, data); + edgesEl.insert("path").attr( + "d", + `M ${bounds2.startX},${bounds2.startY} L ${bounds2.midX},${bounds2.midY} L${bounds2.endX},${bounds2.endY} ` + ).attr("class", "edge section-edge-" + data.section + " edge-depth-" + data.depth); + } + }); + } + function addNodes(mindmap2, cy, conf2, level) { + cy.add({ + group: "nodes", + data: { + id: mindmap2.id.toString(), + labelText: mindmap2.descr, + height: mindmap2.height, + width: mindmap2.width, + level, + nodeId: mindmap2.id, + padding: mindmap2.padding, + type: mindmap2.type + }, + position: { + x: mindmap2.x, + y: mindmap2.y + } + }); + if (mindmap2.children) { + mindmap2.children.forEach((child) => { + addNodes(child, cy, conf2, level + 1); + cy.add({ + group: "edges", + data: { + id: `${mindmap2.id}_${child.id}`, + source: mindmap2.id, + target: child.id, + depth: level, + section: child.section + } + }); + }); + } + } + function layoutMindmap(node2, conf2) { + return new Promise((resolve) => { + const renderEl = d3select("body").append("div").attr("id", "cy").attr("style", "display:none"); + const cy = cytoscape$1({ + container: document.getElementById("cy"), + // container to render in + style: [ + { + selector: "edge", + style: { + "curve-style": "bezier" + } + } + ] + }); + renderEl.remove(); + addNodes(node2, cy, conf2, 0); + cy.nodes().forEach(function(n) { + n.layoutDimensions = () => { + const data = n.data(); + return { w: data.width, h: data.height }; + }; + }); + cy.layout({ + name: "cose-bilkent", + // @ts-ignore Types for cose-bilkent are not correct? + quality: "proof", + styleEnabled: false, + animate: false + }).run(); + cy.ready((e) => { + log$1.info("Ready", e); + resolve(cy); + }); + }); + } + function positionNodes(db2, cy) { + cy.nodes().map((node2, id2) => { + const data = node2.data(); + data.x = node2.position().x; + data.y = node2.position().y; + positionNode(db2, data); + const el = db2.getElementById(data.nodeId); + log$1.info("Id:", id2, "Position: (", node2.position().x, ", ", node2.position().y, ")", data); + el.attr( + "transform", + `translate(${node2.position().x - data.width / 2}, ${node2.position().y - data.height / 2})` + ); + el.attr("attr", `apa-${id2})`); + }); + } + const draw$2 = async (text2, id2, _version, diagObj) => { + var _a2, _b2; + log$1.debug("Rendering mindmap diagram\n" + text2); + const db2 = diagObj.db; + const mm = db2.getMindmap(); + if (!mm) { + return; + } + const conf2 = getConfig$1(); + conf2.htmlLabels = false; + const svg2 = selectSvgElement(id2); + const edgesElem = svg2.append("g"); + edgesElem.attr("class", "mindmap-edges"); + const nodesElem = svg2.append("g"); + nodesElem.attr("class", "mindmap-nodes"); + drawNodes(db2, nodesElem, mm, -1, conf2); + const cy = await layoutMindmap(mm, conf2); + drawEdges(edgesElem, cy); + positionNodes(db2, cy); + setupGraphViewbox$1( + void 0, + svg2, + ((_a2 = conf2.mindmap) == null ? void 0 : _a2.padding) ?? defaultConfig$2.mindmap.padding, + ((_b2 = conf2.mindmap) == null ? void 0 : _b2.useMaxWidth) ?? defaultConfig$2.mindmap.useMaxWidth + ); + }; + const renderer$2 = { + draw: draw$2 + }; + const genSections = (options2) => { + let sections2 = ""; + for (let i2 = 0; i2 < options2.THEME_COLOR_LIMIT; i2++) { + options2["lineColor" + i2] = options2["lineColor" + i2] || options2["cScaleInv" + i2]; + if (isDark$1(options2["lineColor" + i2])) { + options2["lineColor" + i2] = lighten$1(options2["lineColor" + i2], 20); + } else { + options2["lineColor" + i2] = darken$1(options2["lineColor" + i2], 20); + } + } + for (let i2 = 0; i2 < options2.THEME_COLOR_LIMIT; i2++) { + const sw = "" + (17 - 3 * i2); + sections2 += ` + .section-${i2 - 1} rect, .section-${i2 - 1} path, .section-${i2 - 1} circle, .section-${i2 - 1} polygon, .section-${i2 - 1} path { + fill: ${options2["cScale" + i2]}; + } + .section-${i2 - 1} text { + fill: ${options2["cScaleLabel" + i2]}; + } + .node-icon-${i2 - 1} { + font-size: 40px; + color: ${options2["cScaleLabel" + i2]}; + } + .section-edge-${i2 - 1}{ + stroke: ${options2["cScale" + i2]}; + } + .edge-depth-${i2 - 1}{ + stroke-width: ${sw}; + } + .section-${i2 - 1} line { + stroke: ${options2["cScaleInv" + i2]} ; + stroke-width: 3; + } + + .disabled, .disabled circle, .disabled text { + fill: lightgray; + } + .disabled text { + fill: #efefef; + } + `; + } + return sections2; + }; + const getStyles$1 = (options2) => ` + .edge { + stroke-width: 3; + } + ${genSections(options2)} + .section-root rect, .section-root path, .section-root circle, .section-root polygon { + fill: ${options2.git0}; + } + .section-root text { + fill: ${options2.gitBranchLabel0}; + } + .icon-container { + height:100%; + display: flex; + justify-content: center; + align-items: center; + } + .edge { + fill: none; + } + .mindmap-node-label { + dy: 1em; + alignment-baseline: middle; + text-anchor: middle; + dominant-baseline: middle; + text-align: center; + } +`; + const styles = getStyles$1; + const diagram$2 = { + db: db$4, + renderer: renderer$2, + parser: parser$5, + styles + }; + const mindmapDefinition = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + diagram: diagram$2 + }, Symbol.toStringTag, { value: "Module" })); + var parser$2 = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 9], $V1 = [1, 10], $V2 = [1, 5, 10, 12]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "SANKEY": 4, "NEWLINE": 5, "csv": 6, "opt_eof": 7, "record": 8, "csv_tail": 9, "EOF": 10, "field[source]": 11, "COMMA": 12, "field[target]": 13, "field[value]": 14, "field": 15, "escaped": 16, "non_escaped": 17, "DQUOTE": 18, "ESCAPED_TEXT": 19, "NON_ESCAPED_TEXT": 20, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 4: "SANKEY", 5: "NEWLINE", 10: "EOF", 11: "field[source]", 12: "COMMA", 13: "field[target]", 14: "field[value]", 18: "DQUOTE", 19: "ESCAPED_TEXT", 20: "NON_ESCAPED_TEXT" }, + productions_: [0, [3, 4], [6, 2], [9, 2], [9, 0], [7, 1], [7, 0], [8, 5], [15, 1], [15, 1], [16, 3], [17, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 7: + const source = yy.findOrCreateNode($$[$0 - 4].trim().replaceAll('""', '"')); + const target = yy.findOrCreateNode($$[$0 - 2].trim().replaceAll('""', '"')); + const value2 = parseFloat($$[$0].trim()); + yy.addLink(source, target, value2); + break; + case 8: + case 9: + case 11: + this.$ = $$[$0]; + break; + case 10: + this.$ = $$[$0 - 1]; + break; + } + }, + table: [{ 3: 1, 4: [1, 2] }, { 1: [3] }, { 5: [1, 3] }, { 6: 4, 8: 5, 15: 6, 16: 7, 17: 8, 18: $V0, 20: $V1 }, { 1: [2, 6], 7: 11, 10: [1, 12] }, o($V1, [2, 4], { 9: 13, 5: [1, 14] }), { 12: [1, 15] }, o($V2, [2, 8]), o($V2, [2, 9]), { 19: [1, 16] }, o($V2, [2, 11]), { 1: [2, 1] }, { 1: [2, 5] }, o($V1, [2, 2]), { 6: 17, 8: 5, 15: 6, 16: 7, 17: 8, 18: $V0, 20: $V1 }, { 15: 18, 16: 7, 17: 8, 18: $V0, 20: $V1 }, { 18: [1, 19] }, o($V1, [2, 3]), { 12: [1, 20] }, o($V2, [2, 10]), { 15: 21, 16: 7, 17: 8, 18: $V0, 20: $V1 }, o([1, 5, 10], [2, 7])], + defaultActions: { 11: [2, 1], 12: [2, 5] }, + parseError: function parseError(str2, hash) { + if (hash.recoverable) { + this.trace(str2); + } else { + var error = new Error(str2); + error.hash = hash; + throw error; + } + }, + parse: function parse2(input) { + var self2 = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex2() { + var token2; + token2 = tstack.pop() || lexer2.lex() || EOF; + if (typeof token2 !== "number") { + if (token2 instanceof Array) { + tstack = token2; + token2 = tstack.pop(); + } + token2 = self2.symbols_[token2] || token2; + } + return token2; + } + var symbol, state2, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state2 = stack[stack.length - 1]; + if (this.defaultActions[state2]) { + action = this.defaultActions[state2]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex2(); + } + action = table[state2] && table[state2][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state2]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state2 + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str2, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str2, hash); + } else { + throw new Error(str2); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch2 = this._input[0]; + this.yytext += ch2; + this.yyleng++; + this.offset++; + this.match += ch2; + this.matched += ch2; + var lines = ch2.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch2; + }, + // unshifts one char (or a string) into the input + unput: function(ch2) { + var len = ch2.length; + var lines = ch2.split(/(?:\r\n?|\n)/g); + this._input = ch2 + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next2 = this.match; + if (next2.length < 20) { + next2 += this._input.substr(0, 20 - next2.length); + } + return (next2.substr(0, 20) + (next2.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c2 = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c2 + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token2, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token2 = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token2) { + return token2; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token2, match, tempMatch, index2; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i2 = 0; i2 < rules.length; i2++) { + tempMatch = this._input.match(this.rules[rules[i2]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index2 = i2; + if (this.options.backtrack_lexer) { + token2 = this.test_match(tempMatch, rules[i2]); + if (token2 !== false) { + return token2; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token2 = this.test_match(match, rules[index2]); + if (token2 !== false) { + return token2; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex2() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + this.pushState("csv"); + return 4; + case 1: + return 10; + case 2: + return 5; + case 3: + return 12; + case 4: + this.pushState("escaped_text"); + return 18; + case 5: + return 20; + case 6: + this.popState("escaped_text"); + return 18; + case 7: + return 19; + } + }, + rules: [/^(?:sankey-beta\b)/i, /^(?:$)/i, /^(?:((\u000D\u000A)|(\u000A)))/i, /^(?:(\u002C))/i, /^(?:(\u0022))/i, /^(?:([\u0020-\u0021\u0023-\u002B\u002D-\u007E])*)/i, /^(?:(\u0022)(?!(\u0022)))/i, /^(?:(([\u0020-\u0021\u0023-\u002B\u002D-\u007E])|(\u002C)|(\u000D)|(\u000A)|(\u0022)(\u0022))*)/i], + conditions: { "csv": { "rules": [1, 2, 3, 4, 5, 6, 7], "inclusive": false }, "escaped_text": { "rules": [6, 7], "inclusive": false }, "INITIAL": { "rules": [0, 1, 2, 3, 4, 5, 6, 7], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser2() { + this.yy = {}; + } + Parser2.prototype = parser2; + parser2.Parser = Parser2; + return new Parser2(); + }(); + parser$2.parser = parser$2; + const parser$3 = parser$2; + let links = []; + let nodes = []; + let nodesMap = {}; + const clear$1 = () => { + links = []; + nodes = []; + nodesMap = {}; + clear$n(); + }; + class SankeyLink { + constructor(source, target, value2 = 0) { + this.source = source; + this.target = target; + this.value = value2; + } + } + const addLink = (source, target, value2) => { + links.push(new SankeyLink(source, target, value2)); + }; + class SankeyNode { + constructor(ID) { + this.ID = ID; + } + } + const findOrCreateNode = (ID) => { + ID = common$1.sanitizeText(ID, getConfig$1()); + if (!nodesMap[ID]) { + nodesMap[ID] = new SankeyNode(ID); + nodes.push(nodesMap[ID]); + } + return nodesMap[ID]; + }; + const getNodes = () => nodes; + const getLinks = () => links; + const getGraph = () => ({ + nodes: nodes.map((node2) => ({ id: node2.ID })), + links: links.map((link2) => ({ + source: link2.source.ID, + target: link2.target.ID, + value: link2.value + })) + }); + const db$2 = { + nodesMap, + getConfig: () => getConfig$1().sankey, + getNodes, + getLinks, + getGraph, + addLink, + findOrCreateNode, + getAccTitle, + setAccTitle, + getAccDescription, + setAccDescription, + getDiagramTitle, + setDiagramTitle, + clear: clear$1 + }; + function max(values2, valueof) { + let max2; + if (valueof === void 0) { + for (const value2 of values2) { + if (value2 != null && (max2 < value2 || max2 === void 0 && value2 >= value2)) { + max2 = value2; + } + } + } else { + let index2 = -1; + for (let value2 of values2) { + if ((value2 = valueof(value2, ++index2, values2)) != null && (max2 < value2 || max2 === void 0 && value2 >= value2)) { + max2 = value2; + } + } + } + return max2; + } + function min(values2, valueof) { + let min2; + if (valueof === void 0) { + for (const value2 of values2) { + if (value2 != null && (min2 > value2 || min2 === void 0 && value2 >= value2)) { + min2 = value2; + } + } + } else { + let index2 = -1; + for (let value2 of values2) { + if ((value2 = valueof(value2, ++index2, values2)) != null && (min2 > value2 || min2 === void 0 && value2 >= value2)) { + min2 = value2; + } + } + } + return min2; + } + function sum(values2, valueof) { + let sum2 = 0; + if (valueof === void 0) { + for (let value2 of values2) { + if (value2 = +value2) { + sum2 += value2; + } + } + } else { + let index2 = -1; + for (let value2 of values2) { + if (value2 = +valueof(value2, ++index2, values2)) { + sum2 += value2; + } + } + } + return sum2; + } + function targetDepth(d) { + return d.target.depth; + } + function left(node2) { + return node2.depth; + } + function right(node2, n) { + return n - 1 - node2.height; + } + function justify(node2, n) { + return node2.sourceLinks.length ? node2.depth : n - 1; + } + function center(node2) { + return node2.targetLinks.length ? node2.depth : node2.sourceLinks.length ? min(node2.sourceLinks, targetDepth) - 1 : 0; + } + function constant$1(x2) { + return function() { + return x2; + }; + } + function ascendingSourceBreadth(a, b) { + return ascendingBreadth(a.source, b.source) || a.index - b.index; + } + function ascendingTargetBreadth(a, b) { + return ascendingBreadth(a.target, b.target) || a.index - b.index; + } + function ascendingBreadth(a, b) { + return a.y0 - b.y0; + } + function value(d) { + return d.value; + } + function defaultId(d) { + return d.index; + } + function defaultNodes(graph) { + return graph.nodes; + } + function defaultLinks(graph) { + return graph.links; + } + function find(nodeById, id2) { + const node2 = nodeById.get(id2); + if (!node2) + throw new Error("missing: " + id2); + return node2; + } + function computeLinkBreadths({ nodes: nodes2 }) { + for (const node2 of nodes2) { + let y0 = node2.y0; + let y1 = y0; + for (const link2 of node2.sourceLinks) { + link2.y0 = y0 + link2.width / 2; + y0 += link2.width; + } + for (const link2 of node2.targetLinks) { + link2.y1 = y1 + link2.width / 2; + y1 += link2.width; + } + } + } + function Sankey() { + let x0 = 0, y0 = 0, x1 = 1, y1 = 1; + let dx = 24; + let dy = 8, py; + let id2 = defaultId; + let align = justify; + let sort2; + let linkSort; + let nodes2 = defaultNodes; + let links2 = defaultLinks; + let iterations = 6; + function sankey2() { + const graph = { nodes: nodes2.apply(null, arguments), links: links2.apply(null, arguments) }; + computeNodeLinks(graph); + computeNodeValues(graph); + computeNodeDepths(graph); + computeNodeHeights(graph); + computeNodeBreadths(graph); + computeLinkBreadths(graph); + return graph; + } + sankey2.update = function(graph) { + computeLinkBreadths(graph); + return graph; + }; + sankey2.nodeId = function(_2) { + return arguments.length ? (id2 = typeof _2 === "function" ? _2 : constant$1(_2), sankey2) : id2; + }; + sankey2.nodeAlign = function(_2) { + return arguments.length ? (align = typeof _2 === "function" ? _2 : constant$1(_2), sankey2) : align; + }; + sankey2.nodeSort = function(_2) { + return arguments.length ? (sort2 = _2, sankey2) : sort2; + }; + sankey2.nodeWidth = function(_2) { + return arguments.length ? (dx = +_2, sankey2) : dx; + }; + sankey2.nodePadding = function(_2) { + return arguments.length ? (dy = py = +_2, sankey2) : dy; + }; + sankey2.nodes = function(_2) { + return arguments.length ? (nodes2 = typeof _2 === "function" ? _2 : constant$1(_2), sankey2) : nodes2; + }; + sankey2.links = function(_2) { + return arguments.length ? (links2 = typeof _2 === "function" ? _2 : constant$1(_2), sankey2) : links2; + }; + sankey2.linkSort = function(_2) { + return arguments.length ? (linkSort = _2, sankey2) : linkSort; + }; + sankey2.size = function(_2) { + return arguments.length ? (x0 = y0 = 0, x1 = +_2[0], y1 = +_2[1], sankey2) : [x1 - x0, y1 - y0]; + }; + sankey2.extent = function(_2) { + return arguments.length ? (x0 = +_2[0][0], x1 = +_2[1][0], y0 = +_2[0][1], y1 = +_2[1][1], sankey2) : [[x0, y0], [x1, y1]]; + }; + sankey2.iterations = function(_2) { + return arguments.length ? (iterations = +_2, sankey2) : iterations; + }; + function computeNodeLinks({ nodes: nodes3, links: links3 }) { + for (const [i2, node2] of nodes3.entries()) { + node2.index = i2; + node2.sourceLinks = []; + node2.targetLinks = []; + } + const nodeById = new Map(nodes3.map((d, i2) => [id2(d, i2, nodes3), d])); + for (const [i2, link2] of links3.entries()) { + link2.index = i2; + let { source, target } = link2; + if (typeof source !== "object") + source = link2.source = find(nodeById, source); + if (typeof target !== "object") + target = link2.target = find(nodeById, target); + source.sourceLinks.push(link2); + target.targetLinks.push(link2); + } + if (linkSort != null) { + for (const { sourceLinks, targetLinks } of nodes3) { + sourceLinks.sort(linkSort); + targetLinks.sort(linkSort); + } + } + } + function computeNodeValues({ nodes: nodes3 }) { + for (const node2 of nodes3) { + node2.value = node2.fixedValue === void 0 ? Math.max(sum(node2.sourceLinks, value), sum(node2.targetLinks, value)) : node2.fixedValue; + } + } + function computeNodeDepths({ nodes: nodes3 }) { + const n = nodes3.length; + let current = new Set(nodes3); + let next2 = /* @__PURE__ */ new Set(); + let x2 = 0; + while (current.size) { + for (const node2 of current) { + node2.depth = x2; + for (const { target } of node2.sourceLinks) { + next2.add(target); + } + } + if (++x2 > n) + throw new Error("circular link"); + current = next2; + next2 = /* @__PURE__ */ new Set(); + } + } + function computeNodeHeights({ nodes: nodes3 }) { + const n = nodes3.length; + let current = new Set(nodes3); + let next2 = /* @__PURE__ */ new Set(); + let x2 = 0; + while (current.size) { + for (const node2 of current) { + node2.height = x2; + for (const { source } of node2.targetLinks) { + next2.add(source); + } + } + if (++x2 > n) + throw new Error("circular link"); + current = next2; + next2 = /* @__PURE__ */ new Set(); + } + } + function computeNodeLayers({ nodes: nodes3 }) { + const x2 = max(nodes3, (d) => d.depth) + 1; + const kx = (x1 - x0 - dx) / (x2 - 1); + const columns = new Array(x2); + for (const node2 of nodes3) { + const i2 = Math.max(0, Math.min(x2 - 1, Math.floor(align.call(null, node2, x2)))); + node2.layer = i2; + node2.x0 = x0 + i2 * kx; + node2.x1 = node2.x0 + dx; + if (columns[i2]) + columns[i2].push(node2); + else + columns[i2] = [node2]; + } + if (sort2) + for (const column2 of columns) { + column2.sort(sort2); + } + return columns; + } + function initializeNodeBreadths(columns) { + const ky = min(columns, (c2) => (y1 - y0 - (c2.length - 1) * py) / sum(c2, value)); + for (const nodes3 of columns) { + let y2 = y0; + for (const node2 of nodes3) { + node2.y0 = y2; + node2.y1 = y2 + node2.value * ky; + y2 = node2.y1 + py; + for (const link2 of node2.sourceLinks) { + link2.width = link2.value * ky; + } + } + y2 = (y1 - y2 + py) / (nodes3.length + 1); + for (let i2 = 0; i2 < nodes3.length; ++i2) { + const node2 = nodes3[i2]; + node2.y0 += y2 * (i2 + 1); + node2.y1 += y2 * (i2 + 1); + } + reorderLinks(nodes3); + } + } + function computeNodeBreadths(graph) { + const columns = computeNodeLayers(graph); + py = Math.min(dy, (y1 - y0) / (max(columns, (c2) => c2.length) - 1)); + initializeNodeBreadths(columns); + for (let i2 = 0; i2 < iterations; ++i2) { + const alpha = Math.pow(0.99, i2); + const beta = Math.max(1 - alpha, (i2 + 1) / iterations); + relaxRightToLeft(columns, alpha, beta); + relaxLeftToRight(columns, alpha, beta); + } + } + function relaxLeftToRight(columns, alpha, beta) { + for (let i2 = 1, n = columns.length; i2 < n; ++i2) { + const column2 = columns[i2]; + for (const target of column2) { + let y2 = 0; + let w2 = 0; + for (const { source, value: value2 } of target.targetLinks) { + let v = value2 * (target.layer - source.layer); + y2 += targetTop(source, target) * v; + w2 += v; + } + if (!(w2 > 0)) + continue; + let dy2 = (y2 / w2 - target.y0) * alpha; + target.y0 += dy2; + target.y1 += dy2; + reorderNodeLinks(target); + } + if (sort2 === void 0) + column2.sort(ascendingBreadth); + resolveCollisions(column2, beta); + } + } + function relaxRightToLeft(columns, alpha, beta) { + for (let n = columns.length, i2 = n - 2; i2 >= 0; --i2) { + const column2 = columns[i2]; + for (const source of column2) { + let y2 = 0; + let w2 = 0; + for (const { target, value: value2 } of source.sourceLinks) { + let v = value2 * (target.layer - source.layer); + y2 += sourceTop(source, target) * v; + w2 += v; + } + if (!(w2 > 0)) + continue; + let dy2 = (y2 / w2 - source.y0) * alpha; + source.y0 += dy2; + source.y1 += dy2; + reorderNodeLinks(source); + } + if (sort2 === void 0) + column2.sort(ascendingBreadth); + resolveCollisions(column2, beta); + } + } + function resolveCollisions(nodes3, alpha) { + const i2 = nodes3.length >> 1; + const subject = nodes3[i2]; + resolveCollisionsBottomToTop(nodes3, subject.y0 - py, i2 - 1, alpha); + resolveCollisionsTopToBottom(nodes3, subject.y1 + py, i2 + 1, alpha); + resolveCollisionsBottomToTop(nodes3, y1, nodes3.length - 1, alpha); + resolveCollisionsTopToBottom(nodes3, y0, 0, alpha); + } + function resolveCollisionsTopToBottom(nodes3, y2, i2, alpha) { + for (; i2 < nodes3.length; ++i2) { + const node2 = nodes3[i2]; + const dy2 = (y2 - node2.y0) * alpha; + if (dy2 > 1e-6) + node2.y0 += dy2, node2.y1 += dy2; + y2 = node2.y1 + py; + } + } + function resolveCollisionsBottomToTop(nodes3, y2, i2, alpha) { + for (; i2 >= 0; --i2) { + const node2 = nodes3[i2]; + const dy2 = (node2.y1 - y2) * alpha; + if (dy2 > 1e-6) + node2.y0 -= dy2, node2.y1 -= dy2; + y2 = node2.y0 - py; + } + } + function reorderNodeLinks({ sourceLinks, targetLinks }) { + if (linkSort === void 0) { + for (const { source: { sourceLinks: sourceLinks2 } } of targetLinks) { + sourceLinks2.sort(ascendingTargetBreadth); + } + for (const { target: { targetLinks: targetLinks2 } } of sourceLinks) { + targetLinks2.sort(ascendingSourceBreadth); + } + } + } + function reorderLinks(nodes3) { + if (linkSort === void 0) { + for (const { sourceLinks, targetLinks } of nodes3) { + sourceLinks.sort(ascendingTargetBreadth); + targetLinks.sort(ascendingSourceBreadth); + } + } + } + function targetTop(source, target) { + let y2 = source.y0 - (source.sourceLinks.length - 1) * py / 2; + for (const { target: node2, width: width2 } of source.sourceLinks) { + if (node2 === target) + break; + y2 += width2 + py; + } + for (const { source: node2, width: width2 } of target.targetLinks) { + if (node2 === source) + break; + y2 -= width2; + } + return y2; + } + function sourceTop(source, target) { + let y2 = target.y0 - (target.targetLinks.length - 1) * py / 2; + for (const { source: node2, width: width2 } of target.targetLinks) { + if (node2 === source) + break; + y2 += width2 + py; + } + for (const { target: node2, width: width2 } of source.sourceLinks) { + if (node2 === target) + break; + y2 -= width2; + } + return y2; + } + return sankey2; + } + var pi = Math.PI, tau = 2 * pi, epsilon = 1e-6, tauEpsilon = tau - epsilon; + function Path() { + this._x0 = this._y0 = // start of current subpath + this._x1 = this._y1 = null; + this._ = ""; + } + function path() { + return new Path(); + } + Path.prototype = path.prototype = { + constructor: Path, + moveTo: function(x2, y2) { + this._ += "M" + (this._x0 = this._x1 = +x2) + "," + (this._y0 = this._y1 = +y2); + }, + closePath: function() { + if (this._x1 !== null) { + this._x1 = this._x0, this._y1 = this._y0; + this._ += "Z"; + } + }, + lineTo: function(x2, y2) { + this._ += "L" + (this._x1 = +x2) + "," + (this._y1 = +y2); + }, + quadraticCurveTo: function(x1, y1, x2, y2) { + this._ += "Q" + +x1 + "," + +y1 + "," + (this._x1 = +x2) + "," + (this._y1 = +y2); + }, + bezierCurveTo: function(x1, y1, x2, y2, x3, y3) { + this._ += "C" + +x1 + "," + +y1 + "," + +x2 + "," + +y2 + "," + (this._x1 = +x3) + "," + (this._y1 = +y3); + }, + arcTo: function(x1, y1, x2, y2, r) { + x1 = +x1, y1 = +y1, x2 = +x2, y2 = +y2, r = +r; + var x0 = this._x1, y0 = this._y1, x21 = x2 - x1, y21 = y2 - y1, x01 = x0 - x1, y01 = y0 - y1, l01_2 = x01 * x01 + y01 * y01; + if (r < 0) + throw new Error("negative radius: " + r); + if (this._x1 === null) { + this._ += "M" + (this._x1 = x1) + "," + (this._y1 = y1); + } else if (!(l01_2 > epsilon)) + ; + else if (!(Math.abs(y01 * x21 - y21 * x01) > epsilon) || !r) { + this._ += "L" + (this._x1 = x1) + "," + (this._y1 = y1); + } else { + var x20 = x2 - x0, y20 = y2 - y0, l21_2 = x21 * x21 + y21 * y21, l20_2 = x20 * x20 + y20 * y20, l21 = Math.sqrt(l21_2), l01 = Math.sqrt(l01_2), l = r * Math.tan((pi - Math.acos((l21_2 + l01_2 - l20_2) / (2 * l21 * l01))) / 2), t01 = l / l01, t21 = l / l21; + if (Math.abs(t01 - 1) > epsilon) { + this._ += "L" + (x1 + t01 * x01) + "," + (y1 + t01 * y01); + } + this._ += "A" + r + "," + r + ",0,0," + +(y01 * x20 > x01 * y20) + "," + (this._x1 = x1 + t21 * x21) + "," + (this._y1 = y1 + t21 * y21); + } + }, + arc: function(x2, y2, r, a0, a1, ccw) { + x2 = +x2, y2 = +y2, r = +r, ccw = !!ccw; + var dx = r * Math.cos(a0), dy = r * Math.sin(a0), x0 = x2 + dx, y0 = y2 + dy, cw = 1 ^ ccw, da = ccw ? a0 - a1 : a1 - a0; + if (r < 0) + throw new Error("negative radius: " + r); + if (this._x1 === null) { + this._ += "M" + x0 + "," + y0; + } else if (Math.abs(this._x1 - x0) > epsilon || Math.abs(this._y1 - y0) > epsilon) { + this._ += "L" + x0 + "," + y0; + } + if (!r) + return; + if (da < 0) + da = da % tau + tau; + if (da > tauEpsilon) { + this._ += "A" + r + "," + r + ",0,1," + cw + "," + (x2 - dx) + "," + (y2 - dy) + "A" + r + "," + r + ",0,1," + cw + "," + (this._x1 = x0) + "," + (this._y1 = y0); + } else if (da > epsilon) { + this._ += "A" + r + "," + r + ",0," + +(da >= pi) + "," + cw + "," + (this._x1 = x2 + r * Math.cos(a1)) + "," + (this._y1 = y2 + r * Math.sin(a1)); + } + }, + rect: function(x2, y2, w2, h) { + this._ += "M" + (this._x0 = this._x1 = +x2) + "," + (this._y0 = this._y1 = +y2) + "h" + +w2 + "v" + +h + "h" + -w2 + "Z"; + }, + toString: function() { + return this._; + } + }; + function constant(x2) { + return function constant2() { + return x2; + }; + } + function x(p) { + return p[0]; + } + function y(p) { + return p[1]; + } + var slice = Array.prototype.slice; + function linkSource(d) { + return d.source; + } + function linkTarget(d) { + return d.target; + } + function link(curve) { + var source = linkSource, target = linkTarget, x$12 = x, y$12 = y, context = null; + function link2() { + var buffer, argv = slice.call(arguments), s = source.apply(this, argv), t = target.apply(this, argv); + if (!context) + context = buffer = path(); + curve(context, +x$12.apply(this, (argv[0] = s, argv)), +y$12.apply(this, argv), +x$12.apply(this, (argv[0] = t, argv)), +y$12.apply(this, argv)); + if (buffer) + return context = null, buffer + "" || null; + } + link2.source = function(_2) { + return arguments.length ? (source = _2, link2) : source; + }; + link2.target = function(_2) { + return arguments.length ? (target = _2, link2) : target; + }; + link2.x = function(_2) { + return arguments.length ? (x$12 = typeof _2 === "function" ? _2 : constant(+_2), link2) : x$12; + }; + link2.y = function(_2) { + return arguments.length ? (y$12 = typeof _2 === "function" ? _2 : constant(+_2), link2) : y$12; + }; + link2.context = function(_2) { + return arguments.length ? (context = _2 == null ? null : _2, link2) : context; + }; + return link2; + } + function curveHorizontal(context, x0, y0, x1, y1) { + context.moveTo(x0, y0); + context.bezierCurveTo(x0 = (x0 + x1) / 2, y0, x0, y1, x1, y1); + } + function linkHorizontal() { + return link(curveHorizontal); + } + function horizontalSource(d) { + return [d.source.x1, d.y0]; + } + function horizontalTarget(d) { + return [d.target.x0, d.y1]; + } + function d3SankeyLinkHorizontal() { + return linkHorizontal().source(horizontalSource).target(horizontalTarget); + } + const _Uid = class _Uid2 { + static next(name) { + return new _Uid2(name + ++_Uid2.count); + } + constructor(id2) { + this.id = id2; + this.href = `#${id2}`; + } + toString() { + return "url(" + this.href + ")"; + } + }; + _Uid.count = 0; + let Uid = _Uid; + const alignmentsMap = { + left, + right, + center, + justify + }; + const draw$1 = function(text2, id2, _version, diagObj) { + const { securityLevel, sankey: conf2 } = getConfig$1(); + const defaultSankeyConfig = defaultConfig.sankey; + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = d3select("#i" + id2); + } + const root2 = securityLevel === "sandbox" ? d3select(sandboxElement.nodes()[0].contentDocument.body) : d3select("body"); + const svg2 = securityLevel === "sandbox" ? root2.select(`[id="${id2}"]`) : d3select(`[id="${id2}"]`); + const width2 = (conf2 == null ? void 0 : conf2.width) ?? defaultSankeyConfig.width; + const height = (conf2 == null ? void 0 : conf2.height) ?? defaultSankeyConfig.width; + const useMaxWidth = (conf2 == null ? void 0 : conf2.useMaxWidth) ?? defaultSankeyConfig.useMaxWidth; + const nodeAlignment = (conf2 == null ? void 0 : conf2.nodeAlignment) ?? defaultSankeyConfig.nodeAlignment; + const prefix = (conf2 == null ? void 0 : conf2.prefix) ?? defaultSankeyConfig.prefix; + const suffix = (conf2 == null ? void 0 : conf2.suffix) ?? defaultSankeyConfig.suffix; + const showValues = (conf2 == null ? void 0 : conf2.showValues) ?? defaultSankeyConfig.showValues; + const graph = diagObj.db.getGraph(); + const nodeAlign = alignmentsMap[nodeAlignment]; + const nodeWidth = 10; + const sankey2 = Sankey().nodeId((d) => d.id).nodeWidth(nodeWidth).nodePadding(10 + (showValues ? 15 : 0)).nodeAlign(nodeAlign).extent([ + [0, 0], + [width2, height] + ]); + sankey2(graph); + const colorScheme = ordinal(d3schemeTableau10); + svg2.append("g").attr("class", "nodes").selectAll(".node").data(graph.nodes).join("g").attr("class", "node").attr("id", (d) => (d.uid = Uid.next("node-")).id).attr("transform", function(d) { + return "translate(" + d.x0 + "," + d.y0 + ")"; + }).attr("x", (d) => d.x0).attr("y", (d) => d.y0).append("rect").attr("height", (d) => { + return d.y1 - d.y0; + }).attr("width", (d) => d.x1 - d.x0).attr("fill", (d) => colorScheme(d.id)); + const getText = ({ id: id22, value: value2 }) => { + if (!showValues) { + return id22; + } + return `${id22} +${prefix}${Math.round(value2 * 100) / 100}${suffix}`; + }; + svg2.append("g").attr("class", "node-labels").attr("font-family", "sans-serif").attr("font-size", 14).selectAll("text").data(graph.nodes).join("text").attr("x", (d) => d.x0 < width2 / 2 ? d.x1 + 6 : d.x0 - 6).attr("y", (d) => (d.y1 + d.y0) / 2).attr("dy", `${showValues ? "0" : "0.35"}em`).attr("text-anchor", (d) => d.x0 < width2 / 2 ? "start" : "end").text(getText); + const link2 = svg2.append("g").attr("class", "links").attr("fill", "none").attr("stroke-opacity", 0.5).selectAll(".link").data(graph.links).join("g").attr("class", "link").style("mix-blend-mode", "multiply"); + const linkColor = (conf2 == null ? void 0 : conf2.linkColor) || "gradient"; + if (linkColor === "gradient") { + const gradient = link2.append("linearGradient").attr("id", (d) => (d.uid = Uid.next("linearGradient-")).id).attr("gradientUnits", "userSpaceOnUse").attr("x1", (d) => d.source.x1).attr("x2", (d) => d.target.x0); + gradient.append("stop").attr("offset", "0%").attr("stop-color", (d) => colorScheme(d.source.id)); + gradient.append("stop").attr("offset", "100%").attr("stop-color", (d) => colorScheme(d.target.id)); + } + let coloring; + switch (linkColor) { + case "gradient": + coloring = (d) => d.uid; + break; + case "source": + coloring = (d) => colorScheme(d.source.id); + break; + case "target": + coloring = (d) => colorScheme(d.target.id); + break; + default: + coloring = linkColor; + } + link2.append("path").attr("d", d3SankeyLinkHorizontal()).attr("stroke", coloring).attr("stroke-width", (d) => Math.max(1, d.width)); + setupGraphViewbox$1(void 0, svg2, 0, useMaxWidth); + }; + const renderer$1 = { + draw: draw$1 + }; + const prepareTextForParsing = (text2) => { + const textToParse = text2.replaceAll(/^[^\S\n\r]+|[^\S\n\r]+$/g, "").replaceAll(/([\n\r])+/g, "\n").trim(); + return textToParse; + }; + const originalParse = parser$3.parse.bind(parser$3); + parser$3.parse = (text2) => originalParse(prepareTextForParsing(text2)); + const diagram$1 = { + parser: parser$3, + db: db$2, + renderer: renderer$1 + }; + const sankeyDiagram = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + diagram: diagram$1 + }, Symbol.toStringTag, { value: "Module" })); + var parser = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 7], $V1 = [1, 13], $V2 = [1, 14], $V3 = [1, 15], $V4 = [1, 19], $V5 = [1, 16], $V6 = [1, 17], $V7 = [1, 18], $V8 = [8, 30], $V9 = [8, 21, 28, 29, 30, 31, 32, 40, 44, 47], $Va = [1, 23], $Vb = [1, 24], $Vc = [8, 15, 16, 21, 28, 29, 30, 31, 32, 40, 44, 47], $Vd = [8, 15, 16, 21, 27, 28, 29, 30, 31, 32, 40, 44, 47], $Ve = [1, 49]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "spaceLines": 3, "SPACELINE": 4, "NL": 5, "separator": 6, "SPACE": 7, "EOF": 8, "start": 9, "BLOCK_DIAGRAM_KEY": 10, "document": 11, "stop": 12, "statement": 13, "link": 14, "LINK": 15, "START_LINK": 16, "LINK_LABEL": 17, "STR": 18, "nodeStatement": 19, "columnsStatement": 20, "SPACE_BLOCK": 21, "blockStatement": 22, "classDefStatement": 23, "cssClassStatement": 24, "styleStatement": 25, "node": 26, "SIZE": 27, "COLUMNS": 28, "id-block": 29, "end": 30, "block": 31, "NODE_ID": 32, "nodeShapeNLabel": 33, "dirList": 34, "DIR": 35, "NODE_DSTART": 36, "NODE_DEND": 37, "BLOCK_ARROW_START": 38, "BLOCK_ARROW_END": 39, "classDef": 40, "CLASSDEF_ID": 41, "CLASSDEF_STYLEOPTS": 42, "DEFAULT": 43, "class": 44, "CLASSENTITY_IDS": 45, "STYLECLASS": 46, "style": 47, "STYLE_ENTITY_IDS": 48, "STYLE_DEFINITION_DATA": 49, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 4: "SPACELINE", 5: "NL", 7: "SPACE", 8: "EOF", 10: "BLOCK_DIAGRAM_KEY", 15: "LINK", 16: "START_LINK", 17: "LINK_LABEL", 18: "STR", 21: "SPACE_BLOCK", 27: "SIZE", 28: "COLUMNS", 29: "id-block", 30: "end", 31: "block", 32: "NODE_ID", 35: "DIR", 36: "NODE_DSTART", 37: "NODE_DEND", 38: "BLOCK_ARROW_START", 39: "BLOCK_ARROW_END", 40: "classDef", 41: "CLASSDEF_ID", 42: "CLASSDEF_STYLEOPTS", 43: "DEFAULT", 44: "class", 45: "CLASSENTITY_IDS", 46: "STYLECLASS", 47: "style", 48: "STYLE_ENTITY_IDS", 49: "STYLE_DEFINITION_DATA" }, + productions_: [0, [3, 1], [3, 2], [3, 2], [6, 1], [6, 1], [6, 1], [9, 3], [12, 1], [12, 1], [12, 2], [12, 2], [11, 1], [11, 2], [14, 1], [14, 4], [13, 1], [13, 1], [13, 1], [13, 1], [13, 1], [13, 1], [13, 1], [19, 3], [19, 2], [19, 1], [20, 1], [22, 4], [22, 3], [26, 1], [26, 2], [34, 1], [34, 2], [33, 3], [33, 4], [23, 3], [23, 3], [24, 3], [25, 3]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 4: + yy.getLogger().debug("Rule: separator (NL) "); + break; + case 5: + yy.getLogger().debug("Rule: separator (Space) "); + break; + case 6: + yy.getLogger().debug("Rule: separator (EOF) "); + break; + case 7: + yy.getLogger().debug("Rule: hierarchy: ", $$[$0 - 1]); + yy.setHierarchy($$[$0 - 1]); + break; + case 8: + yy.getLogger().debug("Stop NL "); + break; + case 9: + yy.getLogger().debug("Stop EOF "); + break; + case 10: + yy.getLogger().debug("Stop NL2 "); + break; + case 11: + yy.getLogger().debug("Stop EOF2 "); + break; + case 12: + yy.getLogger().debug("Rule: statement: ", $$[$0]); + typeof $$[$0].length === "number" ? this.$ = $$[$0] : this.$ = [$$[$0]]; + break; + case 13: + yy.getLogger().debug("Rule: statement #2: ", $$[$0 - 1]); + this.$ = [$$[$0 - 1]].concat($$[$0]); + break; + case 14: + yy.getLogger().debug("Rule: link: ", $$[$0], yytext); + this.$ = { edgeTypeStr: $$[$0], label: "" }; + break; + case 15: + yy.getLogger().debug("Rule: LABEL link: ", $$[$0 - 3], $$[$0 - 1], $$[$0]); + this.$ = { edgeTypeStr: $$[$0], label: $$[$0 - 1] }; + break; + case 18: + const num = parseInt($$[$0]); + const spaceId = yy.generateId(); + this.$ = { id: spaceId, type: "space", label: "", width: num, children: [] }; + break; + case 23: + yy.getLogger().debug("Rule: (nodeStatement link node) ", $$[$0 - 2], $$[$0 - 1], $$[$0], " typestr: ", $$[$0 - 1].edgeTypeStr); + const edgeData = yy.edgeStrToEdgeData($$[$0 - 1].edgeTypeStr); + this.$ = [ + { id: $$[$0 - 2].id, label: $$[$0 - 2].label, type: $$[$0 - 2].type, directions: $$[$0 - 2].directions }, + { id: $$[$0 - 2].id + "-" + $$[$0].id, start: $$[$0 - 2].id, end: $$[$0].id, label: $$[$0 - 1].label, type: "edge", directions: $$[$0].directions, arrowTypeEnd: edgeData, arrowTypeStart: "arrow_open" }, + { id: $$[$0].id, label: $$[$0].label, type: yy.typeStr2Type($$[$0].typeStr), directions: $$[$0].directions } + ]; + break; + case 24: + yy.getLogger().debug("Rule: nodeStatement (abc88 node size) ", $$[$0 - 1], $$[$0]); + this.$ = { id: $$[$0 - 1].id, label: $$[$0 - 1].label, type: yy.typeStr2Type($$[$0 - 1].typeStr), directions: $$[$0 - 1].directions, widthInColumns: parseInt($$[$0], 10) }; + break; + case 25: + yy.getLogger().debug("Rule: nodeStatement (node) ", $$[$0]); + this.$ = { id: $$[$0].id, label: $$[$0].label, type: yy.typeStr2Type($$[$0].typeStr), directions: $$[$0].directions, widthInColumns: 1 }; + break; + case 26: + yy.getLogger().debug("APA123", this ? this : "na"); + yy.getLogger().debug("COLUMNS: ", $$[$0]); + this.$ = { type: "column-setting", columns: $$[$0] === "auto" ? -1 : parseInt($$[$0]) }; + break; + case 27: + yy.getLogger().debug("Rule: id-block statement : ", $$[$0 - 2], $$[$0 - 1]); + yy.generateId(); + this.$ = { ...$$[$0 - 2], type: "composite", children: $$[$0 - 1] }; + break; + case 28: + yy.getLogger().debug("Rule: blockStatement : ", $$[$0 - 2], $$[$0 - 1], $$[$0]); + const id2 = yy.generateId(); + this.$ = { id: id2, type: "composite", label: "", children: $$[$0 - 1] }; + break; + case 29: + yy.getLogger().debug("Rule: node (NODE_ID separator): ", $$[$0]); + this.$ = { id: $$[$0] }; + break; + case 30: + yy.getLogger().debug("Rule: node (NODE_ID nodeShapeNLabel separator): ", $$[$0 - 1], $$[$0]); + this.$ = { id: $$[$0 - 1], label: $$[$0].label, typeStr: $$[$0].typeStr, directions: $$[$0].directions }; + break; + case 31: + yy.getLogger().debug("Rule: dirList: ", $$[$0]); + this.$ = [$$[$0]]; + break; + case 32: + yy.getLogger().debug("Rule: dirList: ", $$[$0 - 1], $$[$0]); + this.$ = [$$[$0 - 1]].concat($$[$0]); + break; + case 33: + yy.getLogger().debug("Rule: nodeShapeNLabel: ", $$[$0 - 2], $$[$0 - 1], $$[$0]); + this.$ = { typeStr: $$[$0 - 2] + $$[$0], label: $$[$0 - 1] }; + break; + case 34: + yy.getLogger().debug("Rule: BLOCK_ARROW nodeShapeNLabel: ", $$[$0 - 3], $$[$0 - 2], " #3:", $$[$0 - 1], $$[$0]); + this.$ = { typeStr: $$[$0 - 3] + $$[$0], label: $$[$0 - 2], directions: $$[$0 - 1] }; + break; + case 35: + case 36: + this.$ = { type: "classDef", id: $$[$0 - 1].trim(), css: $$[$0].trim() }; + break; + case 37: + this.$ = { type: "applyClass", id: $$[$0 - 1].trim(), styleClass: $$[$0].trim() }; + break; + case 38: + this.$ = { type: "applyStyles", id: $$[$0 - 1].trim(), stylesStr: $$[$0].trim() }; + break; + } + }, + table: [{ 9: 1, 10: [1, 2] }, { 1: [3] }, { 11: 3, 13: 4, 19: 5, 20: 6, 21: $V0, 22: 8, 23: 9, 24: 10, 25: 11, 26: 12, 28: $V1, 29: $V2, 31: $V3, 32: $V4, 40: $V5, 44: $V6, 47: $V7 }, { 8: [1, 20] }, o($V8, [2, 12], { 13: 4, 19: 5, 20: 6, 22: 8, 23: 9, 24: 10, 25: 11, 26: 12, 11: 21, 21: $V0, 28: $V1, 29: $V2, 31: $V3, 32: $V4, 40: $V5, 44: $V6, 47: $V7 }), o($V9, [2, 16], { 14: 22, 15: $Va, 16: $Vb }), o($V9, [2, 17]), o($V9, [2, 18]), o($V9, [2, 19]), o($V9, [2, 20]), o($V9, [2, 21]), o($V9, [2, 22]), o($Vc, [2, 25], { 27: [1, 25] }), o($V9, [2, 26]), { 19: 26, 26: 12, 32: $V4 }, { 11: 27, 13: 4, 19: 5, 20: 6, 21: $V0, 22: 8, 23: 9, 24: 10, 25: 11, 26: 12, 28: $V1, 29: $V2, 31: $V3, 32: $V4, 40: $V5, 44: $V6, 47: $V7 }, { 41: [1, 28], 43: [1, 29] }, { 45: [1, 30] }, { 48: [1, 31] }, o($Vd, [2, 29], { 33: 32, 36: [1, 33], 38: [1, 34] }), { 1: [2, 7] }, o($V8, [2, 13]), { 26: 35, 32: $V4 }, { 32: [2, 14] }, { 17: [1, 36] }, o($Vc, [2, 24]), { 11: 37, 13: 4, 14: 22, 15: $Va, 16: $Vb, 19: 5, 20: 6, 21: $V0, 22: 8, 23: 9, 24: 10, 25: 11, 26: 12, 28: $V1, 29: $V2, 31: $V3, 32: $V4, 40: $V5, 44: $V6, 47: $V7 }, { 30: [1, 38] }, { 42: [1, 39] }, { 42: [1, 40] }, { 46: [1, 41] }, { 49: [1, 42] }, o($Vd, [2, 30]), { 18: [1, 43] }, { 18: [1, 44] }, o($Vc, [2, 23]), { 18: [1, 45] }, { 30: [1, 46] }, o($V9, [2, 28]), o($V9, [2, 35]), o($V9, [2, 36]), o($V9, [2, 37]), o($V9, [2, 38]), { 37: [1, 47] }, { 34: 48, 35: $Ve }, { 15: [1, 50] }, o($V9, [2, 27]), o($Vd, [2, 33]), { 39: [1, 51] }, { 34: 52, 35: $Ve, 39: [2, 31] }, { 32: [2, 15] }, o($Vd, [2, 34]), { 39: [2, 32] }], + defaultActions: { 20: [2, 7], 23: [2, 14], 50: [2, 15], 52: [2, 32] }, + parseError: function parseError(str2, hash) { + if (hash.recoverable) { + this.trace(str2); + } else { + var error = new Error(str2); + error.hash = hash; + throw error; + } + }, + parse: function parse2(input) { + var self2 = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex2() { + var token2; + token2 = tstack.pop() || lexer2.lex() || EOF; + if (typeof token2 !== "number") { + if (token2 instanceof Array) { + tstack = token2; + token2 = tstack.pop(); + } + token2 = self2.symbols_[token2] || token2; + } + return token2; + } + var symbol, state2, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state2 = stack[stack.length - 1]; + if (this.defaultActions[state2]) { + action = this.defaultActions[state2]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex2(); + } + action = table[state2] && table[state2][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state2]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state2 + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str2, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str2, hash); + } else { + throw new Error(str2); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch2 = this._input[0]; + this.yytext += ch2; + this.yyleng++; + this.offset++; + this.match += ch2; + this.matched += ch2; + var lines = ch2.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch2; + }, + // unshifts one char (or a string) into the input + unput: function(ch2) { + var len = ch2.length; + var lines = ch2.split(/(?:\r\n?|\n)/g); + this._input = ch2 + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next2 = this.match; + if (next2.length < 20) { + next2 += this._input.substr(0, 20 - next2.length); + } + return (next2.substr(0, 20) + (next2.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c2 = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c2 + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token2, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token2 = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token2) { + return token2; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token2, match, tempMatch, index2; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i2 = 0; i2 < rules.length; i2++) { + tempMatch = this._input.match(this.rules[rules[i2]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index2 = i2; + if (this.options.backtrack_lexer) { + token2 = this.test_match(tempMatch, rules[i2]); + if (token2 !== false) { + return token2; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token2 = this.test_match(match, rules[index2]); + if (token2 !== false) { + return token2; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex2() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: {}, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + return 10; + case 1: + yy.getLogger().debug("Found space-block"); + return 31; + case 2: + yy.getLogger().debug("Found nl-block"); + return 31; + case 3: + yy.getLogger().debug("Found space-block"); + return 29; + case 4: + yy.getLogger().debug(".", yy_.yytext); + break; + case 5: + yy.getLogger().debug("_", yy_.yytext); + break; + case 6: + return 5; + case 7: + yy_.yytext = -1; + return 28; + case 8: + yy_.yytext = yy_.yytext.replace(/columns\s+/, ""); + yy.getLogger().debug("COLUMNS (LEX)", yy_.yytext); + return 28; + case 9: + this.pushState("md_string"); + break; + case 10: + return "MD_STR"; + case 11: + this.popState(); + break; + case 12: + this.pushState("string"); + break; + case 13: + yy.getLogger().debug("LEX: POPPING STR:", yy_.yytext); + this.popState(); + break; + case 14: + yy.getLogger().debug("LEX: STR end:", yy_.yytext); + return "STR"; + case 15: + yy_.yytext = yy_.yytext.replace(/space\:/, ""); + yy.getLogger().debug("SPACE NUM (LEX)", yy_.yytext); + return 21; + case 16: + yy_.yytext = "1"; + yy.getLogger().debug("COLUMNS (LEX)", yy_.yytext); + return 21; + case 17: + return 43; + case 18: + return "LINKSTYLE"; + case 19: + return "INTERPOLATE"; + case 20: + this.pushState("CLASSDEF"); + return 40; + case 21: + this.popState(); + this.pushState("CLASSDEFID"); + return "DEFAULT_CLASSDEF_ID"; + case 22: + this.popState(); + this.pushState("CLASSDEFID"); + return 41; + case 23: + this.popState(); + return 42; + case 24: + this.pushState("CLASS"); + return 44; + case 25: + this.popState(); + this.pushState("CLASS_STYLE"); + return 45; + case 26: + this.popState(); + return 46; + case 27: + this.pushState("STYLE_STMNT"); + return 47; + case 28: + this.popState(); + this.pushState("STYLE_DEFINITION"); + return 48; + case 29: + this.popState(); + return 49; + case 30: + this.pushState("acc_title"); + return "acc_title"; + case 31: + this.popState(); + return "acc_title_value"; + case 32: + this.pushState("acc_descr"); + return "acc_descr"; + case 33: + this.popState(); + return "acc_descr_value"; + case 34: + this.pushState("acc_descr_multiline"); + break; + case 35: + this.popState(); + break; + case 36: + return "acc_descr_multiline_value"; + case 37: + return 30; + case 38: + this.popState(); + yy.getLogger().debug("Lex: (("); + return "NODE_DEND"; + case 39: + this.popState(); + yy.getLogger().debug("Lex: (("); + return "NODE_DEND"; + case 40: + this.popState(); + yy.getLogger().debug("Lex: ))"); + return "NODE_DEND"; + case 41: + this.popState(); + yy.getLogger().debug("Lex: (("); + return "NODE_DEND"; + case 42: + this.popState(); + yy.getLogger().debug("Lex: (("); + return "NODE_DEND"; + case 43: + this.popState(); + yy.getLogger().debug("Lex: (-"); + return "NODE_DEND"; + case 44: + this.popState(); + yy.getLogger().debug("Lex: -)"); + return "NODE_DEND"; + case 45: + this.popState(); + yy.getLogger().debug("Lex: (("); + return "NODE_DEND"; + case 46: + this.popState(); + yy.getLogger().debug("Lex: ]]"); + return "NODE_DEND"; + case 47: + this.popState(); + yy.getLogger().debug("Lex: ("); + return "NODE_DEND"; + case 48: + this.popState(); + yy.getLogger().debug("Lex: ])"); + return "NODE_DEND"; + case 49: + this.popState(); + yy.getLogger().debug("Lex: /]"); + return "NODE_DEND"; + case 50: + this.popState(); + yy.getLogger().debug("Lex: /]"); + return "NODE_DEND"; + case 51: + this.popState(); + yy.getLogger().debug("Lex: )]"); + return "NODE_DEND"; + case 52: + this.popState(); + yy.getLogger().debug("Lex: )"); + return "NODE_DEND"; + case 53: + this.popState(); + yy.getLogger().debug("Lex: ]>"); + return "NODE_DEND"; + case 54: + this.popState(); + yy.getLogger().debug("Lex: ]"); + return "NODE_DEND"; + case 55: + yy.getLogger().debug("Lexa: -)"); + this.pushState("NODE"); + return 36; + case 56: + yy.getLogger().debug("Lexa: (-"); + this.pushState("NODE"); + return 36; + case 57: + yy.getLogger().debug("Lexa: ))"); + this.pushState("NODE"); + return 36; + case 58: + yy.getLogger().debug("Lexa: )"); + this.pushState("NODE"); + return 36; + case 59: + yy.getLogger().debug("Lex: ((("); + this.pushState("NODE"); + return 36; + case 60: + yy.getLogger().debug("Lexa: )"); + this.pushState("NODE"); + return 36; + case 61: + yy.getLogger().debug("Lexa: )"); + this.pushState("NODE"); + return 36; + case 62: + yy.getLogger().debug("Lexa: )"); + this.pushState("NODE"); + return 36; + case 63: + yy.getLogger().debug("Lexc: >"); + this.pushState("NODE"); + return 36; + case 64: + yy.getLogger().debug("Lexa: (["); + this.pushState("NODE"); + return 36; + case 65: + yy.getLogger().debug("Lexa: )"); + this.pushState("NODE"); + return 36; + case 66: + this.pushState("NODE"); + return 36; + case 67: + this.pushState("NODE"); + return 36; + case 68: + this.pushState("NODE"); + return 36; + case 69: + this.pushState("NODE"); + return 36; + case 70: + this.pushState("NODE"); + return 36; + case 71: + this.pushState("NODE"); + return 36; + case 72: + this.pushState("NODE"); + return 36; + case 73: + yy.getLogger().debug("Lexa: ["); + this.pushState("NODE"); + return 36; + case 74: + this.pushState("BLOCK_ARROW"); + yy.getLogger().debug("LEX ARR START"); + return 38; + case 75: + yy.getLogger().debug("Lex: NODE_ID", yy_.yytext); + return 32; + case 76: + yy.getLogger().debug("Lex: EOF", yy_.yytext); + return 8; + case 77: + this.pushState("md_string"); + break; + case 78: + this.pushState("md_string"); + break; + case 79: + return "NODE_DESCR"; + case 80: + this.popState(); + break; + case 81: + yy.getLogger().debug("Lex: Starting string"); + this.pushState("string"); + break; + case 82: + yy.getLogger().debug("LEX ARR: Starting string"); + this.pushState("string"); + break; + case 83: + yy.getLogger().debug("LEX: NODE_DESCR:", yy_.yytext); + return "NODE_DESCR"; + case 84: + yy.getLogger().debug("LEX POPPING"); + this.popState(); + break; + case 85: + yy.getLogger().debug("Lex: =>BAE"); + this.pushState("ARROW_DIR"); + break; + case 86: + yy_.yytext = yy_.yytext.replace(/^,\s*/, ""); + yy.getLogger().debug("Lex (right): dir:", yy_.yytext); + return "DIR"; + case 87: + yy_.yytext = yy_.yytext.replace(/^,\s*/, ""); + yy.getLogger().debug("Lex (left):", yy_.yytext); + return "DIR"; + case 88: + yy_.yytext = yy_.yytext.replace(/^,\s*/, ""); + yy.getLogger().debug("Lex (x):", yy_.yytext); + return "DIR"; + case 89: + yy_.yytext = yy_.yytext.replace(/^,\s*/, ""); + yy.getLogger().debug("Lex (y):", yy_.yytext); + return "DIR"; + case 90: + yy_.yytext = yy_.yytext.replace(/^,\s*/, ""); + yy.getLogger().debug("Lex (up):", yy_.yytext); + return "DIR"; + case 91: + yy_.yytext = yy_.yytext.replace(/^,\s*/, ""); + yy.getLogger().debug("Lex (down):", yy_.yytext); + return "DIR"; + case 92: + yy_.yytext = "]>"; + yy.getLogger().debug("Lex (ARROW_DIR end):", yy_.yytext); + this.popState(); + this.popState(); + return "BLOCK_ARROW_END"; + case 93: + yy.getLogger().debug("Lex: LINK", "#" + yy_.yytext + "#"); + return 15; + case 94: + yy.getLogger().debug("Lex: LINK", yy_.yytext); + return 15; + case 95: + yy.getLogger().debug("Lex: LINK", yy_.yytext); + return 15; + case 96: + yy.getLogger().debug("Lex: LINK", yy_.yytext); + return 15; + case 97: + yy.getLogger().debug("Lex: START_LINK", yy_.yytext); + this.pushState("LLABEL"); + return 16; + case 98: + yy.getLogger().debug("Lex: START_LINK", yy_.yytext); + this.pushState("LLABEL"); + return 16; + case 99: + yy.getLogger().debug("Lex: START_LINK", yy_.yytext); + this.pushState("LLABEL"); + return 16; + case 100: + this.pushState("md_string"); + break; + case 101: + yy.getLogger().debug("Lex: Starting string"); + this.pushState("string"); + return "LINK_LABEL"; + case 102: + this.popState(); + yy.getLogger().debug("Lex: LINK", "#" + yy_.yytext + "#"); + return 15; + case 103: + this.popState(); + yy.getLogger().debug("Lex: LINK", yy_.yytext); + return 15; + case 104: + this.popState(); + yy.getLogger().debug("Lex: LINK", yy_.yytext); + return 15; + case 105: + yy.getLogger().debug("Lex: COLON", yy_.yytext); + yy_.yytext = yy_.yytext.slice(1); + return 27; + } + }, + rules: [/^(?:block-beta\b)/, /^(?:block\s+)/, /^(?:block\n+)/, /^(?:block:)/, /^(?:[\s]+)/, /^(?:[\n]+)/, /^(?:((\u000D\u000A)|(\u000A)))/, /^(?:columns\s+auto\b)/, /^(?:columns\s+[\d]+)/, /^(?:["][`])/, /^(?:[^`"]+)/, /^(?:[`]["])/, /^(?:["])/, /^(?:["])/, /^(?:[^"]*)/, /^(?:space[:]\d+)/, /^(?:space\b)/, /^(?:default\b)/, /^(?:linkStyle\b)/, /^(?:interpolate\b)/, /^(?:classDef\s+)/, /^(?:DEFAULT\s+)/, /^(?:\w+\s+)/, /^(?:[^\n]*)/, /^(?:class\s+)/, /^(?:(\w+)+((,\s*\w+)*))/, /^(?:[^\n]*)/, /^(?:style\s+)/, /^(?:(\w+)+((,\s*\w+)*))/, /^(?:[^\n]*)/, /^(?:accTitle\s*:\s*)/, /^(?:(?!\n||)*[^\n]*)/, /^(?:accDescr\s*:\s*)/, /^(?:(?!\n||)*[^\n]*)/, /^(?:accDescr\s*\{\s*)/, /^(?:[\}])/, /^(?:[^\}]*)/, /^(?:end\b\s*)/, /^(?:\(\(\()/, /^(?:\)\)\))/, /^(?:[\)]\))/, /^(?:\}\})/, /^(?:\})/, /^(?:\(-)/, /^(?:-\))/, /^(?:\(\()/, /^(?:\]\])/, /^(?:\()/, /^(?:\]\))/, /^(?:\\\])/, /^(?:\/\])/, /^(?:\)\])/, /^(?:[\)])/, /^(?:\]>)/, /^(?:[\]])/, /^(?:-\))/, /^(?:\(-)/, /^(?:\)\))/, /^(?:\))/, /^(?:\(\(\()/, /^(?:\(\()/, /^(?:\{\{)/, /^(?:\{)/, /^(?:>)/, /^(?:\(\[)/, /^(?:\()/, /^(?:\[\[)/, /^(?:\[\|)/, /^(?:\[\()/, /^(?:\)\)\))/, /^(?:\[\\)/, /^(?:\[\/)/, /^(?:\[\\)/, /^(?:\[)/, /^(?:<\[)/, /^(?:[^\(\[\n\-\)\{\}\s\<\>:]+)/, /^(?:$)/, /^(?:["][`])/, /^(?:["][`])/, /^(?:[^`"]+)/, /^(?:[`]["])/, /^(?:["])/, /^(?:["])/, /^(?:[^"]+)/, /^(?:["])/, /^(?:\]>\s*\()/, /^(?:,?\s*right\s*)/, /^(?:,?\s*left\s*)/, /^(?:,?\s*x\s*)/, /^(?:,?\s*y\s*)/, /^(?:,?\s*up\s*)/, /^(?:,?\s*down\s*)/, /^(?:\)\s*)/, /^(?:\s*[xo<]?--+[-xo>]\s*)/, /^(?:\s*[xo<]?==+[=xo>]\s*)/, /^(?:\s*[xo<]?-?\.+-[xo>]?\s*)/, /^(?:\s*~~[\~]+\s*)/, /^(?:\s*[xo<]?--\s*)/, /^(?:\s*[xo<]?==\s*)/, /^(?:\s*[xo<]?-\.\s*)/, /^(?:["][`])/, /^(?:["])/, /^(?:\s*[xo<]?--+[-xo>]\s*)/, /^(?:\s*[xo<]?==+[=xo>]\s*)/, /^(?:\s*[xo<]?-?\.+-[xo>]?\s*)/, /^(?::\d+)/], + conditions: { "STYLE_DEFINITION": { "rules": [29], "inclusive": false }, "STYLE_STMNT": { "rules": [28], "inclusive": false }, "CLASSDEFID": { "rules": [23], "inclusive": false }, "CLASSDEF": { "rules": [21, 22], "inclusive": false }, "CLASS_STYLE": { "rules": [26], "inclusive": false }, "CLASS": { "rules": [25], "inclusive": false }, "LLABEL": { "rules": [100, 101, 102, 103, 104], "inclusive": false }, "ARROW_DIR": { "rules": [86, 87, 88, 89, 90, 91, 92], "inclusive": false }, "BLOCK_ARROW": { "rules": [77, 82, 85], "inclusive": false }, "NODE": { "rules": [38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 78, 81], "inclusive": false }, "md_string": { "rules": [10, 11, 79, 80], "inclusive": false }, "space": { "rules": [], "inclusive": false }, "string": { "rules": [13, 14, 83, 84], "inclusive": false }, "acc_descr_multiline": { "rules": [35, 36], "inclusive": false }, "acc_descr": { "rules": [33], "inclusive": false }, "acc_title": { "rules": [31], "inclusive": false }, "INITIAL": { "rules": [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 12, 15, 16, 17, 18, 19, 20, 24, 27, 30, 32, 34, 37, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 93, 94, 95, 96, 97, 98, 99, 105], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser2() { + this.yy = {}; + } + Parser2.prototype = parser2; + parser2.Parser = Parser2; + return new Parser2(); + }(); + parser.parser = parser; + const parser$1 = parser; + let blockDatabase = {}; + let edgeList = []; + let edgeCount = {}; + const COLOR_KEYWORD = "color"; + const FILL_KEYWORD = "fill"; + const BG_FILL = "bgFill"; + const STYLECLASS_SEP = ","; + const config = getConfig$1(); + let classes = {}; + const sanitizeText = (txt) => common$1.sanitizeText(txt, config); + const addStyleClass = function(id2, styleAttributes = "") { + if (classes[id2] === void 0) { + classes[id2] = { id: id2, styles: [], textStyles: [] }; + } + const foundClass = classes[id2]; + if (styleAttributes !== void 0 && styleAttributes !== null) { + styleAttributes.split(STYLECLASS_SEP).forEach((attrib) => { + const fixedAttrib = attrib.replace(/([^;]*);/, "$1").trim(); + if (attrib.match(COLOR_KEYWORD)) { + const newStyle1 = fixedAttrib.replace(FILL_KEYWORD, BG_FILL); + const newStyle2 = newStyle1.replace(COLOR_KEYWORD, FILL_KEYWORD); + foundClass.textStyles.push(newStyle2); + } + foundClass.styles.push(fixedAttrib); + }); + } + }; + const addStyle2Node = function(id2, styles2 = "") { + const foundBlock = blockDatabase[id2]; + if (styles2 !== void 0 && styles2 !== null) { + foundBlock.styles = styles2.split(STYLECLASS_SEP); + } + }; + const setCssClass = function(itemIds, cssClassName) { + itemIds.split(",").forEach(function(id2) { + let foundBlock = blockDatabase[id2]; + if (foundBlock === void 0) { + const trimmedId = id2.trim(); + blockDatabase[trimmedId] = { id: trimmedId, type: "na", children: [] }; + foundBlock = blockDatabase[trimmedId]; + } + if (!foundBlock.classes) { + foundBlock.classes = []; + } + foundBlock.classes.push(cssClassName); + }); + }; + const populateBlockDatabase = (_blockList, parent) => { + const blockList = _blockList.flat(); + const children2 = []; + for (const block2 of blockList) { + if (block2.label) { + block2.label = sanitizeText(block2.label); + } + if (block2.type === "classDef") { + addStyleClass(block2.id, block2.css); + continue; + } + if (block2.type === "applyClass") { + setCssClass(block2.id, (block2 == null ? void 0 : block2.styleClass) || ""); + continue; + } + if (block2.type === "applyStyles") { + if (block2 == null ? void 0 : block2.stylesStr) { + addStyle2Node(block2.id, block2 == null ? void 0 : block2.stylesStr); + } + continue; + } + if (block2.type === "column-setting") { + parent.columns = block2.columns || -1; + } else if (block2.type === "edge") { + if (edgeCount[block2.id]) { + edgeCount[block2.id]++; + } else { + edgeCount[block2.id] = 1; + } + block2.id = edgeCount[block2.id] + "-" + block2.id; + edgeList.push(block2); + } else { + if (!block2.label) { + if (block2.type === "composite") { + block2.label = ""; + } else { + block2.label = block2.id; + } + } + const newBlock = !blockDatabase[block2.id]; + if (newBlock) { + blockDatabase[block2.id] = block2; + } else { + if (block2.type !== "na") { + blockDatabase[block2.id].type = block2.type; + } + if (block2.label !== block2.id) { + blockDatabase[block2.id].label = block2.label; + } + } + if (block2.children) { + populateBlockDatabase(block2.children, block2); + } + if (block2.type === "space") { + const w2 = block2.width || 1; + for (let j = 0; j < w2; j++) { + const newBlock2 = clone$1(block2); + newBlock2.id = newBlock2.id + "-" + j; + blockDatabase[newBlock2.id] = newBlock2; + children2.push(newBlock2); + } + } else if (newBlock) { + children2.push(block2); + } + } + } + parent.children = children2; + }; + let blocks = []; + let rootBlock = { id: "root", type: "composite", children: [], columns: -1 }; + const clear = () => { + log$1.debug("Clear called"); + clear$n(); + rootBlock = { id: "root", type: "composite", children: [], columns: -1 }; + blockDatabase = { root: rootBlock }; + blocks = []; + classes = {}; + edgeList = []; + edgeCount = {}; + }; + function typeStr2Type(typeStr) { + log$1.debug("typeStr2Type", typeStr); + switch (typeStr) { + case "[]": + return "square"; + case "()": + log$1.debug("we have a round"); + return "round"; + case "(())": + return "circle"; + case ">]": + return "rect_left_inv_arrow"; + case "{}": + return "diamond"; + case "{{}}": + return "hexagon"; + case "([])": + return "stadium"; + case "[[]]": + return "subroutine"; + case "[()]": + return "cylinder"; + case "((()))": + return "doublecircle"; + case "[//]": + return "lean_right"; + case "[\\\\]": + return "lean_left"; + case "[/\\]": + return "trapezoid"; + case "[\\/]": + return "inv_trapezoid"; + case "<[]>": + return "block_arrow"; + default: + return "na"; + } + } + function edgeTypeStr2Type(typeStr) { + log$1.debug("typeStr2Type", typeStr); + switch (typeStr) { + case "==": + return "thick"; + default: + return "normal"; + } + } + function edgeStrToEdgeData(typeStr) { + switch (typeStr.trim()) { + case "--x": + return "arrow_cross"; + case "--o": + return "arrow_circle"; + default: + return "arrow_point"; + } + } + let cnt = 0; + const generateId = () => { + cnt++; + return "id-" + Math.random().toString(36).substr(2, 12) + "-" + cnt; + }; + const setHierarchy = (block2) => { + rootBlock.children = block2; + populateBlockDatabase(block2, rootBlock); + blocks = rootBlock.children; + }; + const getColumns = (blockId) => { + const block2 = blockDatabase[blockId]; + if (!block2) { + return -1; + } + if (block2.columns) { + return block2.columns; + } + if (!block2.children) { + return -1; + } + return block2.children.length; + }; + const getBlocksFlat = () => { + return [...Object.values(blockDatabase)]; + }; + const getBlocks = () => { + return blocks || []; + }; + const getEdges = () => { + return edgeList; + }; + const getBlock = (id2) => { + return blockDatabase[id2]; + }; + const setBlock = (block2) => { + blockDatabase[block2.id] = block2; + }; + const getLogger = () => console; + const getClasses$1 = function() { + return classes; + }; + const db = { + getConfig: () => getConfig$2().block, + typeStr2Type, + edgeTypeStr2Type, + edgeStrToEdgeData, + getLogger, + getBlocksFlat, + getBlocks, + getEdges, + setHierarchy, + getBlock, + setBlock, + getColumns, + getClasses: getClasses$1, + clear, + generateId + }; + const db$1 = db; + const fade = (color2, opacity) => { + const channel2 = channel$1; + const r = channel2(color2, "r"); + const g = channel2(color2, "g"); + const b = channel2(color2, "b"); + return rgba$1(r, g, b, opacity); + }; + const getStyles = (options2) => `.label { + font-family: ${options2.fontFamily}; + color: ${options2.nodeTextColor || options2.textColor}; + } + .cluster-label text { + fill: ${options2.titleColor}; + } + .cluster-label span,p { + color: ${options2.titleColor}; + } + + + + .label text,span,p { + fill: ${options2.nodeTextColor || options2.textColor}; + color: ${options2.nodeTextColor || options2.textColor}; + } + + .node rect, + .node circle, + .node ellipse, + .node polygon, + .node path { + fill: ${options2.mainBkg}; + stroke: ${options2.nodeBorder}; + stroke-width: 1px; + } + .flowchart-label text { + text-anchor: middle; + } + // .flowchart-label .text-outer-tspan { + // text-anchor: middle; + // } + // .flowchart-label .text-inner-tspan { + // text-anchor: start; + // } + + .node .label { + text-align: center; + } + .node.clickable { + cursor: pointer; + } + + .arrowheadPath { + fill: ${options2.arrowheadColor}; + } + + .edgePath .path { + stroke: ${options2.lineColor}; + stroke-width: 2.0px; + } + + .flowchart-link { + stroke: ${options2.lineColor}; + fill: none; + } + + .edgeLabel { + background-color: ${options2.edgeLabelBackground}; + rect { + opacity: 0.5; + background-color: ${options2.edgeLabelBackground}; + fill: ${options2.edgeLabelBackground}; + } + text-align: center; + } + + /* For html labels only */ + .labelBkg { + background-color: ${fade(options2.edgeLabelBackground, 0.5)}; + // background-color: + } + + .node .cluster { + // fill: ${fade(options2.mainBkg, 0.5)}; + fill: ${fade(options2.clusterBkg, 0.5)}; + stroke: ${fade(options2.clusterBorder, 0.2)}; + box-shadow: rgba(50, 50, 93, 0.25) 0px 13px 27px -5px, rgba(0, 0, 0, 0.3) 0px 8px 16px -8px; + stroke-width: 1px; + } + + .cluster text { + fill: ${options2.titleColor}; + } + + .cluster span,p { + color: ${options2.titleColor}; + } + /* .cluster div { + color: ${options2.titleColor}; + } */ + + div.mermaidTooltip { + position: absolute; + text-align: center; + max-width: 200px; + padding: 2px; + font-family: ${options2.fontFamily}; + font-size: 12px; + background: ${options2.tertiaryColor}; + border: 1px solid ${options2.border2}; + border-radius: 2px; + pointer-events: none; + z-index: 100; + } + + .flowchartTitleText { + text-anchor: middle; + font-size: 18px; + fill: ${options2.textColor}; + } +`; + const flowStyles = getStyles; + function getNodeFromBlock(block2, db2, positioned = false) { + var _a2, _b2, _c; + const vertex = block2; + let classStr = "default"; + if ((((_a2 = vertex == null ? void 0 : vertex.classes) == null ? void 0 : _a2.length) || 0) > 0) { + classStr = ((vertex == null ? void 0 : vertex.classes) || []).join(" "); + } + classStr = classStr + " flowchart-label"; + let radius = 0; + let shape = ""; + let padding2; + switch (vertex.type) { + case "round": + radius = 5; + shape = "rect"; + break; + case "composite": + radius = 0; + shape = "composite"; + padding2 = 0; + break; + case "square": + shape = "rect"; + break; + case "diamond": + shape = "question"; + break; + case "hexagon": + shape = "hexagon"; + break; + case "block_arrow": + shape = "block_arrow"; + break; + case "odd": + shape = "rect_left_inv_arrow"; + break; + case "lean_right": + shape = "lean_right"; + break; + case "lean_left": + shape = "lean_left"; + break; + case "trapezoid": + shape = "trapezoid"; + break; + case "inv_trapezoid": + shape = "inv_trapezoid"; + break; + case "rect_left_inv_arrow": + shape = "rect_left_inv_arrow"; + break; + case "circle": + shape = "circle"; + break; + case "ellipse": + shape = "ellipse"; + break; + case "stadium": + shape = "stadium"; + break; + case "subroutine": + shape = "subroutine"; + break; + case "cylinder": + shape = "cylinder"; + break; + case "group": + shape = "rect"; + break; + case "doublecircle": + shape = "doublecircle"; + break; + default: + shape = "rect"; + } + const styles2 = getStylesFromArray((vertex == null ? void 0 : vertex.styles) || []); + const vertexText = vertex.label; + const bounds2 = vertex.size || { width: 0, height: 0, x: 0, y: 0 }; + const node2 = { + labelStyle: styles2.labelStyle, + shape, + labelText: vertexText, + rx: radius, + ry: radius, + class: classStr, + style: styles2.style, + id: vertex.id, + directions: vertex.directions, + width: bounds2.width, + height: bounds2.height, + x: bounds2.x, + y: bounds2.y, + positioned, + intersect: void 0, + type: vertex.type, + padding: padding2 ?? (((_c = (_b2 = getConfig$2()) == null ? void 0 : _b2.block) == null ? void 0 : _c.padding) || 0) + }; + return node2; + } + async function calculateBlockSize(elem, block2, db2) { + const node2 = getNodeFromBlock(block2, db2, false); + if (node2.type === "group") { + return; + } + const nodeEl = await insertNode(elem, node2); + const boundingBox = nodeEl.node().getBBox(); + const obj = db2.getBlock(node2.id); + obj.size = { width: boundingBox.width, height: boundingBox.height, x: 0, y: 0, node: nodeEl }; + db2.setBlock(obj); + nodeEl.remove(); + } + async function insertBlockPositioned(elem, block2, db2) { + const node2 = getNodeFromBlock(block2, db2, true); + const obj = db2.getBlock(node2.id); + if (obj.type !== "space") { + await insertNode(elem, node2); + block2.intersect = node2 == null ? void 0 : node2.intersect; + positionNode$1(node2); + } + } + async function performOperations(elem, blocks2, db2, operation) { + for (const block2 of blocks2) { + await operation(elem, block2, db2); + if (block2.children) { + await performOperations(elem, block2.children, db2, operation); + } + } + } + async function calculateBlockSizes(elem, blocks2, db2) { + await performOperations(elem, blocks2, db2, calculateBlockSize); + } + async function insertBlocks(elem, blocks2, db2) { + await performOperations(elem, blocks2, db2, insertBlockPositioned); + } + async function insertEdges(elem, edges2, blocks2, db2, id2) { + const g = new Graph({ + multigraph: true, + compound: true + }); + g.setGraph({ + rankdir: "TB", + nodesep: 10, + ranksep: 10, + marginx: 8, + marginy: 8 + }); + for (const block2 of blocks2) { + if (block2.size) { + g.setNode(block2.id, { + width: block2.size.width, + height: block2.size.height, + intersect: block2.intersect + }); + } + } + for (const edge of edges2) { + if (edge.start && edge.end) { + const startBlock = db2.getBlock(edge.start); + const endBlock = db2.getBlock(edge.end); + if ((startBlock == null ? void 0 : startBlock.size) && (endBlock == null ? void 0 : endBlock.size)) { + const start2 = startBlock.size; + const end2 = endBlock.size; + const points = [ + { x: start2.x, y: start2.y }, + { x: start2.x + (end2.x - start2.x) / 2, y: start2.y + (end2.y - start2.y) / 2 }, + { x: end2.x, y: end2.y } + ]; + await insertEdge$1( + elem, + { v: edge.start, w: edge.end, name: edge.id }, + { + ...edge, + arrowTypeEnd: edge.arrowTypeEnd, + arrowTypeStart: edge.arrowTypeStart, + points, + classes: "edge-thickness-normal edge-pattern-solid flowchart-link LS-a1 LE-b1" + }, + void 0, + "block", + g, + id2 + ); + if (edge.label) { + await insertEdgeLabel(elem, { + ...edge, + label: edge.label, + labelStyle: "stroke: #333; stroke-width: 1.5px;fill:none;", + arrowTypeEnd: edge.arrowTypeEnd, + arrowTypeStart: edge.arrowTypeStart, + points, + classes: "edge-thickness-normal edge-pattern-solid flowchart-link LS-a1 LE-b1" + }); + await positionEdgeLabel( + { ...edge, x: points[1].x, y: points[1].y }, + { + originalPath: points + } + ); + } + } + } + } + } + const padding = ((_b = (_a = getConfig$1()) == null ? void 0 : _a.block) == null ? void 0 : _b.padding) || 8; + function calculateBlockPosition(columns, position2) { + if (columns === 0 || !Number.isInteger(columns)) { + throw new Error("Columns must be an integer !== 0."); + } + if (position2 < 0 || !Number.isInteger(position2)) { + throw new Error("Position must be a non-negative integer." + position2); + } + if (columns < 0) { + return { px: position2, py: 0 }; + } + if (columns === 1) { + return { px: 0, py: position2 }; + } + const px = position2 % columns; + const py = Math.floor(position2 / columns); + return { px, py }; + } + const getMaxChildSize = (block2) => { + let maxWidth = 0; + let maxHeight = 0; + for (const child of block2.children) { + const { width: width2, height, x: x2, y: y2 } = child.size || { width: 0, height: 0, x: 0, y: 0 }; + log$1.debug( + "getMaxChildSize abc95 child:", + child.id, + "width:", + width2, + "height:", + height, + "x:", + x2, + "y:", + y2, + child.type + ); + if (child.type === "space") { + continue; + } + if (width2 > maxWidth) { + maxWidth = width2 / (block2.widthInColumns || 1); + } + if (height > maxHeight) { + maxHeight = height; + } + } + return { width: maxWidth, height: maxHeight }; + }; + function setBlockSizes(block2, db2, siblingWidth = 0, siblingHeight = 0) { + var _a2, _b2, _c, _d, _e, _f, _g, _h, _i6, _j, _k; + log$1.debug( + "setBlockSizes abc95 (start)", + block2.id, + (_a2 = block2 == null ? void 0 : block2.size) == null ? void 0 : _a2.x, + "block width =", + block2 == null ? void 0 : block2.size, + "sieblingWidth", + siblingWidth + ); + if (!((_b2 = block2 == null ? void 0 : block2.size) == null ? void 0 : _b2.width)) { + block2.size = { + width: siblingWidth, + height: siblingHeight, + x: 0, + y: 0 + }; + } + let maxWidth = 0; + let maxHeight = 0; + if (((_c = block2.children) == null ? void 0 : _c.length) > 0) { + for (const child of block2.children) { + setBlockSizes(child, db2); + } + const childSize = getMaxChildSize(block2); + maxWidth = childSize.width; + maxHeight = childSize.height; + log$1.debug("setBlockSizes abc95 maxWidth of", block2.id, ":s children is ", maxWidth, maxHeight); + for (const child of block2.children) { + if (child.size) { + log$1.debug( + `abc95 Setting size of children of ${block2.id} id=${child.id} ${maxWidth} ${maxHeight} ${child.size}` + ); + child.size.width = maxWidth * (child.widthInColumns || 1) + padding * ((child.widthInColumns || 1) - 1); + child.size.height = maxHeight; + child.size.x = 0; + child.size.y = 0; + log$1.debug( + `abc95 updating size of ${block2.id} children child:${child.id} maxWidth:${maxWidth} maxHeight:${maxHeight}` + ); + } + } + for (const child of block2.children) { + setBlockSizes(child, db2, maxWidth, maxHeight); + } + const columns = block2.columns || -1; + let numItems = 0; + for (const child of block2.children) { + numItems += child.widthInColumns || 1; + } + let xSize = block2.children.length; + if (columns > 0 && columns < numItems) { + xSize = columns; + } + block2.widthInColumns || 1; + const ySize = Math.ceil(numItems / xSize); + let width2 = xSize * (maxWidth + padding) + padding; + let height = ySize * (maxHeight + padding) + padding; + if (width2 < siblingWidth) { + log$1.debug( + `Detected to small siebling: abc95 ${block2.id} sieblingWidth ${siblingWidth} sieblingHeight ${siblingHeight} width ${width2}` + ); + width2 = siblingWidth; + height = siblingHeight; + const childWidth = (siblingWidth - xSize * padding - padding) / xSize; + const childHeight = (siblingHeight - ySize * padding - padding) / ySize; + log$1.debug("Size indata abc88", block2.id, "childWidth", childWidth, "maxWidth", maxWidth); + log$1.debug("Size indata abc88", block2.id, "childHeight", childHeight, "maxHeight", maxHeight); + log$1.debug("Size indata abc88 xSize", xSize, "padding", padding); + for (const child of block2.children) { + if (child.size) { + child.size.width = childWidth; + child.size.height = childHeight; + child.size.x = 0; + child.size.y = 0; + } + } + } + log$1.debug( + `abc95 (finale calc) ${block2.id} xSize ${xSize} ySize ${ySize} columns ${columns}${block2.children.length} width=${Math.max(width2, ((_d = block2.size) == null ? void 0 : _d.width) || 0)}` + ); + if (width2 < (((_e = block2 == null ? void 0 : block2.size) == null ? void 0 : _e.width) || 0)) { + width2 = ((_f = block2 == null ? void 0 : block2.size) == null ? void 0 : _f.width) || 0; + const num = columns > 0 ? Math.min(block2.children.length, columns) : block2.children.length; + if (num > 0) { + const childWidth = (width2 - num * padding - padding) / num; + log$1.debug("abc95 (growing to fit) width", block2.id, width2, (_g = block2.size) == null ? void 0 : _g.width, childWidth); + for (const child of block2.children) { + if (child.size) { + child.size.width = childWidth; + } + } + } + } + block2.size = { + width: width2, + height, + x: 0, + y: 0 + }; + } + log$1.debug( + "setBlockSizes abc94 (done)", + block2.id, + (_h = block2 == null ? void 0 : block2.size) == null ? void 0 : _h.x, + (_i6 = block2 == null ? void 0 : block2.size) == null ? void 0 : _i6.width, + (_j = block2 == null ? void 0 : block2.size) == null ? void 0 : _j.y, + (_k = block2 == null ? void 0 : block2.size) == null ? void 0 : _k.height + ); + } + function layoutBlocks(block2, db2) { + var _a2, _b2, _c, _d, _e, _f, _g, _h, _i6, _j, _k, _l, _m, _n, _o, _p, _q; + log$1.debug( + `abc85 layout blocks (=>layoutBlocks) ${block2.id} x: ${(_a2 = block2 == null ? void 0 : block2.size) == null ? void 0 : _a2.x} y: ${(_b2 = block2 == null ? void 0 : block2.size) == null ? void 0 : _b2.y} width: ${(_c = block2 == null ? void 0 : block2.size) == null ? void 0 : _c.width}` + ); + const columns = block2.columns || -1; + log$1.debug("layoutBlocks columns abc95", block2.id, "=>", columns, block2); + if (block2.children && // find max width of children + block2.children.length > 0) { + const width2 = ((_e = (_d = block2 == null ? void 0 : block2.children[0]) == null ? void 0 : _d.size) == null ? void 0 : _e.width) || 0; + const widthOfChildren = block2.children.length * width2 + (block2.children.length - 1) * padding; + log$1.debug("widthOfChildren 88", widthOfChildren, "posX"); + let columnPos = 0; + log$1.debug("abc91 block?.size?.x", block2.id, (_f = block2 == null ? void 0 : block2.size) == null ? void 0 : _f.x); + let startingPosX = ((_g = block2 == null ? void 0 : block2.size) == null ? void 0 : _g.x) ? ((_h = block2 == null ? void 0 : block2.size) == null ? void 0 : _h.x) + (-((_i6 = block2 == null ? void 0 : block2.size) == null ? void 0 : _i6.width) / 2 || 0) : -padding; + let rowPos = 0; + for (const child of block2.children) { + const parent = block2; + if (!child.size) { + continue; + } + const { width: width22, height } = child.size; + const { px, py } = calculateBlockPosition(columns, columnPos); + if (py != rowPos) { + rowPos = py; + startingPosX = ((_j = block2 == null ? void 0 : block2.size) == null ? void 0 : _j.x) ? ((_k = block2 == null ? void 0 : block2.size) == null ? void 0 : _k.x) + (-((_l = block2 == null ? void 0 : block2.size) == null ? void 0 : _l.width) / 2 || 0) : -padding; + log$1.debug("New row in layout for block", block2.id, " and child ", child.id, rowPos); + } + log$1.debug( + `abc89 layout blocks (child) id: ${child.id} Pos: ${columnPos} (px, py) ${px},${py} (${(_m = parent == null ? void 0 : parent.size) == null ? void 0 : _m.x},${(_n = parent == null ? void 0 : parent.size) == null ? void 0 : _n.y}) parent: ${parent.id} width: ${width22}${padding}` + ); + if (parent.size) { + const halfWidth = width22 / 2; + child.size.x = startingPosX + padding + halfWidth; + log$1.debug( + `abc91 layout blocks (calc) px, pyid:${child.id} startingPos=X${startingPosX} new startingPosX${child.size.x} ${halfWidth} padding=${padding} width=${width22} halfWidth=${halfWidth} => x:${child.size.x} y:${child.size.y} ${child.widthInColumns} (width * (child?.w || 1)) / 2 ${width22 * ((child == null ? void 0 : child.widthInColumns) || 1) / 2}` + ); + startingPosX = child.size.x + halfWidth; + child.size.y = parent.size.y - parent.size.height / 2 + py * (height + padding) + height / 2 + padding; + log$1.debug( + `abc88 layout blocks (calc) px, pyid:${child.id}startingPosX${startingPosX}${padding}${halfWidth}=>x:${child.size.x}y:${child.size.y}${child.widthInColumns}(width * (child?.w || 1)) / 2${width22 * ((child == null ? void 0 : child.widthInColumns) || 1) / 2}` + ); + } + if (child.children) { + layoutBlocks(child); + } + columnPos += (child == null ? void 0 : child.widthInColumns) || 1; + log$1.debug("abc88 columnsPos", child, columnPos); + } + } + log$1.debug( + `layout blocks (<==layoutBlocks) ${block2.id} x: ${(_o = block2 == null ? void 0 : block2.size) == null ? void 0 : _o.x} y: ${(_p = block2 == null ? void 0 : block2.size) == null ? void 0 : _p.y} width: ${(_q = block2 == null ? void 0 : block2.size) == null ? void 0 : _q.width}` + ); + } + function findBounds(block2, { minX, minY, maxX, maxY } = { minX: 0, minY: 0, maxX: 0, maxY: 0 }) { + if (block2.size && block2.id !== "root") { + const { x: x2, y: y2, width: width2, height } = block2.size; + if (x2 - width2 / 2 < minX) { + minX = x2 - width2 / 2; + } + if (y2 - height / 2 < minY) { + minY = y2 - height / 2; + } + if (x2 + width2 / 2 > maxX) { + maxX = x2 + width2 / 2; + } + if (y2 + height / 2 > maxY) { + maxY = y2 + height / 2; + } + } + if (block2.children) { + for (const child of block2.children) { + ({ minX, minY, maxX, maxY } = findBounds(child, { minX, minY, maxX, maxY })); + } + } + return { minX, minY, maxX, maxY }; + } + function layout(db2) { + const root2 = db2.getBlock("root"); + if (!root2) { + return; + } + setBlockSizes(root2, db2, 0, 0); + layoutBlocks(root2); + log$1.debug("getBlocks", JSON.stringify(root2, null, 2)); + const { minX, minY, maxX, maxY } = findBounds(root2); + const height = maxY - minY; + const width2 = maxX - minX; + return { x: minX, y: minY, width: width2, height }; + } + const getClasses = function(text2, diagObj) { + return diagObj.db.getClasses(); + }; + const draw = async function(text2, id2, _version, diagObj) { + const { securityLevel, block: conf2 } = getConfig$2(); + const db2 = diagObj.db; + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = d3select("#i" + id2); + } + const root2 = securityLevel === "sandbox" ? d3select(sandboxElement.nodes()[0].contentDocument.body) : d3select("body"); + const svg2 = securityLevel === "sandbox" ? root2.select(`[id="${id2}"]`) : d3select(`[id="${id2}"]`); + const markers2 = ["point", "circle", "cross"]; + insertMarkers$4(svg2, markers2, diagObj.type, id2); + const bl = db2.getBlocks(); + const blArr = db2.getBlocksFlat(); + const edges2 = db2.getEdges(); + const nodes2 = svg2.insert("g").attr("class", "block"); + await calculateBlockSizes(nodes2, bl, db2); + const bounds2 = layout(db2); + await insertBlocks(nodes2, bl, db2); + await insertEdges(nodes2, edges2, blArr, db2, id2); + if (bounds2) { + const bounds22 = bounds2; + const magicFactor = Math.max(1, Math.round(0.125 * (bounds22.width / bounds22.height))); + const height = bounds22.height + magicFactor + 10; + const width2 = bounds22.width + 10; + const { useMaxWidth } = conf2; + configureSvgSize(svg2, height, width2, !!useMaxWidth); + log$1.debug("Here Bounds", bounds2, bounds22); + svg2.attr( + "viewBox", + `${bounds22.x - 5} ${bounds22.y - 5} ${bounds22.width + 10} ${bounds22.height + 10}` + ); + } + ordinal(d3schemeTableau10); + }; + const renderer = { + draw, + getClasses + }; + const diagram = { + parser: parser$1, + db: db$1, + renderer, + styles: flowStyles + }; + const blockDiagram = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + diagram + }, Symbol.toStringTag, { value: "Module" })); + return mermaid; +}); diff --git a/0.6.0/js/mermaid/mermaid.min.js b/0.6.0/js/mermaid/mermaid.min.js new file mode 100644 index 0000000..3dce007 --- /dev/null +++ b/0.6.0/js/mermaid/mermaid.min.js @@ -0,0 +1,2029 @@ +(function(JM,Ag){typeof exports=="object"&&typeof module<"u"?module.exports=Ag():typeof define=="function"&&define.amd?define(Ag):(JM=typeof globalThis<"u"?globalThis:JM||self,JM.mermaid=Ag())})(this,function(){var FWe,RWe;"use strict";function JM(i){for(var s=[],u=1;u=Pe?Fe:""+Array(Pe+1-Ie.length).join(je)+Fe},be={s:pe,z:function(Fe){var Pe=-Fe.utcOffset(),je=Math.abs(Pe),Ie=Math.floor(je/60),Se=je%60;return(Pe<=0?"+":"-")+pe(Ie,2,"0")+":"+pe(Se,2,"0")},m:function Fe(Pe,je){if(Pe.date()1)return Fe(ke[0])}else{var Ke=Pe.name;ne[Ke]=Pe,Se=Ke}return!Ie&&Se&&(ae=Se),Se||!Ie&&ae},ge=function(Fe,Pe){if(de(Fe))return Fe.clone();var je=typeof Pe=="object"?Pe:{};return je.date=Fe,je.args=arguments,new xe(je)},W=be;W.l=X,W.i=de,W.w=function(Fe,Pe){return ge(Fe,{locale:Pe.$L,utc:Pe.$u,x:Pe.$x,$offset:Pe.$offset})};var xe=function(){function Fe(je){this.$L=X(je.locale,null,!0),this.parse(je),this.$x=this.$x||je.x||{},this[se]=!0}var Pe=Fe.prototype;return Pe.parse=function(je){this.$d=function(Ie){var Se=Ie.date,Ce=Ie.utc;if(Se===null)return new Date(NaN);if(W.u(Se))return new Date;if(Se instanceof Date)return new Date(Se);if(typeof Se=="string"&&!/Z$/i.test(Se)){var ke=Se.match(ee);if(ke){var Ke=ke[2]-1||0,Ft=(ke[7]||"0").substring(0,3);return Ce?new Date(Date.UTC(ke[1],Ke,ke[3]||1,ke[4]||0,ke[5]||0,ke[6]||0,Ft)):new Date(ke[1],Ke,ke[3]||1,ke[4]||0,ke[5]||0,ke[6]||0,Ft)}}return new Date(Se)}(je),this.init()},Pe.init=function(){var je=this.$d;this.$y=je.getFullYear(),this.$M=je.getMonth(),this.$D=je.getDate(),this.$W=je.getDay(),this.$H=je.getHours(),this.$m=je.getMinutes(),this.$s=je.getSeconds(),this.$ms=je.getMilliseconds()},Pe.$utils=function(){return W},Pe.isValid=function(){return this.$d.toString()!==K},Pe.isSame=function(je,Ie){var Se=ge(je);return this.startOf(Ie)<=Se&&Se<=this.endOf(Ie)},Pe.isAfter=function(je,Ie){return ge(je){},debug:(...i)=>{},info:(...i)=>{},warn:(...i)=>{},error:(...i)=>{},fatal:(...i)=>{}},fpe=function(i="fatal"){let s=g7.fatal;typeof i=="string"?(i=i.toLowerCase(),i in g7&&(s=g7[i])):typeof i=="number"&&(s=i),Xe.trace=()=>{},Xe.debug=()=>{},Xe.info=()=>{},Xe.warn=()=>{},Xe.error=()=>{},Xe.fatal=()=>{},s<=g7.fatal&&(Xe.fatal=console.error?console.error.bind(console,Lv("FATAL"),"color: orange"):console.log.bind(console,"\x1B[35m",Lv("FATAL"))),s<=g7.error&&(Xe.error=console.error?console.error.bind(console,Lv("ERROR"),"color: orange"):console.log.bind(console,"\x1B[31m",Lv("ERROR"))),s<=g7.warn&&(Xe.warn=console.warn?console.warn.bind(console,Lv("WARN"),"color: orange"):console.log.bind(console,"\x1B[33m",Lv("WARN"))),s<=g7.info&&(Xe.info=console.info?console.info.bind(console,Lv("INFO"),"color: lightblue"):console.log.bind(console,"\x1B[34m",Lv("INFO"))),s<=g7.debug&&(Xe.debug=console.debug?console.debug.bind(console,Lv("DEBUG"),"color: lightgreen"):console.log.bind(console,"\x1B[32m",Lv("DEBUG"))),s<=g7.trace&&(Xe.trace=console.debug?console.debug.bind(console,Lv("TRACE"),"color: lightgreen"):console.log.bind(console,"\x1B[32m",Lv("TRACE")))},Lv=i=>`%c${Lg().format("ss.SSS")} : ${i} : `;var p9={};(function(i){Object.defineProperty(i,"__esModule",{value:!0}),i.sanitizeUrl=i.BLANK_URL=void 0;var s=/^([^\w]*)(javascript|data|vbscript)/im,u=/&#(\w+)(^\w|;)?/g,d=/&(newline|tab);/gi,p=/[\u0000-\u001F\u007F-\u009F\u2000-\u200D\uFEFF]/gim,v=/^.+(:|:)/gim,b=[".","/"];i.BLANK_URL="about:blank";function y(A){return b.indexOf(A[0])>-1}function T(A){var P=A.replace(p,"");return P.replace(u,function(R,F){return String.fromCharCode(F)})}function _(A){if(!A)return i.BLANK_URL;var P=T(A).replace(d,"").replace(p,"").trim();if(!P)return i.BLANK_URL;if(y(P))return P;var R=P.match(v);if(!R)return P;var F=R[0];return s.test(F)?i.BLANK_URL:P}i.sanitizeUrl=_})(p9);function DY(i,s){return i==null||s==null?NaN:is?1:i>=s?0:NaN}function PAt(i,s){return i==null||s==null?NaN:si?1:s>=i?0:NaN}function dpe(i){let s,u,d;i.length!==2?(s=DY,u=(y,T)=>DY(i(y),T),d=(y,T)=>i(y)-T):(s=i===DY||i===PAt?i:BAt,u=i,d=i);function p(y,T,_=0,A=y.length){if(_>>1;u(y[P],T)<0?_=P+1:A=P}while(_>>1;u(y[P],T)<=0?_=P+1:A=P}while(__&&d(y[P-1],T)>-d(y[P],T)?P-1:P}return{left:p,center:b,right:v}}function BAt(){return 0}function FAt(i){return i===null?NaN:+i}const RAt=dpe(DY).right;dpe(FAt).center;const jAt=RAt;class cBe extends Map{constructor(s,u=qAt){if(super(),Object.defineProperties(this,{_intern:{value:new Map},_key:{value:u}}),s!=null)for(const[d,p]of s)this.set(d,p)}get(s){return super.get(uBe(this,s))}has(s){return super.has(uBe(this,s))}set(s,u){return super.set($At(this,s),u)}delete(s){return super.delete(zAt(this,s))}}function uBe({_intern:i,_key:s},u){const d=s(u);return i.has(d)?i.get(d):u}function $At({_intern:i,_key:s},u){const d=s(u);return i.has(d)?i.get(d):(i.set(d,u),u)}function zAt({_intern:i,_key:s},u){const d=s(u);return i.has(d)&&(u=i.get(d),i.delete(d)),u}function qAt(i){return i!==null&&typeof i=="object"?i.valueOf():i}const HAt=Math.sqrt(50),VAt=Math.sqrt(10),UAt=Math.sqrt(2);function IY(i,s,u){const d=(s-i)/Math.max(0,u),p=Math.floor(Math.log10(d)),v=d/Math.pow(10,p),b=v>=HAt?10:v>=VAt?5:v>=UAt?2:1;let y,T,_;return p<0?(_=Math.pow(10,-p)/b,y=Math.round(i*_),T=Math.round(s*_),y/_s&&--T,_=-_):(_=Math.pow(10,p)*b,y=Math.round(i/_),T=Math.round(s/_),y*_s&&--T),T0))return[];if(i===s)return[i];const d=s=p))return[];const y=v-p+1,T=new Array(y);if(d)if(b<0)for(let _=0;_=d)&&(u=d);else{let d=-1;for(let p of i)(p=s(p,++d,i))!=null&&(u=p)&&(u=p)}return u}function WAt(i,s){let u;if(s===void 0)for(const d of i)d!=null&&(u>d||u===void 0&&d>=d)&&(u=d);else{let d=-1;for(let p of i)(p=s(p,++d,i))!=null&&(u>p||u===void 0&&p>=p)&&(u=p)}return u}function YAt(i,s,u){i=+i,s=+s,u=(p=arguments.length)<2?(s=i,i=0,1):p<3?1:+u;for(var d=-1,p=Math.max(0,Math.ceil((s-i)/u))|0,v=new Array(p);++d+i(s)}function eLt(i,s){return s=Math.max(0,i.bandwidth()-s*2)/2,i.round()&&(s=Math.round(s)),u=>+i(u)+s}function tLt(){return!this.__axis}function hBe(i,s){var u=[],d=null,p=null,v=6,b=6,y=3,T=typeof window<"u"&&window.devicePixelRatio>1?0:.5,_=i===OY||i===NY?-1:1,A=i===NY||i===bpe?"x":"y",P=i===OY||i===mpe?QAt:JAt;function R(F){var j=d??(s.ticks?s.ticks.apply(s,u):s.domain()),K=p??(s.tickFormat?s.tickFormat.apply(s,u):XAt),ee=Math.max(v,0)+y,ie=s.range(),oe=+ie[0]+T,pe=+ie[ie.length-1]+T,be=(s.bandwidth?eLt:ZAt)(s.copy(),T),ae=F.selection?F.selection():F,ne=ae.selectAll(".domain").data([null]),se=ae.selectAll(".tick").data(j,s).order(),de=se.exit(),X=se.enter().append("g").attr("class","tick"),ge=se.select("line"),W=se.select("text");ne=ne.merge(ne.enter().insert("path",".tick").attr("class","domain").attr("stroke","currentColor")),se=se.merge(X),ge=ge.merge(X.append("line").attr("stroke","currentColor").attr(A+"2",_*v)),W=W.merge(X.append("text").attr("fill","currentColor").attr(A,_*ee).attr("dy",i===OY?"0em":i===mpe?"0.71em":"0.32em")),F!==ae&&(ne=ne.transition(F),se=se.transition(F),ge=ge.transition(F),W=W.transition(F),de=de.transition(F).attr("opacity",lBe).attr("transform",function(xe){return isFinite(xe=be(xe))?P(xe+T):this.getAttribute("transform")}),X.attr("opacity",lBe).attr("transform",function(xe){var U=this.parentNode.__axis;return P((U&&isFinite(U=U(xe))?U:be(xe))+T)})),de.remove(),ne.attr("d",i===NY||i===bpe?b?"M"+_*b+","+oe+"H"+T+"V"+pe+"H"+_*b:"M"+T+","+oe+"V"+pe:b?"M"+oe+","+_*b+"V"+T+"H"+pe+"V"+_*b:"M"+oe+","+T+"H"+pe),se.attr("opacity",1).attr("transform",function(xe){return P(be(xe)+T)}),ge.attr(A+"2",_*v),W.attr(A,_*ee).text(K),ae.filter(tLt).attr("fill","none").attr("font-size",10).attr("font-family","sans-serif").attr("text-anchor",i===bpe?"start":i===NY?"end":"middle"),ae.each(function(){this.__axis=be})}return R.scale=function(F){return arguments.length?(s=F,R):s},R.ticks=function(){return u=Array.from(arguments),R},R.tickArguments=function(F){return arguments.length?(u=F==null?[]:Array.from(F),R):u.slice()},R.tickValues=function(F){return arguments.length?(d=F==null?null:Array.from(F),R):d&&d.slice()},R.tickFormat=function(F){return arguments.length?(p=F,R):p},R.tickSize=function(F){return arguments.length?(v=b=+F,R):v},R.tickSizeInner=function(F){return arguments.length?(v=+F,R):v},R.tickSizeOuter=function(F){return arguments.length?(b=+F,R):b},R.tickPadding=function(F){return arguments.length?(y=+F,R):y},R.offset=function(F){return arguments.length?(T=+F,R):T},R}function nLt(i){return hBe(OY,i)}function rLt(i){return hBe(mpe,i)}var iLt={value:()=>{}};function fBe(){for(var i=0,s=arguments.length,u={},d;i=0&&(d=u.slice(p+1),u=u.slice(0,p)),u&&!s.hasOwnProperty(u))throw new Error("unknown type: "+u);return{type:u,name:d}})}PY.prototype=fBe.prototype={constructor:PY,on:function(i,s){var u=this._,d=sLt(i+"",u),p,v=-1,b=d.length;if(arguments.length<2){for(;++v0)for(var u=new Array(p),d=0,p,v;d=0&&(s=i.slice(0,u))!=="xmlns"&&(i=i.slice(u+1)),gBe.hasOwnProperty(s)?{space:gBe[s],local:i}:i}function oLt(i){return function(){var s=this.ownerDocument,u=this.namespaceURI;return u===vpe&&s.documentElement.namespaceURI===vpe?s.createElement(i):s.createElementNS(u,i)}}function cLt(i){return function(){return this.ownerDocument.createElementNS(i.space,i.local)}}function pBe(i){var s=BY(i);return(s.local?cLt:oLt)(s)}function uLt(){}function wpe(i){return i==null?uLt:function(){return this.querySelector(i)}}function lLt(i){typeof i!="function"&&(i=wpe(i));for(var s=this._groups,u=s.length,d=new Array(u),p=0;p=pe&&(pe=oe+1);!(ae=ee[pe])&&++pe=0;)(b=d[p])&&(v&&b.compareDocumentPosition(v)^4&&v.parentNode.insertBefore(b,v),v=b);return this}function NLt(i){i||(i=PLt);function s(P,R){return P&&R?i(P.__data__,R.__data__):!P-!R}for(var u=this._groups,d=u.length,p=new Array(d),v=0;vs?1:i>=s?0:NaN}function BLt(){var i=arguments[0];return arguments[0]=this,i.apply(null,arguments),this}function FLt(){return Array.from(this)}function RLt(){for(var i=this._groups,s=0,u=i.length;s1?this.each((s==null?YLt:typeof s=="function"?QLt:XLt)(i,s,u??"")):ZM(this.node(),i)}function ZM(i,s){return i.style.getPropertyValue(s)||xBe(i).getComputedStyle(i,null).getPropertyValue(s)}function ZLt(i){return function(){delete this[i]}}function eMt(i,s){return function(){this[i]=s}}function tMt(i,s){return function(){var u=s.apply(this,arguments);u==null?delete this[i]:this[i]=u}}function nMt(i,s){return arguments.length>1?this.each((s==null?ZLt:typeof s=="function"?tMt:eMt)(i,s)):this.node()[i]}function kBe(i){return i.trim().split(/^|\s+/)}function ype(i){return i.classList||new EBe(i)}function EBe(i){this._node=i,this._names=kBe(i.getAttribute("class")||"")}EBe.prototype={add:function(i){var s=this._names.indexOf(i);s<0&&(this._names.push(i),this._node.setAttribute("class",this._names.join(" ")))},remove:function(i){var s=this._names.indexOf(i);s>=0&&(this._names.splice(s,1),this._node.setAttribute("class",this._names.join(" ")))},contains:function(i){return this._names.indexOf(i)>=0}};function TBe(i,s){for(var u=ype(i),d=-1,p=s.length;++d=0&&(u=s.slice(d+1),s=s.slice(0,d)),{type:s,name:u}})}function MMt(i){return function(){var s=this.__on;if(s){for(var u=0,d=-1,p=s.length,v;u>8&15|s>>4&240,s>>4&15|s&240,(s&15)<<4|s&15,1):u===8?$Y(s>>24&255,s>>16&255,s>>8&255,(s&255)/255):u===4?$Y(s>>12&15|s>>8&240,s>>8&15|s>>4&240,s>>4&15|s&240,((s&15)<<4|s&15)/255):null):(s=jMt.exec(i))?new Mg(s[1],s[2],s[3],1):(s=$Mt.exec(i))?new Mg(s[1]*255/100,s[2]*255/100,s[3]*255/100,1):(s=zMt.exec(i))?$Y(s[1],s[2],s[3],s[4]):(s=qMt.exec(i))?$Y(s[1]*255/100,s[2]*255/100,s[3]*255/100,s[4]):(s=HMt.exec(i))?PBe(s[1],s[2]/100,s[3]/100,1):(s=VMt.exec(i))?PBe(s[1],s[2]/100,s[3]/100,s[4]):ABe.hasOwnProperty(i)?DBe(ABe[i]):i==="transparent"?new Mg(NaN,NaN,NaN,0):null}function DBe(i){return new Mg(i>>16&255,i>>8&255,i&255,1)}function $Y(i,s,u,d){return d<=0&&(i=s=u=NaN),new Mg(i,s,u,d)}function IBe(i){return i instanceof fC||(i=dC(i)),i?(i=i.rgb(),new Mg(i.r,i.g,i.b,i.opacity)):new Mg}function kpe(i,s,u,d){return arguments.length===1?IBe(i):new Mg(i,s,u,d??1)}function Mg(i,s,u,d){this.r=+i,this.g=+s,this.b=+u,this.opacity=+d}wF(Mg,kpe,RY(fC,{brighter(i){return i=i==null?jY:Math.pow(jY,i),new Mg(this.r*i,this.g*i,this.b*i,this.opacity)},darker(i){return i=i==null?yF:Math.pow(yF,i),new Mg(this.r*i,this.g*i,this.b*i,this.opacity)},rgb(){return this},clamp(){return new Mg(gC(this.r),gC(this.g),gC(this.b),zY(this.opacity))},displayable(){return-.5<=this.r&&this.r<255.5&&-.5<=this.g&&this.g<255.5&&-.5<=this.b&&this.b<255.5&&0<=this.opacity&&this.opacity<=1},hex:OBe,formatHex:OBe,formatHex8:KMt,formatRgb:NBe,toString:NBe}));function OBe(){return`#${pC(this.r)}${pC(this.g)}${pC(this.b)}`}function KMt(){return`#${pC(this.r)}${pC(this.g)}${pC(this.b)}${pC((isNaN(this.opacity)?1:this.opacity)*255)}`}function NBe(){const i=zY(this.opacity);return`${i===1?"rgb(":"rgba("}${gC(this.r)}, ${gC(this.g)}, ${gC(this.b)}${i===1?")":`, ${i})`}`}function zY(i){return isNaN(i)?1:Math.max(0,Math.min(1,i))}function gC(i){return Math.max(0,Math.min(255,Math.round(i)||0))}function pC(i){return i=gC(i),(i<16?"0":"")+i.toString(16)}function PBe(i,s,u,d){return d<=0?i=s=u=NaN:u<=0||u>=1?i=s=NaN:s<=0&&(i=NaN),new A3(i,s,u,d)}function BBe(i){if(i instanceof A3)return new A3(i.h,i.s,i.l,i.opacity);if(i instanceof fC||(i=dC(i)),!i)return new A3;if(i instanceof A3)return i;i=i.rgb();var s=i.r/255,u=i.g/255,d=i.b/255,p=Math.min(s,u,d),v=Math.max(s,u,d),b=NaN,y=v-p,T=(v+p)/2;return y?(s===v?b=(u-d)/y+(u0&&T<1?0:b,new A3(b,y,T,i.opacity)}function WMt(i,s,u,d){return arguments.length===1?BBe(i):new A3(i,s,u,d??1)}function A3(i,s,u,d){this.h=+i,this.s=+s,this.l=+u,this.opacity=+d}wF(A3,WMt,RY(fC,{brighter(i){return i=i==null?jY:Math.pow(jY,i),new A3(this.h,this.s,this.l*i,this.opacity)},darker(i){return i=i==null?yF:Math.pow(yF,i),new A3(this.h,this.s,this.l*i,this.opacity)},rgb(){var i=this.h%360+(this.h<0)*360,s=isNaN(i)||isNaN(this.s)?0:this.s,u=this.l,d=u+(u<.5?u:1-u)*s,p=2*u-d;return new Mg(Epe(i>=240?i-240:i+120,p,d),Epe(i,p,d),Epe(i<120?i+240:i-120,p,d),this.opacity)},clamp(){return new A3(FBe(this.h),qY(this.s),qY(this.l),zY(this.opacity))},displayable(){return(0<=this.s&&this.s<=1||isNaN(this.s))&&0<=this.l&&this.l<=1&&0<=this.opacity&&this.opacity<=1},formatHsl(){const i=zY(this.opacity);return`${i===1?"hsl(":"hsla("}${FBe(this.h)}, ${qY(this.s)*100}%, ${qY(this.l)*100}%${i===1?")":`, ${i})`}`}}));function FBe(i){return i=(i||0)%360,i<0?i+360:i}function qY(i){return Math.max(0,Math.min(1,i||0))}function Epe(i,s,u){return(i<60?s+(u-s)*i/60:i<180?u:i<240?s+(u-s)*(240-i)/60:s)*255}const YMt=Math.PI/180,XMt=180/Math.PI,HY=18,RBe=.96422,jBe=1,$Be=.82521,zBe=4/29,tD=6/29,qBe=3*tD*tD,QMt=tD*tD*tD;function HBe(i){if(i instanceof j4)return new j4(i.l,i.a,i.b,i.opacity);if(i instanceof p7)return VBe(i);i instanceof Mg||(i=IBe(i));var s=_pe(i.r),u=_pe(i.g),d=_pe(i.b),p=Tpe((.2225045*s+.7168786*u+.0606169*d)/jBe),v,b;return s===u&&u===d?v=b=p:(v=Tpe((.4360747*s+.3850649*u+.1430804*d)/RBe),b=Tpe((.0139322*s+.0971045*u+.7141733*d)/$Be)),new j4(116*p-16,500*(v-p),200*(p-b),i.opacity)}function JMt(i,s,u,d){return arguments.length===1?HBe(i):new j4(i,s,u,d??1)}function j4(i,s,u,d){this.l=+i,this.a=+s,this.b=+u,this.opacity=+d}wF(j4,JMt,RY(fC,{brighter(i){return new j4(this.l+HY*(i??1),this.a,this.b,this.opacity)},darker(i){return new j4(this.l-HY*(i??1),this.a,this.b,this.opacity)},rgb(){var i=(this.l+16)/116,s=isNaN(this.a)?i:i+this.a/500,u=isNaN(this.b)?i:i-this.b/200;return s=RBe*Cpe(s),i=jBe*Cpe(i),u=$Be*Cpe(u),new Mg(Spe(3.1338561*s-1.6168667*i-.4906146*u),Spe(-.9787684*s+1.9161415*i+.033454*u),Spe(.0719453*s-.2289914*i+1.4052427*u),this.opacity)}}));function Tpe(i){return i>QMt?Math.pow(i,1/3):i/qBe+zBe}function Cpe(i){return i>tD?i*i*i:qBe*(i-zBe)}function Spe(i){return 255*(i<=.0031308?12.92*i:1.055*Math.pow(i,1/2.4)-.055)}function _pe(i){return(i/=255)<=.04045?i/12.92:Math.pow((i+.055)/1.055,2.4)}function ZMt(i){if(i instanceof p7)return new p7(i.h,i.c,i.l,i.opacity);if(i instanceof j4||(i=HBe(i)),i.a===0&&i.b===0)return new p7(NaN,0()=>i;function UBe(i,s){return function(u){return i+u*s}}function eDt(i,s,u){return i=Math.pow(i,u),s=Math.pow(s,u)-i,u=1/u,function(d){return Math.pow(i+d*s,u)}}function tDt(i,s){var u=s-i;return u?UBe(i,u>180||u<-180?u-360*Math.round(u/360):u):VY(isNaN(i)?s:i)}function nDt(i){return(i=+i)==1?kF:function(s,u){return u-s?eDt(s,u,i):VY(isNaN(s)?u:s)}}function kF(i,s){var u=s-i;return u?UBe(i,u):VY(isNaN(i)?s:i)}const UY=function i(s){var u=nDt(s);function d(p,v){var b=u((p=kpe(p)).r,(v=kpe(v)).r),y=u(p.g,v.g),T=u(p.b,v.b),_=kF(p.opacity,v.opacity);return function(A){return p.r=b(A),p.g=y(A),p.b=T(A),p.opacity=_(A),p+""}}return d.gamma=i,d}(1);function rDt(i,s){s||(s=[]);var u=i?Math.min(s.length,i.length):0,d=s.slice(),p;return function(v){for(p=0;pu&&(v=s.slice(u,v),y[b]?y[b]+=v:y[++b]=v),(d=d[0])===(p=p[0])?y[b]?y[b]+=p:y[++b]=p:(y[++b]=null,T.push({i:b,x:L3(d,p)})),u=Mpe.lastIndex;return u180?A+=360:A-_>180&&(_+=360),R.push({i:P.push(p(P)+"rotate(",null,d)-2,x:L3(_,A)})):A&&P.push(p(P)+"rotate("+A+d)}function y(_,A,P,R){_!==A?R.push({i:P.push(p(P)+"skewX(",null,d)-2,x:L3(_,A)}):A&&P.push(p(P)+"skewX("+A+d)}function T(_,A,P,R,F,j){if(_!==P||A!==R){var K=F.push(p(F)+"scale(",null,",",null,")");j.push({i:K-4,x:L3(_,P)},{i:K-2,x:L3(A,R)})}else(P!==1||R!==1)&&F.push(p(F)+"scale("+P+","+R+")")}return function(_,A){var P=[],R=[];return _=i(_),A=i(A),v(_.translateX,_.translateY,A.translateX,A.translateY,P,R),b(_.rotate,A.rotate,P,R),y(_.skewX,A.skewX,P,R),T(_.scaleX,_.scaleY,A.scaleX,A.scaleY,P,R),_=A=null,function(F){for(var j=-1,K=R.length,ee;++j=0&&i._call.call(void 0,s),i=i._next;--nD}function ZBe(){bC=(WY=SF.now())+YY,nD=EF=0;try{vDt()}finally{nD=0,yDt(),bC=0}}function wDt(){var i=SF.now(),s=i-WY;s>XBe&&(YY-=s,WY=i)}function yDt(){for(var i,s=KY,u,d=1/0;s;)s._call?(d>s._time&&(d=s._time),i=s,s=s._next):(u=s._next,s._next=null,s=i?i._next=u:KY=u);CF=i,Npe(d)}function Npe(i){if(!nD){EF&&(EF=clearTimeout(EF));var s=i-bC;s>24?(i<1/0&&(EF=setTimeout(ZBe,i-SF.now()-YY)),TF&&(TF=clearInterval(TF))):(TF||(WY=SF.now(),TF=setInterval(wDt,XBe)),nD=1,QBe(ZBe))}}function eFe(i,s,u){var d=new XY;return s=s==null?0:+s,d.restart(p=>{d.stop(),i(p+s)},s,u),d}var xDt=fBe("start","end","cancel","interrupt"),kDt=[],tFe=0,nFe=1,Ppe=2,QY=3,rFe=4,Bpe=5,JY=6;function ZY(i,s,u,d,p,v){var b=i.__transition;if(!b)i.__transition={};else if(u in b)return;EDt(i,u,{name:s,index:d,group:p,on:xDt,tween:kDt,time:v.time,delay:v.delay,duration:v.duration,ease:v.ease,timer:null,state:tFe})}function Fpe(i,s){var u=M3(i,s);if(u.state>tFe)throw new Error("too late; already scheduled");return u}function $4(i,s){var u=M3(i,s);if(u.state>QY)throw new Error("too late; already running");return u}function M3(i,s){var u=i.__transition;if(!u||!(u=u[s]))throw new Error("transition not found");return u}function EDt(i,s,u){var d=i.__transition,p;d[s]=u,u.timer=JBe(v,0,u.time);function v(_){u.state=nFe,u.timer.restart(b,u.delay,u.time),u.delay<=_&&b(_-u.delay)}function b(_){var A,P,R,F;if(u.state!==nFe)return T();for(A in d)if(F=d[A],F.name===u.name){if(F.state===QY)return eFe(b);F.state===rFe?(F.state=JY,F.timer.stop(),F.on.call("interrupt",i,i.__data__,F.index,F.group),delete d[A]):+APpe&&d.state=0&&(s=s.slice(0,u)),!s||s==="start"})}function eIt(i,s,u){var d,p,v=ZDt(s)?Fpe:$4;return function(){var b=v(this,i),y=b.on;y!==d&&(p=(d=y).copy()).on(s,u),b.on=p}}function tIt(i,s){var u=this._id;return arguments.length<2?M3(this.node(),u).on.on(i):this.each(eIt(u,i,s))}function nIt(i){return function(){var s=this.parentNode;for(var u in this.__transition)if(+u!==i)return;s&&s.removeChild(this)}}function rIt(){return this.on("end.remove",nIt(this._id))}function iIt(i){var s=this._name,u=this._id;typeof i!="function"&&(i=wpe(i));for(var d=this._groups,p=d.length,v=new Array(p),b=0;b=0))throw new Error(`invalid digits: ${i}`);if(s>15)return oFe;const u=10**s;return function(d){this._+=d[0];for(let p=1,v=d.length;pmC)if(!(Math.abs(P*T-_*A)>mC)||!v)this._append`L${this._x1=s},${this._y1=u}`;else{let F=d-b,j=p-y,K=T*T+_*_,ee=F*F+j*j,ie=Math.sqrt(K),oe=Math.sqrt(R),pe=v*Math.tan((jpe-Math.acos((K+R-ee)/(2*ie*oe)))/2),be=pe/oe,ae=pe/ie;Math.abs(be-1)>mC&&this._append`L${s+be*A},${u+be*P}`,this._append`A${v},${v},0,0,${+(P*F>A*j)},${this._x1=s+ae*T},${this._y1=u+ae*_}`}}arc(s,u,d,p,v,b){if(s=+s,u=+u,d=+d,b=!!b,d<0)throw new Error(`negative radius: ${d}`);let y=d*Math.cos(p),T=d*Math.sin(p),_=s+y,A=u+T,P=1^b,R=b?p-v:v-p;this._x1===null?this._append`M${_},${A}`:(Math.abs(this._x1-_)>mC||Math.abs(this._y1-A)>mC)&&this._append`L${_},${A}`,d&&(R<0&&(R=R%$pe+$pe),R>LIt?this._append`A${d},${d},0,1,${P},${s-y},${u-T}A${d},${d},0,1,${P},${this._x1=_},${this._y1=A}`:R>mC&&this._append`A${d},${d},0,${+(R>=jpe)},${P},${this._x1=s+d*Math.cos(v)},${this._y1=u+d*Math.sin(v)}`)}rect(s,u,d,p){this._append`M${this._x0=this._x1=+s},${this._y0=this._y1=+u}h${d=+d}v${+p}h${-d}Z`}toString(){return this._}};function IIt(i){if(!i.ok)throw new Error(i.status+" "+i.statusText);return i.text()}function OIt(i,s){return fetch(i,s).then(IIt)}function NIt(i){return(s,u)=>OIt(s,u).then(d=>new DOMParser().parseFromString(d,i))}var PIt=NIt("image/svg+xml");function BIt(i){return Math.abs(i=Math.round(i))>=1e21?i.toLocaleString("en").replace(/,/g,""):i.toString(10)}function eX(i,s){if((u=(i=s?i.toExponential(s-1):i.toExponential()).indexOf("e"))<0)return null;var u,d=i.slice(0,u);return[d.length>1?d[0]+d.slice(2):d,+i.slice(u+1)]}function rD(i){return i=eX(Math.abs(i)),i?i[1]:NaN}function FIt(i,s){return function(u,d){for(var p=u.length,v=[],b=0,y=i[0],T=0;p>0&&y>0&&(T+y+1>d&&(y=Math.max(1,d-T)),v.push(u.substring(p-=y,p+y)),!((T+=y+1)>d));)y=i[b=(b+1)%i.length];return v.reverse().join(s)}}function RIt(i){return function(s){return s.replace(/[0-9]/g,function(u){return i[+u]})}}var jIt=/^(?:(.)?([<>=^]))?([+\-( ])?([$#])?(0)?(\d+)?(,)?(\.\d+)?(~)?([a-z%])?$/i;function tX(i){if(!(s=jIt.exec(i)))throw new Error("invalid format: "+i);var s;return new zpe({fill:s[1],align:s[2],sign:s[3],symbol:s[4],zero:s[5],width:s[6],comma:s[7],precision:s[8]&&s[8].slice(1),trim:s[9],type:s[10]})}tX.prototype=zpe.prototype;function zpe(i){this.fill=i.fill===void 0?" ":i.fill+"",this.align=i.align===void 0?">":i.align+"",this.sign=i.sign===void 0?"-":i.sign+"",this.symbol=i.symbol===void 0?"":i.symbol+"",this.zero=!!i.zero,this.width=i.width===void 0?void 0:+i.width,this.comma=!!i.comma,this.precision=i.precision===void 0?void 0:+i.precision,this.trim=!!i.trim,this.type=i.type===void 0?"":i.type+""}zpe.prototype.toString=function(){return this.fill+this.align+this.sign+this.symbol+(this.zero?"0":"")+(this.width===void 0?"":Math.max(1,this.width|0))+(this.comma?",":"")+(this.precision===void 0?"":"."+Math.max(0,this.precision|0))+(this.trim?"~":"")+this.type};function $It(i){e:for(var s=i.length,u=1,d=-1,p;u0&&(d=0);break}return d>0?i.slice(0,d)+i.slice(p+1):i}var cFe;function zIt(i,s){var u=eX(i,s);if(!u)return i+"";var d=u[0],p=u[1],v=p-(cFe=Math.max(-8,Math.min(8,Math.floor(p/3)))*3)+1,b=d.length;return v===b?d:v>b?d+new Array(v-b+1).join("0"):v>0?d.slice(0,v)+"."+d.slice(v):"0."+new Array(1-v).join("0")+eX(i,Math.max(0,s+v-1))[0]}function uFe(i,s){var u=eX(i,s);if(!u)return i+"";var d=u[0],p=u[1];return p<0?"0."+new Array(-p).join("0")+d:d.length>p+1?d.slice(0,p+1)+"."+d.slice(p+1):d+new Array(p-d.length+2).join("0")}const lFe={"%":(i,s)=>(i*100).toFixed(s),b:i=>Math.round(i).toString(2),c:i=>i+"",d:BIt,e:(i,s)=>i.toExponential(s),f:(i,s)=>i.toFixed(s),g:(i,s)=>i.toPrecision(s),o:i=>Math.round(i).toString(8),p:(i,s)=>uFe(i*100,s),r:uFe,s:zIt,X:i=>Math.round(i).toString(16).toUpperCase(),x:i=>Math.round(i).toString(16)};function hFe(i){return i}var fFe=Array.prototype.map,dFe=["y","z","a","f","p","n","µ","m","","k","M","G","T","P","E","Z","Y"];function qIt(i){var s=i.grouping===void 0||i.thousands===void 0?hFe:FIt(fFe.call(i.grouping,Number),i.thousands+""),u=i.currency===void 0?"":i.currency[0]+"",d=i.currency===void 0?"":i.currency[1]+"",p=i.decimal===void 0?".":i.decimal+"",v=i.numerals===void 0?hFe:RIt(fFe.call(i.numerals,String)),b=i.percent===void 0?"%":i.percent+"",y=i.minus===void 0?"−":i.minus+"",T=i.nan===void 0?"NaN":i.nan+"";function _(P){P=tX(P);var R=P.fill,F=P.align,j=P.sign,K=P.symbol,ee=P.zero,ie=P.width,oe=P.comma,pe=P.precision,be=P.trim,ae=P.type;ae==="n"?(oe=!0,ae="g"):lFe[ae]||(pe===void 0&&(pe=12),be=!0,ae="g"),(ee||R==="0"&&F==="=")&&(ee=!0,R="0",F="=");var ne=K==="$"?u:K==="#"&&/[boxX]/.test(ae)?"0"+ae.toLowerCase():"",se=K==="$"?d:/[%p]/.test(ae)?b:"",de=lFe[ae],X=/[defgprs%]/.test(ae);pe=pe===void 0?6:/[gprs]/.test(ae)?Math.max(1,Math.min(21,pe)):Math.max(0,Math.min(20,pe));function ge(W){var xe=ne,U=se,Fe,Pe,je;if(ae==="c")U=de(W)+U,W="";else{W=+W;var Ie=W<0||1/W<0;if(W=isNaN(W)?T:de(Math.abs(W),pe),be&&(W=$It(W)),Ie&&+W==0&&j!=="+"&&(Ie=!1),xe=(Ie?j==="("?j:y:j==="-"||j==="("?"":j)+xe,U=(ae==="s"?dFe[8+cFe/3]:"")+U+(Ie&&j==="("?")":""),X){for(Fe=-1,Pe=W.length;++Feje||je>57){U=(je===46?p+W.slice(Fe+1):W.slice(Fe))+U,W=W.slice(0,Fe);break}}}oe&&!ee&&(W=s(W,1/0));var Se=xe.length+W.length+U.length,Ce=Se>1)+xe+W+U+Ce.slice(Se);break;default:W=Ce+xe+W+U;break}return v(W)}return ge.toString=function(){return P+""},ge}function A(P,R){var F=_((P=tX(P),P.type="f",P)),j=Math.max(-8,Math.min(8,Math.floor(rD(R)/3)))*3,K=Math.pow(10,-j),ee=dFe[8+j/3];return function(ie){return F(K*ie)+ee}}return{format:_,formatPrefix:A}}var nX,gFe,pFe;HIt({thousands:",",grouping:[3],currency:["$",""]});function HIt(i){return nX=qIt(i),gFe=nX.format,pFe=nX.formatPrefix,nX}function VIt(i){return Math.max(0,-rD(Math.abs(i)))}function UIt(i,s){return Math.max(0,Math.max(-8,Math.min(8,Math.floor(rD(s)/3)))*3-rD(Math.abs(i)))}function GIt(i,s){return i=Math.abs(i),s=Math.abs(s)-i,Math.max(0,rD(s)-rD(i))+1}function rX(i,s){switch(arguments.length){case 0:break;case 1:this.range(i);break;default:this.range(s).domain(i);break}return this}const bFe=Symbol("implicit");function _F(){var i=new cBe,s=[],u=[],d=bFe;function p(v){let b=i.get(v);if(b===void 0){if(d!==bFe)return d;i.set(v,b=s.push(v)-1)}return u[b%u.length]}return p.domain=function(v){if(!arguments.length)return s.slice();s=[],i=new cBe;for(const b of v)i.has(b)||i.set(b,s.push(b)-1);return p},p.range=function(v){return arguments.length?(u=Array.from(v),p):u.slice()},p.unknown=function(v){return arguments.length?(d=v,p):d},p.copy=function(){return _F(s,u).unknown(d)},rX.apply(p,arguments),p}function qpe(){var i=_F().unknown(void 0),s=i.domain,u=i.range,d=0,p=1,v,b,y=!1,T=0,_=0,A=.5;delete i.unknown;function P(){var R=s().length,F=ps&&(u=i,i=s,s=u),function(d){return Math.max(i,Math.min(s,d))}}function XIt(i,s,u){var d=i[0],p=i[1],v=s[0],b=s[1];return p2?QIt:XIt,T=_=null,P}function P(R){return R==null||isNaN(R=+R)?v:(T||(T=y(i.map(d),s,u)))(d(b(R)))}return P.invert=function(R){return b(p((_||(_=y(s,i.map(d),L3)))(R)))},P.domain=function(R){return arguments.length?(i=Array.from(R,WIt),A()):i.slice()},P.range=function(R){return arguments.length?(s=Array.from(R),A()):s.slice()},P.rangeRound=function(R){return s=Array.from(R),u=lDt,A()},P.clamp=function(R){return arguments.length?(b=R?!0:iD,A()):b!==iD},P.interpolate=function(R){return arguments.length?(u=R,A()):u},P.unknown=function(R){return arguments.length?(v=R,P):v},function(R,F){return d=R,p=F,A()}}function wFe(){return JIt()(iD,iD)}function ZIt(i,s,u,d){var p=ppe(i,s,u),v;switch(d=tX(d??",f"),d.type){case"s":{var b=Math.max(Math.abs(i),Math.abs(s));return d.precision==null&&!isNaN(v=UIt(p,b))&&(d.precision=v),pFe(d,b)}case"":case"e":case"g":case"p":case"r":{d.precision==null&&!isNaN(v=GIt(p,Math.max(Math.abs(i),Math.abs(s))))&&(d.precision=v-(d.type==="e"));break}case"f":case"%":{d.precision==null&&!isNaN(v=VIt(p))&&(d.precision=v-(d.type==="%")*2);break}}return gFe(d)}function eOt(i){var s=i.domain;return i.ticks=function(u){var d=s();return GAt(d[0],d[d.length-1],u??10)},i.tickFormat=function(u,d){var p=s();return ZIt(p[0],p[p.length-1],u??10,d)},i.nice=function(u){u==null&&(u=10);var d=s(),p=0,v=d.length-1,b=d[p],y=d[v],T,_,A=10;for(y0;){if(_=gpe(b,y,u),_===T)return d[p]=b,d[v]=y,s(d);if(_>0)b=Math.floor(b/_)*_,y=Math.ceil(y/_)*_;else if(_<0)b=Math.ceil(b*_)/_,y=Math.floor(y*_)/_;else break;T=_}return i},i}function sD(){var i=wFe();return i.copy=function(){return vFe(i,sD())},rX.apply(i,arguments),eOt(i)}function tOt(i,s){i=i.slice();var u=0,d=i.length-1,p=i[u],v=i[d],b;return v(i(v=new Date(+v)),v),p.ceil=v=>(i(v=new Date(v-1)),s(v,1),i(v),v),p.round=v=>{const b=p(v),y=p.ceil(v);return v-b(s(v=new Date(+v),b==null?1:Math.floor(b)),v),p.range=(v,b,y)=>{const T=[];if(v=p.ceil(v),y=y==null?1:Math.floor(y),!(v0))return T;let _;do T.push(_=new Date(+v)),s(v,y),i(v);while(_h1(b=>{if(b>=b)for(;i(b),!v(b);)b.setTime(b-1)},(b,y)=>{if(b>=b)if(y<0)for(;++y<=0;)for(;s(b,-1),!v(b););else for(;--y>=0;)for(;s(b,1),!v(b););}),u&&(p.count=(v,b)=>(Vpe.setTime(+v),Upe.setTime(+b),i(Vpe),i(Upe),Math.floor(u(Vpe,Upe))),p.every=v=>(v=Math.floor(v),!isFinite(v)||!(v>0)?null:v>1?p.filter(d?b=>d(b)%v===0:b=>p.count(0,b)%v===0):p)),p}const aD=h1(()=>{},(i,s)=>{i.setTime(+i+s)},(i,s)=>s-i);aD.every=i=>(i=Math.floor(i),!isFinite(i)||!(i>0)?null:i>1?h1(s=>{s.setTime(Math.floor(s/i)*i)},(s,u)=>{s.setTime(+s+u*i)},(s,u)=>(u-s)/i):aD),aD.range;const v7=1e3,Mv=v7*60,w7=Mv*60,y7=w7*24,Gpe=y7*7,yFe=y7*30,Kpe=y7*365,b9=h1(i=>{i.setTime(i-i.getMilliseconds())},(i,s)=>{i.setTime(+i+s*v7)},(i,s)=>(s-i)/v7,i=>i.getUTCSeconds());b9.range;const AF=h1(i=>{i.setTime(i-i.getMilliseconds()-i.getSeconds()*v7)},(i,s)=>{i.setTime(+i+s*Mv)},(i,s)=>(s-i)/Mv,i=>i.getMinutes());AF.range,h1(i=>{i.setUTCSeconds(0,0)},(i,s)=>{i.setTime(+i+s*Mv)},(i,s)=>(s-i)/Mv,i=>i.getUTCMinutes()).range;const LF=h1(i=>{i.setTime(i-i.getMilliseconds()-i.getSeconds()*v7-i.getMinutes()*Mv)},(i,s)=>{i.setTime(+i+s*w7)},(i,s)=>(s-i)/w7,i=>i.getHours());LF.range,h1(i=>{i.setUTCMinutes(0,0,0)},(i,s)=>{i.setTime(+i+s*w7)},(i,s)=>(s-i)/w7,i=>i.getUTCHours()).range;const vC=h1(i=>i.setHours(0,0,0,0),(i,s)=>i.setDate(i.getDate()+s),(i,s)=>(s-i-(s.getTimezoneOffset()-i.getTimezoneOffset())*Mv)/y7,i=>i.getDate()-1);vC.range;const Wpe=h1(i=>{i.setUTCHours(0,0,0,0)},(i,s)=>{i.setUTCDate(i.getUTCDate()+s)},(i,s)=>(s-i)/y7,i=>i.getUTCDate()-1);Wpe.range,h1(i=>{i.setUTCHours(0,0,0,0)},(i,s)=>{i.setUTCDate(i.getUTCDate()+s)},(i,s)=>(s-i)/y7,i=>Math.floor(i/y7)).range;function wC(i){return h1(s=>{s.setDate(s.getDate()-(s.getDay()+7-i)%7),s.setHours(0,0,0,0)},(s,u)=>{s.setDate(s.getDate()+u*7)},(s,u)=>(u-s-(u.getTimezoneOffset()-s.getTimezoneOffset())*Mv)/Gpe)}const MF=wC(0),DF=wC(1),xFe=wC(2),kFe=wC(3),yC=wC(4),EFe=wC(5),TFe=wC(6);MF.range,DF.range,xFe.range,kFe.range,yC.range,EFe.range,TFe.range;function xC(i){return h1(s=>{s.setUTCDate(s.getUTCDate()-(s.getUTCDay()+7-i)%7),s.setUTCHours(0,0,0,0)},(s,u)=>{s.setUTCDate(s.getUTCDate()+u*7)},(s,u)=>(u-s)/Gpe)}const CFe=xC(0),iX=xC(1),nOt=xC(2),rOt=xC(3),oD=xC(4),iOt=xC(5),sOt=xC(6);CFe.range,iX.range,nOt.range,rOt.range,oD.range,iOt.range,sOt.range;const IF=h1(i=>{i.setDate(1),i.setHours(0,0,0,0)},(i,s)=>{i.setMonth(i.getMonth()+s)},(i,s)=>s.getMonth()-i.getMonth()+(s.getFullYear()-i.getFullYear())*12,i=>i.getMonth());IF.range,h1(i=>{i.setUTCDate(1),i.setUTCHours(0,0,0,0)},(i,s)=>{i.setUTCMonth(i.getUTCMonth()+s)},(i,s)=>s.getUTCMonth()-i.getUTCMonth()+(s.getUTCFullYear()-i.getUTCFullYear())*12,i=>i.getUTCMonth()).range;const x7=h1(i=>{i.setMonth(0,1),i.setHours(0,0,0,0)},(i,s)=>{i.setFullYear(i.getFullYear()+s)},(i,s)=>s.getFullYear()-i.getFullYear(),i=>i.getFullYear());x7.every=i=>!isFinite(i=Math.floor(i))||!(i>0)?null:h1(s=>{s.setFullYear(Math.floor(s.getFullYear()/i)*i),s.setMonth(0,1),s.setHours(0,0,0,0)},(s,u)=>{s.setFullYear(s.getFullYear()+u*i)}),x7.range;const kC=h1(i=>{i.setUTCMonth(0,1),i.setUTCHours(0,0,0,0)},(i,s)=>{i.setUTCFullYear(i.getUTCFullYear()+s)},(i,s)=>s.getUTCFullYear()-i.getUTCFullYear(),i=>i.getUTCFullYear());kC.every=i=>!isFinite(i=Math.floor(i))||!(i>0)?null:h1(s=>{s.setUTCFullYear(Math.floor(s.getUTCFullYear()/i)*i),s.setUTCMonth(0,1),s.setUTCHours(0,0,0,0)},(s,u)=>{s.setUTCFullYear(s.getUTCFullYear()+u*i)}),kC.range;function aOt(i,s,u,d,p,v){const b=[[b9,1,v7],[b9,5,5*v7],[b9,15,15*v7],[b9,30,30*v7],[v,1,Mv],[v,5,5*Mv],[v,15,15*Mv],[v,30,30*Mv],[p,1,w7],[p,3,3*w7],[p,6,6*w7],[p,12,12*w7],[d,1,y7],[d,2,2*y7],[u,1,Gpe],[s,1,yFe],[s,3,3*yFe],[i,1,Kpe]];function y(_,A,P){const R=A<_;R&&([_,A]=[A,_]);const F=P&&typeof P.range=="function"?P:T(_,A,P),j=F?F.range(_,+A+1):[];return R?j.reverse():j}function T(_,A,P){const R=Math.abs(A-_)/P,F=dpe(([,,ee])=>ee).right(b,R);if(F===b.length)return i.every(ppe(_/Kpe,A/Kpe,P));if(F===0)return aD.every(Math.max(ppe(_,A,P),1));const[j,K]=b[R/b[F-1][2]53)return null;"w"in Dt||(Dt.w=1),"Z"in Dt?(On=Xpe(OF(Dt.y,0,1)),ht=On.getUTCDay(),On=ht>4||ht===0?iX.ceil(On):iX(On),On=Wpe.offset(On,(Dt.V-1)*7),Dt.y=On.getUTCFullYear(),Dt.m=On.getUTCMonth(),Dt.d=On.getUTCDate()+(Dt.w+6)%7):(On=Ype(OF(Dt.y,0,1)),ht=On.getDay(),On=ht>4||ht===0?DF.ceil(On):DF(On),On=vC.offset(On,(Dt.V-1)*7),Dt.y=On.getFullYear(),Dt.m=On.getMonth(),Dt.d=On.getDate()+(Dt.w+6)%7)}else("W"in Dt||"U"in Dt)&&("w"in Dt||(Dt.w="u"in Dt?Dt.u%7:"W"in Dt?1:0),ht="Z"in Dt?Xpe(OF(Dt.y,0,1)).getUTCDay():Ype(OF(Dt.y,0,1)).getDay(),Dt.m=0,Dt.d="W"in Dt?(Dt.w+6)%7+Dt.W*7-(ht+5)%7:Dt.w+Dt.U*7-(ht+6)%7);return"Z"in Dt?(Dt.H+=Dt.Z/100|0,Dt.M+=Dt.Z%100,Xpe(Dt)):Ype(Dt)}}function de(xt,Pt,Qe,Dt){for(var kt=0,On=Pt.length,ht=Qe.length,zr,yt;kt=ht)return-1;if(zr=Pt.charCodeAt(kt++),zr===37){if(zr=Pt.charAt(kt++),yt=ae[zr in SFe?Pt.charAt(kt++):zr],!yt||(Dt=yt(xt,Qe,Dt))<0)return-1}else if(zr!=Qe.charCodeAt(Dt++))return-1}return Dt}function X(xt,Pt,Qe){var Dt=_.exec(Pt.slice(Qe));return Dt?(xt.p=A.get(Dt[0].toLowerCase()),Qe+Dt[0].length):-1}function ge(xt,Pt,Qe){var Dt=F.exec(Pt.slice(Qe));return Dt?(xt.w=j.get(Dt[0].toLowerCase()),Qe+Dt[0].length):-1}function W(xt,Pt,Qe){var Dt=P.exec(Pt.slice(Qe));return Dt?(xt.w=R.get(Dt[0].toLowerCase()),Qe+Dt[0].length):-1}function xe(xt,Pt,Qe){var Dt=ie.exec(Pt.slice(Qe));return Dt?(xt.m=oe.get(Dt[0].toLowerCase()),Qe+Dt[0].length):-1}function U(xt,Pt,Qe){var Dt=K.exec(Pt.slice(Qe));return Dt?(xt.m=ee.get(Dt[0].toLowerCase()),Qe+Dt[0].length):-1}function Fe(xt,Pt,Qe){return de(xt,s,Pt,Qe)}function Pe(xt,Pt,Qe){return de(xt,u,Pt,Qe)}function je(xt,Pt,Qe){return de(xt,d,Pt,Qe)}function Ie(xt){return b[xt.getDay()]}function Se(xt){return v[xt.getDay()]}function Ce(xt){return T[xt.getMonth()]}function ke(xt){return y[xt.getMonth()]}function Ke(xt){return p[+(xt.getHours()>=12)]}function Ft(xt){return 1+~~(xt.getMonth()/3)}function Ne(xt){return b[xt.getUTCDay()]}function gn(xt){return v[xt.getUTCDay()]}function _t(xt){return T[xt.getUTCMonth()]}function Et(xt){return y[xt.getUTCMonth()]}function Gt(xt){return p[+(xt.getUTCHours()>=12)]}function ln(xt){return 1+~~(xt.getUTCMonth()/3)}return{format:function(xt){var Pt=ne(xt+="",pe);return Pt.toString=function(){return xt},Pt},parse:function(xt){var Pt=se(xt+="",!1);return Pt.toString=function(){return xt},Pt},utcFormat:function(xt){var Pt=ne(xt+="",be);return Pt.toString=function(){return xt},Pt},utcParse:function(xt){var Pt=se(xt+="",!0);return Pt.toString=function(){return xt},Pt}}}var SFe={"-":"",_:" ",0:"0"},rd=/^\s*\d+/,lOt=/^%/,hOt=/[\\^$*+?|[\]().{}]/g;function mu(i,s,u){var d=i<0?"-":"",p=(d?-i:i)+"",v=p.length;return d+(v[s.toLowerCase(),u]))}function dOt(i,s,u){var d=rd.exec(s.slice(u,u+1));return d?(i.w=+d[0],u+d[0].length):-1}function gOt(i,s,u){var d=rd.exec(s.slice(u,u+1));return d?(i.u=+d[0],u+d[0].length):-1}function pOt(i,s,u){var d=rd.exec(s.slice(u,u+2));return d?(i.U=+d[0],u+d[0].length):-1}function bOt(i,s,u){var d=rd.exec(s.slice(u,u+2));return d?(i.V=+d[0],u+d[0].length):-1}function mOt(i,s,u){var d=rd.exec(s.slice(u,u+2));return d?(i.W=+d[0],u+d[0].length):-1}function _Fe(i,s,u){var d=rd.exec(s.slice(u,u+4));return d?(i.y=+d[0],u+d[0].length):-1}function AFe(i,s,u){var d=rd.exec(s.slice(u,u+2));return d?(i.y=+d[0]+(+d[0]>68?1900:2e3),u+d[0].length):-1}function vOt(i,s,u){var d=/^(Z)|([+-]\d\d)(?::?(\d\d))?/.exec(s.slice(u,u+6));return d?(i.Z=d[1]?0:-(d[2]+(d[3]||"00")),u+d[0].length):-1}function wOt(i,s,u){var d=rd.exec(s.slice(u,u+1));return d?(i.q=d[0]*3-3,u+d[0].length):-1}function yOt(i,s,u){var d=rd.exec(s.slice(u,u+2));return d?(i.m=d[0]-1,u+d[0].length):-1}function LFe(i,s,u){var d=rd.exec(s.slice(u,u+2));return d?(i.d=+d[0],u+d[0].length):-1}function xOt(i,s,u){var d=rd.exec(s.slice(u,u+3));return d?(i.m=0,i.d=+d[0],u+d[0].length):-1}function MFe(i,s,u){var d=rd.exec(s.slice(u,u+2));return d?(i.H=+d[0],u+d[0].length):-1}function kOt(i,s,u){var d=rd.exec(s.slice(u,u+2));return d?(i.M=+d[0],u+d[0].length):-1}function EOt(i,s,u){var d=rd.exec(s.slice(u,u+2));return d?(i.S=+d[0],u+d[0].length):-1}function TOt(i,s,u){var d=rd.exec(s.slice(u,u+3));return d?(i.L=+d[0],u+d[0].length):-1}function COt(i,s,u){var d=rd.exec(s.slice(u,u+6));return d?(i.L=Math.floor(d[0]/1e3),u+d[0].length):-1}function SOt(i,s,u){var d=lOt.exec(s.slice(u,u+1));return d?u+d[0].length:-1}function _Ot(i,s,u){var d=rd.exec(s.slice(u));return d?(i.Q=+d[0],u+d[0].length):-1}function AOt(i,s,u){var d=rd.exec(s.slice(u));return d?(i.s=+d[0],u+d[0].length):-1}function DFe(i,s){return mu(i.getDate(),s,2)}function LOt(i,s){return mu(i.getHours(),s,2)}function MOt(i,s){return mu(i.getHours()%12||12,s,2)}function DOt(i,s){return mu(1+vC.count(x7(i),i),s,3)}function IFe(i,s){return mu(i.getMilliseconds(),s,3)}function IOt(i,s){return IFe(i,s)+"000"}function OOt(i,s){return mu(i.getMonth()+1,s,2)}function NOt(i,s){return mu(i.getMinutes(),s,2)}function POt(i,s){return mu(i.getSeconds(),s,2)}function BOt(i){var s=i.getDay();return s===0?7:s}function FOt(i,s){return mu(MF.count(x7(i)-1,i),s,2)}function OFe(i){var s=i.getDay();return s>=4||s===0?yC(i):yC.ceil(i)}function ROt(i,s){return i=OFe(i),mu(yC.count(x7(i),i)+(x7(i).getDay()===4),s,2)}function jOt(i){return i.getDay()}function $Ot(i,s){return mu(DF.count(x7(i)-1,i),s,2)}function zOt(i,s){return mu(i.getFullYear()%100,s,2)}function qOt(i,s){return i=OFe(i),mu(i.getFullYear()%100,s,2)}function HOt(i,s){return mu(i.getFullYear()%1e4,s,4)}function VOt(i,s){var u=i.getDay();return i=u>=4||u===0?yC(i):yC.ceil(i),mu(i.getFullYear()%1e4,s,4)}function UOt(i){var s=i.getTimezoneOffset();return(s>0?"-":(s*=-1,"+"))+mu(s/60|0,"0",2)+mu(s%60,"0",2)}function NFe(i,s){return mu(i.getUTCDate(),s,2)}function GOt(i,s){return mu(i.getUTCHours(),s,2)}function KOt(i,s){return mu(i.getUTCHours()%12||12,s,2)}function WOt(i,s){return mu(1+Wpe.count(kC(i),i),s,3)}function PFe(i,s){return mu(i.getUTCMilliseconds(),s,3)}function YOt(i,s){return PFe(i,s)+"000"}function XOt(i,s){return mu(i.getUTCMonth()+1,s,2)}function QOt(i,s){return mu(i.getUTCMinutes(),s,2)}function JOt(i,s){return mu(i.getUTCSeconds(),s,2)}function ZOt(i){var s=i.getUTCDay();return s===0?7:s}function eNt(i,s){return mu(CFe.count(kC(i)-1,i),s,2)}function BFe(i){var s=i.getUTCDay();return s>=4||s===0?oD(i):oD.ceil(i)}function tNt(i,s){return i=BFe(i),mu(oD.count(kC(i),i)+(kC(i).getUTCDay()===4),s,2)}function nNt(i){return i.getUTCDay()}function rNt(i,s){return mu(iX.count(kC(i)-1,i),s,2)}function iNt(i,s){return mu(i.getUTCFullYear()%100,s,2)}function sNt(i,s){return i=BFe(i),mu(i.getUTCFullYear()%100,s,2)}function aNt(i,s){return mu(i.getUTCFullYear()%1e4,s,4)}function oNt(i,s){var u=i.getUTCDay();return i=u>=4||u===0?oD(i):oD.ceil(i),mu(i.getUTCFullYear()%1e4,s,4)}function cNt(){return"+0000"}function FFe(){return"%"}function RFe(i){return+i}function jFe(i){return Math.floor(+i/1e3)}var cD,sX;uNt({dateTime:"%x, %X",date:"%-m/%-d/%Y",time:"%-I:%M:%S %p",periods:["AM","PM"],days:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],shortDays:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],months:["January","February","March","April","May","June","July","August","September","October","November","December"],shortMonths:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"]});function uNt(i){return cD=uOt(i),sX=cD.format,cD.parse,cD.utcFormat,cD.utcParse,cD}function lNt(i){return new Date(i)}function hNt(i){return i instanceof Date?+i:+new Date(+i)}function $Fe(i,s,u,d,p,v,b,y,T,_){var A=wFe(),P=A.invert,R=A.domain,F=_(".%L"),j=_(":%S"),K=_("%I:%M"),ee=_("%I %p"),ie=_("%a %d"),oe=_("%b %d"),pe=_("%B"),be=_("%Y");function ae(ne){return(T(ne)1?0:i<-1?BF:Math.acos(i)}function HFe(i){return i>=1?aX:i<=-1?-aX:Math.asin(i)}function VFe(i){let s=3;return i.digits=function(u){if(!arguments.length)return s;if(u==null)s=null;else{const d=Math.floor(u);if(!(d>=0))throw new RangeError(`invalid digits: ${u}`);s=d}return i},()=>new DIt(s)}function bNt(i){return i.innerRadius}function mNt(i){return i.outerRadius}function vNt(i){return i.startAngle}function wNt(i){return i.endAngle}function yNt(i){return i&&i.padAngle}function xNt(i,s,u,d,p,v,b,y){var T=u-i,_=d-s,A=b-p,P=y-v,R=P*T-A*_;if(!(R*RFe*Fe+Pe*Pe&&(de=ge,X=W),{cx:de,cy:X,x01:-A,y01:-P,x11:de*(p/ae-1),y11:X*(p/ae-1)}}function lD(){var i=bNt,s=mNt,u=Wf(0),d=null,p=vNt,v=wNt,b=yNt,y=null,T=VFe(_);function _(){var A,P,R=+i.apply(this,arguments),F=+s.apply(this,arguments),j=p.apply(this,arguments)-aX,K=v.apply(this,arguments)-aX,ee=qFe(K-j),ie=K>j;if(y||(y=A=T()),FIg))y.moveTo(0,0);else if(ee>oX-Ig)y.moveTo(F*EC(j),F*z4(j)),y.arc(0,0,F,j,K,!ie),R>Ig&&(y.moveTo(R*EC(K),R*z4(K)),y.arc(0,0,R,K,j,ie));else{var oe=j,pe=K,be=j,ae=K,ne=ee,se=ee,de=b.apply(this,arguments)/2,X=de>Ig&&(d?+d.apply(this,arguments):uD(R*R+F*F)),ge=Qpe(qFe(F-R)/2,+u.apply(this,arguments)),W=ge,xe=ge,U,Fe;if(X>Ig){var Pe=HFe(X/R*z4(de)),je=HFe(X/F*z4(de));(ne-=Pe*2)>Ig?(Pe*=ie?1:-1,be+=Pe,ae-=Pe):(ne=0,be=ae=(j+K)/2),(se-=je*2)>Ig?(je*=ie?1:-1,oe+=je,pe-=je):(se=0,oe=pe=(j+K)/2)}var Ie=F*EC(oe),Se=F*z4(oe),Ce=R*EC(ae),ke=R*z4(ae);if(ge>Ig){var Ke=F*EC(pe),Ft=F*z4(pe),Ne=R*EC(be),gn=R*z4(be),_t;if(eeIg?xe>Ig?(U=cX(Ne,gn,Ie,Se,F,xe,ie),Fe=cX(Ke,Ft,Ce,ke,F,xe,ie),y.moveTo(U.cx+U.x01,U.cy+U.y01),xeIg)||!(ne>Ig)?y.lineTo(Ce,ke):W>Ig?(U=cX(Ce,ke,Ke,Ft,R,-W,ie),Fe=cX(Ie,Se,Ne,gn,R,-W,ie),y.lineTo(U.cx+U.x01,U.cy+U.y01),Wi?1:s>=i?0:NaN}function CNt(i){return i}function SNt(){var i=CNt,s=TNt,u=null,d=Wf(0),p=Wf(oX),v=Wf(0);function b(y){var T,_=(y=UFe(y)).length,A,P,R=0,F=new Array(_),j=new Array(_),K=+d.apply(this,arguments),ee=Math.min(oX,Math.max(-oX,p.apply(this,arguments)-K)),ie,oe=Math.min(Math.abs(ee)/_,v.apply(this,arguments)),pe=oe*(ee<0?-1:1),be;for(T=0;T<_;++T)(be=j[F[T]=T]=+i(y[T],T,y))>0&&(R+=be);for(s!=null?F.sort(function(ae,ne){return s(j[ae],j[ne])}):u!=null&&F.sort(function(ae,ne){return u(y[ae],y[ne])}),T=0,P=R?(ee-_*pe)/R:0;T<_;++T,K=ie)A=F[T],be=j[A],ie=K+(be>0?be*P:0)+pe,j[A]={data:y[A],index:T,value:be,startAngle:K,endAngle:ie,padAngle:oe};return j}return b.value=function(y){return arguments.length?(i=typeof y=="function"?y:Wf(+y),b):i},b.sortValues=function(y){return arguments.length?(s=y,u=null,b):s},b.sort=function(y){return arguments.length?(u=y,s=null,b):u},b.startAngle=function(y){return arguments.length?(d=typeof y=="function"?y:Wf(+y),b):d},b.endAngle=function(y){return arguments.length?(p=typeof y=="function"?y:Wf(+y),b):p},b.padAngle=function(y){return arguments.length?(v=typeof y=="function"?y:Wf(+y),b):v},b}class KFe{constructor(s,u){this._context=s,this._x=u}areaStart(){this._line=0}areaEnd(){this._line=NaN}lineStart(){this._point=0}lineEnd(){(this._line||this._line!==0&&this._point===1)&&this._context.closePath(),this._line=1-this._line}point(s,u){switch(s=+s,u=+u,this._point){case 0:{this._point=1,this._line?this._context.lineTo(s,u):this._context.moveTo(s,u);break}case 1:this._point=2;default:{this._x?this._context.bezierCurveTo(this._x0=(this._x0+s)/2,this._y0,this._x0,u,s,u):this._context.bezierCurveTo(this._x0,this._y0=(this._y0+u)/2,s,this._y0,s,u);break}}this._x0=s,this._y0=u}}function _Nt(i){return new KFe(i,!0)}function ANt(i){return new KFe(i,!1)}function m9(){}function uX(i,s,u){i._context.bezierCurveTo((2*i._x0+i._x1)/3,(2*i._y0+i._y1)/3,(i._x0+2*i._x1)/3,(i._y0+2*i._y1)/3,(i._x0+4*i._x1+s)/6,(i._y0+4*i._y1+u)/6)}function lX(i){this._context=i}lX.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._y0=this._y1=NaN,this._point=0},lineEnd:function(){switch(this._point){case 3:uX(this,this._x1,this._y1);case 2:this._context.lineTo(this._x1,this._y1);break}(this._line||this._line!==0&&this._point===1)&&this._context.closePath(),this._line=1-this._line},point:function(i,s){switch(i=+i,s=+s,this._point){case 0:this._point=1,this._line?this._context.lineTo(i,s):this._context.moveTo(i,s);break;case 1:this._point=2;break;case 2:this._point=3,this._context.lineTo((5*this._x0+this._x1)/6,(5*this._y0+this._y1)/6);default:uX(this,i,s);break}this._x0=this._x1,this._x1=i,this._y0=this._y1,this._y1=s}};function FF(i){return new lX(i)}function WFe(i){this._context=i}WFe.prototype={areaStart:m9,areaEnd:m9,lineStart:function(){this._x0=this._x1=this._x2=this._x3=this._x4=this._y0=this._y1=this._y2=this._y3=this._y4=NaN,this._point=0},lineEnd:function(){switch(this._point){case 1:{this._context.moveTo(this._x2,this._y2),this._context.closePath();break}case 2:{this._context.moveTo((this._x2+2*this._x3)/3,(this._y2+2*this._y3)/3),this._context.lineTo((this._x3+2*this._x2)/3,(this._y3+2*this._y2)/3),this._context.closePath();break}case 3:{this.point(this._x2,this._y2),this.point(this._x3,this._y3),this.point(this._x4,this._y4);break}}},point:function(i,s){switch(i=+i,s=+s,this._point){case 0:this._point=1,this._x2=i,this._y2=s;break;case 1:this._point=2,this._x3=i,this._y3=s;break;case 2:this._point=3,this._x4=i,this._y4=s,this._context.moveTo((this._x0+4*this._x1+i)/6,(this._y0+4*this._y1+s)/6);break;default:uX(this,i,s);break}this._x0=this._x1,this._x1=i,this._y0=this._y1,this._y1=s}};function LNt(i){return new WFe(i)}function YFe(i){this._context=i}YFe.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._y0=this._y1=NaN,this._point=0},lineEnd:function(){(this._line||this._line!==0&&this._point===3)&&this._context.closePath(),this._line=1-this._line},point:function(i,s){switch(i=+i,s=+s,this._point){case 0:this._point=1;break;case 1:this._point=2;break;case 2:this._point=3;var u=(this._x0+4*this._x1+i)/6,d=(this._y0+4*this._y1+s)/6;this._line?this._context.lineTo(u,d):this._context.moveTo(u,d);break;case 3:this._point=4;default:uX(this,i,s);break}this._x0=this._x1,this._x1=i,this._y0=this._y1,this._y1=s}};function MNt(i){return new YFe(i)}function XFe(i,s){this._basis=new lX(i),this._beta=s}XFe.prototype={lineStart:function(){this._x=[],this._y=[],this._basis.lineStart()},lineEnd:function(){var i=this._x,s=this._y,u=i.length-1;if(u>0)for(var d=i[0],p=s[0],v=i[u]-d,b=s[u]-p,y=-1,T;++y<=u;)T=y/u,this._basis.point(this._beta*i[y]+(1-this._beta)*(d+T*v),this._beta*s[y]+(1-this._beta)*(p+T*b));this._x=this._y=null,this._basis.lineEnd()},point:function(i,s){this._x.push(+i),this._y.push(+s)}};const DNt=function i(s){function u(d){return s===1?new lX(d):new XFe(d,s)}return u.beta=function(d){return i(+d)},u}(.85);function hX(i,s,u){i._context.bezierCurveTo(i._x1+i._k*(i._x2-i._x0),i._y1+i._k*(i._y2-i._y0),i._x2+i._k*(i._x1-s),i._y2+i._k*(i._y1-u),i._x2,i._y2)}function Jpe(i,s){this._context=i,this._k=(1-s)/6}Jpe.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._point=0},lineEnd:function(){switch(this._point){case 2:this._context.lineTo(this._x2,this._y2);break;case 3:hX(this,this._x1,this._y1);break}(this._line||this._line!==0&&this._point===1)&&this._context.closePath(),this._line=1-this._line},point:function(i,s){switch(i=+i,s=+s,this._point){case 0:this._point=1,this._line?this._context.lineTo(i,s):this._context.moveTo(i,s);break;case 1:this._point=2,this._x1=i,this._y1=s;break;case 2:this._point=3;default:hX(this,i,s);break}this._x0=this._x1,this._x1=this._x2,this._x2=i,this._y0=this._y1,this._y1=this._y2,this._y2=s}};const INt=function i(s){function u(d){return new Jpe(d,s)}return u.tension=function(d){return i(+d)},u}(0);function Zpe(i,s){this._context=i,this._k=(1-s)/6}Zpe.prototype={areaStart:m9,areaEnd:m9,lineStart:function(){this._x0=this._x1=this._x2=this._x3=this._x4=this._x5=this._y0=this._y1=this._y2=this._y3=this._y4=this._y5=NaN,this._point=0},lineEnd:function(){switch(this._point){case 1:{this._context.moveTo(this._x3,this._y3),this._context.closePath();break}case 2:{this._context.lineTo(this._x3,this._y3),this._context.closePath();break}case 3:{this.point(this._x3,this._y3),this.point(this._x4,this._y4),this.point(this._x5,this._y5);break}}},point:function(i,s){switch(i=+i,s=+s,this._point){case 0:this._point=1,this._x3=i,this._y3=s;break;case 1:this._point=2,this._context.moveTo(this._x4=i,this._y4=s);break;case 2:this._point=3,this._x5=i,this._y5=s;break;default:hX(this,i,s);break}this._x0=this._x1,this._x1=this._x2,this._x2=i,this._y0=this._y1,this._y1=this._y2,this._y2=s}};const ONt=function i(s){function u(d){return new Zpe(d,s)}return u.tension=function(d){return i(+d)},u}(0);function e2e(i,s){this._context=i,this._k=(1-s)/6}e2e.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._point=0},lineEnd:function(){(this._line||this._line!==0&&this._point===3)&&this._context.closePath(),this._line=1-this._line},point:function(i,s){switch(i=+i,s=+s,this._point){case 0:this._point=1;break;case 1:this._point=2;break;case 2:this._point=3,this._line?this._context.lineTo(this._x2,this._y2):this._context.moveTo(this._x2,this._y2);break;case 3:this._point=4;default:hX(this,i,s);break}this._x0=this._x1,this._x1=this._x2,this._x2=i,this._y0=this._y1,this._y1=this._y2,this._y2=s}};const NNt=function i(s){function u(d){return new e2e(d,s)}return u.tension=function(d){return i(+d)},u}(0);function t2e(i,s,u){var d=i._x1,p=i._y1,v=i._x2,b=i._y2;if(i._l01_a>Ig){var y=2*i._l01_2a+3*i._l01_a*i._l12_a+i._l12_2a,T=3*i._l01_a*(i._l01_a+i._l12_a);d=(d*y-i._x0*i._l12_2a+i._x2*i._l01_2a)/T,p=(p*y-i._y0*i._l12_2a+i._y2*i._l01_2a)/T}if(i._l23_a>Ig){var _=2*i._l23_2a+3*i._l23_a*i._l12_a+i._l12_2a,A=3*i._l23_a*(i._l23_a+i._l12_a);v=(v*_+i._x1*i._l23_2a-s*i._l12_2a)/A,b=(b*_+i._y1*i._l23_2a-u*i._l12_2a)/A}i._context.bezierCurveTo(d,p,v,b,i._x2,i._y2)}function QFe(i,s){this._context=i,this._alpha=s}QFe.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._l01_a=this._l12_a=this._l23_a=this._l01_2a=this._l12_2a=this._l23_2a=this._point=0},lineEnd:function(){switch(this._point){case 2:this._context.lineTo(this._x2,this._y2);break;case 3:this.point(this._x2,this._y2);break}(this._line||this._line!==0&&this._point===1)&&this._context.closePath(),this._line=1-this._line},point:function(i,s){if(i=+i,s=+s,this._point){var u=this._x2-i,d=this._y2-s;this._l23_a=Math.sqrt(this._l23_2a=Math.pow(u*u+d*d,this._alpha))}switch(this._point){case 0:this._point=1,this._line?this._context.lineTo(i,s):this._context.moveTo(i,s);break;case 1:this._point=2;break;case 2:this._point=3;default:t2e(this,i,s);break}this._l01_a=this._l12_a,this._l12_a=this._l23_a,this._l01_2a=this._l12_2a,this._l12_2a=this._l23_2a,this._x0=this._x1,this._x1=this._x2,this._x2=i,this._y0=this._y1,this._y1=this._y2,this._y2=s}};const PNt=function i(s){function u(d){return s?new QFe(d,s):new Jpe(d,0)}return u.alpha=function(d){return i(+d)},u}(.5);function JFe(i,s){this._context=i,this._alpha=s}JFe.prototype={areaStart:m9,areaEnd:m9,lineStart:function(){this._x0=this._x1=this._x2=this._x3=this._x4=this._x5=this._y0=this._y1=this._y2=this._y3=this._y4=this._y5=NaN,this._l01_a=this._l12_a=this._l23_a=this._l01_2a=this._l12_2a=this._l23_2a=this._point=0},lineEnd:function(){switch(this._point){case 1:{this._context.moveTo(this._x3,this._y3),this._context.closePath();break}case 2:{this._context.lineTo(this._x3,this._y3),this._context.closePath();break}case 3:{this.point(this._x3,this._y3),this.point(this._x4,this._y4),this.point(this._x5,this._y5);break}}},point:function(i,s){if(i=+i,s=+s,this._point){var u=this._x2-i,d=this._y2-s;this._l23_a=Math.sqrt(this._l23_2a=Math.pow(u*u+d*d,this._alpha))}switch(this._point){case 0:this._point=1,this._x3=i,this._y3=s;break;case 1:this._point=2,this._context.moveTo(this._x4=i,this._y4=s);break;case 2:this._point=3,this._x5=i,this._y5=s;break;default:t2e(this,i,s);break}this._l01_a=this._l12_a,this._l12_a=this._l23_a,this._l01_2a=this._l12_2a,this._l12_2a=this._l23_2a,this._x0=this._x1,this._x1=this._x2,this._x2=i,this._y0=this._y1,this._y1=this._y2,this._y2=s}};const BNt=function i(s){function u(d){return s?new JFe(d,s):new Zpe(d,0)}return u.alpha=function(d){return i(+d)},u}(.5);function ZFe(i,s){this._context=i,this._alpha=s}ZFe.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._l01_a=this._l12_a=this._l23_a=this._l01_2a=this._l12_2a=this._l23_2a=this._point=0},lineEnd:function(){(this._line||this._line!==0&&this._point===3)&&this._context.closePath(),this._line=1-this._line},point:function(i,s){if(i=+i,s=+s,this._point){var u=this._x2-i,d=this._y2-s;this._l23_a=Math.sqrt(this._l23_2a=Math.pow(u*u+d*d,this._alpha))}switch(this._point){case 0:this._point=1;break;case 1:this._point=2;break;case 2:this._point=3,this._line?this._context.lineTo(this._x2,this._y2):this._context.moveTo(this._x2,this._y2);break;case 3:this._point=4;default:t2e(this,i,s);break}this._l01_a=this._l12_a,this._l12_a=this._l23_a,this._l01_2a=this._l12_2a,this._l12_2a=this._l23_2a,this._x0=this._x1,this._x1=this._x2,this._x2=i,this._y0=this._y1,this._y1=this._y2,this._y2=s}};const FNt=function i(s){function u(d){return s?new ZFe(d,s):new e2e(d,0)}return u.alpha=function(d){return i(+d)},u}(.5);function eRe(i){this._context=i}eRe.prototype={areaStart:m9,areaEnd:m9,lineStart:function(){this._point=0},lineEnd:function(){this._point&&this._context.closePath()},point:function(i,s){i=+i,s=+s,this._point?this._context.lineTo(i,s):(this._point=1,this._context.moveTo(i,s))}};function RNt(i){return new eRe(i)}function tRe(i){return i<0?-1:1}function nRe(i,s,u){var d=i._x1-i._x0,p=s-i._x1,v=(i._y1-i._y0)/(d||p<0&&-0),b=(u-i._y1)/(p||d<0&&-0),y=(v*p+b*d)/(d+p);return(tRe(v)+tRe(b))*Math.min(Math.abs(v),Math.abs(b),.5*Math.abs(y))||0}function rRe(i,s){var u=i._x1-i._x0;return u?(3*(i._y1-i._y0)/u-s)/2:s}function n2e(i,s,u){var d=i._x0,p=i._y0,v=i._x1,b=i._y1,y=(v-d)/3;i._context.bezierCurveTo(d+y,p+y*s,v-y,b-y*u,v,b)}function fX(i){this._context=i}fX.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._y0=this._y1=this._t0=NaN,this._point=0},lineEnd:function(){switch(this._point){case 2:this._context.lineTo(this._x1,this._y1);break;case 3:n2e(this,this._t0,rRe(this,this._t0));break}(this._line||this._line!==0&&this._point===1)&&this._context.closePath(),this._line=1-this._line},point:function(i,s){var u=NaN;if(i=+i,s=+s,!(i===this._x1&&s===this._y1)){switch(this._point){case 0:this._point=1,this._line?this._context.lineTo(i,s):this._context.moveTo(i,s);break;case 1:this._point=2;break;case 2:this._point=3,n2e(this,rRe(this,u=nRe(this,i,s)),u);break;default:n2e(this,this._t0,u=nRe(this,i,s));break}this._x0=this._x1,this._x1=i,this._y0=this._y1,this._y1=s,this._t0=u}}};function iRe(i){this._context=new sRe(i)}(iRe.prototype=Object.create(fX.prototype)).point=function(i,s){fX.prototype.point.call(this,s,i)};function sRe(i){this._context=i}sRe.prototype={moveTo:function(i,s){this._context.moveTo(s,i)},closePath:function(){this._context.closePath()},lineTo:function(i,s){this._context.lineTo(s,i)},bezierCurveTo:function(i,s,u,d,p,v){this._context.bezierCurveTo(s,i,d,u,v,p)}};function jNt(i){return new fX(i)}function $Nt(i){return new iRe(i)}function aRe(i){this._context=i}aRe.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x=[],this._y=[]},lineEnd:function(){var i=this._x,s=this._y,u=i.length;if(u)if(this._line?this._context.lineTo(i[0],s[0]):this._context.moveTo(i[0],s[0]),u===2)this._context.lineTo(i[1],s[1]);else for(var d=oRe(i),p=oRe(s),v=0,b=1;b=0;--s)p[s]=(b[s]-p[s+1])/v[s];for(v[u-1]=(i[u]+p[u-1])/2,s=0;s=0&&(this._t=1-this._t,this._line=1-this._line)},point:function(i,s){switch(i=+i,s=+s,this._point){case 0:this._point=1,this._line?this._context.lineTo(i,s):this._context.moveTo(i,s);break;case 1:this._point=2;default:{if(this._t<=0)this._context.lineTo(this._x,s),this._context.lineTo(i,s);else{var u=this._x*(1-this._t)+i*this._t;this._context.lineTo(u,this._y),this._context.lineTo(u,s)}break}}this._x=i,this._y=s}};function qNt(i){return new dX(i,.5)}function HNt(i){return new dX(i,0)}function VNt(i){return new dX(i,1)}function RF(i,s,u){this.k=i,this.x=s,this.y=u}RF.prototype={constructor:RF,scale:function(i){return i===1?this:new RF(this.k*i,this.x,this.y)},translate:function(i,s){return i===0&s===0?this:new RF(this.k,this.x+this.k*i,this.y+this.k*s)},apply:function(i){return[i[0]*this.k+this.x,i[1]*this.k+this.y]},applyX:function(i){return i*this.k+this.x},applyY:function(i){return i*this.k+this.y},invert:function(i){return[(i[0]-this.x)/this.k,(i[1]-this.y)/this.k]},invertX:function(i){return(i-this.x)/this.k},invertY:function(i){return(i-this.y)/this.k},rescaleX:function(i){return i.copy().domain(i.range().map(this.invertX,this).map(i.invert,i))},rescaleY:function(i){return i.copy().domain(i.range().map(this.invertY,this).map(i.invert,i))},toString:function(){return"translate("+this.x+","+this.y+") scale("+this.k+")"}},RF.prototype;/*! @license DOMPurify 3.0.9 | (c) Cure53 and other contributors | Released under the Apache license 2.0 and Mozilla Public License 2.0 | github.com/cure53/DOMPurify/blob/3.0.9/LICENSE */const{entries:cRe,setPrototypeOf:uRe,isFrozen:UNt,getPrototypeOf:GNt,getOwnPropertyDescriptor:KNt}=Object;let{freeze:Ep,seal:D3,create:lRe}=Object,{apply:r2e,construct:i2e}=typeof Reflect<"u"&&Reflect;Ep||(Ep=function(s){return s}),D3||(D3=function(s){return s}),r2e||(r2e=function(s,u,d){return s.apply(u,d)}),i2e||(i2e=function(s,u){return new s(...u)});const gX=sm(Array.prototype.forEach),hRe=sm(Array.prototype.pop),jF=sm(Array.prototype.push),pX=sm(String.prototype.toLowerCase),s2e=sm(String.prototype.toString),WNt=sm(String.prototype.match),$F=sm(String.prototype.replace),YNt=sm(String.prototype.indexOf),XNt=sm(String.prototype.trim),I3=sm(Object.prototype.hasOwnProperty),im=sm(RegExp.prototype.test),zF=QNt(TypeError);function sm(i){return function(s){for(var u=arguments.length,d=new Array(u>1?u-1:0),p=1;p2&&arguments[2]!==void 0?arguments[2]:pX;uRe&&uRe(i,null);let d=s.length;for(;d--;){let p=s[d];if(typeof p=="string"){const v=u(p);v!==p&&(UNt(s)||(s[d]=v),p=v)}i[p]=!0}return i}function JNt(i){for(let s=0;s/gm),rPt=D3(/\${[\w\W]*}/gm),iPt=D3(/^data-[\-\w.\u00B7-\uFFFF]/),sPt=D3(/^aria-[\-\w]+$/),bRe=D3(/^(?:(?:(?:f|ht)tps?|mailto|tel|callto|sms|cid|xmpp):|[^a-z]|[a-z+.\-]+(?:[^a-z+.\-:]|$))/i),aPt=D3(/^(?:\w+script|data):/i),oPt=D3(/[\u0000-\u0020\u00A0\u1680\u180E\u2000-\u2029\u205F\u3000]/g),mRe=D3(/^html$/i);var vRe=Object.freeze({__proto__:null,MUSTACHE_EXPR:tPt,ERB_EXPR:nPt,TMPLIT_EXPR:rPt,DATA_ATTR:iPt,ARIA_ATTR:sPt,IS_ALLOWED_URI:bRe,IS_SCRIPT_OR_DATA:aPt,ATTR_WHITESPACE:oPt,DOCTYPE_NAME:mRe});const cPt=function(){return typeof window>"u"?null:window},uPt=function(s,u){if(typeof s!="object"||typeof s.createPolicy!="function")return null;let d=null;const p="data-tt-policy-suffix";u&&u.hasAttribute(p)&&(d=u.getAttribute(p));const v="dompurify"+(d?"#"+d:"");try{return s.createPolicy(v,{createHTML(b){return b},createScriptURL(b){return b}})}catch{return console.warn("TrustedTypes policy "+v+" could not be created."),null}};function wRe(){let i=arguments.length>0&&arguments[0]!==void 0?arguments[0]:cPt();const s=as=>wRe(as);if(s.version="3.0.9",s.removed=[],!i||!i.document||i.document.nodeType!==9)return s.isSupported=!1,s;let{document:u}=i;const d=u,p=d.currentScript,{DocumentFragment:v,HTMLTemplateElement:b,Node:y,Element:T,NodeFilter:_,NamedNodeMap:A=i.NamedNodeMap||i.MozNamedAttrMap,HTMLFormElement:P,DOMParser:R,trustedTypes:F}=i,j=T.prototype,K=bX(j,"cloneNode"),ee=bX(j,"nextSibling"),ie=bX(j,"childNodes"),oe=bX(j,"parentNode");if(typeof b=="function"){const as=u.createElement("template");as.content&&as.content.ownerDocument&&(u=as.content.ownerDocument)}let pe,be="";const{implementation:ae,createNodeIterator:ne,createDocumentFragment:se,getElementsByTagName:de}=u,{importNode:X}=d;let ge={};s.isSupported=typeof cRe=="function"&&typeof oe=="function"&&ae&&ae.createHTMLDocument!==void 0;const{MUSTACHE_EXPR:W,ERB_EXPR:xe,TMPLIT_EXPR:U,DATA_ATTR:Fe,ARIA_ATTR:Pe,IS_SCRIPT_OR_DATA:je,ATTR_WHITESPACE:Ie}=vRe;let{IS_ALLOWED_URI:Se}=vRe,Ce=null;const ke=Cc({},[...fRe,...a2e,...o2e,...c2e,...dRe]);let Ke=null;const Ft=Cc({},[...gRe,...u2e,...pRe,...mX]);let Ne=Object.seal(lRe(null,{tagNameCheck:{writable:!0,configurable:!1,enumerable:!0,value:null},attributeNameCheck:{writable:!0,configurable:!1,enumerable:!0,value:null},allowCustomizedBuiltInElements:{writable:!0,configurable:!1,enumerable:!0,value:!1}})),gn=null,_t=null,Et=!0,Gt=!0,ln=!1,xt=!0,Pt=!1,Qe=!1,Dt=!1,kt=!1,On=!1,ht=!1,zr=!1,yt=!0,ji=!1;const xi="user-content-";let Ma=!0,zs=!1,ao={},Tr=null;const Fn=Cc({},["annotation-xml","audio","colgroup","desc","foreignobject","head","iframe","math","mi","mn","mo","ms","mtext","noembed","noframes","noscript","plaintext","script","style","svg","template","thead","title","video","xmp"]);let qn=null;const Un=Cc({},["audio","video","img","source","image","track"]);let At=null;const wt=Cc({},["alt","class","for","id","label","name","pattern","placeholder","role","summary","title","value","style","xmlns"]),on="http://www.w3.org/1998/Math/MathML",fn="http://www.w3.org/2000/svg",An="http://www.w3.org/1999/xhtml";let oo=An,jo=!1,$o=null;const Pa=Cc({},[on,fn,An],s2e);let wo=null;const _s=["application/xhtml+xml","text/html"],tl="text/html";let da=null,j0=null;const pm=u.createElement("form"),Ml=function(wn){return wn instanceof RegExp||wn instanceof Function},Xc=function(){let wn=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};if(!(j0&&j0===wn)){if((!wn||typeof wn!="object")&&(wn={}),wn=TC(wn),wo=_s.indexOf(wn.PARSER_MEDIA_TYPE)===-1?tl:wn.PARSER_MEDIA_TYPE,da=wo==="application/xhtml+xml"?s2e:pX,Ce=I3(wn,"ALLOWED_TAGS")?Cc({},wn.ALLOWED_TAGS,da):ke,Ke=I3(wn,"ALLOWED_ATTR")?Cc({},wn.ALLOWED_ATTR,da):Ft,$o=I3(wn,"ALLOWED_NAMESPACES")?Cc({},wn.ALLOWED_NAMESPACES,s2e):Pa,At=I3(wn,"ADD_URI_SAFE_ATTR")?Cc(TC(wt),wn.ADD_URI_SAFE_ATTR,da):wt,qn=I3(wn,"ADD_DATA_URI_TAGS")?Cc(TC(Un),wn.ADD_DATA_URI_TAGS,da):Un,Tr=I3(wn,"FORBID_CONTENTS")?Cc({},wn.FORBID_CONTENTS,da):Fn,gn=I3(wn,"FORBID_TAGS")?Cc({},wn.FORBID_TAGS,da):{},_t=I3(wn,"FORBID_ATTR")?Cc({},wn.FORBID_ATTR,da):{},ao=I3(wn,"USE_PROFILES")?wn.USE_PROFILES:!1,Et=wn.ALLOW_ARIA_ATTR!==!1,Gt=wn.ALLOW_DATA_ATTR!==!1,ln=wn.ALLOW_UNKNOWN_PROTOCOLS||!1,xt=wn.ALLOW_SELF_CLOSE_IN_ATTR!==!1,Pt=wn.SAFE_FOR_TEMPLATES||!1,Qe=wn.WHOLE_DOCUMENT||!1,On=wn.RETURN_DOM||!1,ht=wn.RETURN_DOM_FRAGMENT||!1,zr=wn.RETURN_TRUSTED_TYPE||!1,kt=wn.FORCE_BODY||!1,yt=wn.SANITIZE_DOM!==!1,ji=wn.SANITIZE_NAMED_PROPS||!1,Ma=wn.KEEP_CONTENT!==!1,zs=wn.IN_PLACE||!1,Se=wn.ALLOWED_URI_REGEXP||bRe,oo=wn.NAMESPACE||An,Ne=wn.CUSTOM_ELEMENT_HANDLING||{},wn.CUSTOM_ELEMENT_HANDLING&&Ml(wn.CUSTOM_ELEMENT_HANDLING.tagNameCheck)&&(Ne.tagNameCheck=wn.CUSTOM_ELEMENT_HANDLING.tagNameCheck),wn.CUSTOM_ELEMENT_HANDLING&&Ml(wn.CUSTOM_ELEMENT_HANDLING.attributeNameCheck)&&(Ne.attributeNameCheck=wn.CUSTOM_ELEMENT_HANDLING.attributeNameCheck),wn.CUSTOM_ELEMENT_HANDLING&&typeof wn.CUSTOM_ELEMENT_HANDLING.allowCustomizedBuiltInElements=="boolean"&&(Ne.allowCustomizedBuiltInElements=wn.CUSTOM_ELEMENT_HANDLING.allowCustomizedBuiltInElements),Pt&&(Gt=!1),ht&&(On=!0),ao&&(Ce=Cc({},dRe),Ke=[],ao.html===!0&&(Cc(Ce,fRe),Cc(Ke,gRe)),ao.svg===!0&&(Cc(Ce,a2e),Cc(Ke,u2e),Cc(Ke,mX)),ao.svgFilters===!0&&(Cc(Ce,o2e),Cc(Ke,u2e),Cc(Ke,mX)),ao.mathMl===!0&&(Cc(Ce,c2e),Cc(Ke,pRe),Cc(Ke,mX))),wn.ADD_TAGS&&(Ce===ke&&(Ce=TC(Ce)),Cc(Ce,wn.ADD_TAGS,da)),wn.ADD_ATTR&&(Ke===Ft&&(Ke=TC(Ke)),Cc(Ke,wn.ADD_ATTR,da)),wn.ADD_URI_SAFE_ATTR&&Cc(At,wn.ADD_URI_SAFE_ATTR,da),wn.FORBID_CONTENTS&&(Tr===Fn&&(Tr=TC(Tr)),Cc(Tr,wn.FORBID_CONTENTS,da)),Ma&&(Ce["#text"]=!0),Qe&&Cc(Ce,["html","head","body"]),Ce.table&&(Cc(Ce,["tbody"]),delete gn.tbody),wn.TRUSTED_TYPES_POLICY){if(typeof wn.TRUSTED_TYPES_POLICY.createHTML!="function")throw zF('TRUSTED_TYPES_POLICY configuration option must provide a "createHTML" hook.');if(typeof wn.TRUSTED_TYPES_POLICY.createScriptURL!="function")throw zF('TRUSTED_TYPES_POLICY configuration option must provide a "createScriptURL" hook.');pe=wn.TRUSTED_TYPES_POLICY,be=pe.createHTML("")}else pe===void 0&&(pe=uPt(F,p)),pe!==null&&typeof be=="string"&&(be=pe.createHTML(""));Ep&&Ep(wn),j0=wn}},Bc=Cc({},["mi","mo","mn","ms","mtext"]),ja=Cc({},["foreignobject","desc","title","annotation-xml"]),Ou=Cc({},["title","style","font","a","script"]),Sa=Cc({},[...a2e,...o2e,...ZNt]),Po=Cc({},[...c2e,...ePt]),Fc=function(wn){let Zr=oe(wn);(!Zr||!Zr.tagName)&&(Zr={namespaceURI:oo,tagName:"template"});const Zi=pX(wn.tagName),nu=pX(Zr.tagName);return $o[wn.namespaceURI]?wn.namespaceURI===fn?Zr.namespaceURI===An?Zi==="svg":Zr.namespaceURI===on?Zi==="svg"&&(nu==="annotation-xml"||Bc[nu]):!!Sa[Zi]:wn.namespaceURI===on?Zr.namespaceURI===An?Zi==="math":Zr.namespaceURI===fn?Zi==="math"&&ja[nu]:!!Po[Zi]:wn.namespaceURI===An?Zr.namespaceURI===fn&&!ja[nu]||Zr.namespaceURI===on&&!Bc[nu]?!1:!Po[Zi]&&(Ou[Zi]||!Sa[Zi]):!!(wo==="application/xhtml+xml"&&$o[wn.namespaceURI]):!1},xa=function(wn){jF(s.removed,{element:wn});try{wn.parentNode.removeChild(wn)}catch{wn.remove()}},Ba=function(wn,Zr){try{jF(s.removed,{attribute:Zr.getAttributeNode(wn),from:Zr})}catch{jF(s.removed,{attribute:null,from:Zr})}if(Zr.removeAttribute(wn),wn==="is"&&!Ke[wn])if(On||ht)try{xa(Zr)}catch{}else try{Zr.setAttribute(wn,"")}catch{}},ga=function(wn){let Zr=null,Zi=null;if(kt)wn=""+wn;else{const Dl=WNt(wn,/^[\r\n\t ]+/);Zi=Dl&&Dl[0]}wo==="application/xhtml+xml"&&oo===An&&(wn=''+wn+"");const nu=pe?pe.createHTML(wn):wn;if(oo===An)try{Zr=new R().parseFromString(nu,wo)}catch{}if(!Zr||!Zr.documentElement){Zr=ae.createDocument(oo,"template",null);try{Zr.documentElement.innerHTML=jo?be:nu}catch{}}const vu=Zr.body||Zr.documentElement;return wn&&Zi&&vu.insertBefore(u.createTextNode(Zi),vu.childNodes[0]||null),oo===An?de.call(Zr,Qe?"html":"body")[0]:Qe?Zr.documentElement:vu},kh=function(wn){return ne.call(wn.ownerDocument||wn,wn,_.SHOW_ELEMENT|_.SHOW_COMMENT|_.SHOW_TEXT,null)},lu=function(wn){return wn instanceof P&&(typeof wn.nodeName!="string"||typeof wn.textContent!="string"||typeof wn.removeChild!="function"||!(wn.attributes instanceof A)||typeof wn.removeAttribute!="function"||typeof wn.setAttribute!="function"||typeof wn.namespaceURI!="string"||typeof wn.insertBefore!="function"||typeof wn.hasChildNodes!="function")},o5=function(wn){return typeof y=="function"&&wn instanceof y},Wh=function(wn,Zr,Zi){ge[wn]&&gX(ge[wn],nu=>{nu.call(s,Zr,Zi,j0)})},od=function(wn){let Zr=null;if(Wh("beforeSanitizeElements",wn,null),lu(wn))return xa(wn),!0;const Zi=da(wn.nodeName);if(Wh("uponSanitizeElement",wn,{tagName:Zi,allowedTags:Ce}),wn.hasChildNodes()&&!o5(wn.firstElementChild)&&im(/<[/\w]/g,wn.innerHTML)&&im(/<[/\w]/g,wn.textContent))return xa(wn),!0;if(!Ce[Zi]||gn[Zi]){if(!gn[Zi]&&cd(Zi)&&(Ne.tagNameCheck instanceof RegExp&&im(Ne.tagNameCheck,Zi)||Ne.tagNameCheck instanceof Function&&Ne.tagNameCheck(Zi)))return!1;if(Ma&&!Tr[Zi]){const nu=oe(wn)||wn.parentNode,vu=ie(wn)||wn.childNodes;if(vu&&nu){const Dl=vu.length;for(let Yh=Dl-1;Yh>=0;--Yh)nu.insertBefore(K(vu[Yh],!0),ee(wn))}}return xa(wn),!0}return wn instanceof T&&!Fc(wn)||(Zi==="noscript"||Zi==="noembed"||Zi==="noframes")&&im(/<\/no(script|embed|frames)/i,wn.innerHTML)?(xa(wn),!0):(Pt&&wn.nodeType===3&&(Zr=wn.textContent,gX([W,xe,U],nu=>{Zr=$F(Zr,nu," ")}),wn.textContent!==Zr&&(jF(s.removed,{element:wn.cloneNode()}),wn.textContent=Zr)),Wh("afterSanitizeElements",wn,null),!1)},Gd=function(wn,Zr,Zi){if(yt&&(Zr==="id"||Zr==="name")&&(Zi in u||Zi in pm))return!1;if(!(Gt&&!_t[Zr]&&im(Fe,Zr))){if(!(Et&&im(Pe,Zr))){if(!Ke[Zr]||_t[Zr]){if(!(cd(wn)&&(Ne.tagNameCheck instanceof RegExp&&im(Ne.tagNameCheck,wn)||Ne.tagNameCheck instanceof Function&&Ne.tagNameCheck(wn))&&(Ne.attributeNameCheck instanceof RegExp&&im(Ne.attributeNameCheck,Zr)||Ne.attributeNameCheck instanceof Function&&Ne.attributeNameCheck(Zr))||Zr==="is"&&Ne.allowCustomizedBuiltInElements&&(Ne.tagNameCheck instanceof RegExp&&im(Ne.tagNameCheck,Zi)||Ne.tagNameCheck instanceof Function&&Ne.tagNameCheck(Zi))))return!1}else if(!At[Zr]){if(!im(Se,$F(Zi,Ie,""))){if(!((Zr==="src"||Zr==="xlink:href"||Zr==="href")&&wn!=="script"&&YNt(Zi,"data:")===0&&qn[wn])){if(!(ln&&!im(je,$F(Zi,Ie,"")))){if(Zi)return!1}}}}}}return!0},cd=function(wn){return wn!=="annotation-xml"&&wn.indexOf("-")>0},Kd=function(wn){Wh("beforeSanitizeAttributes",wn,null);const{attributes:Zr}=wn;if(!Zr)return;const Zi={attrName:"",attrValue:"",keepAttr:!0,allowedAttributes:Ke};let nu=Zr.length;for(;nu--;){const vu=Zr[nu],{name:Dl,namespaceURI:Yh,value:w1}=vu,$0=da(Dl);let Wi=Dl==="value"?w1:XNt(w1);if(Zi.attrName=$0,Zi.attrValue=Wi,Zi.keepAttr=!0,Zi.forceKeepAttr=void 0,Wh("uponSanitizeAttribute",wn,Zi),Wi=Zi.attrValue,Zi.forceKeepAttr||(Ba(Dl,wn),!Zi.keepAttr))continue;if(!xt&&im(/\/>/i,Wi)){Ba(Dl,wn);continue}Pt&&gX([W,xe,U],Qa=>{Wi=$F(Wi,Qa," ")});const Bs=da(wn.nodeName);if(Gd(Bs,$0,Wi)){if(ji&&($0==="id"||$0==="name")&&(Ba(Dl,wn),Wi=xi+Wi),pe&&typeof F=="object"&&typeof F.getAttributeType=="function"&&!Yh)switch(F.getAttributeType(Bs,$0)){case"TrustedHTML":{Wi=pe.createHTML(Wi);break}case"TrustedScriptURL":{Wi=pe.createScriptURL(Wi);break}}try{Yh?wn.setAttributeNS(Yh,Dl,Wi):wn.setAttribute(Dl,Wi),hRe(s.removed)}catch{}}}Wh("afterSanitizeAttributes",wn,null)},$g=function as(wn){let Zr=null;const Zi=kh(wn);for(Wh("beforeSanitizeShadowDOM",wn,null);Zr=Zi.nextNode();)Wh("uponSanitizeShadowNode",Zr,null),!od(Zr)&&(Zr.content instanceof v&&as(Zr.content),Kd(Zr));Wh("afterSanitizeShadowDOM",wn,null)};return s.sanitize=function(as){let wn=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{},Zr=null,Zi=null,nu=null,vu=null;if(jo=!as,jo&&(as=""),typeof as!="string"&&!o5(as))if(typeof as.toString=="function"){if(as=as.toString(),typeof as!="string")throw zF("dirty is not a string, aborting")}else throw zF("toString is not a function");if(!s.isSupported)return as;if(Dt||Xc(wn),s.removed=[],typeof as=="string"&&(zs=!1),zs){if(as.nodeName){const w1=da(as.nodeName);if(!Ce[w1]||gn[w1])throw zF("root node is forbidden and cannot be sanitized in-place")}}else if(as instanceof y)Zr=ga(""),Zi=Zr.ownerDocument.importNode(as,!0),Zi.nodeType===1&&Zi.nodeName==="BODY"||Zi.nodeName==="HTML"?Zr=Zi:Zr.appendChild(Zi);else{if(!On&&!Pt&&!Qe&&as.indexOf("<")===-1)return pe&&zr?pe.createHTML(as):as;if(Zr=ga(as),!Zr)return On?null:zr?be:""}Zr&&kt&&xa(Zr.firstChild);const Dl=kh(zs?as:Zr);for(;nu=Dl.nextNode();)od(nu)||(nu.content instanceof v&&$g(nu.content),Kd(nu));if(zs)return as;if(On){if(ht)for(vu=se.call(Zr.ownerDocument);Zr.firstChild;)vu.appendChild(Zr.firstChild);else vu=Zr;return(Ke.shadowroot||Ke.shadowrootmode)&&(vu=X.call(d,vu,!0)),vu}let Yh=Qe?Zr.outerHTML:Zr.innerHTML;return Qe&&Ce["!doctype"]&&Zr.ownerDocument&&Zr.ownerDocument.doctype&&Zr.ownerDocument.doctype.name&&im(mRe,Zr.ownerDocument.doctype.name)&&(Yh=" +`+Yh),Pt&&gX([W,xe,U],w1=>{Yh=$F(Yh,w1," ")}),pe&&zr?pe.createHTML(Yh):Yh},s.setConfig=function(){let as=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};Xc(as),Dt=!0},s.clearConfig=function(){j0=null,Dt=!1},s.isValidAttribute=function(as,wn,Zr){j0||Xc({});const Zi=da(as),nu=da(wn);return Gd(Zi,nu,Zr)},s.addHook=function(as,wn){typeof wn=="function"&&(ge[as]=ge[as]||[],jF(ge[as],wn))},s.removeHook=function(as){if(ge[as])return hRe(ge[as])},s.removeHooks=function(as){ge[as]&&(ge[as]=[])},s.removeAllHooks=function(){ge={}},s}var hD=wRe();const fD=//gi,lPt=i=>i?kRe(i).replace(/\\n/g,"#br#").split("#br#"):[""],hPt=(()=>{let i=!1;return()=>{i||(fPt(),i=!0)}})();function fPt(){const i="data-temp-href-target";hD.addHook("beforeSanitizeAttributes",s=>{s.tagName==="A"&&s.hasAttribute("target")&&s.setAttribute(i,s.getAttribute("target")||"")}),hD.addHook("afterSanitizeAttributes",s=>{s.tagName==="A"&&s.hasAttribute(i)&&(s.setAttribute("target",s.getAttribute(i)||""),s.removeAttribute(i),s.getAttribute("target")==="_blank"&&s.setAttribute("rel","noopener"))})}const yRe=i=>(hPt(),hD.sanitize(i)),xRe=(i,s)=>{var u;if(((u=s.flowchart)==null?void 0:u.htmlLabels)!==!1){const d=s.securityLevel;d==="antiscript"||d==="strict"?i=yRe(i):d!=="loose"&&(i=kRe(i),i=i.replace(//g,">"),i=i.replace(/=/g,"="),i=bPt(i))}return i},Yf=(i,s)=>i&&(s.dompurifyConfig?i=hD.sanitize(xRe(i,s),s.dompurifyConfig).toString():i=hD.sanitize(xRe(i,s),{FORBID_TAGS:["style"]}).toString(),i),dPt=(i,s)=>typeof i=="string"?Yf(i,s):i.flat().map(u=>Yf(u,s)),gPt=i=>fD.test(i),pPt=i=>i.split(fD),bPt=i=>i.replace(/#br#/g,"
    "),kRe=i=>i.replace(fD,"#br#"),mPt=i=>{let s="";return i&&(s=window.location.protocol+"//"+window.location.host+window.location.pathname+window.location.search,s=s.replaceAll(/\(/g,"\\("),s=s.replaceAll(/\)/g,"\\)")),s},f1=i=>!(i===!1||["false","null","0"].includes(String(i).trim().toLowerCase())),vPt=function(...i){const s=i.filter(u=>!isNaN(u));return Math.max(...s)},wPt=function(...i){const s=i.filter(u=>!isNaN(u));return Math.min(...s)},qF=function(i){const s=i.split(/(,)/),u=[];for(let d=0;d0&&d+1Math.max(0,i.split(s).length-1),yPt=(i,s)=>{const u=l2e(i,"~"),d=l2e(s,"~");return u===1&&d===1},xPt=i=>{const s=l2e(i,"~");let u=!1;if(s<=1)return i;s%2!==0&&i.startsWith("~")&&(i=i.substring(1),u=!0);const d=[...i];let p=d.indexOf("~"),v=d.lastIndexOf("~");for(;p!==-1&&v!==-1&&p!==v;)d[p]="<",d[v]=">",p=d.indexOf("~"),v=d.lastIndexOf("~");return u&&d.unshift("~"),d.join("")},ERe=()=>window.MathMLElement!==void 0,h2e=/\$\$(.*)\$\$/g,Dv=i=>{var s;return(((s=i.match(h2e))==null?void 0:s.length)??0)>0},HF=async(i,s)=>{i=await CC(i,s);const u=document.createElement("div");u.innerHTML=i,u.id="katex-temp",u.style.visibility="hidden",u.style.position="absolute",u.style.top="0";const d=document.querySelector("body");d==null||d.insertAdjacentElement("beforeend",u);const p={width:u.clientWidth,height:u.clientHeight};return u.remove(),p},CC=async(i,s)=>{if(!Dv(i))return i;if(!ERe()&&!s.legacyMathML)return i.replace(h2e,"MathML is unsupported in this environment.");const{default:u}=await Promise.resolve().then(()=>MVt);return i.split(fD).map(d=>Dv(d)?` +
    + ${d} +
    + `:`
    ${d}
    `).join("").replace(h2e,(d,p)=>u.renderToString(p,{throwOnError:!0,displayMode:!0,output:ERe()?"mathml":"htmlAndMathml"}).replace(/\n/g," ").replace(//g,""))},ci={getRows:lPt,sanitizeText:Yf,sanitizeTextOrArray:dPt,hasBreaks:gPt,splitBreaks:pPt,lineBreakRegex:fD,removeScript:yRe,getUrl:mPt,evaluate:f1,getMax:vPt,getMin:wPt},vX={min:{r:0,g:0,b:0,s:0,l:0,a:0},max:{r:255,g:255,b:255,h:360,s:100,l:100,a:1},clamp:{r:i=>i>=255?255:i<0?0:i,g:i=>i>=255?255:i<0?0:i,b:i=>i>=255?255:i<0?0:i,h:i=>i%360,s:i=>i>=100?100:i<0?0:i,l:i=>i>=100?100:i<0?0:i,a:i=>i>=1?1:i<0?0:i},toLinear:i=>{const s=i/255;return i>.03928?Math.pow((s+.055)/1.055,2.4):s/12.92},hue2rgb:(i,s,u)=>(u<0&&(u+=1),u>1&&(u-=1),u<1/6?i+(s-i)*6*u:u<1/2?s:u<2/3?i+(s-i)*(2/3-u)*6:i),hsl2rgb:({h:i,s,l:u},d)=>{if(!s)return u*2.55;i/=360,s/=100,u/=100;const p=u<.5?u*(1+s):u+s-u*s,v=2*u-p;switch(d){case"r":return vX.hue2rgb(v,p,i+1/3)*255;case"g":return vX.hue2rgb(v,p,i)*255;case"b":return vX.hue2rgb(v,p,i-1/3)*255}},rgb2hsl:({r:i,g:s,b:u},d)=>{i/=255,s/=255,u/=255;const p=Math.max(i,s,u),v=Math.min(i,s,u),b=(p+v)/2;if(d==="l")return b*100;if(p===v)return 0;const y=p-v,T=b>.5?y/(2-p-v):y/(p+v);if(d==="s")return T*100;switch(p){case i:return((s-u)/y+(ss>u?Math.min(s,Math.max(u,i)):Math.min(u,Math.max(s,i)),round:i=>Math.round(i*1e10)/1e10},unit:{dec2hex:i=>{const s=Math.round(i).toString(16);return s.length>1?s:`0${s}`}}},v9={};for(let i=0;i<=255;i++)v9[i]=Wa.unit.dec2hex(i);const Og={ALL:0,RGB:1,HSL:2};class kPt{constructor(){this.type=Og.ALL}get(){return this.type}set(s){if(this.type&&this.type!==s)throw new Error("Cannot change both RGB and HSL channels at the same time");this.type=s}reset(){this.type=Og.ALL}is(s){return this.type===s}}const EPt=kPt;class TPt{constructor(s,u){this.color=u,this.changed=!1,this.data=s,this.type=new EPt}set(s,u){return this.color=u,this.changed=!1,this.data=s,this.type.type=Og.ALL,this}_ensureHSL(){const s=this.data,{h:u,s:d,l:p}=s;u===void 0&&(s.h=Wa.channel.rgb2hsl(s,"h")),d===void 0&&(s.s=Wa.channel.rgb2hsl(s,"s")),p===void 0&&(s.l=Wa.channel.rgb2hsl(s,"l"))}_ensureRGB(){const s=this.data,{r:u,g:d,b:p}=s;u===void 0&&(s.r=Wa.channel.hsl2rgb(s,"r")),d===void 0&&(s.g=Wa.channel.hsl2rgb(s,"g")),p===void 0&&(s.b=Wa.channel.hsl2rgb(s,"b"))}get r(){const s=this.data,u=s.r;return!this.type.is(Og.HSL)&&u!==void 0?u:(this._ensureHSL(),Wa.channel.hsl2rgb(s,"r"))}get g(){const s=this.data,u=s.g;return!this.type.is(Og.HSL)&&u!==void 0?u:(this._ensureHSL(),Wa.channel.hsl2rgb(s,"g"))}get b(){const s=this.data,u=s.b;return!this.type.is(Og.HSL)&&u!==void 0?u:(this._ensureHSL(),Wa.channel.hsl2rgb(s,"b"))}get h(){const s=this.data,u=s.h;return!this.type.is(Og.RGB)&&u!==void 0?u:(this._ensureRGB(),Wa.channel.rgb2hsl(s,"h"))}get s(){const s=this.data,u=s.s;return!this.type.is(Og.RGB)&&u!==void 0?u:(this._ensureRGB(),Wa.channel.rgb2hsl(s,"s"))}get l(){const s=this.data,u=s.l;return!this.type.is(Og.RGB)&&u!==void 0?u:(this._ensureRGB(),Wa.channel.rgb2hsl(s,"l"))}get a(){return this.data.a}set r(s){this.type.set(Og.RGB),this.changed=!0,this.data.r=s}set g(s){this.type.set(Og.RGB),this.changed=!0,this.data.g=s}set b(s){this.type.set(Og.RGB),this.changed=!0,this.data.b=s}set h(s){this.type.set(Og.HSL),this.changed=!0,this.data.h=s}set s(s){this.type.set(Og.HSL),this.changed=!0,this.data.s=s}set l(s){this.type.set(Og.HSL),this.changed=!0,this.data.l=s}set a(s){this.changed=!0,this.data.a=s}}const CPt=TPt,wX=new CPt({r:0,g:0,b:0,a:0},"transparent"),TRe={re:/^#((?:[a-f0-9]{2}){2,4}|[a-f0-9]{3})$/i,parse:i=>{if(i.charCodeAt(0)!==35)return;const s=i.match(TRe.re);if(!s)return;const u=s[1],d=parseInt(u,16),p=u.length,v=p%4===0,b=p>4,y=b?1:17,T=b?8:4,_=v?0:-1,A=b?255:15;return wX.set({r:(d>>T*(_+3)&A)*y,g:(d>>T*(_+2)&A)*y,b:(d>>T*(_+1)&A)*y,a:v?(d&A)*y/255:1},i)},stringify:i=>{const{r:s,g:u,b:d,a:p}=i;return p<1?`#${v9[Math.round(s)]}${v9[Math.round(u)]}${v9[Math.round(d)]}${v9[Math.round(p*255)]}`:`#${v9[Math.round(s)]}${v9[Math.round(u)]}${v9[Math.round(d)]}`}},VF=TRe,yX={re:/^hsla?\(\s*?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e-?\d+)?(?:deg|grad|rad|turn)?)\s*?(?:,|\s)\s*?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e-?\d+)?%)\s*?(?:,|\s)\s*?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e-?\d+)?%)(?:\s*?(?:,|\/)\s*?\+?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e-?\d+)?(%)?))?\s*?\)$/i,hueRe:/^(.+?)(deg|grad|rad|turn)$/i,_hue2deg:i=>{const s=i.match(yX.hueRe);if(s){const[,u,d]=s;switch(d){case"grad":return Wa.channel.clamp.h(parseFloat(u)*.9);case"rad":return Wa.channel.clamp.h(parseFloat(u)*180/Math.PI);case"turn":return Wa.channel.clamp.h(parseFloat(u)*360)}}return Wa.channel.clamp.h(parseFloat(i))},parse:i=>{const s=i.charCodeAt(0);if(s!==104&&s!==72)return;const u=i.match(yX.re);if(!u)return;const[,d,p,v,b,y]=u;return wX.set({h:yX._hue2deg(d),s:Wa.channel.clamp.s(parseFloat(p)),l:Wa.channel.clamp.l(parseFloat(v)),a:b?Wa.channel.clamp.a(y?parseFloat(b)/100:parseFloat(b)):1},i)},stringify:i=>{const{h:s,s:u,l:d,a:p}=i;return p<1?`hsla(${Wa.lang.round(s)}, ${Wa.lang.round(u)}%, ${Wa.lang.round(d)}%, ${p})`:`hsl(${Wa.lang.round(s)}, ${Wa.lang.round(u)}%, ${Wa.lang.round(d)}%)`}},xX=yX,kX={colors:{aliceblue:"#f0f8ff",antiquewhite:"#faebd7",aqua:"#00ffff",aquamarine:"#7fffd4",azure:"#f0ffff",beige:"#f5f5dc",bisque:"#ffe4c4",black:"#000000",blanchedalmond:"#ffebcd",blue:"#0000ff",blueviolet:"#8a2be2",brown:"#a52a2a",burlywood:"#deb887",cadetblue:"#5f9ea0",chartreuse:"#7fff00",chocolate:"#d2691e",coral:"#ff7f50",cornflowerblue:"#6495ed",cornsilk:"#fff8dc",crimson:"#dc143c",cyanaqua:"#00ffff",darkblue:"#00008b",darkcyan:"#008b8b",darkgoldenrod:"#b8860b",darkgray:"#a9a9a9",darkgreen:"#006400",darkgrey:"#a9a9a9",darkkhaki:"#bdb76b",darkmagenta:"#8b008b",darkolivegreen:"#556b2f",darkorange:"#ff8c00",darkorchid:"#9932cc",darkred:"#8b0000",darksalmon:"#e9967a",darkseagreen:"#8fbc8f",darkslateblue:"#483d8b",darkslategray:"#2f4f4f",darkslategrey:"#2f4f4f",darkturquoise:"#00ced1",darkviolet:"#9400d3",deeppink:"#ff1493",deepskyblue:"#00bfff",dimgray:"#696969",dimgrey:"#696969",dodgerblue:"#1e90ff",firebrick:"#b22222",floralwhite:"#fffaf0",forestgreen:"#228b22",fuchsia:"#ff00ff",gainsboro:"#dcdcdc",ghostwhite:"#f8f8ff",gold:"#ffd700",goldenrod:"#daa520",gray:"#808080",green:"#008000",greenyellow:"#adff2f",grey:"#808080",honeydew:"#f0fff0",hotpink:"#ff69b4",indianred:"#cd5c5c",indigo:"#4b0082",ivory:"#fffff0",khaki:"#f0e68c",lavender:"#e6e6fa",lavenderblush:"#fff0f5",lawngreen:"#7cfc00",lemonchiffon:"#fffacd",lightblue:"#add8e6",lightcoral:"#f08080",lightcyan:"#e0ffff",lightgoldenrodyellow:"#fafad2",lightgray:"#d3d3d3",lightgreen:"#90ee90",lightgrey:"#d3d3d3",lightpink:"#ffb6c1",lightsalmon:"#ffa07a",lightseagreen:"#20b2aa",lightskyblue:"#87cefa",lightslategray:"#778899",lightslategrey:"#778899",lightsteelblue:"#b0c4de",lightyellow:"#ffffe0",lime:"#00ff00",limegreen:"#32cd32",linen:"#faf0e6",magenta:"#ff00ff",maroon:"#800000",mediumaquamarine:"#66cdaa",mediumblue:"#0000cd",mediumorchid:"#ba55d3",mediumpurple:"#9370db",mediumseagreen:"#3cb371",mediumslateblue:"#7b68ee",mediumspringgreen:"#00fa9a",mediumturquoise:"#48d1cc",mediumvioletred:"#c71585",midnightblue:"#191970",mintcream:"#f5fffa",mistyrose:"#ffe4e1",moccasin:"#ffe4b5",navajowhite:"#ffdead",navy:"#000080",oldlace:"#fdf5e6",olive:"#808000",olivedrab:"#6b8e23",orange:"#ffa500",orangered:"#ff4500",orchid:"#da70d6",palegoldenrod:"#eee8aa",palegreen:"#98fb98",paleturquoise:"#afeeee",palevioletred:"#db7093",papayawhip:"#ffefd5",peachpuff:"#ffdab9",peru:"#cd853f",pink:"#ffc0cb",plum:"#dda0dd",powderblue:"#b0e0e6",purple:"#800080",rebeccapurple:"#663399",red:"#ff0000",rosybrown:"#bc8f8f",royalblue:"#4169e1",saddlebrown:"#8b4513",salmon:"#fa8072",sandybrown:"#f4a460",seagreen:"#2e8b57",seashell:"#fff5ee",sienna:"#a0522d",silver:"#c0c0c0",skyblue:"#87ceeb",slateblue:"#6a5acd",slategray:"#708090",slategrey:"#708090",snow:"#fffafa",springgreen:"#00ff7f",tan:"#d2b48c",teal:"#008080",thistle:"#d8bfd8",transparent:"#00000000",turquoise:"#40e0d0",violet:"#ee82ee",wheat:"#f5deb3",white:"#ffffff",whitesmoke:"#f5f5f5",yellow:"#ffff00",yellowgreen:"#9acd32"},parse:i=>{i=i.toLowerCase();const s=kX.colors[i];if(s)return VF.parse(s)},stringify:i=>{const s=VF.stringify(i);for(const u in kX.colors)if(kX.colors[u]===s)return u}},CRe=kX,SRe={re:/^rgba?\(\s*?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e\d+)?(%?))\s*?(?:,|\s)\s*?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e\d+)?(%?))\s*?(?:,|\s)\s*?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e\d+)?(%?))(?:\s*?(?:,|\/)\s*?\+?(-?(?:\d+(?:\.\d+)?|(?:\.\d+))(?:e\d+)?(%?)))?\s*?\)$/i,parse:i=>{const s=i.charCodeAt(0);if(s!==114&&s!==82)return;const u=i.match(SRe.re);if(!u)return;const[,d,p,v,b,y,T,_,A]=u;return wX.set({r:Wa.channel.clamp.r(p?parseFloat(d)*2.55:parseFloat(d)),g:Wa.channel.clamp.g(b?parseFloat(v)*2.55:parseFloat(v)),b:Wa.channel.clamp.b(T?parseFloat(y)*2.55:parseFloat(y)),a:_?Wa.channel.clamp.a(A?parseFloat(_)/100:parseFloat(_)):1},i)},stringify:i=>{const{r:s,g:u,b:d,a:p}=i;return p<1?`rgba(${Wa.lang.round(s)}, ${Wa.lang.round(u)}, ${Wa.lang.round(d)}, ${Wa.lang.round(p)})`:`rgb(${Wa.lang.round(s)}, ${Wa.lang.round(u)}, ${Wa.lang.round(d)})`}},EX=SRe,O3={format:{keyword:CRe,hex:VF,rgb:EX,rgba:EX,hsl:xX,hsla:xX},parse:i=>{if(typeof i!="string")return i;const s=VF.parse(i)||EX.parse(i)||xX.parse(i)||CRe.parse(i);if(s)return s;throw new Error(`Unsupported color format: "${i}"`)},stringify:i=>!i.changed&&i.color?i.color:i.type.is(Og.HSL)||i.data.r===void 0?xX.stringify(i):i.a<1||!Number.isInteger(i.r)||!Number.isInteger(i.g)||!Number.isInteger(i.b)?EX.stringify(i):VF.stringify(i)},_Re=(i,s)=>{const u=O3.parse(i);for(const d in s)u[d]=Wa.channel.clamp[d](s[d]);return O3.stringify(u)},SC=(i,s,u=0,d=1)=>{if(typeof i!="number")return _Re(i,{a:s});const p=wX.set({r:Wa.channel.clamp.r(i),g:Wa.channel.clamp.g(s),b:Wa.channel.clamp.b(u),a:Wa.channel.clamp.a(d)});return O3.stringify(p)},ARe=(i,s)=>Wa.lang.round(O3.parse(i)[s]),SPt=i=>{const{r:s,g:u,b:d}=O3.parse(i),p=.2126*Wa.channel.toLinear(s)+.7152*Wa.channel.toLinear(u)+.0722*Wa.channel.toLinear(d);return Wa.lang.round(p)},_Pt=i=>SPt(i)>=.5,_C=i=>!_Pt(i),LRe=(i,s,u)=>{const d=O3.parse(i),p=d[s],v=Wa.channel.clamp[s](p+u);return p!==v&&(d[s]=v),O3.stringify(d)},Gs=(i,s)=>LRe(i,"l",s),fa=(i,s)=>LRe(i,"l",-s),In=(i,s)=>{const u=O3.parse(i),d={};for(const p in s)s[p]&&(d[p]=u[p]+s[p]);return _Re(i,d)},APt=(i,s,u=50)=>{const{r:d,g:p,b:v,a:b}=O3.parse(i),{r:y,g:T,b:_,a:A}=O3.parse(s),P=u/100,R=P*2-1,F=b-A,K=((R*F===-1?R:(R+F)/(1+R*F))+1)/2,ee=1-K,ie=d*K+y*ee,oe=p*K+T*ee,pe=v*K+_*ee,be=b*P+A*(1-P);return SC(ie,oe,pe,be)},Vi=(i,s=100)=>{const u=O3.parse(i);return u.r=255-u.r,u.g=255-u.g,u.b=255-u.b,APt(u,i,s)},Tp=(i,s)=>s?In(i,{s:-40,l:10}):In(i,{s:-40,l:-10}),TX="#ffffff",CX="#f2f2f2";let LPt=class{constructor(){this.background="#f4f4f4",this.primaryColor="#fff4dd",this.noteBkgColor="#fff5ad",this.noteTextColor="#333",this.THEME_COLOR_LIMIT=12,this.fontFamily='"trebuchet ms", verdana, arial, sans-serif',this.fontSize="16px"}updateColors(){var u,d,p,v,b,y,T,_,A,P,R;if(this.primaryTextColor=this.primaryTextColor||(this.darkMode?"#eee":"#333"),this.secondaryColor=this.secondaryColor||In(this.primaryColor,{h:-120}),this.tertiaryColor=this.tertiaryColor||In(this.primaryColor,{h:180,l:5}),this.primaryBorderColor=this.primaryBorderColor||Tp(this.primaryColor,this.darkMode),this.secondaryBorderColor=this.secondaryBorderColor||Tp(this.secondaryColor,this.darkMode),this.tertiaryBorderColor=this.tertiaryBorderColor||Tp(this.tertiaryColor,this.darkMode),this.noteBorderColor=this.noteBorderColor||Tp(this.noteBkgColor,this.darkMode),this.noteBkgColor=this.noteBkgColor||"#fff5ad",this.noteTextColor=this.noteTextColor||"#333",this.secondaryTextColor=this.secondaryTextColor||Vi(this.secondaryColor),this.tertiaryTextColor=this.tertiaryTextColor||Vi(this.tertiaryColor),this.lineColor=this.lineColor||Vi(this.background),this.arrowheadColor=this.arrowheadColor||Vi(this.background),this.textColor=this.textColor||this.primaryTextColor,this.border2=this.border2||this.tertiaryBorderColor,this.nodeBkg=this.nodeBkg||this.primaryColor,this.mainBkg=this.mainBkg||this.primaryColor,this.nodeBorder=this.nodeBorder||this.primaryBorderColor,this.clusterBkg=this.clusterBkg||this.tertiaryColor,this.clusterBorder=this.clusterBorder||this.tertiaryBorderColor,this.defaultLinkColor=this.defaultLinkColor||this.lineColor,this.titleColor=this.titleColor||this.tertiaryTextColor,this.edgeLabelBackground=this.edgeLabelBackground||(this.darkMode?fa(this.secondaryColor,30):this.secondaryColor),this.nodeTextColor=this.nodeTextColor||this.primaryTextColor,this.actorBorder=this.actorBorder||this.primaryBorderColor,this.actorBkg=this.actorBkg||this.mainBkg,this.actorTextColor=this.actorTextColor||this.primaryTextColor,this.actorLineColor=this.actorLineColor||"grey",this.labelBoxBkgColor=this.labelBoxBkgColor||this.actorBkg,this.signalColor=this.signalColor||this.textColor,this.signalTextColor=this.signalTextColor||this.textColor,this.labelBoxBorderColor=this.labelBoxBorderColor||this.actorBorder,this.labelTextColor=this.labelTextColor||this.actorTextColor,this.loopTextColor=this.loopTextColor||this.actorTextColor,this.activationBorderColor=this.activationBorderColor||fa(this.secondaryColor,10),this.activationBkgColor=this.activationBkgColor||this.secondaryColor,this.sequenceNumberColor=this.sequenceNumberColor||Vi(this.lineColor),this.sectionBkgColor=this.sectionBkgColor||this.tertiaryColor,this.altSectionBkgColor=this.altSectionBkgColor||"white",this.sectionBkgColor=this.sectionBkgColor||this.secondaryColor,this.sectionBkgColor2=this.sectionBkgColor2||this.primaryColor,this.excludeBkgColor=this.excludeBkgColor||"#eeeeee",this.taskBorderColor=this.taskBorderColor||this.primaryBorderColor,this.taskBkgColor=this.taskBkgColor||this.primaryColor,this.activeTaskBorderColor=this.activeTaskBorderColor||this.primaryColor,this.activeTaskBkgColor=this.activeTaskBkgColor||Gs(this.primaryColor,23),this.gridColor=this.gridColor||"lightgrey",this.doneTaskBkgColor=this.doneTaskBkgColor||"lightgrey",this.doneTaskBorderColor=this.doneTaskBorderColor||"grey",this.critBorderColor=this.critBorderColor||"#ff8888",this.critBkgColor=this.critBkgColor||"red",this.todayLineColor=this.todayLineColor||"red",this.taskTextColor=this.taskTextColor||this.textColor,this.taskTextOutsideColor=this.taskTextOutsideColor||this.textColor,this.taskTextLightColor=this.taskTextLightColor||this.textColor,this.taskTextColor=this.taskTextColor||this.primaryTextColor,this.taskTextDarkColor=this.taskTextDarkColor||this.textColor,this.taskTextClickableColor=this.taskTextClickableColor||"#003163",this.personBorder=this.personBorder||this.primaryBorderColor,this.personBkg=this.personBkg||this.mainBkg,this.transitionColor=this.transitionColor||this.lineColor,this.transitionLabelColor=this.transitionLabelColor||this.textColor,this.stateLabelColor=this.stateLabelColor||this.stateBkg||this.primaryTextColor,this.stateBkg=this.stateBkg||this.mainBkg,this.labelBackgroundColor=this.labelBackgroundColor||this.stateBkg,this.compositeBackground=this.compositeBackground||this.background||this.tertiaryColor,this.altBackground=this.altBackground||this.tertiaryColor,this.compositeTitleBackground=this.compositeTitleBackground||this.mainBkg,this.compositeBorder=this.compositeBorder||this.nodeBorder,this.innerEndBackground=this.nodeBorder,this.errorBkgColor=this.errorBkgColor||this.tertiaryColor,this.errorTextColor=this.errorTextColor||this.tertiaryTextColor,this.transitionColor=this.transitionColor||this.lineColor,this.specialStateColor=this.lineColor,this.cScale0=this.cScale0||this.primaryColor,this.cScale1=this.cScale1||this.secondaryColor,this.cScale2=this.cScale2||this.tertiaryColor,this.cScale3=this.cScale3||In(this.primaryColor,{h:30}),this.cScale4=this.cScale4||In(this.primaryColor,{h:60}),this.cScale5=this.cScale5||In(this.primaryColor,{h:90}),this.cScale6=this.cScale6||In(this.primaryColor,{h:120}),this.cScale7=this.cScale7||In(this.primaryColor,{h:150}),this.cScale8=this.cScale8||In(this.primaryColor,{h:210,l:150}),this.cScale9=this.cScale9||In(this.primaryColor,{h:270}),this.cScale10=this.cScale10||In(this.primaryColor,{h:300}),this.cScale11=this.cScale11||In(this.primaryColor,{h:330}),this.darkMode)for(let F=0;F{this[d]=s[d]}),this.updateColors(),u.forEach(d=>{this[d]=s[d]})}};const MPt=i=>{const s=new LPt;return s.calculate(i),s};let DPt=class{constructor(){this.background="#333",this.primaryColor="#1f2020",this.secondaryColor=Gs(this.primaryColor,16),this.tertiaryColor=In(this.primaryColor,{h:-160}),this.primaryBorderColor=Vi(this.background),this.secondaryBorderColor=Tp(this.secondaryColor,this.darkMode),this.tertiaryBorderColor=Tp(this.tertiaryColor,this.darkMode),this.primaryTextColor=Vi(this.primaryColor),this.secondaryTextColor=Vi(this.secondaryColor),this.tertiaryTextColor=Vi(this.tertiaryColor),this.lineColor=Vi(this.background),this.textColor=Vi(this.background),this.mainBkg="#1f2020",this.secondBkg="calculated",this.mainContrastColor="lightgrey",this.darkTextColor=Gs(Vi("#323D47"),10),this.lineColor="calculated",this.border1="#81B1DB",this.border2=SC(255,255,255,.25),this.arrowheadColor="calculated",this.fontFamily='"trebuchet ms", verdana, arial, sans-serif',this.fontSize="16px",this.labelBackground="#181818",this.textColor="#ccc",this.THEME_COLOR_LIMIT=12,this.nodeBkg="calculated",this.nodeBorder="calculated",this.clusterBkg="calculated",this.clusterBorder="calculated",this.defaultLinkColor="calculated",this.titleColor="#F9FFFE",this.edgeLabelBackground="calculated",this.actorBorder="calculated",this.actorBkg="calculated",this.actorTextColor="calculated",this.actorLineColor="calculated",this.signalColor="calculated",this.signalTextColor="calculated",this.labelBoxBkgColor="calculated",this.labelBoxBorderColor="calculated",this.labelTextColor="calculated",this.loopTextColor="calculated",this.noteBorderColor="calculated",this.noteBkgColor="#fff5ad",this.noteTextColor="calculated",this.activationBorderColor="calculated",this.activationBkgColor="calculated",this.sequenceNumberColor="black",this.sectionBkgColor=fa("#EAE8D9",30),this.altSectionBkgColor="calculated",this.sectionBkgColor2="#EAE8D9",this.excludeBkgColor=fa(this.sectionBkgColor,10),this.taskBorderColor=SC(255,255,255,70),this.taskBkgColor="calculated",this.taskTextColor="calculated",this.taskTextLightColor="calculated",this.taskTextOutsideColor="calculated",this.taskTextClickableColor="#003163",this.activeTaskBorderColor=SC(255,255,255,50),this.activeTaskBkgColor="#81B1DB",this.gridColor="calculated",this.doneTaskBkgColor="calculated",this.doneTaskBorderColor="grey",this.critBorderColor="#E83737",this.critBkgColor="#E83737",this.taskTextDarkColor="calculated",this.todayLineColor="#DB5757",this.personBorder=this.primaryBorderColor,this.personBkg=this.mainBkg,this.labelColor="calculated",this.errorBkgColor="#a44141",this.errorTextColor="#ddd"}updateColors(){var s,u,d,p,v,b,y,T,_,A,P;this.secondBkg=Gs(this.mainBkg,16),this.lineColor=this.mainContrastColor,this.arrowheadColor=this.mainContrastColor,this.nodeBkg=this.mainBkg,this.nodeBorder=this.border1,this.clusterBkg=this.secondBkg,this.clusterBorder=this.border2,this.defaultLinkColor=this.lineColor,this.edgeLabelBackground=Gs(this.labelBackground,25),this.actorBorder=this.border1,this.actorBkg=this.mainBkg,this.actorTextColor=this.mainContrastColor,this.actorLineColor=this.mainContrastColor,this.signalColor=this.mainContrastColor,this.signalTextColor=this.mainContrastColor,this.labelBoxBkgColor=this.actorBkg,this.labelBoxBorderColor=this.actorBorder,this.labelTextColor=this.mainContrastColor,this.loopTextColor=this.mainContrastColor,this.noteBorderColor=this.secondaryBorderColor,this.noteBkgColor=this.secondBkg,this.noteTextColor=this.secondaryTextColor,this.activationBorderColor=this.border1,this.activationBkgColor=this.secondBkg,this.altSectionBkgColor=this.background,this.taskBkgColor=Gs(this.mainBkg,23),this.taskTextColor=this.darkTextColor,this.taskTextLightColor=this.mainContrastColor,this.taskTextOutsideColor=this.taskTextLightColor,this.gridColor=this.mainContrastColor,this.doneTaskBkgColor=this.mainContrastColor,this.taskTextDarkColor=this.darkTextColor,this.transitionColor=this.transitionColor||this.lineColor,this.transitionLabelColor=this.transitionLabelColor||this.textColor,this.stateLabelColor=this.stateLabelColor||this.stateBkg||this.primaryTextColor,this.stateBkg=this.stateBkg||this.mainBkg,this.labelBackgroundColor=this.labelBackgroundColor||this.stateBkg,this.compositeBackground=this.compositeBackground||this.background||this.tertiaryColor,this.altBackground=this.altBackground||"#555",this.compositeTitleBackground=this.compositeTitleBackground||this.mainBkg,this.compositeBorder=this.compositeBorder||this.nodeBorder,this.innerEndBackground=this.primaryBorderColor,this.specialStateColor="#f4f4f4",this.errorBkgColor=this.errorBkgColor||this.tertiaryColor,this.errorTextColor=this.errorTextColor||this.tertiaryTextColor,this.fillType0=this.primaryColor,this.fillType1=this.secondaryColor,this.fillType2=In(this.primaryColor,{h:64}),this.fillType3=In(this.secondaryColor,{h:64}),this.fillType4=In(this.primaryColor,{h:-64}),this.fillType5=In(this.secondaryColor,{h:-64}),this.fillType6=In(this.primaryColor,{h:128}),this.fillType7=In(this.secondaryColor,{h:128}),this.cScale1=this.cScale1||"#0b0000",this.cScale2=this.cScale2||"#4d1037",this.cScale3=this.cScale3||"#3f5258",this.cScale4=this.cScale4||"#4f2f1b",this.cScale5=this.cScale5||"#6e0a0a",this.cScale6=this.cScale6||"#3b0048",this.cScale7=this.cScale7||"#995a01",this.cScale8=this.cScale8||"#154706",this.cScale9=this.cScale9||"#161722",this.cScale10=this.cScale10||"#00296f",this.cScale11=this.cScale11||"#01629c",this.cScale12=this.cScale12||"#010029",this.cScale0=this.cScale0||this.primaryColor,this.cScale1=this.cScale1||this.secondaryColor,this.cScale2=this.cScale2||this.tertiaryColor,this.cScale3=this.cScale3||In(this.primaryColor,{h:30}),this.cScale4=this.cScale4||In(this.primaryColor,{h:60}),this.cScale5=this.cScale5||In(this.primaryColor,{h:90}),this.cScale6=this.cScale6||In(this.primaryColor,{h:120}),this.cScale7=this.cScale7||In(this.primaryColor,{h:150}),this.cScale8=this.cScale8||In(this.primaryColor,{h:210}),this.cScale9=this.cScale9||In(this.primaryColor,{h:270}),this.cScale10=this.cScale10||In(this.primaryColor,{h:300}),this.cScale11=this.cScale11||In(this.primaryColor,{h:330});for(let R=0;R{this[d]=s[d]}),this.updateColors(),u.forEach(d=>{this[d]=s[d]})}};const IPt=i=>{const s=new DPt;return s.calculate(i),s};let OPt=class{constructor(){this.background="#f4f4f4",this.primaryColor="#ECECFF",this.secondaryColor=In(this.primaryColor,{h:120}),this.secondaryColor="#ffffde",this.tertiaryColor=In(this.primaryColor,{h:-160}),this.primaryBorderColor=Tp(this.primaryColor,this.darkMode),this.secondaryBorderColor=Tp(this.secondaryColor,this.darkMode),this.tertiaryBorderColor=Tp(this.tertiaryColor,this.darkMode),this.primaryTextColor=Vi(this.primaryColor),this.secondaryTextColor=Vi(this.secondaryColor),this.tertiaryTextColor=Vi(this.tertiaryColor),this.lineColor=Vi(this.background),this.textColor=Vi(this.background),this.background="white",this.mainBkg="#ECECFF",this.secondBkg="#ffffde",this.lineColor="#333333",this.border1="#9370DB",this.border2="#aaaa33",this.arrowheadColor="#333333",this.fontFamily='"trebuchet ms", verdana, arial, sans-serif',this.fontSize="16px",this.labelBackground="#e8e8e8",this.textColor="#333",this.THEME_COLOR_LIMIT=12,this.nodeBkg="calculated",this.nodeBorder="calculated",this.clusterBkg="calculated",this.clusterBorder="calculated",this.defaultLinkColor="calculated",this.titleColor="calculated",this.edgeLabelBackground="calculated",this.actorBorder="calculated",this.actorBkg="calculated",this.actorTextColor="black",this.actorLineColor="grey",this.signalColor="calculated",this.signalTextColor="calculated",this.labelBoxBkgColor="calculated",this.labelBoxBorderColor="calculated",this.labelTextColor="calculated",this.loopTextColor="calculated",this.noteBorderColor="calculated",this.noteBkgColor="#fff5ad",this.noteTextColor="calculated",this.activationBorderColor="#666",this.activationBkgColor="#f4f4f4",this.sequenceNumberColor="white",this.sectionBkgColor="calculated",this.altSectionBkgColor="calculated",this.sectionBkgColor2="calculated",this.excludeBkgColor="#eeeeee",this.taskBorderColor="calculated",this.taskBkgColor="calculated",this.taskTextLightColor="calculated",this.taskTextColor=this.taskTextLightColor,this.taskTextDarkColor="calculated",this.taskTextOutsideColor=this.taskTextDarkColor,this.taskTextClickableColor="calculated",this.activeTaskBorderColor="calculated",this.activeTaskBkgColor="calculated",this.gridColor="calculated",this.doneTaskBkgColor="calculated",this.doneTaskBorderColor="calculated",this.critBorderColor="calculated",this.critBkgColor="calculated",this.todayLineColor="calculated",this.sectionBkgColor=SC(102,102,255,.49),this.altSectionBkgColor="white",this.sectionBkgColor2="#fff400",this.taskBorderColor="#534fbc",this.taskBkgColor="#8a90dd",this.taskTextLightColor="white",this.taskTextColor="calculated",this.taskTextDarkColor="black",this.taskTextOutsideColor="calculated",this.taskTextClickableColor="#003163",this.activeTaskBorderColor="#534fbc",this.activeTaskBkgColor="#bfc7ff",this.gridColor="lightgrey",this.doneTaskBkgColor="lightgrey",this.doneTaskBorderColor="grey",this.critBorderColor="#ff8888",this.critBkgColor="red",this.todayLineColor="red",this.personBorder=this.primaryBorderColor,this.personBkg=this.mainBkg,this.labelColor="black",this.errorBkgColor="#552222",this.errorTextColor="#552222",this.updateColors()}updateColors(){var s,u,d,p,v,b,y,T,_,A,P;this.cScale0=this.cScale0||this.primaryColor,this.cScale1=this.cScale1||this.secondaryColor,this.cScale2=this.cScale2||this.tertiaryColor,this.cScale3=this.cScale3||In(this.primaryColor,{h:30}),this.cScale4=this.cScale4||In(this.primaryColor,{h:60}),this.cScale5=this.cScale5||In(this.primaryColor,{h:90}),this.cScale6=this.cScale6||In(this.primaryColor,{h:120}),this.cScale7=this.cScale7||In(this.primaryColor,{h:150}),this.cScale8=this.cScale8||In(this.primaryColor,{h:210}),this.cScale9=this.cScale9||In(this.primaryColor,{h:270}),this.cScale10=this.cScale10||In(this.primaryColor,{h:300}),this.cScale11=this.cScale11||In(this.primaryColor,{h:330}),this["cScalePeer1"]=this["cScalePeer1"]||fa(this.secondaryColor,45),this["cScalePeer2"]=this["cScalePeer2"]||fa(this.tertiaryColor,40);for(let R=0;R{this[d]=s[d]}),this.updateColors(),u.forEach(d=>{this[d]=s[d]})}};const f2e=i=>{const s=new OPt;return s.calculate(i),s};let NPt=class{constructor(){this.background="#f4f4f4",this.primaryColor="#cde498",this.secondaryColor="#cdffb2",this.background="white",this.mainBkg="#cde498",this.secondBkg="#cdffb2",this.lineColor="green",this.border1="#13540c",this.border2="#6eaa49",this.arrowheadColor="green",this.fontFamily='"trebuchet ms", verdana, arial, sans-serif',this.fontSize="16px",this.tertiaryColor=Gs("#cde498",10),this.primaryBorderColor=Tp(this.primaryColor,this.darkMode),this.secondaryBorderColor=Tp(this.secondaryColor,this.darkMode),this.tertiaryBorderColor=Tp(this.tertiaryColor,this.darkMode),this.primaryTextColor=Vi(this.primaryColor),this.secondaryTextColor=Vi(this.secondaryColor),this.tertiaryTextColor=Vi(this.primaryColor),this.lineColor=Vi(this.background),this.textColor=Vi(this.background),this.THEME_COLOR_LIMIT=12,this.nodeBkg="calculated",this.nodeBorder="calculated",this.clusterBkg="calculated",this.clusterBorder="calculated",this.defaultLinkColor="calculated",this.titleColor="#333",this.edgeLabelBackground="#e8e8e8",this.actorBorder="calculated",this.actorBkg="calculated",this.actorTextColor="black",this.actorLineColor="grey",this.signalColor="#333",this.signalTextColor="#333",this.labelBoxBkgColor="calculated",this.labelBoxBorderColor="#326932",this.labelTextColor="calculated",this.loopTextColor="calculated",this.noteBorderColor="calculated",this.noteBkgColor="#fff5ad",this.noteTextColor="calculated",this.activationBorderColor="#666",this.activationBkgColor="#f4f4f4",this.sequenceNumberColor="white",this.sectionBkgColor="#6eaa49",this.altSectionBkgColor="white",this.sectionBkgColor2="#6eaa49",this.excludeBkgColor="#eeeeee",this.taskBorderColor="calculated",this.taskBkgColor="#487e3a",this.taskTextLightColor="white",this.taskTextColor="calculated",this.taskTextDarkColor="black",this.taskTextOutsideColor="calculated",this.taskTextClickableColor="#003163",this.activeTaskBorderColor="calculated",this.activeTaskBkgColor="calculated",this.gridColor="lightgrey",this.doneTaskBkgColor="lightgrey",this.doneTaskBorderColor="grey",this.critBorderColor="#ff8888",this.critBkgColor="red",this.todayLineColor="red",this.personBorder=this.primaryBorderColor,this.personBkg=this.mainBkg,this.labelColor="black",this.errorBkgColor="#552222",this.errorTextColor="#552222"}updateColors(){var s,u,d,p,v,b,y,T,_,A,P;this.actorBorder=fa(this.mainBkg,20),this.actorBkg=this.mainBkg,this.labelBoxBkgColor=this.actorBkg,this.labelTextColor=this.actorTextColor,this.loopTextColor=this.actorTextColor,this.noteBorderColor=this.border2,this.noteTextColor=this.actorTextColor,this.cScale0=this.cScale0||this.primaryColor,this.cScale1=this.cScale1||this.secondaryColor,this.cScale2=this.cScale2||this.tertiaryColor,this.cScale3=this.cScale3||In(this.primaryColor,{h:30}),this.cScale4=this.cScale4||In(this.primaryColor,{h:60}),this.cScale5=this.cScale5||In(this.primaryColor,{h:90}),this.cScale6=this.cScale6||In(this.primaryColor,{h:120}),this.cScale7=this.cScale7||In(this.primaryColor,{h:150}),this.cScale8=this.cScale8||In(this.primaryColor,{h:210}),this.cScale9=this.cScale9||In(this.primaryColor,{h:270}),this.cScale10=this.cScale10||In(this.primaryColor,{h:300}),this.cScale11=this.cScale11||In(this.primaryColor,{h:330}),this["cScalePeer1"]=this["cScalePeer1"]||fa(this.secondaryColor,45),this["cScalePeer2"]=this["cScalePeer2"]||fa(this.tertiaryColor,40);for(let R=0;R{this[d]=s[d]}),this.updateColors(),u.forEach(d=>{this[d]=s[d]})}};const PPt=i=>{const s=new NPt;return s.calculate(i),s};class BPt{constructor(){this.primaryColor="#eee",this.contrast="#707070",this.secondaryColor=Gs(this.contrast,55),this.background="#ffffff",this.tertiaryColor=In(this.primaryColor,{h:-160}),this.primaryBorderColor=Tp(this.primaryColor,this.darkMode),this.secondaryBorderColor=Tp(this.secondaryColor,this.darkMode),this.tertiaryBorderColor=Tp(this.tertiaryColor,this.darkMode),this.primaryTextColor=Vi(this.primaryColor),this.secondaryTextColor=Vi(this.secondaryColor),this.tertiaryTextColor=Vi(this.tertiaryColor),this.lineColor=Vi(this.background),this.textColor=Vi(this.background),this.mainBkg="#eee",this.secondBkg="calculated",this.lineColor="#666",this.border1="#999",this.border2="calculated",this.note="#ffa",this.text="#333",this.critical="#d42",this.done="#bbb",this.arrowheadColor="#333333",this.fontFamily='"trebuchet ms", verdana, arial, sans-serif',this.fontSize="16px",this.THEME_COLOR_LIMIT=12,this.nodeBkg="calculated",this.nodeBorder="calculated",this.clusterBkg="calculated",this.clusterBorder="calculated",this.defaultLinkColor="calculated",this.titleColor="calculated",this.edgeLabelBackground="white",this.actorBorder="calculated",this.actorBkg="calculated",this.actorTextColor="calculated",this.actorLineColor="calculated",this.signalColor="calculated",this.signalTextColor="calculated",this.labelBoxBkgColor="calculated",this.labelBoxBorderColor="calculated",this.labelTextColor="calculated",this.loopTextColor="calculated",this.noteBorderColor="calculated",this.noteBkgColor="calculated",this.noteTextColor="calculated",this.activationBorderColor="#666",this.activationBkgColor="#f4f4f4",this.sequenceNumberColor="white",this.sectionBkgColor="calculated",this.altSectionBkgColor="white",this.sectionBkgColor2="calculated",this.excludeBkgColor="#eeeeee",this.taskBorderColor="calculated",this.taskBkgColor="calculated",this.taskTextLightColor="white",this.taskTextColor="calculated",this.taskTextDarkColor="calculated",this.taskTextOutsideColor="calculated",this.taskTextClickableColor="#003163",this.activeTaskBorderColor="calculated",this.activeTaskBkgColor="calculated",this.gridColor="calculated",this.doneTaskBkgColor="calculated",this.doneTaskBorderColor="calculated",this.critBkgColor="calculated",this.critBorderColor="calculated",this.todayLineColor="calculated",this.personBorder=this.primaryBorderColor,this.personBkg=this.mainBkg,this.labelColor="black",this.errorBkgColor="#552222",this.errorTextColor="#552222"}updateColors(){var s,u,d,p,v,b,y,T,_,A,P;this.secondBkg=Gs(this.contrast,55),this.border2=this.contrast,this.actorBorder=Gs(this.border1,23),this.actorBkg=this.mainBkg,this.actorTextColor=this.text,this.actorLineColor=this.lineColor,this.signalColor=this.text,this.signalTextColor=this.text,this.labelBoxBkgColor=this.actorBkg,this.labelBoxBorderColor=this.actorBorder,this.labelTextColor=this.text,this.loopTextColor=this.text,this.noteBorderColor="#999",this.noteBkgColor="#666",this.noteTextColor="#fff",this.cScale0=this.cScale0||"#555",this.cScale1=this.cScale1||"#F4F4F4",this.cScale2=this.cScale2||"#555",this.cScale3=this.cScale3||"#BBB",this.cScale4=this.cScale4||"#777",this.cScale5=this.cScale5||"#999",this.cScale6=this.cScale6||"#DDD",this.cScale7=this.cScale7||"#FFF",this.cScale8=this.cScale8||"#DDD",this.cScale9=this.cScale9||"#BBB",this.cScale10=this.cScale10||"#999",this.cScale11=this.cScale11||"#777";for(let R=0;R{this[d]=s[d]}),this.updateColors(),u.forEach(d=>{this[d]=s[d]})}}const E7={base:{getThemeVariables:MPt},dark:{getThemeVariables:IPt},default:{getThemeVariables:f2e},forest:{getThemeVariables:PPt},neutral:{getThemeVariables:i=>{const s=new BPt;return s.calculate(i),s}}},T7={flowchart:{useMaxWidth:!0,titleTopMargin:25,subGraphTitleMargin:{top:0,bottom:0},diagramPadding:8,htmlLabels:!0,nodeSpacing:50,rankSpacing:50,curve:"basis",padding:15,defaultRenderer:"dagre-wrapper",wrappingWidth:200},sequence:{useMaxWidth:!0,hideUnusedParticipants:!1,activationWidth:10,diagramMarginX:50,diagramMarginY:10,actorMargin:50,width:150,height:65,boxMargin:10,boxTextMargin:5,noteMargin:10,messageMargin:35,messageAlign:"center",mirrorActors:!0,forceMenus:!1,bottomMarginAdj:1,rightAngles:!1,showSequenceNumbers:!1,actorFontSize:14,actorFontFamily:'"Open Sans", sans-serif',actorFontWeight:400,noteFontSize:14,noteFontFamily:'"trebuchet ms", verdana, arial, sans-serif',noteFontWeight:400,noteAlign:"center",messageFontSize:16,messageFontFamily:'"trebuchet ms", verdana, arial, sans-serif',messageFontWeight:400,wrap:!1,wrapPadding:10,labelBoxWidth:50,labelBoxHeight:20},gantt:{useMaxWidth:!0,titleTopMargin:25,barHeight:20,barGap:4,topPadding:50,rightPadding:75,leftPadding:75,gridLineStartPadding:35,fontSize:11,sectionFontSize:11,numberSectionStyles:4,axisFormat:"%Y-%m-%d",topAxis:!1,displayMode:"",weekday:"sunday"},journey:{useMaxWidth:!0,diagramMarginX:50,diagramMarginY:10,leftMargin:150,width:150,height:50,boxMargin:10,boxTextMargin:5,noteMargin:10,messageMargin:35,messageAlign:"center",bottomMarginAdj:1,rightAngles:!1,taskFontSize:14,taskFontFamily:'"Open Sans", sans-serif',taskMargin:50,activationWidth:10,textPlacement:"fo",actorColours:["#8FBC8F","#7CFC00","#00FFFF","#20B2AA","#B0E0E6","#FFFFE0"],sectionFills:["#191970","#8B008B","#4B0082","#2F4F4F","#800000","#8B4513","#00008B"],sectionColours:["#fff"]},class:{useMaxWidth:!0,titleTopMargin:25,arrowMarkerAbsolute:!1,dividerMargin:10,padding:5,textHeight:10,defaultRenderer:"dagre-wrapper",htmlLabels:!1},state:{useMaxWidth:!0,titleTopMargin:25,dividerMargin:10,sizeUnit:5,padding:8,textHeight:10,titleShift:-15,noteMargin:10,forkWidth:70,forkHeight:7,miniPadding:2,fontSizeFactor:5.02,fontSize:24,labelHeight:16,edgeLengthFactor:"20",compositTitleSize:35,radius:5,defaultRenderer:"dagre-wrapper"},er:{useMaxWidth:!0,titleTopMargin:25,diagramPadding:20,layoutDirection:"TB",minEntityWidth:100,minEntityHeight:75,entityPadding:15,stroke:"gray",fill:"honeydew",fontSize:12},pie:{useMaxWidth:!0,textPosition:.75},quadrantChart:{useMaxWidth:!0,chartWidth:500,chartHeight:500,titleFontSize:20,titlePadding:10,quadrantPadding:5,xAxisLabelPadding:5,yAxisLabelPadding:5,xAxisLabelFontSize:16,yAxisLabelFontSize:16,quadrantLabelFontSize:16,quadrantTextTopPadding:5,pointTextPadding:5,pointLabelFontSize:12,pointRadius:5,xAxisPosition:"top",yAxisPosition:"left",quadrantInternalBorderStrokeWidth:1,quadrantExternalBorderStrokeWidth:2},xyChart:{useMaxWidth:!0,width:700,height:500,titleFontSize:20,titlePadding:10,showTitle:!0,xAxis:{$ref:"#/$defs/XYChartAxisConfig",showLabel:!0,labelFontSize:14,labelPadding:5,showTitle:!0,titleFontSize:16,titlePadding:5,showTick:!0,tickLength:5,tickWidth:2,showAxisLine:!0,axisLineWidth:2},yAxis:{$ref:"#/$defs/XYChartAxisConfig",showLabel:!0,labelFontSize:14,labelPadding:5,showTitle:!0,titleFontSize:16,titlePadding:5,showTick:!0,tickLength:5,tickWidth:2,showAxisLine:!0,axisLineWidth:2},chartOrientation:"vertical",plotReservedSpacePercent:50},requirement:{useMaxWidth:!0,rect_fill:"#f9f9f9",text_color:"#333",rect_border_size:"0.5px",rect_border_color:"#bbb",rect_min_width:200,rect_min_height:200,fontSize:14,rect_padding:10,line_height:20},mindmap:{useMaxWidth:!0,padding:10,maxNodeWidth:200},timeline:{useMaxWidth:!0,diagramMarginX:50,diagramMarginY:10,leftMargin:150,width:150,height:50,boxMargin:10,boxTextMargin:5,noteMargin:10,messageMargin:35,messageAlign:"center",bottomMarginAdj:1,rightAngles:!1,taskFontSize:14,taskFontFamily:'"Open Sans", sans-serif',taskMargin:50,activationWidth:10,textPlacement:"fo",actorColours:["#8FBC8F","#7CFC00","#00FFFF","#20B2AA","#B0E0E6","#FFFFE0"],sectionFills:["#191970","#8B008B","#4B0082","#2F4F4F","#800000","#8B4513","#00008B"],sectionColours:["#fff"],disableMulticolor:!1},gitGraph:{useMaxWidth:!0,titleTopMargin:25,diagramPadding:8,nodeLabel:{width:75,height:100,x:-25,y:0},mainBranchName:"main",mainBranchOrder:0,showCommitLabel:!0,showBranches:!0,rotateCommitLabel:!0,parallelCommits:!1,arrowMarkerAbsolute:!1},c4:{useMaxWidth:!0,diagramMarginX:50,diagramMarginY:10,c4ShapeMargin:50,c4ShapePadding:20,width:216,height:60,boxMargin:10,c4ShapeInRow:4,nextLinePaddingX:0,c4BoundaryInRow:2,personFontSize:14,personFontFamily:'"Open Sans", sans-serif',personFontWeight:"normal",external_personFontSize:14,external_personFontFamily:'"Open Sans", sans-serif',external_personFontWeight:"normal",systemFontSize:14,systemFontFamily:'"Open Sans", sans-serif',systemFontWeight:"normal",external_systemFontSize:14,external_systemFontFamily:'"Open Sans", sans-serif',external_systemFontWeight:"normal",system_dbFontSize:14,system_dbFontFamily:'"Open Sans", sans-serif',system_dbFontWeight:"normal",external_system_dbFontSize:14,external_system_dbFontFamily:'"Open Sans", sans-serif',external_system_dbFontWeight:"normal",system_queueFontSize:14,system_queueFontFamily:'"Open Sans", sans-serif',system_queueFontWeight:"normal",external_system_queueFontSize:14,external_system_queueFontFamily:'"Open Sans", sans-serif',external_system_queueFontWeight:"normal",boundaryFontSize:14,boundaryFontFamily:'"Open Sans", sans-serif',boundaryFontWeight:"normal",messageFontSize:12,messageFontFamily:'"Open Sans", sans-serif',messageFontWeight:"normal",containerFontSize:14,containerFontFamily:'"Open Sans", sans-serif',containerFontWeight:"normal",external_containerFontSize:14,external_containerFontFamily:'"Open Sans", sans-serif',external_containerFontWeight:"normal",container_dbFontSize:14,container_dbFontFamily:'"Open Sans", sans-serif',container_dbFontWeight:"normal",external_container_dbFontSize:14,external_container_dbFontFamily:'"Open Sans", sans-serif',external_container_dbFontWeight:"normal",container_queueFontSize:14,container_queueFontFamily:'"Open Sans", sans-serif',container_queueFontWeight:"normal",external_container_queueFontSize:14,external_container_queueFontFamily:'"Open Sans", sans-serif',external_container_queueFontWeight:"normal",componentFontSize:14,componentFontFamily:'"Open Sans", sans-serif',componentFontWeight:"normal",external_componentFontSize:14,external_componentFontFamily:'"Open Sans", sans-serif',external_componentFontWeight:"normal",component_dbFontSize:14,component_dbFontFamily:'"Open Sans", sans-serif',component_dbFontWeight:"normal",external_component_dbFontSize:14,external_component_dbFontFamily:'"Open Sans", sans-serif',external_component_dbFontWeight:"normal",component_queueFontSize:14,component_queueFontFamily:'"Open Sans", sans-serif',component_queueFontWeight:"normal",external_component_queueFontSize:14,external_component_queueFontFamily:'"Open Sans", sans-serif',external_component_queueFontWeight:"normal",wrap:!0,wrapPadding:10,person_bg_color:"#08427B",person_border_color:"#073B6F",external_person_bg_color:"#686868",external_person_border_color:"#8A8A8A",system_bg_color:"#1168BD",system_border_color:"#3C7FC0",system_db_bg_color:"#1168BD",system_db_border_color:"#3C7FC0",system_queue_bg_color:"#1168BD",system_queue_border_color:"#3C7FC0",external_system_bg_color:"#999999",external_system_border_color:"#8A8A8A",external_system_db_bg_color:"#999999",external_system_db_border_color:"#8A8A8A",external_system_queue_bg_color:"#999999",external_system_queue_border_color:"#8A8A8A",container_bg_color:"#438DD5",container_border_color:"#3C7FC0",container_db_bg_color:"#438DD5",container_db_border_color:"#3C7FC0",container_queue_bg_color:"#438DD5",container_queue_border_color:"#3C7FC0",external_container_bg_color:"#B3B3B3",external_container_border_color:"#A6A6A6",external_container_db_bg_color:"#B3B3B3",external_container_db_border_color:"#A6A6A6",external_container_queue_bg_color:"#B3B3B3",external_container_queue_border_color:"#A6A6A6",component_bg_color:"#85BBF0",component_border_color:"#78A8D8",component_db_bg_color:"#85BBF0",component_db_border_color:"#78A8D8",component_queue_bg_color:"#85BBF0",component_queue_border_color:"#78A8D8",external_component_bg_color:"#CCCCCC",external_component_border_color:"#BFBFBF",external_component_db_bg_color:"#CCCCCC",external_component_db_border_color:"#BFBFBF",external_component_queue_bg_color:"#CCCCCC",external_component_queue_border_color:"#BFBFBF"},sankey:{useMaxWidth:!0,width:600,height:400,linkColor:"gradient",nodeAlignment:"justify",showValues:!0,prefix:"",suffix:""},block:{useMaxWidth:!0,padding:8},theme:"default",maxTextSize:5e4,maxEdges:500,darkMode:!1,fontFamily:'"trebuchet ms", verdana, arial, sans-serif;',logLevel:5,securityLevel:"strict",startOnLoad:!0,arrowMarkerAbsolute:!1,secure:["secure","securityLevel","startOnLoad","maxTextSize","maxEdges"],legacyMathML:!1,deterministicIds:!1,fontSize:16},MRe={...T7,deterministicIDSeed:void 0,themeCSS:void 0,themeVariables:E7.default.getThemeVariables(),sequence:{...T7.sequence,messageFont:function(){return{fontFamily:this.messageFontFamily,fontSize:this.messageFontSize,fontWeight:this.messageFontWeight}},noteFont:function(){return{fontFamily:this.noteFontFamily,fontSize:this.noteFontSize,fontWeight:this.noteFontWeight}},actorFont:function(){return{fontFamily:this.actorFontFamily,fontSize:this.actorFontSize,fontWeight:this.actorFontWeight}}},gantt:{...T7.gantt,tickInterval:void 0,useWidth:void 0},c4:{...T7.c4,useWidth:void 0,personFont:function(){return{fontFamily:this.personFontFamily,fontSize:this.personFontSize,fontWeight:this.personFontWeight}},external_personFont:function(){return{fontFamily:this.external_personFontFamily,fontSize:this.external_personFontSize,fontWeight:this.external_personFontWeight}},systemFont:function(){return{fontFamily:this.systemFontFamily,fontSize:this.systemFontSize,fontWeight:this.systemFontWeight}},external_systemFont:function(){return{fontFamily:this.external_systemFontFamily,fontSize:this.external_systemFontSize,fontWeight:this.external_systemFontWeight}},system_dbFont:function(){return{fontFamily:this.system_dbFontFamily,fontSize:this.system_dbFontSize,fontWeight:this.system_dbFontWeight}},external_system_dbFont:function(){return{fontFamily:this.external_system_dbFontFamily,fontSize:this.external_system_dbFontSize,fontWeight:this.external_system_dbFontWeight}},system_queueFont:function(){return{fontFamily:this.system_queueFontFamily,fontSize:this.system_queueFontSize,fontWeight:this.system_queueFontWeight}},external_system_queueFont:function(){return{fontFamily:this.external_system_queueFontFamily,fontSize:this.external_system_queueFontSize,fontWeight:this.external_system_queueFontWeight}},containerFont:function(){return{fontFamily:this.containerFontFamily,fontSize:this.containerFontSize,fontWeight:this.containerFontWeight}},external_containerFont:function(){return{fontFamily:this.external_containerFontFamily,fontSize:this.external_containerFontSize,fontWeight:this.external_containerFontWeight}},container_dbFont:function(){return{fontFamily:this.container_dbFontFamily,fontSize:this.container_dbFontSize,fontWeight:this.container_dbFontWeight}},external_container_dbFont:function(){return{fontFamily:this.external_container_dbFontFamily,fontSize:this.external_container_dbFontSize,fontWeight:this.external_container_dbFontWeight}},container_queueFont:function(){return{fontFamily:this.container_queueFontFamily,fontSize:this.container_queueFontSize,fontWeight:this.container_queueFontWeight}},external_container_queueFont:function(){return{fontFamily:this.external_container_queueFontFamily,fontSize:this.external_container_queueFontSize,fontWeight:this.external_container_queueFontWeight}},componentFont:function(){return{fontFamily:this.componentFontFamily,fontSize:this.componentFontSize,fontWeight:this.componentFontWeight}},external_componentFont:function(){return{fontFamily:this.external_componentFontFamily,fontSize:this.external_componentFontSize,fontWeight:this.external_componentFontWeight}},component_dbFont:function(){return{fontFamily:this.component_dbFontFamily,fontSize:this.component_dbFontSize,fontWeight:this.component_dbFontWeight}},external_component_dbFont:function(){return{fontFamily:this.external_component_dbFontFamily,fontSize:this.external_component_dbFontSize,fontWeight:this.external_component_dbFontWeight}},component_queueFont:function(){return{fontFamily:this.component_queueFontFamily,fontSize:this.component_queueFontSize,fontWeight:this.component_queueFontWeight}},external_component_queueFont:function(){return{fontFamily:this.external_component_queueFontFamily,fontSize:this.external_component_queueFontSize,fontWeight:this.external_component_queueFontWeight}},boundaryFont:function(){return{fontFamily:this.boundaryFontFamily,fontSize:this.boundaryFontSize,fontWeight:this.boundaryFontWeight}},messageFont:function(){return{fontFamily:this.messageFontFamily,fontSize:this.messageFontSize,fontWeight:this.messageFontWeight}}},pie:{...T7.pie,useWidth:984},xyChart:{...T7.xyChart,useWidth:void 0},requirement:{...T7.requirement,useWidth:void 0},gitGraph:{...T7.gitGraph,useMaxWidth:!1},sankey:{...T7.sankey,useMaxWidth:!1}},DRe=(i,s="")=>Object.keys(i).reduce((u,d)=>Array.isArray(i[d])?u:typeof i[d]=="object"&&i[d]!==null?[...u,s+d,...DRe(i[d],"")]:[...u,s+d],[]),FPt=new Set(DRe(MRe,"")),sh=MRe,SX=i=>{if(Xe.debug("sanitizeDirective called with",i),!(typeof i!="object"||i==null)){if(Array.isArray(i)){i.forEach(s=>SX(s));return}for(const s of Object.keys(i)){if(Xe.debug("Checking key",s),s.startsWith("__")||s.includes("proto")||s.includes("constr")||!FPt.has(s)||i[s]==null){Xe.debug("sanitize deleting key: ",s),delete i[s];continue}if(typeof i[s]=="object"){Xe.debug("sanitizing object",s),SX(i[s]);continue}const u=["themeCSS","fontFamily","altFontFamily"];for(const d of u)s.includes(d)&&(Xe.debug("sanitizing css option",s),i[s]=RPt(i[s]))}if(i.themeVariables)for(const s of Object.keys(i.themeVariables)){const u=i.themeVariables[s];u!=null&&u.match&&!u.match(/^[\d "#%(),.;A-Za-z]+$/)&&(i.themeVariables[s]="")}Xe.debug("After sanitization",i)}},RPt=i=>{let s=0,u=0;for(const d of i){if(s{for(const{id:s,detector:u,loader:d}of i)PRe(s,u,d)},PRe=(i,s,u)=>{dD[i]?Xe.error(`Detector with key ${i} already exists`):dD[i]={detector:s,loader:u},Xe.debug(`Detector with key ${i} added${u?" with loader":""}`)},$Pt=i=>dD[i].loader,d2e=(i,s,{depth:u=2,clobber:d=!1}={})=>{const p={depth:u,clobber:d};return Array.isArray(s)&&!Array.isArray(i)?(s.forEach(v=>d2e(i,v,p)),i):Array.isArray(s)&&Array.isArray(i)?(s.forEach(v=>{i.includes(v)||i.push(v)}),i):i===void 0||u<=0?i!=null&&typeof i=="object"&&typeof s=="object"?Object.assign(i,s):s:(s!==void 0&&typeof i=="object"&&typeof s=="object"&&Object.keys(s).forEach(v=>{typeof s[v]=="object"&&(i[v]===void 0||typeof i[v]=="object")?(i[v]===void 0&&(i[v]=Array.isArray(s[v])?[]:{}),i[v]=d2e(i[v],s[v],{depth:u-1,clobber:d})):(d||typeof i[v]!="object"&&typeof s[v]!="object")&&(i[v]=s[v])}),i)},id=d2e;var zPt=typeof global=="object"&&global&&global.Object===Object&&global;const BRe=zPt;var qPt=typeof self=="object"&&self&&self.Object===Object&&self,HPt=BRe||qPt||Function("return this")();const N3=HPt;var VPt=N3.Symbol;const Iv=VPt;var FRe=Object.prototype,UPt=FRe.hasOwnProperty,GPt=FRe.toString,GF=Iv?Iv.toStringTag:void 0;function KPt(i){var s=UPt.call(i,GF),u=i[GF];try{i[GF]=void 0;var d=!0}catch{}var p=GPt.call(i);return d&&(s?i[GF]=u:delete i[GF]),p}var WPt=Object.prototype,YPt=WPt.toString;function XPt(i){return YPt.call(i)}var QPt="[object Null]",JPt="[object Undefined]",RRe=Iv?Iv.toStringTag:void 0;function AC(i){return i==null?i===void 0?JPt:QPt:RRe&&RRe in Object(i)?KPt(i):XPt(i)}function am(i){var s=typeof i;return i!=null&&(s=="object"||s=="function")}var ZPt="[object AsyncFunction]",eBt="[object Function]",tBt="[object GeneratorFunction]",nBt="[object Proxy]";function gD(i){if(!am(i))return!1;var s=AC(i);return s==eBt||s==tBt||s==ZPt||s==nBt}var rBt=N3["__core-js_shared__"];const g2e=rBt;var jRe=function(){var i=/[^.]+$/.exec(g2e&&g2e.keys&&g2e.keys.IE_PROTO||"");return i?"Symbol(src)_1."+i:""}();function iBt(i){return!!jRe&&jRe in i}var sBt=Function.prototype,aBt=sBt.toString;function LC(i){if(i!=null){try{return aBt.call(i)}catch{}try{return i+""}catch{}}return""}var oBt=/[\\^$.*+?()[\]{}|]/g,cBt=/^\[object .+?Constructor\]$/,uBt=Function.prototype,lBt=Object.prototype,hBt=uBt.toString,fBt=lBt.hasOwnProperty,dBt=RegExp("^"+hBt.call(fBt).replace(oBt,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$");function gBt(i){if(!am(i)||iBt(i))return!1;var s=gD(i)?dBt:cBt;return s.test(LC(i))}function pBt(i,s){return i==null?void 0:i[s]}function MC(i,s){var u=pBt(i,s);return gBt(u)?u:void 0}var bBt=MC(Object,"create");const KF=bBt;function mBt(){this.__data__=KF?KF(null):{},this.size=0}function vBt(i){var s=this.has(i)&&delete this.__data__[i];return this.size-=s?1:0,s}var wBt="__lodash_hash_undefined__",yBt=Object.prototype,xBt=yBt.hasOwnProperty;function kBt(i){var s=this.__data__;if(KF){var u=s[i];return u===wBt?void 0:u}return xBt.call(s,i)?s[i]:void 0}var EBt=Object.prototype,TBt=EBt.hasOwnProperty;function CBt(i){var s=this.__data__;return KF?s[i]!==void 0:TBt.call(s,i)}var SBt="__lodash_hash_undefined__";function _Bt(i,s){var u=this.__data__;return this.size+=this.has(i)?0:1,u[i]=KF&&s===void 0?SBt:s,this}function DC(i){var s=-1,u=i==null?0:i.length;for(this.clear();++s-1}function NBt(i,s){var u=this.__data__,d=AX(u,i);return d<0?(++this.size,u.push([i,s])):u[d][1]=s,this}function C7(i){var s=-1,u=i==null?0:i.length;for(this.clear();++s-1&&i%1==0&&i<=uFt}function w9(i){return i!=null&&w2e(i.length)&&!gD(i)}function JRe(i){return q4(i)&&w9(i)}function lFt(){return!1}var ZRe=typeof exports=="object"&&exports&&!exports.nodeType&&exports,eje=ZRe&&typeof module=="object"&&module&&!module.nodeType&&module,hFt=eje&&eje.exports===ZRe,tje=hFt?N3.Buffer:void 0,fFt=tje?tje.isBuffer:void 0,dFt=fFt||lFt;const vD=dFt;var gFt="[object Object]",pFt=Function.prototype,bFt=Object.prototype,nje=pFt.toString,mFt=bFt.hasOwnProperty,vFt=nje.call(Object);function rje(i){if(!q4(i)||AC(i)!=gFt)return!1;var s=v2e(i);if(s===null)return!0;var u=mFt.call(s,"constructor")&&s.constructor;return typeof u=="function"&&u instanceof u&&nje.call(u)==vFt}var wFt="[object Arguments]",yFt="[object Array]",xFt="[object Boolean]",kFt="[object Date]",EFt="[object Error]",TFt="[object Function]",CFt="[object Map]",SFt="[object Number]",_Ft="[object Object]",AFt="[object RegExp]",LFt="[object Set]",MFt="[object String]",DFt="[object WeakMap]",IFt="[object ArrayBuffer]",OFt="[object DataView]",NFt="[object Float32Array]",PFt="[object Float64Array]",BFt="[object Int8Array]",FFt="[object Int16Array]",RFt="[object Int32Array]",jFt="[object Uint8Array]",$Ft="[object Uint8ClampedArray]",zFt="[object Uint16Array]",qFt="[object Uint32Array]",ah={};ah[NFt]=ah[PFt]=ah[BFt]=ah[FFt]=ah[RFt]=ah[jFt]=ah[$Ft]=ah[zFt]=ah[qFt]=!0,ah[wFt]=ah[yFt]=ah[IFt]=ah[xFt]=ah[OFt]=ah[kFt]=ah[EFt]=ah[TFt]=ah[CFt]=ah[SFt]=ah[_Ft]=ah[AFt]=ah[LFt]=ah[MFt]=ah[DFt]=!1;function HFt(i){return q4(i)&&w2e(i.length)&&!!ah[AC(i)]}function NX(i){return function(s){return i(s)}}var ije=typeof exports=="object"&&exports&&!exports.nodeType&&exports,YF=ije&&typeof module=="object"&&module&&!module.nodeType&&module,VFt=YF&&YF.exports===ije,y2e=VFt&&BRe.process,UFt=function(){try{var i=YF&&YF.require&&YF.require("util").types;return i||y2e&&y2e.binding&&y2e.binding("util")}catch{}}();const wD=UFt;var sje=wD&&wD.isTypedArray,GFt=sje?NX(sje):HFt;const PX=GFt;function x2e(i,s){if(!(s==="constructor"&&typeof i[s]=="function")&&s!="__proto__")return i[s]}var KFt=Object.prototype,WFt=KFt.hasOwnProperty;function BX(i,s,u){var d=i[s];(!(WFt.call(i,s)&&pD(d,u))||u===void 0&&!(s in i))&&DX(i,s,u)}function XF(i,s,u,d){var p=!u;u||(u={});for(var v=-1,b=s.length;++v-1&&i%1==0&&i0){if(++s>=uRt)return arguments[0]}else s=0;return i.apply(void 0,arguments)}}var dRt=fRt(cRt);const lje=dRt;function RX(i,s){return lje(uje(i,s,OC),i+"")}function QF(i,s,u){if(!am(u))return!1;var d=typeof s;return(d=="number"?w9(u)&&FX(s,u.length):d=="string"&&s in u)?pD(u[s],i):!1}function gRt(i){return RX(function(s,u){var d=-1,p=u.length,v=p>1?u[p-1]:void 0,b=p>2?u[2]:void 0;for(v=i.length>3&&typeof v=="function"?(p--,v):void 0,b&&QF(u[0],u[1],b)&&(v=p<3?void 0:v,p=1),s=Object(s);++dy.args);SX(b),d=id(d,[...b])}else d=u.args;if(!d)return;let p=_X(i,s);const v="config";return d[v]!==void 0&&(p==="flowchart-v2"&&(p="flowchart"),d[p]=d[v],delete d[v]),d},fje=function(i,s=null){try{const u=new RegExp(`[%]{2}(?![{]${mRt.source})(?=[}][%]{2}).* +`,"ig");i=i.trim().replace(u,"").replace(/'/gm,'"'),Xe.debug(`Detecting diagram directive${s!==null?" type:"+s:""} based on the text:${i}`);let d;const p=[];for(;(d=UF.exec(i))!==null;)if(d.index===UF.lastIndex&&UF.lastIndex++,d&&!s||s&&d[1]&&d[1].match(s)||s&&d[2]&&d[2].match(s)){const v=d[1]?d[1]:d[2],b=d[3]?d[3].trim():d[4]?JSON.parse(d[4].trim()):null;p.push({type:v,args:b})}return p.length===0?{type:i,args:null}:p.length===1?p[0]:p}catch(u){return Xe.error(`ERROR: ${u.message} - Unable to parse directive type: '${s}' based on the text: '${i}'`),{type:void 0,args:null}}},wRt=function(i){return i.replace(UF,"")},yRt=function(i,s){for(const[u,d]of s.entries())if(d.match(i))return u;return-1};function Ov(i,s){if(!i)return s;const u=`curve${i.charAt(0).toUpperCase()+i.slice(1)}`;return bRt[u]??s}function xRt(i,s){const u=i.trim();if(u)return s.securityLevel!=="loose"?p9.sanitizeUrl(u):u}const kRt=(i,...s)=>{const u=i.split("."),d=u.length-1,p=u[d];let v=window;for(let b=0;b{u+=dje(p,s),s=p});const d=u/2;return k2e(i,d)}function TRt(i){return i.length===1?i[0]:ERt(i)}const gje=(i,s=2)=>{const u=Math.pow(10,s);return Math.round(i*u)/u},k2e=(i,s)=>{let u,d=s;for(const p of i){if(u){const v=dje(p,u);if(v=1)return{x:p.x,y:p.y};if(b>0&&b<1)return{x:gje((1-b)*u.x+b*p.x,5),y:gje((1-b)*u.y+b*p.y,5)}}}u=p}throw new Error("Could not find a suitable point for the given distance")},CRt=(i,s,u)=>{Xe.info(`our points ${JSON.stringify(s)}`),s[0]!==u&&(s=s.reverse());const p=k2e(s,25),v=i?10:5,b=Math.atan2(s[0].y-p.y,s[0].x-p.x),y={x:0,y:0};return y.x=Math.sin(b)*v+(s[0].x+p.x)/2,y.y=-Math.cos(b)*v+(s[0].y+p.y)/2,y};function SRt(i,s,u){const d=structuredClone(u);Xe.info("our points",d),s!=="start_left"&&s!=="start_right"&&d.reverse();const p=25+i,v=k2e(d,p),b=10+i*.5,y=Math.atan2(d[0].y-v.y,d[0].x-v.x),T={x:0,y:0};return s==="start_left"?(T.x=Math.sin(y+Math.PI)*b+(d[0].x+v.x)/2,T.y=-Math.cos(y+Math.PI)*b+(d[0].y+v.y)/2):s==="end_right"?(T.x=Math.sin(y-Math.PI)*b+(d[0].x+v.x)/2-5,T.y=-Math.cos(y-Math.PI)*b+(d[0].y+v.y)/2-5):s==="end_left"?(T.x=Math.sin(y)*b+(d[0].x+v.x)/2-5,T.y=-Math.cos(y)*b+(d[0].y+v.y)/2-5):(T.x=Math.sin(y)*b+(d[0].x+v.x)/2,T.y=-Math.cos(y)*b+(d[0].y+v.y)/2),T}function om(i){let s="",u="";for(const d of i)d!==void 0&&(d.startsWith("color:")||d.startsWith("text-align:")?u=u+d+";":s=s+d+";");return{style:s,labelStyle:u}}let pje=0;const bje=()=>(pje++,"id-"+Math.random().toString(36).substr(2,12)+"-"+pje);function _Rt(i){let s="";const u="0123456789abcdef",d=u.length;for(let p=0;p_Rt(i.length),ARt=function(){return{x:0,y:0,fill:void 0,anchor:"start",style:"#666",width:100,height:100,textMargin:0,rx:0,ry:0,valign:void 0,text:""}},LRt=function(i,s){const u=s.text.replace(ci.lineBreakRegex," "),[,d]=NC(s.fontSize),p=i.append("text");p.attr("x",s.x),p.attr("y",s.y),p.style("text-anchor",s.anchor),p.style("font-family",s.fontFamily),p.style("font-size",d),p.style("font-weight",s.fontWeight),p.attr("fill",s.fill),s.class!==void 0&&p.attr("class",s.class);const v=p.append("tspan");return v.attr("x",s.x+s.textMargin*2),v.attr("fill",s.fill),v.text(u),p},vje=bD((i,s,u)=>{if(!i||(u=Object.assign({fontSize:12,fontWeight:400,fontFamily:"Arial",joinWith:"
    "},u),ci.lineBreakRegex.test(i)))return i;const d=i.split(" "),p=[];let v="";return d.forEach((b,y)=>{const T=H4(`${b} `,u),_=H4(v,u);if(T>s){const{hyphenatedStrings:R,remainingWord:F}=MRt(b,s,"-",u);p.push(v,...R),v=F}else _+T>=s?(p.push(v),v=b):v=[v,b].filter(Boolean).join(" ");y+1===d.length&&p.push(v)}),p.filter(b=>b!=="").join(u.joinWith)},(i,s,u)=>`${i}${s}${u.fontSize}${u.fontWeight}${u.fontFamily}${u.joinWith}`),MRt=bD((i,s,u="-",d)=>{d=Object.assign({fontSize:12,fontWeight:400,fontFamily:"Arial",margin:0},d);const p=[...i],v=[];let b="";return p.forEach((y,T)=>{const _=`${b}${y}`;if(H4(_,d)>=s){const P=T+1,R=p.length===P,F=`${_}${u}`;v.push(R?_:F),b=""}else b=_}),{hyphenatedStrings:v,remainingWord:b}},(i,s,u="-",d)=>`${i}${s}${u}${d.fontSize}${d.fontWeight}${d.fontFamily}`);function E2e(i,s){return T2e(i,s).height}function H4(i,s){return T2e(i,s).width}const T2e=bD((i,s)=>{const{fontSize:u=12,fontFamily:d="Arial",fontWeight:p=400}=s;if(!i)return{width:0,height:0};const[,v]=NC(u),b=["sans-serif",d],y=i.split(ci.lineBreakRegex),T=[],_=Ir("body");if(!_.remove)return{width:0,height:0,lineHeight:0};const A=_.append("svg");for(const R of b){let F=0;const j={width:0,height:0,lineHeight:0};for(const K of y){const ee=ARt();ee.text=K||hje;const ie=LRt(A,ee).style("font-size",v).style("font-weight",p).style("font-family",R),oe=(ie._groups||ie)[0][0].getBBox();if(oe.width===0&&oe.height===0)throw new Error("svg element not in render tree");j.width=Math.round(Math.max(j.width,oe.width)),F=Math.round(oe.height),j.height+=F,j.lineHeight=Math.round(Math.max(j.lineHeight,F))}T.push(j)}A.remove();const P=isNaN(T[1].height)||isNaN(T[1].width)||isNaN(T[1].lineHeight)||T[0].height>T[1].height&&T[0].width>T[1].width&&T[0].lineHeight>T[1].lineHeight?0:1;return T[P]},(i,s)=>`${i}${s.fontSize}${s.fontWeight}${s.fontFamily}`);class DRt{constructor(s=!1,u){this.count=0,this.count=u?u.length:0,this.next=s?()=>this.count++:()=>Date.now()}}let $X;const IRt=function(i){return $X=$X||document.createElement("div"),i=escape(i).replace(/%26/g,"&").replace(/%23/g,"#").replace(/%3B/g,";"),$X.innerHTML=i,unescape($X.textContent)};function wje(i){return"str"in i}const ORt=(i,s,u,d)=>{var v;if(!d)return;const p=(v=i.node())==null?void 0:v.getBBox();p&&i.append("text").text(d).attr("x",p.x+p.width/2).attr("y",-u).attr("class",s)},NC=i=>{if(typeof i=="number")return[i,i+"px"];const s=parseInt(i??"",10);return Number.isNaN(s)?[void 0,void 0]:i===String(s)?[s,i+"px"]:[s,i]};function JF(i,s){return jX({},i,s)}const Ao={assignWithDepth:id,wrapLabel:vje,calculateTextHeight:E2e,calculateTextWidth:H4,calculateTextDimensions:T2e,cleanAndMerge:JF,detectInit:vRt,detectDirective:fje,isSubstringInArray:yRt,interpolateToCurve:Ov,calcLabelPosition:TRt,calcCardinalityPosition:CRt,calcTerminalLabelPosition:SRt,formatUrl:xRt,getStylesFromArray:om,generateId:bje,random:mje,runFunc:kRt,entityDecode:IRt,insertTitle:ORt,parseFontSize:NC,InitIDGenerator:DRt},NRt=function(i){let s=i;return s=s.replace(/style.*:\S*#.*;/g,function(u){return u.substring(0,u.length-1)}),s=s.replace(/classDef.*:\S*#.*;/g,function(u){return u.substring(0,u.length-1)}),s=s.replace(/#\w+;/g,function(u){const d=u.substring(1,u.length-1);return/^\+?\d+$/.test(d)?"fl°°"+d+"¶ß":"fl°"+d+"¶ß"}),s},ZF=function(i){return i.replace(/fl°°/g,"&#").replace(/fl°/g,"&").replace(/¶ß/g,";")};var yje="comm",xje="rule",kje="decl",PRt="@import",BRt="@keyframes",FRt="@layer",Eje=Math.abs,C2e=String.fromCharCode;function Tje(i){return i.trim()}function zX(i,s,u){return i.replace(s,u)}function RRt(i,s,u){return i.indexOf(s,u)}function eR(i,s){return i.charCodeAt(s)|0}function tR(i,s,u){return i.slice(s,u)}function _7(i){return i.length}function jRt(i){return i.length}function qX(i,s){return s.push(i),i}var HX=1,xD=1,Cje=0,Nv=0,I0=0,kD="";function S2e(i,s,u,d,p,v,b,y){return{value:i,root:s,parent:u,type:d,props:p,children:v,line:HX,column:xD,length:b,return:"",siblings:y}}function $Rt(){return I0}function zRt(){return I0=Nv>0?eR(kD,--Nv):0,xD--,I0===10&&(xD=1,HX--),I0}function B3(){return I0=Nv2||_2e(I0)>3?"":" "}function URt(i,s){for(;--s&&B3()&&!(I0<48||I0>102||I0>57&&I0<65||I0>70&&I0<97););return UX(i,VX()+(s<6&&PC()==32&&B3()==32))}function L2e(i){for(;B3();)switch(I0){case i:return Nv;case 34:case 39:i!==34&&i!==39&&L2e(I0);break;case 40:i===41&&L2e(i);break;case 92:B3();break}return Nv}function GRt(i,s){for(;B3()&&i+I0!==47+10;)if(i+I0===42+42&&PC()===47)break;return"/*"+UX(s,Nv-1)+"*"+C2e(i===47?i:B3())}function KRt(i){for(;!_2e(PC());)B3();return UX(i,Nv)}function WRt(i){return HRt(GX("",null,null,null,[""],i=qRt(i),0,[0],i))}function GX(i,s,u,d,p,v,b,y,T){for(var _=0,A=0,P=b,R=0,F=0,j=0,K=1,ee=1,ie=1,oe=0,pe="",be=p,ae=v,ne=d,se=pe;ee;)switch(j=oe,oe=B3()){case 40:if(j!=108&&eR(se,P-1)==58){RRt(se+=zX(A2e(oe),"&","&\f"),"&\f",Eje(_?y[_-1]:0))!=-1&&(ie=-1);break}case 34:case 39:case 91:se+=A2e(oe);break;case 9:case 10:case 13:case 32:se+=VRt(j);break;case 92:se+=URt(VX()-1,7);continue;case 47:switch(PC()){case 42:case 47:qX(YRt(GRt(B3(),VX()),s,u,T),T);break;default:se+="/"}break;case 123*K:y[_++]=_7(se)*ie;case 125*K:case 59:case 0:switch(oe){case 0:case 125:ee=0;case 59+A:ie==-1&&(se=zX(se,/\f/g,"")),F>0&&_7(se)-P&&qX(F>32?_je(se+";",d,u,P-1,T):_je(zX(se," ","")+";",d,u,P-2,T),T);break;case 59:se+=";";default:if(qX(ne=Sje(se,s,u,_,A,p,y,pe,be=[],ae=[],P,v),v),oe===123)if(A===0)GX(se,s,ne,ne,be,v,P,y,ae);else switch(R===99&&eR(se,3)===110?100:R){case 100:case 108:case 109:case 115:GX(i,ne,ne,d&&qX(Sje(i,ne,ne,0,0,p,y,pe,p,be=[],P,ae),ae),p,ae,P,y,d?be:ae);break;default:GX(se,ne,ne,ne,[""],ae,0,y,ae)}}_=A=F=0,K=ie=1,pe=se="",P=b;break;case 58:P=1+_7(se),F=j;default:if(K<1){if(oe==123)--K;else if(oe==125&&K++==0&&zRt()==125)continue}switch(se+=C2e(oe),oe*K){case 38:ie=A>0?1:(se+="\f",-1);break;case 44:y[_++]=(_7(se)-1)*ie,ie=1;break;case 64:PC()===45&&(se+=A2e(B3())),R=PC(),A=P=_7(pe=se+=KRt(VX())),oe++;break;case 45:j===45&&_7(se)==2&&(K=0)}}return v}function Sje(i,s,u,d,p,v,b,y,T,_,A,P){for(var R=p-1,F=p===0?v:[""],j=jRt(F),K=0,ee=0,ie=0;K0?F[oe]+" "+pe:zX(pe,/&\f/g,F[oe])))&&(T[ie++]=be);return S2e(i,s,u,p===0?xje:y,T,_,A,P)}function YRt(i,s,u,d){return S2e(i,s,u,yje,C2e($Rt()),tR(i,2,-2),0,d)}function _je(i,s,u,d,p){return S2e(i,s,u,kje,tR(i,0,d),tR(i,d+1,-1),d,p)}function M2e(i,s){for(var u="",d=0;d{let u=id({},i),d={};for(const p of s)Ije(p),d=id(d,p);if(u=id(u,d),d.theme&&d.theme in E7){const p=id({},Lje),v=id(p.themeVariables||{},d.themeVariables);u.theme&&u.theme in E7&&(u.themeVariables=E7[u.theme].getThemeVariables(v))}return nR=u,Nje(nR),nR},QRt=i=>(B2=id({},ED),B2=id(B2,i),i.theme&&E7[i.theme]&&(B2.themeVariables=E7[i.theme].getThemeVariables(i.themeVariables)),KX(B2,TD),B2),JRt=i=>{Lje=id({},i)},ZRt=i=>(B2=id(B2,i),KX(B2,TD),B2),Mje=()=>id({},B2),Dje=i=>(Nje(i),id(nR,i),Vh()),Vh=()=>id({},nR),Ije=i=>{i&&(["secure",...B2.secure??[]].forEach(s=>{Object.hasOwn(i,s)&&(Xe.debug(`Denied attempt to modify a secure key ${s}`,i[s]),delete i[s])}),Object.keys(i).forEach(s=>{s.startsWith("__")&&delete i[s]}),Object.keys(i).forEach(s=>{typeof i[s]=="string"&&(i[s].includes("<")||i[s].includes(">")||i[s].includes("url(data:"))&&delete i[s],typeof i[s]=="object"&&Ije(i[s])}))},ejt=i=>{SX(i),i.fontFamily&&(!i.themeVariables||!i.themeVariables.fontFamily)&&(i.themeVariables={fontFamily:i.fontFamily}),TD.push(i),KX(B2,TD)},WX=(i=B2)=>{TD=[],KX(i,TD)},tjt={LAZY_LOAD_DEPRECATED:"The configuration options lazyLoadedDiagrams and loadExternalDiagramsAtStartup are deprecated. Please use registerExternalDiagrams instead."},Oje={},njt=i=>{Oje[i]||(Xe.warn(tjt[i]),Oje[i]=!0)},Nje=i=>{i&&(i.lazyLoadedDiagrams||i.loadExternalDiagramsAtStartup)&&njt("LAZY_LOAD_DEPRECATED")},Pje="c4",rjt={id:Pje,detector:i=>/^\s*C4Context|C4Container|C4Component|C4Dynamic|C4Deployment/.test(i),loader:async()=>{const{diagram:i}=await Promise.resolve().then(()=>wUt);return{id:Pje,diagram:i}}},Bje="flowchart",ijt={id:Bje,detector:(i,s)=>{var u,d;return((u=s==null?void 0:s.flowchart)==null?void 0:u.defaultRenderer)==="dagre-wrapper"||((d=s==null?void 0:s.flowchart)==null?void 0:d.defaultRenderer)==="elk"?!1:/^\s*graph/.test(i)},loader:async()=>{const{diagram:i}=await Promise.resolve().then(()=>_en);return{id:Bje,diagram:i}}},Fje="flowchart-v2",sjt={id:Fje,detector:(i,s)=>{var u,d,p;return((u=s==null?void 0:s.flowchart)==null?void 0:u.defaultRenderer)==="dagre-d3"||((d=s==null?void 0:s.flowchart)==null?void 0:d.defaultRenderer)==="elk"?!1:/^\s*graph/.test(i)&&((p=s==null?void 0:s.flowchart)==null?void 0:p.defaultRenderer)==="dagre-wrapper"?!0:/^\s*flowchart/.test(i)},loader:async()=>{const{diagram:i}=await Promise.resolve().then(()=>Aen);return{id:Fje,diagram:i}}},Rje="er",ajt={id:Rje,detector:i=>/^\s*erDiagram/.test(i),loader:async()=>{const{diagram:i}=await Promise.resolve().then(()=>etn);return{id:Rje,diagram:i}}},jje="gitGraph",ojt={id:jje,detector:i=>/^\s*gitGraph/.test(i),loader:async()=>{const{diagram:i}=await Promise.resolve().then(()=>Stn);return{id:jje,diagram:i}}},$je="gantt",cjt={id:$je,detector:i=>/^\s*gantt/.test(i),loader:async()=>{const{diagram:i}=await Promise.resolve().then(()=>pnn);return{id:$je,diagram:i}}},zje="info",ujt={id:zje,detector:i=>/^\s*info/.test(i),loader:async()=>{const{diagram:i}=await Promise.resolve().then(()=>mnn);return{id:zje,diagram:i}}},qje="pie",ljt={id:qje,detector:i=>/^\s*pie/.test(i),loader:async()=>{const{diagram:i}=await Promise.resolve().then(()=>Enn);return{id:qje,diagram:i}}},Hje="quadrantChart",hjt={id:Hje,detector:i=>/^\s*quadrantChart/.test(i),loader:async()=>{const{diagram:i}=await Promise.resolve().then(()=>jnn);return{id:Hje,diagram:i}}},Vje="xychart",fjt={id:Vje,detector:i=>/^\s*xychart-beta/.test(i),loader:async()=>{const{diagram:i}=await Promise.resolve().then(()=>urn);return{id:Vje,diagram:i}}},Uje="requirement",djt={id:Uje,detector:i=>/^\s*requirement(Diagram)?/.test(i),loader:async()=>{const{diagram:i}=await Promise.resolve().then(()=>wrn);return{id:Uje,diagram:i}}},Gje="sequence",gjt={id:Gje,detector:i=>/^\s*sequenceDiagram/.test(i),loader:async()=>{const{diagram:i}=await Promise.resolve().then(()=>kin);return{id:Gje,diagram:i}}},Kje="class",pjt={id:Kje,detector:(i,s)=>{var u;return((u=s==null?void 0:s.class)==null?void 0:u.defaultRenderer)==="dagre-wrapper"?!1:/^\s*classDiagram/.test(i)},loader:async()=>{const{diagram:i}=await Promise.resolve().then(()=>Gin);return{id:Kje,diagram:i}}},Wje="classDiagram",bjt={id:Wje,detector:(i,s)=>{var u;return/^\s*classDiagram/.test(i)&&((u=s==null?void 0:s.class)==null?void 0:u.defaultRenderer)==="dagre-wrapper"?!0:/^\s*classDiagram-v2/.test(i)},loader:async()=>{const{diagram:i}=await Promise.resolve().then(()=>Jin);return{id:Wje,diagram:i}}},Yje="state",mjt={id:Yje,detector:(i,s)=>{var u;return((u=s==null?void 0:s.state)==null?void 0:u.defaultRenderer)==="dagre-wrapper"?!1:/^\s*stateDiagram/.test(i)},loader:async()=>{const{diagram:i}=await Promise.resolve().then(()=>jsn);return{id:Yje,diagram:i}}},Xje="stateDiagram",vjt={id:Xje,detector:(i,s)=>{var u;return!!(/^\s*stateDiagram-v2/.test(i)||/^\s*stateDiagram/.test(i)&&((u=s==null?void 0:s.state)==null?void 0:u.defaultRenderer)==="dagre-wrapper")},loader:async()=>{const{diagram:i}=await Promise.resolve().then(()=>ian);return{id:Xje,diagram:i}}},Qje="journey",wjt={id:Qje,detector:i=>/^\s*journey/.test(i),loader:async()=>{const{diagram:i}=await Promise.resolve().then(()=>Ean);return{id:Qje,diagram:i}}},yjt=function(i,s){for(let u of s)i.attr(u[0],u[1])},xjt=function(i,s,u){let d=new Map;return u?(d.set("width","100%"),d.set("style",`max-width: ${s}px;`)):(d.set("height",i),d.set("width",s)),d},Ng=function(i,s,u,d){const p=xjt(s,u,d);yjt(i,p)},y9=function(i,s,u,d){const p=s.node().getBBox(),v=p.width,b=p.height;Xe.info(`SVG bounds: ${v}x${b}`,p);let y=0,T=0;Xe.info(`Graph bounds: ${y}x${T}`,i),y=v+u*2,T=b+u*2,Xe.info(`Calculated bounds: ${y}x${T}`),Ng(s,T,y,d);const _=`${p.x-u} ${p.y-u} ${p.width+2*u} ${p.height+2*u}`;s.attr("viewBox",_)},YX={},kjt=(i,s,u)=>{let d="";return i in YX&&YX[i]?d=YX[i](u):Xe.warn(`No theme found for ${i}`),` & { + font-family: ${u.fontFamily}; + font-size: ${u.fontSize}; + fill: ${u.textColor} + } + + /* Classes common for multiple diagrams */ + + & .error-icon { + fill: ${u.errorBkgColor}; + } + & .error-text { + fill: ${u.errorTextColor}; + stroke: ${u.errorTextColor}; + } + + & .edge-thickness-normal { + stroke-width: 2px; + } + & .edge-thickness-thick { + stroke-width: 3.5px + } + & .edge-pattern-solid { + stroke-dasharray: 0; + } + + & .edge-pattern-dashed{ + stroke-dasharray: 3; + } + .edge-pattern-dotted { + stroke-dasharray: 2; + } + + & .marker { + fill: ${u.lineColor}; + stroke: ${u.lineColor}; + } + & .marker.cross { + stroke: ${u.lineColor}; + } + + & svg { + font-family: ${u.fontFamily}; + font-size: ${u.fontSize}; + } + + ${d} + + ${s} +`},Ejt=(i,s)=>{s!==void 0&&(YX[i]=s)},Tjt=kjt;let D2e="",I2e="",O2e="";const N2e=i=>Yf(i,Vh()),Pg=()=>{D2e="",O2e="",I2e=""},Bg=i=>{D2e=N2e(i).replace(/^\s+/g,"")},Cp=()=>D2e,Sp=i=>{O2e=N2e(i).replace(/\n\s+/g,` +`)},_p=()=>O2e,cm=i=>{I2e=N2e(i)},Ap=()=>I2e,Jje=Object.freeze(Object.defineProperty({__proto__:null,clear:Pg,getAccDescription:_p,getAccTitle:Cp,getDiagramTitle:Ap,setAccDescription:Sp,setAccTitle:Bg,setDiagramTitle:cm},Symbol.toStringTag,{value:"Module"})),Cjt=Xe,Sjt=fpe,qt=Vh,_jt=Dje,Zje=ED,Ajt=i=>Yf(i,qt()),e$e=y9,Ljt=()=>Jje,XX={},QX=(i,s,u)=>{var d;if(XX[i])throw new Error(`Diagram ${i} already registered.`);XX[i]=s,u&&PRe(i,u),Ejt(i,s.styles),(d=s.injectUtils)==null||d.call(s,Cjt,Sjt,qt,Ajt,e$e,Ljt(),()=>{})},P2e=i=>{if(i in XX)return XX[i];throw new Mjt(i)};class Mjt extends Error{constructor(s){super(`Diagram ${s} not found.`)}}const rR=i=>{var p;const{securityLevel:s}=qt();let u=Ir("body");if(s==="sandbox"){const b=((p=Ir(`#i${i}`).node())==null?void 0:p.contentDocument)??document;u=Ir(b.body)}return u.select(`#${i}`)},t$e={draw:(i,s,u)=>{Xe.debug(`rendering svg for syntax error +`);const d=rR(s),p=d.append("g");d.attr("viewBox","0 0 2412 512"),Ng(d,100,512,!0),p.append("path").attr("class","error-icon").attr("d","m411.313,123.313c6.25-6.25 6.25-16.375 0-22.625s-16.375-6.25-22.625,0l-32,32-9.375,9.375-20.688-20.688c-12.484-12.5-32.766-12.5-45.25,0l-16,16c-1.261,1.261-2.304,2.648-3.31,4.051-21.739-8.561-45.324-13.426-70.065-13.426-105.867,0-192,86.133-192,192s86.133,192 192,192 192-86.133 192-192c0-24.741-4.864-48.327-13.426-70.065 1.402-1.007 2.79-2.049 4.051-3.31l16-16c12.5-12.492 12.5-32.758 0-45.25l-20.688-20.688 9.375-9.375 32.001-31.999zm-219.313,100.687c-52.938,0-96,43.063-96,96 0,8.836-7.164,16-16,16s-16-7.164-16-16c0-70.578 57.422-128 128-128 8.836,0 16,7.164 16,16s-7.164,16-16,16z"),p.append("path").attr("class","error-icon").attr("d","m459.02,148.98c-6.25-6.25-16.375-6.25-22.625,0s-6.25,16.375 0,22.625l16,16c3.125,3.125 7.219,4.688 11.313,4.688 4.094,0 8.188-1.563 11.313-4.688 6.25-6.25 6.25-16.375 0-22.625l-16.001-16z"),p.append("path").attr("class","error-icon").attr("d","m340.395,75.605c3.125,3.125 7.219,4.688 11.313,4.688 4.094,0 8.188-1.563 11.313-4.688 6.25-6.25 6.25-16.375 0-22.625l-16-16c-6.25-6.25-16.375-6.25-22.625,0s-6.25,16.375 0,22.625l15.999,16z"),p.append("path").attr("class","error-icon").attr("d","m400,64c8.844,0 16-7.164 16-16v-32c0-8.836-7.156-16-16-16-8.844,0-16,7.164-16,16v32c0,8.836 7.156,16 16,16z"),p.append("path").attr("class","error-icon").attr("d","m496,96.586h-32c-8.844,0-16,7.164-16,16 0,8.836 7.156,16 16,16h32c8.844,0 16-7.164 16-16 0-8.836-7.156-16-16-16z"),p.append("path").attr("class","error-icon").attr("d","m436.98,75.605c3.125,3.125 7.219,4.688 11.313,4.688 4.094,0 8.188-1.563 11.313-4.688l32-32c6.25-6.25 6.25-16.375 0-22.625s-16.375-6.25-22.625,0l-32,32c-6.251,6.25-6.251,16.375-0.001,22.625z"),p.append("text").attr("class","error-text").attr("x",1440).attr("y",250).attr("font-size","150px").style("text-anchor","middle").text("Syntax error in text"),p.append("text").attr("class","error-text").attr("x",1250).attr("y",400).attr("font-size","100px").style("text-anchor","middle").text(`mermaid version ${u}`)}},Djt=t$e,Ijt={db:{},renderer:t$e,parser:{parser:{yy:{}},parse:()=>{}}},n$e="flowchart-elk",Ojt={id:n$e,detector:(i,s)=>{var u;return!!(/^\s*flowchart-elk/.test(i)||/^\s*flowchart|graph/.test(i)&&((u=s==null?void 0:s.flowchart)==null?void 0:u.defaultRenderer)==="elk")},loader:async()=>{const{diagram:i}=await Promise.resolve().then(()=>jan);return{id:n$e,diagram:i}}},r$e="timeline",Njt={id:r$e,detector:i=>/^\s*timeline/.test(i),loader:async()=>{const{diagram:i}=await Promise.resolve().then(()=>ion);return{id:r$e,diagram:i}}},i$e="mindmap",Pjt={id:i$e,detector:i=>/^\s*mindmap/.test(i),loader:async()=>{const{diagram:i}=await Promise.resolve().then(()=>Ion);return{id:i$e,diagram:i}}},s$e="sankey",Bjt={id:s$e,detector:i=>/^\s*sankey-beta/.test(i),loader:async()=>{const{diagram:i}=await Promise.resolve().then(()=>ccn);return{id:s$e,diagram:i}}},a$e="block",Fjt={id:a$e,detector:i=>/^\s*block-beta/.test(i),loader:async()=>{const{diagram:i}=await Promise.resolve().then(()=>Mcn);return{id:a$e,diagram:i}}};let o$e=!1;const B2e=()=>{o$e||(o$e=!0,QX("error",Ijt,i=>i.toLowerCase().trim()==="error"),QX("---",{db:{clear:()=>{}},styles:{},renderer:{draw:()=>{}},parser:{parser:{yy:{}},parse:()=>{throw new Error("Diagrams beginning with --- are not valid. If you were trying to use a YAML front-matter, please ensure that you've correctly opened and closed the YAML front-matter with un-indented `---` blocks")}},init:()=>null},i=>i.toLowerCase().trimStart().startsWith("---")),NRe(rjt,bjt,pjt,ajt,cjt,ujt,ljt,djt,gjt,Ojt,sjt,ijt,Pjt,Njt,ojt,vjt,mjt,wjt,hjt,Bjt,fjt,Fjt))};class c$e{constructor(s,u={}){this.text=s,this.metadata=u,this.type="graph",this.text=NRt(s),this.text+=` +`;const d=Vh();try{this.type=_X(s,d)}catch(v){this.type="error",this.detectError=v}const p=P2e(this.type);Xe.debug("Type "+this.type),this.db=p.db,this.renderer=p.renderer,this.parser=p.parser,this.parser.parser.yy=this.db,this.init=p.init,this.parse()}parse(){var u,d,p,v,b;if(this.detectError)throw this.detectError;(d=(u=this.db).clear)==null||d.call(u);const s=Vh();(p=this.init)==null||p.call(this,s),this.metadata.title&&((b=(v=this.db).setDiagramTitle)==null||b.call(v,this.metadata.title)),this.parser.parse(this.text)}async render(s,u){await this.renderer.draw(this.text,s,u,this)}getParser(){return this.parser}getType(){return this.type}}const Rjt=async(i,s={})=>{const u=_X(i,Vh());try{P2e(u)}catch{const p=$Pt(u);if(!p)throw new ORe(`Diagram ${u} not found.`);const{id:v,diagram:b}=await p();QX(v,b)}return new c$e(i,s)};let u$e=[];const jjt=()=>{u$e.forEach(i=>{i()}),u$e=[]};var $jt=WRe(Object.keys,Object);const zjt=$jt;var qjt=Object.prototype,Hjt=qjt.hasOwnProperty;function l$e(i){if(!OX(i))return zjt(i);var s=[];for(var u in Object(i))Hjt.call(i,u)&&u!="constructor"&&s.push(u);return s}var Vjt=MC(N3,"DataView");const F2e=Vjt;var Ujt=MC(N3,"Promise");const R2e=Ujt;var Gjt=MC(N3,"Set");const CD=Gjt;var Kjt=MC(N3,"WeakMap");const j2e=Kjt;var h$e="[object Map]",Wjt="[object Object]",f$e="[object Promise]",d$e="[object Set]",g$e="[object WeakMap]",p$e="[object DataView]",Yjt=LC(F2e),Xjt=LC(WF),Qjt=LC(R2e),Jjt=LC(CD),Zjt=LC(j2e),BC=AC;(F2e&&BC(new F2e(new ArrayBuffer(1)))!=p$e||WF&&BC(new WF)!=h$e||R2e&&BC(R2e.resolve())!=f$e||CD&&BC(new CD)!=d$e||j2e&&BC(new j2e)!=g$e)&&(BC=function(i){var s=AC(i),u=s==Wjt?i.constructor:void 0,d=u?LC(u):"";if(d)switch(d){case Yjt:return p$e;case Xjt:return h$e;case Qjt:return f$e;case Jjt:return d$e;case Zjt:return g$e}return s});const SD=BC;var e$t="[object Map]",t$t="[object Set]",n$t=Object.prototype,r$t=n$t.hasOwnProperty;function iR(i){if(i==null)return!0;if(w9(i)&&(D0(i)||typeof i=="string"||typeof i.splice=="function"||vD(i)||PX(i)||mD(i)))return!i.length;var s=SD(i);if(s==e$t||s==t$t)return!i.size;if(OX(i))return!l$e(i).length;for(var u in i)if(r$t.call(i,u))return!1;return!0}const i$t="graphics-document document";function s$t(i,s){i.attr("role",i$t),s!==""&&i.attr("aria-roledescription",s)}function a$t(i,s,u,d){if(i.insert!==void 0){if(u){const p=`chart-desc-${d}`;i.attr("aria-describedby",p),i.insert("desc",":first-child").attr("id",p).text(u)}if(s){const p=`chart-title-${d}`;i.attr("aria-labelledby",p),i.insert("title",":first-child").attr("id",p).text(s)}}}const o$t=i=>i.replace(/^\s*%%(?!{)[^\n]+\n?/gm,"").trimStart();/*! js-yaml 4.1.0 https://github.com/nodeca/js-yaml @license MIT */function b$e(i){return typeof i>"u"||i===null}function c$t(i){return typeof i=="object"&&i!==null}function u$t(i){return Array.isArray(i)?i:b$e(i)?[]:[i]}function l$t(i,s){var u,d,p,v;if(s)for(v=Object.keys(s),u=0,d=v.length;uy&&(v=" ... ",s=d-y+v.length),u-d>y&&(b=" ...",u=d+y-b.length),{str:v+i.slice(s,u).replace(/\t/g,"→")+b,pos:d-s+v.length}}function z2e(i,s){return Lp.repeat(" ",s-i.length)+i}function w$t(i,s){if(s=Object.create(s||null),!i.buffer)return null;s.maxLength||(s.maxLength=79),typeof s.indent!="number"&&(s.indent=1),typeof s.linesBefore!="number"&&(s.linesBefore=3),typeof s.linesAfter!="number"&&(s.linesAfter=2);for(var u=/\r?\n|\r|\0/g,d=[0],p=[],v,b=-1;v=u.exec(i.buffer);)p.push(v.index),d.push(v.index+v[0].length),i.position<=v.index&&b<0&&(b=d.length-2);b<0&&(b=d.length-1);var y="",T,_,A=Math.min(i.line+s.linesAfter,p.length).toString().length,P=s.maxLength-(s.indent+A+3);for(T=1;T<=s.linesBefore&&!(b-T<0);T++)_=$2e(i.buffer,d[b-T],p[b-T],i.position-(d[b]-d[b-T]),P),y=Lp.repeat(" ",s.indent)+z2e((i.line-T+1).toString(),A)+" | "+_.str+` +`+y;for(_=$2e(i.buffer,d[b],p[b],i.position,P),y+=Lp.repeat(" ",s.indent)+z2e((i.line+1).toString(),A)+" | "+_.str+` +`,y+=Lp.repeat("-",s.indent+A+3+_.pos)+`^ +`,T=1;T<=s.linesAfter&&!(b+T>=p.length);T++)_=$2e(i.buffer,d[b+T],p[b+T],i.position-(d[b]-d[b+T]),P),y+=Lp.repeat(" ",s.indent)+z2e((i.line+T+1).toString(),A)+" | "+_.str+` +`;return y.replace(/\n$/,"")}var y$t=w$t,x$t=["kind","multi","resolve","construct","instanceOf","predicate","represent","representName","defaultStyle","styleAliases"],k$t=["scalar","sequence","mapping"];function E$t(i){var s={};return i!==null&&Object.keys(i).forEach(function(u){i[u].forEach(function(d){s[String(d)]=u})}),s}function T$t(i,s){if(s=s||{},Object.keys(s).forEach(function(u){if(x$t.indexOf(u)===-1)throw new A7('Unknown option "'+u+'" is met in definition of "'+i+'" YAML type.')}),this.options=s,this.tag=i,this.kind=s.kind||null,this.resolve=s.resolve||function(){return!0},this.construct=s.construct||function(u){return u},this.instanceOf=s.instanceOf||null,this.predicate=s.predicate||null,this.represent=s.represent||null,this.representName=s.representName||null,this.defaultStyle=s.defaultStyle||null,this.multi=s.multi||!1,this.styleAliases=E$t(s.styleAliases||null),k$t.indexOf(this.kind)===-1)throw new A7('Unknown kind "'+this.kind+'" is specified for "'+i+'" YAML type.')}var Fg=T$t;function v$e(i,s){var u=[];return i[s].forEach(function(d){var p=u.length;u.forEach(function(v,b){v.tag===d.tag&&v.kind===d.kind&&v.multi===d.multi&&(p=b)}),u[p]=d}),u}function C$t(){var i={scalar:{},sequence:{},mapping:{},fallback:{},multi:{scalar:[],sequence:[],mapping:[],fallback:[]}},s,u;function d(p){p.multi?(i.multi[p.kind].push(p),i.multi.fallback.push(p)):i[p.kind][p.tag]=i.fallback[p.tag]=p}for(s=0,u=arguments.length;s=0?"0b"+i.toString(2):"-0b"+i.toString(2).slice(1)},octal:function(i){return i>=0?"0o"+i.toString(8):"-0o"+i.toString(8).slice(1)},decimal:function(i){return i.toString(10)},hexadecimal:function(i){return i>=0?"0x"+i.toString(16).toUpperCase():"-0x"+i.toString(16).toUpperCase().slice(1)}},defaultStyle:"decimal",styleAliases:{binary:[2,"bin"],octal:[8,"oct"],decimal:[10,"dec"],hexadecimal:[16,"hex"]}}),G$t=new RegExp("^(?:[-+]?(?:[0-9][0-9_]*)(?:\\.[0-9_]*)?(?:[eE][-+]?[0-9]+)?|\\.[0-9_]+(?:[eE][-+]?[0-9]+)?|[-+]?\\.(?:inf|Inf|INF)|\\.(?:nan|NaN|NAN))$");function K$t(i){return!(i===null||!G$t.test(i)||i[i.length-1]==="_")}function W$t(i){var s,u;return s=i.replace(/_/g,"").toLowerCase(),u=s[0]==="-"?-1:1,"+-".indexOf(s[0])>=0&&(s=s.slice(1)),s===".inf"?u===1?Number.POSITIVE_INFINITY:Number.NEGATIVE_INFINITY:s===".nan"?NaN:u*parseFloat(s,10)}var Y$t=/^[-+]?[0-9]+e/;function X$t(i,s){var u;if(isNaN(i))switch(s){case"lowercase":return".nan";case"uppercase":return".NAN";case"camelcase":return".NaN"}else if(Number.POSITIVE_INFINITY===i)switch(s){case"lowercase":return".inf";case"uppercase":return".INF";case"camelcase":return".Inf"}else if(Number.NEGATIVE_INFINITY===i)switch(s){case"lowercase":return"-.inf";case"uppercase":return"-.INF";case"camelcase":return"-.Inf"}else if(Lp.isNegativeZero(i))return"-0.0";return u=i.toString(10),Y$t.test(u)?u.replace("e",".e"):u}function Q$t(i){return Object.prototype.toString.call(i)==="[object Number]"&&(i%1!==0||Lp.isNegativeZero(i))}var J$t=new Fg("tag:yaml.org,2002:float",{kind:"scalar",resolve:K$t,construct:W$t,predicate:Q$t,represent:X$t,defaultStyle:"lowercase"}),w$e=M$t.extend({implicit:[N$t,R$t,U$t,J$t]}),Z$t=w$e,y$e=new RegExp("^([0-9][0-9][0-9][0-9])-([0-9][0-9])-([0-9][0-9])$"),x$e=new RegExp("^([0-9][0-9][0-9][0-9])-([0-9][0-9]?)-([0-9][0-9]?)(?:[Tt]|[ \\t]+)([0-9][0-9]?):([0-9][0-9]):([0-9][0-9])(?:\\.([0-9]*))?(?:[ \\t]*(Z|([-+])([0-9][0-9]?)(?::([0-9][0-9]))?))?$");function ezt(i){return i===null?!1:y$e.exec(i)!==null||x$e.exec(i)!==null}function tzt(i){var s,u,d,p,v,b,y,T=0,_=null,A,P,R;if(s=y$e.exec(i),s===null&&(s=x$e.exec(i)),s===null)throw new Error("Date resolve error");if(u=+s[1],d=+s[2]-1,p=+s[3],!s[4])return new Date(Date.UTC(u,d,p));if(v=+s[4],b=+s[5],y=+s[6],s[7]){for(T=s[7].slice(0,3);T.length<3;)T+="0";T=+T}return s[9]&&(A=+s[10],P=+(s[11]||0),_=(A*60+P)*6e4,s[9]==="-"&&(_=-_)),R=new Date(Date.UTC(u,d,p,v,b,y,T)),_&&R.setTime(R.getTime()-_),R}function nzt(i){return i.toISOString()}var rzt=new Fg("tag:yaml.org,2002:timestamp",{kind:"scalar",resolve:ezt,construct:tzt,instanceOf:Date,represent:nzt});function izt(i){return i==="<<"||i===null}var szt=new Fg("tag:yaml.org,2002:merge",{kind:"scalar",resolve:izt}),H2e=`ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/= +\r`;function azt(i){if(i===null)return!1;var s,u,d=0,p=i.length,v=H2e;for(u=0;u64)){if(s<0)return!1;d+=6}return d%8===0}function ozt(i){var s,u,d=i.replace(/[\r\n=]/g,""),p=d.length,v=H2e,b=0,y=[];for(s=0;s>16&255),y.push(b>>8&255),y.push(b&255)),b=b<<6|v.indexOf(d.charAt(s));return u=p%4*6,u===0?(y.push(b>>16&255),y.push(b>>8&255),y.push(b&255)):u===18?(y.push(b>>10&255),y.push(b>>2&255)):u===12&&y.push(b>>4&255),new Uint8Array(y)}function czt(i){var s="",u=0,d,p,v=i.length,b=H2e;for(d=0;d>18&63],s+=b[u>>12&63],s+=b[u>>6&63],s+=b[u&63]),u=(u<<8)+i[d];return p=v%3,p===0?(s+=b[u>>18&63],s+=b[u>>12&63],s+=b[u>>6&63],s+=b[u&63]):p===2?(s+=b[u>>10&63],s+=b[u>>4&63],s+=b[u<<2&63],s+=b[64]):p===1&&(s+=b[u>>2&63],s+=b[u<<4&63],s+=b[64],s+=b[64]),s}function uzt(i){return Object.prototype.toString.call(i)==="[object Uint8Array]"}var lzt=new Fg("tag:yaml.org,2002:binary",{kind:"scalar",resolve:azt,construct:ozt,predicate:uzt,represent:czt}),hzt=Object.prototype.hasOwnProperty,fzt=Object.prototype.toString;function dzt(i){if(i===null)return!0;var s=[],u,d,p,v,b,y=i;for(u=0,d=y.length;u>10)+55296,(i-65536&1023)+56320)}for(var L$e=new Array(256),M$e=new Array(256),AD=0;AD<256;AD++)L$e[AD]=A$e(AD)?1:0,M$e[AD]=A$e(AD);function Ozt(i,s){this.input=i,this.filename=s.filename||null,this.schema=s.schema||Tzt,this.onWarning=s.onWarning||null,this.legacy=s.legacy||!1,this.json=s.json||!1,this.listener=s.listener||null,this.implicitTypes=this.schema.compiledImplicit,this.typeMap=this.schema.compiledTypeMap,this.length=i.length,this.position=0,this.line=0,this.lineStart=0,this.lineIndent=0,this.firstTabInLine=-1,this.documents=[]}function D$e(i,s){var u={name:i.filename,buffer:i.input.slice(0,-1),position:i.position,line:i.line,column:i.position-i.lineStart};return u.snippet=y$t(u),new A7(s,u)}function oa(i,s){throw D$e(i,s)}function eQ(i,s){i.onWarning&&i.onWarning.call(null,D$e(i,s))}var I$e={YAML:function(s,u,d){var p,v,b;s.version!==null&&oa(s,"duplication of %YAML directive"),d.length!==1&&oa(s,"YAML directive accepts exactly one argument"),p=/^([0-9]+)\.([0-9]+)$/.exec(d[0]),p===null&&oa(s,"ill-formed argument of the YAML directive"),v=parseInt(p[1],10),b=parseInt(p[2],10),v!==1&&oa(s,"unacceptable YAML version of the document"),s.version=d[0],s.checkLineBreaks=b<2,b!==1&&b!==2&&eQ(s,"unsupported YAML version of the document")},TAG:function(s,u,d){var p,v;d.length!==2&&oa(s,"TAG directive accepts exactly two arguments"),p=d[0],v=d[1],C$e.test(p)||oa(s,"ill-formed tag handle (first argument) of the TAG directive"),x9.call(s.tagMap,p)&&oa(s,'there is a previously declared suffix for "'+p+'" tag handle'),S$e.test(v)||oa(s,"ill-formed tag prefix (second argument) of the TAG directive");try{v=decodeURIComponent(v)}catch{oa(s,"tag prefix is malformed: "+v)}s.tagMap[p]=v}};function k9(i,s,u,d){var p,v,b,y;if(s1&&(i.result+=Lp.repeat(` +`,s-1))}function Nzt(i,s,u){var d,p,v,b,y,T,_,A,P=i.kind,R=i.result,F;if(F=i.input.charCodeAt(i.position),F2(F)||_D(F)||F===35||F===38||F===42||F===33||F===124||F===62||F===39||F===34||F===37||F===64||F===96||(F===63||F===45)&&(p=i.input.charCodeAt(i.position+1),F2(p)||u&&_D(p)))return!1;for(i.kind="scalar",i.result="",v=b=i.position,y=!1;F!==0;){if(F===58){if(p=i.input.charCodeAt(i.position+1),F2(p)||u&&_D(p))break}else if(F===35){if(d=i.input.charCodeAt(i.position-1),F2(d))break}else{if(i.position===i.lineStart&&tQ(i)||u&&_D(F))break;if(V4(F))if(T=i.line,_=i.lineStart,A=i.lineIndent,O0(i,!1,-1),i.lineIndent>=s){y=!0,F=i.input.charCodeAt(i.position);continue}else{i.position=b,i.line=T,i.lineStart=_,i.lineIndent=A;break}}y&&(k9(i,v,b,!1),G2e(i,i.line-T),v=b=i.position,y=!1),FC(F)||(b=i.position+1),F=i.input.charCodeAt(++i.position)}return k9(i,v,b,!1),i.result?!0:(i.kind=P,i.result=R,!1)}function Pzt(i,s){var u,d,p;if(u=i.input.charCodeAt(i.position),u!==39)return!1;for(i.kind="scalar",i.result="",i.position++,d=p=i.position;(u=i.input.charCodeAt(i.position))!==0;)if(u===39)if(k9(i,d,i.position,!0),u=i.input.charCodeAt(++i.position),u===39)d=i.position,i.position++,p=i.position;else return!0;else V4(u)?(k9(i,d,p,!0),G2e(i,O0(i,!1,s)),d=p=i.position):i.position===i.lineStart&&tQ(i)?oa(i,"unexpected end of the document within a single quoted scalar"):(i.position++,p=i.position);oa(i,"unexpected end of the stream within a single quoted scalar")}function Bzt(i,s){var u,d,p,v,b,y;if(y=i.input.charCodeAt(i.position),y!==34)return!1;for(i.kind="scalar",i.result="",i.position++,u=d=i.position;(y=i.input.charCodeAt(i.position))!==0;){if(y===34)return k9(i,u,i.position,!0),i.position++,!0;if(y===92){if(k9(i,u,i.position,!0),y=i.input.charCodeAt(++i.position),V4(y))O0(i,!1,s);else if(y<256&&L$e[y])i.result+=M$e[y],i.position++;else if((b=Mzt(y))>0){for(p=b,v=0;p>0;p--)y=i.input.charCodeAt(++i.position),(b=Lzt(y))>=0?v=(v<<4)+b:oa(i,"expected hexadecimal character");i.result+=Izt(v),i.position++}else oa(i,"unknown escape sequence");u=d=i.position}else V4(y)?(k9(i,u,d,!0),G2e(i,O0(i,!1,s)),u=d=i.position):i.position===i.lineStart&&tQ(i)?oa(i,"unexpected end of the document within a double quoted scalar"):(i.position++,d=i.position)}oa(i,"unexpected end of the stream within a double quoted scalar")}function Fzt(i,s){var u=!0,d,p,v,b=i.tag,y,T=i.anchor,_,A,P,R,F,j=Object.create(null),K,ee,ie,oe;if(oe=i.input.charCodeAt(i.position),oe===91)A=93,F=!1,y=[];else if(oe===123)A=125,F=!0,y={};else return!1;for(i.anchor!==null&&(i.anchorMap[i.anchor]=y),oe=i.input.charCodeAt(++i.position);oe!==0;){if(O0(i,!0,s),oe=i.input.charCodeAt(i.position),oe===A)return i.position++,i.tag=b,i.anchor=T,i.kind=F?"mapping":"sequence",i.result=y,!0;u?oe===44&&oa(i,"expected the node content, but found ','"):oa(i,"missed comma between flow collection entries"),ee=K=ie=null,P=R=!1,oe===63&&(_=i.input.charCodeAt(i.position+1),F2(_)&&(P=R=!0,i.position++,O0(i,!0,s))),d=i.line,p=i.lineStart,v=i.position,MD(i,s,JX,!1,!0),ee=i.tag,K=i.result,O0(i,!0,s),oe=i.input.charCodeAt(i.position),(R||i.line===d)&&oe===58&&(P=!0,oe=i.input.charCodeAt(++i.position),O0(i,!0,s),MD(i,s,JX,!1,!0),ie=i.result),F?LD(i,y,j,ee,K,ie,d,p,v):P?y.push(LD(i,null,j,ee,K,ie,d,p,v)):y.push(K),O0(i,!0,s),oe=i.input.charCodeAt(i.position),oe===44?(u=!0,oe=i.input.charCodeAt(++i.position)):u=!1}oa(i,"unexpected end of the stream within a flow collection")}function Rzt(i,s){var u,d,p=V2e,v=!1,b=!1,y=s,T=0,_=!1,A,P;if(P=i.input.charCodeAt(i.position),P===124)d=!1;else if(P===62)d=!0;else return!1;for(i.kind="scalar",i.result="";P!==0;)if(P=i.input.charCodeAt(++i.position),P===43||P===45)V2e===p?p=P===43?T$e:Czt:oa(i,"repeat of a chomping mode identifier");else if((A=Dzt(P))>=0)A===0?oa(i,"bad explicit indentation width of a block scalar; it cannot be less than one"):b?oa(i,"repeat of an indentation width identifier"):(y=s+A-1,b=!0);else break;if(FC(P)){do P=i.input.charCodeAt(++i.position);while(FC(P));if(P===35)do P=i.input.charCodeAt(++i.position);while(!V4(P)&&P!==0)}for(;P!==0;){for(U2e(i),i.lineIndent=0,P=i.input.charCodeAt(i.position);(!b||i.lineIndenty&&(y=i.lineIndent),V4(P)){T++;continue}if(i.lineIndents)&&T!==0)oa(i,"bad indentation of a sequence entry");else if(i.lineIndents)&&(ee&&(b=i.line,y=i.lineStart,T=i.position),MD(i,s,ZX,!0,p)&&(ee?j=i.result:K=i.result),ee||(LD(i,P,R,F,j,K,b,y,T),F=j=K=null),O0(i,!0,-1),oe=i.input.charCodeAt(i.position)),(i.line===v||i.lineIndent>s)&&oe!==0)oa(i,"bad indentation of a mapping entry");else if(i.lineIndents?T=1:i.lineIndent===s?T=0:i.lineIndents?T=1:i.lineIndent===s?T=0:i.lineIndent tag; it should be "scalar", not "'+i.kind+'"'),P=0,R=i.implicitTypes.length;P"),i.result!==null&&j.kind!==i.kind&&oa(i,"unacceptable node kind for !<"+i.tag+'> tag; it should be "'+j.kind+'", not "'+i.kind+'"'),j.resolve(i.result,i.tag)?(i.result=j.construct(i.result,i.tag),i.anchor!==null&&(i.anchorMap[i.anchor]=i.result)):oa(i,"cannot resolve a node with !<"+i.tag+"> explicit tag")}return i.listener!==null&&i.listener("close",i),i.tag!==null||i.anchor!==null||A}function Hzt(i){var s=i.position,u,d,p,v=!1,b;for(i.version=null,i.checkLineBreaks=i.legacy,i.tagMap=Object.create(null),i.anchorMap=Object.create(null);(b=i.input.charCodeAt(i.position))!==0&&(O0(i,!0,-1),b=i.input.charCodeAt(i.position),!(i.lineIndent>0||b!==37));){for(v=!0,b=i.input.charCodeAt(++i.position),u=i.position;b!==0&&!F2(b);)b=i.input.charCodeAt(++i.position);for(d=i.input.slice(u,i.position),p=[],d.length<1&&oa(i,"directive name must not be less than one character in length");b!==0;){for(;FC(b);)b=i.input.charCodeAt(++i.position);if(b===35){do b=i.input.charCodeAt(++i.position);while(b!==0&&!V4(b));break}if(V4(b))break;for(u=i.position;b!==0&&!F2(b);)b=i.input.charCodeAt(++i.position);p.push(i.input.slice(u,i.position))}b!==0&&U2e(i),x9.call(I$e,d)?I$e[d](i,d,p):eQ(i,'unknown document directive "'+d+'"')}if(O0(i,!0,-1),i.lineIndent===0&&i.input.charCodeAt(i.position)===45&&i.input.charCodeAt(i.position+1)===45&&i.input.charCodeAt(i.position+2)===45?(i.position+=3,O0(i,!0,-1)):v&&oa(i,"directives end mark is expected"),MD(i,i.lineIndent-1,ZX,!1,!0),O0(i,!0,-1),i.checkLineBreaks&&_zt.test(i.input.slice(s,i.position))&&eQ(i,"non-ASCII line breaks are interpreted as content"),i.documents.push(i.result),i.position===i.lineStart&&tQ(i)){i.input.charCodeAt(i.position)===46&&(i.position+=3,O0(i,!0,-1));return}if(i.position"u"&&(u=s,s=null);var d=P$e(i,u);if(typeof s!="function")return d;for(var p=0,v=d.length;pi.replace(/\r\n?/g,` +`).replace(/<(\w+)([^>]*)>/g,(s,u,d)=>"<"+u+d.replace(/="([^"]*)"/g,"='$1'")+">"),Zzt=i=>{const{text:s,metadata:u}=Qzt(i),{displayMode:d,title:p,config:v={}}=u;return d&&(v.gantt||(v.gantt={}),v.gantt.displayMode=d),{title:p,config:v,text:s}},eqt=i=>{const s=Ao.detectInit(i)??{},u=Ao.detectDirective(i,"wrap");return Array.isArray(u)?s.wrap=u.some(({type:d})=>{}):(u==null?void 0:u.type)==="wrap"&&(s.wrap=!0),{text:wRt(i),directive:s}};function B$e(i){const s=Jzt(i),u=Zzt(s),d=eqt(u.text),p=JF(u.config,d.directive);return i=o$t(d.text),{code:i,title:u.title,config:p}}const tqt=5e4,nqt="graph TB;a[Maximum text size in diagram exceeded];style a fill:#faa",rqt="sandbox",iqt="loose",sqt="http://www.w3.org/2000/svg",aqt="http://www.w3.org/1999/xlink",oqt="http://www.w3.org/1999/xhtml",cqt="100%",uqt="100%",lqt="border:0;margin:0;",hqt="margin:0",fqt="allow-top-navigation-by-user-activation allow-popups",dqt='The "iframe" tag is not supported by your browser.',gqt=["foreignobject"],pqt=["dominant-baseline"];function F$e(i){const s=B$e(i);return WX(),ejt(s.config??{}),s}async function bqt(i,s){B2e(),i=F$e(i).code;try{await K2e(i)}catch(u){if(s!=null&&s.suppressErrors)return!1;throw u}return!0}const R$e=(i,s,u=[])=>` +.${i} ${s} { ${u.join(" !important; ")} !important; }`,mqt=(i,s={})=>{var d;let u="";if(i.themeCSS!==void 0&&(u+=` +${i.themeCSS}`),i.fontFamily!==void 0&&(u+=` +:root { --mermaid-font-family: ${i.fontFamily}}`),i.altFontFamily!==void 0&&(u+=` +:root { --mermaid-alt-font-family: ${i.altFontFamily}}`),!iR(s)){const y=i.htmlLabels||((d=i.flowchart)==null?void 0:d.htmlLabels)?["> *","span"]:["rect","polygon","ellipse","circle","path"];for(const T in s){const _=s[T];iR(_.styles)||y.forEach(A=>{u+=R$e(_.id,A,_.styles)}),iR(_.textStyles)||(u+=R$e(_.id,"tspan",_.textStyles))}}return u},vqt=(i,s,u,d)=>{const p=mqt(i,u),v=Tjt(s,p,i.themeVariables);return M2e(WRt(`${d}{${v}}`),XRt)},wqt=(i="",s,u)=>{let d=i;return!u&&!s&&(d=d.replace(/marker-end="url\([\d+./:=?A-Za-z-]*?#/g,'marker-end="url(#')),d=ZF(d),d=d.replace(/
    /g,"
    "),d},yqt=(i="",s)=>{var p,v;const u=(v=(p=s==null?void 0:s.viewBox)==null?void 0:p.baseVal)!=null&&v.height?s.viewBox.baseVal.height+"px":uqt,d=btoa(''+i+"");return``},j$e=(i,s,u,d,p)=>{const v=i.append("div");v.attr("id",u),d&&v.attr("style",d);const b=v.append("svg").attr("id",s).attr("width","100%").attr("xmlns",sqt);return p&&b.attr("xmlns:xlink",p),b.append("g"),i};function $$e(i,s){return i.append("iframe").attr("id",s).attr("style","width: 100%; height: 100%;").attr("sandbox","")}const xqt=(i,s,u,d)=>{var p,v,b;(p=i.getElementById(s))==null||p.remove(),(v=i.getElementById(u))==null||v.remove(),(b=i.getElementById(d))==null||b.remove()},kqt=async function(i,s,u){var U,Fe,Pe,je,Ie,Se;B2e();const d=F$e(s);s=d.code;const p=Vh();Xe.debug(p),s.length>((p==null?void 0:p.maxTextSize)??tqt)&&(s=nqt);const v="#"+i,b="i"+i,y="#"+b,T="d"+i,_="#"+T;let A=Ir("body");const P=p.securityLevel===rqt,R=p.securityLevel===iqt,F=p.fontFamily;if(u!==void 0){if(u&&(u.innerHTML=""),P){const Ce=$$e(Ir(u),b);A=Ir(Ce.nodes()[0].contentDocument.body),A.node().style.margin=0}else A=Ir(u);j$e(A,i,T,`font-family: ${F}`,aqt)}else{if(xqt(document,i,T,b),P){const Ce=$$e(Ir("body"),b);A=Ir(Ce.nodes()[0].contentDocument.body),A.node().style.margin=0}else A=Ir("body");j$e(A,i,T)}let j,K;try{j=await K2e(s,{title:d.title})}catch(Ce){j=new c$e("error"),K=Ce}const ee=A.select(_).node(),ie=j.type,oe=ee.firstChild,pe=oe.firstChild,be=(Fe=(U=j.renderer).getClasses)==null?void 0:Fe.call(U,s,j),ae=vqt(p,ie,be,v),ne=document.createElement("style");ne.innerHTML=ae,oe.insertBefore(ne,pe);try{await j.renderer.draw(s,i,Aje,j)}catch(Ce){throw Djt.draw(s,i,Aje),Ce}const se=A.select(`${_} svg`),de=(je=(Pe=j.db).getAccTitle)==null?void 0:je.call(Pe),X=(Se=(Ie=j.db).getAccDescription)==null?void 0:Se.call(Ie);Tqt(ie,se,de,X),A.select(`[id="${i}"]`).selectAll("foreignobject > *").attr("xmlns",oqt);let ge=A.select(_).node().innerHTML;if(Xe.debug("config.arrowMarkerAbsolute",p.arrowMarkerAbsolute),ge=wqt(ge,P,f1(p.arrowMarkerAbsolute)),P){const Ce=A.select(_+" svg").node();ge=yqt(ge,Ce)}else R||(ge=hD.sanitize(ge,{ADD_TAGS:gqt,ADD_ATTR:pqt}));if(jjt(),K)throw K;const xe=Ir(P?y:_).node();return xe&&"remove"in xe&&xe.remove(),{svg:ge,bindFunctions:j.db.bindFunctions}};function Eqt(i={}){var u;i!=null&&i.fontFamily&&!((u=i.themeVariables)!=null&&u.fontFamily)&&(i.themeVariables||(i.themeVariables={}),i.themeVariables.fontFamily=i.fontFamily),JRt(i),i!=null&&i.theme&&i.theme in E7?i.themeVariables=E7[i.theme].getThemeVariables(i.themeVariables):i&&(i.themeVariables=E7.default.getThemeVariables(i.themeVariables));const s=typeof i=="object"?QRt(i):Mje();fpe(s.logLevel),B2e()}const K2e=(i,s={})=>{const{code:u}=B$e(i);return Rjt(u,s)};function Tqt(i,s,u,d){s$t(s,i),a$t(s,u,d,s.attr("id"))}const RC=Object.freeze({render:kqt,parse:bqt,getDiagramFromText:K2e,initialize:Eqt,getConfig:Vh,setConfig:Dje,getSiteConfig:Mje,updateSiteConfig:ZRt,reset:()=>{WX()},globalReset:()=>{WX(ED)},defaultConfig:ED});fpe(Vh().logLevel),WX(Vh());const Cqt=async()=>{Xe.debug("Loading registered diagrams");const s=(await Promise.allSettled(Object.entries(dD).map(async([u,{detector:d,loader:p}])=>{if(p)try{P2e(u)}catch{try{const{diagram:b,id:y}=await p();QX(y,b,d)}catch(b){throw Xe.error(`Failed to load external diagram with key ${u}. Removing from detectors.`),delete dD[u],b}}}))).filter(u=>u.status==="rejected");if(s.length>0){Xe.error(`Failed to load ${s.length} external diagrams`);for(const u of s)Xe.error(u);throw new Error(`Failed to load ${s.length} external diagrams`)}},Sqt=(i,s,u)=>{Xe.warn(i),wje(i)?(u&&u(i.str,i.hash),s.push({...i,message:i.str,error:i})):(u&&u(i),i instanceof Error&&s.push({str:i.message,message:i.message,hash:i.name,error:i}))},z$e=async function(i={querySelector:".mermaid"}){try{await _qt(i)}catch(s){if(wje(s)&&Xe.error(s.str),um.parseError&&um.parseError(s),!i.suppressErrors)throw Xe.error("Use the suppressErrors option to suppress these errors"),s}},_qt=async function({postRenderCallback:i,querySelector:s,nodes:u}={querySelector:".mermaid"}){const d=RC.getConfig();Xe.debug(`${i?"":"No "}Callback function found`);let p;if(u)p=u;else if(s)p=document.querySelectorAll(s);else throw new Error("Nodes and querySelector are both undefined");Xe.debug(`Found ${p.length} diagrams`),(d==null?void 0:d.startOnLoad)!==void 0&&(Xe.debug("Start On Load: "+(d==null?void 0:d.startOnLoad)),RC.updateSiteConfig({startOnLoad:d==null?void 0:d.startOnLoad}));const v=new Ao.InitIDGenerator(d.deterministicIds,d.deterministicIDSeed);let b;const y=[];for(const T of Array.from(p)){Xe.info("Rendering diagram: "+T.id);/*! Check if previously processed */if(T.getAttribute("data-processed"))continue;T.setAttribute("data-processed","true");const _=`mermaid-${v.next()}`;b=T.innerHTML,b=JM(Ao.entityDecode(b)).trim().replace(//gi,"
    ");const A=Ao.detectInit(b);A&&Xe.debug("Detected early reinit: ",A);try{const{svg:P,bindFunctions:R}=await U$e(_,b,T);T.innerHTML=P,i&&await i(_),R&&R(T)}catch(P){Sqt(P,y,um.parseError)}}if(y.length>0)throw y[0]},q$e=function(i){RC.initialize(i)},Aqt=async function(i,s,u){Xe.warn("mermaid.init is deprecated. Please use run instead."),i&&q$e(i);const d={postRenderCallback:u,querySelector:".mermaid"};typeof s=="string"?d.querySelector=s:s&&(s instanceof HTMLElement?d.nodes=[s]:d.nodes=s),await z$e(d)},Lqt=async(i,{lazyLoad:s=!0}={})=>{NRe(...i),s===!1&&await Cqt()},H$e=function(){if(um.startOnLoad){const{startOnLoad:i}=RC.getConfig();i&&um.run().catch(s=>Xe.error("Mermaid failed to initialize",s))}};if(typeof document<"u"){/*! + * Wait for document loaded before starting the execution + */window.addEventListener("load",H$e,!1)}const Mqt=function(i){um.parseError=i},nQ=[];let W2e=!1;const V$e=async()=>{if(!W2e){for(W2e=!0;nQ.length>0;){const i=nQ.shift();if(i)try{await i()}catch(s){Xe.error("Error executing queue",s)}}W2e=!1}},Dqt=async(i,s)=>new Promise((u,d)=>{const p=()=>new Promise((v,b)=>{RC.parse(i,s).then(y=>{v(y),u(y)},y=>{var T;Xe.error("Error parsing",y),(T=um.parseError)==null||T.call(um,y),b(y),d(y)})});nQ.push(p),V$e().catch(d)}),U$e=(i,s,u)=>new Promise((d,p)=>{const v=()=>new Promise((b,y)=>{RC.render(i,s,u).then(T=>{b(T),d(T)},T=>{var _;Xe.error("Error parsing",T),(_=um.parseError)==null||_.call(um,T),y(T),p(T)})});nQ.push(v),V$e().catch(p)}),um={startOnLoad:!0,mermaidAPI:RC,parse:Dqt,render:U$e,init:Aqt,run:z$e,registerExternalDiagrams:Lqt,initialize:q$e,parseError:void 0,contentLoaded:H$e,setParseErrorHandler:Mqt,detectType:_X};class lm{constructor(s,u,d){this.lexer=void 0,this.start=void 0,this.end=void 0,this.lexer=s,this.start=u,this.end=d}static range(s,u){return u?!s||!s.loc||!u.loc||s.loc.lexer!==u.loc.lexer?null:new lm(s.loc.lexer,s.loc.start,u.loc.end):s&&s.loc}}class U4{constructor(s,u){this.text=void 0,this.loc=void 0,this.noexpand=void 0,this.treatAsRelax=void 0,this.text=s,this.loc=u}range(s,u){return new U4(u,lm.range(this,s))}}class Ci{constructor(s,u){this.name=void 0,this.position=void 0,this.length=void 0,this.rawMessage=void 0;var d="KaTeX parse error: "+s,p,v,b=u&&u.loc;if(b&&b.start<=b.end){var y=b.lexer.input;p=b.start,v=b.end,p===y.length?d+=" at end of input: ":d+=" at position "+(p+1)+": ";var T=y.slice(p,v).replace(/[^]/g,"$&̲"),_;p>15?_="…"+y.slice(p-15,p):_=y.slice(0,p);var A;v+15":">","<":"<",'"':""","'":"'"},Fqt=/[&><"']/g;function Rqt(i){return String(i).replace(Fqt,s=>Bqt[s])}var G$e=function i(s){return s.type==="ordgroup"||s.type==="color"?s.body.length===1?i(s.body[0]):s:s.type==="font"?i(s.body):s},jqt=function(s){var u=G$e(s);return u.type==="mathord"||u.type==="textord"||u.type==="atom"},$qt=function(s){if(!s)throw new Error("Expected non-null, but got "+String(s));return s},zqt=function(s){var u=/^\s*([^\\/#]*?)(?::|�*58|�*3a)/i.exec(s);return u!=null?u[1]:"_relative"},Ya={contains:Iqt,deflt:Oqt,escape:Rqt,hyphenate:Pqt,getBaseElem:G$e,isCharacterBox:jqt,protocolFromUrl:zqt},rQ={displayMode:{type:"boolean",description:"Render math in display mode, which puts the math in display style (so \\int and \\sum are large, for example), and centers the math on the page on its own line.",cli:"-d, --display-mode"},output:{type:{enum:["htmlAndMathml","html","mathml"]},description:"Determines the markup language of the output.",cli:"-F, --format "},leqno:{type:"boolean",description:"Render display math in leqno style (left-justified tags)."},fleqn:{type:"boolean",description:"Render display math flush left."},throwOnError:{type:"boolean",default:!0,cli:"-t, --no-throw-on-error",cliDescription:"Render errors (in the color given by --error-color) instead of throwing a ParseError exception when encountering an error."},errorColor:{type:"string",default:"#cc0000",cli:"-c, --error-color ",cliDescription:"A color string given in the format 'rgb' or 'rrggbb' (no #). This option determines the color of errors rendered by the -t option.",cliProcessor:i=>"#"+i},macros:{type:"object",cli:"-m, --macro ",cliDescription:"Define custom macro of the form '\\foo:expansion' (use multiple -m arguments for multiple macros).",cliDefault:[],cliProcessor:(i,s)=>(s.push(i),s)},minRuleThickness:{type:"number",description:"Specifies a minimum thickness, in ems, for fraction lines, `\\sqrt` top lines, `{array}` vertical lines, `\\hline`, `\\hdashline`, `\\underline`, `\\overline`, and the borders of `\\fbox`, `\\boxed`, and `\\fcolorbox`.",processor:i=>Math.max(0,i),cli:"--min-rule-thickness ",cliProcessor:parseFloat},colorIsTextColor:{type:"boolean",description:"Makes \\color behave like LaTeX's 2-argument \\textcolor, instead of LaTeX's one-argument \\color mode change.",cli:"-b, --color-is-text-color"},strict:{type:[{enum:["warn","ignore","error"]},"boolean","function"],description:"Turn on strict / LaTeX faithfulness mode, which throws an error if the input uses features that are not supported by LaTeX.",cli:"-S, --strict",cliDefault:!1},trust:{type:["boolean","function"],description:"Trust the input, enabling all HTML features such as \\url.",cli:"-T, --trust"},maxSize:{type:"number",default:1/0,description:"If non-zero, all user-specified sizes, e.g. in \\rule{500em}{500em}, will be capped to maxSize ems. Otherwise, elements and spaces can be arbitrarily large",processor:i=>Math.max(0,i),cli:"-s, --max-size ",cliProcessor:parseInt},maxExpand:{type:"number",default:1e3,description:"Limit the number of macro expansions to the specified number, to prevent e.g. infinite macro loops. If set to Infinity, the macro expander will try to fully expand as in LaTeX.",processor:i=>Math.max(0,i),cli:"-e, --max-expand ",cliProcessor:i=>i==="Infinity"?1/0:parseInt(i)},globalGroup:{type:"boolean",cli:!1}};function qqt(i){if(i.default)return i.default;var s=i.type,u=Array.isArray(s)?s[0]:s;if(typeof u!="string")return u.enum[0];switch(u){case"boolean":return!1;case"string":return"";case"number":return 0;case"object":return{}}}class Y2e{constructor(s){this.displayMode=void 0,this.output=void 0,this.leqno=void 0,this.fleqn=void 0,this.throwOnError=void 0,this.errorColor=void 0,this.macros=void 0,this.minRuleThickness=void 0,this.colorIsTextColor=void 0,this.strict=void 0,this.trust=void 0,this.maxSize=void 0,this.maxExpand=void 0,this.globalGroup=void 0,s=s||{};for(var u in rQ)if(rQ.hasOwnProperty(u)){var d=rQ[u];this[u]=s[u]!==void 0?d.processor?d.processor(s[u]):s[u]:qqt(d)}}reportNonstrict(s,u,d){var p=this.strict;if(typeof p=="function"&&(p=p(s,u,d)),!(!p||p==="ignore")){if(p===!0||p==="error")throw new Ci("LaTeX-incompatible input and strict mode is set to 'error': "+(u+" ["+s+"]"),d);p==="warn"?typeof console<"u"&&console.warn("LaTeX-incompatible input and strict mode is set to 'warn': "+(u+" ["+s+"]")):typeof console<"u"&&console.warn("LaTeX-incompatible input and strict mode is set to "+("unrecognized '"+p+"': "+u+" ["+s+"]"))}}useStrictBehavior(s,u,d){var p=this.strict;if(typeof p=="function")try{p=p(s,u,d)}catch{p="error"}return!p||p==="ignore"?!1:p===!0||p==="error"?!0:p==="warn"?(typeof console<"u"&&console.warn("LaTeX-incompatible input and strict mode is set to 'warn': "+(u+" ["+s+"]")),!1):(typeof console<"u"&&console.warn("LaTeX-incompatible input and strict mode is set to "+("unrecognized '"+p+"': "+u+" ["+s+"]")),!1)}isTrusted(s){s.url&&!s.protocol&&(s.protocol=Ya.protocolFromUrl(s.url));var u=typeof this.trust=="function"?this.trust(s):this.trust;return!!u}}class E9{constructor(s,u,d){this.id=void 0,this.size=void 0,this.cramped=void 0,this.id=s,this.size=u,this.cramped=d}sup(){return G4[Hqt[this.id]]}sub(){return G4[Vqt[this.id]]}fracNum(){return G4[Uqt[this.id]]}fracDen(){return G4[Gqt[this.id]]}cramp(){return G4[Kqt[this.id]]}text(){return G4[Wqt[this.id]]}isTight(){return this.size>=2}}var X2e=0,iQ=1,DD=2,L7=3,aR=4,Pv=5,ID=6,Mp=7,G4=[new E9(X2e,0,!1),new E9(iQ,0,!0),new E9(DD,1,!1),new E9(L7,1,!0),new E9(aR,2,!1),new E9(Pv,2,!0),new E9(ID,3,!1),new E9(Mp,3,!0)],Hqt=[aR,Pv,aR,Pv,ID,Mp,ID,Mp],Vqt=[Pv,Pv,Pv,Pv,Mp,Mp,Mp,Mp],Uqt=[DD,L7,aR,Pv,ID,Mp,ID,Mp],Gqt=[L7,L7,Pv,Pv,Mp,Mp,Mp,Mp],Kqt=[iQ,iQ,L7,L7,Pv,Pv,Mp,Mp],Wqt=[X2e,iQ,DD,L7,DD,L7,DD,L7],Ta={DISPLAY:G4[X2e],TEXT:G4[DD],SCRIPT:G4[aR],SCRIPTSCRIPT:G4[ID]},Q2e=[{name:"latin",blocks:[[256,591],[768,879]]},{name:"cyrillic",blocks:[[1024,1279]]},{name:"armenian",blocks:[[1328,1423]]},{name:"brahmic",blocks:[[2304,4255]]},{name:"georgian",blocks:[[4256,4351]]},{name:"cjk",blocks:[[12288,12543],[19968,40879],[65280,65376]]},{name:"hangul",blocks:[[44032,55215]]}];function Yqt(i){for(var s=0;s=p[0]&&i<=p[1])return u.name}return null}var sQ=[];Q2e.forEach(i=>i.blocks.forEach(s=>sQ.push(...s)));function K$e(i){for(var s=0;s=sQ[s]&&i<=sQ[s+1])return!0;return!1}var OD=80,Xqt=function(s,u){return"M95,"+(622+s+u)+` +c-2.7,0,-7.17,-2.7,-13.5,-8c-5.8,-5.3,-9.5,-10,-9.5,-14 +c0,-2,0.3,-3.3,1,-4c1.3,-2.7,23.83,-20.7,67.5,-54 +c44.2,-33.3,65.8,-50.3,66.5,-51c1.3,-1.3,3,-2,5,-2c4.7,0,8.7,3.3,12,10 +s173,378,173,378c0.7,0,35.3,-71,104,-213c68.7,-142,137.5,-285,206.5,-429 +c69,-144,104.5,-217.7,106.5,-221 +l`+s/2.075+" -"+s+` +c5.3,-9.3,12,-14,20,-14 +H400000v`+(40+s)+`H845.2724 +s-225.272,467,-225.272,467s-235,486,-235,486c-2.7,4.7,-9,7,-19,7 +c-6,0,-10,-1,-12,-3s-194,-422,-194,-422s-65,47,-65,47z +M`+(834+s)+" "+u+"h400000v"+(40+s)+"h-400000z"},Qqt=function(s,u){return"M263,"+(601+s+u)+`c0.7,0,18,39.7,52,119 +c34,79.3,68.167,158.7,102.5,238c34.3,79.3,51.8,119.3,52.5,120 +c340,-704.7,510.7,-1060.3,512,-1067 +l`+s/2.084+" -"+s+` +c4.7,-7.3,11,-11,19,-11 +H40000v`+(40+s)+`H1012.3 +s-271.3,567,-271.3,567c-38.7,80.7,-84,175,-136,283c-52,108,-89.167,185.3,-111.5,232 +c-22.3,46.7,-33.8,70.3,-34.5,71c-4.7,4.7,-12.3,7,-23,7s-12,-1,-12,-1 +s-109,-253,-109,-253c-72.7,-168,-109.3,-252,-110,-252c-10.7,8,-22,16.7,-34,26 +c-22,17.3,-33.3,26,-34,26s-26,-26,-26,-26s76,-59,76,-59s76,-60,76,-60z +M`+(1001+s)+" "+u+"h400000v"+(40+s)+"h-400000z"},Jqt=function(s,u){return"M983 "+(10+s+u)+` +l`+s/3.13+" -"+s+` +c4,-6.7,10,-10,18,-10 H400000v`+(40+s)+` +H1013.1s-83.4,268,-264.1,840c-180.7,572,-277,876.3,-289,913c-4.7,4.7,-12.7,7,-24,7 +s-12,0,-12,0c-1.3,-3.3,-3.7,-11.7,-7,-25c-35.3,-125.3,-106.7,-373.3,-214,-744 +c-10,12,-21,25,-33,39s-32,39,-32,39c-6,-5.3,-15,-14,-27,-26s25,-30,25,-30 +c26.7,-32.7,52,-63,76,-91s52,-60,52,-60s208,722,208,722 +c56,-175.3,126.3,-397.3,211,-666c84.7,-268.7,153.8,-488.2,207.5,-658.5 +c53.7,-170.3,84.5,-266.8,92.5,-289.5z +M`+(1001+s)+" "+u+"h400000v"+(40+s)+"h-400000z"},Zqt=function(s,u){return"M424,"+(2398+s+u)+` +c-1.3,-0.7,-38.5,-172,-111.5,-514c-73,-342,-109.8,-513.3,-110.5,-514 +c0,-2,-10.7,14.3,-32,49c-4.7,7.3,-9.8,15.7,-15.5,25c-5.7,9.3,-9.8,16,-12.5,20 +s-5,7,-5,7c-4,-3.3,-8.3,-7.7,-13,-13s-13,-13,-13,-13s76,-122,76,-122s77,-121,77,-121 +s209,968,209,968c0,-2,84.7,-361.7,254,-1079c169.3,-717.3,254.7,-1077.7,256,-1081 +l`+s/4.223+" -"+s+`c4,-6.7,10,-10,18,-10 H400000 +v`+(40+s)+`H1014.6 +s-87.3,378.7,-272.6,1166c-185.3,787.3,-279.3,1182.3,-282,1185 +c-2,6,-10,9,-24,9 +c-8,0,-12,-0.7,-12,-2z M`+(1001+s)+" "+u+` +h400000v`+(40+s)+"h-400000z"},eHt=function(s,u){return"M473,"+(2713+s+u)+` +c339.3,-1799.3,509.3,-2700,510,-2702 l`+s/5.298+" -"+s+` +c3.3,-7.3,9.3,-11,18,-11 H400000v`+(40+s)+`H1017.7 +s-90.5,478,-276.2,1466c-185.7,988,-279.5,1483,-281.5,1485c-2,6,-10,9,-24,9 +c-8,0,-12,-0.7,-12,-2c0,-1.3,-5.3,-32,-16,-92c-50.7,-293.3,-119.7,-693.3,-207,-1200 +c0,-1.3,-5.3,8.7,-16,30c-10.7,21.3,-21.3,42.7,-32,64s-16,33,-16,33s-26,-26,-26,-26 +s76,-153,76,-153s77,-151,77,-151c0.7,0.7,35.7,202,105,604c67.3,400.7,102,602.7,104, +606zM`+(1001+s)+" "+u+"h400000v"+(40+s)+"H1017.7z"},tHt=function(s){var u=s/2;return"M400000 "+s+" H0 L"+u+" 0 l65 45 L145 "+(s-80)+" H400000z"},nHt=function(s,u,d){var p=d-54-u-s;return"M702 "+(s+u)+"H400000"+(40+s)+` +H742v`+p+`l-4 4-4 4c-.667.7 -2 1.5-4 2.5s-4.167 1.833-6.5 2.5-5.5 1-9.5 1 +h-12l-28-84c-16.667-52-96.667 -294.333-240-727l-212 -643 -85 170 +c-4-3.333-8.333-7.667-13 -13l-13-13l77-155 77-156c66 199.333 139 419.667 +219 661 l218 661zM702 `+u+"H400000v"+(40+s)+"H742z"},rHt=function(s,u,d){u=1e3*u;var p="";switch(s){case"sqrtMain":p=Xqt(u,OD);break;case"sqrtSize1":p=Qqt(u,OD);break;case"sqrtSize2":p=Jqt(u,OD);break;case"sqrtSize3":p=Zqt(u,OD);break;case"sqrtSize4":p=eHt(u,OD);break;case"sqrtTall":p=nHt(u,OD,d)}return p},iHt=function(s,u){switch(s){case"⎜":return"M291 0 H417 V"+u+" H291z M291 0 H417 V"+u+" H291z";case"∣":return"M145 0 H188 V"+u+" H145z M145 0 H188 V"+u+" H145z";case"∥":return"M145 0 H188 V"+u+" H145z M145 0 H188 V"+u+" H145z"+("M367 0 H410 V"+u+" H367z M367 0 H410 V"+u+" H367z");case"⎟":return"M457 0 H583 V"+u+" H457z M457 0 H583 V"+u+" H457z";case"⎢":return"M319 0 H403 V"+u+" H319z M319 0 H403 V"+u+" H319z";case"⎥":return"M263 0 H347 V"+u+" H263z M263 0 H347 V"+u+" H263z";case"⎪":return"M384 0 H504 V"+u+" H384z M384 0 H504 V"+u+" H384z";case"⏐":return"M312 0 H355 V"+u+" H312z M312 0 H355 V"+u+" H312z";case"‖":return"M257 0 H300 V"+u+" H257z M257 0 H300 V"+u+" H257z"+("M478 0 H521 V"+u+" H478z M478 0 H521 V"+u+" H478z");default:return""}},W$e={doubleleftarrow:`M262 157 +l10-10c34-36 62.7-77 86-123 3.3-8 5-13.3 5-16 0-5.3-6.7-8-20-8-7.3 + 0-12.2.5-14.5 1.5-2.3 1-4.8 4.5-7.5 10.5-49.3 97.3-121.7 169.3-217 216-28 + 14-57.3 25-88 33-6.7 2-11 3.8-13 5.5-2 1.7-3 4.2-3 7.5s1 5.8 3 7.5 +c2 1.7 6.3 3.5 13 5.5 68 17.3 128.2 47.8 180.5 91.5 52.3 43.7 93.8 96.2 124.5 + 157.5 9.3 8 15.3 12.3 18 13h6c12-.7 18-4 18-10 0-2-1.7-7-5-15-23.3-46-52-87 +-86-123l-10-10h399738v-40H218c328 0 0 0 0 0l-10-8c-26.7-20-65.7-43-117-69 2.7 +-2 6-3.7 10-5 36.7-16 72.3-37.3 107-64l10-8h399782v-40z +m8 0v40h399730v-40zm0 194v40h399730v-40z`,doublerightarrow:`M399738 392l +-10 10c-34 36-62.7 77-86 123-3.3 8-5 13.3-5 16 0 5.3 6.7 8 20 8 7.3 0 12.2-.5 + 14.5-1.5 2.3-1 4.8-4.5 7.5-10.5 49.3-97.3 121.7-169.3 217-216 28-14 57.3-25 88 +-33 6.7-2 11-3.8 13-5.5 2-1.7 3-4.2 3-7.5s-1-5.8-3-7.5c-2-1.7-6.3-3.5-13-5.5-68 +-17.3-128.2-47.8-180.5-91.5-52.3-43.7-93.8-96.2-124.5-157.5-9.3-8-15.3-12.3-18 +-13h-6c-12 .7-18 4-18 10 0 2 1.7 7 5 15 23.3 46 52 87 86 123l10 10H0v40h399782 +c-328 0 0 0 0 0l10 8c26.7 20 65.7 43 117 69-2.7 2-6 3.7-10 5-36.7 16-72.3 37.3 +-107 64l-10 8H0v40zM0 157v40h399730v-40zm0 194v40h399730v-40z`,leftarrow:`M400000 241H110l3-3c68.7-52.7 113.7-120 + 135-202 4-14.7 6-23 6-25 0-7.3-7-11-21-11-8 0-13.2.8-15.5 2.5-2.3 1.7-4.2 5.8 +-5.5 12.5-1.3 4.7-2.7 10.3-4 17-12 48.7-34.8 92-68.5 130S65.3 228.3 18 247 +c-10 4-16 7.7-18 11 0 8.7 6 14.3 18 17 47.3 18.7 87.8 47 121.5 85S196 441.3 208 + 490c.7 2 1.3 5 2 9s1.2 6.7 1.5 8c.3 1.3 1 3.3 2 6s2.2 4.5 3.5 5.5c1.3 1 3.3 + 1.8 6 2.5s6 1 10 1c14 0 21-3.7 21-11 0-2-2-10.3-6-25-20-79.3-65-146.7-135-202 + l-3-3h399890zM100 241v40h399900v-40z`,leftbrace:`M6 548l-6-6v-35l6-11c56-104 135.3-181.3 238-232 57.3-28.7 117 +-45 179-50h399577v120H403c-43.3 7-81 15-113 26-100.7 33-179.7 91-237 174-2.7 + 5-6 9-10 13-.7 1-7.3 1-20 1H6z`,leftbraceunder:`M0 6l6-6h17c12.688 0 19.313.3 20 1 4 4 7.313 8.3 10 13 + 35.313 51.3 80.813 93.8 136.5 127.5 55.688 33.7 117.188 55.8 184.5 66.5.688 + 0 2 .3 4 1 18.688 2.7 76 4.3 172 5h399450v120H429l-6-1c-124.688-8-235-61.7 +-331-161C60.687 138.7 32.312 99.3 7 54L0 41V6z`,leftgroup:`M400000 80 +H435C64 80 168.3 229.4 21 260c-5.9 1.2-18 0-18 0-2 0-3-1-3-3v-38C76 61 257 0 + 435 0h399565z`,leftgroupunder:`M400000 262 +H435C64 262 168.3 112.6 21 82c-5.9-1.2-18 0-18 0-2 0-3 1-3 3v38c76 158 257 219 + 435 219h399565z`,leftharpoon:`M0 267c.7 5.3 3 10 7 14h399993v-40H93c3.3 +-3.3 10.2-9.5 20.5-18.5s17.8-15.8 22.5-20.5c50.7-52 88-110.3 112-175 4-11.3 5 +-18.3 3-21-1.3-4-7.3-6-18-6-8 0-13 .7-15 2s-4.7 6.7-8 16c-42 98.7-107.3 174.7 +-196 228-6.7 4.7-10.7 8-12 10-1.3 2-2 5.7-2 11zm100-26v40h399900v-40z`,leftharpoonplus:`M0 267c.7 5.3 3 10 7 14h399993v-40H93c3.3-3.3 10.2-9.5 + 20.5-18.5s17.8-15.8 22.5-20.5c50.7-52 88-110.3 112-175 4-11.3 5-18.3 3-21-1.3 +-4-7.3-6-18-6-8 0-13 .7-15 2s-4.7 6.7-8 16c-42 98.7-107.3 174.7-196 228-6.7 4.7 +-10.7 8-12 10-1.3 2-2 5.7-2 11zm100-26v40h399900v-40zM0 435v40h400000v-40z +m0 0v40h400000v-40z`,leftharpoondown:`M7 241c-4 4-6.333 8.667-7 14 0 5.333.667 9 2 11s5.333 + 5.333 12 10c90.667 54 156 130 196 228 3.333 10.667 6.333 16.333 9 17 2 .667 5 + 1 9 1h5c10.667 0 16.667-2 18-6 2-2.667 1-9.667-3-21-32-87.333-82.667-157.667 +-152-211l-3-3h399907v-40zM93 281 H400000 v-40L7 241z`,leftharpoondownplus:`M7 435c-4 4-6.3 8.7-7 14 0 5.3.7 9 2 11s5.3 5.3 12 + 10c90.7 54 156 130 196 228 3.3 10.7 6.3 16.3 9 17 2 .7 5 1 9 1h5c10.7 0 16.7 +-2 18-6 2-2.7 1-9.7-3-21-32-87.3-82.7-157.7-152-211l-3-3h399907v-40H7zm93 0 +v40h399900v-40zM0 241v40h399900v-40zm0 0v40h399900v-40z`,lefthook:`M400000 281 H103s-33-11.2-61-33.5S0 197.3 0 164s14.2-61.2 42.5 +-83.5C70.8 58.2 104 47 142 47 c16.7 0 25 6.7 25 20 0 12-8.7 18.7-26 20-40 3.3 +-68.7 15.7-86 37-10 12-15 25.3-15 40 0 22.7 9.8 40.7 29.5 54 19.7 13.3 43.5 21 + 71.5 23h399859zM103 281v-40h399897v40z`,leftlinesegment:`M40 281 V428 H0 V94 H40 V241 H400000 v40z +M40 281 V428 H0 V94 H40 V241 H400000 v40z`,leftmapsto:`M40 281 V448H0V74H40V241H400000v40z +M40 281 V448H0V74H40V241H400000v40z`,leftToFrom:`M0 147h400000v40H0zm0 214c68 40 115.7 95.7 143 167h22c15.3 0 23 +-.3 23-1 0-1.3-5.3-13.7-16-37-18-35.3-41.3-69-70-101l-7-8h399905v-40H95l7-8 +c28.7-32 52-65.7 70-101 10.7-23.3 16-35.7 16-37 0-.7-7.7-1-23-1h-22C115.7 265.3 + 68 321 0 361zm0-174v-40h399900v40zm100 154v40h399900v-40z`,longequal:`M0 50 h400000 v40H0z m0 194h40000v40H0z +M0 50 h400000 v40H0z m0 194h40000v40H0z`,midbrace:`M200428 334 +c-100.7-8.3-195.3-44-280-108-55.3-42-101.7-93-139-153l-9-14c-2.7 4-5.7 8.7-9 14 +-53.3 86.7-123.7 153-211 199-66.7 36-137.3 56.3-212 62H0V214h199568c178.3-11.7 + 311.7-78.3 403-201 6-8 9.7-12 11-12 .7-.7 6.7-1 18-1s17.3.3 18 1c1.3 0 5 4 11 + 12 44.7 59.3 101.3 106.3 170 141s145.3 54.3 229 60h199572v120z`,midbraceunder:`M199572 214 +c100.7 8.3 195.3 44 280 108 55.3 42 101.7 93 139 153l9 14c2.7-4 5.7-8.7 9-14 + 53.3-86.7 123.7-153 211-199 66.7-36 137.3-56.3 212-62h199568v120H200432c-178.3 + 11.7-311.7 78.3-403 201-6 8-9.7 12-11 12-.7.7-6.7 1-18 1s-17.3-.3-18-1c-1.3 0 +-5-4-11-12-44.7-59.3-101.3-106.3-170-141s-145.3-54.3-229-60H0V214z`,oiintSize1:`M512.6 71.6c272.6 0 320.3 106.8 320.3 178.2 0 70.8-47.7 177.6 +-320.3 177.6S193.1 320.6 193.1 249.8c0-71.4 46.9-178.2 319.5-178.2z +m368.1 178.2c0-86.4-60.9-215.4-368.1-215.4-306.4 0-367.3 129-367.3 215.4 0 85.8 +60.9 214.8 367.3 214.8 307.2 0 368.1-129 368.1-214.8z`,oiintSize2:`M757.8 100.1c384.7 0 451.1 137.6 451.1 230 0 91.3-66.4 228.8 +-451.1 228.8-386.3 0-452.7-137.5-452.7-228.8 0-92.4 66.4-230 452.7-230z +m502.4 230c0-111.2-82.4-277.2-502.4-277.2s-504 166-504 277.2 +c0 110 84 276 504 276s502.4-166 502.4-276z`,oiiintSize1:`M681.4 71.6c408.9 0 480.5 106.8 480.5 178.2 0 70.8-71.6 177.6 +-480.5 177.6S202.1 320.6 202.1 249.8c0-71.4 70.5-178.2 479.3-178.2z +m525.8 178.2c0-86.4-86.8-215.4-525.7-215.4-437.9 0-524.7 129-524.7 215.4 0 +85.8 86.8 214.8 524.7 214.8 438.9 0 525.7-129 525.7-214.8z`,oiiintSize2:`M1021.2 53c603.6 0 707.8 165.8 707.8 277.2 0 110-104.2 275.8 +-707.8 275.8-606 0-710.2-165.8-710.2-275.8C311 218.8 415.2 53 1021.2 53z +m770.4 277.1c0-131.2-126.4-327.6-770.5-327.6S248.4 198.9 248.4 330.1 +c0 130 128.8 326.4 772.7 326.4s770.5-196.4 770.5-326.4z`,rightarrow:`M0 241v40h399891c-47.3 35.3-84 78-110 128 +-16.7 32-27.7 63.7-33 95 0 1.3-.2 2.7-.5 4-.3 1.3-.5 2.3-.5 3 0 7.3 6.7 11 20 + 11 8 0 13.2-.8 15.5-2.5 2.3-1.7 4.2-5.5 5.5-11.5 2-13.3 5.7-27 11-41 14.7-44.7 + 39-84.5 73-119.5s73.7-60.2 119-75.5c6-2 9-5.7 9-11s-3-9-9-11c-45.3-15.3-85 +-40.5-119-75.5s-58.3-74.8-73-119.5c-4.7-14-8.3-27.3-11-40-1.3-6.7-3.2-10.8-5.5 +-12.5-2.3-1.7-7.5-2.5-15.5-2.5-14 0-21 3.7-21 11 0 2 2 10.3 6 25 20.7 83.3 67 + 151.7 139 205zm0 0v40h399900v-40z`,rightbrace:`M400000 542l +-6 6h-17c-12.7 0-19.3-.3-20-1-4-4-7.3-8.3-10-13-35.3-51.3-80.8-93.8-136.5-127.5 +s-117.2-55.8-184.5-66.5c-.7 0-2-.3-4-1-18.7-2.7-76-4.3-172-5H0V214h399571l6 1 +c124.7 8 235 61.7 331 161 31.3 33.3 59.7 72.7 85 118l7 13v35z`,rightbraceunder:`M399994 0l6 6v35l-6 11c-56 104-135.3 181.3-238 232-57.3 + 28.7-117 45-179 50H-300V214h399897c43.3-7 81-15 113-26 100.7-33 179.7-91 237 +-174 2.7-5 6-9 10-13 .7-1 7.3-1 20-1h17z`,rightgroup:`M0 80h399565c371 0 266.7 149.4 414 180 5.9 1.2 18 0 18 0 2 0 + 3-1 3-3v-38c-76-158-257-219-435-219H0z`,rightgroupunder:`M0 262h399565c371 0 266.7-149.4 414-180 5.9-1.2 18 0 18 + 0 2 0 3 1 3 3v38c-76 158-257 219-435 219H0z`,rightharpoon:`M0 241v40h399993c4.7-4.7 7-9.3 7-14 0-9.3 +-3.7-15.3-11-18-92.7-56.7-159-133.7-199-231-3.3-9.3-6-14.7-8-16-2-1.3-7-2-15-2 +-10.7 0-16.7 2-18 6-2 2.7-1 9.7 3 21 15.3 42 36.7 81.8 64 119.5 27.3 37.7 58 + 69.2 92 94.5zm0 0v40h399900v-40z`,rightharpoonplus:`M0 241v40h399993c4.7-4.7 7-9.3 7-14 0-9.3-3.7-15.3-11 +-18-92.7-56.7-159-133.7-199-231-3.3-9.3-6-14.7-8-16-2-1.3-7-2-15-2-10.7 0-16.7 + 2-18 6-2 2.7-1 9.7 3 21 15.3 42 36.7 81.8 64 119.5 27.3 37.7 58 69.2 92 94.5z +m0 0v40h399900v-40z m100 194v40h399900v-40zm0 0v40h399900v-40z`,rightharpoondown:`M399747 511c0 7.3 6.7 11 20 11 8 0 13-.8 15-2.5s4.7-6.8 + 8-15.5c40-94 99.3-166.3 178-217 13.3-8 20.3-12.3 21-13 5.3-3.3 8.5-5.8 9.5 +-7.5 1-1.7 1.5-5.2 1.5-10.5s-2.3-10.3-7-15H0v40h399908c-34 25.3-64.7 57-92 95 +-27.3 38-48.7 77.7-64 119-3.3 8.7-5 14-5 16zM0 241v40h399900v-40z`,rightharpoondownplus:`M399747 705c0 7.3 6.7 11 20 11 8 0 13-.8 + 15-2.5s4.7-6.8 8-15.5c40-94 99.3-166.3 178-217 13.3-8 20.3-12.3 21-13 5.3-3.3 + 8.5-5.8 9.5-7.5 1-1.7 1.5-5.2 1.5-10.5s-2.3-10.3-7-15H0v40h399908c-34 25.3 +-64.7 57-92 95-27.3 38-48.7 77.7-64 119-3.3 8.7-5 14-5 16zM0 435v40h399900v-40z +m0-194v40h400000v-40zm0 0v40h400000v-40z`,righthook:`M399859 241c-764 0 0 0 0 0 40-3.3 68.7-15.7 86-37 10-12 15-25.3 + 15-40 0-22.7-9.8-40.7-29.5-54-19.7-13.3-43.5-21-71.5-23-17.3-1.3-26-8-26-20 0 +-13.3 8.7-20 26-20 38 0 71 11.2 99 33.5 0 0 7 5.6 21 16.7 14 11.2 21 33.5 21 + 66.8s-14 61.2-42 83.5c-28 22.3-61 33.5-99 33.5L0 241z M0 281v-40h399859v40z`,rightlinesegment:`M399960 241 V94 h40 V428 h-40 V281 H0 v-40z +M399960 241 V94 h40 V428 h-40 V281 H0 v-40z`,rightToFrom:`M400000 167c-70.7-42-118-97.7-142-167h-23c-15.3 0-23 .3-23 + 1 0 1.3 5.3 13.7 16 37 18 35.3 41.3 69 70 101l7 8H0v40h399905l-7 8c-28.7 32 +-52 65.7-70 101-10.7 23.3-16 35.7-16 37 0 .7 7.7 1 23 1h23c24-69.3 71.3-125 142 +-167z M100 147v40h399900v-40zM0 341v40h399900v-40z`,twoheadleftarrow:`M0 167c68 40 + 115.7 95.7 143 167h22c15.3 0 23-.3 23-1 0-1.3-5.3-13.7-16-37-18-35.3-41.3-69 +-70-101l-7-8h125l9 7c50.7 39.3 85 86 103 140h46c0-4.7-6.3-18.7-19-42-18-35.3 +-40-67.3-66-96l-9-9h399716v-40H284l9-9c26-28.7 48-60.7 66-96 12.7-23.333 19 +-37.333 19-42h-46c-18 54-52.3 100.7-103 140l-9 7H95l7-8c28.7-32 52-65.7 70-101 + 10.7-23.333 16-35.7 16-37 0-.7-7.7-1-23-1h-22C115.7 71.3 68 127 0 167z`,twoheadrightarrow:`M400000 167 +c-68-40-115.7-95.7-143-167h-22c-15.3 0-23 .3-23 1 0 1.3 5.3 13.7 16 37 18 35.3 + 41.3 69 70 101l7 8h-125l-9-7c-50.7-39.3-85-86-103-140h-46c0 4.7 6.3 18.7 19 42 + 18 35.3 40 67.3 66 96l9 9H0v40h399716l-9 9c-26 28.7-48 60.7-66 96-12.7 23.333 +-19 37.333-19 42h46c18-54 52.3-100.7 103-140l9-7h125l-7 8c-28.7 32-52 65.7-70 + 101-10.7 23.333-16 35.7-16 37 0 .7 7.7 1 23 1h22c27.3-71.3 75-127 143-167z`,tilde1:`M200 55.538c-77 0-168 73.953-177 73.953-3 0-7 +-2.175-9-5.437L2 97c-1-2-2-4-2-6 0-4 2-7 5-9l20-12C116 12 171 0 207 0c86 0 + 114 68 191 68 78 0 168-68 177-68 4 0 7 2 9 5l12 19c1 2.175 2 4.35 2 6.525 0 + 4.35-2 7.613-5 9.788l-19 13.05c-92 63.077-116.937 75.308-183 76.128 +-68.267.847-113-73.952-191-73.952z`,tilde2:`M344 55.266c-142 0-300.638 81.316-311.5 86.418 +-8.01 3.762-22.5 10.91-23.5 5.562L1 120c-1-2-1-3-1-4 0-5 3-9 8-10l18.4-9C160.9 + 31.9 283 0 358 0c148 0 188 122 331 122s314-97 326-97c4 0 8 2 10 7l7 21.114 +c1 2.14 1 3.21 1 4.28 0 5.347-3 9.626-7 10.696l-22.3 12.622C852.6 158.372 751 + 181.476 676 181.476c-149 0-189-126.21-332-126.21z`,tilde3:`M786 59C457 59 32 175.242 13 175.242c-6 0-10-3.457 +-11-10.37L.15 138c-1-7 3-12 10-13l19.2-6.4C378.4 40.7 634.3 0 804.3 0c337 0 + 411.8 157 746.8 157 328 0 754-112 773-112 5 0 10 3 11 9l1 14.075c1 8.066-.697 + 16.595-6.697 17.492l-21.052 7.31c-367.9 98.146-609.15 122.696-778.15 122.696 + -338 0-409-156.573-744-156.573z`,tilde4:`M786 58C457 58 32 177.487 13 177.487c-6 0-10-3.345 +-11-10.035L.15 143c-1-7 3-12 10-13l22-6.7C381.2 35 637.15 0 807.15 0c337 0 409 + 177 744 177 328 0 754-127 773-127 5 0 10 3 11 9l1 14.794c1 7.805-3 13.38-9 + 14.495l-20.7 5.574c-366.85 99.79-607.3 139.372-776.3 139.372-338 0-409 + -175.236-744-175.236z`,vec:`M377 20c0-5.333 1.833-10 5.5-14S391 0 397 0c4.667 0 8.667 1.667 12 5 +3.333 2.667 6.667 9 10 19 6.667 24.667 20.333 43.667 41 57 7.333 4.667 11 +10.667 11 18 0 6-1 10-3 12s-6.667 5-14 9c-28.667 14.667-53.667 35.667-75 63 +-1.333 1.333-3.167 3.5-5.5 6.5s-4 4.833-5 5.5c-1 .667-2.5 1.333-4.5 2s-4.333 1 +-7 1c-4.667 0-9.167-1.833-13.5-5.5S337 184 337 178c0-12.667 15.667-32.333 47-59 +H213l-171-1c-8.667-6-13-12.333-13-19 0-4.667 4.333-11.333 13-20h359 +c-16-25.333-24-45-24-59z`,widehat1:`M529 0h5l519 115c5 1 9 5 9 10 0 1-1 2-1 3l-4 22 +c-1 5-5 9-11 9h-2L532 67 19 159h-2c-5 0-9-4-11-9l-5-22c-1-6 2-12 8-13z`,widehat2:`M1181 0h2l1171 176c6 0 10 5 10 11l-2 23c-1 6-5 10 +-11 10h-1L1182 67 15 220h-1c-6 0-10-4-11-10l-2-23c-1-6 4-11 10-11z`,widehat3:`M1181 0h2l1171 236c6 0 10 5 10 11l-2 23c-1 6-5 10 +-11 10h-1L1182 67 15 280h-1c-6 0-10-4-11-10l-2-23c-1-6 4-11 10-11z`,widehat4:`M1181 0h2l1171 296c6 0 10 5 10 11l-2 23c-1 6-5 10 +-11 10h-1L1182 67 15 340h-1c-6 0-10-4-11-10l-2-23c-1-6 4-11 10-11z`,widecheck1:`M529,159h5l519,-115c5,-1,9,-5,9,-10c0,-1,-1,-2,-1,-3l-4,-22c-1, +-5,-5,-9,-11,-9h-2l-512,92l-513,-92h-2c-5,0,-9,4,-11,9l-5,22c-1,6,2,12,8,13z`,widecheck2:`M1181,220h2l1171,-176c6,0,10,-5,10,-11l-2,-23c-1,-6,-5,-10, +-11,-10h-1l-1168,153l-1167,-153h-1c-6,0,-10,4,-11,10l-2,23c-1,6,4,11,10,11z`,widecheck3:`M1181,280h2l1171,-236c6,0,10,-5,10,-11l-2,-23c-1,-6,-5,-10, +-11,-10h-1l-1168,213l-1167,-213h-1c-6,0,-10,4,-11,10l-2,23c-1,6,4,11,10,11z`,widecheck4:`M1181,340h2l1171,-296c6,0,10,-5,10,-11l-2,-23c-1,-6,-5,-10, +-11,-10h-1l-1168,273l-1167,-273h-1c-6,0,-10,4,-11,10l-2,23c-1,6,4,11,10,11z`,baraboveleftarrow:`M400000 620h-399890l3 -3c68.7 -52.7 113.7 -120 135 -202 +c4 -14.7 6 -23 6 -25c0 -7.3 -7 -11 -21 -11c-8 0 -13.2 0.8 -15.5 2.5 +c-2.3 1.7 -4.2 5.8 -5.5 12.5c-1.3 4.7 -2.7 10.3 -4 17c-12 48.7 -34.8 92 -68.5 130 +s-74.2 66.3 -121.5 85c-10 4 -16 7.7 -18 11c0 8.7 6 14.3 18 17c47.3 18.7 87.8 47 +121.5 85s56.5 81.3 68.5 130c0.7 2 1.3 5 2 9s1.2 6.7 1.5 8c0.3 1.3 1 3.3 2 6 +s2.2 4.5 3.5 5.5c1.3 1 3.3 1.8 6 2.5s6 1 10 1c14 0 21 -3.7 21 -11 +c0 -2 -2 -10.3 -6 -25c-20 -79.3 -65 -146.7 -135 -202l-3 -3h399890z +M100 620v40h399900v-40z M0 241v40h399900v-40zM0 241v40h399900v-40z`,rightarrowabovebar:`M0 241v40h399891c-47.3 35.3-84 78-110 128-16.7 32 +-27.7 63.7-33 95 0 1.3-.2 2.7-.5 4-.3 1.3-.5 2.3-.5 3 0 7.3 6.7 11 20 11 8 0 +13.2-.8 15.5-2.5 2.3-1.7 4.2-5.5 5.5-11.5 2-13.3 5.7-27 11-41 14.7-44.7 39 +-84.5 73-119.5s73.7-60.2 119-75.5c6-2 9-5.7 9-11s-3-9-9-11c-45.3-15.3-85-40.5 +-119-75.5s-58.3-74.8-73-119.5c-4.7-14-8.3-27.3-11-40-1.3-6.7-3.2-10.8-5.5 +-12.5-2.3-1.7-7.5-2.5-15.5-2.5-14 0-21 3.7-21 11 0 2 2 10.3 6 25 20.7 83.3 67 +151.7 139 205zm96 379h399894v40H0zm0 0h399904v40H0z`,baraboveshortleftharpoon:`M507,435c-4,4,-6.3,8.7,-7,14c0,5.3,0.7,9,2,11 +c1.3,2,5.3,5.3,12,10c90.7,54,156,130,196,228c3.3,10.7,6.3,16.3,9,17 +c2,0.7,5,1,9,1c0,0,5,0,5,0c10.7,0,16.7,-2,18,-6c2,-2.7,1,-9.7,-3,-21 +c-32,-87.3,-82.7,-157.7,-152,-211c0,0,-3,-3,-3,-3l399351,0l0,-40 +c-398570,0,-399437,0,-399437,0z M593 435 v40 H399500 v-40z +M0 281 v-40 H399908 v40z M0 281 v-40 H399908 v40z`,rightharpoonaboveshortbar:`M0,241 l0,40c399126,0,399993,0,399993,0 +c4.7,-4.7,7,-9.3,7,-14c0,-9.3,-3.7,-15.3,-11,-18c-92.7,-56.7,-159,-133.7,-199, +-231c-3.3,-9.3,-6,-14.7,-8,-16c-2,-1.3,-7,-2,-15,-2c-10.7,0,-16.7,2,-18,6 +c-2,2.7,-1,9.7,3,21c15.3,42,36.7,81.8,64,119.5c27.3,37.7,58,69.2,92,94.5z +M0 241 v40 H399908 v-40z M0 475 v-40 H399500 v40z M0 475 v-40 H399500 v40z`,shortbaraboveleftharpoon:`M7,435c-4,4,-6.3,8.7,-7,14c0,5.3,0.7,9,2,11 +c1.3,2,5.3,5.3,12,10c90.7,54,156,130,196,228c3.3,10.7,6.3,16.3,9,17c2,0.7,5,1,9, +1c0,0,5,0,5,0c10.7,0,16.7,-2,18,-6c2,-2.7,1,-9.7,-3,-21c-32,-87.3,-82.7,-157.7, +-152,-211c0,0,-3,-3,-3,-3l399907,0l0,-40c-399126,0,-399993,0,-399993,0z +M93 435 v40 H400000 v-40z M500 241 v40 H400000 v-40z M500 241 v40 H400000 v-40z`,shortrightharpoonabovebar:`M53,241l0,40c398570,0,399437,0,399437,0 +c4.7,-4.7,7,-9.3,7,-14c0,-9.3,-3.7,-15.3,-11,-18c-92.7,-56.7,-159,-133.7,-199, +-231c-3.3,-9.3,-6,-14.7,-8,-16c-2,-1.3,-7,-2,-15,-2c-10.7,0,-16.7,2,-18,6 +c-2,2.7,-1,9.7,3,21c15.3,42,36.7,81.8,64,119.5c27.3,37.7,58,69.2,92,94.5z +M500 241 v40 H399408 v-40z M500 435 v40 H400000 v-40z`},sHt=function(s,u){switch(s){case"lbrack":return"M403 1759 V84 H666 V0 H319 V1759 v"+u+` v1759 h347 v-84 +H403z M403 1759 V0 H319 V1759 v`+u+" v1759 h84z";case"rbrack":return"M347 1759 V0 H0 V84 H263 V1759 v"+u+` v1759 H0 v84 H347z +M347 1759 V0 H263 V1759 v`+u+" v1759 h84z";case"vert":return"M145 15 v585 v"+u+` v585 c2.667,10,9.667,15,21,15 +c10,0,16.667,-5,20,-15 v-585 v`+-u+` v-585 c-2.667,-10,-9.667,-15,-21,-15 +c-10,0,-16.667,5,-20,15z M188 15 H145 v585 v`+u+" v585 h43z";case"doublevert":return"M145 15 v585 v"+u+` v585 c2.667,10,9.667,15,21,15 +c10,0,16.667,-5,20,-15 v-585 v`+-u+` v-585 c-2.667,-10,-9.667,-15,-21,-15 +c-10,0,-16.667,5,-20,15z M188 15 H145 v585 v`+u+` v585 h43z +M367 15 v585 v`+u+` v585 c2.667,10,9.667,15,21,15 +c10,0,16.667,-5,20,-15 v-585 v`+-u+` v-585 c-2.667,-10,-9.667,-15,-21,-15 +c-10,0,-16.667,5,-20,15z M410 15 H367 v585 v`+u+" v585 h43z";case"lfloor":return"M319 602 V0 H403 V602 v"+u+` v1715 h263 v84 H319z +MM319 602 V0 H403 V602 v`+u+" v1715 H319z";case"rfloor":return"M319 602 V0 H403 V602 v"+u+` v1799 H0 v-84 H319z +MM319 602 V0 H403 V602 v`+u+" v1715 H319z";case"lceil":return"M403 1759 V84 H666 V0 H319 V1759 v"+u+` v602 h84z +M403 1759 V0 H319 V1759 v`+u+" v602 h84z";case"rceil":return"M347 1759 V0 H0 V84 H263 V1759 v"+u+` v602 h84z +M347 1759 V0 h-84 V1759 v`+u+" v602 h84z";case"lparen":return`M863,9c0,-2,-2,-5,-6,-9c0,0,-17,0,-17,0c-12.7,0,-19.3,0.3,-20,1 +c-5.3,5.3,-10.3,11,-15,17c-242.7,294.7,-395.3,682,-458,1162c-21.3,163.3,-33.3,349, +-36,557 l0,`+(u+84)+`c0.2,6,0,26,0,60c2,159.3,10,310.7,24,454c53.3,528,210, +949.7,470,1265c4.7,6,9.7,11.7,15,17c0.7,0.7,7,1,19,1c0,0,18,0,18,0c4,-4,6,-7,6,-9 +c0,-2.7,-3.3,-8.7,-10,-18c-135.3,-192.7,-235.5,-414.3,-300.5,-665c-65,-250.7,-102.5, +-544.7,-112.5,-882c-2,-104,-3,-167,-3,-189 +l0,-`+(u+92)+`c0,-162.7,5.7,-314,17,-454c20.7,-272,63.7,-513,129,-723c65.3, +-210,155.3,-396.3,270,-559c6.7,-9.3,10,-15.3,10,-18z`;case"rparen":return`M76,0c-16.7,0,-25,3,-25,9c0,2,2,6.3,6,13c21.3,28.7,42.3,60.3, +63,95c96.7,156.7,172.8,332.5,228.5,527.5c55.7,195,92.8,416.5,111.5,664.5 +c11.3,139.3,17,290.7,17,454c0,28,1.7,43,3.3,45l0,`+(u+9)+` +c-3,4,-3.3,16.7,-3.3,38c0,162,-5.7,313.7,-17,455c-18.7,248,-55.8,469.3,-111.5,664 +c-55.7,194.7,-131.8,370.3,-228.5,527c-20.7,34.7,-41.7,66.3,-63,95c-2,3.3,-4,7,-6,11 +c0,7.3,5.7,11,17,11c0,0,11,0,11,0c9.3,0,14.3,-0.3,15,-1c5.3,-5.3,10.3,-11,15,-17 +c242.7,-294.7,395.3,-681.7,458,-1161c21.3,-164.7,33.3,-350.7,36,-558 +l0,-`+(u+144)+`c-2,-159.3,-10,-310.7,-24,-454c-53.3,-528,-210,-949.7, +-470,-1265c-4.7,-6,-9.7,-11.7,-15,-17c-0.7,-0.7,-6.7,-1,-18,-1z`;default:throw new Error("Unknown stretchy delimiter.")}};class oR{constructor(s){this.children=void 0,this.classes=void 0,this.height=void 0,this.depth=void 0,this.maxFontSize=void 0,this.style=void 0,this.children=s,this.classes=[],this.height=0,this.depth=0,this.maxFontSize=0,this.style={}}hasClass(s){return Ya.contains(this.classes,s)}toNode(){for(var s=document.createDocumentFragment(),u=0;uu.toText();return this.children.map(s).join("")}}var K4={"AMS-Regular":{32:[0,0,0,0,.25],65:[0,.68889,0,0,.72222],66:[0,.68889,0,0,.66667],67:[0,.68889,0,0,.72222],68:[0,.68889,0,0,.72222],69:[0,.68889,0,0,.66667],70:[0,.68889,0,0,.61111],71:[0,.68889,0,0,.77778],72:[0,.68889,0,0,.77778],73:[0,.68889,0,0,.38889],74:[.16667,.68889,0,0,.5],75:[0,.68889,0,0,.77778],76:[0,.68889,0,0,.66667],77:[0,.68889,0,0,.94445],78:[0,.68889,0,0,.72222],79:[.16667,.68889,0,0,.77778],80:[0,.68889,0,0,.61111],81:[.16667,.68889,0,0,.77778],82:[0,.68889,0,0,.72222],83:[0,.68889,0,0,.55556],84:[0,.68889,0,0,.66667],85:[0,.68889,0,0,.72222],86:[0,.68889,0,0,.72222],87:[0,.68889,0,0,1],88:[0,.68889,0,0,.72222],89:[0,.68889,0,0,.72222],90:[0,.68889,0,0,.66667],107:[0,.68889,0,0,.55556],160:[0,0,0,0,.25],165:[0,.675,.025,0,.75],174:[.15559,.69224,0,0,.94666],240:[0,.68889,0,0,.55556],295:[0,.68889,0,0,.54028],710:[0,.825,0,0,2.33334],732:[0,.9,0,0,2.33334],770:[0,.825,0,0,2.33334],771:[0,.9,0,0,2.33334],989:[.08167,.58167,0,0,.77778],1008:[0,.43056,.04028,0,.66667],8245:[0,.54986,0,0,.275],8463:[0,.68889,0,0,.54028],8487:[0,.68889,0,0,.72222],8498:[0,.68889,0,0,.55556],8502:[0,.68889,0,0,.66667],8503:[0,.68889,0,0,.44445],8504:[0,.68889,0,0,.66667],8513:[0,.68889,0,0,.63889],8592:[-.03598,.46402,0,0,.5],8594:[-.03598,.46402,0,0,.5],8602:[-.13313,.36687,0,0,1],8603:[-.13313,.36687,0,0,1],8606:[.01354,.52239,0,0,1],8608:[.01354,.52239,0,0,1],8610:[.01354,.52239,0,0,1.11111],8611:[.01354,.52239,0,0,1.11111],8619:[0,.54986,0,0,1],8620:[0,.54986,0,0,1],8621:[-.13313,.37788,0,0,1.38889],8622:[-.13313,.36687,0,0,1],8624:[0,.69224,0,0,.5],8625:[0,.69224,0,0,.5],8630:[0,.43056,0,0,1],8631:[0,.43056,0,0,1],8634:[.08198,.58198,0,0,.77778],8635:[.08198,.58198,0,0,.77778],8638:[.19444,.69224,0,0,.41667],8639:[.19444,.69224,0,0,.41667],8642:[.19444,.69224,0,0,.41667],8643:[.19444,.69224,0,0,.41667],8644:[.1808,.675,0,0,1],8646:[.1808,.675,0,0,1],8647:[.1808,.675,0,0,1],8648:[.19444,.69224,0,0,.83334],8649:[.1808,.675,0,0,1],8650:[.19444,.69224,0,0,.83334],8651:[.01354,.52239,0,0,1],8652:[.01354,.52239,0,0,1],8653:[-.13313,.36687,0,0,1],8654:[-.13313,.36687,0,0,1],8655:[-.13313,.36687,0,0,1],8666:[.13667,.63667,0,0,1],8667:[.13667,.63667,0,0,1],8669:[-.13313,.37788,0,0,1],8672:[-.064,.437,0,0,1.334],8674:[-.064,.437,0,0,1.334],8705:[0,.825,0,0,.5],8708:[0,.68889,0,0,.55556],8709:[.08167,.58167,0,0,.77778],8717:[0,.43056,0,0,.42917],8722:[-.03598,.46402,0,0,.5],8724:[.08198,.69224,0,0,.77778],8726:[.08167,.58167,0,0,.77778],8733:[0,.69224,0,0,.77778],8736:[0,.69224,0,0,.72222],8737:[0,.69224,0,0,.72222],8738:[.03517,.52239,0,0,.72222],8739:[.08167,.58167,0,0,.22222],8740:[.25142,.74111,0,0,.27778],8741:[.08167,.58167,0,0,.38889],8742:[.25142,.74111,0,0,.5],8756:[0,.69224,0,0,.66667],8757:[0,.69224,0,0,.66667],8764:[-.13313,.36687,0,0,.77778],8765:[-.13313,.37788,0,0,.77778],8769:[-.13313,.36687,0,0,.77778],8770:[-.03625,.46375,0,0,.77778],8774:[.30274,.79383,0,0,.77778],8776:[-.01688,.48312,0,0,.77778],8778:[.08167,.58167,0,0,.77778],8782:[.06062,.54986,0,0,.77778],8783:[.06062,.54986,0,0,.77778],8785:[.08198,.58198,0,0,.77778],8786:[.08198,.58198,0,0,.77778],8787:[.08198,.58198,0,0,.77778],8790:[0,.69224,0,0,.77778],8791:[.22958,.72958,0,0,.77778],8796:[.08198,.91667,0,0,.77778],8806:[.25583,.75583,0,0,.77778],8807:[.25583,.75583,0,0,.77778],8808:[.25142,.75726,0,0,.77778],8809:[.25142,.75726,0,0,.77778],8812:[.25583,.75583,0,0,.5],8814:[.20576,.70576,0,0,.77778],8815:[.20576,.70576,0,0,.77778],8816:[.30274,.79383,0,0,.77778],8817:[.30274,.79383,0,0,.77778],8818:[.22958,.72958,0,0,.77778],8819:[.22958,.72958,0,0,.77778],8822:[.1808,.675,0,0,.77778],8823:[.1808,.675,0,0,.77778],8828:[.13667,.63667,0,0,.77778],8829:[.13667,.63667,0,0,.77778],8830:[.22958,.72958,0,0,.77778],8831:[.22958,.72958,0,0,.77778],8832:[.20576,.70576,0,0,.77778],8833:[.20576,.70576,0,0,.77778],8840:[.30274,.79383,0,0,.77778],8841:[.30274,.79383,0,0,.77778],8842:[.13597,.63597,0,0,.77778],8843:[.13597,.63597,0,0,.77778],8847:[.03517,.54986,0,0,.77778],8848:[.03517,.54986,0,0,.77778],8858:[.08198,.58198,0,0,.77778],8859:[.08198,.58198,0,0,.77778],8861:[.08198,.58198,0,0,.77778],8862:[0,.675,0,0,.77778],8863:[0,.675,0,0,.77778],8864:[0,.675,0,0,.77778],8865:[0,.675,0,0,.77778],8872:[0,.69224,0,0,.61111],8873:[0,.69224,0,0,.72222],8874:[0,.69224,0,0,.88889],8876:[0,.68889,0,0,.61111],8877:[0,.68889,0,0,.61111],8878:[0,.68889,0,0,.72222],8879:[0,.68889,0,0,.72222],8882:[.03517,.54986,0,0,.77778],8883:[.03517,.54986,0,0,.77778],8884:[.13667,.63667,0,0,.77778],8885:[.13667,.63667,0,0,.77778],8888:[0,.54986,0,0,1.11111],8890:[.19444,.43056,0,0,.55556],8891:[.19444,.69224,0,0,.61111],8892:[.19444,.69224,0,0,.61111],8901:[0,.54986,0,0,.27778],8903:[.08167,.58167,0,0,.77778],8905:[.08167,.58167,0,0,.77778],8906:[.08167,.58167,0,0,.77778],8907:[0,.69224,0,0,.77778],8908:[0,.69224,0,0,.77778],8909:[-.03598,.46402,0,0,.77778],8910:[0,.54986,0,0,.76042],8911:[0,.54986,0,0,.76042],8912:[.03517,.54986,0,0,.77778],8913:[.03517,.54986,0,0,.77778],8914:[0,.54986,0,0,.66667],8915:[0,.54986,0,0,.66667],8916:[0,.69224,0,0,.66667],8918:[.0391,.5391,0,0,.77778],8919:[.0391,.5391,0,0,.77778],8920:[.03517,.54986,0,0,1.33334],8921:[.03517,.54986,0,0,1.33334],8922:[.38569,.88569,0,0,.77778],8923:[.38569,.88569,0,0,.77778],8926:[.13667,.63667,0,0,.77778],8927:[.13667,.63667,0,0,.77778],8928:[.30274,.79383,0,0,.77778],8929:[.30274,.79383,0,0,.77778],8934:[.23222,.74111,0,0,.77778],8935:[.23222,.74111,0,0,.77778],8936:[.23222,.74111,0,0,.77778],8937:[.23222,.74111,0,0,.77778],8938:[.20576,.70576,0,0,.77778],8939:[.20576,.70576,0,0,.77778],8940:[.30274,.79383,0,0,.77778],8941:[.30274,.79383,0,0,.77778],8994:[.19444,.69224,0,0,.77778],8995:[.19444,.69224,0,0,.77778],9416:[.15559,.69224,0,0,.90222],9484:[0,.69224,0,0,.5],9488:[0,.69224,0,0,.5],9492:[0,.37788,0,0,.5],9496:[0,.37788,0,0,.5],9585:[.19444,.68889,0,0,.88889],9586:[.19444,.74111,0,0,.88889],9632:[0,.675,0,0,.77778],9633:[0,.675,0,0,.77778],9650:[0,.54986,0,0,.72222],9651:[0,.54986,0,0,.72222],9654:[.03517,.54986,0,0,.77778],9660:[0,.54986,0,0,.72222],9661:[0,.54986,0,0,.72222],9664:[.03517,.54986,0,0,.77778],9674:[.11111,.69224,0,0,.66667],9733:[.19444,.69224,0,0,.94445],10003:[0,.69224,0,0,.83334],10016:[0,.69224,0,0,.83334],10731:[.11111,.69224,0,0,.66667],10846:[.19444,.75583,0,0,.61111],10877:[.13667,.63667,0,0,.77778],10878:[.13667,.63667,0,0,.77778],10885:[.25583,.75583,0,0,.77778],10886:[.25583,.75583,0,0,.77778],10887:[.13597,.63597,0,0,.77778],10888:[.13597,.63597,0,0,.77778],10889:[.26167,.75726,0,0,.77778],10890:[.26167,.75726,0,0,.77778],10891:[.48256,.98256,0,0,.77778],10892:[.48256,.98256,0,0,.77778],10901:[.13667,.63667,0,0,.77778],10902:[.13667,.63667,0,0,.77778],10933:[.25142,.75726,0,0,.77778],10934:[.25142,.75726,0,0,.77778],10935:[.26167,.75726,0,0,.77778],10936:[.26167,.75726,0,0,.77778],10937:[.26167,.75726,0,0,.77778],10938:[.26167,.75726,0,0,.77778],10949:[.25583,.75583,0,0,.77778],10950:[.25583,.75583,0,0,.77778],10955:[.28481,.79383,0,0,.77778],10956:[.28481,.79383,0,0,.77778],57350:[.08167,.58167,0,0,.22222],57351:[.08167,.58167,0,0,.38889],57352:[.08167,.58167,0,0,.77778],57353:[0,.43056,.04028,0,.66667],57356:[.25142,.75726,0,0,.77778],57357:[.25142,.75726,0,0,.77778],57358:[.41951,.91951,0,0,.77778],57359:[.30274,.79383,0,0,.77778],57360:[.30274,.79383,0,0,.77778],57361:[.41951,.91951,0,0,.77778],57366:[.25142,.75726,0,0,.77778],57367:[.25142,.75726,0,0,.77778],57368:[.25142,.75726,0,0,.77778],57369:[.25142,.75726,0,0,.77778],57370:[.13597,.63597,0,0,.77778],57371:[.13597,.63597,0,0,.77778]},"Caligraphic-Regular":{32:[0,0,0,0,.25],65:[0,.68333,0,.19445,.79847],66:[0,.68333,.03041,.13889,.65681],67:[0,.68333,.05834,.13889,.52653],68:[0,.68333,.02778,.08334,.77139],69:[0,.68333,.08944,.11111,.52778],70:[0,.68333,.09931,.11111,.71875],71:[.09722,.68333,.0593,.11111,.59487],72:[0,.68333,.00965,.11111,.84452],73:[0,.68333,.07382,0,.54452],74:[.09722,.68333,.18472,.16667,.67778],75:[0,.68333,.01445,.05556,.76195],76:[0,.68333,0,.13889,.68972],77:[0,.68333,0,.13889,1.2009],78:[0,.68333,.14736,.08334,.82049],79:[0,.68333,.02778,.11111,.79611],80:[0,.68333,.08222,.08334,.69556],81:[.09722,.68333,0,.11111,.81667],82:[0,.68333,0,.08334,.8475],83:[0,.68333,.075,.13889,.60556],84:[0,.68333,.25417,0,.54464],85:[0,.68333,.09931,.08334,.62583],86:[0,.68333,.08222,0,.61278],87:[0,.68333,.08222,.08334,.98778],88:[0,.68333,.14643,.13889,.7133],89:[.09722,.68333,.08222,.08334,.66834],90:[0,.68333,.07944,.13889,.72473],160:[0,0,0,0,.25]},"Fraktur-Regular":{32:[0,0,0,0,.25],33:[0,.69141,0,0,.29574],34:[0,.69141,0,0,.21471],38:[0,.69141,0,0,.73786],39:[0,.69141,0,0,.21201],40:[.24982,.74947,0,0,.38865],41:[.24982,.74947,0,0,.38865],42:[0,.62119,0,0,.27764],43:[.08319,.58283,0,0,.75623],44:[0,.10803,0,0,.27764],45:[.08319,.58283,0,0,.75623],46:[0,.10803,0,0,.27764],47:[.24982,.74947,0,0,.50181],48:[0,.47534,0,0,.50181],49:[0,.47534,0,0,.50181],50:[0,.47534,0,0,.50181],51:[.18906,.47534,0,0,.50181],52:[.18906,.47534,0,0,.50181],53:[.18906,.47534,0,0,.50181],54:[0,.69141,0,0,.50181],55:[.18906,.47534,0,0,.50181],56:[0,.69141,0,0,.50181],57:[.18906,.47534,0,0,.50181],58:[0,.47534,0,0,.21606],59:[.12604,.47534,0,0,.21606],61:[-.13099,.36866,0,0,.75623],63:[0,.69141,0,0,.36245],65:[0,.69141,0,0,.7176],66:[0,.69141,0,0,.88397],67:[0,.69141,0,0,.61254],68:[0,.69141,0,0,.83158],69:[0,.69141,0,0,.66278],70:[.12604,.69141,0,0,.61119],71:[0,.69141,0,0,.78539],72:[.06302,.69141,0,0,.7203],73:[0,.69141,0,0,.55448],74:[.12604,.69141,0,0,.55231],75:[0,.69141,0,0,.66845],76:[0,.69141,0,0,.66602],77:[0,.69141,0,0,1.04953],78:[0,.69141,0,0,.83212],79:[0,.69141,0,0,.82699],80:[.18906,.69141,0,0,.82753],81:[.03781,.69141,0,0,.82699],82:[0,.69141,0,0,.82807],83:[0,.69141,0,0,.82861],84:[0,.69141,0,0,.66899],85:[0,.69141,0,0,.64576],86:[0,.69141,0,0,.83131],87:[0,.69141,0,0,1.04602],88:[0,.69141,0,0,.71922],89:[.18906,.69141,0,0,.83293],90:[.12604,.69141,0,0,.60201],91:[.24982,.74947,0,0,.27764],93:[.24982,.74947,0,0,.27764],94:[0,.69141,0,0,.49965],97:[0,.47534,0,0,.50046],98:[0,.69141,0,0,.51315],99:[0,.47534,0,0,.38946],100:[0,.62119,0,0,.49857],101:[0,.47534,0,0,.40053],102:[.18906,.69141,0,0,.32626],103:[.18906,.47534,0,0,.5037],104:[.18906,.69141,0,0,.52126],105:[0,.69141,0,0,.27899],106:[0,.69141,0,0,.28088],107:[0,.69141,0,0,.38946],108:[0,.69141,0,0,.27953],109:[0,.47534,0,0,.76676],110:[0,.47534,0,0,.52666],111:[0,.47534,0,0,.48885],112:[.18906,.52396,0,0,.50046],113:[.18906,.47534,0,0,.48912],114:[0,.47534,0,0,.38919],115:[0,.47534,0,0,.44266],116:[0,.62119,0,0,.33301],117:[0,.47534,0,0,.5172],118:[0,.52396,0,0,.5118],119:[0,.52396,0,0,.77351],120:[.18906,.47534,0,0,.38865],121:[.18906,.47534,0,0,.49884],122:[.18906,.47534,0,0,.39054],160:[0,0,0,0,.25],8216:[0,.69141,0,0,.21471],8217:[0,.69141,0,0,.21471],58112:[0,.62119,0,0,.49749],58113:[0,.62119,0,0,.4983],58114:[.18906,.69141,0,0,.33328],58115:[.18906,.69141,0,0,.32923],58116:[.18906,.47534,0,0,.50343],58117:[0,.69141,0,0,.33301],58118:[0,.62119,0,0,.33409],58119:[0,.47534,0,0,.50073]},"Main-Bold":{32:[0,0,0,0,.25],33:[0,.69444,0,0,.35],34:[0,.69444,0,0,.60278],35:[.19444,.69444,0,0,.95833],36:[.05556,.75,0,0,.575],37:[.05556,.75,0,0,.95833],38:[0,.69444,0,0,.89444],39:[0,.69444,0,0,.31944],40:[.25,.75,0,0,.44722],41:[.25,.75,0,0,.44722],42:[0,.75,0,0,.575],43:[.13333,.63333,0,0,.89444],44:[.19444,.15556,0,0,.31944],45:[0,.44444,0,0,.38333],46:[0,.15556,0,0,.31944],47:[.25,.75,0,0,.575],48:[0,.64444,0,0,.575],49:[0,.64444,0,0,.575],50:[0,.64444,0,0,.575],51:[0,.64444,0,0,.575],52:[0,.64444,0,0,.575],53:[0,.64444,0,0,.575],54:[0,.64444,0,0,.575],55:[0,.64444,0,0,.575],56:[0,.64444,0,0,.575],57:[0,.64444,0,0,.575],58:[0,.44444,0,0,.31944],59:[.19444,.44444,0,0,.31944],60:[.08556,.58556,0,0,.89444],61:[-.10889,.39111,0,0,.89444],62:[.08556,.58556,0,0,.89444],63:[0,.69444,0,0,.54305],64:[0,.69444,0,0,.89444],65:[0,.68611,0,0,.86944],66:[0,.68611,0,0,.81805],67:[0,.68611,0,0,.83055],68:[0,.68611,0,0,.88194],69:[0,.68611,0,0,.75555],70:[0,.68611,0,0,.72361],71:[0,.68611,0,0,.90416],72:[0,.68611,0,0,.9],73:[0,.68611,0,0,.43611],74:[0,.68611,0,0,.59444],75:[0,.68611,0,0,.90138],76:[0,.68611,0,0,.69166],77:[0,.68611,0,0,1.09166],78:[0,.68611,0,0,.9],79:[0,.68611,0,0,.86388],80:[0,.68611,0,0,.78611],81:[.19444,.68611,0,0,.86388],82:[0,.68611,0,0,.8625],83:[0,.68611,0,0,.63889],84:[0,.68611,0,0,.8],85:[0,.68611,0,0,.88472],86:[0,.68611,.01597,0,.86944],87:[0,.68611,.01597,0,1.18888],88:[0,.68611,0,0,.86944],89:[0,.68611,.02875,0,.86944],90:[0,.68611,0,0,.70277],91:[.25,.75,0,0,.31944],92:[.25,.75,0,0,.575],93:[.25,.75,0,0,.31944],94:[0,.69444,0,0,.575],95:[.31,.13444,.03194,0,.575],97:[0,.44444,0,0,.55902],98:[0,.69444,0,0,.63889],99:[0,.44444,0,0,.51111],100:[0,.69444,0,0,.63889],101:[0,.44444,0,0,.52708],102:[0,.69444,.10903,0,.35139],103:[.19444,.44444,.01597,0,.575],104:[0,.69444,0,0,.63889],105:[0,.69444,0,0,.31944],106:[.19444,.69444,0,0,.35139],107:[0,.69444,0,0,.60694],108:[0,.69444,0,0,.31944],109:[0,.44444,0,0,.95833],110:[0,.44444,0,0,.63889],111:[0,.44444,0,0,.575],112:[.19444,.44444,0,0,.63889],113:[.19444,.44444,0,0,.60694],114:[0,.44444,0,0,.47361],115:[0,.44444,0,0,.45361],116:[0,.63492,0,0,.44722],117:[0,.44444,0,0,.63889],118:[0,.44444,.01597,0,.60694],119:[0,.44444,.01597,0,.83055],120:[0,.44444,0,0,.60694],121:[.19444,.44444,.01597,0,.60694],122:[0,.44444,0,0,.51111],123:[.25,.75,0,0,.575],124:[.25,.75,0,0,.31944],125:[.25,.75,0,0,.575],126:[.35,.34444,0,0,.575],160:[0,0,0,0,.25],163:[0,.69444,0,0,.86853],168:[0,.69444,0,0,.575],172:[0,.44444,0,0,.76666],176:[0,.69444,0,0,.86944],177:[.13333,.63333,0,0,.89444],184:[.17014,0,0,0,.51111],198:[0,.68611,0,0,1.04166],215:[.13333,.63333,0,0,.89444],216:[.04861,.73472,0,0,.89444],223:[0,.69444,0,0,.59722],230:[0,.44444,0,0,.83055],247:[.13333,.63333,0,0,.89444],248:[.09722,.54167,0,0,.575],305:[0,.44444,0,0,.31944],338:[0,.68611,0,0,1.16944],339:[0,.44444,0,0,.89444],567:[.19444,.44444,0,0,.35139],710:[0,.69444,0,0,.575],711:[0,.63194,0,0,.575],713:[0,.59611,0,0,.575],714:[0,.69444,0,0,.575],715:[0,.69444,0,0,.575],728:[0,.69444,0,0,.575],729:[0,.69444,0,0,.31944],730:[0,.69444,0,0,.86944],732:[0,.69444,0,0,.575],733:[0,.69444,0,0,.575],915:[0,.68611,0,0,.69166],916:[0,.68611,0,0,.95833],920:[0,.68611,0,0,.89444],923:[0,.68611,0,0,.80555],926:[0,.68611,0,0,.76666],928:[0,.68611,0,0,.9],931:[0,.68611,0,0,.83055],933:[0,.68611,0,0,.89444],934:[0,.68611,0,0,.83055],936:[0,.68611,0,0,.89444],937:[0,.68611,0,0,.83055],8211:[0,.44444,.03194,0,.575],8212:[0,.44444,.03194,0,1.14999],8216:[0,.69444,0,0,.31944],8217:[0,.69444,0,0,.31944],8220:[0,.69444,0,0,.60278],8221:[0,.69444,0,0,.60278],8224:[.19444,.69444,0,0,.51111],8225:[.19444,.69444,0,0,.51111],8242:[0,.55556,0,0,.34444],8407:[0,.72444,.15486,0,.575],8463:[0,.69444,0,0,.66759],8465:[0,.69444,0,0,.83055],8467:[0,.69444,0,0,.47361],8472:[.19444,.44444,0,0,.74027],8476:[0,.69444,0,0,.83055],8501:[0,.69444,0,0,.70277],8592:[-.10889,.39111,0,0,1.14999],8593:[.19444,.69444,0,0,.575],8594:[-.10889,.39111,0,0,1.14999],8595:[.19444,.69444,0,0,.575],8596:[-.10889,.39111,0,0,1.14999],8597:[.25,.75,0,0,.575],8598:[.19444,.69444,0,0,1.14999],8599:[.19444,.69444,0,0,1.14999],8600:[.19444,.69444,0,0,1.14999],8601:[.19444,.69444,0,0,1.14999],8636:[-.10889,.39111,0,0,1.14999],8637:[-.10889,.39111,0,0,1.14999],8640:[-.10889,.39111,0,0,1.14999],8641:[-.10889,.39111,0,0,1.14999],8656:[-.10889,.39111,0,0,1.14999],8657:[.19444,.69444,0,0,.70277],8658:[-.10889,.39111,0,0,1.14999],8659:[.19444,.69444,0,0,.70277],8660:[-.10889,.39111,0,0,1.14999],8661:[.25,.75,0,0,.70277],8704:[0,.69444,0,0,.63889],8706:[0,.69444,.06389,0,.62847],8707:[0,.69444,0,0,.63889],8709:[.05556,.75,0,0,.575],8711:[0,.68611,0,0,.95833],8712:[.08556,.58556,0,0,.76666],8715:[.08556,.58556,0,0,.76666],8722:[.13333,.63333,0,0,.89444],8723:[.13333,.63333,0,0,.89444],8725:[.25,.75,0,0,.575],8726:[.25,.75,0,0,.575],8727:[-.02778,.47222,0,0,.575],8728:[-.02639,.47361,0,0,.575],8729:[-.02639,.47361,0,0,.575],8730:[.18,.82,0,0,.95833],8733:[0,.44444,0,0,.89444],8734:[0,.44444,0,0,1.14999],8736:[0,.69224,0,0,.72222],8739:[.25,.75,0,0,.31944],8741:[.25,.75,0,0,.575],8743:[0,.55556,0,0,.76666],8744:[0,.55556,0,0,.76666],8745:[0,.55556,0,0,.76666],8746:[0,.55556,0,0,.76666],8747:[.19444,.69444,.12778,0,.56875],8764:[-.10889,.39111,0,0,.89444],8768:[.19444,.69444,0,0,.31944],8771:[.00222,.50222,0,0,.89444],8773:[.027,.638,0,0,.894],8776:[.02444,.52444,0,0,.89444],8781:[.00222,.50222,0,0,.89444],8801:[.00222,.50222,0,0,.89444],8804:[.19667,.69667,0,0,.89444],8805:[.19667,.69667,0,0,.89444],8810:[.08556,.58556,0,0,1.14999],8811:[.08556,.58556,0,0,1.14999],8826:[.08556,.58556,0,0,.89444],8827:[.08556,.58556,0,0,.89444],8834:[.08556,.58556,0,0,.89444],8835:[.08556,.58556,0,0,.89444],8838:[.19667,.69667,0,0,.89444],8839:[.19667,.69667,0,0,.89444],8846:[0,.55556,0,0,.76666],8849:[.19667,.69667,0,0,.89444],8850:[.19667,.69667,0,0,.89444],8851:[0,.55556,0,0,.76666],8852:[0,.55556,0,0,.76666],8853:[.13333,.63333,0,0,.89444],8854:[.13333,.63333,0,0,.89444],8855:[.13333,.63333,0,0,.89444],8856:[.13333,.63333,0,0,.89444],8857:[.13333,.63333,0,0,.89444],8866:[0,.69444,0,0,.70277],8867:[0,.69444,0,0,.70277],8868:[0,.69444,0,0,.89444],8869:[0,.69444,0,0,.89444],8900:[-.02639,.47361,0,0,.575],8901:[-.02639,.47361,0,0,.31944],8902:[-.02778,.47222,0,0,.575],8968:[.25,.75,0,0,.51111],8969:[.25,.75,0,0,.51111],8970:[.25,.75,0,0,.51111],8971:[.25,.75,0,0,.51111],8994:[-.13889,.36111,0,0,1.14999],8995:[-.13889,.36111,0,0,1.14999],9651:[.19444,.69444,0,0,1.02222],9657:[-.02778,.47222,0,0,.575],9661:[.19444,.69444,0,0,1.02222],9667:[-.02778,.47222,0,0,.575],9711:[.19444,.69444,0,0,1.14999],9824:[.12963,.69444,0,0,.89444],9825:[.12963,.69444,0,0,.89444],9826:[.12963,.69444,0,0,.89444],9827:[.12963,.69444,0,0,.89444],9837:[0,.75,0,0,.44722],9838:[.19444,.69444,0,0,.44722],9839:[.19444,.69444,0,0,.44722],10216:[.25,.75,0,0,.44722],10217:[.25,.75,0,0,.44722],10815:[0,.68611,0,0,.9],10927:[.19667,.69667,0,0,.89444],10928:[.19667,.69667,0,0,.89444],57376:[.19444,.69444,0,0,0]},"Main-BoldItalic":{32:[0,0,0,0,.25],33:[0,.69444,.11417,0,.38611],34:[0,.69444,.07939,0,.62055],35:[.19444,.69444,.06833,0,.94444],37:[.05556,.75,.12861,0,.94444],38:[0,.69444,.08528,0,.88555],39:[0,.69444,.12945,0,.35555],40:[.25,.75,.15806,0,.47333],41:[.25,.75,.03306,0,.47333],42:[0,.75,.14333,0,.59111],43:[.10333,.60333,.03306,0,.88555],44:[.19444,.14722,0,0,.35555],45:[0,.44444,.02611,0,.41444],46:[0,.14722,0,0,.35555],47:[.25,.75,.15806,0,.59111],48:[0,.64444,.13167,0,.59111],49:[0,.64444,.13167,0,.59111],50:[0,.64444,.13167,0,.59111],51:[0,.64444,.13167,0,.59111],52:[.19444,.64444,.13167,0,.59111],53:[0,.64444,.13167,0,.59111],54:[0,.64444,.13167,0,.59111],55:[.19444,.64444,.13167,0,.59111],56:[0,.64444,.13167,0,.59111],57:[0,.64444,.13167,0,.59111],58:[0,.44444,.06695,0,.35555],59:[.19444,.44444,.06695,0,.35555],61:[-.10889,.39111,.06833,0,.88555],63:[0,.69444,.11472,0,.59111],64:[0,.69444,.09208,0,.88555],65:[0,.68611,0,0,.86555],66:[0,.68611,.0992,0,.81666],67:[0,.68611,.14208,0,.82666],68:[0,.68611,.09062,0,.87555],69:[0,.68611,.11431,0,.75666],70:[0,.68611,.12903,0,.72722],71:[0,.68611,.07347,0,.89527],72:[0,.68611,.17208,0,.8961],73:[0,.68611,.15681,0,.47166],74:[0,.68611,.145,0,.61055],75:[0,.68611,.14208,0,.89499],76:[0,.68611,0,0,.69777],77:[0,.68611,.17208,0,1.07277],78:[0,.68611,.17208,0,.8961],79:[0,.68611,.09062,0,.85499],80:[0,.68611,.0992,0,.78721],81:[.19444,.68611,.09062,0,.85499],82:[0,.68611,.02559,0,.85944],83:[0,.68611,.11264,0,.64999],84:[0,.68611,.12903,0,.7961],85:[0,.68611,.17208,0,.88083],86:[0,.68611,.18625,0,.86555],87:[0,.68611,.18625,0,1.15999],88:[0,.68611,.15681,0,.86555],89:[0,.68611,.19803,0,.86555],90:[0,.68611,.14208,0,.70888],91:[.25,.75,.1875,0,.35611],93:[.25,.75,.09972,0,.35611],94:[0,.69444,.06709,0,.59111],95:[.31,.13444,.09811,0,.59111],97:[0,.44444,.09426,0,.59111],98:[0,.69444,.07861,0,.53222],99:[0,.44444,.05222,0,.53222],100:[0,.69444,.10861,0,.59111],101:[0,.44444,.085,0,.53222],102:[.19444,.69444,.21778,0,.4],103:[.19444,.44444,.105,0,.53222],104:[0,.69444,.09426,0,.59111],105:[0,.69326,.11387,0,.35555],106:[.19444,.69326,.1672,0,.35555],107:[0,.69444,.11111,0,.53222],108:[0,.69444,.10861,0,.29666],109:[0,.44444,.09426,0,.94444],110:[0,.44444,.09426,0,.64999],111:[0,.44444,.07861,0,.59111],112:[.19444,.44444,.07861,0,.59111],113:[.19444,.44444,.105,0,.53222],114:[0,.44444,.11111,0,.50167],115:[0,.44444,.08167,0,.48694],116:[0,.63492,.09639,0,.385],117:[0,.44444,.09426,0,.62055],118:[0,.44444,.11111,0,.53222],119:[0,.44444,.11111,0,.76777],120:[0,.44444,.12583,0,.56055],121:[.19444,.44444,.105,0,.56166],122:[0,.44444,.13889,0,.49055],126:[.35,.34444,.11472,0,.59111],160:[0,0,0,0,.25],168:[0,.69444,.11473,0,.59111],176:[0,.69444,0,0,.94888],184:[.17014,0,0,0,.53222],198:[0,.68611,.11431,0,1.02277],216:[.04861,.73472,.09062,0,.88555],223:[.19444,.69444,.09736,0,.665],230:[0,.44444,.085,0,.82666],248:[.09722,.54167,.09458,0,.59111],305:[0,.44444,.09426,0,.35555],338:[0,.68611,.11431,0,1.14054],339:[0,.44444,.085,0,.82666],567:[.19444,.44444,.04611,0,.385],710:[0,.69444,.06709,0,.59111],711:[0,.63194,.08271,0,.59111],713:[0,.59444,.10444,0,.59111],714:[0,.69444,.08528,0,.59111],715:[0,.69444,0,0,.59111],728:[0,.69444,.10333,0,.59111],729:[0,.69444,.12945,0,.35555],730:[0,.69444,0,0,.94888],732:[0,.69444,.11472,0,.59111],733:[0,.69444,.11472,0,.59111],915:[0,.68611,.12903,0,.69777],916:[0,.68611,0,0,.94444],920:[0,.68611,.09062,0,.88555],923:[0,.68611,0,0,.80666],926:[0,.68611,.15092,0,.76777],928:[0,.68611,.17208,0,.8961],931:[0,.68611,.11431,0,.82666],933:[0,.68611,.10778,0,.88555],934:[0,.68611,.05632,0,.82666],936:[0,.68611,.10778,0,.88555],937:[0,.68611,.0992,0,.82666],8211:[0,.44444,.09811,0,.59111],8212:[0,.44444,.09811,0,1.18221],8216:[0,.69444,.12945,0,.35555],8217:[0,.69444,.12945,0,.35555],8220:[0,.69444,.16772,0,.62055],8221:[0,.69444,.07939,0,.62055]},"Main-Italic":{32:[0,0,0,0,.25],33:[0,.69444,.12417,0,.30667],34:[0,.69444,.06961,0,.51444],35:[.19444,.69444,.06616,0,.81777],37:[.05556,.75,.13639,0,.81777],38:[0,.69444,.09694,0,.76666],39:[0,.69444,.12417,0,.30667],40:[.25,.75,.16194,0,.40889],41:[.25,.75,.03694,0,.40889],42:[0,.75,.14917,0,.51111],43:[.05667,.56167,.03694,0,.76666],44:[.19444,.10556,0,0,.30667],45:[0,.43056,.02826,0,.35778],46:[0,.10556,0,0,.30667],47:[.25,.75,.16194,0,.51111],48:[0,.64444,.13556,0,.51111],49:[0,.64444,.13556,0,.51111],50:[0,.64444,.13556,0,.51111],51:[0,.64444,.13556,0,.51111],52:[.19444,.64444,.13556,0,.51111],53:[0,.64444,.13556,0,.51111],54:[0,.64444,.13556,0,.51111],55:[.19444,.64444,.13556,0,.51111],56:[0,.64444,.13556,0,.51111],57:[0,.64444,.13556,0,.51111],58:[0,.43056,.0582,0,.30667],59:[.19444,.43056,.0582,0,.30667],61:[-.13313,.36687,.06616,0,.76666],63:[0,.69444,.1225,0,.51111],64:[0,.69444,.09597,0,.76666],65:[0,.68333,0,0,.74333],66:[0,.68333,.10257,0,.70389],67:[0,.68333,.14528,0,.71555],68:[0,.68333,.09403,0,.755],69:[0,.68333,.12028,0,.67833],70:[0,.68333,.13305,0,.65277],71:[0,.68333,.08722,0,.77361],72:[0,.68333,.16389,0,.74333],73:[0,.68333,.15806,0,.38555],74:[0,.68333,.14028,0,.525],75:[0,.68333,.14528,0,.76888],76:[0,.68333,0,0,.62722],77:[0,.68333,.16389,0,.89666],78:[0,.68333,.16389,0,.74333],79:[0,.68333,.09403,0,.76666],80:[0,.68333,.10257,0,.67833],81:[.19444,.68333,.09403,0,.76666],82:[0,.68333,.03868,0,.72944],83:[0,.68333,.11972,0,.56222],84:[0,.68333,.13305,0,.71555],85:[0,.68333,.16389,0,.74333],86:[0,.68333,.18361,0,.74333],87:[0,.68333,.18361,0,.99888],88:[0,.68333,.15806,0,.74333],89:[0,.68333,.19383,0,.74333],90:[0,.68333,.14528,0,.61333],91:[.25,.75,.1875,0,.30667],93:[.25,.75,.10528,0,.30667],94:[0,.69444,.06646,0,.51111],95:[.31,.12056,.09208,0,.51111],97:[0,.43056,.07671,0,.51111],98:[0,.69444,.06312,0,.46],99:[0,.43056,.05653,0,.46],100:[0,.69444,.10333,0,.51111],101:[0,.43056,.07514,0,.46],102:[.19444,.69444,.21194,0,.30667],103:[.19444,.43056,.08847,0,.46],104:[0,.69444,.07671,0,.51111],105:[0,.65536,.1019,0,.30667],106:[.19444,.65536,.14467,0,.30667],107:[0,.69444,.10764,0,.46],108:[0,.69444,.10333,0,.25555],109:[0,.43056,.07671,0,.81777],110:[0,.43056,.07671,0,.56222],111:[0,.43056,.06312,0,.51111],112:[.19444,.43056,.06312,0,.51111],113:[.19444,.43056,.08847,0,.46],114:[0,.43056,.10764,0,.42166],115:[0,.43056,.08208,0,.40889],116:[0,.61508,.09486,0,.33222],117:[0,.43056,.07671,0,.53666],118:[0,.43056,.10764,0,.46],119:[0,.43056,.10764,0,.66444],120:[0,.43056,.12042,0,.46389],121:[.19444,.43056,.08847,0,.48555],122:[0,.43056,.12292,0,.40889],126:[.35,.31786,.11585,0,.51111],160:[0,0,0,0,.25],168:[0,.66786,.10474,0,.51111],176:[0,.69444,0,0,.83129],184:[.17014,0,0,0,.46],198:[0,.68333,.12028,0,.88277],216:[.04861,.73194,.09403,0,.76666],223:[.19444,.69444,.10514,0,.53666],230:[0,.43056,.07514,0,.71555],248:[.09722,.52778,.09194,0,.51111],338:[0,.68333,.12028,0,.98499],339:[0,.43056,.07514,0,.71555],710:[0,.69444,.06646,0,.51111],711:[0,.62847,.08295,0,.51111],713:[0,.56167,.10333,0,.51111],714:[0,.69444,.09694,0,.51111],715:[0,.69444,0,0,.51111],728:[0,.69444,.10806,0,.51111],729:[0,.66786,.11752,0,.30667],730:[0,.69444,0,0,.83129],732:[0,.66786,.11585,0,.51111],733:[0,.69444,.1225,0,.51111],915:[0,.68333,.13305,0,.62722],916:[0,.68333,0,0,.81777],920:[0,.68333,.09403,0,.76666],923:[0,.68333,0,0,.69222],926:[0,.68333,.15294,0,.66444],928:[0,.68333,.16389,0,.74333],931:[0,.68333,.12028,0,.71555],933:[0,.68333,.11111,0,.76666],934:[0,.68333,.05986,0,.71555],936:[0,.68333,.11111,0,.76666],937:[0,.68333,.10257,0,.71555],8211:[0,.43056,.09208,0,.51111],8212:[0,.43056,.09208,0,1.02222],8216:[0,.69444,.12417,0,.30667],8217:[0,.69444,.12417,0,.30667],8220:[0,.69444,.1685,0,.51444],8221:[0,.69444,.06961,0,.51444],8463:[0,.68889,0,0,.54028]},"Main-Regular":{32:[0,0,0,0,.25],33:[0,.69444,0,0,.27778],34:[0,.69444,0,0,.5],35:[.19444,.69444,0,0,.83334],36:[.05556,.75,0,0,.5],37:[.05556,.75,0,0,.83334],38:[0,.69444,0,0,.77778],39:[0,.69444,0,0,.27778],40:[.25,.75,0,0,.38889],41:[.25,.75,0,0,.38889],42:[0,.75,0,0,.5],43:[.08333,.58333,0,0,.77778],44:[.19444,.10556,0,0,.27778],45:[0,.43056,0,0,.33333],46:[0,.10556,0,0,.27778],47:[.25,.75,0,0,.5],48:[0,.64444,0,0,.5],49:[0,.64444,0,0,.5],50:[0,.64444,0,0,.5],51:[0,.64444,0,0,.5],52:[0,.64444,0,0,.5],53:[0,.64444,0,0,.5],54:[0,.64444,0,0,.5],55:[0,.64444,0,0,.5],56:[0,.64444,0,0,.5],57:[0,.64444,0,0,.5],58:[0,.43056,0,0,.27778],59:[.19444,.43056,0,0,.27778],60:[.0391,.5391,0,0,.77778],61:[-.13313,.36687,0,0,.77778],62:[.0391,.5391,0,0,.77778],63:[0,.69444,0,0,.47222],64:[0,.69444,0,0,.77778],65:[0,.68333,0,0,.75],66:[0,.68333,0,0,.70834],67:[0,.68333,0,0,.72222],68:[0,.68333,0,0,.76389],69:[0,.68333,0,0,.68056],70:[0,.68333,0,0,.65278],71:[0,.68333,0,0,.78472],72:[0,.68333,0,0,.75],73:[0,.68333,0,0,.36111],74:[0,.68333,0,0,.51389],75:[0,.68333,0,0,.77778],76:[0,.68333,0,0,.625],77:[0,.68333,0,0,.91667],78:[0,.68333,0,0,.75],79:[0,.68333,0,0,.77778],80:[0,.68333,0,0,.68056],81:[.19444,.68333,0,0,.77778],82:[0,.68333,0,0,.73611],83:[0,.68333,0,0,.55556],84:[0,.68333,0,0,.72222],85:[0,.68333,0,0,.75],86:[0,.68333,.01389,0,.75],87:[0,.68333,.01389,0,1.02778],88:[0,.68333,0,0,.75],89:[0,.68333,.025,0,.75],90:[0,.68333,0,0,.61111],91:[.25,.75,0,0,.27778],92:[.25,.75,0,0,.5],93:[.25,.75,0,0,.27778],94:[0,.69444,0,0,.5],95:[.31,.12056,.02778,0,.5],97:[0,.43056,0,0,.5],98:[0,.69444,0,0,.55556],99:[0,.43056,0,0,.44445],100:[0,.69444,0,0,.55556],101:[0,.43056,0,0,.44445],102:[0,.69444,.07778,0,.30556],103:[.19444,.43056,.01389,0,.5],104:[0,.69444,0,0,.55556],105:[0,.66786,0,0,.27778],106:[.19444,.66786,0,0,.30556],107:[0,.69444,0,0,.52778],108:[0,.69444,0,0,.27778],109:[0,.43056,0,0,.83334],110:[0,.43056,0,0,.55556],111:[0,.43056,0,0,.5],112:[.19444,.43056,0,0,.55556],113:[.19444,.43056,0,0,.52778],114:[0,.43056,0,0,.39167],115:[0,.43056,0,0,.39445],116:[0,.61508,0,0,.38889],117:[0,.43056,0,0,.55556],118:[0,.43056,.01389,0,.52778],119:[0,.43056,.01389,0,.72222],120:[0,.43056,0,0,.52778],121:[.19444,.43056,.01389,0,.52778],122:[0,.43056,0,0,.44445],123:[.25,.75,0,0,.5],124:[.25,.75,0,0,.27778],125:[.25,.75,0,0,.5],126:[.35,.31786,0,0,.5],160:[0,0,0,0,.25],163:[0,.69444,0,0,.76909],167:[.19444,.69444,0,0,.44445],168:[0,.66786,0,0,.5],172:[0,.43056,0,0,.66667],176:[0,.69444,0,0,.75],177:[.08333,.58333,0,0,.77778],182:[.19444,.69444,0,0,.61111],184:[.17014,0,0,0,.44445],198:[0,.68333,0,0,.90278],215:[.08333,.58333,0,0,.77778],216:[.04861,.73194,0,0,.77778],223:[0,.69444,0,0,.5],230:[0,.43056,0,0,.72222],247:[.08333,.58333,0,0,.77778],248:[.09722,.52778,0,0,.5],305:[0,.43056,0,0,.27778],338:[0,.68333,0,0,1.01389],339:[0,.43056,0,0,.77778],567:[.19444,.43056,0,0,.30556],710:[0,.69444,0,0,.5],711:[0,.62847,0,0,.5],713:[0,.56778,0,0,.5],714:[0,.69444,0,0,.5],715:[0,.69444,0,0,.5],728:[0,.69444,0,0,.5],729:[0,.66786,0,0,.27778],730:[0,.69444,0,0,.75],732:[0,.66786,0,0,.5],733:[0,.69444,0,0,.5],915:[0,.68333,0,0,.625],916:[0,.68333,0,0,.83334],920:[0,.68333,0,0,.77778],923:[0,.68333,0,0,.69445],926:[0,.68333,0,0,.66667],928:[0,.68333,0,0,.75],931:[0,.68333,0,0,.72222],933:[0,.68333,0,0,.77778],934:[0,.68333,0,0,.72222],936:[0,.68333,0,0,.77778],937:[0,.68333,0,0,.72222],8211:[0,.43056,.02778,0,.5],8212:[0,.43056,.02778,0,1],8216:[0,.69444,0,0,.27778],8217:[0,.69444,0,0,.27778],8220:[0,.69444,0,0,.5],8221:[0,.69444,0,0,.5],8224:[.19444,.69444,0,0,.44445],8225:[.19444,.69444,0,0,.44445],8230:[0,.123,0,0,1.172],8242:[0,.55556,0,0,.275],8407:[0,.71444,.15382,0,.5],8463:[0,.68889,0,0,.54028],8465:[0,.69444,0,0,.72222],8467:[0,.69444,0,.11111,.41667],8472:[.19444,.43056,0,.11111,.63646],8476:[0,.69444,0,0,.72222],8501:[0,.69444,0,0,.61111],8592:[-.13313,.36687,0,0,1],8593:[.19444,.69444,0,0,.5],8594:[-.13313,.36687,0,0,1],8595:[.19444,.69444,0,0,.5],8596:[-.13313,.36687,0,0,1],8597:[.25,.75,0,0,.5],8598:[.19444,.69444,0,0,1],8599:[.19444,.69444,0,0,1],8600:[.19444,.69444,0,0,1],8601:[.19444,.69444,0,0,1],8614:[.011,.511,0,0,1],8617:[.011,.511,0,0,1.126],8618:[.011,.511,0,0,1.126],8636:[-.13313,.36687,0,0,1],8637:[-.13313,.36687,0,0,1],8640:[-.13313,.36687,0,0,1],8641:[-.13313,.36687,0,0,1],8652:[.011,.671,0,0,1],8656:[-.13313,.36687,0,0,1],8657:[.19444,.69444,0,0,.61111],8658:[-.13313,.36687,0,0,1],8659:[.19444,.69444,0,0,.61111],8660:[-.13313,.36687,0,0,1],8661:[.25,.75,0,0,.61111],8704:[0,.69444,0,0,.55556],8706:[0,.69444,.05556,.08334,.5309],8707:[0,.69444,0,0,.55556],8709:[.05556,.75,0,0,.5],8711:[0,.68333,0,0,.83334],8712:[.0391,.5391,0,0,.66667],8715:[.0391,.5391,0,0,.66667],8722:[.08333,.58333,0,0,.77778],8723:[.08333,.58333,0,0,.77778],8725:[.25,.75,0,0,.5],8726:[.25,.75,0,0,.5],8727:[-.03472,.46528,0,0,.5],8728:[-.05555,.44445,0,0,.5],8729:[-.05555,.44445,0,0,.5],8730:[.2,.8,0,0,.83334],8733:[0,.43056,0,0,.77778],8734:[0,.43056,0,0,1],8736:[0,.69224,0,0,.72222],8739:[.25,.75,0,0,.27778],8741:[.25,.75,0,0,.5],8743:[0,.55556,0,0,.66667],8744:[0,.55556,0,0,.66667],8745:[0,.55556,0,0,.66667],8746:[0,.55556,0,0,.66667],8747:[.19444,.69444,.11111,0,.41667],8764:[-.13313,.36687,0,0,.77778],8768:[.19444,.69444,0,0,.27778],8771:[-.03625,.46375,0,0,.77778],8773:[-.022,.589,0,0,.778],8776:[-.01688,.48312,0,0,.77778],8781:[-.03625,.46375,0,0,.77778],8784:[-.133,.673,0,0,.778],8801:[-.03625,.46375,0,0,.77778],8804:[.13597,.63597,0,0,.77778],8805:[.13597,.63597,0,0,.77778],8810:[.0391,.5391,0,0,1],8811:[.0391,.5391,0,0,1],8826:[.0391,.5391,0,0,.77778],8827:[.0391,.5391,0,0,.77778],8834:[.0391,.5391,0,0,.77778],8835:[.0391,.5391,0,0,.77778],8838:[.13597,.63597,0,0,.77778],8839:[.13597,.63597,0,0,.77778],8846:[0,.55556,0,0,.66667],8849:[.13597,.63597,0,0,.77778],8850:[.13597,.63597,0,0,.77778],8851:[0,.55556,0,0,.66667],8852:[0,.55556,0,0,.66667],8853:[.08333,.58333,0,0,.77778],8854:[.08333,.58333,0,0,.77778],8855:[.08333,.58333,0,0,.77778],8856:[.08333,.58333,0,0,.77778],8857:[.08333,.58333,0,0,.77778],8866:[0,.69444,0,0,.61111],8867:[0,.69444,0,0,.61111],8868:[0,.69444,0,0,.77778],8869:[0,.69444,0,0,.77778],8872:[.249,.75,0,0,.867],8900:[-.05555,.44445,0,0,.5],8901:[-.05555,.44445,0,0,.27778],8902:[-.03472,.46528,0,0,.5],8904:[.005,.505,0,0,.9],8942:[.03,.903,0,0,.278],8943:[-.19,.313,0,0,1.172],8945:[-.1,.823,0,0,1.282],8968:[.25,.75,0,0,.44445],8969:[.25,.75,0,0,.44445],8970:[.25,.75,0,0,.44445],8971:[.25,.75,0,0,.44445],8994:[-.14236,.35764,0,0,1],8995:[-.14236,.35764,0,0,1],9136:[.244,.744,0,0,.412],9137:[.244,.745,0,0,.412],9651:[.19444,.69444,0,0,.88889],9657:[-.03472,.46528,0,0,.5],9661:[.19444,.69444,0,0,.88889],9667:[-.03472,.46528,0,0,.5],9711:[.19444,.69444,0,0,1],9824:[.12963,.69444,0,0,.77778],9825:[.12963,.69444,0,0,.77778],9826:[.12963,.69444,0,0,.77778],9827:[.12963,.69444,0,0,.77778],9837:[0,.75,0,0,.38889],9838:[.19444,.69444,0,0,.38889],9839:[.19444,.69444,0,0,.38889],10216:[.25,.75,0,0,.38889],10217:[.25,.75,0,0,.38889],10222:[.244,.744,0,0,.412],10223:[.244,.745,0,0,.412],10229:[.011,.511,0,0,1.609],10230:[.011,.511,0,0,1.638],10231:[.011,.511,0,0,1.859],10232:[.024,.525,0,0,1.609],10233:[.024,.525,0,0,1.638],10234:[.024,.525,0,0,1.858],10236:[.011,.511,0,0,1.638],10815:[0,.68333,0,0,.75],10927:[.13597,.63597,0,0,.77778],10928:[.13597,.63597,0,0,.77778],57376:[.19444,.69444,0,0,0]},"Math-BoldItalic":{32:[0,0,0,0,.25],48:[0,.44444,0,0,.575],49:[0,.44444,0,0,.575],50:[0,.44444,0,0,.575],51:[.19444,.44444,0,0,.575],52:[.19444,.44444,0,0,.575],53:[.19444,.44444,0,0,.575],54:[0,.64444,0,0,.575],55:[.19444,.44444,0,0,.575],56:[0,.64444,0,0,.575],57:[.19444,.44444,0,0,.575],65:[0,.68611,0,0,.86944],66:[0,.68611,.04835,0,.8664],67:[0,.68611,.06979,0,.81694],68:[0,.68611,.03194,0,.93812],69:[0,.68611,.05451,0,.81007],70:[0,.68611,.15972,0,.68889],71:[0,.68611,0,0,.88673],72:[0,.68611,.08229,0,.98229],73:[0,.68611,.07778,0,.51111],74:[0,.68611,.10069,0,.63125],75:[0,.68611,.06979,0,.97118],76:[0,.68611,0,0,.75555],77:[0,.68611,.11424,0,1.14201],78:[0,.68611,.11424,0,.95034],79:[0,.68611,.03194,0,.83666],80:[0,.68611,.15972,0,.72309],81:[.19444,.68611,0,0,.86861],82:[0,.68611,.00421,0,.87235],83:[0,.68611,.05382,0,.69271],84:[0,.68611,.15972,0,.63663],85:[0,.68611,.11424,0,.80027],86:[0,.68611,.25555,0,.67778],87:[0,.68611,.15972,0,1.09305],88:[0,.68611,.07778,0,.94722],89:[0,.68611,.25555,0,.67458],90:[0,.68611,.06979,0,.77257],97:[0,.44444,0,0,.63287],98:[0,.69444,0,0,.52083],99:[0,.44444,0,0,.51342],100:[0,.69444,0,0,.60972],101:[0,.44444,0,0,.55361],102:[.19444,.69444,.11042,0,.56806],103:[.19444,.44444,.03704,0,.5449],104:[0,.69444,0,0,.66759],105:[0,.69326,0,0,.4048],106:[.19444,.69326,.0622,0,.47083],107:[0,.69444,.01852,0,.6037],108:[0,.69444,.0088,0,.34815],109:[0,.44444,0,0,1.0324],110:[0,.44444,0,0,.71296],111:[0,.44444,0,0,.58472],112:[.19444,.44444,0,0,.60092],113:[.19444,.44444,.03704,0,.54213],114:[0,.44444,.03194,0,.5287],115:[0,.44444,0,0,.53125],116:[0,.63492,0,0,.41528],117:[0,.44444,0,0,.68102],118:[0,.44444,.03704,0,.56666],119:[0,.44444,.02778,0,.83148],120:[0,.44444,0,0,.65903],121:[.19444,.44444,.03704,0,.59028],122:[0,.44444,.04213,0,.55509],160:[0,0,0,0,.25],915:[0,.68611,.15972,0,.65694],916:[0,.68611,0,0,.95833],920:[0,.68611,.03194,0,.86722],923:[0,.68611,0,0,.80555],926:[0,.68611,.07458,0,.84125],928:[0,.68611,.08229,0,.98229],931:[0,.68611,.05451,0,.88507],933:[0,.68611,.15972,0,.67083],934:[0,.68611,0,0,.76666],936:[0,.68611,.11653,0,.71402],937:[0,.68611,.04835,0,.8789],945:[0,.44444,0,0,.76064],946:[.19444,.69444,.03403,0,.65972],947:[.19444,.44444,.06389,0,.59003],948:[0,.69444,.03819,0,.52222],949:[0,.44444,0,0,.52882],950:[.19444,.69444,.06215,0,.50833],951:[.19444,.44444,.03704,0,.6],952:[0,.69444,.03194,0,.5618],953:[0,.44444,0,0,.41204],954:[0,.44444,0,0,.66759],955:[0,.69444,0,0,.67083],956:[.19444,.44444,0,0,.70787],957:[0,.44444,.06898,0,.57685],958:[.19444,.69444,.03021,0,.50833],959:[0,.44444,0,0,.58472],960:[0,.44444,.03704,0,.68241],961:[.19444,.44444,0,0,.6118],962:[.09722,.44444,.07917,0,.42361],963:[0,.44444,.03704,0,.68588],964:[0,.44444,.13472,0,.52083],965:[0,.44444,.03704,0,.63055],966:[.19444,.44444,0,0,.74722],967:[.19444,.44444,0,0,.71805],968:[.19444,.69444,.03704,0,.75833],969:[0,.44444,.03704,0,.71782],977:[0,.69444,0,0,.69155],981:[.19444,.69444,0,0,.7125],982:[0,.44444,.03194,0,.975],1009:[.19444,.44444,0,0,.6118],1013:[0,.44444,0,0,.48333],57649:[0,.44444,0,0,.39352],57911:[.19444,.44444,0,0,.43889]},"Math-Italic":{32:[0,0,0,0,.25],48:[0,.43056,0,0,.5],49:[0,.43056,0,0,.5],50:[0,.43056,0,0,.5],51:[.19444,.43056,0,0,.5],52:[.19444,.43056,0,0,.5],53:[.19444,.43056,0,0,.5],54:[0,.64444,0,0,.5],55:[.19444,.43056,0,0,.5],56:[0,.64444,0,0,.5],57:[.19444,.43056,0,0,.5],65:[0,.68333,0,.13889,.75],66:[0,.68333,.05017,.08334,.75851],67:[0,.68333,.07153,.08334,.71472],68:[0,.68333,.02778,.05556,.82792],69:[0,.68333,.05764,.08334,.7382],70:[0,.68333,.13889,.08334,.64306],71:[0,.68333,0,.08334,.78625],72:[0,.68333,.08125,.05556,.83125],73:[0,.68333,.07847,.11111,.43958],74:[0,.68333,.09618,.16667,.55451],75:[0,.68333,.07153,.05556,.84931],76:[0,.68333,0,.02778,.68056],77:[0,.68333,.10903,.08334,.97014],78:[0,.68333,.10903,.08334,.80347],79:[0,.68333,.02778,.08334,.76278],80:[0,.68333,.13889,.08334,.64201],81:[.19444,.68333,0,.08334,.79056],82:[0,.68333,.00773,.08334,.75929],83:[0,.68333,.05764,.08334,.6132],84:[0,.68333,.13889,.08334,.58438],85:[0,.68333,.10903,.02778,.68278],86:[0,.68333,.22222,0,.58333],87:[0,.68333,.13889,0,.94445],88:[0,.68333,.07847,.08334,.82847],89:[0,.68333,.22222,0,.58056],90:[0,.68333,.07153,.08334,.68264],97:[0,.43056,0,0,.52859],98:[0,.69444,0,0,.42917],99:[0,.43056,0,.05556,.43276],100:[0,.69444,0,.16667,.52049],101:[0,.43056,0,.05556,.46563],102:[.19444,.69444,.10764,.16667,.48959],103:[.19444,.43056,.03588,.02778,.47697],104:[0,.69444,0,0,.57616],105:[0,.65952,0,0,.34451],106:[.19444,.65952,.05724,0,.41181],107:[0,.69444,.03148,0,.5206],108:[0,.69444,.01968,.08334,.29838],109:[0,.43056,0,0,.87801],110:[0,.43056,0,0,.60023],111:[0,.43056,0,.05556,.48472],112:[.19444,.43056,0,.08334,.50313],113:[.19444,.43056,.03588,.08334,.44641],114:[0,.43056,.02778,.05556,.45116],115:[0,.43056,0,.05556,.46875],116:[0,.61508,0,.08334,.36111],117:[0,.43056,0,.02778,.57246],118:[0,.43056,.03588,.02778,.48472],119:[0,.43056,.02691,.08334,.71592],120:[0,.43056,0,.02778,.57153],121:[.19444,.43056,.03588,.05556,.49028],122:[0,.43056,.04398,.05556,.46505],160:[0,0,0,0,.25],915:[0,.68333,.13889,.08334,.61528],916:[0,.68333,0,.16667,.83334],920:[0,.68333,.02778,.08334,.76278],923:[0,.68333,0,.16667,.69445],926:[0,.68333,.07569,.08334,.74236],928:[0,.68333,.08125,.05556,.83125],931:[0,.68333,.05764,.08334,.77986],933:[0,.68333,.13889,.05556,.58333],934:[0,.68333,0,.08334,.66667],936:[0,.68333,.11,.05556,.61222],937:[0,.68333,.05017,.08334,.7724],945:[0,.43056,.0037,.02778,.6397],946:[.19444,.69444,.05278,.08334,.56563],947:[.19444,.43056,.05556,0,.51773],948:[0,.69444,.03785,.05556,.44444],949:[0,.43056,0,.08334,.46632],950:[.19444,.69444,.07378,.08334,.4375],951:[.19444,.43056,.03588,.05556,.49653],952:[0,.69444,.02778,.08334,.46944],953:[0,.43056,0,.05556,.35394],954:[0,.43056,0,0,.57616],955:[0,.69444,0,0,.58334],956:[.19444,.43056,0,.02778,.60255],957:[0,.43056,.06366,.02778,.49398],958:[.19444,.69444,.04601,.11111,.4375],959:[0,.43056,0,.05556,.48472],960:[0,.43056,.03588,0,.57003],961:[.19444,.43056,0,.08334,.51702],962:[.09722,.43056,.07986,.08334,.36285],963:[0,.43056,.03588,0,.57141],964:[0,.43056,.1132,.02778,.43715],965:[0,.43056,.03588,.02778,.54028],966:[.19444,.43056,0,.08334,.65417],967:[.19444,.43056,0,.05556,.62569],968:[.19444,.69444,.03588,.11111,.65139],969:[0,.43056,.03588,0,.62245],977:[0,.69444,0,.08334,.59144],981:[.19444,.69444,0,.08334,.59583],982:[0,.43056,.02778,0,.82813],1009:[.19444,.43056,0,.08334,.51702],1013:[0,.43056,0,.05556,.4059],57649:[0,.43056,0,.02778,.32246],57911:[.19444,.43056,0,.08334,.38403]},"SansSerif-Bold":{32:[0,0,0,0,.25],33:[0,.69444,0,0,.36667],34:[0,.69444,0,0,.55834],35:[.19444,.69444,0,0,.91667],36:[.05556,.75,0,0,.55],37:[.05556,.75,0,0,1.02912],38:[0,.69444,0,0,.83056],39:[0,.69444,0,0,.30556],40:[.25,.75,0,0,.42778],41:[.25,.75,0,0,.42778],42:[0,.75,0,0,.55],43:[.11667,.61667,0,0,.85556],44:[.10556,.13056,0,0,.30556],45:[0,.45833,0,0,.36667],46:[0,.13056,0,0,.30556],47:[.25,.75,0,0,.55],48:[0,.69444,0,0,.55],49:[0,.69444,0,0,.55],50:[0,.69444,0,0,.55],51:[0,.69444,0,0,.55],52:[0,.69444,0,0,.55],53:[0,.69444,0,0,.55],54:[0,.69444,0,0,.55],55:[0,.69444,0,0,.55],56:[0,.69444,0,0,.55],57:[0,.69444,0,0,.55],58:[0,.45833,0,0,.30556],59:[.10556,.45833,0,0,.30556],61:[-.09375,.40625,0,0,.85556],63:[0,.69444,0,0,.51945],64:[0,.69444,0,0,.73334],65:[0,.69444,0,0,.73334],66:[0,.69444,0,0,.73334],67:[0,.69444,0,0,.70278],68:[0,.69444,0,0,.79445],69:[0,.69444,0,0,.64167],70:[0,.69444,0,0,.61111],71:[0,.69444,0,0,.73334],72:[0,.69444,0,0,.79445],73:[0,.69444,0,0,.33056],74:[0,.69444,0,0,.51945],75:[0,.69444,0,0,.76389],76:[0,.69444,0,0,.58056],77:[0,.69444,0,0,.97778],78:[0,.69444,0,0,.79445],79:[0,.69444,0,0,.79445],80:[0,.69444,0,0,.70278],81:[.10556,.69444,0,0,.79445],82:[0,.69444,0,0,.70278],83:[0,.69444,0,0,.61111],84:[0,.69444,0,0,.73334],85:[0,.69444,0,0,.76389],86:[0,.69444,.01528,0,.73334],87:[0,.69444,.01528,0,1.03889],88:[0,.69444,0,0,.73334],89:[0,.69444,.0275,0,.73334],90:[0,.69444,0,0,.67223],91:[.25,.75,0,0,.34306],93:[.25,.75,0,0,.34306],94:[0,.69444,0,0,.55],95:[.35,.10833,.03056,0,.55],97:[0,.45833,0,0,.525],98:[0,.69444,0,0,.56111],99:[0,.45833,0,0,.48889],100:[0,.69444,0,0,.56111],101:[0,.45833,0,0,.51111],102:[0,.69444,.07639,0,.33611],103:[.19444,.45833,.01528,0,.55],104:[0,.69444,0,0,.56111],105:[0,.69444,0,0,.25556],106:[.19444,.69444,0,0,.28611],107:[0,.69444,0,0,.53056],108:[0,.69444,0,0,.25556],109:[0,.45833,0,0,.86667],110:[0,.45833,0,0,.56111],111:[0,.45833,0,0,.55],112:[.19444,.45833,0,0,.56111],113:[.19444,.45833,0,0,.56111],114:[0,.45833,.01528,0,.37222],115:[0,.45833,0,0,.42167],116:[0,.58929,0,0,.40417],117:[0,.45833,0,0,.56111],118:[0,.45833,.01528,0,.5],119:[0,.45833,.01528,0,.74445],120:[0,.45833,0,0,.5],121:[.19444,.45833,.01528,0,.5],122:[0,.45833,0,0,.47639],126:[.35,.34444,0,0,.55],160:[0,0,0,0,.25],168:[0,.69444,0,0,.55],176:[0,.69444,0,0,.73334],180:[0,.69444,0,0,.55],184:[.17014,0,0,0,.48889],305:[0,.45833,0,0,.25556],567:[.19444,.45833,0,0,.28611],710:[0,.69444,0,0,.55],711:[0,.63542,0,0,.55],713:[0,.63778,0,0,.55],728:[0,.69444,0,0,.55],729:[0,.69444,0,0,.30556],730:[0,.69444,0,0,.73334],732:[0,.69444,0,0,.55],733:[0,.69444,0,0,.55],915:[0,.69444,0,0,.58056],916:[0,.69444,0,0,.91667],920:[0,.69444,0,0,.85556],923:[0,.69444,0,0,.67223],926:[0,.69444,0,0,.73334],928:[0,.69444,0,0,.79445],931:[0,.69444,0,0,.79445],933:[0,.69444,0,0,.85556],934:[0,.69444,0,0,.79445],936:[0,.69444,0,0,.85556],937:[0,.69444,0,0,.79445],8211:[0,.45833,.03056,0,.55],8212:[0,.45833,.03056,0,1.10001],8216:[0,.69444,0,0,.30556],8217:[0,.69444,0,0,.30556],8220:[0,.69444,0,0,.55834],8221:[0,.69444,0,0,.55834]},"SansSerif-Italic":{32:[0,0,0,0,.25],33:[0,.69444,.05733,0,.31945],34:[0,.69444,.00316,0,.5],35:[.19444,.69444,.05087,0,.83334],36:[.05556,.75,.11156,0,.5],37:[.05556,.75,.03126,0,.83334],38:[0,.69444,.03058,0,.75834],39:[0,.69444,.07816,0,.27778],40:[.25,.75,.13164,0,.38889],41:[.25,.75,.02536,0,.38889],42:[0,.75,.11775,0,.5],43:[.08333,.58333,.02536,0,.77778],44:[.125,.08333,0,0,.27778],45:[0,.44444,.01946,0,.33333],46:[0,.08333,0,0,.27778],47:[.25,.75,.13164,0,.5],48:[0,.65556,.11156,0,.5],49:[0,.65556,.11156,0,.5],50:[0,.65556,.11156,0,.5],51:[0,.65556,.11156,0,.5],52:[0,.65556,.11156,0,.5],53:[0,.65556,.11156,0,.5],54:[0,.65556,.11156,0,.5],55:[0,.65556,.11156,0,.5],56:[0,.65556,.11156,0,.5],57:[0,.65556,.11156,0,.5],58:[0,.44444,.02502,0,.27778],59:[.125,.44444,.02502,0,.27778],61:[-.13,.37,.05087,0,.77778],63:[0,.69444,.11809,0,.47222],64:[0,.69444,.07555,0,.66667],65:[0,.69444,0,0,.66667],66:[0,.69444,.08293,0,.66667],67:[0,.69444,.11983,0,.63889],68:[0,.69444,.07555,0,.72223],69:[0,.69444,.11983,0,.59722],70:[0,.69444,.13372,0,.56945],71:[0,.69444,.11983,0,.66667],72:[0,.69444,.08094,0,.70834],73:[0,.69444,.13372,0,.27778],74:[0,.69444,.08094,0,.47222],75:[0,.69444,.11983,0,.69445],76:[0,.69444,0,0,.54167],77:[0,.69444,.08094,0,.875],78:[0,.69444,.08094,0,.70834],79:[0,.69444,.07555,0,.73611],80:[0,.69444,.08293,0,.63889],81:[.125,.69444,.07555,0,.73611],82:[0,.69444,.08293,0,.64584],83:[0,.69444,.09205,0,.55556],84:[0,.69444,.13372,0,.68056],85:[0,.69444,.08094,0,.6875],86:[0,.69444,.1615,0,.66667],87:[0,.69444,.1615,0,.94445],88:[0,.69444,.13372,0,.66667],89:[0,.69444,.17261,0,.66667],90:[0,.69444,.11983,0,.61111],91:[.25,.75,.15942,0,.28889],93:[.25,.75,.08719,0,.28889],94:[0,.69444,.0799,0,.5],95:[.35,.09444,.08616,0,.5],97:[0,.44444,.00981,0,.48056],98:[0,.69444,.03057,0,.51667],99:[0,.44444,.08336,0,.44445],100:[0,.69444,.09483,0,.51667],101:[0,.44444,.06778,0,.44445],102:[0,.69444,.21705,0,.30556],103:[.19444,.44444,.10836,0,.5],104:[0,.69444,.01778,0,.51667],105:[0,.67937,.09718,0,.23889],106:[.19444,.67937,.09162,0,.26667],107:[0,.69444,.08336,0,.48889],108:[0,.69444,.09483,0,.23889],109:[0,.44444,.01778,0,.79445],110:[0,.44444,.01778,0,.51667],111:[0,.44444,.06613,0,.5],112:[.19444,.44444,.0389,0,.51667],113:[.19444,.44444,.04169,0,.51667],114:[0,.44444,.10836,0,.34167],115:[0,.44444,.0778,0,.38333],116:[0,.57143,.07225,0,.36111],117:[0,.44444,.04169,0,.51667],118:[0,.44444,.10836,0,.46111],119:[0,.44444,.10836,0,.68334],120:[0,.44444,.09169,0,.46111],121:[.19444,.44444,.10836,0,.46111],122:[0,.44444,.08752,0,.43472],126:[.35,.32659,.08826,0,.5],160:[0,0,0,0,.25],168:[0,.67937,.06385,0,.5],176:[0,.69444,0,0,.73752],184:[.17014,0,0,0,.44445],305:[0,.44444,.04169,0,.23889],567:[.19444,.44444,.04169,0,.26667],710:[0,.69444,.0799,0,.5],711:[0,.63194,.08432,0,.5],713:[0,.60889,.08776,0,.5],714:[0,.69444,.09205,0,.5],715:[0,.69444,0,0,.5],728:[0,.69444,.09483,0,.5],729:[0,.67937,.07774,0,.27778],730:[0,.69444,0,0,.73752],732:[0,.67659,.08826,0,.5],733:[0,.69444,.09205,0,.5],915:[0,.69444,.13372,0,.54167],916:[0,.69444,0,0,.83334],920:[0,.69444,.07555,0,.77778],923:[0,.69444,0,0,.61111],926:[0,.69444,.12816,0,.66667],928:[0,.69444,.08094,0,.70834],931:[0,.69444,.11983,0,.72222],933:[0,.69444,.09031,0,.77778],934:[0,.69444,.04603,0,.72222],936:[0,.69444,.09031,0,.77778],937:[0,.69444,.08293,0,.72222],8211:[0,.44444,.08616,0,.5],8212:[0,.44444,.08616,0,1],8216:[0,.69444,.07816,0,.27778],8217:[0,.69444,.07816,0,.27778],8220:[0,.69444,.14205,0,.5],8221:[0,.69444,.00316,0,.5]},"SansSerif-Regular":{32:[0,0,0,0,.25],33:[0,.69444,0,0,.31945],34:[0,.69444,0,0,.5],35:[.19444,.69444,0,0,.83334],36:[.05556,.75,0,0,.5],37:[.05556,.75,0,0,.83334],38:[0,.69444,0,0,.75834],39:[0,.69444,0,0,.27778],40:[.25,.75,0,0,.38889],41:[.25,.75,0,0,.38889],42:[0,.75,0,0,.5],43:[.08333,.58333,0,0,.77778],44:[.125,.08333,0,0,.27778],45:[0,.44444,0,0,.33333],46:[0,.08333,0,0,.27778],47:[.25,.75,0,0,.5],48:[0,.65556,0,0,.5],49:[0,.65556,0,0,.5],50:[0,.65556,0,0,.5],51:[0,.65556,0,0,.5],52:[0,.65556,0,0,.5],53:[0,.65556,0,0,.5],54:[0,.65556,0,0,.5],55:[0,.65556,0,0,.5],56:[0,.65556,0,0,.5],57:[0,.65556,0,0,.5],58:[0,.44444,0,0,.27778],59:[.125,.44444,0,0,.27778],61:[-.13,.37,0,0,.77778],63:[0,.69444,0,0,.47222],64:[0,.69444,0,0,.66667],65:[0,.69444,0,0,.66667],66:[0,.69444,0,0,.66667],67:[0,.69444,0,0,.63889],68:[0,.69444,0,0,.72223],69:[0,.69444,0,0,.59722],70:[0,.69444,0,0,.56945],71:[0,.69444,0,0,.66667],72:[0,.69444,0,0,.70834],73:[0,.69444,0,0,.27778],74:[0,.69444,0,0,.47222],75:[0,.69444,0,0,.69445],76:[0,.69444,0,0,.54167],77:[0,.69444,0,0,.875],78:[0,.69444,0,0,.70834],79:[0,.69444,0,0,.73611],80:[0,.69444,0,0,.63889],81:[.125,.69444,0,0,.73611],82:[0,.69444,0,0,.64584],83:[0,.69444,0,0,.55556],84:[0,.69444,0,0,.68056],85:[0,.69444,0,0,.6875],86:[0,.69444,.01389,0,.66667],87:[0,.69444,.01389,0,.94445],88:[0,.69444,0,0,.66667],89:[0,.69444,.025,0,.66667],90:[0,.69444,0,0,.61111],91:[.25,.75,0,0,.28889],93:[.25,.75,0,0,.28889],94:[0,.69444,0,0,.5],95:[.35,.09444,.02778,0,.5],97:[0,.44444,0,0,.48056],98:[0,.69444,0,0,.51667],99:[0,.44444,0,0,.44445],100:[0,.69444,0,0,.51667],101:[0,.44444,0,0,.44445],102:[0,.69444,.06944,0,.30556],103:[.19444,.44444,.01389,0,.5],104:[0,.69444,0,0,.51667],105:[0,.67937,0,0,.23889],106:[.19444,.67937,0,0,.26667],107:[0,.69444,0,0,.48889],108:[0,.69444,0,0,.23889],109:[0,.44444,0,0,.79445],110:[0,.44444,0,0,.51667],111:[0,.44444,0,0,.5],112:[.19444,.44444,0,0,.51667],113:[.19444,.44444,0,0,.51667],114:[0,.44444,.01389,0,.34167],115:[0,.44444,0,0,.38333],116:[0,.57143,0,0,.36111],117:[0,.44444,0,0,.51667],118:[0,.44444,.01389,0,.46111],119:[0,.44444,.01389,0,.68334],120:[0,.44444,0,0,.46111],121:[.19444,.44444,.01389,0,.46111],122:[0,.44444,0,0,.43472],126:[.35,.32659,0,0,.5],160:[0,0,0,0,.25],168:[0,.67937,0,0,.5],176:[0,.69444,0,0,.66667],184:[.17014,0,0,0,.44445],305:[0,.44444,0,0,.23889],567:[.19444,.44444,0,0,.26667],710:[0,.69444,0,0,.5],711:[0,.63194,0,0,.5],713:[0,.60889,0,0,.5],714:[0,.69444,0,0,.5],715:[0,.69444,0,0,.5],728:[0,.69444,0,0,.5],729:[0,.67937,0,0,.27778],730:[0,.69444,0,0,.66667],732:[0,.67659,0,0,.5],733:[0,.69444,0,0,.5],915:[0,.69444,0,0,.54167],916:[0,.69444,0,0,.83334],920:[0,.69444,0,0,.77778],923:[0,.69444,0,0,.61111],926:[0,.69444,0,0,.66667],928:[0,.69444,0,0,.70834],931:[0,.69444,0,0,.72222],933:[0,.69444,0,0,.77778],934:[0,.69444,0,0,.72222],936:[0,.69444,0,0,.77778],937:[0,.69444,0,0,.72222],8211:[0,.44444,.02778,0,.5],8212:[0,.44444,.02778,0,1],8216:[0,.69444,0,0,.27778],8217:[0,.69444,0,0,.27778],8220:[0,.69444,0,0,.5],8221:[0,.69444,0,0,.5]},"Script-Regular":{32:[0,0,0,0,.25],65:[0,.7,.22925,0,.80253],66:[0,.7,.04087,0,.90757],67:[0,.7,.1689,0,.66619],68:[0,.7,.09371,0,.77443],69:[0,.7,.18583,0,.56162],70:[0,.7,.13634,0,.89544],71:[0,.7,.17322,0,.60961],72:[0,.7,.29694,0,.96919],73:[0,.7,.19189,0,.80907],74:[.27778,.7,.19189,0,1.05159],75:[0,.7,.31259,0,.91364],76:[0,.7,.19189,0,.87373],77:[0,.7,.15981,0,1.08031],78:[0,.7,.3525,0,.9015],79:[0,.7,.08078,0,.73787],80:[0,.7,.08078,0,1.01262],81:[0,.7,.03305,0,.88282],82:[0,.7,.06259,0,.85],83:[0,.7,.19189,0,.86767],84:[0,.7,.29087,0,.74697],85:[0,.7,.25815,0,.79996],86:[0,.7,.27523,0,.62204],87:[0,.7,.27523,0,.80532],88:[0,.7,.26006,0,.94445],89:[0,.7,.2939,0,.70961],90:[0,.7,.24037,0,.8212],160:[0,0,0,0,.25]},"Size1-Regular":{32:[0,0,0,0,.25],40:[.35001,.85,0,0,.45834],41:[.35001,.85,0,0,.45834],47:[.35001,.85,0,0,.57778],91:[.35001,.85,0,0,.41667],92:[.35001,.85,0,0,.57778],93:[.35001,.85,0,0,.41667],123:[.35001,.85,0,0,.58334],125:[.35001,.85,0,0,.58334],160:[0,0,0,0,.25],710:[0,.72222,0,0,.55556],732:[0,.72222,0,0,.55556],770:[0,.72222,0,0,.55556],771:[0,.72222,0,0,.55556],8214:[-99e-5,.601,0,0,.77778],8593:[1e-5,.6,0,0,.66667],8595:[1e-5,.6,0,0,.66667],8657:[1e-5,.6,0,0,.77778],8659:[1e-5,.6,0,0,.77778],8719:[.25001,.75,0,0,.94445],8720:[.25001,.75,0,0,.94445],8721:[.25001,.75,0,0,1.05556],8730:[.35001,.85,0,0,1],8739:[-.00599,.606,0,0,.33333],8741:[-.00599,.606,0,0,.55556],8747:[.30612,.805,.19445,0,.47222],8748:[.306,.805,.19445,0,.47222],8749:[.306,.805,.19445,0,.47222],8750:[.30612,.805,.19445,0,.47222],8896:[.25001,.75,0,0,.83334],8897:[.25001,.75,0,0,.83334],8898:[.25001,.75,0,0,.83334],8899:[.25001,.75,0,0,.83334],8968:[.35001,.85,0,0,.47222],8969:[.35001,.85,0,0,.47222],8970:[.35001,.85,0,0,.47222],8971:[.35001,.85,0,0,.47222],9168:[-99e-5,.601,0,0,.66667],10216:[.35001,.85,0,0,.47222],10217:[.35001,.85,0,0,.47222],10752:[.25001,.75,0,0,1.11111],10753:[.25001,.75,0,0,1.11111],10754:[.25001,.75,0,0,1.11111],10756:[.25001,.75,0,0,.83334],10758:[.25001,.75,0,0,.83334]},"Size2-Regular":{32:[0,0,0,0,.25],40:[.65002,1.15,0,0,.59722],41:[.65002,1.15,0,0,.59722],47:[.65002,1.15,0,0,.81111],91:[.65002,1.15,0,0,.47222],92:[.65002,1.15,0,0,.81111],93:[.65002,1.15,0,0,.47222],123:[.65002,1.15,0,0,.66667],125:[.65002,1.15,0,0,.66667],160:[0,0,0,0,.25],710:[0,.75,0,0,1],732:[0,.75,0,0,1],770:[0,.75,0,0,1],771:[0,.75,0,0,1],8719:[.55001,1.05,0,0,1.27778],8720:[.55001,1.05,0,0,1.27778],8721:[.55001,1.05,0,0,1.44445],8730:[.65002,1.15,0,0,1],8747:[.86225,1.36,.44445,0,.55556],8748:[.862,1.36,.44445,0,.55556],8749:[.862,1.36,.44445,0,.55556],8750:[.86225,1.36,.44445,0,.55556],8896:[.55001,1.05,0,0,1.11111],8897:[.55001,1.05,0,0,1.11111],8898:[.55001,1.05,0,0,1.11111],8899:[.55001,1.05,0,0,1.11111],8968:[.65002,1.15,0,0,.52778],8969:[.65002,1.15,0,0,.52778],8970:[.65002,1.15,0,0,.52778],8971:[.65002,1.15,0,0,.52778],10216:[.65002,1.15,0,0,.61111],10217:[.65002,1.15,0,0,.61111],10752:[.55001,1.05,0,0,1.51112],10753:[.55001,1.05,0,0,1.51112],10754:[.55001,1.05,0,0,1.51112],10756:[.55001,1.05,0,0,1.11111],10758:[.55001,1.05,0,0,1.11111]},"Size3-Regular":{32:[0,0,0,0,.25],40:[.95003,1.45,0,0,.73611],41:[.95003,1.45,0,0,.73611],47:[.95003,1.45,0,0,1.04445],91:[.95003,1.45,0,0,.52778],92:[.95003,1.45,0,0,1.04445],93:[.95003,1.45,0,0,.52778],123:[.95003,1.45,0,0,.75],125:[.95003,1.45,0,0,.75],160:[0,0,0,0,.25],710:[0,.75,0,0,1.44445],732:[0,.75,0,0,1.44445],770:[0,.75,0,0,1.44445],771:[0,.75,0,0,1.44445],8730:[.95003,1.45,0,0,1],8968:[.95003,1.45,0,0,.58334],8969:[.95003,1.45,0,0,.58334],8970:[.95003,1.45,0,0,.58334],8971:[.95003,1.45,0,0,.58334],10216:[.95003,1.45,0,0,.75],10217:[.95003,1.45,0,0,.75]},"Size4-Regular":{32:[0,0,0,0,.25],40:[1.25003,1.75,0,0,.79167],41:[1.25003,1.75,0,0,.79167],47:[1.25003,1.75,0,0,1.27778],91:[1.25003,1.75,0,0,.58334],92:[1.25003,1.75,0,0,1.27778],93:[1.25003,1.75,0,0,.58334],123:[1.25003,1.75,0,0,.80556],125:[1.25003,1.75,0,0,.80556],160:[0,0,0,0,.25],710:[0,.825,0,0,1.8889],732:[0,.825,0,0,1.8889],770:[0,.825,0,0,1.8889],771:[0,.825,0,0,1.8889],8730:[1.25003,1.75,0,0,1],8968:[1.25003,1.75,0,0,.63889],8969:[1.25003,1.75,0,0,.63889],8970:[1.25003,1.75,0,0,.63889],8971:[1.25003,1.75,0,0,.63889],9115:[.64502,1.155,0,0,.875],9116:[1e-5,.6,0,0,.875],9117:[.64502,1.155,0,0,.875],9118:[.64502,1.155,0,0,.875],9119:[1e-5,.6,0,0,.875],9120:[.64502,1.155,0,0,.875],9121:[.64502,1.155,0,0,.66667],9122:[-99e-5,.601,0,0,.66667],9123:[.64502,1.155,0,0,.66667],9124:[.64502,1.155,0,0,.66667],9125:[-99e-5,.601,0,0,.66667],9126:[.64502,1.155,0,0,.66667],9127:[1e-5,.9,0,0,.88889],9128:[.65002,1.15,0,0,.88889],9129:[.90001,0,0,0,.88889],9130:[0,.3,0,0,.88889],9131:[1e-5,.9,0,0,.88889],9132:[.65002,1.15,0,0,.88889],9133:[.90001,0,0,0,.88889],9143:[.88502,.915,0,0,1.05556],10216:[1.25003,1.75,0,0,.80556],10217:[1.25003,1.75,0,0,.80556],57344:[-.00499,.605,0,0,1.05556],57345:[-.00499,.605,0,0,1.05556],57680:[0,.12,0,0,.45],57681:[0,.12,0,0,.45],57682:[0,.12,0,0,.45],57683:[0,.12,0,0,.45]},"Typewriter-Regular":{32:[0,0,0,0,.525],33:[0,.61111,0,0,.525],34:[0,.61111,0,0,.525],35:[0,.61111,0,0,.525],36:[.08333,.69444,0,0,.525],37:[.08333,.69444,0,0,.525],38:[0,.61111,0,0,.525],39:[0,.61111,0,0,.525],40:[.08333,.69444,0,0,.525],41:[.08333,.69444,0,0,.525],42:[0,.52083,0,0,.525],43:[-.08056,.53055,0,0,.525],44:[.13889,.125,0,0,.525],45:[-.08056,.53055,0,0,.525],46:[0,.125,0,0,.525],47:[.08333,.69444,0,0,.525],48:[0,.61111,0,0,.525],49:[0,.61111,0,0,.525],50:[0,.61111,0,0,.525],51:[0,.61111,0,0,.525],52:[0,.61111,0,0,.525],53:[0,.61111,0,0,.525],54:[0,.61111,0,0,.525],55:[0,.61111,0,0,.525],56:[0,.61111,0,0,.525],57:[0,.61111,0,0,.525],58:[0,.43056,0,0,.525],59:[.13889,.43056,0,0,.525],60:[-.05556,.55556,0,0,.525],61:[-.19549,.41562,0,0,.525],62:[-.05556,.55556,0,0,.525],63:[0,.61111,0,0,.525],64:[0,.61111,0,0,.525],65:[0,.61111,0,0,.525],66:[0,.61111,0,0,.525],67:[0,.61111,0,0,.525],68:[0,.61111,0,0,.525],69:[0,.61111,0,0,.525],70:[0,.61111,0,0,.525],71:[0,.61111,0,0,.525],72:[0,.61111,0,0,.525],73:[0,.61111,0,0,.525],74:[0,.61111,0,0,.525],75:[0,.61111,0,0,.525],76:[0,.61111,0,0,.525],77:[0,.61111,0,0,.525],78:[0,.61111,0,0,.525],79:[0,.61111,0,0,.525],80:[0,.61111,0,0,.525],81:[.13889,.61111,0,0,.525],82:[0,.61111,0,0,.525],83:[0,.61111,0,0,.525],84:[0,.61111,0,0,.525],85:[0,.61111,0,0,.525],86:[0,.61111,0,0,.525],87:[0,.61111,0,0,.525],88:[0,.61111,0,0,.525],89:[0,.61111,0,0,.525],90:[0,.61111,0,0,.525],91:[.08333,.69444,0,0,.525],92:[.08333,.69444,0,0,.525],93:[.08333,.69444,0,0,.525],94:[0,.61111,0,0,.525],95:[.09514,0,0,0,.525],96:[0,.61111,0,0,.525],97:[0,.43056,0,0,.525],98:[0,.61111,0,0,.525],99:[0,.43056,0,0,.525],100:[0,.61111,0,0,.525],101:[0,.43056,0,0,.525],102:[0,.61111,0,0,.525],103:[.22222,.43056,0,0,.525],104:[0,.61111,0,0,.525],105:[0,.61111,0,0,.525],106:[.22222,.61111,0,0,.525],107:[0,.61111,0,0,.525],108:[0,.61111,0,0,.525],109:[0,.43056,0,0,.525],110:[0,.43056,0,0,.525],111:[0,.43056,0,0,.525],112:[.22222,.43056,0,0,.525],113:[.22222,.43056,0,0,.525],114:[0,.43056,0,0,.525],115:[0,.43056,0,0,.525],116:[0,.55358,0,0,.525],117:[0,.43056,0,0,.525],118:[0,.43056,0,0,.525],119:[0,.43056,0,0,.525],120:[0,.43056,0,0,.525],121:[.22222,.43056,0,0,.525],122:[0,.43056,0,0,.525],123:[.08333,.69444,0,0,.525],124:[.08333,.69444,0,0,.525],125:[.08333,.69444,0,0,.525],126:[0,.61111,0,0,.525],127:[0,.61111,0,0,.525],160:[0,0,0,0,.525],176:[0,.61111,0,0,.525],184:[.19445,0,0,0,.525],305:[0,.43056,0,0,.525],567:[.22222,.43056,0,0,.525],711:[0,.56597,0,0,.525],713:[0,.56555,0,0,.525],714:[0,.61111,0,0,.525],715:[0,.61111,0,0,.525],728:[0,.61111,0,0,.525],730:[0,.61111,0,0,.525],770:[0,.61111,0,0,.525],771:[0,.61111,0,0,.525],776:[0,.61111,0,0,.525],915:[0,.61111,0,0,.525],916:[0,.61111,0,0,.525],920:[0,.61111,0,0,.525],923:[0,.61111,0,0,.525],926:[0,.61111,0,0,.525],928:[0,.61111,0,0,.525],931:[0,.61111,0,0,.525],933:[0,.61111,0,0,.525],934:[0,.61111,0,0,.525],936:[0,.61111,0,0,.525],937:[0,.61111,0,0,.525],8216:[0,.61111,0,0,.525],8217:[0,.61111,0,0,.525],8242:[0,.61111,0,0,.525],9251:[.11111,.21944,0,0,.525]}},aQ={slant:[.25,.25,.25],space:[0,0,0],stretch:[0,0,0],shrink:[0,0,0],xHeight:[.431,.431,.431],quad:[1,1.171,1.472],extraSpace:[0,0,0],num1:[.677,.732,.925],num2:[.394,.384,.387],num3:[.444,.471,.504],denom1:[.686,.752,1.025],denom2:[.345,.344,.532],sup1:[.413,.503,.504],sup2:[.363,.431,.404],sup3:[.289,.286,.294],sub1:[.15,.143,.2],sub2:[.247,.286,.4],supDrop:[.386,.353,.494],subDrop:[.05,.071,.1],delim1:[2.39,1.7,1.98],delim2:[1.01,1.157,1.42],axisHeight:[.25,.25,.25],defaultRuleThickness:[.04,.049,.049],bigOpSpacing1:[.111,.111,.111],bigOpSpacing2:[.166,.166,.166],bigOpSpacing3:[.2,.2,.2],bigOpSpacing4:[.6,.611,.611],bigOpSpacing5:[.1,.143,.143],sqrtRuleThickness:[.04,.04,.04],ptPerEm:[10,10,10],doubleRuleSep:[.2,.2,.2],arrayRuleWidth:[.04,.04,.04],fboxsep:[.3,.3,.3],fboxrule:[.04,.04,.04]},Y$e={Å:"A",Ð:"D",Þ:"o",å:"a",ð:"d",þ:"o",А:"A",Б:"B",В:"B",Г:"F",Д:"A",Е:"E",Ж:"K",З:"3",И:"N",Й:"N",К:"K",Л:"N",М:"M",Н:"H",О:"O",П:"N",Р:"P",С:"C",Т:"T",У:"y",Ф:"O",Х:"X",Ц:"U",Ч:"h",Ш:"W",Щ:"W",Ъ:"B",Ы:"X",Ь:"B",Э:"3",Ю:"X",Я:"R",а:"a",б:"b",в:"a",г:"r",д:"y",е:"e",ж:"m",з:"e",и:"n",й:"n",к:"n",л:"n",м:"m",н:"n",о:"o",п:"n",р:"p",с:"c",т:"o",у:"y",ф:"b",х:"x",ц:"n",ч:"n",ш:"w",щ:"w",ъ:"a",ы:"m",ь:"a",э:"e",ю:"m",я:"r"};function aHt(i,s){K4[i]=s}function J2e(i,s,u){if(!K4[s])throw new Error("Font metrics not found for font: "+s+".");var d=i.charCodeAt(0),p=K4[s][d];if(!p&&i[0]in Y$e&&(d=Y$e[i[0]].charCodeAt(0),p=K4[s][d]),!p&&u==="text"&&K$e(d)&&(p=K4[s][77]),p)return{depth:p[0],height:p[1],italic:p[2],skew:p[3],width:p[4]}}var Z2e={};function oHt(i){var s;if(i>=5?s=0:i>=3?s=1:s=2,!Z2e[s]){var u=Z2e[s]={cssEmPerMu:aQ.quad[s]/18};for(var d in aQ)aQ.hasOwnProperty(d)&&(u[d]=aQ[d][s])}return Z2e[s]}var cHt=[[1,1,1],[2,1,1],[3,1,1],[4,2,1],[5,2,1],[6,3,1],[7,4,2],[8,6,3],[9,7,6],[10,8,7],[11,10,9]],X$e=[.5,.6,.7,.8,.9,1,1.2,1.44,1.728,2.074,2.488],Q$e=function(s,u){return u.size<2?s:cHt[s-1][u.size-1]};class M7{constructor(s){this.style=void 0,this.color=void 0,this.size=void 0,this.textSize=void 0,this.phantom=void 0,this.font=void 0,this.fontFamily=void 0,this.fontWeight=void 0,this.fontShape=void 0,this.sizeMultiplier=void 0,this.maxSize=void 0,this.minRuleThickness=void 0,this._fontMetrics=void 0,this.style=s.style,this.color=s.color,this.size=s.size||M7.BASESIZE,this.textSize=s.textSize||this.size,this.phantom=!!s.phantom,this.font=s.font||"",this.fontFamily=s.fontFamily||"",this.fontWeight=s.fontWeight||"",this.fontShape=s.fontShape||"",this.sizeMultiplier=X$e[this.size-1],this.maxSize=s.maxSize,this.minRuleThickness=s.minRuleThickness,this._fontMetrics=void 0}extend(s){var u={style:this.style,size:this.size,textSize:this.textSize,color:this.color,phantom:this.phantom,font:this.font,fontFamily:this.fontFamily,fontWeight:this.fontWeight,fontShape:this.fontShape,maxSize:this.maxSize,minRuleThickness:this.minRuleThickness};for(var d in s)s.hasOwnProperty(d)&&(u[d]=s[d]);return new M7(u)}havingStyle(s){return this.style===s?this:this.extend({style:s,size:Q$e(this.textSize,s)})}havingCrampedStyle(){return this.havingStyle(this.style.cramp())}havingSize(s){return this.size===s&&this.textSize===s?this:this.extend({style:this.style.text(),size:s,textSize:s,sizeMultiplier:X$e[s-1]})}havingBaseStyle(s){s=s||this.style.text();var u=Q$e(M7.BASESIZE,s);return this.size===u&&this.textSize===M7.BASESIZE&&this.style===s?this:this.extend({style:s,size:u})}havingBaseSizing(){var s;switch(this.style.id){case 4:case 5:s=3;break;case 6:case 7:s=1;break;default:s=6}return this.extend({style:this.style.text(),size:s})}withColor(s){return this.extend({color:s})}withPhantom(){return this.extend({phantom:!0})}withFont(s){return this.extend({font:s})}withTextFontFamily(s){return this.extend({fontFamily:s,font:""})}withTextFontWeight(s){return this.extend({fontWeight:s,font:""})}withTextFontShape(s){return this.extend({fontShape:s,font:""})}sizingClasses(s){return s.size!==this.size?["sizing","reset-size"+s.size,"size"+this.size]:[]}baseSizingClasses(){return this.size!==M7.BASESIZE?["sizing","reset-size"+this.size,"size"+M7.BASESIZE]:[]}fontMetrics(){return this._fontMetrics||(this._fontMetrics=oHt(this.size)),this._fontMetrics}getColor(){return this.phantom?"transparent":this.color}}M7.BASESIZE=6;var ebe={pt:1,mm:7227/2540,cm:7227/254,in:72.27,bp:803/800,pc:12,dd:1238/1157,cc:14856/1157,nd:685/642,nc:1370/107,sp:1/65536,px:803/800},uHt={ex:!0,em:!0,mu:!0},J$e=function(s){return typeof s!="string"&&(s=s.unit),s in ebe||s in uHt||s==="ex"},Uh=function(s,u){var d;if(s.unit in ebe)d=ebe[s.unit]/u.fontMetrics().ptPerEm/u.sizeMultiplier;else if(s.unit==="mu")d=u.fontMetrics().cssEmPerMu;else{var p;if(u.style.isTight()?p=u.havingStyle(u.style.text()):p=u,s.unit==="ex")d=p.fontMetrics().xHeight;else if(s.unit==="em")d=p.fontMetrics().quad;else throw new Ci("Invalid unit: '"+s.unit+"'");p!==u&&(d*=p.sizeMultiplier/u.sizeMultiplier)}return Math.min(s.number*d,u.maxSize)},Ri=function(s){return+s.toFixed(4)+"em"},T9=function(s){return s.filter(u=>u).join(" ")},Z$e=function(s,u,d){if(this.classes=s||[],this.attributes={},this.height=0,this.depth=0,this.maxFontSize=0,this.style=d||{},u){u.style.isTight()&&this.classes.push("mtight");var p=u.getColor();p&&(this.style.color=p)}},eze=function(s){var u=document.createElement(s);u.className=T9(this.classes);for(var d in this.style)this.style.hasOwnProperty(d)&&(u.style[d]=this.style[d]);for(var p in this.attributes)this.attributes.hasOwnProperty(p)&&u.setAttribute(p,this.attributes[p]);for(var v=0;v",u};class cR{constructor(s,u,d,p){this.children=void 0,this.attributes=void 0,this.classes=void 0,this.height=void 0,this.depth=void 0,this.width=void 0,this.maxFontSize=void 0,this.style=void 0,Z$e.call(this,s,d,p),this.children=u||[]}setAttribute(s,u){this.attributes[s]=u}hasClass(s){return Ya.contains(this.classes,s)}toNode(){return eze.call(this,"span")}toMarkup(){return tze.call(this,"span")}}class tbe{constructor(s,u,d,p){this.children=void 0,this.attributes=void 0,this.classes=void 0,this.height=void 0,this.depth=void 0,this.maxFontSize=void 0,this.style=void 0,Z$e.call(this,u,p),this.children=d||[],this.setAttribute("href",s)}setAttribute(s,u){this.attributes[s]=u}hasClass(s){return Ya.contains(this.classes,s)}toNode(){return eze.call(this,"a")}toMarkup(){return tze.call(this,"a")}}class lHt{constructor(s,u,d){this.src=void 0,this.alt=void 0,this.classes=void 0,this.height=void 0,this.depth=void 0,this.maxFontSize=void 0,this.style=void 0,this.alt=u,this.src=s,this.classes=["mord"],this.style=d}hasClass(s){return Ya.contains(this.classes,s)}toNode(){var s=document.createElement("img");s.src=this.src,s.alt=this.alt,s.className="mord";for(var u in this.style)this.style.hasOwnProperty(u)&&(s.style[u]=this.style[u]);return s}toMarkup(){var s=""+this.alt+"0&&(u=document.createElement("span"),u.style.marginRight=Ri(this.italic)),this.classes.length>0&&(u=u||document.createElement("span"),u.className=T9(this.classes));for(var d in this.style)this.style.hasOwnProperty(d)&&(u=u||document.createElement("span"),u.style[d]=this.style[d]);return u?(u.appendChild(s),u):s}toMarkup(){var s=!1,u="0&&(d+="margin-right:"+this.italic+"em;");for(var p in this.style)this.style.hasOwnProperty(p)&&(d+=Ya.hyphenate(p)+":"+this.style[p]+";");d&&(s=!0,u+=' style="'+Ya.escape(d)+'"');var v=Ya.escape(this.text);return s?(u+=">",u+=v,u+="",u):v}}class D7{constructor(s,u){this.children=void 0,this.attributes=void 0,this.children=s||[],this.attributes=u||{}}toNode(){var s="http://www.w3.org/2000/svg",u=document.createElementNS(s,"svg");for(var d in this.attributes)Object.prototype.hasOwnProperty.call(this.attributes,d)&&u.setAttribute(d,this.attributes[d]);for(var p=0;p":""}}class nbe{constructor(s){this.attributes=void 0,this.attributes=s||{}}toNode(){var s="http://www.w3.org/2000/svg",u=document.createElementNS(s,"line");for(var d in this.attributes)Object.prototype.hasOwnProperty.call(this.attributes,d)&&u.setAttribute(d,this.attributes[d]);return u}toMarkup(){var s=" but got "+String(i)+".")}var dHt={bin:1,close:1,inner:1,open:1,punct:1,rel:1},gHt={"accent-token":1,mathord:1,"op-token":1,spacing:1,textord:1},Ul={math:{},text:{}};function we(i,s,u,d,p,v){Ul[i][p]={font:s,group:u,replace:d},v&&d&&(Ul[i][d]=Ul[i][p])}var Ae="math",si="text",Ue="main",$t="ams",wh="accent-token",ls="bin",Dp="close",ND="inner",Ca="mathord",N0="op-token",hm="open",oQ="punct",Ht="rel",I7="spacing",mn="textord";we(Ae,Ue,Ht,"≡","\\equiv",!0),we(Ae,Ue,Ht,"≺","\\prec",!0),we(Ae,Ue,Ht,"≻","\\succ",!0),we(Ae,Ue,Ht,"∼","\\sim",!0),we(Ae,Ue,Ht,"⊥","\\perp"),we(Ae,Ue,Ht,"⪯","\\preceq",!0),we(Ae,Ue,Ht,"⪰","\\succeq",!0),we(Ae,Ue,Ht,"≃","\\simeq",!0),we(Ae,Ue,Ht,"∣","\\mid",!0),we(Ae,Ue,Ht,"≪","\\ll",!0),we(Ae,Ue,Ht,"≫","\\gg",!0),we(Ae,Ue,Ht,"≍","\\asymp",!0),we(Ae,Ue,Ht,"∥","\\parallel"),we(Ae,Ue,Ht,"⋈","\\bowtie",!0),we(Ae,Ue,Ht,"⌣","\\smile",!0),we(Ae,Ue,Ht,"⊑","\\sqsubseteq",!0),we(Ae,Ue,Ht,"⊒","\\sqsupseteq",!0),we(Ae,Ue,Ht,"≐","\\doteq",!0),we(Ae,Ue,Ht,"⌢","\\frown",!0),we(Ae,Ue,Ht,"∋","\\ni",!0),we(Ae,Ue,Ht,"∝","\\propto",!0),we(Ae,Ue,Ht,"⊢","\\vdash",!0),we(Ae,Ue,Ht,"⊣","\\dashv",!0),we(Ae,Ue,Ht,"∋","\\owns"),we(Ae,Ue,oQ,".","\\ldotp"),we(Ae,Ue,oQ,"⋅","\\cdotp"),we(Ae,Ue,mn,"#","\\#"),we(si,Ue,mn,"#","\\#"),we(Ae,Ue,mn,"&","\\&"),we(si,Ue,mn,"&","\\&"),we(Ae,Ue,mn,"ℵ","\\aleph",!0),we(Ae,Ue,mn,"∀","\\forall",!0),we(Ae,Ue,mn,"ℏ","\\hbar",!0),we(Ae,Ue,mn,"∃","\\exists",!0),we(Ae,Ue,mn,"∇","\\nabla",!0),we(Ae,Ue,mn,"♭","\\flat",!0),we(Ae,Ue,mn,"ℓ","\\ell",!0),we(Ae,Ue,mn,"♮","\\natural",!0),we(Ae,Ue,mn,"♣","\\clubsuit",!0),we(Ae,Ue,mn,"℘","\\wp",!0),we(Ae,Ue,mn,"♯","\\sharp",!0),we(Ae,Ue,mn,"♢","\\diamondsuit",!0),we(Ae,Ue,mn,"ℜ","\\Re",!0),we(Ae,Ue,mn,"♡","\\heartsuit",!0),we(Ae,Ue,mn,"ℑ","\\Im",!0),we(Ae,Ue,mn,"♠","\\spadesuit",!0),we(Ae,Ue,mn,"§","\\S",!0),we(si,Ue,mn,"§","\\S"),we(Ae,Ue,mn,"¶","\\P",!0),we(si,Ue,mn,"¶","\\P"),we(Ae,Ue,mn,"†","\\dag"),we(si,Ue,mn,"†","\\dag"),we(si,Ue,mn,"†","\\textdagger"),we(Ae,Ue,mn,"‡","\\ddag"),we(si,Ue,mn,"‡","\\ddag"),we(si,Ue,mn,"‡","\\textdaggerdbl"),we(Ae,Ue,Dp,"⎱","\\rmoustache",!0),we(Ae,Ue,hm,"⎰","\\lmoustache",!0),we(Ae,Ue,Dp,"⟯","\\rgroup",!0),we(Ae,Ue,hm,"⟮","\\lgroup",!0),we(Ae,Ue,ls,"∓","\\mp",!0),we(Ae,Ue,ls,"⊖","\\ominus",!0),we(Ae,Ue,ls,"⊎","\\uplus",!0),we(Ae,Ue,ls,"⊓","\\sqcap",!0),we(Ae,Ue,ls,"∗","\\ast"),we(Ae,Ue,ls,"⊔","\\sqcup",!0),we(Ae,Ue,ls,"◯","\\bigcirc",!0),we(Ae,Ue,ls,"∙","\\bullet",!0),we(Ae,Ue,ls,"‡","\\ddagger"),we(Ae,Ue,ls,"≀","\\wr",!0),we(Ae,Ue,ls,"⨿","\\amalg"),we(Ae,Ue,ls,"&","\\And"),we(Ae,Ue,Ht,"⟵","\\longleftarrow",!0),we(Ae,Ue,Ht,"⇐","\\Leftarrow",!0),we(Ae,Ue,Ht,"⟸","\\Longleftarrow",!0),we(Ae,Ue,Ht,"⟶","\\longrightarrow",!0),we(Ae,Ue,Ht,"⇒","\\Rightarrow",!0),we(Ae,Ue,Ht,"⟹","\\Longrightarrow",!0),we(Ae,Ue,Ht,"↔","\\leftrightarrow",!0),we(Ae,Ue,Ht,"⟷","\\longleftrightarrow",!0),we(Ae,Ue,Ht,"⇔","\\Leftrightarrow",!0),we(Ae,Ue,Ht,"⟺","\\Longleftrightarrow",!0),we(Ae,Ue,Ht,"↦","\\mapsto",!0),we(Ae,Ue,Ht,"⟼","\\longmapsto",!0),we(Ae,Ue,Ht,"↗","\\nearrow",!0),we(Ae,Ue,Ht,"↩","\\hookleftarrow",!0),we(Ae,Ue,Ht,"↪","\\hookrightarrow",!0),we(Ae,Ue,Ht,"↘","\\searrow",!0),we(Ae,Ue,Ht,"↼","\\leftharpoonup",!0),we(Ae,Ue,Ht,"⇀","\\rightharpoonup",!0),we(Ae,Ue,Ht,"↙","\\swarrow",!0),we(Ae,Ue,Ht,"↽","\\leftharpoondown",!0),we(Ae,Ue,Ht,"⇁","\\rightharpoondown",!0),we(Ae,Ue,Ht,"↖","\\nwarrow",!0),we(Ae,Ue,Ht,"⇌","\\rightleftharpoons",!0),we(Ae,$t,Ht,"≮","\\nless",!0),we(Ae,$t,Ht,"","\\@nleqslant"),we(Ae,$t,Ht,"","\\@nleqq"),we(Ae,$t,Ht,"⪇","\\lneq",!0),we(Ae,$t,Ht,"≨","\\lneqq",!0),we(Ae,$t,Ht,"","\\@lvertneqq"),we(Ae,$t,Ht,"⋦","\\lnsim",!0),we(Ae,$t,Ht,"⪉","\\lnapprox",!0),we(Ae,$t,Ht,"⊀","\\nprec",!0),we(Ae,$t,Ht,"⋠","\\npreceq",!0),we(Ae,$t,Ht,"⋨","\\precnsim",!0),we(Ae,$t,Ht,"⪹","\\precnapprox",!0),we(Ae,$t,Ht,"≁","\\nsim",!0),we(Ae,$t,Ht,"","\\@nshortmid"),we(Ae,$t,Ht,"∤","\\nmid",!0),we(Ae,$t,Ht,"⊬","\\nvdash",!0),we(Ae,$t,Ht,"⊭","\\nvDash",!0),we(Ae,$t,Ht,"⋪","\\ntriangleleft"),we(Ae,$t,Ht,"⋬","\\ntrianglelefteq",!0),we(Ae,$t,Ht,"⊊","\\subsetneq",!0),we(Ae,$t,Ht,"","\\@varsubsetneq"),we(Ae,$t,Ht,"⫋","\\subsetneqq",!0),we(Ae,$t,Ht,"","\\@varsubsetneqq"),we(Ae,$t,Ht,"≯","\\ngtr",!0),we(Ae,$t,Ht,"","\\@ngeqslant"),we(Ae,$t,Ht,"","\\@ngeqq"),we(Ae,$t,Ht,"⪈","\\gneq",!0),we(Ae,$t,Ht,"≩","\\gneqq",!0),we(Ae,$t,Ht,"","\\@gvertneqq"),we(Ae,$t,Ht,"⋧","\\gnsim",!0),we(Ae,$t,Ht,"⪊","\\gnapprox",!0),we(Ae,$t,Ht,"⊁","\\nsucc",!0),we(Ae,$t,Ht,"⋡","\\nsucceq",!0),we(Ae,$t,Ht,"⋩","\\succnsim",!0),we(Ae,$t,Ht,"⪺","\\succnapprox",!0),we(Ae,$t,Ht,"≆","\\ncong",!0),we(Ae,$t,Ht,"","\\@nshortparallel"),we(Ae,$t,Ht,"∦","\\nparallel",!0),we(Ae,$t,Ht,"⊯","\\nVDash",!0),we(Ae,$t,Ht,"⋫","\\ntriangleright"),we(Ae,$t,Ht,"⋭","\\ntrianglerighteq",!0),we(Ae,$t,Ht,"","\\@nsupseteqq"),we(Ae,$t,Ht,"⊋","\\supsetneq",!0),we(Ae,$t,Ht,"","\\@varsupsetneq"),we(Ae,$t,Ht,"⫌","\\supsetneqq",!0),we(Ae,$t,Ht,"","\\@varsupsetneqq"),we(Ae,$t,Ht,"⊮","\\nVdash",!0),we(Ae,$t,Ht,"⪵","\\precneqq",!0),we(Ae,$t,Ht,"⪶","\\succneqq",!0),we(Ae,$t,Ht,"","\\@nsubseteqq"),we(Ae,$t,ls,"⊴","\\unlhd"),we(Ae,$t,ls,"⊵","\\unrhd"),we(Ae,$t,Ht,"↚","\\nleftarrow",!0),we(Ae,$t,Ht,"↛","\\nrightarrow",!0),we(Ae,$t,Ht,"⇍","\\nLeftarrow",!0),we(Ae,$t,Ht,"⇏","\\nRightarrow",!0),we(Ae,$t,Ht,"↮","\\nleftrightarrow",!0),we(Ae,$t,Ht,"⇎","\\nLeftrightarrow",!0),we(Ae,$t,Ht,"△","\\vartriangle"),we(Ae,$t,mn,"ℏ","\\hslash"),we(Ae,$t,mn,"▽","\\triangledown"),we(Ae,$t,mn,"◊","\\lozenge"),we(Ae,$t,mn,"Ⓢ","\\circledS"),we(Ae,$t,mn,"®","\\circledR"),we(si,$t,mn,"®","\\circledR"),we(Ae,$t,mn,"∡","\\measuredangle",!0),we(Ae,$t,mn,"∄","\\nexists"),we(Ae,$t,mn,"℧","\\mho"),we(Ae,$t,mn,"Ⅎ","\\Finv",!0),we(Ae,$t,mn,"⅁","\\Game",!0),we(Ae,$t,mn,"‵","\\backprime"),we(Ae,$t,mn,"▲","\\blacktriangle"),we(Ae,$t,mn,"▼","\\blacktriangledown"),we(Ae,$t,mn,"■","\\blacksquare"),we(Ae,$t,mn,"⧫","\\blacklozenge"),we(Ae,$t,mn,"★","\\bigstar"),we(Ae,$t,mn,"∢","\\sphericalangle",!0),we(Ae,$t,mn,"∁","\\complement",!0),we(Ae,$t,mn,"ð","\\eth",!0),we(si,Ue,mn,"ð","ð"),we(Ae,$t,mn,"╱","\\diagup"),we(Ae,$t,mn,"╲","\\diagdown"),we(Ae,$t,mn,"□","\\square"),we(Ae,$t,mn,"□","\\Box"),we(Ae,$t,mn,"◊","\\Diamond"),we(Ae,$t,mn,"¥","\\yen",!0),we(si,$t,mn,"¥","\\yen",!0),we(Ae,$t,mn,"✓","\\checkmark",!0),we(si,$t,mn,"✓","\\checkmark"),we(Ae,$t,mn,"ℶ","\\beth",!0),we(Ae,$t,mn,"ℸ","\\daleth",!0),we(Ae,$t,mn,"ℷ","\\gimel",!0),we(Ae,$t,mn,"ϝ","\\digamma",!0),we(Ae,$t,mn,"ϰ","\\varkappa"),we(Ae,$t,hm,"┌","\\@ulcorner",!0),we(Ae,$t,Dp,"┐","\\@urcorner",!0),we(Ae,$t,hm,"└","\\@llcorner",!0),we(Ae,$t,Dp,"┘","\\@lrcorner",!0),we(Ae,$t,Ht,"≦","\\leqq",!0),we(Ae,$t,Ht,"⩽","\\leqslant",!0),we(Ae,$t,Ht,"⪕","\\eqslantless",!0),we(Ae,$t,Ht,"≲","\\lesssim",!0),we(Ae,$t,Ht,"⪅","\\lessapprox",!0),we(Ae,$t,Ht,"≊","\\approxeq",!0),we(Ae,$t,ls,"⋖","\\lessdot"),we(Ae,$t,Ht,"⋘","\\lll",!0),we(Ae,$t,Ht,"≶","\\lessgtr",!0),we(Ae,$t,Ht,"⋚","\\lesseqgtr",!0),we(Ae,$t,Ht,"⪋","\\lesseqqgtr",!0),we(Ae,$t,Ht,"≑","\\doteqdot"),we(Ae,$t,Ht,"≓","\\risingdotseq",!0),we(Ae,$t,Ht,"≒","\\fallingdotseq",!0),we(Ae,$t,Ht,"∽","\\backsim",!0),we(Ae,$t,Ht,"⋍","\\backsimeq",!0),we(Ae,$t,Ht,"⫅","\\subseteqq",!0),we(Ae,$t,Ht,"⋐","\\Subset",!0),we(Ae,$t,Ht,"⊏","\\sqsubset",!0),we(Ae,$t,Ht,"≼","\\preccurlyeq",!0),we(Ae,$t,Ht,"⋞","\\curlyeqprec",!0),we(Ae,$t,Ht,"≾","\\precsim",!0),we(Ae,$t,Ht,"⪷","\\precapprox",!0),we(Ae,$t,Ht,"⊲","\\vartriangleleft"),we(Ae,$t,Ht,"⊴","\\trianglelefteq"),we(Ae,$t,Ht,"⊨","\\vDash",!0),we(Ae,$t,Ht,"⊪","\\Vvdash",!0),we(Ae,$t,Ht,"⌣","\\smallsmile"),we(Ae,$t,Ht,"⌢","\\smallfrown"),we(Ae,$t,Ht,"≏","\\bumpeq",!0),we(Ae,$t,Ht,"≎","\\Bumpeq",!0),we(Ae,$t,Ht,"≧","\\geqq",!0),we(Ae,$t,Ht,"⩾","\\geqslant",!0),we(Ae,$t,Ht,"⪖","\\eqslantgtr",!0),we(Ae,$t,Ht,"≳","\\gtrsim",!0),we(Ae,$t,Ht,"⪆","\\gtrapprox",!0),we(Ae,$t,ls,"⋗","\\gtrdot"),we(Ae,$t,Ht,"⋙","\\ggg",!0),we(Ae,$t,Ht,"≷","\\gtrless",!0),we(Ae,$t,Ht,"⋛","\\gtreqless",!0),we(Ae,$t,Ht,"⪌","\\gtreqqless",!0),we(Ae,$t,Ht,"≖","\\eqcirc",!0),we(Ae,$t,Ht,"≗","\\circeq",!0),we(Ae,$t,Ht,"≜","\\triangleq",!0),we(Ae,$t,Ht,"∼","\\thicksim"),we(Ae,$t,Ht,"≈","\\thickapprox"),we(Ae,$t,Ht,"⫆","\\supseteqq",!0),we(Ae,$t,Ht,"⋑","\\Supset",!0),we(Ae,$t,Ht,"⊐","\\sqsupset",!0),we(Ae,$t,Ht,"≽","\\succcurlyeq",!0),we(Ae,$t,Ht,"⋟","\\curlyeqsucc",!0),we(Ae,$t,Ht,"≿","\\succsim",!0),we(Ae,$t,Ht,"⪸","\\succapprox",!0),we(Ae,$t,Ht,"⊳","\\vartriangleright"),we(Ae,$t,Ht,"⊵","\\trianglerighteq"),we(Ae,$t,Ht,"⊩","\\Vdash",!0),we(Ae,$t,Ht,"∣","\\shortmid"),we(Ae,$t,Ht,"∥","\\shortparallel"),we(Ae,$t,Ht,"≬","\\between",!0),we(Ae,$t,Ht,"⋔","\\pitchfork",!0),we(Ae,$t,Ht,"∝","\\varpropto"),we(Ae,$t,Ht,"◀","\\blacktriangleleft"),we(Ae,$t,Ht,"∴","\\therefore",!0),we(Ae,$t,Ht,"∍","\\backepsilon"),we(Ae,$t,Ht,"▶","\\blacktriangleright"),we(Ae,$t,Ht,"∵","\\because",!0),we(Ae,$t,Ht,"⋘","\\llless"),we(Ae,$t,Ht,"⋙","\\gggtr"),we(Ae,$t,ls,"⊲","\\lhd"),we(Ae,$t,ls,"⊳","\\rhd"),we(Ae,$t,Ht,"≂","\\eqsim",!0),we(Ae,Ue,Ht,"⋈","\\Join"),we(Ae,$t,Ht,"≑","\\Doteq",!0),we(Ae,$t,ls,"∔","\\dotplus",!0),we(Ae,$t,ls,"∖","\\smallsetminus"),we(Ae,$t,ls,"⋒","\\Cap",!0),we(Ae,$t,ls,"⋓","\\Cup",!0),we(Ae,$t,ls,"⩞","\\doublebarwedge",!0),we(Ae,$t,ls,"⊟","\\boxminus",!0),we(Ae,$t,ls,"⊞","\\boxplus",!0),we(Ae,$t,ls,"⋇","\\divideontimes",!0),we(Ae,$t,ls,"⋉","\\ltimes",!0),we(Ae,$t,ls,"⋊","\\rtimes",!0),we(Ae,$t,ls,"⋋","\\leftthreetimes",!0),we(Ae,$t,ls,"⋌","\\rightthreetimes",!0),we(Ae,$t,ls,"⋏","\\curlywedge",!0),we(Ae,$t,ls,"⋎","\\curlyvee",!0),we(Ae,$t,ls,"⊝","\\circleddash",!0),we(Ae,$t,ls,"⊛","\\circledast",!0),we(Ae,$t,ls,"⋅","\\centerdot"),we(Ae,$t,ls,"⊺","\\intercal",!0),we(Ae,$t,ls,"⋒","\\doublecap"),we(Ae,$t,ls,"⋓","\\doublecup"),we(Ae,$t,ls,"⊠","\\boxtimes",!0),we(Ae,$t,Ht,"⇢","\\dashrightarrow",!0),we(Ae,$t,Ht,"⇠","\\dashleftarrow",!0),we(Ae,$t,Ht,"⇇","\\leftleftarrows",!0),we(Ae,$t,Ht,"⇆","\\leftrightarrows",!0),we(Ae,$t,Ht,"⇚","\\Lleftarrow",!0),we(Ae,$t,Ht,"↞","\\twoheadleftarrow",!0),we(Ae,$t,Ht,"↢","\\leftarrowtail",!0),we(Ae,$t,Ht,"↫","\\looparrowleft",!0),we(Ae,$t,Ht,"⇋","\\leftrightharpoons",!0),we(Ae,$t,Ht,"↶","\\curvearrowleft",!0),we(Ae,$t,Ht,"↺","\\circlearrowleft",!0),we(Ae,$t,Ht,"↰","\\Lsh",!0),we(Ae,$t,Ht,"⇈","\\upuparrows",!0),we(Ae,$t,Ht,"↿","\\upharpoonleft",!0),we(Ae,$t,Ht,"⇃","\\downharpoonleft",!0),we(Ae,Ue,Ht,"⊶","\\origof",!0),we(Ae,Ue,Ht,"⊷","\\imageof",!0),we(Ae,$t,Ht,"⊸","\\multimap",!0),we(Ae,$t,Ht,"↭","\\leftrightsquigarrow",!0),we(Ae,$t,Ht,"⇉","\\rightrightarrows",!0),we(Ae,$t,Ht,"⇄","\\rightleftarrows",!0),we(Ae,$t,Ht,"↠","\\twoheadrightarrow",!0),we(Ae,$t,Ht,"↣","\\rightarrowtail",!0),we(Ae,$t,Ht,"↬","\\looparrowright",!0),we(Ae,$t,Ht,"↷","\\curvearrowright",!0),we(Ae,$t,Ht,"↻","\\circlearrowright",!0),we(Ae,$t,Ht,"↱","\\Rsh",!0),we(Ae,$t,Ht,"⇊","\\downdownarrows",!0),we(Ae,$t,Ht,"↾","\\upharpoonright",!0),we(Ae,$t,Ht,"⇂","\\downharpoonright",!0),we(Ae,$t,Ht,"⇝","\\rightsquigarrow",!0),we(Ae,$t,Ht,"⇝","\\leadsto"),we(Ae,$t,Ht,"⇛","\\Rrightarrow",!0),we(Ae,$t,Ht,"↾","\\restriction"),we(Ae,Ue,mn,"‘","`"),we(Ae,Ue,mn,"$","\\$"),we(si,Ue,mn,"$","\\$"),we(si,Ue,mn,"$","\\textdollar"),we(Ae,Ue,mn,"%","\\%"),we(si,Ue,mn,"%","\\%"),we(Ae,Ue,mn,"_","\\_"),we(si,Ue,mn,"_","\\_"),we(si,Ue,mn,"_","\\textunderscore"),we(Ae,Ue,mn,"∠","\\angle",!0),we(Ae,Ue,mn,"∞","\\infty",!0),we(Ae,Ue,mn,"′","\\prime"),we(Ae,Ue,mn,"△","\\triangle"),we(Ae,Ue,mn,"Γ","\\Gamma",!0),we(Ae,Ue,mn,"Δ","\\Delta",!0),we(Ae,Ue,mn,"Θ","\\Theta",!0),we(Ae,Ue,mn,"Λ","\\Lambda",!0),we(Ae,Ue,mn,"Ξ","\\Xi",!0),we(Ae,Ue,mn,"Π","\\Pi",!0),we(Ae,Ue,mn,"Σ","\\Sigma",!0),we(Ae,Ue,mn,"Υ","\\Upsilon",!0),we(Ae,Ue,mn,"Φ","\\Phi",!0),we(Ae,Ue,mn,"Ψ","\\Psi",!0),we(Ae,Ue,mn,"Ω","\\Omega",!0),we(Ae,Ue,mn,"A","Α"),we(Ae,Ue,mn,"B","Β"),we(Ae,Ue,mn,"E","Ε"),we(Ae,Ue,mn,"Z","Ζ"),we(Ae,Ue,mn,"H","Η"),we(Ae,Ue,mn,"I","Ι"),we(Ae,Ue,mn,"K","Κ"),we(Ae,Ue,mn,"M","Μ"),we(Ae,Ue,mn,"N","Ν"),we(Ae,Ue,mn,"O","Ο"),we(Ae,Ue,mn,"P","Ρ"),we(Ae,Ue,mn,"T","Τ"),we(Ae,Ue,mn,"X","Χ"),we(Ae,Ue,mn,"¬","\\neg",!0),we(Ae,Ue,mn,"¬","\\lnot"),we(Ae,Ue,mn,"⊤","\\top"),we(Ae,Ue,mn,"⊥","\\bot"),we(Ae,Ue,mn,"∅","\\emptyset"),we(Ae,$t,mn,"∅","\\varnothing"),we(Ae,Ue,Ca,"α","\\alpha",!0),we(Ae,Ue,Ca,"β","\\beta",!0),we(Ae,Ue,Ca,"γ","\\gamma",!0),we(Ae,Ue,Ca,"δ","\\delta",!0),we(Ae,Ue,Ca,"ϵ","\\epsilon",!0),we(Ae,Ue,Ca,"ζ","\\zeta",!0),we(Ae,Ue,Ca,"η","\\eta",!0),we(Ae,Ue,Ca,"θ","\\theta",!0),we(Ae,Ue,Ca,"ι","\\iota",!0),we(Ae,Ue,Ca,"κ","\\kappa",!0),we(Ae,Ue,Ca,"λ","\\lambda",!0),we(Ae,Ue,Ca,"μ","\\mu",!0),we(Ae,Ue,Ca,"ν","\\nu",!0),we(Ae,Ue,Ca,"ξ","\\xi",!0),we(Ae,Ue,Ca,"ο","\\omicron",!0),we(Ae,Ue,Ca,"π","\\pi",!0),we(Ae,Ue,Ca,"ρ","\\rho",!0),we(Ae,Ue,Ca,"σ","\\sigma",!0),we(Ae,Ue,Ca,"τ","\\tau",!0),we(Ae,Ue,Ca,"υ","\\upsilon",!0),we(Ae,Ue,Ca,"ϕ","\\phi",!0),we(Ae,Ue,Ca,"χ","\\chi",!0),we(Ae,Ue,Ca,"ψ","\\psi",!0),we(Ae,Ue,Ca,"ω","\\omega",!0),we(Ae,Ue,Ca,"ε","\\varepsilon",!0),we(Ae,Ue,Ca,"ϑ","\\vartheta",!0),we(Ae,Ue,Ca,"ϖ","\\varpi",!0),we(Ae,Ue,Ca,"ϱ","\\varrho",!0),we(Ae,Ue,Ca,"ς","\\varsigma",!0),we(Ae,Ue,Ca,"φ","\\varphi",!0),we(Ae,Ue,ls,"∗","*",!0),we(Ae,Ue,ls,"+","+"),we(Ae,Ue,ls,"−","-",!0),we(Ae,Ue,ls,"⋅","\\cdot",!0),we(Ae,Ue,ls,"∘","\\circ",!0),we(Ae,Ue,ls,"÷","\\div",!0),we(Ae,Ue,ls,"±","\\pm",!0),we(Ae,Ue,ls,"×","\\times",!0),we(Ae,Ue,ls,"∩","\\cap",!0),we(Ae,Ue,ls,"∪","\\cup",!0),we(Ae,Ue,ls,"∖","\\setminus",!0),we(Ae,Ue,ls,"∧","\\land"),we(Ae,Ue,ls,"∨","\\lor"),we(Ae,Ue,ls,"∧","\\wedge",!0),we(Ae,Ue,ls,"∨","\\vee",!0),we(Ae,Ue,mn,"√","\\surd"),we(Ae,Ue,hm,"⟨","\\langle",!0),we(Ae,Ue,hm,"∣","\\lvert"),we(Ae,Ue,hm,"∥","\\lVert"),we(Ae,Ue,Dp,"?","?"),we(Ae,Ue,Dp,"!","!"),we(Ae,Ue,Dp,"⟩","\\rangle",!0),we(Ae,Ue,Dp,"∣","\\rvert"),we(Ae,Ue,Dp,"∥","\\rVert"),we(Ae,Ue,Ht,"=","="),we(Ae,Ue,Ht,":",":"),we(Ae,Ue,Ht,"≈","\\approx",!0),we(Ae,Ue,Ht,"≅","\\cong",!0),we(Ae,Ue,Ht,"≥","\\ge"),we(Ae,Ue,Ht,"≥","\\geq",!0),we(Ae,Ue,Ht,"←","\\gets"),we(Ae,Ue,Ht,">","\\gt",!0),we(Ae,Ue,Ht,"∈","\\in",!0),we(Ae,Ue,Ht,"","\\@not"),we(Ae,Ue,Ht,"⊂","\\subset",!0),we(Ae,Ue,Ht,"⊃","\\supset",!0),we(Ae,Ue,Ht,"⊆","\\subseteq",!0),we(Ae,Ue,Ht,"⊇","\\supseteq",!0),we(Ae,$t,Ht,"⊈","\\nsubseteq",!0),we(Ae,$t,Ht,"⊉","\\nsupseteq",!0),we(Ae,Ue,Ht,"⊨","\\models"),we(Ae,Ue,Ht,"←","\\leftarrow",!0),we(Ae,Ue,Ht,"≤","\\le"),we(Ae,Ue,Ht,"≤","\\leq",!0),we(Ae,Ue,Ht,"<","\\lt",!0),we(Ae,Ue,Ht,"→","\\rightarrow",!0),we(Ae,Ue,Ht,"→","\\to"),we(Ae,$t,Ht,"≱","\\ngeq",!0),we(Ae,$t,Ht,"≰","\\nleq",!0),we(Ae,Ue,I7," ","\\ "),we(Ae,Ue,I7," ","\\space"),we(Ae,Ue,I7," ","\\nobreakspace"),we(si,Ue,I7," ","\\ "),we(si,Ue,I7," "," "),we(si,Ue,I7," ","\\space"),we(si,Ue,I7," ","\\nobreakspace"),we(Ae,Ue,I7,null,"\\nobreak"),we(Ae,Ue,I7,null,"\\allowbreak"),we(Ae,Ue,oQ,",",","),we(Ae,Ue,oQ,";",";"),we(Ae,$t,ls,"⊼","\\barwedge",!0),we(Ae,$t,ls,"⊻","\\veebar",!0),we(Ae,Ue,ls,"⊙","\\odot",!0),we(Ae,Ue,ls,"⊕","\\oplus",!0),we(Ae,Ue,ls,"⊗","\\otimes",!0),we(Ae,Ue,mn,"∂","\\partial",!0),we(Ae,Ue,ls,"⊘","\\oslash",!0),we(Ae,$t,ls,"⊚","\\circledcirc",!0),we(Ae,$t,ls,"⊡","\\boxdot",!0),we(Ae,Ue,ls,"△","\\bigtriangleup"),we(Ae,Ue,ls,"▽","\\bigtriangledown"),we(Ae,Ue,ls,"†","\\dagger"),we(Ae,Ue,ls,"⋄","\\diamond"),we(Ae,Ue,ls,"⋆","\\star"),we(Ae,Ue,ls,"◃","\\triangleleft"),we(Ae,Ue,ls,"▹","\\triangleright"),we(Ae,Ue,hm,"{","\\{"),we(si,Ue,mn,"{","\\{"),we(si,Ue,mn,"{","\\textbraceleft"),we(Ae,Ue,Dp,"}","\\}"),we(si,Ue,mn,"}","\\}"),we(si,Ue,mn,"}","\\textbraceright"),we(Ae,Ue,hm,"{","\\lbrace"),we(Ae,Ue,Dp,"}","\\rbrace"),we(Ae,Ue,hm,"[","\\lbrack",!0),we(si,Ue,mn,"[","\\lbrack",!0),we(Ae,Ue,Dp,"]","\\rbrack",!0),we(si,Ue,mn,"]","\\rbrack",!0),we(Ae,Ue,hm,"(","\\lparen",!0),we(Ae,Ue,Dp,")","\\rparen",!0),we(si,Ue,mn,"<","\\textless",!0),we(si,Ue,mn,">","\\textgreater",!0),we(Ae,Ue,hm,"⌊","\\lfloor",!0),we(Ae,Ue,Dp,"⌋","\\rfloor",!0),we(Ae,Ue,hm,"⌈","\\lceil",!0),we(Ae,Ue,Dp,"⌉","\\rceil",!0),we(Ae,Ue,mn,"\\","\\backslash"),we(Ae,Ue,mn,"∣","|"),we(Ae,Ue,mn,"∣","\\vert"),we(si,Ue,mn,"|","\\textbar",!0),we(Ae,Ue,mn,"∥","\\|"),we(Ae,Ue,mn,"∥","\\Vert"),we(si,Ue,mn,"∥","\\textbardbl"),we(si,Ue,mn,"~","\\textasciitilde"),we(si,Ue,mn,"\\","\\textbackslash"),we(si,Ue,mn,"^","\\textasciicircum"),we(Ae,Ue,Ht,"↑","\\uparrow",!0),we(Ae,Ue,Ht,"⇑","\\Uparrow",!0),we(Ae,Ue,Ht,"↓","\\downarrow",!0),we(Ae,Ue,Ht,"⇓","\\Downarrow",!0),we(Ae,Ue,Ht,"↕","\\updownarrow",!0),we(Ae,Ue,Ht,"⇕","\\Updownarrow",!0),we(Ae,Ue,N0,"∐","\\coprod"),we(Ae,Ue,N0,"⋁","\\bigvee"),we(Ae,Ue,N0,"⋀","\\bigwedge"),we(Ae,Ue,N0,"⨄","\\biguplus"),we(Ae,Ue,N0,"⋂","\\bigcap"),we(Ae,Ue,N0,"⋃","\\bigcup"),we(Ae,Ue,N0,"∫","\\int"),we(Ae,Ue,N0,"∫","\\intop"),we(Ae,Ue,N0,"∬","\\iint"),we(Ae,Ue,N0,"∭","\\iiint"),we(Ae,Ue,N0,"∏","\\prod"),we(Ae,Ue,N0,"∑","\\sum"),we(Ae,Ue,N0,"⨂","\\bigotimes"),we(Ae,Ue,N0,"⨁","\\bigoplus"),we(Ae,Ue,N0,"⨀","\\bigodot"),we(Ae,Ue,N0,"∮","\\oint"),we(Ae,Ue,N0,"∯","\\oiint"),we(Ae,Ue,N0,"∰","\\oiiint"),we(Ae,Ue,N0,"⨆","\\bigsqcup"),we(Ae,Ue,N0,"∫","\\smallint"),we(si,Ue,ND,"…","\\textellipsis"),we(Ae,Ue,ND,"…","\\mathellipsis"),we(si,Ue,ND,"…","\\ldots",!0),we(Ae,Ue,ND,"…","\\ldots",!0),we(Ae,Ue,ND,"⋯","\\@cdots",!0),we(Ae,Ue,ND,"⋱","\\ddots",!0),we(Ae,Ue,mn,"⋮","\\varvdots"),we(Ae,Ue,wh,"ˊ","\\acute"),we(Ae,Ue,wh,"ˋ","\\grave"),we(Ae,Ue,wh,"¨","\\ddot"),we(Ae,Ue,wh,"~","\\tilde"),we(Ae,Ue,wh,"ˉ","\\bar"),we(Ae,Ue,wh,"˘","\\breve"),we(Ae,Ue,wh,"ˇ","\\check"),we(Ae,Ue,wh,"^","\\hat"),we(Ae,Ue,wh,"⃗","\\vec"),we(Ae,Ue,wh,"˙","\\dot"),we(Ae,Ue,wh,"˚","\\mathring"),we(Ae,Ue,Ca,"","\\@imath"),we(Ae,Ue,Ca,"","\\@jmath"),we(Ae,Ue,mn,"ı","ı"),we(Ae,Ue,mn,"ȷ","ȷ"),we(si,Ue,mn,"ı","\\i",!0),we(si,Ue,mn,"ȷ","\\j",!0),we(si,Ue,mn,"ß","\\ss",!0),we(si,Ue,mn,"æ","\\ae",!0),we(si,Ue,mn,"œ","\\oe",!0),we(si,Ue,mn,"ø","\\o",!0),we(si,Ue,mn,"Æ","\\AE",!0),we(si,Ue,mn,"Œ","\\OE",!0),we(si,Ue,mn,"Ø","\\O",!0),we(si,Ue,wh,"ˊ","\\'"),we(si,Ue,wh,"ˋ","\\`"),we(si,Ue,wh,"ˆ","\\^"),we(si,Ue,wh,"˜","\\~"),we(si,Ue,wh,"ˉ","\\="),we(si,Ue,wh,"˘","\\u"),we(si,Ue,wh,"˙","\\."),we(si,Ue,wh,"¸","\\c"),we(si,Ue,wh,"˚","\\r"),we(si,Ue,wh,"ˇ","\\v"),we(si,Ue,wh,"¨",'\\"'),we(si,Ue,wh,"˝","\\H"),we(si,Ue,wh,"◯","\\textcircled");var rze={"--":!0,"---":!0,"``":!0,"''":!0};we(si,Ue,mn,"–","--",!0),we(si,Ue,mn,"–","\\textendash"),we(si,Ue,mn,"—","---",!0),we(si,Ue,mn,"—","\\textemdash"),we(si,Ue,mn,"‘","`",!0),we(si,Ue,mn,"‘","\\textquoteleft"),we(si,Ue,mn,"’","'",!0),we(si,Ue,mn,"’","\\textquoteright"),we(si,Ue,mn,"“","``",!0),we(si,Ue,mn,"“","\\textquotedblleft"),we(si,Ue,mn,"”","''",!0),we(si,Ue,mn,"”","\\textquotedblright"),we(Ae,Ue,mn,"°","\\degree",!0),we(si,Ue,mn,"°","\\degree"),we(si,Ue,mn,"°","\\textdegree",!0),we(Ae,Ue,mn,"£","\\pounds"),we(Ae,Ue,mn,"£","\\mathsterling",!0),we(si,Ue,mn,"£","\\pounds"),we(si,Ue,mn,"£","\\textsterling",!0),we(Ae,$t,mn,"✠","\\maltese"),we(si,$t,mn,"✠","\\maltese");for(var ize='0123456789/@."',rbe=0;rbe0)return F3(v,_,p,u,b.concat(A));if(T){var P,R;if(T==="boldsymbol"){var F=mHt(v,p,u,b,d);P=F.fontName,R=[F.fontClass]}else y?(P=hze[T].fontName,R=[T]):(P=dQ(T,u.fontWeight,u.fontShape),R=[T,u.fontWeight,u.fontShape]);if(fQ(v,P,p).metrics)return F3(v,P,p,u,b.concat(R));if(rze.hasOwnProperty(v)&&P.slice(0,10)==="Typewriter"){for(var j=[],K=0;K{if(T9(i.classes)!==T9(s.classes)||i.skew!==s.skew||i.maxFontSize!==s.maxFontSize)return!1;if(i.classes.length===1){var u=i.classes[0];if(u==="mbin"||u==="mord")return!1}for(var d in i.style)if(i.style.hasOwnProperty(d)&&i.style[d]!==s.style[d])return!1;for(var p in s.style)if(s.style.hasOwnProperty(p)&&i.style[p]!==s.style[p])return!1;return!0},yHt=i=>{for(var s=0;su&&(u=b.height),b.depth>d&&(d=b.depth),b.maxFontSize>p&&(p=b.maxFontSize)}s.height=u,s.depth=d,s.maxFontSize=p},R2=function(s,u,d,p){var v=new cR(s,u,d,p);return cbe(v),v},uze=(i,s,u,d)=>new cR(i,s,u,d),xHt=function(s,u,d){var p=R2([s],[],u);return p.height=Math.max(d||u.fontMetrics().defaultRuleThickness,u.minRuleThickness),p.style.borderBottomWidth=Ri(p.height),p.maxFontSize=1,p},kHt=function(s,u,d,p){var v=new tbe(s,u,d,p);return cbe(v),v},lze=function(s){var u=new oR(s);return cbe(u),u},EHt=function(s,u){return s instanceof oR?R2([],[s],u):s},THt=function(s){if(s.positionType==="individualShift"){for(var u=s.children,d=[u[0]],p=-u[0].shift-u[0].elem.depth,v=p,b=1;b{var u=R2(["mspace"],[],s),d=Uh(i,s);return u.style.marginRight=Ri(d),u},dQ=function(s,u,d){var p="";switch(s){case"amsrm":p="AMS";break;case"textrm":p="Main";break;case"textsf":p="SansSerif";break;case"texttt":p="Typewriter";break;default:p=s}var v;return u==="textbf"&&d==="textit"?v="BoldItalic":u==="textbf"?v="Bold":u==="textit"?v="Italic":v="Regular",p+"-"+v},hze={mathbf:{variant:"bold",fontName:"Main-Bold"},mathrm:{variant:"normal",fontName:"Main-Regular"},textit:{variant:"italic",fontName:"Main-Italic"},mathit:{variant:"italic",fontName:"Main-Italic"},mathnormal:{variant:"italic",fontName:"Math-Italic"},mathbb:{variant:"double-struck",fontName:"AMS-Regular"},mathcal:{variant:"script",fontName:"Caligraphic-Regular"},mathfrak:{variant:"fraktur",fontName:"Fraktur-Regular"},mathscr:{variant:"script",fontName:"Script-Regular"},mathsf:{variant:"sans-serif",fontName:"SansSerif-Regular"},mathtt:{variant:"monospace",fontName:"Typewriter-Regular"}},fze={vec:["vec",.471,.714],oiintSize1:["oiintSize1",.957,.499],oiintSize2:["oiintSize2",1.472,.659],oiiintSize1:["oiiintSize1",1.304,.499],oiiintSize2:["oiiintSize2",1.98,.659]},_Ht=function(s,u){var[d,p,v]=fze[s],b=new C9(d),y=new D7([b],{width:Ri(p),height:Ri(v),style:"width:"+Ri(p),viewBox:"0 0 "+1e3*p+" "+1e3*v,preserveAspectRatio:"xMinYMin"}),T=uze(["overlay"],[y],u);return T.height=v,T.style.height=Ri(v),T.style.width=Ri(p),T},zn={fontMap:hze,makeSymbol:F3,mathsym:bHt,makeSpan:R2,makeSvgSpan:uze,makeLineSpan:xHt,makeAnchor:kHt,makeFragment:lze,wrapFragment:EHt,makeVList:CHt,makeOrd:vHt,makeGlue:SHt,staticSvg:_Ht,svgData:fze,tryCombineChars:yHt},Gh={number:3,unit:"mu"},$C={number:4,unit:"mu"},O7={number:5,unit:"mu"},AHt={mord:{mop:Gh,mbin:$C,mrel:O7,minner:Gh},mop:{mord:Gh,mop:Gh,mrel:O7,minner:Gh},mbin:{mord:$C,mop:$C,mopen:$C,minner:$C},mrel:{mord:O7,mop:O7,mopen:O7,minner:O7},mopen:{},mclose:{mop:Gh,mbin:$C,mrel:O7,minner:Gh},mpunct:{mord:Gh,mop:Gh,mrel:O7,mopen:Gh,mclose:Gh,mpunct:Gh,minner:Gh},minner:{mord:Gh,mop:Gh,mbin:$C,mrel:O7,mopen:Gh,mpunct:Gh,minner:Gh}},LHt={mord:{mop:Gh},mop:{mord:Gh,mop:Gh},mbin:{},mrel:{},mopen:{},mclose:{mop:Gh},mpunct:{},minner:{mop:Gh}},dze={},gQ={},pQ={};function Ji(i){for(var{type:s,names:u,props:d,handler:p,htmlBuilder:v,mathmlBuilder:b}=i,y={type:s,numArgs:d.numArgs,argTypes:d.argTypes,allowedInArgument:!!d.allowedInArgument,allowedInText:!!d.allowedInText,allowedInMath:d.allowedInMath===void 0?!0:d.allowedInMath,numOptionalArgs:d.numOptionalArgs||0,infix:!!d.infix,primitive:!!d.primitive,handler:p},T=0;T{var ee=K.classes[0],ie=j.classes[0];ee==="mbin"&&Ya.contains(DHt,ie)?K.classes[0]="mord":ie==="mbin"&&Ya.contains(MHt,ee)&&(j.classes[0]="mord")},{node:P},R,F),gze(v,(j,K)=>{var ee=ube(K),ie=ube(j),oe=ee&&ie?j.hasClass("mtight")?LHt[ee][ie]:AHt[ee][ie]:null;if(oe)return zn.makeGlue(oe,_)},{node:P},R,F),v},gze=function i(s,u,d,p,v){p&&s.push(p);for(var b=0;bR=>{s.splice(P+1,0,R),b++})(b)}p&&s.pop()},pze=function(s){return s instanceof oR||s instanceof tbe||s instanceof cR&&s.hasClass("enclosing")?s:null},NHt=function i(s,u){var d=pze(s);if(d){var p=d.children;if(p.length){if(u==="right")return i(p[p.length-1],"right");if(u==="left")return i(p[0],"left")}}return s},ube=function(s,u){return s?(u&&(s=NHt(s,u)),OHt[s.classes[0]]||null):null},uR=function(s,u){var d=["nulldelimiter"].concat(s.baseSizingClasses());return N7(u.concat(d))},uu=function(s,u,d){if(!s)return N7();if(gQ[s.type]){var p=gQ[s.type](s,u);if(d&&u.size!==d.size){p=N7(u.sizingClasses(d),[p],u);var v=u.sizeMultiplier/d.sizeMultiplier;p.height*=v,p.depth*=v}return p}else throw new Ci("Got group of unknown type: '"+s.type+"'")};function mQ(i,s){var u=N7(["base"],i,s),d=N7(["strut"]);return d.style.height=Ri(u.height+u.depth),u.depth&&(d.style.verticalAlign=Ri(-u.depth)),u.children.unshift(d),u}function lbe(i,s){var u=null;i.length===1&&i[0].type==="tag"&&(u=i[0].tag,i=i[0].body);var d=d1(i,s,"root"),p;d.length===2&&d[1].hasClass("tag")&&(p=d.pop());for(var v=[],b=[],y=0;y0&&(v.push(mQ(b,s)),b=[]),v.push(d[y]));b.length>0&&v.push(mQ(b,s));var _;u?(_=mQ(d1(u,s,!0)),_.classes=["tag"],v.push(_)):p&&v.push(p);var A=N7(["katex-html"],v);if(A.setAttribute("aria-hidden","true"),_){var P=_.children[0];P.style.height=Ri(A.height+A.depth),A.depth&&(P.style.verticalAlign=Ri(-A.depth))}return A}function bze(i){return new oR(i)}class Fv{constructor(s,u,d){this.type=void 0,this.attributes=void 0,this.children=void 0,this.classes=void 0,this.type=s,this.attributes={},this.children=u||[],this.classes=d||[]}setAttribute(s,u){this.attributes[s]=u}getAttribute(s){return this.attributes[s]}toNode(){var s=document.createElementNS("http://www.w3.org/1998/Math/MathML",this.type);for(var u in this.attributes)Object.prototype.hasOwnProperty.call(this.attributes,u)&&s.setAttribute(u,this.attributes[u]);this.classes.length>0&&(s.className=T9(this.classes));for(var d=0;d0&&(s+=' class ="'+Ya.escape(T9(this.classes))+'"'),s+=">";for(var d=0;d",s}toText(){return this.children.map(s=>s.toText()).join("")}}class lR{constructor(s){this.text=void 0,this.text=s}toNode(){return document.createTextNode(this.text)}toMarkup(){return Ya.escape(this.toText())}toText(){return this.text}}class PHt{constructor(s){this.width=void 0,this.character=void 0,this.width=s,s>=.05555&&s<=.05556?this.character=" ":s>=.1666&&s<=.1667?this.character=" ":s>=.2222&&s<=.2223?this.character=" ":s>=.2777&&s<=.2778?this.character="  ":s>=-.05556&&s<=-.05555?this.character=" ⁣":s>=-.1667&&s<=-.1666?this.character=" ⁣":s>=-.2223&&s<=-.2222?this.character=" ⁣":s>=-.2778&&s<=-.2777?this.character=" ⁣":this.character=null}toNode(){if(this.character)return document.createTextNode(this.character);var s=document.createElementNS("http://www.w3.org/1998/Math/MathML","mspace");return s.setAttribute("width",Ri(this.width)),s}toMarkup(){return this.character?""+this.character+"":''}toText(){return this.character?this.character:" "}}var vi={MathNode:Fv,TextNode:lR,SpaceNode:PHt,newDocumentFragment:bze},Rv=function(s,u,d){return Ul[u][s]&&Ul[u][s].replace&&s.charCodeAt(0)!==55349&&!(rze.hasOwnProperty(s)&&d&&(d.fontFamily&&d.fontFamily.slice(4,6)==="tt"||d.font&&d.font.slice(4,6)==="tt"))&&(s=Ul[u][s].replace),new vi.TextNode(s)},hbe=function(s){return s.length===1?s[0]:new vi.MathNode("mrow",s)},fbe=function(s,u){if(u.fontFamily==="texttt")return"monospace";if(u.fontFamily==="textsf")return u.fontShape==="textit"&&u.fontWeight==="textbf"?"sans-serif-bold-italic":u.fontShape==="textit"?"sans-serif-italic":u.fontWeight==="textbf"?"bold-sans-serif":"sans-serif";if(u.fontShape==="textit"&&u.fontWeight==="textbf")return"bold-italic";if(u.fontShape==="textit")return"italic";if(u.fontWeight==="textbf")return"bold";var d=u.font;if(!d||d==="mathnormal")return null;var p=s.mode;if(d==="mathit")return"italic";if(d==="boldsymbol")return s.type==="textord"?"bold":"bold-italic";if(d==="mathbf")return"bold";if(d==="mathbb")return"double-struck";if(d==="mathfrak")return"fraktur";if(d==="mathscr"||d==="mathcal")return"script";if(d==="mathsf")return"sans-serif";if(d==="mathtt")return"monospace";var v=s.text;if(Ya.contains(["\\imath","\\jmath"],v))return null;Ul[p][v]&&Ul[p][v].replace&&(v=Ul[p][v].replace);var b=zn.fontMap[d].fontName;return J2e(v,b,p)?zn.fontMap[d].variant:null},j2=function(s,u,d){if(s.length===1){var p=Ll(s[0],u);return d&&p instanceof Fv&&p.type==="mo"&&(p.setAttribute("lspace","0em"),p.setAttribute("rspace","0em")),[p]}for(var v=[],b,y=0;y0&&(P.text=P.text.slice(0,1)+"̸"+P.text.slice(1),v.pop())}}}v.push(T),b=T}return v},_9=function(s,u,d){return hbe(j2(s,u,d))},Ll=function(s,u){if(!s)return new vi.MathNode("mrow");if(pQ[s.type]){var d=pQ[s.type](s,u);return d}else throw new Ci("Got group of unknown type: '"+s.type+"'")};function mze(i,s,u,d,p){var v=j2(i,u),b;v.length===1&&v[0]instanceof Fv&&Ya.contains(["mrow","mtable"],v[0].type)?b=v[0]:b=new vi.MathNode("mrow",v);var y=new vi.MathNode("annotation",[new vi.TextNode(s)]);y.setAttribute("encoding","application/x-tex");var T=new vi.MathNode("semantics",[b,y]),_=new vi.MathNode("math",[T]);_.setAttribute("xmlns","http://www.w3.org/1998/Math/MathML"),d&&_.setAttribute("display","block");var A=p?"katex":"katex-mathml";return zn.makeSpan([A],[_])}var vze=function(s){return new M7({style:s.displayMode?Ta.DISPLAY:Ta.TEXT,maxSize:s.maxSize,minRuleThickness:s.minRuleThickness})},wze=function(s,u){if(u.displayMode){var d=["katex-display"];u.leqno&&d.push("leqno"),u.fleqn&&d.push("fleqn"),s=zn.makeSpan(d,[s])}return s},BHt=function(s,u,d){var p=vze(d),v;if(d.output==="mathml")return mze(s,u,p,d.displayMode,!0);if(d.output==="html"){var b=lbe(s,p);v=zn.makeSpan(["katex"],[b])}else{var y=mze(s,u,p,d.displayMode,!1),T=lbe(s,p);v=zn.makeSpan(["katex"],[y,T])}return wze(v,d)},FHt=function(s,u,d){var p=vze(d),v=lbe(s,p),b=zn.makeSpan(["katex"],[v]);return wze(b,d)},RHt={widehat:"^",widecheck:"ˇ",widetilde:"~",utilde:"~",overleftarrow:"←",underleftarrow:"←",xleftarrow:"←",overrightarrow:"→",underrightarrow:"→",xrightarrow:"→",underbrace:"⏟",overbrace:"⏞",overgroup:"⏠",undergroup:"⏡",overleftrightarrow:"↔",underleftrightarrow:"↔",xleftrightarrow:"↔",Overrightarrow:"⇒",xRightarrow:"⇒",overleftharpoon:"↼",xleftharpoonup:"↼",overrightharpoon:"⇀",xrightharpoonup:"⇀",xLeftarrow:"⇐",xLeftrightarrow:"⇔",xhookleftarrow:"↩",xhookrightarrow:"↪",xmapsto:"↦",xrightharpoondown:"⇁",xleftharpoondown:"↽",xrightleftharpoons:"⇌",xleftrightharpoons:"⇋",xtwoheadleftarrow:"↞",xtwoheadrightarrow:"↠",xlongequal:"=",xtofrom:"⇄",xrightleftarrows:"⇄",xrightequilibrium:"⇌",xleftequilibrium:"⇋","\\cdrightarrow":"→","\\cdleftarrow":"←","\\cdlongequal":"="},jHt=function(s){var u=new vi.MathNode("mo",[new vi.TextNode(RHt[s.replace(/^\\/,"")])]);return u.setAttribute("stretchy","true"),u},$Ht={overrightarrow:[["rightarrow"],.888,522,"xMaxYMin"],overleftarrow:[["leftarrow"],.888,522,"xMinYMin"],underrightarrow:[["rightarrow"],.888,522,"xMaxYMin"],underleftarrow:[["leftarrow"],.888,522,"xMinYMin"],xrightarrow:[["rightarrow"],1.469,522,"xMaxYMin"],"\\cdrightarrow":[["rightarrow"],3,522,"xMaxYMin"],xleftarrow:[["leftarrow"],1.469,522,"xMinYMin"],"\\cdleftarrow":[["leftarrow"],3,522,"xMinYMin"],Overrightarrow:[["doublerightarrow"],.888,560,"xMaxYMin"],xRightarrow:[["doublerightarrow"],1.526,560,"xMaxYMin"],xLeftarrow:[["doubleleftarrow"],1.526,560,"xMinYMin"],overleftharpoon:[["leftharpoon"],.888,522,"xMinYMin"],xleftharpoonup:[["leftharpoon"],.888,522,"xMinYMin"],xleftharpoondown:[["leftharpoondown"],.888,522,"xMinYMin"],overrightharpoon:[["rightharpoon"],.888,522,"xMaxYMin"],xrightharpoonup:[["rightharpoon"],.888,522,"xMaxYMin"],xrightharpoondown:[["rightharpoondown"],.888,522,"xMaxYMin"],xlongequal:[["longequal"],.888,334,"xMinYMin"],"\\cdlongequal":[["longequal"],3,334,"xMinYMin"],xtwoheadleftarrow:[["twoheadleftarrow"],.888,334,"xMinYMin"],xtwoheadrightarrow:[["twoheadrightarrow"],.888,334,"xMaxYMin"],overleftrightarrow:[["leftarrow","rightarrow"],.888,522],overbrace:[["leftbrace","midbrace","rightbrace"],1.6,548],underbrace:[["leftbraceunder","midbraceunder","rightbraceunder"],1.6,548],underleftrightarrow:[["leftarrow","rightarrow"],.888,522],xleftrightarrow:[["leftarrow","rightarrow"],1.75,522],xLeftrightarrow:[["doubleleftarrow","doublerightarrow"],1.75,560],xrightleftharpoons:[["leftharpoondownplus","rightharpoonplus"],1.75,716],xleftrightharpoons:[["leftharpoonplus","rightharpoondownplus"],1.75,716],xhookleftarrow:[["leftarrow","righthook"],1.08,522],xhookrightarrow:[["lefthook","rightarrow"],1.08,522],overlinesegment:[["leftlinesegment","rightlinesegment"],.888,522],underlinesegment:[["leftlinesegment","rightlinesegment"],.888,522],overgroup:[["leftgroup","rightgroup"],.888,342],undergroup:[["leftgroupunder","rightgroupunder"],.888,342],xmapsto:[["leftmapsto","rightarrow"],1.5,522],xtofrom:[["leftToFrom","rightToFrom"],1.75,528],xrightleftarrows:[["baraboveleftarrow","rightarrowabovebar"],1.75,901],xrightequilibrium:[["baraboveshortleftharpoon","rightharpoonaboveshortbar"],1.75,716],xleftequilibrium:[["shortbaraboveleftharpoon","shortrightharpoonabovebar"],1.75,716]},zHt=function(s){return s.type==="ordgroup"?s.body.length:1},qHt=function(s,u){function d(){var y=4e5,T=s.label.slice(1);if(Ya.contains(["widehat","widecheck","widetilde","utilde"],T)){var _=s,A=zHt(_.base),P,R,F;if(A>5)T==="widehat"||T==="widecheck"?(P=420,y=2364,F=.42,R=T+"4"):(P=312,y=2340,F=.34,R="tilde4");else{var j=[1,1,2,2,3,3][A];T==="widehat"||T==="widecheck"?(y=[0,1062,2364,2364,2364][j],P=[0,239,300,360,420][j],F=[0,.24,.3,.3,.36,.42][j],R=T+j):(y=[0,600,1033,2339,2340][j],P=[0,260,286,306,312][j],F=[0,.26,.286,.3,.306,.34][j],R="tilde"+j)}var K=new C9(R),ee=new D7([K],{width:"100%",height:Ri(F),viewBox:"0 0 "+y+" "+P,preserveAspectRatio:"none"});return{span:zn.makeSvgSpan([],[ee],u),minWidth:0,height:F}}else{var ie=[],oe=$Ht[T],[pe,be,ae]=oe,ne=ae/1e3,se=pe.length,de,X;if(se===1){var ge=oe[3];de=["hide-tail"],X=[ge]}else if(se===2)de=["halfarrow-left","halfarrow-right"],X=["xMinYMin","xMaxYMin"];else if(se===3)de=["brace-left","brace-center","brace-right"],X=["xMinYMin","xMidYMin","xMaxYMin"];else throw new Error(`Correct katexImagesData or update code here to support + `+se+" children.");for(var W=0;W0&&(p.style.minWidth=Ri(v)),p},HHt=function(s,u,d,p,v){var b,y=s.height+s.depth+d+p;if(/fbox|color|angl/.test(u)){if(b=zn.makeSpan(["stretchy",u],[],v),u==="fbox"){var T=v.color&&v.getColor();T&&(b.style.borderColor=T)}}else{var _=[];/^[bx]cancel$/.test(u)&&_.push(new nbe({x1:"0",y1:"0",x2:"100%",y2:"100%","stroke-width":"0.046em"})),/^x?cancel$/.test(u)&&_.push(new nbe({x1:"0",y1:"100%",x2:"100%",y2:"0","stroke-width":"0.046em"}));var A=new D7(_,{width:"100%",height:Ri(y)});b=zn.makeSvgSpan([],[A],v)}return b.height=y,b.style.height=Ri(y),b},P7={encloseSpan:HHt,mathMLnode:jHt,svgSpan:qHt};function Yo(i,s){if(!i||i.type!==s)throw new Error("Expected node of type "+s+", but got "+(i?"node of type "+i.type:String(i)));return i}function dbe(i){var s=vQ(i);if(!s)throw new Error("Expected node of symbol group type, but got "+(i?"node of type "+i.type:String(i)));return s}function vQ(i){return i&&(i.type==="atom"||gHt.hasOwnProperty(i.type))?i:null}var gbe=(i,s)=>{var u,d,p;i&&i.type==="supsub"?(d=Yo(i.base,"accent"),u=d.base,i.base=u,p=fHt(uu(i,s)),i.base=d):(d=Yo(i,"accent"),u=d.base);var v=uu(u,s.havingCrampedStyle()),b=d.isShifty&&Ya.isCharacterBox(u),y=0;if(b){var T=Ya.getBaseElem(u),_=uu(T,s.havingCrampedStyle());y=nze(_).skew}var A=d.label==="\\c",P=A?v.height+v.depth:Math.min(v.height,s.fontMetrics().xHeight),R;if(d.isStretchy)R=P7.svgSpan(d,s),R=zn.makeVList({positionType:"firstBaseline",children:[{type:"elem",elem:v},{type:"elem",elem:R,wrapperClasses:["svg-align"],wrapperStyle:y>0?{width:"calc(100% - "+Ri(2*y)+")",marginLeft:Ri(2*y)}:void 0}]},s);else{var F,j;d.label==="\\vec"?(F=zn.staticSvg("vec",s),j=zn.svgData.vec[1]):(F=zn.makeOrd({mode:d.mode,text:d.label},s,"textord"),F=nze(F),F.italic=0,j=F.width,A&&(P+=F.depth)),R=zn.makeSpan(["accent-body"],[F]);var K=d.label==="\\textcircled";K&&(R.classes.push("accent-full"),P=v.height);var ee=y;K||(ee-=j/2),R.style.left=Ri(ee),d.label==="\\textcircled"&&(R.style.top=".2em"),R=zn.makeVList({positionType:"firstBaseline",children:[{type:"elem",elem:v},{type:"kern",size:-P},{type:"elem",elem:R}]},s)}var ie=zn.makeSpan(["mord","accent"],[R],s);return p?(p.children[0]=ie,p.height=Math.max(ie.height,p.height),p.classes[0]="mord",p):ie},yze=(i,s)=>{var u=i.isStretchy?P7.mathMLnode(i.label):new vi.MathNode("mo",[Rv(i.label,i.mode)]),d=new vi.MathNode("mover",[Ll(i.base,s),u]);return d.setAttribute("accent","true"),d},VHt=new RegExp(["\\acute","\\grave","\\ddot","\\tilde","\\bar","\\breve","\\check","\\hat","\\vec","\\dot","\\mathring"].map(i=>"\\"+i).join("|"));Ji({type:"accent",names:["\\acute","\\grave","\\ddot","\\tilde","\\bar","\\breve","\\check","\\hat","\\vec","\\dot","\\mathring","\\widecheck","\\widehat","\\widetilde","\\overrightarrow","\\overleftarrow","\\Overrightarrow","\\overleftrightarrow","\\overgroup","\\overlinesegment","\\overleftharpoon","\\overrightharpoon"],props:{numArgs:1},handler:(i,s)=>{var u=bQ(s[0]),d=!VHt.test(i.funcName),p=!d||i.funcName==="\\widehat"||i.funcName==="\\widetilde"||i.funcName==="\\widecheck";return{type:"accent",mode:i.parser.mode,label:i.funcName,isStretchy:d,isShifty:p,base:u}},htmlBuilder:gbe,mathmlBuilder:yze}),Ji({type:"accent",names:["\\'","\\`","\\^","\\~","\\=","\\u","\\.",'\\"',"\\c","\\r","\\H","\\v","\\textcircled"],props:{numArgs:1,allowedInText:!0,allowedInMath:!0,argTypes:["primitive"]},handler:(i,s)=>{var u=s[0],d=i.parser.mode;return d==="math"&&(i.parser.settings.reportNonstrict("mathVsTextAccents","LaTeX's accent "+i.funcName+" works only in text mode"),d="text"),{type:"accent",mode:d,label:i.funcName,isStretchy:!1,isShifty:!0,base:u}},htmlBuilder:gbe,mathmlBuilder:yze}),Ji({type:"accentUnder",names:["\\underleftarrow","\\underrightarrow","\\underleftrightarrow","\\undergroup","\\underlinesegment","\\utilde"],props:{numArgs:1},handler:(i,s)=>{var{parser:u,funcName:d}=i,p=s[0];return{type:"accentUnder",mode:u.mode,label:d,base:p}},htmlBuilder:(i,s)=>{var u=uu(i.base,s),d=P7.svgSpan(i,s),p=i.label==="\\utilde"?.12:0,v=zn.makeVList({positionType:"top",positionData:u.height,children:[{type:"elem",elem:d,wrapperClasses:["svg-align"]},{type:"kern",size:p},{type:"elem",elem:u}]},s);return zn.makeSpan(["mord","accentunder"],[v],s)},mathmlBuilder:(i,s)=>{var u=P7.mathMLnode(i.label),d=new vi.MathNode("munder",[Ll(i.base,s),u]);return d.setAttribute("accentunder","true"),d}});var wQ=i=>{var s=new vi.MathNode("mpadded",i?[i]:[]);return s.setAttribute("width","+0.6em"),s.setAttribute("lspace","0.3em"),s};Ji({type:"xArrow",names:["\\xleftarrow","\\xrightarrow","\\xLeftarrow","\\xRightarrow","\\xleftrightarrow","\\xLeftrightarrow","\\xhookleftarrow","\\xhookrightarrow","\\xmapsto","\\xrightharpoondown","\\xrightharpoonup","\\xleftharpoondown","\\xleftharpoonup","\\xrightleftharpoons","\\xleftrightharpoons","\\xlongequal","\\xtwoheadrightarrow","\\xtwoheadleftarrow","\\xtofrom","\\xrightleftarrows","\\xrightequilibrium","\\xleftequilibrium","\\\\cdrightarrow","\\\\cdleftarrow","\\\\cdlongequal"],props:{numArgs:1,numOptionalArgs:1},handler(i,s,u){var{parser:d,funcName:p}=i;return{type:"xArrow",mode:d.mode,label:p,body:s[0],below:u[0]}},htmlBuilder(i,s){var u=s.style,d=s.havingStyle(u.sup()),p=zn.wrapFragment(uu(i.body,d,s),s),v=i.label.slice(0,2)==="\\x"?"x":"cd";p.classes.push(v+"-arrow-pad");var b;i.below&&(d=s.havingStyle(u.sub()),b=zn.wrapFragment(uu(i.below,d,s),s),b.classes.push(v+"-arrow-pad"));var y=P7.svgSpan(i,s),T=-s.fontMetrics().axisHeight+.5*y.height,_=-s.fontMetrics().axisHeight-.5*y.height-.111;(p.depth>.25||i.label==="\\xleftequilibrium")&&(_-=p.depth);var A;if(b){var P=-s.fontMetrics().axisHeight+b.height+.5*y.height+.111;A=zn.makeVList({positionType:"individualShift",children:[{type:"elem",elem:p,shift:_},{type:"elem",elem:y,shift:T},{type:"elem",elem:b,shift:P}]},s)}else A=zn.makeVList({positionType:"individualShift",children:[{type:"elem",elem:p,shift:_},{type:"elem",elem:y,shift:T}]},s);return A.children[0].children[0].children[1].classes.push("svg-align"),zn.makeSpan(["mrel","x-arrow"],[A],s)},mathmlBuilder(i,s){var u=P7.mathMLnode(i.label);u.setAttribute("minsize",i.label.charAt(0)==="x"?"1.75em":"3.0em");var d;if(i.body){var p=wQ(Ll(i.body,s));if(i.below){var v=wQ(Ll(i.below,s));d=new vi.MathNode("munderover",[u,v,p])}else d=new vi.MathNode("mover",[u,p])}else if(i.below){var b=wQ(Ll(i.below,s));d=new vi.MathNode("munder",[u,b])}else d=wQ(),d=new vi.MathNode("mover",[u,d]);return d}});var UHt=zn.makeSpan;function xze(i,s){var u=d1(i.body,s,!0);return UHt([i.mclass],u,s)}function kze(i,s){var u,d=j2(i.body,s);return i.mclass==="minner"?u=new vi.MathNode("mpadded",d):i.mclass==="mord"?i.isCharacterBox?(u=d[0],u.type="mi"):u=new vi.MathNode("mi",d):(i.isCharacterBox?(u=d[0],u.type="mo"):u=new vi.MathNode("mo",d),i.mclass==="mbin"?(u.attributes.lspace="0.22em",u.attributes.rspace="0.22em"):i.mclass==="mpunct"?(u.attributes.lspace="0em",u.attributes.rspace="0.17em"):i.mclass==="mopen"||i.mclass==="mclose"?(u.attributes.lspace="0em",u.attributes.rspace="0em"):i.mclass==="minner"&&(u.attributes.lspace="0.0556em",u.attributes.width="+0.1111em")),u}Ji({type:"mclass",names:["\\mathord","\\mathbin","\\mathrel","\\mathopen","\\mathclose","\\mathpunct","\\mathinner"],props:{numArgs:1,primitive:!0},handler(i,s){var{parser:u,funcName:d}=i,p=s[0];return{type:"mclass",mode:u.mode,mclass:"m"+d.slice(5),body:Xf(p),isCharacterBox:Ya.isCharacterBox(p)}},htmlBuilder:xze,mathmlBuilder:kze});var yQ=i=>{var s=i.type==="ordgroup"&&i.body.length?i.body[0]:i;return s.type==="atom"&&(s.family==="bin"||s.family==="rel")?"m"+s.family:"mord"};Ji({type:"mclass",names:["\\@binrel"],props:{numArgs:2},handler(i,s){var{parser:u}=i;return{type:"mclass",mode:u.mode,mclass:yQ(s[0]),body:Xf(s[1]),isCharacterBox:Ya.isCharacterBox(s[1])}}}),Ji({type:"mclass",names:["\\stackrel","\\overset","\\underset"],props:{numArgs:2},handler(i,s){var{parser:u,funcName:d}=i,p=s[1],v=s[0],b;d!=="\\stackrel"?b=yQ(p):b="mrel";var y={type:"op",mode:p.mode,limits:!0,alwaysHandleSupSub:!0,parentIsSupSub:!1,symbol:!1,suppressBaseShift:d!=="\\stackrel",body:Xf(p)},T={type:"supsub",mode:v.mode,base:y,sup:d==="\\underset"?null:v,sub:d==="\\underset"?v:null};return{type:"mclass",mode:u.mode,mclass:b,body:[T],isCharacterBox:Ya.isCharacterBox(T)}},htmlBuilder:xze,mathmlBuilder:kze}),Ji({type:"pmb",names:["\\pmb"],props:{numArgs:1,allowedInText:!0},handler(i,s){var{parser:u}=i;return{type:"pmb",mode:u.mode,mclass:yQ(s[0]),body:Xf(s[0])}},htmlBuilder(i,s){var u=d1(i.body,s,!0),d=zn.makeSpan([i.mclass],u,s);return d.style.textShadow="0.02em 0.01em 0.04px",d},mathmlBuilder(i,s){var u=j2(i.body,s),d=new vi.MathNode("mstyle",u);return d.setAttribute("style","text-shadow: 0.02em 0.01em 0.04px"),d}});var GHt={">":"\\\\cdrightarrow","<":"\\\\cdleftarrow","=":"\\\\cdlongequal",A:"\\uparrow",V:"\\downarrow","|":"\\Vert",".":"no arrow"},Eze=()=>({type:"styling",body:[],mode:"math",style:"display"}),Tze=i=>i.type==="textord"&&i.text==="@",KHt=(i,s)=>(i.type==="mathord"||i.type==="atom")&&i.text===s;function WHt(i,s,u){var d=GHt[i];switch(d){case"\\\\cdrightarrow":case"\\\\cdleftarrow":return u.callFunction(d,[s[0]],[s[1]]);case"\\uparrow":case"\\downarrow":{var p=u.callFunction("\\\\cdleft",[s[0]],[]),v={type:"atom",text:d,mode:"math",family:"rel"},b=u.callFunction("\\Big",[v],[]),y=u.callFunction("\\\\cdright",[s[1]],[]),T={type:"ordgroup",mode:"math",body:[p,b,y]};return u.callFunction("\\\\cdparent",[T],[])}case"\\\\cdlongequal":return u.callFunction("\\\\cdlongequal",[],[]);case"\\Vert":{var _={type:"textord",text:"\\Vert",mode:"math"};return u.callFunction("\\Big",[_],[])}default:return{type:"textord",text:" ",mode:"math"}}}function YHt(i){var s=[];for(i.gullet.beginGroup(),i.gullet.macros.set("\\cr","\\\\\\relax"),i.gullet.beginGroup();;){s.push(i.parseExpression(!1,"\\\\")),i.gullet.endGroup(),i.gullet.beginGroup();var u=i.fetch().text;if(u==="&"||u==="\\\\")i.consume();else if(u==="\\end"){s[s.length-1].length===0&&s.pop();break}else throw new Ci("Expected \\\\ or \\cr or \\end",i.nextToken)}for(var d=[],p=[d],v=0;v-1))if("<>AV".indexOf(_)>-1)for(var P=0;P<2;P++){for(var R=!0,F=T+1;FAV=|." after @',b[T]);var j=WHt(_,A,i),K={type:"styling",body:[j],mode:"math",style:"display"};d.push(K),y=Eze()}v%2===0?d.push(y):d.shift(),d=[],p.push(d)}i.gullet.endGroup(),i.gullet.endGroup();var ee=new Array(p[0].length).fill({type:"align",align:"c",pregap:.25,postgap:.25});return{type:"array",mode:"math",body:p,arraystretch:1,addJot:!0,rowGaps:[null],cols:ee,colSeparationType:"CD",hLinesBeforeRow:new Array(p.length+1).fill([])}}Ji({type:"cdlabel",names:["\\\\cdleft","\\\\cdright"],props:{numArgs:1},handler(i,s){var{parser:u,funcName:d}=i;return{type:"cdlabel",mode:u.mode,side:d.slice(4),label:s[0]}},htmlBuilder(i,s){var u=s.havingStyle(s.style.sup()),d=zn.wrapFragment(uu(i.label,u,s),s);return d.classes.push("cd-label-"+i.side),d.style.bottom=Ri(.8-d.depth),d.height=0,d.depth=0,d},mathmlBuilder(i,s){var u=new vi.MathNode("mrow",[Ll(i.label,s)]);return u=new vi.MathNode("mpadded",[u]),u.setAttribute("width","0"),i.side==="left"&&u.setAttribute("lspace","-1width"),u.setAttribute("voffset","0.7em"),u=new vi.MathNode("mstyle",[u]),u.setAttribute("displaystyle","false"),u.setAttribute("scriptlevel","1"),u}}),Ji({type:"cdlabelparent",names:["\\\\cdparent"],props:{numArgs:1},handler(i,s){var{parser:u}=i;return{type:"cdlabelparent",mode:u.mode,fragment:s[0]}},htmlBuilder(i,s){var u=zn.wrapFragment(uu(i.fragment,s),s);return u.classes.push("cd-vert-arrow"),u},mathmlBuilder(i,s){return new vi.MathNode("mrow",[Ll(i.fragment,s)])}}),Ji({type:"textord",names:["\\@char"],props:{numArgs:1,allowedInText:!0},handler(i,s){for(var{parser:u}=i,d=Yo(s[0],"ordgroup"),p=d.body,v="",b=0;b=1114111)throw new Ci("\\@char with invalid code point "+v);return T<=65535?_=String.fromCharCode(T):(T-=65536,_=String.fromCharCode((T>>10)+55296,(T&1023)+56320)),{type:"textord",mode:u.mode,text:_}}});var Cze=(i,s)=>{var u=d1(i.body,s.withColor(i.color),!1);return zn.makeFragment(u)},Sze=(i,s)=>{var u=j2(i.body,s.withColor(i.color)),d=new vi.MathNode("mstyle",u);return d.setAttribute("mathcolor",i.color),d};Ji({type:"color",names:["\\textcolor"],props:{numArgs:2,allowedInText:!0,argTypes:["color","original"]},handler(i,s){var{parser:u}=i,d=Yo(s[0],"color-token").color,p=s[1];return{type:"color",mode:u.mode,color:d,body:Xf(p)}},htmlBuilder:Cze,mathmlBuilder:Sze}),Ji({type:"color",names:["\\color"],props:{numArgs:1,allowedInText:!0,argTypes:["color"]},handler(i,s){var{parser:u,breakOnTokenText:d}=i,p=Yo(s[0],"color-token").color;u.gullet.macros.set("\\current@color",p);var v=u.parseExpression(!0,d);return{type:"color",mode:u.mode,color:p,body:v}},htmlBuilder:Cze,mathmlBuilder:Sze}),Ji({type:"cr",names:["\\\\"],props:{numArgs:0,numOptionalArgs:0,allowedInText:!0},handler(i,s,u){var{parser:d}=i,p=d.gullet.future().text==="["?d.parseSizeGroup(!0):null,v=!d.settings.displayMode||!d.settings.useStrictBehavior("newLineInDisplayMode","In LaTeX, \\\\ or \\newline does nothing in display mode");return{type:"cr",mode:d.mode,newLine:v,size:p&&Yo(p,"size").value}},htmlBuilder(i,s){var u=zn.makeSpan(["mspace"],[],s);return i.newLine&&(u.classes.push("newline"),i.size&&(u.style.marginTop=Ri(Uh(i.size,s)))),u},mathmlBuilder(i,s){var u=new vi.MathNode("mspace");return i.newLine&&(u.setAttribute("linebreak","newline"),i.size&&u.setAttribute("height",Ri(Uh(i.size,s)))),u}});var pbe={"\\global":"\\global","\\long":"\\\\globallong","\\\\globallong":"\\\\globallong","\\def":"\\gdef","\\gdef":"\\gdef","\\edef":"\\xdef","\\xdef":"\\xdef","\\let":"\\\\globallet","\\futurelet":"\\\\globalfuture"},_ze=i=>{var s=i.text;if(/^(?:[\\{}$&#^_]|EOF)$/.test(s))throw new Ci("Expected a control sequence",i);return s},XHt=i=>{var s=i.gullet.popToken();return s.text==="="&&(s=i.gullet.popToken(),s.text===" "&&(s=i.gullet.popToken())),s},Aze=(i,s,u,d)=>{var p=i.gullet.macros.get(u.text);p==null&&(u.noexpand=!0,p={tokens:[u],numArgs:0,unexpandable:!i.gullet.isExpandable(u.text)}),i.gullet.macros.set(s,p,d)};Ji({type:"internal",names:["\\global","\\long","\\\\globallong"],props:{numArgs:0,allowedInText:!0},handler(i){var{parser:s,funcName:u}=i;s.consumeSpaces();var d=s.fetch();if(pbe[d.text])return(u==="\\global"||u==="\\\\globallong")&&(d.text=pbe[d.text]),Yo(s.parseFunction(),"internal");throw new Ci("Invalid token after macro prefix",d)}}),Ji({type:"internal",names:["\\def","\\gdef","\\edef","\\xdef"],props:{numArgs:0,allowedInText:!0,primitive:!0},handler(i){var{parser:s,funcName:u}=i,d=s.gullet.popToken(),p=d.text;if(/^(?:[\\{}$&#^_]|EOF)$/.test(p))throw new Ci("Expected a control sequence",d);for(var v=0,b,y=[[]];s.gullet.future().text!=="{";)if(d=s.gullet.popToken(),d.text==="#"){if(s.gullet.future().text==="{"){b=s.gullet.future(),y[v].push("{");break}if(d=s.gullet.popToken(),!/^[1-9]$/.test(d.text))throw new Ci('Invalid argument number "'+d.text+'"');if(parseInt(d.text)!==v+1)throw new Ci('Argument number "'+d.text+'" out of order');v++,y.push([])}else{if(d.text==="EOF")throw new Ci("Expected a macro definition");y[v].push(d.text)}var{tokens:T}=s.gullet.consumeArg();return b&&T.unshift(b),(u==="\\edef"||u==="\\xdef")&&(T=s.gullet.expandTokens(T),T.reverse()),s.gullet.macros.set(p,{tokens:T,numArgs:v,delimiters:y},u===pbe[u]),{type:"internal",mode:s.mode}}}),Ji({type:"internal",names:["\\let","\\\\globallet"],props:{numArgs:0,allowedInText:!0,primitive:!0},handler(i){var{parser:s,funcName:u}=i,d=_ze(s.gullet.popToken());s.gullet.consumeSpaces();var p=XHt(s);return Aze(s,d,p,u==="\\\\globallet"),{type:"internal",mode:s.mode}}}),Ji({type:"internal",names:["\\futurelet","\\\\globalfuture"],props:{numArgs:0,allowedInText:!0,primitive:!0},handler(i){var{parser:s,funcName:u}=i,d=_ze(s.gullet.popToken()),p=s.gullet.popToken(),v=s.gullet.popToken();return Aze(s,d,v,u==="\\\\globalfuture"),s.gullet.pushToken(v),s.gullet.pushToken(p),{type:"internal",mode:s.mode}}});var hR=function(s,u,d){var p=Ul.math[s]&&Ul.math[s].replace,v=J2e(p||s,u,d);if(!v)throw new Error("Unsupported symbol "+s+" and font size "+u+".");return v},bbe=function(s,u,d,p){var v=d.havingBaseStyle(u),b=zn.makeSpan(p.concat(v.sizingClasses(d)),[s],d),y=v.sizeMultiplier/d.sizeMultiplier;return b.height*=y,b.depth*=y,b.maxFontSize=v.sizeMultiplier,b},Lze=function(s,u,d){var p=u.havingBaseStyle(d),v=(1-u.sizeMultiplier/p.sizeMultiplier)*u.fontMetrics().axisHeight;s.classes.push("delimcenter"),s.style.top=Ri(v),s.height-=v,s.depth+=v},QHt=function(s,u,d,p,v,b){var y=zn.makeSymbol(s,"Main-Regular",v,p),T=bbe(y,u,p,b);return d&&Lze(T,p,u),T},JHt=function(s,u,d,p){return zn.makeSymbol(s,"Size"+u+"-Regular",d,p)},Mze=function(s,u,d,p,v,b){var y=JHt(s,u,v,p),T=bbe(zn.makeSpan(["delimsizing","size"+u],[y],p),Ta.TEXT,p,b);return d&&Lze(T,p,Ta.TEXT),T},mbe=function(s,u,d){var p;u==="Size1-Regular"?p="delim-size1":p="delim-size4";var v=zn.makeSpan(["delimsizinginner",p],[zn.makeSpan([],[zn.makeSymbol(s,u,d)])]);return{type:"elem",elem:v}},vbe=function(s,u,d){var p=K4["Size4-Regular"][s.charCodeAt(0)]?K4["Size4-Regular"][s.charCodeAt(0)][4]:K4["Size1-Regular"][s.charCodeAt(0)][4],v=new C9("inner",iHt(s,Math.round(1e3*u))),b=new D7([v],{width:Ri(p),height:Ri(u),style:"width:"+Ri(p),viewBox:"0 0 "+1e3*p+" "+Math.round(1e3*u),preserveAspectRatio:"xMinYMin"}),y=zn.makeSvgSpan([],[b],d);return y.height=u,y.style.height=Ri(u),y.style.width=Ri(p),{type:"elem",elem:y}},wbe=.008,xQ={type:"kern",size:-1*wbe},ZHt=["|","\\lvert","\\rvert","\\vert"],eVt=["\\|","\\lVert","\\rVert","\\Vert"],Dze=function(s,u,d,p,v,b){var y,T,_,A,P="",R=0;y=_=A=s,T=null;var F="Size1-Regular";s==="\\uparrow"?_=A="⏐":s==="\\Uparrow"?_=A="‖":s==="\\downarrow"?y=_="⏐":s==="\\Downarrow"?y=_="‖":s==="\\updownarrow"?(y="\\uparrow",_="⏐",A="\\downarrow"):s==="\\Updownarrow"?(y="\\Uparrow",_="‖",A="\\Downarrow"):Ya.contains(ZHt,s)?(_="∣",P="vert",R=333):Ya.contains(eVt,s)?(_="∥",P="doublevert",R=556):s==="["||s==="\\lbrack"?(y="⎡",_="⎢",A="⎣",F="Size4-Regular",P="lbrack",R=667):s==="]"||s==="\\rbrack"?(y="⎤",_="⎥",A="⎦",F="Size4-Regular",P="rbrack",R=667):s==="\\lfloor"||s==="⌊"?(_=y="⎢",A="⎣",F="Size4-Regular",P="lfloor",R=667):s==="\\lceil"||s==="⌈"?(y="⎡",_=A="⎢",F="Size4-Regular",P="lceil",R=667):s==="\\rfloor"||s==="⌋"?(_=y="⎥",A="⎦",F="Size4-Regular",P="rfloor",R=667):s==="\\rceil"||s==="⌉"?(y="⎤",_=A="⎥",F="Size4-Regular",P="rceil",R=667):s==="("||s==="\\lparen"?(y="⎛",_="⎜",A="⎝",F="Size4-Regular",P="lparen",R=875):s===")"||s==="\\rparen"?(y="⎞",_="⎟",A="⎠",F="Size4-Regular",P="rparen",R=875):s==="\\{"||s==="\\lbrace"?(y="⎧",T="⎨",A="⎩",_="⎪",F="Size4-Regular"):s==="\\}"||s==="\\rbrace"?(y="⎫",T="⎬",A="⎭",_="⎪",F="Size4-Regular"):s==="\\lgroup"||s==="⟮"?(y="⎧",A="⎩",_="⎪",F="Size4-Regular"):s==="\\rgroup"||s==="⟯"?(y="⎫",A="⎭",_="⎪",F="Size4-Regular"):s==="\\lmoustache"||s==="⎰"?(y="⎧",A="⎭",_="⎪",F="Size4-Regular"):(s==="\\rmoustache"||s==="⎱")&&(y="⎫",A="⎩",_="⎪",F="Size4-Regular");var j=hR(y,F,v),K=j.height+j.depth,ee=hR(_,F,v),ie=ee.height+ee.depth,oe=hR(A,F,v),pe=oe.height+oe.depth,be=0,ae=1;if(T!==null){var ne=hR(T,F,v);be=ne.height+ne.depth,ae=2}var se=K+pe+be,de=Math.max(0,Math.ceil((u-se)/(ae*ie))),X=se+de*ae*ie,ge=p.fontMetrics().axisHeight;d&&(ge*=p.sizeMultiplier);var W=X/2-ge,xe=[];if(P.length>0){var U=X-K-pe,Fe=Math.round(X*1e3),Pe=sHt(P,Math.round(U*1e3)),je=new C9(P,Pe),Ie=(R/1e3).toFixed(3)+"em",Se=(Fe/1e3).toFixed(3)+"em",Ce=new D7([je],{width:Ie,height:Se,viewBox:"0 0 "+R+" "+Fe}),ke=zn.makeSvgSpan([],[Ce],p);ke.height=Fe/1e3,ke.style.width=Ie,ke.style.height=Se,xe.push({type:"elem",elem:ke})}else{if(xe.push(mbe(A,F,v)),xe.push(xQ),T===null){var Ke=X-K-pe+2*wbe;xe.push(vbe(_,Ke,p))}else{var Ft=(X-K-pe-be)/2+2*wbe;xe.push(vbe(_,Ft,p)),xe.push(xQ),xe.push(mbe(T,F,v)),xe.push(xQ),xe.push(vbe(_,Ft,p))}xe.push(xQ),xe.push(mbe(y,F,v))}var Ne=p.havingBaseStyle(Ta.TEXT),gn=zn.makeVList({positionType:"bottom",positionData:W,children:xe},Ne);return bbe(zn.makeSpan(["delimsizing","mult"],[gn],Ne),Ta.TEXT,p,b)},ybe=80,xbe=.08,kbe=function(s,u,d,p,v){var b=rHt(s,p,d),y=new C9(s,b),T=new D7([y],{width:"400em",height:Ri(u),viewBox:"0 0 400000 "+d,preserveAspectRatio:"xMinYMin slice"});return zn.makeSvgSpan(["hide-tail"],[T],v)},tVt=function(s,u){var d=u.havingBaseSizing(),p=Pze("\\surd",s*d.sizeMultiplier,Nze,d),v=d.sizeMultiplier,b=Math.max(0,u.minRuleThickness-u.fontMetrics().sqrtRuleThickness),y,T=0,_=0,A=0,P;return p.type==="small"?(A=1e3+1e3*b+ybe,s<1?v=1:s<1.4&&(v=.7),T=(1+b+xbe)/v,_=(1+b)/v,y=kbe("sqrtMain",T,A,b,u),y.style.minWidth="0.853em",P=.833/v):p.type==="large"?(A=(1e3+ybe)*fR[p.size],_=(fR[p.size]+b)/v,T=(fR[p.size]+b+xbe)/v,y=kbe("sqrtSize"+p.size,T,A,b,u),y.style.minWidth="1.02em",P=1/v):(T=s+b+xbe,_=s+b,A=Math.floor(1e3*s+b)+ybe,y=kbe("sqrtTall",T,A,b,u),y.style.minWidth="0.742em",P=1.056),y.height=_,y.style.height=Ri(T),{span:y,advanceWidth:P,ruleWidth:(u.fontMetrics().sqrtRuleThickness+b)*v}},Ize=["(","\\lparen",")","\\rparen","[","\\lbrack","]","\\rbrack","\\{","\\lbrace","\\}","\\rbrace","\\lfloor","\\rfloor","⌊","⌋","\\lceil","\\rceil","⌈","⌉","\\surd"],nVt=["\\uparrow","\\downarrow","\\updownarrow","\\Uparrow","\\Downarrow","\\Updownarrow","|","\\|","\\vert","\\Vert","\\lvert","\\rvert","\\lVert","\\rVert","\\lgroup","\\rgroup","⟮","⟯","\\lmoustache","\\rmoustache","⎰","⎱"],Oze=["<",">","\\langle","\\rangle","/","\\backslash","\\lt","\\gt"],fR=[0,1.2,1.8,2.4,3],rVt=function(s,u,d,p,v){if(s==="<"||s==="\\lt"||s==="⟨"?s="\\langle":(s===">"||s==="\\gt"||s==="⟩")&&(s="\\rangle"),Ya.contains(Ize,s)||Ya.contains(Oze,s))return Mze(s,u,!1,d,p,v);if(Ya.contains(nVt,s))return Dze(s,fR[u],!1,d,p,v);throw new Ci("Illegal delimiter: '"+s+"'")},iVt=[{type:"small",style:Ta.SCRIPTSCRIPT},{type:"small",style:Ta.SCRIPT},{type:"small",style:Ta.TEXT},{type:"large",size:1},{type:"large",size:2},{type:"large",size:3},{type:"large",size:4}],sVt=[{type:"small",style:Ta.SCRIPTSCRIPT},{type:"small",style:Ta.SCRIPT},{type:"small",style:Ta.TEXT},{type:"stack"}],Nze=[{type:"small",style:Ta.SCRIPTSCRIPT},{type:"small",style:Ta.SCRIPT},{type:"small",style:Ta.TEXT},{type:"large",size:1},{type:"large",size:2},{type:"large",size:3},{type:"large",size:4},{type:"stack"}],aVt=function(s){if(s.type==="small")return"Main-Regular";if(s.type==="large")return"Size"+s.size+"-Regular";if(s.type==="stack")return"Size4-Regular";throw new Error("Add support for delim type '"+s.type+"' here.")},Pze=function(s,u,d,p){for(var v=Math.min(2,3-p.style.size),b=v;bu)return d[b]}return d[d.length-1]},Bze=function(s,u,d,p,v,b){s==="<"||s==="\\lt"||s==="⟨"?s="\\langle":(s===">"||s==="\\gt"||s==="⟩")&&(s="\\rangle");var y;Ya.contains(Oze,s)?y=iVt:Ya.contains(Ize,s)?y=Nze:y=sVt;var T=Pze(s,u,y,p);return T.type==="small"?QHt(s,T.style,d,p,v,b):T.type==="large"?Mze(s,T.size,d,p,v,b):Dze(s,u,d,p,v,b)},oVt=function(s,u,d,p,v,b){var y=p.fontMetrics().axisHeight*p.sizeMultiplier,T=901,_=5/p.fontMetrics().ptPerEm,A=Math.max(u-y,d+y),P=Math.max(A/500*T,2*A-_);return Bze(s,P,!0,p,v,b)},B7={sqrtImage:tVt,sizedDelim:rVt,sizeToMaxHeight:fR,customSizedDelim:Bze,leftRightDelim:oVt},Fze={"\\bigl":{mclass:"mopen",size:1},"\\Bigl":{mclass:"mopen",size:2},"\\biggl":{mclass:"mopen",size:3},"\\Biggl":{mclass:"mopen",size:4},"\\bigr":{mclass:"mclose",size:1},"\\Bigr":{mclass:"mclose",size:2},"\\biggr":{mclass:"mclose",size:3},"\\Biggr":{mclass:"mclose",size:4},"\\bigm":{mclass:"mrel",size:1},"\\Bigm":{mclass:"mrel",size:2},"\\biggm":{mclass:"mrel",size:3},"\\Biggm":{mclass:"mrel",size:4},"\\big":{mclass:"mord",size:1},"\\Big":{mclass:"mord",size:2},"\\bigg":{mclass:"mord",size:3},"\\Bigg":{mclass:"mord",size:4}},cVt=["(","\\lparen",")","\\rparen","[","\\lbrack","]","\\rbrack","\\{","\\lbrace","\\}","\\rbrace","\\lfloor","\\rfloor","⌊","⌋","\\lceil","\\rceil","⌈","⌉","<",">","\\langle","⟨","\\rangle","⟩","\\lt","\\gt","\\lvert","\\rvert","\\lVert","\\rVert","\\lgroup","\\rgroup","⟮","⟯","\\lmoustache","\\rmoustache","⎰","⎱","/","\\backslash","|","\\vert","\\|","\\Vert","\\uparrow","\\Uparrow","\\downarrow","\\Downarrow","\\updownarrow","\\Updownarrow","."];function kQ(i,s){var u=vQ(i);if(u&&Ya.contains(cVt,u.text))return u;throw u?new Ci("Invalid delimiter '"+u.text+"' after '"+s.funcName+"'",i):new Ci("Invalid delimiter type '"+i.type+"'",i)}Ji({type:"delimsizing",names:["\\bigl","\\Bigl","\\biggl","\\Biggl","\\bigr","\\Bigr","\\biggr","\\Biggr","\\bigm","\\Bigm","\\biggm","\\Biggm","\\big","\\Big","\\bigg","\\Bigg"],props:{numArgs:1,argTypes:["primitive"]},handler:(i,s)=>{var u=kQ(s[0],i);return{type:"delimsizing",mode:i.parser.mode,size:Fze[i.funcName].size,mclass:Fze[i.funcName].mclass,delim:u.text}},htmlBuilder:(i,s)=>i.delim==="."?zn.makeSpan([i.mclass]):B7.sizedDelim(i.delim,i.size,s,i.mode,[i.mclass]),mathmlBuilder:i=>{var s=[];i.delim!=="."&&s.push(Rv(i.delim,i.mode));var u=new vi.MathNode("mo",s);i.mclass==="mopen"||i.mclass==="mclose"?u.setAttribute("fence","true"):u.setAttribute("fence","false"),u.setAttribute("stretchy","true");var d=Ri(B7.sizeToMaxHeight[i.size]);return u.setAttribute("minsize",d),u.setAttribute("maxsize",d),u}});function Rze(i){if(!i.body)throw new Error("Bug: The leftright ParseNode wasn't fully parsed.")}Ji({type:"leftright-right",names:["\\right"],props:{numArgs:1,primitive:!0},handler:(i,s)=>{var u=i.parser.gullet.macros.get("\\current@color");if(u&&typeof u!="string")throw new Ci("\\current@color set to non-string in \\right");return{type:"leftright-right",mode:i.parser.mode,delim:kQ(s[0],i).text,color:u}}}),Ji({type:"leftright",names:["\\left"],props:{numArgs:1,primitive:!0},handler:(i,s)=>{var u=kQ(s[0],i),d=i.parser;++d.leftrightDepth;var p=d.parseExpression(!1);--d.leftrightDepth,d.expect("\\right",!1);var v=Yo(d.parseFunction(),"leftright-right");return{type:"leftright",mode:d.mode,body:p,left:u.text,right:v.delim,rightColor:v.color}},htmlBuilder:(i,s)=>{Rze(i);for(var u=d1(i.body,s,!0,["mopen","mclose"]),d=0,p=0,v=!1,b=0;b{Rze(i);var u=j2(i.body,s);if(i.left!=="."){var d=new vi.MathNode("mo",[Rv(i.left,i.mode)]);d.setAttribute("fence","true"),u.unshift(d)}if(i.right!=="."){var p=new vi.MathNode("mo",[Rv(i.right,i.mode)]);p.setAttribute("fence","true"),i.rightColor&&p.setAttribute("mathcolor",i.rightColor),u.push(p)}return hbe(u)}}),Ji({type:"middle",names:["\\middle"],props:{numArgs:1,primitive:!0},handler:(i,s)=>{var u=kQ(s[0],i);if(!i.parser.leftrightDepth)throw new Ci("\\middle without preceding \\left",u);return{type:"middle",mode:i.parser.mode,delim:u.text}},htmlBuilder:(i,s)=>{var u;if(i.delim===".")u=uR(s,[]);else{u=B7.sizedDelim(i.delim,1,s,i.mode,[]);var d={delim:i.delim,options:s};u.isMiddle=d}return u},mathmlBuilder:(i,s)=>{var u=i.delim==="\\vert"||i.delim==="|"?Rv("|","text"):Rv(i.delim,i.mode),d=new vi.MathNode("mo",[u]);return d.setAttribute("fence","true"),d.setAttribute("lspace","0.05em"),d.setAttribute("rspace","0.05em"),d}});var Ebe=(i,s)=>{var u=zn.wrapFragment(uu(i.body,s),s),d=i.label.slice(1),p=s.sizeMultiplier,v,b=0,y=Ya.isCharacterBox(i.body);if(d==="sout")v=zn.makeSpan(["stretchy","sout"]),v.height=s.fontMetrics().defaultRuleThickness/p,b=-.5*s.fontMetrics().xHeight;else if(d==="phase"){var T=Uh({number:.6,unit:"pt"},s),_=Uh({number:.35,unit:"ex"},s),A=s.havingBaseSizing();p=p/A.sizeMultiplier;var P=u.height+u.depth+T+_;u.style.paddingLeft=Ri(P/2+T);var R=Math.floor(1e3*P*p),F=tHt(R),j=new D7([new C9("phase",F)],{width:"400em",height:Ri(R/1e3),viewBox:"0 0 400000 "+R,preserveAspectRatio:"xMinYMin slice"});v=zn.makeSvgSpan(["hide-tail"],[j],s),v.style.height=Ri(P),b=u.depth+T+_}else{/cancel/.test(d)?y||u.classes.push("cancel-pad"):d==="angl"?u.classes.push("anglpad"):u.classes.push("boxpad");var K=0,ee=0,ie=0;/box/.test(d)?(ie=Math.max(s.fontMetrics().fboxrule,s.minRuleThickness),K=s.fontMetrics().fboxsep+(d==="colorbox"?0:ie),ee=K):d==="angl"?(ie=Math.max(s.fontMetrics().defaultRuleThickness,s.minRuleThickness),K=4*ie,ee=Math.max(0,.25-u.depth)):(K=y?.2:0,ee=K),v=P7.encloseSpan(u,d,K,ee,s),/fbox|boxed|fcolorbox/.test(d)?(v.style.borderStyle="solid",v.style.borderWidth=Ri(ie)):d==="angl"&&ie!==.049&&(v.style.borderTopWidth=Ri(ie),v.style.borderRightWidth=Ri(ie)),b=u.depth+ee,i.backgroundColor&&(v.style.backgroundColor=i.backgroundColor,i.borderColor&&(v.style.borderColor=i.borderColor))}var oe;if(i.backgroundColor)oe=zn.makeVList({positionType:"individualShift",children:[{type:"elem",elem:v,shift:b},{type:"elem",elem:u,shift:0}]},s);else{var pe=/cancel|phase/.test(d)?["svg-align"]:[];oe=zn.makeVList({positionType:"individualShift",children:[{type:"elem",elem:u,shift:0},{type:"elem",elem:v,shift:b,wrapperClasses:pe}]},s)}return/cancel/.test(d)&&(oe.height=u.height,oe.depth=u.depth),/cancel/.test(d)&&!y?zn.makeSpan(["mord","cancel-lap"],[oe],s):zn.makeSpan(["mord"],[oe],s)},Tbe=(i,s)=>{var u=0,d=new vi.MathNode(i.label.indexOf("colorbox")>-1?"mpadded":"menclose",[Ll(i.body,s)]);switch(i.label){case"\\cancel":d.setAttribute("notation","updiagonalstrike");break;case"\\bcancel":d.setAttribute("notation","downdiagonalstrike");break;case"\\phase":d.setAttribute("notation","phasorangle");break;case"\\sout":d.setAttribute("notation","horizontalstrike");break;case"\\fbox":d.setAttribute("notation","box");break;case"\\angl":d.setAttribute("notation","actuarial");break;case"\\fcolorbox":case"\\colorbox":if(u=s.fontMetrics().fboxsep*s.fontMetrics().ptPerEm,d.setAttribute("width","+"+2*u+"pt"),d.setAttribute("height","+"+2*u+"pt"),d.setAttribute("lspace",u+"pt"),d.setAttribute("voffset",u+"pt"),i.label==="\\fcolorbox"){var p=Math.max(s.fontMetrics().fboxrule,s.minRuleThickness);d.setAttribute("style","border: "+p+"em solid "+String(i.borderColor))}break;case"\\xcancel":d.setAttribute("notation","updiagonalstrike downdiagonalstrike");break}return i.backgroundColor&&d.setAttribute("mathbackground",i.backgroundColor),d};Ji({type:"enclose",names:["\\colorbox"],props:{numArgs:2,allowedInText:!0,argTypes:["color","text"]},handler(i,s,u){var{parser:d,funcName:p}=i,v=Yo(s[0],"color-token").color,b=s[1];return{type:"enclose",mode:d.mode,label:p,backgroundColor:v,body:b}},htmlBuilder:Ebe,mathmlBuilder:Tbe}),Ji({type:"enclose",names:["\\fcolorbox"],props:{numArgs:3,allowedInText:!0,argTypes:["color","color","text"]},handler(i,s,u){var{parser:d,funcName:p}=i,v=Yo(s[0],"color-token").color,b=Yo(s[1],"color-token").color,y=s[2];return{type:"enclose",mode:d.mode,label:p,backgroundColor:b,borderColor:v,body:y}},htmlBuilder:Ebe,mathmlBuilder:Tbe}),Ji({type:"enclose",names:["\\fbox"],props:{numArgs:1,argTypes:["hbox"],allowedInText:!0},handler(i,s){var{parser:u}=i;return{type:"enclose",mode:u.mode,label:"\\fbox",body:s[0]}}}),Ji({type:"enclose",names:["\\cancel","\\bcancel","\\xcancel","\\sout","\\phase"],props:{numArgs:1},handler(i,s){var{parser:u,funcName:d}=i,p=s[0];return{type:"enclose",mode:u.mode,label:d,body:p}},htmlBuilder:Ebe,mathmlBuilder:Tbe}),Ji({type:"enclose",names:["\\angl"],props:{numArgs:1,argTypes:["hbox"],allowedInText:!1},handler(i,s){var{parser:u}=i;return{type:"enclose",mode:u.mode,label:"\\angl",body:s[0]}}});var jze={};function W4(i){for(var{type:s,names:u,props:d,handler:p,htmlBuilder:v,mathmlBuilder:b}=i,y={type:s,numArgs:d.numArgs||0,allowedInText:!1,numOptionalArgs:0,handler:p},T=0;T{var s=i.parser.settings;if(!s.displayMode)throw new Ci("{"+i.envName+"} can be used only in display mode.")};function Cbe(i){if(i.indexOf("ed")===-1)return i.indexOf("*")===-1}function A9(i,s,u){var{hskipBeforeAndAfter:d,addJot:p,cols:v,arraystretch:b,colSeparationType:y,autoTag:T,singleRow:_,emptySingleRow:A,maxNumCols:P,leqno:R}=s;if(i.gullet.beginGroup(),_||i.gullet.macros.set("\\cr","\\\\\\relax"),!b){var F=i.gullet.expandMacroAsText("\\arraystretch");if(F==null)b=1;else if(b=parseFloat(F),!b||b<0)throw new Ci("Invalid \\arraystretch: "+F)}i.gullet.beginGroup();var j=[],K=[j],ee=[],ie=[],oe=T!=null?[]:void 0;function pe(){T&&i.gullet.macros.set("\\@eqnsw","1",!0)}function be(){oe&&(i.gullet.macros.get("\\df@tag")?(oe.push(i.subparse([new U4("\\df@tag")])),i.gullet.macros.set("\\df@tag",void 0,!0)):oe.push(!!T&&i.gullet.macros.get("\\@eqnsw")==="1"))}for(pe(),ie.push(zze(i));;){var ae=i.parseExpression(!1,_?"\\end":"\\\\");i.gullet.endGroup(),i.gullet.beginGroup(),ae={type:"ordgroup",mode:i.mode,body:ae},u&&(ae={type:"styling",mode:i.mode,style:u,body:[ae]}),j.push(ae);var ne=i.fetch().text;if(ne==="&"){if(P&&j.length===P){if(_||y)throw new Ci("Too many tab characters: &",i.nextToken);i.settings.reportNonstrict("textEnv","Too few columns specified in the {array} column argument.")}i.consume()}else if(ne==="\\end"){be(),j.length===1&&ae.type==="styling"&&ae.body[0].body.length===0&&(K.length>1||!A)&&K.pop(),ie.length0&&(pe+=.25),_.push({pos:pe,isDashed:ji[xi]})}for(be(b[0]),d=0;d0&&(W+=oe,seji))for(d=0;d=y)){var Gt=void 0;(p>0||s.hskipBeforeAndAfter)&&(Gt=Ya.deflt(Ft.pregap,R),Gt!==0&&(Pe=zn.makeSpan(["arraycolsep"],[]),Pe.style.width=Ri(Gt),Fe.push(Pe)));var ln=[];for(d=0;d0){for(var Dt=zn.makeLineSpan("hline",u,A),kt=zn.makeLineSpan("hdashline",u,A),On=[{type:"elem",elem:T,shift:0}];_.length>0;){var ht=_.pop(),zr=ht.pos-xe;ht.isDashed?On.push({type:"elem",elem:kt,shift:zr}):On.push({type:"elem",elem:Dt,shift:zr})}T=zn.makeVList({positionType:"individualShift",children:On},u)}if(Ie.length===0)return zn.makeSpan(["mord"],[T],u);var yt=zn.makeVList({positionType:"individualShift",children:Ie},u);return yt=zn.makeSpan(["tag"],[yt],u),zn.makeFragment([T,yt])},uVt={c:"center ",l:"left ",r:"right "},X4=function(s,u){for(var d=[],p=new vi.MathNode("mtd",[],["mtr-glue"]),v=new vi.MathNode("mtd",[],["mml-eqn-num"]),b=0;b0){var j=s.cols,K="",ee=!1,ie=0,oe=j.length;j[0].type==="separator"&&(R+="top ",ie=1),j[j.length-1].type==="separator"&&(R+="bottom ",oe-=1);for(var pe=ie;pe0?"left ":"",R+=de[de.length-1].length>0?"right ":"";for(var X=1;X-1?"alignat":"align",v=s.envName==="split",b=A9(s.parser,{cols:d,addJot:!0,autoTag:v?void 0:Cbe(s.envName),emptySingleRow:!0,colSeparationType:p,maxNumCols:v?2:void 0,leqno:s.parser.settings.leqno},"display"),y,T=0,_={type:"ordgroup",mode:s.mode,body:[]};if(u[0]&&u[0].type==="ordgroup"){for(var A="",P=0;P0&&F&&(ee=1),d[j]={type:"align",align:K,pregap:ee,postgap:0}}return b.colSeparationType=F?"align":"alignat",b};W4({type:"array",names:["array","darray"],props:{numArgs:1},handler(i,s){var u=vQ(s[0]),d=u?[s[0]]:Yo(s[0],"ordgroup").body,p=d.map(function(b){var y=dbe(b),T=y.text;if("lcr".indexOf(T)!==-1)return{type:"align",align:T};if(T==="|")return{type:"separator",separator:"|"};if(T===":")return{type:"separator",separator:":"};throw new Ci("Unknown column alignment: "+T,b)}),v={cols:p,hskipBeforeAndAfter:!0,maxNumCols:p.length};return A9(i.parser,v,Sbe(i.envName))},htmlBuilder:Y4,mathmlBuilder:X4}),W4({type:"array",names:["matrix","pmatrix","bmatrix","Bmatrix","vmatrix","Vmatrix","matrix*","pmatrix*","bmatrix*","Bmatrix*","vmatrix*","Vmatrix*"],props:{numArgs:0},handler(i){var s={matrix:null,pmatrix:["(",")"],bmatrix:["[","]"],Bmatrix:["\\{","\\}"],vmatrix:["|","|"],Vmatrix:["\\Vert","\\Vert"]}[i.envName.replace("*","")],u="c",d={hskipBeforeAndAfter:!1,cols:[{type:"align",align:u}]};if(i.envName.charAt(i.envName.length-1)==="*"){var p=i.parser;if(p.consumeSpaces(),p.fetch().text==="["){if(p.consume(),p.consumeSpaces(),u=p.fetch().text,"lcr".indexOf(u)===-1)throw new Ci("Expected l or c or r",p.nextToken);p.consume(),p.consumeSpaces(),p.expect("]"),p.consume(),d.cols=[{type:"align",align:u}]}}var v=A9(i.parser,d,Sbe(i.envName)),b=Math.max(0,...v.body.map(y=>y.length));return v.cols=new Array(b).fill({type:"align",align:u}),s?{type:"leftright",mode:i.mode,body:[v],left:s[0],right:s[1],rightColor:void 0}:v},htmlBuilder:Y4,mathmlBuilder:X4}),W4({type:"array",names:["smallmatrix"],props:{numArgs:0},handler(i){var s={arraystretch:.5},u=A9(i.parser,s,"script");return u.colSeparationType="small",u},htmlBuilder:Y4,mathmlBuilder:X4}),W4({type:"array",names:["subarray"],props:{numArgs:1},handler(i,s){var u=vQ(s[0]),d=u?[s[0]]:Yo(s[0],"ordgroup").body,p=d.map(function(b){var y=dbe(b),T=y.text;if("lc".indexOf(T)!==-1)return{type:"align",align:T};throw new Ci("Unknown column alignment: "+T,b)});if(p.length>1)throw new Ci("{subarray} can contain only one column");var v={cols:p,hskipBeforeAndAfter:!1,arraystretch:.5};if(v=A9(i.parser,v,"script"),v.body.length>0&&v.body[0].length>1)throw new Ci("{subarray} can contain only one column");return v},htmlBuilder:Y4,mathmlBuilder:X4}),W4({type:"array",names:["cases","dcases","rcases","drcases"],props:{numArgs:0},handler(i){var s={arraystretch:1.2,cols:[{type:"align",align:"l",pregap:0,postgap:1},{type:"align",align:"l",pregap:0,postgap:0}]},u=A9(i.parser,s,Sbe(i.envName));return{type:"leftright",mode:i.mode,body:[u],left:i.envName.indexOf("r")>-1?".":"\\{",right:i.envName.indexOf("r")>-1?"\\}":".",rightColor:void 0}},htmlBuilder:Y4,mathmlBuilder:X4}),W4({type:"array",names:["align","align*","aligned","split"],props:{numArgs:0},handler:qze,htmlBuilder:Y4,mathmlBuilder:X4}),W4({type:"array",names:["gathered","gather","gather*"],props:{numArgs:0},handler(i){Ya.contains(["gather","gather*"],i.envName)&&EQ(i);var s={cols:[{type:"align",align:"c"}],addJot:!0,colSeparationType:"gather",autoTag:Cbe(i.envName),emptySingleRow:!0,leqno:i.parser.settings.leqno};return A9(i.parser,s,"display")},htmlBuilder:Y4,mathmlBuilder:X4}),W4({type:"array",names:["alignat","alignat*","alignedat"],props:{numArgs:1},handler:qze,htmlBuilder:Y4,mathmlBuilder:X4}),W4({type:"array",names:["equation","equation*"],props:{numArgs:0},handler(i){EQ(i);var s={autoTag:Cbe(i.envName),emptySingleRow:!0,singleRow:!0,maxNumCols:1,leqno:i.parser.settings.leqno};return A9(i.parser,s,"display")},htmlBuilder:Y4,mathmlBuilder:X4}),W4({type:"array",names:["CD"],props:{numArgs:0},handler(i){return EQ(i),YHt(i.parser)},htmlBuilder:Y4,mathmlBuilder:X4}),et("\\nonumber","\\gdef\\@eqnsw{0}"),et("\\notag","\\nonumber"),Ji({type:"text",names:["\\hline","\\hdashline"],props:{numArgs:0,allowedInText:!0,allowedInMath:!0},handler(i,s){throw new Ci(i.funcName+" valid only within array environment")}});var Hze=jze;Ji({type:"environment",names:["\\begin","\\end"],props:{numArgs:1,argTypes:["text"]},handler(i,s){var{parser:u,funcName:d}=i,p=s[0];if(p.type!=="ordgroup")throw new Ci("Invalid environment name",p);for(var v="",b=0;b{var u=i.font,d=s.withFont(u);return uu(i.body,d)},Uze=(i,s)=>{var u=i.font,d=s.withFont(u);return Ll(i.body,d)},Gze={"\\Bbb":"\\mathbb","\\bold":"\\mathbf","\\frak":"\\mathfrak","\\bm":"\\boldsymbol"};Ji({type:"font",names:["\\mathrm","\\mathit","\\mathbf","\\mathnormal","\\mathbb","\\mathcal","\\mathfrak","\\mathscr","\\mathsf","\\mathtt","\\Bbb","\\bold","\\frak"],props:{numArgs:1,allowedInArgument:!0},handler:(i,s)=>{var{parser:u,funcName:d}=i,p=bQ(s[0]),v=d;return v in Gze&&(v=Gze[v]),{type:"font",mode:u.mode,font:v.slice(1),body:p}},htmlBuilder:Vze,mathmlBuilder:Uze}),Ji({type:"mclass",names:["\\boldsymbol","\\bm"],props:{numArgs:1},handler:(i,s)=>{var{parser:u}=i,d=s[0],p=Ya.isCharacterBox(d);return{type:"mclass",mode:u.mode,mclass:yQ(d),body:[{type:"font",mode:u.mode,font:"boldsymbol",body:d}],isCharacterBox:p}}}),Ji({type:"font",names:["\\rm","\\sf","\\tt","\\bf","\\it","\\cal"],props:{numArgs:0,allowedInText:!0},handler:(i,s)=>{var{parser:u,funcName:d,breakOnTokenText:p}=i,{mode:v}=u,b=u.parseExpression(!0,p),y="math"+d.slice(1);return{type:"font",mode:v,font:y,body:{type:"ordgroup",mode:u.mode,body:b}}},htmlBuilder:Vze,mathmlBuilder:Uze});var Kze=(i,s)=>{var u=s;return i==="display"?u=u.id>=Ta.SCRIPT.id?u.text():Ta.DISPLAY:i==="text"&&u.size===Ta.DISPLAY.size?u=Ta.TEXT:i==="script"?u=Ta.SCRIPT:i==="scriptscript"&&(u=Ta.SCRIPTSCRIPT),u},_be=(i,s)=>{var u=Kze(i.size,s.style),d=u.fracNum(),p=u.fracDen(),v;v=s.havingStyle(d);var b=uu(i.numer,v,s);if(i.continued){var y=8.5/s.fontMetrics().ptPerEm,T=3.5/s.fontMetrics().ptPerEm;b.height=b.height0?j=3*R:j=7*R,K=s.fontMetrics().denom1):(P>0?(F=s.fontMetrics().num2,j=R):(F=s.fontMetrics().num3,j=3*R),K=s.fontMetrics().denom2);var ee;if(A){var oe=s.fontMetrics().axisHeight;F-b.depth-(oe+.5*P){var u=new vi.MathNode("mfrac",[Ll(i.numer,s),Ll(i.denom,s)]);if(!i.hasBarLine)u.setAttribute("linethickness","0px");else if(i.barSize){var d=Uh(i.barSize,s);u.setAttribute("linethickness",Ri(d))}var p=Kze(i.size,s.style);if(p.size!==s.style.size){u=new vi.MathNode("mstyle",[u]);var v=p.size===Ta.DISPLAY.size?"true":"false";u.setAttribute("displaystyle",v),u.setAttribute("scriptlevel","0")}if(i.leftDelim!=null||i.rightDelim!=null){var b=[];if(i.leftDelim!=null){var y=new vi.MathNode("mo",[new vi.TextNode(i.leftDelim.replace("\\",""))]);y.setAttribute("fence","true"),b.push(y)}if(b.push(u),i.rightDelim!=null){var T=new vi.MathNode("mo",[new vi.TextNode(i.rightDelim.replace("\\",""))]);T.setAttribute("fence","true"),b.push(T)}return hbe(b)}return u};Ji({type:"genfrac",names:["\\dfrac","\\frac","\\tfrac","\\dbinom","\\binom","\\tbinom","\\\\atopfrac","\\\\bracefrac","\\\\brackfrac"],props:{numArgs:2,allowedInArgument:!0},handler:(i,s)=>{var{parser:u,funcName:d}=i,p=s[0],v=s[1],b,y=null,T=null,_="auto";switch(d){case"\\dfrac":case"\\frac":case"\\tfrac":b=!0;break;case"\\\\atopfrac":b=!1;break;case"\\dbinom":case"\\binom":case"\\tbinom":b=!1,y="(",T=")";break;case"\\\\bracefrac":b=!1,y="\\{",T="\\}";break;case"\\\\brackfrac":b=!1,y="[",T="]";break;default:throw new Error("Unrecognized genfrac command")}switch(d){case"\\dfrac":case"\\dbinom":_="display";break;case"\\tfrac":case"\\tbinom":_="text";break}return{type:"genfrac",mode:u.mode,continued:!1,numer:p,denom:v,hasBarLine:b,leftDelim:y,rightDelim:T,size:_,barSize:null}},htmlBuilder:_be,mathmlBuilder:Abe}),Ji({type:"genfrac",names:["\\cfrac"],props:{numArgs:2},handler:(i,s)=>{var{parser:u,funcName:d}=i,p=s[0],v=s[1];return{type:"genfrac",mode:u.mode,continued:!0,numer:p,denom:v,hasBarLine:!0,leftDelim:null,rightDelim:null,size:"display",barSize:null}}}),Ji({type:"infix",names:["\\over","\\choose","\\atop","\\brace","\\brack"],props:{numArgs:0,infix:!0},handler(i){var{parser:s,funcName:u,token:d}=i,p;switch(u){case"\\over":p="\\frac";break;case"\\choose":p="\\binom";break;case"\\atop":p="\\\\atopfrac";break;case"\\brace":p="\\\\bracefrac";break;case"\\brack":p="\\\\brackfrac";break;default:throw new Error("Unrecognized infix genfrac command")}return{type:"infix",mode:s.mode,replaceWith:p,token:d}}});var Wze=["display","text","script","scriptscript"],Yze=function(s){var u=null;return s.length>0&&(u=s,u=u==="."?null:u),u};Ji({type:"genfrac",names:["\\genfrac"],props:{numArgs:6,allowedInArgument:!0,argTypes:["math","math","size","text","math","math"]},handler(i,s){var{parser:u}=i,d=s[4],p=s[5],v=bQ(s[0]),b=v.type==="atom"&&v.family==="open"?Yze(v.text):null,y=bQ(s[1]),T=y.type==="atom"&&y.family==="close"?Yze(y.text):null,_=Yo(s[2],"size"),A,P=null;_.isBlank?A=!0:(P=_.value,A=P.number>0);var R="auto",F=s[3];if(F.type==="ordgroup"){if(F.body.length>0){var j=Yo(F.body[0],"textord");R=Wze[Number(j.text)]}}else F=Yo(F,"textord"),R=Wze[Number(F.text)];return{type:"genfrac",mode:u.mode,numer:d,denom:p,continued:!1,hasBarLine:A,barSize:P,leftDelim:b,rightDelim:T,size:R}},htmlBuilder:_be,mathmlBuilder:Abe}),Ji({type:"infix",names:["\\above"],props:{numArgs:1,argTypes:["size"],infix:!0},handler(i,s){var{parser:u,funcName:d,token:p}=i;return{type:"infix",mode:u.mode,replaceWith:"\\\\abovefrac",size:Yo(s[0],"size").value,token:p}}}),Ji({type:"genfrac",names:["\\\\abovefrac"],props:{numArgs:3,argTypes:["math","size","math"]},handler:(i,s)=>{var{parser:u,funcName:d}=i,p=s[0],v=$qt(Yo(s[1],"infix").size),b=s[2],y=v.number>0;return{type:"genfrac",mode:u.mode,numer:p,denom:b,continued:!1,hasBarLine:y,barSize:v,leftDelim:null,rightDelim:null,size:"auto"}},htmlBuilder:_be,mathmlBuilder:Abe});var Xze=(i,s)=>{var u=s.style,d,p;i.type==="supsub"?(d=i.sup?uu(i.sup,s.havingStyle(u.sup()),s):uu(i.sub,s.havingStyle(u.sub()),s),p=Yo(i.base,"horizBrace")):p=Yo(i,"horizBrace");var v=uu(p.base,s.havingBaseStyle(Ta.DISPLAY)),b=P7.svgSpan(p,s),y;if(p.isOver?(y=zn.makeVList({positionType:"firstBaseline",children:[{type:"elem",elem:v},{type:"kern",size:.1},{type:"elem",elem:b}]},s),y.children[0].children[0].children[1].classes.push("svg-align")):(y=zn.makeVList({positionType:"bottom",positionData:v.depth+.1+b.height,children:[{type:"elem",elem:b},{type:"kern",size:.1},{type:"elem",elem:v}]},s),y.children[0].children[0].children[0].classes.push("svg-align")),d){var T=zn.makeSpan(["mord",p.isOver?"mover":"munder"],[y],s);p.isOver?y=zn.makeVList({positionType:"firstBaseline",children:[{type:"elem",elem:T},{type:"kern",size:.2},{type:"elem",elem:d}]},s):y=zn.makeVList({positionType:"bottom",positionData:T.depth+.2+d.height+d.depth,children:[{type:"elem",elem:d},{type:"kern",size:.2},{type:"elem",elem:T}]},s)}return zn.makeSpan(["mord",p.isOver?"mover":"munder"],[y],s)},lVt=(i,s)=>{var u=P7.mathMLnode(i.label);return new vi.MathNode(i.isOver?"mover":"munder",[Ll(i.base,s),u])};Ji({type:"horizBrace",names:["\\overbrace","\\underbrace"],props:{numArgs:1},handler(i,s){var{parser:u,funcName:d}=i;return{type:"horizBrace",mode:u.mode,label:d,isOver:/^\\over/.test(d),base:s[0]}},htmlBuilder:Xze,mathmlBuilder:lVt}),Ji({type:"href",names:["\\href"],props:{numArgs:2,argTypes:["url","original"],allowedInText:!0},handler:(i,s)=>{var{parser:u}=i,d=s[1],p=Yo(s[0],"url").url;return u.settings.isTrusted({command:"\\href",url:p})?{type:"href",mode:u.mode,href:p,body:Xf(d)}:u.formatUnsupportedCmd("\\href")},htmlBuilder:(i,s)=>{var u=d1(i.body,s,!1);return zn.makeAnchor(i.href,[],u,s)},mathmlBuilder:(i,s)=>{var u=_9(i.body,s);return u instanceof Fv||(u=new Fv("mrow",[u])),u.setAttribute("href",i.href),u}}),Ji({type:"href",names:["\\url"],props:{numArgs:1,argTypes:["url"],allowedInText:!0},handler:(i,s)=>{var{parser:u}=i,d=Yo(s[0],"url").url;if(!u.settings.isTrusted({command:"\\url",url:d}))return u.formatUnsupportedCmd("\\url");for(var p=[],v=0;v{var{parser:u,funcName:d,token:p}=i,v=Yo(s[0],"raw").string,b=s[1];u.settings.strict&&u.settings.reportNonstrict("htmlExtension","HTML extension is disabled on strict mode");var y,T={};switch(d){case"\\htmlClass":T.class=v,y={command:"\\htmlClass",class:v};break;case"\\htmlId":T.id=v,y={command:"\\htmlId",id:v};break;case"\\htmlStyle":T.style=v,y={command:"\\htmlStyle",style:v};break;case"\\htmlData":{for(var _=v.split(","),A=0;A<_.length;A++){var P=_[A].split("=");if(P.length!==2)throw new Ci("Error parsing key-value for \\htmlData");T["data-"+P[0].trim()]=P[1].trim()}y={command:"\\htmlData",attributes:T};break}default:throw new Error("Unrecognized html command")}return u.settings.isTrusted(y)?{type:"html",mode:u.mode,attributes:T,body:Xf(b)}:u.formatUnsupportedCmd(d)},htmlBuilder:(i,s)=>{var u=d1(i.body,s,!1),d=["enclosing"];i.attributes.class&&d.push(...i.attributes.class.trim().split(/\s+/));var p=zn.makeSpan(d,u,s);for(var v in i.attributes)v!=="class"&&i.attributes.hasOwnProperty(v)&&p.setAttribute(v,i.attributes[v]);return p},mathmlBuilder:(i,s)=>_9(i.body,s)}),Ji({type:"htmlmathml",names:["\\html@mathml"],props:{numArgs:2,allowedInText:!0},handler:(i,s)=>{var{parser:u}=i;return{type:"htmlmathml",mode:u.mode,html:Xf(s[0]),mathml:Xf(s[1])}},htmlBuilder:(i,s)=>{var u=d1(i.html,s,!1);return zn.makeFragment(u)},mathmlBuilder:(i,s)=>_9(i.mathml,s)});var Lbe=function(s){if(/^[-+]? *(\d+(\.\d*)?|\.\d+)$/.test(s))return{number:+s,unit:"bp"};var u=/([-+]?) *(\d+(?:\.\d*)?|\.\d+) *([a-z]{2})/.exec(s);if(!u)throw new Ci("Invalid size: '"+s+"' in \\includegraphics");var d={number:+(u[1]+u[2]),unit:u[3]};if(!J$e(d))throw new Ci("Invalid unit: '"+d.unit+"' in \\includegraphics.");return d};Ji({type:"includegraphics",names:["\\includegraphics"],props:{numArgs:1,numOptionalArgs:1,argTypes:["raw","url"],allowedInText:!1},handler:(i,s,u)=>{var{parser:d}=i,p={number:0,unit:"em"},v={number:.9,unit:"em"},b={number:0,unit:"em"},y="";if(u[0])for(var T=Yo(u[0],"raw").string,_=T.split(","),A=0;A<_.length;A++){var P=_[A].split("=");if(P.length===2){var R=P[1].trim();switch(P[0].trim()){case"alt":y=R;break;case"width":p=Lbe(R);break;case"height":v=Lbe(R);break;case"totalheight":b=Lbe(R);break;default:throw new Ci("Invalid key: '"+P[0]+"' in \\includegraphics.")}}}var F=Yo(s[0],"url").url;return y===""&&(y=F,y=y.replace(/^.*[\\/]/,""),y=y.substring(0,y.lastIndexOf("."))),d.settings.isTrusted({command:"\\includegraphics",url:F})?{type:"includegraphics",mode:d.mode,alt:y,width:p,height:v,totalheight:b,src:F}:d.formatUnsupportedCmd("\\includegraphics")},htmlBuilder:(i,s)=>{var u=Uh(i.height,s),d=0;i.totalheight.number>0&&(d=Uh(i.totalheight,s)-u);var p=0;i.width.number>0&&(p=Uh(i.width,s));var v={height:Ri(u+d)};p>0&&(v.width=Ri(p)),d>0&&(v.verticalAlign=Ri(-d));var b=new lHt(i.src,i.alt,v);return b.height=u,b.depth=d,b},mathmlBuilder:(i,s)=>{var u=new vi.MathNode("mglyph",[]);u.setAttribute("alt",i.alt);var d=Uh(i.height,s),p=0;if(i.totalheight.number>0&&(p=Uh(i.totalheight,s)-d,u.setAttribute("valign",Ri(-p))),u.setAttribute("height",Ri(d+p)),i.width.number>0){var v=Uh(i.width,s);u.setAttribute("width",Ri(v))}return u.setAttribute("src",i.src),u}}),Ji({type:"kern",names:["\\kern","\\mkern","\\hskip","\\mskip"],props:{numArgs:1,argTypes:["size"],primitive:!0,allowedInText:!0},handler(i,s){var{parser:u,funcName:d}=i,p=Yo(s[0],"size");if(u.settings.strict){var v=d[1]==="m",b=p.value.unit==="mu";v?(b||u.settings.reportNonstrict("mathVsTextUnits","LaTeX's "+d+" supports only mu units, "+("not "+p.value.unit+" units")),u.mode!=="math"&&u.settings.reportNonstrict("mathVsTextUnits","LaTeX's "+d+" works only in math mode")):b&&u.settings.reportNonstrict("mathVsTextUnits","LaTeX's "+d+" doesn't support mu units")}return{type:"kern",mode:u.mode,dimension:p.value}},htmlBuilder(i,s){return zn.makeGlue(i.dimension,s)},mathmlBuilder(i,s){var u=Uh(i.dimension,s);return new vi.SpaceNode(u)}}),Ji({type:"lap",names:["\\mathllap","\\mathrlap","\\mathclap"],props:{numArgs:1,allowedInText:!0},handler:(i,s)=>{var{parser:u,funcName:d}=i,p=s[0];return{type:"lap",mode:u.mode,alignment:d.slice(5),body:p}},htmlBuilder:(i,s)=>{var u;i.alignment==="clap"?(u=zn.makeSpan([],[uu(i.body,s)]),u=zn.makeSpan(["inner"],[u],s)):u=zn.makeSpan(["inner"],[uu(i.body,s)]);var d=zn.makeSpan(["fix"],[]),p=zn.makeSpan([i.alignment],[u,d],s),v=zn.makeSpan(["strut"]);return v.style.height=Ri(p.height+p.depth),p.depth&&(v.style.verticalAlign=Ri(-p.depth)),p.children.unshift(v),p=zn.makeSpan(["thinbox"],[p],s),zn.makeSpan(["mord","vbox"],[p],s)},mathmlBuilder:(i,s)=>{var u=new vi.MathNode("mpadded",[Ll(i.body,s)]);if(i.alignment!=="rlap"){var d=i.alignment==="llap"?"-1":"-0.5";u.setAttribute("lspace",d+"width")}return u.setAttribute("width","0px"),u}}),Ji({type:"styling",names:["\\(","$"],props:{numArgs:0,allowedInText:!0,allowedInMath:!1},handler(i,s){var{funcName:u,parser:d}=i,p=d.mode;d.switchMode("math");var v=u==="\\("?"\\)":"$",b=d.parseExpression(!1,v);return d.expect(v),d.switchMode(p),{type:"styling",mode:d.mode,style:"text",body:b}}}),Ji({type:"text",names:["\\)","\\]"],props:{numArgs:0,allowedInText:!0,allowedInMath:!1},handler(i,s){throw new Ci("Mismatched "+i.funcName)}});var Qze=(i,s)=>{switch(s.style.size){case Ta.DISPLAY.size:return i.display;case Ta.TEXT.size:return i.text;case Ta.SCRIPT.size:return i.script;case Ta.SCRIPTSCRIPT.size:return i.scriptscript;default:return i.text}};Ji({type:"mathchoice",names:["\\mathchoice"],props:{numArgs:4,primitive:!0},handler:(i,s)=>{var{parser:u}=i;return{type:"mathchoice",mode:u.mode,display:Xf(s[0]),text:Xf(s[1]),script:Xf(s[2]),scriptscript:Xf(s[3])}},htmlBuilder:(i,s)=>{var u=Qze(i,s),d=d1(u,s,!1);return zn.makeFragment(d)},mathmlBuilder:(i,s)=>{var u=Qze(i,s);return _9(u,s)}});var Jze=(i,s,u,d,p,v,b)=>{i=zn.makeSpan([],[i]);var y=u&&Ya.isCharacterBox(u),T,_;if(s){var A=uu(s,d.havingStyle(p.sup()),d);_={elem:A,kern:Math.max(d.fontMetrics().bigOpSpacing1,d.fontMetrics().bigOpSpacing3-A.depth)}}if(u){var P=uu(u,d.havingStyle(p.sub()),d);T={elem:P,kern:Math.max(d.fontMetrics().bigOpSpacing2,d.fontMetrics().bigOpSpacing4-P.height)}}var R;if(_&&T){var F=d.fontMetrics().bigOpSpacing5+T.elem.height+T.elem.depth+T.kern+i.depth+b;R=zn.makeVList({positionType:"bottom",positionData:F,children:[{type:"kern",size:d.fontMetrics().bigOpSpacing5},{type:"elem",elem:T.elem,marginLeft:Ri(-v)},{type:"kern",size:T.kern},{type:"elem",elem:i},{type:"kern",size:_.kern},{type:"elem",elem:_.elem,marginLeft:Ri(v)},{type:"kern",size:d.fontMetrics().bigOpSpacing5}]},d)}else if(T){var j=i.height-b;R=zn.makeVList({positionType:"top",positionData:j,children:[{type:"kern",size:d.fontMetrics().bigOpSpacing5},{type:"elem",elem:T.elem,marginLeft:Ri(-v)},{type:"kern",size:T.kern},{type:"elem",elem:i}]},d)}else if(_){var K=i.depth+b;R=zn.makeVList({positionType:"bottom",positionData:K,children:[{type:"elem",elem:i},{type:"kern",size:_.kern},{type:"elem",elem:_.elem,marginLeft:Ri(v)},{type:"kern",size:d.fontMetrics().bigOpSpacing5}]},d)}else return i;var ee=[R];if(T&&v!==0&&!y){var ie=zn.makeSpan(["mspace"],[],d);ie.style.marginRight=Ri(v),ee.unshift(ie)}return zn.makeSpan(["mop","op-limits"],ee,d)},Zze=["\\smallint"],PD=(i,s)=>{var u,d,p=!1,v;i.type==="supsub"?(u=i.sup,d=i.sub,v=Yo(i.base,"op"),p=!0):v=Yo(i,"op");var b=s.style,y=!1;b.size===Ta.DISPLAY.size&&v.symbol&&!Ya.contains(Zze,v.name)&&(y=!0);var T;if(v.symbol){var _=y?"Size2-Regular":"Size1-Regular",A="";if((v.name==="\\oiint"||v.name==="\\oiiint")&&(A=v.name.slice(1),v.name=A==="oiint"?"\\iint":"\\iiint"),T=zn.makeSymbol(v.name,_,"math",s,["mop","op-symbol",y?"large-op":"small-op"]),A.length>0){var P=T.italic,R=zn.staticSvg(A+"Size"+(y?"2":"1"),s);T=zn.makeVList({positionType:"individualShift",children:[{type:"elem",elem:T,shift:0},{type:"elem",elem:R,shift:y?.08:0}]},s),v.name="\\"+A,T.classes.unshift("mop"),T.italic=P}}else if(v.body){var F=d1(v.body,s,!0);F.length===1&&F[0]instanceof Bv?(T=F[0],T.classes[0]="mop"):T=zn.makeSpan(["mop"],F,s)}else{for(var j=[],K=1;K{var u;if(i.symbol)u=new Fv("mo",[Rv(i.name,i.mode)]),Ya.contains(Zze,i.name)&&u.setAttribute("largeop","false");else if(i.body)u=new Fv("mo",j2(i.body,s));else{u=new Fv("mi",[new lR(i.name.slice(1))]);var d=new Fv("mo",[Rv("⁡","text")]);i.parentIsSupSub?u=new Fv("mrow",[u,d]):u=bze([u,d])}return u},hVt={"∏":"\\prod","∐":"\\coprod","∑":"\\sum","⋀":"\\bigwedge","⋁":"\\bigvee","⋂":"\\bigcap","⋃":"\\bigcup","⨀":"\\bigodot","⨁":"\\bigoplus","⨂":"\\bigotimes","⨄":"\\biguplus","⨆":"\\bigsqcup"};Ji({type:"op",names:["\\coprod","\\bigvee","\\bigwedge","\\biguplus","\\bigcap","\\bigcup","\\intop","\\prod","\\sum","\\bigotimes","\\bigoplus","\\bigodot","\\bigsqcup","\\smallint","∏","∐","∑","⋀","⋁","⋂","⋃","⨀","⨁","⨂","⨄","⨆"],props:{numArgs:0},handler:(i,s)=>{var{parser:u,funcName:d}=i,p=d;return p.length===1&&(p=hVt[p]),{type:"op",mode:u.mode,limits:!0,parentIsSupSub:!1,symbol:!0,name:p}},htmlBuilder:PD,mathmlBuilder:dR}),Ji({type:"op",names:["\\mathop"],props:{numArgs:1,primitive:!0},handler:(i,s)=>{var{parser:u}=i,d=s[0];return{type:"op",mode:u.mode,limits:!1,parentIsSupSub:!1,symbol:!1,body:Xf(d)}},htmlBuilder:PD,mathmlBuilder:dR});var fVt={"∫":"\\int","∬":"\\iint","∭":"\\iiint","∮":"\\oint","∯":"\\oiint","∰":"\\oiiint"};Ji({type:"op",names:["\\arcsin","\\arccos","\\arctan","\\arctg","\\arcctg","\\arg","\\ch","\\cos","\\cosec","\\cosh","\\cot","\\cotg","\\coth","\\csc","\\ctg","\\cth","\\deg","\\dim","\\exp","\\hom","\\ker","\\lg","\\ln","\\log","\\sec","\\sin","\\sinh","\\sh","\\tan","\\tanh","\\tg","\\th"],props:{numArgs:0},handler(i){var{parser:s,funcName:u}=i;return{type:"op",mode:s.mode,limits:!1,parentIsSupSub:!1,symbol:!1,name:u}},htmlBuilder:PD,mathmlBuilder:dR}),Ji({type:"op",names:["\\det","\\gcd","\\inf","\\lim","\\max","\\min","\\Pr","\\sup"],props:{numArgs:0},handler(i){var{parser:s,funcName:u}=i;return{type:"op",mode:s.mode,limits:!0,parentIsSupSub:!1,symbol:!1,name:u}},htmlBuilder:PD,mathmlBuilder:dR}),Ji({type:"op",names:["\\int","\\iint","\\iiint","\\oint","\\oiint","\\oiiint","∫","∬","∭","∮","∯","∰"],props:{numArgs:0},handler(i){var{parser:s,funcName:u}=i,d=u;return d.length===1&&(d=fVt[d]),{type:"op",mode:s.mode,limits:!1,parentIsSupSub:!1,symbol:!0,name:d}},htmlBuilder:PD,mathmlBuilder:dR});var eqe=(i,s)=>{var u,d,p=!1,v;i.type==="supsub"?(u=i.sup,d=i.sub,v=Yo(i.base,"operatorname"),p=!0):v=Yo(i,"operatorname");var b;if(v.body.length>0){for(var y=v.body.map(P=>{var R=P.text;return typeof R=="string"?{type:"textord",mode:P.mode,text:R}:P}),T=d1(y,s.withFont("mathrm"),!0),_=0;_{for(var u=j2(i.body,s.withFont("mathrm")),d=!0,p=0;pA.toText()).join("");u=[new vi.TextNode(y)]}var T=new vi.MathNode("mi",u);T.setAttribute("mathvariant","normal");var _=new vi.MathNode("mo",[Rv("⁡","text")]);return i.parentIsSupSub?new vi.MathNode("mrow",[T,_]):vi.newDocumentFragment([T,_])};Ji({type:"operatorname",names:["\\operatorname@","\\operatornamewithlimits"],props:{numArgs:1},handler:(i,s)=>{var{parser:u,funcName:d}=i,p=s[0];return{type:"operatorname",mode:u.mode,body:Xf(p),alwaysHandleSupSub:d==="\\operatornamewithlimits",limits:!1,parentIsSupSub:!1}},htmlBuilder:eqe,mathmlBuilder:dVt}),et("\\operatorname","\\@ifstar\\operatornamewithlimits\\operatorname@"),zC({type:"ordgroup",htmlBuilder(i,s){return i.semisimple?zn.makeFragment(d1(i.body,s,!1)):zn.makeSpan(["mord"],d1(i.body,s,!0),s)},mathmlBuilder(i,s){return _9(i.body,s,!0)}}),Ji({type:"overline",names:["\\overline"],props:{numArgs:1},handler(i,s){var{parser:u}=i,d=s[0];return{type:"overline",mode:u.mode,body:d}},htmlBuilder(i,s){var u=uu(i.body,s.havingCrampedStyle()),d=zn.makeLineSpan("overline-line",s),p=s.fontMetrics().defaultRuleThickness,v=zn.makeVList({positionType:"firstBaseline",children:[{type:"elem",elem:u},{type:"kern",size:3*p},{type:"elem",elem:d},{type:"kern",size:p}]},s);return zn.makeSpan(["mord","overline"],[v],s)},mathmlBuilder(i,s){var u=new vi.MathNode("mo",[new vi.TextNode("‾")]);u.setAttribute("stretchy","true");var d=new vi.MathNode("mover",[Ll(i.body,s),u]);return d.setAttribute("accent","true"),d}}),Ji({type:"phantom",names:["\\phantom"],props:{numArgs:1,allowedInText:!0},handler:(i,s)=>{var{parser:u}=i,d=s[0];return{type:"phantom",mode:u.mode,body:Xf(d)}},htmlBuilder:(i,s)=>{var u=d1(i.body,s.withPhantom(),!1);return zn.makeFragment(u)},mathmlBuilder:(i,s)=>{var u=j2(i.body,s);return new vi.MathNode("mphantom",u)}}),Ji({type:"hphantom",names:["\\hphantom"],props:{numArgs:1,allowedInText:!0},handler:(i,s)=>{var{parser:u}=i,d=s[0];return{type:"hphantom",mode:u.mode,body:d}},htmlBuilder:(i,s)=>{var u=zn.makeSpan([],[uu(i.body,s.withPhantom())]);if(u.height=0,u.depth=0,u.children)for(var d=0;d{var u=j2(Xf(i.body),s),d=new vi.MathNode("mphantom",u),p=new vi.MathNode("mpadded",[d]);return p.setAttribute("height","0px"),p.setAttribute("depth","0px"),p}}),Ji({type:"vphantom",names:["\\vphantom"],props:{numArgs:1,allowedInText:!0},handler:(i,s)=>{var{parser:u}=i,d=s[0];return{type:"vphantom",mode:u.mode,body:d}},htmlBuilder:(i,s)=>{var u=zn.makeSpan(["inner"],[uu(i.body,s.withPhantom())]),d=zn.makeSpan(["fix"],[]);return zn.makeSpan(["mord","rlap"],[u,d],s)},mathmlBuilder:(i,s)=>{var u=j2(Xf(i.body),s),d=new vi.MathNode("mphantom",u),p=new vi.MathNode("mpadded",[d]);return p.setAttribute("width","0px"),p}}),Ji({type:"raisebox",names:["\\raisebox"],props:{numArgs:2,argTypes:["size","hbox"],allowedInText:!0},handler(i,s){var{parser:u}=i,d=Yo(s[0],"size").value,p=s[1];return{type:"raisebox",mode:u.mode,dy:d,body:p}},htmlBuilder(i,s){var u=uu(i.body,s),d=Uh(i.dy,s);return zn.makeVList({positionType:"shift",positionData:-d,children:[{type:"elem",elem:u}]},s)},mathmlBuilder(i,s){var u=new vi.MathNode("mpadded",[Ll(i.body,s)]),d=i.dy.number+i.dy.unit;return u.setAttribute("voffset",d),u}}),Ji({type:"internal",names:["\\relax"],props:{numArgs:0,allowedInText:!0},handler(i){var{parser:s}=i;return{type:"internal",mode:s.mode}}}),Ji({type:"rule",names:["\\rule"],props:{numArgs:2,numOptionalArgs:1,argTypes:["size","size","size"]},handler(i,s,u){var{parser:d}=i,p=u[0],v=Yo(s[0],"size"),b=Yo(s[1],"size");return{type:"rule",mode:d.mode,shift:p&&Yo(p,"size").value,width:v.value,height:b.value}},htmlBuilder(i,s){var u=zn.makeSpan(["mord","rule"],[],s),d=Uh(i.width,s),p=Uh(i.height,s),v=i.shift?Uh(i.shift,s):0;return u.style.borderRightWidth=Ri(d),u.style.borderTopWidth=Ri(p),u.style.bottom=Ri(v),u.width=d,u.height=p+v,u.depth=-v,u.maxFontSize=p*1.125*s.sizeMultiplier,u},mathmlBuilder(i,s){var u=Uh(i.width,s),d=Uh(i.height,s),p=i.shift?Uh(i.shift,s):0,v=s.color&&s.getColor()||"black",b=new vi.MathNode("mspace");b.setAttribute("mathbackground",v),b.setAttribute("width",Ri(u)),b.setAttribute("height",Ri(d));var y=new vi.MathNode("mpadded",[b]);return p>=0?y.setAttribute("height",Ri(p)):(y.setAttribute("height",Ri(p)),y.setAttribute("depth",Ri(-p))),y.setAttribute("voffset",Ri(p)),y}});function tqe(i,s,u){for(var d=d1(i,s,!1),p=s.sizeMultiplier/u.sizeMultiplier,v=0;v{var u=s.havingSize(i.size);return tqe(i.body,u,s)};Ji({type:"sizing",names:nqe,props:{numArgs:0,allowedInText:!0},handler:(i,s)=>{var{breakOnTokenText:u,funcName:d,parser:p}=i,v=p.parseExpression(!1,u);return{type:"sizing",mode:p.mode,size:nqe.indexOf(d)+1,body:v}},htmlBuilder:gVt,mathmlBuilder:(i,s)=>{var u=s.havingSize(i.size),d=j2(i.body,u),p=new vi.MathNode("mstyle",d);return p.setAttribute("mathsize",Ri(u.sizeMultiplier)),p}}),Ji({type:"smash",names:["\\smash"],props:{numArgs:1,numOptionalArgs:1,allowedInText:!0},handler:(i,s,u)=>{var{parser:d}=i,p=!1,v=!1,b=u[0]&&Yo(u[0],"ordgroup");if(b)for(var y="",T=0;T{var u=zn.makeSpan([],[uu(i.body,s)]);if(!i.smashHeight&&!i.smashDepth)return u;if(i.smashHeight&&(u.height=0,u.children))for(var d=0;d{var u=new vi.MathNode("mpadded",[Ll(i.body,s)]);return i.smashHeight&&u.setAttribute("height","0px"),i.smashDepth&&u.setAttribute("depth","0px"),u}}),Ji({type:"sqrt",names:["\\sqrt"],props:{numArgs:1,numOptionalArgs:1},handler(i,s,u){var{parser:d}=i,p=u[0],v=s[0];return{type:"sqrt",mode:d.mode,body:v,index:p}},htmlBuilder(i,s){var u=uu(i.body,s.havingCrampedStyle());u.height===0&&(u.height=s.fontMetrics().xHeight),u=zn.wrapFragment(u,s);var d=s.fontMetrics(),p=d.defaultRuleThickness,v=p;s.style.idu.height+u.depth+b&&(b=(b+P-u.height-u.depth)/2);var R=T.height-u.height-b-_;u.style.paddingLeft=Ri(A);var F=zn.makeVList({positionType:"firstBaseline",children:[{type:"elem",elem:u,wrapperClasses:["svg-align"]},{type:"kern",size:-(u.height+R)},{type:"elem",elem:T},{type:"kern",size:_}]},s);if(i.index){var j=s.havingStyle(Ta.SCRIPTSCRIPT),K=uu(i.index,j,s),ee=.6*(F.height-F.depth),ie=zn.makeVList({positionType:"shift",positionData:-ee,children:[{type:"elem",elem:K}]},s),oe=zn.makeSpan(["root"],[ie]);return zn.makeSpan(["mord","sqrt"],[oe,F],s)}else return zn.makeSpan(["mord","sqrt"],[F],s)},mathmlBuilder(i,s){var{body:u,index:d}=i;return d?new vi.MathNode("mroot",[Ll(u,s),Ll(d,s)]):new vi.MathNode("msqrt",[Ll(u,s)])}});var rqe={display:Ta.DISPLAY,text:Ta.TEXT,script:Ta.SCRIPT,scriptscript:Ta.SCRIPTSCRIPT};Ji({type:"styling",names:["\\displaystyle","\\textstyle","\\scriptstyle","\\scriptscriptstyle"],props:{numArgs:0,allowedInText:!0,primitive:!0},handler(i,s){var{breakOnTokenText:u,funcName:d,parser:p}=i,v=p.parseExpression(!0,u),b=d.slice(1,d.length-5);return{type:"styling",mode:p.mode,style:b,body:v}},htmlBuilder(i,s){var u=rqe[i.style],d=s.havingStyle(u).withFont("");return tqe(i.body,d,s)},mathmlBuilder(i,s){var u=rqe[i.style],d=s.havingStyle(u),p=j2(i.body,d),v=new vi.MathNode("mstyle",p),b={display:["0","true"],text:["0","false"],script:["1","false"],scriptscript:["2","false"]},y=b[i.style];return v.setAttribute("scriptlevel",y[0]),v.setAttribute("displaystyle",y[1]),v}});var pVt=function(s,u){var d=s.base;if(d)if(d.type==="op"){var p=d.limits&&(u.style.size===Ta.DISPLAY.size||d.alwaysHandleSupSub);return p?PD:null}else if(d.type==="operatorname"){var v=d.alwaysHandleSupSub&&(u.style.size===Ta.DISPLAY.size||d.limits);return v?eqe:null}else{if(d.type==="accent")return Ya.isCharacterBox(d.base)?gbe:null;if(d.type==="horizBrace"){var b=!s.sub;return b===d.isOver?Xze:null}else return null}else return null};zC({type:"supsub",htmlBuilder(i,s){var u=pVt(i,s);if(u)return u(i,s);var{base:d,sup:p,sub:v}=i,b=uu(d,s),y,T,_=s.fontMetrics(),A=0,P=0,R=d&&Ya.isCharacterBox(d);if(p){var F=s.havingStyle(s.style.sup());y=uu(p,F,s),R||(A=b.height-F.fontMetrics().supDrop*F.sizeMultiplier/s.sizeMultiplier)}if(v){var j=s.havingStyle(s.style.sub());T=uu(v,j,s),R||(P=b.depth+j.fontMetrics().subDrop*j.sizeMultiplier/s.sizeMultiplier)}var K;s.style===Ta.DISPLAY?K=_.sup1:s.style.cramped?K=_.sup3:K=_.sup2;var ee=s.sizeMultiplier,ie=Ri(.5/_.ptPerEm/ee),oe=null;if(T){var pe=i.base&&i.base.type==="op"&&i.base.name&&(i.base.name==="\\oiint"||i.base.name==="\\oiiint");(b instanceof Bv||pe)&&(oe=Ri(-b.italic))}var be;if(y&&T){A=Math.max(A,K,y.depth+.25*_.xHeight),P=Math.max(P,_.sub2);var ae=_.defaultRuleThickness,ne=4*ae;if(A-y.depth-(T.height-P)0&&(A+=se,P-=se)}var de=[{type:"elem",elem:T,shift:P,marginRight:ie,marginLeft:oe},{type:"elem",elem:y,shift:-A,marginRight:ie}];be=zn.makeVList({positionType:"individualShift",children:de},s)}else if(T){P=Math.max(P,_.sub1,T.height-.8*_.xHeight);var X=[{type:"elem",elem:T,marginLeft:oe,marginRight:ie}];be=zn.makeVList({positionType:"shift",positionData:P,children:X},s)}else if(y)A=Math.max(A,K,y.depth+.25*_.xHeight),be=zn.makeVList({positionType:"shift",positionData:-A,children:[{type:"elem",elem:y,marginRight:ie}]},s);else throw new Error("supsub must have either sup or sub.");var ge=ube(b,"right")||"mord";return zn.makeSpan([ge],[b,zn.makeSpan(["msupsub"],[be])],s)},mathmlBuilder(i,s){var u=!1,d,p;i.base&&i.base.type==="horizBrace"&&(p=!!i.sup,p===i.base.isOver&&(u=!0,d=i.base.isOver)),i.base&&(i.base.type==="op"||i.base.type==="operatorname")&&(i.base.parentIsSupSub=!0);var v=[Ll(i.base,s)];i.sub&&v.push(Ll(i.sub,s)),i.sup&&v.push(Ll(i.sup,s));var b;if(u)b=d?"mover":"munder";else if(i.sub)if(i.sup){var _=i.base;_&&_.type==="op"&&_.limits&&s.style===Ta.DISPLAY||_&&_.type==="operatorname"&&_.alwaysHandleSupSub&&(s.style===Ta.DISPLAY||_.limits)?b="munderover":b="msubsup"}else{var T=i.base;T&&T.type==="op"&&T.limits&&(s.style===Ta.DISPLAY||T.alwaysHandleSupSub)||T&&T.type==="operatorname"&&T.alwaysHandleSupSub&&(T.limits||s.style===Ta.DISPLAY)?b="munder":b="msub"}else{var y=i.base;y&&y.type==="op"&&y.limits&&(s.style===Ta.DISPLAY||y.alwaysHandleSupSub)||y&&y.type==="operatorname"&&y.alwaysHandleSupSub&&(y.limits||s.style===Ta.DISPLAY)?b="mover":b="msup"}return new vi.MathNode(b,v)}}),zC({type:"atom",htmlBuilder(i,s){return zn.mathsym(i.text,i.mode,s,["m"+i.family])},mathmlBuilder(i,s){var u=new vi.MathNode("mo",[Rv(i.text,i.mode)]);if(i.family==="bin"){var d=fbe(i,s);d==="bold-italic"&&u.setAttribute("mathvariant",d)}else i.family==="punct"?u.setAttribute("separator","true"):(i.family==="open"||i.family==="close")&&u.setAttribute("stretchy","false");return u}});var iqe={mi:"italic",mn:"normal",mtext:"normal"};zC({type:"mathord",htmlBuilder(i,s){return zn.makeOrd(i,s,"mathord")},mathmlBuilder(i,s){var u=new vi.MathNode("mi",[Rv(i.text,i.mode,s)]),d=fbe(i,s)||"italic";return d!==iqe[u.type]&&u.setAttribute("mathvariant",d),u}}),zC({type:"textord",htmlBuilder(i,s){return zn.makeOrd(i,s,"textord")},mathmlBuilder(i,s){var u=Rv(i.text,i.mode,s),d=fbe(i,s)||"normal",p;return i.mode==="text"?p=new vi.MathNode("mtext",[u]):/[0-9]/.test(i.text)?p=new vi.MathNode("mn",[u]):i.text==="\\prime"?p=new vi.MathNode("mo",[u]):p=new vi.MathNode("mi",[u]),d!==iqe[p.type]&&p.setAttribute("mathvariant",d),p}});var Mbe={"\\nobreak":"nobreak","\\allowbreak":"allowbreak"},Dbe={" ":{},"\\ ":{},"~":{className:"nobreak"},"\\space":{},"\\nobreakspace":{className:"nobreak"}};zC({type:"spacing",htmlBuilder(i,s){if(Dbe.hasOwnProperty(i.text)){var u=Dbe[i.text].className||"";if(i.mode==="text"){var d=zn.makeOrd(i,s,"textord");return d.classes.push(u),d}else return zn.makeSpan(["mspace",u],[zn.mathsym(i.text,i.mode,s)],s)}else{if(Mbe.hasOwnProperty(i.text))return zn.makeSpan(["mspace",Mbe[i.text]],[],s);throw new Ci('Unknown type of space "'+i.text+'"')}},mathmlBuilder(i,s){var u;if(Dbe.hasOwnProperty(i.text))u=new vi.MathNode("mtext",[new vi.TextNode(" ")]);else{if(Mbe.hasOwnProperty(i.text))return new vi.MathNode("mspace");throw new Ci('Unknown type of space "'+i.text+'"')}return u}});var sqe=()=>{var i=new vi.MathNode("mtd",[]);return i.setAttribute("width","50%"),i};zC({type:"tag",mathmlBuilder(i,s){var u=new vi.MathNode("mtable",[new vi.MathNode("mtr",[sqe(),new vi.MathNode("mtd",[_9(i.body,s)]),sqe(),new vi.MathNode("mtd",[_9(i.tag,s)])])]);return u.setAttribute("width","100%"),u}});var aqe={"\\text":void 0,"\\textrm":"textrm","\\textsf":"textsf","\\texttt":"texttt","\\textnormal":"textrm"},oqe={"\\textbf":"textbf","\\textmd":"textmd"},bVt={"\\textit":"textit","\\textup":"textup"},cqe=(i,s)=>{var u=i.font;return u?aqe[u]?s.withTextFontFamily(aqe[u]):oqe[u]?s.withTextFontWeight(oqe[u]):s.withTextFontShape(bVt[u]):s};Ji({type:"text",names:["\\text","\\textrm","\\textsf","\\texttt","\\textnormal","\\textbf","\\textmd","\\textit","\\textup"],props:{numArgs:1,argTypes:["text"],allowedInArgument:!0,allowedInText:!0},handler(i,s){var{parser:u,funcName:d}=i,p=s[0];return{type:"text",mode:u.mode,body:Xf(p),font:d}},htmlBuilder(i,s){var u=cqe(i,s),d=d1(i.body,u,!0);return zn.makeSpan(["mord","text"],d,u)},mathmlBuilder(i,s){var u=cqe(i,s);return _9(i.body,u)}}),Ji({type:"underline",names:["\\underline"],props:{numArgs:1,allowedInText:!0},handler(i,s){var{parser:u}=i;return{type:"underline",mode:u.mode,body:s[0]}},htmlBuilder(i,s){var u=uu(i.body,s),d=zn.makeLineSpan("underline-line",s),p=s.fontMetrics().defaultRuleThickness,v=zn.makeVList({positionType:"top",positionData:u.height,children:[{type:"kern",size:p},{type:"elem",elem:d},{type:"kern",size:3*p},{type:"elem",elem:u}]},s);return zn.makeSpan(["mord","underline"],[v],s)},mathmlBuilder(i,s){var u=new vi.MathNode("mo",[new vi.TextNode("‾")]);u.setAttribute("stretchy","true");var d=new vi.MathNode("munder",[Ll(i.body,s),u]);return d.setAttribute("accentunder","true"),d}}),Ji({type:"vcenter",names:["\\vcenter"],props:{numArgs:1,argTypes:["original"],allowedInText:!1},handler(i,s){var{parser:u}=i;return{type:"vcenter",mode:u.mode,body:s[0]}},htmlBuilder(i,s){var u=uu(i.body,s),d=s.fontMetrics().axisHeight,p=.5*(u.height-d-(u.depth+d));return zn.makeVList({positionType:"shift",positionData:p,children:[{type:"elem",elem:u}]},s)},mathmlBuilder(i,s){return new vi.MathNode("mpadded",[Ll(i.body,s)],["vcenter"])}}),Ji({type:"verb",names:["\\verb"],props:{numArgs:0,allowedInText:!0},handler(i,s,u){throw new Ci("\\verb ended by end of line instead of matching delimiter")},htmlBuilder(i,s){for(var u=uqe(i),d=[],p=s.havingStyle(s.style.text()),v=0;vi.body.replace(/ /g,i.star?"␣":" "),L9=dze,lqe=`[ \r + ]`,mVt="\\\\[a-zA-Z@]+",vVt="\\\\[^\uD800-\uDFFF]",wVt="("+mVt+")"+lqe+"*",yVt=`\\\\( +|[ \r ]+ +?)[ \r ]*`,Ibe="[̀-ͯ]",xVt=new RegExp(Ibe+"+$"),kVt="("+lqe+"+)|"+(yVt+"|")+"([!-\\[\\]-‧‪-퟿豈-￿]"+(Ibe+"*")+"|[\uD800-\uDBFF][\uDC00-\uDFFF]"+(Ibe+"*")+"|\\\\verb\\*([^]).*?\\4|\\\\verb([^*a-zA-Z]).*?\\5"+("|"+wVt)+("|"+vVt+")");class hqe{constructor(s,u){this.input=void 0,this.settings=void 0,this.tokenRegex=void 0,this.catcodes=void 0,this.input=s,this.settings=u,this.tokenRegex=new RegExp(kVt,"g"),this.catcodes={"%":14,"~":13}}setCatcode(s,u){this.catcodes[s]=u}lex(){var s=this.input,u=this.tokenRegex.lastIndex;if(u===s.length)return new U4("EOF",new lm(this,u,u));var d=this.tokenRegex.exec(s);if(d===null||d.index!==u)throw new Ci("Unexpected character: '"+s[u]+"'",new U4(s[u],new lm(this,u,u+1)));var p=d[6]||d[3]||(d[2]?"\\ ":" ");if(this.catcodes[p]===14){var v=s.indexOf(` +`,this.tokenRegex.lastIndex);return v===-1?(this.tokenRegex.lastIndex=s.length,this.settings.reportNonstrict("commentAtEnd","% comment has no terminating newline; LaTeX would fail because of commenting the end of math mode (e.g. $)")):this.tokenRegex.lastIndex=v+1,this.lex()}return new U4(p,new lm(this,u,this.tokenRegex.lastIndex))}}class EVt{constructor(s,u){s===void 0&&(s={}),u===void 0&&(u={}),this.current=void 0,this.builtins=void 0,this.undefStack=void 0,this.current=u,this.builtins=s,this.undefStack=[]}beginGroup(){this.undefStack.push({})}endGroup(){if(this.undefStack.length===0)throw new Ci("Unbalanced namespace destruction: attempt to pop global namespace; please report this as a bug");var s=this.undefStack.pop();for(var u in s)s.hasOwnProperty(u)&&(s[u]==null?delete this.current[u]:this.current[u]=s[u])}endGroups(){for(;this.undefStack.length>0;)this.endGroup()}has(s){return this.current.hasOwnProperty(s)||this.builtins.hasOwnProperty(s)}get(s){return this.current.hasOwnProperty(s)?this.current[s]:this.builtins[s]}set(s,u,d){if(d===void 0&&(d=!1),d){for(var p=0;p0&&(this.undefStack[this.undefStack.length-1][s]=u)}else{var v=this.undefStack[this.undefStack.length-1];v&&!v.hasOwnProperty(s)&&(v[s]=this.current[s])}u==null?delete this.current[s]:this.current[s]=u}}var TVt=$ze;et("\\noexpand",function(i){var s=i.popToken();return i.isExpandable(s.text)&&(s.noexpand=!0,s.treatAsRelax=!0),{tokens:[s],numArgs:0}}),et("\\expandafter",function(i){var s=i.popToken();return i.expandOnce(!0),{tokens:[s],numArgs:0}}),et("\\@firstoftwo",function(i){var s=i.consumeArgs(2);return{tokens:s[0],numArgs:0}}),et("\\@secondoftwo",function(i){var s=i.consumeArgs(2);return{tokens:s[1],numArgs:0}}),et("\\@ifnextchar",function(i){var s=i.consumeArgs(3);i.consumeSpaces();var u=i.future();return s[0].length===1&&s[0][0].text===u.text?{tokens:s[1],numArgs:0}:{tokens:s[2],numArgs:0}}),et("\\@ifstar","\\@ifnextchar *{\\@firstoftwo{#1}}"),et("\\TextOrMath",function(i){var s=i.consumeArgs(2);return i.mode==="text"?{tokens:s[0],numArgs:0}:{tokens:s[1],numArgs:0}});var fqe={0:0,1:1,2:2,3:3,4:4,5:5,6:6,7:7,8:8,9:9,a:10,A:10,b:11,B:11,c:12,C:12,d:13,D:13,e:14,E:14,f:15,F:15};et("\\char",function(i){var s=i.popToken(),u,d="";if(s.text==="'")u=8,s=i.popToken();else if(s.text==='"')u=16,s=i.popToken();else if(s.text==="`")if(s=i.popToken(),s.text[0]==="\\")d=s.text.charCodeAt(1);else{if(s.text==="EOF")throw new Ci("\\char` missing argument");d=s.text.charCodeAt(0)}else u=10;if(u){if(d=fqe[s.text],d==null||d>=u)throw new Ci("Invalid base-"+u+" digit "+s.text);for(var p;(p=fqe[i.future().text])!=null&&p{var d=i.consumeArg().tokens;if(d.length!==1)throw new Ci("\\newcommand's first argument must be a macro name");var p=d[0].text,v=i.isDefined(p);if(v&&!s)throw new Ci("\\newcommand{"+p+"} attempting to redefine "+(p+"; use \\renewcommand"));if(!v&&!u)throw new Ci("\\renewcommand{"+p+"} when command "+p+" does not yet exist; use \\newcommand");var b=0;if(d=i.consumeArg().tokens,d.length===1&&d[0].text==="["){for(var y="",T=i.expandNextToken();T.text!=="]"&&T.text!=="EOF";)y+=T.text,T=i.expandNextToken();if(!y.match(/^\s*[0-9]+\s*$/))throw new Ci("Invalid number of arguments: "+y);b=parseInt(y),d=i.consumeArg().tokens}return i.macros.set(p,{tokens:d,numArgs:b}),""};et("\\newcommand",i=>Obe(i,!1,!0)),et("\\renewcommand",i=>Obe(i,!0,!1)),et("\\providecommand",i=>Obe(i,!0,!0)),et("\\message",i=>{var s=i.consumeArgs(1)[0];return console.log(s.reverse().map(u=>u.text).join("")),""}),et("\\errmessage",i=>{var s=i.consumeArgs(1)[0];return console.error(s.reverse().map(u=>u.text).join("")),""}),et("\\show",i=>{var s=i.popToken(),u=s.text;return console.log(s,i.macros.get(u),L9[u],Ul.math[u],Ul.text[u]),""}),et("\\bgroup","{"),et("\\egroup","}"),et("~","\\nobreakspace"),et("\\lq","`"),et("\\rq","'"),et("\\aa","\\r a"),et("\\AA","\\r A"),et("\\textcopyright","\\html@mathml{\\textcircled{c}}{\\char`©}"),et("\\copyright","\\TextOrMath{\\textcopyright}{\\text{\\textcopyright}}"),et("\\textregistered","\\html@mathml{\\textcircled{\\scriptsize R}}{\\char`®}"),et("ℬ","\\mathscr{B}"),et("ℰ","\\mathscr{E}"),et("ℱ","\\mathscr{F}"),et("ℋ","\\mathscr{H}"),et("ℐ","\\mathscr{I}"),et("ℒ","\\mathscr{L}"),et("ℳ","\\mathscr{M}"),et("ℛ","\\mathscr{R}"),et("ℭ","\\mathfrak{C}"),et("ℌ","\\mathfrak{H}"),et("ℨ","\\mathfrak{Z}"),et("\\Bbbk","\\Bbb{k}"),et("·","\\cdotp"),et("\\llap","\\mathllap{\\textrm{#1}}"),et("\\rlap","\\mathrlap{\\textrm{#1}}"),et("\\clap","\\mathclap{\\textrm{#1}}"),et("\\mathstrut","\\vphantom{(}"),et("\\underbar","\\underline{\\text{#1}}"),et("\\not",'\\html@mathml{\\mathrel{\\mathrlap\\@not}}{\\char"338}'),et("\\neq","\\html@mathml{\\mathrel{\\not=}}{\\mathrel{\\char`≠}}"),et("\\ne","\\neq"),et("≠","\\neq"),et("\\notin","\\html@mathml{\\mathrel{{\\in}\\mathllap{/\\mskip1mu}}}{\\mathrel{\\char`∉}}"),et("∉","\\notin"),et("≘","\\html@mathml{\\mathrel{=\\kern{-1em}\\raisebox{0.4em}{$\\scriptsize\\frown$}}}{\\mathrel{\\char`≘}}"),et("≙","\\html@mathml{\\stackrel{\\tiny\\wedge}{=}}{\\mathrel{\\char`≘}}"),et("≚","\\html@mathml{\\stackrel{\\tiny\\vee}{=}}{\\mathrel{\\char`≚}}"),et("≛","\\html@mathml{\\stackrel{\\scriptsize\\star}{=}}{\\mathrel{\\char`≛}}"),et("≝","\\html@mathml{\\stackrel{\\tiny\\mathrm{def}}{=}}{\\mathrel{\\char`≝}}"),et("≞","\\html@mathml{\\stackrel{\\tiny\\mathrm{m}}{=}}{\\mathrel{\\char`≞}}"),et("≟","\\html@mathml{\\stackrel{\\tiny?}{=}}{\\mathrel{\\char`≟}}"),et("⟂","\\perp"),et("‼","\\mathclose{!\\mkern-0.8mu!}"),et("∌","\\notni"),et("⌜","\\ulcorner"),et("⌝","\\urcorner"),et("⌞","\\llcorner"),et("⌟","\\lrcorner"),et("©","\\copyright"),et("®","\\textregistered"),et("️","\\textregistered"),et("\\ulcorner",'\\html@mathml{\\@ulcorner}{\\mathop{\\char"231c}}'),et("\\urcorner",'\\html@mathml{\\@urcorner}{\\mathop{\\char"231d}}'),et("\\llcorner",'\\html@mathml{\\@llcorner}{\\mathop{\\char"231e}}'),et("\\lrcorner",'\\html@mathml{\\@lrcorner}{\\mathop{\\char"231f}}'),et("\\vdots","\\mathord{\\varvdots\\rule{0pt}{15pt}}"),et("⋮","\\vdots"),et("\\varGamma","\\mathit{\\Gamma}"),et("\\varDelta","\\mathit{\\Delta}"),et("\\varTheta","\\mathit{\\Theta}"),et("\\varLambda","\\mathit{\\Lambda}"),et("\\varXi","\\mathit{\\Xi}"),et("\\varPi","\\mathit{\\Pi}"),et("\\varSigma","\\mathit{\\Sigma}"),et("\\varUpsilon","\\mathit{\\Upsilon}"),et("\\varPhi","\\mathit{\\Phi}"),et("\\varPsi","\\mathit{\\Psi}"),et("\\varOmega","\\mathit{\\Omega}"),et("\\substack","\\begin{subarray}{c}#1\\end{subarray}"),et("\\colon","\\nobreak\\mskip2mu\\mathpunct{}\\mathchoice{\\mkern-3mu}{\\mkern-3mu}{}{}{:}\\mskip6mu\\relax"),et("\\boxed","\\fbox{$\\displaystyle{#1}$}"),et("\\iff","\\DOTSB\\;\\Longleftrightarrow\\;"),et("\\implies","\\DOTSB\\;\\Longrightarrow\\;"),et("\\impliedby","\\DOTSB\\;\\Longleftarrow\\;");var dqe={",":"\\dotsc","\\not":"\\dotsb","+":"\\dotsb","=":"\\dotsb","<":"\\dotsb",">":"\\dotsb","-":"\\dotsb","*":"\\dotsb",":":"\\dotsb","\\DOTSB":"\\dotsb","\\coprod":"\\dotsb","\\bigvee":"\\dotsb","\\bigwedge":"\\dotsb","\\biguplus":"\\dotsb","\\bigcap":"\\dotsb","\\bigcup":"\\dotsb","\\prod":"\\dotsb","\\sum":"\\dotsb","\\bigotimes":"\\dotsb","\\bigoplus":"\\dotsb","\\bigodot":"\\dotsb","\\bigsqcup":"\\dotsb","\\And":"\\dotsb","\\longrightarrow":"\\dotsb","\\Longrightarrow":"\\dotsb","\\longleftarrow":"\\dotsb","\\Longleftarrow":"\\dotsb","\\longleftrightarrow":"\\dotsb","\\Longleftrightarrow":"\\dotsb","\\mapsto":"\\dotsb","\\longmapsto":"\\dotsb","\\hookrightarrow":"\\dotsb","\\doteq":"\\dotsb","\\mathbin":"\\dotsb","\\mathrel":"\\dotsb","\\relbar":"\\dotsb","\\Relbar":"\\dotsb","\\xrightarrow":"\\dotsb","\\xleftarrow":"\\dotsb","\\DOTSI":"\\dotsi","\\int":"\\dotsi","\\oint":"\\dotsi","\\iint":"\\dotsi","\\iiint":"\\dotsi","\\iiiint":"\\dotsi","\\idotsint":"\\dotsi","\\DOTSX":"\\dotsx"};et("\\dots",function(i){var s="\\dotso",u=i.expandAfterFuture().text;return u in dqe?s=dqe[u]:(u.slice(0,4)==="\\not"||u in Ul.math&&Ya.contains(["bin","rel"],Ul.math[u].group))&&(s="\\dotsb"),s});var Nbe={")":!0,"]":!0,"\\rbrack":!0,"\\}":!0,"\\rbrace":!0,"\\rangle":!0,"\\rceil":!0,"\\rfloor":!0,"\\rgroup":!0,"\\rmoustache":!0,"\\right":!0,"\\bigr":!0,"\\biggr":!0,"\\Bigr":!0,"\\Biggr":!0,$:!0,";":!0,".":!0,",":!0};et("\\dotso",function(i){var s=i.future().text;return s in Nbe?"\\ldots\\,":"\\ldots"}),et("\\dotsc",function(i){var s=i.future().text;return s in Nbe&&s!==","?"\\ldots\\,":"\\ldots"}),et("\\cdots",function(i){var s=i.future().text;return s in Nbe?"\\@cdots\\,":"\\@cdots"}),et("\\dotsb","\\cdots"),et("\\dotsm","\\cdots"),et("\\dotsi","\\!\\cdots"),et("\\dotsx","\\ldots\\,"),et("\\DOTSI","\\relax"),et("\\DOTSB","\\relax"),et("\\DOTSX","\\relax"),et("\\tmspace","\\TextOrMath{\\kern#1#3}{\\mskip#1#2}\\relax"),et("\\,","\\tmspace+{3mu}{.1667em}"),et("\\thinspace","\\,"),et("\\>","\\mskip{4mu}"),et("\\:","\\tmspace+{4mu}{.2222em}"),et("\\medspace","\\:"),et("\\;","\\tmspace+{5mu}{.2777em}"),et("\\thickspace","\\;"),et("\\!","\\tmspace-{3mu}{.1667em}"),et("\\negthinspace","\\!"),et("\\negmedspace","\\tmspace-{4mu}{.2222em}"),et("\\negthickspace","\\tmspace-{5mu}{.277em}"),et("\\enspace","\\kern.5em "),et("\\enskip","\\hskip.5em\\relax"),et("\\quad","\\hskip1em\\relax"),et("\\qquad","\\hskip2em\\relax"),et("\\tag","\\@ifstar\\tag@literal\\tag@paren"),et("\\tag@paren","\\tag@literal{({#1})}"),et("\\tag@literal",i=>{if(i.macros.get("\\df@tag"))throw new Ci("Multiple \\tag");return"\\gdef\\df@tag{\\text{#1}}"}),et("\\bmod","\\mathchoice{\\mskip1mu}{\\mskip1mu}{\\mskip5mu}{\\mskip5mu}\\mathbin{\\rm mod}\\mathchoice{\\mskip1mu}{\\mskip1mu}{\\mskip5mu}{\\mskip5mu}"),et("\\pod","\\allowbreak\\mathchoice{\\mkern18mu}{\\mkern8mu}{\\mkern8mu}{\\mkern8mu}(#1)"),et("\\pmod","\\pod{{\\rm mod}\\mkern6mu#1}"),et("\\mod","\\allowbreak\\mathchoice{\\mkern18mu}{\\mkern12mu}{\\mkern12mu}{\\mkern12mu}{\\rm mod}\\,\\,#1"),et("\\newline","\\\\\\relax"),et("\\TeX","\\textrm{\\html@mathml{T\\kern-.1667em\\raisebox{-.5ex}{E}\\kern-.125emX}{TeX}}");var gqe=Ri(K4["Main-Regular"]["T".charCodeAt(0)][1]-.7*K4["Main-Regular"]["A".charCodeAt(0)][1]);et("\\LaTeX","\\textrm{\\html@mathml{"+("L\\kern-.36em\\raisebox{"+gqe+"}{\\scriptstyle A}")+"\\kern-.15em\\TeX}{LaTeX}}"),et("\\KaTeX","\\textrm{\\html@mathml{"+("K\\kern-.17em\\raisebox{"+gqe+"}{\\scriptstyle A}")+"\\kern-.15em\\TeX}{KaTeX}}"),et("\\hspace","\\@ifstar\\@hspacer\\@hspace"),et("\\@hspace","\\hskip #1\\relax"),et("\\@hspacer","\\rule{0pt}{0pt}\\hskip #1\\relax"),et("\\ordinarycolon",":"),et("\\vcentcolon","\\mathrel{\\mathop\\ordinarycolon}"),et("\\dblcolon",'\\html@mathml{\\mathrel{\\vcentcolon\\mathrel{\\mkern-.9mu}\\vcentcolon}}{\\mathop{\\char"2237}}'),et("\\coloneqq",'\\html@mathml{\\mathrel{\\vcentcolon\\mathrel{\\mkern-1.2mu}=}}{\\mathop{\\char"2254}}'),et("\\Coloneqq",'\\html@mathml{\\mathrel{\\dblcolon\\mathrel{\\mkern-1.2mu}=}}{\\mathop{\\char"2237\\char"3d}}'),et("\\coloneq",'\\html@mathml{\\mathrel{\\vcentcolon\\mathrel{\\mkern-1.2mu}\\mathrel{-}}}{\\mathop{\\char"3a\\char"2212}}'),et("\\Coloneq",'\\html@mathml{\\mathrel{\\dblcolon\\mathrel{\\mkern-1.2mu}\\mathrel{-}}}{\\mathop{\\char"2237\\char"2212}}'),et("\\eqqcolon",'\\html@mathml{\\mathrel{=\\mathrel{\\mkern-1.2mu}\\vcentcolon}}{\\mathop{\\char"2255}}'),et("\\Eqqcolon",'\\html@mathml{\\mathrel{=\\mathrel{\\mkern-1.2mu}\\dblcolon}}{\\mathop{\\char"3d\\char"2237}}'),et("\\eqcolon",'\\html@mathml{\\mathrel{\\mathrel{-}\\mathrel{\\mkern-1.2mu}\\vcentcolon}}{\\mathop{\\char"2239}}'),et("\\Eqcolon",'\\html@mathml{\\mathrel{\\mathrel{-}\\mathrel{\\mkern-1.2mu}\\dblcolon}}{\\mathop{\\char"2212\\char"2237}}'),et("\\colonapprox",'\\html@mathml{\\mathrel{\\vcentcolon\\mathrel{\\mkern-1.2mu}\\approx}}{\\mathop{\\char"3a\\char"2248}}'),et("\\Colonapprox",'\\html@mathml{\\mathrel{\\dblcolon\\mathrel{\\mkern-1.2mu}\\approx}}{\\mathop{\\char"2237\\char"2248}}'),et("\\colonsim",'\\html@mathml{\\mathrel{\\vcentcolon\\mathrel{\\mkern-1.2mu}\\sim}}{\\mathop{\\char"3a\\char"223c}}'),et("\\Colonsim",'\\html@mathml{\\mathrel{\\dblcolon\\mathrel{\\mkern-1.2mu}\\sim}}{\\mathop{\\char"2237\\char"223c}}'),et("∷","\\dblcolon"),et("∹","\\eqcolon"),et("≔","\\coloneqq"),et("≕","\\eqqcolon"),et("⩴","\\Coloneqq"),et("\\ratio","\\vcentcolon"),et("\\coloncolon","\\dblcolon"),et("\\colonequals","\\coloneqq"),et("\\coloncolonequals","\\Coloneqq"),et("\\equalscolon","\\eqqcolon"),et("\\equalscoloncolon","\\Eqqcolon"),et("\\colonminus","\\coloneq"),et("\\coloncolonminus","\\Coloneq"),et("\\minuscolon","\\eqcolon"),et("\\minuscoloncolon","\\Eqcolon"),et("\\coloncolonapprox","\\Colonapprox"),et("\\coloncolonsim","\\Colonsim"),et("\\simcolon","\\mathrel{\\sim\\mathrel{\\mkern-1.2mu}\\vcentcolon}"),et("\\simcoloncolon","\\mathrel{\\sim\\mathrel{\\mkern-1.2mu}\\dblcolon}"),et("\\approxcolon","\\mathrel{\\approx\\mathrel{\\mkern-1.2mu}\\vcentcolon}"),et("\\approxcoloncolon","\\mathrel{\\approx\\mathrel{\\mkern-1.2mu}\\dblcolon}"),et("\\notni","\\html@mathml{\\not\\ni}{\\mathrel{\\char`∌}}"),et("\\limsup","\\DOTSB\\operatorname*{lim\\,sup}"),et("\\liminf","\\DOTSB\\operatorname*{lim\\,inf}"),et("\\injlim","\\DOTSB\\operatorname*{inj\\,lim}"),et("\\projlim","\\DOTSB\\operatorname*{proj\\,lim}"),et("\\varlimsup","\\DOTSB\\operatorname*{\\overline{lim}}"),et("\\varliminf","\\DOTSB\\operatorname*{\\underline{lim}}"),et("\\varinjlim","\\DOTSB\\operatorname*{\\underrightarrow{lim}}"),et("\\varprojlim","\\DOTSB\\operatorname*{\\underleftarrow{lim}}"),et("\\gvertneqq","\\html@mathml{\\@gvertneqq}{≩}"),et("\\lvertneqq","\\html@mathml{\\@lvertneqq}{≨}"),et("\\ngeqq","\\html@mathml{\\@ngeqq}{≱}"),et("\\ngeqslant","\\html@mathml{\\@ngeqslant}{≱}"),et("\\nleqq","\\html@mathml{\\@nleqq}{≰}"),et("\\nleqslant","\\html@mathml{\\@nleqslant}{≰}"),et("\\nshortmid","\\html@mathml{\\@nshortmid}{∤}"),et("\\nshortparallel","\\html@mathml{\\@nshortparallel}{∦}"),et("\\nsubseteqq","\\html@mathml{\\@nsubseteqq}{⊈}"),et("\\nsupseteqq","\\html@mathml{\\@nsupseteqq}{⊉}"),et("\\varsubsetneq","\\html@mathml{\\@varsubsetneq}{⊊}"),et("\\varsubsetneqq","\\html@mathml{\\@varsubsetneqq}{⫋}"),et("\\varsupsetneq","\\html@mathml{\\@varsupsetneq}{⊋}"),et("\\varsupsetneqq","\\html@mathml{\\@varsupsetneqq}{⫌}"),et("\\imath","\\html@mathml{\\@imath}{ı}"),et("\\jmath","\\html@mathml{\\@jmath}{ȷ}"),et("\\llbracket","\\html@mathml{\\mathopen{[\\mkern-3.2mu[}}{\\mathopen{\\char`⟦}}"),et("\\rrbracket","\\html@mathml{\\mathclose{]\\mkern-3.2mu]}}{\\mathclose{\\char`⟧}}"),et("⟦","\\llbracket"),et("⟧","\\rrbracket"),et("\\lBrace","\\html@mathml{\\mathopen{\\{\\mkern-3.2mu[}}{\\mathopen{\\char`⦃}}"),et("\\rBrace","\\html@mathml{\\mathclose{]\\mkern-3.2mu\\}}}{\\mathclose{\\char`⦄}}"),et("⦃","\\lBrace"),et("⦄","\\rBrace"),et("\\minuso","\\mathbin{\\html@mathml{{\\mathrlap{\\mathchoice{\\kern{0.145em}}{\\kern{0.145em}}{\\kern{0.1015em}}{\\kern{0.0725em}}\\circ}{-}}}{\\char`⦵}}"),et("⦵","\\minuso"),et("\\darr","\\downarrow"),et("\\dArr","\\Downarrow"),et("\\Darr","\\Downarrow"),et("\\lang","\\langle"),et("\\rang","\\rangle"),et("\\uarr","\\uparrow"),et("\\uArr","\\Uparrow"),et("\\Uarr","\\Uparrow"),et("\\N","\\mathbb{N}"),et("\\R","\\mathbb{R}"),et("\\Z","\\mathbb{Z}"),et("\\alef","\\aleph"),et("\\alefsym","\\aleph"),et("\\Alpha","\\mathrm{A}"),et("\\Beta","\\mathrm{B}"),et("\\bull","\\bullet"),et("\\Chi","\\mathrm{X}"),et("\\clubs","\\clubsuit"),et("\\cnums","\\mathbb{C}"),et("\\Complex","\\mathbb{C}"),et("\\Dagger","\\ddagger"),et("\\diamonds","\\diamondsuit"),et("\\empty","\\emptyset"),et("\\Epsilon","\\mathrm{E}"),et("\\Eta","\\mathrm{H}"),et("\\exist","\\exists"),et("\\harr","\\leftrightarrow"),et("\\hArr","\\Leftrightarrow"),et("\\Harr","\\Leftrightarrow"),et("\\hearts","\\heartsuit"),et("\\image","\\Im"),et("\\infin","\\infty"),et("\\Iota","\\mathrm{I}"),et("\\isin","\\in"),et("\\Kappa","\\mathrm{K}"),et("\\larr","\\leftarrow"),et("\\lArr","\\Leftarrow"),et("\\Larr","\\Leftarrow"),et("\\lrarr","\\leftrightarrow"),et("\\lrArr","\\Leftrightarrow"),et("\\Lrarr","\\Leftrightarrow"),et("\\Mu","\\mathrm{M}"),et("\\natnums","\\mathbb{N}"),et("\\Nu","\\mathrm{N}"),et("\\Omicron","\\mathrm{O}"),et("\\plusmn","\\pm"),et("\\rarr","\\rightarrow"),et("\\rArr","\\Rightarrow"),et("\\Rarr","\\Rightarrow"),et("\\real","\\Re"),et("\\reals","\\mathbb{R}"),et("\\Reals","\\mathbb{R}"),et("\\Rho","\\mathrm{P}"),et("\\sdot","\\cdot"),et("\\sect","\\S"),et("\\spades","\\spadesuit"),et("\\sub","\\subset"),et("\\sube","\\subseteq"),et("\\supe","\\supseteq"),et("\\Tau","\\mathrm{T}"),et("\\thetasym","\\vartheta"),et("\\weierp","\\wp"),et("\\Zeta","\\mathrm{Z}"),et("\\argmin","\\DOTSB\\operatorname*{arg\\,min}"),et("\\argmax","\\DOTSB\\operatorname*{arg\\,max}"),et("\\plim","\\DOTSB\\mathop{\\operatorname{plim}}\\limits"),et("\\bra","\\mathinner{\\langle{#1}|}"),et("\\ket","\\mathinner{|{#1}\\rangle}"),et("\\braket","\\mathinner{\\langle{#1}\\rangle}"),et("\\Bra","\\left\\langle#1\\right|"),et("\\Ket","\\left|#1\\right\\rangle");var pqe=i=>s=>{var u=s.consumeArg().tokens,d=s.consumeArg().tokens,p=s.consumeArg().tokens,v=s.consumeArg().tokens,b=s.macros.get("|"),y=s.macros.get("\\|");s.macros.beginGroup();var T=P=>R=>{i&&(R.macros.set("|",b),p.length&&R.macros.set("\\|",y));var F=P;if(!P&&p.length){var j=R.future();j.text==="|"&&(R.popToken(),F=!0)}return{tokens:F?p:d,numArgs:0}};s.macros.set("|",T(!1)),p.length&&s.macros.set("\\|",T(!0));var _=s.consumeArg().tokens,A=s.expandTokens([...v,..._,...u]);return s.macros.endGroup(),{tokens:A.reverse(),numArgs:0}};et("\\bra@ket",pqe(!1)),et("\\bra@set",pqe(!0)),et("\\Braket","\\bra@ket{\\left\\langle}{\\,\\middle\\vert\\,}{\\,\\middle\\vert\\,}{\\right\\rangle}"),et("\\Set","\\bra@set{\\left\\{\\:}{\\;\\middle\\vert\\;}{\\;\\middle\\Vert\\;}{\\:\\right\\}}"),et("\\set","\\bra@set{\\{\\,}{\\mid}{}{\\,\\}}"),et("\\angln","{\\angl n}"),et("\\blue","\\textcolor{##6495ed}{#1}"),et("\\orange","\\textcolor{##ffa500}{#1}"),et("\\pink","\\textcolor{##ff00af}{#1}"),et("\\red","\\textcolor{##df0030}{#1}"),et("\\green","\\textcolor{##28ae7b}{#1}"),et("\\gray","\\textcolor{gray}{#1}"),et("\\purple","\\textcolor{##9d38bd}{#1}"),et("\\blueA","\\textcolor{##ccfaff}{#1}"),et("\\blueB","\\textcolor{##80f6ff}{#1}"),et("\\blueC","\\textcolor{##63d9ea}{#1}"),et("\\blueD","\\textcolor{##11accd}{#1}"),et("\\blueE","\\textcolor{##0c7f99}{#1}"),et("\\tealA","\\textcolor{##94fff5}{#1}"),et("\\tealB","\\textcolor{##26edd5}{#1}"),et("\\tealC","\\textcolor{##01d1c1}{#1}"),et("\\tealD","\\textcolor{##01a995}{#1}"),et("\\tealE","\\textcolor{##208170}{#1}"),et("\\greenA","\\textcolor{##b6ffb0}{#1}"),et("\\greenB","\\textcolor{##8af281}{#1}"),et("\\greenC","\\textcolor{##74cf70}{#1}"),et("\\greenD","\\textcolor{##1fab54}{#1}"),et("\\greenE","\\textcolor{##0d923f}{#1}"),et("\\goldA","\\textcolor{##ffd0a9}{#1}"),et("\\goldB","\\textcolor{##ffbb71}{#1}"),et("\\goldC","\\textcolor{##ff9c39}{#1}"),et("\\goldD","\\textcolor{##e07d10}{#1}"),et("\\goldE","\\textcolor{##a75a05}{#1}"),et("\\redA","\\textcolor{##fca9a9}{#1}"),et("\\redB","\\textcolor{##ff8482}{#1}"),et("\\redC","\\textcolor{##f9685d}{#1}"),et("\\redD","\\textcolor{##e84d39}{#1}"),et("\\redE","\\textcolor{##bc2612}{#1}"),et("\\maroonA","\\textcolor{##ffbde0}{#1}"),et("\\maroonB","\\textcolor{##ff92c6}{#1}"),et("\\maroonC","\\textcolor{##ed5fa6}{#1}"),et("\\maroonD","\\textcolor{##ca337c}{#1}"),et("\\maroonE","\\textcolor{##9e034e}{#1}"),et("\\purpleA","\\textcolor{##ddd7ff}{#1}"),et("\\purpleB","\\textcolor{##c6b9fc}{#1}"),et("\\purpleC","\\textcolor{##aa87ff}{#1}"),et("\\purpleD","\\textcolor{##7854ab}{#1}"),et("\\purpleE","\\textcolor{##543b78}{#1}"),et("\\mintA","\\textcolor{##f5f9e8}{#1}"),et("\\mintB","\\textcolor{##edf2df}{#1}"),et("\\mintC","\\textcolor{##e0e5cc}{#1}"),et("\\grayA","\\textcolor{##f6f7f7}{#1}"),et("\\grayB","\\textcolor{##f0f1f2}{#1}"),et("\\grayC","\\textcolor{##e3e5e6}{#1}"),et("\\grayD","\\textcolor{##d6d8da}{#1}"),et("\\grayE","\\textcolor{##babec2}{#1}"),et("\\grayF","\\textcolor{##888d93}{#1}"),et("\\grayG","\\textcolor{##626569}{#1}"),et("\\grayH","\\textcolor{##3b3e40}{#1}"),et("\\grayI","\\textcolor{##21242c}{#1}"),et("\\kaBlue","\\textcolor{##314453}{#1}"),et("\\kaGreen","\\textcolor{##71B307}{#1}");var bqe={"^":!0,_:!0,"\\limits":!0,"\\nolimits":!0};class CVt{constructor(s,u,d){this.settings=void 0,this.expansionCount=void 0,this.lexer=void 0,this.macros=void 0,this.stack=void 0,this.mode=void 0,this.settings=u,this.expansionCount=0,this.feed(s),this.macros=new EVt(TVt,u.macros),this.mode=d,this.stack=[]}feed(s){this.lexer=new hqe(s,this.settings)}switchMode(s){this.mode=s}beginGroup(){this.macros.beginGroup()}endGroup(){this.macros.endGroup()}endGroups(){this.macros.endGroups()}future(){return this.stack.length===0&&this.pushToken(this.lexer.lex()),this.stack[this.stack.length-1]}popToken(){return this.future(),this.stack.pop()}pushToken(s){this.stack.push(s)}pushTokens(s){this.stack.push(...s)}scanArgument(s){var u,d,p;if(s){if(this.consumeSpaces(),this.future().text!=="[")return null;u=this.popToken(),{tokens:p,end:d}=this.consumeArg(["]"])}else({tokens:p,start:u,end:d}=this.consumeArg());return this.pushToken(new U4("EOF",d.loc)),this.pushTokens(p),u.range(d,"")}consumeSpaces(){for(;;){var s=this.future();if(s.text===" ")this.stack.pop();else break}}consumeArg(s){var u=[],d=s&&s.length>0;d||this.consumeSpaces();var p=this.future(),v,b=0,y=0;do{if(v=this.popToken(),u.push(v),v.text==="{")++b;else if(v.text==="}"){if(--b,b===-1)throw new Ci("Extra }",v)}else if(v.text==="EOF")throw new Ci("Unexpected end of input in a macro argument, expected '"+(s&&d?s[y]:"}")+"'",v);if(s&&d)if((b===0||b===1&&s[y]==="{")&&v.text===s[y]){if(++y,y===s.length){u.splice(-y,y);break}}else y=0}while(b!==0||d);return p.text==="{"&&u[u.length-1].text==="}"&&(u.pop(),u.shift()),u.reverse(),{tokens:u,start:p,end:v}}consumeArgs(s,u){if(u){if(u.length!==s+1)throw new Ci("The length of delimiters doesn't match the number of args!");for(var d=u[0],p=0;pthis.settings.maxExpand)throw new Ci("Too many expansions: infinite loop or need to increase maxExpand setting");var v=p.tokens,b=this.consumeArgs(p.numArgs,p.delimiters);if(p.numArgs){v=v.slice();for(var y=v.length-1;y>=0;--y){var T=v[y];if(T.text==="#"){if(y===0)throw new Ci("Incomplete placeholder at end of macro body",T);if(T=v[--y],T.text==="#")v.splice(y+1,1);else if(/^[1-9]$/.test(T.text))v.splice(y,2,...b[+T.text-1]);else throw new Ci("Not a valid argument number",T)}}}return this.pushTokens(v),v.length}expandAfterFuture(){return this.expandOnce(),this.future()}expandNextToken(){for(;;)if(this.expandOnce()===!1){var s=this.stack.pop();return s.treatAsRelax&&(s.text="\\relax"),s}throw new Error}expandMacro(s){return this.macros.has(s)?this.expandTokens([new U4(s)]):void 0}expandTokens(s){var u=[],d=this.stack.length;for(this.pushTokens(s);this.stack.length>d;)if(this.expandOnce(!0)===!1){var p=this.stack.pop();p.treatAsRelax&&(p.noexpand=!1,p.treatAsRelax=!1),u.push(p)}return u}expandMacroAsText(s){var u=this.expandMacro(s);return u&&u.map(d=>d.text).join("")}_getExpansion(s){var u=this.macros.get(s);if(u==null)return u;if(s.length===1){var d=this.lexer.catcodes[s];if(d!=null&&d!==13)return}var p=typeof u=="function"?u(this):u;if(typeof p=="string"){var v=0;if(p.indexOf("#")!==-1)for(var b=p.replace(/##/g,"");b.indexOf("#"+(v+1))!==-1;)++v;for(var y=new hqe(p,this.settings),T=[],_=y.lex();_.text!=="EOF";)T.push(_),_=y.lex();T.reverse();var A={tokens:T,numArgs:v};return A}return p}isDefined(s){return this.macros.has(s)||L9.hasOwnProperty(s)||Ul.math.hasOwnProperty(s)||Ul.text.hasOwnProperty(s)||bqe.hasOwnProperty(s)}isExpandable(s){var u=this.macros.get(s);return u!=null?typeof u=="string"||typeof u=="function"||!u.unexpandable:L9.hasOwnProperty(s)&&!L9[s].primitive}}var mqe=/^[₊₋₌₍₎₀₁₂₃₄₅₆₇₈₉ₐₑₕᵢⱼₖₗₘₙₒₚᵣₛₜᵤᵥₓᵦᵧᵨᵩᵪ]/,TQ=Object.freeze({"₊":"+","₋":"-","₌":"=","₍":"(","₎":")","₀":"0","₁":"1","₂":"2","₃":"3","₄":"4","₅":"5","₆":"6","₇":"7","₈":"8","₉":"9","ₐ":"a","ₑ":"e","ₕ":"h","ᵢ":"i","ⱼ":"j","ₖ":"k","ₗ":"l","ₘ":"m","ₙ":"n","ₒ":"o","ₚ":"p","ᵣ":"r","ₛ":"s","ₜ":"t","ᵤ":"u","ᵥ":"v","ₓ":"x","ᵦ":"β","ᵧ":"γ","ᵨ":"ρ","ᵩ":"ϕ","ᵪ":"χ","⁺":"+","⁻":"-","⁼":"=","⁽":"(","⁾":")","⁰":"0","¹":"1","²":"2","³":"3","⁴":"4","⁵":"5","⁶":"6","⁷":"7","⁸":"8","⁹":"9","ᴬ":"A","ᴮ":"B","ᴰ":"D","ᴱ":"E","ᴳ":"G","ᴴ":"H","ᴵ":"I","ᴶ":"J","ᴷ":"K","ᴸ":"L","ᴹ":"M","ᴺ":"N","ᴼ":"O","ᴾ":"P","ᴿ":"R","ᵀ":"T","ᵁ":"U","ⱽ":"V","ᵂ":"W","ᵃ":"a","ᵇ":"b","ᶜ":"c","ᵈ":"d","ᵉ":"e","ᶠ":"f","ᵍ":"g",ʰ:"h","ⁱ":"i",ʲ:"j","ᵏ":"k",ˡ:"l","ᵐ":"m",ⁿ:"n","ᵒ":"o","ᵖ":"p",ʳ:"r",ˢ:"s","ᵗ":"t","ᵘ":"u","ᵛ":"v",ʷ:"w",ˣ:"x",ʸ:"y","ᶻ":"z","ᵝ":"β","ᵞ":"γ","ᵟ":"δ","ᵠ":"ϕ","ᵡ":"χ","ᶿ":"θ"}),Pbe={"́":{text:"\\'",math:"\\acute"},"̀":{text:"\\`",math:"\\grave"},"̈":{text:'\\"',math:"\\ddot"},"̃":{text:"\\~",math:"\\tilde"},"̄":{text:"\\=",math:"\\bar"},"̆":{text:"\\u",math:"\\breve"},"̌":{text:"\\v",math:"\\check"},"̂":{text:"\\^",math:"\\hat"},"̇":{text:"\\.",math:"\\dot"},"̊":{text:"\\r",math:"\\mathring"},"̋":{text:"\\H"},"̧":{text:"\\c"}},vqe={á:"á",à:"à",ä:"ä",ǟ:"ǟ",ã:"ã",ā:"ā",ă:"ă",ắ:"ắ",ằ:"ằ",ẵ:"ẵ",ǎ:"ǎ",â:"â",ấ:"ấ",ầ:"ầ",ẫ:"ẫ",ȧ:"ȧ",ǡ:"ǡ",å:"å",ǻ:"ǻ",ḃ:"ḃ",ć:"ć",ḉ:"ḉ",č:"č",ĉ:"ĉ",ċ:"ċ",ç:"ç",ď:"ď",ḋ:"ḋ",ḑ:"ḑ",é:"é",è:"è",ë:"ë",ẽ:"ẽ",ē:"ē",ḗ:"ḗ",ḕ:"ḕ",ĕ:"ĕ",ḝ:"ḝ",ě:"ě",ê:"ê",ế:"ế",ề:"ề",ễ:"ễ",ė:"ė",ȩ:"ȩ",ḟ:"ḟ",ǵ:"ǵ",ḡ:"ḡ",ğ:"ğ",ǧ:"ǧ",ĝ:"ĝ",ġ:"ġ",ģ:"ģ",ḧ:"ḧ",ȟ:"ȟ",ĥ:"ĥ",ḣ:"ḣ",ḩ:"ḩ",í:"í",ì:"ì",ï:"ï",ḯ:"ḯ",ĩ:"ĩ",ī:"ī",ĭ:"ĭ",ǐ:"ǐ",î:"î",ǰ:"ǰ",ĵ:"ĵ",ḱ:"ḱ",ǩ:"ǩ",ķ:"ķ",ĺ:"ĺ",ľ:"ľ",ļ:"ļ",ḿ:"ḿ",ṁ:"ṁ",ń:"ń",ǹ:"ǹ",ñ:"ñ",ň:"ň",ṅ:"ṅ",ņ:"ņ",ó:"ó",ò:"ò",ö:"ö",ȫ:"ȫ",õ:"õ",ṍ:"ṍ",ṏ:"ṏ",ȭ:"ȭ",ō:"ō",ṓ:"ṓ",ṑ:"ṑ",ŏ:"ŏ",ǒ:"ǒ",ô:"ô",ố:"ố",ồ:"ồ",ỗ:"ỗ",ȯ:"ȯ",ȱ:"ȱ",ő:"ő",ṕ:"ṕ",ṗ:"ṗ",ŕ:"ŕ",ř:"ř",ṙ:"ṙ",ŗ:"ŗ",ś:"ś",ṥ:"ṥ",š:"š",ṧ:"ṧ",ŝ:"ŝ",ṡ:"ṡ",ş:"ş",ẗ:"ẗ",ť:"ť",ṫ:"ṫ",ţ:"ţ",ú:"ú",ù:"ù",ü:"ü",ǘ:"ǘ",ǜ:"ǜ",ǖ:"ǖ",ǚ:"ǚ",ũ:"ũ",ṹ:"ṹ",ū:"ū",ṻ:"ṻ",ŭ:"ŭ",ǔ:"ǔ",û:"û",ů:"ů",ű:"ű",ṽ:"ṽ",ẃ:"ẃ",ẁ:"ẁ",ẅ:"ẅ",ŵ:"ŵ",ẇ:"ẇ",ẘ:"ẘ",ẍ:"ẍ",ẋ:"ẋ",ý:"ý",ỳ:"ỳ",ÿ:"ÿ",ỹ:"ỹ",ȳ:"ȳ",ŷ:"ŷ",ẏ:"ẏ",ẙ:"ẙ",ź:"ź",ž:"ž",ẑ:"ẑ",ż:"ż",Á:"Á",À:"À",Ä:"Ä",Ǟ:"Ǟ",Ã:"Ã",Ā:"Ā",Ă:"Ă",Ắ:"Ắ",Ằ:"Ằ",Ẵ:"Ẵ",Ǎ:"Ǎ",Â:"Â",Ấ:"Ấ",Ầ:"Ầ",Ẫ:"Ẫ",Ȧ:"Ȧ",Ǡ:"Ǡ",Å:"Å",Ǻ:"Ǻ",Ḃ:"Ḃ",Ć:"Ć",Ḉ:"Ḉ",Č:"Č",Ĉ:"Ĉ",Ċ:"Ċ",Ç:"Ç",Ď:"Ď",Ḋ:"Ḋ",Ḑ:"Ḑ",É:"É",È:"È",Ë:"Ë",Ẽ:"Ẽ",Ē:"Ē",Ḗ:"Ḗ",Ḕ:"Ḕ",Ĕ:"Ĕ",Ḝ:"Ḝ",Ě:"Ě",Ê:"Ê",Ế:"Ế",Ề:"Ề",Ễ:"Ễ",Ė:"Ė",Ȩ:"Ȩ",Ḟ:"Ḟ",Ǵ:"Ǵ",Ḡ:"Ḡ",Ğ:"Ğ",Ǧ:"Ǧ",Ĝ:"Ĝ",Ġ:"Ġ",Ģ:"Ģ",Ḧ:"Ḧ",Ȟ:"Ȟ",Ĥ:"Ĥ",Ḣ:"Ḣ",Ḩ:"Ḩ",Í:"Í",Ì:"Ì",Ï:"Ï",Ḯ:"Ḯ",Ĩ:"Ĩ",Ī:"Ī",Ĭ:"Ĭ",Ǐ:"Ǐ",Î:"Î",İ:"İ",Ĵ:"Ĵ",Ḱ:"Ḱ",Ǩ:"Ǩ",Ķ:"Ķ",Ĺ:"Ĺ",Ľ:"Ľ",Ļ:"Ļ",Ḿ:"Ḿ",Ṁ:"Ṁ",Ń:"Ń",Ǹ:"Ǹ",Ñ:"Ñ",Ň:"Ň",Ṅ:"Ṅ",Ņ:"Ņ",Ó:"Ó",Ò:"Ò",Ö:"Ö",Ȫ:"Ȫ",Õ:"Õ",Ṍ:"Ṍ",Ṏ:"Ṏ",Ȭ:"Ȭ",Ō:"Ō",Ṓ:"Ṓ",Ṑ:"Ṑ",Ŏ:"Ŏ",Ǒ:"Ǒ",Ô:"Ô",Ố:"Ố",Ồ:"Ồ",Ỗ:"Ỗ",Ȯ:"Ȯ",Ȱ:"Ȱ",Ő:"Ő",Ṕ:"Ṕ",Ṗ:"Ṗ",Ŕ:"Ŕ",Ř:"Ř",Ṙ:"Ṙ",Ŗ:"Ŗ",Ś:"Ś",Ṥ:"Ṥ",Š:"Š",Ṧ:"Ṧ",Ŝ:"Ŝ",Ṡ:"Ṡ",Ş:"Ş",Ť:"Ť",Ṫ:"Ṫ",Ţ:"Ţ",Ú:"Ú",Ù:"Ù",Ü:"Ü",Ǘ:"Ǘ",Ǜ:"Ǜ",Ǖ:"Ǖ",Ǚ:"Ǚ",Ũ:"Ũ",Ṹ:"Ṹ",Ū:"Ū",Ṻ:"Ṻ",Ŭ:"Ŭ",Ǔ:"Ǔ",Û:"Û",Ů:"Ů",Ű:"Ű",Ṽ:"Ṽ",Ẃ:"Ẃ",Ẁ:"Ẁ",Ẅ:"Ẅ",Ŵ:"Ŵ",Ẇ:"Ẇ",Ẍ:"Ẍ",Ẋ:"Ẋ",Ý:"Ý",Ỳ:"Ỳ",Ÿ:"Ÿ",Ỹ:"Ỹ",Ȳ:"Ȳ",Ŷ:"Ŷ",Ẏ:"Ẏ",Ź:"Ź",Ž:"Ž",Ẑ:"Ẑ",Ż:"Ż",ά:"ά",ὰ:"ὰ",ᾱ:"ᾱ",ᾰ:"ᾰ",έ:"έ",ὲ:"ὲ",ή:"ή",ὴ:"ὴ",ί:"ί",ὶ:"ὶ",ϊ:"ϊ",ΐ:"ΐ",ῒ:"ῒ",ῑ:"ῑ",ῐ:"ῐ",ό:"ό",ὸ:"ὸ",ύ:"ύ",ὺ:"ὺ",ϋ:"ϋ",ΰ:"ΰ",ῢ:"ῢ",ῡ:"ῡ",ῠ:"ῠ",ώ:"ώ",ὼ:"ὼ",Ύ:"Ύ",Ὺ:"Ὺ",Ϋ:"Ϋ",Ῡ:"Ῡ",Ῠ:"Ῠ",Ώ:"Ώ",Ὼ:"Ὼ"};class gR{constructor(s,u){this.mode=void 0,this.gullet=void 0,this.settings=void 0,this.leftrightDepth=void 0,this.nextToken=void 0,this.mode="math",this.gullet=new CVt(s,u,this.mode),this.settings=u,this.leftrightDepth=0}expect(s,u){if(u===void 0&&(u=!0),this.fetch().text!==s)throw new Ci("Expected '"+s+"', got '"+this.fetch().text+"'",this.fetch());u&&this.consume()}consume(){this.nextToken=null}fetch(){return this.nextToken==null&&(this.nextToken=this.gullet.expandNextToken()),this.nextToken}switchMode(s){this.mode=s,this.gullet.switchMode(s)}parse(){this.settings.globalGroup||this.gullet.beginGroup(),this.settings.colorIsTextColor&&this.gullet.macros.set("\\color","\\textcolor");try{var s=this.parseExpression(!1);return this.expect("EOF"),this.settings.globalGroup||this.gullet.endGroup(),s}finally{this.gullet.endGroups()}}subparse(s){var u=this.nextToken;this.consume(),this.gullet.pushToken(new U4("}")),this.gullet.pushTokens(s);var d=this.parseExpression(!1);return this.expect("}"),this.nextToken=u,d}parseExpression(s,u){for(var d=[];;){this.mode==="math"&&this.consumeSpaces();var p=this.fetch();if(gR.endOfExpression.indexOf(p.text)!==-1||u&&p.text===u||s&&L9[p.text]&&L9[p.text].infix)break;var v=this.parseAtom(u);if(v){if(v.type==="internal")continue}else break;d.push(v)}return this.mode==="text"&&this.formLigatures(d),this.handleInfixNodes(d)}handleInfixNodes(s){for(var u=-1,d,p=0;p=0&&this.settings.reportNonstrict("unicodeTextInMathMode",'Latin-1/Unicode text character "'+u[0]+'" used in math mode',s);var y=Ul[this.mode][u].group,T=lm.range(s),_;if(dHt.hasOwnProperty(y)){var A=y;_={type:"atom",mode:this.mode,family:A,loc:T,text:u}}else _={type:y,mode:this.mode,loc:T,text:u};b=_}else if(u.charCodeAt(0)>=128)this.settings.strict&&(K$e(u.charCodeAt(0))?this.mode==="math"&&this.settings.reportNonstrict("unicodeTextInMathMode",'Unicode text character "'+u[0]+'" used in math mode',s):this.settings.reportNonstrict("unknownSymbol",'Unrecognized Unicode character "'+u[0]+'"'+(" ("+u.charCodeAt(0)+")"),s)),b={type:"textord",mode:"text",loc:lm.range(s),text:u};else return null;if(this.consume(),v)for(var P=0;P"u"&&(_s.yylloc={});var j0=_s.yylloc;on.push(j0);var pm=_s.options&&_s.options.ranges;typeof tl.yy.parseError=="function"?this.parseError=tl.yy.parseError:this.parseError=Object.getPrototypeOf(this).parseError;function Ml(){var kh;return kh=At.pop()||_s.lex()||Pa,typeof kh!="number"&&(kh instanceof Array&&(At=kh,kh=At.pop()),kh=qn.symbols_[kh]||kh),kh}for(var Xc,Bc,ja,Ou,Sa={},Po,Fc,xa,Ba;;){if(Bc=Un[Un.length-1],this.defaultActions[Bc]?ja=this.defaultActions[Bc]:((Xc===null||typeof Xc>"u")&&(Xc=Ml()),ja=fn[Bc]&&fn[Bc][Xc]),typeof ja>"u"||!ja.length||!ja[0]){var ga="";Ba=[];for(Po in fn[Bc])this.terminals_[Po]&&Po>$o&&Ba.push("'"+this.terminals_[Po]+"'");_s.showPosition?ga="Parse error on line "+(oo+1)+`: +`+_s.showPosition()+` +Expecting `+Ba.join(", ")+", got '"+(this.terminals_[Xc]||Xc)+"'":ga="Parse error on line "+(oo+1)+": Unexpected "+(Xc==Pa?"end of input":"'"+(this.terminals_[Xc]||Xc)+"'"),this.parseError(ga,{text:_s.match,token:this.terminals_[Xc]||Xc,line:_s.yylineno,loc:j0,expected:Ba})}if(ja[0]instanceof Array&&ja.length>1)throw new Error("Parse Error: multiple actions possible at state: "+Bc+", token: "+Xc);switch(ja[0]){case 1:Un.push(Xc),wt.push(_s.yytext),on.push(_s.yylloc),Un.push(ja[1]),Xc=null,jo=_s.yyleng,An=_s.yytext,oo=_s.yylineno,j0=_s.yylloc;break;case 2:if(Fc=this.productions_[ja[1]][1],Sa.$=wt[wt.length-Fc],Sa._$={first_line:on[on.length-(Fc||1)].first_line,last_line:on[on.length-1].last_line,first_column:on[on.length-(Fc||1)].first_column,last_column:on[on.length-1].last_column},pm&&(Sa._$.range=[on[on.length-(Fc||1)].range[0],on[on.length-1].range[1]]),Ou=this.performAction.apply(Sa,[An,jo,oo,tl.yy,ja[1],wt,on].concat(wo)),typeof Ou<"u")return Ou;Fc&&(Un=Un.slice(0,-1*Fc*2),wt=wt.slice(0,-1*Fc),on=on.slice(0,-1*Fc)),Un.push(this.productions_[ja[1]][0]),wt.push(Sa.$),on.push(Sa._$),xa=fn[Un[Un.length-2]][Un[Un.length-1]],Un.push(xa);break;case 3:return!0}}return!0}},zs=function(){var Tr={EOF:1,parseError:function(qn,Un){if(this.yy.parser)this.yy.parser.parseError(qn,Un);else throw new Error(qn)},setInput:function(Fn,qn){return this.yy=qn||this.yy||{},this._input=Fn,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},input:function(){var Fn=this._input[0];this.yytext+=Fn,this.yyleng++,this.offset++,this.match+=Fn,this.matched+=Fn;var qn=Fn.match(/(?:\r\n?|\n).*/g);return qn?(this.yylineno++,this.yylloc.last_line++):this.yylloc.last_column++,this.options.ranges&&this.yylloc.range[1]++,this._input=this._input.slice(1),Fn},unput:function(Fn){var qn=Fn.length,Un=Fn.split(/(?:\r\n?|\n)/g);this._input=Fn+this._input,this.yytext=this.yytext.substr(0,this.yytext.length-qn),this.offset-=qn;var At=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),Un.length-1&&(this.yylineno-=Un.length-1);var wt=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:Un?(Un.length===At.length?this.yylloc.first_column:0)+At[At.length-Un.length].length-Un[0].length:this.yylloc.first_column-qn},this.options.ranges&&(this.yylloc.range=[wt[0],wt[0]+this.yyleng-qn]),this.yyleng=this.yytext.length,this},more:function(){return this._more=!0,this},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},less:function(Fn){this.unput(this.match.slice(Fn))},pastInput:function(){var Fn=this.matched.substr(0,this.matched.length-this.match.length);return(Fn.length>20?"...":"")+Fn.substr(-20).replace(/\n/g,"")},upcomingInput:function(){var Fn=this.match;return Fn.length<20&&(Fn+=this._input.substr(0,20-Fn.length)),(Fn.substr(0,20)+(Fn.length>20?"...":"")).replace(/\n/g,"")},showPosition:function(){var Fn=this.pastInput(),qn=new Array(Fn.length+1).join("-");return Fn+this.upcomingInput()+` +`+qn+"^"},test_match:function(Fn,qn){var Un,At,wt;if(this.options.backtrack_lexer&&(wt={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&&(wt.yylloc.range=this.yylloc.range.slice(0))),At=Fn[0].match(/(?:\r\n?|\n).*/g),At&&(this.yylineno+=At.length),this.yylloc={first_line:this.yylloc.last_line,last_line:this.yylineno+1,first_column:this.yylloc.last_column,last_column:At?At[At.length-1].length-At[At.length-1].match(/\r?\n?/)[0].length:this.yylloc.last_column+Fn[0].length},this.yytext+=Fn[0],this.match+=Fn[0],this.matches=Fn,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(Fn[0].length),this.matched+=Fn[0],Un=this.performAction.call(this,this.yy,this,qn,this.conditionStack[this.conditionStack.length-1]),this.done&&this._input&&(this.done=!1),Un)return Un;if(this._backtrack){for(var on in wt)this[on]=wt[on];return!1}return!1},next:function(){if(this.done)return this.EOF;this._input||(this.done=!0);var Fn,qn,Un,At;this._more||(this.yytext="",this.match="");for(var wt=this._currentRules(),on=0;onqn[0].length)){if(qn=Un,At=on,this.options.backtrack_lexer){if(Fn=this.test_match(Un,wt[on]),Fn!==!1)return Fn;if(this._backtrack){qn=!1;continue}else return!1}else if(!this.options.flex)break}return qn?(Fn=this.test_match(qn,wt[At]),Fn!==!1?Fn:!1):this._input===""?this.EOF:this.parseError("Lexical error on line "+(this.yylineno+1)+`. Unrecognized text. +`+this.showPosition(),{text:"",token:null,line:this.yylineno})},lex:function(){var qn=this.next();return qn||this.lex()},begin:function(qn){this.conditionStack.push(qn)},popState:function(){var qn=this.conditionStack.length-1;return qn>0?this.conditionStack.pop():this.conditionStack[0]},_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},topState:function(qn){return qn=this.conditionStack.length-1-Math.abs(qn||0),qn>=0?this.conditionStack[qn]:"INITIAL"},pushState:function(qn){this.begin(qn)},stateStackSize:function(){return this.conditionStack.length},options:{},performAction:function(qn,Un,At,wt){switch(At){case 0:return 6;case 1:return 7;case 2:return 8;case 3:return 9;case 4:return 22;case 5:return 23;case 6:return this.begin("acc_title"),24;case 7:return this.popState(),"acc_title_value";case 8:return this.begin("acc_descr"),26;case 9:return this.popState(),"acc_descr_value";case 10:this.begin("acc_descr_multiline");break;case 11:this.popState();break;case 12:return"acc_descr_multiline_value";case 13:break;case 14:c;break;case 15:return 12;case 16:break;case 17:return 11;case 18:return 15;case 19:return 16;case 20:return 17;case 21:return 18;case 22:return this.begin("person_ext"),45;case 23:return this.begin("person"),44;case 24:return this.begin("system_ext_queue"),51;case 25:return this.begin("system_ext_db"),50;case 26:return this.begin("system_ext"),49;case 27:return this.begin("system_queue"),48;case 28:return this.begin("system_db"),47;case 29:return this.begin("system"),46;case 30:return this.begin("boundary"),37;case 31:return this.begin("enterprise_boundary"),34;case 32:return this.begin("system_boundary"),36;case 33:return this.begin("container_ext_queue"),57;case 34:return this.begin("container_ext_db"),56;case 35:return this.begin("container_ext"),55;case 36:return this.begin("container_queue"),54;case 37:return this.begin("container_db"),53;case 38:return this.begin("container"),52;case 39:return this.begin("container_boundary"),38;case 40:return this.begin("component_ext_queue"),63;case 41:return this.begin("component_ext_db"),62;case 42:return this.begin("component_ext"),61;case 43:return this.begin("component_queue"),60;case 44:return this.begin("component_db"),59;case 45:return this.begin("component"),58;case 46:return this.begin("node"),39;case 47:return this.begin("node"),39;case 48:return this.begin("node_l"),40;case 49:return this.begin("node_r"),41;case 50:return this.begin("rel"),64;case 51:return this.begin("birel"),65;case 52:return this.begin("rel_u"),66;case 53:return this.begin("rel_u"),66;case 54:return this.begin("rel_d"),67;case 55:return this.begin("rel_d"),67;case 56:return this.begin("rel_l"),68;case 57:return this.begin("rel_l"),68;case 58:return this.begin("rel_r"),69;case 59:return this.begin("rel_r"),69;case 60:return this.begin("rel_b"),70;case 61:return this.begin("rel_index"),71;case 62:return this.begin("update_el_style"),72;case 63:return this.begin("update_rel_style"),73;case 64:return this.begin("update_layout_config"),74;case 65:return"EOF_IN_STRUCT";case 66:return this.begin("attribute"),"ATTRIBUTE_EMPTY";case 67:this.begin("attribute");break;case 68:this.popState(),this.popState();break;case 69:return 80;case 70:break;case 71:return 80;case 72:this.begin("string");break;case 73:this.popState();break;case 74:return"STR";case 75:this.begin("string_kv");break;case 76:return this.begin("string_kv_key"),"STR_KEY";case 77:this.popState(),this.begin("string_kv_value");break;case 78:return"STR_VALUE";case 79:this.popState(),this.popState();break;case 80:return"STR";case 81:return"LBRACE";case 82:return"RBRACE";case 83:return"SPACE";case 84:return"EOL";case 85:return 14}},rules:[/^(?:.*direction\s+TB[^\n]*)/,/^(?:.*direction\s+BT[^\n]*)/,/^(?:.*direction\s+RL[^\n]*)/,/^(?:.*direction\s+LR[^\n]*)/,/^(?:title\s[^#\n;]+)/,/^(?:accDescription\s[^#\n;]+)/,/^(?:accTitle\s*:\s*)/,/^(?:(?!\n||)*[^\n]*)/,/^(?:accDescr\s*:\s*)/,/^(?:(?!\n||)*[^\n]*)/,/^(?:accDescr\s*\{\s*)/,/^(?:[\}])/,/^(?:[^\}]*)/,/^(?:%%(?!\{)*[^\n]*(\r?\n?)+)/,/^(?:%%[^\n]*(\r?\n)*)/,/^(?:\s*(\r?\n)+)/,/^(?:\s+)/,/^(?:C4Context\b)/,/^(?:C4Container\b)/,/^(?:C4Component\b)/,/^(?:C4Dynamic\b)/,/^(?:C4Deployment\b)/,/^(?:Person_Ext\b)/,/^(?:Person\b)/,/^(?:SystemQueue_Ext\b)/,/^(?:SystemDb_Ext\b)/,/^(?:System_Ext\b)/,/^(?:SystemQueue\b)/,/^(?:SystemDb\b)/,/^(?:System\b)/,/^(?:Boundary\b)/,/^(?:Enterprise_Boundary\b)/,/^(?:System_Boundary\b)/,/^(?:ContainerQueue_Ext\b)/,/^(?:ContainerDb_Ext\b)/,/^(?:Container_Ext\b)/,/^(?:ContainerQueue\b)/,/^(?:ContainerDb\b)/,/^(?:Container\b)/,/^(?:Container_Boundary\b)/,/^(?:ComponentQueue_Ext\b)/,/^(?:ComponentDb_Ext\b)/,/^(?:Component_Ext\b)/,/^(?:ComponentQueue\b)/,/^(?:ComponentDb\b)/,/^(?:Component\b)/,/^(?:Deployment_Node\b)/,/^(?:Node\b)/,/^(?:Node_L\b)/,/^(?:Node_R\b)/,/^(?:Rel\b)/,/^(?:BiRel\b)/,/^(?:Rel_Up\b)/,/^(?:Rel_U\b)/,/^(?:Rel_Down\b)/,/^(?:Rel_D\b)/,/^(?:Rel_Left\b)/,/^(?:Rel_L\b)/,/^(?:Rel_Right\b)/,/^(?:Rel_R\b)/,/^(?:Rel_Back\b)/,/^(?:RelIndex\b)/,/^(?:UpdateElementStyle\b)/,/^(?:UpdateRelStyle\b)/,/^(?:UpdateLayoutConfig\b)/,/^(?:$)/,/^(?:[(][ ]*[,])/,/^(?:[(])/,/^(?:[)])/,/^(?:,,)/,/^(?:,)/,/^(?:[ ]*["]["])/,/^(?:[ ]*["])/,/^(?:["])/,/^(?:[^"]*)/,/^(?:[ ]*[\$])/,/^(?:[^=]*)/,/^(?:[=][ ]*["])/,/^(?:[^"]+)/,/^(?:["])/,/^(?:[^,]+)/,/^(?:\{)/,/^(?:\})/,/^(?:[\s]+)/,/^(?:[\n\r]+)/,/^(?:$)/],conditions:{acc_descr_multiline:{rules:[11,12],inclusive:!1},acc_descr:{rules:[9],inclusive:!1},acc_title:{rules:[7],inclusive:!1},string_kv_value:{rules:[78,79],inclusive:!1},string_kv_key:{rules:[77],inclusive:!1},string_kv:{rules:[76],inclusive:!1},string:{rules:[73,74],inclusive:!1},attribute:{rules:[68,69,70,71,72,75,80],inclusive:!1},update_layout_config:{rules:[65,66,67,68],inclusive:!1},update_rel_style:{rules:[65,66,67,68],inclusive:!1},update_el_style:{rules:[65,66,67,68],inclusive:!1},rel_b:{rules:[65,66,67,68],inclusive:!1},rel_r:{rules:[65,66,67,68],inclusive:!1},rel_l:{rules:[65,66,67,68],inclusive:!1},rel_d:{rules:[65,66,67,68],inclusive:!1},rel_u:{rules:[65,66,67,68],inclusive:!1},rel_bi:{rules:[],inclusive:!1},rel:{rules:[65,66,67,68],inclusive:!1},node_r:{rules:[65,66,67,68],inclusive:!1},node_l:{rules:[65,66,67,68],inclusive:!1},node:{rules:[65,66,67,68],inclusive:!1},index:{rules:[],inclusive:!1},rel_index:{rules:[65,66,67,68],inclusive:!1},component_ext_queue:{rules:[],inclusive:!1},component_ext_db:{rules:[65,66,67,68],inclusive:!1},component_ext:{rules:[65,66,67,68],inclusive:!1},component_queue:{rules:[65,66,67,68],inclusive:!1},component_db:{rules:[65,66,67,68],inclusive:!1},component:{rules:[65,66,67,68],inclusive:!1},container_boundary:{rules:[65,66,67,68],inclusive:!1},container_ext_queue:{rules:[65,66,67,68],inclusive:!1},container_ext_db:{rules:[65,66,67,68],inclusive:!1},container_ext:{rules:[65,66,67,68],inclusive:!1},container_queue:{rules:[65,66,67,68],inclusive:!1},container_db:{rules:[65,66,67,68],inclusive:!1},container:{rules:[65,66,67,68],inclusive:!1},birel:{rules:[65,66,67,68],inclusive:!1},system_boundary:{rules:[65,66,67,68],inclusive:!1},enterprise_boundary:{rules:[65,66,67,68],inclusive:!1},boundary:{rules:[65,66,67,68],inclusive:!1},system_ext_queue:{rules:[65,66,67,68],inclusive:!1},system_ext_db:{rules:[65,66,67,68],inclusive:!1},system_ext:{rules:[65,66,67,68],inclusive:!1},system_queue:{rules:[65,66,67,68],inclusive:!1},system_db:{rules:[65,66,67,68],inclusive:!1},system:{rules:[65,66,67,68],inclusive:!1},person_ext:{rules:[65,66,67,68],inclusive:!1},person:{rules:[65,66,67,68],inclusive:!1},INITIAL:{rules:[0,1,2,3,4,5,6,8,10,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,81,82,83,84,85],inclusive:!0}}};return Tr}();Ma.lexer=zs;function ao(){this.yy={}}return ao.prototype=Ma,Ma.Parser=ao,new ao}();CQ.parser=CQ;const DVt=CQ;let R3=[],M9=[""],Op="global",j3="",Q4=[{alias:"global",label:{text:"global"},type:{text:"global"},tags:null,link:null,parentBoundary:""}],pR=[],Rbe="",jbe=!1,SQ=4,_Q=2;var xqe;const IVt=function(){return xqe},OVt=function(i){xqe=Yf(i,qt())},NVt=function(i,s,u,d,p,v,b,y,T){if(i==null||s===void 0||s===null||u===void 0||u===null||d===void 0||d===null)return;let _={};const A=pR.find(P=>P.from===s&&P.to===u);if(A?_=A:pR.push(_),_.type=i,_.from=s,_.to=u,_.label={text:d},p==null)_.techn={text:""};else if(typeof p=="object"){let[P,R]=Object.entries(p)[0];_[P]={text:R}}else _.techn={text:p};if(v==null)_.descr={text:""};else if(typeof v=="object"){let[P,R]=Object.entries(v)[0];_[P]={text:R}}else _.descr={text:v};if(typeof b=="object"){let[P,R]=Object.entries(b)[0];_[P]=R}else _.sprite=b;if(typeof y=="object"){let[P,R]=Object.entries(y)[0];_[P]=R}else _.tags=y;if(typeof T=="object"){let[P,R]=Object.entries(T)[0];_[P]=R}else _.link=T;_.wrap=D9()},PVt=function(i,s,u,d,p,v,b){if(s===null||u===null)return;let y={};const T=R3.find(_=>_.alias===s);if(T&&s===T.alias?y=T:(y.alias=s,R3.push(y)),u==null?y.label={text:""}:y.label={text:u},d==null)y.descr={text:""};else if(typeof d=="object"){let[_,A]=Object.entries(d)[0];y[_]={text:A}}else y.descr={text:d};if(typeof p=="object"){let[_,A]=Object.entries(p)[0];y[_]=A}else y.sprite=p;if(typeof v=="object"){let[_,A]=Object.entries(v)[0];y[_]=A}else y.tags=v;if(typeof b=="object"){let[_,A]=Object.entries(b)[0];y[_]=A}else y.link=b;y.typeC4Shape={text:i},y.parentBoundary=Op,y.wrap=D9()},BVt=function(i,s,u,d,p,v,b,y){if(s===null||u===null)return;let T={};const _=R3.find(A=>A.alias===s);if(_&&s===_.alias?T=_:(T.alias=s,R3.push(T)),u==null?T.label={text:""}:T.label={text:u},d==null)T.techn={text:""};else if(typeof d=="object"){let[A,P]=Object.entries(d)[0];T[A]={text:P}}else T.techn={text:d};if(p==null)T.descr={text:""};else if(typeof p=="object"){let[A,P]=Object.entries(p)[0];T[A]={text:P}}else T.descr={text:p};if(typeof v=="object"){let[A,P]=Object.entries(v)[0];T[A]=P}else T.sprite=v;if(typeof b=="object"){let[A,P]=Object.entries(b)[0];T[A]=P}else T.tags=b;if(typeof y=="object"){let[A,P]=Object.entries(y)[0];T[A]=P}else T.link=y;T.wrap=D9(),T.typeC4Shape={text:i},T.parentBoundary=Op},FVt=function(i,s,u,d,p,v,b,y){if(s===null||u===null)return;let T={};const _=R3.find(A=>A.alias===s);if(_&&s===_.alias?T=_:(T.alias=s,R3.push(T)),u==null?T.label={text:""}:T.label={text:u},d==null)T.techn={text:""};else if(typeof d=="object"){let[A,P]=Object.entries(d)[0];T[A]={text:P}}else T.techn={text:d};if(p==null)T.descr={text:""};else if(typeof p=="object"){let[A,P]=Object.entries(p)[0];T[A]={text:P}}else T.descr={text:p};if(typeof v=="object"){let[A,P]=Object.entries(v)[0];T[A]=P}else T.sprite=v;if(typeof b=="object"){let[A,P]=Object.entries(b)[0];T[A]=P}else T.tags=b;if(typeof y=="object"){let[A,P]=Object.entries(y)[0];T[A]=P}else T.link=y;T.wrap=D9(),T.typeC4Shape={text:i},T.parentBoundary=Op},RVt=function(i,s,u,d,p){if(i===null||s===null)return;let v={};const b=Q4.find(y=>y.alias===i);if(b&&i===b.alias?v=b:(v.alias=i,Q4.push(v)),s==null?v.label={text:""}:v.label={text:s},u==null)v.type={text:"system"};else if(typeof u=="object"){let[y,T]=Object.entries(u)[0];v[y]={text:T}}else v.type={text:u};if(typeof d=="object"){let[y,T]=Object.entries(d)[0];v[y]=T}else v.tags=d;if(typeof p=="object"){let[y,T]=Object.entries(p)[0];v[y]=T}else v.link=p;v.parentBoundary=Op,v.wrap=D9(),j3=Op,Op=i,M9.push(j3)},jVt=function(i,s,u,d,p){if(i===null||s===null)return;let v={};const b=Q4.find(y=>y.alias===i);if(b&&i===b.alias?v=b:(v.alias=i,Q4.push(v)),s==null?v.label={text:""}:v.label={text:s},u==null)v.type={text:"container"};else if(typeof u=="object"){let[y,T]=Object.entries(u)[0];v[y]={text:T}}else v.type={text:u};if(typeof d=="object"){let[y,T]=Object.entries(d)[0];v[y]=T}else v.tags=d;if(typeof p=="object"){let[y,T]=Object.entries(p)[0];v[y]=T}else v.link=p;v.parentBoundary=Op,v.wrap=D9(),j3=Op,Op=i,M9.push(j3)},$Vt=function(i,s,u,d,p,v,b,y){if(s===null||u===null)return;let T={};const _=Q4.find(A=>A.alias===s);if(_&&s===_.alias?T=_:(T.alias=s,Q4.push(T)),u==null?T.label={text:""}:T.label={text:u},d==null)T.type={text:"node"};else if(typeof d=="object"){let[A,P]=Object.entries(d)[0];T[A]={text:P}}else T.type={text:d};if(p==null)T.descr={text:""};else if(typeof p=="object"){let[A,P]=Object.entries(p)[0];T[A]={text:P}}else T.descr={text:p};if(typeof b=="object"){let[A,P]=Object.entries(b)[0];T[A]=P}else T.tags=b;if(typeof y=="object"){let[A,P]=Object.entries(y)[0];T[A]=P}else T.link=y;T.nodeType=i,T.parentBoundary=Op,T.wrap=D9(),j3=Op,Op=s,M9.push(j3)},zVt=function(){Op=j3,M9.pop(),j3=M9.pop(),M9.push(j3)},qVt=function(i,s,u,d,p,v,b,y,T,_,A){let P=R3.find(R=>R.alias===s);if(!(P===void 0&&(P=Q4.find(R=>R.alias===s),P===void 0))){if(u!=null)if(typeof u=="object"){let[R,F]=Object.entries(u)[0];P[R]=F}else P.bgColor=u;if(d!=null)if(typeof d=="object"){let[R,F]=Object.entries(d)[0];P[R]=F}else P.fontColor=d;if(p!=null)if(typeof p=="object"){let[R,F]=Object.entries(p)[0];P[R]=F}else P.borderColor=p;if(v!=null)if(typeof v=="object"){let[R,F]=Object.entries(v)[0];P[R]=F}else P.shadowing=v;if(b!=null)if(typeof b=="object"){let[R,F]=Object.entries(b)[0];P[R]=F}else P.shape=b;if(y!=null)if(typeof y=="object"){let[R,F]=Object.entries(y)[0];P[R]=F}else P.sprite=y;if(T!=null)if(typeof T=="object"){let[R,F]=Object.entries(T)[0];P[R]=F}else P.techn=T;if(_!=null)if(typeof _=="object"){let[R,F]=Object.entries(_)[0];P[R]=F}else P.legendText=_;if(A!=null)if(typeof A=="object"){let[R,F]=Object.entries(A)[0];P[R]=F}else P.legendSprite=A}},HVt=function(i,s,u,d,p,v,b){const y=pR.find(T=>T.from===s&&T.to===u);if(y!==void 0){if(d!=null)if(typeof d=="object"){let[T,_]=Object.entries(d)[0];y[T]=_}else y.textColor=d;if(p!=null)if(typeof p=="object"){let[T,_]=Object.entries(p)[0];y[T]=_}else y.lineColor=p;if(v!=null)if(typeof v=="object"){let[T,_]=Object.entries(v)[0];y[T]=parseInt(_)}else y.offsetX=parseInt(v);if(b!=null)if(typeof b=="object"){let[T,_]=Object.entries(b)[0];y[T]=parseInt(_)}else y.offsetY=parseInt(b)}},VVt=function(i,s,u){let d=SQ,p=_Q;if(typeof s=="object"){const v=Object.values(s)[0];d=parseInt(v)}else d=parseInt(s);if(typeof u=="object"){const v=Object.values(u)[0];p=parseInt(v)}else p=parseInt(u);d>=1&&(SQ=d),p>=1&&(_Q=p)},UVt=function(){return SQ},GVt=function(){return _Q},KVt=function(){return Op},WVt=function(){return j3},kqe=function(i){return i==null?R3:R3.filter(s=>s.parentBoundary===i)},YVt=function(i){return R3.find(s=>s.alias===i)},XVt=function(i){return Object.keys(kqe(i))},Eqe=function(i){return i==null?Q4:Q4.filter(s=>s.parentBoundary===i)},QVt=Eqe,JVt=function(){return pR},ZVt=function(){return Rbe},eUt=function(i){jbe=i},D9=function(){return jbe},$be={addPersonOrSystem:PVt,addPersonOrSystemBoundary:RVt,addContainer:BVt,addContainerBoundary:jVt,addComponent:FVt,addDeploymentNode:$Vt,popBoundaryParseStack:zVt,addRel:NVt,updateElStyle:qVt,updateRelStyle:HVt,updateLayoutConfig:VVt,autoWrap:D9,setWrap:eUt,getC4ShapeArray:kqe,getC4Shape:YVt,getC4ShapeKeys:XVt,getBoundaries:Eqe,getBoundarys:QVt,getCurrentBoundaryParse:KVt,getParentBoundaryParse:WVt,getRels:JVt,getTitle:ZVt,getC4Type:IVt,getC4ShapeInRow:UVt,getC4BoundaryInRow:GVt,setAccTitle:Bg,getAccTitle:Cp,getAccDescription:_p,setAccDescription:Sp,getConfig:()=>qt().c4,clear:function(){R3=[],Q4=[{alias:"global",label:{text:"global"},type:{text:"global"},tags:null,link:null,parentBoundary:""}],j3="",Op="global",M9=[""],pR=[],M9=[""],Rbe="",jbe=!1,SQ=4,_Q=2},LINETYPE:{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},ARROWTYPE:{FILLED:0,OPEN:1},PLACEMENT:{LEFTOF:0,RIGHTOF:1,OVER:2},setTitle:function(i){Rbe=Yf(i,qt())},setC4Type:OVt},AQ=(i,s)=>{const u=i.append("rect");if(u.attr("x",s.x),u.attr("y",s.y),u.attr("fill",s.fill),u.attr("stroke",s.stroke),u.attr("width",s.width),u.attr("height",s.height),s.name&&u.attr("name",s.name),s.rx!==void 0&&u.attr("rx",s.rx),s.ry!==void 0&&u.attr("ry",s.ry),s.attrs!==void 0)for(const d in s.attrs)u.attr(d,s.attrs[d]);return s.class!==void 0&&u.attr("class",s.class),u},Tqe=(i,s)=>{const u={x:s.startx,y:s.starty,width:s.stopx-s.startx,height:s.stopy-s.starty,fill:s.fill,stroke:s.stroke,class:"rect"};AQ(i,u).lower()},tUt=(i,s)=>{const u=s.text.replace(fD," "),d=i.append("text");d.attr("x",s.x),d.attr("y",s.y),d.attr("class","legend"),d.style("text-anchor",s.anchor),s.class!==void 0&&d.attr("class",s.class);const p=d.append("tspan");return p.attr("x",s.x+s.textMargin*2),p.text(u),d},nUt=(i,s,u,d)=>{const p=i.append("image");p.attr("x",s),p.attr("y",u);const v=p9.sanitizeUrl(d);p.attr("xlink:href",v)},rUt=(i,s,u,d)=>{const p=i.append("use");p.attr("x",s),p.attr("y",u);const v=p9.sanitizeUrl(d);p.attr("xlink:href",`#${v}`)},qC=()=>({x:0,y:0,width:100,height:100,fill:"#EDF2AE",stroke:"#666",anchor:"start",rx:0,ry:0}),zbe=()=>({x:0,y:0,width:100,height:100,"text-anchor":"start",style:"#666",textMargin:0,rx:0,ry:0,tspan:!0}),qbe=function(i,s){return AQ(i,s)},Cqe=function(i,s,u,d,p,v){const b=i.append("image");b.attr("width",s),b.attr("height",u),b.attr("x",d),b.attr("y",p);let y=v.startsWith("data:image/png;base64")?v:p9.sanitizeUrl(v);b.attr("xlink:href",y)},iUt=(i,s,u)=>{const d=i.append("g");let p=0;for(let v of s){let b=v.textColor?v.textColor:"#444444",y=v.lineColor?v.lineColor:"#444444",T=v.offsetX?parseInt(v.offsetX):0,_=v.offsetY?parseInt(v.offsetY):0,A="";if(p===0){let R=d.append("line");R.attr("x1",v.startPoint.x),R.attr("y1",v.startPoint.y),R.attr("x2",v.endPoint.x),R.attr("y2",v.endPoint.y),R.attr("stroke-width","1"),R.attr("stroke",y),R.style("fill","none"),v.type!=="rel_b"&&R.attr("marker-end","url("+A+"#arrowhead)"),(v.type==="birel"||v.type==="rel_b")&&R.attr("marker-start","url("+A+"#arrowend)"),p=-1}else{let R=d.append("path");R.attr("fill","none").attr("stroke-width","1").attr("stroke",y).attr("d","Mstartx,starty Qcontrolx,controly stopx,stopy ".replaceAll("startx",v.startPoint.x).replaceAll("starty",v.startPoint.y).replaceAll("controlx",v.startPoint.x+(v.endPoint.x-v.startPoint.x)/2-(v.endPoint.x-v.startPoint.x)/4).replaceAll("controly",v.startPoint.y+(v.endPoint.y-v.startPoint.y)/2).replaceAll("stopx",v.endPoint.x).replaceAll("stopy",v.endPoint.y)),v.type!=="rel_b"&&R.attr("marker-end","url("+A+"#arrowhead)"),(v.type==="birel"||v.type==="rel_b")&&R.attr("marker-start","url("+A+"#arrowend)")}let P=u.messageFont();F7(u)(v.label.text,d,Math.min(v.startPoint.x,v.endPoint.x)+Math.abs(v.endPoint.x-v.startPoint.x)/2+T,Math.min(v.startPoint.y,v.endPoint.y)+Math.abs(v.endPoint.y-v.startPoint.y)/2+_,v.label.width,v.label.height,{fill:b},P),v.techn&&v.techn.text!==""&&(P=u.messageFont(),F7(u)("["+v.techn.text+"]",d,Math.min(v.startPoint.x,v.endPoint.x)+Math.abs(v.endPoint.x-v.startPoint.x)/2+T,Math.min(v.startPoint.y,v.endPoint.y)+Math.abs(v.endPoint.y-v.startPoint.y)/2+u.messageFontSize+5+_,Math.max(v.label.width,v.techn.width),v.techn.height,{fill:b,"font-style":"italic"},P))}},sUt=function(i,s,u){const d=i.append("g");let p=s.bgColor?s.bgColor:"none",v=s.borderColor?s.borderColor:"#444444",b=s.fontColor?s.fontColor:"black",y={"stroke-width":1,"stroke-dasharray":"7.0,7.0"};s.nodeType&&(y={"stroke-width":1});let T={x:s.x,y:s.y,fill:p,stroke:v,width:s.width,height:s.height,rx:2.5,ry:2.5,attrs:y};qbe(d,T);let _=u.boundaryFont();_.fontWeight="bold",_.fontSize=_.fontSize+2,_.fontColor=b,F7(u)(s.label.text,d,s.x,s.y+s.label.Y,s.width,s.height,{fill:"#444444"},_),s.type&&s.type.text!==""&&(_=u.boundaryFont(),_.fontColor=b,F7(u)(s.type.text,d,s.x,s.y+s.type.Y,s.width,s.height,{fill:"#444444"},_)),s.descr&&s.descr.text!==""&&(_=u.boundaryFont(),_.fontSize=_.fontSize-2,_.fontColor=b,F7(u)(s.descr.text,d,s.x,s.y+s.descr.Y,s.width,s.height,{fill:"#444444"},_))},aUt=function(i,s,u){var P;let d=s.bgColor?s.bgColor:u[s.typeC4Shape.text+"_bg_color"],p=s.borderColor?s.borderColor:u[s.typeC4Shape.text+"_border_color"],v=s.fontColor?s.fontColor:"#FFFFFF",b="";switch(s.typeC4Shape.text){case"person":b="";break;case"external_person":b="";break}const y=i.append("g");y.attr("class","person-man");const T=qC();switch(s.typeC4Shape.text){case"person":case"external_person":case"system":case"external_system":case"container":case"external_container":case"component":case"external_component":T.x=s.x,T.y=s.y,T.fill=d,T.width=s.width,T.height=s.height,T.stroke=p,T.rx=2.5,T.ry=2.5,T.attrs={"stroke-width":.5},qbe(y,T);break;case"system_db":case"external_system_db":case"container_db":case"external_container_db":case"component_db":case"external_component_db":y.append("path").attr("fill",d).attr("stroke-width","0.5").attr("stroke",p).attr("d","Mstartx,startyc0,-10 half,-10 half,-10c0,0 half,0 half,10l0,heightc0,10 -half,10 -half,10c0,0 -half,0 -half,-10l0,-height".replaceAll("startx",s.x).replaceAll("starty",s.y).replaceAll("half",s.width/2).replaceAll("height",s.height)),y.append("path").attr("fill","none").attr("stroke-width","0.5").attr("stroke",p).attr("d","Mstartx,startyc0,10 half,10 half,10c0,0 half,0 half,-10".replaceAll("startx",s.x).replaceAll("starty",s.y).replaceAll("half",s.width/2));break;case"system_queue":case"external_system_queue":case"container_queue":case"external_container_queue":case"component_queue":case"external_component_queue":y.append("path").attr("fill",d).attr("stroke-width","0.5").attr("stroke",p).attr("d","Mstartx,startylwidth,0c5,0 5,half 5,halfc0,0 0,half -5,halfl-width,0c-5,0 -5,-half -5,-halfc0,0 0,-half 5,-half".replaceAll("startx",s.x).replaceAll("starty",s.y).replaceAll("width",s.width).replaceAll("half",s.height/2)),y.append("path").attr("fill","none").attr("stroke-width","0.5").attr("stroke",p).attr("d","Mstartx,startyc-5,0 -5,half -5,halfc0,half 5,half 5,half".replaceAll("startx",s.x+s.width).replaceAll("starty",s.y).replaceAll("half",s.height/2));break}let _=pUt(u,s.typeC4Shape.text);switch(y.append("text").attr("fill",v).attr("font-family",_.fontFamily).attr("font-size",_.fontSize-2).attr("font-style","italic").attr("lengthAdjust","spacing").attr("textLength",s.typeC4Shape.width).attr("x",s.x+s.width/2-s.typeC4Shape.width/2).attr("y",s.y+s.typeC4Shape.Y).text("<<"+s.typeC4Shape.text+">>"),s.typeC4Shape.text){case"person":case"external_person":Cqe(y,48,48,s.x+s.width/2-24,s.y+s.image.Y,b);break}let A=u[s.typeC4Shape.text+"Font"]();return A.fontWeight="bold",A.fontSize=A.fontSize+2,A.fontColor=v,F7(u)(s.label.text,y,s.x,s.y+s.label.Y,s.width,s.height,{fill:v},A),A=u[s.typeC4Shape.text+"Font"](),A.fontColor=v,s.techn&&((P=s.techn)==null?void 0:P.text)!==""?F7(u)(s.techn.text,y,s.x,s.y+s.techn.Y,s.width,s.height,{fill:v,"font-style":"italic"},A):s.type&&s.type.text!==""&&F7(u)(s.type.text,y,s.x,s.y+s.type.Y,s.width,s.height,{fill:v,"font-style":"italic"},A),s.descr&&s.descr.text!==""&&(A=u.personFont(),A.fontColor=v,F7(u)(s.descr.text,y,s.x,s.y+s.descr.Y,s.width,s.height,{fill:v},A)),s.height},oUt=function(i){i.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-.047.148-.048.143-.049.139-.049.136-.05.131-.05.126-.05.123-.051.118-.052.114-.051.11-.052.106-.052.101-.052.096-.052.092-.052.088-.053.083-.051.079-.052.074-.052.07-.051.065-.051.06-.051.056-.05.051-.05.023-.024.023-.025.021-.024.02-.024.019-.024.018-.024.017-.024.015-.023.014-.024.013-.023.012-.023.01-.023.01-.022.008-.022.006-.022.006-.022.004-.022.004-.021.001-.021.001-.021v-4.127l-.077.055-.08.053-.083.054-.085.053-.087.052-.09.052-.093.051-.095.05-.097.05-.1.049-.102.049-.105.048-.106.047-.109.047-.111.046-.114.045-.115.045-.118.044-.12.043-.122.042-.124.042-.126.041-.128.04-.13.04-.132.038-.134.038-.135.037-.138.037-.139.035-.142.035-.143.034-.144.033-.147.032-.148.031-.15.03-.151.03-.153.029-.154.027-.156.027-.158.026-.159.025-.161.024-.162.023-.163.022-.165.021-.166.02-.167.019-.169.018-.169.017-.171.016-.173.015-.173.014-.175.013-.175.012-.177.011-.178.01-.179.008-.179.008-.181.006-.182.005-.182.004-.184.003-.184.002h-.37l-.184-.002-.184-.003-.182-.004-.182-.005-.181-.006-.179-.008-.179-.008-.178-.01-.176-.011-.176-.012-.175-.013-.173-.014-.172-.015-.171-.016-.17-.017-.169-.018-.167-.019-.166-.02-.165-.021-.163-.022-.162-.023-.161-.024-.159-.025-.157-.026-.156-.027-.155-.027-.153-.029-.151-.03-.15-.03-.148-.031-.146-.032-.145-.033-.143-.034-.141-.035-.14-.035-.137-.037-.136-.037-.134-.038-.132-.038-.13-.04-.128-.04-.126-.041-.124-.042-.122-.042-.12-.044-.117-.043-.116-.045-.113-.045-.112-.046-.109-.047-.106-.047-.105-.048-.102-.049-.1-.049-.097-.05-.095-.05-.093-.052-.09-.051-.087-.052-.085-.053-.083-.054-.08-.054-.077-.054v4.127zm0-5.654v.011l.001.021.003.021.004.021.005.022.006.022.007.022.009.022.01.022.011.023.012.023.013.023.015.024.016.023.017.024.018.024.019.024.021.024.022.024.023.025.024.024.052.05.056.05.061.05.066.051.07.051.075.052.079.051.084.052.088.052.092.052.097.052.102.052.105.052.11.051.114.051.119.052.123.05.127.051.131.05.135.049.139.049.144.048.147.048.152.047.155.046.16.045.163.045.167.044.171.042.176.042.178.04.183.04.187.038.19.037.194.036.197.034.202.033.204.032.209.03.212.028.216.027.219.025.222.024.226.022.23.02.233.018.236.016.24.014.243.012.246.01.249.008.253.006.256.003.259.001.26-.001.257-.003.254-.006.25-.008.247-.01.244-.012.241-.015.237-.016.233-.018.231-.02.226-.022.224-.024.22-.025.216-.027.212-.029.21-.03.205-.032.202-.033.198-.035.194-.036.191-.037.187-.039.183-.039.179-.041.175-.042.172-.043.168-.044.163-.045.16-.045.155-.047.152-.047.148-.048.143-.048.139-.05.136-.049.131-.05.126-.051.123-.051.118-.051.114-.052.11-.052.106-.052.101-.052.096-.052.092-.052.088-.052.083-.052.079-.052.074-.051.07-.052.065-.051.06-.05.056-.051.051-.049.023-.025.023-.024.021-.025.02-.024.019-.024.018-.024.017-.024.015-.023.014-.023.013-.024.012-.022.01-.023.01-.023.008-.022.006-.022.006-.022.004-.021.004-.022.001-.021.001-.021v-4.139l-.077.054-.08.054-.083.054-.085.052-.087.053-.09.051-.093.051-.095.051-.097.05-.1.049-.102.049-.105.048-.106.047-.109.047-.111.046-.114.045-.115.044-.118.044-.12.044-.122.042-.124.042-.126.041-.128.04-.13.039-.132.039-.134.038-.135.037-.138.036-.139.036-.142.035-.143.033-.144.033-.147.033-.148.031-.15.03-.151.03-.153.028-.154.028-.156.027-.158.026-.159.025-.161.024-.162.023-.163.022-.165.021-.166.02-.167.019-.169.018-.169.017-.171.016-.173.015-.173.014-.175.013-.175.012-.177.011-.178.009-.179.009-.179.007-.181.007-.182.005-.182.004-.184.003-.184.002h-.37l-.184-.002-.184-.003-.182-.004-.182-.005-.181-.007-.179-.007-.179-.009-.178-.009-.176-.011-.176-.012-.175-.013-.173-.014-.172-.015-.171-.016-.17-.017-.169-.018-.167-.019-.166-.02-.165-.021-.163-.022-.162-.023-.161-.024-.159-.025-.157-.026-.156-.027-.155-.028-.153-.028-.151-.03-.15-.03-.148-.031-.146-.033-.145-.033-.143-.033-.141-.035-.14-.036-.137-.036-.136-.037-.134-.038-.132-.039-.13-.039-.128-.04-.126-.041-.124-.042-.122-.043-.12-.043-.117-.044-.116-.044-.113-.046-.112-.046-.109-.046-.106-.047-.105-.048-.102-.049-.1-.049-.097-.05-.095-.051-.093-.051-.09-.051-.087-.053-.085-.052-.083-.054-.08-.054-.077-.054v4.139zm0-5.666v.011l.001.02.003.022.004.021.005.022.006.021.007.022.009.023.01.022.011.023.012.023.013.023.015.023.016.024.017.024.018.023.019.024.021.025.022.024.023.024.024.025.052.05.056.05.061.05.066.051.07.051.075.052.079.051.084.052.088.052.092.052.097.052.102.052.105.051.11.052.114.051.119.051.123.051.127.05.131.05.135.05.139.049.144.048.147.048.152.047.155.046.16.045.163.045.167.043.171.043.176.042.178.04.183.04.187.038.19.037.194.036.197.034.202.033.204.032.209.03.212.028.216.027.219.025.222.024.226.021.23.02.233.018.236.017.24.014.243.012.246.01.249.008.253.006.256.003.259.001.26-.001.257-.003.254-.006.25-.008.247-.01.244-.013.241-.014.237-.016.233-.018.231-.02.226-.022.224-.024.22-.025.216-.027.212-.029.21-.03.205-.032.202-.033.198-.035.194-.036.191-.037.187-.039.183-.039.179-.041.175-.042.172-.043.168-.044.163-.045.16-.045.155-.047.152-.047.148-.048.143-.049.139-.049.136-.049.131-.051.126-.05.123-.051.118-.052.114-.051.11-.052.106-.052.101-.052.096-.052.092-.052.088-.052.083-.052.079-.052.074-.052.07-.051.065-.051.06-.051.056-.05.051-.049.023-.025.023-.025.021-.024.02-.024.019-.024.018-.024.017-.024.015-.023.014-.024.013-.023.012-.023.01-.022.01-.023.008-.022.006-.022.006-.022.004-.022.004-.021.001-.021.001-.021v-4.153l-.077.054-.08.054-.083.053-.085.053-.087.053-.09.051-.093.051-.095.051-.097.05-.1.049-.102.048-.105.048-.106.048-.109.046-.111.046-.114.046-.115.044-.118.044-.12.043-.122.043-.124.042-.126.041-.128.04-.13.039-.132.039-.134.038-.135.037-.138.036-.139.036-.142.034-.143.034-.144.033-.147.032-.148.032-.15.03-.151.03-.153.028-.154.028-.156.027-.158.026-.159.024-.161.024-.162.023-.163.023-.165.021-.166.02-.167.019-.169.018-.169.017-.171.016-.173.015-.173.014-.175.013-.175.012-.177.01-.178.01-.179.009-.179.007-.181.006-.182.006-.182.004-.184.003-.184.001-.185.001-.185-.001-.184-.001-.184-.003-.182-.004-.182-.006-.181-.006-.179-.007-.179-.009-.178-.01-.176-.01-.176-.012-.175-.013-.173-.014-.172-.015-.171-.016-.17-.017-.169-.018-.167-.019-.166-.02-.165-.021-.163-.023-.162-.023-.161-.024-.159-.024-.157-.026-.156-.027-.155-.028-.153-.028-.151-.03-.15-.03-.148-.032-.146-.032-.145-.033-.143-.034-.141-.034-.14-.036-.137-.036-.136-.037-.134-.038-.132-.039-.13-.039-.128-.041-.126-.041-.124-.041-.122-.043-.12-.043-.117-.044-.116-.044-.113-.046-.112-.046-.109-.046-.106-.048-.105-.048-.102-.048-.1-.05-.097-.049-.095-.051-.093-.051-.09-.052-.087-.052-.085-.053-.083-.053-.08-.054-.077-.054v4.153zm8.74-8.179l-.257.004-.254.005-.25.008-.247.011-.244.012-.241.014-.237.016-.233.018-.231.021-.226.022-.224.023-.22.026-.216.027-.212.028-.21.031-.205.032-.202.033-.198.034-.194.036-.191.038-.187.038-.183.04-.179.041-.175.042-.172.043-.168.043-.163.045-.16.046-.155.046-.152.048-.148.048-.143.048-.139.049-.136.05-.131.05-.126.051-.123.051-.118.051-.114.052-.11.052-.106.052-.101.052-.096.052-.092.052-.088.052-.083.052-.079.052-.074.051-.07.052-.065.051-.06.05-.056.05-.051.05-.023.025-.023.024-.021.024-.02.025-.019.024-.018.024-.017.023-.015.024-.014.023-.013.023-.012.023-.01.023-.01.022-.008.022-.006.023-.006.021-.004.022-.004.021-.001.021-.001.021.001.021.001.021.004.021.004.022.006.021.006.023.008.022.01.022.01.023.012.023.013.023.014.023.015.024.017.023.018.024.019.024.02.025.021.024.023.024.023.025.051.05.056.05.06.05.065.051.07.052.074.051.079.052.083.052.088.052.092.052.096.052.101.052.106.052.11.052.114.052.118.051.123.051.126.051.131.05.136.05.139.049.143.048.148.048.152.048.155.046.16.046.163.045.168.043.172.043.175.042.179.041.183.04.187.038.191.038.194.036.198.034.202.033.205.032.21.031.212.028.216.027.22.026.224.023.226.022.231.021.233.018.237.016.241.014.244.012.247.011.25.008.254.005.257.004.26.001.26-.001.257-.004.254-.005.25-.008.247-.011.244-.012.241-.014.237-.016.233-.018.231-.021.226-.022.224-.023.22-.026.216-.027.212-.028.21-.031.205-.032.202-.033.198-.034.194-.036.191-.038.187-.038.183-.04.179-.041.175-.042.172-.043.168-.043.163-.045.16-.046.155-.046.152-.048.148-.048.143-.048.139-.049.136-.05.131-.05.126-.051.123-.051.118-.051.114-.052.11-.052.106-.052.101-.052.096-.052.092-.052.088-.052.083-.052.079-.052.074-.051.07-.052.065-.051.06-.05.056-.05.051-.05.023-.025.023-.024.021-.024.02-.025.019-.024.018-.024.017-.023.015-.024.014-.023.013-.023.012-.023.01-.023.01-.022.008-.022.006-.023.006-.021.004-.022.004-.021.001-.021.001-.021-.001-.021-.001-.021-.004-.021-.004-.022-.006-.021-.006-.023-.008-.022-.01-.022-.01-.023-.012-.023-.013-.023-.014-.023-.015-.024-.017-.023-.018-.024-.019-.024-.02-.025-.021-.024-.023-.024-.023-.025-.051-.05-.056-.05-.06-.05-.065-.051-.07-.052-.074-.051-.079-.052-.083-.052-.088-.052-.092-.052-.096-.052-.101-.052-.106-.052-.11-.052-.114-.052-.118-.051-.123-.051-.126-.051-.131-.05-.136-.05-.139-.049-.143-.048-.148-.048-.152-.048-.155-.046-.16-.046-.163-.045-.168-.043-.172-.043-.175-.042-.179-.041-.183-.04-.187-.038-.191-.038-.194-.036-.198-.034-.202-.033-.205-.032-.21-.031-.212-.028-.216-.027-.22-.026-.224-.023-.226-.022-.231-.021-.233-.018-.237-.016-.241-.014-.244-.012-.247-.011-.25-.008-.254-.005-.257-.004-.26-.001-.26.001z")},cUt=function(i){i.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")},uUt=function(i){i.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")},lUt=function(i){i.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")},hUt=function(i){i.append("defs").append("marker").attr("id","arrowend").attr("refX",1).attr("refY",5).attr("markerUnits","userSpaceOnUse").attr("markerWidth",12).attr("markerHeight",12).attr("orient","auto").append("path").attr("d","M 10 0 L 0 5 L 10 10 z")},fUt=function(i){i.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")},dUt=function(i){i.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)},gUt=function(i){const u=i.append("defs").append("marker").attr("id","crosshead").attr("markerWidth",15).attr("markerHeight",8).attr("orient","auto").attr("refX",16).attr("refY",4);u.append("path").attr("fill","black").attr("stroke","#000000").style("stroke-dasharray","0, 0").attr("stroke-width","1px").attr("d","M 9,2 V 6 L16,4 Z"),u.append("path").attr("fill","none").attr("stroke","#000000").style("stroke-dasharray","0, 0").attr("stroke-width","1px").attr("d","M 0,1 L 6,7 M 6,1 L 0,7")},pUt=(i,s)=>({fontFamily:i[s+"FontFamily"],fontSize:i[s+"FontSize"],fontWeight:i[s+"FontWeight"]}),F7=function(){function i(p,v,b,y,T,_,A){const P=v.append("text").attr("x",b+T/2).attr("y",y+_/2+5).style("text-anchor","middle").text(p);d(P,A)}function s(p,v,b,y,T,_,A,P){const{fontSize:R,fontFamily:F,fontWeight:j}=P,K=p.split(ci.lineBreakRegex);for(let ee=0;ee=this.data.widthLimit||d>=this.data.widthLimit||this.nextData.cnt>Sqe)&&(u=this.nextData.startx+s.margin+$s.nextLinePaddingX,p=this.nextData.stopy+s.margin*2,this.nextData.stopx=d=u+s.width,this.nextData.starty=this.nextData.stopy,this.nextData.stopy=v=p+s.height,this.nextData.cnt=1),s.x=u,s.y=p,this.updateVal(this.data,"startx",u,Math.min),this.updateVal(this.data,"starty",p,Math.min),this.updateVal(this.data,"stopx",d,Math.max),this.updateVal(this.data,"stopy",v,Math.max),this.updateVal(this.nextData,"startx",u,Math.min),this.updateVal(this.nextData,"starty",p,Math.min),this.updateVal(this.nextData,"stopx",d,Math.max),this.updateVal(this.nextData,"stopy",v,Math.max)}init(s){this.name="",this.data={startx:void 0,stopx:void 0,starty:void 0,stopy:void 0,widthLimit:void 0},this.nextData={startx:void 0,stopx:void 0,starty:void 0,stopy:void 0,cnt:0},Vbe(s.db.getConfig())}bumpLastMargin(s){this.data.stopx+=s,this.data.stopy+=s}}const Vbe=function(i){id($s,i),i.fontFamily&&($s.personFontFamily=$s.systemFontFamily=$s.messageFontFamily=i.fontFamily),i.fontSize&&($s.personFontSize=$s.systemFontSize=$s.messageFontSize=i.fontSize),i.fontWeight&&($s.personFontWeight=$s.systemFontWeight=$s.messageFontWeight=i.fontWeight)},bR=(i,s)=>({fontFamily:i[s+"FontFamily"],fontSize:i[s+"FontSize"],fontWeight:i[s+"FontWeight"]}),DQ=i=>({fontFamily:i.boundaryFontFamily,fontSize:i.boundaryFontSize,fontWeight:i.boundaryFontWeight}),bUt=i=>({fontFamily:i.messageFontFamily,fontSize:i.messageFontSize,fontWeight:i.messageFontWeight});function $3(i,s,u,d,p){if(!s[i].width)if(u)s[i].text=vje(s[i].text,p,d),s[i].textLines=s[i].text.split(ci.lineBreakRegex).length,s[i].width=p,s[i].height=E2e(s[i].text,d);else{let v=s[i].text.split(ci.lineBreakRegex);s[i].textLines=v.length;let b=0;s[i].height=0,s[i].width=0;for(const y of v)s[i].width=Math.max(H4(y,d),s[i].width),b=E2e(y,d),s[i].height=s[i].height+b}}const Aqe=function(i,s,u){s.x=u.data.startx,s.y=u.data.starty,s.width=u.data.stopx-u.data.startx,s.height=u.data.stopy-u.data.starty,s.label.y=$s.c4ShapeMargin-35;let d=s.wrap&&$s.wrap,p=DQ($s);p.fontSize=p.fontSize+2,p.fontWeight="bold";let v=H4(s.label.text,p);$3("label",s,d,p,v),J4.drawBoundary(i,s,$s)},Lqe=function(i,s,u,d){let p=0;for(const v of d){p=0;const b=u[v];let y=bR($s,b.typeC4Shape.text);switch(y.fontSize=y.fontSize-2,b.typeC4Shape.width=H4("«"+b.typeC4Shape.text+"»",y),b.typeC4Shape.height=y.fontSize+2,b.typeC4Shape.Y=$s.c4ShapePadding,p=b.typeC4Shape.Y+b.typeC4Shape.height-4,b.image={width:0,height:0,Y:0},b.typeC4Shape.text){case"person":case"external_person":b.image.width=48,b.image.height=48,b.image.Y=p,p=b.image.Y+b.image.height;break}b.sprite&&(b.image.width=48,b.image.height=48,b.image.Y=p,p=b.image.Y+b.image.height);let T=b.wrap&&$s.wrap,_=$s.width-$s.c4ShapePadding*2,A=bR($s,b.typeC4Shape.text);if(A.fontSize=A.fontSize+2,A.fontWeight="bold",$3("label",b,T,A,_),b.label.Y=p+8,p=b.label.Y+b.label.height,b.type&&b.type.text!==""){b.type.text="["+b.type.text+"]";let F=bR($s,b.typeC4Shape.text);$3("type",b,T,F,_),b.type.Y=p+5,p=b.type.Y+b.type.height}else if(b.techn&&b.techn.text!==""){b.techn.text="["+b.techn.text+"]";let F=bR($s,b.techn.text);$3("techn",b,T,F,_),b.techn.Y=p+5,p=b.techn.Y+b.techn.height}let P=p,R=b.label.width;if(b.descr&&b.descr.text!==""){let F=bR($s,b.typeC4Shape.text);$3("descr",b,T,F,_),b.descr.Y=p+20,p=b.descr.Y+b.descr.height,R=Math.max(b.label.width,b.descr.width),P=p-b.descr.textLines*5}R=R+$s.c4ShapePadding,b.width=Math.max(b.width||$s.width,R,$s.width),b.height=Math.max(b.height||$s.height,P,$s.height),b.margin=b.margin||$s.c4ShapeMargin,i.insert(b),J4.drawC4Shape(s,b,$s)}i.bumpLastMargin($s.c4ShapeMargin)};let jv=class{constructor(s,u){this.x=s,this.y=u}},Mqe=function(i,s){let u=i.x,d=i.y,p=s.x,v=s.y,b=u+i.width/2,y=d+i.height/2,T=Math.abs(u-p),_=Math.abs(d-v),A=_/T,P=i.height/i.width,R=null;return d==v&&up?R=new jv(u,y):u==p&&dv&&(R=new jv(b,d)),u>p&&d=A?R=new jv(u,y+A*i.width/2):R=new jv(b-T/_*i.height/2,d+i.height):u=A?R=new jv(u+i.width,y+A*i.width/2):R=new jv(b+T/_*i.height/2,d+i.height):uv?P>=A?R=new jv(u+i.width,y-A*i.width/2):R=new jv(b+i.height/2*T/_,d):u>p&&d>v&&(P>=A?R=new jv(u,y-i.width/2*A):R=new jv(b-i.height/2*T/_,d)),R},mUt=function(i,s){let u={x:0,y:0};u.x=s.x+s.width/2,u.y=s.y+s.height/2;let d=Mqe(i,u);u.x=i.x+i.width/2,u.y=i.y+i.height/2;let p=Mqe(s,u);return{startPoint:d,endPoint:p}};const vUt=function(i,s,u,d){let p=0;for(let v of s){p=p+1;let b=v.wrap&&$s.wrap,y=bUt($s);d.db.getC4Type()==="C4Dynamic"&&(v.label.text=p+": "+v.label.text);let _=H4(v.label.text,y);$3("label",v,b,y,_),v.techn&&v.techn.text!==""&&(_=H4(v.techn.text,y),$3("techn",v,b,y,_)),v.descr&&v.descr.text!==""&&(_=H4(v.descr.text,y),$3("descr",v,b,y,_));let A=u(v.from),P=u(v.to),R=mUt(A,P);v.startPoint=R.startPoint,v.endPoint=R.endPoint}J4.drawRels(i,s,$s)};function Dqe(i,s,u,d,p){let v=new _qe(p);v.data.widthLimit=u.data.widthLimit/Math.min(Hbe,d.length);for(let[b,y]of d.entries()){let T=0;y.image={width:0,height:0,Y:0},y.sprite&&(y.image.width=48,y.image.height=48,y.image.Y=T,T=y.image.Y+y.image.height);let _=y.wrap&&$s.wrap,A=DQ($s);if(A.fontSize=A.fontSize+2,A.fontWeight="bold",$3("label",y,_,A,v.data.widthLimit),y.label.Y=T+8,T=y.label.Y+y.label.height,y.type&&y.type.text!==""){y.type.text="["+y.type.text+"]";let j=DQ($s);$3("type",y,_,j,v.data.widthLimit),y.type.Y=T+5,T=y.type.Y+y.type.height}if(y.descr&&y.descr.text!==""){let j=DQ($s);j.fontSize=j.fontSize-2,$3("descr",y,_,j,v.data.widthLimit),y.descr.Y=T+20,T=y.descr.Y+y.descr.height}if(b==0||b%Hbe===0){let j=u.data.startx+$s.diagramMarginX,K=u.data.stopy+$s.diagramMarginY+T;v.setData(j,j,K,K)}else{let j=v.data.stopx!==v.data.startx?v.data.stopx+$s.diagramMarginX:v.data.startx,K=v.data.starty;v.setData(j,j,K,K)}v.name=y.alias;let P=p.db.getC4ShapeArray(y.alias),R=p.db.getC4ShapeKeys(y.alias);R.length>0&&Lqe(v,i,P,R),s=y.alias;let F=p.db.getBoundarys(s);F.length>0&&Dqe(i,s,v,F,p),y.alias!=="global"&&Aqe(i,y,v),u.data.stopy=Math.max(v.data.stopy+$s.c4ShapeMargin,u.data.stopy),u.data.stopx=Math.max(v.data.stopx+$s.c4ShapeMargin,u.data.stopx),LQ=Math.max(LQ,u.data.stopx),MQ=Math.max(MQ,u.data.stopy)}}const Iqe={drawPersonOrSystemArray:Lqe,drawBoundary:Aqe,setConf:Vbe,draw:function(i,s,u,d){$s=qt().c4;const p=qt().securityLevel;let v;p==="sandbox"&&(v=Ir("#i"+s));const b=Ir(p==="sandbox"?v.nodes()[0].contentDocument.body:"body");let y=d.db;d.db.setWrap($s.wrap),Sqe=y.getC4ShapeInRow(),Hbe=y.getC4BoundaryInRow(),Xe.debug(`C:${JSON.stringify($s,null,2)}`);const T=p==="sandbox"?b.select(`[id="${s}"]`):Ir(`[id="${s}"]`);J4.insertComputerIcon(T),J4.insertDatabaseIcon(T),J4.insertClockIcon(T);let _=new _qe(d);_.setData($s.diagramMarginX,$s.diagramMarginX,$s.diagramMarginY,$s.diagramMarginY),_.data.widthLimit=screen.availWidth,LQ=$s.diagramMarginX,MQ=$s.diagramMarginY;const A=d.db.getTitle();let P=d.db.getBoundarys("");Dqe(T,"",_,P,d),J4.insertArrowHead(T),J4.insertArrowEnd(T),J4.insertArrowCrossHead(T),J4.insertArrowFilledHead(T),vUt(T,d.db.getRels(),d.db.getC4Shape,d),_.data.stopx=LQ,_.data.stopy=MQ;const R=_.data;let j=R.stopy-R.starty+2*$s.diagramMarginY;const ee=R.stopx-R.startx+2*$s.diagramMarginX;A&&T.append("text").text(A).attr("x",(R.stopx-R.startx)/2-4*$s.diagramMarginX).attr("y",R.starty+$s.diagramMarginY),Ng(T,j,ee,$s.useMaxWidth);const ie=A?60:0;T.attr("viewBox",R.startx-$s.diagramMarginX+" -"+($s.diagramMarginY+ie)+" "+ee+" "+(j+ie)),Xe.debug("models:",R)}},wUt=Object.freeze(Object.defineProperty({__proto__:null,diagram:{parser:DVt,db:$be,renderer:Iqe,styles:i=>`.person { + stroke: ${i.personBorder}; + fill: ${i.personBkg}; + } +`,init:({c4:i,wrap:s})=>{Iqe.setConf(i),$be.setWrap(s)}}},Symbol.toStringTag,{value:"Module"}));var Ube=function(){var i=function($0,Wi,Bs,Qa){for(Bs=Bs||{},Qa=$0.length;Qa--;Bs[$0[Qa]]=Wi);return Bs},s=[1,4],u=[1,3],d=[1,5],p=[1,8,9,10,11,27,34,36,38,42,58,81,82,83,84,85,86,99,102,103,106,108,111,112,113,118,119,120,121],v=[2,2],b=[1,13],y=[1,14],T=[1,15],_=[1,16],A=[1,23],P=[1,25],R=[1,26],F=[1,27],j=[1,49],K=[1,48],ee=[1,29],ie=[1,30],oe=[1,31],pe=[1,32],be=[1,33],ae=[1,44],ne=[1,46],se=[1,42],de=[1,47],X=[1,43],ge=[1,50],W=[1,45],xe=[1,51],U=[1,52],Fe=[1,34],Pe=[1,35],je=[1,36],Ie=[1,37],Se=[1,57],Ce=[1,8,9,10,11,27,32,34,36,38,42,58,81,82,83,84,85,86,99,102,103,106,108,111,112,113,118,119,120,121],ke=[1,61],Ke=[1,60],Ft=[1,62],Ne=[8,9,11,73,75],gn=[1,88],_t=[1,93],Et=[1,92],Gt=[1,89],ln=[1,85],xt=[1,91],Pt=[1,87],Qe=[1,94],Dt=[1,90],kt=[1,95],On=[1,86],ht=[8,9,10,11,73,75],zr=[8,9,10,11,44,73,75],yt=[8,9,10,11,29,42,44,46,48,50,52,54,56,58,61,63,65,66,68,73,75,86,99,102,103,106,108,111,112,113],ji=[8,9,11,42,58,73,75,86,99,102,103,106,108,111,112,113],xi=[42,58,86,99,102,103,106,108,111,112,113],Ma=[1,121],zs=[1,120],ao=[1,128],Tr=[1,142],Fn=[1,143],qn=[1,144],Un=[1,145],At=[1,130],wt=[1,132],on=[1,136],fn=[1,137],An=[1,138],oo=[1,139],jo=[1,140],$o=[1,141],Pa=[1,146],wo=[1,147],_s=[1,126],tl=[1,127],da=[1,134],j0=[1,129],pm=[1,133],Ml=[1,131],Xc=[8,9,10,11,27,32,34,36,38,42,58,81,82,83,84,85,86,99,102,103,106,108,111,112,113,118,119,120,121],Bc=[1,149],ja=[8,9,11],Ou=[8,9,10,11,14,42,58,86,102,103,106,108,111,112,113],Sa=[1,169],Po=[1,165],Fc=[1,166],xa=[1,170],Ba=[1,167],ga=[1,168],kh=[75,113,116],lu=[8,9,10,11,12,14,27,29,32,42,58,73,81,82,83,84,85,86,87,102,106,108,111,112,113],o5=[10,103],Wh=[31,47,49,51,53,55,60,62,64,65,67,69,113,114,115],od=[1,235],Gd=[1,233],cd=[1,237],Kd=[1,231],$g=[1,232],as=[1,234],wn=[1,236],Zr=[1,238],Zi=[1,255],nu=[8,9,11,103],vu=[8,9,10,11,58,81,102,103,106,107,108,109],Dl={trace:function(){},yy:{},symbols_:{error:2,start:3,graphConfig:4,document:5,line:6,statement:7,SEMI:8,NEWLINE:9,SPACE:10,EOF:11,GRAPH:12,NODIR:13,DIR:14,FirstStmtSeparator:15,ending:16,endToken:17,spaceList:18,spaceListNewline:19,vertexStatement:20,separator:21,styleStatement:22,linkStyleStatement:23,classDefStatement:24,classStatement:25,clickStatement:26,subgraph:27,textNoTags:28,SQS:29,text:30,SQE:31,end:32,direction:33,acc_title:34,acc_title_value:35,acc_descr:36,acc_descr_value:37,acc_descr_multiline_value:38,link:39,node:40,styledVertex:41,AMP:42,vertex:43,STYLE_SEPARATOR:44,idString:45,DOUBLECIRCLESTART:46,DOUBLECIRCLEEND:47,PS:48,PE:49,"(-":50,"-)":51,STADIUMSTART:52,STADIUMEND:53,SUBROUTINESTART:54,SUBROUTINEEND:55,VERTEX_WITH_PROPS_START:56,"NODE_STRING[field]":57,COLON:58,"NODE_STRING[value]":59,PIPE:60,CYLINDERSTART:61,CYLINDEREND:62,DIAMOND_START:63,DIAMOND_STOP:64,TAGEND:65,TRAPSTART:66,TRAPEND:67,INVTRAPSTART:68,INVTRAPEND:69,linkStatement:70,arrowText:71,TESTSTR:72,START_LINK:73,edgeText:74,LINK:75,edgeTextToken:76,STR:77,MD_STR:78,textToken:79,keywords:80,STYLE:81,LINKSTYLE:82,CLASSDEF:83,CLASS:84,CLICK:85,DOWN:86,UP:87,textNoTagsToken:88,stylesOpt:89,"idString[vertex]":90,"idString[class]":91,CALLBACKNAME:92,CALLBACKARGS:93,HREF:94,LINK_TARGET:95,"STR[link]":96,"STR[tooltip]":97,alphaNum:98,DEFAULT:99,numList:100,INTERPOLATE:101,NUM:102,COMMA:103,style:104,styleComponent:105,NODE_STRING:106,UNIT:107,BRKT:108,PCT:109,idStringToken:110,MINUS:111,MULT:112,UNICODE_TEXT:113,TEXT:114,TAGSTART:115,EDGE_TEXT:116,alphaNumToken:117,direction_tb:118,direction_bt:119,direction_rl:120,direction_lr:121,$accept:0,$end:1},terminals_:{2:"error",8:"SEMI",9:"NEWLINE",10:"SPACE",11:"EOF",12:"GRAPH",13:"NODIR",14:"DIR",27:"subgraph",29:"SQS",31:"SQE",32:"end",34:"acc_title",35:"acc_title_value",36:"acc_descr",37:"acc_descr_value",38:"acc_descr_multiline_value",42:"AMP",44:"STYLE_SEPARATOR",46:"DOUBLECIRCLESTART",47:"DOUBLECIRCLEEND",48:"PS",49:"PE",50:"(-",51:"-)",52:"STADIUMSTART",53:"STADIUMEND",54:"SUBROUTINESTART",55:"SUBROUTINEEND",56:"VERTEX_WITH_PROPS_START",57:"NODE_STRING[field]",58:"COLON",59:"NODE_STRING[value]",60:"PIPE",61:"CYLINDERSTART",62:"CYLINDEREND",63:"DIAMOND_START",64:"DIAMOND_STOP",65:"TAGEND",66:"TRAPSTART",67:"TRAPEND",68:"INVTRAPSTART",69:"INVTRAPEND",72:"TESTSTR",73:"START_LINK",75:"LINK",77:"STR",78:"MD_STR",81:"STYLE",82:"LINKSTYLE",83:"CLASSDEF",84:"CLASS",85:"CLICK",86:"DOWN",87:"UP",90:"idString[vertex]",91:"idString[class]",92:"CALLBACKNAME",93:"CALLBACKARGS",94:"HREF",95:"LINK_TARGET",96:"STR[link]",97:"STR[tooltip]",99:"DEFAULT",101:"INTERPOLATE",102:"NUM",103:"COMMA",106:"NODE_STRING",107:"UNIT",108:"BRKT",109:"PCT",111:"MINUS",112:"MULT",113:"UNICODE_TEXT",114:"TEXT",115:"TAGSTART",116:"EDGE_TEXT",118:"direction_tb",119:"direction_bt",120:"direction_rl",121:"direction_lr"},productions_:[0,[3,2],[5,0],[5,2],[6,1],[6,1],[6,1],[6,1],[6,1],[4,2],[4,2],[4,2],[4,3],[16,2],[16,1],[17,1],[17,1],[17,1],[15,1],[15,1],[15,2],[19,2],[19,2],[19,1],[19,1],[18,2],[18,1],[7,2],[7,2],[7,2],[7,2],[7,2],[7,2],[7,9],[7,6],[7,4],[7,1],[7,2],[7,2],[7,1],[21,1],[21,1],[21,1],[20,3],[20,4],[20,2],[20,1],[40,1],[40,5],[41,1],[41,3],[43,4],[43,4],[43,6],[43,4],[43,4],[43,4],[43,8],[43,4],[43,4],[43,4],[43,6],[43,4],[43,4],[43,4],[43,4],[43,4],[43,1],[39,2],[39,3],[39,3],[39,1],[39,3],[74,1],[74,2],[74,1],[74,1],[70,1],[71,3],[30,1],[30,2],[30,1],[30,1],[80,1],[80,1],[80,1],[80,1],[80,1],[80,1],[80,1],[80,1],[80,1],[80,1],[80,1],[28,1],[28,2],[28,1],[28,1],[24,5],[25,5],[26,2],[26,4],[26,3],[26,5],[26,3],[26,5],[26,5],[26,7],[26,2],[26,4],[26,2],[26,4],[26,4],[26,6],[22,5],[23,5],[23,5],[23,9],[23,9],[23,7],[23,7],[100,1],[100,3],[89,1],[89,3],[104,1],[104,2],[105,1],[105,1],[105,1],[105,1],[105,1],[105,1],[105,1],[105,1],[110,1],[110,1],[110,1],[110,1],[110,1],[110,1],[110,1],[110,1],[110,1],[110,1],[110,1],[79,1],[79,1],[79,1],[79,1],[88,1],[88,1],[88,1],[88,1],[88,1],[88,1],[88,1],[88,1],[88,1],[88,1],[88,1],[76,1],[76,1],[117,1],[117,1],[117,1],[117,1],[117,1],[117,1],[117,1],[117,1],[117,1],[117,1],[117,1],[45,1],[45,2],[98,1],[98,2],[33,1],[33,1],[33,1],[33,1]],performAction:function(Wi,Bs,Qa,Bi,Nu,Ot,W3){var Kt=Ot.length-1;switch(Nu){case 2:this.$=[];break;case 3:(!Array.isArray(Ot[Kt])||Ot[Kt].length>0)&&Ot[Kt-1].push(Ot[Kt]),this.$=Ot[Kt-1];break;case 4:case 176:this.$=Ot[Kt];break;case 11:Bi.setDirection("TB"),this.$="TB";break;case 12:Bi.setDirection(Ot[Kt-1]),this.$=Ot[Kt-1];break;case 27:this.$=Ot[Kt-1].nodes;break;case 28:case 29:case 30:case 31:case 32:this.$=[];break;case 33:this.$=Bi.addSubGraph(Ot[Kt-6],Ot[Kt-1],Ot[Kt-4]);break;case 34:this.$=Bi.addSubGraph(Ot[Kt-3],Ot[Kt-1],Ot[Kt-3]);break;case 35:this.$=Bi.addSubGraph(void 0,Ot[Kt-1],void 0);break;case 37:this.$=Ot[Kt].trim(),Bi.setAccTitle(this.$);break;case 38:case 39:this.$=Ot[Kt].trim(),Bi.setAccDescription(this.$);break;case 43:Bi.addLink(Ot[Kt-2].stmt,Ot[Kt],Ot[Kt-1]),this.$={stmt:Ot[Kt],nodes:Ot[Kt].concat(Ot[Kt-2].nodes)};break;case 44:Bi.addLink(Ot[Kt-3].stmt,Ot[Kt-1],Ot[Kt-2]),this.$={stmt:Ot[Kt-1],nodes:Ot[Kt-1].concat(Ot[Kt-3].nodes)};break;case 45:this.$={stmt:Ot[Kt-1],nodes:Ot[Kt-1]};break;case 46:this.$={stmt:Ot[Kt],nodes:Ot[Kt]};break;case 47:this.$=[Ot[Kt]];break;case 48:this.$=Ot[Kt-4].concat(Ot[Kt]);break;case 49:this.$=Ot[Kt];break;case 50:this.$=Ot[Kt-2],Bi.setClass(Ot[Kt-2],Ot[Kt]);break;case 51:this.$=Ot[Kt-3],Bi.addVertex(Ot[Kt-3],Ot[Kt-1],"square");break;case 52:this.$=Ot[Kt-3],Bi.addVertex(Ot[Kt-3],Ot[Kt-1],"doublecircle");break;case 53:this.$=Ot[Kt-5],Bi.addVertex(Ot[Kt-5],Ot[Kt-2],"circle");break;case 54:this.$=Ot[Kt-3],Bi.addVertex(Ot[Kt-3],Ot[Kt-1],"ellipse");break;case 55:this.$=Ot[Kt-3],Bi.addVertex(Ot[Kt-3],Ot[Kt-1],"stadium");break;case 56:this.$=Ot[Kt-3],Bi.addVertex(Ot[Kt-3],Ot[Kt-1],"subroutine");break;case 57:this.$=Ot[Kt-7],Bi.addVertex(Ot[Kt-7],Ot[Kt-1],"rect",void 0,void 0,void 0,Object.fromEntries([[Ot[Kt-5],Ot[Kt-3]]]));break;case 58:this.$=Ot[Kt-3],Bi.addVertex(Ot[Kt-3],Ot[Kt-1],"cylinder");break;case 59:this.$=Ot[Kt-3],Bi.addVertex(Ot[Kt-3],Ot[Kt-1],"round");break;case 60:this.$=Ot[Kt-3],Bi.addVertex(Ot[Kt-3],Ot[Kt-1],"diamond");break;case 61:this.$=Ot[Kt-5],Bi.addVertex(Ot[Kt-5],Ot[Kt-2],"hexagon");break;case 62:this.$=Ot[Kt-3],Bi.addVertex(Ot[Kt-3],Ot[Kt-1],"odd");break;case 63:this.$=Ot[Kt-3],Bi.addVertex(Ot[Kt-3],Ot[Kt-1],"trapezoid");break;case 64:this.$=Ot[Kt-3],Bi.addVertex(Ot[Kt-3],Ot[Kt-1],"inv_trapezoid");break;case 65:this.$=Ot[Kt-3],Bi.addVertex(Ot[Kt-3],Ot[Kt-1],"lean_right");break;case 66:this.$=Ot[Kt-3],Bi.addVertex(Ot[Kt-3],Ot[Kt-1],"lean_left");break;case 67:this.$=Ot[Kt],Bi.addVertex(Ot[Kt]);break;case 68:Ot[Kt-1].text=Ot[Kt],this.$=Ot[Kt-1];break;case 69:case 70:Ot[Kt-2].text=Ot[Kt-1],this.$=Ot[Kt-2];break;case 71:this.$=Ot[Kt];break;case 72:var z0=Bi.destructLink(Ot[Kt],Ot[Kt-2]);this.$={type:z0.type,stroke:z0.stroke,length:z0.length,text:Ot[Kt-1]};break;case 73:this.$={text:Ot[Kt],type:"text"};break;case 74:this.$={text:Ot[Kt-1].text+""+Ot[Kt],type:Ot[Kt-1].type};break;case 75:this.$={text:Ot[Kt],type:"string"};break;case 76:this.$={text:Ot[Kt],type:"markdown"};break;case 77:var z0=Bi.destructLink(Ot[Kt]);this.$={type:z0.type,stroke:z0.stroke,length:z0.length};break;case 78:this.$=Ot[Kt-1];break;case 79:this.$={text:Ot[Kt],type:"text"};break;case 80:this.$={text:Ot[Kt-1].text+""+Ot[Kt],type:Ot[Kt-1].type};break;case 81:this.$={text:Ot[Kt],type:"string"};break;case 82:case 97:this.$={text:Ot[Kt],type:"markdown"};break;case 94:this.$={text:Ot[Kt],type:"text"};break;case 95:this.$={text:Ot[Kt-1].text+""+Ot[Kt],type:Ot[Kt-1].type};break;case 96:this.$={text:Ot[Kt],type:"text"};break;case 98:this.$=Ot[Kt-4],Bi.addClass(Ot[Kt-2],Ot[Kt]);break;case 99:this.$=Ot[Kt-4],Bi.setClass(Ot[Kt-2],Ot[Kt]);break;case 100:case 108:this.$=Ot[Kt-1],Bi.setClickEvent(Ot[Kt-1],Ot[Kt]);break;case 101:case 109:this.$=Ot[Kt-3],Bi.setClickEvent(Ot[Kt-3],Ot[Kt-2]),Bi.setTooltip(Ot[Kt-3],Ot[Kt]);break;case 102:this.$=Ot[Kt-2],Bi.setClickEvent(Ot[Kt-2],Ot[Kt-1],Ot[Kt]);break;case 103:this.$=Ot[Kt-4],Bi.setClickEvent(Ot[Kt-4],Ot[Kt-3],Ot[Kt-2]),Bi.setTooltip(Ot[Kt-4],Ot[Kt]);break;case 104:this.$=Ot[Kt-2],Bi.setLink(Ot[Kt-2],Ot[Kt]);break;case 105:this.$=Ot[Kt-4],Bi.setLink(Ot[Kt-4],Ot[Kt-2]),Bi.setTooltip(Ot[Kt-4],Ot[Kt]);break;case 106:this.$=Ot[Kt-4],Bi.setLink(Ot[Kt-4],Ot[Kt-2],Ot[Kt]);break;case 107:this.$=Ot[Kt-6],Bi.setLink(Ot[Kt-6],Ot[Kt-4],Ot[Kt]),Bi.setTooltip(Ot[Kt-6],Ot[Kt-2]);break;case 110:this.$=Ot[Kt-1],Bi.setLink(Ot[Kt-1],Ot[Kt]);break;case 111:this.$=Ot[Kt-3],Bi.setLink(Ot[Kt-3],Ot[Kt-2]),Bi.setTooltip(Ot[Kt-3],Ot[Kt]);break;case 112:this.$=Ot[Kt-3],Bi.setLink(Ot[Kt-3],Ot[Kt-2],Ot[Kt]);break;case 113:this.$=Ot[Kt-5],Bi.setLink(Ot[Kt-5],Ot[Kt-4],Ot[Kt]),Bi.setTooltip(Ot[Kt-5],Ot[Kt-2]);break;case 114:this.$=Ot[Kt-4],Bi.addVertex(Ot[Kt-2],void 0,void 0,Ot[Kt]);break;case 115:this.$=Ot[Kt-4],Bi.updateLink([Ot[Kt-2]],Ot[Kt]);break;case 116:this.$=Ot[Kt-4],Bi.updateLink(Ot[Kt-2],Ot[Kt]);break;case 117:this.$=Ot[Kt-8],Bi.updateLinkInterpolate([Ot[Kt-6]],Ot[Kt-2]),Bi.updateLink([Ot[Kt-6]],Ot[Kt]);break;case 118:this.$=Ot[Kt-8],Bi.updateLinkInterpolate(Ot[Kt-6],Ot[Kt-2]),Bi.updateLink(Ot[Kt-6],Ot[Kt]);break;case 119:this.$=Ot[Kt-6],Bi.updateLinkInterpolate([Ot[Kt-4]],Ot[Kt]);break;case 120:this.$=Ot[Kt-6],Bi.updateLinkInterpolate(Ot[Kt-4],Ot[Kt]);break;case 121:case 123:this.$=[Ot[Kt]];break;case 122:case 124:Ot[Kt-2].push(Ot[Kt]),this.$=Ot[Kt-2];break;case 126:this.$=Ot[Kt-1]+Ot[Kt];break;case 174:this.$=Ot[Kt];break;case 175:this.$=Ot[Kt-1]+""+Ot[Kt];break;case 177:this.$=Ot[Kt-1]+""+Ot[Kt];break;case 178:this.$={stmt:"dir",value:"TB"};break;case 179:this.$={stmt:"dir",value:"BT"};break;case 180:this.$={stmt:"dir",value:"RL"};break;case 181:this.$={stmt:"dir",value:"LR"};break}},table:[{3:1,4:2,9:s,10:u,12:d},{1:[3]},i(p,v,{5:6}),{4:7,9:s,10:u,12:d},{4:8,9:s,10:u,12:d},{13:[1,9],14:[1,10]},{1:[2,1],6:11,7:12,8:b,9:y,10:T,11:_,20:17,22:18,23:19,24:20,25:21,26:22,27:A,33:24,34:P,36:R,38:F,40:28,41:38,42:j,43:39,45:40,58:K,81:ee,82:ie,83:oe,84:pe,85:be,86:ae,99:ne,102:se,103:de,106:X,108:ge,110:41,111:W,112:xe,113:U,118:Fe,119:Pe,120:je,121:Ie},i(p,[2,9]),i(p,[2,10]),i(p,[2,11]),{8:[1,54],9:[1,55],10:Se,15:53,18:56},i(Ce,[2,3]),i(Ce,[2,4]),i(Ce,[2,5]),i(Ce,[2,6]),i(Ce,[2,7]),i(Ce,[2,8]),{8:ke,9:Ke,11:Ft,21:58,39:59,70:63,73:[1,64],75:[1,65]},{8:ke,9:Ke,11:Ft,21:66},{8:ke,9:Ke,11:Ft,21:67},{8:ke,9:Ke,11:Ft,21:68},{8:ke,9:Ke,11:Ft,21:69},{8:ke,9:Ke,11:Ft,21:70},{8:ke,9:Ke,10:[1,71],11:Ft,21:72},i(Ce,[2,36]),{35:[1,73]},{37:[1,74]},i(Ce,[2,39]),i(Ne,[2,46],{18:75,10:Se}),{10:[1,76]},{10:[1,77]},{10:[1,78]},{10:[1,79]},{14:gn,42:_t,58:Et,77:[1,83],86:Gt,92:[1,80],94:[1,81],98:82,102:ln,103:xt,106:Pt,108:Qe,111:Dt,112:kt,113:On,117:84},i(Ce,[2,178]),i(Ce,[2,179]),i(Ce,[2,180]),i(Ce,[2,181]),i(ht,[2,47]),i(ht,[2,49],{44:[1,96]}),i(zr,[2,67],{110:109,29:[1,97],42:j,46:[1,98],48:[1,99],50:[1,100],52:[1,101],54:[1,102],56:[1,103],58:K,61:[1,104],63:[1,105],65:[1,106],66:[1,107],68:[1,108],86:ae,99:ne,102:se,103:de,106:X,108:ge,111:W,112:xe,113:U}),i(yt,[2,174]),i(yt,[2,135]),i(yt,[2,136]),i(yt,[2,137]),i(yt,[2,138]),i(yt,[2,139]),i(yt,[2,140]),i(yt,[2,141]),i(yt,[2,142]),i(yt,[2,143]),i(yt,[2,144]),i(yt,[2,145]),i(p,[2,12]),i(p,[2,18]),i(p,[2,19]),{9:[1,110]},i(ji,[2,26],{18:111,10:Se}),i(Ce,[2,27]),{40:112,41:38,42:j,43:39,45:40,58:K,86:ae,99:ne,102:se,103:de,106:X,108:ge,110:41,111:W,112:xe,113:U},i(Ce,[2,40]),i(Ce,[2,41]),i(Ce,[2,42]),i(xi,[2,71],{71:113,60:[1,115],72:[1,114]}),{74:116,76:117,77:[1,118],78:[1,119],113:Ma,116:zs},i([42,58,60,72,86,99,102,103,106,108,111,112,113],[2,77]),i(Ce,[2,28]),i(Ce,[2,29]),i(Ce,[2,30]),i(Ce,[2,31]),i(Ce,[2,32]),{10:ao,12:Tr,14:Fn,27:qn,28:122,32:Un,42:At,58:wt,73:on,77:[1,124],78:[1,125],80:135,81:fn,82:An,83:oo,84:jo,85:$o,86:Pa,87:wo,88:123,102:_s,106:tl,108:da,111:j0,112:pm,113:Ml},i(Xc,v,{5:148}),i(Ce,[2,37]),i(Ce,[2,38]),i(Ne,[2,45],{42:Bc}),{42:j,45:150,58:K,86:ae,99:ne,102:se,103:de,106:X,108:ge,110:41,111:W,112:xe,113:U},{99:[1,151],100:152,102:[1,153]},{42:j,45:154,58:K,86:ae,99:ne,102:se,103:de,106:X,108:ge,110:41,111:W,112:xe,113:U},{42:j,45:155,58:K,86:ae,99:ne,102:se,103:de,106:X,108:ge,110:41,111:W,112:xe,113:U},i(ja,[2,100],{10:[1,156],93:[1,157]}),{77:[1,158]},i(ja,[2,108],{117:160,10:[1,159],14:gn,42:_t,58:Et,86:Gt,102:ln,103:xt,106:Pt,108:Qe,111:Dt,112:kt,113:On}),i(ja,[2,110],{10:[1,161]}),i(Ou,[2,176]),i(Ou,[2,163]),i(Ou,[2,164]),i(Ou,[2,165]),i(Ou,[2,166]),i(Ou,[2,167]),i(Ou,[2,168]),i(Ou,[2,169]),i(Ou,[2,170]),i(Ou,[2,171]),i(Ou,[2,172]),i(Ou,[2,173]),{42:j,45:162,58:K,86:ae,99:ne,102:se,103:de,106:X,108:ge,110:41,111:W,112:xe,113:U},{30:163,65:Sa,77:Po,78:Fc,79:164,113:xa,114:Ba,115:ga},{30:171,65:Sa,77:Po,78:Fc,79:164,113:xa,114:Ba,115:ga},{30:173,48:[1,172],65:Sa,77:Po,78:Fc,79:164,113:xa,114:Ba,115:ga},{30:174,65:Sa,77:Po,78:Fc,79:164,113:xa,114:Ba,115:ga},{30:175,65:Sa,77:Po,78:Fc,79:164,113:xa,114:Ba,115:ga},{30:176,65:Sa,77:Po,78:Fc,79:164,113:xa,114:Ba,115:ga},{106:[1,177]},{30:178,65:Sa,77:Po,78:Fc,79:164,113:xa,114:Ba,115:ga},{30:179,63:[1,180],65:Sa,77:Po,78:Fc,79:164,113:xa,114:Ba,115:ga},{30:181,65:Sa,77:Po,78:Fc,79:164,113:xa,114:Ba,115:ga},{30:182,65:Sa,77:Po,78:Fc,79:164,113:xa,114:Ba,115:ga},{30:183,65:Sa,77:Po,78:Fc,79:164,113:xa,114:Ba,115:ga},i(yt,[2,175]),i(p,[2,20]),i(ji,[2,25]),i(Ne,[2,43],{18:184,10:Se}),i(xi,[2,68],{10:[1,185]}),{10:[1,186]},{30:187,65:Sa,77:Po,78:Fc,79:164,113:xa,114:Ba,115:ga},{75:[1,188],76:189,113:Ma,116:zs},i(kh,[2,73]),i(kh,[2,75]),i(kh,[2,76]),i(kh,[2,161]),i(kh,[2,162]),{8:ke,9:Ke,10:ao,11:Ft,12:Tr,14:Fn,21:191,27:qn,29:[1,190],32:Un,42:At,58:wt,73:on,80:135,81:fn,82:An,83:oo,84:jo,85:$o,86:Pa,87:wo,88:192,102:_s,106:tl,108:da,111:j0,112:pm,113:Ml},i(lu,[2,94]),i(lu,[2,96]),i(lu,[2,97]),i(lu,[2,150]),i(lu,[2,151]),i(lu,[2,152]),i(lu,[2,153]),i(lu,[2,154]),i(lu,[2,155]),i(lu,[2,156]),i(lu,[2,157]),i(lu,[2,158]),i(lu,[2,159]),i(lu,[2,160]),i(lu,[2,83]),i(lu,[2,84]),i(lu,[2,85]),i(lu,[2,86]),i(lu,[2,87]),i(lu,[2,88]),i(lu,[2,89]),i(lu,[2,90]),i(lu,[2,91]),i(lu,[2,92]),i(lu,[2,93]),{6:11,7:12,8:b,9:y,10:T,11:_,20:17,22:18,23:19,24:20,25:21,26:22,27:A,32:[1,193],33:24,34:P,36:R,38:F,40:28,41:38,42:j,43:39,45:40,58:K,81:ee,82:ie,83:oe,84:pe,85:be,86:ae,99:ne,102:se,103:de,106:X,108:ge,110:41,111:W,112:xe,113:U,118:Fe,119:Pe,120:je,121:Ie},{10:Se,18:194},{10:[1,195],42:j,58:K,86:ae,99:ne,102:se,103:de,106:X,108:ge,110:109,111:W,112:xe,113:U},{10:[1,196]},{10:[1,197],103:[1,198]},i(o5,[2,121]),{10:[1,199],42:j,58:K,86:ae,99:ne,102:se,103:de,106:X,108:ge,110:109,111:W,112:xe,113:U},{10:[1,200],42:j,58:K,86:ae,99:ne,102:se,103:de,106:X,108:ge,110:109,111:W,112:xe,113:U},{77:[1,201]},i(ja,[2,102],{10:[1,202]}),i(ja,[2,104],{10:[1,203]}),{77:[1,204]},i(Ou,[2,177]),{77:[1,205],95:[1,206]},i(ht,[2,50],{110:109,42:j,58:K,86:ae,99:ne,102:se,103:de,106:X,108:ge,111:W,112:xe,113:U}),{31:[1,207],65:Sa,79:208,113:xa,114:Ba,115:ga},i(Wh,[2,79]),i(Wh,[2,81]),i(Wh,[2,82]),i(Wh,[2,146]),i(Wh,[2,147]),i(Wh,[2,148]),i(Wh,[2,149]),{47:[1,209],65:Sa,79:208,113:xa,114:Ba,115:ga},{30:210,65:Sa,77:Po,78:Fc,79:164,113:xa,114:Ba,115:ga},{49:[1,211],65:Sa,79:208,113:xa,114:Ba,115:ga},{51:[1,212],65:Sa,79:208,113:xa,114:Ba,115:ga},{53:[1,213],65:Sa,79:208,113:xa,114:Ba,115:ga},{55:[1,214],65:Sa,79:208,113:xa,114:Ba,115:ga},{58:[1,215]},{62:[1,216],65:Sa,79:208,113:xa,114:Ba,115:ga},{64:[1,217],65:Sa,79:208,113:xa,114:Ba,115:ga},{30:218,65:Sa,77:Po,78:Fc,79:164,113:xa,114:Ba,115:ga},{31:[1,219],65:Sa,79:208,113:xa,114:Ba,115:ga},{65:Sa,67:[1,220],69:[1,221],79:208,113:xa,114:Ba,115:ga},{65:Sa,67:[1,223],69:[1,222],79:208,113:xa,114:Ba,115:ga},i(Ne,[2,44],{42:Bc}),i(xi,[2,70]),i(xi,[2,69]),{60:[1,224],65:Sa,79:208,113:xa,114:Ba,115:ga},i(xi,[2,72]),i(kh,[2,74]),{30:225,65:Sa,77:Po,78:Fc,79:164,113:xa,114:Ba,115:ga},i(Xc,v,{5:226}),i(lu,[2,95]),i(Ce,[2,35]),{41:227,42:j,43:39,45:40,58:K,86:ae,99:ne,102:se,103:de,106:X,108:ge,110:41,111:W,112:xe,113:U},{10:od,58:Gd,81:cd,89:228,102:Kd,104:229,105:230,106:$g,107:as,108:wn,109:Zr},{10:od,58:Gd,81:cd,89:239,101:[1,240],102:Kd,104:229,105:230,106:$g,107:as,108:wn,109:Zr},{10:od,58:Gd,81:cd,89:241,101:[1,242],102:Kd,104:229,105:230,106:$g,107:as,108:wn,109:Zr},{102:[1,243]},{10:od,58:Gd,81:cd,89:244,102:Kd,104:229,105:230,106:$g,107:as,108:wn,109:Zr},{42:j,45:245,58:K,86:ae,99:ne,102:se,103:de,106:X,108:ge,110:41,111:W,112:xe,113:U},i(ja,[2,101]),{77:[1,246]},{77:[1,247],95:[1,248]},i(ja,[2,109]),i(ja,[2,111],{10:[1,249]}),i(ja,[2,112]),i(zr,[2,51]),i(Wh,[2,80]),i(zr,[2,52]),{49:[1,250],65:Sa,79:208,113:xa,114:Ba,115:ga},i(zr,[2,59]),i(zr,[2,54]),i(zr,[2,55]),i(zr,[2,56]),{106:[1,251]},i(zr,[2,58]),i(zr,[2,60]),{64:[1,252],65:Sa,79:208,113:xa,114:Ba,115:ga},i(zr,[2,62]),i(zr,[2,63]),i(zr,[2,65]),i(zr,[2,64]),i(zr,[2,66]),i([10,42,58,86,99,102,103,106,108,111,112,113],[2,78]),{31:[1,253],65:Sa,79:208,113:xa,114:Ba,115:ga},{6:11,7:12,8:b,9:y,10:T,11:_,20:17,22:18,23:19,24:20,25:21,26:22,27:A,32:[1,254],33:24,34:P,36:R,38:F,40:28,41:38,42:j,43:39,45:40,58:K,81:ee,82:ie,83:oe,84:pe,85:be,86:ae,99:ne,102:se,103:de,106:X,108:ge,110:41,111:W,112:xe,113:U,118:Fe,119:Pe,120:je,121:Ie},i(ht,[2,48]),i(ja,[2,114],{103:Zi}),i(nu,[2,123],{105:256,10:od,58:Gd,81:cd,102:Kd,106:$g,107:as,108:wn,109:Zr}),i(vu,[2,125]),i(vu,[2,127]),i(vu,[2,128]),i(vu,[2,129]),i(vu,[2,130]),i(vu,[2,131]),i(vu,[2,132]),i(vu,[2,133]),i(vu,[2,134]),i(ja,[2,115],{103:Zi}),{10:[1,257]},i(ja,[2,116],{103:Zi}),{10:[1,258]},i(o5,[2,122]),i(ja,[2,98],{103:Zi}),i(ja,[2,99],{110:109,42:j,58:K,86:ae,99:ne,102:se,103:de,106:X,108:ge,111:W,112:xe,113:U}),i(ja,[2,103]),i(ja,[2,105],{10:[1,259]}),i(ja,[2,106]),{95:[1,260]},{49:[1,261]},{60:[1,262]},{64:[1,263]},{8:ke,9:Ke,11:Ft,21:264},i(Ce,[2,34]),{10:od,58:Gd,81:cd,102:Kd,104:265,105:230,106:$g,107:as,108:wn,109:Zr},i(vu,[2,126]),{14:gn,42:_t,58:Et,86:Gt,98:266,102:ln,103:xt,106:Pt,108:Qe,111:Dt,112:kt,113:On,117:84},{14:gn,42:_t,58:Et,86:Gt,98:267,102:ln,103:xt,106:Pt,108:Qe,111:Dt,112:kt,113:On,117:84},{95:[1,268]},i(ja,[2,113]),i(zr,[2,53]),{30:269,65:Sa,77:Po,78:Fc,79:164,113:xa,114:Ba,115:ga},i(zr,[2,61]),i(Xc,v,{5:270}),i(nu,[2,124],{105:256,10:od,58:Gd,81:cd,102:Kd,106:$g,107:as,108:wn,109:Zr}),i(ja,[2,119],{117:160,10:[1,271],14:gn,42:_t,58:Et,86:Gt,102:ln,103:xt,106:Pt,108:Qe,111:Dt,112:kt,113:On}),i(ja,[2,120],{117:160,10:[1,272],14:gn,42:_t,58:Et,86:Gt,102:ln,103:xt,106:Pt,108:Qe,111:Dt,112:kt,113:On}),i(ja,[2,107]),{31:[1,273],65:Sa,79:208,113:xa,114:Ba,115:ga},{6:11,7:12,8:b,9:y,10:T,11:_,20:17,22:18,23:19,24:20,25:21,26:22,27:A,32:[1,274],33:24,34:P,36:R,38:F,40:28,41:38,42:j,43:39,45:40,58:K,81:ee,82:ie,83:oe,84:pe,85:be,86:ae,99:ne,102:se,103:de,106:X,108:ge,110:41,111:W,112:xe,113:U,118:Fe,119:Pe,120:je,121:Ie},{10:od,58:Gd,81:cd,89:275,102:Kd,104:229,105:230,106:$g,107:as,108:wn,109:Zr},{10:od,58:Gd,81:cd,89:276,102:Kd,104:229,105:230,106:$g,107:as,108:wn,109:Zr},i(zr,[2,57]),i(Ce,[2,33]),i(ja,[2,117],{103:Zi}),i(ja,[2,118],{103:Zi})],defaultActions:{},parseError:function(Wi,Bs){if(Bs.recoverable)this.trace(Wi);else{var Qa=new Error(Wi);throw Qa.hash=Bs,Qa}},parse:function(Wi){var Bs=this,Qa=[0],Bi=[],Nu=[null],Ot=[],W3=this.table,Kt="",z0=0,Bp=0,Y3=2,$9=1,c5=Ot.slice.call(arguments,1),Eh=Object.create(this.lexer),zg={yy:{}};for(var bm in this.yy)Object.prototype.hasOwnProperty.call(this.yy,bm)&&(zg.yy[bm]=this.yy[bm]);Eh.setInput(Wi,zg.yy),zg.yy.lexer=Eh,zg.yy.parser=this,typeof Eh.yylloc>"u"&&(Eh.yylloc={});var z9=Eh.yylloc;Ot.push(z9);var mm=Eh.options&&Eh.options.ranges;typeof zg.yy.parseError=="function"?this.parseError=zg.yy.parseError:this.parseError=Object.getPrototypeOf(this).parseError;function u5(){var Fp;return Fp=Bi.pop()||Eh.lex()||$9,typeof Fp!="number"&&(Fp instanceof Array&&(Bi=Fp,Fp=Bi.pop()),Fp=Bs.symbols_[Fp]||Fp),Fp}for(var y1,ud,ld,q9,Vv={},Y7,G2,X7,l5;;){if(ud=Qa[Qa.length-1],this.defaultActions[ud]?ld=this.defaultActions[ud]:((y1===null||typeof y1>"u")&&(y1=u5()),ld=W3[ud]&&W3[ud][y1]),typeof ld>"u"||!ld.length||!ld[0]){var X3="";l5=[];for(Y7 in W3[ud])this.terminals_[Y7]&&Y7>Y3&&l5.push("'"+this.terminals_[Y7]+"'");Eh.showPosition?X3="Parse error on line "+(z0+1)+`: +`+Eh.showPosition()+` +Expecting `+l5.join(", ")+", got '"+(this.terminals_[y1]||y1)+"'":X3="Parse error on line "+(z0+1)+": Unexpected "+(y1==$9?"end of input":"'"+(this.terminals_[y1]||y1)+"'"),this.parseError(X3,{text:Eh.match,token:this.terminals_[y1]||y1,line:Eh.yylineno,loc:z9,expected:l5})}if(ld[0]instanceof Array&&ld.length>1)throw new Error("Parse Error: multiple actions possible at state: "+ud+", token: "+y1);switch(ld[0]){case 1:Qa.push(y1),Nu.push(Eh.yytext),Ot.push(Eh.yylloc),Qa.push(ld[1]),y1=null,Bp=Eh.yyleng,Kt=Eh.yytext,z0=Eh.yylineno,z9=Eh.yylloc;break;case 2:if(G2=this.productions_[ld[1]][1],Vv.$=Nu[Nu.length-G2],Vv._$={first_line:Ot[Ot.length-(G2||1)].first_line,last_line:Ot[Ot.length-1].last_line,first_column:Ot[Ot.length-(G2||1)].first_column,last_column:Ot[Ot.length-1].last_column},mm&&(Vv._$.range=[Ot[Ot.length-(G2||1)].range[0],Ot[Ot.length-1].range[1]]),q9=this.performAction.apply(Vv,[Kt,Bp,z0,zg.yy,ld[1],Nu,Ot].concat(c5)),typeof q9<"u")return q9;G2&&(Qa=Qa.slice(0,-1*G2*2),Nu=Nu.slice(0,-1*G2),Ot=Ot.slice(0,-1*G2)),Qa.push(this.productions_[ld[1]][0]),Nu.push(Vv.$),Ot.push(Vv._$),X7=W3[Qa[Qa.length-2]][Qa[Qa.length-1]],Qa.push(X7);break;case 3:return!0}}return!0}},Yh=function(){var $0={EOF:1,parseError:function(Bs,Qa){if(this.yy.parser)this.yy.parser.parseError(Bs,Qa);else throw new Error(Bs)},setInput:function(Wi,Bs){return this.yy=Bs||this.yy||{},this._input=Wi,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},input:function(){var Wi=this._input[0];this.yytext+=Wi,this.yyleng++,this.offset++,this.match+=Wi,this.matched+=Wi;var Bs=Wi.match(/(?:\r\n?|\n).*/g);return Bs?(this.yylineno++,this.yylloc.last_line++):this.yylloc.last_column++,this.options.ranges&&this.yylloc.range[1]++,this._input=this._input.slice(1),Wi},unput:function(Wi){var Bs=Wi.length,Qa=Wi.split(/(?:\r\n?|\n)/g);this._input=Wi+this._input,this.yytext=this.yytext.substr(0,this.yytext.length-Bs),this.offset-=Bs;var Bi=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),Qa.length-1&&(this.yylineno-=Qa.length-1);var Nu=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:Qa?(Qa.length===Bi.length?this.yylloc.first_column:0)+Bi[Bi.length-Qa.length].length-Qa[0].length:this.yylloc.first_column-Bs},this.options.ranges&&(this.yylloc.range=[Nu[0],Nu[0]+this.yyleng-Bs]),this.yyleng=this.yytext.length,this},more:function(){return this._more=!0,this},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},less:function(Wi){this.unput(this.match.slice(Wi))},pastInput:function(){var Wi=this.matched.substr(0,this.matched.length-this.match.length);return(Wi.length>20?"...":"")+Wi.substr(-20).replace(/\n/g,"")},upcomingInput:function(){var Wi=this.match;return Wi.length<20&&(Wi+=this._input.substr(0,20-Wi.length)),(Wi.substr(0,20)+(Wi.length>20?"...":"")).replace(/\n/g,"")},showPosition:function(){var Wi=this.pastInput(),Bs=new Array(Wi.length+1).join("-");return Wi+this.upcomingInput()+` +`+Bs+"^"},test_match:function(Wi,Bs){var Qa,Bi,Nu;if(this.options.backtrack_lexer&&(Nu={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&&(Nu.yylloc.range=this.yylloc.range.slice(0))),Bi=Wi[0].match(/(?:\r\n?|\n).*/g),Bi&&(this.yylineno+=Bi.length),this.yylloc={first_line:this.yylloc.last_line,last_line:this.yylineno+1,first_column:this.yylloc.last_column,last_column:Bi?Bi[Bi.length-1].length-Bi[Bi.length-1].match(/\r?\n?/)[0].length:this.yylloc.last_column+Wi[0].length},this.yytext+=Wi[0],this.match+=Wi[0],this.matches=Wi,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(Wi[0].length),this.matched+=Wi[0],Qa=this.performAction.call(this,this.yy,this,Bs,this.conditionStack[this.conditionStack.length-1]),this.done&&this._input&&(this.done=!1),Qa)return Qa;if(this._backtrack){for(var Ot in Nu)this[Ot]=Nu[Ot];return!1}return!1},next:function(){if(this.done)return this.EOF;this._input||(this.done=!0);var Wi,Bs,Qa,Bi;this._more||(this.yytext="",this.match="");for(var Nu=this._currentRules(),Ot=0;OtBs[0].length)){if(Bs=Qa,Bi=Ot,this.options.backtrack_lexer){if(Wi=this.test_match(Qa,Nu[Ot]),Wi!==!1)return Wi;if(this._backtrack){Bs=!1;continue}else return!1}else if(!this.options.flex)break}return Bs?(Wi=this.test_match(Bs,Nu[Bi]),Wi!==!1?Wi:!1):this._input===""?this.EOF:this.parseError("Lexical error on line "+(this.yylineno+1)+`. Unrecognized text. +`+this.showPosition(),{text:"",token:null,line:this.yylineno})},lex:function(){var Bs=this.next();return Bs||this.lex()},begin:function(Bs){this.conditionStack.push(Bs)},popState:function(){var Bs=this.conditionStack.length-1;return Bs>0?this.conditionStack.pop():this.conditionStack[0]},_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},topState:function(Bs){return Bs=this.conditionStack.length-1-Math.abs(Bs||0),Bs>=0?this.conditionStack[Bs]:"INITIAL"},pushState:function(Bs){this.begin(Bs)},stateStackSize:function(){return this.conditionStack.length},options:{},performAction:function(Bs,Qa,Bi,Nu){switch(Bi){case 0:return this.begin("acc_title"),34;case 1:return this.popState(),"acc_title_value";case 2:return this.begin("acc_descr"),36;case 3:return this.popState(),"acc_descr_value";case 4:this.begin("acc_descr_multiline");break;case 5:this.popState();break;case 6:return"acc_descr_multiline_value";case 7:this.begin("callbackname");break;case 8:this.popState();break;case 9:this.popState(),this.begin("callbackargs");break;case 10:return 92;case 11:this.popState();break;case 12:return 93;case 13:return"MD_STR";case 14:this.popState();break;case 15:this.begin("md_string");break;case 16:return"STR";case 17:this.popState();break;case 18:this.pushState("string");break;case 19:return 81;case 20:return 99;case 21:return 82;case 22:return 101;case 23:return 83;case 24:return 84;case 25:return 94;case 26:this.begin("click");break;case 27:this.popState();break;case 28:return 85;case 29:return Bs.lex.firstGraph()&&this.begin("dir"),12;case 30:return Bs.lex.firstGraph()&&this.begin("dir"),12;case 31:return Bs.lex.firstGraph()&&this.begin("dir"),12;case 32:return 27;case 33:return 32;case 34:return 95;case 35:return 95;case 36:return 95;case 37:return 95;case 38:return this.popState(),13;case 39:return this.popState(),14;case 40:return this.popState(),14;case 41:return this.popState(),14;case 42:return this.popState(),14;case 43:return this.popState(),14;case 44:return this.popState(),14;case 45:return this.popState(),14;case 46:return this.popState(),14;case 47:return this.popState(),14;case 48:return this.popState(),14;case 49:return 118;case 50:return 119;case 51:return 120;case 52:return 121;case 53:return 102;case 54:return 108;case 55:return 44;case 56:return 58;case 57:return 42;case 58:return 8;case 59:return 103;case 60:return 112;case 61:return this.popState(),75;case 62:return this.pushState("edgeText"),73;case 63:return 116;case 64:return this.popState(),75;case 65:return this.pushState("thickEdgeText"),73;case 66:return 116;case 67:return this.popState(),75;case 68:return this.pushState("dottedEdgeText"),73;case 69:return 116;case 70:return 75;case 71:return this.popState(),51;case 72:return"TEXT";case 73:return this.pushState("ellipseText"),50;case 74:return this.popState(),53;case 75:return this.pushState("text"),52;case 76:return this.popState(),55;case 77:return this.pushState("text"),54;case 78:return 56;case 79:return this.pushState("text"),65;case 80:return this.popState(),62;case 81:return this.pushState("text"),61;case 82:return this.popState(),47;case 83:return this.pushState("text"),46;case 84:return this.popState(),67;case 85:return this.popState(),69;case 86:return 114;case 87:return this.pushState("trapText"),66;case 88:return this.pushState("trapText"),68;case 89:return 115;case 90:return 65;case 91:return 87;case 92:return"SEP";case 93:return 86;case 94:return 112;case 95:return 108;case 96:return 42;case 97:return 106;case 98:return 111;case 99:return 113;case 100:return this.popState(),60;case 101:return this.pushState("text"),60;case 102:return this.popState(),49;case 103:return this.pushState("text"),48;case 104:return this.popState(),31;case 105:return this.pushState("text"),29;case 106:return this.popState(),64;case 107:return this.pushState("text"),63;case 108:return"TEXT";case 109:return"QUOTE";case 110:return 9;case 111:return 10;case 112:return 11}},rules:[/^(?:accTitle\s*:\s*)/,/^(?:(?!\n||)*[^\n]*)/,/^(?:accDescr\s*:\s*)/,/^(?:(?!\n||)*[^\n]*)/,/^(?:accDescr\s*\{\s*)/,/^(?:[\}])/,/^(?:[^\}]*)/,/^(?:call[\s]+)/,/^(?:\([\s]*\))/,/^(?:\()/,/^(?:[^(]*)/,/^(?:\))/,/^(?:[^)]*)/,/^(?:[^`"]+)/,/^(?:[`]["])/,/^(?:["][`])/,/^(?:[^"]+)/,/^(?:["])/,/^(?:["])/,/^(?:style\b)/,/^(?:default\b)/,/^(?:linkStyle\b)/,/^(?:interpolate\b)/,/^(?:classDef\b)/,/^(?:class\b)/,/^(?:href[\s])/,/^(?:click[\s]+)/,/^(?:[\s\n])/,/^(?:[^\s\n]*)/,/^(?:flowchart-elk\b)/,/^(?:graph\b)/,/^(?:flowchart\b)/,/^(?:subgraph\b)/,/^(?:end\b\s*)/,/^(?:_self\b)/,/^(?:_blank\b)/,/^(?:_parent\b)/,/^(?:_top\b)/,/^(?:(\r?\n)*\s*\n)/,/^(?:\s*LR\b)/,/^(?:\s*RL\b)/,/^(?:\s*TB\b)/,/^(?:\s*BT\b)/,/^(?:\s*TD\b)/,/^(?:\s*BR\b)/,/^(?:\s*<)/,/^(?:\s*>)/,/^(?:\s*\^)/,/^(?:\s*v\b)/,/^(?:.*direction\s+TB[^\n]*)/,/^(?:.*direction\s+BT[^\n]*)/,/^(?:.*direction\s+RL[^\n]*)/,/^(?:.*direction\s+LR[^\n]*)/,/^(?:[0-9]+)/,/^(?:#)/,/^(?::::)/,/^(?::)/,/^(?:&)/,/^(?:;)/,/^(?:,)/,/^(?:\*)/,/^(?:\s*[xo<]?--+[-xo>]\s*)/,/^(?:\s*[xo<]?--\s*)/,/^(?:[^-]|-(?!-)+)/,/^(?:\s*[xo<]?==+[=xo>]\s*)/,/^(?:\s*[xo<]?==\s*)/,/^(?:[^=]|=(?!))/,/^(?:\s*[xo<]?-?\.+-[xo>]?\s*)/,/^(?:\s*[xo<]?-\.\s*)/,/^(?:[^\.]|\.(?!))/,/^(?:\s*~~[\~]+\s*)/,/^(?:[-/\)][\)])/,/^(?:[^\(\)\[\]\{\}]|!\)+)/,/^(?:\(-)/,/^(?:\]\))/,/^(?:\(\[)/,/^(?:\]\])/,/^(?:\[\[)/,/^(?:\[\|)/,/^(?:>)/,/^(?:\)\])/,/^(?:\[\()/,/^(?:\)\)\))/,/^(?:\(\(\()/,/^(?:[\\(?=\])][\]])/,/^(?:\/(?=\])\])/,/^(?:\/(?!\])|\\(?!\])|[^\\\[\]\(\)\{\}\/]+)/,/^(?:\[\/)/,/^(?:\[\\)/,/^(?:<)/,/^(?:>)/,/^(?:\^)/,/^(?:\\\|)/,/^(?:v\b)/,/^(?:\*)/,/^(?:#)/,/^(?:&)/,/^(?:([A-Za-z0-9!"\#$%&'*+\.`?\\_\/]|-(?=[^\>\-\.])|(?!))+)/,/^(?:-)/,/^(?:[\u00AA\u00B5\u00BA\u00C0-\u00D6\u00D8-\u00F6]|[\u00F8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377]|[\u037A-\u037D\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5]|[\u03F7-\u0481\u048A-\u0527\u0531-\u0556\u0559\u0561-\u0587\u05D0-\u05EA]|[\u05F0-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE]|[\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA]|[\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u08A0]|[\u08A2-\u08AC\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0977]|[\u0979-\u097F\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2]|[\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u0A05-\u0A0A]|[\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39]|[\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8]|[\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0B05-\u0B0C]|[\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C]|[\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99]|[\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0]|[\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C33\u0C35-\u0C39\u0C3D]|[\u0C58\u0C59\u0C60\u0C61\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3]|[\u0CB5-\u0CB9\u0CBD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D05-\u0D0C\u0D0E-\u0D10]|[\u0D12-\u0D3A\u0D3D\u0D4E\u0D60\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1]|[\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81]|[\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3]|[\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6]|[\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A]|[\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081]|[\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D]|[\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0]|[\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310]|[\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F4\u1401-\u166C]|[\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u1700-\u170C\u170E-\u1711]|[\u1720-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7]|[\u17DC\u1820-\u1877\u1880-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191C]|[\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19C1-\u19C7\u1A00-\u1A16]|[\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4B\u1B83-\u1BA0\u1BAE\u1BAF]|[\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1CE9-\u1CEC]|[\u1CEE-\u1CF1\u1CF5\u1CF6\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D]|[\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D]|[\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3]|[\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F]|[\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128]|[\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2183\u2184]|[\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3]|[\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6]|[\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE]|[\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005\u3006\u3031-\u3035\u303B\u303C]|[\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312D]|[\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FCC]|[\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B]|[\uA640-\uA66E\uA67F-\uA697\uA6A0-\uA6E5\uA717-\uA71F\uA722-\uA788]|[\uA78B-\uA78E\uA790-\uA793\uA7A0-\uA7AA\uA7F8-\uA801\uA803-\uA805]|[\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB]|[\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uAA00-\uAA28]|[\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA80-\uAAAF\uAAB1\uAAB5]|[\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4]|[\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E]|[\uABC0-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D]|[\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36]|[\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D]|[\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC]|[\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF]|[\uFFD2-\uFFD7\uFFDA-\uFFDC])/,/^(?:\|)/,/^(?:\|)/,/^(?:\))/,/^(?:\()/,/^(?:\])/,/^(?:\[)/,/^(?:(\}))/,/^(?:\{)/,/^(?:[^\[\]\(\)\{\}\|\"]+)/,/^(?:")/,/^(?:(\r?\n)+)/,/^(?:\s)/,/^(?:$)/],conditions:{callbackargs:{rules:[11,12,15,18,70,73,75,77,81,83,87,88,101,103,105,107],inclusive:!1},callbackname:{rules:[8,9,10,15,18,70,73,75,77,81,83,87,88,101,103,105,107],inclusive:!1},href:{rules:[15,18,70,73,75,77,81,83,87,88,101,103,105,107],inclusive:!1},click:{rules:[15,18,27,28,70,73,75,77,81,83,87,88,101,103,105,107],inclusive:!1},dottedEdgeText:{rules:[15,18,67,69,70,73,75,77,81,83,87,88,101,103,105,107],inclusive:!1},thickEdgeText:{rules:[15,18,64,66,70,73,75,77,81,83,87,88,101,103,105,107],inclusive:!1},edgeText:{rules:[15,18,61,63,70,73,75,77,81,83,87,88,101,103,105,107],inclusive:!1},trapText:{rules:[15,18,70,73,75,77,81,83,84,85,86,87,88,101,103,105,107],inclusive:!1},ellipseText:{rules:[15,18,70,71,72,73,75,77,81,83,87,88,101,103,105,107],inclusive:!1},text:{rules:[15,18,70,73,74,75,76,77,80,81,82,83,87,88,100,101,102,103,104,105,106,107,108],inclusive:!1},vertex:{rules:[15,18,70,73,75,77,81,83,87,88,101,103,105,107],inclusive:!1},dir:{rules:[15,18,38,39,40,41,42,43,44,45,46,47,48,70,73,75,77,81,83,87,88,101,103,105,107],inclusive:!1},acc_descr_multiline:{rules:[5,6,15,18,70,73,75,77,81,83,87,88,101,103,105,107],inclusive:!1},acc_descr:{rules:[3,15,18,70,73,75,77,81,83,87,88,101,103,105,107],inclusive:!1},acc_title:{rules:[1,15,18,70,73,75,77,81,83,87,88,101,103,105,107],inclusive:!1},md_string:{rules:[13,14,15,18,70,73,75,77,81,83,87,88,101,103,105,107],inclusive:!1},string:{rules:[15,16,17,18,70,73,75,77,81,83,87,88,101,103,105,107],inclusive:!1},INITIAL:{rules:[0,2,4,7,15,18,19,20,21,22,23,24,25,26,29,30,31,32,33,34,35,36,37,49,50,51,52,53,54,55,56,57,58,59,60,61,62,64,65,67,68,70,73,75,77,78,79,81,83,87,88,89,90,91,92,93,94,95,96,97,98,99,101,103,105,107,109,110,111,112],inclusive:!0}}};return $0}();Dl.lexer=Yh;function w1(){this.yy={}}return w1.prototype=Dl,Dl.Parser=w1,new w1}();Ube.parser=Ube;const Gbe=Ube,yUt="flowchart-";let Oqe=0,BD=qt(),oh={},z3=[],FD={},R7=[],IQ={},OQ={},NQ=0,Kbe=!0,$v,PQ,BQ=[];const FQ=i=>ci.sanitizeText(i,BD),mR=function(i){const s=Object.keys(oh);for(const u of s)if(oh[u].id===i)return oh[u].domId;return i},Nqe=function(i,s,u,d,p,v,b={}){let y,T=i;T!==void 0&&T.trim().length!==0&&(oh[T]===void 0&&(oh[T]={id:T,labelType:"text",domId:yUt+T+"-"+Oqe,styles:[],classes:[]}),Oqe++,s!==void 0?(BD=qt(),y=FQ(s.text.trim()),oh[T].labelType=s.type,y[0]==='"'&&y[y.length-1]==='"'&&(y=y.substring(1,y.length-1)),oh[T].text=y):oh[T].text===void 0&&(oh[T].text=i),u!==void 0&&(oh[T].type=u),d!=null&&d.forEach(function(_){oh[T].styles.push(_)}),p!=null&&p.forEach(function(_){oh[T].classes.push(_)}),v!==void 0&&(oh[T].dir=v),oh[T].props===void 0?oh[T].props=b:b!==void 0&&Object.assign(oh[T].props,b))},Pqe=function(i,s,u){const v={start:i,end:s,type:void 0,text:"",labelType:"text"};Xe.info("abc78 Got edge...",v);const b=u.text;if(b!==void 0&&(v.text=FQ(b.text.trim()),v.text[0]==='"'&&v.text[v.text.length-1]==='"'&&(v.text=v.text.substring(1,v.text.length-1)),v.labelType=b.type),u!==void 0&&(v.type=u.type,v.stroke=u.stroke,v.length=u.length),(v==null?void 0:v.length)>10&&(v.length=10),z3.length<(BD.maxEdges??500))Xe.info("abc78 pushing edge..."),z3.push(v);else throw new Error(`Edge limit exceeded. ${z3.length} edges found, but the limit is ${BD.maxEdges}. + +Initialize mermaid with maxEdges set to a higher number to allow more edges. +You cannot set this config via configuration inside the diagram as it is a secure config. +You have to call mermaid.initialize.`)},Bqe=function(i,s,u){Xe.info("addLink (abc78)",i,s,u);let d,p;for(d=0;d=z3.length)throw new Error(`The index ${u} for linkStyle is out of bounds. Valid indices for linkStyle are between 0 and ${z3.length-1}. (Help: Ensure that the index is within the range of existing edges.)`);u==="default"?z3.defaultStyle=s:(Ao.isSubstringInArray("fill",s)===-1&&s.push("fill:none"),z3[u].style=s)})},jqe=function(i,s){i.split(",").forEach(function(u){FD[u]===void 0&&(FD[u]={id:u,styles:[],textStyles:[]}),s!=null&&s.forEach(function(d){if(d.match("color")){const p=d.replace("fill","bgFill").replace("color","fill");FD[u].textStyles.push(p)}FD[u].styles.push(d)})})},$qe=function(i){$v=i,$v.match(/.*/)&&($v="LR"),$v.match(/.*v/)&&($v="TB"),$v==="TD"&&($v="TB")},RQ=function(i,s){i.split(",").forEach(function(u){let d=u;oh[d]!==void 0&&oh[d].classes.push(s),IQ[d]!==void 0&&IQ[d].classes.push(s)})},xUt=function(i,s){i.split(",").forEach(function(u){s!==void 0&&(OQ[PQ==="gen-1"?mR(u):u]=FQ(s))})},kUt=function(i,s,u){let d=mR(i);if(qt().securityLevel!=="loose"||s===void 0)return;let p=[];if(typeof u=="string"){p=u.split(/,(?=(?:(?:[^"]*"){2})*[^"]*$)/);for(let v=0;v")),p.classed("hover",!0)}).on("mouseout",function(){s.transition().duration(500).style("opacity",0),Ir(this).classed("hover",!1)})};BQ.push(Yqe);const Xqe=function(i="gen-1"){oh={},FD={},z3=[],BQ=[Yqe],R7=[],IQ={},NQ=0,OQ={},Kbe=!0,PQ=i,BD=qt(),Pg()},Qqe=i=>{PQ=i||"gen-2"},Jqe=function(){return"fill:#ffa;stroke: #f66; stroke-width: 3px; stroke-dasharray: 5, 5;fill:#ffa;stroke: #666;"},Zqe=function(i,s,u){let d=i.text.trim(),p=u.text;i===u&&u.text.match(/\s/)&&(d=void 0);function v(A){const P={boolean:{},number:{},string:{}},R=[];let F;return{nodeList:A.filter(function(K){const ee=typeof K;return K.stmt&&K.stmt==="dir"?(F=K.value,!1):K.trim()===""?!1:ee in P?P[ee].hasOwnProperty(K)?!1:P[ee][K]=!0:R.includes(K)?!1:R.push(K)}),dir:F}}let b=[];const{nodeList:y,dir:T}=v(b.concat.apply(b,s));if(b=y,PQ==="gen-1")for(let A=0;A2e3)return;if(eHe[vR]=s,R7[s].id===i)return{result:!0,count:0};let d=0,p=1;for(;d=0){const b=tHe(i,v);if(b.result)return{result:!0,count:p+b.count};p=p+b.count}d=d+1}return{result:!1,count:p}},nHe=function(i){return eHe[i]},rHe=function(){vR=-1,R7.length>0&&tHe("none",R7.length-1)},iHe=function(){return R7},sHe=()=>Kbe?(Kbe=!1,!0):!1,TUt=i=>{let s=i.trim(),u="arrow_open";switch(s[0]){case"<":u="arrow_point",s=s.slice(1);break;case"x":u="arrow_cross",s=s.slice(1);break;case"o":u="arrow_circle",s=s.slice(1);break}let d="normal";return s.includes("=")&&(d="thick"),s.includes(".")&&(d="dotted"),{type:u,stroke:d}},CUt=(i,s)=>{const u=s.length;let d=0;for(let p=0;p{const s=i.trim();let u=s.slice(0,-1),d="arrow_open";switch(s.slice(-1)){case"x":d="arrow_cross",s[0]==="x"&&(d="double_"+d,u=u.slice(1));break;case">":d="arrow_point",s[0]==="<"&&(d="double_"+d,u=u.slice(1));break;case"o":d="arrow_circle",s[0]==="o"&&(d="double_"+d,u=u.slice(1));break}let p="normal",v=u.length-1;u[0]==="="&&(p="thick"),u[0]==="~"&&(p="invisible");let b=CUt(".",u);return b&&(p="dotted",v=b),{type:d,stroke:p,length:v}},aHe=(i,s)=>{const u=SUt(i);let d;if(s){if(d=TUt(s),d.stroke!==u.stroke)return{type:"INVALID",stroke:"INVALID"};if(d.type==="arrow_open")d.type=u.type;else{if(d.type!==u.type)return{type:"INVALID",stroke:"INVALID"};d.type="double_"+d.type}return d.type==="double_arrow"&&(d.type="double_arrow_point"),d.length=u.length,d}return u},oHe=(i,s)=>{let u=!1;return i.forEach(d=>{d.nodes.indexOf(s)>=0&&(u=!0)}),u},cHe=(i,s)=>{const u=[];return i.nodes.forEach((d,p)=>{oHe(s,d)||u.push(i.nodes[p])}),{nodes:u}},uHe={firstGraph:sHe},HC={defaultConfig:()=>Zje.flowchart,setAccTitle:Bg,getAccTitle:Cp,getAccDescription:_p,setAccDescription:Sp,addVertex:Nqe,lookUpDomId:mR,addLink:Bqe,updateLinkInterpolate:Fqe,updateLink:Rqe,addClass:jqe,setDirection:$qe,setClass:RQ,setTooltip:xUt,getTooltip:qqe,setClickEvent:Hqe,setLink:zqe,bindFunctions:Vqe,getDirection:Uqe,getVertices:Gqe,getEdges:Kqe,getClasses:Wqe,clear:Xqe,setGen:Qqe,defaultStyle:Jqe,addSubGraph:Zqe,getDepthFirstPos:nHe,indexNodes:rHe,getSubGraphs:iHe,destructLink:aHe,lex:uHe,exists:oHe,makeUniq:cHe,setDiagramTitle:cm,getDiagramTitle:Ap},_Ut=Object.freeze(Object.defineProperty({__proto__:null,addClass:jqe,addLink:Bqe,addSingleLink:Pqe,addSubGraph:Zqe,addVertex:Nqe,bindFunctions:Vqe,clear:Xqe,default:HC,defaultStyle:Jqe,destructLink:aHe,firstGraph:sHe,getClasses:Wqe,getDepthFirstPos:nHe,getDirection:Uqe,getEdges:Kqe,getSubGraphs:iHe,getTooltip:qqe,getVertices:Gqe,indexNodes:rHe,lex:uHe,lookUpDomId:mR,setClass:RQ,setClickEvent:Hqe,setDirection:$qe,setGen:Qqe,setLink:zqe,updateLink:Rqe,updateLinkInterpolate:Fqe},Symbol.toStringTag,{value:"Module"}));var AUt="[object Symbol]";function VC(i){return typeof i=="symbol"||q4(i)&&AC(i)==AUt}function RD(i,s){for(var u=-1,d=i==null?0:i.length,p=Array(d);++u-1}function fm(i){return w9(i)?aje(i):l$e(i)}var GUt=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,KUt=/^\w*$/;function Wbe(i,s){if(D0(i))return!1;var u=typeof i;return u=="number"||u=="symbol"||u=="boolean"||i==null||VC(i)?!0:KUt.test(i)||!GUt.test(i)||s!=null&&i in Object(s)}var WUt=500;function YUt(i){var s=bD(i,function(d){return u.size===WUt&&u.clear(),d}),u=s.cache;return s}var XUt=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,QUt=/\\(\\)?/g,JUt=YUt(function(i){var s=[];return i.charCodeAt(0)===46&&s.push(""),i.replace(XUt,function(u,d,p,v){s.push(p?v.replace(QUt,"$1"):d||u)}),s});const ZUt=JUt;function mHe(i){return i==null?"":fHe(i)}function $Q(i,s){return D0(i)?i:Wbe(i,s)?[i]:ZUt(mHe(i))}var eGt=1/0;function wR(i){if(typeof i=="string"||VC(i))return i;var s=i+"";return s=="0"&&1/i==-eGt?"-0":s}function zQ(i,s){s=$Q(s,i);for(var u=0,d=s.length;i!=null&&u0&&u(y)?s>1?qQ(y,s-1,u,d,p):Ybe(p,y):d||(p[p.length]=y)}return p}function jD(i){var s=i==null?0:i.length;return s?qQ(i,1):[]}function rGt(i){return lje(uje(i,void 0,jD),i+"")}function iGt(i,s,u,d){var p=-1,v=i==null?0:i.length;for(d&&v&&(u=i[++p]);++py))return!1;var _=v.get(i),A=v.get(s);if(_&&A)return _==s&&A==i;var P=-1,R=!0,F=u&DKt?new xR:void 0;for(v.set(i,s),v.set(s,i);++P2?s[2]:void 0;for(p&&QF(s[0],s[1],p)&&(d=1);++u-1?p[v?s[b]:b]:void 0}}var yWt=Math.max;function xWt(i,s,u){var d=i==null?0:i.length;if(!d)return-1;var p=u==null?0:$Ut(u);return p<0&&(p=yWt(d+p,0)),bHe(i,I9(s),p)}var kWt=wWt(xWt);const rme=kWt;function VHe(i,s){var u=-1,d=w9(i)?Array(i.length):[];return VQ(i,function(p,v,b){d[++u]=s(p,v,b)}),d}function P0(i,s){var u=D0(i)?RD:VHe;return u(i,I9(s))}function EWt(i,s){return i==null?i:b2e(i,nme(s),IC)}function TWt(i,s){return i&&tme(i,nme(s))}function CWt(i,s){return i>s}var SWt=Object.prototype,_Wt=SWt.hasOwnProperty;function AWt(i,s){return i!=null&&_Wt.call(i,s)}function Lo(i,s){return i!=null&&$He(i,s,AWt)}function LWt(i,s){return RD(s,function(u){return i[u]})}function $7(i){return i==null?[]:LWt(i,fm(i))}function Qf(i){return i===void 0}function UHe(i,s){return is||v&&b&&T&&!y&&!_||d&&b&&T||!u&&T||!p)return 1;if(!d&&!v&&!_&&i=y)return T;var _=u[d];return T*(_=="desc"?-1:1)}}return i.index-s.index}function PWt(i,s,u){s.length?s=RD(s,function(v){return D0(v)?function(b){return zQ(b,v.length===1?v[0]:v)}:v}):s=[OC];var d=-1;s=RD(s,NX(I9));var p=VHe(i,function(v,b,y){var T=RD(s,function(_){return _(v)});return{criteria:T,index:++d,value:v}});return IWt(p,function(v,b){return NWt(v,b,u)})}function BWt(i,s){return DWt(i,s,function(u,d){return zHe(i,d)})}var FWt=rGt(function(i,s){return i==null?{}:BWt(i,s)});const ER=FWt;var RWt=Math.ceil,jWt=Math.max;function $Wt(i,s,u,d){for(var p=-1,v=jWt(RWt((s-i)/(u||1)),0),b=Array(v);v--;)b[d?v:++p]=i,i+=u;return b}function zWt(i){return function(s,u,d){return d&&typeof d!="number"&&QF(s,u,d)&&(u=d=void 0),s=jQ(s),u===void 0?(u=s,s=0):u=jQ(u),d=d===void 0?s1&&QF(i,s[0],s[1])?s=[]:u>2&&QF(s[0],s[1],s[2])&&(s=[s[0]]),PWt(i,qQ(s,1),[])});const CR=VWt;var UWt=1/0,GWt=CD&&1/Jbe(new CD([,-0]))[1]==UWt?function(i){return new CD(i)}:zUt;const KWt=GWt;var WWt=200;function YWt(i,s,u){var d=-1,p=UUt,v=i.length,b=!0,y=[],T=y;if(u)b=!1,p=mWt;else if(v>=WWt){var _=s?null:KWt(i);if(_)return Jbe(_);b=!1,p=IHe,T=new xR}else T=s?[]:y;e:for(;++d1?p.setNode(v,u):p.setNode(v)}),this}setNode(s,u){return Lo(this._nodes,s)?(arguments.length>1&&(this._nodes[s]=u),this):(this._nodes[s]=arguments.length>1?u:this._defaultNodeLabelFn(s),this._isCompound&&(this._parent[s]=KC,this._children[s]={},this._children[KC][s]=!0),this._in[s]={},this._preds[s]={},this._out[s]={},this._sucs[s]={},++this._nodeCount,this)}node(s){return this._nodes[s]}hasNode(s){return Lo(this._nodes,s)}removeNode(s){var u=this;if(Lo(this._nodes,s)){var d=function(p){u.removeEdge(u._edgeObjs[p])};delete this._nodes[s],this._isCompound&&(this._removeFromParentsChildList(s),delete this._parent[s],Ar(this.children(s),function(p){u.setParent(p)}),delete this._children[s]),Ar(fm(this._in[s]),d),delete this._in[s],delete this._preds[s],Ar(fm(this._out[s]),d),delete this._out[s],delete this._sucs[s],--this._nodeCount}return this}setParent(s,u){if(!this._isCompound)throw new Error("Cannot set parent in a non-compound graph");if(Qf(u))u=KC;else{u+="";for(var d=u;!Qf(d);d=this.parent(d))if(d===s)throw new Error("Setting "+u+" as parent of "+s+" would create a cycle");this.setNode(u)}return this.setNode(s),this._removeFromParentsChildList(s),this._parent[s]=u,this._children[u][s]=!0,this}_removeFromParentsChildList(s){delete this._children[this._parent[s]][s]}parent(s){if(this._isCompound){var u=this._parent[s];if(u!==KC)return u}}children(s){if(Qf(s)&&(s=KC),this._isCompound){var u=this._children[s];if(u)return fm(u)}else{if(s===KC)return this.nodes();if(this.hasNode(s))return[]}}predecessors(s){var u=this._preds[s];if(u)return fm(u)}successors(s){var u=this._sucs[s];if(u)return fm(u)}neighbors(s){var u=this.predecessors(s);if(u)return QWt(u,this.successors(s))}isLeaf(s){var u;return this.isDirected()?u=this.successors(s):u=this.neighbors(s),u.length===0}filterNodes(s){var u=new this.constructor({directed:this._isDirected,multigraph:this._isMultigraph,compound:this._isCompound});u.setGraph(this.graph());var d=this;Ar(this._nodes,function(b,y){s(y)&&u.setNode(y,b)}),Ar(this._edgeObjs,function(b){u.hasNode(b.v)&&u.hasNode(b.w)&&u.setEdge(b,d.edge(b))});var p={};function v(b){var y=d.parent(b);return y===void 0||u.hasNode(y)?(p[b]=y,y):y in p?p[y]:v(y)}return this._isCompound&&Ar(u.nodes(),function(b){u.setParent(b,v(b))}),u}setDefaultEdgeLabel(s){return gD(s)||(s=yD(s)),this._defaultEdgeLabelFn=s,this}edgeCount(){return this._edgeCount}edges(){return $7(this._edgeObjs)}setPath(s,u){var d=this,p=arguments;return TR(s,function(v,b){return p.length>1?d.setEdge(v,b,u):d.setEdge(v,b),b}),this}setEdge(){var s,u,d,p,v=!1,b=arguments[0];typeof b=="object"&&b!==null&&"v"in b?(s=b.v,u=b.w,d=b.name,arguments.length===2&&(p=arguments[1],v=!0)):(s=b,u=arguments[1],d=arguments[3],arguments.length>2&&(p=arguments[2],v=!0)),s=""+s,u=""+u,Qf(d)||(d=""+d);var y=SR(this._isDirected,s,u,d);if(Lo(this._edgeLabels,y))return v&&(this._edgeLabels[y]=p),this;if(!Qf(d)&&!this._isMultigraph)throw new Error("Cannot set a named edge when isMultigraph = false");this.setNode(s),this.setNode(u),this._edgeLabels[y]=v?p:this._defaultEdgeLabelFn(s,u,d);var T=nYt(this._isDirected,s,u,d);return s=T.v,u=T.w,Object.freeze(T),this._edgeObjs[y]=T,KHe(this._preds[u],s),KHe(this._sucs[s],u),this._in[u][y]=T,this._out[s][y]=T,this._edgeCount++,this}edge(s,u,d){var p=arguments.length===1?ame(this._isDirected,arguments[0]):SR(this._isDirected,s,u,d);return this._edgeLabels[p]}hasEdge(s,u,d){var p=arguments.length===1?ame(this._isDirected,arguments[0]):SR(this._isDirected,s,u,d);return Lo(this._edgeLabels,p)}removeEdge(s,u,d){var p=arguments.length===1?ame(this._isDirected,arguments[0]):SR(this._isDirected,s,u,d),v=this._edgeObjs[p];return v&&(s=v.v,u=v.w,delete this._edgeLabels[p],delete this._edgeObjs[p],WHe(this._preds[u],s),WHe(this._sucs[s],u),delete this._in[u][p],delete this._out[s][p],this._edgeCount--),this}inEdges(s,u){var d=this._in[s];if(d){var p=$7(d);return u?j7(p,function(v){return v.v===u}):p}}outEdges(s,u){var d=this._out[s];if(d){var p=$7(d);return u?j7(p,function(v){return v.w===u}):p}}nodeEdges(s,u){var d=this.inEdges(s,u);if(d)return d.concat(this.outEdges(s,u))}}B0.prototype._nodeCount=0,B0.prototype._edgeCount=0;function KHe(i,s){i[s]?i[s]++:i[s]=1}function WHe(i,s){--i[s]||delete i[s]}function SR(i,s,u,d){var p=""+s,v=""+u;if(!i&&p>v){var b=p;p=v,v=b}return p+GHe+v+GHe+(Qf(d)?tYt:d)}function nYt(i,s,u,d){var p=""+s,v=""+u;if(!i&&p>v){var b=p;p=v,v=b}var y={v:p,w:v};return d&&(y.name=d),y}function ame(i,s){return SR(i,s.v,s.w,s.name)}class rYt{constructor(){var s={};s._next=s._prev=s,this._sentinel=s}dequeue(){var s=this._sentinel,u=s._prev;if(u!==s)return YHe(u),u}enqueue(s){var u=this._sentinel;s._prev&&s._next&&YHe(s),s._next=u._next,u._next._prev=s,u._next=s,s._prev=u}toString(){for(var s=[],u=this._sentinel,d=u._prev;d!==u;)s.push(JSON.stringify(d,iYt)),d=d._prev;return"["+s.join(", ")+"]"}}function YHe(i){i._prev._next=i._next,i._next._prev=i._prev,delete i._next,delete i._prev}function iYt(i,s){if(i!=="_next"&&i!=="_prev")return s}var sYt=yD(1);function aYt(i,s){if(i.nodeCount()<=1)return[];var u=cYt(i,s||sYt),d=oYt(u.graph,u.buckets,u.zeroIdx);return jD(P0(d,function(p){return i.outEdges(p.v,p.w)}))}function oYt(i,s,u){for(var d=[],p=s[s.length-1],v=s[0],b;i.nodeCount();){for(;b=v.dequeue();)ome(i,s,u,b);for(;b=p.dequeue();)ome(i,s,u,b);if(i.nodeCount()){for(var y=s.length-2;y>0;--y)if(b=s[y].dequeue(),b){d=d.concat(ome(i,s,u,b,!0));break}}}return d}function ome(i,s,u,d,p){var v=p?[]:void 0;return Ar(i.inEdges(d.v),function(b){var y=i.edge(b),T=i.node(b.v);p&&v.push({v:b.v,w:b.w}),T.out-=y,cme(s,u,T)}),Ar(i.outEdges(d.v),function(b){var y=i.edge(b),T=b.w,_=i.node(T);_.in-=y,cme(s,u,_)}),i.removeNode(d.v),v}function cYt(i,s){var u=new B0,d=0,p=0;Ar(i.nodes(),function(y){u.setNode(y,{v:y,in:0,out:0})}),Ar(i.edges(),function(y){var T=u.edge(y.v,y.w)||0,_=s(y),A=T+_;u.setEdge(y.v,y.w,A),p=Math.max(p,u.node(y.v).out+=_),d=Math.max(d,u.node(y.w).in+=_)});var v=GC(p+d+3).map(function(){return new rYt}),b=d+1;return Ar(u.nodes(),function(y){cme(v,b,u.node(y))}),{graph:u,buckets:v,zeroIdx:b}}function cme(i,s,u){u.out?u.in?i[u.out-u.in+s].enqueue(u):i[i.length-1].enqueue(u):i[0].enqueue(u)}function uYt(i){var s=i.graph().acyclicer==="greedy"?aYt(i,u(i)):lYt(i);Ar(s,function(d){var p=i.edge(d);i.removeEdge(d),p.forwardName=d.name,p.reversed=!0,i.setEdge(d.w,d.v,p,KQ("rev"))});function u(d){return function(p){return d.edge(p).weight}}}function lYt(i){var s=[],u={},d={};function p(v){Lo(d,v)||(d[v]=!0,u[v]=!0,Ar(i.outEdges(v),function(b){Lo(u,b.w)?s.push(b):p(b.w)}),delete u[v])}return Ar(i.nodes(),p),s}function hYt(i){Ar(i.edges(),function(s){var u=i.edge(s);if(u.reversed){i.removeEdge(s);var d=u.forwardName;delete u.reversed,delete u.forwardName,i.setEdge(s.w,s.v,u,d)}})}function zD(i,s,u,d){var p;do p=KQ(d);while(i.hasNode(p));return u.dummy=s,i.setNode(p,u),p}function fYt(i){var s=new B0().setGraph(i.graph());return Ar(i.nodes(),function(u){s.setNode(u,i.node(u))}),Ar(i.edges(),function(u){var d=s.edge(u.v,u.w)||{weight:0,minlen:1},p=i.edge(u);s.setEdge(u.v,u.w,{weight:d.weight+p.weight,minlen:Math.max(d.minlen,p.minlen)})}),s}function XHe(i){var s=new B0({multigraph:i.isMultigraph()}).setGraph(i.graph());return Ar(i.nodes(),function(u){i.children(u).length||s.setNode(u,i.node(u))}),Ar(i.edges(),function(u){s.setEdge(u,i.edge(u))}),s}function QHe(i,s){var u=i.x,d=i.y,p=s.x-u,v=s.y-d,b=i.width/2,y=i.height/2;if(!p&&!v)throw new Error("Not possible to find intersection inside of the rectangle");var T,_;return Math.abs(v)*b>Math.abs(p)*y?(v<0&&(y=-y),T=y*p/v,_=y):(p<0&&(b=-b),T=b,_=b*v/p),{x:u+T,y:d+_}}function WQ(i){var s=P0(GC(ZHe(i)+1),function(){return[]});return Ar(i.nodes(),function(u){var d=i.node(u),p=d.rank;Qf(p)||(s[p][d.order]=u)}),s}function dYt(i){var s=kR(P0(i.nodes(),function(u){return i.node(u).rank}));Ar(i.nodes(),function(u){var d=i.node(u);Lo(d,"rank")&&(d.rank-=s)})}function gYt(i){var s=kR(P0(i.nodes(),function(v){return i.node(v).rank})),u=[];Ar(i.nodes(),function(v){var b=i.node(v).rank-s;u[b]||(u[b]=[]),u[b].push(v)});var d=0,p=i.graph().nodeRankFactor;Ar(u,function(v,b){Qf(v)&&b%p!==0?--d:d&&Ar(v,function(y){i.node(y).rank+=d})})}function JHe(i,s,u,d){var p={width:0,height:0};return arguments.length>=4&&(p.rank=u,p.order=d),zD(i,"border",p,s)}function ZHe(i){return UC(P0(i.nodes(),function(s){var u=i.node(s).rank;if(!Qf(u))return u}))}function pYt(i,s){var u={lhs:[],rhs:[]};return Ar(i,function(d){s(d)?u.lhs.push(d):u.rhs.push(d)}),u}function bYt(i,s){var u=qHe();try{return s()}finally{console.log(i+" time: "+(qHe()-u)+"ms")}}function mYt(i,s){return s()}function vYt(i){function s(u){var d=i.children(u),p=i.node(u);if(d.length&&Ar(d,s),Lo(p,"minRank")){p.borderLeft=[],p.borderRight=[];for(var v=p.minRank,b=p.maxRank+1;vb.lim&&(y=b,T=!0);var _=j7(s.edges(),function(A){return T===hVe(i,i.node(A.v),y)&&T!==hVe(i,i.node(A.w),y)});return sme(_,function(A){return _R(s,A)})}function lVe(i,s,u,d){var p=u.v,v=u.w;i.removeEdge(p,v),i.setEdge(d.v,d.w,{}),dme(i),fme(i,s),OYt(i,s)}function OYt(i,s){var u=rme(i.nodes(),function(p){return!s.node(p).parent}),d=DYt(i,u);d=d.slice(1),Ar(d,function(p){var v=i.node(p).parent,b=s.edge(p,v),y=!1;b||(b=s.edge(v,p),y=!0),s.node(p).rank=s.node(v).rank+(y?b.minlen:-b.minlen)})}function NYt(i,s,u){return i.hasEdge(s,u)}function hVe(i,s,u){return u.low<=s.lim&&s.lim<=u.lim}function PYt(i){switch(i.graph().ranker){case"network-simplex":fVe(i);break;case"tight-tree":FYt(i);break;case"longest-path":BYt(i);break;default:fVe(i)}}var BYt=hme;function FYt(i){hme(i),rVe(i)}function fVe(i){WC(i)}function RYt(i){var s=zD(i,"root",{},"_root"),u=jYt(i),d=UC($7(u))-1,p=2*d+1;i.graph().nestingRoot=s,Ar(i.edges(),function(b){i.edge(b).minlen*=p});var v=$Yt(i)+1;Ar(i.children(),function(b){dVe(i,s,p,v,d,u,b)}),i.graph().nodeRankFactor=p}function dVe(i,s,u,d,p,v,b){var y=i.children(b);if(!y.length){b!==s&&i.setEdge(s,b,{weight:0,minlen:u});return}var T=JHe(i,"_bt"),_=JHe(i,"_bb"),A=i.node(b);i.setParent(T,b),A.borderTop=T,i.setParent(_,b),A.borderBottom=_,Ar(y,function(P){dVe(i,s,u,d,p,v,P);var R=i.node(P),F=R.borderTop?R.borderTop:P,j=R.borderBottom?R.borderBottom:P,K=R.borderTop?d:2*d,ee=F!==j?1:p-v[b]+1;i.setEdge(T,F,{weight:K,minlen:ee,nestingEdge:!0}),i.setEdge(j,_,{weight:K,minlen:ee,nestingEdge:!0})}),i.parent(b)||i.setEdge(s,T,{weight:0,minlen:p+v[b]})}function jYt(i){var s={};function u(d,p){var v=i.children(d);v&&v.length&&Ar(v,function(b){u(b,p+1)}),s[d]=p}return Ar(i.children(),function(d){u(d,1)}),s}function $Yt(i){return TR(i.edges(),function(s,u){return s+i.edge(u).weight},0)}function zYt(i){var s=i.graph();i.removeNode(s.nestingRoot),delete s.nestingRoot,Ar(i.edges(),function(u){var d=i.edge(u);d.nestingEdge&&i.removeEdge(u)})}function qYt(i,s,u){var d={},p;Ar(u,function(v){for(var b=i.parent(v),y,T;b;){if(y=i.parent(b),y?(T=d[y],d[y]=b):(T=p,p=b),T&&T!==b){s.setEdge(T,b);return}b=y}})}function HYt(i,s,u){var d=VYt(i),p=new B0({compound:!0}).setGraph({root:d}).setDefaultNodeLabel(function(v){return i.node(v)});return Ar(i.nodes(),function(v){var b=i.node(v),y=i.parent(v);(b.rank===s||b.minRank<=s&&s<=b.maxRank)&&(p.setNode(v),p.setParent(v,y||d),Ar(i[u](v),function(T){var _=T.v===v?T.w:T.v,A=p.edge(_,v),P=Qf(A)?0:A.weight;p.setEdge(_,v,{weight:i.edge(T).weight+P})}),Lo(b,"minRank")&&p.setNode(v,{borderLeft:b.borderLeft[s],borderRight:b.borderRight[s]}))}),p}function VYt(i){for(var s;i.hasNode(s=KQ("_root")););return s}function UYt(i,s){for(var u=0,d=1;d0;)A%2&&(P+=y[A+1]),A=A-1>>1,y[A]+=_.weight;T+=_.weight*P})),T}function KYt(i){var s={},u=j7(i.nodes(),function(y){return!i.children(y).length}),d=UC(P0(u,function(y){return i.node(y).rank})),p=P0(GC(d+1),function(){return[]});function v(y){if(!Lo(s,y)){s[y]=!0;var T=i.node(y);p[T.rank].push(y),Ar(i.successors(y),v)}}var b=CR(u,function(y){return i.node(y).rank});return Ar(b,v),p}function WYt(i,s){return P0(s,function(u){var d=i.inEdges(u);if(d.length){var p=TR(d,function(v,b){var y=i.edge(b),T=i.node(b.v);return{sum:v.sum+y.weight*T.order,weight:v.weight+y.weight}},{sum:0,weight:0});return{v:u,barycenter:p.sum/p.weight,weight:p.weight}}else return{v:u}})}function YYt(i,s){var u={};Ar(i,function(p,v){var b=u[p.v]={indegree:0,in:[],out:[],vs:[p.v],i:v};Qf(p.barycenter)||(b.barycenter=p.barycenter,b.weight=p.weight)}),Ar(s.edges(),function(p){var v=u[p.v],b=u[p.w];!Qf(v)&&!Qf(b)&&(b.indegree++,v.out.push(u[p.w]))});var d=j7(u,function(p){return!p.indegree});return XYt(d)}function XYt(i){var s=[];function u(v){return function(b){b.merged||(Qf(b.barycenter)||Qf(v.barycenter)||b.barycenter>=v.barycenter)&&QYt(v,b)}}function d(v){return function(b){b.in.push(v),--b.indegree===0&&i.push(b)}}for(;i.length;){var p=i.pop();s.push(p),Ar(p.in.reverse(),u(p)),Ar(p.out,d(p))}return P0(j7(s,function(v){return!v.merged}),function(v){return ER(v,["vs","i","barycenter","weight"])})}function QYt(i,s){var u=0,d=0;i.weight&&(u+=i.barycenter*i.weight,d+=i.weight),s.weight&&(u+=s.barycenter*s.weight,d+=s.weight),i.vs=s.vs.concat(i.vs),i.barycenter=u/d,i.weight=d,i.i=Math.min(s.i,i.i),s.merged=!0}function JYt(i,s){var u=pYt(i,function(A){return Lo(A,"barycenter")}),d=u.lhs,p=CR(u.rhs,function(A){return-A.i}),v=[],b=0,y=0,T=0;d.sort(ZYt(!!s)),T=gVe(v,p,T),Ar(d,function(A){T+=A.vs.length,v.push(A.vs),b+=A.barycenter*A.weight,y+=A.weight,T=gVe(v,p,T)});var _={vs:jD(v)};return y&&(_.barycenter=b/y,_.weight=y),_}function gVe(i,s,u){for(var d;s.length&&(d=UQ(s)).i<=u;)s.pop(),i.push(d.vs),u++;return u}function ZYt(i){return function(s,u){return s.barycenteru.barycenter?1:i?u.i-s.i:s.i-u.i}}function pVe(i,s,u,d){var p=i.children(s),v=i.node(s),b=v?v.borderLeft:void 0,y=v?v.borderRight:void 0,T={};b&&(p=j7(p,function(j){return j!==b&&j!==y}));var _=WYt(i,p);Ar(_,function(j){if(i.children(j.v).length){var K=pVe(i,j.v,u,d);T[j.v]=K,Lo(K,"barycenter")&&tXt(j,K)}});var A=YYt(_,u);eXt(A,T);var P=JYt(A,d);if(b&&(P.vs=jD([b,P.vs,y]),i.predecessors(b).length)){var R=i.node(i.predecessors(b)[0]),F=i.node(i.predecessors(y)[0]);Lo(P,"barycenter")||(P.barycenter=0,P.weight=0),P.barycenter=(P.barycenter*P.weight+R.order+F.order)/(P.weight+2),P.weight+=2}return P}function eXt(i,s){Ar(i,function(u){u.vs=jD(u.vs.map(function(d){return s[d]?s[d].vs:d}))})}function tXt(i,s){Qf(i.barycenter)?(i.barycenter=s.barycenter,i.weight=s.weight):(i.barycenter=(i.barycenter*i.weight+s.barycenter*s.weight)/(i.weight+s.weight),i.weight+=s.weight)}function nXt(i){var s=ZHe(i),u=bVe(i,GC(1,s+1),"inEdges"),d=bVe(i,GC(s-1,-1,-1),"outEdges"),p=KYt(i);mVe(i,p);for(var v=Number.POSITIVE_INFINITY,b,y=0,T=0;T<4;++y,++T){rXt(y%2?u:d,y%4>=2),p=WQ(i);var _=UYt(i,p);_b||y>s[T].lim));for(_=T,T=d;(T=i.parent(T))!==_;)v.push(T);return{path:p.concat(v.reverse()),lca:_}}function aXt(i){var s={},u=0;function d(p){var v=u;Ar(i.children(p),d),s[p]={low:v,lim:u++}}return Ar(i.children(),d),s}function oXt(i,s){var u={};function d(p,v){var b=0,y=0,T=p.length,_=UQ(v);return Ar(v,function(A,P){var R=uXt(i,A),F=R?i.node(R).order:T;(R||A===_)&&(Ar(v.slice(y,P+1),function(j){Ar(i.predecessors(j),function(K){var ee=i.node(K),ie=ee.order;(ie_)&&vVe(u,R,A)})})}function p(v,b){var y=-1,T,_=0;return Ar(b,function(A,P){if(i.node(A).dummy==="border"){var R=i.predecessors(A);R.length&&(T=i.node(R[0]).order,d(b,_,P,y,T),_=P,y=T)}d(b,_,b.length,T,v.length)}),b}return TR(s,p),u}function uXt(i,s){if(i.node(s).dummy)return rme(i.predecessors(s),function(u){return i.node(u).dummy})}function vVe(i,s,u){if(s>u){var d=s;s=u,u=d}var p=i[s];p||(i[s]=p={}),p[u]=!0}function lXt(i,s,u){if(s>u){var d=s;s=u,u=d}return Lo(i[s],u)}function hXt(i,s,u,d){var p={},v={},b={};return Ar(s,function(y){Ar(y,function(T,_){p[T]=T,v[T]=T,b[T]=_})}),Ar(s,function(y){var T=-1;Ar(y,function(_){var A=d(_);if(A.length){A=CR(A,function(K){return b[K]});for(var P=(A.length-1)/2,R=Math.floor(P),F=Math.ceil(P);R<=F;++R){var j=A[R];v[_]===_&&T0}function e5(i,s,u){var d=i.x,p=i.y,v=[],b=Number.POSITIVE_INFINITY,y=Number.POSITIVE_INFINITY;s.forEach(function(j){b=Math.min(b,j.x),y=Math.min(y,j.y)});for(var T=d-i.width/2-b,_=p-i.height/2-y,A=0;A1&&v.sort(function(j,K){var ee=j.x-u.x,ie=j.y-u.y,oe=Math.sqrt(ee*ee+ie*ie),pe=K.x-u.x,be=K.y-u.y,ae=Math.sqrt(pe*pe+be*be);return oeMath.abs(p)*y?(v<0&&(y=-y),T=v===0?0:y*p/v,_=y):(p<0&&(b=-b),T=b,_=p===0?0:b*v/p),{x:u+T,y:d+_}}var Cme={rect:gQt,ellipse:pQt,circle:bQt,diamond:mQt};function dQt(i){Cme=i}function gQt(i,s,u){var d=i.insert("rect",":first-child").attr("rx",u.rx).attr("ry",u.ry).attr("x",-s.width/2).attr("y",-s.height/2).attr("width",s.width).attr("height",s.height);return u.intersect=function(p){return Tme(u,p)},d}function pQt(i,s,u){var d=s.width/2,p=s.height/2,v=i.insert("ellipse",":first-child").attr("x",-s.width/2).attr("y",-s.height/2).attr("rx",d).attr("ry",p);return u.intersect=function(b){return TVe(u,d,p,b)},v}function bQt(i,s,u){var d=Math.max(s.width,s.height)/2,p=i.insert("circle",":first-child").attr("x",-s.width/2).attr("y",-s.height/2).attr("r",d);return u.intersect=function(v){return hQt(u,d,v)},p}function mQt(i,s,u){var d=s.width*Math.SQRT2/2,p=s.height*Math.SQRT2/2,v=[{x:0,y:-p},{x:-d,y:0},{x:0,y:p},{x:d,y:0}],b=i.insert("polygon",":first-child").attr("points",v.map(function(y){return y.x+","+y.y}).join(" "));return u.intersect=function(y){return e5(u,v,y)},b}function vQt(){var i=function(s,u){xQt(u);var d=AR(s,"output"),p=AR(d,"clusters"),v=AR(d,"edgePaths"),b=xme(AR(d,"edgeLabels"),u),y=Eme(AR(d,"nodes"),u,Cme);qD(u),lQt(y,u),uQt(b,u),kme(v,u,mme);var T=yme(p,u);cQt(T,u),kQt(u)};return i.createNodes=function(s){return arguments.length?(oQt(s),i):Eme},i.createClusters=function(s){return arguments.length?(ZXt(s),i):yme},i.createEdgeLabels=function(s){return arguments.length?(eQt(s),i):xme},i.createEdgePaths=function(s){return arguments.length?(tQt(s),i):kme},i.shapes=function(s){return arguments.length?(dQt(s),i):Cme},i.arrows=function(s){return arguments.length?(GXt(s),i):mme},i}var wQt={paddingLeft:10,paddingRight:10,paddingTop:10,paddingBottom:10,rx:0,ry:0,shape:"rect"},yQt={arrowhead:"normal",curve:kp};function xQt(i){i.nodes().forEach(function(s){var u=i.node(s);!Lo(u,"label")&&!i.children(s).length&&(u.label=s),Lo(u,"paddingX")&&$D(u,{paddingLeft:u.paddingX,paddingRight:u.paddingX}),Lo(u,"paddingY")&&$D(u,{paddingTop:u.paddingY,paddingBottom:u.paddingY}),Lo(u,"padding")&&$D(u,{paddingLeft:u.padding,paddingRight:u.padding,paddingTop:u.padding,paddingBottom:u.padding}),$D(u,wQt),Ar(["paddingLeft","paddingRight","paddingTop","paddingBottom"],function(d){u[d]=Number(u[d])}),Lo(u,"width")&&(u._prevWidth=u.width),Lo(u,"height")&&(u._prevHeight=u.height)}),i.edges().forEach(function(s){var u=i.edge(s);Lo(u,"label")||(u.label=""),$D(u,yQt)})}function kQt(i){Ar(i.nodes(),function(s){var u=i.node(s);Lo(u,"_prevWidth")?u.width=u._prevWidth:delete u.width,Lo(u,"_prevHeight")?u.height=u._prevHeight:delete u.height,delete u._prevWidth,delete u._prevHeight})}function AR(i,s){var u=i.select("g."+s);return u.empty()&&(u=i.append("g").attr("class",s)),u}function SVe(i,s,u){const d=s.width,p=s.height,v=(d+p)*.9,b=[{x:v/2,y:0},{x:v,y:-v/2},{x:v/2,y:-v},{x:0,y:-v/2}],y=z7(i,v,v,b);return u.intersect=function(T){return e5(u,b,T)},y}function _Ve(i,s,u){const p=s.height,v=p/4,b=s.width+2*v,y=[{x:v,y:0},{x:b-v,y:0},{x:b,y:-p/2},{x:b-v,y:-p},{x:v,y:-p},{x:0,y:-p/2}],T=z7(i,b,p,y);return u.intersect=function(_){return e5(u,y,_)},T}function AVe(i,s,u){const d=s.width,p=s.height,v=[{x:-p/2,y:0},{x:d,y:0},{x:d,y:-p},{x:-p/2,y:-p},{x:0,y:-p/2}],b=z7(i,d,p,v);return u.intersect=function(y){return e5(u,v,y)},b}function LVe(i,s,u){const d=s.width,p=s.height,v=[{x:-2*p/6,y:0},{x:d-p/6,y:0},{x:d+2*p/6,y:-p},{x:p/6,y:-p}],b=z7(i,d,p,v);return u.intersect=function(y){return e5(u,v,y)},b}function MVe(i,s,u){const d=s.width,p=s.height,v=[{x:2*p/6,y:0},{x:d+p/6,y:0},{x:d-2*p/6,y:-p},{x:-p/6,y:-p}],b=z7(i,d,p,v);return u.intersect=function(y){return e5(u,v,y)},b}function DVe(i,s,u){const d=s.width,p=s.height,v=[{x:-2*p/6,y:0},{x:d+2*p/6,y:0},{x:d-p/6,y:-p},{x:p/6,y:-p}],b=z7(i,d,p,v);return u.intersect=function(y){return e5(u,v,y)},b}function IVe(i,s,u){const d=s.width,p=s.height,v=[{x:p/6,y:0},{x:d-p/6,y:0},{x:d+2*p/6,y:-p},{x:-2*p/6,y:-p}],b=z7(i,d,p,v);return u.intersect=function(y){return e5(u,v,y)},b}function OVe(i,s,u){const d=s.width,p=s.height,v=[{x:0,y:0},{x:d+p/2,y:0},{x:d,y:-p/2},{x:d+p/2,y:-p},{x:0,y:-p}],b=z7(i,d,p,v);return u.intersect=function(y){return e5(u,v,y)},b}function NVe(i,s,u){const d=s.height,p=s.width+d/4,v=i.insert("rect",":first-child").attr("rx",d/2).attr("ry",d/2).attr("x",-p/2).attr("y",-d/2).attr("width",p).attr("height",d);return u.intersect=function(b){return Tme(u,b)},v}function PVe(i,s,u){const d=s.width,p=s.height,v=[{x:0,y:0},{x:d,y:0},{x:d,y:-p},{x:0,y:-p},{x:0,y:0},{x:-8,y:0},{x:d+8,y:0},{x:d+8,y:-p},{x:-8,y:-p},{x:-8,y:0}],b=z7(i,d,p,v);return u.intersect=function(y){return e5(u,v,y)},b}function BVe(i,s,u){const d=s.width,p=d/2,v=p/(2.5+d/50),b=s.height+v,y="M 0,"+v+" a "+p+","+v+" 0,0,0 "+d+" 0 a "+p+","+v+" 0,0,0 "+-d+" 0 l 0,"+b+" a "+p+","+v+" 0,0,0 "+d+" 0 l 0,"+-b,T=i.attr("label-offset-y",v).insert("path",":first-child").attr("d",y).attr("transform","translate("+-d/2+","+-(b/2+v)+")");return u.intersect=function(_){const A=Tme(u,_),P=A.x-u.x;if(p!=0&&(Math.abs(P)u.height/2-v)){let R=v*v*(1-P*P/(p*p));R!=0&&(R=Math.sqrt(R)),R=v-R,_.y-u.y>0&&(R=-R),A.y+=R}return A},T}function EQt(i){i.shapes().question=SVe,i.shapes().hexagon=_Ve,i.shapes().stadium=NVe,i.shapes().subroutine=PVe,i.shapes().cylinder=BVe,i.shapes().rect_left_inv_arrow=AVe,i.shapes().lean_right=LVe,i.shapes().lean_left=MVe,i.shapes().trapezoid=DVe,i.shapes().inv_trapezoid=IVe,i.shapes().rect_right_inv_arrow=OVe}function TQt(i){i({question:SVe}),i({hexagon:_Ve}),i({stadium:NVe}),i({subroutine:PVe}),i({cylinder:BVe}),i({rect_left_inv_arrow:AVe}),i({lean_right:LVe}),i({lean_left:MVe}),i({trapezoid:DVe}),i({inv_trapezoid:IVe}),i({rect_right_inv_arrow:OVe})}function z7(i,s,u,d){return i.insert("polygon",":first-child").attr("points",d.map(function(p){return p.x+","+p.y}).join(" ")).attr("transform","translate("+-s/2+","+u/2+")")}const CQt={addToRender:EQt,addToRenderV2:TQt},FVe={},SQt=function(i){const s=Object.keys(i);for(const u of s)FVe[u]=i[u]},RVe=async function(i,s,u,d,p,v){const b=d?d.select(`[id="${u}"]`):Ir(`[id="${u}"]`),y=p||document,T=Object.keys(i);for(const _ of T){const A=i[_];let P="default";A.classes.length>0&&(P=A.classes.join(" "));const R=om(A.styles);let F=A.text!==void 0?A.text:A.id,j;if(f1(qt().flowchart.htmlLabels)){const ie={label:await CC(F.replace(/fa[blrs]?:fa-[\w-]+/g,oe=>``),qt())};j=vme(b,ie).node(),j.parentNode.removeChild(j)}else{const ie=y.createElementNS("http://www.w3.org/2000/svg","text");ie.setAttribute("style",R.labelStyle.replace("color:","fill:"));const oe=F.split(ci.lineBreakRegex);for(const pe of oe){const be=y.createElementNS("http://www.w3.org/2000/svg","tspan");be.setAttributeNS("http://www.w3.org/XML/1998/namespace","xml:space","preserve"),be.setAttribute("dy","1em"),be.setAttribute("x","1"),be.textContent=pe,ie.appendChild(be)}j=ie}let K=0,ee="";switch(A.type){case"round":K=5,ee="rect";break;case"square":ee="rect";break;case"diamond":ee="question";break;case"hexagon":ee="hexagon";break;case"odd":ee="rect_left_inv_arrow";break;case"lean_right":ee="lean_right";break;case"lean_left":ee="lean_left";break;case"trapezoid":ee="trapezoid";break;case"inv_trapezoid":ee="inv_trapezoid";break;case"odd_right":ee="rect_left_inv_arrow";break;case"circle":ee="circle";break;case"ellipse":ee="ellipse";break;case"stadium":ee="stadium";break;case"subroutine":ee="subroutine";break;case"cylinder":ee="cylinder";break;case"group":ee="rect";break;default:ee="rect"}Xe.warn("Adding node",A.id,A.domId),s.setNode(v.db.lookUpDomId(A.id),{labelType:"svg",labelStyle:R.labelStyle,shape:ee,label:j,rx:K,ry:K,class:P,style:R.style,id:v.db.lookUpDomId(A.id)})}},jVe=async function(i,s,u){let d=0,p,v;if(i.defaultStyle!==void 0){const b=om(i.defaultStyle);p=b.style,v=b.labelStyle}for(const b of i){d++;const y="L-"+b.start+"-"+b.end,T="LS-"+b.start,_="LE-"+b.end,A={};b.type==="arrow_open"?A.arrowhead="none":A.arrowhead="normal";let P="",R="";if(b.style!==void 0){const F=om(b.style);P=F.style,R=F.labelStyle}else switch(b.stroke){case"normal":P="fill:none",p!==void 0&&(P=p),v!==void 0&&(R=v);break;case"dotted":P="fill:none;stroke-width:2px;stroke-dasharray:3;";break;case"thick":P=" stroke-width: 3.5px;fill:none";break}A.style=P,A.labelStyle=R,b.interpolate!==void 0?A.curve=Ov(b.interpolate,kp):i.defaultInterpolate!==void 0?A.curve=Ov(i.defaultInterpolate,kp):A.curve=Ov(FVe.curve,kp),b.text===void 0?b.style!==void 0&&(A.arrowheadStyle="fill: #333"):(A.arrowheadStyle="fill: #333",A.labelpos="c",f1(qt().flowchart.htmlLabels)?(A.labelType="html",A.label=`${await CC(b.text.replace(/fa[blrs]?:fa-[\w-]+/g,F=>``),qt())}`):(A.labelType="text",A.label=b.text.replace(ci.lineBreakRegex,` +`),b.style===void 0&&(A.style=A.style||"stroke: #333; stroke-width: 1.5px;fill:none"),A.labelStyle=A.labelStyle.replace("color:","fill:"))),A.id=y,A.class=T+" "+_,A.minlen=b.length||1,s.setEdge(u.db.lookUpDomId(b.start),u.db.lookUpDomId(b.end),A,d)}},_Qt={setConf:SQt,addVertices:RVe,addEdges:jVe,getClasses:function(i,s){return Xe.info("Extracting classes"),s.db.getClasses()},draw:async function(i,s,u,d){Xe.info("Drawing flowchart");const{securityLevel:p,flowchart:v}=qt();let b;p==="sandbox"&&(b=Ir("#i"+s));const y=Ir(p==="sandbox"?b.nodes()[0].contentDocument.body:"body"),T=p==="sandbox"?b.nodes()[0].contentDocument:document;let _=d.db.getDirection();_===void 0&&(_="TD");const A=v.nodeSpacing||50,P=v.rankSpacing||50,R=new B0({multigraph:!0,compound:!0}).setGraph({rankdir:_,nodesep:A,ranksep:P,marginx:8,marginy:8}).setDefaultEdgeLabel(function(){return{}});let F;const j=d.db.getSubGraphs();for(let ne=j.length-1;ne>=0;ne--)F=j[ne],d.db.addVertex(F.id,F.title,"group",void 0,F.classes);const K=d.db.getVertices();Xe.warn("Get vertices",K);const ee=d.db.getEdges();let ie=0;for(ie=j.length-1;ie>=0;ie--){F=j[ie],_Be("cluster").append("text");for(let ne=0;ne{s.forEach(p=>{DQt[p](i,u,d)})},DQt={extension:(i,s,u)=>{Xe.trace("Making markers for ",u),i.append("defs").append("marker").attr("id",u+"_"+s+"-extensionStart").attr("class","marker extension "+s).attr("refX",18).attr("refY",7).attr("markerWidth",190).attr("markerHeight",240).attr("orient","auto").append("path").attr("d","M 1,7 L18,13 V 1 Z"),i.append("defs").append("marker").attr("id",u+"_"+s+"-extensionEnd").attr("class","marker extension "+s).attr("refX",1).attr("refY",7).attr("markerWidth",20).attr("markerHeight",28).attr("orient","auto").append("path").attr("d","M 1,1 V 13 L18,7 Z")},composition:(i,s,u)=>{i.append("defs").append("marker").attr("id",u+"_"+s+"-compositionStart").attr("class","marker composition "+s).attr("refX",18).attr("refY",7).attr("markerWidth",190).attr("markerHeight",240).attr("orient","auto").append("path").attr("d","M 18,7 L9,13 L1,7 L9,1 Z"),i.append("defs").append("marker").attr("id",u+"_"+s+"-compositionEnd").attr("class","marker composition "+s).attr("refX",1).attr("refY",7).attr("markerWidth",20).attr("markerHeight",28).attr("orient","auto").append("path").attr("d","M 18,7 L9,13 L1,7 L9,1 Z")},aggregation:(i,s,u)=>{i.append("defs").append("marker").attr("id",u+"_"+s+"-aggregationStart").attr("class","marker aggregation "+s).attr("refX",18).attr("refY",7).attr("markerWidth",190).attr("markerHeight",240).attr("orient","auto").append("path").attr("d","M 18,7 L9,13 L1,7 L9,1 Z"),i.append("defs").append("marker").attr("id",u+"_"+s+"-aggregationEnd").attr("class","marker aggregation "+s).attr("refX",1).attr("refY",7).attr("markerWidth",20).attr("markerHeight",28).attr("orient","auto").append("path").attr("d","M 18,7 L9,13 L1,7 L9,1 Z")},dependency:(i,s,u)=>{i.append("defs").append("marker").attr("id",u+"_"+s+"-dependencyStart").attr("class","marker dependency "+s).attr("refX",6).attr("refY",7).attr("markerWidth",190).attr("markerHeight",240).attr("orient","auto").append("path").attr("d","M 5,7 L9,13 L1,7 L9,1 Z"),i.append("defs").append("marker").attr("id",u+"_"+s+"-dependencyEnd").attr("class","marker dependency "+s).attr("refX",13).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")},lollipop:(i,s,u)=>{i.append("defs").append("marker").attr("id",u+"_"+s+"-lollipopStart").attr("class","marker lollipop "+s).attr("refX",13).attr("refY",7).attr("markerWidth",190).attr("markerHeight",240).attr("orient","auto").append("circle").attr("stroke","black").attr("fill","transparent").attr("cx",7).attr("cy",7).attr("r",6),i.append("defs").append("marker").attr("id",u+"_"+s+"-lollipopEnd").attr("class","marker lollipop "+s).attr("refX",1).attr("refY",7).attr("markerWidth",190).attr("markerHeight",240).attr("orient","auto").append("circle").attr("stroke","black").attr("fill","transparent").attr("cx",7).attr("cy",7).attr("r",6)},point:(i,s,u)=>{i.append("marker").attr("id",u+"_"+s+"-pointEnd").attr("class","marker "+s).attr("viewBox","0 0 10 10").attr("refX",6).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").attr("class","arrowMarkerPath").style("stroke-width",1).style("stroke-dasharray","1,0"),i.append("marker").attr("id",u+"_"+s+"-pointStart").attr("class","marker "+s).attr("viewBox","0 0 10 10").attr("refX",4.5).attr("refY",5).attr("markerUnits","userSpaceOnUse").attr("markerWidth",12).attr("markerHeight",12).attr("orient","auto").append("path").attr("d","M 0 5 L 10 10 L 10 0 z").attr("class","arrowMarkerPath").style("stroke-width",1).style("stroke-dasharray","1,0")},circle:(i,s,u)=>{i.append("marker").attr("id",u+"_"+s+"-circleEnd").attr("class","marker "+s).attr("viewBox","0 0 10 10").attr("refX",11).attr("refY",5).attr("markerUnits","userSpaceOnUse").attr("markerWidth",11).attr("markerHeight",11).attr("orient","auto").append("circle").attr("cx","5").attr("cy","5").attr("r","5").attr("class","arrowMarkerPath").style("stroke-width",1).style("stroke-dasharray","1,0"),i.append("marker").attr("id",u+"_"+s+"-circleStart").attr("class","marker "+s).attr("viewBox","0 0 10 10").attr("refX",-1).attr("refY",5).attr("markerUnits","userSpaceOnUse").attr("markerWidth",11).attr("markerHeight",11).attr("orient","auto").append("circle").attr("cx","5").attr("cy","5").attr("r","5").attr("class","arrowMarkerPath").style("stroke-width",1).style("stroke-dasharray","1,0")},cross:(i,s,u)=>{i.append("marker").attr("id",u+"_"+s+"-crossEnd").attr("class","marker cross "+s).attr("viewBox","0 0 11 11").attr("refX",12).attr("refY",5.2).attr("markerUnits","userSpaceOnUse").attr("markerWidth",11).attr("markerHeight",11).attr("orient","auto").append("path").attr("d","M 1,1 l 9,9 M 10,1 l -9,9").attr("class","arrowMarkerPath").style("stroke-width",2).style("stroke-dasharray","1,0"),i.append("marker").attr("id",u+"_"+s+"-crossStart").attr("class","marker cross "+s).attr("viewBox","0 0 11 11").attr("refX",-1).attr("refY",5.2).attr("markerUnits","userSpaceOnUse").attr("markerWidth",11).attr("markerHeight",11).attr("orient","auto").append("path").attr("d","M 1,1 l 9,9 M 10,1 l -9,9").attr("class","arrowMarkerPath").style("stroke-width",2).style("stroke-dasharray","1,0")},barb:(i,s,u)=>{i.append("defs").append("marker").attr("id",u+"_"+s+"-barbEnd").attr("refX",19).attr("refY",7).attr("markerWidth",20).attr("markerHeight",14).attr("markerUnits","strokeWidth").attr("orient","auto").append("path").attr("d","M 19,7 L9,13 L14,7 L9,1 Z")}},Sme=MQt;function IQt(i,s){s&&i.attr("style",s)}function OQt(i){const s=Ir(document.createElementNS("http://www.w3.org/2000/svg","foreignObject")),u=s.append("xhtml:div"),d=i.label,p=i.isNode?"nodeLabel":"edgeLabel";return u.html('"+d+""),IQt(u,i.labelStyle),u.style("display","inline-block"),u.style("white-space","nowrap"),u.attr("xmlns","http://www.w3.org/1999/xhtml"),s.node()}const $2=(i,s,u,d)=>{let p=i||"";if(typeof p=="object"&&(p=p[0]),f1(qt().flowchart.htmlLabels)){p=p.replace(/\\n|\n/g,"
    "),Xe.debug("vertexText"+p);const v={isNode:d,label:ZF(p).replace(/fa[blrs]?:fa-[\w-]+/g,y=>``),labelStyle:s.replace("fill:","color:")};return OQt(v)}else{const v=document.createElementNS("http://www.w3.org/2000/svg","text");v.setAttribute("style",s.replace("color:","fill:"));let b=[];typeof p=="string"?b=p.split(/\\n|\n|/gi):Array.isArray(p)?b=p:b=[];for(const y of b){const T=document.createElementNS("http://www.w3.org/2000/svg","tspan");T.setAttributeNS("http://www.w3.org/XML/1998/namespace","xml:space","preserve"),T.setAttribute("dy","1em"),T.setAttribute("x","0"),u?T.setAttribute("class","title-row"):T.setAttribute("class","row"),T.textContent=y.trim(),v.appendChild(T)}return v}},NQt={};function PQt(i,s){const u=s||NQt,d=typeof u.includeImageAlt=="boolean"?u.includeImageAlt:!0,p=typeof u.includeHtml=="boolean"?u.includeHtml:!0;return $Ve(i,d,p)}function $Ve(i,s,u){if(BQt(i)){if("value"in i)return i.type==="html"&&!u?"":i.value;if(s&&"alt"in i&&i.alt)return i.alt;if("children"in i)return zVe(i.children,s,u)}return Array.isArray(i)?zVe(i,s,u):""}function zVe(i,s,u){const d=[];let p=-1;for(;++pp?0:p+s:s=s>p?p:s,u=u>0?u:0,d.length<1e4)b=Array.from(d),b.unshift(s,u),i.splice(...b);else for(u&&i.splice(s,u);v0?(t5(i,i.length,0,s),i):s}const qVe={}.hasOwnProperty;function FQt(i){const s={};let u=-1;for(;++ub))return;const se=s.events.length;let de=se,X,ge;for(;de--;)if(s.events[de][0]==="exit"&&s.events[de][1].type==="chunkFlow"){if(X){ge=s.events[de][1].end;break}X=!0}for(ie(d),ne=se;nepe;){const ae=u[be];s.containerState=ae[1],ae[0].exit.call(s,i)}u.length=pe}function oe(){p.write([null]),v=void 0,p=void 0,s.containerState._closeFlow=void 0}}function XQt(i,s,u){return Kl(i,i.attempt(this.parser.constructs.document,s,u),"linePrefix",this.parser.constructs.disable.null.includes("codeIndented")?void 0:4)}function VVe(i){if(i===null||z2(i)||UQt(i))return 1;if(VQt(i))return 2}function Lme(i,s,u){const d=[];let p=-1;for(;++p1&&i[u][1].end.offset-i[u][1].start.offset>1?2:1;const P=Object.assign({},i[d][1].end),R=Object.assign({},i[u][1].start);UVe(P,-T),UVe(R,T),b={type:T>1?"strongSequence":"emphasisSequence",start:P,end:Object.assign({},i[d][1].end)},y={type:T>1?"strongSequence":"emphasisSequence",start:Object.assign({},i[u][1].start),end:R},v={type:T>1?"strongText":"emphasisText",start:Object.assign({},i[d][1].end),end:Object.assign({},i[u][1].start)},p={type:T>1?"strong":"emphasis",start:Object.assign({},b.start),end:Object.assign({},y.end)},i[d][1].end=Object.assign({},b.start),i[u][1].start=Object.assign({},y.end),_=[],i[d][1].end.offset-i[d][1].start.offset&&(_=zv(_,[["enter",i[d][1],s],["exit",i[d][1],s]])),_=zv(_,[["enter",p,s],["enter",b,s],["exit",b,s],["enter",v,s]]),_=zv(_,Lme(s.parser.constructs.insideSpan.null,i.slice(d+1,u),s)),_=zv(_,[["exit",v,s],["enter",y,s],["exit",y,s],["exit",p,s]]),i[u][1].end.offset-i[u][1].start.offset?(A=2,_=zv(_,[["enter",i[u][1],s],["exit",i[u][1],s]])):A=0,t5(i,d-1,u-d+3,_),u=d+_.length-A-2;break}}for(u=-1;++u0&&Iu(ne)?Kl(i,oe,"linePrefix",v+1)(ne):oe(ne)}function oe(ne){return ne===null||so(ne)?i.check(XVe,K,be)(ne):(i.enter("codeFlowValue"),pe(ne))}function pe(ne){return ne===null||so(ne)?(i.exit("codeFlowValue"),oe(ne)):(i.consume(ne),pe)}function be(ne){return i.exit("codeFenced"),s(ne)}function ae(ne,se,de){let X=0;return ge;function ge(Pe){return ne.enter("lineEnding"),ne.consume(Pe),ne.exit("lineEnding"),W}function W(Pe){return ne.enter("codeFencedFence"),Iu(Pe)?Kl(ne,xe,"linePrefix",d.parser.constructs.disable.null.includes("codeIndented")?void 0:4)(Pe):xe(Pe)}function xe(Pe){return Pe===y?(ne.enter("codeFencedFenceSequence"),U(Pe)):de(Pe)}function U(Pe){return Pe===y?(X++,ne.consume(Pe),U):X>=b?(ne.exit("codeFencedFenceSequence"),Iu(Pe)?Kl(ne,Fe,"whitespace")(Pe):Fe(Pe)):de(Pe)}function Fe(Pe){return Pe===null||so(Pe)?(ne.exit("codeFencedFence"),se(Pe)):de(Pe)}}}function cJt(i,s,u){const d=this;return p;function p(b){return b===null?u(b):(i.enter("lineEnding"),i.consume(b),i.exit("lineEnding"),v)}function v(b){return d.parser.lazy[d.now().line]?u(b):s(b)}}const Ime={name:"codeIndented",tokenize:lJt},uJt={tokenize:hJt,partial:!0};function lJt(i,s,u){const d=this;return p;function p(_){return i.enter("codeIndented"),Kl(i,v,"linePrefix",4+1)(_)}function v(_){const A=d.events[d.events.length-1];return A&&A[1].type==="linePrefix"&&A[2].sliceSerialize(A[1],!0).length>=4?b(_):u(_)}function b(_){return _===null?T(_):so(_)?i.attempt(uJt,b,T)(_):(i.enter("codeFlowValue"),y(_))}function y(_){return _===null||so(_)?(i.exit("codeFlowValue"),b(_)):(i.consume(_),y)}function T(_){return i.exit("codeIndented"),s(_)}}function hJt(i,s,u){const d=this;return p;function p(b){return d.parser.lazy[d.now().line]?u(b):so(b)?(i.enter("lineEnding"),i.consume(b),i.exit("lineEnding"),p):Kl(i,v,"linePrefix",4+1)(b)}function v(b){const y=d.events[d.events.length-1];return y&&y[1].type==="linePrefix"&&y[2].sliceSerialize(y[1],!0).length>=4?s(b):so(b)?p(b):u(b)}}const fJt={name:"codeText",tokenize:pJt,resolve:dJt,previous:gJt};function dJt(i){let s=i.length-4,u=3,d,p;if((i[u][1].type==="lineEnding"||i[u][1].type==="space")&&(i[s][1].type==="lineEnding"||i[s][1].type==="space")){for(d=u;++d=4?s(b):i.interrupt(d.parser.constructs.flow,u,s)(b)}}function ZVe(i,s,u,d,p,v,b,y,T){const _=T||Number.POSITIVE_INFINITY;let A=0;return P;function P(ie){return ie===60?(i.enter(d),i.enter(p),i.enter(v),i.consume(ie),i.exit(v),R):ie===null||ie===32||ie===41||_me(ie)?u(ie):(i.enter(d),i.enter(b),i.enter(y),i.enter("chunkString",{contentType:"string"}),K(ie))}function R(ie){return ie===62?(i.enter(v),i.consume(ie),i.exit(v),i.exit(p),i.exit(d),s):(i.enter(y),i.enter("chunkString",{contentType:"string"}),F(ie))}function F(ie){return ie===62?(i.exit("chunkString"),i.exit(y),R(ie)):ie===null||ie===60||so(ie)?u(ie):(i.consume(ie),ie===92?j:F)}function j(ie){return ie===60||ie===62||ie===92?(i.consume(ie),F):F(ie)}function K(ie){return!A&&(ie===null||ie===41||z2(ie))?(i.exit("chunkString"),i.exit(y),i.exit(b),i.exit(d),s(ie)):A<_&&ie===40?(i.consume(ie),A++,K):ie===41?(i.consume(ie),A--,K):ie===null||ie===32||ie===40||_me(ie)?u(ie):(i.consume(ie),ie===92?ee:K)}function ee(ie){return ie===40||ie===41||ie===92?(i.consume(ie),K):K(ie)}}function eUe(i,s,u,d,p,v){const b=this;let y=0,T;return _;function _(F){return i.enter(d),i.enter(p),i.consume(F),i.exit(p),i.enter(v),A}function A(F){return y>999||F===null||F===91||F===93&&!T||F===94&&!y&&"_hiddenFootnoteSupport"in b.parser.constructs?u(F):F===93?(i.exit(v),i.enter(p),i.consume(F),i.exit(p),i.exit(d),s):so(F)?(i.enter("lineEnding"),i.consume(F),i.exit("lineEnding"),A):(i.enter("chunkString",{contentType:"string"}),P(F))}function P(F){return F===null||F===91||F===93||so(F)||y++>999?(i.exit("chunkString"),A(F)):(i.consume(F),T||(T=!Iu(F)),F===92?R:P)}function R(F){return F===91||F===92||F===93?(i.consume(F),y++,P):P(F)}}function tUe(i,s,u,d,p,v){let b;return y;function y(R){return R===34||R===39||R===40?(i.enter(d),i.enter(p),i.consume(R),i.exit(p),b=R===40?41:R,T):u(R)}function T(R){return R===b?(i.enter(p),i.consume(R),i.exit(p),i.exit(d),s):(i.enter(v),_(R))}function _(R){return R===b?(i.exit(v),T(b)):R===null?u(R):so(R)?(i.enter("lineEnding"),i.consume(R),i.exit("lineEnding"),Kl(i,_,"linePrefix")):(i.enter("chunkString",{contentType:"string"}),A(R))}function A(R){return R===b||R===null||so(R)?(i.exit("chunkString"),_(R)):(i.consume(R),R===92?P:A)}function P(R){return R===b||R===92?(i.consume(R),A):A(R)}}function LR(i,s){let u;return d;function d(p){return so(p)?(i.enter("lineEnding"),i.consume(p),i.exit("lineEnding"),u=!0,d):Iu(p)?Kl(i,d,u?"linePrefix":"lineSuffix")(p):s(p)}}function HD(i){return i.replace(/[\t\n\r ]+/g," ").replace(/^ | $/g,"").toLowerCase().toUpperCase()}const kJt={name:"definition",tokenize:TJt},EJt={tokenize:CJt,partial:!0};function TJt(i,s,u){const d=this;let p;return v;function v(F){return i.enter("definition"),b(F)}function b(F){return eUe.call(d,i,y,u,"definitionLabel","definitionLabelMarker","definitionLabelString")(F)}function y(F){return p=HD(d.sliceSerialize(d.events[d.events.length-1][1]).slice(1,-1)),F===58?(i.enter("definitionMarker"),i.consume(F),i.exit("definitionMarker"),T):u(F)}function T(F){return z2(F)?LR(i,_)(F):_(F)}function _(F){return ZVe(i,A,u,"definitionDestination","definitionDestinationLiteral","definitionDestinationLiteralMarker","definitionDestinationRaw","definitionDestinationString")(F)}function A(F){return i.attempt(EJt,P,P)(F)}function P(F){return Iu(F)?Kl(i,R,"whitespace")(F):R(F)}function R(F){return F===null||so(F)?(i.exit("definition"),d.parser.defined.push(p),s(F)):u(F)}}function CJt(i,s,u){return d;function d(y){return z2(y)?LR(i,p)(y):u(y)}function p(y){return tUe(i,v,u,"definitionTitle","definitionTitleMarker","definitionTitleString")(y)}function v(y){return Iu(y)?Kl(i,b,"whitespace")(y):b(y)}function b(y){return y===null||so(y)?s(y):u(y)}}const SJt={name:"hardBreakEscape",tokenize:_Jt};function _Jt(i,s,u){return d;function d(v){return i.enter("hardBreakEscape"),i.consume(v),p}function p(v){return so(v)?(i.exit("hardBreakEscape"),s(v)):u(v)}}const AJt={name:"headingAtx",tokenize:MJt,resolve:LJt};function LJt(i,s){let u=i.length-2,d=3,p,v;return i[d][1].type==="whitespace"&&(d+=2),u-2>d&&i[u][1].type==="whitespace"&&(u-=2),i[u][1].type==="atxHeadingSequence"&&(d===u-1||u-4>d&&i[u-2][1].type==="whitespace")&&(u-=d+1===u?2:4),u>d&&(p={type:"atxHeadingText",start:i[d][1].start,end:i[u][1].end},v={type:"chunkText",start:i[d][1].start,end:i[u][1].end,contentType:"text"},t5(i,d,u-d+1,[["enter",p,s],["enter",v,s],["exit",v,s],["exit",p,s]])),i}function MJt(i,s,u){let d=0;return p;function p(A){return i.enter("atxHeading"),v(A)}function v(A){return i.enter("atxHeadingSequence"),b(A)}function b(A){return A===35&&d++<6?(i.consume(A),b):A===null||z2(A)?(i.exit("atxHeadingSequence"),y(A)):u(A)}function y(A){return A===35?(i.enter("atxHeadingSequence"),T(A)):A===null||so(A)?(i.exit("atxHeading"),s(A)):Iu(A)?Kl(i,y,"whitespace")(A):(i.enter("atxHeadingText"),_(A))}function T(A){return A===35?(i.consume(A),T):(i.exit("atxHeadingSequence"),y(A))}function _(A){return A===null||A===35||z2(A)?(i.exit("atxHeadingText"),y(A)):(i.consume(A),_)}}const DJt=["address","article","aside","base","basefont","blockquote","body","caption","center","col","colgroup","dd","details","dialog","dir","div","dl","dt","fieldset","figcaption","figure","footer","form","frame","frameset","h1","h2","h3","h4","h5","h6","head","header","hr","html","iframe","legend","li","link","main","menu","menuitem","nav","noframes","ol","optgroup","option","p","param","search","section","summary","table","tbody","td","tfoot","th","thead","title","tr","track","ul"],nUe=["pre","script","style","textarea"],IJt={name:"htmlFlow",tokenize:BJt,resolveTo:PJt,concrete:!0},OJt={tokenize:RJt,partial:!0},NJt={tokenize:FJt,partial:!0};function PJt(i){let s=i.length;for(;s--&&!(i[s][0]==="enter"&&i[s][1].type==="htmlFlow"););return s>1&&i[s-2][1].type==="linePrefix"&&(i[s][1].start=i[s-2][1].start,i[s+1][1].start=i[s-2][1].start,i.splice(s-2,2)),i}function BJt(i,s,u){const d=this;let p,v,b,y,T;return _;function _(Ne){return A(Ne)}function A(Ne){return i.enter("htmlFlow"),i.enter("htmlFlowData"),i.consume(Ne),P}function P(Ne){return Ne===33?(i.consume(Ne),R):Ne===47?(i.consume(Ne),v=!0,K):Ne===63?(i.consume(Ne),p=3,d.interrupt?s:ke):n5(Ne)?(i.consume(Ne),b=String.fromCharCode(Ne),ee):u(Ne)}function R(Ne){return Ne===45?(i.consume(Ne),p=2,F):Ne===91?(i.consume(Ne),p=5,y=0,j):n5(Ne)?(i.consume(Ne),p=4,d.interrupt?s:ke):u(Ne)}function F(Ne){return Ne===45?(i.consume(Ne),d.interrupt?s:ke):u(Ne)}function j(Ne){const gn="CDATA[";return Ne===gn.charCodeAt(y++)?(i.consume(Ne),y===gn.length?d.interrupt?s:xe:j):u(Ne)}function K(Ne){return n5(Ne)?(i.consume(Ne),b=String.fromCharCode(Ne),ee):u(Ne)}function ee(Ne){if(Ne===null||Ne===47||Ne===62||z2(Ne)){const gn=Ne===47,_t=b.toLowerCase();return!gn&&!v&&nUe.includes(_t)?(p=1,d.interrupt?s(Ne):xe(Ne)):DJt.includes(b.toLowerCase())?(p=6,gn?(i.consume(Ne),ie):d.interrupt?s(Ne):xe(Ne)):(p=7,d.interrupt&&!d.parser.lazy[d.now().line]?u(Ne):v?oe(Ne):pe(Ne))}return Ne===45||H3(Ne)?(i.consume(Ne),b+=String.fromCharCode(Ne),ee):u(Ne)}function ie(Ne){return Ne===62?(i.consume(Ne),d.interrupt?s:xe):u(Ne)}function oe(Ne){return Iu(Ne)?(i.consume(Ne),oe):ge(Ne)}function pe(Ne){return Ne===47?(i.consume(Ne),ge):Ne===58||Ne===95||n5(Ne)?(i.consume(Ne),be):Iu(Ne)?(i.consume(Ne),pe):ge(Ne)}function be(Ne){return Ne===45||Ne===46||Ne===58||Ne===95||H3(Ne)?(i.consume(Ne),be):ae(Ne)}function ae(Ne){return Ne===61?(i.consume(Ne),ne):Iu(Ne)?(i.consume(Ne),ae):pe(Ne)}function ne(Ne){return Ne===null||Ne===60||Ne===61||Ne===62||Ne===96?u(Ne):Ne===34||Ne===39?(i.consume(Ne),T=Ne,se):Iu(Ne)?(i.consume(Ne),ne):de(Ne)}function se(Ne){return Ne===T?(i.consume(Ne),T=null,X):Ne===null||so(Ne)?u(Ne):(i.consume(Ne),se)}function de(Ne){return Ne===null||Ne===34||Ne===39||Ne===47||Ne===60||Ne===61||Ne===62||Ne===96||z2(Ne)?ae(Ne):(i.consume(Ne),de)}function X(Ne){return Ne===47||Ne===62||Iu(Ne)?pe(Ne):u(Ne)}function ge(Ne){return Ne===62?(i.consume(Ne),W):u(Ne)}function W(Ne){return Ne===null||so(Ne)?xe(Ne):Iu(Ne)?(i.consume(Ne),W):u(Ne)}function xe(Ne){return Ne===45&&p===2?(i.consume(Ne),je):Ne===60&&p===1?(i.consume(Ne),Ie):Ne===62&&p===4?(i.consume(Ne),Ke):Ne===63&&p===3?(i.consume(Ne),ke):Ne===93&&p===5?(i.consume(Ne),Ce):so(Ne)&&(p===6||p===7)?(i.exit("htmlFlowData"),i.check(OJt,Ft,U)(Ne)):Ne===null||so(Ne)?(i.exit("htmlFlowData"),U(Ne)):(i.consume(Ne),xe)}function U(Ne){return i.check(NJt,Fe,Ft)(Ne)}function Fe(Ne){return i.enter("lineEnding"),i.consume(Ne),i.exit("lineEnding"),Pe}function Pe(Ne){return Ne===null||so(Ne)?U(Ne):(i.enter("htmlFlowData"),xe(Ne))}function je(Ne){return Ne===45?(i.consume(Ne),ke):xe(Ne)}function Ie(Ne){return Ne===47?(i.consume(Ne),b="",Se):xe(Ne)}function Se(Ne){if(Ne===62){const gn=b.toLowerCase();return nUe.includes(gn)?(i.consume(Ne),Ke):xe(Ne)}return n5(Ne)&&b.length<8?(i.consume(Ne),b+=String.fromCharCode(Ne),Se):xe(Ne)}function Ce(Ne){return Ne===93?(i.consume(Ne),ke):xe(Ne)}function ke(Ne){return Ne===62?(i.consume(Ne),Ke):Ne===45&&p===2?(i.consume(Ne),ke):xe(Ne)}function Ke(Ne){return Ne===null||so(Ne)?(i.exit("htmlFlowData"),Ft(Ne)):(i.consume(Ne),Ke)}function Ft(Ne){return i.exit("htmlFlow"),s(Ne)}}function FJt(i,s,u){const d=this;return p;function p(b){return so(b)?(i.enter("lineEnding"),i.consume(b),i.exit("lineEnding"),v):u(b)}function v(b){return d.parser.lazy[d.now().line]?u(b):s(b)}}function RJt(i,s,u){return d;function d(p){return i.enter("lineEnding"),i.consume(p),i.exit("lineEnding"),i.attempt(YQ,s,u)}}const jJt={name:"htmlText",tokenize:$Jt};function $Jt(i,s,u){const d=this;let p,v,b;return y;function y(ke){return i.enter("htmlText"),i.enter("htmlTextData"),i.consume(ke),T}function T(ke){return ke===33?(i.consume(ke),_):ke===47?(i.consume(ke),ae):ke===63?(i.consume(ke),pe):n5(ke)?(i.consume(ke),de):u(ke)}function _(ke){return ke===45?(i.consume(ke),A):ke===91?(i.consume(ke),v=0,j):n5(ke)?(i.consume(ke),oe):u(ke)}function A(ke){return ke===45?(i.consume(ke),F):u(ke)}function P(ke){return ke===null?u(ke):ke===45?(i.consume(ke),R):so(ke)?(b=P,Ie(ke)):(i.consume(ke),P)}function R(ke){return ke===45?(i.consume(ke),F):P(ke)}function F(ke){return ke===62?je(ke):ke===45?R(ke):P(ke)}function j(ke){const Ke="CDATA[";return ke===Ke.charCodeAt(v++)?(i.consume(ke),v===Ke.length?K:j):u(ke)}function K(ke){return ke===null?u(ke):ke===93?(i.consume(ke),ee):so(ke)?(b=K,Ie(ke)):(i.consume(ke),K)}function ee(ke){return ke===93?(i.consume(ke),ie):K(ke)}function ie(ke){return ke===62?je(ke):ke===93?(i.consume(ke),ie):K(ke)}function oe(ke){return ke===null||ke===62?je(ke):so(ke)?(b=oe,Ie(ke)):(i.consume(ke),oe)}function pe(ke){return ke===null?u(ke):ke===63?(i.consume(ke),be):so(ke)?(b=pe,Ie(ke)):(i.consume(ke),pe)}function be(ke){return ke===62?je(ke):pe(ke)}function ae(ke){return n5(ke)?(i.consume(ke),ne):u(ke)}function ne(ke){return ke===45||H3(ke)?(i.consume(ke),ne):se(ke)}function se(ke){return so(ke)?(b=se,Ie(ke)):Iu(ke)?(i.consume(ke),se):je(ke)}function de(ke){return ke===45||H3(ke)?(i.consume(ke),de):ke===47||ke===62||z2(ke)?X(ke):u(ke)}function X(ke){return ke===47?(i.consume(ke),je):ke===58||ke===95||n5(ke)?(i.consume(ke),ge):so(ke)?(b=X,Ie(ke)):Iu(ke)?(i.consume(ke),X):je(ke)}function ge(ke){return ke===45||ke===46||ke===58||ke===95||H3(ke)?(i.consume(ke),ge):W(ke)}function W(ke){return ke===61?(i.consume(ke),xe):so(ke)?(b=W,Ie(ke)):Iu(ke)?(i.consume(ke),W):X(ke)}function xe(ke){return ke===null||ke===60||ke===61||ke===62||ke===96?u(ke):ke===34||ke===39?(i.consume(ke),p=ke,U):so(ke)?(b=xe,Ie(ke)):Iu(ke)?(i.consume(ke),xe):(i.consume(ke),Fe)}function U(ke){return ke===p?(i.consume(ke),p=void 0,Pe):ke===null?u(ke):so(ke)?(b=U,Ie(ke)):(i.consume(ke),U)}function Fe(ke){return ke===null||ke===34||ke===39||ke===60||ke===61||ke===96?u(ke):ke===47||ke===62||z2(ke)?X(ke):(i.consume(ke),Fe)}function Pe(ke){return ke===47||ke===62||z2(ke)?X(ke):u(ke)}function je(ke){return ke===62?(i.consume(ke),i.exit("htmlTextData"),i.exit("htmlText"),s):u(ke)}function Ie(ke){return i.exit("htmlTextData"),i.enter("lineEnding"),i.consume(ke),i.exit("lineEnding"),Se}function Se(ke){return Iu(ke)?Kl(i,Ce,"linePrefix",d.parser.constructs.disable.null.includes("codeIndented")?void 0:4)(ke):Ce(ke)}function Ce(ke){return i.enter("htmlTextData"),b(ke)}}const Ome={name:"labelEnd",tokenize:GJt,resolveTo:UJt,resolveAll:VJt},zJt={tokenize:KJt},qJt={tokenize:WJt},HJt={tokenize:YJt};function VJt(i){let s=-1;for(;++s=3&&(_===null||so(_))?(i.exit("thematicBreak"),s(_)):u(_)}function T(_){return _===p?(i.consume(_),d++,T):(i.exit("thematicBreakSequence"),Iu(_)?Kl(i,y,"whitespace")(_):y(_))}}const q2={name:"list",tokenize:iZt,continuation:{tokenize:sZt},exit:oZt},nZt={tokenize:cZt,partial:!0},rZt={tokenize:aZt,partial:!0};function iZt(i,s,u){const d=this,p=d.events[d.events.length-1];let v=p&&p[1].type==="linePrefix"?p[2].sliceSerialize(p[1],!0).length:0,b=0;return y;function y(F){const j=d.containerState.type||(F===42||F===43||F===45?"listUnordered":"listOrdered");if(j==="listUnordered"?!d.containerState.marker||F===d.containerState.marker:Ame(F)){if(d.containerState.type||(d.containerState.type=j,i.enter(j,{_container:!0})),j==="listUnordered")return i.enter("listItemPrefix"),F===42||F===45?i.check(XQ,u,_)(F):_(F);if(!d.interrupt||F===49)return i.enter("listItemPrefix"),i.enter("listItemValue"),T(F)}return u(F)}function T(F){return Ame(F)&&++b<10?(i.consume(F),T):(!d.interrupt||b<2)&&(d.containerState.marker?F===d.containerState.marker:F===41||F===46)?(i.exit("listItemValue"),_(F)):u(F)}function _(F){return i.enter("listItemMarker"),i.consume(F),i.exit("listItemMarker"),d.containerState.marker=d.containerState.marker||F,i.check(YQ,d.interrupt?u:A,i.attempt(nZt,R,P))}function A(F){return d.containerState.initialBlankLine=!0,v++,R(F)}function P(F){return Iu(F)?(i.enter("listItemPrefixWhitespace"),i.consume(F),i.exit("listItemPrefixWhitespace"),R):u(F)}function R(F){return d.containerState.size=v+d.sliceSerialize(i.exit("listItemPrefix"),!0).length,s(F)}}function sZt(i,s,u){const d=this;return d.containerState._closeFlow=void 0,i.check(YQ,p,v);function p(y){return d.containerState.furtherBlankLines=d.containerState.furtherBlankLines||d.containerState.initialBlankLine,Kl(i,s,"listItemIndent",d.containerState.size+1)(y)}function v(y){return d.containerState.furtherBlankLines||!Iu(y)?(d.containerState.furtherBlankLines=void 0,d.containerState.initialBlankLine=void 0,b(y)):(d.containerState.furtherBlankLines=void 0,d.containerState.initialBlankLine=void 0,i.attempt(rZt,s,b)(y))}function b(y){return d.containerState._closeFlow=!0,d.interrupt=void 0,Kl(i,i.attempt(q2,s,u),"linePrefix",d.parser.constructs.disable.null.includes("codeIndented")?void 0:4)(y)}}function aZt(i,s,u){const d=this;return Kl(i,p,"listItemIndent",d.containerState.size+1);function p(v){const b=d.events[d.events.length-1];return b&&b[1].type==="listItemIndent"&&b[2].sliceSerialize(b[1],!0).length===d.containerState.size?s(v):u(v)}}function oZt(i){i.exit(this.containerState.type)}function cZt(i,s,u){const d=this;return Kl(i,p,"listItemPrefixWhitespace",d.parser.constructs.disable.null.includes("codeIndented")?void 0:4+1);function p(v){const b=d.events[d.events.length-1];return!Iu(v)&&b&&b[1].type==="listItemPrefixWhitespace"?s(v):u(v)}}const rUe={name:"setextUnderline",tokenize:lZt,resolveTo:uZt};function uZt(i,s){let u=i.length,d,p,v;for(;u--;)if(i[u][0]==="enter"){if(i[u][1].type==="content"){d=u;break}i[u][1].type==="paragraph"&&(p=u)}else i[u][1].type==="content"&&i.splice(u,1),!v&&i[u][1].type==="definition"&&(v=u);const b={type:"setextHeading",start:Object.assign({},i[p][1].start),end:Object.assign({},i[i.length-1][1].end)};return i[p][1].type="setextHeadingText",v?(i.splice(p,0,["enter",b,s]),i.splice(v+1,0,["exit",i[d][1],s]),i[d][1].end=Object.assign({},i[v][1].end)):i[d][1]=b,i.push(["exit",b,s]),i}function lZt(i,s,u){const d=this;let p;return v;function v(_){let A=d.events.length,P;for(;A--;)if(d.events[A][1].type!=="lineEnding"&&d.events[A][1].type!=="linePrefix"&&d.events[A][1].type!=="content"){P=d.events[A][1].type==="paragraph";break}return!d.parser.lazy[d.now().line]&&(d.interrupt||P)?(i.enter("setextHeadingLine"),p=_,b(_)):u(_)}function b(_){return i.enter("setextHeadingLineSequence"),y(_)}function y(_){return _===p?(i.consume(_),y):(i.exit("setextHeadingLineSequence"),Iu(_)?Kl(i,T,"lineSuffix")(_):T(_))}function T(_){return _===null||so(_)?(i.exit("setextHeadingLine"),s(_)):u(_)}}const hZt={tokenize:fZt};function fZt(i){const s=this,u=i.attempt(YQ,d,i.attempt(this.parser.constructs.flowInitial,p,Kl(i,i.attempt(this.parser.constructs.flow,p,i.attempt(mJt,p)),"linePrefix")));return u;function d(v){if(v===null){i.consume(v);return}return i.enter("lineEndingBlank"),i.consume(v),i.exit("lineEndingBlank"),s.currentConstruct=void 0,u}function p(v){if(v===null){i.consume(v);return}return i.enter("lineEnding"),i.consume(v),i.exit("lineEnding"),s.currentConstruct=void 0,u}}const dZt={resolveAll:sUe()},gZt=iUe("string"),pZt=iUe("text");function iUe(i){return{tokenize:s,resolveAll:sUe(i==="text"?bZt:void 0)};function s(u){const d=this,p=this.parser.constructs[i],v=u.attempt(p,b,y);return b;function b(A){return _(A)?v(A):y(A)}function y(A){if(A===null){u.consume(A);return}return u.enter("data"),u.consume(A),T}function T(A){return _(A)?(u.exit("data"),v(A)):(u.consume(A),T)}function _(A){if(A===null)return!0;const P=p[A];let R=-1;if(P)for(;++R-1){const y=b[0];typeof y=="string"?b[0]=y.slice(d):b.shift()}v>0&&b.push(i[p].slice(0,v))}return b}function wZt(i,s){let u=-1;const d=[];let p;for(;++u13&&u<32||u>126&&u<160||u>55295&&u<57344||u>64975&&u<65008||(u&65535)===65535||(u&65535)===65534||u>1114111?"�":String.fromCharCode(u)}const TZt=/\\([!-/:-@[-`{-~])|&(#(?:\d{1,7}|x[\da-f]{1,6})|[\da-z]{1,31});/gi;function CZt(i){return i.replace(TZt,SZt)}function SZt(i,s,u){if(s)return s;if(u.charCodeAt(0)===35){const p=u.charCodeAt(1),v=p===120||p===88;return oUe(u.slice(v?2:1),v?16:10)}return Dme(u)||i}function QQ(i){return!i||typeof i!="object"?"":"position"in i||"type"in i?cUe(i.position):"start"in i||"end"in i?cUe(i):"line"in i||"column"in i?Pme(i):""}function Pme(i){return uUe(i&&i.line)+":"+uUe(i&&i.column)}function cUe(i){return Pme(i&&i.start)+"-"+Pme(i&&i.end)}function uUe(i){return i&&typeof i=="number"?i:1}const lUe={}.hasOwnProperty,hUe=function(i,s,u){return typeof s!="string"&&(u=s,s=void 0),_Zt(u)(EZt(xZt(u).document().write(kZt()(i,s,!0))))};function _Zt(i){const s={transforms:[],canContainEols:["emphasis","fragment","heading","paragraph","strong"],enter:{autolink:y(Ma),autolinkProtocol:W,autolinkEmail:W,atxHeading:y(zr),blockQuote:y(Qe),characterEscape:W,characterReference:W,codeFenced:y(Dt),codeFencedFenceInfo:T,codeFencedFenceMeta:T,codeIndented:y(Dt,T),codeText:y(kt,T),codeTextData:W,data:W,codeFlowValue:W,definition:y(On),definitionDestinationString:T,definitionLabelString:T,definitionTitleString:T,emphasis:y(ht),hardBreakEscape:y(yt),hardBreakTrailing:y(yt),htmlFlow:y(ji,T),htmlFlowData:W,htmlText:y(ji,T),htmlTextData:W,image:y(xi),label:T,link:y(Ma),listItem:y(ao),listItemValue:j,listOrdered:y(zs,F),listUnordered:y(zs),paragraph:y(Tr),reference:_t,referenceString:T,resourceDestinationString:T,resourceTitleString:T,setextHeading:y(zr),strong:y(Fn),thematicBreak:y(Un)},exit:{atxHeading:A(),atxHeadingSequence:se,autolink:A(),autolinkEmail:Pt,autolinkProtocol:xt,blockQuote:A(),characterEscapeValue:xe,characterReferenceMarkerHexadecimal:Gt,characterReferenceMarkerNumeric:Gt,characterReferenceValue:ln,codeFenced:A(oe),codeFencedFence:ie,codeFencedFenceInfo:K,codeFencedFenceMeta:ee,codeFlowValue:xe,codeIndented:A(pe),codeText:A(Ie),codeTextData:xe,data:xe,definition:A(),definitionDestinationString:ne,definitionLabelString:be,definitionTitleString:ae,emphasis:A(),hardBreakEscape:A(Fe),hardBreakTrailing:A(Fe),htmlFlow:A(Pe),htmlFlowData:xe,htmlText:A(je),htmlTextData:xe,image:A(Ce),label:Ke,labelText:ke,lineEnding:U,link:A(Se),listItem:A(),listOrdered:A(),listUnordered:A(),paragraph:A(),referenceString:Et,resourceDestinationString:Ft,resourceTitleString:Ne,resource:gn,setextHeading:A(ge),setextHeadingLineSequence:X,setextHeadingText:de,strong:A(),thematicBreak:A()}};fUe(s,(i||{}).mdastExtensions||[]);const u={};return d;function d(At){let wt={type:"root",children:[]};const on={stack:[wt],tokenStack:[],config:s,enter:_,exit:P,buffer:T,resume:R,setData:v,getData:b},fn=[];let An=-1;for(;++An0){const oo=on.tokenStack[on.tokenStack.length-1];(oo[1]||dUe).call(on,void 0,oo[0])}for(wt.position={start:N9(At.length>0?At[0][1].start:{line:1,column:1,offset:0}),end:N9(At.length>0?At[At.length-2][1].end:{line:1,column:1,offset:0})},An=-1;++An{A!==0&&(p++,d.push([])),_.split(" ").forEach(P=>{P&&d[p].push({content:P,type:y})})}):(b.type==="strong"||b.type==="emphasis")&&b.children.forEach(T=>{v(T,b.type)})}return u.forEach(b=>{b.type==="paragraph"&&b.children.forEach(y=>{v(y)})}),d}function DZt(i){const{children:s}=hUe(i);function u(d){return d.type==="text"?d.value.replace(/\n/g,"
    "):d.type==="strong"?`${d.children.map(u).join("")}`:d.type==="emphasis"?`${d.children.map(u).join("")}`:d.type==="paragraph"?`

    ${d.children.map(u).join("")}

    `:`Unsupported markdown: ${d.type}`}return s.map(u).join("")}function IZt(i){return Intl.Segmenter?[...new Intl.Segmenter().segment(i)].map(s=>s.segment):[...i]}function OZt(i,s){const u=IZt(s.content);return gUe(i,[],u,s.type)}function gUe(i,s,u,d){if(u.length===0)return[{content:s.join(""),type:d},{content:"",type:d}];const[p,...v]=u,b=[...s,p];return i([{content:b.join(""),type:d}])?gUe(i,b,v,d):(s.length===0&&p&&(s.push(p),u.shift()),[{content:s.join(""),type:d},{content:u.join(""),type:d}])}function NZt(i,s){if(i.some(({content:u})=>u.includes(` +`)))throw new Error("splitLineToFitWidth does not support newlines in the line");return Bme(i,s)}function Bme(i,s,u=[],d=[]){if(i.length===0)return d.length>0&&u.push(d),u.length>0?u:[];let p="";i[0].content===" "&&(p=" ",i.shift());const v=i.shift()??{content:" ",type:"normal"},b=[...d];if(p!==""&&b.push({content:p,type:"normal"}),b.push(v),s(b))return Bme(i,s,u,b);if(d.length>0)u.push(d),i.unshift(v);else if(v.content){const[y,T]=OZt(s,v);u.push([y]),T.content&&i.unshift(T)}return Bme(i,s,u)}function PZt(i,s){s&&i.attr("style",s)}function BZt(i,s,u,d,p=!1){const v=i.append("foreignObject"),b=v.append("xhtml:div"),y=s.label,T=s.isNode?"nodeLabel":"edgeLabel";b.html(` + "+y+""),PZt(b,s.labelStyle),b.style("display","table-cell"),b.style("white-space","nowrap"),b.style("max-width",u+"px"),b.attr("xmlns","http://www.w3.org/1999/xhtml"),p&&b.attr("class","labelBkg");let _=b.node().getBoundingClientRect();return _.width===u&&(b.style("display","table"),b.style("white-space","break-spaces"),b.style("width",u+"px"),_=b.node().getBoundingClientRect()),v.style("width",_.width),v.style("height",_.height),v.node()}function Fme(i,s,u){return i.append("tspan").attr("class","text-outer-tspan").attr("x",0).attr("y",s*u-.1+"em").attr("dy",u+"em")}function FZt(i,s,u){const d=i.append("text"),p=Fme(d,1,s);Rme(p,u);const v=p.node().getComputedTextLength();return d.remove(),v}function RZt(i,s,u){var b;const d=i.append("text"),p=Fme(d,1,s);Rme(p,[{content:u,type:"normal"}]);const v=(b=p.node())==null?void 0:b.getBoundingClientRect();return v&&d.remove(),v}function jZt(i,s,u,d=!1){const v=s.append("g"),b=v.insert("rect").attr("class","background"),y=v.append("text").attr("y","-10.1");let T=0;for(const _ of u){const A=R=>FZt(v,1.1,R)<=i,P=A(_)?[_]:NZt(_,A);for(const R of P){const F=Fme(y,T,1.1);Rme(F,R),T++}}if(d){const _=y.node().getBBox(),A=2;return b.attr("x",-A).attr("y",-A).attr("width",_.width+2*A).attr("height",_.height+2*A),v.node()}else return y.node()}function Rme(i,s){i.text(""),s.forEach((u,d)=>{const p=i.append("tspan").attr("font-style",u.type==="emphasis"?"italic":"normal").attr("class","text-inner-tspan").attr("font-weight",u.type==="strong"?"bold":"normal");d===0?p.text(u.content):p.text(" "+u.content)})}const JQ=(i,s="",{style:u="",isTitle:d=!1,classes:p="",useHtmlLabels:v=!0,isNode:b=!0,width:y=200,addSvgBackground:T=!1}={})=>{if(Xe.info("createText",s,u,d,p,v,b,T),v){const _=DZt(s),A={isNode:b,label:ZF(_).replace(/fa[blrs]?:fa-[\w-]+/g,R=>``),labelStyle:u.replace("fill:","color:")};return BZt(i,A,y,p,T)}else{const _=MZt(s);return jZt(y,i,_,T)}},g1=async(i,s,u,d)=>{let p;const v=s.useHtmlLabels||f1(qt().flowchart.htmlLabels);u?p=u:p="node default";const b=i.insert("g").attr("class",p).attr("id",s.domId||s.id),y=b.insert("g").attr("class","label").attr("style",s.labelStyle);let T;s.labelText===void 0?T="":T=typeof s.labelText=="string"?s.labelText:s.labelText[0];const _=y.node();let A;s.labelType==="markdown"?A=JQ(y,Yf(ZF(T),qt()),{useHtmlLabels:v,width:s.width||qt().flowchart.wrappingWidth,classes:"markdown-node-label"}):A=_.appendChild($2(Yf(ZF(T),qt()),s.labelStyle,!1,d));let P=A.getBBox();const R=s.padding/2;if(f1(qt().flowchart.htmlLabels)){const F=A.children[0],j=Ir(A),K=F.getElementsByTagName("img");if(K){const ee=T.replace(/]*>/g,"").trim()==="";await Promise.all([...K].map(ie=>new Promise(oe=>{function pe(){if(ie.style.display="flex",ie.style.flexDirection="column",ee){const be=qt().fontSize?qt().fontSize:window.getComputedStyle(document.body).fontSize,ae=5,ne=parseInt(be,10)*ae+"px";ie.style.minWidth=ne,ie.style.maxWidth=ne}else ie.style.width="100%";oe(ie)}setTimeout(()=>{ie.complete&&pe()}),ie.addEventListener("error",pe),ie.addEventListener("load",pe)})))}P=F.getBoundingClientRect(),j.attr("width",P.width),j.attr("height",P.height)}return v?y.attr("transform","translate("+-P.width/2+", "+-P.height/2+")"):y.attr("transform","translate(0, "+-P.height/2+")"),s.centerLabel&&y.attr("transform","translate("+-P.width/2+", "+-P.height/2+")"),y.insert("rect",":first-child"),{shapeSvg:b,bbox:P,halfPadding:R,label:y}},Kh=(i,s)=>{const u=s.node().getBBox();i.width=u.width,i.height=u.height};function r5(i,s,u,d){return i.insert("polygon",":first-child").attr("points",d.map(function(p){return p.x+","+p.y}).join(" ")).attr("class","label-container").attr("transform","translate("+-s/2+","+u/2+")")}let Mo={},V3={},pUe={};const $Zt=()=>{V3={},pUe={},Mo={}},ZQ=(i,s)=>(Xe.trace("In isDescendant",s," ",i," = ",V3[s].includes(i)),!!V3[s].includes(i)),zZt=(i,s)=>(Xe.info("Descendants of ",s," is ",V3[s]),Xe.info("Edge is ",i),i.v===s||i.w===s?!1:V3[s]?V3[s].includes(i.v)||ZQ(i.v,s)||ZQ(i.w,s)||V3[s].includes(i.w):(Xe.debug("Tilt, ",s,",not in descendants"),!1)),bUe=(i,s,u,d)=>{Xe.warn("Copying children of ",i,"root",d,"data",s.node(i),d);const p=s.children(i)||[];i!==d&&p.push(i),Xe.warn("Copying (nodes) clusterId",i,"nodes",p),p.forEach(v=>{if(s.children(v).length>0)bUe(v,s,u,d);else{const b=s.node(v);Xe.info("cp ",v," to ",d," with parent ",i),u.setNode(v,b),d!==s.parent(v)&&(Xe.warn("Setting parent",v,s.parent(v)),u.setParent(v,s.parent(v))),i!==d&&v!==i?(Xe.debug("Setting parent",v,i),u.setParent(v,i)):(Xe.info("In copy ",i,"root",d,"data",s.node(i),d),Xe.debug("Not Setting parent for node=",v,"cluster!==rootId",i!==d,"node!==clusterId",v!==i));const y=s.edges(v);Xe.debug("Copying Edges",y),y.forEach(T=>{Xe.info("Edge",T);const _=s.edge(T.v,T.w,T.name);Xe.info("Edge data",_,d);try{zZt(T,d)?(Xe.info("Copying as ",T.v,T.w,_,T.name),u.setEdge(T.v,T.w,_,T.name),Xe.info("newGraph edges ",u.edges(),u.edge(u.edges()[0]))):Xe.info("Skipping copy of edge ",T.v,"-->",T.w," rootId: ",d," clusterId:",i)}catch(A){Xe.error(A)}})}Xe.debug("Removing node",v),s.removeNode(v)})},mUe=(i,s)=>{const u=s.children(i);let d=[...u];for(const p of u)pUe[p]=i,d=[...d,...mUe(p,s)];return d},MR=(i,s)=>{Xe.trace("Searching",i);const u=s.children(i);if(Xe.trace("Searching children of id ",i,u),u.length<1)return Xe.trace("This is a valid node",i),i;for(const d of u){const p=MR(d,s);if(p)return Xe.trace("Found replacement for",i," => ",p),p}},eJ=i=>!Mo[i]||!Mo[i].externalConnections?i:Mo[i]?Mo[i].id:i,qZt=(i,s)=>{if(!i||s>10){Xe.debug("Opting out, no graph ");return}else Xe.debug("Opting in, graph ");i.nodes().forEach(function(u){i.children(u).length>0&&(Xe.warn("Cluster identified",u," Replacement id in edges: ",MR(u,i)),V3[u]=mUe(u,i),Mo[u]={id:MR(u,i),clusterData:i.node(u)})}),i.nodes().forEach(function(u){const d=i.children(u),p=i.edges();d.length>0?(Xe.debug("Cluster identified",u,V3),p.forEach(v=>{if(v.v!==u&&v.w!==u){const b=ZQ(v.v,u),y=ZQ(v.w,u);b^y&&(Xe.warn("Edge: ",v," leaves cluster ",u),Xe.warn("Descendants of XXX ",u,": ",V3[u]),Mo[u].externalConnections=!0)}})):Xe.debug("Not a cluster ",u,V3)});for(let u of Object.keys(Mo)){const d=Mo[u].id,p=i.parent(d);p!==u&&Mo[p]&&!Mo[p].externalConnections&&(Mo[u].id=p)}i.edges().forEach(function(u){const d=i.edge(u);Xe.warn("Edge "+u.v+" -> "+u.w+": "+JSON.stringify(u)),Xe.warn("Edge "+u.v+" -> "+u.w+": "+JSON.stringify(i.edge(u)));let p=u.v,v=u.w;if(Xe.warn("Fix XXX",Mo,"ids:",u.v,u.w,"Translating: ",Mo[u.v]," --- ",Mo[u.w]),Mo[u.v]&&Mo[u.w]&&Mo[u.v]===Mo[u.w]){Xe.warn("Fixing and trixing link to self - removing XXX",u.v,u.w,u.name),Xe.warn("Fixing and trixing - removing XXX",u.v,u.w,u.name),p=eJ(u.v),v=eJ(u.w),i.removeEdge(u.v,u.w,u.name);const b=u.w+"---"+u.v;i.setNode(b,{domId:b,id:b,labelStyle:"",labelText:d.label,padding:0,shape:"labelRect",style:""});const y=structuredClone(d),T=structuredClone(d);y.label="",y.arrowTypeEnd="none",T.label="",y.fromCluster=u.v,T.toCluster=u.v,i.setEdge(p,b,y,u.name+"-cyclic-special"),i.setEdge(b,v,T,u.name+"-cyclic-special")}else if(Mo[u.v]||Mo[u.w]){if(Xe.warn("Fixing and trixing - removing XXX",u.v,u.w,u.name),p=eJ(u.v),v=eJ(u.w),i.removeEdge(u.v,u.w,u.name),p!==u.v){const b=i.parent(p);Mo[b].externalConnections=!0,d.fromCluster=u.v}if(v!==u.w){const b=i.parent(v);Mo[b].externalConnections=!0,d.toCluster=u.w}Xe.warn("Fix Replacing with XXX",p,v,u.name),i.setEdge(p,v,d,u.name)}}),Xe.warn("Adjusted Graph",q7(i)),vUe(i,0),Xe.trace(Mo)},vUe=(i,s)=>{if(Xe.warn("extractor - ",s,q7(i),i.children("D")),s>10){Xe.error("Bailing out");return}let u=i.nodes(),d=!1;for(const p of u){const v=i.children(p);d=d||v.length>0}if(!d){Xe.debug("Done, no node has children",i.nodes());return}Xe.debug("Nodes = ",u,s);for(const p of u)if(Xe.debug("Extracting node",p,Mo,Mo[p]&&!Mo[p].externalConnections,!i.parent(p),i.node(p),i.children("D")," Depth ",s),!Mo[p])Xe.debug("Not a cluster",p,s);else if(!Mo[p].externalConnections&&i.children(p)&&i.children(p).length>0){Xe.warn("Cluster without external connections, without a parent and with children",p,s);let b=i.graph().rankdir==="TB"?"LR":"TB";Mo[p]&&Mo[p].clusterData&&Mo[p].clusterData.dir&&(b=Mo[p].clusterData.dir,Xe.warn("Fixing dir",Mo[p].clusterData.dir,b));const y=new B0({multigraph:!0,compound:!0}).setGraph({rankdir:b,nodesep:50,ranksep:50,marginx:8,marginy:8}).setDefaultEdgeLabel(function(){return{}});Xe.warn("Old graph before copy",q7(i)),bUe(p,i,y,p),i.setNode(p,{clusterNode:!0,id:p,clusterData:Mo[p].clusterData,labelText:Mo[p].labelText,graph:y}),Xe.warn("New graph after copy node: (",p,")",q7(y)),Xe.debug("Old graph after copy",q7(i))}else Xe.warn("Cluster ** ",p," **not meeting the criteria !externalConnections:",!Mo[p].externalConnections," no parent: ",!i.parent(p)," children ",i.children(p)&&i.children(p).length>0,i.children("D"),s),Xe.debug(Mo);u=i.nodes(),Xe.warn("New list of nodes",u);for(const p of u){const v=i.node(p);Xe.warn(" Now next level",p,v),v.clusterNode&&vUe(v.graph,s+1)}},wUe=(i,s)=>{if(s.length===0)return[];let u=Object.assign(s);return s.forEach(d=>{const p=i.children(d),v=wUe(i,p);u=[...u,...v]}),u},HZt=i=>wUe(i,i.children());function VZt(i,s){return i.intersect(s)}function yUe(i,s,u,d){var p=i.x,v=i.y,b=p-d.x,y=v-d.y,T=Math.sqrt(s*s*y*y+u*u*b*b),_=Math.abs(s*u*b/T);d.x0}function KZt(i,s,u){var d=i.x,p=i.y,v=[],b=Number.POSITIVE_INFINITY,y=Number.POSITIVE_INFINITY;typeof s.forEach=="function"?s.forEach(function(j){b=Math.min(b,j.x),y=Math.min(y,j.y)}):(b=Math.min(b,s.x),y=Math.min(y,s.y));for(var T=d-i.width/2-b,_=p-i.height/2-y,A=0;A1&&v.sort(function(j,K){var ee=j.x-u.x,ie=j.y-u.y,oe=Math.sqrt(ee*ee+ie*ie),pe=K.x-u.x,be=K.y-u.y,ae=Math.sqrt(pe*pe+be*be);return oe{var u=i.x,d=i.y,p=s.x-u,v=s.y-d,b=i.width/2,y=i.height/2,T,_;return Math.abs(v)*b>Math.abs(p)*y?(v<0&&(y=-y),T=v===0?0:y*p/v,_=y):(p<0&&(b=-b),T=b,_=p===0?0:b*v/p),{x:u+T,y:d+_}},yh={node:VZt,circle:UZt,ellipse:yUe,polygon:KZt,rect:DR},WZt=async(i,s)=>{s.useHtmlLabels||qt().flowchart.htmlLabels||(s.centerLabel=!0);const{shapeSvg:d,bbox:p,halfPadding:v}=await g1(i,s,"node "+s.classes,!0);Xe.info("Classes = ",s.classes);const b=d.insert("rect",":first-child");return b.attr("rx",s.rx).attr("ry",s.ry).attr("x",-p.width/2-v).attr("y",-p.height/2-v).attr("width",p.width+s.padding).attr("height",p.height+s.padding),Kh(s,b),s.intersect=function(y){return yh.rect(s,y)},d},YZt=i=>{const s=new Set;for(const u of i)switch(u){case"x":s.add("right"),s.add("left");break;case"y":s.add("up"),s.add("down");break;default:s.add(u);break}return s},XZt=(i,s,u)=>{const d=YZt(i),p=2,v=s.height+2*u.padding,b=v/p,y=s.width+2*b+u.padding,T=u.padding/2;return d.has("right")&&d.has("left")&&d.has("up")&&d.has("down")?[{x:0,y:0},{x:b,y:0},{x:y/2,y:2*T},{x:y-b,y:0},{x:y,y:0},{x:y,y:-v/3},{x:y+2*T,y:-v/2},{x:y,y:-2*v/3},{x:y,y:-v},{x:y-b,y:-v},{x:y/2,y:-v-2*T},{x:b,y:-v},{x:0,y:-v},{x:0,y:-2*v/3},{x:-2*T,y:-v/2},{x:0,y:-v/3}]:d.has("right")&&d.has("left")&&d.has("up")?[{x:b,y:0},{x:y-b,y:0},{x:y,y:-v/2},{x:y-b,y:-v},{x:b,y:-v},{x:0,y:-v/2}]:d.has("right")&&d.has("left")&&d.has("down")?[{x:0,y:0},{x:b,y:-v},{x:y-b,y:-v},{x:y,y:0}]:d.has("right")&&d.has("up")&&d.has("down")?[{x:0,y:0},{x:y,y:-b},{x:y,y:-v+b},{x:0,y:-v}]:d.has("left")&&d.has("up")&&d.has("down")?[{x:y,y:0},{x:0,y:-b},{x:0,y:-v+b},{x:y,y:-v}]:d.has("right")&&d.has("left")?[{x:b,y:0},{x:b,y:-T},{x:y-b,y:-T},{x:y-b,y:0},{x:y,y:-v/2},{x:y-b,y:-v},{x:y-b,y:-v+T},{x:b,y:-v+T},{x:b,y:-v},{x:0,y:-v/2}]:d.has("up")&&d.has("down")?[{x:y/2,y:0},{x:0,y:-T},{x:b,y:-T},{x:b,y:-v+T},{x:0,y:-v+T},{x:y/2,y:-v},{x:y,y:-v+T},{x:y-b,y:-v+T},{x:y-b,y:-T},{x:y,y:-T}]:d.has("right")&&d.has("up")?[{x:0,y:0},{x:y,y:-b},{x:0,y:-v}]:d.has("right")&&d.has("down")?[{x:0,y:0},{x:y,y:0},{x:0,y:-v}]:d.has("left")&&d.has("up")?[{x:y,y:0},{x:0,y:-b},{x:y,y:-v}]:d.has("left")&&d.has("down")?[{x:y,y:0},{x:0,y:0},{x:y,y:-v}]:d.has("right")?[{x:b,y:-T},{x:b,y:-T},{x:y-b,y:-T},{x:y-b,y:0},{x:y,y:-v/2},{x:y-b,y:-v},{x:y-b,y:-v+T},{x:b,y:-v+T},{x:b,y:-v+T}]:d.has("left")?[{x:b,y:0},{x:b,y:-T},{x:y-b,y:-T},{x:y-b,y:-v+T},{x:b,y:-v+T},{x:b,y:-v},{x:0,y:-v/2}]:d.has("up")?[{x:b,y:-T},{x:b,y:-v+T},{x:0,y:-v+T},{x:y/2,y:-v},{x:y,y:-v+T},{x:y-b,y:-v+T},{x:y-b,y:-T}]:d.has("down")?[{x:y/2,y:0},{x:0,y:-T},{x:b,y:-T},{x:b,y:-v+T},{x:y-b,y:-v+T},{x:y-b,y:-T},{x:y,y:-T}]:[{x:0,y:0}]},kUe=i=>i?" "+i:"",dm=(i,s)=>`${s||"node default"}${kUe(i.classes)} ${kUe(i.class)}`,EUe=async(i,s)=>{const{shapeSvg:u,bbox:d}=await g1(i,s,dm(s,void 0),!0),p=d.width+s.padding,v=d.height+s.padding,b=p+v,y=[{x:b/2,y:0},{x:b,y:-b/2},{x:b/2,y:-b},{x:0,y:-b/2}];Xe.info("Question main (Circle)");const T=r5(u,b,b,y);return T.attr("style",s.style),Kh(s,T),s.intersect=function(_){return Xe.warn("Intersect called"),yh.polygon(s,y,_)},u},QZt=(i,s)=>{const u=i.insert("g").attr("class","node default").attr("id",s.domId||s.id),d=28,p=[{x:0,y:d/2},{x:d/2,y:0},{x:0,y:-d/2},{x:-d/2,y:0}];return u.insert("polygon",":first-child").attr("points",p.map(function(b){return b.x+","+b.y}).join(" ")).attr("class","state-start").attr("r",7).attr("width",28).attr("height",28),s.width=28,s.height=28,s.intersect=function(b){return yh.circle(s,14,b)},u},JZt=async(i,s)=>{const{shapeSvg:u,bbox:d}=await g1(i,s,dm(s,void 0),!0),p=4,v=d.height+s.padding,b=v/p,y=d.width+2*b+s.padding,T=[{x:b,y:0},{x:y-b,y:0},{x:y,y:-v/2},{x:y-b,y:-v},{x:b,y:-v},{x:0,y:-v/2}],_=r5(u,y,v,T);return _.attr("style",s.style),Kh(s,_),s.intersect=function(A){return yh.polygon(s,T,A)},u},ZZt=async(i,s)=>{const{shapeSvg:u,bbox:d}=await g1(i,s,void 0,!0),p=2,v=d.height+2*s.padding,b=v/p,y=d.width+2*b+s.padding,T=XZt(s.directions,d,s),_=r5(u,y,v,T);return _.attr("style",s.style),Kh(s,_),s.intersect=function(A){return yh.polygon(s,T,A)},u},een=async(i,s)=>{const{shapeSvg:u,bbox:d}=await g1(i,s,dm(s,void 0),!0),p=d.width+s.padding,v=d.height+s.padding,b=[{x:-v/2,y:0},{x:p,y:0},{x:p,y:-v},{x:-v/2,y:-v},{x:0,y:-v/2}];return r5(u,p,v,b).attr("style",s.style),s.width=p+v,s.height=v,s.intersect=function(T){return yh.polygon(s,b,T)},u},ten=async(i,s)=>{const{shapeSvg:u,bbox:d}=await g1(i,s,dm(s),!0),p=d.width+s.padding,v=d.height+s.padding,b=[{x:-2*v/6,y:0},{x:p-v/6,y:0},{x:p+2*v/6,y:-v},{x:v/6,y:-v}],y=r5(u,p,v,b);return y.attr("style",s.style),Kh(s,y),s.intersect=function(T){return yh.polygon(s,b,T)},u},nen=async(i,s)=>{const{shapeSvg:u,bbox:d}=await g1(i,s,dm(s,void 0),!0),p=d.width+s.padding,v=d.height+s.padding,b=[{x:2*v/6,y:0},{x:p+v/6,y:0},{x:p-2*v/6,y:-v},{x:-v/6,y:-v}],y=r5(u,p,v,b);return y.attr("style",s.style),Kh(s,y),s.intersect=function(T){return yh.polygon(s,b,T)},u},ren=async(i,s)=>{const{shapeSvg:u,bbox:d}=await g1(i,s,dm(s,void 0),!0),p=d.width+s.padding,v=d.height+s.padding,b=[{x:-2*v/6,y:0},{x:p+2*v/6,y:0},{x:p-v/6,y:-v},{x:v/6,y:-v}],y=r5(u,p,v,b);return y.attr("style",s.style),Kh(s,y),s.intersect=function(T){return yh.polygon(s,b,T)},u},ien=async(i,s)=>{const{shapeSvg:u,bbox:d}=await g1(i,s,dm(s,void 0),!0),p=d.width+s.padding,v=d.height+s.padding,b=[{x:v/6,y:0},{x:p-v/6,y:0},{x:p+2*v/6,y:-v},{x:-2*v/6,y:-v}],y=r5(u,p,v,b);return y.attr("style",s.style),Kh(s,y),s.intersect=function(T){return yh.polygon(s,b,T)},u},sen=async(i,s)=>{const{shapeSvg:u,bbox:d}=await g1(i,s,dm(s,void 0),!0),p=d.width+s.padding,v=d.height+s.padding,b=[{x:0,y:0},{x:p+v/2,y:0},{x:p,y:-v/2},{x:p+v/2,y:-v},{x:0,y:-v}],y=r5(u,p,v,b);return y.attr("style",s.style),Kh(s,y),s.intersect=function(T){return yh.polygon(s,b,T)},u},aen=async(i,s)=>{const{shapeSvg:u,bbox:d}=await g1(i,s,dm(s,void 0),!0),p=d.width+s.padding,v=p/2,b=v/(2.5+p/50),y=d.height+b+s.padding,T="M 0,"+b+" a "+v+","+b+" 0,0,0 "+p+" 0 a "+v+","+b+" 0,0,0 "+-p+" 0 l 0,"+y+" a "+v+","+b+" 0,0,0 "+p+" 0 l 0,"+-y,_=u.attr("label-offset-y",b).insert("path",":first-child").attr("style",s.style).attr("d",T).attr("transform","translate("+-p/2+","+-(y/2+b)+")");return Kh(s,_),s.intersect=function(A){const P=yh.rect(s,A),R=P.x-s.x;if(v!=0&&(Math.abs(R)s.height/2-b)){let F=b*b*(1-R*R/(v*v));F!=0&&(F=Math.sqrt(F)),F=b-F,A.y-s.y>0&&(F=-F),P.y+=F}return P},u},oen=async(i,s)=>{const{shapeSvg:u,bbox:d,halfPadding:p}=await g1(i,s,"node "+s.classes+" "+s.class,!0),v=u.insert("rect",":first-child"),b=s.positioned?s.width:d.width+s.padding,y=s.positioned?s.height:d.height+s.padding,T=s.positioned?-b/2:-d.width/2-p,_=s.positioned?-y/2:-d.height/2-p;if(v.attr("class","basic label-container").attr("style",s.style).attr("rx",s.rx).attr("ry",s.ry).attr("x",T).attr("y",_).attr("width",b).attr("height",y),s.props){const A=new Set(Object.keys(s.props));s.props.borders&&(jme(v,s.props.borders,b,y),A.delete("borders")),A.forEach(P=>{Xe.warn(`Unknown node property ${P}`)})}return Kh(s,v),s.intersect=function(A){return yh.rect(s,A)},u},cen=async(i,s)=>{const{shapeSvg:u,bbox:d,halfPadding:p}=await g1(i,s,"node "+s.classes,!0),v=u.insert("rect",":first-child"),b=s.positioned?s.width:d.width+s.padding,y=s.positioned?s.height:d.height+s.padding,T=s.positioned?-b/2:-d.width/2-p,_=s.positioned?-y/2:-d.height/2-p;if(v.attr("class","basic cluster composite label-container").attr("style",s.style).attr("rx",s.rx).attr("ry",s.ry).attr("x",T).attr("y",_).attr("width",b).attr("height",y),s.props){const A=new Set(Object.keys(s.props));s.props.borders&&(jme(v,s.props.borders,b,y),A.delete("borders")),A.forEach(P=>{Xe.warn(`Unknown node property ${P}`)})}return Kh(s,v),s.intersect=function(A){return yh.rect(s,A)},u},uen=async(i,s)=>{const{shapeSvg:u}=await g1(i,s,"label",!0);Xe.trace("Classes = ",s.class);const d=u.insert("rect",":first-child"),p=0,v=0;if(d.attr("width",p).attr("height",v),u.attr("class","label edgeLabel"),s.props){const b=new Set(Object.keys(s.props));s.props.borders&&(jme(d,s.props.borders,p,v),b.delete("borders")),b.forEach(y=>{Xe.warn(`Unknown node property ${y}`)})}return Kh(s,d),s.intersect=function(b){return yh.rect(s,b)},u};function jme(i,s,u,d){const p=[],v=y=>{p.push(y,0)},b=y=>{p.push(0,y)};s.includes("t")?(Xe.debug("add top border"),v(u)):b(u),s.includes("r")?(Xe.debug("add right border"),v(d)):b(d),s.includes("b")?(Xe.debug("add bottom border"),v(u)):b(u),s.includes("l")?(Xe.debug("add left border"),v(d)):b(d),i.attr("stroke-dasharray",p.join(" "))}const len=(i,s)=>{let u;s.classes?u="node "+s.classes:u="node default";const d=i.insert("g").attr("class",u).attr("id",s.domId||s.id),p=d.insert("rect",":first-child"),v=d.insert("line"),b=d.insert("g").attr("class","label"),y=s.labelText.flat?s.labelText.flat():s.labelText;let T="";typeof y=="object"?T=y[0]:T=y,Xe.info("Label text abc79",T,y,typeof y=="object");const _=b.node().appendChild($2(T,s.labelStyle,!0,!0));let A={width:0,height:0};if(f1(qt().flowchart.htmlLabels)){const K=_.children[0],ee=Ir(_);A=K.getBoundingClientRect(),ee.attr("width",A.width),ee.attr("height",A.height)}Xe.info("Text 2",y);const P=y.slice(1,y.length);let R=_.getBBox();const F=b.node().appendChild($2(P.join?P.join("
    "):P,s.labelStyle,!0,!0));if(f1(qt().flowchart.htmlLabels)){const K=F.children[0],ee=Ir(F);A=K.getBoundingClientRect(),ee.attr("width",A.width),ee.attr("height",A.height)}const j=s.padding/2;return Ir(F).attr("transform","translate( "+(A.width>R.width?0:(R.width-A.width)/2)+", "+(R.height+j+5)+")"),Ir(_).attr("transform","translate( "+(A.width{const{shapeSvg:u,bbox:d}=await g1(i,s,dm(s,void 0),!0),p=d.height+s.padding,v=d.width+p/4+s.padding,b=u.insert("rect",":first-child").attr("style",s.style).attr("rx",p/2).attr("ry",p/2).attr("x",-v/2).attr("y",-p/2).attr("width",v).attr("height",p);return Kh(s,b),s.intersect=function(y){return yh.rect(s,y)},u},fen=async(i,s)=>{const{shapeSvg:u,bbox:d,halfPadding:p}=await g1(i,s,dm(s,void 0),!0),v=u.insert("circle",":first-child");return v.attr("style",s.style).attr("rx",s.rx).attr("ry",s.ry).attr("r",d.width/2+p).attr("width",d.width+s.padding).attr("height",d.height+s.padding),Xe.info("Circle main"),Kh(s,v),s.intersect=function(b){return Xe.info("Circle intersect",s,d.width/2+p,b),yh.circle(s,d.width/2+p,b)},u},den=async(i,s)=>{const{shapeSvg:u,bbox:d,halfPadding:p}=await g1(i,s,dm(s,void 0),!0),v=5,b=u.insert("g",":first-child"),y=b.insert("circle"),T=b.insert("circle");return b.attr("class",s.class),y.attr("style",s.style).attr("rx",s.rx).attr("ry",s.ry).attr("r",d.width/2+p+v).attr("width",d.width+s.padding+v*2).attr("height",d.height+s.padding+v*2),T.attr("style",s.style).attr("rx",s.rx).attr("ry",s.ry).attr("r",d.width/2+p).attr("width",d.width+s.padding).attr("height",d.height+s.padding),Xe.info("DoubleCircle main"),Kh(s,y),s.intersect=function(_){return Xe.info("DoubleCircle intersect",s,d.width/2+p+v,_),yh.circle(s,d.width/2+p+v,_)},u},gen=async(i,s)=>{const{shapeSvg:u,bbox:d}=await g1(i,s,dm(s,void 0),!0),p=d.width+s.padding,v=d.height+s.padding,b=[{x:0,y:0},{x:p,y:0},{x:p,y:-v},{x:0,y:-v},{x:0,y:0},{x:-8,y:0},{x:p+8,y:0},{x:p+8,y:-v},{x:-8,y:-v},{x:-8,y:0}],y=r5(u,p,v,b);return y.attr("style",s.style),Kh(s,y),s.intersect=function(T){return yh.polygon(s,b,T)},u},pen=(i,s)=>{const u=i.insert("g").attr("class","node default").attr("id",s.domId||s.id),d=u.insert("circle",":first-child");return d.attr("class","state-start").attr("r",7).attr("width",14).attr("height",14),Kh(s,d),s.intersect=function(p){return yh.circle(s,7,p)},u},TUe=(i,s,u)=>{const d=i.insert("g").attr("class","node default").attr("id",s.domId||s.id);let p=70,v=10;u==="LR"&&(p=10,v=70);const b=d.append("rect").attr("x",-1*p/2).attr("y",-1*v/2).attr("width",p).attr("height",v).attr("class","fork-join");return Kh(s,b),s.height=s.height+s.padding/2,s.width=s.width+s.padding/2,s.intersect=function(y){return yh.rect(s,y)},d},CUe={rhombus:EUe,composite:cen,question:EUe,rect:oen,labelRect:uen,rectWithTitle:len,choice:QZt,circle:fen,doublecircle:den,stadium:hen,hexagon:JZt,block_arrow:ZZt,rect_left_inv_arrow:een,lean_right:ten,lean_left:nen,trapezoid:ren,inv_trapezoid:ien,rect_right_inv_arrow:sen,cylinder:aen,start:pen,end:(i,s)=>{const u=i.insert("g").attr("class","node default").attr("id",s.domId||s.id),d=u.insert("circle",":first-child"),p=u.insert("circle",":first-child");return p.attr("class","state-start").attr("r",7).attr("width",14).attr("height",14),d.attr("class","state-end").attr("r",5).attr("width",10).attr("height",10),Kh(s,p),s.intersect=function(v){return yh.circle(s,7,v)},u},note:WZt,subroutine:gen,fork:TUe,join:TUe,class_box:(i,s)=>{const u=s.padding/2,d=4,p=8;let v;s.classes?v="node "+s.classes:v="node default";const b=i.insert("g").attr("class",v).attr("id",s.domId||s.id),y=b.insert("rect",":first-child"),T=b.insert("line"),_=b.insert("line");let A=0,P=d;const R=b.insert("g").attr("class","label");let F=0;const j=s.classData.annotations&&s.classData.annotations[0],K=s.classData.annotations[0]?"«"+s.classData.annotations[0]+"»":"",ee=R.node().appendChild($2(K,s.labelStyle,!0,!0));let ie=ee.getBBox();if(f1(qt().flowchart.htmlLabels)){const de=ee.children[0],X=Ir(ee);ie=de.getBoundingClientRect(),X.attr("width",ie.width),X.attr("height",ie.height)}s.classData.annotations[0]&&(P+=ie.height+d,A+=ie.width);let oe=s.classData.label;s.classData.type!==void 0&&s.classData.type!==""&&(qt().flowchart.htmlLabels?oe+="<"+s.classData.type+">":oe+="<"+s.classData.type+">");const pe=R.node().appendChild($2(oe,s.labelStyle,!0,!0));Ir(pe).attr("class","classTitle");let be=pe.getBBox();if(f1(qt().flowchart.htmlLabels)){const de=pe.children[0],X=Ir(pe);be=de.getBoundingClientRect(),X.attr("width",be.width),X.attr("height",be.height)}P+=be.height+d,be.width>A&&(A=be.width);const ae=[];s.classData.members.forEach(de=>{const X=de.getDisplayDetails();let ge=X.displayText;qt().flowchart.htmlLabels&&(ge=ge.replace(//g,">"));const W=R.node().appendChild($2(ge,X.cssStyle?X.cssStyle:s.labelStyle,!0,!0));let xe=W.getBBox();if(f1(qt().flowchart.htmlLabels)){const U=W.children[0],Fe=Ir(W);xe=U.getBoundingClientRect(),Fe.attr("width",xe.width),Fe.attr("height",xe.height)}xe.width>A&&(A=xe.width),P+=xe.height+d,ae.push(W)}),P+=p;const ne=[];if(s.classData.methods.forEach(de=>{const X=de.getDisplayDetails();let ge=X.displayText;qt().flowchart.htmlLabels&&(ge=ge.replace(//g,">"));const W=R.node().appendChild($2(ge,X.cssStyle?X.cssStyle:s.labelStyle,!0,!0));let xe=W.getBBox();if(f1(qt().flowchart.htmlLabels)){const U=W.children[0],Fe=Ir(W);xe=U.getBoundingClientRect(),Fe.attr("width",xe.width),Fe.attr("height",xe.height)}xe.width>A&&(A=xe.width),P+=xe.height+d,ne.push(W)}),P+=p,j){let de=(A-ie.width)/2;Ir(ee).attr("transform","translate( "+(-1*A/2+de)+", "+-1*P/2+")"),F=ie.height+d}let se=(A-be.width)/2;return Ir(pe).attr("transform","translate( "+(-1*A/2+se)+", "+(-1*P/2+F)+")"),F+=be.height+d,T.attr("class","divider").attr("x1",-A/2-u).attr("x2",A/2+u).attr("y1",-P/2-u+p+F).attr("y2",-P/2-u+p+F),F+=p,ae.forEach(de=>{Ir(de).attr("transform","translate( "+-A/2+", "+(-1*P/2+F+p/2)+")");const X=de==null?void 0:de.getBBox();F+=((X==null?void 0:X.height)??0)+d}),F+=p,_.attr("class","divider").attr("x1",-A/2-u).attr("x2",A/2+u).attr("y1",-P/2-u+p+F).attr("y2",-P/2-u+p+F),F+=p,ne.forEach(de=>{Ir(de).attr("transform","translate( "+-A/2+", "+(-1*P/2+F)+")");const X=de==null?void 0:de.getBBox();F+=((X==null?void 0:X.height)??0)+d}),y.attr("style",s.style).attr("class","outer title-state").attr("x",-A/2-u).attr("y",-(P/2)-u).attr("width",A+s.padding).attr("height",P+s.padding),Kh(s,y),s.intersect=function(de){return yh.rect(s,de)},b}};let VD={};const tJ=async(i,s,u)=>{let d,p;if(s.link){let v;qt().securityLevel==="sandbox"?v="_top":s.linkTarget&&(v=s.linkTarget||"_blank"),d=i.insert("svg:a").attr("xlink:href",s.link).attr("target",v),p=await CUe[s.shape](d,s,u)}else p=await CUe[s.shape](i,s,u),d=p;return s.tooltip&&p.attr("title",s.tooltip),s.class&&p.attr("class","node default "+s.class),d.attr("data-node","true"),d.attr("data-id",s.id),VD[s.id]=d,s.haveCallback&&VD[s.id].attr("class",VD[s.id].attr("class")+" clickable"),d},ben=(i,s)=>{VD[s.id]=i},men=()=>{VD={}},$me=i=>{const s=VD[i.id];Xe.trace("Transforming node",i.diff,i,"translate("+(i.x-i.width/2-5)+", "+i.width/2+")");const u=8,d=i.diff||0;return i.clusterNode?s.attr("transform","translate("+(i.x+d-i.width/2)+", "+(i.y-i.height/2-u)+")"):s.attr("transform","translate("+i.x+", "+i.y+")"),d},nJ=({flowchart:i})=>{var p,v;const s=((p=i==null?void 0:i.subGraphTitleMargin)==null?void 0:p.top)??0,u=((v=i==null?void 0:i.subGraphTitleMargin)==null?void 0:v.bottom)??0,d=s+u;return{subGraphTitleTopMargin:s,subGraphTitleBottomMargin:u,subGraphTitleTotalMargin:d}},ven={rect:(i,s)=>{Xe.info("Creating subgraph rect for ",s.id,s);const u=qt(),d=i.insert("g").attr("class","cluster"+(s.class?" "+s.class:"")).attr("id",s.id),p=d.insert("rect",":first-child"),v=f1(u.flowchart.htmlLabels),b=d.insert("g").attr("class","cluster-label"),y=s.labelType==="markdown"?JQ(b,s.labelText,{style:s.labelStyle,useHtmlLabels:v}):b.node().appendChild($2(s.labelText,s.labelStyle,void 0,!0));let T=y.getBBox();if(f1(u.flowchart.htmlLabels)){const j=y.children[0],K=Ir(y);T=j.getBoundingClientRect(),K.attr("width",T.width),K.attr("height",T.height)}const _=0*s.padding,A=_/2,P=s.width<=T.width+_?T.width+_:s.width;s.width<=T.width+_?s.diff=(T.width-s.width)/2-s.padding/2:s.diff=-s.padding/2,Xe.trace("Data ",s,JSON.stringify(s)),p.attr("style",s.style).attr("rx",s.rx).attr("ry",s.ry).attr("x",s.x-P/2).attr("y",s.y-s.height/2-A).attr("width",P).attr("height",s.height+_);const{subGraphTitleTopMargin:R}=nJ(u);v?b.attr("transform",`translate(${s.x-T.width/2}, ${s.y-s.height/2+R})`):b.attr("transform",`translate(${s.x}, ${s.y-s.height/2+R})`);const F=p.node().getBBox();return s.width=F.width,s.height=F.height,s.intersect=function(j){return DR(s,j)},d},roundedWithTitle:(i,s)=>{const u=qt(),d=i.insert("g").attr("class",s.classes).attr("id",s.id),p=d.insert("rect",":first-child"),v=d.insert("g").attr("class","cluster-label"),b=d.append("rect"),y=v.node().appendChild($2(s.labelText,s.labelStyle,void 0,!0));let T=y.getBBox();if(f1(u.flowchart.htmlLabels)){const j=y.children[0],K=Ir(y);T=j.getBoundingClientRect(),K.attr("width",T.width),K.attr("height",T.height)}T=y.getBBox();const _=0*s.padding,A=_/2,P=s.width<=T.width+s.padding?T.width+s.padding:s.width;s.width<=T.width+s.padding?s.diff=(T.width+s.padding*0-s.width)/2:s.diff=-s.padding/2,p.attr("class","outer").attr("x",s.x-P/2-A).attr("y",s.y-s.height/2-A).attr("width",P+_).attr("height",s.height+_),b.attr("class","inner").attr("x",s.x-P/2-A).attr("y",s.y-s.height/2-A+T.height-1).attr("width",P+_).attr("height",s.height+_-T.height-3);const{subGraphTitleTopMargin:R}=nJ(u);v.attr("transform",`translate(${s.x-T.width/2}, ${s.y-s.height/2-s.padding/3+(f1(u.flowchart.htmlLabels)?5:3)+R})`);const F=p.node().getBBox();return s.height=F.height,s.intersect=function(j){return DR(s,j)},d},noteGroup:(i,s)=>{const u=i.insert("g").attr("class","note-cluster").attr("id",s.id),d=u.insert("rect",":first-child"),p=0*s.padding,v=p/2;d.attr("rx",s.rx).attr("ry",s.ry).attr("x",s.x-s.width/2-v).attr("y",s.y-s.height/2-v).attr("width",s.width+p).attr("height",s.height+p).attr("fill","none");const b=d.node().getBBox();return s.width=b.width,s.height=b.height,s.intersect=function(y){return DR(s,y)},u},divider:(i,s)=>{const u=i.insert("g").attr("class",s.classes).attr("id",s.id),d=u.insert("rect",":first-child"),p=0*s.padding,v=p/2;d.attr("class","divider").attr("x",s.x-s.width/2-v).attr("y",s.y-s.height/2).attr("width",s.width+p).attr("height",s.height+p);const b=d.node().getBBox();return s.width=b.width,s.height=b.height,s.diff=-s.padding/2,s.intersect=function(y){return DR(s,y)},u}};let SUe={};const wen=(i,s)=>{Xe.trace("Inserting cluster");const u=s.shape||"rect";SUe[s.id]=ven[u](i,s)},yen=()=>{SUe={}},P9={aggregation:18,extension:18,composition:18,dependency:6,lollipop:13.5,arrow_point:5.3};function rJ(i,s){if(i===void 0||s===void 0)return{angle:0,deltaX:0,deltaY:0};i=iJ(i),s=iJ(s);const[u,d]=[i.x,i.y],[p,v]=[s.x,s.y],b=p-u,y=v-d;return{angle:Math.atan(y/b),deltaX:b,deltaY:y}}const iJ=i=>Array.isArray(i)?{x:i[0],y:i[1]}:i,_Ue=i=>({x:function(s,u,d){let p=0;if(u===0&&Object.hasOwn(P9,i.arrowTypeStart)){const{angle:v,deltaX:b}=rJ(d[0],d[1]);p=P9[i.arrowTypeStart]*Math.cos(v)*(b>=0?1:-1)}else if(u===d.length-1&&Object.hasOwn(P9,i.arrowTypeEnd)){const{angle:v,deltaX:b}=rJ(d[d.length-1],d[d.length-2]);p=P9[i.arrowTypeEnd]*Math.cos(v)*(b>=0?1:-1)}return iJ(s).x+p},y:function(s,u,d){let p=0;if(u===0&&Object.hasOwn(P9,i.arrowTypeStart)){const{angle:v,deltaY:b}=rJ(d[0],d[1]);p=P9[i.arrowTypeStart]*Math.abs(Math.sin(v))*(b>=0?1:-1)}else if(u===d.length-1&&Object.hasOwn(P9,i.arrowTypeEnd)){const{angle:v,deltaY:b}=rJ(d[d.length-1],d[d.length-2]);p=P9[i.arrowTypeEnd]*Math.abs(Math.sin(v))*(b>=0?1:-1)}return iJ(s).y+p}}),AUe=(i,s,u,d,p)=>{s.arrowTypeStart&&LUe(i,"start",s.arrowTypeStart,u,d,p),s.arrowTypeEnd&&LUe(i,"end",s.arrowTypeEnd,u,d,p)},xen={arrow_cross:"cross",arrow_point:"point",arrow_barb:"barb",arrow_circle:"circle",aggregation:"aggregation",extension:"extension",composition:"composition",dependency:"dependency",lollipop:"lollipop"},LUe=(i,s,u,d,p,v)=>{const b=xen[u];if(!b){Xe.warn(`Unknown arrow type: ${u}`);return}const y=s==="start"?"Start":"End";i.attr(`marker-${s}`,`url(${d}#${p}_${v}-${b}${y})`)};let sJ={},Vd={};const ken=()=>{sJ={},Vd={}},zme=(i,s)=>{const u=f1(qt().flowchart.htmlLabels),d=s.labelType==="markdown"?JQ(i,s.label,{style:s.labelStyle,useHtmlLabels:u,addSvgBackground:!0}):$2(s.label,s.labelStyle),p=i.insert("g").attr("class","edgeLabel"),v=p.insert("g").attr("class","label");v.node().appendChild(d);let b=d.getBBox();if(u){const T=d.children[0],_=Ir(d);b=T.getBoundingClientRect(),_.attr("width",b.width),_.attr("height",b.height)}v.attr("transform","translate("+-b.width/2+", "+-b.height/2+")"),sJ[s.id]=p,s.width=b.width,s.height=b.height;let y;if(s.startLabelLeft){const T=$2(s.startLabelLeft,s.labelStyle),_=i.insert("g").attr("class","edgeTerminals"),A=_.insert("g").attr("class","inner");y=A.node().appendChild(T);const P=T.getBBox();A.attr("transform","translate("+-P.width/2+", "+-P.height/2+")"),Vd[s.id]||(Vd[s.id]={}),Vd[s.id].startLeft=_,aJ(y,s.startLabelLeft)}if(s.startLabelRight){const T=$2(s.startLabelRight,s.labelStyle),_=i.insert("g").attr("class","edgeTerminals"),A=_.insert("g").attr("class","inner");y=_.node().appendChild(T),A.node().appendChild(T);const P=T.getBBox();A.attr("transform","translate("+-P.width/2+", "+-P.height/2+")"),Vd[s.id]||(Vd[s.id]={}),Vd[s.id].startRight=_,aJ(y,s.startLabelRight)}if(s.endLabelLeft){const T=$2(s.endLabelLeft,s.labelStyle),_=i.insert("g").attr("class","edgeTerminals"),A=_.insert("g").attr("class","inner");y=A.node().appendChild(T);const P=T.getBBox();A.attr("transform","translate("+-P.width/2+", "+-P.height/2+")"),_.node().appendChild(T),Vd[s.id]||(Vd[s.id]={}),Vd[s.id].endLeft=_,aJ(y,s.endLabelLeft)}if(s.endLabelRight){const T=$2(s.endLabelRight,s.labelStyle),_=i.insert("g").attr("class","edgeTerminals"),A=_.insert("g").attr("class","inner");y=A.node().appendChild(T);const P=T.getBBox();A.attr("transform","translate("+-P.width/2+", "+-P.height/2+")"),_.node().appendChild(T),Vd[s.id]||(Vd[s.id]={}),Vd[s.id].endRight=_,aJ(y,s.endLabelRight)}return d};function aJ(i,s){qt().flowchart.htmlLabels&&i&&(i.style.width=s.length*9+"px",i.style.height="12px")}const MUe=(i,s)=>{Xe.debug("Moving label abc88 ",i.id,i.label,sJ[i.id],s);let u=s.updatedPath?s.updatedPath:s.originalPath;const d=qt(),{subGraphTitleTotalMargin:p}=nJ(d);if(i.label){const v=sJ[i.id];let b=i.x,y=i.y;if(u){const T=Ao.calcLabelPosition(u);Xe.debug("Moving label "+i.label+" from (",b,",",y,") to (",T.x,",",T.y,") abc88"),s.updatedPath&&(b=T.x,y=T.y)}v.attr("transform",`translate(${b}, ${y+p/2})`)}if(i.startLabelLeft){const v=Vd[i.id].startLeft;let b=i.x,y=i.y;if(u){const T=Ao.calcTerminalLabelPosition(i.arrowTypeStart?10:0,"start_left",u);b=T.x,y=T.y}v.attr("transform",`translate(${b}, ${y})`)}if(i.startLabelRight){const v=Vd[i.id].startRight;let b=i.x,y=i.y;if(u){const T=Ao.calcTerminalLabelPosition(i.arrowTypeStart?10:0,"start_right",u);b=T.x,y=T.y}v.attr("transform",`translate(${b}, ${y})`)}if(i.endLabelLeft){const v=Vd[i.id].endLeft;let b=i.x,y=i.y;if(u){const T=Ao.calcTerminalLabelPosition(i.arrowTypeEnd?10:0,"end_left",u);b=T.x,y=T.y}v.attr("transform",`translate(${b}, ${y})`)}if(i.endLabelRight){const v=Vd[i.id].endRight;let b=i.x,y=i.y;if(u){const T=Ao.calcTerminalLabelPosition(i.arrowTypeEnd?10:0,"end_right",u);b=T.x,y=T.y}v.attr("transform",`translate(${b}, ${y})`)}},Een=(i,s)=>{const u=i.x,d=i.y,p=Math.abs(s.x-u),v=Math.abs(s.y-d),b=i.width/2,y=i.height/2;return p>=b||v>=y},Ten=(i,s,u)=>{Xe.debug(`intersection calc abc89: + outsidePoint: ${JSON.stringify(s)} + insidePoint : ${JSON.stringify(u)} + node : x:${i.x} y:${i.y} w:${i.width} h:${i.height}`);const d=i.x,p=i.y,v=Math.abs(d-u.x),b=i.width/2;let y=u.xMath.abs(d-s.x)*T){let P=u.y{Xe.debug("abc88 cutPathAtIntersect",i,s);let u=[],d=i[0],p=!1;return i.forEach(v=>{if(!Een(s,v)&&!p){const b=Ten(s,d,v);let y=!1;u.forEach(T=>{y=y||T.x===b.x&&T.y===b.y}),u.some(T=>T.x===b.x&&T.y===b.y)||u.push(b),p=!0}else d=v,p||u.push(v)}),u},IUe=function(i,s,u,d,p,v,b){let y=u.points;Xe.debug("abc88 InsertEdge: edge=",u,"e=",s);let T=!1;const _=v.node(s.v);var A=v.node(s.w);A!=null&&A.intersect&&(_!=null&&_.intersect)&&(y=y.slice(1,u.points.length-1),y.unshift(_.intersect(y[0])),y.push(A.intersect(y[y.length-1]))),u.toCluster&&(Xe.debug("to cluster abc88",d[u.toCluster]),y=DUe(u.points,d[u.toCluster].node),T=!0),u.fromCluster&&(Xe.debug("from cluster abc88",d[u.fromCluster]),y=DUe(y.reverse(),d[u.fromCluster].node).reverse(),T=!0);const P=y.filter(be=>!Number.isNaN(be.y));let R=FF;u.curve&&(p==="graph"||p==="flowchart")&&(R=u.curve);const{x:F,y:j}=_Ue(u),K=k7().x(F).y(j).curve(R);let ee;switch(u.thickness){case"normal":ee="edge-thickness-normal";break;case"thick":ee="edge-thickness-thick";break;case"invisible":ee="edge-thickness-thick";break;default:ee=""}switch(u.pattern){case"solid":ee+=" edge-pattern-solid";break;case"dotted":ee+=" edge-pattern-dotted";break;case"dashed":ee+=" edge-pattern-dashed";break}const ie=i.append("path").attr("d",K(P)).attr("id",u.id).attr("class"," "+ee+(u.classes?" "+u.classes:"")).attr("style",u.style);let oe="";(qt().flowchart.arrowMarkerAbsolute||qt().state.arrowMarkerAbsolute)&&(oe=window.location.protocol+"//"+window.location.host+window.location.pathname+window.location.search,oe=oe.replace(/\(/g,"\\("),oe=oe.replace(/\)/g,"\\)")),AUe(ie,u,oe,b,p);let pe={};return T&&(pe.updatedPath=y),pe.originalPath=u.points,pe},OUe=async(i,s,u,d,p,v)=>{Xe.info("Graph in recursive render: XXX",q7(s),p);const b=s.graph().rankdir;Xe.trace("Dir in recursive render - dir:",b);const y=i.insert("g").attr("class","root");s.nodes()?Xe.info("Recursive render XXX",s.nodes()):Xe.info("No nodes found for",s),s.edges().length>0&&Xe.trace("Recursive edges",s.edge(s.edges()[0]));const T=y.insert("g").attr("class","clusters"),_=y.insert("g").attr("class","edgePaths"),A=y.insert("g").attr("class","edgeLabels"),P=y.insert("g").attr("class","nodes");await Promise.all(s.nodes().map(async function(j){const K=s.node(j);if(p!==void 0){const ee=JSON.parse(JSON.stringify(p.clusterData));Xe.info("Setting data for cluster XXX (",j,") ",ee,p),s.setNode(p.id,ee),s.parent(j)||(Xe.trace("Setting parent",j,p.id),s.setParent(j,p.id,ee))}if(Xe.info("(Insert) Node XXX"+j+": "+JSON.stringify(s.node(j))),K&&K.clusterNode){Xe.info("Cluster identified",j,K.width,s.node(j));const ee=await OUe(P,K.graph,u,d,s.node(j),v),ie=ee.elem;Kh(K,ie),K.diff=ee.diff||0,Xe.info("Node bounds (abc123)",j,K,K.width,K.x,K.y),ben(ie,K),Xe.warn("Recursive render complete ",ie,K)}else s.children(j).length>0?(Xe.info("Cluster - the non recursive path XXX",j,K.id,K,s),Xe.info(MR(K.id,s)),Mo[K.id]={id:MR(K.id,s),node:K}):(Xe.info("Node - the non recursive path",j,K.id,K),await tJ(P,s.node(j),b))})),s.edges().forEach(function(j){const K=s.edge(j.v,j.w,j.name);Xe.info("Edge "+j.v+" -> "+j.w+": "+JSON.stringify(j)),Xe.info("Edge "+j.v+" -> "+j.w+": ",j," ",JSON.stringify(s.edge(j))),Xe.info("Fix",Mo,"ids:",j.v,j.w,"Translating: ",Mo[j.v],Mo[j.w]),zme(A,K)}),s.edges().forEach(function(j){Xe.info("Edge "+j.v+" -> "+j.w+": "+JSON.stringify(j))}),Xe.info("#############################################"),Xe.info("### Layout ###"),Xe.info("#############################################"),Xe.info(s),qD(s),Xe.info("Graph after layout:",q7(s));let R=0;const{subGraphTitleTotalMargin:F}=nJ(v);return HZt(s).forEach(function(j){const K=s.node(j);Xe.info("Position "+j+": "+JSON.stringify(s.node(j))),Xe.info("Position "+j+": ("+K.x,","+K.y,") width: ",K.width," height: ",K.height),K&&K.clusterNode?(K.y+=F,$me(K)):s.children(j).length>0?(K.height+=F,wen(T,K),Mo[K.id].node=K):(K.y+=F/2,$me(K))}),s.edges().forEach(function(j){const K=s.edge(j);Xe.info("Edge "+j.v+" -> "+j.w+": "+JSON.stringify(K),K),K.points.forEach(ie=>ie.y+=F/2);const ee=IUe(_,j,K,Mo,u,s,d);MUe(K,ee)}),s.nodes().forEach(function(j){const K=s.node(j);Xe.info(j,K.type,K.diff),K.type==="group"&&(R=K.diff)}),{elem:y,diff:R}},qme=async(i,s,u,d,p)=>{Sme(i,u,d,p),men(),ken(),yen(),$Zt(),Xe.warn("Graph at first:",JSON.stringify(q7(s))),qZt(s),Xe.warn("Graph after:",JSON.stringify(q7(s)));const v=qt();await OUe(i,s,d,p,void 0,v)},NUe={},Cen=function(i){const s=Object.keys(i);for(const u of s)NUe[u]=i[u]},PUe=async function(i,s,u,d,p,v){const b=d.select(`[id="${u}"]`),y=Object.keys(i);for(const T of y){const _=i[T];let A="default";_.classes.length>0&&(A=_.classes.join(" ")),A=A+" flowchart-label";const P=om(_.styles);let R=_.text!==void 0?_.text:_.id,F;if(Xe.info("vertex",_,_.labelType),_.labelType==="markdown")Xe.info("vertex",_,_.labelType);else if(f1(qt().flowchart.htmlLabels))F=vme(b,{label:R}).node(),F.parentNode.removeChild(F);else{const ie=p.createElementNS("http://www.w3.org/2000/svg","text");ie.setAttribute("style",P.labelStyle.replace("color:","fill:"));const oe=R.split(ci.lineBreakRegex);for(const pe of oe){const be=p.createElementNS("http://www.w3.org/2000/svg","tspan");be.setAttributeNS("http://www.w3.org/XML/1998/namespace","xml:space","preserve"),be.setAttribute("dy","1em"),be.setAttribute("x","1"),be.textContent=pe,ie.appendChild(be)}F=ie}let j=0,K="";switch(_.type){case"round":j=5,K="rect";break;case"square":K="rect";break;case"diamond":K="question";break;case"hexagon":K="hexagon";break;case"odd":K="rect_left_inv_arrow";break;case"lean_right":K="lean_right";break;case"lean_left":K="lean_left";break;case"trapezoid":K="trapezoid";break;case"inv_trapezoid":K="inv_trapezoid";break;case"odd_right":K="rect_left_inv_arrow";break;case"circle":K="circle";break;case"ellipse":K="ellipse";break;case"stadium":K="stadium";break;case"subroutine":K="subroutine";break;case"cylinder":K="cylinder";break;case"group":K="rect";break;case"doublecircle":K="doublecircle";break;default:K="rect"}const ee=await CC(R,qt());s.setNode(_.id,{labelStyle:P.labelStyle,shape:K,labelText:ee,labelType:_.labelType,rx:j,ry:j,class:A,style:P.style,id:_.id,link:_.link,linkTarget:_.linkTarget,tooltip:v.db.getTooltip(_.id)||"",domId:v.db.lookUpDomId(_.id),haveCallback:_.haveCallback,width:_.type==="group"?500:void 0,dir:_.dir,type:_.type,props:_.props,padding:qt().flowchart.padding}),Xe.info("setNode",{labelStyle:P.labelStyle,labelType:_.labelType,shape:K,labelText:ee,rx:j,ry:j,class:A,style:P.style,id:_.id,domId:v.db.lookUpDomId(_.id),width:_.type==="group"?500:void 0,type:_.type,dir:_.dir,props:_.props,padding:qt().flowchart.padding})}},BUe=async function(i,s,u){Xe.info("abc78 edges = ",i);let d=0,p={},v,b;if(i.defaultStyle!==void 0){const y=om(i.defaultStyle);v=y.style,b=y.labelStyle}for(const y of i){d++;const T="L-"+y.start+"-"+y.end;p[T]===void 0?(p[T]=0,Xe.info("abc78 new entry",T,p[T])):(p[T]++,Xe.info("abc78 new entry",T,p[T]));let _=T+"-"+p[T];Xe.info("abc78 new link id to be used is",T,_,p[T]);const A="LS-"+y.start,P="LE-"+y.end,R={style:"",labelStyle:""};switch(R.minlen=y.length||1,y.type==="arrow_open"?R.arrowhead="none":R.arrowhead="normal",R.arrowTypeStart="arrow_open",R.arrowTypeEnd="arrow_open",y.type){case"double_arrow_cross":R.arrowTypeStart="arrow_cross";case"arrow_cross":R.arrowTypeEnd="arrow_cross";break;case"double_arrow_point":R.arrowTypeStart="arrow_point";case"arrow_point":R.arrowTypeEnd="arrow_point";break;case"double_arrow_circle":R.arrowTypeStart="arrow_circle";case"arrow_circle":R.arrowTypeEnd="arrow_circle";break}let F="",j="";switch(y.stroke){case"normal":F="fill:none;",v!==void 0&&(F=v),b!==void 0&&(j=b),R.thickness="normal",R.pattern="solid";break;case"dotted":R.thickness="normal",R.pattern="dotted",R.style="fill:none;stroke-width:2px;stroke-dasharray:3;";break;case"thick":R.thickness="thick",R.pattern="solid",R.style="stroke-width: 3.5px;fill:none;";break;case"invisible":R.thickness="invisible",R.pattern="solid",R.style="stroke-width: 0;fill:none;";break}if(y.style!==void 0){const K=om(y.style);F=K.style,j=K.labelStyle}R.style=R.style+=F,R.labelStyle=R.labelStyle+=j,y.interpolate!==void 0?R.curve=Ov(y.interpolate,kp):i.defaultInterpolate!==void 0?R.curve=Ov(i.defaultInterpolate,kp):R.curve=Ov(NUe.curve,kp),y.text===void 0?y.style!==void 0&&(R.arrowheadStyle="fill: #333"):(R.arrowheadStyle="fill: #333",R.labelpos="c"),R.labelType=y.labelType,R.label=await CC(y.text.replace(ci.lineBreakRegex,` +`),qt()),y.style===void 0&&(R.style=R.style||"stroke: #333; stroke-width: 1.5px;fill:none;"),R.labelStyle=R.labelStyle.replace("color:","fill:"),R.id=_,R.classes="flowchart-link "+A+" "+P,s.setEdge(y.start,y.end,R,d)}},Hme={setConf:Cen,addVertices:PUe,addEdges:BUe,getClasses:function(i,s){return s.db.getClasses()},draw:async function(i,s,u,d){Xe.info("Drawing flowchart");let p=d.db.getDirection();p===void 0&&(p="TD");const{securityLevel:v,flowchart:b}=qt(),y=b.nodeSpacing||50,T=b.rankSpacing||50;let _;v==="sandbox"&&(_=Ir("#i"+s));const A=Ir(v==="sandbox"?_.nodes()[0].contentDocument.body:"body"),P=v==="sandbox"?_.nodes()[0].contentDocument:document,R=new B0({multigraph:!0,compound:!0}).setGraph({rankdir:p,nodesep:y,ranksep:T,marginx:0,marginy:0}).setDefaultEdgeLabel(function(){return{}});let F;const j=d.db.getSubGraphs();Xe.info("Subgraphs - ",j);for(let ae=j.length-1;ae>=0;ae--)F=j[ae],Xe.info("Subgraph - ",F),d.db.addVertex(F.id,{text:F.title,type:F.labelType},"group",void 0,F.classes,F.dir);const K=d.db.getVertices(),ee=d.db.getEdges();Xe.info("Edges",ee);let ie=0;for(ie=j.length-1;ie>=0;ie--){F=j[ie],_Be("cluster").append("text");for(let ae=0;ae{const u=ARe,d=u(i,"r"),p=u(i,"g"),v=u(i,"b");return SC(d,p,v,s)},FUe=i=>`.label { + font-family: ${i.fontFamily}; + color: ${i.nodeTextColor||i.textColor}; + } + .cluster-label text { + fill: ${i.titleColor}; + } + .cluster-label span,p { + color: ${i.titleColor}; + } + + .label text,span,p { + fill: ${i.nodeTextColor||i.textColor}; + color: ${i.nodeTextColor||i.textColor}; + } + + .node rect, + .node circle, + .node ellipse, + .node polygon, + .node path { + fill: ${i.mainBkg}; + stroke: ${i.nodeBorder}; + stroke-width: 1px; + } + .flowchart-label text { + text-anchor: middle; + } + // .flowchart-label .text-outer-tspan { + // text-anchor: middle; + // } + // .flowchart-label .text-inner-tspan { + // text-anchor: start; + // } + + .node .katex path { + fill: #000; + stroke: #000; + stroke-width: 1px; + } + + .node .label { + text-align: center; + } + .node.clickable { + cursor: pointer; + } + + .arrowheadPath { + fill: ${i.arrowheadColor}; + } + + .edgePath .path { + stroke: ${i.lineColor}; + stroke-width: 2.0px; + } + + .flowchart-link { + stroke: ${i.lineColor}; + fill: none; + } + + .edgeLabel { + background-color: ${i.edgeLabelBackground}; + rect { + opacity: 0.5; + background-color: ${i.edgeLabelBackground}; + fill: ${i.edgeLabelBackground}; + } + text-align: center; + } + + /* For html labels only */ + .labelBkg { + background-color: ${Sen(i.edgeLabelBackground,.5)}; + // background-color: + } + + .cluster rect { + fill: ${i.clusterBkg}; + stroke: ${i.clusterBorder}; + stroke-width: 1px; + } + + .cluster text { + fill: ${i.titleColor}; + } + + .cluster span,p { + color: ${i.titleColor}; + } + /* .cluster div { + color: ${i.titleColor}; + } */ + + div.mermaidTooltip { + position: absolute; + text-align: center; + max-width: 200px; + padding: 2px; + font-family: ${i.fontFamily}; + font-size: 12px; + background: ${i.tertiaryColor}; + border: 1px solid ${i.border2}; + border-radius: 2px; + pointer-events: none; + z-index: 100; + } + + .flowchartTitleText { + text-anchor: middle; + font-size: 18px; + fill: ${i.textColor}; + } +`,_en=Object.freeze(Object.defineProperty({__proto__:null,diagram:{parser:Gbe,db:HC,renderer:Hme,styles:FUe,init:i=>{i.flowchart||(i.flowchart={}),i.flowchart.arrowMarkerAbsolute=i.arrowMarkerAbsolute,_Qt.setConf(i.flowchart),HC.clear(),HC.setGen("gen-1")}}},Symbol.toStringTag,{value:"Module"})),Aen=Object.freeze(Object.defineProperty({__proto__:null,diagram:{parser:Gbe,db:HC,renderer:Hme,styles:FUe,init:i=>{i.flowchart||(i.flowchart={}),i.flowchart.arrowMarkerAbsolute=i.arrowMarkerAbsolute,_jt({flowchart:{arrowMarkerAbsolute:i.arrowMarkerAbsolute}}),Hme.setConf(i.flowchart),HC.clear(),HC.setGen("gen-2")}}},Symbol.toStringTag,{value:"Module"}));var Vme=function(){var i=function(de,X,ge,W){for(ge=ge||{},W=de.length;W--;ge[de[W]]=X);return ge},s=[6,8,10,20,22,24,26,27,28],u=[1,10],d=[1,11],p=[1,12],v=[1,13],b=[1,14],y=[1,15],T=[1,21],_=[1,22],A=[1,23],P=[1,24],R=[1,25],F=[6,8,10,13,15,18,19,20,22,24,26,27,28,41,42,43,44,45],j=[1,34],K=[27,28,46,47],ee=[41,42,43,44,45],ie=[17,34],oe=[1,54],pe=[1,53],be=[17,34,36,38],ae={trace:function(){},yy:{},symbols_:{error:2,start:3,ER_DIAGRAM:4,document:5,EOF:6,line:7,SPACE:8,statement:9,NEWLINE:10,entityName:11,relSpec:12,":":13,role:14,BLOCK_START:15,attributes:16,BLOCK_STOP:17,SQS:18,SQE:19,title:20,title_value:21,acc_title:22,acc_title_value:23,acc_descr:24,acc_descr_value:25,acc_descr_multiline_value:26,ALPHANUM:27,ENTITY_NAME:28,attribute:29,attributeType:30,attributeName:31,attributeKeyTypeList:32,attributeComment:33,ATTRIBUTE_WORD:34,attributeKeyType:35,COMMA:36,ATTRIBUTE_KEY:37,COMMENT:38,cardinality:39,relType:40,ZERO_OR_ONE:41,ZERO_OR_MORE:42,ONE_OR_MORE:43,ONLY_ONE:44,MD_PARENT:45,NON_IDENTIFYING:46,IDENTIFYING:47,WORD:48,$accept:0,$end:1},terminals_:{2:"error",4:"ER_DIAGRAM",6:"EOF",8:"SPACE",10:"NEWLINE",13:":",15:"BLOCK_START",17:"BLOCK_STOP",18:"SQS",19:"SQE",20:"title",21:"title_value",22:"acc_title",23:"acc_title_value",24:"acc_descr",25:"acc_descr_value",26:"acc_descr_multiline_value",27:"ALPHANUM",28:"ENTITY_NAME",34:"ATTRIBUTE_WORD",36:"COMMA",37:"ATTRIBUTE_KEY",38:"COMMENT",41:"ZERO_OR_ONE",42:"ZERO_OR_MORE",43:"ONE_OR_MORE",44:"ONLY_ONE",45:"MD_PARENT",46:"NON_IDENTIFYING",47:"IDENTIFYING",48:"WORD"},productions_:[0,[3,3],[5,0],[5,2],[7,2],[7,1],[7,1],[7,1],[9,5],[9,4],[9,3],[9,1],[9,7],[9,6],[9,4],[9,2],[9,2],[9,2],[9,1],[11,1],[11,1],[16,1],[16,2],[29,2],[29,3],[29,3],[29,4],[30,1],[31,1],[32,1],[32,3],[35,1],[33,1],[12,3],[39,1],[39,1],[39,1],[39,1],[39,1],[40,1],[40,1],[14,1],[14,1],[14,1]],performAction:function(X,ge,W,xe,U,Fe,Pe){var je=Fe.length-1;switch(U){case 1:break;case 2:this.$=[];break;case 3:Fe[je-1].push(Fe[je]),this.$=Fe[je-1];break;case 4:case 5:this.$=Fe[je];break;case 6:case 7:this.$=[];break;case 8:xe.addEntity(Fe[je-4]),xe.addEntity(Fe[je-2]),xe.addRelationship(Fe[je-4],Fe[je],Fe[je-2],Fe[je-3]);break;case 9:xe.addEntity(Fe[je-3]),xe.addAttributes(Fe[je-3],Fe[je-1]);break;case 10:xe.addEntity(Fe[je-2]);break;case 11:xe.addEntity(Fe[je]);break;case 12:xe.addEntity(Fe[je-6],Fe[je-4]),xe.addAttributes(Fe[je-6],Fe[je-1]);break;case 13:xe.addEntity(Fe[je-5],Fe[je-3]);break;case 14:xe.addEntity(Fe[je-3],Fe[je-1]);break;case 15:case 16:this.$=Fe[je].trim(),xe.setAccTitle(this.$);break;case 17:case 18:this.$=Fe[je].trim(),xe.setAccDescription(this.$);break;case 19:case 43:this.$=Fe[je];break;case 20:case 41:case 42:this.$=Fe[je].replace(/"/g,"");break;case 21:case 29:this.$=[Fe[je]];break;case 22:Fe[je].push(Fe[je-1]),this.$=Fe[je];break;case 23:this.$={attributeType:Fe[je-1],attributeName:Fe[je]};break;case 24:this.$={attributeType:Fe[je-2],attributeName:Fe[je-1],attributeKeyTypeList:Fe[je]};break;case 25:this.$={attributeType:Fe[je-2],attributeName:Fe[je-1],attributeComment:Fe[je]};break;case 26:this.$={attributeType:Fe[je-3],attributeName:Fe[je-2],attributeKeyTypeList:Fe[je-1],attributeComment:Fe[je]};break;case 27:case 28:case 31:this.$=Fe[je];break;case 30:Fe[je-2].push(Fe[je]),this.$=Fe[je-2];break;case 32:this.$=Fe[je].replace(/"/g,"");break;case 33:this.$={cardA:Fe[je],relType:Fe[je-1],cardB:Fe[je-2]};break;case 34:this.$=xe.Cardinality.ZERO_OR_ONE;break;case 35:this.$=xe.Cardinality.ZERO_OR_MORE;break;case 36:this.$=xe.Cardinality.ONE_OR_MORE;break;case 37:this.$=xe.Cardinality.ONLY_ONE;break;case 38:this.$=xe.Cardinality.MD_PARENT;break;case 39:this.$=xe.Identification.NON_IDENTIFYING;break;case 40:this.$=xe.Identification.IDENTIFYING;break}},table:[{3:1,4:[1,2]},{1:[3]},i(s,[2,2],{5:3}),{6:[1,4],7:5,8:[1,6],9:7,10:[1,8],11:9,20:u,22:d,24:p,26:v,27:b,28:y},i(s,[2,7],{1:[2,1]}),i(s,[2,3]),{9:16,11:9,20:u,22:d,24:p,26:v,27:b,28:y},i(s,[2,5]),i(s,[2,6]),i(s,[2,11],{12:17,39:20,15:[1,18],18:[1,19],41:T,42:_,43:A,44:P,45:R}),{21:[1,26]},{23:[1,27]},{25:[1,28]},i(s,[2,18]),i(F,[2,19]),i(F,[2,20]),i(s,[2,4]),{11:29,27:b,28:y},{16:30,17:[1,31],29:32,30:33,34:j},{11:35,27:b,28:y},{40:36,46:[1,37],47:[1,38]},i(K,[2,34]),i(K,[2,35]),i(K,[2,36]),i(K,[2,37]),i(K,[2,38]),i(s,[2,15]),i(s,[2,16]),i(s,[2,17]),{13:[1,39]},{17:[1,40]},i(s,[2,10]),{16:41,17:[2,21],29:32,30:33,34:j},{31:42,34:[1,43]},{34:[2,27]},{19:[1,44]},{39:45,41:T,42:_,43:A,44:P,45:R},i(ee,[2,39]),i(ee,[2,40]),{14:46,27:[1,49],28:[1,48],48:[1,47]},i(s,[2,9]),{17:[2,22]},i(ie,[2,23],{32:50,33:51,35:52,37:oe,38:pe}),i([17,34,37,38],[2,28]),i(s,[2,14],{15:[1,55]}),i([27,28],[2,33]),i(s,[2,8]),i(s,[2,41]),i(s,[2,42]),i(s,[2,43]),i(ie,[2,24],{33:56,36:[1,57],38:pe}),i(ie,[2,25]),i(be,[2,29]),i(ie,[2,32]),i(be,[2,31]),{16:58,17:[1,59],29:32,30:33,34:j},i(ie,[2,26]),{35:60,37:oe},{17:[1,61]},i(s,[2,13]),i(be,[2,30]),i(s,[2,12])],defaultActions:{34:[2,27],41:[2,22]},parseError:function(X,ge){if(ge.recoverable)this.trace(X);else{var W=new Error(X);throw W.hash=ge,W}},parse:function(X){var ge=this,W=[0],xe=[],U=[null],Fe=[],Pe=this.table,je="",Ie=0,Se=0,Ce=2,ke=1,Ke=Fe.slice.call(arguments,1),Ft=Object.create(this.lexer),Ne={yy:{}};for(var gn in this.yy)Object.prototype.hasOwnProperty.call(this.yy,gn)&&(Ne.yy[gn]=this.yy[gn]);Ft.setInput(X,Ne.yy),Ne.yy.lexer=Ft,Ne.yy.parser=this,typeof Ft.yylloc>"u"&&(Ft.yylloc={});var _t=Ft.yylloc;Fe.push(_t);var Et=Ft.options&&Ft.options.ranges;typeof Ne.yy.parseError=="function"?this.parseError=Ne.yy.parseError:this.parseError=Object.getPrototypeOf(this).parseError;function Gt(){var ji;return ji=xe.pop()||Ft.lex()||ke,typeof ji!="number"&&(ji instanceof Array&&(xe=ji,ji=xe.pop()),ji=ge.symbols_[ji]||ji),ji}for(var ln,xt,Pt,Qe,Dt={},kt,On,ht,zr;;){if(xt=W[W.length-1],this.defaultActions[xt]?Pt=this.defaultActions[xt]:((ln===null||typeof ln>"u")&&(ln=Gt()),Pt=Pe[xt]&&Pe[xt][ln]),typeof Pt>"u"||!Pt.length||!Pt[0]){var yt="";zr=[];for(kt in Pe[xt])this.terminals_[kt]&&kt>Ce&&zr.push("'"+this.terminals_[kt]+"'");Ft.showPosition?yt="Parse error on line "+(Ie+1)+`: +`+Ft.showPosition()+` +Expecting `+zr.join(", ")+", got '"+(this.terminals_[ln]||ln)+"'":yt="Parse error on line "+(Ie+1)+": Unexpected "+(ln==ke?"end of input":"'"+(this.terminals_[ln]||ln)+"'"),this.parseError(yt,{text:Ft.match,token:this.terminals_[ln]||ln,line:Ft.yylineno,loc:_t,expected:zr})}if(Pt[0]instanceof Array&&Pt.length>1)throw new Error("Parse Error: multiple actions possible at state: "+xt+", token: "+ln);switch(Pt[0]){case 1:W.push(ln),U.push(Ft.yytext),Fe.push(Ft.yylloc),W.push(Pt[1]),ln=null,Se=Ft.yyleng,je=Ft.yytext,Ie=Ft.yylineno,_t=Ft.yylloc;break;case 2:if(On=this.productions_[Pt[1]][1],Dt.$=U[U.length-On],Dt._$={first_line:Fe[Fe.length-(On||1)].first_line,last_line:Fe[Fe.length-1].last_line,first_column:Fe[Fe.length-(On||1)].first_column,last_column:Fe[Fe.length-1].last_column},Et&&(Dt._$.range=[Fe[Fe.length-(On||1)].range[0],Fe[Fe.length-1].range[1]]),Qe=this.performAction.apply(Dt,[je,Se,Ie,Ne.yy,Pt[1],U,Fe].concat(Ke)),typeof Qe<"u")return Qe;On&&(W=W.slice(0,-1*On*2),U=U.slice(0,-1*On),Fe=Fe.slice(0,-1*On)),W.push(this.productions_[Pt[1]][0]),U.push(Dt.$),Fe.push(Dt._$),ht=Pe[W[W.length-2]][W[W.length-1]],W.push(ht);break;case 3:return!0}}return!0}},ne=function(){var de={EOF:1,parseError:function(ge,W){if(this.yy.parser)this.yy.parser.parseError(ge,W);else throw new Error(ge)},setInput:function(X,ge){return this.yy=ge||this.yy||{},this._input=X,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},input:function(){var X=this._input[0];this.yytext+=X,this.yyleng++,this.offset++,this.match+=X,this.matched+=X;var ge=X.match(/(?:\r\n?|\n).*/g);return ge?(this.yylineno++,this.yylloc.last_line++):this.yylloc.last_column++,this.options.ranges&&this.yylloc.range[1]++,this._input=this._input.slice(1),X},unput:function(X){var ge=X.length,W=X.split(/(?:\r\n?|\n)/g);this._input=X+this._input,this.yytext=this.yytext.substr(0,this.yytext.length-ge),this.offset-=ge;var xe=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),W.length-1&&(this.yylineno-=W.length-1);var U=this.yylloc.range;return this.yylloc={first_line:this.yylloc.first_line,last_line:this.yylineno+1,first_column:this.yylloc.first_column,last_column:W?(W.length===xe.length?this.yylloc.first_column:0)+xe[xe.length-W.length].length-W[0].length:this.yylloc.first_column-ge},this.options.ranges&&(this.yylloc.range=[U[0],U[0]+this.yyleng-ge]),this.yyleng=this.yytext.length,this},more:function(){return this._more=!0,this},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},less:function(X){this.unput(this.match.slice(X))},pastInput:function(){var X=this.matched.substr(0,this.matched.length-this.match.length);return(X.length>20?"...":"")+X.substr(-20).replace(/\n/g,"")},upcomingInput:function(){var X=this.match;return X.length<20&&(X+=this._input.substr(0,20-X.length)),(X.substr(0,20)+(X.length>20?"...":"")).replace(/\n/g,"")},showPosition:function(){var X=this.pastInput(),ge=new Array(X.length+1).join("-");return X+this.upcomingInput()+` +`+ge+"^"},test_match:function(X,ge){var W,xe,U;if(this.options.backtrack_lexer&&(U={yylineno:this.yylineno,yylloc:{first_line:this.yylloc.first_line,last_line:this.last_line,first_column:this.yylloc.first_column,last_column:this.yylloc.last_column},yytext:this.yytext,match:this.match,matches:this.matches,matched:this.matched,yyleng:this.yyleng,offset:this.offset,_more:this._more,_input:this._input,yy:this.yy,conditionStack:this.conditionStack.slice(0),done:this.done},this.options.ranges&&(U.yylloc.range=this.yylloc.range.slice(0))),xe=X[0].match(/(?:\r\n?|\n).*/g),xe&&(this.yylineno+=xe.length),this.yylloc={first_line:this.yylloc.last_line,last_line:this.yylineno+1,first_column:this.yylloc.last_column,last_column:xe?xe[xe.length-1].length-xe[xe.length-1].match(/\r?\n?/)[0].length:this.yylloc.last_column+X[0].length},this.yytext+=X[0],this.match+=X[0],this.matches=X,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(X[0].length),this.matched+=X[0],W=this.performAction.call(this,this.yy,this,ge,this.conditionStack[this.conditionStack.length-1]),this.done&&this._input&&(this.done=!1),W)return W;if(this._backtrack){for(var Fe in U)this[Fe]=U[Fe];return!1}return!1},next:function(){if(this.done)return this.EOF;this._input||(this.done=!0);var X,ge,W,xe;this._more||(this.yytext="",this.match="");for(var U=this._currentRules(),Fe=0;Fege[0].length)){if(ge=W,xe=Fe,this.options.backtrack_lexer){if(X=this.test_match(W,U[Fe]),X!==!1)return X;if(this._backtrack){ge=!1;continue}else return!1}else if(!this.options.flex)break}return ge?(X=this.test_match(ge,U[xe]),X!==!1?X:!1):this._input===""?this.EOF:this.parseError("Lexical error on line "+(this.yylineno+1)+`. Unrecognized text. +`+this.showPosition(),{text:"",token:null,line:this.yylineno})},lex:function(){var ge=this.next();return ge||this.lex()},begin:function(ge){this.conditionStack.push(ge)},popState:function(){var ge=this.conditionStack.length-1;return ge>0?this.conditionStack.pop():this.conditionStack[0]},_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},topState:function(ge){return ge=this.conditionStack.length-1-Math.abs(ge||0),ge>=0?this.conditionStack[ge]:"INITIAL"},pushState:function(ge){this.begin(ge)},stateStackSize:function(){return this.conditionStack.length},options:{"case-insensitive":!0},performAction:function(ge,W,xe,U){switch(xe){case 0:return this.begin("acc_title"),22;case 1:return this.popState(),"acc_title_value";case 2:return this.begin("acc_descr"),24;case 3:return this.popState(),"acc_descr_value";case 4:this.begin("acc_descr_multiline");break;case 5:this.popState();break;case 6:return"acc_descr_multiline_value";case 7:return 10;case 8:break;case 9:return 8;case 10:return 28;case 11:return 48;case 12:return 4;case 13:return this.begin("block"),15;case 14:return 36;case 15:break;case 16:return 37;case 17:return 34;case 18:return 34;case 19:return 38;case 20:break;case 21:return this.popState(),17;case 22:return W.yytext[0];case 23:return 18;case 24:return 19;case 25:return 41;case 26:return 43;case 27:return 43;case 28:return 43;case 29:return 41;case 30:return 41;case 31:return 42;case 32:return 42;case 33:return 42;case 34:return 42;case 35:return 42;case 36:return 43;case 37:return 42;case 38:return 43;case 39:return 44;case 40:return 44;case 41:return 44;case 42:return 44;case 43:return 41;case 44:return 42;case 45:return 43;case 46:return 45;case 47:return 46;case 48:return 47;case 49:return 47;case 50:return 46;case 51:return 46;case 52:return 46;case 53:return 27;case 54:return W.yytext[0];case 55:return 6}},rules:[/^(?:accTitle\s*:\s*)/i,/^(?:(?!\n||)*[^\n]*)/i,/^(?:accDescr\s*:\s*)/i,/^(?:(?!\n||)*[^\n]*)/i,/^(?:accDescr\s*\{\s*)/i,/^(?:[\}])/i,/^(?:[^\}]*)/i,/^(?:[\n]+)/i,/^(?:\s+)/i,/^(?:[\s]+)/i,/^(?:"[^"%\r\n\v\b\\]+")/i,/^(?:"[^"]*")/i,/^(?:erDiagram\b)/i,/^(?:\{)/i,/^(?:,)/i,/^(?:\s+)/i,/^(?:\b((?:PK)|(?:FK)|(?:UK))\b)/i,/^(?:(.*?)[~](.*?)*[~])/i,/^(?:[\*A-Za-z_][A-Za-z0-9\-_\[\]\(\)]*)/i,/^(?:"[^"]*")/i,/^(?:[\n]+)/i,/^(?:\})/i,/^(?:.)/i,/^(?:\[)/i,/^(?:\])/i,/^(?:one or zero\b)/i,/^(?:one or more\b)/i,/^(?:one or many\b)/i,/^(?:1\+)/i,/^(?:\|o\b)/i,/^(?:zero or one\b)/i,/^(?:zero or more\b)/i,/^(?:zero or many\b)/i,/^(?:0\+)/i,/^(?:\}o\b)/i,/^(?:many\(0\))/i,/^(?:many\(1\))/i,/^(?:many\b)/i,/^(?:\}\|)/i,/^(?:one\b)/i,/^(?:only one\b)/i,/^(?:1\b)/i,/^(?:\|\|)/i,/^(?:o\|)/i,/^(?:o\{)/i,/^(?:\|\{)/i,/^(?:\s*u\b)/i,/^(?:\.\.)/i,/^(?:--)/i,/^(?:to\b)/i,/^(?:optionally to\b)/i,/^(?:\.-)/i,/^(?:-\.)/i,/^(?:[A-Za-z_][A-Za-z0-9\-_]*)/i,/^(?:.)/i,/^(?:$)/i],conditions:{acc_descr_multiline:{rules:[5,6],inclusive:!1},acc_descr:{rules:[3],inclusive:!1},acc_title:{rules:[1],inclusive:!1},block:{rules:[14,15,16,17,18,19,20,21,22],inclusive:!1},INITIAL:{rules:[0,2,4,7,8,9,10,11,12,13,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55],inclusive:!0}}};return de}();ae.lexer=ne;function se(){this.yy={}}return se.prototype=ae,ae.Parser=se,new se}();Vme.parser=Vme;const Len=Vme;let B9={},Ume=[];const Men={ZERO_OR_ONE:"ZERO_OR_ONE",ZERO_OR_MORE:"ZERO_OR_MORE",ONE_OR_MORE:"ONE_OR_MORE",ONLY_ONE:"ONLY_ONE",MD_PARENT:"MD_PARENT"},Den={NON_IDENTIFYING:"NON_IDENTIFYING",IDENTIFYING:"IDENTIFYING"},RUe=function(i,s=void 0){return B9[i]===void 0?(B9[i]={attributes:[],alias:s},Xe.info("Added new entity :",i)):B9[i]&&!B9[i].alias&&s&&(B9[i].alias=s,Xe.info(`Add alias '${s}' to entity '${i}'`)),B9[i]},Ien={Cardinality:Men,Identification:Den,getConfig:()=>qt().er,addEntity:RUe,addAttributes:function(i,s){let u=RUe(i),d;for(d=s.length-1;d>=0;d--)u.attributes.push(s[d]),Xe.debug("Added attribute ",s[d].attributeName)},getEntities:()=>B9,addRelationship:function(i,s,u,d){let p={entityA:i,roleA:s,entityB:u,relSpec:d};Ume.push(p),Xe.debug("Added new relationship :",p)},getRelationships:()=>Ume,clear:function(){B9={},Ume=[],Pg()},setAccTitle:Bg,getAccTitle:Cp,setAccDescription:Sp,getAccDescription:_p,setDiagramTitle:cm,getDiagramTitle:Ap},U3={ONLY_ONE_START:"ONLY_ONE_START",ONLY_ONE_END:"ONLY_ONE_END",ZERO_OR_ONE_START:"ZERO_OR_ONE_START",ZERO_OR_ONE_END:"ZERO_OR_ONE_END",ONE_OR_MORE_START:"ONE_OR_MORE_START",ONE_OR_MORE_END:"ONE_OR_MORE_END",ZERO_OR_MORE_START:"ZERO_OR_MORE_START",ZERO_OR_MORE_END:"ZERO_OR_MORE_END",MD_PARENT_END:"MD_PARENT_END",MD_PARENT_START:"MD_PARENT_START"},G3={ERMarkers:U3,insertMarkers:function(i,s){let u;i.append("defs").append("marker").attr("id",U3.MD_PARENT_START).attr("refX",0).attr("refY",7).attr("markerWidth",190).attr("markerHeight",240).attr("orient","auto").append("path").attr("d","M 18,7 L9,13 L1,7 L9,1 Z"),i.append("defs").append("marker").attr("id",U3.MD_PARENT_END).attr("refX",19).attr("refY",7).attr("markerWidth",20).attr("markerHeight",28).attr("orient","auto").append("path").attr("d","M 18,7 L9,13 L1,7 L9,1 Z"),i.append("defs").append("marker").attr("id",U3.ONLY_ONE_START).attr("refX",0).attr("refY",9).attr("markerWidth",18).attr("markerHeight",18).attr("orient","auto").append("path").attr("stroke",s.stroke).attr("fill","none").attr("d","M9,0 L9,18 M15,0 L15,18"),i.append("defs").append("marker").attr("id",U3.ONLY_ONE_END).attr("refX",18).attr("refY",9).attr("markerWidth",18).attr("markerHeight",18).attr("orient","auto").append("path").attr("stroke",s.stroke).attr("fill","none").attr("d","M3,0 L3,18 M9,0 L9,18"),u=i.append("defs").append("marker").attr("id",U3.ZERO_OR_ONE_START).attr("refX",0).attr("refY",9).attr("markerWidth",30).attr("markerHeight",18).attr("orient","auto"),u.append("circle").attr("stroke",s.stroke).attr("fill","white").attr("cx",21).attr("cy",9).attr("r",6),u.append("path").attr("stroke",s.stroke).attr("fill","none").attr("d","M9,0 L9,18"),u=i.append("defs").append("marker").attr("id",U3.ZERO_OR_ONE_END).attr("refX",30).attr("refY",9).attr("markerWidth",30).attr("markerHeight",18).attr("orient","auto"),u.append("circle").attr("stroke",s.stroke).attr("fill","white").attr("cx",9).attr("cy",9).attr("r",6),u.append("path").attr("stroke",s.stroke).attr("fill","none").attr("d","M21,0 L21,18"),i.append("defs").append("marker").attr("id",U3.ONE_OR_MORE_START).attr("refX",18).attr("refY",18).attr("markerWidth",45).attr("markerHeight",36).attr("orient","auto").append("path").attr("stroke",s.stroke).attr("fill","none").attr("d","M0,18 Q 18,0 36,18 Q 18,36 0,18 M42,9 L42,27"),i.append("defs").append("marker").attr("id",U3.ONE_OR_MORE_END).attr("refX",27).attr("refY",18).attr("markerWidth",45).attr("markerHeight",36).attr("orient","auto").append("path").attr("stroke",s.stroke).attr("fill","none").attr("d","M3,9 L3,27 M9,18 Q27,0 45,18 Q27,36 9,18"),u=i.append("defs").append("marker").attr("id",U3.ZERO_OR_MORE_START).attr("refX",18).attr("refY",18).attr("markerWidth",57).attr("markerHeight",36).attr("orient","auto"),u.append("circle").attr("stroke",s.stroke).attr("fill","white").attr("cx",48).attr("cy",18).attr("r",6),u.append("path").attr("stroke",s.stroke).attr("fill","none").attr("d","M0,18 Q18,0 36,18 Q18,36 0,18"),u=i.append("defs").append("marker").attr("id",U3.ZERO_OR_MORE_END).attr("refX",39).attr("refY",18).attr("markerWidth",57).attr("markerHeight",36).attr("orient","auto"),u.append("circle").attr("stroke",s.stroke).attr("fill","white").attr("cx",9).attr("cy",18).attr("r",6),u.append("path").attr("stroke",s.stroke).attr("fill","none").attr("d","M21,18 Q39,0 57,18 Q39,36 21,18")}},Oen=/^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000)$/i;function Nen(i){return typeof i=="string"&&Oen.test(i)}const Ud=[];for(let i=0;i<256;++i)Ud.push((i+256).toString(16).slice(1));function Pen(i,s=0){return Ud[i[s+0]]+Ud[i[s+1]]+Ud[i[s+2]]+Ud[i[s+3]]+"-"+Ud[i[s+4]]+Ud[i[s+5]]+"-"+Ud[i[s+6]]+Ud[i[s+7]]+"-"+Ud[i[s+8]]+Ud[i[s+9]]+"-"+Ud[i[s+10]]+Ud[i[s+11]]+Ud[i[s+12]]+Ud[i[s+13]]+Ud[i[s+14]]+Ud[i[s+15]]}function Ben(i){if(!Nen(i))throw TypeError("Invalid UUID");let s;const u=new Uint8Array(16);return u[0]=(s=parseInt(i.slice(0,8),16))>>>24,u[1]=s>>>16&255,u[2]=s>>>8&255,u[3]=s&255,u[4]=(s=parseInt(i.slice(9,13),16))>>>8,u[5]=s&255,u[6]=(s=parseInt(i.slice(14,18),16))>>>8,u[7]=s&255,u[8]=(s=parseInt(i.slice(19,23),16))>>>8,u[9]=s&255,u[10]=(s=parseInt(i.slice(24,36),16))/1099511627776&255,u[11]=s/4294967296&255,u[12]=s>>>24&255,u[13]=s>>>16&255,u[14]=s>>>8&255,u[15]=s&255,u}function Fen(i){i=unescape(encodeURIComponent(i));const s=[];for(let u=0;u>>32-s}function qen(i){const s=[1518500249,1859775393,2400959708,3395469782],u=[1732584193,4023233417,2562383102,271733878,3285377520];if(typeof i=="string"){const b=unescape(encodeURIComponent(i));i=[];for(let y=0;y>>0;R=P,P=A,A=Gme(_,30)>>>0,_=T,T=K}u[0]=u[0]+T>>>0,u[1]=u[1]+_>>>0,u[2]=u[2]+A>>>0,u[3]=u[3]+P>>>0,u[4]=u[4]+R>>>0}return[u[0]>>24&255,u[0]>>16&255,u[0]>>8&255,u[0]&255,u[1]>>24&255,u[1]>>16&255,u[1]>>8&255,u[1]&255,u[2]>>24&255,u[2]>>16&255,u[2]>>8&255,u[2]&255,u[3]>>24&255,u[3]>>16&255,u[3]>>8&255,u[3]&255,u[4]>>24&255,u[4]>>16&255,u[4]>>8&255,u[4]&255]}const Hen=$en("v5",80,qen),Ven=/[^\dA-Za-z](\W)*/g;let p1={},IR=new Map;const Uen=function(i){const s=Object.keys(i);for(const u of s)p1[u]=i[u]},Gen=(i,s,u)=>{const d=p1.entityPadding/3,p=p1.entityPadding/3,v=p1.fontSize*.85,b=s.node().getBBox(),y=[];let T=!1,_=!1,A=0,P=0,R=0,F=0,j=b.height+d*2,K=1;u.forEach(pe=>{pe.attributeKeyTypeList!==void 0&&pe.attributeKeyTypeList.length>0&&(T=!0),pe.attributeComment!==void 0&&(_=!0)}),u.forEach(pe=>{const be=`${s.node().id}-attr-${K}`;let ae=0;const ne=qF(pe.attributeType),se=i.append("text").classed("er entityLabel",!0).attr("id",`${be}-type`).attr("x",0).attr("y",0).style("dominant-baseline","middle").style("text-anchor","left").style("font-family",qt().fontFamily).style("font-size",v+"px").text(ne),de=i.append("text").classed("er entityLabel",!0).attr("id",`${be}-name`).attr("x",0).attr("y",0).style("dominant-baseline","middle").style("text-anchor","left").style("font-family",qt().fontFamily).style("font-size",v+"px").text(pe.attributeName),X={};X.tn=se,X.nn=de;const ge=se.node().getBBox(),W=de.node().getBBox();if(A=Math.max(A,ge.width),P=Math.max(P,W.width),ae=Math.max(ge.height,W.height),T){const xe=pe.attributeKeyTypeList!==void 0?pe.attributeKeyTypeList.join(","):"",U=i.append("text").classed("er entityLabel",!0).attr("id",`${be}-key`).attr("x",0).attr("y",0).style("dominant-baseline","middle").style("text-anchor","left").style("font-family",qt().fontFamily).style("font-size",v+"px").text(xe);X.kn=U;const Fe=U.node().getBBox();R=Math.max(R,Fe.width),ae=Math.max(ae,Fe.height)}if(_){const xe=i.append("text").classed("er entityLabel",!0).attr("id",`${be}-comment`).attr("x",0).attr("y",0).style("dominant-baseline","middle").style("text-anchor","left").style("font-family",qt().fontFamily).style("font-size",v+"px").text(pe.attributeComment||"");X.cn=xe;const U=xe.node().getBBox();F=Math.max(F,U.width),ae=Math.max(ae,U.height)}X.height=ae,y.push(X),j+=ae+d*2,K+=1});let ee=4;T&&(ee+=2),_&&(ee+=2);const ie=A+P+R+F,oe={width:Math.max(p1.minEntityWidth,Math.max(b.width+p1.entityPadding*2,ie+p*ee)),height:u.length>0?j:Math.max(p1.minEntityHeight,b.height+p1.entityPadding*2)};if(u.length>0){const pe=Math.max(0,(oe.width-ie-p*ee)/(ee/2));s.attr("transform","translate("+oe.width/2+","+(d+b.height/2)+")");let be=b.height+d*2,ae="attributeBoxOdd";y.forEach(ne=>{const se=be+d+ne.height/2;ne.tn.attr("transform","translate("+p+","+se+")");const de=i.insert("rect","#"+ne.tn.node().id).classed(`er ${ae}`,!0).attr("x",0).attr("y",be).attr("width",A+p*2+pe).attr("height",ne.height+d*2),X=parseFloat(de.attr("x"))+parseFloat(de.attr("width"));ne.nn.attr("transform","translate("+(X+p)+","+se+")");const ge=i.insert("rect","#"+ne.nn.node().id).classed(`er ${ae}`,!0).attr("x",X).attr("y",be).attr("width",P+p*2+pe).attr("height",ne.height+d*2);let W=parseFloat(ge.attr("x"))+parseFloat(ge.attr("width"));if(T){ne.kn.attr("transform","translate("+(W+p)+","+se+")");const xe=i.insert("rect","#"+ne.kn.node().id).classed(`er ${ae}`,!0).attr("x",W).attr("y",be).attr("width",R+p*2+pe).attr("height",ne.height+d*2);W=parseFloat(xe.attr("x"))+parseFloat(xe.attr("width"))}_&&(ne.cn.attr("transform","translate("+(W+p)+","+se+")"),i.insert("rect","#"+ne.cn.node().id).classed(`er ${ae}`,"true").attr("x",W).attr("y",be).attr("width",F+p*2+pe).attr("height",ne.height+d*2)),be+=ne.height+d*2,ae=ae==="attributeBoxOdd"?"attributeBoxEven":"attributeBoxOdd"})}else oe.height=Math.max(p1.minEntityHeight,j),s.attr("transform","translate("+oe.width/2+","+oe.height/2+")");return oe},Ken=function(i,s,u){const d=Object.keys(s);let p;return d.forEach(function(v){const b=Zen(v,"entity");IR.set(v,b);const y=i.append("g").attr("id",b);p=p===void 0?b:p;const T="text-"+b,_=y.append("text").classed("er entityLabel",!0).attr("id",T).attr("x",0).attr("y",0).style("dominant-baseline","middle").style("text-anchor","middle").style("font-family",qt().fontFamily).style("font-size",p1.fontSize+"px").text(s[v].alias??v),{width:A,height:P}=Gen(y,_,s[v].attributes),F=y.insert("rect","#"+T).classed("er entityBox",!0).attr("x",0).attr("y",0).attr("width",A).attr("height",P).node().getBBox();u.setNode(b,{width:F.width,height:F.height,shape:"rect",id:b})}),p},Wen=function(i,s){s.nodes().forEach(function(u){u!==void 0&&s.node(u)!==void 0&&i.select("#"+u).attr("transform","translate("+(s.node(u).x-s.node(u).width/2)+","+(s.node(u).y-s.node(u).height/2)+" )")})},jUe=function(i){return(i.entityA+i.roleA+i.entityB).replace(/\s/g,"")},Yen=function(i,s){return i.forEach(function(u){s.setEdge(IR.get(u.entityA),IR.get(u.entityB),{relationship:u},jUe(u))}),i};let $Ue=0;const Xen=function(i,s,u,d,p){$Ue++;const v=u.edge(IR.get(s.entityA),IR.get(s.entityB),jUe(s)),b=k7().x(function(j){return j.x}).y(function(j){return j.y}).curve(FF),y=i.insert("path","#"+d).classed("er relationshipLine",!0).attr("d",b(v.points)).style("stroke",p1.stroke).style("fill","none");s.relSpec.relType===p.db.Identification.NON_IDENTIFYING&&y.attr("stroke-dasharray","8,8");let T="";switch(p1.arrowMarkerAbsolute&&(T=window.location.protocol+"//"+window.location.host+window.location.pathname+window.location.search,T=T.replace(/\(/g,"\\("),T=T.replace(/\)/g,"\\)")),s.relSpec.cardA){case p.db.Cardinality.ZERO_OR_ONE:y.attr("marker-end","url("+T+"#"+G3.ERMarkers.ZERO_OR_ONE_END+")");break;case p.db.Cardinality.ZERO_OR_MORE:y.attr("marker-end","url("+T+"#"+G3.ERMarkers.ZERO_OR_MORE_END+")");break;case p.db.Cardinality.ONE_OR_MORE:y.attr("marker-end","url("+T+"#"+G3.ERMarkers.ONE_OR_MORE_END+")");break;case p.db.Cardinality.ONLY_ONE:y.attr("marker-end","url("+T+"#"+G3.ERMarkers.ONLY_ONE_END+")");break;case p.db.Cardinality.MD_PARENT:y.attr("marker-end","url("+T+"#"+G3.ERMarkers.MD_PARENT_END+")");break}switch(s.relSpec.cardB){case p.db.Cardinality.ZERO_OR_ONE:y.attr("marker-start","url("+T+"#"+G3.ERMarkers.ZERO_OR_ONE_START+")");break;case p.db.Cardinality.ZERO_OR_MORE:y.attr("marker-start","url("+T+"#"+G3.ERMarkers.ZERO_OR_MORE_START+")");break;case p.db.Cardinality.ONE_OR_MORE:y.attr("marker-start","url("+T+"#"+G3.ERMarkers.ONE_OR_MORE_START+")");break;case p.db.Cardinality.ONLY_ONE:y.attr("marker-start","url("+T+"#"+G3.ERMarkers.ONLY_ONE_START+")");break;case p.db.Cardinality.MD_PARENT:y.attr("marker-start","url("+T+"#"+G3.ERMarkers.MD_PARENT_START+")");break}const _=y.node().getTotalLength(),A=y.node().getPointAtLength(_*.5),P="rel"+$Ue,F=i.append("text").classed("er relationshipLabel",!0).attr("id",P).attr("x",A.x).attr("y",A.y).style("text-anchor","middle").style("dominant-baseline","middle").style("font-family",qt().fontFamily).style("font-size",p1.fontSize+"px").text(s.roleA).node().getBBox();i.insert("rect","#"+P).classed("er relationshipLabelBox",!0).attr("x",A.x-F.width/2).attr("y",A.y-F.height/2).attr("width",F.width).attr("height",F.height)},Qen=function(i,s,u,d){p1=qt().er,Xe.info("Drawing ER diagram");const p=qt().securityLevel;let v;p==="sandbox"&&(v=Ir("#i"+s));const y=Ir(p==="sandbox"?v.nodes()[0].contentDocument.body:"body").select(`[id='${s}']`);G3.insertMarkers(y,p1);let T;T=new B0({multigraph:!0,directed:!0,compound:!1}).setGraph({rankdir:p1.layoutDirection,marginx:20,marginy:20,nodesep:100,edgesep:100,ranksep:100}).setDefaultEdgeLabel(function(){return{}});const _=Ken(y,d.db.getEntities(),T),A=Yen(d.db.getRelationships(),T);qD(T),Wen(y,T),A.forEach(function(K){Xen(y,K,T,_,d)});const P=p1.diagramPadding;Ao.insertTitle(y,"entityTitleText",p1.titleTopMargin,d.db.getDiagramTitle());const R=y.node().getBBox(),F=R.width+P*2,j=R.height+P*2;Ng(y,j,F,p1.useMaxWidth),y.attr("viewBox",`${R.x-P} ${R.y-P} ${F} ${j}`)},Jen="28e9f9db-3c8d-5aa5-9faf-44286ae5937c";function Zen(i="",s=""){const u=i.replace(Ven,"");return`${zUe(s)}${zUe(u)}${Hen(i,Jen)}`}function zUe(i=""){return i.length>0?`${i}-`:""}const etn=Object.freeze(Object.defineProperty({__proto__:null,diagram:{parser:Len,db:Ien,renderer:{setConf:Uen,draw:Qen},styles:i=>` + .entityBox { + fill: ${i.mainBkg}; + stroke: ${i.nodeBorder}; + } + + .attributeBoxOdd { + fill: ${i.attributeBackgroundColorOdd}; + stroke: ${i.nodeBorder}; + } + + .attributeBoxEven { + fill: ${i.attributeBackgroundColorEven}; + stroke: ${i.nodeBorder}; + } + + .relationshipLabelBox { + fill: ${i.tertiaryColor}; + opacity: 0.7; + background-color: ${i.tertiaryColor}; + rect { + opacity: 0.5; + } + } + + .relationshipLine { + stroke: ${i.lineColor}; + } + + .entityTitleText { + text-anchor: middle; + font-size: 18px; + fill: ${i.textColor}; + } + #MD_PARENT_START { + fill: #f5f5f5 !important; + stroke: ${i.lineColor} !important; + stroke-width: 1; + } + #MD_PARENT_END { + fill: #f5f5f5 !important; + stroke: ${i.lineColor} !important; + stroke-width: 1; + } + +`}},Symbol.toStringTag,{value:"Module"}));var Kme=function(){var i=function(ae,ne,se,de){for(se=se||{},de=ae.length;de--;se[ae[de]]=ne);return se},s=[1,3],u=[1,6],d=[1,4],p=[1,5],v=[2,5],b=[1,12],y=[5,7,13,19,21,23,24,26,28,31,37,40,47],T=[7,13,19,21,23,24,26,28,31,37,40],_=[7,12,13,19,21,23,24,26,28,31,37,40],A=[7,13,47],P=[1,42],R=[1,41],F=[7,13,29,32,35,38,47],j=[1,55],K=[1,56],ee=[1,57],ie=[7,13,32,35,42,47],oe={trace:function(){},yy:{},symbols_:{error:2,start:3,eol:4,GG:5,document:6,EOF:7,":":8,DIR:9,options:10,body:11,OPT:12,NL:13,line:14,statement:15,commitStatement:16,mergeStatement:17,cherryPickStatement:18,acc_title:19,acc_title_value:20,acc_descr:21,acc_descr_value:22,acc_descr_multiline_value:23,section:24,branchStatement:25,CHECKOUT:26,ref:27,BRANCH:28,ORDER:29,NUM:30,CHERRY_PICK:31,COMMIT_ID:32,STR:33,PARENT_COMMIT:34,COMMIT_TAG:35,EMPTYSTR:36,MERGE:37,COMMIT_TYPE:38,commitType:39,COMMIT:40,commit_arg:41,COMMIT_MSG:42,NORMAL:43,REVERSE:44,HIGHLIGHT:45,ID:46,";":47,$accept:0,$end:1},terminals_:{2:"error",5:"GG",7:"EOF",8:":",9:"DIR",12:"OPT",13:"NL",19:"acc_title",20:"acc_title_value",21:"acc_descr",22:"acc_descr_value",23:"acc_descr_multiline_value",24:"section",26:"CHECKOUT",28:"BRANCH",29:"ORDER",30:"NUM",31:"CHERRY_PICK",32:"COMMIT_ID",33:"STR",34:"PARENT_COMMIT",35:"COMMIT_TAG",36:"EMPTYSTR",37:"MERGE",38:"COMMIT_TYPE",40:"COMMIT",42:"COMMIT_MSG",43:"NORMAL",44:"REVERSE",45:"HIGHLIGHT",46:"ID",47:";"},productions_:[0,[3,2],[3,3],[3,4],[3,5],[6,0],[6,2],[10,2],[10,1],[11,0],[11,2],[14,2],[14,1],[15,1],[15,1],[15,1],[15,2],[15,2],[15,1],[15,1],[15,1],[15,2],[25,2],[25,4],[18,3],[18,5],[18,5],[18,7],[18,7],[18,5],[18,5],[18,5],[18,7],[18,7],[18,7],[18,7],[17,2],[17,4],[17,4],[17,4],[17,6],[17,6],[17,6],[17,6],[17,6],[17,6],[17,8],[17,8],[17,8],[17,8],[17,8],[17,8],[16,2],[16,3],[16,3],[16,5],[16,5],[16,3],[16,5],[16,5],[16,5],[16,5],[16,7],[16,7],[16,7],[16,7],[16,7],[16,7],[16,3],[16,5],[16,5],[16,5],[16,5],[16,5],[16,5],[16,7],[16,7],[16,7],[16,7],[16,7],[16,7],[16,7],[16,7],[16,7],[16,7],[16,7],[16,7],[16,7],[16,7],[16,7],[16,7],[16,7],[16,7],[16,9],[16,9],[16,9],[16,9],[16,9],[16,9],[16,9],[16,9],[16,9],[16,9],[16,9],[16,9],[16,9],[16,9],[16,9],[16,9],[16,9],[16,9],[16,9],[16,9],[16,9],[16,9],[16,9],[16,9],[41,0],[41,1],[39,1],[39,1],[39,1],[27,1],[27,1],[4,1],[4,1],[4,1]],performAction:function(ne,se,de,X,ge,W,xe){var U=W.length-1;switch(ge){case 2:return W[U];case 3:return W[U-1];case 4:return X.setDirection(W[U-3]),W[U-1];case 6:X.setOptions(W[U-1]),this.$=W[U];break;case 7:W[U-1]+=W[U],this.$=W[U-1];break;case 9:this.$=[];break;case 10:W[U-1].push(W[U]),this.$=W[U-1];break;case 11:this.$=W[U-1];break;case 16:this.$=W[U].trim(),X.setAccTitle(this.$);break;case 17:case 18:this.$=W[U].trim(),X.setAccDescription(this.$);break;case 19:X.addSection(W[U].substr(8)),this.$=W[U].substr(8);break;case 21:X.checkout(W[U]);break;case 22:X.branch(W[U]);break;case 23:X.branch(W[U-2],W[U]);break;case 24:X.cherryPick(W[U],"",void 0);break;case 25:X.cherryPick(W[U-2],"",void 0,W[U]);break;case 26:X.cherryPick(W[U-2],"",W[U]);break;case 27:X.cherryPick(W[U-4],"",W[U],W[U-2]);break;case 28:X.cherryPick(W[U-4],"",W[U-2],W[U]);break;case 29:X.cherryPick(W[U],"",W[U-2]);break;case 30:X.cherryPick(W[U],"","");break;case 31:X.cherryPick(W[U-2],"","");break;case 32:X.cherryPick(W[U-4],"","",W[U-2]);break;case 33:X.cherryPick(W[U-4],"","",W[U]);break;case 34:X.cherryPick(W[U-2],"",W[U-4],W[U]);break;case 35:X.cherryPick(W[U-2],"","",W[U]);break;case 36:X.merge(W[U],"","","");break;case 37:X.merge(W[U-2],W[U],"","");break;case 38:X.merge(W[U-2],"",W[U],"");break;case 39:X.merge(W[U-2],"","",W[U]);break;case 40:X.merge(W[U-4],W[U],"",W[U-2]);break;case 41:X.merge(W[U-4],"",W[U],W[U-2]);break;case 42:X.merge(W[U-4],"",W[U-2],W[U]);break;case 43:X.merge(W[U-4],W[U-2],W[U],"");break;case 44:X.merge(W[U-4],W[U-2],"",W[U]);break;case 45:X.merge(W[U-4],W[U],W[U-2],"");break;case 46:X.merge(W[U-6],W[U-4],W[U-2],W[U]);break;case 47:X.merge(W[U-6],W[U],W[U-4],W[U-2]);break;case 48:X.merge(W[U-6],W[U-4],W[U],W[U-2]);break;case 49:X.merge(W[U-6],W[U-2],W[U-4],W[U]);break;case 50:X.merge(W[U-6],W[U],W[U-2],W[U-4]);break;case 51:X.merge(W[U-6],W[U-2],W[U],W[U-4]);break;case 52:X.commit(W[U]);break;case 53:X.commit("","",X.commitType.NORMAL,W[U]);break;case 54:X.commit("","",W[U],"");break;case 55:X.commit("","",W[U],W[U-2]);break;case 56:X.commit("","",W[U-2],W[U]);break;case 57:X.commit("",W[U],X.commitType.NORMAL,"");break;case 58:X.commit("",W[U-2],X.commitType.NORMAL,W[U]);break;case 59:X.commit("",W[U],X.commitType.NORMAL,W[U-2]);break;case 60:X.commit("",W[U-2],W[U],"");break;case 61:X.commit("",W[U],W[U-2],"");break;case 62:X.commit("",W[U-4],W[U-2],W[U]);break;case 63:X.commit("",W[U-4],W[U],W[U-2]);break;case 64:X.commit("",W[U-2],W[U-4],W[U]);break;case 65:X.commit("",W[U],W[U-4],W[U-2]);break;case 66:X.commit("",W[U],W[U-2],W[U-4]);break;case 67:X.commit("",W[U-2],W[U],W[U-4]);break;case 68:X.commit(W[U],"",X.commitType.NORMAL,"");break;case 69:X.commit(W[U],"",X.commitType.NORMAL,W[U-2]);break;case 70:X.commit(W[U-2],"",X.commitType.NORMAL,W[U]);break;case 71:X.commit(W[U-2],"",W[U],"");break;case 72:X.commit(W[U],"",W[U-2],"");break;case 73:X.commit(W[U],W[U-2],X.commitType.NORMAL,"");break;case 74:X.commit(W[U-2],W[U],X.commitType.NORMAL,"");break;case 75:X.commit(W[U-4],"",W[U-2],W[U]);break;case 76:X.commit(W[U-4],"",W[U],W[U-2]);break;case 77:X.commit(W[U-2],"",W[U-4],W[U]);break;case 78:X.commit(W[U],"",W[U-4],W[U-2]);break;case 79:X.commit(W[U],"",W[U-2],W[U-4]);break;case 80:X.commit(W[U-2],"",W[U],W[U-4]);break;case 81:X.commit(W[U-4],W[U],W[U-2],"");break;case 82:X.commit(W[U-4],W[U-2],W[U],"");break;case 83:X.commit(W[U-2],W[U],W[U-4],"");break;case 84:X.commit(W[U],W[U-2],W[U-4],"");break;case 85:X.commit(W[U],W[U-4],W[U-2],"");break;case 86:X.commit(W[U-2],W[U-4],W[U],"");break;case 87:X.commit(W[U-4],W[U],X.commitType.NORMAL,W[U-2]);break;case 88:X.commit(W[U-4],W[U-2],X.commitType.NORMAL,W[U]);break;case 89:X.commit(W[U-2],W[U],X.commitType.NORMAL,W[U-4]);break;case 90:X.commit(W[U],W[U-2],X.commitType.NORMAL,W[U-4]);break;case 91:X.commit(W[U],W[U-4],X.commitType.NORMAL,W[U-2]);break;case 92:X.commit(W[U-2],W[U-4],X.commitType.NORMAL,W[U]);break;case 93:X.commit(W[U-6],W[U-4],W[U-2],W[U]);break;case 94:X.commit(W[U-6],W[U-4],W[U],W[U-2]);break;case 95:X.commit(W[U-6],W[U-2],W[U-4],W[U]);break;case 96:X.commit(W[U-6],W[U],W[U-4],W[U-2]);break;case 97:X.commit(W[U-6],W[U-2],W[U],W[U-4]);break;case 98:X.commit(W[U-6],W[U],W[U-2],W[U-4]);break;case 99:X.commit(W[U-4],W[U-6],W[U-2],W[U]);break;case 100:X.commit(W[U-4],W[U-6],W[U],W[U-2]);break;case 101:X.commit(W[U-2],W[U-6],W[U-4],W[U]);break;case 102:X.commit(W[U],W[U-6],W[U-4],W[U-2]);break;case 103:X.commit(W[U-2],W[U-6],W[U],W[U-4]);break;case 104:X.commit(W[U],W[U-6],W[U-2],W[U-4]);break;case 105:X.commit(W[U],W[U-4],W[U-2],W[U-6]);break;case 106:X.commit(W[U-2],W[U-4],W[U],W[U-6]);break;case 107:X.commit(W[U],W[U-2],W[U-4],W[U-6]);break;case 108:X.commit(W[U-2],W[U],W[U-4],W[U-6]);break;case 109:X.commit(W[U-4],W[U-2],W[U],W[U-6]);break;case 110:X.commit(W[U-4],W[U],W[U-2],W[U-6]);break;case 111:X.commit(W[U-2],W[U-4],W[U-6],W[U]);break;case 112:X.commit(W[U],W[U-4],W[U-6],W[U-2]);break;case 113:X.commit(W[U-2],W[U],W[U-6],W[U-4]);break;case 114:X.commit(W[U],W[U-2],W[U-6],W[U-4]);break;case 115:X.commit(W[U-4],W[U-2],W[U-6],W[U]);break;case 116:X.commit(W[U-4],W[U],W[U-6],W[U-2]);break;case 117:this.$="";break;case 118:this.$=W[U];break;case 119:this.$=X.commitType.NORMAL;break;case 120:this.$=X.commitType.REVERSE;break;case 121:this.$=X.commitType.HIGHLIGHT;break}},table:[{3:1,4:2,5:s,7:u,13:d,47:p},{1:[3]},{3:7,4:2,5:s,7:u,13:d,47:p},{6:8,7:v,8:[1,9],9:[1,10],10:11,13:b},i(y,[2,124]),i(y,[2,125]),i(y,[2,126]),{1:[2,1]},{7:[1,13]},{6:14,7:v,10:11,13:b},{8:[1,15]},i(T,[2,9],{11:16,12:[1,17]}),i(_,[2,8]),{1:[2,2]},{7:[1,18]},{6:19,7:v,10:11,13:b},{7:[2,6],13:[1,22],14:20,15:21,16:23,17:24,18:25,19:[1,26],21:[1,27],23:[1,28],24:[1,29],25:30,26:[1,31],28:[1,35],31:[1,34],37:[1,33],40:[1,32]},i(_,[2,7]),{1:[2,3]},{7:[1,36]},i(T,[2,10]),{4:37,7:u,13:d,47:p},i(T,[2,12]),i(A,[2,13]),i(A,[2,14]),i(A,[2,15]),{20:[1,38]},{22:[1,39]},i(A,[2,18]),i(A,[2,19]),i(A,[2,20]),{27:40,33:P,46:R},i(A,[2,117],{41:43,32:[1,46],33:[1,48],35:[1,44],38:[1,45],42:[1,47]}),{27:49,33:P,46:R},{32:[1,50],35:[1,51]},{27:52,33:P,46:R},{1:[2,4]},i(T,[2,11]),i(A,[2,16]),i(A,[2,17]),i(A,[2,21]),i(F,[2,122]),i(F,[2,123]),i(A,[2,52]),{33:[1,53]},{39:54,43:j,44:K,45:ee},{33:[1,58]},{33:[1,59]},i(A,[2,118]),i(A,[2,36],{32:[1,60],35:[1,62],38:[1,61]}),{33:[1,63]},{33:[1,64],36:[1,65]},i(A,[2,22],{29:[1,66]}),i(A,[2,53],{32:[1,68],38:[1,67],42:[1,69]}),i(A,[2,54],{32:[1,71],35:[1,70],42:[1,72]}),i(ie,[2,119]),i(ie,[2,120]),i(ie,[2,121]),i(A,[2,57],{35:[1,73],38:[1,74],42:[1,75]}),i(A,[2,68],{32:[1,78],35:[1,76],38:[1,77]}),{33:[1,79]},{39:80,43:j,44:K,45:ee},{33:[1,81]},i(A,[2,24],{34:[1,82],35:[1,83]}),{32:[1,84]},{32:[1,85]},{30:[1,86]},{39:87,43:j,44:K,45:ee},{33:[1,88]},{33:[1,89]},{33:[1,90]},{33:[1,91]},{33:[1,92]},{33:[1,93]},{39:94,43:j,44:K,45:ee},{33:[1,95]},{33:[1,96]},{39:97,43:j,44:K,45:ee},{33:[1,98]},i(A,[2,37],{35:[1,100],38:[1,99]}),i(A,[2,38],{32:[1,102],35:[1,101]}),i(A,[2,39],{32:[1,103],38:[1,104]}),{33:[1,105]},{33:[1,106],36:[1,107]},{33:[1,108]},{33:[1,109]},i(A,[2,23]),i(A,[2,55],{32:[1,110],42:[1,111]}),i(A,[2,59],{38:[1,112],42:[1,113]}),i(A,[2,69],{32:[1,115],38:[1,114]}),i(A,[2,56],{32:[1,116],42:[1,117]}),i(A,[2,61],{35:[1,118],42:[1,119]}),i(A,[2,72],{32:[1,121],35:[1,120]}),i(A,[2,58],{38:[1,122],42:[1,123]}),i(A,[2,60],{35:[1,124],42:[1,125]}),i(A,[2,73],{35:[1,127],38:[1,126]}),i(A,[2,70],{32:[1,129],38:[1,128]}),i(A,[2,71],{32:[1,131],35:[1,130]}),i(A,[2,74],{35:[1,133],38:[1,132]}),{39:134,43:j,44:K,45:ee},{33:[1,135]},{33:[1,136]},{33:[1,137]},{33:[1,138]},{39:139,43:j,44:K,45:ee},i(A,[2,25],{35:[1,140]}),i(A,[2,26],{34:[1,141]}),i(A,[2,31],{34:[1,142]}),i(A,[2,29],{34:[1,143]}),i(A,[2,30],{34:[1,144]}),{33:[1,145]},{33:[1,146]},{39:147,43:j,44:K,45:ee},{33:[1,148]},{39:149,43:j,44:K,45:ee},{33:[1,150]},{33:[1,151]},{33:[1,152]},{33:[1,153]},{33:[1,154]},{33:[1,155]},{33:[1,156]},{39:157,43:j,44:K,45:ee},{33:[1,158]},{33:[1,159]},{33:[1,160]},{39:161,43:j,44:K,45:ee},{33:[1,162]},{39:163,43:j,44:K,45:ee},{33:[1,164]},{33:[1,165]},{33:[1,166]},{39:167,43:j,44:K,45:ee},{33:[1,168]},i(A,[2,43],{35:[1,169]}),i(A,[2,44],{38:[1,170]}),i(A,[2,42],{32:[1,171]}),i(A,[2,45],{35:[1,172]}),i(A,[2,40],{38:[1,173]}),i(A,[2,41],{32:[1,174]}),{33:[1,175],36:[1,176]},{33:[1,177]},{33:[1,178]},{33:[1,179]},{33:[1,180]},i(A,[2,66],{42:[1,181]}),i(A,[2,79],{32:[1,182]}),i(A,[2,67],{42:[1,183]}),i(A,[2,90],{38:[1,184]}),i(A,[2,80],{32:[1,185]}),i(A,[2,89],{38:[1,186]}),i(A,[2,65],{42:[1,187]}),i(A,[2,78],{32:[1,188]}),i(A,[2,64],{42:[1,189]}),i(A,[2,84],{35:[1,190]}),i(A,[2,77],{32:[1,191]}),i(A,[2,83],{35:[1,192]}),i(A,[2,63],{42:[1,193]}),i(A,[2,91],{38:[1,194]}),i(A,[2,62],{42:[1,195]}),i(A,[2,85],{35:[1,196]}),i(A,[2,86],{35:[1,197]}),i(A,[2,92],{38:[1,198]}),i(A,[2,76],{32:[1,199]}),i(A,[2,87],{38:[1,200]}),i(A,[2,75],{32:[1,201]}),i(A,[2,81],{35:[1,202]}),i(A,[2,82],{35:[1,203]}),i(A,[2,88],{38:[1,204]}),{33:[1,205]},{39:206,43:j,44:K,45:ee},{33:[1,207]},{33:[1,208]},{39:209,43:j,44:K,45:ee},{33:[1,210]},i(A,[2,27]),i(A,[2,32]),i(A,[2,28]),i(A,[2,33]),i(A,[2,34]),i(A,[2,35]),{33:[1,211]},{33:[1,212]},{33:[1,213]},{39:214,43:j,44:K,45:ee},{33:[1,215]},{39:216,43:j,44:K,45:ee},{33:[1,217]},{33:[1,218]},{33:[1,219]},{33:[1,220]},{33:[1,221]},{33:[1,222]},{33:[1,223]},{39:224,43:j,44:K,45:ee},{33:[1,225]},{33:[1,226]},{33:[1,227]},{39:228,43:j,44:K,45:ee},{33:[1,229]},{39:230,43:j,44:K,45:ee},{33:[1,231]},{33:[1,232]},{33:[1,233]},{39:234,43:j,44:K,45:ee},i(A,[2,46]),i(A,[2,48]),i(A,[2,47]),i(A,[2,49]),i(A,[2,51]),i(A,[2,50]),i(A,[2,107]),i(A,[2,108]),i(A,[2,105]),i(A,[2,106]),i(A,[2,110]),i(A,[2,109]),i(A,[2,114]),i(A,[2,113]),i(A,[2,112]),i(A,[2,111]),i(A,[2,116]),i(A,[2,115]),i(A,[2,104]),i(A,[2,103]),i(A,[2,102]),i(A,[2,101]),i(A,[2,99]),i(A,[2,100]),i(A,[2,98]),i(A,[2,97]),i(A,[2,96]),i(A,[2,95]),i(A,[2,93]),i(A,[2,94])],defaultActions:{7:[2,1],13:[2,2],18:[2,3],36:[2,4]},parseError:function(ne,se){if(se.recoverable)this.trace(ne);else{var de=new Error(ne);throw de.hash=se,de}},parse:function(ne){var se=this,de=[0],X=[],ge=[null],W=[],xe=this.table,U="",Fe=0,Pe=0,je=2,Ie=1,Se=W.slice.call(arguments,1),Ce=Object.create(this.lexer),ke={yy:{}};for(var Ke in this.yy)Object.prototype.hasOwnProperty.call(this.yy,Ke)&&(ke.yy[Ke]=this.yy[Ke]);Ce.setInput(ne,ke.yy),ke.yy.lexer=Ce,ke.yy.parser=this,typeof Ce.yylloc>"u"&&(Ce.yylloc={});var Ft=Ce.yylloc;W.push(Ft);var Ne=Ce.options&&Ce.options.ranges;typeof ke.yy.parseError=="function"?this.parseError=ke.yy.parseError:this.parseError=Object.getPrototypeOf(this).parseError;function gn(){var ht;return ht=X.pop()||Ce.lex()||Ie,typeof ht!="number"&&(ht instanceof Array&&(X=ht,ht=X.pop()),ht=se.symbols_[ht]||ht),ht}for(var _t,Et,Gt,ln,xt={},Pt,Qe,Dt,kt;;){if(Et=de[de.length-1],this.defaultActions[Et]?Gt=this.defaultActions[Et]:((_t===null||typeof _t>"u")&&(_t=gn()),Gt=xe[Et]&&xe[Et][_t]),typeof Gt>"u"||!Gt.length||!Gt[0]){var On="";kt=[];for(Pt in xe[Et])this.terminals_[Pt]&&Pt>je&&kt.push("'"+this.terminals_[Pt]+"'");Ce.showPosition?On="Parse error on line "+(Fe+1)+`: +`+Ce.showPosition()+` +Expecting `+kt.join(", ")+", got '"+(this.terminals_[_t]||_t)+"'":On="Parse error on line "+(Fe+1)+": Unexpected "+(_t==Ie?"end of input":"'"+(this.terminals_[_t]||_t)+"'"),this.parseError(On,{text:Ce.match,token:this.terminals_[_t]||_t,line:Ce.yylineno,loc:Ft,expected:kt})}if(Gt[0]instanceof Array&&Gt.length>1)throw new Error("Parse Error: multiple actions possible at state: "+Et+", token: "+_t);switch(Gt[0]){case 1:de.push(_t),ge.push(Ce.yytext),W.push(Ce.yylloc),de.push(Gt[1]),_t=null,Pe=Ce.yyleng,U=Ce.yytext,Fe=Ce.yylineno,Ft=Ce.yylloc;break;case 2:if(Qe=this.productions_[Gt[1]][1],xt.$=ge[ge.length-Qe],xt._$={first_line:W[W.length-(Qe||1)].first_line,last_line:W[W.length-1].last_line,first_column:W[W.length-(Qe||1)].first_column,last_column:W[W.length-1].last_column},Ne&&(xt._$.range=[W[W.length-(Qe||1)].range[0],W[W.length-1].range[1]]),ln=this.performAction.apply(xt,[U,Pe,Fe,ke.yy,Gt[1],ge,W].concat(Se)),typeof ln<"u")return ln;Qe&&(de=de.slice(0,-1*Qe*2),ge=ge.slice(0,-1*Qe),W=W.slice(0,-1*Qe)),de.push(this.productions_[Gt[1]][0]),ge.push(xt.$),W.push(xt._$),Dt=xe[de[de.length-2]][de[de.length-1]],de.push(Dt);break;case 3:return!0}}return!0}},pe=function(){var ae={EOF:1,parseError:function(se,de){if(this.yy.parser)this.yy.parser.parseError(se,de);else throw new Error(se)},setInput:function(ne,se){return this.yy=se||this.yy||{},this._input=ne,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},input:function(){var ne=this._input[0];this.yytext+=ne,this.yyleng++,this.offset++,this.match+=ne,this.matched+=ne;var se=ne.match(/(?:\r\n?|\n).*/g);return se?(this.yylineno++,this.yylloc.last_line++):this.yylloc.last_column++,this.options.ranges&&this.yylloc.range[1]++,this._input=this._input.slice(1),ne},unput:function(ne){var se=ne.length,de=ne.split(/(?:\r\n?|\n)/g);this._input=ne+this._input,this.yytext=this.yytext.substr(0,this.yytext.length-se),this.offset-=se;var X=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),de.length-1&&(this.yylineno-=de.length-1);var ge=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:de?(de.length===X.length?this.yylloc.first_column:0)+X[X.length-de.length].length-de[0].length:this.yylloc.first_column-se},this.options.ranges&&(this.yylloc.range=[ge[0],ge[0]+this.yyleng-se]),this.yyleng=this.yytext.length,this},more:function(){return this._more=!0,this},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},less:function(ne){this.unput(this.match.slice(ne))},pastInput:function(){var ne=this.matched.substr(0,this.matched.length-this.match.length);return(ne.length>20?"...":"")+ne.substr(-20).replace(/\n/g,"")},upcomingInput:function(){var ne=this.match;return ne.length<20&&(ne+=this._input.substr(0,20-ne.length)),(ne.substr(0,20)+(ne.length>20?"...":"")).replace(/\n/g,"")},showPosition:function(){var ne=this.pastInput(),se=new Array(ne.length+1).join("-");return ne+this.upcomingInput()+` +`+se+"^"},test_match:function(ne,se){var de,X,ge;if(this.options.backtrack_lexer&&(ge={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&&(ge.yylloc.range=this.yylloc.range.slice(0))),X=ne[0].match(/(?:\r\n?|\n).*/g),X&&(this.yylineno+=X.length),this.yylloc={first_line:this.yylloc.last_line,last_line:this.yylineno+1,first_column:this.yylloc.last_column,last_column:X?X[X.length-1].length-X[X.length-1].match(/\r?\n?/)[0].length:this.yylloc.last_column+ne[0].length},this.yytext+=ne[0],this.match+=ne[0],this.matches=ne,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(ne[0].length),this.matched+=ne[0],de=this.performAction.call(this,this.yy,this,se,this.conditionStack[this.conditionStack.length-1]),this.done&&this._input&&(this.done=!1),de)return de;if(this._backtrack){for(var W in ge)this[W]=ge[W];return!1}return!1},next:function(){if(this.done)return this.EOF;this._input||(this.done=!0);var ne,se,de,X;this._more||(this.yytext="",this.match="");for(var ge=this._currentRules(),W=0;Wse[0].length)){if(se=de,X=W,this.options.backtrack_lexer){if(ne=this.test_match(de,ge[W]),ne!==!1)return ne;if(this._backtrack){se=!1;continue}else return!1}else if(!this.options.flex)break}return se?(ne=this.test_match(se,ge[X]),ne!==!1?ne:!1):this._input===""?this.EOF:this.parseError("Lexical error on line "+(this.yylineno+1)+`. Unrecognized text. +`+this.showPosition(),{text:"",token:null,line:this.yylineno})},lex:function(){var se=this.next();return se||this.lex()},begin:function(se){this.conditionStack.push(se)},popState:function(){var se=this.conditionStack.length-1;return se>0?this.conditionStack.pop():this.conditionStack[0]},_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},topState:function(se){return se=this.conditionStack.length-1-Math.abs(se||0),se>=0?this.conditionStack[se]:"INITIAL"},pushState:function(se){this.begin(se)},stateStackSize:function(){return this.conditionStack.length},options:{"case-insensitive":!0},performAction:function(se,de,X,ge){switch(X){case 0:return this.begin("acc_title"),19;case 1:return this.popState(),"acc_title_value";case 2:return this.begin("acc_descr"),21;case 3:return this.popState(),"acc_descr_value";case 4:this.begin("acc_descr_multiline");break;case 5:this.popState();break;case 6:return"acc_descr_multiline_value";case 7:return 13;case 8:break;case 9:break;case 10:return 5;case 11:return 40;case 12:return 32;case 13:return 38;case 14:return 42;case 15:return 43;case 16:return 44;case 17:return 45;case 18:return 35;case 19:return 28;case 20:return 29;case 21:return 37;case 22:return 31;case 23:return 34;case 24:return 26;case 25:return 9;case 26:return 9;case 27:return 8;case 28:return"CARET";case 29:this.begin("options");break;case 30:this.popState();break;case 31:return 12;case 32:return 36;case 33:this.begin("string");break;case 34:this.popState();break;case 35:return 33;case 36:return 30;case 37:return 46;case 38:return 7}},rules:[/^(?:accTitle\s*:\s*)/i,/^(?:(?!\n||)*[^\n]*)/i,/^(?:accDescr\s*:\s*)/i,/^(?:(?!\n||)*[^\n]*)/i,/^(?:accDescr\s*\{\s*)/i,/^(?:[\}])/i,/^(?:[^\}]*)/i,/^(?:(\r?\n)+)/i,/^(?:#[^\n]*)/i,/^(?:%[^\n]*)/i,/^(?:gitGraph\b)/i,/^(?:commit(?=\s|$))/i,/^(?:id:)/i,/^(?:type:)/i,/^(?:msg:)/i,/^(?:NORMAL\b)/i,/^(?:REVERSE\b)/i,/^(?:HIGHLIGHT\b)/i,/^(?:tag:)/i,/^(?:branch(?=\s|$))/i,/^(?:order:)/i,/^(?:merge(?=\s|$))/i,/^(?:cherry-pick(?=\s|$))/i,/^(?:parent:)/i,/^(?:checkout(?=\s|$))/i,/^(?:LR\b)/i,/^(?:TB\b)/i,/^(?::)/i,/^(?:\^)/i,/^(?:options\r?\n)/i,/^(?:[ \r\n\t]+end\b)/i,/^(?:[\s\S]+(?=[ \r\n\t]+end))/i,/^(?:["]["])/i,/^(?:["])/i,/^(?:["])/i,/^(?:[^"]*)/i,/^(?:[0-9]+(?=\s|$))/i,/^(?:\w([-\./\w]*[-\w])?)/i,/^(?:$)/i,/^(?:\s+)/i],conditions:{acc_descr_multiline:{rules:[5,6],inclusive:!1},acc_descr:{rules:[3],inclusive:!1},acc_title:{rules:[1],inclusive:!1},options:{rules:[30,31],inclusive:!1},string:{rules:[34,35],inclusive:!1},INITIAL:{rules:[0,2,4,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,32,33,36,37,38,39],inclusive:!0}}};return ae}();oe.lexer=pe;function be(){this.yy={}}return be.prototype=oe,oe.Parser=be,new be}();Kme.parser=Kme;const ttn=Kme;let oJ=qt().gitGraph.mainBranchName,ntn=qt().gitGraph.mainBranchOrder,b1={},Np=null,OR={};OR[oJ]={name:oJ,order:ntn};let F0={};F0[oJ]=Np;let sd=oJ,qUe="LR",YC=0;function Wme(){return mje({length:7})}function rtn(i,s){const u=Object.create(null);return i.reduce((d,p)=>{const v=s(p);return u[v]||(u[v]=!0,d.push(p)),d},[])}const itn=function(i){qUe=i};let HUe={};const stn=function(i){Xe.debug("options str",i),i=i&&i.trim(),i=i||"{}";try{HUe=JSON.parse(i)}catch(s){Xe.error("error while parsing gitGraph options",s.message)}},atn=function(){return HUe},otn=function(i,s,u,d){Xe.debug("Entering commit:",i,s,u,d),s=ci.sanitizeText(s,qt()),i=ci.sanitizeText(i,qt()),d=ci.sanitizeText(d,qt());const p={id:s||YC+"-"+Wme(),message:i,seq:YC++,type:u||UD.NORMAL,tag:d||"",parents:Np==null?[]:[Np.id],branch:sd};Np=p,b1[p.id]=p,F0[sd]=p.id,Xe.debug("in pushCommit "+p.id)},ctn=function(i,s){if(i=ci.sanitizeText(i,qt()),F0[i]===void 0)F0[i]=Np!=null?Np.id:null,OR[i]={name:i,order:s?parseInt(s,10):null},VUe(i),Xe.debug("in createBranch");else{let u=new Error('Trying to create an existing branch. (Help: Either use a new name if you want create a new branch or try using "checkout '+i+'")');throw u.hash={text:"branch "+i,token:"branch "+i,line:"1",loc:{first_line:1,last_line:1,first_column:1,last_column:1},expected:['"checkout '+i+'"']},u}},utn=function(i,s,u,d){i=ci.sanitizeText(i,qt()),s=ci.sanitizeText(s,qt());const p=b1[F0[sd]],v=b1[F0[i]];if(sd===i){let y=new Error('Incorrect usage of "merge". Cannot merge a branch to itself');throw y.hash={text:"merge "+i,token:"merge "+i,line:"1",loc:{first_line:1,last_line:1,first_column:1,last_column:1},expected:["branch abc"]},y}else if(p===void 0||!p){let y=new Error('Incorrect usage of "merge". Current branch ('+sd+")has no commits");throw y.hash={text:"merge "+i,token:"merge "+i,line:"1",loc:{first_line:1,last_line:1,first_column:1,last_column:1},expected:["commit"]},y}else if(F0[i]===void 0){let y=new Error('Incorrect usage of "merge". Branch to be merged ('+i+") does not exist");throw y.hash={text:"merge "+i,token:"merge "+i,line:"1",loc:{first_line:1,last_line:1,first_column:1,last_column:1},expected:["branch "+i]},y}else if(v===void 0||!v){let y=new Error('Incorrect usage of "merge". Branch to be merged ('+i+") has no commits");throw y.hash={text:"merge "+i,token:"merge "+i,line:"1",loc:{first_line:1,last_line:1,first_column:1,last_column:1},expected:['"commit"']},y}else if(p===v){let y=new Error('Incorrect usage of "merge". Both branches have same head');throw y.hash={text:"merge "+i,token:"merge "+i,line:"1",loc:{first_line:1,last_line:1,first_column:1,last_column:1},expected:["branch abc"]},y}else if(s&&b1[s]!==void 0){let y=new Error('Incorrect usage of "merge". Commit with id:'+s+" already exists, use different custom Id");throw y.hash={text:"merge "+i+s+u+d,token:"merge "+i+s+u+d,line:"1",loc:{first_line:1,last_line:1,first_column:1,last_column:1},expected:["merge "+i+" "+s+"_UNIQUE "+u+" "+d]},y}const b={id:s||YC+"-"+Wme(),message:"merged branch "+i+" into "+sd,seq:YC++,parents:[Np==null?null:Np.id,F0[i]],branch:sd,type:UD.MERGE,customType:u,customId:!!s,tag:d||""};Np=b,b1[b.id]=b,F0[sd]=b.id,Xe.debug(F0),Xe.debug("in mergeBranch")},ltn=function(i,s,u,d){if(Xe.debug("Entering cherryPick:",i,s,u),i=ci.sanitizeText(i,qt()),s=ci.sanitizeText(s,qt()),u=ci.sanitizeText(u,qt()),d=ci.sanitizeText(d,qt()),!i||b1[i]===void 0){let b=new Error('Incorrect usage of "cherryPick". Source commit id should exist and provided');throw b.hash={text:"cherryPick "+i+" "+s,token:"cherryPick "+i+" "+s,line:"1",loc:{first_line:1,last_line:1,first_column:1,last_column:1},expected:["cherry-pick abc"]},b}let p=b1[i],v=p.branch;if(d&&!(Array.isArray(p.parents)&&p.parents.includes(d)))throw new Error("Invalid operation: The specified parent commit is not an immediate parent of the cherry-picked commit.");if(p.type===UD.MERGE&&!d)throw new Error("Incorrect usage of cherry-pick: If the source commit is a merge commit, an immediate parent commit must be specified.");if(!s||b1[s]===void 0){if(v===sd){let T=new Error('Incorrect usage of "cherryPick". Source commit is already on current branch');throw T.hash={text:"cherryPick "+i+" "+s,token:"cherryPick "+i+" "+s,line:"1",loc:{first_line:1,last_line:1,first_column:1,last_column:1},expected:["cherry-pick abc"]},T}const b=b1[F0[sd]];if(b===void 0||!b){let T=new Error('Incorrect usage of "cherry-pick". Current branch ('+sd+")has no commits");throw T.hash={text:"cherryPick "+i+" "+s,token:"cherryPick "+i+" "+s,line:"1",loc:{first_line:1,last_line:1,first_column:1,last_column:1},expected:["cherry-pick abc"]},T}const y={id:YC+"-"+Wme(),message:"cherry-picked "+p+" into "+sd,seq:YC++,parents:[Np==null?null:Np.id,p.id],branch:sd,type:UD.CHERRY_PICK,tag:u??`cherry-pick:${p.id}${p.type===UD.MERGE?`|parent:${d}`:""}`};Np=y,b1[y.id]=y,F0[sd]=y.id,Xe.debug(F0),Xe.debug("in cherryPick")}},VUe=function(i){if(i=ci.sanitizeText(i,qt()),F0[i]===void 0){let s=new Error('Trying to checkout branch which is not yet created. (Help try using "branch '+i+'")');throw s.hash={text:"checkout "+i,token:"checkout "+i,line:"1",loc:{first_line:1,last_line:1,first_column:1,last_column:1},expected:['"branch '+i+'"']},s}else{sd=i;const s=F0[sd];Np=b1[s]}};function UUe(i,s,u){const d=i.indexOf(s);d===-1?i.push(u):i.splice(d,1,u)}function GUe(i){const s=i.reduce((p,v)=>p.seq>v.seq?p:v,i[0]);let u="";i.forEach(function(p){p===s?u+=" *":u+=" |"});const d=[u,s.id,s.seq];for(let p in F0)F0[p]===s.id&&d.push(p);if(Xe.debug(d.join(" ")),s.parents&&s.parents.length==2){const p=b1[s.parents[0]];UUe(i,s,p),i.push(b1[s.parents[1]])}else{if(s.parents.length==0)return;{const p=b1[s.parents];UUe(i,s,p)}}i=rtn(i,p=>p.id),GUe(i)}const htn=function(){Xe.debug(b1);const i=KUe()[0];GUe([i])},ftn=function(){b1={},Np=null;let i=qt().gitGraph.mainBranchName,s=qt().gitGraph.mainBranchOrder;F0={},F0[i]=null,OR={},OR[i]={name:i,order:s},sd=i,YC=0,Pg()},dtn=function(){return Object.values(OR).map((s,u)=>s.order!==null?s:{...s,order:parseFloat(`0.${u}`,10)}).sort((s,u)=>s.order-u.order).map(({name:s})=>({name:s}))},gtn=function(){return F0},ptn=function(){return b1},KUe=function(){const i=Object.keys(b1).map(function(s){return b1[s]});return i.forEach(function(s){Xe.debug(s.id)}),i.sort((s,u)=>s.seq-u.seq),i},btn=function(){return sd},mtn=function(){return qUe},vtn=function(){return Np},UD={NORMAL:0,REVERSE:1,HIGHLIGHT:2,MERGE:3,CHERRY_PICK:4},wtn={getConfig:()=>qt().gitGraph,setDirection:itn,setOptions:stn,getOptions:atn,commit:otn,branch:ctn,merge:utn,cherryPick:ltn,checkout:VUe,prettyPrint:htn,clear:ftn,getBranchesAsObjArray:dtn,getBranches:gtn,getCommits:ptn,getCommitsArray:KUe,getCurrentBranch:btn,getDirection:mtn,getHead:vtn,setAccTitle:Bg,getAccTitle:Cp,getAccDescription:_p,setAccDescription:Sp,setDiagramTitle:cm,getDiagramTitle:Ap,commitType:UD};let NR={};const ad={NORMAL:0,REVERSE:1,HIGHLIGHT:2,MERGE:3,CHERRY_PICK:4},XC=8;let H2={},H7={},cJ=[],PR=0,R0="LR";const ytn=()=>{H2={},H7={},NR={},PR=0,cJ=[],R0="LR"},WUe=i=>{const s=document.createElementNS("http://www.w3.org/2000/svg","text");let u=[];typeof i=="string"?u=i.split(/\\n|\n|/gi):Array.isArray(i)?u=i:u=[];for(const d of u){const p=document.createElementNS("http://www.w3.org/2000/svg","tspan");p.setAttributeNS("http://www.w3.org/XML/1998/namespace","xml:space","preserve"),p.setAttribute("dy","1em"),p.setAttribute("x","0"),p.setAttribute("class","row"),p.textContent=d.trim(),s.appendChild(p)}return s},xtn=i=>{let s="",u=0;return i.forEach(d=>{const p=R0==="TB"?H7[d].y:H7[d].x;p>=u&&(s=d,u=p)}),s||void 0},YUe=(i,s,u)=>{const d=qt().gitGraph,p=i.append("g").attr("class","commit-bullets"),v=i.append("g").attr("class","commit-labels");let b=0;R0==="TB"&&(b=30);const T=Object.keys(s).sort((R,F)=>s[R].seq-s[F].seq),_=d.parallelCommits,A=10,P=40;T.forEach(R=>{const F=s[R];if(_)if(F.parents.length){const ie=xtn(F.parents);b=R0==="TB"?H7[ie].y+P:H7[ie].x+P}else b=0,R0==="TB"&&(b=30);const j=b+A,K=R0==="TB"?j:H2[F.branch].pos,ee=R0==="TB"?H2[F.branch].pos:j;if(u){let ie,oe=F.customType!==void 0&&F.customType!==""?F.customType:F.type;switch(oe){case ad.NORMAL:ie="commit-normal";break;case ad.REVERSE:ie="commit-reverse";break;case ad.HIGHLIGHT:ie="commit-highlight";break;case ad.MERGE:ie="commit-merge";break;case ad.CHERRY_PICK:ie="commit-cherry-pick";break;default:ie="commit-normal"}if(oe===ad.HIGHLIGHT){const pe=p.append("rect");pe.attr("x",ee-10),pe.attr("y",K-10),pe.attr("height",20),pe.attr("width",20),pe.attr("class",`commit ${F.id} commit-highlight${H2[F.branch].index%XC} ${ie}-outer`),p.append("rect").attr("x",ee-6).attr("y",K-6).attr("height",12).attr("width",12).attr("class",`commit ${F.id} commit${H2[F.branch].index%XC} ${ie}-inner`)}else if(oe===ad.CHERRY_PICK)p.append("circle").attr("cx",ee).attr("cy",K).attr("r",10).attr("class",`commit ${F.id} ${ie}`),p.append("circle").attr("cx",ee-3).attr("cy",K+2).attr("r",2.75).attr("fill","#fff").attr("class",`commit ${F.id} ${ie}`),p.append("circle").attr("cx",ee+3).attr("cy",K+2).attr("r",2.75).attr("fill","#fff").attr("class",`commit ${F.id} ${ie}`),p.append("line").attr("x1",ee+3).attr("y1",K+1).attr("x2",ee).attr("y2",K-5).attr("stroke","#fff").attr("class",`commit ${F.id} ${ie}`),p.append("line").attr("x1",ee-3).attr("y1",K+1).attr("x2",ee).attr("y2",K-5).attr("stroke","#fff").attr("class",`commit ${F.id} ${ie}`);else{const pe=p.append("circle");if(pe.attr("cx",ee),pe.attr("cy",K),pe.attr("r",F.type===ad.MERGE?9:10),pe.attr("class",`commit ${F.id} commit${H2[F.branch].index%XC}`),oe===ad.MERGE){const be=p.append("circle");be.attr("cx",ee),be.attr("cy",K),be.attr("r",6),be.attr("class",`commit ${ie} ${F.id} commit${H2[F.branch].index%XC}`)}oe===ad.REVERSE&&p.append("path").attr("d",`M ${ee-5},${K-5}L${ee+5},${K+5}M${ee-5},${K+5}L${ee+5},${K-5}`).attr("class",`commit ${ie} ${F.id} commit${H2[F.branch].index%XC}`)}}if(R0==="TB"?H7[F.id]={x:ee,y:j}:H7[F.id]={x:j,y:K},u){if(F.type!==ad.CHERRY_PICK&&(F.customId&&F.type===ad.MERGE||F.type!==ad.MERGE)&&d.showCommitLabel){const pe=v.append("g"),be=pe.insert("rect").attr("class","commit-label-bkg"),ae=pe.append("text").attr("x",b).attr("y",K+25).attr("class","commit-label").text(F.id);let ne=ae.node().getBBox();if(be.attr("x",j-ne.width/2-2).attr("y",K+13.5).attr("width",ne.width+2*2).attr("height",ne.height+2*2),R0==="TB"&&(be.attr("x",ee-(ne.width+4*4+5)).attr("y",K-12),ae.attr("x",ee-(ne.width+4*4)).attr("y",K+ne.height-12)),R0!=="TB"&&ae.attr("x",j-ne.width/2),d.rotateCommitLabel)if(R0==="TB")ae.attr("transform","rotate(-45, "+ee+", "+K+")"),be.attr("transform","rotate(-45, "+ee+", "+K+")");else{let se=-7.5-(ne.width+10)/25*9.5,de=10+ne.width/25*8.5;pe.attr("transform","translate("+se+", "+de+") rotate(-45, "+b+", "+K+")")}}if(F.tag){const pe=v.insert("polygon"),be=v.append("circle"),ae=v.append("text").attr("y",K-16).attr("class","tag-label").text(F.tag);let ne=ae.node().getBBox();ae.attr("x",j-ne.width/2);const se=ne.height/2,de=K-19.2;pe.attr("class","tag-label-bkg").attr("points",` + ${b-ne.width/2-4/2},${de+2} + ${b-ne.width/2-4/2},${de-2} + ${j-ne.width/2-4},${de-se-2} + ${j+ne.width/2+4},${de-se-2} + ${j+ne.width/2+4},${de+se+2} + ${j-ne.width/2-4},${de+se+2}`),be.attr("cx",b-ne.width/2+4/2).attr("cy",de).attr("r",1.5).attr("class","tag-hole"),R0==="TB"&&(pe.attr("class","tag-label-bkg").attr("points",` + ${ee},${b+2} + ${ee},${b-2} + ${ee+A},${b-se-2} + ${ee+A+ne.width+4},${b-se-2} + ${ee+A+ne.width+4},${b+se+2} + ${ee+A},${b+se+2}`).attr("transform","translate(12,12) rotate(45, "+ee+","+b+")"),be.attr("cx",ee+4/2).attr("cy",b).attr("transform","translate(12,12) rotate(45, "+ee+","+b+")"),ae.attr("x",ee+5).attr("y",b+3).attr("transform","translate(14,14) rotate(45, "+ee+","+b+")"))}}b+=P+A,b>PR&&(PR=b)})},ktn=(i,s,u,d,p)=>{const b=(R0==="TB"?u.x_.branch===b,T=_=>_.seq>i.seq&&_.seqT(_)&&y(_))},BR=(i,s,u=0)=>{const d=i+Math.abs(i-s)/2;if(u>5)return d;if(cJ.every(b=>Math.abs(b-d)>=10))return cJ.push(d),d;const v=Math.abs(i-s);return BR(i,s-v/5,u+1)},Etn=(i,s,u,d)=>{const p=H7[s.id],v=H7[u.id],b=ktn(s,u,p,v,d);let y="",T="",_=0,A=0,P=H2[u.branch].index;u.type===ad.MERGE&&s.id!==u.parents[0]&&(P=H2[s.branch].index);let R;if(b){y="A 10 10, 0, 0, 0,",T="A 10 10, 0, 0, 1,",_=10,A=10;const F=p.yv.x&&(y="A 20 20, 0, 0, 0,",T="A 20 20, 0, 0, 1,",_=20,A=20,u.type===ad.MERGE&&s.id!==u.parents[0]?R=`M ${p.x} ${p.y} L ${p.x} ${v.y-_} ${T} ${p.x-A} ${v.y} L ${v.x} ${v.y}`:R=`M ${p.x} ${p.y} L ${v.x+_} ${p.y} ${y} ${v.x} ${p.y+A} L ${v.x} ${v.y}`),p.x===v.x&&(R=`M ${p.x} ${p.y} L ${v.x} ${v.y}`)):(p.yv.y&&(u.type===ad.MERGE&&s.id!==u.parents[0]?R=`M ${p.x} ${p.y} L ${v.x-_} ${p.y} ${y} ${v.x} ${p.y-A} L ${v.x} ${v.y}`:R=`M ${p.x} ${p.y} L ${p.x} ${v.y+_} ${T} ${p.x+A} ${v.y} L ${v.x} ${v.y}`),p.y===v.y&&(R=`M ${p.x} ${p.y} L ${v.x} ${v.y}`));i.append("path").attr("d",R).attr("class","arrow arrow"+P%XC)},Ttn=(i,s)=>{const u=i.append("g").attr("class","commit-arrows");Object.keys(s).forEach(d=>{const p=s[d];p.parents&&p.parents.length>0&&p.parents.forEach(v=>{Etn(u,s[v],p,s)})})},Ctn=(i,s)=>{const u=qt().gitGraph,d=i.append("g");s.forEach((p,v)=>{const b=v%XC,y=H2[p.name].pos,T=d.append("line");T.attr("x1",0),T.attr("y1",y),T.attr("x2",PR),T.attr("y2",y),T.attr("class","branch branch"+b),R0==="TB"&&(T.attr("y1",30),T.attr("x1",y),T.attr("y2",PR),T.attr("x2",y)),cJ.push(y);let _=p.name;const A=WUe(_),P=d.insert("rect"),F=d.insert("g").attr("class","branchLabel").insert("g").attr("class","label branch-label"+b);F.node().appendChild(A);let j=A.getBBox();P.attr("class","branchLabelBkg label"+b).attr("rx",4).attr("ry",4).attr("x",-j.width-4-(u.rotateCommitLabel===!0?30:0)).attr("y",-j.height/2+8).attr("width",j.width+18).attr("height",j.height+4),F.attr("transform","translate("+(-j.width-14-(u.rotateCommitLabel===!0?30:0))+", "+(y-j.height/2-1)+")"),R0==="TB"&&(P.attr("x",y-j.width/2-10).attr("y",0),F.attr("transform","translate("+(y-j.width/2-5)+", 0)")),R0!=="TB"&&P.attr("transform","translate(-19, "+(y-j.height/2)+")")})},Stn=Object.freeze(Object.defineProperty({__proto__:null,diagram:{parser:ttn,db:wtn,renderer:{draw:function(i,s,u,d){ytn();const p=qt(),v=p.gitGraph;Xe.debug("in gitgraph renderer",i+` +`,"id:",s,u),NR=d.db.getCommits();const b=d.db.getBranchesAsObjArray();R0=d.db.getDirection();const y=Ir(`[id="${s}"]`);let T=0;b.forEach((_,A)=>{const P=WUe(_.name),R=y.append("g"),F=R.insert("g").attr("class","branchLabel"),j=F.insert("g").attr("class","label branch-label");j.node().appendChild(P);let K=P.getBBox();H2[_.name]={pos:T,index:A},T+=50+(v.rotateCommitLabel?40:0)+(R0==="TB"?K.width/2:0),j.remove(),F.remove(),R.remove()}),YUe(y,NR,!1),v.showBranches&&Ctn(y,b),Ttn(y,NR),YUe(y,NR,!0),Ao.insertTitle(y,"gitTitleText",v.titleTopMargin,d.db.getDiagramTitle()),e$e(void 0,y,v.diagramPadding,v.useMaxWidth??p.useMaxWidth)}},styles:i=>` + .commit-id, + .commit-msg, + .branch-label { + fill: lightgrey; + color: lightgrey; + font-family: 'trebuchet ms', verdana, arial, sans-serif; + font-family: var(--mermaid-font-family); + } + ${[0,1,2,3,4,5,6,7].map(s=>` + .branch-label${s} { fill: ${i["gitBranchLabel"+s]}; } + .commit${s} { stroke: ${i["git"+s]}; fill: ${i["git"+s]}; } + .commit-highlight${s} { stroke: ${i["gitInv"+s]}; fill: ${i["gitInv"+s]}; } + .label${s} { fill: ${i["git"+s]}; } + .arrow${s} { stroke: ${i["git"+s]}; } + `).join(` +`)} + + .branch { + stroke-width: 1; + stroke: ${i.lineColor}; + stroke-dasharray: 2; + } + .commit-label { font-size: ${i.commitLabelFontSize}; fill: ${i.commitLabelColor};} + .commit-label-bkg { font-size: ${i.commitLabelFontSize}; fill: ${i.commitLabelBackground}; opacity: 0.5; } + .tag-label { font-size: ${i.tagLabelFontSize}; fill: ${i.tagLabelColor};} + .tag-label-bkg { fill: ${i.tagLabelBackground}; stroke: ${i.tagLabelBorder}; } + .tag-hole { fill: ${i.textColor}; } + + .commit-merge { + stroke: ${i.primaryColor}; + fill: ${i.primaryColor}; + } + .commit-reverse { + stroke: ${i.primaryColor}; + fill: ${i.primaryColor}; + stroke-width: 3; + } + .commit-highlight-outer { + } + .commit-highlight-inner { + stroke: ${i.primaryColor}; + fill: ${i.primaryColor}; + } + + .arrow { stroke-width: 8; stroke-linecap: round; fill: none} + .gitTitleText { + text-anchor: middle; + font-size: 18px; + fill: ${i.textColor}; + } +`}},Symbol.toStringTag,{value:"Module"}));var Yme=function(){var i=function(W,xe,U,Fe){for(U=U||{},Fe=W.length;Fe--;U[W[Fe]]=xe);return U},s=[6,8,10,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,30,32,33,35,37],u=[1,25],d=[1,26],p=[1,27],v=[1,28],b=[1,29],y=[1,30],T=[1,31],_=[1,9],A=[1,10],P=[1,11],R=[1,12],F=[1,13],j=[1,14],K=[1,15],ee=[1,16],ie=[1,18],oe=[1,19],pe=[1,20],be=[1,21],ae=[1,22],ne=[1,24],se=[1,32],de={trace:function(){},yy:{},symbols_:{error:2,start:3,gantt:4,document:5,EOF:6,line:7,SPACE:8,statement:9,NL:10,weekday:11,weekday_monday:12,weekday_tuesday:13,weekday_wednesday:14,weekday_thursday:15,weekday_friday:16,weekday_saturday:17,weekday_sunday:18,dateFormat:19,inclusiveEndDates:20,topAxis:21,axisFormat:22,tickInterval:23,excludes:24,includes:25,todayMarker:26,title:27,acc_title:28,acc_title_value:29,acc_descr:30,acc_descr_value:31,acc_descr_multiline_value:32,section:33,clickStatement:34,taskTxt:35,taskData:36,click:37,callbackname:38,callbackargs:39,href:40,clickStatementDebug:41,$accept:0,$end:1},terminals_:{2:"error",4:"gantt",6:"EOF",8:"SPACE",10:"NL",12:"weekday_monday",13:"weekday_tuesday",14:"weekday_wednesday",15:"weekday_thursday",16:"weekday_friday",17:"weekday_saturday",18:"weekday_sunday",19:"dateFormat",20:"inclusiveEndDates",21:"topAxis",22:"axisFormat",23:"tickInterval",24:"excludes",25:"includes",26:"todayMarker",27:"title",28:"acc_title",29:"acc_title_value",30:"acc_descr",31:"acc_descr_value",32:"acc_descr_multiline_value",33:"section",35:"taskTxt",36:"taskData",37:"click",38:"callbackname",39:"callbackargs",40:"href"},productions_:[0,[3,3],[5,0],[5,2],[7,2],[7,1],[7,1],[7,1],[11,1],[11,1],[11,1],[11,1],[11,1],[11,1],[11,1],[9,1],[9,1],[9,1],[9,1],[9,1],[9,1],[9,1],[9,1],[9,1],[9,1],[9,2],[9,2],[9,1],[9,1],[9,1],[9,2],[34,2],[34,3],[34,3],[34,4],[34,3],[34,4],[34,2],[41,2],[41,3],[41,3],[41,4],[41,3],[41,4],[41,2]],performAction:function(xe,U,Fe,Pe,je,Ie,Se){var Ce=Ie.length-1;switch(je){case 1:return Ie[Ce-1];case 2:this.$=[];break;case 3:Ie[Ce-1].push(Ie[Ce]),this.$=Ie[Ce-1];break;case 4:case 5:this.$=Ie[Ce];break;case 6:case 7:this.$=[];break;case 8:Pe.setWeekday("monday");break;case 9:Pe.setWeekday("tuesday");break;case 10:Pe.setWeekday("wednesday");break;case 11:Pe.setWeekday("thursday");break;case 12:Pe.setWeekday("friday");break;case 13:Pe.setWeekday("saturday");break;case 14:Pe.setWeekday("sunday");break;case 15:Pe.setDateFormat(Ie[Ce].substr(11)),this.$=Ie[Ce].substr(11);break;case 16:Pe.enableInclusiveEndDates(),this.$=Ie[Ce].substr(18);break;case 17:Pe.TopAxis(),this.$=Ie[Ce].substr(8);break;case 18:Pe.setAxisFormat(Ie[Ce].substr(11)),this.$=Ie[Ce].substr(11);break;case 19:Pe.setTickInterval(Ie[Ce].substr(13)),this.$=Ie[Ce].substr(13);break;case 20:Pe.setExcludes(Ie[Ce].substr(9)),this.$=Ie[Ce].substr(9);break;case 21:Pe.setIncludes(Ie[Ce].substr(9)),this.$=Ie[Ce].substr(9);break;case 22:Pe.setTodayMarker(Ie[Ce].substr(12)),this.$=Ie[Ce].substr(12);break;case 24:Pe.setDiagramTitle(Ie[Ce].substr(6)),this.$=Ie[Ce].substr(6);break;case 25:this.$=Ie[Ce].trim(),Pe.setAccTitle(this.$);break;case 26:case 27:this.$=Ie[Ce].trim(),Pe.setAccDescription(this.$);break;case 28:Pe.addSection(Ie[Ce].substr(8)),this.$=Ie[Ce].substr(8);break;case 30:Pe.addTask(Ie[Ce-1],Ie[Ce]),this.$="task";break;case 31:this.$=Ie[Ce-1],Pe.setClickEvent(Ie[Ce-1],Ie[Ce],null);break;case 32:this.$=Ie[Ce-2],Pe.setClickEvent(Ie[Ce-2],Ie[Ce-1],Ie[Ce]);break;case 33:this.$=Ie[Ce-2],Pe.setClickEvent(Ie[Ce-2],Ie[Ce-1],null),Pe.setLink(Ie[Ce-2],Ie[Ce]);break;case 34:this.$=Ie[Ce-3],Pe.setClickEvent(Ie[Ce-3],Ie[Ce-2],Ie[Ce-1]),Pe.setLink(Ie[Ce-3],Ie[Ce]);break;case 35:this.$=Ie[Ce-2],Pe.setClickEvent(Ie[Ce-2],Ie[Ce],null),Pe.setLink(Ie[Ce-2],Ie[Ce-1]);break;case 36:this.$=Ie[Ce-3],Pe.setClickEvent(Ie[Ce-3],Ie[Ce-1],Ie[Ce]),Pe.setLink(Ie[Ce-3],Ie[Ce-2]);break;case 37:this.$=Ie[Ce-1],Pe.setLink(Ie[Ce-1],Ie[Ce]);break;case 38:case 44:this.$=Ie[Ce-1]+" "+Ie[Ce];break;case 39:case 40:case 42:this.$=Ie[Ce-2]+" "+Ie[Ce-1]+" "+Ie[Ce];break;case 41:case 43:this.$=Ie[Ce-3]+" "+Ie[Ce-2]+" "+Ie[Ce-1]+" "+Ie[Ce];break}},table:[{3:1,4:[1,2]},{1:[3]},i(s,[2,2],{5:3}),{6:[1,4],7:5,8:[1,6],9:7,10:[1,8],11:17,12:u,13:d,14:p,15:v,16:b,17:y,18:T,19:_,20:A,21:P,22:R,23:F,24:j,25:K,26:ee,27:ie,28:oe,30:pe,32:be,33:ae,34:23,35:ne,37:se},i(s,[2,7],{1:[2,1]}),i(s,[2,3]),{9:33,11:17,12:u,13:d,14:p,15:v,16:b,17:y,18:T,19:_,20:A,21:P,22:R,23:F,24:j,25:K,26:ee,27:ie,28:oe,30:pe,32:be,33:ae,34:23,35:ne,37:se},i(s,[2,5]),i(s,[2,6]),i(s,[2,15]),i(s,[2,16]),i(s,[2,17]),i(s,[2,18]),i(s,[2,19]),i(s,[2,20]),i(s,[2,21]),i(s,[2,22]),i(s,[2,23]),i(s,[2,24]),{29:[1,34]},{31:[1,35]},i(s,[2,27]),i(s,[2,28]),i(s,[2,29]),{36:[1,36]},i(s,[2,8]),i(s,[2,9]),i(s,[2,10]),i(s,[2,11]),i(s,[2,12]),i(s,[2,13]),i(s,[2,14]),{38:[1,37],40:[1,38]},i(s,[2,4]),i(s,[2,25]),i(s,[2,26]),i(s,[2,30]),i(s,[2,31],{39:[1,39],40:[1,40]}),i(s,[2,37],{38:[1,41]}),i(s,[2,32],{40:[1,42]}),i(s,[2,33]),i(s,[2,35],{39:[1,43]}),i(s,[2,34]),i(s,[2,36])],defaultActions:{},parseError:function(xe,U){if(U.recoverable)this.trace(xe);else{var Fe=new Error(xe);throw Fe.hash=U,Fe}},parse:function(xe){var U=this,Fe=[0],Pe=[],je=[null],Ie=[],Se=this.table,Ce="",ke=0,Ke=0,Ft=2,Ne=1,gn=Ie.slice.call(arguments,1),_t=Object.create(this.lexer),Et={yy:{}};for(var Gt in this.yy)Object.prototype.hasOwnProperty.call(this.yy,Gt)&&(Et.yy[Gt]=this.yy[Gt]);_t.setInput(xe,Et.yy),Et.yy.lexer=_t,Et.yy.parser=this,typeof _t.yylloc>"u"&&(_t.yylloc={});var ln=_t.yylloc;Ie.push(ln);var xt=_t.options&&_t.options.ranges;typeof Et.yy.parseError=="function"?this.parseError=Et.yy.parseError:this.parseError=Object.getPrototypeOf(this).parseError;function Pt(){var zs;return zs=Pe.pop()||_t.lex()||Ne,typeof zs!="number"&&(zs instanceof Array&&(Pe=zs,zs=Pe.pop()),zs=U.symbols_[zs]||zs),zs}for(var Qe,Dt,kt,On,ht={},zr,yt,ji,xi;;){if(Dt=Fe[Fe.length-1],this.defaultActions[Dt]?kt=this.defaultActions[Dt]:((Qe===null||typeof Qe>"u")&&(Qe=Pt()),kt=Se[Dt]&&Se[Dt][Qe]),typeof kt>"u"||!kt.length||!kt[0]){var Ma="";xi=[];for(zr in Se[Dt])this.terminals_[zr]&&zr>Ft&&xi.push("'"+this.terminals_[zr]+"'");_t.showPosition?Ma="Parse error on line "+(ke+1)+`: +`+_t.showPosition()+` +Expecting `+xi.join(", ")+", got '"+(this.terminals_[Qe]||Qe)+"'":Ma="Parse error on line "+(ke+1)+": Unexpected "+(Qe==Ne?"end of input":"'"+(this.terminals_[Qe]||Qe)+"'"),this.parseError(Ma,{text:_t.match,token:this.terminals_[Qe]||Qe,line:_t.yylineno,loc:ln,expected:xi})}if(kt[0]instanceof Array&&kt.length>1)throw new Error("Parse Error: multiple actions possible at state: "+Dt+", token: "+Qe);switch(kt[0]){case 1:Fe.push(Qe),je.push(_t.yytext),Ie.push(_t.yylloc),Fe.push(kt[1]),Qe=null,Ke=_t.yyleng,Ce=_t.yytext,ke=_t.yylineno,ln=_t.yylloc;break;case 2:if(yt=this.productions_[kt[1]][1],ht.$=je[je.length-yt],ht._$={first_line:Ie[Ie.length-(yt||1)].first_line,last_line:Ie[Ie.length-1].last_line,first_column:Ie[Ie.length-(yt||1)].first_column,last_column:Ie[Ie.length-1].last_column},xt&&(ht._$.range=[Ie[Ie.length-(yt||1)].range[0],Ie[Ie.length-1].range[1]]),On=this.performAction.apply(ht,[Ce,Ke,ke,Et.yy,kt[1],je,Ie].concat(gn)),typeof On<"u")return On;yt&&(Fe=Fe.slice(0,-1*yt*2),je=je.slice(0,-1*yt),Ie=Ie.slice(0,-1*yt)),Fe.push(this.productions_[kt[1]][0]),je.push(ht.$),Ie.push(ht._$),ji=Se[Fe[Fe.length-2]][Fe[Fe.length-1]],Fe.push(ji);break;case 3:return!0}}return!0}},X=function(){var W={EOF:1,parseError:function(U,Fe){if(this.yy.parser)this.yy.parser.parseError(U,Fe);else throw new Error(U)},setInput:function(xe,U){return this.yy=U||this.yy||{},this._input=xe,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},input:function(){var xe=this._input[0];this.yytext+=xe,this.yyleng++,this.offset++,this.match+=xe,this.matched+=xe;var U=xe.match(/(?:\r\n?|\n).*/g);return U?(this.yylineno++,this.yylloc.last_line++):this.yylloc.last_column++,this.options.ranges&&this.yylloc.range[1]++,this._input=this._input.slice(1),xe},unput:function(xe){var U=xe.length,Fe=xe.split(/(?:\r\n?|\n)/g);this._input=xe+this._input,this.yytext=this.yytext.substr(0,this.yytext.length-U),this.offset-=U;var Pe=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),Fe.length-1&&(this.yylineno-=Fe.length-1);var je=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:Fe?(Fe.length===Pe.length?this.yylloc.first_column:0)+Pe[Pe.length-Fe.length].length-Fe[0].length:this.yylloc.first_column-U},this.options.ranges&&(this.yylloc.range=[je[0],je[0]+this.yyleng-U]),this.yyleng=this.yytext.length,this},more:function(){return this._more=!0,this},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},less:function(xe){this.unput(this.match.slice(xe))},pastInput:function(){var xe=this.matched.substr(0,this.matched.length-this.match.length);return(xe.length>20?"...":"")+xe.substr(-20).replace(/\n/g,"")},upcomingInput:function(){var xe=this.match;return xe.length<20&&(xe+=this._input.substr(0,20-xe.length)),(xe.substr(0,20)+(xe.length>20?"...":"")).replace(/\n/g,"")},showPosition:function(){var xe=this.pastInput(),U=new Array(xe.length+1).join("-");return xe+this.upcomingInput()+` +`+U+"^"},test_match:function(xe,U){var Fe,Pe,je;if(this.options.backtrack_lexer&&(je={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&&(je.yylloc.range=this.yylloc.range.slice(0))),Pe=xe[0].match(/(?:\r\n?|\n).*/g),Pe&&(this.yylineno+=Pe.length),this.yylloc={first_line:this.yylloc.last_line,last_line:this.yylineno+1,first_column:this.yylloc.last_column,last_column:Pe?Pe[Pe.length-1].length-Pe[Pe.length-1].match(/\r?\n?/)[0].length:this.yylloc.last_column+xe[0].length},this.yytext+=xe[0],this.match+=xe[0],this.matches=xe,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(xe[0].length),this.matched+=xe[0],Fe=this.performAction.call(this,this.yy,this,U,this.conditionStack[this.conditionStack.length-1]),this.done&&this._input&&(this.done=!1),Fe)return Fe;if(this._backtrack){for(var Ie in je)this[Ie]=je[Ie];return!1}return!1},next:function(){if(this.done)return this.EOF;this._input||(this.done=!0);var xe,U,Fe,Pe;this._more||(this.yytext="",this.match="");for(var je=this._currentRules(),Ie=0;IeU[0].length)){if(U=Fe,Pe=Ie,this.options.backtrack_lexer){if(xe=this.test_match(Fe,je[Ie]),xe!==!1)return xe;if(this._backtrack){U=!1;continue}else return!1}else if(!this.options.flex)break}return U?(xe=this.test_match(U,je[Pe]),xe!==!1?xe:!1):this._input===""?this.EOF:this.parseError("Lexical error on line "+(this.yylineno+1)+`. Unrecognized text. +`+this.showPosition(),{text:"",token:null,line:this.yylineno})},lex:function(){var U=this.next();return U||this.lex()},begin:function(U){this.conditionStack.push(U)},popState:function(){var U=this.conditionStack.length-1;return U>0?this.conditionStack.pop():this.conditionStack[0]},_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},topState:function(U){return U=this.conditionStack.length-1-Math.abs(U||0),U>=0?this.conditionStack[U]:"INITIAL"},pushState:function(U){this.begin(U)},stateStackSize:function(){return this.conditionStack.length},options:{"case-insensitive":!0},performAction:function(U,Fe,Pe,je){switch(Pe){case 0:return this.begin("open_directive"),"open_directive";case 1:return this.begin("acc_title"),28;case 2:return this.popState(),"acc_title_value";case 3:return this.begin("acc_descr"),30;case 4:return this.popState(),"acc_descr_value";case 5:this.begin("acc_descr_multiline");break;case 6:this.popState();break;case 7:return"acc_descr_multiline_value";case 8:break;case 9:break;case 10:break;case 11:return 10;case 12:break;case 13:break;case 14:this.begin("href");break;case 15:this.popState();break;case 16:return 40;case 17:this.begin("callbackname");break;case 18:this.popState();break;case 19:this.popState(),this.begin("callbackargs");break;case 20:return 38;case 21:this.popState();break;case 22:return 39;case 23:this.begin("click");break;case 24:this.popState();break;case 25:return 37;case 26:return 4;case 27:return 19;case 28:return 20;case 29:return 21;case 30:return 22;case 31:return 23;case 32:return 25;case 33:return 24;case 34:return 26;case 35:return 12;case 36:return 13;case 37:return 14;case 38:return 15;case 39:return 16;case 40:return 17;case 41:return 18;case 42:return"date";case 43:return 27;case 44:return"accDescription";case 45:return 33;case 46:return 35;case 47:return 36;case 48:return":";case 49:return 6;case 50:return"INVALID"}},rules:[/^(?:%%\{)/i,/^(?:accTitle\s*:\s*)/i,/^(?:(?!\n||)*[^\n]*)/i,/^(?:accDescr\s*:\s*)/i,/^(?:(?!\n||)*[^\n]*)/i,/^(?:accDescr\s*\{\s*)/i,/^(?:[\}])/i,/^(?:[^\}]*)/i,/^(?:%%(?!\{)*[^\n]*)/i,/^(?:[^\}]%%*[^\n]*)/i,/^(?:%%*[^\n]*[\n]*)/i,/^(?:[\n]+)/i,/^(?:\s+)/i,/^(?:%[^\n]*)/i,/^(?:href[\s]+["])/i,/^(?:["])/i,/^(?:[^"]*)/i,/^(?:call[\s]+)/i,/^(?:\([\s]*\))/i,/^(?:\()/i,/^(?:[^(]*)/i,/^(?:\))/i,/^(?:[^)]*)/i,/^(?:click[\s]+)/i,/^(?:[\s\n])/i,/^(?:[^\s\n]*)/i,/^(?:gantt\b)/i,/^(?:dateFormat\s[^#\n;]+)/i,/^(?:inclusiveEndDates\b)/i,/^(?:topAxis\b)/i,/^(?:axisFormat\s[^#\n;]+)/i,/^(?:tickInterval\s[^#\n;]+)/i,/^(?:includes\s[^#\n;]+)/i,/^(?:excludes\s[^#\n;]+)/i,/^(?:todayMarker\s[^\n;]+)/i,/^(?:weekday\s+monday\b)/i,/^(?:weekday\s+tuesday\b)/i,/^(?:weekday\s+wednesday\b)/i,/^(?:weekday\s+thursday\b)/i,/^(?:weekday\s+friday\b)/i,/^(?:weekday\s+saturday\b)/i,/^(?:weekday\s+sunday\b)/i,/^(?:\d\d\d\d-\d\d-\d\d\b)/i,/^(?:title\s[^\n]+)/i,/^(?:accDescription\s[^#\n;]+)/i,/^(?:section\s[^\n]+)/i,/^(?:[^:\n]+)/i,/^(?::[^#\n;]+)/i,/^(?::)/i,/^(?:$)/i,/^(?:.)/i],conditions:{acc_descr_multiline:{rules:[6,7],inclusive:!1},acc_descr:{rules:[4],inclusive:!1},acc_title:{rules:[2],inclusive:!1},callbackargs:{rules:[21,22],inclusive:!1},callbackname:{rules:[18,19,20],inclusive:!1},href:{rules:[15,16],inclusive:!1},click:{rules:[24,25],inclusive:!1},INITIAL:{rules:[0,1,3,5,8,9,10,11,12,13,14,17,23,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50],inclusive:!0}}};return W}();de.lexer=X;function ge(){this.yy={}}return ge.prototype=de,de.Parser=ge,new ge}();Yme.parser=Yme;const _tn=Yme;var XUe={exports:{}};(function(i,s){(function(u,d){i.exports=d()})(Ag,function(){var u="day";return function(d,p,v){var b=function(_){return _.add(4-_.isoWeekday(),u)},y=p.prototype;y.isoWeekYear=function(){return b(this).year()},y.isoWeek=function(_){if(!this.$utils().u(_))return this.add(7*(_-this.isoWeek()),u);var A,P,R,F,j=b(this),K=(A=this.isoWeekYear(),P=this.$u,R=(P?v.utc:v)().year(A).startOf("year"),F=4-R.isoWeekday(),R.isoWeekday()>4&&(F+=7),R.add(F,u));return j.diff(K,"week")+1},y.isoWeekday=function(_){return this.$utils().u(_)?this.day()||7:this.day(this.day()%7?_:_-7)};var T=y.startOf;y.startOf=function(_,A){var P=this.$utils(),R=!!P.u(A)||A;return P.p(_)==="isoweek"?R?this.date(this.date()-(this.isoWeekday()-1)).startOf("day"):this.date(this.date()-1-(this.isoWeekday()-1)+7).endOf("day"):T.bind(this)(_,A)}}})})(XUe);var Atn=XUe.exports;const Ltn=hC(Atn);var QUe={exports:{}};(function(i,s){(function(u,d){i.exports=d()})(Ag,function(){var u={LTS:"h:mm:ss A",LT:"h:mm A",L:"MM/DD/YYYY",LL:"MMMM D, YYYY",LLL:"MMMM D, YYYY h:mm A",LLLL:"dddd, MMMM D, YYYY h:mm A"},d=/(\[[^[]*\])|([-_:/.,()\s]+)|(A|a|YYYY|YY?|MM?M?M?|Do|DD?|hh?|HH?|mm?|ss?|S{1,3}|z|ZZ?)/g,p=/\d\d/,v=/\d\d?/,b=/\d*[^-_:/,()\s\d]+/,y={},T=function(K){return(K=+K)+(K>68?1900:2e3)},_=function(K){return function(ee){this[K]=+ee}},A=[/[+-]\d\d:?(\d\d)?|Z/,function(K){(this.zone||(this.zone={})).offset=function(ee){if(!ee||ee==="Z")return 0;var ie=ee.match(/([+-]|\d\d)/g),oe=60*ie[1]+(+ie[2]||0);return oe===0?0:ie[0]==="+"?-oe:oe}(K)}],P=function(K){var ee=y[K];return ee&&(ee.indexOf?ee:ee.s.concat(ee.f))},R=function(K,ee){var ie,oe=y.meridiem;if(oe){for(var pe=1;pe<=24;pe+=1)if(K.indexOf(oe(pe,0,ee))>-1){ie=pe>12;break}}else ie=K===(ee?"pm":"PM");return ie},F={A:[b,function(K){this.afternoon=R(K,!1)}],a:[b,function(K){this.afternoon=R(K,!0)}],S:[/\d/,function(K){this.milliseconds=100*+K}],SS:[p,function(K){this.milliseconds=10*+K}],SSS:[/\d{3}/,function(K){this.milliseconds=+K}],s:[v,_("seconds")],ss:[v,_("seconds")],m:[v,_("minutes")],mm:[v,_("minutes")],H:[v,_("hours")],h:[v,_("hours")],HH:[v,_("hours")],hh:[v,_("hours")],D:[v,_("day")],DD:[p,_("day")],Do:[b,function(K){var ee=y.ordinal,ie=K.match(/\d+/);if(this.day=ie[0],ee)for(var oe=1;oe<=31;oe+=1)ee(oe).replace(/\[|\]/g,"")===K&&(this.day=oe)}],M:[v,_("month")],MM:[p,_("month")],MMM:[b,function(K){var ee=P("months"),ie=(P("monthsShort")||ee.map(function(oe){return oe.slice(0,3)})).indexOf(K)+1;if(ie<1)throw new Error;this.month=ie%12||ie}],MMMM:[b,function(K){var ee=P("months").indexOf(K)+1;if(ee<1)throw new Error;this.month=ee%12||ee}],Y:[/[+-]?\d+/,_("year")],YY:[p,function(K){this.year=T(K)}],YYYY:[/\d{4}/,_("year")],Z:A,ZZ:A};function j(K){var ee,ie;ee=K,ie=y&&y.formats;for(var oe=(K=ee.replace(/(\[[^\]]+])|(LTS?|l{1,4}|L{1,4})/g,function(X,ge,W){var xe=W&&W.toUpperCase();return ge||ie[W]||u[W]||ie[xe].replace(/(\[[^\]]+])|(MMMM|MM|DD|dddd)/g,function(U,Fe,Pe){return Fe||Pe.slice(1)})})).match(d),pe=oe.length,be=0;be-1)return new Date((Ie==="X"?1e3:1)*je);var Ce=j(Ie)(je),ke=Ce.year,Ke=Ce.month,Ft=Ce.day,Ne=Ce.hours,gn=Ce.minutes,_t=Ce.seconds,Et=Ce.milliseconds,Gt=Ce.zone,ln=new Date,xt=Ft||(ke||Ke?1:ln.getDate()),Pt=ke||ln.getFullYear(),Qe=0;ke&&!Ke||(Qe=Ke>0?Ke-1:ln.getMonth());var Dt=Ne||0,kt=gn||0,On=_t||0,ht=Et||0;return Gt?new Date(Date.UTC(Pt,Qe,xt,Dt,kt,On,ht+60*Gt.offset*1e3)):Se?new Date(Date.UTC(Pt,Qe,xt,Dt,kt,On,ht)):new Date(Pt,Qe,xt,Dt,kt,On,ht)}catch{return new Date("")}}(ae,de,ne),this.init(),xe&&xe!==!0&&(this.$L=this.locale(xe).$L),W&&ae!=this.format(de)&&(this.$d=new Date("")),y={}}else if(de instanceof Array)for(var U=de.length,Fe=1;Fe<=U;Fe+=1){se[1]=de[Fe-1];var Pe=ie.apply(this,se);if(Pe.isValid()){this.$d=Pe.$d,this.$L=Pe.$L,this.init();break}Fe===U&&(this.$d=new Date(""))}else pe.call(this,be)}}})})(QUe);var Mtn=QUe.exports;const Dtn=hC(Mtn);var JUe={exports:{}};(function(i,s){(function(u,d){i.exports=d()})(Ag,function(){return function(u,d){var p=d.prototype,v=p.format;p.format=function(b){var y=this,T=this.$locale();if(!this.isValid())return v.bind(this)(b);var _=this.$utils(),A=(b||"YYYY-MM-DDTHH:mm:ssZ").replace(/\[([^\]]+)]|Q|wo|ww|w|WW|W|zzz|z|gggg|GGGG|Do|X|x|k{1,2}|S/g,function(P){switch(P){case"Q":return Math.ceil((y.$M+1)/3);case"Do":return T.ordinal(y.$D);case"gggg":return y.weekYear();case"GGGG":return y.isoWeekYear();case"wo":return T.ordinal(y.week(),"W");case"w":case"ww":return _.s(y.week(),P==="w"?1:2,"0");case"W":case"WW":return _.s(y.isoWeek(),P==="W"?1:2,"0");case"k":case"kk":return _.s(String(y.$H===0?24:y.$H),P==="k"?1:2,"0");case"X":return Math.floor(y.$d.getTime()/1e3);case"x":return y.$d.getTime();case"z":return"["+y.offsetName()+"]";case"zzz":return"["+y.offsetName("long")+"]";default:return P}});return v.bind(this)(A)}}})})(JUe);var Itn=JUe.exports;const Otn=hC(Itn);Lg.extend(Ltn),Lg.extend(Dtn),Lg.extend(Otn);let i5="",Xme="",Qme,Jme="",FR=[],RR=[],Zme={},eve=[],uJ=[],GD="",tve="";const ZUe=["active","done","crit","milestone"];let nve=[],jR=!1,rve=!1,ive="sunday",sve=0;const Ntn=function(){eve=[],uJ=[],GD="",nve=[],lJ=0,ove=void 0,hJ=void 0,m1=[],i5="",Xme="",tve="",Qme=void 0,Jme="",FR=[],RR=[],jR=!1,rve=!1,sve=0,Zme={},Pg(),ive="sunday"},Ptn=function(i){Xme=i},Btn=function(){return Xme},Ftn=function(i){Qme=i},Rtn=function(){return Qme},jtn=function(i){Jme=i},$tn=function(){return Jme},ztn=function(i){i5=i},qtn=function(){jR=!0},Htn=function(){return jR},Vtn=function(){rve=!0},Utn=function(){return rve},Gtn=function(i){tve=i},Ktn=function(){return tve},Wtn=function(){return i5},Ytn=function(i){FR=i.toLowerCase().split(/[\s,]+/)},Xtn=function(){return FR},Qtn=function(i){RR=i.toLowerCase().split(/[\s,]+/)},Jtn=function(){return RR},Ztn=function(){return Zme},enn=function(i){GD=i,eve.push(i)},tnn=function(){return eve},nnn=function(){let i=sGe();const s=10;let u=0;for(;!i&&u=6&&u.includes("weekends")||u.includes(i.format("dddd").toLowerCase())?!0:u.includes(i.format(s.trim()))},rnn=function(i){ive=i},inn=function(){return ive},tGe=function(i,s,u,d){if(!u.length||i.manualEndTime)return;let p;i.startTime instanceof Date?p=Lg(i.startTime):p=Lg(i.startTime,s,!0),p=p.add(1,"d");let v;i.endTime instanceof Date?v=Lg(i.endTime):v=Lg(i.endTime,s,!0);const[b,y]=snn(p,v,s,u,d);i.endTime=b.toDate(),i.renderEndTime=y},snn=function(i,s,u,d,p){let v=!1,b=null;for(;i<=s;)v||(b=s.toDate()),v=eGe(i,u,d,p),v&&(s=s.add(1,"d")),i=i.add(1,"d");return[s,b]},ave=function(i,s,u){u=u.trim();const p=/^after\s+(?[\d\w- ]+)/.exec(u);if(p!==null){let b=null;for(const T of p.groups.ids.split(" ")){let _=QC(T);_!==void 0&&(!b||_.endTime>b.endTime)&&(b=_)}if(b)return b.endTime;const y=new Date;return y.setHours(0,0,0,0),y}let v=Lg(u,s.trim(),!0);if(v.isValid())return v.toDate();{Xe.debug("Invalid date:"+u),Xe.debug("With date format:"+s.trim());const b=new Date(u);if(b===void 0||isNaN(b.getTime())||b.getFullYear()<-1e4||b.getFullYear()>1e4)throw new Error("Invalid date:"+u);return b}},nGe=function(i){const s=/^(\d+(?:\.\d+)?)([Mdhmswy]|ms)$/.exec(i.trim());return s!==null?[Number.parseFloat(s[1]),s[2]]:[NaN,"ms"]},rGe=function(i,s,u,d=!1){u=u.trim();const v=/^until\s+(?[\d\w- ]+)/.exec(u);if(v!==null){let A=null;for(const R of v.groups.ids.split(" ")){let F=QC(R);F!==void 0&&(!A||F.startTime{window.open(u,"_self")}),Zme[d]=u)}),aGe(i,"clickable")},aGe=function(i,s){i.split(",").forEach(function(u){let d=QC(u);d!==void 0&&d.classes.push(s)})},hnn=function(i,s,u){if(qt().securityLevel!=="loose"||s===void 0)return;let d=[];if(typeof u=="string"){d=u.split(/,(?=(?:(?:[^"]*"){2})*[^"]*$)/);for(let v=0;v{Ao.runFunc(s,...d)})},oGe=function(i,s){nve.push(function(){const u=document.querySelector(`[id="${i}"]`);u!==null&&u.addEventListener("click",function(){s()})},function(){const u=document.querySelector(`[id="${i}-text"]`);u!==null&&u.addEventListener("click",function(){s()})})},fnn={getConfig:()=>qt().gantt,clear:Ntn,setDateFormat:ztn,getDateFormat:Wtn,enableInclusiveEndDates:qtn,endDatesAreInclusive:Htn,enableTopAxis:Vtn,topAxisEnabled:Utn,setAxisFormat:Ptn,getAxisFormat:Btn,setTickInterval:Ftn,getTickInterval:Rtn,setTodayMarker:jtn,getTodayMarker:$tn,setAccTitle:Bg,getAccTitle:Cp,setDiagramTitle:cm,getDiagramTitle:Ap,setDisplayMode:Gtn,getDisplayMode:Ktn,setAccDescription:Sp,getAccDescription:_p,addSection:enn,getSections:tnn,getTasks:nnn,addTask:cnn,findTaskById:QC,addTaskOrg:unn,setIncludes:Ytn,getIncludes:Xtn,setExcludes:Qtn,getExcludes:Jtn,setClickEvent:function(i,s,u){i.split(",").forEach(function(d){hnn(d,s,u)}),aGe(i,"clickable")},setLink:lnn,getLinks:Ztn,bindFunctions:function(i){nve.forEach(function(s){s(i)})},parseDuration:nGe,isInvalidDate:eGe,setWeekday:rnn,getWeekday:inn};function cGe(i,s,u){let d=!0;for(;d;)d=!1,u.forEach(function(p){const v="^\\s*"+p+"\\s*$",b=new RegExp(v);i[0].match(b)&&(s[p]=!0,i.shift(1),d=!0)})}const dnn=function(){Xe.debug("Something is calling, setConf, remove the call")},uGe={monday:DF,tuesday:xFe,wednesday:kFe,thursday:yC,friday:EFe,saturday:TFe,sunday:MF},gnn=(i,s)=>{let u=[...i].map(()=>-1/0),d=[...i].sort((v,b)=>v.startTime-b.startTime||v.order-b.order),p=0;for(const v of d)for(let b=0;b=u[b]){u[b]=v.endTime,v.order=b+s,b>p&&(p=b);break}return p};let V7;const pnn=Object.freeze(Object.defineProperty({__proto__:null,diagram:{parser:_tn,db:fnn,renderer:{setConf:dnn,draw:function(i,s,u,d){const p=qt().gantt,v=qt().securityLevel;let b;v==="sandbox"&&(b=Ir("#i"+s));const y=Ir(v==="sandbox"?b.nodes()[0].contentDocument.body:"body"),T=v==="sandbox"?b.nodes()[0].contentDocument:document,_=T.getElementById(s);V7=_.parentElement.offsetWidth,V7===void 0&&(V7=1200),p.useWidth!==void 0&&(V7=p.useWidth);const A=d.db.getTasks();let P=[];for(const de of A)P.push(de.type);P=se(P);const R={};let F=2*p.topPadding;if(d.db.getDisplayMode()==="compact"||p.displayMode==="compact"){const de={};for(const ge of A)de[ge.section]===void 0?de[ge.section]=[ge]:de[ge.section].push(ge);let X=0;for(const ge of Object.keys(de)){const W=gnn(de[ge],X)+1;X+=W,F+=W*(p.barHeight+p.barGap),R[ge]=W}}else{F+=A.length*(p.barHeight+p.barGap);for(const de of P)R[de]=A.filter(X=>X.type===de).length}_.setAttribute("viewBox","0 0 "+V7+" "+F);const j=y.select(`[id="${s}"]`),K=fNt().domain([WAt(A,function(de){return de.startTime}),KAt(A,function(de){return de.endTime})]).rangeRound([0,V7-p.leftPadding-p.rightPadding]);function ee(de,X){const ge=de.startTime,W=X.startTime;let xe=0;return ge>W?xe=1:geke.order))].map(ke=>de.find(Ke=>Ke.order===ke));j.append("g").selectAll("rect").data(je).enter().append("rect").attr("x",0).attr("y",function(ke,Ke){return Ke=ke.order,Ke*X+ge-2}).attr("width",function(){return Fe-p.rightPadding/2}).attr("height",X).attr("class",function(ke){for(const[Ke,Ft]of P.entries())if(ke.type===Ft)return"section section"+Ke%p.numberSectionStyles;return"section section0"});const Ie=j.append("g").selectAll("rect").data(de).enter(),Se=d.db.getLinks();if(Ie.append("rect").attr("id",function(ke){return ke.id}).attr("rx",3).attr("ry",3).attr("x",function(ke){return ke.milestone?K(ke.startTime)+W+.5*(K(ke.endTime)-K(ke.startTime))-.5*xe:K(ke.startTime)+W}).attr("y",function(ke,Ke){return Ke=ke.order,Ke*X+ge}).attr("width",function(ke){return ke.milestone?xe:K(ke.renderEndTime||ke.endTime)-K(ke.startTime)}).attr("height",xe).attr("transform-origin",function(ke,Ke){return Ke=ke.order,(K(ke.startTime)+W+.5*(K(ke.endTime)-K(ke.startTime))).toString()+"px "+(Ke*X+ge+.5*xe).toString()+"px"}).attr("class",function(ke){const Ke="task";let Ft="";ke.classes.length>0&&(Ft=ke.classes.join(" "));let Ne=0;for(const[_t,Et]of P.entries())ke.type===Et&&(Ne=_t%p.numberSectionStyles);let gn="";return ke.active?ke.crit?gn+=" activeCrit":gn=" active":ke.done?ke.crit?gn=" doneCrit":gn=" done":ke.crit&&(gn+=" crit"),gn.length===0&&(gn=" task"),ke.milestone&&(gn=" milestone "+gn),gn+=Ne,gn+=" "+Ft,Ke+gn}),Ie.append("text").attr("id",function(ke){return ke.id+"-text"}).text(function(ke){return ke.task}).attr("font-size",p.fontSize).attr("x",function(ke){let Ke=K(ke.startTime),Ft=K(ke.renderEndTime||ke.endTime);ke.milestone&&(Ke+=.5*(K(ke.endTime)-K(ke.startTime))-.5*xe),ke.milestone&&(Ft=Ke+xe);const Ne=this.getBBox().width;return Ne>Ft-Ke?Ft+Ne+1.5*p.leftPadding>Fe?Ke+W-5:Ft+W+5:(Ft-Ke)/2+Ke+W}).attr("y",function(ke,Ke){return Ke=ke.order,Ke*X+p.barHeight/2+(p.fontSize/2-2)+ge}).attr("text-height",xe).attr("class",function(ke){const Ke=K(ke.startTime);let Ft=K(ke.endTime);ke.milestone&&(Ft=Ke+xe);const Ne=this.getBBox().width;let gn="";ke.classes.length>0&&(gn=ke.classes.join(" "));let _t=0;for(const[Gt,ln]of P.entries())ke.type===ln&&(_t=Gt%p.numberSectionStyles);let Et="";return ke.active&&(ke.crit?Et="activeCritText"+_t:Et="activeText"+_t),ke.done?ke.crit?Et=Et+" doneCritText"+_t:Et=Et+" doneText"+_t:ke.crit&&(Et=Et+" critText"+_t),ke.milestone&&(Et+=" milestoneText"),Ne>Ft-Ke?Ft+Ne+1.5*p.leftPadding>Fe?gn+" taskTextOutsideLeft taskTextOutside"+_t+" "+Et:gn+" taskTextOutsideRight taskTextOutside"+_t+" "+Et+" width-"+Ne:gn+" taskText taskText"+_t+" "+Et+" width-"+Ne}),qt().securityLevel==="sandbox"){let ke;ke=Ir("#i"+s);const Ke=ke.nodes()[0].contentDocument;Ie.filter(function(Ft){return Se[Ft.id]!==void 0}).each(function(Ft){var Ne=Ke.querySelector("#"+Ft.id),gn=Ke.querySelector("#"+Ft.id+"-text");const _t=Ne.parentNode;var Et=Ke.createElement("a");Et.setAttribute("xlink:href",Se[Ft.id]),Et.setAttribute("target","_top"),_t.appendChild(Et),Et.appendChild(Ne),Et.appendChild(gn)})}}function pe(de,X,ge,W,xe,U,Fe,Pe){if(Fe.length===0&&Pe.length===0)return;let je,Ie;for(const{startTime:Ne,endTime:gn}of U)(je===void 0||NeIe)&&(Ie=gn);if(!je||!Ie)return;if(Lg(Ie).diff(Lg(je),"year")>5){Xe.warn("The difference between the min and max time is more than 5 years. This will cause performance issues. Skipping drawing exclude days.");return}const Se=d.db.getDateFormat(),Ce=[];let ke=null,Ke=Lg(je);for(;Ke.valueOf()<=Ie;)d.db.isInvalidDate(Ke,Se,Fe,Pe)?ke?ke.end=Ke:ke={start:Ke,end:Ke}:ke&&(Ce.push(ke),ke=null),Ke=Ke.add(1,"d");j.append("g").selectAll("rect").data(Ce).enter().append("rect").attr("id",function(Ne){return"exclude-"+Ne.start.format("YYYY-MM-DD")}).attr("x",function(Ne){return K(Ne.start)+ge}).attr("y",p.gridLineStartPadding).attr("width",function(Ne){const gn=Ne.end.add(1,"day");return K(gn)-K(Ne.start)}).attr("height",xe-X-p.gridLineStartPadding).attr("transform-origin",function(Ne,gn){return(K(Ne.start)+ge+.5*(K(Ne.end)-K(Ne.start))).toString()+"px "+(gn*de+.5*xe).toString()+"px"}).attr("class","exclude-range")}function be(de,X,ge,W){let xe=rLt(K).tickSize(-W+X+p.gridLineStartPadding).tickFormat(sX(d.db.getAxisFormat()||p.axisFormat||"%Y-%m-%d"));const Fe=/^([1-9]\d*)(millisecond|second|minute|hour|day|week|month)$/.exec(d.db.getTickInterval()||p.tickInterval);if(Fe!==null){const Pe=Fe[1],je=Fe[2],Ie=d.db.getWeekday()||p.weekday;switch(je){case"millisecond":xe.ticks(aD.every(Pe));break;case"second":xe.ticks(b9.every(Pe));break;case"minute":xe.ticks(AF.every(Pe));break;case"hour":xe.ticks(LF.every(Pe));break;case"day":xe.ticks(vC.every(Pe));break;case"week":xe.ticks(uGe[Ie].every(Pe));break;case"month":xe.ticks(IF.every(Pe));break}}if(j.append("g").attr("class","grid").attr("transform","translate("+de+", "+(W-50)+")").call(xe).selectAll("text").style("text-anchor","middle").attr("fill","#000").attr("stroke","none").attr("font-size",10).attr("dy","1em"),d.db.topAxisEnabled()||p.topAxis){let Pe=nLt(K).tickSize(-W+X+p.gridLineStartPadding).tickFormat(sX(d.db.getAxisFormat()||p.axisFormat||"%Y-%m-%d"));if(Fe!==null){const je=Fe[1],Ie=Fe[2],Se=d.db.getWeekday()||p.weekday;switch(Ie){case"millisecond":Pe.ticks(aD.every(je));break;case"second":Pe.ticks(b9.every(je));break;case"minute":Pe.ticks(AF.every(je));break;case"hour":Pe.ticks(LF.every(je));break;case"day":Pe.ticks(vC.every(je));break;case"week":Pe.ticks(uGe[Se].every(je));break;case"month":Pe.ticks(IF.every(je));break}}j.append("g").attr("class","grid").attr("transform","translate("+de+", "+X+")").call(Pe).selectAll("text").style("text-anchor","middle").attr("fill","#000").attr("stroke","none").attr("font-size",10)}}function ae(de,X){let ge=0;const W=Object.keys(R).map(xe=>[xe,R[xe]]);j.append("g").selectAll("text").data(W).enter().append(function(xe){const U=xe[0].split(ci.lineBreakRegex),Fe=-(U.length-1)/2,Pe=T.createElementNS("http://www.w3.org/2000/svg","text");Pe.setAttribute("dy",Fe+"em");for(const[je,Ie]of U.entries()){const Se=T.createElementNS("http://www.w3.org/2000/svg","tspan");Se.setAttribute("alignment-baseline","central"),Se.setAttribute("x","10"),je>0&&Se.setAttribute("dy","1em"),Se.textContent=Ie,Pe.appendChild(Se)}return Pe}).attr("x",10).attr("y",function(xe,U){if(U>0)for(let Fe=0;Fe` + .mermaid-main-font { + font-family: var(--mermaid-font-family, "trebuchet ms", verdana, arial, sans-serif); + } + + .exclude-range { + fill: ${i.excludeBkgColor}; + } + + .section { + stroke: none; + opacity: 0.2; + } + + .section0 { + fill: ${i.sectionBkgColor}; + } + + .section2 { + fill: ${i.sectionBkgColor2}; + } + + .section1, + .section3 { + fill: ${i.altSectionBkgColor}; + opacity: 0.2; + } + + .sectionTitle0 { + fill: ${i.titleColor}; + } + + .sectionTitle1 { + fill: ${i.titleColor}; + } + + .sectionTitle2 { + fill: ${i.titleColor}; + } + + .sectionTitle3 { + fill: ${i.titleColor}; + } + + .sectionTitle { + text-anchor: start; + font-family: var(--mermaid-font-family, "trebuchet ms", verdana, arial, sans-serif); + } + + + /* Grid and axis */ + + .grid .tick { + stroke: ${i.gridColor}; + opacity: 0.8; + shape-rendering: crispEdges; + } + + .grid .tick text { + font-family: ${i.fontFamily}; + fill: ${i.textColor}; + } + + .grid path { + stroke-width: 0; + } + + + /* Today line */ + + .today { + fill: none; + stroke: ${i.todayLineColor}; + stroke-width: 2px; + } + + + /* Task styling */ + + /* Default task */ + + .task { + stroke-width: 2; + } + + .taskText { + text-anchor: middle; + font-family: var(--mermaid-font-family, "trebuchet ms", verdana, arial, sans-serif); + } + + .taskTextOutsideRight { + fill: ${i.taskTextDarkColor}; + text-anchor: start; + font-family: var(--mermaid-font-family, "trebuchet ms", verdana, arial, sans-serif); + } + + .taskTextOutsideLeft { + fill: ${i.taskTextDarkColor}; + text-anchor: end; + } + + + /* Special case clickable */ + + .task.clickable { + cursor: pointer; + } + + .taskText.clickable { + cursor: pointer; + fill: ${i.taskTextClickableColor} !important; + font-weight: bold; + } + + .taskTextOutsideLeft.clickable { + cursor: pointer; + fill: ${i.taskTextClickableColor} !important; + font-weight: bold; + } + + .taskTextOutsideRight.clickable { + cursor: pointer; + fill: ${i.taskTextClickableColor} !important; + font-weight: bold; + } + + + /* Specific task settings for the sections*/ + + .taskText0, + .taskText1, + .taskText2, + .taskText3 { + fill: ${i.taskTextColor}; + } + + .task0, + .task1, + .task2, + .task3 { + fill: ${i.taskBkgColor}; + stroke: ${i.taskBorderColor}; + } + + .taskTextOutside0, + .taskTextOutside2 + { + fill: ${i.taskTextOutsideColor}; + } + + .taskTextOutside1, + .taskTextOutside3 { + fill: ${i.taskTextOutsideColor}; + } + + + /* Active task */ + + .active0, + .active1, + .active2, + .active3 { + fill: ${i.activeTaskBkgColor}; + stroke: ${i.activeTaskBorderColor}; + } + + .activeText0, + .activeText1, + .activeText2, + .activeText3 { + fill: ${i.taskTextDarkColor} !important; + } + + + /* Completed task */ + + .done0, + .done1, + .done2, + .done3 { + stroke: ${i.doneTaskBorderColor}; + fill: ${i.doneTaskBkgColor}; + stroke-width: 2; + } + + .doneText0, + .doneText1, + .doneText2, + .doneText3 { + fill: ${i.taskTextDarkColor} !important; + } + + + /* Tasks on the critical line */ + + .crit0, + .crit1, + .crit2, + .crit3 { + stroke: ${i.critBorderColor}; + fill: ${i.critBkgColor}; + stroke-width: 2; + } + + .activeCrit0, + .activeCrit1, + .activeCrit2, + .activeCrit3 { + stroke: ${i.critBorderColor}; + fill: ${i.activeTaskBkgColor}; + stroke-width: 2; + } + + .doneCrit0, + .doneCrit1, + .doneCrit2, + .doneCrit3 { + stroke: ${i.critBorderColor}; + fill: ${i.doneTaskBkgColor}; + stroke-width: 2; + cursor: pointer; + shape-rendering: crispEdges; + } + + .milestone { + transform: rotate(45deg) scale(0.8,0.8); + } + + .milestoneText { + font-style: italic; + } + .doneCritText0, + .doneCritText1, + .doneCritText2, + .doneCritText3 { + fill: ${i.taskTextDarkColor} !important; + } + + .activeCritText0, + .activeCritText1, + .activeCritText2, + .activeCritText3 { + fill: ${i.taskTextDarkColor} !important; + } + + .titleText { + text-anchor: middle; + font-size: 18px; + fill: ${i.titleColor||i.textColor}; + font-family: var(--mermaid-font-family, "trebuchet ms", verdana, arial, sans-serif); + } +`}},Symbol.toStringTag,{value:"Module"}));var cve=function(){var i=function(v,b,y,T){for(y=y||{},T=v.length;T--;y[v[T]]=b);return y},s=[6,9,10],u={trace:function(){},yy:{},symbols_:{error:2,start:3,info:4,document:5,EOF:6,line:7,statement:8,NL:9,showInfo:10,$accept:0,$end:1},terminals_:{2:"error",4:"info",6:"EOF",9:"NL",10:"showInfo"},productions_:[0,[3,3],[5,0],[5,2],[7,1],[7,1],[8,1]],performAction:function(b,y,T,_,A,P,R){switch(P.length-1,A){case 1:return _;case 4:break;case 6:_.setInfo(!0);break}},table:[{3:1,4:[1,2]},{1:[3]},i(s,[2,2],{5:3}),{6:[1,4],7:5,8:6,9:[1,7],10:[1,8]},{1:[2,1]},i(s,[2,3]),i(s,[2,4]),i(s,[2,5]),i(s,[2,6])],defaultActions:{4:[2,1]},parseError:function(b,y){if(y.recoverable)this.trace(b);else{var T=new Error(b);throw T.hash=y,T}},parse:function(b){var y=this,T=[0],_=[],A=[null],P=[],R=this.table,F="",j=0,K=0,ee=2,ie=1,oe=P.slice.call(arguments,1),pe=Object.create(this.lexer),be={yy:{}};for(var ae in this.yy)Object.prototype.hasOwnProperty.call(this.yy,ae)&&(be.yy[ae]=this.yy[ae]);pe.setInput(b,be.yy),be.yy.lexer=pe,be.yy.parser=this,typeof pe.yylloc>"u"&&(pe.yylloc={});var ne=pe.yylloc;P.push(ne);var se=pe.options&&pe.options.ranges;typeof be.yy.parseError=="function"?this.parseError=be.yy.parseError:this.parseError=Object.getPrototypeOf(this).parseError;function de(){var Ce;return Ce=_.pop()||pe.lex()||ie,typeof Ce!="number"&&(Ce instanceof Array&&(_=Ce,Ce=_.pop()),Ce=y.symbols_[Ce]||Ce),Ce}for(var X,ge,W,xe,U={},Fe,Pe,je,Ie;;){if(ge=T[T.length-1],this.defaultActions[ge]?W=this.defaultActions[ge]:((X===null||typeof X>"u")&&(X=de()),W=R[ge]&&R[ge][X]),typeof W>"u"||!W.length||!W[0]){var Se="";Ie=[];for(Fe in R[ge])this.terminals_[Fe]&&Fe>ee&&Ie.push("'"+this.terminals_[Fe]+"'");pe.showPosition?Se="Parse error on line "+(j+1)+`: +`+pe.showPosition()+` +Expecting `+Ie.join(", ")+", got '"+(this.terminals_[X]||X)+"'":Se="Parse error on line "+(j+1)+": Unexpected "+(X==ie?"end of input":"'"+(this.terminals_[X]||X)+"'"),this.parseError(Se,{text:pe.match,token:this.terminals_[X]||X,line:pe.yylineno,loc:ne,expected:Ie})}if(W[0]instanceof Array&&W.length>1)throw new Error("Parse Error: multiple actions possible at state: "+ge+", token: "+X);switch(W[0]){case 1:T.push(X),A.push(pe.yytext),P.push(pe.yylloc),T.push(W[1]),X=null,K=pe.yyleng,F=pe.yytext,j=pe.yylineno,ne=pe.yylloc;break;case 2:if(Pe=this.productions_[W[1]][1],U.$=A[A.length-Pe],U._$={first_line:P[P.length-(Pe||1)].first_line,last_line:P[P.length-1].last_line,first_column:P[P.length-(Pe||1)].first_column,last_column:P[P.length-1].last_column},se&&(U._$.range=[P[P.length-(Pe||1)].range[0],P[P.length-1].range[1]]),xe=this.performAction.apply(U,[F,K,j,be.yy,W[1],A,P].concat(oe)),typeof xe<"u")return xe;Pe&&(T=T.slice(0,-1*Pe*2),A=A.slice(0,-1*Pe),P=P.slice(0,-1*Pe)),T.push(this.productions_[W[1]][0]),A.push(U.$),P.push(U._$),je=R[T[T.length-2]][T[T.length-1]],T.push(je);break;case 3:return!0}}return!0}},d=function(){var v={EOF:1,parseError:function(y,T){if(this.yy.parser)this.yy.parser.parseError(y,T);else throw new Error(y)},setInput:function(b,y){return this.yy=y||this.yy||{},this._input=b,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},input:function(){var b=this._input[0];this.yytext+=b,this.yyleng++,this.offset++,this.match+=b,this.matched+=b;var y=b.match(/(?:\r\n?|\n).*/g);return y?(this.yylineno++,this.yylloc.last_line++):this.yylloc.last_column++,this.options.ranges&&this.yylloc.range[1]++,this._input=this._input.slice(1),b},unput:function(b){var y=b.length,T=b.split(/(?:\r\n?|\n)/g);this._input=b+this._input,this.yytext=this.yytext.substr(0,this.yytext.length-y),this.offset-=y;var _=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),T.length-1&&(this.yylineno-=T.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:T?(T.length===_.length?this.yylloc.first_column:0)+_[_.length-T.length].length-T[0].length:this.yylloc.first_column-y},this.options.ranges&&(this.yylloc.range=[A[0],A[0]+this.yyleng-y]),this.yyleng=this.yytext.length,this},more:function(){return this._more=!0,this},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},less:function(b){this.unput(this.match.slice(b))},pastInput:function(){var b=this.matched.substr(0,this.matched.length-this.match.length);return(b.length>20?"...":"")+b.substr(-20).replace(/\n/g,"")},upcomingInput:function(){var b=this.match;return b.length<20&&(b+=this._input.substr(0,20-b.length)),(b.substr(0,20)+(b.length>20?"...":"")).replace(/\n/g,"")},showPosition:function(){var b=this.pastInput(),y=new Array(b.length+1).join("-");return b+this.upcomingInput()+` +`+y+"^"},test_match:function(b,y){var T,_,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))),_=b[0].match(/(?:\r\n?|\n).*/g),_&&(this.yylineno+=_.length),this.yylloc={first_line:this.yylloc.last_line,last_line:this.yylineno+1,first_column:this.yylloc.last_column,last_column:_?_[_.length-1].length-_[_.length-1].match(/\r?\n?/)[0].length:this.yylloc.last_column+b[0].length},this.yytext+=b[0],this.match+=b[0],this.matches=b,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(b[0].length),this.matched+=b[0],T=this.performAction.call(this,this.yy,this,y,this.conditionStack[this.conditionStack.length-1]),this.done&&this._input&&(this.done=!1),T)return T;if(this._backtrack){for(var P in A)this[P]=A[P];return!1}return!1},next:function(){if(this.done)return this.EOF;this._input||(this.done=!0);var b,y,T,_;this._more||(this.yytext="",this.match="");for(var A=this._currentRules(),P=0;Py[0].length)){if(y=T,_=P,this.options.backtrack_lexer){if(b=this.test_match(T,A[P]),b!==!1)return b;if(this._backtrack){y=!1;continue}else return!1}else if(!this.options.flex)break}return y?(b=this.test_match(y,A[_]),b!==!1?b:!1):this._input===""?this.EOF:this.parseError("Lexical error on line "+(this.yylineno+1)+`. Unrecognized text. +`+this.showPosition(),{text:"",token:null,line:this.yylineno})},lex:function(){var y=this.next();return y||this.lex()},begin:function(y){this.conditionStack.push(y)},popState:function(){var y=this.conditionStack.length-1;return y>0?this.conditionStack.pop():this.conditionStack[0]},_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},topState:function(y){return y=this.conditionStack.length-1-Math.abs(y||0),y>=0?this.conditionStack[y]:"INITIAL"},pushState:function(y){this.begin(y)},stateStackSize:function(){return this.conditionStack.length},options:{"case-insensitive":!0},performAction:function(y,T,_,A){switch(_){case 0:return 4;case 1:return 9;case 2:return"space";case 3:return 10;case 4:return 6;case 5:return"TXT"}},rules:[/^(?:info\b)/i,/^(?:[\s\n\r]+)/i,/^(?:[\s]+)/i,/^(?:showInfo\b)/i,/^(?:$)/i,/^(?:.)/i],conditions:{INITIAL:{rules:[0,1,2,3,4,5],inclusive:!0}}};return v}();u.lexer=d;function p(){this.yy={}}return p.prototype=u,u.Parser=p,new p}();cve.parser=cve;const bnn=cve,lGe={info:!1};let uve=lGe.info;const mnn=Object.freeze(Object.defineProperty({__proto__:null,diagram:{parser:bnn,db:{clear:()=>{uve=lGe.info},setInfo:i=>{uve=i},getInfo:()=>uve},renderer:{draw:(i,s,u)=>{Xe.debug(`rendering info diagram +`+i);const d=rR(s);Ng(d,100,400,!0),d.append("g").append("text").attr("x",100).attr("y",40).attr("class","version").attr("font-size",32).style("text-anchor","middle").text(`v${u}`)}}}},Symbol.toStringTag,{value:"Module"}));var lve=function(){var i=function(pe,be,ae,ne){for(ae=ae||{},ne=pe.length;ne--;ae[pe[ne]]=be);return ae},s=[1,3],u=[1,4],d=[1,5],p=[1,6],v=[1,10,12,14,16,18,19,20,21,22],b=[2,4],y=[1,5,10,12,14,16,18,19,20,21,22],T=[20,21,22],_=[2,7],A=[1,12],P=[1,13],R=[1,14],F=[1,15],j=[1,16],K=[1,17],ee={trace:function(){},yy:{},symbols_:{error:2,start:3,eol:4,PIE:5,document:6,showData:7,line:8,statement:9,txt:10,value:11,title:12,title_value:13,acc_title:14,acc_title_value:15,acc_descr:16,acc_descr_value:17,acc_descr_multiline_value:18,section:19,NEWLINE:20,";":21,EOF:22,$accept:0,$end:1},terminals_:{2:"error",5:"PIE",7:"showData",10:"txt",11:"value",12:"title",13:"title_value",14:"acc_title",15:"acc_title_value",16:"acc_descr",17:"acc_descr_value",18:"acc_descr_multiline_value",19:"section",20:"NEWLINE",21:";",22:"EOF"},productions_:[0,[3,2],[3,2],[3,3],[6,0],[6,2],[8,2],[9,0],[9,2],[9,2],[9,2],[9,2],[9,1],[9,1],[4,1],[4,1],[4,1]],performAction:function(be,ae,ne,se,de,X,ge){var W=X.length-1;switch(de){case 3:se.setShowData(!0);break;case 6:this.$=X[W-1];break;case 8:se.addSection(X[W-1],se.cleanupValue(X[W]));break;case 9:this.$=X[W].trim(),se.setDiagramTitle(this.$);break;case 10:this.$=X[W].trim(),se.setAccTitle(this.$);break;case 11:case 12:this.$=X[W].trim(),se.setAccDescription(this.$);break;case 13:se.addSection(X[W].substr(8)),this.$=X[W].substr(8);break}},table:[{3:1,4:2,5:s,20:u,21:d,22:p},{1:[3]},{3:7,4:2,5:s,20:u,21:d,22:p},i(v,b,{6:8,7:[1,9]}),i(y,[2,14]),i(y,[2,15]),i(y,[2,16]),{1:[2,1]},i(T,_,{8:10,9:11,1:[2,2],10:A,12:P,14:R,16:F,18:j,19:K}),i(v,b,{6:18}),i(v,[2,5]),{4:19,20:u,21:d,22:p},{11:[1,20]},{13:[1,21]},{15:[1,22]},{17:[1,23]},i(T,[2,12]),i(T,[2,13]),i(T,_,{8:10,9:11,1:[2,3],10:A,12:P,14:R,16:F,18:j,19:K}),i(v,[2,6]),i(T,[2,8]),i(T,[2,9]),i(T,[2,10]),i(T,[2,11])],defaultActions:{7:[2,1]},parseError:function(be,ae){if(ae.recoverable)this.trace(be);else{var ne=new Error(be);throw ne.hash=ae,ne}},parse:function(be){var ae=this,ne=[0],se=[],de=[null],X=[],ge=this.table,W="",xe=0,U=0,Fe=2,Pe=1,je=X.slice.call(arguments,1),Ie=Object.create(this.lexer),Se={yy:{}};for(var Ce in this.yy)Object.prototype.hasOwnProperty.call(this.yy,Ce)&&(Se.yy[Ce]=this.yy[Ce]);Ie.setInput(be,Se.yy),Se.yy.lexer=Ie,Se.yy.parser=this,typeof Ie.yylloc>"u"&&(Ie.yylloc={});var ke=Ie.yylloc;X.push(ke);var Ke=Ie.options&&Ie.options.ranges;typeof Se.yy.parseError=="function"?this.parseError=Se.yy.parseError:this.parseError=Object.getPrototypeOf(this).parseError;function Ft(){var kt;return kt=se.pop()||Ie.lex()||Pe,typeof kt!="number"&&(kt instanceof Array&&(se=kt,kt=se.pop()),kt=ae.symbols_[kt]||kt),kt}for(var Ne,gn,_t,Et,Gt={},ln,xt,Pt,Qe;;){if(gn=ne[ne.length-1],this.defaultActions[gn]?_t=this.defaultActions[gn]:((Ne===null||typeof Ne>"u")&&(Ne=Ft()),_t=ge[gn]&&ge[gn][Ne]),typeof _t>"u"||!_t.length||!_t[0]){var Dt="";Qe=[];for(ln in ge[gn])this.terminals_[ln]&&ln>Fe&&Qe.push("'"+this.terminals_[ln]+"'");Ie.showPosition?Dt="Parse error on line "+(xe+1)+`: +`+Ie.showPosition()+` +Expecting `+Qe.join(", ")+", got '"+(this.terminals_[Ne]||Ne)+"'":Dt="Parse error on line "+(xe+1)+": Unexpected "+(Ne==Pe?"end of input":"'"+(this.terminals_[Ne]||Ne)+"'"),this.parseError(Dt,{text:Ie.match,token:this.terminals_[Ne]||Ne,line:Ie.yylineno,loc:ke,expected:Qe})}if(_t[0]instanceof Array&&_t.length>1)throw new Error("Parse Error: multiple actions possible at state: "+gn+", token: "+Ne);switch(_t[0]){case 1:ne.push(Ne),de.push(Ie.yytext),X.push(Ie.yylloc),ne.push(_t[1]),Ne=null,U=Ie.yyleng,W=Ie.yytext,xe=Ie.yylineno,ke=Ie.yylloc;break;case 2:if(xt=this.productions_[_t[1]][1],Gt.$=de[de.length-xt],Gt._$={first_line:X[X.length-(xt||1)].first_line,last_line:X[X.length-1].last_line,first_column:X[X.length-(xt||1)].first_column,last_column:X[X.length-1].last_column},Ke&&(Gt._$.range=[X[X.length-(xt||1)].range[0],X[X.length-1].range[1]]),Et=this.performAction.apply(Gt,[W,U,xe,Se.yy,_t[1],de,X].concat(je)),typeof Et<"u")return Et;xt&&(ne=ne.slice(0,-1*xt*2),de=de.slice(0,-1*xt),X=X.slice(0,-1*xt)),ne.push(this.productions_[_t[1]][0]),de.push(Gt.$),X.push(Gt._$),Pt=ge[ne[ne.length-2]][ne[ne.length-1]],ne.push(Pt);break;case 3:return!0}}return!0}},ie=function(){var pe={EOF:1,parseError:function(ae,ne){if(this.yy.parser)this.yy.parser.parseError(ae,ne);else throw new Error(ae)},setInput:function(be,ae){return this.yy=ae||this.yy||{},this._input=be,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},input:function(){var be=this._input[0];this.yytext+=be,this.yyleng++,this.offset++,this.match+=be,this.matched+=be;var ae=be.match(/(?:\r\n?|\n).*/g);return ae?(this.yylineno++,this.yylloc.last_line++):this.yylloc.last_column++,this.options.ranges&&this.yylloc.range[1]++,this._input=this._input.slice(1),be},unput:function(be){var ae=be.length,ne=be.split(/(?:\r\n?|\n)/g);this._input=be+this._input,this.yytext=this.yytext.substr(0,this.yytext.length-ae),this.offset-=ae;var se=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),ne.length-1&&(this.yylineno-=ne.length-1);var de=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:ne?(ne.length===se.length?this.yylloc.first_column:0)+se[se.length-ne.length].length-ne[0].length:this.yylloc.first_column-ae},this.options.ranges&&(this.yylloc.range=[de[0],de[0]+this.yyleng-ae]),this.yyleng=this.yytext.length,this},more:function(){return this._more=!0,this},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},less:function(be){this.unput(this.match.slice(be))},pastInput:function(){var be=this.matched.substr(0,this.matched.length-this.match.length);return(be.length>20?"...":"")+be.substr(-20).replace(/\n/g,"")},upcomingInput:function(){var be=this.match;return be.length<20&&(be+=this._input.substr(0,20-be.length)),(be.substr(0,20)+(be.length>20?"...":"")).replace(/\n/g,"")},showPosition:function(){var be=this.pastInput(),ae=new Array(be.length+1).join("-");return be+this.upcomingInput()+` +`+ae+"^"},test_match:function(be,ae){var ne,se,de;if(this.options.backtrack_lexer&&(de={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&&(de.yylloc.range=this.yylloc.range.slice(0))),se=be[0].match(/(?:\r\n?|\n).*/g),se&&(this.yylineno+=se.length),this.yylloc={first_line:this.yylloc.last_line,last_line:this.yylineno+1,first_column:this.yylloc.last_column,last_column:se?se[se.length-1].length-se[se.length-1].match(/\r?\n?/)[0].length:this.yylloc.last_column+be[0].length},this.yytext+=be[0],this.match+=be[0],this.matches=be,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(be[0].length),this.matched+=be[0],ne=this.performAction.call(this,this.yy,this,ae,this.conditionStack[this.conditionStack.length-1]),this.done&&this._input&&(this.done=!1),ne)return ne;if(this._backtrack){for(var X in de)this[X]=de[X];return!1}return!1},next:function(){if(this.done)return this.EOF;this._input||(this.done=!0);var be,ae,ne,se;this._more||(this.yytext="",this.match="");for(var de=this._currentRules(),X=0;Xae[0].length)){if(ae=ne,se=X,this.options.backtrack_lexer){if(be=this.test_match(ne,de[X]),be!==!1)return be;if(this._backtrack){ae=!1;continue}else return!1}else if(!this.options.flex)break}return ae?(be=this.test_match(ae,de[se]),be!==!1?be:!1):this._input===""?this.EOF:this.parseError("Lexical error on line "+(this.yylineno+1)+`. Unrecognized text. +`+this.showPosition(),{text:"",token:null,line:this.yylineno})},lex:function(){var ae=this.next();return ae||this.lex()},begin:function(ae){this.conditionStack.push(ae)},popState:function(){var ae=this.conditionStack.length-1;return ae>0?this.conditionStack.pop():this.conditionStack[0]},_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},topState:function(ae){return ae=this.conditionStack.length-1-Math.abs(ae||0),ae>=0?this.conditionStack[ae]:"INITIAL"},pushState:function(ae){this.begin(ae)},stateStackSize:function(){return this.conditionStack.length},options:{"case-insensitive":!0},performAction:function(ae,ne,se,de){switch(se){case 0:break;case 1:break;case 2:return 20;case 3:break;case 4:break;case 5:return this.begin("title"),12;case 6:return this.popState(),"title_value";case 7:return this.begin("acc_title"),14;case 8:return this.popState(),"acc_title_value";case 9:return this.begin("acc_descr"),16;case 10:return this.popState(),"acc_descr_value";case 11:this.begin("acc_descr_multiline");break;case 12:this.popState();break;case 13:return"acc_descr_multiline_value";case 14:this.begin("string");break;case 15:this.popState();break;case 16:return"txt";case 17:return 5;case 18:return 7;case 19:return"value";case 20:return 22}},rules:[/^(?:%%(?!\{)[^\n]*)/i,/^(?:[^\}]%%[^\n]*)/i,/^(?:[\n\r]+)/i,/^(?:%%[^\n]*)/i,/^(?:[\s]+)/i,/^(?:title\b)/i,/^(?:(?!\n||)*[^\n]*)/i,/^(?:accTitle\s*:\s*)/i,/^(?:(?!\n||)*[^\n]*)/i,/^(?:accDescr\s*:\s*)/i,/^(?:(?!\n||)*[^\n]*)/i,/^(?:accDescr\s*\{\s*)/i,/^(?:[\}])/i,/^(?:[^\}]*)/i,/^(?:["])/i,/^(?:["])/i,/^(?:[^"]*)/i,/^(?:pie\b)/i,/^(?:showData\b)/i,/^(?::[\s]*[\d]+(?:\.[\d]+)?)/i,/^(?:$)/i],conditions:{acc_descr_multiline:{rules:[12,13],inclusive:!1},acc_descr:{rules:[10],inclusive:!1},acc_title:{rules:[8],inclusive:!1},title:{rules:[6],inclusive:!1},string:{rules:[15,16],inclusive:!1},INITIAL:{rules:[0,1,2,3,4,5,7,9,11,14,17,18,19,20],inclusive:!0}}};return pe}();ee.lexer=ie;function oe(){this.yy={}}return oe.prototype=ee,ee.Parser=oe,new oe}();lve.parser=lve;const vnn=lve,hGe=sh.pie,fJ={sections:{},showData:!1,config:hGe};let dJ=fJ.sections,hve=fJ.showData;const wnn=structuredClone(hGe),ynn={getConfig:()=>structuredClone(wnn),clear:()=>{dJ=structuredClone(fJ.sections),hve=fJ.showData,Pg()},setDiagramTitle:cm,getDiagramTitle:Ap,setAccTitle:Bg,getAccTitle:Cp,setAccDescription:Sp,getAccDescription:_p,addSection:(i,s)=>{i=Yf(i,qt()),dJ[i]===void 0&&(dJ[i]=s,Xe.debug(`added new section: ${i}, with value: ${s}`))},getSections:()=>dJ,cleanupValue:i=>(i.substring(0,1)===":"&&(i=i.substring(1).trim()),Number(i.trim())),setShowData:i=>{hve=i},getShowData:()=>hve},xnn=i=>` + .pieCircle{ + stroke: ${i.pieStrokeColor}; + stroke-width : ${i.pieStrokeWidth}; + opacity : ${i.pieOpacity}; + } + .pieOuterCircle{ + stroke: ${i.pieOuterStrokeColor}; + stroke-width: ${i.pieOuterStrokeWidth}; + fill: none; + } + .pieTitleText { + text-anchor: middle; + font-size: ${i.pieTitleTextSize}; + fill: ${i.pieTitleTextColor}; + font-family: ${i.fontFamily}; + } + .slice { + font-family: ${i.fontFamily}; + fill: ${i.pieSectionTextColor}; + font-size:${i.pieSectionTextSize}; + // fill: white; + } + .legend text { + fill: ${i.pieLegendTextColor}; + font-family: ${i.fontFamily}; + font-size: ${i.pieLegendTextSize}; + } +`,knn=i=>{const s=Object.entries(i).map(d=>({label:d[0],value:d[1]})).sort((d,p)=>p.value-d.value);return SNt().value(d=>d.value)(s)},Enn=Object.freeze(Object.defineProperty({__proto__:null,diagram:{parser:vnn,db:ynn,renderer:{draw:(i,s,u,d)=>{Xe.debug(`rendering pie chart +`+i);const p=d.db,v=qt(),b=JF(p.getConfig(),v.pie),y=40,T=18,_=4,A=450,P=A,R=rR(s),F=R.append("g"),j=p.getSections();F.attr("transform","translate("+P/2+","+A/2+")");const{themeVariables:K}=v;let[ee]=NC(K.pieOuterStrokeWidth);ee??(ee=2);const ie=b.textPosition,oe=Math.min(P,A)/2-y,pe=lD().innerRadius(0).outerRadius(oe),be=lD().innerRadius(oe*ie).outerRadius(oe*ie);F.append("circle").attr("cx",0).attr("cy",0).attr("r",oe+ee/2).attr("class","pieOuterCircle");const ae=knn(j),ne=[K.pie1,K.pie2,K.pie3,K.pie4,K.pie5,K.pie6,K.pie7,K.pie8,K.pie9,K.pie10,K.pie11,K.pie12],se=_F(ne);F.selectAll("mySlices").data(ae).enter().append("path").attr("d",pe).attr("fill",xe=>se(xe.data.label)).attr("class","pieCircle");let de=0;Object.keys(j).forEach(xe=>{de+=j[xe]}),F.selectAll("mySlices").data(ae).enter().append("text").text(xe=>(xe.data.value/de*100).toFixed(0)+"%").attr("transform",xe=>"translate("+be.centroid(xe)+")").style("text-anchor","middle").attr("class","slice"),F.append("text").text(p.getDiagramTitle()).attr("x",0).attr("y",-(A-50)/2).attr("class","pieTitleText");const X=F.selectAll(".legend").data(se.domain()).enter().append("g").attr("class","legend").attr("transform",(xe,U)=>{const Fe=T+_,Pe=Fe*se.domain().length/2,je=12*T,Ie=U*Fe-Pe;return"translate("+je+","+Ie+")"});X.append("rect").attr("width",T).attr("height",T).style("fill",se).style("stroke",se),X.data(ae).append("text").attr("x",T+_).attr("y",T-_).text(xe=>{const{label:U,value:Fe}=xe.data;return p.getShowData()?`${U} [${Fe}]`:U});const ge=Math.max(...X.selectAll("text").nodes().map(xe=>(xe==null?void 0:xe.getBoundingClientRect().width)??0)),W=P+y+T+_+ge;R.attr("viewBox",`0 0 ${W} ${A}`),Ng(R,A,W,b.useMaxWidth)}},styles:xnn}},Symbol.toStringTag,{value:"Module"}));var fve=function(){var i=function(_t,Et,Gt,ln){for(Gt=Gt||{},ln=_t.length;ln--;Gt[_t[ln]]=Et);return Gt},s=[1,3],u=[1,4],d=[1,5],p=[1,6],v=[1,7],b=[1,5,13,15,17,19,20,25,27,28,29,30,31,32,33,34,37,38,40,41,42,43,44,45,46,47,48,49,50],y=[1,5,6,13,15,17,19,20,25,27,28,29,30,31,32,33,34,37,38,40,41,42,43,44,45,46,47,48,49,50],T=[32,33,34],_=[2,7],A=[1,13],P=[1,17],R=[1,18],F=[1,19],j=[1,20],K=[1,21],ee=[1,22],ie=[1,23],oe=[1,24],pe=[1,25],be=[1,26],ae=[1,27],ne=[1,30],se=[1,31],de=[1,32],X=[1,33],ge=[1,34],W=[1,35],xe=[1,36],U=[1,37],Fe=[1,38],Pe=[1,39],je=[1,40],Ie=[1,41],Se=[1,42],Ce=[1,57],ke=[1,58],Ke=[5,22,26,32,33,34,40,41,42,43,44,45,46,47,48,49,50,51],Ft={trace:function(){},yy:{},symbols_:{error:2,start:3,eol:4,SPACE:5,QUADRANT:6,document:7,line:8,statement:9,axisDetails:10,quadrantDetails:11,points:12,title:13,title_value:14,acc_title:15,acc_title_value:16,acc_descr:17,acc_descr_value:18,acc_descr_multiline_value:19,section:20,text:21,point_start:22,point_x:23,point_y:24,"X-AXIS":25,"AXIS-TEXT-DELIMITER":26,"Y-AXIS":27,QUADRANT_1:28,QUADRANT_2:29,QUADRANT_3:30,QUADRANT_4:31,NEWLINE:32,SEMI:33,EOF:34,alphaNumToken:35,textNoTagsToken:36,STR:37,MD_STR:38,alphaNum:39,PUNCTUATION:40,AMP:41,NUM:42,ALPHA:43,COMMA:44,PLUS:45,EQUALS:46,MULT:47,DOT:48,BRKT:49,UNDERSCORE:50,MINUS:51,$accept:0,$end:1},terminals_:{2:"error",5:"SPACE",6:"QUADRANT",13:"title",14:"title_value",15:"acc_title",16:"acc_title_value",17:"acc_descr",18:"acc_descr_value",19:"acc_descr_multiline_value",20:"section",22:"point_start",23:"point_x",24:"point_y",25:"X-AXIS",26:"AXIS-TEXT-DELIMITER",27:"Y-AXIS",28:"QUADRANT_1",29:"QUADRANT_2",30:"QUADRANT_3",31:"QUADRANT_4",32:"NEWLINE",33:"SEMI",34:"EOF",37:"STR",38:"MD_STR",40:"PUNCTUATION",41:"AMP",42:"NUM",43:"ALPHA",44:"COMMA",45:"PLUS",46:"EQUALS",47:"MULT",48:"DOT",49:"BRKT",50:"UNDERSCORE",51:"MINUS"},productions_:[0,[3,2],[3,2],[3,2],[7,0],[7,2],[8,2],[9,0],[9,2],[9,1],[9,1],[9,1],[9,2],[9,2],[9,2],[9,1],[9,1],[12,4],[10,4],[10,3],[10,2],[10,4],[10,3],[10,2],[11,2],[11,2],[11,2],[11,2],[4,1],[4,1],[4,1],[21,1],[21,2],[21,1],[21,1],[39,1],[39,2],[35,1],[35,1],[35,1],[35,1],[35,1],[35,1],[35,1],[35,1],[35,1],[35,1],[35,1],[36,1],[36,1],[36,1]],performAction:function(Et,Gt,ln,xt,Pt,Qe,Dt){var kt=Qe.length-1;switch(Pt){case 12:this.$=Qe[kt].trim(),xt.setDiagramTitle(this.$);break;case 13:this.$=Qe[kt].trim(),xt.setAccTitle(this.$);break;case 14:case 15:this.$=Qe[kt].trim(),xt.setAccDescription(this.$);break;case 16:xt.addSection(Qe[kt].substr(8)),this.$=Qe[kt].substr(8);break;case 17:xt.addPoint(Qe[kt-3],Qe[kt-1],Qe[kt]);break;case 18:xt.setXAxisLeftText(Qe[kt-2]),xt.setXAxisRightText(Qe[kt]);break;case 19:Qe[kt-1].text+=" ⟶ ",xt.setXAxisLeftText(Qe[kt-1]);break;case 20:xt.setXAxisLeftText(Qe[kt]);break;case 21:xt.setYAxisBottomText(Qe[kt-2]),xt.setYAxisTopText(Qe[kt]);break;case 22:Qe[kt-1].text+=" ⟶ ",xt.setYAxisBottomText(Qe[kt-1]);break;case 23:xt.setYAxisBottomText(Qe[kt]);break;case 24:xt.setQuadrant1Text(Qe[kt]);break;case 25:xt.setQuadrant2Text(Qe[kt]);break;case 26:xt.setQuadrant3Text(Qe[kt]);break;case 27:xt.setQuadrant4Text(Qe[kt]);break;case 31:this.$={text:Qe[kt],type:"text"};break;case 32:this.$={text:Qe[kt-1].text+""+Qe[kt],type:Qe[kt-1].type};break;case 33:this.$={text:Qe[kt],type:"text"};break;case 34:this.$={text:Qe[kt],type:"markdown"};break;case 35:this.$=Qe[kt];break;case 36:this.$=Qe[kt-1]+""+Qe[kt];break}},table:[{3:1,4:2,5:s,6:u,32:d,33:p,34:v},{1:[3]},{3:8,4:2,5:s,6:u,32:d,33:p,34:v},{3:9,4:2,5:s,6:u,32:d,33:p,34:v},i(b,[2,4],{7:10}),i(y,[2,28]),i(y,[2,29]),i(y,[2,30]),{1:[2,1]},{1:[2,2]},i(T,_,{8:11,9:12,10:14,11:15,12:16,21:28,35:29,1:[2,3],5:A,13:P,15:R,17:F,19:j,20:K,25:ee,27:ie,28:oe,29:pe,30:be,31:ae,37:ne,38:se,40:de,41:X,42:ge,43:W,44:xe,45:U,46:Fe,47:Pe,48:je,49:Ie,50:Se}),i(b,[2,5]),{4:43,32:d,33:p,34:v},i(T,_,{10:14,11:15,12:16,21:28,35:29,9:44,5:A,13:P,15:R,17:F,19:j,20:K,25:ee,27:ie,28:oe,29:pe,30:be,31:ae,37:ne,38:se,40:de,41:X,42:ge,43:W,44:xe,45:U,46:Fe,47:Pe,48:je,49:Ie,50:Se}),i(T,[2,9]),i(T,[2,10]),i(T,[2,11]),{14:[1,45]},{16:[1,46]},{18:[1,47]},i(T,[2,15]),i(T,[2,16]),{21:48,35:29,37:ne,38:se,40:de,41:X,42:ge,43:W,44:xe,45:U,46:Fe,47:Pe,48:je,49:Ie,50:Se},{21:49,35:29,37:ne,38:se,40:de,41:X,42:ge,43:W,44:xe,45:U,46:Fe,47:Pe,48:je,49:Ie,50:Se},{21:50,35:29,37:ne,38:se,40:de,41:X,42:ge,43:W,44:xe,45:U,46:Fe,47:Pe,48:je,49:Ie,50:Se},{21:51,35:29,37:ne,38:se,40:de,41:X,42:ge,43:W,44:xe,45:U,46:Fe,47:Pe,48:je,49:Ie,50:Se},{21:52,35:29,37:ne,38:se,40:de,41:X,42:ge,43:W,44:xe,45:U,46:Fe,47:Pe,48:je,49:Ie,50:Se},{21:53,35:29,37:ne,38:se,40:de,41:X,42:ge,43:W,44:xe,45:U,46:Fe,47:Pe,48:je,49:Ie,50:Se},{5:Ce,22:[1,54],35:56,36:55,40:de,41:X,42:ge,43:W,44:xe,45:U,46:Fe,47:Pe,48:je,49:Ie,50:Se,51:ke},i(Ke,[2,31]),i(Ke,[2,33]),i(Ke,[2,34]),i(Ke,[2,37]),i(Ke,[2,38]),i(Ke,[2,39]),i(Ke,[2,40]),i(Ke,[2,41]),i(Ke,[2,42]),i(Ke,[2,43]),i(Ke,[2,44]),i(Ke,[2,45]),i(Ke,[2,46]),i(Ke,[2,47]),i(b,[2,6]),i(T,[2,8]),i(T,[2,12]),i(T,[2,13]),i(T,[2,14]),i(T,[2,20],{36:55,35:56,5:Ce,26:[1,59],40:de,41:X,42:ge,43:W,44:xe,45:U,46:Fe,47:Pe,48:je,49:Ie,50:Se,51:ke}),i(T,[2,23],{36:55,35:56,5:Ce,26:[1,60],40:de,41:X,42:ge,43:W,44:xe,45:U,46:Fe,47:Pe,48:je,49:Ie,50:Se,51:ke}),i(T,[2,24],{36:55,35:56,5:Ce,40:de,41:X,42:ge,43:W,44:xe,45:U,46:Fe,47:Pe,48:je,49:Ie,50:Se,51:ke}),i(T,[2,25],{36:55,35:56,5:Ce,40:de,41:X,42:ge,43:W,44:xe,45:U,46:Fe,47:Pe,48:je,49:Ie,50:Se,51:ke}),i(T,[2,26],{36:55,35:56,5:Ce,40:de,41:X,42:ge,43:W,44:xe,45:U,46:Fe,47:Pe,48:je,49:Ie,50:Se,51:ke}),i(T,[2,27],{36:55,35:56,5:Ce,40:de,41:X,42:ge,43:W,44:xe,45:U,46:Fe,47:Pe,48:je,49:Ie,50:Se,51:ke}),{23:[1,61]},i(Ke,[2,32]),i(Ke,[2,48]),i(Ke,[2,49]),i(Ke,[2,50]),i(T,[2,19],{35:29,21:62,37:ne,38:se,40:de,41:X,42:ge,43:W,44:xe,45:U,46:Fe,47:Pe,48:je,49:Ie,50:Se}),i(T,[2,22],{35:29,21:63,37:ne,38:se,40:de,41:X,42:ge,43:W,44:xe,45:U,46:Fe,47:Pe,48:je,49:Ie,50:Se}),{24:[1,64]},i(T,[2,18],{36:55,35:56,5:Ce,40:de,41:X,42:ge,43:W,44:xe,45:U,46:Fe,47:Pe,48:je,49:Ie,50:Se,51:ke}),i(T,[2,21],{36:55,35:56,5:Ce,40:de,41:X,42:ge,43:W,44:xe,45:U,46:Fe,47:Pe,48:je,49:Ie,50:Se,51:ke}),i(T,[2,17])],defaultActions:{8:[2,1],9:[2,2]},parseError:function(Et,Gt){if(Gt.recoverable)this.trace(Et);else{var ln=new Error(Et);throw ln.hash=Gt,ln}},parse:function(Et){var Gt=this,ln=[0],xt=[],Pt=[null],Qe=[],Dt=this.table,kt="",On=0,ht=0,zr=2,yt=1,ji=Qe.slice.call(arguments,1),xi=Object.create(this.lexer),Ma={yy:{}};for(var zs in this.yy)Object.prototype.hasOwnProperty.call(this.yy,zs)&&(Ma.yy[zs]=this.yy[zs]);xi.setInput(Et,Ma.yy),Ma.yy.lexer=xi,Ma.yy.parser=this,typeof xi.yylloc>"u"&&(xi.yylloc={});var ao=xi.yylloc;Qe.push(ao);var Tr=xi.options&&xi.options.ranges;typeof Ma.yy.parseError=="function"?this.parseError=Ma.yy.parseError:this.parseError=Object.getPrototypeOf(this).parseError;function Fn(){var Pa;return Pa=xt.pop()||xi.lex()||yt,typeof Pa!="number"&&(Pa instanceof Array&&(xt=Pa,Pa=xt.pop()),Pa=Gt.symbols_[Pa]||Pa),Pa}for(var qn,Un,At,wt,on={},fn,An,oo,jo;;){if(Un=ln[ln.length-1],this.defaultActions[Un]?At=this.defaultActions[Un]:((qn===null||typeof qn>"u")&&(qn=Fn()),At=Dt[Un]&&Dt[Un][qn]),typeof At>"u"||!At.length||!At[0]){var $o="";jo=[];for(fn in Dt[Un])this.terminals_[fn]&&fn>zr&&jo.push("'"+this.terminals_[fn]+"'");xi.showPosition?$o="Parse error on line "+(On+1)+`: +`+xi.showPosition()+` +Expecting `+jo.join(", ")+", got '"+(this.terminals_[qn]||qn)+"'":$o="Parse error on line "+(On+1)+": Unexpected "+(qn==yt?"end of input":"'"+(this.terminals_[qn]||qn)+"'"),this.parseError($o,{text:xi.match,token:this.terminals_[qn]||qn,line:xi.yylineno,loc:ao,expected:jo})}if(At[0]instanceof Array&&At.length>1)throw new Error("Parse Error: multiple actions possible at state: "+Un+", token: "+qn);switch(At[0]){case 1:ln.push(qn),Pt.push(xi.yytext),Qe.push(xi.yylloc),ln.push(At[1]),qn=null,ht=xi.yyleng,kt=xi.yytext,On=xi.yylineno,ao=xi.yylloc;break;case 2:if(An=this.productions_[At[1]][1],on.$=Pt[Pt.length-An],on._$={first_line:Qe[Qe.length-(An||1)].first_line,last_line:Qe[Qe.length-1].last_line,first_column:Qe[Qe.length-(An||1)].first_column,last_column:Qe[Qe.length-1].last_column},Tr&&(on._$.range=[Qe[Qe.length-(An||1)].range[0],Qe[Qe.length-1].range[1]]),wt=this.performAction.apply(on,[kt,ht,On,Ma.yy,At[1],Pt,Qe].concat(ji)),typeof wt<"u")return wt;An&&(ln=ln.slice(0,-1*An*2),Pt=Pt.slice(0,-1*An),Qe=Qe.slice(0,-1*An)),ln.push(this.productions_[At[1]][0]),Pt.push(on.$),Qe.push(on._$),oo=Dt[ln[ln.length-2]][ln[ln.length-1]],ln.push(oo);break;case 3:return!0}}return!0}},Ne=function(){var _t={EOF:1,parseError:function(Gt,ln){if(this.yy.parser)this.yy.parser.parseError(Gt,ln);else throw new Error(Gt)},setInput:function(Et,Gt){return this.yy=Gt||this.yy||{},this._input=Et,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},input:function(){var Et=this._input[0];this.yytext+=Et,this.yyleng++,this.offset++,this.match+=Et,this.matched+=Et;var Gt=Et.match(/(?:\r\n?|\n).*/g);return Gt?(this.yylineno++,this.yylloc.last_line++):this.yylloc.last_column++,this.options.ranges&&this.yylloc.range[1]++,this._input=this._input.slice(1),Et},unput:function(Et){var Gt=Et.length,ln=Et.split(/(?:\r\n?|\n)/g);this._input=Et+this._input,this.yytext=this.yytext.substr(0,this.yytext.length-Gt),this.offset-=Gt;var xt=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),ln.length-1&&(this.yylineno-=ln.length-1);var Pt=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:ln?(ln.length===xt.length?this.yylloc.first_column:0)+xt[xt.length-ln.length].length-ln[0].length:this.yylloc.first_column-Gt},this.options.ranges&&(this.yylloc.range=[Pt[0],Pt[0]+this.yyleng-Gt]),this.yyleng=this.yytext.length,this},more:function(){return this._more=!0,this},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},less:function(Et){this.unput(this.match.slice(Et))},pastInput:function(){var Et=this.matched.substr(0,this.matched.length-this.match.length);return(Et.length>20?"...":"")+Et.substr(-20).replace(/\n/g,"")},upcomingInput:function(){var Et=this.match;return Et.length<20&&(Et+=this._input.substr(0,20-Et.length)),(Et.substr(0,20)+(Et.length>20?"...":"")).replace(/\n/g,"")},showPosition:function(){var Et=this.pastInput(),Gt=new Array(Et.length+1).join("-");return Et+this.upcomingInput()+` +`+Gt+"^"},test_match:function(Et,Gt){var ln,xt,Pt;if(this.options.backtrack_lexer&&(Pt={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&&(Pt.yylloc.range=this.yylloc.range.slice(0))),xt=Et[0].match(/(?:\r\n?|\n).*/g),xt&&(this.yylineno+=xt.length),this.yylloc={first_line:this.yylloc.last_line,last_line:this.yylineno+1,first_column:this.yylloc.last_column,last_column:xt?xt[xt.length-1].length-xt[xt.length-1].match(/\r?\n?/)[0].length:this.yylloc.last_column+Et[0].length},this.yytext+=Et[0],this.match+=Et[0],this.matches=Et,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(Et[0].length),this.matched+=Et[0],ln=this.performAction.call(this,this.yy,this,Gt,this.conditionStack[this.conditionStack.length-1]),this.done&&this._input&&(this.done=!1),ln)return ln;if(this._backtrack){for(var Qe in Pt)this[Qe]=Pt[Qe];return!1}return!1},next:function(){if(this.done)return this.EOF;this._input||(this.done=!0);var Et,Gt,ln,xt;this._more||(this.yytext="",this.match="");for(var Pt=this._currentRules(),Qe=0;QeGt[0].length)){if(Gt=ln,xt=Qe,this.options.backtrack_lexer){if(Et=this.test_match(ln,Pt[Qe]),Et!==!1)return Et;if(this._backtrack){Gt=!1;continue}else return!1}else if(!this.options.flex)break}return Gt?(Et=this.test_match(Gt,Pt[xt]),Et!==!1?Et:!1):this._input===""?this.EOF:this.parseError("Lexical error on line "+(this.yylineno+1)+`. Unrecognized text. +`+this.showPosition(),{text:"",token:null,line:this.yylineno})},lex:function(){var Gt=this.next();return Gt||this.lex()},begin:function(Gt){this.conditionStack.push(Gt)},popState:function(){var Gt=this.conditionStack.length-1;return Gt>0?this.conditionStack.pop():this.conditionStack[0]},_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},topState:function(Gt){return Gt=this.conditionStack.length-1-Math.abs(Gt||0),Gt>=0?this.conditionStack[Gt]:"INITIAL"},pushState:function(Gt){this.begin(Gt)},stateStackSize:function(){return this.conditionStack.length},options:{"case-insensitive":!0},performAction:function(Gt,ln,xt,Pt){switch(xt){case 0:break;case 1:break;case 2:return 32;case 3:break;case 4:return this.begin("title"),13;case 5:return this.popState(),"title_value";case 6:return this.begin("acc_title"),15;case 7:return this.popState(),"acc_title_value";case 8:return this.begin("acc_descr"),17;case 9:return this.popState(),"acc_descr_value";case 10:this.begin("acc_descr_multiline");break;case 11:this.popState();break;case 12:return"acc_descr_multiline_value";case 13:return 25;case 14:return 27;case 15:return 26;case 16:return 28;case 17:return 29;case 18:return 30;case 19:return 31;case 20:this.begin("md_string");break;case 21:return"MD_STR";case 22:this.popState();break;case 23:this.begin("string");break;case 24:this.popState();break;case 25:return"STR";case 26:return this.begin("point_start"),22;case 27:return this.begin("point_x"),23;case 28:this.popState();break;case 29:this.popState(),this.begin("point_y");break;case 30:return this.popState(),24;case 31:return 6;case 32:return 43;case 33:return"COLON";case 34:return 45;case 35:return 44;case 36:return 46;case 37:return 46;case 38:return 47;case 39:return 49;case 40:return 50;case 41:return 48;case 42:return 41;case 43:return 51;case 44:return 42;case 45:return 5;case 46:return 33;case 47:return 40;case 48:return 34}},rules:[/^(?:%%(?!\{)[^\n]*)/i,/^(?:[^\}]%%[^\n]*)/i,/^(?:[\n\r]+)/i,/^(?:%%[^\n]*)/i,/^(?:title\b)/i,/^(?:(?!\n||)*[^\n]*)/i,/^(?:accTitle\s*:\s*)/i,/^(?:(?!\n||)*[^\n]*)/i,/^(?:accDescr\s*:\s*)/i,/^(?:(?!\n||)*[^\n]*)/i,/^(?:accDescr\s*\{\s*)/i,/^(?:[\}])/i,/^(?:[^\}]*)/i,/^(?: *x-axis *)/i,/^(?: *y-axis *)/i,/^(?: *--+> *)/i,/^(?: *quadrant-1 *)/i,/^(?: *quadrant-2 *)/i,/^(?: *quadrant-3 *)/i,/^(?: *quadrant-4 *)/i,/^(?:["][`])/i,/^(?:[^`"]+)/i,/^(?:[`]["])/i,/^(?:["])/i,/^(?:["])/i,/^(?:[^"]*)/i,/^(?:\s*:\s*\[\s*)/i,/^(?:(1)|(0(.\d+)?))/i,/^(?:\s*\] *)/i,/^(?:\s*,\s*)/i,/^(?:(1)|(0(.\d+)?))/i,/^(?: *quadrantChart *)/i,/^(?:[A-Za-z]+)/i,/^(?::)/i,/^(?:\+)/i,/^(?:,)/i,/^(?:=)/i,/^(?:=)/i,/^(?:\*)/i,/^(?:#)/i,/^(?:[\_])/i,/^(?:\.)/i,/^(?:&)/i,/^(?:-)/i,/^(?:[0-9]+)/i,/^(?:\s)/i,/^(?:;)/i,/^(?:[!"#$%&'*+,-.`?\\_/])/i,/^(?:$)/i],conditions:{point_y:{rules:[30],inclusive:!1},point_x:{rules:[29],inclusive:!1},point_start:{rules:[27,28],inclusive:!1},acc_descr_multiline:{rules:[11,12],inclusive:!1},acc_descr:{rules:[9],inclusive:!1},acc_title:{rules:[7],inclusive:!1},title:{rules:[5],inclusive:!1},md_string:{rules:[21,22],inclusive:!1},string:{rules:[24,25],inclusive:!1},INITIAL:{rules:[0,1,2,3,4,6,8,10,13,14,15,16,17,18,19,20,23,26,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48],inclusive:!0}}};return _t}();Ft.lexer=Ne;function gn(){this.yy={}}return gn.prototype=Ft,Ft.Parser=gn,new gn}();fve.parser=fve;const Tnn=fve,Pp=f2e();class Cnn{constructor(){this.config=this.getDefaultConfig(),this.themeConfig=this.getDefaultThemeConfig(),this.data=this.getDefaultData()}getDefaultData(){return{titleText:"",quadrant1Text:"",quadrant2Text:"",quadrant3Text:"",quadrant4Text:"",xAxisLeftText:"",xAxisRightText:"",yAxisBottomText:"",yAxisTopText:"",points:[]}}getDefaultConfig(){var s,u,d,p,v,b,y,T,_,A,P,R,F,j,K,ee,ie,oe;return{showXAxis:!0,showYAxis:!0,showTitle:!0,chartHeight:((s=sh.quadrantChart)==null?void 0:s.chartWidth)||500,chartWidth:((u=sh.quadrantChart)==null?void 0:u.chartHeight)||500,titlePadding:((d=sh.quadrantChart)==null?void 0:d.titlePadding)||10,titleFontSize:((p=sh.quadrantChart)==null?void 0:p.titleFontSize)||20,quadrantPadding:((v=sh.quadrantChart)==null?void 0:v.quadrantPadding)||5,xAxisLabelPadding:((b=sh.quadrantChart)==null?void 0:b.xAxisLabelPadding)||5,yAxisLabelPadding:((y=sh.quadrantChart)==null?void 0:y.yAxisLabelPadding)||5,xAxisLabelFontSize:((T=sh.quadrantChart)==null?void 0:T.xAxisLabelFontSize)||16,yAxisLabelFontSize:((_=sh.quadrantChart)==null?void 0:_.yAxisLabelFontSize)||16,quadrantLabelFontSize:((A=sh.quadrantChart)==null?void 0:A.quadrantLabelFontSize)||16,quadrantTextTopPadding:((P=sh.quadrantChart)==null?void 0:P.quadrantTextTopPadding)||5,pointTextPadding:((R=sh.quadrantChart)==null?void 0:R.pointTextPadding)||5,pointLabelFontSize:((F=sh.quadrantChart)==null?void 0:F.pointLabelFontSize)||12,pointRadius:((j=sh.quadrantChart)==null?void 0:j.pointRadius)||5,xAxisPosition:((K=sh.quadrantChart)==null?void 0:K.xAxisPosition)||"top",yAxisPosition:((ee=sh.quadrantChart)==null?void 0:ee.yAxisPosition)||"left",quadrantInternalBorderStrokeWidth:((ie=sh.quadrantChart)==null?void 0:ie.quadrantInternalBorderStrokeWidth)||1,quadrantExternalBorderStrokeWidth:((oe=sh.quadrantChart)==null?void 0:oe.quadrantExternalBorderStrokeWidth)||2}}getDefaultThemeConfig(){return{quadrant1Fill:Pp.quadrant1Fill,quadrant2Fill:Pp.quadrant2Fill,quadrant3Fill:Pp.quadrant3Fill,quadrant4Fill:Pp.quadrant4Fill,quadrant1TextFill:Pp.quadrant1TextFill,quadrant2TextFill:Pp.quadrant2TextFill,quadrant3TextFill:Pp.quadrant3TextFill,quadrant4TextFill:Pp.quadrant4TextFill,quadrantPointFill:Pp.quadrantPointFill,quadrantPointTextFill:Pp.quadrantPointTextFill,quadrantXAxisTextFill:Pp.quadrantXAxisTextFill,quadrantYAxisTextFill:Pp.quadrantYAxisTextFill,quadrantTitleFill:Pp.quadrantTitleFill,quadrantInternalBorderStrokeFill:Pp.quadrantInternalBorderStrokeFill,quadrantExternalBorderStrokeFill:Pp.quadrantExternalBorderStrokeFill}}clear(){this.config=this.getDefaultConfig(),this.themeConfig=this.getDefaultThemeConfig(),this.data=this.getDefaultData(),Xe.info("clear called")}setData(s){this.data={...this.data,...s}}addPoints(s){this.data.points=[...s,...this.data.points]}setConfig(s){Xe.trace("setConfig called with: ",s),this.config={...this.config,...s}}setThemeConfig(s){Xe.trace("setThemeConfig called with: ",s),this.themeConfig={...this.themeConfig,...s}}calculateSpace(s,u,d,p){const v=this.config.xAxisLabelPadding*2+this.config.xAxisLabelFontSize,b={top:s==="top"&&u?v:0,bottom:s==="bottom"&&u?v:0},y=this.config.yAxisLabelPadding*2+this.config.yAxisLabelFontSize,T={left:this.config.yAxisPosition==="left"&&d?y:0,right:this.config.yAxisPosition==="right"&&d?y:0},_=this.config.titleFontSize+this.config.titlePadding*2,A={top:p?_:0},P=this.config.quadrantPadding+T.left,R=this.config.quadrantPadding+b.top+A.top,F=this.config.chartWidth-this.config.quadrantPadding*2-T.left-T.right,j=this.config.chartHeight-this.config.quadrantPadding*2-b.top-b.bottom-A.top,K=F/2,ee=j/2;return{xAxisSpace:b,yAxisSpace:T,titleSpace:A,quadrantSpace:{quadrantLeft:P,quadrantTop:R,quadrantWidth:F,quadrantHalfWidth:K,quadrantHeight:j,quadrantHalfHeight:ee}}}getAxisLabels(s,u,d,p){const{quadrantSpace:v,titleSpace:b}=p,{quadrantHalfHeight:y,quadrantHeight:T,quadrantLeft:_,quadrantHalfWidth:A,quadrantTop:P,quadrantWidth:R}=v,F=!!this.data.xAxisRightText,j=!!this.data.yAxisTopText,K=[];return this.data.xAxisLeftText&&u&&K.push({text:this.data.xAxisLeftText,fill:this.themeConfig.quadrantXAxisTextFill,x:_+(F?A/2:0),y:s==="top"?this.config.xAxisLabelPadding+b.top:this.config.xAxisLabelPadding+P+T+this.config.quadrantPadding,fontSize:this.config.xAxisLabelFontSize,verticalPos:F?"center":"left",horizontalPos:"top",rotation:0}),this.data.xAxisRightText&&u&&K.push({text:this.data.xAxisRightText,fill:this.themeConfig.quadrantXAxisTextFill,x:_+A+(F?A/2:0),y:s==="top"?this.config.xAxisLabelPadding+b.top:this.config.xAxisLabelPadding+P+T+this.config.quadrantPadding,fontSize:this.config.xAxisLabelFontSize,verticalPos:F?"center":"left",horizontalPos:"top",rotation:0}),this.data.yAxisBottomText&&d&&K.push({text:this.data.yAxisBottomText,fill:this.themeConfig.quadrantYAxisTextFill,x:this.config.yAxisPosition==="left"?this.config.yAxisLabelPadding:this.config.yAxisLabelPadding+_+R+this.config.quadrantPadding,y:P+T-(j?y/2:0),fontSize:this.config.yAxisLabelFontSize,verticalPos:j?"center":"left",horizontalPos:"top",rotation:-90}),this.data.yAxisTopText&&d&&K.push({text:this.data.yAxisTopText,fill:this.themeConfig.quadrantYAxisTextFill,x:this.config.yAxisPosition==="left"?this.config.yAxisLabelPadding:this.config.yAxisLabelPadding+_+R+this.config.quadrantPadding,y:P+y-(j?y/2:0),fontSize:this.config.yAxisLabelFontSize,verticalPos:j?"center":"left",horizontalPos:"top",rotation:-90}),K}getQuadrants(s){const{quadrantSpace:u}=s,{quadrantHalfHeight:d,quadrantLeft:p,quadrantHalfWidth:v,quadrantTop:b}=u,y=[{text:{text:this.data.quadrant1Text,fill:this.themeConfig.quadrant1TextFill,x:0,y:0,fontSize:this.config.quadrantLabelFontSize,verticalPos:"center",horizontalPos:"middle",rotation:0},x:p+v,y:b,width:v,height:d,fill:this.themeConfig.quadrant1Fill},{text:{text:this.data.quadrant2Text,fill:this.themeConfig.quadrant2TextFill,x:0,y:0,fontSize:this.config.quadrantLabelFontSize,verticalPos:"center",horizontalPos:"middle",rotation:0},x:p,y:b,width:v,height:d,fill:this.themeConfig.quadrant2Fill},{text:{text:this.data.quadrant3Text,fill:this.themeConfig.quadrant3TextFill,x:0,y:0,fontSize:this.config.quadrantLabelFontSize,verticalPos:"center",horizontalPos:"middle",rotation:0},x:p,y:b+d,width:v,height:d,fill:this.themeConfig.quadrant3Fill},{text:{text:this.data.quadrant4Text,fill:this.themeConfig.quadrant4TextFill,x:0,y:0,fontSize:this.config.quadrantLabelFontSize,verticalPos:"center",horizontalPos:"middle",rotation:0},x:p+v,y:b+d,width:v,height:d,fill:this.themeConfig.quadrant4Fill}];for(const T of y)T.text.x=T.x+T.width/2,this.data.points.length===0?(T.text.y=T.y+T.height/2,T.text.horizontalPos="middle"):(T.text.y=T.y+this.config.quadrantTextTopPadding,T.text.horizontalPos="top");return y}getQuadrantPoints(s){const{quadrantSpace:u}=s,{quadrantHeight:d,quadrantLeft:p,quadrantTop:v,quadrantWidth:b}=u,y=sD().domain([0,1]).range([p,b+p]),T=sD().domain([0,1]).range([d+v,v]);return this.data.points.map(A=>({x:y(A.x),y:T(A.y),fill:this.themeConfig.quadrantPointFill,radius:this.config.pointRadius,text:{text:A.text,fill:this.themeConfig.quadrantPointTextFill,x:y(A.x),y:T(A.y)+this.config.pointTextPadding,verticalPos:"center",horizontalPos:"top",fontSize:this.config.pointLabelFontSize,rotation:0}}))}getBorders(s){const u=this.config.quadrantExternalBorderStrokeWidth/2,{quadrantSpace:d}=s,{quadrantHalfHeight:p,quadrantHeight:v,quadrantLeft:b,quadrantHalfWidth:y,quadrantTop:T,quadrantWidth:_}=d;return[{strokeFill:this.themeConfig.quadrantExternalBorderStrokeFill,strokeWidth:this.config.quadrantExternalBorderStrokeWidth,x1:b-u,y1:T,x2:b+_+u,y2:T},{strokeFill:this.themeConfig.quadrantExternalBorderStrokeFill,strokeWidth:this.config.quadrantExternalBorderStrokeWidth,x1:b+_,y1:T+u,x2:b+_,y2:T+v-u},{strokeFill:this.themeConfig.quadrantExternalBorderStrokeFill,strokeWidth:this.config.quadrantExternalBorderStrokeWidth,x1:b-u,y1:T+v,x2:b+_+u,y2:T+v},{strokeFill:this.themeConfig.quadrantExternalBorderStrokeFill,strokeWidth:this.config.quadrantExternalBorderStrokeWidth,x1:b,y1:T+u,x2:b,y2:T+v-u},{strokeFill:this.themeConfig.quadrantInternalBorderStrokeFill,strokeWidth:this.config.quadrantInternalBorderStrokeWidth,x1:b+y,y1:T+u,x2:b+y,y2:T+v-u},{strokeFill:this.themeConfig.quadrantInternalBorderStrokeFill,strokeWidth:this.config.quadrantInternalBorderStrokeWidth,x1:b+u,y1:T+p,x2:b+_-u,y2:T+p}]}getTitle(s){if(s)return{text:this.data.titleText,fill:this.themeConfig.quadrantTitleFill,fontSize:this.config.titleFontSize,horizontalPos:"top",verticalPos:"center",rotation:0,y:this.config.titlePadding,x:this.config.chartWidth/2}}build(){const s=this.config.showXAxis&&!!(this.data.xAxisLeftText||this.data.xAxisRightText),u=this.config.showYAxis&&!!(this.data.yAxisTopText||this.data.yAxisBottomText),d=this.config.showTitle&&!!this.data.titleText,p=this.data.points.length>0?"bottom":this.config.xAxisPosition,v=this.calculateSpace(p,s,u,d);return{points:this.getQuadrantPoints(v),quadrants:this.getQuadrants(v),axisLabels:this.getAxisLabels(p,s,u,v),borderLines:this.getBorders(v),title:this.getTitle(d)}}}const Snn=qt();function U7(i){return Yf(i.trim(),Snn)}const Rg=new Cnn;function _nn(i){Rg.setData({quadrant1Text:U7(i.text)})}function Ann(i){Rg.setData({quadrant2Text:U7(i.text)})}function Lnn(i){Rg.setData({quadrant3Text:U7(i.text)})}function Mnn(i){Rg.setData({quadrant4Text:U7(i.text)})}function Dnn(i){Rg.setData({xAxisLeftText:U7(i.text)})}function Inn(i){Rg.setData({xAxisRightText:U7(i.text)})}function Onn(i){Rg.setData({yAxisTopText:U7(i.text)})}function Nnn(i){Rg.setData({yAxisBottomText:U7(i.text)})}function Pnn(i,s,u){Rg.addPoints([{x:s,y:u,text:U7(i.text)}])}function Bnn(i){Rg.setConfig({chartWidth:i})}function Fnn(i){Rg.setConfig({chartHeight:i})}function Rnn(){const i=qt(),{themeVariables:s,quadrantChart:u}=i;return u&&Rg.setConfig(u),Rg.setThemeConfig({quadrant1Fill:s.quadrant1Fill,quadrant2Fill:s.quadrant2Fill,quadrant3Fill:s.quadrant3Fill,quadrant4Fill:s.quadrant4Fill,quadrant1TextFill:s.quadrant1TextFill,quadrant2TextFill:s.quadrant2TextFill,quadrant3TextFill:s.quadrant3TextFill,quadrant4TextFill:s.quadrant4TextFill,quadrantPointFill:s.quadrantPointFill,quadrantPointTextFill:s.quadrantPointTextFill,quadrantXAxisTextFill:s.quadrantXAxisTextFill,quadrantYAxisTextFill:s.quadrantYAxisTextFill,quadrantExternalBorderStrokeFill:s.quadrantExternalBorderStrokeFill,quadrantInternalBorderStrokeFill:s.quadrantInternalBorderStrokeFill,quadrantTitleFill:s.quadrantTitleFill}),Rg.setData({titleText:Ap()}),Rg.build()}const jnn=Object.freeze(Object.defineProperty({__proto__:null,diagram:{parser:Tnn,db:{setWidth:Bnn,setHeight:Fnn,setQuadrant1Text:_nn,setQuadrant2Text:Ann,setQuadrant3Text:Lnn,setQuadrant4Text:Mnn,setXAxisLeftText:Dnn,setXAxisRightText:Inn,setYAxisTopText:Onn,setYAxisBottomText:Nnn,addPoint:Pnn,getQuadrantData:Rnn,clear:function(){Rg.clear(),Pg()},setAccTitle:Bg,getAccTitle:Cp,setDiagramTitle:cm,getDiagramTitle:Ap,getAccDescription:_p,setAccDescription:Sp},renderer:{draw:(i,s,u,d)=>{var de,X,ge;function p(W){return W==="top"?"hanging":"middle"}function v(W){return W==="left"?"start":"middle"}function b(W){return`translate(${W.x}, ${W.y}) rotate(${W.rotation||0})`}const y=qt();Xe.debug(`Rendering quadrant chart +`+i);const T=y.securityLevel;let _;T==="sandbox"&&(_=Ir("#i"+s));const P=Ir(T==="sandbox"?_.nodes()[0].contentDocument.body:"body").select(`[id="${s}"]`),R=P.append("g").attr("class","main"),F=((de=y.quadrantChart)==null?void 0:de.chartWidth)||500,j=((X=y.quadrantChart)==null?void 0:X.chartHeight)||500;Ng(P,j,F,((ge=y.quadrantChart)==null?void 0:ge.useMaxWidth)||!0),P.attr("viewBox","0 0 "+F+" "+j),d.db.setHeight(j),d.db.setWidth(F);const K=d.db.getQuadrantData(),ee=R.append("g").attr("class","quadrants"),ie=R.append("g").attr("class","border"),oe=R.append("g").attr("class","data-points"),pe=R.append("g").attr("class","labels"),be=R.append("g").attr("class","title");K.title&&be.append("text").attr("x",0).attr("y",0).attr("fill",K.title.fill).attr("font-size",K.title.fontSize).attr("dominant-baseline",p(K.title.horizontalPos)).attr("text-anchor",v(K.title.verticalPos)).attr("transform",b(K.title)).text(K.title.text),K.borderLines&&ie.selectAll("line").data(K.borderLines).enter().append("line").attr("x1",W=>W.x1).attr("y1",W=>W.y1).attr("x2",W=>W.x2).attr("y2",W=>W.y2).style("stroke",W=>W.strokeFill).style("stroke-width",W=>W.strokeWidth);const ae=ee.selectAll("g.quadrant").data(K.quadrants).enter().append("g").attr("class","quadrant");ae.append("rect").attr("x",W=>W.x).attr("y",W=>W.y).attr("width",W=>W.width).attr("height",W=>W.height).attr("fill",W=>W.fill),ae.append("text").attr("x",0).attr("y",0).attr("fill",W=>W.text.fill).attr("font-size",W=>W.text.fontSize).attr("dominant-baseline",W=>p(W.text.horizontalPos)).attr("text-anchor",W=>v(W.text.verticalPos)).attr("transform",W=>b(W.text)).text(W=>W.text.text),pe.selectAll("g.label").data(K.axisLabels).enter().append("g").attr("class","label").append("text").attr("x",0).attr("y",0).text(W=>W.text).attr("fill",W=>W.fill).attr("font-size",W=>W.fontSize).attr("dominant-baseline",W=>p(W.horizontalPos)).attr("text-anchor",W=>v(W.verticalPos)).attr("transform",W=>b(W));const se=oe.selectAll("g.data-point").data(K.points).enter().append("g").attr("class","data-point");se.append("circle").attr("cx",W=>W.x).attr("cy",W=>W.y).attr("r",W=>W.radius).attr("fill",W=>W.fill),se.append("text").attr("x",0).attr("y",0).text(W=>W.text.text).attr("fill",W=>W.text.fill).attr("font-size",W=>W.text.fontSize).attr("dominant-baseline",W=>p(W.text.horizontalPos)).attr("text-anchor",W=>v(W.text.verticalPos)).attr("transform",W=>b(W.text))}},styles:()=>""}},Symbol.toStringTag,{value:"Module"}));var dve=function(){var i=function(Pe,je,Ie,Se){for(Ie=Ie||{},Se=Pe.length;Se--;Ie[Pe[Se]]=je);return Ie},s=[1,10,12,14,16,18,19,21,23],u=[2,6],d=[1,3],p=[1,5],v=[1,6],b=[1,7],y=[1,5,10,12,14,16,18,19,21,23,34,35,36],T=[1,25],_=[1,26],A=[1,28],P=[1,29],R=[1,30],F=[1,31],j=[1,32],K=[1,33],ee=[1,34],ie=[1,35],oe=[1,36],pe=[1,37],be=[1,43],ae=[1,42],ne=[1,47],se=[1,50],de=[1,10,12,14,16,18,19,21,23,34,35,36],X=[1,10,12,14,16,18,19,21,23,24,26,27,28,34,35,36],ge=[1,10,12,14,16,18,19,21,23,24,26,27,28,34,35,36,41,42,43,44,45,46,47,48,49,50],W=[1,64],xe={trace:function(){},yy:{},symbols_:{error:2,start:3,eol:4,XYCHART:5,chartConfig:6,document:7,CHART_ORIENTATION:8,statement:9,title:10,text:11,X_AXIS:12,parseXAxis:13,Y_AXIS:14,parseYAxis:15,LINE:16,plotData:17,BAR:18,acc_title:19,acc_title_value:20,acc_descr:21,acc_descr_value:22,acc_descr_multiline_value:23,SQUARE_BRACES_START:24,commaSeparatedNumbers:25,SQUARE_BRACES_END:26,NUMBER_WITH_DECIMAL:27,COMMA:28,xAxisData:29,bandData:30,ARROW_DELIMITER:31,commaSeparatedTexts:32,yAxisData:33,NEWLINE:34,SEMI:35,EOF:36,alphaNum:37,STR:38,MD_STR:39,alphaNumToken:40,AMP:41,NUM:42,ALPHA:43,PLUS:44,EQUALS:45,MULT:46,DOT:47,BRKT:48,MINUS:49,UNDERSCORE:50,$accept:0,$end:1},terminals_:{2:"error",5:"XYCHART",8:"CHART_ORIENTATION",10:"title",12:"X_AXIS",14:"Y_AXIS",16:"LINE",18:"BAR",19:"acc_title",20:"acc_title_value",21:"acc_descr",22:"acc_descr_value",23:"acc_descr_multiline_value",24:"SQUARE_BRACES_START",26:"SQUARE_BRACES_END",27:"NUMBER_WITH_DECIMAL",28:"COMMA",31:"ARROW_DELIMITER",34:"NEWLINE",35:"SEMI",36:"EOF",38:"STR",39:"MD_STR",41:"AMP",42:"NUM",43:"ALPHA",44:"PLUS",45:"EQUALS",46:"MULT",47:"DOT",48:"BRKT",49:"MINUS",50:"UNDERSCORE"},productions_:[0,[3,2],[3,3],[3,2],[3,1],[6,1],[7,0],[7,2],[9,2],[9,2],[9,2],[9,2],[9,2],[9,3],[9,2],[9,3],[9,2],[9,2],[9,1],[17,3],[25,3],[25,1],[13,1],[13,2],[13,1],[29,1],[29,3],[30,3],[32,3],[32,1],[15,1],[15,2],[15,1],[33,3],[4,1],[4,1],[4,1],[11,1],[11,1],[11,1],[37,1],[37,2],[40,1],[40,1],[40,1],[40,1],[40,1],[40,1],[40,1],[40,1],[40,1],[40,1]],performAction:function(je,Ie,Se,Ce,ke,Ke,Ft){var Ne=Ke.length-1;switch(ke){case 5:Ce.setOrientation(Ke[Ne]);break;case 9:Ce.setDiagramTitle(Ke[Ne].text.trim());break;case 12:Ce.setLineData({text:"",type:"text"},Ke[Ne]);break;case 13:Ce.setLineData(Ke[Ne-1],Ke[Ne]);break;case 14:Ce.setBarData({text:"",type:"text"},Ke[Ne]);break;case 15:Ce.setBarData(Ke[Ne-1],Ke[Ne]);break;case 16:this.$=Ke[Ne].trim(),Ce.setAccTitle(this.$);break;case 17:case 18:this.$=Ke[Ne].trim(),Ce.setAccDescription(this.$);break;case 19:this.$=Ke[Ne-1];break;case 20:this.$=[Number(Ke[Ne-2]),...Ke[Ne]];break;case 21:this.$=[Number(Ke[Ne])];break;case 22:Ce.setXAxisTitle(Ke[Ne]);break;case 23:Ce.setXAxisTitle(Ke[Ne-1]);break;case 24:Ce.setXAxisTitle({type:"text",text:""});break;case 25:Ce.setXAxisBand(Ke[Ne]);break;case 26:Ce.setXAxisRangeData(Number(Ke[Ne-2]),Number(Ke[Ne]));break;case 27:this.$=Ke[Ne-1];break;case 28:this.$=[Ke[Ne-2],...Ke[Ne]];break;case 29:this.$=[Ke[Ne]];break;case 30:Ce.setYAxisTitle(Ke[Ne]);break;case 31:Ce.setYAxisTitle(Ke[Ne-1]);break;case 32:Ce.setYAxisTitle({type:"text",text:""});break;case 33:Ce.setYAxisRangeData(Number(Ke[Ne-2]),Number(Ke[Ne]));break;case 37:this.$={text:Ke[Ne],type:"text"};break;case 38:this.$={text:Ke[Ne],type:"text"};break;case 39:this.$={text:Ke[Ne],type:"markdown"};break;case 40:this.$=Ke[Ne];break;case 41:this.$=Ke[Ne-1]+""+Ke[Ne];break}},table:[i(s,u,{3:1,4:2,7:4,5:d,34:p,35:v,36:b}),{1:[3]},i(s,u,{4:2,7:4,3:8,5:d,34:p,35:v,36:b}),i(s,u,{4:2,7:4,6:9,3:10,5:d,8:[1,11],34:p,35:v,36:b}),{1:[2,4],9:12,10:[1,13],12:[1,14],14:[1,15],16:[1,16],18:[1,17],19:[1,18],21:[1,19],23:[1,20]},i(y,[2,34]),i(y,[2,35]),i(y,[2,36]),{1:[2,1]},i(s,u,{4:2,7:4,3:21,5:d,34:p,35:v,36:b}),{1:[2,3]},i(y,[2,5]),i(s,[2,7],{4:22,34:p,35:v,36:b}),{11:23,37:24,38:T,39:_,40:27,41:A,42:P,43:R,44:F,45:j,46:K,47:ee,48:ie,49:oe,50:pe},{11:39,13:38,24:be,27:ae,29:40,30:41,37:24,38:T,39:_,40:27,41:A,42:P,43:R,44:F,45:j,46:K,47:ee,48:ie,49:oe,50:pe},{11:45,15:44,27:ne,33:46,37:24,38:T,39:_,40:27,41:A,42:P,43:R,44:F,45:j,46:K,47:ee,48:ie,49:oe,50:pe},{11:49,17:48,24:se,37:24,38:T,39:_,40:27,41:A,42:P,43:R,44:F,45:j,46:K,47:ee,48:ie,49:oe,50:pe},{11:52,17:51,24:se,37:24,38:T,39:_,40:27,41:A,42:P,43:R,44:F,45:j,46:K,47:ee,48:ie,49:oe,50:pe},{20:[1,53]},{22:[1,54]},i(de,[2,18]),{1:[2,2]},i(de,[2,8]),i(de,[2,9]),i(X,[2,37],{40:55,41:A,42:P,43:R,44:F,45:j,46:K,47:ee,48:ie,49:oe,50:pe}),i(X,[2,38]),i(X,[2,39]),i(ge,[2,40]),i(ge,[2,42]),i(ge,[2,43]),i(ge,[2,44]),i(ge,[2,45]),i(ge,[2,46]),i(ge,[2,47]),i(ge,[2,48]),i(ge,[2,49]),i(ge,[2,50]),i(ge,[2,51]),i(de,[2,10]),i(de,[2,22],{30:41,29:56,24:be,27:ae}),i(de,[2,24]),i(de,[2,25]),{31:[1,57]},{11:59,32:58,37:24,38:T,39:_,40:27,41:A,42:P,43:R,44:F,45:j,46:K,47:ee,48:ie,49:oe,50:pe},i(de,[2,11]),i(de,[2,30],{33:60,27:ne}),i(de,[2,32]),{31:[1,61]},i(de,[2,12]),{17:62,24:se},{25:63,27:W},i(de,[2,14]),{17:65,24:se},i(de,[2,16]),i(de,[2,17]),i(ge,[2,41]),i(de,[2,23]),{27:[1,66]},{26:[1,67]},{26:[2,29],28:[1,68]},i(de,[2,31]),{27:[1,69]},i(de,[2,13]),{26:[1,70]},{26:[2,21],28:[1,71]},i(de,[2,15]),i(de,[2,26]),i(de,[2,27]),{11:59,32:72,37:24,38:T,39:_,40:27,41:A,42:P,43:R,44:F,45:j,46:K,47:ee,48:ie,49:oe,50:pe},i(de,[2,33]),i(de,[2,19]),{25:73,27:W},{26:[2,28]},{26:[2,20]}],defaultActions:{8:[2,1],10:[2,3],21:[2,2],72:[2,28],73:[2,20]},parseError:function(je,Ie){if(Ie.recoverable)this.trace(je);else{var Se=new Error(je);throw Se.hash=Ie,Se}},parse:function(je){var Ie=this,Se=[0],Ce=[],ke=[null],Ke=[],Ft=this.table,Ne="",gn=0,_t=0,Et=2,Gt=1,ln=Ke.slice.call(arguments,1),xt=Object.create(this.lexer),Pt={yy:{}};for(var Qe in this.yy)Object.prototype.hasOwnProperty.call(this.yy,Qe)&&(Pt.yy[Qe]=this.yy[Qe]);xt.setInput(je,Pt.yy),Pt.yy.lexer=xt,Pt.yy.parser=this,typeof xt.yylloc>"u"&&(xt.yylloc={});var Dt=xt.yylloc;Ke.push(Dt);var kt=xt.options&&xt.options.ranges;typeof Pt.yy.parseError=="function"?this.parseError=Pt.yy.parseError:this.parseError=Object.getPrototypeOf(this).parseError;function On(){var qn;return qn=Ce.pop()||xt.lex()||Gt,typeof qn!="number"&&(qn instanceof Array&&(Ce=qn,qn=Ce.pop()),qn=Ie.symbols_[qn]||qn),qn}for(var ht,zr,yt,ji,xi={},Ma,zs,ao,Tr;;){if(zr=Se[Se.length-1],this.defaultActions[zr]?yt=this.defaultActions[zr]:((ht===null||typeof ht>"u")&&(ht=On()),yt=Ft[zr]&&Ft[zr][ht]),typeof yt>"u"||!yt.length||!yt[0]){var Fn="";Tr=[];for(Ma in Ft[zr])this.terminals_[Ma]&&Ma>Et&&Tr.push("'"+this.terminals_[Ma]+"'");xt.showPosition?Fn="Parse error on line "+(gn+1)+`: +`+xt.showPosition()+` +Expecting `+Tr.join(", ")+", got '"+(this.terminals_[ht]||ht)+"'":Fn="Parse error on line "+(gn+1)+": Unexpected "+(ht==Gt?"end of input":"'"+(this.terminals_[ht]||ht)+"'"),this.parseError(Fn,{text:xt.match,token:this.terminals_[ht]||ht,line:xt.yylineno,loc:Dt,expected:Tr})}if(yt[0]instanceof Array&&yt.length>1)throw new Error("Parse Error: multiple actions possible at state: "+zr+", token: "+ht);switch(yt[0]){case 1:Se.push(ht),ke.push(xt.yytext),Ke.push(xt.yylloc),Se.push(yt[1]),ht=null,_t=xt.yyleng,Ne=xt.yytext,gn=xt.yylineno,Dt=xt.yylloc;break;case 2:if(zs=this.productions_[yt[1]][1],xi.$=ke[ke.length-zs],xi._$={first_line:Ke[Ke.length-(zs||1)].first_line,last_line:Ke[Ke.length-1].last_line,first_column:Ke[Ke.length-(zs||1)].first_column,last_column:Ke[Ke.length-1].last_column},kt&&(xi._$.range=[Ke[Ke.length-(zs||1)].range[0],Ke[Ke.length-1].range[1]]),ji=this.performAction.apply(xi,[Ne,_t,gn,Pt.yy,yt[1],ke,Ke].concat(ln)),typeof ji<"u")return ji;zs&&(Se=Se.slice(0,-1*zs*2),ke=ke.slice(0,-1*zs),Ke=Ke.slice(0,-1*zs)),Se.push(this.productions_[yt[1]][0]),ke.push(xi.$),Ke.push(xi._$),ao=Ft[Se[Se.length-2]][Se[Se.length-1]],Se.push(ao);break;case 3:return!0}}return!0}},U=function(){var Pe={EOF:1,parseError:function(Ie,Se){if(this.yy.parser)this.yy.parser.parseError(Ie,Se);else throw new Error(Ie)},setInput:function(je,Ie){return this.yy=Ie||this.yy||{},this._input=je,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},input:function(){var je=this._input[0];this.yytext+=je,this.yyleng++,this.offset++,this.match+=je,this.matched+=je;var Ie=je.match(/(?:\r\n?|\n).*/g);return Ie?(this.yylineno++,this.yylloc.last_line++):this.yylloc.last_column++,this.options.ranges&&this.yylloc.range[1]++,this._input=this._input.slice(1),je},unput:function(je){var Ie=je.length,Se=je.split(/(?:\r\n?|\n)/g);this._input=je+this._input,this.yytext=this.yytext.substr(0,this.yytext.length-Ie),this.offset-=Ie;var Ce=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),Se.length-1&&(this.yylineno-=Se.length-1);var ke=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:Se?(Se.length===Ce.length?this.yylloc.first_column:0)+Ce[Ce.length-Se.length].length-Se[0].length:this.yylloc.first_column-Ie},this.options.ranges&&(this.yylloc.range=[ke[0],ke[0]+this.yyleng-Ie]),this.yyleng=this.yytext.length,this},more:function(){return this._more=!0,this},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},less:function(je){this.unput(this.match.slice(je))},pastInput:function(){var je=this.matched.substr(0,this.matched.length-this.match.length);return(je.length>20?"...":"")+je.substr(-20).replace(/\n/g,"")},upcomingInput:function(){var je=this.match;return je.length<20&&(je+=this._input.substr(0,20-je.length)),(je.substr(0,20)+(je.length>20?"...":"")).replace(/\n/g,"")},showPosition:function(){var je=this.pastInput(),Ie=new Array(je.length+1).join("-");return je+this.upcomingInput()+` +`+Ie+"^"},test_match:function(je,Ie){var Se,Ce,ke;if(this.options.backtrack_lexer&&(ke={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&&(ke.yylloc.range=this.yylloc.range.slice(0))),Ce=je[0].match(/(?:\r\n?|\n).*/g),Ce&&(this.yylineno+=Ce.length),this.yylloc={first_line:this.yylloc.last_line,last_line:this.yylineno+1,first_column:this.yylloc.last_column,last_column:Ce?Ce[Ce.length-1].length-Ce[Ce.length-1].match(/\r?\n?/)[0].length:this.yylloc.last_column+je[0].length},this.yytext+=je[0],this.match+=je[0],this.matches=je,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(je[0].length),this.matched+=je[0],Se=this.performAction.call(this,this.yy,this,Ie,this.conditionStack[this.conditionStack.length-1]),this.done&&this._input&&(this.done=!1),Se)return Se;if(this._backtrack){for(var Ke in ke)this[Ke]=ke[Ke];return!1}return!1},next:function(){if(this.done)return this.EOF;this._input||(this.done=!0);var je,Ie,Se,Ce;this._more||(this.yytext="",this.match="");for(var ke=this._currentRules(),Ke=0;KeIe[0].length)){if(Ie=Se,Ce=Ke,this.options.backtrack_lexer){if(je=this.test_match(Se,ke[Ke]),je!==!1)return je;if(this._backtrack){Ie=!1;continue}else return!1}else if(!this.options.flex)break}return Ie?(je=this.test_match(Ie,ke[Ce]),je!==!1?je:!1):this._input===""?this.EOF:this.parseError("Lexical error on line "+(this.yylineno+1)+`. Unrecognized text. +`+this.showPosition(),{text:"",token:null,line:this.yylineno})},lex:function(){var Ie=this.next();return Ie||this.lex()},begin:function(Ie){this.conditionStack.push(Ie)},popState:function(){var Ie=this.conditionStack.length-1;return Ie>0?this.conditionStack.pop():this.conditionStack[0]},_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},topState:function(Ie){return Ie=this.conditionStack.length-1-Math.abs(Ie||0),Ie>=0?this.conditionStack[Ie]:"INITIAL"},pushState:function(Ie){this.begin(Ie)},stateStackSize:function(){return this.conditionStack.length},options:{"case-insensitive":!0},performAction:function(Ie,Se,Ce,ke){switch(Ce){case 0:break;case 1:break;case 2:return this.popState(),34;case 3:return this.popState(),34;case 4:return 34;case 5:break;case 6:return 10;case 7:return this.pushState("acc_title"),19;case 8:return this.popState(),"acc_title_value";case 9:return this.pushState("acc_descr"),21;case 10:return this.popState(),"acc_descr_value";case 11:this.pushState("acc_descr_multiline");break;case 12:this.popState();break;case 13:return"acc_descr_multiline_value";case 14:return 5;case 15:return 8;case 16:return this.pushState("axis_data"),"X_AXIS";case 17:return this.pushState("axis_data"),"Y_AXIS";case 18:return this.pushState("axis_band_data"),24;case 19:return 31;case 20:return this.pushState("data"),16;case 21:return this.pushState("data"),18;case 22:return this.pushState("data_inner"),24;case 23:return 27;case 24:return this.popState(),26;case 25:this.popState();break;case 26:this.pushState("string");break;case 27:this.popState();break;case 28:return"STR";case 29:return 24;case 30:return 26;case 31:return 43;case 32:return"COLON";case 33:return 44;case 34:return 28;case 35:return 45;case 36:return 46;case 37:return 48;case 38:return 50;case 39:return 47;case 40:return 41;case 41:return 49;case 42:return 42;case 43:break;case 44:return 35;case 45:return 36}},rules:[/^(?:%%(?!\{)[^\n]*)/i,/^(?:[^\}]%%[^\n]*)/i,/^(?:(\r?\n))/i,/^(?:(\r?\n))/i,/^(?:[\n\r]+)/i,/^(?:%%[^\n]*)/i,/^(?:title\b)/i,/^(?:accTitle\s*:\s*)/i,/^(?:(?!\n||)*[^\n]*)/i,/^(?:accDescr\s*:\s*)/i,/^(?:(?!\n||)*[^\n]*)/i,/^(?:accDescr\s*\{\s*)/i,/^(?:\{)/i,/^(?:[^\}]*)/i,/^(?:xychart-beta\b)/i,/^(?:(?:vertical|horizontal))/i,/^(?:x-axis\b)/i,/^(?:y-axis\b)/i,/^(?:\[)/i,/^(?:-->)/i,/^(?:line\b)/i,/^(?:bar\b)/i,/^(?:\[)/i,/^(?:[+-]?(?:\d+(?:\.\d+)?|\.\d+))/i,/^(?:\])/i,/^(?:(?:`\) \{ this\.pushState\(md_string\); \}\n\(\?:\(\?!`"\)\.\)\+ \{ return MD_STR; \}\n\(\?:`))/i,/^(?:["])/i,/^(?:["])/i,/^(?:[^"]*)/i,/^(?:\[)/i,/^(?:\])/i,/^(?:[A-Za-z]+)/i,/^(?::)/i,/^(?:\+)/i,/^(?:,)/i,/^(?:=)/i,/^(?:\*)/i,/^(?:#)/i,/^(?:[\_])/i,/^(?:\.)/i,/^(?:&)/i,/^(?:-)/i,/^(?:[0-9]+)/i,/^(?:\s+)/i,/^(?:;)/i,/^(?:$)/i],conditions:{data_inner:{rules:[0,1,4,5,6,7,9,11,14,15,16,17,20,21,23,24,25,26,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45],inclusive:!0},data:{rules:[0,1,3,4,5,6,7,9,11,14,15,16,17,20,21,22,25,26,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45],inclusive:!0},axis_band_data:{rules:[0,1,4,5,6,7,9,11,14,15,16,17,20,21,24,25,26,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45],inclusive:!0},axis_data:{rules:[0,1,2,4,5,6,7,9,11,14,15,16,17,18,19,20,21,23,25,26,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45],inclusive:!0},acc_descr_multiline:{rules:[12,13],inclusive:!1},acc_descr:{rules:[10],inclusive:!1},acc_title:{rules:[8],inclusive:!1},title:{rules:[],inclusive:!1},md_string:{rules:[],inclusive:!1},string:{rules:[27,28],inclusive:!1},INITIAL:{rules:[0,1,4,5,6,7,9,11,14,15,16,17,20,21,25,26,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45],inclusive:!0}}};return Pe}();xe.lexer=U;function Fe(){this.yy={}}return Fe.prototype=xe,xe.Parser=Fe,new Fe}();dve.parser=dve;const $nn=dve;function fGe(i){return i.type==="bar"}function dGe(i){return i.type==="band"}function $R(i){return i.type==="linear"}class gGe{constructor(s){this.parentGroup=s}getMaxDimension(s,u){if(!this.parentGroup)return{width:s.reduce((v,b)=>Math.max(b.length,v),0)*u,height:u};const d={width:0,height:0},p=this.parentGroup.append("g").attr("visibility","hidden").attr("font-size",u);for(const v of s){const b=RZt(p,1,v),y=b?b.width:v.length*u,T=b?b.height:u;d.width=Math.max(d.width,y),d.height=Math.max(d.height,T)}return p.remove(),d}}const pGe=.7,bGe=.2;class mGe{constructor(s,u,d,p){this.axisConfig=s,this.title=u,this.textDimensionCalculator=d,this.axisThemeConfig=p,this.boundingRect={x:0,y:0,width:0,height:0},this.axisPosition="left",this.showTitle=!1,this.showLabel=!1,this.showTick=!1,this.showAxisLine=!1,this.outerPadding=0,this.titleTextHeight=0,this.labelTextHeight=0,this.range=[0,10],this.boundingRect={x:0,y:0,width:0,height:0},this.axisPosition="left"}setRange(s){this.range=s,this.axisPosition==="left"||this.axisPosition==="right"?this.boundingRect.height=s[1]-s[0]:this.boundingRect.width=s[1]-s[0],this.recalculateScale()}getRange(){return[this.range[0]+this.outerPadding,this.range[1]-this.outerPadding]}setAxisPosition(s){this.axisPosition=s,this.setRange(this.range)}getTickDistance(){const s=this.getRange();return Math.abs(s[0]-s[1])/this.getTickValues().length}getAxisOuterPadding(){return this.outerPadding}getLabelDimension(){return this.textDimensionCalculator.getMaxDimension(this.getTickValues().map(s=>s.toString()),this.axisConfig.labelFontSize)}recalculateOuterPaddingToDrawBar(){pGe*this.getTickDistance()>this.outerPadding*2&&(this.outerPadding=Math.floor(pGe*this.getTickDistance()/2)),this.recalculateScale()}calculateSpaceIfDrawnHorizontally(s){let u=s.height;if(this.axisConfig.showAxisLine&&u>this.axisConfig.axisLineWidth&&(u-=this.axisConfig.axisLineWidth,this.showAxisLine=!0),this.axisConfig.showLabel){const d=this.getLabelDimension(),p=bGe*s.width;this.outerPadding=Math.min(d.width/2,p);const v=d.height+this.axisConfig.labelPadding*2;this.labelTextHeight=d.height,v<=u&&(u-=v,this.showLabel=!0)}if(this.axisConfig.showTick&&u>=this.axisConfig.tickLength&&(this.showTick=!0,u-=this.axisConfig.tickLength),this.axisConfig.showTitle&&this.title){const d=this.textDimensionCalculator.getMaxDimension([this.title],this.axisConfig.titleFontSize),p=d.height+this.axisConfig.titlePadding*2;this.titleTextHeight=d.height,p<=u&&(u-=p,this.showTitle=!0)}this.boundingRect.width=s.width,this.boundingRect.height=s.height-u}calculateSpaceIfDrawnVertical(s){let u=s.width;if(this.axisConfig.showAxisLine&&u>this.axisConfig.axisLineWidth&&(u-=this.axisConfig.axisLineWidth,this.showAxisLine=!0),this.axisConfig.showLabel){const d=this.getLabelDimension(),p=bGe*s.height;this.outerPadding=Math.min(d.height/2,p);const v=d.width+this.axisConfig.labelPadding*2;v<=u&&(u-=v,this.showLabel=!0)}if(this.axisConfig.showTick&&u>=this.axisConfig.tickLength&&(this.showTick=!0,u-=this.axisConfig.tickLength),this.axisConfig.showTitle&&this.title){const d=this.textDimensionCalculator.getMaxDimension([this.title],this.axisConfig.titleFontSize),p=d.height+this.axisConfig.titlePadding*2;this.titleTextHeight=d.height,p<=u&&(u-=p,this.showTitle=!0)}this.boundingRect.width=s.width-u,this.boundingRect.height=s.height}calculateSpace(s){return this.axisPosition==="left"||this.axisPosition==="right"?this.calculateSpaceIfDrawnVertical(s):this.calculateSpaceIfDrawnHorizontally(s),this.recalculateScale(),{width:this.boundingRect.width,height:this.boundingRect.height}}setBoundingBoxXY(s){this.boundingRect.x=s.x,this.boundingRect.y=s.y}getDrawableElementsForLeftAxis(){const s=[];if(this.showAxisLine){const u=this.boundingRect.x+this.boundingRect.width-this.axisConfig.axisLineWidth/2;s.push({type:"path",groupTexts:["left-axis","axisl-line"],data:[{path:`M ${u},${this.boundingRect.y} L ${u},${this.boundingRect.y+this.boundingRect.height} `,strokeFill:this.axisThemeConfig.axisLineColor,strokeWidth:this.axisConfig.axisLineWidth}]})}if(this.showLabel&&s.push({type:"text",groupTexts:["left-axis","label"],data:this.getTickValues().map(u=>({text:u.toString(),x:this.boundingRect.x+this.boundingRect.width-(this.showLabel?this.axisConfig.labelPadding:0)-(this.showTick?this.axisConfig.tickLength:0)-(this.showAxisLine?this.axisConfig.axisLineWidth:0),y:this.getScaleValue(u),fill:this.axisThemeConfig.labelColor,fontSize:this.axisConfig.labelFontSize,rotation:0,verticalPos:"middle",horizontalPos:"right"}))}),this.showTick){const u=this.boundingRect.x+this.boundingRect.width-(this.showAxisLine?this.axisConfig.axisLineWidth:0);s.push({type:"path",groupTexts:["left-axis","ticks"],data:this.getTickValues().map(d=>({path:`M ${u},${this.getScaleValue(d)} L ${u-this.axisConfig.tickLength},${this.getScaleValue(d)}`,strokeFill:this.axisThemeConfig.tickColor,strokeWidth:this.axisConfig.tickWidth}))})}return this.showTitle&&s.push({type:"text",groupTexts:["left-axis","title"],data:[{text:this.title,x:this.boundingRect.x+this.axisConfig.titlePadding,y:this.boundingRect.y+this.boundingRect.height/2,fill:this.axisThemeConfig.titleColor,fontSize:this.axisConfig.titleFontSize,rotation:270,verticalPos:"top",horizontalPos:"center"}]}),s}getDrawableElementsForBottomAxis(){const s=[];if(this.showAxisLine){const u=this.boundingRect.y+this.axisConfig.axisLineWidth/2;s.push({type:"path",groupTexts:["bottom-axis","axis-line"],data:[{path:`M ${this.boundingRect.x},${u} L ${this.boundingRect.x+this.boundingRect.width},${u}`,strokeFill:this.axisThemeConfig.axisLineColor,strokeWidth:this.axisConfig.axisLineWidth}]})}if(this.showLabel&&s.push({type:"text",groupTexts:["bottom-axis","label"],data:this.getTickValues().map(u=>({text:u.toString(),x:this.getScaleValue(u),y:this.boundingRect.y+this.axisConfig.labelPadding+(this.showTick?this.axisConfig.tickLength:0)+(this.showAxisLine?this.axisConfig.axisLineWidth:0),fill:this.axisThemeConfig.labelColor,fontSize:this.axisConfig.labelFontSize,rotation:0,verticalPos:"top",horizontalPos:"center"}))}),this.showTick){const u=this.boundingRect.y+(this.showAxisLine?this.axisConfig.axisLineWidth:0);s.push({type:"path",groupTexts:["bottom-axis","ticks"],data:this.getTickValues().map(d=>({path:`M ${this.getScaleValue(d)},${u} L ${this.getScaleValue(d)},${u+this.axisConfig.tickLength}`,strokeFill:this.axisThemeConfig.tickColor,strokeWidth:this.axisConfig.tickWidth}))})}return this.showTitle&&s.push({type:"text",groupTexts:["bottom-axis","title"],data:[{text:this.title,x:this.range[0]+(this.range[1]-this.range[0])/2,y:this.boundingRect.y+this.boundingRect.height-this.axisConfig.titlePadding-this.titleTextHeight,fill:this.axisThemeConfig.titleColor,fontSize:this.axisConfig.titleFontSize,rotation:0,verticalPos:"top",horizontalPos:"center"}]}),s}getDrawableElementsForTopAxis(){const s=[];if(this.showAxisLine){const u=this.boundingRect.y+this.boundingRect.height-this.axisConfig.axisLineWidth/2;s.push({type:"path",groupTexts:["top-axis","axis-line"],data:[{path:`M ${this.boundingRect.x},${u} L ${this.boundingRect.x+this.boundingRect.width},${u}`,strokeFill:this.axisThemeConfig.axisLineColor,strokeWidth:this.axisConfig.axisLineWidth}]})}if(this.showLabel&&s.push({type:"text",groupTexts:["top-axis","label"],data:this.getTickValues().map(u=>({text:u.toString(),x:this.getScaleValue(u),y:this.boundingRect.y+(this.showTitle?this.titleTextHeight+this.axisConfig.titlePadding*2:0)+this.axisConfig.labelPadding,fill:this.axisThemeConfig.labelColor,fontSize:this.axisConfig.labelFontSize,rotation:0,verticalPos:"top",horizontalPos:"center"}))}),this.showTick){const u=this.boundingRect.y;s.push({type:"path",groupTexts:["top-axis","ticks"],data:this.getTickValues().map(d=>({path:`M ${this.getScaleValue(d)},${u+this.boundingRect.height-(this.showAxisLine?this.axisConfig.axisLineWidth:0)} L ${this.getScaleValue(d)},${u+this.boundingRect.height-this.axisConfig.tickLength-(this.showAxisLine?this.axisConfig.axisLineWidth:0)}`,strokeFill:this.axisThemeConfig.tickColor,strokeWidth:this.axisConfig.tickWidth}))})}return this.showTitle&&s.push({type:"text",groupTexts:["top-axis","title"],data:[{text:this.title,x:this.boundingRect.x+this.boundingRect.width/2,y:this.boundingRect.y+this.axisConfig.titlePadding,fill:this.axisThemeConfig.titleColor,fontSize:this.axisConfig.titleFontSize,rotation:0,verticalPos:"top",horizontalPos:"center"}]}),s}getDrawableElements(){if(this.axisPosition==="left")return this.getDrawableElementsForLeftAxis();if(this.axisPosition==="right")throw Error("Drawing of right axis is not implemented");return this.axisPosition==="bottom"?this.getDrawableElementsForBottomAxis():this.axisPosition==="top"?this.getDrawableElementsForTopAxis():[]}}class znn extends mGe{constructor(s,u,d,p,v){super(s,p,v,u),this.categories=d,this.scale=qpe().domain(this.categories).range(this.getRange())}setRange(s){super.setRange(s)}recalculateScale(){this.scale=qpe().domain(this.categories).range(this.getRange()).paddingInner(1).paddingOuter(0).align(.5),Xe.trace("BandAxis axis final categories, range: ",this.categories,this.getRange())}getTickValues(){return this.categories}getScaleValue(s){return this.scale(s)||this.getRange()[0]}}class qnn extends mGe{constructor(s,u,d,p,v){super(s,p,v,u),this.domain=d,this.scale=sD().domain(this.domain).range(this.getRange())}getTickValues(){return this.scale.ticks()}recalculateScale(){const s=[...this.domain];this.axisPosition==="left"&&s.reverse(),this.scale=sD().domain(s).range(this.getRange())}getScaleValue(s){return this.scale(s)}}function vGe(i,s,u,d){const p=new gGe(d);return dGe(i)?new znn(s,u,i.categories,i.title,p):new qnn(s,u,[i.min,i.max],i.title,p)}class Hnn{constructor(s,u,d,p){this.textDimensionCalculator=s,this.chartConfig=u,this.chartData=d,this.chartThemeConfig=p,this.boundingRect={x:0,y:0,width:0,height:0},this.showChartTitle=!1}setBoundingBoxXY(s){this.boundingRect.x=s.x,this.boundingRect.y=s.y}calculateSpace(s){const u=this.textDimensionCalculator.getMaxDimension([this.chartData.title],this.chartConfig.titleFontSize),d=Math.max(u.width,s.width),p=u.height+2*this.chartConfig.titlePadding;return u.width<=d&&u.height<=p&&this.chartConfig.showTitle&&this.chartData.title&&(this.boundingRect.width=d,this.boundingRect.height=p,this.showChartTitle=!0),{width:this.boundingRect.width,height:this.boundingRect.height}}getDrawableElements(){const s=[];return this.showChartTitle&&s.push({groupTexts:["chart-title"],type:"text",data:[{fontSize:this.chartConfig.titleFontSize,text:this.chartData.title,verticalPos:"middle",horizontalPos:"center",x:this.boundingRect.x+this.boundingRect.width/2,y:this.boundingRect.y+this.boundingRect.height/2,fill:this.chartThemeConfig.titleColor,rotation:0}]}),s}}function Vnn(i,s,u,d){const p=new gGe(d);return new Hnn(p,i,s,u)}class Unn{constructor(s,u,d,p,v){this.plotData=s,this.xAxis=u,this.yAxis=d,this.orientation=p,this.plotIndex=v}getDrawableElement(){const s=this.plotData.data.map(d=>[this.xAxis.getScaleValue(d[0]),this.yAxis.getScaleValue(d[1])]);let u;return this.orientation==="horizontal"?u=k7().y(d=>d[0]).x(d=>d[1])(s):u=k7().x(d=>d[0]).y(d=>d[1])(s),u?[{groupTexts:["plot",`line-plot-${this.plotIndex}`],type:"path",data:[{path:u,strokeFill:this.plotData.strokeFill,strokeWidth:this.plotData.strokeWidth}]}]:[]}}class Gnn{constructor(s,u,d,p,v,b){this.barData=s,this.boundingRect=u,this.xAxis=d,this.yAxis=p,this.orientation=v,this.plotIndex=b}getDrawableElement(){const s=this.barData.data.map(v=>[this.xAxis.getScaleValue(v[0]),this.yAxis.getScaleValue(v[1])]),u=.05,d=Math.min(this.xAxis.getAxisOuterPadding()*2,this.xAxis.getTickDistance())*(1-u),p=d/2;return this.orientation==="horizontal"?[{groupTexts:["plot",`bar-plot-${this.plotIndex}`],type:"rect",data:s.map(v=>({x:this.boundingRect.x,y:v[0]-p,height:d,width:v[1]-this.boundingRect.x,fill:this.barData.fill,strokeWidth:0,strokeFill:this.barData.fill}))}]:[{groupTexts:["plot",`bar-plot-${this.plotIndex}`],type:"rect",data:s.map(v=>({x:v[0]-p,y:v[1],width:d,height:this.boundingRect.y+this.boundingRect.height-v[1],fill:this.barData.fill,strokeWidth:0,strokeFill:this.barData.fill}))}]}}class Knn{constructor(s,u,d){this.chartConfig=s,this.chartData=u,this.chartThemeConfig=d,this.boundingRect={x:0,y:0,width:0,height:0}}setAxes(s,u){this.xAxis=s,this.yAxis=u}setBoundingBoxXY(s){this.boundingRect.x=s.x,this.boundingRect.y=s.y}calculateSpace(s){return this.boundingRect.width=s.width,this.boundingRect.height=s.height,{width:this.boundingRect.width,height:this.boundingRect.height}}getDrawableElements(){if(!(this.xAxis&&this.yAxis))throw Error("Axes must be passed to render Plots");const s=[];for(const[u,d]of this.chartData.plots.entries())switch(d.type){case"line":{const p=new Unn(d,this.xAxis,this.yAxis,this.chartConfig.chartOrientation,u);s.push(...p.getDrawableElement())}break;case"bar":{const p=new Gnn(d,this.boundingRect,this.xAxis,this.yAxis,this.chartConfig.chartOrientation,u);s.push(...p.getDrawableElement())}break}return s}}function Wnn(i,s,u){return new Knn(i,s,u)}class Ynn{constructor(s,u,d,p){this.chartConfig=s,this.chartData=u,this.componentStore={title:Vnn(s,u,d,p),plot:Wnn(s,u,d),xAxis:vGe(u.xAxis,s.xAxis,{titleColor:d.xAxisTitleColor,labelColor:d.xAxisLabelColor,tickColor:d.xAxisTickColor,axisLineColor:d.xAxisLineColor},p),yAxis:vGe(u.yAxis,s.yAxis,{titleColor:d.yAxisTitleColor,labelColor:d.yAxisLabelColor,tickColor:d.yAxisTickColor,axisLineColor:d.yAxisLineColor},p)}}calculateVerticalSpace(){let s=this.chartConfig.width,u=this.chartConfig.height,d=0,p=0,v=Math.floor(s*this.chartConfig.plotReservedSpacePercent/100),b=Math.floor(u*this.chartConfig.plotReservedSpacePercent/100),y=this.componentStore.plot.calculateSpace({width:v,height:b});s-=y.width,u-=y.height,y=this.componentStore.title.calculateSpace({width:this.chartConfig.width,height:u}),p=y.height,u-=y.height,this.componentStore.xAxis.setAxisPosition("bottom"),y=this.componentStore.xAxis.calculateSpace({width:s,height:u}),u-=y.height,this.componentStore.yAxis.setAxisPosition("left"),y=this.componentStore.yAxis.calculateSpace({width:s,height:u}),d=y.width,s-=y.width,s>0&&(v+=s,s=0),u>0&&(b+=u,u=0),this.componentStore.plot.calculateSpace({width:v,height:b}),this.componentStore.plot.setBoundingBoxXY({x:d,y:p}),this.componentStore.xAxis.setRange([d,d+v]),this.componentStore.xAxis.setBoundingBoxXY({x:d,y:p+b}),this.componentStore.yAxis.setRange([p,p+b]),this.componentStore.yAxis.setBoundingBoxXY({x:0,y:p}),this.chartData.plots.some(T=>fGe(T))&&this.componentStore.xAxis.recalculateOuterPaddingToDrawBar()}calculateHorizontalSpace(){let s=this.chartConfig.width,u=this.chartConfig.height,d=0,p=0,v=0,b=Math.floor(s*this.chartConfig.plotReservedSpacePercent/100),y=Math.floor(u*this.chartConfig.plotReservedSpacePercent/100),T=this.componentStore.plot.calculateSpace({width:b,height:y});s-=T.width,u-=T.height,T=this.componentStore.title.calculateSpace({width:this.chartConfig.width,height:u}),d=T.height,u-=T.height,this.componentStore.xAxis.setAxisPosition("left"),T=this.componentStore.xAxis.calculateSpace({width:s,height:u}),s-=T.width,p=T.width,this.componentStore.yAxis.setAxisPosition("top"),T=this.componentStore.yAxis.calculateSpace({width:s,height:u}),u-=T.height,v=d+T.height,s>0&&(b+=s,s=0),u>0&&(y+=u,u=0),this.componentStore.plot.calculateSpace({width:b,height:y}),this.componentStore.plot.setBoundingBoxXY({x:p,y:v}),this.componentStore.yAxis.setRange([p,p+b]),this.componentStore.yAxis.setBoundingBoxXY({x:p,y:d}),this.componentStore.xAxis.setRange([v,v+y]),this.componentStore.xAxis.setBoundingBoxXY({x:0,y:v}),this.chartData.plots.some(_=>fGe(_))&&this.componentStore.xAxis.recalculateOuterPaddingToDrawBar()}calculateSpace(){this.chartConfig.chartOrientation==="horizontal"?this.calculateHorizontalSpace():this.calculateVerticalSpace()}getDrawableElement(){this.calculateSpace();const s=[];this.componentStore.plot.setAxes(this.componentStore.xAxis,this.componentStore.yAxis);for(const u of Object.values(this.componentStore))s.push(...u.getDrawableElements());return s}}class Xnn{static build(s,u,d,p){return new Ynn(s,u,d,p).getDrawableElement()}}let zR=0,wGe,qR=xGe(),HR=yGe(),el=kGe(),gve=HR.plotColorPalette.split(",").map(i=>i.trim()),gJ=!1,pve=!1;function yGe(){const i=f2e(),s=Vh();return JF(i.xyChart,s.themeVariables.xyChart)}function xGe(){const i=Vh();return JF(sh.xyChart,i.xyChart)}function kGe(){return{yAxis:{type:"linear",title:"",min:1/0,max:-1/0},xAxis:{type:"band",title:"",categories:[]},title:"",plots:[]}}function bve(i){const s=Vh();return Yf(i.trim(),s)}function Qnn(i){wGe=i}function Jnn(i){i==="horizontal"?qR.chartOrientation="horizontal":qR.chartOrientation="vertical"}function Znn(i){el.xAxis.title=bve(i.text)}function EGe(i,s){el.xAxis={type:"linear",title:el.xAxis.title,min:i,max:s},gJ=!0}function ern(i){el.xAxis={type:"band",title:el.xAxis.title,categories:i.map(s=>bve(s.text))},gJ=!0}function trn(i){el.yAxis.title=bve(i.text)}function nrn(i,s){el.yAxis={type:"linear",title:el.yAxis.title,min:i,max:s},pve=!0}function rrn(i){const s=Math.min(...i),u=Math.max(...i),d=$R(el.yAxis)?el.yAxis.min:1/0,p=$R(el.yAxis)?el.yAxis.max:-1/0;el.yAxis={type:"linear",title:el.yAxis.title,min:Math.min(d,s),max:Math.max(p,u)}}function TGe(i){let s=[];if(i.length===0)return s;if(!gJ){const u=$R(el.xAxis)?el.xAxis.min:1/0,d=$R(el.xAxis)?el.xAxis.max:-1/0;EGe(Math.min(u,1),Math.max(d,i.length))}if(pve||rrn(i),dGe(el.xAxis)&&(s=el.xAxis.categories.map((u,d)=>[u,i[d]])),$R(el.xAxis)){const u=el.xAxis.min,d=el.xAxis.max,p=(d-u+1)/i.length,v=[];for(let b=u;b<=d;b+=p)v.push(`${b}`);s=v.map((b,y)=>[b,i[y]])}return s}function CGe(i){return gve[i===0?0:i%gve.length]}function irn(i,s){const u=TGe(s);el.plots.push({type:"line",strokeFill:CGe(zR),strokeWidth:2,data:u}),zR++}function srn(i,s){const u=TGe(s);el.plots.push({type:"bar",fill:CGe(zR),data:u}),zR++}function arn(){if(el.plots.length===0)throw Error("No Plot to render, please provide a plot with some data");return el.title=Ap(),Xnn.build(qR,el,HR,wGe)}function orn(){return HR}function crn(){return qR}const urn=Object.freeze(Object.defineProperty({__proto__:null,diagram:{parser:$nn,db:{getDrawableElem:arn,clear:function(){Pg(),zR=0,qR=xGe(),el=kGe(),HR=yGe(),gve=HR.plotColorPalette.split(",").map(i=>i.trim()),gJ=!1,pve=!1},setAccTitle:Bg,getAccTitle:Cp,setDiagramTitle:cm,getDiagramTitle:Ap,getAccDescription:_p,setAccDescription:Sp,setOrientation:Jnn,setXAxisTitle:Znn,setXAxisRangeData:EGe,setXAxisBand:ern,setYAxisTitle:trn,setYAxisRangeData:nrn,setLineData:irn,setBarData:srn,setTmpSVGG:Qnn,getChartThemeConfig:orn,getChartConfig:crn},renderer:{draw:(i,s,u,d)=>{const p=d.db,v=p.getChartThemeConfig(),b=p.getChartConfig();function y(ee){return ee==="top"?"text-before-edge":"middle"}function T(ee){return ee==="left"?"start":ee==="right"?"end":"middle"}function _(ee){return`translate(${ee.x}, ${ee.y}) rotate(${ee.rotation||0})`}Xe.debug(`Rendering xychart chart +`+i);const A=rR(s),P=A.append("g").attr("class","main"),R=P.append("rect").attr("width",b.width).attr("height",b.height).attr("class","background");Ng(A,b.height,b.width,!0),A.attr("viewBox",`0 0 ${b.width} ${b.height}`),R.attr("fill",v.backgroundColor),p.setTmpSVGG(A.append("g").attr("class","mermaid-tmp-group"));const F=p.getDrawableElem(),j={};function K(ee){let ie=P,oe="";for(const[pe]of ee.entries()){let be=P;pe>0&&j[oe]&&(be=j[oe]),oe+=ee[pe],ie=j[oe],ie||(ie=j[oe]=be.append("g").attr("class",ee[pe]))}return ie}for(const ee of F){if(ee.data.length===0)continue;const ie=K(ee.groupTexts);switch(ee.type){case"rect":ie.selectAll("rect").data(ee.data).enter().append("rect").attr("x",oe=>oe.x).attr("y",oe=>oe.y).attr("width",oe=>oe.width).attr("height",oe=>oe.height).attr("fill",oe=>oe.fill).attr("stroke",oe=>oe.strokeFill).attr("stroke-width",oe=>oe.strokeWidth);break;case"text":ie.selectAll("text").data(ee.data).enter().append("text").attr("x",0).attr("y",0).attr("fill",oe=>oe.fill).attr("font-size",oe=>oe.fontSize).attr("dominant-baseline",oe=>y(oe.verticalPos)).attr("text-anchor",oe=>T(oe.horizontalPos)).attr("transform",oe=>_(oe)).text(oe=>oe.text);break;case"path":ie.selectAll("path").data(ee.data).enter().append("path").attr("d",oe=>oe.path).attr("fill",oe=>oe.fill?oe.fill:"none").attr("stroke",oe=>oe.strokeFill).attr("stroke-width",oe=>oe.strokeWidth);break}}}}}},Symbol.toStringTag,{value:"Module"}));var mve=function(){var i=function(_t,Et,Gt,ln){for(Gt=Gt||{},ln=_t.length;ln--;Gt[_t[ln]]=Et);return Gt},s=[1,3],u=[1,4],d=[1,5],p=[1,6],v=[5,6,8,9,11,13,31,32,33,34,35,36,44,62,63],b=[1,18],y=[2,7],T=[1,22],_=[1,23],A=[1,24],P=[1,25],R=[1,26],F=[1,27],j=[1,20],K=[1,28],ee=[1,29],ie=[62,63],oe=[5,8,9,11,13,31,32,33,34,35,36,44,51,53,62,63],pe=[1,47],be=[1,48],ae=[1,49],ne=[1,50],se=[1,51],de=[1,52],X=[1,53],ge=[53,54],W=[1,64],xe=[1,60],U=[1,61],Fe=[1,62],Pe=[1,63],je=[1,65],Ie=[1,69],Se=[1,70],Ce=[1,67],ke=[1,68],Ke=[5,8,9,11,13,31,32,33,34,35,36,44,62,63],Ft={trace:function(){},yy:{},symbols_:{error:2,start:3,directive:4,NEWLINE:5,RD:6,diagram:7,EOF:8,acc_title:9,acc_title_value:10,acc_descr:11,acc_descr_value:12,acc_descr_multiline_value:13,requirementDef:14,elementDef:15,relationshipDef:16,requirementType:17,requirementName:18,STRUCT_START:19,requirementBody:20,ID:21,COLONSEP:22,id:23,TEXT:24,text:25,RISK:26,riskLevel:27,VERIFYMTHD:28,verifyType:29,STRUCT_STOP:30,REQUIREMENT:31,FUNCTIONAL_REQUIREMENT:32,INTERFACE_REQUIREMENT:33,PERFORMANCE_REQUIREMENT:34,PHYSICAL_REQUIREMENT:35,DESIGN_CONSTRAINT:36,LOW_RISK:37,MED_RISK:38,HIGH_RISK:39,VERIFY_ANALYSIS:40,VERIFY_DEMONSTRATION:41,VERIFY_INSPECTION:42,VERIFY_TEST:43,ELEMENT:44,elementName:45,elementBody:46,TYPE:47,type:48,DOCREF:49,ref:50,END_ARROW_L:51,relationship:52,LINE:53,END_ARROW_R:54,CONTAINS:55,COPIES:56,DERIVES:57,SATISFIES:58,VERIFIES:59,REFINES:60,TRACES:61,unqString:62,qString:63,$accept:0,$end:1},terminals_:{2:"error",5:"NEWLINE",6:"RD",8:"EOF",9:"acc_title",10:"acc_title_value",11:"acc_descr",12:"acc_descr_value",13:"acc_descr_multiline_value",19:"STRUCT_START",21:"ID",22:"COLONSEP",24:"TEXT",26:"RISK",28:"VERIFYMTHD",30:"STRUCT_STOP",31:"REQUIREMENT",32:"FUNCTIONAL_REQUIREMENT",33:"INTERFACE_REQUIREMENT",34:"PERFORMANCE_REQUIREMENT",35:"PHYSICAL_REQUIREMENT",36:"DESIGN_CONSTRAINT",37:"LOW_RISK",38:"MED_RISK",39:"HIGH_RISK",40:"VERIFY_ANALYSIS",41:"VERIFY_DEMONSTRATION",42:"VERIFY_INSPECTION",43:"VERIFY_TEST",44:"ELEMENT",47:"TYPE",49:"DOCREF",51:"END_ARROW_L",53:"LINE",54:"END_ARROW_R",55:"CONTAINS",56:"COPIES",57:"DERIVES",58:"SATISFIES",59:"VERIFIES",60:"REFINES",61:"TRACES",62:"unqString",63:"qString"},productions_:[0,[3,3],[3,2],[3,4],[4,2],[4,2],[4,1],[7,0],[7,2],[7,2],[7,2],[7,2],[7,2],[14,5],[20,5],[20,5],[20,5],[20,5],[20,2],[20,1],[17,1],[17,1],[17,1],[17,1],[17,1],[17,1],[27,1],[27,1],[27,1],[29,1],[29,1],[29,1],[29,1],[15,5],[46,5],[46,5],[46,2],[46,1],[16,5],[16,5],[52,1],[52,1],[52,1],[52,1],[52,1],[52,1],[52,1],[18,1],[18,1],[23,1],[23,1],[25,1],[25,1],[45,1],[45,1],[48,1],[48,1],[50,1],[50,1]],performAction:function(Et,Gt,ln,xt,Pt,Qe,Dt){var kt=Qe.length-1;switch(Pt){case 4:this.$=Qe[kt].trim(),xt.setAccTitle(this.$);break;case 5:case 6:this.$=Qe[kt].trim(),xt.setAccDescription(this.$);break;case 7:this.$=[];break;case 13:xt.addRequirement(Qe[kt-3],Qe[kt-4]);break;case 14:xt.setNewReqId(Qe[kt-2]);break;case 15:xt.setNewReqText(Qe[kt-2]);break;case 16:xt.setNewReqRisk(Qe[kt-2]);break;case 17:xt.setNewReqVerifyMethod(Qe[kt-2]);break;case 20:this.$=xt.RequirementType.REQUIREMENT;break;case 21:this.$=xt.RequirementType.FUNCTIONAL_REQUIREMENT;break;case 22:this.$=xt.RequirementType.INTERFACE_REQUIREMENT;break;case 23:this.$=xt.RequirementType.PERFORMANCE_REQUIREMENT;break;case 24:this.$=xt.RequirementType.PHYSICAL_REQUIREMENT;break;case 25:this.$=xt.RequirementType.DESIGN_CONSTRAINT;break;case 26:this.$=xt.RiskLevel.LOW_RISK;break;case 27:this.$=xt.RiskLevel.MED_RISK;break;case 28:this.$=xt.RiskLevel.HIGH_RISK;break;case 29:this.$=xt.VerifyType.VERIFY_ANALYSIS;break;case 30:this.$=xt.VerifyType.VERIFY_DEMONSTRATION;break;case 31:this.$=xt.VerifyType.VERIFY_INSPECTION;break;case 32:this.$=xt.VerifyType.VERIFY_TEST;break;case 33:xt.addElement(Qe[kt-3]);break;case 34:xt.setNewElementType(Qe[kt-2]);break;case 35:xt.setNewElementDocRef(Qe[kt-2]);break;case 38:xt.addRelationship(Qe[kt-2],Qe[kt],Qe[kt-4]);break;case 39:xt.addRelationship(Qe[kt-2],Qe[kt-4],Qe[kt]);break;case 40:this.$=xt.Relationships.CONTAINS;break;case 41:this.$=xt.Relationships.COPIES;break;case 42:this.$=xt.Relationships.DERIVES;break;case 43:this.$=xt.Relationships.SATISFIES;break;case 44:this.$=xt.Relationships.VERIFIES;break;case 45:this.$=xt.Relationships.REFINES;break;case 46:this.$=xt.Relationships.TRACES;break}},table:[{3:1,4:2,6:s,9:u,11:d,13:p},{1:[3]},{3:8,4:2,5:[1,7],6:s,9:u,11:d,13:p},{5:[1,9]},{10:[1,10]},{12:[1,11]},i(v,[2,6]),{3:12,4:2,6:s,9:u,11:d,13:p},{1:[2,2]},{4:17,5:b,7:13,8:y,9:u,11:d,13:p,14:14,15:15,16:16,17:19,23:21,31:T,32:_,33:A,34:P,35:R,36:F,44:j,62:K,63:ee},i(v,[2,4]),i(v,[2,5]),{1:[2,1]},{8:[1,30]},{4:17,5:b,7:31,8:y,9:u,11:d,13:p,14:14,15:15,16:16,17:19,23:21,31:T,32:_,33:A,34:P,35:R,36:F,44:j,62:K,63:ee},{4:17,5:b,7:32,8:y,9:u,11:d,13:p,14:14,15:15,16:16,17:19,23:21,31:T,32:_,33:A,34:P,35:R,36:F,44:j,62:K,63:ee},{4:17,5:b,7:33,8:y,9:u,11:d,13:p,14:14,15:15,16:16,17:19,23:21,31:T,32:_,33:A,34:P,35:R,36:F,44:j,62:K,63:ee},{4:17,5:b,7:34,8:y,9:u,11:d,13:p,14:14,15:15,16:16,17:19,23:21,31:T,32:_,33:A,34:P,35:R,36:F,44:j,62:K,63:ee},{4:17,5:b,7:35,8:y,9:u,11:d,13:p,14:14,15:15,16:16,17:19,23:21,31:T,32:_,33:A,34:P,35:R,36:F,44:j,62:K,63:ee},{18:36,62:[1,37],63:[1,38]},{45:39,62:[1,40],63:[1,41]},{51:[1,42],53:[1,43]},i(ie,[2,20]),i(ie,[2,21]),i(ie,[2,22]),i(ie,[2,23]),i(ie,[2,24]),i(ie,[2,25]),i(oe,[2,49]),i(oe,[2,50]),{1:[2,3]},{8:[2,8]},{8:[2,9]},{8:[2,10]},{8:[2,11]},{8:[2,12]},{19:[1,44]},{19:[2,47]},{19:[2,48]},{19:[1,45]},{19:[2,53]},{19:[2,54]},{52:46,55:pe,56:be,57:ae,58:ne,59:se,60:de,61:X},{52:54,55:pe,56:be,57:ae,58:ne,59:se,60:de,61:X},{5:[1,55]},{5:[1,56]},{53:[1,57]},i(ge,[2,40]),i(ge,[2,41]),i(ge,[2,42]),i(ge,[2,43]),i(ge,[2,44]),i(ge,[2,45]),i(ge,[2,46]),{54:[1,58]},{5:W,20:59,21:xe,24:U,26:Fe,28:Pe,30:je},{5:Ie,30:Se,46:66,47:Ce,49:ke},{23:71,62:K,63:ee},{23:72,62:K,63:ee},i(Ke,[2,13]),{22:[1,73]},{22:[1,74]},{22:[1,75]},{22:[1,76]},{5:W,20:77,21:xe,24:U,26:Fe,28:Pe,30:je},i(Ke,[2,19]),i(Ke,[2,33]),{22:[1,78]},{22:[1,79]},{5:Ie,30:Se,46:80,47:Ce,49:ke},i(Ke,[2,37]),i(Ke,[2,38]),i(Ke,[2,39]),{23:81,62:K,63:ee},{25:82,62:[1,83],63:[1,84]},{27:85,37:[1,86],38:[1,87],39:[1,88]},{29:89,40:[1,90],41:[1,91],42:[1,92],43:[1,93]},i(Ke,[2,18]),{48:94,62:[1,95],63:[1,96]},{50:97,62:[1,98],63:[1,99]},i(Ke,[2,36]),{5:[1,100]},{5:[1,101]},{5:[2,51]},{5:[2,52]},{5:[1,102]},{5:[2,26]},{5:[2,27]},{5:[2,28]},{5:[1,103]},{5:[2,29]},{5:[2,30]},{5:[2,31]},{5:[2,32]},{5:[1,104]},{5:[2,55]},{5:[2,56]},{5:[1,105]},{5:[2,57]},{5:[2,58]},{5:W,20:106,21:xe,24:U,26:Fe,28:Pe,30:je},{5:W,20:107,21:xe,24:U,26:Fe,28:Pe,30:je},{5:W,20:108,21:xe,24:U,26:Fe,28:Pe,30:je},{5:W,20:109,21:xe,24:U,26:Fe,28:Pe,30:je},{5:Ie,30:Se,46:110,47:Ce,49:ke},{5:Ie,30:Se,46:111,47:Ce,49:ke},i(Ke,[2,14]),i(Ke,[2,15]),i(Ke,[2,16]),i(Ke,[2,17]),i(Ke,[2,34]),i(Ke,[2,35])],defaultActions:{8:[2,2],12:[2,1],30:[2,3],31:[2,8],32:[2,9],33:[2,10],34:[2,11],35:[2,12],37:[2,47],38:[2,48],40:[2,53],41:[2,54],83:[2,51],84:[2,52],86:[2,26],87:[2,27],88:[2,28],90:[2,29],91:[2,30],92:[2,31],93:[2,32],95:[2,55],96:[2,56],98:[2,57],99:[2,58]},parseError:function(Et,Gt){if(Gt.recoverable)this.trace(Et);else{var ln=new Error(Et);throw ln.hash=Gt,ln}},parse:function(Et){var Gt=this,ln=[0],xt=[],Pt=[null],Qe=[],Dt=this.table,kt="",On=0,ht=0,zr=2,yt=1,ji=Qe.slice.call(arguments,1),xi=Object.create(this.lexer),Ma={yy:{}};for(var zs in this.yy)Object.prototype.hasOwnProperty.call(this.yy,zs)&&(Ma.yy[zs]=this.yy[zs]);xi.setInput(Et,Ma.yy),Ma.yy.lexer=xi,Ma.yy.parser=this,typeof xi.yylloc>"u"&&(xi.yylloc={});var ao=xi.yylloc;Qe.push(ao);var Tr=xi.options&&xi.options.ranges;typeof Ma.yy.parseError=="function"?this.parseError=Ma.yy.parseError:this.parseError=Object.getPrototypeOf(this).parseError;function Fn(){var Pa;return Pa=xt.pop()||xi.lex()||yt,typeof Pa!="number"&&(Pa instanceof Array&&(xt=Pa,Pa=xt.pop()),Pa=Gt.symbols_[Pa]||Pa),Pa}for(var qn,Un,At,wt,on={},fn,An,oo,jo;;){if(Un=ln[ln.length-1],this.defaultActions[Un]?At=this.defaultActions[Un]:((qn===null||typeof qn>"u")&&(qn=Fn()),At=Dt[Un]&&Dt[Un][qn]),typeof At>"u"||!At.length||!At[0]){var $o="";jo=[];for(fn in Dt[Un])this.terminals_[fn]&&fn>zr&&jo.push("'"+this.terminals_[fn]+"'");xi.showPosition?$o="Parse error on line "+(On+1)+`: +`+xi.showPosition()+` +Expecting `+jo.join(", ")+", got '"+(this.terminals_[qn]||qn)+"'":$o="Parse error on line "+(On+1)+": Unexpected "+(qn==yt?"end of input":"'"+(this.terminals_[qn]||qn)+"'"),this.parseError($o,{text:xi.match,token:this.terminals_[qn]||qn,line:xi.yylineno,loc:ao,expected:jo})}if(At[0]instanceof Array&&At.length>1)throw new Error("Parse Error: multiple actions possible at state: "+Un+", token: "+qn);switch(At[0]){case 1:ln.push(qn),Pt.push(xi.yytext),Qe.push(xi.yylloc),ln.push(At[1]),qn=null,ht=xi.yyleng,kt=xi.yytext,On=xi.yylineno,ao=xi.yylloc;break;case 2:if(An=this.productions_[At[1]][1],on.$=Pt[Pt.length-An],on._$={first_line:Qe[Qe.length-(An||1)].first_line,last_line:Qe[Qe.length-1].last_line,first_column:Qe[Qe.length-(An||1)].first_column,last_column:Qe[Qe.length-1].last_column},Tr&&(on._$.range=[Qe[Qe.length-(An||1)].range[0],Qe[Qe.length-1].range[1]]),wt=this.performAction.apply(on,[kt,ht,On,Ma.yy,At[1],Pt,Qe].concat(ji)),typeof wt<"u")return wt;An&&(ln=ln.slice(0,-1*An*2),Pt=Pt.slice(0,-1*An),Qe=Qe.slice(0,-1*An)),ln.push(this.productions_[At[1]][0]),Pt.push(on.$),Qe.push(on._$),oo=Dt[ln[ln.length-2]][ln[ln.length-1]],ln.push(oo);break;case 3:return!0}}return!0}},Ne=function(){var _t={EOF:1,parseError:function(Gt,ln){if(this.yy.parser)this.yy.parser.parseError(Gt,ln);else throw new Error(Gt)},setInput:function(Et,Gt){return this.yy=Gt||this.yy||{},this._input=Et,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},input:function(){var Et=this._input[0];this.yytext+=Et,this.yyleng++,this.offset++,this.match+=Et,this.matched+=Et;var Gt=Et.match(/(?:\r\n?|\n).*/g);return Gt?(this.yylineno++,this.yylloc.last_line++):this.yylloc.last_column++,this.options.ranges&&this.yylloc.range[1]++,this._input=this._input.slice(1),Et},unput:function(Et){var Gt=Et.length,ln=Et.split(/(?:\r\n?|\n)/g);this._input=Et+this._input,this.yytext=this.yytext.substr(0,this.yytext.length-Gt),this.offset-=Gt;var xt=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),ln.length-1&&(this.yylineno-=ln.length-1);var Pt=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:ln?(ln.length===xt.length?this.yylloc.first_column:0)+xt[xt.length-ln.length].length-ln[0].length:this.yylloc.first_column-Gt},this.options.ranges&&(this.yylloc.range=[Pt[0],Pt[0]+this.yyleng-Gt]),this.yyleng=this.yytext.length,this},more:function(){return this._more=!0,this},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},less:function(Et){this.unput(this.match.slice(Et))},pastInput:function(){var Et=this.matched.substr(0,this.matched.length-this.match.length);return(Et.length>20?"...":"")+Et.substr(-20).replace(/\n/g,"")},upcomingInput:function(){var Et=this.match;return Et.length<20&&(Et+=this._input.substr(0,20-Et.length)),(Et.substr(0,20)+(Et.length>20?"...":"")).replace(/\n/g,"")},showPosition:function(){var Et=this.pastInput(),Gt=new Array(Et.length+1).join("-");return Et+this.upcomingInput()+` +`+Gt+"^"},test_match:function(Et,Gt){var ln,xt,Pt;if(this.options.backtrack_lexer&&(Pt={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&&(Pt.yylloc.range=this.yylloc.range.slice(0))),xt=Et[0].match(/(?:\r\n?|\n).*/g),xt&&(this.yylineno+=xt.length),this.yylloc={first_line:this.yylloc.last_line,last_line:this.yylineno+1,first_column:this.yylloc.last_column,last_column:xt?xt[xt.length-1].length-xt[xt.length-1].match(/\r?\n?/)[0].length:this.yylloc.last_column+Et[0].length},this.yytext+=Et[0],this.match+=Et[0],this.matches=Et,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(Et[0].length),this.matched+=Et[0],ln=this.performAction.call(this,this.yy,this,Gt,this.conditionStack[this.conditionStack.length-1]),this.done&&this._input&&(this.done=!1),ln)return ln;if(this._backtrack){for(var Qe in Pt)this[Qe]=Pt[Qe];return!1}return!1},next:function(){if(this.done)return this.EOF;this._input||(this.done=!0);var Et,Gt,ln,xt;this._more||(this.yytext="",this.match="");for(var Pt=this._currentRules(),Qe=0;QeGt[0].length)){if(Gt=ln,xt=Qe,this.options.backtrack_lexer){if(Et=this.test_match(ln,Pt[Qe]),Et!==!1)return Et;if(this._backtrack){Gt=!1;continue}else return!1}else if(!this.options.flex)break}return Gt?(Et=this.test_match(Gt,Pt[xt]),Et!==!1?Et:!1):this._input===""?this.EOF:this.parseError("Lexical error on line "+(this.yylineno+1)+`. Unrecognized text. +`+this.showPosition(),{text:"",token:null,line:this.yylineno})},lex:function(){var Gt=this.next();return Gt||this.lex()},begin:function(Gt){this.conditionStack.push(Gt)},popState:function(){var Gt=this.conditionStack.length-1;return Gt>0?this.conditionStack.pop():this.conditionStack[0]},_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},topState:function(Gt){return Gt=this.conditionStack.length-1-Math.abs(Gt||0),Gt>=0?this.conditionStack[Gt]:"INITIAL"},pushState:function(Gt){this.begin(Gt)},stateStackSize:function(){return this.conditionStack.length},options:{"case-insensitive":!0},performAction:function(Gt,ln,xt,Pt){switch(xt){case 0:return"title";case 1:return this.begin("acc_title"),9;case 2:return this.popState(),"acc_title_value";case 3:return this.begin("acc_descr"),11;case 4:return this.popState(),"acc_descr_value";case 5:this.begin("acc_descr_multiline");break;case 6:this.popState();break;case 7:return"acc_descr_multiline_value";case 8:return 5;case 9:break;case 10:break;case 11:break;case 12:return 8;case 13:return 6;case 14:return 19;case 15:return 30;case 16:return 22;case 17:return 21;case 18:return 24;case 19:return 26;case 20:return 28;case 21:return 31;case 22:return 32;case 23:return 33;case 24:return 34;case 25:return 35;case 26:return 36;case 27:return 37;case 28:return 38;case 29:return 39;case 30:return 40;case 31:return 41;case 32:return 42;case 33:return 43;case 34:return 44;case 35:return 55;case 36:return 56;case 37:return 57;case 38:return 58;case 39:return 59;case 40:return 60;case 41:return 61;case 42:return 47;case 43:return 49;case 44:return 51;case 45:return 54;case 46:return 53;case 47:this.begin("string");break;case 48:this.popState();break;case 49:return"qString";case 50:return ln.yytext=ln.yytext.trim(),62}},rules:[/^(?:title\s[^#\n;]+)/i,/^(?:accTitle\s*:\s*)/i,/^(?:(?!\n||)*[^\n]*)/i,/^(?:accDescr\s*:\s*)/i,/^(?:(?!\n||)*[^\n]*)/i,/^(?:accDescr\s*\{\s*)/i,/^(?:[\}])/i,/^(?:[^\}]*)/i,/^(?:(\r?\n)+)/i,/^(?:\s+)/i,/^(?:#[^\n]*)/i,/^(?:%[^\n]*)/i,/^(?:$)/i,/^(?:requirementDiagram\b)/i,/^(?:\{)/i,/^(?:\})/i,/^(?::)/i,/^(?:id\b)/i,/^(?:text\b)/i,/^(?:risk\b)/i,/^(?:verifyMethod\b)/i,/^(?:requirement\b)/i,/^(?:functionalRequirement\b)/i,/^(?:interfaceRequirement\b)/i,/^(?:performanceRequirement\b)/i,/^(?:physicalRequirement\b)/i,/^(?:designConstraint\b)/i,/^(?:low\b)/i,/^(?:medium\b)/i,/^(?:high\b)/i,/^(?:analysis\b)/i,/^(?:demonstration\b)/i,/^(?:inspection\b)/i,/^(?:test\b)/i,/^(?:element\b)/i,/^(?:contains\b)/i,/^(?:copies\b)/i,/^(?:derives\b)/i,/^(?:satisfies\b)/i,/^(?:verifies\b)/i,/^(?:refines\b)/i,/^(?:traces\b)/i,/^(?:type\b)/i,/^(?:docref\b)/i,/^(?:<-)/i,/^(?:->)/i,/^(?:-)/i,/^(?:["])/i,/^(?:["])/i,/^(?:[^"]*)/i,/^(?:[\w][^\r\n\{\<\>\-\=]*)/i],conditions:{acc_descr_multiline:{rules:[6,7],inclusive:!1},acc_descr:{rules:[4],inclusive:!1},acc_title:{rules:[2],inclusive:!1},unqString:{rules:[],inclusive:!1},token:{rules:[],inclusive:!1},string:{rules:[48,49],inclusive:!1},INITIAL:{rules:[0,1,3,5,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,50],inclusive:!0}}};return _t}();Ft.lexer=Ne;function gn(){this.yy={}}return gn.prototype=Ft,Ft.Parser=gn,new gn}();mve.parser=mve;const lrn=mve;let vve=[],V2={},VR={},F9={},UR={};const hrn={RequirementType:{REQUIREMENT:"Requirement",FUNCTIONAL_REQUIREMENT:"Functional Requirement",INTERFACE_REQUIREMENT:"Interface Requirement",PERFORMANCE_REQUIREMENT:"Performance Requirement",PHYSICAL_REQUIREMENT:"Physical Requirement",DESIGN_CONSTRAINT:"Design Constraint"},RiskLevel:{LOW_RISK:"Low",MED_RISK:"Medium",HIGH_RISK:"High"},VerifyType:{VERIFY_ANALYSIS:"Analysis",VERIFY_DEMONSTRATION:"Demonstration",VERIFY_INSPECTION:"Inspection",VERIFY_TEST:"Test"},Relationships:{CONTAINS:"contains",COPIES:"copies",DERIVES:"derives",SATISFIES:"satisfies",VERIFIES:"verifies",REFINES:"refines",TRACES:"traces"},getConfig:()=>qt().req,addRequirement:(i,s)=>(VR[i]===void 0&&(VR[i]={name:i,type:s,id:V2.id,text:V2.text,risk:V2.risk,verifyMethod:V2.verifyMethod}),V2={},VR[i]),getRequirements:()=>VR,setNewReqId:i=>{V2!==void 0&&(V2.id=i)},setNewReqText:i=>{V2!==void 0&&(V2.text=i)},setNewReqRisk:i=>{V2!==void 0&&(V2.risk=i)},setNewReqVerifyMethod:i=>{V2!==void 0&&(V2.verifyMethod=i)},setAccTitle:Bg,getAccTitle:Cp,setAccDescription:Sp,getAccDescription:_p,addElement:i=>(UR[i]===void 0&&(UR[i]={name:i,type:F9.type,docRef:F9.docRef},Xe.info("Added new requirement: ",i)),F9={},UR[i]),getElements:()=>UR,setNewElementType:i=>{F9!==void 0&&(F9.type=i)},setNewElementDocRef:i=>{F9!==void 0&&(F9.docRef=i)},addRelationship:(i,s,u)=>{vve.push({type:i,src:s,dst:u})},getRelationships:()=>vve,clear:()=>{vve=[],V2={},VR={},F9={},UR={},Pg()}},frn=i=>` + + marker { + fill: ${i.relationColor}; + stroke: ${i.relationColor}; + } + + marker.cross { + stroke: ${i.lineColor}; + } + + svg { + font-family: ${i.fontFamily}; + font-size: ${i.fontSize}; + } + + .reqBox { + fill: ${i.requirementBackground}; + fill-opacity: 1.0; + stroke: ${i.requirementBorderColor}; + stroke-width: ${i.requirementBorderSize}; + } + + .reqTitle, .reqLabel{ + fill: ${i.requirementTextColor}; + } + .reqLabelBox { + fill: ${i.relationLabelBackground}; + fill-opacity: 1.0; + } + + .req-title-line { + stroke: ${i.requirementBorderColor}; + stroke-width: ${i.requirementBorderSize}; + } + .relationshipLine { + stroke: ${i.relationColor}; + stroke-width: 1; + } + .relationshipLabel { + fill: ${i.relationLabelColor}; + } + +`,wve={CONTAINS:"contains",ARROW:"arrow"},SGe={ReqMarkers:wve,insertLineEndings:(i,s)=>{let u=i.append("defs").append("marker").attr("id",wve.CONTAINS+"_line_ending").attr("refX",0).attr("refY",s.line_height/2).attr("markerWidth",s.line_height).attr("markerHeight",s.line_height).attr("orient","auto").append("g");u.append("circle").attr("cx",s.line_height/2).attr("cy",s.line_height/2).attr("r",s.line_height/2).attr("fill","none"),u.append("line").attr("x1",0).attr("x2",s.line_height).attr("y1",s.line_height/2).attr("y2",s.line_height/2).attr("stroke-width",1),u.append("line").attr("y1",0).attr("y2",s.line_height).attr("x1",s.line_height/2).attr("x2",s.line_height/2).attr("stroke-width",1),i.append("defs").append("marker").attr("id",wve.ARROW+"_line_ending").attr("refX",s.line_height).attr("refY",.5*s.line_height).attr("markerWidth",s.line_height).attr("markerHeight",s.line_height).attr("orient","auto").append("path").attr("d",`M0,0 + L${s.line_height},${s.line_height/2} + M${s.line_height},${s.line_height/2} + L0,${s.line_height}`).attr("stroke-width",1)}};let Tf={},_Ge=0;const AGe=(i,s)=>i.insert("rect","#"+s).attr("class","req reqBox").attr("x",0).attr("y",0).attr("width",Tf.rect_min_width+"px").attr("height",Tf.rect_min_height+"px"),LGe=(i,s,u)=>{let d=Tf.rect_min_width/2,p=i.append("text").attr("class","req reqLabel reqTitle").attr("id",s).attr("x",d).attr("y",Tf.rect_padding).attr("dominant-baseline","hanging"),v=0;u.forEach(_=>{v==0?p.append("tspan").attr("text-anchor","middle").attr("x",Tf.rect_min_width/2).attr("dy",0).text(_):p.append("tspan").attr("text-anchor","middle").attr("x",Tf.rect_min_width/2).attr("dy",Tf.line_height*.75).text(_),v++});let b=1.5*Tf.rect_padding,y=v*Tf.line_height*.75,T=b+y;return i.append("line").attr("class","req-title-line").attr("x1","0").attr("x2",Tf.rect_min_width).attr("y1",T).attr("y2",T),{titleNode:p,y:T}},MGe=(i,s,u,d)=>{let p=i.append("text").attr("class","req reqLabel").attr("id",s).attr("x",Tf.rect_padding).attr("y",d).attr("dominant-baseline","hanging"),v=0;const b=30;let y=[];return u.forEach(T=>{let _=T.length;for(;_>b&&v<3;){let A=T.substring(0,b);T=T.substring(b,T.length),_=T.length,y[y.length]=A,v++}if(v==3){let A=y[y.length-1];y[y.length-1]=A.substring(0,A.length-4)+"..."}else y[y.length]=T;v=0}),y.forEach(T=>{p.append("tspan").attr("x",Tf.rect_padding).attr("dy",Tf.line_height).text(T)}),p},drn=(i,s,u,d)=>{const p=s.node().getTotalLength(),v=s.node().getPointAtLength(p*.5),b="rel"+_Ge;_Ge++;const T=i.append("text").attr("class","req relationshipLabel").attr("id",b).attr("x",v.x).attr("y",v.y).attr("text-anchor","middle").attr("dominant-baseline","middle").text(d).node().getBBox();i.insert("rect","#"+b).attr("class","req reqLabelBox").attr("x",v.x-T.width/2).attr("y",v.y-T.height/2).attr("width",T.width).attr("height",T.height).attr("fill","white").attr("fill-opacity","85%")},grn=function(i,s,u,d,p){const v=u.edge(WD(s.src),WD(s.dst)),b=k7().x(function(T){return T.x}).y(function(T){return T.y}),y=i.insert("path","#"+d).attr("class","er relationshipLine").attr("d",b(v.points)).attr("fill","none");s.type==p.db.Relationships.CONTAINS?y.attr("marker-start","url("+ci.getUrl(Tf.arrowMarkerAbsolute)+"#"+s.type+"_line_ending)"):(y.attr("stroke-dasharray","10,7"),y.attr("marker-end","url("+ci.getUrl(Tf.arrowMarkerAbsolute)+"#"+SGe.ReqMarkers.ARROW+"_line_ending)")),drn(i,y,Tf,`<<${s.type}>>`)},prn=(i,s,u)=>{Object.keys(i).forEach(d=>{let p=i[d];d=WD(d),Xe.info("Added new requirement: ",d);const v=u.append("g").attr("id",d),b="req-"+d,y=AGe(v,b);let T=LGe(v,d+"_title",[`<<${p.type}>>`,`${p.name}`]);MGe(v,d+"_body",[`Id: ${p.id}`,`Text: ${p.text}`,`Risk: ${p.risk}`,`Verification: ${p.verifyMethod}`],T.y);const _=y.node().getBBox();s.setNode(d,{width:_.width,height:_.height,shape:"rect",id:d})})},brn=(i,s,u)=>{Object.keys(i).forEach(d=>{let p=i[d];const v=WD(d),b=u.append("g").attr("id",v),y="element-"+v,T=AGe(b,y);let _=LGe(b,y+"_title",["<>",`${d}`]);MGe(b,y+"_body",[`Type: ${p.type||"Not Specified"}`,`Doc Ref: ${p.docRef||"None"}`],_.y);const A=T.node().getBBox();s.setNode(v,{width:A.width,height:A.height,shape:"rect",id:v})})},mrn=(i,s)=>(i.forEach(function(u){let d=WD(u.src),p=WD(u.dst);s.setEdge(d,p,{relationship:u})}),i),vrn=function(i,s){s.nodes().forEach(function(u){u!==void 0&&s.node(u)!==void 0&&(i.select("#"+u),i.select("#"+u).attr("transform","translate("+(s.node(u).x-s.node(u).width/2)+","+(s.node(u).y-s.node(u).height/2)+" )"))})},WD=i=>i.replace(/\s/g,"").replace(/\./g,"_"),wrn=Object.freeze(Object.defineProperty({__proto__:null,diagram:{parser:lrn,db:hrn,renderer:{draw:(i,s,u,d)=>{Tf=qt().requirement;const p=Tf.securityLevel;let v;p==="sandbox"&&(v=Ir("#i"+s));const y=Ir(p==="sandbox"?v.nodes()[0].contentDocument.body:"body").select(`[id='${s}']`);SGe.insertLineEndings(y,Tf);const T=new B0({multigraph:!1,compound:!1,directed:!0}).setGraph({rankdir:Tf.layoutDirection,marginx:20,marginy:20,nodesep:100,edgesep:100,ranksep:100}).setDefaultEdgeLabel(function(){return{}});let _=d.db.getRequirements(),A=d.db.getElements(),P=d.db.getRelationships();prn(_,T,y),brn(A,T,y),mrn(P,T),qD(T),vrn(y,T),P.forEach(function(ee){grn(y,ee,T,s,d)});const R=Tf.rect_padding,F=y.node().getBBox(),j=F.width+R*2,K=F.height+R*2;Ng(y,K,j,Tf.useMaxWidth),y.attr("viewBox",`${F.x-R} ${F.y-R} ${j} ${K}`)}},styles:frn}},Symbol.toStringTag,{value:"Module"}));var yve=function(){var i=function(xt,Pt,Qe,Dt){for(Qe=Qe||{},Dt=xt.length;Dt--;Qe[xt[Dt]]=Pt);return Qe},s=[1,2],u=[1,3],d=[1,4],p=[2,4],v=[1,9],b=[1,11],y=[1,13],T=[1,14],_=[1,16],A=[1,17],P=[1,18],R=[1,24],F=[1,25],j=[1,26],K=[1,27],ee=[1,28],ie=[1,29],oe=[1,30],pe=[1,31],be=[1,32],ae=[1,33],ne=[1,34],se=[1,35],de=[1,36],X=[1,37],ge=[1,38],W=[1,39],xe=[1,41],U=[1,42],Fe=[1,43],Pe=[1,44],je=[1,45],Ie=[1,46],Se=[1,4,5,13,14,16,18,21,23,29,30,31,33,35,36,37,38,39,41,43,44,46,47,48,49,50,52,53,54,59,60,61,62,70],Ce=[4,5,16,50,52,53],ke=[4,5,13,14,16,18,21,23,29,30,31,33,35,36,37,38,39,41,43,44,46,50,52,53,54,59,60,61,62,70],Ke=[4,5,13,14,16,18,21,23,29,30,31,33,35,36,37,38,39,41,43,44,46,49,50,52,53,54,59,60,61,62,70],Ft=[4,5,13,14,16,18,21,23,29,30,31,33,35,36,37,38,39,41,43,44,46,48,50,52,53,54,59,60,61,62,70],Ne=[4,5,13,14,16,18,21,23,29,30,31,33,35,36,37,38,39,41,43,44,46,47,50,52,53,54,59,60,61,62,70],gn=[68,69,70],_t=[1,120],Et={trace:function(){},yy:{},symbols_:{error:2,start:3,SPACE:4,NEWLINE:5,SD:6,document:7,line:8,statement:9,box_section:10,box_line:11,participant_statement:12,create:13,box:14,restOfLine:15,end:16,signal:17,autonumber:18,NUM:19,off:20,activate:21,actor:22,deactivate:23,note_statement:24,links_statement:25,link_statement:26,properties_statement:27,details_statement:28,title:29,legacy_title:30,acc_title:31,acc_title_value:32,acc_descr:33,acc_descr_value:34,acc_descr_multiline_value:35,loop:36,rect:37,opt:38,alt:39,else_sections:40,par:41,par_sections:42,par_over:43,critical:44,option_sections:45,break:46,option:47,and:48,else:49,participant:50,AS:51,participant_actor:52,destroy:53,note:54,placement:55,text2:56,over:57,actor_pair:58,links:59,link:60,properties:61,details:62,spaceList:63,",":64,left_of:65,right_of:66,signaltype:67,"+":68,"-":69,ACTOR:70,SOLID_OPEN_ARROW:71,DOTTED_OPEN_ARROW:72,SOLID_ARROW:73,DOTTED_ARROW:74,SOLID_CROSS:75,DOTTED_CROSS:76,SOLID_POINT:77,DOTTED_POINT:78,TXT:79,$accept:0,$end:1},terminals_:{2:"error",4:"SPACE",5:"NEWLINE",6:"SD",13:"create",14:"box",15:"restOfLine",16:"end",18:"autonumber",19:"NUM",20:"off",21:"activate",23:"deactivate",29:"title",30:"legacy_title",31:"acc_title",32:"acc_title_value",33:"acc_descr",34:"acc_descr_value",35:"acc_descr_multiline_value",36:"loop",37:"rect",38:"opt",39:"alt",41:"par",43:"par_over",44:"critical",46:"break",47:"option",48:"and",49:"else",50:"participant",51:"AS",52:"participant_actor",53:"destroy",54:"note",57:"over",59:"links",60:"link",61:"properties",62:"details",64:",",65:"left_of",66:"right_of",68:"+",69:"-",70:"ACTOR",71:"SOLID_OPEN_ARROW",72:"DOTTED_OPEN_ARROW",73:"SOLID_ARROW",74:"DOTTED_ARROW",75:"SOLID_CROSS",76:"DOTTED_CROSS",77:"SOLID_POINT",78:"DOTTED_POINT",79:"TXT"},productions_:[0,[3,2],[3,2],[3,2],[7,0],[7,2],[8,2],[8,1],[8,1],[10,0],[10,2],[11,2],[11,1],[11,1],[9,1],[9,2],[9,4],[9,2],[9,4],[9,3],[9,3],[9,2],[9,3],[9,3],[9,2],[9,2],[9,2],[9,2],[9,2],[9,1],[9,1],[9,2],[9,2],[9,1],[9,4],[9,4],[9,4],[9,4],[9,4],[9,4],[9,4],[9,4],[45,1],[45,4],[42,1],[42,4],[40,1],[40,4],[12,5],[12,3],[12,5],[12,3],[12,3],[24,4],[24,4],[25,3],[26,3],[27,3],[28,3],[63,2],[63,1],[58,3],[58,1],[55,1],[55,1],[17,5],[17,5],[17,4],[22,1],[67,1],[67,1],[67,1],[67,1],[67,1],[67,1],[67,1],[67,1],[56,1]],performAction:function(Pt,Qe,Dt,kt,On,ht,zr){var yt=ht.length-1;switch(On){case 3:return kt.apply(ht[yt]),ht[yt];case 4:case 9:this.$=[];break;case 5:case 10:ht[yt-1].push(ht[yt]),this.$=ht[yt-1];break;case 6:case 7:case 11:case 12:this.$=ht[yt];break;case 8:case 13:this.$=[];break;case 15:ht[yt].type="createParticipant",this.$=ht[yt];break;case 16:ht[yt-1].unshift({type:"boxStart",boxData:kt.parseBoxData(ht[yt-2])}),ht[yt-1].push({type:"boxEnd",boxText:ht[yt-2]}),this.$=ht[yt-1];break;case 18:this.$={type:"sequenceIndex",sequenceIndex:Number(ht[yt-2]),sequenceIndexStep:Number(ht[yt-1]),sequenceVisible:!0,signalType:kt.LINETYPE.AUTONUMBER};break;case 19:this.$={type:"sequenceIndex",sequenceIndex:Number(ht[yt-1]),sequenceIndexStep:1,sequenceVisible:!0,signalType:kt.LINETYPE.AUTONUMBER};break;case 20:this.$={type:"sequenceIndex",sequenceVisible:!1,signalType:kt.LINETYPE.AUTONUMBER};break;case 21:this.$={type:"sequenceIndex",sequenceVisible:!0,signalType:kt.LINETYPE.AUTONUMBER};break;case 22:this.$={type:"activeStart",signalType:kt.LINETYPE.ACTIVE_START,actor:ht[yt-1]};break;case 23:this.$={type:"activeEnd",signalType:kt.LINETYPE.ACTIVE_END,actor:ht[yt-1]};break;case 29:kt.setDiagramTitle(ht[yt].substring(6)),this.$=ht[yt].substring(6);break;case 30:kt.setDiagramTitle(ht[yt].substring(7)),this.$=ht[yt].substring(7);break;case 31:this.$=ht[yt].trim(),kt.setAccTitle(this.$);break;case 32:case 33:this.$=ht[yt].trim(),kt.setAccDescription(this.$);break;case 34:ht[yt-1].unshift({type:"loopStart",loopText:kt.parseMessage(ht[yt-2]),signalType:kt.LINETYPE.LOOP_START}),ht[yt-1].push({type:"loopEnd",loopText:ht[yt-2],signalType:kt.LINETYPE.LOOP_END}),this.$=ht[yt-1];break;case 35:ht[yt-1].unshift({type:"rectStart",color:kt.parseMessage(ht[yt-2]),signalType:kt.LINETYPE.RECT_START}),ht[yt-1].push({type:"rectEnd",color:kt.parseMessage(ht[yt-2]),signalType:kt.LINETYPE.RECT_END}),this.$=ht[yt-1];break;case 36:ht[yt-1].unshift({type:"optStart",optText:kt.parseMessage(ht[yt-2]),signalType:kt.LINETYPE.OPT_START}),ht[yt-1].push({type:"optEnd",optText:kt.parseMessage(ht[yt-2]),signalType:kt.LINETYPE.OPT_END}),this.$=ht[yt-1];break;case 37:ht[yt-1].unshift({type:"altStart",altText:kt.parseMessage(ht[yt-2]),signalType:kt.LINETYPE.ALT_START}),ht[yt-1].push({type:"altEnd",signalType:kt.LINETYPE.ALT_END}),this.$=ht[yt-1];break;case 38:ht[yt-1].unshift({type:"parStart",parText:kt.parseMessage(ht[yt-2]),signalType:kt.LINETYPE.PAR_START}),ht[yt-1].push({type:"parEnd",signalType:kt.LINETYPE.PAR_END}),this.$=ht[yt-1];break;case 39:ht[yt-1].unshift({type:"parStart",parText:kt.parseMessage(ht[yt-2]),signalType:kt.LINETYPE.PAR_OVER_START}),ht[yt-1].push({type:"parEnd",signalType:kt.LINETYPE.PAR_END}),this.$=ht[yt-1];break;case 40:ht[yt-1].unshift({type:"criticalStart",criticalText:kt.parseMessage(ht[yt-2]),signalType:kt.LINETYPE.CRITICAL_START}),ht[yt-1].push({type:"criticalEnd",signalType:kt.LINETYPE.CRITICAL_END}),this.$=ht[yt-1];break;case 41:ht[yt-1].unshift({type:"breakStart",breakText:kt.parseMessage(ht[yt-2]),signalType:kt.LINETYPE.BREAK_START}),ht[yt-1].push({type:"breakEnd",optText:kt.parseMessage(ht[yt-2]),signalType:kt.LINETYPE.BREAK_END}),this.$=ht[yt-1];break;case 43:this.$=ht[yt-3].concat([{type:"option",optionText:kt.parseMessage(ht[yt-1]),signalType:kt.LINETYPE.CRITICAL_OPTION},ht[yt]]);break;case 45:this.$=ht[yt-3].concat([{type:"and",parText:kt.parseMessage(ht[yt-1]),signalType:kt.LINETYPE.PAR_AND},ht[yt]]);break;case 47:this.$=ht[yt-3].concat([{type:"else",altText:kt.parseMessage(ht[yt-1]),signalType:kt.LINETYPE.ALT_ELSE},ht[yt]]);break;case 48:ht[yt-3].draw="participant",ht[yt-3].type="addParticipant",ht[yt-3].description=kt.parseMessage(ht[yt-1]),this.$=ht[yt-3];break;case 49:ht[yt-1].draw="participant",ht[yt-1].type="addParticipant",this.$=ht[yt-1];break;case 50:ht[yt-3].draw="actor",ht[yt-3].type="addParticipant",ht[yt-3].description=kt.parseMessage(ht[yt-1]),this.$=ht[yt-3];break;case 51:ht[yt-1].draw="actor",ht[yt-1].type="addParticipant",this.$=ht[yt-1];break;case 52:ht[yt-1].type="destroyParticipant",this.$=ht[yt-1];break;case 53:this.$=[ht[yt-1],{type:"addNote",placement:ht[yt-2],actor:ht[yt-1].actor,text:ht[yt]}];break;case 54:ht[yt-2]=[].concat(ht[yt-1],ht[yt-1]).slice(0,2),ht[yt-2][0]=ht[yt-2][0].actor,ht[yt-2][1]=ht[yt-2][1].actor,this.$=[ht[yt-1],{type:"addNote",placement:kt.PLACEMENT.OVER,actor:ht[yt-2].slice(0,2),text:ht[yt]}];break;case 55:this.$=[ht[yt-1],{type:"addLinks",actor:ht[yt-1].actor,text:ht[yt]}];break;case 56:this.$=[ht[yt-1],{type:"addALink",actor:ht[yt-1].actor,text:ht[yt]}];break;case 57:this.$=[ht[yt-1],{type:"addProperties",actor:ht[yt-1].actor,text:ht[yt]}];break;case 58:this.$=[ht[yt-1],{type:"addDetails",actor:ht[yt-1].actor,text:ht[yt]}];break;case 61:this.$=[ht[yt-2],ht[yt]];break;case 62:this.$=ht[yt];break;case 63:this.$=kt.PLACEMENT.LEFTOF;break;case 64:this.$=kt.PLACEMENT.RIGHTOF;break;case 65:this.$=[ht[yt-4],ht[yt-1],{type:"addMessage",from:ht[yt-4].actor,to:ht[yt-1].actor,signalType:ht[yt-3],msg:ht[yt],activate:!0},{type:"activeStart",signalType:kt.LINETYPE.ACTIVE_START,actor:ht[yt-1]}];break;case 66:this.$=[ht[yt-4],ht[yt-1],{type:"addMessage",from:ht[yt-4].actor,to:ht[yt-1].actor,signalType:ht[yt-3],msg:ht[yt]},{type:"activeEnd",signalType:kt.LINETYPE.ACTIVE_END,actor:ht[yt-4]}];break;case 67:this.$=[ht[yt-3],ht[yt-1],{type:"addMessage",from:ht[yt-3].actor,to:ht[yt-1].actor,signalType:ht[yt-2],msg:ht[yt]}];break;case 68:this.$={type:"addParticipant",actor:ht[yt]};break;case 69:this.$=kt.LINETYPE.SOLID_OPEN;break;case 70:this.$=kt.LINETYPE.DOTTED_OPEN;break;case 71:this.$=kt.LINETYPE.SOLID;break;case 72:this.$=kt.LINETYPE.DOTTED;break;case 73:this.$=kt.LINETYPE.SOLID_CROSS;break;case 74:this.$=kt.LINETYPE.DOTTED_CROSS;break;case 75:this.$=kt.LINETYPE.SOLID_POINT;break;case 76:this.$=kt.LINETYPE.DOTTED_POINT;break;case 77:this.$=kt.parseMessage(ht[yt].trim().substring(1));break}},table:[{3:1,4:s,5:u,6:d},{1:[3]},{3:5,4:s,5:u,6:d},{3:6,4:s,5:u,6:d},i([1,4,5,13,14,18,21,23,29,30,31,33,35,36,37,38,39,41,43,44,46,50,52,53,54,59,60,61,62,70],p,{7:7}),{1:[2,1]},{1:[2,2]},{1:[2,3],4:v,5:b,8:8,9:10,12:12,13:y,14:T,17:15,18:_,21:A,22:40,23:P,24:19,25:20,26:21,27:22,28:23,29:R,30:F,31:j,33:K,35:ee,36:ie,37:oe,38:pe,39:be,41:ae,43:ne,44:se,46:de,50:X,52:ge,53:W,54:xe,59:U,60:Fe,61:Pe,62:je,70:Ie},i(Se,[2,5]),{9:47,12:12,13:y,14:T,17:15,18:_,21:A,22:40,23:P,24:19,25:20,26:21,27:22,28:23,29:R,30:F,31:j,33:K,35:ee,36:ie,37:oe,38:pe,39:be,41:ae,43:ne,44:se,46:de,50:X,52:ge,53:W,54:xe,59:U,60:Fe,61:Pe,62:je,70:Ie},i(Se,[2,7]),i(Se,[2,8]),i(Se,[2,14]),{12:48,50:X,52:ge,53:W},{15:[1,49]},{5:[1,50]},{5:[1,53],19:[1,51],20:[1,52]},{22:54,70:Ie},{22:55,70:Ie},{5:[1,56]},{5:[1,57]},{5:[1,58]},{5:[1,59]},{5:[1,60]},i(Se,[2,29]),i(Se,[2,30]),{32:[1,61]},{34:[1,62]},i(Se,[2,33]),{15:[1,63]},{15:[1,64]},{15:[1,65]},{15:[1,66]},{15:[1,67]},{15:[1,68]},{15:[1,69]},{15:[1,70]},{22:71,70:Ie},{22:72,70:Ie},{22:73,70:Ie},{67:74,71:[1,75],72:[1,76],73:[1,77],74:[1,78],75:[1,79],76:[1,80],77:[1,81],78:[1,82]},{55:83,57:[1,84],65:[1,85],66:[1,86]},{22:87,70:Ie},{22:88,70:Ie},{22:89,70:Ie},{22:90,70:Ie},i([5,51,64,71,72,73,74,75,76,77,78,79],[2,68]),i(Se,[2,6]),i(Se,[2,15]),i(Ce,[2,9],{10:91}),i(Se,[2,17]),{5:[1,93],19:[1,92]},{5:[1,94]},i(Se,[2,21]),{5:[1,95]},{5:[1,96]},i(Se,[2,24]),i(Se,[2,25]),i(Se,[2,26]),i(Se,[2,27]),i(Se,[2,28]),i(Se,[2,31]),i(Se,[2,32]),i(ke,p,{7:97}),i(ke,p,{7:98}),i(ke,p,{7:99}),i(Ke,p,{40:100,7:101}),i(Ft,p,{42:102,7:103}),i(Ft,p,{7:103,42:104}),i(Ne,p,{45:105,7:106}),i(ke,p,{7:107}),{5:[1,109],51:[1,108]},{5:[1,111],51:[1,110]},{5:[1,112]},{22:115,68:[1,113],69:[1,114],70:Ie},i(gn,[2,69]),i(gn,[2,70]),i(gn,[2,71]),i(gn,[2,72]),i(gn,[2,73]),i(gn,[2,74]),i(gn,[2,75]),i(gn,[2,76]),{22:116,70:Ie},{22:118,58:117,70:Ie},{70:[2,63]},{70:[2,64]},{56:119,79:_t},{56:121,79:_t},{56:122,79:_t},{56:123,79:_t},{4:[1,126],5:[1,128],11:125,12:127,16:[1,124],50:X,52:ge,53:W},{5:[1,129]},i(Se,[2,19]),i(Se,[2,20]),i(Se,[2,22]),i(Se,[2,23]),{4:v,5:b,8:8,9:10,12:12,13:y,14:T,16:[1,130],17:15,18:_,21:A,22:40,23:P,24:19,25:20,26:21,27:22,28:23,29:R,30:F,31:j,33:K,35:ee,36:ie,37:oe,38:pe,39:be,41:ae,43:ne,44:se,46:de,50:X,52:ge,53:W,54:xe,59:U,60:Fe,61:Pe,62:je,70:Ie},{4:v,5:b,8:8,9:10,12:12,13:y,14:T,16:[1,131],17:15,18:_,21:A,22:40,23:P,24:19,25:20,26:21,27:22,28:23,29:R,30:F,31:j,33:K,35:ee,36:ie,37:oe,38:pe,39:be,41:ae,43:ne,44:se,46:de,50:X,52:ge,53:W,54:xe,59:U,60:Fe,61:Pe,62:je,70:Ie},{4:v,5:b,8:8,9:10,12:12,13:y,14:T,16:[1,132],17:15,18:_,21:A,22:40,23:P,24:19,25:20,26:21,27:22,28:23,29:R,30:F,31:j,33:K,35:ee,36:ie,37:oe,38:pe,39:be,41:ae,43:ne,44:se,46:de,50:X,52:ge,53:W,54:xe,59:U,60:Fe,61:Pe,62:je,70:Ie},{16:[1,133]},{4:v,5:b,8:8,9:10,12:12,13:y,14:T,16:[2,46],17:15,18:_,21:A,22:40,23:P,24:19,25:20,26:21,27:22,28:23,29:R,30:F,31:j,33:K,35:ee,36:ie,37:oe,38:pe,39:be,41:ae,43:ne,44:se,46:de,49:[1,134],50:X,52:ge,53:W,54:xe,59:U,60:Fe,61:Pe,62:je,70:Ie},{16:[1,135]},{4:v,5:b,8:8,9:10,12:12,13:y,14:T,16:[2,44],17:15,18:_,21:A,22:40,23:P,24:19,25:20,26:21,27:22,28:23,29:R,30:F,31:j,33:K,35:ee,36:ie,37:oe,38:pe,39:be,41:ae,43:ne,44:se,46:de,48:[1,136],50:X,52:ge,53:W,54:xe,59:U,60:Fe,61:Pe,62:je,70:Ie},{16:[1,137]},{16:[1,138]},{4:v,5:b,8:8,9:10,12:12,13:y,14:T,16:[2,42],17:15,18:_,21:A,22:40,23:P,24:19,25:20,26:21,27:22,28:23,29:R,30:F,31:j,33:K,35:ee,36:ie,37:oe,38:pe,39:be,41:ae,43:ne,44:se,46:de,47:[1,139],50:X,52:ge,53:W,54:xe,59:U,60:Fe,61:Pe,62:je,70:Ie},{4:v,5:b,8:8,9:10,12:12,13:y,14:T,16:[1,140],17:15,18:_,21:A,22:40,23:P,24:19,25:20,26:21,27:22,28:23,29:R,30:F,31:j,33:K,35:ee,36:ie,37:oe,38:pe,39:be,41:ae,43:ne,44:se,46:de,50:X,52:ge,53:W,54:xe,59:U,60:Fe,61:Pe,62:je,70:Ie},{15:[1,141]},i(Se,[2,49]),{15:[1,142]},i(Se,[2,51]),i(Se,[2,52]),{22:143,70:Ie},{22:144,70:Ie},{56:145,79:_t},{56:146,79:_t},{56:147,79:_t},{64:[1,148],79:[2,62]},{5:[2,55]},{5:[2,77]},{5:[2,56]},{5:[2,57]},{5:[2,58]},i(Se,[2,16]),i(Ce,[2,10]),{12:149,50:X,52:ge,53:W},i(Ce,[2,12]),i(Ce,[2,13]),i(Se,[2,18]),i(Se,[2,34]),i(Se,[2,35]),i(Se,[2,36]),i(Se,[2,37]),{15:[1,150]},i(Se,[2,38]),{15:[1,151]},i(Se,[2,39]),i(Se,[2,40]),{15:[1,152]},i(Se,[2,41]),{5:[1,153]},{5:[1,154]},{56:155,79:_t},{56:156,79:_t},{5:[2,67]},{5:[2,53]},{5:[2,54]},{22:157,70:Ie},i(Ce,[2,11]),i(Ke,p,{7:101,40:158}),i(Ft,p,{7:103,42:159}),i(Ne,p,{7:106,45:160}),i(Se,[2,48]),i(Se,[2,50]),{5:[2,65]},{5:[2,66]},{79:[2,61]},{16:[2,47]},{16:[2,45]},{16:[2,43]}],defaultActions:{5:[2,1],6:[2,2],85:[2,63],86:[2,64],119:[2,55],120:[2,77],121:[2,56],122:[2,57],123:[2,58],145:[2,67],146:[2,53],147:[2,54],155:[2,65],156:[2,66],157:[2,61],158:[2,47],159:[2,45],160:[2,43]},parseError:function(Pt,Qe){if(Qe.recoverable)this.trace(Pt);else{var Dt=new Error(Pt);throw Dt.hash=Qe,Dt}},parse:function(Pt){var Qe=this,Dt=[0],kt=[],On=[null],ht=[],zr=this.table,yt="",ji=0,xi=0,Ma=2,zs=1,ao=ht.slice.call(arguments,1),Tr=Object.create(this.lexer),Fn={yy:{}};for(var qn in this.yy)Object.prototype.hasOwnProperty.call(this.yy,qn)&&(Fn.yy[qn]=this.yy[qn]);Tr.setInput(Pt,Fn.yy),Fn.yy.lexer=Tr,Fn.yy.parser=this,typeof Tr.yylloc>"u"&&(Tr.yylloc={});var Un=Tr.yylloc;ht.push(Un);var At=Tr.options&&Tr.options.ranges;typeof Fn.yy.parseError=="function"?this.parseError=Fn.yy.parseError:this.parseError=Object.getPrototypeOf(this).parseError;function wt(){var da;return da=kt.pop()||Tr.lex()||zs,typeof da!="number"&&(da instanceof Array&&(kt=da,da=kt.pop()),da=Qe.symbols_[da]||da),da}for(var on,fn,An,oo,jo={},$o,Pa,wo,_s;;){if(fn=Dt[Dt.length-1],this.defaultActions[fn]?An=this.defaultActions[fn]:((on===null||typeof on>"u")&&(on=wt()),An=zr[fn]&&zr[fn][on]),typeof An>"u"||!An.length||!An[0]){var tl="";_s=[];for($o in zr[fn])this.terminals_[$o]&&$o>Ma&&_s.push("'"+this.terminals_[$o]+"'");Tr.showPosition?tl="Parse error on line "+(ji+1)+`: +`+Tr.showPosition()+` +Expecting `+_s.join(", ")+", got '"+(this.terminals_[on]||on)+"'":tl="Parse error on line "+(ji+1)+": Unexpected "+(on==zs?"end of input":"'"+(this.terminals_[on]||on)+"'"),this.parseError(tl,{text:Tr.match,token:this.terminals_[on]||on,line:Tr.yylineno,loc:Un,expected:_s})}if(An[0]instanceof Array&&An.length>1)throw new Error("Parse Error: multiple actions possible at state: "+fn+", token: "+on);switch(An[0]){case 1:Dt.push(on),On.push(Tr.yytext),ht.push(Tr.yylloc),Dt.push(An[1]),on=null,xi=Tr.yyleng,yt=Tr.yytext,ji=Tr.yylineno,Un=Tr.yylloc;break;case 2:if(Pa=this.productions_[An[1]][1],jo.$=On[On.length-Pa],jo._$={first_line:ht[ht.length-(Pa||1)].first_line,last_line:ht[ht.length-1].last_line,first_column:ht[ht.length-(Pa||1)].first_column,last_column:ht[ht.length-1].last_column},At&&(jo._$.range=[ht[ht.length-(Pa||1)].range[0],ht[ht.length-1].range[1]]),oo=this.performAction.apply(jo,[yt,xi,ji,Fn.yy,An[1],On,ht].concat(ao)),typeof oo<"u")return oo;Pa&&(Dt=Dt.slice(0,-1*Pa*2),On=On.slice(0,-1*Pa),ht=ht.slice(0,-1*Pa)),Dt.push(this.productions_[An[1]][0]),On.push(jo.$),ht.push(jo._$),wo=zr[Dt[Dt.length-2]][Dt[Dt.length-1]],Dt.push(wo);break;case 3:return!0}}return!0}},Gt=function(){var xt={EOF:1,parseError:function(Qe,Dt){if(this.yy.parser)this.yy.parser.parseError(Qe,Dt);else throw new Error(Qe)},setInput:function(Pt,Qe){return this.yy=Qe||this.yy||{},this._input=Pt,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},input:function(){var Pt=this._input[0];this.yytext+=Pt,this.yyleng++,this.offset++,this.match+=Pt,this.matched+=Pt;var Qe=Pt.match(/(?:\r\n?|\n).*/g);return Qe?(this.yylineno++,this.yylloc.last_line++):this.yylloc.last_column++,this.options.ranges&&this.yylloc.range[1]++,this._input=this._input.slice(1),Pt},unput:function(Pt){var Qe=Pt.length,Dt=Pt.split(/(?:\r\n?|\n)/g);this._input=Pt+this._input,this.yytext=this.yytext.substr(0,this.yytext.length-Qe),this.offset-=Qe;var kt=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),Dt.length-1&&(this.yylineno-=Dt.length-1);var On=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:Dt?(Dt.length===kt.length?this.yylloc.first_column:0)+kt[kt.length-Dt.length].length-Dt[0].length:this.yylloc.first_column-Qe},this.options.ranges&&(this.yylloc.range=[On[0],On[0]+this.yyleng-Qe]),this.yyleng=this.yytext.length,this},more:function(){return this._more=!0,this},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},less:function(Pt){this.unput(this.match.slice(Pt))},pastInput:function(){var Pt=this.matched.substr(0,this.matched.length-this.match.length);return(Pt.length>20?"...":"")+Pt.substr(-20).replace(/\n/g,"")},upcomingInput:function(){var Pt=this.match;return Pt.length<20&&(Pt+=this._input.substr(0,20-Pt.length)),(Pt.substr(0,20)+(Pt.length>20?"...":"")).replace(/\n/g,"")},showPosition:function(){var Pt=this.pastInput(),Qe=new Array(Pt.length+1).join("-");return Pt+this.upcomingInput()+` +`+Qe+"^"},test_match:function(Pt,Qe){var Dt,kt,On;if(this.options.backtrack_lexer&&(On={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&&(On.yylloc.range=this.yylloc.range.slice(0))),kt=Pt[0].match(/(?:\r\n?|\n).*/g),kt&&(this.yylineno+=kt.length),this.yylloc={first_line:this.yylloc.last_line,last_line:this.yylineno+1,first_column:this.yylloc.last_column,last_column:kt?kt[kt.length-1].length-kt[kt.length-1].match(/\r?\n?/)[0].length:this.yylloc.last_column+Pt[0].length},this.yytext+=Pt[0],this.match+=Pt[0],this.matches=Pt,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(Pt[0].length),this.matched+=Pt[0],Dt=this.performAction.call(this,this.yy,this,Qe,this.conditionStack[this.conditionStack.length-1]),this.done&&this._input&&(this.done=!1),Dt)return Dt;if(this._backtrack){for(var ht in On)this[ht]=On[ht];return!1}return!1},next:function(){if(this.done)return this.EOF;this._input||(this.done=!0);var Pt,Qe,Dt,kt;this._more||(this.yytext="",this.match="");for(var On=this._currentRules(),ht=0;htQe[0].length)){if(Qe=Dt,kt=ht,this.options.backtrack_lexer){if(Pt=this.test_match(Dt,On[ht]),Pt!==!1)return Pt;if(this._backtrack){Qe=!1;continue}else return!1}else if(!this.options.flex)break}return Qe?(Pt=this.test_match(Qe,On[kt]),Pt!==!1?Pt:!1):this._input===""?this.EOF:this.parseError("Lexical error on line "+(this.yylineno+1)+`. Unrecognized text. +`+this.showPosition(),{text:"",token:null,line:this.yylineno})},lex:function(){var Qe=this.next();return Qe||this.lex()},begin:function(Qe){this.conditionStack.push(Qe)},popState:function(){var Qe=this.conditionStack.length-1;return Qe>0?this.conditionStack.pop():this.conditionStack[0]},_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},topState:function(Qe){return Qe=this.conditionStack.length-1-Math.abs(Qe||0),Qe>=0?this.conditionStack[Qe]:"INITIAL"},pushState:function(Qe){this.begin(Qe)},stateStackSize:function(){return this.conditionStack.length},options:{"case-insensitive":!0},performAction:function(Qe,Dt,kt,On){switch(kt){case 0:return 5;case 1:break;case 2:break;case 3:break;case 4:break;case 5:break;case 6:return 19;case 7:return this.begin("LINE"),14;case 8:return this.begin("ID"),50;case 9:return this.begin("ID"),52;case 10:return 13;case 11:return this.begin("ID"),53;case 12:return Dt.yytext=Dt.yytext.trim(),this.begin("ALIAS"),70;case 13:return this.popState(),this.popState(),this.begin("LINE"),51;case 14:return this.popState(),this.popState(),5;case 15:return this.begin("LINE"),36;case 16:return this.begin("LINE"),37;case 17:return this.begin("LINE"),38;case 18:return this.begin("LINE"),39;case 19:return this.begin("LINE"),49;case 20:return this.begin("LINE"),41;case 21:return this.begin("LINE"),43;case 22:return this.begin("LINE"),48;case 23:return this.begin("LINE"),44;case 24:return this.begin("LINE"),47;case 25:return this.begin("LINE"),46;case 26:return this.popState(),15;case 27:return 16;case 28:return 65;case 29:return 66;case 30:return 59;case 31:return 60;case 32:return 61;case 33:return 62;case 34:return 57;case 35:return 54;case 36:return this.begin("ID"),21;case 37:return this.begin("ID"),23;case 38:return 29;case 39:return 30;case 40:return this.begin("acc_title"),31;case 41:return this.popState(),"acc_title_value";case 42:return this.begin("acc_descr"),33;case 43:return this.popState(),"acc_descr_value";case 44:this.begin("acc_descr_multiline");break;case 45:this.popState();break;case 46:return"acc_descr_multiline_value";case 47:return 6;case 48:return 18;case 49:return 20;case 50:return 64;case 51:return 5;case 52:return Dt.yytext=Dt.yytext.trim(),70;case 53:return 73;case 54:return 74;case 55:return 71;case 56:return 72;case 57:return 75;case 58:return 76;case 59:return 77;case 60:return 78;case 61:return 79;case 62:return 68;case 63:return 69;case 64:return 5;case 65:return"INVALID"}},rules:[/^(?:[\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,/^(?:create\b)/i,/^(?:destroy\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,/^(?:par_over\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:[45,46],inclusive:!1},acc_descr:{rules:[43],inclusive:!1},acc_title:{rules:[41],inclusive:!1},ID:{rules:[2,3,12],inclusive:!1},ALIAS:{rules:[2,3,13,14],inclusive:!1},LINE:{rules:[2,3,26],inclusive:!1},INITIAL:{rules:[0,1,3,4,5,6,7,8,9,10,11,15,16,17,18,19,20,21,22,23,24,25,27,28,29,30,31,32,33,34,35,36,37,38,39,40,42,44,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65],inclusive:!0}}};return xt}();Et.lexer=Gt;function ln(){this.yy={}}return ln.prototype=Et,Et.Parser=ln,new ln}();yve.parser=yve;const yrn=yve;class xrn{constructor(s){this.init=s,this.records=this.init()}reset(){this.records=this.init()}}const Ds=new xrn(()=>({prevActor:void 0,actors:{},createdActors:{},destroyedActors:{},boxes:[],messages:[],notes:[],sequenceNumbersEnabled:!1,wrapEnabled:void 0,currentBox:void 0,lastCreated:void 0,lastDestroyed:void 0})),krn=function(i){Ds.records.boxes.push({name:i.text,wrap:i.wrap===void 0&&JC()||!!i.wrap,fill:i.color,actorKeys:[]}),Ds.records.currentBox=Ds.records.boxes.slice(-1)[0]},xve=function(i,s,u,d){let p=Ds.records.currentBox;const v=Ds.records.actors[i];if(v){if(Ds.records.currentBox&&v.box&&Ds.records.currentBox!==v.box)throw new Error("A same participant should only be defined in one Box: "+v.name+" can't be in '"+v.box.name+"' and in '"+Ds.records.currentBox.name+"' at the same time.");if(p=v.box?v.box:Ds.records.currentBox,v.box=p,v&&s===v.name&&u==null)return}(u==null||u.text==null)&&(u={text:s,wrap:null,type:d}),(d==null||u.text==null)&&(u={text:s,wrap:null,type:d}),Ds.records.actors[i]={box:p,name:s,description:u.text,wrap:u.wrap===void 0&&JC()||!!u.wrap,prevActor:Ds.records.prevActor,links:{},properties:{},actorCnt:null,rectData:null,type:d||"participant"},Ds.records.prevActor&&Ds.records.actors[Ds.records.prevActor]&&(Ds.records.actors[Ds.records.prevActor].nextActor=i),Ds.records.currentBox&&Ds.records.currentBox.actorKeys.push(i),Ds.records.prevActor=i},Ern=i=>{let s,u=0;for(s=0;s>-",token:"->>-",line:"1",loc:{first_line:1,last_line:1,first_column:1,last_column:1},expected:["'ACTIVE_PARTICIPANT'"]},b}return Ds.records.messages.push({from:i,to:s,message:u.text,wrap:u.wrap===void 0&&JC()||!!u.wrap,type:d,activate:p}),!0},Crn=function(){return Ds.records.boxes.length>0},Srn=function(){return Ds.records.boxes.some(i=>i.name)},_rn=function(){return Ds.records.messages},Arn=function(){return Ds.records.boxes},Lrn=function(){return Ds.records.actors},Mrn=function(){return Ds.records.createdActors},Drn=function(){return Ds.records.destroyedActors},GR=function(i){return Ds.records.actors[i]},Irn=function(){return Object.keys(Ds.records.actors)},Orn=function(){Ds.records.sequenceNumbersEnabled=!0},Nrn=function(){Ds.records.sequenceNumbersEnabled=!1},Prn=()=>Ds.records.sequenceNumbersEnabled,Brn=function(i){Ds.records.wrapEnabled=i},JC=()=>Ds.records.wrapEnabled!==void 0?Ds.records.wrapEnabled:qt().sequence.wrap,Frn=function(){Ds.reset(),Pg()},Rrn=function(i){const s=i.trim(),u={text:s.replace(/^:?(?:no)?wrap:/,"").trim(),wrap:s.match(/^:?wrap:/)!==null?!0:s.match(/^:?nowrap:/)!==null?!1:void 0};return Xe.debug("parseMessage:",u),u},jrn=function(i){const s=i.match(/^((?:rgba?|hsla?)\s*\(.*\)|\w*)(.*)$/);let u=s!=null&&s[1]?s[1].trim():"transparent",d=s!=null&&s[2]?s[2].trim():void 0;if(window&&window.CSS)window.CSS.supports("color",u)||(u="transparent",d=i.trim());else{const p=new Option().style;p.color=u,p.color!==u&&(u="transparent",d=i.trim())}return{color:u,text:d!==void 0?Yf(d.replace(/^:?(?:no)?wrap:/,""),qt()):void 0,wrap:d!==void 0?d.match(/^:?wrap:/)!==null?!0:d.match(/^:?nowrap:/)!==null?!1:void 0:void 0}},KR={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,PAR_OVER_START:32},$rn={FILLED:0,OPEN:1},zrn={LEFTOF:0,RIGHTOF:1,OVER:2},DGe=function(i,s,u){const d={actor:i,placement:s,message:u.text,wrap:u.wrap===void 0&&JC()||!!u.wrap},p=[].concat(i,i);Ds.records.notes.push(d),Ds.records.messages.push({from:p[0],to:p[1],message:u.text,wrap:u.wrap===void 0&&JC()||!!u.wrap,type:KR.NOTE,placement:s})},IGe=function(i,s){const u=GR(i);try{let d=Yf(s.text,qt());d=d.replace(/&/g,"&"),d=d.replace(/=/g,"=");const p=JSON.parse(d);kve(u,p)}catch(d){Xe.error("error while parsing actor link text",d)}},qrn=function(i,s){const u=GR(i);try{const b={};let y=Yf(s.text,qt());var d=y.indexOf("@");y=y.replace(/&/g,"&"),y=y.replace(/=/g,"=");var p=y.slice(0,d-1).trim(),v=y.slice(d+1).trim();b[p]=v,kve(u,b)}catch(b){Xe.error("error while parsing actor link text",b)}};function kve(i,s){if(i.links==null)i.links=s;else for(let u in s)i.links[u]=s[u]}const OGe=function(i,s){const u=GR(i);try{let d=Yf(s.text,qt());const p=JSON.parse(d);NGe(u,p)}catch(d){Xe.error("error while parsing actor properties text",d)}};function NGe(i,s){if(i.properties==null)i.properties=s;else for(let u in s)i.properties[u]=s[u]}function Hrn(){Ds.records.currentBox=void 0}const PGe=function(i,s){const u=GR(i),d=document.getElementById(s.text);try{const p=d.innerHTML,v=JSON.parse(p);v.properties&&NGe(u,v.properties),v.links&&kve(u,v.links)}catch(p){Xe.error("error while parsing actor details text",p)}},Vrn=function(i,s){if(i!==void 0&&i.properties!==void 0)return i.properties[s]},BGe=function(i){if(Array.isArray(i))i.forEach(function(s){BGe(s)});else switch(i.type){case"sequenceIndex":Ds.records.messages.push({from:void 0,to:void 0,message:{start:i.sequenceIndex,step:i.sequenceIndexStep,visible:i.sequenceVisible},wrap:!1,type:i.signalType});break;case"addParticipant":xve(i.actor,i.actor,i.description,i.draw);break;case"createParticipant":if(Ds.records.actors[i.actor])throw new Error("It is not possible to have actors with the same id, even if one is destroyed before the next is created. Use 'AS' aliases to simulate the behavior");Ds.records.lastCreated=i.actor,xve(i.actor,i.actor,i.description,i.draw),Ds.records.createdActors[i.actor]=Ds.records.messages.length;break;case"destroyParticipant":Ds.records.lastDestroyed=i.actor,Ds.records.destroyedActors[i.actor]=Ds.records.messages.length;break;case"activeStart":Jf(i.actor,void 0,void 0,i.signalType);break;case"activeEnd":Jf(i.actor,void 0,void 0,i.signalType);break;case"addNote":DGe(i.actor,i.placement,i.text);break;case"addLinks":IGe(i.actor,i.text);break;case"addALink":qrn(i.actor,i.text);break;case"addProperties":OGe(i.actor,i.text);break;case"addDetails":PGe(i.actor,i.text);break;case"addMessage":if(Ds.records.lastCreated){if(i.to!==Ds.records.lastCreated)throw new Error("The created participant "+Ds.records.lastCreated+" does not have an associated creating message after its declaration. Please check the sequence diagram.");Ds.records.lastCreated=void 0}else if(Ds.records.lastDestroyed){if(i.to!==Ds.records.lastDestroyed&&i.from!==Ds.records.lastDestroyed)throw new Error("The destroyed participant "+Ds.records.lastDestroyed+" does not have an associated destroying message after its declaration. Please check the sequence diagram.");Ds.records.lastDestroyed=void 0}Jf(i.from,i.to,i.msg,i.signalType,i.activate);break;case"boxStart":krn(i.boxData);break;case"boxEnd":Hrn();break;case"loopStart":Jf(void 0,void 0,i.loopText,i.signalType);break;case"loopEnd":Jf(void 0,void 0,void 0,i.signalType);break;case"rectStart":Jf(void 0,void 0,i.color,i.signalType);break;case"rectEnd":Jf(void 0,void 0,void 0,i.signalType);break;case"optStart":Jf(void 0,void 0,i.optText,i.signalType);break;case"optEnd":Jf(void 0,void 0,void 0,i.signalType);break;case"altStart":Jf(void 0,void 0,i.altText,i.signalType);break;case"else":Jf(void 0,void 0,i.altText,i.signalType);break;case"altEnd":Jf(void 0,void 0,void 0,i.signalType);break;case"setAccTitle":Bg(i.text);break;case"parStart":Jf(void 0,void 0,i.parText,i.signalType);break;case"and":Jf(void 0,void 0,i.parText,i.signalType);break;case"parEnd":Jf(void 0,void 0,void 0,i.signalType);break;case"criticalStart":Jf(void 0,void 0,i.criticalText,i.signalType);break;case"option":Jf(void 0,void 0,i.optionText,i.signalType);break;case"criticalEnd":Jf(void 0,void 0,void 0,i.signalType);break;case"breakStart":Jf(void 0,void 0,i.breakText,i.signalType);break;case"breakEnd":Jf(void 0,void 0,void 0,i.signalType);break}},FGe={addActor:xve,addMessage:Trn,addSignal:Jf,addLinks:IGe,addDetails:PGe,addProperties:OGe,autoWrap:JC,setWrap:Brn,enableSequenceNumbers:Orn,disableSequenceNumbers:Nrn,showSequenceNumbers:Prn,getMessages:_rn,getActors:Lrn,getCreatedActors:Mrn,getDestroyedActors:Drn,getActor:GR,getActorKeys:Irn,getActorProperty:Vrn,getAccTitle:Cp,getBoxes:Arn,getDiagramTitle:Ap,setDiagramTitle:cm,getConfig:()=>qt().sequence,clear:Frn,parseMessage:Rrn,parseBoxData:jrn,LINETYPE:KR,ARROWTYPE:$rn,PLACEMENT:zrn,addNote:DGe,setAccTitle:Bg,apply:BGe,setAccDescription:Sp,getAccDescription:_p,hasAtLeastOneBox:Crn,hasAtLeastOneBoxWithTitle:Srn},Urn=i=>`.actor { + stroke: ${i.actorBorder}; + fill: ${i.actorBkg}; + } + + text.actor > tspan { + fill: ${i.actorTextColor}; + stroke: none; + } + + .actor-line { + stroke: ${i.actorLineColor}; + } + + .messageLine0 { + stroke-width: 1.5; + stroke-dasharray: none; + stroke: ${i.signalColor}; + } + + .messageLine1 { + stroke-width: 1.5; + stroke-dasharray: 2, 2; + stroke: ${i.signalColor}; + } + + #arrowhead path { + fill: ${i.signalColor}; + stroke: ${i.signalColor}; + } + + .sequenceNumber { + fill: ${i.sequenceNumberColor}; + } + + #sequencenumber { + fill: ${i.signalColor}; + } + + #crosshead path { + fill: ${i.signalColor}; + stroke: ${i.signalColor}; + } + + .messageText { + fill: ${i.signalTextColor}; + stroke: none; + } + + .labelBox { + stroke: ${i.labelBoxBorderColor}; + fill: ${i.labelBoxBkgColor}; + } + + .labelText, .labelText > tspan { + fill: ${i.labelTextColor}; + stroke: none; + } + + .loopText, .loopText > tspan { + fill: ${i.loopTextColor}; + stroke: none; + } + + .loopLine { + stroke-width: 2px; + stroke-dasharray: 2, 2; + stroke: ${i.labelBoxBorderColor}; + fill: ${i.labelBoxBorderColor}; + } + + .note { + //stroke: #decc93; + stroke: ${i.noteBorderColor}; + fill: ${i.noteBkgColor}; + } + + .noteText, .noteText > tspan { + fill: ${i.noteTextColor}; + stroke: none; + } + + .activation0 { + fill: ${i.activationBkgColor}; + stroke: ${i.activationBorderColor}; + } + + .activation1 { + fill: ${i.activationBkgColor}; + stroke: ${i.activationBorderColor}; + } + + .activation2 { + fill: ${i.activationBkgColor}; + stroke: ${i.activationBorderColor}; + } + + .actorPopupMenu { + position: absolute; + } + + .actorPopupMenuPanel { + position: absolute; + fill: ${i.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: ${i.actorBorder}; + fill: ${i.actorBkg}; + } + .actor-man circle, line { + stroke: ${i.actorBorder}; + fill: ${i.actorBkg}; + stroke-width: 2px; + } +`,ZC=18*2,RGe="actor-top",jGe="actor-bottom",Eve=function(i,s){return AQ(i,s)},Grn=function(i,s,u,d,p){if(s.links===void 0||s.links===null||Object.keys(s.links).length===0)return{height:0,width:0};const v=s.links,b=s.actorCnt,y=s.rectData;var T="none";p&&(T="block !important");const _=i.append("g");_.attr("id","actor"+b+"_popup"),_.attr("class","actorPopupMenu"),_.attr("display",T);var A="";y.class!==void 0&&(A=" "+y.class);let P=y.width>u?y.width:u;const R=_.append("rect");if(R.attr("class","actorPopupMenuPanel"+A),R.attr("x",y.x),R.attr("y",y.height),R.attr("fill",y.fill),R.attr("stroke",y.stroke),R.attr("width",P),R.attr("height",y.height),R.attr("rx",y.rx),R.attr("ry",y.ry),v!=null){var F=20;for(let ee in v){var j=_.append("a"),K=p9.sanitizeUrl(v[ee]);j.attr("xlink:href",K),j.attr("target","_blank"),uin(d)(ee,j,y.x+10,y.height+F,P,20,{class:"actor"},d),F+=30}}return R.attr("height",F),{height:y.height+F,width:P}},Krn=function(i){return"var pu = document.getElementById('"+i+"'); if (pu != null) { pu.style.display = pu.style.display == 'block' ? 'none' : 'block'; }"},pJ=async function(i,s,u=null){let d=i.append("foreignObject");const p=await CC(s.text,Vh()),b=d.append("xhtml:div").attr("style","width: fit-content;").attr("xmlns","http://www.w3.org/1999/xhtml").html(p).node().getBoundingClientRect();if(d.attr("height",Math.round(b.height)).attr("width",Math.round(b.width)),s.class==="noteText"){const y=i.node().firstChild;y.setAttribute("height",b.height+2*s.textMargin);const T=y.getBBox();d.attr("x",Math.round(T.x+T.width/2-b.width/2)).attr("y",Math.round(T.y+T.height/2-b.height/2))}else if(u){let{startx:y,stopx:T,starty:_}=u;if(y>T){const A=y;y=T,T=A}d.attr("x",Math.round(y+Math.abs(y-T)/2-b.width/2)),s.class==="loopText"?d.attr("y",Math.round(_)):d.attr("y",Math.round(_-b.height))}return[d]},YD=function(i,s){let u=0,d=0;const p=s.text.split(ci.lineBreakRegex),[v,b]=NC(s.fontSize);let y=[],T=0,_=()=>s.y;if(s.valign!==void 0&&s.textMargin!==void 0&&s.textMargin>0)switch(s.valign){case"top":case"start":_=()=>Math.round(s.y+s.textMargin);break;case"middle":case"center":_=()=>Math.round(s.y+(u+d+s.textMargin)/2);break;case"bottom":case"end":_=()=>Math.round(s.y+(u+d+2*s.textMargin)-s.textMargin);break}if(s.anchor!==void 0&&s.textMargin!==void 0&&s.width!==void 0)switch(s.anchor){case"left":case"start":s.x=Math.round(s.x+s.textMargin),s.anchor="start",s.dominantBaseline="middle",s.alignmentBaseline="middle";break;case"middle":case"center":s.x=Math.round(s.x+s.width/2),s.anchor="middle",s.dominantBaseline="middle",s.alignmentBaseline="middle";break;case"right":case"end":s.x=Math.round(s.x+s.width-s.textMargin),s.anchor="end",s.dominantBaseline="middle",s.alignmentBaseline="middle";break}for(let[A,P]of p.entries()){s.textMargin!==void 0&&s.textMargin===0&&v!==void 0&&(T=A*v);const R=i.append("text");R.attr("x",s.x),R.attr("y",_()),s.anchor!==void 0&&R.attr("text-anchor",s.anchor).attr("dominant-baseline",s.dominantBaseline).attr("alignment-baseline",s.alignmentBaseline),s.fontFamily!==void 0&&R.style("font-family",s.fontFamily),b!==void 0&&R.style("font-size",b),s.fontWeight!==void 0&&R.style("font-weight",s.fontWeight),s.fill!==void 0&&R.attr("fill",s.fill),s.class!==void 0&&R.attr("class",s.class),s.dy!==void 0?R.attr("dy",s.dy):T!==0&&R.attr("dy",T);const F=P||hje;if(s.tspan){const j=R.append("tspan");j.attr("x",s.x),s.fill!==void 0&&j.attr("fill",s.fill),j.text(F)}else R.text(F);s.valign!==void 0&&s.textMargin!==void 0&&s.textMargin>0&&(d+=(R._groups||R)[0][0].getBBox().height,u=d),y.push(R)}return y},$Ge=function(i,s){function u(p,v,b,y,T){return p+","+v+" "+(p+b)+","+v+" "+(p+b)+","+(v+y-T)+" "+(p+b-T*1.2)+","+(v+y)+" "+p+","+(v+y)}const d=i.append("polygon");return d.attr("points",u(s.x,s.y,s.width,s.height,7)),d.attr("class","labelBox"),s.y=s.y+s.height/2,YD(i,s),d};let s5=-1;const zGe=(i,s,u,d)=>{i.select&&u.forEach(p=>{const v=s[p],b=i.select("#actor"+v.actorCnt);!d.mirrorActors&&v.stopy?b.attr("y2",v.stopy+v.height/2):d.mirrorActors&&b.attr("y2",v.stopy)})},Wrn=async function(i,s,u,d){const p=d?s.stopy:s.starty,v=s.x+s.width/2,b=p+5,y=i.append("g").lower();var T=y;d||(s5++,Object.keys(s.links||{}).length&&!u.forceMenus&&T.attr("onclick",Krn(`actor${s5}_popup`)).attr("cursor","pointer"),T.append("line").attr("id","actor"+s5).attr("x1",v).attr("y1",b).attr("x2",v).attr("y2",2e3).attr("class","actor-line").attr("class","200").attr("stroke-width","0.5px").attr("stroke","#999"),T=y.append("g"),s.actorCnt=s5,s.links!=null&&T.attr("id","root-"+s5));const _=qC();var A="actor";s.properties!=null&&s.properties.class?A=s.properties.class:_.fill="#eaeaea",d?A+=` ${jGe}`:A+=` ${RGe}`,_.x=s.x,_.y=p,_.width=s.width,_.height=s.height,_.class=A,_.rx=3,_.ry=3,_.name=s.name;const P=Eve(T,_);if(s.rectData=_,s.properties!=null&&s.properties.icon){const F=s.properties.icon.trim();F.charAt(0)==="@"?rUt(T,_.x+_.width-20,_.y+10,F.substr(1)):nUt(T,_.x+_.width-20,_.y+10,F)}await Tve(u,Dv(s.description))(s.description,T,_.x,_.y,_.width,_.height,{class:"actor"},u);let R=s.height;if(P.node){const F=P.node().getBBox();s.height=F.height,R=F.height}return R},Yrn=async function(i,s,u,d){const p=d?s.stopy:s.starty,v=s.x+s.width/2,b=p+80;i.lower(),d||(s5++,i.append("line").attr("id","actor"+s5).attr("x1",v).attr("y1",b).attr("x2",v).attr("y2",2e3).attr("class","actor-line").attr("class","200").attr("stroke-width","0.5px").attr("stroke","#999"),s.actorCnt=s5);const y=i.append("g");let T="actor-man";d?T+=` ${jGe}`:T+=` ${RGe}`,y.attr("class",T),y.attr("name",s.name);const _=qC();_.x=s.x,_.y=p,_.fill="#eaeaea",_.width=s.width,_.height=s.height,_.class="actor",_.rx=3,_.ry=3,y.append("line").attr("id","actor-man-torso"+s5).attr("x1",v).attr("y1",p+25).attr("x2",v).attr("y2",p+45),y.append("line").attr("id","actor-man-arms"+s5).attr("x1",v-ZC/2).attr("y1",p+33).attr("x2",v+ZC/2).attr("y2",p+33),y.append("line").attr("x1",v-ZC/2).attr("y1",p+60).attr("x2",v).attr("y2",p+45),y.append("line").attr("x1",v).attr("y1",p+45).attr("x2",v+ZC/2-2).attr("y2",p+60);const A=y.append("circle");A.attr("cx",s.x+s.width/2),A.attr("cy",p+10),A.attr("r",15),A.attr("width",s.width),A.attr("height",s.height);const P=y.node().getBBox();return s.height=P.height,await Tve(u,Dv(s.description))(s.description,y,_.x,_.y+35,_.width,_.height,{class:"actor"},u),s.height},Xrn=async function(i,s,u,d){switch(s.type){case"actor":return await Yrn(i,s,u,d);case"participant":return await Wrn(i,s,u,d)}},Qrn=async function(i,s,u){const p=i.append("g");qGe(p,s),s.name&&await Tve(u)(s.name,p,s.x,s.y+(s.textMaxHeight||0)/2,s.width,0,{class:"text"},u),p.lower()},Jrn=function(i){return i.append("g")},Zrn=function(i,s,u,d,p){const v=qC(),b=s.anchored;v.x=s.startx,v.y=s.starty,v.class="activation"+p%3,v.width=s.stopx-s.startx,v.height=u-s.starty,Eve(b,v)},ein=async function(i,s,u,d){const{boxMargin:p,boxTextMargin:v,labelBoxHeight:b,labelBoxWidth:y,messageFontFamily:T,messageFontSize:_,messageFontWeight:A}=d,P=i.append("g"),R=function(K,ee,ie,oe){return P.append("line").attr("x1",K).attr("y1",ee).attr("x2",ie).attr("y2",oe).attr("class","loopLine")};R(s.startx,s.starty,s.stopx,s.starty),R(s.stopx,s.starty,s.stopx,s.stopy),R(s.startx,s.stopy,s.stopx,s.stopy),R(s.startx,s.starty,s.startx,s.stopy),s.sections!==void 0&&s.sections.forEach(function(K){R(s.startx,K.y,s.stopx,K.y).style("stroke-dasharray","3, 3")});let F=zbe();F.text=u,F.x=s.startx,F.y=s.starty,F.fontFamily=T,F.fontSize=_,F.fontWeight=A,F.anchor="middle",F.valign="middle",F.tspan=!1,F.width=y||50,F.height=b||20,F.textMargin=v,F.class="labelText",$Ge(P,F),F=HGe(),F.text=s.title,F.x=s.startx+y/2+(s.stopx-s.startx)/2,F.y=s.starty+p+v,F.anchor="middle",F.valign="middle",F.textMargin=v,F.class="loopText",F.fontFamily=T,F.fontSize=_,F.fontWeight=A,F.wrap=!0;let j=Dv(F.text)?await pJ(P,F,s):YD(P,F);if(s.sectionTitles!==void 0){for(const[K,ee]of Object.entries(s.sectionTitles))if(ee.message){F.text=ee.message,F.x=s.startx+(s.stopx-s.startx)/2,F.y=s.sections[K].y+p+v,F.class="loopText",F.anchor="middle",F.valign="middle",F.tspan=!1,F.fontFamily=T,F.fontSize=_,F.fontWeight=A,F.wrap=s.wrap,Dv(F.text)?(s.starty=s.sections[K].y,await pJ(P,F,s)):YD(P,F);let ie=Math.round(j.map(oe=>(oe._groups||oe)[0][0].getBBox().height).reduce((oe,pe)=>oe+pe));s.sections[K].height+=ie-(p+v)}}return s.height=Math.round(s.stopy-s.starty),P},qGe=function(i,s){Tqe(i,s)},tin=function(i){i.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-.047.148-.048.143-.049.139-.049.136-.05.131-.05.126-.05.123-.051.118-.052.114-.051.11-.052.106-.052.101-.052.096-.052.092-.052.088-.053.083-.051.079-.052.074-.052.07-.051.065-.051.06-.051.056-.05.051-.05.023-.024.023-.025.021-.024.02-.024.019-.024.018-.024.017-.024.015-.023.014-.024.013-.023.012-.023.01-.023.01-.022.008-.022.006-.022.006-.022.004-.022.004-.021.001-.021.001-.021v-4.127l-.077.055-.08.053-.083.054-.085.053-.087.052-.09.052-.093.051-.095.05-.097.05-.1.049-.102.049-.105.048-.106.047-.109.047-.111.046-.114.045-.115.045-.118.044-.12.043-.122.042-.124.042-.126.041-.128.04-.13.04-.132.038-.134.038-.135.037-.138.037-.139.035-.142.035-.143.034-.144.033-.147.032-.148.031-.15.03-.151.03-.153.029-.154.027-.156.027-.158.026-.159.025-.161.024-.162.023-.163.022-.165.021-.166.02-.167.019-.169.018-.169.017-.171.016-.173.015-.173.014-.175.013-.175.012-.177.011-.178.01-.179.008-.179.008-.181.006-.182.005-.182.004-.184.003-.184.002h-.37l-.184-.002-.184-.003-.182-.004-.182-.005-.181-.006-.179-.008-.179-.008-.178-.01-.176-.011-.176-.012-.175-.013-.173-.014-.172-.015-.171-.016-.17-.017-.169-.018-.167-.019-.166-.02-.165-.021-.163-.022-.162-.023-.161-.024-.159-.025-.157-.026-.156-.027-.155-.027-.153-.029-.151-.03-.15-.03-.148-.031-.146-.032-.145-.033-.143-.034-.141-.035-.14-.035-.137-.037-.136-.037-.134-.038-.132-.038-.13-.04-.128-.04-.126-.041-.124-.042-.122-.042-.12-.044-.117-.043-.116-.045-.113-.045-.112-.046-.109-.047-.106-.047-.105-.048-.102-.049-.1-.049-.097-.05-.095-.05-.093-.052-.09-.051-.087-.052-.085-.053-.083-.054-.08-.054-.077-.054v4.127zm0-5.654v.011l.001.021.003.021.004.021.005.022.006.022.007.022.009.022.01.022.011.023.012.023.013.023.015.024.016.023.017.024.018.024.019.024.021.024.022.024.023.025.024.024.052.05.056.05.061.05.066.051.07.051.075.052.079.051.084.052.088.052.092.052.097.052.102.052.105.052.11.051.114.051.119.052.123.05.127.051.131.05.135.049.139.049.144.048.147.048.152.047.155.046.16.045.163.045.167.044.171.042.176.042.178.04.183.04.187.038.19.037.194.036.197.034.202.033.204.032.209.03.212.028.216.027.219.025.222.024.226.022.23.02.233.018.236.016.24.014.243.012.246.01.249.008.253.006.256.003.259.001.26-.001.257-.003.254-.006.25-.008.247-.01.244-.012.241-.015.237-.016.233-.018.231-.02.226-.022.224-.024.22-.025.216-.027.212-.029.21-.03.205-.032.202-.033.198-.035.194-.036.191-.037.187-.039.183-.039.179-.041.175-.042.172-.043.168-.044.163-.045.16-.045.155-.047.152-.047.148-.048.143-.048.139-.05.136-.049.131-.05.126-.051.123-.051.118-.051.114-.052.11-.052.106-.052.101-.052.096-.052.092-.052.088-.052.083-.052.079-.052.074-.051.07-.052.065-.051.06-.05.056-.051.051-.049.023-.025.023-.024.021-.025.02-.024.019-.024.018-.024.017-.024.015-.023.014-.023.013-.024.012-.022.01-.023.01-.023.008-.022.006-.022.006-.022.004-.021.004-.022.001-.021.001-.021v-4.139l-.077.054-.08.054-.083.054-.085.052-.087.053-.09.051-.093.051-.095.051-.097.05-.1.049-.102.049-.105.048-.106.047-.109.047-.111.046-.114.045-.115.044-.118.044-.12.044-.122.042-.124.042-.126.041-.128.04-.13.039-.132.039-.134.038-.135.037-.138.036-.139.036-.142.035-.143.033-.144.033-.147.033-.148.031-.15.03-.151.03-.153.028-.154.028-.156.027-.158.026-.159.025-.161.024-.162.023-.163.022-.165.021-.166.02-.167.019-.169.018-.169.017-.171.016-.173.015-.173.014-.175.013-.175.012-.177.011-.178.009-.179.009-.179.007-.181.007-.182.005-.182.004-.184.003-.184.002h-.37l-.184-.002-.184-.003-.182-.004-.182-.005-.181-.007-.179-.007-.179-.009-.178-.009-.176-.011-.176-.012-.175-.013-.173-.014-.172-.015-.171-.016-.17-.017-.169-.018-.167-.019-.166-.02-.165-.021-.163-.022-.162-.023-.161-.024-.159-.025-.157-.026-.156-.027-.155-.028-.153-.028-.151-.03-.15-.03-.148-.031-.146-.033-.145-.033-.143-.033-.141-.035-.14-.036-.137-.036-.136-.037-.134-.038-.132-.039-.13-.039-.128-.04-.126-.041-.124-.042-.122-.043-.12-.043-.117-.044-.116-.044-.113-.046-.112-.046-.109-.046-.106-.047-.105-.048-.102-.049-.1-.049-.097-.05-.095-.051-.093-.051-.09-.051-.087-.053-.085-.052-.083-.054-.08-.054-.077-.054v4.139zm0-5.666v.011l.001.02.003.022.004.021.005.022.006.021.007.022.009.023.01.022.011.023.012.023.013.023.015.023.016.024.017.024.018.023.019.024.021.025.022.024.023.024.024.025.052.05.056.05.061.05.066.051.07.051.075.052.079.051.084.052.088.052.092.052.097.052.102.052.105.051.11.052.114.051.119.051.123.051.127.05.131.05.135.05.139.049.144.048.147.048.152.047.155.046.16.045.163.045.167.043.171.043.176.042.178.04.183.04.187.038.19.037.194.036.197.034.202.033.204.032.209.03.212.028.216.027.219.025.222.024.226.021.23.02.233.018.236.017.24.014.243.012.246.01.249.008.253.006.256.003.259.001.26-.001.257-.003.254-.006.25-.008.247-.01.244-.013.241-.014.237-.016.233-.018.231-.02.226-.022.224-.024.22-.025.216-.027.212-.029.21-.03.205-.032.202-.033.198-.035.194-.036.191-.037.187-.039.183-.039.179-.041.175-.042.172-.043.168-.044.163-.045.16-.045.155-.047.152-.047.148-.048.143-.049.139-.049.136-.049.131-.051.126-.05.123-.051.118-.052.114-.051.11-.052.106-.052.101-.052.096-.052.092-.052.088-.052.083-.052.079-.052.074-.052.07-.051.065-.051.06-.051.056-.05.051-.049.023-.025.023-.025.021-.024.02-.024.019-.024.018-.024.017-.024.015-.023.014-.024.013-.023.012-.023.01-.022.01-.023.008-.022.006-.022.006-.022.004-.022.004-.021.001-.021.001-.021v-4.153l-.077.054-.08.054-.083.053-.085.053-.087.053-.09.051-.093.051-.095.051-.097.05-.1.049-.102.048-.105.048-.106.048-.109.046-.111.046-.114.046-.115.044-.118.044-.12.043-.122.043-.124.042-.126.041-.128.04-.13.039-.132.039-.134.038-.135.037-.138.036-.139.036-.142.034-.143.034-.144.033-.147.032-.148.032-.15.03-.151.03-.153.028-.154.028-.156.027-.158.026-.159.024-.161.024-.162.023-.163.023-.165.021-.166.02-.167.019-.169.018-.169.017-.171.016-.173.015-.173.014-.175.013-.175.012-.177.01-.178.01-.179.009-.179.007-.181.006-.182.006-.182.004-.184.003-.184.001-.185.001-.185-.001-.184-.001-.184-.003-.182-.004-.182-.006-.181-.006-.179-.007-.179-.009-.178-.01-.176-.01-.176-.012-.175-.013-.173-.014-.172-.015-.171-.016-.17-.017-.169-.018-.167-.019-.166-.02-.165-.021-.163-.023-.162-.023-.161-.024-.159-.024-.157-.026-.156-.027-.155-.028-.153-.028-.151-.03-.15-.03-.148-.032-.146-.032-.145-.033-.143-.034-.141-.034-.14-.036-.137-.036-.136-.037-.134-.038-.132-.039-.13-.039-.128-.041-.126-.041-.124-.041-.122-.043-.12-.043-.117-.044-.116-.044-.113-.046-.112-.046-.109-.046-.106-.048-.105-.048-.102-.048-.1-.05-.097-.049-.095-.051-.093-.051-.09-.052-.087-.052-.085-.053-.083-.053-.08-.054-.077-.054v4.153zm8.74-8.179l-.257.004-.254.005-.25.008-.247.011-.244.012-.241.014-.237.016-.233.018-.231.021-.226.022-.224.023-.22.026-.216.027-.212.028-.21.031-.205.032-.202.033-.198.034-.194.036-.191.038-.187.038-.183.04-.179.041-.175.042-.172.043-.168.043-.163.045-.16.046-.155.046-.152.048-.148.048-.143.048-.139.049-.136.05-.131.05-.126.051-.123.051-.118.051-.114.052-.11.052-.106.052-.101.052-.096.052-.092.052-.088.052-.083.052-.079.052-.074.051-.07.052-.065.051-.06.05-.056.05-.051.05-.023.025-.023.024-.021.024-.02.025-.019.024-.018.024-.017.023-.015.024-.014.023-.013.023-.012.023-.01.023-.01.022-.008.022-.006.023-.006.021-.004.022-.004.021-.001.021-.001.021.001.021.001.021.004.021.004.022.006.021.006.023.008.022.01.022.01.023.012.023.013.023.014.023.015.024.017.023.018.024.019.024.02.025.021.024.023.024.023.025.051.05.056.05.06.05.065.051.07.052.074.051.079.052.083.052.088.052.092.052.096.052.101.052.106.052.11.052.114.052.118.051.123.051.126.051.131.05.136.05.139.049.143.048.148.048.152.048.155.046.16.046.163.045.168.043.172.043.175.042.179.041.183.04.187.038.191.038.194.036.198.034.202.033.205.032.21.031.212.028.216.027.22.026.224.023.226.022.231.021.233.018.237.016.241.014.244.012.247.011.25.008.254.005.257.004.26.001.26-.001.257-.004.254-.005.25-.008.247-.011.244-.012.241-.014.237-.016.233-.018.231-.021.226-.022.224-.023.22-.026.216-.027.212-.028.21-.031.205-.032.202-.033.198-.034.194-.036.191-.038.187-.038.183-.04.179-.041.175-.042.172-.043.168-.043.163-.045.16-.046.155-.046.152-.048.148-.048.143-.048.139-.049.136-.05.131-.05.126-.051.123-.051.118-.051.114-.052.11-.052.106-.052.101-.052.096-.052.092-.052.088-.052.083-.052.079-.052.074-.051.07-.052.065-.051.06-.05.056-.05.051-.05.023-.025.023-.024.021-.024.02-.025.019-.024.018-.024.017-.023.015-.024.014-.023.013-.023.012-.023.01-.023.01-.022.008-.022.006-.023.006-.021.004-.022.004-.021.001-.021.001-.021-.001-.021-.001-.021-.004-.021-.004-.022-.006-.021-.006-.023-.008-.022-.01-.022-.01-.023-.012-.023-.013-.023-.014-.023-.015-.024-.017-.023-.018-.024-.019-.024-.02-.025-.021-.024-.023-.024-.023-.025-.051-.05-.056-.05-.06-.05-.065-.051-.07-.052-.074-.051-.079-.052-.083-.052-.088-.052-.092-.052-.096-.052-.101-.052-.106-.052-.11-.052-.114-.052-.118-.051-.123-.051-.126-.051-.131-.05-.136-.05-.139-.049-.143-.048-.148-.048-.152-.048-.155-.046-.16-.046-.163-.045-.168-.043-.172-.043-.175-.042-.179-.041-.183-.04-.187-.038-.191-.038-.194-.036-.198-.034-.202-.033-.205-.032-.21-.031-.212-.028-.216-.027-.22-.026-.224-.023-.226-.022-.231-.021-.233-.018-.237-.016-.241-.014-.244-.012-.247-.011-.25-.008-.254-.005-.257-.004-.26-.001-.26.001z")},nin=function(i){i.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")},rin=function(i){i.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")},iin=function(i){i.append("defs").append("marker").attr("id","arrowhead").attr("refX",7.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")},sin=function(i){i.append("defs").append("marker").attr("id","filled-head").attr("refX",15.5).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")},ain=function(i){i.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)},oin=function(i){i.append("defs").append("marker").attr("id","crosshead").attr("markerWidth",15).attr("markerHeight",8).attr("orient","auto").attr("refX",4).attr("refY",4.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")},HGe=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}},cin=function(){return{x:0,y:0,fill:"#EDF2AE",stroke:"#666",width:100,anchor:"start",height:100,rx:0,ry:0}},Tve=function(){function i(v,b,y,T,_,A,P){const R=b.append("text").attr("x",y+_/2).attr("y",T+A/2+5).style("text-anchor","middle").text(v);p(R,P)}function s(v,b,y,T,_,A,P,R){const{actorFontSize:F,actorFontFamily:j,actorFontWeight:K}=R,[ee,ie]=NC(F),oe=v.split(ci.lineBreakRegex);for(let pe=0;pei.height||0))+(this.loops.length===0?0:this.loops.map(i=>i.height||0).reduce((i,s)=>i+s))+(this.messages.length===0?0:this.messages.map(i=>i.height||0).reduce((i,s)=>i+s))+(this.notes.length===0?0:this.notes.map(i=>i.height||0).reduce((i,s)=>i+s))},clear:function(){this.actors=[],this.boxes=[],this.loops=[],this.messages=[],this.notes=[]},addBox:function(i){this.boxes.push(i)},addActor:function(i){this.actors.push(i)},addLoop:function(i){this.loops.push(i)},addMessage:function(i){this.messages.push(i)},addNote:function(i){this.notes.push(i)},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,UGe(qt())},updateVal:function(i,s,u,d){i[s]===void 0?i[s]=u:i[s]=d(u,i[s])},updateBounds:function(i,s,u,d){const p=this;let v=0;function b(y){return function(_){v++;const A=p.sequenceItems.length-v+1;p.updateVal(_,"starty",s-A*En.boxMargin,Math.min),p.updateVal(_,"stopy",d+A*En.boxMargin,Math.max),p.updateVal(ni.data,"startx",i-A*En.boxMargin,Math.min),p.updateVal(ni.data,"stopx",u+A*En.boxMargin,Math.max),y!=="activation"&&(p.updateVal(_,"startx",i-A*En.boxMargin,Math.min),p.updateVal(_,"stopx",u+A*En.boxMargin,Math.max),p.updateVal(ni.data,"starty",s-A*En.boxMargin,Math.min),p.updateVal(ni.data,"stopy",d+A*En.boxMargin,Math.max))}}this.sequenceItems.forEach(b()),this.activations.forEach(b("activation"))},insert:function(i,s,u,d){const p=ci.getMin(i,u),v=ci.getMax(i,u),b=ci.getMin(s,d),y=ci.getMax(s,d);this.updateVal(ni.data,"startx",p,Math.min),this.updateVal(ni.data,"starty",b,Math.min),this.updateVal(ni.data,"stopx",v,Math.max),this.updateVal(ni.data,"stopy",y,Math.max),this.updateBounds(p,b,v,y)},newActivation:function(i,s,u){const d=u[i.from.actor],p=bJ(i.from.actor).length||0,v=d.x+d.width/2+(p-1)*En.activationWidth/2;this.activations.push({startx:v,starty:this.verticalPos+2,stopx:v+En.activationWidth,stopy:void 0,actor:i.from.actor,anchored:Zf.anchorElement(s)})},endActivation:function(i){const s=this.activations.map(function(u){return u.actor}).lastIndexOf(i.from.actor);return this.activations.splice(s,1)[0]},createLoop:function(i={message:void 0,wrap:!1,width:void 0},s){return{startx:void 0,starty:this.verticalPos,stopx:void 0,stopy:void 0,title:i.message,wrap:i.wrap,width:i.width,height:0,fill:s}},newLoop:function(i={message:void 0,wrap:!1,width:void 0},s){this.sequenceItems.push(this.createLoop(i,s))},endLoop:function(){return this.sequenceItems.pop()},isLoopOverlap:function(){return this.sequenceItems.length?this.sequenceItems[this.sequenceItems.length-1].overlap:!1},addSectionToLoop:function(i){const s=this.sequenceItems.pop();s.sections=s.sections||[],s.sectionTitles=s.sectionTitles||[],s.sections.push({y:ni.getVerticalPos(),height:0}),s.sectionTitles.push(i),this.sequenceItems.push(s)},saveVerticalPos:function(){this.isLoopOverlap()&&(this.savedVerticalPos=this.verticalPos)},resetVerticalPos:function(){this.isLoopOverlap()&&(this.verticalPos=this.savedVerticalPos)},bumpVerticalPos:function(i){this.verticalPos=this.verticalPos+i,this.data.stopy=ci.getMax(this.data.stopy,this.verticalPos)},getVerticalPos:function(){return this.verticalPos},getBounds:function(){return{bounds:this.data,models:this.models}}},lin=async function(i,s){ni.bumpVerticalPos(En.boxMargin),s.height=En.boxMargin,s.starty=ni.getVerticalPos();const u=qC();u.x=s.startx,u.y=s.starty,u.width=s.width||En.width,u.class="note";const d=i.append("g"),p=Zf.drawRect(d,u),v=zbe();v.x=s.startx,v.y=s.starty,v.width=u.width,v.dy="1em",v.text=s.message,v.class="noteText",v.fontFamily=En.noteFontFamily,v.fontSize=En.noteFontSize,v.fontWeight=En.noteFontWeight,v.anchor=En.noteAlign,v.textMargin=En.noteMargin,v.valign="center";const b=Dv(v.text)?await pJ(d,v):YD(d,v),y=Math.round(b.map(T=>(T._groups||T)[0][0].getBBox().height).reduce((T,_)=>T+_));p.attr("height",y+2*En.noteMargin),s.height+=y+2*En.noteMargin,ni.bumpVerticalPos(y+2*En.noteMargin),s.stopy=s.starty+y+2*En.noteMargin,s.stopx=s.startx+u.width,ni.insert(s.startx,s.starty,s.stopx,s.stopy),ni.models.addNote(s)},eS=i=>({fontFamily:i.messageFontFamily,fontSize:i.messageFontSize,fontWeight:i.messageFontWeight}),XD=i=>({fontFamily:i.noteFontFamily,fontSize:i.noteFontSize,fontWeight:i.noteFontWeight}),Cve=i=>({fontFamily:i.actorFontFamily,fontSize:i.actorFontSize,fontWeight:i.actorFontWeight});async function hin(i,s){ni.bumpVerticalPos(10);const{startx:u,stopx:d,message:p}=s,v=ci.splitBreaks(p).length,b=Dv(p),y=b?await HF(p,qt()):Ao.calculateTextDimensions(p,eS(En));if(!b){const P=y.height/v;s.height+=P,ni.bumpVerticalPos(P)}let T,_=y.height-10;const A=y.width;if(u===d){T=ni.getVerticalPos()+_,En.rightAngles||(_+=En.boxMargin,T=ni.getVerticalPos()+_),_+=30;const P=ci.getMax(A/2,En.width/2);ni.insert(u-P,ni.getVerticalPos()-10+_,d+P,ni.getVerticalPos()+30+_)}else _+=En.boxMargin,T=ni.getVerticalPos()+_,ni.insert(u,T-10,d,T);return ni.bumpVerticalPos(_),s.height+=_,s.stopy=s.starty+s.height,ni.insert(s.fromBounds,s.starty,s.toBounds,s.stopy),T}const fin=async function(i,s,u,d){const{startx:p,stopx:v,starty:b,message:y,type:T,sequenceIndex:_,sequenceVisible:A}=s,P=Ao.calculateTextDimensions(y,eS(En)),R=zbe();R.x=p,R.y=b+10,R.width=v-p,R.class="messageText",R.dy="1em",R.text=y,R.fontFamily=En.messageFontFamily,R.fontSize=En.messageFontSize,R.fontWeight=En.messageFontWeight,R.anchor=En.messageAlign,R.valign="center",R.textMargin=En.wrapPadding,R.tspan=!1,Dv(R.text)?await pJ(i,R,{startx:p,stopx:v,starty:u}):YD(i,R);const F=P.width;let j;p===v?En.rightAngles?j=i.append("path").attr("d",`M ${p},${u} H ${p+ci.getMax(En.width/2,F/2)} V ${u+25} H ${p}`):j=i.append("path").attr("d","M "+p+","+u+" C "+(p+60)+","+(u-10)+" "+(p+60)+","+(u+30)+" "+p+","+(u+20)):(j=i.append("line"),j.attr("x1",p),j.attr("y1",u),j.attr("x2",v),j.attr("y2",u)),T===d.db.LINETYPE.DOTTED||T===d.db.LINETYPE.DOTTED_CROSS||T===d.db.LINETYPE.DOTTED_POINT||T===d.db.LINETYPE.DOTTED_OPEN?(j.style("stroke-dasharray","3, 3"),j.attr("class","messageLine1")):j.attr("class","messageLine0");let K="";En.arrowMarkerAbsolute&&(K=window.location.protocol+"//"+window.location.host+window.location.pathname+window.location.search,K=K.replace(/\(/g,"\\("),K=K.replace(/\)/g,"\\)")),j.attr("stroke-width",2),j.attr("stroke","none"),j.style("fill","none"),(T===d.db.LINETYPE.SOLID||T===d.db.LINETYPE.DOTTED)&&j.attr("marker-end","url("+K+"#arrowhead)"),(T===d.db.LINETYPE.SOLID_POINT||T===d.db.LINETYPE.DOTTED_POINT)&&j.attr("marker-end","url("+K+"#filled-head)"),(T===d.db.LINETYPE.SOLID_CROSS||T===d.db.LINETYPE.DOTTED_CROSS)&&j.attr("marker-end","url("+K+"#crosshead)"),(A||En.showSequenceNumbers)&&(j.attr("marker-start","url("+K+"#sequencenumber)"),i.append("text").attr("x",p).attr("y",u+4).attr("font-family","sans-serif").attr("font-size","12px").attr("text-anchor","middle").attr("class","sequenceNumber").text(_))},din=async function(i,s,u,d,p,v,b){let y=0,T=0,_,A=0;for(const P of d){const R=s[P],F=R.box;_&&_!=F&&(b||ni.models.addBox(_),T+=En.boxMargin+_.margin),F&&F!=_&&(b||(F.x=y+T,F.y=p),T+=F.margin),R.width=R.width||En.width,R.height=ci.getMax(R.height||En.height,En.height),R.margin=R.margin||En.actorMargin,A=ci.getMax(A,R.height),u[R.name]&&(T+=R.width/2),R.x=y+T,R.starty=ni.getVerticalPos(),ni.insert(R.x,p,R.x+R.width,R.height),y+=R.width+T,R.box&&(R.box.width=y+F.margin-R.box.x),T=R.margin,_=R.box,ni.models.addActor(R)}_&&!b&&ni.models.addBox(_),ni.bumpVerticalPos(A)},Sve=async function(i,s,u,d){if(d){let p=0;ni.bumpVerticalPos(En.boxMargin*2);for(const v of u){const b=s[v];b.stopy||(b.stopy=ni.getVerticalPos());const y=await Zf.drawActor(i,b,En,!0);p=ci.getMax(p,y)}ni.bumpVerticalPos(p+En.boxMargin)}else for(const p of u){const v=s[p];await Zf.drawActor(i,v,En,!1)}},VGe=function(i,s,u,d){let p=0,v=0;for(const b of u){const y=s[b],T=min(y),_=Zf.drawPopup(i,y,T,En,En.forceMenus,d);_.height>p&&(p=_.height),_.width+y.x>v&&(v=_.width+y.x)}return{maxHeight:p,maxWidth:v}},UGe=function(i){id(En,i),i.fontFamily&&(En.actorFontFamily=En.noteFontFamily=En.messageFontFamily=i.fontFamily),i.fontSize&&(En.actorFontSize=En.noteFontSize=En.messageFontSize=i.fontSize),i.fontWeight&&(En.actorFontWeight=En.noteFontWeight=En.messageFontWeight=i.fontWeight)},bJ=function(i){return ni.activations.filter(function(s){return s.actor===i})},GGe=function(i,s){const u=s[i],d=bJ(i),p=d.reduce(function(b,y){return ci.getMin(b,y.startx)},u.x+u.width/2-1),v=d.reduce(function(b,y){return ci.getMax(b,y.stopx)},u.x+u.width/2+1);return[p,v]};function a5(i,s,u,d,p){ni.bumpVerticalPos(u);let v=d;if(s.id&&s.message&&i[s.id]){const b=i[s.id].width,y=eS(En);s.message=Ao.wrapLabel(`[${s.message}]`,b-2*En.wrapPadding,y),s.width=b,s.wrap=!0;const T=Ao.calculateTextDimensions(s.message,y),_=ci.getMax(T.height,En.labelBoxHeight);v=d+_,Xe.debug(`${_} - ${s.message}`)}p(s),ni.bumpVerticalPos(v)}function gin(i,s,u,d,p,v,b){function y(_,A){_.x{Se.add(Ce.from),Se.add(Ce.to)}),j=j.filter(Ce=>Se.has(Ce))}await din(_,A,P,j,0,K,!1);const be=await xin(K,A,pe,d);Zf.insertArrowHead(_),Zf.insertArrowCrossHead(_),Zf.insertArrowFilledHead(_),Zf.insertSequenceNumber(_);function ae(Se,Ce){const ke=ni.endActivation(Se);ke.starty+18>Ce&&(ke.starty=Ce-6,Ce+=12),Zf.drawActivation(_,ke,Ce,En,bJ(Se.from.actor).length),ni.insert(ke.startx,Ce-10,ke.stopx,Ce)}let ne=1,se=1;const de=[],X=[];let ge=0;for(const Se of K){let Ce,ke,Ke;switch(Se.type){case d.db.LINETYPE.NOTE:ni.resetVerticalPos(),ke=Se.noteModel,await lin(_,ke);break;case d.db.LINETYPE.ACTIVE_START:ni.newActivation(Se,_,A);break;case d.db.LINETYPE.ACTIVE_END:ae(Se,ni.getVerticalPos());break;case d.db.LINETYPE.LOOP_START:a5(be,Se,En.boxMargin,En.boxMargin+En.boxTextMargin,Ft=>ni.newLoop(Ft));break;case d.db.LINETYPE.LOOP_END:Ce=ni.endLoop(),await Zf.drawLoop(_,Ce,"loop",En),ni.bumpVerticalPos(Ce.stopy-ni.getVerticalPos()),ni.models.addLoop(Ce);break;case d.db.LINETYPE.RECT_START:a5(be,Se,En.boxMargin,En.boxMargin,Ft=>ni.newLoop(void 0,Ft.message));break;case d.db.LINETYPE.RECT_END:Ce=ni.endLoop(),X.push(Ce),ni.models.addLoop(Ce),ni.bumpVerticalPos(Ce.stopy-ni.getVerticalPos());break;case d.db.LINETYPE.OPT_START:a5(be,Se,En.boxMargin,En.boxMargin+En.boxTextMargin,Ft=>ni.newLoop(Ft));break;case d.db.LINETYPE.OPT_END:Ce=ni.endLoop(),await Zf.drawLoop(_,Ce,"opt",En),ni.bumpVerticalPos(Ce.stopy-ni.getVerticalPos()),ni.models.addLoop(Ce);break;case d.db.LINETYPE.ALT_START:a5(be,Se,En.boxMargin,En.boxMargin+En.boxTextMargin,Ft=>ni.newLoop(Ft));break;case d.db.LINETYPE.ALT_ELSE:a5(be,Se,En.boxMargin+En.boxTextMargin,En.boxMargin,Ft=>ni.addSectionToLoop(Ft));break;case d.db.LINETYPE.ALT_END:Ce=ni.endLoop(),await Zf.drawLoop(_,Ce,"alt",En),ni.bumpVerticalPos(Ce.stopy-ni.getVerticalPos()),ni.models.addLoop(Ce);break;case d.db.LINETYPE.PAR_START:case d.db.LINETYPE.PAR_OVER_START:a5(be,Se,En.boxMargin,En.boxMargin+En.boxTextMargin,Ft=>ni.newLoop(Ft)),ni.saveVerticalPos();break;case d.db.LINETYPE.PAR_AND:a5(be,Se,En.boxMargin+En.boxTextMargin,En.boxMargin,Ft=>ni.addSectionToLoop(Ft));break;case d.db.LINETYPE.PAR_END:Ce=ni.endLoop(),await Zf.drawLoop(_,Ce,"par",En),ni.bumpVerticalPos(Ce.stopy-ni.getVerticalPos()),ni.models.addLoop(Ce);break;case d.db.LINETYPE.AUTONUMBER:ne=Se.message.start||ne,se=Se.message.step||se,Se.message.visible?d.db.enableSequenceNumbers():d.db.disableSequenceNumbers();break;case d.db.LINETYPE.CRITICAL_START:a5(be,Se,En.boxMargin,En.boxMargin+En.boxTextMargin,Ft=>ni.newLoop(Ft));break;case d.db.LINETYPE.CRITICAL_OPTION:a5(be,Se,En.boxMargin+En.boxTextMargin,En.boxMargin,Ft=>ni.addSectionToLoop(Ft));break;case d.db.LINETYPE.CRITICAL_END:Ce=ni.endLoop(),await Zf.drawLoop(_,Ce,"critical",En),ni.bumpVerticalPos(Ce.stopy-ni.getVerticalPos()),ni.models.addLoop(Ce);break;case d.db.LINETYPE.BREAK_START:a5(be,Se,En.boxMargin,En.boxMargin+En.boxTextMargin,Ft=>ni.newLoop(Ft));break;case d.db.LINETYPE.BREAK_END:Ce=ni.endLoop(),await Zf.drawLoop(_,Ce,"break",En),ni.bumpVerticalPos(Ce.stopy-ni.getVerticalPos()),ni.models.addLoop(Ce);break;default:try{Ke=Se.msgModel,Ke.starty=ni.getVerticalPos(),Ke.sequenceIndex=ne,Ke.sequenceVisible=d.db.showSequenceNumbers();const Ft=await hin(_,Ke);gin(Se,Ke,Ft,ge,A,P,R),de.push({messageModel:Ke,lineStartY:Ft}),ni.models.addMessage(Ke)}catch(Ft){Xe.error("error while drawing message",Ft)}}[d.db.LINETYPE.SOLID_OPEN,d.db.LINETYPE.DOTTED_OPEN,d.db.LINETYPE.SOLID,d.db.LINETYPE.DOTTED,d.db.LINETYPE.SOLID_CROSS,d.db.LINETYPE.DOTTED_CROSS,d.db.LINETYPE.SOLID_POINT,d.db.LINETYPE.DOTTED_POINT].includes(Se.type)&&(ne=ne+se),ge++}Xe.debug("createdActors",P),Xe.debug("destroyedActors",R),await Sve(_,A,j,!1);for(const Se of de)await fin(_,Se.messageModel,Se.lineStartY,d);En.mirrorActors&&await Sve(_,A,j,!0),X.forEach(Se=>Zf.drawBackgroundRect(_,Se)),zGe(_,A,j,En);for(const Se of ni.models.boxes)Se.height=ni.getVerticalPos()-Se.y,ni.insert(Se.x,Se.y,Se.x+Se.width,Se.height),Se.startx=Se.x,Se.starty=Se.y,Se.stopx=Se.startx+Se.width,Se.stopy=Se.starty+Se.height,Se.stroke="rgb(0,0,0, 0.5)",await Zf.drawBox(_,Se,En);ie&&ni.bumpVerticalPos(En.boxMargin);const W=VGe(_,A,j,T),{bounds:xe}=ni.getBounds();let U=xe.stopy-xe.starty;U{const b=eS(En);let y=v.actorKeys.reduce((A,P)=>A+=i[P].width+(i[P].margin||0),0);y-=2*En.boxTextMargin,v.wrap&&(v.name=Ao.wrapLabel(v.name,y-2*En.wrapPadding,b));const T=Ao.calculateTextDimensions(v.name,b);p=ci.getMax(T.height,p);const _=ci.getMax(y,T.width+2*En.wrapPadding);if(v.margin=En.boxTextMargin,y<_){const A=(_-y)/2;v.margin+=A}}),u.forEach(v=>v.textMaxHeight=p),ci.getMax(d,En.height)}const win=async function(i,s,u){const d=s[i.from].x,p=s[i.to].x,v=i.wrap&&i.message;let b=Dv(i.message)?await HF(i.message,qt()):Ao.calculateTextDimensions(v?Ao.wrapLabel(i.message,En.width,XD(En)):i.message,XD(En));const y={width:v?En.width:ci.getMax(En.width,b.width+2*En.noteMargin),height:0,startx:s[i.from].x,stopx:0,starty:0,stopy:0,message:i.message};return i.placement===u.db.PLACEMENT.RIGHTOF?(y.width=v?ci.getMax(En.width,b.width):ci.getMax(s[i.from].width/2+s[i.to].width/2,b.width+2*En.noteMargin),y.startx=d+(s[i.from].width+En.actorMargin)/2):i.placement===u.db.PLACEMENT.LEFTOF?(y.width=v?ci.getMax(En.width,b.width+2*En.noteMargin):ci.getMax(s[i.from].width/2+s[i.to].width/2,b.width+2*En.noteMargin),y.startx=d-y.width+(s[i.from].width-En.actorMargin)/2):i.to===i.from?(b=Ao.calculateTextDimensions(v?Ao.wrapLabel(i.message,ci.getMax(En.width,s[i.from].width),XD(En)):i.message,XD(En)),y.width=v?ci.getMax(En.width,s[i.from].width):ci.getMax(s[i.from].width,En.width,b.width+2*En.noteMargin),y.startx=d+(s[i.from].width-y.width)/2):(y.width=Math.abs(d+s[i.from].width/2-(p+s[i.to].width/2))+En.actorMargin,y.startx=d2,P=K=>y?-K:K;i.from===i.to?_=T:(i.activate&&!A&&(_+=P(En.activationWidth/2-1)),[u.db.LINETYPE.SOLID_OPEN,u.db.LINETYPE.DOTTED_OPEN].includes(i.type)||(_+=P(3)));const R=[d,p,v,b],F=Math.abs(T-_);i.wrap&&i.message&&(i.message=Ao.wrapLabel(i.message,ci.getMax(F+2*En.wrapPadding,En.width),eS(En)));const j=Ao.calculateTextDimensions(i.message,eS(En));return{width:ci.getMax(i.wrap?0:j.width+2*En.wrapPadding,F+2*En.wrapPadding,En.width),height:0,startx:T,stopx:_,starty:0,stopy:0,message:i.message,type:i.type,wrap:i.wrap,fromBounds:Math.min.apply(null,R),toBounds:Math.max.apply(null,R)}},xin=async function(i,s,u,d){const p={},v=[];let b,y,T;for(const _ of i){switch(_.id=Ao.random({length:10}),_.type){case d.db.LINETYPE.LOOP_START:case d.db.LINETYPE.ALT_START:case d.db.LINETYPE.OPT_START:case d.db.LINETYPE.PAR_START:case d.db.LINETYPE.PAR_OVER_START:case d.db.LINETYPE.CRITICAL_START:case d.db.LINETYPE.BREAK_START:v.push({id:_.id,msg:_.message,from:Number.MAX_SAFE_INTEGER,to:Number.MIN_SAFE_INTEGER,width:0});break;case d.db.LINETYPE.ALT_ELSE:case d.db.LINETYPE.PAR_AND:case d.db.LINETYPE.CRITICAL_OPTION:_.message&&(b=v.pop(),p[b.id]=b,p[_.id]=b,v.push(b));break;case d.db.LINETYPE.LOOP_END:case d.db.LINETYPE.ALT_END:case d.db.LINETYPE.OPT_END:case d.db.LINETYPE.PAR_END:case d.db.LINETYPE.CRITICAL_END:case d.db.LINETYPE.BREAK_END:b=v.pop(),p[b.id]=b;break;case d.db.LINETYPE.ACTIVE_START:{const P=s[_.from?_.from.actor:_.to.actor],R=bJ(_.from?_.from.actor:_.to.actor).length,F=P.x+P.width/2+(R-1)*En.activationWidth/2,j={startx:F,stopx:F+En.activationWidth,actor:_.from.actor,enabled:!0};ni.activations.push(j)}break;case d.db.LINETYPE.ACTIVE_END:{const P=ni.activations.map(R=>R.actor).lastIndexOf(_.from.actor);delete ni.activations.splice(P,1)[0]}break}_.placement!==void 0?(y=await win(_,s,d),_.noteModel=y,v.forEach(P=>{b=P,b.from=ci.getMin(b.from,y.startx),b.to=ci.getMax(b.to,y.startx+y.width),b.width=ci.getMax(b.width,Math.abs(b.from-b.to))-En.labelBoxWidth})):(T=yin(_,s,d),_.msgModel=T,T.startx&&T.stopx&&v.length>0&&v.forEach(P=>{if(b=P,T.startx===T.stopx){const R=s[_.from],F=s[_.to];b.from=ci.getMin(R.x-T.width/2,R.x-R.width/2,b.from),b.to=ci.getMax(F.x+T.width/2,F.x+R.width/2,b.to),b.width=ci.getMax(b.width,Math.abs(b.to-b.from))-En.labelBoxWidth}else b.from=ci.getMin(T.startx,b.from),b.to=ci.getMax(T.stopx,b.to),b.width=ci.getMax(b.width,T.width)-En.labelBoxWidth}))}return ni.activations=[],Xe.debug("Loop type widths:",p),p},kin=Object.freeze(Object.defineProperty({__proto__:null,diagram:{parser:yrn,db:FGe,renderer:{bounds:ni,drawActors:Sve,drawActorsPopup:VGe,setConf:UGe,draw:pin},styles:Urn,init:({wrap:i})=>{FGe.setWrap(i)}}},Symbol.toStringTag,{value:"Module"}));var _ve=function(){var i=function(ao,Tr,Fn,qn){for(Fn=Fn||{},qn=ao.length;qn--;Fn[ao[qn]]=Tr);return Fn},s=[1,17],u=[1,18],d=[1,19],p=[1,39],v=[1,40],b=[1,25],y=[1,23],T=[1,24],_=[1,31],A=[1,32],P=[1,33],R=[1,34],F=[1,35],j=[1,36],K=[1,26],ee=[1,27],ie=[1,28],oe=[1,29],pe=[1,43],be=[1,30],ae=[1,42],ne=[1,44],se=[1,41],de=[1,45],X=[1,9],ge=[1,8,9],W=[1,56],xe=[1,57],U=[1,58],Fe=[1,59],Pe=[1,60],je=[1,61],Ie=[1,62],Se=[1,8,9,39],Ce=[1,74],ke=[1,8,9,12,13,21,37,39,42,59,60,61,62,63,64,65,70,72],Ke=[1,8,9,12,13,19,21,37,39,42,46,59,60,61,62,63,64,65,70,72,74,80,95,97,98],Ft=[13,74,80,95,97,98],Ne=[13,64,65,74,80,95,97,98],gn=[13,59,60,61,62,63,74,80,95,97,98],_t=[1,93],Et=[1,110],Gt=[1,108],ln=[1,102],xt=[1,103],Pt=[1,104],Qe=[1,105],Dt=[1,106],kt=[1,107],On=[1,109],ht=[1,8,9,37,39,42],zr=[1,8,9,21],yt=[1,8,9,78],ji=[1,8,9,21,73,74,78,80,81,82,83,84,85],xi={trace:function(){},yy:{},symbols_:{error:2,start:3,mermaidDoc:4,statements:5,graphConfig:6,CLASS_DIAGRAM:7,NEWLINE:8,EOF:9,statement:10,classLabel:11,SQS:12,STR:13,SQE:14,namespaceName:15,alphaNumToken:16,className:17,classLiteralName:18,GENERICTYPE:19,relationStatement:20,LABEL:21,namespaceStatement:22,classStatement:23,memberStatement:24,annotationStatement:25,clickStatement:26,styleStatement:27,cssClassStatement:28,noteStatement:29,direction:30,acc_title:31,acc_title_value:32,acc_descr:33,acc_descr_value:34,acc_descr_multiline_value:35,namespaceIdentifier:36,STRUCT_START:37,classStatements:38,STRUCT_STOP:39,NAMESPACE:40,classIdentifier:41,STYLE_SEPARATOR:42,members:43,CLASS:44,ANNOTATION_START:45,ANNOTATION_END:46,MEMBER:47,SEPARATOR:48,relation:49,NOTE_FOR:50,noteText:51,NOTE:52,direction_tb:53,direction_bt:54,direction_rl:55,direction_lr:56,relationType:57,lineType:58,AGGREGATION:59,EXTENSION:60,COMPOSITION:61,DEPENDENCY:62,LOLLIPOP:63,LINE:64,DOTTED_LINE:65,CALLBACK:66,LINK:67,LINK_TARGET:68,CLICK:69,CALLBACK_NAME:70,CALLBACK_ARGS:71,HREF:72,STYLE:73,ALPHA:74,stylesOpt:75,CSSCLASS:76,style:77,COMMA:78,styleComponent:79,NUM:80,COLON:81,UNIT:82,SPACE:83,BRKT:84,PCT:85,commentToken:86,textToken:87,graphCodeTokens:88,textNoTagsToken:89,TAGSTART:90,TAGEND:91,"==":92,"--":93,DEFAULT:94,MINUS:95,keywords:96,UNICODE_TEXT:97,BQUOTE_STR:98,$accept:0,$end:1},terminals_:{2:"error",7:"CLASS_DIAGRAM",8:"NEWLINE",9:"EOF",12:"SQS",13:"STR",14:"SQE",19:"GENERICTYPE",21:"LABEL",31:"acc_title",32:"acc_title_value",33:"acc_descr",34:"acc_descr_value",35:"acc_descr_multiline_value",37:"STRUCT_START",39:"STRUCT_STOP",40:"NAMESPACE",42:"STYLE_SEPARATOR",44:"CLASS",45:"ANNOTATION_START",46:"ANNOTATION_END",47:"MEMBER",48:"SEPARATOR",50:"NOTE_FOR",52:"NOTE",53:"direction_tb",54:"direction_bt",55:"direction_rl",56:"direction_lr",59:"AGGREGATION",60:"EXTENSION",61:"COMPOSITION",62:"DEPENDENCY",63:"LOLLIPOP",64:"LINE",65:"DOTTED_LINE",66:"CALLBACK",67:"LINK",68:"LINK_TARGET",69:"CLICK",70:"CALLBACK_NAME",71:"CALLBACK_ARGS",72:"HREF",73:"STYLE",74:"ALPHA",76:"CSSCLASS",78:"COMMA",80:"NUM",81:"COLON",82:"UNIT",83:"SPACE",84:"BRKT",85:"PCT",88:"graphCodeTokens",90:"TAGSTART",91:"TAGEND",92:"==",93:"--",94:"DEFAULT",95:"MINUS",96:"keywords",97:"UNICODE_TEXT",98:"BQUOTE_STR"},productions_:[0,[3,1],[3,1],[4,1],[6,4],[5,1],[5,2],[5,3],[11,3],[15,1],[15,2],[17,1],[17,1],[17,2],[17,2],[17,2],[10,1],[10,2],[10,1],[10,1],[10,1],[10,1],[10,1],[10,1],[10,1],[10,1],[10,1],[10,2],[10,2],[10,1],[22,4],[22,5],[36,2],[38,1],[38,2],[38,3],[23,1],[23,3],[23,4],[23,6],[41,2],[41,3],[25,4],[43,1],[43,2],[24,1],[24,2],[24,1],[24,1],[20,3],[20,4],[20,4],[20,5],[29,3],[29,2],[30,1],[30,1],[30,1],[30,1],[49,3],[49,2],[49,2],[49,1],[57,1],[57,1],[57,1],[57,1],[57,1],[58,1],[58,1],[26,3],[26,4],[26,3],[26,4],[26,4],[26,5],[26,3],[26,4],[26,4],[26,5],[26,4],[26,5],[26,5],[26,6],[27,3],[28,3],[75,1],[75,3],[77,1],[77,2],[79,1],[79,1],[79,1],[79,1],[79,1],[79,1],[79,1],[79,1],[79,1],[86,1],[86,1],[87,1],[87,1],[87,1],[87,1],[87,1],[87,1],[87,1],[89,1],[89,1],[89,1],[89,1],[16,1],[16,1],[16,1],[16,1],[18,1],[51,1]],performAction:function(Tr,Fn,qn,Un,At,wt,on){var fn=wt.length-1;switch(At){case 8:this.$=wt[fn-1];break;case 9:case 11:case 12:this.$=wt[fn];break;case 10:case 13:this.$=wt[fn-1]+wt[fn];break;case 14:case 15:this.$=wt[fn-1]+"~"+wt[fn]+"~";break;case 16:Un.addRelation(wt[fn]);break;case 17:wt[fn-1].title=Un.cleanupLabel(wt[fn]),Un.addRelation(wt[fn-1]);break;case 27:this.$=wt[fn].trim(),Un.setAccTitle(this.$);break;case 28:case 29:this.$=wt[fn].trim(),Un.setAccDescription(this.$);break;case 30:Un.addClassesToNamespace(wt[fn-3],wt[fn-1]);break;case 31:Un.addClassesToNamespace(wt[fn-4],wt[fn-1]);break;case 32:this.$=wt[fn],Un.addNamespace(wt[fn]);break;case 33:this.$=[wt[fn]];break;case 34:this.$=[wt[fn-1]];break;case 35:wt[fn].unshift(wt[fn-2]),this.$=wt[fn];break;case 37:Un.setCssClass(wt[fn-2],wt[fn]);break;case 38:Un.addMembers(wt[fn-3],wt[fn-1]);break;case 39:Un.setCssClass(wt[fn-5],wt[fn-3]),Un.addMembers(wt[fn-5],wt[fn-1]);break;case 40:this.$=wt[fn],Un.addClass(wt[fn]);break;case 41:this.$=wt[fn-1],Un.addClass(wt[fn-1]),Un.setClassLabel(wt[fn-1],wt[fn]);break;case 42:Un.addAnnotation(wt[fn],wt[fn-2]);break;case 43:this.$=[wt[fn]];break;case 44:wt[fn].push(wt[fn-1]),this.$=wt[fn];break;case 45:break;case 46:Un.addMember(wt[fn-1],Un.cleanupLabel(wt[fn]));break;case 47:break;case 48:break;case 49:this.$={id1:wt[fn-2],id2:wt[fn],relation:wt[fn-1],relationTitle1:"none",relationTitle2:"none"};break;case 50:this.$={id1:wt[fn-3],id2:wt[fn],relation:wt[fn-1],relationTitle1:wt[fn-2],relationTitle2:"none"};break;case 51:this.$={id1:wt[fn-3],id2:wt[fn],relation:wt[fn-2],relationTitle1:"none",relationTitle2:wt[fn-1]};break;case 52:this.$={id1:wt[fn-4],id2:wt[fn],relation:wt[fn-2],relationTitle1:wt[fn-3],relationTitle2:wt[fn-1]};break;case 53:Un.addNote(wt[fn],wt[fn-1]);break;case 54:Un.addNote(wt[fn]);break;case 55:Un.setDirection("TB");break;case 56:Un.setDirection("BT");break;case 57:Un.setDirection("RL");break;case 58:Un.setDirection("LR");break;case 59:this.$={type1:wt[fn-2],type2:wt[fn],lineType:wt[fn-1]};break;case 60:this.$={type1:"none",type2:wt[fn],lineType:wt[fn-1]};break;case 61:this.$={type1:wt[fn-1],type2:"none",lineType:wt[fn]};break;case 62:this.$={type1:"none",type2:"none",lineType:wt[fn]};break;case 63:this.$=Un.relationType.AGGREGATION;break;case 64:this.$=Un.relationType.EXTENSION;break;case 65:this.$=Un.relationType.COMPOSITION;break;case 66:this.$=Un.relationType.DEPENDENCY;break;case 67:this.$=Un.relationType.LOLLIPOP;break;case 68:this.$=Un.lineType.LINE;break;case 69:this.$=Un.lineType.DOTTED_LINE;break;case 70:case 76:this.$=wt[fn-2],Un.setClickEvent(wt[fn-1],wt[fn]);break;case 71:case 77:this.$=wt[fn-3],Un.setClickEvent(wt[fn-2],wt[fn-1]),Un.setTooltip(wt[fn-2],wt[fn]);break;case 72:this.$=wt[fn-2],Un.setLink(wt[fn-1],wt[fn]);break;case 73:this.$=wt[fn-3],Un.setLink(wt[fn-2],wt[fn-1],wt[fn]);break;case 74:this.$=wt[fn-3],Un.setLink(wt[fn-2],wt[fn-1]),Un.setTooltip(wt[fn-2],wt[fn]);break;case 75:this.$=wt[fn-4],Un.setLink(wt[fn-3],wt[fn-2],wt[fn]),Un.setTooltip(wt[fn-3],wt[fn-1]);break;case 78:this.$=wt[fn-3],Un.setClickEvent(wt[fn-2],wt[fn-1],wt[fn]);break;case 79:this.$=wt[fn-4],Un.setClickEvent(wt[fn-3],wt[fn-2],wt[fn-1]),Un.setTooltip(wt[fn-3],wt[fn]);break;case 80:this.$=wt[fn-3],Un.setLink(wt[fn-2],wt[fn]);break;case 81:this.$=wt[fn-4],Un.setLink(wt[fn-3],wt[fn-1],wt[fn]);break;case 82:this.$=wt[fn-4],Un.setLink(wt[fn-3],wt[fn-1]),Un.setTooltip(wt[fn-3],wt[fn]);break;case 83:this.$=wt[fn-5],Un.setLink(wt[fn-4],wt[fn-2],wt[fn]),Un.setTooltip(wt[fn-4],wt[fn-1]);break;case 84:this.$=wt[fn-2],Un.setCssStyle(wt[fn-1],wt[fn]);break;case 85:Un.setCssClass(wt[fn-1],wt[fn]);break;case 86:this.$=[wt[fn]];break;case 87:wt[fn-2].push(wt[fn]),this.$=wt[fn-2];break;case 89:this.$=wt[fn-1]+wt[fn];break}},table:[{3:1,4:2,5:3,6:4,7:[1,6],10:5,16:37,17:20,18:38,20:7,22:8,23:9,24:10,25:11,26:12,27:13,28:14,29:15,30:16,31:s,33:u,35:d,36:21,40:p,41:22,44:v,45:b,47:y,48:T,50:_,52:A,53:P,54:R,55:F,56:j,66:K,67:ee,69:ie,73:oe,74:pe,76:be,80:ae,95:ne,97:se,98:de},{1:[3]},{1:[2,1]},{1:[2,2]},{1:[2,3]},i(X,[2,5],{8:[1,46]}),{8:[1,47]},i(ge,[2,16],{21:[1,48]}),i(ge,[2,18]),i(ge,[2,19]),i(ge,[2,20]),i(ge,[2,21]),i(ge,[2,22]),i(ge,[2,23]),i(ge,[2,24]),i(ge,[2,25]),i(ge,[2,26]),{32:[1,49]},{34:[1,50]},i(ge,[2,29]),i(ge,[2,45],{49:51,57:54,58:55,13:[1,52],21:[1,53],59:W,60:xe,61:U,62:Fe,63:Pe,64:je,65:Ie}),{37:[1,63]},i(Se,[2,36],{37:[1,65],42:[1,64]}),i(ge,[2,47]),i(ge,[2,48]),{16:66,74:pe,80:ae,95:ne,97:se},{16:37,17:67,18:38,74:pe,80:ae,95:ne,97:se,98:de},{16:37,17:68,18:38,74:pe,80:ae,95:ne,97:se,98:de},{16:37,17:69,18:38,74:pe,80:ae,95:ne,97:se,98:de},{74:[1,70]},{13:[1,71]},{16:37,17:72,18:38,74:pe,80:ae,95:ne,97:se,98:de},{13:Ce,51:73},i(ge,[2,55]),i(ge,[2,56]),i(ge,[2,57]),i(ge,[2,58]),i(ke,[2,11],{16:37,18:38,17:75,19:[1,76],74:pe,80:ae,95:ne,97:se,98:de}),i(ke,[2,12],{19:[1,77]}),{15:78,16:79,74:pe,80:ae,95:ne,97:se},{16:37,17:80,18:38,74:pe,80:ae,95:ne,97:se,98:de},i(Ke,[2,112]),i(Ke,[2,113]),i(Ke,[2,114]),i(Ke,[2,115]),i([1,8,9,12,13,19,21,37,39,42,59,60,61,62,63,64,65,70,72],[2,116]),i(X,[2,6],{10:5,20:7,22:8,23:9,24:10,25:11,26:12,27:13,28:14,29:15,30:16,17:20,36:21,41:22,16:37,18:38,5:81,31:s,33:u,35:d,40:p,44:v,45:b,47:y,48:T,50:_,52:A,53:P,54:R,55:F,56:j,66:K,67:ee,69:ie,73:oe,74:pe,76:be,80:ae,95:ne,97:se,98:de}),{5:82,10:5,16:37,17:20,18:38,20:7,22:8,23:9,24:10,25:11,26:12,27:13,28:14,29:15,30:16,31:s,33:u,35:d,36:21,40:p,41:22,44:v,45:b,47:y,48:T,50:_,52:A,53:P,54:R,55:F,56:j,66:K,67:ee,69:ie,73:oe,74:pe,76:be,80:ae,95:ne,97:se,98:de},i(ge,[2,17]),i(ge,[2,27]),i(ge,[2,28]),{13:[1,84],16:37,17:83,18:38,74:pe,80:ae,95:ne,97:se,98:de},{49:85,57:54,58:55,59:W,60:xe,61:U,62:Fe,63:Pe,64:je,65:Ie},i(ge,[2,46]),{58:86,64:je,65:Ie},i(Ft,[2,62],{57:87,59:W,60:xe,61:U,62:Fe,63:Pe}),i(Ne,[2,63]),i(Ne,[2,64]),i(Ne,[2,65]),i(Ne,[2,66]),i(Ne,[2,67]),i(gn,[2,68]),i(gn,[2,69]),{8:[1,89],23:90,38:88,41:22,44:v},{16:91,74:pe,80:ae,95:ne,97:se},{43:92,47:_t},{46:[1,94]},{13:[1,95]},{13:[1,96]},{70:[1,97],72:[1,98]},{21:Et,73:Gt,74:ln,75:99,77:100,79:101,80:xt,81:Pt,82:Qe,83:Dt,84:kt,85:On},{74:[1,111]},{13:Ce,51:112},i(ge,[2,54]),i(ge,[2,117]),i(ke,[2,13]),i(ke,[2,14]),i(ke,[2,15]),{37:[2,32]},{15:113,16:79,37:[2,9],74:pe,80:ae,95:ne,97:se},i(ht,[2,40],{11:114,12:[1,115]}),i(X,[2,7]),{9:[1,116]},i(zr,[2,49]),{16:37,17:117,18:38,74:pe,80:ae,95:ne,97:se,98:de},{13:[1,119],16:37,17:118,18:38,74:pe,80:ae,95:ne,97:se,98:de},i(Ft,[2,61],{57:120,59:W,60:xe,61:U,62:Fe,63:Pe}),i(Ft,[2,60]),{39:[1,121]},{23:90,38:122,41:22,44:v},{8:[1,123],39:[2,33]},i(Se,[2,37],{37:[1,124]}),{39:[1,125]},{39:[2,43],43:126,47:_t},{16:37,17:127,18:38,74:pe,80:ae,95:ne,97:se,98:de},i(ge,[2,70],{13:[1,128]}),i(ge,[2,72],{13:[1,130],68:[1,129]}),i(ge,[2,76],{13:[1,131],71:[1,132]}),{13:[1,133]},i(ge,[2,84],{78:[1,134]}),i(yt,[2,86],{79:135,21:Et,73:Gt,74:ln,80:xt,81:Pt,82:Qe,83:Dt,84:kt,85:On}),i(ji,[2,88]),i(ji,[2,90]),i(ji,[2,91]),i(ji,[2,92]),i(ji,[2,93]),i(ji,[2,94]),i(ji,[2,95]),i(ji,[2,96]),i(ji,[2,97]),i(ji,[2,98]),i(ge,[2,85]),i(ge,[2,53]),{37:[2,10]},i(ht,[2,41]),{13:[1,136]},{1:[2,4]},i(zr,[2,51]),i(zr,[2,50]),{16:37,17:137,18:38,74:pe,80:ae,95:ne,97:se,98:de},i(Ft,[2,59]),i(ge,[2,30]),{39:[1,138]},{23:90,38:139,39:[2,34],41:22,44:v},{43:140,47:_t},i(Se,[2,38]),{39:[2,44]},i(ge,[2,42]),i(ge,[2,71]),i(ge,[2,73]),i(ge,[2,74],{68:[1,141]}),i(ge,[2,77]),i(ge,[2,78],{13:[1,142]}),i(ge,[2,80],{13:[1,144],68:[1,143]}),{21:Et,73:Gt,74:ln,77:145,79:101,80:xt,81:Pt,82:Qe,83:Dt,84:kt,85:On},i(ji,[2,89]),{14:[1,146]},i(zr,[2,52]),i(ge,[2,31]),{39:[2,35]},{39:[1,147]},i(ge,[2,75]),i(ge,[2,79]),i(ge,[2,81]),i(ge,[2,82],{68:[1,148]}),i(yt,[2,87],{79:135,21:Et,73:Gt,74:ln,80:xt,81:Pt,82:Qe,83:Dt,84:kt,85:On}),i(ht,[2,8]),i(Se,[2,39]),i(ge,[2,83])],defaultActions:{2:[2,1],3:[2,2],4:[2,3],78:[2,32],113:[2,10],116:[2,4],126:[2,44],139:[2,35]},parseError:function(Tr,Fn){if(Fn.recoverable)this.trace(Tr);else{var qn=new Error(Tr);throw qn.hash=Fn,qn}},parse:function(Tr){var Fn=this,qn=[0],Un=[],At=[null],wt=[],on=this.table,fn="",An=0,oo=0,jo=2,$o=1,Pa=wt.slice.call(arguments,1),wo=Object.create(this.lexer),_s={yy:{}};for(var tl in this.yy)Object.prototype.hasOwnProperty.call(this.yy,tl)&&(_s.yy[tl]=this.yy[tl]);wo.setInput(Tr,_s.yy),_s.yy.lexer=wo,_s.yy.parser=this,typeof wo.yylloc>"u"&&(wo.yylloc={});var da=wo.yylloc;wt.push(da);var j0=wo.options&&wo.options.ranges;typeof _s.yy.parseError=="function"?this.parseError=_s.yy.parseError:this.parseError=Object.getPrototypeOf(this).parseError;function pm(){var ga;return ga=Un.pop()||wo.lex()||$o,typeof ga!="number"&&(ga instanceof Array&&(Un=ga,ga=Un.pop()),ga=Fn.symbols_[ga]||ga),ga}for(var Ml,Xc,Bc,ja,Ou={},Sa,Po,Fc,xa;;){if(Xc=qn[qn.length-1],this.defaultActions[Xc]?Bc=this.defaultActions[Xc]:((Ml===null||typeof Ml>"u")&&(Ml=pm()),Bc=on[Xc]&&on[Xc][Ml]),typeof Bc>"u"||!Bc.length||!Bc[0]){var Ba="";xa=[];for(Sa in on[Xc])this.terminals_[Sa]&&Sa>jo&&xa.push("'"+this.terminals_[Sa]+"'");wo.showPosition?Ba="Parse error on line "+(An+1)+`: +`+wo.showPosition()+` +Expecting `+xa.join(", ")+", got '"+(this.terminals_[Ml]||Ml)+"'":Ba="Parse error on line "+(An+1)+": Unexpected "+(Ml==$o?"end of input":"'"+(this.terminals_[Ml]||Ml)+"'"),this.parseError(Ba,{text:wo.match,token:this.terminals_[Ml]||Ml,line:wo.yylineno,loc:da,expected:xa})}if(Bc[0]instanceof Array&&Bc.length>1)throw new Error("Parse Error: multiple actions possible at state: "+Xc+", token: "+Ml);switch(Bc[0]){case 1:qn.push(Ml),At.push(wo.yytext),wt.push(wo.yylloc),qn.push(Bc[1]),Ml=null,oo=wo.yyleng,fn=wo.yytext,An=wo.yylineno,da=wo.yylloc;break;case 2:if(Po=this.productions_[Bc[1]][1],Ou.$=At[At.length-Po],Ou._$={first_line:wt[wt.length-(Po||1)].first_line,last_line:wt[wt.length-1].last_line,first_column:wt[wt.length-(Po||1)].first_column,last_column:wt[wt.length-1].last_column},j0&&(Ou._$.range=[wt[wt.length-(Po||1)].range[0],wt[wt.length-1].range[1]]),ja=this.performAction.apply(Ou,[fn,oo,An,_s.yy,Bc[1],At,wt].concat(Pa)),typeof ja<"u")return ja;Po&&(qn=qn.slice(0,-1*Po*2),At=At.slice(0,-1*Po),wt=wt.slice(0,-1*Po)),qn.push(this.productions_[Bc[1]][0]),At.push(Ou.$),wt.push(Ou._$),Fc=on[qn[qn.length-2]][qn[qn.length-1]],qn.push(Fc);break;case 3:return!0}}return!0}},Ma=function(){var ao={EOF:1,parseError:function(Fn,qn){if(this.yy.parser)this.yy.parser.parseError(Fn,qn);else throw new Error(Fn)},setInput:function(Tr,Fn){return this.yy=Fn||this.yy||{},this._input=Tr,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},input:function(){var Tr=this._input[0];this.yytext+=Tr,this.yyleng++,this.offset++,this.match+=Tr,this.matched+=Tr;var Fn=Tr.match(/(?:\r\n?|\n).*/g);return Fn?(this.yylineno++,this.yylloc.last_line++):this.yylloc.last_column++,this.options.ranges&&this.yylloc.range[1]++,this._input=this._input.slice(1),Tr},unput:function(Tr){var Fn=Tr.length,qn=Tr.split(/(?:\r\n?|\n)/g);this._input=Tr+this._input,this.yytext=this.yytext.substr(0,this.yytext.length-Fn),this.offset-=Fn;var Un=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),qn.length-1&&(this.yylineno-=qn.length-1);var At=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:qn?(qn.length===Un.length?this.yylloc.first_column:0)+Un[Un.length-qn.length].length-qn[0].length:this.yylloc.first_column-Fn},this.options.ranges&&(this.yylloc.range=[At[0],At[0]+this.yyleng-Fn]),this.yyleng=this.yytext.length,this},more:function(){return this._more=!0,this},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},less:function(Tr){this.unput(this.match.slice(Tr))},pastInput:function(){var Tr=this.matched.substr(0,this.matched.length-this.match.length);return(Tr.length>20?"...":"")+Tr.substr(-20).replace(/\n/g,"")},upcomingInput:function(){var Tr=this.match;return Tr.length<20&&(Tr+=this._input.substr(0,20-Tr.length)),(Tr.substr(0,20)+(Tr.length>20?"...":"")).replace(/\n/g,"")},showPosition:function(){var Tr=this.pastInput(),Fn=new Array(Tr.length+1).join("-");return Tr+this.upcomingInput()+` +`+Fn+"^"},test_match:function(Tr,Fn){var qn,Un,At;if(this.options.backtrack_lexer&&(At={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&&(At.yylloc.range=this.yylloc.range.slice(0))),Un=Tr[0].match(/(?:\r\n?|\n).*/g),Un&&(this.yylineno+=Un.length),this.yylloc={first_line:this.yylloc.last_line,last_line:this.yylineno+1,first_column:this.yylloc.last_column,last_column:Un?Un[Un.length-1].length-Un[Un.length-1].match(/\r?\n?/)[0].length:this.yylloc.last_column+Tr[0].length},this.yytext+=Tr[0],this.match+=Tr[0],this.matches=Tr,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(Tr[0].length),this.matched+=Tr[0],qn=this.performAction.call(this,this.yy,this,Fn,this.conditionStack[this.conditionStack.length-1]),this.done&&this._input&&(this.done=!1),qn)return qn;if(this._backtrack){for(var wt in At)this[wt]=At[wt];return!1}return!1},next:function(){if(this.done)return this.EOF;this._input||(this.done=!0);var Tr,Fn,qn,Un;this._more||(this.yytext="",this.match="");for(var At=this._currentRules(),wt=0;wtFn[0].length)){if(Fn=qn,Un=wt,this.options.backtrack_lexer){if(Tr=this.test_match(qn,At[wt]),Tr!==!1)return Tr;if(this._backtrack){Fn=!1;continue}else return!1}else if(!this.options.flex)break}return Fn?(Tr=this.test_match(Fn,At[Un]),Tr!==!1?Tr:!1):this._input===""?this.EOF:this.parseError("Lexical error on line "+(this.yylineno+1)+`. Unrecognized text. +`+this.showPosition(),{text:"",token:null,line:this.yylineno})},lex:function(){var Fn=this.next();return Fn||this.lex()},begin:function(Fn){this.conditionStack.push(Fn)},popState:function(){var Fn=this.conditionStack.length-1;return Fn>0?this.conditionStack.pop():this.conditionStack[0]},_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},topState:function(Fn){return Fn=this.conditionStack.length-1-Math.abs(Fn||0),Fn>=0?this.conditionStack[Fn]:"INITIAL"},pushState:function(Fn){this.begin(Fn)},stateStackSize:function(){return this.conditionStack.length},options:{},performAction:function(Fn,qn,Un,At){switch(Un){case 0:return 53;case 1:return 54;case 2:return 55;case 3:return 56;case 4:break;case 5:break;case 6:return this.begin("acc_title"),31;case 7:return this.popState(),"acc_title_value";case 8:return this.begin("acc_descr"),33;case 9:return this.popState(),"acc_descr_value";case 10:this.begin("acc_descr_multiline");break;case 11:this.popState();break;case 12:return"acc_descr_multiline_value";case 13:return 8;case 14:break;case 15:return 7;case 16:return 7;case 17:return"EDGE_STATE";case 18:this.begin("callback_name");break;case 19:this.popState();break;case 20:this.popState(),this.begin("callback_args");break;case 21:return 70;case 22:this.popState();break;case 23:return 71;case 24:this.popState();break;case 25:return"STR";case 26:this.begin("string");break;case 27:return 73;case 28:return this.begin("namespace"),40;case 29:return this.popState(),8;case 30:break;case 31:return this.begin("namespace-body"),37;case 32:return this.popState(),39;case 33:return"EOF_IN_STRUCT";case 34:return 8;case 35:break;case 36:return"EDGE_STATE";case 37:return this.begin("class"),44;case 38:return this.popState(),8;case 39:break;case 40:return this.popState(),this.popState(),39;case 41:return this.begin("class-body"),37;case 42:return this.popState(),39;case 43:return"EOF_IN_STRUCT";case 44:return"EDGE_STATE";case 45:return"OPEN_IN_STRUCT";case 46:break;case 47:return"MEMBER";case 48:return 76;case 49:return 66;case 50:return 67;case 51:return 69;case 52:return 50;case 53:return 52;case 54:return 45;case 55:return 46;case 56:return 72;case 57:this.popState();break;case 58:return"GENERICTYPE";case 59:this.begin("generic");break;case 60:this.popState();break;case 61:return"BQUOTE_STR";case 62:this.begin("bqstring");break;case 63:return 68;case 64:return 68;case 65:return 68;case 66:return 68;case 67:return 60;case 68:return 60;case 69:return 62;case 70:return 62;case 71:return 61;case 72:return 59;case 73:return 63;case 74:return 64;case 75:return 65;case 76:return 21;case 77:return 42;case 78:return 95;case 79:return"DOT";case 80:return"PLUS";case 81:return 81;case 82:return 78;case 83:return 84;case 84:return 84;case 85:return 85;case 86:return"EQUALS";case 87:return"EQUALS";case 88:return 74;case 89:return 12;case 90:return 14;case 91:return"PUNCTUATION";case 92:return 80;case 93:return 97;case 94:return 83;case 95:return 83;case 96:return 9}},rules:[/^(?:.*direction\s+TB[^\n]*)/,/^(?:.*direction\s+BT[^\n]*)/,/^(?:.*direction\s+RL[^\n]*)/,/^(?:.*direction\s+LR[^\n]*)/,/^(?:%%(?!\{)*[^\n]*(\r?\n?)+)/,/^(?:%%[^\n]*(\r?\n)*)/,/^(?:accTitle\s*:\s*)/,/^(?:(?!\n||)*[^\n]*)/,/^(?:accDescr\s*:\s*)/,/^(?:(?!\n||)*[^\n]*)/,/^(?:accDescr\s*\{\s*)/,/^(?:[\}])/,/^(?:[^\}]*)/,/^(?:\s*(\r?\n)+)/,/^(?:\s+)/,/^(?:classDiagram-v2\b)/,/^(?:classDiagram\b)/,/^(?:\[\*\])/,/^(?:call[\s]+)/,/^(?:\([\s]*\))/,/^(?:\()/,/^(?:[^(]*)/,/^(?:\))/,/^(?:[^)]*)/,/^(?:["])/,/^(?:[^"]*)/,/^(?:["])/,/^(?:style\b)/,/^(?:namespace\b)/,/^(?:\s*(\r?\n)+)/,/^(?:\s+)/,/^(?:[{])/,/^(?:[}])/,/^(?:$)/,/^(?:\s*(\r?\n)+)/,/^(?:\s+)/,/^(?:\[\*\])/,/^(?:class\b)/,/^(?:\s*(\r?\n)+)/,/^(?:\s+)/,/^(?:[}])/,/^(?:[{])/,/^(?:[}])/,/^(?:$)/,/^(?:\[\*\])/,/^(?:[{])/,/^(?:[\n])/,/^(?:[^{}\n]*)/,/^(?:cssClass\b)/,/^(?:callback\b)/,/^(?:link\b)/,/^(?:click\b)/,/^(?:note for\b)/,/^(?:note\b)/,/^(?:<<)/,/^(?:>>)/,/^(?:href\b)/,/^(?:[~])/,/^(?:[^~]*)/,/^(?:~)/,/^(?:[`])/,/^(?:[^`]+)/,/^(?:[`])/,/^(?:_self\b)/,/^(?:_blank\b)/,/^(?:_parent\b)/,/^(?:_top\b)/,/^(?:\s*<\|)/,/^(?:\s*\|>)/,/^(?:\s*>)/,/^(?:\s*<)/,/^(?:\s*\*)/,/^(?:\s*o\b)/,/^(?:\s*\(\))/,/^(?:--)/,/^(?:\.\.)/,/^(?::{1}[^:\n;]+)/,/^(?::{3})/,/^(?:-)/,/^(?:\.)/,/^(?:\+)/,/^(?::)/,/^(?:,)/,/^(?:#)/,/^(?:#)/,/^(?:%)/,/^(?:=)/,/^(?:=)/,/^(?:\w+)/,/^(?:\[)/,/^(?:\])/,/^(?:[!"#$%&'*+,-.`?\\/])/,/^(?:[0-9]+)/,/^(?:[\u00AA\u00B5\u00BA\u00C0-\u00D6\u00D8-\u00F6]|[\u00F8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377]|[\u037A-\u037D\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5]|[\u03F7-\u0481\u048A-\u0527\u0531-\u0556\u0559\u0561-\u0587\u05D0-\u05EA]|[\u05F0-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE]|[\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA]|[\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u08A0]|[\u08A2-\u08AC\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0977]|[\u0979-\u097F\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2]|[\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u0A05-\u0A0A]|[\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39]|[\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8]|[\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0B05-\u0B0C]|[\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C]|[\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99]|[\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0]|[\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C33\u0C35-\u0C39\u0C3D]|[\u0C58\u0C59\u0C60\u0C61\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3]|[\u0CB5-\u0CB9\u0CBD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D05-\u0D0C\u0D0E-\u0D10]|[\u0D12-\u0D3A\u0D3D\u0D4E\u0D60\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1]|[\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81]|[\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3]|[\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6]|[\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A]|[\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081]|[\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D]|[\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0]|[\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310]|[\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F4\u1401-\u166C]|[\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u1700-\u170C\u170E-\u1711]|[\u1720-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7]|[\u17DC\u1820-\u1877\u1880-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191C]|[\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19C1-\u19C7\u1A00-\u1A16]|[\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4B\u1B83-\u1BA0\u1BAE\u1BAF]|[\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1CE9-\u1CEC]|[\u1CEE-\u1CF1\u1CF5\u1CF6\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D]|[\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D]|[\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3]|[\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F]|[\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128]|[\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2183\u2184]|[\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3]|[\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6]|[\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE]|[\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005\u3006\u3031-\u3035\u303B\u303C]|[\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312D]|[\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FCC]|[\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B]|[\uA640-\uA66E\uA67F-\uA697\uA6A0-\uA6E5\uA717-\uA71F\uA722-\uA788]|[\uA78B-\uA78E\uA790-\uA793\uA7A0-\uA7AA\uA7F8-\uA801\uA803-\uA805]|[\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB]|[\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uAA00-\uAA28]|[\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA80-\uAAAF\uAAB1\uAAB5]|[\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4]|[\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E]|[\uABC0-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D]|[\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36]|[\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D]|[\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC]|[\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF]|[\uFFD2-\uFFD7\uFFDA-\uFFDC])/,/^(?:\s)/,/^(?:\s)/,/^(?:$)/],conditions:{"namespace-body":{rules:[26,32,33,34,35,36,37,48,49,50,51,52,53,54,55,56,59,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,85,86,87,88,89,90,91,92,93,94,96],inclusive:!1},namespace:{rules:[26,28,29,30,31,48,49,50,51,52,53,54,55,56,59,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,85,86,87,88,89,90,91,92,93,94,96],inclusive:!1},"class-body":{rules:[26,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,59,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,85,86,87,88,89,90,91,92,93,94,96],inclusive:!1},class:{rules:[26,38,39,40,41,48,49,50,51,52,53,54,55,56,59,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,85,86,87,88,89,90,91,92,93,94,96],inclusive:!1},acc_descr_multiline:{rules:[11,12,26,48,49,50,51,52,53,54,55,56,59,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,85,86,87,88,89,90,91,92,93,94,96],inclusive:!1},acc_descr:{rules:[9,26,48,49,50,51,52,53,54,55,56,59,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,85,86,87,88,89,90,91,92,93,94,96],inclusive:!1},acc_title:{rules:[7,26,48,49,50,51,52,53,54,55,56,59,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,85,86,87,88,89,90,91,92,93,94,96],inclusive:!1},callback_args:{rules:[22,23,26,48,49,50,51,52,53,54,55,56,59,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,85,86,87,88,89,90,91,92,93,94,96],inclusive:!1},callback_name:{rules:[19,20,21,26,48,49,50,51,52,53,54,55,56,59,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,85,86,87,88,89,90,91,92,93,94,96],inclusive:!1},href:{rules:[26,48,49,50,51,52,53,54,55,56,59,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,85,86,87,88,89,90,91,92,93,94,96],inclusive:!1},struct:{rules:[26,48,49,50,51,52,53,54,55,56,59,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,85,86,87,88,89,90,91,92,93,94,96],inclusive:!1},generic:{rules:[26,48,49,50,51,52,53,54,55,56,57,58,59,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,85,86,87,88,89,90,91,92,93,94,96],inclusive:!1},bqstring:{rules:[26,48,49,50,51,52,53,54,55,56,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,85,86,87,88,89,90,91,92,93,94,96],inclusive:!1},string:{rules:[24,25,26,48,49,50,51,52,53,54,55,56,59,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,85,86,87,88,89,90,91,92,93,94,96],inclusive:!1},INITIAL:{rules:[0,1,2,3,4,5,6,8,10,13,14,15,16,17,18,26,27,28,37,48,49,50,51,52,53,54,55,56,59,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96],inclusive:!0}}};return ao}();xi.lexer=Ma;function zs(){this.yy={}}return zs.prototype=xi,xi.Parser=zs,new zs}();_ve.parser=_ve;const KGe=_ve,WGe=["#","+","~","-",""];class YGe{constructor(s,u){this.memberType=u,this.visibility="",this.classifier="";const d=Yf(s,qt());this.parseMember(d)}getDisplayDetails(){let s=this.visibility+qF(this.id);this.memberType==="method"&&(s+=`(${qF(this.parameters.trim())})`,this.returnType&&(s+=" : "+qF(this.returnType))),s=s.trim();const u=this.parseClassifier();return{displayText:s,cssStyle:u}}parseMember(s){let u="";if(this.memberType==="method"){const d=/([#+~-])?(.+)\((.*)\)([\s$*])?(.*)([$*])?/,p=s.match(d);if(p){const v=p[1]?p[1].trim():"";if(WGe.includes(v)&&(this.visibility=v),this.id=p[2].trim(),this.parameters=p[3]?p[3].trim():"",u=p[4]?p[4].trim():"",this.returnType=p[5]?p[5].trim():"",u===""){const b=this.returnType.substring(this.returnType.length-1);b.match(/[$*]/)&&(u=b,this.returnType=this.returnType.substring(0,this.returnType.length-1))}}}else{const d=s.length,p=s.substring(0,1),v=s.substring(d-1);WGe.includes(p)&&(this.visibility=p),v.match(/[$*]/)&&(u=v),this.id=s.substring(this.visibility===""?0:1,u===""?d:d-1)}this.classifier=u}parseClassifier(){switch(this.classifier){case"*":return"font-style:italic;";case"$":return"text-decoration:underline;";default:return""}}}const mJ="classId-";let Ave=[],xh={},vJ=[],XGe=0,R9={},Lve=0,WR=[];const tS=i=>ci.sanitizeText(i,qt()),nS=function(i){const s=ci.sanitizeText(i,qt());let u="",d=s;if(s.indexOf("~")>0){const p=s.split("~");d=tS(p[0]),u=tS(p[1])}return{className:d,type:u}},Ein=function(i,s){const u=ci.sanitizeText(i,qt());s&&(s=tS(s));const{className:d}=nS(u);xh[d].label=s},wJ=function(i){const s=ci.sanitizeText(i,qt()),{className:u,type:d}=nS(s);if(Object.hasOwn(xh,u))return;const p=ci.sanitizeText(u,qt());xh[p]={id:p,type:d,label:p,cssClasses:[],methods:[],members:[],annotations:[],styles:[],domId:mJ+p+"-"+XGe},XGe++},QGe=function(i){const s=ci.sanitizeText(i,qt());if(s in xh)return xh[s].domId;throw new Error("Class not found: "+s)},Tin=function(){Ave=[],xh={},vJ=[],WR=[],WR.push(ZGe),R9={},Lve=0,Pg()},Cin=function(i){return xh[i]},Sin=function(){return xh},_in=function(){return Ave},Ain=function(){return vJ},Lin=function(i){Xe.debug("Adding relation: "+JSON.stringify(i)),wJ(i.id1),wJ(i.id2),i.id1=nS(i.id1).className,i.id2=nS(i.id2).className,i.relationTitle1=ci.sanitizeText(i.relationTitle1.trim(),qt()),i.relationTitle2=ci.sanitizeText(i.relationTitle2.trim(),qt()),Ave.push(i)},Min=function(i,s){const u=nS(i).className;xh[u].annotations.push(s)},JGe=function(i,s){wJ(i);const u=nS(i).className,d=xh[u];if(typeof s=="string"){const p=s.trim();p.startsWith("<<")&&p.endsWith(">>")?d.annotations.push(tS(p.substring(2,p.length-2))):p.indexOf(")")>0?d.methods.push(new YGe(p,"method")):p&&d.members.push(new YGe(p,"attribute"))}},Din=function(i,s){Array.isArray(s)&&(s.reverse(),s.forEach(u=>JGe(i,u)))},Iin=function(i,s){const u={id:`note${vJ.length}`,class:s,text:i};vJ.push(u)},Oin=function(i){return i.startsWith(":")&&(i=i.substring(1)),tS(i.trim())},Mve=function(i,s){i.split(",").forEach(function(u){let d=u;u[0].match(/\d/)&&(d=mJ+d),xh[d]!==void 0&&xh[d].cssClasses.push(s)})},Nin=function(i,s){i.split(",").forEach(function(u){s!==void 0&&(xh[u].tooltip=tS(s))})},Pin=function(i,s){return s?R9[s].classes[i].tooltip:xh[i].tooltip},Bin=function(i,s,u){const d=qt();i.split(",").forEach(function(p){let v=p;p[0].match(/\d/)&&(v=mJ+v),xh[v]!==void 0&&(xh[v].link=Ao.formatUrl(s,d),d.securityLevel==="sandbox"?xh[v].linkTarget="_top":typeof u=="string"?xh[v].linkTarget=tS(u):xh[v].linkTarget="_blank")}),Mve(i,"clickable")},Fin=function(i,s,u){i.split(",").forEach(function(d){Rin(d,s,u),xh[d].haveCallback=!0}),Mve(i,"clickable")},Rin=function(i,s,u){const d=ci.sanitizeText(i,qt());if(qt().securityLevel!=="loose"||s===void 0)return;const v=d;if(xh[v]!==void 0){const b=QGe(v);let y=[];if(typeof u=="string"){y=u.split(/,(?=(?:(?:[^"]*"){2})*[^"]*$)/);for(let T=0;T")),p.classed("hover",!0)}).on("mouseout",function(){s.transition().duration(500).style("opacity",0),Ir(this).classed("hover",!1)})};WR.push(ZGe);let eKe="TB";const yJ={setAccTitle:Bg,getAccTitle:Cp,getAccDescription:_p,setAccDescription:Sp,getConfig:()=>qt().class,addClass:wJ,bindFunctions:jin,clear:Tin,getClass:Cin,getClasses:Sin,getNotes:Ain,addAnnotation:Min,addNote:Iin,getRelations:_in,addRelation:Lin,getDirection:()=>eKe,setDirection:i=>{eKe=i},addMember:JGe,addMembers:Din,cleanupLabel:Oin,lineType:$in,relationType:zin,setClickEvent:Fin,setCssClass:Mve,setLink:Bin,getTooltip:Pin,setTooltip:Nin,lookUpDomId:QGe,setDiagramTitle:cm,getDiagramTitle:Ap,setClassLabel:Ein,addNamespace:function(i){R9[i]===void 0&&(R9[i]={id:i,classes:{},children:{},domId:mJ+i+"-"+Lve},Lve++)},addClassesToNamespace:function(i,s){if(R9[i]!==void 0)for(const u of s){const{className:d}=nS(u);xh[d].parent=i,R9[i].classes[d]=xh[d]}},getNamespace:function(i){return R9[i]},getNamespaces:function(){return R9},setCssStyle:function(i,s){const u=xh[i];if(!(!s||!u))for(const d of s)d.includes(",")?u.styles.push(...d.split(",")):u.styles.push(d)}},tKe=i=>`g.classGroup text { + fill: ${i.nodeBorder||i.classText}; + stroke: none; + font-family: ${i.fontFamily}; + font-size: 10px; + + .title { + font-weight: bolder; + } + +} + +.nodeLabel, .edgeLabel { + color: ${i.classText}; +} +.edgeLabel .label rect { + fill: ${i.mainBkg}; +} +.label text { + fill: ${i.classText}; +} +.edgeLabel .label span { + background: ${i.mainBkg}; +} + +.classTitle { + font-weight: bolder; +} +.node rect, + .node circle, + .node ellipse, + .node polygon, + .node path { + fill: ${i.mainBkg}; + stroke: ${i.nodeBorder}; + stroke-width: 1px; + } + + +.divider { + stroke: ${i.nodeBorder}; + stroke-width: 1; +} + +g.clickable { + cursor: pointer; +} + +g.classGroup rect { + fill: ${i.mainBkg}; + stroke: ${i.nodeBorder}; +} + +g.classGroup line { + stroke: ${i.nodeBorder}; + stroke-width: 1; +} + +.classLabel .box { + stroke: none; + stroke-width: 0; + fill: ${i.mainBkg}; + opacity: 0.5; +} + +.classLabel .label { + fill: ${i.nodeBorder}; + font-size: 10px; +} + +.relation { + stroke: ${i.lineColor}; + stroke-width: 1; + fill: none; +} + +.dashed-line{ + stroke-dasharray: 3; +} + +.dotted-line{ + stroke-dasharray: 1 2; +} + +#compositionStart, .composition { + fill: ${i.lineColor} !important; + stroke: ${i.lineColor} !important; + stroke-width: 1; +} + +#compositionEnd, .composition { + fill: ${i.lineColor} !important; + stroke: ${i.lineColor} !important; + stroke-width: 1; +} + +#dependencyStart, .dependency { + fill: ${i.lineColor} !important; + stroke: ${i.lineColor} !important; + stroke-width: 1; +} + +#dependencyStart, .dependency { + fill: ${i.lineColor} !important; + stroke: ${i.lineColor} !important; + stroke-width: 1; +} + +#extensionStart, .extension { + fill: transparent !important; + stroke: ${i.lineColor} !important; + stroke-width: 1; +} + +#extensionEnd, .extension { + fill: transparent !important; + stroke: ${i.lineColor} !important; + stroke-width: 1; +} + +#aggregationStart, .aggregation { + fill: transparent !important; + stroke: ${i.lineColor} !important; + stroke-width: 1; +} + +#aggregationEnd, .aggregation { + fill: transparent !important; + stroke: ${i.lineColor} !important; + stroke-width: 1; +} + +#lollipopStart, .lollipop { + fill: ${i.mainBkg} !important; + stroke: ${i.lineColor} !important; + stroke-width: 1; +} + +#lollipopEnd, .lollipop { + fill: ${i.mainBkg} !important; + stroke: ${i.lineColor} !important; + stroke-width: 1; +} + +.edgeTerminals { + font-size: 11px; + line-height: initial; +} + +.classTitleText { + text-anchor: middle; + font-size: 18px; + fill: ${i.textColor}; +} +`;let nKe=0;const qin=function(i,s,u,d,p){const v=function(oe){switch(oe){case p.db.relationType.AGGREGATION:return"aggregation";case p.db.relationType.EXTENSION:return"extension";case p.db.relationType.COMPOSITION:return"composition";case p.db.relationType.DEPENDENCY:return"dependency";case p.db.relationType.LOLLIPOP:return"lollipop"}};s.points=s.points.filter(oe=>!Number.isNaN(oe.y));const b=s.points,y=k7().x(function(oe){return oe.x}).y(function(oe){return oe.y}).curve(FF),T=i.append("path").attr("d",y(b)).attr("id","edge"+nKe).attr("class","relation");let _="";d.arrowMarkerAbsolute&&(_=window.location.protocol+"//"+window.location.host+window.location.pathname+window.location.search,_=_.replace(/\(/g,"\\("),_=_.replace(/\)/g,"\\)")),u.relation.lineType==1&&T.attr("class","relation dashed-line"),u.relation.lineType==10&&T.attr("class","relation dotted-line"),u.relation.type1!=="none"&&T.attr("marker-start","url("+_+"#"+v(u.relation.type1)+"Start)"),u.relation.type2!=="none"&&T.attr("marker-end","url("+_+"#"+v(u.relation.type2)+"End)");let A,P;const R=s.points.length;let F=Ao.calcLabelPosition(s.points);A=F.x,P=F.y;let j,K,ee,ie;if(R%2!==0&&R>1){let oe=Ao.calcCardinalityPosition(u.relation.type1!=="none",s.points,s.points[0]),pe=Ao.calcCardinalityPosition(u.relation.type2!=="none",s.points,s.points[R-1]);Xe.debug("cardinality_1_point "+JSON.stringify(oe)),Xe.debug("cardinality_2_point "+JSON.stringify(pe)),j=oe.x,K=oe.y,ee=pe.x,ie=pe.y}if(u.title!==void 0){const oe=i.append("g").attr("class","classLabel"),pe=oe.append("text").attr("class","label").attr("x",A).attr("y",P).attr("fill","red").attr("text-anchor","middle").text(u.title);window.label=pe;const be=pe.node().getBBox();oe.insert("rect",":first-child").attr("class","box").attr("x",be.x-d.padding/2).attr("y",be.y-d.padding/2).attr("width",be.width+d.padding).attr("height",be.height+d.padding)}Xe.info("Rendering relation "+JSON.stringify(u)),u.relationTitle1!==void 0&&u.relationTitle1!=="none"&&i.append("g").attr("class","cardinality").append("text").attr("class","type1").attr("x",j).attr("y",K).attr("fill","black").attr("font-size","6").text(u.relationTitle1),u.relationTitle2!==void 0&&u.relationTitle2!=="none"&&i.append("g").attr("class","cardinality").append("text").attr("class","type2").attr("x",ee).attr("y",ie).attr("fill","black").attr("font-size","6").text(u.relationTitle2),nKe++},Hin=function(i,s,u,d){Xe.debug("Rendering class ",s,u);const p=s.id,v={id:p,label:s.id,width:0,height:0},b=i.append("g").attr("id",d.db.lookUpDomId(p)).attr("class","classGroup");let y;s.link?y=b.append("svg:a").attr("xlink:href",s.link).attr("target",s.linkTarget).append("text").attr("y",u.textHeight+u.padding).attr("x",0):y=b.append("text").attr("y",u.textHeight+u.padding).attr("x",0);let T=!0;s.annotations.forEach(function(pe){const be=y.append("tspan").text("«"+pe+"»");T||be.attr("dy",u.textHeight),T=!1});let _=rKe(s);const A=y.append("tspan").text(_).attr("class","title");T||A.attr("dy",u.textHeight);const P=y.node().getBBox().height;let R,F,j;if(s.members.length>0){R=b.append("line").attr("x1",0).attr("y1",u.padding+P+u.dividerMargin/2).attr("y2",u.padding+P+u.dividerMargin/2);const pe=b.append("text").attr("x",u.padding).attr("y",P+u.dividerMargin+u.textHeight).attr("fill","white").attr("class","classText");T=!0,s.members.forEach(function(be){iKe(pe,be,T,u),T=!1}),F=pe.node().getBBox()}if(s.methods.length>0){j=b.append("line").attr("x1",0).attr("y1",u.padding+P+u.dividerMargin+F.height).attr("y2",u.padding+P+u.dividerMargin+F.height);const pe=b.append("text").attr("x",u.padding).attr("y",P+2*u.dividerMargin+F.height+u.textHeight).attr("fill","white").attr("class","classText");T=!0,s.methods.forEach(function(be){iKe(pe,be,T,u),T=!1})}const K=b.node().getBBox();var ee=" ";s.cssClasses.length>0&&(ee=ee+s.cssClasses.join(" "));const oe=b.insert("rect",":first-child").attr("x",0).attr("y",0).attr("width",K.width+2*u.padding).attr("height",K.height+u.padding+.5*u.dividerMargin).attr("class",ee).node().getBBox().width;return y.node().childNodes.forEach(function(pe){pe.setAttribute("x",(oe-pe.getBBox().width)/2)}),s.tooltip&&y.insert("title").text(s.tooltip),R&&R.attr("x2",oe),j&&j.attr("x2",oe),v.width=oe,v.height=K.height+u.padding+.5*u.dividerMargin,v},rKe=function(i){let s=i.id;return i.type&&(s+="<"+qF(i.type)+">"),s},Vin=function(i,s,u,d){Xe.debug("Rendering note ",s,u);const p=s.id,v={id:p,text:s.text,width:0,height:0},b=i.append("g").attr("id",p).attr("class","classGroup");let y=b.append("text").attr("y",u.textHeight+u.padding).attr("x",0);const T=JSON.parse(`"${s.text}"`).split(` +`);T.forEach(function(R){Xe.debug(`Adding line: ${R}`),y.append("tspan").text(R).attr("class","title").attr("dy",u.textHeight)});const _=b.node().getBBox(),P=b.insert("rect",":first-child").attr("x",0).attr("y",0).attr("width",_.width+2*u.padding).attr("height",_.height+T.length*u.textHeight+u.padding+.5*u.dividerMargin).node().getBBox().width;return y.node().childNodes.forEach(function(R){R.setAttribute("x",(P-R.getBBox().width)/2)}),v.width=P,v.height=_.height+T.length*u.textHeight+u.padding+.5*u.dividerMargin,v},iKe=function(i,s,u,d){const{displayText:p,cssStyle:v}=s.getDisplayDetails(),b=i.append("tspan").attr("x",d.padding).text(p);v!==""&&b.attr("style",s.cssStyle),u||b.attr("dy",d.textHeight)},Dve={getClassTitleString:rKe,drawClass:Hin,drawEdge:qin,drawNote:Vin};let xJ={};const kJ=20,YR=function(i){const s=Object.entries(xJ).find(u=>u[1].label===i);if(s)return s[0]},Uin=function(i){i.append("defs").append("marker").attr("id","extensionStart").attr("class","extension").attr("refX",0).attr("refY",7).attr("markerWidth",190).attr("markerHeight",240).attr("orient","auto").append("path").attr("d","M 1,7 L18,13 V 1 Z"),i.append("defs").append("marker").attr("id","extensionEnd").attr("refX",19).attr("refY",7).attr("markerWidth",20).attr("markerHeight",28).attr("orient","auto").append("path").attr("d","M 1,1 V 13 L18,7 Z"),i.append("defs").append("marker").attr("id","compositionStart").attr("class","extension").attr("refX",0).attr("refY",7).attr("markerWidth",190).attr("markerHeight",240).attr("orient","auto").append("path").attr("d","M 18,7 L9,13 L1,7 L9,1 Z"),i.append("defs").append("marker").attr("id","compositionEnd").attr("refX",19).attr("refY",7).attr("markerWidth",20).attr("markerHeight",28).attr("orient","auto").append("path").attr("d","M 18,7 L9,13 L1,7 L9,1 Z"),i.append("defs").append("marker").attr("id","aggregationStart").attr("class","extension").attr("refX",0).attr("refY",7).attr("markerWidth",190).attr("markerHeight",240).attr("orient","auto").append("path").attr("d","M 18,7 L9,13 L1,7 L9,1 Z"),i.append("defs").append("marker").attr("id","aggregationEnd").attr("refX",19).attr("refY",7).attr("markerWidth",20).attr("markerHeight",28).attr("orient","auto").append("path").attr("d","M 18,7 L9,13 L1,7 L9,1 Z"),i.append("defs").append("marker").attr("id","dependencyStart").attr("class","extension").attr("refX",0).attr("refY",7).attr("markerWidth",190).attr("markerHeight",240).attr("orient","auto").append("path").attr("d","M 5,7 L9,13 L1,7 L9,1 Z"),i.append("defs").append("marker").attr("id","dependencyEnd").attr("refX",19).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")},Gin=Object.freeze(Object.defineProperty({__proto__:null,diagram:{parser:KGe,db:yJ,renderer:{draw:function(i,s,u,d){const p=qt().class;xJ={},Xe.info("Rendering diagram "+i);const v=qt().securityLevel;let b;v==="sandbox"&&(b=Ir("#i"+s));const y=Ir(v==="sandbox"?b.nodes()[0].contentDocument.body:"body"),T=y.select(`[id='${s}']`);Uin(T);const _=new B0({multigraph:!0});_.setGraph({isMultiGraph:!0}),_.setDefaultEdgeLabel(function(){return{}});const A=d.db.getClasses(),P=Object.keys(A);for(const oe of P){const pe=A[oe],be=Dve.drawClass(T,pe,p,d);xJ[be.id]=be,_.setNode(be.id,be),Xe.info("Org height: "+be.height)}d.db.getRelations().forEach(function(oe){Xe.info("tjoho"+YR(oe.id1)+YR(oe.id2)+JSON.stringify(oe)),_.setEdge(YR(oe.id1),YR(oe.id2),{relation:oe},oe.title||"DEFAULT")}),d.db.getNotes().forEach(function(oe){Xe.debug(`Adding note: ${JSON.stringify(oe)}`);const pe=Dve.drawNote(T,oe,p,d);xJ[pe.id]=pe,_.setNode(pe.id,pe),oe.class&&oe.class in A&&_.setEdge(oe.id,YR(oe.class),{relation:{id1:oe.id,id2:oe.class,relation:{type1:"none",type2:"none",lineType:10}}},"DEFAULT")}),qD(_),_.nodes().forEach(function(oe){oe!==void 0&&_.node(oe)!==void 0&&(Xe.debug("Node "+oe+": "+JSON.stringify(_.node(oe))),y.select("#"+(d.db.lookUpDomId(oe)||oe)).attr("transform","translate("+(_.node(oe).x-_.node(oe).width/2)+","+(_.node(oe).y-_.node(oe).height/2)+" )"))}),_.edges().forEach(function(oe){oe!==void 0&&_.edge(oe)!==void 0&&(Xe.debug("Edge "+oe.v+" -> "+oe.w+": "+JSON.stringify(_.edge(oe))),Dve.drawEdge(T,_.edge(oe),_.edge(oe).relation,p,d))});const j=T.node().getBBox(),K=j.width+kJ*2,ee=j.height+kJ*2;Ng(T,ee,K,p.useMaxWidth);const ie=`${j.x-kJ} ${j.y-kJ} ${K} ${ee}`;Xe.debug(`viewBox ${ie}`),T.attr("viewBox",ie)}},styles:tKe,init:i=>{i.class||(i.class={}),i.class.arrowMarkerAbsolute=i.arrowMarkerAbsolute,yJ.clear()}}},Symbol.toStringTag,{value:"Module"})),Ive=i=>ci.sanitizeText(i,qt());let Ove={dividerMargin:10,padding:5,textHeight:10,curve:void 0};const Kin=function(i,s,u,d){const p=Object.keys(i);Xe.info("keys:",p),Xe.info(i),p.forEach(function(v){var _,A;const b=i[v],T={shape:"rect",id:b.id,domId:b.domId,labelText:Ive(b.id),labelStyle:"",style:"fill: none; stroke: black",padding:((_=qt().flowchart)==null?void 0:_.padding)??((A=qt().class)==null?void 0:A.padding)};s.setNode(b.id,T),sKe(b.classes,s,u,d,b.id),Xe.info("setNode",T)})},sKe=function(i,s,u,d,p){const v=Object.keys(i);Xe.info("keys:",v),Xe.info(i),v.filter(b=>i[b].parent==p).forEach(function(b){var j,K;const y=i[b],T=y.cssClasses.join(" "),_=om(y.styles),A=y.label??y.id,P=0,R="class_box",F={labelStyle:_.labelStyle,shape:R,labelText:Ive(A),classData:y,rx:P,ry:P,class:T,style:_.style,id:y.id,domId:y.domId,tooltip:d.db.getTooltip(y.id,p)||"",haveCallback:y.haveCallback,link:y.link,width:y.type==="group"?500:void 0,type:y.type,padding:((j=qt().flowchart)==null?void 0:j.padding)??((K=qt().class)==null?void 0:K.padding)};s.setNode(y.id,F),p&&s.setParent(y.id,p),Xe.info("setNode",F)})},Win=function(i,s,u,d){Xe.info(i),i.forEach(function(p,v){var K,ee;const b=p,y="",T={labelStyle:"",style:""},_=b.text,A=0,P="note",R={labelStyle:T.labelStyle,shape:P,labelText:Ive(_),noteData:b,rx:A,ry:A,class:y,style:T.style,id:b.id,domId:b.id,tooltip:"",type:"note",padding:((K=qt().flowchart)==null?void 0:K.padding)??((ee=qt().class)==null?void 0:ee.padding)};if(s.setNode(b.id,R),Xe.info("setNode",R),!b.class||!(b.class in d))return;const F=u+v,j={id:`edgeNote${F}`,classes:"relation",pattern:"dotted",arrowhead:"none",startLabelRight:"",endLabelLeft:"",arrowTypeStart:"none",arrowTypeEnd:"none",style:"fill:none",labelStyle:"",curve:Ov(Ove.curve,kp)};s.setEdge(b.id,b.class,j,F)})},Yin=function(i,s){const u=qt().flowchart;let d=0;i.forEach(function(p){var b;d++;const v={classes:"relation",pattern:p.relation.lineType==1?"dashed":"solid",id:`id_${p.id1}_${p.id2}_${d}`,arrowhead:p.type==="arrow_open"?"none":"normal",startLabelRight:p.relationTitle1==="none"?"":p.relationTitle1,endLabelLeft:p.relationTitle2==="none"?"":p.relationTitle2,arrowTypeStart:aKe(p.relation.type1),arrowTypeEnd:aKe(p.relation.type2),style:"fill:none",labelStyle:"",curve:Ov(u==null?void 0:u.curve,kp)};if(Xe.info(v,p),p.style!==void 0){const y=om(p.style);v.style=y.style,v.labelStyle=y.labelStyle}p.text=p.title,p.text===void 0?p.style!==void 0&&(v.arrowheadStyle="fill: #333"):(v.arrowheadStyle="fill: #333",v.labelpos="c",((b=qt().flowchart)==null?void 0:b.htmlLabels)??qt().htmlLabels?(v.labelType="html",v.label=''+p.text+""):(v.labelType="text",v.label=p.text.replace(ci.lineBreakRegex,` +`),p.style===void 0&&(v.style=v.style||"stroke: #333; stroke-width: 1.5px;fill:none"),v.labelStyle=v.labelStyle.replace("color:","fill:"))),s.setEdge(p.id1,p.id2,v,d)})},Xin=function(i){Ove={...Ove,...i}},Qin=async function(i,s,u,d){Xe.info("Drawing class - ",s);const p=qt().flowchart??qt().class,v=qt().securityLevel;Xe.info("config:",p);const b=(p==null?void 0:p.nodeSpacing)??50,y=(p==null?void 0:p.rankSpacing)??50,T=new B0({multigraph:!0,compound:!0}).setGraph({rankdir:d.db.getDirection(),nodesep:b,ranksep:y,marginx:8,marginy:8}).setDefaultEdgeLabel(function(){return{}}),_=d.db.getNamespaces(),A=d.db.getClasses(),P=d.db.getRelations(),R=d.db.getNotes();Xe.info(P),Kin(_,T,s,d),sKe(A,T,s,d),Yin(P,T),Win(R,T,P.length+1,A);let F;v==="sandbox"&&(F=Ir("#i"+s));const j=Ir(v==="sandbox"?F.nodes()[0].contentDocument.body:"body"),K=j.select(`[id="${s}"]`),ee=j.select("#"+s+" g");if(await qme(ee,T,["aggregation","extension","composition","dependency","lollipop"],"classDiagram",s),Ao.insertTitle(K,"classTitleText",(p==null?void 0:p.titleTopMargin)??5,d.db.getDiagramTitle()),y9(T,K,p==null?void 0:p.diagramPadding,p==null?void 0:p.useMaxWidth),!(p!=null&&p.htmlLabels)){const ie=v==="sandbox"?F.nodes()[0].contentDocument:document,oe=ie.querySelectorAll('[id="'+s+'"] .edgeLabel .label');for(const pe of oe){const be=pe.getBBox(),ae=ie.createElementNS("http://www.w3.org/2000/svg","rect");ae.setAttribute("rx",0),ae.setAttribute("ry",0),ae.setAttribute("width",be.width),ae.setAttribute("height",be.height),pe.insertBefore(ae,pe.firstChild)}}};function aKe(i){let s;switch(i){case 0:s="aggregation";break;case 1:s="extension";break;case 2:s="composition";break;case 3:s="dependency";break;case 4:s="lollipop";break;default:s="none"}return s}const Jin=Object.freeze(Object.defineProperty({__proto__:null,diagram:{parser:KGe,db:yJ,renderer:{setConf:Xin,draw:Qin},styles:tKe,init:i=>{i.class||(i.class={}),i.class.arrowMarkerAbsolute=i.arrowMarkerAbsolute,yJ.clear()}}},Symbol.toStringTag,{value:"Module"}));var Nve=function(){var i=function(Ie,Se,Ce,ke){for(Ce=Ce||{},ke=Ie.length;ke--;Ce[Ie[ke]]=Se);return Ce},s=[1,2],u=[1,3],d=[1,4],p=[2,4],v=[1,9],b=[1,11],y=[1,15],T=[1,16],_=[1,17],A=[1,18],P=[1,30],R=[1,19],F=[1,20],j=[1,21],K=[1,22],ee=[1,23],ie=[1,25],oe=[1,26],pe=[1,27],be=[1,28],ae=[1,29],ne=[1,32],se=[1,33],de=[1,34],X=[1,35],ge=[1,31],W=[1,4,5,15,16,18,20,21,23,24,25,26,27,28,32,34,36,37,41,44,45,46,47,50],xe=[1,4,5,13,14,15,16,18,20,21,23,24,25,26,27,28,32,34,36,37,41,44,45,46,47,50],U=[4,5,15,16,18,20,21,23,24,25,26,27,28,32,34,36,37,41,44,45,46,47,50],Fe={trace:function(){},yy:{},symbols_:{error:2,start:3,SPACE:4,NL:5,SD:6,document:7,line:8,statement:9,classDefStatement:10,cssClassStatement:11,idStatement:12,DESCR:13,"-->":14,HIDE_EMPTY:15,scale:16,WIDTH:17,COMPOSIT_STATE:18,STRUCT_START:19,STRUCT_STOP:20,STATE_DESCR:21,AS:22,ID:23,FORK:24,JOIN:25,CHOICE:26,CONCURRENT:27,note:28,notePosition:29,NOTE_TEXT:30,direction:31,acc_title:32,acc_title_value:33,acc_descr:34,acc_descr_value:35,acc_descr_multiline_value:36,classDef:37,CLASSDEF_ID:38,CLASSDEF_STYLEOPTS:39,DEFAULT:40,class:41,CLASSENTITY_IDS:42,STYLECLASS:43,direction_tb:44,direction_bt:45,direction_rl:46,direction_lr:47,eol:48,";":49,EDGE_STATE:50,STYLE_SEPARATOR:51,left_of:52,right_of:53,$accept:0,$end:1},terminals_:{2:"error",4:"SPACE",5:"NL",6:"SD",13:"DESCR",14:"-->",15:"HIDE_EMPTY",16:"scale",17:"WIDTH",18:"COMPOSIT_STATE",19:"STRUCT_START",20:"STRUCT_STOP",21:"STATE_DESCR",22:"AS",23:"ID",24:"FORK",25:"JOIN",26:"CHOICE",27:"CONCURRENT",28:"note",30:"NOTE_TEXT",32:"acc_title",33:"acc_title_value",34:"acc_descr",35:"acc_descr_value",36:"acc_descr_multiline_value",37:"classDef",38:"CLASSDEF_ID",39:"CLASSDEF_STYLEOPTS",40:"DEFAULT",41:"class",42:"CLASSENTITY_IDS",43:"STYLECLASS",44:"direction_tb",45:"direction_bt",46:"direction_rl",47:"direction_lr",49:";",50:"EDGE_STATE",51:"STYLE_SEPARATOR",52:"left_of",53:"right_of"},productions_:[0,[3,2],[3,2],[3,2],[7,0],[7,2],[8,2],[8,1],[8,1],[9,1],[9,1],[9,1],[9,2],[9,3],[9,4],[9,1],[9,2],[9,1],[9,4],[9,3],[9,6],[9,1],[9,1],[9,1],[9,1],[9,4],[9,4],[9,1],[9,2],[9,2],[9,1],[10,3],[10,3],[11,3],[31,1],[31,1],[31,1],[31,1],[48,1],[48,1],[12,1],[12,1],[12,3],[12,3],[29,1],[29,1]],performAction:function(Se,Ce,ke,Ke,Ft,Ne,gn){var _t=Ne.length-1;switch(Ft){case 3:return Ke.setRootDoc(Ne[_t]),Ne[_t];case 4:this.$=[];break;case 5:Ne[_t]!="nl"&&(Ne[_t-1].push(Ne[_t]),this.$=Ne[_t-1]);break;case 6:case 7:this.$=Ne[_t];break;case 8:this.$="nl";break;case 11:this.$=Ne[_t];break;case 12:const xt=Ne[_t-1];xt.description=Ke.trimColon(Ne[_t]),this.$=xt;break;case 13:this.$={stmt:"relation",state1:Ne[_t-2],state2:Ne[_t]};break;case 14:const Pt=Ke.trimColon(Ne[_t]);this.$={stmt:"relation",state1:Ne[_t-3],state2:Ne[_t-1],description:Pt};break;case 18:this.$={stmt:"state",id:Ne[_t-3],type:"default",description:"",doc:Ne[_t-1]};break;case 19:var Et=Ne[_t],Gt=Ne[_t-2].trim();if(Ne[_t].match(":")){var ln=Ne[_t].split(":");Et=ln[0],Gt=[Gt,ln[1]]}this.$={stmt:"state",id:Et,type:"default",description:Gt};break;case 20:this.$={stmt:"state",id:Ne[_t-3],type:"default",description:Ne[_t-5],doc:Ne[_t-1]};break;case 21:this.$={stmt:"state",id:Ne[_t],type:"fork"};break;case 22:this.$={stmt:"state",id:Ne[_t],type:"join"};break;case 23:this.$={stmt:"state",id:Ne[_t],type:"choice"};break;case 24:this.$={stmt:"state",id:Ke.getDividerId(),type:"divider"};break;case 25:this.$={stmt:"state",id:Ne[_t-1].trim(),note:{position:Ne[_t-2].trim(),text:Ne[_t].trim()}};break;case 28:this.$=Ne[_t].trim(),Ke.setAccTitle(this.$);break;case 29:case 30:this.$=Ne[_t].trim(),Ke.setAccDescription(this.$);break;case 31:case 32:this.$={stmt:"classDef",id:Ne[_t-1].trim(),classes:Ne[_t].trim()};break;case 33:this.$={stmt:"applyClass",id:Ne[_t-1].trim(),styleClass:Ne[_t].trim()};break;case 34:Ke.setDirection("TB"),this.$={stmt:"dir",value:"TB"};break;case 35:Ke.setDirection("BT"),this.$={stmt:"dir",value:"BT"};break;case 36:Ke.setDirection("RL"),this.$={stmt:"dir",value:"RL"};break;case 37:Ke.setDirection("LR"),this.$={stmt:"dir",value:"LR"};break;case 40:case 41:this.$={stmt:"state",id:Ne[_t].trim(),type:"default",description:""};break;case 42:this.$={stmt:"state",id:Ne[_t-2].trim(),classes:[Ne[_t].trim()],type:"default",description:""};break;case 43:this.$={stmt:"state",id:Ne[_t-2].trim(),classes:[Ne[_t].trim()],type:"default",description:""};break}},table:[{3:1,4:s,5:u,6:d},{1:[3]},{3:5,4:s,5:u,6:d},{3:6,4:s,5:u,6:d},i([1,4,5,15,16,18,21,23,24,25,26,27,28,32,34,36,37,41,44,45,46,47,50],p,{7:7}),{1:[2,1]},{1:[2,2]},{1:[2,3],4:v,5:b,8:8,9:10,10:12,11:13,12:14,15:y,16:T,18:_,21:A,23:P,24:R,25:F,26:j,27:K,28:ee,31:24,32:ie,34:oe,36:pe,37:be,41:ae,44:ne,45:se,46:de,47:X,50:ge},i(W,[2,5]),{9:36,10:12,11:13,12:14,15:y,16:T,18:_,21:A,23:P,24:R,25:F,26:j,27:K,28:ee,31:24,32:ie,34:oe,36:pe,37:be,41:ae,44:ne,45:se,46:de,47:X,50:ge},i(W,[2,7]),i(W,[2,8]),i(W,[2,9]),i(W,[2,10]),i(W,[2,11],{13:[1,37],14:[1,38]}),i(W,[2,15]),{17:[1,39]},i(W,[2,17],{19:[1,40]}),{22:[1,41]},i(W,[2,21]),i(W,[2,22]),i(W,[2,23]),i(W,[2,24]),{29:42,30:[1,43],52:[1,44],53:[1,45]},i(W,[2,27]),{33:[1,46]},{35:[1,47]},i(W,[2,30]),{38:[1,48],40:[1,49]},{42:[1,50]},i(xe,[2,40],{51:[1,51]}),i(xe,[2,41],{51:[1,52]}),i(W,[2,34]),i(W,[2,35]),i(W,[2,36]),i(W,[2,37]),i(W,[2,6]),i(W,[2,12]),{12:53,23:P,50:ge},i(W,[2,16]),i(U,p,{7:54}),{23:[1,55]},{23:[1,56]},{22:[1,57]},{23:[2,44]},{23:[2,45]},i(W,[2,28]),i(W,[2,29]),{39:[1,58]},{39:[1,59]},{43:[1,60]},{23:[1,61]},{23:[1,62]},i(W,[2,13],{13:[1,63]}),{4:v,5:b,8:8,9:10,10:12,11:13,12:14,15:y,16:T,18:_,20:[1,64],21:A,23:P,24:R,25:F,26:j,27:K,28:ee,31:24,32:ie,34:oe,36:pe,37:be,41:ae,44:ne,45:se,46:de,47:X,50:ge},i(W,[2,19],{19:[1,65]}),{30:[1,66]},{23:[1,67]},i(W,[2,31]),i(W,[2,32]),i(W,[2,33]),i(xe,[2,42]),i(xe,[2,43]),i(W,[2,14]),i(W,[2,18]),i(U,p,{7:68}),i(W,[2,25]),i(W,[2,26]),{4:v,5:b,8:8,9:10,10:12,11:13,12:14,15:y,16:T,18:_,20:[1,69],21:A,23:P,24:R,25:F,26:j,27:K,28:ee,31:24,32:ie,34:oe,36:pe,37:be,41:ae,44:ne,45:se,46:de,47:X,50:ge},i(W,[2,20])],defaultActions:{5:[2,1],6:[2,2],44:[2,44],45:[2,45]},parseError:function(Se,Ce){if(Ce.recoverable)this.trace(Se);else{var ke=new Error(Se);throw ke.hash=Ce,ke}},parse:function(Se){var Ce=this,ke=[0],Ke=[],Ft=[null],Ne=[],gn=this.table,_t="",Et=0,Gt=0,ln=2,xt=1,Pt=Ne.slice.call(arguments,1),Qe=Object.create(this.lexer),Dt={yy:{}};for(var kt in this.yy)Object.prototype.hasOwnProperty.call(this.yy,kt)&&(Dt.yy[kt]=this.yy[kt]);Qe.setInput(Se,Dt.yy),Dt.yy.lexer=Qe,Dt.yy.parser=this,typeof Qe.yylloc>"u"&&(Qe.yylloc={});var On=Qe.yylloc;Ne.push(On);var ht=Qe.options&&Qe.options.ranges;typeof Dt.yy.parseError=="function"?this.parseError=Dt.yy.parseError:this.parseError=Object.getPrototypeOf(this).parseError;function zr(){var At;return At=Ke.pop()||Qe.lex()||xt,typeof At!="number"&&(At instanceof Array&&(Ke=At,At=Ke.pop()),At=Ce.symbols_[At]||At),At}for(var yt,ji,xi,Ma,zs={},ao,Tr,Fn,qn;;){if(ji=ke[ke.length-1],this.defaultActions[ji]?xi=this.defaultActions[ji]:((yt===null||typeof yt>"u")&&(yt=zr()),xi=gn[ji]&&gn[ji][yt]),typeof xi>"u"||!xi.length||!xi[0]){var Un="";qn=[];for(ao in gn[ji])this.terminals_[ao]&&ao>ln&&qn.push("'"+this.terminals_[ao]+"'");Qe.showPosition?Un="Parse error on line "+(Et+1)+`: +`+Qe.showPosition()+` +Expecting `+qn.join(", ")+", got '"+(this.terminals_[yt]||yt)+"'":Un="Parse error on line "+(Et+1)+": Unexpected "+(yt==xt?"end of input":"'"+(this.terminals_[yt]||yt)+"'"),this.parseError(Un,{text:Qe.match,token:this.terminals_[yt]||yt,line:Qe.yylineno,loc:On,expected:qn})}if(xi[0]instanceof Array&&xi.length>1)throw new Error("Parse Error: multiple actions possible at state: "+ji+", token: "+yt);switch(xi[0]){case 1:ke.push(yt),Ft.push(Qe.yytext),Ne.push(Qe.yylloc),ke.push(xi[1]),yt=null,Gt=Qe.yyleng,_t=Qe.yytext,Et=Qe.yylineno,On=Qe.yylloc;break;case 2:if(Tr=this.productions_[xi[1]][1],zs.$=Ft[Ft.length-Tr],zs._$={first_line:Ne[Ne.length-(Tr||1)].first_line,last_line:Ne[Ne.length-1].last_line,first_column:Ne[Ne.length-(Tr||1)].first_column,last_column:Ne[Ne.length-1].last_column},ht&&(zs._$.range=[Ne[Ne.length-(Tr||1)].range[0],Ne[Ne.length-1].range[1]]),Ma=this.performAction.apply(zs,[_t,Gt,Et,Dt.yy,xi[1],Ft,Ne].concat(Pt)),typeof Ma<"u")return Ma;Tr&&(ke=ke.slice(0,-1*Tr*2),Ft=Ft.slice(0,-1*Tr),Ne=Ne.slice(0,-1*Tr)),ke.push(this.productions_[xi[1]][0]),Ft.push(zs.$),Ne.push(zs._$),Fn=gn[ke[ke.length-2]][ke[ke.length-1]],ke.push(Fn);break;case 3:return!0}}return!0}},Pe=function(){var Ie={EOF:1,parseError:function(Ce,ke){if(this.yy.parser)this.yy.parser.parseError(Ce,ke);else throw new Error(Ce)},setInput:function(Se,Ce){return this.yy=Ce||this.yy||{},this._input=Se,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},input:function(){var Se=this._input[0];this.yytext+=Se,this.yyleng++,this.offset++,this.match+=Se,this.matched+=Se;var Ce=Se.match(/(?:\r\n?|\n).*/g);return Ce?(this.yylineno++,this.yylloc.last_line++):this.yylloc.last_column++,this.options.ranges&&this.yylloc.range[1]++,this._input=this._input.slice(1),Se},unput:function(Se){var Ce=Se.length,ke=Se.split(/(?:\r\n?|\n)/g);this._input=Se+this._input,this.yytext=this.yytext.substr(0,this.yytext.length-Ce),this.offset-=Ce;var Ke=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),ke.length-1&&(this.yylineno-=ke.length-1);var Ft=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:ke?(ke.length===Ke.length?this.yylloc.first_column:0)+Ke[Ke.length-ke.length].length-ke[0].length:this.yylloc.first_column-Ce},this.options.ranges&&(this.yylloc.range=[Ft[0],Ft[0]+this.yyleng-Ce]),this.yyleng=this.yytext.length,this},more:function(){return this._more=!0,this},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},less:function(Se){this.unput(this.match.slice(Se))},pastInput:function(){var Se=this.matched.substr(0,this.matched.length-this.match.length);return(Se.length>20?"...":"")+Se.substr(-20).replace(/\n/g,"")},upcomingInput:function(){var Se=this.match;return Se.length<20&&(Se+=this._input.substr(0,20-Se.length)),(Se.substr(0,20)+(Se.length>20?"...":"")).replace(/\n/g,"")},showPosition:function(){var Se=this.pastInput(),Ce=new Array(Se.length+1).join("-");return Se+this.upcomingInput()+` +`+Ce+"^"},test_match:function(Se,Ce){var ke,Ke,Ft;if(this.options.backtrack_lexer&&(Ft={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&&(Ft.yylloc.range=this.yylloc.range.slice(0))),Ke=Se[0].match(/(?:\r\n?|\n).*/g),Ke&&(this.yylineno+=Ke.length),this.yylloc={first_line:this.yylloc.last_line,last_line:this.yylineno+1,first_column:this.yylloc.last_column,last_column:Ke?Ke[Ke.length-1].length-Ke[Ke.length-1].match(/\r?\n?/)[0].length:this.yylloc.last_column+Se[0].length},this.yytext+=Se[0],this.match+=Se[0],this.matches=Se,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(Se[0].length),this.matched+=Se[0],ke=this.performAction.call(this,this.yy,this,Ce,this.conditionStack[this.conditionStack.length-1]),this.done&&this._input&&(this.done=!1),ke)return ke;if(this._backtrack){for(var Ne in Ft)this[Ne]=Ft[Ne];return!1}return!1},next:function(){if(this.done)return this.EOF;this._input||(this.done=!0);var Se,Ce,ke,Ke;this._more||(this.yytext="",this.match="");for(var Ft=this._currentRules(),Ne=0;NeCe[0].length)){if(Ce=ke,Ke=Ne,this.options.backtrack_lexer){if(Se=this.test_match(ke,Ft[Ne]),Se!==!1)return Se;if(this._backtrack){Ce=!1;continue}else return!1}else if(!this.options.flex)break}return Ce?(Se=this.test_match(Ce,Ft[Ke]),Se!==!1?Se:!1):this._input===""?this.EOF:this.parseError("Lexical error on line "+(this.yylineno+1)+`. Unrecognized text. +`+this.showPosition(),{text:"",token:null,line:this.yylineno})},lex:function(){var Ce=this.next();return Ce||this.lex()},begin:function(Ce){this.conditionStack.push(Ce)},popState:function(){var Ce=this.conditionStack.length-1;return Ce>0?this.conditionStack.pop():this.conditionStack[0]},_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},topState:function(Ce){return Ce=this.conditionStack.length-1-Math.abs(Ce||0),Ce>=0?this.conditionStack[Ce]:"INITIAL"},pushState:function(Ce){this.begin(Ce)},stateStackSize:function(){return this.conditionStack.length},options:{"case-insensitive":!0},performAction:function(Ce,ke,Ke,Ft){switch(Ke){case 0:return 40;case 1:return 44;case 2:return 45;case 3:return 46;case 4:return 47;case 5:break;case 6:break;case 7:return 5;case 8:break;case 9:break;case 10:break;case 11:break;case 12:return this.pushState("SCALE"),16;case 13:return 17;case 14:this.popState();break;case 15:return this.begin("acc_title"),32;case 16:return this.popState(),"acc_title_value";case 17:return this.begin("acc_descr"),34;case 18:return this.popState(),"acc_descr_value";case 19:this.begin("acc_descr_multiline");break;case 20:this.popState();break;case 21:return"acc_descr_multiline_value";case 22:return this.pushState("CLASSDEF"),37;case 23:return this.popState(),this.pushState("CLASSDEFID"),"DEFAULT_CLASSDEF_ID";case 24:return this.popState(),this.pushState("CLASSDEFID"),38;case 25:return this.popState(),39;case 26:return this.pushState("CLASS"),41;case 27:return this.popState(),this.pushState("CLASS_STYLE"),42;case 28:return this.popState(),43;case 29:return this.pushState("SCALE"),16;case 30:return 17;case 31:this.popState();break;case 32:this.pushState("STATE");break;case 33:return this.popState(),ke.yytext=ke.yytext.slice(0,-8).trim(),24;case 34:return this.popState(),ke.yytext=ke.yytext.slice(0,-8).trim(),25;case 35:return this.popState(),ke.yytext=ke.yytext.slice(0,-10).trim(),26;case 36:return this.popState(),ke.yytext=ke.yytext.slice(0,-8).trim(),24;case 37:return this.popState(),ke.yytext=ke.yytext.slice(0,-8).trim(),25;case 38:return this.popState(),ke.yytext=ke.yytext.slice(0,-10).trim(),26;case 39:return 44;case 40:return 45;case 41:return 46;case 42:return 47;case 43:this.pushState("STATE_STRING");break;case 44:return this.pushState("STATE_ID"),"AS";case 45:return this.popState(),"ID";case 46:this.popState();break;case 47:return"STATE_DESCR";case 48:return 18;case 49:this.popState();break;case 50:return this.popState(),this.pushState("struct"),19;case 51:break;case 52:return this.popState(),20;case 53:break;case 54:return this.begin("NOTE"),28;case 55:return this.popState(),this.pushState("NOTE_ID"),52;case 56:return this.popState(),this.pushState("NOTE_ID"),53;case 57:this.popState(),this.pushState("FLOATING_NOTE");break;case 58:return this.popState(),this.pushState("FLOATING_NOTE_ID"),"AS";case 59:break;case 60:return"NOTE_TEXT";case 61:return this.popState(),"ID";case 62:return this.popState(),this.pushState("NOTE_TEXT"),23;case 63:return this.popState(),ke.yytext=ke.yytext.substr(2).trim(),30;case 64:return this.popState(),ke.yytext=ke.yytext.slice(0,-8).trim(),30;case 65:return 6;case 66:return 6;case 67:return 15;case 68:return 50;case 69:return 23;case 70:return ke.yytext=ke.yytext.trim(),13;case 71:return 14;case 72:return 27;case 73:return 51;case 74:return 5;case 75:return"INVALID"}},rules:[/^(?:default\b)/i,/^(?:.*direction\s+TB[^\n]*)/i,/^(?:.*direction\s+BT[^\n]*)/i,/^(?:.*direction\s+RL[^\n]*)/i,/^(?:.*direction\s+LR[^\n]*)/i,/^(?:%%(?!\{)[^\n]*)/i,/^(?:[^\}]%%[^\n]*)/i,/^(?:[\n]+)/i,/^(?:[\s]+)/i,/^(?:((?!\n)\s)+)/i,/^(?:#[^\n]*)/i,/^(?:%[^\n]*)/i,/^(?:scale\s+)/i,/^(?:\d+)/i,/^(?:\s+width\b)/i,/^(?:accTitle\s*:\s*)/i,/^(?:(?!\n||)*[^\n]*)/i,/^(?:accDescr\s*:\s*)/i,/^(?:(?!\n||)*[^\n]*)/i,/^(?:accDescr\s*\{\s*)/i,/^(?:[\}])/i,/^(?:[^\}]*)/i,/^(?:classDef\s+)/i,/^(?:DEFAULT\s+)/i,/^(?:\w+\s+)/i,/^(?:[^\n]*)/i,/^(?:class\s+)/i,/^(?:(\w+)+((,\s*\w+)*))/i,/^(?:[^\n]*)/i,/^(?:scale\s+)/i,/^(?:\d+)/i,/^(?:\s+width\b)/i,/^(?:state\s+)/i,/^(?:.*<>)/i,/^(?:.*<>)/i,/^(?:.*<>)/i,/^(?:.*\[\[fork\]\])/i,/^(?:.*\[\[join\]\])/i,/^(?:.*\[\[choice\]\])/i,/^(?:.*direction\s+TB[^\n]*)/i,/^(?:.*direction\s+BT[^\n]*)/i,/^(?:.*direction\s+RL[^\n]*)/i,/^(?:.*direction\s+LR[^\n]*)/i,/^(?:["])/i,/^(?:\s*as\s+)/i,/^(?:[^\n\{]*)/i,/^(?:["])/i,/^(?:[^"]*)/i,/^(?:[^\n\s\{]+)/i,/^(?:\n)/i,/^(?:\{)/i,/^(?:%%(?!\{)[^\n]*)/i,/^(?:\})/i,/^(?:[\n])/i,/^(?:note\s+)/i,/^(?:left of\b)/i,/^(?:right of\b)/i,/^(?:")/i,/^(?:\s*as\s*)/i,/^(?:["])/i,/^(?:[^"]*)/i,/^(?:[^\n]*)/i,/^(?:\s*[^:\n\s\-]+)/i,/^(?:\s*:[^:\n;]+)/i,/^(?:[\s\S]*?end note\b)/i,/^(?:stateDiagram\s+)/i,/^(?:stateDiagram-v2\s+)/i,/^(?:hide empty description\b)/i,/^(?:\[\*\])/i,/^(?:[^:\n\s\-\{]+)/i,/^(?:\s*:[^:\n;]+)/i,/^(?:-->)/i,/^(?:--)/i,/^(?::::)/i,/^(?:$)/i,/^(?:.)/i],conditions:{LINE:{rules:[9,10],inclusive:!1},struct:{rules:[9,10,22,26,32,39,40,41,42,51,52,53,54,68,69,70,71,72],inclusive:!1},FLOATING_NOTE_ID:{rules:[61],inclusive:!1},FLOATING_NOTE:{rules:[58,59,60],inclusive:!1},NOTE_TEXT:{rules:[63,64],inclusive:!1},NOTE_ID:{rules:[62],inclusive:!1},NOTE:{rules:[55,56,57],inclusive:!1},CLASS_STYLE:{rules:[28],inclusive:!1},CLASS:{rules:[27],inclusive:!1},CLASSDEFID:{rules:[25],inclusive:!1},CLASSDEF:{rules:[23,24],inclusive:!1},acc_descr_multiline:{rules:[20,21],inclusive:!1},acc_descr:{rules:[18],inclusive:!1},acc_title:{rules:[16],inclusive:!1},SCALE:{rules:[13,14,30,31],inclusive:!1},ALIAS:{rules:[],inclusive:!1},STATE_ID:{rules:[45],inclusive:!1},STATE_STRING:{rules:[46,47],inclusive:!1},FORK_STATE:{rules:[],inclusive:!1},STATE:{rules:[9,10,33,34,35,36,37,38,43,44,48,49,50],inclusive:!1},ID:{rules:[9,10],inclusive:!1},INITIAL:{rules:[0,1,2,3,4,5,6,7,8,10,11,12,15,17,19,22,26,29,32,50,54,65,66,67,68,69,70,71,73,74,75],inclusive:!0}}};return Ie}();Fe.lexer=Pe;function je(){this.yy={}}return je.prototype=Fe,Fe.Parser=je,new je}();Nve.parser=Nve;const oKe=Nve,Zin="LR",esn="TB",EJ="state",Pve="relation",tsn="classDef",nsn="applyClass",XR="default",cKe="divider",Bve="[*]",uKe="start",lKe=Bve,hKe="end",fKe="color",dKe="fill",rsn="bgFill",isn=",";function gKe(){return{}}let pKe=Zin,TJ=[],QR=gKe();const bKe=()=>({relations:[],states:{},documents:{}});let CJ={root:bKe()},jg=CJ.root,JR=0,mKe=0;const ssn={LINE:0,DOTTED_LINE:1},asn={AGGREGATION:0,EXTENSION:1,COMPOSITION:2,DEPENDENCY:3},SJ=i=>JSON.parse(JSON.stringify(i)),osn=i=>{Xe.info("Setting root doc",i),TJ=i},csn=()=>TJ,_J=(i,s,u)=>{if(s.stmt===Pve)_J(i,s.state1,!0),_J(i,s.state2,!1);else if(s.stmt===EJ&&(s.id==="[*]"?(s.id=u?i.id+"_start":i.id+"_end",s.start=u):s.id=s.id.trim()),s.doc){const d=[];let p=[],v;for(v=0;v0&&p.length>0){const b={stmt:EJ,id:bje(),type:"divider",doc:SJ(p)};d.push(SJ(b)),s.doc=d}s.doc.forEach(b=>_J(s,b,!0))}},usn=()=>(_J({id:"root"},{id:"root",doc:TJ},!0),{id:"root",doc:TJ}),lsn=i=>{let s;i.doc?s=i.doc:s=i,Xe.info(s),vKe(!0),Xe.info("Extract",s),s.forEach(u=>{switch(u.stmt){case EJ:rS(u.id.trim(),u.type,u.doc,u.description,u.note,u.classes,u.styles,u.textStyles);break;case Pve:wKe(u.state1,u.state2,u.description);break;case tsn:yKe(u.id.trim(),u.classes);break;case nsn:$ve(u.id.trim(),u.styleClass);break}})},rS=function(i,s=XR,u=null,d=null,p=null,v=null,b=null,y=null){const T=i==null?void 0:i.trim();jg.states[T]===void 0?(Xe.info("Adding state ",T,d),jg.states[T]={id:T,descriptions:[],type:s,doc:u,note:p,classes:[],styles:[],textStyles:[]}):(jg.states[T].doc||(jg.states[T].doc=u),jg.states[T].type||(jg.states[T].type=s)),d&&(Xe.info("Setting state description",T,d),typeof d=="string"&&jve(T,d.trim()),typeof d=="object"&&d.forEach(_=>jve(T,_.trim()))),p&&(jg.states[T].note=p,jg.states[T].note.text=ci.sanitizeText(jg.states[T].note.text,qt())),v&&(Xe.info("Setting state classes",T,v),(typeof v=="string"?[v]:v).forEach(A=>$ve(T,A.trim()))),b&&(Xe.info("Setting state styles",T,b),(typeof b=="string"?[b]:b).forEach(A=>ysn(T,A.trim()))),y&&(Xe.info("Setting state styles",T,b),(typeof y=="string"?[y]:y).forEach(A=>xsn(T,A.trim())))},vKe=function(i){CJ={root:bKe()},jg=CJ.root,JR=0,QR=gKe(),i||Pg()},ZR=function(i){return jg.states[i]},hsn=function(){return jg.states},fsn=function(){Xe.info("Documents = ",CJ)},dsn=function(){return jg.relations};function Fve(i=""){let s=i;return i===Bve&&(JR++,s=`${uKe}${JR}`),s}function Rve(i="",s=XR){return i===Bve?uKe:s}function gsn(i=""){let s=i;return i===lKe&&(JR++,s=`${hKe}${JR}`),s}function psn(i="",s=XR){return i===lKe?hKe:s}function bsn(i,s,u){let d=Fve(i.id.trim()),p=Rve(i.id.trim(),i.type),v=Fve(s.id.trim()),b=Rve(s.id.trim(),s.type);rS(d,p,i.doc,i.description,i.note,i.classes,i.styles,i.textStyles),rS(v,b,s.doc,s.description,s.note,s.classes,s.styles,s.textStyles),jg.relations.push({id1:d,id2:v,relationTitle:ci.sanitizeText(u,qt())})}const wKe=function(i,s,u){if(typeof i=="object")bsn(i,s,u);else{const d=Fve(i.trim()),p=Rve(i),v=gsn(s.trim()),b=psn(s);rS(d,p),rS(v,b),jg.relations.push({id1:d,id2:v,title:ci.sanitizeText(u,qt())})}},jve=function(i,s){const u=jg.states[i],d=s.startsWith(":")?s.replace(":","").trim():s;u.descriptions.push(ci.sanitizeText(d,qt()))},msn=function(i){return i.substring(0,1)===":"?i.substr(2).trim():i.trim()},vsn=()=>(mKe++,"divider-id-"+mKe),yKe=function(i,s=""){QR[i]===void 0&&(QR[i]={id:i,styles:[],textStyles:[]});const u=QR[i];s!=null&&s.split(isn).forEach(d=>{const p=d.replace(/([^;]*);/,"$1").trim();if(d.match(fKe)){const b=p.replace(dKe,rsn).replace(fKe,dKe);u.textStyles.push(b)}u.styles.push(p)})},wsn=function(){return QR},$ve=function(i,s){i.split(",").forEach(function(u){let d=ZR(u);if(d===void 0){const p=u.trim();rS(p),d=ZR(p)}d.classes.push(s)})},ysn=function(i,s){const u=ZR(i);u!==void 0&&u.textStyles.push(s)},xsn=function(i,s){const u=ZR(i);u!==void 0&&u.textStyles.push(s)},G7={getConfig:()=>qt().state,addState:rS,clear:vKe,getState:ZR,getStates:hsn,getRelations:dsn,getClasses:wsn,getDirection:()=>pKe,addRelation:wKe,getDividerId:vsn,setDirection:i=>{pKe=i},cleanupLabel:msn,lineType:ssn,relationType:asn,logDocuments:fsn,getRootDoc:csn,setRootDoc:osn,getRootDocV2:usn,extract:lsn,trimColon:i=>i&&i[0]===":"?i.substr(1).trim():i.trim(),getAccTitle:Cp,setAccTitle:Bg,getAccDescription:_p,setAccDescription:Sp,addStyleClass:yKe,setCssClass:$ve,addDescription:jve,setDiagramTitle:cm,getDiagramTitle:Ap},xKe=i=>` +defs #statediagram-barbEnd { + fill: ${i.transitionColor}; + stroke: ${i.transitionColor}; + } +g.stateGroup text { + fill: ${i.nodeBorder}; + stroke: none; + font-size: 10px; +} +g.stateGroup text { + fill: ${i.textColor}; + stroke: none; + font-size: 10px; + +} +g.stateGroup .state-title { + font-weight: bolder; + fill: ${i.stateLabelColor}; +} + +g.stateGroup rect { + fill: ${i.mainBkg}; + stroke: ${i.nodeBorder}; +} + +g.stateGroup line { + stroke: ${i.lineColor}; + stroke-width: 1; +} + +.transition { + stroke: ${i.transitionColor}; + stroke-width: 1; + fill: none; +} + +.stateGroup .composit { + fill: ${i.background}; + border-bottom: 1px +} + +.stateGroup .alt-composit { + fill: #e0e0e0; + border-bottom: 1px +} + +.state-note { + stroke: ${i.noteBorderColor}; + fill: ${i.noteBkgColor}; + + text { + fill: ${i.noteTextColor}; + stroke: none; + font-size: 10px; + } +} + +.stateLabel .box { + stroke: none; + stroke-width: 0; + fill: ${i.mainBkg}; + opacity: 0.5; +} + +.edgeLabel .label rect { + fill: ${i.labelBackgroundColor}; + opacity: 0.5; +} +.edgeLabel .label text { + fill: ${i.transitionLabelColor||i.tertiaryTextColor}; +} +.label div .edgeLabel { + color: ${i.transitionLabelColor||i.tertiaryTextColor}; +} + +.stateLabel text { + fill: ${i.stateLabelColor}; + font-size: 10px; + font-weight: bold; +} + +.node circle.state-start { + fill: ${i.specialStateColor}; + stroke: ${i.specialStateColor}; +} + +.node .fork-join { + fill: ${i.specialStateColor}; + stroke: ${i.specialStateColor}; +} + +.node circle.state-end { + fill: ${i.innerEndBackground}; + stroke: ${i.background}; + stroke-width: 1.5 +} +.end-state-inner { + fill: ${i.compositeBackground||i.background}; + // stroke: ${i.background}; + stroke-width: 1.5 +} + +.node rect { + fill: ${i.stateBkg||i.mainBkg}; + stroke: ${i.stateBorder||i.nodeBorder}; + stroke-width: 1px; +} +.node polygon { + fill: ${i.mainBkg}; + stroke: ${i.stateBorder||i.nodeBorder};; + stroke-width: 1px; +} +#statediagram-barbEnd { + fill: ${i.lineColor}; +} + +.statediagram-cluster rect { + fill: ${i.compositeTitleBackground}; + stroke: ${i.stateBorder||i.nodeBorder}; + stroke-width: 1px; +} + +.cluster-label, .nodeLabel { + color: ${i.stateLabelColor}; +} + +.statediagram-cluster rect.outer { + rx: 5px; + ry: 5px; +} +.statediagram-state .divider { + stroke: ${i.stateBorder||i.nodeBorder}; +} + +.statediagram-state .title-state { + rx: 5px; + ry: 5px; +} +.statediagram-cluster.statediagram-cluster .inner { + fill: ${i.compositeBackground||i.background}; +} +.statediagram-cluster.statediagram-cluster-alt .inner { + fill: ${i.altBackground?i.altBackground:"#efefef"}; +} + +.statediagram-cluster .inner { + rx:0; + ry:0; +} + +.statediagram-state rect.basic { + rx: 5px; + ry: 5px; +} +.statediagram-state rect.divider { + stroke-dasharray: 10,10; + fill: ${i.altBackground?i.altBackground:"#efefef"}; +} + +.note-edge { + stroke-dasharray: 5; +} + +.statediagram-note rect { + fill: ${i.noteBkgColor}; + stroke: ${i.noteBorderColor}; + stroke-width: 1px; + rx: 0; + ry: 0; +} +.statediagram-note rect { + fill: ${i.noteBkgColor}; + stroke: ${i.noteBorderColor}; + stroke-width: 1px; + rx: 0; + ry: 0; +} + +.statediagram-note text { + fill: ${i.noteTextColor}; +} + +.statediagram-note .nodeLabel { + color: ${i.noteTextColor}; +} +.statediagram .edgeLabel { + color: red; // ${i.noteTextColor}; +} + +#dependencyStart, #dependencyEnd { + fill: ${i.lineColor}; + stroke: ${i.lineColor}; + stroke-width: 1; +} + +.statediagramTitleText { + text-anchor: middle; + font-size: 18px; + fill: ${i.textColor}; +} +`,zve={},ksn=(i,s)=>{zve[i]=s},Esn=i=>zve[i],kKe=()=>Object.keys(zve),Tsn={get:Esn,set:ksn,keys:kKe,size:()=>kKe().length},Csn=i=>i.append("circle").attr("class","start-state").attr("r",qt().state.sizeUnit).attr("cx",qt().state.padding+qt().state.sizeUnit).attr("cy",qt().state.padding+qt().state.sizeUnit),Ssn=i=>i.append("line").style("stroke","grey").style("stroke-dasharray","3").attr("x1",qt().state.textHeight).attr("class","divider").attr("x2",qt().state.textHeight*2).attr("y1",0).attr("y2",0),_sn=(i,s)=>{const u=i.append("text").attr("x",2*qt().state.padding).attr("y",qt().state.textHeight+2*qt().state.padding).attr("font-size",qt().state.fontSize).attr("class","state-title").text(s.id),d=u.node().getBBox();return i.insert("rect",":first-child").attr("x",qt().state.padding).attr("y",qt().state.padding).attr("width",d.width+2*qt().state.padding).attr("height",d.height+2*qt().state.padding).attr("rx",qt().state.radius),u},Asn=(i,s)=>{const u=function(R,F,j){const K=R.append("tspan").attr("x",2*qt().state.padding).text(F);j||K.attr("dy",qt().state.textHeight)},p=i.append("text").attr("x",2*qt().state.padding).attr("y",qt().state.textHeight+1.3*qt().state.padding).attr("font-size",qt().state.fontSize).attr("class","state-title").text(s.descriptions[0]).node().getBBox(),v=p.height,b=i.append("text").attr("x",qt().state.padding).attr("y",v+qt().state.padding*.4+qt().state.dividerMargin+qt().state.textHeight).attr("class","state-description");let y=!0,T=!0;s.descriptions.forEach(function(R){y||(u(b,R,T),T=!1),y=!1});const _=i.append("line").attr("x1",qt().state.padding).attr("y1",qt().state.padding+v+qt().state.dividerMargin/2).attr("y2",qt().state.padding+v+qt().state.dividerMargin/2).attr("class","descr-divider"),A=b.node().getBBox(),P=Math.max(A.width,p.width);return _.attr("x2",P+3*qt().state.padding),i.insert("rect",":first-child").attr("x",qt().state.padding).attr("y",qt().state.padding).attr("width",P+2*qt().state.padding).attr("height",A.height+v+2*qt().state.padding).attr("rx",qt().state.radius),i},Lsn=(i,s,u)=>{const d=qt().state.padding,p=2*qt().state.padding,v=i.node().getBBox(),b=v.width,y=v.x,T=i.append("text").attr("x",0).attr("y",qt().state.titleShift).attr("font-size",qt().state.fontSize).attr("class","state-title").text(s.id),A=T.node().getBBox().width+p;let P=Math.max(A,b);P===b&&(P=P+p);let R;const F=i.node().getBBox();s.doc,R=y-d,A>b&&(R=(b-P)/2+d),Math.abs(y-F.x)b&&(R=y-(A-b)/2);const j=1-qt().state.textHeight;return i.insert("rect",":first-child").attr("x",R).attr("y",j).attr("class",u?"alt-composit":"composit").attr("width",P).attr("height",F.height+qt().state.textHeight+qt().state.titleShift+1).attr("rx","0"),T.attr("x",R+d),A<=b&&T.attr("x",y+(P-p)/2-A/2+d),i.insert("rect",":first-child").attr("x",R).attr("y",qt().state.titleShift-qt().state.textHeight-qt().state.padding).attr("width",P).attr("height",qt().state.textHeight*3).attr("rx",qt().state.radius),i.insert("rect",":first-child").attr("x",R).attr("y",qt().state.titleShift-qt().state.textHeight-qt().state.padding).attr("width",P).attr("height",F.height+3+2*qt().state.textHeight).attr("rx",qt().state.radius),i},Msn=i=>(i.append("circle").attr("class","end-state-outer").attr("r",qt().state.sizeUnit+qt().state.miniPadding).attr("cx",qt().state.padding+qt().state.sizeUnit+qt().state.miniPadding).attr("cy",qt().state.padding+qt().state.sizeUnit+qt().state.miniPadding),i.append("circle").attr("class","end-state-inner").attr("r",qt().state.sizeUnit).attr("cx",qt().state.padding+qt().state.sizeUnit+2).attr("cy",qt().state.padding+qt().state.sizeUnit+2)),Dsn=(i,s)=>{let u=qt().state.forkWidth,d=qt().state.forkHeight;if(s.parentId){let p=u;u=d,d=p}return i.append("rect").style("stroke","black").style("fill","black").attr("width",u).attr("height",d).attr("x",qt().state.padding).attr("y",qt().state.padding)},Isn=(i,s,u,d)=>{let p=0;const v=d.append("text");v.style("text-anchor","start"),v.attr("class","noteText");let b=i.replace(/\r\n/g,"
    ");b=b.replace(/\n/g,"
    ");const y=b.split(ci.lineBreakRegex);let T=1.25*qt().state.noteMargin;for(const _ of y){const A=_.trim();if(A.length>0){const P=v.append("tspan");if(P.text(A),T===0){const R=P.node().getBBox();T+=R.height}p+=T,P.attr("x",s+qt().state.noteMargin),P.attr("y",u+p+1.25*qt().state.noteMargin)}}return{textWidth:v.node().getBBox().width,textHeight:p}},Osn=(i,s)=>{s.attr("class","state-note");const u=s.append("rect").attr("x",0).attr("y",qt().state.padding),d=s.append("g"),{textWidth:p,textHeight:v}=Isn(i,0,0,d);return u.attr("height",v+2*qt().state.noteMargin),u.attr("width",p+qt().state.noteMargin*2),u},EKe=function(i,s){const u=s.id,d={id:u,label:s.id,width:0,height:0},p=i.append("g").attr("id",u).attr("class","stateGroup");s.type==="start"&&Csn(p),s.type==="end"&&Msn(p),(s.type==="fork"||s.type==="join")&&Dsn(p,s),s.type==="note"&&Osn(s.note.text,p),s.type==="divider"&&Ssn(p),s.type==="default"&&s.descriptions.length===0&&_sn(p,s),s.type==="default"&&s.descriptions.length>0&&Asn(p,s);const v=p.node().getBBox();return d.width=v.width+2*qt().state.padding,d.height=v.height+2*qt().state.padding,Tsn.set(u,d),d};let TKe=0;const Nsn=function(i,s,u){const d=function(T){switch(T){case G7.relationType.AGGREGATION:return"aggregation";case G7.relationType.EXTENSION:return"extension";case G7.relationType.COMPOSITION:return"composition";case G7.relationType.DEPENDENCY:return"dependency"}};s.points=s.points.filter(T=>!Number.isNaN(T.y));const p=s.points,v=k7().x(function(T){return T.x}).y(function(T){return T.y}).curve(FF),b=i.append("path").attr("d",v(p)).attr("id","edge"+TKe).attr("class","transition");let y="";if(qt().state.arrowMarkerAbsolute&&(y=window.location.protocol+"//"+window.location.host+window.location.pathname+window.location.search,y=y.replace(/\(/g,"\\("),y=y.replace(/\)/g,"\\)")),b.attr("marker-end","url("+y+"#"+d(G7.relationType.DEPENDENCY)+"End)"),u.title!==void 0){const T=i.append("g").attr("class","stateLabel"),{x:_,y:A}=Ao.calcLabelPosition(s.points),P=ci.getRows(u.title);let R=0;const F=[];let j=0,K=0;for(let oe=0;oe<=P.length;oe++){const pe=T.append("text").attr("text-anchor","middle").text(P[oe]).attr("x",_).attr("y",A+R),be=pe.node().getBBox();j=Math.max(j,be.width),K=Math.min(K,be.x),Xe.info(be.x,_,A+R),R===0&&(R=pe.node().getBBox().height,Xe.info("Title height",R,A)),F.push(pe)}let ee=R*P.length;if(P.length>1){const oe=(P.length-1)*R*.5;F.forEach((pe,be)=>pe.attr("y",A+be*R-oe)),ee=R*P.length}const ie=T.node().getBBox();T.insert("rect",":first-child").attr("class","box").attr("x",_-j/2-qt().state.padding/2).attr("y",A-ee/2-qt().state.padding/2-3.5).attr("width",j+qt().state.padding).attr("height",ee+qt().state.padding),Xe.info(ie)}TKe++};let gm;const qve={},Psn=function(){},Bsn=function(i){i.append("defs").append("marker").attr("id","dependencyEnd").attr("refX",19).attr("refY",7).attr("markerWidth",20).attr("markerHeight",28).attr("orient","auto").append("path").attr("d","M 19,7 L9,13 L14,7 L9,1 Z")},Fsn=function(i,s,u,d){gm=qt().state;const p=qt().securityLevel;let v;p==="sandbox"&&(v=Ir("#i"+s));const b=Ir(p==="sandbox"?v.nodes()[0].contentDocument.body:"body"),y=p==="sandbox"?v.nodes()[0].contentDocument:document;Xe.debug("Rendering diagram "+i);const T=b.select(`[id='${s}']`);Bsn(T);const _=d.db.getRootDoc();CKe(_,T,void 0,!1,b,y,d);const A=gm.padding,P=T.node().getBBox(),R=P.width+A*2,F=P.height+A*2,j=R*1.75;Ng(T,F,j,gm.useMaxWidth),T.attr("viewBox",`${P.x-gm.padding} ${P.y-gm.padding} `+R+" "+F)},Rsn=i=>i?i.length*gm.fontSizeFactor:1,CKe=(i,s,u,d,p,v,b)=>{const y=new B0({compound:!0,multigraph:!0});let T,_=!0;for(T=0;T{const be=pe.parentElement;let ae=0,ne=0;be&&(be.parentElement&&(ae=be.parentElement.getBBox().width),ne=parseInt(be.getAttribute("data-x-shift"),10),Number.isNaN(ne)&&(ne=0)),pe.setAttribute("x1",0-ne+8),pe.setAttribute("x2",ae-ne-8)})):Xe.debug("No Node "+ie+": "+JSON.stringify(y.node(ie)))});let K=j.getBBox();y.edges().forEach(function(ie){ie!==void 0&&y.edge(ie)!==void 0&&(Xe.debug("Edge "+ie.v+" -> "+ie.w+": "+JSON.stringify(y.edge(ie))),Nsn(s,y.edge(ie),y.edge(ie).relation))}),K=j.getBBox();const ee={id:u||"root",label:u||"root",width:0,height:0};return ee.width=K.width+2*gm.padding,ee.height=K.height+2*gm.padding,Xe.debug("Doc rendered",ee,y),ee},jsn=Object.freeze(Object.defineProperty({__proto__:null,diagram:{parser:oKe,db:G7,renderer:{setConf:Psn,draw:Fsn},styles:xKe,init:i=>{i.state||(i.state={}),i.state.arrowMarkerAbsolute=i.arrowMarkerAbsolute,G7.clear()}}},Symbol.toStringTag,{value:"Module"})),AJ="rect",Hve="rectWithTitle",$sn="start",zsn="end",qsn="divider",Hsn="roundedWithTitle",Vsn="note",Usn="noteGroup",QD="statediagram",Gsn=`${QD}-state`,SKe="transition",Ksn="note",Wsn=`${SKe} note-edge`,Ysn=`${QD}-${Ksn}`,Xsn=`${QD}-cluster`,Qsn=`${QD}-cluster-alt`,_Ke="parent",AKe="note",Jsn="state",Vve="----",Zsn=`${Vve}${AKe}`,LKe=`${Vve}${_Ke}`,MKe="fill:none",DKe="fill: #333",IKe="c",OKe="text",NKe="normal";let LJ={},j9=0;const ean=function(i){const s=Object.keys(i);for(const u of s)i[u]},tan=function(i,s){return s.db.extract(s.db.getRootDocV2()),s.db.getClasses()};function nan(i){return i==null?"":i.classes?i.classes.join(" "):""}function Uve(i="",s=0,u="",d=Vve){const p=u!==null&&u.length>0?`${d}${u}`:"";return`${Jsn}-${i}${p}-${s}`}const ej=(i,s,u,d,p,v)=>{const b=u.id,y=nan(d[b]);if(b!=="root"){let T=AJ;u.start===!0&&(T=$sn),u.start===!1&&(T=zsn),u.type!==XR&&(T=u.type),LJ[b]||(LJ[b]={id:b,shape:T,description:ci.sanitizeText(b,qt()),classes:`${y} ${Gsn}`});const _=LJ[b];u.description&&(Array.isArray(_.description)?(_.shape=Hve,_.description.push(u.description)):_.description.length>0?(_.shape=Hve,_.description===b?_.description=[u.description]:_.description=[_.description,u.description]):(_.shape=AJ,_.description=u.description),_.description=ci.sanitizeTextOrArray(_.description,qt())),_.description.length===1&&_.shape===Hve&&(_.shape=AJ),!_.type&&u.doc&&(Xe.info("Setting cluster for ",b,Gve(u)),_.type="group",_.dir=Gve(u),_.shape=u.type===cKe?qsn:Hsn,_.classes=_.classes+" "+Xsn+" "+(v?Qsn:""));const A={labelStyle:"",shape:_.shape,labelText:_.description,classes:_.classes,style:"",id:b,dir:_.dir,domId:Uve(b,j9),type:_.type,padding:15};if(A.centerLabel=!0,u.note){const P={labelStyle:"",shape:Vsn,labelText:u.note.text,classes:Ysn,style:"",id:b+Zsn+"-"+j9,domId:Uve(b,j9,AKe),type:_.type,padding:15},R={labelStyle:"",shape:Usn,labelText:u.note.text,classes:_.classes,style:"",id:b+LKe,domId:Uve(b,j9,_Ke),type:"group",padding:0};j9++;const F=b+LKe;i.setNode(F,R),i.setNode(P.id,P),i.setNode(b,A),i.setParent(b,F),i.setParent(P.id,F);let j=b,K=P.id;u.note.position==="left of"&&(j=P.id,K=b),i.setEdge(j,K,{arrowhead:"none",arrowType:"",style:MKe,labelStyle:"",classes:Wsn,arrowheadStyle:DKe,labelpos:IKe,labelType:OKe,thickness:NKe})}else i.setNode(b,A)}s&&s.id!=="root"&&(Xe.trace("Setting node ",b," to be child of its parent ",s.id),i.setParent(b,s.id)),u.doc&&(Xe.trace("Adding nodes children "),ran(i,u,u.doc,d,p,!v))},ran=(i,s,u,d,p,v)=>{Xe.trace("items",u),u.forEach(b=>{switch(b.stmt){case EJ:ej(i,s,b,d,p,v);break;case XR:ej(i,s,b,d,p,v);break;case Pve:{ej(i,s,b.state1,d,p,v),ej(i,s,b.state2,d,p,v);const y={id:"edge"+j9,arrowhead:"normal",arrowTypeEnd:"arrow_barb",style:MKe,labelStyle:"",label:ci.sanitizeText(b.description,qt()),arrowheadStyle:DKe,labelpos:IKe,labelType:OKe,thickness:NKe,classes:SKe};i.setEdge(b.state1.id,b.state2.id,y,j9),j9++}break}})},Gve=(i,s=esn)=>{let u=s;if(i.doc)for(let d=0;d{i.state||(i.state={}),i.state.arrowMarkerAbsolute=i.arrowMarkerAbsolute,G7.clear()}}},Symbol.toStringTag,{value:"Module"}));var Kve=function(){var i=function(P,R,F,j){for(F=F||{},j=P.length;j--;F[P[j]]=R);return F},s=[6,8,10,11,12,14,16,17,18],u=[1,9],d=[1,10],p=[1,11],v=[1,12],b=[1,13],y=[1,14],T={trace:function(){},yy:{},symbols_:{error:2,start:3,journey:4,document:5,EOF:6,line:7,SPACE:8,statement:9,NEWLINE:10,title:11,acc_title:12,acc_title_value:13,acc_descr:14,acc_descr_value:15,acc_descr_multiline_value:16,section:17,taskName:18,taskData:19,$accept:0,$end:1},terminals_:{2:"error",4:"journey",6:"EOF",8:"SPACE",10:"NEWLINE",11:"title",12:"acc_title",13:"acc_title_value",14:"acc_descr",15:"acc_descr_value",16:"acc_descr_multiline_value",17:"section",18:"taskName",19:"taskData"},productions_:[0,[3,3],[5,0],[5,2],[7,2],[7,1],[7,1],[7,1],[9,1],[9,2],[9,2],[9,1],[9,1],[9,2]],performAction:function(R,F,j,K,ee,ie,oe){var pe=ie.length-1;switch(ee){case 1:return ie[pe-1];case 2:this.$=[];break;case 3:ie[pe-1].push(ie[pe]),this.$=ie[pe-1];break;case 4:case 5:this.$=ie[pe];break;case 6:case 7:this.$=[];break;case 8:K.setDiagramTitle(ie[pe].substr(6)),this.$=ie[pe].substr(6);break;case 9:this.$=ie[pe].trim(),K.setAccTitle(this.$);break;case 10:case 11:this.$=ie[pe].trim(),K.setAccDescription(this.$);break;case 12:K.addSection(ie[pe].substr(8)),this.$=ie[pe].substr(8);break;case 13:K.addTask(ie[pe-1],ie[pe]),this.$="task";break}},table:[{3:1,4:[1,2]},{1:[3]},i(s,[2,2],{5:3}),{6:[1,4],7:5,8:[1,6],9:7,10:[1,8],11:u,12:d,14:p,16:v,17:b,18:y},i(s,[2,7],{1:[2,1]}),i(s,[2,3]),{9:15,11:u,12:d,14:p,16:v,17:b,18:y},i(s,[2,5]),i(s,[2,6]),i(s,[2,8]),{13:[1,16]},{15:[1,17]},i(s,[2,11]),i(s,[2,12]),{19:[1,18]},i(s,[2,4]),i(s,[2,9]),i(s,[2,10]),i(s,[2,13])],defaultActions:{},parseError:function(R,F){if(F.recoverable)this.trace(R);else{var j=new Error(R);throw j.hash=F,j}},parse:function(R){var F=this,j=[0],K=[],ee=[null],ie=[],oe=this.table,pe="",be=0,ae=0,ne=2,se=1,de=ie.slice.call(arguments,1),X=Object.create(this.lexer),ge={yy:{}};for(var W in this.yy)Object.prototype.hasOwnProperty.call(this.yy,W)&&(ge.yy[W]=this.yy[W]);X.setInput(R,ge.yy),ge.yy.lexer=X,ge.yy.parser=this,typeof X.yylloc>"u"&&(X.yylloc={});var xe=X.yylloc;ie.push(xe);var U=X.options&&X.options.ranges;typeof ge.yy.parseError=="function"?this.parseError=ge.yy.parseError:this.parseError=Object.getPrototypeOf(this).parseError;function Fe(){var _t;return _t=K.pop()||X.lex()||se,typeof _t!="number"&&(_t instanceof Array&&(K=_t,_t=K.pop()),_t=F.symbols_[_t]||_t),_t}for(var Pe,je,Ie,Se,Ce={},ke,Ke,Ft,Ne;;){if(je=j[j.length-1],this.defaultActions[je]?Ie=this.defaultActions[je]:((Pe===null||typeof Pe>"u")&&(Pe=Fe()),Ie=oe[je]&&oe[je][Pe]),typeof Ie>"u"||!Ie.length||!Ie[0]){var gn="";Ne=[];for(ke in oe[je])this.terminals_[ke]&&ke>ne&&Ne.push("'"+this.terminals_[ke]+"'");X.showPosition?gn="Parse error on line "+(be+1)+`: +`+X.showPosition()+` +Expecting `+Ne.join(", ")+", got '"+(this.terminals_[Pe]||Pe)+"'":gn="Parse error on line "+(be+1)+": Unexpected "+(Pe==se?"end of input":"'"+(this.terminals_[Pe]||Pe)+"'"),this.parseError(gn,{text:X.match,token:this.terminals_[Pe]||Pe,line:X.yylineno,loc:xe,expected:Ne})}if(Ie[0]instanceof Array&&Ie.length>1)throw new Error("Parse Error: multiple actions possible at state: "+je+", token: "+Pe);switch(Ie[0]){case 1:j.push(Pe),ee.push(X.yytext),ie.push(X.yylloc),j.push(Ie[1]),Pe=null,ae=X.yyleng,pe=X.yytext,be=X.yylineno,xe=X.yylloc;break;case 2:if(Ke=this.productions_[Ie[1]][1],Ce.$=ee[ee.length-Ke],Ce._$={first_line:ie[ie.length-(Ke||1)].first_line,last_line:ie[ie.length-1].last_line,first_column:ie[ie.length-(Ke||1)].first_column,last_column:ie[ie.length-1].last_column},U&&(Ce._$.range=[ie[ie.length-(Ke||1)].range[0],ie[ie.length-1].range[1]]),Se=this.performAction.apply(Ce,[pe,ae,be,ge.yy,Ie[1],ee,ie].concat(de)),typeof Se<"u")return Se;Ke&&(j=j.slice(0,-1*Ke*2),ee=ee.slice(0,-1*Ke),ie=ie.slice(0,-1*Ke)),j.push(this.productions_[Ie[1]][0]),ee.push(Ce.$),ie.push(Ce._$),Ft=oe[j[j.length-2]][j[j.length-1]],j.push(Ft);break;case 3:return!0}}return!0}},_=function(){var P={EOF:1,parseError:function(F,j){if(this.yy.parser)this.yy.parser.parseError(F,j);else throw new Error(F)},setInput:function(R,F){return this.yy=F||this.yy||{},this._input=R,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},input:function(){var R=this._input[0];this.yytext+=R,this.yyleng++,this.offset++,this.match+=R,this.matched+=R;var F=R.match(/(?:\r\n?|\n).*/g);return F?(this.yylineno++,this.yylloc.last_line++):this.yylloc.last_column++,this.options.ranges&&this.yylloc.range[1]++,this._input=this._input.slice(1),R},unput:function(R){var F=R.length,j=R.split(/(?:\r\n?|\n)/g);this._input=R+this._input,this.yytext=this.yytext.substr(0,this.yytext.length-F),this.offset-=F;var K=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),j.length-1&&(this.yylineno-=j.length-1);var ee=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:j?(j.length===K.length?this.yylloc.first_column:0)+K[K.length-j.length].length-j[0].length:this.yylloc.first_column-F},this.options.ranges&&(this.yylloc.range=[ee[0],ee[0]+this.yyleng-F]),this.yyleng=this.yytext.length,this},more:function(){return this._more=!0,this},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},less:function(R){this.unput(this.match.slice(R))},pastInput:function(){var R=this.matched.substr(0,this.matched.length-this.match.length);return(R.length>20?"...":"")+R.substr(-20).replace(/\n/g,"")},upcomingInput:function(){var R=this.match;return R.length<20&&(R+=this._input.substr(0,20-R.length)),(R.substr(0,20)+(R.length>20?"...":"")).replace(/\n/g,"")},showPosition:function(){var R=this.pastInput(),F=new Array(R.length+1).join("-");return R+this.upcomingInput()+` +`+F+"^"},test_match:function(R,F){var j,K,ee;if(this.options.backtrack_lexer&&(ee={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&&(ee.yylloc.range=this.yylloc.range.slice(0))),K=R[0].match(/(?:\r\n?|\n).*/g),K&&(this.yylineno+=K.length),this.yylloc={first_line:this.yylloc.last_line,last_line:this.yylineno+1,first_column:this.yylloc.last_column,last_column:K?K[K.length-1].length-K[K.length-1].match(/\r?\n?/)[0].length:this.yylloc.last_column+R[0].length},this.yytext+=R[0],this.match+=R[0],this.matches=R,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(R[0].length),this.matched+=R[0],j=this.performAction.call(this,this.yy,this,F,this.conditionStack[this.conditionStack.length-1]),this.done&&this._input&&(this.done=!1),j)return j;if(this._backtrack){for(var ie in ee)this[ie]=ee[ie];return!1}return!1},next:function(){if(this.done)return this.EOF;this._input||(this.done=!0);var R,F,j,K;this._more||(this.yytext="",this.match="");for(var ee=this._currentRules(),ie=0;ieF[0].length)){if(F=j,K=ie,this.options.backtrack_lexer){if(R=this.test_match(j,ee[ie]),R!==!1)return R;if(this._backtrack){F=!1;continue}else return!1}else if(!this.options.flex)break}return F?(R=this.test_match(F,ee[K]),R!==!1?R:!1):this._input===""?this.EOF:this.parseError("Lexical error on line "+(this.yylineno+1)+`. Unrecognized text. +`+this.showPosition(),{text:"",token:null,line:this.yylineno})},lex:function(){var F=this.next();return F||this.lex()},begin:function(F){this.conditionStack.push(F)},popState:function(){var F=this.conditionStack.length-1;return F>0?this.conditionStack.pop():this.conditionStack[0]},_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},topState:function(F){return F=this.conditionStack.length-1-Math.abs(F||0),F>=0?this.conditionStack[F]:"INITIAL"},pushState:function(F){this.begin(F)},stateStackSize:function(){return this.conditionStack.length},options:{"case-insensitive":!0},performAction:function(F,j,K,ee){switch(K){case 0:break;case 1:break;case 2:return 10;case 3:break;case 4:break;case 5:return 4;case 6:return 11;case 7:return this.begin("acc_title"),12;case 8:return this.popState(),"acc_title_value";case 9:return this.begin("acc_descr"),14;case 10:return this.popState(),"acc_descr_value";case 11:this.begin("acc_descr_multiline");break;case 12:this.popState();break;case 13:return"acc_descr_multiline_value";case 14:return 17;case 15:return 18;case 16:return 19;case 17:return":";case 18:return 6;case 19:return"INVALID"}},rules:[/^(?:%(?!\{)[^\n]*)/i,/^(?:[^\}]%%[^\n]*)/i,/^(?:[\n]+)/i,/^(?:\s+)/i,/^(?:#[^\n]*)/i,/^(?:journey\b)/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,/^(?:section\s[^#:\n;]+)/i,/^(?:[^#:\n;]+)/i,/^(?::[^#\n;]+)/i,/^(?::)/i,/^(?:$)/i,/^(?:.)/i],conditions:{acc_descr_multiline:{rules:[12,13],inclusive:!1},acc_descr:{rules:[10],inclusive:!1},acc_title:{rules:[8],inclusive:!1},INITIAL:{rules:[0,1,2,3,4,5,6,7,9,11,14,15,16,17,18,19],inclusive:!0}}};return P}();T.lexer=_;function A(){this.yy={}}return A.prototype=T,T.Parser=A,new A}();Kve.parser=Kve;const san=Kve;let JD="";const Wve=[],tj=[],nj=[],aan=function(){Wve.length=0,tj.length=0,JD="",nj.length=0,Pg()},oan=function(i){JD=i,Wve.push(i)},can=function(){return Wve},uan=function(){let i=PKe();const s=100;let u=0;for(;!i&&u{u.people&&i.push(...u.people)}),[...new Set(i)].sort()},han=function(i,s){const u=s.substr(1).split(":");let d=0,p=[];u.length===1?(d=Number(u[0]),p=[]):(d=Number(u[0]),p=u[1].split(","));const v=p.map(y=>y.trim()),b={section:JD,type:JD,people:v,task:i,score:d};nj.push(b)},fan=function(i){const s={section:JD,type:JD,description:i,task:i,classes:[]};tj.push(s)},PKe=function(){const i=function(u){return nj[u].processed};let s=!0;for(const[u,d]of nj.entries())i(u),s=s&&d.processed;return s},BKe={getConfig:()=>qt().journey,clear:aan,setDiagramTitle:cm,getDiagramTitle:Ap,setAccTitle:Bg,getAccTitle:Cp,setAccDescription:Sp,getAccDescription:_p,addSection:oan,getSections:can,getTasks:uan,addTask:han,addTaskOrg:fan,getActors:function(){return lan()}},dan=i=>`.label { + font-family: 'trebuchet ms', verdana, arial, sans-serif; + font-family: var(--mermaid-font-family); + color: ${i.textColor}; + } + .mouth { + stroke: #666; + } + + line { + stroke: ${i.textColor} + } + + .legend { + fill: ${i.textColor}; + } + + .label text { + fill: #333; + } + .label { + color: ${i.textColor} + } + + .face { + ${i.faceColor?`fill: ${i.faceColor}`:"fill: #FFF8DC"}; + stroke: #999; + } + + .node rect, + .node circle, + .node ellipse, + .node polygon, + .node path { + fill: ${i.mainBkg}; + stroke: ${i.nodeBorder}; + stroke-width: 1px; + } + + .node .label { + text-align: center; + } + .node.clickable { + cursor: pointer; + } + + .arrowheadPath { + fill: ${i.arrowheadColor}; + } + + .edgePath .path { + stroke: ${i.lineColor}; + stroke-width: 1.5px; + } + + .flowchart-link { + stroke: ${i.lineColor}; + fill: none; + } + + .edgeLabel { + background-color: ${i.edgeLabelBackground}; + rect { + opacity: 0.5; + } + text-align: center; + } + + .cluster rect { + } + + .cluster text { + fill: ${i.titleColor}; + } + + div.mermaidTooltip { + position: absolute; + text-align: center; + max-width: 200px; + padding: 2px; + font-family: 'trebuchet ms', verdana, arial, sans-serif; + font-family: var(--mermaid-font-family); + font-size: 12px; + background: ${i.tertiaryColor}; + border: 1px solid ${i.border2}; + border-radius: 2px; + pointer-events: none; + z-index: 100; + } + + .task-type-0, .section-type-0 { + ${i.fillType0?`fill: ${i.fillType0}`:""}; + } + .task-type-1, .section-type-1 { + ${i.fillType0?`fill: ${i.fillType1}`:""}; + } + .task-type-2, .section-type-2 { + ${i.fillType0?`fill: ${i.fillType2}`:""}; + } + .task-type-3, .section-type-3 { + ${i.fillType0?`fill: ${i.fillType3}`:""}; + } + .task-type-4, .section-type-4 { + ${i.fillType0?`fill: ${i.fillType4}`:""}; + } + .task-type-5, .section-type-5 { + ${i.fillType0?`fill: ${i.fillType5}`:""}; + } + .task-type-6, .section-type-6 { + ${i.fillType0?`fill: ${i.fillType6}`:""}; + } + .task-type-7, .section-type-7 { + ${i.fillType0?`fill: ${i.fillType7}`:""}; + } + + .actor-0 { + ${i.actor0?`fill: ${i.actor0}`:""}; + } + .actor-1 { + ${i.actor1?`fill: ${i.actor1}`:""}; + } + .actor-2 { + ${i.actor2?`fill: ${i.actor2}`:""}; + } + .actor-3 { + ${i.actor3?`fill: ${i.actor3}`:""}; + } + .actor-4 { + ${i.actor4?`fill: ${i.actor4}`:""}; + } + .actor-5 { + ${i.actor5?`fill: ${i.actor5}`:""}; + } +`,Yve=function(i,s){return AQ(i,s)},gan=function(i,s){const d=i.append("circle").attr("cx",s.cx).attr("cy",s.cy).attr("class","face").attr("r",15).attr("stroke-width",2).attr("overflow","visible"),p=i.append("g");p.append("circle").attr("cx",s.cx-15/3).attr("cy",s.cy-15/3).attr("r",1.5).attr("stroke-width",2).attr("fill","#666").attr("stroke","#666"),p.append("circle").attr("cx",s.cx+15/3).attr("cy",s.cy-15/3).attr("r",1.5).attr("stroke-width",2).attr("fill","#666").attr("stroke","#666");function v(T){const _=lD().startAngle(Math.PI/2).endAngle(3*(Math.PI/2)).innerRadius(7.5).outerRadius(6.8181818181818175);T.append("path").attr("class","mouth").attr("d",_).attr("transform","translate("+s.cx+","+(s.cy+2)+")")}function b(T){const _=lD().startAngle(3*Math.PI/2).endAngle(5*(Math.PI/2)).innerRadius(7.5).outerRadius(6.8181818181818175);T.append("path").attr("class","mouth").attr("d",_).attr("transform","translate("+s.cx+","+(s.cy+7)+")")}function y(T){T.append("line").attr("class","mouth").attr("stroke",2).attr("x1",s.cx-5).attr("y1",s.cy+7).attr("x2",s.cx+5).attr("y2",s.cy+7).attr("class","mouth").attr("stroke-width","1px").attr("stroke","#666")}return s.score>3?v(p):s.score<3?b(p):y(p),d},FKe=function(i,s){const u=i.append("circle");return u.attr("cx",s.cx),u.attr("cy",s.cy),u.attr("class","actor-"+s.pos),u.attr("fill",s.fill),u.attr("stroke",s.stroke),u.attr("r",s.r),u.class!==void 0&&u.attr("class",u.class),s.title!==void 0&&u.append("title").text(s.title),u},RKe=function(i,s){return tUt(i,s)},pan=function(i,s){function u(p,v,b,y,T){return p+","+v+" "+(p+b)+","+v+" "+(p+b)+","+(v+y-T)+" "+(p+b-T*1.2)+","+(v+y)+" "+p+","+(v+y)}const d=i.append("polygon");d.attr("points",u(s.x,s.y,50,20,7)),d.attr("class","labelBox"),s.y=s.y+s.labelMargin,s.x=s.x+.5*s.labelMargin,RKe(i,s)},ban=function(i,s,u){const d=i.append("g"),p=qC();p.x=s.x,p.y=s.y,p.fill=s.fill,p.width=u.width*s.taskCount+u.diagramMarginX*(s.taskCount-1),p.height=u.height,p.class="journey-section section-type-"+s.num,p.rx=3,p.ry=3,Yve(d,p),$Ke(u)(s.text,d,p.x,p.y,p.width,p.height,{class:"journey-section section-type-"+s.num},u,s.colour)};let jKe=-1;const man=function(i,s,u){const d=s.x+u.width/2,p=i.append("g");jKe++;const v=300+5*30;p.append("line").attr("id","task"+jKe).attr("x1",d).attr("y1",s.y).attr("x2",d).attr("y2",v).attr("class","task-line").attr("stroke-width","1px").attr("stroke-dasharray","4 2").attr("stroke","#666"),gan(p,{cx:d,cy:300+(5-s.score)*30,score:s.score});const b=qC();b.x=s.x,b.y=s.y,b.fill=s.fill,b.width=u.width,b.height=u.height,b.class="task task-type-"+s.num,b.rx=3,b.ry=3,Yve(p,b);let y=s.x+14;s.people.forEach(T=>{const _=s.actors[T].color,A={cx:y,cy:s.y,r:7,fill:_,stroke:"#000",title:T,pos:s.actors[T].position};FKe(p,A),y+=10}),$Ke(u)(s.task,p,b.x,b.y,b.width,b.height,{class:"task"},u,s.colour)},van=function(i,s){Tqe(i,s)},$Ke=function(){function i(p,v,b,y,T,_,A,P){const R=v.append("text").attr("x",b+T/2).attr("y",y+_/2+5).style("font-color",P).style("text-anchor","middle").text(p);d(R,A)}function s(p,v,b,y,T,_,A,P,R){const{taskFontSize:F,taskFontFamily:j}=P,K=p.split(//gi);for(let ee=0;ee{const p=K7[d].color,v={cx:20,cy:u,r:7,fill:p,stroke:"#000",pos:K7[d].position};rj.drawCircle(i,v);const b={x:40,y:u+7,fill:"#666",text:d,textMargin:s.boxTextMargin|5};rj.drawText(i,b),u+=20})}const MJ=qt().journey,iS=MJ.leftMargin,xan=function(i,s,u,d){const p=qt().journey,v=qt().securityLevel;let b;v==="sandbox"&&(b=Ir("#i"+s));const y=Ir(v==="sandbox"?b.nodes()[0].contentDocument.body:"body");qv.init();const T=y.select("#"+s);rj.initGraphics(T);const _=d.db.getTasks(),A=d.db.getDiagramTitle(),P=d.db.getActors();for(const ie in K7)delete K7[ie];let R=0;P.forEach(ie=>{K7[ie]={color:p.actorColours[R%p.actorColours.length],position:R},R++}),yan(T),qv.insert(0,0,iS,Object.keys(K7).length*50),kan(T,_,0);const F=qv.getBounds();A&&T.append("text").text(A).attr("x",iS).attr("font-size","4ex").attr("font-weight","bold").attr("y",25);const j=F.stopy-F.starty+2*p.diagramMarginY,K=iS+F.stopx+2*p.diagramMarginX;Ng(T,j,K,p.useMaxWidth),T.append("line").attr("x1",iS).attr("y1",p.height*4).attr("x2",K-iS-4).attr("y2",p.height*4).attr("stroke-width",4).attr("stroke","black").attr("marker-end","url(#arrowhead)");const ee=A?70:0;T.attr("viewBox",`${F.startx} -25 ${K} ${j+ee}`),T.attr("preserveAspectRatio","xMinYMin meet"),T.attr("height",j+ee+25)},qv={data:{startx:void 0,stopx:void 0,starty:void 0,stopy:void 0},verticalPos:0,sequenceItems:[],init:function(){this.sequenceItems=[],this.data={startx:void 0,stopx:void 0,starty:void 0,stopy:void 0},this.verticalPos=0},updateVal:function(i,s,u,d){i[s]===void 0?i[s]=u:i[s]=d(u,i[s])},updateBounds:function(i,s,u,d){const p=qt().journey,v=this;let b=0;function y(T){return function(A){b++;const P=v.sequenceItems.length-b+1;v.updateVal(A,"starty",s-P*p.boxMargin,Math.min),v.updateVal(A,"stopy",d+P*p.boxMargin,Math.max),v.updateVal(qv.data,"startx",i-P*p.boxMargin,Math.min),v.updateVal(qv.data,"stopx",u+P*p.boxMargin,Math.max),T!=="activation"&&(v.updateVal(A,"startx",i-P*p.boxMargin,Math.min),v.updateVal(A,"stopx",u+P*p.boxMargin,Math.max),v.updateVal(qv.data,"starty",s-P*p.boxMargin,Math.min),v.updateVal(qv.data,"stopy",d+P*p.boxMargin,Math.max))}}this.sequenceItems.forEach(y())},insert:function(i,s,u,d){const p=Math.min(i,u),v=Math.max(i,u),b=Math.min(s,d),y=Math.max(s,d);this.updateVal(qv.data,"startx",p,Math.min),this.updateVal(qv.data,"starty",b,Math.min),this.updateVal(qv.data,"stopx",v,Math.max),this.updateVal(qv.data,"stopy",y,Math.max),this.updateBounds(p,b,v,y)},bumpVerticalPos:function(i){this.verticalPos=this.verticalPos+i,this.data.stopy=this.verticalPos},getVerticalPos:function(){return this.verticalPos},getBounds:function(){return this.data}},Xve=MJ.sectionFills,zKe=MJ.sectionColours,kan=function(i,s,u){const d=qt().journey;let p="";const v=d.height*2+d.diagramMarginY,b=u+v;let y=0,T="#CCC",_="black",A=0;for(const[P,R]of s.entries()){if(p!==R.section){T=Xve[y%Xve.length],A=y%Xve.length,_=zKe[y%zKe.length];let j=0;const K=R.section;for(let ie=P;ie(K7[K]&&(j[K]=K7[K]),j),{});R.x=P*d.taskMargin+P*d.width+iS,R.y=b,R.width=d.diagramMarginX,R.height=d.diagramMarginY,R.colour=_,R.fill=T,R.num=A,R.actors=F,rj.drawTask(i,R,d),qv.insert(R.x,R.y,R.x+R.width+d.taskMargin,300+5*30)}},qKe={setConf:wan,draw:xan},Ean=Object.freeze(Object.defineProperty({__proto__:null,diagram:{parser:san,db:BKe,renderer:qKe,styles:dan,init:i=>{qKe.setConf(i.journey),BKe.clear()}}},Symbol.toStringTag,{value:"Module"})),Tan=(i,s,u)=>{const{parentById:d}=u,p=new Set;let v=i;for(;v;){if(p.add(v),v===s)return v;v=d[v]}for(v=s;v;){if(p.has(v))return v;v=d[v]}return"root"};function DJ(i){throw new Error('Could not dynamically require "'+i+'". Please configure the dynamicRequireTargets or/and ignoreDynamicRequires option of @rollup/plugin-commonjs appropriately for this require call to work.')}var HKe={exports:{}};(function(i,s){(function(u){i.exports=u()})(function(){return function(){function u(d,p,v){function b(_,A){if(!p[_]){if(!d[_]){var P=typeof DJ=="function"&&DJ;if(!A&&P)return P(_,!0);if(y)return y(_,!0);var R=new Error("Cannot find module '"+_+"'");throw R.code="MODULE_NOT_FOUND",R}var F=p[_]={exports:{}};d[_][0].call(F.exports,function(j){var K=d[_][1][j];return b(K||j)},F,F.exports,u,d,p,v)}return p[_].exports}for(var y=typeof DJ=="function"&&DJ,T=0;T0&&arguments[0]!==void 0?arguments[0]:{},R=P.defaultLayoutOptions,F=R===void 0?{}:R,j=P.algorithms,K=j===void 0?["layered","stress","mrtree","radial","force","disco","sporeOverlap","sporeCompaction","rectpacking"]:j,ee=P.workerFactory,ie=P.workerUrl;if(b(this,_),this.defaultLayoutOptions=F,this.initialized=!1,typeof ie>"u"&&typeof ee>"u")throw new Error("Cannot construct an ELK without both 'workerUrl' and 'workerFactory'.");var oe=ee;typeof ie<"u"&&typeof ee>"u"&&(oe=function(ae){return new Worker(ae)});var pe=oe(ie);if(typeof pe.postMessage!="function")throw new TypeError("Created worker does not provide the required 'postMessage' function.");this.worker=new T(pe),this.worker.postMessage({cmd:"register",algorithms:K}).then(function(be){return A.initialized=!0}).catch(console.err)}return v(_,[{key:"layout",value:function(P){var R=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{},F=R.layoutOptions,j=F===void 0?this.defaultLayoutOptions:F,K=R.logging,ee=K===void 0?!1:K,ie=R.measureExecutionTime,oe=ie===void 0?!1:ie;return P?this.worker.postMessage({cmd:"layout",graph:P,layoutOptions:j,options:{logging:ee,measureExecutionTime:oe}}):Promise.reject(new Error("Missing mandatory parameter 'graph'."))}},{key:"knownLayoutAlgorithms",value:function(){return this.worker.postMessage({cmd:"algorithms"})}},{key:"knownLayoutOptions",value:function(){return this.worker.postMessage({cmd:"options"})}},{key:"knownLayoutCategories",value:function(){return this.worker.postMessage({cmd:"categories"})}},{key:"terminateWorker",value:function(){this.worker.terminate()}}]),_}();p.default=y;var T=function(){function _(A){var P=this;if(b(this,_),A===void 0)throw new Error("Missing mandatory parameter 'worker'.");this.resolvers={},this.worker=A,this.worker.onmessage=function(R){setTimeout(function(){P.receive(P,R)},0)}}return v(_,[{key:"postMessage",value:function(P){var R=this.id||0;this.id=R+1,P.id=R;var F=this;return new Promise(function(j,K){F.resolvers[R]=function(ee,ie){ee?(F.convertGwtStyleError(ee),K(ee)):j(ie)},F.worker.postMessage(P)})}},{key:"receive",value:function(P,R){var F=R.data,j=P.resolvers[F.id];j&&(delete P.resolvers[F.id],F.error?j(F.error):j(null,F.data))}},{key:"terminate",value:function(){this.worker.terminate&&this.worker.terminate()}},{key:"convertGwtStyleError",value:function(P){if(P){var R=P.__java$exception;R&&(R.cause&&R.cause.backingJsObject&&(P.cause=R.cause.backingJsObject,this.convertGwtStyleError(P.cause)),delete P.__java$exception)}}}]),_}()},{}],2:[function(u,d,p){(function(v){(function(){var b;typeof window<"u"?b=window:typeof v<"u"?b=v:typeof self<"u"&&(b=self);var y;function T(){}function _(){}function A(){}function P(){}function R(){}function F(){}function j(){}function K(){}function ee(){}function ie(){}function oe(){}function pe(){}function be(){}function ae(){}function ne(){}function se(){}function de(){}function X(){}function ge(){}function W(){}function xe(){}function U(){}function Fe(){}function Pe(){}function je(){}function Ie(){}function Se(){}function Ce(){}function ke(){}function Ke(){}function Ft(){}function Ne(){}function gn(){}function _t(){}function Et(){}function Gt(){}function ln(){}function xt(){}function Pt(){}function Qe(){}function Dt(){}function kt(){}function On(){}function ht(){}function zr(){}function yt(){}function ji(){}function xi(){}function Ma(){}function zs(){}function ao(){}function Tr(){}function Fn(){}function qn(){}function Un(){}function At(){}function wt(){}function on(){}function fn(){}function An(){}function oo(){}function jo(){}function $o(){}function Pa(){}function wo(){}function _s(){}function tl(){}function da(){}function j0(){}function pm(){}function Ml(){}function Xc(){}function Bc(){}function ja(){}function Ou(){}function Sa(){}function Po(){}function Fc(){}function xa(){}function Ba(){}function ga(){}function kh(){}function lu(){}function o5(){}function Wh(){}function od(){}function Gd(){}function cd(){}function Kd(){}function $g(){}function as(){}function wn(){}function Zr(){}function Zi(){}function nu(){}function vu(){}function Dl(){}function Yh(){}function w1(){}function $0(){}function Wi(){}function Bs(){}function Qa(){}function Bi(){}function Nu(){}function Ot(){}function W3(){}function Kt(){}function z0(){}function Bp(){}function Y3(){}function $9(){}function c5(){}function Eh(){}function zg(){}function bm(){}function z9(){}function mm(){}function u5(){}function y1(){}function ud(){}function ld(){}function q9(){}function Vv(){}function Y7(){}function G2(){}function X7(){}function l5(){}function X3(){}function Fp(){}function nI(){}function ch(){}function oS(){}function hu(){}function $J(){}function vm(){}function zJ(){}function oj(){}function qJ(){}function cj(){}function q0(){}function Q3(){}function cS(){}function uj(){}function K2(){}function J3(){}function HJ(){}function wm(){}function VJ(){}function UJ(){}function Q7(){}function uS(){}function lj(){}function H9(){}function GJ(){}function V9(){}function KJ(){}function WJ(){}function YJ(){}function XJ(){}function QJ(){}function JJ(){}function ZJ(){}function eZ(){}function tZ(){}function nZ(){}function rZ(){}function rI(){}function iZ(){}function sZ(){}function lS(){}function hj(){}function J7(){}function aZ(){}function oZ(){}function cZ(){}function uZ(){}function lZ(){}function hS(){}function iI(){}function fj(){}function h5(){}function f5(){}function hZ(){}function t0(){}function Z7(){}function fZ(){}function U9(){}function Wd(){}function dZ(){}function gZ(){}function pZ(){}function dj(){}function bZ(){}function fS(){}function dS(){}function gj(){}function sI(){}function e8(){}function mZ(){}function pj(){}function bj(){}function vZ(){}function wZ(){}function yZ(){}function xZ(){}function kZ(){}function EZ(){}function Yd(){}function Uv(){}function TZ(){}function gS(){}function pS(){}function CZ(){}function d5(){}function G9(){}function aI(){}function Z3(){}function K9(){}function SZ(){}function bS(){}function hd(){}function mj(){}function oI(){}function W9(){}function cI(){}function vj(){}function _Z(){}function uI(){}function AZ(){}function LZ(){}function wj(){}function t8(){}function yj(){}function n8(){}function MZ(){}function lI(){}function DZ(){}function IZ(){}function OZ(){}function NZ(){}function xj(){}function PZ(){}function BZ(){}function kj(){}function FZ(){}function RZ(){}function jZ(){}function $Z(){}function Ej(){}function zZ(){}function qZ(){}function Tj(){}function Cj(){}function Sj(){}function HZ(){}function VZ(){}function Y9(){}function r8(){}function mS(){}function UZ(){}function hI(){}function vS(){}function fI(){}function _j(){}function Aj(){}function GZ(){}function KZ(){}function WZ(){}function Lj(){}function Mj(){}function YZ(){}function XZ(){}function QZ(){}function JZ(){}function ZZ(){}function Dj(){}function eee(){}function tee(){}function nee(){}function ree(){}function Ij(){}function wS(){}function iee(){}function see(){}function Oj(){}function aee(){}function oee(){}function cee(){}function uee(){}function lee(){}function hee(){}function Nj(){}function fee(){}function Pj(){}function dee(){}function gee(){}function pee(){}function yS(){}function bee(){}function xS(){}function mee(){}function Bj(){}function Fj(){}function Rj(){}function jj(){}function Gv(){}function $j(){}function zj(){}function qj(){}function Hj(){}function vee(){}function i8(){}function dI(){}function g5(){}function wee(){}function yee(){}function kS(){}function Vj(){}function xee(){}function kee(){}function Eee(){}function Tee(){}function Cee(){}function See(){}function _ee(){}function Aee(){}function Lee(){}function Mee(){}function ES(){}function Uj(){}function Dee(){}function Iee(){}function Oee(){}function Nee(){}function Pee(){}function Gj(){}function Kj(){}function Bee(){}function Wj(){}function Yj(){}function Fee(){}function Ree(){}function jee(){}function $ee(){}function zee(){}function qee(){}function Hee(){}function Vee(){}function gI(){}function Uee(){}function X9(){}function Xj(){}function Gee(){}function Kee(){}function Wee(){}function Yee(){}function Xee(){}function Qee(){}function Jee(){}function Zee(){}function ete(){}function tte(){}function nte(){}function rte(){}function ite(){}function ste(){}function ate(){}function s8(){}function Qj(){}function ote(){}function cte(){}function ute(){}function Jj(){}function lte(){}function TS(){}function hte(){}function fte(){}function dte(){}function gte(){}function pte(){}function bte(){}function mte(){}function vte(){}function wte(){}function yte(){}function a8(){}function xte(){}function kte(){}function Ete(){}function Tte(){}function Cte(){}function Ste(){}function _te(){}function Ate(){}function CS(){}function Lte(){}function Mte(){}function Dte(){}function Ite(){}function Ote(){}function Nte(){}function Pte(){}function Bte(){}function o8(){}function Zj(){}function Fte(){}function pI(){}function Rte(){}function jte(){}function $te(){}function zte(){}function qte(){}function Hte(){}function Vte(){}function e$(){}function Ute(){}function t$(){}function Gte(){}function n$(){}function r$(){}function i$(){}function Kte(){}function Wte(){}function s$(){}function Yte(){}function a$(){}function Xte(){}function Qte(){}function bI(){}function Jte(){}function Zte(){}function ene(){}function tne(){}function nne(){}function o$(){}function rne(){}function ine(){}function sne(){}function pwe(){}function ane(){}function one(){}function cne(){}function une(){}function lne(){}function hne(){}function fne(){}function dne(){}function gne(){}function pne(){}function bne(){}function mne(){}function vne(){}function wne(){}function yne(){}function xne(){}function fu(){}function kne(){}function SS(){}function Rc(){}function Pu(){}function hs(){}function mI(){}function Ene(){}function Tne(){}function Cne(){}function c8(){}function ym(){}function Q9(){}function Sne(){}function vI(){}function _ne(){}function Ane(){}function Lne(){}function c$(){}function Mne(){}function Dne(){}function wI(){}function Ine(){}function uh(){}function gl(){}function u$(){}function One(){}function Nne(){}function ey(){}function p5(){}function ty(){}function Rp(){}function u8(){}function yI(){}function l$(){}function h$(){}function Pne(){}function x1(){}function f$(){}function ny(){}function J9(){}function xI(){}function l8(){}function W2(){}function d$(){}function g$(){}function p$(){}function Bne(){}function h8(){}function ry(){}function jp(){}function Y2(){}function b5(){}function Z9(){}function _S(){}function kI(){}function Fne(){}function Rne(){}function b$(){}function m$(){}function Ut(){}function ek(){}function v$(){}function w$(){}function jne(){}function tk(){}function nk(){}function y$(){}function $ne(){}function zne(){}function qne(){}function Hne(){}function Vne(){}function Une(){}function EI(){}function Gne(){}function Kne(){}function x$(){}function AS(){}function Wne(){}function TI(){}function rk(){}function ik(){}function sk(){}function k$(){}function Yne(){}function E$(){}function T$(){}function Xne(){}function LS(){}function X2(){}function C$(){}function S$(){}function MS(){}function Qne(){}function m5(){}function _$(){}function CI(){}function Qc(){}function SI(){}function _I(){}function DS(){}function Jne(){}function Zne(){}function IS(){}function ere(){}function OS(){}function NS(){}function H0(){}function AI(){}function LI(){}function f8(){}function tre(){}function nre(){}function rre(){}function ire(){}function Xd(){}function PS(){}function d8(){}function k1(){}function A$(){}function L$(){}function M$(){}function D$(){}function I$(){}function O$(){}function V0(){}function nl(){}function sre(){}function are(){}function ore(){}function rl(){}function BS(){}function N$(){}function P$(){}function g8(){}function cre(){}function ak(){}function ure(){}function B$(){}function lre(){}function hre(){}function FS(){}function F$(){}function MI(){}function RS(){}function fre(){}function dre(){}function DI(){}function jS(){}function E1(){}function ok(){}function gre(){}function ck(){}function II(){}function xm(){}function $S(){}function OI(){}function U0(){}function zS(){}function T1(){}function C1(){}function pre(){}function bre(){}function v5(){}function uk(){}function lk(){}function qS(){}function mre(){}function vre(){}function p8(){}function R$(){}function j$(){}function wre(){}function $$(){}function yre(){}function z$(){}function NI(){}function xre(){}function HS(){}function kre(){}function Ere(){}function Tre(){}function Cre(){}function Sre(){}function q$(){}function _re(){}function Are(){}function Lre(){}function H$(){}function Mre(){}function Dre(){}function VS(){}function Ire(){}function Ore(){}function Nre(){}function Pre(){}function Bre(){}function Fre(){}function V$(){}function Rre(){}function U$(){}function jre(){}function PI(){}function $re(){}function G$(){}function zre(){}function K$(){}function qre(){}function W$(){}function Y$(){}function X$(){}function BI(){}function w5(){}function US(){}function S1(){}function Q$(){}function hk(){}function FI(){}function J$(){}function km(){}function Z$(){}function GS(){o_()}function Hre(){iO()}function ez(){dU()}function tz(){Lce()}function nz(){IA()}function KS(){Xxe()}function WS(){b0()}function rz(){axe()}function iz(){VN()}function b8(){sO()}function Kv(){OO()}function fk(){het()}function sz(){lx()}function Vre(){$ut()}function az(){s7e()}function m8(){Aot()}function RI(){a7e()}function oz(){mlt()}function Ure(){_ot()}function cz(){TE()}function YS(){eft()}function XS(){Zht()}function jI(){Ect()}function Gre(){tft()}function Kre(){Cb()}function Wre(){eq()}function Yre(){Yke()}function Xre(){Nt()}function Qre(){nft()}function Jre(){Lft()}function Zre(){Lot()}function eie(){egt()}function tie(){Mot()}function nie(){gmt()}function rie(){_9e()}function iie(){tp()}function sie(){p1t()}function v8(){Hc()}function aie(){jot()}function dk(){ux()}function Cf(){uke()}function oie(){Sb()}function gk(){lke()}function QS(){z1()}function cie(){YN()}function uie(){tle()}function lie(){lue()}function Sf(){pit()}function hie(){ZH()}function fie(){wU()}function uz(){pi()}function die(){PV()}function lz(){B8e()}function hz(){lce()}function fz(){zU()}function dz(){xke()}function n0(e){nr(e)}function gz(e){this.a=e}function JS(e){this.a=e}function pz(e){this.a=e}function bz(e){this.a=e}function gie(e){this.a=e}function pie(e){this.a=e}function mz(e){this.a=e}function bie(e){this.a=e}function vz(e){this.a=e}function Q2(e){this.a=e}function mie(e){this.a=e}function vie(e){this.a=e}function $I(e){this.a=e}function wie(e){this.a=e}function yie(e){this.a=e}function pk(e){this.a=e}function J2(e){this.a=e}function wz(e){this.a=e}function bk(e){this.a=e}function y5(e){this.a=e}function zI(e){this.a=e}function w8(e){this.a=e}function qI(e){this.b=e}function qg(e){this.c=e}function xie(e){this.a=e}function iy(e){this.a=e}function yz(e){this.a=e}function xz(e){this.a=e}function HI(e){this.a=e}function VI(e){this.a=e}function kz(e){this.a=e}function y8(e){this.a=e}function mk(e){this.a=e}function kie(e){this.a=e}function Ez(e){this.a=e}function Tz(e){this.a=e}function Cz(e){this.a=e}function Sz(e){this.a=e}function jc(e){this.a=e}function vk(e){this.a=e}function wk(e){this.a=e}function $p(){this.a=[]}function Eie(e,t){e.a=t}function Tie(e,t){e.a=t}function Cie(e,t){e.b=t}function Sie(e,t){e.b=t}function _ie(e,t){e.b=t}function _z(e,t){e.j=t}function bwe(e,t){e.g=t}function Az(e,t){e.i=t}function Aie(e,t){e.c=t}function x8(e,t){e.c=t}function mwe(e,t){e.d=t}function k8(e,t){e.d=t}function x(e,t){e.k=t}function m(e,t){e.c=t}function k(e,t){e.c=t}function S(e,t){e.a=t}function M(e,t){e.a=t}function O(e,t){e.f=t}function N(e,t){e.a=t}function $(e,t){e.b=t}function H(e,t){e.d=t}function q(e,t){e.i=t}function Y(e,t){e.o=t}function Z(e,t){e.r=t}function ce(e,t){e.a=t}function ve(e,t){e.b=t}function me(e,t){e.e=t}function Le(e,t){e.f=t}function _e(e,t){e.g=t}function Ee(e,t){e.e=t}function Be(e,t){e.f=t}function Re(e,t){e.f=t}function Ve(e,t){e.a=t}function ct(e,t){e.b=t}function st(e,t){e.n=t}function Ye(e,t){e.a=t}function mt(e,t){e.c=t}function Je(e,t){e.c=t}function Lt(e,t){e.c=t}function Mt(e,t){e.a=t}function ut(e,t){e.a=t}function Wt(e,t){e.d=t}function Tt(e,t){e.d=t}function _n(e,t){e.e=t}function hn(e,t){e.e=t}function Yt(e,t){e.g=t}function Dn(e,t){e.f=t}function ir(e,t){e.j=t}function vr(e,t){e.a=t}function Nn(e,t){e.a=t}function pr(e,t){e.b=t}function Er(e){e.b=e.a}function Mr(e){e.c=e.d.d}function Cr(e){this.a=e}function Or(e){this.a=e}function Wn(e){this.a=e}function br(e){this.a=e}function Sr(e){this.a=e}function Nr(e){this.a=e}function Si(e){this.a=e}function ys(e){this.a=e}function pa(e){this.a=e}function Mi(e){this.a=e}function gi(e){this.a=e}function fs(e){this.a=e}function Fs(e){this.a=e}function xs(e){this.a=e}function Rs(e){this.b=e}function yo(e){this.b=e}function $a(e){this.b=e}function Da(e){this.a=e}function Bo(e){this.a=e}function tr(e){this.c=e}function G(e){this.c=e}function Jn(e){this.c=e}function kr(e){this.d=e}function lr(e){this.a=e}function Vt(e){this.a=e}function Hs(e){this.a=e}function wr(e){this.a=e}function Es(e){this.a=e}function go(e){this.a=e}function $c(e){this.a=e}function za(e){this.a=e}function Sc(e){this.a=e}function ba(e){this.a=e}function xo(e){this.a=e}function lh(e){this.a=e}function Wl(e){this.a=e}function Z2(e){this.a=e}function eb(e){this.a=e}function G0(e){this.a=e}function zp(e){this.a=e}function fd(e){this.a=e}function Wv(e){this.a=e}function sy(e){this.a=e}function E8(e){this.a=e}function x5(e){this.a=e}function T8(e){this.a=e}function ZS(e){this.a=e}function k5(e){this.a=e}function Qd(e){this.a=e}function _1(e){this.a=e}function Jd(e){this.a=e}function Yv(e){this.a=e}function Em(e){this.a=e}function Lz(e){this.a=e}function Lie(e){this.a=e}function Mie(e){this.a=e}function e_(e){this.a=e}function Die(e){this.a=e}function Iie(e){this.a=e}function E5(e){this.a=e}function Mz(e){this.a=e}function yk(e){this.a=e}function UI(e){this.a=e}function t_(e){this.a=e}function Dz(e){this.a=e}function Iz(e){this.a=e}function Oie(e){this.a=e}function qp(e){this.a=e}function n_(e){this.a=e}function GI(e){this.a=e}function Tm(e){this.a=e}function Zd(e){this.e=e}function T5(e){this.a=e}function jWe(e){this.a=e}function C8(e){this.a=e}function vwe(e){this.a=e}function $We(e){this.a=e}function zWe(e){this.a=e}function qWe(e){this.a=e}function HWe(e){this.a=e}function VWe(e){this.a=e}function UWe(e){this.a=e}function GWe(e){this.a=e}function KWe(e){this.a=e}function WWe(e){this.a=e}function YWe(e){this.a=e}function XWe(e){this.a=e}function wwe(e){this.a=e}function QWe(e){this.a=e}function JWe(e){this.a=e}function ZWe(e){this.a=e}function eYe(e){this.a=e}function tYe(e){this.a=e}function nYe(e){this.a=e}function rYe(e){this.a=e}function iYe(e){this.a=e}function sYe(e){this.a=e}function aYe(e){this.a=e}function oYe(e){this.a=e}function cYe(e){this.a=e}function uYe(e){this.a=e}function lYe(e){this.a=e}function hYe(e){this.a=e}function fYe(e){this.a=e}function dYe(e){this.a=e}function gYe(e){this.a=e}function pYe(e){this.a=e}function bYe(e){this.a=e}function mYe(e){this.a=e}function vYe(e){this.a=e}function wYe(e){this.a=e}function yYe(e){this.a=e}function xYe(e){this.a=e}function kYe(e){this.a=e}function EYe(e){this.a=e}function TYe(e){this.a=e}function CYe(e){this.a=e}function SYe(e){this.a=e}function _Ye(e){this.a=e}function AYe(e){this.a=e}function LYe(e){this.a=e}function MYe(e){this.a=e}function DYe(e){this.a=e}function IYe(e){this.a=e}function OYe(e){this.a=e}function NYe(e){this.a=e}function PYe(e){this.c=e}function BYe(e){this.b=e}function FYe(e){this.a=e}function RYe(e){this.a=e}function jYe(e){this.a=e}function $Ye(e){this.a=e}function zYe(e){this.a=e}function qYe(e){this.a=e}function HYe(e){this.a=e}function VYe(e){this.a=e}function UYe(e){this.a=e}function GYe(e){this.a=e}function KYe(e){this.a=e}function WYe(e){this.a=e}function YYe(e){this.a=e}function XYe(e){this.a=e}function QYe(e){this.a=e}function JYe(e){this.a=e}function ZYe(e){this.a=e}function eXe(e){this.a=e}function tXe(e){this.a=e}function nXe(e){this.a=e}function rXe(e){this.a=e}function iXe(e){this.a=e}function sXe(e){this.a=e}function aXe(e){this.a=e}function oXe(e){this.a=e}function cXe(e){this.a=e}function uXe(e){this.a=e}function Hg(e){this.a=e}function C5(e){this.a=e}function lXe(e){this.a=e}function hXe(e){this.a=e}function fXe(e){this.a=e}function dXe(e){this.a=e}function gXe(e){this.a=e}function pXe(e){this.a=e}function bXe(e){this.a=e}function mXe(e){this.a=e}function vXe(e){this.a=e}function wXe(e){this.a=e}function yXe(e){this.a=e}function xXe(e){this.a=e}function kXe(e){this.a=e}function EXe(e){this.a=e}function TXe(e){this.a=e}function CXe(e){this.a=e}function SXe(e){this.a=e}function _Xe(e){this.a=e}function AXe(e){this.a=e}function LXe(e){this.a=e}function MXe(e){this.a=e}function DXe(e){this.a=e}function IXe(e){this.a=e}function OXe(e){this.a=e}function NXe(e){this.a=e}function PXe(e){this.a=e}function Oz(e){this.a=e}function BXe(e){this.f=e}function FXe(e){this.a=e}function RXe(e){this.a=e}function jXe(e){this.a=e}function $Xe(e){this.a=e}function zXe(e){this.a=e}function qXe(e){this.a=e}function HXe(e){this.a=e}function VXe(e){this.a=e}function UXe(e){this.a=e}function GXe(e){this.a=e}function KXe(e){this.a=e}function WXe(e){this.a=e}function YXe(e){this.a=e}function XXe(e){this.a=e}function QXe(e){this.a=e}function JXe(e){this.a=e}function ZXe(e){this.a=e}function eQe(e){this.a=e}function tQe(e){this.a=e}function nQe(e){this.a=e}function rQe(e){this.a=e}function iQe(e){this.a=e}function sQe(e){this.a=e}function aQe(e){this.a=e}function oQe(e){this.a=e}function cQe(e){this.a=e}function uQe(e){this.a=e}function lQe(e){this.a=e}function Nie(e){this.a=e}function ywe(e){this.a=e}function Ui(e){this.b=e}function hQe(e){this.a=e}function fQe(e){this.a=e}function dQe(e){this.a=e}function gQe(e){this.a=e}function pQe(e){this.a=e}function bQe(e){this.a=e}function mQe(e){this.a=e}function vQe(e){this.b=e}function wQe(e){this.a=e}function KI(e){this.a=e}function yQe(e){this.a=e}function xQe(e){this.a=e}function xwe(e){this.c=e}function Nz(e){this.e=e}function Pz(e){this.a=e}function Bz(e){this.a=e}function Pie(e){this.a=e}function kQe(e){this.d=e}function EQe(e){this.a=e}function kwe(e){this.a=e}function Ewe(e){this.a=e}function Xv(e){this.e=e}function Dcn(){this.a=0}function Pr(){Nl(this)}function bt(){Yse(this)}function Bie(){cat(this)}function TQe(){}function Qv(){this.c=LPe}function CQe(e,t){e.b+=t}function Icn(e,t){t.Wb(e)}function Ocn(e){return e.a}function Ncn(e){return e.a}function Pcn(e){return e.a}function Bcn(e){return e.a}function Fcn(e){return e.a}function ue(e){return e.e}function Rcn(){return null}function jcn(){return null}function $cn(){c3e(),wIn()}function zcn(e){e.b.Of(e.e)}function SQe(e){e.b=new nse}function r_(e,t){e.b=t-e.b}function i_(e,t){e.a=t-e.a}function $n(e,t){e.push(t)}function _Qe(e,t){e.sort(t)}function AQe(e,t){t.jd(e.a)}function qcn(e,t){la(t,e)}function Hcn(e,t,n){e.Yd(n,t)}function WI(e,t){e.e=t,t.b=e}function Twe(e){wd(),this.a=e}function LQe(e){wd(),this.a=e}function MQe(e){wd(),this.a=e}function Fie(e){ww(),this.a=e}function DQe(e){Xk(),S0e.le(e)}function Cwe(){Cwe=U,new Pr}function Cm(){Jnt.call(this)}function Swe(){Jnt.call(this)}function _we(){Cm.call(this)}function Rie(){Cm.call(this)}function IQe(){Cm.call(this)}function YI(){Cm.call(this)}function pl(){Cm.call(this)}function S8(){Cm.call(this)}function Qr(){Cm.call(this)}function Xh(){Cm.call(this)}function OQe(){Cm.call(this)}function _c(){Cm.call(this)}function NQe(){Cm.call(this)}function PQe(){this.a=this}function Fz(){this.Bb|=256}function BQe(){this.b=new Utt}function ay(e,t){e.length=t}function Rz(e,t){vt(e.a,t)}function Vcn(e,t){Jxe(e.c,t)}function Ucn(e,t){na(e.b,t)}function Gcn(e,t){oU(e.a,t)}function Kcn(e,t){Fce(e.a,t)}function xk(e,t){Ni(e.e,t)}function _8(e){EU(e.c,e.b)}function Wcn(e,t){e.kc().Nb(t)}function Awe(e){this.a=$4n(e)}function Ks(){this.a=new Pr}function FQe(){this.a=new Pr}function Lwe(){this.a=new net}function jz(){this.a=new bt}function jie(){this.a=new bt}function Mwe(){this.a=new bt}function _f(){this.a=new pm}function Sm(){this.a=new Nut}function Dwe(){this.a=new bm}function Iwe(){this.a=new Sot}function Owe(){this.a=new Rrt}function RQe(){this.a=new bt}function jQe(){this.a=new bt}function $Qe(){this.a=new bt}function Nwe(){this.a=new bt}function zQe(){this.d=new bt}function qQe(){this.a=new Got}function HQe(){this.a=new Ks}function VQe(){this.a=new Pr}function UQe(){this.b=new Pr}function GQe(){this.b=new bt}function Pwe(){this.e=new bt}function KQe(){this.a=new Kre}function WQe(){this.d=new bt}function YQe(){Qat.call(this)}function XQe(){Qat.call(this)}function QQe(){bt.call(this)}function Bwe(){_we.call(this)}function Fwe(){jz.call(this)}function JQe(){Vq.call(this)}function ZQe(){Nwe.call(this)}function s_(){TQe.call(this)}function $ie(){s_.call(this)}function A8(){TQe.call(this)}function Rwe(){A8.call(this)}function eJe(){qwe.call(this)}function tJe(){qwe.call(this)}function nJe(){qwe.call(this)}function rJe(){Hwe.call(this)}function a_(){Wne.call(this)}function jwe(){Wne.call(this)}function bl(){os.call(this)}function iJe(){wJe.call(this)}function sJe(){wJe.call(this)}function aJe(){Pr.call(this)}function oJe(){Pr.call(this)}function cJe(){Pr.call(this)}function zie(){sft.call(this)}function uJe(){Ks.call(this)}function lJe(){Fz.call(this)}function qie(){kye.call(this)}function $we(){Pr.call(this)}function Hie(){kye.call(this)}function Vie(){Pr.call(this)}function hJe(){Pr.call(this)}function zwe(){m5.call(this)}function fJe(){zwe.call(this)}function dJe(){m5.call(this)}function gJe(){J$.call(this)}function qwe(){this.a=new Ks}function pJe(){this.a=new Pr}function bJe(){this.a=new bt}function Hwe(){this.a=new Pr}function L8(){this.a=new os}function mJe(){this.j=new bt}function vJe(){this.a=new bZe}function wJe(){this.a=new Qne}function Vwe(){this.a=new hs}function o_(){o_=U,v0e=new _}function Uie(){Uie=U,w0e=new xJe}function Gie(){Gie=U,y0e=new yJe}function yJe(){pk.call(this,"")}function xJe(){pk.call(this,"")}function kJe(e){Aht.call(this,e)}function EJe(e){Aht.call(this,e)}function Uwe(e){vz.call(this,e)}function Gwe(e){UZe.call(this,e)}function Ycn(e){UZe.call(this,e)}function Xcn(e){Gwe.call(this,e)}function Qcn(e){Gwe.call(this,e)}function Jcn(e){Gwe.call(this,e)}function TJe(e){Toe.call(this,e)}function CJe(e){Toe.call(this,e)}function SJe(e){ait.call(this,e)}function _Je(e){p3e.call(this,e)}function c_(e){Xz.call(this,e)}function Kwe(e){Xz.call(this,e)}function AJe(e){Xz.call(this,e)}function Wwe(e){y9n.call(this,e)}function Ywe(e){Wwe.call(this,e)}function Ac(e){_st.call(this,e)}function LJe(e){Ac.call(this,e)}function M8(){wk.call(this,{})}function MJe(){MJe=U,d6t=new W}function $z(){$z=U,E0e=new Ant}function DJe(){DJe=U,USe=new T}function Xwe(){Xwe=U,GSe=new ae}function zz(){zz=U,NL=new de}function Kie(e){Ok(),this.a=e}function Wie(e){E7e(),this.a=e}function Jv(e){Iae(),this.f=e}function Yie(e){Iae(),this.f=e}function IJe(e){git(),this.a=e}function OJe(e){e.b=null,e.c=0}function Zcn(e,t){e.e=t,gbt(e,t)}function eun(e,t){e.a=t,okn(e)}function Xie(e,t,n){e.a[t.g]=n}function tun(e,t,n){k8n(n,e,t)}function nun(e,t){Qfn(t.i,e.n)}function NJe(e,t){xyn(e).Cd(t)}function run(e,t){e.a.ec().Mc(t)}function PJe(e,t){return e.g-t.g}function iun(e,t){return e*e/t}function Rt(e){return nr(e),e}function ze(e){return nr(e),e}function XI(e){return nr(e),e}function sun(e){return new vk(e)}function aun(e){return new yy(e)}function Qwe(e){return nr(e),e}function oun(e){return nr(e),e}function qz(e){Ac.call(this,e)}function tc(e){Ac.call(this,e)}function BJe(e){Ac.call(this,e)}function Qie(e){_st.call(this,e)}function kk(e){Ac.call(this,e)}function Yn(e){Ac.call(this,e)}function nc(e){Ac.call(this,e)}function FJe(e){Ac.call(this,e)}function D8(e){Ac.call(this,e)}function Hp(e){Ac.call(this,e)}function Vp(e){Ac.call(this,e)}function I8(e){Ac.call(this,e)}function dd(e){Ac.call(this,e)}function Jie(e){Ac.call(this,e)}function ri(e){Ac.call(this,e)}function Il(e){nr(e),this.a=e}function Jwe(e){return Um(e),e}function u_(e){l5e(e,e.length)}function l_(e){return e.b==e.c}function oy(e){return!!e&&e.b}function cun(e){return!!e&&e.k}function uun(e){return!!e&&e.j}function lun(e,t,n){e.c.Ef(t,n)}function RJe(e,t){e.be(t),t.ae(e)}function O8(e){wd(),this.a=Xr(e)}function Zie(){this.a=ei(Xr(Co))}function jJe(){throw ue(new Qr)}function hun(){throw ue(new Qr)}function Zwe(){throw ue(new Qr)}function $Je(){throw ue(new Qr)}function fun(){throw ue(new Qr)}function dun(){throw ue(new Qr)}function Hz(){Hz=U,Xk()}function Up(){Nr.call(this,"")}function h_(){Nr.call(this,"")}function tb(){Nr.call(this,"")}function S5(){Nr.call(this,"")}function e3e(e){tc.call(this,e)}function t3e(e){tc.call(this,e)}function gd(e){Yn.call(this,e)}function Ek(e){$a.call(this,e)}function zJe(e){Ek.call(this,e)}function ese(e){jq.call(this,e)}function tse(e){Nye.call(this,e,0)}function nse(){G5e.call(this,12,3)}function le(e,t){return yot(e,t)}function Vz(e,t){return joe(e,t)}function gun(e,t){return e.a-t.a}function pun(e,t){return e.a-t.a}function bun(e,t){return e.a-t.a}function mun(e,t){return t in e.a}function qJe(e){return e.a?e.b:0}function vun(e){return e.a?e.b:0}function wun(e,t,n){t.Cd(e.a[n])}function yun(e,t,n){t.Pe(e.a[n])}function xun(e,t){e.b=new Eo(t)}function kun(e,t){return e.b=t,e}function HJe(e,t){return e.c=t,e}function VJe(e,t){return e.f=t,e}function Eun(e,t){return e.g=t,e}function n3e(e,t){return e.a=t,e}function r3e(e,t){return e.f=t,e}function Tun(e,t){return e.k=t,e}function i3e(e,t){return e.a=t,e}function Cun(e,t){return e.e=t,e}function s3e(e,t){return e.e=t,e}function Sun(e,t){return e.f=t,e}function _un(e,t){e.b=!0,e.d=t}function Aun(e,t){return e.b-t.b}function Lun(e,t){return e.g-t.g}function Mun(e,t){return e?0:t-1}function UJe(e,t){return e?0:t-1}function Dun(e,t){return e?t-1:0}function Iun(e,t){return e.s-t.s}function Oun(e,t){return t.rg(e)}function Zv(e,t){return e.b=t,e}function Uz(e,t){return e.a=t,e}function ew(e,t){return e.c=t,e}function tw(e,t){return e.d=t,e}function nw(e,t){return e.e=t,e}function a3e(e,t){return e.f=t,e}function f_(e,t){return e.a=t,e}function Tk(e,t){return e.b=t,e}function Ck(e,t){return e.c=t,e}function Qt(e,t){return e.c=t,e}function yn(e,t){return e.b=t,e}function Jt(e,t){return e.d=t,e}function Zt(e,t){return e.e=t,e}function Nun(e,t){return e.f=t,e}function en(e,t){return e.g=t,e}function tn(e,t){return e.a=t,e}function nn(e,t){return e.i=t,e}function rn(e,t){return e.j=t,e}function Pun(e,t){Cb(),Mc(t,e)}function Bun(e,t,n){Jdn(e.a,t,n)}function Gz(e){dae.call(this,e)}function GJe(e){t5n.call(this,e)}function KJe(e){Aat.call(this,e)}function o3e(e){Aat.call(this,e)}function nb(e){Lw.call(this,e)}function WJe(e){noe.call(this,e)}function YJe(e){noe.call(this,e)}function XJe(){bye.call(this,"")}function qa(){this.a=0,this.b=0}function QJe(){this.b=0,this.a=0}function JJe(e,t){e.b=0,My(e,t)}function ZJe(e,t){return e.k=t,e}function Fun(e,t){return e.j=t,e}function Run(e,t){e.c=t,e.b=!0}function eZe(){eZe=U,S6t=Y8n()}function rb(){rb=U,w_t=a8n()}function tZe(){tZe=U,La=vxn()}function c3e(){c3e=U,Qb=hE()}function Sk(){Sk=U,APe=o8n()}function nZe(){nZe=U,rAt=c8n()}function u3e(){u3e=U,tu=ikn()}function K0(e){return e.e&&e.e()}function rZe(e){return e.l|e.m<<22}function iZe(e,t){return e.c._b(t)}function sZe(e,t){return i1t(e.b,t)}function rse(e){return e?e.d:null}function jun(e){return e?e.g:null}function $un(e){return e?e.i:null}function _m(e){return Gg(e),e.o}function _5(e,t){return e.a+=t,e}function ise(e,t){return e.a+=t,e}function Gp(e,t){return e.a+=t,e}function rw(e,t){return e.a+=t,e}function l3e(e,t){for(;e.Bd(t););}function Kz(e){this.a=new N8(e)}function aZe(){throw ue(new Qr)}function oZe(){throw ue(new Qr)}function cZe(){throw ue(new Qr)}function uZe(){throw ue(new Qr)}function lZe(){throw ue(new Qr)}function hZe(){throw ue(new Qr)}function Kp(e){this.a=new Pae(e)}function fZe(){this.a=new UA(EIe)}function dZe(){this.b=new UA(qDe)}function gZe(){this.a=new UA(KIe)}function pZe(){this.b=new UA(pge)}function bZe(){this.b=new UA(pge)}function Wz(e){this.a=0,this.b=e}function h3e(e){Gvt(),IIn(this,e)}function _k(e){return fb(e),e.a}function QI(e){return e.b!=e.d.c}function f3e(e,t){return e.d[t.p]}function mZe(e,t){return YCn(e,t)}function d3e(e,t,n){e.splice(t,n)}function A5(e,t){for(;e.Re(t););}function vZe(e){e.c?Ibt(e):Obt(e)}function wZe(){throw ue(new Qr)}function yZe(){throw ue(new Qr)}function xZe(){throw ue(new Qr)}function kZe(){throw ue(new Qr)}function EZe(){throw ue(new Qr)}function TZe(){throw ue(new Qr)}function CZe(){throw ue(new Qr)}function SZe(){throw ue(new Qr)}function _Ze(){throw ue(new Qr)}function AZe(){throw ue(new Qr)}function zun(){throw ue(new _c)}function qun(){throw ue(new _c)}function JI(e){this.a=new LZe(e)}function LZe(e){Gwn(this,e,T9n())}function ZI(e){return!e||oat(e)}function eO(e){return nd[e]!=-1}function Hun(){aK!=0&&(aK=0),oK=-1}function MZe(){m0e==null&&(m0e=[])}function tO(e,t){q5.call(this,e,t)}function Ak(e,t){tO.call(this,e,t)}function DZe(e,t){this.a=e,this.b=t}function IZe(e,t){this.a=e,this.b=t}function OZe(e,t){this.a=e,this.b=t}function NZe(e,t){this.a=e,this.b=t}function PZe(e,t){this.a=e,this.b=t}function BZe(e,t){this.a=e,this.b=t}function FZe(e,t){this.a=e,this.b=t}function Lk(e,t){this.e=e,this.d=t}function g3e(e,t){this.b=e,this.c=t}function RZe(e,t){this.b=e,this.a=t}function jZe(e,t){this.b=e,this.a=t}function $Ze(e,t){this.b=e,this.a=t}function zZe(e,t){this.b=e,this.a=t}function qZe(e,t){this.a=e,this.b=t}function sse(e,t){this.a=e,this.b=t}function HZe(e,t){this.a=e,this.f=t}function iw(e,t){this.g=e,this.i=t}function Ur(e,t){this.f=e,this.g=t}function VZe(e,t){this.b=e,this.c=t}function UZe(e){Tye(e.dc()),this.c=e}function Vun(e,t){this.a=e,this.b=t}function GZe(e,t){this.a=e,this.b=t}function KZe(e){this.a=l(Xr(e),15)}function p3e(e){this.a=l(Xr(e),15)}function WZe(e){this.a=l(Xr(e),85)}function Yz(e){this.b=l(Xr(e),85)}function Xz(e){this.b=l(Xr(e),51)}function Qz(){this.q=new b.Date}function ase(e,t){this.a=e,this.b=t}function YZe(e,t){return Hu(e.b,t)}function nO(e,t){return e.b.Hc(t)}function XZe(e,t){return e.b.Ic(t)}function QZe(e,t){return e.b.Qc(t)}function JZe(e,t){return e.b.Hc(t)}function ZZe(e,t){return e.c.uc(t)}function eet(e,t){return Pi(e.c,t)}function W0(e,t){return e.a._b(t)}function tet(e,t){return e>t&&t0}function fse(e,t){return iu(e,t)<0}function vet(e,t){return Aae(e.a,t)}function uln(e,t){xot.call(this,e,t)}function k3e(e){Kae(),ait.call(this,e)}function E3e(e,t){gst(e,e.length,t)}function aO(e,t){qst(e,e.length,t)}function y_(e,t){return e.a.get(t)}function wet(e,t){return Hu(e.e,t)}function T3e(e){return nr(e),!1}function C3e(e){this.a=l(Xr(e),229)}function aq(e){kn.call(this,e,21)}function oq(e,t){Ur.call(this,e,t)}function dse(e,t){Ur.call(this,e,t)}function yet(e,t){this.b=e,this.a=t}function cq(e,t){this.d=e,this.e=t}function xet(e,t){this.a=e,this.b=t}function ket(e,t){this.a=e,this.b=t}function Eet(e,t){this.a=e,this.b=t}function Tet(e,t){this.a=e,this.b=t}function B8(e,t){this.a=e,this.b=t}function Cet(e,t){this.b=e,this.a=t}function S3e(e,t){this.b=e,this.a=t}function _3e(e,t){Ur.call(this,e,t)}function A3e(e,t){Ur.call(this,e,t)}function L5(e,t){Ur.call(this,e,t)}function gse(e,t){Ur.call(this,e,t)}function pse(e,t){Ur.call(this,e,t)}function bse(e,t){Ur.call(this,e,t)}function uq(e,t){Ur.call(this,e,t)}function L3e(e,t){this.b=e,this.a=t}function lq(e,t){Ur.call(this,e,t)}function M3e(e,t){this.b=e,this.a=t}function hq(e,t){Ur.call(this,e,t)}function _et(e,t){this.b=e,this.a=t}function D3e(e,t){Ur.call(this,e,t)}function mse(e,t){Ur.call(this,e,t)}function oO(e,t){Ur.call(this,e,t)}function x_(e,t,n){e.splice(t,0,n)}function lln(e,t,n){e.Mb(n)&&t.Cd(n)}function hln(e,t,n){t.Pe(e.a.Ye(n))}function fln(e,t,n){t.Dd(e.a.Ze(n))}function dln(e,t,n){t.Cd(e.a.Kb(n))}function gln(e,t){return vl(e.c,t)}function pln(e,t){return vl(e.e,t)}function fq(e,t){Ur.call(this,e,t)}function dq(e,t){Ur.call(this,e,t)}function k_(e,t){Ur.call(this,e,t)}function I3e(e,t){Ur.call(this,e,t)}function Ws(e,t){Ur.call(this,e,t)}function gq(e,t){Ur.call(this,e,t)}function Aet(e,t){this.a=e,this.b=t}function Let(e,t){this.a=e,this.b=t}function Met(e,t){this.a=e,this.b=t}function Det(e,t){this.a=e,this.b=t}function Iet(e,t){this.a=e,this.b=t}function Oet(e,t){this.a=e,this.b=t}function Net(e,t){this.b=e,this.a=t}function Pet(e,t){this.b=e,this.a=t}function O3e(e,t){this.b=e,this.a=t}function Ik(e,t){this.c=e,this.d=t}function Bet(e,t){this.e=e,this.d=t}function Fet(e,t){this.a=e,this.b=t}function Ret(e,t){this.a=e,this.b=t}function jet(e,t){this.a=e,this.b=t}function $et(e,t){this.b=e,this.a=t}function zet(e,t){this.b=t,this.c=e}function pq(e,t){Ur.call(this,e,t)}function cO(e,t){Ur.call(this,e,t)}function vse(e,t){Ur.call(this,e,t)}function N3e(e,t){Ur.call(this,e,t)}function E_(e,t){Ur.call(this,e,t)}function wse(e,t){Ur.call(this,e,t)}function yse(e,t){Ur.call(this,e,t)}function uO(e,t){Ur.call(this,e,t)}function P3e(e,t){Ur.call(this,e,t)}function xse(e,t){Ur.call(this,e,t)}function T_(e,t){Ur.call(this,e,t)}function B3e(e,t){Ur.call(this,e,t)}function C_(e,t){Ur.call(this,e,t)}function S_(e,t){Ur.call(this,e,t)}function uy(e,t){Ur.call(this,e,t)}function kse(e,t){Ur.call(this,e,t)}function Ese(e,t){Ur.call(this,e,t)}function F3e(e,t){Ur.call(this,e,t)}function lO(e,t){Ur.call(this,e,t)}function M5(e,t){Ur.call(this,e,t)}function Tse(e,t){Ur.call(this,e,t)}function bq(e,t){Ur.call(this,e,t)}function hO(e,t){Ur.call(this,e,t)}function ly(e,t){Ur.call(this,e,t)}function mq(e,t){Ur.call(this,e,t)}function R3e(e,t){Ur.call(this,e,t)}function Cse(e,t){Ur.call(this,e,t)}function Sse(e,t){Ur.call(this,e,t)}function _se(e,t){Ur.call(this,e,t)}function Ase(e,t){Ur.call(this,e,t)}function Lse(e,t){Ur.call(this,e,t)}function Mse(e,t){Ur.call(this,e,t)}function Dse(e,t){Ur.call(this,e,t)}function qet(e,t){this.b=e,this.a=t}function j3e(e,t){Ur.call(this,e,t)}function Het(e,t){this.a=e,this.b=t}function Vet(e,t){this.a=e,this.b=t}function Uet(e,t){this.a=e,this.b=t}function $3e(e,t){Ur.call(this,e,t)}function z3e(e,t){Ur.call(this,e,t)}function Get(e,t){this.a=e,this.b=t}function bln(e,t){return jk(),t!=e}function fO(e){return mr(e.a),e.b}function Ise(e){return EEn(e,e.c),e}function Ket(){return eZe(),new S6t}function Wet(){Yq(),this.a=new i4e}function Yet(){IU(),this.a=new Ks}function Xet(){foe(),this.b=new Ks}function Qet(e,t){this.b=e,this.d=t}function Jet(e,t){this.a=e,this.b=t}function Zet(e,t){this.a=e,this.b=t}function ett(e,t){this.a=e,this.b=t}function ttt(e,t){this.b=e,this.a=t}function q3e(e,t){Ur.call(this,e,t)}function H3e(e,t){Ur.call(this,e,t)}function vq(e,t){Ur.call(this,e,t)}function ow(e,t){Ur.call(this,e,t)}function Ose(e,t){Ur.call(this,e,t)}function wq(e,t){Ur.call(this,e,t)}function V3e(e,t){Ur.call(this,e,t)}function U3e(e,t){Ur.call(this,e,t)}function dO(e,t){Ur.call(this,e,t)}function G3e(e,t){Ur.call(this,e,t)}function Nse(e,t){Ur.call(this,e,t)}function yq(e,t){Ur.call(this,e,t)}function Pse(e,t){Ur.call(this,e,t)}function Bse(e,t){Ur.call(this,e,t)}function Fse(e,t){Ur.call(this,e,t)}function Rse(e,t){Ur.call(this,e,t)}function K3e(e,t){Ur.call(this,e,t)}function jse(e,t){Ur.call(this,e,t)}function W3e(e,t){Ur.call(this,e,t)}function gO(e,t){Ur.call(this,e,t)}function $se(e,t){Ur.call(this,e,t)}function Y3e(e,t){Ur.call(this,e,t)}function pO(e,t){Ur.call(this,e,t)}function X3e(e,t){Ur.call(this,e,t)}function ntt(e,t){this.b=e,this.a=t}function rtt(e,t){this.b=e,this.a=t}function itt(e,t){this.b=e,this.a=t}function stt(e,t){this.b=e,this.a=t}function Q3e(e,t){this.a=e,this.b=t}function att(e,t){this.a=e,this.b=t}function ott(e,t){this.a=e,this.b=t}function lt(e,t){this.a=e,this.b=t}function __(e,t){Ur.call(this,e,t)}function bO(e,t){Ur.call(this,e,t)}function F8(e,t){Ur.call(this,e,t)}function A_(e,t){Ur.call(this,e,t)}function mO(e,t){Ur.call(this,e,t)}function zse(e,t){Ur.call(this,e,t)}function xq(e,t){Ur.call(this,e,t)}function L_(e,t){Ur.call(this,e,t)}function qse(e,t){Ur.call(this,e,t)}function kq(e,t){Ur.call(this,e,t)}function D5(e,t){Ur.call(this,e,t)}function vO(e,t){Ur.call(this,e,t)}function M_(e,t){Ur.call(this,e,t)}function D_(e,t){Ur.call(this,e,t)}function wO(e,t){Ur.call(this,e,t)}function Eq(e,t){Ur.call(this,e,t)}function I5(e,t){Ur.call(this,e,t)}function Hse(e,t){Ur.call(this,e,t)}function ctt(e,t){Ur.call(this,e,t)}function Tq(e,t){Ur.call(this,e,t)}function utt(e,t){this.a=e,this.b=t}function ltt(e,t){this.a=e,this.b=t}function htt(e,t){this.a=e,this.b=t}function ftt(e,t){this.a=e,this.b=t}function dtt(e,t){this.a=e,this.b=t}function gtt(e,t){this.a=e,this.b=t}function ca(e,t){this.a=e,this.b=t}function ptt(e,t){this.a=e,this.b=t}function btt(e,t){this.a=e,this.b=t}function mtt(e,t){this.a=e,this.b=t}function vtt(e,t){this.a=e,this.b=t}function wtt(e,t){this.a=e,this.b=t}function ytt(e,t){this.a=e,this.b=t}function xtt(e,t){this.b=e,this.a=t}function ktt(e,t){this.b=e,this.a=t}function Ett(e,t){this.b=e,this.a=t}function Ttt(e,t){this.b=e,this.a=t}function Ctt(e,t){this.a=e,this.b=t}function Stt(e,t){this.a=e,this.b=t}function Cq(e,t){Ur.call(this,e,t)}function _tt(e,t){this.a=e,this.b=t}function Att(e,t){this.a=e,this.b=t}function R8(e,t){Ur.call(this,e,t)}function Ltt(e,t){this.f=e,this.c=t}function J3e(e,t){return vl(e.g,t)}function mln(e,t){return vl(t.b,e)}function Mtt(e,t){return Kce(e.a,t)}function vln(e,t){return-e.b.af(t)}function wln(e,t){e&&ki(lF,e,t)}function Z3e(e,t){e.i=null,xV(e,t)}function yln(e,t,n){xgt(t,jue(e,n))}function xln(e,t,n){xgt(t,jue(e,n))}function kln(e,t){XTn(e.a,l(t,58))}function Dtt(e,t){Gvn(e.a,l(t,12))}function Sq(e,t){this.a=e,this.b=t}function Itt(e,t){this.a=e,this.b=t}function Ott(e,t){this.a=e,this.b=t}function Ntt(e,t){this.a=e,this.b=t}function Ptt(e,t){this.a=e,this.b=t}function Btt(e,t){this.d=e,this.b=t}function Ftt(e,t){this.e=e,this.a=t}function yO(e,t){this.b=e,this.c=t}function eye(e,t){this.i=e,this.g=t}function tye(e,t){this.d=e,this.e=t}function Eln(e,t){own(new or(e),t)}function _q(e){return FN(e.c,e.b)}function hc(e){return e?e.md():null}function qe(e){return e??null}function Ia(e){return typeof e===Ile}function hy(e){return typeof e===Cx}function fy(e){return typeof e===Qke}function cw(e,t){return iu(e,t)==0}function Aq(e,t){return iu(e,t)>=0}function I_(e,t){return iu(e,t)!=0}function Lq(e,t){return T3n(e.Kc(),t)}function ab(e,t){return e.Rd().Xb(t)}function Rtt(e){return Ql(e),e.d.gc()}function Mq(e){return V_(e==null),e}function O_(e,t){return e.a+=""+t,e}function Xo(e,t){return e.a+=""+t,e}function N_(e,t){return e.a+=""+t,e}function wu(e,t){return e.a+=""+t,e}function hi(e,t){return e.a+=""+t,e}function nye(e,t){return e.a+=""+t,e}function Tln(e){return""+(nr(e),e)}function jtt(e){Nl(this),bA(this,e)}function $tt(){U5e(),Q4e.call(this)}function ztt(e,t){n5e.call(this,e,t)}function qtt(e,t){n5e.call(this,e,t)}function Dq(e,t){n5e.call(this,e,t)}function ko(e,t){Cs(e,t,e.c.b,e.c)}function O5(e,t){Cs(e,t,e.a,e.a.a)}function rye(e){return Sn(e,0),null}function Htt(){this.b=0,this.a=!1}function Vtt(){this.b=0,this.a=!1}function Utt(){this.b=new N8(Ay(12))}function Gtt(){Gtt=U,y7t=Kr(eue())}function Ktt(){Ktt=U,q8t=Kr(rbt())}function Wtt(){Wtt=U,hTt=Kr(Bft())}function iye(){iye=U,Cwe(),KSe=new Pr}function Y0(e){return e.a=0,e.b=0,e}function Ytt(e,t){return e.a=t.g+1,e}function Vse(e,t){my.call(this,e,t)}function pn(e,t){vs.call(this,e,t)}function N5(e,t){eye.call(this,e,t)}function Xtt(e,t){TO.call(this,e,t)}function Use(e,t){mE.call(this,e,t)}function wi(e,t){iq(),ki(kY,e,t)}function Qtt(e,t){e.q.setTime(Fm(t))}function Cln(e){b.clearTimeout(e)}function Sln(e){return Xr(e),new P_(e)}function Jtt(e,t){return qe(e)===qe(t)}function Ztt(e,t){return e.a.a.a.cc(t)}function Gse(e,t){return tf(e.a,0,t)}function sye(e){return Lgn(l(e,74))}function j8(e){return ua((nr(e),e))}function _ln(e){return ua((nr(e),e))}function ent(e){return qu(e.l,e.m,e.h)}function aye(e,t){return ru(e.a,t.a)}function Aln(e,t){return $st(e.a,t.a)}function Lln(e,t){return Yi(e.a,t.a)}function pd(e,t){return e.indexOf(t)}function Mln(e,t){return e.j[t.p]==2}function uw(e,t){return e==t?0:e?1:-1}function Iq(e){return e<10?"0"+e:""+e}function wc(e){return typeof e===Qke}function Dln(e){return e==s3||e==o4}function Iln(e){return e==s3||e==a4}function tnt(e,t){return ru(e.g,t.g)}function oye(e){return gc(e.b.b,e,0)}function nnt(){sH.call(this,0,0,0,0)}function bd(){wr.call(this,new e2)}function cye(e,t){nE(e,0,e.length,t)}function Oln(e,t){return vt(e.a,t),t}function Nln(e,t){return u0(),t.a+=e}function Pln(e,t){return u0(),t.a+=e}function Bln(e,t){return u0(),t.c+=e}function Fln(e,t){return vt(e.c,t),e}function uye(e,t){return Dh(e.a,t),e}function rnt(e){this.a=Ket(),this.b=e}function int(e){this.a=Ket(),this.b=e}function Eo(e){this.a=e.a,this.b=e.b}function P_(e){this.a=e,GS.call(this)}function snt(e){this.a=e,GS.call(this)}function $8(){ef.call(this,0,0,0,0)}function Oq(e){return Dh(new Xs,e)}function ant(e){return EH(l(e,123))}function hh(e){return e.vh()&&e.wh()}function P5(e){return e!=Z1&&e!=Wb}function Ug(e){return e==uc||e==vc}function B5(e){return e==wf||e==Q1}function ont(e){return e==G6||e==U6}function Rln(e,t){return ru(e.g,t.g)}function cnt(e,t){return new mE(t,e)}function jln(e,t){return new mE(t,e)}function lye(e){return adn(e.b.Kc(),e.a)}function Kse(e,t){CE(e,t),lE(e,e.D)}function Wse(e,t,n){dV(e,t),fV(e,n)}function F5(e,t,n){Dw(e,t),Mw(e,n)}function Qh(e,t,n){Uu(e,t),Gu(e,n)}function xO(e,t,n){aE(e,t),cE(e,n)}function kO(e,t,n){oE(e,t),uE(e,n)}function unt(e,t,n){Gye.call(this,e,t,n)}function hye(e){Ltt.call(this,e,!0)}function lnt(){oq.call(this,"Tail",3)}function hnt(){oq.call(this,"Head",1)}function ob(e){Cd(),y3n.call(this,e)}function lw(e){sH.call(this,e,e,e,e)}function Yse(e){e.c=We(wa,Rn,1,0,5,1)}function fye(e){return e.b&&gle(e),e.a}function dye(e){return e.b&&gle(e),e.c}function $ln(e,t){G1||(e.b=t)}function zln(e,t){return e[e.length]=t}function qln(e,t){return e[e.length]=t}function Hln(e,t){return Ly(t,M1(e))}function Vln(e,t){return Ly(t,M1(e))}function Uln(e,t){return vV(Uae(e.d),t)}function Gln(e,t){return vV(Uae(e.g),t)}function Kln(e,t){return vV(Uae(e.j),t)}function Ha(e,t){vs.call(this,e.b,t)}function Wln(e,t){qr(du(e.a),Iot(t))}function Yln(e,t){qr(Xl(e.a),Oot(t))}function Xln(e,t,n){Qh(n,n.i+e,n.j+t)}function fnt(e,t,n){Ts(e.c[t.g],t.g,n)}function Qln(e,t,n){l(e.c,71).Gi(t,n)}function Xse(e,t,n){return Ts(e,t,n),n}function dnt(e){Vu(e.Sf(),new Mie(e))}function R5(e){return e!=null?es(e):0}function Jln(e){return e==null?0:es(e)}function B_(e){Di(),Xv.call(this,e)}function gnt(e){this.a=e,_4e.call(this,e)}function A1(){A1=U,b.Math.log(2)}function Jh(){Jh=U,Sg=(bet(),C_t)}function pnt(){pnt=U,Mde=new LA(Vge)}function Jr(){Jr=U,new bnt,new bt}function bnt(){new Pr,new Pr,new Pr}function Zln(){throw ue(new Hp(Q5t))}function ehn(){throw ue(new Hp(Q5t))}function thn(){throw ue(new Hp(J5t))}function nhn(){throw ue(new Hp(J5t))}function Qse(e){this.a=e,Yz.call(this,e)}function Jse(e){this.a=e,Yz.call(this,e)}function mnt(e,t){ww(),this.a=e,this.b=t}function rhn(e,t){Xr(t),V5(e).Jc(new ie)}function Vs(e,t){Lae(e.c,e.c.length,t)}function Lc(e){return e.at?1:0}function pye(e,t){return iu(e,t)>0?e:t}function qu(e,t,n){return{l:e,m:t,h:n}}function ihn(e,t){e.a!=null&&Dtt(t,e.a)}function shn(e){po(e,null),Fa(e,null)}function ahn(e,t,n){return ki(e.g,n,t)}function j5(e,t,n){return R8e(t,n,e.c)}function ohn(e,t,n){return ki(e.k,n,t)}function chn(e,t,n){return KMn(e,t,n),n}function uhn(e,t){return Sh(),t.n.b+=e}function wnt(e){R5e.call(this),this.b=e}function bye(e){r4e.call(this),this.a=e}function ynt(){oq.call(this,"Range",2)}function Nq(e){this.b=e,this.a=new bt}function xnt(e){this.b=new Nu,this.a=e}function knt(e){e.a=new _t,e.c=new _t}function Ent(e){e.a=new Pr,e.d=new Pr}function Tnt(e){doe(e,null),goe(e,null)}function Cnt(e,t){return YMn(e.a,t,null)}function lhn(e,t){return ki(e.a,t.a,t)}function Ja(e){return new lt(e.a,e.b)}function mye(e){return new lt(e.c,e.d)}function hhn(e){return new lt(e.c,e.d)}function F_(e,t){return oMn(e.c,e.b,t)}function De(e,t){return e!=null&&iue(e,t)}function Zse(e,t){return eyn(e.Kc(),t)!=-1}function Pq(e){return e.Ob()?e.Pb():null}function fhn(e){this.b=(Cn(),new tr(e))}function vye(e){this.a=e,Pr.call(this)}function Snt(){TO.call(this,null,null)}function _nt(){qq.call(this,null,null)}function Ant(){Ur.call(this,"INSTANCE",0)}function Lnt(){mxe(),this.a=new UA(gAe)}function Mnt(e){return If(e,0,e.length)}function dhn(e,t){return new Wnt(e.Kc(),t)}function wye(e,t){return e.a.Bc(t)!=null}function Dnt(e,t){$r(e),e.Gc(l(t,15))}function ghn(e,t,n){e.c.bd(t,l(n,136))}function phn(e,t,n){e.c.Ui(t,l(n,136))}function Int(e,t){e.c&&($4e(t),iot(t))}function bhn(e,t){e.q.setHours(t),XA(e,t)}function mhn(e,t){dw(t,e.a.a.a,e.a.a.b)}function vhn(e,t,n,r){Ts(e.a[t.g],n.g,r)}function eae(e,t,n){return e.a[t.g][n.g]}function whn(e,t){return e.e[t.c.p][t.p]}function yhn(e,t){return e.c[t.c.p][t.p]}function L1(e,t){return e.a[t.c.p][t.p]}function xhn(e,t){return e.j[t.p]=ITn(t)}function tae(e,t){return e.a.Bc(t)!=null}function khn(e,t){return ze(Ge(t.a))<=e}function Ehn(e,t){return ze(Ge(t.a))>=e}function Thn(e,t){return E6e(e.f,t.Pg())}function z8(e,t){return e.a*t.a+e.b*t.b}function Chn(e,t){return e.a0?t/(e*e):t*100}function Xhn(e,t){return e>0?t*t/e:t*t*100}function dy(e,t){return l(B1(e.a,t),34)}function Qhn(e,t){return Cb(),xn(e,t.e,t)}function Jhn(e,t,n){return tq(),n.Mg(e,t)}function Zhn(e){return tp(),e.e.a+e.f.a/2}function efn(e,t,n){return tp(),n.e.a-e*t}function tfn(e){return tp(),e.e.b+e.f.b/2}function nfn(e,t,n){return tp(),n.e.b-e*t}function crt(e){e.d=new srt(e),e.e=new Pr}function urt(){this.a=new Cw,this.b=new Cw}function lrt(e){this.c=e,this.a=1,this.b=1}function hrt(e){Mle(),SQe(this),this.Ff(e)}function rfn(e,t,n){ZH(),e.pf(t)&&n.Cd(e)}function ifn(e,t,n){return vt(t,k1t(e,n))}function dw(e,t,n){return e.a+=t,e.b+=n,e}function sfn(e,t,n){return e.a*=t,e.b*=n,e}function Fye(e,t){return e.a=t.a,e.b=t.b,e}function Hq(e){return e.a=-e.a,e.b=-e.b,e}function z_(e,t,n){return e.a-=t,e.b-=n,e}function frt(e){os.call(this),fA(this,e)}function drt(){Ur.call(this,"GROW_TREE",0)}function grt(){Ur.call(this,"POLYOMINO",0)}function dh(e,t,n){xl.call(this,e,t,n,2)}function afn(e,t,n){_A(du(e.a),t,Iot(n))}function prt(e,t){w_(),TO.call(this,e,t)}function Rye(e,t){Wp(),qq.call(this,e,t)}function brt(e,t){Wp(),Rye.call(this,e,t)}function mrt(e,t){Wp(),qq.call(this,e,t)}function ofn(e,t){return e.c.Fc(l(t,136))}function cfn(e,t,n){_A(Xl(e.a),t,Oot(n))}function vrt(e){this.c=e,Uu(e,0),Gu(e,0)}function oae(e,t){Jh(),cH.call(this,e,t)}function wrt(e,t){Jh(),oae.call(this,e,t)}function jye(e,t){Jh(),oae.call(this,e,t)}function $ye(e,t){Jh(),cH.call(this,e,t)}function yrt(e,t){Jh(),jye.call(this,e,t)}function xrt(e,t){Jh(),$ye.call(this,e,t)}function krt(e,t){Jh(),cH.call(this,e,t)}function ufn(e,t,n){return t.zl(e.e,e.c,n)}function lfn(e,t,n){return t.Al(e.e,e.c,n)}function zye(e,t,n){return VU(lN(e,t),n)}function cae(e,t){return yb(e.e,l(t,54))}function hfn(e){return e==null?null:BDn(e)}function ffn(e){return e==null?null:L9n(e)}function dfn(e){return e==null?null:xc(e)}function gfn(e){return e==null?null:xc(e)}function Bt(e){return V_(e==null||hy(e)),e}function Ge(e){return V_(e==null||fy(e)),e}function ei(e){return V_(e==null||Ia(e)),e}function Gg(e){e.o==null&&oTn(e)}function qye(e){if(!e)throw ue(new YI)}function pfn(e){if(!e)throw ue(new Rie)}function mr(e){if(!e)throw ue(new _c)}function gy(e){if(!e)throw ue(new pl)}function Ert(e){if(!e)throw ue(new Xh)}function Fk(){Fk=U,fF=new iJe,new sJe}function H5(){H5=U,Y6=new Ui("root")}function Hye(){sft.call(this),this.Bb|=Io}function bfn(e,t){this.d=e,Mr(this),this.b=t}function Vye(e,t){Poe.call(this,e),this.a=t}function Uye(e,t){Poe.call(this,e),this.a=t}function Gye(e,t,n){YH.call(this,e,t,n,null)}function Trt(e,t,n){YH.call(this,e,t,n,null)}function _O(e,t){this.c=e,Lk.call(this,e,t)}function q_(e,t){this.a=e,_O.call(this,e,t)}function Kye(e){this.q=new b.Date(Fm(e))}function Crt(e){return e>8?0:e+1}function Srt(e,t){G1||vt(e.a,t)}function mfn(e,t){return sO(),bE(t.d.i,e)}function vfn(e,t){return lx(),new nmt(t,e)}function wfn(e,t,n){return e.Ne(t,n)<=0?n:t}function yfn(e,t,n){return e.Ne(t,n)<=0?t:n}function xfn(e,t){return l(B1(e.b,t),143)}function kfn(e,t){return l(B1(e.c,t),233)}function uae(e){return l(jt(e.a,e.b),294)}function _rt(e){return new lt(e.c,e.d+e.a)}function Art(e){return nr(e),e?1231:1237}function Lrt(e){return Sh(),ont(l(e,203))}function py(){py=U,q_e=un((mh(),Cv))}function Efn(e,t){t.a?_En(e,t):tae(e.a,t.b)}function AO(e,t,n){++e.j,e.tj(),Noe(e,t,n)}function Mrt(e,t,n){++e.j,e.qj(t,e.Zi(t,n))}function Drt(e,t,n){var r;r=e.fd(t),r.Rb(n)}function Wye(e,t,n){return n=Nh(e,t,6,n),n}function Yye(e,t,n){return n=Nh(e,t,3,n),n}function Xye(e,t,n){return n=Nh(e,t,9,n),n}function vd(e,t){return UO(t,yEe),e.f=t,e}function Qye(e,t){return(t&Ii)%e.d.length}function Irt(e,t,n){return Mke(e.c,e.b,t,n)}function Ort(e,t){this.c=e,Lw.call(this,t)}function Nrt(e,t){this.a=e,vQe.call(this,t)}function LO(e,t){this.a=e,vQe.call(this,t)}function vs(e,t){Ui.call(this,e),this.a=t}function Jye(e,t){xwe.call(this,e),this.a=t}function lae(e,t){xwe.call(this,e),this.a=t}function Tfn(e){I8e.call(this,0,0),this.f=e}function Prt(e,t,n){return e.a+=If(t,0,n),e}function MO(e){return!e.a&&(e.a=new ge),e.a}function Zye(e,t){var n;return n=e.e,e.e=t,n}function e4e(e,t){var n;return n=t,!!e.Fe(n)}function Cfn(e,t){return Hn(),e==t?0:e?1:-1}function by(e,t){e.a.bd(e.b,t),++e.b,e.c=-1}function DO(e){e.b?DO(e.b):e.f.c.zc(e.e,e.d)}function Brt(e){Nl(e.e),e.d.b=e.d,e.d.a=e.d}function Sfn(e,t,n){Am(),Eie(e,t.Ve(e.a,n))}function t4e(e,t,n){return Q8(e,l(t,22),n)}function c0(e,t){return Vz(new Array(t),e)}function _fn(e){return Yr(ub(e,32))^Yr(e)}function hae(e){return String.fromCharCode(e)}function Afn(e){return e==null?null:e.message}function Lfn(e,t,n){return e.apply(t,n)}function Mfn(e,t){var n;n=e[lhe],n.call(e,t)}function Dfn(e,t){var n;n=e[lhe],n.call(e,t)}function Ifn(e,t){return sO(),!bE(t.d.i,e)}function n4e(e,t,n,r){sH.call(this,e,t,n,r)}function Frt(){Vq.call(this),this.a=new qa}function r4e(){this.n=new qa,this.o=new qa}function Rrt(){this.b=new qa,this.c=new bt}function jrt(){this.a=new bt,this.b=new bt}function $rt(){this.a=new bm,this.b=new BQe}function i4e(){this.b=new e2,this.a=new e2}function zrt(){this.b=new Ks,this.a=new Ks}function qrt(){this.b=new Pr,this.a=new Pr}function Hrt(){this.b=new dZe,this.a=new CS}function Vrt(){this.a=new Wre,this.b=new Aee}function Urt(){this.a=new bt,this.d=new bt}function Vq(){this.n=new A8,this.i=new $8}function Grt(e){this.a=(Mh(e,Yy),new Bu(e))}function Krt(e){this.a=(Mh(e,Yy),new Bu(e))}function Ofn(e){return e<100?null:new nb(e)}function Nfn(e,t){return e.n.a=(nr(t),t+10)}function Pfn(e,t){return e.n.a=(nr(t),t+10)}function Bfn(e,t){return t==e||jE(_U(t),e)}function Wrt(e,t){return ki(e.a,t,"")==null}function Ffn(e,t){var n;return n=t.qi(e.a),n}function Oi(e,t){return e.a+=t.a,e.b+=t.b,e}function ma(e,t){return e.a-=t.a,e.b-=t.b,e}function Rfn(e){return ay(e.j.c,0),e.a=-1,e}function s4e(e,t,n){return n=Nh(e,t,11,n),n}function jfn(e,t,n){n!=null&&wV(t,pue(e,n))}function $fn(e,t,n){n!=null&&yV(t,pue(e,n))}function V8(e,t,n,r){nt.call(this,e,t,n,r)}function a4e(e,t,n,r){nt.call(this,e,t,n,r)}function Yrt(e,t,n,r){a4e.call(this,e,t,n,r)}function Xrt(e,t,n,r){pH.call(this,e,t,n,r)}function fae(e,t,n,r){pH.call(this,e,t,n,r)}function o4e(e,t,n,r){pH.call(this,e,t,n,r)}function Qrt(e,t,n,r){fae.call(this,e,t,n,r)}function c4e(e,t,n,r){fae.call(this,e,t,n,r)}function Ln(e,t,n,r){o4e.call(this,e,t,n,r)}function Jrt(e,t,n,r){c4e.call(this,e,t,n,r)}function Zrt(e,t,n,r){a5e.call(this,e,t,n,r)}function my(e,t){tc.call(this,CL+e+av+t)}function u4e(e,t){return e.jk().wi().ri(e,t)}function l4e(e,t){return e.jk().wi().ti(e,t)}function eit(e,t){return nr(e),qe(e)===qe(t)}function vn(e,t){return nr(e),qe(e)===qe(t)}function zfn(e,t){return e.b.Bd(new ket(e,t))}function qfn(e,t){return e.b.Bd(new Eet(e,t))}function tit(e,t){return e.b.Bd(new Tet(e,t))}function Hfn(e,t){return e.e=l(e.d.Kb(t),159)}function h4e(e,t,n){return e.lastIndexOf(t,n)}function Vfn(e,t,n){return Yi(e[t.a],e[n.a])}function Ufn(e,t){return rt(t,(Nt(),TB),e)}function Gfn(e,t){return ru(t.a.d.p,e.a.d.p)}function Kfn(e,t){return ru(e.a.d.p,t.a.d.p)}function Wfn(e,t){return Yi(e.c-e.s,t.c-t.s)}function Yfn(e,t){return Yi(e.b.e.a,t.b.e.a)}function Xfn(e,t){return Yi(e.c.e.a,t.c.e.a)}function nit(e){return e.c?gc(e.c.a,e,0):-1}function U8(e){return e==Tv||e==Tg||e==Mu}function f4e(e,t){this.c=e,jae.call(this,e,t)}function rit(e,t,n){this.a=e,Nye.call(this,t,n)}function iit(e){this.c=e,Dq.call(this,EP,0)}function sit(e,t,n){this.c=t,this.b=n,this.a=e}function IO(e){jk(),this.d=e,this.a=new z5}function ait(e){wd(),this.a=(Cn(),new Ek(e))}function Qfn(e,t){Ug(e.f)?ZEn(e,t):Mxn(e,t)}function oit(e,t){ldn.call(this,e,e.length,t)}function Jfn(e,t){G1||t&&(e.d=t)}function cit(e,t){return De(t,15)&&Bbt(e.c,t)}function Zfn(e,t,n){return l(e.c,71).Wk(t,n)}function Uq(e,t,n){return l(e.c,71).Xk(t,n)}function e0n(e,t,n){return ufn(e,l(t,343),n)}function d4e(e,t,n){return lfn(e,l(t,343),n)}function t0n(e,t,n){return Lgt(e,l(t,343),n)}function uit(e,t,n){return Hxn(e,l(t,343),n)}function H_(e,t){return t==null?null:Oy(e.b,t)}function g4e(e){return fy(e)?(nr(e),e):e.ue()}function Gq(e){return!isNaN(e)&&!isFinite(e)}function dae(e){knt(this),Ch(this),Ka(this,e)}function Ol(e){Yse(this),M4e(this.c,0,e.Pc())}function Zh(e,t,n){this.a=e,this.b=t,this.c=n}function lit(e,t,n){this.a=e,this.b=t,this.c=n}function hit(e,t,n){this.d=e,this.b=n,this.a=t}function fit(e){this.a=e,Vg(),Zc(Date.now())}function dit(e){ph(e.a),L6e(e.c,e.b),e.b=null}function gae(){gae=U,p_e=new Et,_6t=new Gt}function git(){git=U,M_t=We(wa,Rn,1,0,5,1)}function pit(){pit=U,W_t=We(wa,Rn,1,0,5,1)}function p4e(){p4e=U,Y_t=We(wa,Rn,1,0,5,1)}function wd(){wd=U,new Twe((Cn(),Cn(),_o))}function n0n(e){return rE(),Gr((xlt(),M6t),e)}function r0n(e){return Fl(),Gr((hlt(),B6t),e)}function i0n(e){return ZV(),Gr((Xct(),q6t),e)}function s0n(e){return aV(),Gr((Qct(),H6t),e)}function a0n(e){return PU(),Gr((Xft(),V6t),e)}function o0n(e){return t1(),Gr((ult(),K6t),e)}function c0n(e){return Bl(),Gr((clt(),Y6t),e)}function u0n(e){return ol(),Gr((llt(),Q6t),e)}function l0n(e){return YU(),Gr((Gtt(),y7t),e)}function h0n(e){return Pw(),Gr((Elt(),k7t),e)}function f0n(e){return bx(),Gr((Clt(),T7t),e)}function d0n(e){return NA(),Gr((Tlt(),_7t),e)}function g0n(e){return Zz(),Gr((kct(),A7t),e)}function p0n(e){return oV(),Gr((Jct(),U7t),e)}function b0n(e){return lA(),Gr((flt(),m8t),e)}function m0n(e){return uo(),Gr((aht(),x8t),e)}function v0n(e){return wE(),Gr((_lt(),S8t),e)}function w0n(e){return Km(),Gr((Slt(),I8t),e)}function b4e(e,t){if(!e)throw ue(new Yn(t))}function Rk(e){if(!e)throw ue(new nc(Jke))}function pae(e,t){if(e!=t)throw ue(new Xh)}function bit(e,t,n){this.a=e,this.b=t,this.c=n}function m4e(e,t,n){this.a=e,this.b=t,this.c=n}function mit(e,t,n){this.a=e,this.b=t,this.c=n}function Kq(e,t,n){this.b=e,this.a=t,this.c=n}function v4e(e,t,n){this.b=e,this.c=t,this.a=n}function w4e(e,t,n){this.a=e,this.b=t,this.c=n}function Wq(e,t,n){this.e=t,this.b=e,this.d=n}function vit(e,t,n){this.b=e,this.a=t,this.c=n}function y0n(e,t,n){return Am(),e.a.Yd(t,n),t}function bae(e){var t;return t=new Ml,t.e=e,t}function y4e(e){var t;return t=new zQe,t.b=e,t}function OO(){OO=U,CK=new pZ,SK=new dj}function Yq(){Yq=U,K8t=new SZ,G8t=new bS}function u0(){u0=U,J8t=new iee,Z8t=new see}function x0n(e){return Ow(),Gr((Hut(),uxt),e)}function k0n(e){return vo(),Gr((Ktt(),q8t),e)}function E0n(e){return IV(),Gr((Llt(),U8t),e)}function T0n(e){return R1(),Gr((Alt(),nxt),e)}function C0n(e){return Ry(),Gr((oht(),ixt),e)}function S0n(e){return OU(),Gr((Pft(),lxt),e)}function _0n(e){return yx(),Gr((Iht(),hxt),e)}function A0n(e){return JH(),Gr((sut(),fxt),e)}function L0n(e){return dA(),Gr((zut(),dxt),e)}function M0n(e){return pV(),Gr((qut(),gxt),e)}function D0n(e){return l2(),Gr((cht(),pxt),e)}function I0n(e){return pN(),Gr((tut(),bxt),e)}function O0n(e){return zE(),Gr((Pht(),kxt),e)}function N0n(e){return Ho(),Gr((f0t(),Ext),e)}function P0n(e){return vE(),Gr((Uut(),Txt),e)}function B0n(e){return ep(),Gr((Gut(),Sxt),e)}function F0n(e){return zH(),Gr((eut(),_xt),e)}function R0n(e){return WN(),Gr((Nht(),xxt),e)}function j0n(e){return Vm(),Gr((Vut(),vxt),e)}function $0n(e){return yU(),Gr((Oht(),wxt),e)}function z0n(e){return cN(),Gr((nut(),yxt),e)}function q0n(e){return hf(),Gr((lht(),Axt),e)}function H0n(e){return p2(),Gr((Kft(),Jkt),e)}function V0n(e){return EA(),Gr((Kut(),Zkt),e)}function U0n(e){return By(),Gr((Mlt(),eEt),e)}function G0n(e){return OA(),Gr((uht(),tEt),e)}function K0n(e){return Nf(),Gr((d0t(),nEt),e)}function W0n(e){return Ed(),Gr((Dlt(),rEt),e)}function Y0n(e){return dN(),Gr((rut(),iEt),e)}function X0n(e){return qo(),Gr((Xut(),aEt),e)}function Q0n(e){return LV(),Gr((Wut(),oEt),e)}function J0n(e){return yA(),Gr((Yut(),cEt),e)}function Z0n(e){return SE(),Gr((Qut(),uEt),e)}function e1n(e){return gV(),Gr((Jut(),lEt),e)}function t1n(e){return OV(),Gr((Zut(),hEt),e)}function n1n(e){return Iw(),Gr((olt(),_Et),e)}function r1n(e){return oA(),Gr((iut(),IEt),e)}function i1n(e){return xd(),Gr((cut(),jEt),e)}function s1n(e){return D1(),Gr((uut(),zEt),e)}function a1n(e){return J0(),Gr((lut(),nTt),e)}function o1n(e){return Sw(),Gr((hut(),uTt),e)}function c1n(e){return wx(),Gr((Rlt(),lTt),e)}function u1n(e){return WA(),Gr((Wtt(),hTt),e)}function l1n(e){return xA(),Gr((elt(),fTt),e)}function h1n(e){return kA(),Gr((Flt(),PTt),e)}function f1n(e){return RH(),Gr((aut(),BTt),e)}function d1n(e){return kV(),Gr((out(),zTt),e)}function g1n(e){return bU(),Gr((hht(),HTt),e)}function p1n(e){return LN(),Gr((tlt(),UTt),e)}function b1n(e){return eV(),Gr((fut(),VTt),e)}function m1n(e){return uU(),Gr((Blt(),hCt),e)}function v1n(e){return AV(),Gr((nlt(),fCt),e)}function w1n(e){return WV(),Gr((rlt(),dCt),e)}function y1n(e){return sU(),Gr((ilt(),pCt),e)}function x1n(e){return qV(),Gr((slt(),vCt),e)}function k1n(e){return GH(),Gr((dut(),jCt),e)}function E1n(e){return dE(),Gr((Zct(),z8t),e)}function T1n(e){return Zn(),Gr((Bht(),B8t),e)}function C1n(e){return tV(),Gr((alt(),$Ct),e)}function S1n(e){return fce(),Gr((gut(),zCt),e)}function _1n(e){return VA(),Gr((fht(),HCt),e)}function A1n(e){return nq(),Gr((Mct(),UCt),e)}function L1n(e){return PN(),Gr((glt(),VCt),e)}function M1n(e){return rq(),Gr((Dct(),KCt),e)}function D1n(e){return rN(),Gr((put(),WCt),e)}function I1n(e){return XN(),Gr((dht(),YCt),e)}function O1n(e){return b_(),Gr((Ict(),hSt),e)}function N1n(e){return CN(),Gr((but(),fSt),e)}function P1n(e){return r1(),Gr((pht(),vSt),e)}function B1n(e){return g2(),Gr((Oft(),ySt),e)}function F1n(e){return og(),Gr((Fht(),xSt),e)}function R1n(e){return Ym(),Gr((Rht(),_St),e)}function j1n(e){return Js(),Gr((ght(),GSt),e)}function $1n(e){return F1(),Gr((plt(),KSt),e)}function z1n(e){return ip(),Gr((jlt(),WSt),e)}function q1n(e){return vU(),Gr((jht(),YSt),e)}function H1n(e){return rp(),Gr((dlt(),QSt),e)}function V1n(e){return Ih(),Gr(($lt(),ZSt),e)}function U1n(e){return qy(),Gr((Yft(),e_t),e)}function G1n(e){return t6(),Gr((bht(),t_t),e)}function K1n(e){return Ra(),Gr(($ht(),n_t),e)}function W1n(e){return Rl(),Gr((zht(),r_t),e)}function Y1n(e){return Ct(),Gr((mht(),i_t),e)}function X1n(e){return mh(),Gr((zlt(),u_t),e)}function Q1n(e){return Zl(),Gr((Wft(),l_t),e)}function J1n(e){return dx(),Gr((blt(),h_t),e)}function Z1n(e,t){return nr(e),e+(nr(t),t)}function edn(e){return mae(),Gr((mut(),f_t),e)}function tdn(e){return VV(),Gr((qlt(),d_t),e)}function ndn(e){return NV(),Gr((Hlt(),b_t),e)}function jk(){jk=U,$De=(Ct(),er),DW=ar}function mae(){mae=U,rPe=new Wit,iPe=new Ost}function rdn(e){return!e.e&&(e.e=new bt),e.e}function vae(e,t){this.c=e,this.a=t,this.b=t-e}function wit(e,t,n){this.a=e,this.b=t,this.c=n}function wae(e,t,n){this.a=e,this.b=t,this.c=n}function x4e(e,t,n){this.a=e,this.b=t,this.c=n}function k4e(e,t,n){this.a=e,this.b=t,this.c=n}function yit(e,t,n){this.a=e,this.b=t,this.c=n}function xit(e,t,n){this.a=e,this.b=t,this.c=n}function Xp(e,t,n){this.e=e,this.a=t,this.c=n}function kit(e,t,n){Jh(),$5e.call(this,e,t,n)}function yae(e,t,n){Jh(),E5e.call(this,e,t,n)}function E4e(e,t,n){Jh(),E5e.call(this,e,t,n)}function T4e(e,t,n){Jh(),E5e.call(this,e,t,n)}function Eit(e,t,n){Jh(),yae.call(this,e,t,n)}function C4e(e,t,n){Jh(),yae.call(this,e,t,n)}function Tit(e,t,n){Jh(),C4e.call(this,e,t,n)}function Cit(e,t,n){Jh(),E4e.call(this,e,t,n)}function Sit(e,t,n){Jh(),T4e.call(this,e,t,n)}function xae(e){sH.call(this,e.d,e.c,e.a,e.b)}function S4e(e){sH.call(this,e.d,e.c,e.a,e.b)}function _4e(e){this.d=e,Mr(this),this.b=ngn(e.d)}function idn(e){return HE(),Gr((Nft(),L_t),e)}function NO(e,t){return Xr(e),Xr(t),new IZe(e,t)}function G8(e,t){return Xr(e),Xr(t),new jit(e,t)}function sdn(e,t){return Xr(e),Xr(t),new $it(e,t)}function adn(e,t){return Xr(e),Xr(t),new zZe(e,t)}function kae(e){return mr(e.b!=0),af(e,e.a.a)}function odn(e){return mr(e.b!=0),af(e,e.c.b)}function cdn(e){return!e.c&&(e.c=new Xd),e.c}function $k(e){var t;return t=new bt,Goe(t,e),t}function udn(e){var t;return t=new Ks,Goe(t,e),t}function _it(e){var t;return t=new Lwe,sce(t,e),t}function PO(e){var t;return t=new os,sce(t,e),t}function l(e,t){return V_(e==null||iue(e,t)),e}function ldn(e,t,n){Sst.call(this,t,n),this.a=e}function Ait(e,t){this.c=e,this.b=t,this.a=!1}function Lit(){this.a=";,;",this.b="",this.c=""}function Mit(e,t,n){this.b=e,ztt.call(this,t,n)}function A4e(e,t,n){this.c=e,cq.call(this,t,n)}function L4e(e,t,n){Ik.call(this,e,t),this.b=n}function M4e(e,t,n){k9e(n,0,e,t,n.length,!1)}function tg(e,t,n,r,a){e.b=t,e.c=n,e.d=r,e.a=a}function D4e(e,t,n,r,a){e.d=t,e.c=n,e.a=r,e.b=a}function hdn(e,t){t&&(e.b=t,e.a=(fb(t),t.a))}function BO(e,t){if(!e)throw ue(new Yn(t))}function K8(e,t){if(!e)throw ue(new nc(t))}function I4e(e,t){if(!e)throw ue(new BJe(t))}function fdn(e,t){return eq(),ru(e.d.p,t.d.p)}function ddn(e,t){return tp(),Yi(e.e.b,t.e.b)}function gdn(e,t){return tp(),Yi(e.e.a,t.e.a)}function pdn(e,t){return ru(Uit(e.d),Uit(t.d))}function Xq(e,t){return t&&yH(e,t.d)?t:null}function bdn(e,t){return t==(Ct(),er)?e.c:e.d}function O4e(e){return mb(pgn(wc(e)?Mf(e):e))}function mdn(e){return new lt(e.c+e.b,e.d+e.a)}function Dit(e){return e!=null&&!Hce(e,$M,zM)}function vdn(e,t){return(u1t(e)<<4|u1t(t))&Zs}function Iit(e,t,n,r,a){e.c=t,e.d=n,e.b=r,e.a=a}function N4e(e){var t,n;t=e.b,n=e.c,e.b=n,e.c=t}function P4e(e){var t,n;n=e.d,t=e.a,e.d=t,e.a=n}function wdn(e,t){var n;return n=e.c,d7e(e,t),n}function B4e(e,t){return t<0?e.g=-1:e.g=t,e}function Qq(e,t){return _wn(e),e.a*=t,e.b*=t,e}function Oit(e,t,n){_ht.call(this,t,n),this.d=e}function FO(e,t,n){tye.call(this,e,t),this.c=n}function Jq(e,t,n){tye.call(this,e,t),this.c=n}function F4e(e){p4e(),m5.call(this),this.ci(e)}function Nit(){eE(),$gn.call(this,(ib(),Gf))}function Pit(e){return Di(),new ng(0,e)}function Bit(){Bit=U,spe=(Cn(),new Da(c0e))}function Zq(){Zq=U,new W8e((Gie(),y0e),(Uie(),w0e))}function Fit(){Fit=U,t_e=We(ro,dt,17,256,0,1)}function Rit(){this.b=ze(Ge(It((b0(),Z0e))))}function Eae(e){this.b=e,this.a=Mm(this.b.a).Od()}function jit(e,t){this.b=e,this.a=t,GS.call(this)}function $it(e,t){this.a=e,this.b=t,GS.call(this)}function zit(e,t,n){this.a=e,N5.call(this,t,n)}function qit(e,t,n){this.a=e,N5.call(this,t,n)}function zk(e,t,n){var r;r=new yy(n),e1(e,t,r)}function R4e(e,t,n){var r;return r=e[t],e[t]=n,r}function eH(e){var t;return t=e.slice(),joe(t,e)}function tH(e){var t;return t=e.n,e.a.b+t.d+t.a}function Hit(e){var t;return t=e.n,e.e.b+t.d+t.a}function j4e(e){var t;return t=e.n,e.e.a+t.b+t.c}function $4e(e){e.a.b=e.b,e.b.a=e.a,e.a=e.b=null}function ui(e,t){return Cs(e,t,e.c.b,e.c),!0}function ydn(e){return e.a?e.a:Qae(e)}function xdn(e){return tx(),cg(e)==ds(Eb(e))}function kdn(e){return tx(),Eb(e)==ds(cg(e))}function gw(e,t){return RA(e,new Ik(t.a,t.b))}function Edn(e,t){return kH(),fue(e,t),new hat(e,t)}function Tdn(e,t){return e.c=t)throw ue(new Bwe)}function vy(e,t){return ON(e,(nr(t),new xo(t)))}function Y8(e,t){return ON(e,(nr(t),new lh(t)))}function Ast(e,t,n){return XIn(e,l(t,12),l(n,12))}function Lst(e){return kl(),l(e,12).g.c.length!=0}function Mst(e){return kl(),l(e,12).e.c.length!=0}function cgn(e,t){return lx(),Yi(t.a.o.a,e.a.o.a)}function ugn(e,t){t.Bb&eu&&!e.a.o&&(e.a.o=t)}function lgn(e,t){t.Ug("General 'Rotator",1),TDn(e)}function hgn(e,t,n){t.qf(n,ze(Ge(cr(e.b,n)))*e.a)}function Dst(e,t,n){return h6(),gE(e,t)&&gE(e,n)}function W_(e){return Rl(),!e.Hc(vp)&&!e.Hc(Yb)}function fgn(e){return e.e?_6e(e.e):null}function Y_(e){return wc(e)?""+e:Pbt(e)}function s5e(e){var t;for(t=e;t.f;)t=t.f;return t}function dgn(e,t,n){return Ts(t,0,U4e(t[0],n[0])),t}function Qp(e,t,n,r){var a;a=e.i,a.i=t,a.a=n,a.b=r}function nt(e,t,n,r){Ys.call(this,e,t,n),this.b=r}function _a(e,t,n,r,a){Foe.call(this,e,t,n,r,a,-1)}function X_(e,t,n,r,a){sN.call(this,e,t,n,r,a,-1)}function pH(e,t,n,r){FO.call(this,e,t,n),this.b=r}function Ist(e){Ltt.call(this,e,!1),this.a=!1}function Ost(){ctt.call(this,"LOOKAHEAD_LAYOUT",1)}function Nst(e){this.b=e,q8.call(this,e),jnt(this)}function Pst(e){this.b=e,CO.call(this,e),$nt(this)}function wy(e,t,n){this.a=e,V8.call(this,t,n,5,6)}function a5e(e,t,n,r){this.b=e,Ys.call(this,t,n,r)}function Bst(e,t){this.b=e,qg.call(this,e.b),this.a=t}function Fst(e){this.a=ydt(e.a),this.b=new Ol(e.b)}function o5e(e,t){ww(),Vun.call(this,e,RV(new Il(t)))}function bH(e,t){return Di(),new k5e(e,t,0)}function Bae(e,t){return Di(),new k5e(6,e,t)}function Za(e,t){for(nr(t);e.Ob();)t.Cd(e.Pb())}function Hu(e,t){return Ia(t)?soe(e,t):!!zo(e.f,t)}function Fae(e,t){return t.Vh()?yb(e.b,l(t,54)):t}function ggn(e,t){return vn(e.substr(0,t.length),t)}function rg(e){return new hr(new Aye(e.a.length,e.a))}function mH(e){return new lt(e.c+e.b/2,e.d+e.a/2)}function pgn(e){return qu(~e.l&eh,~e.m&eh,~e.h&hp)}function Rae(e){return typeof e===wP||typeof e===Ole}function Nl(e){e.f=new rnt(e),e.i=new int(e),++e.g}function Rst(e){if(!e)throw ue(new _c);return e.d}function X8(e){var t;return t=wA(e),mr(t!=null),t}function bgn(e){var t;return t=I4n(e),mr(t!=null),t}function Hk(e,t){var n;return n=e.a.gc(),k6e(t,n),n-t}function na(e,t){var n;return n=e.a.zc(t,e),n==null}function jO(e,t){return e.a.zc(t,(Hn(),Pb))==null}function c5e(e){return new bn(null,xgn(e,e.length))}function u5e(e,t,n){return svt(e,l(t,42),l(n,176))}function Q8(e,t,n){return d0(e.a,t),R4e(e.b,t.g,n)}function mgn(e,t,n){qk(n,e.a.c.length),rf(e.a,n,t)}function He(e,t,n,r){B0t(t,n,e.length),vgn(e,t,n,r)}function vgn(e,t,n,r){var a;for(a=t;a0?b.Math.log(e/t):-100}function $st(e,t){return iu(e,t)<0?-1:iu(e,t)>0?1:0}function $O(e,t){Dnt(e,De(t,160)?t:l(t,2036).Rl())}function d5e(e,t){if(e==null)throw ue(new D8(t))}function xgn(e,t){return Ewn(t,e.length),new Kit(e,t)}function g5e(e,t){return t?Ka(e,t):!1}function kgn(){return $z(),he(le(a6t,1),it,549,0,[E0e])}function J_(e){return e.e==0?e:new Im(-e.e,e.d,e.a)}function Egn(e,t){return Yi(e.c.c+e.c.b,t.c.c+t.c.b)}function zO(e,t){Cs(e.d,t,e.b.b,e.b),++e.a,e.c=null}function zst(e,t){return e.c?zst(e.c,t):vt(e.b,t),e}function Tgn(e,t,n){var r;return r=_y(e,t),xoe(e,t,n),r}function qst(e,t,n){var r;for(r=0;r=e.g}function Ts(e,t,n){return pfn(n==null||lAn(e,n)),e[t]=n}function w5e(e,t){return Xn(t,e.length+1),e.substr(t)}function Wae(e,t){for(nr(t);e.c=e?new b3e:Kwn(e-1)}function eo(e){return!e.a&&e.c?e.c.b:e.a}function T5e(e){return De(e,616)?e:new oot(e)}function fb(e){e.c?fb(e.c):(xb(e),e.d=!0)}function tA(e){e.c?e.c.$e():(e.d=!0,hCn(e))}function cat(e){e.b=!1,e.c=!1,e.d=!1,e.a=!1}function uat(e){var t,n;return t=e.c.i.c,n=e.d.i.c,t==n}function Hgn(e,t){var n;n=e.Ih(t),n>=0?e.ki(n):d9e(e,t)}function lat(e,t){e.c<0||e.b.b0;)e=e<<1|(e<0?1:0);return e}function vat(e,t){var n;return n=new yu(e),$n(t.c,n),n}function wat(e,t){e.u.Hc((Rl(),vp))&&Wkn(e,t),fvn(e,t)}function Jc(e,t){return qe(e)===qe(t)||e!=null&&Pi(e,t)}function Qo(e,t){return Aae(e.a,t)?e.b[l(t,22).g]:null}function npn(){return Zz(),he(le(U_e,1),it,489,0,[G0e])}function rpn(){return nq(),he(le(wOe,1),it,490,0,[bge])}function ipn(){return rq(),he(le(GCt,1),it,558,0,[mge])}function spn(){return b_(),he(le($Oe,1),it,539,0,[qB])}function EH(e){return!e.n&&(e.n=new nt(ec,e,1,7)),e.n}function Xae(e){return!e.c&&(e.c=new nt(Hl,e,9,9)),e.c}function A5e(e){return!e.c&&(e.c=new Ln(_r,e,5,8)),e.c}function apn(e){return!e.b&&(e.b=new Ln(_r,e,4,7)),e.b}function qO(e){return e.j.c.length=0,M5e(e.c),Rfn(e.a),e}function Wk(e){return e.e==ET&&hn(e,e6n(e.g,e.b)),e.e}function HO(e){return e.f==ET&&Dn(e,U7n(e.g,e.b)),e.f}function Ei(e,t,n,r){return qft(e,t,n,!1),jV(e,r),e}function yat(e,t){this.b=e,jae.call(this,e,t),jnt(this)}function xat(e,t){this.b=e,f4e.call(this,e,t),$nt(this)}function nA(e){this.d=e,this.a=this.d.b,this.b=this.d.c}function L5e(e,t){this.b=e,this.c=t,this.a=new P8(this.b)}function co(e,t){return Xn(t,e.length),e.charCodeAt(t)}function opn(e,t){b8e(e,ze(np(t,"x")),ze(np(t,"y")))}function cpn(e,t){b8e(e,ze(np(t,"x")),ze(np(t,"y")))}function Fi(e,t){return xb(e),new bn(e,new $6e(t,e.a))}function fc(e,t){return xb(e),new bn(e,new C6e(t,e.a))}function xy(e,t){return xb(e),new Vye(e,new Mut(t,e.a))}function TH(e,t){return xb(e),new Uye(e,new Dut(t,e.a))}function upn(e,t){return new Uat(l(Xr(e),50),l(Xr(t),50))}function lpn(e,t){return Yi(e.d.c+e.d.b/2,t.d.c+t.d.b/2)}function kat(e,t,n){n.a?Gu(e,t.b-e.f/2):Uu(e,t.a-e.g/2)}function hpn(e,t){return Yi(e.g.c+e.g.b/2,t.g.c+t.g.b/2)}function fpn(e,t){return w3e(),Yi((nr(e),e),(nr(t),t))}function dpn(e){return e!=null&&nO(EY,e.toLowerCase())}function M5e(e){var t;for(t=e.Kc();t.Ob();)t.Pb(),t.Qb()}function V5(e){var t;return t=e.b,!t&&(e.b=t=new mie(e)),t}function Qae(e){var t;return t=Qwn(e),t||null}function Eat(e,t){var n,r;return n=e/t,r=ua(n),n>r&&++r,r}function gpn(e,t,n){var r;r=l(e.d.Kb(n),159),r&&r.Nb(t)}function ppn(e,t,n){mLn(e.a,n),W3n(n),REn(e.b,n),RLn(t,n)}function CH(e,t,n,r){this.a=e,this.c=t,this.b=n,this.d=r}function D5e(e,t,n,r){this.c=e,this.b=t,this.a=n,this.d=r}function Tat(e,t,n,r){this.c=e,this.b=t,this.d=n,this.a=r}function ef(e,t,n,r){this.c=e,this.d=t,this.b=n,this.a=r}function Cat(e,t,n,r){this.a=e,this.d=t,this.c=n,this.b=r}function Jae(e,t,n,r){this.a=e,this.e=t,this.d=n,this.c=r}function Sat(e,t,n,r){this.a=e,this.c=t,this.d=n,this.b=r}function Zae(e,t,n){this.a=iEe,this.d=e,this.b=t,this.c=n}function Z8(e,t,n,r){Ur.call(this,e,t),this.a=n,this.b=r}function _at(e,t){this.d=(nr(e),e),this.a=16449,this.c=t}function Aat(e){this.a=new bt,this.e=We(Vr,dt,53,e,0,2)}function bpn(e){e.Ug("No crossing minimization",1),e.Vg()}function Lat(){Ac.call(this,"There is no more element.")}function Mat(e,t,n,r){this.a=e,this.b=t,this.c=n,this.d=r}function Dat(e,t,n,r){this.a=e,this.b=t,this.c=n,this.d=r}function Om(e,t,n,r){this.e=e,this.a=t,this.c=n,this.d=r}function Iat(e,t,n,r){this.a=e,this.c=t,this.d=n,this.b=r}function Oat(e,t,n,r){Jh(),Iut.call(this,t,n,r),this.a=e}function Nat(e,t,n,r){Jh(),Iut.call(this,t,n,r),this.a=e}function eoe(e,t,n){var r,a;return r=Vke(e),a=t.ti(n,r),a}function Kg(e){var t,n;return n=(t=new Qv,t),sE(n,e),n}function toe(e){var t,n;return n=(t=new Qv,t),Kxe(n,e),n}function mpn(e,t){var n;return n=cr(e.f,t),S7e(t,n),null}function Pat(e){return!e.b&&(e.b=new nt(js,e,12,3)),e.b}function Bat(e){return V_(e==null||Rae(e)&&e.Tm!==xe),e}function SH(e){return e.n&&(e.e!==Fwt&&e.je(),e.j=null),e}function Yk(e){if(Ql(e.d),e.d.d!=e.c)throw ue(new Xh)}function I5e(e){return mr(e.b0&&ggt(this)}function Fat(e,t){this.a=e,bfn.call(this,e,l(e.d,15).fd(t))}function vpn(e,t){return Yi(wl(e)*gh(e),wl(t)*gh(t))}function wpn(e,t){return Yi(wl(e)*gh(e),wl(t)*gh(t))}function ypn(e){return qw(e)&&Rt(Bt(at(e,(Nt(),gv))))}function xpn(e,t){return xn(e,l(Q(t,(Nt(),HT)),17),t)}function kpn(e,t){return l(Q(e,(ft(),Wx)),15).Fc(t),t}function O5e(e,t){return e.b=t.b,e.c=t.c,e.d=t.d,e.a=t.a,e}function Rat(e,t,n,r){this.b=e,this.c=r,Dq.call(this,t,n)}function Epn(e,t,n){e.i=0,e.e=0,t!=n&&x0t(e,t,n)}function Tpn(e,t,n){e.i=0,e.e=0,t!=n&&k0t(e,t,n)}function Cpn(e,t,n){return p_(),J4n(l(cr(e.e,t),529),n)}function ex(e){var t;return t=e.f,t||(e.f=new Lk(e,e.c))}function jat(e,t){return e6(e.j,t.s,t.c)+e6(t.e,e.s,e.c)}function $at(e,t){e.e&&!e.e.a&&(CQe(e.e,t),$at(e.e,t))}function zat(e,t){e.d&&!e.d.a&&(CQe(e.d,t),zat(e.d,t))}function Spn(e,t){return-Yi(wl(e)*gh(e),wl(t)*gh(t))}function _pn(e){return l(e.ld(),149).Pg()+":"+xc(e.md())}function qat(){Nue(this,new fz),this.wb=(lb(),Vn),Sk()}function Hat(e){this.b=new bt,ra(this.b,this.b),this.a=e}function N5e(e,t){new os,this.a=new bl,this.b=e,this.c=t}function Ew(){Ew=U,d_e=new Ke,D0e=new Ke,g_e=new Ft}function Cn(){Cn=U,_o=new je,mg=new Se,hK=new Ce}function P5e(){P5e=U,j6t=new wo,z6t=new X4e,$6t=new _s}function tx(){tx=U,wK=new bt,X0e=new Pr,Y0e=new bt}function _H(e,t){if(e==null)throw ue(new D8(t));return e}function AH(e){return!e.a&&(e.a=new nt(Ai,e,10,11)),e.a}function qi(e){return!e.q&&(e.q=new nt(Uf,e,11,10)),e.q}function tt(e){return!e.s&&(e.s=new nt(dl,e,21,17)),e.s}function Apn(e){return Xr(e),Mdt(new hr(dr(e.a.Kc(),new j)))}function Lpn(e,t){return bh(e),bh(t),PJe(l(e,22),l(t,22))}function Nm(e,t,n){var r,a;r=g4e(n),a=new vk(r),e1(e,t,a)}function roe(e,t,n,r,a,o){sN.call(this,e,t,n,r,a,o?-2:-1)}function Vat(e,t,n,r){tye.call(this,t,n),this.b=e,this.a=r}function Uat(e,t){Xcn.call(this,new Pae(e)),this.a=e,this.b=t}function B5e(e){this.b=e,this.c=e,e.e=null,e.c=null,this.a=1}function Mpn(e){u0();var t;t=l(e.g,10),t.n.a=e.d.c+t.d.b}function Xk(){Xk=U;var e,t;t=!F5n(),e=new se,S0e=t?new ne:e}function ioe(e){return Cn(),De(e,59)?new ese(e):new jq(e)}function LH(e){return De(e,16)?new U_(l(e,16)):udn(e.Kc())}function Dpn(e){return new qnt(e,e.e.Rd().gc()*e.c.Rd().gc())}function Ipn(e){return new Hnt(e,e.e.Rd().gc()*e.c.Rd().gc())}function F5e(e){return e&&e.hashCode?e.hashCode():fw(e)}function soe(e,t){return t==null?!!zo(e.f,null):Wdn(e.i,t)}function Opn(e,t){var n;return n=wye(e.a,t),n&&(t.d=null),n}function Gat(e,t,n){return e.f?e.f.ef(t,n):!1}function VO(e,t,n,r){Ts(e.c[t.g],n.g,r),Ts(e.c[n.g],t.g,r)}function aoe(e,t,n,r){Ts(e.c[t.g],t.g,n),Ts(e.b[t.g],t.g,r)}function Npn(e,t,n){return ze(Ge(n.a))<=e&&ze(Ge(n.b))>=t}function Kat(e,t){this.g=e,this.d=he(le(wg,1),m2,10,0,[t])}function Wat(e){this.c=e,this.b=new Kp(l(Xr(new tl),50))}function Yat(e){this.c=e,this.b=new Kp(l(Xr(new l5),50))}function Xat(e){this.b=e,this.a=new Kp(l(Xr(new Bi),50))}function Qat(){this.b=new Ks,this.d=new os,this.e=new Fwe}function R5e(){this.c=new qa,this.d=new qa,this.e=new qa}function Tw(){this.a=new bl,this.b=(Mh(3,Yy),new Bu(3))}function Jp(e,t){this.e=e,this.a=wa,this.b=Qbt(t),this.c=t}function MH(e){this.c=e.c,this.d=e.d,this.b=e.b,this.a=e.a}function Jat(e,t,n,r,a,o){this.a=e,Joe.call(this,t,n,r,a,o)}function Zat(e,t,n,r,a,o){this.a=e,Joe.call(this,t,n,r,a,o)}function db(e,t,n,r,a,o,f){return new Eoe(e.e,t,n,r,a,o,f)}function Ppn(e,t,n){return n>=0&&vn(e.substr(n,t.length),t)}function eot(e,t){return De(t,149)&&vn(e.b,l(t,149).Pg())}function Bpn(e,t){return e.a?t.Gh().Kc():l(t.Gh(),71).Ii()}function tot(e,t){var n;return n=e.b.Qc(t),Yct(n,e.b.gc()),n}function UO(e,t){if(e==null)throw ue(new D8(t));return e}function dc(e){return e.u||(Yl(e),e.u=new Nrt(e,e)),e.u}function ooe(e){this.a=(Cn(),De(e,59)?new ese(e):new jq(e))}function sl(e){var t;return t=l(Kn(e,16),29),t||e.ii()}function DH(e,t){var n;return n=_m(e.Rm),t==null?n:n+": "+t}function tf(e,t,n){return Ga(t,n,e.length),e.substr(t,n-t)}function not(e,t){Vq.call(this),Y6e(this),this.a=e,this.c=t}function Fpn(e){e&&DH(e,e.ie())}function Rpn(e){Hz(),b.setTimeout(function(){throw e},0)}function jpn(){return ZV(),he(le(k_e,1),it,436,0,[j0e,x_e])}function $pn(){return aV(),he(le(T_e,1),it,435,0,[E_e,$0e])}function zpn(){return oV(),he(le(J_e,1),it,432,0,[Q0e,yK])}function qpn(){return dE(),he(le($8t,1),it,517,0,[dB,h1e])}function Hpn(){return zH(),he(le(PLe,1),it,429,0,[z1e,NLe])}function Vpn(){return pN(),he(le(wLe,1),it,428,0,[XK,vLe])}function Upn(){return JH(),he(le(hLe,1),it,431,0,[lLe,S1e])}function Gpn(){return dN(),he(le(_De,1),it,430,0,[kde,Ede])}function Kpn(){return oA(),he(le(DEt,1),it,531,0,[uM,cM])}function Wpn(){return kV(),he(le(EIe,1),it,501,0,[$W,X6])}function Ypn(){return xd(),he(le(REt,1),it,523,0,[w3,T2])}function Xpn(){return D1(),he(le($Et,1),it,522,0,[wv,Y1])}function Qpn(){return J0(),he(le(tTt,1),it,528,0,[E4,qb])}function Jpn(){return cN(),he(le(kLe,1),it,488,0,[xLe,JK])}function Zpn(){return GH(),he(le(fOe,1),it,491,0,[dge,hOe])}function e2n(){return fce(),he(le(vOe,1),it,492,0,[bOe,mOe])}function t2n(){return RH(),he(le(kIe,1),it,433,0,[Ude,xIe])}function n2n(){return eV(),he(le(CIe,1),it,434,0,[TIe,Qde])}function r2n(){return Sw(),he(le(cTt,1),it,465,0,[Hb,K6])}function i2n(){return rN(),he(le(yOe,1),it,438,0,[vge,QW])}function s2n(){return CN(),he(le(qOe,1),it,437,0,[ZW,zOe])}function a2n(){return mae(),he(le(gY,1),it,347,0,[rPe,iPe])}function IH(e,t,n,r){return n>=0?e.Uh(t,n,r):e.Ch(null,n,r)}function GO(e){return e.b.b==0?e.a.sf():kae(e.b)}function o2n(e){if(e.p!=5)throw ue(new pl);return Yr(e.f)}function c2n(e){if(e.p!=5)throw ue(new pl);return Yr(e.k)}function j5e(e){return qe(e.a)===qe((lce(),npe))&&aMn(e),e.a}function u2n(e,t){e.b=t,e.c>0&&e.b>0&&(e.g=aH(e.c,e.b,e.a))}function l2n(e,t){e.c=t,e.c>0&&e.b>0&&(e.g=aH(e.c,e.b,e.a))}function rot(e,t){ce(this,new lt(e.a,e.b)),ve(this,PO(t))}function Cw(){Qcn.call(this,new N8(Ay(12))),Tye(!0),this.a=2}function coe(e,t,n){Di(),Xv.call(this,e),this.b=t,this.a=n}function $5e(e,t,n){Jh(),Nz.call(this,t),this.a=e,this.b=n}function iot(e){var t;t=e.c.d.b,e.b=t,e.a=e.c.d,t.a=e.c.d.b=e}function h2n(e){return e.b==0?null:(mr(e.b!=0),af(e,e.a.a))}function xu(e,t){return t==null?hc(zo(e.f,null)):y_(e.i,t)}function sot(e,t,n,r,a){return new Bue(e,(rE(),P0e),t,n,r,a)}function OH(e,t){return Gct(t),Pwn(e,We(Vr,di,28,t,15,1),t)}function NH(e,t){return _H(e,"set1"),_H(t,"set2"),new GZe(e,t)}function f2n(e,t){var n=C0e[e.charCodeAt(0)];return n??e}function aot(e,t){var n,r;return n=t,r=new xt,Ovt(e,n,r),r.d}function uoe(e,t,n,r){var a;a=new Frt,t.a[n.g]=a,Q8(e.b,r,a)}function d2n(e,t){var n;return n=Iwn(e.f,t),Oi(Hq(n),e.f.d)}function KO(e){var t;Hwn(e.a),dnt(e.a),t=new e_(e.a),S8e(t)}function g2n(e,t){zbt(e,!0),Vu(e.e.Rf(),new v4e(e,!0,t))}function p2n(e,t){return tx(),e==ds(cg(t))||e==ds(Eb(t))}function b2n(e,t){return tp(),l(Q(t,(Hc(),$d)),17).a==e}function ua(e){return Math.max(Math.min(e,Ii),-2147483648)|0}function oot(e){this.a=l(Xr(e),277),this.b=(Cn(),new Dye(e))}function cot(e,t,n){this.i=new bt,this.b=e,this.g=t,this.a=n}function z5e(e,t,n){this.a=new bt,this.e=e,this.f=t,this.c=n}function PH(e,t,n){this.c=new bt,this.e=e,this.f=t,this.b=n}function uot(e){Vq.call(this),Y6e(this),this.a=e,this.c=!0}function m2n(e){function t(){}return t.prototype=e||{},new t}function v2n(e){if(e.Ae())return null;var t=e.n;return sK[t]}function WO(e){return e.Db>>16!=3?null:l(e.Cb,27)}function M1(e){return e.Db>>16!=9?null:l(e.Cb,27)}function lot(e){return e.Db>>16!=6?null:l(e.Cb,74)}function Sw(){Sw=U,Hb=new H3e(Mx,0),K6=new H3e(Dx,1)}function xd(){xd=U,w3=new $3e(Dx,0),T2=new $3e(Mx,1)}function D1(){D1=U,wv=new z3e(whe,0),Y1=new z3e("UP",1)}function hot(){hot=U,o6t=Kr(($z(),he(le(a6t,1),it,549,0,[E0e])))}function fot(e){var t;return t=new Kz(Ay(e.length)),j7e(t,e),t}function dot(e,t){return e.b+=t.b,e.c+=t.c,e.d+=t.d,e.a+=t.a,e}function w2n(e,t){return Zft(e,t)?(Yht(e),!0):!1}function Wg(e,t){if(t==null)throw ue(new S8);return j5n(e,t)}function YO(e,t){var n;n=e.q.getHours(),e.q.setDate(t),XA(e,n)}function q5e(e,t,n){var r;r=e.Ih(t),r>=0?e.bi(r,n):$9e(e,t,n)}function got(e,t){var n;return n=e.Ih(t),n>=0?e.Wh(n):que(e,t)}function pot(e,t){var n;for(Xr(t),n=e.a;n;n=n.c)t.Yd(n.g,n.i)}function loe(e,t,n){var r;r=w0t(e,t,n),e.b=new TV(r.c.length)}function U5(e,t,n){BH(),e&&ki(Zge,e,t),e&&ki(lF,e,n)}function y2n(e,t){return Yq(),Hn(),l(t.a,17).a0}function H5e(e){var t;return t=e.d,t=e.bj(e.f),qr(e,t),t.Ob()}function bot(e,t){var n;return n=new K4e(t),zgt(n,e),new Ol(n)}function E2n(e){if(e.p!=0)throw ue(new pl);return I_(e.f,0)}function T2n(e){if(e.p!=0)throw ue(new pl);return I_(e.k,0)}function mot(e){return e.Db>>16!=7?null:l(e.Cb,241)}function Qk(e){return e.Db>>16!=6?null:l(e.Cb,241)}function vot(e){return e.Db>>16!=7?null:l(e.Cb,167)}function ds(e){return e.Db>>16!=11?null:l(e.Cb,27)}function ky(e){return e.Db>>16!=17?null:l(e.Cb,29)}function wot(e){return e.Db>>16!=3?null:l(e.Cb,155)}function V5e(e){var t;return xb(e),t=new Ks,Fi(e,new k5(t))}function yot(e,t){var n=e.a=e.a||[];return n[t]||(n[t]=e.ve(t))}function C2n(e,t){var n;n=e.q.getHours(),e.q.setMonth(t),XA(e,n)}function xot(e,t){Fq(this),this.f=t,this.g=e,SH(this),this.je()}function kot(e,t){this.a=e,this.c=Ja(this.a),this.b=new MH(t)}function Eot(e,t,n){this.a=t,this.c=e,this.b=(Xr(n),new Ol(n))}function Tot(e,t,n){this.a=t,this.c=e,this.b=(Xr(n),new Ol(n))}function Cot(e){this.a=e,this.b=We(AEt,dt,2043,e.e.length,0,2)}function Sot(){this.a=new bd,this.e=new Ks,this.g=0,this.i=0}function BH(){BH=U,Zge=new Pr,lF=new Pr,wln(C6t,new LS)}function _ot(){_ot=U,fEt=yl(new Xs,(uo(),mc),(vo(),gB))}function U5e(){U5e=U,dEt=yl(new Xs,(uo(),mc),(vo(),gB))}function Aot(){Aot=U,pEt=yl(new Xs,(uo(),mc),(vo(),gB))}function Lot(){Lot=U,OEt=fi(new Xs,(uo(),mc),(vo(),zL))}function Sh(){Sh=U,BEt=fi(new Xs,(uo(),mc),(vo(),zL))}function Mot(){Mot=U,FEt=fi(new Xs,(uo(),mc),(vo(),zL))}function foe(){foe=U,qEt=fi(new Xs,(uo(),mc),(vo(),zL))}function rA(e,t,n,r,a,o){return new Zg(e.e,t,e.Lj(),n,r,a,o)}function rc(e,t,n){return t==null?ju(e.f,null,n):Bw(e.i,t,n)}function po(e,t){e.c&&al(e.c.g,e),e.c=t,e.c&&vt(e.c.g,e)}function Va(e,t){e.c&&al(e.c.a,e),e.c=t,e.c&&vt(e.c.a,e)}function Mc(e,t){e.i&&al(e.i.j,e),e.i=t,e.i&&vt(e.i.j,e)}function Fa(e,t){e.d&&al(e.d.e,e),e.d=t,e.d&&vt(e.d.e,e)}function doe(e,t){e.a&&al(e.a.k,e),e.a=t,e.a&&vt(e.a.k,e)}function goe(e,t){e.b&&al(e.b.f,e),e.b=t,e.b&&vt(e.b.f,e)}function Dot(e,t){Fgn(e,e.b,e.c),l(e.b.b,68),t&&l(t.b,68).b}function S2n(e,t){return Yi(l(e.c,65).c.e.b,l(t.c,65).c.e.b)}function _2n(e,t){return Yi(l(e.c,65).c.e.a,l(t.c,65).c.e.a)}function A2n(e){return Mce(),Hn(),l(e.a,86).d.e!=0}function FH(e,t){De(e.Cb,184)&&(l(e.Cb,184).tb=null),Fu(e,t)}function poe(e,t){De(e.Cb,90)&&zy(Yl(l(e.Cb,90)),4),Fu(e,t)}function L2n(e,t){m8e(e,t),De(e.Cb,90)&&zy(Yl(l(e.Cb,90)),2)}function M2n(e,t){var n,r;n=t.c,r=n!=null,r&&J8(e,new yy(t.c))}function Iot(e){var t,n;return n=(Sk(),t=new Qv,t),sE(n,e),n}function Oot(e){var t,n;return n=(Sk(),t=new Qv,t),sE(n,e),n}function Not(e){for(var t;;)if(t=e.Pb(),!e.Ob())return t}function D2n(e,t,n){return vt(e.a,(kH(),fue(t,n),new iw(t,n))),e}function ku(e,t){return Fo(),Voe(t)?new nH(t,e):new yO(t,e)}function XO(e){return Cd(),iu(e,0)>=0?kb(e):J_(kb(r2(e)))}function I2n(e){var t;return t=l(eH(e.b),9),new Zh(e.a,t,e.c)}function Pot(e,t){var n;return n=l(Oy(ex(e.a),t),16),n?n.gc():0}function Bot(e,t,n){var r;o1t(t,n,e.c.length),r=n-t,d3e(e.c,t,r)}function Zp(e,t,n){o1t(t,n,e.gc()),this.c=e,this.a=t,this.b=n-t}function nx(e){this.c=new os,this.b=e.b,this.d=e.c,this.a=e.a}function boe(e){this.a=b.Math.cos(e),this.b=b.Math.sin(e)}function Pm(e,t,n,r){this.c=e,this.d=r,doe(this,t),goe(this,n)}function G5e(e,t){Ycn.call(this,new N8(Ay(e))),Mh(t,Dwt),this.a=t}function Fot(e,t,n){return new Bue(e,(rE(),N0e),null,!1,t,n)}function Rot(e,t,n){return new Bue(e,(rE(),B0e),t,n,null,!1)}function O2n(){return Fl(),he(le(oc,1),it,108,0,[y_e,Ec,i4])}function N2n(){return ol(),he(le(X6t,1),it,472,0,[a1,Fb,w0])}function P2n(){return Bl(),he(le(W6t,1),it,471,0,[Fd,Bb,v0])}function B2n(){return t1(),he(le(s4,1),it,237,0,[Gc,$u,Kc])}function F2n(){return lA(),he(le(dAe,1),it,391,0,[t1e,e1e,n1e])}function R2n(){return Ow(),he(le(m1e,1),it,372,0,[o3,Rb,a3])}function j2n(){return dA(),he(le(dLe,1),it,322,0,[HL,mB,fLe])}function $2n(){return pV(),he(le(pLe,1),it,351,0,[gLe,YK,_1e])}function z2n(){return Vm(),he(le(mxt,1),it,460,0,[M1e,FT,P6])}function q2n(){return vE(),he(le($1e,1),it,299,0,[R1e,j1e,vB])}function H2n(){return ep(),he(le(Cxt,1),it,311,0,[wB,F6,Ux])}function V2n(){return EA(),he(le(mDe,1),it,390,0,[pde,bDe,SW])}function U2n(){return qo(),he(le(sEt,1),it,463,0,[sM,$l,zu])}function G2n(){return LV(),he(le(MDe,1),it,387,0,[ADe,Tde,LDe])}function K2n(){return yA(),he(le(DDe,1),it,349,0,[Sde,Cde,MB])}function W2n(){return SE(),he(le(ODe,1),it,350,0,[_de,IDe,aM])}function Y2n(){return gV(),he(le(BDe,1),it,352,0,[PDe,Ade,NDe])}function X2n(){return OV(),he(le(FDe,1),it,388,0,[Lde,XT,k4])}function Q2n(){return Iw(),he(le(SEt,1),it,464,0,[DB,oM,MW])}function I1(e){return Ic(he(le(Ea,1),dt,8,0,[e.i.n,e.n,e.a]))}function J2n(){return xA(),he(le(eIe,1),it,392,0,[ZDe,Ide,OB])}function jot(){jot=U,FTt=yl(new Xs,(wx(),hM),(WA(),VDe))}function RH(){RH=U,Ude=new V3e("DFS",0),xIe=new V3e("BFS",1)}function $ot(e,t,n){var r;r=new hte,r.b=t,r.a=n,++t.b,vt(e.d,r)}function Z2n(e,t,n){var r;r=new Eo(n.d),Oi(r,e),b8e(t,r.a,r.b)}function ebn(e,t){Ont(e,Yr(va(bw(t,24),ZU)),Yr(va(t,ZU)))}function Ey(e,t){if(e<0||e>t)throw ue(new tc(dEe+e+gEe+t))}function Sn(e,t){if(e<0||e>=t)throw ue(new tc(dEe+e+gEe+t))}function Xn(e,t){if(e<0||e>=t)throw ue(new e3e(dEe+e+gEe+t))}function kn(e,t){this.b=(nr(e),e),this.a=t&Xy?t:t|64|_d}function K5e(e){var t;return xb(e),t=(Ew(),Ew(),D0e),lV(e,t)}function tbn(e,t,n){var r;return r=ZA(e,t,!1),r.b<=t&&r.a<=n}function nbn(){return tV(),he(le(pOe,1),it,439,0,[gge,gOe,dOe])}function rbn(){return qV(),he(le(XIe,1),it,394,0,[YIe,uge,WIe])}function ibn(){return WV(),he(le(KIe,1),it,445,0,[RB,VW,rge])}function sbn(){return sU(),he(le(gCt,1),it,456,0,[ige,age,sge])}function abn(){return LN(),he(le(AIe,1),it,393,0,[zW,SIe,_Ie])}function obn(){return AV(),he(le(GIe,1),it,300,0,[nge,UIe,VIe])}function cbn(){return rp(),he(le(YNe,1),it,346,0,[oY,A2,DM])}function ubn(){return PN(),he(le(pge,1),it,444,0,[WW,YW,XW])}function lbn(){return F1(),he(le(FNe,1),it,278,0,[nC,_4,rC])}function hbn(){return dx(),he(le(nPe,1),it,280,0,[tPe,L4,dY])}function _w(e){return Xr(e),De(e,16)?new Ol(l(e,16)):$k(e.Kc())}function W5e(e,t){return e&&e.equals?e.equals(t):qe(e)===qe(t)}function va(e,t){return mb(rgn(wc(e)?Mf(e):e,wc(t)?Mf(t):t))}function Q0(e,t){return mb(ign(wc(e)?Mf(e):e,wc(t)?Mf(t):t))}function moe(e,t){return mb(sgn(wc(e)?Mf(e):e,wc(t)?Mf(t):t))}function fbn(e,t){var n;return n=(nr(e),e).g,qye(!!n),nr(t),n(t)}function zot(e,t){var n,r;return r=Hk(e,t),n=e.a.fd(r),new VZe(e,n)}function dbn(e){return e.Db>>16!=6?null:l(Uue(e),241)}function gbn(e){if(e.p!=2)throw ue(new pl);return Yr(e.f)&Zs}function pbn(e){if(e.p!=2)throw ue(new pl);return Yr(e.k)&Zs}function re(e){return mr(e.ar?1:0}function Uot(e,t){var n,r;return n=$oe(t),r=n,l(cr(e.c,r),17).a}function voe(e,t,n){var r;r=e.d[t.p],e.d[t.p]=e.d[n.p],e.d[n.p]=r}function Sbn(e,t,n){var r;e.n&&t&&n&&(r=new Kne,vt(e.e,r))}function woe(e,t){if(na(e.a,t),t.d)throw ue(new Ac(e3t));t.d=e}function Q5e(e,t){this.a=new bt,this.d=new bt,this.f=e,this.c=t}function Got(){this.c=new Lnt,this.a=new Put,this.b=new UQe,uet()}function Kot(){hx(),this.b=new Pr,this.a=new Pr,this.c=new bt}function Wot(e,t,n){this.d=e,this.j=t,this.e=n,this.o=-1,this.p=3}function Yot(e,t,n){this.d=e,this.k=t,this.f=n,this.o=-1,this.p=5}function Xot(e,t,n,r,a,o){Q6e.call(this,e,t,n,r,a),o&&(this.o=-2)}function Qot(e,t,n,r,a,o){J6e.call(this,e,t,n,r,a),o&&(this.o=-2)}function Jot(e,t,n,r,a,o){p6e.call(this,e,t,n,r,a),o&&(this.o=-2)}function Zot(e,t,n,r,a,o){t7e.call(this,e,t,n,r,a),o&&(this.o=-2)}function ect(e,t,n,r,a,o){b6e.call(this,e,t,n,r,a),o&&(this.o=-2)}function tct(e,t,n,r,a,o){Z6e.call(this,e,t,n,r,a),o&&(this.o=-2)}function nct(e,t,n,r,a,o){e7e.call(this,e,t,n,r,a),o&&(this.o=-2)}function rct(e,t,n,r,a,o){m6e.call(this,e,t,n,r,a),o&&(this.o=-2)}function ict(e,t,n,r){Nz.call(this,n),this.b=e,this.c=t,this.d=r}function sct(e,t){this.f=e,this.a=(eE(),SY),this.c=SY,this.b=t}function act(e,t){this.g=e,this.d=(eE(),_Y),this.a=_Y,this.b=t}function J5e(e,t){!e.c&&(e.c=new Ls(e,0)),HU(e.c,(Gi(),HM),t)}function _bn(e,t){return uTn(e,t,De(t,102)&&(l(t,19).Bb&Io)!=0)}function Abn(e,t){return $st(Zc(e.q.getTime()),Zc(t.q.getTime()))}function oct(e){return Cae(e.e.Rd().gc()*e.c.Rd().gc(),16,new pie(e))}function Lbn(e){return!!e.u&&du(e.u.a).i!=0&&!(e.n&&cue(e.n))}function Mbn(e){return!!e.a&&Xl(e.a.a).i!=0&&!(e.b&&uue(e.b))}function Z5e(e,t){return t==0?!!e.o&&e.o.f!=0:nue(e,t)}function Dbn(e,t,n){var r;return r=l(e.Zb().xc(t),16),!!r&&r.Hc(n)}function cct(e,t,n){var r;return r=l(e.Zb().xc(t),16),!!r&&r.Mc(n)}function uct(e,t){var n;return n=1-t,e.a[n]=EV(e.a[n],n),EV(e,t)}function lct(e,t){var n,r;return r=va(e,Vo),n=l0(t,32),Q0(n,r)}function hct(e,t,n){var r;r=(Xr(e),new Ol(e)),O7n(new Eot(r,t,n))}function QO(e,t,n){var r;r=(Xr(e),new Ol(e)),N7n(new Tot(r,t,n))}function zc(e,t,n,r,a,o){return qft(e,t,n,o),c8e(e,r),u8e(e,a),e}function fct(e,t,n,r){return e.a+=""+tf(t==null?ul:xc(t),n,r),e}function Ua(e,t){this.a=e,kr.call(this,e),Ey(t,e.gc()),this.b=t}function dct(e){this.a=We(wa,Rn,1,P7e(b.Math.max(8,e))<<1,5,1)}function JO(e){return l(j1(e,We(wg,m2,10,e.c.length,0,1)),199)}function kd(e){return l(j1(e,We(u1e,Bhe,18,e.c.length,0,1)),483)}function gct(e){return e.a?e.e.length==0?e.a.a:e.a.a+(""+e.e):e.c}function iA(e){for(;e.d>0&&e.a[--e.d]==0;);e.a[e.d++]==0&&(e.e=0)}function pct(e){return mr(e.b.b!=e.d.a),e.c=e.b=e.b.b,--e.a,e.c.c}function Ibn(e,t,n){e.a=t,e.c=n,e.b.a.$b(),Ch(e.d),ay(e.e.a.c,0)}function bct(e,t){var n;e.e=new Vwe,n=Hy(t),Vs(n,e.c),Mbt(e,n,0)}function Qs(e,t,n,r){var a;a=new J9,a.a=t,a.b=n,a.c=r,ui(e.a,a)}function gt(e,t,n,r){var a;a=new J9,a.a=t,a.b=n,a.c=r,ui(e.b,a)}function mct(e,t,n){if(e<0||tn)throw ue(new tc(U9n(e,t,n)))}function ZO(e,t){if(e<0||e>=t)throw ue(new tc(kkn(e,t)));return e}function Obn(e){if(!("stack"in e))try{throw e}catch{}return e}function G5(e){return p_(),De(e.g,10)?l(e.g,10):null}function Nbn(e){return V5(e).dc()?!1:(rhn(e,new oe),!0)}function Fm(e){var t;return wc(e)?(t=e,t==-0?0:t):Yvn(e)}function vct(e,t){return De(t,44)?gue(e.a,l(t,44)):!1}function wct(e,t){return De(t,44)?gue(e.a,l(t,44)):!1}function yct(e,t){return De(t,44)?gue(e.a,l(t,44)):!1}function e6e(e){var t;return fb(e),t=new Ne,A5(e.a,new x5(t)),t}function t6e(){var e,t,n;return t=(n=(e=new Qv,e),n),vt(RPe,t),t}function jH(e){var t;return fb(e),t=new gn,A5(e.a,new T8(t)),t}function Pbn(e,t){return e.a<=e.b?(t.Dd(e.a++),!0):!1}function xct(e){oce.call(this,e,(rE(),O0e),null,!1,null,!1)}function kct(){kct=U,A7t=Kr((Zz(),he(le(U_e,1),it,489,0,[G0e])))}function Ect(){Ect=U,jDe=pat(pt(1),pt(4)),RDe=pat(pt(1),pt(2))}function Bbn(e,t){return new wae(t,z_(Ja(t.e),e,e),(Hn(),!0))}function $H(e){return new Bu((Mh(e,Fle),cV(bo(bo(5,e),e/10|0))))}function Fbn(e){return Cae(e.e.Rd().gc()*e.c.Rd().gc(),273,new gie(e))}function Tct(e){return l(j1(e,We(F8t,I3t,12,e.c.length,0,1)),2042)}function Rbn(e){return Sh(),!Do(e)&&!(!Do(e)&&e.c.i.c==e.d.i.c)}function jbn(e,t){return ux(),l(Q(t,(Hc(),W6)),17).a>=e.gc()}function sA(e,t){xIn(t,e),N4e(e.d),N4e(l(Q(e,(Nt(),wW)),214))}function yoe(e,t){kIn(t,e),P4e(e.d),P4e(l(Q(e,(Nt(),wW)),214))}function $bn(e,t,n){e.d&&al(e.d.e,e),e.d=t,e.d&&pw(e.d.e,n,e)}function zbn(e,t,n){return n.f.c.length>0?u5e(e.a,t,n):u5e(e.b,t,n)}function qbn(e,t,n){var r;r=s6n();try{return Lfn(e,t,n)}finally{Nmn(r)}}function Aw(e,t){var n,r;return n=Wg(e,t),r=null,n&&(r=n.pe()),r}function aA(e,t){var n,r;return n=Wg(e,t),r=null,n&&(r=n.se()),r}function Jk(e,t){var n,r;return n=_y(e,t),r=null,n&&(r=n.se()),r}function Yg(e,t){var n,r;return n=Wg(e,t),r=null,n&&(r=e9e(n)),r}function Hbn(e,t,n){var r;return r=NE(n),RU(e.g,r,t),RU(e.i,t,n),t}function n6e(e,t,n){this.d=new OYe(this),this.e=e,this.i=t,this.f=n}function Cct(e,t,n,r){this.e=null,this.c=e,this.d=t,this.a=n,this.b=r}function Sct(e,t,n,r){Ent(this),this.c=e,this.e=t,this.f=n,this.b=r}function r6e(e,t,n,r){this.d=e,this.n=t,this.g=n,this.o=r,this.p=-1}function _ct(e,t,n,r){return De(n,59)?new rrt(e,t,n,r):new r5e(e,t,n,r)}function Zk(e){return De(e,16)?l(e,16).dc():!e.Kc().Ob()}function Act(e){if(e.e.g!=e.b)throw ue(new Xh);return!!e.c&&e.d>0}function Br(e){return mr(e.b!=e.d.c),e.c=e.b,e.b=e.b.a,++e.a,e.c.c}function i6e(e,t){nr(t),Ts(e.a,e.c,t),e.c=e.c+1&e.a.length-1,Xdt(e)}function gb(e,t){nr(t),e.b=e.b-1&e.a.length-1,Ts(e.a,e.b,t),Xdt(e)}function Lct(e){var t;t=e.Gh(),this.a=De(t,71)?l(t,71).Ii():t.Kc()}function Vbn(e){return new kn(Lwn(l(e.a.md(),16).gc(),e.a.ld()),16)}function Mct(){Mct=U,UCt=Kr((nq(),he(le(wOe,1),it,490,0,[bge])))}function Dct(){Dct=U,KCt=Kr((rq(),he(le(GCt,1),it,558,0,[mge])))}function Ict(){Ict=U,hSt=Kr((b_(),he(le($Oe,1),it,539,0,[qB])))}function Ubn(){return Km(),he(le(mAe,1),it,389,0,[c4,bAe,o1e,c1e])}function Gbn(){return rE(),he(le(fK,1),it,304,0,[O0e,N0e,P0e,B0e])}function Kbn(){return bx(),he(le(E7t,1),it,332,0,[aB,sB,oB,cB])}function Wbn(){return NA(),he(le(S7t,1),it,406,0,[uB,bK,mK,lB])}function Ybn(){return Pw(),he(le(x7t,1),it,417,0,[iB,rB,V0e,U0e])}function Xbn(){return wE(),he(le(C8t,1),it,416,0,[s3,o4,a4,M6])}function Qbn(){return R1(),he(le(txt,1),it,421,0,[Vx,MT,DT,b1e])}function Jbn(){return IV(),he(le(V8t,1),it,371,0,[p1e,HK,VK,pB])}function Zbn(){return By(),he(le(mde,1),it,203,0,[_W,bde,G6,U6])}function emn(){return Ed(),he(le(SDe,1),it,284,0,[E2,CDe,yde,xde])}function tmn(e){var t;return e.j==(Ct(),Dr)&&(t=v2t(e),vl(t,ar))}function nmn(e,t){var n;n=t.a,po(n,t.c.d),Fa(n,t.d.d),Dy(n.a,e.n)}function s6e(e,t){var n;return n=l(B1(e.b,t),67),!n&&(n=new os),n}function ix(e){return p_(),De(e.g,154)?l(e.g,154):null}function rmn(e){e.a=null,e.e=null,ay(e.b.c,0),ay(e.f.c,0),e.c=null}function zH(){zH=U,z1e=new F3e(cT,0),NLe=new F3e("TOP_LEFT",1)}function oA(){oA=U,uM=new j3e("UPPER",0),cM=new j3e("LOWER",1)}function imn(e,t){return z8(new lt(t.e.a+t.f.a/2,t.e.b+t.f.b/2),e)}function Oct(e,t){return l(fh(vy(l($i(e.k,t),15).Oc(),I6)),113)}function Nct(e,t){return l(fh(Y8(l($i(e.k,t),15).Oc(),I6)),113)}function smn(){return wx(),he(le(qDe,1),it,405,0,[NW,lM,hM,fM])}function amn(){return kA(),he(le(yIe,1),it,353,0,[Vde,jW,Hde,qde])}function omn(){return uU(),he(le(HIe,1),it,354,0,[tge,zIe,qIe,$Ie])}function cmn(){return mh(),he(le(BM,1),it,386,0,[iF,Cv,rF,A4])}function umn(){return Ih(),he(le(JSt,1),it,291,0,[eF,kg,Gb,ZB])}function lmn(){return ip(),he(le(Vge,1),it,223,0,[Hge,JB,iC,s9])}function hmn(){return VV(),he(le(cPe,1),it,320,0,[Kge,sPe,oPe,aPe])}function fmn(){return NV(),he(le(p_t,1),it,415,0,[Wge,lPe,uPe,hPe])}function dmn(e){return BH(),Hu(Zge,e)?l(cr(Zge,e),341).Qg():null}function nf(e,t,n){return t<0?que(e,n):l(n,69).wk().Bk(e,e.hi(),t)}function gmn(e,t,n){var r;return r=NE(n),RU(e.j,r,t),ki(e.k,t,n),t}function pmn(e,t,n){var r;return r=NE(n),RU(e.d,r,t),ki(e.e,t,n),t}function Pct(e){var t,n;return t=(rb(),n=new TI,n),e&&AU(t,e),t}function a6e(e){var t;return t=e.aj(e.i),e.i>0&&pu(e.g,0,t,0,e.i),t}function Bct(e,t){var n;for(n=e.j.c.length;n>24}function mmn(e){if(e.p!=1)throw ue(new pl);return Yr(e.k)<<24>>24}function vmn(e){if(e.p!=7)throw ue(new pl);return Yr(e.k)<<16>>16}function wmn(e){if(e.p!=7)throw ue(new pl);return Yr(e.f)<<16>>16}function K5(e,t){return t.e==0||e.e==0?BL:(GE(),Que(e,t))}function jct(e,t){return qe(t)===qe(e)?"(this Map)":t==null?ul:xc(t)}function ymn(e,t,n){return Nae(Ge(hc(zo(e.f,t))),Ge(hc(zo(e.f,n))))}function xmn(e,t,n){var r;r=l(cr(e.g,n),60),vt(e.a.c,new ca(t,r))}function $ct(e,t,n){e.i=0,e.e=0,t!=n&&(k0t(e,t,n),x0t(e,t,n))}function kmn(e,t,n,r,a){var o;o=ETn(a,n,r),vt(t,pkn(a,o)),a9n(e,a,t)}function o6e(e,t,n,r,a){this.i=e,this.a=t,this.e=n,this.j=r,this.f=a}function zct(e,t){R5e.call(this),this.a=e,this.b=t,vt(this.a.b,this)}function qct(e){this.b=new Pr,this.c=new Pr,this.d=new Pr,this.a=e}function Hct(e,t){var n;return n=new S5,e.Gd(n),n.a+="..",t.Hd(n),n.a}function Vct(e,t){var n;for(n=t;n;)dw(e,n.i,n.j),n=ds(n);return e}function Uct(e,t,n){var r;return r=NE(n),ki(e.b,r,t),ki(e.c,t,n),t}function Xg(e){var t;for(t=0;e.Ob();)e.Pb(),t=bo(t,1);return cV(t)}function sg(e,t){Fo();var n;return n=l(e,69).vk(),k9n(n,t),n.xl(t)}function Emn(e,t,n){if(n){var r=n.oe();e.a[t]=r(n)}else delete e.a[t]}function c6e(e,t){var n;n=e.q.getHours(),e.q.setFullYear(t+Lb),XA(e,n)}function Tmn(e,t){return l(t==null?hc(zo(e.f,null)):y_(e.i,t),288)}function u6e(e,t){return e==(Zn(),Ps)&&t==Ps?4:e==Ps||t==Ps?8:32}function qH(e,t,n){return $U(e,t,n,De(t,102)&&(l(t,19).Bb&Io)!=0)}function Cmn(e,t,n){return XE(e,t,n,De(t,102)&&(l(t,19).Bb&Io)!=0)}function Smn(e,t,n){return bTn(e,t,n,De(t,102)&&(l(t,19).Bb&Io)!=0)}function l6e(e){e.b!=e.c&&(e.a=We(wa,Rn,1,8,5,1),e.b=0,e.c=0)}function cA(e){return mr(e.a=0&&e.a[n]===t[n];n--);return n<0}function HH(e){var t;return e?new K4e(e):(t=new bd,sce(t,e),t)}function Omn(e,t){var n,r;r=!1;do n=h0t(e,t),r=r|n;while(n);return r}function Nmn(e){e&&awn((Xwe(),GSe)),--aK,e&&oK!=-1&&(Cln(oK),oK=-1)}function VH(e){Rxe(),Ont(this,Yr(va(bw(e,24),ZU)),Yr(va(e,ZU)))}function Xct(){Xct=U,q6t=Kr((ZV(),he(le(k_e,1),it,436,0,[j0e,x_e])))}function Qct(){Qct=U,H6t=Kr((aV(),he(le(T_e,1),it,435,0,[E_e,$0e])))}function Jct(){Jct=U,U7t=Kr((oV(),he(le(J_e,1),it,432,0,[Q0e,yK])))}function Zct(){Zct=U,z8t=Kr((dE(),he(le($8t,1),it,517,0,[dB,h1e])))}function eut(){eut=U,_xt=Kr((zH(),he(le(PLe,1),it,429,0,[z1e,NLe])))}function tut(){tut=U,bxt=Kr((pN(),he(le(wLe,1),it,428,0,[XK,vLe])))}function nut(){nut=U,yxt=Kr((cN(),he(le(kLe,1),it,488,0,[xLe,JK])))}function rut(){rut=U,iEt=Kr((dN(),he(le(_De,1),it,430,0,[kde,Ede])))}function iut(){iut=U,IEt=Kr((oA(),he(le(DEt,1),it,531,0,[uM,cM])))}function sut(){sut=U,fxt=Kr((JH(),he(le(hLe,1),it,431,0,[lLe,S1e])))}function aut(){aut=U,BTt=Kr((RH(),he(le(kIe,1),it,433,0,[Ude,xIe])))}function out(){out=U,zTt=Kr((kV(),he(le(EIe,1),it,501,0,[$W,X6])))}function cut(){cut=U,jEt=Kr((xd(),he(le(REt,1),it,523,0,[w3,T2])))}function uut(){uut=U,zEt=Kr((D1(),he(le($Et,1),it,522,0,[wv,Y1])))}function lut(){lut=U,nTt=Kr((J0(),he(le(tTt,1),it,528,0,[E4,qb])))}function hut(){hut=U,uTt=Kr((Sw(),he(le(cTt,1),it,465,0,[Hb,K6])))}function fut(){fut=U,VTt=Kr((eV(),he(le(CIe,1),it,434,0,[TIe,Qde])))}function dut(){dut=U,jCt=Kr((GH(),he(le(fOe,1),it,491,0,[dge,hOe])))}function gut(){gut=U,zCt=Kr((fce(),he(le(vOe,1),it,492,0,[bOe,mOe])))}function put(){put=U,WCt=Kr((rN(),he(le(yOe,1),it,438,0,[vge,QW])))}function but(){but=U,fSt=Kr((CN(),he(le(qOe,1),it,437,0,[ZW,zOe])))}function mut(){mut=U,f_t=Kr((mae(),he(le(gY,1),it,347,0,[rPe,iPe])))}function Pmn(){return Js(),he(le(LM,1),it,88,0,[J1,vc,uc,Q1,wf])}function Bmn(){return Ct(),he(le(Oo,1),au,64,0,[Pc,Qn,ar,Dr,er])}function Fmn(e,t,n){return l(t==null?ju(e.f,null,n):Bw(e.i,t,n),288)}function Rmn(e){return(e.k==(Zn(),Ps)||e.k==Us)&&ns(e,(ft(),KL))}function Coe(e){return e.c&&e.d?X5e(e.c)+"->"+X5e(e.d):"e_"+fw(e)}function to(e,t){var n,r;for(nr(t),r=e.Kc();r.Ob();)n=r.Pb(),t.Cd(n)}function jmn(e,t){var n;n=new M8,Nm(n,"x",t.a),Nm(n,"y",t.b),J8(e,n)}function $mn(e,t){var n;n=new M8,Nm(n,"x",t.a),Nm(n,"y",t.b),J8(e,n)}function vut(e,t){var n;for(n=t;n;)dw(e,-n.i,-n.j),n=ds(n);return e}function f6e(e,t){var n,r;for(n=t,r=0;n>0;)r+=e.a[n],n-=n&-n;return r}function rf(e,t,n){var r;return r=(Sn(t,e.c.length),e.c[t]),e.c[t]=n,r}function d6e(e,t,n){e.a.c.length=0,hMn(e,t,n),e.a.c.length==0||j_n(e,t)}function eN(e){e.i=0,aO(e.b,null),aO(e.c,null),e.a=null,e.e=null,++e.g}function UH(){UH=U,G1=!0,I6t=!1,O6t=!1,P6t=!1,N6t=!1}function Soe(e){UH(),!G1&&(this.c=e,this.e=!0,this.a=new bt)}function wut(e,t){this.c=0,this.b=t,qtt.call(this,e,17493),this.a=this.c}function yut(e){kwt(),SQe(this),this.a=new os,G7e(this,e),ui(this.a,e)}function xut(){Yse(this),this.b=new lt(gs,gs),this.a=new lt(ia,ia)}function GH(){GH=U,dge=new K3e(HEe,0),hOe=new K3e("TARGET_WIDTH",1)}function W5(e,t){return(xb(e),_k(new bn(e,new $6e(t,e.a)))).Bd(zx)}function zmn(){return uo(),he(le(gAe,1),it,367,0,[y0,vg,bu,_u,mc])}function qmn(){return Ry(),he(le(rxt,1),it,375,0,[bB,KK,WK,GK,UK])}function Hmn(){return l2(),he(le(mLe,1),it,348,0,[A1e,bLe,L1e,BT,PT])}function Vmn(){return OA(),he(le(wDe,1),it,323,0,[vDe,vde,wde,rM,iM])}function Umn(){return hf(),he(le(WLe,1),it,171,0,[EB,YL,$b,XL,d4])}function Gmn(){return bU(),he(le(qTt,1),it,368,0,[Yde,Gde,Xde,Kde,Wde])}function Kmn(){return VA(),he(le(qCt,1),it,373,0,[Q6,e9,xM,yM,zB])}function Wmn(){return XN(),he(le(TOe,1),it,324,0,[xOe,wge,EOe,yge,kOe])}function Ymn(){return r1(),he(le(xg,1),it,170,0,[Pn,ha,zd,yv,S2])}function Xmn(){return t6(),he(le(OM,1),it,256,0,[Kb,tF,XNe,IM,QNe])}function Qmn(e){return Hz(),function(){return qbn(e,this,arguments)}}function Do(e){return!e.c||!e.d?!1:!!e.c.i&&e.c.i==e.d.i}function g6e(e,t){return De(t,143)?vn(e.c,l(t,143).c):!1}function Yl(e){return e.t||(e.t=new bQe(e),_A(new IJe(e),0,e.t)),e.t}function kut(e){this.b=e,or.call(this,e),this.a=l(Kn(this.b.a,4),129)}function Eut(e){this.b=e,H8.call(this,e),this.a=l(Kn(this.b.a,4),129)}function h0(e,t,n,r,a){Out.call(this,t,r,a),this.c=e,this.b=n}function p6e(e,t,n,r,a){Wot.call(this,t,r,a),this.c=e,this.a=n}function b6e(e,t,n,r,a){Yot.call(this,t,r,a),this.c=e,this.a=n}function m6e(e,t,n,r,a){Out.call(this,t,r,a),this.c=e,this.a=n}function _oe(e,t){var n;return n=l(B1(e.d,t),23),n||l(B1(e.e,t),23)}function Tut(e,t){var n,r;return n=t.ld(),r=e.Fe(n),!!r&&Jc(r.e,t.md())}function Cut(e,t){var n;return n=t.ld(),new iw(n,e.e.pc(n,l(t.md(),16)))}function Jmn(e,t){var n;return n=e.a.get(t),n??We(wa,Rn,1,0,5,1)}function Sut(e){var t;return t=e.length,vn(sr.substr(sr.length-t,t),e)}function xr(e){if(jr(e))return e.c=e.a,e.a.Pb();throw ue(new _c)}function v6e(e,t){return t==0||e.e==0?e:t>0?pbt(e,t):j1t(e,-t)}function sx(e,t){return t==0||e.e==0?e:t>0?j1t(e,t):pbt(e,-t)}function w6e(e){uln.call(this,e==null?ul:xc(e),De(e,82)?l(e,82):null)}function _ut(e){var t;return e.c||(t=e.r,De(t,90)&&(e.c=l(t,29))),e.c}function Aoe(e){var t;return t=new Tw,pc(t,e),rt(t,(Nt(),cc),null),t}function Aut(e){var t,n;return t=e.c.i,n=e.d.i,t.k==(Zn(),Us)&&n.k==Us}function Loe(e){var t,n,r;return t=e&eh,n=e>>22&eh,r=e<0?hp:0,qu(t,n,r)}function Zmn(e){var t,n,r,a;for(n=e,r=0,a=n.length;r=0?e.Lh(r,n,!0):Hw(e,t,n)}function tvn(e,t,n){return Yi(z8(BE(e),Ja(t.b)),z8(BE(e),Ja(n.b)))}function nvn(e,t,n){return Yi(z8(BE(e),Ja(t.e)),z8(BE(e),Ja(n.e)))}function rvn(e,t){return b.Math.min(pb(t.a,e.d.d.c),pb(t.b,e.d.d.c))}function tN(e,t){e._i(e.i+1),R_(e,e.i,e.Zi(e.i,t)),e.Mi(e.i++,t),e.Ni()}function uA(e){var t,n;++e.j,t=e.g,n=e.i,e.g=null,e.i=0,e.Oi(n,t),e.Ni()}function Lut(e,t,n){var r;r=new vye(e.a),bA(r,e.a.a),ju(r.f,t,n),e.a.a=r}function y6e(e,t,n,r){var a;for(a=0;at)throw ue(new tc(u9e(e,t,"index")));return e}function t2(e,t){var n;return n=(Sn(t,e.c.length),e.c[t]),d3e(e.c,t,1),n}function E6e(e,t){var n,r;return n=(nr(e),e),r=(nr(t),t),n==r?0:nt.p?-1:0}function Fut(e){var t;return e.a||(t=e.r,De(t,156)&&(e.a=l(t,156))),e.a}function uvn(e,t,n){var r;return++e.e,--e.f,r=l(e.d[t].gd(n),136),r.md()}function lvn(e){var t,n;return t=e.ld(),n=l(e.md(),16),NO(n.Nc(),new bie(t))}function Rut(e,t){return Hu(e.a,t)?(ax(e.a,t),!0):!1}function ox(e,t,n){return ZO(t,e.e.Rd().gc()),ZO(n,e.c.Rd().gc()),e.a[t][n]}function WH(e,t,n){this.a=e,this.b=t,this.c=n,vt(e.t,this),vt(t.i,this)}function YH(e,t,n,r){this.f=e,this.e=t,this.d=n,this.b=r,this.c=r?r.d:null}function nN(){this.b=new os,this.a=new os,this.b=new os,this.a=new os}function eE(){eE=U;var e,t;SY=(Sk(),t=new Fz,t),_Y=(e=new zie,e)}function hvn(e){var t;return xb(e),t=new Mit(e,e.a.e,e.a.d|4),new Vye(e,t)}function jut(e){var t;for(fb(e),t=0;e.a.Bd(new An);)t=bo(t,1);return t}function XH(e,t){return nr(t),e.c=0,"Initial capacity must not be negative")}function QH(){QH=U,kM=new Ui("org.eclipse.elk.labels.labelManager")}function $ut(){$ut=U,sLe=new vs("separateLayerConnections",(IV(),p1e))}function J0(){J0=U,E4=new q3e("REGULAR",0),qb=new q3e("CRITICAL",1)}function rN(){rN=U,vge=new Y3e("FIXED",0),QW=new Y3e("CENTER_NODE",1)}function JH(){JH=U,lLe=new N3e("QUADRATIC",0),S1e=new N3e("SCANLINE",1)}function zut(){zut=U,dxt=Kr((dA(),he(le(dLe,1),it,322,0,[HL,mB,fLe])))}function qut(){qut=U,gxt=Kr((pV(),he(le(pLe,1),it,351,0,[gLe,YK,_1e])))}function Hut(){Hut=U,uxt=Kr((Ow(),he(le(m1e,1),it,372,0,[o3,Rb,a3])))}function Vut(){Vut=U,vxt=Kr((Vm(),he(le(mxt,1),it,460,0,[M1e,FT,P6])))}function Uut(){Uut=U,Txt=Kr((vE(),he(le($1e,1),it,299,0,[R1e,j1e,vB])))}function Gut(){Gut=U,Sxt=Kr((ep(),he(le(Cxt,1),it,311,0,[wB,F6,Ux])))}function Kut(){Kut=U,Zkt=Kr((EA(),he(le(mDe,1),it,390,0,[pde,bDe,SW])))}function Wut(){Wut=U,oEt=Kr((LV(),he(le(MDe,1),it,387,0,[ADe,Tde,LDe])))}function Yut(){Yut=U,cEt=Kr((yA(),he(le(DDe,1),it,349,0,[Sde,Cde,MB])))}function Xut(){Xut=U,aEt=Kr((qo(),he(le(sEt,1),it,463,0,[sM,$l,zu])))}function Qut(){Qut=U,uEt=Kr((SE(),he(le(ODe,1),it,350,0,[_de,IDe,aM])))}function Jut(){Jut=U,lEt=Kr((gV(),he(le(BDe,1),it,352,0,[PDe,Ade,NDe])))}function Zut(){Zut=U,hEt=Kr((OV(),he(le(FDe,1),it,388,0,[Lde,XT,k4])))}function elt(){elt=U,fTt=Kr((xA(),he(le(eIe,1),it,392,0,[ZDe,Ide,OB])))}function tlt(){tlt=U,UTt=Kr((LN(),he(le(AIe,1),it,393,0,[zW,SIe,_Ie])))}function nlt(){nlt=U,fCt=Kr((AV(),he(le(GIe,1),it,300,0,[nge,UIe,VIe])))}function rlt(){rlt=U,dCt=Kr((WV(),he(le(KIe,1),it,445,0,[RB,VW,rge])))}function ilt(){ilt=U,pCt=Kr((sU(),he(le(gCt,1),it,456,0,[ige,age,sge])))}function slt(){slt=U,vCt=Kr((qV(),he(le(XIe,1),it,394,0,[YIe,uge,WIe])))}function alt(){alt=U,$Ct=Kr((tV(),he(le(pOe,1),it,439,0,[gge,gOe,dOe])))}function olt(){olt=U,_Et=Kr((Iw(),he(le(SEt,1),it,464,0,[DB,oM,MW])))}function clt(){clt=U,Y6t=Kr((Bl(),he(le(W6t,1),it,471,0,[Fd,Bb,v0])))}function ult(){ult=U,K6t=Kr((t1(),he(le(s4,1),it,237,0,[Gc,$u,Kc])))}function llt(){llt=U,Q6t=Kr((ol(),he(le(X6t,1),it,472,0,[a1,Fb,w0])))}function hlt(){hlt=U,B6t=Kr((Fl(),he(le(oc,1),it,108,0,[y_e,Ec,i4])))}function flt(){flt=U,m8t=Kr((lA(),he(le(dAe,1),it,391,0,[t1e,e1e,n1e])))}function dlt(){dlt=U,QSt=Kr((rp(),he(le(YNe,1),it,346,0,[oY,A2,DM])))}function glt(){glt=U,VCt=Kr((PN(),he(le(pge,1),it,444,0,[WW,YW,XW])))}function plt(){plt=U,KSt=Kr((F1(),he(le(FNe,1),it,278,0,[nC,_4,rC])))}function blt(){blt=U,h_t=Kr((dx(),he(le(nPe,1),it,280,0,[tPe,L4,dY])))}function P1(e,t){return!e.o&&(e.o=new xl((su(),Cg),L2,e,0)),Kce(e.o,t)}function fvn(e,t){var n;e.C&&(n=l(Qo(e.b,t),127).n,n.d=e.C.d,n.a=e.C.a)}function A6e(e){var t,n,r,a;a=e.d,t=e.a,n=e.b,r=e.c,e.d=n,e.a=r,e.b=a,e.c=t}function dvn(e){return!e.g&&(e.g=new MS),!e.g.b&&(e.g.b=new fQe(e)),e.g.b}function iN(e){return!e.g&&(e.g=new MS),!e.g.c&&(e.g.c=new pQe(e)),e.g.c}function gvn(e){return!e.g&&(e.g=new MS),!e.g.d&&(e.g.d=new dQe(e)),e.g.d}function pvn(e){return!e.g&&(e.g=new MS),!e.g.a&&(e.g.a=new gQe(e)),e.g.a}function bvn(e,t,n,r){return n&&(r=n.Rh(t,ms(n.Dh(),e.c.uk()),null,r)),r}function mvn(e,t,n,r){return n&&(r=n.Th(t,ms(n.Dh(),e.c.uk()),null,r)),r}function Ooe(e,t,n,r){var a;return a=We(Vr,di,28,t+1,15,1),xAn(a,e,t,n,r),a}function We(e,t,n,r,a,o){var f;return f=zdt(a,r),a!=10&&he(le(e,o),t,n,a,f),f}function vvn(e,t,n){var r,a;for(a=new mE(t,e),r=0;rn||t=0?e.Lh(n,!0,!0):Hw(e,t,!0)}function Pvn(e,t,n){var r;return r=w0t(e,t,n),e.b=new TV(r.c.length),Q9e(e,r)}function Bvn(e){if(e.b<=0)throw ue(new _c);return--e.b,e.a-=e.c.c,pt(e.a)}function Fvn(e){var t;if(!e.a)throw ue(new Lat);return t=e.a,e.a=ds(e.a),t}function Rvn(e){for(;!e.a;)if(!tit(e.c,new ZS(e)))return!1;return!0}function cx(e){var t;return Xr(e),De(e,204)?(t=l(e,204),t):new w8(e)}function jvn(e){ZH(),l(e.of((pi(),S4)),181).Fc((Rl(),nF)),e.qf($ge,null)}function ZH(){ZH=U,pSt=new l$,mSt=new h$,bSt=_yn((pi(),$ge),pSt,Ub,mSt)}function eV(){eV=U,TIe=new G3e("LEAF_NUMBER",0),Qde=new G3e("NODE_SIZE",1)}function Roe(e){e.a=We(Vr,di,28,e.b+1,15,1),e.c=We(Vr,di,28,e.b,15,1),e.d=0}function $vn(e,t){e.a.Ne(t.d,e.b)>0&&(vt(e.c,new L4e(t.c,t.d,e.d)),e.b=t.d)}function R6e(e,t){if(e.g==null||t>=e.i)throw ue(new Vse(t,e.i));return e.g[t]}function ylt(e,t,n){if(EE(e,n),n!=null&&!e.fk(n))throw ue(new Rie);return n}function joe(e,t){return gN(t)!=10&&he(bh(t),t.Sm,t.__elementTypeId$,gN(t),e),e}function nE(e,t,n,r){var a;r=(Ew(),r||d_e),a=e.slice(t,n),l9e(a,e,t,n,-t,r)}function sf(e,t,n,r,a){return t<0?Hw(e,n,r):l(n,69).wk().yk(e,e.hi(),t,r,a)}function zvn(e,t){return Yi(ze(Ge(Q(e,(ft(),l3)))),ze(Ge(Q(t,l3))))}function xlt(){xlt=U,M6t=Kr((rE(),he(le(fK,1),it,304,0,[O0e,N0e,P0e,B0e])))}function rE(){rE=U,O0e=new oq("All",0),N0e=new hnt,P0e=new ynt,B0e=new lnt}function Bl(){Bl=U,Fd=new pse(Mx,0),Bb=new pse(cT,1),v0=new pse(Dx,2)}function klt(){klt=U,zU(),GPe=gs,vAt=ia,KPe=new pa(gs),wAt=new pa(ia)}function Elt(){Elt=U,k7t=Kr((Pw(),he(le(x7t,1),it,417,0,[iB,rB,V0e,U0e])))}function Tlt(){Tlt=U,_7t=Kr((NA(),he(le(S7t,1),it,406,0,[uB,bK,mK,lB])))}function Clt(){Clt=U,T7t=Kr((bx(),he(le(E7t,1),it,332,0,[aB,sB,oB,cB])))}function Slt(){Slt=U,I8t=Kr((Km(),he(le(mAe,1),it,389,0,[c4,bAe,o1e,c1e])))}function _lt(){_lt=U,S8t=Kr((wE(),he(le(C8t,1),it,416,0,[s3,o4,a4,M6])))}function Alt(){Alt=U,nxt=Kr((R1(),he(le(txt,1),it,421,0,[Vx,MT,DT,b1e])))}function Llt(){Llt=U,U8t=Kr((IV(),he(le(V8t,1),it,371,0,[p1e,HK,VK,pB])))}function Mlt(){Mlt=U,eEt=Kr((By(),he(le(mde,1),it,203,0,[_W,bde,G6,U6])))}function Dlt(){Dlt=U,rEt=Kr((Ed(),he(le(SDe,1),it,284,0,[E2,CDe,yde,xde])))}function cN(){cN=U,xLe=new B3e(Id,0),JK=new B3e("IMPROVE_STRAIGHTNESS",1)}function Ilt(e,t){var n,r;return r=t/e.c.Rd().gc()|0,n=t%e.c.Rd().gc(),ox(e,r,n)}function Olt(e){var t;if(e.nl())for(t=e.i-1;t>=0;--t)Oe(e,t);return a6e(e)}function j6e(e){var t,n;if(!e.b)return null;for(n=e.b;t=n.a[0];)n=t;return n}function Nlt(e){var t,n;if(!e.b)return null;for(n=e.b;t=n.a[1];)n=t;return n}function qvn(e){return De(e,180)?""+l(e,180).a:e==null?null:xc(e)}function Hvn(e){return De(e,180)?""+l(e,180).a:e==null?null:xc(e)}function Plt(e,t){if(t.a)throw ue(new Ac(e3t));na(e.a,t),t.a=e,!e.j&&(e.j=t)}function $6e(e,t){Dq.call(this,t.zd(),t.yd()&-16449),nr(e),this.a=e,this.c=t}function Vvn(e,t){return new wae(t,dw(Ja(t.e),t.f.a+e,t.f.b+e),(Hn(),!1))}function Uvn(e,t){return jk(),vt(e,new ca(t,pt(t.e.c.length+t.g.c.length)))}function Gvn(e,t){return jk(),vt(e,new ca(t,pt(t.e.c.length+t.g.c.length)))}function Blt(){Blt=U,hCt=Kr((uU(),he(le(HIe,1),it,354,0,[tge,zIe,qIe,$Ie])))}function Flt(){Flt=U,PTt=Kr((kA(),he(le(yIe,1),it,353,0,[Vde,jW,Hde,qde])))}function Rlt(){Rlt=U,lTt=Kr((wx(),he(le(qDe,1),it,405,0,[NW,lM,hM,fM])))}function jlt(){jlt=U,WSt=Kr((ip(),he(le(Vge,1),it,223,0,[Hge,JB,iC,s9])))}function $lt(){$lt=U,ZSt=Kr((Ih(),he(le(JSt,1),it,291,0,[eF,kg,Gb,ZB])))}function zlt(){zlt=U,u_t=Kr((mh(),he(le(BM,1),it,386,0,[iF,Cv,rF,A4])))}function qlt(){qlt=U,d_t=Kr((VV(),he(le(cPe,1),it,320,0,[Kge,sPe,oPe,aPe])))}function Hlt(){Hlt=U,b_t=Kr((NV(),he(le(p_t,1),it,415,0,[Wge,lPe,uPe,hPe])))}function tV(){tV=U,gge=new jse(vyt,0),gOe=new jse(cCe,1),dOe=new jse(Id,2)}function Sy(e,t,n,r,a){return nr(e),nr(t),nr(n),nr(r),nr(a),new h5e(e,t,r)}function Vlt(e,t){var n;return n=l(ax(e.e,t),400),n?($4e(n),n.e):null}function al(e,t){var n;return n=gc(e,t,0),n==-1?!1:(t2(e,n),!0)}function Ult(e,t,n){var r;return fb(e),r=new on,r.a=t,e.a.Nb(new Cet(r,n)),r.a}function Kvn(e){var t;return fb(e),t=We(Na,Zo,28,0,15,1),A5(e.a,new E8(t)),t}function z6e(e){var t;if(!tce(e))throw ue(new _c);return e.e=1,t=e.d,e.d=null,t}function r2(e){var t;return wc(e)&&(t=0-e,!isNaN(t))?t:mb(xE(e))}function gc(e,t,n){for(;n=0?rU(e,n,!0,!0):Hw(e,t,!0)}function H6e(e){var t;return t=jm(Kn(e,32)),t==null&&(Ku(e),t=jm(Kn(e,32))),t}function V6e(e){var t;return e.Oh()||(t=yr(e.Dh())-e.ji(),e.$h().Mk(t)),e.zh()}function Qlt(e,t){H_e=new Ot,C7t=t,RL=e,l(RL.b,68),D6e(RL,H_e,null),fvt(RL)}function lA(){lA=U,t1e=new mse("XY",0),e1e=new mse("X",1),n1e=new mse("Y",2)}function ol(){ol=U,a1=new bse("TOP",0),Fb=new bse(cT,1),w0=new bse(xEe,2)}function ep(){ep=U,wB=new Ese(Id,0),F6=new Ese("TOP",1),Ux=new Ese(xEe,2)}function dN(){dN=U,kde=new R3e("INPUT_ORDER",0),Ede=new R3e("PORT_DEGREE",1)}function iE(){iE=U,WSe=qu(eh,eh,524287),g6t=qu(0,0,SP),YSe=Loe(1),Loe(2),XSe=Loe(0)}function Voe(e){var t;return e.d!=e.r&&(t=Of(e),e.e=!!t&&t.lk()==g5t,e.d=t),e.e}function Uoe(e,t,n){var r;return r=e.g[t],R_(e,t,e.Zi(t,n)),e.Ri(t,n,r),e.Ni(),r}function sV(e,t){var n;return n=e.dd(t),n>=0?(e.gd(n),!0):!1}function Goe(e,t){var n;for(Xr(e),Xr(t),n=!1;t.Ob();)n=n|e.Fc(t.Pb());return n}function B1(e,t){var n;return n=l(cr(e.e,t),400),n?(Int(e,n),n.e):null}function Jlt(e){var t,n;return t=e/60|0,n=e%60,n==0?""+t:""+t+":"+(""+n)}function _y(e,t){var n=e.a[t],r=(vce(),_0e)[typeof n];return r?r(n):Z7e(typeof n)}function Dc(e,t){var n,r;return xb(e),r=new C6e(t,e.a),n=new iit(r),new bn(e,n)}function Koe(e){var t;return t=e.b.c.length==0?null:jt(e.b,0),t!=null&&rce(e,0),t}function Qvn(e,t){var n,r,a;a=t.c.i,n=l(cr(e.f,a),60),r=n.d.c-n.e.c,k7e(t.a,r,0)}function U6e(e,t){var n;for(++e.d,++e.c[t],n=t+1;n=0;)++t[0]}function Jvn(e,t){Uu(e,t==null||Gq((nr(t),t))||isNaN((nr(t),t))?0:(nr(t),t))}function Zvn(e,t){Gu(e,t==null||Gq((nr(t),t))||isNaN((nr(t),t))?0:(nr(t),t))}function ewn(e,t){Dw(e,t==null||Gq((nr(t),t))||isNaN((nr(t),t))?0:(nr(t),t))}function twn(e,t){Mw(e,t==null||Gq((nr(t),t))||isNaN((nr(t),t))?0:(nr(t),t))}function nwn(e,t,n){return z8(new lt(n.e.a+n.f.a/2,n.e.b+n.f.b/2),e)==(nr(t),t)}function rwn(e,t){return De(t,102)&&l(t,19).Bb&Io?new Use(t,e):new mE(t,e)}function iwn(e,t){return De(t,102)&&l(t,19).Bb&Io?new Use(t,e):new mE(t,e)}function gN(e){return e.__elementTypeCategory$==null?10:e.__elementTypeCategory$}function tht(e,t){return t==(gae(),gae(),_6t)?e.toLocaleLowerCase():e.toLowerCase()}function nht(e){if(!e.e)throw ue(new _c);return e.c=e.a=e.e,e.e=e.e.e,--e.d,e.a.f}function G6e(e){if(!e.c)throw ue(new _c);return e.e=e.a=e.c,e.c=e.c.c,++e.d,e.a.f}function rht(e){var t;for(++e.a,t=e.c.a.length;e.ae.a[r]&&(r=n);return r}function iht(e){var t;return t=l(Q(e,(ft(),c3)),313),t?t.a==e:!1}function sht(e){var t;return t=l(Q(e,(ft(),c3)),313),t?t.i==e:!1}function aht(){aht=U,x8t=Kr((uo(),he(le(gAe,1),it,367,0,[y0,vg,bu,_u,mc])))}function oht(){oht=U,ixt=Kr((Ry(),he(le(rxt,1),it,375,0,[bB,KK,WK,GK,UK])))}function cht(){cht=U,pxt=Kr((l2(),he(le(mLe,1),it,348,0,[A1e,bLe,L1e,BT,PT])))}function uht(){uht=U,tEt=Kr((OA(),he(le(wDe,1),it,323,0,[vDe,vde,wde,rM,iM])))}function lht(){lht=U,Axt=Kr((hf(),he(le(WLe,1),it,171,0,[EB,YL,$b,XL,d4])))}function hht(){hht=U,HTt=Kr((bU(),he(le(qTt,1),it,368,0,[Yde,Gde,Xde,Kde,Wde])))}function fht(){fht=U,HCt=Kr((VA(),he(le(qCt,1),it,373,0,[Q6,e9,xM,yM,zB])))}function dht(){dht=U,YCt=Kr((XN(),he(le(TOe,1),it,324,0,[xOe,wge,EOe,yge,kOe])))}function ght(){ght=U,GSt=Kr((Js(),he(le(LM,1),it,88,0,[J1,vc,uc,Q1,wf])))}function pht(){pht=U,vSt=Kr((r1(),he(le(xg,1),it,170,0,[Pn,ha,zd,yv,S2])))}function bht(){bht=U,t_t=Kr((t6(),he(le(OM,1),it,256,0,[Kb,tF,XNe,IM,QNe])))}function mht(){mht=U,i_t=Kr((Ct(),he(le(Oo,1),au,64,0,[Pc,Qn,ar,Dr,er])))}function aV(){aV=U,E_e=new A3e("BY_SIZE",0),$0e=new A3e("BY_SIZE_AND_SHAPE",1)}function oV(){oV=U,Q0e=new D3e("EADES",0),yK=new D3e("FRUCHTERMAN_REINGOLD",1)}function pN(){pN=U,XK=new P3e("READING_DIRECTION",0),vLe=new P3e("ROTATION",1)}function hA(){hA=U,L8t=new nI,M8t=new $J,_8t=new vm,A8t=new hu,D8t=new zJ}function vht(e){this.b=new bt,this.a=new bt,this.c=new bt,this.d=new bt,this.e=e}function wht(e){this.g=e,this.f=new bt,this.a=b.Math.min(this.g.c.c,this.g.d.c)}function yht(e,t,n){Vq.call(this),Y6e(this),this.a=e,this.c=n,this.b=t.d,this.f=t.e}function lwn(e,t,n){var r,a;for(a=new G(n);a.a=0&&t0?t-1:t,ZJe(Fun(Vht(B4e(new L8,n),e.n),e.j),e.k)}function sc(e){var t,n;n=(t=new qie,t),qr((!e.q&&(e.q=new nt(Uf,e,11,10)),e.q),n)}function K6e(e){return(e.i&2?"interface ":e.i&1?"":"class ")+(Gg(e),e.o)}function cV(e){return iu(e,Ii)>0?Ii:iu(e,lo)<0?lo:Yr(e)}function Ay(e){return e<3?(Mh(e,Pwt),e+1):e=-.01&&e.a<=H1&&(e.a=0),e.b>=-.01&&e.b<=H1&&(e.b=0),e}function Y5(e){h6();var t,n;for(n=hCe,t=0;tn&&(n=e[t]);return n}function Tht(e,t){var n;if(n=oP(e.Dh(),t),!n)throw ue(new Yn(Ob+t+$fe));return n}function Ly(e,t){var n;for(n=e;ds(n);)if(n=ds(n),n==t)return!0;return!1}function xwn(e,t){var n,r,a;for(r=t.a.ld(),n=l(t.a.md(),16).gc(),a=0;ae||e>t)throw ue(new t3e("fromIndex: 0, toIndex: "+e+uEe+t))}function Lw(e){if(e<0)throw ue(new Yn("Illegal Capacity: "+e));this.g=this.aj(e)}function W6e(e,t){return A1(),f0(Ab),b.Math.abs(e-t)<=Ab||e==t||isNaN(e)&&isNaN(t)}function Xoe(e,t){var n,r,a,o;for(r=e.d,a=0,o=r.length;a0&&(e.a/=t,e.b/=t),e}function Ah(e){var t;return e.w?e.w:(t=dbn(e),t&&!t.Vh()&&(e.w=t),t)}function sE(e,t){var n,r;r=e.a,n=m4n(e,t,null),r!=t&&!e.e&&(n=ZE(e,t,n)),n&&n.oj()}function Lht(e,t,n){var r,a;r=t;do a=ze(e.p[r.p])+n,e.p[r.p]=a,r=e.a[r.p];while(r!=t)}function Mht(e,t,n){var r=function(){return e.apply(r,arguments)};return t.apply(r,n),r}function Awn(e){var t;return e==null?null:(t=l(e,195),$xn(t,t.length))}function Oe(e,t){if(e.g==null||t>=e.i)throw ue(new Vse(t,e.i));return e.Wi(t,e.g[t])}function Lwn(e,t){Cn();var n,r;for(r=new bt,n=0;n=14&&t<=16))),e}function Gr(e,t){var n;return nr(t),n=e[":"+t],BO(!!n,"Enum constant undefined: "+t),n}function Fr(e,t,n,r,a,o){var f;return f=Gae(e,t),Uht(n,f),f.i=a?8:0,f.f=r,f.e=a,f.g=o,f}function Q6e(e,t,n,r,a){this.d=t,this.k=r,this.f=a,this.o=-1,this.p=1,this.c=e,this.a=n}function J6e(e,t,n,r,a){this.d=t,this.k=r,this.f=a,this.o=-1,this.p=2,this.c=e,this.a=n}function Z6e(e,t,n,r,a){this.d=t,this.k=r,this.f=a,this.o=-1,this.p=6,this.c=e,this.a=n}function e7e(e,t,n,r,a){this.d=t,this.k=r,this.f=a,this.o=-1,this.p=7,this.c=e,this.a=n}function t7e(e,t,n,r,a){this.d=t,this.j=r,this.e=a,this.o=-1,this.p=4,this.c=e,this.a=n}function Ght(e,t){var n,r,a,o;for(r=t,a=0,o=r.length;a=0))throw ue(new Yn("tolerance ("+e+") must be >= 0"));return e}function Wht(e,t){var n;return De(t,44)?e.c.Mc(t):(n=Kce(e,t),YV(e,t),n)}function Jo(e,t,n){return Gm(e,t),Fu(e,n),i2(e,0),My(e,1),u2(e,!0),c2(e,!0),e}function mN(e,t){var n;if(n=e.gc(),t<0||t>n)throw ue(new my(t,n));return new f4e(e,t)}function bV(e,t){e.b=b.Math.max(e.b,t.d),e.e+=t.r+(e.a.c.length==0?0:e.c),vt(e.a,t)}function Yht(e){gy(e.c>=0),H5n(e.d,e.c)<0&&(e.a=e.a-1&e.d.a.length-1,e.b=e.d.c),e.c=-1}function mV(e){var t,n;for(n=e.c.Cc().Kc();n.Ob();)t=l(n.Pb(),16),t.$b();e.c.$b(),e.d=0}function jwn(e){var t,n,r,a;for(n=e.a,r=0,a=n.length;r=0}function c7e(e,t){e.r>0&&e.c0&&e.g!=0&&c7e(e.i,t/e.r*e.i.d))}function u7e(e,t){var n;n=e.c,e.c=t,e.Db&4&&!(e.Db&1)&&Ni(e,new _a(e,1,1,n,e.c))}function Zoe(e,t){var n;n=e.c,e.c=t,e.Db&4&&!(e.Db&1)&&Ni(e,new _a(e,1,4,n,e.c))}function fE(e,t){var n;n=e.k,e.k=t,e.Db&4&&!(e.Db&1)&&Ni(e,new _a(e,1,2,n,e.k))}function ece(e,t){var n;n=e.D,e.D=t,e.Db&4&&!(e.Db&1)&&Ni(e,new _a(e,1,2,n,e.D))}function wV(e,t){var n;n=e.f,e.f=t,e.Db&4&&!(e.Db&1)&&Ni(e,new _a(e,1,8,n,e.f))}function yV(e,t){var n;n=e.i,e.i=t,e.Db&4&&!(e.Db&1)&&Ni(e,new _a(e,1,7,n,e.i))}function l7e(e,t){var n;n=e.a,e.a=t,e.Db&4&&!(e.Db&1)&&Ni(e,new _a(e,1,8,n,e.a))}function h7e(e,t){var n;n=e.b,e.b=t,e.Db&4&&!(e.Db&1)&&Ni(e,new _a(e,1,0,n,e.b))}function f7e(e,t){var n;n=e.b,e.b=t,e.Db&4&&!(e.Db&1)&&Ni(e,new _a(e,1,0,n,e.b))}function d7e(e,t){var n;n=e.c,e.c=t,e.Db&4&&!(e.Db&1)&&Ni(e,new _a(e,1,1,n,e.c))}function g7e(e,t){var n;n=e.d,e.d=t,e.Db&4&&!(e.Db&1)&&Ni(e,new _a(e,1,1,n,e.d))}function Gwn(e,t,n){var r;e.b=t,e.a=n,r=(e.a&512)==512?new gJe:new J$,e.c=aSn(r,e.b,e.a)}function oft(e,t){return up(e.e,t)?(Fo(),Voe(t)?new nH(t,e):new yO(t,e)):new Ptt(t,e)}function Kwn(e){var t,n;return 0>e?new b3e:(t=e+1,n=new wut(t,e),new Uye(null,n))}function Wwn(e,t){Cn();var n;return n=new N8(1),Ia(e)?rc(n,e,t):ju(n.f,e,t),new tr(n)}function Ywn(e,t){var n,r;return n=e.c,r=t.e[e.p],r>0?l(jt(n.a,r-1),10):null}function Xwn(e,t){var n,r;return n=e.o+e.p,r=t.o+t.p,nt?(t<<=1,t>0?t:rL):t}function tce(e){switch(Cye(e.e!=3),e.e){case 2:return!1;case 0:return!0}return svn(e)}function uft(e,t){var n;return De(t,8)?(n=l(t,8),e.a==n.a&&e.b==n.b):!1}function Jwn(e,t){var n;n=new Ot,l(t.b,68),l(t.b,68),l(t.b,68),Vu(t.a,new k4e(e,n,t))}function lft(e,t){var n,r;for(r=t.vc().Kc();r.Ob();)n=l(r.Pb(),44),GN(e,n.ld(),n.md())}function p7e(e,t){var n;n=e.d,e.d=t,e.Db&4&&!(e.Db&1)&&Ni(e,new _a(e,1,11,n,e.d))}function xV(e,t){var n;n=e.j,e.j=t,e.Db&4&&!(e.Db&1)&&Ni(e,new _a(e,1,13,n,e.j))}function b7e(e,t){var n;n=e.b,e.b=t,e.Db&4&&!(e.Db&1)&&Ni(e,new _a(e,1,21,n,e.b))}function Zwn(e,t){(UH(),G1?null:t.c).length==0&&Srt(t,new Dt),rc(e.a,G1?null:t.c,t)}function e3n(e,t){t.Ug("Hierarchical port constraint processing",1),v6n(e),RIn(e),t.Vg()}function Ow(){Ow=U,o3=new vse("START",0),Rb=new vse("MIDDLE",1),a3=new vse("END",2)}function kV(){kV=U,$W=new U3e("P1_NODE_PLACEMENT",0),X6=new U3e("P2_EDGE_ROUTING",1)}function bb(){bb=U,Hx=new Ui(NEe),EK=new Ui(C3t),$L=new Ui(S3t),hB=new Ui(_3t)}function Nw(e){var t;return pae(e.f.g,e.d),mr(e.b),e.c=e.a,t=l(e.a.Pb(),44),e.b=L7e(e),t}function m7e(e){var t;return e.b==null?(Wp(),Wp(),dF):(t=e.ul()?e.tl():e.sl(),t)}function hft(e,t){var n;return n=t==null?-1:gc(e.b,t,0),n<0?!1:(rce(e,n),!0)}function d0(e,t){var n;return nr(t),n=t.g,e.b[n]?!1:(Ts(e.b,n,t),++e.c,!0)}function EV(e,t){var n,r;return n=1-t,r=e.a[n],e.a[n]=r.a[t],r.a[t]=e,e.b=!0,r.b=!1,r}function t3n(e,t){var n,r;for(r=t.Kc();r.Ob();)n=l(r.Pb(),272),e.b=!0,na(e.e,n),n.b=e}function n3n(e,t){var n,r;return n=l(Q(e,(Nt(),w4)),8),r=l(Q(t,w4),8),Yi(n.b,r.b)}function nce(e,t,n){var r,a,o;return o=t>>5,a=t&31,r=va(ub(e.n[n][o],Yr(l0(a,1))),3),r}function fft(e,t,n){var r,a,o;for(o=e.a.length-1,a=e.b,r=0;r0?1:0:(!e.c&&(e.c=XO(Zc(e.f))),e.c).e}function xft(e,t){t?e.B==null&&(e.B=e.D,e.D=null):e.B!=null&&(e.D=e.B,e.B=null)}function a3n(e,t){return wE(),e==s3&&t==o4||e==o4&&t==s3||e==M6&&t==a4||e==a4&&t==M6}function o3n(e,t){return wE(),e==s3&&t==a4||e==s3&&t==M6||e==o4&&t==M6||e==o4&&t==a4}function kft(e,t){return A1(),f0(H1),b.Math.abs(0-t)<=H1||t==0||isNaN(0)&&isNaN(t)?0:e/t}function Eft(e,t){return ze(Ge(fh(ON(fc(new bn(null,new kn(e.c.b,16)),new AYe(e)),t))))}function x7e(e,t){return ze(Ge(fh(ON(fc(new bn(null,new kn(e.c.b,16)),new _Ye(e)),t))))}function c3n(){return Ho(),he(le(F1e,1),it,259,0,[eW,vf,UL,tW,$T,B6,GL,RT,jT,nW])}function u3n(){return Nf(),he(le(TDe,1),it,243,0,[AW,AB,LB,xDe,kDe,yDe,EDe,LW,v3,x4])}function l3n(e,t){var n;t.Ug("General Compactor",1),n=p5n(l(at(e,(Sb(),Zde)),393)),n.Cg(e)}function h3n(e,t){var n,r;return n=l(at(e,(Sb(),qW)),17),r=l(at(t,qW),17),ru(n.a,r.a)}function k7e(e,t,n){var r,a;for(a=Rr(e,0);a.b!=a.d.c;)r=l(Br(a),8),r.a+=t,r.b+=n;return e}function gA(e,t,n){var r;for(r=e.b[n&e.f];r;r=r.b)if(n==r.a&&yd(t,r.g))return r;return null}function pA(e,t,n){var r;for(r=e.c[n&e.f];r;r=r.d)if(n==r.f&&yd(t,r.i))return r;return null}function f3n(e,t,n){var r,a,o;for(r=0,a=0;a>>31;r!=0&&(e[n]=r)}function oce(e,t,n,r,a,o){var f;this.c=e,f=new bt,txe(e,f,t,e.b,n,r,a,o),this.a=new Ua(f,0)}function Tft(){this.c=new Wz(0),this.b=new Wz(lCe),this.d=new Wz(hyt),this.a=new Wz(Lhe)}function of(e,t,n,r,a,o,f){Ur.call(this,e,t),this.d=n,this.e=r,this.c=a,this.b=o,this.a=O1(f)}function Os(e,t,n,r,a,o,f,g,w,E,C,L,B){return Lpt(e,t,n,r,a,o,f,g,w,E,C,L,B),$ce(e,!1),e}function d3n(e){return e.b.c.i.k==(Zn(),Us)?l(Q(e.b.c.i,(ft(),zi)),12):e.b.c}function Cft(e){return e.b.d.i.k==(Zn(),Us)?l(Q(e.b.d.i,(ft(),zi)),12):e.b.d}function g3n(e){var t;return t=jH(e),cw(t.a,0)?(Jz(),Jz(),A6t):(Jz(),new art(t.b))}function cce(e){var t;return t=e6e(e),cw(t.a,0)?(cy(),cy(),I0e):(cy(),new sae(t.b))}function uce(e){var t;return t=e6e(e),cw(t.a,0)?(cy(),cy(),I0e):(cy(),new sae(t.c))}function Sft(e){switch(e.g){case 2:return Ct(),er;case 4:return Ct(),ar;default:return e}}function _ft(e){switch(e.g){case 1:return Ct(),Dr;case 3:return Ct(),Qn;default:return e}}function Aft(e){switch(e.g){case 0:return new Mne;case 1:return new Dne;default:return null}}function lx(){lx=U,g1e=new vs("edgelabelcenterednessanalysis.includelabel",(Hn(),Pb))}function E7e(){E7e=U,CEt=Td(Ytt(fi(fi(new Xs,(uo(),bu),(vo(),PK)),_u,MK),mc),NK)}function Lft(){Lft=U,LEt=Td(Ytt(fi(fi(new Xs,(uo(),bu),(vo(),PK)),_u,MK),mc),NK)}function lce(){lce=U,qM=new uJe,npe=he(le(dl,1),S6,179,0,[]),X_t=he(le(Uf,1),LSe,62,0,[])}function dE(){dE=U,dB=new I3e("TO_INTERNAL_LTR",0),h1e=new I3e("TO_INPUT_DIRECTION",1)}function kl(){kl=U,EAe=new K2,xAe=new J3,kAe=new HJ,yAe=new wm,TAe=new VJ,CAe=new UJ}function p3n(e,t){t.Ug(q3t,1),S8e(Zun(new e_((g_(),new Jae(e,!1,!1,new cS))))),t.Vg()}function b3n(e,t,n){n.Ug("DFS Treeifying phase",1),O5n(e,t),DCn(e,t),e.a=null,e.b=null,n.Vg()}function vN(e,t){return Hn(),Ia(e)?E6e(e,ei(t)):fy(e)?Nae(e,Ge(t)):hy(e)?agn(e,Bt(t)):e.Fd(t)}function bA(e,t){var n,r;for(nr(t),r=t.vc().Kc();r.Ob();)n=l(r.Pb(),44),e.zc(n.ld(),n.md())}function m3n(e,t,n){var r;for(r=n.Kc();r.Ob();)if(!qH(e,t,r.Pb()))return!1;return!0}function v3n(e,t,n,r,a){var o;return n&&(o=ms(t.Dh(),e.c),a=n.Rh(t,-1-(o==-1?r:o),null,a)),a}function w3n(e,t,n,r,a){var o;return n&&(o=ms(t.Dh(),e.c),a=n.Th(t,-1-(o==-1?r:o),null,a)),a}function Mft(e){var t;if(e.b==-2){if(e.e==0)t=-1;else for(t=0;e.a[t]==0;t++);e.b=t}return e.b}function y3n(e){if(nr(e),e.length==0)throw ue(new gd("Zero length BigInteger"));S_n(this,e)}function T7e(e){this.i=e.gc(),this.i>0&&(this.g=this.aj(this.i+(this.i/8|0)+1),e.Qc(this.g))}function Dft(e,t,n){this.g=e,this.d=t,this.e=n,this.a=new bt,Ikn(this),Cn(),Vs(this.a,null)}function C7e(e,t){t.q=e,e.d=b.Math.max(e.d,t.r),e.b+=t.d+(e.a.c.length==0?0:e.c),vt(e.a,t)}function gE(e,t){var n,r,a,o;return a=e.c,n=e.c+e.b,o=e.d,r=e.d+e.a,t.a>a&&t.ao&&t.ba?n=a:Xn(t,n+1),e.a=tf(e.a,0,t)+(""+r)+w5e(e.a,n)}function $ft(e,t){e.a=bo(e.a,1),e.c=b.Math.min(e.c,t),e.b=b.Math.max(e.b,t),e.d=bo(e.d,t)}function _3n(e,t){return t1||e.Ob())return++e.a,e.g=0,t=e.i,e.Ob(),t;throw ue(new _c)}function Vft(e){switch(e.a.g){case 1:return new Yet;case 3:return new Ydt;default:return new nie}}function _7e(e,t){switch(t){case 1:return!!e.n&&e.n.i!=0;case 2:return e.k!=null}return Z5e(e,t)}function Zc(e){return _P>22),a=e.h+t.h+(r>>22),qu(n&eh,r&eh,a&hp)}function Jft(e,t){var n,r,a;return n=e.l-t.l,r=e.m-t.m+(n>>22),a=e.h-t.h+(r>>22),qu(n&eh,r&eh,a&hp)}function W3n(e){var t,n;for(zDn(e),n=new G(e.d);n.ar)throw ue(new my(t,r));return e.Si()&&(n=bot(e,n)),e.Ei(t,n)}function yE(e,t,n,r,a){var o,f;for(f=n;f<=a;f++)for(o=t;o<=r;o++)r6(e,o,f)||FU(e,o,f,!0,!1)}function cyn(e){h6();var t,n,r;for(n=We(Ea,dt,8,2,0,1),r=0,t=0;t<2;t++)r+=.5,n[t]=t7n(r,e);return n}function xE(e){var t,n,r;return t=~e.l+1&eh,n=~e.m+(t==0?1:0)&eh,r=~e.h+(t==0&&n==0?1:0)&hp,qu(t,n,r)}function P7e(e){var t;if(e<0)return lo;if(e==0)return 0;for(t=rL;!(t&e);t>>=1);return t}function mce(e,t,n){return e>=128?!1:e<64?I_(va(l0(1,e),n),0):I_(va(l0(1,e-64),t),0)}function _N(e,t,n){return n==null?(!e.q&&(e.q=new Pr),ax(e.q,t)):(!e.q&&(e.q=new Pr),ki(e.q,t,n)),e}function rt(e,t,n){return n==null?(!e.q&&(e.q=new Pr),ax(e.q,t)):(!e.q&&(e.q=new Pr),ki(e.q,t,n)),e}function u0t(e){var t,n;return n=new KH,pc(n,e),rt(n,(bb(),Hx),e),t=new Pr,FAn(e,n,t),hDn(e,n,t),n}function l0t(e){var t,n;return t=e.t-e.k[e.o.p]*e.d+e.j[e.o.p]>e.f,n=e.u+e.e[e.o.p]*e.d>e.f*e.s*e.d,t||n}function h0t(e,t){var n,r,a,o;for(n=!1,r=e.a[t].length,o=0;o=0,"Negative initial capacity"),BO(t>=0,"Non-positive load factor"),Nl(this)}function lyn(e,t,n,r,a){var o,f;if(f=e.length,o=n.length,t<0||r<0||a<0||t+a>f||r+a>o)throw ue(new _we)}function j7e(e,t){Cn();var n,r,a,o,f;for(f=!1,r=t,a=0,o=r.length;a1||t>=0&&e.b<3)}function yce(e){var t,n,r;t=~e.l+1&eh,n=~e.m+(t==0?1:0)&eh,r=~e.h+(t==0&&n==0?1:0)&hp,e.l=t,e.m=n,e.h=r}function q7e(e){Cn();var t,n,r;for(r=1,n=e.Kc();n.Ob();)t=n.Pb(),r=31*r+(t!=null?es(t):0),r=r|0;return r}function pyn(e,t,n,r,a){var o;return o=D9e(e,t),n&&yce(o),a&&(e=c7n(e,t),r?Nb=xE(e):Nb=qu(e.l,e.m,e.h)),o}function x0t(e,t,n){e.g=Rue(e,t,(Ct(),ar),e.b),e.d=Rue(e,n,ar,e.b),!(e.g.c==0||e.d.c==0)&&Jgt(e)}function k0t(e,t,n){e.g=Rue(e,t,(Ct(),er),e.j),e.d=Rue(e,n,er,e.j),!(e.g.c==0||e.d.c==0)&&Jgt(e)}function H7e(e,t){switch(t){case 7:return!!e.e&&e.e.i!=0;case 8:return!!e.d&&e.d.i!=0}return _8e(e,t)}function byn(e,t){switch(t.g){case 0:De(e.b,641)||(e.b=new jft);break;case 1:De(e.b,642)||(e.b=new Rit)}}function E0t(e){switch(e.g){case 0:return new One;default:throw ue(new Yn(FG+(e.f!=null?e.f:""+e.g)))}}function T0t(e){switch(e.g){case 0:return new gl;default:throw ue(new Yn(FG+(e.f!=null?e.f:""+e.g)))}}function myn(e,t,n){return!_k(Fi(new bn(null,new kn(e.c,16)),new Wl(new ltt(t,n)))).Bd((Am(),zx))}function C0t(e,t){return z8(BE(l(Q(t,(Hc(),y3)),88)),new lt(e.c.e.a-e.b.e.a,e.c.e.b-e.b.e.b))<=0}function vyn(e,t){for(;e.g==null&&!e.c?H5e(e):e.g==null||e.i!=0&&l(e.g[e.i-1],51).Ob();)kln(t,CU(e))}function Um(e){var t,n;for(n=new G(e.a.b);n.ar?1:0}function xyn(e){return vt(e.c,(hx(),gSt)),W6e(e.a,ze(Ge(It((Gce(),TW)))))?new Hne:new OXe(e)}function kyn(e){for(;!e.d||!e.d.Ob();)if(e.b&&!l_(e.b))e.d=l(X8(e.b),51);else return null;return e.d}function U7e(e){switch(e.g){case 1:return hyt;default:case 2:return 0;case 3:return Lhe;case 4:return lCe}}function Eyn(){Di();var e;return cpe||(e=Hhn(_b("M",!0)),e=oH(_b("M",!1),e),cpe=e,cpe)}function NV(){NV=U,Wge=new Cq("ELK",0),lPe=new Cq("JSON",1),uPe=new Cq("DOT",2),hPe=new Cq("SVG",3)}function yA(){yA=U,Sde=new _se("STACKED",0),Cde=new _se("REVERSE_STACKED",1),MB=new _se("SEQUENCED",2)}function xA(){xA=U,ZDe=new Ose(Id,0),Ide=new Ose("MIDDLE_TO_MIDDLE",1),OB=new Ose("AVOID_OVERLAP",2)}function TE(){TE=U,oLe=new MZ,cLe=new lI,X8t=new yj,Y8t=new DZ,W8t=new n8,aLe=(nr(W8t),new ke)}function PV(){PV=U,WNe=new lw(15),XSt=new Ha((pi(),_2),WNe),MM=n9,VNe=LSt,UNe=kv,KNe=i7,GNe=C4}function Q5(e,t){var n,r,a,o,f;for(r=t,a=0,o=r.length;a=e.b.c.length||(K7e(e,2*t+1),n=2*t+2,n0&&(t.Cd(n),n.i&&C4n(n))}function W7e(e,t,n){var r;for(r=n-1;r>=0&&e[r]===t[r];r--);return r<0?0:fse(va(e[r],Vo),va(t[r],Vo))?-1:1}function A0t(e,t,n){var r,a;this.g=e,this.c=t,this.a=this,this.d=this,a=cft(n),r=We(c6t,TP,227,a,0,1),this.b=r}function Cce(e,t,n,r,a){var o,f;for(f=n;f<=a;f++)for(o=t;o<=r;o++)if(r6(e,o,f))return!0;return!1}function Lyn(e,t){var n,r;for(r=e.Zb().Cc().Kc();r.Ob();)if(n=l(r.Pb(),16),n.Hc(t))return!0;return!1}function L0t(e,t,n){var r,a,o,f;for(nr(n),f=!1,o=e.fd(t),a=n.Kc();a.Ob();)r=a.Pb(),o.Rb(r),f=!0;return f}function Sce(e,t){var n,r;return r=l(Kn(e.a,4),129),n=We(epe,r0e,424,t,0,1),r!=null&&pu(r,0,n,0,r.length),n}function M0t(e,t){var n;return n=new ele((e.f&256)!=0,e.i,e.a,e.d,(e.f&16)!=0,e.j,e.g,t),e.e!=null||(n.c=e),n}function Myn(e,t){var n;return e===t?!0:De(t,85)?(n=l(t,85),Qxe(Mm(e),n.vc())):!1}function D0t(e,t,n){var r,a;for(a=n.Kc();a.Ob();)if(r=l(a.Pb(),44),e.Be(t,r.md()))return!0;return!1}function I0t(e,t,n){return e.d[t.p][n.p]||(O6n(e,t,n),e.d[t.p][n.p]=!0,e.d[n.p][t.p]=!0),e.a[t.p][n.p]}function Dyn(e,t){var n;return!e||e==t||!ns(t,(ft(),u3))?!1:(n=l(Q(t,(ft(),u3)),10),n!=e)}function _ce(e){switch(e.i){case 2:return!0;case 1:return!1;case-1:++e.c;default:return e.$l()}}function O0t(e){switch(e.i){case-2:return!0;case-1:return!1;case 1:--e.c;default:return e._l()}}function N0t(e){xot.call(this,"The given string does not match the expected format for individual spacings.",e)}function Iyn(e,t){var n;t.Ug("Min Size Preprocessing",1),n=a9e(e),Hi(e,(ug(),mM),n.a),Hi(e,UW,n.b),t.Vg()}function Oyn(e){var t,n,r;for(t=0,r=We(Ea,dt,8,e.b,0,1),n=Rr(e,0);n.b!=n.d.c;)r[t++]=l(Br(n),8);return r}function Ace(e,t,n){var r,a,o;for(r=new os,o=Rr(n,0);o.b!=o.d.c;)a=l(Br(o),8),ui(r,new Eo(a));L0t(e,t,r)}function Nyn(e,t){var n;return n=bo(e,t),fse(moe(e,t),0)|Aq(moe(e,n),0)?n:bo(EP,moe(ub(n,63),1))}function Pyn(e,t){var n,r;return n=l(e.d.Bc(t),16),n?(r=e.e.hc(),r.Gc(n),e.e.d-=n.gc(),n.$b(),r):null}function P0t(e){var t;if(t=e.a.c.length,t>0)return qk(t-1,e.a.c.length),t2(e.a,t-1);throw ue(new OQe)}function B0t(e,t,n){if(e>t)throw ue(new Yn(eG+e+Qwt+t));if(e<0||t>n)throw ue(new t3e(eG+e+fEe+t+uEe+n))}function CE(e,t){e.D==null&&e.B!=null&&(e.D=e.B,e.B=null),ece(e,t==null?null:(nr(t),t)),e.C&&e.hl(null)}function Byn(e,t){var n;n=It((Gce(),TW))!=null&&t.Sg()!=null?ze(Ge(t.Sg()))/ze(Ge(It(TW))):1,ki(e.b,t,n)}function Y7e(e,t){var n,r;if(r=e.c[t],r!=0)for(e.c[t]=0,e.d-=r,n=t+1;nMG?e-n>MG:n-e>MG}function K0t(e,t){var n;for(n=0;na&&(Egt(t.q,a),r=n!=t.q.d)),r}function W0t(e,t){var n,r,a,o,f,g,w,E;return w=t.i,E=t.j,r=e.f,a=r.i,o=r.j,f=w-a,g=E-o,n=b.Math.sqrt(f*f+g*g),n}function t8e(e,t){var n,r;return r=XV(e),r||(n=(kle(),P2t(t)),r=new kQe(n),qr(r.El(),e)),r}function DN(e,t){var n,r;return n=l(e.c.Bc(t),16),n?(r=e.hc(),r.Gc(n),e.d-=n.gc(),n.$b(),e.mc(r)):e.jc()}function Kyn(e,t){var n,r;for(r=Jl(e.d,1)!=0,n=!0;n;)n=!1,n=t.c.mg(t.e,r),n=n|cP(e,t,r,!1),r=!r;w7e(e)}function Y0t(e,t,n,r){var a,o;e.a=t,o=r?0:1,e.f=(a=new cpt(e.c,e.a,n,o),new $bt(n,e.a,a,e.e,e.b,e.c==(Iw(),oM)))}function FV(e){var t;return mr(e.a!=e.b),t=e.d.a[e.a],Ert(e.b==e.d.c&&t!=null),e.c=e.a,e.a=e.a+1&e.d.a.length-1,t}function X0t(e){var t;if(e.c!=0)return e.c;for(t=0;t=e.c.b:e.a<=e.c.b))throw ue(new _c);return t=e.a,e.a+=e.c.c,++e.b,pt(t)}function Oce(e){var t;return t=new bye(e.a),pc(t,e),rt(t,(ft(),zi),e),t.o.a=e.g,t.o.b=e.f,t.n.a=e.i,t.n.b=e.j,t}function Nce(e){return(Ct(),hl).Hc(e.j)?ze(Ge(Q(e,(ft(),zT)))):Ic(he(le(Ea,1),dt,8,0,[e.i.n,e.n,e.a])).b}function Yyn(e){var t;return t=Oq(TEt),l(Q(e,(ft(),Lu)),21).Hc((Ho(),$T))&&fi(t,(uo(),bu),(vo(),RK)),t}function Xyn(e){var t,n,r,a;for(a=new Ks,r=new G(e);r.a=0?t:-t;r>0;)r%2==0?(n*=n,r=r/2|0):(a*=n,r-=1);return t<0?1/a:a}function t4n(e,t){var n,r,a;for(a=1,n=e,r=t>=0?t:-t;r>0;)r%2==0?(n*=n,r=r/2|0):(a*=n,r-=1);return t<0?1/a:a}function yb(e,t){var n,r,a,o;return o=(a=e?XV(e):null,Dpt((r=t,a&&a.Gl(),r))),o==t&&(n=XV(e),n&&n.Gl()),o}function Q0t(e,t,n){var r,a;return a=e.f,e.f=t,e.Db&4&&!(e.Db&1)&&(r=new _a(e,1,0,a,t),n?n.nj(r):n=r),n}function J0t(e,t,n){var r,a;return a=e.b,e.b=t,e.Db&4&&!(e.Db&1)&&(r=new _a(e,1,3,a,t),n?n.nj(r):n=r),n}function r8e(e,t,n){var r,a;return a=e.a,e.a=t,e.Db&4&&!(e.Db&1)&&(r=new _a(e,1,1,a,t),n?n.nj(r):n=r),n}function Z0t(e){var t,n;if(e!=null)for(n=0;n=r||t-129&&e<128?(Fit(),t=e+128,n=t_e[t],!n&&(n=t_e[t]=new Cr(e)),n):new Cr(e)}function _E(e){var t,n;return e>-129&&e<128?(est(),t=e+128,n=s_e[t],!n&&(n=s_e[t]=new Wn(e)),n):new Wn(e)}function n1t(e,t){var n;e.a.c.length>0&&(n=l(jt(e.a,e.a.c.length-1),579),G7e(n,t))||vt(e.a,new yut(t))}function o4n(e){u0();var t,n;t=e.d.c-e.e.c,n=l(e.g,154),Vu(n.b,new pYe(t)),Vu(n.c,new bYe(t)),to(n.i,new mYe(t))}function r1t(e){var t;return t=new tb,t.a+="VerticalSegment ",wu(t,e.e),t.a+=" ",hi(t,Eye(new Zie,new G(e.k))),t.a}function Pce(e,t){var n,r,a;for(n=0,a=Oc(e,t).Kc();a.Ob();)r=l(a.Pb(),12),n+=Q(r,(ft(),jl))!=null?1:0;return n}function e6(e,t,n){var r,a,o;for(r=0,o=Rr(e,0);o.b!=o.d.c&&(a=ze(Ge(Br(o))),!(a>n));)a>=t&&++r;return r}function i1t(e,t){Xr(e);try{return e._b(t)}catch(n){if(n=bs(n),De(n,212)||De(n,169))return!1;throw ue(n)}}function s8e(e,t){Xr(e);try{return e.Hc(t)}catch(n){if(n=bs(n),De(n,212)||De(n,169))return!1;throw ue(n)}}function c4n(e,t){Xr(e);try{return e.Mc(t)}catch(n){if(n=bs(n),De(n,212)||De(n,169))return!1;throw ue(n)}}function Oy(e,t){Xr(e);try{return e.xc(t)}catch(n){if(n=bs(n),De(n,212)||De(n,169))return null;throw ue(n)}}function u4n(e,t){Xr(e);try{return e.Bc(t)}catch(n){if(n=bs(n),De(n,212)||De(n,169))return null;throw ue(n)}}function TA(e,t){switch(t.g){case 2:case 1:return Oc(e,t);case 3:case 4:return lf(Oc(e,t))}return Cn(),Cn(),_o}function CA(e){var t;return e.Db&64?g0(e):(t=new Af(g0(e)),t.a+=" (name: ",Xo(t,e.zb),t.a+=")",t.a)}function l4n(e){var t;return t=l(B1(e.c.c,""),233),t||(t=new nx(Ck(Tk(new ny,""),"Other")),h2(e.c.c,"",t)),t}function a8e(e,t,n){var r,a;return a=e.sb,e.sb=t,e.Db&4&&!(e.Db&1)&&(r=new _a(e,1,4,a,t),n?n.nj(r):n=r),n}function o8e(e,t,n){var r,a;return a=e.r,e.r=t,e.Db&4&&!(e.Db&1)&&(r=new _a(e,1,8,a,e.r),n?n.nj(r):n=r),n}function h4n(e,t,n){var r,a;return r=new Zg(e.e,4,13,(a=t.c,a||(Tn(),td)),null,f2(e,t),!1),n?n.nj(r):n=r,n}function f4n(e,t,n){var r,a;return r=new Zg(e.e,3,13,null,(a=t.c,a||(Tn(),td)),f2(e,t),!1),n?n.nj(r):n=r,n}function o2(e,t){var n,r;return n=l(t,691),r=n.el(),!r&&n.fl(r=De(t,90)?new Btt(e,l(t,29)):new sct(e,l(t,156))),r}function IN(e,t,n){var r;e._i(e.i+1),r=e.Zi(t,n),t!=e.i&&pu(e.g,t,e.g,t+1,e.i-t),Ts(e.g,t,r),++e.i,e.Mi(t,n),e.Ni()}function d4n(e,t){var n;return t.a&&(n=t.a.a.length,e.a?hi(e.a,e.b):e.a=new Th(e.d),fct(e.a,t.a,t.d.length,n)),e}function g4n(e,t){var n;e.c=t,e.a=w5n(t),e.a<54&&(e.f=(n=t.d>1?lct(t.a[0],t.a[1]):lct(t.a[0],0),Fm(t.e>0?n:r2(n))))}function ON(e,t){var n;return n=new on,e.a.Bd(n)?(Ok(),new Kie(nr(Ult(e,n.a,t)))):(fb(e),Ok(),Ok(),b_e)}function s1t(e,t){var n;e.c.length!=0&&(n=l(j1(e,We(wg,m2,10,e.c.length,0,1)),199),cye(n,new U9),Jpt(n,t))}function a1t(e,t){var n;e.c.length!=0&&(n=l(j1(e,We(wg,m2,10,e.c.length,0,1)),199),cye(n,new Wd),Jpt(n,t))}function Pi(e,t){return Ia(e)?vn(e,t):fy(e)?eit(e,t):hy(e)?(nr(e),qe(e)===qe(t)):t5e(e)?e.Fb(t):W4e(e)?Jtt(e,t):W5e(e,t)}function cf(e,t,n){if(t<0)d9e(e,n);else{if(!n.rk())throw ue(new Yn(Ob+n.xe()+kL));l(n,69).wk().Ek(e,e.hi(),t)}}function o1t(e,t,n){if(e<0||t>n)throw ue(new tc(eG+e+fEe+t+", size: "+n));if(e>t)throw ue(new Yn(eG+e+Qwt+t))}function c1t(e){var t;return e.Db&64?g0(e):(t=new Af(g0(e)),t.a+=" (source: ",Xo(t,e.d),t.a+=")",t.a)}function u1t(e){return e>=65&&e<=70?e-65+10:e>=97&&e<=102?e-97+10:e>=48&&e<=57?e-48:0}function p4n(e){YU();var t,n,r,a;for(n=eue(),r=0,a=n.length;r=0?kb(e):J_(kb(r2(e))))}function f1t(e,t,n,r,a,o){this.e=new bt,this.f=(qo(),sM),vt(this.e,e),this.d=t,this.a=n,this.b=r,this.f=a,this.c=o}function v4n(e,t,n){e.n=Lm(nm,[dt,ahe],[376,28],14,[n,ua(b.Math.ceil(t/32))],2),e.o=t,e.p=n,e.j=t-1>>1,e.k=n-1>>1}function d1t(e){return e-=e>>1&1431655765,e=(e>>2&858993459)+(e&858993459),e=(e>>4)+e&252645135,e+=e>>8,e+=e>>16,e&63}function g1t(e,t){var n,r;for(r=new or(e);r.e!=r.i.gc();)if(n=l(gr(r),142),qe(t)===qe(n))return!0;return!1}function w4n(e,t,n){var r,a,o;return o=(a=VE(e.b,t),a),o&&(r=l(VU(lN(e,o),""),29),r)?P9e(e,r,t,n):null}function Bce(e,t,n){var r,a,o;return o=(a=VE(e.b,t),a),o&&(r=l(VU(lN(e,o),""),29),r)?B9e(e,r,t,n):null}function y4n(e,t){var n;if(n=X5(e.i,t),n==null)throw ue(new dd("Node did not exist in input."));return S7e(t,n),null}function x4n(e,t){var n;if(n=oP(e,t),De(n,331))return l(n,35);throw ue(new Yn(Ob+t+"' is not a valid attribute"))}function _A(e,t,n){var r;if(r=e.gc(),t>r)throw ue(new my(t,r));if(e.Si()&&e.Hc(n))throw ue(new Yn(WP));e.Gi(t,n)}function k4n(e,t){t.Ug("Sort end labels",1),Is(Fi(Dc(new bn(null,new kn(e.b,16)),new hj),new J7),new aZ),t.Vg()}function Js(){Js=U,J1=new mO(cL,0),vc=new mO(Dx,1),uc=new mO(Mx,2),Q1=new mO(whe,3),wf=new mO("UP",4)}function PN(){PN=U,WW=new $se("P1_STRUCTURE",0),YW=new $se("P2_PROCESSING_ORDER",1),XW=new $se("P3_EXECUTION",2)}function p1t(){p1t=U,jTt=Td(Td(v_(Td(Td(v_(fi(new Xs,(wx(),lM),(WA(),Dde)),hM),YDe),QDe),fM),UDe),JDe)}function E4n(e){switch(l(Q(e,(ft(),hv)),311).g){case 1:rt(e,hv,(ep(),Ux));break;case 2:rt(e,hv,(ep(),F6))}}function T4n(e){switch(e){case 0:return new nJe;case 1:return new eJe;case 2:return new tJe;default:throw ue(new YI)}}function b1t(e){switch(e.g){case 2:return vc;case 1:return uc;case 4:return Q1;case 3:return wf;default:return J1}}function h8e(e,t){switch(e.b.g){case 0:case 1:return t;case 2:case 3:return new ef(t.d,0,t.a,t.b);default:return null}}function f8e(e){switch(e.g){case 1:return er;case 2:return Qn;case 3:return ar;case 4:return Dr;default:return Pc}}function BN(e){switch(e.g){case 1:return Dr;case 2:return er;case 3:return Qn;case 4:return ar;default:return Pc}}function $V(e){switch(e.g){case 1:return ar;case 2:return Dr;case 3:return er;case 4:return Qn;default:return Pc}}function d8e(e,t,n,r){switch(t){case 1:return!e.n&&(e.n=new nt(ec,e,1,7)),e.n;case 2:return e.k}return sxe(e,t,n,r)}function AA(e,t,n){var r,a;return e.Pj()?(a=e.Qj(),r=Hue(e,t,n),e.Jj(e.Ij(7,pt(n),r,t,a)),r):Hue(e,t,n)}function Fce(e,t){var n,r,a;e.d==null?(++e.e,--e.f):(a=t.ld(),n=t.Bi(),r=(n&Ii)%e.d.length,uvn(e,r,j2t(e,r,n,a)))}function AE(e,t){var n;n=(e.Bb&m0)!=0,t?e.Bb|=m0:e.Bb&=-1025,e.Db&4&&!(e.Db&1)&&Ni(e,new h0(e,1,10,n,t))}function LE(e,t){var n;n=(e.Bb&Xy)!=0,t?e.Bb|=Xy:e.Bb&=-4097,e.Db&4&&!(e.Db&1)&&Ni(e,new h0(e,1,12,n,t))}function ME(e,t){var n;n=(e.Bb&Sl)!=0,t?e.Bb|=Sl:e.Bb&=-8193,e.Db&4&&!(e.Db&1)&&Ni(e,new h0(e,1,15,n,t))}function DE(e,t){var n;n=(e.Bb&r4)!=0,t?e.Bb|=r4:e.Bb&=-2049,e.Db&4&&!(e.Db&1)&&Ni(e,new h0(e,1,11,n,t))}function C4n(e){var t;e.g&&(t=e.c.kg()?e.f:e.a,Y9e(t.a,e.o,!0),Y9e(t.a,e.o,!1),rt(e.o,(Nt(),Ms),(Ra(),Tv)))}function S4n(e){var t;if(!e.a)throw ue(new nc("Cannot offset an unassigned cut."));t=e.c-e.b,e.b+=t,zat(e,t),$at(e,t)}function _4n(e,t){var n;if(n=cr(e.k,t),n==null)throw ue(new dd("Port did not exist in input."));return S7e(t,n),null}function A4n(e){var t,n;for(n=B2t(Ah(e)).Kc();n.Ob();)if(t=ei(n.Pb()),YA(e,t))return Lmn((met(),R_t),t);return null}function m1t(e){var t,n;for(n=e.p.a.ec().Kc();n.Ob();)if(t=l(n.Pb(),218),t.f&&e.b[t.c]<-1e-10)return t;return null}function L4n(e){var t,n;for(n=hb(new tb,91),t=!0;e.Ob();)t||(n.a+=Co),t=!1,wu(n,e.Pb());return(n.a+="]",n).a}function M4n(e){var t,n,r;for(t=new bt,r=new G(e.b);r.at?1:e==t?e==0?Yi(1/e,1/t):0:isNaN(e)?isNaN(t)?0:1:-1}function I4n(e){var t;return t=e.a[e.c-1&e.a.length-1],t==null?null:(e.c=e.c-1&e.a.length-1,Ts(e.a,e.c,null),t)}function O4n(e){var t,n,r;for(r=0,n=e.length,t=0;t=1?vc:Q1):n}function F4n(e){switch(l(Q(e,(Nt(),bp)),223).g){case 1:return new Tee;case 3:return new Lee;default:return new Eee}}function xb(e){if(e.c)xb(e.c);else if(e.d)throw ue(new nc("Stream already terminated, can't be modified or used"))}function Bw(e,t,n){var r;return r=e.a.get(t),e.a.set(t,n===void 0?null:n),r===void 0?(++e.c,++e.b.g):++e.d,r}function R4n(e,t,n){var r,a;for(a=e.a.ec().Kc();a.Ob();)if(r=l(a.Pb(),10),EN(n,l(jt(t,r.p),16)))return r;return null}function p8e(e,t,n){var r;return r=0,t&&(B5(e.a)?r+=t.f.a/2:r+=t.f.b/2),n&&(B5(e.a)?r+=n.f.a/2:r+=n.f.b/2),r}function j4n(e,t,n){var r;r=n,!r&&(r=B4e(new L8,0)),r.Ug(L3t,2),kdt(e.b,t,r.eh(1)),eMn(e,t,r.eh(1)),rIn(t,r.eh(1)),r.Vg()}function b8e(e,t,n){var r,a;return r=(rb(),a=new AS,a),dV(r,t),fV(r,n),e&&qr((!e.a&&(e.a=new Ys(qh,e,5)),e.a),r),r}function jce(e){var t;return e.Db&64?g0(e):(t=new Af(g0(e)),t.a+=" (identifier: ",Xo(t,e.k),t.a+=")",t.a)}function $ce(e,t){var n;n=(e.Bb&eu)!=0,t?e.Bb|=eu:e.Bb&=-32769,e.Db&4&&!(e.Db&1)&&Ni(e,new h0(e,1,18,n,t))}function m8e(e,t){var n;n=(e.Bb&eu)!=0,t?e.Bb|=eu:e.Bb&=-32769,e.Db&4&&!(e.Db&1)&&Ni(e,new h0(e,1,18,n,t))}function IE(e,t){var n;n=(e.Bb&_d)!=0,t?e.Bb|=_d:e.Bb&=-16385,e.Db&4&&!(e.Db&1)&&Ni(e,new h0(e,1,16,n,t))}function v8e(e,t){var n;n=(e.Bb&Io)!=0,t?e.Bb|=Io:e.Bb&=-65537,e.Db&4&&!(e.Db&1)&&Ni(e,new h0(e,1,20,n,t))}function w8e(e){var t;return t=We(kf,Ad,28,2,15,1),e-=Io,t[0]=(e>>10)+AP&Zs,t[1]=(e&1023)+56320&Zs,If(t,0,t.length)}function $4n(e){var t;return t=jy(e),t>34028234663852886e22?gs:t<-34028234663852886e22?ia:t}function bo(e,t){var n;return wc(e)&&wc(t)&&(n=e+t,_P"+Bm(t.c):"e_"+es(t),e.b&&e.c?Bm(e.b)+"->"+Bm(e.c):"e_"+es(e))}function H4n(e,t){return vn(t.b&&t.c?Bm(t.b)+"->"+Bm(t.c):"e_"+es(t),e.b&&e.c?Bm(e.b)+"->"+Bm(e.c):"e_"+es(e))}function Fw(e,t){return A1(),f0(Ab),b.Math.abs(e-t)<=Ab||e==t||isNaN(e)&&isNaN(t)?0:et?1:uw(isNaN(e),isNaN(t))}function ip(){ip=U,Hge=new xq(cL,0),JB=new xq("POLYLINE",1),iC=new xq("ORTHOGONAL",2),s9=new xq("SPLINES",3)}function qV(){qV=U,YIe=new Rse("ASPECT_RATIO_DRIVEN",0),uge=new Rse("MAX_SCALE_DRIVEN",1),WIe=new Rse("AREA_DRIVEN",2)}function V4n(e,t,n){var r;try{dyn(e,t,n)}catch(a){throw a=bs(a),De(a,606)?(r=a,ue(new w6e(r))):ue(a)}return t}function U4n(e){var t,n,r;for(n=0,r=e.length;nt&&r.Ne(e[o-1],e[o])>0;--o)f=e[o],Ts(e,o,e[o-1]),Ts(e,o-1,f)}function sn(e,t){var n,r,a,o,f;if(n=t.f,h2(e.c.d,n,t),t.g!=null)for(a=t.g,o=0,f=a.length;ot){pct(n);break}}zO(n,t)}function Y4n(e,t){var n,r,a;r=G5(t),a=ze(Ge(Py(r,(Nt(),x0)))),n=b.Math.max(0,a/2-.5),FA(t,n,1),vt(e,new Net(t,n))}function X4n(e,t,n){var r;n.Ug("Straight Line Edge Routing",1),n.dh(t,yCe),r=l(at(t,(H5(),Y6)),27),rvt(e,r),n.dh(t,OG)}function y8e(e,t){e.n.c.length==0&&vt(e.n,new PH(e.s,e.t,e.i)),vt(e.b,t),exe(l(jt(e.n,e.n.c.length-1),209),t),jmt(e,t)}function LA(e){var t;this.a=(t=l(e.e&&e.e(),9),new Zh(t,l(c0(t,t.length),9),0)),this.b=We(wa,Rn,1,this.a.a.length,5,1)}function xc(e){var t;return Array.isArray(e)&&e.Tm===xe?_m(bh(e))+"@"+(t=es(e)>>>0,t.toString(16)):e.toString()}function Q4n(e,t){return e.h==SP&&e.m==0&&e.l==0?(t&&(Nb=qu(0,0,0)),ent((iE(),YSe))):(t&&(Nb=qu(e.l,e.m,e.h)),qu(0,0,0))}function J4n(e,t){switch(t.g){case 2:return e.b;case 1:return e.c;case 4:return e.d;case 3:return e.a;default:return!1}}function x1t(e,t){switch(t.g){case 2:return e.b;case 1:return e.c;case 4:return e.d;case 3:return e.a;default:return!1}}function x8e(e,t,n,r){switch(t){case 3:return e.f;case 4:return e.g;case 5:return e.i;case 6:return e.j}return d8e(e,t,n,r)}function HV(e,t){if(t==e.d)return e.e;if(t==e.e)return e.d;throw ue(new Yn("Node "+t+" not part of edge "+e))}function Z4n(e,t){var n;if(n=oP(e.Dh(),t),De(n,102))return l(n,19);throw ue(new Yn(Ob+t+"' is not a valid reference"))}function uf(e,t,n,r){if(t<0)$9e(e,n,r);else{if(!n.rk())throw ue(new Yn(Ob+n.xe()+kL));l(n,69).wk().Ck(e,e.hi(),t,r)}}function Ql(e){var t;if(e.b){if(Ql(e.b),e.b.d!=e.c)throw ue(new Xh)}else e.d.dc()&&(t=l(e.f.c.xc(e.e),16),t&&(e.d=t))}function e5n(e){py();var t,n,r,a;for(t=e.o.b,r=l(l($i(e.r,(Ct(),Dr)),21),87).Kc();r.Ob();)n=l(r.Pb(),117),a=n.e,a.b+=t}function t5n(e){var t,n,r;for(this.a=new bd,r=new G(e);r.a=a)return t.c+n;return t.c+t.b.gc()}function r5n(e,t){Fk();var n,r,a,o;for(r=Olt(e),a=t,nE(r,0,r.length,a),n=0;n0&&(r+=a,++n);return n>1&&(r+=e.d*(n-1)),r}function s5n(e){var t,n,r,a,o;return o=jxe(e),n=ZI(e.c),r=!n,r&&(a=new $p,e1(o,"knownLayouters",a),t=new uQe(a),to(e.c,t)),o}function T8e(e){var t,n,r;for(r=new Up,r.a+="[",t=0,n=e.gc();t0&&(Xn(t-1,e.length),e.charCodeAt(t-1)==58)&&!Hce(e,$M,zM))}function C8e(e,t){var n;return qe(e)===qe(t)?!0:De(t,92)?(n=l(t,92),e.e==n.e&&e.d==n.d&&Imn(e,n.a)):!1}function gx(e){switch(Ct(),e.g){case 4:return Qn;case 1:return ar;case 3:return Dr;case 2:return er;default:return Pc}}function u5n(e){var t,n;if(e.b)return e.b;for(n=G1?null:e.d;n;){if(t=G1?null:n.b,t)return t;n=G1?null:n.d}return Dk(),w_e}function S8e(e){var t,n,r;for(r=ze(Ge(e.a.of((pi(),iY)))),n=new G(e.a.Sf());n.a>5,t=e&31,r=We(Vr,di,28,n+1,15,1),r[n]=1<3;)a*=10,--o;e=(e+(a>>1))/a|0}return r.i=e,!0}function ms(e,t){var n,r,a;if(n=(e.i==null&&Sd(e),e.i),r=t.Lj(),r!=-1){for(a=n.length;r=0;--r)for(t=n[r],a=0;a>1,this.k=t-1>>1}function T5n(e){ZH(),l(e.of((pi(),Ub)),181).Hc((Zl(),hY))&&(l(e.of(S4),181).Fc((Rl(),a9)),l(e.of(Ub),181).Mc(hY))}function A1t(e){var t,n;t=e.d==(yx(),IT),n=Lxe(e),t&&!n||!t&&n?rt(e.a,(Nt(),Rd),(og(),VB)):rt(e.a,(Nt(),Rd),(og(),HB))}function Gce(){Gce=U,tq(),TW=(Nt(),m3),Qkt=O1(he(le(Cge,1),oCe,149,0,[SB,x0,H6,b3,y4,cde,GT,KT,ude,tM,q6,vv,V6]))}function C5n(e,t){var n;return n=l(yc(e,Pl(new zr,new ht,new Fn,he(le(oc,1),it,108,0,[(Fl(),Ec)]))),15),n.Qc(Yit(n.gc()))}function L1t(e,t){var n,r;if(r=new ba(e.a.ad(t,!0)),r.a.gc()<=1)throw ue(new S8);return n=r.a.ec().Kc(),n.Pb(),l(n.Pb(),40)}function S5n(e,t,n){var r,a;return r=ze(e.p[t.i.p])+ze(e.d[t.i.p])+t.n.b+t.a.b,a=ze(e.p[n.i.p])+ze(e.d[n.i.p])+n.n.b+n.a.b,a-r}function O8e(e,t){var n;return e.i>0&&(t.lengthe.i&&Ts(t,e.i,null),t}function UV(e){var t;return e.Db&64?CA(e):(t=new Af(CA(e)),t.a+=" (instanceClassName: ",Xo(t,e.D),t.a+=")",t.a)}function GV(e){var t,n,r,a;for(a=0,n=0,r=e.length;n0?(e._j(),r=t==null?0:es(t),a=(r&Ii)%e.d.length,n=j2t(e,a,r,t),n!=-1):!1}function M1t(e,t){var n,r;e.a=bo(e.a,1),e.c=b.Math.min(e.c,t),e.b=b.Math.max(e.b,t),e.d+=t,n=t-e.f,r=e.e+n,e.f=r-e.e-n,e.e=r}function N8e(e,t){switch(t){case 3:Mw(e,0);return;case 4:Dw(e,0);return;case 5:Uu(e,0);return;case 6:Gu(e,0);return}i8e(e,t)}function Rw(e,t){switch(t.g){case 1:return G8(e.j,(kl(),xAe));case 2:return G8(e.j,(kl(),EAe));default:return Cn(),Cn(),_o}}function P8e(e){ww();var t;switch(t=e.Pc(),t.length){case 0:return x0e;case 1:return new Sae(Xr(t[0]));default:return new ooe(U4n(t))}}function D1t(e,t){e.Xj();try{e.d.bd(e.e++,t),e.f=e.d.j,e.g=-1}catch(n){throw n=bs(n),De(n,77)?ue(new Xh):ue(n)}}function Wce(){Wce=U,ipe=new NS,MPe=new H0,DPe=new AI,IPe=new LI,OPe=new f8,NPe=new tre,PPe=new nre,BPe=new rre,FPe=new ire}function KV(e,t){iye();var n,r;return n=MO((zz(),zz(),NL)),r=null,t==n&&(r=l(xu(KSe,e),624)),r||(r=new Xst(e),t==n&&rc(KSe,e,r)),r}function I1t(e){By();var t;return(e.q?e.q:(Cn(),Cn(),mg))._b((Nt(),g3))?t=l(Q(e,g3),203):t=l(Q(eo(e),eM),203),t}function Py(e,t){var n,r;return r=null,ns(e,(Nt(),kW))&&(n=l(Q(e,kW),96),n.pf(t)&&(r=n.of(t))),r==null&&(r=Q(eo(e),t)),r}function O1t(e,t){var n,r,a;return De(t,44)?(n=l(t,44),r=n.ld(),a=Oy(e.Rc(),r),yd(a,n.md())&&(a!=null||e.Rc()._b(r))):!1}function n1(e,t){var n,r,a;return e.f>0&&(e._j(),r=t==null?0:es(t),a=(r&Ii)%e.d.length,n=y9e(e,a,r,t),n)?n.md():null}function Ru(e,t,n){var r,a,o;return e.Pj()?(r=e.i,o=e.Qj(),IN(e,r,t),a=e.Ij(3,null,t,r,o),n?n.nj(a):n=a):IN(e,e.i,t),n}function A5n(e,t,n){var r,a;return r=new Zg(e.e,4,10,(a=t.c,De(a,90)?l(a,29):(Tn(),Kf)),null,f2(e,t),!1),n?n.nj(r):n=r,n}function L5n(e,t,n){var r,a;return r=new Zg(e.e,3,10,null,(a=t.c,De(a,90)?l(a,29):(Tn(),Kf)),f2(e,t),!1),n?n.nj(r):n=r,n}function N1t(e){py();var t;return t=new Eo(l(e.e.of((pi(),i7)),8)),e.B.Hc((Zl(),aC))&&(t.a<=0&&(t.a=20),t.b<=0&&(t.b=20)),t}function kb(e){Cd();var t,n;return n=Yr(e),t=Yr(ub(e,32)),t!=0?new qot(n,t):n>10||n<0?new Qg(1,n):y6t[n]}function RN(e,t){var n;return wc(e)&&wc(t)&&(n=e%t,_P=0?o=o.a[1]:(a=o,o=o.a[0])}return a}function $N(e,t,n){var r,a,o;for(a=null,o=e.b;o;){if(r=e.a.Ne(t,o.d),n&&r==0)return o;r<=0?o=o.a[0]:(a=o,o=o.a[1])}return a}function P5n(e,t,n,r){var a,o,f;return a=!1,RMn(e.f,n,r)&&(r6n(e.f,e.a[t][n],e.a[t][r]),o=e.a[t],f=o[r],o[r]=o[n],o[n]=f,a=!0),a}function R1t(e,t,n){var r,a,o,f;for(a=l(cr(e.b,n),183),r=0,f=new G(t.j);f.a>5,t&=31,a=e.d+n+(t==0?0:1),r=We(Vr,di,28,a,15,1),Oxn(r,e.a,n,t),o=new Im(e.e,a,r),iA(o),o}function B5n(e,t){var n,r,a;for(r=new hr(dr(qs(e).a.Kc(),new j));jr(r);)if(n=l(xr(r),18),a=n.d.i,a.c==t)return!1;return!0}function R8e(e,t,n){var r,a,o,f,g;return f=e.k,g=t.k,r=n[f.g][g.g],a=Ge(Py(e,r)),o=Ge(Py(t,r)),b.Math.max((nr(a),a),(nr(o),o))}function F5n(){return Error.stackTraceLimit>0?(b.Error.stackTraceLimit=Error.stackTraceLimit=64,!0):"stack"in new Error}function R5n(e,t){return A1(),A1(),f0(Ab),(b.Math.abs(e-t)<=Ab||e==t||isNaN(e)&&isNaN(t)?0:et?1:uw(isNaN(e),isNaN(t)))>0}function j8e(e,t){return A1(),A1(),f0(Ab),(b.Math.abs(e-t)<=Ab||e==t||isNaN(e)&&isNaN(t)?0:et?1:uw(isNaN(e),isNaN(t)))<0}function $1t(e,t){return A1(),A1(),f0(Ab),(b.Math.abs(e-t)<=Ab||e==t||isNaN(e)&&isNaN(t)?0:et?1:uw(isNaN(e),isNaN(t)))<=0}function Xce(e,t){for(var n=0;!t[n]||t[n]=="";)n++;for(var r=t[n++];n0&&this.b>0&&(this.g=aH(this.c,this.b,this.a))}function j5n(e,t){var n=e.a,r;t=String(t),n.hasOwnProperty(t)&&(r=n[t]);var a=(vce(),_0e)[typeof r],o=a?a(r):Z7e(typeof r);return o}function NE(e){var t,n,r;if(r=null,t=Pd in e.a,n=!t,n)throw ue(new dd("Every element must have an id."));return r=xx(Wg(e,Pd)),r}function jw(e){var t,n;for(n=fpt(e),t=null;e.c==2;)Li(e),t||(t=(Di(),Di(),new B_(2)),Qm(t,n),n=t),n.Jm(fpt(e));return n}function YV(e,t){var n,r,a;return e._j(),r=t==null?0:es(t),a=(r&Ii)%e.d.length,n=y9e(e,a,r,t),n?(Wht(e,n),n.md()):null}function K1t(e,t){return e.e>t.e?1:e.et.d?e.e:e.d=48&&e<48+b.Math.min(10,10)?e-48:e>=97&&e<97?e-97+10:e>=65&&e<65?e-65+10:-1}function $5n(e,t){if(t.c==e)return t.d;if(t.d==e)return t.c;throw ue(new Yn("Input edge is not connected to the input port."))}function z5n(e){if(QV(wT,e))return Hn(),ST;if(QV(Ffe,e))return Hn(),Pb;throw ue(new Yn("Expecting true or false"))}function q8e(e){switch(typeof e){case Ile:return s2(e);case Qke:return j8(e);case Cx:return Art(e);default:return e==null?0:fw(e)}}function Td(e,t){if(e.a<0)throw ue(new nc("Did not call before(...) or after(...) before calling add(...)."));return Bye(e,e.a,t),e}function H8e(e){return BH(),De(e,162)?l(cr(lF,C6t),295).Rg(e):Hu(lF,bh(e))?l(cr(lF,bh(e)),295).Rg(e):null}function Ku(e){var t,n;return e.Db&32||(n=(t=l(Kn(e,16),29),yr(t||e.ii())-yr(e.ii())),n!=0&&px(e,32,We(wa,Rn,1,n,5,1))),e}function px(e,t,n){var r;e.Db&t?n==null?TEn(e,t):(r=mue(e,t),r==-1?e.Eb=n:Ts(jm(e.Eb),r,n)):n!=null&&KCn(e,t,n)}function q5n(e,t,n,r){var a,o;t.c.length!=0&&(a=FTn(n,r),o=Rkn(t),Is(lV(new bn(null,new kn(o,1)),new a8),new Cat(e,n,a,r)))}function H5n(e,t){var n,r,a,o;return r=e.a.length-1,n=t-e.b&r,o=e.c-t&r,a=e.c-e.b&r,Ert(n=o?(zyn(e,t),-1):($yn(e,t),1)}function XV(e){var t,n,r;if(r=e.Jh(),!r)for(t=0,n=e.Ph();n;n=n.Ph()){if(++t>ohe)return n.Qh();if(r=n.Jh(),r||n==e)break}return r}function Y1t(e,t){var n;return qe(t)===qe(e)?!0:!De(t,21)||(n=l(t,21),n.gc()!=e.gc())?!1:e.Ic(n)}function V5n(e,t){return e.et.e?1:e.ft.f?1:es(e)-es(t)}function QV(e,t){return nr(e),t==null?!1:vn(e,t)?!0:e.length==t.length&&vn(e.toLowerCase(),t.toLowerCase())}function ap(e){var t,n;return iu(e,-129)>0&&iu(e,128)<0?(Zit(),t=Yr(e)+128,n=n_e[t],!n&&(n=n_e[t]=new Or(e)),n):new Or(e)}function Km(){Km=U,c4=new dq(Id,0),bAe=new dq("INSIDE_PORT_SIDE_GROUPS",1),o1e=new dq("GROUP_MODEL_ORDER",2),c1e=new dq($Ee,3)}function U5n(e){var t;return e.b||Run(e,(t=Ffn(e.e,e.a),!t||!vn(Ffe,n1((!t.b&&(t.b=new dh((Tn(),No),Yc,t)),t.b),"qualified")))),e.c}function G5n(e,t){var n,r;for(n=(Xn(t,e.length),e.charCodeAt(t)),r=t+1;r2e3&&(l6t=e,oK=b.setTimeout(Hun,10))),aK++==0?(swn((Xwe(),GSe)),!0):!1}function a6n(e,t,n){var r;(I6t?(u5n(e),!0):O6t||P6t?(Dk(),!0):N6t&&(Dk(),!1))&&(r=new fit(t),r.b=n,g9n(e,r))}function Jce(e,t){var n;n=!e.A.Hc((mh(),Cv))||e.q==(Ra(),Mu),e.u.Hc((Rl(),vp))?n?YDn(e,t):Vvt(e,t):e.u.Hc(Yb)&&(n?pDn(e,t):swt(e,t))}function tdt(e){var t;qe(at(e,(pi(),n7)))===qe((rp(),oY))&&(ds(e)?(t=l(at(ds(e),n7),346),Hi(e,n7,t)):Hi(e,n7,DM))}function o6n(e){var t,n;return ns(e.d.i,(Nt(),HT))?(t=l(Q(e.c.i,HT),17),n=l(Q(e.d.i,HT),17),ru(t.a,n.a)>0):!1}function ndt(e,t,n){return new ef(b.Math.min(e.a,t.a)-n/2,b.Math.min(e.b,t.b)-n/2,b.Math.abs(e.a-t.a)+n,b.Math.abs(e.b-t.b)+n)}function rdt(e){var t;this.d=new bt,this.j=new qa,this.g=new qa,t=e.g.b,this.f=l(Q(eo(t),(Nt(),Rh)),88),this.e=ze(Ge(tU(t,y4)))}function idt(e){this.d=new bt,this.e=new e2,this.c=We(Vr,di,28,(Ct(),he(le(Oo,1),au,64,0,[Pc,Qn,ar,Dr,er])).length,15,1),this.b=e}function G8e(e,t,n){var r;switch(r=n[e.g][t],e.g){case 1:case 3:return new lt(0,r);case 2:case 4:return new lt(r,0);default:return null}}function sdt(e,t,n){var r,a;a=l(GO(t.f),205);try{a.rf(e,n),lat(t.f,a)}catch(o){throw o=bs(o),De(o,103)?(r=o,ue(r)):ue(o)}}function adt(e,t,n){var r,a,o,f,g,w;return r=null,g=Fke(hE(),t),o=null,g&&(a=null,w=Pke(g,n),f=null,w!=null&&(f=e.qf(g,w)),a=f,o=a),r=o,r}function Zce(e,t,n,r){var a;if(a=e.length,t>=a)return a;for(t=t>0?t:0;tr&&Ts(t,r,null),t}function odt(e,t){var n,r;for(r=e.a.length,t.lengthr&&Ts(t,r,null),t}function PE(e,t){var n,r;if(++e.j,t!=null&&(n=(r=e.a.Cb,De(r,99)?l(r,99).th():null),fEn(t,n))){px(e.a,4,n);return}px(e.a,4,l(t,129))}function c6n(e){var t;if(e==null)return null;if(t=dTn(Tu(e,!0)),t==null)throw ue(new Jie("Invalid hexBinary value: '"+e+"'"));return t}function JV(e,t,n){var r;t.a.length>0&&(vt(e.b,new Ait(t.a,n)),r=t.a.length,0r&&(t.a+=Mnt(We(kf,Ad,28,-r,15,1))))}function cdt(e,t,n){var r,a,o;if(!n[t.d])for(n[t.d]=!0,a=new G(Z5(t));a.a=e.b>>1)for(r=e.c,n=e.b;n>t;--n)r=r.b;else for(r=e.a.a,n=0;n=0?e.Wh(a):que(e,r)):n<0?que(e,r):l(r,69).wk().Bk(e,e.hi(),n)}function fdt(e){var t,n,r;for(r=(!e.o&&(e.o=new xl((su(),Cg),L2,e,0)),e.o),n=r.c.Kc();n.e!=n.i.gc();)t=l(n.Yj(),44),t.md();return iN(r)}function It(e){var t;if(De(e.a,4)){if(t=H8e(e.a),t==null)throw ue(new nc(Nyt+e.b+"'. "+Oyt+(Gg(hF),hF.k)+JCe));return t}else return e.a}function b6n(e,t){var n,r;if(e.j.length!=t.j.length)return!1;for(n=0,r=e.j.length;n=64&&t<128&&(a=Q0(a,l0(1,t-64)));return a}function tU(e,t){var n,r;return r=null,ns(e,(pi(),r9))&&(n=l(Q(e,r9),96),n.pf(t)&&(r=n.of(t))),r==null&&eo(e)&&(r=Q(eo(e),t)),r}function m6n(e,t){var n;return n=l(Q(e,(Nt(),cc)),75),Zse(t,O8t)?n?Ch(n):(n=new bl,rt(e,cc,n)):n&&rt(e,cc,null),n}function IA(){IA=U,X_e=(pi(),_Ne),W0e=oNe,I7t=Z6,Y_e=_2,B7t=(dU(),A_e),P7t=S_e,F7t=M_e,N7t=C_e,O7t=(Lce(),G_e),K0e=L7t,W_e=M7t,vK=D7t}function nU(e){switch(w3e(),this.c=new bt,this.d=e,e.g){case 0:case 2:this.a=_5e(pAe),this.b=gs;break;case 3:case 1:this.a=pAe,this.b=ia}}function v6n(e){var t;U8(l(Q(e,(Nt(),Ms)),101))&&(t=e.b,e2t((Sn(0,t.c.length),l(t.c[0],30))),e2t(l(jt(t,t.c.length-1),30)))}function w6n(e,t){t.Ug("Self-Loop post-processing",1),Is(Fi(Fi(Dc(new bn(null,new kn(e.b,16)),new RZ),new jZ),new $Z),new Ej),t.Vg()}function ddt(e,t,n){var r,a;if(e.c)Uu(e.c,e.c.i+t),Gu(e.c,e.c.j+n);else for(a=new G(e.b);a.a=0&&(n.d=e.t);break;case 3:e.t>=0&&(n.a=e.t)}e.C&&(n.b=e.C.b,n.c=e.C.c)}function OA(){OA=U,vDe=new hO(cCe,0),vde=new hO($he,1),wde=new hO("LINEAR_SEGMENTS",2),rM=new hO("BRANDES_KOEPF",3),iM=new hO(cyt,4)}function NA(){NA=U,uB=new hq(nG,0),bK=new hq(yhe,1),mK=new hq(xhe,2),lB=new hq(khe,3),uB.a=!1,bK.a=!0,mK.a=!1,lB.a=!0}function bx(){bx=U,aB=new lq(nG,0),sB=new lq(yhe,1),oB=new lq(xhe,2),cB=new lq(khe,3),aB.a=!1,sB.a=!0,oB.a=!1,cB.a=!0}function mx(e,t,n,r){var a;return n>=0?e.Sh(t,n,r):(e.Ph()&&(r=(a=e.Fh(),a>=0?e.Ah(r):e.Ph().Th(e,-1-a,null,r))),e.Ch(t,n,r))}function K8e(e,t){switch(t){case 7:!e.e&&(e.e=new Ln(js,e,7,4)),$r(e.e);return;case 8:!e.d&&(e.d=new Ln(js,e,8,5)),$r(e.d);return}N8e(e,t)}function Hi(e,t,n){return n==null?(!e.o&&(e.o=new xl((su(),Cg),L2,e,0)),YV(e.o,t)):(!e.o&&(e.o=new xl((su(),Cg),L2,e,0)),GN(e.o,t,n)),e}function mdt(e,t){Cn();var n,r,a,o;for(n=e,o=t,De(e,21)&&!De(t,21)&&(n=t,o=e),a=n.Kc();a.Ob();)if(r=a.Pb(),o.Hc(r))return!1;return!0}function T6n(e,t,n,r){if(t.an.b)return!0}return!1}function iue(e,t){return Ia(e)?!!r6t[t]:e.Sm?!!e.Sm[t]:fy(e)?!!n6t[t]:hy(e)?!!t6t[t]:!1}function C6n(e){var t;t=e.a;do t=l(xr(new hr(dr(ka(t).a.Kc(),new j))),18).c.i,t.k==(Zn(),Aa)&&e.b.Fc(t);while(t.k==(Zn(),Aa));e.b=lf(e.b)}function vdt(e,t){var n,r,a;for(a=e,r=new hr(dr(ka(t).a.Kc(),new j));jr(r);)n=l(xr(r),18),n.c.i.c&&(a=b.Math.max(a,n.c.i.c.p));return a}function S6n(e,t){var n,r,a;for(a=0,r=l(l($i(e.r,t),21),87).Kc();r.Ob();)n=l(r.Pb(),117),a+=n.d.d+n.b.Mf().b+n.d.a,r.Ob()&&(a+=e.w);return a}function _6n(e,t){var n,r,a;for(a=0,r=l(l($i(e.r,t),21),87).Kc();r.Ob();)n=l(r.Pb(),117),a+=n.d.b+n.b.Mf().a+n.d.c,r.Ob()&&(a+=e.w);return a}function wdt(e){var t,n,r,a;if(r=0,a=Hy(e),a.c.length==0)return 1;for(n=new G(a);n.a=0?e.Lh(f,n,!0):Hw(e,o,n)):l(o,69).wk().yk(e,e.hi(),a,n,r)}function D6n(e,t,n,r){var a,o;o=t.pf((pi(),r7))?l(t.of(r7),21):e.j,a=p4n(o),a!=(YU(),H0e)&&(n&&!$8e(a)||Jxe(gTn(e,a,r),t))}function I6n(e){switch(e.g){case 1:return Pw(),iB;case 3:return Pw(),rB;case 2:return Pw(),U0e;case 4:return Pw(),V0e;default:return null}}function O6n(e,t,n){if(e.e)switch(e.b){case 1:Epn(e.c,t,n);break;case 0:Tpn(e.c,t,n)}else $ct(e.c,t,n);e.a[t.p][n.p]=e.c.i,e.a[n.p][t.p]=e.c.e}function ydt(e){var t,n;if(e==null)return null;for(n=We(wg,dt,199,e.length,0,2),t=0;t=0)return a;if(e.ol()){for(r=0;r=a)throw ue(new my(t,a));if(e.Si()&&(r=e.dd(n),r>=0&&r!=t))throw ue(new Yn(WP));return e.Xi(t,n)}function W8e(e,t){if(this.a=l(Xr(e),253),this.b=l(Xr(t),253),e.Ed(t)>0||e==(Uie(),w0e)||t==(Gie(),y0e))throw ue(new Yn("Invalid range: "+Hct(e,t)))}function xdt(e){var t,n;for(this.b=new bt,this.c=e,this.a=!1,n=new G(e.a);n.a0),(t&-t)==t)return ua(t*Jl(e,31)*4656612873077393e-25);do n=Jl(e,31),r=n%t;while(n-r+(t-1)<0);return ua(r)}function j6n(e,t,n){switch(n.g){case 1:e.a=t.a/2,e.b=0;break;case 2:e.a=t.a,e.b=t.b/2;break;case 3:e.a=t.a/2,e.b=t.b;break;case 4:e.a=0,e.b=t.b/2}}function zN(e,t,n,r){var a,o;for(a=t;a1&&(o=P6n(e,t)),o}function Tdt(e){var t;return t=ze(Ge(at(e,(pi(),QB))))*b.Math.sqrt((!e.a&&(e.a=new nt(Ai,e,10,11)),e.a).i),new lt(t,t/ze(Ge(at(e,sY))))}function aue(e){var t;return e.f&&e.f.Vh()&&(t=l(e.f,54),e.f=l(yb(e,t),84),e.f!=t&&e.Db&4&&!(e.Db&1)&&Ni(e,new _a(e,9,8,t,e.f))),e.f}function oue(e){var t;return e.i&&e.i.Vh()&&(t=l(e.i,54),e.i=l(yb(e,t),84),e.i!=t&&e.Db&4&&!(e.Db&1)&&Ni(e,new _a(e,9,7,t,e.i))),e.i}function Ro(e){var t;return e.b&&e.b.Db&64&&(t=e.b,e.b=l(yb(e,t),19),e.b!=t&&e.Db&4&&!(e.Db&1)&&Ni(e,new _a(e,9,21,t,e.b))),e.b}function oU(e,t){var n,r,a;e.d==null?(++e.e,++e.f):(r=t.Bi(),cCn(e,e.f+1),a=(r&Ii)%e.d.length,n=e.d[a],!n&&(n=e.d[a]=e.dk()),n.Fc(t),++e.f)}function Q8e(e,t,n){var r;return t.tk()?!1:t.Ik()!=-2?(r=t.ik(),r==null?n==null:Pi(r,n)):t.qk()==e.e.Dh()&&n==null}function cU(){var e;Mh(16,Pwt),e=cft(16),this.b=We(k0e,TP,303,e,0,1),this.c=We(k0e,TP,303,e,0,1),this.a=null,this.e=null,this.i=0,this.f=e-1,this.g=0}function op(e){r4e.call(this),this.k=(Zn(),Ps),this.j=(Mh(6,Yy),new Bu(6)),this.b=(Mh(2,Yy),new Bu(2)),this.d=new $ie,this.f=new Rwe,this.a=e}function z6n(e){var t,n;e.c.length<=1||(t=Abt(e,(Ct(),Dr)),ppt(e,l(t.a,17).a,l(t.b,17).a),n=Abt(e,er),ppt(e,l(n.a,17).a,l(n.b,17).a))}function q6n(e,t,n){var r,a;for(a=e.a.b,r=a.c.length;r102?-1:e<=57?e-48:e<65?-1:e<=70?e-65+10:e<97?-1:e-97+10}function fue(e,t){if(e==null)throw ue(new D8("null key in entry: null="+t));if(t==null)throw ue(new D8("null value in entry: "+e+"=null"))}function U6n(e,t){for(var n,r;e.Ob();)if(!t.Ob()||(n=e.Pb(),r=t.Pb(),!(qe(n)===qe(r)||n!=null&&Pi(n,r))))return!1;return!t.Ob()}function _dt(e,t){var n;return n=he(le(Na,1),Zo,28,15,[Dce(e.a[0],t),Dce(e.a[1],t),Dce(e.a[2],t)]),e.d&&(n[0]=b.Math.max(n[0],n[2]),n[2]=n[0]),n}function Adt(e,t){var n;return n=he(le(Na,1),Zo,28,15,[BV(e.a[0],t),BV(e.a[1],t),BV(e.a[2],t)]),e.d&&(n[0]=b.Math.max(n[0],n[2]),n[2]=n[0]),n}function Z8e(e,t,n){U8(l(Q(t,(Nt(),Ms)),101))||(d6e(e,t,d2(t,n)),d6e(e,t,d2(t,(Ct(),Dr))),d6e(e,t,d2(t,Qn)),Cn(),Vs(t.j,new IYe(e)))}function Ldt(e){var t,n;for(e.c||lMn(e),n=new bl,t=new G(e.a),re(t);t.a0&&(Xn(0,t.length),t.charCodeAt(0)==43)?(Xn(1,t.length+1),t.substr(1)):t))}function s7n(e){var t;return e==null?null:new ob((t=Tu(e,!0),t.length>0&&(Xn(0,t.length),t.charCodeAt(0)==43)?(Xn(1,t.length+1),t.substr(1)):t))}function txe(e,t,n,r,a,o,f,g){var w,E;r&&(w=r.a[0],w&&txe(e,t,n,w,a,o,f,g),xue(e,n,r.d,a,o,f,g)&&t.Fc(r),E=r.a[1],E&&txe(e,t,n,E,a,o,f,g))}function r6(e,t,n){try{return cw(nce(e,t,n),1)}catch(r){throw r=bs(r),De(r,333)?ue(new tc(Ehe+e.o+"*"+e.p+The+t+Co+n+Che)):ue(r)}}function Ndt(e,t,n){try{return cw(nce(e,t,n),0)}catch(r){throw r=bs(r),De(r,333)?ue(new tc(Ehe+e.o+"*"+e.p+The+t+Co+n+Che)):ue(r)}}function Pdt(e,t,n){try{return cw(nce(e,t,n),2)}catch(r){throw r=bs(r),De(r,333)?ue(new tc(Ehe+e.o+"*"+e.p+The+t+Co+n+Che)):ue(r)}}function Bdt(e,t){if(e.g==-1)throw ue(new pl);e.Xj();try{e.d.hd(e.g,t),e.f=e.d.j}catch(n){throw n=bs(n),De(n,77)?ue(new Xh):ue(n)}}function a7n(e){var t,n,r,a,o;for(r=new G(e.b);r.ao&&Ts(t,o,null),t}function o7n(e,t){var n,r;if(r=e.gc(),t==null){for(n=0;n0&&(w+=a),E[C]=f,f+=g*(w+r)}function Rdt(e){var t,n,r;for(r=e.f,e.n=We(Na,Zo,28,r,15,1),e.d=We(Na,Zo,28,r,15,1),t=0;t0?e.c:0),++a;e.b=r,e.d=o}function Hdt(e,t){var n;return n=he(le(Na,1),Zo,28,15,[X8e(e,(t1(),Gc),t),X8e(e,$u,t),X8e(e,Kc,t)]),e.f&&(n[0]=b.Math.max(n[0],n[2]),n[2]=n[0]),n}function p7n(e,t,n){var r;try{FU(e,t+e.j,n+e.k,!1,!0)}catch(a){throw a=bs(a),De(a,77)?(r=a,ue(new tc(r.g+iG+t+Co+n+")."))):ue(a)}}function b7n(e,t,n){var r;try{FU(e,t+e.j,n+e.k,!0,!1)}catch(a){throw a=bs(a),De(a,77)?(r=a,ue(new tc(r.g+iG+t+Co+n+")."))):ue(a)}}function Vdt(e){var t;ns(e,(Nt(),d3))&&(t=l(Q(e,d3),21),t.Hc((qy(),E0))?(t.Mc(E0),t.Fc(T0)):t.Hc(T0)&&(t.Mc(T0),t.Fc(E0)))}function Udt(e){var t;ns(e,(Nt(),d3))&&(t=l(Q(e,d3),21),t.Hc((qy(),S0))?(t.Mc(S0),t.Fc(qf)):t.Hc(qf)&&(t.Mc(qf),t.Fc(S0)))}function vue(e,t,n,r){var a,o,f,g;return e.a==null&&v9n(e,t),f=t.b.j.c.length,o=n.d.p,g=r.d.p,a=g-1,a<0&&(a=f-1),o<=a?e.a[a]-e.a[o]:e.a[f-1]-e.a[o]+e.a[a]}function m7n(e){var t,n;if(!e.b)for(e.b=$H(l(e.f,27).kh().i),n=new or(l(e.f,27).kh());n.e!=n.i.gc();)t=l(gr(n),135),vt(e.b,new Yie(t));return e.b}function v7n(e){var t,n;if(!e.e)for(e.e=$H(Xae(l(e.f,27)).i),n=new or(Xae(l(e.f,27)));n.e!=n.i.gc();)t=l(gr(n),123),vt(e.e,new BXe(t));return e.e}function Gdt(e){var t,n;if(!e.a)for(e.a=$H(AH(l(e.f,27)).i),n=new or(AH(l(e.f,27)));n.e!=n.i.gc();)t=l(gr(n),27),vt(e.a,new rae(e,t));return e.a}function zw(e){var t;if(!e.C&&(e.D!=null||e.B!=null))if(t=sDn(e),t)e.hl(t);else try{e.hl(null)}catch(n){if(n=bs(n),!De(n,63))throw ue(n)}return e.C}function w7n(e){switch(e.q.g){case 5:bgt(e,(Ct(),Qn)),bgt(e,Dr);break;case 4:vvt(e,(Ct(),Qn)),vvt(e,Dr);break;default:xpt(e,(Ct(),Qn)),xpt(e,Dr)}}function y7n(e){switch(e.q.g){case 5:mgt(e,(Ct(),ar)),mgt(e,er);break;case 4:wvt(e,(Ct(),ar)),wvt(e,er);break;default:kpt(e,(Ct(),ar)),kpt(e,er)}}function i6(e,t){var n,r,a;for(a=new qa,r=e.Kc();r.Ob();)n=l(r.Pb(),36),KE(n,a.a,0),a.a+=n.f.a+t,a.b=b.Math.max(a.b,n.f.b);return a.b>0&&(a.b+=t),a}function hU(e,t){var n,r,a;for(a=new qa,r=e.Kc();r.Ob();)n=l(r.Pb(),36),KE(n,0,a.b),a.b+=n.f.b+t,a.a=b.Math.max(a.a,n.f.a);return a.a>0&&(a.a+=t),a}function Kdt(e){var t,n,r;for(r=Ii,n=new G(e.a);n.a>16==6?e.Cb.Th(e,5,u1,t):(r=Ro(l(Mn((n=l(Kn(e,16),29),n||e.ii()),e.Db>>16),19)),e.Cb.Th(e,r.n,r.f,t))}function x7n(e){Xk();var t=e.e;if(t&&t.stack){var n=t.stack,r=t+` +`;return n.substring(0,r.length)==r&&(n=n.substring(r.length)),n.split(` +`)}return[]}function k7n(e){var t;return t=(Qht(),p6t),t[e>>>28]|t[e>>24&15]<<4|t[e>>20&15]<<8|t[e>>16&15]<<12|t[e>>12&15]<<16|t[e>>8&15]<<20|t[e>>4&15]<<24|t[e&15]<<28}function Xdt(e){var t,n,r;e.b==e.c&&(r=e.a.length,n=P7e(b.Math.max(8,r))<<1,e.b!=0?(t=c0(e.a,n),fft(e,t,r),e.a=t,e.b=0):ay(e.a,n),e.c=r)}function E7n(e,t){var n;return n=e.b,n.pf((pi(),rh))?n.ag()==(Ct(),er)?-n.Mf().a-ze(Ge(n.of(rh))):t+ze(Ge(n.of(rh))):n.ag()==(Ct(),er)?-n.Mf().a:t}function HN(e){var t;return e.b.c.length!=0&&l(jt(e.b,0),72).a?l(jt(e.b,0),72).a:(t=Qae(e),t??""+(e.c?gc(e.c.a,e,0):-1))}function fU(e){var t;return e.f.c.length!=0&&l(jt(e.f,0),72).a?l(jt(e.f,0),72).a:(t=Qae(e),t??""+(e.i?gc(e.i.j,e,0):-1))}function T7n(e,t){var n,r;if(t<0||t>=e.gc())return null;for(n=t;n0?e.c:0),a=b.Math.max(a,t.d),++r;e.e=o,e.b=a}function S7n(e){var t,n;if(!e.b)for(e.b=$H(l(e.f,123).kh().i),n=new or(l(e.f,123).kh());n.e!=n.i.gc();)t=l(gr(n),135),vt(e.b,new Yie(t));return e.b}function _7n(e,t){var n,r,a;if(t.dc())return Fk(),Fk(),fF;for(n=new Ort(e,t.gc()),a=new or(e);a.e!=a.i.gc();)r=gr(a),t.Hc(r)&&qr(n,r);return n}function sxe(e,t,n,r){return t==0?r?(!e.o&&(e.o=new xl((su(),Cg),L2,e,0)),e.o):(!e.o&&(e.o=new xl((su(),Cg),L2,e,0)),iN(e.o)):rU(e,t,n,r)}function yue(e){var t,n;if(e.rb)for(t=0,n=e.rb.i;t>22),a+=r>>22,a<0)?!1:(e.l=n&eh,e.m=r&eh,e.h=a&hp,!0)}function xue(e,t,n,r,a,o,f){var g,w;return!(t.Te()&&(w=e.a.Ne(n,r),w<0||!a&&w==0)||t.Ue()&&(g=e.a.Ne(n,o),g>0||!f&&g==0))}function D7n(e,t){TE();var n;if(n=e.j.g-t.j.g,n!=0)return 0;switch(e.j.g){case 2:return zce(t,cLe)-zce(e,cLe);case 4:return zce(e,oLe)-zce(t,oLe)}return 0}function I7n(e){switch(e.g){case 0:return D1e;case 1:return I1e;case 2:return O1e;case 3:return N1e;case 4:return QK;case 5:return P1e;default:return null}}function ac(e,t,n){var r,a;return r=(a=new Hie,Gm(a,t),Fu(a,n),qr((!e.c&&(e.c=new nt(k3,e,12,10)),e.c),a),a),i2(r,0),My(r,1),u2(r,!0),c2(r,!0),r}function vx(e,t){var n,r;if(t>=e.i)throw ue(new Vse(t,e.i));return++e.j,n=e.g[t],r=e.i-t-1,r>0&&pu(e.g,t+1,e.g,t,r),Ts(e.g,--e.i,null),e.Qi(t,n),e.Ni(),n}function Qdt(e,t){var n,r;return e.Db>>16==17?e.Cb.Th(e,21,Vf,t):(r=Ro(l(Mn((n=l(Kn(e,16),29),n||e.ii()),e.Db>>16),19)),e.Cb.Th(e,r.n,r.f,t))}function O7n(e){var t,n,r,a;for(Cn(),Vs(e.c,e.a),a=new G(e.c);a.an.a.c.length))throw ue(new Yn("index must be >= 0 and <= layer node count"));e.c&&al(e.c.a,e),e.c=n,n&&pw(n.a,t,e)}function ngt(e,t){var n,r,a;for(r=new hr(dr(sp(e).a.Kc(),new j));jr(r);)return n=l(xr(r),18),a=l(t.Kb(n),10),new JS(Xr(a.n.b+a.o.b/2));return o_(),o_(),v0e}function rgt(e,t){this.c=new Pr,this.a=e,this.b=t,this.d=l(Q(e,(ft(),$6)),312),qe(Q(e,(Nt(),GMe)))===qe((cN(),JK))?this.e=new XQe:this.e=new YQe}function BA(e,t){var n,r;return r=null,e.pf((pi(),r9))&&(n=l(e.of(r9),96),n.pf(t)&&(r=n.of(t))),r==null&&e.Tf()&&(r=e.Tf().of(t)),r==null&&(r=It(t)),r}function kue(e,t){var n,r;n=e.fd(t);try{return r=n.Pb(),n.Qb(),r}catch(a){throw a=bs(a),De(a,112)?ue(new tc("Can't remove element "+t)):ue(a)}}function z7n(e,t){var n,r,a;if(r=new Qz,a=new R7e(r.q.getFullYear()-Lb,r.q.getMonth(),r.q.getDate()),n=JAn(e,t,a),n==0||n0?t:0),++n;return new lt(r,a)}function lxe(e,t){var n,r;return e.Db>>16==6?e.Cb.Th(e,6,js,t):(r=Ro(l(Mn((n=l(Kn(e,16),29),n||(su(),pY)),e.Db>>16),19)),e.Cb.Th(e,r.n,r.f,t))}function hxe(e,t){var n,r;return e.Db>>16==7?e.Cb.Th(e,1,oF,t):(r=Ro(l(Mn((n=l(Kn(e,16),29),n||(su(),dPe)),e.Db>>16),19)),e.Cb.Th(e,r.n,r.f,t))}function fxe(e,t){var n,r;return e.Db>>16==9?e.Cb.Th(e,9,Ai,t):(r=Ro(l(Mn((n=l(Kn(e,16),29),n||(su(),pPe)),e.Db>>16),19)),e.Cb.Th(e,r.n,r.f,t))}function agt(e,t){var n,r;return e.Db>>16==5?e.Cb.Th(e,9,TY,t):(r=Ro(l(Mn((n=l(Kn(e,16),29),n||(Tn(),D2)),e.Db>>16),19)),e.Cb.Th(e,r.n,r.f,t))}function ogt(e,t){var n,r;return e.Db>>16==7?e.Cb.Th(e,6,u1,t):(r=Ro(l(Mn((n=l(Kn(e,16),29),n||(Tn(),O2)),e.Db>>16),19)),e.Cb.Th(e,r.n,r.f,t))}function dxe(e,t){var n,r;return e.Db>>16==3?e.Cb.Th(e,0,uF,t):(r=Ro(l(Mn((n=l(Kn(e,16),29),n||(Tn(),M2)),e.Db>>16),19)),e.Cb.Th(e,r.n,r.f,t))}function cgt(){this.a=new T$,this.g=new cU,this.j=new cU,this.b=new Pr,this.d=new cU,this.i=new cU,this.k=new Pr,this.c=new Pr,this.e=new Pr,this.f=new Pr}function V7n(e,t,n){var r,a,o;for(n<0&&(n=0),o=e.i,a=n;aohe)return FE(e,r);if(r==e)return!0}}return!1}function G7n(e){switch(zq(),e.q.g){case 5:Vpt(e,(Ct(),Qn)),Vpt(e,Dr);break;case 4:U2t(e,(Ct(),Qn)),U2t(e,Dr);break;default:Wvt(e,(Ct(),Qn)),Wvt(e,Dr)}}function K7n(e){switch(zq(),e.q.g){case 5:u2t(e,(Ct(),ar)),u2t(e,er);break;case 4:gdt(e,(Ct(),ar)),gdt(e,er);break;default:Yvt(e,(Ct(),ar)),Yvt(e,er)}}function W7n(e){var t,n;t=l(Q(e,(b0(),e8t)),17),t?(n=t.a,n==0?rt(e,(bb(),EK),new Uce):rt(e,(bb(),EK),new VH(n))):rt(e,(bb(),EK),new VH(1))}function Y7n(e,t){var n;switch(n=e.i,t.g){case 1:return-(e.n.b+e.o.b);case 2:return e.n.a-n.o.a;case 3:return e.n.b-n.o.b;case 4:return-(e.n.a+e.o.a)}return 0}function X7n(e,t){switch(e.g){case 0:return t==(hf(),$b)?HK:VK;case 1:return t==(hf(),$b)?HK:pB;case 2:return t==(hf(),$b)?pB:VK;default:return pB}}function UN(e,t){var n,r,a;for(al(e.a,t),e.e-=t.r+(e.a.c.length==0?0:e.c),a=xCe,r=new G(e.a);r.a>16==3?e.Cb.Th(e,12,Ai,t):(r=Ro(l(Mn((n=l(Kn(e,16),29),n||(su(),fPe)),e.Db>>16),19)),e.Cb.Th(e,r.n,r.f,t))}function pxe(e,t){var n,r;return e.Db>>16==11?e.Cb.Th(e,10,Ai,t):(r=Ro(l(Mn((n=l(Kn(e,16),29),n||(su(),gPe)),e.Db>>16),19)),e.Cb.Th(e,r.n,r.f,t))}function ugt(e,t){var n,r;return e.Db>>16==10?e.Cb.Th(e,11,Vf,t):(r=Ro(l(Mn((n=l(Kn(e,16),29),n||(Tn(),I2)),e.Db>>16),19)),e.Cb.Th(e,r.n,r.f,t))}function lgt(e,t){var n,r;return e.Db>>16==10?e.Cb.Th(e,12,Uf,t):(r=Ro(l(Mn((n=l(Kn(e,16),29),n||(Tn(),N4)),e.Db>>16),19)),e.Cb.Th(e,r.n,r.f,t))}function Of(e){var t;return!(e.Bb&1)&&e.r&&e.r.Vh()&&(t=l(e.r,54),e.r=l(yb(e,t),142),e.r!=t&&e.Db&4&&!(e.Db&1)&&Ni(e,new _a(e,9,8,t,e.r))),e.r}function Eue(e,t,n){var r;return r=he(le(Na,1),Zo,28,15,[zxe(e,(t1(),Gc),t,n),zxe(e,$u,t,n),zxe(e,Kc,t,n)]),e.f&&(r[0]=b.Math.max(r[0],r[2]),r[2]=r[0]),r}function Q7n(e,t){var n,r,a;if(a=x6n(e,t),a.c.length!=0)for(Vs(a,new pS),n=a.c.length,r=0;r>19,E=t.h>>19,w!=E?E-w:(a=e.h,g=t.h,a!=g?a-g:(r=e.m,f=t.m,r!=f?r-f:(n=e.l,o=t.l,n-o)))}function dU(){dU=U,D_e=(PU(),z0e),M_e=new pn(pEe,D_e),L_e=(aV(),$0e),A_e=new pn(bEe,L_e),__e=(ZV(),j0e),S_e=new pn(mEe,__e),C_e=new pn(vEe,(Hn(),!0))}function FA(e,t,n){var r,a;r=t*n,De(e.g,154)?(a=ix(e),a.f.d?a.f.a||(e.d.a+=r+H1):(e.d.d-=r+H1,e.d.a+=r+H1)):De(e.g,10)&&(e.d.d-=r,e.d.a+=2*r)}function hgt(e,t,n){var r,a,o,f,g;for(a=e[n.g],g=new G(t.d);g.a0?e.b:0),++n;t.b=r,t.e=a}function fgt(e){var t,n,r;if(r=e.b,tet(e.i,r.length)){for(n=r.length*2,e.b=We(k0e,TP,303,n,0,1),e.c=We(k0e,TP,303,n,0,1),e.f=n-1,e.i=0,t=e.a;t;t=t.c)eP(e,t,t);++e.g}}function i8n(e,t,n,r){var a,o,f,g;for(a=0;af&&(g=f/r),a>o&&(w=o/a),md(e,b.Math.min(g,w)),e}function a8n(){zU();var e,t;try{if(t=l(Sxe((ib(),Gf),xT),2113),t)return t}catch(n){if(n=bs(n),De(n,103))e=n,p5e((Jr(),e));else throw ue(n)}return new ik}function o8n(){zU();var e,t;try{if(t=l(Sxe((ib(),Gf),Ff),2040),t)return t}catch(n){if(n=bs(n),De(n,103))e=n,p5e((Jr(),e));else throw ue(n)}return new d8}function c8n(){klt();var e,t;try{if(t=l(Sxe((ib(),Gf),cv),2122),t)return t}catch(n){if(n=bs(n),De(n,103))e=n,p5e((Jr(),e));else throw ue(n)}return new uk}function u8n(e,t,n){var r,a;return a=e.e,e.e=t,e.Db&4&&!(e.Db&1)&&(r=new _a(e,1,4,a,t),n?n.nj(r):n=r),a!=t&&(t?n=ZE(e,SU(e,t),n):n=ZE(e,e.a,n)),n}function dgt(){Qz.call(this),this.e=-1,this.a=!1,this.p=lo,this.k=-1,this.c=-1,this.b=-1,this.g=!1,this.f=-1,this.j=-1,this.n=-1,this.i=-1,this.d=-1,this.o=lo}function l8n(e,t){var n,r,a;if(r=e.b.d.d,e.a||(r+=e.b.d.a),a=t.b.d.d,t.a||(a+=t.b.d.a),n=Yi(r,a),n==0){if(!e.a&&t.a)return-1;if(!t.a&&e.a)return 1}return n}function h8n(e,t){var n,r,a;if(r=e.b.b.d,e.a||(r+=e.b.b.a),a=t.b.b.d,t.a||(a+=t.b.b.a),n=Yi(r,a),n==0){if(!e.a&&t.a)return-1;if(!t.a&&e.a)return 1}return n}function f8n(e,t){var n,r,a;if(r=e.b.g.d,e.a||(r+=e.b.g.a),a=t.b.g.d,t.a||(a+=t.b.g.a),n=Yi(r,a),n==0){if(!e.a&&t.a)return-1;if(!t.a&&e.a)return 1}return n}function mxe(){mxe=U,v8t=yl(fi(fi(fi(new Xs,(uo(),_u),(vo(),KAe)),_u,WAe),mc,YAe),mc,BAe),y8t=fi(fi(new Xs,_u,LAe),_u,FAe),w8t=yl(new Xs,mc,jAe)}function d8n(e){var t,n,r,a,o;for(t=l(Q(e,(ft(),KL)),85),o=e.n,r=t.Cc().Kc();r.Ob();)n=l(r.Pb(),314),a=n.i,a.c+=o.a,a.d+=o.b,n.c?Ibt(n):Obt(n);rt(e,KL,null)}function g8n(e,t,n){var r,a;switch(a=e.b,r=a.d,t.g){case 1:return-r.d-n;case 2:return a.o.a+r.c+n;case 3:return a.o.b+r.a+n;case 4:return-r.b-n;default:return-1}}function p8n(e,t,n){var r,a;for(n.Ug("Interactive node placement",1),e.a=l(Q(t,(ft(),$6)),312),a=new G(t.b);a.a0&&(f=(o&Ii)%e.d.length,a=y9e(e,f,o,t),a)?(g=a.nd(n),g):(r=e.ck(o,t,n),e.c.Fc(r),null)}function yxe(e,t){var n,r,a,o;switch(o2(e,t).Kl()){case 3:case 2:{for(n=d6(t),a=0,o=n.i;a=0;r--)if(vn(e[r].d,t)||vn(e[r].d,n)){e.length>=r+1&&e.splice(0,r+1);break}return e}function KN(e,t){var n;return wc(e)&&wc(t)&&(n=e/t,_P0&&(e.b+=2,e.a+=r):(e.b+=1,e.a+=b.Math.min(r,a))}function ygt(e){var t;t=l(Q(l(ff(e.b,0),40),(Hc(),gIe)),107),rt(e,(Qi(),QT),new lt(0,0)),hmt(new nN,e,t.b+t.c-ze(Ge(Q(e,Bde))),t.d+t.a-ze(Ge(Q(e,Fde))))}function xgt(e,t){var n,r;if(r=!1,Ia(t)&&(r=!0,J8(e,new yy(ei(t)))),r||De(t,242)&&(r=!0,J8(e,(n=g4e(l(t,242)),new vk(n)))),!r)throw ue(new Qie(mSe))}function I8n(e,t,n,r){var a,o,f;return a=new Zg(e.e,1,10,(f=t.c,De(f,90)?l(f,29):(Tn(),Kf)),(o=n.c,De(o,90)?l(o,29):(Tn(),Kf)),f2(e,t),!1),r?r.nj(a):r=a,r}function Exe(e){var t,n;switch(l(Q(eo(e),(Nt(),jMe)),429).g){case 0:return t=e.n,n=e.o,new lt(t.a+n.a/2,t.b+n.b/2);case 1:return new Eo(e.n);default:return null}}function WN(){WN=U,ZK=new C_(Id,0),TLe=new C_("LEFTUP",1),SLe=new C_("RIGHTUP",2),ELe=new C_("LEFTDOWN",3),CLe=new C_("RIGHTDOWN",4),B1e=new C_("BALANCED",5)}function O8n(e,t,n){var r,a,o;if(r=Yi(e.a[t.p],e.a[n.p]),r==0){if(a=l(Q(t,(ft(),Wx)),15),o=l(Q(n,Wx),15),a.Hc(n))return-1;if(o.Hc(t))return 1}return r}function N8n(e){switch(e.g){case 1:return new vne;case 2:return new wne;case 3:return new mne;case 0:return null;default:throw ue(new Yn(Efe+(e.f!=null?e.f:""+e.g)))}}function Txe(e,t,n){switch(t){case 1:!e.n&&(e.n=new nt(ec,e,1,7)),$r(e.n),!e.n&&(e.n=new nt(ec,e,1,7)),As(e.n,l(n,16));return;case 2:fE(e,ei(n));return}V7e(e,t,n)}function Cxe(e,t,n){switch(t){case 3:Mw(e,ze(Ge(n)));return;case 4:Dw(e,ze(Ge(n)));return;case 5:Uu(e,ze(Ge(n)));return;case 6:Gu(e,ze(Ge(n)));return}Txe(e,t,n)}function gU(e,t,n){var r,a,o;o=(r=new Hie,r),a=$1(o,t,null),a&&a.oj(),Fu(o,n),qr((!e.c&&(e.c=new nt(k3,e,12,10)),e.c),o),i2(o,0),My(o,1),u2(o,!0),c2(o,!0)}function Sxe(e,t){var n,r,a;return n=y_(e.i,t),De(n,241)?(a=l(n,241),a.zi()==null,a.wi()):De(n,507)?(r=l(n,2037),a=r.b,a):null}function P8n(e,t,n,r){var a,o;return Xr(t),Xr(n),o=l(H_(e.d,t),17),Wlt(!!o,"Row %s not in %s",t,e.e),a=l(H_(e.b,n),17),Wlt(!!a,"Column %s not in %s",n,e.c),s0t(e,o.a,a.a,r)}function kgt(e,t,n,r,a,o,f){var g,w,E,C,L;if(C=a[o],E=o==f-1,g=E?r:0,L=zdt(g,C),r!=10&&he(le(e,f-o),t[o],n[o],g,L),!E)for(++o,w=0;w1||g==-1?(o=l(w,15),a.Wb(v5n(e,o))):a.Wb(cle(e,l(w,58)))))}function q8n(e,t,n,r){MZe();var a=m0e;function o(){for(var f=0;f0)return!1;return!0}function U8n(e){var t,n,r,a,o;for(r=new qm(new Sr(e.b).a);r.b;)n=Nw(r),t=l(n.ld(),10),o=l(l(n.md(),42).a,10),a=l(l(n.md(),42).b,8),Oi(Y0(t.n),Oi(Ja(o.n),a))}function G8n(e){switch(l(Q(e.b,(Nt(),IMe)),387).g){case 1:Is(fc(Dc(new bn(null,new kn(e.d,16)),new dI),new g5),new wee);break;case 2:zSn(e);break;case 0:wkn(e)}}function K8n(e,t,n){var r,a,o;for(r=n,!r&&(r=new L8),r.Ug("Layout",e.a.c.length),o=new G(e.a);o.awfe)return n;a>-1e-6&&++n}return n}function Axe(e,t){var n;t!=e.b?(n=null,e.b&&(n=IH(e.b,e,-4,n)),t&&(n=mx(t,e,-4,n)),n=J0t(e,t,n),n&&n.oj()):e.Db&4&&!(e.Db&1)&&Ni(e,new _a(e,1,3,t,t))}function Cgt(e,t){var n;t!=e.f?(n=null,e.f&&(n=IH(e.f,e,-1,n)),t&&(n=mx(t,e,-1,n)),n=Q0t(e,t,n),n&&n.oj()):e.Db&4&&!(e.Db&1)&&Ni(e,new _a(e,1,0,t,t))}function Q8n(e,t,n,r){var a,o,f,g;return hh(e.e)&&(a=t.Lk(),g=t.md(),o=n.md(),f=db(e,1,a,g,o,a.Jk()?XE(e,a,o,De(a,102)&&(l(a,19).Bb&Io)!=0):-1,!0),r?r.nj(f):r=f),r}function Sgt(e){var t,n,r;if(e==null)return null;if(n=l(e,15),n.dc())return"";for(r=new Up,t=n.Kc();t.Ob();)Xo(r,(Gi(),ei(t.Pb()))),r.a+=" ";return Gse(r,r.a.length-1)}function _gt(e){var t,n,r;if(e==null)return null;if(n=l(e,15),n.dc())return"";for(r=new Up,t=n.Kc();t.Ob();)Xo(r,(Gi(),ei(t.Pb()))),r.a+=" ";return Gse(r,r.a.length-1)}function J8n(e,t,n){var r,a;return r=e.c[t.c.p][t.p],a=e.c[n.c.p][n.p],r.a!=null&&a.a!=null?Nae(r.a,a.a):r.a!=null?-1:a.a!=null?1:0}function Z8n(e,t,n){return n.Ug("Tree layout",1),qO(e.b),X0(e.b,(wx(),NW),NW),X0(e.b,lM,lM),X0(e.b,hM,hM),X0(e.b,fM,fM),e.a=bP(e.b,t),K8n(e,t,n.eh(1)),n.Vg(),t}function exn(e,t){var n,r,a,o,f,g;if(t)for(o=t.a.length,n=new Dm(o),g=(n.b-n.a)*n.c<0?(sb(),tm):new cb(n);g.Ob();)f=l(g.Pb(),17),a=Jk(t,f.a),r=new GXe(e),cpn(r.a,a)}function txn(e,t){var n,r,a,o,f,g;if(t)for(o=t.a.length,n=new Dm(o),g=(n.b-n.a)*n.c<0?(sb(),tm):new cb(n);g.Ob();)f=l(g.Pb(),17),a=Jk(t,f.a),r=new FXe(e),opn(r.a,a)}function nxn(e){var t;if(e!=null&&e.length>0&&co(e,e.length-1)==33)try{return t=P2t(tf(e,0,e.length-1)),t.e==null}catch(n){if(n=bs(n),!De(n,33))throw ue(n)}return!1}function rxn(e,t,n){var r,a,o;switch(r=eo(t),a=zV(r),o=new gu,Mc(o,t),n.g){case 1:la(o,BN(gx(a)));break;case 2:la(o,gx(a))}return rt(o,(Nt(),m4),Ge(Q(e,m4))),o}function Lxe(e){var t,n;return t=l(xr(new hr(dr(ka(e.a).a.Kc(),new j))),18),n=l(xr(new hr(dr(qs(e.a).a.Kc(),new j))),18),Rt(Bt(Q(t,(ft(),W1))))||Rt(Bt(Q(n,W1)))}function Ry(){Ry=U,bB=new cO("ONE_SIDE",0),KK=new cO("TWO_SIDES_CORNER",1),WK=new cO("TWO_SIDES_OPPOSING",2),GK=new cO("THREE_SIDES",3),UK=new cO("FOUR_SIDES",4)}function Agt(e,t){var n,r,a,o;for(o=new bt,a=0,r=t.Kc();r.Ob();){for(n=pt(l(r.Pb(),17).a+a);n.a=e.f)break;$n(o.c,n)}return o}function ixn(e,t){var n,r,a,o,f;for(o=new G(t.a);o.a0&&Jdt(this,this.c-1,(Ct(),ar)),this.c0&&e[0].length>0&&(this.c=Rt(Bt(Q(eo(e[0][0]),(ft(),zLe))))),this.a=We(kEt,dt,2117,e.length,0,2),this.b=We(EEt,dt,2118,e.length,0,2),this.d=new G0t}function uxn(e){return e.c.length==0?!1:(Sn(0,e.c.length),l(e.c[0],18)).c.i.k==(Zn(),Aa)?!0:W5(fc(new bn(null,new kn(e,16)),new Wee),new Yee)}function Dgt(e,t){var n,r,a,o,f,g,w;for(g=Hy(t),o=t.f,w=t.g,f=b.Math.sqrt(o*o+w*w),a=0,r=new G(g);r.a=0?(n=KN(e,JU),r=RN(e,JU)):(t=ub(e,1),n=KN(t,5e8),r=RN(t,5e8),r=bo(l0(r,1),va(e,1))),Q0(l0(r,32),va(n,Vo))}function Ngt(e,t,n){var r,a;switch(r=(mr(t.b!=0),l(af(t,t.a.a),8)),n.g){case 0:r.b=0;break;case 2:r.b=e.f;break;case 3:r.a=0;break;default:r.a=e.g}return a=Rr(t,0),zO(a,r),t}function Pgt(e,t,n,r){var a,o,f,g,w;switch(w=e.b,o=t.d,f=o.j,g=G8e(f,w.d[f.g],n),a=Oi(Ja(o.n),o.a),o.j.g){case 1:case 3:g.a+=a.a;break;case 2:case 4:g.b+=a.b}Cs(r,g,r.c.b,r.c)}function xxn(e,t,n){var r,a,o,f;for(f=gc(e.e,t,0),o=new Pwe,o.b=n,r=new Ua(e.e,f);r.b1;t>>=1)t&1&&(r=K5(r,n)),n.d==1?n=K5(n,n):n=new Q1t(mmt(n.a,n.d,We(Vr,di,28,n.d<<1,15,1)));return r=K5(r,n),r}function Rxe(){Rxe=U;var e,t,n,r;for(m_e=We(Na,Zo,28,25,15,1),v_e=We(Na,Zo,28,33,15,1),r=152587890625e-16,t=32;t>=0;t--)v_e[t]=r,r*=.5;for(n=1,e=24;e>=0;e--)m_e[e]=n,n*=.5}function _xn(e){var t,n;if(Rt(Bt(at(e,(Nt(),b4))))){for(n=new hr(dr(cp(e).a.Kc(),new j));jr(n);)if(t=l(xr(n),74),qw(t)&&Rt(Bt(at(t,gv))))return!0}return!1}function Bgt(e,t){var n,r,a;na(e.f,t)&&(t.b=e,r=t.c,gc(e.j,r,0)!=-1||vt(e.j,r),a=t.d,gc(e.j,a,0)!=-1||vt(e.j,a),n=t.a.b,n.c.length!=0&&(!e.i&&(e.i=new rdt(e)),I3n(e.i,n)))}function Axn(e){var t,n,r,a,o;return n=e.c.d,r=n.j,a=e.d.d,o=a.j,r==o?n.p=0&&vn(e.substr(t,3),"GMT")||t>=0&&vn(e.substr(t,3),"UTC"))&&(n[0]=t+3),mke(e,n,r)}function Mxn(e,t){var n,r,a,o,f;for(o=e.g.a,f=e.g.b,r=new G(e.d);r.an;o--)e[o]|=t[o-n-1]>>>f,e[o-1]=t[o-n-1]<0&&pu(e.g,t,e.g,t+r,g),f=n.Kc(),e.i+=r,a=0;a>4&15,o=e[r]&15,f[a++]=bPe[n],f[a++]=bPe[o];return If(f,0,f.length)}function cl(e){var t,n;return e>=Io?(t=AP+(e-Io>>10&1023)&Zs,n=56320+(e-Io&1023)&Zs,String.fromCharCode(t)+(""+String.fromCharCode(n))):String.fromCharCode(e&Zs)}function zxn(e,t){py();var n,r,a,o;return a=l(l($i(e.r,t),21),87),a.gc()>=2?(r=l(a.Kc().Pb(),117),n=e.u.Hc((Rl(),PM)),o=e.u.Hc(a9),!r.a&&!n&&(a.gc()==2||o)):!1}function jgt(e,t,n,r,a){var o,f,g;for(o=Tbt(e,t,n,r,a),g=!1;!o;)TU(e,a,!0),g=!0,o=Tbt(e,t,n,r,a);g&&TU(e,a,!1),f=bce(a),f.c.length!=0&&(e.d&&e.d.Gg(f),jgt(e,a,n,r,f))}function vU(){vU=U,Uge=new L_(Id,0),$Ne=new L_("DIRECTED",1),qNe=new L_("UNDIRECTED",2),RNe=new L_("ASSOCIATION",3),zNe=new L_("GENERALIZATION",4),jNe=new L_("DEPENDENCY",5)}function qxn(e,t){var n;if(!M1(e))throw ue(new nc(t4t));switch(n=M1(e),t.g){case 1:return-(e.j+e.f);case 2:return e.i-n.g;case 3:return e.j-n.f;case 4:return-(e.i+e.g)}return 0}function Hxn(e,t,n){var r,a,o;return r=t.Lk(),o=t.md(),a=r.Jk()?db(e,4,r,o,null,XE(e,r,o,De(r,102)&&(l(r,19).Bb&Io)!=0),!0):db(e,r.tk()?2:1,r,o,r.ik(),-1,!0),n?n.nj(a):n=a,n}function $E(e,t){var n,r;for(nr(t),r=e.b.c.length,vt(e.b,t);r>0;){if(n=r,r=(r-1)/2|0,e.a.Ne(jt(e.b,r),t)<=0)return rf(e.b,n,t),!0;rf(e.b,n,jt(e.b,r))}return rf(e.b,r,t),!0}function zxe(e,t,n,r){var a,o;if(a=0,n)a=BV(e.a[n.g][t.g],r);else for(o=0;o=g)}function $gt(e){switch(e.g){case 0:return new Sne;case 1:return new _ne;default:throw ue(new Yn("No implementation is available for the width approximator "+(e.f!=null?e.f:""+e.g)))}}function qxe(e,t,n,r){var a;if(a=!1,Ia(r)&&(a=!0,zk(t,n,ei(r))),a||hy(r)&&(a=!0,qxe(e,t,n,r)),a||De(r,242)&&(a=!0,Nm(t,n,l(r,242))),!a)throw ue(new Qie(mSe))}function Uxn(e,t){var n,r,a;if(n=t.qi(e.a),n&&(a=n1((!n.b&&(n.b=new dh((Tn(),No),Yc,n)),n.b),Bf),a!=null)){for(r=1;r<(El(),$Pe).length;++r)if(vn($Pe[r],a))return r}return 0}function Gxn(e,t){var n,r,a;if(n=t.qi(e.a),n&&(a=n1((!n.b&&(n.b=new dh((Tn(),No),Yc,n)),n.b),Bf),a!=null)){for(r=1;r<(El(),zPe).length;++r)if(vn(zPe[r],a))return r}return 0}function zgt(e,t){var n,r,a,o;if(nr(t),o=e.a.gc(),o0?1:0;o.a[a]!=n;)o=o.a[a],a=e.a.Ne(n.d,o.d)>0?1:0;o.a[a]=r,r.b=n.b,r.a[0]=n.a[0],r.a[1]=n.a[1],n.a[0]=null,n.a[1]=null}function Yxn(e){var t,n,r,a;for(t=new bt,n=We(ih,pg,28,e.a.c.length,16,1),l5e(n,n.length),a=new G(e.a);a.a0&&dmt((Sn(0,n.c.length),l(n.c[0],30)),e),n.c.length>1&&dmt(l(jt(n,n.c.length-1),30),e),t.Vg()}function Qxn(e){Rl();var t,n;return t=rs(vp,he(le(cY,1),it,279,0,[Yb])),!(yN(NH(t,e))>1||(n=rs(PM,he(le(cY,1),it,279,0,[NM,a9])),yN(NH(n,e))>1))}function Vxe(e,t){var n;n=xu((ib(),Gf),e),De(n,507)?rc(Gf,e,new Ott(this,t)):rc(Gf,e,this),Nue(this,t),t==(Sk(),APe)?(this.wb=l(this,2038),l(t,2040)):this.wb=(lb(),Vn)}function Jxn(e){var t,n,r;if(e==null)return null;for(t=null,n=0;n=b2?"error":r>=900?"warn":r>=800?"info":"log"),eat(n,e.a),e.b&&G9e(t,n,e.b,"Exception: ",!0))}function Q(e,t){var n,r;return r=(!e.q&&(e.q=new Pr),cr(e.q,t)),r??(n=t.Sg(),De(n,4)&&(n==null?(!e.q&&(e.q=new Pr),ax(e.q,t)):(!e.q&&(e.q=new Pr),ki(e.q,t,n))),n)}function uo(){uo=U,y0=new oO("P1_CYCLE_BREAKING",0),vg=new oO("P2_LAYERING",1),bu=new oO("P3_NODE_ORDERING",2),_u=new oO("P4_NODE_PLACEMENT",3),mc=new oO("P5_EDGE_ROUTING",4)}function Zxn(e,t){hA();var n;if(e.c==t.c){if(e.b==t.b||a3n(e.b,t.b)){if(n=Dln(e.b)?1:-1,e.a&&!t.a)return n;if(!e.a&&t.a)return-n}return ru(e.b.g,t.b.g)}else return Yi(e.c,t.c)}function Ggt(e,t){var n,r,a;if(Gxe(e,t))return!0;for(r=new G(t);r.a=a||t<0)throw ue(new tc(Qfe+t+av+a));if(n>=a||n<0)throw ue(new tc(Jfe+n+av+a));return t!=n?r=(o=e.Cj(n),e.qj(t,o),o):r=e.xj(n),r}function Ygt(e){var t,n,r;if(r=e,e)for(t=0,n=e.Eh();n;n=n.Eh()){if(++t>ohe)return Ygt(n);if(r=n,n==e)throw ue(new nc("There is a cycle in the containment hierarchy of "+e))}return r}function Tb(e){var t,n,r;for(r=new Hm(Co,"[","]"),n=e.Kc();n.Ob();)t=n.Pb(),Jg(r,qe(t)===qe(e)?"(this Collection)":t==null?ul:xc(t));return r.a?r.e.length==0?r.a.a:r.a.a+(""+r.e):r.c}function Gxe(e,t){var n,r;if(r=!1,t.gc()<2)return!1;for(n=0;n1&&(e.j.b+=e.e)):(e.j.a+=n.a,e.j.b=b.Math.max(e.j.b,n.b),e.d.c.length>1&&(e.j.a+=e.e))}function Cb(){Cb=U,axt=he(le(Oo,1),au,64,0,[(Ct(),Qn),ar,Dr]),sxt=he(le(Oo,1),au,64,0,[ar,Dr,er]),oxt=he(le(Oo,1),au,64,0,[Dr,er,Qn]),cxt=he(le(Oo,1),au,64,0,[er,Qn,ar])}function t9n(e,t,n,r){var a,o,f,g,w,E,C;if(f=e.c.d,g=e.d.d,f.j!=g.j)for(C=e.b,a=f.j,w=null;a!=g.j;)w=t==0?$V(a):f8e(a),o=G8e(a,C.d[a.g],n),E=G8e(w,C.d[w.g],n),ui(r,Oi(o,E)),a=w}function n9n(e,t,n,r){var a,o,f,g,w;return f=Zdt(e.a,t,n),g=l(f.a,17).a,o=l(f.b,17).a,r&&(w=l(Q(t,(ft(),jl)),10),a=l(Q(n,jl),10),w&&a&&($ct(e.b,w,a),g+=e.b.i,o+=e.b.e)),g>o}function Qgt(e){var t,n,r,a,o,f,g,w,E;for(this.a=ydt(e),this.b=new bt,n=e,r=0,a=n.length;ruae(e.d).c?(e.i+=e.g.c,Yce(e.d)):uae(e.d).c>uae(e.g).c?(e.e+=e.d.c,Yce(e.g)):(e.i+=cst(e.g),e.e+=cst(e.d),Yce(e.g),Yce(e.d))}function a9n(e,t,n){var r,a,o,f;for(o=t.q,f=t.r,new Pm((J0(),qb),t,o,1),new Pm(qb,o,f,1),a=new G(n);a.ag&&(w=g/r),a>o&&(E=o/a),f=b.Math.min(w,E),e.a+=f*(t.a-e.a),e.b+=f*(t.b-e.b)}function l9n(e,t,n,r,a){var o,f;for(f=!1,o=l(jt(n.b,0),27);jAn(e,t,o,r,a)&&(f=!0,$8n(n,o),n.b.c.length!=0);)o=l(jt(n.b,0),27);return n.b.c.length==0&&UN(n.j,n),f&&lU(t.q),f}function h9n(e,t){h6();var n,r,a,o;if(t.b<2)return!1;for(o=Rr(t,0),n=l(Br(o),8),r=n;o.b!=o.d.c;){if(a=l(Br(o),8),Xue(e,r,a))return!0;r=a}return!!Xue(e,r,n)}function Wxe(e,t,n,r){var a,o;return n==0?(!e.o&&(e.o=new xl((su(),Cg),L2,e,0)),Uq(e.o,t,r)):(o=l(Mn((a=l(Kn(e,16),29),a||e.ii()),n),69),o.wk().Ak(e,Ku(e),n-yr(e.ii()),t,r))}function Nue(e,t){var n;t!=e.sb?(n=null,e.sb&&(n=l(e.sb,54).Th(e,1,RM,n)),t&&(n=l(t,54).Rh(e,1,RM,n)),n=a8e(e,t,n),n&&n.oj()):e.Db&4&&!(e.Db&1)&&Ni(e,new _a(e,1,4,t,t))}function f9n(e,t){var n,r,a,o;if(t)a=np(t,"x"),n=new HXe(e),aE(n.a,(nr(a),a)),o=np(t,"y"),r=new VXe(e),cE(r.a,(nr(o),o));else throw ue(new dd("All edge sections need an end point."))}function d9n(e,t){var n,r,a,o;if(t)a=np(t,"x"),n=new $Xe(e),oE(n.a,(nr(a),a)),o=np(t,"y"),r=new zXe(e),uE(r.a,(nr(o),o));else throw ue(new dd("All edge sections need a start point."))}function g9n(e,t){var n,r,a,o,f,g,w;for(r=_0t(e),o=0,g=r.length;o>22-t,a=e.h<>22-t):t<44?(n=0,r=e.l<>44-t):(n=0,r=0,a=e.l<e)throw ue(new Yn("k must be smaller than n"));return t==0||t==e?1:e==0?0:xxe(e)/(xxe(t)*xxe(e-t))}function Yxe(e,t){var n,r,a,o;for(n=new hye(e);n.g==null&&!n.c?H5e(n):n.g==null||n.i!=0&&l(n.g[n.i-1],51).Ob();)if(o=l(CU(n),58),De(o,167))for(r=l(o,167),a=0;a>4],t[n*2+1]=LY[o&15];return If(t,0,t.length)}function M9n(e){kH();var t,n,r;switch(r=e.c.length,r){case 0:return i6t;case 1:return t=l(Rpt(new G(e)),44),Edn(t.ld(),t.md());default:return n=l(j1(e,We(uv,XU,44,e.c.length,0,1)),173),new Wwe(n)}}function D9n(e){var t,n,r,a,o,f;for(t=new z5,n=new z5,gb(t,e),gb(n,e);n.b!=n.c;)for(a=l(X8(n),36),f=new G(a.a);f.a0&&lP(e,n,t),a):wEn(e,t,n)}function Sb(){Sb=U,uCt=(pi(),n9),lCt=Ev,sCt=kv,aCt=i7,oCt=Ub,iCt=r7,NIe=YB,cCt=S4,Jde=(uke(),KTt),Zde=WTt,BIe=JTt,ege=tCt,FIe=ZTt,RIe=eCt,PIe=YTt,qW=XTt,HW=QTt,FB=nCt,jIe=rCt,OIe=GTt}function spt(e,t){var n,r,a,o,f;if(e.e<=t||tbn(e,e.g,t))return e.g;for(o=e.r,r=e.g,f=e.r,a=(o-r)/2+r;r+11&&(e.e.b+=e.a)):(e.e.a+=n.a,e.e.b=b.Math.max(e.e.b,n.b),e.d.c.length>1&&(e.e.a+=e.a))}function B9n(e){var t,n,r,a;switch(a=e.i,t=a.b,r=a.j,n=a.g,a.a.g){case 0:n.a=(e.g.b.o.a-r.a)/2;break;case 1:n.a=t.d.n.a+t.d.a.a;break;case 2:n.a=t.d.n.a+t.d.a.a-r.a;break;case 3:n.b=t.d.n.b+t.d.a.b}}function F9n(e,t,n){var r,a,o;for(a=new hr(dr(sp(n).a.Kc(),new j));jr(a);)r=l(xr(a),18),!Do(r)&&!(!Do(r)&&r.c.i.c==r.d.i.c)&&(o=Y2t(e,r,n,new QQe),o.c.length>1&&$n(t.c,o))}function opt(e,t,n,r,a){if(rr&&(e.a=r),e.ba&&(e.b=a),e}function R9n(e){if(De(e,143))return pCn(l(e,143));if(De(e,233))return s5n(l(e,233));if(De(e,23))return b9n(l(e,23));throw ue(new Yn(vSe+Tb(new Il(he(le(wa,1),Rn,1,5,[e])))))}function j9n(e,t,n,r,a){var o,f,g;for(o=!0,f=0;f>>a|n[f+r+1]<>>a,++f}return o}function Zxe(e,t,n,r){var a,o,f;if(t.k==(Zn(),Aa)){for(o=new hr(dr(ka(t).a.Kc(),new j));jr(o);)if(a=l(xr(o),18),f=a.c.i.k,f==Aa&&e.c.a[a.c.i.c.p]==r&&e.c.a[t.c.p]==n)return!0}return!1}function $9n(e,t){var n,r,a,o;return t&=63,n=e.h&hp,t<22?(o=n>>>t,a=e.m>>t|n<<22-t,r=e.l>>t|e.m<<22-t):t<44?(o=0,a=n>>>t-22,r=e.m>>t-22|e.h<<44-t):(o=0,a=0,r=n>>>t-44),qu(r&eh,a&eh,o&hp)}function cpt(e,t,n,r){var a;this.b=r,this.e=e==(Iw(),oM),a=t[n],this.d=Lm(ih,[dt,pg],[183,28],16,[a.length,a.length],2),this.a=Lm(Vr,[dt,di],[53,28],15,[a.length,a.length],2),this.c=new Nxe(t,n)}function z9n(e){var t,n,r;for(e.k=new G5e((Ct(),he(le(Oo,1),au,64,0,[Pc,Qn,ar,Dr,er])).length,e.j.c.length),r=new G(e.j);r.a=n)return qE(e,t,r.p),!0;return!1}function o6(e,t,n,r){var a,o,f,g,w,E;for(f=n.length,o=0,a=-1,E=tht((Xn(t,e.length+1),e.substr(t)),(gae(),p_e)),g=0;go&&ggn(E,tht(n[g],p_e))&&(a=g,o=w);return a>=0&&(r[0]=t+o),a}function lpt(e){var t;return e.Db&64?Pue(e):(t=new Th(oSe),!e.a||hi(hi((t.a+=' "',t),e.a),'"'),hi(rw(hi(rw(hi(rw(hi(rw((t.a+=" (",t),e.i),","),e.j)," | "),e.g),","),e.f),")"),t.a)}function hpt(e,t,n){var r,a,o,f,g;for(g=Wu(e.e.Dh(),t),a=l(e.g,124),r=0,f=0;fn?u9e(e,n,"start index"):t<0||t>n?u9e(t,n,"end index"):KA("end index (%s) must not be less than start index (%s)",he(le(wa,1),Rn,1,5,[pt(t),pt(e)]))}function dpt(e,t){var n,r,a,o;for(r=0,a=e.length;r0&&gpt(e,o,n));t.p=0}function Xt(e){var t;this.c=new os,this.f=e.e,this.e=e.d,this.i=e.g,this.d=e.c,this.b=e.b,this.k=e.j,this.a=e.a,e.i?this.j=e.i:this.j=(t=l(K0(xg),9),new Zh(t,l(c0(t,t.length),9),0)),this.g=e.f}function K9n(e){var t,n,r,a;for(t=hb(hi(new Th("Predicates."),"and"),40),n=!0,a=new kr(e);a.b0?g[f-1]:We(wg,m2,10,0,0,1),a=g[f],E=f=0?e.ki(a):d9e(e,r);else throw ue(new Yn(Ob+r.xe()+kL));else throw ue(new Yn(f4t+t+d4t));else cf(e,n,r)}function e9e(e){var t,n;if(n=null,t=!1,De(e,211)&&(t=!0,n=l(e,211).a),t||De(e,263)&&(t=!0,n=""+l(e,263).a),t||De(e,493)&&(t=!0,n=""+l(e,493).a),!t)throw ue(new Qie(mSe));return n}function t9e(e,t,n){var r,a,o,f,g,w;for(w=Wu(e.e.Dh(),t),r=0,g=e.i,a=l(e.g,124),f=0;f=e.d.b.c.length&&(t=new yu(e.d),t.p=r.p-1,vt(e.d.b,t),n=new yu(e.d),n.p=r.p,vt(e.d.b,n)),Va(r,l(jt(e.d.b,r.p),30))}function i9e(e,t,n){var r,a,o;if(!e.b[t.g]){for(e.b[t.g]=!0,r=n,!r&&(r=new nN),ui(r.b,t),o=e.a[t.g].Kc();o.Ob();)a=l(o.Pb(),65),a.b!=t&&i9e(e,a.b,r),a.c!=t&&i9e(e,a.c,r),ui(r.a,a);return r}return null}function Q9n(e){switch(e.g){case 0:case 1:case 2:return Ct(),Qn;case 3:case 4:case 5:return Ct(),Dr;case 6:case 7:case 8:return Ct(),er;case 9:case 10:case 11:return Ct(),ar;default:return Ct(),Pc}}function J9n(e,t){var n;return e.c.length==0?!1:(n=I1t((Sn(0,e.c.length),l(e.c[0],18)).c.i),Sh(),n==(By(),G6)||n==U6?!0:W5(fc(new bn(null,new kn(e,16)),new Xee),new XYe(t)))}function jue(e,t){if(De(t,207))return Gln(e,l(t,27));if(De(t,193))return Kln(e,l(t,123));if(De(t,452))return Uln(e,l(t,166));throw ue(new Yn(vSe+Tb(new Il(he(le(wa,1),Rn,1,5,[t])))))}function ypt(e,t,n){var r,a;if(this.f=e,r=l(cr(e.b,t),260),a=r?r.a:0,k6e(n,a),n>=(a/2|0))for(this.e=r?r.c:null,this.d=a;n++0;)G6e(this);this.b=t,this.a=null}function Z9n(e,t){var n,r;t.a?OCn(e,t):(n=l(cse(e.b,t.b),60),n&&n==e.a[t.b.f]&&n.a&&n.a!=t.b.a&&n.c.Fc(t.b),r=l(ose(e.b,t.b),60),r&&e.a[r.f]==t.b&&r.a&&r.a!=t.b.a&&t.b.c.Fc(r),tae(e.b,t.b))}function xpt(e,t){var n,r;if(n=l(Qo(e.b,t),127),l(l($i(e.r,t),21),87).dc()){n.n.b=0,n.n.c=0;return}n.n.b=e.C.b,n.n.c=e.C.c,e.A.Hc((mh(),Cv))&&Kbt(e,t),r=_6n(e,t),Jue(e,t)==(t6(),Kb)&&(r+=2*e.w),n.a.a=r}function kpt(e,t){var n,r;if(n=l(Qo(e.b,t),127),l(l($i(e.r,t),21),87).dc()){n.n.d=0,n.n.a=0;return}n.n.d=e.C.d,n.n.a=e.C.a,e.A.Hc((mh(),Cv))&&Wbt(e,t),r=S6n(e,t),Jue(e,t)==(t6(),Kb)&&(r+=2*e.w),n.a.b=r}function ekn(e,t){var n,r,a,o;for(o=new bt,r=new G(t);r.ar&&(Xn(t-1,e.length),e.charCodeAt(t-1)<=32);)--t;return r>0||tn.a&&(r.Hc((Ym(),EM))?a=(t.a-n.a)/2:r.Hc(TM)&&(a=t.a-n.a)),t.b>n.b&&(r.Hc((Ym(),SM))?o=(t.b-n.b)/2:r.Hc(CM)&&(o=t.b-n.b)),Hxe(e,a,o)}function Lpt(e,t,n,r,a,o,f,g,w,E,C,L,B){De(e.Cb,90)&&zy(Yl(l(e.Cb,90)),4),Fu(e,n),e.f=f,LE(e,g),DE(e,w),AE(e,E),ME(e,C),u2(e,L),IE(e,B),c2(e,!0),i2(e,a),e.Zk(o),Gm(e,t),r!=null&&(e.i=null,xV(e,r))}function u9e(e,t,n){if(e<0)return KA(Swt,he(le(wa,1),Rn,1,5,[n,pt(e)]));if(t<0)throw ue(new Yn(_wt+t));return KA("%s (%s) must not be greater than size (%s)",he(le(wa,1),Rn,1,5,[n,pt(e),pt(t)]))}function l9e(e,t,n,r,a,o){var f,g,w,E;if(f=r-n,f<7){W4n(t,n,r,o);return}if(w=n+a,g=r+a,E=w+(g-w>>1),l9e(t,e,w,E,-a,o),l9e(t,e,E,g,-a,o),o.Ne(e[E-1],e[E])<=0){for(;n=0?e.bi(o,n):$9e(e,a,n);else throw ue(new Yn(Ob+a.xe()+kL));else throw ue(new Yn(f4t+t+d4t));else uf(e,r,a,n)}function Mpt(e){var t,n;if(e.f){for(;e.n>0;){if(t=l(e.k.Xb(e.n-1),76),n=t.Lk(),De(n,102)&&l(n,19).Bb&eu&&(!e.e||n.pk()!=oC||n.Lj()!=0)&&t.md()!=null)return!0;--e.n}return!1}else return e.n>0}function Dpt(e){var t,n,r,a;if(n=l(e,54)._h(),n)try{if(r=null,t=VE((ib(),Gf),bmt(a5n(n))),t&&(a=t.ai(),a&&(r=a.Fl(oun(n.e)))),r&&r!=e)return Dpt(r)}catch(o){if(o=bs(o),!De(o,63))throw ue(o)}return e}function bkn(e,t,n){var r,a,o;n.Ug("Remove overlaps",1),n.dh(t,yCe),r=l(at(t,(H5(),Y6)),27),e.f=r,e.a=sue(l(at(t,(Sb(),FB)),300)),a=Ge(at(t,(pi(),Ev))),_e(e,(nr(a),a)),o=Hy(r),Rvt(e,t,o,n),n.dh(t,OG)}function mkn(e){var t,n,r;if(Rt(Bt(at(e,(pi(),KB))))){for(r=new bt,n=new hr(dr(cp(e).a.Kc(),new j));jr(n);)t=l(xr(n),74),qw(t)&&Rt(Bt(at(t,Oge)))&&$n(r.c,t);return r}else return Cn(),Cn(),_o}function Ipt(e){if(!e)return MJe(),d6t;var t=e.valueOf?e.valueOf():e;if(t!==e){var n=_0e[typeof t];return n?n(t):Z7e(typeof t)}else return e instanceof Array||e instanceof b.Array?new Sz(e):new wk(e)}function Opt(e,t,n){var r,a,o;switch(o=e.o,r=l(Qo(e.p,n),252),a=r.i,a.b=nP(r),a.a=tP(r),a.b=b.Math.max(a.b,o.a),a.b>o.a&&!t&&(a.b=o.a),a.c=-(a.b-o.a)/2,n.g){case 1:a.d=-a.a;break;case 3:a.d=o.b}hle(r),fle(r)}function Npt(e,t,n){var r,a,o;switch(o=e.o,r=l(Qo(e.p,n),252),a=r.i,a.b=nP(r),a.a=tP(r),a.a=b.Math.max(a.a,o.b),a.a>o.b&&!t&&(a.a=o.b),a.d=-(a.a-o.b)/2,n.g){case 4:a.c=-a.b;break;case 2:a.c=o.a}hle(r),fle(r)}function vkn(e,t){var n,r,a,o,f;if(!t.dc()){if(a=l(t.Xb(0),131),t.gc()==1){hbt(e,a,a,1,0,t);return}for(n=1;n0)try{a=Oh(t,lo,Ii)}catch(o){throw o=bs(o),De(o,130)?(r=o,ue(new nV(r))):ue(o)}return n=(!e.a&&(e.a=new Pie(e)),e.a),a=0?l(Oe(n,a),58):null}function kkn(e,t){if(e<0)return KA(Swt,he(le(wa,1),Rn,1,5,["index",pt(e)]));if(t<0)throw ue(new Yn(_wt+t));return KA("%s (%s) must be less than size (%s)",he(le(wa,1),Rn,1,5,["index",pt(e),pt(t)]))}function Ekn(e){var t,n,r,a,o;if(e==null)return ul;for(o=new Hm(Co,"[","]"),n=e,r=0,a=n.length;r=0?e.Lh(n,!0,!0):Hw(e,a,!0),160)),l(r,220).Zl(t);else throw ue(new Yn(Ob+t.xe()+kL))}function g9e(e){var t,n;return e>-0x800000000000&&e<0x800000000000?e==0?0:(t=e<0,t&&(e=-e),n=ua(b.Math.floor(b.Math.log(e)/.6931471805599453)),(!t||e!=b.Math.pow(2,n))&&++n,n):Qft(Zc(e))}function Rkn(e){var t,n,r,a,o,f,g;for(o=new bd,n=new G(e);n.a2&&g.e.b+g.j.b<=2&&(a=g,r=f),o.a.zc(a,o),a.q=r);return o}function jkn(e,t,n){n.Ug("Eades radial",1),n.dh(t,OG),e.d=l(at(t,(H5(),Y6)),27),e.c=ze(Ge(at(t,(Sb(),HW)))),e.e=sue(l(at(t,FB),300)),e.a=g5n(l(at(t,jIe),434)),e.b=N8n(l(at(t,PIe),354)),b8n(e),n.dh(t,OG)}function $kn(e,t){if(t.Ug("Target Width Setter",1),P1(e,(z1(),fge)))Hi(e,(ug(),T4),Ge(at(e,fge)));else throw ue(new Vp("A target width has to be set if the TargetWidthWidthApproximator should be used."));t.Vg()}function jpt(e,t){var n,r,a;return r=new op(e),pc(r,t),rt(r,(ft(),aW),t),rt(r,(Nt(),Ms),(Ra(),Mu)),rt(r,Rd,(og(),tY)),x(r,(Zn(),Us)),n=new gu,Mc(n,r),la(n,(Ct(),er)),a=new gu,Mc(a,r),la(a,ar),r}function $pt(e){switch(e.g){case 0:return new Wie((Iw(),DB));case 1:return new Qre;case 2:return new Jre;default:throw ue(new Yn("No implementation is available for the crossing minimizer "+(e.f!=null?e.f:""+e.g)))}}function zpt(e,t){var n,r,a,o,f;for(e.c[t.p]=!0,vt(e.a,t),f=new G(t.j);f.a=o)f.$b();else for(a=f.Kc(),r=0;r0?Zwe():f<0&&Upt(e,t,-f),!0):!1}function tP(e){var t,n,r,a,o,f,g;if(g=0,e.b==0){for(f=_dt(e,!0),t=0,r=f,a=0,o=r.length;a0&&(g+=n,++t);t>1&&(g+=e.c*(t-1))}else g=qJe(cce(xy(Fi(c5e(e.a),new ja),new Ou)));return g>0?g+e.n.d+e.n.a:0}function nP(e){var t,n,r,a,o,f,g;if(g=0,e.b==0)g=qJe(cce(xy(Fi(c5e(e.a),new Xc),new Bc)));else{for(f=Adt(e,!0),t=0,r=f,a=0,o=r.length;a0&&(g+=n,++t);t>1&&(g+=e.c*(t-1))}return g>0?g+e.n.b+e.n.c:0}function Kkn(e){var t,n;if(e.c.length!=2)throw ue(new nc("Order only allowed for two paths."));t=(Sn(0,e.c.length),l(e.c[0],18)),n=(Sn(1,e.c.length),l(e.c[1],18)),t.d.i!=n.c.i&&(e.c.length=0,$n(e.c,n),$n(e.c,t))}function Gpt(e,t,n){var r;for(F5(n,t.g,t.f),Qh(n,t.i,t.j),r=0;r<(!t.a&&(t.a=new nt(Ai,t,10,11)),t.a).i;r++)Gpt(e,l(Oe((!t.a&&(t.a=new nt(Ai,t,10,11)),t.a),r),27),l(Oe((!n.a&&(n.a=new nt(Ai,n,10,11)),n.a),r),27))}function Wkn(e,t){var n,r,a,o;for(o=l(Qo(e.b,t),127),n=o.a,a=l(l($i(e.r,t),21),87).Kc();a.Ob();)r=l(a.Pb(),117),r.c&&(n.a=b.Math.max(n.a,j4e(r.c)));if(n.a>0)switch(t.g){case 2:o.n.c=e.s;break;case 4:o.n.b=e.s}}function Ykn(e,t){var n,r,a;return n=l(Q(t,(b0(),qx)),17).a-l(Q(e,qx),17).a,n==0?(r=ma(Ja(l(Q(e,(bb(),hB)),8)),l(Q(e,$L),8)),a=ma(Ja(l(Q(t,hB),8)),l(Q(t,$L),8)),Yi(r.a*r.b,a.a*a.b)):n}function Xkn(e,t){var n,r,a;return n=l(Q(t,(Hc(),RW)),17).a-l(Q(e,RW),17).a,n==0?(r=ma(Ja(l(Q(e,(Qi(),NB)),8)),l(Q(e,QT),8)),a=ma(Ja(l(Q(t,NB),8)),l(Q(t,QT),8)),Yi(r.a*r.b,a.a*a.b)):n}function Kpt(e){var t,n;return n=new tb,n.a+="e_",t=H3n(e),t!=null&&(n.a+=""+t),e.c&&e.d&&(hi((n.a+=" ",n),fU(e.c)),hi(wu((n.a+="[",n),e.c.i),"]"),hi((n.a+=Phe,n),fU(e.d)),hi(wu((n.a+="[",n),e.d.i),"]")),n.a}function Wpt(e){switch(e.g){case 0:return new aie;case 1:return new dk;case 2:return new sie;case 3:return new iie;default:throw ue(new Yn("No implementation is available for the layout phase "+(e.f!=null?e.f:""+e.g)))}}function m9e(e,t,n,r,a){var o;switch(o=0,a.g){case 1:o=b.Math.max(0,t.b+e.b-(n.b+r));break;case 3:o=b.Math.max(0,-e.b-r);break;case 2:o=b.Math.max(0,-e.a-r);break;case 4:o=b.Math.max(0,t.a+e.a-(n.a+r))}return o}function Qkn(e,t,n){var r,a,o,f,g;if(n)for(a=n.a.length,r=new Dm(a),g=(r.b-r.a)*r.c<0?(sb(),tm):new cb(r);g.Ob();)f=l(g.Pb(),17),o=Jk(n,f.a),hSe in o.a||Yfe in o.a?h_n(e,o,t):MIn(e,o,t),Lhn(l(cr(e.b,NE(o)),74))}function v9e(e){var t,n;switch(e.b){case-1:return!0;case 0:return n=e.t,n>1||n==-1?(e.b=-1,!0):(t=Of(e),t&&(Fo(),t.lk()==g5t)?(e.b=-1,!0):(e.b=1,!1));default:case 1:return!1}}function w9e(e,t){var n,r,a,o;if(Li(e),e.c!=0||e.a!=123)throw ue(new ri(ai((Jr(),B4t))));if(o=t==112,r=e.d,n=Nk(e.i,125,r),n<0)throw ue(new ri(ai((Jr(),F4t))));return a=tf(e.i,r,n),e.d=n+1,vlt(a,o,(e.e&512)==512)}function Ypt(e){var t,n,r,a,o,f,g;if(r=e.a.c.length,r>0)for(f=e.c.d,g=e.d.d,a=md(ma(new lt(g.a,g.b),f),1/(r+1)),o=new lt(f.a,f.b),n=new G(e.a);n.a=0&&r=0?e.Lh(n,!0,!0):Hw(e,a,!0),160)),l(r,220).Wl(t);throw ue(new Yn(Ob+t.xe()+$fe))}function tEn(){x3e();var e;return J_t?l(VE((ib(),Gf),Ff),2038):(wi(uv,new OI),XMn(),e=l(De(xu((ib(),Gf),Ff),560)?xu(Gf,Ff):new fat,560),J_t=!0,QIn(e),iOn(e),ki((y3e(),_Pe),e,new k1),rc(Gf,Ff,e),e)}function nEn(e,t){var n,r,a,o;e.j=-1,hh(e.e)?(n=e.i,o=e.i!=0,tN(e,t),r=new Zg(e.e,3,e.c,null,t,n,o),a=t.zl(e.e,e.c,null),a=Lgt(e,t,a),a?(a.nj(r),a.oj()):Ni(e.e,r)):(tN(e,t),a=t.zl(e.e,e.c,null),a&&a.oj())}function kU(e,t){var n,r,a;if(a=0,r=t[0],r>=e.length)return-1;for(n=(Xn(r,e.length),e.charCodeAt(r));n>=48&&n<=57&&(a=a*10+(n-48),++r,!(r>=e.length));)n=(Xn(r,e.length),e.charCodeAt(r));return r>t[0]?t[0]=r:a=-1,a}function rEn(e){var t,n,r,a,o;return a=l(e.a,17).a,o=l(e.b,17).a,n=a,r=o,t=b.Math.max(b.Math.abs(a),b.Math.abs(o)),a<=0&&a==o?(n=0,r=o-1):a==-t&&o!=t?(n=o,r=a,o>=0&&++n):(n=-o,r=a),new ca(pt(n),pt(r))}function iEn(e,t,n,r){var a,o,f,g,w,E;for(a=0;a=0&&E>=0&&w=e.i)throw ue(new tc(Qfe+t+av+e.i));if(n>=e.i)throw ue(new tc(Jfe+n+av+e.i));return r=e.g[n],t!=n&&(t>16),t=r>>16&16,n=16-t,e=e>>t,r=e-256,t=r>>16&8,n+=t,e<<=t,r=e-Xy,t=r>>16&4,n+=t,e<<=t,r=e-_d,t=r>>16&2,n+=t,e<<=t,r=e>>14,t=r&~(r>>1),n+2-t)}function aEn(e){tx();var t,n,r,a;for(wK=new bt,X0e=new Pr,Y0e=new bt,t=(!e.a&&(e.a=new nt(Ai,e,10,11)),e.a),XDn(t),a=new or(t);a.e!=a.i.gc();)r=l(gr(a),27),gc(wK,r,0)==-1&&(n=new bt,vt(Y0e,n),Z1t(r,n));return Y0e}function oEn(e,t,n){var r,a,o,f;e.a=n.b.d,De(t,326)?(a=l6(l(t,74),!1,!1),o=QN(a),r=new t_(e),to(o,r),dP(o,a),t.of((pi(),x3))!=null&&to(l(t.of(x3),75),r)):(f=l(t,422),f.rh(f.nh()+e.a.a),f.sh(f.oh()+e.a.b))}function cEn(e,t){var n,r,a;for(a=new bt,r=Rr(t.a,0);r.b!=r.d.c;)n=l(Br(r),65),n.c.g==e.g&&qe(Q(n.b,(Hc(),$d)))!==qe(Q(n.c,$d))&&!W5(new bn(null,new kn(a,16)),new cXe(n))&&$n(a.c,n);return Vs(a,new Mte),a}function Qpt(e,t,n){var r,a,o,f;return De(t,153)&&De(n,153)?(o=l(t,153),f=l(n,153),e.a[o.a][f.a]+e.a[f.a][o.a]):De(t,250)&&De(n,250)&&(r=l(t,250),a=l(n,250),r.a==a.a)?l(Q(a.a,(b0(),qx)),17).a:0}function Jpt(e,t){var n,r,a,o,f,g,w,E;for(E=ze(Ge(Q(t,(Nt(),tM)))),w=e[0].n.a+e[0].o.a+e[0].d.c+E,g=1;g=0?n:(g=eA(ma(new lt(f.c+f.b/2,f.d+f.a/2),new lt(o.c+o.b/2,o.d+o.a/2))),-(Tmt(o,f)-1)*g)}function lEn(e,t,n){var r;Is(new bn(null,(!n.a&&(n.a=new nt(cs,n,6,6)),new kn(n.a,16))),new dtt(e,t)),Is(new bn(null,(!n.n&&(n.n=new nt(ec,n,1,7)),new kn(n.n,16))),new gtt(e,t)),r=l(at(n,(pi(),x3)),75),r&&k7e(r,e,t)}function Hw(e,t,n){var r,a,o;if(o=g6((El(),io),e.Dh(),t),o)return Fo(),l(o,69).xk()||(o=rx(ic(io,o))),a=(r=e.Ih(o),l(r>=0?e.Lh(r,!0,!0):Hw(e,o,!0),160)),l(a,220).Sl(t,n);throw ue(new Yn(Ob+t.xe()+$fe))}function y9e(e,t,n,r){var a,o,f,g,w;if(a=e.d[t],a){if(o=a.g,w=a.i,r!=null){for(g=0;g=n&&(r=t,E=(w.c+w.a)/2,f=E-n,w.c<=E-n&&(a=new vae(w.c,f),pw(e,r++,a)),g=E+n,g<=w.a&&(o=new vae(g,w.a),Ey(r,e.c.length),x_(e.c,r,o)))}function t2t(e,t,n){var r,a,o,f,g,w;if(!t.dc()){for(a=new os,w=t.Kc();w.Ob();)for(g=l(w.Pb(),40),ki(e.a,pt(g.g),pt(n)),f=(r=Rr(new Hg(g).a.d,0),new C5(r));QI(f.a);)o=l(Br(f.a),65).c,Cs(a,o,a.c.b,a.c);t2t(e,a,n+1)}}function x9e(e){var t;if(!e.c&&e.g==null)e.d=e.bj(e.f),qr(e,e.d),t=e.d;else{if(e.g==null)return!0;if(e.i==0)return!1;t=l(e.g[e.i-1],51)}return t==e.b&&null.Vm>=null.Um()?(CU(e),x9e(e)):t.Ob()}function n2t(e){if(this.a=e,e.c.i.k==(Zn(),Us))this.c=e.c,this.d=l(Q(e.c.i,(ft(),Wc)),64);else if(e.d.i.k==Us)this.c=e.d,this.d=l(Q(e.d.i,(ft(),Wc)),64);else throw ue(new Yn("Edge "+e+" is not an external edge."))}function r2t(e,t){var n,r,a;a=e.b,e.b=t,e.Db&4&&!(e.Db&1)&&Ni(e,new _a(e,1,3,a,e.b)),t?t!=e&&(Fu(e,t.zb),Qoe(e,t.d),n=(r=t.c,r??t.zb),Zoe(e,n==null||vn(n,t.zb)?null:n)):(Fu(e,null),Qoe(e,0),Zoe(e,null))}function i2t(e,t){var n;this.e=(ww(),Xr(e),ww(),P8e(e)),this.c=(Xr(t),P8e(t)),Tye(this.e.Rd().dc()==this.c.Rd().dc()),this.d=w1t(this.e),this.b=w1t(this.c),n=Lm(wa,[dt,Rn],[5,1],5,[this.e.Rd().gc(),this.c.Rd().gc()],2),this.a=n,jwn(this)}function s2t(e){!C0e&&(C0e=cIn());var t=e.replace(/[\x00-\x1f\xad\u0600-\u0603\u06dd\u070f\u17b4\u17b5\u200b-\u200f\u2028-\u202e\u2060-\u2064\u206a-\u206f\ufeff\ufff9-\ufffb"\\]/g,function(n){return f2n(n)});return'"'+t+'"'}function k9e(e,t,n,r,a,o){var f,g,w,E,C;if(a!=0)for(qe(e)===qe(n)&&(e=e.slice(t,t+a),t=0),w=n,g=t,E=t+a;g=f)throw ue(new my(t,f));return a=n[t],f==1?r=null:(r=We(epe,r0e,424,f-1,0,1),pu(n,0,r,0,t),o=f-t-1,o>0&&pu(n,t+1,r,t,o)),PE(e,r),Apt(e,t,a),a}function o2t(e){var t,n;if(e.f){for(;e.n0?o=gx(n):o=BN(gx(n))),Hi(t,VT,o)}function mEn(e,t){var n;t.Ug("Partition preprocessing",1),n=l(yc(Fi(Dc(Fi(new bn(null,new kn(e.a,16)),new AZ),new LZ),new wj),Pl(new zr,new ht,new Fn,he(le(oc,1),it,108,0,[(Fl(),Ec)]))),15),Is(n.Oc(),new t8),t.Vg()}function vEn(e,t){var n,r,a,o,f;for(f=e.j,t.a!=t.b&&Vs(f,new kS),a=f.c.length/2|0,r=0;r0&&lP(e,n,t),o):r.a!=null?(lP(e,t,n),-1):a.a!=null?(lP(e,n,t),1):0}function yEn(e,t){var n,r,a,o,f;for(a=t.b.b,e.a=We(mf,Qy,15,a,0,1),e.b=We(ih,pg,28,a,16,1),f=Rr(t.b,0);f.b!=f.d.c;)o=l(Br(f),40),e.a[o.g]=new os;for(r=Rr(t.a,0);r.b!=r.d.c;)n=l(Br(r),65),e.a[n.b.g].Fc(n),e.a[n.c.g].Fc(n)}function h2t(e,t){var n,r,a,o;e.Pj()?(n=e.Ej(),o=e.Qj(),++e.j,e.qj(n,e.Zi(n,t)),r=e.Ij(3,null,t,n,o),e.Mj()?(a=e.Nj(t,null),a?(a.nj(r),a.oj()):e.Jj(r)):e.Jj(r)):(tat(e,t),e.Mj()&&(a=e.Nj(t,null),a&&a.oj()))}function E9e(e,t,n){var r,a,o;e.Pj()?(o=e.Qj(),IN(e,t,n),r=e.Ij(3,null,n,t,o),e.Mj()?(a=e.Nj(n,null),e.Tj()&&(a=e.Uj(n,a)),a?(a.nj(r),a.oj()):e.Jj(r)):e.Jj(r)):(IN(e,t,n),e.Mj()&&(a=e.Nj(n,null),a&&a.oj()))}function EU(e,t){var n,r,a,o,f;for(f=Wu(e.e.Dh(),t),a=new X2,n=l(e.g,124),o=e.i;--o>=0;)r=n[o],f.am(r.Lk())&&qr(a,r);!awt(e,a)&&hh(e.e)&&xk(e,t.Jk()?db(e,6,t,(Cn(),_o),null,-1,!1):db(e,t.tk()?2:1,t,null,null,-1,!1))}function xEn(e,t){var n,r,a,o,f;return e.a==(zE(),VL)?!0:(o=t.a.c,n=t.a.c+t.a.b,!(t.j&&(r=t.A,f=r.c.c.a-r.o.a/2,a=o-(r.n.a+r.o.a),a>f)||t.q&&(r=t.C,f=r.c.c.a-r.o.a/2,a=r.n.a-n,a>f)))}function f2t(e){foe();var t,n,r,a,o,f,g;for(n=new e2,a=new G(e.e.b);a.a1?e.e*=ze(e.a):e.f/=ze(e.a),Hyn(e),Y5n(e),GSn(e),rt(e.b,(IA(),vK),e.g)}function b2t(e,t,n){var r,a,o,f,g,w;for(r=0,w=n,t||(r=n*(e.c.length-1),w*=-1),o=new G(e);o.a=0?e.Ah(null):e.Ph().Th(e,-1-t,null,null)),e.Bh(l(a,54),n),r&&r.oj(),e.vh()&&e.wh()&&n>-1&&Ni(e,new _a(e,9,n,o,a)),a):o}function S9e(e,t){var n,r,a,o,f;for(o=e.b.Ce(t),r=(n=e.a.get(o),n??We(wa,Rn,1,0,5,1)),f=0;f>5,a>=e.d)return e.e<0;if(n=e.a[a],t=1<<(t&31),e.e<0){if(r=Mft(e),a>16)),15).dd(o),g0&&(!(Ug(e.a.c)&&t.n.d)&&!(B5(e.a.c)&&t.n.b)&&(t.g.d+=b.Math.max(0,r/2-.5)),!(Ug(e.a.c)&&t.n.a)&&!(B5(e.a.c)&&t.n.c)&&(t.g.a-=r-1))}function C2t(e){var t,n,r,a,o;if(a=new bt,o=ymt(e,a),t=l(Q(e,(ft(),jl)),10),t)for(r=new G(t.j);r.a>t,o=e.m>>t|n<<22-t,a=e.l>>t|e.m<<22-t):t<44?(f=r?hp:0,o=n>>t-22,a=e.m>>t-22|n<<44-t):(f=r?hp:0,o=r?eh:0,a=n>>t-44),qu(a&eh,o&eh,f&hp)}function Gue(e){var t,n,r,a,o,f;for(this.c=new bt,this.d=e,r=gs,a=gs,t=ia,n=ia,f=Rr(e,0);f.b!=f.d.c;)o=l(Br(f),8),r=b.Math.min(r,o.a),a=b.Math.min(a,o.b),t=b.Math.max(t,o.a),n=b.Math.max(n,o.b);this.a=new ef(r,a,t-r,n-a)}function _2t(e,t){var n,r,a,o,f,g;for(o=new G(e.b);o.a0&&De(t,44)&&(e.a._j(),E=l(t,44),w=E.ld(),o=w==null?0:es(w),f=Qye(e.a,o),n=e.a.d[f],n)){for(r=l(n.g,379),C=n.i,g=0;g=2)for(n=a.Kc(),t=Ge(n.Pb());n.Ob();)o=t,t=Ge(n.Pb()),r=b.Math.min(r,(nr(t),t-(nr(o),o)));return r}function HEn(e,t){var n,r,a;for(a=new bt,r=Rr(t.a,0);r.b!=r.d.c;)n=l(Br(r),65),n.b.g==e.g&&!vn(n.b.c,DG)&&qe(Q(n.b,(Hc(),$d)))!==qe(Q(n.c,$d))&&!W5(new bn(null,new kn(a,16)),new uXe(n))&&$n(a.c,n);return Vs(a,new Nte),a}function VEn(e,t){var n,r,a;if(qe(t)===qe(Xr(e)))return!0;if(!De(t,15)||(r=l(t,15),a=e.gc(),a!=r.gc()))return!1;if(De(r,59)){for(n=0;n0&&(a=n),f=new G(e.f.e);f.a0?(t-=1,n-=1):r>=0&&a<0?(t+=1,n+=1):r>0&&a>=0?(t-=1,n+=1):(t+=1,n-=1),new ca(pt(t),pt(n))}function iTn(e,t){return e.ct.c?1:e.bt.b?1:e.a!=t.a?es(e.a)-es(t.a):e.d==(oA(),uM)&&t.d==cM?-1:e.d==cM&&t.d==uM?1:0}function N2t(e,t){var n,r,a,o,f;return o=t.a,o.c.i==t.b?f=o.d:f=o.c,o.c.i==t.b?r=o.c:r=o.d,a=S5n(e.a,f,r),a>0&&a0):a<0&&-a0):!1}function sTn(e,t,n,r){var a,o,f,g,w,E,C,L;for(a=(t-e.d)/e.c.c.length,o=0,e.a+=n,e.d=t,L=new G(e.c);L.a>24;return f}function oTn(e){if(e.ze()){var t=e.c;t.Ae()?e.o="["+t.n:t.ze()?e.o="["+t.xe():e.o="[L"+t.xe()+";",e.b=t.we()+"[]",e.k=t.ye()+"[]";return}var n=e.j,r=e.d;r=r.split("/"),e.o=Xce(".",[n,Xce("$",r)]),e.b=Xce(".",[n,Xce(".",r)]),e.k=r[r.length-1]}function cTn(e,t){var n,r,a,o,f;for(f=null,o=new G(e.e.a);o.a=0;t-=2)for(n=0;n<=t;n+=2)(e.b[n]>e.b[n+2]||e.b[n]===e.b[n+2]&&e.b[n+1]>e.b[n+3])&&(r=e.b[n+2],e.b[n+2]=e.b[n],e.b[n]=r,r=e.b[n+3],e.b[n+3]=e.b[n+1],e.b[n+1]=r);e.c=!0}}function hTn(e,t){var n,r,a,o,f,g,w,E,C;for(E=-1,C=0,f=e,g=0,w=f.length;g0&&++C;++E}return C}function g0(e){var t,n;return n=new Th(_m(e.Rm)),n.a+="@",hi(n,(t=es(e)>>>0,t.toString(16))),e.Vh()?(n.a+=" (eProxyURI: ",wu(n,e._h()),e.Kh()&&(n.a+=" eClass: ",wu(n,e.Kh())),n.a+=")"):e.Kh()&&(n.a+=" (eClass: ",wu(n,e.Kh()),n.a+=")"),n.a}function HA(e){var t,n,r,a;if(e.e)throw ue(new nc((Gg(R0e),phe+R0e.k+bhe)));for(e.d==(Js(),J1)&&UU(e,uc),n=new G(e.a.a);n.a>24}return n}function gTn(e,t,n){var r,a,o;if(a=l(Qo(e.i,t),314),!a)if(a=new yht(e.d,t,n),Q8(e.i,t,a),$8e(t))vhn(e.a,t.c,t.b,a);else switch(o=Q9n(t),r=l(Qo(e.p,o),252),o.g){case 1:case 3:a.j=!0,Xie(r,t.b,a);break;case 4:case 2:a.k=!0,Xie(r,t.c,a)}return a}function pTn(e,t){var n,r,a,o,f,g,w,E,C;for(w=eg(e.c-e.b&e.a.length-1),E=null,C=null,o=new nA(e);o.a!=o.b;)a=l(FV(o),10),n=(g=l(Q(a,(ft(),o1)),12),g?g.i:null),r=(f=l(Q(a,$f),12),f?f.i:null),(E!=n||C!=r)&&(m2t(w,t),E=n,C=r),$n(w.c,a);m2t(w,t)}function bTn(e,t,n,r){var a,o,f,g,w,E;if(g=new X2,w=Wu(e.e.Dh(),t),a=l(e.g,124),Fo(),l(t,69).xk())for(f=0;f=0)return a;for(o=1,g=new G(t.j);g.a=0)return a;for(o=1,g=new G(t.j);g.a0&&t.Ne((Sn(a-1,e.c.length),l(e.c[a-1],10)),o)>0;)rf(e,a,(Sn(a-1,e.c.length),l(e.c[a-1],10))),--a;Sn(a,e.c.length),e.c[a]=o}n.a=new Pr,n.b=new Pr}function mTn(e,t,n){var r,a,o,f,g,w,E,C;for(C=(r=l(t.e&&t.e(),9),new Zh(r,l(c0(r,r.length),9),0)),w=Gy(n,"[\\[\\]\\s,]+"),o=w,f=0,g=o.length;f=0?(t||(t=new h_,r>0&&Xo(t,(Ga(0,r,e.length),e.substr(0,r)))),t.a+="\\",Uk(t,n&Zs)):t&&Uk(t,n&Zs);return t?t.a:e}function wTn(e){var t,n,r;for(n=new G(e.a.a.b);n.a0&&(!(Ug(e.a.c)&&t.n.d)&&!(B5(e.a.c)&&t.n.b)&&(t.g.d-=b.Math.max(0,r/2-.5)),!(Ug(e.a.c)&&t.n.a)&&!(B5(e.a.c)&&t.n.c)&&(t.g.a+=b.Math.max(0,r-1)))}function H2t(e,t,n){var r,a;if((e.c-e.b&e.a.length-1)==2)t==(Ct(),Qn)||t==ar?(uV(l(wA(e),15),(Ih(),kg)),uV(l(wA(e),15),Gb)):(uV(l(wA(e),15),(Ih(),Gb)),uV(l(wA(e),15),kg));else for(a=new nA(e);a.a!=a.b;)r=l(FV(a),15),uV(r,n)}function yTn(e,t){var n,r,a,o,f,g,w;for(a=$k(new ywe(e)),g=new Ua(a,a.c.length),o=$k(new ywe(t)),w=new Ua(o,o.c.length),f=null;g.b>0&&w.b>0&&(n=(mr(g.b>0),l(g.a.Xb(g.c=--g.b),27)),r=(mr(w.b>0),l(w.a.Xb(w.c=--w.b),27)),n==r);)f=n;return f}function V2t(e,t,n){var r,a,o,f;Uot(e,t)>Uot(e,n)?(r=Oc(n,(Ct(),ar)),e.d=r.dc()?0:Tae(l(r.Xb(0),12)),f=Oc(t,er),e.b=f.dc()?0:Tae(l(f.Xb(0),12))):(a=Oc(n,(Ct(),er)),e.d=a.dc()?0:Tae(l(a.Xb(0),12)),o=Oc(t,ar),e.b=o.dc()?0:Tae(l(o.Xb(0),12)))}function U2t(e,t){var n,r,a,o;for(n=e.o.a,o=l(l($i(e.r,t),21),87).Kc();o.Ob();)a=l(o.Pb(),117),a.e.a=n*ze(Ge(a.b.of(pK))),a.e.b=(r=a.b,r.pf((pi(),rh))?r.ag()==(Ct(),Qn)?-r.Mf().b-ze(Ge(r.of(rh))):ze(Ge(r.of(rh))):r.ag()==(Ct(),Qn)?-r.Mf().b:0)}function xTn(e,t){var n,r,a,o;for(t.Ug("Self-Loop pre-processing",1),r=new G(e.a);r.ae.c));f++)a.a>=e.s&&(o<0&&(o=f),g=f);return w=(e.s+e.c)/2,o>=0&&(r=u_n(e,t,o,g),w=oln((Sn(r,t.c.length),l(t.c[r],339))),gEn(t,r,n)),w}function Wr(e,t,n){var r,a,o,f,g,w,E;for(f=(o=new CI,o),g7e(f,(nr(t),t)),E=(!f.b&&(f.b=new dh((Tn(),No),Yc,f)),f.b),w=1;w0&&sMn(this,a)}function F9e(e,t,n,r,a,o){var f,g,w;if(!a[t.a]){for(a[t.a]=!0,f=r,!f&&(f=new KH),vt(f.e,t),w=o[t.a].Kc();w.Ob();)g=l(w.Pb(),290),!(g.d==n||g.c==n)&&(g.c!=t&&F9e(e,g.c,t,f,a,o),g.d!=t&&F9e(e,g.d,t,f,a,o),vt(f.c,g),ra(f.d,g.b));return f}return null}function TTn(e){var t,n,r,a,o,f,g;for(t=0,a=new G(e.e);a.a=2}function CTn(e,t,n,r,a){var o,f,g,w,E,C;for(o=e.c.d.j,f=l(ff(n,0),8),C=1;C1||(t=rs(E0,he(le(Ko,1),it,95,0,[mp,T0])),yN(NH(t,e))>1)||(r=rs(S0,he(le(Ko,1),it,95,0,[Eg,qf])),yN(NH(r,e))>1))}function R9e(e,t,n){var r,a,o;for(o=new G(e.t);o.a0&&(r.b.n-=r.c,r.b.n<=0&&r.b.u>0&&ui(t,r.b));for(a=new G(e.i);a.a0&&(r.a.u-=r.c,r.a.u<=0&&r.a.n>0&&ui(n,r.a))}function CU(e){var t,n,r,a,o;if(e.g==null&&(e.d=e.bj(e.f),qr(e,e.d),e.c))return o=e.f,o;if(t=l(e.g[e.i-1],51),a=t.Pb(),e.e=t,n=e.bj(a),n.Ob())e.d=n,qr(e,n);else for(e.d=null;!t.Ob()&&(Ts(e.g,--e.i,null),e.i!=0);)r=l(e.g[e.i-1],51),t=r;return a}function _Tn(e,t){var n,r,a,o,f,g;if(r=t,a=r.Lk(),up(e.e,a)){if(a.Si()&&qH(e,a,r.md()))return!1}else for(g=Wu(e.e.Dh(),a),n=l(e.g,124),o=0;o1||n>1)return 2;return t+n==1?2:0}function Jl(e,t){var n,r,a,o,f,g;return o=e.a*hhe+e.b*1502,g=e.b*hhe+11,n=b.Math.floor(g*MP),o+=n,g-=n*cEe,o%=cEe,e.a=o,e.b=g,t<=24?b.Math.floor(e.a*m_e[t]):(a=e.a*(1<=2147483648&&(r-=4294967296),r)}function X2t(e,t,n){var r,a,o,f,g,w,E;for(o=new bt,E=new os,f=new os,YAn(e,E,f,t),_Mn(e,E,f,t,n),w=new G(e);w.ar.b.g&&$n(o.c,r);return o}function OTn(e,t,n){var r,a,o,f,g,w;for(g=e.c,f=(n.q?n.q:(Cn(),Cn(),mg)).vc().Kc();f.Ob();)o=l(f.Pb(),44),r=!_k(Fi(new bn(null,new kn(g,16)),new Wl(new att(t,o)))).Bd((Am(),zx)),r&&(w=o.md(),De(w,4)&&(a=H8e(w),a!=null&&(w=a)),t.qf(l(o.ld(),149),w))}function NTn(e,t,n){var r,a;if(qO(e.b),X0(e.b,(PN(),WW),(b_(),qB)),X0(e.b,YW,t.g),X0(e.b,XW,t.a),e.a=bP(e.b,t),n.Ug("Compaction by shrinking a tree",e.a.c.length),t.i.c.length>1)for(a=new G(e.a);a.a=0?e.Lh(r,!0,!0):Hw(e,o,!0),160)),l(a,220).Xl(t,n)}else throw ue(new Yn(Ob+t.xe()+kL))}function SU(e,t){var n,r,a,o,f;if(t){for(o=De(e.Cb,90)||De(e.Cb,102),f=!o&&De(e.Cb,331),r=new or((!t.a&&(t.a=new G_(t,Wo,t)),t.a));r.e!=r.i.gc();)if(n=l(gr(r),89),a=jU(n),o?De(a,90):f?De(a,156):a)return a;return o?(Tn(),Kf):(Tn(),td)}else return null}function PTn(e,t){var n,r,a,o;for(t.Ug("Resize child graph to fit parent.",1),r=new G(e.b);r.a=2*t&&vt(n,new vae(f[r-1]+t,f[r]-t));return n}function RTn(e,t,n){var r,a,o,f,g,w,E,C;if(n)for(o=n.a.length,r=new Dm(o),g=(r.b-r.a)*r.c<0?(sb(),tm):new cb(r);g.Ob();)f=l(g.Pb(),17),a=Jk(n,f.a),a&&(w=gmn(e,(E=(rb(),C=new jwe,C),t&&z9e(E,t),E),a),fE(w,Yg(a,Pd)),mU(a,w),h9e(a,w),wce(e,a,w))}function _U(e){var t,n,r,a,o,f;if(!e.j){if(f=new IS,t=qM,o=t.a.zc(e,t),o==null){for(r=new or(dc(e));r.e!=r.i.gc();)n=l(gr(r),29),a=_U(n),As(f,a),qr(f,n);t.a.Bc(e)!=null}Iy(f),e.j=new N5((l(Oe(tt((lb(),Vn).o),11),19),f.i),f.g),Yl(e).b&=-33}return e.j}function jTn(e){var t,n,r,a;if(e==null)return null;if(r=Tu(e,!0),a=eB.length,vn(r.substr(r.length-a,a),eB)){if(n=r.length,n==4){if(t=(Xn(0,r.length),r.charCodeAt(0)),t==43)return KPe;if(t==45)return wAt}else if(n==3)return KPe}return new Awe(r)}function $Tn(e){var t,n,r;return n=e.l,n&n-1||(r=e.m,r&r-1)||(t=e.h,t&t-1)||t==0&&r==0&&n==0?-1:t==0&&r==0&&n!=0?i7e(n):t==0&&r!=0&&n==0?i7e(r)+22:t!=0&&r==0&&n==0?i7e(t)+44:-1}function u6(e,t){var n,r,a,o,f;for(a=t.a&e.f,o=null,r=e.b[a];;r=r.b){if(r==t){o?o.b=t.b:e.b[a]=t.b;break}o=r}for(f=t.f&e.f,o=null,n=e.c[f];;n=n.d){if(n==t){o?o.d=t.d:e.c[f]=t.d;break}o=n}t.e?t.e.c=t.c:e.a=t.c,t.c?t.c.e=t.e:e.e=t.e,--e.i,++e.g}function zTn(e,t){var n;t.d?t.d.b=t.b:e.a=t.b,t.b?t.b.d=t.d:e.e=t.d,!t.e&&!t.c?(n=l(Lf(l(ax(e.b,t.a),260)),260),n.a=0,++e.c):(n=l(Lf(l(cr(e.b,t.a),260)),260),--n.a,t.e?t.e.c=t.c:n.b=l(Lf(t.c),511),t.c?t.c.e=t.e:n.c=l(Lf(t.e),511)),--e.d}function qTn(e){var t,n,r,a,o,f,g,w,E,C;for(n=e.o,t=e.p,f=Ii,a=lo,g=Ii,o=lo,E=0;E0),o.a.Xb(o.c=--o.b),by(o,a),mr(o.b3&&ag(e,0,t-3))}function VTn(e){var t,n,r,a;return qe(Q(e,(Nt(),p4)))===qe((rp(),A2))?!e.e&&qe(Q(e,TB))!==qe((vE(),vB)):(r=l(Q(e,Z1e),299),a=Rt(Bt(Q(e,ede)))||qe(Q(e,JL))===qe((dA(),mB)),t=l(Q(e,SMe),17).a,n=e.a.c.length,!a&&r!=(vE(),vB)&&(t==0||t>n))}function UTn(e){var t,n;for(n=0;n0);n++);if(n>0&&n0);t++);return t>0&&n>16!=6&&t){if(FE(e,t))throw ue(new Yn(EL+d2t(e)));r=null,e.Cb&&(r=(n=e.Db>>16,n>=0?lxe(e,r):e.Cb.Th(e,-1-n,null,r))),t&&(r=mx(t,e,6,r)),r=Wye(e,t,r),r&&r.oj()}else e.Db&4&&!(e.Db&1)&&Ni(e,new _a(e,1,6,t,t))}function AU(e,t){var n,r;if(t!=e.Cb||e.Db>>16!=3&&t){if(FE(e,t))throw ue(new Yn(EL+evt(e)));r=null,e.Cb&&(r=(n=e.Db>>16,n>=0?gxe(e,r):e.Cb.Th(e,-1-n,null,r))),t&&(r=mx(t,e,12,r)),r=Yye(e,t,r),r&&r.oj()}else e.Db&4&&!(e.Db&1)&&Ni(e,new _a(e,1,3,t,t))}function z9e(e,t){var n,r;if(t!=e.Cb||e.Db>>16!=9&&t){if(FE(e,t))throw ue(new Yn(EL+Jbt(e)));r=null,e.Cb&&(r=(n=e.Db>>16,n>=0?fxe(e,r):e.Cb.Th(e,-1-n,null,r))),t&&(r=mx(t,e,9,r)),r=Xye(e,t,r),r&&r.oj()}else e.Db&4&&!(e.Db&1)&&Ni(e,new _a(e,1,9,t,t))}function UE(e){var t,n,r,a,o;if(r=Of(e),o=e.j,o==null&&r)return e.Jk()?null:r.ik();if(De(r,156)){if(n=r.jk(),n&&(a=n.wi(),a!=e.i)){if(t=l(r,156),t.nk())try{e.g=a.ti(t,o)}catch(f){if(f=bs(f),De(f,82))e.g=null;else throw ue(f)}e.i=a}return e.g}return null}function ebt(e){var t;return t=new bt,vt(t,new B8(new lt(e.c,e.d),new lt(e.c+e.b,e.d))),vt(t,new B8(new lt(e.c,e.d),new lt(e.c,e.d+e.a))),vt(t,new B8(new lt(e.c+e.b,e.d+e.a),new lt(e.c+e.b,e.d))),vt(t,new B8(new lt(e.c+e.b,e.d+e.a),new lt(e.c,e.d+e.a))),t}function GTn(e){var t,n,r;if(e==null)return ul;try{return xc(e)}catch(a){if(a=bs(a),De(a,103))return t=a,r=_m(bh(e))+"@"+(n=(Vg(),q8e(e)>>>0),n.toString(16)),a6n(U3n(),(Dk(),"Exception during lenientFormat for "+r),t),"<"+r+" threw "+_m(t.Rm)+">";throw ue(a)}}function KTn(e,t,n){var r,a,o;for(o=t.a.ec().Kc();o.Ob();)a=l(o.Pb(),74),r=l(cr(e.b,a),272),!r&&(ds(cg(a))==ds(Eb(a))?NCn(e,a,n):cg(a)==ds(Eb(a))?cr(e.c,a)==null&&cr(e.b,Eb(a))!=null&&Ivt(e,a,n,!1):cr(e.d,a)==null&&cr(e.b,cg(a))!=null&&Ivt(e,a,n,!0))}function WTn(e,t){var n,r,a,o,f,g,w;for(a=e.Kc();a.Ob();)for(r=l(a.Pb(),10),g=new gu,Mc(g,r),la(g,(Ct(),ar)),rt(g,(ft(),oW),(Hn(),!0)),f=t.Kc();f.Ob();)o=l(f.Pb(),10),w=new gu,Mc(w,o),la(w,er),rt(w,oW,!0),n=new Tw,rt(n,oW,!0),po(n,g),Fa(n,w)}function YTn(e,t,n,r){var a,o,f,g;a=R1t(e,t,n),o=R1t(e,n,t),f=l(cr(e.c,t),118),g=l(cr(e.c,n),118),a1)for(t=hw((n=new Sm,++e.b,n),e.d),g=Rr(o,0);g.b!=g.d.c;)f=l(Br(g),125),p0(s0(i0(a0(r0(new _f,1),0),t),f))}function JTn(e,t,n){var r,a,o,f,g;for(n.Ug("Breaking Point Removing",1),e.a=l(Q(t,(Nt(),bp)),223),o=new G(t.b);o.a>16!=11&&t){if(FE(e,t))throw ue(new Yn(EL+oke(e)));r=null,e.Cb&&(r=(n=e.Db>>16,n>=0?pxe(e,r):e.Cb.Th(e,-1-n,null,r))),t&&(r=mx(t,e,10,r)),r=s4e(e,t,r),r&&r.oj()}else e.Db&4&&!(e.Db&1)&&Ni(e,new _a(e,1,11,t,t))}function ZTn(e){var t,n,r,a;for(r=new qm(new Sr(e.b).a);r.b;)n=Nw(r),a=l(n.ld(),12),t=l(n.md(),10),rt(t,(ft(),zi),a),rt(a,jl,t),rt(a,xB,(Hn(),!0)),la(a,l(Q(t,Wc),64)),Q(t,Wc),rt(a.i,(Nt(),Ms),(Ra(),sC)),l(Q(eo(a.i),Lu),21).Fc((Ho(),$T))}function eCn(e,t,n){var r,a,o,f,g,w;if(o=0,f=0,e.c)for(w=new G(e.d.i.j);w.ao.a?-1:a.aw){for(C=e.d,e.d=We(vPe,_Se,66,2*w+4,0,1),o=0;o=9223372036854776e3?(iE(),WSe):(a=!1,e<0&&(a=!0,e=-e),r=0,e>=Zm&&(r=ua(e/Zm),e-=r*Zm),n=0,e>=Lx&&(n=ua(e/Lx),e-=n*Lx),t=ua(e),o=qu(t,n,r),a&&yce(o),o)}function hCn(e){var t,n,r,a,o;if(o=new bt,Vu(e.b,new Jd(o)),e.b.c.length=0,o.c.length!=0){for(t=(Sn(0,o.c.length),l(o.c[0],82)),n=1,r=o.c.length;n=-t&&r==t?new ca(pt(n-1),pt(r)):new ca(pt(n),pt(r-1))}function rbt(){return vo(),he(le(EOn,1),it,81,0,[PAe,IAe,D6,f1e,eLe,DK,zK,l4,JAe,HAe,XAe,u4,ZAe,$Ae,tLe,SAe,PK,d1e,LK,RK,rLe,FK,_Ae,QAe,iLe,jK,nLe,MK,FAe,WAe,KAe,qK,MAe,AK,OK,LAe,LT,UAe,zAe,YAe,zL,OAe,DAe,GAe,qAe,NK,$K,AAe,BK,VAe,IK,RAe,BAe,gB,_K,jAe,NAe])}function gCn(e,t,n){e.d=0,e.b=0,t.k==(Zn(),Au)&&n.k==Au&&l(Q(t,(ft(),zi)),10)==l(Q(n,zi),10)&&($oe(t).j==(Ct(),Qn)?V2t(e,t,n):V2t(e,n,t)),t.k==Au&&n.k==Aa?$oe(t).j==(Ct(),Qn)?e.d=1:e.b=1:n.k==Au&&t.k==Aa&&($oe(n).j==(Ct(),Qn)?e.b=1:e.d=1),J6n(e,t,n)}function pCn(e){var t,n,r,a,o,f,g,w,E,C,L;return L=jxe(e),t=e.a,w=t!=null,w&&zk(L,"category",e.a),a=ZI(new br(e.d)),f=!a,f&&(E=new $p,e1(L,"knownOptions",E),n=new oQe(E),to(new br(e.d),n)),o=ZI(e.g),g=!o,g&&(C=new $p,e1(L,"supportedFeatures",C),r=new cQe(C),to(e.g,r)),L}function bCn(e){var t,n,r,a,o,f,g,w,E;for(r=!1,t=336,n=0,o=new Grt(e.length),g=e,w=0,E=g.length;w>16!=7&&t){if(FE(e,t))throw ue(new Yn(EL+lpt(e)));r=null,e.Cb&&(r=(n=e.Db>>16,n>=0?hxe(e,r):e.Cb.Th(e,-1-n,null,r))),t&&(r=l(t,54).Rh(e,1,oF,r)),r=J4e(e,t,r),r&&r.oj()}else e.Db&4&&!(e.Db&1)&&Ni(e,new _a(e,1,7,t,t))}function ibt(e,t){var n,r;if(t!=e.Cb||e.Db>>16!=3&&t){if(FE(e,t))throw ue(new Yn(EL+c1t(e)));r=null,e.Cb&&(r=(n=e.Db>>16,n>=0?dxe(e,r):e.Cb.Th(e,-1-n,null,r))),t&&(r=l(t,54).Rh(e,0,uF,r)),r=Z4e(e,t,r),r&&r.oj()}else e.Db&4&&!(e.Db&1)&&Ni(e,new _a(e,1,3,t,t))}function Que(e,t){GE();var n,r,a,o,f,g,w,E,C;return t.d>e.d&&(g=e,e=t,t=g),t.d<63?iSn(e,t):(f=(e.d&-2)<<4,E=v6e(e,f),C=v6e(t,f),r=mle(e,sx(E,f)),a=mle(t,sx(C,f)),w=Que(E,C),n=Que(r,a),o=Que(mle(E,r),mle(a,C)),o=Tle(Tle(o,w),n),o=sx(o,f),w=sx(w,f<<1),Tle(Tle(w,o),n))}function p2(){p2=U,gde=new M5(cyt,0),fDe=new M5("LONGEST_PATH",1),dDe=new M5("LONGEST_PATH_SOURCE",2),dde=new M5("COFFMAN_GRAHAM",3),hDe=new M5($he,4),gDe=new M5("STRETCH_WIDTH",5),CW=new M5("MIN_WIDTH",6),WT=new M5("BF_MODEL_ORDER",7),YT=new M5("DF_MODEL_ORDER",8)}function vCn(e,t,n){var r,a,o,f,g;for(f=TA(e,n),g=We(wg,m2,10,t.length,0,1),r=0,o=f.Kc();o.Ob();)a=l(o.Pb(),12),Rt(Bt(Q(a,(ft(),xB))))&&(g[r++]=l(Q(a,jl),10));if(r=0;o+=n?1:-1)f=f|t.c.lg(w,o,n,r&&!Rt(Bt(Q(t.j,(ft(),jb))))&&!Rt(Bt(Q(t.j,(ft(),j6))))),f=f|t.q.ug(w,o,n),f=f|Ubt(e,w[o],n,r);return na(e.c,t),f}function DU(e,t,n){var r,a,o,f,g,w,E,C,L,B;for(C=Tct(e.j),L=0,B=C.length;L1&&(e.a=!0),Qdn(l(n.b,68),Oi(Ja(l(t.b,68).c),md(ma(Ja(l(n.b,68).a),l(t.b,68).a),a))),Dot(e,t),sbt(e,n)}function abt(e){var t,n,r,a,o,f,g;for(o=new G(e.a.a);o.a0&&o>0?f.p=t++:r>0?f.p=n++:o>0?f.p=a++:f.p=n++}Cn(),Vs(e.j,new W9)}function ECn(e){var t,n;n=null,t=l(jt(e.g,0),18);do{if(n=t.d.i,ns(n,(ft(),$f)))return l(Q(n,$f),12).i;if(n.k!=(Zn(),Ps)&&jr(new hr(dr(qs(n).a.Kc(),new j))))t=l(xr(new hr(dr(qs(n).a.Kc(),new j))),18);else if(n.k!=Ps)return null}while(n&&n.k!=(Zn(),Ps));return n}function TCn(e,t){var n,r,a,o,f,g,w,E,C;for(g=t.j,f=t.g,w=l(jt(g,g.c.length-1),113),C=(Sn(0,g.c.length),l(g.c[0],113)),E=vue(e,f,w,C),o=1;oE&&(w=n,C=a,E=r);t.a=C,t.c=w}function CCn(e,t,n){var r,a,o,f,g,w,E;for(E=new Kp(new UYe(e)),f=he(le(F8t,1),I3t,12,0,[t,n]),g=0,w=f.length;gw-e.b&&gw-e.a&&g0?o.a?(g=o.b.Mf().a,n>g&&(a=(n-g)/2,o.d.b=a,o.d.c=a)):o.d.c=e.s+n:W_(e.u)&&(r=$xe(o.b),r.c<0&&(o.d.b=-r.c),r.c+r.b>o.b.Mf().a&&(o.d.c=r.c+r.b-o.b.Mf().a))}function qCn(e,t){var n,r,a,o,f;f=new bt,n=t;do o=l(cr(e.b,n),131),o.B=n.c,o.D=n.d,$n(f.c,o),n=l(cr(e.k,n),18);while(n);return r=(Sn(0,f.c.length),l(f.c[0],131)),r.j=!0,r.A=l(r.d.a.ec().Kc().Pb(),18).c.i,a=l(jt(f,f.c.length-1),131),a.q=!0,a.C=l(a.d.a.ec().Kc().Pb(),18).d.i,f}function HCn(e){var t,n;if(t=l(e.a,17).a,n=l(e.b,17).a,t>=0){if(t==n)return new ca(pt(-t-1),pt(-t-1));if(t==-n)return new ca(pt(-t),pt(n+1))}return b.Math.abs(t)>b.Math.abs(n)?t<0?new ca(pt(-t),pt(n)):new ca(pt(-t),pt(n+1)):new ca(pt(t+1),pt(n))}function VCn(e){var t,n;n=l(Q(e,(Nt(),Qu)),171),t=l(Q(e,(ft(),hv)),311),n==(hf(),$b)?(rt(e,Qu,EB),rt(e,hv,(ep(),F6))):n==d4?(rt(e,Qu,EB),rt(e,hv,(ep(),Ux))):t==(ep(),F6)?(rt(e,Qu,$b),rt(e,hv,wB)):t==Ux&&(rt(e,Qu,d4),rt(e,hv,wB))}function IU(){IU=U,IB=new pte,XEt=fi(new Xs,(uo(),bu),(vo(),LK)),ZEt=yl(fi(new Xs,bu,FK),mc,BK),eTt=Td(Td(v_(yl(fi(new Xs,y0,zK),mc,$K),_u),jK),qK),QEt=yl(fi(fi(fi(new Xs,vg,DK),_u,OK),_u,LT),mc,IK),JEt=yl(fi(fi(new Xs,_u,LT),_u,AK),mc,_K)}function GA(){GA=U,rTt=fi(yl(new Xs,(uo(),mc),(vo(),RAe)),bu,LK),oTt=Td(Td(v_(yl(fi(new Xs,y0,zK),mc,$K),_u),jK),qK),iTt=yl(fi(fi(fi(new Xs,vg,DK),_u,OK),_u,LT),mc,IK),aTt=fi(fi(new Xs,bu,FK),mc,BK),sTt=yl(fi(fi(new Xs,_u,LT),_u,AK),mc,_K)}function UCn(e,t,n,r,a){var o,f;(!Do(t)&&t.c.i.c==t.d.i.c||!uft(Ic(he(le(Ea,1),dt,8,0,[a.i.n,a.n,a.a])),n))&&!Do(t)&&(t.c==a?Pk(t.a,0,new Eo(n)):ui(t.a,new Eo(n)),r&&!W0(e.a,n)&&(f=l(Q(t,(Nt(),cc)),75),f||(f=new bl,rt(t,cc,f)),o=new Eo(n),Cs(f,o,f.c.b,f.c),na(e.a,o)))}function ubt(e,t){var n,r,a,o;for(o=Yr(mo(fg,ig(Yr(mo(t==null?0:es(t),dg)),15))),n=o&e.b.length-1,a=null,r=e.b[n];r;a=r,r=r.a)if(r.d==o&&yd(r.i,t))return a?a.a=r.a:e.b[n]=r.a,RJe(l(Lf(r.c),604),l(Lf(r.f),604)),WI(l(Lf(r.b),227),l(Lf(r.e),227)),--e.f,++e.e,!0;return!1}function GCn(e){var t,n;for(n=new hr(dr(ka(e).a.Kc(),new j));jr(n);)if(t=l(xr(n),18),t.c.i.k!=(Zn(),cu))throw ue(new Vp(jhe+HN(e)+"' has its layer constraint set to FIRST, but has at least one incoming edge that does not come from a FIRST_SEPARATE node. That must not happen."))}function KCn(e,t,n){var r,a,o,f,g,w,E;if(a=d1t(e.Db&254),a==0)e.Eb=n;else{if(a==1)g=We(wa,Rn,1,2,5,1),o=mue(e,t),o==0?(g[0]=n,g[1]=e.Eb):(g[0]=e.Eb,g[1]=n);else for(g=We(wa,Rn,1,a+1,5,1),f=jm(e.Eb),r=2,w=0,E=0;r<=128;r<<=1)r==t?g[E++]=n:e.Db&r&&(g[E++]=f[w++]);e.Eb=g}e.Db|=t}function lbt(e,t,n){var r,a,o,f;for(this.b=new bt,a=0,r=0,f=new G(e);f.a0&&(o=l(jt(this.b,0),176),a+=o.o,r+=o.p),a*=2,r*=2,t>1?a=ua(b.Math.ceil(a*t)):r=ua(b.Math.ceil(r/t)),this.a=new I8e(a,r)}function hbt(e,t,n,r,a,o){var f,g,w,E,C,L,B,z,V,J,te,fe;for(C=r,t.j&&t.o?(z=l(cr(e.f,t.A),60),J=z.d.c+z.d.b,--C):J=t.a.c+t.a.b,L=a,n.q&&n.o?(z=l(cr(e.f,n.C),60),E=z.d.c,++L):E=n.a.c,te=E-J,w=b.Math.max(2,L-C),g=te/w,V=J+g,B=C;B=0;f+=a?1:-1){for(g=t[f],w=r==(Ct(),ar)?a?Oc(g,r):lf(Oc(g,r)):a?lf(Oc(g,r)):Oc(g,r),o&&(e.c[g.p]=w.gc()),L=w.Kc();L.Ob();)C=l(L.Pb(),12),e.d[C.p]=E++;ra(n,w)}}function dbt(e,t,n){var r,a,o,f,g,w,E,C;for(o=ze(Ge(e.b.Kc().Pb())),E=ze(Ge(V3n(t.b))),r=md(Ja(e.a),E-n),a=md(Ja(t.a),n-o),C=Oi(r,a),md(C,1/(E-o)),this.a=C,this.b=new bt,g=!0,f=e.b.Kc(),f.Pb();f.Ob();)w=ze(Ge(f.Pb())),g&&w-n>wfe&&(this.b.Fc(n),g=!1),this.b.Fc(w);g&&this.b.Fc(n)}function WCn(e){var t,n,r,a;if(f_n(e,e.n),e.d.c.length>0){for(u_(e.c);L9e(e,l(re(new G(e.e.a)),125))>5,t&=31,r>=e.d)return e.e<0?(Cd(),w6t):(Cd(),BL);if(o=e.d-r,a=We(Vr,di,28,o+1,15,1),j9n(a,o,e.a,r,t),e.e<0){for(n=0;n0&&e.a[n]<<32-t){for(n=0;n=0?!1:(n=g6((El(),io),a,t),n?(r=n.Ik(),(r>1||r==-1)&&kw(ic(io,n))!=3):!0)):!1}function JCn(e,t,n,r){var a,o,f,g,w;return g=bc(l(Oe((!t.b&&(t.b=new Ln(_r,t,4,7)),t.b),0),84)),w=bc(l(Oe((!t.c&&(t.c=new Ln(_r,t,5,8)),t.c),0),84)),ds(g)==ds(w)||Ly(w,g)?null:(f=WO(t),f==n?r:(o=l(cr(e.a,f),10),o&&(a=o.e,a)?a:null))}function ZCn(e,t,n){var r,a,o,f,g;for(n.Ug("Longest path to source layering",1),e.a=t,g=e.a.a,e.b=We(Vr,di,28,g.c.length,15,1),r=0,f=new G(g);f.a0&&(n[0]+=e.d,f-=n[0]),n[2]>0&&(n[2]+=e.d,f-=n[2]),o=b.Math.max(0,f),n[1]=b.Math.max(n[1],f),y6e(e,$u,a.c+r.b+n[0]-(n[1]-f)/2,n),t==$u&&(e.c.b=o,e.c.c=a.c+r.b+(o-f)/2)}function Ebt(){this.c=We(Na,Zo,28,(Ct(),he(le(Oo,1),au,64,0,[Pc,Qn,ar,Dr,er])).length,15,1),this.b=We(Na,Zo,28,he(le(Oo,1),au,64,0,[Pc,Qn,ar,Dr,er]).length,15,1),this.a=We(Na,Zo,28,he(le(Oo,1),au,64,0,[Pc,Qn,ar,Dr,er]).length,15,1),E3e(this.c,gs),E3e(this.b,ia),E3e(this.a,ia)}function Eu(e,t,n){var r,a,o,f;if(t<=n?(a=t,o=n):(a=n,o=t),r=0,e.b==null)e.b=We(Vr,di,28,2,15,1),e.b[0]=a,e.b[1]=o,e.c=!0;else{if(r=e.b.length,e.b[r-1]+1==a){e.b[r-1]=o;return}f=We(Vr,di,28,r+2,15,1),pu(e.b,0,f,0,r),e.b=f,e.b[r-1]>=a&&(e.c=!1,e.a=!1),e.b[r++]=a,e.b[r]=o,e.c||c6(e)}}function sSn(e,t,n){var r,a,o,f,g,w,E;for(E=t.d,e.a=new Bu(E.c.length),e.c=new Pr,g=new G(E);g.a=0?e.Lh(E,!1,!0):Hw(e,n,!1),61));e:for(o=L.Kc();o.Ob();){for(a=l(o.Pb(),58),C=0;C1;)Vy(a,a.i-1);return r}function Cbt(e,t){var n,r,a,o,f,g,w;for(n=new z5,o=new G(e.b);o.ae.d[f.p]&&(n+=f6e(e.b,o),gb(e.a,pt(o)));for(;!l_(e.a);)U6e(e.b,l(X8(e.a),17).a)}return n}function hSn(e){var t,n,r,a,o,f,g,w,E;for(e.a=new i4e,E=0,a=0,r=new G(e.i.b);r.ag.d&&(C=g.d+g.a+E));n.c.d=C,t.a.zc(n,t),w=b.Math.max(w,n.c.d+n.c.a)}return w}function Ho(){Ho=U,eW=new uy("COMMENTS",0),vf=new uy("EXTERNAL_PORTS",1),UL=new uy("HYPEREDGES",2),tW=new uy("HYPERNODES",3),$T=new uy("NON_FREE_PORTS",4),B6=new uy("NORTH_SOUTH_PORTS",5),GL=new uy(X3t,6),RT=new uy("CENTER_LABELS",7),jT=new uy("END_LABELS",8),nW=new uy("PARTITIONS",9)}function dSn(e,t,n,r,a){return r<0?(r=o6(e,a,he(le(zt,1),dt,2,6,[$le,zle,qle,Hle,_x,Vle,Ule,Gle,Kle,Wle,Yle,Xle]),t),r<0&&(r=o6(e,a,he(le(zt,1),dt,2,6,["Jan","Feb","Mar","Apr",_x,"Jun","Jul","Aug","Sep","Oct","Nov","Dec"]),t)),r<0?!1:(n.k=r,!0)):r>0?(n.k=r-1,!0):!1}function gSn(e,t,n,r,a){return r<0?(r=o6(e,a,he(le(zt,1),dt,2,6,[$le,zle,qle,Hle,_x,Vle,Ule,Gle,Kle,Wle,Yle,Xle]),t),r<0&&(r=o6(e,a,he(le(zt,1),dt,2,6,["Jan","Feb","Mar","Apr",_x,"Jun","Jul","Aug","Sep","Oct","Nov","Dec"]),t)),r<0?!1:(n.k=r,!0)):r>0?(n.k=r-1,!0):!1}function pSn(e,t,n,r,a,o){var f,g,w,E;if(g=32,r<0){if(t[0]>=e.length||(g=co(e,t[0]),g!=43&&g!=45)||(++t[0],r=kU(e,t),r<0))return!1;g==45&&(r=-r)}return g==32&&t[0]-n==2&&a.b==2&&(w=new Qz,E=w.q.getFullYear()-Lb+Lb-80,f=E%100,o.a=r==f,r+=(E/100|0)*100+(r=0?kb(e):J_(kb(r2(e)))),FL[t]=Aq(l0(e,t),0)?kb(l0(e,t)):J_(kb(r2(l0(e,t)))),e=mo(e,5);for(;t=E&&(w=r);w&&(C=b.Math.max(C,w.a.o.a)),C>B&&(L=E,B=C)}return L}function xSn(e){var t,n,r,a,o,f,g;for(o=new Kp(l(Xr(new Wh),50)),g=ia,n=new G(e.d);n.akyt?Vs(w,e.b):r<=kyt&&r>Eyt?Vs(w,e.d):r<=Eyt&&r>Tyt?Vs(w,e.c):r<=Tyt&&Vs(w,e.a),o=Mbt(e,w,o);return a}function Dbt(e,t,n,r){var a,o,f,g,w,E;for(a=(r.c+r.a)/2,Ch(t.j),ui(t.j,a),Ch(n.e),ui(n.e,a),E=new QJe,g=new G(e.f);g.a1,g&&(r=new lt(a,n.b),ui(t.a,r)),fA(t.a,he(le(Ea,1),dt,8,0,[B,L]))}function J9e(e,t,n){var r,a;for(t=48;n--)GM[n]=n-48<<24>>24;for(r=70;r>=65;r--)GM[r]=r-65+10<<24>>24;for(a=102;a>=97;a--)GM[a]=a-97+10<<24>>24;for(o=0;o<10;o++)LY[o]=48+o&Zs;for(e=10;e<=15;e++)LY[e]=65+e-10&Zs}function CSn(e,t){t.Ug("Process graph bounds",1),rt(e,(Qi(),Bde),fO(uce(xy(new bn(null,new kn(e.b,16)),new zte)))),rt(e,Fde,fO(uce(xy(new bn(null,new kn(e.b,16)),new qte)))),rt(e,rIe,fO(cce(xy(new bn(null,new kn(e.b,16)),new Hte)))),rt(e,iIe,fO(cce(xy(new bn(null,new kn(e.b,16)),new Vte)))),t.Vg()}function SSn(e){var t,n,r,a,o;a=l(Q(e,(Nt(),bv)),21),o=l(Q(e,xW),21),n=new lt(e.f.a+e.d.b+e.d.c,e.f.b+e.d.d+e.d.a),t=new Eo(n),a.Hc((mh(),A4))&&(r=l(Q(e,qT),8),o.Hc((Zl(),aC))&&(r.a<=0&&(r.a=20),r.b<=0&&(r.b=20)),t.a=b.Math.max(n.a,r.a),t.b=b.Math.max(n.b,r.b)),Rt(Bt(Q(e,ade)))||nLn(e,n,t)}function _Sn(e,t){var n,r,a,o;for(o=Oc(t,(Ct(),Dr)).Kc();o.Ob();)r=l(o.Pb(),12),n=l(Q(r,(ft(),jl)),10),n&&p0(s0(i0(a0(r0(new _f,0),.1),e.i[t.p].d),e.i[n.p].a));for(a=Oc(t,Qn).Kc();a.Ob();)r=l(a.Pb(),12),n=l(Q(r,(ft(),jl)),10),n&&p0(s0(i0(a0(r0(new _f,0),.1),e.i[n.p].d),e.i[t.p].a))}function Zue(e){var t,n,r,a,o,f;if(!e.c){if(f=new Qc,t=qM,o=t.a.zc(e,t),o==null){for(r=new or(du(e));r.e!=r.i.gc();)n=l(gr(r),89),a=jU(n),De(a,90)&&As(f,Zue(l(a,29))),qr(f,n);t.a.Bc(e)!=null,t.a.gc()==0}k5n(f),Iy(f),e.c=new N5((l(Oe(tt((lb(),Vn).o),15),19),f.i),f.g),Yl(e).b&=-33}return e.c}function eke(e){var t;if(e.c!=10)throw ue(new ri(ai((Jr(),VG))));switch(t=e.a,t){case 110:t=10;break;case 114:t=13;break;case 116:t=9;break;case 92:case 124:case 46:case 94:case 45:case 63:case 42:case 43:case 123:case 125:case 40:case 41:case 91:case 93:break;default:throw ue(new ri(ai((Jr(),bf))))}return t}function Pbt(e){var t,n,r,a,o;if(e.l==0&&e.m==0&&e.h==0)return"0";if(e.h==SP&&e.m==0&&e.l==0)return"-9223372036854775808";if(e.h>>19)return"-"+Pbt(xE(e));for(n=e,r="";!(n.l==0&&n.m==0&&n.h==0);){if(a=Loe(JU),n=Nke(n,a,!0),t=""+rZe(Nb),!(n.l==0&&n.m==0&&n.h==0))for(o=9-t.length;o>0;o--)t="0"+t;r=t+r}return r}function ASn(e){var t,n,r,a,o,f,g;for(t=!1,n=0,a=new G(e.d.b);a.a=e.a||!Bxe(t,n))return-1;if(Zk(l(r.Kb(t),20)))return 1;for(a=0,f=l(r.Kb(t),20).Kc();f.Ob();)if(o=l(f.Pb(),18),w=o.c.i==t?o.d.i:o.c.i,g=tke(e,w,n,r),g==-1||(a=b.Math.max(a,g),a>e.c-1))return-1;return a+1}function Bbt(e,t){var n,r,a,o,f,g;if(qe(t)===qe(e))return!0;if(!De(t,15)||(r=l(t,15),g=e.gc(),r.gc()!=g))return!1;if(f=r.Kc(),e.Yi()){for(n=0;n0){if(e._j(),t!=null){for(o=0;o>24;case 97:case 98:case 99:case 100:case 101:case 102:return e-97+10<<24>>24;case 65:case 66:case 67:case 68:case 69:case 70:return e-65+10<<24>>24;default:throw ue(new gd("Invalid hexadecimal"))}}function PU(){PU=U,j_e=new L5("SPIRAL",0),P_e=new L5("LINE_BY_LINE",1),B_e=new L5("MANHATTAN",2),N_e=new L5("JITTER",3),z0e=new L5("QUADRANTS_LINE_BY_LINE",4),R_e=new L5("QUADRANTS_MANHATTAN",5),F_e=new L5("QUADRANTS_JITTER",6),O_e=new L5("COMBINE_LINE_BY_LINE_MANHATTAN",7),I_e=new L5("COMBINE_JITTER_MANHATTAN",8)}function Rbt(e,t,n,r){var a,o,f,g,w,E;for(w=Tue(e,n),E=Tue(t,n),a=!1;w&&E&&(r||C7n(w,E,n));)f=Tue(w,n),g=Tue(E,n),uN(t),uN(e),o=w.c,Cle(w,!1),Cle(E,!1),n?(Fy(t,E.p,o),t.p=E.p,Fy(e,w.p+1,o),e.p=w.p):(Fy(e,w.p,o),e.p=w.p,Fy(t,E.p+1,o),t.p=E.p),Va(w,null),Va(E,null),w=f,E=g,a=!0;return a}function jbt(e){switch(e.g){case 0:return new Gre;case 1:return new XS;case 3:return new fet;case 4:return new zee;case 5:return new zrt;case 6:return new jI;case 2:return new YS;case 7:return new az;case 8:return new RI;default:throw ue(new Yn("No implementation is available for the layerer "+(e.f!=null?e.f:""+e.g)))}}function NSn(e,t,n,r){var a,o,f,g,w;for(a=!1,o=!1,g=new G(r.j);g.a=t.length)throw ue(new tc("Greedy SwitchDecider: Free layer not in graph."));this.c=t[e],this.e=new IO(r),ice(this.e,this.c,(Ct(),er)),this.i=new IO(r),ice(this.i,this.c,ar),this.f=new ist(this.c),this.a=!o&&a.i&&!a.s&&this.c[0].k==(Zn(),Us),this.a&&W9n(this,e,t.length)}function zbt(e,t){var n,r,a,o,f,g;o=!e.B.Hc((Zl(),sF)),f=e.B.Hc(Gge),e.a=new _1t(f,o,e.c),e.n&&O5e(e.a.n,e.n),Xie(e.g,(t1(),$u),e.a),t||(r=new DA(1,o,e.c),r.n.a=e.k,Q8(e.p,(Ct(),Qn),r),a=new DA(1,o,e.c),a.n.d=e.k,Q8(e.p,Dr,a),g=new DA(0,o,e.c),g.n.c=e.k,Q8(e.p,er,g),n=new DA(0,o,e.c),n.n.b=e.k,Q8(e.p,ar,n))}function BSn(e){var t,n,r;switch(t=l(Q(e.d,(Nt(),bp)),223),t.g){case 2:n=TIn(e);break;case 3:n=(r=new bt,Is(Fi(fc(Dc(Dc(new bn(null,new kn(e.d.b,16)),new dee),new gee),new pee),new wS),new xYe(r)),r);break;default:throw ue(new nc("Compaction not supported for "+t+" edges."))}GLn(e,n),to(new br(e.g),new wYe(e))}function FSn(e,t){var n,r,a,o,f,g,w;if(t.Ug("Process directions",1),n=l(Q(e,(Hc(),y3)),88),n!=(Js(),Q1))for(a=Rr(e.b,0);a.b!=a.d.c;){switch(r=l(Br(a),40),g=l(Q(r,(Qi(),PB)),17).a,w=l(Q(r,BB),17).a,n.g){case 4:w*=-1;break;case 1:o=g,g=w,w=o;break;case 2:f=g,g=-w,w=f}rt(r,PB,pt(g)),rt(r,BB,pt(w))}t.Vg()}function RSn(e,t){var n;return n=new Bs,t&&pc(n,l(cr(e.a,oF),96)),De(t,422)&&pc(n,l(cr(e.a,cF),96)),De(t,366)?(pc(n,l(cr(e.a,ec),96)),n):(De(t,84)&&pc(n,l(cr(e.a,_r),96)),De(t,207)?(pc(n,l(cr(e.a,Ai),96)),n):De(t,193)?(pc(n,l(cr(e.a,Hl),96)),n):(De(t,326)&&pc(n,l(cr(e.a,js),96)),n))}function jSn(e){var t,n,r,a,o,f,g,w;for(w=new xut,g=new G(e.a);g.a0&&t=0)return!1;if(t.p=n.b,vt(n.e,t),a==(Zn(),Aa)||a==Au){for(f=new G(t.j);f.ae.d[g.p]&&(n+=f6e(e.b,o),gb(e.a,pt(o)))):++f;for(n+=e.b.d*f;!l_(e.a);)U6e(e.b,l(X8(e.a),17).a)}return n}function Qbt(e){var t,n,r,a,o,f;return o=0,t=Of(e),t.kk()&&(o|=4),e.Bb&Sl&&(o|=2),De(e,102)?(n=l(e,19),a=Ro(n),n.Bb&eu&&(o|=32),a&&(yr(ky(a)),o|=8,f=a.t,(f>1||f==-1)&&(o|=16),a.Bb&eu&&(o|=64)),n.Bb&Io&&(o|=r4),o|=m0):De(t,469)?o|=512:(r=t.kk(),r&&r.i&1&&(o|=256)),e.Bb&512&&(o|=128),o}function QSn(e,t){var n;return e.f==spe?(n=kw(ic((El(),io),t)),e.e?n==4&&t!=(kx(),u9)&&t!=(kx(),c9)&&t!=(kx(),ape)&&t!=(kx(),ope):n==2):e.d&&(e.d.Hc(t)||e.d.Hc(rx(ic((El(),io),t)))||e.d.Hc(g6((El(),io),e.b,t)))?!0:e.f&&q9e((El(),e.f),HO(ic(io,t)))?(n=kw(ic(io,t)),e.e?n==4:n==2):!1}function JSn(e){var t,n,r,a,o,f,g,w,E,C,L,B,z;for(B=-1,z=0,E=e,C=0,L=E.length;C0&&++z;++B}return z}function ZSn(e,t,n,r){var a,o,f,g,w,E,C,L;return f=l(at(n,(pi(),n9)),8),w=f.a,C=f.b+e,a=b.Math.atan2(C,w),a<0&&(a+=iv),a+=t,a>iv&&(a-=iv),g=l(at(r,n9),8),E=g.a,L=g.b+e,o=b.Math.atan2(L,E),o<0&&(o+=iv),o+=t,o>iv&&(o-=iv),A1(),f0(1e-10),b.Math.abs(a-o)<=1e-10||a==o||isNaN(a)&&isNaN(o)?0:ao?1:uw(isNaN(a),isNaN(o))}function nle(e){var t,n,r,a,o,f,g;for(g=new Pr,r=new G(e.a.b);r.a=e.o)throw ue(new Bwe);g=t>>5,f=t&31,o=l0(1,Yr(l0(f,1))),a?e.n[n][g]=Q0(e.n[n][g],o):e.n[n][g]=va(e.n[n][g],O4e(o)),o=l0(o,1),r?e.n[n][g]=Q0(e.n[n][g],o):e.n[n][g]=va(e.n[n][g],O4e(o))}catch(w){throw w=bs(w),De(w,333)?ue(new tc(Ehe+e.o+"*"+e.p+The+t+Co+n+Che)):ue(w)}}function n_n(e,t,n,r){var a,o,f,g,w,E,C,L,B;for(B=new Kp(new VYe(e)),g=he(le(wg,1),m2,10,0,[t,n]),w=0,E=g.length;w0&&(r=(!e.n&&(e.n=new nt(ec,e,1,7)),l(Oe(e.n,0),135)).a,!r||hi(hi((t.a+=' "',t),r),'"'))),hi(rw(hi(rw(hi(rw(hi(rw((t.a+=" (",t),e.i),","),e.j)," | "),e.g),","),e.f),")"),t.a)}function Jbt(e){var t,n,r;return e.Db&64?Pue(e):(t=new Th(uSe),n=e.k,n?hi(hi((t.a+=' "',t),n),'"'):(!e.n&&(e.n=new nt(ec,e,1,7)),e.n.i>0&&(r=(!e.n&&(e.n=new nt(ec,e,1,7)),l(Oe(e.n,0),135)).a,!r||hi(hi((t.a+=' "',t),r),'"'))),hi(rw(hi(rw(hi(rw(hi(rw((t.a+=" (",t),e.i),","),e.j)," | "),e.g),","),e.f),")"),t.a)}function s_n(e,t){var n,r,a,o,f;for(t==(yA(),Cde)&&JN(l($i(e.a,(Ry(),bB)),15)),a=l($i(e.a,(Ry(),bB)),15).Kc();a.Ob();)switch(r=l(a.Pb(),105),n=l(jt(r.j,0),113).d.j,o=new Ol(r.j),Vs(o,new Rj),t.g){case 2:Lue(e,o,n,(Ow(),Rb),1);break;case 1:case 0:f=UTn(o),Lue(e,new Zp(o,0,f),n,(Ow(),Rb),0),Lue(e,new Zp(o,f,o.c.length),n,Rb,1)}}function ile(e,t){var n,r,a,o,f,g,w;if(t==null||t.length==0)return null;if(a=l(xu(e.a,t),143),!a){for(r=(g=new gi(e.b).a.vc().Kc(),new fs(g));r.a.Ob();)if(n=(o=l(r.a.Pb(),44),l(o.md(),143)),f=n.c,w=t.length,vn(f.substr(f.length-w,w),t)&&(t.length==f.length||co(f,f.length-t.length-1)==46)){if(a)return null;a=n}a&&rc(e.a,t,a)}return a}function a_n(e,t){var n,r,a,o;return n=new as,r=l(yc(fc(new bn(null,new kn(e.f,16)),n),Sy(new yt,new ji,new qn,new Un,he(le(oc,1),it,108,0,[(Fl(),i4),Ec]))),21),a=r.gc(),r=l(yc(fc(new bn(null,new kn(t.f,16)),n),Sy(new yt,new ji,new qn,new Un,he(le(oc,1),it,108,0,[i4,Ec]))),21),o=r.gc(),aa.p?(la(o,Dr),o.d&&(g=o.o.b,t=o.a.b,o.a.b=g-t)):o.j==Dr&&a.p>e.p&&(la(o,Qn),o.d&&(g=o.o.b,t=o.a.b,o.a.b=-(g-t)));break}return a}function uP(e,t,n,r,a){var o,f,g,w,E,C,L;if(!(De(t,207)||De(t,366)||De(t,193)))throw ue(new Yn("Method only works for ElkNode-, ElkLabel and ElkPort-objects."));return f=e.a/2,w=t.i+r-f,C=t.j+a-f,E=w+t.g+e.a,L=C+t.f+e.a,o=new bl,ui(o,new lt(w,C)),ui(o,new lt(w,L)),ui(o,new lt(E,L)),ui(o,new lt(E,C)),g=new Gue(o),pc(g,t),n&&ki(e.b,t,g),g}function KE(e,t,n){var r,a,o,f,g,w,E,C,L,B;for(o=new lt(t,n),C=new G(e.a);C.a1,g&&(r=new lt(a,n.b),ui(t.a,r)),fA(t.a,he(le(Ea,1),dt,8,0,[B,L]))}function Nf(){Nf=U,AW=new ly(Id,0),AB=new ly("NIKOLOV",1),LB=new ly("NIKOLOV_PIXEL",2),xDe=new ly("NIKOLOV_IMPROVED",3),kDe=new ly("NIKOLOV_IMPROVED_PIXEL",4),yDe=new ly("DUMMYNODE_PERCENTAGE",5),EDe=new ly("NODECOUNT_PERCENTAGE",6),LW=new ly("NO_BOUNDARY",7),v3=new ly("MODEL_ORDER_LEFT_TO_RIGHT",8),x4=new ly("MODEL_ORDER_RIGHT_TO_LEFT",9)}function b_n(e){var t,n,r,a,o;for(r=e.length,t=new h_,o=0;o=40,f&&mAn(e),SLn(e),WCn(e),n=m1t(e),r=0;n&&r0&&ui(e.f,o)):(e.c[f]-=E+1,e.c[f]<=0&&e.a[f]>0&&ui(e.e,o))))}function hmt(e,t,n,r){var a,o,f,g,w,E,C;for(w=new lt(n,r),ma(w,l(Q(t,(Qi(),QT)),8)),C=Rr(t.b,0);C.b!=C.d.c;)E=l(Br(C),40),Oi(E.e,w),ui(e.b,E);for(g=l(yc(V5e(new bn(null,new kn(t.a,16))),Pl(new zr,new ht,new Fn,he(le(oc,1),it,108,0,[(Fl(),Ec)]))),15).Kc();g.Ob();){for(f=l(g.Pb(),65),o=Rr(f.a,0);o.b!=o.d.c;)a=l(Br(o),8),a.a+=w.a,a.b+=w.b;ui(e.a,f)}}function bke(e,t){var n,r,a,o;if(0<(De(e,16)?l(e,16).gc():Xg(e.Kc()))){if(a=t,1=0&&wo*2?(C=new hV(L),E=wl(f)/gh(f),w=Lle(C,t,new A8,n,r,a,E),Oi(Y0(C.e),w),L.c.length=0,o=0,$n(L.c,C),$n(L.c,f),o=wl(C)*gh(C)+wl(f)*gh(f)):($n(L.c,f),o+=wl(f)*gh(f));return L}function dmt(e,t){var n,r,a,o,f,g;if(g=l(Q(t,(Nt(),Ms)),101),g==(Ra(),Tg)||g==Mu)for(a=new lt(t.f.a+t.d.b+t.d.c,t.f.b+t.d.d+t.d.a).b,f=new G(e.a);f.an?t:n;E<=L;++E)E==n?g=r++:(o=a[E],C=V.am(o.Lk()),E==t&&(w=E==L&&!C?r-1:r),C&&++r);return B=l(AA(e,t,n),76),g!=w&&xk(e,new sN(e.e,7,f,pt(g),z.md(),w)),B}}else return l(Hue(e,t,n),76);return l(AA(e,t,n),76)}function B_n(e,t){var n,r,a,o,f,g,w;for(t.Ug("Port order processing",1),w=l(Q(e,(Nt(),ZMe)),430),r=new G(e.b);r.a=0&&(g=M7n(e,f),!(g&&(E<22?w.l|=1<>>1,f.m=C>>>1|(L&1)<<21,f.l=B>>>1|(C&1)<<21,--E;return n&&yce(w),o&&(r?(Nb=xE(e),a&&(Nb=Jft(Nb,(iE(),YSe)))):Nb=qu(e.l,e.m,e.h)),w}function j_n(e,t){var n,r,a,o,f,g,w,E,C,L;for(E=e.e[t.c.p][t.p]+1,w=t.c.a.c.length+1,g=new G(e.a);g.a0&&(Xn(0,e.length),e.charCodeAt(0)==45||(Xn(0,e.length),e.charCodeAt(0)==43))?1:0,r=f;rn)throw ue(new gd(Yw+e+'"'));return g}function $_n(e){var t,n,r,a,o,f,g;for(f=new os,o=new G(e.a);o.a1)&&t==1&&l(e.a[e.b],10).k==(Zn(),cu)?Tx(l(e.a[e.b],10),(Ih(),kg)):r&&(!n||(e.c-e.b&e.a.length-1)>1)&&t==1&&l(e.a[e.c-1&e.a.length-1],10).k==(Zn(),cu)?Tx(l(e.a[e.c-1&e.a.length-1],10),(Ih(),Gb)):(e.c-e.b&e.a.length-1)==2?(Tx(l(wA(e),10),(Ih(),kg)),Tx(l(wA(e),10),Gb)):pTn(e,a),l6e(e)}function H_n(e,t,n){var r,a,o,f,g;for(o=0,a=new or((!e.a&&(e.a=new nt(Ai,e,10,11)),e.a));a.e!=a.i.gc();)r=l(gr(a),27),f="",(!r.n&&(r.n=new nt(ec,r,1,7)),r.n).i==0||(f=l(Oe((!r.n&&(r.n=new nt(ec,r,1,7)),r.n),0),135).a),g=new xce(o++,t,f),pc(g,r),rt(g,(Qi(),gM),r),g.e.b=r.j+r.f/2,g.f.a=b.Math.max(r.g,1),g.e.a=r.i+r.g/2,g.f.b=b.Math.max(r.f,1),ui(t.b,g),ju(n.f,r,g)}function V_n(e){var t,n,r,a,o;r=l(Q(e,(ft(),zi)),27),o=l(at(r,(Nt(),bv)),181).Hc((mh(),Cv)),e.e||(a=l(Q(e,Lu),21),t=new lt(e.f.a+e.d.b+e.d.c,e.f.b+e.d.d+e.d.a),a.Hc((Ho(),vf))?(Hi(r,Ms,(Ra(),Mu)),Gw(r,t.a,t.b,!1,!0)):Rt(Bt(at(r,ade)))||Gw(r,t.a,t.b,!0,!0)),o?Hi(r,bv,un(Cv)):Hi(r,bv,(n=l(K0(BM),9),new Zh(n,l(c0(n,n.length),9),0)))}function mke(e,t,n){var r,a,o,f;if(t[0]>=e.length)return n.o=0,!0;switch(co(e,t[0])){case 43:a=1;break;case 45:a=-1;break;default:return n.o=0,!0}if(++t[0],o=t[0],f=kU(e,t),f==0&&t[0]==o)return!1;if(t[0]g&&(g=a,C.c.length=0),a==g&&vt(C,new ca(n.c.i,n)));Cn(),Vs(C,e.c),pw(e.b,w.p,C)}}function W_n(e,t){var n,r,a,o,f,g,w,E,C;for(f=new G(t.b);f.ag&&(g=a,C.c.length=0),a==g&&vt(C,new ca(n.d.i,n)));Cn(),Vs(C,e.c),pw(e.f,w.p,C)}}function Y_n(e,t){var n,r,a,o,f,g,w,E;if(E=Bt(Q(t,(Hc(),MTt))),E==null||(nr(E),E)){for(yEn(e,t),a=new bt,w=Rr(t.b,0);w.b!=w.d.c;)f=l(Br(w),40),n=i9e(e,f,null),n&&(pc(n,t),$n(a.c,n));if(e.a=null,e.b=null,a.c.length>1)for(r=new G(a);r.a=0&&g!=n&&(o=new _a(e,1,g,f,null),r?r.nj(o):r=o),n>=0&&(o=new _a(e,1,n,g==n?f:null,t),r?r.nj(o):r=o)),r}function bmt(e){var t,n,r;if(e.b==null){if(r=new Up,e.i!=null&&(Xo(r,e.i),r.a+=":"),e.f&256){for(e.f&256&&e.a!=null&&(dpn(e.i)||(r.a+="//"),Xo(r,e.a)),e.d!=null&&(r.a+="/",Xo(r,e.d)),e.f&16&&(r.a+="/"),t=0,n=e.j.length;tB?!1:(L=(w=ZA(r,B,!1),w.a),C+g+L<=t.b&&(aN(n,o-n.s),n.c=!0,aN(r,o-n.s),qN(r,n.s,n.t+n.d+g),r.k=!0,C7e(n.q,r),z=!0,a&&(bV(t,r),r.j=t,e.c.length>f&&(UN((Sn(f,e.c.length),l(e.c[f],186)),r),(Sn(f,e.c.length),l(e.c[f],186)).a.c.length==0&&t2(e,f)))),z)}function nAn(e,t){var n,r,a,o,f,g;if(t.Ug("Partition midprocessing",1),a=new Cw,Is(Fi(new bn(null,new kn(e.a,16)),new vj),new cYe(a)),a.d!=0){for(g=l(yc(K5e((o=a.i,new bn(null,(o||(a.i=new q5(a,a.c))).Nc()))),Pl(new zr,new ht,new Fn,he(le(oc,1),it,108,0,[(Fl(),Ec)]))),15),r=g.Kc(),n=l(r.Pb(),17);r.Ob();)f=l(r.Pb(),17),WTn(l($i(a,n),21),l($i(a,f),21)),n=f;t.Vg()}}function wmt(e,t,n){var r,a,o,f,g,w,E,C;if(t.p==0){for(t.p=1,f=n,f||(a=new bt,o=(r=l(K0(Oo),9),new Zh(r,l(c0(r,r.length),9),0)),f=new ca(a,o)),l(f.a,15).Fc(t),t.k==(Zn(),Us)&&l(f.b,21).Fc(l(Q(t,(ft(),Wc)),64)),w=new G(t.j);w.a0){if(a=l(e.Ab.g,2033),t==null){for(o=0;on.s&&gf)return Ct(),ar;break;case 4:case 3:if(C<0)return Ct(),Qn;if(C+n>o)return Ct(),Dr}return w=(E+g/2)/f,r=(C+n/2)/o,w+r<=1&&w-r<=0?(Ct(),er):w+r>=1&&w-r>=0?(Ct(),ar):r<.5?(Ct(),Qn):(Ct(),Dr)}function oAn(e,t){var n,r,a,o,f,g,w,E,C,L,B,z,V,J;for(n=!1,C=ze(Ge(Q(t,(Nt(),m3)))),V=Ab*C,a=new G(t.b);a.aw+V&&(J=L.g+B.g,B.a=(B.g*B.a+L.g*L.a)/J,B.g=J,L.f=B,n=!0)),o=g,L=B;return n}function Emt(e,t,n,r,a,o,f){var g,w,E,C,L,B;for(B=new $8,E=t.Kc();E.Ob();)for(g=l(E.Pb(),853),L=new G(g.Rf());L.a0?g.a?(E=g.b.Mf().b,a>E&&(e.v||g.c.d.c.length==1?(f=(a-E)/2,g.d.d=f,g.d.a=f):(n=l(jt(g.c.d,0),187).Mf().b,r=(n-E)/2,g.d.d=b.Math.max(0,r),g.d.a=a-r-E))):g.d.a=e.t+a:W_(e.u)&&(o=$xe(g.b),o.d<0&&(g.d.d=-o.d),o.d+o.a>g.b.Mf().b&&(g.d.a=o.d+o.a-g.b.Mf().b))}function b0(){b0=U,qx=new Ha((pi(),XB),pt(1)),kK=new Ha(Ev,80),n8t=new Ha(ANe,5),G7t=new Ha(Z6,lT),e8t=new Ha(zge,pt(1)),t8t=new Ha(qge,(Hn(),!0)),nAe=new lw(50),J7t=new Ha(_2,nAe),Z_e=WB,rAe=_M,K7t=new Ha(Dge,!1),tAe=YB,X7t=C4,Q7t=Ub,Y7t=kv,W7t=r7,Z7t=S4,eAe=(Xxe(),j7t),Z0e=H7t,xK=R7t,J0e=$7t,iAe=q7t,s8t=AM,a8t=aY,i8t=QB,r8t=sY,sAe=(dx(),L4),new Ha(i9,sAe)}function lAn(e,t){var n;switch(gN(e)){case 6:return Ia(t);case 7:return fy(t);case 8:return hy(t);case 3:return Array.isArray(t)&&(n=gN(t),!(n>=14&&n<=16));case 11:return t!=null&&typeof t===Ole;case 12:return t!=null&&(typeof t===wP||typeof t==Ole);case 0:return iue(t,e.__elementTypeId$);case 2:return Rae(t)&&t.Tm!==xe;case 1:return Rae(t)&&t.Tm!==xe||iue(t,e.__elementTypeId$);default:return!0}}function Tmt(e,t){var n,r,a,o;return r=b.Math.min(b.Math.abs(e.c-(t.c+t.b)),b.Math.abs(e.c+e.b-t.c)),o=b.Math.min(b.Math.abs(e.d-(t.d+t.a)),b.Math.abs(e.d+e.a-t.d)),n=b.Math.abs(e.c+e.b/2-(t.c+t.b/2)),n>e.b/2+t.b/2||(a=b.Math.abs(e.d+e.a/2-(t.d+t.a/2)),a>e.a/2+t.a/2)?1:n==0&&a==0?0:n==0?o/a+1:a==0?r/n+1:b.Math.min(r/n,o/a)+1}function hAn(e,t){var n,r,a,o,f,g,w;for(o=0,g=0,w=0,a=new G(e.f.e);a.a0&&e.d!=(lA(),n1e)&&(g+=f*(r.d.a+e.a[t.a][r.a]*(t.d.a-r.d.a)/n)),n>0&&e.d!=(lA(),e1e)&&(w+=f*(r.d.b+e.a[t.a][r.a]*(t.d.b-r.d.b)/n)));switch(e.d.g){case 1:return new lt(g/o,t.d.b);case 2:return new lt(t.d.a,w/o);default:return new lt(g/o,w/o)}}function Cmt(e){var t,n,r,a,o,f;for(n=(!e.a&&(e.a=new Ys(qh,e,5)),e.a).i+2,f=new Bu(n),vt(f,new lt(e.j,e.k)),Is(new bn(null,(!e.a&&(e.a=new Ys(qh,e,5)),new kn(e.a,16))),new NXe(f)),vt(f,new lt(e.b,e.c)),t=1;t0&&(SN(w,!1,(Js(),uc)),SN(w,!0,vc)),Vu(t.g,new jet(e,n)),ki(e.g,t,n)}function Amt(){Amt=U;var e;for(r_e=he(le(Vr,1),di,28,15,[-1,-1,30,19,15,13,11,11,10,9,9,8,8,8,8,7,7,7,7,7,7,7,6,6,6,6,6,6,6,6,6,6,6,6,6,6,5]),A0e=We(Vr,di,28,37,15,1),b6t=he(le(Vr,1),di,28,15,[-1,-1,63,40,32,28,25,23,21,20,19,19,18,18,17,17,16,16,16,15,15,15,15,14,14,14,14,14,14,13,13,13,13,13,13,13,13]),i_e=We(nm,ahe,28,37,14,1),e=2;e<=36;e++)A0e[e]=ua(b.Math.pow(e,r_e[e])),i_e[e]=KN(EP,A0e[e])}function fAn(e){var t;if((!e.a&&(e.a=new nt(cs,e,6,6)),e.a).i!=1)throw ue(new Yn(n4t+(!e.a&&(e.a=new nt(cs,e,6,6)),e.a).i));return t=new bl,TN(l(Oe((!e.b&&(e.b=new Ln(_r,e,4,7)),e.b),0),84))&&Ka(t,bwt(e,TN(l(Oe((!e.b&&(e.b=new Ln(_r,e,4,7)),e.b),0),84)),!1)),TN(l(Oe((!e.c&&(e.c=new Ln(_r,e,5,8)),e.c),0),84))&&Ka(t,bwt(e,TN(l(Oe((!e.c&&(e.c=new Ln(_r,e,5,8)),e.c),0),84)),!0)),t}function Lmt(e,t){var n,r,a,o,f;for(t.d?a=e.a.c==(xd(),w3)?ka(t.b):qs(t.b):a=e.a.c==(xd(),T2)?ka(t.b):qs(t.b),o=!1,r=new hr(dr(a.a.Kc(),new j));jr(r);)if(n=l(xr(r),18),f=Rt(e.a.f[e.a.g[t.b.p].p]),!(!f&&!Do(n)&&n.c.i.c==n.d.i.c)&&!(Rt(e.a.n[e.a.g[t.b.p].p])||Rt(e.a.n[e.a.g[t.b.p].p]))&&(o=!0,W0(e.b,e.a.g[f7n(n,t.b).p])))return t.c=!0,t.a=n,t;return t.c=o,t.a=null,t}function wke(e,t,n){var r,a,o,f,g,w,E;if(r=n.gc(),r==0)return!1;if(e.Pj())if(w=e.Qj(),A8e(e,t,n),f=r==1?e.Ij(3,null,n.Kc().Pb(),t,w):e.Ij(5,null,n,t,w),e.Mj()){for(g=r<100?null:new nb(r),o=t+r,a=t;a0){for(f=0;f>16==-15&&e.Cb.Yh()&&qoe(new Foe(e.Cb,9,13,n,e.c,f2(Xl(l(e.Cb,62)),e))):De(e.Cb,90)&&e.Db>>16==-23&&e.Cb.Yh()&&(t=e.c,De(t,90)||(t=(Tn(),Kf)),De(n,90)||(n=(Tn(),Kf)),qoe(new Foe(e.Cb,9,10,n,t,f2(du(l(e.Cb,29)),e)))))),e.c}function pAn(e,t,n){var r,a,o,f,g,w,E,C,L;for(n.Ug("Hyperedge merging",1),jEn(e,t),w=new Ua(t.b,0);w.b0,g=HV(t,o),Iye(n?g.b:g.g,t),Z5(g).c.length==1&&Cs(r,g,r.c.b,r.c),a=new ca(o,t),gb(e.o,a),al(e.e.a,o))}function Bmt(e,t){var n,r,a,o,f,g,w;return r=b.Math.abs(mH(e.b).a-mH(t.b).a),g=b.Math.abs(mH(e.b).b-mH(t.b).b),a=0,w=0,n=1,f=1,r>e.b.b/2+t.b.b/2&&(a=b.Math.min(b.Math.abs(e.b.c-(t.b.c+t.b.b)),b.Math.abs(e.b.c+e.b.b-t.b.c)),n=1-a/r),g>e.b.a/2+t.b.a/2&&(w=b.Math.min(b.Math.abs(e.b.d-(t.b.d+t.b.a)),b.Math.abs(e.b.d+e.b.a-t.b.d)),f=1-w/g),o=b.Math.min(n,f),(1-o)*b.Math.sqrt(r*r+g*g)}function vAn(e){var t,n,r,a;for(Ale(e,e.e,e.f,(Sw(),Hb),!0,e.c,e.i),Ale(e,e.e,e.f,Hb,!1,e.c,e.i),Ale(e,e.e,e.f,K6,!0,e.c,e.i),Ale(e,e.e,e.f,K6,!1,e.c,e.i),gAn(e,e.c,e.e,e.f,e.i),r=new Ua(e.i,0);r.b=65;n--)nd[n]=n-65<<24>>24;for(r=122;r>=97;r--)nd[r]=r-97+26<<24>>24;for(a=57;a>=48;a--)nd[a]=a-48+52<<24>>24;for(nd[43]=62,nd[47]=63,o=0;o<=25;o++)N2[o]=65+o&Zs;for(f=26,w=0;f<=51;++f,w++)N2[f]=97+w&Zs;for(e=52,g=0;e<=61;++e,g++)N2[e]=48+g&Zs;N2[62]=43,N2[63]=47}function Fmt(e,t){var n,r,a,o,f,g;return a=y7e(e),g=y7e(t),a==g?e.e==t.e&&e.a<54&&t.a<54?e.ft.f?1:0:(r=e.e-t.e,n=(e.d>0?e.d:b.Math.floor((e.a-1)*Vwt)+1)-(t.d>0?t.d:b.Math.floor((t.a-1)*Vwt)+1),n>r+1?a:n0&&(f=K5(f,Wmt(r))),K1t(o,f))):aE&&(B=0,z+=w+t,w=0),KE(f,B,z),n=b.Math.max(n,B+C.a),w=b.Math.max(w,C.b),B+=C.a+t;return new lt(n+t,z+w+t)}function Eke(e,t){var n,r,a,o,f,g,w;if(!M1(e))throw ue(new nc(t4t));if(r=M1(e),o=r.g,a=r.f,o<=0&&a<=0)return Ct(),Pc;switch(g=e.i,w=e.j,t.g){case 2:case 1:if(g<0)return Ct(),er;if(g+e.g>o)return Ct(),ar;break;case 4:case 3:if(w<0)return Ct(),Qn;if(w+e.f>a)return Ct(),Dr}return f=(g+e.g/2)/o,n=(w+e.f/2)/a,f+n<=1&&f-n<=0?(Ct(),er):f+n>=1&&f-n>=0?(Ct(),ar):n<.5?(Ct(),Qn):(Ct(),Dr)}function xAn(e,t,n,r,a){var o,f;if(o=bo(va(t[0],Vo),va(r[0],Vo)),e[0]=Yr(o),o=bw(o,32),n>=a){for(f=1;f0&&(a.b[f++]=0,a.b[f++]=o.b[0]-1),t=1;t0&&(H(w,w.d-a.d),a.c==(J0(),qb)&&N(w,w.a-a.d),w.d<=0&&w.i>0&&Cs(t,w,t.c.b,t.c)));for(o=new G(e.f);o.a0&&(q(g,g.i-a.d),a.c==(J0(),qb)&&$(g,g.b-a.d),g.i<=0&&g.d>0&&Cs(n,g,n.c.b,n.c)))}function TAn(e,t,n,r,a){var o,f,g,w,E,C,L,B,z;for(Cn(),Vs(e,new tk),f=PO(e),z=new bt,B=new bt,g=null,w=0;f.b!=0;)o=l(f.b==0?null:(mr(f.b!=0),af(f,f.a.a)),163),!g||wl(g)*gh(g)/21&&(w>wl(g)*gh(g)/2||f.b==0)&&(L=new hV(B),C=wl(g)/gh(g),E=Lle(L,t,new A8,n,r,a,C),Oi(Y0(L.e),E),g=L,$n(z.c,L),w=0,B.c.length=0));return ra(z,B),z}function pu(e,t,n,r,a){Vg();var o,f,g,w,E,C,L;if(d5e(e,"src"),d5e(n,"dest"),L=bh(e),w=bh(n),I4e((L.i&4)!=0,"srcType is not an array"),I4e((w.i&4)!=0,"destType is not an array"),C=L.c,f=w.c,I4e(C.i&1?C==f:(f.i&1)==0,"Array types don't match"),lyn(e,t,n,r,a),!(C.i&1)&&L!=w)if(E=jm(e),o=jm(n),qe(e)===qe(n)&&tr;)Ts(o,g,E[--t]);else for(g=r+a;r0),r.a.Xb(r.c=--r.b),L>B+w&&ph(r);for(f=new G(z);f.a0),r.a.Xb(r.c=--r.b)}}function SAn(){Di();var e,t,n,r,a,o;if(upe)return upe;for(e=new _h(4),Ky(e,_b(p0e,!0)),nL(e,_b("M",!0)),nL(e,_b("C",!0)),o=new _h(4),r=0;r<11;r++)Eu(o,r,r);return t=new _h(4),Ky(t,_b("M",!0)),Eu(t,4448,4607),Eu(t,65438,65439),a=new B_(2),Qm(a,e),Qm(a,WM),n=new B_(2),n.Jm(oH(o,_b("L",!0))),n.Jm(t),n=new Ty(3,n),n=new f5e(a,n),upe=n,upe}function Gy(e,t){var n,r,a,o,f,g,w,E;for(n=new RegExp(t,"g"),w=We(zt,dt,2,0,6,1),r=0,E=e,o=null;;)if(g=n.exec(E),g==null||E==""){w[r]=E;break}else f=g.index,w[r]=(Ga(0,f,E.length),E.substr(0,f)),E=tf(E,f+g[0].length,E.length),n.lastIndex=0,o==E&&(w[r]=(Ga(0,1,E.length),E.substr(0,1)),E=(Xn(1,E.length+1),E.substr(1))),o=E,++r;if(e.length>0){for(a=w.length;a>0&&w[a-1]=="";)--a;a0&&(L-=r[0]+e.c,r[0]+=e.c),r[2]>0&&(L-=r[2]+e.c),r[1]=b.Math.max(r[1],L),hH(e.a[1],n.c+t.b+r[0]-(r[1]-L)/2,r[1]);for(o=e.a,g=0,E=o.length;g0?(e.n.c.length-1)*e.i:0,r=new G(e.n);r.a1)for(r=Rr(a,0);r.b!=r.d.c;)for(n=l(Br(r),235),o=0,w=new G(n.e);w.a0&&(t[0]+=e.c,L-=t[0]),t[2]>0&&(L-=t[2]+e.c),t[1]=b.Math.max(t[1],L),fH(e.a[1],r.d+n.d+t[0]-(t[1]-L)/2,t[1]);else for(V=r.d+n.d,z=r.a-n.d-n.a,f=e.a,w=0,C=f.length;w0||Fw(a.b.d,e.b.d+e.b.a)==0&&r.b<0||Fw(a.b.d+a.b.a,e.b.d)==0&&r.b>0){g=0;break}}else g=b.Math.min(g,Bpt(e,a,r));g=b.Math.min(g,zmt(e,o,g,r))}return g}function dP(e,t){var n,r,a,o,f,g,w;if(e.b<2)throw ue(new Yn("The vector chain must contain at least a source and a target point."));for(a=(mr(e.b!=0),l(e.a.a.c,8)),kO(t,a.a,a.b),w=new q8((!t.a&&(t.a=new Ys(qh,t,5)),t.a)),f=Rr(e,1);f.a=0&&o!=n))throw ue(new Yn(WP));for(a=0,w=0;wze(L1(f.g,f.d[0]).a)?(mr(w.b>0),w.a.Xb(w.c=--w.b),by(w,f),a=!0):g.e&&g.e.gc()>0&&(o=(!g.e&&(g.e=new bt),g.e).Mc(t),E=(!g.e&&(g.e=new bt),g.e).Mc(n),(o||E)&&((!g.e&&(g.e=new bt),g.e).Fc(f),++f.c));a||$n(r.c,f)}function OAn(e,t,n){var r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe;return L=e.a.i+e.a.g/2,B=e.a.i+e.a.g/2,V=t.i+t.g/2,te=t.j+t.f/2,g=new lt(V,te),E=l(at(t,(pi(),n9)),8),E.a=E.a+L,E.b=E.b+B,o=(g.b-E.b)/(g.a-E.a),r=g.b-o*g.a,J=n.i+n.g/2,fe=n.j+n.f/2,w=new lt(J,fe),C=l(at(n,n9),8),C.a=C.a+L,C.b=C.b+B,f=(w.b-C.b)/(w.a-C.a),a=w.b-f*w.a,z=(r-a)/(f-o),E.a>>0,"0"+t.toString(16)),r="\\x"+tf(n,n.length-2,n.length)):e>=Io?(n=(t=e>>>0,"0"+t.toString(16)),r="\\v"+tf(n,n.length-6,n.length)):r=""+String.fromCharCode(e&Zs)}return r}function Umt(e){var t,n,r;if(P5(l(Q(e,(Nt(),Ms)),101)))for(n=new G(e.j);n.a=t.o&&n.f<=t.f||t.a*.5<=n.f&&t.a*1.5>=n.f){if(f=l(jt(t.n,t.n.c.length-1),209),f.e+f.d+n.g+a<=r&&(o=l(jt(t.n,t.n.c.length-1),209),o.f-e.f+n.f<=e.b||e.a.c.length==1))return y8e(t,n),!0;if(t.s+n.g<=r&&(t.t+t.d+n.f+a<=e.b||e.a.c.length==1))return vt(t.b,n),g=l(jt(t.n,t.n.c.length-1),209),vt(t.n,new PH(t.s,g.f+g.a+t.i,t.i)),exe(l(jt(t.n,t.n.c.length-1),209),n),jmt(t,n),!0}return!1}function Kmt(e,t,n){var r,a,o,f;return e.Pj()?(a=null,o=e.Qj(),r=e.Ij(1,f=Uoe(e,t,n),n,t,o),e.Mj()&&!(e.Yi()&&f!=null?Pi(f,n):qe(f)===qe(n))?(f!=null&&(a=e.Oj(f,a)),a=e.Nj(n,a),e.Tj()&&(a=e.Wj(f,n,a)),a?(a.nj(r),a.oj()):e.Jj(r)):(e.Tj()&&(a=e.Wj(f,n,a)),a?(a.nj(r),a.oj()):e.Jj(r)),f):(f=Uoe(e,t,n),e.Mj()&&!(e.Yi()&&f!=null?Pi(f,n):qe(f)===qe(n))&&(a=null,f!=null&&(a=e.Oj(f,null)),a=e.Nj(n,a),a&&a.oj()),f)}function $An(e,t){var n,r,a,o,f;if(t.Ug("Path-Like Graph Wrapping",1),e.b.c.length==0){t.Vg();return}if(a=new M9e(e),f=(a.i==null&&(a.i=x7e(a,new Gj)),ze(a.i)*a.f),n=f/(a.i==null&&(a.i=x7e(a,new Gj)),ze(a.i)),a.b>n){t.Vg();return}switch(l(Q(e,(Nt(),hde)),351).g){case 2:o=new Wj;break;case 0:o=new ES;break;default:o=new Yj}if(r=o.og(e,a),!o.pg())switch(l(Q(e,EW),352).g){case 2:r=Fpt(a,r);break;case 1:r=Agt(a,r)}BLn(e,a,r),t.Vg()}function XA(e,t){var n,r,a,o,f,g,w,E;t%=24,e.q.getHours()!=t&&(r=new b.Date(e.q.getTime()),r.setDate(r.getDate()+1),g=e.q.getTimezoneOffset()-r.getTimezoneOffset(),g>0&&(w=g/60|0,E=g%60,a=e.q.getDate(),n=e.q.getHours(),n+w>=24&&++a,o=new b.Date(e.q.getFullYear(),e.q.getMonth(),a,t+w,e.q.getMinutes()+E,e.q.getSeconds(),e.q.getMilliseconds()),e.q.setTime(o.getTime()))),f=e.q.getTime(),e.q.setTime(f+36e5),e.q.getHours()!=t&&e.q.setTime(f)}function zAn(e,t){var n,r,a,o;if(ebn(e.d,e.e),e.c.a.$b(),ze(Ge(Q(t.j,(Nt(),hW))))!=0||ze(Ge(Q(t.j,hW)))!=0)for(n=y6,qe(Q(t.j,yg))!==qe((Ed(),E2))&&rt(t.j,(ft(),jb),(Hn(),!0)),o=l(Q(t.j,nM),17).a,a=0;aa&&++E,vt(f,(Sn(g+E,t.c.length),l(t.c[g+E],17))),w+=(Sn(g+E,t.c.length),l(t.c[g+E],17)).a-r,++n;n=te&&e.e[w.p]>V*e.b||Me>=n*te)&&($n(B.c,g),g=new bt,Ka(f,o),o.a.$b(),E-=C,z=b.Math.max(z,E*e.b+J),E+=Me,Te=Me,Me=0,C=0,J=0);return new ca(z,B)}function dle(e){var t,n,r,a,o,f,g;if(!e.d){if(g=new Jne,t=qM,o=t.a.zc(e,t),o==null){for(r=new or(dc(e));r.e!=r.i.gc();)n=l(gr(r),29),As(g,dle(n));t.a.Bc(e)!=null,t.a.gc()==0}for(f=g.i,a=(!e.q&&(e.q=new nt(Uf,e,11,10)),new or(e.q));a.e!=a.i.gc();++f)l(gr(a),411);As(g,(!e.q&&(e.q=new nt(Uf,e,11,10)),e.q)),Iy(g),e.d=new N5((l(Oe(tt((lb(),Vn).o),9),19),g.i),g.g),e.e=l(g.g,688),e.e==null&&(e.e=X_t),Yl(e).b&=-17}return e.d}function XE(e,t,n,r){var a,o,f,g,w,E;if(E=Wu(e.e.Dh(),t),w=0,a=l(e.g,124),Fo(),l(t,69).xk()){for(f=0;f1||V==-1)if(L=l(J,71),B=l(C,71),L.dc())B.$b();else for(f=!!Ro(t),o=0,g=e.a?L.Kc():L.Ii();g.Ob();)E=l(g.Pb(),58),a=l(B1(e,E),58),a?(f?(w=B.dd(a),w==-1?B.Gi(o,a):o!=w&&B.Ui(o,a)):B.Gi(o,a),++o):e.b&&!f&&(B.Gi(o,E),++o);else J==null?C.Wb(null):(a=B1(e,J),a==null?e.b&&!Ro(t)&&C.Wb(J):C.Wb(a))}function GAn(e,t){var n,r,a,o,f,g,w,E;for(n=new gZ,a=new hr(dr(ka(t).a.Kc(),new j));jr(a);)if(r=l(xr(a),18),!Do(r)&&(g=r.c.i,Bxe(g,SK))){if(E=tke(e,g,SK,CK),E==-1)continue;n.b=b.Math.max(n.b,E),!n.a&&(n.a=new bt),vt(n.a,g)}for(f=new hr(dr(qs(t).a.Kc(),new j));jr(f);)if(o=l(xr(f),18),!Do(o)&&(w=o.d.i,Bxe(w,CK))){if(E=tke(e,w,CK,SK),E==-1)continue;n.d=b.Math.max(n.d,E),!n.c&&(n.c=new bt),vt(n.c,w)}return n}function KAn(e,t,n,r){var a,o,f,g,w,E,C;if(n.d.i!=t.i){for(a=new op(e),x(a,(Zn(),Aa)),rt(a,(ft(),zi),n),rt(a,(Nt(),Ms),(Ra(),Mu)),$n(r.c,a),f=new gu,Mc(f,a),la(f,(Ct(),er)),g=new gu,Mc(g,a),la(g,ar),C=n.d,Fa(n,f),o=new Tw,pc(o,n),rt(o,cc,null),po(o,g),Fa(o,C),E=new Ua(n.b,0);E.b1e6)throw ue(new qz("power of ten too big"));if(e<=Ii)return sx(iP($x[1],t),t);for(r=iP($x[1],Ii),a=r,n=Zc(e-Ii),t=ua(e%Ii);iu(n,Ii)>0;)a=K5(a,r),n=Df(n,Ii);for(a=K5(a,iP($x[1],t)),a=sx(a,Ii),n=Zc(e-Ii);iu(n,Ii)>0;)a=sx(a,Ii),n=Df(n,Ii);return a=sx(a,t),a}function Ymt(e){var t,n,r,a,o,f,g,w,E,C;for(w=new G(e.a);w.aE&&r>E)C=g,E=ze(t.p[g.p])+ze(t.d[g.p])+g.o.b+g.d.a;else{a=!1,n._g()&&n.bh("bk node placement breaks on "+g+" which should have been after "+C);break}if(!a)break}return n._g()&&n.bh(t+" is feasible: "+a),a}function _ke(e,t,n,r){var a,o,f,g,w,E,C,L,B;if(o=new op(e),x(o,(Zn(),Au)),rt(o,(Nt(),Ms),(Ra(),Mu)),a=0,t){for(f=new gu,rt(f,(ft(),zi),t),rt(o,zi,t.i),la(f,(Ct(),er)),Mc(f,o),B=kd(t.e),E=B,C=0,L=E.length;C0){if(a<0&&C.a&&(a=w,o=E[0],r=0),a>=0){if(g=C.b,w==a&&(g-=r++,g==0))return 0;if(!Zvt(t,E,C,g,f)){w=a-1,E[0]=o;continue}}else if(a=-1,!Zvt(t,E,C,0,f))return 0}else{if(a=-1,co(C.c,0)==32){if(L=E[0],eht(t,E),E[0]>L)continue}else if(Ppn(t,C.c,E[0])){E[0]+=C.c.length;continue}return 0}return FDn(f,n)?E[0]:0}function ZAn(e,t,n){var r,a,o,f,g,w,E,C,L,B;for(C=new gH(new Dz(n)),g=We(ih,pg,28,e.f.e.c.length,16,1),l5e(g,g.length),n[t.a]=0,E=new G(e.f.e);E.a=0&&!r6(e,C,L);)--L;a[C]=L}for(z=0;z=0&&!r6(e,g,V);)--g;o[V]=g}for(w=0;wt[B]&&Br[w]&&FU(e,w,B,!1,!0)}function Ake(e){var t,n,r,a,o,f,g,w;n=Rt(Bt(Q(e,(b0(),K7t)))),o=e.a.c.d,g=e.a.d.d,n?(f=md(ma(new lt(g.a,g.b),o),.5),w=md(Ja(e.e),.5),t=ma(Oi(new lt(o.a,o.b),f),w),Fye(e.d,t)):(a=ze(Ge(Q(e.a,n8t))),r=e.d,o.a>=g.a?o.b>=g.b?(r.a=g.a+(o.a-g.a)/2+a,r.b=g.b+(o.b-g.b)/2-a-e.e.b):(r.a=g.a+(o.a-g.a)/2+a,r.b=o.b+(g.b-o.b)/2+a):o.b>=g.b?(r.a=o.a+(g.a-o.a)/2+a,r.b=g.b+(o.b-g.b)/2+a):(r.a=o.a+(g.a-o.a)/2+a,r.b=o.b+(g.b-o.b)/2-a-e.e.b))}function JA(e){var t,n,r,a,o,f,g,w;if(!e.f){if(w=new _I,g=new _I,t=qM,f=t.a.zc(e,t),f==null){for(o=new or(dc(e));o.e!=o.i.gc();)a=l(gr(o),29),As(w,JA(a));t.a.Bc(e)!=null,t.a.gc()==0}for(r=(!e.s&&(e.s=new nt(dl,e,21,17)),new or(e.s));r.e!=r.i.gc();)n=l(gr(r),179),De(n,102)&&qr(g,l(n,19));Iy(g),e.r=new zit(e,(l(Oe(tt((lb(),Vn).o),6),19),g.i),g.g),As(w,e.r),Iy(w),e.f=new N5((l(Oe(tt(Vn.o),5),19),w.i),w.g),Yl(e).b&=-3}return e.f}function Qmt(e){sw(e,new Xm(nw(Zv(tw(ew(new x1,nv),"ELK DisCo"),"Layouter for arranging unconnected subgraphs. The subgraphs themselves are, by default, not laid out."),new z0))),gt(e,nv,_he,It(X_e)),gt(e,nv,Ahe,It(W0e)),gt(e,nv,Ox,It(I7t)),gt(e,nv,Xw,It(Y_e)),gt(e,nv,bEe,It(B7t)),gt(e,nv,mEe,It(P7t)),gt(e,nv,pEe,It(F7t)),gt(e,nv,vEe,It(N7t)),gt(e,nv,CEe,It(O7t)),gt(e,nv,SEe,It(K0e)),gt(e,nv,_Ee,It(W_e)),gt(e,nv,AEe,It(vK))}function zU(){zU=U,bPe=he(le(kf,1),Ad,28,15,[48,49,50,51,52,53,54,55,56,57,65,66,67,68,69,70]),S_t=new RegExp(`[ +\r\f]+`);try{jM=he(le(POn,1),Rn,2114,0,[new KI((iye(),KV("yyyy-MM-dd'T'HH:mm:ss'.'SSSZ",MO((zz(),zz(),NL))))),new KI(KV("yyyy-MM-dd'T'HH:mm:ss'.'SSS",MO(NL))),new KI(KV("yyyy-MM-dd'T'HH:mm:ss",MO(NL))),new KI(KV("yyyy-MM-dd'T'HH:mm",MO(NL))),new KI(KV("yyyy-MM-dd",MO(NL)))])}catch(e){if(e=bs(e),!De(e,82))throw ue(e)}}function tLn(e,t){var n,r,a,o;if(a=Jl(e.d,1)!=0,r=cke(e,t),r==0&&Rt(Bt(Q(t.j,(ft(),jb)))))return 0;!Rt(Bt(Q(t.j,(ft(),jb))))&&!Rt(Bt(Q(t.j,j6)))||qe(Q(t.j,(Nt(),yg)))===qe((Ed(),E2))?t.c.mg(t.e,a):a=Rt(Bt(Q(t.j,jb))),cP(e,t,a,!0),Rt(Bt(Q(t.j,j6)))&&rt(t.j,j6,(Hn(),!1)),Rt(Bt(Q(t.j,jb)))&&(rt(t.j,jb,(Hn(),!1)),rt(t.j,j6,!0)),n=cke(e,t);do{if(w7e(e),n==0)return 0;a=!a,o=n,cP(e,t,a,!1),n=cke(e,t)}while(o>n);return o}function Jmt(e,t){var n,r,a,o;if(a=Jl(e.d,1)!=0,r=xU(e,t),r==0&&Rt(Bt(Q(t.j,(ft(),jb)))))return 0;!Rt(Bt(Q(t.j,(ft(),jb))))&&!Rt(Bt(Q(t.j,j6)))||qe(Q(t.j,(Nt(),yg)))===qe((Ed(),E2))?t.c.mg(t.e,a):a=Rt(Bt(Q(t.j,jb))),cP(e,t,a,!0),Rt(Bt(Q(t.j,j6)))&&rt(t.j,j6,(Hn(),!1)),Rt(Bt(Q(t.j,jb)))&&(rt(t.j,jb,(Hn(),!1)),rt(t.j,j6,!0)),n=xU(e,t);do{if(w7e(e),n==0)return 0;a=!a,o=n,cP(e,t,a,!1),n=xU(e,t)}while(o>n);return o}function Lke(e,t,n,r){var a,o,f,g,w,E,C,L,B;return w=ma(new lt(n.a,n.b),e),E=w.a*t.b-w.b*t.a,C=t.a*r.b-t.b*r.a,L=(w.a*r.b-w.b*r.a)/C,B=E/C,C==0?E==0?(a=Oi(new lt(n.a,n.b),md(new lt(r.a,r.b),.5)),o=pb(e,a),f=pb(Oi(new lt(e.a,e.b),t),a),g=b.Math.sqrt(r.a*r.a+r.b*r.b)*.5,o=0&&L<=1&&B>=0&&B<=1?Oi(new lt(e.a,e.b),md(new lt(t.a,t.b),L)):null}function nLn(e,t,n){var r,a,o,f,g;if(r=l(Q(e,(Nt(),J1e)),21),n.a>t.a&&(r.Hc((Ym(),EM))?e.c.a+=(n.a-t.a)/2:r.Hc(TM)&&(e.c.a+=n.a-t.a)),n.b>t.b&&(r.Hc((Ym(),SM))?e.c.b+=(n.b-t.b)/2:r.Hc(CM)&&(e.c.b+=n.b-t.b)),l(Q(e,(ft(),Lu)),21).Hc((Ho(),vf))&&(n.a>t.a||n.b>t.b))for(g=new G(e.a);g.at.a&&(r.Hc((Ym(),EM))?e.c.a+=(n.a-t.a)/2:r.Hc(TM)&&(e.c.a+=n.a-t.a)),n.b>t.b&&(r.Hc((Ym(),SM))?e.c.b+=(n.b-t.b)/2:r.Hc(CM)&&(e.c.b+=n.b-t.b)),l(Q(e,(ft(),Lu)),21).Hc((Ho(),vf))&&(n.a>t.a||n.b>t.b))for(f=new G(e.a);f.a0?e.i:0)>t&&w>0&&(o=0,f+=w+e.i,a=b.Math.max(a,B),r+=w+e.i,w=0,B=0,n&&(++L,vt(e.n,new PH(e.s,f,e.i))),g=0),B+=E.g+(g>0?e.i:0),w=b.Math.max(w,E.f),n&&exe(l(jt(e.n,L),209),E),o+=E.g+(g>0?e.i:0),++g;return a=b.Math.max(a,B),r+=w,n&&(e.r=a,e.d=r,ixe(e.j)),new ef(e.s,e.t,a,r)}function gle(e){var t,n,r,a,o,f,g,w,E,C,L,B;for(e.b=!1,L=gs,w=ia,B=gs,E=ia,r=e.e.a.ec().Kc();r.Ob();)for(n=l(r.Pb(),272),a=n.a,L=b.Math.min(L,a.c),w=b.Math.max(w,a.c+a.b),B=b.Math.min(B,a.d),E=b.Math.max(E,a.d+a.a),f=new G(n.c);f.ae.o.a&&(C=(w-e.o.a)/2,g.b=b.Math.max(g.b,C),g.c=b.Math.max(g.c,C))}}function aLn(e){var t,n,r,a,o,f,g,w;for(o=new Kot,Fln(o,(hx(),dSt)),r=(a=ace(e,We(zt,dt,2,0,6,1)),new kr(new Il(new ase(e,a).b)));r.bg?1:-1:W7e(e.a,t.a,o),a==-1)L=-w,C=f==w?Doe(t.a,g,e.a,o):Ooe(t.a,g,e.a,o);else if(L=f,f==w){if(a==0)return Cd(),BL;C=Doe(e.a,o,t.a,g)}else C=Ooe(e.a,o,t.a,g);return E=new Im(L,C.length,C),iA(E),E}function oLn(e,t){var n,r,a,o;if(o=Pmt(t),!t.c&&(t.c=new nt(Hl,t,9,9)),Is(new bn(null,(!t.c&&(t.c=new nt(Hl,t,9,9)),new kn(t.c,16))),new $We(o)),a=l(Q(o,(ft(),Lu)),21),ZMn(t,a),a.Hc((Ho(),vf)))for(r=new or((!t.c&&(t.c=new nt(Hl,t,9,9)),t.c));r.e!=r.i.gc();)n=l(gr(r),123),ADn(e,t,o,n);return l(at(t,(Nt(),bv)),181).gc()!=0&&_bt(t,o),Rt(Bt(Q(o,XMe)))&&a.Fc(nW),ns(o,CB)&&NJe(new D8e(ze(Ge(Q(o,CB)))),o),qe(at(t,p4))===qe((rp(),A2))?JIn(e,t,o):BIn(e,t,o),o}function cLn(e){var t,n,r,a,o,f,g,w;for(a=new G(e.b);a.a0?tf(n.a,0,o-1):""):(Ga(0,o-1,e.length),e.substr(0,o-1)):n?n.a:e}function uLn(e,t){var n,r,a,o,f,g,w;for(t.Ug("Sort By Input Model "+Q(e,(Nt(),yg)),1),a=0,r=new G(e.b);r.a=e.b.length?(o[a++]=f.b[r++],o[a++]=f.b[r++]):r>=f.b.length?(o[a++]=e.b[n++],o[a++]=e.b[n++]):f.b[r]0?e.i:0)),++t;for(g8e(e.n,w),e.d=n,e.r=r,e.g=0,e.f=0,e.e=0,e.o=gs,e.p=gs,o=new G(e.b);o.a0&&(a=(!e.n&&(e.n=new nt(ec,e,1,7)),l(Oe(e.n,0),135)).a,!a||hi(hi((t.a+=' "',t),a),'"'))),n=(!e.b&&(e.b=new Ln(_r,e,4,7)),!(e.b.i<=1&&(!e.c&&(e.c=new Ln(_r,e,5,8)),e.c.i<=1))),n?t.a+=" [":t.a+=" ",hi(t,Eye(new Zie,new or(e.b))),n&&(t.a+="]"),t.a+=Phe,n&&(t.a+="["),hi(t,Eye(new Zie,new or(e.c))),n&&(t.a+="]"),t.a)}function hLn(e,t){var n,r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e,Ze,ot,St,cn,an,Bn;for(Ze=e.c,ot=t.c,n=gc(Ze.a,e,0),r=gc(ot.a,t,0),Me=l(Rw(e,(qo(),$l)).Kc().Pb(),12),an=l(Rw(e,zu).Kc().Pb(),12),$e=l(Rw(t,$l).Kc().Pb(),12),Bn=l(Rw(t,zu).Kc().Pb(),12),fe=kd(Me.e),St=kd(an.g),Te=kd($e.e),cn=kd(Bn.g),Fy(e,r,ot),f=Te,C=0,V=f.length;CC?new Pm((J0(),E4),n,t,E-C):E>0&&C>0&&(new Pm((J0(),E4),t,n,0),new Pm(E4,n,t,0))),f)}function gLn(e,t,n){var r,a,o;for(e.a=new bt,o=Rr(t.b,0);o.b!=o.d.c;){for(a=l(Br(o),40);l(Q(a,(Hc(),$d)),17).a>e.a.c.length-1;)vt(e.a,new ca(y6,hCe));r=l(Q(a,$d),17).a,n==(Js(),uc)||n==vc?(a.e.aze(Ge(l(jt(e.a,r),42).b))&&ct(l(jt(e.a,r),42),a.e.a+a.f.a)):(a.e.bze(Ge(l(jt(e.a,r),42).b))&&ct(l(jt(e.a,r),42),a.e.b+a.f.b))}}function tvt(e,t,n,r){var a,o,f,g,w,E,C;if(o=zV(r),g=Rt(Bt(Q(r,(Nt(),VMe)))),(g||Rt(Bt(Q(e,bW))))&&!P5(l(Q(e,Ms),101)))a=gx(o),w=vke(e,n,n==(qo(),zu)?a:BN(a));else switch(w=new gu,Mc(w,e),t?(C=w.n,C.a=t.a-e.n.a,C.b=t.b-e.n.b,opt(C,0,0,e.o.a,e.o.b),la(w,kmt(w,o))):(a=gx(o),la(w,n==(qo(),zu)?a:BN(a))),f=l(Q(r,(ft(),Lu)),21),E=w.j,o.g){case 2:case 1:(E==(Ct(),Qn)||E==Dr)&&f.Fc((Ho(),B6));break;case 4:case 3:(E==(Ct(),ar)||E==er)&&f.Fc((Ho(),B6))}return w}function nvt(e,t){var n,r,a,o,f,g;for(f=new qm(new Sr(e.f.b).a);f.b;){if(o=Nw(f),a=l(o.ld(),602),t==1){if(a.Af()!=(Js(),wf)&&a.Af()!=Q1)continue}else if(a.Af()!=(Js(),uc)&&a.Af()!=vc)continue;switch(r=l(l(o.md(),42).b,86),g=l(l(o.md(),42).a,194),n=g.c,a.Af().g){case 2:r.g.c=e.e.a,r.g.b=b.Math.max(1,r.g.b+n);break;case 1:r.g.c=r.g.c+n,r.g.b=b.Math.max(1,r.g.b-n);break;case 4:r.g.d=e.e.b,r.g.a=b.Math.max(1,r.g.a+n);break;case 3:r.g.d=r.g.d+n,r.g.a=b.Math.max(1,r.g.a-n)}}}function pLn(e,t){var n,r,a,o,f,g,w,E,C,L,B,z,V,J;for(g=We(Vr,di,28,t.b.c.length,15,1),E=We(l1e,it,273,t.b.c.length,0,1),w=We(wg,m2,10,t.b.c.length,0,1),L=e.a,B=0,z=L.length;B0&&w[r]&&(V=j5(e.b,w[r],a)),J=b.Math.max(J,a.c.c.b+V);for(o=new G(C.e);o.a1)throw ue(new Yn(ZP));w||(o=sg(t,r.Kc().Pb()),f.Fc(o))}return N7e(e,t9e(e,t,n),f)}function HU(e,t,n){var r,a,o,f,g,w,E,C;if(up(e.e,t))w=(Fo(),l(t,69).xk()?new nH(t,e):new yO(t,e)),EU(w.c,w.b),F_(w,l(n,16));else{for(C=Wu(e.e.Dh(),t),r=l(e.g,124),f=0;f"}w!=null&&(t.a+=""+w)}else e.e?(g=e.e.zb,g!=null&&(t.a+=""+g)):(t.a+="?",e.b?(t.a+=" super ",wle(e.b,t)):e.f&&(t.a+=" extends ",wle(e.f,t)))}function xLn(e){e.b=null,e.a=null,e.o=null,e.q=null,e.v=null,e.w=null,e.B=null,e.p=null,e.Q=null,e.R=null,e.S=null,e.T=null,e.U=null,e.V=null,e.W=null,e.bb=null,e.eb=null,e.ab=null,e.H=null,e.db=null,e.c=null,e.d=null,e.f=null,e.n=null,e.r=null,e.s=null,e.u=null,e.G=null,e.J=null,e.e=null,e.j=null,e.i=null,e.g=null,e.k=null,e.t=null,e.F=null,e.I=null,e.L=null,e.M=null,e.O=null,e.P=null,e.$=null,e.N=null,e.Z=null,e.cb=null,e.K=null,e.D=null,e.A=null,e.C=null,e._=null,e.fb=null,e.X=null,e.Y=null,e.gb=!1,e.hb=!1}function kLn(e){var t,n,r,a;if(r=Dle((!e.c&&(e.c=XO(Zc(e.f))),e.c),0),e.e==0||e.a==0&&e.f!=-1&&e.e<0)return r;if(t=y7e(e)<0?1:0,n=e.e,a=(r.length+1+b.Math.abs(ua(e.e)),new S5),t==1&&(a.a+="-"),e.e>0)if(n-=r.length-t,n>=0){for(a.a+="0.";n>lv.length;n-=lv.length)Qit(a,lv);Prt(a,lv,ua(n)),hi(a,(Xn(t,r.length+1),r.substr(t)))}else n=t-n,hi(a,tf(r,t,ua(n))),a.a+=".",hi(a,w5e(r,ua(n)));else{for(hi(a,(Xn(t,r.length+1),r.substr(t)));n<-lv.length;n+=lv.length)Qit(a,lv);Prt(a,lv,ua(-n))}return a.a}function yle(e){var t,n,r,a,o,f,g,w,E;return!(e.k!=(Zn(),Ps)||e.j.c.length<=1||(o=l(Q(e,(Nt(),Ms)),101),o==(Ra(),Mu))||(a=(By(),(e.q?e.q:(Cn(),Cn(),mg))._b(g3)?r=l(Q(e,g3),203):r=l(Q(eo(e),eM),203),r),a==_W)||!(a==G6||a==U6)&&(f=ze(Ge(Py(e,tM))),t=l(Q(e,_B),140),!t&&(t=new n4e(f,f,f,f)),E=Oc(e,(Ct(),er)),w=t.d+t.a+(E.gc()-1)*f,w>e.o.b||(n=Oc(e,ar),g=t.d+t.a+(n.gc()-1)*f,g>e.o.b)))}function ELn(e,t){var n,r,a,o,f,g,w,E,C,L,B,z,V,J,te;t.Ug("Orthogonal edge routing",1),E=ze(Ge(Q(e,(Nt(),V6)))),n=ze(Ge(Q(e,q6))),r=ze(Ge(Q(e,vv))),B=new Hae(0,n),te=0,f=new Ua(e.b,0),g=null,C=null,w=null,L=null;do C=f.b0?(z=(V-1)*n,g&&(z+=r),C&&(z+=r),zt||Rt(Bt(at(w,(z1(),$B)))))&&(a=0,o+=C.b+n,$n(L.c,C),C=new Q5e(o,n),r=new kce(0,C.f,C,n),bV(C,r),a=0),r.b.c.length==0||!Rt(Bt(at(ds(w),(z1(),hge))))&&(w.f>=r.o&&w.f<=r.f||r.a*.5<=w.f&&r.a*1.5>=w.f)?y8e(r,w):(f=new kce(r.s+r.r+n,C.f,C,n),bV(C,f),y8e(f,w)),a=w.i+w.g;return $n(L.c,C),L}function eL(e){var t,n,r,a;if(!(e.b==null||e.b.length<=2)&&!e.a){for(t=0,a=0;a=e.b[a+1])a+=2;else if(n0)for(r=new Ol(l($i(e.a,o),21)),Cn(),Vs(r,new GI(t)),a=new Ua(o.b,0);a.b0&&r>=-6?r>=0?EO(o,n-ua(e.e),String.fromCharCode(46)):(hce(o,t-1,t-1,"0."),EO(o,t+1,If(lv,0,-ua(r)-1))):(n-t>=1&&(EO(o,t,String.fromCharCode(46)),++n),EO(o,n,String.fromCharCode(69)),r>0&&EO(o,++n,String.fromCharCode(43)),EO(o,++n,""+Y_(Zc(r)))),e.g=o.a,e.g))}function OLn(e,t){var n,r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e,Ze,ot,St;r=ze(Ge(Q(t,(Nt(),KMe)))),Ze=l(Q(t,nM),17).a,B=4,a=3,ot=20/Ze,z=!1,w=0,f=Ii;do{for(o=w!=1,L=w!=0,St=0,te=e.a,Te=0,$e=te.length;Te<$e;++Te)V=te[Te],V.f=null,yDn(e,V,o,L,r),St+=b.Math.abs(V.a);do g=oAn(e,t);while(g);for(J=e.a,fe=0,Me=J.length;feZe)?(w=2,f=Ii):w==0?(w=1,f=St):(w=0,f=St)):(z=St>=f||f-St0?1:uw(isNaN(r),isNaN(0)))>=0^(f0(Nd),(b.Math.abs(g)<=Nd||g==0||isNaN(g)&&isNaN(0)?0:g<0?-1:g>0?1:uw(isNaN(g),isNaN(0)))>=0)?b.Math.max(g,r):(f0(Nd),(b.Math.abs(r)<=Nd||r==0||isNaN(r)&&isNaN(0)?0:r<0?-1:r>0?1:uw(isNaN(r),isNaN(0)))>0?b.Math.sqrt(g*g+r*r):-b.Math.sqrt(g*g+r*r))}function Qm(e,t){var n,r,a,o,f,g;if(t){if(!e.a&&(e.a=new jz),e.e==2){Rz(e.a,t);return}if(t.e==1){for(a=0;a=Io?Xo(n,w8e(r)):Uk(n,r&Zs),f=new coe(10,null,0),mgn(e.a,f,g-1)):(n=(f.Mm().length+o,new h_),Xo(n,f.Mm())),t.e==0?(r=t.Km(),r>=Io?Xo(n,w8e(r)):Uk(n,r&Zs)):Xo(n,t.Mm()),l(f,530).b=n.a}}function BLn(e,t,n){var r,a,o,f,g,w,E,C,L,B,z,V,J,te;if(!n.dc()){for(g=0,B=0,r=n.Kc(),V=l(r.Pb(),17).a;g1&&(w=E.Hg(w,e.a,g));return w.c.length==1?l(jt(w,w.c.length-1),238):w.c.length==2?CLn((Sn(0,w.c.length),l(w.c[0],238)),(Sn(1,w.c.length),l(w.c[1],238)),f,o):null}function $Ln(e,t,n){var r,a,o,f,g,w,E;for(n.Ug("Find roots",1),e.a.c.length=0,a=Rr(t.b,0);a.b!=a.d.c;)r=l(Br(a),40),r.b.b==0&&(rt(r,(Qi(),Vb),(Hn(),!0)),vt(e.a,r));switch(e.a.c.length){case 0:o=new xce(0,t,"DUMMY_ROOT"),rt(o,(Qi(),Vb),(Hn(),!0)),rt(o,Nde,!0),ui(t.b,o);break;case 1:break;default:for(f=new xce(0,t,DG),w=new G(e.a);w.a=b.Math.abs(r.b)?(r.b=0,o.d+o.a>f.d&&o.df.c&&o.c0){if(t=new eye(e.i,e.g),n=e.i,o=n<100?null:new nb(n),e.Tj())for(r=0;r0){for(g=e.g,E=e.i,uA(e),o=E<100?null:new nb(E),r=0;r>13|(e.m&15)<<9,a=e.m>>4&8191,o=e.m>>17|(e.h&255)<<5,f=(e.h&1048320)>>8,g=t.l&8191,w=t.l>>13|(t.m&15)<<9,E=t.m>>4&8191,C=t.m>>17|(t.h&255)<<5,L=(t.h&1048320)>>8,cn=n*g,an=r*g,Bn=a*g,jn=o*g,ur=f*g,w!=0&&(an+=n*w,Bn+=r*w,jn+=a*w,ur+=o*w),E!=0&&(Bn+=n*E,jn+=r*E,ur+=a*E),C!=0&&(jn+=n*C,ur+=r*C),L!=0&&(ur+=n*L),z=cn&eh,V=(an&511)<<13,B=z+V,te=cn>>22,fe=an>>9,Te=(Bn&262143)<<4,Me=(jn&31)<<17,J=te+fe+Te+Me,Ze=Bn>>18,ot=jn>>5,St=(ur&4095)<<8,$e=Ze+ot+St,J+=B>>22,B&=eh,$e+=J>>22,J&=eh,$e&=hp,qu(B,J,$e)}function dvt(e){var t,n,r,a,o,f,g;if(g=l(jt(e.j,0),12),g.g.c.length!=0&&g.e.c.length!=0)throw ue(new nc("Interactive layout does not support NORTH/SOUTH ports with incoming _and_ outgoing edges."));if(g.g.c.length!=0){for(o=gs,n=new G(g.g);n.a4)if(e.fk(t)){if(e.al()){if(a=l(t,54),r=a.Eh(),w=r==e.e&&(e.ml()?a.yh(a.Fh(),e.il())==e.jl():-1-a.Fh()==e.Lj()),e.nl()&&!w&&!r&&a.Jh()){for(o=0;o0&&gpt(e,g,L);for(a=new G(L);a.ae.d[f.p]&&(n+=f6e(e.b,o)*l(w.b,17).a,gb(e.a,pt(o)));for(;!l_(e.a);)U6e(e.b,l(X8(e.a),17).a)}return n}function ULn(e,t){var n,r,a,o,f,g,w,E,C,L;if(C=l(Q(e,(ft(),Wc)),64),r=l(jt(e.j,0),12),C==(Ct(),Qn)?la(r,Dr):C==Dr&&la(r,Qn),l(Q(t,(Nt(),bv)),181).Hc((mh(),Cv))){if(w=ze(Ge(Q(e,GT))),E=ze(Ge(Q(e,KT))),f=ze(Ge(Q(e,y4))),g=l(Q(t,v4),21),g.Hc((Rl(),vp)))for(n=E,L=e.o.a/2-r.n.a,o=new G(r.f);o.a0&&(E=e.n.a/o);break;case 2:case 4:a=e.i.o.b,a>0&&(E=e.n.b/a)}rt(e,(ft(),l3),E)}if(w=e.o,f=e.a,r)f.a=r.a,f.b=r.b,e.d=!0;else if(t!=Z1&&t!=Wb&&g!=Pc)switch(g.g){case 1:f.a=w.a/2;break;case 2:f.a=w.a,f.b=w.b/2;break;case 3:f.a=w.a/2,f.b=w.b;break;case 4:f.b=w.b/2}else f.a=w.a/2,f.b=w.b/2}function tL(e){var t,n,r,a,o,f,g,w,E,C;if(e.Pj())if(C=e.Ej(),w=e.Qj(),C>0)if(t=new T7e(e.pj()),n=C,o=n<100?null:new nb(n),AO(e,n,t.g),a=n==1?e.Ij(4,Oe(t,0),null,0,w):e.Ij(6,t,null,-1,w),e.Mj()){for(r=new or(t);r.e!=r.i.gc();)o=e.Oj(gr(r),o);o?(o.nj(a),o.oj()):e.Jj(a)}else o?(o.nj(a),o.oj()):e.Jj(a);else AO(e,e.Ej(),e.Fj()),e.Jj(e.Ij(6,(Cn(),_o),null,-1,w));else if(e.Mj())if(C=e.Ej(),C>0){for(g=e.Fj(),E=C,AO(e,C,g),o=E<100?null:new nb(E),r=0;r1&&wl(f)*gh(f)/2>g[0]){for(o=0;og[o];)++o;V=new Zp(J,0,o+1),L=new hV(V),C=wl(f)/gh(f),w=Lle(L,t,new A8,n,r,a,C),Oi(Y0(L.e),w),K8($E(B,L),aT),z=new Zp(J,o+1,J.c.length),cxe(B,z),J.c.length=0,E=0,gst(g,g.length,0)}else te=B.b.c.length==0?null:jt(B.b,0),te!=null&&rce(B,0),E>0&&(g[E]=g[E-1]),g[E]+=wl(f)*gh(f),++E,$n(J.c,f);return J}function QLn(e,t){var n,r,a,o;n=t.b,o=new Ol(n.j),a=0,r=n.j,r.c.length=0,mw(l(zm(e.b,(Ct(),Qn),(Ow(),o3)),15),n),a=zN(o,a,new Gv,r),mw(l(zm(e.b,Qn,Rb),15),n),a=zN(o,a,new bee,r),mw(l(zm(e.b,Qn,a3),15),n),mw(l(zm(e.b,ar,o3),15),n),mw(l(zm(e.b,ar,Rb),15),n),a=zN(o,a,new $j,r),mw(l(zm(e.b,ar,a3),15),n),mw(l(zm(e.b,Dr,o3),15),n),a=zN(o,a,new zj,r),mw(l(zm(e.b,Dr,Rb),15),n),a=zN(o,a,new qj,r),mw(l(zm(e.b,Dr,a3),15),n),mw(l(zm(e.b,er,o3),15),n),a=zN(o,a,new Bj,r),mw(l(zm(e.b,er,Rb),15),n),mw(l(zm(e.b,er,a3),15),n)}function JLn(e,t,n){var r,a,o,f,g,w,E,C,L,B,z;for(g=new G(t);g.a.5?fe-=f*2*(V-.5):V<.5&&(fe+=o*2*(.5-V)),a=g.d.b,fete.a-J-C&&(fe=te.a-J-C),g.n.a=t+fe}}function nMn(e){var t,n,r,a,o;if(r=l(Q(e,(Nt(),Qu)),171),r==(hf(),$b)){for(n=new hr(dr(ka(e).a.Kc(),new j));jr(n);)if(t=l(xr(n),18),!Aut(t))throw ue(new Vp(jhe+HN(e)+"' has its layer constraint set to FIRST_SEPARATE, but has at least one incoming edge. FIRST_SEPARATE nodes must not have incoming edges."))}else if(r==d4){for(o=new hr(dr(qs(e).a.Kc(),new j));jr(o);)if(a=l(xr(o),18),!Aut(a))throw ue(new Vp(jhe+HN(e)+"' has its layer constraint set to LAST_SEPARATE, but has at least one outgoing edge. LAST_SEPARATE nodes must not have outgoing edges."))}}function bP(e,t){var n,r,a,o,f,g,w,E,C,L,B,z,V;if(e.e&&e.c.c>19&&(t=xE(t),w=!w),f=$Tn(t),o=!1,a=!1,r=!1,e.h==SP&&e.m==0&&e.l==0)if(a=!0,o=!0,f==-1)e=ent((iE(),WSe)),r=!0,w=!w;else return g=D9e(e,f),w&&yce(g),n&&(Nb=qu(0,0,0)),g;else e.h>>19&&(o=!0,e=xE(e),r=!0,w=!w);return f!=-1?pyn(e,f,w,o,n):bxe(e,t)<0?(n&&(o?Nb=xE(e):Nb=qu(e.l,e.m,e.h)),qu(0,0,0)):R_n(r?e:qu(e.l,e.m,e.h),t,w,o,a,n)}function Tle(e,t){var n,r,a,o,f,g,w,E,C,L,B,z,V;if(f=e.e,w=t.e,f==0)return t;if(w==0)return e;if(o=e.d,g=t.d,o+g==2)return n=va(e.a[0],Vo),r=va(t.a[0],Vo),f==w?(C=bo(n,r),V=Yr(C),z=Yr(ub(C,32)),z==0?new Qg(f,V):new Im(f,2,he(le(Vr,1),di,28,15,[V,z]))):(Cd(),Aq(f<0?Df(r,n):Df(n,r),0)?kb(f<0?Df(r,n):Df(n,r)):J_(kb(r2(f<0?Df(r,n):Df(n,r)))));if(f==w)B=f,L=o>=g?Ooe(e.a,o,t.a,g):Ooe(t.a,g,e.a,o);else{if(a=o!=g?o>g?1:-1:W7e(e.a,t.a,o),a==0)return Cd(),BL;a==1?(B=f,L=Doe(e.a,o,t.a,g)):(B=w,L=Doe(t.a,g,e.a,o))}return E=new Im(B,L.length,L),iA(E),E}function iMn(e,t){var n,r,a,o,f,g,w;if(!(e.g>t.f||t.g>e.f)){for(n=0,r=0,f=e.w.a.ec().Kc();f.Ob();)a=l(f.Pb(),12),Ice(Ic(he(le(Ea,1),dt,8,0,[a.i.n,a.n,a.a])).b,t.g,t.f)&&++n;for(g=e.r.a.ec().Kc();g.Ob();)a=l(g.Pb(),12),Ice(Ic(he(le(Ea,1),dt,8,0,[a.i.n,a.n,a.a])).b,t.g,t.f)&&--n;for(w=t.w.a.ec().Kc();w.Ob();)a=l(w.Pb(),12),Ice(Ic(he(le(Ea,1),dt,8,0,[a.i.n,a.n,a.a])).b,e.g,e.f)&&++r;for(o=t.r.a.ec().Kc();o.Ob();)a=l(o.Pb(),12),Ice(Ic(he(le(Ea,1),dt,8,0,[a.i.n,a.n,a.a])).b,e.g,e.f)&&--r;n=0)return n;switch(kw(ic(e,n))){case 2:{if(vn("",o2(e,n.qk()).xe())){if(w=HO(ic(e,n)),g=Wk(ic(e,n)),C=P9e(e,t,w,g),C)return C;for(a=hke(e,t),f=0,L=a.gc();f1)throw ue(new Yn(ZP));for(C=Wu(e.e.Dh(),t),r=l(e.g,124),f=0;f1,E=new N1(B.b);Lc(E.a)||Lc(E.b);)w=l(Lc(E.a)?re(E.a):re(E.b),18),L=w.c==B?w.d:w.c,b.Math.abs(Ic(he(le(Ea,1),dt,8,0,[L.i.n,L.n,L.a])).b-f.b)>1&&UCn(e,w,f,o,B)}}function lMn(e){var t,n,r,a,o,f;if(a=new Ua(e.e,0),r=new Ua(e.a,0),e.d)for(n=0;nwfe;){for(o=t,f=0;b.Math.abs(t-o)0),a.a.Xb(a.c=--a.b),CAn(e,e.b-f,o,r,a),mr(a.b0),r.a.Xb(r.c=--r.b)}if(!e.d)for(n=0;n0?(e.f[C.p]=z/(C.e.c.length+C.g.c.length),e.c=b.Math.min(e.c,e.f[C.p]),e.b=b.Math.max(e.b,e.f[C.p])):g&&(e.f[C.p]=z)}}function fMn(e){e.b=null,e.bb=null,e.fb=null,e.qb=null,e.a=null,e.c=null,e.d=null,e.e=null,e.f=null,e.n=null,e.M=null,e.L=null,e.Q=null,e.R=null,e.K=null,e.db=null,e.eb=null,e.g=null,e.i=null,e.j=null,e.k=null,e.gb=null,e.o=null,e.p=null,e.q=null,e.r=null,e.$=null,e.ib=null,e.S=null,e.T=null,e.t=null,e.s=null,e.u=null,e.v=null,e.w=null,e.B=null,e.A=null,e.C=null,e.D=null,e.F=null,e.G=null,e.H=null,e.I=null,e.J=null,e.P=null,e.Z=null,e.U=null,e.V=null,e.W=null,e.X=null,e.Y=null,e._=null,e.ab=null,e.cb=null,e.hb=null,e.nb=null,e.lb=null,e.mb=null,e.ob=null,e.pb=null,e.jb=null,e.kb=null,e.N=!1,e.O=!1}function dMn(e,t,n){var r,a,o,f;for(n.Ug("Graph transformation ("+e.a+")",1),f=_w(t.a),o=new G(t.b);o.a=g.b.c)&&(g.b=t),(!g.c||t.c<=g.c.c)&&(g.d=g.c,g.c=t),(!g.e||t.d>=g.e.d)&&(g.e=t),(!g.f||t.d<=g.f.d)&&(g.f=t);return r=new nU((wE(),s3)),QO(e,M8t,new Il(he(le(fB,1),Rn,382,0,[r]))),f=new nU(o4),QO(e,L8t,new Il(he(le(fB,1),Rn,382,0,[f]))),a=new nU(a4),QO(e,A8t,new Il(he(le(fB,1),Rn,382,0,[a]))),o=new nU(M6),QO(e,_8t,new Il(he(le(fB,1),Rn,382,0,[o]))),Yue(r.c,s3),Yue(a.c,a4),Yue(o.c,M6),Yue(f.c,o4),g.a.c.length=0,ra(g.a,r.c),ra(g.a,lf(a.c)),ra(g.a,o.c),ra(g.a,lf(f.c)),g}function bMn(e,t){var n,r,a,o,f,g,w,E,C,L,B,z,V;for(t.Ug(Ayt,1),z=ze(Ge(at(e,(ug(),T4)))),f=ze(Ge(at(e,(z1(),wM)))),g=l(at(e,vM),107),v7e((!e.a&&(e.a=new nt(Ai,e,10,11)),e.a)),C=uvt((!e.a&&(e.a=new nt(Ai,e,10,11)),e.a),z,f),!e.a&&(e.a=new nt(Ai,e,10,11)),E=new G(C);E.a0&&(e.a=w+(z-1)*o,t.c.b+=e.a,t.f.b+=e.a)),V.a.gc()!=0&&(B=new Hae(1,o),z=Rke(B,t,V,J,t.f.b+w-t.c.b),z>0&&(t.f.b+=w+(z-1)*o))}function bvt(e,t,n){var r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e;for(C=ze(Ge(Q(e,(Nt(),b3)))),r=ze(Ge(Q(e,rDe))),B=new EI,rt(B,b3,C+r),E=t,fe=E.d,J=E.c.i,Te=E.d.i,te=oye(J.c),Me=oye(Te.c),a=new bt,L=te;L<=Me;L++)g=new op(e),x(g,(Zn(),Aa)),rt(g,(ft(),zi),E),rt(g,Ms,(Ra(),Mu)),rt(g,kW,B),z=l(jt(e.b,L),30),L==te?Fy(g,z.a.c.length-n,z):Va(g,z),$e=ze(Ge(Q(E,x2))),$e<0&&($e=0,rt(E,x2,$e)),g.o.b=$e,V=b.Math.floor($e/2),f=new gu,la(f,(Ct(),er)),Mc(f,g),f.n.b=V,w=new gu,la(w,ar),Mc(w,g),w.n.b=V,Fa(E,f),o=new Tw,pc(o,E),rt(o,cc,null),po(o,w),Fa(o,fe),s8n(g,E,o),$n(a.c,o),E=o;return a}function Cle(e,t){var n,r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me;for(w=l(d2(e,(Ct(),er)).Kc().Pb(),12).e,z=l(d2(e,ar).Kc().Pb(),12).g,g=w.c.length,Me=I1(l(jt(e.j,0),12));g-- >0;){for(J=(Sn(0,w.c.length),l(w.c[0],18)),a=(Sn(0,z.c.length),l(z.c[0],18)),Te=a.d.e,o=gc(Te,a,0),$bn(J,a.d,o),po(a,null),Fa(a,null),V=J.a,t&&ui(V,new Eo(Me)),r=Rr(a.a,0);r.b!=r.d.c;)n=l(Br(r),8),ui(V,new Eo(n));for(fe=J.b,B=new G(a.b);B.af)&&na(e.b,l(te.b,18));++g}o=f}}}function Pke(e,t){var n;if(t==null||vn(t,ul)||t.length==0&&e.k!=(g2(),t9))return null;switch(e.k.g){case 1:return QV(t,wT)?(Hn(),ST):QV(t,Ffe)?(Hn(),Pb):null;case 2:try{return pt(Oh(t,lo,Ii))}catch(r){if(r=bs(r),De(r,130))return null;throw ue(r)}case 4:try{return jy(t)}catch(r){if(r=bs(r),De(r,130))return null;throw ue(r)}case 3:return t;case 5:return F0t(e),Xpt(e,t);case 6:return F0t(e),mTn(e,e.a,t);case 7:try{return n=AEn(e),n.cg(t),n}catch(r){if(r=bs(r),De(r,33))return null;throw ue(r)}default:throw ue(new nc("Invalid type set for this layout option."))}}function Bke(e){var t;switch(e.d){case 1:{if(e.Sj())return e.o!=-2;break}case 2:{if(e.Sj())return e.o==-2;break}case 3:case 5:case 4:case 6:case 7:return e.o>-2;default:return!1}switch(t=e.Rj(),e.p){case 0:return t!=null&&Rt(Bt(t))!=I_(e.k,0);case 1:return t!=null&&l(t,222).a!=Yr(e.k)<<24>>24;case 2:return t!=null&&l(t,180).a!=(Yr(e.k)&Zs);case 6:return t!=null&&I_(l(t,168).a,e.k);case 5:return t!=null&&l(t,17).a!=Yr(e.k);case 7:return t!=null&&l(t,191).a!=Yr(e.k)<<16>>16;case 3:return t!=null&&ze(Ge(t))!=e.j;case 4:return t!=null&&l(t,161).a!=e.j;default:return t==null?e.n!=null:!Pi(t,e.n)}}function mP(e,t,n){var r,a,o,f;return e.ol()&&e.nl()&&(f=Fae(e,l(n,58)),qe(f)!==qe(n))?(e.xj(t),e.Dj(t,ylt(e,t,f)),e.al()&&(o=(a=l(n,54),e.ml()?e.kl()?a.Th(e.b,Ro(l(Mn(sl(e.b),e.Lj()),19)).n,l(Mn(sl(e.b),e.Lj()).Hk(),29).kk(),null):a.Th(e.b,ms(a.Dh(),Ro(l(Mn(sl(e.b),e.Lj()),19))),null,null):a.Th(e.b,-1-e.Lj(),null,null)),!l(f,54).Ph()&&(o=(r=l(f,54),e.ml()?e.kl()?r.Rh(e.b,Ro(l(Mn(sl(e.b),e.Lj()),19)).n,l(Mn(sl(e.b),e.Lj()).Hk(),29).kk(),o):r.Rh(e.b,ms(r.Dh(),Ro(l(Mn(sl(e.b),e.Lj()),19))),null,o):r.Rh(e.b,-1-e.Lj(),null,o))),o&&o.oj()),hh(e.b)&&e.Jj(e.Ij(9,n,f,t,!1)),f):n}function mvt(e){var t,n,r,a,o,f,g,w,E,C;for(r=new bt,f=new G(e.e.a);f.a0&&(f=b.Math.max(f,kft(e.C.b+r.d.b,a))),C=r,L=a,B=o;e.C&&e.C.c>0&&(z=B+e.C.c,E&&(z+=C.d.c),f=b.Math.max(f,(A1(),f0(H1),b.Math.abs(L-1)<=H1||L==1||isNaN(L)&&isNaN(1)?0:z/(1-L)))),n.n.b=0,n.a.a=f}function wvt(e,t){var n,r,a,o,f,g,w,E,C,L,B,z;if(n=l(Qo(e.b,t),127),w=l(l($i(e.r,t),21),87),w.dc()){n.n.d=0,n.n.a=0;return}for(E=e.u.Hc((Rl(),vp)),f=0,e.A.Hc((mh(),Cv))&&Wbt(e,t),g=w.Kc(),C=null,B=0,L=0;g.Ob();)r=l(g.Pb(),117),o=ze(Ge(r.b.of((zq(),pK)))),a=r.b.Mf().b,C?(z=L+C.d.a+e.w+r.d.d,f=b.Math.max(f,(A1(),f0(H1),b.Math.abs(B-o)<=H1||B==o||isNaN(B)&&isNaN(o)?0:z/(o-B)))):e.C&&e.C.d>0&&(f=b.Math.max(f,kft(e.C.d+r.d.d,o))),C=r,B=o,L=a;e.C&&e.C.a>0&&(z=L+e.C.a,E&&(z+=C.d.a),f=b.Math.max(f,(A1(),f0(H1),b.Math.abs(B-1)<=H1||B==1||isNaN(B)&&isNaN(1)?0:z/(1-B)))),n.n.d=0,n.a.b=f}function wMn(e,t,n,r,a,o,f,g){var w,E,C,L,B,z,V,J,te,fe;if(V=!1,E=H9e(n.q,t.f+t.b-n.q.f),z=r.f>t.b&&g,fe=a-(n.q.e+E-f),L=(w=ZA(r,fe,!1),w.a),z&&L>r.f)return!1;if(z){for(B=0,te=new G(t.d);te.a=(Sn(o,e.c.length),l(e.c[o],186)).e,!z&&L>t.b&&!C)?!1:((C||z||L<=t.b)&&(C&&L>t.b?(n.d=L,aN(n,spt(n,L))):(Egt(n.q,E),n.c=!0),aN(r,a-(n.s+n.r)),qN(r,n.q.e+n.q.d,t.f),bV(t,r),e.c.length>o&&(UN((Sn(o,e.c.length),l(e.c[o],186)),r),(Sn(o,e.c.length),l(e.c[o],186)).a.c.length==0&&t2(e,o)),V=!0),V)}function yvt(e,t,n){var r,a,o,f,g,w;for(this.g=e,g=t.d.length,w=n.d.length,this.d=We(wg,m2,10,g+w,0,1),f=0;f0?Xoe(this,this.f/this.a):L1(t.g,t.d[0]).a!=null&&L1(n.g,n.d[0]).a!=null?Xoe(this,(ze(L1(t.g,t.d[0]).a)+ze(L1(n.g,n.d[0]).a))/2):L1(t.g,t.d[0]).a!=null?Xoe(this,L1(t.g,t.d[0]).a):L1(n.g,n.d[0]).a!=null&&Xoe(this,L1(n.g,n.d[0]).a)}function yMn(e,t){var n,r,a,o,f,g,w,E,C,L;for(e.a=new Zst(nyn(LM)),r=new G(t.a);r.a=1&&(te-f>0&&L>=0?(w.n.a+=J,w.n.b+=o*f):te-f<0&&C>=0&&(w.n.a+=J*te,w.n.b+=o));e.o.a=t.a,e.o.b=t.b,rt(e,(Nt(),bv),(mh(),r=l(K0(BM),9),new Zh(r,l(c0(r,r.length),9),0)))}function EMn(e,t,n,r,a,o){var f;if(!(t==null||!Hce(t,TPe,CPe)))throw ue(new Yn("invalid scheme: "+t));if(!e&&!(n!=null&&pd(n,cl(35))==-1&&n.length>0&&(Xn(0,n.length),n.charCodeAt(0)!=47)))throw ue(new Yn("invalid opaquePart: "+n));if(e&&!(t!=null&&nO(EY,t.toLowerCase()))&&!(n==null||!Hce(n,$M,zM)))throw ue(new Yn(n5t+n));if(e&&t!=null&&nO(EY,t.toLowerCase())&&!nxn(n))throw ue(new Yn(n5t+n));if(!c5n(r))throw ue(new Yn("invalid device: "+r));if(!Gyn(a))throw f=a==null?"invalid segments: null":"invalid segment: "+qyn(a),ue(new Yn(f));if(!(o==null||pd(o,cl(35))==-1))throw ue(new Yn("invalid query: "+o))}function TMn(e,t,n){var r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe;if(n.Ug("Network simplex layering",1),e.b=t,fe=l(Q(t,(Nt(),nM)),17).a*4,te=e.b.a,te.c.length<1){n.Vg();return}for(o=k_n(e,te),J=null,a=Rr(o,0);a.b!=a.d.c;){for(r=l(Br(a),15),g=fe*ua(b.Math.sqrt(r.gc())),f=F_n(r),ole(n3e(Tun(r3e(bae(f),g),J),!0),n.eh(1)),B=e.b.b,V=new G(f.a);V.a1)for(J=We(Vr,di,28,e.b.b.c.length,15,1),L=0,E=new G(e.b.b);E.a0){JV(e,n,0),n.a+=String.fromCharCode(r),a=G5n(t,o),JV(e,n,a),o+=a-1;continue}r==39?o+10&&V.a<=0){w.c.length=0,$n(w.c,V);break}z=V.i-V.d,z>=g&&(z>g&&(w.c.length=0,g=z),$n(w.c,V))}w.c.length!=0&&(f=l(jt(w,aU(a,w.c.length)),118),Me.a.Bc(f)!=null,f.g=C++,Tke(f,t,n,r),w.c.length=0)}for(te=e.c.length+1,B=new G(e);B.aia||t.o==wv&&C=g&&a<=w)g<=a&&o<=w?(n[C++]=a,n[C++]=o,r+=2):g<=a?(n[C++]=a,n[C++]=w,e.b[r]=w+1,f+=2):o<=w?(n[C++]=g,n[C++]=o,r+=2):(n[C++]=g,n[C++]=w,e.b[r]=w+1);else if(wAb)&&g<10);s3e(e.c,new Y7),Tvt(e),wgn(e.c),gMn(e.f)}function OMn(e,t){var n,r,a,o,f,g,w,E,C,L,B,z,V,J;for(n=l(Q(e,(Nt(),Ms)),101),f=e.f,o=e.d,g=f.a+o.b+o.c,w=0-o.d-e.c.b,C=f.b+o.d+o.a-e.c.b,E=new bt,L=new bt,a=new G(t);a.a=2){for(w=Rr(n,0),f=l(Br(w),8),g=l(Br(w),8);g.a0&&SN(E,!0,(Js(),vc)),g.k==(Zn(),Us)&&cat(E),ki(e.f,g,t)}}function BMn(e){var t,n,r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e;for(a=l(Q(e,(Qi(),gM)),27),E=Ii,C=Ii,g=lo,w=lo,Me=Rr(e.b,0);Me.b!=Me.d.c;)fe=l(Br(Me),40),z=fe.e,V=fe.f,E=b.Math.min(E,z.a-V.a/2),C=b.Math.min(C,z.b-V.b/2),g=b.Math.max(g,z.a+V.a/2),w=b.Math.max(w,z.b+V.b/2);for(B=l(at(a,(Hc(),gIe)),107),Te=Rr(e.b,0);Te.b!=Te.d.c;)fe=l(Br(Te),40),L=Q(fe,gM),De(L,207)&&(o=l(L,27),Qh(o,fe.e.a,fe.e.b),aP(o,fe));for(te=Rr(e.a,0);te.b!=te.d.c;)J=l(Br(te),65),r=l(Q(J,gM),74),r&&(t=J.a,n=l6(r,!0,!0),dP(t,n));$e=g-E+(B.b+B.c),f=w-C+(B.d+B.a),Rt(Bt(at(a,(pi(),C4))))||Gw(a,$e,f,!1,!1),Hi(a,t7,$e-(B.b+B.c)),Hi(a,e7,f-(B.d+B.a))}function Svt(e,t){var n,r,a,o,f,g,w,E,C,L;for(w=!0,a=0,E=e.g[t.p],C=t.o.b+e.o,n=e.d[t.p][2],rf(e.b,E,pt(l(jt(e.b,E),17).a-1+n)),rf(e.c,E,ze(Ge(jt(e.c,E)))-C+n*e.f),++E,E>=e.j?(++e.j,vt(e.b,pt(1)),vt(e.c,C)):(r=e.d[t.p][1],rf(e.b,E,pt(l(jt(e.b,E),17).a+1-r)),rf(e.c,E,ze(Ge(jt(e.c,E)))+C-r*e.f)),(e.r==(Nf(),AB)&&(l(jt(e.b,E),17).a>e.k||l(jt(e.b,E-1),17).a>e.k)||e.r==LB&&(ze(Ge(jt(e.c,E)))>e.n||ze(Ge(jt(e.c,E-1)))>e.n))&&(w=!1),f=new hr(dr(ka(t).a.Kc(),new j));jr(f);)o=l(xr(f),18),g=o.c.i,e.g[g.p]==E&&(L=Svt(e,g),a=a+l(L.a,17).a,w=w&&Rt(Bt(L.b)));return e.g[t.p]=E,a=a+e.d[t.p][0],new ca(pt(a),(Hn(),!!w))}function _vt(e,t){var n,r,a,o,f;n=ze(Ge(Q(t,(Nt(),x0)))),n<2&&rt(t,x0,2),r=l(Q(t,Rh),88),r==(Js(),J1)&&rt(t,Rh,zV(t)),a=l(Q(t,Vkt),17),a.a==0?rt(t,(ft(),Xx),new Uce):rt(t,(ft(),Xx),new VH(a.a)),o=Bt(Q(t,ZL)),o==null&&rt(t,ZL,(Hn(),qe(Q(t,bp))===qe((ip(),iC)))),Is(new bn(null,new kn(t.a,16)),new qp(e)),Is(Dc(new bn(null,new kn(t.b,16)),new u5),new n_(e)),f=new xvt(t),rt(t,(ft(),$6),f),qO(e.a),X0(e.a,(uo(),y0),l(Q(t,dv),188)),X0(e.a,vg,l(Q(t,pv),188)),X0(e.a,bu,l(Q(t,JL),188)),X0(e.a,_u,l(Q(t,yW),188)),X0(e.a,mc,B3n(l(Q(t,bp),223))),uye(e.a,DIn(t)),rt(t,K1e,bP(e.a,t))}function Rke(e,t,n,r,a){var o,f,g,w,E,C,L,B,z,V,J,te,fe;for(L=new Pr,f=new bt,Spt(e,n,e.d.Ag(),f,L),Spt(e,r,e.d.Bg(),f,L),e.b=.2*(J=D2t(Dc(new bn(null,new kn(f,16)),new Tte)),te=D2t(Dc(new bn(null,new kn(f,16)),new Cte)),b.Math.min(J,te)),o=0,g=0;g=2&&(fe=X2t(f,!0,B),!e.e&&(e.e=new sXe(e)),q5n(e.e,fe,f,e.b)),Ogt(f,B),qMn(f),z=-1,C=new G(f);C.ag)}function Avt(e,t){var n,r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te;for(E=gs,C=gs,g=ia,w=ia,B=new G(t.i);B.a-1){for(a=Rr(g,0);a.b!=a.d.c;)r=l(Br(a),131),r.v=f;for(;g.b!=0;)for(r=l(kue(g,0),131),n=new G(r.i);n.a-1){for(o=new G(g);o.a0)&&(Y(w,b.Math.min(w.o,a.o-1)),q(w,w.i-1),w.i==0&&$n(g.c,w))}}function Mvt(e,t,n,r,a){var o,f,g,w;return w=gs,f=!1,g=Lke(e,ma(new lt(t.a,t.b),e),Oi(new lt(n.a,n.b),a),ma(new lt(r.a,r.b),n)),o=!!g&&!(b.Math.abs(g.a-e.a)<=Zw&&b.Math.abs(g.b-e.b)<=Zw||b.Math.abs(g.a-t.a)<=Zw&&b.Math.abs(g.b-t.b)<=Zw),g=Lke(e,ma(new lt(t.a,t.b),e),n,a),g&&((b.Math.abs(g.a-e.a)<=Zw&&b.Math.abs(g.b-e.b)<=Zw)==(b.Math.abs(g.a-t.a)<=Zw&&b.Math.abs(g.b-t.b)<=Zw)||o?w=b.Math.min(w,eA(ma(g,n))):f=!0),g=Lke(e,ma(new lt(t.a,t.b),e),r,a),g&&(f||(b.Math.abs(g.a-e.a)<=Zw&&b.Math.abs(g.b-e.b)<=Zw)==(b.Math.abs(g.a-t.a)<=Zw&&b.Math.abs(g.b-t.b)<=Zw)||o)&&(w=b.Math.min(w,eA(ma(g,r)))),w}function Dvt(e){sw(e,new Xm(Uz(nw(Zv(tw(ew(new x1,Mb),A3t),"Minimizes the stress within a layout using stress majorization. Stress exists if the euclidean distance between a pair of nodes doesn't match their graph theoretic distance, that is, the shortest path between the two nodes. The method allows to specify individual edge lengths."),new y1),Yu))),gt(e,Mb,hL,It(lAe)),gt(e,Mb,cG,(Hn(),!0)),gt(e,Mb,x6,It(d8t)),gt(e,Mb,Px,It(g8t)),gt(e,Mb,Nx,It(p8t)),gt(e,Mb,fT,It(f8t)),gt(e,Mb,fL,It(fAe)),gt(e,Mb,dT,It(b8t)),gt(e,Mb,PEe,It(uAe)),gt(e,Mb,FEe,It(oAe)),gt(e,Mb,REe,It(cAe)),gt(e,Mb,jEe,It(hAe)),gt(e,Mb,BEe,It(TK))}function HMn(e){var t,n,r,a,o,f,g,w;for(t=null,r=new G(e);r.a0&&n.c==0&&(!t&&(t=new bt),$n(t.c,n));if(t)for(;t.c.length!=0;){if(n=l(t2(t,0),239),n.b&&n.b.c.length>0){for(o=(!n.b&&(n.b=new bt),new G(n.b));o.agc(e,n,0))return new ca(a,n)}else if(ze(L1(a.g,a.d[0]).a)>ze(L1(n.g,n.d[0]).a))return new ca(a,n)}for(g=(!n.e&&(n.e=new bt),n.e).Kc();g.Ob();)f=l(g.Pb(),239),w=(!f.b&&(f.b=new bt),f.b),Ey(0,w.c.length),x_(w.c,0,n),f.c==w.c.length&&$n(t.c,f)}return null}function VMn(e,t){var n,r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe;for(t.Ug("Interactive crossing minimization",1),f=0,o=new G(e.b);o.a0&&(n+=w.n.a+w.o.a/2,++L),V=new G(w.j);V.a0&&(n/=L),fe=We(Na,Zo,28,r.a.c.length,15,1),g=0,E=new G(r.a);E.a=g&&a<=w)g<=a&&o<=w?r+=2:g<=a?(e.b[r]=w+1,f+=2):o<=w?(n[C++]=a,n[C++]=g-1,r+=2):(n[C++]=a,n[C++]=g-1,e.b[r]=w+1,f+=2);else if(w2?(C=new bt,ra(C,new Zp(fe,1,fe.b)),o=vwt(C,Me+e.a),Te=new Gue(o),pc(Te,t),$n(n.c,Te)):r?Te=l(cr(e.b,cg(t)),272):Te=l(cr(e.b,Eb(t)),272),w=cg(t),r&&(w=Eb(t)),f=H9n(te,w),E=Me+e.a,f.a?(E+=b.Math.abs(te.b-L.b),J=new lt(L.a,(L.b+te.b)/2)):(E+=b.Math.abs(te.a-L.a),J=new lt((L.a+te.a)/2,L.b)),r?ki(e.d,t,new nxe(Te,f,J,E)):ki(e.c,t,new nxe(Te,f,J,E)),ki(e.b,t,Te),V=(!t.n&&(t.n=new nt(ec,t,1,7)),t.n),z=new or(V);z.e!=z.i.gc();)B=l(gr(z),135),a=uP(e,B,!0,0,0),$n(n.c,a)}function UMn(e){var t,n,r,a,o,f,g;if(!e.A.dc()){if(e.A.Hc((mh(),iF))&&(l(Qo(e.b,(Ct(),Qn)),127).k=!0,l(Qo(e.b,Dr),127).k=!0,t=e.q!=(Ra(),Tg)&&e.q!=Mu,_z(l(Qo(e.b,ar),127),t),_z(l(Qo(e.b,er),127),t),_z(e.g,t),e.A.Hc(Cv)&&(l(Qo(e.b,Qn),127).j=!0,l(Qo(e.b,Dr),127).j=!0,l(Qo(e.b,ar),127).k=!0,l(Qo(e.b,er),127).k=!0,e.g.k=!0)),e.A.Hc(rF))for(e.a.j=!0,e.a.k=!0,e.g.j=!0,e.g.k=!0,g=e.B.Hc((Zl(),FM)),a=eue(),o=0,f=a.length;o0),l(C.a.Xb(C.c=--C.b),18));o!=r&&C.b>0;)e.a[o.p]=!0,e.a[r.p]=!0,o=(mr(C.b>0),l(C.a.Xb(C.c=--C.b),18));C.b>0&&ph(C)}}function Ovt(e,t,n){var r,a,o,f,g,w,E,C,L,B,z;if(!e.b)return!1;for(f=null,B=null,w=new Boe(null,null),a=1,w.a[1]=e.b,L=w;L.a[a];)E=a,g=B,B=L,L=L.a[a],r=e.a.Ne(t,L.d),a=r<0?0:1,r==0&&(!n.c||Jc(L.e,n.d))&&(f=L),!(L&&L.b)&&!oy(L.a[a])&&(oy(L.a[1-a])?B=B.a[E]=EV(L,a):oy(L.a[1-a])||(z=B.a[1-E],z&&(!oy(z.a[1-E])&&!oy(z.a[E])?(B.b=!1,z.b=!0,L.b=!0):(o=g.a[1]==B?1:0,oy(z.a[E])?g.a[o]=uct(B,E):oy(z.a[1-E])&&(g.a[o]=EV(B,E)),L.b=g.a[o].b=!0,g.a[o].a[0].b=!1,g.a[o].a[1].b=!1))));return f&&(n.b=!0,n.d=f.e,L!=f&&(C=new Boe(L.d,L.e),Wxn(e,w,f,C),B==f&&(B=C)),B.a[B.a[1]==L?1:0]=L.a[L.a[0]?0:1],--e.c),e.b=w.a[1],e.b&&(e.b.b=!1),n.b}function WMn(e){var t,n,r,a,o,f,g,w,E,C,L,B;for(a=new G(e.a.a.b);a.a0?a-=864e5:a+=864e5,w=new Kye(bo(Zc(t.q.getTime()),a))),C=new S5,E=e.a.length,o=0;o=97&&r<=122||r>=65&&r<=90){for(f=o+1;f=E)throw ue(new Yn("Missing trailing '"));f+1=14&&C<=16))?t.a._b(r)?(n.a?hi(n.a,n.b):n.a=new Th(n.d),N_(n.a,"[...]")):(g=jm(r),E=new U_(t),Jg(n,Pvt(g,E))):De(r,183)?Jg(n,Skn(l(r,183))):De(r,195)?Jg(n,hxn(l(r,195))):De(r,201)?Jg(n,x9n(l(r,201))):De(r,2111)?Jg(n,fxn(l(r,2111))):De(r,53)?Jg(n,Ckn(l(r,53))):De(r,376)?Jg(n,Hkn(l(r,376))):De(r,846)?Jg(n,Tkn(l(r,846))):De(r,109)&&Jg(n,Ekn(l(r,109))):Jg(n,r==null?ul:xc(r));return n.a?n.e.length==0?n.a.a:n.a.a+(""+n.e):n.c}function JE(e,t){var n,r,a,o;o=e.F,t==null?(e.F=null,CE(e,null)):(e.F=(nr(t),t),r=pd(t,cl(60)),r!=-1?(a=(Ga(0,r,t.length),t.substr(0,r)),pd(t,cl(46))==-1&&!vn(a,Cx)&&!vn(a,SL)&&!vn(a,GG)&&!vn(a,_L)&&!vn(a,AL)&&!vn(a,LL)&&!vn(a,ML)&&!vn(a,DL)&&(a=p5t),n=Rq(t,cl(62)),n!=-1&&(a+=""+(Xn(n+1,t.length+1),t.substr(n+1))),CE(e,a)):(a=t,pd(t,cl(46))==-1&&(r=pd(t,cl(91)),r!=-1&&(a=(Ga(0,r,t.length),t.substr(0,r))),!vn(a,Cx)&&!vn(a,SL)&&!vn(a,GG)&&!vn(a,_L)&&!vn(a,AL)&&!vn(a,LL)&&!vn(a,ML)&&!vn(a,DL)?(a=p5t,r!=-1&&(a+=""+(Xn(r,t.length+1),t.substr(r)))):a=t),CE(e,a),a==t&&(e.F=e.D))),e.Db&4&&!(e.Db&1)&&Ni(e,new _a(e,1,5,o,t))}function Bvt(e,t){var n,r,a,o,f,g,w,E,C,L;if(w=t.length-1,g=(Xn(w,t.length),t.charCodeAt(w)),g==93){if(f=pd(t,cl(91)),f>=0)return a=Z4n(e,(Ga(1,f,t.length),t.substr(1,f-1))),C=(Ga(f+1,w,t.length),t.substr(f+1,w-(f+1))),CIn(e,C,a)}else{if(n=-1,ZSe==null&&(ZSe=new RegExp("\\d")),ZSe.test(String.fromCharCode(g))&&(n=h4e(t,cl(46),w-1),n>=0)){r=l(Moe(e,Tht(e,(Ga(1,n,t.length),t.substr(1,n-1))),!1),61),E=0;try{E=Oh((Xn(n+1,t.length+1),t.substr(n+1)),lo,Ii)}catch(B){throw B=bs(B),De(B,130)?(o=B,ue(new nV(o))):ue(B)}if(E>16==-10?n=l(e.Cb,292).Yk(t,n):e.Db>>16==-15&&(!t&&(t=(Tn(),td)),!E&&(E=(Tn(),td)),e.Cb.Yh()&&(w=new Zg(e.Cb,1,13,E,t,f2(Xl(l(e.Cb,62)),e),!1),n?n.nj(w):n=w));else if(De(e.Cb,90))e.Db>>16==-23&&(De(t,90)||(t=(Tn(),Kf)),De(E,90)||(E=(Tn(),Kf)),e.Cb.Yh()&&(w=new Zg(e.Cb,1,10,E,t,f2(du(l(e.Cb,29)),e),!1),n?n.nj(w):n=w));else if(De(e.Cb,457))for(g=l(e.Cb,850),f=(!g.b&&(g.b=new Pz(new Vie)),g.b),o=(r=new qm(new Sr(f.a).a),new Bz(r));o.a.b;)a=l(Nw(o.a).ld(),89),n=ZE(a,SU(a,g),n)}return n}function ZMn(e,t){var n,r,a,o,f,g,w,E,C,L,B;for(f=Rt(Bt(at(e,(Nt(),b4)))),B=l(at(e,v4),21),w=!1,E=!1,L=new or((!e.c&&(e.c=new nt(Hl,e,9,9)),e.c));L.e!=L.i.gc()&&(!w||!E);){for(o=l(gr(L),123),g=0,a=rg(Lh(he(le(Fh,1),Rn,20,0,[(!o.d&&(o.d=new Ln(js,o,8,5)),o.d),(!o.e&&(o.e=new Ln(js,o,7,4)),o.e)])));jr(a)&&(r=l(xr(a),74),C=f&&qw(r)&&Rt(Bt(at(r,gv))),n=gvt((!r.b&&(r.b=new Ln(_r,r,4,7)),r.b),o)?e==ds(bc(l(Oe((!r.c&&(r.c=new Ln(_r,r,5,8)),r.c),0),84))):e==ds(bc(l(Oe((!r.b&&(r.b=new Ln(_r,r,4,7)),r.b),0),84))),!((C||n)&&(++g,g>1))););(g>0||B.Hc((Rl(),vp))&&(!o.n&&(o.n=new nt(ec,o,1,7)),o.n).i>0)&&(w=!0),g>1&&(E=!0)}w&&t.Fc((Ho(),vf)),E&&t.Fc((Ho(),UL))}function Fvt(e){var t,n,r,a,o,f,g,w,E,C,L,B;if(B=l(at(e,(pi(),kv)),21),B.dc())return null;if(g=0,f=0,B.Hc((mh(),iF))){for(C=l(at(e,_M),101),r=2,n=2,a=2,o=2,t=ds(e)?l(at(ds(e),xv),88):l(at(e,xv),88),E=new or((!e.c&&(e.c=new nt(Hl,e,9,9)),e.c));E.e!=E.i.gc();)if(w=l(gr(E),123),L=l(at(w,s7),64),L==(Ct(),Pc)&&(L=Eke(w,t),Hi(w,s7,L)),C==(Ra(),Mu))switch(L.g){case 1:r=b.Math.max(r,w.i+w.g);break;case 2:n=b.Math.max(n,w.j+w.f);break;case 3:a=b.Math.max(a,w.i+w.g);break;case 4:o=b.Math.max(o,w.j+w.f)}else switch(L.g){case 1:r+=w.g+2;break;case 2:n+=w.f+2;break;case 3:a+=w.g+2;break;case 4:o+=w.f+2}g=b.Math.max(r,a),f=b.Math.max(n,o)}return Gw(e,g,f,!0,!0)}function Sle(e,t,n,r,a){var o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e;for(Te=l(yc(lV(Fi(new bn(null,new kn(t.d,16)),new CYe(n)),new SYe(n)),Pl(new zr,new ht,new Fn,he(le(oc,1),it,108,0,[(Fl(),Ec)]))),15),L=Ii,C=lo,w=new G(t.b.j);w.a0,E?E&&(B=fe.p,f?++B:--B,L=l(jt(fe.c.a,B),10),r=o0t(L),z=!(Xue(r,ot,n[0])||Dst(r,ot,n[0]))):z=!0),V=!1,Ze=t.D.i,Ze&&Ze.c&&g.e&&(C=f&&Ze.p>0||!f&&Ze.p=0){for(w=null,g=new Ua(C.a,E+1);g.bf?1:uw(isNaN(0),isNaN(f)))<0&&(f0(Nd),(b.Math.abs(f-1)<=Nd||f==1||isNaN(f)&&isNaN(1)?0:f<1?-1:f>1?1:uw(isNaN(f),isNaN(1)))<0)&&(f0(Nd),(b.Math.abs(0-g)<=Nd||g==0||isNaN(0)&&isNaN(g)?0:0g?1:uw(isNaN(0),isNaN(g)))<0)&&(f0(Nd),(b.Math.abs(g-1)<=Nd||g==1||isNaN(g)&&isNaN(1)?0:g<1?-1:g>1?1:uw(isNaN(g),isNaN(1)))<0)),o)}function sDn(e){var t,n,r,a;if(n=e.D!=null?e.D:e.B,t=pd(n,cl(91)),t!=-1){r=(Ga(0,t,n.length),n.substr(0,t)),a=new Up;do a.a+="[";while((t=Nk(n,91,++t))!=-1);vn(r,Cx)?a.a+="Z":vn(r,SL)?a.a+="B":vn(r,GG)?a.a+="C":vn(r,_L)?a.a+="D":vn(r,AL)?a.a+="F":vn(r,LL)?a.a+="I":vn(r,ML)?a.a+="J":vn(r,DL)?a.a+="S":(a.a+="L",a.a+=""+r,a.a+=";");try{return null}catch(o){if(o=bs(o),!De(o,63))throw ue(o)}}else if(pd(n,cl(46))==-1){if(vn(n,Cx))return ih;if(vn(n,SL))return Al;if(vn(n,GG))return kf;if(vn(n,_L))return Na;if(vn(n,AL))return B4;if(vn(n,LL))return Vr;if(vn(n,ML))return nm;if(vn(n,DL))return h7}return null}function aDn(e,t){var n,r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e,Ze,ot,St;for(e.e=t,g=aEn(t),ot=new bt,r=new G(g);r.a=0&&J=E.c.c.length?C=u6e((Zn(),Ps),Aa):C=u6e((Zn(),Aa),Aa),C*=2,o=n.a.g,n.a.g=b.Math.max(o,o+(C-o)),f=n.b.g,n.b.g=b.Math.max(f,f+(C-f)),a=t}}function lDn(e){var t,n,r,a;for(Is(Fi(new bn(null,new kn(e.a.b,16)),new Oj),new aee),U8n(e),Is(Fi(new bn(null,new kn(e.a.b,16)),new oee),new cee),e.c==(ip(),s9)&&(Is(Fi(Dc(new bn(null,new kn(new br(e.f),1)),new uee),new lee),new vYe(e)),Is(Fi(fc(Dc(Dc(new bn(null,new kn(e.d.b,16)),new hee),new Nj),new fee),new Pj),new yYe(e))),a=new lt(gs,gs),t=new lt(ia,ia),r=new G(e.a.b);r.a0&&(t.a+=Co),GU(l(gr(g),167),t);for(t.a+=Phe,w=new q8((!r.c&&(r.c=new Ln(_r,r,5,8)),r.c));w.e!=w.i.gc();)w.e>0&&(t.a+=Co),GU(l(gr(w),167),t);t.a+=")"}}function hDn(e,t,n){var r,a,o,f,g,w,E,C;for(w=new or((!e.a&&(e.a=new nt(Ai,e,10,11)),e.a));w.e!=w.i.gc();)for(g=l(gr(w),27),a=new hr(dr(cp(g).a.Kc(),new j));jr(a);){if(r=l(xr(a),74),!r.b&&(r.b=new Ln(_r,r,4,7)),!(r.b.i<=1&&(!r.c&&(r.c=new Ln(_r,r,5,8)),r.c.i<=1)))throw ue(new I8("Graph must not contain hyperedges."));if(!qA(r)&&g!=bc(l(Oe((!r.c&&(r.c=new Ln(_r,r,5,8)),r.c),0),84)))for(E=new jrt,pc(E,r),rt(E,(bb(),Hx),r),Aie(E,l(hc(zo(n.f,g)),153)),k8(E,l(cr(n,bc(l(Oe((!r.c&&(r.c=new Ln(_r,r,5,8)),r.c),0),84))),153)),vt(t.c,E),f=new or((!r.n&&(r.n=new nt(ec,r,1,7)),r.n));f.e!=f.i.gc();)o=l(gr(f),135),C=new zct(E,o.a),pc(C,o),rt(C,Hx,o),C.e.a=b.Math.max(o.g,1),C.e.b=b.Math.max(o.f,1),Ake(C),vt(t.d,C)}}function fDn(e,t,n){var r,a,o,f,g,w,E,C,L,B;switch(n.Ug("Node promotion heuristic",1),e.i=t,e.r=l(Q(t,(Nt(),zb)),243),e.r!=(Nf(),v3)&&e.r!=x4?jDn(e):hSn(e),C=l(Q(e.i,HMe),17).a,o=new hd,e.r.g){case 2:case 1:QE(e,o);break;case 3:for(e.r=LW,QE(e,o),w=0,g=new G(e.b);g.ae.k&&(e.r=AB,QE(e,o));break;case 4:for(e.r=LW,QE(e,o),E=0,a=new G(e.c);a.ae.n&&(e.r=LB,QE(e,o));break;case 6:B=ua(b.Math.ceil(e.g.length*C/100)),QE(e,new aYe(B));break;case 5:L=ua(b.Math.ceil(e.e*C/100)),QE(e,new oYe(L));break;case 8:xwt(e,!0);break;case 9:xwt(e,!1);break;default:QE(e,o)}e.r!=v3&&e.r!=x4?PCn(e,t):t_n(e,t),n.Vg()}function dDn(e){var t,n,r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me;for(L=e.b,C=new Ua(L,0),by(C,new yu(e)),Te=!1,f=1;C.b0&&(B.d+=C.n.d,B.d+=C.d),B.a>0&&(B.a+=C.n.a,B.a+=C.d),B.b>0&&(B.b+=C.n.b,B.b+=C.d),B.c>0&&(B.c+=C.n.c,B.c+=C.d),B}function jvt(e,t,n){var r,a,o,f,g,w,E,C,L,B,z,V;for(B=n.d,L=n.c,o=new lt(n.f.a+n.d.b+n.d.c,n.f.b+n.d.d+n.d.a),f=o.b,E=new G(e.a);E.a0&&(e.c[t.c.p][t.p].d+=Jl(e.i,24)*MP*.07000000029802322-.03500000014901161,e.c[t.c.p][t.p].a=e.c[t.c.p][t.p].d/e.c[t.c.p][t.p].b)}}function bDn(e){var t,n,r,a,o,f,g,w,E,C,L,B,z,V,J,te;for(V=new G(e);V.ar.d,r.d=b.Math.max(r.d,t),g&&n&&(r.d=b.Math.max(r.d,r.a),r.a=r.d+a);break;case 3:n=t>r.a,r.a=b.Math.max(r.a,t),g&&n&&(r.a=b.Math.max(r.a,r.d),r.d=r.a+a);break;case 2:n=t>r.c,r.c=b.Math.max(r.c,t),g&&n&&(r.c=b.Math.max(r.b,r.c),r.b=r.c+a);break;case 4:n=t>r.b,r.b=b.Math.max(r.b,t),g&&n&&(r.b=b.Math.max(r.b,r.c),r.c=r.b+a)}}}function zvt(e,t){var n,r,a,o,f,g,w,E,C;return E="",t.length==0?e.ne(iEe,Rle,-1,-1):(C=$y(t),vn(C.substr(0,3),"at ")&&(C=(Xn(3,C.length+1),C.substr(3))),C=C.replace(/\[.*?\]/g,""),f=C.indexOf("("),f==-1?(f=C.indexOf("@"),f==-1?(E=C,C=""):(E=$y((Xn(f+1,C.length+1),C.substr(f+1))),C=$y((Ga(0,f,C.length),C.substr(0,f))))):(n=C.indexOf(")",f),E=(Ga(f+1,n,C.length),C.substr(f+1,n-(f+1))),C=$y((Ga(0,f,C.length),C.substr(0,f)))),f=pd(C,cl(46)),f!=-1&&(C=(Xn(f+1,C.length+1),C.substr(f+1))),(C.length==0||vn(C,"Anonymous function"))&&(C=Rle),g=Rq(E,cl(58)),a=h4e(E,cl(58),g-1),w=-1,r=-1,o=iEe,g!=-1&&a!=-1&&(o=(Ga(0,a,E.length),E.substr(0,a)),w=irt((Ga(a+1,g,E.length),E.substr(a+1,g-(a+1)))),r=irt((Xn(g+1,E.length+1),E.substr(g+1)))),e.ne(o,C,w,r))}function wDn(e){var t,n,r,a,o,f,g,w,E,C,L;for(E=new G(e);E.a0||C.j==er&&C.e.c.length-C.g.c.length<0)){t=!1;break}for(a=new G(C.g);a.a=E&&Ze>=te&&(B+=V.n.b+J.n.b+J.a.b-$e,++g));if(n)for(f=new G(Te.e);f.a=E&&Ze>=te&&(B+=V.n.b+J.n.b+J.a.b-$e,++g))}g>0&&(ot+=B/g,++z)}z>0?(t.a=a*ot/z,t.g=z):(t.a=0,t.g=0)}function xDn(e){var t,n,r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e,Ze,ot,St;for(o=e.f.b,B=o.a,C=o.b,V=e.e.g,z=e.e.f,F5(e.e,o.a,o.b),ot=B/V,St=C/z,E=new or(EH(e.e));E.e!=E.i.gc();)w=l(gr(E),135),Uu(w,w.i*ot),Gu(w,w.j*St);for(Te=new or(Xae(e.e));Te.e!=Te.i.gc();)fe=l(gr(Te),123),$e=fe.i,Ze=fe.j,$e>0&&Uu(fe,$e*ot),Ze>0&&Gu(fe,Ze*St);for(mA(e.b,new zg),t=new bt,g=new qm(new Sr(e.c).a);g.b;)f=Nw(g),r=l(f.ld(),74),n=l(f.md(),407).a,a=l6(r,!1,!1),L=Ngt(cg(r),QN(a),n),dP(L,a),Me=Kgt(r),Me&&gc(t,Me,0)==-1&&($n(t.c,Me),kat(Me,(mr(L.b!=0),l(L.a.a.c,8)),n));for(te=new qm(new Sr(e.d).a);te.b;)J=Nw(te),r=l(J.ld(),74),n=l(J.md(),407).a,a=l6(r,!1,!1),L=Ngt(Eb(r),AN(QN(a)),n),L=AN(L),dP(L,a),Me=Wgt(r),Me&&gc(t,Me,0)==-1&&($n(t.c,Me),kat(Me,(mr(L.b!=0),l(L.c.b.c,8)),n))}function qvt(e,t,n,r){var a,o,f,g,w;return g=new zke(t),fCn(g,r),a=!0,e&&e.pf((pi(),xv))&&(o=l(e.of((pi(),xv)),88),a=o==(Js(),J1)||o==uc||o==vc),zbt(g,!1),Vu(g.e.Rf(),new v4e(g,!1,a)),uoe(g,g.f,(t1(),Gc),(Ct(),Qn)),uoe(g,g.f,Kc,Dr),uoe(g,g.g,Gc,er),uoe(g,g.g,Kc,ar),bdt(g,Qn),bdt(g,Dr),wat(g,ar),wat(g,er),py(),f=g.A.Hc((mh(),A4))&&g.B.Hc((Zl(),aF))?N1t(g):null,f&&xun(g.a,f),vDn(g),w7n(g),y7n(g),UMn(g),w_n(g),G7n(g),Jce(g,Qn),Jce(g,Dr),XSn(g),wLn(g),n&&(e5n(g),K7n(g),Jce(g,ar),Jce(g,er),w=g.B.Hc((Zl(),FM)),Opt(g,w,Qn),Opt(g,w,Dr),Npt(g,w,ar),Npt(g,w,er),Is(new bn(null,new kn(new gi(g.i),0)),new Fc),Is(Fi(new bn(null,b5e(g.r).a.oc()),new xa),new Ba),oxn(g),g.e.Pf(g.o),Is(new bn(null,b5e(g.r).a.oc()),new ga)),g.o}function kDn(e){var t,n,r,a,o,f,g,w,E,C,L,B,z,V,J;for(E=gs,r=new G(e.a.b);r.a1)for(z=new Ike(V,Me,r),to(Me,new Jet(e,z)),$n(f.c,z),L=Me.a.ec().Kc();L.Ob();)C=l(L.Pb(),42),al(o,C.b);if(g.a.gc()>1)for(z=new Ike(V,g,r),to(g,new Zet(e,z)),$n(f.c,z),L=g.a.ec().Kc();L.Ob();)C=l(L.Pb(),42),al(o,C.b)}}function SDn(e,t,n){var r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe;if(J=e.n,te=e.o,B=e.d,L=ze(Ge(Py(e,(Nt(),ode)))),t){for(C=L*(t.gc()-1),z=0,w=t.Kc();w.Ob();)f=l(w.Pb(),10),C+=f.o.a,z=b.Math.max(z,f.o.b);for(fe=J.a-(C-te.a)/2,o=J.b-B.d+z,r=te.a/(t.gc()+1),a=r,g=t.Kc();g.Ob();)f=l(g.Pb(),10),f.n.a=fe,f.n.b=o-f.o.b,fe+=f.o.a+L,E=Q2t(f),E.n.a=f.o.a/2-E.a.a,E.n.b=f.o.b,V=l(Q(f,(ft(),rW)),12),V.e.c.length+V.g.c.length==1&&(V.n.a=a-V.a.a,V.n.b=0,Mc(V,e)),a+=r}if(n){for(C=L*(n.gc()-1),z=0,w=n.Kc();w.Ob();)f=l(w.Pb(),10),C+=f.o.a,z=b.Math.max(z,f.o.b);for(fe=J.a-(C-te.a)/2,o=J.b+te.b+B.a-z,r=te.a/(n.gc()+1),a=r,g=n.Kc();g.Ob();)f=l(g.Pb(),10),f.n.a=fe,f.n.b=o,fe+=f.o.a+L,E=Q2t(f),E.n.a=f.o.a/2-E.a.a,E.n.b=0,V=l(Q(f,(ft(),rW)),12),V.e.c.length+V.g.c.length==1&&(V.n.a=a-V.a.a,V.n.b=te.b,Mc(V,e)),a+=r}}function _Dn(e,t){var n,r,a,o,f,g;if(l(Q(t,(ft(),Lu)),21).Hc((Ho(),vf))){for(g=new G(t.a);g.a=0&&f0&&(l(Qo(e.b,t),127).a.b=n)}function IDn(e,t,n,r){var a,o,f,g,w,E,C,L,B,z,V,J;if(B=ze(Ge(Q(e,(Nt(),GT)))),z=ze(Ge(Q(e,KT))),L=ze(Ge(Q(e,y4))),g=e.o,o=l(jt(e.j,0),12),f=o.n,J=Y9n(o,L),!!J){if(t.Hc((Rl(),vp)))switch(l(Q(e,(ft(),Wc)),64).g){case 1:J.c=(g.a-J.b)/2-f.a,J.d=z;break;case 3:J.c=(g.a-J.b)/2-f.a,J.d=-z-J.a;break;case 2:n&&o.e.c.length==0&&o.g.c.length==0?(C=r?J.a:l(jt(o.f,0),72).o.b,J.d=(g.b-C)/2-f.b):J.d=g.b+z-f.b,J.c=-B-J.b;break;case 4:n&&o.e.c.length==0&&o.g.c.length==0?(C=r?J.a:l(jt(o.f,0),72).o.b,J.d=(g.b-C)/2-f.b):J.d=g.b+z-f.b,J.c=B}else if(t.Hc(Yb))switch(l(Q(e,(ft(),Wc)),64).g){case 1:case 3:J.c=f.a+B;break;case 2:case 4:n&&!o.c?(C=r?J.a:l(jt(o.f,0),72).o.b,J.d=(g.b-C)/2-f.b):J.d=f.b+z}for(a=J.d,E=new G(o.f);E.a=t.length)return{done:!0};var a=t[r++];return{value:[a,n.get(a)],done:!1}}}},LSn()||(e.prototype.createObject=function(){return{}},e.prototype.get=function(t){return this.obj[":"+t]},e.prototype.set=function(t,n){this.obj[":"+t]=n},e.prototype[lhe]=function(t){delete this.obj[":"+t]},e.prototype.keys=function(){var t=[];for(var n in this.obj)n.charCodeAt(0)==58&&t.push(n.substring(1));return t}),e}function Qi(){Qi=U,gM=new Ui(NEe),new vs("DEPTH",pt(0)),Pde=new vs("FAN",pt(0)),nIe=new vs(gyt,pt(0)),Vb=new vs("ROOT",(Hn(),!1)),Rde=new vs("LEFTNEIGHBOR",null),dTt=new vs("RIGHTNEIGHBOR",null),BW=new vs("LEFTSIBLING",null),jde=new vs("RIGHTSIBLING",null),Nde=new vs("DUMMY",!1),new vs("LEVEL",pt(0)),sIe=new vs("REMOVABLE_EDGES",new os),PB=new vs("XCOOR",pt(0)),BB=new vs("YCOOR",pt(0)),FW=new vs("LEVELHEIGHT",0),c1=new vs("LEVELMIN",0),k0=new vs("LEVELMAX",0),Bde=new vs("GRAPH_XMIN",0),Fde=new vs("GRAPH_YMIN",0),rIe=new vs("GRAPH_XMAX",0),iIe=new vs("GRAPH_YMAX",0),tIe=new vs("COMPACT_LEVEL_ASCENSION",!1),Ode=new vs("COMPACT_CONSTRAINTS",new bt),dM=new vs("ID",""),pM=new vs("POSITION",pt(0)),C2=new vs("PRELIM",0),JT=new vs("MODIFIER",0),QT=new Ui(S3t),NB=new Ui(_3t)}function BDn(e){kke();var t,n,r,a,o,f,g,w,E,C,L,B,z,V,J,te;if(e==null)return null;if(L=e.length*8,L==0)return"";for(g=L%24,z=L/24|0,B=g!=0?z+1:z,o=null,o=We(kf,Ad,28,B*4,15,1),E=0,C=0,t=0,n=0,r=0,f=0,a=0,w=0;w>24,E=(t&3)<<24>>24,V=t&-128?(t>>2^192)<<24>>24:t>>2<<24>>24,J=n&-128?(n>>4^240)<<24>>24:n>>4<<24>>24,te=r&-128?(r>>6^252)<<24>>24:r>>6<<24>>24,o[f++]=N2[V],o[f++]=N2[J|E<<4],o[f++]=N2[C<<2|te],o[f++]=N2[r&63];return g==8?(t=e[a],E=(t&3)<<24>>24,V=t&-128?(t>>2^192)<<24>>24:t>>2<<24>>24,o[f++]=N2[V],o[f++]=N2[E<<4],o[f++]=61,o[f++]=61):g==16&&(t=e[a],n=e[a+1],C=(n&15)<<24>>24,E=(t&3)<<24>>24,V=t&-128?(t>>2^192)<<24>>24:t>>2<<24>>24,J=n&-128?(n>>4^240)<<24>>24:n>>4<<24>>24,o[f++]=N2[V],o[f++]=N2[J|E<<4],o[f++]=N2[C<<2],o[f++]=61),If(o,0,o.length)}function FDn(e,t){var n,r,a,o,f,g,w;if(e.e==0&&e.p>0&&(e.p=-(e.p-1)),e.p>lo&&c6e(t,e.p-Lb),f=t.q.getDate(),YO(t,1),e.k>=0&&C2n(t,e.k),e.c>=0?YO(t,e.c):e.k>=0?(w=new R7e(t.q.getFullYear()-Lb,t.q.getMonth(),35),r=35-w.q.getDate(),YO(t,b.Math.min(r,f))):YO(t,f),e.f<0&&(e.f=t.q.getHours()),e.b>0&&e.f<12&&(e.f+=12),bhn(t,e.f==24&&e.g?0:e.f),e.j>=0&&ovn(t,e.j),e.n>=0&&wvn(t,e.n),e.i>=0&&Qtt(t,bo(mo(KN(Zc(t.q.getTime()),b2),b2),e.i)),e.a&&(a=new Qz,c6e(a,a.q.getFullYear()-Lb-80),fse(Zc(t.q.getTime()),Zc(a.q.getTime()))&&c6e(t,a.q.getFullYear()-Lb+100)),e.d>=0){if(e.c==-1)n=(7+e.d-t.q.getDay())%7,n>3&&(n-=7),g=t.q.getMonth(),YO(t,t.q.getDate()+n),t.q.getMonth()!=g&&YO(t,t.q.getDate()+(n>0?-7:7));else if(t.q.getDay()!=e.d)return!1}return e.o>lo&&(o=t.q.getTimezoneOffset(),Qtt(t,bo(Zc(t.q.getTime()),(e.o-o)*60*b2))),!0}function Kvt(e,t){var n,r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e;if(a=Q(t,(ft(),zi)),!!De(a,207)){for(V=l(a,27),J=t.e,B=new Eo(t.c),o=t.d,B.a+=o.b,B.b+=o.d,$e=l(at(V,(Nt(),xW)),181),vl($e,(Zl(),uY))&&(z=l(at(V,WMe),107),Tie(z,o.a),mwe(z,o.d),Cie(z,o.b),x8(z,o.c)),n=new bt,C=new G(t.a);C.ar.c.length-1;)vt(r,new ca(y6,hCe));n=l(Q(a,$d),17).a,Ug(l(Q(e,y3),88))?(a.e.aze(Ge((Sn(n,r.c.length),l(r.c[n],42)).b))&&ct((Sn(n,r.c.length),l(r.c[n],42)),a.e.a+a.f.a)):(a.e.bze(Ge((Sn(n,r.c.length),l(r.c[n],42)).b))&&ct((Sn(n,r.c.length),l(r.c[n],42)),a.e.b+a.f.b))}for(o=Rr(e.b,0);o.b!=o.d.c;)a=l(Br(o),40),n=l(Q(a,(Hc(),$d)),17).a,rt(a,(Qi(),c1),Ge((Sn(n,r.c.length),l(r.c[n],42)).a)),rt(a,k0,Ge((Sn(n,r.c.length),l(r.c[n],42)).b));t.Vg()}function jDn(e){var t,n,r,a,o,f,g,w,E,C,L,B,z,V,J;for(e.o=ze(Ge(Q(e.i,(Nt(),m3)))),e.f=ze(Ge(Q(e.i,vv))),e.j=e.i.b.c.length,g=e.j-1,B=0,e.k=0,e.n=0,e.b=O1(We(ro,dt,17,e.j,0,1)),e.c=O1(We(ta,dt,345,e.j,7,1)),f=new G(e.i.b);f.a0&&vt(e.q,C),vt(e.p,C);t-=r,z=w+t,E+=t*e.f,rf(e.b,g,pt(z)),rf(e.c,g,E),e.k=b.Math.max(e.k,z),e.n=b.Math.max(e.n,E),e.e+=t,t+=J}}function Ct(){Ct=U;var e;Pc=new wO(cL,0),Qn=new wO(nG,1),ar=new wO(yhe,2),Dr=new wO(xhe,3),er=new wO(khe,4),ed=(Cn(),new Ek((e=l(K0(Oo),9),new Zh(e,l(c0(e,e.length),9),0)))),_0=a2(rs(Qn,he(le(Oo,1),au,64,0,[]))),yf=a2(rs(ar,he(le(Oo,1),au,64,0,[]))),$h=a2(rs(Dr,he(le(Oo,1),au,64,0,[]))),Hf=a2(rs(er,he(le(Oo,1),au,64,0,[]))),hl=a2(rs(Qn,he(le(Oo,1),au,64,0,[Dr]))),Ju=a2(rs(ar,he(le(Oo,1),au,64,0,[er]))),A0=a2(rs(Qn,he(le(Oo,1),au,64,0,[er]))),zl=a2(rs(Qn,he(le(Oo,1),au,64,0,[ar]))),zh=a2(rs(Dr,he(le(Oo,1),au,64,0,[er]))),xf=a2(rs(ar,he(le(Oo,1),au,64,0,[Dr]))),ql=a2(rs(Qn,he(le(Oo,1),au,64,0,[ar,er]))),ll=a2(rs(ar,he(le(Oo,1),au,64,0,[Dr,er]))),fl=a2(rs(Qn,he(le(Oo,1),au,64,0,[Dr,er]))),_l=a2(rs(Qn,he(le(Oo,1),au,64,0,[ar,Dr]))),Du=a2(rs(Qn,he(le(Oo,1),au,64,0,[ar,Dr,er])))}function $Dn(e,t){var n,r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e,Ze,ot,St;for(t.Ug(K3t,1),J=new bt,ot=new bt,E=new G(e.b);E.a0&&(Me-=z),Oke(f,Me),C=0,B=new G(f.a);B.a0),g.a.Xb(g.c=--g.b)),w=.4*r*C,!o&&g.b0&&(w=(Xn(0,t.length),t.charCodeAt(0)),w!=64)){if(w==37&&(L=t.lastIndexOf("%"),E=!1,L!=0&&(L==B-1||(E=(Xn(L+1,t.length),t.charCodeAt(L+1)==46))))){if(f=(Ga(1,L,t.length),t.substr(1,L-1)),Me=vn("%",f)?null:Vke(f),r=0,E)try{r=Oh((Xn(L+2,t.length+1),t.substr(L+2)),lo,Ii)}catch($e){throw $e=bs($e),De($e,130)?(g=$e,ue(new nV(g))):ue($e)}for(te=m7e(e.Gh());te.Ob();)if(V=MV(te),De(V,519)&&(a=l(V,598),Te=a.d,(Me==null?Te==null:vn(Me,Te))&&r--==0))return a;return null}if(C=t.lastIndexOf("."),z=C==-1?t:(Ga(0,C,t.length),t.substr(0,C)),n=0,C!=-1)try{n=Oh((Xn(C+1,t.length+1),t.substr(C+1)),lo,Ii)}catch($e){if($e=bs($e),De($e,130))z=t;else throw ue($e)}for(z=vn("%",z)?null:Vke(z),J=m7e(e.Gh());J.Ob();)if(V=MV(J),De(V,197)&&(o=l(V,197),fe=o.xe(),(z==null?fe==null:vn(z,fe))&&n--==0))return o;return null}return Bvt(e,t)}function WDn(e){var t,n,r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te;for(C=new Pr,w=new Cw,r=new G(e.a.a.b);r.at.d.c){if(z=e.c[t.a.d],te=e.c[L.a.d],z==te)continue;p0(s0(i0(a0(r0(new _f,1),100),z),te))}}}}}function YDn(e,t){var n,r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e,Ze,ot;if(B=l(l($i(e.r,t),21),87),t==(Ct(),ar)||t==er){Vvt(e,t);return}for(o=t==Qn?(Pw(),rB):(Pw(),iB),$e=t==Qn?(ol(),a1):(ol(),w0),n=l(Qo(e.b,t),127),r=n.i,a=r.c+Y5(he(le(Na,1),Zo,28,15,[n.n.b,e.C.b,e.k])),fe=r.c+r.b-Y5(he(le(Na,1),Zo,28,15,[n.n.c,e.C.c,e.k])),f=i3e(y4e(o),e.t),Te=t==Qn?ia:gs,L=B.Kc();L.Ob();)E=l(L.Pb(),117),!(!E.c||E.c.d.c.length<=0)&&(te=E.b.Mf(),J=E.e,z=E.c,V=z.i,V.b=(w=z.n,z.e.a+w.b+w.c),V.a=(g=z.n,z.e.b+g.d+g.a),UO($e,yEe),z.f=$e,Z0(z,(Bl(),v0)),V.c=J.a-(V.b-te.a)/2,Ze=b.Math.min(a,J.a),ot=b.Math.max(fe,J.a+te.a),V.cot&&(V.c=ot-V.b),vt(f.d,new Dae(V,h8e(f,V))),Te=t==Qn?b.Math.max(Te,J.b+E.b.Mf().b):b.Math.min(Te,J.b));for(Te+=t==Qn?e.t:-e.t,Me=M8e((f.e=Te,f)),Me>0&&(l(Qo(e.b,t),127).a.b=Me),C=B.Kc();C.Ob();)E=l(C.Pb(),117),!(!E.c||E.c.d.c.length<=0)&&(V=E.c.i,V.c-=E.e.a,V.d-=E.e.b)}function XDn(e){var t,n,r,a,o,f,g,w,E,C,L,B,z;for(t=new Pr,w=new or(e);w.e!=w.i.gc();){for(g=l(gr(w),27),n=new Ks,ki(X0e,g,n),z=new Bp,a=l(yc(new bn(null,new vw(new hr(dr(sP(g).a.Kc(),new j)))),dst(z,Pl(new zr,new ht,new Fn,he(le(oc,1),it,108,0,[(Fl(),Ec)])))),85),Kht(n,l(a.xc((Hn(),!0)),16),new Y3),r=l(yc(Fi(l(a.xc(!1),15).Lc(),new $9),Pl(new zr,new ht,new Fn,he(le(oc,1),it,108,0,[Ec]))),15),f=r.Kc();f.Ob();)o=l(f.Pb(),74),B=Kgt(o),B&&(E=l(hc(zo(t.f,B)),21),E||(E=bbt(B),ju(t.f,B,E)),Ka(n,E));for(a=l(yc(new bn(null,new vw(new hr(dr(cp(g).a.Kc(),new j)))),dst(z,Pl(new zr,new ht,new Fn,he(le(oc,1),it,108,0,[Ec])))),85),Kht(n,l(a.xc(!0),16),new c5),r=l(yc(Fi(l(a.xc(!1),15).Lc(),new Eh),Pl(new zr,new ht,new Fn,he(le(oc,1),it,108,0,[Ec]))),15),L=r.Kc();L.Ob();)C=l(L.Pb(),74),B=Wgt(C),B&&(E=l(hc(zo(t.f,B)),21),E||(E=bbt(B),ju(t.f,B,E)),Ka(n,E))}}function QDn(e,t){ble();var n,r,a,o,f,g,w,E,C,L,B,z,V,J;if(w=iu(e,0)<0,w&&(e=r2(e)),iu(e,0)==0)switch(t){case 0:return"0";case 1:return sT;case 2:return"0.00";case 3:return"0.000";case 4:return"0.0000";case 5:return"0.00000";case 6:return"0.000000";default:return z=new tb,t<0?z.a+="0E+":z.a+="0E",z.a+=t==lo?"2147483648":""+-t,z.a}C=18,L=We(kf,Ad,28,C+1,15,1),n=C,J=e;do E=J,J=KN(J,10),L[--n]=Yr(bo(48,Df(E,mo(J,10))))&Zs;while(iu(J,0)!=0);if(a=Df(Df(Df(C,n),t),1),t==0)return w&&(L[--n]=45),If(L,n,C-n);if(t>0&&iu(a,-6)>=0){if(iu(a,0)>=0){for(o=n+Yr(a),g=C-1;g>=o;g--)L[g+1]=L[g];return L[++o]=46,w&&(L[--n]=45),If(L,n,C-n+1)}for(f=2;fse(f,bo(r2(a),1));f++)L[--n]=48;return L[--n]=46,L[--n]=48,w&&(L[--n]=45),If(L,n,C-n)}return V=n+1,r=C,B=new S5,w&&(B.a+="-"),r-V>=1?(hb(B,L[n]),B.a+=".",B.a+=If(L,n+1,C-n-1)):B.a+=If(L,n,C-n),B.a+="E",iu(a,0)>0&&(B.a+="+"),B.a+=""+Y_(a),B.a}function Gw(e,t,n,r,a){var o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e,Ze,ot;if(te=new lt(e.g,e.f),J=a9e(e),J.a=b.Math.max(J.a,t),J.b=b.Math.max(J.b,n),ot=J.a/te.a,C=J.b/te.b,$e=J.a-te.a,w=J.b-te.b,r)for(f=ds(e)?l(at(ds(e),(pi(),xv)),88):l(at(e,(pi(),xv)),88),g=qe(at(e,(pi(),_M)))===qe((Ra(),Mu)),Te=new or((!e.c&&(e.c=new nt(Hl,e,9,9)),e.c));Te.e!=Te.i.gc();)switch(fe=l(gr(Te),123),Me=l(at(fe,s7),64),Me==(Ct(),Pc)&&(Me=Eke(fe,f),Hi(fe,s7,Me)),Me.g){case 1:g||Uu(fe,fe.i*ot);break;case 2:Uu(fe,fe.i+$e),g||Gu(fe,fe.j*C);break;case 3:g||Uu(fe,fe.i*ot),Gu(fe,fe.j+w);break;case 4:g||Gu(fe,fe.j*C)}if(F5(e,J.a,J.b),a)for(B=new or((!e.n&&(e.n=new nt(ec,e,1,7)),e.n));B.e!=B.i.gc();)L=l(gr(B),135),z=L.i+L.g/2,V=L.j+L.f/2,Ze=z/te.a,E=V/te.b,Ze+E>=1&&(Ze-E>0&&V>=0?(Uu(L,L.i+$e),Gu(L,L.j+w*E)):Ze-E<0&&z>=0&&(Uu(L,L.i+$e*Ze),Gu(L,L.j+w)));return Hi(e,(pi(),kv),(mh(),o=l(K0(BM),9),new Zh(o,l(c0(o,o.length),9),0))),new lt(ot,C)}function Qvt(e){sw(e,new Xm(Uz(nw(Zv(tw(ew(new x1,gf),"ELK Radial"),'A radial layout provider which is based on the algorithm of Peter Eades published in "Drawing free trees.", published by International Institute for Advanced Study of Social Information Science, Fujitsu Limited in 1991. The radial layouter takes a tree and places the nodes in radial order around the root. The nodes of the same tree level are placed on the same radius.'),new fu),gf))),gt(e,gf,_G,It(uCt)),gt(e,gf,Jy,It(lCt)),gt(e,gf,x6,It(sCt)),gt(e,gf,Px,It(aCt)),gt(e,gf,Nx,It(oCt)),gt(e,gf,fT,It(iCt)),gt(e,gf,fL,It(NIe)),gt(e,gf,dT,It(cCt)),gt(e,gf,Cfe,It(Jde)),gt(e,gf,Tfe,It(Zde)),gt(e,gf,NG,It(BIe)),gt(e,gf,Sfe,It(ege)),gt(e,gf,_fe,It(FIe)),gt(e,gf,MCe,It(RIe)),gt(e,gf,LCe,It(PIe)),gt(e,gf,CCe,It(qW)),gt(e,gf,SCe,It(HW)),gt(e,gf,_Ce,It(FB)),gt(e,gf,ACe,It(jIe)),gt(e,gf,TCe,It(OIe))}function KU(e){var t,n,r,a,o,f,g,w,E,C,L;if(e==null)throw ue(new gd(ul));if(E=e,o=e.length,w=!1,o>0&&(t=(Xn(0,e.length),e.charCodeAt(0)),(t==45||t==43)&&(e=(Xn(1,e.length+1),e.substr(1)),--o,w=t==45)),o==0)throw ue(new gd(Yw+E+'"'));for(;e.length>0&&(Xn(0,e.length),e.charCodeAt(0)==48);)e=(Xn(1,e.length+1),e.substr(1)),--o;if(o>(Amt(),b6t)[10])throw ue(new gd(Yw+E+'"'));for(a=0;a0&&(L=-parseInt((Ga(0,r,e.length),e.substr(0,r)),10),e=(Xn(r,e.length+1),e.substr(r)),o-=r,n=!1);o>=f;){if(r=parseInt((Ga(0,f,e.length),e.substr(0,f)),10),e=(Xn(f,e.length+1),e.substr(f)),o-=f,n)n=!1;else{if(iu(L,g)<0)throw ue(new gd(Yw+E+'"'));L=mo(L,C)}L=Df(L,r)}if(iu(L,0)>0)throw ue(new gd(Yw+E+'"'));if(!w&&(L=r2(L),iu(L,0)<0))throw ue(new gd(Yw+E+'"'));return L}function Vke(e){kle();var t,n,r,a,o,f,g,w;if(e==null)return null;if(a=pd(e,cl(37)),a<0)return e;for(w=new Th((Ga(0,a,e.length),e.substr(0,a))),t=We(Al,C6,28,4,15,1),g=0,r=0,f=e.length;aa+2&&mce((Xn(a+1,e.length),e.charCodeAt(a+1)),kPe,EPe)&&mce((Xn(a+2,e.length),e.charCodeAt(a+2)),kPe,EPe))if(n=vdn((Xn(a+1,e.length),e.charCodeAt(a+1)),(Xn(a+2,e.length),e.charCodeAt(a+2))),a+=2,r>0?(n&192)==128?t[g++]=n<<24>>24:r=0:n>=128&&((n&224)==192?(t[g++]=n<<24>>24,r=2):(n&240)==224?(t[g++]=n<<24>>24,r=3):(n&248)==240&&(t[g++]=n<<24>>24,r=4)),r>0){if(g==r){switch(g){case 2:{hb(w,((t[0]&31)<<6|t[1]&63)&Zs);break}case 3:{hb(w,((t[0]&15)<<12|(t[1]&63)<<6|t[2]&63)&Zs);break}}g=0,r=0}}else{for(o=0;o=2){if((!e.a&&(e.a=new nt(cs,e,6,6)),e.a).i==0)n=(rb(),a=new rk,a),qr((!e.a&&(e.a=new nt(cs,e,6,6)),e.a),n);else if((!e.a&&(e.a=new nt(cs,e,6,6)),e.a).i>1)for(B=new q8((!e.a&&(e.a=new nt(cs,e,6,6)),e.a));B.e!=B.i.gc();)jA(B);dP(t,l(Oe((!e.a&&(e.a=new nt(cs,e,6,6)),e.a),0),166))}if(L)for(r=new or((!e.a&&(e.a=new nt(cs,e,6,6)),e.a));r.e!=r.i.gc();)for(n=l(gr(r),166),E=new or((!n.a&&(n.a=new Ys(qh,n,5)),n.a));E.e!=E.i.gc();)w=l(gr(E),377),g.a=b.Math.max(g.a,w.a),g.b=b.Math.max(g.b,w.b);for(f=new or((!e.n&&(e.n=new nt(ec,e,1,7)),e.n));f.e!=f.i.gc();)o=l(gr(f),135),C=l(at(o,MM),8),C&&Qh(o,C.a,C.b),L&&(g.a=b.Math.max(g.a,o.i+o.g),g.b=b.Math.max(g.b,o.j+o.f));return g}function Zvt(e,t,n,r,a){var o,f,g;if(eht(e,t),f=t[0],o=co(n.c,0),g=-1,z7e(n))if(r>0){if(f+r>e.length)return!1;g=kU((Ga(0,f+r,e.length),e.substr(0,f+r)),t)}else g=kU(e,t);switch(o){case 71:return g=o6(e,f,he(le(zt,1),dt,2,6,[Rwt,jwt]),t),a.e=g,!0;case 77:return dSn(e,t,a,g,f);case 76:return gSn(e,t,a,g,f);case 69:return skn(e,t,f,a);case 99:return akn(e,t,f,a);case 97:return g=o6(e,f,he(le(zt,1),dt,2,6,["AM","PM"]),t),a.b=g,!0;case 121:return pSn(e,t,f,g,n,a);case 100:return g<=0?!1:(a.c=g,!0);case 83:return g<0?!1:x5n(g,f,t[0],a);case 104:g==12&&(g=0);case 75:case 72:return g<0?!1:(a.f=g,a.g=!1,!0);case 107:return g<0?!1:(a.f=g,a.g=!0,!0);case 109:return g<0?!1:(a.j=g,!0);case 115:return g<0?!1:(a.n=g,!0);case 90:if(fcn[w]&&(te=w),L=new G(e.a.b);L.a1;){if(a=aCn(t),L=o.g,V=l(at(t,vM),107),J=ze(Ge(at(t,KW))),(!t.a&&(t.a=new nt(Ai,t,10,11)),t.a).i>1&&ze(Ge(at(t,(ug(),cge))))!=gs&&(o.c+(V.b+V.c))/(o.b+(V.d+V.a))1&&ze(Ge(at(t,(ug(),oge))))!=gs&&(o.c+(V.b+V.c))/(o.b+(V.d+V.a))>J&&Hi(a,(ug(),T4),b.Math.max(ze(Ge(at(t,mM))),ze(Ge(at(a,T4)))-ze(Ge(at(t,oge))))),z=new Q3e(r,C),w=wwt(z,a,B),E=w.g,E>=L&&E==E){for(f=0;f<(!a.a&&(a.a=new nt(Ai,a,10,11)),a.a).i;f++)Gpt(e,l(Oe((!a.a&&(a.a=new nt(Ai,a,10,11)),a.a),f),27),l(Oe((!t.a&&(t.a=new nt(Ai,t,10,11)),t.a),f),27));Sht(t,z),l2n(o,w.c),u2n(o,w.b)}--g}Hi(t,(ug(),ZT),o.b),Hi(t,Zx,o.c),n.Vg()}function tIn(e,t){var n,r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te;for(t.Ug("Interactive node layering",1),n=new bt,B=new G(e.a);B.a=g){mr(Te.b>0),Te.a.Xb(Te.c=--Te.b);break}else te.a>w&&(r?(ra(r.b,te.b),r.a=b.Math.max(r.a,te.a),ph(Te)):(vt(te.b,C),te.c=b.Math.min(te.c,w),te.a=b.Math.max(te.a,g),r=te));r||(r=new GQe,r.c=w,r.a=g,by(Te,r),vt(r.b,C))}for(f=e.b,E=0,fe=new G(n);fe.az&&(o&&(ko(ot,B),ko(cn,pt(E.b-1))),oi=n.b,ws+=B+t,B=0,C=b.Math.max(C,n.b+n.c+ur)),Uu(g,oi),Gu(g,ws),C=b.Math.max(C,oi+ur+n.c),B=b.Math.max(B,L),oi+=ur+t;if(C=b.Math.max(C,r),jn=ws+B+n.a,jnDd,an=b.Math.abs(B.b-V.b)>Dd,(!n&&cn&&an||n&&(cn||an))&&ui(te.a,$e)),Ka(te.a,r),r.b==0?B=$e:B=(mr(r.b!=0),l(r.c.b.c,8)),z3n(z,L,J),Cft(a)==St&&(eo(St.i)!=a.a&&(J=new qa,n9e(J,eo(St.i),Te)),rt(te,Y1e,J)),E9n(z,te,Te),C.a.zc(z,C);po(te,Ze),Fa(te,St)}for(E=C.a.ec().Kc();E.Ob();)w=l(E.Pb(),18),po(w,null),Fa(w,null);t.Vg()}function iIn(e,t){var n,r,a,o,f,g,w,E,C,L,B;for(a=l(Q(e,(Hc(),y3)),88),C=a==(Js(),uc)||a==vc?Q1:vc,n=l(yc(Fi(new bn(null,new kn(e.b,16)),new pI),Pl(new zr,new ht,new Fn,he(le(oc,1),it,108,0,[(Fl(),Ec)]))),15),w=l(yc(fc(n.Oc(),new dXe(t)),Pl(new zr,new ht,new Fn,he(le(oc,1),it,108,0,[Ec]))),15),w.Gc(l(yc(fc(n.Oc(),new gXe(t)),Pl(new zr,new ht,new Fn,he(le(oc,1),it,108,0,[Ec]))),16)),w.jd(new pXe(C)),B=new Kp(new bXe(a)),r=new Pr,g=w.Kc();g.Ob();)f=l(g.Pb(),240),E=l(f.a,40),Rt(Bt(f.c))?(B.a.zc(E,(Hn(),Pb))==null,new ba(B.a.Zc(E,!1)).a.gc()>0&&ki(r,E,l(new ba(B.a.Zc(E,!1)).a.Vc(),40)),new ba(B.a.ad(E,!0)).a.gc()>1&&ki(r,L1t(B,E),E)):(new ba(B.a.Zc(E,!1)).a.gc()>0&&(o=l(new ba(B.a.Zc(E,!1)).a.Vc(),40),qe(o)===qe(hc(zo(r.f,E)))&&l(Q(E,(Qi(),Ode)),15).Fc(o)),new ba(B.a.ad(E,!0)).a.gc()>1&&(L=L1t(B,E),qe(hc(zo(r.f,L)))===qe(E)&&l(Q(L,(Qi(),Ode)),15).Fc(E)),B.a.Bc(E)!=null)}function ewt(e){var t,n,r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e;if(e.gc()==1)return l(e.Xb(0),235);if(e.gc()<=0)return new KH;for(a=e.Kc();a.Ob();){for(n=l(a.Pb(),235),V=0,C=Ii,L=Ii,w=lo,E=lo,z=new G(n.e);z.ag&&(Me=0,$e+=f+fe,f=0),D_n(J,n,Me,$e),t=b.Math.max(t,Me+te.a),f=b.Math.max(f,te.b),Me+=te.a+fe;return J}function sIn(e){kke();var t,n,r,a,o,f,g,w,E,C,L,B,z,V,J,te;if(e==null||(o=iV(e),V=O4n(o),V%4!=0))return null;if(J=V/4|0,J==0)return We(Al,C6,28,0,15,1);for(L=null,t=0,n=0,r=0,a=0,f=0,g=0,w=0,E=0,z=0,B=0,C=0,L=We(Al,C6,28,J*3,15,1);z>4)<<24>>24,L[B++]=((n&15)<<4|r>>2&15)<<24>>24,L[B++]=(r<<6|a)<<24>>24}return!eO(f=o[C++])||!eO(g=o[C++])?null:(t=nd[f],n=nd[g],w=o[C++],E=o[C++],nd[w]==-1||nd[E]==-1?w==61&&E==61?n&15?null:(te=We(Al,C6,28,z*3+1,15,1),pu(L,0,te,0,z*3),te[B]=(t<<2|n>>4)<<24>>24,te):w!=61&&E==61?(r=nd[w],r&3?null:(te=We(Al,C6,28,z*3+2,15,1),pu(L,0,te,0,z*3),te[B++]=(t<<2|n>>4)<<24>>24,te[B]=((n&15)<<4|r>>2&15)<<24>>24,te)):null:(r=nd[w],a=nd[E],L[B++]=(t<<2|n>>4)<<24>>24,L[B++]=((n&15)<<4|r>>2&15)<<24>>24,L[B++]=(r<<6|a)<<24>>24,L))}function aIn(e,t){var n,r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e,Ze;for(t.Ug(K3t,1),V=l(Q(e,(Nt(),bp)),223),a=new G(e.b);a.a=2){for(J=!0,B=new G(o.j),n=l(re(B),12),z=null;B.a0)if(r=L.gc(),E=ua(b.Math.floor((r+1)/2))-1,a=ua(b.Math.ceil((r+1)/2))-1,t.o==Y1)for(C=a;C>=E;C--)t.a[$e.p]==$e&&(J=l(L.Xb(C),42),V=l(J.a,10),!W0(n,J.b)&&z>e.b.e[V.p]&&(t.a[V.p]=$e,t.g[$e.p]=t.g[V.p],t.a[$e.p]=t.g[$e.p],t.f[t.g[$e.p].p]=(Hn(),!!(Rt(t.f[t.g[$e.p].p])&$e.k==(Zn(),Aa))),z=e.b.e[V.p]));else for(C=E;C<=a;C++)t.a[$e.p]==$e&&(fe=l(L.Xb(C),42),te=l(fe.a,10),!W0(n,fe.b)&&z0&&(a=l(jt(te.c.a,ot-1),10),f=e.i[a.p],cn=b.Math.ceil(j5(e.n,a,te)),o=Ze.a.e-te.d.d-(f.a.e+a.o.b+a.d.a)-cn),E=gs,ot0&&St.a.e.e-St.a.a-(St.b.e.e-St.b.a)<0,V=Me.a.e.e-Me.a.a-(Me.b.e.e-Me.b.a)<0&&St.a.e.e-St.a.a-(St.b.e.e-St.b.a)>0,z=Me.a.e.e+Me.b.aSt.b.e.e+St.a.a,$e=0,!J&&!V&&(B?o+L>0?$e=L:E-r>0&&($e=r):z&&(o+g>0?$e=g:E-Te>0&&($e=Te))),Ze.a.e+=$e,Ze.b&&(Ze.d.e+=$e),!1))}function nwt(e,t,n){var r,a,o,f,g,w,E,C,L,B;if(r=new ef(t.Lf().a,t.Lf().b,t.Mf().a,t.Mf().b),a=new $8,e.c)for(f=new G(t.Rf());f.aE&&(r.a+=Mnt(We(kf,Ad,28,-E,15,1))),r.a+="Is",pd(w,cl(32))>=0)for(a=0;a=r.o.b/2}else Te=!L;Te?(fe=l(Q(r,(ft(),Qx)),15),fe?B?o=fe:(a=l(Q(r,Gx),15),a?fe.gc()<=a.gc()?o=fe:o=a:(o=new bt,rt(r,Gx,o))):(o=new bt,rt(r,Qx,o))):(a=l(Q(r,(ft(),Gx)),15),a?L?o=a:(fe=l(Q(r,Qx),15),fe?a.gc()<=fe.gc()?o=a:o=fe:(o=new bt,rt(r,Qx,o))):(o=new bt,rt(r,Gx,o))),o.Fc(e),rt(e,(ft(),rW),n),t.d==n?(Fa(t,null),n.e.c.length+n.g.c.length==0&&Mc(n,null),Tyn(n)):(po(t,null),n.e.c.length+n.g.c.length==0&&Mc(n,null)),Ch(t.a)}function lIn(e,t,n){var r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e,Ze,ot,St,cn,an,Bn,jn,ur,oi,ws;for(n.Ug("MinWidth layering",1),z=t.b,St=t.a,ws=l(Q(t,(Nt(),zMe)),17).a,g=l(Q(t,qMe),17).a,e.b=ze(Ge(Q(t,x0))),e.d=gs,$e=new G(St);$e.a<$e.c.c.length;)Te=l(re($e),10),Te.k==(Zn(),Ps)&&(Bn=Te.o.b,e.d=b.Math.min(e.d,Bn));for(e.d=b.Math.max(1,e.d),cn=St.c.length,e.c=We(Vr,di,28,cn,15,1),e.f=We(Vr,di,28,cn,15,1),e.e=We(Na,Zo,28,cn,15,1),E=0,e.a=0,Ze=new G(St);Ze.a0?(E=0,te&&(E+=g),E+=(an-1)*f,Me&&(E+=g),cn&&Me&&(E=b.Math.max(E,MCn(Me,f,Te,St))),E=e.a&&(r=GAn(e,Te),C=b.Math.max(C,r.b),$e=b.Math.max($e,r.d),vt(g,new ca(Te,r)));for(cn=new bt,E=0;E0),te.a.Xb(te.c=--te.b),an=new yu(e.b),by(te,an),mr(te.b0){for(B=C<100?null:new nb(C),E=new T7e(t),V=E.g,fe=We(Vr,di,28,C,15,1),r=0,$e=new Lw(C),a=0;a=0;)if(z!=null?Pi(z,V[w]):qe(z)===qe(V[w])){fe.length<=r&&(te=fe,fe=We(Vr,di,28,2*fe.length,15,1),pu(te,0,fe,0,r)),fe[r++]=a,qr($e,V[w]);break e}if(z=z,qe(z)===qe(g))break}}if(E=$e,V=$e.g,C=r,r>fe.length&&(te=fe,fe=We(Vr,di,28,r,15,1),pu(te,0,fe,0,r)),r>0){for(Me=!0,o=0;o=0;)vx(e,fe[f]);if(r!=C){for(a=C;--a>=r;)vx(E,a);te=fe,fe=We(Vr,di,28,r,15,1),pu(te,0,fe,0,r)}t=E}}}else for(t=_7n(e,t),a=e.i;--a>=0;)t.Hc(e.g[a])&&(vx(e,a),Me=!0);if(Me){if(fe!=null){for(n=t.gc(),L=n==1?rA(e,4,t.Kc().Pb(),null,fe[0],J):rA(e,6,t,fe,fe[0],J),B=n<100?null:new nb(n),a=t.Kc();a.Ob();)z=a.Pb(),B=d4e(e,l(z,76),B);B?(B.nj(L),B.oj()):Ni(e.e,L)}else{for(B=Ofn(t.gc()),a=t.Kc();a.Ob();)z=a.Pb(),B=d4e(e,l(z,76),B);B&&B.oj()}return!0}else return!1}function dIn(e,t){var n,r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me;for(n=new xdt(t),n.a||q_n(t),E=jSn(t),w=new Cw,te=new Ebt,J=new G(t.a);J.a0||n.o==Y1&&a=n}function pIn(e,t,n){var r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e,Ze,ot,St,cn,an,Bn,jn,ur;for(Me=t,Te=new Cw,$e=new Cw,C=Aw(Me,fSe),r=new Mat(e,n,Te,$e),P9n(r.a,r.b,r.c,r.d,C),w=(St=Te.i,St||(Te.i=new q5(Te,Te.c))),an=w.Kc();an.Ob();)for(cn=l(an.Pb(),166),a=l($i(Te,cn),21),J=a.Kc();J.Ob();)if(V=J.Pb(),Ze=l(X5(e.d,V),166),Ze)g=(!cn.e&&(cn.e=new Ln(cs,cn,10,9)),cn.e),qr(g,Ze);else throw f=Yg(Me,Pd),B=y4t+V+x4t+f,z=B+kT,ue(new dd(z));for(E=(ot=$e.i,ot||($e.i=new q5($e,$e.c))),jn=E.Kc();jn.Ob();)for(Bn=l(jn.Pb(),166),o=l($i($e,Bn),21),fe=o.Kc();fe.Ob();)if(te=fe.Pb(),Ze=l(X5(e.d,te),166),Ze)L=(!Bn.g&&(Bn.g=new Ln(cs,Bn,9,10)),Bn.g),qr(L,Ze);else throw f=Yg(Me,Pd),B=y4t+te+x4t+f,z=B+kT,ue(new dd(z));!n.b&&(n.b=new Ln(_r,n,4,7)),n.b.i!=0&&(!n.c&&(n.c=new Ln(_r,n,5,8)),n.c.i!=0)&&(!n.b&&(n.b=new Ln(_r,n,4,7)),n.b.i<=1&&(!n.c&&(n.c=new Ln(_r,n,5,8)),n.c.i<=1))&&(!n.a&&(n.a=new nt(cs,n,6,6)),n.a).i==1&&(ur=l(Oe((!n.a&&(n.a=new nt(cs,n,6,6)),n.a),0),166),!aue(ur)&&!oue(ur)&&(wV(ur,l(Oe((!n.b&&(n.b=new Ln(_r,n,4,7)),n.b),0),84)),yV(ur,l(Oe((!n.c&&(n.c=new Ln(_r,n,5,8)),n.c),0),84))))}function bIn(e){var t,n,r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e,Ze,ot,St,cn,an,Bn;for(Me=e.a,$e=0,Ze=Me.length;$e0?(L=l(jt(B.c.a,f-1),10),cn=j5(e.b,B,L),te=B.n.b-B.d.d-(L.n.b+L.o.b+L.d.a+cn)):te=B.n.b-B.d.d,E=b.Math.min(te,E),f1&&(f=b.Math.min(f,b.Math.abs(l(ff(g.a,1),8).b-C.b)))));else for(J=new G(t.j);J.aa&&(o=B.a-a,f=Ii,r.c.length=0,a=B.a),B.a>=a&&($n(r.c,g),g.a.b>1&&(f=b.Math.min(f,b.Math.abs(l(ff(g.a,g.a.b-2),8).b-B.b)))));if(r.c.length!=0&&o>t.o.a/2&&f>t.o.b/2){for(z=new gu,Mc(z,t),la(z,(Ct(),Qn)),z.n.a=t.o.a/2,fe=new gu,Mc(fe,t),la(fe,Dr),fe.n.a=t.o.a/2,fe.n.b=t.o.b,w=new G(r);w.a=E.b?po(g,fe):po(g,z)):(E=l(odn(g.a),8),te=g.a.b==0?I1(g.c):l(o0(g.a),8),te.b>=E.b?Fa(g,fe):Fa(g,z)),L=l(Q(g,(Nt(),cc)),75),L&&Ny(L,E,!0);t.n.a=a-t.o.a/2}}function vIn(e,t,n){var r,a,o,f,g,w,E,C,L,B;for(g=Rr(e.b,0);g.b!=g.d.c;)if(f=l(Br(g),40),!vn(f.c,DG))for(E=HEn(f,e),t==(Js(),uc)||t==vc?Vs(E,new ene):Vs(E,new tne),w=E.c.length,r=0;r=0?z=gx(g):z=BN(gx(g)),e.qf(VT,z)),E=new qa,B=!1,e.pf(p3)?(Fye(E,l(e.of(p3),8)),B=!0):Ahn(E,f.a/2,f.b/2),z.g){case 4:rt(C,Qu,(hf(),$b)),rt(C,sW,(Vm(),P6)),C.o.b=f.b,J<0&&(C.o.a=-J),la(L,(Ct(),ar)),B||(E.a=f.a),E.a-=f.a;break;case 2:rt(C,Qu,(hf(),d4)),rt(C,sW,(Vm(),FT)),C.o.b=f.b,J<0&&(C.o.a=-J),la(L,(Ct(),er)),B||(E.a=0);break;case 1:rt(C,hv,(ep(),F6)),C.o.a=f.a,J<0&&(C.o.b=-J),la(L,(Ct(),Dr)),B||(E.b=f.b),E.b-=f.b;break;case 3:rt(C,hv,(ep(),Ux)),C.o.a=f.a,J<0&&(C.o.b=-J),la(L,(Ct(),Qn)),B||(E.b=0)}if(Fye(L.n,E),rt(C,p3,E),t==Tv||t==Tg||t==Mu){if(V=0,t==Tv&&e.pf(k2))switch(z.g){case 1:case 2:V=l(e.of(k2),17).a;break;case 3:case 4:V=-l(e.of(k2),17).a}else switch(z.g){case 4:case 2:V=o.b,t==Tg&&(V/=a.b);break;case 1:case 3:V=o.a,t==Tg&&(V/=a.a)}rt(C,l3,V)}return rt(C,Wc,z),C}function wIn(){c3e();function e(r){var a=this;this.dispatch=function(o){var f=o.data;switch(f.cmd){case"algorithms":var g=L8e((Cn(),new $a(new gi(Qb.b))));r.postMessage({id:f.id,data:g});break;case"categories":var w=L8e((Cn(),new $a(new gi(Qb.c))));r.postMessage({id:f.id,data:w});break;case"options":var E=L8e((Cn(),new $a(new gi(Qb.d))));r.postMessage({id:f.id,data:E});break;case"register":kMn(f.algorithms),r.postMessage({id:f.id});break;case"layout":QAn(f.graph,f.layoutOptions||{},f.options||{}),r.postMessage({id:f.id,data:f.graph});break}},this.saveDispatch=function(o){try{a.dispatch(o)}catch(f){r.postMessage({id:o.data.id,error:f})}}}function t(r){var a=this;this.dispatcher=new e({postMessage:function(o){a.onmessage({data:o})}}),this.postMessage=function(o){setTimeout(function(){a.dispatcher.saveDispatch({data:o})},0)}}if(typeof document===ghe&&typeof self!==ghe){var n=new e(self);self.onmessage=n.saveDispatch}else typeof d!==ghe&&d.exports&&(Object.defineProperty(p,"__esModule",{value:!0}),d.exports={default:t,Worker:t})}function cwt(e,t,n){var r,a,o,f,g,w,E,C,L,B;for(C=new op(n),pc(C,t),rt(C,(ft(),zi),t),C.o.a=t.g,C.o.b=t.f,C.n.a=t.i,C.n.b=t.j,vt(n.a,C),ki(e.a,t,C),((!t.a&&(t.a=new nt(Ai,t,10,11)),t.a).i!=0||Rt(Bt(at(t,(Nt(),b4)))))&&rt(C,FLe,(Hn(),!0)),E=l(Q(n,Lu),21),L=l(Q(C,(Nt(),Ms)),101),L==(Ra(),Wb)?rt(C,Ms,Z1):L!=Z1&&E.Fc((Ho(),$T)),B=0,r=l(Q(n,Rh),88),w=new or((!t.c&&(t.c=new nt(Hl,t,9,9)),t.c));w.e!=w.i.gc();)g=l(gr(w),123),a=ds(t),(qe(at(a,yg))!==qe((Ed(),E2))||qe(at(a,dv))===qe((l2(),BT))||qe(at(a,dv))===qe((l2(),PT))||Rt(Bt(at(a,f3)))||qe(at(a,g4))!==qe((Km(),c4))||qe(at(a,zb))===qe((Nf(),v3))||qe(at(a,zb))===qe((Nf(),x4))||qe(at(a,pv))===qe((p2(),WT))||qe(at(a,pv))===qe((p2(),YT)))&&!Rt(Bt(at(t,fW)))&&Hi(g,Ki,pt(B++)),Rt(Bt(at(g,mv)))||LDn(e,g,C,E,r,L);for(f=new or((!t.n&&(t.n=new nt(ec,t,1,7)),t.n));f.e!=f.i.gc();)o=l(gr(f),135),!Rt(Bt(at(o,mv)))&&o.a&&vt(C.b,Oce(o));return Rt(Bt(Q(C,QL)))&&E.Fc((Ho(),eW)),Rt(Bt(Q(C,bW)))&&(E.Fc((Ho(),tW)),E.Fc(UL),rt(C,Ms,Z1)),C}function Lle(e,t,n,r,a,o,f){var g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e,Ze,ot,St,cn,an,Bn,jn,ur,oi,ws;for(J=0,Bn=0,E=new G(e.b);E.aJ&&(o&&(ko(ot,z),ko(cn,pt(C.b-1)),vt(e.d,V),g.c.length=0),oi=n.b,ws+=z+t,z=0,L=b.Math.max(L,n.b+n.c+ur)),$n(g.c,w),ddt(w,oi,ws),L=b.Math.max(L,oi+ur+n.c),z=b.Math.max(z,B),oi+=ur+t,V=w;if(ra(e.a,g),vt(e.d,l(jt(g,g.c.length-1),163)),L=b.Math.max(L,r),jn=ws+z+n.a,jna.d.d+a.d.a?C.f.d=!0:(C.f.d=!0,C.f.a=!0))),r.b!=r.d.c&&(t=n);C&&(o=l(cr(e.f,f.d.i),60),t.bo.d.d+o.d.a?C.f.d=!0:(C.f.d=!0,C.f.a=!0))}for(g=new hr(dr(ka(z).a.Kc(),new j));jr(g);)f=l(xr(g),18),f.a.b!=0&&(t=l(o0(f.a),8),f.d.j==(Ct(),Qn)&&(te=new QA(t,new lt(t.a,a.d.d),a,f),te.f.a=!0,te.a=f.d,$n(J.c,te)),f.d.j==Dr&&(te=new QA(t,new lt(t.a,a.d.d+a.d.a),a,f),te.f.d=!0,te.a=f.d,$n(J.c,te)))}return J}function CIn(e,t,n){var r,a,o,f,g,w,E,C,L,B;for(w=new bt,L=t.length,f=$7e(n),E=0;E=V&&(Te>V&&(z.c.length=0,V=Te),$n(z.c,f));z.c.length!=0&&(B=l(jt(z,aU(t,z.c.length)),131),jn.a.Bc(B)!=null,B.s=J++,R9e(B,an,ot),z.c.length=0)}for($e=e.c.length+1,g=new G(e);g.aBn.s&&(ph(n),al(Bn.i,r),r.c>0&&(r.a=Bn,vt(Bn.t,r),r.b=St,vt(St.i,r)))}function uwt(e,t,n,r,a){var o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e,Ze,ot,St,cn,an,Bn,jn;for(J=new Bu(t.b),$e=new Bu(t.b),B=new Bu(t.b),cn=new Bu(t.b),te=new Bu(t.b),St=Rr(t,0);St.b!=St.d.c;)for(Ze=l(Br(St),12),g=new G(Ze.g);g.a0,fe=Ze.g.c.length>0,E&&fe?$n(B.c,Ze):E?$n(J.c,Ze):fe&&$n($e.c,Ze);for(V=new G(J);V.aTe.nh()-E.b&&(B=Te.nh()-E.b),z>Te.oh()-E.d&&(z=Te.oh()-E.d),C0){for(Me=Rr(e.f,0);Me.b!=Me.d.c;)Te=l(Br(Me),10),Te.p+=B-e.e;r9e(e),Ch(e.f),J9e(e,r,z)}else{for(ui(e.f,z),z.p=r,e.e=b.Math.max(e.e,r),o=new hr(dr(ka(z).a.Kc(),new j));jr(o);)a=l(xr(o),18),!a.c.i.c&&a.c.i.k==(Zn(),cu)&&(ui(e.f,a.c.i),a.c.i.p=r-1);e.c=r}else r9e(e),Ch(e.f),r=0,jr(new hr(dr(ka(z).a.Kc(),new j)))?(B=0,B=vdt(B,z),r=B+2,J9e(e,r,z)):(ui(e.f,z),z.p=0,e.e=b.Math.max(e.e,0),e.b=l(jt(e.d.b,0),30),e.c=0);for(e.f.b==0||r9e(e),e.d.a.c.length=0,fe=new bt,E=new G(e.d.b);E.a=48&&t<=57){for(r=t-48;a=48&&t<=57;)if(r=r*10+t-48,r<0)throw ue(new ri(ai((Jr(),CSe))))}else throw ue(new ri(ai((Jr(),K4t))));if(n=r,t==44){if(a>=e.j)throw ue(new ri(ai((Jr(),Y4t))));if((t=co(e.i,a++))>=48&&t<=57){for(n=t-48;a=48&&t<=57;)if(n=n*10+t-48,n<0)throw ue(new ri(ai((Jr(),CSe))));if(r>n)throw ue(new ri(ai((Jr(),X4t))))}else n=-1}if(t!=125)throw ue(new ri(ai((Jr(),W4t))));e.bm(a)?(o=(Di(),Di(),new Ty(9,o)),e.d=a+1):(o=(Di(),Di(),new Ty(3,o)),e.d=a),o.Om(r),o.Nm(n),Li(e)}}return o}function DIn(e){var t,n,r,a,o;switch(n=l(Q(e,(ft(),Lu)),21),t=Oq(v8t),a=l(Q(e,(Nt(),p4)),346),a==(rp(),A2)&&Dh(t,w8t),Rt(Bt(Q(e,ide)))?fi(t,(uo(),y0),(vo(),d1e)):fi(t,(uo(),bu),(vo(),d1e)),Q(e,(QH(),kM))!=null&&Dh(t,y8t),(Rt(Bt(Q(e,RMe)))||Rt(Bt(Q(e,NMe))))&&yl(t,(uo(),mc),(vo(),OAe)),l(Q(e,Rh),88).g){case 2:case 3:case 4:yl(fi(t,(uo(),y0),(vo(),PAe)),mc,NAe)}switch(n.Hc((Ho(),eW))&&yl(fi(fi(t,(uo(),y0),(vo(),IAe)),_u,MAe),mc,DAe),qe(Q(e,zb))!==qe((Nf(),AW))&&fi(t,(uo(),bu),(vo(),XAe)),n.Hc(nW)&&(fi(t,(uo(),y0),(vo(),eLe)),fi(t,vg,JAe),fi(t,bu,ZAe)),qe(Q(e,lW))!==qe((zE(),VL))&&qe(Q(e,bp))!==qe((ip(),JB))&&yl(t,(uo(),mc),(vo(),VAe)),Rt(Bt(Q(e,BMe)))&&fi(t,(uo(),bu),(vo(),HAe)),Rt(Bt(Q(e,ede)))&&fi(t,(uo(),bu),(vo(),tLe)),VTn(e)&&(qe(Q(e,p4))===qe(A2)?r=l(Q(e,TB),299):r=l(Q(e,Z1e),299),o=r==(vE(),R1e)?(vo(),QAe):(vo(),iLe),fi(t,(uo(),_u),o)),l(Q(e,lDe),388).g){case 1:fi(t,(uo(),_u),(vo(),nLe));break;case 2:yl(fi(fi(t,(uo(),bu),(vo(),SAe)),_u,_Ae),mc,AAe)}return qe(Q(e,yg))!==qe((Ed(),E2))&&fi(t,(uo(),bu),(vo(),rLe)),t}function dwt(e,t,n){var r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me;if(Hu(e.a,t)){if(W0(l(cr(e.a,t),49),n))return 1}else ki(e.a,t,new Ks);if(Hu(e.a,n)){if(W0(l(cr(e.a,n),49),t))return-1}else ki(e.a,n,new Ks);if(Hu(e.e,t)){if(W0(l(cr(e.e,t),49),n))return-1}else ki(e.e,t,new Ks);if(Hu(e.e,n)){if(W0(l(cr(e.a,n),49),t))return 1}else ki(e.e,n,new Ks);if(e.c==(Ed(),yde)||!ns(t,(ft(),Ki))||!ns(n,(ft(),Ki))){for(L=null,E=new G(t.j);E.af?WE(e,t,n):WE(e,n,t),af?1:0}return r=l(Q(t,(ft(),Ki)),17).a,o=l(Q(n,Ki),17).a,r>o?WE(e,t,n):WE(e,n,t),ro?1:0}function Kw(e,t,n){var r,a,o,f,g,w,E,C,L,B,z,V,J,te;if(n==null)return null;if(e.a!=t.jk())throw ue(new Yn(yT+t.xe()+t3));if(De(t,469)){if(te=kSn(l(t,685),n),!te)throw ue(new Yn(zfe+n+"' is not a valid enumerator of '"+t.xe()+"'"));return te}switch(o2((El(),io),t).Nl()){case 2:{n=Tu(n,!1);break}case 3:{n=Tu(n,!0);break}}if(r=o2(io,t).Jl(),r)return r.jk().wi().ti(r,n);if(B=o2(io,t).Ll(),B){for(te=new bt,E=Tce(n),C=0,L=E.length;C1)for(V=new q8((!e.a&&(e.a=new nt(cs,e,6,6)),e.a));V.e!=V.i.gc();)jA(V);for(f=l(Oe((!e.a&&(e.a=new nt(cs,e,6,6)),e.a),0),166),te=oi,oi>Ze+$e?te=Ze+$e:oiot+J?fe=ot+J:wsZe-$e&&teot-J&&feoi+ur?cn=oi+ur:Zews+St?an=ws+St:otoi-ur&&cnws-St&&ann&&(B=n-1),z=P2+Jl(t,24)*MP*L-L/2,z<0?z=1:z>r&&(z=r-1),a=(rb(),w=new AS,w),dV(a,B),fV(a,z),qr((!f.a&&(f.a=new Ys(qh,f,5)),f.a),a)}function gwt(e){sw(e,new Xm(nw(Zv(tw(ew(new x1,th),"ELK Rectangle Packing"),"Algorithm for packing of unconnected boxes, i.e. graphs without edges. The given order of the boxes is always preserved and the main reading direction of the boxes is left to right. The algorithm is divided into two phases. One phase approximates the width in which the rectangles can be placed. The next phase places the rectangles in rows using the previously calculated width as bounding width and bundles rectangles with a similar height in blocks. A compaction step reduces the size of the drawing. Finally, the rectangles are expanded to fill their bounding box and eliminate empty unused spaces."),new c8))),gt(e,th,Ox,1.3),gt(e,th,hT,(Hn(),!1)),gt(e,th,Xw,iOe),gt(e,th,Jy,15),gt(e,th,SG,It(DCt)),gt(e,th,x6,It(NCt)),gt(e,th,Px,It(BCt)),gt(e,th,Nx,It(FCt)),gt(e,th,fT,It(OCt)),gt(e,th,fL,It(lge)),gt(e,th,dT,It(RCt)),gt(e,th,jCe,It(cOe)),gt(e,th,$Ce,It(oOe)),gt(e,th,RCe,It(fge)),gt(e,th,FCe,It(uOe)),gt(e,th,zCe,It(rOe)),gt(e,th,qCe,It(hge)),gt(e,th,HCe,It(nOe)),gt(e,th,VCe,It(aOe)),gt(e,th,hL,It(tOe)),gt(e,th,AG,It(ICt)),gt(e,th,PCe,It(jB)),gt(e,th,NCe,It(eOe)),gt(e,th,BCe,It($B)),gt(e,th,OCe,It(sOe))}function Dle(e,t){ble();var n,r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e,Ze,ot,St,cn,an,Bn,jn,ur,oi;if(cn=e.e,V=e.d,a=e.a,cn==0)switch(t){case 0:return"0";case 1:return sT;case 2:return"0.00";case 3:return"0.000";case 4:return"0.0000";case 5:return"0.00000";case 6:return"0.000000";default:return ot=new tb,t<0?ot.a+="0E+":ot.a+="0E",ot.a+=-t,ot.a}if(Me=V*10+1+7,$e=We(kf,Ad,28,Me+1,15,1),n=Me,V==1)if(g=a[0],g<0){oi=va(g,Vo);do J=oi,oi=KN(oi,10),$e[--n]=48+Yr(Df(J,mo(oi,10)))&Zs;while(iu(oi,0)!=0)}else{oi=g;do J=oi,oi=oi/10|0,$e[--n]=48+(J-oi*10)&Zs;while(oi!=0)}else{Bn=We(Vr,di,28,V,15,1),ur=V,pu(a,0,Bn,0,ur);e:for(;;){for(St=0,E=ur-1;E>=0;E--)jn=bo(l0(St,32),va(Bn[E],Vo)),fe=yxn(jn),Bn[E]=Yr(fe),St=Yr(bw(fe,32));Te=Yr(St),te=n;do $e[--n]=48+Te%10&Zs;while((Te=Te/10|0)!=0&&n!=0);for(r=9-te+n,w=0;w0;w++)$e[--n]=48;for(L=ur-1;Bn[L]==0;L--)if(L==0)break e;ur=L+1}for(;$e[n]==48;)++n}if(z=cn<0,f=Me-n-t-1,t==0)return z&&($e[--n]=45),If($e,n,Me-n);if(t>0&&f>=-6){if(f>=0){for(C=n+f,B=Me-1;B>=C;B--)$e[B+1]=$e[B];return $e[++C]=46,z&&($e[--n]=45),If($e,n,Me-n+1)}for(L=2;L<-f+1;L++)$e[--n]=48;return $e[--n]=46,$e[--n]=48,z&&($e[--n]=45),If($e,n,Me-n)}return an=n+1,o=Me,Ze=new S5,z&&(Ze.a+="-"),o-an>=1?(hb(Ze,$e[n]),Ze.a+=".",Ze.a+=If($e,n+1,Me-n-1)):Ze.a+=If($e,n,Me-n),Ze.a+="E",f>0&&(Ze.a+="+"),Ze.a+=""+f,Ze.a}function pwt(e,t){var n,r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e,Ze,ot;switch(e.c=t,e.g=new Pr,n=(aw(),new Jv(e.c)),r=new e_(n),S8e(r),Me=ei(at(e.c,(YN(),AOe))),w=l(at(e.c,kge),324),Ze=l(at(e.c,Ege),437),f=l(at(e.c,COe),490),$e=l(at(e.c,xge),438),e.j=ze(Ge(at(e.c,JCt))),g=e.a,w.g){case 0:g=e.a;break;case 1:g=e.b;break;case 2:g=e.i;break;case 3:g=e.e;break;case 4:g=e.f;break;default:throw ue(new Yn(FG+(w.f!=null?w.f:""+w.g)))}if(e.d=new cot(g,Ze,f),rt(e.d,(pE(),jL),Bt(at(e.c,XCt))),e.d.c=Rt(Bt(at(e.c,SOe))),AH(e.c).i==0)return e.d;for(L=new or(AH(e.c));L.e!=L.i.gc();){for(C=l(gr(L),27),z=C.g/2,B=C.f/2,ot=new lt(C.i+z,C.j+B);Hu(e.g,ot);)dw(ot,(b.Math.random()-.5)*Dd,(b.Math.random()-.5)*Dd);J=l(at(C,(pi(),tC)),140),te=new kot(ot,new ef(ot.a-z-e.j/2-J.b,ot.b-B-e.j/2-J.d,C.g+e.j+(J.b+J.c),C.f+e.j+(J.d+J.a))),vt(e.d.i,te),ki(e.g,ot,new ca(te,C))}switch($e.g){case 0:if(Me==null)e.d.d=l(jt(e.d.i,0),68);else for(Te=new G(e.d.i);Te.a0?ur+1:1);for(f=new G(ot.g);f.a0?ur+1:1)}e.c[E]==0?ui(e.e,J):e.a[E]==0&&ui(e.f,J),++E}for(V=-1,z=1,L=new bt,e.d=l(Q(t,(ft(),Xx)),234);Hh>0;){for(;e.e.b!=0;)ws=l(kae(e.e),10),e.b[ws.p]=V--,pke(e,ws),--Hh;for(;e.f.b!=0;)Vl=l(kae(e.f),10),e.b[Vl.p]=z++,pke(e,Vl),--Hh;if(Hh>0){for(B=lo,Te=new G(Me);Te.a=B&&($e>B&&(L.c.length=0,B=$e),$n(L.c,J)));C=e.sg(L),e.b[C.p]=z++,pke(e,C),--Hh}}for(oi=Me.c.length+1,E=0;Ee.b[lc]&&(Uw(r,!0),rt(t,yB,(Hn(),!0)));e.a=null,e.c=null,e.b=null,Ch(e.f),Ch(e.e),n.Vg()}function bwt(e,t,n){var r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e,Ze,ot;for(Ze=l(Oe((!e.a&&(e.a=new nt(cs,e,6,6)),e.a),0),166),C=new bl,$e=new Pr,ot=Cmt(Ze),ju($e.f,Ze,ot),B=new Pr,r=new os,V=rg(Lh(he(le(Fh,1),Rn,20,0,[(!t.d&&(t.d=new Ln(js,t,8,5)),t.d),(!t.e&&(t.e=new Ln(js,t,7,4)),t.e)])));jr(V);){if(z=l(xr(V),74),(!e.a&&(e.a=new nt(cs,e,6,6)),e.a).i!=1)throw ue(new Yn(n4t+(!e.a&&(e.a=new nt(cs,e,6,6)),e.a).i));z!=e&&(te=l(Oe((!z.a&&(z.a=new nt(cs,z,6,6)),z.a),0),166),Cs(r,te,r.c.b,r.c),J=l(hc(zo($e.f,te)),13),J||(J=Cmt(te),ju($e.f,te,J)),L=n?ma(new Eo(l(jt(ot,ot.c.length-1),8)),l(jt(J,J.c.length-1),8)):ma(new Eo((Sn(0,ot.c.length),l(ot.c[0],8))),(Sn(0,J.c.length),l(J.c[0],8))),ju(B.f,te,L))}if(r.b!=0)for(fe=l(jt(ot,n?ot.c.length-1:0),8),E=1;E1&&Cs(C,fe,C.c.b,C.c),Yoe(a)));fe=Te}return C}function mwt(e,t,n){var r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e,Ze,ot,St,cn,an,Bn;for(n.Ug(myt,1),Bn=l(yc(Fi(new bn(null,new kn(t,16)),new one),Pl(new zr,new ht,new Fn,he(le(oc,1),it,108,0,[(Fl(),Ec)]))),15),C=l(yc(Fi(new bn(null,new kn(t,16)),new vXe(t)),Pl(new zr,new ht,new Fn,he(le(oc,1),it,108,0,[Ec]))),15),V=l(yc(Fi(new bn(null,new kn(t,16)),new mXe(t)),Pl(new zr,new ht,new Fn,he(le(oc,1),it,108,0,[Ec]))),15),J=We(PW,IG,40,t.gc(),0,1),f=0;f=0&&an=0&&!J[z]){J[z]=a,C.gd(g),--g;break}if(z=an-B,z=0&&!J[z]){J[z]=a,C.gd(g),--g;break}}for(V.jd(new cne),w=J.length-1;w>=0;w--)!J[w]&&!V.dc()&&(J[w]=l(V.Xb(0),40),V.gd(0));for(E=0;E=0;w--)ui(n,(Sn(w,f.c.length),l(f.c[w],8)));return n}function wwt(e,t,n){var r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e;for(Me=ze(Ge(at(t,(ug(),T4)))),z=ze(Ge(at(t,mM))),B=ze(Ge(at(t,UW))),v7e((!t.a&&(t.a=new nt(Ai,t,10,11)),t.a)),fe=uvt((!t.a&&(t.a=new nt(Ai,t,10,11)),t.a),Me,e.b),te=0;teB&&UN((Sn(B,t.c.length),l(t.c[B],186)),C),C=null;t.c.length>B&&(Sn(B,t.c.length),l(t.c[B],186)).a.c.length==0;)al(t,(Sn(B,t.c.length),t.c[B]));if(!C){--f;continue}if(!Rt(Bt(l(jt(C.b,0),27).of((z1(),$B))))&&tAn(t,V,o,C,te,n,B,r)){J=!0;continue}if(te){if(z=V.b,L=C.f,!Rt(Bt(l(jt(C.b,0),27).of($B)))&&wMn(t,V,o,C,n,B,r,a)){if(J=!0,z=e.j){e.a=-1,e.c=1;return}if(t=co(e.i,e.d++),e.a=t,e.b==1){switch(t){case 92:if(r=10,e.d>=e.j)throw ue(new ri(ai((Jr(),VG))));e.a=co(e.i,e.d++);break;case 45:(e.e&512)==512&&e.d=e.j||co(e.i,e.d)!=63)break;if(++e.d>=e.j)throw ue(new ri(ai((Jr(),e0e))));switch(t=co(e.i,e.d++),t){case 58:r=13;break;case 61:r=14;break;case 33:r=15;break;case 91:r=19;break;case 62:r=18;break;case 60:if(e.d>=e.j)throw ue(new ri(ai((Jr(),e0e))));if(t=co(e.i,e.d++),t==61)r=16;else if(t==33)r=17;else throw ue(new ri(ai((Jr(),L4t))));break;case 35:for(;e.d=e.j)throw ue(new ri(ai((Jr(),VG))));e.a=co(e.i,e.d++);break;default:r=0}e.c=r}function zIn(e,t,n){var r,a,o,f,g,w,E,C,L,B,z,V,J,te;if(n.Ug("Process compaction",1),!!Rt(Bt(Q(t,(Hc(),uIe))))){for(a=l(Q(t,y3),88),z=ze(Ge(Q(t,zde))),gLn(e,t,a),iIn(t,z/2/2),V=t.b,$m(V,new lXe(a)),E=Rr(V,0);E.b!=E.d.c;)if(w=l(Br(E),40),!Rt(Bt(Q(w,(Qi(),Vb))))){if(r=$Sn(w,a),J=PAn(w,t),L=0,B=0,r)switch(te=r.e,a.g){case 2:L=te.a-z-w.f.a,J.e.a-z-w.f.aL&&(L=J.e.a+J.f.a+z),B=L+w.f.a;break;case 4:L=te.b-z-w.f.b,J.e.b-z-w.f.bL&&(L=J.e.b+J.f.b+z),B=L+w.f.b}else if(J)switch(a.g){case 2:L=J.e.a-z-w.f.a,B=L+w.f.a;break;case 1:L=J.e.a+J.f.a+z,B=L+w.f.a;break;case 4:L=J.e.b-z-w.f.b,B=L+w.f.b;break;case 3:L=J.e.b+J.f.b+z,B=L+w.f.b}qe(Q(t,$de))===qe((xA(),OB))?(o=L,f=B,g=kE(Fi(new bn(null,new kn(e.a,16)),new ttt(o,f))),g.a!=null?a==(Js(),uc)||a==vc?w.e.a=L:w.e.b=L:(a==(Js(),uc)||a==wf?g=kE(Fi(Dht(new bn(null,new kn(e.a,16))),new hXe(o))):g=kE(Fi(Dht(new bn(null,new kn(e.a,16))),new fXe(o))),g.a!=null&&(a==uc||a==vc?w.e.a=ze(Ge((mr(g.a!=null),l(g.a,42)).a)):w.e.b=ze(Ge((mr(g.a!=null),l(g.a,42)).a)))),g.a!=null&&(C=gc(e.a,(mr(g.a!=null),g.a),0),C>0&&C!=l(Q(w,$d),17).a&&(rt(w,tIe,(Hn(),!0)),rt(w,$d,pt(C))))):a==(Js(),uc)||a==vc?w.e.a=L:w.e.b=L}n.Vg()}}function ywt(e){var t,n,r,a,o,f,g,w,E;for(e.b=1,Li(e),t=null,e.c==0&&e.a==94?(Li(e),t=(Di(),Di(),new _h(4)),Eu(t,0,TT),g=new _h(4)):g=(Di(),Di(),new _h(4)),a=!0;(E=e.c)!=1;){if(E==0&&e.a==93&&!a){t&&(nL(t,g),g=t);break}if(n=e.a,r=!1,E==10)switch(n){case 100:case 68:case 119:case 87:case 115:case 83:Ky(g,YE(n)),r=!0;break;case 105:case 73:case 99:case 67:n=(Ky(g,YE(n)),-1),n<0&&(r=!0);break;case 112:case 80:if(w=w9e(e,n),!w)throw ue(new ri(ai((Jr(),t0e))));Ky(g,w),r=!0;break;default:n=eke(e)}else if(E==24&&!a){if(t&&(nL(t,g),g=t),o=ywt(e),nL(g,o),e.c!=0||e.a!=93)throw ue(new ri(ai((Jr(),j4t))));break}if(Li(e),!r){if(E==0){if(n==91)throw ue(new ri(ai((Jr(),ESe))));if(n==93)throw ue(new ri(ai((Jr(),TSe))));if(n==45&&!a&&e.a!=93)throw ue(new ri(ai((Jr(),n0e))))}if(e.c!=0||e.a!=45||n==45&&a)Eu(g,n,n);else{if(Li(e),(E=e.c)==1)throw ue(new ri(ai((Jr(),UG))));if(E==0&&e.a==93)Eu(g,n,n),Eu(g,45,45);else{if(E==0&&e.a==93||E==24)throw ue(new ri(ai((Jr(),n0e))));if(f=e.a,E==0){if(f==91)throw ue(new ri(ai((Jr(),ESe))));if(f==93)throw ue(new ri(ai((Jr(),TSe))));if(f==45)throw ue(new ri(ai((Jr(),n0e))))}else E==10&&(f=eke(e));if(Li(e),n>f)throw ue(new ri(ai((Jr(),q4t))));Eu(g,n,f)}}}a=!1}if(e.c==1)throw ue(new ri(ai((Jr(),UG))));return c6(g),eL(g),e.b=0,Li(e),g}function qIn(e,t,n){var r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e,Ze;if(n.Ug("Coffman-Graham Layering",1),t.a.c.length==0){n.Vg();return}for(Ze=l(Q(t,(Nt(),$Me)),17).a,w=0,f=0,B=new G(t.a);B.a=Ze||!B5n(fe,r))&&(r=vat(t,C)),Va(fe,r),o=new hr(dr(ka(fe).a.Kc(),new j));jr(o);)a=l(xr(o),18),!e.a[a.p]&&(J=a.c.i,--e.e[J.p],e.e[J.p]==0&&K8($E(z,J),aT));for(E=C.c.length-1;E>=0;--E)vt(t.b,(Sn(E,C.c.length),l(C.c[E],30)));t.a.c.length=0,n.Vg()}function xwt(e,t){var n,r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e;$e=!1;do for($e=!1,o=t?new br(e.a.b).a.gc()-2:1;t?o>=0:ol(Q(te,Ki),17).a)&&(Me=!1);if(Me){for(w=t?o+1:o-1,g=s6e(e.a,pt(w)),f=!1,Te=!0,r=!1,C=Rr(g,0);C.b!=C.d.c;)E=l(Br(C),10),ns(E,Ki)?E.p!=L.p&&(f=f|(t?l(Q(E,Ki),17).al(Q(L,Ki),17).a),Te=!1):!f&&Te&&E.k==(Zn(),cu)&&(r=!0,t?B=l(xr(new hr(dr(ka(E).a.Kc(),new j))),18).c.i:B=l(xr(new hr(dr(qs(E).a.Kc(),new j))),18).d.i,B==L&&(t?n=l(xr(new hr(dr(qs(E).a.Kc(),new j))),18).d.i:n=l(xr(new hr(dr(ka(E).a.Kc(),new j))),18).c.i,(t?l(dy(e.a,n),17).a-l(dy(e.a,B),17).a:l(dy(e.a,B),17).a-l(dy(e.a,n),17).a)<=2&&(Te=!1)));if(r&&Te&&(t?n=l(xr(new hr(dr(qs(L).a.Kc(),new j))),18).d.i:n=l(xr(new hr(dr(ka(L).a.Kc(),new j))),18).c.i,(t?l(dy(e.a,n),17).a-l(dy(e.a,L),17).a:l(dy(e.a,L),17).a-l(dy(e.a,n),17).a)<=2&&n.k==(Zn(),Ps)&&(Te=!1)),f||Te){for(J=J2t(e,L,t);J.a.gc()!=0;)V=l(J.a.ec().Kc().Pb(),10),J.a.Bc(V)!=null,Ka(J,J2t(e,V,t));--z,$e=!0}}}while($e)}function HIn(e){Wr(e.c,li,he(le(zt,1),dt,2,6,[ho,"http://www.w3.org/2001/XMLSchema#decimal"])),Wr(e.d,li,he(le(zt,1),dt,2,6,[ho,"http://www.w3.org/2001/XMLSchema#integer"])),Wr(e.e,li,he(le(zt,1),dt,2,6,[ho,"http://www.w3.org/2001/XMLSchema#boolean"])),Wr(e.f,li,he(le(zt,1),dt,2,6,[ho,"EBoolean",_i,"EBoolean:Object"])),Wr(e.i,li,he(le(zt,1),dt,2,6,[ho,"http://www.w3.org/2001/XMLSchema#byte"])),Wr(e.g,li,he(le(zt,1),dt,2,6,[ho,"http://www.w3.org/2001/XMLSchema#hexBinary"])),Wr(e.j,li,he(le(zt,1),dt,2,6,[ho,"EByte",_i,"EByte:Object"])),Wr(e.n,li,he(le(zt,1),dt,2,6,[ho,"EChar",_i,"EChar:Object"])),Wr(e.t,li,he(le(zt,1),dt,2,6,[ho,"http://www.w3.org/2001/XMLSchema#double"])),Wr(e.u,li,he(le(zt,1),dt,2,6,[ho,"EDouble",_i,"EDouble:Object"])),Wr(e.F,li,he(le(zt,1),dt,2,6,[ho,"http://www.w3.org/2001/XMLSchema#float"])),Wr(e.G,li,he(le(zt,1),dt,2,6,[ho,"EFloat",_i,"EFloat:Object"])),Wr(e.I,li,he(le(zt,1),dt,2,6,[ho,"http://www.w3.org/2001/XMLSchema#int"])),Wr(e.J,li,he(le(zt,1),dt,2,6,[ho,"EInt",_i,"EInt:Object"])),Wr(e.N,li,he(le(zt,1),dt,2,6,[ho,"http://www.w3.org/2001/XMLSchema#long"])),Wr(e.O,li,he(le(zt,1),dt,2,6,[ho,"ELong",_i,"ELong:Object"])),Wr(e.Z,li,he(le(zt,1),dt,2,6,[ho,"http://www.w3.org/2001/XMLSchema#short"])),Wr(e.$,li,he(le(zt,1),dt,2,6,[ho,"EShort",_i,"EShort:Object"])),Wr(e._,li,he(le(zt,1),dt,2,6,[ho,"http://www.w3.org/2001/XMLSchema#string"]))}function VIn(e,t,n,r,a,o,f){var g,w,E,C,L,B,z,V;return B=l(r.a,17).a,z=l(r.b,17).a,L=e.b,V=e.c,g=0,C=0,t==(Js(),uc)||t==vc?(C=fO(h1t(xy(fc(new bn(null,new kn(n.b,16)),new lne),new Yte))),L.e.b+L.f.b/2>C?(E=++z,g=ze(Ge(fh(vy(fc(new bn(null,new kn(n.b,16)),new itt(a,E)),new a$))))):(w=++B,g=ze(Ge(fh(Y8(fc(new bn(null,new kn(n.b,16)),new stt(a,w)),new Xte)))))):(C=fO(h1t(xy(fc(new bn(null,new kn(n.b,16)),new Zte),new s$))),L.e.a+L.f.a/2>C?(E=++z,g=ze(Ge(fh(vy(fc(new bn(null,new kn(n.b,16)),new ntt(a,E)),new Qte))))):(w=++B,g=ze(Ge(fh(Y8(fc(new bn(null,new kn(n.b,16)),new rtt(a,w)),new bI)))))),t==uc?(ko(e.a,new lt(ze(Ge(Q(L,(Qi(),c1))))-a,g)),ko(e.a,new lt(V.e.a+V.f.a+a+o,g)),ko(e.a,new lt(V.e.a+V.f.a+a+o,V.e.b+V.f.b/2)),ko(e.a,new lt(V.e.a+V.f.a,V.e.b+V.f.b/2))):t==vc?(ko(e.a,new lt(ze(Ge(Q(L,(Qi(),k0))))+a,L.e.b+L.f.b/2)),ko(e.a,new lt(L.e.a+L.f.a+a,g)),ko(e.a,new lt(V.e.a-a-o,g)),ko(e.a,new lt(V.e.a-a-o,V.e.b+V.f.b/2)),ko(e.a,new lt(V.e.a,V.e.b+V.f.b/2))):t==wf?(ko(e.a,new lt(g,ze(Ge(Q(L,(Qi(),c1))))-a)),ko(e.a,new lt(g,V.e.b+V.f.b+a+o)),ko(e.a,new lt(V.e.a+V.f.a/2,V.e.b+V.f.b+a+o)),ko(e.a,new lt(V.e.a+V.f.a/2,V.e.b+V.f.b+a))):(e.a.b==0||(l(o0(e.a),8).b=ze(Ge(Q(L,(Qi(),k0))))+a*l(f.b,17).a),ko(e.a,new lt(g,ze(Ge(Q(L,(Qi(),k0))))+a*l(f.b,17).a)),ko(e.a,new lt(g,V.e.b-a*l(f.a,17).a-o))),new ca(pt(B),pt(z))}function UIn(e){var t,n,r,a,o,f,g,w,E,C,L,B,z;if(f=!0,L=null,r=null,a=null,t=!1,z=P_t,E=null,o=null,g=0,w=Zce(e,g,TPe,CPe),w=0&&vn(e.substr(g,2),"//")?(g+=2,w=Zce(e,g,$M,zM),r=(Ga(g,w,e.length),e.substr(g,w-g)),g=w):L!=null&&(g==e.length||(Xn(g,e.length),e.charCodeAt(g)!=47))&&(f=!1,w=Lye(e,cl(35),g),w==-1&&(w=e.length),r=(Ga(g,w,e.length),e.substr(g,w-g)),g=w);if(!n&&g0&&co(C,C.length-1)==58&&(a=C,g=w)),gWue(o))&&(L=o);for(!L&&(L=(Sn(0,te.c.length),l(te.c[0],185))),J=new G(t.b);J.aL&&(jn=0,ur+=C+St,C=0),hmt(Ze,f,jn,ur),t=b.Math.max(t,jn+ot.a),C=b.Math.max(C,ot.b),jn+=ot.a+St;for($e=new Pr,n=new Pr,an=new G(e);an.a=-1900?1:0,n>=4?hi(e,he(le(zt,1),dt,2,6,[Rwt,jwt])[g]):hi(e,he(le(zt,1),dt,2,6,["BC","AD"])[g]);break;case 121:h6n(e,n,r);break;case 77:M_n(e,n,r);break;case 107:w=a.q.getHours(),w==0?ag(e,24,n):ag(e,w,n);break;case 83:HTn(e,n,a);break;case 69:C=r.q.getDay(),n==5?hi(e,he(le(zt,1),dt,2,6,["S","M","T","W","T","F","S"])[C]):n==4?hi(e,he(le(zt,1),dt,2,6,[Qle,Jle,Zle,ehe,the,nhe,rhe])[C]):hi(e,he(le(zt,1),dt,2,6,["Sun","Mon","Tue","Wed","Thu","Fri","Sat"])[C]);break;case 97:a.q.getHours()>=12&&a.q.getHours()<24?hi(e,he(le(zt,1),dt,2,6,["AM","PM"])[1]):hi(e,he(le(zt,1),dt,2,6,["AM","PM"])[0]);break;case 104:L=a.q.getHours()%12,L==0?ag(e,12,n):ag(e,L,n);break;case 75:B=a.q.getHours()%12,ag(e,B,n);break;case 72:z=a.q.getHours(),ag(e,z,n);break;case 99:V=r.q.getDay(),n==5?hi(e,he(le(zt,1),dt,2,6,["S","M","T","W","T","F","S"])[V]):n==4?hi(e,he(le(zt,1),dt,2,6,[Qle,Jle,Zle,ehe,the,nhe,rhe])[V]):n==3?hi(e,he(le(zt,1),dt,2,6,["Sun","Mon","Tue","Wed","Thu","Fri","Sat"])[V]):ag(e,V,1);break;case 76:J=r.q.getMonth(),n==5?hi(e,he(le(zt,1),dt,2,6,["J","F","M","A","M","J","J","A","S","O","N","D"])[J]):n==4?hi(e,he(le(zt,1),dt,2,6,[$le,zle,qle,Hle,_x,Vle,Ule,Gle,Kle,Wle,Yle,Xle])[J]):n==3?hi(e,he(le(zt,1),dt,2,6,["Jan","Feb","Mar","Apr",_x,"Jun","Jul","Aug","Sep","Oct","Nov","Dec"])[J]):ag(e,J+1,n);break;case 81:te=r.q.getMonth()/3|0,n<4?hi(e,he(le(zt,1),dt,2,6,["Q1","Q2","Q3","Q4"])[te]):hi(e,he(le(zt,1),dt,2,6,["1st quarter","2nd quarter","3rd quarter","4th quarter"])[te]);break;case 100:fe=r.q.getDate(),ag(e,fe,n);break;case 109:E=a.q.getMinutes(),ag(e,E,n);break;case 115:f=a.q.getSeconds(),ag(e,f,n);break;case 122:n<4?hi(e,o.c[0]):hi(e,o.c[1]);break;case 118:hi(e,o.b);break;case 90:n<3?hi(e,Bkn(o)):n==3?hi(e,zkn(o)):hi(e,qkn(o.a));break;default:return!1}return!0}function Wke(e,t,n,r){var a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e,Ze,ot,St,cn,an,Bn,jn,ur,oi;if(emt(t),w=l(Oe((!t.b&&(t.b=new Ln(_r,t,4,7)),t.b),0),84),C=l(Oe((!t.c&&(t.c=new Ln(_r,t,5,8)),t.c),0),84),g=bc(w),E=bc(C),f=(!t.a&&(t.a=new nt(cs,t,6,6)),t.a).i==0?null:l(Oe((!t.a&&(t.a=new nt(cs,t,6,6)),t.a),0),166),St=l(cr(e.a,g),10),jn=l(cr(e.a,E),10),cn=null,ur=null,De(w,193)&&(ot=l(cr(e.a,w),305),De(ot,12)?cn=l(ot,12):De(ot,10)&&(St=l(ot,10),cn=l(jt(St.j,0),12))),De(C,193)&&(Bn=l(cr(e.a,C),305),De(Bn,12)?ur=l(Bn,12):De(Bn,10)&&(jn=l(Bn,10),ur=l(jt(jn.j,0),12))),!St||!jn)throw ue(new I8("The source or the target of edge "+t+" could not be found. This usually happens when an edge connects a node laid out by ELK Layered to a node in another level of hierarchy laid out by either another instance of ELK Layered or another layout algorithm alltogether. The former can be solved by setting the hierarchyHandling option to INCLUDE_CHILDREN."));for(J=new Tw,pc(J,t),rt(J,(ft(),zi),t),rt(J,(Nt(),cc),null),z=l(Q(r,Lu),21),St==jn&&z.Fc((Ho(),GL)),cn||(Ze=(qo(),zu),an=null,f&&P5(l(Q(St,Ms),101))&&(an=new lt(f.j,f.k),Vct(an,WO(t)),vut(an,n),Ly(E,g)&&(Ze=$l,Oi(an,St.n))),cn=tvt(St,an,Ze,r)),ur||(Ze=(qo(),$l),oi=null,f&&P5(l(Q(jn,Ms),101))&&(oi=new lt(f.b,f.c),Vct(oi,WO(t)),vut(oi,n)),ur=tvt(jn,oi,Ze,eo(jn))),po(J,cn),Fa(J,ur),(cn.e.c.length>1||cn.g.c.length>1||ur.e.c.length>1||ur.g.c.length>1)&&z.Fc((Ho(),UL)),B=new or((!t.n&&(t.n=new nt(ec,t,1,7)),t.n));B.e!=B.i.gc();)if(L=l(gr(B),135),!Rt(Bt(at(L,mv)))&&L.a)switch(te=Oce(L),vt(J.b,te),l(Q(te,jd),278).g){case 1:case 2:z.Fc((Ho(),jT));break;case 0:z.Fc((Ho(),RT)),rt(te,jd,(F1(),nC))}if(o=l(Q(r,JL),322),fe=l(Q(r,yW),323),a=o==(dA(),mB)||fe==(OA(),vde),f&&(!f.a&&(f.a=new Ys(qh,f,5)),f.a).i!=0&&a){for(Te=QN(f),V=new bl,$e=Rr(Te,0);$e.b!=$e.d.c;)Me=l(Br($e),8),ui(V,new Eo(Me));rt(J,qLe,V)}return J}function YIn(e,t,n,r){var a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e,Ze,ot,St,cn,an,Bn,jn,ur,oi,ws;for(an=0,Bn=0,St=new Pr,Ze=l(fh(vy(fc(new bn(null,new kn(e.b,16)),new Jte),new sne)),17).a+1,cn=We(Vr,di,28,Ze,15,1),te=We(Vr,di,28,Ze,15,1),J=0;J1)for(g=ur+1;gE.b.e.b*(1-fe)+E.c.e.b*fe));V++);if(ot.gc()>0&&(oi=E.a.b==0?Ja(E.b.e):l(o0(E.a),8),Me=Oi(Ja(l(ot.Xb(ot.gc()-1),40).e),l(ot.Xb(ot.gc()-1),40).f),B=Oi(Ja(l(ot.Xb(0),40).e),l(ot.Xb(0),40).f),V>=ot.gc()-1&&oi.b>Me.b&&E.c.e.b>Me.b||V<=0&&oi.bE.b.e.a*(1-fe)+E.c.e.a*fe));V++);if(ot.gc()>0&&(oi=E.a.b==0?Ja(E.b.e):l(o0(E.a),8),Me=Oi(Ja(l(ot.Xb(ot.gc()-1),40).e),l(ot.Xb(ot.gc()-1),40).f),B=Oi(Ja(l(ot.Xb(0),40).e),l(ot.Xb(0),40).f),V>=ot.gc()-1&&oi.a>Me.a&&E.c.e.a>Me.a||V<=0&&oi.a=ze(Ge(Q(e,(Qi(),iIe))))&&++Bn):(z.f&&z.d.e.a<=ze(Ge(Q(e,(Qi(),Bde))))&&++an,z.g&&z.c.e.a+z.c.f.a>=ze(Ge(Q(e,(Qi(),rIe))))&&++Bn)}else $e==0?b9e(E):$e<0&&(++cn[ur],++te[ws],jn=VIn(E,t,e,new ca(pt(an),pt(Bn)),n,r,new ca(pt(te[ws]),pt(cn[ur]))),an=l(jn.a,17).a,Bn=l(jn.b,17).a)}function XIn(e,t,n){var r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te;if(r=t,w=n,e.b&&r.j==(Ct(),er)&&w.j==(Ct(),er)&&(Te=r,r=w,w=Te),Hu(e.a,r)){if(W0(l(cr(e.a,r),49),w))return 1}else ki(e.a,r,new Ks);if(Hu(e.a,w)){if(W0(l(cr(e.a,w),49),r))return-1}else ki(e.a,w,new Ks);if(Hu(e.d,r)){if(W0(l(cr(e.d,r),49),w))return-1}else ki(e.d,r,new Ks);if(Hu(e.d,w)){if(W0(l(cr(e.a,w),49),r))return 1}else ki(e.d,w,new Ks);if(r.j!=w.j)return fe=Rln(r.j,w.j),fe==-1?df(e,w,r):df(e,r,w),fe;if(r.e.c.length!=0&&w.e.c.length!=0){if(e.b&&(fe=j0t(r,w),fe!=0))return fe==-1?df(e,w,r):fe==1&&df(e,r,w),fe;if(o=l(jt(r.e,0),18).c.i,C=l(jt(w.e,0),18).c.i,o==C)return a=l(Q(l(jt(r.e,0),18),(ft(),Ki)),17).a,E=l(Q(l(jt(w.e,0),18),Ki),17).a,a>E?df(e,r,w):df(e,w,r),aE?1:0;for(V=e.c,J=0,te=V.length;JE?df(e,r,w):df(e,w,r),aE?1:0):e.b&&(fe=j0t(r,w),fe!=0)?(fe==-1?df(e,w,r):fe==1&&df(e,r,w),fe):(f=0,L=0,ns(l(jt(r.g,0),18),Ki)&&(f=l(Q(l(jt(r.g,0),18),Ki),17).a),ns(l(jt(w.g,0),18),Ki)&&(L=l(Q(l(jt(r.g,0),18),Ki),17).a),g&&g==B?Rt(Bt(Q(l(jt(r.g,0),18),W1)))&&!Rt(Bt(Q(l(jt(w.g,0),18),W1)))?(df(e,r,w),1):!Rt(Bt(Q(l(jt(r.g,0),18),W1)))&&Rt(Bt(Q(l(jt(w.g,0),18),W1)))?(df(e,w,r),-1):(f>L?df(e,r,w):df(e,w,r),fL?1:0):(e.f&&(e.f._b(g)&&(f=l(e.f.xc(g),17).a),e.f._b(B)&&(L=l(e.f.xc(B),17).a)),f>L?df(e,r,w):df(e,w,r),fL?1:0))):r.e.c.length!=0&&w.g.c.length!=0?(df(e,r,w),1):r.g.c.length!=0&&w.e.c.length!=0?(df(e,w,r),-1):ns(r,(ft(),Ki))&&ns(w,Ki)?(a=l(Q(r,Ki),17).a,E=l(Q(w,Ki),17).a,a>E?df(e,r,w):df(e,w,r),aE?1:0):(df(e,w,r),-1)}function QIn(e){e.gb||(e.gb=!0,e.b=qc(e,0),Ss(e.b,18),is(e.b,19),e.a=qc(e,1),Ss(e.a,1),is(e.a,2),is(e.a,3),is(e.a,4),is(e.a,5),e.o=qc(e,2),Ss(e.o,8),Ss(e.o,9),is(e.o,10),is(e.o,11),is(e.o,12),is(e.o,13),is(e.o,14),is(e.o,15),is(e.o,16),is(e.o,17),is(e.o,18),is(e.o,19),is(e.o,20),is(e.o,21),is(e.o,22),is(e.o,23),sc(e.o),sc(e.o),sc(e.o),sc(e.o),sc(e.o),sc(e.o),sc(e.o),sc(e.o),sc(e.o),sc(e.o),e.p=qc(e,3),Ss(e.p,2),Ss(e.p,3),Ss(e.p,4),Ss(e.p,5),is(e.p,6),is(e.p,7),sc(e.p),sc(e.p),e.q=qc(e,4),Ss(e.q,8),e.v=qc(e,5),is(e.v,9),sc(e.v),sc(e.v),sc(e.v),e.w=qc(e,6),Ss(e.w,2),Ss(e.w,3),Ss(e.w,4),is(e.w,5),e.B=qc(e,7),is(e.B,1),sc(e.B),sc(e.B),sc(e.B),e.Q=qc(e,8),is(e.Q,0),sc(e.Q),e.R=qc(e,9),Ss(e.R,1),e.S=qc(e,10),sc(e.S),sc(e.S),sc(e.S),sc(e.S),sc(e.S),sc(e.S),sc(e.S),sc(e.S),sc(e.S),sc(e.S),sc(e.S),sc(e.S),sc(e.S),sc(e.S),sc(e.S),e.T=qc(e,11),is(e.T,10),is(e.T,11),is(e.T,12),is(e.T,13),is(e.T,14),sc(e.T),sc(e.T),e.U=qc(e,12),Ss(e.U,2),Ss(e.U,3),is(e.U,4),is(e.U,5),is(e.U,6),is(e.U,7),sc(e.U),e.V=qc(e,13),is(e.V,10),e.W=qc(e,14),Ss(e.W,18),Ss(e.W,19),Ss(e.W,20),is(e.W,21),is(e.W,22),is(e.W,23),e.bb=qc(e,15),Ss(e.bb,10),Ss(e.bb,11),Ss(e.bb,12),Ss(e.bb,13),Ss(e.bb,14),Ss(e.bb,15),Ss(e.bb,16),is(e.bb,17),sc(e.bb),sc(e.bb),e.eb=qc(e,16),Ss(e.eb,2),Ss(e.eb,3),Ss(e.eb,4),Ss(e.eb,5),Ss(e.eb,6),Ss(e.eb,7),is(e.eb,8),is(e.eb,9),e.ab=qc(e,17),Ss(e.ab,0),Ss(e.ab,1),e.H=qc(e,18),is(e.H,0),is(e.H,1),is(e.H,2),is(e.H,3),is(e.H,4),is(e.H,5),sc(e.H),e.db=qc(e,19),is(e.db,2),e.c=Ti(e,20),e.d=Ti(e,21),e.e=Ti(e,22),e.f=Ti(e,23),e.i=Ti(e,24),e.g=Ti(e,25),e.j=Ti(e,26),e.k=Ti(e,27),e.n=Ti(e,28),e.r=Ti(e,29),e.s=Ti(e,30),e.t=Ti(e,31),e.u=Ti(e,32),e.fb=Ti(e,33),e.A=Ti(e,34),e.C=Ti(e,35),e.D=Ti(e,36),e.F=Ti(e,37),e.G=Ti(e,38),e.I=Ti(e,39),e.J=Ti(e,40),e.L=Ti(e,41),e.M=Ti(e,42),e.N=Ti(e,43),e.O=Ti(e,44),e.P=Ti(e,45),e.X=Ti(e,46),e.Y=Ti(e,47),e.Z=Ti(e,48),e.$=Ti(e,49),e._=Ti(e,50),e.cb=Ti(e,51),e.K=Ti(e,52))}function JIn(e,t,n){var r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e,Ze,ot,St,cn,an,Bn,jn,ur;for(f=new os,ot=l(Q(n,(Nt(),Rh)),88),J=0,Ka(f,(!t.a&&(t.a=new nt(Ai,t,10,11)),t.a));f.b!=0;)C=l(f.b==0?null:(mr(f.b!=0),af(f,f.a.a)),27),E=ds(C),(qe(at(E,yg))!==qe((Ed(),E2))||qe(at(E,dv))===qe((l2(),BT))||qe(at(E,dv))===qe((l2(),PT))||Rt(Bt(at(E,f3)))||qe(at(E,g4))!==qe((Km(),c4))||qe(at(E,zb))===qe((Nf(),v3))||qe(at(E,zb))===qe((Nf(),x4))||qe(at(E,pv))===qe((p2(),WT))||qe(at(E,pv))===qe((p2(),YT)))&&!Rt(Bt(at(C,fW)))&&Hi(C,(ft(),Ki),pt(J++)),fe=!Rt(Bt(at(C,mv))),fe&&(B=(!C.a&&(C.a=new nt(Ai,C,10,11)),C.a).i!=0,V=_xn(C),z=qe(at(C,p4))===qe((rp(),A2)),ur=!P1(C,(pi(),eC))||Sut(ei(at(C,eC))),$e=null,ur&&z&&(B||V)&&($e=Pmt(C),rt($e,Rh,ot),ns($e,CB)&&NJe(new D8e(ze(Ge(Q($e,CB)))),$e),l(at(C,bv),181).gc()!=0&&(L=$e,Is(new bn(null,(!C.c&&(C.c=new nt(Hl,C,9,9)),new kn(C.c,16))),new zWe(L)),_bt(C,$e))),St=n,cn=l(cr(e.a,ds(C)),10),cn&&(St=cn.e),Me=cwt(e,C,St),$e&&(Me.e=$e,$e.e=Me,Ka(f,(!C.a&&(C.a=new nt(Ai,C,10,11)),C.a))));for(J=0,Cs(f,t,f.c.b,f.c);f.b!=0;){for(o=l(f.b==0?null:(mr(f.b!=0),af(f,f.a.a)),27),w=new or((!o.b&&(o.b=new nt(js,o,12,3)),o.b));w.e!=w.i.gc();)g=l(gr(w),74),emt(g),(qe(at(t,yg))!==qe((Ed(),E2))||qe(at(t,dv))===qe((l2(),BT))||qe(at(t,dv))===qe((l2(),PT))||Rt(Bt(at(t,f3)))||qe(at(t,g4))!==qe((Km(),c4))||qe(at(t,zb))===qe((Nf(),v3))||qe(at(t,zb))===qe((Nf(),x4))||qe(at(t,pv))===qe((p2(),WT))||qe(at(t,pv))===qe((p2(),YT)))&&Hi(g,(ft(),Ki),pt(J++)),Bn=bc(l(Oe((!g.b&&(g.b=new Ln(_r,g,4,7)),g.b),0),84)),jn=bc(l(Oe((!g.c&&(g.c=new Ln(_r,g,5,8)),g.c),0),84)),!(Rt(Bt(at(g,mv)))||Rt(Bt(at(Bn,mv)))||Rt(Bt(at(jn,mv))))&&(te=qw(g)&&Rt(Bt(at(Bn,b4)))&&Rt(Bt(at(g,gv))),Ze=o,te||Ly(jn,Bn)?Ze=Bn:Ly(Bn,jn)&&(Ze=jn),St=n,cn=l(cr(e.a,Ze),10),cn&&(St=cn.e),Te=Wke(e,g,Ze,St),rt(Te,(ft(),RLe),JCn(e,g,t,n)));if(z=qe(at(o,p4))===qe((rp(),A2)),z)for(a=new or((!o.a&&(o.a=new nt(Ai,o,10,11)),o.a));a.e!=a.i.gc();)r=l(gr(a),27),ur=!P1(r,(pi(),eC))||Sut(ei(at(r,eC))),an=qe(at(r,p4))===qe(A2),ur&&an&&Cs(f,r,f.c.b,f.c)}}function ft(){ft=U;var e,t;zi=new Ui(NEe),RLe=new Ui("coordinateOrigin"),K1e=new Ui("processors"),FLe=new vs("compoundNode",(Hn(),!1)),xB=new vs("insideConnections",!1),qLe=new Ui("originalBendpoints"),HLe=new Ui("originalDummyNodePosition"),VLe=new Ui("originalLabelEdge"),WL=new Ui("representedLabels"),KL=new Ui("endLabels"),Kx=new Ui("endLabel.origin"),Yx=new vs("labelSide",(Ih(),eF)),R6=new vs("maxEdgeThickness",0),W1=new vs("reversed",!1),Xx=new Ui(C3t),o1=new vs("longEdgeSource",null),$f=new vs("longEdgeTarget",null),f4=new vs("longEdgeHasLabelDummies",!1),kB=new vs("longEdgeBeforeLabelDummy",!1),sW=new vs("edgeConstraint",(Vm(),M1e)),u3=new Ui("inLayerLayoutUnit"),hv=new vs("inLayerConstraint",(ep(),wB)),Wx=new vs("inLayerSuccessorConstraint",new bt),zLe=new vs("inLayerSuccessorConstraintBetweenNonDummies",!1),jl=new Ui("portDummy"),iW=new vs("crossingHint",pt(0)),Lu=new vs("graphProperties",(t=l(K0(F1e),9),new Zh(t,l(c0(t,t.length),9),0))),Wc=new vs("externalPortSide",(Ct(),Pc)),$Le=new vs("externalPortSize",new qa),q1e=new Ui("externalPortReplacedDummies"),aW=new Ui("externalPortReplacedDummy"),pp=new vs("externalPortConnections",(e=l(K0(Oo),9),new Zh(e,l(c0(e,e.length),9),0))),l3=new vs(b3t,0),BLe=new Ui("barycenterAssociates"),Qx=new Ui("TopSideComments"),Gx=new Ui("BottomSideComments"),rW=new Ui("CommentConnectionPort"),V1e=new vs("inputCollect",!1),G1e=new vs("outputCollect",!1),yB=new vs("cyclic",!1),jLe=new Ui("crossHierarchyMap"),Y1e=new Ui("targetOffset"),new vs("splineLabelSize",new qa),$6=new Ui("spacings"),oW=new vs("partitionConstraint",!1),c3=new Ui("breakingPoint.info"),KLe=new Ui("splines.survivingEdge"),fv=new Ui("splines.route.start"),z6=new Ui("splines.edgeChain"),GLe=new Ui("originalPortConstraints"),h3=new Ui("selfLoopHolder"),zT=new Ui("splines.nsPortY"),Ki=new Ui("modelOrder"),U1e=new Ui("longEdgeTargetNode"),jb=new vs(Q3t,!1),j6=new vs(Q3t,!1),H1e=new Ui("layerConstraints.hiddenNodes"),ULe=new Ui("layerConstraints.opposidePort"),W1e=new Ui("targetNode.modelOrder")}function ZIn(e,t,n,r){var a,o,f,g,w,E,C,L,B,z,V;for(L=Rr(e.b,0);L.b!=L.d.c;)if(C=l(Br(L),40),!vn(C.c,DG))for(o=l(yc(new bn(null,new kn(cEn(C,e),16)),Pl(new zr,new ht,new Fn,he(le(oc,1),it,108,0,[(Fl(),Ec)]))),15),t==(Js(),uc)||t==vc?o.jd(new nne):o.jd(new o$),V=o.gc(),a=0;a0&&(g=l(o0(l(o.Xb(a),65).a),8).a,B=C.e.a+C.f.a/2,w=l(o0(l(o.Xb(a),65).a),8).b,z=C.e.b+C.f.b/2,r>0&&b.Math.abs(w-z)/(b.Math.abs(g-B)/40)>50&&(z>w?ko(l(o.Xb(a),65).a,new lt(C.e.a+C.f.a+r/5.3,C.e.b+C.f.b*f-r/2)):ko(l(o.Xb(a),65).a,new lt(C.e.a+C.f.a+r/5.3,C.e.b+C.f.b*f+r/2)))),ko(l(o.Xb(a),65).a,new lt(C.e.a+C.f.a,C.e.b+C.f.b*f))):t==vc?(E=ze(Ge(Q(C,(Qi(),c1)))),C.e.a-r>E?ko(l(o.Xb(a),65).a,new lt(E-n,C.e.b+C.f.b*f)):l(o.Xb(a),65).a.b>0&&(g=l(o0(l(o.Xb(a),65).a),8).a,B=C.e.a+C.f.a/2,w=l(o0(l(o.Xb(a),65).a),8).b,z=C.e.b+C.f.b/2,r>0&&b.Math.abs(w-z)/(b.Math.abs(g-B)/40)>50&&(z>w?ko(l(o.Xb(a),65).a,new lt(C.e.a-r/5.3,C.e.b+C.f.b*f-r/2)):ko(l(o.Xb(a),65).a,new lt(C.e.a-r/5.3,C.e.b+C.f.b*f+r/2)))),ko(l(o.Xb(a),65).a,new lt(C.e.a,C.e.b+C.f.b*f))):t==wf?(E=ze(Ge(Q(C,(Qi(),k0)))),C.e.b+C.f.b+r0&&(g=l(o0(l(o.Xb(a),65).a),8).a,B=C.e.a+C.f.a/2,w=l(o0(l(o.Xb(a),65).a),8).b,z=C.e.b+C.f.b/2,r>0&&b.Math.abs(g-B)/(b.Math.abs(w-z)/40)>50&&(B>g?ko(l(o.Xb(a),65).a,new lt(C.e.a+C.f.a*f-r/2,C.e.b+r/5.3+C.f.b)):ko(l(o.Xb(a),65).a,new lt(C.e.a+C.f.a*f+r/2,C.e.b+r/5.3+C.f.b)))),ko(l(o.Xb(a),65).a,new lt(C.e.a+C.f.a*f,C.e.b+C.f.b))):(E=ze(Ge(Q(C,(Qi(),c1)))),C0t(l(o.Xb(a),65),e)?ko(l(o.Xb(a),65).a,new lt(C.e.a+C.f.a*f,l(o0(l(o.Xb(a),65).a),8).b)):C.e.b-r>E?ko(l(o.Xb(a),65).a,new lt(C.e.a+C.f.a*f,E-n)):l(o.Xb(a),65).a.b>0&&(g=l(o0(l(o.Xb(a),65).a),8).a,B=C.e.a+C.f.a/2,w=l(o0(l(o.Xb(a),65).a),8).b,z=C.e.b+C.f.b/2,r>0&&b.Math.abs(g-B)/(b.Math.abs(w-z)/40)>50&&(B>g?ko(l(o.Xb(a),65).a,new lt(C.e.a+C.f.a*f-r/2,C.e.b-r/5.3)):ko(l(o.Xb(a),65).a,new lt(C.e.a+C.f.a*f+r/2,C.e.b-r/5.3)))),ko(l(o.Xb(a),65).a,new lt(C.e.a+C.f.a*f,C.e.b)))}function pi(){pi=U;var e,t;eC=new Ui(Byt),a7=new Ui(Fyt),eNe=(og(),Sge),ASt=new pn(qTe,eNe),Z6=new pn(Ox,null),LSt=new Ui(tSe),nNe=(Ym(),rs(Lge,he(le(Mge,1),it,298,0,[Age]))),UB=new pn(SG,nNe),GB=new pn(VP,(Hn(),!1)),rNe=(Js(),J1),xv=new pn(gfe,rNe),aNe=(ip(),Hge),sNe=new pn(HP,aNe),ISt=new pn(ZCe,!1),uNe=(rp(),oY),n7=new pn(CG,uNe),vNe=new lw(12),_2=new pn(Xw,vNe),WB=new pn(hL,!1),Nge=new pn(AG,!1),YB=new pn(fL,!1),ENe=(Ra(),Wb),_M=new pn(Nhe,ENe),n9=new Ui(_G),XB=new Ui(NP),zge=new Ui(oG),qge=new Ui(lL),lNe=new bl,x3=new pn(ZTe,lNe),DSt=new pn(nCe,!1),OSt=new pn(rCe,!1),hNe=new s_,tC=new pn(sCe,hNe),rY=new pn($Te,!1),FSt=new pn(Ryt,1),t7=new Ui(jyt),e7=new Ui($yt),AM=new pn(PP,!1),new pn(zyt,!0),pt(0),new pn(qyt,pt(100)),new pn(Hyt,!1),pt(0),new pn(Vyt,pt(4e3)),pt(0),new pn(Uyt,pt(400)),new pn(Gyt,!1),new pn(Kyt,!1),new pn(Wyt,!0),new pn(Yyt,!1),tNe=(VV(),Kge),MSt=new pn(eSe,tNe),RSt=new pn(LTe,10),jSt=new pn(MTe,10),_Ne=new pn(_he,20),$St=new pn(DTe,10),ANe=new pn(Ohe,2),LNe=new pn(dfe,10),MNe=new pn(ITe,0),iY=new pn(PTe,5),DNe=new pn(OTe,1),INe=new pn(NTe,1),Ev=new pn(Jy,20),zSt=new pn(BTe,10),PNe=new pn(FTe,10),r9=new Ui(RTe),NNe=new nnt,ONe=new pn(aCe,NNe),PSt=new Ui(bfe),wNe=!1,NSt=new pn(pfe,wNe),dNe=new lw(5),fNe=new pn(UTe,dNe),gNe=(qy(),t=l(K0(Ko),9),new Zh(t,l(c0(t,t.length),9),0)),r7=new pn(fT,gNe),xNe=(t6(),Kb),yNe=new pn(WTe,xNe),Bge=new Ui(YTe),Fge=new Ui(XTe),Rge=new Ui(QTe),Pge=new Ui(JTe),pNe=(e=l(K0(BM),9),new Zh(e,l(c0(e,e.length),9),0)),kv=new pn(x6,pNe),mNe=un((Zl(),aC)),Ub=new pn(Nx,mNe),bNe=new lt(0,0),i7=new pn(Px,bNe),C4=new pn(hT,!1),iNe=(F1(),nC),Ige=new pn(eCe,iNe),Dge=new pn(cG,!1),pt(1),new pn(Xyt,null),kNe=new Ui(iCe),jge=new Ui(tCe),SNe=(Ct(),Pc),s7=new pn(zTe,SNe),rh=new Ui(jTe),TNe=(Rl(),un(Yb)),S4=new pn(dT,TNe),$ge=new pn(GTe,!1),CNe=new pn(KTe,!0),aY=new pn(BP,1),BNe=new pn(nSe,null),QB=new pn(FP,150),sY=new pn(RP,1.414),i9=new pn(Qw,null),qSt=new pn(rSe,1),KB=new pn(HTe,!1),Oge=new pn(VTe,!1),oNe=new pn(Ahe,1),cNe=(vU(),Uge),new pn(Qyt,cNe),BSt=!0,VSt=(dx(),L4),USt=L4,HSt=L4}function vo(){vo=U,PAe=new Ws("DIRECTION_PREPROCESSOR",0),IAe=new Ws("COMMENT_PREPROCESSOR",1),D6=new Ws("EDGE_AND_LAYER_CONSTRAINT_EDGE_REVERSER",2),f1e=new Ws("INTERACTIVE_EXTERNAL_PORT_POSITIONER",3),eLe=new Ws("PARTITION_PREPROCESSOR",4),DK=new Ws("LABEL_DUMMY_INSERTER",5),zK=new Ws("SELF_LOOP_PREPROCESSOR",6),l4=new Ws("LAYER_CONSTRAINT_PREPROCESSOR",7),JAe=new Ws("PARTITION_MIDPROCESSOR",8),HAe=new Ws("HIGH_DEGREE_NODE_LAYER_PROCESSOR",9),XAe=new Ws("NODE_PROMOTION",10),u4=new Ws("LAYER_CONSTRAINT_POSTPROCESSOR",11),ZAe=new Ws("PARTITION_POSTPROCESSOR",12),$Ae=new Ws("HIERARCHICAL_PORT_CONSTRAINT_PROCESSOR",13),tLe=new Ws("SEMI_INTERACTIVE_CROSSMIN_PROCESSOR",14),SAe=new Ws("BREAKING_POINT_INSERTER",15),PK=new Ws("LONG_EDGE_SPLITTER",16),d1e=new Ws("PORT_SIDE_PROCESSOR",17),LK=new Ws("INVERTED_PORT_PROCESSOR",18),RK=new Ws("PORT_LIST_SORTER",19),rLe=new Ws("SORT_BY_INPUT_ORDER_OF_MODEL",20),FK=new Ws("NORTH_SOUTH_PORT_PREPROCESSOR",21),_Ae=new Ws("BREAKING_POINT_PROCESSOR",22),QAe=new Ws(H3t,23),iLe=new Ws(V3t,24),jK=new Ws("SELF_LOOP_PORT_RESTORER",25),nLe=new Ws("SINGLE_EDGE_GRAPH_WRAPPER",26),MK=new Ws("IN_LAYER_CONSTRAINT_PROCESSOR",27),FAe=new Ws("END_NODE_PORT_LABEL_MANAGEMENT_PROCESSOR",28),WAe=new Ws("LABEL_AND_NODE_SIZE_PROCESSOR",29),KAe=new Ws("INNERMOST_NODE_MARGIN_CALCULATOR",30),qK=new Ws("SELF_LOOP_ROUTER",31),MAe=new Ws("COMMENT_NODE_MARGIN_CALCULATOR",32),AK=new Ws("END_LABEL_PREPROCESSOR",33),OK=new Ws("LABEL_DUMMY_SWITCHER",34),LAe=new Ws("CENTER_LABEL_MANAGEMENT_PROCESSOR",35),LT=new Ws("LABEL_SIDE_SELECTOR",36),UAe=new Ws("HYPEREDGE_DUMMY_MERGER",37),zAe=new Ws("HIERARCHICAL_PORT_DUMMY_SIZE_PROCESSOR",38),YAe=new Ws("LAYER_SIZE_AND_GRAPH_HEIGHT_CALCULATOR",39),zL=new Ws("HIERARCHICAL_PORT_POSITION_PROCESSOR",40),OAe=new Ws("CONSTRAINTS_POSTPROCESSOR",41),DAe=new Ws("COMMENT_POSTPROCESSOR",42),GAe=new Ws("HYPERNODE_PROCESSOR",43),qAe=new Ws("HIERARCHICAL_PORT_ORTHOGONAL_EDGE_ROUTER",44),NK=new Ws("LONG_EDGE_JOINER",45),$K=new Ws("SELF_LOOP_POSTPROCESSOR",46),AAe=new Ws("BREAKING_POINT_REMOVER",47),BK=new Ws("NORTH_SOUTH_PORT_POSTPROCESSOR",48),VAe=new Ws("HORIZONTAL_COMPACTOR",49),IK=new Ws("LABEL_DUMMY_REMOVER",50),RAe=new Ws("FINAL_SPLINE_BENDPOINTS_CALCULATOR",51),BAe=new Ws("END_LABEL_SORTER",52),gB=new Ws("REVERSED_EDGE_RESTORER",53),_K=new Ws("END_LABEL_POSTPROCESSOR",54),jAe=new Ws("HIERARCHICAL_NODE_RESIZER",55),NAe=new Ws("DIRECTION_POSTPROCESSOR",56)}function Yke(){Yke=U,iMe=(pN(),XK),r9t=new pn(VEe,iMe),p9t=new pn(UEe,(Hn(),!1)),lMe=(zH(),z1e),y9t=new pn(fG,lMe),P9t=new pn(GEe,!1),B9t=new pn(KEe,!0),Lxt=new pn(WEe,!1),vMe=(dN(),kde),Q9t=new pn(YEe,vMe),pt(1),skt=new pn(XEe,pt(7)),akt=new pn(QEe,!1),b9t=new pn(JEe,!1),rMe=(l2(),A1e),n9t=new pn(zhe,rMe),dMe=(p2(),gde),N9t=new pn(qP,dMe),hMe=(hf(),EB),S9t=new pn(ZEe,hMe),pt(-1),C9t=new pn(eTe,null),pt(-1),_9t=new pn(tTe,pt(-1)),pt(-1),A9t=new pn(qhe,pt(4)),pt(-1),M9t=new pn(Hhe,pt(2)),fMe=(Nf(),AW),O9t=new pn(Vhe,fMe),pt(0),I9t=new pn(Uhe,pt(0)),E9t=new pn(Ghe,pt(Ii)),nMe=(dA(),HL),t9t=new pn(pL,nMe),$xt=new pn(nTe,!1),Kxt=new pn(Khe,.1),Zxt=new pn(Whe,!1),Yxt=new pn(rTe,null),Xxt=new pn(iTe,null),pt(-1),Qxt=new pn(sTe,null),pt(-1),Jxt=new pn(aTe,pt(-1)),pt(0),zxt=new pn(oTe,pt(40)),tMe=(vE(),j1e),Uxt=new pn(Yhe,tMe),eMe=vB,qxt=new pn(dG,eMe),mMe=(OA(),rM),X9t=new pn(k6,mMe),z9t=new Ui(gG),gMe=(cN(),JK),F9t=new pn(Xhe,gMe),pMe=(WN(),ZK),j9t=new pn(Qhe,pMe),V9t=new pn(Jhe,.3),G9t=new Ui(Zhe),bMe=(By(),_W),K9t=new pn(efe,bMe),oMe=(LV(),Tde),c9t=new pn(cTe,oMe),cMe=(yA(),Sde),u9t=new pn(uTe,cMe),uMe=(SE(),aM),l9t=new pn(pG,uMe),f9t=new pn(bG,.2),a9t=new pn(tfe,2),tkt=new pn(lTe,null),rkt=new pn(hTe,10),nkt=new pn(fTe,10),ikt=new pn(dTe,20),pt(0),J9t=new pn(gTe,pt(0)),pt(0),Z9t=new pn(pTe,pt(0)),pt(0),ekt=new pn(bTe,pt(0)),Mxt=new pn(nfe,!1),XLe=(zE(),VL),Ixt=new pn(mTe,XLe),YLe=(JH(),S1e),Dxt=new pn(vTe,YLe),v9t=new pn(mG,!1),pt(0),m9t=new pn(rfe,pt(16)),pt(0),w9t=new pn(ife,pt(5)),xMe=(OV(),Lde),Skt=new pn(fp,xMe),okt=new pn(vG,10),lkt=new pn(wG,1),yMe=(pV(),YK),mkt=new pn(bL,yMe),dkt=new Ui(sfe),wMe=pt(1),pt(0),pkt=new pn(afe,wMe),kMe=(gV(),Ade),Mkt=new pn(yG,kMe),_kt=new Ui(xG),kkt=new pn(kG,!0),ykt=new pn(EG,2),Tkt=new pn(ofe,!0),aMe=(yU(),QK),s9t=new pn(wTe,aMe),sMe=(yx(),OT),i9t=new pn(yTe,sMe),ZLe=(Ed(),E2),jxt=new pn(TG,ZLe),Rxt=new pn(xTe,!1),Fxt=new pn(kTe,!1),QLe=(Km(),c4),Oxt=new pn(cfe,QLe),JLe=(EA(),pde),Bxt=new pn(ETe,JLe),Nxt=new pn(ufe,0),Pxt=new pn(lfe,0),k9t=L1e,x9t=mB,L9t=CW,D9t=CW,T9t=dde,Wxt=(rp(),A2),e9t=HL,Gxt=HL,Hxt=HL,Vxt=A2,q9t=iM,H9t=rM,R9t=rM,$9t=rM,U9t=wde,Y9t=iM,W9t=iM,h9t=(ip(),s9),d9t=s9,g9t=aM,o9t=JB,ckt=XT,ukt=k4,hkt=XT,fkt=k4,vkt=XT,wkt=k4,gkt=_1e,bkt=YK,Dkt=XT,Ikt=k4,Akt=XT,Lkt=k4,Ekt=k4,xkt=k4,Ckt=k4}function eOn(e,t,n){var r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e,Ze,ot,St,cn,an,Bn,jn,ur,oi,ws,Vl,lc,Hh,f7,P2,L0,M0,_v,h9,rm,f9,qd,_g,S3,d9,d7,Hd,Av,yp,IAt,sBe,_3,YM,lpe,g9,XM,F4,QM,hpe,OAt;for(sBe=0,oi=t,lc=0,P2=oi.length;lc0&&(e.a[qd.p]=sBe++)}for(XM=0,ws=n,Hh=0,L0=ws.length;Hh0;){for(qd=(mr(d7.b>0),l(d7.a.Xb(d7.c=--d7.b),12)),d9=0,g=new G(qd.e);g.a0&&(qd.j==(Ct(),Qn)?(e.a[qd.p]=XM,++XM):(e.a[qd.p]=XM+M0+h9,++h9))}XM+=h9}for(S3=new Pr,V=new bd,ur=t,Vl=0,f7=ur.length;VlE.b&&(E.b=Hd)):qd.i.c==IAt&&(HdE.c&&(E.c=Hd));for(nE(J,0,J.length,null),g9=We(Vr,di,28,J.length,15,1),r=We(Vr,di,28,XM+1,15,1),fe=0;fe0;)St%2>0&&(a+=hpe[St+1]),St=(St-1)/2|0,++hpe[St];for(an=We(MEt,Rn,374,J.length*2,0,1),$e=0;$e0&&GO(Vl.f),at(fe,BNe)!=null&&(g=l(at(fe,BNe),347),S3=g.Tg(fe),F5(fe,b.Math.max(fe.g,S3.a),b.Math.max(fe.f,S3.b)));if(L0=l(at(t,_2),107),z=t.g-(L0.b+L0.c),B=t.f-(L0.d+L0.a),Hd.bh("Available Child Area: ("+z+"|"+B+")"),Hi(t,Z6,z/B),sdt(t,a,r.eh(f7)),l(at(t,i9),280)==dY&&(Uke(t),F5(t,L0.b+ze(Ge(at(t,t7)))+L0.c,L0.d+ze(Ge(at(t,e7)))+L0.a)),Hd.bh("Executed layout algorithm: "+ei(at(t,eC))+" on node "+t.k),l(at(t,i9),280)==L4){if(z<0||B<0)throw ue(new Vp("The size defined by the parent parallel node is too small for the space provided by the paddings of the child hierarchical node. "+t.k));for(P1(t,t7)||P1(t,e7)||Uke(t),J=ze(Ge(at(t,t7))),V=ze(Ge(at(t,e7))),Hd.bh("Desired Child Area: ("+J+"|"+V+")"),_v=z/J,h9=B/V,M0=b.Math.min(_v,b.Math.min(h9,ze(Ge(at(t,qSt))))),Hi(t,aY,M0),Hd.bh(t.k+" -- Local Scale Factor (X|Y): ("+_v+"|"+h9+")"),$e=l(at(t,UB),21),o=0,f=0,M0<_v&&($e.Hc((Ym(),EM))?o=(z/2-J*M0/2)/M0:$e.Hc(TM)&&(o=(z-J*M0)/M0)),M0'?":vn(L4t,e)?"'(?<' or '(? toIndex: ",fEe=", toIndex: ",dEe="Index: ",gEe=", Size: ",oT="org.eclipse.elk.alg.common",ii={50:1},Jwt="org.eclipse.elk.alg.common.compaction",Zwt="Scanline/EventHandler",gg="org.eclipse.elk.alg.common.compaction.oned",e3t="CNode belongs to another CGroup.",t3t="ISpacingsHandler/1",phe="The ",bhe=" instance has been finished already.",n3t="The direction ",r3t=" is not supported by the CGraph instance.",i3t="OneDimensionalCompactor",s3t="OneDimensionalCompactor/lambda$0$Type",a3t="Quadruplet",o3t="ScanlineConstraintCalculator",c3t="ScanlineConstraintCalculator/ConstraintsScanlineHandler",u3t="ScanlineConstraintCalculator/ConstraintsScanlineHandler/lambda$0$Type",l3t="ScanlineConstraintCalculator/Timestamp",h3t="ScanlineConstraintCalculator/lambda$0$Type",Ld={178:1,46:1},mhe="org.eclipse.elk.alg.common.compaction.options",Nc="org.eclipse.elk.core.data",pEe="org.eclipse.elk.polyomino.traversalStrategy",bEe="org.eclipse.elk.polyomino.lowLevelSort",mEe="org.eclipse.elk.polyomino.highLevelSort",vEe="org.eclipse.elk.polyomino.fill",Pf={134:1},vhe="polyomino",oL="org.eclipse.elk.alg.common.networksimplex",pg={183:1,3:1,4:1},f3t="org.eclipse.elk.alg.common.nodespacing",ev="org.eclipse.elk.alg.common.nodespacing.cellsystem",cT="CENTER",d3t={217:1,336:1},wEe={3:1,4:1,5:1,603:1},Mx="LEFT",Dx="RIGHT",yEe="Vertical alignment cannot be null",xEe="BOTTOM",tG="org.eclipse.elk.alg.common.nodespacing.internal",cL="UNDEFINED",H1=.01,DP="org.eclipse.elk.alg.common.nodespacing.internal.algorithm",g3t="LabelPlacer/lambda$0$Type",p3t="LabelPlacer/lambda$1$Type",b3t="portRatioOrPosition",uT="org.eclipse.elk.alg.common.overlaps",whe="DOWN",Md="org.eclipse.elk.alg.common.polyomino",nG="NORTH",yhe="EAST",xhe="SOUTH",khe="WEST",rG="org.eclipse.elk.alg.common.polyomino.structures",kEe="Direction",Ehe="Grid is only of size ",The=". Requested point (",Che=") is out of bounds.",iG=" Given center based coordinates were (",IP="org.eclipse.elk.graph.properties",m3t="IPropertyHolder",EEe={3:1,96:1,137:1},Ix="org.eclipse.elk.alg.common.spore",v3t="org.eclipse.elk.alg.common.utils",tv={205:1},v6="org.eclipse.elk.core",w3t="Connected Components Compaction",y3t="org.eclipse.elk.alg.disco",sG="org.eclipse.elk.alg.disco.graph",She="org.eclipse.elk.alg.disco.options",TEe="CompactionStrategy",CEe="org.eclipse.elk.disco.componentCompaction.strategy",SEe="org.eclipse.elk.disco.componentCompaction.componentLayoutAlgorithm",_Ee="org.eclipse.elk.disco.debug.discoGraph",AEe="org.eclipse.elk.disco.debug.discoPolys",x3t="componentCompaction",nv="org.eclipse.elk.disco",_he="org.eclipse.elk.spacing.componentComponent",Ahe="org.eclipse.elk.edge.thickness",Ox="org.eclipse.elk.aspectRatio",Xw="org.eclipse.elk.padding",w6="org.eclipse.elk.alg.disco.transform",Lhe=1.5707963267948966,y6=17976931348623157e292,Qy={3:1,4:1,5:1,198:1},k3t={3:1,6:1,4:1,5:1,100:1,115:1},Mhe="org.eclipse.elk.alg.force",LEe="ComponentsProcessor",E3t="ComponentsProcessor/1",MEe="ElkGraphImporter/lambda$0$Type",OP="org.eclipse.elk.alg.force.graph",T3t="Component Layout",DEe="org.eclipse.elk.alg.force.model",aG="org.eclipse.elk.force.model",IEe="org.eclipse.elk.force.iterations",OEe="org.eclipse.elk.force.repulsivePower",Dhe="org.eclipse.elk.force.temperature",Dd=.001,Ihe="org.eclipse.elk.force.repulsion",uL="org.eclipse.elk.alg.force.options",lT=1.600000023841858,Yu="org.eclipse.elk.force",NP="org.eclipse.elk.priority",Jy="org.eclipse.elk.spacing.nodeNode",Ohe="org.eclipse.elk.spacing.edgeLabel",oG="org.eclipse.elk.randomSeed",lL="org.eclipse.elk.separateConnectedComponents",hL="org.eclipse.elk.interactive",Nhe="org.eclipse.elk.portConstraints",cG="org.eclipse.elk.edgeLabels.inline",fL="org.eclipse.elk.omitNodeMicroLayout",hT="org.eclipse.elk.nodeSize.fixedGraphSize",Nx="org.eclipse.elk.nodeSize.options",x6="org.eclipse.elk.nodeSize.constraints",fT="org.eclipse.elk.nodeLabels.placement",dT="org.eclipse.elk.portLabels.placement",PP="org.eclipse.elk.topdownLayout",BP="org.eclipse.elk.topdown.scaleFactor",FP="org.eclipse.elk.topdown.hierarchicalNodeWidth",RP="org.eclipse.elk.topdown.hierarchicalNodeAspectRatio",Qw="org.eclipse.elk.topdown.nodeType",NEe="origin",C3t="random",S3t="boundingBox.upLeft",_3t="boundingBox.lowRight",PEe="org.eclipse.elk.stress.fixed",BEe="org.eclipse.elk.stress.desiredEdgeLength",FEe="org.eclipse.elk.stress.dimension",REe="org.eclipse.elk.stress.epsilon",jEe="org.eclipse.elk.stress.iterationLimit",Mb="org.eclipse.elk.stress",A3t="ELK Stress",Px="org.eclipse.elk.nodeSize.minimum",uG="org.eclipse.elk.alg.force.stress",L3t="Layered layout",Bx="org.eclipse.elk.alg.layered",jP="org.eclipse.elk.alg.layered.compaction.components",dL="org.eclipse.elk.alg.layered.compaction.oned",lG="org.eclipse.elk.alg.layered.compaction.oned.algs",rv="org.eclipse.elk.alg.layered.compaction.recthull",V1="org.eclipse.elk.alg.layered.components",Id="NONE",$Ee="MODEL_ORDER",au={3:1,6:1,4:1,9:1,5:1,126:1},M3t={3:1,6:1,4:1,5:1,150:1,100:1,115:1},hG="org.eclipse.elk.alg.layered.compound",ts={47:1},Cu="org.eclipse.elk.alg.layered.graph",Phe=" -> ",D3t="Not supported by LGraph",zEe="Port side is undefined",Bhe={3:1,6:1,4:1,5:1,483:1,150:1,100:1,115:1},m2={3:1,6:1,4:1,5:1,150:1,199:1,210:1,100:1,115:1},I3t={3:1,6:1,4:1,5:1,150:1,2042:1,210:1,100:1,115:1},O3t=`([{"' \r +`,N3t=`)]}"' \r +`,P3t="The given string contains parts that cannot be parsed as numbers.",$P="org.eclipse.elk.core.math",B3t={3:1,4:1,140:1,214:1,423:1},F3t={3:1,4:1,107:1,214:1,423:1},v2="org.eclipse.elk.alg.layered.graph.transform",R3t="ElkGraphImporter",j3t="ElkGraphImporter/lambda$1$Type",$3t="ElkGraphImporter/lambda$2$Type",z3t="ElkGraphImporter/lambda$4$Type",rr="org.eclipse.elk.alg.layered.intermediate",q3t="Node margin calculation",H3t="ONE_SIDED_GREEDY_SWITCH",V3t="TWO_SIDED_GREEDY_SWITCH",Fhe="No implementation is available for the layout processor ",Rhe="IntermediateProcessorStrategy",jhe="Node '",U3t="FIRST_SEPARATE",G3t="LAST_SEPARATE",K3t="Odd port side processing",aa="org.eclipse.elk.alg.layered.intermediate.compaction",gL="org.eclipse.elk.alg.layered.intermediate.greedyswitch",bg="org.eclipse.elk.alg.layered.p3order.counting",zP={230:1},Fx="org.eclipse.elk.alg.layered.intermediate.loops",Bh="org.eclipse.elk.alg.layered.intermediate.loops.ordering",Db="org.eclipse.elk.alg.layered.intermediate.loops.routing",qEe="org.eclipse.elk.alg.layered.intermediate.preserveorder",Od="org.eclipse.elk.alg.layered.intermediate.wrapping",ou="org.eclipse.elk.alg.layered.options",$he="INTERACTIVE",HEe="GREEDY",W3t="DEPTH_FIRST",Y3t="EDGE_LENGTH",X3t="SELF_LOOPS",Q3t="firstTryWithInitialOrder",VEe="org.eclipse.elk.layered.directionCongruency",UEe="org.eclipse.elk.layered.feedbackEdges",fG="org.eclipse.elk.layered.interactiveReferencePoint",GEe="org.eclipse.elk.layered.mergeEdges",KEe="org.eclipse.elk.layered.mergeHierarchyEdges",WEe="org.eclipse.elk.layered.allowNonFlowPortsToSwitchSides",YEe="org.eclipse.elk.layered.portSortingStrategy",XEe="org.eclipse.elk.layered.thoroughness",QEe="org.eclipse.elk.layered.unnecessaryBendpoints",JEe="org.eclipse.elk.layered.generatePositionAndLayerIds",zhe="org.eclipse.elk.layered.cycleBreaking.strategy",qP="org.eclipse.elk.layered.layering.strategy",ZEe="org.eclipse.elk.layered.layering.layerConstraint",eTe="org.eclipse.elk.layered.layering.layerChoiceConstraint",tTe="org.eclipse.elk.layered.layering.layerId",qhe="org.eclipse.elk.layered.layering.minWidth.upperBoundOnWidth",Hhe="org.eclipse.elk.layered.layering.minWidth.upperLayerEstimationScalingFactor",Vhe="org.eclipse.elk.layered.layering.nodePromotion.strategy",Uhe="org.eclipse.elk.layered.layering.nodePromotion.maxIterations",Ghe="org.eclipse.elk.layered.layering.coffmanGraham.layerBound",pL="org.eclipse.elk.layered.crossingMinimization.strategy",nTe="org.eclipse.elk.layered.crossingMinimization.forceNodeModelOrder",Khe="org.eclipse.elk.layered.crossingMinimization.hierarchicalSweepiness",Whe="org.eclipse.elk.layered.crossingMinimization.semiInteractive",rTe="org.eclipse.elk.layered.crossingMinimization.inLayerPredOf",iTe="org.eclipse.elk.layered.crossingMinimization.inLayerSuccOf",sTe="org.eclipse.elk.layered.crossingMinimization.positionChoiceConstraint",aTe="org.eclipse.elk.layered.crossingMinimization.positionId",oTe="org.eclipse.elk.layered.crossingMinimization.greedySwitch.activationThreshold",Yhe="org.eclipse.elk.layered.crossingMinimization.greedySwitch.type",dG="org.eclipse.elk.layered.crossingMinimization.greedySwitchHierarchical.type",k6="org.eclipse.elk.layered.nodePlacement.strategy",gG="org.eclipse.elk.layered.nodePlacement.favorStraightEdges",Xhe="org.eclipse.elk.layered.nodePlacement.bk.edgeStraightening",Qhe="org.eclipse.elk.layered.nodePlacement.bk.fixedAlignment",Jhe="org.eclipse.elk.layered.nodePlacement.linearSegments.deflectionDampening",Zhe="org.eclipse.elk.layered.nodePlacement.networkSimplex.nodeFlexibility",efe="org.eclipse.elk.layered.nodePlacement.networkSimplex.nodeFlexibility.default",cTe="org.eclipse.elk.layered.edgeRouting.selfLoopDistribution",uTe="org.eclipse.elk.layered.edgeRouting.selfLoopOrdering",pG="org.eclipse.elk.layered.edgeRouting.splines.mode",bG="org.eclipse.elk.layered.edgeRouting.splines.sloppy.layerSpacingFactor",tfe="org.eclipse.elk.layered.edgeRouting.polyline.slopedEdgeZoneWidth",lTe="org.eclipse.elk.layered.spacing.baseValue",hTe="org.eclipse.elk.layered.spacing.edgeNodeBetweenLayers",fTe="org.eclipse.elk.layered.spacing.edgeEdgeBetweenLayers",dTe="org.eclipse.elk.layered.spacing.nodeNodeBetweenLayers",gTe="org.eclipse.elk.layered.priority.direction",pTe="org.eclipse.elk.layered.priority.shortness",bTe="org.eclipse.elk.layered.priority.straightness",nfe="org.eclipse.elk.layered.compaction.connectedComponents",mTe="org.eclipse.elk.layered.compaction.postCompaction.strategy",vTe="org.eclipse.elk.layered.compaction.postCompaction.constraints",mG="org.eclipse.elk.layered.highDegreeNodes.treatment",rfe="org.eclipse.elk.layered.highDegreeNodes.threshold",ife="org.eclipse.elk.layered.highDegreeNodes.treeHeight",fp="org.eclipse.elk.layered.wrapping.strategy",vG="org.eclipse.elk.layered.wrapping.additionalEdgeSpacing",wG="org.eclipse.elk.layered.wrapping.correctionFactor",bL="org.eclipse.elk.layered.wrapping.cutting.strategy",sfe="org.eclipse.elk.layered.wrapping.cutting.cuts",afe="org.eclipse.elk.layered.wrapping.cutting.msd.freedom",yG="org.eclipse.elk.layered.wrapping.validify.strategy",xG="org.eclipse.elk.layered.wrapping.validify.forbiddenIndices",kG="org.eclipse.elk.layered.wrapping.multiEdge.improveCuts",EG="org.eclipse.elk.layered.wrapping.multiEdge.distancePenalty",ofe="org.eclipse.elk.layered.wrapping.multiEdge.improveWrappedEdges",wTe="org.eclipse.elk.layered.edgeLabels.sideSelection",yTe="org.eclipse.elk.layered.edgeLabels.centerLabelPlacementStrategy",TG="org.eclipse.elk.layered.considerModelOrder.strategy",xTe="org.eclipse.elk.layered.considerModelOrder.portModelOrder",kTe="org.eclipse.elk.layered.considerModelOrder.noModelOrder",cfe="org.eclipse.elk.layered.considerModelOrder.components",ETe="org.eclipse.elk.layered.considerModelOrder.longEdgeStrategy",ufe="org.eclipse.elk.layered.considerModelOrder.crossingCounterNodeInfluence",lfe="org.eclipse.elk.layered.considerModelOrder.crossingCounterPortInfluence",hfe="layering",J3t="layering.minWidth",Z3t="layering.nodePromotion",gT="crossingMinimization",CG="org.eclipse.elk.hierarchyHandling",eyt="crossingMinimization.greedySwitch",tyt="nodePlacement",nyt="nodePlacement.bk",ryt="edgeRouting",HP="org.eclipse.elk.edgeRouting",U1="spacing",TTe="priority",CTe="compaction",iyt="compaction.postCompaction",syt="Specifies whether and how post-process compaction is applied.",STe="highDegreeNodes",_Te="wrapping",ayt="wrapping.cutting",oyt="wrapping.validify",ATe="wrapping.multiEdge",ffe="edgeLabels",mL="considerModelOrder",LTe="org.eclipse.elk.spacing.commentComment",MTe="org.eclipse.elk.spacing.commentNode",DTe="org.eclipse.elk.spacing.edgeEdge",dfe="org.eclipse.elk.spacing.edgeNode",ITe="org.eclipse.elk.spacing.labelLabel",OTe="org.eclipse.elk.spacing.labelPortHorizontal",NTe="org.eclipse.elk.spacing.labelPortVertical",PTe="org.eclipse.elk.spacing.labelNode",BTe="org.eclipse.elk.spacing.nodeSelfLoop",FTe="org.eclipse.elk.spacing.portPort",RTe="org.eclipse.elk.spacing.individual",jTe="org.eclipse.elk.port.borderOffset",$Te="org.eclipse.elk.noLayout",zTe="org.eclipse.elk.port.side",VP="org.eclipse.elk.debugMode",qTe="org.eclipse.elk.alignment",HTe="org.eclipse.elk.insideSelfLoops.activate",VTe="org.eclipse.elk.insideSelfLoops.yo",gfe="org.eclipse.elk.direction",UTe="org.eclipse.elk.nodeLabels.padding",GTe="org.eclipse.elk.portLabels.nextToPortIfPossible",KTe="org.eclipse.elk.portLabels.treatAsGroup",WTe="org.eclipse.elk.portAlignment.default",YTe="org.eclipse.elk.portAlignment.north",XTe="org.eclipse.elk.portAlignment.south",QTe="org.eclipse.elk.portAlignment.west",JTe="org.eclipse.elk.portAlignment.east",SG="org.eclipse.elk.contentAlignment",ZTe="org.eclipse.elk.junctionPoints",eCe="org.eclipse.elk.edgeLabels.placement",tCe="org.eclipse.elk.port.index",nCe="org.eclipse.elk.commentBox",rCe="org.eclipse.elk.hypernode",iCe="org.eclipse.elk.port.anchor",pfe="org.eclipse.elk.partitioning.activate",bfe="org.eclipse.elk.partitioning.partition",_G="org.eclipse.elk.position",sCe="org.eclipse.elk.margins",aCe="org.eclipse.elk.spacing.portsSurrounding",AG="org.eclipse.elk.interactiveLayout",Uc="org.eclipse.elk.core.util",oCe={3:1,4:1,5:1,601:1},cyt="NETWORK_SIMPLEX",cCe="SIMPLE",Uo={106:1,47:1},LG="org.eclipse.elk.alg.layered.p1cycles",dp="org.eclipse.elk.alg.layered.p2layers",uCe={413:1,230:1},uyt={846:1,3:1,4:1},Cl="org.eclipse.elk.alg.layered.p3order",Go="org.eclipse.elk.alg.layered.p4nodes",lyt={3:1,4:1,5:1,854:1},Nd=1e-5,Ib="org.eclipse.elk.alg.layered.p4nodes.bk",mfe="org.eclipse.elk.alg.layered.p5edges",i1="org.eclipse.elk.alg.layered.p5edges.orthogonal",vfe="org.eclipse.elk.alg.layered.p5edges.orthogonal.direction",wfe=1e-6,Zy="org.eclipse.elk.alg.layered.p5edges.splines",yfe=.09999999999999998,MG=1e-8,hyt=4.71238898038469,lCe=3.141592653589793,gp="org.eclipse.elk.alg.mrtree",xfe=.10000000149011612,DG="SUPER_ROOT",vL="org.eclipse.elk.alg.mrtree.graph",hCe=-17976931348623157e292,Su="org.eclipse.elk.alg.mrtree.intermediate",fyt="Processor compute fanout",IG={3:1,6:1,4:1,5:1,534:1,100:1,115:1},dyt="Set neighbors in level",UP="org.eclipse.elk.alg.mrtree.options",gyt="DESCENDANTS",fCe="org.eclipse.elk.mrtree.compaction",dCe="org.eclipse.elk.mrtree.edgeEndTextureLength",gCe="org.eclipse.elk.mrtree.treeLevel",pCe="org.eclipse.elk.mrtree.positionConstraint",bCe="org.eclipse.elk.mrtree.weighting",mCe="org.eclipse.elk.mrtree.edgeRoutingMode",vCe="org.eclipse.elk.mrtree.searchOrder",pyt="Position Constraint",Xu="org.eclipse.elk.mrtree",byt="org.eclipse.elk.tree",myt="Processor arrange level",pT="org.eclipse.elk.alg.mrtree.p2order",vh="org.eclipse.elk.alg.mrtree.p4route",wCe="org.eclipse.elk.alg.radial",iv=6.283185307179586,yCe="Before",xCe=5e-324,OG="After",kCe="org.eclipse.elk.alg.radial.intermediate",vyt="COMPACTION",kfe="org.eclipse.elk.alg.radial.intermediate.compaction",wyt={3:1,4:1,5:1,100:1},ECe="org.eclipse.elk.alg.radial.intermediate.optimization",Efe="No implementation is available for the layout option ",wL="org.eclipse.elk.alg.radial.options",TCe="org.eclipse.elk.radial.centerOnRoot",CCe="org.eclipse.elk.radial.orderId",SCe="org.eclipse.elk.radial.radius",NG="org.eclipse.elk.radial.rotate",Tfe="org.eclipse.elk.radial.compactor",Cfe="org.eclipse.elk.radial.compactionStepSize",_Ce="org.eclipse.elk.radial.sorter",ACe="org.eclipse.elk.radial.wedgeCriteria",LCe="org.eclipse.elk.radial.optimizationCriteria",Sfe="org.eclipse.elk.radial.rotation.targetAngle",_fe="org.eclipse.elk.radial.rotation.computeAdditionalWedgeSpace",MCe="org.eclipse.elk.radial.rotation.outgoingEdgeAngles",yyt="Compaction",DCe="rotation",gf="org.eclipse.elk.radial",xyt="org.eclipse.elk.alg.radial.p1position.wedge",ICe="org.eclipse.elk.alg.radial.sorting",kyt=5.497787143782138,Eyt=3.9269908169872414,Tyt=2.356194490192345,Cyt="org.eclipse.elk.alg.rectpacking",PG="org.eclipse.elk.alg.rectpacking.intermediate",Afe="org.eclipse.elk.alg.rectpacking.options",OCe="org.eclipse.elk.rectpacking.trybox",NCe="org.eclipse.elk.rectpacking.currentPosition",PCe="org.eclipse.elk.rectpacking.desiredPosition",BCe="org.eclipse.elk.rectpacking.inNewRow",FCe="org.eclipse.elk.rectpacking.widthApproximation.strategy",RCe="org.eclipse.elk.rectpacking.widthApproximation.targetWidth",jCe="org.eclipse.elk.rectpacking.widthApproximation.optimizationGoal",$Ce="org.eclipse.elk.rectpacking.widthApproximation.lastPlaceShift",zCe="org.eclipse.elk.rectpacking.packing.strategy",qCe="org.eclipse.elk.rectpacking.packing.compaction.rowHeightReevaluation",HCe="org.eclipse.elk.rectpacking.packing.compaction.iterations",VCe="org.eclipse.elk.rectpacking.whiteSpaceElimination.strategy",Lfe="widthApproximation",Syt="Compaction Strategy",_yt="packing.compaction",th="org.eclipse.elk.rectpacking",bT="org.eclipse.elk.alg.rectpacking.p1widthapproximation",BG="org.eclipse.elk.alg.rectpacking.p2packing",Ayt="No Compaction",UCe="org.eclipse.elk.alg.rectpacking.p3whitespaceelimination",GP="org.eclipse.elk.alg.rectpacking.util",FG="No implementation available for ",e4="org.eclipse.elk.alg.spore",t4="org.eclipse.elk.alg.spore.options",Jw="org.eclipse.elk.sporeCompaction",Mfe="org.eclipse.elk.underlyingLayoutAlgorithm",GCe="org.eclipse.elk.processingOrder.treeConstruction",KCe="org.eclipse.elk.processingOrder.spanningTreeCostFunction",Dfe="org.eclipse.elk.processingOrder.preferredRoot",Ife="org.eclipse.elk.processingOrder.rootSelection",Ofe="org.eclipse.elk.structure.structureExtractionStrategy",WCe="org.eclipse.elk.compaction.compactionStrategy",YCe="org.eclipse.elk.compaction.orthogonal",XCe="org.eclipse.elk.overlapRemoval.maxIterations",QCe="org.eclipse.elk.overlapRemoval.runScanline",Nfe="processingOrder",Lyt="overlapRemoval",mT="org.eclipse.elk.sporeOverlap",Myt="org.eclipse.elk.alg.spore.p1structure",Pfe="org.eclipse.elk.alg.spore.p2processingorder",Bfe="org.eclipse.elk.alg.spore.p3execution",Dyt="Topdown Layout",Iyt="Invalid index: ",vT="org.eclipse.elk.core.alg",E6={341:1},n4={295:1},Oyt="Make sure its type is registered with the ",JCe=" utility class.",wT="true",Ffe="false",Nyt="Couldn't clone property '",Zw=.05,nh="org.eclipse.elk.core.options",Pyt=1.2999999523162842,e3="org.eclipse.elk.box",ZCe="org.eclipse.elk.expandNodes",eSe="org.eclipse.elk.box.packingMode",Byt="org.eclipse.elk.algorithm",Fyt="org.eclipse.elk.resolvedAlgorithm",tSe="org.eclipse.elk.bendPoints",sOn="org.eclipse.elk.labelManager",Ryt="org.eclipse.elk.scaleFactor",jyt="org.eclipse.elk.childAreaWidth",$yt="org.eclipse.elk.childAreaHeight",zyt="org.eclipse.elk.animate",qyt="org.eclipse.elk.animTimeFactor",Hyt="org.eclipse.elk.layoutAncestors",Vyt="org.eclipse.elk.maxAnimTime",Uyt="org.eclipse.elk.minAnimTime",Gyt="org.eclipse.elk.progressBar",Kyt="org.eclipse.elk.validateGraph",Wyt="org.eclipse.elk.validateOptions",Yyt="org.eclipse.elk.zoomToFit",aOn="org.eclipse.elk.font.name",Xyt="org.eclipse.elk.font.size",nSe="org.eclipse.elk.topdown.sizeApproximator",rSe="org.eclipse.elk.topdown.scaleCap",Qyt="org.eclipse.elk.edge.type",Jyt="partitioning",Zyt="nodeLabels",RG="portAlignment",Rfe="nodeSize",jfe="port",iSe="portLabels",KP="topdown",e4t="insideSelfLoops",yL="org.eclipse.elk.fixed",jG="org.eclipse.elk.random",sSe={3:1,34:1,22:1,347:1},t4t="port must have a parent node to calculate the port side",n4t="The edge needs to have exactly one edge section. Found: ",xL="org.eclipse.elk.core.util.adapters",pf="org.eclipse.emf.ecore",T6="org.eclipse.elk.graph",r4t="EMapPropertyHolder",i4t="ElkBendPoint",s4t="ElkGraphElement",a4t="ElkConnectableShape",aSe="ElkEdge",o4t="ElkEdgeSection",c4t="EModelElement",u4t="ENamedElement",oSe="ElkLabel",cSe="ElkNode",uSe="ElkPort",l4t={94:1,93:1},Rx="org.eclipse.emf.common.notify.impl",Ob="The feature '",kL="' is not a valid changeable feature",h4t="Expecting null",$fe="' is not a valid feature",f4t="The feature ID",d4t=" is not a valid feature ID",eu=32768,g4t={110:1,94:1,93:1,58:1,54:1,99:1},Gn="org.eclipse.emf.ecore.impl",sv="org.eclipse.elk.graph.impl",EL="Recursive containment not allowed for ",yT="The datatype '",t3="' is not a valid classifier",zfe="The value '",C6={195:1,3:1,4:1},qfe="The class '",xT="http://www.eclipse.org/elk/ElkGraph",lSe="property",TL="value",Hfe="source",p4t="properties",b4t="identifier",Vfe="height",Ufe="width",Gfe="parent",Kfe="text",Wfe="children",m4t="hierarchical",hSe="sources",Yfe="targets",fSe="sections",$G="bendPoints",dSe="outgoingShape",gSe="incomingShape",pSe="outgoingSections",bSe="incomingSections",So="org.eclipse.emf.common.util",mSe="Severe implementation error in the Json to ElkGraph importer.",Pd="id",no="org.eclipse.elk.graph.json",vSe="Unhandled parameter types: ",v4t="startPoint",w4t="An edge must have at least one source and one target (edge id: '",kT="').",y4t="Referenced edge section does not exist: ",x4t=" (edge id: '",wSe="target",k4t="sourcePoint",E4t="targetPoint",zG="group",_i="name",T4t="connectableShape cannot be null",C4t="edge cannot be null",Xfe="Passed edge is not 'simple'.",qG="org.eclipse.elk.graph.util",WP="The 'no duplicates' constraint is violated",Qfe="targetIndex=",av=", size=",Jfe="sourceIndex=",Bd={3:1,4:1,20:1,31:1,56:1,16:1,15:1,59:1,70:1,66:1,61:1},Zfe={3:1,4:1,20:1,31:1,56:1,16:1,51:1,15:1,59:1,70:1,66:1,61:1,596:1},HG="logging",S4t="measureExecutionTime",_4t="parser.parse.1",A4t="parser.parse.2",VG="parser.next.1",e0e="parser.next.2",L4t="parser.next.3",M4t="parser.next.4",ov="parser.factor.1",ySe="parser.factor.2",D4t="parser.factor.3",I4t="parser.factor.4",O4t="parser.factor.5",N4t="parser.factor.6",P4t="parser.atom.1",B4t="parser.atom.2",F4t="parser.atom.3",xSe="parser.atom.4",t0e="parser.atom.5",kSe="parser.cc.1",UG="parser.cc.2",R4t="parser.cc.3",j4t="parser.cc.5",ESe="parser.cc.6",TSe="parser.cc.7",n0e="parser.cc.8",$4t="parser.ope.1",z4t="parser.ope.2",q4t="parser.ope.3",w2="parser.descape.1",H4t="parser.descape.2",V4t="parser.descape.3",U4t="parser.descape.4",G4t="parser.descape.5",bf="parser.process.1",K4t="parser.quantifier.1",W4t="parser.quantifier.2",Y4t="parser.quantifier.3",X4t="parser.quantifier.4",CSe="parser.quantifier.5",Q4t="org.eclipse.emf.common.notify",SSe={424:1,686:1},J4t={3:1,4:1,20:1,31:1,56:1,16:1,15:1,70:1,61:1},YP={378:1,152:1},CL="index=",r0e={3:1,4:1,5:1,129:1},Z4t={3:1,4:1,20:1,31:1,56:1,16:1,15:1,59:1,70:1,61:1},_Se={3:1,6:1,4:1,5:1,198:1},e5t={3:1,4:1,5:1,173:1,379:1},t5t=";/?:@&=+$,",n5t="invalid authority: ",r5t="EAnnotation",i5t="ETypedElement",s5t="EStructuralFeature",a5t="EAttribute",o5t="EClassifier",c5t="EEnumLiteral",u5t="EGenericType",l5t="EOperation",h5t="EParameter",f5t="EReference",d5t="ETypeParameter",us="org.eclipse.emf.ecore.util",i0e={79:1},ASe={3:1,20:1,16:1,15:1,61:1,597:1,79:1,71:1,97:1},g5t="org.eclipse.emf.ecore.util.FeatureMap$Entry",Sl=8192,r4=2048,SL="byte",GG="char",_L="double",AL="float",LL="int",ML="long",DL="short",p5t="java.lang.Object",S6={3:1,4:1,5:1,254:1},LSe={3:1,4:1,5:1,688:1},b5t={3:1,4:1,20:1,31:1,56:1,16:1,15:1,59:1,70:1,66:1,61:1,71:1},kc={3:1,4:1,20:1,31:1,56:1,16:1,15:1,59:1,70:1,66:1,61:1,79:1,71:1,97:1},XP="mixed",li="http:///org/eclipse/emf/ecore/util/ExtendedMetaData",Bf="kind",m5t={3:1,4:1,5:1,689:1},MSe={3:1,4:1,20:1,31:1,56:1,16:1,15:1,70:1,61:1,79:1,71:1,97:1},KG={20:1,31:1,56:1,16:1,15:1,61:1,71:1},WG={51:1,128:1,287:1},YG={76:1,343:1},XG="The value of type '",QG="' must be of type '",_6=1352,Ff="http://www.eclipse.org/emf/2002/Ecore",JG=-32768,n3="constraints",ho="baseType",v5t="getEStructuralFeature",w5t="getFeatureID",IL="feature",y5t="getOperationID",DSe="operation",x5t="defaultValue",k5t="eTypeParameters",E5t="isInstance",T5t="getEEnumLiteral",C5t="eContainingClass",yi={57:1},S5t={3:1,4:1,5:1,124:1},_5t="org.eclipse.emf.ecore.resource",A5t={94:1,93:1,599:1,2034:1},s0e="org.eclipse.emf.ecore.resource.impl",ISe="unspecified",QP="simple",ZG="attribute",L5t="attributeWildcard",eK="element",a0e="elementWildcard",s1="collapse",o0e="itemType",tK="namespace",JP="##targetNamespace",Rf="whiteSpace",OSe="wildcards",cv="http://www.eclipse.org/emf/2003/XMLType",c0e="##any",ET="uninitialized",ZP="The multiplicity constraint is violated",nK="org.eclipse.emf.ecore.xml.type",M5t="ProcessingInstruction",D5t="SimpleAnyType",I5t="XMLTypeDocumentRoot",ea="org.eclipse.emf.ecore.xml.type.impl",eB="INF",O5t="processing",N5t="ENTITIES_._base",NSe="minLength",PSe="ENTITY",rK="NCName",P5t="IDREFS_._base",BSe="integer",u0e="token",l0e="pattern",B5t="[a-zA-Z]{1,8}(-[a-zA-Z0-9]{1,8})*",FSe="\\i\\c*",F5t="[\\i-[:]][\\c-[:]]*",R5t="nonPositiveInteger",tB="maxInclusive",RSe="NMTOKEN",j5t="NMTOKENS_._base",jSe="nonNegativeInteger",nB="minInclusive",$5t="normalizedString",z5t="unsignedByte",q5t="unsignedInt",H5t="18446744073709551615",V5t="unsignedShort",U5t="processingInstruction",y2="org.eclipse.emf.ecore.xml.type.internal",TT=1114111,G5t="Internal Error: shorthands: \\u",OL="xml:isDigit",h0e="xml:isWord",f0e="xml:isSpace",d0e="xml:isNameChar",g0e="xml:isInitialNameChar",K5t="09٠٩۰۹०९০৯੦੯૦૯୦୯௧௯౦౯೦೯൦൯๐๙໐໙༠༩",W5t="AZazÀÖØöøıĴľŁňŊžƀǃǍǰǴǵǺȗɐʨʻˁΆΆΈΊΌΌΎΡΣώϐϖϚϚϜϜϞϞϠϠϢϳЁЌЎяёќўҁҐӄӇӈӋӌӐӫӮӵӸӹԱՖՙՙաֆאתװײءغفيٱڷںھۀێېۓەەۥۦअहऽऽक़ॡঅঌএঐওনপরললশহড়ঢ়য়ৡৰৱਅਊਏਐਓਨਪਰਲਲ਼ਵਸ਼ਸਹਖ਼ੜਫ਼ਫ਼ੲੴઅઋઍઍએઑઓનપરલળવહઽઽૠૠଅଌଏଐଓନପରଲଳଶହଽଽଡ଼ଢ଼ୟୡஅஊஎஐஒகஙசஜஜஞடணதநபமவஷஹఅఌఎఐఒనపళవహౠౡಅಌಎಐಒನಪಳವಹೞೞೠೡഅഌഎഐഒനപഹൠൡกฮะะาำเๅກຂຄຄງຈຊຊຍຍດທນຟມຣລລວວສຫອຮະະາຳຽຽເໄཀཇཉཀྵႠჅაჶᄀᄀᄂᄃᄅᄇᄉᄉᄋᄌᄎᄒᄼᄼᄾᄾᅀᅀᅌᅌᅎᅎᅐᅐᅔᅕᅙᅙᅟᅡᅣᅣᅥᅥᅧᅧᅩᅩᅭᅮᅲᅳᅵᅵᆞᆞᆨᆨᆫᆫᆮᆯᆷᆸᆺᆺᆼᇂᇫᇫᇰᇰᇹᇹḀẛẠỹἀἕἘἝἠὅὈὍὐὗὙὙὛὛὝὝὟώᾀᾴᾶᾼιιῂῄῆῌῐΐῖΊῠῬῲῴῶῼΩΩKÅ℮℮ↀↂ〇〇〡〩ぁゔァヺㄅㄬ一龥가힣",Y5t="Private Use",p0e="ASSIGNED",b0e="\0€ÿĀſƀɏɐʯʰ˿̀ͯͰϿЀӿ԰֏֐׿؀ۿ܀ݏހ޿ऀॿঀ৿਀੿઀૿଀୿஀௿ఀ౿ಀ೿ഀൿ඀෿฀๿຀໿ༀ࿿က႟Ⴀჿᄀᇿሀ፿Ꭰ᏿᐀ᙿ ᚟ᚠ᛿ក៿᠀᢯Ḁỿἀ῿ ⁰₟₠⃏⃐⃿℀⅏⅐↏←⇿∀⋿⌀⏿␀␿⑀⑟①⓿─╿▀▟■◿☀⛿✀➿⠀⣿⺀⻿⼀⿟⿰⿿ 〿぀ゟ゠ヿ㄀ㄯ㄰㆏㆐㆟ㆠㆿ㈀㋿㌀㏿㐀䶵一鿿ꀀ꒏꒐꓏가힣豈﫿ffﭏﭐ﷿︠︯︰﹏﹐﹯ﹰ﻾\uFEFF\uFEFF＀￯",$Se="UNASSIGNED",CT={3:1,122:1},X5t="org.eclipse.emf.ecore.xml.type.util",iK={3:1,4:1,5:1,381:1},zSe="org.eclipse.xtext.xbase.lib",Q5t="Cannot add elements to a Range",J5t="Cannot set elements in a Range",Z5t="Cannot remove elements from a Range",e6t="user.agent",h,sK,m0e;b.goog=b.goog||{},b.goog.global=b.goog.global||b,sK={},D(1,null,{},T),h.Fb=function(t){return Jtt(this,t)},h.Gb=function(){return this.Rm},h.Hb=function(){return fw(this)},h.Ib=function(){var t;return _m(bh(this))+"@"+(t=es(this)>>>0,t.toString(16))},h.equals=function(e){return this.Fb(e)},h.hashCode=function(){return this.Hb()},h.toString=function(){return this.Ib()};var t6t,n6t,r6t;D(297,1,{297:1,2124:1},B7e),h.ve=function(t){var n;return n=new B7e,n.i=4,t>1?n.c=yot(this,t-1):n.c=this,n},h.we=function(){return Gg(this),this.b},h.xe=function(){return _m(this)},h.ye=function(){return Gg(this),this.k},h.ze=function(){return(this.i&4)!=0},h.Ae=function(){return(this.i&1)!=0},h.Ib=function(){return K6e(this)},h.i=0;var wa=I(Vc,"Object",1),qSe=I(Vc,"Class",297);D(2096,1,yP),I(xP,"Optional",2096),D(1191,2096,yP,_),h.Fb=function(t){return t===this},h.Hb=function(){return 2040732332},h.Ib=function(){return"Optional.absent()"},h.Jb=function(t){return Xr(t),o_(),v0e};var v0e;I(xP,"Absent",1191),D(636,1,{},Zie),I(xP,"Joiner",636);var oOn=ks(xP,"Predicate");D(589,1,{178:1,589:1,3:1,46:1},gz),h.Mb=function(t){return y0t(this,t)},h.Lb=function(t){return y0t(this,t)},h.Fb=function(t){var n;return De(t,589)?(n=l(t,589),O9e(this.a,n.a)):!1},h.Hb=function(){return q7e(this.a)+306654252},h.Ib=function(){return K9n(this.a)},I(xP,"Predicates/AndPredicate",589),D(419,2096,{419:1,3:1},JS),h.Fb=function(t){var n;return De(t,419)?(n=l(t,419),Pi(this.a,n.a)):!1},h.Hb=function(){return 1502476572+es(this.a)},h.Ib=function(){return Awt+this.a+")"},h.Jb=function(t){return new JS(_H(t.Kb(this.a),"the Function passed to Optional.transform() must not return null."))},I(xP,"Present",419),D(204,1,eT),h.Nb=function(t){Za(this,t)},h.Qb=function(){jJe()},I(dn,"UnmodifiableIterator",204),D(2076,204,tT),h.Qb=function(){jJe()},h.Rb=function(t){throw ue(new Qr)},h.Wb=function(t){throw ue(new Qr)},I(dn,"UnmodifiableListIterator",2076),D(399,2076,tT),h.Ob=function(){return this.c0},h.Pb=function(){if(this.c>=this.d)throw ue(new _c);return this.Xb(this.c++)},h.Tb=function(){return this.c},h.Ub=function(){if(this.c<=0)throw ue(new _c);return this.Xb(--this.c)},h.Vb=function(){return this.c-1},h.c=0,h.d=0,I(dn,"AbstractIndexedListIterator",399),D(713,204,eT),h.Ob=function(){return tce(this)},h.Pb=function(){return z6e(this)},h.e=1,I(dn,"AbstractIterator",713),D(2084,1,{229:1}),h.Zb=function(){var t;return t=this.f,t||(this.f=this.ac())},h.Fb=function(t){return Ece(this,t)},h.Hb=function(){return es(this.Zb())},h.dc=function(){return this.gc()==0},h.ec=function(){return W8(this)},h.Ib=function(){return xc(this.Zb())},I(dn,"AbstractMultimap",2084),D(742,2084,Jm),h.$b=function(){mV(this)},h._b=function(t){return iZe(this,t)},h.ac=function(){return new Lk(this,this.c)},h.ic=function(t){return this.hc()},h.bc=function(){return new q5(this,this.c)},h.jc=function(){return this.mc(this.hc())},h.kc=function(){return new EJe(this)},h.lc=function(){return Iue(this.c.vc().Nc(),new P,64,this.d)},h.cc=function(t){return $i(this,t)},h.fc=function(t){return DN(this,t)},h.gc=function(){return this.d},h.mc=function(t){return Cn(),new $a(t)},h.nc=function(){return new kJe(this)},h.oc=function(){return Iue(this.c.Cc().Nc(),new A,64,this.d)},h.pc=function(t,n){return new YH(this,t,n,null)},h.d=0,I(dn,"AbstractMapBasedMultimap",742),D(1696,742,Jm),h.hc=function(){return new Bu(this.a)},h.jc=function(){return Cn(),Cn(),_o},h.cc=function(t){return l($i(this,t),15)},h.fc=function(t){return l(DN(this,t),15)},h.Zb=function(){return ex(this)},h.Fb=function(t){return Ece(this,t)},h.qc=function(t){return l($i(this,t),15)},h.rc=function(t){return l(DN(this,t),15)},h.mc=function(t){return ioe(l(t,15))},h.pc=function(t,n){return _ct(this,t,l(n,15),null)},I(dn,"AbstractListMultimap",1696),D(748,1,Oa),h.Nb=function(t){Za(this,t)},h.Ob=function(){return this.c.Ob()||this.e.Ob()},h.Pb=function(){var t;return this.e.Ob()||(t=l(this.c.Pb(),44),this.b=t.ld(),this.a=l(t.md(),16),this.e=this.a.Kc()),this.sc(this.b,this.e.Pb())},h.Qb=function(){this.e.Qb(),l(Lf(this.a),16).dc()&&this.c.Qb(),--this.d.d},I(dn,"AbstractMapBasedMultimap/Itr",748),D(1129,748,Oa,kJe),h.sc=function(t,n){return n},I(dn,"AbstractMapBasedMultimap/1",1129),D(1130,1,{},A),h.Kb=function(t){return l(t,16).Nc()},I(dn,"AbstractMapBasedMultimap/1methodref$spliterator$Type",1130),D(1131,748,Oa,EJe),h.sc=function(t,n){return new iw(t,n)},I(dn,"AbstractMapBasedMultimap/2",1131);var HSe=ks(Lr,"Map");D(2065,1,Ww),h.wc=function(t){mA(this,t)},h.yc=function(t,n,r){return qce(this,t,n,r)},h.$b=function(){this.vc().$b()},h.tc=function(t){return gue(this,t)},h._b=function(t){return!!Dxe(this,t,!1)},h.uc=function(t){var n,r,a;for(r=this.vc().Kc();r.Ob();)if(n=l(r.Pb(),44),a=n.md(),qe(t)===qe(a)||t!=null&&Pi(t,a))return!0;return!1},h.Fb=function(t){var n,r,a;if(t===this)return!0;if(!De(t,85)||(a=l(t,85),this.gc()!=a.gc()))return!1;for(r=a.vc().Kc();r.Ob();)if(n=l(r.Pb(),44),!this.tc(n))return!1;return!0},h.xc=function(t){return hc(Dxe(this,t,!1))},h.Hb=function(){return I7e(this.vc())},h.dc=function(){return this.gc()==0},h.ec=function(){return new br(this)},h.zc=function(t,n){throw ue(new Hp("Put not supported on this map"))},h.Ac=function(t){bA(this,t)},h.Bc=function(t){return hc(Dxe(this,t,!0))},h.gc=function(){return this.vc().gc()},h.Ib=function(){return Igt(this)},h.Cc=function(){return new gi(this)},I(Lr,"AbstractMap",2065),D(2085,2065,Ww),h.bc=function(){return new Yz(this)},h.vc=function(){return Est(this)},h.ec=function(){var t;return t=this.g,t||(this.g=this.bc())},h.Cc=function(){var t;return t=this.i,t||(this.i=new WZe(this))},I(dn,"Maps/ViewCachingAbstractMap",2085),D(402,2085,Ww,Lk),h.xc=function(t){return fwn(this,t)},h.Bc=function(t){return Pyn(this,t)},h.$b=function(){this.d==this.e.c?this.e.$b():iH(new V4e(this))},h._b=function(t){return i1t(this.d,t)},h.Ec=function(){return new pz(this)},h.Dc=function(){return this.Ec()},h.Fb=function(t){return this===t||Pi(this.d,t)},h.Hb=function(){return es(this.d)},h.ec=function(){return this.e.ec()},h.gc=function(){return this.d.gc()},h.Ib=function(){return xc(this.d)},I(dn,"AbstractMapBasedMultimap/AsMap",402);var Fh=ks(Vc,"Iterable");D(31,1,Wy),h.Jc=function(t){to(this,t)},h.Lc=function(){return this.Oc()},h.Nc=function(){return new kn(this,0)},h.Oc=function(){return new bn(null,this.Nc())},h.Fc=function(t){throw ue(new Hp("Add not supported on this collection"))},h.Gc=function(t){return Ka(this,t)},h.$b=function(){M5e(this)},h.Hc=function(t){return Ny(this,t,!1)},h.Ic=function(t){return EN(this,t)},h.dc=function(){return this.gc()==0},h.Mc=function(t){return Ny(this,t,!0)},h.Pc=function(){return e5e(this)},h.Qc=function(t){return PA(this,t)},h.Ib=function(){return Tb(this)},I(Lr,"AbstractCollection",31);var jf=ks(Lr,"Set");D(q1,31,Tl),h.Nc=function(){return new kn(this,1)},h.Fb=function(t){return Y1t(this,t)},h.Hb=function(){return I7e(this)},I(Lr,"AbstractSet",q1),D(2068,q1,Tl),I(dn,"Sets/ImprovedAbstractSet",2068),D(2069,2068,Tl),h.$b=function(){this.Rc().$b()},h.Hc=function(t){return O1t(this,t)},h.dc=function(){return this.Rc().dc()},h.Mc=function(t){var n;return this.Hc(t)&&De(t,44)?(n=l(t,44),this.Rc().ec().Mc(n.ld())):!1},h.gc=function(){return this.Rc().gc()},I(dn,"Maps/EntrySet",2069),D(1127,2069,Tl,pz),h.Hc=function(t){return s8e(this.a.d.vc(),t)},h.Kc=function(){return new V4e(this.a)},h.Rc=function(){return this.a},h.Mc=function(t){var n;return s8e(this.a.d.vc(),t)?(n=l(Lf(l(t,44)),44),evn(this.a.e,n.ld()),!0):!1},h.Nc=function(){return NO(this.a.d.vc().Nc(),new bz(this.a))},I(dn,"AbstractMapBasedMultimap/AsMap/AsMapEntries",1127),D(1128,1,{},bz),h.Kb=function(t){return Cut(this.a,l(t,44))},I(dn,"AbstractMapBasedMultimap/AsMap/AsMapEntries/0methodref$wrapEntry$Type",1128),D(746,1,Oa,V4e),h.Nb=function(t){Za(this,t)},h.Pb=function(){var t;return t=l(this.b.Pb(),44),this.a=l(t.md(),16),Cut(this.c,t)},h.Ob=function(){return this.b.Ob()},h.Qb=function(){Rk(!!this.a),this.b.Qb(),this.c.e.d-=this.a.gc(),this.a.$b(),this.a=null},I(dn,"AbstractMapBasedMultimap/AsMap/AsMapIterator",746),D(542,2068,Tl,Yz),h.$b=function(){this.b.$b()},h.Hc=function(t){return this.b._b(t)},h.Jc=function(t){Xr(t),this.b.wc(new xz(t))},h.dc=function(){return this.b.dc()},h.Kc=function(){return new c_(this.b.vc().Kc())},h.Mc=function(t){return this.b._b(t)?(this.b.Bc(t),!0):!1},h.gc=function(){return this.b.gc()},I(dn,"Maps/KeySet",542),D(327,542,Tl,q5),h.$b=function(){var t;iH((t=this.b.vc().Kc(),new g3e(this,t)))},h.Ic=function(t){return this.b.ec().Ic(t)},h.Fb=function(t){return this===t||Pi(this.b.ec(),t)},h.Hb=function(){return es(this.b.ec())},h.Kc=function(){var t;return t=this.b.vc().Kc(),new g3e(this,t)},h.Mc=function(t){var n,r;return r=0,n=l(this.b.Bc(t),16),n&&(r=n.gc(),n.$b(),this.a.d-=r),r>0},h.Nc=function(){return this.b.ec().Nc()},I(dn,"AbstractMapBasedMultimap/KeySet",327),D(747,1,Oa,g3e),h.Nb=function(t){Za(this,t)},h.Ob=function(){return this.c.Ob()},h.Pb=function(){return this.a=l(this.c.Pb(),44),this.a.ld()},h.Qb=function(){var t;Rk(!!this.a),t=l(this.a.md(),16),this.c.Qb(),this.b.a.d-=t.gc(),t.$b(),this.a=null},I(dn,"AbstractMapBasedMultimap/KeySet/1",747),D(503,402,{85:1,133:1},_O),h.bc=function(){return this.Sc()},h.ec=function(){return this.Uc()},h.Sc=function(){return new tO(this.c,this.Wc())},h.Tc=function(){return this.Wc().Tc()},h.Uc=function(){var t;return t=this.b,t||(this.b=this.Sc())},h.Vc=function(){return this.Wc().Vc()},h.Wc=function(){return l(this.d,133)},I(dn,"AbstractMapBasedMultimap/SortedAsMap",503),D(446,503,Zke,q_),h.bc=function(){return new Ak(this.a,l(l(this.d,133),139))},h.Sc=function(){return new Ak(this.a,l(l(this.d,133),139))},h.ec=function(){var t;return t=this.b,l(t||(this.b=new Ak(this.a,l(l(this.d,133),139))),277)},h.Uc=function(){var t;return t=this.b,l(t||(this.b=new Ak(this.a,l(l(this.d,133),139))),277)},h.Wc=function(){return l(l(this.d,133),139)},h.Xc=function(t){return l(l(this.d,133),139).Xc(t)},h.Yc=function(t){return l(l(this.d,133),139).Yc(t)},h.Zc=function(t,n){return new q_(this.a,l(l(this.d,133),139).Zc(t,n))},h.$c=function(t){return l(l(this.d,133),139).$c(t)},h._c=function(t){return l(l(this.d,133),139)._c(t)},h.ad=function(t,n){return new q_(this.a,l(l(this.d,133),139).ad(t,n))},I(dn,"AbstractMapBasedMultimap/NavigableAsMap",446),D(502,327,Lwt,tO),h.Nc=function(){return this.b.ec().Nc()},I(dn,"AbstractMapBasedMultimap/SortedKeySet",502),D(401,502,eEe,Ak),I(dn,"AbstractMapBasedMultimap/NavigableKeySet",401),D(551,31,Wy,YH),h.Fc=function(t){var n,r;return Ql(this),r=this.d.dc(),n=this.d.Fc(t),n&&(++this.f.d,r&&DO(this)),n},h.Gc=function(t){var n,r,a;return t.dc()?!1:(a=(Ql(this),this.d.gc()),n=this.d.Gc(t),n&&(r=this.d.gc(),this.f.d+=r-a,a==0&&DO(this)),n)},h.$b=function(){var t;t=(Ql(this),this.d.gc()),t!=0&&(this.d.$b(),this.f.d-=t,lH(this))},h.Hc=function(t){return Ql(this),this.d.Hc(t)},h.Ic=function(t){return Ql(this),this.d.Ic(t)},h.Fb=function(t){return t===this?!0:(Ql(this),Pi(this.d,t))},h.Hb=function(){return Ql(this),es(this.d)},h.Kc=function(){return Ql(this),new _4e(this)},h.Mc=function(t){var n;return Ql(this),n=this.d.Mc(t),n&&(--this.f.d,lH(this)),n},h.gc=function(){return Rtt(this)},h.Nc=function(){return Ql(this),this.d.Nc()},h.Ib=function(){return Ql(this),xc(this.d)},I(dn,"AbstractMapBasedMultimap/WrappedCollection",551);var mf=ks(Lr,"List");D(744,551,{20:1,31:1,16:1,15:1},r5e),h.jd=function(t){$m(this,t)},h.Nc=function(){return Ql(this),this.d.Nc()},h.bd=function(t,n){var r;Ql(this),r=this.d.dc(),l(this.d,15).bd(t,n),++this.a.d,r&&DO(this)},h.cd=function(t,n){var r,a,o;return n.dc()?!1:(o=(Ql(this),this.d.gc()),r=l(this.d,15).cd(t,n),r&&(a=this.d.gc(),this.a.d+=a-o,o==0&&DO(this)),r)},h.Xb=function(t){return Ql(this),l(this.d,15).Xb(t)},h.dd=function(t){return Ql(this),l(this.d,15).dd(t)},h.ed=function(){return Ql(this),new gnt(this)},h.fd=function(t){return Ql(this),new Fat(this,t)},h.gd=function(t){var n;return Ql(this),n=l(this.d,15).gd(t),--this.a.d,lH(this),n},h.hd=function(t,n){return Ql(this),l(this.d,15).hd(t,n)},h.kd=function(t,n){return Ql(this),_ct(this.a,this.e,l(this.d,15).kd(t,n),this.b?this.b:this)},I(dn,"AbstractMapBasedMultimap/WrappedList",744),D(1126,744,{20:1,31:1,16:1,15:1,59:1},rrt),I(dn,"AbstractMapBasedMultimap/RandomAccessWrappedList",1126),D(628,1,Oa,_4e),h.Nb=function(t){Za(this,t)},h.Ob=function(){return Yk(this),this.b.Ob()},h.Pb=function(){return Yk(this),this.b.Pb()},h.Qb=function(){znt(this)},I(dn,"AbstractMapBasedMultimap/WrappedCollection/WrappedIterator",628),D(745,628,lg,gnt,Fat),h.Qb=function(){znt(this)},h.Rb=function(t){var n;n=Rtt(this.a)==0,(Yk(this),l(this.b,128)).Rb(t),++this.a.a.d,n&&DO(this.a)},h.Sb=function(){return(Yk(this),l(this.b,128)).Sb()},h.Tb=function(){return(Yk(this),l(this.b,128)).Tb()},h.Ub=function(){return(Yk(this),l(this.b,128)).Ub()},h.Vb=function(){return(Yk(this),l(this.b,128)).Vb()},h.Wb=function(t){(Yk(this),l(this.b,128)).Wb(t)},I(dn,"AbstractMapBasedMultimap/WrappedList/WrappedListIterator",745),D(743,551,Lwt,Gye),h.Nc=function(){return Ql(this),this.d.Nc()},I(dn,"AbstractMapBasedMultimap/WrappedSortedSet",743),D(1125,743,eEe,unt),I(dn,"AbstractMapBasedMultimap/WrappedNavigableSet",1125),D(1124,551,Tl,Trt),h.Nc=function(){return Ql(this),this.d.Nc()},I(dn,"AbstractMapBasedMultimap/WrappedSet",1124),D(1133,1,{},P),h.Kb=function(t){return lvn(l(t,44))},I(dn,"AbstractMapBasedMultimap/lambda$1$Type",1133),D(1132,1,{},bie),h.Kb=function(t){return new iw(this.a,t)},I(dn,"AbstractMapBasedMultimap/lambda$2$Type",1132);var uv=ks(Lr,"Map/Entry");D(358,1,Nle),h.Fb=function(t){var n;return De(t,44)?(n=l(t,44),yd(this.ld(),n.ld())&&yd(this.md(),n.md())):!1},h.Hb=function(){var t,n;return t=this.ld(),n=this.md(),(t==null?0:es(t))^(n==null?0:es(n))},h.nd=function(t){throw ue(new Qr)},h.Ib=function(){return this.ld()+"="+this.md()},I(dn,Mwt,358),D(2086,31,Wy),h.$b=function(){this.od().$b()},h.Hc=function(t){var n;return De(t,44)?(n=l(t,44),Dbn(this.od(),n.ld(),n.md())):!1},h.Mc=function(t){var n;return De(t,44)?(n=l(t,44),cct(this.od(),n.ld(),n.md())):!1},h.gc=function(){return this.od().d},I(dn,"Multimaps/Entries",2086),D(749,2086,Wy,vz),h.Kc=function(){return this.a.kc()},h.od=function(){return this.a},h.Nc=function(){return this.a.lc()},I(dn,"AbstractMultimap/Entries",749),D(750,749,Tl,Uwe),h.Nc=function(){return this.a.lc()},h.Fb=function(t){return Qxe(this,t)},h.Hb=function(){return wft(this)},I(dn,"AbstractMultimap/EntrySet",750),D(751,31,Wy,Q2),h.$b=function(){this.a.$b()},h.Hc=function(t){return Lyn(this.a,t)},h.Kc=function(){return this.a.nc()},h.gc=function(){return this.a.d},h.Nc=function(){return this.a.oc()},I(dn,"AbstractMultimap/Values",751),D(2087,31,{849:1,20:1,31:1,16:1}),h.Jc=function(t){Xr(t),V5(this).Jc(new kie(t))},h.Nc=function(){var t;return t=V5(this).Nc(),Iue(t,new pe,64|t.yd()&1296,this.a.d)},h.Fc=function(t){return Zwe(),!0},h.Gc=function(t){return Xr(this),Xr(t),De(t,552)?Nbn(l(t,849)):!t.dc()&&Goe(this,t.Kc())},h.Hc=function(t){var n;return n=l(Oy(ex(this.a),t),16),(n?n.gc():0)>0},h.Fb=function(t){return nTn(this,t)},h.Hb=function(){return es(V5(this))},h.dc=function(){return V5(this).dc()},h.Mc=function(t){return Upt(this,t,1)>0},h.Ib=function(){return xc(V5(this))},I(dn,"AbstractMultiset",2087),D(2089,2068,Tl),h.$b=function(){mV(this.a.a)},h.Hc=function(t){var n,r;return De(t,504)?(r=l(t,425),l(r.a.md(),16).gc()<=0?!1:(n=Pot(this.a,r.a.ld()),n==l(r.a.md(),16).gc())):!1},h.Mc=function(t){var n,r,a,o;return De(t,504)&&(r=l(t,425),n=r.a.ld(),a=l(r.a.md(),16).gc(),a!=0)?(o=this.a,Gkn(o,n,a)):!1},I(dn,"Multisets/EntrySet",2089),D(1139,2089,Tl,mie),h.Kc=function(){return new AJe(Est(ex(this.a.a)).Kc())},h.gc=function(){return ex(this.a.a).gc()},I(dn,"AbstractMultiset/EntrySet",1139),D(627,742,Jm),h.hc=function(){return this.pd()},h.jc=function(){return this.qd()},h.cc=function(t){return this.rd(t)},h.fc=function(t){return this.sd(t)},h.Zb=function(){var t;return t=this.f,t||(this.f=this.ac())},h.qd=function(){return Cn(),Cn(),hK},h.Fb=function(t){return Ece(this,t)},h.rd=function(t){return l($i(this,t),21)},h.sd=function(t){return l(DN(this,t),21)},h.mc=function(t){return Cn(),new Ek(l(t,21))},h.pc=function(t,n){return new Trt(this,t,l(n,21))},I(dn,"AbstractSetMultimap",627),D(1723,627,Jm),h.hc=function(){return new Kp(this.b)},h.pd=function(){return new Kp(this.b)},h.jc=function(){return T5e(new Kp(this.b))},h.qd=function(){return T5e(new Kp(this.b))},h.cc=function(t){return l(l($i(this,t),21),87)},h.rd=function(t){return l(l($i(this,t),21),87)},h.fc=function(t){return l(l(DN(this,t),21),87)},h.sd=function(t){return l(l(DN(this,t),21),87)},h.mc=function(t){return De(t,277)?T5e(l(t,277)):(Cn(),new Dye(l(t,87)))},h.Zb=function(){var t;return t=this.f,t||(this.f=De(this.c,139)?new q_(this,l(this.c,139)):De(this.c,133)?new _O(this,l(this.c,133)):new Lk(this,this.c))},h.pc=function(t,n){return De(n,277)?new unt(this,t,l(n,277)):new Gye(this,t,l(n,87))},I(dn,"AbstractSortedSetMultimap",1723),D(1724,1723,Jm),h.Zb=function(){var t;return t=this.f,l(l(t||(this.f=De(this.c,139)?new q_(this,l(this.c,139)):De(this.c,133)?new _O(this,l(this.c,133)):new Lk(this,this.c)),133),139)},h.ec=function(){var t;return t=this.i,l(l(t||(this.i=De(this.c,139)?new Ak(this,l(this.c,139)):De(this.c,133)?new tO(this,l(this.c,133)):new q5(this,this.c)),87),277)},h.bc=function(){return De(this.c,139)?new Ak(this,l(this.c,139)):De(this.c,133)?new tO(this,l(this.c,133)):new q5(this,this.c)},I(dn,"AbstractSortedKeySortedSetMultimap",1724),D(2109,1,{2046:1}),h.Fb=function(t){return _8n(this,t)},h.Hb=function(){var t;return I7e((t=this.g,t||(this.g=new $I(this))))},h.Ib=function(){var t;return Igt((t=this.f,t||(this.f=new _ye(this))))},I(dn,"AbstractTable",2109),D(679,q1,Tl,$I),h.$b=function(){$Je()},h.Hc=function(t){var n,r;return De(t,479)?(n=l(t,697),r=l(Oy(Kst(this.a),ab(n.c.e,n.b)),85),!!r&&s8e(r.vc(),new iw(ab(n.c.c,n.a),ox(n.c,n.b,n.a)))):!1},h.Kc=function(){return Dpn(this.a)},h.Mc=function(t){var n,r;return De(t,479)?(n=l(t,697),r=l(Oy(Kst(this.a),ab(n.c.e,n.b)),85),!!r&&c4n(r.vc(),new iw(ab(n.c.c,n.a),ox(n.c,n.b,n.a)))):!1},h.gc=function(){return Xit(this.a)},h.Nc=function(){return Fbn(this.a)},I(dn,"AbstractTable/CellSet",679),D(2025,31,Wy,wie),h.$b=function(){$Je()},h.Hc=function(t){return wxn(this.a,t)},h.Kc=function(){return Ipn(this.a)},h.gc=function(){return Xit(this.a)},h.Nc=function(){return oct(this.a)},I(dn,"AbstractTable/Values",2025),D(1697,1696,Jm),I(dn,"ArrayListMultimapGwtSerializationDependencies",1697),D(520,1697,Jm,nse,G5e),h.hc=function(){return new Bu(this.a)},h.a=0,I(dn,"ArrayListMultimap",520),D(678,2109,{678:1,2046:1,3:1},i2t),I(dn,"ArrayTable",678),D(2021,399,tT,qnt),h.Xb=function(t){return new F7e(this.a,t)},I(dn,"ArrayTable/1",2021),D(2022,1,{},gie),h.td=function(t){return new F7e(this.a,t)},I(dn,"ArrayTable/1methodref$getCell$Type",2022),D(2110,1,{697:1}),h.Fb=function(t){var n;return t===this?!0:De(t,479)?(n=l(t,697),yd(ab(this.c.e,this.b),ab(n.c.e,n.b))&&yd(ab(this.c.c,this.a),ab(n.c.c,n.a))&&yd(ox(this.c,this.b,this.a),ox(n.c,n.b,n.a))):!1},h.Hb=function(){return MN(he(le(wa,1),Rn,1,5,[ab(this.c.e,this.b),ab(this.c.c,this.a),ox(this.c,this.b,this.a)]))},h.Ib=function(){return"("+ab(this.c.e,this.b)+","+ab(this.c.c,this.a)+")="+ox(this.c,this.b,this.a)},I(dn,"Tables/AbstractCell",2110),D(479,2110,{479:1,697:1},F7e),h.a=0,h.b=0,h.d=0,I(dn,"ArrayTable/2",479),D(2024,1,{},pie),h.td=function(t){return Ilt(this.a,t)},I(dn,"ArrayTable/2methodref$getValue$Type",2024),D(2023,399,tT,Hnt),h.Xb=function(t){return Ilt(this.a,t)},I(dn,"ArrayTable/3",2023),D(2077,2065,Ww),h.$b=function(){iH(this.kc())},h.vc=function(){return new yz(this)},h.lc=function(){return new _at(this.kc(),this.gc())},I(dn,"Maps/IteratorBasedAbstractMap",2077),D(842,2077,Ww),h.$b=function(){throw ue(new Qr)},h._b=function(t){return sZe(this.c,t)},h.kc=function(){return new Vnt(this,this.c.b.c.gc())},h.lc=function(){return Cae(this.c.b.c.gc(),16,new mz(this))},h.xc=function(t){var n;return n=l(H_(this.c,t),17),n?this.vd(n.a):null},h.dc=function(){return this.c.b.c.dc()},h.ec=function(){return Oae(this.c)},h.zc=function(t,n){var r;if(r=l(H_(this.c,t),17),!r)throw ue(new Yn(this.ud()+" "+t+" not in "+Oae(this.c)));return this.wd(r.a,n)},h.Bc=function(t){throw ue(new Qr)},h.gc=function(){return this.c.b.c.gc()},I(dn,"ArrayTable/ArrayMap",842),D(2020,1,{},mz),h.td=function(t){return Yst(this.a,t)},I(dn,"ArrayTable/ArrayMap/0methodref$getEntry$Type",2020),D(2018,358,Nle,DZe),h.ld=function(){return Uhn(this.a,this.b)},h.md=function(){return this.a.vd(this.b)},h.nd=function(t){return this.a.wd(this.b,t)},h.b=0,I(dn,"ArrayTable/ArrayMap/1",2018),D(2019,399,tT,Vnt),h.Xb=function(t){return Yst(this.a,t)},I(dn,"ArrayTable/ArrayMap/2",2019),D(2017,842,Ww,Bst),h.ud=function(){return"Column"},h.vd=function(t){return ox(this.b,this.a,t)},h.wd=function(t,n){return s0t(this.b,this.a,t,n)},h.a=0,I(dn,"ArrayTable/Row",2017),D(843,842,Ww,_ye),h.vd=function(t){return new Bst(this.a,t)},h.zc=function(t,n){return l(n,85),fun()},h.wd=function(t,n){return l(n,85),dun()},h.ud=function(){return"Row"},I(dn,"ArrayTable/RowMap",843),D(1157,1,Ph,IZe),h.Ad=function(t){return(this.a.yd()&-262&t)!=0},h.yd=function(){return this.a.yd()&-262},h.zd=function(){return this.a.zd()},h.Nb=function(t){this.a.Nb(new NZe(t,this.b))},h.Bd=function(t){return this.a.Bd(new OZe(t,this.b))},I(dn,"CollectSpliterators/1",1157),D(1158,1,fr,OZe),h.Cd=function(t){this.a.Cd(this.b.Kb(t))},I(dn,"CollectSpliterators/1/lambda$0$Type",1158),D(1159,1,fr,NZe),h.Cd=function(t){this.a.Cd(this.b.Kb(t))},I(dn,"CollectSpliterators/1/lambda$1$Type",1159),D(1154,1,Ph,sit),h.Ad=function(t){return((16464|this.b)&t)!=0},h.yd=function(){return 16464|this.b},h.zd=function(){return this.a.zd()},h.Nb=function(t){this.a.Qe(new BZe(t,this.c))},h.Bd=function(t){return this.a.Re(new PZe(t,this.c))},h.b=0,I(dn,"CollectSpliterators/1WithCharacteristics",1154),D(1155,1,kP,PZe),h.Dd=function(t){this.a.Cd(this.b.td(t))},I(dn,"CollectSpliterators/1WithCharacteristics/lambda$0$Type",1155),D(1156,1,kP,BZe),h.Dd=function(t){this.a.Cd(this.b.td(t))},I(dn,"CollectSpliterators/1WithCharacteristics/lambda$1$Type",1156),D(1150,1,Ph),h.Ad=function(t){return(this.a&t)!=0},h.yd=function(){return this.a},h.zd=function(){return this.e&&(this.b=pye(this.b,this.e.zd())),pye(this.b,0)},h.Nb=function(t){this.e&&(this.e.Nb(t),this.e=null),this.c.Nb(new FZe(this,t)),this.b=0},h.Bd=function(t){for(;;){if(this.e&&this.e.Bd(t))return I_(this.b,EP)&&(this.b=Df(this.b,1)),!0;if(this.e=null,!this.c.Bd(new yie(this)))return!1}},h.a=0,h.b=0,I(dn,"CollectSpliterators/FlatMapSpliterator",1150),D(1152,1,fr,yie),h.Cd=function(t){Hfn(this.a,t)},I(dn,"CollectSpliterators/FlatMapSpliterator/lambda$0$Type",1152),D(1153,1,fr,FZe),h.Cd=function(t){gpn(this.a,this.b,t)},I(dn,"CollectSpliterators/FlatMapSpliterator/lambda$1$Type",1153),D(1151,1150,Ph,Cct),I(dn,"CollectSpliterators/FlatMapSpliteratorOfObject",1151),D(253,1,Ple),h.Fd=function(t){return this.Ed(l(t,253))},h.Ed=function(t){var n;return t==(Gie(),y0e)?1:t==(Uie(),w0e)?-1:(n=(Zq(),vN(this.a,t.a)),n!=0?n:De(this,526)==De(t,526)?0:De(this,526)?1:-1)},h.Id=function(){return this.a},h.Fb=function(t){return rxe(this,t)},I(dn,"Cut",253),D(1823,253,Ple,xJe),h.Ed=function(t){return t==this?0:1},h.Gd=function(t){throw ue(new Swe)},h.Hd=function(t){t.a+="+∞)"},h.Id=function(){throw ue(new nc(Iwt))},h.Hb=function(){return Vg(),q8e(this)},h.Jd=function(t){return!1},h.Ib=function(){return"+∞"};var w0e;I(dn,"Cut/AboveAll",1823),D(526,253,{253:1,526:1,3:1,34:1},Xnt),h.Gd=function(t){wu((t.a+="(",t),this.a)},h.Hd=function(t){hb(wu(t,this.a),93)},h.Hb=function(){return~es(this.a)},h.Jd=function(t){return Zq(),vN(this.a,t)<0},h.Ib=function(){return"/"+this.a+"\\"},I(dn,"Cut/AboveValue",526),D(1822,253,Ple,yJe),h.Ed=function(t){return t==this?0:-1},h.Gd=function(t){t.a+="(-∞"},h.Hd=function(t){throw ue(new Swe)},h.Id=function(){throw ue(new nc(Iwt))},h.Hb=function(){return Vg(),q8e(this)},h.Jd=function(t){return!0},h.Ib=function(){return"-∞"};var y0e;I(dn,"Cut/BelowAll",1822),D(1824,253,Ple,Qnt),h.Gd=function(t){wu((t.a+="[",t),this.a)},h.Hd=function(t){hb(wu(t,this.a),41)},h.Hb=function(){return es(this.a)},h.Jd=function(t){return Zq(),vN(this.a,t)<=0},h.Ib=function(){return"\\"+this.a+"/"},I(dn,"Cut/BelowValue",1824),D(547,1,hg),h.Jc=function(t){to(this,t)},h.Ib=function(){return L4n(l(_H(this,"use Optional.orNull() instead of Optional.or(null)"),20).Kc())},I(dn,"FluentIterable",547),D(442,547,hg,P_),h.Kc=function(){return new hr(dr(this.a.Kc(),new j))},I(dn,"FluentIterable/2",442),D(1059,547,hg,snt),h.Kc=function(){return rg(this)},I(dn,"FluentIterable/3",1059),D(724,399,tT,Aye),h.Xb=function(t){return this.a[t].Kc()},I(dn,"FluentIterable/3/1",724),D(2070,1,{}),h.Ib=function(){return xc(this.Kd().b)},I(dn,"ForwardingObject",2070),D(2071,2070,Owt),h.Kd=function(){return this.Ld()},h.Jc=function(t){to(this,t)},h.Lc=function(){return this.Oc()},h.Nc=function(){return new kn(this,0)},h.Oc=function(){return new bn(null,this.Nc())},h.Fc=function(t){return this.Ld(),oZe()},h.Gc=function(t){return this.Ld(),cZe()},h.$b=function(){this.Ld(),uZe()},h.Hc=function(t){return this.Ld().Hc(t)},h.Ic=function(t){return this.Ld().Ic(t)},h.dc=function(){return this.Ld().b.dc()},h.Kc=function(){return this.Ld().Kc()},h.Mc=function(t){return this.Ld(),lZe()},h.gc=function(){return this.Ld().b.gc()},h.Pc=function(){return this.Ld().Pc()},h.Qc=function(t){return this.Ld().Qc(t)},I(dn,"ForwardingCollection",2071),D(2078,31,tEe),h.Kc=function(){return this.Od()},h.Fc=function(t){throw ue(new Qr)},h.Gc=function(t){throw ue(new Qr)},h.Md=function(){var t;return t=this.c,t||(this.c=this.Nd())},h.$b=function(){throw ue(new Qr)},h.Hc=function(t){return t!=null&&Ny(this,t,!1)},h.Nd=function(){switch(this.gc()){case 0:return ww(),ww(),x0e;case 1:return ww(),new Sae(Xr(this.Od().Pb()));default:return new o5e(this,this.Pc())}},h.Mc=function(t){throw ue(new Qr)},I(dn,"ImmutableCollection",2078),D(727,2078,tEe,Twe),h.Kc=function(){return cx(this.a.Kc())},h.Hc=function(t){return t!=null&&this.a.Hc(t)},h.Ic=function(t){return this.a.Ic(t)},h.dc=function(){return this.a.dc()},h.Od=function(){return cx(this.a.Kc())},h.gc=function(){return this.a.gc()},h.Pc=function(){return this.a.Pc()},h.Qc=function(t){return this.a.Qc(t)},h.Ib=function(){return xc(this.a)},I(dn,"ForwardingImmutableCollection",727),D(307,2078,nT),h.Kc=function(){return this.Od()},h.ed=function(){return this.Pd(0)},h.fd=function(t){return this.Pd(t)},h.jd=function(t){$m(this,t)},h.Nc=function(){return new kn(this,16)},h.kd=function(t,n){return this.Qd(t,n)},h.bd=function(t,n){throw ue(new Qr)},h.cd=function(t,n){throw ue(new Qr)},h.Md=function(){return this},h.Fb=function(t){return VEn(this,t)},h.Hb=function(){return R3n(this)},h.dd=function(t){return t==null?-1:o7n(this,t)},h.Od=function(){return this.Pd(0)},h.Pd=function(t){return iae(this,t)},h.gd=function(t){throw ue(new Qr)},h.hd=function(t,n){throw ue(new Qr)},h.Qd=function(t,n){var r;return RV((r=new KZe(this),new Zp(r,t,n)))};var x0e;I(dn,"ImmutableList",307),D(2105,307,nT),h.Kc=function(){return cx(this.Rd().Kc())},h.kd=function(t,n){return RV(this.Rd().kd(t,n))},h.Hc=function(t){return t!=null&&this.Rd().Hc(t)},h.Ic=function(t){return this.Rd().Ic(t)},h.Fb=function(t){return Pi(this.Rd(),t)},h.Xb=function(t){return ab(this,t)},h.Hb=function(){return es(this.Rd())},h.dd=function(t){return this.Rd().dd(t)},h.dc=function(){return this.Rd().dc()},h.Od=function(){return cx(this.Rd().Kc())},h.gc=function(){return this.Rd().gc()},h.Qd=function(t,n){return RV(this.Rd().kd(t,n))},h.Pc=function(){return this.Rd().Qc(We(wa,Rn,1,this.Rd().gc(),5,1))},h.Qc=function(t){return this.Rd().Qc(t)},h.Ib=function(){return xc(this.Rd())},I(dn,"ForwardingImmutableList",2105),D(729,1,rT),h.vc=function(){return Mm(this)},h.wc=function(t){mA(this,t)},h.ec=function(){return Oae(this)},h.yc=function(t,n,r){return qce(this,t,n,r)},h.Cc=function(){return this.Vd()},h.$b=function(){throw ue(new Qr)},h._b=function(t){return this.xc(t)!=null},h.uc=function(t){return this.Vd().Hc(t)},h.Td=function(){return new LQe(this)},h.Ud=function(){return new MQe(this)},h.Fb=function(t){return Myn(this,t)},h.Hb=function(){return Mm(this).Hb()},h.dc=function(){return this.gc()==0},h.zc=function(t,n){return hun()},h.Bc=function(t){throw ue(new Qr)},h.Ib=function(){return m9n(this)},h.Vd=function(){return this.e?this.e:this.e=this.Ud()},h.c=null,h.d=null,h.e=null;var i6t;I(dn,"ImmutableMap",729),D(730,729,rT),h._b=function(t){return sZe(this,t)},h.uc=function(t){return ZZe(this.b,t)},h.Sd=function(){return t1t(new vie(this))},h.Td=function(){return t1t(mat(this.b))},h.Ud=function(){return wd(),new Twe(bat(this.b))},h.Fb=function(t){return eet(this.b,t)},h.xc=function(t){return H_(this,t)},h.Hb=function(){return es(this.b.c)},h.dc=function(){return this.b.c.dc()},h.gc=function(){return this.b.c.gc()},h.Ib=function(){return xc(this.b.c)},I(dn,"ForwardingImmutableMap",730),D(2072,2071,Ble),h.Kd=function(){return this.Wd()},h.Ld=function(){return this.Wd()},h.Nc=function(){return new kn(this,1)},h.Fb=function(t){return t===this||this.Wd().Fb(t)},h.Hb=function(){return this.Wd().Hb()},I(dn,"ForwardingSet",2072),D(1085,2072,Ble,vie),h.Kd=function(){return Kk(this.a.b)},h.Ld=function(){return Kk(this.a.b)},h.Hc=function(t){if(De(t,44)&&l(t,44).ld()==null)return!1;try{return JZe(Kk(this.a.b),t)}catch(n){if(n=bs(n),De(n,212))return!1;throw ue(n)}},h.Wd=function(){return Kk(this.a.b)},h.Qc=function(t){var n;return n=tot(Kk(this.a.b),t),Kk(this.a.b).b.gc()=0?"+":"")+(r/60|0),n=Iq(b.Math.abs(r)%60),(Vgt(),E6t)[this.q.getDay()]+" "+T6t[this.q.getMonth()]+" "+Iq(this.q.getDate())+" "+Iq(this.q.getHours())+":"+Iq(this.q.getMinutes())+":"+Iq(this.q.getSeconds())+" GMT"+t+n+" "+this.q.getFullYear()};var cK=I(Lr,"Date",206);D(2015,206,qwt,dgt),h.a=!1,h.b=0,h.c=0,h.d=0,h.e=0,h.f=0,h.g=!1,h.i=0,h.j=0,h.k=0,h.n=0,h.o=0,h.p=0,I("com.google.gwt.i18n.shared.impl","DateRecord",2015),D(2064,1,{}),h.pe=function(){return null},h.qe=function(){return null},h.re=function(){return null},h.se=function(){return null},h.te=function(){return null},I(Ax,"JSONValue",2064),D(221,2064,{221:1},$p,Sz),h.Fb=function(t){return De(t,221)?W5e(this.a,l(t,221).a):!1},h.oe=function(){return Bcn},h.Hb=function(){return F5e(this.a)},h.pe=function(){return this},h.Ib=function(){var t,n,r;for(r=new Th("["),n=0,t=this.a.length;n0&&(r.a+=","),wu(r,_y(this,n));return r.a+="]",r.a},I(Ax,"JSONArray",221),D(493,2064,{493:1},jc),h.oe=function(){return Fcn},h.qe=function(){return this},h.Ib=function(){return Hn(),""+this.a},h.a=!1;var h6t,f6t;I(Ax,"JSONBoolean",493),D(997,63,lp,LJe),I(Ax,"JSONException",997),D(1036,2064,{},W),h.oe=function(){return Rcn},h.Ib=function(){return ul};var d6t;I(Ax,"JSONNull",1036),D(263,2064,{263:1},vk),h.Fb=function(t){return De(t,263)?this.a==l(t,263).a:!1},h.oe=function(){return Ncn},h.Hb=function(){return j8(this.a)},h.re=function(){return this},h.Ib=function(){return this.a+""},h.a=0,I(Ax,"JSONNumber",263),D(190,2064,{190:1},M8,wk),h.Fb=function(t){return De(t,190)?W5e(this.a,l(t,190).a):!1},h.oe=function(){return Pcn},h.Hb=function(){return F5e(this.a)},h.se=function(){return this},h.Ib=function(){var t,n,r,a,o,f,g;for(g=new Th("{"),t=!0,f=ace(this,We(zt,dt,2,0,6,1)),r=f,a=0,o=r.length;a=0?":"+this.c:"")+")"},h.c=0;var a_e=I(Vc,"StackTraceElement",319);r6t={3:1,484:1,34:1,2:1};var zt=I(Vc,nEe,2);D(111,427,{484:1},Up,h_,Af),I(Vc,"StringBuffer",111),D(104,427,{484:1},tb,S5,Th),I(Vc,"StringBuilder",104),D(702,77,she,e3e),I(Vc,"StringIndexOutOfBoundsException",702),D(2145,1,{});var m6t;D(48,63,{3:1,103:1,63:1,82:1,48:1},Qr,Hp),I(Vc,"UnsupportedOperationException",48),D(247,242,{3:1,34:1,242:1,247:1},NN,h3e),h.Fd=function(t){return Fmt(this,l(t,247))},h.ue=function(){return jy(hvt(this))},h.Fb=function(t){var n;return this===t?!0:De(t,247)?(n=l(t,247),this.e==n.e&&Fmt(this,n)==0):!1},h.Hb=function(){var t;return this.b!=0?this.b:this.a<54?(t=Zc(this.f),this.b=Yr(va(t,-1)),this.b=33*this.b+Yr(va(bw(t,32),-1)),this.b=17*this.b+ua(this.e),this.b):(this.b=17*X0t(this.c)+ua(this.e),this.b)},h.Ib=function(){return hvt(this)},h.a=0,h.b=0,h.d=0,h.e=0,h.f=0;var v6t,lv,o_e,c_e,u_e,l_e,h_e,f_e,L0e=I("java.math","BigDecimal",247);D(92,242,{3:1,34:1,242:1,92:1},Qg,qot,Im,Q1t,ob),h.Fd=function(t){return K1t(this,l(t,92))},h.ue=function(){return jy(Dle(this,0))},h.Fb=function(t){return C8e(this,t)},h.Hb=function(){return X0t(this)},h.Ib=function(){return Dle(this,0)},h.b=-2,h.c=0,h.d=0,h.e=0;var w6t,uK,y6t,M0e,lK,BL,A6=I("java.math","BigInteger",92),x6t,k6t,$x,FL;D(498,2065,Ww),h.$b=function(){Nl(this)},h._b=function(t){return Hu(this,t)},h.uc=function(t){return D0t(this,t,this.i)||D0t(this,t,this.f)},h.vc=function(){return new Sr(this)},h.xc=function(t){return cr(this,t)},h.zc=function(t,n){return ki(this,t,n)},h.Bc=function(t){return ax(this,t)},h.gc=function(){return d_(this)},h.g=0,I(Lr,"AbstractHashMap",498),D(267,q1,Tl,Sr),h.$b=function(){this.a.$b()},h.Hc=function(t){return vct(this,t)},h.Kc=function(){return new qm(this.a)},h.Mc=function(t){var n;return vct(this,t)?(n=l(t,44).ld(),this.a.Bc(n),!0):!1},h.gc=function(){return this.a.gc()},I(Lr,"AbstractHashMap/EntrySet",267),D(268,1,Oa,qm),h.Nb=function(t){Za(this,t)},h.Pb=function(){return Nw(this)},h.Ob=function(){return this.b},h.Qb=function(){Klt(this)},h.b=!1,h.d=0,I(Lr,"AbstractHashMap/EntrySetIterator",268),D(426,1,Oa,kr),h.Nb=function(t){Za(this,t)},h.Ob=function(){return lse(this)},h.Pb=function(){return I5e(this)},h.Qb=function(){ph(this)},h.b=0,h.c=-1,I(Lr,"AbstractList/IteratorImpl",426),D(98,426,lg,Ua),h.Qb=function(){ph(this)},h.Rb=function(t){by(this,t)},h.Sb=function(){return this.b>0},h.Tb=function(){return this.b},h.Ub=function(){return mr(this.b>0),this.a.Xb(this.c=--this.b)},h.Vb=function(){return this.b-1},h.Wb=function(t){gy(this.c!=-1),this.a.hd(this.c,t)},I(Lr,"AbstractList/ListIteratorImpl",98),D(244,56,iT,Zp),h.bd=function(t,n){Ey(t,this.b),this.c.bd(this.a+t,n),++this.b},h.Xb=function(t){return Sn(t,this.b),this.c.Xb(this.a+t)},h.gd=function(t){var n;return Sn(t,this.b),n=this.c.gd(this.a+t),--this.b,n},h.hd=function(t,n){return Sn(t,this.b),this.c.hd(this.a+t,n)},h.gc=function(){return this.b},h.a=0,h.b=0,I(Lr,"AbstractList/SubList",244),D(266,q1,Tl,br),h.$b=function(){this.a.$b()},h.Hc=function(t){return this.a._b(t)},h.Kc=function(){var t;return t=this.a.vc().Kc(),new Mi(t)},h.Mc=function(t){return this.a._b(t)?(this.a.Bc(t),!0):!1},h.gc=function(){return this.a.gc()},I(Lr,"AbstractMap/1",266),D(541,1,Oa,Mi),h.Nb=function(t){Za(this,t)},h.Ob=function(){return this.a.Ob()},h.Pb=function(){var t;return t=l(this.a.Pb(),44),t.ld()},h.Qb=function(){this.a.Qb()},I(Lr,"AbstractMap/1/1",541),D(231,31,Wy,gi),h.$b=function(){this.a.$b()},h.Hc=function(t){return this.a.uc(t)},h.Kc=function(){var t;return t=this.a.vc().Kc(),new fs(t)},h.gc=function(){return this.a.gc()},I(Lr,"AbstractMap/2",231),D(301,1,Oa,fs),h.Nb=function(t){Za(this,t)},h.Ob=function(){return this.a.Ob()},h.Pb=function(){var t;return t=l(this.a.Pb(),44),t.md()},h.Qb=function(){this.a.Qb()},I(Lr,"AbstractMap/2/1",301),D(494,1,{494:1,44:1}),h.Fb=function(t){var n;return De(t,44)?(n=l(t,44),Jc(this.d,n.ld())&&Jc(this.e,n.md())):!1},h.ld=function(){return this.d},h.md=function(){return this.e},h.Hb=function(){return R5(this.d)^R5(this.e)},h.nd=function(t){return Zye(this,t)},h.Ib=function(){return this.d+"="+this.e},I(Lr,"AbstractMap/AbstractEntry",494),D(397,494,{494:1,397:1,44:1},cq),I(Lr,"AbstractMap/SimpleEntry",397),D(2082,1,che),h.Fb=function(t){var n;return De(t,44)?(n=l(t,44),Jc(this.ld(),n.ld())&&Jc(this.md(),n.md())):!1},h.Hb=function(){return R5(this.ld())^R5(this.md())},h.Ib=function(){return this.ld()+"="+this.md()},I(Lr,Mwt,2082),D(2090,2065,Zke),h.Xc=function(t){return rse(this.Ee(t))},h.tc=function(t){return Tut(this,t)},h._b=function(t){return e4e(this,t)},h.vc=function(){return new Rs(this)},h.Tc=function(){return Rst(this.Ge())},h.Yc=function(t){return rse(this.He(t))},h.xc=function(t){var n;return n=t,hc(this.Fe(n))},h.$c=function(t){return rse(this.Ie(t))},h.ec=function(){return new Fs(this)},h.Vc=function(){return Rst(this.Je())},h._c=function(t){return rse(this.Ke(t))},I(Lr,"AbstractNavigableMap",2090),D(629,q1,Tl,Rs),h.Hc=function(t){return De(t,44)&&Tut(this.b,l(t,44))},h.Kc=function(){return this.b.De()},h.Mc=function(t){var n;return De(t,44)?(n=l(t,44),this.b.Le(n)):!1},h.gc=function(){return this.b.gc()},I(Lr,"AbstractNavigableMap/EntrySet",629),D(1146,q1,eEe,Fs),h.Nc=function(){return new aq(this)},h.$b=function(){this.a.$b()},h.Hc=function(t){return e4e(this.a,t)},h.Kc=function(){var t;return t=this.a.vc().b.De(),new xs(t)},h.Mc=function(t){return e4e(this.a,t)?(this.a.Bc(t),!0):!1},h.gc=function(){return this.a.gc()},I(Lr,"AbstractNavigableMap/NavigableKeySet",1146),D(1147,1,Oa,xs),h.Nb=function(t){Za(this,t)},h.Ob=function(){return lse(this.a.a)},h.Pb=function(){var t;return t=ort(this.a),t.ld()},h.Qb=function(){dit(this.a)},I(Lr,"AbstractNavigableMap/NavigableKeySet/1",1147),D(2103,31,Wy),h.Fc=function(t){return K8($E(this,t),aT),!0},h.Gc=function(t){return nr(t),BO(t!=this,"Can't add a queue to itself"),Ka(this,t)},h.$b=function(){for(;Koe(this)!=null;);},I(Lr,"AbstractQueue",2103),D(310,31,{4:1,20:1,31:1,16:1},z5,dct),h.Fc=function(t){return i6e(this,t),!0},h.$b=function(){l6e(this)},h.Hc=function(t){return Zft(new nA(this),t)},h.dc=function(){return l_(this)},h.Kc=function(){return new nA(this)},h.Mc=function(t){return w2n(new nA(this),t)},h.gc=function(){return this.c-this.b&this.a.length-1},h.Nc=function(){return new kn(this,272)},h.Qc=function(t){var n;return n=this.c-this.b&this.a.length-1,t.lengthn&&Ts(t,n,null),t},h.b=0,h.c=0,I(Lr,"ArrayDeque",310),D(459,1,Oa,nA),h.Nb=function(t){Za(this,t)},h.Ob=function(){return this.a!=this.b},h.Pb=function(){return FV(this)},h.Qb=function(){Yht(this)},h.a=0,h.b=0,h.c=-1,I(Lr,"ArrayDeque/IteratorImpl",459),D(13,56,Uwt,bt,Bu,Ol),h.bd=function(t,n){pw(this,t,n)},h.Fc=function(t){return vt(this,t)},h.cd=function(t,n){return Q7e(this,t,n)},h.Gc=function(t){return ra(this,t)},h.$b=function(){ay(this.c,0)},h.Hc=function(t){return gc(this,t,0)!=-1},h.Jc=function(t){Vu(this,t)},h.Xb=function(t){return jt(this,t)},h.dd=function(t){return gc(this,t,0)},h.dc=function(){return this.c.length==0},h.Kc=function(){return new G(this)},h.gd=function(t){return t2(this,t)},h.Mc=function(t){return al(this,t)},h.ce=function(t,n){Bot(this,t,n)},h.hd=function(t,n){return rf(this,t,n)},h.gc=function(){return this.c.length},h.jd=function(t){Vs(this,t)},h.Pc=function(){return eH(this.c)},h.Qc=function(t){return j1(this,t)};var cOn=I(Lr,"ArrayList",13);D(7,1,Oa,G),h.Nb=function(t){Za(this,t)},h.Ob=function(){return Lc(this)},h.Pb=function(){return re(this)},h.Qb=function(){Q_(this)},h.a=0,h.b=-1,I(Lr,"ArrayList/1",7),D(2112,b.Function,{},Pe),h.Me=function(t,n){return Yi(t,n)},D(151,56,Gwt,Il),h.Hc=function(t){return Xht(this,t)!=-1},h.Jc=function(t){var n,r,a,o;for(nr(t),r=this.a,a=0,o=r.length;a0)throw ue(new Yn(lEe+t+" greater than "+this.e));return this.f.Te()?sot(this.c,this.b,this.a,t,n):Fot(this.c,t,n)},h.zc=function(t,n){if(!xue(this.c,this.f,t,this.b,this.a,this.e,this.d))throw ue(new Yn(t+" outside the range "+this.b+" to "+this.e));return b0t(this.c,t,n)},h.Bc=function(t){var n;return n=t,xue(this.c,this.f,n,this.b,this.a,this.e,this.d)?aot(this.c,n):null},h.Le=function(t){return yH(this,t.ld())&&L6e(this.c,t)},h.gc=function(){var t,n,r;if(this.f.Te()?this.a?n=OE(this.c,this.b,!0):n=OE(this.c,this.b,!1):n=j6e(this.c),!(n&&yH(this,n.d)&&n))return 0;for(t=0,r=new oce(this.c,this.f,this.b,this.a,this.e,this.d);lse(r.a);r.b=l(I5e(r.a),44))++t;return t},h.ad=function(t,n){if(this.f.Te()&&this.c.a.Ne(t,this.b)<0)throw ue(new Yn(lEe+t+Ywt+this.b));return this.f.Ue()?sot(this.c,t,n,this.e,this.d):Rot(this.c,t,n)},h.a=!1,h.d=!1,I(Lr,"TreeMap/SubMap",631),D(304,22,fhe,oq),h.Te=function(){return!1},h.Ue=function(){return!1};var O0e,N0e,P0e,B0e,fK=Fr(Lr,"TreeMap/SubMapType",304,Hr,Gbn,n0n);D(1143,304,fhe,hnt),h.Ue=function(){return!0},Fr(Lr,"TreeMap/SubMapType/1",1143,fK,null,null),D(1144,304,fhe,ynt),h.Te=function(){return!0},h.Ue=function(){return!0},Fr(Lr,"TreeMap/SubMapType/2",1144,fK,null,null),D(1145,304,fhe,lnt),h.Te=function(){return!0},Fr(Lr,"TreeMap/SubMapType/3",1145,fK,null,null);var M6t;D(157,q1,{3:1,20:1,31:1,16:1,277:1,21:1,87:1,157:1},Lwe,Kp,ba),h.Nc=function(){return new aq(this)},h.Fc=function(t){return jO(this,t)},h.$b=function(){this.a.$b()},h.Hc=function(t){return this.a._b(t)},h.Kc=function(){return this.a.ec().Kc()},h.Mc=function(t){return tae(this,t)},h.gc=function(){return this.a.gc()};var gOn=I(Lr,"TreeSet",157);D(1082,1,{},xo),h.Ve=function(t,n){return wfn(this.a,t,n)},I(dhe,"BinaryOperator/lambda$0$Type",1082),D(1083,1,{},lh),h.Ve=function(t,n){return yfn(this.a,t,n)},I(dhe,"BinaryOperator/lambda$1$Type",1083),D(952,1,{},Pt),h.Kb=function(t){return t},I(dhe,"Function/lambda$0$Type",952),D(395,1,ti,Wl),h.Mb=function(t){return!this.a.Mb(t)},I(dhe,"Predicate/lambda$2$Type",395),D(581,1,{581:1});var D6t=I(aL,"Handler",581);D(2107,1,yP),h.xe=function(){return"DUMMY"},h.Ib=function(){return this.xe()};var w_e;I(aL,"Level",2107),D(1706,2107,yP,Qe),h.xe=function(){return"INFO"},I(aL,"Level/LevelInfo",1706),D(1843,1,{},FQe);var F0e;I(aL,"LogManager",1843),D(1896,1,yP,fit),h.b=null,I(aL,"LogRecord",1896),D(525,1,{525:1},Soe),h.e=!1;var I6t=!1,O6t=!1,G1=!1,N6t=!1,P6t=!1;I(aL,"Logger",525),D(835,581,{581:1},Dt),I(aL,"SimpleConsoleLogHandler",835),D(108,22,{3:1,34:1,22:1,108:1},dse);var y_e,Ec,i4,oc=Fr(sa,"Collector/Characteristics",108,Hr,O2n,r0n),B6t;D(758,1,{},h5e),I(sa,"CollectorImpl",758),D(1074,1,{},kt),h.Ve=function(t,n){return d4n(l(t,213),l(n,213))},I(sa,"Collectors/10methodref$merge$Type",1074),D(1075,1,{},On),h.Kb=function(t){return gct(l(t,213))},I(sa,"Collectors/11methodref$toString$Type",1075),D(1076,1,{},Z2),h.Kb=function(t){return Hn(),!!sye(t)},I(sa,"Collectors/12methodref$test$Type",1076),D(144,1,{},ht),h.Yd=function(t,n){l(t,16).Fc(n)},I(sa,"Collectors/20methodref$add$Type",144),D(146,1,{},zr),h.Xe=function(){return new bt},I(sa,"Collectors/21methodref$ctor$Type",146),D(359,1,{},yt),h.Xe=function(){return new Ks},I(sa,"Collectors/23methodref$ctor$Type",359),D(360,1,{},ji),h.Yd=function(t,n){na(l(t,49),n)},I(sa,"Collectors/24methodref$add$Type",360),D(1069,1,{},xi),h.Ve=function(t,n){return ret(l(t,15),l(n,16))},I(sa,"Collectors/4methodref$addAll$Type",1069),D(1073,1,{},Ma),h.Yd=function(t,n){Jg(l(t,213),l(n,484))},I(sa,"Collectors/9methodref$add$Type",1073),D(1072,1,{},Lit),h.Xe=function(){return new Hm(this.a,this.b,this.c)},I(sa,"Collectors/lambda$15$Type",1072),D(1077,1,{},zs),h.Xe=function(){var t;return t=new e2,h2(t,(Hn(),!1),new bt),h2(t,!0,new bt),t},I(sa,"Collectors/lambda$22$Type",1077),D(1078,1,{},eb),h.Xe=function(){return he(le(wa,1),Rn,1,5,[this.a])},I(sa,"Collectors/lambda$25$Type",1078),D(1079,1,{},G0),h.Yd=function(t,n){jdn(this.a,jm(t))},I(sa,"Collectors/lambda$26$Type",1079),D(1080,1,{},zp),h.Ve=function(t,n){return dgn(this.a,jm(t),jm(n))},I(sa,"Collectors/lambda$27$Type",1080),D(1081,1,{},ao),h.Kb=function(t){return jm(t)[0]},I(sa,"Collectors/lambda$28$Type",1081),D(728,1,{},Tr),h.Ve=function(t,n){return U4e(t,n)},I(sa,"Collectors/lambda$4$Type",728),D(145,1,{},Fn),h.Ve=function(t,n){return Wun(l(t,16),l(n,16))},I(sa,"Collectors/lambda$42$Type",145),D(361,1,{},qn),h.Ve=function(t,n){return Yun(l(t,49),l(n,49))},I(sa,"Collectors/lambda$50$Type",361),D(362,1,{},Un),h.Kb=function(t){return l(t,49)},I(sa,"Collectors/lambda$51$Type",362),D(1068,1,{},fd),h.Yd=function(t,n){wyn(this.a,l(t,85),n)},I(sa,"Collectors/lambda$7$Type",1068),D(1070,1,{},At),h.Ve=function(t,n){return Y3n(l(t,85),l(n,85),new xi)},I(sa,"Collectors/lambda$8$Type",1070),D(1071,1,{},Wv),h.Kb=function(t){return G4n(this.a,l(t,85))},I(sa,"Collectors/lambda$9$Type",1071),D(550,1,{}),h.$e=function(){tA(this)},h.d=!1,I(sa,"TerminatableStream",550),D(827,550,hEe,Vye),h.$e=function(){tA(this)},I(sa,"DoubleStreamImpl",827),D(1847,736,Ph,Mit),h.Re=function(t){return Y6n(this,l(t,189))},h.a=null,I(sa,"DoubleStreamImpl/2",1847),D(1848,1,LP,sy),h.Pe=function(t){qln(this.a,t)},I(sa,"DoubleStreamImpl/2/lambda$0$Type",1848),D(1845,1,LP,E8),h.Pe=function(t){zln(this.a,t)},I(sa,"DoubleStreamImpl/lambda$0$Type",1845),D(1846,1,LP,x5),h.Pe=function(t){M1t(this.a,t)},I(sa,"DoubleStreamImpl/lambda$2$Type",1846),D(1397,735,Ph,wut),h.Re=function(t){return Pbn(this,l(t,202))},h.a=0,h.b=0,h.c=0,I(sa,"IntStream/5",1397),D(806,550,hEe,Uye),h.$e=function(){tA(this)},h._e=function(){return fb(this),this.a},I(sa,"IntStreamImpl",806),D(807,550,hEe,b3e),h.$e=function(){tA(this)},h._e=function(){return fb(this),Sye(),L6t},I(sa,"IntStreamImpl/Empty",807),D(1687,1,kP,T8),h.Dd=function(t){$ft(this.a,t)},I(sa,"IntStreamImpl/lambda$4$Type",1687);var pOn=ks(sa,"Stream");D(26,550,{533:1,687:1,848:1},bn),h.$e=function(){tA(this)};var zx;I(sa,"StreamImpl",26),D(1102,500,Ph,iit),h.Bd=function(t){for(;Rvn(this);){if(this.a.Bd(t))return!0;tA(this.b),this.b=null,this.a=null}return!1},I(sa,"StreamImpl/1",1102),D(1103,1,fr,ZS),h.Cd=function(t){hdn(this.a,l(t,848))},I(sa,"StreamImpl/1/lambda$0$Type",1103),D(1104,1,ti,k5),h.Mb=function(t){return na(this.a,t)},I(sa,"StreamImpl/1methodref$add$Type",1104),D(1105,500,Ph,Rat),h.Bd=function(t){var n;return this.a||(n=new bt,this.b.a.Nb(new Qd(n)),Cn(),Vs(n,this.c),this.a=new kn(n,16)),xht(this.a,t)},h.a=null,I(sa,"StreamImpl/5",1105),D(1106,1,fr,Qd),h.Cd=function(t){vt(this.a,t)},I(sa,"StreamImpl/5/2methodref$add$Type",1106),D(737,500,Ph,$6e),h.Bd=function(t){for(this.b=!1;!this.b&&this.c.Bd(new xet(this,t)););return this.b},h.b=!1,I(sa,"StreamImpl/FilterSpliterator",737),D(1096,1,fr,xet),h.Cd=function(t){ogn(this.a,this.b,t)},I(sa,"StreamImpl/FilterSpliterator/lambda$0$Type",1096),D(1091,736,Ph,Mut),h.Re=function(t){return zfn(this,l(t,189))},I(sa,"StreamImpl/MapToDoubleSpliterator",1091),D(1095,1,fr,ket),h.Cd=function(t){hln(this.a,this.b,t)},I(sa,"StreamImpl/MapToDoubleSpliterator/lambda$0$Type",1095),D(1090,735,Ph,Dut),h.Re=function(t){return qfn(this,l(t,202))},I(sa,"StreamImpl/MapToIntSpliterator",1090),D(1094,1,fr,Eet),h.Cd=function(t){fln(this.a,this.b,t)},I(sa,"StreamImpl/MapToIntSpliterator/lambda$0$Type",1094),D(734,500,Ph,C6e),h.Bd=function(t){return tit(this,t)},I(sa,"StreamImpl/MapToObjSpliterator",734),D(1093,1,fr,Tet),h.Cd=function(t){dln(this.a,this.b,t)},I(sa,"StreamImpl/MapToObjSpliterator/lambda$0$Type",1093),D(1092,500,Ph,aft),h.Bd=function(t){for(;hse(this.b,0);){if(!this.a.Bd(new wt))return!1;this.b=Df(this.b,1)}return this.a.Bd(t)},h.b=0,I(sa,"StreamImpl/SkipSpliterator",1092),D(1097,1,fr,wt),h.Cd=function(t){},I(sa,"StreamImpl/SkipSpliterator/lambda$0$Type",1097),D(626,1,fr,on),h.Cd=function(t){Eie(this,t)},I(sa,"StreamImpl/ValueConsumer",626),D(1098,1,fr,fn),h.Cd=function(t){Am()},I(sa,"StreamImpl/lambda$0$Type",1098),D(1099,1,fr,An),h.Cd=function(t){Am()},I(sa,"StreamImpl/lambda$1$Type",1099),D(1100,1,{},_1),h.Ve=function(t,n){return y0n(this.a,t,n)},I(sa,"StreamImpl/lambda$4$Type",1100),D(1101,1,fr,Cet),h.Cd=function(t){Sfn(this.b,this.a,t)},I(sa,"StreamImpl/lambda$5$Type",1101),D(1107,1,fr,Jd),h.Cd=function(t){F3n(this.a,l(t,380))},I(sa,"TerminatableStream/lambda$0$Type",1107),D(2142,1,{}),D(2014,1,{},oo),I("javaemul.internal","ConsoleLogger",2014);var bOn=0;D(2134,1,{}),D(1830,1,fr,jo),h.Cd=function(t){l(t,317)},I(oT,"BowyerWatsonTriangulation/lambda$0$Type",1830),D(1831,1,fr,Em),h.Cd=function(t){Ka(this.a,l(t,317).e)},I(oT,"BowyerWatsonTriangulation/lambda$1$Type",1831),D(1832,1,fr,$o),h.Cd=function(t){l(t,177)},I(oT,"BowyerWatsonTriangulation/lambda$2$Type",1832),D(1827,1,ii,Lz),h.Ne=function(t,n){return ymn(this.a,l(t,177),l(n,177))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(oT,"NaiveMinST/lambda$0$Type",1827),D(449,1,{},Yv),I(oT,"NodeMicroLayout",449),D(177,1,{177:1},B8),h.Fb=function(t){var n;return De(t,177)?(n=l(t,177),Jc(this.a,n.a)&&Jc(this.b,n.b)||Jc(this.a,n.b)&&Jc(this.b,n.a)):!1},h.Hb=function(){return R5(this.a)+R5(this.b)};var mOn=I(oT,"TEdge",177);D(317,1,{317:1},Cke),h.Fb=function(t){var n;return De(t,317)?(n=l(t,317),rV(this,n.a)&&rV(this,n.b)&&rV(this,n.c)):!1},h.Hb=function(){return R5(this.a)+R5(this.b)+R5(this.c)},I(oT,"TTriangle",317),D(225,1,{225:1},Nq),I(oT,"Tree",225),D(1218,1,{},Eot),I(Jwt,"Scanline",1218);var F6t=ks(Jwt,Zwt);D(1758,1,{},vht),I(gg,"CGraph",1758),D(316,1,{316:1},Sot),h.b=0,h.c=0,h.d=0,h.g=0,h.i=0,h.k=ia,I(gg,"CGroup",316),D(830,1,{},Iwe),I(gg,"CGroup/CGroupBuilder",830),D(60,1,{60:1},Rrt),h.Ib=function(){var t;return this.j?ei(this.j.Kb(this)):(Gg(dK),dK.o+"@"+(t=fw(this)>>>0,t.toString(16)))},h.f=0,h.i=ia;var dK=I(gg,"CNode",60);D(829,1,{},Owe),I(gg,"CNode/CNodeBuilder",829);var R6t;D(1590,1,{},Pa),h.ff=function(t,n){return 0},h.gf=function(t,n){return 0},I(gg,t3t,1590),D(1853,1,{},wo),h.cf=function(t){var n,r,a,o,f,g,w,E,C,L,B,z,V,J,te;for(C=gs,a=new G(t.a.b);a.aa.d.c||a.d.c==f.d.c&&a.d.b0?t+this.n.d+this.n.a:0},h.kf=function(){var t,n,r,a,o;if(o=0,this.e)this.b?o=this.b.a:this.a[1][1]&&(o=this.a[1][1].kf());else if(this.g)o=E8e(this,Eue(this,null,!0));else for(n=(t1(),he(le(s4,1),it,237,0,[Gc,$u,Kc])),r=0,a=n.length;r0?o+this.n.b+this.n.c:0},h.lf=function(){var t,n,r,a,o;if(this.g)for(t=Eue(this,null,!1),r=(t1(),he(le(s4,1),it,237,0,[Gc,$u,Kc])),a=0,o=r.length;a0&&(a[0]+=this.d,r-=a[0]),a[2]>0&&(a[2]+=this.d,r-=a[2]),this.c.a=b.Math.max(0,r),this.c.d=n.d+t.d+(this.c.a-r)/2,a[1]=b.Math.max(a[1],r),x6e(this,$u,n.d+t.d+a[0]-(a[1]-r)/2,a)},h.b=null,h.d=0,h.e=!1,h.f=!1,h.g=!1;var q0e=0,gK=0;I(ev,"GridContainerCell",1538),D(471,22,{3:1,34:1,22:1,471:1},pse);var Bb,Fd,v0,W6t=Fr(ev,"HorizontalLabelAlignment",471,Hr,P2n,c0n),Y6t;D(314,217,{217:1,314:1},uot,yht,not),h.jf=function(){return Hit(this)},h.kf=function(){return j4e(this)},h.a=0,h.c=!1;var vOn=I(ev,"LabelCell",314);D(252,336,{217:1,336:1,252:1},DA),h.jf=function(){return tP(this)},h.kf=function(){return nP(this)},h.lf=function(){hle(this)},h.mf=function(){fle(this)},h.b=0,h.c=0,h.d=!1,I(ev,"StripContainerCell",252),D(1691,1,ti,Xc),h.Mb=function(t){return cun(l(t,217))},I(ev,"StripContainerCell/lambda$0$Type",1691),D(1692,1,{},Bc),h.Ye=function(t){return l(t,217).kf()},I(ev,"StripContainerCell/lambda$1$Type",1692),D(1693,1,ti,ja),h.Mb=function(t){return uun(l(t,217))},I(ev,"StripContainerCell/lambda$2$Type",1693),D(1694,1,{},Ou),h.Ye=function(t){return l(t,217).jf()},I(ev,"StripContainerCell/lambda$3$Type",1694),D(472,22,{3:1,34:1,22:1,472:1},bse);var w0,Fb,a1,X6t=Fr(ev,"VerticalLabelAlignment",472,Hr,N2n,u0n),Q6t;D(800,1,{},zke),h.c=0,h.d=0,h.k=0,h.s=0,h.t=0,h.v=!1,h.w=0,h.D=!1,I(tG,"NodeContext",800),D(1536,1,ii,Sa),h.Ne=function(t,n){return tnt(l(t,64),l(n,64))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(tG,"NodeContext/0methodref$comparePortSides$Type",1536),D(1537,1,ii,Po),h.Ne=function(t,n){return Rxn(l(t,117),l(n,117))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(tG,"NodeContext/1methodref$comparePortContexts$Type",1537),D(164,22,{3:1,34:1,22:1,164:1},of);var J6t,Z6t,e7t,t7t,n7t,r7t,i7t,s7t,a7t,o7t,c7t,u7t,l7t,h7t,f7t,d7t,g7t,p7t,b7t,m7t,v7t,H0e,w7t=Fr(tG,"NodeLabelLocation",164,Hr,eue,l0n),y7t;D(117,1,{117:1},c2t),h.a=!1,I(tG,"PortContext",117),D(1541,1,fr,Fc),h.Cd=function(t){vZe(l(t,314))},I(DP,g3t,1541),D(1542,1,ti,xa),h.Mb=function(t){return!!l(t,117).c},I(DP,p3t,1542),D(1543,1,fr,Ba),h.Cd=function(t){vZe(l(t,117).c)},I(DP,"LabelPlacer/lambda$2$Type",1543);var q_e;D(1540,1,fr,ga),h.Cd=function(t){py(),zcn(l(t,117))},I(DP,"NodeLabelAndSizeUtilities/lambda$0$Type",1540),D(801,1,fr,v4e),h.Cd=function(t){tln(this.b,this.c,this.a,l(t,187))},h.a=!1,h.c=!1,I(DP,"NodeLabelCellCreator/lambda$0$Type",801),D(1539,1,fr,Die),h.Cd=function(t){Vcn(this.a,l(t,187))},I(DP,"PortContextCreator/lambda$0$Type",1539);var pK;D(1902,1,{},kh),I(uT,"GreedyRectangleStripOverlapRemover",1902),D(1903,1,ii,lu),h.Ne=function(t,n){return Ohn(l(t,226),l(n,226))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(uT,"GreedyRectangleStripOverlapRemover/0methodref$compareByYCoordinate$Type",1903),D(1849,1,{},zQe),h.a=5,h.e=0,I(uT,"RectangleStripOverlapRemover",1849),D(1850,1,ii,o5),h.Ne=function(t,n){return Nhn(l(t,226),l(n,226))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(uT,"RectangleStripOverlapRemover/0methodref$compareLeftRectangleBorders$Type",1850),D(1852,1,ii,Wh),h.Ne=function(t,n){return Egn(l(t,226),l(n,226))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(uT,"RectangleStripOverlapRemover/1methodref$compareRightRectangleBorders$Type",1852),D(417,22,{3:1,34:1,22:1,417:1},uq);var rB,V0e,U0e,iB,x7t=Fr(uT,"RectangleStripOverlapRemover/OverlapRemovalDirection",417,Hr,Ybn,h0n),k7t;D(226,1,{226:1},Dae),I(uT,"RectangleStripOverlapRemover/RectangleNode",226),D(1851,1,fr,Iie),h.Cd=function(t){l7n(this.a,l(t,226))},I(uT,"RectangleStripOverlapRemover/lambda$1$Type",1851),D(1323,1,ii,od),h.Ne=function(t,n){return MLn(l(t,176),l(n,176))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(Md,"PolyominoCompactor/CornerCasesGreaterThanRestComparator",1323),D(1326,1,{},Gd),h.Kb=function(t){return l(t,334).a},I(Md,"PolyominoCompactor/CornerCasesGreaterThanRestComparator/lambda$0$Type",1326),D(1327,1,ti,cd),h.Mb=function(t){return l(t,332).a},I(Md,"PolyominoCompactor/CornerCasesGreaterThanRestComparator/lambda$1$Type",1327),D(1328,1,ti,Kd),h.Mb=function(t){return l(t,332).a},I(Md,"PolyominoCompactor/CornerCasesGreaterThanRestComparator/lambda$2$Type",1328),D(1321,1,ii,$g),h.Ne=function(t,n){return a_n(l(t,176),l(n,176))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(Md,"PolyominoCompactor/MinNumOfExtensionDirectionsComparator",1321),D(1324,1,{},as),h.Kb=function(t){return l(t,334).a},I(Md,"PolyominoCompactor/MinNumOfExtensionDirectionsComparator/lambda$0$Type",1324),D(781,1,ii,wn),h.Ne=function(t,n){return q3n(l(t,176),l(n,176))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(Md,"PolyominoCompactor/MinNumOfExtensionsComparator",781),D(1319,1,ii,Zr),h.Ne=function(t,n){return Xwn(l(t,330),l(n,330))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(Md,"PolyominoCompactor/MinPerimeterComparator",1319),D(1320,1,ii,Zi),h.Ne=function(t,n){return N6n(l(t,330),l(n,330))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(Md,"PolyominoCompactor/MinPerimeterComparatorWithShape",1320),D(1322,1,ii,nu),h.Ne=function(t,n){return __n(l(t,176),l(n,176))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(Md,"PolyominoCompactor/SingleExtensionSideGreaterThanRestComparator",1322),D(1325,1,{},vu),h.Kb=function(t){return l(t,334).a},I(Md,"PolyominoCompactor/SingleExtensionSideGreaterThanRestComparator/lambda$0$Type",1325),D(782,1,{},L3e),h.Ve=function(t,n){return zbn(this,l(t,42),l(n,176))},I(Md,"SuccessorCombination",782),D(649,1,{},Dl),h.Ve=function(t,n){var r;return rEn((r=l(t,42),l(n,176),r))},I(Md,"SuccessorJitter",649),D(648,1,{},Yh),h.Ve=function(t,n){var r;return HCn((r=l(t,42),l(n,176),r))},I(Md,"SuccessorLineByLine",648),D(573,1,{},w1),h.Ve=function(t,n){var r;return rTn((r=l(t,42),l(n,176),r))},I(Md,"SuccessorManhattan",573),D(1344,1,{},$0),h.Ve=function(t,n){var r;return dCn((r=l(t,42),l(n,176),r))},I(Md,"SuccessorMaxNormWindingInMathPosSense",1344),D(409,1,{},E5),h.Ve=function(t,n){return u5e(this,t,n)},h.c=!1,h.d=!1,h.e=!1,h.f=!1,I(Md,"SuccessorQuadrantsGeneric",409),D(1345,1,{},Wi),h.Kb=function(t){return l(t,334).a},I(Md,"SuccessorQuadrantsGeneric/lambda$0$Type",1345),D(332,22,{3:1,34:1,22:1,332:1},lq),h.a=!1;var sB,aB,oB,cB,E7t=Fr(rG,kEe,332,Hr,Kbn,f0n),T7t;D(1317,1,{}),h.Ib=function(){var t,n,r,a,o,f;for(r=" ",t=pt(0),o=0;o=0?"b"+t+"["+Coe(this.a)+"]":"b["+Coe(this.a)+"]"):"b_"+fw(this)},I(OP,"FBendpoint",250),D(290,137,{3:1,290:1,96:1,137:1},jrt),h.Ib=function(){return Coe(this)},I(OP,"FEdge",290),D(235,137,{3:1,235:1,96:1,137:1},KH);var yOn=I(OP,"FGraph",235);D(454,309,{3:1,454:1,309:1,96:1,137:1},zct),h.Ib=function(){return this.b==null||this.b.length==0?"l["+Coe(this.a)+"]":"l_"+this.b},I(OP,"FLabel",454),D(153,309,{3:1,153:1,309:1,96:1,137:1},wnt),h.Ib=function(){return X5e(this)},h.a=0,I(OP,"FNode",153),D(2100,1,{}),h.vf=function(t){yke(this,t)},h.wf=function(){qdt(this)},h.d=0,I(DEe,"AbstractForceModel",2100),D(641,2100,{641:1},jft),h.uf=function(t,n){var r,a,o,f,g;return pvt(this.f,t,n),o=ma(Ja(n.d),t.d),g=b.Math.sqrt(o.a*o.a+o.b*o.b),a=b.Math.max(0,g-eA(t.e)/2-eA(n.e)/2),r=Qpt(this.e,t,n),r>0?f=-ygn(a,this.c)*r:f=Yhn(a,this.b)*l(Q(t,(b0(),qx)),17).a,md(o,f/g),o},h.vf=function(t){yke(this,t),this.a=l(Q(t,(b0(),xK)),17).a,this.c=ze(Ge(Q(t,kK))),this.b=ze(Ge(Q(t,J0e)))},h.xf=function(t){return t0&&(f-=iun(a,this.a)*r),md(o,f*this.b/g),o},h.vf=function(t){var n,r,a,o,f,g,w;for(yke(this,t),this.b=ze(Ge(Q(t,(b0(),Z0e)))),this.c=this.b/l(Q(t,xK),17).a,a=t.e.c.length,f=0,o=0,w=new G(t.e);w.a0},h.a=0,h.b=0,h.c=0,I(DEe,"FruchtermanReingoldModel",642),D(860,1,Pf,KS),h.hf=function(t){sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,aG),""),"Force Model"),"Determines the model for force calculation."),Q_e),(g2(),ps)),J_e),un((r1(),Pn))))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,IEe),""),"Iterations"),"The number of iterations on the force model."),pt(300)),Tc),ro),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,OEe),""),"Repulsive Power"),"Determines how many bend points are added to the edge; such bend points are regarded as repelling particles in the force model"),pt(0)),Tc),ro),un(zd)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,Dhe),""),"FR Temperature"),"The temperature is used as a scaling factor for particle displacements."),Dd),fo),ta),un(Pn)))),Qs(t,Dhe,aG,V7t),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,Ihe),""),"Eades Repulsion"),"Factor for repulsive forces in Eades' model."),5),fo),ta),un(Pn)))),Qs(t,Ihe,aG,z7t),rwt((new WS,t))};var R7t,j7t,Q_e,$7t,z7t,q7t,H7t,V7t;I(uL,"ForceMetaDataProvider",860),D(432,22,{3:1,34:1,22:1,432:1},D3e);var Q0e,yK,J_e=Fr(uL,"ForceModelStrategy",432,Hr,zpn,p0n),U7t;D(b2,1,Pf,WS),h.hf=function(t){rwt(t)};var G7t,K7t,Z_e,xK,eAe,W7t,Y7t,X7t,Q7t,tAe,J7t,nAe,rAe,Z7t,qx,e8t,J0e,iAe,t8t,n8t,kK,Z0e,r8t,i8t,s8t,sAe,a8t;I(uL,"ForceOptions",b2),D(1001,1,{},ld),h.sf=function(){var t;return t=new Dwe,t},h.tf=function(t){},I(uL,"ForceOptions/ForceFactory",1001);var hB,$L,Hx,EK;D(861,1,Pf,rz),h.hf=function(t){sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,PEe),""),"Fixed Position"),"Prevent that the node is moved by the layout algorithm."),(Hn(),!1)),(g2(),ya)),Ns),un((r1(),ha))))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,BEe),""),"Desired Edge Length"),"Either specified for parent nodes or for individual edges, where the latter takes higher precedence."),100),fo),ta),rs(Pn,he(le(xg,1),it,170,0,[zd]))))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,FEe),""),"Layout Dimension"),"Dimensions that are permitted to be altered during layout."),aAe),ps),dAe),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,REe),""),"Stress Epsilon"),"Termination criterion for the iterative process."),Dd),fo),ta),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,jEe),""),"Iteration Limit"),"Maximum number of performed iterations. Takes higher precedence than 'epsilon'."),pt(Ii)),Tc),ro),un(Pn)))),Dvt((new iz,t))};var o8t,c8t,aAe,u8t,l8t,h8t;I(uL,"StressMetaDataProvider",861),D(1004,1,Pf,iz),h.hf=function(t){Dvt(t)};var TK,oAe,cAe,uAe,lAe,hAe,f8t,d8t,g8t,p8t,fAe,b8t;I(uL,"StressOptions",1004),D(1005,1,{},y1),h.sf=function(){var t;return t=new $rt,t},h.tf=function(t){},I(uL,"StressOptions/StressFactory",1005),D(1110,205,tv,$rt),h.rf=function(t,n){var r,a,o,f,g;for(n.Ug(A3t,1),Rt(Bt(at(t,(VN(),lAe))))?Rt(Bt(at(t,fAe)))||KO((r=new Yv((aw(),new Jv(t))),r)):W2t(new Dwe,t,n.eh(1)),o=u0t(t),a=$mt(this.a,o),g=a.Kc();g.Ob();)f=l(g.Pb(),235),!(f.e.c.length<=1)&&(_Ln(this.b,f),JEn(this.b),Vu(f.d,new ud));o=ewt(a),lwt(o),n.Vg()},I(uG,"StressLayoutProvider",1110),D(1111,1,fr,ud),h.Cd=function(t){Ake(l(t,454))},I(uG,"StressLayoutProvider/lambda$0$Type",1111),D(1002,1,{},BQe),h.c=0,h.e=0,h.g=0,I(uG,"StressMajorization",1002),D(391,22,{3:1,34:1,22:1,391:1},mse);var e1e,t1e,n1e,dAe=Fr(uG,"StressMajorization/Dimension",391,Hr,F2n,b0n),m8t;D(1003,1,ii,Dz),h.Ne=function(t,n){return Vfn(this.a,l(t,153),l(n,153))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(uG,"StressMajorization/lambda$0$Type",1003),D(1192,1,{},Got),I(Bx,"ElkLayered",1192),D(1193,1,fr,Iz),h.Cd=function(t){_kn(this.a,l(t,36))},I(Bx,"ElkLayered/lambda$0$Type",1193),D(1194,1,fr,Oie),h.Cd=function(t){Ufn(this.a,l(t,36))},I(Bx,"ElkLayered/lambda$1$Type",1194),D(1281,1,{},Lnt);var v8t,w8t,y8t;I(Bx,"GraphConfigurator",1281),D(770,1,fr,qp),h.Cd=function(t){tpt(this.a,l(t,10))},I(Bx,"GraphConfigurator/lambda$0$Type",770),D(771,1,{},u5),h.Kb=function(t){return mxe(),new bn(null,new kn(l(t,30).a,16))},I(Bx,"GraphConfigurator/lambda$1$Type",771),D(772,1,fr,n_),h.Cd=function(t){tpt(this.a,l(t,10))},I(Bx,"GraphConfigurator/lambda$2$Type",772),D(1109,205,tv,qQe),h.rf=function(t,n){var r;r=oLn(new VQe,t),qe(at(t,(Nt(),p4)))===qe((rp(),A2))?j4n(this.a,r,n):WEn(this.a,r,n),n.$g()||Kvt(new b8,r)},I(Bx,"LayeredLayoutProvider",1109),D(367,22,{3:1,34:1,22:1,367:1},oO);var y0,vg,bu,_u,mc,gAe=Fr(Bx,"LayeredPhases",367,Hr,zmn,m0n),x8t;D(1717,1,{},rft),h.i=0;var k8t;I(jP,"ComponentsToCGraphTransformer",1717);var E8t;D(1718,1,{},mm),h.yf=function(t,n){return b.Math.min(t.a!=null?ze(t.a):t.c.i,n.a!=null?ze(n.a):n.c.i)},h.zf=function(t,n){return b.Math.min(t.a!=null?ze(t.a):t.c.i,n.a!=null?ze(n.a):n.c.i)},I(jP,"ComponentsToCGraphTransformer/1",1718),D(86,1,{86:1}),h.i=0,h.k=!0,h.o=ia;var r1e=I(dL,"CNode",86);D(470,86,{470:1,86:1},Pye,U8e),h.Ib=function(){return""},I(jP,"ComponentsToCGraphTransformer/CRectNode",470),D(1688,1,{},q9);var i1e,s1e;I(jP,"OneDimensionalComponentsCompaction",1688),D(1689,1,{},Vv),h.Kb=function(t){return A2n(l(t,42))},h.Fb=function(t){return this===t},I(jP,"OneDimensionalComponentsCompaction/lambda$0$Type",1689),D(1690,1,{},Y7),h.Kb=function(t){return z4n(l(t,42))},h.Fb=function(t){return this===t},I(jP,"OneDimensionalComponentsCompaction/lambda$1$Type",1690),D(1720,1,{},Zst),I(dL,"CGraph",1720),D(194,1,{194:1},Qce),h.b=0,h.c=0,h.e=0,h.g=!0,h.i=ia,I(dL,"CGroup",194),D(1719,1,{},G2),h.yf=function(t,n){return b.Math.max(t.a!=null?ze(t.a):t.c.i,n.a!=null?ze(n.a):n.c.i)},h.zf=function(t,n){return b.Math.max(t.a!=null?ze(t.a):t.c.i,n.a!=null?ze(n.a):n.c.i)},I(dL,t3t,1719),D(1721,1,{},Zpt),h.d=!1;var T8t,a1e=I(dL,i3t,1721);D(1722,1,{},X7),h.Kb=function(t){return v3e(),Hn(),l(l(t,42).a,86).d.e!=0},h.Fb=function(t){return this===t},I(dL,s3t,1722),D(833,1,{},G4e),h.a=!1,h.b=!1,h.c=!1,h.d=!1,I(dL,a3t,833),D(1898,1,{},pst),I(lG,o3t,1898);var fB=ks(rv,Zwt);D(1899,1,{382:1},Yat),h.bf=function(t){nSn(this,l(t,476))},I(lG,c3t,1899),D(Lb,1,ii,l5),h.Ne=function(t,n){return hpn(l(t,86),l(n,86))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(lG,u3t,Lb),D(476,1,{476:1},O3e),h.a=!1,I(lG,l3t,476),D(1901,1,ii,X3),h.Ne=function(t,n){return f8n(l(t,476),l(n,476))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(lG,h3t,1901),D(148,1,{148:1},Ik,L4e),h.Fb=function(t){var n;return t==null||xOn!=bh(t)?!1:(n=l(t,148),Jc(this.c,n.c)&&Jc(this.d,n.d))},h.Hb=function(){return MN(he(le(wa,1),Rn,1,5,[this.c,this.d]))},h.Ib=function(){return"("+this.c+Co+this.d+(this.a?"cx":"")+this.b+")"},h.a=!0,h.c=0,h.d=0;var xOn=I(rv,"Point",148);D(416,22,{3:1,34:1,22:1,416:1},fq);var s3,a4,M6,o4,C8t=Fr(rv,"Point/Quadrant",416,Hr,Xbn,v0n),S8t;D(1708,1,{},$Qe),h.b=null,h.c=null,h.d=null,h.e=null,h.f=null;var _8t,A8t,L8t,M8t,D8t;I(rv,"RectilinearConvexHull",1708),D(583,1,{382:1},nU),h.bf=function(t){$vn(this,l(t,148))},h.b=0;var pAe;I(rv,"RectilinearConvexHull/MaximalElementsEventHandler",583),D(1710,1,ii,Fp),h.Ne=function(t,n){return fpn(Ge(t),Ge(n))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(rv,"RectilinearConvexHull/MaximalElementsEventHandler/lambda$0$Type",1710),D(1709,1,{382:1},wht),h.bf=function(t){mCn(this,l(t,148))},h.a=0,h.b=null,h.c=null,h.d=null,h.e=null,I(rv,"RectilinearConvexHull/RectangleEventHandler",1709),D(1711,1,ii,nI),h.Ne=function(t,n){return ybn(l(t,148),l(n,148))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(rv,"RectilinearConvexHull/lambda$0$Type",1711),D(1712,1,ii,$J),h.Ne=function(t,n){return xbn(l(t,148),l(n,148))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(rv,"RectilinearConvexHull/lambda$1$Type",1712),D(1713,1,ii,vm),h.Ne=function(t,n){return wbn(l(t,148),l(n,148))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(rv,"RectilinearConvexHull/lambda$2$Type",1713),D(1714,1,ii,hu),h.Ne=function(t,n){return kbn(l(t,148),l(n,148))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(rv,"RectilinearConvexHull/lambda$3$Type",1714),D(1715,1,ii,zJ),h.Ne=function(t,n){return Zxn(l(t,148),l(n,148))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(rv,"RectilinearConvexHull/lambda$4$Type",1715),D(1716,1,{},Tot),I(rv,"Scanline",1716),D(2104,1,{}),I(V1,"AbstractGraphPlacer",2104),D(335,1,{335:1},hrt),h.Ff=function(t){return this.Gf(t)?(xn(this.b,l(Q(t,(ft(),pp)),21),t),!0):!1},h.Gf=function(t){var n,r,a,o;for(n=l(Q(t,(ft(),pp)),21),o=l($i(Xi,n),21),a=o.Kc();a.Ob();)if(r=l(a.Pb(),21),!l($i(this.b,r),15).dc())return!1;return!0};var Xi;I(V1,"ComponentGroup",335),D(779,2104,{},Nwe),h.Hf=function(t){var n,r;for(r=new G(this.a);r.ar&&(L=0,B+=w+a,w=0),E=f.c,KE(f,L+E.a,B+E.b),Y0(E),o=b.Math.max(o,L+C.a),w=b.Math.max(w,C.b),L+=C.a+a;n.f.a=o,n.f.b=B+w},h.Jf=function(t,n){var r,a,o,f,g;if(qe(Q(n,(Nt(),g4)))===qe((Km(),c4))){for(a=t.Kc();a.Ob();){for(r=l(a.Pb(),36),g=0,f=new G(r.a);f.ar&&!l(Q(f,(ft(),pp)),21).Hc((Ct(),Qn))||E&&l(Q(E,(ft(),pp)),21).Hc((Ct(),ar))||l(Q(f,(ft(),pp)),21).Hc((Ct(),er)))&&(z=B,V+=w+a,w=0),C=f.c,l(Q(f,(ft(),pp)),21).Hc((Ct(),Qn))&&(z=o+a),KE(f,z+C.a,V+C.b),o=b.Math.max(o,z+L.a),l(Q(f,pp),21).Hc(Dr)&&(B=b.Math.max(B,z+L.a+a)),Y0(C),w=b.Math.max(w,L.b),z+=L.a+a,E=f;n.f.a=o,n.f.b=V+w},h.Jf=function(t,n){},I(V1,"ModelOrderRowGraphPlacer",1313),D(1311,1,ii,cj),h.Ne=function(t,n){return j3n(l(t,36),l(n,36))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(V1,"SimpleRowGraphPlacer/1",1311);var O8t;D(1280,1,Ld,q0),h.Lb=function(t){var n;return n=l(Q(l(t,249).b,(Nt(),cc)),75),!!n&&n.b!=0},h.Fb=function(t){return this===t},h.Mb=function(t){var n;return n=l(Q(l(t,249).b,(Nt(),cc)),75),!!n&&n.b!=0},I(hG,"CompoundGraphPostprocessor/1",1280),D(1279,1,ts,UQe),h.Kf=function(t,n){kdt(this,l(t,36),n)},I(hG,"CompoundGraphPreprocessor",1279),D(453,1,{453:1},f1t),h.c=!1,I(hG,"CompoundGraphPreprocessor/ExternalPort",453),D(249,1,{249:1},Kq),h.Ib=function(){return aae(this.c)+":"+Kpt(this.b)},I(hG,"CrossHierarchyEdge",249),D(777,1,ii,GI),h.Ne=function(t,n){return $7n(this,l(t,249),l(n,249))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(hG,"CrossHierarchyEdgeComparator",777),D(305,137,{3:1,305:1,96:1,137:1}),h.p=0,I(Cu,"LGraphElement",305),D(18,305,{3:1,18:1,305:1,96:1,137:1},Tw),h.Ib=function(){return Kpt(this)};var u1e=I(Cu,"LEdge",18);D(36,305,{3:1,20:1,36:1,305:1,96:1,137:1},o7e),h.Jc=function(t){to(this,t)},h.Kc=function(){return new G(this.b)},h.Ib=function(){return this.b.c.length==0?"G-unlayered"+Tb(this.a):this.a.c.length==0?"G-layered"+Tb(this.b):"G[layerless"+Tb(this.a)+", layers"+Tb(this.b)+"]"};var N8t=I(Cu,"LGraph",36),P8t;D(666,1,{}),h.Lf=function(){return this.e.n},h.of=function(t){return Q(this.e,t)},h.Mf=function(){return this.e.o},h.Nf=function(){return this.e.p},h.pf=function(t){return ns(this.e,t)},h.Of=function(t){this.e.n.a=t.a,this.e.n.b=t.b},h.Pf=function(t){this.e.o.a=t.a,this.e.o.b=t.b},h.Qf=function(t){this.e.p=t},I(Cu,"LGraphAdapters/AbstractLShapeAdapter",666),D(474,1,{853:1},Tm),h.Rf=function(){var t,n;if(!this.b)for(this.b=eg(this.a.b.c.length),n=new G(this.a.b);n.a0&&H0t((Xn(n-1,t.length),t.charCodeAt(n-1)),N3t);)--n;if(f> ",t),fU(r)),hi(wu((t.a+="[",t),r.i),"]")),t.a},h.c=!0,h.d=!1;var yAe,xAe,kAe,EAe,TAe,CAe,F8t=I(Cu,"LPort",12);D(408,1,hg,T5),h.Jc=function(t){to(this,t)},h.Kc=function(){var t;return t=new G(this.a.e),new jWe(t)},I(Cu,"LPort/1",408),D(1309,1,Oa,jWe),h.Nb=function(t){Za(this,t)},h.Pb=function(){return l(re(this.a),18).c},h.Ob=function(){return Lc(this.a)},h.Qb=function(){Q_(this.a)},I(Cu,"LPort/1/1",1309),D(369,1,hg,C8),h.Jc=function(t){to(this,t)},h.Kc=function(){var t;return t=new G(this.a.g),new vwe(t)},I(Cu,"LPort/2",369),D(776,1,Oa,vwe),h.Nb=function(t){Za(this,t)},h.Pb=function(){return l(re(this.a),18).d},h.Ob=function(){return Lc(this.a)},h.Qb=function(){Q_(this.a)},I(Cu,"LPort/2/1",776),D(1302,1,hg,Met),h.Jc=function(t){to(this,t)},h.Kc=function(){return new N1(this)},I(Cu,"LPort/CombineIter",1302),D(208,1,Oa,N1),h.Nb=function(t){Za(this,t)},h.Qb=function(){aZe()},h.Ob=function(){return $_(this)},h.Pb=function(){return Lc(this.a)?re(this.a):re(this.b)},I(Cu,"LPort/CombineIter/1",208),D(1303,1,Ld,K2),h.Lb=function(t){return Lst(t)},h.Fb=function(t){return this===t},h.Mb=function(t){return kl(),l(t,12).g.c.length!=0},I(Cu,"LPort/lambda$0$Type",1303),D(1304,1,Ld,J3),h.Lb=function(t){return Mst(t)},h.Fb=function(t){return this===t},h.Mb=function(t){return kl(),l(t,12).e.c.length!=0},I(Cu,"LPort/lambda$1$Type",1304),D(1305,1,Ld,HJ),h.Lb=function(t){return kl(),l(t,12).j==(Ct(),Qn)},h.Fb=function(t){return this===t},h.Mb=function(t){return kl(),l(t,12).j==(Ct(),Qn)},I(Cu,"LPort/lambda$2$Type",1305),D(1306,1,Ld,wm),h.Lb=function(t){return kl(),l(t,12).j==(Ct(),ar)},h.Fb=function(t){return this===t},h.Mb=function(t){return kl(),l(t,12).j==(Ct(),ar)},I(Cu,"LPort/lambda$3$Type",1306),D(1307,1,Ld,VJ),h.Lb=function(t){return kl(),l(t,12).j==(Ct(),Dr)},h.Fb=function(t){return this===t},h.Mb=function(t){return kl(),l(t,12).j==(Ct(),Dr)},I(Cu,"LPort/lambda$4$Type",1307),D(1308,1,Ld,UJ),h.Lb=function(t){return kl(),l(t,12).j==(Ct(),er)},h.Fb=function(t){return this===t},h.Mb=function(t){return kl(),l(t,12).j==(Ct(),er)},I(Cu,"LPort/lambda$5$Type",1308),D(30,305,{3:1,20:1,305:1,30:1,96:1,137:1},yu),h.Jc=function(t){to(this,t)},h.Kc=function(){return new G(this.a)},h.Ib=function(){return"L_"+gc(this.b.b,this,0)+Tb(this.a)},I(Cu,"Layer",30),D(1330,1,{},VQe),I(v2,R3t,1330),D(1334,1,{},Q7),h.Kb=function(t){return bc(l(t,84))},I(v2,"ElkGraphImporter/0methodref$connectableShapeToNode$Type",1334),D(1337,1,{},uS),h.Kb=function(t){return bc(l(t,84))},I(v2,"ElkGraphImporter/1methodref$connectableShapeToNode$Type",1337),D(1331,1,fr,$We),h.Cd=function(t){l2t(this.a,l(t,123))},I(v2,MEe,1331),D(1332,1,fr,zWe),h.Cd=function(t){l2t(this.a,l(t,123))},I(v2,j3t,1332),D(1333,1,{},lj),h.Kb=function(t){return new bn(null,new kn(A5e(l(t,74)),16))},I(v2,$3t,1333),D(1335,1,ti,qWe),h.Mb=function(t){return Hln(this.a,l(t,27))},I(v2,z3t,1335),D(1336,1,{},H9),h.Kb=function(t){return new bn(null,new kn(apn(l(t,74)),16))},I(v2,"ElkGraphImporter/lambda$5$Type",1336),D(1338,1,ti,HWe),h.Mb=function(t){return Vln(this.a,l(t,27))},I(v2,"ElkGraphImporter/lambda$7$Type",1338),D(1339,1,ti,GJ),h.Mb=function(t){return ypn(l(t,74))},I(v2,"ElkGraphImporter/lambda$8$Type",1339),D(1297,1,{},b8);var R8t;I(v2,"ElkGraphLayoutTransferrer",1297),D(1298,1,ti,VWe),h.Mb=function(t){return Ifn(this.a,l(t,18))},I(v2,"ElkGraphLayoutTransferrer/lambda$0$Type",1298),D(1299,1,fr,UWe),h.Cd=function(t){sO(),vt(this.a,l(t,18))},I(v2,"ElkGraphLayoutTransferrer/lambda$1$Type",1299),D(1300,1,ti,GWe),h.Mb=function(t){return mfn(this.a,l(t,18))},I(v2,"ElkGraphLayoutTransferrer/lambda$2$Type",1300),D(1301,1,fr,KWe),h.Cd=function(t){sO(),vt(this.a,l(t,18))},I(v2,"ElkGraphLayoutTransferrer/lambda$3$Type",1301),D(819,1,{},i4e),I(rr,"BiLinkedHashMultiMap",819),D(1550,1,ts,V9),h.Kf=function(t,n){s3n(l(t,36),n)},I(rr,"CommentNodeMarginCalculator",1550),D(1551,1,{},KJ),h.Kb=function(t){return new bn(null,new kn(l(t,30).a,16))},I(rr,"CommentNodeMarginCalculator/lambda$0$Type",1551),D(1552,1,fr,WJ),h.Cd=function(t){sLn(l(t,10))},I(rr,"CommentNodeMarginCalculator/lambda$1$Type",1552),D(1553,1,ts,YJ),h.Kf=function(t,n){uSn(l(t,36),n)},I(rr,"CommentPostprocessor",1553),D(1554,1,ts,XJ),h.Kf=function(t,n){DDn(l(t,36),n)},I(rr,"CommentPreprocessor",1554),D(1555,1,ts,QJ),h.Kf=function(t,n){SCn(l(t,36),n)},I(rr,"ConstraintsPostprocessor",1555),D(1556,1,ts,JJ),h.Kf=function(t,n){O3n(l(t,36),n)},I(rr,"EdgeAndLayerConstraintEdgeReverser",1556),D(1557,1,ts,ZJ),h.Kf=function(t,n){E5n(l(t,36),n)},I(rr,"EndLabelPostprocessor",1557),D(1558,1,{},eZ),h.Kb=function(t){return new bn(null,new kn(l(t,30).a,16))},I(rr,"EndLabelPostprocessor/lambda$0$Type",1558),D(1559,1,ti,tZ),h.Mb=function(t){return Rmn(l(t,10))},I(rr,"EndLabelPostprocessor/lambda$1$Type",1559),D(1560,1,fr,nZ),h.Cd=function(t){d8n(l(t,10))},I(rr,"EndLabelPostprocessor/lambda$2$Type",1560),D(1561,1,ts,rZ),h.Kf=function(t,n){tkn(l(t,36),n)},I(rr,"EndLabelPreprocessor",1561),D(1562,1,{},rI),h.Kb=function(t){return new bn(null,new kn(l(t,30).a,16))},I(rr,"EndLabelPreprocessor/lambda$0$Type",1562),D(1563,1,fr,mit),h.Cd=function(t){nln(this.a,this.b,this.c,l(t,10))},h.a=0,h.b=0,h.c=!1,I(rr,"EndLabelPreprocessor/lambda$1$Type",1563),D(1564,1,ti,iZ),h.Mb=function(t){return qe(Q(l(t,72),(Nt(),jd)))===qe((F1(),rC))},I(rr,"EndLabelPreprocessor/lambda$2$Type",1564),D(1565,1,fr,WWe),h.Cd=function(t){ui(this.a,l(t,72))},I(rr,"EndLabelPreprocessor/lambda$3$Type",1565),D(1566,1,ti,sZ),h.Mb=function(t){return qe(Q(l(t,72),(Nt(),jd)))===qe((F1(),_4))},I(rr,"EndLabelPreprocessor/lambda$4$Type",1566),D(1567,1,fr,YWe),h.Cd=function(t){ui(this.a,l(t,72))},I(rr,"EndLabelPreprocessor/lambda$5$Type",1567),D(1615,1,ts,Hre),h.Kf=function(t,n){k4n(l(t,36),n)};var j8t;I(rr,"EndLabelSorter",1615),D(1616,1,ii,lS),h.Ne=function(t,n){return t6n(l(t,466),l(n,466))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(rr,"EndLabelSorter/1",1616),D(466,1,{466:1},Hat),I(rr,"EndLabelSorter/LabelGroup",466),D(1617,1,{},hj),h.Kb=function(t){return iO(),new bn(null,new kn(l(t,30).a,16))},I(rr,"EndLabelSorter/lambda$0$Type",1617),D(1618,1,ti,J7),h.Mb=function(t){return iO(),l(t,10).k==(Zn(),Ps)},I(rr,"EndLabelSorter/lambda$1$Type",1618),D(1619,1,fr,aZ),h.Cd=function(t){p9n(l(t,10))},I(rr,"EndLabelSorter/lambda$2$Type",1619),D(1620,1,ti,oZ),h.Mb=function(t){return iO(),qe(Q(l(t,72),(Nt(),jd)))===qe((F1(),_4))},I(rr,"EndLabelSorter/lambda$3$Type",1620),D(1621,1,ti,cZ),h.Mb=function(t){return iO(),qe(Q(l(t,72),(Nt(),jd)))===qe((F1(),rC))},I(rr,"EndLabelSorter/lambda$4$Type",1621),D(1568,1,ts,uZ),h.Kf=function(t,n){yLn(this,l(t,36))},h.b=0,h.c=0,I(rr,"FinalSplineBendpointsCalculator",1568),D(1569,1,{},lZ),h.Kb=function(t){return new bn(null,new kn(l(t,30).a,16))},I(rr,"FinalSplineBendpointsCalculator/lambda$0$Type",1569),D(1570,1,{},hS),h.Kb=function(t){return new bn(null,new vw(new hr(dr(qs(l(t,10)).a.Kc(),new j))))},I(rr,"FinalSplineBendpointsCalculator/lambda$1$Type",1570),D(1571,1,ti,iI),h.Mb=function(t){return!Do(l(t,18))},I(rr,"FinalSplineBendpointsCalculator/lambda$2$Type",1571),D(1572,1,ti,fj),h.Mb=function(t){return ns(l(t,18),(ft(),fv))},I(rr,"FinalSplineBendpointsCalculator/lambda$3$Type",1572),D(1573,1,fr,XWe),h.Cd=function(t){L_n(this.a,l(t,131))},I(rr,"FinalSplineBendpointsCalculator/lambda$4$Type",1573),D(1574,1,fr,h5),h.Cd=function(t){JN(l(t,18).a)},I(rr,"FinalSplineBendpointsCalculator/lambda$5$Type",1574),D(803,1,ts,wwe),h.Kf=function(t,n){dMn(this,l(t,36),n)},I(rr,"GraphTransformer",803),D(517,22,{3:1,34:1,22:1,517:1},I3e);var h1e,dB,$8t=Fr(rr,"GraphTransformer/Mode",517,Hr,qpn,E1n),z8t;D(1575,1,ts,f5),h.Kf=function(t,n){PTn(l(t,36),n)},I(rr,"HierarchicalNodeResizingProcessor",1575),D(1576,1,ts,hZ),h.Kf=function(t,n){e3n(l(t,36),n)},I(rr,"HierarchicalPortConstraintProcessor",1576),D(1577,1,ii,t0),h.Ne=function(t,n){return k6n(l(t,10),l(n,10))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(rr,"HierarchicalPortConstraintProcessor/NodeComparator",1577),D(1578,1,ts,Z7),h.Kf=function(t,n){EAn(l(t,36),n)},I(rr,"HierarchicalPortDummySizeProcessor",1578),D(1579,1,ts,fZ),h.Kf=function(t,n){OSn(this,l(t,36),n)},h.a=0,I(rr,"HierarchicalPortOrthogonalEdgeRouter",1579),D(1580,1,ii,U9),h.Ne=function(t,n){return Phn(l(t,10),l(n,10))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(rr,"HierarchicalPortOrthogonalEdgeRouter/1",1580),D(1581,1,ii,Wd),h.Ne=function(t,n){return zvn(l(t,10),l(n,10))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(rr,"HierarchicalPortOrthogonalEdgeRouter/2",1581),D(1582,1,ts,dZ),h.Kf=function(t,n){Xxn(l(t,36),n)},I(rr,"HierarchicalPortPositionProcessor",1582),D(1583,1,ts,Kv),h.Kf=function(t,n){fIn(this,l(t,36))},h.a=0,h.c=0;var CK,SK;I(rr,"HighDegreeNodeLayeringProcessor",1583),D(580,1,{580:1},gZ),h.b=-1,h.d=-1,I(rr,"HighDegreeNodeLayeringProcessor/HighDegreeNodeInformation",580),D(1584,1,{},pZ),h.Kb=function(t){return OO(),ka(l(t,10))},h.Fb=function(t){return this===t},I(rr,"HighDegreeNodeLayeringProcessor/lambda$0$Type",1584),D(1585,1,{},dj),h.Kb=function(t){return OO(),qs(l(t,10))},h.Fb=function(t){return this===t},I(rr,"HighDegreeNodeLayeringProcessor/lambda$1$Type",1585),D(1591,1,ts,bZ),h.Kf=function(t,n){pAn(this,l(t,36),n)},I(rr,"HyperedgeDummyMerger",1591),D(804,1,{},w4e),h.a=!1,h.b=!1,h.c=!1,I(rr,"HyperedgeDummyMerger/MergeState",804),D(1592,1,{},fS),h.Kb=function(t){return new bn(null,new kn(l(t,30).a,16))},I(rr,"HyperedgeDummyMerger/lambda$0$Type",1592),D(1593,1,{},dS),h.Kb=function(t){return new bn(null,new kn(l(t,10).j,16))},I(rr,"HyperedgeDummyMerger/lambda$1$Type",1593),D(1594,1,fr,gj),h.Cd=function(t){l(t,12).p=-1},I(rr,"HyperedgeDummyMerger/lambda$2$Type",1594),D(1595,1,ts,sI),h.Kf=function(t,n){dAn(l(t,36),n)},I(rr,"HypernodesProcessor",1595),D(1596,1,ts,e8),h.Kf=function(t,n){kAn(l(t,36),n)},I(rr,"InLayerConstraintProcessor",1596),D(1597,1,ts,mZ),h.Kf=function(t,n){p3n(l(t,36),n)},I(rr,"InnermostNodeMarginCalculator",1597),D(1598,1,ts,pj),h.Kf=function(t,n){_Dn(this,l(t,36))},h.a=ia,h.b=ia,h.c=gs,h.d=gs;var kOn=I(rr,"InteractiveExternalPortPositioner",1598);D(1599,1,{},bj),h.Kb=function(t){return l(t,18).d.i},h.Fb=function(t){return this===t},I(rr,"InteractiveExternalPortPositioner/lambda$0$Type",1599),D(1600,1,{},QWe),h.Kb=function(t){return Bhn(this.a,Ge(t))},h.Fb=function(t){return this===t},I(rr,"InteractiveExternalPortPositioner/lambda$1$Type",1600),D(1601,1,{},vZ),h.Kb=function(t){return l(t,18).c.i},h.Fb=function(t){return this===t},I(rr,"InteractiveExternalPortPositioner/lambda$2$Type",1601),D(1602,1,{},JWe),h.Kb=function(t){return Fhn(this.a,Ge(t))},h.Fb=function(t){return this===t},I(rr,"InteractiveExternalPortPositioner/lambda$3$Type",1602),D(1603,1,{},ZWe),h.Kb=function(t){return Nfn(this.a,Ge(t))},h.Fb=function(t){return this===t},I(rr,"InteractiveExternalPortPositioner/lambda$4$Type",1603),D(1604,1,{},eYe),h.Kb=function(t){return Pfn(this.a,Ge(t))},h.Fb=function(t){return this===t},I(rr,"InteractiveExternalPortPositioner/lambda$5$Type",1604),D(81,22,{3:1,34:1,22:1,81:1,196:1},Ws),h.dg=function(){switch(this.g){case 15:return new Uj;case 22:return new Dee;case 47:return new Nee;case 28:case 35:return new CZ;case 32:return new V9;case 42:return new YJ;case 1:return new XJ;case 41:return new QJ;case 56:return new wwe((dE(),dB));case 0:return new wwe((dE(),h1e));case 2:return new JJ;case 54:return new ZJ;case 33:return new rZ;case 51:return new uZ;case 55:return new f5;case 13:return new hZ;case 38:return new Z7;case 44:return new fZ;case 40:return new dZ;case 9:return new Kv;case 49:return new nrt;case 37:return new bZ;case 43:return new sI;case 27:return new e8;case 30:return new mZ;case 3:return new pj;case 18:return new yZ;case 29:return new xZ;case 5:return new fk;case 50:return new wZ;case 34:return new sz;case 36:return new d5;case 52:return new Hre;case 11:return new G9;case 7:return new Vre;case 39:return new aI;case 45:return new Z3;case 16:return new K9;case 10:return new Wet;case 48:return new mj;case 21:return new oI;case 23:return new Wie((Iw(),oM));case 8:return new cI;case 12:return new _Z;case 4:return new uI;case 19:return new cz;case 17:return new IZ;case 53:return new OZ;case 6:return new Tj;case 25:return new KQe;case 46:return new FZ;case 31:return new Vrt;case 14:return new UZ;case 26:return new Fee;case 20:return new Aj;case 24:return new Wie((Iw(),MW));default:throw ue(new Yn(Fhe+(this.f!=null?this.f:""+this.g)))}};var SAe,_Ae,AAe,LAe,MAe,DAe,IAe,OAe,NAe,PAe,D6,_K,AK,BAe,FAe,RAe,jAe,$Ae,zAe,qAe,zL,HAe,VAe,UAe,GAe,KAe,f1e,LK,MK,WAe,DK,IK,OK,LT,u4,l4,YAe,NK,PK,XAe,BK,FK,QAe,JAe,ZAe,eLe,RK,d1e,gB,jK,$K,zK,qK,tLe,nLe,rLe,iLe,EOn=Fr(rr,Rhe,81,Hr,rbt,k0n),q8t;D(1605,1,ts,yZ),h.Kf=function(t,n){CDn(l(t,36),n)},I(rr,"InvertedPortProcessor",1605),D(1606,1,ts,xZ),h.Kf=function(t,n){x_n(l(t,36),n)},I(rr,"LabelAndNodeSizeProcessor",1606),D(1607,1,ti,kZ),h.Mb=function(t){return l(t,10).k==(Zn(),Ps)},I(rr,"LabelAndNodeSizeProcessor/lambda$0$Type",1607),D(1608,1,ti,EZ),h.Mb=function(t){return l(t,10).k==(Zn(),Us)},I(rr,"LabelAndNodeSizeProcessor/lambda$1$Type",1608),D(1609,1,fr,vit),h.Cd=function(t){rln(this.b,this.a,this.c,l(t,10))},h.a=!1,h.c=!1,I(rr,"LabelAndNodeSizeProcessor/lambda$2$Type",1609),D(1610,1,ts,fk),h.Kf=function(t,n){QMn(l(t,36),n)};var H8t;I(rr,"LabelDummyInserter",1610),D(1611,1,Ld,Yd),h.Lb=function(t){return qe(Q(l(t,72),(Nt(),jd)))===qe((F1(),nC))},h.Fb=function(t){return this===t},h.Mb=function(t){return qe(Q(l(t,72),(Nt(),jd)))===qe((F1(),nC))},I(rr,"LabelDummyInserter/1",1611),D(1612,1,ts,wZ),h.Kf=function(t,n){jMn(l(t,36),n)},I(rr,"LabelDummyRemover",1612),D(1613,1,ti,Uv),h.Mb=function(t){return Rt(Bt(Q(l(t,72),(Nt(),tde))))},I(rr,"LabelDummyRemover/lambda$0$Type",1613),D(1378,1,ts,sz),h.Kf=function(t,n){DMn(this,l(t,36),n)},h.a=null;var g1e;I(rr,"LabelDummySwitcher",1378),D(293,1,{293:1},nmt),h.c=0,h.d=null,h.f=0,I(rr,"LabelDummySwitcher/LabelDummyInfo",293),D(1379,1,{},TZ),h.Kb=function(t){return lx(),new bn(null,new kn(l(t,30).a,16))},I(rr,"LabelDummySwitcher/lambda$0$Type",1379),D(1380,1,ti,gS),h.Mb=function(t){return lx(),l(t,10).k==(Zn(),cu)},I(rr,"LabelDummySwitcher/lambda$1$Type",1380),D(1381,1,{},tYe),h.Kb=function(t){return vfn(this.a,l(t,10))},I(rr,"LabelDummySwitcher/lambda$2$Type",1381),D(1382,1,fr,nYe),h.Cd=function(t){Rgn(this.a,l(t,293))},I(rr,"LabelDummySwitcher/lambda$3$Type",1382),D(1383,1,ii,pS),h.Ne=function(t,n){return cgn(l(t,293),l(n,293))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(rr,"LabelDummySwitcher/lambda$4$Type",1383),D(802,1,ts,CZ),h.Kf=function(t,n){yvn(l(t,36),n)},I(rr,"LabelManagementProcessor",802),D(1614,1,ts,d5),h.Kf=function(t,n){QCn(l(t,36),n)},I(rr,"LabelSideSelector",1614),D(1622,1,ts,G9),h.Kf=function(t,n){RAn(l(t,36),n)},I(rr,"LayerConstraintPostprocessor",1622),D(1623,1,ts,Vre),h.Kf=function(t,n){OEn(l(t,36),n)};var sLe;I(rr,"LayerConstraintPreprocessor",1623),D(371,22,{3:1,34:1,22:1,371:1},gq);var pB,HK,VK,p1e,V8t=Fr(rr,"LayerConstraintPreprocessor/HiddenNodeConnections",371,Hr,Jbn,E0n),U8t;D(1624,1,ts,aI),h.Kf=function(t,n){tMn(l(t,36),n)},I(rr,"LayerSizeAndGraphHeightCalculator",1624),D(1625,1,ts,Z3),h.Kf=function(t,n){BTn(l(t,36),n)},I(rr,"LongEdgeJoiner",1625),D(1626,1,ts,K9),h.Kf=function(t,n){DLn(l(t,36),n)},I(rr,"LongEdgeSplitter",1626),D(1627,1,ts,Wet),h.Kf=function(t,n){fDn(this,l(t,36),n)},h.e=0,h.f=0,h.j=0,h.k=0,h.n=0,h.o=0;var G8t,K8t;I(rr,"NodePromotion",1627),D(1628,1,ii,SZ),h.Ne=function(t,n){return Cyn(l(t,10),l(n,10))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(rr,"NodePromotion/1",1628),D(1629,1,ii,bS),h.Ne=function(t,n){return Syn(l(t,10),l(n,10))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(rr,"NodePromotion/2",1629),D(1630,1,{},hd),h.Kb=function(t){return l(t,42),Yq(),Hn(),!0},h.Fb=function(t){return this===t},I(rr,"NodePromotion/lambda$0$Type",1630),D(1631,1,{},aYe),h.Kb=function(t){return x2n(this.a,l(t,42))},h.Fb=function(t){return this===t},h.a=0,I(rr,"NodePromotion/lambda$1$Type",1631),D(1632,1,{},oYe),h.Kb=function(t){return y2n(this.a,l(t,42))},h.Fb=function(t){return this===t},h.a=0,I(rr,"NodePromotion/lambda$2$Type",1632),D(1633,1,ts,mj),h.Kf=function(t,n){aIn(l(t,36),n)},I(rr,"NorthSouthPortPostprocessor",1633),D(1634,1,ts,oI),h.Kf=function(t,n){$Dn(l(t,36),n)},I(rr,"NorthSouthPortPreprocessor",1634),D(1635,1,ii,W9),h.Ne=function(t,n){return $3n(l(t,12),l(n,12))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(rr,"NorthSouthPortPreprocessor/lambda$0$Type",1635),D(1636,1,ts,cI),h.Kf=function(t,n){nAn(l(t,36),n)},I(rr,"PartitionMidprocessor",1636),D(1637,1,ti,vj),h.Mb=function(t){return ns(l(t,10),(Nt(),HT))},I(rr,"PartitionMidprocessor/lambda$0$Type",1637),D(1638,1,fr,cYe),h.Cd=function(t){xpn(this.a,l(t,10))},I(rr,"PartitionMidprocessor/lambda$1$Type",1638),D(1639,1,ts,_Z),h.Kf=function(t,n){rCn(l(t,36),n)},I(rr,"PartitionPostprocessor",1639),D(1640,1,ts,uI),h.Kf=function(t,n){mEn(l(t,36),n)},I(rr,"PartitionPreprocessor",1640),D(1641,1,ti,AZ),h.Mb=function(t){return ns(l(t,10),(Nt(),HT))},I(rr,"PartitionPreprocessor/lambda$0$Type",1641),D(1642,1,{},LZ),h.Kb=function(t){return new bn(null,new vw(new hr(dr(qs(l(t,10)).a.Kc(),new j))))},I(rr,"PartitionPreprocessor/lambda$1$Type",1642),D(1643,1,ti,wj),h.Mb=function(t){return o6n(l(t,18))},I(rr,"PartitionPreprocessor/lambda$2$Type",1643),D(1644,1,fr,t8),h.Cd=function(t){ryn(l(t,18))},I(rr,"PartitionPreprocessor/lambda$3$Type",1644),D(1645,1,ts,cz),h.Kf=function(t,n){B_n(l(t,36),n)};var aLe,W8t,Y8t,X8t,oLe,cLe;I(rr,"PortListSorter",1645),D(1648,1,ii,yj),h.Ne=function(t,n){return Kct(l(t,12),l(n,12))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(rr,"PortListSorter/lambda$0$Type",1648),D(1650,1,ii,n8),h.Ne=function(t,n){return Smt(l(t,12),l(n,12))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(rr,"PortListSorter/lambda$1$Type",1650),D(1646,1,{},MZ),h.Kb=function(t){return TE(),l(t,12).e},I(rr,"PortListSorter/lambda$2$Type",1646),D(1647,1,{},lI),h.Kb=function(t){return TE(),l(t,12).g},I(rr,"PortListSorter/lambda$3$Type",1647),D(1649,1,ii,DZ),h.Ne=function(t,n){return D7n(l(t,12),l(n,12))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(rr,"PortListSorter/lambda$4$Type",1649),D(1651,1,ts,IZ),h.Kf=function(t,n){GEn(l(t,36),n)},I(rr,"PortSideProcessor",1651),D(1652,1,ts,OZ),h.Kf=function(t,n){KSn(l(t,36),n)},I(rr,"ReversedEdgeRestorer",1652),D(1657,1,ts,KQe),h.Kf=function(t,n){d7n(this,l(t,36),n)},I(rr,"SelfLoopPortRestorer",1657),D(1658,1,{},NZ),h.Kb=function(t){return new bn(null,new kn(l(t,30).a,16))},I(rr,"SelfLoopPortRestorer/lambda$0$Type",1658),D(1659,1,ti,xj),h.Mb=function(t){return l(t,10).k==(Zn(),Ps)},I(rr,"SelfLoopPortRestorer/lambda$1$Type",1659),D(1660,1,ti,PZ),h.Mb=function(t){return ns(l(t,10),(ft(),h3))},I(rr,"SelfLoopPortRestorer/lambda$2$Type",1660),D(1661,1,{},BZ),h.Kb=function(t){return l(Q(l(t,10),(ft(),h3)),337)},I(rr,"SelfLoopPortRestorer/lambda$3$Type",1661),D(1662,1,fr,iYe),h.Cd=function(t){A9n(this.a,l(t,337))},I(rr,"SelfLoopPortRestorer/lambda$4$Type",1662),D(805,1,fr,kj),h.Cd=function(t){z9n(l(t,105))},I(rr,"SelfLoopPortRestorer/lambda$5$Type",805),D(1663,1,ts,FZ),h.Kf=function(t,n){w6n(l(t,36),n)},I(rr,"SelfLoopPostProcessor",1663),D(1664,1,{},RZ),h.Kb=function(t){return new bn(null,new kn(l(t,30).a,16))},I(rr,"SelfLoopPostProcessor/lambda$0$Type",1664),D(1665,1,ti,jZ),h.Mb=function(t){return l(t,10).k==(Zn(),Ps)},I(rr,"SelfLoopPostProcessor/lambda$1$Type",1665),D(1666,1,ti,$Z),h.Mb=function(t){return ns(l(t,10),(ft(),h3))},I(rr,"SelfLoopPostProcessor/lambda$2$Type",1666),D(1667,1,fr,Ej),h.Cd=function(t){M8n(l(t,10))},I(rr,"SelfLoopPostProcessor/lambda$3$Type",1667),D(1668,1,{},zZ),h.Kb=function(t){return new bn(null,new kn(l(t,105).f,1))},I(rr,"SelfLoopPostProcessor/lambda$4$Type",1668),D(1669,1,fr,rYe),h.Cd=function(t){nmn(this.a,l(t,340))},I(rr,"SelfLoopPostProcessor/lambda$5$Type",1669),D(1670,1,ti,qZ),h.Mb=function(t){return!!l(t,105).i},I(rr,"SelfLoopPostProcessor/lambda$6$Type",1670),D(1671,1,fr,sYe),h.Cd=function(t){nun(this.a,l(t,105))},I(rr,"SelfLoopPostProcessor/lambda$7$Type",1671),D(1653,1,ts,Tj),h.Kf=function(t,n){xTn(l(t,36),n)},I(rr,"SelfLoopPreProcessor",1653),D(1654,1,{},Cj),h.Kb=function(t){return new bn(null,new kn(l(t,105).f,1))},I(rr,"SelfLoopPreProcessor/lambda$0$Type",1654),D(1655,1,{},Sj),h.Kb=function(t){return l(t,340).a},I(rr,"SelfLoopPreProcessor/lambda$1$Type",1655),D(1656,1,fr,HZ),h.Cd=function(t){shn(l(t,18))},I(rr,"SelfLoopPreProcessor/lambda$2$Type",1656),D(1672,1,ts,Vrt),h.Kf=function(t,n){u9n(this,l(t,36),n)},I(rr,"SelfLoopRouter",1672),D(1673,1,{},VZ),h.Kb=function(t){return new bn(null,new kn(l(t,30).a,16))},I(rr,"SelfLoopRouter/lambda$0$Type",1673),D(1674,1,ti,Y9),h.Mb=function(t){return l(t,10).k==(Zn(),Ps)},I(rr,"SelfLoopRouter/lambda$1$Type",1674),D(1675,1,ti,r8),h.Mb=function(t){return ns(l(t,10),(ft(),h3))},I(rr,"SelfLoopRouter/lambda$2$Type",1675),D(1676,1,{},mS),h.Kb=function(t){return l(Q(l(t,10),(ft(),h3)),337)},I(rr,"SelfLoopRouter/lambda$3$Type",1676),D(1677,1,fr,Aet),h.Cd=function(t){ppn(this.a,this.b,l(t,337))},I(rr,"SelfLoopRouter/lambda$4$Type",1677),D(1678,1,ts,UZ),h.Kf=function(t,n){jCn(l(t,36),n)},I(rr,"SemiInteractiveCrossMinProcessor",1678),D(1679,1,ti,hI),h.Mb=function(t){return l(t,10).k==(Zn(),Ps)},I(rr,"SemiInteractiveCrossMinProcessor/lambda$0$Type",1679),D(1680,1,ti,vS),h.Mb=function(t){return ost(l(t,10))._b((Nt(),w4))},I(rr,"SemiInteractiveCrossMinProcessor/lambda$1$Type",1680),D(1681,1,ii,fI),h.Ne=function(t,n){return n3n(l(t,10),l(n,10))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(rr,"SemiInteractiveCrossMinProcessor/lambda$2$Type",1681),D(1682,1,{},_j),h.Ve=function(t,n){return kpn(l(t,10),l(n,10))},I(rr,"SemiInteractiveCrossMinProcessor/lambda$3$Type",1682),D(1684,1,ts,Aj),h.Kf=function(t,n){uLn(l(t,36),n)},I(rr,"SortByInputModelProcessor",1684),D(1685,1,ti,GZ),h.Mb=function(t){return l(t,12).g.c.length!=0},I(rr,"SortByInputModelProcessor/lambda$0$Type",1685),D(1686,1,fr,uYe),h.Cd=function(t){G9n(this.a,l(t,12))},I(rr,"SortByInputModelProcessor/lambda$1$Type",1686),D(1759,817,{},mft),h.df=function(t){var n,r,a,o;switch(this.c=t,this.a.g){case 2:n=new bt,Is(Fi(new bn(null,new kn(this.c.a.b,16)),new ree),new Fet(this,n)),ZN(this,new WZ),Vu(n,new Lj),n.c.length=0,Is(Fi(new bn(null,new kn(this.c.a.b,16)),new Mj),new hYe(n)),ZN(this,new YZ),Vu(n,new XZ),n.c.length=0,r=vnt(uce(xy(new bn(null,new kn(this.c.a.b,16)),new fYe(this))),new QZ),Is(new bn(null,new kn(this.c.a.a,16)),new Det(r,n)),ZN(this,new ZZ),Vu(n,new Dj),n.c.length=0;break;case 3:a=new bt,ZN(this,new KZ),o=vnt(uce(xy(new bn(null,new kn(this.c.a.b,16)),new lYe(this))),new JZ),Is(Fi(new bn(null,new kn(this.c.a.b,16)),new eee),new Oet(o,a)),ZN(this,new tee),Vu(a,new nee),a.c.length=0;break;default:throw ue(new NQe)}},h.b=0,I(aa,"EdgeAwareScanlineConstraintCalculation",1759),D(1760,1,Ld,KZ),h.Lb=function(t){return De(l(t,60).g,154)},h.Fb=function(t){return this===t},h.Mb=function(t){return De(l(t,60).g,154)},I(aa,"EdgeAwareScanlineConstraintCalculation/lambda$0$Type",1760),D(1761,1,{},lYe),h.Ye=function(t){return Lkn(this.a,l(t,60))},I(aa,"EdgeAwareScanlineConstraintCalculation/lambda$1$Type",1761),D(1769,1,QU,Let),h.de=function(){FA(this.a,this.b,-1)},h.b=0,I(aa,"EdgeAwareScanlineConstraintCalculation/lambda$10$Type",1769),D(1771,1,Ld,WZ),h.Lb=function(t){return De(l(t,60).g,154)},h.Fb=function(t){return this===t},h.Mb=function(t){return De(l(t,60).g,154)},I(aa,"EdgeAwareScanlineConstraintCalculation/lambda$11$Type",1771),D(1772,1,fr,Lj),h.Cd=function(t){l(t,380).de()},I(aa,"EdgeAwareScanlineConstraintCalculation/lambda$12$Type",1772),D(1773,1,ti,Mj),h.Mb=function(t){return De(l(t,60).g,10)},I(aa,"EdgeAwareScanlineConstraintCalculation/lambda$13$Type",1773),D(1775,1,fr,hYe),h.Cd=function(t){Y4n(this.a,l(t,60))},I(aa,"EdgeAwareScanlineConstraintCalculation/lambda$14$Type",1775),D(1774,1,QU,Net),h.de=function(){FA(this.b,this.a,-1)},h.a=0,I(aa,"EdgeAwareScanlineConstraintCalculation/lambda$15$Type",1774),D(1776,1,Ld,YZ),h.Lb=function(t){return De(l(t,60).g,10)},h.Fb=function(t){return this===t},h.Mb=function(t){return De(l(t,60).g,10)},I(aa,"EdgeAwareScanlineConstraintCalculation/lambda$16$Type",1776),D(1777,1,fr,XZ),h.Cd=function(t){l(t,380).de()},I(aa,"EdgeAwareScanlineConstraintCalculation/lambda$17$Type",1777),D(1778,1,{},fYe),h.Ye=function(t){return Mkn(this.a,l(t,60))},I(aa,"EdgeAwareScanlineConstraintCalculation/lambda$18$Type",1778),D(1779,1,{},QZ),h.We=function(){return 0},I(aa,"EdgeAwareScanlineConstraintCalculation/lambda$19$Type",1779),D(1762,1,{},JZ),h.We=function(){return 0},I(aa,"EdgeAwareScanlineConstraintCalculation/lambda$2$Type",1762),D(1781,1,fr,Det),h.Cd=function(t){egn(this.a,this.b,l(t,316))},h.a=0,I(aa,"EdgeAwareScanlineConstraintCalculation/lambda$20$Type",1781),D(1780,1,QU,Iet),h.de=function(){I2t(this.a,this.b,-1)},h.b=0,I(aa,"EdgeAwareScanlineConstraintCalculation/lambda$21$Type",1780),D(1782,1,Ld,ZZ),h.Lb=function(t){return l(t,60),!0},h.Fb=function(t){return this===t},h.Mb=function(t){return l(t,60),!0},I(aa,"EdgeAwareScanlineConstraintCalculation/lambda$22$Type",1782),D(1783,1,fr,Dj),h.Cd=function(t){l(t,380).de()},I(aa,"EdgeAwareScanlineConstraintCalculation/lambda$23$Type",1783),D(1763,1,ti,eee),h.Mb=function(t){return De(l(t,60).g,10)},I(aa,"EdgeAwareScanlineConstraintCalculation/lambda$3$Type",1763),D(1765,1,fr,Oet),h.Cd=function(t){tgn(this.a,this.b,l(t,60))},h.a=0,I(aa,"EdgeAwareScanlineConstraintCalculation/lambda$4$Type",1765),D(1764,1,QU,Pet),h.de=function(){FA(this.b,this.a,-1)},h.a=0,I(aa,"EdgeAwareScanlineConstraintCalculation/lambda$5$Type",1764),D(1766,1,Ld,tee),h.Lb=function(t){return l(t,60),!0},h.Fb=function(t){return this===t},h.Mb=function(t){return l(t,60),!0},I(aa,"EdgeAwareScanlineConstraintCalculation/lambda$6$Type",1766),D(1767,1,fr,nee),h.Cd=function(t){l(t,380).de()},I(aa,"EdgeAwareScanlineConstraintCalculation/lambda$7$Type",1767),D(1768,1,ti,ree),h.Mb=function(t){return De(l(t,60).g,154)},I(aa,"EdgeAwareScanlineConstraintCalculation/lambda$8$Type",1768),D(1770,1,fr,Fet),h.Cd=function(t){wwn(this.a,this.b,l(t,60))},I(aa,"EdgeAwareScanlineConstraintCalculation/lambda$9$Type",1770),D(1586,1,ts,nrt),h.Kf=function(t,n){FLn(this,l(t,36),n)};var Q8t;I(aa,"HorizontalGraphCompactor",1586),D(1587,1,{},dYe),h.ff=function(t,n){var r,a,o;return q6e(t,n)||(r=G5(t),a=G5(n),r&&r.k==(Zn(),Us)||a&&a.k==(Zn(),Us))?0:(o=l(Q(this.a.a,(ft(),$6)),312),zhn(o,r?r.k:(Zn(),Aa),a?a.k:(Zn(),Aa)))},h.gf=function(t,n){var r,a,o;return q6e(t,n)?1:(r=G5(t),a=G5(n),o=l(Q(this.a.a,(ft(),$6)),312),Oye(o,r?r.k:(Zn(),Aa),a?a.k:(Zn(),Aa)))},I(aa,"HorizontalGraphCompactor/1",1587),D(1588,1,{},Ij),h.ef=function(t,n){return p_(),t.a.i==0},I(aa,"HorizontalGraphCompactor/lambda$0$Type",1588),D(1589,1,{},gYe),h.ef=function(t,n){return Cpn(this.a,t,n)},I(aa,"HorizontalGraphCompactor/lambda$1$Type",1589),D(1730,1,{},Glt);var J8t,Z8t;I(aa,"LGraphToCGraphTransformer",1730),D(1738,1,ti,wS),h.Mb=function(t){return t!=null},I(aa,"LGraphToCGraphTransformer/0methodref$nonNull$Type",1738),D(1731,1,{},iee),h.Kb=function(t){return u0(),xc(Q(l(l(t,60).g,10),(ft(),zi)))},I(aa,"LGraphToCGraphTransformer/lambda$0$Type",1731),D(1732,1,{},see),h.Kb=function(t){return u0(),r1t(l(l(t,60).g,154))},I(aa,"LGraphToCGraphTransformer/lambda$1$Type",1732),D(1741,1,ti,Oj),h.Mb=function(t){return u0(),De(l(t,60).g,10)},I(aa,"LGraphToCGraphTransformer/lambda$10$Type",1741),D(1742,1,fr,aee),h.Cd=function(t){Mpn(l(t,60))},I(aa,"LGraphToCGraphTransformer/lambda$11$Type",1742),D(1743,1,ti,oee),h.Mb=function(t){return u0(),De(l(t,60).g,154)},I(aa,"LGraphToCGraphTransformer/lambda$12$Type",1743),D(1747,1,fr,cee),h.Cd=function(t){o4n(l(t,60))},I(aa,"LGraphToCGraphTransformer/lambda$13$Type",1747),D(1744,1,fr,pYe),h.Cd=function(t){Nln(this.a,l(t,8))},h.a=0,I(aa,"LGraphToCGraphTransformer/lambda$14$Type",1744),D(1745,1,fr,bYe),h.Cd=function(t){Bln(this.a,l(t,116))},h.a=0,I(aa,"LGraphToCGraphTransformer/lambda$15$Type",1745),D(1746,1,fr,mYe),h.Cd=function(t){Pln(this.a,l(t,8))},h.a=0,I(aa,"LGraphToCGraphTransformer/lambda$16$Type",1746),D(1748,1,{},uee),h.Kb=function(t){return u0(),new bn(null,new vw(new hr(dr(qs(l(t,10)).a.Kc(),new j))))},I(aa,"LGraphToCGraphTransformer/lambda$17$Type",1748),D(1749,1,ti,lee),h.Mb=function(t){return u0(),Do(l(t,18))},I(aa,"LGraphToCGraphTransformer/lambda$18$Type",1749),D(1750,1,fr,vYe),h.Cd=function(t){Qvn(this.a,l(t,18))},I(aa,"LGraphToCGraphTransformer/lambda$19$Type",1750),D(1734,1,fr,wYe),h.Cd=function(t){Tbn(this.a,l(t,154))},I(aa,"LGraphToCGraphTransformer/lambda$2$Type",1734),D(1751,1,{},hee),h.Kb=function(t){return u0(),new bn(null,new kn(l(t,30).a,16))},I(aa,"LGraphToCGraphTransformer/lambda$20$Type",1751),D(1752,1,{},Nj),h.Kb=function(t){return u0(),new bn(null,new vw(new hr(dr(qs(l(t,10)).a.Kc(),new j))))},I(aa,"LGraphToCGraphTransformer/lambda$21$Type",1752),D(1753,1,{},fee),h.Kb=function(t){return u0(),l(Q(l(t,18),(ft(),fv)),15)},I(aa,"LGraphToCGraphTransformer/lambda$22$Type",1753),D(1754,1,ti,Pj),h.Mb=function(t){return qhn(l(t,15))},I(aa,"LGraphToCGraphTransformer/lambda$23$Type",1754),D(1755,1,fr,yYe),h.Cd=function(t){vkn(this.a,l(t,15))},I(aa,"LGraphToCGraphTransformer/lambda$24$Type",1755),D(1733,1,fr,Ret),h.Cd=function(t){xmn(this.a,this.b,l(t,154))},I(aa,"LGraphToCGraphTransformer/lambda$3$Type",1733),D(1735,1,{},dee),h.Kb=function(t){return u0(),new bn(null,new kn(l(t,30).a,16))},I(aa,"LGraphToCGraphTransformer/lambda$4$Type",1735),D(1736,1,{},gee),h.Kb=function(t){return u0(),new bn(null,new vw(new hr(dr(qs(l(t,10)).a.Kc(),new j))))},I(aa,"LGraphToCGraphTransformer/lambda$5$Type",1736),D(1737,1,{},pee),h.Kb=function(t){return u0(),l(Q(l(t,18),(ft(),fv)),15)},I(aa,"LGraphToCGraphTransformer/lambda$6$Type",1737),D(1739,1,fr,xYe),h.Cd=function(t){Dkn(this.a,l(t,15))},I(aa,"LGraphToCGraphTransformer/lambda$8$Type",1739),D(1740,1,fr,jet),h.Cd=function(t){ahn(this.a,this.b,l(t,154))},I(aa,"LGraphToCGraphTransformer/lambda$9$Type",1740),D(1729,1,{},yS),h.cf=function(t){var n,r,a,o,f;for(this.a=t,this.d=new jie,this.c=We(z_e,Rn,125,this.a.a.a.c.length,0,1),this.b=0,r=new G(this.a.a.a);r.a=te&&(vt(f,pt(L)),Me=b.Math.max(Me,$e[L-1]-B),w+=J,fe+=$e[L-1]-fe,B=$e[L-1],J=E[L]),J=b.Math.max(J,E[L]),++L;w+=J}V=b.Math.min(1/Me,1/n.b/w),V>a&&(a=V,r=f)}return r},h.pg=function(){return!1},I(Od,"MSDCutIndexHeuristic",816),D(1683,1,ts,Fee),h.Kf=function(t,n){$An(l(t,36),n)},I(Od,"SingleEdgeGraphWrapper",1683),D(232,22,{3:1,34:1,22:1,232:1},E_);var O6,IT,OT,h4,qL,N6,NT=Fr(ou,"CenterEdgeLabelPlacementStrategy",232,Hr,Cvn,_0n),hxt;D(431,22,{3:1,34:1,22:1,431:1},N3e);var lLe,S1e,hLe=Fr(ou,"ConstraintCalculationStrategy",431,Hr,Upn,A0n),fxt;D(322,22,{3:1,34:1,22:1,322:1,188:1,196:1},wse),h.dg=function(){return $pt(this)},h.qg=function(){return $pt(this)};var mB,HL,fLe,dLe=Fr(ou,"CrossingMinimizationStrategy",322,Hr,j2n,L0n),dxt;D(351,22,{3:1,34:1,22:1,351:1},yse);var gLe,_1e,YK,pLe=Fr(ou,"CuttingStrategy",351,Hr,$2n,M0n),gxt;D(348,22,{3:1,34:1,22:1,348:1,188:1,196:1},uO),h.dg=function(){return M2t(this)},h.qg=function(){return M2t(this)};var bLe,A1e,PT,L1e,BT,mLe=Fr(ou,"CycleBreakingStrategy",348,Hr,Hmn,D0n),pxt;D(428,22,{3:1,34:1,22:1,428:1},P3e);var XK,vLe,wLe=Fr(ou,"DirectionCongruency",428,Hr,Vpn,I0n),bxt;D(460,22,{3:1,34:1,22:1,460:1},xse);var FT,M1e,P6,mxt=Fr(ou,"EdgeConstraint",460,Hr,z2n,j0n),vxt;D(283,22,{3:1,34:1,22:1,283:1},T_);var D1e,I1e,O1e,N1e,QK,P1e,yLe=Fr(ou,"EdgeLabelSideSelection",283,Hr,kvn,$0n),wxt;D(488,22,{3:1,34:1,22:1,488:1},B3e);var JK,xLe,kLe=Fr(ou,"EdgeStraighteningStrategy",488,Hr,Jpn,z0n),yxt;D(281,22,{3:1,34:1,22:1,281:1},C_);var B1e,ELe,TLe,ZK,CLe,SLe,_Le=Fr(ou,"FixedAlignment",281,Hr,Evn,R0n),xxt;D(282,22,{3:1,34:1,22:1,282:1},S_);var ALe,LLe,MLe,DLe,VL,ILe,OLe=Fr(ou,"GraphCompactionStrategy",282,Hr,Tvn,O0n),kxt;D(259,22,{3:1,34:1,22:1,259:1},uy);var RT,eW,jT,vf,UL,tW,$T,B6,nW,GL,F1e=Fr(ou,"GraphProperties",259,Hr,c3n,N0n),Ext;D(299,22,{3:1,34:1,22:1,299:1},kse);var vB,R1e,j1e,$1e=Fr(ou,"GreedySwitchType",299,Hr,q2n,P0n),Txt;D(311,22,{3:1,34:1,22:1,311:1},Ese);var Ux,wB,F6,Cxt=Fr(ou,"InLayerConstraint",311,Hr,H2n,B0n),Sxt;D(429,22,{3:1,34:1,22:1,429:1},F3e);var z1e,NLe,PLe=Fr(ou,"InteractiveReferencePoint",429,Hr,Hpn,F0n),_xt,BLe,Gx,c3,rW,FLe,RLe,iW,jLe,yB,sW,KL,Kx,pp,q1e,aW,Wc,$Le,jb,Lu,H1e,V1e,xB,hv,u3,Wx,zLe,Yx,kB,f4,o1,$f,U1e,R6,Ki,zi,qLe,HLe,VLe,ULe,GLe,G1e,oW,jl,l3,K1e,Xx,WL,W1,j6,h3,$6,z6,zT,fv,KLe,W1e,Y1e,Qx;D(171,22,{3:1,34:1,22:1,171:1},lO);var YL,$b,XL,d4,EB,WLe=Fr(ou,"LayerConstraint",171,Hr,Umn,q0n),Axt;D(859,1,Pf,Yre),h.hf=function(t){sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,VEe),""),"Direction Congruency"),"Specifies how drawings of the same graph with different layout directions compare to each other: either a natural reading direction is preserved or the drawings are rotated versions of each other."),iMe),(g2(),ps)),wLe),un((r1(),Pn))))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,UEe),""),"Feedback Edges"),"Whether feedback edges should be highlighted by routing around the nodes."),(Hn(),!1)),ya),Ns),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,fG),""),"Interactive Reference Point"),"Determines which point of a node is considered by interactive layout phases."),lMe),ps),PLe),un(Pn)))),Qs(t,fG,zhe,k9t),Qs(t,fG,pL,x9t),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,GEe),""),"Merge Edges"),"Edges that have no ports are merged so they touch the connected nodes at the same points. When this option is disabled, one port is created for each edge directly connected to a node. When it is enabled, all such incoming edges share an input port, and all outgoing edges share an output port."),!1),ya),Ns),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,KEe),""),"Merge Hierarchy-Crossing Edges"),"If hierarchical layout is active, hierarchy-crossing edges use as few hierarchical ports as possible. They are broken by the algorithm, with hierarchical ports inserted as required. Usually, one such port is created for each edge at each hierarchy crossing point. With this option set to true, we try to create as few hierarchical ports as possible in the process. In particular, all edges that form a hyperedge can share a port."),!0),ya),Ns),un(Pn)))),sn(t,new Xt(Nun(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,WEe),""),"Allow Non-Flow Ports To Switch Sides"),"Specifies whether non-flow ports may switch sides if their node's port constraints are either FIXED_SIDE or FIXED_ORDER. A non-flow port is a port on a side that is not part of the currently configured layout flow. For instance, given a left-to-right layout direction, north and south ports would be considered non-flow ports. Further note that the underlying criterium whether to switch sides or not solely relies on the minimization of edge crossings. Hence, edge length and other aesthetics criteria are not addressed."),!1),ya),Ns),un(yv)),he(le(zt,1),dt,2,6,["org.eclipse.elk.layered.northOrSouthPort"])))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,YEe),""),"Port Sorting Strategy"),"Only relevant for nodes with FIXED_SIDE port constraints. Determines the way a node's ports are distributed on the sides of a node if their order is not prescribed. The option is set on parent nodes."),vMe),ps),_De),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,XEe),""),"Thoroughness"),"How much effort should be spent to produce a nice layout."),pt(7)),Tc),ro),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,QEe),""),"Add Unnecessary Bendpoints"),"Adds bend points even if an edge does not change direction. If true, each long edge dummy will contribute a bend point to its edges and hierarchy-crossing edges will always get a bend point where they cross hierarchy boundaries. By default, bend points are only added where an edge changes direction."),!1),ya),Ns),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,JEe),""),"Generate Position and Layer IDs"),"If enabled position id and layer id are generated, which are usually only used internally when setting the interactiveLayout option. This option should be specified on the root node."),!1),ya),Ns),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,zhe),"cycleBreaking"),"Cycle Breaking Strategy"),"Strategy for cycle breaking. Cycle breaking looks for cycles in the graph and determines which edges to reverse to break the cycles. Reversed edges will end up pointing to the opposite direction of regular edges (that is, reversed edges will point left if edges usually point right)."),rMe),ps),mLe),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,qP),hfe),"Node Layering Strategy"),"Strategy for node layering."),dMe),ps),pDe),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,ZEe),hfe),"Layer Constraint"),"Determines a constraint on the placement of the node regarding the layering."),hMe),ps),WLe),un(ha)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,eTe),hfe),"Layer Choice Constraint"),"Allows to set a constraint regarding the layer placement of a node. Let i be the value of teh constraint. Assumed the drawing has n layers and i < n. If set to i, it expresses that the node should be placed in i-th layer. Should i>=n be true then the node is placed in the last layer of the drawing. Note that this option is not part of any of ELK Layered's default configurations but is only evaluated as part of the `InteractiveLayeredGraphVisitor`, which must be applied manually or used via the `DiagramLayoutEngine."),null),Tc),ro),un(ha)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,tTe),hfe),"Layer ID"),"Layer identifier that was calculated by ELK Layered for a node. This is only generated if interactiveLayot or generatePositionAndLayerIds is set."),pt(-1)),Tc),ro),un(ha)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,qhe),J3t),"Upper Bound On Width [MinWidth Layerer]"),"Defines a loose upper bound on the width of the MinWidth layerer. If set to '-1' multiple values are tested and the best result is selected."),pt(4)),Tc),ro),un(Pn)))),Qs(t,qhe,qP,L9t),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,Hhe),J3t),"Upper Layer Estimation Scaling Factor [MinWidth Layerer]"),"Multiplied with Upper Bound On Width for defining an upper bound on the width of layers which haven't been determined yet, but whose maximum width had been (roughly) estimated by the MinWidth algorithm. Compensates for too high estimations. If set to '-1' multiple values are tested and the best result is selected."),pt(2)),Tc),ro),un(Pn)))),Qs(t,Hhe,qP,D9t),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,Vhe),Z3t),"Node Promotion Strategy"),"Reduces number of dummy nodes after layering phase (if possible)."),fMe),ps),TDe),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,Uhe),Z3t),"Max Node Promotion Iterations"),"Limits the number of iterations for node promotion."),pt(0)),Tc),ro),un(Pn)))),Qs(t,Uhe,Vhe,null),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,Ghe),"layering.coffmanGraham"),"Layer Bound"),"The maximum number of nodes allowed per layer."),pt(Ii)),Tc),ro),un(Pn)))),Qs(t,Ghe,qP,T9t),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,pL),gT),"Crossing Minimization Strategy"),"Strategy for crossing minimization."),nMe),ps),dLe),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,nTe),gT),"Force Node Model Order"),"The node order given by the model does not change to produce a better layout. E.g. if node A is before node B in the model this is not changed during crossing minimization. This assumes that the node model order is already respected before crossing minimization. This can be achieved by setting considerModelOrder.strategy to NODES_AND_EDGES."),!1),ya),Ns),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,Khe),gT),"Hierarchical Sweepiness"),"How likely it is to use cross-hierarchy (1) vs bottom-up (-1)."),.1),fo),ta),un(Pn)))),Qs(t,Khe,CG,Wxt),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,Whe),gT),"Semi-Interactive Crossing Minimization"),"Preserves the order of nodes within a layer but still minimizes crossings between edges connecting long edge dummies. Derives the desired order from positions specified by the 'org.eclipse.elk.position' layout option. Requires a crossing minimization strategy that is able to process 'in-layer' constraints."),!1),ya),Ns),un(Pn)))),Qs(t,Whe,pL,e9t),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,rTe),gT),"In Layer Predecessor of"),"Allows to set a constraint which specifies of which node the current node is the predecessor. If set to 's' then the node is the predecessor of 's' and is in the same layer"),null),J6),zt),un(ha)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,iTe),gT),"In Layer Successor of"),"Allows to set a constraint which specifies of which node the current node is the successor. If set to 's' then the node is the successor of 's' and is in the same layer"),null),J6),zt),un(ha)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,sTe),gT),"Position Choice Constraint"),"Allows to set a constraint regarding the position placement of a node in a layer. Assumed the layer in which the node placed includes n other nodes and i < n. If set to i, it expresses that the node should be placed at the i-th position. Should i>=n be true then the node is placed at the last position in the layer. Note that this option is not part of any of ELK Layered's default configurations but is only evaluated as part of the `InteractiveLayeredGraphVisitor`, which must be applied manually or used via the `DiagramLayoutEngine."),null),Tc),ro),un(ha)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,aTe),gT),"Position ID"),"Position within a layer that was determined by ELK Layered for a node. This is only generated if interactiveLayot or generatePositionAndLayerIds is set."),pt(-1)),Tc),ro),un(ha)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,oTe),eyt),"Greedy Switch Activation Threshold"),"By default it is decided automatically if the greedy switch is activated or not. The decision is based on whether the size of the input graph (without dummy nodes) is smaller than the value of this option. A '0' enforces the activation."),pt(40)),Tc),ro),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,Yhe),eyt),"Greedy Switch Crossing Minimization"),"Greedy Switch strategy for crossing minimization. The greedy switch heuristic is executed after the regular crossing minimization as a post-processor. Note that if 'hierarchyHandling' is set to 'INCLUDE_CHILDREN', the 'greedySwitchHierarchical.type' option must be used."),tMe),ps),$1e),un(Pn)))),Qs(t,Yhe,pL,Gxt),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,dG),"crossingMinimization.greedySwitchHierarchical"),"Greedy Switch Crossing Minimization (hierarchical)"),"Activates the greedy switch heuristic in case hierarchical layout is used. The differences to the non-hierarchical case (see 'greedySwitch.type') are: 1) greedy switch is inactive by default, 3) only the option value set on the node at which hierarchical layout starts is relevant, and 2) if it's activated by the user, it properly addresses hierarchy-crossing edges."),eMe),ps),$1e),un(Pn)))),Qs(t,dG,pL,Hxt),Qs(t,dG,CG,Vxt),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,k6),tyt),"Node Placement Strategy"),"Strategy for node placement."),mMe),ps),wDe),un(Pn)))),sn(t,new Xt(nn(tn(rn(Qt(en(Jt(Zt(new Ut,gG),tyt),"Favor Straight Edges Over Balancing"),"Favor straight edges over a balanced node placement. The default behavior is determined automatically based on the used 'edgeRouting'. For an orthogonal style it is set to true, for all other styles to false."),ya),Ns),un(Pn)))),Qs(t,gG,k6,q9t),Qs(t,gG,k6,H9t),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,Xhe),nyt),"BK Edge Straightening"),"Specifies whether the Brandes Koepf node placer tries to increase the number of straight edges at the expense of diagram size. There is a subtle difference to the 'favorStraightEdges' option, which decides whether a balanced placement of the nodes is desired, or not. In bk terms this means combining the four alignments into a single balanced one, or not. This option on the other hand tries to straighten additional edges during the creation of each of the four alignments."),gMe),ps),kLe),un(Pn)))),Qs(t,Xhe,k6,R9t),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,Qhe),nyt),"BK Fixed Alignment"),"Tells the BK node placer to use a certain alignment (out of its four) instead of the one producing the smallest height, or the combination of all four."),pMe),ps),_Le),un(Pn)))),Qs(t,Qhe,k6,$9t),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,Jhe),"nodePlacement.linearSegments"),"Linear Segments Deflection Dampening"),"Dampens the movement of nodes to keep the diagram from getting too large."),.3),fo),ta),un(Pn)))),Qs(t,Jhe,k6,U9t),sn(t,new Xt(nn(tn(rn(Qt(en(Jt(Zt(new Ut,Zhe),"nodePlacement.networkSimplex"),"Node Flexibility"),"Aims at shorter and straighter edges. Two configurations are possible: (a) allow ports to move freely on the side they are assigned to (the order is always defined beforehand), (b) additionally allow to enlarge a node wherever it helps. If this option is not configured for a node, the 'nodeFlexibility.default' value is used, which is specified for the node's parent."),ps),mde),un(ha)))),Qs(t,Zhe,k6,Y9t),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,efe),"nodePlacement.networkSimplex.nodeFlexibility"),"Node Flexibility Default"),"Default value of the 'nodeFlexibility' option for the children of a hierarchical node."),bMe),ps),mde),un(Pn)))),Qs(t,efe,k6,W9t),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,cTe),ryt),"Self-Loop Distribution"),"Alter the distribution of the loops around the node. It only takes effect for PortConstraints.FREE."),oMe),ps),MDe),un(ha)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,uTe),ryt),"Self-Loop Ordering"),"Alter the ordering of the loops they can either be stacked or sequenced. It only takes effect for PortConstraints.FREE."),cMe),ps),DDe),un(ha)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,pG),"edgeRouting.splines"),"Spline Routing Mode"),"Specifies the way control points are assembled for each individual edge. CONSERVATIVE ensures that edges are properly routed around the nodes but feels rather orthogonal at times. SLOPPY uses fewer control points to obtain curvier edge routes but may result in edges overlapping nodes."),uMe),ps),ODe),un(Pn)))),Qs(t,pG,HP,h9t),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,bG),"edgeRouting.splines.sloppy"),"Sloppy Spline Layer Spacing Factor"),"Spacing factor for routing area between layers when using sloppy spline routing."),.2),fo),ta),un(Pn)))),Qs(t,bG,HP,d9t),Qs(t,bG,pG,g9t),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,tfe),"edgeRouting.polyline"),"Sloped Edge Zone Width"),"Width of the strip to the left and to the right of each layer where the polyline edge router is allowed to refrain from ensuring that edges are routed horizontally. This prevents awkward bend points for nodes that extent almost to the edge of their layer."),2),fo),ta),un(Pn)))),Qs(t,tfe,HP,o9t),sn(t,new Xt(nn(tn(rn(Qt(en(Jt(Zt(new Ut,lTe),U1),"Spacing Base Value"),"An optional base value for all other layout options of the 'spacing' group. It can be used to conveniently alter the overall 'spaciousness' of the drawing. Whenever an explicit value is set for the other layout options, this base value will have no effect. The base value is not inherited, i.e. it must be set for each hierarchical node."),fo),ta),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,hTe),U1),"Edge Node Between Layers Spacing"),"The spacing to be preserved between nodes and edges that are routed next to the node's layer. For the spacing between nodes and edges that cross the node's layer 'spacing.edgeNode' is used."),10),fo),ta),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,fTe),U1),"Edge Edge Between Layer Spacing"),"Spacing to be preserved between pairs of edges that are routed between the same pair of layers. Note that 'spacing.edgeEdge' is used for the spacing between pairs of edges crossing the same layer."),10),fo),ta),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,dTe),U1),"Node Node Between Layers Spacing"),"The spacing to be preserved between any pair of nodes of two adjacent layers. Note that 'spacing.nodeNode' is used for the spacing between nodes within the layer itself."),20),fo),ta),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,gTe),TTe),"Direction Priority"),"Defines how important it is to have a certain edge point into the direction of the overall layout. This option is evaluated during the cycle breaking phase."),pt(0)),Tc),ro),un(zd)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,pTe),TTe),"Shortness Priority"),"Defines how important it is to keep an edge as short as possible. This option is evaluated during the layering phase."),pt(0)),Tc),ro),un(zd)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,bTe),TTe),"Straightness Priority"),"Defines how important it is to keep an edge straight, i.e. aligned with one of the two axes. This option is evaluated during node placement."),pt(0)),Tc),ro),un(zd)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,nfe),CTe),w3t),"Tries to further compact components (disconnected sub-graphs)."),!1),ya),Ns),un(Pn)))),Qs(t,nfe,lL,!0),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,mTe),iyt),"Post Compaction Strategy"),syt),XLe),ps),OLe),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,vTe),iyt),"Post Compaction Constraint Calculation"),syt),YLe),ps),hLe),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,mG),STe),"High Degree Node Treatment"),"Makes room around high degree nodes to place leafs and trees."),!1),ya),Ns),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,rfe),STe),"High Degree Node Threshold"),"Whether a node is considered to have a high degree."),pt(16)),Tc),ro),un(Pn)))),Qs(t,rfe,mG,!0),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,ife),STe),"High Degree Node Maximum Tree Height"),"Maximum height of a subtree connected to a high degree node to be moved to separate layers."),pt(5)),Tc),ro),un(Pn)))),Qs(t,ife,mG,!0),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,fp),_Te),"Graph Wrapping Strategy"),"For certain graphs and certain prescribed drawing areas it may be desirable to split the laid out graph into chunks that are placed side by side. The edges that connect different chunks are 'wrapped' around from the end of one chunk to the start of the other chunk. The points between the chunks are referred to as 'cuts'."),xMe),ps),FDe),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,vG),_Te),"Additional Wrapped Edges Spacing"),"To visually separate edges that are wrapped from regularly routed edges an additional spacing value can be specified in form of this layout option. The spacing is added to the regular edgeNode spacing."),10),fo),ta),un(Pn)))),Qs(t,vG,fp,ckt),Qs(t,vG,fp,ukt),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,wG),_Te),"Correction Factor for Wrapping"),"At times and for certain types of graphs the executed wrapping may produce results that are consistently biased in the same fashion: either wrapping to often or to rarely. This factor can be used to correct the bias. Internally, it is simply multiplied with the 'aspect ratio' layout option."),1),fo),ta),un(Pn)))),Qs(t,wG,fp,hkt),Qs(t,wG,fp,fkt),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,bL),ayt),"Cutting Strategy"),"The strategy by which the layer indexes are determined at which the layering crumbles into chunks."),yMe),ps),pLe),un(Pn)))),Qs(t,bL,fp,vkt),Qs(t,bL,fp,wkt),sn(t,new Xt(nn(tn(rn(Qt(en(Jt(Zt(new Ut,sfe),ayt),"Manually Specified Cuts"),"Allows the user to specify her own cuts for a certain graph."),X1),mf),un(Pn)))),Qs(t,sfe,bL,gkt),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,afe),"wrapping.cutting.msd"),"MSD Freedom"),"The MSD cutting strategy starts with an initial guess on the number of chunks the graph should be split into. The freedom specifies how much the strategy may deviate from this guess. E.g. if an initial number of 3 is computed, a freedom of 1 allows 2, 3, and 4 cuts."),wMe),Tc),ro),un(Pn)))),Qs(t,afe,bL,bkt),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,yG),oyt),"Validification Strategy"),"When wrapping graphs, one can specify indices that are not allowed as split points. The validification strategy makes sure every computed split point is allowed."),kMe),ps),BDe),un(Pn)))),Qs(t,yG,fp,Dkt),Qs(t,yG,fp,Ikt),sn(t,new Xt(nn(tn(rn(Qt(en(Jt(Zt(new Ut,xG),oyt),"Valid Indices for Wrapping"),null),X1),mf),un(Pn)))),Qs(t,xG,fp,Akt),Qs(t,xG,fp,Lkt),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,kG),ATe),"Improve Cuts"),"For general graphs it is important that not too many edges wrap backwards. Thus a compromise between evenly-distributed cuts and the total number of cut edges is sought."),!0),ya),Ns),un(Pn)))),Qs(t,kG,fp,Ekt),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,EG),ATe),"Distance Penalty When Improving Cuts"),null),2),fo),ta),un(Pn)))),Qs(t,EG,fp,xkt),Qs(t,EG,kG,!0),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,ofe),ATe),"Improve Wrapped Edges"),"The initial wrapping is performed in a very simple way. As a consequence, edges that wrap from one chunk to another may be unnecessarily long. Activating this option tries to shorten such edges."),!0),ya),Ns),un(Pn)))),Qs(t,ofe,fp,Ckt),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,wTe),ffe),"Edge Label Side Selection"),"Method to decide on edge label sides."),aMe),ps),yLe),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,yTe),ffe),"Edge Center Label Placement Strategy"),"Determines in which layer center labels of long edges should be placed."),sMe),ps),NT),rs(Pn,he(le(xg,1),it,170,0,[S2]))))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,TG),mL),"Consider Model Order"),"Preserves the order of nodes and edges in the model file if this does not lead to additional edge crossings. Depending on the strategy this is not always possible since the node and edge order might be conflicting."),ZLe),ps),SDe),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,xTe),mL),"Consider Port Order"),"If disabled the port order of output ports is derived from the edge order and input ports are ordered by their incoming connections. If enabled all ports are ordered by the port model order."),!1),ya),Ns),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,kTe),mL),"No Model Order"),"Set on a node to not set a model order for this node even though it is a real node."),!1),ya),Ns),un(ha)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,cfe),mL),"Consider Model Order for Components"),"If set to NONE the usual ordering strategy (by cumulative node priority and size of nodes) is used. INSIDE_PORT_SIDES orders the components with external ports only inside the groups with the same port side. FORCE_MODEL_ORDER enforces the mode order on components. This option might produce bad alignments and sub optimal drawings in terms of used area since the ordering should be respected."),QLe),ps),mAe),un(Pn)))),Qs(t,cfe,lL,null),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,ETe),mL),"Long Edge Ordering Strategy"),"Indicates whether long edges are sorted under, over, or equal to nodes that have no connection to a previous layer in a left-to-right or right-to-left layout. Under and over changes to right and left in a vertical layout."),JLe),ps),mDe),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,ufe),mL),"Crossing Counter Node Order Influence"),"Indicates with what percentage (1 for 100%) violations of the node model order are weighted against the crossings e.g. a value of 0.5 means two model order violations are as important as on edge crossing. This allows some edge crossings in favor of preserving the model order. It is advised to set this value to a very small positive value (e.g. 0.001) to have minimal crossing and a optimal node order. Defaults to no influence (0)."),0),fo),ta),un(Pn)))),Qs(t,ufe,TG,null),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,lfe),mL),"Crossing Counter Port Order Influence"),"Indicates with what percentage (1 for 100%) violations of the port model order are weighted against the crossings e.g. a value of 0.5 means two model order violations are as important as on edge crossing. This allows some edge crossings in favor of preserving the model order. It is advised to set this value to a very small positive value (e.g. 0.001) to have minimal crossing and a optimal port order. Defaults to no influence (0)."),0),fo),ta),un(Pn)))),Qs(t,lfe,TG,null),Twt((new Xre,t))};var Lxt,Mxt,Dxt,YLe,Ixt,XLe,Oxt,QLe,Nxt,Pxt,Bxt,JLe,Fxt,Rxt,jxt,ZLe,$xt,zxt,qxt,eMe,Hxt,Vxt,Uxt,tMe,Gxt,Kxt,Wxt,Yxt,Xxt,Qxt,Jxt,Zxt,e9t,t9t,nMe,n9t,rMe,r9t,iMe,i9t,sMe,s9t,aMe,a9t,o9t,c9t,oMe,u9t,cMe,l9t,uMe,h9t,f9t,d9t,g9t,p9t,b9t,m9t,v9t,w9t,y9t,lMe,x9t,k9t,E9t,T9t,C9t,S9t,hMe,_9t,A9t,L9t,M9t,D9t,I9t,O9t,fMe,N9t,dMe,P9t,B9t,F9t,gMe,R9t,j9t,pMe,$9t,z9t,q9t,H9t,V9t,U9t,G9t,K9t,bMe,W9t,Y9t,X9t,mMe,Q9t,vMe,J9t,Z9t,ekt,tkt,nkt,rkt,ikt,skt,akt,okt,ckt,ukt,lkt,hkt,fkt,dkt,gkt,pkt,wMe,bkt,mkt,yMe,vkt,wkt,ykt,xkt,kkt,Ekt,Tkt,Ckt,Skt,xMe,_kt,Akt,Lkt,Mkt,kMe,Dkt,Ikt;I(ou,"LayeredMetaDataProvider",859),D(998,1,Pf,Xre),h.hf=function(t){Twt(t)};var Rd,X1e,cW,QL,uW,EMe,lW,g4,hW,TMe,CMe,fW,Q1e,yg,J1e,f3,SMe,TB,Z1e,_Me,Okt,Nkt,Pkt,dW,ede,JL,dv,Bkt,Rh,AMe,LMe,gW,tde,jd,pW,bp,MMe,DMe,IMe,nde,rde,OMe,x2,ide,NMe,p4,PMe,BMe,FMe,bW,b4,gv,RMe,jMe,cc,$Me,Fkt,Qu,mW,zMe,qMe,HMe,zb,pv,vW,VMe,UMe,wW,d3,GMe,sde,ZL,KMe,g3,eM,yW,bv,ade,qT,xW,mv,WMe,YMe,XMe,HT,QMe,Rkt,jkt,$kt,zkt,p3,m4,Ms,k2,qkt,v4,JMe,VT,ZMe,w4,Hkt,UT,eDe,Jx,Vkt,Ukt,CB,ode,tDe,SB,x0,q6,H6,b3,vv,kW,y4,cde,GT,KT,m3,V6,ude,_B,tM,nM,Gkt,Kkt,Wkt,nDe,Ykt,lde,rDe,iDe,sDe,aDe,hde,oDe,cDe,uDe,lDe,fde,EW;I(ou,"LayeredOptions",998),D(999,1,{},Ree),h.sf=function(){var t;return t=new qQe,t},h.tf=function(t){},I(ou,"LayeredOptions/LayeredFactory",999),D(1391,1,{}),h.a=0;var Xkt;I(Uc,"ElkSpacings/AbstractSpacingsBuilder",1391),D(792,1391,{},D8e);var TW,Qkt;I(ou,"LayeredSpacings/LayeredSpacingsBuilder",792),D(265,22,{3:1,34:1,22:1,265:1,188:1,196:1},M5),h.dg=function(){return jbt(this)},h.qg=function(){return jbt(this)};var WT,dde,YT,hDe,fDe,dDe,CW,gde,gDe,pDe=Fr(ou,"LayeringStrategy",265,Hr,Rwn,H0n),Jkt;D(390,22,{3:1,34:1,22:1,390:1},Tse);var pde,bDe,SW,mDe=Fr(ou,"LongEdgeOrderingStrategy",390,Hr,V2n,V0n),Zkt;D(203,22,{3:1,34:1,22:1,203:1},bq);var U6,G6,_W,bde,mde=Fr(ou,"NodeFlexibility",203,Hr,Zbn,U0n),eEt;D(323,22,{3:1,34:1,22:1,323:1,188:1,196:1},hO),h.dg=function(){return L2t(this)},h.qg=function(){return L2t(this)};var rM,vde,wde,iM,vDe,wDe=Fr(ou,"NodePlacementStrategy",323,Hr,Vmn,G0n),tEt;D(243,22,{3:1,34:1,22:1,243:1},ly);var yDe,v3,x4,AB,xDe,kDe,LB,EDe,AW,LW,TDe=Fr(ou,"NodePromotionStrategy",243,Hr,u3n,K0n),nEt;D(284,22,{3:1,34:1,22:1,284:1},mq);var CDe,E2,yde,xde,SDe=Fr(ou,"OrderingStrategy",284,Hr,emn,W0n),rEt;D(430,22,{3:1,34:1,22:1,430:1},R3e);var kde,Ede,_De=Fr(ou,"PortSortingStrategy",430,Hr,Gpn,Y0n),iEt;D(463,22,{3:1,34:1,22:1,463:1},Cse);var $l,zu,sM,sEt=Fr(ou,"PortType",463,Hr,U2n,X0n),aEt;D(387,22,{3:1,34:1,22:1,387:1},Sse);var ADe,Tde,LDe,MDe=Fr(ou,"SelfLoopDistributionStrategy",387,Hr,G2n,Q0n),oEt;D(349,22,{3:1,34:1,22:1,349:1},_se);var Cde,MB,Sde,DDe=Fr(ou,"SelfLoopOrderingStrategy",349,Hr,K2n,J0n),cEt;D(312,1,{312:1},xvt),I(ou,"Spacings",312),D(350,22,{3:1,34:1,22:1,350:1},Ase);var _de,IDe,aM,ODe=Fr(ou,"SplineRoutingMode",350,Hr,W2n,Z0n),uEt;D(352,22,{3:1,34:1,22:1,352:1},Lse);var Ade,NDe,PDe,BDe=Fr(ou,"ValidifyStrategy",352,Hr,Y2n,e1n),lEt;D(388,22,{3:1,34:1,22:1,388:1},Mse);var k4,Lde,XT,FDe=Fr(ou,"WrappingStrategy",388,Hr,X2n,t1n),hEt;D(1398,1,Uo,Ure),h.rg=function(t){return l(t,36),fEt},h.Kf=function(t,n){NLn(this,l(t,36),n)};var fEt;I(LG,"DepthFirstCycleBreaker",1398),D(793,1,Uo,Q4e),h.rg=function(t){return l(t,36),dEt},h.Kf=function(t,n){FIn(this,l(t,36),n)},h.sg=function(t){return l(jt(t,aU(this.d,t.c.length)),10)};var dEt;I(LG,"GreedyCycleBreaker",793),D(1401,793,Uo,$tt),h.sg=function(t){var n,r,a,o;for(o=null,n=Ii,a=new G(t);a.a1&&(Rt(Bt(Q(eo((Sn(0,t.c.length),l(t.c[0],10))),(Nt(),f3))))?q2t(t,this.d,l(this,669)):(Cn(),Vs(t,this.d)),Hft(this.e,t))},h.lg=function(t,n,r,a){var o,f,g,w,E,C,L;for(n!=ast(r,t.length)&&(f=t[n-(r?1:-1)],S6e(this.f,f,r?(qo(),zu):(qo(),$l))),o=t[n][0],L=!a||o.k==(Zn(),Us),C=O1(t[n]),this.vg(C,L,!1,r),g=0,E=new G(C);E.a"),t0?loe(this.a,t[n-1],t[n]):!r&&n1&&(Rt(Bt(Q(eo((Sn(0,t.c.length),l(t.c[0],10))),(Nt(),f3))))?q2t(t,this.d,this):(Cn(),Vs(t,this.d)),Rt(Bt(Q(eo((Sn(0,t.c.length),l(t.c[0],10))),f3)))||Hft(this.e,t))},I(Cl,"ModelOrderBarycenterHeuristic",669),D(1866,1,ii,zYe),h.Ne=function(t,n){return O9n(this.a,l(t,10),l(n,10))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(Cl,"ModelOrderBarycenterHeuristic/lambda$0$Type",1866),D(1423,1,Uo,Jre),h.rg=function(t){var n;return l(t,36),n=Oq(LEt),fi(n,(uo(),bu),(vo(),RK)),n},h.Kf=function(t,n){bpn((l(t,36),n))};var LEt;I(Cl,"NoCrossingMinimizer",1423),D(809,413,uCe,o3e),h.tg=function(t,n,r){var a,o,f,g,w,E,C,L,B,z,V;switch(B=this.g,r.g){case 1:{for(o=0,f=0,L=new G(t.j);L.a1&&(o.j==(Ct(),ar)?this.b[t]=!0:o.j==er&&t>0&&(this.b[t-1]=!0))},h.f=0,I(bg,"AllCrossingsCounter",1861),D(595,1,{},TV),h.b=0,h.d=0,I(bg,"BinaryIndexedTree",595),D(532,1,{},IO);var $De,DW;I(bg,"CrossingsCounter",532),D(1950,1,ii,qYe),h.Ne=function(t,n){return qdn(this.a,l(t,12),l(n,12))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(bg,"CrossingsCounter/lambda$0$Type",1950),D(1951,1,ii,HYe),h.Ne=function(t,n){return Hdn(this.a,l(t,12),l(n,12))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(bg,"CrossingsCounter/lambda$1$Type",1951),D(1952,1,ii,VYe),h.Ne=function(t,n){return Vdn(this.a,l(t,12),l(n,12))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(bg,"CrossingsCounter/lambda$2$Type",1952),D(1953,1,ii,UYe),h.Ne=function(t,n){return Udn(this.a,l(t,12),l(n,12))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(bg,"CrossingsCounter/lambda$3$Type",1953),D(1954,1,fr,GYe),h.Cd=function(t){Uvn(this.a,l(t,12))},I(bg,"CrossingsCounter/lambda$4$Type",1954),D(1955,1,ti,KYe),h.Mb=function(t){return bln(this.a,l(t,12))},I(bg,"CrossingsCounter/lambda$5$Type",1955),D(1956,1,fr,WYe),h.Cd=function(t){Dtt(this,t)},I(bg,"CrossingsCounter/lambda$6$Type",1956),D(1957,1,fr,qet),h.Cd=function(t){var n;jk(),gb(this.b,(n=this.a,l(t,12),n))},I(bg,"CrossingsCounter/lambda$7$Type",1957),D(839,1,Ld,Xj),h.Lb=function(t){return jk(),ns(l(t,12),(ft(),jl))},h.Fb=function(t){return this===t},h.Mb=function(t){return jk(),ns(l(t,12),(ft(),jl))},I(bg,"CrossingsCounter/lambda$8$Type",839),D(1949,1,{},YYe),I(bg,"HyperedgeCrossingsCounter",1949),D(478,1,{34:1,478:1},Urt),h.Fd=function(t){return V5n(this,l(t,478))},h.b=0,h.c=0,h.e=0,h.f=0;var TOn=I(bg,"HyperedgeCrossingsCounter/Hyperedge",478);D(374,1,{34:1,374:1},CH),h.Fd=function(t){return iTn(this,l(t,374))},h.b=0,h.c=0;var MEt=I(bg,"HyperedgeCrossingsCounter/HyperedgeCorner",374);D(531,22,{3:1,34:1,22:1,531:1},j3e);var cM,uM,DEt=Fr(bg,"HyperedgeCrossingsCounter/HyperedgeCorner/Type",531,Hr,Kpn,r1n),IEt;D(1425,1,Uo,Zre),h.rg=function(t){return l(Q(l(t,36),(ft(),Lu)),21).Hc((Ho(),vf))?OEt:null},h.Kf=function(t,n){p8n(this,l(t,36),n)};var OEt;I(Go,"InteractiveNodePlacer",1425),D(1426,1,Uo,eie),h.rg=function(t){return l(Q(l(t,36),(ft(),Lu)),21).Hc((Ho(),vf))?NEt:null},h.Kf=function(t,n){Z6n(this,l(t,36),n)};var NEt,IW,OW;I(Go,"LinearSegmentsNodePlacer",1426),D(261,1,{34:1,261:1},Pwe),h.Fd=function(t){return Aun(this,l(t,261))},h.Fb=function(t){var n;return De(t,261)?(n=l(t,261),this.b==n.b):!1},h.Hb=function(){return this.b},h.Ib=function(){return"ls"+Tb(this.e)},h.a=0,h.b=0,h.c=-1,h.d=-1,h.g=0;var PEt=I(Go,"LinearSegmentsNodePlacer/LinearSegment",261);D(1428,1,Uo,bst),h.rg=function(t){return l(Q(l(t,36),(ft(),Lu)),21).Hc((Ho(),vf))?BEt:null},h.Kf=function(t,n){AIn(this,l(t,36),n)},h.b=0,h.g=0;var BEt;I(Go,"NetworkSimplexPlacer",1428),D(1447,1,ii,Gee),h.Ne=function(t,n){return ru(l(t,17).a,l(n,17).a)},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(Go,"NetworkSimplexPlacer/0methodref$compare$Type",1447),D(1449,1,ii,Kee),h.Ne=function(t,n){return ru(l(t,17).a,l(n,17).a)},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(Go,"NetworkSimplexPlacer/1methodref$compare$Type",1449),D(655,1,{655:1},Het);var COn=I(Go,"NetworkSimplexPlacer/EdgeRep",655);D(412,1,{412:1},D5e),h.b=!1;var SOn=I(Go,"NetworkSimplexPlacer/NodeRep",412);D(515,13,{3:1,4:1,20:1,31:1,56:1,13:1,16:1,15:1,59:1,515:1},QQe),I(Go,"NetworkSimplexPlacer/Path",515),D(1429,1,{},Wee),h.Kb=function(t){return l(t,18).d.i.k},I(Go,"NetworkSimplexPlacer/Path/lambda$0$Type",1429),D(1430,1,ti,Yee),h.Mb=function(t){return l(t,273)==(Zn(),Aa)},I(Go,"NetworkSimplexPlacer/Path/lambda$1$Type",1430),D(1431,1,{},Xee),h.Kb=function(t){return l(t,18).d.i},I(Go,"NetworkSimplexPlacer/Path/lambda$2$Type",1431),D(1432,1,ti,XYe),h.Mb=function(t){return Lrt(I1t(l(t,10)))},I(Go,"NetworkSimplexPlacer/Path/lambda$3$Type",1432),D(1433,1,ti,Qee),h.Mb=function(t){return Sdn(l(t,12))},I(Go,"NetworkSimplexPlacer/lambda$0$Type",1433),D(1434,1,fr,Vet),h.Cd=function(t){ohn(this.a,this.b,l(t,12))},I(Go,"NetworkSimplexPlacer/lambda$1$Type",1434),D(1443,1,fr,QYe),h.Cd=function(t){Okn(this.a,l(t,18))},I(Go,"NetworkSimplexPlacer/lambda$10$Type",1443),D(1444,1,{},Jee),h.Kb=function(t){return Sh(),new bn(null,new kn(l(t,30).a,16))},I(Go,"NetworkSimplexPlacer/lambda$11$Type",1444),D(1445,1,fr,JYe),h.Cd=function(t){_Sn(this.a,l(t,10))},I(Go,"NetworkSimplexPlacer/lambda$12$Type",1445),D(1446,1,{},Zee),h.Kb=function(t){return Sh(),pt(l(t,125).e)},I(Go,"NetworkSimplexPlacer/lambda$13$Type",1446),D(1448,1,{},ete),h.Kb=function(t){return Sh(),pt(l(t,125).e)},I(Go,"NetworkSimplexPlacer/lambda$15$Type",1448),D(1450,1,ti,tte),h.Mb=function(t){return Sh(),l(t,412).c.k==(Zn(),Ps)},I(Go,"NetworkSimplexPlacer/lambda$17$Type",1450),D(1451,1,ti,nte),h.Mb=function(t){return Sh(),l(t,412).c.j.c.length>1},I(Go,"NetworkSimplexPlacer/lambda$18$Type",1451),D(1452,1,fr,Tat),h.Cd=function(t){f5n(this.c,this.b,this.d,this.a,l(t,412))},h.c=0,h.d=0,I(Go,"NetworkSimplexPlacer/lambda$19$Type",1452),D(1435,1,{},rte),h.Kb=function(t){return Sh(),new bn(null,new kn(l(t,30).a,16))},I(Go,"NetworkSimplexPlacer/lambda$2$Type",1435),D(1453,1,fr,ZYe),h.Cd=function(t){uhn(this.a,l(t,12))},h.a=0,I(Go,"NetworkSimplexPlacer/lambda$20$Type",1453),D(1454,1,{},ite),h.Kb=function(t){return Sh(),new bn(null,new kn(l(t,30).a,16))},I(Go,"NetworkSimplexPlacer/lambda$21$Type",1454),D(1455,1,fr,eXe),h.Cd=function(t){xhn(this.a,l(t,10))},I(Go,"NetworkSimplexPlacer/lambda$22$Type",1455),D(1456,1,ti,ste),h.Mb=function(t){return Lrt(t)},I(Go,"NetworkSimplexPlacer/lambda$23$Type",1456),D(1457,1,{},ate),h.Kb=function(t){return Sh(),new bn(null,new kn(l(t,30).a,16))},I(Go,"NetworkSimplexPlacer/lambda$24$Type",1457),D(1458,1,ti,tXe),h.Mb=function(t){return Mln(this.a,l(t,10))},I(Go,"NetworkSimplexPlacer/lambda$25$Type",1458),D(1459,1,fr,Uet),h.Cd=function(t){F9n(this.a,this.b,l(t,10))},I(Go,"NetworkSimplexPlacer/lambda$26$Type",1459),D(1460,1,ti,s8),h.Mb=function(t){return Sh(),!Do(l(t,18))},I(Go,"NetworkSimplexPlacer/lambda$27$Type",1460),D(1461,1,ti,Qj),h.Mb=function(t){return Sh(),!Do(l(t,18))},I(Go,"NetworkSimplexPlacer/lambda$28$Type",1461),D(1462,1,{},nXe),h.Ve=function(t,n){return chn(this.a,l(t,30),l(n,30))},I(Go,"NetworkSimplexPlacer/lambda$29$Type",1462),D(1436,1,{},ote),h.Kb=function(t){return Sh(),new bn(null,new vw(new hr(dr(qs(l(t,10)).a.Kc(),new j))))},I(Go,"NetworkSimplexPlacer/lambda$3$Type",1436),D(1437,1,ti,cte),h.Mb=function(t){return Sh(),Rbn(l(t,18))},I(Go,"NetworkSimplexPlacer/lambda$4$Type",1437),D(1438,1,fr,rXe),h.Cd=function(t){BAn(this.a,l(t,18))},I(Go,"NetworkSimplexPlacer/lambda$5$Type",1438),D(1439,1,{},ute),h.Kb=function(t){return Sh(),new bn(null,new kn(l(t,30).a,16))},I(Go,"NetworkSimplexPlacer/lambda$6$Type",1439),D(1440,1,ti,Jj),h.Mb=function(t){return Sh(),l(t,10).k==(Zn(),Ps)},I(Go,"NetworkSimplexPlacer/lambda$7$Type",1440),D(1441,1,{},lte),h.Kb=function(t){return Sh(),new bn(null,new vw(new hr(dr(sp(l(t,10)).a.Kc(),new j))))},I(Go,"NetworkSimplexPlacer/lambda$8$Type",1441),D(1442,1,ti,TS),h.Mb=function(t){return Sh(),Cdn(l(t,18))},I(Go,"NetworkSimplexPlacer/lambda$9$Type",1442),D(1424,1,Uo,tie),h.rg=function(t){return l(Q(l(t,36),(ft(),Lu)),21).Hc((Ho(),vf))?FEt:null},h.Kf=function(t,n){bLn(l(t,36),n)};var FEt;I(Go,"SimpleNodePlacer",1424),D(185,1,{185:1},f6),h.Ib=function(){var t;return t="",this.c==(xd(),w3)?t+=Dx:this.c==T2&&(t+=Mx),this.o==(D1(),wv)?t+=whe:this.o==Y1?t+="UP":t+="BALANCED",t},I(Ib,"BKAlignedLayout",185),D(523,22,{3:1,34:1,22:1,523:1},$3e);var T2,w3,REt=Fr(Ib,"BKAlignedLayout/HDirection",523,Hr,Ypn,i1n),jEt;D(522,22,{3:1,34:1,22:1,522:1},z3e);var wv,Y1,$Et=Fr(Ib,"BKAlignedLayout/VDirection",522,Hr,Xpn,s1n),zEt;D(1699,1,{},Get),I(Ib,"BKAligner",1699),D(1702,1,{},rgt),I(Ib,"BKCompactor",1702),D(663,1,{663:1},hte),h.a=0,I(Ib,"BKCompactor/ClassEdge",663),D(467,1,{467:1},WQe),h.a=null,h.b=0,I(Ib,"BKCompactor/ClassNode",467),D(1427,1,Uo,Xet),h.rg=function(t){return l(Q(l(t,36),(ft(),Lu)),21).Hc((Ho(),vf))?qEt:null},h.Kf=function(t,n){GIn(this,l(t,36),n)},h.d=!1;var qEt;I(Ib,"BKNodePlacer",1427),D(1700,1,{},fte),h.d=0,I(Ib,"NeighborhoodInformation",1700),D(1701,1,ii,iXe),h.Ne=function(t,n){return ywn(this,l(t,42),l(n,42))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(Ib,"NeighborhoodInformation/NeighborComparator",1701),D(823,1,{}),I(Ib,"ThresholdStrategy",823),D(1825,823,{},YQe),h.wg=function(t,n,r){return this.a.o==(D1(),Y1)?gs:ia},h.xg=function(){},I(Ib,"ThresholdStrategy/NullThresholdStrategy",1825),D(587,1,{587:1},Qet),h.c=!1,h.d=!1,I(Ib,"ThresholdStrategy/Postprocessable",587),D(1826,823,{},XQe),h.wg=function(t,n,r){var a,o,f;return o=n==r,a=this.a.a[r.p]==n,o||a?(f=t,this.a.c==(xd(),w3)?(o&&(f=vle(this,n,!0)),!isNaN(f)&&!isFinite(f)&&a&&(f=vle(this,r,!1))):(o&&(f=vle(this,n,!0)),!isNaN(f)&&!isFinite(f)&&a&&(f=vle(this,r,!1))),f):t},h.xg=function(){for(var t,n,r,a,o;this.d.b!=0;)o=l(h2n(this.d),587),a=Lmt(this,o),a.a&&(t=a.a,r=Rt(this.a.f[this.a.g[o.b.p].p]),!(!r&&!Do(t)&&t.c.i.c==t.d.i.c)&&(n=N2t(this,o),n||Oln(this.e,o)));for(;this.e.a.c.length!=0;)N2t(this,l(P0t(this.e),587))},I(Ib,"ThresholdStrategy/SimpleThresholdStrategy",1826),D(645,1,{645:1,188:1,196:1},dte),h.dg=function(){return Vft(this)},h.qg=function(){return Vft(this)};var Mde;I(mfe,"EdgeRouterFactory",645),D(1485,1,Uo,nie),h.rg=function(t){return rSn(l(t,36))},h.Kf=function(t,n){ELn(l(t,36),n)};var HEt,VEt,UEt,GEt,KEt,zDe,WEt,YEt;I(mfe,"OrthogonalEdgeRouter",1485),D(1478,1,Uo,Yet),h.rg=function(t){return C8n(l(t,36))},h.Kf=function(t,n){GDn(this,l(t,36),n)};var XEt,QEt,JEt,ZEt,IB,eTt;I(mfe,"PolylineEdgeRouter",1478),D(1479,1,Ld,pte),h.Lb=function(t){return A7e(l(t,10))},h.Fb=function(t){return this===t},h.Mb=function(t){return A7e(l(t,10))},I(mfe,"PolylineEdgeRouter/1",1479),D(1872,1,ti,bte),h.Mb=function(t){return l(t,132).c==(J0(),qb)},I(i1,"HyperEdgeCycleDetector/lambda$0$Type",1872),D(1873,1,{},mte),h.Ze=function(t){return l(t,132).d},I(i1,"HyperEdgeCycleDetector/lambda$1$Type",1873),D(1874,1,ti,vte),h.Mb=function(t){return l(t,132).c==(J0(),qb)},I(i1,"HyperEdgeCycleDetector/lambda$2$Type",1874),D(1875,1,{},wte),h.Ze=function(t){return l(t,132).d},I(i1,"HyperEdgeCycleDetector/lambda$3$Type",1875),D(1876,1,{},yte),h.Ze=function(t){return l(t,132).d},I(i1,"HyperEdgeCycleDetector/lambda$4$Type",1876),D(1877,1,{},gte),h.Ze=function(t){return l(t,132).d},I(i1,"HyperEdgeCycleDetector/lambda$5$Type",1877),D(118,1,{34:1,118:1},xN),h.Fd=function(t){return Lun(this,l(t,118))},h.Fb=function(t){var n;return De(t,118)?(n=l(t,118),this.g==n.g):!1},h.Hb=function(){return this.g},h.Ib=function(){var t,n,r,a;for(t=new Th("{"),a=new G(this.n);a.a"+this.b+" ("+Whn(this.c)+")"},h.d=0,I(i1,"HyperEdgeSegmentDependency",132),D(528,22,{3:1,34:1,22:1,528:1},q3e);var qb,E4,tTt=Fr(i1,"HyperEdgeSegmentDependency/DependencyType",528,Hr,Qpn,a1n),nTt;D(1878,1,{},sXe),I(i1,"HyperEdgeSegmentSplitter",1878),D(1879,1,{},QJe),h.a=0,h.b=0,I(i1,"HyperEdgeSegmentSplitter/AreaRating",1879),D(339,1,{339:1},vae),h.a=0,h.b=0,h.c=0,I(i1,"HyperEdgeSegmentSplitter/FreeArea",339),D(1880,1,ii,a8),h.Ne=function(t,n){return Wfn(l(t,118),l(n,118))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(i1,"HyperEdgeSegmentSplitter/lambda$0$Type",1880),D(1881,1,fr,Cat),h.Cd=function(t){kmn(this.a,this.d,this.c,this.b,l(t,118))},h.b=0,I(i1,"HyperEdgeSegmentSplitter/lambda$1$Type",1881),D(1882,1,{},xte),h.Kb=function(t){return new bn(null,new kn(l(t,118).e,16))},I(i1,"HyperEdgeSegmentSplitter/lambda$2$Type",1882),D(1883,1,{},kte),h.Kb=function(t){return new bn(null,new kn(l(t,118).j,16))},I(i1,"HyperEdgeSegmentSplitter/lambda$3$Type",1883),D(1884,1,{},Ete),h.Ye=function(t){return ze(Ge(t))},I(i1,"HyperEdgeSegmentSplitter/lambda$4$Type",1884),D(664,1,{},Hae),h.a=0,h.b=0,h.c=0,I(i1,"OrthogonalRoutingGenerator",664),D(1703,1,{},Tte),h.Kb=function(t){return new bn(null,new kn(l(t,118).e,16))},I(i1,"OrthogonalRoutingGenerator/lambda$0$Type",1703),D(1704,1,{},Cte),h.Kb=function(t){return new bn(null,new kn(l(t,118).j,16))},I(i1,"OrthogonalRoutingGenerator/lambda$1$Type",1704),D(670,1,{}),I(vfe,"BaseRoutingDirectionStrategy",670),D(1870,670,{},eJe),h.yg=function(t,n,r){var a,o,f,g,w,E,C,L,B,z,V,J,te;if(!(t.r&&!t.q))for(L=n+t.o*r,C=new G(t.n);C.aDd&&(f=L,o=t,a=new lt(B,f),ui(g.a,a),Vw(this,g,o,a,!1),z=t.r,z&&(V=ze(Ge(ff(z.e,0))),a=new lt(V,f),ui(g.a,a),Vw(this,g,o,a,!1),f=n+z.o*r,o=z,a=new lt(V,f),ui(g.a,a),Vw(this,g,o,a,!1)),a=new lt(te,f),ui(g.a,a),Vw(this,g,o,a,!1)))},h.zg=function(t){return t.i.n.a+t.n.a+t.a.a},h.Ag=function(){return Ct(),Dr},h.Bg=function(){return Ct(),Qn},I(vfe,"NorthToSouthRoutingStrategy",1870),D(1871,670,{},tJe),h.yg=function(t,n,r){var a,o,f,g,w,E,C,L,B,z,V,J,te;if(!(t.r&&!t.q))for(L=n-t.o*r,C=new G(t.n);C.aDd&&(f=L,o=t,a=new lt(B,f),ui(g.a,a),Vw(this,g,o,a,!1),z=t.r,z&&(V=ze(Ge(ff(z.e,0))),a=new lt(V,f),ui(g.a,a),Vw(this,g,o,a,!1),f=n-z.o*r,o=z,a=new lt(V,f),ui(g.a,a),Vw(this,g,o,a,!1)),a=new lt(te,f),ui(g.a,a),Vw(this,g,o,a,!1)))},h.zg=function(t){return t.i.n.a+t.n.a+t.a.a},h.Ag=function(){return Ct(),Qn},h.Bg=function(){return Ct(),Dr},I(vfe,"SouthToNorthRoutingStrategy",1871),D(1869,670,{},nJe),h.yg=function(t,n,r){var a,o,f,g,w,E,C,L,B,z,V,J,te;if(!(t.r&&!t.q))for(L=n+t.o*r,C=new G(t.n);C.aDd&&(f=L,o=t,a=new lt(f,B),ui(g.a,a),Vw(this,g,o,a,!0),z=t.r,z&&(V=ze(Ge(ff(z.e,0))),a=new lt(f,V),ui(g.a,a),Vw(this,g,o,a,!0),f=n+z.o*r,o=z,a=new lt(f,V),ui(g.a,a),Vw(this,g,o,a,!0)),a=new lt(f,te),ui(g.a,a),Vw(this,g,o,a,!0)))},h.zg=function(t){return t.i.n.b+t.n.b+t.a.b},h.Ag=function(){return Ct(),ar},h.Bg=function(){return Ct(),er},I(vfe,"WestToEastRoutingStrategy",1869),D(828,1,{},Ske),h.Ib=function(){return Tb(this.a)},h.b=0,h.c=!1,h.d=!1,h.f=0,I(Zy,"NubSpline",828),D(418,1,{418:1},dbt,rot),I(Zy,"NubSpline/PolarCP",418),D(1480,1,Uo,Ydt),h.rg=function(t){return gxn(l(t,36))},h.Kf=function(t,n){hIn(this,l(t,36),n)};var rTt,iTt,sTt,aTt,oTt;I(Zy,"SplineEdgeRouter",1480),D(274,1,{274:1},WH),h.Ib=function(){return this.a+" ->("+this.c+") "+this.b},h.c=0,I(Zy,"SplineEdgeRouter/Dependency",274),D(465,22,{3:1,34:1,22:1,465:1},H3e);var Hb,K6,cTt=Fr(Zy,"SplineEdgeRouter/SideToProcess",465,Hr,r2n,o1n),uTt;D(1481,1,ti,Ste),h.Mb=function(t){return GA(),!l(t,131).o},I(Zy,"SplineEdgeRouter/lambda$0$Type",1481),D(1482,1,{},_te),h.Ze=function(t){return GA(),l(t,131).v+1},I(Zy,"SplineEdgeRouter/lambda$1$Type",1482),D(1483,1,fr,Jet),h.Cd=function(t){Ldn(this.a,this.b,l(t,42))},I(Zy,"SplineEdgeRouter/lambda$2$Type",1483),D(1484,1,fr,Zet),h.Cd=function(t){Mdn(this.a,this.b,l(t,42))},I(Zy,"SplineEdgeRouter/lambda$3$Type",1484),D(131,1,{34:1,131:1},_pt,Ike),h.Fd=function(t){return Iun(this,l(t,131))},h.b=0,h.e=!1,h.f=0,h.g=0,h.j=!1,h.k=!1,h.n=0,h.o=!1,h.p=!1,h.q=!1,h.s=0,h.u=0,h.v=0,h.F=0,I(Zy,"SplineSegment",131),D(468,1,{468:1},Ate),h.a=0,h.b=!1,h.c=!1,h.d=!1,h.e=!1,h.f=0,I(Zy,"SplineSegment/EdgeInformation",468),D(1198,1,{},CS),I(gp,LEe,1198),D(1199,1,ii,Lte),h.Ne=function(t,n){return Xkn(l(t,121),l(n,121))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(gp,E3t,1199),D(1197,1,{},dZe),I(gp,"MrTree",1197),D(405,22,{3:1,34:1,22:1,405:1,188:1,196:1},vq),h.dg=function(){return Wpt(this)},h.qg=function(){return Wpt(this)};var NW,lM,hM,fM,qDe=Fr(gp,"TreeLayoutPhases",405,Hr,smn,c1n),lTt;D(1112,205,tv,Hrt),h.rf=function(t,n){var r,a,o,f,g,w,E,C;for(Rt(Bt(at(t,(Hc(),dIe))))||KO((r=new Yv((aw(),new Jv(t))),r)),g=n.eh(xfe),g.Ug("build tGraph",1),w=(E=new nN,pc(E,t),rt(E,(Qi(),gM),t),C=new Pr,H_n(t,E,C),cAn(t,E,C),E),g.Vg(),g=n.eh(xfe),g.Ug("Split graph",1),f=Y_n(this.a,w),g.Vg(),o=new G(f);o.a"+Bm(this.c):"e_"+es(this)},I(vL,"TEdge",65),D(121,137,{3:1,121:1,96:1,137:1},nN),h.Ib=function(){var t,n,r,a,o;for(o=null,a=Rr(this.b,0);a.b!=a.d.c;)r=l(Br(a),40),o+=(r.c==null||r.c.length==0?"n_"+r.g:"n_"+r.c)+` +`;for(n=Rr(this.a,0);n.b!=n.d.c;)t=l(Br(n),65),o+=(t.b&&t.c?Bm(t.b)+"->"+Bm(t.c):"e_"+es(t))+` +`;return o};var _On=I(vL,"TGraph",121);D(643,508,{3:1,508:1,643:1,96:1,137:1}),I(vL,"TShape",643),D(40,643,{3:1,508:1,40:1,643:1,96:1,137:1},xce),h.Ib=function(){return Bm(this)};var PW=I(vL,"TNode",40);D(236,1,hg,Hg),h.Jc=function(t){to(this,t)},h.Kc=function(){var t;return t=Rr(this.a.d,0),new C5(t)},I(vL,"TNode/2",236),D(329,1,Oa,C5),h.Nb=function(t){Za(this,t)},h.Pb=function(){return l(Br(this.a),65).c},h.Ob=function(){return QI(this.a)},h.Qb=function(){Yoe(this.a)},I(vL,"TNode/2/1",329),D(1923,1,ts,Bte),h.Kf=function(t,n){zIn(this,l(t,121),n)},I(Su,"CompactionProcessor",1923),D(1924,1,ii,lXe),h.Ne=function(t,n){return A3n(this.a,l(t,40),l(n,40))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(Su,"CompactionProcessor/lambda$0$Type",1924),D(1925,1,ti,ttt),h.Mb=function(t){return Npn(this.b,this.a,l(t,42))},h.a=0,h.b=0,I(Su,"CompactionProcessor/lambda$1$Type",1925),D(1934,1,ii,o8),h.Ne=function(t,n){return Cgn(l(t,40),l(n,40))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(Su,"CompactionProcessor/lambda$10$Type",1934),D(1935,1,ii,Zj),h.Ne=function(t,n){return jhn(l(t,40),l(n,40))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(Su,"CompactionProcessor/lambda$11$Type",1935),D(1936,1,ii,Fte),h.Ne=function(t,n){return Sgn(l(t,40),l(n,40))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(Su,"CompactionProcessor/lambda$12$Type",1936),D(1926,1,ti,hXe),h.Mb=function(t){return khn(this.a,l(t,42))},h.a=0,I(Su,"CompactionProcessor/lambda$2$Type",1926),D(1927,1,ti,fXe),h.Mb=function(t){return Ehn(this.a,l(t,42))},h.a=0,I(Su,"CompactionProcessor/lambda$3$Type",1927),D(1928,1,ti,pI),h.Mb=function(t){return l(t,40).c.indexOf(DG)==-1},I(Su,"CompactionProcessor/lambda$4$Type",1928),D(1929,1,{},dXe),h.Kb=function(t){return Bbn(this.a,l(t,40))},h.a=0,I(Su,"CompactionProcessor/lambda$5$Type",1929),D(1930,1,{},gXe),h.Kb=function(t){return Vvn(this.a,l(t,40))},h.a=0,I(Su,"CompactionProcessor/lambda$6$Type",1930),D(1931,1,ii,pXe),h.Ne=function(t,n){return tvn(this.a,l(t,240),l(n,240))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(Su,"CompactionProcessor/lambda$7$Type",1931),D(1932,1,ii,bXe),h.Ne=function(t,n){return nvn(this.a,l(t,40),l(n,40))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(Su,"CompactionProcessor/lambda$8$Type",1932),D(1933,1,ii,Rte),h.Ne=function(t,n){return $hn(l(t,40),l(n,40))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(Su,"CompactionProcessor/lambda$9$Type",1933),D(1921,1,ts,jte),h.Kf=function(t,n){FSn(l(t,121),n)},I(Su,"DirectionProcessor",1921),D(1913,1,ts,qrt),h.Kf=function(t,n){aAn(this,l(t,121),n)},I(Su,"FanProcessor",1913),D(1937,1,ts,$te),h.Kf=function(t,n){CSn(l(t,121),n)},I(Su,"GraphBoundsProcessor",1937),D(1938,1,{},zte),h.Ye=function(t){return l(t,40).e.a},I(Su,"GraphBoundsProcessor/lambda$0$Type",1938),D(1939,1,{},qte),h.Ye=function(t){return l(t,40).e.b},I(Su,"GraphBoundsProcessor/lambda$1$Type",1939),D(1940,1,{},Hte),h.Ye=function(t){return sln(l(t,40))},I(Su,"GraphBoundsProcessor/lambda$2$Type",1940),D(1941,1,{},Vte),h.Ye=function(t){return iln(l(t,40))},I(Su,"GraphBoundsProcessor/lambda$3$Type",1941),D(262,22,{3:1,34:1,22:1,262:1,196:1},ow),h.dg=function(){switch(this.g){case 0:return new bJe;case 1:return new qrt;case 2:return new pJe;case 3:return new n$;case 4:return new Ute;case 8:return new e$;case 5:return new jte;case 6:return new i$;case 7:return new Bte;case 9:return new $te;case 10:return new Kte;default:throw ue(new Yn(Fhe+(this.f!=null?this.f:""+this.g)))}};var HDe,VDe,UDe,GDe,KDe,WDe,YDe,XDe,QDe,JDe,Dde,AOn=Fr(Su,Rhe,262,Hr,Bft,u1n),hTt;D(1920,1,ts,e$),h.Kf=function(t,n){RDn(l(t,121),n)},I(Su,"LevelCoordinatesProcessor",1920),D(1918,1,ts,Ute),h.Kf=function(t,n){sCn(this,l(t,121),n)},h.a=0,I(Su,"LevelHeightProcessor",1918),D(1919,1,hg,t$),h.Jc=function(t){to(this,t)},h.Kc=function(){return Cn(),Mk(),AT},I(Su,"LevelHeightProcessor/1",1919),D(1914,1,ts,pJe),h.Kf=function(t,n){wSn(this,l(t,121),n)},I(Su,"LevelProcessor",1914),D(1915,1,ti,Gte),h.Mb=function(t){return Rt(Bt(Q(l(t,40),(Qi(),Vb))))},I(Su,"LevelProcessor/lambda$0$Type",1915),D(1916,1,ts,n$),h.Kf=function(t,n){nkn(this,l(t,121),n)},h.a=0,I(Su,"NeighborsProcessor",1916),D(1917,1,hg,r$),h.Jc=function(t){to(this,t)},h.Kc=function(){return Cn(),Mk(),AT},I(Su,"NeighborsProcessor/1",1917),D(1922,1,ts,i$),h.Kf=function(t,n){sAn(this,l(t,121),n)},h.a=0,I(Su,"NodePositionProcessor",1922),D(1912,1,ts,bJe),h.Kf=function(t,n){$Ln(this,l(t,121),n)},I(Su,"RootProcessor",1912),D(1942,1,ts,Kte),h.Kf=function(t,n){B6n(l(t,121),n)},I(Su,"Untreeifyer",1942),D(392,22,{3:1,34:1,22:1,392:1},Ose);var OB,Ide,ZDe,eIe=Fr(UP,"EdgeRoutingMode",392,Hr,J2n,l1n),fTt,NB,QT,Ode,tIe,nIe,Nde,Pde,rIe,Bde,iIe,Fde,dM,Rde,BW,FW,k0,c1,JT,gM,pM,C2,sIe,dTt,jde,Vb,PB,BB;D(862,1,Pf,rie),h.hf=function(t){sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,fCe),""),pyt),"Turns on Tree compaction which decreases the size of the whole tree by placing nodes of multiple levels in one large level"),(Hn(),!1)),(g2(),ya)),Ns),un((r1(),Pn))))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,dCe),""),"Edge End Texture Length"),"Should be set to the length of the texture at the end of an edge. This value can be used to improve the Edge Routing."),7),fo),ta),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,gCe),""),"Tree Level"),"The index for the tree level the node is in"),pt(0)),Tc),ro),un(ha)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,pCe),""),pyt),"When set to a positive number this option will force the algorithm to place the node to the specified position within the trees layer if weighting is set to constraint"),pt(-1)),Tc),ro),un(ha)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,bCe),""),"Weighting of Nodes"),"Which weighting to use when computing a node order."),cIe),ps),yIe),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,mCe),""),"Edge Routing Mode"),"Chooses an Edge Routing algorithm."),aIe),ps),eIe),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,vCe),""),"Search Order"),"Which search order to use when computing a spanning tree."),oIe),ps),kIe),un(Pn)))),iwt((new v8,t))};var gTt,pTt,bTt,aIe,mTt,vTt,oIe,wTt,yTt,cIe;I(UP,"MrTreeMetaDataProvider",862),D(1006,1,Pf,v8),h.hf=function(t){iwt(t)};var xTt,uIe,lIe,y3,hIe,fIe,$de,kTt,ETt,TTt,CTt,STt,_Tt,ATt,dIe,gIe,pIe,LTt,W6,RW,bIe,MTt,mIe,zde,DTt,ITt,OTt,vIe,NTt,$d,wIe;I(UP,"MrTreeOptions",1006),D(1007,1,{},Wte),h.sf=function(){var t;return t=new Hrt,t},h.tf=function(t){},I(UP,"MrTreeOptions/MrtreeFactory",1007),D(353,22,{3:1,34:1,22:1,353:1},wq);var qde,jW,Hde,Vde,yIe=Fr(UP,"OrderWeighting",353,Hr,amn,h1n),PTt;D(433,22,{3:1,34:1,22:1,433:1},V3e);var xIe,Ude,kIe=Fr(UP,"TreeifyingOrder",433,Hr,t2n,f1n),BTt;D(1486,1,Uo,aie),h.rg=function(t){return l(t,121),FTt},h.Kf=function(t,n){b3n(this,l(t,121),n)};var FTt;I("org.eclipse.elk.alg.mrtree.p1treeify","DFSTreeifyer",1486),D(1487,1,Uo,dk),h.rg=function(t){return l(t,121),RTt},h.Kf=function(t,n){ESn(this,l(t,121),n)};var RTt;I(pT,"NodeOrderer",1487),D(1494,1,{},pwe),h.td=function(t){return Yit(t)},I(pT,"NodeOrderer/0methodref$lambda$6$Type",1494),D(1488,1,ti,ane),h.Mb=function(t){return ux(),Rt(Bt(Q(l(t,40),(Qi(),Vb))))},I(pT,"NodeOrderer/lambda$0$Type",1488),D(1489,1,ti,one),h.Mb=function(t){return ux(),l(Q(l(t,40),(Hc(),W6)),17).a<0},I(pT,"NodeOrderer/lambda$1$Type",1489),D(1490,1,ti,vXe),h.Mb=function(t){return Uwn(this.a,l(t,40))},I(pT,"NodeOrderer/lambda$2$Type",1490),D(1491,1,ti,mXe),h.Mb=function(t){return jbn(this.a,l(t,40))},I(pT,"NodeOrderer/lambda$3$Type",1491),D(1492,1,ii,cne),h.Ne=function(t,n){return gwn(l(t,40),l(n,40))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(pT,"NodeOrderer/lambda$4$Type",1492),D(1493,1,ti,une),h.Mb=function(t){return ux(),l(Q(l(t,40),(Qi(),Pde)),17).a!=0},I(pT,"NodeOrderer/lambda$5$Type",1493),D(1495,1,Uo,sie),h.rg=function(t){return l(t,121),jTt},h.Kf=function(t,n){I_n(this,l(t,121),n)},h.b=0;var jTt;I("org.eclipse.elk.alg.mrtree.p3place","NodePlacer",1495),D(1496,1,Uo,iie),h.rg=function(t){return l(t,121),$Tt},h.Kf=function(t,n){d_n(l(t,121),n)};var $Tt,LOn=I(vh,"EdgeRouter",1496);D(1498,1,ii,sne),h.Ne=function(t,n){return ru(l(t,17).a,l(n,17).a)},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(vh,"EdgeRouter/0methodref$compare$Type",1498),D(1503,1,{},Yte),h.Ye=function(t){return ze(Ge(t))},I(vh,"EdgeRouter/1methodref$doubleValue$Type",1503),D(1505,1,ii,a$),h.Ne=function(t,n){return Yi(ze(Ge(t)),ze(Ge(n)))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(vh,"EdgeRouter/2methodref$compare$Type",1505),D(1507,1,ii,Xte),h.Ne=function(t,n){return Yi(ze(Ge(t)),ze(Ge(n)))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(vh,"EdgeRouter/3methodref$compare$Type",1507),D(1509,1,{},s$),h.Ye=function(t){return ze(Ge(t))},I(vh,"EdgeRouter/4methodref$doubleValue$Type",1509),D(1511,1,ii,Qte),h.Ne=function(t,n){return Yi(ze(Ge(t)),ze(Ge(n)))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(vh,"EdgeRouter/5methodref$compare$Type",1511),D(1513,1,ii,bI),h.Ne=function(t,n){return Yi(ze(Ge(t)),ze(Ge(n)))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(vh,"EdgeRouter/6methodref$compare$Type",1513),D(1497,1,{},Jte),h.Kb=function(t){return tp(),l(Q(l(t,40),(Hc(),$d)),17)},I(vh,"EdgeRouter/lambda$0$Type",1497),D(1508,1,{},Zte),h.Kb=function(t){return Zhn(l(t,40))},I(vh,"EdgeRouter/lambda$11$Type",1508),D(1510,1,{},ntt),h.Kb=function(t){return _dn(this.b,this.a,l(t,40))},h.a=0,h.b=0,I(vh,"EdgeRouter/lambda$13$Type",1510),D(1512,1,{},rtt),h.Kb=function(t){return efn(this.b,this.a,l(t,40))},h.a=0,h.b=0,I(vh,"EdgeRouter/lambda$15$Type",1512),D(1514,1,ii,ene),h.Ne=function(t,n){return f6n(l(t,65),l(n,65))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(vh,"EdgeRouter/lambda$17$Type",1514),D(1515,1,ii,tne),h.Ne=function(t,n){return d6n(l(t,65),l(n,65))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(vh,"EdgeRouter/lambda$18$Type",1515),D(1516,1,ii,nne),h.Ne=function(t,n){return p6n(l(t,65),l(n,65))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(vh,"EdgeRouter/lambda$19$Type",1516),D(1499,1,ti,wXe),h.Mb=function(t){return b2n(this.a,l(t,40))},h.a=0,I(vh,"EdgeRouter/lambda$2$Type",1499),D(1517,1,ii,o$),h.Ne=function(t,n){return g6n(l(t,65),l(n,65))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(vh,"EdgeRouter/lambda$20$Type",1517),D(1500,1,ii,rne),h.Ne=function(t,n){return ddn(l(t,40),l(n,40))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(vh,"EdgeRouter/lambda$3$Type",1500),D(1501,1,ii,ine),h.Ne=function(t,n){return gdn(l(t,40),l(n,40))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(vh,"EdgeRouter/lambda$4$Type",1501),D(1502,1,{},lne),h.Kb=function(t){return tfn(l(t,40))},I(vh,"EdgeRouter/lambda$5$Type",1502),D(1504,1,{},itt),h.Kb=function(t){return Adn(this.b,this.a,l(t,40))},h.a=0,h.b=0,I(vh,"EdgeRouter/lambda$7$Type",1504),D(1506,1,{},stt),h.Kb=function(t){return nfn(this.b,this.a,l(t,40))},h.a=0,h.b=0,I(vh,"EdgeRouter/lambda$9$Type",1506),D(675,1,{675:1},Fdt),h.e=0,h.f=!1,h.g=!1,I(vh,"MultiLevelEdgeNodeNodeGap",675),D(1943,1,ii,hne),h.Ne=function(t,n){return S2n(l(t,240),l(n,240))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(vh,"MultiLevelEdgeNodeNodeGap/lambda$0$Type",1943),D(1944,1,ii,fne),h.Ne=function(t,n){return _2n(l(t,240),l(n,240))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(vh,"MultiLevelEdgeNodeNodeGap/lambda$1$Type",1944);var Y6;D(501,22,{3:1,34:1,22:1,501:1,188:1,196:1},U3e),h.dg=function(){return E1t(this)},h.qg=function(){return E1t(this)};var $W,X6,EIe=Fr(wCe,"RadialLayoutPhases",501,Hr,Wpn,d1n),zTt;D(1113,205,tv,fZe),h.rf=function(t,n){var r,a,o,f,g,w;if(r=cbt(this,t),n.Ug("Radial layout",r.c.length),Rt(Bt(at(t,(Sb(),NIe))))||KO((a=new Yv((aw(),new Jv(t))),a)),w=mxn(t),Hi(t,(H5(),Y6),w),!w)throw ue(new Yn("The given graph is not a tree!"));for(o=ze(Ge(at(t,HW))),o==0&&(o=qpt(t)),Hi(t,HW,o),g=new G(cbt(this,t));g.a=3)for(ot=l(Oe($e,0),27),St=l(Oe($e,1),27),f=0;f+2<$e.i;)if(Ze=ot,ot=St,St=l(Oe($e,f+2),27),Ze.f>=ot.f+St.f+L||St.f>=Ze.f+ot.f+L){cn=!0;break}else++f;else cn=!0;if(!cn){for(z=$e.i,w=new or($e);w.e!=w.i.gc();)g=l(gr(w),27),Hi(g,(pi(),XB),pt(z)),--z;Rmt(t,new L8),n.Vg();return}for(r=(qO(this.a),X0(this.a,(WV(),RB),l(at(t,uOe),188)),X0(this.a,VW,l(at(t,rOe),188)),X0(this.a,rge,l(at(t,aOe),188)),uye(this.a,(Bn=new Xs,fi(Bn,RB,(sU(),age)),fi(Bn,VW,sge),Rt(Bt(at(t,tOe)))&&fi(Bn,RB,ige),Bn)),bP(this.a,t)),C=1/r.c.length,J=new G(r);J.a0&&K0t((Xn(n-1,t.length),t.charCodeAt(n-1)),N3t);)--n;if(a>=n)throw ue(new Yn("The given string does not contain any numbers."));if(o=Gy((Ga(a,n,t.length),t.substr(a,n-a)),`,|;|\r| +`),o.length!=2)throw ue(new Yn("Exactly two numbers are expected, "+o.length+" were found."));try{this.a=jy($y(o[0])),this.b=jy($y(o[1]))}catch(f){throw f=bs(f),De(f,130)?(r=f,ue(new Yn(P3t+r))):ue(f)}},h.Ib=function(){return"("+this.a+","+this.b+")"},h.a=0,h.b=0;var Ea=I($P,"KVector",8);D(75,67,{3:1,4:1,20:1,31:1,56:1,16:1,67:1,15:1,75:1,423:1},bl,Gz,frt),h.Pc=function(){return Oyn(this)},h.cg=function(t){var n,r,a,o,f,g;a=Gy(t,`,|;|\\(|\\)|\\[|\\]|\\{|\\}| | | +`),Ch(this);try{for(r=0,f=0,o=0,g=0;r0&&(f%2==0?o=jy(a[r]):g=jy(a[r]),f>0&&f%2!=0&&ui(this,new lt(o,g)),++f),++r}catch(w){throw w=bs(w),De(w,130)?(n=w,ue(new Yn("The given string does not match the expected format for vectors."+n))):ue(w)}},h.Ib=function(){var t,n,r;for(t=new Th("("),n=Rr(this,0);n.b!=n.d.c;)r=l(Br(n),8),hi(t,r.a+","+r.b),n.b!=n.d.c&&(t.a+="; ");return(t.a+=")",t).a};var GOe=I($P,"KVectorChain",75);D(255,22,{3:1,34:1,22:1,255:1},__);var Sge,eY,tY,HB,VB,nY,KOe=Fr(nh,"Alignment",255,Hr,Mvn,F1n),xSt;D(991,1,Pf,fie),h.hf=function(t){xmt(t)};var WOe,_ge,kSt,YOe,XOe,ESt,QOe,TSt,CSt,JOe,ZOe,SSt;I(nh,"BoxLayouterOptions",991),D(992,1,{},ek),h.sf=function(){var t;return t=new jne,t},h.tf=function(t){},I(nh,"BoxLayouterOptions/BoxFactory",992),D(298,22,{3:1,34:1,22:1,298:1},A_);var EM,Age,TM,CM,SM,Lge,Mge=Fr(nh,"ContentAlignment",298,Hr,Dvn,R1n),_St;D(699,1,Pf,uz),h.hf=function(t){sn(t,new Xt(nn(tn(rn(Qt(en(Jt(Zt(new Ut,Byt),""),"Layout Algorithm"),"Select a specific layout algorithm."),(g2(),J6)),zt),un((r1(),Pn))))),sn(t,new Xt(nn(tn(rn(Qt(en(Jt(Zt(new Ut,Fyt),""),"Resolved Layout Algorithm"),"Meta data associated with the selected algorithm."),X1),IOn),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,qTe),""),"Alignment"),"Alignment of the selected node relative to other nodes; the exact meaning depends on the used algorithm."),eNe),ps),KOe),un(ha)))),sn(t,new Xt(nn(tn(rn(Qt(en(Jt(Zt(new Ut,Ox),""),"Aspect Ratio"),"The desired aspect ratio of the drawing, that is the quotient of width by height."),fo),ta),un(Pn)))),sn(t,new Xt(nn(tn(rn(Qt(en(Jt(Zt(new Ut,tSe),""),"Bend Points"),"A fixed list of bend points for the edge. This is used by the 'Fixed Layout' algorithm to specify a pre-defined routing for an edge. The vector chain must include the source point, any bend points, and the target point, so it must have at least two points."),X1),GOe),un(zd)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,SG),""),"Content Alignment"),"Specifies how the content of a node are aligned. Each node can individually control the alignment of its contents. I.e. if a node should be aligned top left in its parent node, the parent node should specify that option."),nNe),t9),Mge),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,VP),""),"Debug Mode"),"Whether additional debug information shall be generated."),(Hn(),!1)),ya),Ns),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,gfe),""),kEe),"Overall direction of edges: horizontal (right / left) or vertical (down / up)."),rNe),ps),LM),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,HP),""),"Edge Routing"),"What kind of edge routing style should be applied for the content of a parent node. Algorithms may also set this option to single edges in order to mark them as splines. The bend point list of edges with this option set to SPLINES must be interpreted as control points for a piecewise cubic spline."),aNe),ps),Vge),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,ZCe),""),"Expand Nodes"),"If active, nodes are expanded to fill the area of their parent."),!1),ya),Ns),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,CG),""),"Hierarchy Handling"),"Determines whether separate layout runs are triggered for different compound nodes in a hierarchical graph. Setting a node's hierarchy handling to `INCLUDE_CHILDREN` will lay out that node and all of its descendants in a single layout run, until a descendant is encountered which has its hierarchy handling set to `SEPARATE_CHILDREN`. In general, `SEPARATE_CHILDREN` will ensure that a new layout run is triggered for a node with that setting. Including multiple levels of hierarchy in a single layout run may allow cross-hierarchical edges to be laid out properly. If the root node is set to `INHERIT` (or not set at all), the default behavior is `SEPARATE_CHILDREN`."),uNe),ps),YNe),rs(Pn,he(le(xg,1),it,170,0,[ha]))))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,Xw),""),"Padding"),"The padding to be left to a parent element's border when placing child elements. This can also serve as an output option of a layout algorithm if node size calculation is setup appropriately."),vNe),X1),wAe),rs(Pn,he(le(xg,1),it,170,0,[ha]))))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,hL),""),"Interactive"),"Whether the algorithm should be run in interactive mode for the content of a parent node. What this means exactly depends on how the specific algorithm interprets this option. Usually in the interactive mode algorithms try to modify the current layout as little as possible."),!1),ya),Ns),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,AG),""),"interactive Layout"),"Whether the graph should be changeable interactively and by setting constraints"),!1),ya),Ns),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,fL),""),"Omit Node Micro Layout"),"Node micro layout comprises the computation of node dimensions (if requested), the placement of ports and their labels, and the placement of node labels. The functionality is implemented independent of any specific layout algorithm and shouldn't have any negative impact on the layout algorithm's performance itself. Yet, if any unforeseen behavior occurs, this option allows to deactivate the micro layout."),!1),ya),Ns),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,Nhe),""),"Port Constraints"),"Defines constraints of the position of the ports of a node."),ENe),ps),JNe),un(ha)))),sn(t,new Xt(nn(tn(rn(Qt(en(Jt(Zt(new Ut,_G),""),"Position"),"The position of a node, port, or label. This is used by the 'Fixed Layout' algorithm to specify a pre-defined position."),X1),Ea),rs(ha,he(le(xg,1),it,170,0,[yv,S2]))))),sn(t,new Xt(nn(tn(rn(Qt(en(Jt(Zt(new Ut,NP),""),"Priority"),"Defines the priority of an object; its meaning depends on the specific layout algorithm and the context where it is used."),Tc),ro),rs(ha,he(le(xg,1),it,170,0,[zd]))))),sn(t,new Xt(nn(tn(rn(Qt(en(Jt(Zt(new Ut,oG),""),"Randomization Seed"),"Seed used for pseudo-random number generators to control the layout algorithm. If the value is 0, the seed shall be determined pseudo-randomly (e.g. from the system time)."),Tc),ro),un(Pn)))),sn(t,new Xt(nn(tn(rn(Qt(en(Jt(Zt(new Ut,lL),""),"Separate Connected Components"),"Whether each connected component should be processed separately."),ya),Ns),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,ZTe),""),"Junction Points"),"This option is not used as option, but as output of the layout algorithms. It is attached to edges and determines the points where junction symbols should be drawn in order to represent hyperedges with orthogonal routing. Whether such points are computed depends on the chosen layout algorithm and edge routing style. The points are put into the vector chain with no specific order."),lNe),X1),GOe),un(zd)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,nCe),""),"Comment Box"),"Whether the node should be regarded as a comment box instead of a regular node. In that case its placement should be similar to how labels are handled. Any edges incident to a comment box specify to which graph elements the comment is related."),!1),ya),Ns),un(ha)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,rCe),""),"Hypernode"),"Whether the node should be handled as a hypernode."),!1),ya),Ns),un(ha)))),sn(t,new Xt(nn(tn(rn(Qt(en(Jt(Zt(new Ut,sOn),""),"Label Manager"),"Label managers can shorten labels upon a layout algorithm's request."),X1),FOn),rs(Pn,he(le(xg,1),it,170,0,[S2]))))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,sCe),""),"Margins"),"Margins define additional space around the actual bounds of a graph element. For instance, ports or labels being placed on the outside of a node's border might introduce such a margin. The margin is used to guarantee non-overlap of other graph elements with those ports or labels."),hNe),X1),vAe),un(ha)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,$Te),""),"No Layout"),"No layout is done for the associated element. This is used to mark parts of a diagram to avoid their inclusion in the layout graph, or to mark parts of the layout graph to prevent layout engines from processing them. If you wish to exclude the contents of a compound node from automatic layout, while the node itself is still considered on its own layer, use the 'Fixed Layout' algorithm for that node."),!1),ya),Ns),rs(ha,he(le(xg,1),it,170,0,[zd,yv,S2]))))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,Ryt),""),"Scale Factor"),"The scaling factor to be applied to the corresponding node in recursive layout. It causes the corresponding node's size to be adjusted, and its ports and labels to be sized and placed accordingly after the layout of that node has been determined (and before the node itself and its siblings are arranged). The scaling is not reverted afterwards, so the resulting layout graph contains the adjusted size and position data. This option is currently not supported if 'Layout Hierarchy' is set."),1),fo),ta),un(ha)))),sn(t,new Xt(nn(tn(rn(Qt(en(Jt(Zt(new Ut,jyt),""),"Child Area Width"),"The width of the area occupied by the laid out children of a node."),fo),ta),un(Pn)))),sn(t,new Xt(nn(tn(rn(Qt(en(Jt(Zt(new Ut,$yt),""),"Child Area Height"),"The height of the area occupied by the laid out children of a node."),fo),ta),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,PP),""),Dyt),"Turns topdown layout on and off. If this option is enabled, hierarchical layout will be computed first for the root node and then for its children recursively. Layouts are then scaled down to fit the area provided by their parents. Graphs must follow a certain structure for topdown layout to work properly. {@link TopdownNodeTypes.PARALLEL_NODE} nodes must have children of type {@link TopdownNodeTypes.HIERARCHICAL_NODE} and must define {@link topdown.hierarchicalNodeWidth} and {@link topdown.hierarchicalNodeAspectRatio} for their children. Furthermore they need to be laid out using an algorithm that is a {@link TopdownLayoutProvider}. Hierarchical nodes can also be parents of other hierarchical nodes and can optionally use a {@link TopdownSizeApproximator} to dynamically set sizes during topdown layout. In this case {@link topdown.hierarchicalNodeWidth} and {@link topdown.hierarchicalNodeAspectRatio} should be set on the node itself rather than the parent. The values are then used by the size approximator as base values. Hierarchical nodes require the layout option {@link nodeSize.fixedGraphSize} to be true to prevent the algorithm used there from resizing the hierarchical node. This option is not supported if 'Hierarchy Handling' is set to 'INCLUDE_CHILDREN'"),!1),ya),Ns),un(Pn)))),Qs(t,PP,Qw,null),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,zyt),""),"Animate"),"Whether the shift from the old layout to the new computed layout shall be animated."),!0),ya),Ns),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,qyt),""),"Animation Time Factor"),"Factor for computation of animation time. The higher the value, the longer the animation time. If the value is 0, the resulting time is always equal to the minimum defined by 'Minimal Animation Time'."),pt(100)),Tc),ro),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,Hyt),""),"Layout Ancestors"),"Whether the hierarchy levels on the path from the selected element to the root of the diagram shall be included in the layout process."),!1),ya),Ns),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,Vyt),""),"Maximal Animation Time"),"The maximal time for animations, in milliseconds."),pt(4e3)),Tc),ro),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,Uyt),""),"Minimal Animation Time"),"The minimal time for animations, in milliseconds."),pt(400)),Tc),ro),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,Gyt),""),"Progress Bar"),"Whether a progress bar shall be displayed during layout computations."),!1),ya),Ns),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,Kyt),""),"Validate Graph"),"Whether the graph shall be validated before any layout algorithm is applied. If this option is enabled and at least one error is found, the layout process is aborted and a message is shown to the user."),!1),ya),Ns),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,Wyt),""),"Validate Options"),"Whether layout options shall be validated before any layout algorithm is applied. If this option is enabled and at least one error is found, the layout process is aborted and a message is shown to the user."),!0),ya),Ns),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,Yyt),""),"Zoom to Fit"),"Whether the zoom level shall be set to view the whole diagram after layout."),!1),ya),Ns),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,eSe),"box"),"Box Layout Mode"),"Configures the packing mode used by the {@link BoxLayoutProvider}. If SIMPLE is not required (neither priorities are used nor the interactive mode), GROUP_DEC can improve the packing and decrease the area. GROUP_MIXED and GROUP_INC may, in very specific scenarios, work better."),tNe),ps),cPe),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,LTe),U1),"Comment Comment Spacing"),"Spacing to be preserved between a comment box and other comment boxes connected to the same node. The space left between comment boxes of different nodes is controlled by the node-node spacing."),10),fo),ta),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,MTe),U1),"Comment Node Spacing"),"Spacing to be preserved between a node and its connected comment boxes. The space left between a node and the comments of another node is controlled by the node-node spacing."),10),fo),ta),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,_he),U1),"Components Spacing"),"Spacing to be preserved between pairs of connected components. This option is only relevant if 'separateConnectedComponents' is activated."),20),fo),ta),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,DTe),U1),"Edge Spacing"),"Spacing to be preserved between any two edges. Note that while this can somewhat easily be satisfied for the segments of orthogonally drawn edges, it is harder for general polylines or splines."),10),fo),ta),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,Ohe),U1),"Edge Label Spacing"),"The minimal distance to be preserved between a label and the edge it is associated with. Note that the placement of a label is influenced by the 'edgelabels.placement' option."),2),fo),ta),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,dfe),U1),"Edge Node Spacing"),"Spacing to be preserved between nodes and edges."),10),fo),ta),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,ITe),U1),"Label Spacing"),"Determines the amount of space to be left between two labels of the same graph element."),0),fo),ta),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,PTe),U1),"Label Node Spacing"),"Spacing to be preserved between labels and the border of node they are associated with. Note that the placement of a label is influenced by the 'nodelabels.placement' option."),5),fo),ta),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,OTe),U1),"Horizontal spacing between Label and Port"),"Horizontal spacing to be preserved between labels and the ports they are associated with. Note that the placement of a label is influenced by the 'portlabels.placement' option."),1),fo),ta),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,NTe),U1),"Vertical spacing between Label and Port"),"Vertical spacing to be preserved between labels and the ports they are associated with. Note that the placement of a label is influenced by the 'portlabels.placement' option."),1),fo),ta),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,Jy),U1),"Node Spacing"),"The minimal distance to be preserved between each two nodes."),20),fo),ta),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,BTe),U1),"Node Self Loop Spacing"),"Spacing to be preserved between a node and its self loops."),10),fo),ta),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,FTe),U1),"Port Spacing"),"Spacing between pairs of ports of the same node."),10),fo),ta),rs(Pn,he(le(xg,1),it,170,0,[ha]))))),sn(t,new Xt(nn(tn(rn(Qt(en(Jt(Zt(new Ut,RTe),U1),"Individual Spacing"),"Allows to specify individual spacing values for graph elements that shall be different from the value specified for the element's parent."),X1),g_t),rs(ha,he(le(xg,1),it,170,0,[zd,yv,S2]))))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,aCe),U1),"Additional Port Space"),"Additional space around the sets of ports on each node side. For each side of a node, this option can reserve additional space before and after the ports on each side. For example, a top spacing of 20 makes sure that the first port on the western and eastern side is 20 units away from the northern border."),NNe),X1),vAe),un(Pn)))),sn(t,new Xt(nn(tn(rn(Qt(en(Jt(Zt(new Ut,bfe),Jyt),"Layout Partition"),"Partition to which the node belongs. This requires Layout Partitioning to be active. Nodes with lower partition IDs will appear to the left of nodes with higher partition IDs (assuming a left-to-right layout direction)."),Tc),ro),rs(Pn,he(le(xg,1),it,170,0,[ha]))))),Qs(t,bfe,pfe,BSt),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,pfe),Jyt),"Layout Partitioning"),"Whether to activate partitioned layout. This will allow to group nodes through the Layout Partition option. a pair of nodes with different partition indices is then placed such that the node with lower index is placed to the left of the other node (with left-to-right layout direction). Depending on the layout algorithm, this may only be guaranteed to work if all nodes have a layout partition configured, or at least if edges that cross partitions are not part of a partition-crossing cycle."),wNe),ya),Ns),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,UTe),Zyt),"Node Label Padding"),"Define padding for node labels that are placed inside of a node."),dNe),X1),wAe),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,fT),Zyt),"Node Label Placement"),"Hints for where node labels are to be placed; if empty, the node label's position is not modified."),gNe),t9),Ko),rs(ha,he(le(xg,1),it,170,0,[S2]))))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,WTe),RG),"Port Alignment"),"Defines the default port distribution for a node. May be overridden for each side individually."),xNe),ps),OM),un(ha)))),sn(t,new Xt(nn(tn(rn(Qt(en(Jt(Zt(new Ut,YTe),RG),"Port Alignment (North)"),"Defines how ports on the northern side are placed, overriding the node's general port alignment."),ps),OM),un(ha)))),sn(t,new Xt(nn(tn(rn(Qt(en(Jt(Zt(new Ut,XTe),RG),"Port Alignment (South)"),"Defines how ports on the southern side are placed, overriding the node's general port alignment."),ps),OM),un(ha)))),sn(t,new Xt(nn(tn(rn(Qt(en(Jt(Zt(new Ut,QTe),RG),"Port Alignment (West)"),"Defines how ports on the western side are placed, overriding the node's general port alignment."),ps),OM),un(ha)))),sn(t,new Xt(nn(tn(rn(Qt(en(Jt(Zt(new Ut,JTe),RG),"Port Alignment (East)"),"Defines how ports on the eastern side are placed, overriding the node's general port alignment."),ps),OM),un(ha)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,x6),Rfe),"Node Size Constraints"),"What should be taken into account when calculating a node's size. Empty size constraints specify that a node's size is already fixed and should not be changed."),pNe),t9),BM),un(ha)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,Nx),Rfe),"Node Size Options"),"Options modifying the behavior of the size constraints set on a node. Each member of the set specifies something that should be taken into account when calculating node sizes. The empty set corresponds to no further modifications."),mNe),t9),ePe),un(ha)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,Px),Rfe),"Node Size Minimum"),"The minimal size to which a node can be reduced."),bNe),X1),Ea),un(ha)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,hT),Rfe),"Fixed Graph Size"),"By default, the fixed layout provider will enlarge a graph until it is large enough to contain its children. If this option is set, it won't do so."),!1),ya),Ns),un(Pn)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,eCe),ffe),"Edge Label Placement"),"Gives a hint on where to put edge labels."),iNe),ps),FNe),un(S2)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,cG),ffe),"Inline Edge Labels"),"If true, an edge label is placed directly on its edge. May only apply to center edge labels. This kind of label placement is only advisable if the label's rendering is such that it is not crossed by its edge and thus stays legible."),!1),ya),Ns),un(S2)))),sn(t,new Xt(nn(tn(rn(Qt(en(Jt(Zt(new Ut,aOn),"font"),"Font Name"),"Font name used for a label."),J6),zt),un(S2)))),sn(t,new Xt(nn(tn(rn(Qt(en(Jt(Zt(new Ut,Xyt),"font"),"Font Size"),"Font size used for a label."),Tc),ro),un(S2)))),sn(t,new Xt(nn(tn(rn(Qt(en(Jt(Zt(new Ut,iCe),jfe),"Port Anchor Offset"),"The offset to the port position where connections shall be attached."),X1),Ea),un(yv)))),sn(t,new Xt(nn(tn(rn(Qt(en(Jt(Zt(new Ut,tCe),jfe),"Port Index"),"The index of a port in the fixed order around a node. The order is assumed as clockwise, starting with the leftmost port on the top side. This option must be set if 'Port Constraints' is set to FIXED_ORDER and no specific positions are given for the ports. Additionally, the option 'Port Side' must be defined in this case."),Tc),ro),un(yv)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,zTe),jfe),"Port Side"),"The side of a node on which a port is situated. This option must be set if 'Port Constraints' is set to FIXED_SIDE or FIXED_ORDER and no specific positions are given for the ports."),SNe),ps),Oo),un(yv)))),sn(t,new Xt(nn(tn(rn(Qt(en(Jt(Zt(new Ut,jTe),jfe),"Port Border Offset"),"The offset of ports on the node border. With a positive offset the port is moved outside of the node, while with a negative offset the port is moved towards the inside. An offset of 0 means that the port is placed directly on the node border, i.e. if the port side is north, the port's south border touches the nodes's north border; if the port side is east, the port's west border touches the nodes's east border; if the port side is south, the port's north border touches the node's south border; if the port side is west, the port's east border touches the node's west border."),fo),ta),un(yv)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,dT),iSe),"Port Label Placement"),"Decides on a placement method for port labels; if empty, the node label's position is not modified."),TNe),t9),cY),un(ha)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,GTe),iSe),"Port Labels Next to Port"),"Use 'portLabels.placement': NEXT_TO_PORT_OF_POSSIBLE."),!1),ya),Ns),un(ha)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,KTe),iSe),"Treat Port Labels as Group"),"If this option is true (default), the labels of a port will be treated as a group when it comes to centering them next to their port. If this option is false, only the first label will be centered next to the port, with the others being placed below. This only applies to labels of eastern and western ports and will have no effect if labels are not placed next to their port."),!0),ya),Ns),un(ha)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,BP),KP),"Topdown Scale Factor"),"The scaling factor to be applied to the nodes laid out within the node in recursive topdown layout. The difference to 'Scale Factor' is that the node itself is not scaled. This value has to be set on hierarchical nodes."),1),fo),ta),un(Pn)))),Qs(t,BP,Qw,VSt),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,nSe),KP),"Topdown Size Approximator"),"The size approximator to be used to set sizes of hierarchical nodes during topdown layout. The default value is null, which results in nodes keeping whatever size is defined for them e.g. through parent parallel node or by manually setting the size."),null),ps),gY),un(ha)))),Qs(t,nSe,Qw,USt),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,FP),KP),"Topdown Hierarchical Node Width"),"The fixed size of a hierarchical node when using topdown layout. If this value is set on a parallel node it applies to its children, when set on a hierarchical node it applies to the node itself."),150),fo),ta),rs(Pn,he(le(xg,1),it,170,0,[ha]))))),Qs(t,FP,Qw,null),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,RP),KP),"Topdown Hierarchical Node Aspect Ratio"),"The fixed aspect ratio of a hierarchical node when using topdown layout. Default is 1/sqrt(2). If this value is set on a parallel node it applies to its children, when set on a hierarchical node it applies to the node itself."),1.414),fo),ta),rs(Pn,he(le(xg,1),it,170,0,[ha]))))),Qs(t,RP,Qw,null),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,Qw),KP),"Topdown Node Type"),"The different node types used for topdown layout. If the node type is set to {@link TopdownNodeTypes.PARALLEL_NODE} the algorithm must be set to a {@link TopdownLayoutProvider} such as {@link TopdownPacking}. The {@link nodeSize.fixedGraphSize} option is technically only required for hierarchical nodes."),null),ps),nPe),un(ha)))),Qs(t,Qw,hT,null),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,rSe),KP),"Topdown Scale Cap"),"Determines the upper limit for the topdown scale factor. The default value is 1.0 which ensures that nested children never end up appearing larger than their parents in terms of unit sizes such as the font size. If the limit is larger, nodes will fully utilize the available space, but it is counteriniuitive for inner nodes to have a larger scale than outer nodes."),1),fo),ta),un(Pn)))),Qs(t,rSe,Qw,HSt),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,HTe),e4t),"Activate Inside Self Loops"),"Whether this node allows to route self loops inside of it instead of around it. If set to true, this will make the node a compound node if it isn't already, and will require the layout algorithm to support compound nodes with hierarchical ports."),!1),ya),Ns),un(ha)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,VTe),e4t),"Inside Self Loop"),"Whether a self loop should be routed inside a node instead of around that node."),!1),ya),Ns),un(zd)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,Ahe),"edge"),"Edge Thickness"),"The thickness of an edge. This is a hint on the line width used to draw an edge, possibly requiring more space to be reserved for it."),1),fo),ta),un(zd)))),sn(t,new Xt(nn(tn(rn(yn(Qt(en(Jt(Zt(new Ut,Qyt),"edge"),"Edge Type"),"The type of an edge. This is usually used for UML class diagrams, where associations must be handled differently from generalizations."),cNe),ps),HNe),un(zd)))),m_(t,new nx(f_(Ck(Tk(new ny,sr),"Layered"),'The layer-based method was introduced by Sugiyama, Tagawa and Toda in 1981. It emphasizes the direction of edges by pointing as many edges as possible into the same direction. The nodes are arranged in layers, which are sometimes called "hierarchies", and then reordered such that the number of edge crossings is minimized. Afterwards, concrete coordinates are computed for the nodes and edge bend points.'))),m_(t,new nx(f_(Ck(Tk(new ny,"org.eclipse.elk.orthogonal"),"Orthogonal"),`Orthogonal methods that follow the "topology-shape-metrics" approach by Batini, Nardelli and Tamassia '86. The first phase determines the topology of the drawing by applying a planarization technique, which results in a planar representation of the graph. The orthogonal shape is computed in the second phase, which aims at minimizing the number of edge bends, and is called orthogonalization. The third phase leads to concrete coordinates for nodes and edge bend points by applying a compaction method, thus defining the metrics.`))),m_(t,new nx(f_(Ck(Tk(new ny,Yu),"Force"),"Layout algorithms that follow physical analogies by simulating a system of attractive and repulsive forces. The first successful method of this kind was proposed by Eades in 1984."))),m_(t,new nx(f_(Ck(Tk(new ny,"org.eclipse.elk.circle"),"Circle"),"Circular layout algorithms emphasize cycles or biconnected components of a graph by arranging them in circles. This is useful if a drawing is desired where such components are clearly grouped, or where cycles are shown as prominent OPTIONS of the graph."))),m_(t,new nx(f_(Ck(Tk(new ny,byt),"Tree"),"Specialized layout methods for trees, i.e. acyclic graphs. The regular structure of graphs that have no undirected cycles can be emphasized using an algorithm of this type."))),m_(t,new nx(f_(Ck(Tk(new ny,"org.eclipse.elk.planar"),"Planar"),"Algorithms that require a planar or upward planar graph. Most of these algorithms are theoretically interesting, but not practically usable."))),m_(t,new nx(f_(Ck(Tk(new ny,gf),"Radial"),"Radial layout algorithms usually position the nodes of the graph on concentric circles."))),amt((new die,t)),xmt((new fie,t)),Nbt((new lz,t))};var eC,ASt,eNe,Z6,LSt,MSt,tNe,e7,t7,DSt,UB,nNe,GB,xv,rNe,Dge,Ige,iNe,sNe,aNe,oNe,cNe,ISt,n7,uNe,OSt,KB,Oge,WB,Nge,x3,lNe,tC,hNe,fNe,dNe,r7,gNe,kv,pNe,C4,i7,bNe,Ub,mNe,rY,YB,_2,vNe,NSt,wNe,PSt,BSt,yNe,xNe,Pge,Bge,Fge,Rge,kNe,rh,_M,ENe,jge,$ge,S4,TNe,CNe,s7,SNe,n9,XB,zge,a7,FSt,qge,RSt,jSt,_Ne,$St,ANe,LNe,r9,MNe,iY,DNe,INe,Ev,zSt,ONe,NNe,PNe,sY,QB,AM,i9,qSt,HSt,aY,VSt,BNe,USt;I(nh,"CoreOptions",699),D(88,22,{3:1,34:1,22:1,88:1},mO);var Q1,uc,vc,J1,wf,LM=Fr(nh,kEe,88,Hr,Pmn,j1n),GSt;D(278,22,{3:1,34:1,22:1,278:1},zse);var nC,_4,rC,FNe=Fr(nh,"EdgeLabelPlacement",278,Hr,lbn,$1n),KSt;D(223,22,{3:1,34:1,22:1,223:1},xq);var iC,JB,s9,Hge,Vge=Fr(nh,"EdgeRouting",223,Hr,lmn,z1n),WSt;D(321,22,{3:1,34:1,22:1,321:1},L_);var RNe,jNe,$Ne,zNe,Uge,qNe,HNe=Fr(nh,"EdgeType",321,Hr,Lvn,q1n),YSt;D(989,1,Pf,die),h.hf=function(t){amt(t)};var VNe,UNe,GNe,KNe,XSt,WNe,MM;I(nh,"FixedLayouterOptions",989),D(990,1,{},v$),h.sf=function(){var t;return t=new Une,t},h.tf=function(t){},I(nh,"FixedLayouterOptions/FixedFactory",990),D(346,22,{3:1,34:1,22:1,346:1},qse);var A2,oY,DM,YNe=Fr(nh,"HierarchyHandling",346,Hr,cbn,H1n),QSt;D(291,22,{3:1,34:1,22:1,291:1},kq);var kg,Gb,ZB,eF,JSt=Fr(nh,"LabelSide",291,Hr,umn,V1n),ZSt;D(95,22,{3:1,34:1,22:1,95:1},D5);var mp,E0,zf,T0,jh,C0,qf,Eg,S0,Ko=Fr(nh,"NodeLabelPlacement",95,Hr,Mwn,U1n),e_t;D(256,22,{3:1,34:1,22:1,256:1},vO);var XNe,IM,Kb,QNe,tF,OM=Fr(nh,"PortAlignment",256,Hr,Xmn,G1n),t_t;D(101,22,{3:1,34:1,22:1,101:1},M_);var Tv,Mu,Tg,sC,Z1,Wb,JNe=Fr(nh,"PortConstraints",101,Hr,Avn,K1n),n_t;D(279,22,{3:1,34:1,22:1,279:1},D_);var NM,PM,vp,nF,Yb,a9,cY=Fr(nh,"PortLabelPlacement",279,Hr,_vn,W1n),r_t;D(64,22,{3:1,34:1,22:1,64:1},wO);var ar,Qn,yf,xf,ll,Ju,ed,_0,zl,_l,Du,ql,hl,fl,A0,$h,zh,Hf,Dr,Pc,er,Oo=Fr(nh,"PortSide",64,Hr,Bmn,Y1n),i_t;D(993,1,Pf,lz),h.hf=function(t){Nbt(t)};var s_t,a_t,ZNe,o_t,c_t;I(nh,"RandomLayouterOptions",993),D(994,1,{},w$),h.sf=function(){var t;return t=new qne,t},h.tf=function(t){},I(nh,"RandomLayouterOptions/RandomFactory",994),D(386,22,{3:1,34:1,22:1,386:1},Eq);var A4,rF,iF,Cv,BM=Fr(nh,"SizeConstraint",386,Hr,cmn,X1n),u_t;D(264,22,{3:1,34:1,22:1,264:1},I5);var sF,uY,aC,Gge,aF,FM,lY,hY,fY,ePe=Fr(nh,"SizeOptions",264,Hr,qwn,Q1n),l_t;D(280,22,{3:1,34:1,22:1,280:1},Hse);var L4,tPe,dY,nPe=Fr(nh,"TopdownNodeTypes",280,Hr,hbn,J1n),h_t;D(347,22,sSe);var rPe,iPe,gY=Fr(nh,"TopdownSizeApproximator",347,Hr,a2n,edn);D(987,347,sSe,Wit),h.Tg=function(t){return Tdt(t)},Fr(nh,"TopdownSizeApproximator/1",987,gY,null,null),D(988,347,sSe,Ost),h.Tg=function(t){var n,r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e,Ze,ot,St,cn,an,Bn;for(n=l(at(t,(pi(),a7)),143),St=(rb(),V=new a_,V),aP(St,t),cn=new Pr,f=new or((!t.a&&(t.a=new nt(Ai,t,10,11)),t.a));f.e!=f.i.gc();)a=l(gr(f),27),Me=(z=new a_,z),LU(Me,St),aP(Me,a),Bn=Tdt(a),F5(Me,b.Math.max(a.g,Bn.a),b.Math.max(a.f,Bn.b)),ju(cn.f,a,Me);for(o=new or((!t.a&&(t.a=new nt(Ai,t,10,11)),t.a));o.e!=o.i.gc();)for(a=l(gr(o),27),L=new or((!a.e&&(a.e=new Ln(js,a,7,4)),a.e));L.e!=L.i.gc();)C=l(gr(L),74),Ze=l(hc(zo(cn.f,a)),27),ot=l(cr(cn,Oe((!C.c&&(C.c=new Ln(_r,C,5,8)),C.c),0)),27),$e=(B=new TI,B),qr((!$e.b&&($e.b=new Ln(_r,$e,4,7)),$e.b),Ze),qr((!$e.c&&($e.c=new Ln(_r,$e,5,8)),$e.c),ot),AU($e,ds(Ze)),aP($e,C);te=l(GO(n.f),205);try{te.rf(St,new x$),lat(n.f,te)}catch(jn){throw jn=bs(jn),De(jn,103)?(J=jn,ue(J)):ue(jn)}return P1(St,t7)||P1(St,e7)||Uke(St),E=ze(Ge(at(St,t7))),w=ze(Ge(at(St,e7))),g=E/w,r=ze(Ge(at(St,QB)))*b.Math.sqrt((!St.a&&(St.a=new nt(Ai,St,10,11)),St.a).i),an=l(at(St,_2),107),Te=an.b+an.c+1,fe=an.d+an.a+1,new lt(b.Math.max(Te,r),b.Math.max(fe,r/g))},Fr(nh,"TopdownSizeApproximator/2",988,gY,null,null);var f_t;D(344,1,{871:1},L8),h.Ug=function(t,n){return Fgt(this,t,n)},h.Vg=function(){apt(this)},h.Wg=function(){return this.q},h.Xg=function(){return this.f?ioe(this.f):null},h.Yg=function(){return ioe(this.a)},h.Zg=function(){return this.p},h.$g=function(){return!1},h._g=function(){return this.n},h.ah=function(){return this.p!=null&&!this.b},h.bh=function(t){var n;this.n&&(n=t,vt(this.f,n))},h.dh=function(t,n){var r,a;this.n&&t&&Sbn(this,(r=new Ust,a=cle(r,t),oDn(r),a),(NV(),Wge))},h.eh=function(t){var n;return this.b?null:(n=hwn(this,this.g),ui(this.a,n),n.i=this,this.d=t,n)},h.fh=function(t){t>0&&!this.b&&c7e(this,t)},h.b=!1,h.c=0,h.d=-1,h.e=null,h.f=null,h.g=-1,h.j=!1,h.k=!1,h.n=!1,h.o=0,h.q=0,h.r=0,I(Uc,"BasicProgressMonitor",344),D(717,205,tv,jne),h.rf=function(t,n){Rmt(t,n)},I(Uc,"BoxLayoutProvider",717),D(983,1,ii,DXe),h.Ne=function(t,n){return oCn(this,l(t,27),l(n,27))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},h.a=!1,I(Uc,"BoxLayoutProvider/1",983),D(163,1,{163:1},hV,vrt),h.Ib=function(){return this.c?oke(this.c):Tb(this.b)},I(Uc,"BoxLayoutProvider/Group",163),D(320,22,{3:1,34:1,22:1,320:1},Tq);var sPe,aPe,oPe,Kge,cPe=Fr(Uc,"BoxLayoutProvider/PackingMode",320,Hr,hmn,tdn),d_t;D(984,1,ii,tk),h.Ne=function(t,n){return Spn(l(t,163),l(n,163))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(Uc,"BoxLayoutProvider/lambda$0$Type",984),D(985,1,ii,nk),h.Ne=function(t,n){return vpn(l(t,163),l(n,163))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(Uc,"BoxLayoutProvider/lambda$1$Type",985),D(986,1,ii,y$),h.Ne=function(t,n){return wpn(l(t,163),l(n,163))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(Uc,"BoxLayoutProvider/lambda$2$Type",986),D(1384,1,{845:1},$ne),h.Mg=function(t,n){return tq(),!De(n,167)||mZe((hx(),l(t,167)),n)},I(Uc,"ElkSpacings/AbstractSpacingsBuilder/lambda$0$Type",1384),D(1385,1,fr,IXe),h.Cd=function(t){Byn(this.a,l(t,149))},I(Uc,"ElkSpacings/AbstractSpacingsBuilder/lambda$1$Type",1385),D(1386,1,fr,Hne),h.Cd=function(t){l(t,96),tq()},I(Uc,"ElkSpacings/AbstractSpacingsBuilder/lambda$2$Type",1386),D(1390,1,fr,OXe),h.Cd=function(t){i3n(this.a,l(t,96))},I(Uc,"ElkSpacings/AbstractSpacingsBuilder/lambda$3$Type",1390),D(1388,1,ti,utt),h.Mb=function(t){return myn(this.a,this.b,l(t,149))},I(Uc,"ElkSpacings/AbstractSpacingsBuilder/lambda$4$Type",1388),D(1387,1,ti,ltt),h.Mb=function(t){return Jhn(this.a,this.b,l(t,845))},I(Uc,"ElkSpacings/AbstractSpacingsBuilder/lambda$5$Type",1387),D(1389,1,fr,htt),h.Cd=function(t){hgn(this.a,this.b,l(t,149))},I(Uc,"ElkSpacings/AbstractSpacingsBuilder/lambda$6$Type",1389),D(947,1,{},Vne),h.Kb=function(t){return ant(t)},h.Fb=function(t){return this===t},I(Uc,"ElkUtil/lambda$0$Type",947),D(948,1,fr,ftt),h.Cd=function(t){lEn(this.a,this.b,l(t,74))},h.a=0,h.b=0,I(Uc,"ElkUtil/lambda$1$Type",948),D(949,1,fr,dtt),h.Cd=function(t){tun(this.a,this.b,l(t,166))},h.a=0,h.b=0,I(Uc,"ElkUtil/lambda$2$Type",949),D(950,1,fr,gtt),h.Cd=function(t){Xln(this.a,this.b,l(t,135))},h.a=0,h.b=0,I(Uc,"ElkUtil/lambda$3$Type",950),D(951,1,fr,NXe),h.Cd=function(t){Idn(this.a,l(t,377))},I(Uc,"ElkUtil/lambda$4$Type",951),D(325,1,{34:1,325:1},Dcn),h.Fd=function(t){return Chn(this,l(t,242))},h.Fb=function(t){var n;return De(t,325)?(n=l(t,325),this.a==n.a):!1},h.Hb=function(){return ua(this.a)},h.Ib=function(){return this.a+" (exclusive)"},h.a=0,I(Uc,"ExclusiveBounds/ExclusiveLowerBound",325),D(1119,205,tv,Une),h.rf=function(t,n){var r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te,Me,$e,Ze,ot,St,cn,an;for(n.Ug("Fixed Layout",1),f=l(at(t,(pi(),sNe)),223),B=0,z=0,Me=new or((!t.a&&(t.a=new nt(Ai,t,10,11)),t.a));Me.e!=Me.i.gc();){for(fe=l(gr(Me),27),an=l(at(fe,(PV(),MM)),8),an&&(Qh(fe,an.a,an.b),l(at(fe,UNe),181).Hc((mh(),A4))&&(V=l(at(fe,KNe),8),V.a>0&&V.b>0&&Gw(fe,V.a,V.b,!0,!0))),B=b.Math.max(B,fe.i+fe.g),z=b.Math.max(z,fe.j+fe.f),C=new or((!fe.n&&(fe.n=new nt(ec,fe,1,7)),fe.n));C.e!=C.i.gc();)w=l(gr(C),135),an=l(at(w,MM),8),an&&Qh(w,an.a,an.b),B=b.Math.max(B,fe.i+w.i+w.g),z=b.Math.max(z,fe.j+w.j+w.f);for(ot=new or((!fe.c&&(fe.c=new nt(Hl,fe,9,9)),fe.c));ot.e!=ot.i.gc();)for(Ze=l(gr(ot),123),an=l(at(Ze,MM),8),an&&Qh(Ze,an.a,an.b),St=fe.i+Ze.i,cn=fe.j+Ze.j,B=b.Math.max(B,St+Ze.g),z=b.Math.max(z,cn+Ze.f),E=new or((!Ze.n&&(Ze.n=new nt(ec,Ze,1,7)),Ze.n));E.e!=E.i.gc();)w=l(gr(E),135),an=l(at(w,MM),8),an&&Qh(w,an.a,an.b),B=b.Math.max(B,St+w.i+w.g),z=b.Math.max(z,cn+w.j+w.f);for(o=new hr(dr(cp(fe).a.Kc(),new j));jr(o);)r=l(xr(o),74),L=Jvt(r),B=b.Math.max(B,L.a),z=b.Math.max(z,L.b);for(a=new hr(dr(sP(fe).a.Kc(),new j));jr(a);)r=l(xr(a),74),ds(cg(r))!=t&&(L=Jvt(r),B=b.Math.max(B,L.a),z=b.Math.max(z,L.b))}if(f==(ip(),iC))for(Te=new or((!t.a&&(t.a=new nt(Ai,t,10,11)),t.a));Te.e!=Te.i.gc();)for(fe=l(gr(Te),27),a=new hr(dr(cp(fe).a.Kc(),new j));jr(a);)r=l(xr(a),74),g=fAn(r),g.b==0?Hi(r,x3,null):Hi(r,x3,g);Rt(Bt(at(t,(PV(),GNe))))||($e=l(at(t,XSt),107),te=B+$e.b+$e.c,J=z+$e.d+$e.a,Gw(t,te,J,!0,!0)),n.Vg()},I(Uc,"FixedLayoutProvider",1119),D(385,137,{3:1,423:1,385:1,96:1,137:1},EI,Xlt),h.cg=function(t){var n,r,a,o,f,g,w,E,C;if(t)try{for(E=Gy(t,";,;"),f=E,g=0,w=f.length;g>16&Zs|n^a<<16},h.Kc=function(){return new PXe(this)},h.Ib=function(){return this.a==null&&this.b==null?"pair(null,null)":this.a==null?"pair(null,"+xc(this.b)+")":this.b==null?"pair("+xc(this.a)+",null)":"pair("+xc(this.a)+","+xc(this.b)+")"},I(Uc,"Pair",42),D(995,1,Oa,PXe),h.Nb=function(t){Za(this,t)},h.Ob=function(){return!this.c&&(!this.b&&this.a.a!=null||this.a.b!=null)},h.Pb=function(){if(!this.c&&!this.b&&this.a.a!=null)return this.b=!0,this.a.a;if(!this.c&&this.a.b!=null)return this.c=!0,this.a.b;throw ue(new _c)},h.Qb=function(){throw this.c&&this.a.b!=null?this.a.b=null:this.b&&this.a.a!=null&&(this.a.a=null),ue(new pl)},h.b=!1,h.c=!1,I(Uc,"Pair/1",995),D(455,1,{455:1},Sat),h.Fb=function(t){return Jc(this.a,l(t,455).a)&&Jc(this.c,l(t,455).c)&&Jc(this.d,l(t,455).d)&&Jc(this.b,l(t,455).b)},h.Hb=function(){return MN(he(le(wa,1),Rn,1,5,[this.a,this.c,this.d,this.b]))},h.Ib=function(){return"("+this.a+Co+this.c+Co+this.d+Co+this.b+")"},I(Uc,"Quadruple",455),D(1108,205,tv,qne),h.rf=function(t,n){var r,a,o,f,g;if(n.Ug("Random Layout",1),(!t.a&&(t.a=new nt(Ai,t,10,11)),t.a).i==0){n.Vg();return}f=l(at(t,(B8e(),o_t)),17),f&&f.a!=0?o=new VH(f.a):o=new Uce,r=XI(Ge(at(t,s_t))),g=XI(Ge(at(t,c_t))),a=l(at(t,a_t),107),MDn(t,o,r,g,a),n.Vg()},I(Uc,"RandomLayoutProvider",1108),D(240,1,{240:1},wae),h.Fb=function(t){return Jc(this.a,l(t,240).a)&&Jc(this.b,l(t,240).b)&&Jc(this.c,l(t,240).c)},h.Hb=function(){return MN(he(le(wa,1),Rn,1,5,[this.a,this.b,this.c]))},h.Ib=function(){return"("+this.a+Co+this.b+Co+this.c+")"},I(Uc,"Triple",240);var m_t;D(562,1,{}),h.Lf=function(){return new lt(this.f.i,this.f.j)},h.of=function(t){return eot(t,(pi(),rh))?at(this.f,v_t):at(this.f,t)},h.Mf=function(){return new lt(this.f.g,this.f.f)},h.Nf=function(){return this.g},h.pf=function(t){return P1(this.f,t)},h.Of=function(t){Uu(this.f,t.a),Gu(this.f,t.b)},h.Pf=function(t){Dw(this.f,t.a),Mw(this.f,t.b)},h.Qf=function(t){this.g=t},h.g=0;var v_t;I(xL,"ElkGraphAdapters/AbstractElkGraphElementAdapter",562),D(563,1,{853:1},Oz),h.Rf=function(){var t,n;if(!this.b)for(this.b=$H(EH(this.a).i),n=new or(EH(this.a));n.e!=n.i.gc();)t=l(gr(n),135),vt(this.b,new Yie(t));return this.b},h.b=null,I(xL,"ElkGraphAdapters/ElkEdgeAdapter",563),D(289,562,{},Jv),h.Sf=function(){return Gdt(this)},h.a=null,I(xL,"ElkGraphAdapters/ElkGraphAdapter",289),D(640,562,{187:1},Yie),I(xL,"ElkGraphAdapters/ElkLabelAdapter",640),D(639,562,{695:1},rae),h.Rf=function(){return m7n(this)},h.Vf=function(){var t;return t=l(at(this.f,(pi(),tC)),140),!t&&(t=new s_),t},h.Xf=function(){return v7n(this)},h.Zf=function(t){var n;n=new xae(t),Hi(this.f,(pi(),tC),n)},h.$f=function(t){Hi(this.f,(pi(),_2),new S4e(t))},h.Tf=function(){return this.d},h.Uf=function(){var t,n;if(!this.a)for(this.a=new bt,n=new hr(dr(sP(l(this.f,27)).a.Kc(),new j));jr(n);)t=l(xr(n),74),vt(this.a,new Oz(t));return this.a},h.Wf=function(){var t,n;if(!this.c)for(this.c=new bt,n=new hr(dr(cp(l(this.f,27)).a.Kc(),new j));jr(n);)t=l(xr(n),74),vt(this.c,new Oz(t));return this.c},h.Yf=function(){return AH(l(this.f,27)).i!=0||Rt(Bt(l(this.f,27).of((pi(),KB))))},h._f=function(){Xvn(this,(aw(),m_t))},h.a=null,h.b=null,h.c=null,h.d=null,h.e=null,I(xL,"ElkGraphAdapters/ElkNodeAdapter",639),D(1284,562,{852:1},BXe),h.Rf=function(){return S7n(this)},h.Uf=function(){var t,n;if(!this.a)for(this.a=eg(l(this.f,123).hh().i),n=new or(l(this.f,123).hh());n.e!=n.i.gc();)t=l(gr(n),74),vt(this.a,new Oz(t));return this.a},h.Wf=function(){var t,n;if(!this.c)for(this.c=eg(l(this.f,123).ih().i),n=new or(l(this.f,123).ih());n.e!=n.i.gc();)t=l(gr(n),74),vt(this.c,new Oz(t));return this.c},h.ag=function(){return l(l(this.f,123).of((pi(),s7)),64)},h.bg=function(){var t,n,r,a,o,f,g,w;for(a=M1(l(this.f,123)),r=new or(l(this.f,123).ih());r.e!=r.i.gc();)for(t=l(gr(r),74),w=new or((!t.c&&(t.c=new Ln(_r,t,5,8)),t.c));w.e!=w.i.gc();){if(g=l(gr(w),84),Ly(bc(g),a))return!0;if(bc(g)==a&&Rt(Bt(at(t,(pi(),Oge)))))return!0}for(n=new or(l(this.f,123).hh());n.e!=n.i.gc();)for(t=l(gr(n),74),f=new or((!t.b&&(t.b=new Ln(_r,t,4,7)),t.b));f.e!=f.i.gc();)if(o=l(gr(f),84),Ly(bc(o),a))return!0;return!1},h.a=null,h.b=null,h.c=null,I(xL,"ElkGraphAdapters/ElkPortAdapter",1284),D(1285,1,ii,zne),h.Ne=function(t,n){return i_n(l(t,123),l(n,123))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(xL,"ElkGraphAdapters/PortComparator",1285);var Xb=ks(pf,"EObject"),oC=ks(T6,r4t),qh=ks(T6,i4t),oF=ks(T6,s4t),cF=ks(T6,"ElkShape"),_r=ks(T6,a4t),js=ks(T6,aSe),cs=ks(T6,o4t),uF=ks(pf,c4t),RM=ks(pf,"EFactory"),w_t,Yge=ks(pf,u4t),u1=ks(pf,"EPackage"),La,y_t,x_t,fPe,pY,k_t,dPe,gPe,pPe,Cg,E_t,T_t,ec=ks(T6,oSe),Ai=ks(T6,cSe),Hl=ks(T6,uSe);D(93,1,l4t),h.th=function(){return this.uh(),null},h.uh=function(){return null},h.vh=function(){return this.uh(),!1},h.wh=function(){return!1},h.xh=function(t){Ni(this,t)},I(Rx,"BasicNotifierImpl",93),D(99,93,g4t),h.Yh=function(){return hh(this)},h.yh=function(t,n){return t},h.zh=function(){throw ue(new Qr)},h.Ah=function(t){var n;return n=Ro(l(Mn(this.Dh(),this.Fh()),19)),this.Ph().Th(this,n.n,n.f,t)},h.Bh=function(t,n){throw ue(new Qr)},h.Ch=function(t,n,r){return Nh(this,t,n,r)},h.Dh=function(){var t;return this.zh()&&(t=this.zh().Nk(),t)?t:this.ii()},h.Eh=function(){return Uue(this)},h.Fh=function(){throw ue(new Qr)},h.Gh=function(){var t,n;return n=this.$h().Ok(),!n&&this.zh().Tk(n=(w_(),t=j5e(Sd(this.Dh())),t==null?rpe:new TO(this,t))),n},h.Hh=function(t,n){return t},h.Ih=function(t){var n;return n=t.pk(),n?t.Lj():ms(this.Dh(),t)},h.Jh=function(){var t;return t=this.zh(),t?t.Qk():null},h.Kh=function(){return this.zh()?this.zh().Nk():null},h.Lh=function(t,n,r){return rU(this,t,n,r)},h.Mh=function(t){return tE(this,t)},h.Nh=function(t,n){return Moe(this,t,n)},h.Oh=function(){var t;return t=this.zh(),!!t&&t.Rk()},h.Ph=function(){throw ue(new Qr)},h.Qh=function(){return XV(this)},h.Rh=function(t,n,r,a){return mx(this,t,n,a)},h.Sh=function(t,n,r){var a;return a=l(Mn(this.Dh(),n),69),a.wk().zk(this,this.hi(),n-this.ji(),t,r)},h.Th=function(t,n,r,a){return IH(this,t,n,a)},h.Uh=function(t,n,r){var a;return a=l(Mn(this.Dh(),n),69),a.wk().Ak(this,this.hi(),n-this.ji(),t,r)},h.Vh=function(){return!!this.zh()&&!!this.zh().Pk()},h.Wh=function(t){return nue(this,t)},h.Xh=function(t){return got(this,t)},h.Zh=function(t){return Bvt(this,t)},h.$h=function(){throw ue(new Qr)},h._h=function(){return this.zh()?this.zh().Pk():null},h.ai=function(){return XV(this)},h.bi=function(t,n){$ue(this,t,n)},h.ci=function(t){this.$h().Sk(t)},h.di=function(t){this.$h().Vk(t)},h.ei=function(t){this.$h().Uk(t)},h.fi=function(t,n){var r,a,o,f;return f=this.Jh(),f&&t&&(n=To(f.El(),this,n),f.Il(this)),a=this.Ph(),a&&(sle(this,this.Ph(),this.Fh()).Bb&Io?(o=a.Qh(),o&&(t?!f&&o.Il(this):o.Hl(this))):(n=(r=this.Fh(),r>=0?this.Ah(n):this.Ph().Th(this,-1-r,null,n)),n=this.Ch(null,-1,n))),this.di(t),n},h.gi=function(t){var n,r,a,o,f,g,w,E;if(r=this.Dh(),f=ms(r,t),n=this.ji(),f>=n)return l(t,69).wk().Dk(this,this.hi(),f-n);if(f<=-1)if(g=g6((El(),io),r,t),g){if(Fo(),l(g,69).xk()||(g=rx(ic(io,g))),o=(a=this.Ih(g),l(a>=0?this.Lh(a,!0,!0):Hw(this,g,!0),160)),E=g.Ik(),E>1||E==-1)return l(l(o,220).Sl(t,!1),79)}else throw ue(new Yn(Ob+t.xe()+$fe));else if(t.Jk())return a=this.Ih(t),l(a>=0?this.Lh(a,!1,!0):Hw(this,t,!1),79);return w=new Itt(this,t),w},h.hi=function(){return V6e(this)},h.ii=function(){return(lb(),Vn).S},h.ji=function(){return yr(this.ii())},h.ki=function(t){Fue(this,t)},h.Ib=function(){return g0(this)},I(Gn,"BasicEObjectImpl",99);var C_t;D(119,99,{110:1,94:1,93:1,58:1,114:1,54:1,99:1,119:1}),h.li=function(t){var n;return n=H6e(this),n[t]},h.mi=function(t,n){var r;r=H6e(this),Ts(r,t,n)},h.ni=function(t){var n;n=H6e(this),Ts(n,t,null)},h.th=function(){return l(Kn(this,4),129)},h.uh=function(){throw ue(new Qr)},h.vh=function(){return(this.Db&4)!=0},h.zh=function(){throw ue(new Qr)},h.oi=function(t){px(this,2,t)},h.Bh=function(t,n){this.Db=n<<16|this.Db&255,this.oi(t)},h.Dh=function(){return sl(this)},h.Fh=function(){return this.Db>>16},h.Gh=function(){var t,n;return w_(),n=j5e(Sd((t=l(Kn(this,16),29),t||this.ii()))),n==null?rpe:new TO(this,n)},h.wh=function(){return(this.Db&1)==0},h.Jh=function(){return l(Kn(this,128),2034)},h.Kh=function(){return l(Kn(this,16),29)},h.Oh=function(){return(this.Db&32)!=0},h.Ph=function(){return l(Kn(this,2),54)},h.Vh=function(){return(this.Db&64)!=0},h.$h=function(){throw ue(new Qr)},h._h=function(){return l(Kn(this,64),288)},h.ci=function(t){px(this,16,t)},h.di=function(t){px(this,128,t)},h.ei=function(t){px(this,64,t)},h.hi=function(){return Ku(this)},h.Db=0,I(Gn,"MinimalEObjectImpl",119),D(120,119,{110:1,94:1,93:1,58:1,114:1,54:1,99:1,119:1,120:1}),h.oi=function(t){this.Cb=t},h.Ph=function(){return this.Cb},I(Gn,"MinimalEObjectImpl/Container",120),D(2083,120,{110:1,342:1,96:1,94:1,93:1,58:1,114:1,54:1,99:1,119:1,120:1}),h.Lh=function(t,n,r){return sxe(this,t,n,r)},h.Uh=function(t,n,r){return Wxe(this,t,n,r)},h.Wh=function(t){return Z5e(this,t)},h.bi=function(t,n){V7e(this,t,n)},h.ii=function(){return su(),T_t},h.ki=function(t){O7e(this,t)},h.nf=function(){return fdt(this)},h.gh=function(){return!this.o&&(this.o=new xl((su(),Cg),L2,this,0)),this.o},h.of=function(t){return at(this,t)},h.pf=function(t){return P1(this,t)},h.qf=function(t,n){return Hi(this,t,n)},I(sv,"EMapPropertyHolderImpl",2083),D(572,120,{110:1,377:1,94:1,93:1,58:1,114:1,54:1,99:1,119:1,120:1},AS),h.Lh=function(t,n,r){switch(t){case 0:return this.a;case 1:return this.b}return rU(this,t,n,r)},h.Wh=function(t){switch(t){case 0:return this.a!=0;case 1:return this.b!=0}return nue(this,t)},h.bi=function(t,n){switch(t){case 0:dV(this,ze(Ge(n)));return;case 1:fV(this,ze(Ge(n)));return}$ue(this,t,n)},h.ii=function(){return su(),y_t},h.ki=function(t){switch(t){case 0:dV(this,0);return;case 1:fV(this,0);return}Fue(this,t)},h.Ib=function(){var t;return this.Db&64?g0(this):(t=new Af(g0(this)),t.a+=" (x: ",_5(t,this.a),t.a+=", y: ",_5(t,this.b),t.a+=")",t.a)},h.a=0,h.b=0,I(sv,"ElkBendPointImpl",572),D(739,2083,{110:1,342:1,167:1,96:1,94:1,93:1,58:1,114:1,54:1,99:1,119:1,120:1}),h.Lh=function(t,n,r){return d8e(this,t,n,r)},h.Sh=function(t,n,r){return Mue(this,t,n,r)},h.Uh=function(t,n,r){return dce(this,t,n,r)},h.Wh=function(t){return _7e(this,t)},h.bi=function(t,n){Txe(this,t,n)},h.ii=function(){return su(),k_t},h.ki=function(t){i8e(this,t)},h.jh=function(){return this.k},h.kh=function(){return EH(this)},h.Ib=function(){return jce(this)},h.k=null,I(sv,"ElkGraphElementImpl",739),D(740,739,{110:1,342:1,167:1,422:1,96:1,94:1,93:1,58:1,114:1,54:1,99:1,119:1,120:1}),h.Lh=function(t,n,r){return x8e(this,t,n,r)},h.Wh=function(t){return _8e(this,t)},h.bi=function(t,n){Cxe(this,t,n)},h.ii=function(){return su(),E_t},h.ki=function(t){N8e(this,t)},h.lh=function(){return this.f},h.mh=function(){return this.g},h.nh=function(){return this.i},h.oh=function(){return this.j},h.ph=function(t,n){F5(this,t,n)},h.qh=function(t,n){Qh(this,t,n)},h.rh=function(t){Uu(this,t)},h.sh=function(t){Gu(this,t)},h.Ib=function(){return Pue(this)},h.f=0,h.g=0,h.i=0,h.j=0,I(sv,"ElkShapeImpl",740),D(741,740,{110:1,342:1,84:1,167:1,422:1,96:1,94:1,93:1,58:1,114:1,54:1,99:1,119:1,120:1}),h.Lh=function(t,n,r){return J8e(this,t,n,r)},h.Sh=function(t,n,r){return vxe(this,t,n,r)},h.Uh=function(t,n,r){return wxe(this,t,n,r)},h.Wh=function(t){return H7e(this,t)},h.bi=function(t,n){I9e(this,t,n)},h.ii=function(){return su(),x_t},h.ki=function(t){K8e(this,t)},h.hh=function(){return!this.d&&(this.d=new Ln(js,this,8,5)),this.d},h.ih=function(){return!this.e&&(this.e=new Ln(js,this,7,4)),this.e},I(sv,"ElkConnectableShapeImpl",741),D(326,739,{110:1,342:1,74:1,167:1,326:1,96:1,94:1,93:1,58:1,114:1,54:1,99:1,119:1,120:1},TI),h.Ah=function(t){return gxe(this,t)},h.Lh=function(t,n,r){switch(t){case 3:return WO(this);case 4:return!this.b&&(this.b=new Ln(_r,this,4,7)),this.b;case 5:return!this.c&&(this.c=new Ln(_r,this,5,8)),this.c;case 6:return!this.a&&(this.a=new nt(cs,this,6,6)),this.a;case 7:return Hn(),!this.b&&(this.b=new Ln(_r,this,4,7)),!(this.b.i<=1&&(!this.c&&(this.c=new Ln(_r,this,5,8)),this.c.i<=1));case 8:return Hn(),!!qA(this);case 9:return Hn(),!!qw(this);case 10:return Hn(),!this.b&&(this.b=new Ln(_r,this,4,7)),this.b.i!=0&&(!this.c&&(this.c=new Ln(_r,this,5,8)),this.c.i!=0)}return d8e(this,t,n,r)},h.Sh=function(t,n,r){var a;switch(n){case 3:return this.Cb&&(r=(a=this.Db>>16,a>=0?gxe(this,r):this.Cb.Th(this,-1-a,null,r))),Yye(this,l(t,27),r);case 4:return!this.b&&(this.b=new Ln(_r,this,4,7)),Ru(this.b,t,r);case 5:return!this.c&&(this.c=new Ln(_r,this,5,8)),Ru(this.c,t,r);case 6:return!this.a&&(this.a=new nt(cs,this,6,6)),Ru(this.a,t,r)}return Mue(this,t,n,r)},h.Uh=function(t,n,r){switch(n){case 3:return Yye(this,null,r);case 4:return!this.b&&(this.b=new Ln(_r,this,4,7)),To(this.b,t,r);case 5:return!this.c&&(this.c=new Ln(_r,this,5,8)),To(this.c,t,r);case 6:return!this.a&&(this.a=new nt(cs,this,6,6)),To(this.a,t,r)}return dce(this,t,n,r)},h.Wh=function(t){switch(t){case 3:return!!WO(this);case 4:return!!this.b&&this.b.i!=0;case 5:return!!this.c&&this.c.i!=0;case 6:return!!this.a&&this.a.i!=0;case 7:return!this.b&&(this.b=new Ln(_r,this,4,7)),!(this.b.i<=1&&(!this.c&&(this.c=new Ln(_r,this,5,8)),this.c.i<=1));case 8:return qA(this);case 9:return qw(this);case 10:return!this.b&&(this.b=new Ln(_r,this,4,7)),this.b.i!=0&&(!this.c&&(this.c=new Ln(_r,this,5,8)),this.c.i!=0)}return _7e(this,t)},h.bi=function(t,n){switch(t){case 3:AU(this,l(n,27));return;case 4:!this.b&&(this.b=new Ln(_r,this,4,7)),$r(this.b),!this.b&&(this.b=new Ln(_r,this,4,7)),As(this.b,l(n,16));return;case 5:!this.c&&(this.c=new Ln(_r,this,5,8)),$r(this.c),!this.c&&(this.c=new Ln(_r,this,5,8)),As(this.c,l(n,16));return;case 6:!this.a&&(this.a=new nt(cs,this,6,6)),$r(this.a),!this.a&&(this.a=new nt(cs,this,6,6)),As(this.a,l(n,16));return}Txe(this,t,n)},h.ii=function(){return su(),fPe},h.ki=function(t){switch(t){case 3:AU(this,null);return;case 4:!this.b&&(this.b=new Ln(_r,this,4,7)),$r(this.b);return;case 5:!this.c&&(this.c=new Ln(_r,this,5,8)),$r(this.c);return;case 6:!this.a&&(this.a=new nt(cs,this,6,6)),$r(this.a);return}i8e(this,t)},h.Ib=function(){return evt(this)},I(sv,"ElkEdgeImpl",326),D(452,2083,{110:1,342:1,166:1,452:1,96:1,94:1,93:1,58:1,114:1,54:1,99:1,119:1,120:1},rk),h.Ah=function(t){return lxe(this,t)},h.Lh=function(t,n,r){switch(t){case 1:return this.j;case 2:return this.k;case 3:return this.b;case 4:return this.c;case 5:return!this.a&&(this.a=new Ys(qh,this,5)),this.a;case 6:return lot(this);case 7:return n?oue(this):this.i;case 8:return n?aue(this):this.f;case 9:return!this.g&&(this.g=new Ln(cs,this,9,10)),this.g;case 10:return!this.e&&(this.e=new Ln(cs,this,10,9)),this.e;case 11:return this.d}return sxe(this,t,n,r)},h.Sh=function(t,n,r){var a,o,f;switch(n){case 6:return this.Cb&&(r=(o=this.Db>>16,o>=0?lxe(this,r):this.Cb.Th(this,-1-o,null,r))),Wye(this,l(t,74),r);case 9:return!this.g&&(this.g=new Ln(cs,this,9,10)),Ru(this.g,t,r);case 10:return!this.e&&(this.e=new Ln(cs,this,10,9)),Ru(this.e,t,r)}return f=l(Mn((a=l(Kn(this,16),29),a||(su(),pY)),n),69),f.wk().zk(this,Ku(this),n-yr((su(),pY)),t,r)},h.Uh=function(t,n,r){switch(n){case 5:return!this.a&&(this.a=new Ys(qh,this,5)),To(this.a,t,r);case 6:return Wye(this,null,r);case 9:return!this.g&&(this.g=new Ln(cs,this,9,10)),To(this.g,t,r);case 10:return!this.e&&(this.e=new Ln(cs,this,10,9)),To(this.e,t,r)}return Wxe(this,t,n,r)},h.Wh=function(t){switch(t){case 1:return this.j!=0;case 2:return this.k!=0;case 3:return this.b!=0;case 4:return this.c!=0;case 5:return!!this.a&&this.a.i!=0;case 6:return!!lot(this);case 7:return!!this.i;case 8:return!!this.f;case 9:return!!this.g&&this.g.i!=0;case 10:return!!this.e&&this.e.i!=0;case 11:return this.d!=null}return Z5e(this,t)},h.bi=function(t,n){switch(t){case 1:oE(this,ze(Ge(n)));return;case 2:uE(this,ze(Ge(n)));return;case 3:aE(this,ze(Ge(n)));return;case 4:cE(this,ze(Ge(n)));return;case 5:!this.a&&(this.a=new Ys(qh,this,5)),$r(this.a),!this.a&&(this.a=new Ys(qh,this,5)),As(this.a,l(n,16));return;case 6:Z2t(this,l(n,74));return;case 7:yV(this,l(n,84));return;case 8:wV(this,l(n,84));return;case 9:!this.g&&(this.g=new Ln(cs,this,9,10)),$r(this.g),!this.g&&(this.g=new Ln(cs,this,9,10)),As(this.g,l(n,16));return;case 10:!this.e&&(this.e=new Ln(cs,this,10,9)),$r(this.e),!this.e&&(this.e=new Ln(cs,this,10,9)),As(this.e,l(n,16));return;case 11:p7e(this,ei(n));return}V7e(this,t,n)},h.ii=function(){return su(),pY},h.ki=function(t){switch(t){case 1:oE(this,0);return;case 2:uE(this,0);return;case 3:aE(this,0);return;case 4:cE(this,0);return;case 5:!this.a&&(this.a=new Ys(qh,this,5)),$r(this.a);return;case 6:Z2t(this,null);return;case 7:yV(this,null);return;case 8:wV(this,null);return;case 9:!this.g&&(this.g=new Ln(cs,this,9,10)),$r(this.g);return;case 10:!this.e&&(this.e=new Ln(cs,this,10,9)),$r(this.e);return;case 11:p7e(this,null);return}O7e(this,t)},h.Ib=function(){return d2t(this)},h.b=0,h.c=0,h.d=null,h.j=0,h.k=0,I(sv,"ElkEdgeSectionImpl",452),D(158,120,{110:1,94:1,93:1,155:1,58:1,114:1,54:1,99:1,158:1,119:1,120:1}),h.Lh=function(t,n,r){var a;return t==0?(!this.Ab&&(this.Ab=new nt(mi,this,0,3)),this.Ab):sf(this,t-yr(this.ii()),Mn((a=l(Kn(this,16),29),a||this.ii()),t),n,r)},h.Sh=function(t,n,r){var a,o;return n==0?(!this.Ab&&(this.Ab=new nt(mi,this,0,3)),Ru(this.Ab,t,r)):(o=l(Mn((a=l(Kn(this,16),29),a||this.ii()),n),69),o.wk().zk(this,Ku(this),n-yr(this.ii()),t,r))},h.Uh=function(t,n,r){var a,o;return n==0?(!this.Ab&&(this.Ab=new nt(mi,this,0,3)),To(this.Ab,t,r)):(o=l(Mn((a=l(Kn(this,16),29),a||this.ii()),n),69),o.wk().Ak(this,Ku(this),n-yr(this.ii()),t,r))},h.Wh=function(t){var n;return t==0?!!this.Ab&&this.Ab.i!=0:nf(this,t-yr(this.ii()),Mn((n=l(Kn(this,16),29),n||this.ii()),t))},h.Zh=function(t){return Hke(this,t)},h.bi=function(t,n){var r;switch(t){case 0:!this.Ab&&(this.Ab=new nt(mi,this,0,3)),$r(this.Ab),!this.Ab&&(this.Ab=new nt(mi,this,0,3)),As(this.Ab,l(n,16));return}uf(this,t-yr(this.ii()),Mn((r=l(Kn(this,16),29),r||this.ii()),t),n)},h.di=function(t){px(this,128,t)},h.ii=function(){return Tn(),H_t},h.ki=function(t){var n;switch(t){case 0:!this.Ab&&(this.Ab=new nt(mi,this,0,3)),$r(this.Ab);return}cf(this,t-yr(this.ii()),Mn((n=l(Kn(this,16),29),n||this.ii()),t))},h.pi=function(){this.Bb|=1},h.qi=function(t){return YA(this,t)},h.Bb=0,I(Gn,"EModelElementImpl",158),D(720,158,{110:1,94:1,93:1,480:1,155:1,58:1,114:1,54:1,99:1,158:1,119:1,120:1},fz),h.ri=function(t,n){return Lvt(this,t,n)},h.si=function(t){var n,r,a,o,f;if(this.a!=Ah(t)||t.Bb&256)throw ue(new Yn(qfe+t.zb+t3));for(a=dc(t);du(a.a).i!=0;){if(r=l(mP(a,0,(n=l(Oe(du(a.a),0),89),f=n.c,De(f,90)?l(f,29):(Tn(),Kf))),29),zw(r))return o=Ah(r).wi().si(r),l(o,54).ci(t),o;a=dc(r)}return(t.D!=null?t.D:t.B)=="java.util.Map$Entry"?new Git(t):new F4e(t)},h.ti=function(t,n){return Kw(this,t,n)},h.Lh=function(t,n,r){var a;switch(t){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),this.Ab;case 1:return this.a}return sf(this,t-yr((Tn(),em)),Mn((a=l(Kn(this,16),29),a||em),t),n,r)},h.Sh=function(t,n,r){var a,o;switch(n){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),Ru(this.Ab,t,r);case 1:return this.a&&(r=l(this.a,54).Th(this,4,u1,r)),r8e(this,l(t,241),r)}return o=l(Mn((a=l(Kn(this,16),29),a||(Tn(),em)),n),69),o.wk().zk(this,Ku(this),n-yr((Tn(),em)),t,r)},h.Uh=function(t,n,r){var a,o;switch(n){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),To(this.Ab,t,r);case 1:return r8e(this,null,r)}return o=l(Mn((a=l(Kn(this,16),29),a||(Tn(),em)),n),69),o.wk().Ak(this,Ku(this),n-yr((Tn(),em)),t,r)},h.Wh=function(t){var n;switch(t){case 0:return!!this.Ab&&this.Ab.i!=0;case 1:return!!this.a}return nf(this,t-yr((Tn(),em)),Mn((n=l(Kn(this,16),29),n||em),t))},h.bi=function(t,n){var r;switch(t){case 0:!this.Ab&&(this.Ab=new nt(mi,this,0,3)),$r(this.Ab),!this.Ab&&(this.Ab=new nt(mi,this,0,3)),As(this.Ab,l(n,16));return;case 1:Xgt(this,l(n,241));return}uf(this,t-yr((Tn(),em)),Mn((r=l(Kn(this,16),29),r||em),t),n)},h.ii=function(){return Tn(),em},h.ki=function(t){var n;switch(t){case 0:!this.Ab&&(this.Ab=new nt(mi,this,0,3)),$r(this.Ab);return;case 1:Xgt(this,null);return}cf(this,t-yr((Tn(),em)),Mn((n=l(Kn(this,16),29),n||em),t))};var jM,bPe,S_t;I(Gn,"EFactoryImpl",720),D(1037,720,{110:1,2113:1,94:1,93:1,480:1,155:1,58:1,114:1,54:1,99:1,158:1,119:1,120:1},ik),h.ri=function(t,n){switch(t.hk()){case 12:return l(n,149).Pg();case 13:return xc(n);default:throw ue(new Yn(yT+t.xe()+t3))}},h.si=function(t){var n,r,a,o,f,g,w,E;switch(t.G==-1&&(t.G=(n=Ah(t),n?f2(n.vi(),t):-1)),t.G){case 4:return f=new sk,f;case 6:return g=new a_,g;case 7:return w=new jwe,w;case 8:return a=new TI,a;case 9:return r=new AS,r;case 10:return o=new rk,o;case 11:return E=new k$,E;default:throw ue(new Yn(qfe+t.zb+t3))}},h.ti=function(t,n){switch(t.hk()){case 13:case 12:return null;default:throw ue(new Yn(yT+t.xe()+t3))}},I(sv,"ElkGraphFactoryImpl",1037),D(448,158,{110:1,94:1,93:1,155:1,197:1,58:1,114:1,54:1,99:1,158:1,119:1,120:1}),h.Gh=function(){var t,n;return n=(t=l(Kn(this,16),29),j5e(Sd(t||this.ii()))),n==null?(w_(),w_(),rpe):new prt(this,n)},h.Lh=function(t,n,r){var a;switch(t){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),this.Ab;case 1:return this.xe()}return sf(this,t-yr(this.ii()),Mn((a=l(Kn(this,16),29),a||this.ii()),t),n,r)},h.Wh=function(t){var n;switch(t){case 0:return!!this.Ab&&this.Ab.i!=0;case 1:return this.zb!=null}return nf(this,t-yr(this.ii()),Mn((n=l(Kn(this,16),29),n||this.ii()),t))},h.bi=function(t,n){var r;switch(t){case 0:!this.Ab&&(this.Ab=new nt(mi,this,0,3)),$r(this.Ab),!this.Ab&&(this.Ab=new nt(mi,this,0,3)),As(this.Ab,l(n,16));return;case 1:this.ui(ei(n));return}uf(this,t-yr(this.ii()),Mn((r=l(Kn(this,16),29),r||this.ii()),t),n)},h.ii=function(){return Tn(),V_t},h.ki=function(t){var n;switch(t){case 0:!this.Ab&&(this.Ab=new nt(mi,this,0,3)),$r(this.Ab);return;case 1:this.ui(null);return}cf(this,t-yr(this.ii()),Mn((n=l(Kn(this,16),29),n||this.ii()),t))},h.xe=function(){return this.zb},h.ui=function(t){Fu(this,t)},h.Ib=function(){return CA(this)},h.zb=null,I(Gn,"ENamedElementImpl",448),D(184,448,{110:1,94:1,93:1,155:1,197:1,58:1,241:1,114:1,54:1,99:1,158:1,184:1,119:1,120:1,690:1},qat),h.Ah=function(t){return ogt(this,t)},h.Lh=function(t,n,r){var a;switch(t){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),this.Ab;case 1:return this.zb;case 2:return this.yb;case 3:return this.xb;case 4:return this.sb;case 5:return!this.rb&&(this.rb=new wy(this,l1,this)),this.rb;case 6:return!this.vb&&(this.vb=new V8(u1,this,6,7)),this.vb;case 7:return n?this.Db>>16==7?l(this.Cb,241):null:mot(this)}return sf(this,t-yr((Tn(),O2)),Mn((a=l(Kn(this,16),29),a||O2),t),n,r)},h.Sh=function(t,n,r){var a,o,f;switch(n){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),Ru(this.Ab,t,r);case 4:return this.sb&&(r=l(this.sb,54).Th(this,1,RM,r)),a8e(this,l(t,480),r);case 5:return!this.rb&&(this.rb=new wy(this,l1,this)),Ru(this.rb,t,r);case 6:return!this.vb&&(this.vb=new V8(u1,this,6,7)),Ru(this.vb,t,r);case 7:return this.Cb&&(r=(o=this.Db>>16,o>=0?ogt(this,r):this.Cb.Th(this,-1-o,null,r))),Nh(this,t,7,r)}return f=l(Mn((a=l(Kn(this,16),29),a||(Tn(),O2)),n),69),f.wk().zk(this,Ku(this),n-yr((Tn(),O2)),t,r)},h.Uh=function(t,n,r){var a,o;switch(n){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),To(this.Ab,t,r);case 4:return a8e(this,null,r);case 5:return!this.rb&&(this.rb=new wy(this,l1,this)),To(this.rb,t,r);case 6:return!this.vb&&(this.vb=new V8(u1,this,6,7)),To(this.vb,t,r);case 7:return Nh(this,null,7,r)}return o=l(Mn((a=l(Kn(this,16),29),a||(Tn(),O2)),n),69),o.wk().Ak(this,Ku(this),n-yr((Tn(),O2)),t,r)},h.Wh=function(t){var n;switch(t){case 0:return!!this.Ab&&this.Ab.i!=0;case 1:return this.zb!=null;case 2:return this.yb!=null;case 3:return this.xb!=null;case 4:return!!this.sb;case 5:return!!this.rb&&this.rb.i!=0;case 6:return!!this.vb&&this.vb.i!=0;case 7:return!!mot(this)}return nf(this,t-yr((Tn(),O2)),Mn((n=l(Kn(this,16),29),n||O2),t))},h.Zh=function(t){var n;return n=wCn(this,t),n||Hke(this,t)},h.bi=function(t,n){var r;switch(t){case 0:!this.Ab&&(this.Ab=new nt(mi,this,0,3)),$r(this.Ab),!this.Ab&&(this.Ab=new nt(mi,this,0,3)),As(this.Ab,l(n,16));return;case 1:Fu(this,ei(n));return;case 2:SV(this,ei(n));return;case 3:CV(this,ei(n));return;case 4:Nue(this,l(n,480));return;case 5:!this.rb&&(this.rb=new wy(this,l1,this)),$r(this.rb),!this.rb&&(this.rb=new wy(this,l1,this)),As(this.rb,l(n,16));return;case 6:!this.vb&&(this.vb=new V8(u1,this,6,7)),$r(this.vb),!this.vb&&(this.vb=new V8(u1,this,6,7)),As(this.vb,l(n,16));return}uf(this,t-yr((Tn(),O2)),Mn((r=l(Kn(this,16),29),r||O2),t),n)},h.ei=function(t){var n,r;if(t&&this.rb)for(r=new or(this.rb);r.e!=r.i.gc();)n=gr(r),De(n,364)&&(l(n,364).w=null);px(this,64,t)},h.ii=function(){return Tn(),O2},h.ki=function(t){var n;switch(t){case 0:!this.Ab&&(this.Ab=new nt(mi,this,0,3)),$r(this.Ab);return;case 1:Fu(this,null);return;case 2:SV(this,null);return;case 3:CV(this,null);return;case 4:Nue(this,null);return;case 5:!this.rb&&(this.rb=new wy(this,l1,this)),$r(this.rb);return;case 6:!this.vb&&(this.vb=new V8(u1,this,6,7)),$r(this.vb);return}cf(this,t-yr((Tn(),O2)),Mn((n=l(Kn(this,16),29),n||O2),t))},h.pi=function(){yue(this)},h.vi=function(){return!this.rb&&(this.rb=new wy(this,l1,this)),this.rb},h.wi=function(){return this.sb},h.xi=function(){return this.ub},h.yi=function(){return this.xb},h.zi=function(){return this.yb},h.Ai=function(t){this.ub=t},h.Ib=function(){var t;return this.Db&64?CA(this):(t=new Af(CA(this)),t.a+=" (nsURI: ",Xo(t,this.yb),t.a+=", nsPrefix: ",Xo(t,this.xb),t.a+=")",t.a)},h.xb=null,h.yb=null,I(Gn,"EPackageImpl",184),D(569,184,{110:1,2115:1,569:1,94:1,93:1,155:1,197:1,58:1,241:1,114:1,54:1,99:1,158:1,184:1,119:1,120:1,690:1},k2t),h.q=!1,h.r=!1;var __t=!1;I(sv,"ElkGraphPackageImpl",569),D(366,740,{110:1,342:1,167:1,135:1,422:1,366:1,96:1,94:1,93:1,58:1,114:1,54:1,99:1,119:1,120:1},sk),h.Ah=function(t){return hxe(this,t)},h.Lh=function(t,n,r){switch(t){case 7:return vot(this);case 8:return this.a}return x8e(this,t,n,r)},h.Sh=function(t,n,r){var a;switch(n){case 7:return this.Cb&&(r=(a=this.Db>>16,a>=0?hxe(this,r):this.Cb.Th(this,-1-a,null,r))),J4e(this,l(t,167),r)}return Mue(this,t,n,r)},h.Uh=function(t,n,r){return n==7?J4e(this,null,r):dce(this,t,n,r)},h.Wh=function(t){switch(t){case 7:return!!vot(this);case 8:return!vn("",this.a)}return _8e(this,t)},h.bi=function(t,n){switch(t){case 7:U9e(this,l(n,167));return;case 8:l7e(this,ei(n));return}Cxe(this,t,n)},h.ii=function(){return su(),dPe},h.ki=function(t){switch(t){case 7:U9e(this,null);return;case 8:l7e(this,"");return}N8e(this,t)},h.Ib=function(){return lpt(this)},h.a="",I(sv,"ElkLabelImpl",366),D(207,741,{110:1,342:1,84:1,167:1,27:1,422:1,207:1,96:1,94:1,93:1,58:1,114:1,54:1,99:1,119:1,120:1},a_),h.Ah=function(t){return pxe(this,t)},h.Lh=function(t,n,r){switch(t){case 9:return!this.c&&(this.c=new nt(Hl,this,9,9)),this.c;case 10:return!this.a&&(this.a=new nt(Ai,this,10,11)),this.a;case 11:return ds(this);case 12:return!this.b&&(this.b=new nt(js,this,12,3)),this.b;case 13:return Hn(),!this.a&&(this.a=new nt(Ai,this,10,11)),this.a.i>0}return J8e(this,t,n,r)},h.Sh=function(t,n,r){var a;switch(n){case 9:return!this.c&&(this.c=new nt(Hl,this,9,9)),Ru(this.c,t,r);case 10:return!this.a&&(this.a=new nt(Ai,this,10,11)),Ru(this.a,t,r);case 11:return this.Cb&&(r=(a=this.Db>>16,a>=0?pxe(this,r):this.Cb.Th(this,-1-a,null,r))),s4e(this,l(t,27),r);case 12:return!this.b&&(this.b=new nt(js,this,12,3)),Ru(this.b,t,r)}return vxe(this,t,n,r)},h.Uh=function(t,n,r){switch(n){case 9:return!this.c&&(this.c=new nt(Hl,this,9,9)),To(this.c,t,r);case 10:return!this.a&&(this.a=new nt(Ai,this,10,11)),To(this.a,t,r);case 11:return s4e(this,null,r);case 12:return!this.b&&(this.b=new nt(js,this,12,3)),To(this.b,t,r)}return wxe(this,t,n,r)},h.Wh=function(t){switch(t){case 9:return!!this.c&&this.c.i!=0;case 10:return!!this.a&&this.a.i!=0;case 11:return!!ds(this);case 12:return!!this.b&&this.b.i!=0;case 13:return!this.a&&(this.a=new nt(Ai,this,10,11)),this.a.i>0}return H7e(this,t)},h.bi=function(t,n){switch(t){case 9:!this.c&&(this.c=new nt(Hl,this,9,9)),$r(this.c),!this.c&&(this.c=new nt(Hl,this,9,9)),As(this.c,l(n,16));return;case 10:!this.a&&(this.a=new nt(Ai,this,10,11)),$r(this.a),!this.a&&(this.a=new nt(Ai,this,10,11)),As(this.a,l(n,16));return;case 11:LU(this,l(n,27));return;case 12:!this.b&&(this.b=new nt(js,this,12,3)),$r(this.b),!this.b&&(this.b=new nt(js,this,12,3)),As(this.b,l(n,16));return}I9e(this,t,n)},h.ii=function(){return su(),gPe},h.ki=function(t){switch(t){case 9:!this.c&&(this.c=new nt(Hl,this,9,9)),$r(this.c);return;case 10:!this.a&&(this.a=new nt(Ai,this,10,11)),$r(this.a);return;case 11:LU(this,null);return;case 12:!this.b&&(this.b=new nt(js,this,12,3)),$r(this.b);return}K8e(this,t)},h.Ib=function(){return oke(this)},I(sv,"ElkNodeImpl",207),D(193,741,{110:1,342:1,84:1,167:1,123:1,422:1,193:1,96:1,94:1,93:1,58:1,114:1,54:1,99:1,119:1,120:1},jwe),h.Ah=function(t){return fxe(this,t)},h.Lh=function(t,n,r){return t==9?M1(this):J8e(this,t,n,r)},h.Sh=function(t,n,r){var a;switch(n){case 9:return this.Cb&&(r=(a=this.Db>>16,a>=0?fxe(this,r):this.Cb.Th(this,-1-a,null,r))),Xye(this,l(t,27),r)}return vxe(this,t,n,r)},h.Uh=function(t,n,r){return n==9?Xye(this,null,r):wxe(this,t,n,r)},h.Wh=function(t){return t==9?!!M1(this):H7e(this,t)},h.bi=function(t,n){switch(t){case 9:z9e(this,l(n,27));return}I9e(this,t,n)},h.ii=function(){return su(),pPe},h.ki=function(t){switch(t){case 9:z9e(this,null);return}K8e(this,t)},h.Ib=function(){return Jbt(this)},I(sv,"ElkPortImpl",193);var A_t=ks(So,"BasicEMap/Entry");D(1122,120,{110:1,44:1,94:1,93:1,136:1,58:1,114:1,54:1,99:1,119:1,120:1},k$),h.Fb=function(t){return this===t},h.ld=function(){return this.b},h.Hb=function(){return fw(this)},h.Di=function(t){h7e(this,l(t,149))},h.Lh=function(t,n,r){switch(t){case 0:return this.b;case 1:return this.c}return rU(this,t,n,r)},h.Wh=function(t){switch(t){case 0:return!!this.b;case 1:return this.c!=null}return nue(this,t)},h.bi=function(t,n){switch(t){case 0:h7e(this,l(n,149));return;case 1:u7e(this,n);return}$ue(this,t,n)},h.ii=function(){return su(),Cg},h.ki=function(t){switch(t){case 0:h7e(this,null);return;case 1:u7e(this,null);return}Fue(this,t)},h.Bi=function(){var t;return this.a==-1&&(t=this.b,this.a=t?es(t):0),this.a},h.md=function(){return this.c},h.Ci=function(t){this.a=t},h.nd=function(t){var n;return n=this.c,u7e(this,t),n},h.Ib=function(){var t;return this.Db&64?g0(this):(t=new tb,hi(hi(hi(t,this.b?this.b.Pg():ul),Phe),j_(this.c)),t.a)},h.a=-1,h.c=null;var L2=I(sv,"ElkPropertyToValueMapEntryImpl",1122);D(996,1,{},T$),I(no,"JsonAdapter",996),D(216,63,lp,dd),I(no,"JsonImportException",216),D(868,1,{},cgt),I(no,"JsonImporter",868),D(903,1,{},ptt),I(no,"JsonImporter/lambda$0$Type",903),D(904,1,{},btt),I(no,"JsonImporter/lambda$1$Type",904),D(912,1,{},FXe),I(no,"JsonImporter/lambda$10$Type",912),D(914,1,{},mtt),I(no,"JsonImporter/lambda$11$Type",914),D(915,1,{},vtt),I(no,"JsonImporter/lambda$12$Type",915),D(921,1,{},Mat),I(no,"JsonImporter/lambda$13$Type",921),D(920,1,{},Dat),I(no,"JsonImporter/lambda$14$Type",920),D(916,1,{},wtt),I(no,"JsonImporter/lambda$15$Type",916),D(917,1,{},ytt),I(no,"JsonImporter/lambda$16$Type",917),D(918,1,{},xtt),I(no,"JsonImporter/lambda$17$Type",918),D(919,1,{},ktt),I(no,"JsonImporter/lambda$18$Type",919),D(924,1,{},RXe),I(no,"JsonImporter/lambda$19$Type",924),D(905,1,{},jXe),I(no,"JsonImporter/lambda$2$Type",905),D(922,1,{},$Xe),I(no,"JsonImporter/lambda$20$Type",922),D(923,1,{},zXe),I(no,"JsonImporter/lambda$21$Type",923),D(927,1,{},qXe),I(no,"JsonImporter/lambda$22$Type",927),D(925,1,{},HXe),I(no,"JsonImporter/lambda$23$Type",925),D(926,1,{},VXe),I(no,"JsonImporter/lambda$24$Type",926),D(929,1,{},UXe),I(no,"JsonImporter/lambda$25$Type",929),D(928,1,{},GXe),I(no,"JsonImporter/lambda$26$Type",928),D(930,1,fr,Ett),h.Cd=function(t){Ovn(this.b,this.a,ei(t))},I(no,"JsonImporter/lambda$27$Type",930),D(931,1,fr,Ttt),h.Cd=function(t){Nvn(this.b,this.a,ei(t))},I(no,"JsonImporter/lambda$28$Type",931),D(932,1,{},Ctt),I(no,"JsonImporter/lambda$29$Type",932),D(908,1,{},KXe),I(no,"JsonImporter/lambda$3$Type",908),D(933,1,{},Stt),I(no,"JsonImporter/lambda$30$Type",933),D(934,1,{},WXe),I(no,"JsonImporter/lambda$31$Type",934),D(935,1,{},YXe),I(no,"JsonImporter/lambda$32$Type",935),D(936,1,{},XXe),I(no,"JsonImporter/lambda$33$Type",936),D(937,1,{},QXe),I(no,"JsonImporter/lambda$34$Type",937),D(870,1,{},JXe),I(no,"JsonImporter/lambda$35$Type",870),D(941,1,{},yit),I(no,"JsonImporter/lambda$36$Type",941),D(938,1,fr,ZXe),h.Cd=function(t){jmn(this.a,l(t,377))},I(no,"JsonImporter/lambda$37$Type",938),D(939,1,fr,_tt),h.Cd=function(t){yln(this.a,this.b,l(t,166))},I(no,"JsonImporter/lambda$38$Type",939),D(940,1,fr,Att),h.Cd=function(t){xln(this.a,this.b,l(t,166))},I(no,"JsonImporter/lambda$39$Type",940),D(906,1,{},eQe),I(no,"JsonImporter/lambda$4$Type",906),D(942,1,fr,tQe),h.Cd=function(t){$mn(this.a,l(t,8))},I(no,"JsonImporter/lambda$40$Type",942),D(907,1,{},nQe),I(no,"JsonImporter/lambda$5$Type",907),D(911,1,{},rQe),I(no,"JsonImporter/lambda$6$Type",911),D(909,1,{},iQe),I(no,"JsonImporter/lambda$7$Type",909),D(910,1,{},sQe),I(no,"JsonImporter/lambda$8$Type",910),D(913,1,{},aQe),I(no,"JsonImporter/lambda$9$Type",913),D(961,1,fr,oQe),h.Cd=function(t){J8(this.a,new yy(ei(t)))},I(no,"JsonMetaDataConverter/lambda$0$Type",961),D(962,1,fr,cQe),h.Cd=function(t){Dgn(this.a,l(t,245))},I(no,"JsonMetaDataConverter/lambda$1$Type",962),D(963,1,fr,uQe),h.Cd=function(t){M2n(this.a,l(t,143))},I(no,"JsonMetaDataConverter/lambda$2$Type",963),D(964,1,fr,lQe),h.Cd=function(t){Ign(this.a,l(t,170))},I(no,"JsonMetaDataConverter/lambda$3$Type",964),D(245,22,{3:1,34:1,22:1,245:1},R8);var bY,mY,Xge,vY,wY,yY,Qge,Jge,xY=Fr(IP,"GraphFeature",245,Hr,pwn,idn),L_t;D(11,1,{34:1,149:1},Ui,vs,pn,Ha),h.Fd=function(t){return Shn(this,l(t,149))},h.Fb=function(t){return eot(this,t)},h.Sg=function(){return It(this)},h.Pg=function(){return this.b},h.Hb=function(){return s2(this.b)},h.Ib=function(){return this.b},I(IP,"Property",11),D(671,1,ii,Nie),h.Ne=function(t,n){return B4n(this,l(t,96),l(n,96))},h.Fb=function(t){return this===t},h.Oe=function(){return new Vt(this)},I(IP,"PropertyHolderComparator",671),D(709,1,Oa,ywe),h.Nb=function(t){Za(this,t)},h.Pb=function(){return Fvn(this)},h.Qb=function(){aZe()},h.Ob=function(){return!!this.a},I(qG,"ElkGraphUtil/AncestorIterator",709);var mPe=ks(So,"EList");D(70,56,{20:1,31:1,56:1,16:1,15:1,70:1,61:1}),h.bd=function(t,n){_A(this,t,n)},h.Fc=function(t){return qr(this,t)},h.cd=function(t,n){return N7e(this,t,n)},h.Gc=function(t){return As(this,t)},h.Ii=function(){return new H8(this)},h.Ji=function(){return new CO(this)},h.Ki=function(t){return mN(this,t)},h.Li=function(){return!0},h.Mi=function(t,n){},h.Ni=function(){},h.Oi=function(t,n){Noe(this,t,n)},h.Pi=function(t,n,r){},h.Qi=function(t,n){},h.Ri=function(t,n,r){},h.Fb=function(t){return Bbt(this,t)},h.Hb=function(){return M7e(this)},h.Si=function(){return!1},h.Kc=function(){return new or(this)},h.ed=function(){return new q8(this)},h.fd=function(t){var n;if(n=this.gc(),t<0||t>n)throw ue(new my(t,n));return new jae(this,t)},h.Ui=function(t,n){this.Ti(t,this.dd(n))},h.Mc=function(t){return sV(this,t)},h.Wi=function(t,n){return n},h.hd=function(t,n){return n6(this,t,n)},h.Ib=function(){return T8e(this)},h.Yi=function(){return!0},h.Zi=function(t,n){return EE(this,n)},I(So,"AbstractEList",70),D(66,70,Bd,X2,Lw,T7e),h.Ei=function(t,n){return Due(this,t,n)},h.Fi=function(t){return Odt(this,t)},h.Gi=function(t,n){IN(this,t,n)},h.Hi=function(t){tN(this,t)},h.$i=function(t){return R6e(this,t)},h.$b=function(){uA(this)},h.Hc=function(t){return jE(this,t)},h.Xb=function(t){return Oe(this,t)},h._i=function(t){var n,r,a;++this.j,r=this.g==null?0:this.g.length,t>r&&(a=this.g,n=r+(r/2|0)+4,n=0?(this.gd(n),!0):!1},h.Xi=function(t,n){return this.Dj(t,this.Zi(t,n))},h.gc=function(){return this.Ej()},h.Pc=function(){return this.Fj()},h.Qc=function(t){return this.Gj(t)},h.Ib=function(){return this.Hj()},I(So,"DelegatingEList",2093),D(2094,2093,J4t),h.Ei=function(t,n){return wke(this,t,n)},h.Fi=function(t){return this.Ei(this.Ej(),t)},h.Gi=function(t,n){E2t(this,t,n)},h.Hi=function(t){h2t(this,t)},h.Li=function(){return!this.Mj()},h.$b=function(){tL(this)},h.Ij=function(t,n,r,a,o){return new Zat(this,t,n,r,a,o)},h.Jj=function(t){Ni(this.jj(),t)},h.Kj=function(){return null},h.Lj=function(){return-1},h.jj=function(){return null},h.Mj=function(){return!1},h.Nj=function(t,n){return n},h.Oj=function(t,n){return n},h.Pj=function(){return!1},h.Qj=function(){return!this.Aj()},h.Ti=function(t,n){var r,a;return this.Pj()?(a=this.Qj(),r=Uxe(this,t,n),this.Jj(this.Ij(7,pt(n),r,t,a)),r):Uxe(this,t,n)},h.gd=function(t){var n,r,a,o;return this.Pj()?(r=null,a=this.Qj(),n=this.Ij(4,o=rH(this,t),null,t,a),this.Mj()&&o?(r=this.Oj(o,r),r?(r.nj(n),r.oj()):this.Jj(n)):r?(r.nj(n),r.oj()):this.Jj(n),o):(o=rH(this,t),this.Mj()&&o&&(r=this.Oj(o,null),r&&r.oj()),o)},h.Xi=function(t,n){return Mmt(this,t,n)},I(Rx,"DelegatingNotifyingListImpl",2094),D(152,1,YP),h.nj=function(t){return Mxe(this,t)},h.oj=function(){qoe(this)},h.gj=function(){return this.d},h.Kj=function(){return null},h.Rj=function(){return null},h.hj=function(t){return-1},h.ij=function(){return mbt(this)},h.jj=function(){return null},h.kj=function(){return X9e(this)},h.lj=function(){return this.o<0?this.o<-2?-2-this.o-1:-1:this.o},h.Sj=function(){return!1},h.mj=function(t){var n,r,a,o,f,g,w,E,C,L,B;switch(this.d){case 1:case 2:switch(o=t.gj(),o){case 1:case 2:if(f=t.jj(),qe(f)===qe(this.jj())&&this.hj(null)==t.hj(null))return this.g=t.ij(),t.gj()==1&&(this.d=1),!0}case 4:{switch(o=t.gj(),o){case 4:{if(f=t.jj(),qe(f)===qe(this.jj())&&this.hj(null)==t.hj(null))return C=Bke(this),E=this.o<0?this.o<-2?-2-this.o-1:-1:this.o,g=t.lj(),this.d=6,B=new Lw(2),E<=g?(qr(B,this.n),qr(B,t.kj()),this.g=he(le(Vr,1),di,28,15,[this.o=E,g+1])):(qr(B,t.kj()),qr(B,this.n),this.g=he(le(Vr,1),di,28,15,[this.o=g,E])),this.n=B,C||(this.o=-2-this.o-1),!0;break}}break}case 6:{switch(o=t.gj(),o){case 4:{if(f=t.jj(),qe(f)===qe(this.jj())&&this.hj(null)==t.hj(null)){for(C=Bke(this),g=t.lj(),L=l(this.g,53),a=We(Vr,di,28,L.length+1,15,1),n=0;n>>0,n.toString(16))),a.a+=" (eventType: ",this.d){case 1:{a.a+="SET";break}case 2:{a.a+="UNSET";break}case 3:{a.a+="ADD";break}case 5:{a.a+="ADD_MANY";break}case 4:{a.a+="REMOVE";break}case 6:{a.a+="REMOVE_MANY";break}case 7:{a.a+="MOVE";break}case 8:{a.a+="REMOVING_ADAPTER";break}case 9:{a.a+="RESOLVE";break}default:{ise(a,this.d);break}}if(imt(this)&&(a.a+=", touch: true"),a.a+=", position: ",ise(a,this.o<0?this.o<-2?-2-this.o-1:-1:this.o),a.a+=", notifier: ",O_(a,this.jj()),a.a+=", feature: ",O_(a,this.Kj()),a.a+=", oldValue: ",O_(a,X9e(this)),a.a+=", newValue: ",this.d==6&&De(this.g,53)){for(r=l(this.g,53),a.a+="[",t=0;t10?((!this.b||this.c.j!=this.a)&&(this.b=new U_(this),this.a=this.j),W0(this.b,t)):jE(this,t)},h.Yi=function(){return!0},h.a=0,I(So,"AbstractEList/1",966),D(302,77,she,my),I(So,"AbstractEList/BasicIndexOutOfBoundsException",302),D(37,1,Oa,or),h.Nb=function(t){Za(this,t)},h.Xj=function(){if(this.i.j!=this.f)throw ue(new Xh)},h.Yj=function(){return gr(this)},h.Ob=function(){return this.e!=this.i.gc()},h.Pb=function(){return this.Yj()},h.Qb=function(){jA(this)},h.e=0,h.f=0,h.g=-1,I(So,"AbstractEList/EIterator",37),D(286,37,lg,q8,jae),h.Qb=function(){jA(this)},h.Rb=function(t){D1t(this,t)},h.Zj=function(){var t;try{return t=this.d.Xb(--this.e),this.Xj(),this.g=this.e,t}catch(n){throw n=bs(n),De(n,77)?(this.Xj(),ue(new _c)):ue(n)}},h.$j=function(t){Bdt(this,t)},h.Sb=function(){return this.e!=0},h.Tb=function(){return this.e},h.Ub=function(){return this.Zj()},h.Vb=function(){return this.e-1},h.Wb=function(t){this.$j(t)},I(So,"AbstractEList/EListIterator",286),D(355,37,Oa,H8),h.Yj=function(){return rue(this)},h.Qb=function(){throw ue(new Qr)},I(So,"AbstractEList/NonResolvingEIterator",355),D(398,286,lg,CO,f4e),h.Rb=function(t){throw ue(new Qr)},h.Yj=function(){var t;try{return t=this.c.Vi(this.e),this.Xj(),this.g=this.e++,t}catch(n){throw n=bs(n),De(n,77)?(this.Xj(),ue(new _c)):ue(n)}},h.Zj=function(){var t;try{return t=this.c.Vi(--this.e),this.Xj(),this.g=this.e,t}catch(n){throw n=bs(n),De(n,77)?(this.Xj(),ue(new _c)):ue(n)}},h.Qb=function(){throw ue(new Qr)},h.Wb=function(t){throw ue(new Qr)},I(So,"AbstractEList/NonResolvingEListIterator",398),D(2080,70,Z4t),h.Ei=function(t,n){var r,a,o,f,g,w,E,C,L,B,z;if(o=n.gc(),o!=0){for(C=l(Kn(this.a,4),129),L=C==null?0:C.length,z=L+o,a=Sce(this,z),B=L-t,B>0&&pu(C,t,a,t+o,B),E=n.Kc(),g=0;gr)throw ue(new my(t,r));return new xat(this,t)},h.$b=function(){var t,n;++this.j,t=l(Kn(this.a,4),129),n=t==null?0:t.length,PE(this,null),Noe(this,n,t)},h.Hc=function(t){var n,r,a,o,f;if(n=l(Kn(this.a,4),129),n!=null){if(t!=null){for(a=n,o=0,f=a.length;o=r)throw ue(new my(t,r));return n[t]},h.dd=function(t){var n,r,a;if(n=l(Kn(this.a,4),129),n!=null){if(t!=null){for(r=0,a=n.length;rr)throw ue(new my(t,r));return new yat(this,t)},h.Ti=function(t,n){var r,a,o;if(r=z1t(this),o=r==null?0:r.length,t>=o)throw ue(new tc(Qfe+t+av+o));if(n>=o)throw ue(new tc(Jfe+n+av+o));return a=r[n],t!=n&&(t0&&pu(t,0,n,0,r),n},h.Qc=function(t){var n,r,a;return n=l(Kn(this.a,4),129),a=n==null?0:n.length,a>0&&(t.lengtha&&Ts(t,a,null),t};var M_t;I(So,"ArrayDelegatingEList",2080),D(1051,37,Oa,kut),h.Xj=function(){if(this.b.j!=this.f||qe(l(Kn(this.b.a,4),129))!==qe(this.a))throw ue(new Xh)},h.Qb=function(){jA(this),this.a=l(Kn(this.b.a,4),129)},I(So,"ArrayDelegatingEList/EIterator",1051),D(722,286,lg,Nst,yat),h.Xj=function(){if(this.b.j!=this.f||qe(l(Kn(this.b.a,4),129))!==qe(this.a))throw ue(new Xh)},h.$j=function(t){Bdt(this,t),this.a=l(Kn(this.b.a,4),129)},h.Qb=function(){jA(this),this.a=l(Kn(this.b.a,4),129)},I(So,"ArrayDelegatingEList/EListIterator",722),D(1052,355,Oa,Eut),h.Xj=function(){if(this.b.j!=this.f||qe(l(Kn(this.b.a,4),129))!==qe(this.a))throw ue(new Xh)},I(So,"ArrayDelegatingEList/NonResolvingEIterator",1052),D(723,398,lg,Pst,xat),h.Xj=function(){if(this.b.j!=this.f||qe(l(Kn(this.b.a,4),129))!==qe(this.a))throw ue(new Xh)},I(So,"ArrayDelegatingEList/NonResolvingEListIterator",723),D(615,302,she,Vse),I(So,"BasicEList/BasicIndexOutOfBoundsException",615),D(710,66,Bd,eye),h.bd=function(t,n){throw ue(new Qr)},h.Fc=function(t){throw ue(new Qr)},h.cd=function(t,n){throw ue(new Qr)},h.Gc=function(t){throw ue(new Qr)},h.$b=function(){throw ue(new Qr)},h._i=function(t){throw ue(new Qr)},h.Kc=function(){return this.Ii()},h.ed=function(){return this.Ji()},h.fd=function(t){return this.Ki(t)},h.Ti=function(t,n){throw ue(new Qr)},h.Ui=function(t,n){throw ue(new Qr)},h.gd=function(t){throw ue(new Qr)},h.Mc=function(t){throw ue(new Qr)},h.hd=function(t,n){throw ue(new Qr)},I(So,"BasicEList/UnmodifiableEList",710),D(721,1,{3:1,20:1,16:1,15:1,61:1,597:1}),h.bd=function(t,n){ghn(this,t,l(n,44))},h.Fc=function(t){return ofn(this,l(t,44))},h.Jc=function(t){to(this,t)},h.Xb=function(t){return l(Oe(this.c,t),136)},h.Ti=function(t,n){return l(this.c.Ti(t,n),44)},h.Ui=function(t,n){phn(this,t,l(n,44))},h.Lc=function(){return new bn(null,new kn(this,16))},h.gd=function(t){return l(this.c.gd(t),44)},h.hd=function(t,n){return Mgn(this,t,l(n,44))},h.jd=function(t){$m(this,t)},h.Nc=function(){return new kn(this,16)},h.Oc=function(){return new bn(null,new kn(this,16))},h.cd=function(t,n){return this.c.cd(t,n)},h.Gc=function(t){return this.c.Gc(t)},h.$b=function(){this.c.$b()},h.Hc=function(t){return this.c.Hc(t)},h.Ic=function(t){return EN(this.c,t)},h._j=function(){var t,n,r;if(this.d==null){for(this.d=We(vPe,_Se,66,2*this.f+1,0,1),r=this.e,this.f=0,n=this.c.Kc();n.e!=n.i.gc();)t=l(n.Yj(),136),oU(this,t);this.e=r}},h.Fb=function(t){return cit(this,t)},h.Hb=function(){return M7e(this.c)},h.dd=function(t){return this.c.dd(t)},h.ak=function(){this.c=new hQe(this)},h.dc=function(){return this.f==0},h.Kc=function(){return this.c.Kc()},h.ed=function(){return this.c.ed()},h.fd=function(t){return this.c.fd(t)},h.bk=function(){return iN(this)},h.ck=function(t,n,r){return new xit(t,n,r)},h.dk=function(){return new S$},h.Mc=function(t){return Wht(this,t)},h.gc=function(){return this.f},h.kd=function(t,n){return new Zp(this.c,t,n)},h.Pc=function(){return this.c.Pc()},h.Qc=function(t){return this.c.Qc(t)},h.Ib=function(){return T8e(this.c)},h.e=0,h.f=0,I(So,"BasicEMap",721),D(1046,66,Bd,hQe),h.Mi=function(t,n){Gcn(this,l(n,136))},h.Pi=function(t,n,r){var a;++(a=this,l(n,136),a).a.e},h.Qi=function(t,n){Kcn(this,l(n,136))},h.Ri=function(t,n,r){Ghn(this,l(n,136),l(r,136))},h.Oi=function(t,n){zft(this.a)},I(So,"BasicEMap/1",1046),D(1047,66,Bd,S$),h.aj=function(t){return We(NOn,e5t,621,t,0,1)},I(So,"BasicEMap/2",1047),D(1048,q1,Tl,fQe),h.$b=function(){this.a.c.$b()},h.Hc=function(t){return Kce(this.a,t)},h.Kc=function(){return this.a.f==0?(Fk(),fF.a):new WJe(this.a)},h.Mc=function(t){var n;return n=this.a.f,YV(this.a,t),this.a.f!=n},h.gc=function(){return this.a.f},I(So,"BasicEMap/3",1048),D(1049,31,Wy,dQe),h.$b=function(){this.a.c.$b()},h.Hc=function(t){return Fbt(this.a,t)},h.Kc=function(){return this.a.f==0?(Fk(),fF.a):new YJe(this.a)},h.gc=function(){return this.a.f},I(So,"BasicEMap/4",1049),D(1050,q1,Tl,gQe),h.$b=function(){this.a.c.$b()},h.Hc=function(t){var n,r,a,o,f,g,w,E,C;if(this.a.f>0&&De(t,44)&&(this.a._j(),E=l(t,44),w=E.ld(),o=w==null?0:es(w),f=Qye(this.a,o),n=this.a.d[f],n)){for(r=l(n.g,379),C=n.i,g=0;g"+this.c},h.a=0;var NOn=I(So,"BasicEMap/EntryImpl",621);D(546,1,{},MS),I(So,"BasicEMap/View",546);var fF;D(783,1,{}),h.Fb=function(t){return O9e((Cn(),_o),t)},h.Hb=function(){return q7e((Cn(),_o))},h.Ib=function(){return Tb((Cn(),_o))},I(So,"ECollections/BasicEmptyUnmodifiableEList",783),D(1348,1,lg,Qne),h.Nb=function(t){Za(this,t)},h.Rb=function(t){throw ue(new Qr)},h.Ob=function(){return!1},h.Sb=function(){return!1},h.Pb=function(){throw ue(new _c)},h.Tb=function(){return 0},h.Ub=function(){throw ue(new _c)},h.Vb=function(){return-1},h.Qb=function(){throw ue(new Qr)},h.Wb=function(t){throw ue(new Qr)},I(So,"ECollections/BasicEmptyUnmodifiableEList/1",1348),D(1346,783,{20:1,16:1,15:1,61:1},iJe),h.bd=function(t,n){wZe()},h.Fc=function(t){return yZe()},h.cd=function(t,n){return xZe()},h.Gc=function(t){return kZe()},h.$b=function(){EZe()},h.Hc=function(t){return!1},h.Ic=function(t){return!1},h.Jc=function(t){to(this,t)},h.Xb=function(t){return rye((Cn(),t)),null},h.dd=function(t){return-1},h.dc=function(){return!0},h.Kc=function(){return this.a},h.ed=function(){return this.a},h.fd=function(t){return this.a},h.Ti=function(t,n){return TZe()},h.Ui=function(t,n){CZe()},h.Lc=function(){return new bn(null,new kn(this,16))},h.gd=function(t){return SZe()},h.Mc=function(t){return _Ze()},h.hd=function(t,n){return AZe()},h.gc=function(){return 0},h.jd=function(t){$m(this,t)},h.Nc=function(){return new kn(this,16)},h.Oc=function(){return new bn(null,new kn(this,16))},h.kd=function(t,n){return Cn(),new Zp(_o,t,n)},h.Pc=function(){return e5e((Cn(),_o))},h.Qc=function(t){return Cn(),PA(_o,t)},I(So,"ECollections/EmptyUnmodifiableEList",1346),D(1347,783,{20:1,16:1,15:1,61:1,597:1},sJe),h.bd=function(t,n){wZe()},h.Fc=function(t){return yZe()},h.cd=function(t,n){return xZe()},h.Gc=function(t){return kZe()},h.$b=function(){EZe()},h.Hc=function(t){return!1},h.Ic=function(t){return!1},h.Jc=function(t){to(this,t)},h.Xb=function(t){return rye((Cn(),t)),null},h.dd=function(t){return-1},h.dc=function(){return!0},h.Kc=function(){return this.a},h.ed=function(){return this.a},h.fd=function(t){return this.a},h.Ti=function(t,n){return TZe()},h.Ui=function(t,n){CZe()},h.Lc=function(){return new bn(null,new kn(this,16))},h.gd=function(t){return SZe()},h.Mc=function(t){return _Ze()},h.hd=function(t,n){return AZe()},h.gc=function(){return 0},h.jd=function(t){$m(this,t)},h.Nc=function(){return new kn(this,16)},h.Oc=function(){return new bn(null,new kn(this,16))},h.kd=function(t,n){return Cn(),new Zp(_o,t,n)},h.Pc=function(){return e5e((Cn(),_o))},h.Qc=function(t){return Cn(),PA(_o,t)},h.bk=function(){return Cn(),Cn(),mg},I(So,"ECollections/EmptyUnmodifiableEMap",1347);var yPe=ks(So,"Enumerator"),kY;D(288,1,{288:1},ele),h.Fb=function(t){var n;return this===t?!0:De(t,288)?(n=l(t,288),this.f==n.f&&Gdn(this.i,n.i)&&_ae(this.a,this.f&256?n.f&256?n.a:null:n.f&256?null:n.a)&&_ae(this.d,n.d)&&_ae(this.g,n.g)&&_ae(this.e,n.e)&&b6n(this,n)):!1},h.Hb=function(){return this.f},h.Ib=function(){return bmt(this)},h.f=0;var D_t=0,I_t=0,O_t=0,N_t=0,xPe=0,kPe=0,EPe=0,TPe=0,CPe=0,P_t,$M=0,zM=0,B_t=0,F_t=0,EY,SPe;I(So,"URI",288),D(1121,45,m6,aJe),h.zc=function(t,n){return l(rc(this,ei(t),l(n,288)),288)},I(So,"URI/URICache",1121),D(506,66,Bd,E$,uH),h.Si=function(){return!0},I(So,"UniqueEList",506),D(590,63,lp,nV),I(So,"WrappedException",590);var mi=ks(pf,r5t),M4=ks(pf,i5t),dl=ks(pf,s5t),D4=ks(pf,a5t),l1=ks(pf,o5t),Vf=ks(pf,"EClass"),tpe=ks(pf,"EDataType"),R_t;D(1233,45,m6,oJe),h.xc=function(t){return Ia(t)?xu(this,t):hc(zo(this.f,t))},I(pf,"EDataType/Internal/ConversionDelegate/Factory/Registry/Impl",1233);var TY=ks(pf,"EEnum"),wp=ks(pf,c5t),Wo=ks(pf,u5t),Uf=ks(pf,l5t),Gf,k3=ks(pf,h5t),I4=ks(pf,f5t);D(1042,1,{},Yne),h.Ib=function(){return"NIL"},I(pf,"EStructuralFeature/Internal/DynamicValueHolder/1",1042);var j_t;D(1041,45,m6,cJe),h.xc=function(t){return Ia(t)?xu(this,t):hc(zo(this.f,t))},I(pf,"EStructuralFeature/Internal/SettingDelegate/Factory/Registry/Impl",1041);var Zu=ks(pf,d5t),o9=ks(pf,"EValidator/PatternMatcher"),_Pe,APe,Vn,M2,O4,Jb,$_t,z_t,q_t,Zb,D2,em,E3,td,H_t,V_t,Kf,I2,U_t,O2,N4,o7,No,G_t,K_t,T3,CY=ks(us,"FeatureMap/Entry");D(545,1,{76:1},Sq),h.Lk=function(){return this.a},h.md=function(){return this.b},I(Gn,"BasicEObjectImpl/1",545),D(1040,1,i0e,Itt),h.Fk=function(t){return Moe(this.a,this.b,t)},h.Qj=function(){return got(this.a,this.b)},h.Wb=function(t){q5e(this.a,this.b,t)},h.Gk=function(){Hgn(this.a,this.b)},I(Gn,"BasicEObjectImpl/4",1040),D(2081,1,{114:1}),h.Mk=function(t){this.e=t==0?W_t:We(wa,Rn,1,t,5,1)},h.li=function(t){return this.e[t]},h.mi=function(t,n){this.e[t]=n},h.ni=function(t){this.e[t]=null},h.Nk=function(){return this.c},h.Ok=function(){throw ue(new Qr)},h.Pk=function(){throw ue(new Qr)},h.Qk=function(){return this.d},h.Rk=function(){return this.e!=null},h.Sk=function(t){this.c=t},h.Tk=function(t){throw ue(new Qr)},h.Uk=function(t){throw ue(new Qr)},h.Vk=function(t){this.d=t};var W_t;I(Gn,"BasicEObjectImpl/EPropertiesHolderBaseImpl",2081),D(192,2081,{114:1},Sf),h.Ok=function(){return this.a},h.Pk=function(){return this.b},h.Tk=function(t){this.a=t},h.Uk=function(t){this.b=t},I(Gn,"BasicEObjectImpl/EPropertiesHolderImpl",192),D(516,99,g4t,m5),h.uh=function(){return this.f},h.zh=function(){return this.k},h.Bh=function(t,n){this.g=t,this.i=n},h.Dh=function(){return this.j&2?this.$h().Nk():this.ii()},h.Fh=function(){return this.i},h.wh=function(){return(this.j&1)!=0},h.Ph=function(){return this.g},h.Vh=function(){return(this.j&4)!=0},h.$h=function(){return!this.k&&(this.k=new Sf),this.k},h.ci=function(t){this.$h().Sk(t),t?this.j|=2:this.j&=-3},h.ei=function(t){this.$h().Uk(t),t?this.j|=4:this.j&=-5},h.ii=function(){return(lb(),Vn).S},h.i=0,h.j=1,I(Gn,"EObjectImpl",516),D(798,516,{110:1,94:1,93:1,58:1,114:1,54:1,99:1},F4e),h.li=function(t){return this.e[t]},h.mi=function(t,n){this.e[t]=n},h.ni=function(t){this.e[t]=null},h.Dh=function(){return this.d},h.Ih=function(t){return ms(this.d,t)},h.Kh=function(){return this.d},h.Oh=function(){return this.e!=null},h.$h=function(){return!this.k&&(this.k=new _$),this.k},h.ci=function(t){this.d=t},h.hi=function(){var t;return this.e==null&&(t=yr(this.d),this.e=t==0?Y_t:We(wa,Rn,1,t,5,1)),this},h.ji=function(){return 0};var Y_t;I(Gn,"DynamicEObjectImpl",798),D(1522,798,{110:1,44:1,94:1,93:1,136:1,58:1,114:1,54:1,99:1},Git),h.Fb=function(t){return this===t},h.Hb=function(){return fw(this)},h.ci=function(t){this.d=t,this.b=oP(t,"key"),this.c=oP(t,TL)},h.Bi=function(){var t;return this.a==-1&&(t=Hoe(this,this.b),this.a=t==null?0:es(t)),this.a},h.ld=function(){return Hoe(this,this.b)},h.md=function(){return Hoe(this,this.c)},h.Ci=function(t){this.a=t},h.Di=function(t){q5e(this,this.b,t)},h.nd=function(t){var n;return n=Hoe(this,this.c),q5e(this,this.c,t),n},h.a=0,I(Gn,"DynamicEObjectImpl/BasicEMapEntry",1522),D(1523,1,{114:1},_$),h.Mk=function(t){throw ue(new Qr)},h.li=function(t){throw ue(new Qr)},h.mi=function(t,n){throw ue(new Qr)},h.ni=function(t){throw ue(new Qr)},h.Nk=function(){throw ue(new Qr)},h.Ok=function(){return this.a},h.Pk=function(){return this.b},h.Qk=function(){return this.c},h.Rk=function(){throw ue(new Qr)},h.Sk=function(t){throw ue(new Qr)},h.Tk=function(t){this.a=t},h.Uk=function(t){this.b=t},h.Vk=function(t){this.c=t},I(Gn,"DynamicEObjectImpl/DynamicEPropertiesHolderImpl",1523),D(519,158,{110:1,94:1,93:1,598:1,155:1,58:1,114:1,54:1,99:1,519:1,158:1,119:1,120:1},CI),h.Ah=function(t){return dxe(this,t)},h.Lh=function(t,n,r){var a;switch(t){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),this.Ab;case 1:return this.d;case 2:return r?(!this.b&&(this.b=new dh((Tn(),No),Yc,this)),this.b):(!this.b&&(this.b=new dh((Tn(),No),Yc,this)),iN(this.b));case 3:return wot(this);case 4:return!this.a&&(this.a=new Ys(Xb,this,4)),this.a;case 5:return!this.c&&(this.c=new $5(Xb,this,5)),this.c}return sf(this,t-yr((Tn(),M2)),Mn((a=l(Kn(this,16),29),a||M2),t),n,r)},h.Sh=function(t,n,r){var a,o,f;switch(n){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),Ru(this.Ab,t,r);case 3:return this.Cb&&(r=(o=this.Db>>16,o>=0?dxe(this,r):this.Cb.Th(this,-1-o,null,r))),Z4e(this,l(t,155),r)}return f=l(Mn((a=l(Kn(this,16),29),a||(Tn(),M2)),n),69),f.wk().zk(this,Ku(this),n-yr((Tn(),M2)),t,r)},h.Uh=function(t,n,r){var a,o;switch(n){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),To(this.Ab,t,r);case 2:return!this.b&&(this.b=new dh((Tn(),No),Yc,this)),Uq(this.b,t,r);case 3:return Z4e(this,null,r);case 4:return!this.a&&(this.a=new Ys(Xb,this,4)),To(this.a,t,r)}return o=l(Mn((a=l(Kn(this,16),29),a||(Tn(),M2)),n),69),o.wk().Ak(this,Ku(this),n-yr((Tn(),M2)),t,r)},h.Wh=function(t){var n;switch(t){case 0:return!!this.Ab&&this.Ab.i!=0;case 1:return this.d!=null;case 2:return!!this.b&&this.b.f!=0;case 3:return!!wot(this);case 4:return!!this.a&&this.a.i!=0;case 5:return!!this.c&&this.c.i!=0}return nf(this,t-yr((Tn(),M2)),Mn((n=l(Kn(this,16),29),n||M2),t))},h.bi=function(t,n){var r;switch(t){case 0:!this.Ab&&(this.Ab=new nt(mi,this,0,3)),$r(this.Ab),!this.Ab&&(this.Ab=new nt(mi,this,0,3)),As(this.Ab,l(n,16));return;case 1:Odn(this,ei(n));return;case 2:!this.b&&(this.b=new dh((Tn(),No),Yc,this)),_V(this.b,n);return;case 3:ibt(this,l(n,155));return;case 4:!this.a&&(this.a=new Ys(Xb,this,4)),$r(this.a),!this.a&&(this.a=new Ys(Xb,this,4)),As(this.a,l(n,16));return;case 5:!this.c&&(this.c=new $5(Xb,this,5)),$r(this.c),!this.c&&(this.c=new $5(Xb,this,5)),As(this.c,l(n,16));return}uf(this,t-yr((Tn(),M2)),Mn((r=l(Kn(this,16),29),r||M2),t),n)},h.ii=function(){return Tn(),M2},h.ki=function(t){var n;switch(t){case 0:!this.Ab&&(this.Ab=new nt(mi,this,0,3)),$r(this.Ab);return;case 1:g7e(this,null);return;case 2:!this.b&&(this.b=new dh((Tn(),No),Yc,this)),this.b.c.$b();return;case 3:ibt(this,null);return;case 4:!this.a&&(this.a=new Ys(Xb,this,4)),$r(this.a);return;case 5:!this.c&&(this.c=new $5(Xb,this,5)),$r(this.c);return}cf(this,t-yr((Tn(),M2)),Mn((n=l(Kn(this,16),29),n||M2),t))},h.Ib=function(){return c1t(this)},h.d=null,I(Gn,"EAnnotationImpl",519),D(141,721,ASe,xl),h.Gi=function(t,n){Qln(this,t,l(n,44))},h.Wk=function(t,n){return Zfn(this,l(t,44),n)},h.$i=function(t){return l(l(this.c,71).$i(t),136)},h.Ii=function(){return l(this.c,71).Ii()},h.Ji=function(){return l(this.c,71).Ji()},h.Ki=function(t){return l(this.c,71).Ki(t)},h.Xk=function(t,n){return Uq(this,t,n)},h.Fk=function(t){return l(this.c,79).Fk(t)},h.ak=function(){},h.Qj=function(){return l(this.c,79).Qj()},h.ck=function(t,n,r){var a;return a=l(Ah(this.b).wi().si(this.b),136),a.Ci(t),a.Di(n),a.nd(r),a},h.dk=function(){return new kwe(this)},h.Wb=function(t){_V(this,t)},h.Gk=function(){l(this.c,79).Gk()},I(us,"EcoreEMap",141),D(165,141,ASe,dh),h._j=function(){var t,n,r,a,o,f;if(this.d==null){for(f=We(vPe,_Se,66,2*this.f+1,0,1),r=this.c.Kc();r.e!=r.i.gc();)n=l(r.Yj(),136),a=n.Bi(),o=(a&Ii)%f.length,t=f[o],!t&&(t=f[o]=new kwe(this)),t.Fc(n);this.d=f}},I(Gn,"EAnnotationImpl/1",165),D(292,448,{110:1,94:1,93:1,155:1,197:1,58:1,114:1,481:1,54:1,99:1,158:1,292:1,119:1,120:1}),h.Lh=function(t,n,r){var a,o;switch(t){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),this.Ab;case 1:return this.zb;case 2:return Hn(),!!(this.Bb&256);case 3:return Hn(),!!(this.Bb&512);case 4:return pt(this.s);case 5:return pt(this.t);case 6:return Hn(),!!this.Jk();case 7:return Hn(),o=this.s,o>=1;case 8:return n?Of(this):this.r;case 9:return this.q}return sf(this,t-yr(this.ii()),Mn((a=l(Kn(this,16),29),a||this.ii()),t),n,r)},h.Uh=function(t,n,r){var a,o;switch(n){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),To(this.Ab,t,r);case 9:return qae(this,r)}return o=l(Mn((a=l(Kn(this,16),29),a||this.ii()),n),69),o.wk().Ak(this,Ku(this),n-yr(this.ii()),t,r)},h.Wh=function(t){var n,r;switch(t){case 0:return!!this.Ab&&this.Ab.i!=0;case 1:return this.zb!=null;case 2:return(this.Bb&256)==0;case 3:return(this.Bb&512)==0;case 4:return this.s!=0;case 5:return this.t!=1;case 6:return this.Jk();case 7:return r=this.s,r>=1;case 8:return!!this.r&&!this.q.e&&yw(this.q).i==0;case 9:return!!this.q&&!(this.r&&!this.q.e&&yw(this.q).i==0)}return nf(this,t-yr(this.ii()),Mn((n=l(Kn(this,16),29),n||this.ii()),t))},h.bi=function(t,n){var r,a;switch(t){case 0:!this.Ab&&(this.Ab=new nt(mi,this,0,3)),$r(this.Ab),!this.Ab&&(this.Ab=new nt(mi,this,0,3)),As(this.Ab,l(n,16));return;case 1:this.ui(ei(n));return;case 2:c2(this,Rt(Bt(n)));return;case 3:u2(this,Rt(Bt(n)));return;case 4:i2(this,l(n,17).a);return;case 5:this.Zk(l(n,17).a);return;case 8:Gm(this,l(n,142));return;case 9:a=$1(this,l(n,89),null),a&&a.oj();return}uf(this,t-yr(this.ii()),Mn((r=l(Kn(this,16),29),r||this.ii()),t),n)},h.ii=function(){return Tn(),K_t},h.ki=function(t){var n,r;switch(t){case 0:!this.Ab&&(this.Ab=new nt(mi,this,0,3)),$r(this.Ab);return;case 1:this.ui(null);return;case 2:c2(this,!0);return;case 3:u2(this,!0);return;case 4:i2(this,0);return;case 5:this.Zk(1);return;case 8:Gm(this,null);return;case 9:r=$1(this,null,null),r&&r.oj();return}cf(this,t-yr(this.ii()),Mn((n=l(Kn(this,16),29),n||this.ii()),t))},h.pi=function(){Of(this),this.Bb|=1},h.Hk=function(){return Of(this)},h.Ik=function(){return this.t},h.Jk=function(){var t;return t=this.t,t>1||t==-1},h.Si=function(){return(this.Bb&512)!=0},h.Yk=function(t,n){return o8e(this,t,n)},h.Zk=function(t){My(this,t)},h.Ib=function(){return T9e(this)},h.s=0,h.t=1,I(Gn,"ETypedElementImpl",292),D(462,292,{110:1,94:1,93:1,155:1,197:1,58:1,179:1,69:1,114:1,481:1,54:1,99:1,158:1,462:1,292:1,119:1,120:1,692:1}),h.Ah=function(t){return Qdt(this,t)},h.Lh=function(t,n,r){var a,o;switch(t){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),this.Ab;case 1:return this.zb;case 2:return Hn(),!!(this.Bb&256);case 3:return Hn(),!!(this.Bb&512);case 4:return pt(this.s);case 5:return pt(this.t);case 6:return Hn(),!!this.Jk();case 7:return Hn(),o=this.s,o>=1;case 8:return n?Of(this):this.r;case 9:return this.q;case 10:return Hn(),!!(this.Bb&m0);case 11:return Hn(),!!(this.Bb&r4);case 12:return Hn(),!!(this.Bb&Xy);case 13:return this.j;case 14:return UE(this);case 15:return Hn(),!!(this.Bb&Sl);case 16:return Hn(),!!(this.Bb&_d);case 17:return ky(this)}return sf(this,t-yr(this.ii()),Mn((a=l(Kn(this,16),29),a||this.ii()),t),n,r)},h.Sh=function(t,n,r){var a,o,f;switch(n){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),Ru(this.Ab,t,r);case 17:return this.Cb&&(r=(o=this.Db>>16,o>=0?Qdt(this,r):this.Cb.Th(this,-1-o,null,r))),Nh(this,t,17,r)}return f=l(Mn((a=l(Kn(this,16),29),a||this.ii()),n),69),f.wk().zk(this,Ku(this),n-yr(this.ii()),t,r)},h.Uh=function(t,n,r){var a,o;switch(n){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),To(this.Ab,t,r);case 9:return qae(this,r);case 17:return Nh(this,null,17,r)}return o=l(Mn((a=l(Kn(this,16),29),a||this.ii()),n),69),o.wk().Ak(this,Ku(this),n-yr(this.ii()),t,r)},h.Wh=function(t){var n,r;switch(t){case 0:return!!this.Ab&&this.Ab.i!=0;case 1:return this.zb!=null;case 2:return(this.Bb&256)==0;case 3:return(this.Bb&512)==0;case 4:return this.s!=0;case 5:return this.t!=1;case 6:return this.Jk();case 7:return r=this.s,r>=1;case 8:return!!this.r&&!this.q.e&&yw(this.q).i==0;case 9:return!!this.q&&!(this.r&&!this.q.e&&yw(this.q).i==0);case 10:return(this.Bb&m0)==0;case 11:return(this.Bb&r4)!=0;case 12:return(this.Bb&Xy)!=0;case 13:return this.j!=null;case 14:return UE(this)!=null;case 15:return(this.Bb&Sl)!=0;case 16:return(this.Bb&_d)!=0;case 17:return!!ky(this)}return nf(this,t-yr(this.ii()),Mn((n=l(Kn(this,16),29),n||this.ii()),t))},h.bi=function(t,n){var r,a;switch(t){case 0:!this.Ab&&(this.Ab=new nt(mi,this,0,3)),$r(this.Ab),!this.Ab&&(this.Ab=new nt(mi,this,0,3)),As(this.Ab,l(n,16));return;case 1:poe(this,ei(n));return;case 2:c2(this,Rt(Bt(n)));return;case 3:u2(this,Rt(Bt(n)));return;case 4:i2(this,l(n,17).a);return;case 5:this.Zk(l(n,17).a);return;case 8:Gm(this,l(n,142));return;case 9:a=$1(this,l(n,89),null),a&&a.oj();return;case 10:AE(this,Rt(Bt(n)));return;case 11:DE(this,Rt(Bt(n)));return;case 12:LE(this,Rt(Bt(n)));return;case 13:Z3e(this,ei(n));return;case 15:ME(this,Rt(Bt(n)));return;case 16:IE(this,Rt(Bt(n)));return}uf(this,t-yr(this.ii()),Mn((r=l(Kn(this,16),29),r||this.ii()),t),n)},h.ii=function(){return Tn(),G_t},h.ki=function(t){var n,r;switch(t){case 0:!this.Ab&&(this.Ab=new nt(mi,this,0,3)),$r(this.Ab);return;case 1:De(this.Cb,90)&&zy(Yl(l(this.Cb,90)),4),Fu(this,null);return;case 2:c2(this,!0);return;case 3:u2(this,!0);return;case 4:i2(this,0);return;case 5:this.Zk(1);return;case 8:Gm(this,null);return;case 9:r=$1(this,null,null),r&&r.oj();return;case 10:AE(this,!0);return;case 11:DE(this,!1);return;case 12:LE(this,!1);return;case 13:this.i=null,xV(this,null);return;case 15:ME(this,!1);return;case 16:IE(this,!1);return}cf(this,t-yr(this.ii()),Mn((n=l(Kn(this,16),29),n||this.ii()),t))},h.pi=function(){Wk(ic((El(),io),this)),Of(this),this.Bb|=1},h.pk=function(){return this.f},h.ik=function(){return UE(this)},h.qk=function(){return ky(this)},h.uk=function(){return null},h.$k=function(){return this.k},h.Lj=function(){return this.n},h.vk=function(){return pU(this)},h.wk=function(){var t,n,r,a,o,f,g,w,E;return this.p||(r=ky(this),(r.i==null&&Sd(r),r.i).length,a=this.uk(),a&&yr(ky(a)),o=Of(this),g=o.kk(),t=g?g.i&1?g==ih?Ns:g==Vr?ro:g==B4?_T:g==Na?ta:g==nm?r3:g==h7?i3:g==Al?jx:PL:g:null,n=UE(this),w=o.ik(),K4n(this),this.Bb&_d&&((f=yxe((El(),io),r))&&f!=this||(f=rx(ic(io,this))))?this.p=new Ntt(this,f):this.Jk()?this.al()?a?this.Bb&Sl?t?this.bl()?this.p=new Om(47,t,this,a):this.p=new Om(5,t,this,a):this.bl()?this.p=new Rm(46,this,a):this.p=new Rm(4,this,a):t?this.bl()?this.p=new Om(49,t,this,a):this.p=new Om(7,t,this,a):this.bl()?this.p=new Rm(48,this,a):this.p=new Rm(6,this,a):this.Bb&Sl?t?t==uv?this.p=new Xp(50,A_t,this):this.bl()?this.p=new Xp(43,t,this):this.p=new Xp(1,t,this):this.bl()?this.p=new Jp(42,this):this.p=new Jp(0,this):t?t==uv?this.p=new Xp(41,A_t,this):this.bl()?this.p=new Xp(45,t,this):this.p=new Xp(3,t,this):this.bl()?this.p=new Jp(44,this):this.p=new Jp(2,this):De(o,156)?t==CY?this.p=new Jp(40,this):this.Bb&512?this.Bb&Sl?t?this.p=new Xp(9,t,this):this.p=new Jp(8,this):t?this.p=new Xp(11,t,this):this.p=new Jp(10,this):this.Bb&Sl?t?this.p=new Xp(13,t,this):this.p=new Jp(12,this):t?this.p=new Xp(15,t,this):this.p=new Jp(14,this):a?(E=a.t,E>1||E==-1?this.bl()?this.Bb&Sl?t?this.p=new Om(25,t,this,a):this.p=new Rm(24,this,a):t?this.p=new Om(27,t,this,a):this.p=new Rm(26,this,a):this.Bb&Sl?t?this.p=new Om(29,t,this,a):this.p=new Rm(28,this,a):t?this.p=new Om(31,t,this,a):this.p=new Rm(30,this,a):this.bl()?this.Bb&Sl?t?this.p=new Om(33,t,this,a):this.p=new Rm(32,this,a):t?this.p=new Om(35,t,this,a):this.p=new Rm(34,this,a):this.Bb&Sl?t?this.p=new Om(37,t,this,a):this.p=new Rm(36,this,a):t?this.p=new Om(39,t,this,a):this.p=new Rm(38,this,a)):this.bl()?this.Bb&Sl?t?this.p=new Xp(17,t,this):this.p=new Jp(16,this):t?this.p=new Xp(19,t,this):this.p=new Jp(18,this):this.Bb&Sl?t?this.p=new Xp(21,t,this):this.p=new Jp(20,this):t?this.p=new Xp(23,t,this):this.p=new Jp(22,this):this._k()?this.bl()?this.p=new kit(l(o,29),this,a):this.p=new $5e(l(o,29),this,a):De(o,156)?t==CY?this.p=new Jp(40,this):this.Bb&Sl?t?this.p=new xst(n,w,this,(Wce(),g==Vr?PPe:g==ih?MPe:g==nm?BPe:g==B4?NPe:g==Na?OPe:g==h7?FPe:g==Al?DPe:g==kf?IPe:ipe)):this.p=new Nat(l(o,156),n,w,this):t?this.p=new yst(n,w,this,(Wce(),g==Vr?PPe:g==ih?MPe:g==nm?BPe:g==B4?NPe:g==Na?OPe:g==h7?FPe:g==Al?DPe:g==kf?IPe:ipe)):this.p=new Oat(l(o,156),n,w,this):this.al()?a?this.Bb&Sl?this.bl()?this.p=new Tit(l(o,29),this,a):this.p=new C4e(l(o,29),this,a):this.bl()?this.p=new Eit(l(o,29),this,a):this.p=new yae(l(o,29),this,a):this.Bb&Sl?this.bl()?this.p=new yrt(l(o,29),this):this.p=new jye(l(o,29),this):this.bl()?this.p=new wrt(l(o,29),this):this.p=new oae(l(o,29),this):this.bl()?a?this.Bb&Sl?this.p=new Cit(l(o,29),this,a):this.p=new E4e(l(o,29),this,a):this.Bb&Sl?this.p=new xrt(l(o,29),this):this.p=new $ye(l(o,29),this):a?this.Bb&Sl?this.p=new Sit(l(o,29),this,a):this.p=new T4e(l(o,29),this,a):this.Bb&Sl?this.p=new krt(l(o,29),this):this.p=new cH(l(o,29),this)),this.p},h.rk=function(){return(this.Bb&m0)!=0},h._k=function(){return!1},h.al=function(){return!1},h.sk=function(){return(this.Bb&_d)!=0},h.xk=function(){return Voe(this)},h.bl=function(){return!1},h.tk=function(){return(this.Bb&Sl)!=0},h.cl=function(t){this.k=t},h.ui=function(t){poe(this,t)},h.Ib=function(){return BU(this)},h.e=!1,h.n=0,I(Gn,"EStructuralFeatureImpl",462),D(331,462,{110:1,94:1,93:1,35:1,155:1,197:1,58:1,179:1,69:1,114:1,481:1,54:1,99:1,331:1,158:1,462:1,292:1,119:1,120:1,692:1},zie),h.Lh=function(t,n,r){var a,o;switch(t){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),this.Ab;case 1:return this.zb;case 2:return Hn(),!!(this.Bb&256);case 3:return Hn(),!!(this.Bb&512);case 4:return pt(this.s);case 5:return pt(this.t);case 6:return Hn(),!!v9e(this);case 7:return Hn(),o=this.s,o>=1;case 8:return n?Of(this):this.r;case 9:return this.q;case 10:return Hn(),!!(this.Bb&m0);case 11:return Hn(),!!(this.Bb&r4);case 12:return Hn(),!!(this.Bb&Xy);case 13:return this.j;case 14:return UE(this);case 15:return Hn(),!!(this.Bb&Sl);case 16:return Hn(),!!(this.Bb&_d);case 17:return ky(this);case 18:return Hn(),!!(this.Bb&eu);case 19:return n?gce(this):Fut(this)}return sf(this,t-yr((Tn(),O4)),Mn((a=l(Kn(this,16),29),a||O4),t),n,r)},h.Wh=function(t){var n,r;switch(t){case 0:return!!this.Ab&&this.Ab.i!=0;case 1:return this.zb!=null;case 2:return(this.Bb&256)==0;case 3:return(this.Bb&512)==0;case 4:return this.s!=0;case 5:return this.t!=1;case 6:return v9e(this);case 7:return r=this.s,r>=1;case 8:return!!this.r&&!this.q.e&&yw(this.q).i==0;case 9:return!!this.q&&!(this.r&&!this.q.e&&yw(this.q).i==0);case 10:return(this.Bb&m0)==0;case 11:return(this.Bb&r4)!=0;case 12:return(this.Bb&Xy)!=0;case 13:return this.j!=null;case 14:return UE(this)!=null;case 15:return(this.Bb&Sl)!=0;case 16:return(this.Bb&_d)!=0;case 17:return!!ky(this);case 18:return(this.Bb&eu)!=0;case 19:return!!Fut(this)}return nf(this,t-yr((Tn(),O4)),Mn((n=l(Kn(this,16),29),n||O4),t))},h.bi=function(t,n){var r,a;switch(t){case 0:!this.Ab&&(this.Ab=new nt(mi,this,0,3)),$r(this.Ab),!this.Ab&&(this.Ab=new nt(mi,this,0,3)),As(this.Ab,l(n,16));return;case 1:poe(this,ei(n));return;case 2:c2(this,Rt(Bt(n)));return;case 3:u2(this,Rt(Bt(n)));return;case 4:i2(this,l(n,17).a);return;case 5:JJe(this,l(n,17).a);return;case 8:Gm(this,l(n,142));return;case 9:a=$1(this,l(n,89),null),a&&a.oj();return;case 10:AE(this,Rt(Bt(n)));return;case 11:DE(this,Rt(Bt(n)));return;case 12:LE(this,Rt(Bt(n)));return;case 13:Z3e(this,ei(n));return;case 15:ME(this,Rt(Bt(n)));return;case 16:IE(this,Rt(Bt(n)));return;case 18:$ce(this,Rt(Bt(n)));return}uf(this,t-yr((Tn(),O4)),Mn((r=l(Kn(this,16),29),r||O4),t),n)},h.ii=function(){return Tn(),O4},h.ki=function(t){var n,r;switch(t){case 0:!this.Ab&&(this.Ab=new nt(mi,this,0,3)),$r(this.Ab);return;case 1:De(this.Cb,90)&&zy(Yl(l(this.Cb,90)),4),Fu(this,null);return;case 2:c2(this,!0);return;case 3:u2(this,!0);return;case 4:i2(this,0);return;case 5:this.b=0,My(this,1);return;case 8:Gm(this,null);return;case 9:r=$1(this,null,null),r&&r.oj();return;case 10:AE(this,!0);return;case 11:DE(this,!1);return;case 12:LE(this,!1);return;case 13:this.i=null,xV(this,null);return;case 15:ME(this,!1);return;case 16:IE(this,!1);return;case 18:$ce(this,!1);return}cf(this,t-yr((Tn(),O4)),Mn((n=l(Kn(this,16),29),n||O4),t))},h.pi=function(){gce(this),Wk(ic((El(),io),this)),Of(this),this.Bb|=1},h.Jk=function(){return v9e(this)},h.Yk=function(t,n){return this.b=0,this.a=null,o8e(this,t,n)},h.Zk=function(t){JJe(this,t)},h.Ib=function(){var t;return this.Db&64?BU(this):(t=new Af(BU(this)),t.a+=" (iD: ",Gp(t,(this.Bb&eu)!=0),t.a+=")",t.a)},h.b=0,I(Gn,"EAttributeImpl",331),D(364,448,{110:1,94:1,93:1,142:1,155:1,197:1,58:1,114:1,54:1,99:1,364:1,158:1,119:1,120:1,691:1}),h.dl=function(t){return t.Dh()==this},h.Ah=function(t){return wue(this,t)},h.Bh=function(t,n){this.w=null,this.Db=n<<16|this.Db&255,this.Cb=t},h.Lh=function(t,n,r){var a;switch(t){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),this.Ab;case 1:return this.zb;case 2:return this.D!=null?this.D:this.B;case 3:return zw(this);case 4:return this.ik();case 5:return this.F;case 6:return n?Ah(this):Qk(this);case 7:return!this.A&&(this.A=new ml(Zu,this,7)),this.A}return sf(this,t-yr(this.ii()),Mn((a=l(Kn(this,16),29),a||this.ii()),t),n,r)},h.Sh=function(t,n,r){var a,o,f;switch(n){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),Ru(this.Ab,t,r);case 6:return this.Cb&&(r=(o=this.Db>>16,o>=0?wue(this,r):this.Cb.Th(this,-1-o,null,r))),Nh(this,t,6,r)}return f=l(Mn((a=l(Kn(this,16),29),a||this.ii()),n),69),f.wk().zk(this,Ku(this),n-yr(this.ii()),t,r)},h.Uh=function(t,n,r){var a,o;switch(n){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),To(this.Ab,t,r);case 6:return Nh(this,null,6,r);case 7:return!this.A&&(this.A=new ml(Zu,this,7)),To(this.A,t,r)}return o=l(Mn((a=l(Kn(this,16),29),a||this.ii()),n),69),o.wk().Ak(this,Ku(this),n-yr(this.ii()),t,r)},h.Wh=function(t){var n;switch(t){case 0:return!!this.Ab&&this.Ab.i!=0;case 1:return this.zb!=null;case 2:return this.D!=null&&this.D==this.F;case 3:return!!zw(this);case 4:return this.ik()!=null;case 5:return this.F!=null&&this.F!=this.D&&this.F!=this.B;case 6:return!!Qk(this);case 7:return!!this.A&&this.A.i!=0}return nf(this,t-yr(this.ii()),Mn((n=l(Kn(this,16),29),n||this.ii()),t))},h.bi=function(t,n){var r;switch(t){case 0:!this.Ab&&(this.Ab=new nt(mi,this,0,3)),$r(this.Ab),!this.Ab&&(this.Ab=new nt(mi,this,0,3)),As(this.Ab,l(n,16));return;case 1:FH(this,ei(n));return;case 2:Kse(this,ei(n));return;case 5:JE(this,ei(n));return;case 7:!this.A&&(this.A=new ml(Zu,this,7)),$r(this.A),!this.A&&(this.A=new ml(Zu,this,7)),As(this.A,l(n,16));return}uf(this,t-yr(this.ii()),Mn((r=l(Kn(this,16),29),r||this.ii()),t),n)},h.ii=function(){return Tn(),$_t},h.ki=function(t){var n;switch(t){case 0:!this.Ab&&(this.Ab=new nt(mi,this,0,3)),$r(this.Ab);return;case 1:De(this.Cb,184)&&(l(this.Cb,184).tb=null),Fu(this,null);return;case 2:CE(this,null),lE(this,this.D);return;case 5:JE(this,null);return;case 7:!this.A&&(this.A=new ml(Zu,this,7)),$r(this.A);return}cf(this,t-yr(this.ii()),Mn((n=l(Kn(this,16),29),n||this.ii()),t))},h.hk=function(){var t;return this.G==-1&&(this.G=(t=Ah(this),t?f2(t.vi(),this):-1)),this.G},h.ik=function(){return null},h.jk=function(){return Ah(this)},h.el=function(){return this.v},h.kk=function(){return zw(this)},h.lk=function(){return this.D!=null?this.D:this.B},h.mk=function(){return this.F},h.fk=function(t){return ule(this,t)},h.fl=function(t){this.v=t},h.gl=function(t){xft(this,t)},h.hl=function(t){this.C=t},h.ui=function(t){FH(this,t)},h.Ib=function(){return UV(this)},h.C=null,h.D=null,h.G=-1,I(Gn,"EClassifierImpl",364),D(90,364,{110:1,94:1,93:1,29:1,142:1,155:1,197:1,58:1,114:1,54:1,99:1,90:1,364:1,158:1,482:1,119:1,120:1,691:1},hz),h.dl=function(t){return Bfn(this,t.Dh())},h.Lh=function(t,n,r){var a;switch(t){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),this.Ab;case 1:return this.zb;case 2:return this.D!=null?this.D:this.B;case 3:return zw(this);case 4:return null;case 5:return this.F;case 6:return n?Ah(this):Qk(this);case 7:return!this.A&&(this.A=new ml(Zu,this,7)),this.A;case 8:return Hn(),!!(this.Bb&256);case 9:return Hn(),!!(this.Bb&512);case 10:return dc(this);case 11:return!this.q&&(this.q=new nt(Uf,this,11,10)),this.q;case 12:return d6(this);case 13:return JA(this);case 14:return JA(this),this.r;case 15:return d6(this),this.k;case 16:return o9e(this);case 17:return dle(this);case 18:return Sd(this);case 19:return _U(this);case 20:return d6(this),this.o;case 21:return!this.s&&(this.s=new nt(dl,this,21,17)),this.s;case 22:return du(this);case 23:return Zue(this)}return sf(this,t-yr((Tn(),Jb)),Mn((a=l(Kn(this,16),29),a||Jb),t),n,r)},h.Sh=function(t,n,r){var a,o,f;switch(n){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),Ru(this.Ab,t,r);case 6:return this.Cb&&(r=(o=this.Db>>16,o>=0?wue(this,r):this.Cb.Th(this,-1-o,null,r))),Nh(this,t,6,r);case 11:return!this.q&&(this.q=new nt(Uf,this,11,10)),Ru(this.q,t,r);case 21:return!this.s&&(this.s=new nt(dl,this,21,17)),Ru(this.s,t,r)}return f=l(Mn((a=l(Kn(this,16),29),a||(Tn(),Jb)),n),69),f.wk().zk(this,Ku(this),n-yr((Tn(),Jb)),t,r)},h.Uh=function(t,n,r){var a,o;switch(n){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),To(this.Ab,t,r);case 6:return Nh(this,null,6,r);case 7:return!this.A&&(this.A=new ml(Zu,this,7)),To(this.A,t,r);case 11:return!this.q&&(this.q=new nt(Uf,this,11,10)),To(this.q,t,r);case 21:return!this.s&&(this.s=new nt(dl,this,21,17)),To(this.s,t,r);case 22:return To(du(this),t,r)}return o=l(Mn((a=l(Kn(this,16),29),a||(Tn(),Jb)),n),69),o.wk().Ak(this,Ku(this),n-yr((Tn(),Jb)),t,r)},h.Wh=function(t){var n;switch(t){case 0:return!!this.Ab&&this.Ab.i!=0;case 1:return this.zb!=null;case 2:return this.D!=null&&this.D==this.F;case 3:return!!zw(this);case 4:return!1;case 5:return this.F!=null&&this.F!=this.D&&this.F!=this.B;case 6:return!!Qk(this);case 7:return!!this.A&&this.A.i!=0;case 8:return(this.Bb&256)!=0;case 9:return(this.Bb&512)!=0;case 10:return!!this.u&&du(this.u.a).i!=0&&!(this.n&&cue(this.n));case 11:return!!this.q&&this.q.i!=0;case 12:return d6(this).i!=0;case 13:return JA(this).i!=0;case 14:return JA(this),this.r.i!=0;case 15:return d6(this),this.k.i!=0;case 16:return o9e(this).i!=0;case 17:return dle(this).i!=0;case 18:return Sd(this).i!=0;case 19:return _U(this).i!=0;case 20:return d6(this),!!this.o;case 21:return!!this.s&&this.s.i!=0;case 22:return!!this.n&&cue(this.n);case 23:return Zue(this).i!=0}return nf(this,t-yr((Tn(),Jb)),Mn((n=l(Kn(this,16),29),n||Jb),t))},h.Zh=function(t){var n;return n=this.i==null||this.q&&this.q.i!=0?null:oP(this,t),n||Hke(this,t)},h.bi=function(t,n){var r;switch(t){case 0:!this.Ab&&(this.Ab=new nt(mi,this,0,3)),$r(this.Ab),!this.Ab&&(this.Ab=new nt(mi,this,0,3)),As(this.Ab,l(n,16));return;case 1:FH(this,ei(n));return;case 2:Kse(this,ei(n));return;case 5:JE(this,ei(n));return;case 7:!this.A&&(this.A=new ml(Zu,this,7)),$r(this.A),!this.A&&(this.A=new ml(Zu,this,7)),As(this.A,l(n,16));return;case 8:c8e(this,Rt(Bt(n)));return;case 9:u8e(this,Rt(Bt(n)));return;case 10:tL(dc(this)),As(dc(this),l(n,16));return;case 11:!this.q&&(this.q=new nt(Uf,this,11,10)),$r(this.q),!this.q&&(this.q=new nt(Uf,this,11,10)),As(this.q,l(n,16));return;case 21:!this.s&&(this.s=new nt(dl,this,21,17)),$r(this.s),!this.s&&(this.s=new nt(dl,this,21,17)),As(this.s,l(n,16));return;case 22:$r(du(this)),As(du(this),l(n,16));return}uf(this,t-yr((Tn(),Jb)),Mn((r=l(Kn(this,16),29),r||Jb),t),n)},h.ii=function(){return Tn(),Jb},h.ki=function(t){var n;switch(t){case 0:!this.Ab&&(this.Ab=new nt(mi,this,0,3)),$r(this.Ab);return;case 1:De(this.Cb,184)&&(l(this.Cb,184).tb=null),Fu(this,null);return;case 2:CE(this,null),lE(this,this.D);return;case 5:JE(this,null);return;case 7:!this.A&&(this.A=new ml(Zu,this,7)),$r(this.A);return;case 8:c8e(this,!1);return;case 9:u8e(this,!1);return;case 10:this.u&&tL(this.u);return;case 11:!this.q&&(this.q=new nt(Uf,this,11,10)),$r(this.q);return;case 21:!this.s&&(this.s=new nt(dl,this,21,17)),$r(this.s);return;case 22:this.n&&$r(this.n);return}cf(this,t-yr((Tn(),Jb)),Mn((n=l(Kn(this,16),29),n||Jb),t))},h.pi=function(){var t,n;if(d6(this),JA(this),o9e(this),dle(this),Sd(this),_U(this),Zue(this),uA(cdn(Yl(this))),this.s)for(t=0,n=this.s.i;t=0;--n)Oe(this,n);return O8e(this,t)},h.Gk=function(){$r(this)},h.Zi=function(t,n){return Hht(this,t,n)},I(us,"EcoreEList",632),D(505,632,kc,FO),h.Li=function(){return!1},h.Lj=function(){return this.c},h.Mj=function(){return!1},h.ol=function(){return!0},h.Si=function(){return!0},h.Wi=function(t,n){return n},h.Yi=function(){return!1},h.c=0,I(us,"EObjectEList",505),D(83,505,kc,Ys),h.Mj=function(){return!0},h.ml=function(){return!1},h.al=function(){return!0},I(us,"EObjectContainmentEList",83),D(555,83,kc,Bq),h.Ni=function(){this.b=!0},h.Qj=function(){return this.b},h.Gk=function(){var t;$r(this),hh(this.e)?(t=this.b,this.b=!1,Ni(this.e,new h0(this.e,2,this.c,t,!1))):this.b=!1},h.b=!1,I(us,"EObjectContainmentEList/Unsettable",555),D(1161,555,kc,vst),h.Ti=function(t,n){var r,a;return r=l(AA(this,t,n),89),hh(this.e)&&xk(this,new sN(this.a,7,(Tn(),z_t),pt(n),(a=r.c,De(a,90)?l(a,29):Kf),t)),r},h.Uj=function(t,n){return L5n(this,l(t,89),n)},h.Vj=function(t,n){return A5n(this,l(t,89),n)},h.Wj=function(t,n,r){return I8n(this,l(t,89),l(n,89),r)},h.Ij=function(t,n,r,a,o){switch(t){case 3:return rA(this,t,n,r,a,this.i>1);case 5:return rA(this,t,n,r,a,this.i-l(r,15).gc()>0);default:return new Zg(this.e,t,this.c,n,r,a,!0)}},h.Tj=function(){return!0},h.Qj=function(){return cue(this)},h.Gk=function(){$r(this)},I(Gn,"EClassImpl/1",1161),D(1175,1174,SSe),h.dj=function(t){var n,r,a,o,f,g,w;if(r=t.gj(),r!=8){if(a=l6n(t),a==0)switch(r){case 1:case 9:{w=t.kj(),w!=null&&(n=Yl(l(w,482)),!n.c&&(n.c=new Xd),sV(n.c,t.jj())),g=t.ij(),g!=null&&(o=l(g,482),o.Bb&1||(n=Yl(o),!n.c&&(n.c=new Xd),qr(n.c,l(t.jj(),29))));break}case 3:{g=t.ij(),g!=null&&(o=l(g,482),o.Bb&1||(n=Yl(o),!n.c&&(n.c=new Xd),qr(n.c,l(t.jj(),29))));break}case 5:{if(g=t.ij(),g!=null)for(f=l(g,16).Kc();f.Ob();)o=l(f.Pb(),482),o.Bb&1||(n=Yl(o),!n.c&&(n.c=new Xd),qr(n.c,l(t.jj(),29)));break}case 4:{w=t.kj(),w!=null&&(o=l(w,482),o.Bb&1||(n=Yl(o),!n.c&&(n.c=new Xd),sV(n.c,t.jj())));break}case 6:{if(w=t.kj(),w!=null)for(f=l(w,16).Kc();f.Ob();)o=l(f.Pb(),482),o.Bb&1||(n=Yl(o),!n.c&&(n.c=new Xd),sV(n.c,t.jj()));break}}this.ql(a)}},h.ql=function(t){Vbt(this,t)},h.b=63,I(Gn,"ESuperAdapter",1175),D(1176,1175,SSe,bQe),h.ql=function(t){zy(this,t)},I(Gn,"EClassImpl/10",1176),D(1165,710,kc),h.Ei=function(t,n){return Due(this,t,n)},h.Fi=function(t){return Odt(this,t)},h.Gi=function(t,n){IN(this,t,n)},h.Hi=function(t){tN(this,t)},h.$i=function(t){return R6e(this,t)},h.Xi=function(t,n){return Uoe(this,t,n)},h.Wk=function(t,n){throw ue(new Qr)},h.Ii=function(){return new H8(this)},h.Ji=function(){return new CO(this)},h.Ki=function(t){return mN(this,t)},h.Xk=function(t,n){throw ue(new Qr)},h.Fk=function(t){return this},h.Qj=function(){return this.i!=0},h.Wb=function(t){throw ue(new Qr)},h.Gk=function(){throw ue(new Qr)},I(us,"EcoreEList/UnmodifiableEList",1165),D(328,1165,kc,N5),h.Yi=function(){return!1},I(us,"EcoreEList/UnmodifiableEList/FastCompare",328),D(1168,328,kc,g0t),h.dd=function(t){var n,r,a;if(De(t,179)&&(n=l(t,179),r=n.Lj(),r!=-1)){for(a=this.i;r4)if(this.fk(t)){if(this.al()){if(a=l(t,54),r=a.Eh(),w=r==this.b&&(this.ml()?a.yh(a.Fh(),l(Mn(sl(this.b),this.Lj()).Hk(),29).kk())==Ro(l(Mn(sl(this.b),this.Lj()),19)).n:-1-a.Fh()==this.Lj()),this.nl()&&!w&&!r&&a.Jh()){for(o=0;o1||a==-1)):!1},h.ml=function(){var t,n,r;return n=Mn(sl(this.b),this.Lj()),De(n,102)?(t=l(n,19),r=Ro(t),!!r):!1},h.nl=function(){var t,n;return n=Mn(sl(this.b),this.Lj()),De(n,102)?(t=l(n,19),(t.Bb&Io)!=0):!1},h.dd=function(t){var n,r,a,o;if(a=this.zj(t),a>=0)return a;if(this.ol()){for(r=0,o=this.Ej();r=0;--t)mP(this,t,this.xj(t));return this.Fj()},h.Qc=function(t){var n;if(this.nl())for(n=this.Ej()-1;n>=0;--n)mP(this,n,this.xj(n));return this.Gj(t)},h.Gk=function(){tL(this)},h.Zi=function(t,n){return ylt(this,t,n)},I(us,"DelegatingEcoreEList",756),D(1171,756,MSe,Nrt),h.qj=function(t,n){afn(this,t,l(n,29))},h.rj=function(t){Wln(this,l(t,29))},h.xj=function(t){var n,r;return n=l(Oe(du(this.a),t),89),r=n.c,De(r,90)?l(r,29):(Tn(),Kf)},h.Cj=function(t){var n,r;return n=l(Vy(du(this.a),t),89),r=n.c,De(r,90)?l(r,29):(Tn(),Kf)},h.Dj=function(t,n){return r7n(this,t,l(n,29))},h.Li=function(){return!1},h.Ij=function(t,n,r,a,o){return null},h.sj=function(){return new wQe(this)},h.tj=function(){$r(du(this.a))},h.uj=function(t){return l1t(this,t)},h.vj=function(t){var n,r;for(r=t.Kc();r.Ob();)if(n=r.Pb(),!l1t(this,n))return!1;return!0},h.wj=function(t){var n,r,a;if(De(t,15)&&(a=l(t,15),a.gc()==du(this.a).i)){for(n=a.Kc(),r=new or(this);n.Ob();)if(qe(n.Pb())!==qe(gr(r)))return!1;return!0}return!1},h.yj=function(){var t,n,r,a,o;for(r=1,n=new or(du(this.a));n.e!=n.i.gc();)t=l(gr(n),89),a=(o=t.c,De(o,90)?l(o,29):(Tn(),Kf)),r=31*r+(a?fw(a):0);return r},h.zj=function(t){var n,r,a,o;for(a=0,r=new or(du(this.a));r.e!=r.i.gc();){if(n=l(gr(r),89),qe(t)===qe((o=n.c,De(o,90)?l(o,29):(Tn(),Kf))))return a;++a}return-1},h.Aj=function(){return du(this.a).i==0},h.Bj=function(){return null},h.Ej=function(){return du(this.a).i},h.Fj=function(){var t,n,r,a,o,f;for(f=du(this.a).i,o=We(wa,Rn,1,f,5,1),r=0,n=new or(du(this.a));n.e!=n.i.gc();)t=l(gr(n),89),o[r++]=(a=t.c,De(a,90)?l(a,29):(Tn(),Kf));return o},h.Gj=function(t){var n,r,a,o,f,g,w;for(w=du(this.a).i,t.lengthw&&Ts(t,w,null),a=0,r=new or(du(this.a));r.e!=r.i.gc();)n=l(gr(r),89),f=(g=n.c,De(g,90)?l(g,29):(Tn(),Kf)),Ts(t,a++,f);return t},h.Hj=function(){var t,n,r,a,o;for(o=new Up,o.a+="[",t=du(this.a),n=0,a=du(this.a).i;n>16,o>=0?wue(this,r):this.Cb.Th(this,-1-o,null,r))),Nh(this,t,6,r);case 9:return!this.a&&(this.a=new nt(wp,this,9,5)),Ru(this.a,t,r)}return f=l(Mn((a=l(Kn(this,16),29),a||(Tn(),Zb)),n),69),f.wk().zk(this,Ku(this),n-yr((Tn(),Zb)),t,r)},h.Uh=function(t,n,r){var a,o;switch(n){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),To(this.Ab,t,r);case 6:return Nh(this,null,6,r);case 7:return!this.A&&(this.A=new ml(Zu,this,7)),To(this.A,t,r);case 9:return!this.a&&(this.a=new nt(wp,this,9,5)),To(this.a,t,r)}return o=l(Mn((a=l(Kn(this,16),29),a||(Tn(),Zb)),n),69),o.wk().Ak(this,Ku(this),n-yr((Tn(),Zb)),t,r)},h.Wh=function(t){var n;switch(t){case 0:return!!this.Ab&&this.Ab.i!=0;case 1:return this.zb!=null;case 2:return this.D!=null&&this.D==this.F;case 3:return!!zw(this);case 4:return!!X7e(this);case 5:return this.F!=null&&this.F!=this.D&&this.F!=this.B;case 6:return!!Qk(this);case 7:return!!this.A&&this.A.i!=0;case 8:return(this.Bb&256)==0;case 9:return!!this.a&&this.a.i!=0}return nf(this,t-yr((Tn(),Zb)),Mn((n=l(Kn(this,16),29),n||Zb),t))},h.bi=function(t,n){var r;switch(t){case 0:!this.Ab&&(this.Ab=new nt(mi,this,0,3)),$r(this.Ab),!this.Ab&&(this.Ab=new nt(mi,this,0,3)),As(this.Ab,l(n,16));return;case 1:FH(this,ei(n));return;case 2:Kse(this,ei(n));return;case 5:JE(this,ei(n));return;case 7:!this.A&&(this.A=new ml(Zu,this,7)),$r(this.A),!this.A&&(this.A=new ml(Zu,this,7)),As(this.A,l(n,16));return;case 8:jV(this,Rt(Bt(n)));return;case 9:!this.a&&(this.a=new nt(wp,this,9,5)),$r(this.a),!this.a&&(this.a=new nt(wp,this,9,5)),As(this.a,l(n,16));return}uf(this,t-yr((Tn(),Zb)),Mn((r=l(Kn(this,16),29),r||Zb),t),n)},h.ii=function(){return Tn(),Zb},h.ki=function(t){var n;switch(t){case 0:!this.Ab&&(this.Ab=new nt(mi,this,0,3)),$r(this.Ab);return;case 1:De(this.Cb,184)&&(l(this.Cb,184).tb=null),Fu(this,null);return;case 2:CE(this,null),lE(this,this.D);return;case 5:JE(this,null);return;case 7:!this.A&&(this.A=new ml(Zu,this,7)),$r(this.A);return;case 8:jV(this,!0);return;case 9:!this.a&&(this.a=new nt(wp,this,9,5)),$r(this.a);return}cf(this,t-yr((Tn(),Zb)),Mn((n=l(Kn(this,16),29),n||Zb),t))},h.pi=function(){var t,n;if(this.a)for(t=0,n=this.a.i;t>16==5?l(this.Cb,685):null}return sf(this,t-yr((Tn(),D2)),Mn((a=l(Kn(this,16),29),a||D2),t),n,r)},h.Sh=function(t,n,r){var a,o,f;switch(n){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),Ru(this.Ab,t,r);case 5:return this.Cb&&(r=(o=this.Db>>16,o>=0?agt(this,r):this.Cb.Th(this,-1-o,null,r))),Nh(this,t,5,r)}return f=l(Mn((a=l(Kn(this,16),29),a||(Tn(),D2)),n),69),f.wk().zk(this,Ku(this),n-yr((Tn(),D2)),t,r)},h.Uh=function(t,n,r){var a,o;switch(n){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),To(this.Ab,t,r);case 5:return Nh(this,null,5,r)}return o=l(Mn((a=l(Kn(this,16),29),a||(Tn(),D2)),n),69),o.wk().Ak(this,Ku(this),n-yr((Tn(),D2)),t,r)},h.Wh=function(t){var n;switch(t){case 0:return!!this.Ab&&this.Ab.i!=0;case 1:return this.zb!=null;case 2:return this.d!=0;case 3:return!!this.b;case 4:return this.c!=null;case 5:return!!(this.Db>>16==5&&l(this.Cb,685))}return nf(this,t-yr((Tn(),D2)),Mn((n=l(Kn(this,16),29),n||D2),t))},h.bi=function(t,n){var r;switch(t){case 0:!this.Ab&&(this.Ab=new nt(mi,this,0,3)),$r(this.Ab),!this.Ab&&(this.Ab=new nt(mi,this,0,3)),As(this.Ab,l(n,16));return;case 1:Fu(this,ei(n));return;case 2:Qoe(this,l(n,17).a);return;case 3:r2t(this,l(n,2039));return;case 4:Zoe(this,ei(n));return}uf(this,t-yr((Tn(),D2)),Mn((r=l(Kn(this,16),29),r||D2),t),n)},h.ii=function(){return Tn(),D2},h.ki=function(t){var n;switch(t){case 0:!this.Ab&&(this.Ab=new nt(mi,this,0,3)),$r(this.Ab);return;case 1:Fu(this,null);return;case 2:Qoe(this,0);return;case 3:r2t(this,null);return;case 4:Zoe(this,null);return}cf(this,t-yr((Tn(),D2)),Mn((n=l(Kn(this,16),29),n||D2),t))},h.Ib=function(){var t;return t=this.c,t??this.zb},h.b=null,h.c=null,h.d=0,I(Gn,"EEnumLiteralImpl",582);var POn=ks(Gn,"EFactoryImpl/InternalEDateTimeFormat");D(499,1,{2114:1},KI),I(Gn,"EFactoryImpl/1ClientInternalEDateTimeFormat",499),D(248,120,{110:1,94:1,93:1,89:1,58:1,114:1,54:1,99:1,248:1,119:1,120:1},Qv),h.Ch=function(t,n,r){var a;return r=Nh(this,t,n,r),this.e&&De(t,179)&&(a=SU(this,this.e),a!=this.c&&(r=ZE(this,a,r))),r},h.Lh=function(t,n,r){var a;switch(t){case 0:return this.f;case 1:return!this.d&&(this.d=new Ys(Wo,this,1)),this.d;case 2:return n?jU(this):this.c;case 3:return this.b;case 4:return this.e;case 5:return n?hue(this):this.a}return sf(this,t-yr((Tn(),E3)),Mn((a=l(Kn(this,16),29),a||E3),t),n,r)},h.Uh=function(t,n,r){var a,o;switch(n){case 0:return Q0t(this,null,r);case 1:return!this.d&&(this.d=new Ys(Wo,this,1)),To(this.d,t,r);case 3:return J0t(this,null,r)}return o=l(Mn((a=l(Kn(this,16),29),a||(Tn(),E3)),n),69),o.wk().Ak(this,Ku(this),n-yr((Tn(),E3)),t,r)},h.Wh=function(t){var n;switch(t){case 0:return!!this.f;case 1:return!!this.d&&this.d.i!=0;case 2:return!!this.c;case 3:return!!this.b;case 4:return!!this.e;case 5:return!!this.a}return nf(this,t-yr((Tn(),E3)),Mn((n=l(Kn(this,16),29),n||E3),t))},h.bi=function(t,n){var r;switch(t){case 0:Cgt(this,l(n,89));return;case 1:!this.d&&(this.d=new Ys(Wo,this,1)),$r(this.d),!this.d&&(this.d=new Ys(Wo,this,1)),As(this.d,l(n,16));return;case 3:Axe(this,l(n,89));return;case 4:Kxe(this,l(n,850));return;case 5:sE(this,l(n,142));return}uf(this,t-yr((Tn(),E3)),Mn((r=l(Kn(this,16),29),r||E3),t),n)},h.ii=function(){return Tn(),E3},h.ki=function(t){var n;switch(t){case 0:Cgt(this,null);return;case 1:!this.d&&(this.d=new Ys(Wo,this,1)),$r(this.d);return;case 3:Axe(this,null);return;case 4:Kxe(this,null);return;case 5:sE(this,null);return}cf(this,t-yr((Tn(),E3)),Mn((n=l(Kn(this,16),29),n||E3),t))},h.Ib=function(){var t;return t=new Th(g0(this)),t.a+=" (expression: ",wle(this,t),t.a+=")",t.a};var LPe;I(Gn,"EGenericTypeImpl",248),D(2067,2062,KG),h.Gi=function(t,n){Drt(this,t,n)},h.Wk=function(t,n){return Drt(this,this.gc(),t),n},h.$i=function(t){return ff(this.pj(),t)},h.Ii=function(){return this.Ji()},h.pj=function(){return new EQe(this)},h.Ji=function(){return this.Ki(0)},h.Ki=function(t){return this.pj().fd(t)},h.Xk=function(t,n){return Ny(this,t,!0),n},h.Ti=function(t,n){var r,a;return a=kue(this,n),r=this.fd(t),r.Rb(a),a},h.Ui=function(t,n){var r;Ny(this,n,!0),r=this.fd(t),r.Rb(n)},I(us,"AbstractSequentialInternalEList",2067),D(496,2067,KG,TO),h.$i=function(t){return ff(this.pj(),t)},h.Ii=function(){return this.b==null?(Wp(),Wp(),dF):this.sl()},h.pj=function(){return new Xtt(this.a,this.b)},h.Ji=function(){return this.b==null?(Wp(),Wp(),dF):this.sl()},h.Ki=function(t){var n,r;if(this.b==null){if(t<0||t>1)throw ue(new tc(CL+t+", size=0"));return Wp(),Wp(),dF}for(r=this.sl(),n=0;n0;)if(n=this.c[--this.d],(!this.e||n.pk()!=oC||n.Lj()!=0)&&(!this.vl()||this.b.Xh(n))){if(f=this.b.Nh(n,this.ul()),this.f=(Fo(),l(n,69).xk()),this.f||n.Jk()){if(this.ul()?(a=l(f,15),this.k=a):(a=l(f,71),this.k=this.j=a),De(this.k,59)?(this.o=this.k.gc(),this.n=this.o):this.p=this.j?this.j.Ki(this.k.gc()):this.k.fd(this.k.gc()),this.p?wpt(this,this.p):Mpt(this))return o=this.p?this.p.Ub():this.j?this.j.$i(--this.n):this.k.Xb(--this.n),this.f?(t=l(o,76),t.Lk(),r=t.md(),this.i=r):(r=o,this.i=r),this.g=-3,!0}else if(f!=null)return this.k=null,this.p=null,r=f,this.i=r,this.g=-2,!0}return this.k=null,this.p=null,this.g=-1,!1}else return o=this.p?this.p.Ub():this.j?this.j.$i(--this.n):this.k.Xb(--this.n),this.f?(t=l(o,76),t.Lk(),r=t.md(),this.i=r):(r=o,this.i=r),this.g=-3,!0}},h.Pb=function(){return MV(this)},h.Tb=function(){return this.a},h.Ub=function(){var t;if(this.g<-1||this.Sb())return--this.a,this.g=0,t=this.i,this.Sb(),t;throw ue(new _c)},h.Vb=function(){return this.a-1},h.Qb=function(){throw ue(new Qr)},h.ul=function(){return!1},h.Wb=function(t){throw ue(new Qr)},h.vl=function(){return!0},h.a=0,h.d=0,h.f=!1,h.g=0,h.n=0,h.o=0;var dF;I(us,"EContentsEList/FeatureIteratorImpl",287),D(711,287,WG,Rye),h.ul=function(){return!0},I(us,"EContentsEList/ResolvingFeatureIteratorImpl",711),D(1178,711,WG,brt),h.vl=function(){return!1},I(Gn,"ENamedElementImpl/1/1",1178),D(1179,287,WG,mrt),h.vl=function(){return!1},I(Gn,"ENamedElementImpl/1/2",1179),D(39,152,YP,Cy,koe,_a,Foe,Zg,h0,Q6e,Xot,J6e,Qot,p6e,Jot,t7e,Zot,b6e,ect,Z6e,tct,X_,sN,roe,e7e,nct,m6e,rct),h.Kj=function(){return N6e(this)},h.Rj=function(){var t;return t=N6e(this),t?t.ik():null},h.hj=function(t){return this.b==-1&&this.a&&(this.b=this.c.Hh(this.a.Lj(),this.a.pk())),this.c.yh(this.b,t)},h.jj=function(){return this.c},h.Sj=function(){var t;return t=N6e(this),t?t.tk():!1},h.b=-1,I(Gn,"ENotificationImpl",39),D(411,292,{110:1,94:1,93:1,155:1,197:1,58:1,62:1,114:1,481:1,54:1,99:1,158:1,411:1,292:1,119:1,120:1},qie),h.Ah=function(t){return ugt(this,t)},h.Lh=function(t,n,r){var a,o,f;switch(t){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),this.Ab;case 1:return this.zb;case 2:return Hn(),!!(this.Bb&256);case 3:return Hn(),!!(this.Bb&512);case 4:return pt(this.s);case 5:return pt(this.t);case 6:return Hn(),f=this.t,f>1||f==-1;case 7:return Hn(),o=this.s,o>=1;case 8:return n?Of(this):this.r;case 9:return this.q;case 10:return this.Db>>16==10?l(this.Cb,29):null;case 11:return!this.d&&(this.d=new ml(Zu,this,11)),this.d;case 12:return!this.c&&(this.c=new nt(k3,this,12,10)),this.c;case 13:return!this.a&&(this.a=new LO(this,this)),this.a;case 14:return Xl(this)}return sf(this,t-yr((Tn(),I2)),Mn((a=l(Kn(this,16),29),a||I2),t),n,r)},h.Sh=function(t,n,r){var a,o,f;switch(n){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),Ru(this.Ab,t,r);case 10:return this.Cb&&(r=(o=this.Db>>16,o>=0?ugt(this,r):this.Cb.Th(this,-1-o,null,r))),Nh(this,t,10,r);case 12:return!this.c&&(this.c=new nt(k3,this,12,10)),Ru(this.c,t,r)}return f=l(Mn((a=l(Kn(this,16),29),a||(Tn(),I2)),n),69),f.wk().zk(this,Ku(this),n-yr((Tn(),I2)),t,r)},h.Uh=function(t,n,r){var a,o;switch(n){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),To(this.Ab,t,r);case 9:return qae(this,r);case 10:return Nh(this,null,10,r);case 11:return!this.d&&(this.d=new ml(Zu,this,11)),To(this.d,t,r);case 12:return!this.c&&(this.c=new nt(k3,this,12,10)),To(this.c,t,r);case 14:return To(Xl(this),t,r)}return o=l(Mn((a=l(Kn(this,16),29),a||(Tn(),I2)),n),69),o.wk().Ak(this,Ku(this),n-yr((Tn(),I2)),t,r)},h.Wh=function(t){var n,r,a;switch(t){case 0:return!!this.Ab&&this.Ab.i!=0;case 1:return this.zb!=null;case 2:return(this.Bb&256)==0;case 3:return(this.Bb&512)==0;case 4:return this.s!=0;case 5:return this.t!=1;case 6:return a=this.t,a>1||a==-1;case 7:return r=this.s,r>=1;case 8:return!!this.r&&!this.q.e&&yw(this.q).i==0;case 9:return!!this.q&&!(this.r&&!this.q.e&&yw(this.q).i==0);case 10:return!!(this.Db>>16==10&&l(this.Cb,29));case 11:return!!this.d&&this.d.i!=0;case 12:return!!this.c&&this.c.i!=0;case 13:return!!this.a&&Xl(this.a.a).i!=0&&!(this.b&&uue(this.b));case 14:return!!this.b&&uue(this.b)}return nf(this,t-yr((Tn(),I2)),Mn((n=l(Kn(this,16),29),n||I2),t))},h.bi=function(t,n){var r,a;switch(t){case 0:!this.Ab&&(this.Ab=new nt(mi,this,0,3)),$r(this.Ab),!this.Ab&&(this.Ab=new nt(mi,this,0,3)),As(this.Ab,l(n,16));return;case 1:Fu(this,ei(n));return;case 2:c2(this,Rt(Bt(n)));return;case 3:u2(this,Rt(Bt(n)));return;case 4:i2(this,l(n,17).a);return;case 5:My(this,l(n,17).a);return;case 8:Gm(this,l(n,142));return;case 9:a=$1(this,l(n,89),null),a&&a.oj();return;case 11:!this.d&&(this.d=new ml(Zu,this,11)),$r(this.d),!this.d&&(this.d=new ml(Zu,this,11)),As(this.d,l(n,16));return;case 12:!this.c&&(this.c=new nt(k3,this,12,10)),$r(this.c),!this.c&&(this.c=new nt(k3,this,12,10)),As(this.c,l(n,16));return;case 13:!this.a&&(this.a=new LO(this,this)),tL(this.a),!this.a&&(this.a=new LO(this,this)),As(this.a,l(n,16));return;case 14:$r(Xl(this)),As(Xl(this),l(n,16));return}uf(this,t-yr((Tn(),I2)),Mn((r=l(Kn(this,16),29),r||I2),t),n)},h.ii=function(){return Tn(),I2},h.ki=function(t){var n,r;switch(t){case 0:!this.Ab&&(this.Ab=new nt(mi,this,0,3)),$r(this.Ab);return;case 1:Fu(this,null);return;case 2:c2(this,!0);return;case 3:u2(this,!0);return;case 4:i2(this,0);return;case 5:My(this,1);return;case 8:Gm(this,null);return;case 9:r=$1(this,null,null),r&&r.oj();return;case 11:!this.d&&(this.d=new ml(Zu,this,11)),$r(this.d);return;case 12:!this.c&&(this.c=new nt(k3,this,12,10)),$r(this.c);return;case 13:this.a&&tL(this.a);return;case 14:this.b&&$r(this.b);return}cf(this,t-yr((Tn(),I2)),Mn((n=l(Kn(this,16),29),n||I2),t))},h.pi=function(){var t,n;if(this.c)for(t=0,n=this.c.i;tw&&Ts(t,w,null),a=0,r=new or(Xl(this.a));r.e!=r.i.gc();)n=l(gr(r),89),f=(g=n.c,g||(Tn(),td)),Ts(t,a++,f);return t},h.Hj=function(){var t,n,r,a,o;for(o=new Up,o.a+="[",t=Xl(this.a),n=0,a=Xl(this.a).i;n1);case 5:return rA(this,t,n,r,a,this.i-l(r,15).gc()>0);default:return new Zg(this.e,t,this.c,n,r,a,!0)}},h.Tj=function(){return!0},h.Qj=function(){return uue(this)},h.Gk=function(){$r(this)},I(Gn,"EOperationImpl/2",1377),D(507,1,{2037:1,507:1},Ott),I(Gn,"EPackageImpl/1",507),D(14,83,kc,nt),h.il=function(){return this.d},h.jl=function(){return this.b},h.ml=function(){return!0},h.b=0,I(us,"EObjectContainmentWithInverseEList",14),D(365,14,kc,V8),h.nl=function(){return!0},h.Wi=function(t,n){return Ex(this,t,l(n,58))},I(us,"EObjectContainmentWithInverseEList/Resolving",365),D(308,365,kc,wy),h.Ni=function(){this.a.tb=null},I(Gn,"EPackageImpl/2",308),D(1278,1,{},ere),I(Gn,"EPackageImpl/3",1278),D(733,45,m6,$we),h._b=function(t){return Ia(t)?soe(this,t):!!zo(this.f,t)},I(Gn,"EPackageRegistryImpl",733),D(518,292,{110:1,94:1,93:1,155:1,197:1,58:1,2116:1,114:1,481:1,54:1,99:1,158:1,518:1,292:1,119:1,120:1},Hie),h.Ah=function(t){return lgt(this,t)},h.Lh=function(t,n,r){var a,o,f;switch(t){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),this.Ab;case 1:return this.zb;case 2:return Hn(),!!(this.Bb&256);case 3:return Hn(),!!(this.Bb&512);case 4:return pt(this.s);case 5:return pt(this.t);case 6:return Hn(),f=this.t,f>1||f==-1;case 7:return Hn(),o=this.s,o>=1;case 8:return n?Of(this):this.r;case 9:return this.q;case 10:return this.Db>>16==10?l(this.Cb,62):null}return sf(this,t-yr((Tn(),N4)),Mn((a=l(Kn(this,16),29),a||N4),t),n,r)},h.Sh=function(t,n,r){var a,o,f;switch(n){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),Ru(this.Ab,t,r);case 10:return this.Cb&&(r=(o=this.Db>>16,o>=0?lgt(this,r):this.Cb.Th(this,-1-o,null,r))),Nh(this,t,10,r)}return f=l(Mn((a=l(Kn(this,16),29),a||(Tn(),N4)),n),69),f.wk().zk(this,Ku(this),n-yr((Tn(),N4)),t,r)},h.Uh=function(t,n,r){var a,o;switch(n){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),To(this.Ab,t,r);case 9:return qae(this,r);case 10:return Nh(this,null,10,r)}return o=l(Mn((a=l(Kn(this,16),29),a||(Tn(),N4)),n),69),o.wk().Ak(this,Ku(this),n-yr((Tn(),N4)),t,r)},h.Wh=function(t){var n,r,a;switch(t){case 0:return!!this.Ab&&this.Ab.i!=0;case 1:return this.zb!=null;case 2:return(this.Bb&256)==0;case 3:return(this.Bb&512)==0;case 4:return this.s!=0;case 5:return this.t!=1;case 6:return a=this.t,a>1||a==-1;case 7:return r=this.s,r>=1;case 8:return!!this.r&&!this.q.e&&yw(this.q).i==0;case 9:return!!this.q&&!(this.r&&!this.q.e&&yw(this.q).i==0);case 10:return!!(this.Db>>16==10&&l(this.Cb,62))}return nf(this,t-yr((Tn(),N4)),Mn((n=l(Kn(this,16),29),n||N4),t))},h.ii=function(){return Tn(),N4},I(Gn,"EParameterImpl",518),D(102,462,{110:1,94:1,93:1,155:1,197:1,58:1,19:1,179:1,69:1,114:1,481:1,54:1,99:1,158:1,102:1,462:1,292:1,119:1,120:1,692:1},Hye),h.Lh=function(t,n,r){var a,o,f,g;switch(t){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),this.Ab;case 1:return this.zb;case 2:return Hn(),!!(this.Bb&256);case 3:return Hn(),!!(this.Bb&512);case 4:return pt(this.s);case 5:return pt(this.t);case 6:return Hn(),g=this.t,g>1||g==-1;case 7:return Hn(),o=this.s,o>=1;case 8:return n?Of(this):this.r;case 9:return this.q;case 10:return Hn(),!!(this.Bb&m0);case 11:return Hn(),!!(this.Bb&r4);case 12:return Hn(),!!(this.Bb&Xy);case 13:return this.j;case 14:return UE(this);case 15:return Hn(),!!(this.Bb&Sl);case 16:return Hn(),!!(this.Bb&_d);case 17:return ky(this);case 18:return Hn(),!!(this.Bb&eu);case 19:return Hn(),f=Ro(this),!!(f&&f.Bb&eu);case 20:return Hn(),!!(this.Bb&Io);case 21:return n?Ro(this):this.b;case 22:return n?$7e(this):_ut(this);case 23:return!this.a&&(this.a=new $5(D4,this,23)),this.a}return sf(this,t-yr((Tn(),o7)),Mn((a=l(Kn(this,16),29),a||o7),t),n,r)},h.Wh=function(t){var n,r,a,o;switch(t){case 0:return!!this.Ab&&this.Ab.i!=0;case 1:return this.zb!=null;case 2:return(this.Bb&256)==0;case 3:return(this.Bb&512)==0;case 4:return this.s!=0;case 5:return this.t!=1;case 6:return o=this.t,o>1||o==-1;case 7:return r=this.s,r>=1;case 8:return!!this.r&&!this.q.e&&yw(this.q).i==0;case 9:return!!this.q&&!(this.r&&!this.q.e&&yw(this.q).i==0);case 10:return(this.Bb&m0)==0;case 11:return(this.Bb&r4)!=0;case 12:return(this.Bb&Xy)!=0;case 13:return this.j!=null;case 14:return UE(this)!=null;case 15:return(this.Bb&Sl)!=0;case 16:return(this.Bb&_d)!=0;case 17:return!!ky(this);case 18:return(this.Bb&eu)!=0;case 19:return a=Ro(this),!!a&&(a.Bb&eu)!=0;case 20:return(this.Bb&Io)==0;case 21:return!!this.b;case 22:return!!_ut(this);case 23:return!!this.a&&this.a.i!=0}return nf(this,t-yr((Tn(),o7)),Mn((n=l(Kn(this,16),29),n||o7),t))},h.bi=function(t,n){var r,a;switch(t){case 0:!this.Ab&&(this.Ab=new nt(mi,this,0,3)),$r(this.Ab),!this.Ab&&(this.Ab=new nt(mi,this,0,3)),As(this.Ab,l(n,16));return;case 1:poe(this,ei(n));return;case 2:c2(this,Rt(Bt(n)));return;case 3:u2(this,Rt(Bt(n)));return;case 4:i2(this,l(n,17).a);return;case 5:My(this,l(n,17).a);return;case 8:Gm(this,l(n,142));return;case 9:a=$1(this,l(n,89),null),a&&a.oj();return;case 10:AE(this,Rt(Bt(n)));return;case 11:DE(this,Rt(Bt(n)));return;case 12:LE(this,Rt(Bt(n)));return;case 13:Z3e(this,ei(n));return;case 15:ME(this,Rt(Bt(n)));return;case 16:IE(this,Rt(Bt(n)));return;case 18:L2n(this,Rt(Bt(n)));return;case 20:v8e(this,Rt(Bt(n)));return;case 21:b7e(this,l(n,19));return;case 23:!this.a&&(this.a=new $5(D4,this,23)),$r(this.a),!this.a&&(this.a=new $5(D4,this,23)),As(this.a,l(n,16));return}uf(this,t-yr((Tn(),o7)),Mn((r=l(Kn(this,16),29),r||o7),t),n)},h.ii=function(){return Tn(),o7},h.ki=function(t){var n,r;switch(t){case 0:!this.Ab&&(this.Ab=new nt(mi,this,0,3)),$r(this.Ab);return;case 1:De(this.Cb,90)&&zy(Yl(l(this.Cb,90)),4),Fu(this,null);return;case 2:c2(this,!0);return;case 3:u2(this,!0);return;case 4:i2(this,0);return;case 5:My(this,1);return;case 8:Gm(this,null);return;case 9:r=$1(this,null,null),r&&r.oj();return;case 10:AE(this,!0);return;case 11:DE(this,!1);return;case 12:LE(this,!1);return;case 13:this.i=null,xV(this,null);return;case 15:ME(this,!1);return;case 16:IE(this,!1);return;case 18:m8e(this,!1),De(this.Cb,90)&&zy(Yl(l(this.Cb,90)),2);return;case 20:v8e(this,!0);return;case 21:b7e(this,null);return;case 23:!this.a&&(this.a=new $5(D4,this,23)),$r(this.a);return}cf(this,t-yr((Tn(),o7)),Mn((n=l(Kn(this,16),29),n||o7),t))},h.pi=function(){$7e(this),Wk(ic((El(),io),this)),Of(this),this.Bb|=1},h.uk=function(){return Ro(this)},h._k=function(){var t;return t=Ro(this),!!t&&(t.Bb&eu)!=0},h.al=function(){return(this.Bb&eu)!=0},h.bl=function(){return(this.Bb&Io)!=0},h.Yk=function(t,n){return this.c=null,o8e(this,t,n)},h.Ib=function(){var t;return this.Db&64?BU(this):(t=new Af(BU(this)),t.a+=" (containment: ",Gp(t,(this.Bb&eu)!=0),t.a+=", resolveProxies: ",Gp(t,(this.Bb&Io)!=0),t.a+=")",t.a)},I(Gn,"EReferenceImpl",102),D(561,120,{110:1,44:1,94:1,93:1,136:1,58:1,114:1,54:1,99:1,561:1,119:1,120:1},OS),h.Fb=function(t){return this===t},h.ld=function(){return this.b},h.md=function(){return this.c},h.Hb=function(){return fw(this)},h.Di=function(t){Ndn(this,ei(t))},h.nd=function(t){return wdn(this,ei(t))},h.Lh=function(t,n,r){var a;switch(t){case 0:return this.b;case 1:return this.c}return sf(this,t-yr((Tn(),No)),Mn((a=l(Kn(this,16),29),a||No),t),n,r)},h.Wh=function(t){var n;switch(t){case 0:return this.b!=null;case 1:return this.c!=null}return nf(this,t-yr((Tn(),No)),Mn((n=l(Kn(this,16),29),n||No),t))},h.bi=function(t,n){var r;switch(t){case 0:Pdn(this,ei(n));return;case 1:d7e(this,ei(n));return}uf(this,t-yr((Tn(),No)),Mn((r=l(Kn(this,16),29),r||No),t),n)},h.ii=function(){return Tn(),No},h.ki=function(t){var n;switch(t){case 0:f7e(this,null);return;case 1:d7e(this,null);return}cf(this,t-yr((Tn(),No)),Mn((n=l(Kn(this,16),29),n||No),t))},h.Bi=function(){var t;return this.a==-1&&(t=this.b,this.a=t==null?0:s2(t)),this.a},h.Ci=function(t){this.a=t},h.Ib=function(){var t;return this.Db&64?g0(this):(t=new Af(g0(this)),t.a+=" (key: ",Xo(t,this.b),t.a+=", value: ",Xo(t,this.c),t.a+=")",t.a)},h.a=-1,h.b=null,h.c=null;var Yc=I(Gn,"EStringToStringMapEntryImpl",561),Q_t=ks(us,"FeatureMap/Entry/Internal");D(576,1,YG),h.xl=function(t){return this.yl(l(t,54))},h.yl=function(t){return this.xl(t)},h.Fb=function(t){var n,r;return this===t?!0:De(t,76)?(n=l(t,76),n.Lk()==this.c?(r=this.md(),r==null?n.md()==null:Pi(r,n.md())):!1):!1},h.Lk=function(){return this.c},h.Hb=function(){var t;return t=this.md(),es(this.c)^(t==null?0:es(t))},h.Ib=function(){var t,n;return t=this.c,n=Ah(t.qk()).yi(),t.xe(),(n!=null&&n.length!=0?n+":"+t.xe():t.xe())+"="+this.md()},I(Gn,"EStructuralFeatureImpl/BasicFeatureMapEntry",576),D(791,576,YG,Jye),h.yl=function(t){return new Jye(this.c,t)},h.md=function(){return this.a},h.zl=function(t,n,r){return v3n(this,t,this.a,n,r)},h.Al=function(t,n,r){return w3n(this,t,this.a,n,r)},I(Gn,"EStructuralFeatureImpl/ContainmentUpdatingFeatureMapEntry",791),D(1350,1,{},Ntt),h.yk=function(t,n,r,a,o){var f;return f=l(tE(t,this.b),220),f.Yl(this.a).Fk(a)},h.zk=function(t,n,r,a,o){var f;return f=l(tE(t,this.b),220),f.Pl(this.a,a,o)},h.Ak=function(t,n,r,a,o){var f;return f=l(tE(t,this.b),220),f.Ql(this.a,a,o)},h.Bk=function(t,n,r){var a;return a=l(tE(t,this.b),220),a.Yl(this.a).Qj()},h.Ck=function(t,n,r,a){var o;o=l(tE(t,this.b),220),o.Yl(this.a).Wb(a)},h.Dk=function(t,n,r){return l(tE(t,this.b),220).Yl(this.a)},h.Ek=function(t,n,r){var a;a=l(tE(t,this.b),220),a.Yl(this.a).Gk()},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateFeatureMapDelegator",1350),D(91,1,{},Xp,Om,Jp,Rm),h.yk=function(t,n,r,a,o){var f;if(f=n.li(r),f==null&&n.mi(r,f=WU(this,t)),!o)switch(this.e){case 50:case 41:return l(f,597).bk();case 40:return l(f,220).Vl()}return f},h.zk=function(t,n,r,a,o){var f,g;return g=n.li(r),g==null&&n.mi(r,g=WU(this,t)),f=l(g,71).Wk(a,o),f},h.Ak=function(t,n,r,a,o){var f;return f=n.li(r),f!=null&&(o=l(f,71).Xk(a,o)),o},h.Bk=function(t,n,r){var a;return a=n.li(r),a!=null&&l(a,79).Qj()},h.Ck=function(t,n,r,a){var o;o=l(n.li(r),79),!o&&n.mi(r,o=WU(this,t)),o.Wb(a)},h.Dk=function(t,n,r){var a,o;return o=n.li(r),o==null&&n.mi(r,o=WU(this,t)),De(o,79)?l(o,79):(a=l(n.li(r),15),new xQe(a))},h.Ek=function(t,n,r){var a;a=l(n.li(r),79),!a&&n.mi(r,a=WU(this,t)),a.Gk()},h.b=0,h.e=0,I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateMany",91),D(512,1,{}),h.zk=function(t,n,r,a,o){throw ue(new Qr)},h.Ak=function(t,n,r,a,o){throw ue(new Qr)},h.Dk=function(t,n,r){return new Iat(this,t,n,r)};var Sg;I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingle",512),D(1367,1,i0e,Iat),h.Fk=function(t){return this.a.yk(this.c,this.d,this.b,t,!0)},h.Qj=function(){return this.a.Bk(this.c,this.d,this.b)},h.Wb=function(t){this.a.Ck(this.c,this.d,this.b,t)},h.Gk=function(){this.a.Ek(this.c,this.d,this.b)},h.b=0,I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingle/1",1367),D(784,512,{},$5e),h.yk=function(t,n,r,a,o){return sle(t,t.Ph(),t.Fh())==this.b?this.bl()&&a?Uue(t):t.Ph():null},h.zk=function(t,n,r,a,o){var f,g;return t.Ph()&&(o=(f=t.Fh(),f>=0?t.Ah(o):t.Ph().Th(t,-1-f,null,o))),g=ms(t.Dh(),this.e),t.Ch(a,g,o)},h.Ak=function(t,n,r,a,o){var f;return f=ms(t.Dh(),this.e),t.Ch(null,f,o)},h.Bk=function(t,n,r){var a;return a=ms(t.Dh(),this.e),!!t.Ph()&&t.Fh()==a},h.Ck=function(t,n,r,a){var o,f,g,w,E;if(a!=null&&!ule(this.a,a))throw ue(new kk(XG+(De(a,58)?_xe(l(a,58).Dh()):K6e(bh(a)))+QG+this.a+"'"));if(o=t.Ph(),g=ms(t.Dh(),this.e),qe(a)!==qe(o)||t.Fh()!=g&&a!=null){if(FE(t,l(a,58)))throw ue(new Yn(EL+t.Ib()));E=null,o&&(E=(f=t.Fh(),f>=0?t.Ah(E):t.Ph().Th(t,-1-f,null,E))),w=l(a,54),w&&(E=w.Rh(t,ms(w.Dh(),this.b),null,E)),E=t.Ch(w,g,E),E&&E.oj()}else t.vh()&&t.wh()&&Ni(t,new _a(t,1,g,a,a))},h.Ek=function(t,n,r){var a,o,f,g;a=t.Ph(),a?(g=(o=t.Fh(),o>=0?t.Ah(null):t.Ph().Th(t,-1-o,null,null)),f=ms(t.Dh(),this.e),g=t.Ch(null,f,g),g&&g.oj()):t.vh()&&t.wh()&&Ni(t,new X_(t,1,this.e,null,null))},h.bl=function(){return!1},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleContainer",784),D(1351,784,{},kit),h.bl=function(){return!0},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleContainerResolving",1351),D(574,512,{}),h.yk=function(t,n,r,a,o){var f;return f=n.li(r),f==null?this.b:qe(f)===qe(Sg)?null:f},h.Bk=function(t,n,r){var a;return a=n.li(r),a!=null&&(qe(a)===qe(Sg)||!Pi(a,this.b))},h.Ck=function(t,n,r,a){var o,f;t.vh()&&t.wh()?(o=(f=n.li(r),f==null?this.b:qe(f)===qe(Sg)?null:f),a==null?this.c!=null?(n.mi(r,null),a=this.b):this.b!=null?n.mi(r,Sg):n.mi(r,null):(this.Bl(a),n.mi(r,a)),Ni(t,this.d.Cl(t,1,this.e,o,a))):a==null?this.c!=null?n.mi(r,null):this.b!=null?n.mi(r,Sg):n.mi(r,null):(this.Bl(a),n.mi(r,a))},h.Ek=function(t,n,r){var a,o;t.vh()&&t.wh()?(a=(o=n.li(r),o==null?this.b:qe(o)===qe(Sg)?null:o),n.ni(r),Ni(t,this.d.Cl(t,1,this.e,a,this.b))):n.ni(r)},h.Bl=function(t){throw ue(new IQe)},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleData",574),D(_6,1,{},NS),h.Cl=function(t,n,r,a,o){return new X_(t,n,r,a,o)},h.Dl=function(t,n,r,a,o,f){return new roe(t,n,r,a,o,f)};var MPe,DPe,IPe,OPe,NPe,PPe,BPe,ipe,FPe;I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleData/NotificationCreator",_6),D(1368,_6,{},H0),h.Cl=function(t,n,r,a,o){return new m6e(t,n,r,Rt(Bt(a)),Rt(Bt(o)))},h.Dl=function(t,n,r,a,o,f){return new rct(t,n,r,Rt(Bt(a)),Rt(Bt(o)),f)},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleData/NotificationCreator/1",1368),D(1369,_6,{},AI),h.Cl=function(t,n,r,a,o){return new Q6e(t,n,r,l(a,222).a,l(o,222).a)},h.Dl=function(t,n,r,a,o,f){return new Xot(t,n,r,l(a,222).a,l(o,222).a,f)},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleData/NotificationCreator/2",1369),D(1370,_6,{},LI),h.Cl=function(t,n,r,a,o){return new J6e(t,n,r,l(a,180).a,l(o,180).a)},h.Dl=function(t,n,r,a,o,f){return new Qot(t,n,r,l(a,180).a,l(o,180).a,f)},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleData/NotificationCreator/3",1370),D(1371,_6,{},f8),h.Cl=function(t,n,r,a,o){return new p6e(t,n,r,ze(Ge(a)),ze(Ge(o)))},h.Dl=function(t,n,r,a,o,f){return new Jot(t,n,r,ze(Ge(a)),ze(Ge(o)),f)},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleData/NotificationCreator/4",1371),D(1372,_6,{},tre),h.Cl=function(t,n,r,a,o){return new t7e(t,n,r,l(a,161).a,l(o,161).a)},h.Dl=function(t,n,r,a,o,f){return new Zot(t,n,r,l(a,161).a,l(o,161).a,f)},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleData/NotificationCreator/5",1372),D(1373,_6,{},nre),h.Cl=function(t,n,r,a,o){return new b6e(t,n,r,l(a,17).a,l(o,17).a)},h.Dl=function(t,n,r,a,o,f){return new ect(t,n,r,l(a,17).a,l(o,17).a,f)},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleData/NotificationCreator/6",1373),D(1374,_6,{},rre),h.Cl=function(t,n,r,a,o){return new Z6e(t,n,r,l(a,168).a,l(o,168).a)},h.Dl=function(t,n,r,a,o,f){return new tct(t,n,r,l(a,168).a,l(o,168).a,f)},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleData/NotificationCreator/7",1374),D(1375,_6,{},ire),h.Cl=function(t,n,r,a,o){return new e7e(t,n,r,l(a,191).a,l(o,191).a)},h.Dl=function(t,n,r,a,o,f){return new nct(t,n,r,l(a,191).a,l(o,191).a,f)},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleData/NotificationCreator/8",1375),D(1353,574,{},Oat),h.Bl=function(t){if(!this.a.fk(t))throw ue(new kk(XG+bh(t)+QG+this.a+"'"))},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleDataDynamic",1353),D(1354,574,{},yst),h.Bl=function(t){},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleDataStatic",1354),D(785,574,{}),h.Bk=function(t,n,r){var a;return a=n.li(r),a!=null},h.Ck=function(t,n,r,a){var o,f;t.vh()&&t.wh()?(o=!0,f=n.li(r),f==null?(o=!1,f=this.b):qe(f)===qe(Sg)&&(f=null),a==null?this.c!=null?(n.mi(r,null),a=this.b):n.mi(r,Sg):(this.Bl(a),n.mi(r,a)),Ni(t,this.d.Dl(t,1,this.e,f,a,!o))):a==null?this.c!=null?n.mi(r,null):n.mi(r,Sg):(this.Bl(a),n.mi(r,a))},h.Ek=function(t,n,r){var a,o;t.vh()&&t.wh()?(a=!0,o=n.li(r),o==null?(a=!1,o=this.b):qe(o)===qe(Sg)&&(o=null),n.ni(r),Ni(t,this.d.Dl(t,2,this.e,o,this.b,a))):n.ni(r)},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleDataUnsettable",785),D(1355,785,{},Nat),h.Bl=function(t){if(!this.a.fk(t))throw ue(new kk(XG+bh(t)+QG+this.a+"'"))},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleDataUnsettableDynamic",1355),D(1356,785,{},xst),h.Bl=function(t){},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleDataUnsettableStatic",1356),D(410,512,{},cH),h.yk=function(t,n,r,a,o){var f,g,w,E,C;if(C=n.li(r),this.tk()&&qe(C)===qe(Sg))return null;if(this.bl()&&a&&C!=null){if(w=l(C,54),w.Vh()&&(E=yb(t,w),w!=E)){if(!ule(this.a,E))throw ue(new kk(XG+bh(E)+QG+this.a+"'"));n.mi(r,C=E),this.al()&&(f=l(E,54),g=w.Th(t,this.b?ms(w.Dh(),this.b):-1-ms(t.Dh(),this.e),null,null),!f.Ph()&&(g=f.Rh(t,this.b?ms(f.Dh(),this.b):-1-ms(t.Dh(),this.e),null,g)),g&&g.oj()),t.vh()&&t.wh()&&Ni(t,new X_(t,9,this.e,w,E))}return C}else return C},h.zk=function(t,n,r,a,o){var f,g;return g=n.li(r),qe(g)===qe(Sg)&&(g=null),n.mi(r,a),this.Mj()?qe(g)!==qe(a)&&g!=null&&(f=l(g,54),o=f.Th(t,ms(f.Dh(),this.b),null,o)):this.al()&&g!=null&&(o=l(g,54).Th(t,-1-ms(t.Dh(),this.e),null,o)),t.vh()&&t.wh()&&(!o&&(o=new nb(4)),o.nj(new X_(t,1,this.e,g,a))),o},h.Ak=function(t,n,r,a,o){var f;return f=n.li(r),qe(f)===qe(Sg)&&(f=null),n.ni(r),t.vh()&&t.wh()&&(!o&&(o=new nb(4)),this.tk()?o.nj(new X_(t,2,this.e,f,null)):o.nj(new X_(t,1,this.e,f,null))),o},h.Bk=function(t,n,r){var a;return a=n.li(r),a!=null},h.Ck=function(t,n,r,a){var o,f,g,w,E;if(a!=null&&!ule(this.a,a))throw ue(new kk(XG+(De(a,58)?_xe(l(a,58).Dh()):K6e(bh(a)))+QG+this.a+"'"));E=n.li(r),w=E!=null,this.tk()&&qe(E)===qe(Sg)&&(E=null),g=null,this.Mj()?qe(E)!==qe(a)&&(E!=null&&(o=l(E,54),g=o.Th(t,ms(o.Dh(),this.b),null,g)),a!=null&&(o=l(a,54),g=o.Rh(t,ms(o.Dh(),this.b),null,g))):this.al()&&qe(E)!==qe(a)&&(E!=null&&(g=l(E,54).Th(t,-1-ms(t.Dh(),this.e),null,g)),a!=null&&(g=l(a,54).Rh(t,-1-ms(t.Dh(),this.e),null,g))),a==null&&this.tk()?n.mi(r,Sg):n.mi(r,a),t.vh()&&t.wh()?(f=new roe(t,1,this.e,E,a,this.tk()&&!w),g?(g.nj(f),g.oj()):Ni(t,f)):g&&g.oj()},h.Ek=function(t,n,r){var a,o,f,g,w;w=n.li(r),g=w!=null,this.tk()&&qe(w)===qe(Sg)&&(w=null),f=null,w!=null&&(this.Mj()?(a=l(w,54),f=a.Th(t,ms(a.Dh(),this.b),null,f)):this.al()&&(f=l(w,54).Th(t,-1-ms(t.Dh(),this.e),null,f))),n.ni(r),t.vh()&&t.wh()?(o=new roe(t,this.tk()?2:1,this.e,w,null,g),f?(f.nj(o),f.oj()):Ni(t,o)):f&&f.oj()},h.Mj=function(){return!1},h.al=function(){return!1},h.bl=function(){return!1},h.tk=function(){return!1},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleEObject",410),D(575,410,{},oae),h.al=function(){return!0},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleEObjectContainment",575),D(1359,575,{},wrt),h.bl=function(){return!0},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleEObjectContainmentResolving",1359),D(787,575,{},jye),h.tk=function(){return!0},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleEObjectContainmentUnsettable",787),D(1361,787,{},yrt),h.bl=function(){return!0},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleEObjectContainmentUnsettableResolving",1361),D(650,575,{},yae),h.Mj=function(){return!0},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleEObjectContainmentWithInverse",650),D(1360,650,{},Eit),h.bl=function(){return!0},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleEObjectContainmentWithInverseResolving",1360),D(788,650,{},C4e),h.tk=function(){return!0},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleEObjectContainmentWithInverseUnsettable",788),D(1362,788,{},Tit),h.bl=function(){return!0},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleEObjectContainmentWithInverseUnsettableResolving",1362),D(651,410,{},$ye),h.bl=function(){return!0},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleEObjectResolving",651),D(1363,651,{},xrt),h.tk=function(){return!0},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleEObjectResolvingUnsettable",1363),D(789,651,{},E4e),h.Mj=function(){return!0},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleEObjectResolvingWithInverse",789),D(1364,789,{},Cit),h.tk=function(){return!0},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleEObjectResolvingWithInverseUnsettable",1364),D(1357,410,{},krt),h.tk=function(){return!0},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleEObjectUnsettable",1357),D(786,410,{},T4e),h.Mj=function(){return!0},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleEObjectWithInverse",786),D(1358,786,{},Sit),h.tk=function(){return!0},I(Gn,"EStructuralFeatureImpl/InternalSettingDelegateSingleEObjectWithInverseUnsettable",1358),D(790,576,YG,x5e),h.yl=function(t){return new x5e(this.a,this.c,t)},h.md=function(){return this.b},h.zl=function(t,n,r){return bvn(this,t,this.b,r)},h.Al=function(t,n,r){return mvn(this,t,this.b,r)},I(Gn,"EStructuralFeatureImpl/InverseUpdatingFeatureMapEntry",790),D(1365,1,i0e,xQe),h.Fk=function(t){return this.a},h.Qj=function(){return De(this.a,97)?l(this.a,97).Qj():!this.a.dc()},h.Wb=function(t){this.a.$b(),this.a.Gc(l(t,15))},h.Gk=function(){De(this.a,97)?l(this.a,97).Gk():this.a.$b()},I(Gn,"EStructuralFeatureImpl/SettingMany",1365),D(1366,576,YG,Wct),h.xl=function(t){return new lae((Gi(),UM),this.b.ri(this.a,t))},h.md=function(){return null},h.zl=function(t,n,r){return r},h.Al=function(t,n,r){return r},I(Gn,"EStructuralFeatureImpl/SimpleContentFeatureMapEntry",1366),D(652,576,YG,lae),h.xl=function(t){return new lae(this.c,t)},h.md=function(){return this.a},h.zl=function(t,n,r){return r},h.Al=function(t,n,r){return r},I(Gn,"EStructuralFeatureImpl/SimpleFeatureMapEntry",652),D(403,506,Bd,Xd),h.aj=function(t){return We(Vf,Rn,29,t,0,1)},h.Yi=function(){return!1},I(Gn,"ESuperAdapter/1",403),D(457,448,{110:1,94:1,93:1,155:1,197:1,58:1,114:1,850:1,54:1,99:1,158:1,457:1,119:1,120:1},PS),h.Lh=function(t,n,r){var a;switch(t){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),this.Ab;case 1:return this.zb;case 2:return!this.a&&(this.a=new G_(this,Wo,this)),this.a}return sf(this,t-yr((Tn(),T3)),Mn((a=l(Kn(this,16),29),a||T3),t),n,r)},h.Uh=function(t,n,r){var a,o;switch(n){case 0:return!this.Ab&&(this.Ab=new nt(mi,this,0,3)),To(this.Ab,t,r);case 2:return!this.a&&(this.a=new G_(this,Wo,this)),To(this.a,t,r)}return o=l(Mn((a=l(Kn(this,16),29),a||(Tn(),T3)),n),69),o.wk().Ak(this,Ku(this),n-yr((Tn(),T3)),t,r)},h.Wh=function(t){var n;switch(t){case 0:return!!this.Ab&&this.Ab.i!=0;case 1:return this.zb!=null;case 2:return!!this.a&&this.a.i!=0}return nf(this,t-yr((Tn(),T3)),Mn((n=l(Kn(this,16),29),n||T3),t))},h.bi=function(t,n){var r;switch(t){case 0:!this.Ab&&(this.Ab=new nt(mi,this,0,3)),$r(this.Ab),!this.Ab&&(this.Ab=new nt(mi,this,0,3)),As(this.Ab,l(n,16));return;case 1:Fu(this,ei(n));return;case 2:!this.a&&(this.a=new G_(this,Wo,this)),$r(this.a),!this.a&&(this.a=new G_(this,Wo,this)),As(this.a,l(n,16));return}uf(this,t-yr((Tn(),T3)),Mn((r=l(Kn(this,16),29),r||T3),t),n)},h.ii=function(){return Tn(),T3},h.ki=function(t){var n;switch(t){case 0:!this.Ab&&(this.Ab=new nt(mi,this,0,3)),$r(this.Ab);return;case 1:Fu(this,null);return;case 2:!this.a&&(this.a=new G_(this,Wo,this)),$r(this.a);return}cf(this,t-yr((Tn(),T3)),Mn((n=l(Kn(this,16),29),n||T3),t))},I(Gn,"ETypeParameterImpl",457),D(458,83,kc,G_),h.Nj=function(t,n){return Dxn(this,l(t,89),n)},h.Oj=function(t,n){return Ixn(this,l(t,89),n)},I(Gn,"ETypeParameterImpl/1",458),D(647,45,m6,Vie),h.ec=function(){return new Pz(this)},I(Gn,"ETypeParameterImpl/2",647),D(570,q1,Tl,Pz),h.Fc=function(t){return Wrt(this,l(t,89))},h.Gc=function(t){var n,r,a;for(a=!1,r=t.Kc();r.Ob();)n=l(r.Pb(),89),ki(this.a,n,"")==null&&(a=!0);return a},h.$b=function(){Nl(this.a)},h.Hc=function(t){return Hu(this.a,t)},h.Kc=function(){var t;return t=new qm(new Sr(this.a).a),new Bz(t)},h.Mc=function(t){return Rut(this,t)},h.gc=function(){return d_(this.a)},I(Gn,"ETypeParameterImpl/2/1",570),D(571,1,Oa,Bz),h.Nb=function(t){Za(this,t)},h.Pb=function(){return l(Nw(this.a).ld(),89)},h.Ob=function(){return this.a.b},h.Qb=function(){Klt(this.a)},I(Gn,"ETypeParameterImpl/2/1/1",571),D(1329,45,m6,hJe),h._b=function(t){return Ia(t)?soe(this,t):!!zo(this.f,t)},h.xc=function(t){var n,r;return n=Ia(t)?xu(this,t):hc(zo(this.f,t)),De(n,851)?(r=l(n,851),n=r.Kk(),ki(this,l(t,241),n),n):n??(t==null?(use(),Z_t):null)},I(Gn,"EValidatorRegistryImpl",1329),D(1349,720,{110:1,94:1,93:1,480:1,155:1,58:1,114:1,2040:1,54:1,99:1,158:1,119:1,120:1},d8),h.ri=function(t,n){switch(t.hk()){case 21:case 22:case 23:case 24:case 26:case 31:case 32:case 37:case 38:case 39:case 40:case 43:case 44:case 48:case 49:case 20:return n==null?null:xc(n);case 25:return Awn(n);case 27:return qvn(n);case 28:return Hvn(n);case 29:return n==null?null:Cnt(jM[0],l(n,206));case 41:return n==null?"":_m(l(n,297));case 42:return xc(n);case 50:return ei(n);default:throw ue(new Yn(yT+t.xe()+t3))}},h.si=function(t){var n,r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe;switch(t.G==-1&&(t.G=(z=Ah(t),z?f2(z.vi(),t):-1)),t.G){case 0:return r=new zie,r;case 1:return n=new CI,n;case 2:return a=new hz,a;case 4:return o=new Fz,o;case 5:return f=new lJe,f;case 6:return g=new PQe,g;case 7:return w=new fz,w;case 10:return C=new m5,C;case 11:return L=new qie,L;case 12:return B=new qat,B;case 13:return V=new Hie,V;case 14:return J=new Hye,J;case 17:return te=new OS,te;case 18:return E=new Qv,E;case 19:return fe=new PS,fe;default:throw ue(new Yn(qfe+t.zb+t3))}},h.ti=function(t,n){switch(t.hk()){case 20:return n==null?null:new h3e(n);case 21:return n==null?null:new ob(n);case 23:case 22:return n==null?null:z5n(n);case 26:case 24:return n==null?null:fN(Oh(n,-128,127)<<24>>24);case 25:return aTn(n);case 27:return A7n(n);case 28:return L7n(n);case 29:return Jxn(n);case 32:case 31:return n==null?null:jy(n);case 38:case 37:return n==null?null:new Awe(n);case 40:case 39:return n==null?null:pt(Oh(n,lo,Ii));case 41:return null;case 42:return n==null,null;case 44:case 43:return n==null?null:ap(KU(n));case 49:case 48:return n==null?null:_E(Oh(n,JG,32767)<<16>>16);case 50:return n;default:throw ue(new Yn(yT+t.xe()+t3))}},I(Gn,"EcoreFactoryImpl",1349),D(560,184,{110:1,94:1,93:1,155:1,197:1,58:1,241:1,114:1,2038:1,54:1,99:1,158:1,184:1,560:1,119:1,120:1,690:1},fat),h.gb=!1,h.hb=!1;var RPe,J_t=!1;I(Gn,"EcorePackageImpl",560),D(1234,1,{851:1},k1),h.Kk=function(){return Rnt(),eAt},I(Gn,"EcorePackageImpl/1",1234),D(1243,1,yi,A$),h.fk=function(t){return De(t,155)},h.gk=function(t){return We(uF,Rn,155,t,0,1)},I(Gn,"EcorePackageImpl/10",1243),D(1244,1,yi,L$),h.fk=function(t){return De(t,197)},h.gk=function(t){return We(Yge,Rn,197,t,0,1)},I(Gn,"EcorePackageImpl/11",1244),D(1245,1,yi,M$),h.fk=function(t){return De(t,58)},h.gk=function(t){return We(Xb,Rn,58,t,0,1)},I(Gn,"EcorePackageImpl/12",1245),D(1246,1,yi,D$),h.fk=function(t){return De(t,411)},h.gk=function(t){return We(Uf,LSe,62,t,0,1)},I(Gn,"EcorePackageImpl/13",1246),D(1247,1,yi,I$),h.fk=function(t){return De(t,241)},h.gk=function(t){return We(u1,Rn,241,t,0,1)},I(Gn,"EcorePackageImpl/14",1247),D(1248,1,yi,O$),h.fk=function(t){return De(t,518)},h.gk=function(t){return We(k3,Rn,2116,t,0,1)},I(Gn,"EcorePackageImpl/15",1248),D(1249,1,yi,V0),h.fk=function(t){return De(t,102)},h.gk=function(t){return We(I4,S6,19,t,0,1)},I(Gn,"EcorePackageImpl/16",1249),D(1250,1,yi,nl),h.fk=function(t){return De(t,179)},h.gk=function(t){return We(dl,S6,179,t,0,1)},I(Gn,"EcorePackageImpl/17",1250),D(1251,1,yi,sre),h.fk=function(t){return De(t,481)},h.gk=function(t){return We(M4,Rn,481,t,0,1)},I(Gn,"EcorePackageImpl/18",1251),D(1252,1,yi,are),h.fk=function(t){return De(t,561)},h.gk=function(t){return We(Yc,e5t,561,t,0,1)},I(Gn,"EcorePackageImpl/19",1252),D(1235,1,yi,ore),h.fk=function(t){return De(t,331)},h.gk=function(t){return We(D4,S6,35,t,0,1)},I(Gn,"EcorePackageImpl/2",1235),D(1253,1,yi,rl),h.fk=function(t){return De(t,248)},h.gk=function(t){return We(Wo,m5t,89,t,0,1)},I(Gn,"EcorePackageImpl/20",1253),D(1254,1,yi,BS),h.fk=function(t){return De(t,457)},h.gk=function(t){return We(Zu,Rn,850,t,0,1)},I(Gn,"EcorePackageImpl/21",1254),D(1255,1,yi,N$),h.fk=function(t){return hy(t)},h.gk=function(t){return We(Ns,dt,485,t,8,1)},I(Gn,"EcorePackageImpl/22",1255),D(1256,1,yi,P$),h.fk=function(t){return De(t,195)},h.gk=function(t){return We(Al,dt,195,t,0,2)},I(Gn,"EcorePackageImpl/23",1256),D(1257,1,yi,g8),h.fk=function(t){return De(t,222)},h.gk=function(t){return We(jx,dt,222,t,0,1)},I(Gn,"EcorePackageImpl/24",1257),D(1258,1,yi,cre),h.fk=function(t){return De(t,180)},h.gk=function(t){return We(PL,dt,180,t,0,1)},I(Gn,"EcorePackageImpl/25",1258),D(1259,1,yi,ak),h.fk=function(t){return De(t,206)},h.gk=function(t){return We(cK,dt,206,t,0,1)},I(Gn,"EcorePackageImpl/26",1259),D(1260,1,yi,ure),h.fk=function(t){return!1},h.gk=function(t){return We(nBe,Rn,2215,t,0,1)},I(Gn,"EcorePackageImpl/27",1260),D(1261,1,yi,B$),h.fk=function(t){return fy(t)},h.gk=function(t){return We(ta,dt,345,t,7,1)},I(Gn,"EcorePackageImpl/28",1261),D(1262,1,yi,lre),h.fk=function(t){return De(t,61)},h.gk=function(t){return We(mPe,Qy,61,t,0,1)},I(Gn,"EcorePackageImpl/29",1262),D(1236,1,yi,hre),h.fk=function(t){return De(t,519)},h.gk=function(t){return We(mi,{3:1,4:1,5:1,2033:1},598,t,0,1)},I(Gn,"EcorePackageImpl/3",1236),D(1263,1,yi,FS),h.fk=function(t){return De(t,582)},h.gk=function(t){return We(yPe,Rn,2039,t,0,1)},I(Gn,"EcorePackageImpl/30",1263),D(1264,1,yi,F$),h.fk=function(t){return De(t,160)},h.gk=function(t){return We(HPe,Qy,160,t,0,1)},I(Gn,"EcorePackageImpl/31",1264),D(1265,1,yi,MI),h.fk=function(t){return De(t,76)},h.gk=function(t){return We(CY,S5t,76,t,0,1)},I(Gn,"EcorePackageImpl/32",1265),D(1266,1,yi,RS),h.fk=function(t){return De(t,161)},h.gk=function(t){return We(_T,dt,161,t,0,1)},I(Gn,"EcorePackageImpl/33",1266),D(1267,1,yi,fre),h.fk=function(t){return De(t,17)},h.gk=function(t){return We(ro,dt,17,t,0,1)},I(Gn,"EcorePackageImpl/34",1267),D(1268,1,yi,dre),h.fk=function(t){return De(t,297)},h.gk=function(t){return We(qSe,Rn,297,t,0,1)},I(Gn,"EcorePackageImpl/35",1268),D(1269,1,yi,DI),h.fk=function(t){return De(t,168)},h.gk=function(t){return We(r3,dt,168,t,0,1)},I(Gn,"EcorePackageImpl/36",1269),D(1270,1,yi,jS),h.fk=function(t){return De(t,85)},h.gk=function(t){return We(HSe,Rn,85,t,0,1)},I(Gn,"EcorePackageImpl/37",1270),D(1271,1,yi,E1),h.fk=function(t){return De(t,599)},h.gk=function(t){return We(jPe,Rn,599,t,0,1)},I(Gn,"EcorePackageImpl/38",1271),D(1272,1,yi,ok),h.fk=function(t){return!1},h.gk=function(t){return We(rBe,Rn,2216,t,0,1)},I(Gn,"EcorePackageImpl/39",1272),D(1237,1,yi,gre),h.fk=function(t){return De(t,90)},h.gk=function(t){return We(Vf,Rn,29,t,0,1)},I(Gn,"EcorePackageImpl/4",1237),D(1273,1,yi,ck),h.fk=function(t){return De(t,191)},h.gk=function(t){return We(i3,dt,191,t,0,1)},I(Gn,"EcorePackageImpl/40",1273),D(1274,1,yi,II),h.fk=function(t){return Ia(t)},h.gk=function(t){return We(zt,dt,2,t,6,1)},I(Gn,"EcorePackageImpl/41",1274),D(1275,1,yi,xm),h.fk=function(t){return De(t,596)},h.gk=function(t){return We(wPe,Rn,596,t,0,1)},I(Gn,"EcorePackageImpl/42",1275),D(1276,1,yi,$S),h.fk=function(t){return!1},h.gk=function(t){return We(iBe,dt,2217,t,0,1)},I(Gn,"EcorePackageImpl/43",1276),D(1277,1,yi,OI),h.fk=function(t){return De(t,44)},h.gk=function(t){return We(uv,XU,44,t,0,1)},I(Gn,"EcorePackageImpl/44",1277),D(1238,1,yi,U0),h.fk=function(t){return De(t,142)},h.gk=function(t){return We(l1,Rn,142,t,0,1)},I(Gn,"EcorePackageImpl/5",1238),D(1239,1,yi,zS),h.fk=function(t){return De(t,156)},h.gk=function(t){return We(tpe,Rn,156,t,0,1)},I(Gn,"EcorePackageImpl/6",1239),D(1240,1,yi,T1),h.fk=function(t){return De(t,469)},h.gk=function(t){return We(TY,Rn,685,t,0,1)},I(Gn,"EcorePackageImpl/7",1240),D(1241,1,yi,C1),h.fk=function(t){return De(t,582)},h.gk=function(t){return We(wp,Rn,694,t,0,1)},I(Gn,"EcorePackageImpl/8",1241),D(1242,1,yi,pre),h.fk=function(t){return De(t,480)},h.gk=function(t){return We(RM,Rn,480,t,0,1)},I(Gn,"EcorePackageImpl/9",1242),D(1038,2080,Z4t,IJe),h.Mi=function(t,n){b4n(this,l(n,424))},h.Qi=function(t,n){Apt(this,t,l(n,424))},I(Gn,"MinimalEObjectImpl/1ArrayDelegatingAdapterList",1038),D(1039,152,YP,nat),h.jj=function(){return this.a.a},I(Gn,"MinimalEObjectImpl/1ArrayDelegatingAdapterList/1",1039),D(1067,1066,{},bnt),I("org.eclipse.emf.ecore.plugin","EcorePlugin",1067);var jPe=ks(_5t,"Resource");D(799,1524,A5t),h.Hl=function(t){},h.Il=function(t){},h.El=function(){return!this.a&&(this.a=new Pie(this)),this.a},h.Fl=function(t){var n,r,a,o,f;if(a=t.length,a>0)if(Xn(0,t.length),t.charCodeAt(0)==47){for(f=new Bu(4),o=1,n=1;n0&&(t=(Ga(0,r,t.length),t.substr(0,r))));return Ukn(this,t)},h.Gl=function(){return this.c},h.Ib=function(){var t;return _m(this.Rm)+"@"+(t=es(this)>>>0,t.toString(16))+" uri='"+this.d+"'"},h.b=!1,I(s0e,"ResourceImpl",799),D(1525,799,A5t,kQe),I(s0e,"BinaryResourceImpl",1525),D(1190,708,Zfe),h.bj=function(t){return De(t,58)?Bpn(this,l(t,58)):De(t,599)?new or(l(t,599).El()):qe(t)===qe(this.f)?l(t,16).Kc():(Fk(),fF.a)},h.Ob=function(){return x9e(this)},h.a=!1,I(us,"EcoreUtil/ContentTreeIterator",1190),D(1526,1190,Zfe,Ist),h.bj=function(t){return qe(t)===qe(this.f)?l(t,15).Kc():new Lct(l(t,58))},I(s0e,"ResourceImpl/5",1526),D(658,2092,b5t,Pie),h.Hc=function(t){return this.i<=4?jE(this,t):De(t,54)&&l(t,54).Jh()==this.a},h.Mi=function(t,n){t==this.i-1&&(this.a.b||(this.a.b=!0))},h.Oi=function(t,n){t==0?this.a.b||(this.a.b=!0):Noe(this,t,n)},h.Qi=function(t,n){},h.Ri=function(t,n,r){},h.Lj=function(){return 2},h.jj=function(){return this.a},h.Mj=function(){return!0},h.Nj=function(t,n){var r;return r=l(t,54),n=r.fi(this.a,n),n},h.Oj=function(t,n){var r;return r=l(t,54),r.fi(null,n)},h.Pj=function(){return!1},h.Si=function(){return!0},h.aj=function(t){return We(Xb,Rn,58,t,0,1)},h.Yi=function(){return!1},I(s0e,"ResourceImpl/ContentsEList",658),D(970,2062,iT,EQe),h.fd=function(t){return this.a.Ki(t)},h.gc=function(){return this.a.gc()},I(us,"AbstractSequentialInternalEList/1",970);var $Pe,zPe,io,qPe;D(634,1,{},Nit);var SY,_Y;I(us,"BasicExtendedMetaData",634),D(1181,1,{},Btt),h.Jl=function(){return null},h.Kl=function(){return this.a==-2&&Ye(this,Uxn(this.d,this.b)),this.a},h.Ll=function(){return null},h.Ml=function(){return Cn(),Cn(),_o},h.xe=function(){return this.c==ET&&mt(this,J1t(this.d,this.b)),this.c},h.Nl=function(){return 0},h.a=-2,h.c=ET,I(us,"BasicExtendedMetaData/EClassExtendedMetaDataImpl",1181),D(1182,1,{},sct),h.Jl=function(){return this.a==(eE(),SY)&&Mt(this,VSn(this.f,this.b)),this.a},h.Kl=function(){return 0},h.Ll=function(){return this.c==(eE(),SY)&&Je(this,USn(this.f,this.b)),this.c},h.Ml=function(){return!this.d&&Wt(this,LAn(this.f,this.b)),this.d},h.xe=function(){return this.e==ET&&_n(this,J1t(this.f,this.b)),this.e},h.Nl=function(){return this.g==-2&&Yt(this,lxn(this.f,this.b)),this.g},h.e=ET,h.g=-2,I(us,"BasicExtendedMetaData/EDataTypeExtendedMetaDataImpl",1182),D(1180,1,{},Ftt),h.b=!1,h.c=!1,I(us,"BasicExtendedMetaData/EPackageExtendedMetaDataImpl",1180),D(1183,1,{},act),h.c=-2,h.e=ET,h.f=ET,I(us,"BasicExtendedMetaData/EStructuralFeatureExtendedMetaDataImpl",1183),D(593,632,kc,Jq),h.Lj=function(){return this.c},h.ol=function(){return!1},h.Wi=function(t,n){return n},h.c=0,I(us,"EDataTypeEList",593);var HPe=ks(us,"FeatureMap");D(78,593,{3:1,4:1,20:1,31:1,56:1,16:1,15:1,59:1,70:1,66:1,61:1,79:1,160:1,220:1,2036:1,71:1,97:1},Ls),h.bd=function(t,n){uCn(this,t,l(n,76))},h.Fc=function(t){return _Tn(this,l(t,76))},h.Hi=function(t){Ogn(this,l(t,76))},h.Nj=function(t,n){return e0n(this,l(t,76),n)},h.Oj=function(t,n){return d4e(this,l(t,76),n)},h.Ti=function(t,n){return P_n(this,t,n)},h.Wi=function(t,n){return xMn(this,t,l(n,76))},h.hd=function(t,n){return XCn(this,t,l(n,76))},h.Uj=function(t,n){return t0n(this,l(t,76),n)},h.Vj=function(t,n){return uit(this,l(t,76),n)},h.Wj=function(t,n,r){return Q8n(this,l(t,76),l(n,76),r)},h.Zi=function(t,n){return Aue(this,t,l(n,76))},h.Ol=function(t,n){return fke(this,t,n)},h.cd=function(t,n){var r,a,o,f,g,w,E,C,L;for(C=new Lw(n.gc()),o=n.Kc();o.Ob();)if(a=l(o.Pb(),76),f=a.Lk(),up(this.e,f))(!f.Si()||!qH(this,f,a.md())&&!jE(C,a))&&qr(C,a);else{for(L=Wu(this.e.Dh(),f),r=l(this.g,124),g=!0,w=0;w=0;)if(n=t[this.c],this.k.am(n.Lk()))return this.j=this.f?n:n.md(),this.i=-2,!0;return this.i=-1,this.g=-1,!1},I(us,"BasicFeatureMap/FeatureEIterator",420),D(676,420,lg,Use),h.ul=function(){return!0},I(us,"BasicFeatureMap/ResolvingFeatureEIterator",676),D(968,496,KG,Snt),h.pj=function(){return this},I(us,"EContentsEList/1",968),D(969,496,KG,Xtt),h.ul=function(){return!1},I(us,"EContentsEList/2",969),D(967,287,WG,_nt),h.wl=function(t){},h.Ob=function(){return!1},h.Sb=function(){return!1},I(us,"EContentsEList/FeatureIteratorImpl/1",967),D(840,593,kc,yye),h.Ni=function(){this.a=!0},h.Qj=function(){return this.a},h.Gk=function(){var t;$r(this),hh(this.e)?(t=this.a,this.a=!1,Ni(this.e,new h0(this.e,2,this.c,t,!1))):this.a=!1},h.a=!1,I(us,"EDataTypeEList/Unsettable",840),D(1958,593,kc,Nnt),h.Si=function(){return!0},I(us,"EDataTypeUniqueEList",1958),D(1959,840,kc,Pnt),h.Si=function(){return!0},I(us,"EDataTypeUniqueEList/Unsettable",1959),D(147,83,kc,ml),h.nl=function(){return!0},h.Wi=function(t,n){return Ex(this,t,l(n,58))},I(us,"EObjectContainmentEList/Resolving",147),D(1184,555,kc,Bnt),h.nl=function(){return!0},h.Wi=function(t,n){return Ex(this,t,l(n,58))},I(us,"EObjectContainmentEList/Unsettable/Resolving",1184),D(766,14,kc,a4e),h.Ni=function(){this.a=!0},h.Qj=function(){return this.a},h.Gk=function(){var t;$r(this),hh(this.e)?(t=this.a,this.a=!1,Ni(this.e,new h0(this.e,2,this.c,t,!1))):this.a=!1},h.a=!1,I(us,"EObjectContainmentWithInverseEList/Unsettable",766),D(1222,766,kc,Yrt),h.nl=function(){return!0},h.Wi=function(t,n){return Ex(this,t,l(n,58))},I(us,"EObjectContainmentWithInverseEList/Unsettable/Resolving",1222),D(757,505,kc,xye),h.Ni=function(){this.a=!0},h.Qj=function(){return this.a},h.Gk=function(){var t;$r(this),hh(this.e)?(t=this.a,this.a=!1,Ni(this.e,new h0(this.e,2,this.c,t,!1))):this.a=!1},h.a=!1,I(us,"EObjectEList/Unsettable",757),D(338,505,kc,$5),h.nl=function(){return!0},h.Wi=function(t,n){return Ex(this,t,l(n,58))},I(us,"EObjectResolvingEList",338),D(1844,757,kc,Fnt),h.nl=function(){return!0},h.Wi=function(t,n){return Ex(this,t,l(n,58))},I(us,"EObjectResolvingEList/Unsettable",1844),D(1527,1,{},bre);var Z_t;I(us,"EObjectValidator",1527),D(559,505,kc,pH),h.il=function(){return this.d},h.jl=function(){return this.b},h.Mj=function(){return!0},h.ml=function(){return!0},h.b=0,I(us,"EObjectWithInverseEList",559),D(1225,559,kc,Xrt),h.ll=function(){return!0},I(us,"EObjectWithInverseEList/ManyInverse",1225),D(635,559,kc,fae),h.Ni=function(){this.a=!0},h.Qj=function(){return this.a},h.Gk=function(){var t;$r(this),hh(this.e)?(t=this.a,this.a=!1,Ni(this.e,new h0(this.e,2,this.c,t,!1))):this.a=!1},h.a=!1,I(us,"EObjectWithInverseEList/Unsettable",635),D(1224,635,kc,Qrt),h.ll=function(){return!0},I(us,"EObjectWithInverseEList/Unsettable/ManyInverse",1224),D(767,559,kc,o4e),h.nl=function(){return!0},h.Wi=function(t,n){return Ex(this,t,l(n,58))},I(us,"EObjectWithInverseResolvingEList",767),D(32,767,kc,Ln),h.ll=function(){return!0},I(us,"EObjectWithInverseResolvingEList/ManyInverse",32),D(768,635,kc,c4e),h.nl=function(){return!0},h.Wi=function(t,n){return Ex(this,t,l(n,58))},I(us,"EObjectWithInverseResolvingEList/Unsettable",768),D(1223,768,kc,Jrt),h.ll=function(){return!0},I(us,"EObjectWithInverseResolvingEList/Unsettable/ManyInverse",1223),D(1185,632,kc),h.Li=function(){return(this.b&1792)==0},h.Ni=function(){this.b|=1},h.kl=function(){return(this.b&4)!=0},h.Mj=function(){return(this.b&40)!=0},h.ll=function(){return(this.b&16)!=0},h.ml=function(){return(this.b&8)!=0},h.nl=function(){return(this.b&r4)!=0},h.al=function(){return(this.b&32)!=0},h.ol=function(){return(this.b&m0)!=0},h.fk=function(t){return this.d?Rct(this.d,t):this.Lk().Hk().fk(t)},h.Qj=function(){return this.b&2?(this.b&1)!=0:this.i!=0},h.Si=function(){return(this.b&128)!=0},h.Gk=function(){var t;$r(this),this.b&2&&(hh(this.e)?(t=(this.b&1)!=0,this.b&=-2,xk(this,new h0(this.e,2,ms(this.e.Dh(),this.Lk()),t,!1))):this.b&=-2)},h.Yi=function(){return(this.b&1536)==0},h.b=0,I(us,"EcoreEList/Generic",1185),D(1186,1185,kc,Vat),h.Lk=function(){return this.a},I(us,"EcoreEList/Dynamic",1186),D(765,66,Bd,kwe),h.aj=function(t){return bN(this.a.a,t)},I(us,"EcoreEMap/1",765),D(764,83,kc,a5e),h.Mi=function(t,n){oU(this.b,l(n,136))},h.Oi=function(t,n){zft(this.b)},h.Pi=function(t,n,r){var a;++(a=this.b,l(n,136),a).e},h.Qi=function(t,n){Fce(this.b,l(n,136))},h.Ri=function(t,n,r){Fce(this.b,l(r,136)),qe(r)===qe(n)&&l(r,136).Ci(Jln(l(n,136).ld())),oU(this.b,l(n,136))},I(us,"EcoreEMap/DelegateEObjectContainmentEList",764),D(1220,141,ASe,ift),I(us,"EcoreEMap/Unsettable",1220),D(1221,764,kc,Zrt),h.Ni=function(){this.a=!0},h.Qj=function(){return this.a},h.Gk=function(){var t;$r(this),hh(this.e)?(t=this.a,this.a=!1,Ni(this.e,new h0(this.e,2,this.c,t,!1))):this.a=!1},h.a=!1,I(us,"EcoreEMap/Unsettable/UnsettableDelegateEObjectContainmentEList",1221),D(1189,215,m6,Ust),h.a=!1,h.b=!1,I(us,"EcoreUtil/Copier",1189),D(759,1,Oa,Lct),h.Nb=function(t){Za(this,t)},h.Ob=function(){return F1t(this)},h.Pb=function(){var t;return F1t(this),t=this.b,this.b=null,t},h.Qb=function(){this.a.Qb()},I(us,"EcoreUtil/ProperContentIterator",759),D(1528,1527,{},dz);var eAt;I(us,"EcoreValidator",1528);var tAt;ks(us,"FeatureMapUtil/Validator"),D(1295,1,{2041:1},v5),h.am=function(t){return!0},I(us,"FeatureMapUtil/1",1295),D(773,1,{2041:1},qke),h.am=function(t){var n;return this.c==t?!0:(n=Bt(cr(this.a,t)),n==null?QSn(this,t)?(Lut(this.a,t,(Hn(),ST)),!0):(Lut(this.a,t,(Hn(),Pb)),!1):n==(Hn(),ST))},h.e=!1;var spe;I(us,"FeatureMapUtil/BasicValidator",773),D(774,45,m6,vye),I(us,"FeatureMapUtil/BasicValidator/Cache",774),D(509,56,{20:1,31:1,56:1,16:1,15:1,61:1,79:1,71:1,97:1},yO),h.bd=function(t,n){vbt(this.c,this.b,t,n)},h.Fc=function(t){return fke(this.c,this.b,t)},h.cd=function(t,n){return vLn(this.c,this.b,t,n)},h.Gc=function(t){return F_(this,t)},h.Gi=function(t,n){dwn(this.c,this.b,t,n)},h.Wk=function(t,n){return ike(this.c,this.b,t,n)},h.$i=function(t){return qU(this.c,this.b,t,!1)},h.Ii=function(){return cnt(this.c,this.b)},h.Ji=function(){return jln(this.c,this.b)},h.Ki=function(t){return vvn(this.c,this.b,t)},h.Xk=function(t,n){return Irt(this,t,n)},h.$b=function(){_8(this)},h.Hc=function(t){return qH(this.c,this.b,t)},h.Ic=function(t){return m3n(this.c,this.b,t)},h.Xb=function(t){return qU(this.c,this.b,t,!0)},h.Fk=function(t){return this},h.dd=function(t){return Cmn(this.c,this.b,t)},h.dc=function(){return _q(this)},h.Qj=function(){return!FN(this.c,this.b)},h.Kc=function(){return rwn(this.c,this.b)},h.ed=function(){return iwn(this.c,this.b)},h.fd=function(t){return P4n(this.c,this.b,t)},h.Ti=function(t,n){return Omt(this.c,this.b,t,n)},h.Ui=function(t,n){xvn(this.c,this.b,t,n)},h.gd=function(t){return hpt(this.c,this.b,t)},h.Mc=function(t){return y_n(this.c,this.b,t)},h.hd=function(t,n){return qmt(this.c,this.b,t,n)},h.Wb=function(t){EU(this.c,this.b),F_(this,l(t,15))},h.gc=function(){return N4n(this.c,this.b)},h.Pc=function(){return _bn(this.c,this.b)},h.Qc=function(t){return Smn(this.c,this.b,t)},h.Ib=function(){var t,n;for(n=new Up,n.a+="[",t=cnt(this.c,this.b);_ce(t);)Xo(n,j_(iU(t))),_ce(t)&&(n.a+=Co);return n.a+="]",n.a},h.Gk=function(){EU(this.c,this.b)},I(us,"FeatureMapUtil/FeatureEList",509),D(644,39,YP,Eoe),h.hj=function(t){return SA(this,t)},h.mj=function(t){var n,r,a,o,f,g,w;switch(this.d){case 1:case 2:{if(f=t.jj(),qe(f)===qe(this.c)&&SA(this,null)==t.hj(null))return this.g=t.ij(),t.gj()==1&&(this.d=1),!0;break}case 3:{switch(o=t.gj(),o){case 3:{if(f=t.jj(),qe(f)===qe(this.c)&&SA(this,null)==t.hj(null))return this.d=5,n=new Lw(2),qr(n,this.g),qr(n,t.ij()),this.g=n,!0;break}}break}case 5:{switch(o=t.gj(),o){case 3:{if(f=t.jj(),qe(f)===qe(this.c)&&SA(this,null)==t.hj(null))return r=l(this.g,16),r.Fc(t.ij()),!0;break}}break}case 4:{switch(o=t.gj(),o){case 3:{if(f=t.jj(),qe(f)===qe(this.c)&&SA(this,null)==t.hj(null))return this.d=1,this.g=t.ij(),!0;break}case 4:{if(f=t.jj(),qe(f)===qe(this.c)&&SA(this,null)==t.hj(null))return this.d=6,w=new Lw(2),qr(w,this.n),qr(w,t.kj()),this.n=w,g=he(le(Vr,1),di,28,15,[this.o,t.lj()]),this.g=g,!0;break}}break}case 6:{switch(o=t.gj(),o){case 4:{if(f=t.jj(),qe(f)===qe(this.c)&&SA(this,null)==t.hj(null))return r=l(this.n,16),r.Fc(t.kj()),g=l(this.g,53),a=We(Vr,di,28,g.length+1,15,1),pu(g,0,a,0,g.length),a[g.length]=t.lj(),this.g=a,!0;break}}break}}return!1},I(us,"FeatureMapUtil/FeatureENotificationImpl",644),D(564,509,{20:1,31:1,56:1,16:1,15:1,61:1,79:1,160:1,220:1,2036:1,71:1,97:1},nH),h.Ol=function(t,n){return fke(this.c,t,n)},h.Pl=function(t,n,r){return ike(this.c,t,n,r)},h.Ql=function(t,n,r){return Mke(this.c,t,n,r)},h.Rl=function(){return this},h.Sl=function(t,n){return pP(this.c,t,n)},h.Tl=function(t){return l(qU(this.c,this.b,t,!1),76).Lk()},h.Ul=function(t){return l(qU(this.c,this.b,t,!1),76).md()},h.Vl=function(){return this.a},h.Wl=function(t){return!FN(this.c,t)},h.Xl=function(t,n){HU(this.c,t,n)},h.Yl=function(t){return oft(this.c,t)},h.Zl=function(t){jdt(this.c,t)},I(us,"FeatureMapUtil/FeatureFeatureMap",564),D(1294,1,i0e,Ptt),h.Fk=function(t){return qU(this.b,this.a,-1,t)},h.Qj=function(){return!FN(this.b,this.a)},h.Wb=function(t){HU(this.b,this.a,t)},h.Gk=function(){EU(this.b,this.a)},I(us,"FeatureMapUtil/FeatureValue",1294);var c9,ape,ope,u9,nAt,gF=ks(nK,"AnyType");D(680,63,lp,Jie),I(nK,"InvalidDatatypeValueException",680);var AY=ks(nK,M5t),pF=ks(nK,D5t),VPe=ks(nK,I5t),rAt,tu,UPe,Sv,iAt,sAt,aAt,oAt,cAt,uAt,lAt,hAt,fAt,dAt,gAt,c7,pAt,u7,HM,bAt,C3,bF,mF,mAt,VM,UM;D(844,516,{110:1,94:1,93:1,58:1,54:1,99:1,857:1},zwe),h.Lh=function(t,n,r){switch(t){case 0:return r?(!this.c&&(this.c=new Ls(this,0)),this.c):(!this.c&&(this.c=new Ls(this,0)),this.c.b);case 1:return r?(!this.c&&(this.c=new Ls(this,0)),l(ku(this.c,(Gi(),Sv)),160)):(!this.c&&(this.c=new Ls(this,0)),l(l(ku(this.c,(Gi(),Sv)),160),220)).Vl();case 2:return r?(!this.b&&(this.b=new Ls(this,2)),this.b):(!this.b&&(this.b=new Ls(this,2)),this.b.b)}return sf(this,t-yr(this.ii()),Mn(this.j&2?(!this.k&&(this.k=new Sf),this.k).Nk():this.ii(),t),n,r)},h.Uh=function(t,n,r){var a;switch(n){case 0:return!this.c&&(this.c=new Ls(this,0)),hP(this.c,t,r);case 1:return(!this.c&&(this.c=new Ls(this,0)),l(l(ku(this.c,(Gi(),Sv)),160),71)).Xk(t,r);case 2:return!this.b&&(this.b=new Ls(this,2)),hP(this.b,t,r)}return a=l(Mn(this.j&2?(!this.k&&(this.k=new Sf),this.k).Nk():this.ii(),n),69),a.wk().Ak(this,V6e(this),n-yr(this.ii()),t,r)},h.Wh=function(t){switch(t){case 0:return!!this.c&&this.c.i!=0;case 1:return!(!this.c&&(this.c=new Ls(this,0)),l(ku(this.c,(Gi(),Sv)),160)).dc();case 2:return!!this.b&&this.b.i!=0}return nf(this,t-yr(this.ii()),Mn(this.j&2?(!this.k&&(this.k=new Sf),this.k).Nk():this.ii(),t))},h.bi=function(t,n){switch(t){case 0:!this.c&&(this.c=new Ls(this,0)),$O(this.c,n);return;case 1:(!this.c&&(this.c=new Ls(this,0)),l(l(ku(this.c,(Gi(),Sv)),160),220)).Wb(n);return;case 2:!this.b&&(this.b=new Ls(this,2)),$O(this.b,n);return}uf(this,t-yr(this.ii()),Mn(this.j&2?(!this.k&&(this.k=new Sf),this.k).Nk():this.ii(),t),n)},h.ii=function(){return Gi(),UPe},h.ki=function(t){switch(t){case 0:!this.c&&(this.c=new Ls(this,0)),$r(this.c);return;case 1:(!this.c&&(this.c=new Ls(this,0)),l(ku(this.c,(Gi(),Sv)),160)).$b();return;case 2:!this.b&&(this.b=new Ls(this,2)),$r(this.b);return}cf(this,t-yr(this.ii()),Mn(this.j&2?(!this.k&&(this.k=new Sf),this.k).Nk():this.ii(),t))},h.Ib=function(){var t;return this.j&4?g0(this):(t=new Af(g0(this)),t.a+=" (mixed: ",O_(t,this.c),t.a+=", anyAttribute: ",O_(t,this.b),t.a+=")",t.a)},I(ea,"AnyTypeImpl",844),D(681,516,{110:1,94:1,93:1,58:1,54:1,99:1,2119:1,681:1},yre),h.Lh=function(t,n,r){switch(t){case 0:return this.a;case 1:return this.b}return sf(this,t-yr((Gi(),c7)),Mn(this.j&2?(!this.k&&(this.k=new Sf),this.k).Nk():c7,t),n,r)},h.Wh=function(t){switch(t){case 0:return this.a!=null;case 1:return this.b!=null}return nf(this,t-yr((Gi(),c7)),Mn(this.j&2?(!this.k&&(this.k=new Sf),this.k).Nk():c7,t))},h.bi=function(t,n){switch(t){case 0:vr(this,ei(n));return;case 1:pr(this,ei(n));return}uf(this,t-yr((Gi(),c7)),Mn(this.j&2?(!this.k&&(this.k=new Sf),this.k).Nk():c7,t),n)},h.ii=function(){return Gi(),c7},h.ki=function(t){switch(t){case 0:this.a=null;return;case 1:this.b=null;return}cf(this,t-yr((Gi(),c7)),Mn(this.j&2?(!this.k&&(this.k=new Sf),this.k).Nk():c7,t))},h.Ib=function(){var t;return this.j&4?g0(this):(t=new Af(g0(this)),t.a+=" (data: ",Xo(t,this.a),t.a+=", target: ",Xo(t,this.b),t.a+=")",t.a)},h.a=null,h.b=null,I(ea,"ProcessingInstructionImpl",681),D(682,844,{110:1,94:1,93:1,58:1,54:1,99:1,857:1,2120:1,682:1},fJe),h.Lh=function(t,n,r){switch(t){case 0:return r?(!this.c&&(this.c=new Ls(this,0)),this.c):(!this.c&&(this.c=new Ls(this,0)),this.c.b);case 1:return r?(!this.c&&(this.c=new Ls(this,0)),l(ku(this.c,(Gi(),Sv)),160)):(!this.c&&(this.c=new Ls(this,0)),l(l(ku(this.c,(Gi(),Sv)),160),220)).Vl();case 2:return r?(!this.b&&(this.b=new Ls(this,2)),this.b):(!this.b&&(this.b=new Ls(this,2)),this.b.b);case 3:return!this.c&&(this.c=new Ls(this,0)),ei(pP(this.c,(Gi(),HM),!0));case 4:return l4e(this.a,(!this.c&&(this.c=new Ls(this,0)),ei(pP(this.c,(Gi(),HM),!0))));case 5:return this.a}return sf(this,t-yr((Gi(),u7)),Mn(this.j&2?(!this.k&&(this.k=new Sf),this.k).Nk():u7,t),n,r)},h.Wh=function(t){switch(t){case 0:return!!this.c&&this.c.i!=0;case 1:return!(!this.c&&(this.c=new Ls(this,0)),l(ku(this.c,(Gi(),Sv)),160)).dc();case 2:return!!this.b&&this.b.i!=0;case 3:return!this.c&&(this.c=new Ls(this,0)),ei(pP(this.c,(Gi(),HM),!0))!=null;case 4:return l4e(this.a,(!this.c&&(this.c=new Ls(this,0)),ei(pP(this.c,(Gi(),HM),!0))))!=null;case 5:return!!this.a}return nf(this,t-yr((Gi(),u7)),Mn(this.j&2?(!this.k&&(this.k=new Sf),this.k).Nk():u7,t))},h.bi=function(t,n){switch(t){case 0:!this.c&&(this.c=new Ls(this,0)),$O(this.c,n);return;case 1:(!this.c&&(this.c=new Ls(this,0)),l(l(ku(this.c,(Gi(),Sv)),160),220)).Wb(n);return;case 2:!this.b&&(this.b=new Ls(this,2)),$O(this.b,n);return;case 3:J5e(this,ei(n));return;case 4:J5e(this,u4e(this.a,n));return;case 5:Nn(this,l(n,156));return}uf(this,t-yr((Gi(),u7)),Mn(this.j&2?(!this.k&&(this.k=new Sf),this.k).Nk():u7,t),n)},h.ii=function(){return Gi(),u7},h.ki=function(t){switch(t){case 0:!this.c&&(this.c=new Ls(this,0)),$r(this.c);return;case 1:(!this.c&&(this.c=new Ls(this,0)),l(ku(this.c,(Gi(),Sv)),160)).$b();return;case 2:!this.b&&(this.b=new Ls(this,2)),$r(this.b);return;case 3:!this.c&&(this.c=new Ls(this,0)),HU(this.c,(Gi(),HM),null);return;case 4:J5e(this,u4e(this.a,null));return;case 5:this.a=null;return}cf(this,t-yr((Gi(),u7)),Mn(this.j&2?(!this.k&&(this.k=new Sf),this.k).Nk():u7,t))},I(ea,"SimpleAnyTypeImpl",682),D(683,516,{110:1,94:1,93:1,58:1,54:1,99:1,2121:1,683:1},dJe),h.Lh=function(t,n,r){switch(t){case 0:return r?(!this.a&&(this.a=new Ls(this,0)),this.a):(!this.a&&(this.a=new Ls(this,0)),this.a.b);case 1:return r?(!this.b&&(this.b=new xl((Tn(),No),Yc,this,1)),this.b):(!this.b&&(this.b=new xl((Tn(),No),Yc,this,1)),iN(this.b));case 2:return r?(!this.c&&(this.c=new xl((Tn(),No),Yc,this,2)),this.c):(!this.c&&(this.c=new xl((Tn(),No),Yc,this,2)),iN(this.c));case 3:return!this.a&&(this.a=new Ls(this,0)),ku(this.a,(Gi(),bF));case 4:return!this.a&&(this.a=new Ls(this,0)),ku(this.a,(Gi(),mF));case 5:return!this.a&&(this.a=new Ls(this,0)),ku(this.a,(Gi(),VM));case 6:return!this.a&&(this.a=new Ls(this,0)),ku(this.a,(Gi(),UM))}return sf(this,t-yr((Gi(),C3)),Mn(this.j&2?(!this.k&&(this.k=new Sf),this.k).Nk():C3,t),n,r)},h.Uh=function(t,n,r){var a;switch(n){case 0:return!this.a&&(this.a=new Ls(this,0)),hP(this.a,t,r);case 1:return!this.b&&(this.b=new xl((Tn(),No),Yc,this,1)),Uq(this.b,t,r);case 2:return!this.c&&(this.c=new xl((Tn(),No),Yc,this,2)),Uq(this.c,t,r);case 5:return!this.a&&(this.a=new Ls(this,0)),Irt(ku(this.a,(Gi(),VM)),t,r)}return a=l(Mn(this.j&2?(!this.k&&(this.k=new Sf),this.k).Nk():(Gi(),C3),n),69),a.wk().Ak(this,V6e(this),n-yr((Gi(),C3)),t,r)},h.Wh=function(t){switch(t){case 0:return!!this.a&&this.a.i!=0;case 1:return!!this.b&&this.b.f!=0;case 2:return!!this.c&&this.c.f!=0;case 3:return!this.a&&(this.a=new Ls(this,0)),!_q(ku(this.a,(Gi(),bF)));case 4:return!this.a&&(this.a=new Ls(this,0)),!_q(ku(this.a,(Gi(),mF)));case 5:return!this.a&&(this.a=new Ls(this,0)),!_q(ku(this.a,(Gi(),VM)));case 6:return!this.a&&(this.a=new Ls(this,0)),!_q(ku(this.a,(Gi(),UM)))}return nf(this,t-yr((Gi(),C3)),Mn(this.j&2?(!this.k&&(this.k=new Sf),this.k).Nk():C3,t))},h.bi=function(t,n){switch(t){case 0:!this.a&&(this.a=new Ls(this,0)),$O(this.a,n);return;case 1:!this.b&&(this.b=new xl((Tn(),No),Yc,this,1)),_V(this.b,n);return;case 2:!this.c&&(this.c=new xl((Tn(),No),Yc,this,2)),_V(this.c,n);return;case 3:!this.a&&(this.a=new Ls(this,0)),_8(ku(this.a,(Gi(),bF))),!this.a&&(this.a=new Ls(this,0)),F_(ku(this.a,bF),l(n,16));return;case 4:!this.a&&(this.a=new Ls(this,0)),_8(ku(this.a,(Gi(),mF))),!this.a&&(this.a=new Ls(this,0)),F_(ku(this.a,mF),l(n,16));return;case 5:!this.a&&(this.a=new Ls(this,0)),_8(ku(this.a,(Gi(),VM))),!this.a&&(this.a=new Ls(this,0)),F_(ku(this.a,VM),l(n,16));return;case 6:!this.a&&(this.a=new Ls(this,0)),_8(ku(this.a,(Gi(),UM))),!this.a&&(this.a=new Ls(this,0)),F_(ku(this.a,UM),l(n,16));return}uf(this,t-yr((Gi(),C3)),Mn(this.j&2?(!this.k&&(this.k=new Sf),this.k).Nk():C3,t),n)},h.ii=function(){return Gi(),C3},h.ki=function(t){switch(t){case 0:!this.a&&(this.a=new Ls(this,0)),$r(this.a);return;case 1:!this.b&&(this.b=new xl((Tn(),No),Yc,this,1)),this.b.c.$b();return;case 2:!this.c&&(this.c=new xl((Tn(),No),Yc,this,2)),this.c.c.$b();return;case 3:!this.a&&(this.a=new Ls(this,0)),_8(ku(this.a,(Gi(),bF)));return;case 4:!this.a&&(this.a=new Ls(this,0)),_8(ku(this.a,(Gi(),mF)));return;case 5:!this.a&&(this.a=new Ls(this,0)),_8(ku(this.a,(Gi(),VM)));return;case 6:!this.a&&(this.a=new Ls(this,0)),_8(ku(this.a,(Gi(),UM)));return}cf(this,t-yr((Gi(),C3)),Mn(this.j&2?(!this.k&&(this.k=new Sf),this.k).Nk():C3,t))},h.Ib=function(){var t;return this.j&4?g0(this):(t=new Af(g0(this)),t.a+=" (mixed: ",O_(t,this.a),t.a+=")",t.a)},I(ea,"XMLTypeDocumentRootImpl",683),D(2028,720,{110:1,94:1,93:1,480:1,155:1,58:1,114:1,54:1,99:1,158:1,119:1,120:1,2122:1},uk),h.ri=function(t,n){switch(t.hk()){case 7:case 8:case 9:case 10:case 16:case 22:case 23:case 24:case 25:case 26:case 32:case 33:case 34:case 36:case 37:case 44:case 45:case 50:case 51:case 53:case 55:case 56:case 57:case 58:case 60:case 61:case 4:return n==null?null:xc(n);case 19:case 28:case 29:case 35:case 38:case 39:case 41:case 46:case 52:case 54:case 5:return ei(n);case 6:return hfn(l(n,195));case 12:case 47:case 49:case 11:return Lvt(this,t,n);case 13:return n==null?null:kLn(l(n,247));case 15:case 14:return n==null?null:_gn(ze(Ge(n)));case 17:return Sgt((Gi(),n));case 18:return Sgt(n);case 21:case 20:return n==null?null:Agn(l(n,161).a);case 27:return ffn(l(n,195));case 30:return $dt((Gi(),l(n,15)));case 31:return $dt(l(n,15));case 40:return gfn((Gi(),n));case 42:return _gt((Gi(),n));case 43:return _gt(n);case 59:case 48:return dfn((Gi(),n));default:throw ue(new Yn(yT+t.xe()+t3))}},h.si=function(t){var n,r,a,o,f;switch(t.G==-1&&(t.G=(r=Ah(t),r?f2(r.vi(),t):-1)),t.G){case 0:return n=new zwe,n;case 1:return a=new yre,a;case 2:return o=new fJe,o;case 3:return f=new dJe,f;default:throw ue(new Yn(qfe+t.zb+t3))}},h.ti=function(t,n){var r,a,o,f,g,w,E,C,L,B,z,V,J,te,fe,Te;switch(t.hk()){case 5:case 52:case 4:return n;case 6:return y6n(n);case 8:case 7:return n==null?null:axn(n);case 9:return n==null?null:fN(Oh((a=Tu(n,!0),a.length>0&&(Xn(0,a.length),a.charCodeAt(0)==43)?(Xn(1,a.length+1),a.substr(1)):a),-128,127)<<24>>24);case 10:return n==null?null:fN(Oh((o=Tu(n,!0),o.length>0&&(Xn(0,o.length),o.charCodeAt(0)==43)?(Xn(1,o.length+1),o.substr(1)):o),-128,127)<<24>>24);case 11:return ei(Kw(this,(Gi(),aAt),n));case 12:return ei(Kw(this,(Gi(),oAt),n));case 13:return n==null?null:new h3e(Tu(n,!0));case 15:case 14:return LTn(n);case 16:return ei(Kw(this,(Gi(),cAt),n));case 17:return q1t((Gi(),n));case 18:return q1t(n);case 28:case 29:case 35:case 38:case 39:case 41:case 54:case 19:return Tu(n,!0);case 21:case 20:return jTn(n);case 22:return ei(Kw(this,(Gi(),uAt),n));case 23:return ei(Kw(this,(Gi(),lAt),n));case 24:return ei(Kw(this,(Gi(),hAt),n));case 25:return ei(Kw(this,(Gi(),fAt),n));case 26:return ei(Kw(this,(Gi(),dAt),n));case 27:return c6n(n);case 30:return H1t((Gi(),n));case 31:return H1t(n);case 32:return n==null?null:pt(Oh((L=Tu(n,!0),L.length>0&&(Xn(0,L.length),L.charCodeAt(0)==43)?(Xn(1,L.length+1),L.substr(1)):L),lo,Ii));case 33:return n==null?null:new ob((B=Tu(n,!0),B.length>0&&(Xn(0,B.length),B.charCodeAt(0)==43)?(Xn(1,B.length+1),B.substr(1)):B));case 34:return n==null?null:pt(Oh((z=Tu(n,!0),z.length>0&&(Xn(0,z.length),z.charCodeAt(0)==43)?(Xn(1,z.length+1),z.substr(1)):z),lo,Ii));case 36:return n==null?null:ap(KU((V=Tu(n,!0),V.length>0&&(Xn(0,V.length),V.charCodeAt(0)==43)?(Xn(1,V.length+1),V.substr(1)):V)));case 37:return n==null?null:ap(KU((J=Tu(n,!0),J.length>0&&(Xn(0,J.length),J.charCodeAt(0)==43)?(Xn(1,J.length+1),J.substr(1)):J)));case 40:return s7n((Gi(),n));case 42:return V1t((Gi(),n));case 43:return V1t(n);case 44:return n==null?null:new ob((te=Tu(n,!0),te.length>0&&(Xn(0,te.length),te.charCodeAt(0)==43)?(Xn(1,te.length+1),te.substr(1)):te));case 45:return n==null?null:new ob((fe=Tu(n,!0),fe.length>0&&(Xn(0,fe.length),fe.charCodeAt(0)==43)?(Xn(1,fe.length+1),fe.substr(1)):fe));case 46:return Tu(n,!1);case 47:return ei(Kw(this,(Gi(),gAt),n));case 59:case 48:return i7n((Gi(),n));case 49:return ei(Kw(this,(Gi(),pAt),n));case 50:return n==null?null:_E(Oh((Te=Tu(n,!0),Te.length>0&&(Xn(0,Te.length),Te.charCodeAt(0)==43)?(Xn(1,Te.length+1),Te.substr(1)):Te),JG,32767)<<16>>16);case 51:return n==null?null:_E(Oh((f=Tu(n,!0),f.length>0&&(Xn(0,f.length),f.charCodeAt(0)==43)?(Xn(1,f.length+1),f.substr(1)):f),JG,32767)<<16>>16);case 53:return ei(Kw(this,(Gi(),bAt),n));case 55:return n==null?null:_E(Oh((g=Tu(n,!0),g.length>0&&(Xn(0,g.length),g.charCodeAt(0)==43)?(Xn(1,g.length+1),g.substr(1)):g),JG,32767)<<16>>16);case 56:return n==null?null:_E(Oh((w=Tu(n,!0),w.length>0&&(Xn(0,w.length),w.charCodeAt(0)==43)?(Xn(1,w.length+1),w.substr(1)):w),JG,32767)<<16>>16);case 57:return n==null?null:ap(KU((E=Tu(n,!0),E.length>0&&(Xn(0,E.length),E.charCodeAt(0)==43)?(Xn(1,E.length+1),E.substr(1)):E)));case 58:return n==null?null:ap(KU((C=Tu(n,!0),C.length>0&&(Xn(0,C.length),C.charCodeAt(0)==43)?(Xn(1,C.length+1),C.substr(1)):C)));case 60:return n==null?null:pt(Oh((r=Tu(n,!0),r.length>0&&(Xn(0,r.length),r.charCodeAt(0)==43)?(Xn(1,r.length+1),r.substr(1)):r),lo,Ii));case 61:return n==null?null:pt(Oh(Tu(n,!0),lo,Ii));default:throw ue(new Yn(yT+t.xe()+t3))}};var vAt,GPe,wAt,KPe;I(ea,"XMLTypeFactoryImpl",2028),D(594,184,{110:1,94:1,93:1,155:1,197:1,58:1,241:1,114:1,54:1,99:1,158:1,184:1,119:1,120:1,690:1,2044:1,594:1},dat),h.N=!1,h.O=!1;var yAt=!1;I(ea,"XMLTypePackageImpl",594),D(1961,1,{851:1},lk),h.Kk=function(){return xke(),LAt},I(ea,"XMLTypePackageImpl/1",1961),D(1970,1,yi,qS),h.fk=function(t){return Ia(t)},h.gk=function(t){return We(zt,dt,2,t,6,1)},I(ea,"XMLTypePackageImpl/10",1970),D(1971,1,yi,mre),h.fk=function(t){return Ia(t)},h.gk=function(t){return We(zt,dt,2,t,6,1)},I(ea,"XMLTypePackageImpl/11",1971),D(1972,1,yi,vre),h.fk=function(t){return Ia(t)},h.gk=function(t){return We(zt,dt,2,t,6,1)},I(ea,"XMLTypePackageImpl/12",1972),D(1973,1,yi,p8),h.fk=function(t){return fy(t)},h.gk=function(t){return We(ta,dt,345,t,7,1)},I(ea,"XMLTypePackageImpl/13",1973),D(1974,1,yi,R$),h.fk=function(t){return Ia(t)},h.gk=function(t){return We(zt,dt,2,t,6,1)},I(ea,"XMLTypePackageImpl/14",1974),D(1975,1,yi,j$),h.fk=function(t){return De(t,15)},h.gk=function(t){return We(mf,Qy,15,t,0,1)},I(ea,"XMLTypePackageImpl/15",1975),D(1976,1,yi,wre),h.fk=function(t){return De(t,15)},h.gk=function(t){return We(mf,Qy,15,t,0,1)},I(ea,"XMLTypePackageImpl/16",1976),D(1977,1,yi,$$),h.fk=function(t){return Ia(t)},h.gk=function(t){return We(zt,dt,2,t,6,1)},I(ea,"XMLTypePackageImpl/17",1977),D(1978,1,yi,z$),h.fk=function(t){return De(t,161)},h.gk=function(t){return We(_T,dt,161,t,0,1)},I(ea,"XMLTypePackageImpl/18",1978),D(1979,1,yi,NI),h.fk=function(t){return Ia(t)},h.gk=function(t){return We(zt,dt,2,t,6,1)},I(ea,"XMLTypePackageImpl/19",1979),D(1962,1,yi,xre),h.fk=function(t){return De(t,857)},h.gk=function(t){return We(gF,Rn,857,t,0,1)},I(ea,"XMLTypePackageImpl/2",1962),D(1980,1,yi,HS),h.fk=function(t){return Ia(t)},h.gk=function(t){return We(zt,dt,2,t,6,1)},I(ea,"XMLTypePackageImpl/20",1980),D(1981,1,yi,kre),h.fk=function(t){return Ia(t)},h.gk=function(t){return We(zt,dt,2,t,6,1)},I(ea,"XMLTypePackageImpl/21",1981),D(1982,1,yi,Ere),h.fk=function(t){return Ia(t)},h.gk=function(t){return We(zt,dt,2,t,6,1)},I(ea,"XMLTypePackageImpl/22",1982),D(1983,1,yi,Tre),h.fk=function(t){return Ia(t)},h.gk=function(t){return We(zt,dt,2,t,6,1)},I(ea,"XMLTypePackageImpl/23",1983),D(1984,1,yi,Cre),h.fk=function(t){return De(t,195)},h.gk=function(t){return We(Al,dt,195,t,0,2)},I(ea,"XMLTypePackageImpl/24",1984),D(1985,1,yi,Sre),h.fk=function(t){return Ia(t)},h.gk=function(t){return We(zt,dt,2,t,6,1)},I(ea,"XMLTypePackageImpl/25",1985),D(1986,1,yi,q$),h.fk=function(t){return Ia(t)},h.gk=function(t){return We(zt,dt,2,t,6,1)},I(ea,"XMLTypePackageImpl/26",1986),D(1987,1,yi,_re),h.fk=function(t){return De(t,15)},h.gk=function(t){return We(mf,Qy,15,t,0,1)},I(ea,"XMLTypePackageImpl/27",1987),D(1988,1,yi,Are),h.fk=function(t){return De(t,15)},h.gk=function(t){return We(mf,Qy,15,t,0,1)},I(ea,"XMLTypePackageImpl/28",1988),D(1989,1,yi,Lre),h.fk=function(t){return Ia(t)},h.gk=function(t){return We(zt,dt,2,t,6,1)},I(ea,"XMLTypePackageImpl/29",1989),D(1963,1,yi,H$),h.fk=function(t){return De(t,681)},h.gk=function(t){return We(AY,Rn,2119,t,0,1)},I(ea,"XMLTypePackageImpl/3",1963),D(1990,1,yi,Mre),h.fk=function(t){return De(t,17)},h.gk=function(t){return We(ro,dt,17,t,0,1)},I(ea,"XMLTypePackageImpl/30",1990),D(1991,1,yi,Dre),h.fk=function(t){return Ia(t)},h.gk=function(t){return We(zt,dt,2,t,6,1)},I(ea,"XMLTypePackageImpl/31",1991),D(1992,1,yi,VS),h.fk=function(t){return De(t,168)},h.gk=function(t){return We(r3,dt,168,t,0,1)},I(ea,"XMLTypePackageImpl/32",1992),D(1993,1,yi,Ire),h.fk=function(t){return Ia(t)},h.gk=function(t){return We(zt,dt,2,t,6,1)},I(ea,"XMLTypePackageImpl/33",1993),D(1994,1,yi,Ore),h.fk=function(t){return Ia(t)},h.gk=function(t){return We(zt,dt,2,t,6,1)},I(ea,"XMLTypePackageImpl/34",1994),D(1995,1,yi,Nre),h.fk=function(t){return Ia(t)},h.gk=function(t){return We(zt,dt,2,t,6,1)},I(ea,"XMLTypePackageImpl/35",1995),D(1996,1,yi,Pre),h.fk=function(t){return Ia(t)},h.gk=function(t){return We(zt,dt,2,t,6,1)},I(ea,"XMLTypePackageImpl/36",1996),D(1997,1,yi,Bre),h.fk=function(t){return De(t,15)},h.gk=function(t){return We(mf,Qy,15,t,0,1)},I(ea,"XMLTypePackageImpl/37",1997),D(1998,1,yi,Fre),h.fk=function(t){return De(t,15)},h.gk=function(t){return We(mf,Qy,15,t,0,1)},I(ea,"XMLTypePackageImpl/38",1998),D(1999,1,yi,V$),h.fk=function(t){return Ia(t)},h.gk=function(t){return We(zt,dt,2,t,6,1)},I(ea,"XMLTypePackageImpl/39",1999),D(1964,1,yi,Rre),h.fk=function(t){return De(t,682)},h.gk=function(t){return We(pF,Rn,2120,t,0,1)},I(ea,"XMLTypePackageImpl/4",1964),D(2e3,1,yi,U$),h.fk=function(t){return Ia(t)},h.gk=function(t){return We(zt,dt,2,t,6,1)},I(ea,"XMLTypePackageImpl/40",2e3),D(2001,1,yi,jre),h.fk=function(t){return Ia(t)},h.gk=function(t){return We(zt,dt,2,t,6,1)},I(ea,"XMLTypePackageImpl/41",2001),D(2002,1,yi,PI),h.fk=function(t){return Ia(t)},h.gk=function(t){return We(zt,dt,2,t,6,1)},I(ea,"XMLTypePackageImpl/42",2002),D(2003,1,yi,$re),h.fk=function(t){return Ia(t)},h.gk=function(t){return We(zt,dt,2,t,6,1)},I(ea,"XMLTypePackageImpl/43",2003),D(2004,1,yi,G$),h.fk=function(t){return Ia(t)},h.gk=function(t){return We(zt,dt,2,t,6,1)},I(ea,"XMLTypePackageImpl/44",2004),D(2005,1,yi,zre),h.fk=function(t){return De(t,191)},h.gk=function(t){return We(i3,dt,191,t,0,1)},I(ea,"XMLTypePackageImpl/45",2005),D(2006,1,yi,K$),h.fk=function(t){return Ia(t)},h.gk=function(t){return We(zt,dt,2,t,6,1)},I(ea,"XMLTypePackageImpl/46",2006),D(2007,1,yi,qre),h.fk=function(t){return Ia(t)},h.gk=function(t){return We(zt,dt,2,t,6,1)},I(ea,"XMLTypePackageImpl/47",2007),D(2008,1,yi,W$),h.fk=function(t){return Ia(t)},h.gk=function(t){return We(zt,dt,2,t,6,1)},I(ea,"XMLTypePackageImpl/48",2008),D(2009,1,yi,Y$),h.fk=function(t){return De(t,191)},h.gk=function(t){return We(i3,dt,191,t,0,1)},I(ea,"XMLTypePackageImpl/49",2009),D(1965,1,yi,X$),h.fk=function(t){return De(t,683)},h.gk=function(t){return We(VPe,Rn,2121,t,0,1)},I(ea,"XMLTypePackageImpl/5",1965),D(2010,1,yi,BI),h.fk=function(t){return De(t,168)},h.gk=function(t){return We(r3,dt,168,t,0,1)},I(ea,"XMLTypePackageImpl/50",2010),D(2011,1,yi,w5),h.fk=function(t){return Ia(t)},h.gk=function(t){return We(zt,dt,2,t,6,1)},I(ea,"XMLTypePackageImpl/51",2011),D(2012,1,yi,US),h.fk=function(t){return De(t,17)},h.gk=function(t){return We(ro,dt,17,t,0,1)},I(ea,"XMLTypePackageImpl/52",2012),D(1966,1,yi,S1),h.fk=function(t){return Ia(t)},h.gk=function(t){return We(zt,dt,2,t,6,1)},I(ea,"XMLTypePackageImpl/6",1966),D(1967,1,yi,Q$),h.fk=function(t){return De(t,195)},h.gk=function(t){return We(Al,dt,195,t,0,2)},I(ea,"XMLTypePackageImpl/7",1967),D(1968,1,yi,hk),h.fk=function(t){return hy(t)},h.gk=function(t){return We(Ns,dt,485,t,8,1)},I(ea,"XMLTypePackageImpl/8",1968),D(1969,1,yi,FI),h.fk=function(t){return De(t,222)},h.gk=function(t){return We(jx,dt,222,t,0,1)},I(ea,"XMLTypePackageImpl/9",1969);var nd,N2,GM,LY,ye;D(55,63,lp,ri),I(y2,"RegEx/ParseException",55),D(836,1,{},J$),h.bm=function(t){return tr*16)throw ue(new ri(ai((Jr(),H4t))));r=r*16+o}while(!0);if(this.a!=125)throw ue(new ri(ai((Jr(),V4t))));if(r>TT)throw ue(new ri(ai((Jr(),U4t))));t=r}else{if(o=0,this.c!=0||(o=Wm(this.a))<0)throw ue(new ri(ai((Jr(),w2))));if(r=o,Li(this),this.c!=0||(o=Wm(this.a))<0)throw ue(new ri(ai((Jr(),w2))));r=r*16+o,t=r}break;case 117:if(a=0,Li(this),this.c!=0||(a=Wm(this.a))<0)throw ue(new ri(ai((Jr(),w2))));if(n=a,Li(this),this.c!=0||(a=Wm(this.a))<0)throw ue(new ri(ai((Jr(),w2))));if(n=n*16+a,Li(this),this.c!=0||(a=Wm(this.a))<0)throw ue(new ri(ai((Jr(),w2))));if(n=n*16+a,Li(this),this.c!=0||(a=Wm(this.a))<0)throw ue(new ri(ai((Jr(),w2))));n=n*16+a,t=n;break;case 118:if(Li(this),this.c!=0||(a=Wm(this.a))<0)throw ue(new ri(ai((Jr(),w2))));if(n=a,Li(this),this.c!=0||(a=Wm(this.a))<0)throw ue(new ri(ai((Jr(),w2))));if(n=n*16+a,Li(this),this.c!=0||(a=Wm(this.a))<0)throw ue(new ri(ai((Jr(),w2))));if(n=n*16+a,Li(this),this.c!=0||(a=Wm(this.a))<0)throw ue(new ri(ai((Jr(),w2))));if(n=n*16+a,Li(this),this.c!=0||(a=Wm(this.a))<0)throw ue(new ri(ai((Jr(),w2))));if(n=n*16+a,Li(this),this.c!=0||(a=Wm(this.a))<0)throw ue(new ri(ai((Jr(),w2))));if(n=n*16+a,n>TT)throw ue(new ri(ai((Jr(),"parser.descappe.4"))));t=n;break;case 65:case 90:case 122:throw ue(new ri(ai((Jr(),G4t))))}return t},h.dm=function(t){var n,r;switch(t){case 100:r=(this.e&32)==32?_b("Nd",!0):(Di(),MY);break;case 68:r=(this.e&32)==32?_b("Nd",!1):(Di(),ZPe);break;case 119:r=(this.e&32)==32?_b("IsWord",!0):(Di(),lC);break;case 87:r=(this.e&32)==32?_b("IsWord",!1):(Di(),tBe);break;case 115:r=(this.e&32)==32?_b("IsSpace",!0):(Di(),l9);break;case 83:r=(this.e&32)==32?_b("IsSpace",!1):(Di(),eBe);break;default:throw ue(new Ac((n=t,G5t+n.toString(16))))}return r},h.em=function(t){var n,r,a,o,f,g,w,E,C,L,B,z;for(this.b=1,Li(this),n=null,this.c==0&&this.a==94?(Li(this),t?L=(Di(),Di(),new _h(5)):(n=(Di(),Di(),new _h(4)),Eu(n,0,TT),L=new _h(4))):L=(Di(),Di(),new _h(4)),o=!0;(z=this.c)!=1&&!(z==0&&this.a==93&&!o);){if(o=!1,r=this.a,a=!1,z==10)switch(r){case 100:case 68:case 119:case 87:case 115:case 83:Ky(L,this.dm(r)),a=!0;break;case 105:case 73:case 99:case 67:r=this.um(L,r),r<0&&(a=!0);break;case 112:case 80:if(B=w9e(this,r),!B)throw ue(new ri(ai((Jr(),t0e))));Ky(L,B),a=!0;break;default:r=this.cm()}else if(z==20){if(g=Nk(this.i,58,this.d),g<0)throw ue(new ri(ai((Jr(),kSe))));if(w=!0,co(this.i,this.d)==94&&(++this.d,w=!1),f=tf(this.i,this.d,g),E=vlt(f,w,(this.e&512)==512),!E)throw ue(new ri(ai((Jr(),R4t))));if(Ky(L,E),a=!0,g+1>=this.j||co(this.i,g+1)!=93)throw ue(new ri(ai((Jr(),kSe))));this.d=g+2}if(Li(this),!a)if(this.c!=0||this.a!=45)Eu(L,r,r);else{if(Li(this),(z=this.c)==1)throw ue(new ri(ai((Jr(),UG))));z==0&&this.a==93?(Eu(L,r,r),Eu(L,45,45)):(C=this.a,z==10&&(C=this.cm()),Li(this),Eu(L,r,C))}(this.e&m0)==m0&&this.c==0&&this.a==44&&Li(this)}if(this.c==1)throw ue(new ri(ai((Jr(),UG))));return n&&(nL(n,L),L=n),c6(L),eL(L),this.b=0,Li(this),L},h.fm=function(){var t,n,r,a;for(r=this.em(!1);(a=this.c)!=7;)if(t=this.a,a==0&&(t==45||t==38)||a==4){if(Li(this),this.c!=9)throw ue(new ri(ai((Jr(),$4t))));if(n=this.em(!1),a==4)Ky(r,n);else if(t==45)nL(r,n);else if(t==38)Cvt(r,n);else throw ue(new Ac("ASSERT"))}else throw ue(new ri(ai((Jr(),z4t))));return Li(this),r},h.gm=function(){var t,n;return t=this.a-48,n=(Di(),Di(),new coe(12,null,t)),!this.g&&(this.g=new jz),Rz(this.g,new Ewe(t)),Li(this),n},h.hm=function(){return Li(this),Di(),EAt},h.im=function(){return Li(this),Di(),kAt},h.jm=function(){throw ue(new ri(ai((Jr(),bf))))},h.km=function(){throw ue(new ri(ai((Jr(),bf))))},h.lm=function(){return Li(this),Eyn()},h.mm=function(){return Li(this),Di(),CAt},h.nm=function(){return Li(this),Di(),_At},h.om=function(){var t;if(this.d>=this.j||((t=co(this.i,this.d++))&65504)!=64)throw ue(new ri(ai((Jr(),P4t))));return Li(this),Di(),Di(),new ng(0,t-64)},h.pm=function(){return Li(this),SAn()},h.qm=function(){return Li(this),Di(),AAt},h.rm=function(){var t;return t=(Di(),Di(),new ng(0,105)),Li(this),t},h.sm=function(){return Li(this),Di(),SAt},h.tm=function(){return Li(this),Di(),TAt},h.um=function(t,n){return this.cm()},h.vm=function(){return Li(this),Di(),QPe},h.wm=function(){var t,n,r,a,o;if(this.d+1>=this.j)throw ue(new ri(ai((Jr(),I4t))));if(a=-1,n=null,t=co(this.i,this.d),49<=t&&t<=57){if(a=t-48,!this.g&&(this.g=new jz),Rz(this.g,new Ewe(a)),++this.d,co(this.i,this.d)!=41)throw ue(new ri(ai((Jr(),ov))));++this.d}else switch(t==63&&--this.d,Li(this),n=Gke(this),n.e){case 20:case 21:case 22:case 23:break;case 8:if(this.c!=7)throw ue(new ri(ai((Jr(),ov))));break;default:throw ue(new ri(ai((Jr(),O4t))))}if(Li(this),o=jw(this),r=null,o.e==2){if(o.Pm()!=2)throw ue(new ri(ai((Jr(),N4t))));r=o.Lm(1),o=o.Lm(0)}if(this.c!=7)throw ue(new ri(ai((Jr(),ov))));return Li(this),Di(),Di(),new Zlt(a,n,o,r)},h.xm=function(){return Li(this),Di(),JPe},h.ym=function(){var t;if(Li(this),t=bH(24,jw(this)),this.c!=7)throw ue(new ri(ai((Jr(),ov))));return Li(this),t},h.zm=function(){var t;if(Li(this),t=bH(20,jw(this)),this.c!=7)throw ue(new ri(ai((Jr(),ov))));return Li(this),t},h.Am=function(){var t;if(Li(this),t=bH(22,jw(this)),this.c!=7)throw ue(new ri(ai((Jr(),ov))));return Li(this),t},h.Bm=function(){var t,n,r,a,o;for(t=0,r=0,n=-1;this.d=this.j)throw ue(new ri(ai((Jr(),ySe))));if(n==45){for(++this.d;this.d=this.j)throw ue(new ri(ai((Jr(),ySe))))}if(n==58){if(++this.d,Li(this),a=Wst(jw(this),t,r),this.c!=7)throw ue(new ri(ai((Jr(),ov))));Li(this)}else if(n==41)++this.d,Li(this),a=Wst(jw(this),t,r);else throw ue(new ri(ai((Jr(),D4t))));return a},h.Cm=function(){var t;if(Li(this),t=bH(21,jw(this)),this.c!=7)throw ue(new ri(ai((Jr(),ov))));return Li(this),t},h.Dm=function(){var t;if(Li(this),t=bH(23,jw(this)),this.c!=7)throw ue(new ri(ai((Jr(),ov))));return Li(this),t},h.Em=function(){var t,n;if(Li(this),t=this.f++,n=Bae(jw(this),t),this.c!=7)throw ue(new ri(ai((Jr(),ov))));return Li(this),n},h.Fm=function(){var t;if(Li(this),t=Bae(jw(this),0),this.c!=7)throw ue(new ri(ai((Jr(),ov))));return Li(this),t},h.Gm=function(t){return Li(this),this.c==5?(Li(this),oH(t,(Di(),Di(),new Ty(9,t)))):oH(t,(Di(),Di(),new Ty(3,t)))},h.Hm=function(t){var n;return Li(this),n=(Di(),Di(),new B_(2)),this.c==5?(Li(this),Qm(n,WM),Qm(n,t)):(Qm(n,t),Qm(n,WM)),n},h.Im=function(t){return Li(this),this.c==5?(Li(this),Di(),Di(),new Ty(9,t)):(Di(),Di(),new Ty(3,t))},h.a=0,h.b=0,h.c=0,h.d=0,h.e=0,h.f=1,h.g=null,h.j=0,I(y2,"RegEx/RegexParser",836),D(1947,836,{},gJe),h.bm=function(t){return!1},h.cm=function(){return eke(this)},h.dm=function(t){return YE(t)},h.em=function(t){return ywt(this)},h.fm=function(){throw ue(new ri(ai((Jr(),bf))))},h.gm=function(){throw ue(new ri(ai((Jr(),bf))))},h.hm=function(){throw ue(new ri(ai((Jr(),bf))))},h.im=function(){throw ue(new ri(ai((Jr(),bf))))},h.jm=function(){return Li(this),YE(67)},h.km=function(){return Li(this),YE(73)},h.lm=function(){throw ue(new ri(ai((Jr(),bf))))},h.mm=function(){throw ue(new ri(ai((Jr(),bf))))},h.nm=function(){throw ue(new ri(ai((Jr(),bf))))},h.om=function(){return Li(this),YE(99)},h.pm=function(){throw ue(new ri(ai((Jr(),bf))))},h.qm=function(){throw ue(new ri(ai((Jr(),bf))))},h.rm=function(){return Li(this),YE(105)},h.sm=function(){throw ue(new ri(ai((Jr(),bf))))},h.tm=function(){throw ue(new ri(ai((Jr(),bf))))},h.um=function(t,n){return Ky(t,YE(n)),-1},h.vm=function(){return Li(this),Di(),Di(),new ng(0,94)},h.wm=function(){throw ue(new ri(ai((Jr(),bf))))},h.xm=function(){return Li(this),Di(),Di(),new ng(0,36)},h.ym=function(){throw ue(new ri(ai((Jr(),bf))))},h.zm=function(){throw ue(new ri(ai((Jr(),bf))))},h.Am=function(){throw ue(new ri(ai((Jr(),bf))))},h.Bm=function(){throw ue(new ri(ai((Jr(),bf))))},h.Cm=function(){throw ue(new ri(ai((Jr(),bf))))},h.Dm=function(){throw ue(new ri(ai((Jr(),bf))))},h.Em=function(){var t;if(Li(this),t=Bae(jw(this),0),this.c!=7)throw ue(new ri(ai((Jr(),ov))));return Li(this),t},h.Fm=function(){throw ue(new ri(ai((Jr(),bf))))},h.Gm=function(t){return Li(this),oH(t,(Di(),Di(),new Ty(3,t)))},h.Hm=function(t){var n;return Li(this),n=(Di(),Di(),new B_(2)),Qm(n,t),Qm(n,WM),n},h.Im=function(t){return Li(this),Di(),Di(),new Ty(3,t)};var l7=null,cC=null;I(y2,"RegEx/ParserForXMLSchema",1947),D(122,1,CT,Xv),h.Jm=function(t){throw ue(new Ac("Not supported."))},h.Km=function(){return-1},h.Lm=function(t){return null},h.Mm=function(){return null},h.Nm=function(t){},h.Om=function(t){},h.Pm=function(){return 0},h.Ib=function(){return this.Qm(0)},h.Qm=function(t){return this.e==11?".":""},h.e=0;var WPe,uC,KM,xAt,YPe,P4=null,MY,cpe=null,XPe,WM,upe=null,QPe,JPe,ZPe,eBe,tBe,kAt,l9,EAt,TAt,CAt,SAt,lC,_At,AAt,BOn=I(y2,"RegEx/Token",122);D(138,122,{3:1,138:1,122:1},_h),h.Qm=function(t){var n,r,a;if(this.e==4)if(this==XPe)r=".";else if(this==MY)r="\\d";else if(this==lC)r="\\w";else if(this==l9)r="\\s";else{for(a=new Up,a.a+="[",n=0;n0&&(a.a+=","),this.b[n]===this.b[n+1]?Xo(a,gP(this.b[n])):(Xo(a,gP(this.b[n])),a.a+="-",Xo(a,gP(this.b[n+1])));a.a+="]",r=a.a}else if(this==ZPe)r="\\D";else if(this==tBe)r="\\W";else if(this==eBe)r="\\S";else{for(a=new Up,a.a+="[^",n=0;n0&&(a.a+=","),this.b[n]===this.b[n+1]?Xo(a,gP(this.b[n])):(Xo(a,gP(this.b[n])),a.a+="-",Xo(a,gP(this.b[n+1])));a.a+="]",r=a.a}return r},h.a=!1,h.c=!1,I(y2,"RegEx/RangeToken",138),D(592,1,{592:1},Ewe),h.a=0,I(y2,"RegEx/RegexParser/ReferencePosition",592),D(591,1,{3:1,591:1},LZe),h.Fb=function(t){var n;return t==null||!De(t,591)?!1:(n=l(t,591),vn(this.b,n.b)&&this.a==n.a)},h.Hb=function(){return s2(this.b+"/"+K9e(this.a))},h.Ib=function(){return this.c.Qm(this.a)},h.a=0,I(y2,"RegEx/RegularExpression",591),D(228,122,CT,ng),h.Km=function(){return this.a},h.Qm=function(t){var n,r,a;switch(this.e){case 0:switch(this.a){case 124:case 42:case 43:case 63:case 40:case 41:case 46:case 91:case 123:case 92:a="\\"+hae(this.a&Zs);break;case 12:a="\\f";break;case 10:a="\\n";break;case 13:a="\\r";break;case 9:a="\\t";break;case 27:a="\\e";break;default:this.a>=Io?(r=(n=this.a>>>0,"0"+n.toString(16)),a="\\v"+tf(r,r.length-6,r.length)):a=""+hae(this.a&Zs)}break;case 8:this==QPe||this==JPe?a=""+hae(this.a&Zs):a="\\"+hae(this.a&Zs);break;default:a=null}return a},h.a=0,I(y2,"RegEx/Token/CharToken",228),D(318,122,CT,Ty),h.Lm=function(t){return this.a},h.Nm=function(t){this.b=t},h.Om=function(t){this.c=t},h.Pm=function(){return 1},h.Qm=function(t){var n;if(this.e==3)if(this.c<0&&this.b<0)n=this.a.Qm(t)+"*";else if(this.c==this.b)n=this.a.Qm(t)+"{"+this.c+"}";else if(this.c>=0&&this.b>=0)n=this.a.Qm(t)+"{"+this.c+","+this.b+"}";else if(this.c>=0&&this.b<0)n=this.a.Qm(t)+"{"+this.c+",}";else throw ue(new Ac("Token#toString(): CLOSURE "+this.c+Co+this.b));else if(this.c<0&&this.b<0)n=this.a.Qm(t)+"*?";else if(this.c==this.b)n=this.a.Qm(t)+"{"+this.c+"}?";else if(this.c>=0&&this.b>=0)n=this.a.Qm(t)+"{"+this.c+","+this.b+"}?";else if(this.c>=0&&this.b<0)n=this.a.Qm(t)+"{"+this.c+",}?";else throw ue(new Ac("Token#toString(): NONGREEDYCLOSURE "+this.c+Co+this.b));return n},h.b=0,h.c=0,I(y2,"RegEx/Token/ClosureToken",318),D(837,122,CT,f5e),h.Lm=function(t){return t==0?this.a:this.b},h.Pm=function(){return 2},h.Qm=function(t){var n;return this.b.e==3&&this.b.Lm(0)==this.a?n=this.a.Qm(t)+"+":this.b.e==9&&this.b.Lm(0)==this.a?n=this.a.Qm(t)+"+?":n=this.a.Qm(t)+(""+this.b.Qm(t)),n},I(y2,"RegEx/Token/ConcatToken",837),D(1945,122,CT,Zlt),h.Lm=function(t){if(t==0)return this.d;if(t==1)return this.b;throw ue(new Ac("Internal Error: "+t))},h.Pm=function(){return this.b?2:1},h.Qm=function(t){var n;return this.c>0?n="(?("+this.c+")":this.a.e==8?n="(?("+this.a+")":n="(?"+this.a,this.b?n+=this.d+"|"+this.b+")":n+=this.d+")",n},h.c=0,I(y2,"RegEx/Token/ConditionToken",1945),D(1946,122,CT,Hot),h.Lm=function(t){return this.b},h.Pm=function(){return 1},h.Qm=function(t){return"(?"+(this.a==0?"":K9e(this.a))+(this.c==0?"":K9e(this.c))+":"+this.b.Qm(t)+")"},h.a=0,h.c=0,I(y2,"RegEx/Token/ModifierToken",1946),D(838,122,CT,k5e),h.Lm=function(t){return this.a},h.Pm=function(){return 1},h.Qm=function(t){var n;switch(n=null,this.e){case 6:this.b==0?n="(?:"+this.a.Qm(t)+")":n="("+this.a.Qm(t)+")";break;case 20:n="(?="+this.a.Qm(t)+")";break;case 21:n="(?!"+this.a.Qm(t)+")";break;case 22:n="(?<="+this.a.Qm(t)+")";break;case 23:n="(?"+this.a.Qm(t)+")"}return n},h.b=0,I(y2,"RegEx/Token/ParenToken",838),D(530,122,{3:1,122:1,530:1},coe),h.Mm=function(){return this.b},h.Qm=function(t){return this.e==12?"\\"+this.a:vTn(this.b)},h.a=0,I(y2,"RegEx/Token/StringToken",530),D(477,122,CT,B_),h.Jm=function(t){Qm(this,t)},h.Lm=function(t){return l(xw(this.a,t),122)},h.Pm=function(){return this.a?this.a.a.c.length:0},h.Qm=function(t){var n,r,a,o,f;if(this.e==1){if(this.a.a.c.length==2)n=l(xw(this.a,0),122),r=l(xw(this.a,1),122),r.e==3&&r.Lm(0)==n?o=n.Qm(t)+"+":r.e==9&&r.Lm(0)==n?o=n.Qm(t)+"+?":o=n.Qm(t)+(""+r.Qm(t));else{for(f=new Up,a=0;a=this.c.b:this.a<=this.c.b},h.Sb=function(){return this.b>0},h.Tb=function(){return this.b},h.Vb=function(){return this.b-1},h.Qb=function(){throw ue(new Hp(Z5t))},h.a=0,h.b=0,I(zSe,"ExclusiveRange/RangeIterator",258);var kf=Gk(GG,"C"),Vr=Gk(LL,"I"),ih=Gk(Cx,"Z"),nm=Gk(ML,"J"),Al=Gk(SL,"B"),Na=Gk(_L,"D"),B4=Gk(AL,"F"),h7=Gk(DL,"S"),FOn=ks("org.eclipse.elk.core.labels","ILabelManager"),nBe=ks(So,"DiagnosticChain"),rBe=ks(_5t,"ResourceSet"),iBe=I(So,"InvocationTargetException",null),MAt=(Hz(),Qmn),DAt=DAt=q8n;Vwn($cn),$wn("permProps",[[["locale","default"],[e6t,"gecko1_8"]],[["locale","default"],[e6t,"safari"]]]),DAt(null,"elk",null)}).call(this)}).call(this,typeof Ag<"u"?Ag:typeof self<"u"?self:typeof window<"u"?window:{})},{}],3:[function(u,d,p){function v(A,P){if(!(A instanceof P))throw new TypeError("Cannot call a class as a function")}function b(A,P){if(!A)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return P&&(typeof P=="object"||typeof P=="function")?P:A}function y(A,P){if(typeof P!="function"&&P!==null)throw new TypeError("Super expression must either be null or a function, not "+typeof P);A.prototype=Object.create(P&&P.prototype,{constructor:{value:A,enumerable:!1,writable:!0,configurable:!0}}),P&&(Object.setPrototypeOf?Object.setPrototypeOf(A,P):A.__proto__=P)}var T=u("./elk-api.js").default,_=function(A){y(P,A);function P(){var R=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};v(this,P);var F=Object.assign({},R),j=!1;try{u.resolve("web-worker"),j=!0}catch{}if(R.workerUrl)if(j){var K=u("web-worker");F.workerFactory=function(oe){return new K(oe)}}else console.warn(`Web worker requested but 'web-worker' package not installed. +Consider installing the package or pass your own 'workerFactory' to ELK's constructor. +... Falling back to non-web worker version.`);if(!F.workerFactory){var ee=u("./elk-worker.min.js"),ie=ee.Worker;F.workerFactory=function(oe){return new ie(oe)}}return b(this,(P.__proto__||Object.getPrototypeOf(P)).call(this,F))}return P}(T);Object.defineProperty(d.exports,"__esModule",{value:!0}),d.exports=_,_.default=_},{"./elk-api.js":1,"./elk-worker.min.js":2,"web-worker":4}],4:[function(u,d,p){d.exports=Worker},{}]},{},[3])(3)})})(HKe);var Can=HKe.exports;const San=hC(Can),VKe=new San;let Hv={};const _an={};let W7={};const Aan=async function(i,s,u,d,p,v,b){const T=u.select(`[id="${s}"]`).insert("g").attr("class","nodes"),_=Object.keys(i);return await Promise.all(_.map(async function(A){const P=i[A];let R="default";P.classes.length>0&&(R=P.classes.join(" ")),R=R+" flowchart-label";const F=om(P.styles);let j=P.text!==void 0?P.text:P.id;const K={width:0,height:0},ee=[{id:P.id+"-west",layoutOptions:{"port.side":"WEST"}},{id:P.id+"-east",layoutOptions:{"port.side":"EAST"}},{id:P.id+"-south",layoutOptions:{"port.side":"SOUTH"}},{id:P.id+"-north",layoutOptions:{"port.side":"NORTH"}}];let ie=0,oe="",pe={};switch(P.type){case"round":ie=5,oe="rect";break;case"square":oe="rect";break;case"diamond":oe="question",pe={portConstraints:"FIXED_SIDE"};break;case"hexagon":oe="hexagon";break;case"odd":oe="rect_left_inv_arrow";break;case"lean_right":oe="lean_right";break;case"lean_left":oe="lean_left";break;case"trapezoid":oe="trapezoid";break;case"inv_trapezoid":oe="inv_trapezoid";break;case"odd_right":oe="rect_left_inv_arrow";break;case"circle":oe="circle";break;case"ellipse":oe="ellipse";break;case"stadium":oe="stadium";break;case"subroutine":oe="subroutine";break;case"cylinder":oe="cylinder";break;case"group":oe="rect";break;case"doublecircle":oe="doublecircle";break;default:oe="rect"}const be={labelStyle:F.labelStyle,shape:oe,labelText:j,labelType:P.labelType,rx:ie,ry:ie,class:R,style:F.style,id:P.id,link:P.link,linkTarget:P.linkTarget,tooltip:p.db.getTooltip(P.id)||"",domId:p.db.lookUpDomId(P.id),haveCallback:P.haveCallback,width:P.type==="group"?500:void 0,dir:P.dir,type:P.type,props:P.props,padding:Vh().flowchart.padding};let ae,ne;if(be.type!=="group")ne=await tJ(T,be,P.dir),ae=ne.node().getBBox();else{d.createElementNS("http://www.w3.org/2000/svg","text");const{shapeSvg:de,bbox:X}=await g1(T,be,void 0,!0);K.width=X.width,K.wrappingWidth=Vh().flowchart.wrappingWidth,K.height=X.height,K.labelNode=de.node(),be.labelData=K}const se={id:P.id,ports:P.type==="diamond"?ee:[],layoutOptions:pe,labelText:j,labelData:K,domId:p.db.lookUpDomId(P.id),width:ae==null?void 0:ae.width,height:ae==null?void 0:ae.height,type:P.type,el:ne,parent:v.parentById[P.id]};W7[be.id]=se})),b},UKe=(i,s,u)=>{const d={TB:{in:{north:"north"},out:{south:"west",west:"east",east:"south"}},LR:{in:{west:"west"},out:{east:"south",south:"north",north:"east"}},RL:{in:{east:"east"},out:{west:"north",north:"south",south:"west"}},BT:{in:{south:"south"},out:{north:"east",east:"west",west:"north"}}};return d.TD=d.TB,d[u][s][i]},GKe=(i,s,u)=>{if(Xe.info("getNextPort",{node:i,edgeDirection:s,graphDirection:u}),!Hv[i])switch(u){case"TB":case"TD":Hv[i]={inPosition:"north",outPosition:"south"};break;case"BT":Hv[i]={inPosition:"south",outPosition:"north"};break;case"RL":Hv[i]={inPosition:"east",outPosition:"west"};break;case"LR":Hv[i]={inPosition:"west",outPosition:"east"};break}const d=s==="in"?Hv[i].inPosition:Hv[i].outPosition;return s==="in"?Hv[i].inPosition=UKe(Hv[i].inPosition,s,u):Hv[i].outPosition=UKe(Hv[i].outPosition,s,u),d},Lan=(i,s)=>{let u=i.start,d=i.end;const p=u,v=d,b=W7[u],y=W7[d];return!b||!y?{source:u,target:d}:(b.type==="diamond"&&(u=`${u}-${GKe(u,"out",s)}`),y.type==="diamond"&&(d=`${d}-${GKe(d,"in",s)}`),{source:u,target:d,sourceId:p,targetId:v})},Man=function(i,s,u,d){Xe.info("abc78 edges = ",i);const p=d.insert("g").attr("class","edgeLabels");let v={},b=s.db.getDirection(),y,T;if(i.defaultStyle!==void 0){const _=om(i.defaultStyle);y=_.style,T=_.labelStyle}return i.forEach(function(_){const A="L-"+_.start+"-"+_.end;v[A]===void 0?(v[A]=0,Xe.info("abc78 new entry",A,v[A])):(v[A]++,Xe.info("abc78 new entry",A,v[A]));let P=A+"-"+v[A];Xe.info("abc78 new link id to be used is",A,P,v[A]);const R="LS-"+_.start,F="LE-"+_.end,j={style:"",labelStyle:""};switch(j.minlen=_.length||1,_.type==="arrow_open"?j.arrowhead="none":j.arrowhead="normal",j.arrowTypeStart="arrow_open",j.arrowTypeEnd="arrow_open",_.type){case"double_arrow_cross":j.arrowTypeStart="arrow_cross";case"arrow_cross":j.arrowTypeEnd="arrow_cross";break;case"double_arrow_point":j.arrowTypeStart="arrow_point";case"arrow_point":j.arrowTypeEnd="arrow_point";break;case"double_arrow_circle":j.arrowTypeStart="arrow_circle";case"arrow_circle":j.arrowTypeEnd="arrow_circle";break}let K="",ee="";switch(_.stroke){case"normal":K="fill:none;",y!==void 0&&(K=y),T!==void 0&&(ee=T),j.thickness="normal",j.pattern="solid";break;case"dotted":j.thickness="normal",j.pattern="dotted",j.style="fill:none;stroke-width:2px;stroke-dasharray:3;";break;case"thick":j.thickness="thick",j.pattern="solid",j.style="stroke-width: 3.5px;fill:none;";break}if(_.style!==void 0){const ne=om(_.style);K=ne.style,ee=ne.labelStyle}j.style=j.style+=K,j.labelStyle=j.labelStyle+=ee,_.interpolate!==void 0?j.curve=Ov(_.interpolate,kp):i.defaultInterpolate!==void 0?j.curve=Ov(i.defaultInterpolate,kp):j.curve=Ov(_an.curve,kp),_.text===void 0?_.style!==void 0&&(j.arrowheadStyle="fill: #333"):(j.arrowheadStyle="fill: #333",j.labelpos="c"),j.labelType=_.labelType,j.label=_.text.replace(ci.lineBreakRegex,` +`),_.style===void 0&&(j.style=j.style||"stroke: #333; stroke-width: 1.5px;fill:none;"),j.labelStyle=j.labelStyle.replace("color:","fill:"),j.id=P,j.classes="flowchart-link "+R+" "+F;const ie=zme(p,j),{source:oe,target:pe,sourceId:be,targetId:ae}=Lan(_,b);Xe.debug("abc78 source and target",oe,pe),u.edges.push({id:"e"+_.start+_.end,sources:[oe],targets:[pe],sourceId:be,targetId:ae,labelEl:ie,labels:[{width:j.width,height:j.height,orgWidth:j.width,orgHeight:j.height,text:j.label,layoutOptions:{"edgeLabels.inline":"true","edgeLabels.placement":"CENTER"}}],edgeData:j})}),u},Dan=function(i,s,u,d,p){let v="";d&&(v=window.location.protocol+"//"+window.location.host+window.location.pathname+window.location.search,v=v.replace(/\(/g,"\\("),v=v.replace(/\)/g,"\\)")),AUe(i,s,v,p,u)},Ian=function(i,s){return Xe.info("Extracting classes"),s.db.getClasses()},Oan=function(i){const s={parentById:{},childrenById:{}},u=i.getSubGraphs();return Xe.info("Subgraphs - ",u),u.forEach(function(d){d.nodes.forEach(function(p){s.parentById[p]=d.id,s.childrenById[d.id]===void 0&&(s.childrenById[d.id]=[]),s.childrenById[d.id].push(p)})}),u.forEach(function(d){d.id,s.parentById[d.id]!==void 0&&s.parentById[d.id]}),s},Nan=function(i,s,u){const d=Tan(i,s,u);if(d===void 0||d==="root")return{x:0,y:0};const p=W7[d].offset;return{x:p.posX,y:p.posY}},Pan=function(i,s,u,d,p,v){const b=Nan(s.sourceId,s.targetId,p),y=s.sections[0].startPoint,T=s.sections[0].endPoint,A=(s.sections[0].bendPoints?s.sections[0].bendPoints:[]).map(pe=>[pe.x+b.x,pe.y+b.y]),P=[[y.x+b.x,y.y+b.y],...A,[T.x+b.x,T.y+b.y]],{x:R,y:F}=_Ue(s.edgeData),j=k7().x(R).y(F).curve(kp),K=i.insert("path").attr("d",j(P)).attr("class","path "+u.classes).attr("fill","none"),ee=i.insert("g").attr("class","edgeLabel"),ie=Ir(ee.node().appendChild(s.labelEl)),oe=ie.node().firstChild.getBoundingClientRect();ie.attr("width",oe.width),ie.attr("height",oe.height),ee.attr("transform",`translate(${s.labels[0].x+b.x}, ${s.labels[0].y+b.y})`),Dan(K,u,d.type,d.arrowMarkerAbsolute,v)},KKe=(i,s)=>{i.forEach(u=>{u.children||(u.children=[]);const d=s.childrenById[u.id];d&&d.forEach(p=>{u.children.push(W7[p])}),KKe(u.children,s)})},Ban=async function(i,s,u,d){var se;d.db.clear(),W7={},Hv={},d.db.setGen("gen-2"),d.parser.parse(i);const p=Ir("body").append("div").attr("style","height:400px").attr("id","cy");let v={id:"root",layoutOptions:{"elk.hierarchyHandling":"INCLUDE_CHILDREN","org.eclipse.elk.padding":"[top=100, left=100, bottom=110, right=110]","elk.layered.spacing.edgeNodeBetweenLayers":"30","elk.direction":"DOWN"},children:[],edges:[]};switch(Xe.info("Drawing flowchart using v3 renderer",VKe),d.db.getDirection()){case"BT":v.layoutOptions["elk.direction"]="UP";break;case"TB":v.layoutOptions["elk.direction"]="DOWN";break;case"LR":v.layoutOptions["elk.direction"]="RIGHT";break;case"RL":v.layoutOptions["elk.direction"]="LEFT";break}const{securityLevel:y,flowchart:T}=Vh();let _;y==="sandbox"&&(_=Ir("#i"+s));const A=Ir(y==="sandbox"?_.nodes()[0].contentDocument.body:"body"),P=y==="sandbox"?_.nodes()[0].contentDocument:document,R=A.select(`[id="${s}"]`);Sme(R,["point","circle","cross"],d.type,s);const j=d.db.getVertices();let K;const ee=d.db.getSubGraphs();Xe.info("Subgraphs - ",ee);for(let de=ee.length-1;de>=0;de--)K=ee[de],d.db.addVertex(K.id,{text:K.title,type:K.labelType},"group",void 0,K.classes,K.dir);const ie=R.insert("g").attr("class","subgraphs"),oe=Oan(d.db);v=await Aan(j,s,A,P,d,oe,v);const pe=R.insert("g").attr("class","edges edgePath"),be=d.db.getEdges();v=Man(be,d,v,R),Object.keys(W7).forEach(de=>{const X=W7[de];X.parent||v.children.push(X),oe.childrenById[de]!==void 0&&(X.labels=[{text:X.labelText,layoutOptions:{"nodeLabels.placement":"[H_CENTER, V_TOP, INSIDE]"},width:X.labelData.width,height:X.labelData.height}],delete X.x,delete X.y,delete X.width,delete X.height)}),KKe(v.children,oe),Xe.info("after layout",JSON.stringify(v,null,2));const ne=await VKe.layout(v);WKe(0,0,ne.children,R,ie,d,0),Xe.info("after layout",ne),(se=ne.edges)==null||se.map(de=>{Pan(pe,de,de.edgeData,d,oe,s)}),y9({},R,T.diagramPadding,T.useMaxWidth),p.remove()},WKe=(i,s,u,d,p,v,b)=>{u.forEach(function(y){if(y)if(W7[y.id].offset={posX:y.x+i,posY:y.y+s,x:i,y:s,depth:b,width:y.width,height:y.height},y.type==="group"){const T=p.insert("g").attr("class","subgraph");T.insert("rect").attr("class","subgraph subgraph-lvl-"+b%5+" node").attr("x",y.x+i).attr("y",y.y+s).attr("width",y.width).attr("height",y.height);const _=T.insert("g").attr("class","label"),A=Vh().flowchart.htmlLabels?y.labelData.width/2:0;_.attr("transform",`translate(${y.labels[0].x+i+y.x+A}, ${y.labels[0].y+s+y.y+3})`),_.node().appendChild(y.labelData.labelNode),Xe.info("Id (UGH)= ",y.type,y.labels)}else Xe.info("Id (UGH)= ",y.id),y.el.attr("transform",`translate(${y.x+i+y.width/2}, ${y.y+s+y.height/2})`)}),u.forEach(function(y){y&&y.type==="group"&&WKe(i+y.x,s+y.y,y.children,d,p,v,b+1)})},Fan={getClasses:Ian,draw:Ban},Ran=i=>{let s="";for(let u=0;u<5;u++)s+=` + .subgraph-lvl-${u} { + fill: ${i[`surface${u}`]}; + stroke: ${i[`surfacePeer${u}`]}; + } + `;return s},jan=Object.freeze(Object.defineProperty({__proto__:null,diagram:{db:_Ut,renderer:Fan,parser:Gbe,styles:i=>`.label { + font-family: ${i.fontFamily}; + color: ${i.nodeTextColor||i.textColor}; + } + .cluster-label text { + fill: ${i.titleColor}; + } + .cluster-label span { + color: ${i.titleColor}; + } + + .label text,span { + fill: ${i.nodeTextColor||i.textColor}; + color: ${i.nodeTextColor||i.textColor}; + } + + .node rect, + .node circle, + .node ellipse, + .node polygon, + .node path { + fill: ${i.mainBkg}; + stroke: ${i.nodeBorder}; + stroke-width: 1px; + } + + .node .label { + text-align: center; + } + .node.clickable { + cursor: pointer; + } + + .arrowheadPath { + fill: ${i.arrowheadColor}; + } + + .edgePath .path { + stroke: ${i.lineColor}; + stroke-width: 2.0px; + } + + .flowchart-link { + stroke: ${i.lineColor}; + fill: none; + } + + .edgeLabel { + background-color: ${i.edgeLabelBackground}; + rect { + opacity: 0.85; + background-color: ${i.edgeLabelBackground}; + fill: ${i.edgeLabelBackground}; + } + text-align: center; + } + + .cluster rect { + fill: ${i.clusterBkg}; + stroke: ${i.clusterBorder}; + stroke-width: 1px; + } + + .cluster text { + fill: ${i.titleColor}; + } + + .cluster span { + color: ${i.titleColor}; + } + /* .cluster div { + color: ${i.titleColor}; + } */ + + div.mermaidTooltip { + position: absolute; + text-align: center; + max-width: 200px; + padding: 2px; + font-family: ${i.fontFamily}; + font-size: 12px; + background: ${i.tertiaryColor}; + border: 1px solid ${i.border2}; + border-radius: 2px; + pointer-events: none; + z-index: 100; + } + + .flowchartTitleText { + text-anchor: middle; + font-size: 18px; + fill: ${i.textColor}; + } + .subgraph { + stroke-width:2; + rx:3; + } + // .subgraph-lvl-1 { + // fill:#ccc; + // // stroke:black; + // } + + .flowchart-label text { + text-anchor: middle; + } + + ${Ran(i)} +`}},Symbol.toStringTag,{value:"Module"}));var Qve=function(){var i=function(R,F,j,K){for(j=j||{},K=R.length;K--;j[R[K]]=F);return j},s=[6,8,10,11,12,14,16,17,20,21],u=[1,9],d=[1,10],p=[1,11],v=[1,12],b=[1,13],y=[1,16],T=[1,17],_={trace:function(){},yy:{},symbols_:{error:2,start:3,timeline:4,document:5,EOF:6,line:7,SPACE:8,statement:9,NEWLINE:10,title:11,acc_title:12,acc_title_value:13,acc_descr:14,acc_descr_value:15,acc_descr_multiline_value:16,section:17,period_statement:18,event_statement:19,period:20,event:21,$accept:0,$end:1},terminals_:{2:"error",4:"timeline",6:"EOF",8:"SPACE",10:"NEWLINE",11:"title",12:"acc_title",13:"acc_title_value",14:"acc_descr",15:"acc_descr_value",16:"acc_descr_multiline_value",17:"section",20:"period",21:"event"},productions_:[0,[3,3],[5,0],[5,2],[7,2],[7,1],[7,1],[7,1],[9,1],[9,2],[9,2],[9,1],[9,1],[9,1],[9,1],[18,1],[19,1]],performAction:function(F,j,K,ee,ie,oe,pe){var be=oe.length-1;switch(ie){case 1:return oe[be-1];case 2:this.$=[];break;case 3:oe[be-1].push(oe[be]),this.$=oe[be-1];break;case 4:case 5:this.$=oe[be];break;case 6:case 7:this.$=[];break;case 8:ee.getCommonDb().setDiagramTitle(oe[be].substr(6)),this.$=oe[be].substr(6);break;case 9:this.$=oe[be].trim(),ee.getCommonDb().setAccTitle(this.$);break;case 10:case 11:this.$=oe[be].trim(),ee.getCommonDb().setAccDescription(this.$);break;case 12:ee.addSection(oe[be].substr(8)),this.$=oe[be].substr(8);break;case 15:ee.addTask(oe[be],0,""),this.$=oe[be];break;case 16:ee.addEvent(oe[be].substr(2)),this.$=oe[be];break}},table:[{3:1,4:[1,2]},{1:[3]},i(s,[2,2],{5:3}),{6:[1,4],7:5,8:[1,6],9:7,10:[1,8],11:u,12:d,14:p,16:v,17:b,18:14,19:15,20:y,21:T},i(s,[2,7],{1:[2,1]}),i(s,[2,3]),{9:18,11:u,12:d,14:p,16:v,17:b,18:14,19:15,20:y,21:T},i(s,[2,5]),i(s,[2,6]),i(s,[2,8]),{13:[1,19]},{15:[1,20]},i(s,[2,11]),i(s,[2,12]),i(s,[2,13]),i(s,[2,14]),i(s,[2,15]),i(s,[2,16]),i(s,[2,4]),i(s,[2,9]),i(s,[2,10])],defaultActions:{},parseError:function(F,j){if(j.recoverable)this.trace(F);else{var K=new Error(F);throw K.hash=j,K}},parse:function(F){var j=this,K=[0],ee=[],ie=[null],oe=[],pe=this.table,be="",ae=0,ne=0,se=2,de=1,X=oe.slice.call(arguments,1),ge=Object.create(this.lexer),W={yy:{}};for(var xe in this.yy)Object.prototype.hasOwnProperty.call(this.yy,xe)&&(W.yy[xe]=this.yy[xe]);ge.setInput(F,W.yy),W.yy.lexer=ge,W.yy.parser=this,typeof ge.yylloc>"u"&&(ge.yylloc={});var U=ge.yylloc;oe.push(U);var Fe=ge.options&&ge.options.ranges;typeof W.yy.parseError=="function"?this.parseError=W.yy.parseError:this.parseError=Object.getPrototypeOf(this).parseError;function Pe(){var Et;return Et=ee.pop()||ge.lex()||de,typeof Et!="number"&&(Et instanceof Array&&(ee=Et,Et=ee.pop()),Et=j.symbols_[Et]||Et),Et}for(var je,Ie,Se,Ce,ke={},Ke,Ft,Ne,gn;;){if(Ie=K[K.length-1],this.defaultActions[Ie]?Se=this.defaultActions[Ie]:((je===null||typeof je>"u")&&(je=Pe()),Se=pe[Ie]&&pe[Ie][je]),typeof Se>"u"||!Se.length||!Se[0]){var _t="";gn=[];for(Ke in pe[Ie])this.terminals_[Ke]&&Ke>se&&gn.push("'"+this.terminals_[Ke]+"'");ge.showPosition?_t="Parse error on line "+(ae+1)+`: +`+ge.showPosition()+` +Expecting `+gn.join(", ")+", got '"+(this.terminals_[je]||je)+"'":_t="Parse error on line "+(ae+1)+": Unexpected "+(je==de?"end of input":"'"+(this.terminals_[je]||je)+"'"),this.parseError(_t,{text:ge.match,token:this.terminals_[je]||je,line:ge.yylineno,loc:U,expected:gn})}if(Se[0]instanceof Array&&Se.length>1)throw new Error("Parse Error: multiple actions possible at state: "+Ie+", token: "+je);switch(Se[0]){case 1:K.push(je),ie.push(ge.yytext),oe.push(ge.yylloc),K.push(Se[1]),je=null,ne=ge.yyleng,be=ge.yytext,ae=ge.yylineno,U=ge.yylloc;break;case 2:if(Ft=this.productions_[Se[1]][1],ke.$=ie[ie.length-Ft],ke._$={first_line:oe[oe.length-(Ft||1)].first_line,last_line:oe[oe.length-1].last_line,first_column:oe[oe.length-(Ft||1)].first_column,last_column:oe[oe.length-1].last_column},Fe&&(ke._$.range=[oe[oe.length-(Ft||1)].range[0],oe[oe.length-1].range[1]]),Ce=this.performAction.apply(ke,[be,ne,ae,W.yy,Se[1],ie,oe].concat(X)),typeof Ce<"u")return Ce;Ft&&(K=K.slice(0,-1*Ft*2),ie=ie.slice(0,-1*Ft),oe=oe.slice(0,-1*Ft)),K.push(this.productions_[Se[1]][0]),ie.push(ke.$),oe.push(ke._$),Ne=pe[K[K.length-2]][K[K.length-1]],K.push(Ne);break;case 3:return!0}}return!0}},A=function(){var R={EOF:1,parseError:function(j,K){if(this.yy.parser)this.yy.parser.parseError(j,K);else throw new Error(j)},setInput:function(F,j){return this.yy=j||this.yy||{},this._input=F,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},input:function(){var F=this._input[0];this.yytext+=F,this.yyleng++,this.offset++,this.match+=F,this.matched+=F;var j=F.match(/(?:\r\n?|\n).*/g);return j?(this.yylineno++,this.yylloc.last_line++):this.yylloc.last_column++,this.options.ranges&&this.yylloc.range[1]++,this._input=this._input.slice(1),F},unput:function(F){var j=F.length,K=F.split(/(?:\r\n?|\n)/g);this._input=F+this._input,this.yytext=this.yytext.substr(0,this.yytext.length-j),this.offset-=j;var ee=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 ie=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===ee.length?this.yylloc.first_column:0)+ee[ee.length-K.length].length-K[0].length:this.yylloc.first_column-j},this.options.ranges&&(this.yylloc.range=[ie[0],ie[0]+this.yyleng-j]),this.yyleng=this.yytext.length,this},more:function(){return this._more=!0,this},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},less:function(F){this.unput(this.match.slice(F))},pastInput:function(){var F=this.matched.substr(0,this.matched.length-this.match.length);return(F.length>20?"...":"")+F.substr(-20).replace(/\n/g,"")},upcomingInput:function(){var F=this.match;return F.length<20&&(F+=this._input.substr(0,20-F.length)),(F.substr(0,20)+(F.length>20?"...":"")).replace(/\n/g,"")},showPosition:function(){var F=this.pastInput(),j=new Array(F.length+1).join("-");return F+this.upcomingInput()+` +`+j+"^"},test_match:function(F,j){var K,ee,ie;if(this.options.backtrack_lexer&&(ie={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&&(ie.yylloc.range=this.yylloc.range.slice(0))),ee=F[0].match(/(?:\r\n?|\n).*/g),ee&&(this.yylineno+=ee.length),this.yylloc={first_line:this.yylloc.last_line,last_line:this.yylineno+1,first_column:this.yylloc.last_column,last_column:ee?ee[ee.length-1].length-ee[ee.length-1].match(/\r?\n?/)[0].length:this.yylloc.last_column+F[0].length},this.yytext+=F[0],this.match+=F[0],this.matches=F,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(F[0].length),this.matched+=F[0],K=this.performAction.call(this,this.yy,this,j,this.conditionStack[this.conditionStack.length-1]),this.done&&this._input&&(this.done=!1),K)return K;if(this._backtrack){for(var oe in ie)this[oe]=ie[oe];return!1}return!1},next:function(){if(this.done)return this.EOF;this._input||(this.done=!0);var F,j,K,ee;this._more||(this.yytext="",this.match="");for(var ie=this._currentRules(),oe=0;oej[0].length)){if(j=K,ee=oe,this.options.backtrack_lexer){if(F=this.test_match(K,ie[oe]),F!==!1)return F;if(this._backtrack){j=!1;continue}else return!1}else if(!this.options.flex)break}return j?(F=this.test_match(j,ie[ee]),F!==!1?F:!1):this._input===""?this.EOF:this.parseError("Lexical error on line "+(this.yylineno+1)+`. Unrecognized text. +`+this.showPosition(),{text:"",token:null,line:this.yylineno})},lex:function(){var j=this.next();return j||this.lex()},begin:function(j){this.conditionStack.push(j)},popState:function(){var j=this.conditionStack.length-1;return j>0?this.conditionStack.pop():this.conditionStack[0]},_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},topState:function(j){return j=this.conditionStack.length-1-Math.abs(j||0),j>=0?this.conditionStack[j]:"INITIAL"},pushState:function(j){this.begin(j)},stateStackSize:function(){return this.conditionStack.length},options:{"case-insensitive":!0},performAction:function(j,K,ee,ie){switch(ee){case 0:break;case 1:break;case 2:return 10;case 3:break;case 4:break;case 5:return 4;case 6:return 11;case 7:return this.begin("acc_title"),12;case 8:return this.popState(),"acc_title_value";case 9:return this.begin("acc_descr"),14;case 10:return this.popState(),"acc_descr_value";case 11:this.begin("acc_descr_multiline");break;case 12:this.popState();break;case 13:return"acc_descr_multiline_value";case 14:return 17;case 15:return 21;case 16:return 20;case 17:return 6;case 18:return"INVALID"}},rules:[/^(?:%(?!\{)[^\n]*)/i,/^(?:[^\}]%%[^\n]*)/i,/^(?:[\n]+)/i,/^(?:\s+)/i,/^(?:#[^\n]*)/i,/^(?:timeline\b)/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,/^(?:section\s[^#:\n;]+)/i,/^(?::\s[^#:\n;]+)/i,/^(?:[^#:\n;]+)/i,/^(?:$)/i,/^(?:.)/i],conditions:{acc_descr_multiline:{rules:[12,13],inclusive:!1},acc_descr:{rules:[10],inclusive:!1},acc_title:{rules:[8],inclusive:!1},INITIAL:{rules:[0,1,2,3,4,5,6,7,9,11,14,15,16,17,18],inclusive:!0}}};return R}();_.lexer=A;function P(){this.yy={}}return P.prototype=_,_.Parser=P,new P}();Qve.parser=Qve;const $an=Qve;let ZD="",YKe=0;const Jve=[],IJ=[],eI=[],XKe=()=>Jje,QKe=function(){Jve.length=0,IJ.length=0,ZD="",eI.length=0,Pg()},JKe=function(i){ZD=i,Jve.push(i)},ZKe=function(){return Jve},eWe=function(){let i=iWe();const s=100;let u=0;for(;!i&&uu.id===YKe-1).events.push(i)},rWe=function(i){const s={section:ZD,type:ZD,description:i,task:i,classes:[]};IJ.push(s)},iWe=function(){const i=function(u){return eI[u].processed};let s=!0;for(const[u,d]of eI.entries())i(u),s=s&&d.processed;return s},zan=Object.freeze(Object.defineProperty({__proto__:null,addEvent:nWe,addSection:JKe,addTask:tWe,addTaskOrg:rWe,clear:QKe,default:{clear:QKe,getCommonDb:XKe,addSection:JKe,getSections:ZKe,getTasks:eWe,addTask:tWe,addTaskOrg:rWe,addEvent:nWe},getCommonDb:XKe,getSections:ZKe,getTasks:eWe},Symbol.toStringTag,{value:"Module"})),qan=12,OJ=function(i,s){const u=i.append("rect");return u.attr("x",s.x),u.attr("y",s.y),u.attr("fill",s.fill),u.attr("stroke",s.stroke),u.attr("width",s.width),u.attr("height",s.height),u.attr("rx",s.rx),u.attr("ry",s.ry),s.class!==void 0&&u.attr("class",s.class),u},Han=function(i,s){const d=i.append("circle").attr("cx",s.cx).attr("cy",s.cy).attr("class","face").attr("r",15).attr("stroke-width",2).attr("overflow","visible"),p=i.append("g");p.append("circle").attr("cx",s.cx-15/3).attr("cy",s.cy-15/3).attr("r",1.5).attr("stroke-width",2).attr("fill","#666").attr("stroke","#666"),p.append("circle").attr("cx",s.cx+15/3).attr("cy",s.cy-15/3).attr("r",1.5).attr("stroke-width",2).attr("fill","#666").attr("stroke","#666");function v(T){const _=lD().startAngle(Math.PI/2).endAngle(3*(Math.PI/2)).innerRadius(7.5).outerRadius(6.8181818181818175);T.append("path").attr("class","mouth").attr("d",_).attr("transform","translate("+s.cx+","+(s.cy+2)+")")}function b(T){const _=lD().startAngle(3*Math.PI/2).endAngle(5*(Math.PI/2)).innerRadius(7.5).outerRadius(6.8181818181818175);T.append("path").attr("class","mouth").attr("d",_).attr("transform","translate("+s.cx+","+(s.cy+7)+")")}function y(T){T.append("line").attr("class","mouth").attr("stroke",2).attr("x1",s.cx-5).attr("y1",s.cy+7).attr("x2",s.cx+5).attr("y2",s.cy+7).attr("class","mouth").attr("stroke-width","1px").attr("stroke","#666")}return s.score>3?v(p):s.score<3?b(p):y(p),d},Van=function(i,s){const u=i.append("circle");return u.attr("cx",s.cx),u.attr("cy",s.cy),u.attr("class","actor-"+s.pos),u.attr("fill",s.fill),u.attr("stroke",s.stroke),u.attr("r",s.r),u.class!==void 0&&u.attr("class",u.class),s.title!==void 0&&u.append("title").text(s.title),u},sWe=function(i,s){const u=s.text.replace(//gi," "),d=i.append("text");d.attr("x",s.x),d.attr("y",s.y),d.attr("class","legend"),d.style("text-anchor",s.anchor),s.class!==void 0&&d.attr("class",s.class);const p=d.append("tspan");return p.attr("x",s.x+s.textMargin*2),p.text(u),d},Uan=function(i,s){function u(p,v,b,y,T){return p+","+v+" "+(p+b)+","+v+" "+(p+b)+","+(v+y-T)+" "+(p+b-T*1.2)+","+(v+y)+" "+p+","+(v+y)}const d=i.append("polygon");d.attr("points",u(s.x,s.y,50,20,7)),d.attr("class","labelBox"),s.y=s.y+s.labelMargin,s.x=s.x+.5*s.labelMargin,sWe(i,s)},Gan=function(i,s,u){const d=i.append("g"),p=Zve();p.x=s.x,p.y=s.y,p.fill=s.fill,p.width=u.width,p.height=u.height,p.class="journey-section section-type-"+s.num,p.rx=3,p.ry=3,OJ(d,p),oWe(u)(s.text,d,p.x,p.y,p.width,p.height,{class:"journey-section section-type-"+s.num},u,s.colour)};let aWe=-1;const Kan=function(i,s,u){const d=s.x+u.width/2,p=i.append("g");aWe++;const v=300+5*30;p.append("line").attr("id","task"+aWe).attr("x1",d).attr("y1",s.y).attr("x2",d).attr("y2",v).attr("class","task-line").attr("stroke-width","1px").attr("stroke-dasharray","4 2").attr("stroke","#666"),Han(p,{cx:d,cy:300+(5-s.score)*30,score:s.score});const b=Zve();b.x=s.x,b.y=s.y,b.fill=s.fill,b.width=u.width,b.height=u.height,b.class="task task-type-"+s.num,b.rx=3,b.ry=3,OJ(p,b),s.x+14,oWe(u)(s.task,p,b.x,b.y,b.width,b.height,{class:"task"},u,s.colour)},Wan=function(i,s){OJ(i,{x:s.startx,y:s.starty,width:s.stopx-s.startx,height:s.stopy-s.starty,fill:s.fill,class:"rect"}).lower()},Yan=function(){return{x:0,y:0,fill:void 0,"text-anchor":"start",width:100,height:100,textMargin:0,rx:0,ry:0}},Zve=function(){return{x:0,y:0,width:100,anchor:"start",height:100,rx:0,ry:0}},oWe=function(){function i(p,v,b,y,T,_,A,P){const R=v.append("text").attr("x",b+T/2).attr("y",y+_/2+5).style("font-color",P).style("text-anchor","middle").text(p);d(R,A)}function s(p,v,b,y,T,_,A,P,R){const{taskFontSize:F,taskFontFamily:j}=P,K=p.split(//gi);for(let ee=0;ee)/).reverse(),p,v=[],b=1.1,y=u.attr("y"),T=parseFloat(u.attr("dy")),_=u.text(null).append("tspan").attr("x",0).attr("y",y).attr("dy",T+"em");for(let A=0;As||p==="
    ")&&(v.pop(),_.text(v.join(" ").trim()),p==="
    "?v=[""]:v=[p],_=u.append("tspan").attr("x",0).attr("y",y).attr("dy",b+"em").text(p))})}const Qan=function(i,s,u,d){const p=u%qan-1,v=i.append("g");s.section=p,v.attr("class",(s.class?s.class+" ":"")+"timeline-node "+("section-"+p));const b=v.append("g"),y=v.append("g"),_=y.append("text").text(s.descr).attr("dy","1em").attr("alignment-baseline","middle").attr("dominant-baseline","middle").attr("text-anchor","middle").call(cWe,s.width).node().getBBox(),A=d.fontSize&&d.fontSize.replace?d.fontSize.replace("px",""):d.fontSize;return s.height=_.height+A*1.1*.5+s.padding,s.height=Math.max(s.height,s.maxHeight),s.width=s.width+2*s.padding,y.attr("transform","translate("+s.width/2+", "+s.padding/2+")"),Zan(b,s,p),s},Jan=function(i,s,u){const d=i.append("g"),v=d.append("text").text(s.descr).attr("dy","1em").attr("alignment-baseline","middle").attr("dominant-baseline","middle").attr("text-anchor","middle").call(cWe,s.width).node().getBBox(),b=u.fontSize&&u.fontSize.replace?u.fontSize.replace("px",""):u.fontSize;return d.remove(),v.height+b*1.1*.5+s.padding},Zan=function(i,s,u){i.append("path").attr("id","node-"+s.id).attr("class","node-bkg node-"+s.type).attr("d",`M0 ${s.height-5} v${-s.height+2*5} q0,-5 5,-5 h${s.width-2*5} q5,0 5,5 v${s.height-5} H0 Z`),i.append("line").attr("class","node-line-"+u).attr("x1",0).attr("y1",s.height).attr("x2",s.width).attr("y2",s.height)},sS={drawRect:OJ,drawCircle:Van,drawSection:Gan,drawText:sWe,drawLabel:Uan,drawTask:Kan,drawBackgroundRect:Wan,getTextObj:Yan,getNoteRect:Zve,initGraphics:Xan,drawNode:Qan,getVirtualNodeHeight:Jan},eon=function(i,s,u,d){var X,ge;const p=qt(),v=p.leftMargin??50;Xe.debug("timeline",d.db);const b=p.securityLevel;let y;b==="sandbox"&&(y=Ir("#i"+s));const _=Ir(b==="sandbox"?y.nodes()[0].contentDocument.body:"body").select("#"+s);_.append("g");const A=d.db.getTasks(),P=d.db.getCommonDb().getDiagramTitle();Xe.debug("task",A),sS.initGraphics(_);const R=d.db.getSections();Xe.debug("sections",R);let F=0,j=0,K=0,ee=0,ie=50+v,oe=50;ee=50;let pe=0,be=!0;R.forEach(function(W){const xe={number:pe,descr:W,section:pe,width:150,padding:20,maxHeight:F},U=sS.getVirtualNodeHeight(_,xe,p);Xe.debug("sectionHeight before draw",U),F=Math.max(F,U+20)});let ae=0,ne=0;Xe.debug("tasks.length",A.length);for(const[W,xe]of A.entries()){const U={number:W,descr:xe,section:xe.section,width:150,padding:20,maxHeight:j},Fe=sS.getVirtualNodeHeight(_,U,p);Xe.debug("taskHeight before draw",Fe),j=Math.max(j,Fe+20),ae=Math.max(ae,xe.events.length);let Pe=0;for(let je=0;je0?R.forEach(W=>{const xe=A.filter(je=>je.section===W),U={number:pe,descr:W,section:pe,width:200*Math.max(xe.length,1)-50,padding:20,maxHeight:F};Xe.debug("sectionNode",U);const Fe=_.append("g"),Pe=sS.drawNode(Fe,U,pe,p);Xe.debug("sectionNode output",Pe),Fe.attr("transform",`translate(${ie}, ${ee})`),oe+=F+50,xe.length>0&&uWe(_,xe,pe,ie,oe,j,p,ae,ne,F,!1),ie+=200*Math.max(xe.length,1),oe=ee,pe++}):(be=!1,uWe(_,A,pe,ie,oe,j,p,ae,ne,F,!0));const se=_.node().getBBox();Xe.debug("bounds",se),P&&_.append("text").text(P).attr("x",se.width/2-v).attr("font-size","4ex").attr("font-weight","bold").attr("y",20),K=be?F+j+150:j+100,_.append("g").attr("class","lineWrapper").append("line").attr("x1",v).attr("y1",K).attr("x2",se.width+3*v).attr("y2",K).attr("stroke-width",4).attr("stroke","black").attr("marker-end","url(#arrowhead)"),y9(void 0,_,((X=p.timeline)==null?void 0:X.padding)??50,((ge=p.timeline)==null?void 0:ge.useMaxWidth)??!1)},uWe=function(i,s,u,d,p,v,b,y,T,_,A){var P;for(const R of s){const F={descr:R.task,section:u,number:u,width:150,padding:20,maxHeight:v};Xe.debug("taskNode",F);const j=i.append("g").attr("class","taskWrapper"),ee=sS.drawNode(j,F,u,b).height;if(Xe.debug("taskHeight after draw",ee),j.attr("transform",`translate(${d}, ${p})`),v=Math.max(v,ee),R.events){const ie=i.append("g").attr("class","lineWrapper");let oe=v;p+=100,oe=oe+ton(i,R.events,u,d,p,b),p-=100,ie.append("line").attr("x1",d+190/2).attr("y1",p+v).attr("x2",d+190/2).attr("y2",p+v+(A?v:_)+T+120).attr("stroke-width",2).attr("stroke","black").attr("marker-end","url(#arrowhead)").attr("stroke-dasharray","5,5")}d=d+200,A&&!((P=b.timeline)!=null&&P.disableMulticolor)&&u++}p=p-10},ton=function(i,s,u,d,p,v){let b=0;const y=p;p=p+100;for(const T of s){const _={descr:T,section:u,number:u,width:150,padding:20,maxHeight:50};Xe.debug("eventNode",_);const A=i.append("g").attr("class","eventWrapper"),R=sS.drawNode(A,_,u,v).height;b=b+R,A.attr("transform",`translate(${d}, ${p})`),p=p+10+R}return p=y,b},non={setConf:()=>{},draw:eon},ron=i=>{let s="";for(let u=0;u` + .edge { + stroke-width: 3; + } + ${ron(i)} + .section-root rect, .section-root path, .section-root circle { + fill: ${i.git0}; + } + .section-root text { + fill: ${i.gitBranchLabel0}; + } + .icon-container { + height:100%; + display: flex; + justify-content: center; + align-items: center; + } + .edge { + fill: none; + } + .eventWrapper { + filter: brightness(120%); + } +`}},Symbol.toStringTag,{value:"Module"}));var ewe=function(){var i=function(be,ae,ne,se){for(ne=ne||{},se=be.length;se--;ne[be[se]]=ae);return ne},s=[1,4],u=[1,13],d=[1,12],p=[1,15],v=[1,16],b=[1,20],y=[1,19],T=[6,7,8],_=[1,26],A=[1,24],P=[1,25],R=[6,7,11],F=[1,6,13,15,16,19,22],j=[1,33],K=[1,34],ee=[1,6,7,11,13,15,16,19,22],ie={trace:function(){},yy:{},symbols_:{error:2,start:3,mindMap:4,spaceLines:5,SPACELINE:6,NL:7,MINDMAP:8,document:9,stop:10,EOF:11,statement:12,SPACELIST:13,node:14,ICON:15,CLASS:16,nodeWithId:17,nodeWithoutId:18,NODE_DSTART:19,NODE_DESCR:20,NODE_DEND:21,NODE_ID:22,$accept:0,$end:1},terminals_:{2:"error",6:"SPACELINE",7:"NL",8:"MINDMAP",11:"EOF",13:"SPACELIST",15:"ICON",16:"CLASS",19:"NODE_DSTART",20:"NODE_DESCR",21:"NODE_DEND",22:"NODE_ID"},productions_:[0,[3,1],[3,2],[5,1],[5,2],[5,2],[4,2],[4,3],[10,1],[10,1],[10,1],[10,2],[10,2],[9,3],[9,2],[12,2],[12,2],[12,2],[12,1],[12,1],[12,1],[12,1],[12,1],[14,1],[14,1],[18,3],[17,1],[17,4]],performAction:function(ae,ne,se,de,X,ge,W){var xe=ge.length-1;switch(X){case 6:case 7:return de;case 8:de.getLogger().trace("Stop NL ");break;case 9:de.getLogger().trace("Stop EOF ");break;case 11:de.getLogger().trace("Stop NL2 ");break;case 12:de.getLogger().trace("Stop EOF2 ");break;case 15:de.getLogger().info("Node: ",ge[xe].id),de.addNode(ge[xe-1].length,ge[xe].id,ge[xe].descr,ge[xe].type);break;case 16:de.getLogger().trace("Icon: ",ge[xe]),de.decorateNode({icon:ge[xe]});break;case 17:case 21:de.decorateNode({class:ge[xe]});break;case 18:de.getLogger().trace("SPACELIST");break;case 19:de.getLogger().trace("Node: ",ge[xe].id),de.addNode(0,ge[xe].id,ge[xe].descr,ge[xe].type);break;case 20:de.decorateNode({icon:ge[xe]});break;case 25:de.getLogger().trace("node found ..",ge[xe-2]),this.$={id:ge[xe-1],descr:ge[xe-1],type:de.getType(ge[xe-2],ge[xe])};break;case 26:this.$={id:ge[xe],descr:ge[xe],type:de.nodeType.DEFAULT};break;case 27:de.getLogger().trace("node found ..",ge[xe-3]),this.$={id:ge[xe-3],descr:ge[xe-1],type:de.getType(ge[xe-2],ge[xe])};break}},table:[{3:1,4:2,5:3,6:[1,5],8:s},{1:[3]},{1:[2,1]},{4:6,6:[1,7],7:[1,8],8:s},{6:u,7:[1,10],9:9,12:11,13:d,14:14,15:p,16:v,17:17,18:18,19:b,22:y},i(T,[2,3]),{1:[2,2]},i(T,[2,4]),i(T,[2,5]),{1:[2,6],6:u,12:21,13:d,14:14,15:p,16:v,17:17,18:18,19:b,22:y},{6:u,9:22,12:11,13:d,14:14,15:p,16:v,17:17,18:18,19:b,22:y},{6:_,7:A,10:23,11:P},i(R,[2,22],{17:17,18:18,14:27,15:[1,28],16:[1,29],19:b,22:y}),i(R,[2,18]),i(R,[2,19]),i(R,[2,20]),i(R,[2,21]),i(R,[2,23]),i(R,[2,24]),i(R,[2,26],{19:[1,30]}),{20:[1,31]},{6:_,7:A,10:32,11:P},{1:[2,7],6:u,12:21,13:d,14:14,15:p,16:v,17:17,18:18,19:b,22:y},i(F,[2,14],{7:j,11:K}),i(ee,[2,8]),i(ee,[2,9]),i(ee,[2,10]),i(R,[2,15]),i(R,[2,16]),i(R,[2,17]),{20:[1,35]},{21:[1,36]},i(F,[2,13],{7:j,11:K}),i(ee,[2,11]),i(ee,[2,12]),{21:[1,37]},i(R,[2,25]),i(R,[2,27])],defaultActions:{2:[2,1],6:[2,2]},parseError:function(ae,ne){if(ne.recoverable)this.trace(ae);else{var se=new Error(ae);throw se.hash=ne,se}},parse:function(ae){var ne=this,se=[0],de=[],X=[null],ge=[],W=this.table,xe="",U=0,Fe=0,Pe=2,je=1,Ie=ge.slice.call(arguments,1),Se=Object.create(this.lexer),Ce={yy:{}};for(var ke in this.yy)Object.prototype.hasOwnProperty.call(this.yy,ke)&&(Ce.yy[ke]=this.yy[ke]);Se.setInput(ae,Ce.yy),Ce.yy.lexer=Se,Ce.yy.parser=this,typeof Se.yylloc>"u"&&(Se.yylloc={});var Ke=Se.yylloc;ge.push(Ke);var Ft=Se.options&&Se.options.ranges;typeof Ce.yy.parseError=="function"?this.parseError=Ce.yy.parseError:this.parseError=Object.getPrototypeOf(this).parseError;function Ne(){var On;return On=de.pop()||Se.lex()||je,typeof On!="number"&&(On instanceof Array&&(de=On,On=de.pop()),On=ne.symbols_[On]||On),On}for(var gn,_t,Et,Gt,ln={},xt,Pt,Qe,Dt;;){if(_t=se[se.length-1],this.defaultActions[_t]?Et=this.defaultActions[_t]:((gn===null||typeof gn>"u")&&(gn=Ne()),Et=W[_t]&&W[_t][gn]),typeof Et>"u"||!Et.length||!Et[0]){var kt="";Dt=[];for(xt in W[_t])this.terminals_[xt]&&xt>Pe&&Dt.push("'"+this.terminals_[xt]+"'");Se.showPosition?kt="Parse error on line "+(U+1)+`: +`+Se.showPosition()+` +Expecting `+Dt.join(", ")+", got '"+(this.terminals_[gn]||gn)+"'":kt="Parse error on line "+(U+1)+": Unexpected "+(gn==je?"end of input":"'"+(this.terminals_[gn]||gn)+"'"),this.parseError(kt,{text:Se.match,token:this.terminals_[gn]||gn,line:Se.yylineno,loc:Ke,expected:Dt})}if(Et[0]instanceof Array&&Et.length>1)throw new Error("Parse Error: multiple actions possible at state: "+_t+", token: "+gn);switch(Et[0]){case 1:se.push(gn),X.push(Se.yytext),ge.push(Se.yylloc),se.push(Et[1]),gn=null,Fe=Se.yyleng,xe=Se.yytext,U=Se.yylineno,Ke=Se.yylloc;break;case 2:if(Pt=this.productions_[Et[1]][1],ln.$=X[X.length-Pt],ln._$={first_line:ge[ge.length-(Pt||1)].first_line,last_line:ge[ge.length-1].last_line,first_column:ge[ge.length-(Pt||1)].first_column,last_column:ge[ge.length-1].last_column},Ft&&(ln._$.range=[ge[ge.length-(Pt||1)].range[0],ge[ge.length-1].range[1]]),Gt=this.performAction.apply(ln,[xe,Fe,U,Ce.yy,Et[1],X,ge].concat(Ie)),typeof Gt<"u")return Gt;Pt&&(se=se.slice(0,-1*Pt*2),X=X.slice(0,-1*Pt),ge=ge.slice(0,-1*Pt)),se.push(this.productions_[Et[1]][0]),X.push(ln.$),ge.push(ln._$),Qe=W[se[se.length-2]][se[se.length-1]],se.push(Qe);break;case 3:return!0}}return!0}},oe=function(){var be={EOF:1,parseError:function(ne,se){if(this.yy.parser)this.yy.parser.parseError(ne,se);else throw new Error(ne)},setInput:function(ae,ne){return this.yy=ne||this.yy||{},this._input=ae,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},input:function(){var ae=this._input[0];this.yytext+=ae,this.yyleng++,this.offset++,this.match+=ae,this.matched+=ae;var ne=ae.match(/(?:\r\n?|\n).*/g);return ne?(this.yylineno++,this.yylloc.last_line++):this.yylloc.last_column++,this.options.ranges&&this.yylloc.range[1]++,this._input=this._input.slice(1),ae},unput:function(ae){var ne=ae.length,se=ae.split(/(?:\r\n?|\n)/g);this._input=ae+this._input,this.yytext=this.yytext.substr(0,this.yytext.length-ne),this.offset-=ne;var de=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),se.length-1&&(this.yylineno-=se.length-1);var X=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:se?(se.length===de.length?this.yylloc.first_column:0)+de[de.length-se.length].length-se[0].length:this.yylloc.first_column-ne},this.options.ranges&&(this.yylloc.range=[X[0],X[0]+this.yyleng-ne]),this.yyleng=this.yytext.length,this},more:function(){return this._more=!0,this},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},less:function(ae){this.unput(this.match.slice(ae))},pastInput:function(){var ae=this.matched.substr(0,this.matched.length-this.match.length);return(ae.length>20?"...":"")+ae.substr(-20).replace(/\n/g,"")},upcomingInput:function(){var ae=this.match;return ae.length<20&&(ae+=this._input.substr(0,20-ae.length)),(ae.substr(0,20)+(ae.length>20?"...":"")).replace(/\n/g,"")},showPosition:function(){var ae=this.pastInput(),ne=new Array(ae.length+1).join("-");return ae+this.upcomingInput()+` +`+ne+"^"},test_match:function(ae,ne){var se,de,X;if(this.options.backtrack_lexer&&(X={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&&(X.yylloc.range=this.yylloc.range.slice(0))),de=ae[0].match(/(?:\r\n?|\n).*/g),de&&(this.yylineno+=de.length),this.yylloc={first_line:this.yylloc.last_line,last_line:this.yylineno+1,first_column:this.yylloc.last_column,last_column:de?de[de.length-1].length-de[de.length-1].match(/\r?\n?/)[0].length:this.yylloc.last_column+ae[0].length},this.yytext+=ae[0],this.match+=ae[0],this.matches=ae,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(ae[0].length),this.matched+=ae[0],se=this.performAction.call(this,this.yy,this,ne,this.conditionStack[this.conditionStack.length-1]),this.done&&this._input&&(this.done=!1),se)return se;if(this._backtrack){for(var ge in X)this[ge]=X[ge];return!1}return!1},next:function(){if(this.done)return this.EOF;this._input||(this.done=!0);var ae,ne,se,de;this._more||(this.yytext="",this.match="");for(var X=this._currentRules(),ge=0;gene[0].length)){if(ne=se,de=ge,this.options.backtrack_lexer){if(ae=this.test_match(se,X[ge]),ae!==!1)return ae;if(this._backtrack){ne=!1;continue}else return!1}else if(!this.options.flex)break}return ne?(ae=this.test_match(ne,X[de]),ae!==!1?ae:!1):this._input===""?this.EOF:this.parseError("Lexical error on line "+(this.yylineno+1)+`. Unrecognized text. +`+this.showPosition(),{text:"",token:null,line:this.yylineno})},lex:function(){var ne=this.next();return ne||this.lex()},begin:function(ne){this.conditionStack.push(ne)},popState:function(){var ne=this.conditionStack.length-1;return ne>0?this.conditionStack.pop():this.conditionStack[0]},_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},topState:function(ne){return ne=this.conditionStack.length-1-Math.abs(ne||0),ne>=0?this.conditionStack[ne]:"INITIAL"},pushState:function(ne){this.begin(ne)},stateStackSize:function(){return this.conditionStack.length},options:{"case-insensitive":!0},performAction:function(ne,se,de,X){switch(de){case 0:return ne.getLogger().trace("Found comment",se.yytext),6;case 1:return 8;case 2:this.begin("CLASS");break;case 3:return this.popState(),16;case 4:this.popState();break;case 5:ne.getLogger().trace("Begin icon"),this.begin("ICON");break;case 6:return ne.getLogger().trace("SPACELINE"),6;case 7:return 7;case 8:return 15;case 9:ne.getLogger().trace("end icon"),this.popState();break;case 10:return ne.getLogger().trace("Exploding node"),this.begin("NODE"),19;case 11:return ne.getLogger().trace("Cloud"),this.begin("NODE"),19;case 12:return ne.getLogger().trace("Explosion Bang"),this.begin("NODE"),19;case 13:return ne.getLogger().trace("Cloud Bang"),this.begin("NODE"),19;case 14:return this.begin("NODE"),19;case 15:return this.begin("NODE"),19;case 16:return this.begin("NODE"),19;case 17:return this.begin("NODE"),19;case 18:return 13;case 19:return 22;case 20:return 11;case 21:this.begin("NSTR2");break;case 22:return"NODE_DESCR";case 23:this.popState();break;case 24:ne.getLogger().trace("Starting NSTR"),this.begin("NSTR");break;case 25:return ne.getLogger().trace("description:",se.yytext),"NODE_DESCR";case 26:this.popState();break;case 27:return this.popState(),ne.getLogger().trace("node end ))"),"NODE_DEND";case 28:return this.popState(),ne.getLogger().trace("node end )"),"NODE_DEND";case 29:return this.popState(),ne.getLogger().trace("node end ...",se.yytext),"NODE_DEND";case 30:return this.popState(),ne.getLogger().trace("node end (("),"NODE_DEND";case 31:return this.popState(),ne.getLogger().trace("node end (-"),"NODE_DEND";case 32:return this.popState(),ne.getLogger().trace("node end (-"),"NODE_DEND";case 33:return this.popState(),ne.getLogger().trace("node end (("),"NODE_DEND";case 34:return this.popState(),ne.getLogger().trace("node end (("),"NODE_DEND";case 35:return ne.getLogger().trace("Long description:",se.yytext),20;case 36:return ne.getLogger().trace("Long description:",se.yytext),20}},rules:[/^(?:\s*%%.*)/i,/^(?:mindmap\b)/i,/^(?::::)/i,/^(?:.+)/i,/^(?:\n)/i,/^(?:::icon\()/i,/^(?:[\s]+[\n])/i,/^(?:[\n]+)/i,/^(?:[^\)]+)/i,/^(?:\))/i,/^(?:-\))/i,/^(?:\(-)/i,/^(?:\)\))/i,/^(?:\))/i,/^(?:\(\()/i,/^(?:\{\{)/i,/^(?:\()/i,/^(?:\[)/i,/^(?:[\s]+)/i,/^(?:[^\(\[\n\)\{\}]+)/i,/^(?:$)/i,/^(?:["][`])/i,/^(?:[^`"]+)/i,/^(?:[`]["])/i,/^(?:["])/i,/^(?:[^"]+)/i,/^(?:["])/i,/^(?:[\)]\))/i,/^(?:[\)])/i,/^(?:[\]])/i,/^(?:\}\})/i,/^(?:\(-)/i,/^(?:-\))/i,/^(?:\(\()/i,/^(?:\()/i,/^(?:[^\)\]\(\}]+)/i,/^(?:.+(?!\(\())/i],conditions:{CLASS:{rules:[3,4],inclusive:!1},ICON:{rules:[8,9],inclusive:!1},NSTR2:{rules:[22,23],inclusive:!1},NSTR:{rules:[25,26],inclusive:!1},NODE:{rules:[21,24,27,28,29,30,31,32,33,34,35,36],inclusive:!1},INITIAL:{rules:[0,1,2,5,6,7,10,11,12,13,14,15,16,17,18,19,20],inclusive:!0}}};return be}();ie.lexer=oe;function pe(){this.yy={}}return pe.prototype=ie,ie.Parser=pe,new pe}();ewe.parser=ewe;const son=ewe;let K3=[],lWe=0,twe={};const aon=()=>{K3=[],lWe=0,twe={}},oon=function(i){for(let s=K3.length-1;s>=0;s--)if(K3[s].levelK3.length>0?K3[0]:null,uon=(i,s,u,d)=>{var T,_;Xe.info("addNode",i,s,u,d);const p=qt();let v=((T=p.mindmap)==null?void 0:T.padding)??sh.mindmap.padding;switch(d){case v1.ROUNDED_RECT:case v1.RECT:case v1.HEXAGON:v*=2}const b={id:lWe++,nodeId:Yf(s,p),level:i,descr:Yf(u,p),type:d,children:[],width:((_=p.mindmap)==null?void 0:_.maxNodeWidth)??sh.mindmap.maxNodeWidth,padding:v},y=oon(i);if(y)y.children.push(b),K3.push(b);else if(K3.length===0)K3.push(b);else throw new Error('There can be only one root. No parent could be found for ("'+b.descr+'")')},v1={DEFAULT:0,NO_BORDER:0,ROUNDED_RECT:1,RECT:2,CIRCLE:3,CLOUD:4,BANG:5,HEXAGON:6},lon={clear:aon,addNode:uon,getMindmap:con,nodeType:v1,getType:(i,s)=>{switch(Xe.debug("In get type",i,s),i){case"[":return v1.RECT;case"(":return s===")"?v1.ROUNDED_RECT:v1.CLOUD;case"((":return v1.CIRCLE;case")":return v1.CLOUD;case"))":return v1.BANG;case"{{":return v1.HEXAGON;default:return v1.DEFAULT}},setElementForId:(i,s)=>{twe[i]=s},decorateNode:i=>{if(!i)return;const s=qt(),u=K3[K3.length-1];i.icon&&(u.icon=Yf(i.icon,s)),i.class&&(u.class=Yf(i.class,s))},type2Str:i=>{switch(i){case v1.DEFAULT:return"no-border";case v1.RECT:return"rect";case v1.ROUNDED_RECT:return"rounded-rect";case v1.CIRCLE:return"circle";case v1.CLOUD:return"cloud";case v1.BANG:return"bang";case v1.HEXAGON:return"hexgon";default:return"no-border"}},getLogger:()=>Xe,getElementById:i=>twe[i]};var hWe={exports:{}};(function(i,s){(function(u,d){i.exports=d()})(Ag,function(){function u(x){"@babel/helpers - typeof";return u=typeof Symbol=="function"&&typeof Symbol.iterator=="symbol"?function(m){return typeof m}:function(m){return m&&typeof Symbol=="function"&&m.constructor===Symbol&&m!==Symbol.prototype?"symbol":typeof m},u(x)}function d(x,m){if(!(x instanceof m))throw new TypeError("Cannot call a class as a function")}function p(x,m){for(var k=0;kx.length)&&(m=x.length);for(var k=0,S=new Array(m);k"u"?null:window,j=F?F.navigator:null;F&&F.document;var K=u(""),ee=u({}),ie=u(function(){}),oe=typeof HTMLElement>"u"?"undefined":u(HTMLElement),pe=function(m){return m&&m.instanceString&&ae(m.instanceString)?m.instanceString():null},be=function(m){return m!=null&&u(m)==K},ae=function(m){return m!=null&&u(m)===ie},ne=function(m){return!xe(m)&&(Array.isArray?Array.isArray(m):m!=null&&m instanceof Array)},se=function(m){return m!=null&&u(m)===ee&&!ne(m)&&m.constructor===Object},de=function(m){return m!=null&&u(m)===ee},X=function(m){return m!=null&&u(m)===u(1)&&!isNaN(m)},ge=function(m){return X(m)&&Math.floor(m)===m},W=function(m){if(oe!=="undefined")return m!=null&&m instanceof HTMLElement},xe=function(m){return U(m)||Fe(m)},U=function(m){return pe(m)==="collection"&&m._private.single},Fe=function(m){return pe(m)==="collection"&&!m._private.single},Pe=function(m){return pe(m)==="core"},je=function(m){return pe(m)==="stylesheet"},Ie=function(m){return pe(m)==="event"},Se=function(m){return m==null?!0:!!(m===""||m.match(/^\s+$/))},Ce=function(m){return typeof HTMLElement>"u"?!1:m instanceof HTMLElement},ke=function(m){return se(m)&&X(m.x1)&&X(m.x2)&&X(m.y1)&&X(m.y2)},Ke=function(m){return de(m)&&ae(m.then)},Ft=function(){return j&&j.userAgent.match(/msie|trident|edge/i)},Ne=function(m,k){k||(k=function(){if(arguments.length===1)return arguments[0];if(arguments.length===0)return"undefined";for(var O=[],N=0;Nk?1:0},zr=function(m,k){return-1*ht(m,k)},yt=Object.assign!=null?Object.assign.bind(Object):function(x){for(var m=arguments,k=1;k1&&(_e-=1),_e<1/6?me+(Le-me)*6*_e:_e<1/2?Le:_e<2/3?me+(Le-me)*(2/3-_e)*6:me}var Z=new RegExp("^"+Qe+"$").exec(m);if(Z){if(S=parseInt(Z[1]),S<0?S=(360- -1*S%360)%360:S>360&&(S=S%360),S/=360,M=parseFloat(Z[2]),M<0||M>100||(M=M/100,O=parseFloat(Z[3]),O<0||O>100)||(O=O/100,N=Z[4],N!==void 0&&(N=parseFloat(N),N<0||N>1)))return;if(M===0)$=H=q=Math.round(O*255);else{var ce=O<.5?O*(1+M):O+M-O*M,ve=2*O-ce;$=Math.round(255*Y(ve,ce,S+1/3)),H=Math.round(255*Y(ve,ce,S)),q=Math.round(255*Y(ve,ce,S-1/3))}k=[$,H,q,N]}return k},Ma=function(m){var k,S=new RegExp("^"+xt+"$").exec(m);if(S){k=[];for(var M=[],O=1;O<=3;O++){var N=S[O];if(N[N.length-1]==="%"&&(M[O]=!0),N=parseFloat(N),M[O]&&(N=N/100*255),N<0||N>255)return;k.push(Math.floor(N))}var $=M[1]||M[2]||M[3],H=M[1]&&M[2]&&M[3];if($&&!H)return;var q=S[4];if(q!==void 0){if(q=parseFloat(q),q<0||q>1)return;k.push(q)}}return k},zs=function(m){return Tr[m.toLowerCase()]},ao=function(m){return(ne(m)?m:null)||zs(m)||ji(m)||Ma(m)||xi(m)},Tr={transparent:[0,0,0,0],aliceblue:[240,248,255],antiquewhite:[250,235,215],aqua:[0,255,255],aquamarine:[127,255,212],azure:[240,255,255],beige:[245,245,220],bisque:[255,228,196],black:[0,0,0],blanchedalmond:[255,235,205],blue:[0,0,255],blueviolet:[138,43,226],brown:[165,42,42],burlywood:[222,184,135],cadetblue:[95,158,160],chartreuse:[127,255,0],chocolate:[210,105,30],coral:[255,127,80],cornflowerblue:[100,149,237],cornsilk:[255,248,220],crimson:[220,20,60],cyan:[0,255,255],darkblue:[0,0,139],darkcyan:[0,139,139],darkgoldenrod:[184,134,11],darkgray:[169,169,169],darkgreen:[0,100,0],darkgrey:[169,169,169],darkkhaki:[189,183,107],darkmagenta:[139,0,139],darkolivegreen:[85,107,47],darkorange:[255,140,0],darkorchid:[153,50,204],darkred:[139,0,0],darksalmon:[233,150,122],darkseagreen:[143,188,143],darkslateblue:[72,61,139],darkslategray:[47,79,79],darkslategrey:[47,79,79],darkturquoise:[0,206,209],darkviolet:[148,0,211],deeppink:[255,20,147],deepskyblue:[0,191,255],dimgray:[105,105,105],dimgrey:[105,105,105],dodgerblue:[30,144,255],firebrick:[178,34,34],floralwhite:[255,250,240],forestgreen:[34,139,34],fuchsia:[255,0,255],gainsboro:[220,220,220],ghostwhite:[248,248,255],gold:[255,215,0],goldenrod:[218,165,32],gray:[128,128,128],grey:[128,128,128],green:[0,128,0],greenyellow:[173,255,47],honeydew:[240,255,240],hotpink:[255,105,180],indianred:[205,92,92],indigo:[75,0,130],ivory:[255,255,240],khaki:[240,230,140],lavender:[230,230,250],lavenderblush:[255,240,245],lawngreen:[124,252,0],lemonchiffon:[255,250,205],lightblue:[173,216,230],lightcoral:[240,128,128],lightcyan:[224,255,255],lightgoldenrodyellow:[250,250,210],lightgray:[211,211,211],lightgreen:[144,238,144],lightgrey:[211,211,211],lightpink:[255,182,193],lightsalmon:[255,160,122],lightseagreen:[32,178,170],lightskyblue:[135,206,250],lightslategray:[119,136,153],lightslategrey:[119,136,153],lightsteelblue:[176,196,222],lightyellow:[255,255,224],lime:[0,255,0],limegreen:[50,205,50],linen:[250,240,230],magenta:[255,0,255],maroon:[128,0,0],mediumaquamarine:[102,205,170],mediumblue:[0,0,205],mediumorchid:[186,85,211],mediumpurple:[147,112,219],mediumseagreen:[60,179,113],mediumslateblue:[123,104,238],mediumspringgreen:[0,250,154],mediumturquoise:[72,209,204],mediumvioletred:[199,21,133],midnightblue:[25,25,112],mintcream:[245,255,250],mistyrose:[255,228,225],moccasin:[255,228,181],navajowhite:[255,222,173],navy:[0,0,128],oldlace:[253,245,230],olive:[128,128,0],olivedrab:[107,142,35],orange:[255,165,0],orangered:[255,69,0],orchid:[218,112,214],palegoldenrod:[238,232,170],palegreen:[152,251,152],paleturquoise:[175,238,238],palevioletred:[219,112,147],papayawhip:[255,239,213],peachpuff:[255,218,185],peru:[205,133,63],pink:[255,192,203],plum:[221,160,221],powderblue:[176,224,230],purple:[128,0,128],red:[255,0,0],rosybrown:[188,143,143],royalblue:[65,105,225],saddlebrown:[139,69,19],salmon:[250,128,114],sandybrown:[244,164,96],seagreen:[46,139,87],seashell:[255,245,238],sienna:[160,82,45],silver:[192,192,192],skyblue:[135,206,235],slateblue:[106,90,205],slategray:[112,128,144],slategrey:[112,128,144],snow:[255,250,250],springgreen:[0,255,127],steelblue:[70,130,180],tan:[210,180,140],teal:[0,128,128],thistle:[216,191,216],tomato:[255,99,71],turquoise:[64,224,208],violet:[238,130,238],wheat:[245,222,179],white:[255,255,255],whitesmoke:[245,245,245],yellow:[255,255,0],yellowgreen:[154,205,50]},Fn=function(m){for(var k=m.map,S=m.keys,M=S.length,O=0;O=m||Ye<0||Z&&mt>=O}function Ee(){var st=wo();if(_e(st))return Be(st);$=setTimeout(Ee,Le(st))}function Be(st){return $=void 0,ce&&S?ve(st):(S=M=void 0,N)}function Re(){$!==void 0&&clearTimeout($),q=0,S=H=M=$=void 0}function Ve(){return $===void 0?N:Be(wo())}function ct(){var st=wo(),Ye=_e(st);if(S=arguments,M=this,H=st,Ye){if($===void 0)return me(H);if(Z)return clearTimeout($),$=setTimeout(Ee,m),ve(H)}return $===void 0&&($=setTimeout(Ee,m)),N}return ct.cancel=Re,ct.flush=Ve,ct}var Nu=Bi,Ot=F?F.performance:null,W3=Ot&&Ot.now?function(){return Ot.now()}:function(){return Date.now()},Kt=function(){if(F){if(F.requestAnimationFrame)return function(x){F.requestAnimationFrame(x)};if(F.mozRequestAnimationFrame)return function(x){F.mozRequestAnimationFrame(x)};if(F.webkitRequestAnimationFrame)return function(x){F.webkitRequestAnimationFrame(x)};if(F.msRequestAnimationFrame)return function(x){F.msRequestAnimationFrame(x)}}return function(x){x&&setTimeout(function(){x(W3())},1e3/60)}}(),z0=function(m){return Kt(m)},Bp=W3,Y3=9261,$9=65599,c5=5381,Eh=function(m){for(var k=arguments.length>1&&arguments[1]!==void 0?arguments[1]:Y3,S=k,M;M=m.next(),!M.done;)S=S*$9+M.value|0;return S},zg=function(m){var k=arguments.length>1&&arguments[1]!==void 0?arguments[1]:Y3;return k*$9+m|0},bm=function(m){var k=arguments.length>1&&arguments[1]!==void 0?arguments[1]:c5;return(k<<5)+k+m|0},z9=function(m,k){return m*2097152+k},mm=function(m){return m[0]*2097152+m[1]},u5=function(m,k){return[zg(m[0],k[0]),bm(m[1],k[1])]},y1=function(m,k){var S={value:0,done:!1},M=0,O=m.length,N={next:function(){return M=0&&!(m[M]===k&&(m.splice(M,1),S));M--);},cS=function(m){m.splice(0,m.length)},uj=function(m,k){for(var S=0;S"u"?"undefined":u(Set))!==VJ?Set:UJ,uS=function(m,k){var S=arguments.length>2&&arguments[2]!==void 0?arguments[2]:!0;if(m===void 0||k===void 0||!Pe(m)){ch("An element must have a core reference and parameters set");return}var M=k.group;if(M==null&&(k.data&&k.data.source!=null&&k.data.target!=null?M="edges":M="nodes"),M!=="nodes"&&M!=="edges"){ch("An element must be of type `nodes` or `edges`; you specified `"+M+"`");return}this.length=1,this[0]=this;var O=this._private={cy:m,single:!0,data:k.data||{},position:k.position||{x:0,y:0},autoWidth:void 0,autoHeight:void 0,autoPadding:void 0,compoundBoundsClean:!1,listeners:[],group:M,style:{},rstyle:{},styleCxts:[],styleKeys:{},removed:!0,selected:!!k.selected,selectable:k.selectable===void 0?!0:!!k.selectable,locked:!!k.locked,grabbed:!1,grabbable:k.grabbable===void 0?!0:!!k.grabbable,pannable:k.pannable===void 0?M==="edges":!!k.pannable,active:!1,classes:new Q7,animation:{current:[],queue:[]},rscratch:{},scratch:k.scratch||{},edges:[],children:[],parent:k.parent&&k.parent.isNode()?k.parent:null,traversalCache:{},backgrounding:!1,bbCache:null,bbCacheShift:{x:0,y:0},bodyBounds:null,overlayBounds:null,labelBounds:{all:null,source:null,target:null,main:null},arrowBounds:{source:null,target:null,"mid-source":null,"mid-target":null}};if(O.position.x==null&&(O.position.x=0),O.position.y==null&&(O.position.y=0),k.renderedPosition){var N=k.renderedPosition,$=m.pan(),H=m.zoom();O.position={x:(N.x-$.x)/H,y:(N.y-$.y)/H}}var q=[];ne(k.classes)?q=k.classes:be(k.classes)&&(q=k.classes.split(/\s+/));for(var Y=0,Z=q.length;YBe?1:0},Y=function(Ee,Be,Re,Ve,ct){var st;if(Re==null&&(Re=0),ct==null&&(ct=S),Re<0)throw new Error("lo must be non-negative");for(Ve==null&&(Ve=Ee.length);ReLt;0<=Lt?Je++:Je--)mt.push(Je);return mt}).apply(this).reverse(),Ye=[],Ve=0,ct=st.length;VeMt;0<=Mt?++mt:--mt)ut.push(N(Ee,Re));return ut},Le=function(Ee,Be,Re,Ve){var ct,st,Ye;for(Ve==null&&(Ve=S),ct=Ee[Re];Re>Be;){if(Ye=Re-1>>1,st=Ee[Ye],Ve(ct,st)<0){Ee[Re]=st,Re=Ye;continue}break}return Ee[Re]=ct},_e=function(Ee,Be,Re){var Ve,ct,st,Ye,mt;for(Re==null&&(Re=S),ct=Ee.length,mt=Be,st=Ee[Be],Ve=2*Be+1;Ve0;){var st=Be.pop(),Ye=_e(st),mt=st.id();if(ce[mt]=Ye,Ye!==1/0)for(var Je=st.neighborhood().intersect(me),Lt=0;Lt0)for(Dn.unshift(Yt);Z[vr];){var Nn=Z[vr];Dn.unshift(Nn.edge),Dn.unshift(Nn.node),ir=Nn.node,vr=ir.id()}return $.spawn(Dn)}}}},YJ={kruskal:function(m){m=m||function(Re){return 1};for(var k=this.byGroup(),S=k.nodes,M=k.edges,O=S.length,N=new Array(O),$=S,H=function(Ve){for(var ct=0;ct0;){if(ct(),Ye++,Ve===Y){for(var mt=[],Je=O,Lt=Y,Mt=Ee[Lt];mt.unshift(Je),Mt!=null&&mt.unshift(Mt),Je=_e[Lt],Je!=null;)Lt=Je.id(),Mt=Ee[Lt];return{found:!0,distance:Z[Ve],path:this.spawn(mt),steps:Ye}}ve[Ve]=!0;for(var ut=Re._private.edges,Wt=0;WtMt&&(me[Lt]=Mt,Be[Lt]=Je,Re[Lt]=ct),!O){var ut=Je*Y+mt;!O&&me[ut]>Mt&&(me[ut]=Mt,Be[ut]=mt,Re[ut]=ct)}}}for(var Wt=0;Wt1&&arguments[1]!==void 0?arguments[1]:N,yo=Re(xs),$a=[],Da=yo;;){if(Da==null)return k.spawn();var Bo=Be(Da),tr=Bo.edge,G=Bo.pred;if($a.unshift(Da[0]),Da.same(Rs)&&$a.length>0)break;tr!=null&&$a.unshift(tr),Da=G}return H.spawn($a)},st=0;st=0;Y--){var Z=q[Y],ce=Z[1],ve=Z[2];(k[ce]===$&&k[ve]===H||k[ce]===H&&k[ve]===$)&&q.splice(Y,1)}for(var me=0;meM;){var O=Math.floor(Math.random()*k.length);k=rZ(O,m,k),S--}return k},iZ={kargerStein:function(){var m=this,k=this.byGroup(),S=k.nodes,M=k.edges;M.unmergeBy(function(Dn){return Dn.isLoop()});var O=S.length,N=M.length,$=Math.ceil(Math.pow(Math.log(O)/Math.LN2,2)),H=Math.floor(O/nZ);if(O<2){ch("At least 2 nodes are required for Karger-Stein algorithm");return}for(var q=[],Y=0;Y1&&arguments[1]!==void 0?arguments[1]:0,S=arguments.length>2&&arguments[2]!==void 0?arguments[2]:m.length,M=1/0,O=k;O1&&arguments[1]!==void 0?arguments[1]:0,S=arguments.length>2&&arguments[2]!==void 0?arguments[2]:m.length,M=-1/0,O=k;O1&&arguments[1]!==void 0?arguments[1]:0,S=arguments.length>2&&arguments[2]!==void 0?arguments[2]:m.length,M=0,O=0,N=k;N1&&arguments[1]!==void 0?arguments[1]:0,S=arguments.length>2&&arguments[2]!==void 0?arguments[2]:m.length,M=arguments.length>3&&arguments[3]!==void 0?arguments[3]:!0,O=arguments.length>4&&arguments[4]!==void 0?arguments[4]:!0,N=arguments.length>5&&arguments[5]!==void 0?arguments[5]:!0;M?m=m.slice(k,S):(S0&&m.splice(0,k));for(var $=0,H=m.length-1;H>=0;H--){var q=m[H];N?isFinite(q)||(m[H]=-1/0,$++):m.splice(H,1)}O&&m.sort(function(ce,ve){return ce-ve});var Y=m.length,Z=Math.floor(Y/2);return Y%2!==0?m[Z+1+$]:(m[Z-1+$]+m[Z+$])/2},lZ=function(m){return Math.PI*m/180},hS=function(m,k){return Math.atan2(k,m)-Math.PI/2},iI=Math.log2||function(x){return Math.log(x)/Math.log(2)},fj=function(m){return m>0?1:m<0?-1:0},h5=function(m,k){return Math.sqrt(f5(m,k))},f5=function(m,k){var S=k.x-m.x,M=k.y-m.y;return S*S+M*M},hZ=function(m){for(var k=m.length,S=0,M=0;M=m.x1&&m.y2>=m.y1)return{x1:m.x1,y1:m.y1,x2:m.x2,y2:m.y2,w:m.x2-m.x1,h:m.y2-m.y1};if(m.w!=null&&m.h!=null&&m.w>=0&&m.h>=0)return{x1:m.x1,y1:m.y1,x2:m.x1+m.w,y2:m.y1+m.h,w:m.w,h:m.h}}},dZ=function(m){return{x1:m.x1,x2:m.x2,w:m.w,y1:m.y1,y2:m.y2,h:m.h}},gZ=function(m){m.x1=1/0,m.y1=1/0,m.x2=-1/0,m.y2=-1/0,m.w=0,m.h=0},pZ=function(m,k,S){return{x1:m.x1+k,x2:m.x2+k,y1:m.y1+S,y2:m.y2+S,w:m.w,h:m.h}},dj=function(m,k){m.x1=Math.min(m.x1,k.x1),m.x2=Math.max(m.x2,k.x2),m.w=m.x2-m.x1,m.y1=Math.min(m.y1,k.y1),m.y2=Math.max(m.y2,k.y2),m.h=m.y2-m.y1},bZ=function(m,k,S){m.x1=Math.min(m.x1,k),m.x2=Math.max(m.x2,k),m.w=m.x2-m.x1,m.y1=Math.min(m.y1,S),m.y2=Math.max(m.y2,S),m.h=m.y2-m.y1},fS=function(m){var k=arguments.length>1&&arguments[1]!==void 0?arguments[1]:0;return m.x1-=k,m.x2+=k,m.y1-=k,m.y2+=k,m.w=m.x2-m.x1,m.h=m.y2-m.y1,m},dS=function(m){var k=arguments.length>1&&arguments[1]!==void 0?arguments[1]:[0],S,M,O,N;if(k.length===1)S=M=O=N=k[0];else if(k.length===2)S=O=k[0],N=M=k[1];else if(k.length===4){var $=y(k,4);S=$[0],M=$[1],O=$[2],N=$[3]}return m.x1-=N,m.x2+=M,m.y1-=S,m.y2+=O,m.w=m.x2-m.x1,m.h=m.y2-m.y1,m},gj=function(m,k){m.x1=k.x1,m.y1=k.y1,m.x2=k.x2,m.y2=k.y2,m.w=m.x2-m.x1,m.h=m.y2-m.y1},sI=function(m,k){return!(m.x1>k.x2||k.x1>m.x2||m.x2k.y2||k.y1>m.y2)},e8=function(m,k,S){return m.x1<=k&&k<=m.x2&&m.y1<=S&&S<=m.y2},mZ=function(m,k){return e8(m,k.x,k.y)},pj=function(m,k){return e8(m,k.x1,k.y1)&&e8(m,k.x2,k.y2)},bj=function(m,k,S,M,O,N,$){var H=W9(O,N),q=O/2,Y=N/2,Z;{var ce=S-q+H-$,ve=M-Y-$,me=S+q-H+$,Le=ve;if(Z=Z3(m,k,S,M,ce,ve,me,Le,!1),Z.length>0)return Z}{var _e=S+q+$,Ee=M-Y+H-$,Be=_e,Re=M+Y-H+$;if(Z=Z3(m,k,S,M,_e,Ee,Be,Re,!1),Z.length>0)return Z}{var Ve=S-q+H-$,ct=M+Y+$,st=S+q-H+$,Ye=ct;if(Z=Z3(m,k,S,M,Ve,ct,st,Ye,!1),Z.length>0)return Z}{var mt=S-q-$,Je=M-Y+H-$,Lt=mt,Mt=M+Y-H+$;if(Z=Z3(m,k,S,M,mt,Je,Lt,Mt,!1),Z.length>0)return Z}var ut;{var Wt=S-q+H,Tt=M-Y+H;if(ut=G9(m,k,S,M,Wt,Tt,H+$),ut.length>0&&ut[0]<=Wt&&ut[1]<=Tt)return[ut[0],ut[1]]}{var _n=S+q-H,hn=M-Y+H;if(ut=G9(m,k,S,M,_n,hn,H+$),ut.length>0&&ut[0]>=_n&&ut[1]<=hn)return[ut[0],ut[1]]}{var Yt=S+q-H,Dn=M+Y-H;if(ut=G9(m,k,S,M,Yt,Dn,H+$),ut.length>0&&ut[0]>=Yt&&ut[1]>=Dn)return[ut[0],ut[1]]}{var ir=S-q+H,vr=M+Y-H;if(ut=G9(m,k,S,M,ir,vr,H+$),ut.length>0&&ut[0]<=ir&&ut[1]>=vr)return[ut[0],ut[1]]}return[]},vZ=function(m,k,S,M,O,N,$){var H=$,q=Math.min(S,O),Y=Math.max(S,O),Z=Math.min(M,N),ce=Math.max(M,N);return q-H<=m&&m<=Y+H&&Z-H<=k&&k<=ce+H},wZ=function(m,k,S,M,O,N,$,H,q){var Y={x1:Math.min(S,$,O)-q,x2:Math.max(S,$,O)+q,y1:Math.min(M,H,N)-q,y2:Math.max(M,H,N)+q};return!(mY.x2||kY.y2)},yZ=function(m,k,S,M){S-=M;var O=k*k-4*m*S;if(O<0)return[];var N=Math.sqrt(O),$=2*m,H=(-k+N)/$,q=(-k-N)/$;return[H,q]},xZ=function(m,k,S,M,O){var N=1e-5;m===0&&(m=N),k/=m,S/=m,M/=m;var $,H,q,Y,Z,ce,ve,me;if(H=(3*S-k*k)/9,q=-(27*M)+k*(9*S-2*(k*k)),q/=54,$=H*H*H+q*q,O[1]=0,ve=k/3,$>0){Z=q+Math.sqrt($),Z=Z<0?-Math.pow(-Z,1/3):Math.pow(Z,1/3),ce=q-Math.sqrt($),ce=ce<0?-Math.pow(-ce,1/3):Math.pow(ce,1/3),O[0]=-ve+Z+ce,ve+=(Z+ce)/2,O[4]=O[2]=-ve,ve=Math.sqrt(3)*(-ce+Z)/2,O[3]=ve,O[5]=-ve;return}if(O[5]=O[3]=0,$===0){me=q<0?-Math.pow(-q,1/3):Math.pow(q,1/3),O[0]=-ve+2*me,O[4]=O[2]=-(me+ve);return}H=-H,Y=H*H*H,Y=Math.acos(q/Math.sqrt(Y)),me=2*Math.sqrt(H),O[0]=-ve+me*Math.cos(Y/3),O[2]=-ve+me*Math.cos((Y+2*Math.PI)/3),O[4]=-ve+me*Math.cos((Y+4*Math.PI)/3)},kZ=function(m,k,S,M,O,N,$,H){var q=1*S*S-4*S*O+2*S*$+4*O*O-4*O*$+$*$+M*M-4*M*N+2*M*H+4*N*N-4*N*H+H*H,Y=1*9*S*O-3*S*S-3*S*$-6*O*O+3*O*$+9*M*N-3*M*M-3*M*H-6*N*N+3*N*H,Z=1*3*S*S-6*S*O+S*$-S*m+2*O*O+2*O*m-$*m+3*M*M-6*M*N+M*H-M*k+2*N*N+2*N*k-H*k,ce=1*S*O-S*S+S*m-O*m+M*N-M*M+M*k-N*k,ve=[];xZ(q,Y,Z,ce,ve);for(var me=1e-7,Le=[],_e=0;_e<6;_e+=2)Math.abs(ve[_e+1])=0&&ve[_e]<=1&&Le.push(ve[_e]);Le.push(1),Le.push(0);for(var Ee=-1,Be,Re,Ve,ct=0;ct=0?Veq?(m-O)*(m-O)+(k-N)*(k-N):Y-ce},Yd=function(m,k,S){for(var M,O,N,$,H,q=0,Y=0;Y=m&&m>=N||M<=m&&m<=N)H=(m-M)/(N-M)*($-O)+O,H>k&&q++;else continue;return q%2!==0},Uv=function(m,k,S,M,O,N,$,H,q){var Y=new Array(S.length),Z;H[0]!=null?(Z=Math.atan(H[1]/H[0]),H[0]<0?Z=Z+Math.PI/2:Z=-Z-Math.PI/2):Z=H;for(var ce=Math.cos(-Z),ve=Math.sin(-Z),me=0;me0){var _e=pS(Y,-q);Le=gS(_e)}else Le=Y;return Yd(m,k,Le)},TZ=function(m,k,S,M,O,N,$){for(var H=new Array(S.length),q=N/2,Y=$/2,Z=cI(N,$),ce=Z*Z,ve=0;ve=0&&_e<=1&&Be.push(_e),Ee>=0&&Ee<=1&&Be.push(Ee),Be.length===0)return[];var Re=Be[0]*H[0]+m,Ve=Be[0]*H[1]+k;if(Be.length>1){if(Be[0]==Be[1])return[Re,Ve];var ct=Be[1]*H[0]+m,st=Be[1]*H[1]+k;return[Re,Ve,ct,st]}else return[Re,Ve]},aI=function(m,k,S){return k<=m&&m<=S||S<=m&&m<=k?m:m<=k&&k<=S||S<=k&&k<=m?k:S},Z3=function(m,k,S,M,O,N,$,H,q){var Y=m-O,Z=S-m,ce=$-O,ve=k-N,me=M-k,Le=H-N,_e=ce*ve-Le*Y,Ee=Z*ve-me*Y,Be=Le*Z-ce*me;if(Be!==0){var Re=_e/Be,Ve=Ee/Be,ct=.001,st=0-ct,Ye=1+ct;return st<=Re&&Re<=Ye&&st<=Ve&&Ve<=Ye?[m+Re*Z,k+Re*me]:q?[m+Re*Z,k+Re*me]:[]}else return _e===0||Ee===0?aI(m,S,$)===$?[$,H]:aI(m,S,O)===O?[O,N]:aI(O,$,S)===S?[S,M]:[]:[]},K9=function(m,k,S,M,O,N,$,H){var q=[],Y,Z=new Array(S.length),ce=!0;N==null&&(ce=!1);var ve;if(ce){for(var me=0;me0){var Le=pS(Z,-H);ve=gS(Le)}else ve=Z}else ve=S;for(var _e,Ee,Be,Re,Ve=0;Ve2){for(var hn=[q[0],q[1]],Yt=Math.pow(hn[0]-m,2)+Math.pow(hn[1]-k,2),Dn=1;DnY&&(Y=Ve)},get:function(Re){return q[Re]}},ce=0;ce<$.length;ce++){var ve=$[ce],me=ve.id();S?H[me]=ve.outgoers().nodes():H[me]=ve.openNeighborhood().nodes(),Z.set(me,0)}for(var Le=function(Re){for(var Ve=$[Re].id(),ct=[],st={},Ye={},mt={},Je=new V9(function(Cr,Or){return mt[Cr]-mt[Or]}),Lt=0;Lt<$.length;Lt++){var Mt=$[Lt].id();st[Mt]=[],Ye[Mt]=0,mt[Mt]=1/0}for(Ye[Ve]=1,mt[Ve]=0,Je.push(Ve);!Je.empty();){var ut=Je.pop();if(ct.push(ut),O)for(var Wt=0;Wt0?hn=_n.edgesTo(Tt)[0]:hn=Tt.edgesTo(_n)[0];var Yt=M(hn);Tt=Tt.id(),mt[Tt]>mt[ut]+Yt&&(mt[Tt]=mt[ut]+Yt,Je.nodes.indexOf(Tt)<0?Je.push(Tt):Je.updateItem(Tt),Ye[Tt]=0,st[Tt]=[]),mt[Tt]==mt[ut]+Yt&&(Ye[Tt]=Ye[Tt]+Ye[ut],st[Tt].push(ut))}else for(var Dn=0;Dn0;){for(var pr=ct.pop(),Er=0;Er0&&$.push(S[H]);$.length!==0&&O.push(M.collection($))}return O},jZ=function(m,k){for(var S=0;S5&&arguments[5]!==void 0?arguments[5]:qZ,$=M,H,q,Y=0;Y=2?Y9(m,k,S,0,Sj,HZ):Y9(m,k,S,0,Cj)},squaredEuclidean:function(m,k,S){return Y9(m,k,S,0,Sj)},manhattan:function(m,k,S){return Y9(m,k,S,0,Cj)},max:function(m,k,S){return Y9(m,k,S,-1/0,VZ)}};r8["squared-euclidean"]=r8.squaredEuclidean,r8.squaredeuclidean=r8.squaredEuclidean;function mS(x,m,k,S,M,O){var N;return ae(x)?N=x:N=r8[x]||r8.euclidean,m===0&&ae(x)?N(M,O):N(m,k,S,M,O)}var UZ=q0({k:2,m:2,sensitivityThreshold:1e-4,distance:"euclidean",maxIterations:10,attributes:[],testMode:!1,testCentroids:null}),hI=function(m){return UZ(m)},vS=function(m,k,S,M,O){var N=O!=="kMedoids",$=N?function(Z){return S[Z]}:function(Z){return M[Z](S)},H=function(ce){return M[ce](k)},q=S,Y=k;return mS(m,M.length,$,H,q,Y)},fI=function(m,k,S){for(var M=S.length,O=new Array(M),N=new Array(M),$=new Array(k),H=null,q=0;qS)return!1}return!0},WZ=function(m,k,S){for(var M=0;M$&&($=k[q][Y],H=Y);O[H].push(m[q])}for(var Z=0;Z=O.threshold||O.mode==="dendrogram"&&m.length===1)return!1;var me=k[N],Le=k[M[N]],_e;O.mode==="dendrogram"?_e={left:me,right:Le,key:me.key}:_e={value:me.value.concat(Le.value),key:me.key},m[me.index]=_e,m.splice(Le.index,1),k[me.key]=_e;for(var Ee=0;EeS[Le.key][Be.key]&&(H=S[Le.key][Be.key])):O.linkage==="max"?(H=S[me.key][Be.key],S[me.key][Be.key]0&&M.push(O);return M},Nj=function(m,k,S){for(var M=[],O=0;O$&&(N=q,$=k[O*m+q])}N>0&&M.push(N)}for(var Y=0;Yq&&(H=Y,q=Z)}S[O]=N[H]}return M=Nj(m,k,S),M},Pj=function(m){for(var k=this.cy(),S=this.nodes(),M=cee(m),O={},N=0;N=Mt?(ut=Mt,Mt=Tt,Wt=_n):Tt>ut&&(ut=Tt);for(var hn=0;hn<$;hn++)Z[Lt*$+hn]=(1-M.damping)*(q[Lt*$+hn]-Mt)+M.damping*Re[hn];Z[Lt*$+Wt]=(1-M.damping)*(q[Lt*$+Wt]-ut)+M.damping*Re[Wt]}for(var Yt=0;Yt<$;Yt++){for(var Dn=0,ir=0;ir<$;ir++)Re[ir]=ce[ir*$+Yt],Ve[ir]=Math.max(0,Z[ir*$+Yt]),Dn+=Ve[ir];Dn-=Ve[Yt],Ve[Yt]=Z[Yt*$+Yt],Dn+=Ve[Yt];for(var vr=0;vr<$;vr++)ce[vr*$+Yt]=(1-M.damping)*Math.min(0,Dn-Ve[vr])+M.damping*Re[vr];ce[Yt*$+Yt]=(1-M.damping)*(Dn-Ve[Yt])+M.damping*Re[Yt]}for(var Nn=0,pr=0;pr<$;pr++){var Er=ce[pr*$+pr]+Z[pr*$+pr]>0?1:0;Ye[Je%M.minIterations*$+pr]=Er,Nn+=Er}if(Nn>0&&(Je>=M.minIterations-1||Je==M.maxIterations-1)){for(var Mr=0,Cr=0;Cr<$;Cr++){ct[Cr]=0;for(var Or=0;Or1||st>1)&&($=!0),Z[Re]=[],Be.outgoers().forEach(function(mt){mt.isEdge()&&Z[Re].push(mt.id())})}else ce[Re]=[void 0,Be.target().id()]}):N.forEach(function(Be){var Re=Be.id();if(Be.isNode()){var Ve=Be.degree(!0);Ve%2&&(H?q?$=!0:q=Re:H=Re),Z[Re]=[],Be.connectedEdges().forEach(function(ct){return Z[Re].push(ct.id())})}else ce[Re]=[Be.source().id(),Be.target().id()]});var ve={found:!1,trail:void 0};if($)return ve;if(q&&H)if(O){if(Y&&q!=Y)return ve;Y=q}else{if(Y&&q!=Y&&H!=Y)return ve;Y||(Y=q)}else Y||(Y=N[0].id());var me=function(Re){for(var Ve=Re,ct=[Re],st,Ye,mt;Z[Ve].length;)st=Z[Ve].shift(),Ye=ce[st][0],mt=ce[st][1],Ve!=mt?(Z[mt]=Z[mt].filter(function(Je){return Je!=st}),Ve=mt):!O&&Ve!=Ye&&(Z[Ye]=Z[Ye].filter(function(Je){return Je!=st}),Ve=Ye),ct.unshift(st),ct.unshift(Ve);return ct},Le=[],_e=[];for(_e=me(Y);_e.length!=1;)Z[_e[0]].length==0?(Le.unshift(N.getElementById(_e.shift())),Le.unshift(N.getElementById(_e.shift()))):_e=me(_e.shift()).concat(_e);Le.unshift(N.getElementById(_e.shift()));for(var Ee in Z)if(Z[Ee].length)return ve;return ve.found=!0,ve.trail=this.spawn(Le,!0),ve}},yS=function(){var m=this,k={},S=0,M=0,O=[],N=[],$={},H=function(ce,ve){for(var me=N.length-1,Le=[],_e=m.spawn();N[me].x!=ce||N[me].y!=ve;)Le.push(N.pop().edge),me--;Le.push(N.pop().edge),Le.forEach(function(Ee){var Be=Ee.connectedNodes().intersection(m);_e.merge(Ee),Be.forEach(function(Re){var Ve=Re.id(),ct=Re.connectedEdges().intersection(m);_e.merge(Re),k[Ve].cutVertex?_e.merge(ct.filter(function(st){return st.isLoop()})):_e.merge(ct)})}),O.push(_e)},q=function Z(ce,ve,me){ce===me&&(M+=1),k[ve]={id:S,low:S++,cutVertex:!1};var Le=m.getElementById(ve).connectedEdges().intersection(m);if(Le.size()===0)O.push(m.spawn(m.getElementById(ve)));else{var _e,Ee,Be,Re;Le.forEach(function(Ve){_e=Ve.source().id(),Ee=Ve.target().id(),Be=_e===ve?Ee:_e,Be!==me&&(Re=Ve.id(),$[Re]||($[Re]=!0,N.push({x:ve,y:Be,edge:Ve})),Be in k?k[ve].low=Math.min(k[ve].low,k[Be].id):(Z(ce,Be,ve),k[ve].low=Math.min(k[ve].low,k[Be].low),k[ve].id<=k[Be].low&&(k[ve].cutVertex=!0,H(ve,Be))))})}};m.forEach(function(Z){if(Z.isNode()){var ce=Z.id();ce in k||(M=0,q(ce,ce),k[ce].cutVertex=M>1)}});var Y=Object.keys(k).filter(function(Z){return k[Z].cutVertex}).map(function(Z){return m.getElementById(Z)});return{cut:m.spawn(Y),components:O}},bee={hopcroftTarjanBiconnected:yS,htbc:yS,htb:yS,hopcroftTarjanBiconnectedComponents:yS},xS=function(){var m=this,k={},S=0,M=[],O=[],N=m.spawn(m),$=function H(q){O.push(q),k[q]={index:S,low:S++,explored:!1};var Y=m.getElementById(q).connectedEdges().intersection(m);if(Y.forEach(function(Le){var _e=Le.target().id();_e!==q&&(_e in k||H(_e),k[_e].explored||(k[q].low=Math.min(k[q].low,k[_e].low)))}),k[q].index===k[q].low){for(var Z=m.spawn();;){var ce=O.pop();if(Z.merge(m.getElementById(ce)),k[ce].low=k[q].index,k[ce].explored=!0,ce===q)break}var ve=Z.edgesWith(Z),me=Z.merge(ve);M.push(me),N=N.difference(me)}};return m.forEach(function(H){if(H.isNode()){var q=H.id();q in k||$(q)}}),{cut:N,components:M}},mee={tarjanStronglyConnected:xS,tsc:xS,tscc:xS,tarjanStronglyConnectedComponents:xS},Bj={};[H9,WJ,YJ,QJ,ZJ,tZ,iZ,LZ,t8,n8,lI,zZ,eee,aee,dee,pee,bee,mee].forEach(function(x){yt(Bj,x)});/*! +Embeddable Minimum Strictly-Compliant Promises/A+ 1.1.1 Thenable +Copyright (c) 2013-2014 Ralf S. Engelschall (http://engelschall.com) +Licensed under The MIT License (http://opensource.org/licenses/MIT) +*/var Fj=0,Rj=1,jj=2,Gv=function x(m){if(!(this instanceof x))return new x(m);this.id="Thenable/1.0.7",this.state=Fj,this.fulfillValue=void 0,this.rejectReason=void 0,this.onFulfilled=[],this.onRejected=[],this.proxy={then:this.then.bind(this)},typeof m=="function"&&m.call(this,this.fulfill.bind(this),this.reject.bind(this))};Gv.prototype={fulfill:function(m){return $j(this,Rj,"fulfillValue",m)},reject:function(m){return $j(this,jj,"rejectReason",m)},then:function(m,k){var S=this,M=new Gv;return S.onFulfilled.push(Hj(m,M,"fulfill")),S.onRejected.push(Hj(k,M,"reject")),zj(S),M.proxy}};var $j=function(m,k,S,M){return m.state===Fj&&(m.state=k,m[S]=M,zj(m)),m},zj=function(m){m.state===Rj?qj(m,"onFulfilled",m.fulfillValue):m.state===jj&&qj(m,"onRejected",m.rejectReason)},qj=function(m,k,S){if(m[k].length!==0){var M=m[k];m[k]=[];var O=function(){for(var $=0;$0}},clearQueue:function(){return function(){var k=this,S=k.length!==void 0,M=S?k:[k],O=this._private.cy||this;if(!O.styleEnabled())return this;for(var N=0;N-1}var vte=mte;function wte(x,m){var k=this.__data__,S=TS(k,x);return S<0?(++this.size,k.push([x,m])):k[S][1]=m,this}var yte=wte;function a8(x){var m=-1,k=x==null?0:x.length;for(this.clear();++m-1&&x%1==0&&x0&&this.spawn(M).updateStyle().emit("class"),k},addClass:function(m){return this.toggleClass(m,!0)},hasClass:function(m){var k=this[0];return k!=null&&k._private.classes.has(m)},toggleClass:function(m,k){ne(m)||(m=m.match(/\S+/g)||[]);for(var S=this,M=k===void 0,O=[],N=0,$=S.length;N<$;N++)for(var H=S[N],q=H._private.classes,Y=!1,Z=0;Z0&&this.spawn(O).updateStyle().emit("class"),S},removeClass:function(m){return this.toggleClass(m,!1)},flashClass:function(m,k){var S=this;if(k==null)k=250;else if(k===0)return S;return S.addClass(m),setTimeout(function(){S.removeClass(m)},k),S}};SS.className=SS.classNames=SS.classes;var Rc={metaChar:"[\\!\\\"\\#\\$\\%\\&\\'\\(\\)\\*\\+\\,\\.\\/\\:\\;\\<\\=\\>\\?\\@\\[\\]\\^\\`\\{\\|\\}\\~]",comparatorOp:"=|\\!=|>|>=|<|<=|\\$=|\\^=|\\*=",boolOp:"\\?|\\!|\\^",string:`"(?:\\\\"|[^"])*"|'(?:\\\\'|[^'])*'`,number:ln,meta:"degree|indegree|outdegree",separator:"\\s*,\\s*",descendant:"\\s+",child:"\\s+>\\s+",subject:"\\$",group:"node|edge|\\*",directedEdge:"\\s+->\\s+",undirectedEdge:"\\s+<->\\s+"};Rc.variable="(?:[\\w-.]|(?:\\\\"+Rc.metaChar+"))+",Rc.className="(?:[\\w-]|(?:\\\\"+Rc.metaChar+"))+",Rc.value=Rc.string+"|"+Rc.number,Rc.id=Rc.variable,function(){var x,m,k;for(x=Rc.comparatorOp.split("|"),k=0;k=0)&&m!=="="&&(Rc.comparatorOp+="|\\!"+m)}();var Pu=function(){return{checks:[]}},hs={GROUP:0,COLLECTION:1,FILTER:2,DATA_COMPARE:3,DATA_EXIST:4,DATA_BOOL:5,META_COMPARE:6,STATE:7,ID:8,CLASS:9,UNDIRECTED_EDGE:10,DIRECTED_EDGE:11,NODE_SOURCE:12,NODE_TARGET:13,NODE_NEIGHBOR:14,CHILD:15,DESCENDANT:16,PARENT:17,ANCESTOR:18,COMPOUND_SPLIT:19,TRUE:20},mI=[{selector:":selected",matches:function(m){return m.selected()}},{selector:":unselected",matches:function(m){return!m.selected()}},{selector:":selectable",matches:function(m){return m.selectable()}},{selector:":unselectable",matches:function(m){return!m.selectable()}},{selector:":locked",matches:function(m){return m.locked()}},{selector:":unlocked",matches:function(m){return!m.locked()}},{selector:":visible",matches:function(m){return m.visible()}},{selector:":hidden",matches:function(m){return!m.visible()}},{selector:":transparent",matches:function(m){return m.transparent()}},{selector:":grabbed",matches:function(m){return m.grabbed()}},{selector:":free",matches:function(m){return!m.grabbed()}},{selector:":removed",matches:function(m){return m.removed()}},{selector:":inside",matches:function(m){return!m.removed()}},{selector:":grabbable",matches:function(m){return m.grabbable()}},{selector:":ungrabbable",matches:function(m){return!m.grabbable()}},{selector:":animated",matches:function(m){return m.animated()}},{selector:":unanimated",matches:function(m){return!m.animated()}},{selector:":parent",matches:function(m){return m.isParent()}},{selector:":childless",matches:function(m){return m.isChildless()}},{selector:":child",matches:function(m){return m.isChild()}},{selector:":orphan",matches:function(m){return m.isOrphan()}},{selector:":nonorphan",matches:function(m){return m.isChild()}},{selector:":compound",matches:function(m){return m.isNode()?m.isParent():m.source().isParent()||m.target().isParent()}},{selector:":loop",matches:function(m){return m.isLoop()}},{selector:":simple",matches:function(m){return m.isSimple()}},{selector:":active",matches:function(m){return m.active()}},{selector:":inactive",matches:function(m){return!m.active()}},{selector:":backgrounding",matches:function(m){return m.backgrounding()}},{selector:":nonbackgrounding",matches:function(m){return!m.backgrounding()}}].sort(function(x,m){return zr(x.selector,m.selector)}),Ene=function(){for(var x={},m,k=0;k0&&Y.edgeCount>0)return hu("The selector `"+m+"` is invalid because it uses both a compound selector and an edge selector"),!1;if(Y.edgeCount>1)return hu("The selector `"+m+"` is invalid because it uses multiple edge selectors"),!1;Y.edgeCount===1&&hu("The selector `"+m+"` is deprecated. Edge selectors do not take effect on changes to source and target nodes after an edge is added, for performance reasons. Use a class or data selector on edges instead, updating the class or data of an edge when your app detects a change in source or target nodes.")}return!0},Ane=function(){if(this.toStringCache!=null)return this.toStringCache;for(var m=function(Y){return Y??""},k=function(Y){return be(Y)?'"'+Y+'"':m(Y)},S=function(Y){return" "+Y+" "},M=function(Y,Z){var ce=Y.type,ve=Y.value;switch(ce){case hs.GROUP:{var me=m(ve);return me.substring(0,me.length-1)}case hs.DATA_COMPARE:{var Le=Y.field,_e=Y.operator;return"["+Le+S(m(_e))+k(ve)+"]"}case hs.DATA_BOOL:{var Ee=Y.operator,Be=Y.field;return"["+m(Ee)+Be+"]"}case hs.DATA_EXIST:{var Re=Y.field;return"["+Re+"]"}case hs.META_COMPARE:{var Ve=Y.operator,ct=Y.field;return"[["+ct+S(m(Ve))+k(ve)+"]]"}case hs.STATE:return ve;case hs.ID:return"#"+ve;case hs.CLASS:return"."+ve;case hs.PARENT:case hs.CHILD:return O(Y.parent,Z)+S(">")+O(Y.child,Z);case hs.ANCESTOR:case hs.DESCENDANT:return O(Y.ancestor,Z)+" "+O(Y.descendant,Z);case hs.COMPOUND_SPLIT:{var st=O(Y.left,Z),Ye=O(Y.subject,Z),mt=O(Y.right,Z);return st+(st.length>0?" ":"")+Ye+mt}case hs.TRUE:return""}},O=function(Y,Z){return Y.checks.reduce(function(ce,ve,me){return ce+(Z===Y&&me===0?"$":"")+M(ve,Z)},"")},N="",$=0;$1&&$=0&&(k=k.replace("!",""),Z=!0),k.indexOf("@")>=0&&(k=k.replace("@",""),Y=!0),(O||$||Y)&&(H=!O&&!N?"":""+m,q=""+S),Y&&(m=H=H.toLowerCase(),S=q=q.toLowerCase()),k){case"*=":M=H.indexOf(q)>=0;break;case"$=":M=H.indexOf(q,H.length-q.length)>=0;break;case"^=":M=H.indexOf(q)===0;break;case"=":M=m===S;break;case">":ce=!0,M=m>S;break;case">=":ce=!0,M=m>=S;break;case"<":ce=!0,M=m0;){var Y=M.shift();m(Y),O.add(Y.id()),$&&S(M,O,Y)}return x}function l$(x,m,k){if(k.isParent())for(var S=k._private.children,M=0;M1&&arguments[1]!==void 0?arguments[1]:!0;return yI(this,x,m,l$)};function h$(x,m,k){if(k.isChild()){var S=k._private.parent;m.has(S.id())||x.push(S)}}u8.forEachUp=function(x){var m=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!0;return yI(this,x,m,h$)};function Pne(x,m,k){h$(x,m,k),l$(x,m,k)}u8.forEachUpAndDown=function(x){var m=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!0;return yI(this,x,m,Pne)},u8.ancestors=u8.parents;var x1,f$;x1=f$={data:fu.data({field:"data",bindingEvent:"data",allowBinding:!0,allowSetting:!0,settingEvent:"data",settingTriggersEvent:!0,triggerFnName:"trigger",allowGetting:!0,immutableKeys:{id:!0,source:!0,target:!0,parent:!0},updateStyle:!0}),removeData:fu.removeData({field:"data",event:"data",triggerFnName:"trigger",triggerEvent:!0,immutableKeys:{id:!0,source:!0,target:!0,parent:!0},updateStyle:!0}),scratch:fu.data({field:"scratch",bindingEvent:"scratch",allowBinding:!0,allowSetting:!0,settingEvent:"scratch",settingTriggersEvent:!0,triggerFnName:"trigger",allowGetting:!0,updateStyle:!0}),removeScratch:fu.removeData({field:"scratch",event:"scratch",triggerFnName:"trigger",triggerEvent:!0,updateStyle:!0}),rscratch:fu.data({field:"rscratch",allowBinding:!1,allowSetting:!0,settingTriggersEvent:!1,allowGetting:!0}),removeRscratch:fu.removeData({field:"rscratch",triggerEvent:!1}),id:function(){var m=this[0];if(m)return m._private.data.id}},x1.attr=x1.data,x1.removeAttr=x1.removeData;var ny=f$,J9={};function xI(x){return function(m){var k=this;if(m===void 0&&(m=!0),k.length!==0)if(k.isNode()&&!k.removed()){for(var S=0,M=k[0],O=M._private.edges,N=0;Nm}),minIndegree:l8("indegree",function(x,m){return xm}),minOutdegree:l8("outdegree",function(x,m){return xm})}),yt(J9,{totalDegree:function(m){for(var k=0,S=this.nodes(),M=0;M0,ce=Z;Z&&(Y=Y[0]);var ve=ce?Y.position():{x:0,y:0};k!==void 0?q.position(m,k+ve[m]):O!==void 0&&q.position({x:O.x+ve.x,y:O.y+ve.y})}else{var me=S.position(),Le=$?S.parent():null,_e=Le&&Le.length>0,Ee=_e;_e&&(Le=Le[0]);var Be=Ee?Le.position():{x:0,y:0};return O={x:me.x-Be.x,y:me.y-Be.y},m===void 0?O:O[m]}else if(!N)return;return this}},W2.modelPosition=W2.point=W2.position,W2.modelPositions=W2.points=W2.positions,W2.renderedPoint=W2.renderedPosition,W2.relativePoint=W2.relativePosition;var Bne=d$,h8,ry;h8=ry={},ry.renderedBoundingBox=function(x){var m=this.boundingBox(x),k=this.cy(),S=k.zoom(),M=k.pan(),O=m.x1*S+M.x,N=m.x2*S+M.x,$=m.y1*S+M.y,H=m.y2*S+M.y;return{x1:O,x2:N,y1:$,y2:H,w:N-O,h:H-$}},ry.dirtyCompoundBoundsCache=function(){var x=arguments.length>0&&arguments[0]!==void 0?arguments[0]:!1,m=this.cy();return!m.styleEnabled()||!m.hasCompoundNodes()?this:(this.forEachUp(function(k){if(k.isParent()){var S=k._private;S.compoundBoundsClean=!1,S.bbCache=null,x||k.emitAndNotify("bounds")}}),this)},ry.updateCompoundBounds=function(){var x=arguments.length>0&&arguments[0]!==void 0?arguments[0]:!1,m=this.cy();if(!m.styleEnabled()||!m.hasCompoundNodes())return this;if(!x&&m.batching())return this;function k(N){if(!N.isParent())return;var $=N._private,H=N.children(),q=N.pstyle("compound-sizing-wrt-labels").value==="include",Y={width:{val:N.pstyle("min-width").pfValue,left:N.pstyle("min-width-bias-left"),right:N.pstyle("min-width-bias-right")},height:{val:N.pstyle("min-height").pfValue,top:N.pstyle("min-height-bias-top"),bottom:N.pstyle("min-height-bias-bottom")}},Z=H.boundingBox({includeLabels:q,includeOverlays:!1,useCache:!1}),ce=$.position;(Z.w===0||Z.h===0)&&(Z={w:N.pstyle("width").pfValue,h:N.pstyle("height").pfValue},Z.x1=ce.x-Z.w/2,Z.x2=ce.x+Z.w/2,Z.y1=ce.y-Z.h/2,Z.y2=ce.y+Z.h/2);function ve(Je,Lt,Mt){var ut=0,Wt=0,Tt=Lt+Mt;return Je>0&&Tt>0&&(ut=Lt/Tt*Je,Wt=Mt/Tt*Je),{biasDiff:ut,biasComplementDiff:Wt}}function me(Je,Lt,Mt,ut){if(Mt.units==="%")switch(ut){case"width":return Je>0?Mt.pfValue*Je:0;case"height":return Lt>0?Mt.pfValue*Lt:0;case"average":return Je>0&&Lt>0?Mt.pfValue*(Je+Lt)/2:0;case"min":return Je>0&&Lt>0?Je>Lt?Mt.pfValue*Lt:Mt.pfValue*Je:0;case"max":return Je>0&&Lt>0?Je>Lt?Mt.pfValue*Je:Mt.pfValue*Lt:0;default:return 0}else return Mt.units==="px"?Mt.pfValue:0}var Le=Y.width.left.value;Y.width.left.units==="px"&&Y.width.val>0&&(Le=Le*100/Y.width.val);var _e=Y.width.right.value;Y.width.right.units==="px"&&Y.width.val>0&&(_e=_e*100/Y.width.val);var Ee=Y.height.top.value;Y.height.top.units==="px"&&Y.height.val>0&&(Ee=Ee*100/Y.height.val);var Be=Y.height.bottom.value;Y.height.bottom.units==="px"&&Y.height.val>0&&(Be=Be*100/Y.height.val);var Re=ve(Y.width.val-Z.w,Le,_e),Ve=Re.biasDiff,ct=Re.biasComplementDiff,st=ve(Y.height.val-Z.h,Ee,Be),Ye=st.biasDiff,mt=st.biasComplementDiff;$.autoPadding=me(Z.w,Z.h,N.pstyle("padding"),N.pstyle("padding-relative-to").value),$.autoWidth=Math.max(Z.w,Y.width.val),ce.x=(-Ve+Z.x1+Z.x2+ct)/2,$.autoHeight=Math.max(Z.h,Y.height.val),ce.y=(-Ye+Z.y1+Z.y2+mt)/2}for(var S=0;Sm.x2?M:m.x2,m.y1=Sm.y2?O:m.y2,m.w=m.x2-m.x1,m.h=m.y2-m.y1)},b5=function(m,k){return k==null?m:Y2(m,k.x1,k.y1,k.x2,k.y2)},Z9=function(m,k,S){return K2(m,k,S)},_S=function(m,k,S){if(!k.cy().headless()){var M=k._private,O=M.rstyle,N=O.arrowWidth/2,$=k.pstyle(S+"-arrow-shape").value,H,q;if($!=="none"){S==="source"?(H=O.srcX,q=O.srcY):S==="target"?(H=O.tgtX,q=O.tgtY):(H=O.midX,q=O.midY);var Y=M.arrowBounds=M.arrowBounds||{},Z=Y[S]=Y[S]||{};Z.x1=H-N,Z.y1=q-N,Z.x2=H+N,Z.y2=q+N,Z.w=Z.x2-Z.x1,Z.h=Z.y2-Z.y1,fS(Z,1),Y2(m,Z.x1,Z.y1,Z.x2,Z.y2)}}},kI=function(m,k,S){if(!k.cy().headless()){var M;S?M=S+"-":M="";var O=k._private,N=O.rstyle,$=k.pstyle(M+"label").strValue;if($){var H=k.pstyle("text-halign"),q=k.pstyle("text-valign"),Y=Z9(N,"labelWidth",S),Z=Z9(N,"labelHeight",S),ce=Z9(N,"labelX",S),ve=Z9(N,"labelY",S),me=k.pstyle(M+"text-margin-x").pfValue,Le=k.pstyle(M+"text-margin-y").pfValue,_e=k.isEdge(),Ee=k.pstyle(M+"text-rotation"),Be=k.pstyle("text-outline-width").pfValue,Re=k.pstyle("text-border-width").pfValue,Ve=Re/2,ct=k.pstyle("text-background-padding").pfValue,st=2,Ye=Z,mt=Y,Je=mt/2,Lt=Ye/2,Mt,ut,Wt,Tt;if(_e)Mt=ce-Je,ut=ce+Je,Wt=ve-Lt,Tt=ve+Lt;else{switch(H.value){case"left":Mt=ce-mt,ut=ce;break;case"center":Mt=ce-Je,ut=ce+Je;break;case"right":Mt=ce,ut=ce+mt;break}switch(q.value){case"top":Wt=ve-Ye,Tt=ve;break;case"center":Wt=ve-Lt,Tt=ve+Lt;break;case"bottom":Wt=ve,Tt=ve+Ye;break}}Mt+=me-Math.max(Be,Ve)-ct-st,ut+=me+Math.max(Be,Ve)+ct+st,Wt+=Le-Math.max(Be,Ve)-ct-st,Tt+=Le+Math.max(Be,Ve)+ct+st;var _n=S||"main",hn=O.labelBounds,Yt=hn[_n]=hn[_n]||{};Yt.x1=Mt,Yt.y1=Wt,Yt.x2=ut,Yt.y2=Tt,Yt.w=ut-Mt,Yt.h=Tt-Wt;var Dn=_e&&Ee.strValue==="autorotate",ir=Ee.pfValue!=null&&Ee.pfValue!==0;if(Dn||ir){var vr=Dn?Z9(O.rstyle,"labelAngle",S):Ee.pfValue,Nn=Math.cos(vr),pr=Math.sin(vr),Er=(Mt+ut)/2,Mr=(Wt+Tt)/2;if(!_e){switch(H.value){case"left":Er=ut;break;case"right":Er=Mt;break}switch(q.value){case"top":Mr=Tt;break;case"bottom":Mr=Wt;break}}var Cr=function(pa,Mi){return pa=pa-Er,Mi=Mi-Mr,{x:pa*Nn-Mi*pr+Er,y:pa*pr+Mi*Nn+Mr}},Or=Cr(Mt,Wt),Wn=Cr(Mt,Tt),br=Cr(ut,Wt),Sr=Cr(ut,Tt);Mt=Math.min(Or.x,Wn.x,br.x,Sr.x),ut=Math.max(Or.x,Wn.x,br.x,Sr.x),Wt=Math.min(Or.y,Wn.y,br.y,Sr.y),Tt=Math.max(Or.y,Wn.y,br.y,Sr.y)}var Nr=_n+"Rot",Si=hn[Nr]=hn[Nr]||{};Si.x1=Mt,Si.y1=Wt,Si.x2=ut,Si.y2=Tt,Si.w=ut-Mt,Si.h=Tt-Wt,Y2(m,Mt,Wt,ut,Tt),Y2(O.labelBounds.all,Mt,Wt,ut,Tt)}return m}},Fne=function(m,k){if(!k.cy().headless()){var S=k.pstyle("outline-opacity").value,M=k.pstyle("outline-width").value;if(S>0&&M>0){var O=k.pstyle("outline-offset").value,N=k.pstyle("shape").value,$=M+O,H=(m.w+$*2)/m.w,q=(m.h+$*2)/m.h,Y=0,Z=0;["diamond","pentagon","round-triangle"].includes(N)?(H=(m.w+$*2.4)/m.w,Z=-$/3.6):["concave-hexagon","rhomboid","right-rhomboid"].includes(N)?H=(m.w+$*2.4)/m.w:N==="star"?(H=(m.w+$*2.8)/m.w,q=(m.h+$*2.6)/m.h,Z=-$/3.8):N==="triangle"?(H=(m.w+$*2.8)/m.w,q=(m.h+$*2.4)/m.h,Z=-$/1.4):N==="vee"&&(H=(m.w+$*4.4)/m.w,q=(m.h+$*3.8)/m.h,Z=-$*.5);var ce=m.h*q-m.h,ve=m.w*H-m.w;if(dS(m,[Math.ceil(ce/2),Math.ceil(ve/2)]),Y!=0||Z!==0){var me=pZ(m,Y,Z);dj(m,me)}}}},Rne=function(m,k){var S=m._private.cy,M=S.styleEnabled(),O=S.headless(),N=Wd(),$=m._private,H=m.isNode(),q=m.isEdge(),Y,Z,ce,ve,me,Le,_e=$.rstyle,Ee=H&&M?m.pstyle("bounds-expansion").pfValue:[0],Be=function(fs){return fs.pstyle("display").value!=="none"},Re=!M||Be(m)&&(!q||Be(m.source())&&Be(m.target()));if(Re){var Ve=0,ct=0;M&&k.includeOverlays&&(Ve=m.pstyle("overlay-opacity").value,Ve!==0&&(ct=m.pstyle("overlay-padding").value));var st=0,Ye=0;M&&k.includeUnderlays&&(st=m.pstyle("underlay-opacity").value,st!==0&&(Ye=m.pstyle("underlay-padding").value));var mt=Math.max(ct,Ye),Je=0,Lt=0;if(M&&(Je=m.pstyle("width").pfValue,Lt=Je/2),H&&k.includeNodes){var Mt=m.position();me=Mt.x,Le=Mt.y;var ut=m.outerWidth(),Wt=ut/2,Tt=m.outerHeight(),_n=Tt/2;Y=me-Wt,Z=me+Wt,ce=Le-_n,ve=Le+_n,Y2(N,Y,ce,Z,ve),M&&k.includeOutlines&&Fne(N,m)}else if(q&&k.includeEdges)if(M&&!O){var hn=m.pstyle("curve-style").strValue;if(Y=Math.min(_e.srcX,_e.midX,_e.tgtX),Z=Math.max(_e.srcX,_e.midX,_e.tgtX),ce=Math.min(_e.srcY,_e.midY,_e.tgtY),ve=Math.max(_e.srcY,_e.midY,_e.tgtY),Y-=Lt,Z+=Lt,ce-=Lt,ve+=Lt,Y2(N,Y,ce,Z,ve),hn==="haystack"){var Yt=_e.haystackPts;if(Yt&&Yt.length===2){if(Y=Yt[0].x,ce=Yt[0].y,Z=Yt[1].x,ve=Yt[1].y,Y>Z){var Dn=Y;Y=Z,Z=Dn}if(ce>ve){var ir=ce;ce=ve,ve=ir}Y2(N,Y-Lt,ce-Lt,Z+Lt,ve+Lt)}}else if(hn==="bezier"||hn==="unbundled-bezier"||hn==="segments"||hn==="taxi"){var vr;switch(hn){case"bezier":case"unbundled-bezier":vr=_e.bezierPts;break;case"segments":case"taxi":vr=_e.linePts;break}if(vr!=null)for(var Nn=0;NnZ){var Wn=Y;Y=Z,Z=Wn}if(ce>ve){var br=ce;ce=ve,ve=br}Y-=Lt,Z+=Lt,ce-=Lt,ve+=Lt,Y2(N,Y,ce,Z,ve)}if(M&&k.includeEdges&&q&&(_S(N,m,"mid-source"),_S(N,m,"mid-target"),_S(N,m,"source"),_S(N,m,"target")),M){var Sr=m.pstyle("ghost").value==="yes";if(Sr){var Nr=m.pstyle("ghost-offset-x").pfValue,Si=m.pstyle("ghost-offset-y").pfValue;Y2(N,N.x1+Nr,N.y1+Si,N.x2+Nr,N.y2+Si)}}var ys=$.bodyBounds=$.bodyBounds||{};gj(ys,N),dS(ys,Ee),fS(ys,1),M&&(Y=N.x1,Z=N.x2,ce=N.y1,ve=N.y2,Y2(N,Y-mt,ce-mt,Z+mt,ve+mt));var pa=$.overlayBounds=$.overlayBounds||{};gj(pa,N),dS(pa,Ee),fS(pa,1);var Mi=$.labelBounds=$.labelBounds||{};Mi.all!=null?gZ(Mi.all):Mi.all=Wd(),M&&k.includeLabels&&(k.includeMainLabels&&kI(N,m,null),q&&(k.includeSourceLabels&&kI(N,m,"source"),k.includeTargetLabels&&kI(N,m,"target")))}return N.x1=jp(N.x1),N.y1=jp(N.y1),N.x2=jp(N.x2),N.y2=jp(N.y2),N.w=jp(N.x2-N.x1),N.h=jp(N.y2-N.y1),N.w>0&&N.h>0&&Re&&(dS(N,Ee),fS(N,1)),N},b$=function(m){var k=0,S=function(N){return(N?1:0)<0&&arguments[0]!==void 0?arguments[0]:Xne,m=arguments.length>1?arguments[1]:void 0,k=0;k=0;$--)N($);return this},X2.removeAllListeners=function(){return this.removeListener("*")},X2.emit=X2.trigger=function(x,m,k){var S=this.listeners,M=S.length;return this.emitting++,ne(m)||(m=[m]),MS(this,function(O,N){k!=null&&(S=[{event:N.event,type:N.type,namespace:N.namespace,callback:k}],M=S.length);for(var $=function(Y){var Z=S[Y];if(Z.type===N.type&&(!Z.namespace||Z.namespace===N.namespace||Z.namespace===Yne)&&O.eventMatches(O.context,Z,N)){var ce=[N];m!=null&&uj(ce,m),O.beforeEmit(O.context,Z,N),Z.conf&&Z.conf.one&&(O.listeners=O.listeners.filter(function(Le){return Le!==Z}));var ve=O.callbackContext(O.context,Z,N),me=Z.callback.apply(ve,ce);O.afterEmit(O.context,Z,N),me===!1&&(N.stopPropagation(),N.preventDefault())}},H=0;H1&&!N){var $=this.length-1,H=this[$],q=H._private.data.id;this[$]=void 0,this[m]=H,O.set(q,{ele:H,index:m})}return this.length--,this},unmergeOne:function(m){m=m[0];var k=this._private,S=m._private.data.id,M=k.map,O=M.get(S);if(!O)return this;var N=O.index;return this.unmergeAt(N),this},unmerge:function(m){var k=this._private.cy;if(!m)return this;if(m&&be(m)){var S=m;m=k.mutableElements().filter(S)}for(var M=0;M=0;k--){var S=this[k];m(S)&&this.unmergeAt(k)}return this},map:function(m,k){for(var S=[],M=this,O=0;OS&&(S=H,M=$)}return{value:S,ele:M}},min:function(m,k){for(var S=1/0,M,O=this,N=0;N=0&&O"u"?"undefined":u(Symbol))!=m&&u(Symbol.iterator)!=m;k&&(DS[Symbol.iterator]=function(){var S=this,M={value:void 0,done:!1},O=0,N=this.length;return b({next:function(){return O1&&arguments[1]!==void 0?arguments[1]:!0,S=this[0],M=S.cy();if(M.styleEnabled()&&S){this.cleanStyle();var O=S._private.style[m];return O??(k?M.style().getDefaultProperty(m):null)}},numericStyle:function(m){var k=this[0];if(k.cy().styleEnabled()&&k){var S=k.pstyle(m);return S.pfValue!==void 0?S.pfValue:S.value}},numericStyleUnits:function(m){var k=this[0];if(k.cy().styleEnabled()&&k)return k.pstyle(m).units},renderedStyle:function(m){var k=this.cy();if(!k.styleEnabled())return this;var S=this[0];if(S)return k.style().getRenderedStyle(S,m)},style:function(m,k){var S=this.cy();if(!S.styleEnabled())return this;var M=!1,O=S.style();if(se(m)){var N=m;O.applyBypass(this,N,M),this.emitAndNotify("style")}else if(be(m))if(k===void 0){var $=this[0];return $?O.getStylePropertyValue($,m):void 0}else O.applyBypass(this,m,k,M),this.emitAndNotify("style");else if(m===void 0){var H=this[0];return H?O.getRawStyle(H):void 0}return this},removeStyle:function(m){var k=this.cy();if(!k.styleEnabled())return this;var S=!1,M=k.style(),O=this;if(m===void 0)for(var N=0;N0&&m.push(Y[0]),m.push($[0])}return this.spawn(m,!0).filter(x)},"neighborhood"),closedNeighborhood:function(m){return this.neighborhood().add(this).filter(m)},openNeighborhood:function(m){return this.neighborhood(m)}}),k1.neighbourhood=k1.neighborhood,k1.closedNeighbourhood=k1.closedNeighborhood,k1.openNeighbourhood=k1.openNeighborhood,yt(k1,{source:Rp(function(m){var k=this[0],S;return k&&(S=k._private.source||k.cy().collection()),S&&m?S.filter(m):S},"source"),target:Rp(function(m){var k=this[0],S;return k&&(S=k._private.target||k.cy().collection()),S&&m?S.filter(m):S},"target"),sources:D$({attr:"source"}),targets:D$({attr:"target"})});function D$(x){return function(k){for(var S=[],M=0;M0);return N},component:function(){var m=this[0];return m.cy().mutableElements().components(m)[0]}}),k1.componentsOf=k1.components;var V0=function(m,k){var S=arguments.length>2&&arguments[2]!==void 0?arguments[2]:!1,M=arguments.length>3&&arguments[3]!==void 0?arguments[3]:!1;if(m===void 0){ch("A collection must have a reference to the core");return}var O=new wm,N=!1;if(!k)k=[];else if(k.length>0&&se(k[0])&&!U(k[0])){N=!0;for(var $=[],H=new Q7,q=0,Y=k.length;q0&&arguments[0]!==void 0?arguments[0]:!0,m=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!0,k=this,S=k.cy(),M=S._private,O=[],N=[],$,H=0,q=k.length;H0){for(var ir=$.length===k.length?k:new V0(S,$),vr=0;vr0&&arguments[0]!==void 0?arguments[0]:!0,m=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!0,k=this,S=[],M={},O=k._private.cy;function N(Tt){for(var _n=Tt._private.edges,hn=0;hn<_n.length;hn++)H(_n[hn])}function $(Tt){for(var _n=Tt._private.children,hn=0;hn<_n.length;hn++)H(_n[hn])}function H(Tt){var _n=M[Tt.id()];m&&Tt.removed()||_n||(M[Tt.id()]=!0,Tt.isNode()?(S.push(Tt),N(Tt),$(Tt)):S.unshift(Tt))}for(var q=0,Y=k.length;q0&&(x?Mt.emitAndNotify("remove"):m&&Mt.emit("remove"));for(var ut=0;ut0?ut=Tt:Mt=Tt;while(Math.abs(Wt)>N&&++_n<$);return Tt}function ct(Lt){for(var Mt=0,ut=1,Wt=H-1;ut!==Wt&&ce[ut]<=Lt;++ut)Mt+=q;--ut;var Tt=(Lt-ce[ut])/(ce[ut+1]-ce[ut]),_n=Mt+Tt*q,hn=Ee(_n,x,k);return hn>=O?Be(Lt,_n):hn===0?_n:Ve(Lt,Mt,Mt+q)}var st=!1;function Ye(){st=!0,(x!==m||k!==S)&&Re()}var mt=function(Mt){return st||Ye(),x===m&&k===S?Mt:Mt===0?0:Mt===1?1:_e(ct(Mt),m,S)};mt.getControlPoints=function(){return[{x,y:m},{x:k,y:S}]};var Je="generateBezier("+[x,m,k,S]+")";return mt.toString=function(){return Je},mt}/*! Runge-Kutta spring physics function generator. Adapted from Framer.js, copyright Koen Bok. MIT License: http://en.wikipedia.org/wiki/MIT_License */var ore=function(){function x(S){return-S.tension*S.x-S.friction*S.v}function m(S,M,O){var N={x:S.x+O.dx*M,v:S.v+O.dv*M,tension:S.tension,friction:S.friction};return{dx:N.v,dv:x(N)}}function k(S,M){var O={dx:S.v,dv:x(S)},N=m(S,M*.5,O),$=m(S,M*.5,N),H=m(S,M,$),q=1/6*(O.dx+2*(N.dx+$.dx)+H.dx),Y=1/6*(O.dv+2*(N.dv+$.dv)+H.dv);return S.x=S.x+q*M,S.v=S.v+Y*M,S}return function S(M,O,N){var $={x:-1,v:0,tension:null,friction:null},H=[0],q=0,Y=1/1e4,Z=16/1e3,ce,ve,me;for(M=parseFloat(M)||500,O=parseFloat(O)||20,N=N||null,$.tension=M,$.friction=O,ce=N!==null,ce?(q=S(M,O),ve=q/N*Z):ve=Z;me=k(me||$,ve),H.push(1+me.x),q+=16,Math.abs(me.x)>Y&&Math.abs(me.v)>Y;);return ce?function(Le){return H[Le*(H.length-1)|0]}:q}}(),rl=function(m,k,S,M){var O=are(m,k,S,M);return function(N,$,H){return N+($-N)*O(H)}},BS={linear:function(m,k,S){return m+(k-m)*S},ease:rl(.25,.1,.25,1),"ease-in":rl(.42,0,1,1),"ease-out":rl(0,0,.58,1),"ease-in-out":rl(.42,0,.58,1),"ease-in-sine":rl(.47,0,.745,.715),"ease-out-sine":rl(.39,.575,.565,1),"ease-in-out-sine":rl(.445,.05,.55,.95),"ease-in-quad":rl(.55,.085,.68,.53),"ease-out-quad":rl(.25,.46,.45,.94),"ease-in-out-quad":rl(.455,.03,.515,.955),"ease-in-cubic":rl(.55,.055,.675,.19),"ease-out-cubic":rl(.215,.61,.355,1),"ease-in-out-cubic":rl(.645,.045,.355,1),"ease-in-quart":rl(.895,.03,.685,.22),"ease-out-quart":rl(.165,.84,.44,1),"ease-in-out-quart":rl(.77,0,.175,1),"ease-in-quint":rl(.755,.05,.855,.06),"ease-out-quint":rl(.23,1,.32,1),"ease-in-out-quint":rl(.86,0,.07,1),"ease-in-expo":rl(.95,.05,.795,.035),"ease-out-expo":rl(.19,1,.22,1),"ease-in-out-expo":rl(1,0,0,1),"ease-in-circ":rl(.6,.04,.98,.335),"ease-out-circ":rl(.075,.82,.165,1),"ease-in-out-circ":rl(.785,.135,.15,.86),spring:function(m,k,S){if(S===0)return BS.linear;var M=ore(m,k,S);return function(O,N,$){return O+(N-O)*M($)}},"cubic-bezier":rl};function N$(x,m,k,S,M){if(S===1||m===k)return k;var O=M(m,k,S);return x==null||((x.roundValue||x.color)&&(O=Math.round(O)),x.min!==void 0&&(O=Math.max(O,x.min)),x.max!==void 0&&(O=Math.min(O,x.max))),O}function P$(x,m){return x.pfValue!=null||x.value!=null?x.pfValue!=null&&(m==null||m.type.units!=="%")?x.pfValue:x.value:x}function g8(x,m,k,S,M){var O=M!=null?M.type:null;k<0?k=0:k>1&&(k=1);var N=P$(x,M),$=P$(m,M);if(X(N)&&X($))return N$(O,N,$,k,S);if(ne(N)&&ne($)){for(var H=[],q=0;q<$.length;q++){var Y=N[q],Z=$[q];if(Y!=null&&Z!=null){var ce=N$(O,Y,Z,k,S);H.push(ce)}else H.push(Z)}return H}}function cre(x,m,k,S){var M=!S,O=x._private,N=m._private,$=N.easing,H=N.startTime,q=S?x:x.cy(),Y=q.style();if(!N.easingImpl)if($==null)N.easingImpl=BS.linear;else{var Z;if(be($)){var ce=Y.parse("transition-timing-function",$);Z=ce.value}else Z=$;var ve,me;be(Z)?(ve=Z,me=[]):(ve=Z[1],me=Z.slice(2).map(function(ir){return+ir})),me.length>0?(ve==="spring"&&me.push(N.duration),N.easingImpl=BS[ve].apply(null,me)):N.easingImpl=BS[ve]}var Le=N.easingImpl,_e;if(N.duration===0?_e=1:_e=(k-H)/N.duration,N.applying&&(_e=N.progress),_e<0?_e=0:_e>1&&(_e=1),N.delay==null){var Ee=N.startPosition,Be=N.position;if(Be&&M&&!x.locked()){var Re={};ak(Ee.x,Be.x)&&(Re.x=g8(Ee.x,Be.x,_e,Le)),ak(Ee.y,Be.y)&&(Re.y=g8(Ee.y,Be.y,_e,Le)),x.position(Re)}var Ve=N.startPan,ct=N.pan,st=O.pan,Ye=ct!=null&&S;Ye&&(ak(Ve.x,ct.x)&&(st.x=g8(Ve.x,ct.x,_e,Le)),ak(Ve.y,ct.y)&&(st.y=g8(Ve.y,ct.y,_e,Le)),x.emit("pan"));var mt=N.startZoom,Je=N.zoom,Lt=Je!=null&&S;Lt&&(ak(mt,Je)&&(O.zoom=U9(O.minZoom,g8(mt,Je,_e,Le),O.maxZoom)),x.emit("zoom")),(Ye||Lt)&&x.emit("viewport");var Mt=N.style;if(Mt&&Mt.length>0&&M){for(var ut=0;ut=0;Ye--){var mt=st[Ye];mt()}st.splice(0,st.length)},Be=ve.length-1;Be>=0;Be--){var Re=ve[Be],Ve=Re._private;if(Ve.stopped){ve.splice(Be,1),Ve.hooked=!1,Ve.playing=!1,Ve.started=!1,Ee(Ve.frames);continue}!Ve.playing&&!Ve.applying||(Ve.playing&&Ve.applying&&(Ve.applying=!1),Ve.started||ure(Y,Re,x),cre(Y,Re,x,Z),Ve.applying&&(Ve.applying=!1),Ee(Ve.frames),Ve.step!=null&&Ve.step(x),Re.completed()&&(ve.splice(Be,1),Ve.hooked=!1,Ve.playing=!1,Ve.started=!1,Ee(Ve.completes)),Le=!0)}return!Z&&ve.length===0&&me.length===0&&S.push(Y),Le}for(var O=!1,N=0;N0?m.notify("draw",k):m.notify("draw")),k.unmerge(S),m.emit("step")}var lre={animate:fu.animate(),animation:fu.animation(),animated:fu.animated(),clearQueue:fu.clearQueue(),delay:fu.delay(),delayAnimation:fu.delayAnimation(),stop:fu.stop(),addToAnimationPool:function(m){var k=this;k.styleEnabled()&&k._private.aniEles.merge(m)},stopAnimationLoop:function(){this._private.animationsRunning=!1},startAnimationLoop:function(){var m=this;if(m._private.animationsRunning=!0,!m.styleEnabled())return;function k(){m._private.animationsRunning&&z0(function(O){B$(O,m),k()})}var S=m.renderer();S&&S.beforeRender?S.beforeRender(function(O,N){B$(N,m)},S.beforeRenderPriorities.animations):k()}},hre={qualifierCompare:function(m,k){return m==null||k==null?m==null&&k==null:m.sameText(k)},eventMatches:function(m,k,S){var M=k.qualifier;return M!=null?m!==S.target&&U(S.target)&&M.matches(S.target):!0},addEventFields:function(m,k){k.cy=m,k.target=m},callbackContext:function(m,k,S){return k.qualifier!=null?S.target:m}},FS=function(m){return be(m)?new ey(m):m},F$={createEmitter:function(){var m=this._private;return m.emitter||(m.emitter=new LS(hre,this)),this},emitter:function(){return this._private.emitter},on:function(m,k,S){return this.emitter().on(m,FS(k),S),this},removeListener:function(m,k,S){return this.emitter().removeListener(m,FS(k),S),this},removeAllListeners:function(){return this.emitter().removeAllListeners(),this},one:function(m,k,S){return this.emitter().one(m,FS(k),S),this},once:function(m,k,S){return this.emitter().one(m,FS(k),S),this},emit:function(m,k){return this.emitter().emit(m,k),this},emitAndNotify:function(m,k){return this.emit(m),this.notify(m,k),this}};fu.eventAliasesOn(F$);var MI={png:function(m){var k=this._private.renderer;return m=m||{},k.png(m)},jpg:function(m){var k=this._private.renderer;return m=m||{},m.bg=m.bg||"#fff",k.jpg(m)}};MI.jpeg=MI.jpg;var RS={layout:function(m){var k=this;if(m==null){ch("Layout options must be specified to make a layout");return}if(m.name==null){ch("A `name` must be specified to make a layout");return}var S=m.name,M=k.extension("layout",S);if(M==null){ch("No such layout `"+S+"` found. Did you forget to import it and `cytoscape.use()` it?");return}var O;be(m.eles)?O=k.$(m.eles):O=m.eles!=null?m.eles:k.$();var N=new M(yt({},m,{cy:k,eles:O}));return N}};RS.createLayout=RS.makeLayout=RS.layout;var fre={notify:function(m,k){var S=this._private;if(this.batching()){S.batchNotifications=S.batchNotifications||{};var M=S.batchNotifications[m]=S.batchNotifications[m]||this.collection();k!=null&&M.merge(k);return}if(S.notificationsEnabled){var O=this.renderer();this.destroyed()||!O||O.notify(m,k)}},notifications:function(m){var k=this._private;return m===void 0?k.notificationsEnabled:(k.notificationsEnabled=!!m,this)},noNotifications:function(m){this.notifications(!1),m(),this.notifications(!0)},batching:function(){return this._private.batchCount>0},startBatch:function(){var m=this._private;return m.batchCount==null&&(m.batchCount=0),m.batchCount===0&&(m.batchStyleEles=this.collection(),m.batchNotifications={}),m.batchCount++,this},endBatch:function(){var m=this._private;if(m.batchCount===0)return this;if(m.batchCount--,m.batchCount===0){m.batchStyleEles.updateStyle();var k=this.renderer();Object.keys(m.batchNotifications).forEach(function(S){var M=m.batchNotifications[S];M.empty()?k.notify(S):k.notify(S,M)})}return this},batch:function(m){return this.startBatch(),m(),this.endBatch(),this},batchData:function(m){var k=this;return this.batch(function(){for(var S=Object.keys(m),M=0;M0;)k.removeChild(k.childNodes[0]);m._private.renderer=null,m.mutableElements().forEach(function(S){var M=S._private;M.rscratch={},M.rstyle={},M.animation.current=[],M.animation.queue=[]})},onRender:function(m){return this.on("render",m)},offRender:function(m){return this.off("render",m)}};DI.invalidateDimensions=DI.resize;var jS={collection:function(m,k){return be(m)?this.$(m):xe(m)?m.collection():ne(m)?(k||(k={}),new V0(this,m,k.unique,k.removed)):new V0(this)},nodes:function(m){var k=this.$(function(S){return S.isNode()});return m?k.filter(m):k},edges:function(m){var k=this.$(function(S){return S.isEdge()});return m?k.filter(m):k},$:function(m){var k=this._private.elements;return m?k.filter(m):k.spawnSelf()},mutableElements:function(){return this._private.elements}};jS.elements=jS.filter=jS.$;var E1={},ok="t",gre="f";E1.apply=function(x){for(var m=this,k=m._private,S=k.cy,M=S.collection(),O=0;O0;if(ce||Z&&ve){var me=void 0;ce&&ve||ce?me=q.properties:ve&&(me=q.mappedProperties);for(var Le=0;Le1&&(Ve=1),$.color){var st=S.valueMin[0],Ye=S.valueMax[0],mt=S.valueMin[1],Je=S.valueMax[1],Lt=S.valueMin[2],Mt=S.valueMax[2],ut=S.valueMin[3]==null?1:S.valueMin[3],Wt=S.valueMax[3]==null?1:S.valueMax[3],Tt=[Math.round(st+(Ye-st)*Ve),Math.round(mt+(Je-mt)*Ve),Math.round(Lt+(Mt-Lt)*Ve),Math.round(ut+(Wt-ut)*Ve)];O={bypass:S.bypass,name:S.name,value:Tt,strValue:"rgb("+Tt[0]+", "+Tt[1]+", "+Tt[2]+")"}}else if($.number){var _n=S.valueMin+(S.valueMax-S.valueMin)*Ve;O=this.parse(S.name,_n,S.bypass,ce)}else return!1;if(!O)return Le(),!1;O.mapping=S,S=O;break}case N.data:{for(var hn=S.field.split("."),Yt=Z.data,Dn=0;Dn0&&O>0){for(var $={},H=!1,q=0;q0?x.delayAnimation(N).play().promise().then(Re):Re()}).then(function(){return x.animation({style:$,duration:O,easing:x.pstyle("transition-timing-function").value,queue:!1}).play().promise()}).then(function(){k.removeBypasses(x,M),x.emitAndNotify("style"),S.transitioning=!1})}else S.transitioning&&(this.removeBypasses(x,M),x.emitAndNotify("style"),S.transitioning=!1)},E1.checkTrigger=function(x,m,k,S,M,O){var N=this.properties[m],$=M(N);$!=null&&$(k,S)&&O(N)},E1.checkZOrderTrigger=function(x,m,k,S){var M=this;this.checkTrigger(x,m,k,S,function(O){return O.triggersZOrder},function(){M._private.cy.notify("zorder",x)})},E1.checkBoundsTrigger=function(x,m,k,S){this.checkTrigger(x,m,k,S,function(M){return M.triggersBounds},function(M){x.dirtyCompoundBoundsCache(),x.dirtyBoundingBoxCache(),M.triggersBoundsOfParallelBeziers&&m==="curve-style"&&(k==="bezier"||S==="bezier")&&x.parallelEdges().forEach(function(O){O.isBundledBezier()&&O.dirtyBoundingBoxCache()}),M.triggersBoundsOfConnectedEdges&&m==="display"&&(k==="none"||S==="none")&&x.connectedEdges().forEach(function(O){O.dirtyBoundingBoxCache()})})},E1.checkTriggers=function(x,m,k,S){x.dirtyStyleCache(),this.checkZOrderTrigger(x,m,k,S),this.checkBoundsTrigger(x,m,k,S)};var ck={};ck.applyBypass=function(x,m,k,S){var M=this,O=[],N=!0;if(m==="*"||m==="**"){if(k!==void 0)for(var $=0;$M.length?S=S.substr(M.length):S=""}function H(){O.length>N.length?O=O.substr(N.length):O=""}for(;;){var q=S.match(/^\s*$/);if(q)break;var Y=S.match(/^\s*((?:.|\s)+?)\s*\{((?:.|\s)+?)\}/);if(!Y){hu("Halting stylesheet parsing: String stylesheet contains more to parse but no selector and block found in: "+S);break}M=Y[0];var Z=Y[1];if(Z!=="core"){var ce=new ey(Z);if(ce.invalid){hu("Skipping parsing of block: Invalid selector found in string stylesheet: "+Z),$();continue}}var ve=Y[2],me=!1;O=ve;for(var Le=[];;){var _e=O.match(/^\s*$/);if(_e)break;var Ee=O.match(/^\s*(.+?)\s*:\s*(.+?)(?:\s*;|\s*$)/);if(!Ee){hu("Skipping parsing of block: Invalid formatting of style property and value definitions found in:"+ve),me=!0;break}N=Ee[0];var Be=Ee[1],Re=Ee[2],Ve=m.properties[Be];if(!Ve){hu("Skipping property: Invalid property name in: "+N),H();continue}var ct=k.parse(Be,Re);if(!ct){hu("Skipping property: Invalid property definition in: "+N),H();continue}Le.push({name:Be,val:Re}),H()}if(me){$();break}k.selector(Z);for(var st=0;st=7&&m[0]==="d"&&(Y=new RegExp($.data.regex).exec(m))){if(k)return!1;var ce=$.data;return{name:x,value:Y,strValue:""+m,mapped:ce,field:Y[1],bypass:k}}else if(m.length>=10&&m[0]==="m"&&(Z=new RegExp($.mapData.regex).exec(m))){if(k||q.multiple)return!1;var ve=$.mapData;if(!(q.color||q.number))return!1;var me=this.parse(x,Z[4]);if(!me||me.mapped)return!1;var Le=this.parse(x,Z[5]);if(!Le||Le.mapped)return!1;if(me.pfValue===Le.pfValue||me.strValue===Le.strValue)return hu("`"+x+": "+m+"` is not a valid mapper because the output range is zero; converting to `"+x+": "+me.strValue+"`"),this.parse(x,me.strValue);if(q.color){var _e=me.value,Ee=Le.value,Be=_e[0]===Ee[0]&&_e[1]===Ee[1]&&_e[2]===Ee[2]&&(_e[3]===Ee[3]||(_e[3]==null||_e[3]===1)&&(Ee[3]==null||Ee[3]===1));if(Be)return!1}return{name:x,value:Z,strValue:""+m,mapped:ve,field:Z[1],fieldMin:parseFloat(Z[2]),fieldMax:parseFloat(Z[3]),valueMin:me.value,valueMax:Le.value,bypass:k}}}if(q.multiple&&S!=="multiple"){var Re;if(H?Re=m.split(/\s+/):ne(m)?Re=m:Re=[m],q.evenMultiple&&Re.length%2!==0)return null;for(var Ve=[],ct=[],st=[],Ye="",mt=!1,Je=0;Je0?" ":"")+Lt.strValue}return q.validate&&!q.validate(Ve,ct)?null:q.singleEnum&&mt?Ve.length===1&&be(Ve[0])?{name:x,value:Ve[0],strValue:Ve[0],bypass:k}:null:{name:x,value:Ve,pfValue:st,strValue:Ye,bypass:k,units:ct}}var Mt=function(){for(var Sr=0;Srq.max||q.strictMax&&m===q.max))return null;var hn={name:x,value:m,strValue:""+m+(ut||""),units:ut,bypass:k};return q.unitless||ut!=="px"&&ut!=="em"?hn.pfValue=m:hn.pfValue=ut==="px"||!ut?m:this.getEmSizeInPixels()*m,(ut==="ms"||ut==="s")&&(hn.pfValue=ut==="ms"?m:1e3*m),(ut==="deg"||ut==="rad")&&(hn.pfValue=ut==="rad"?m:lZ(m)),ut==="%"&&(hn.pfValue=m/100),hn}else if(q.propList){var Yt=[],Dn=""+m;if(Dn!=="none"){for(var ir=Dn.split(/\s*,\s*|\s+/),vr=0;vr0&&$>0&&!isNaN(S.w)&&!isNaN(S.h)&&S.w>0&&S.h>0){H=Math.min((N-2*k)/S.w,($-2*k)/S.h),H=H>this._private.maxZoom?this._private.maxZoom:H,H=H=S.minZoom&&(S.maxZoom=k),this},minZoom:function(m){return m===void 0?this._private.minZoom:this.zoomRange({min:m})},maxZoom:function(m){return m===void 0?this._private.maxZoom:this.zoomRange({max:m})},getZoomedViewport:function(m){var k=this._private,S=k.pan,M=k.zoom,O,N,$=!1;if(k.zoomingEnabled||($=!0),X(m)?N=m:se(m)&&(N=m.level,m.position!=null?O=lS(m.position,M,S):m.renderedPosition!=null&&(O=m.renderedPosition),O!=null&&!k.panningEnabled&&($=!0)),N=N>k.maxZoom?k.maxZoom:N,N=Nk.maxZoom||!k.zoomingEnabled?N=!0:(k.zoom=H,O.push("zoom"))}if(M&&(!N||!m.cancelOnFailedZoom)&&k.panningEnabled){var q=m.pan;X(q.x)&&(k.pan.x=q.x,$=!1),X(q.y)&&(k.pan.y=q.y,$=!1),$||O.push("pan")}return O.length>0&&(O.push("viewport"),this.emit(O.join(" ")),this.notify("viewport")),this},center:function(m){var k=this.getCenterPan(m);return k&&(this._private.pan=k,this.emit("pan viewport"),this.notify("viewport")),this},getCenterPan:function(m,k){if(this._private.panningEnabled){if(be(m)){var S=m;m=this.mutableElements().filter(S)}else xe(m)||(m=this.mutableElements());if(m.length!==0){var M=m.boundingBox(),O=this.width(),N=this.height();k=k===void 0?this._private.zoom:k;var $={x:(O-k*(M.x1+M.x2))/2,y:(N-k*(M.y1+M.y2))/2};return $}}},reset:function(){return!this._private.panningEnabled||!this._private.zoomingEnabled?this:(this.viewport({pan:{x:0,y:0},zoom:1}),this)},invalidateSize:function(){this._private.sizeCache=null},size:function(){var m=this._private,k=m.container,S=this;return m.sizeCache=m.sizeCache||(k?function(){var M=S.window().getComputedStyle(k),O=function($){return parseFloat(M.getPropertyValue($))};return{width:k.clientWidth-O("padding-left")-O("padding-right"),height:k.clientHeight-O("padding-top")-O("padding-bottom")}}():{width:1,height:1})},width:function(){return this.size().width},height:function(){return this.size().height},extent:function(){var m=this._private.pan,k=this._private.zoom,S=this.renderedExtent(),M={x1:(S.x1-m.x)/k,x2:(S.x2-m.x)/k,y1:(S.y1-m.y)/k,y2:(S.y2-m.y)/k};return M.w=M.x2-M.x1,M.h=M.y2-M.y1,M},renderedExtent:function(){var m=this.width(),k=this.height();return{x1:0,y1:0,x2:m,y2:k,w:m,h:k}},multiClickDebounceTime:function(m){if(m)this._private.multiClickDebounceTime=m;else return this._private.multiClickDebounceTime;return this}};v5.centre=v5.center,v5.autolockNodes=v5.autolock,v5.autoungrabifyNodes=v5.autoungrabify;var uk={data:fu.data({field:"data",bindingEvent:"data",allowBinding:!0,allowSetting:!0,settingEvent:"data",settingTriggersEvent:!0,triggerFnName:"trigger",allowGetting:!0,updateStyle:!0}),removeData:fu.removeData({field:"data",event:"data",triggerFnName:"trigger",triggerEvent:!0,updateStyle:!0}),scratch:fu.data({field:"scratch",bindingEvent:"scratch",allowBinding:!0,allowSetting:!0,settingEvent:"scratch",settingTriggersEvent:!0,triggerFnName:"trigger",allowGetting:!0,updateStyle:!0}),removeScratch:fu.removeData({field:"scratch",event:"scratch",triggerFnName:"trigger",triggerEvent:!0,updateStyle:!0})};uk.attr=uk.data,uk.removeAttr=uk.removeData;var lk=function(m){var k=this;m=yt({},m);var S=m.container;S&&!W(S)&&W(S[0])&&(S=S[0]);var M=S?S._cyreg:null;M=M||{},M&&M.cy&&(M.cy.destroy(),M={});var O=M.readies=M.readies||[];S&&(S._cyreg=M),M.cy=k;var N=F!==void 0&&S!==void 0&&!m.headless,$=m;$.layout=yt({name:N?"grid":"null"},$.layout),$.renderer=yt({name:N?"canvas":"null"},$.renderer);var H=function(me,Le,_e){return Le!==void 0?Le:_e!==void 0?_e:me},q=this._private={container:S,ready:!1,options:$,elements:new V0(this),listeners:[],aniEles:new V0(this),data:$.data||{},scratch:{},layout:null,renderer:null,destroyed:!1,notificationsEnabled:!0,minZoom:1e-50,maxZoom:1e50,zoomingEnabled:H(!0,$.zoomingEnabled),userZoomingEnabled:H(!0,$.userZoomingEnabled),panningEnabled:H(!0,$.panningEnabled),userPanningEnabled:H(!0,$.userPanningEnabled),boxSelectionEnabled:H(!0,$.boxSelectionEnabled),autolock:H(!1,$.autolock,$.autolockNodes),autoungrabify:H(!1,$.autoungrabify,$.autoungrabifyNodes),autounselectify:H(!1,$.autounselectify),styleEnabled:$.styleEnabled===void 0?N:$.styleEnabled,zoom:X($.zoom)?$.zoom:1,pan:{x:se($.pan)&&X($.pan.x)?$.pan.x:0,y:se($.pan)&&X($.pan.y)?$.pan.y:0},animation:{current:[],queue:[]},hasCompoundNodes:!1,multiClickDebounceTime:H(250,$.multiClickDebounceTime)};this.createEmitter(),this.selectionType($.selectionType),this.zoomRange({min:$.minZoom,max:$.maxZoom});var Y=function(me,Le){var _e=me.some(Ke);if(_e)return i8.all(me).then(Le);Le(me)};q.styleEnabled&&k.setStyle([]);var Z=yt({},$,$.renderer);k.initRenderer(Z);var ce=function(me,Le,_e){k.notifications(!1);var Ee=k.mutableElements();Ee.length>0&&Ee.remove(),me!=null&&(se(me)||ne(me))&&k.add(me),k.one("layoutready",function(Re){k.notifications(!0),k.emit(Re),k.one("load",Le),k.emitAndNotify("load")}).one("layoutstop",function(){k.one("done",_e),k.emit("done")});var Be=yt({},k._private.options.layout);Be.eles=k.elements(),k.layout(Be).run()};Y([$.style,$.elements],function(ve){var me=ve[0],Le=ve[1];q.styleEnabled&&k.style().append(me),ce(Le,function(){k.startAnimationLoop(),q.ready=!0,ae($.ready)&&k.on("ready",$.ready);for(var _e=0;_e0,H=Wd(m.boundingBox?m.boundingBox:{x1:0,y1:0,w:k.width(),h:k.height()}),q;if(xe(m.roots))q=m.roots;else if(ne(m.roots)){for(var Y=[],Z=0;Z0;){var _n=Tt(),hn=Lt(_n,ut);if(hn)_n.outgoers().filter(function(Mi){return Mi.isNode()&&S.has(Mi)}).forEach(Wt);else if(hn===null){hu("Detected double maximal shift for node `"+_n.id()+"`. Bailing maximal adjustment due to cycle. Use `options.maximal: true` only on DAGs.");break}}}Je();var Yt=0;if(m.avoidOverlap)for(var Dn=0;Dn0&&Ee[0].length<=3?Da/2:0),G=2*Math.PI/Ee[Fs].length*xs;return Fs===0&&Ee[0].length===1&&(tr=1),{x:Si.x+tr*Math.cos(G),y:Si.y+tr*Math.sin(G)}}else{var Bo={x:Si.x+(xs+1-(Rs+1)/2)*yo,y:(Fs+1)*$a};return Bo}};return S.nodes().layoutPositions(this,m,pa),this};var wre={fit:!0,padding:30,boundingBox:void 0,avoidOverlap:!0,nodeDimensionsIncludeLabels:!1,spacingFactor:void 0,radius:void 0,startAngle:3/2*Math.PI,sweep:void 0,clockwise:!0,sort:void 0,animate:!1,animationDuration:500,animationEasing:void 0,animateFilter:function(m,k){return!0},ready:void 0,stop:void 0,transform:function(m,k){return k}};function $$(x){this.options=yt({},wre,x)}$$.prototype.run=function(){var x=this.options,m=x,k=x.cy,S=m.eles,M=m.counterclockwise!==void 0?!m.counterclockwise:m.clockwise,O=S.nodes().not(":parent");m.sort&&(O=O.sort(m.sort));for(var N=Wd(m.boundingBox?m.boundingBox:{x1:0,y1:0,w:k.width(),h:k.height()}),$={x:N.x1+N.w/2,y:N.y1+N.h/2},H=m.sweep===void 0?2*Math.PI-2*Math.PI/O.length:m.sweep,q=H/Math.max(1,O.length-1),Y,Z=0,ce=0;ce1&&m.avoidOverlap){Z*=1.75;var Ee=Math.cos(q)-Math.cos(0),Be=Math.sin(q)-Math.sin(0),Re=Math.sqrt(Z*Z/(Ee*Ee+Be*Be));Y=Math.max(Re,Y)}var Ve=function(st,Ye){var mt=m.startAngle+Ye*q*(M?1:-1),Je=Y*Math.cos(mt),Lt=Y*Math.sin(mt),Mt={x:$.x+Je,y:$.y+Lt};return Mt};return S.nodes().layoutPositions(this,m,Ve),this};var yre={fit:!0,padding:30,startAngle:3/2*Math.PI,sweep:void 0,clockwise:!0,equidistant:!1,minNodeSpacing:10,boundingBox:void 0,avoidOverlap:!0,nodeDimensionsIncludeLabels:!1,height:void 0,width:void 0,spacingFactor:void 0,concentric:function(m){return m.degree()},levelWidth:function(m){return m.maxDegree()/4},animate:!1,animationDuration:500,animationEasing:void 0,animateFilter:function(m,k){return!0},ready:void 0,stop:void 0,transform:function(m,k){return k}};function z$(x){this.options=yt({},yre,x)}z$.prototype.run=function(){for(var x=this.options,m=x,k=m.counterclockwise!==void 0?!m.counterclockwise:m.clockwise,S=x.cy,M=m.eles,O=M.nodes().not(":parent"),N=Wd(m.boundingBox?m.boundingBox:{x1:0,y1:0,w:S.width(),h:S.height()}),$={x:N.x1+N.w/2,y:N.y1+N.h/2},H=[],q=0,Y=0;Y0){var ct=Math.abs(Be[0].value-Ve.value);ct>=_e&&(Be=[],Ee.push(Be))}Be.push(Ve)}var st=q+m.minNodeSpacing;if(!m.avoidOverlap){var Ye=Ee.length>0&&Ee[0].length>1,mt=Math.min(N.w,N.h)/2-st,Je=mt/(Ee.length+Ye?1:0);st=Math.min(st,Je)}for(var Lt=0,Mt=0;Mt1&&m.avoidOverlap){var _n=Math.cos(Tt)-Math.cos(0),hn=Math.sin(Tt)-Math.sin(0),Yt=Math.sqrt(st*st/(_n*_n+hn*hn));Lt=Math.max(Yt,Lt)}ut.r=Lt,Lt+=st}if(m.equidistant){for(var Dn=0,ir=0,vr=0;vr=x.numIter||(Are(S,x),S.temperature=S.temperature*x.coolingFactor,S.temperature=x.animationThreshold&&O(),z0(Z)}};Y()}else{for(;q;)q=N(H),H++;V$(S,x),$()}return this},HS.prototype.stop=function(){return this.stopped=!0,this.thread&&this.thread.stop(),this.emit("layoutstop"),this},HS.prototype.destroy=function(){return this.thread&&this.thread.stop(),this};var kre=function(m,k,S){for(var M=S.eles.edges(),O=S.eles.nodes(),N=Wd(S.boundingBox?S.boundingBox:{x1:0,y1:0,w:m.width(),h:m.height()}),$={isCompound:m.hasCompoundNodes(),layoutNodes:[],idToIndex:{},nodeSize:O.size(),graphSet:[],indexToGraph:[],layoutEdges:[],edgeSize:M.size(),temperature:S.initialTemp,clientWidth:N.w,clientHeight:N.h,boundingBox:N},H=S.eles.components(),q={},Y=0;Y0){$.graphSet.push(mt);for(var Y=0;YM.count?0:M.graph},Tre=function x(m,k,S,M){var O=M.graphSet[S];if(-10)var Z=M.nodeOverlap*Y,ce=Math.sqrt($*$+H*H),ve=Z*$/ce,me=Z*H/ce;else var Le=VS(m,$,H),_e=VS(k,-1*$,-1*H),Ee=_e.x-Le.x,Be=_e.y-Le.y,Re=Ee*Ee+Be*Be,ce=Math.sqrt(Re),Z=(m.nodeRepulsion+k.nodeRepulsion)/Re,ve=Z*Ee/ce,me=Z*Be/ce;m.isLocked||(m.offsetX-=ve,m.offsetY-=me),k.isLocked||(k.offsetX+=ve,k.offsetY+=me)}},Dre=function(m,k,S,M){if(S>0)var O=m.maxX-k.minX;else var O=k.maxX-m.minX;if(M>0)var N=m.maxY-k.minY;else var N=k.maxY-m.minY;return O>=0&&N>=0?Math.sqrt(O*O+N*N):0},VS=function(m,k,S){var M=m.positionX,O=m.positionY,N=m.height||1,$=m.width||1,H=S/k,q=N/$,Y={};return k===0&&0S?(Y.x=M,Y.y=O+N/2,Y):0k&&-1*q<=H&&H<=q?(Y.x=M-$/2,Y.y=O-$*S/2/k,Y):0=q)?(Y.x=M+N*k/2/S,Y.y=O+N/2,Y):(0>S&&(H<=-1*q||H>=q)&&(Y.x=M-N*k/2/S,Y.y=O-N/2),Y)},Ire=function(m,k){for(var S=0;SS){var _e=k.gravity*ve/Le,Ee=k.gravity*me/Le;ce.offsetX+=_e,ce.offsetY+=Ee}}}}},Nre=function(m,k){var S=[],M=0,O=-1;for(S.push.apply(S,m.graphSet[0]),O+=m.graphSet[0].length;M<=O;){var N=S[M++],$=m.idToIndex[N],H=m.layoutNodes[$],q=H.children;if(0S)var O={x:S*m/M,y:S*k/M};else var O={x:m,y:k};return O},Fre=function x(m,k){var S=m.parentId;if(S!=null){var M=k.layoutNodes[k.idToIndex[S]],O=!1;if((M.maxX==null||m.maxX+M.padRight>M.maxX)&&(M.maxX=m.maxX+M.padRight,O=!0),(M.minX==null||m.minX-M.padLeftM.maxY)&&(M.maxY=m.maxY+M.padBottom,O=!0),(M.minY==null||m.minY-M.padTopEe&&(me+=_e+k.componentSpacing,ve=0,Le=0,_e=0)}}},Rre={fit:!0,padding:30,boundingBox:void 0,avoidOverlap:!0,avoidOverlapPadding:10,nodeDimensionsIncludeLabels:!1,spacingFactor:void 0,condense:!1,rows:void 0,cols:void 0,position:function(m){},sort:void 0,animate:!1,animationDuration:500,animationEasing:void 0,animateFilter:function(m,k){return!0},ready:void 0,stop:void 0,transform:function(m,k){return k}};function U$(x){this.options=yt({},Rre,x)}U$.prototype.run=function(){var x=this.options,m=x,k=x.cy,S=m.eles,M=S.nodes().not(":parent");m.sort&&(M=M.sort(m.sort));var O=Wd(m.boundingBox?m.boundingBox:{x1:0,y1:0,w:k.width(),h:k.height()});if(O.h===0||O.w===0)S.nodes().layoutPositions(this,m,function(Er){return{x:O.x1,y:O.y1}});else{var N=M.size(),$=Math.sqrt(N*O.h/O.w),H=Math.round($),q=Math.round(O.w/O.h*$),Y=function(Mr){if(Mr==null)return Math.min(H,q);var Cr=Math.min(H,q);Cr==H?H=Mr:q=Mr},Z=function(Mr){if(Mr==null)return Math.max(H,q);var Cr=Math.max(H,q);Cr==H?H=Mr:q=Mr},ce=m.rows,ve=m.cols!=null?m.cols:m.columns;if(ce!=null&&ve!=null)H=ce,q=ve;else if(ce!=null&&ve==null)H=ce,q=Math.ceil(N/H);else if(ce==null&&ve!=null)q=ve,H=Math.ceil(N/q);else if(q*H>N){var me=Y(),Le=Z();(me-1)*Le>=N?Y(me-1):(Le-1)*me>=N&&Z(Le-1)}else for(;q*H=N?Z(Ee+1):Y(_e+1)}var Be=O.w/q,Re=O.h/H;if(m.condense&&(Be=0,Re=0),m.avoidOverlap)for(var Ve=0;Ve=q&&(_n=0,Tt++)},Yt={},Dn=0;Dn(_n=EZ(x,m,hn[Yt],hn[Yt+1],hn[Yt+2],hn[Yt+3])))return _e(Ye,_n),!0}else if(Je.edgeType==="bezier"||Je.edgeType==="multibezier"||Je.edgeType==="self"||Je.edgeType==="compound"){for(var hn=Je.allpts,Yt=0;Yt+5(_n=kZ(x,m,hn[Yt],hn[Yt+1],hn[Yt+2],hn[Yt+3],hn[Yt+4],hn[Yt+5])))return _e(Ye,_n),!0}for(var Dn=Dn||mt.source,ir=ir||mt.target,vr=M.getArrowWidth(Lt,Mt),Nn=[{name:"source",x:Je.arrowStartX,y:Je.arrowStartY,angle:Je.srcArrowAngle},{name:"target",x:Je.arrowEndX,y:Je.arrowEndY,angle:Je.tgtArrowAngle},{name:"mid-source",x:Je.midX,y:Je.midY,angle:Je.midsrcArrowAngle},{name:"mid-target",x:Je.midX,y:Je.midY,angle:Je.midtgtArrowAngle}],Yt=0;Yt0&&(Ee(Dn),Ee(ir))}function Re(Ye,mt,Je){return K2(Ye,mt,Je)}function Ve(Ye,mt){var Je=Ye._private,Lt=ce,Mt;mt?Mt=mt+"-":Mt="",Ye.boundingBox();var ut=Je.labelBounds[mt||"main"],Wt=Ye.pstyle(Mt+"label").value,Tt=Ye.pstyle("text-events").strValue==="yes";if(!(!Tt||!Wt)){var _n=Re(Je.rscratch,"labelX",mt),hn=Re(Je.rscratch,"labelY",mt),Yt=Re(Je.rscratch,"labelAngle",mt),Dn=Ye.pstyle(Mt+"text-margin-x").pfValue,ir=Ye.pstyle(Mt+"text-margin-y").pfValue,vr=ut.x1-Lt-Dn,Nn=ut.x2+Lt-Dn,pr=ut.y1-Lt-ir,Er=ut.y2+Lt-ir;if(Yt){var Mr=Math.cos(Yt),Cr=Math.sin(Yt),Or=function(pa,Mi){return pa=pa-_n,Mi=Mi-hn,{x:pa*Mr-Mi*Cr+_n,y:pa*Cr+Mi*Mr+hn}},Wn=Or(vr,pr),br=Or(vr,Er),Sr=Or(Nn,pr),Nr=Or(Nn,Er),Si=[Wn.x+Dn,Wn.y+ir,Sr.x+Dn,Sr.y+ir,Nr.x+Dn,Nr.y+ir,br.x+Dn,br.y+ir];if(Yd(x,m,Si))return _e(Ye),!0}else if(e8(ut,x,m))return _e(Ye),!0}}for(var ct=N.length-1;ct>=0;ct--){var st=N[ct];st.isNode()?Ee(st)||Ve(st):Be(st)||Ve(st)||Ve(st,"source")||Ve(st,"target")}return $},w5.getAllInBox=function(x,m,k,S){var M=this.getCachedZSortedEles().interactive,O=[],N=Math.min(x,k),$=Math.max(x,k),H=Math.min(m,S),q=Math.max(m,S);x=N,k=$,m=H,S=q;for(var Y=Wd({x1:x,y1:m,x2:k,y2:S}),Z=0;Z0?Math.max(wr-Es,0):Math.min(wr+Es,0)},Wt=ut(Lt,mt),Tt=ut(Mt,Je),_n=!1;Be===q?Ee=Math.abs(Wt)>Math.abs(Tt)?M:S:Be===H||Be===$?(Ee=S,_n=!0):(Be===O||Be===N)&&(Ee=M,_n=!0);var hn=Ee===S,Yt=hn?Tt:Wt,Dn=hn?Mt:Lt,ir=fj(Dn),vr=!1;!(_n&&(Ve||st))&&(Be===$&&Dn<0||Be===H&&Dn>0||Be===O&&Dn>0||Be===N&&Dn<0)&&(ir*=-1,Yt=ir*Math.abs(Yt),vr=!0);var Nn;if(Ve){var pr=ct<0?1+ct:ct;Nn=pr*Yt}else{var Er=ct<0?Yt:0;Nn=Er+ct*ir}var Mr=function(wr){return Math.abs(wr)=Math.abs(Yt)},Cr=Mr(Nn),Or=Mr(Math.abs(Yt)-Math.abs(Nn)),Wn=Cr||Or;if(Wn&&!vr)if(hn){var br=Math.abs(Dn)<=ce/2,Sr=Math.abs(Lt)<=ve/2;if(br){var Nr=(Y.x1+Y.x2)/2,Si=Y.y1,ys=Y.y2;k.segpts=[Nr,Si,Nr,ys]}else if(Sr){var pa=(Y.y1+Y.y2)/2,Mi=Y.x1,gi=Y.x2;k.segpts=[Mi,pa,gi,pa]}else k.segpts=[Y.x1,Y.y2]}else{var fs=Math.abs(Dn)<=Z/2,Fs=Math.abs(Mt)<=me/2;if(fs){var xs=(Y.y1+Y.y2)/2,Rs=Y.x1,yo=Y.x2;k.segpts=[Rs,xs,yo,xs]}else if(Fs){var $a=(Y.x1+Y.x2)/2,Da=Y.y1,Bo=Y.y2;k.segpts=[$a,Da,$a,Bo]}else k.segpts=[Y.x2,Y.y1]}else if(hn){var tr=Y.y1+Nn+(_e?ce/2*ir:0),G=Y.x1,Jn=Y.x2;k.segpts=[G,tr,Jn,tr]}else{var kr=Y.x1+Nn+(_e?Z/2*ir:0),lr=Y.y1,Vt=Y.y2;k.segpts=[kr,lr,kr,Vt]}},S1.tryToCorrectInvalidPoints=function(x,m){var k=x._private.rscratch;if(k.edgeType==="bezier"){var S=m.srcPos,M=m.tgtPos,O=m.srcW,N=m.srcH,$=m.tgtW,H=m.tgtH,q=m.srcShape,Y=m.tgtShape,Z=!X(k.startX)||!X(k.startY),ce=!X(k.arrowStartX)||!X(k.arrowStartY),ve=!X(k.endX)||!X(k.endY),me=!X(k.arrowEndX)||!X(k.arrowEndY),Le=3,_e=this.getArrowWidth(x.pstyle("width").pfValue,x.pstyle("arrow-scale").value)*this.arrowShapeWidth,Ee=Le*_e,Be=h5({x:k.ctrlpts[0],y:k.ctrlpts[1]},{x:k.startX,y:k.startY}),Re=BeTt.poolIndex()){var _n=Wt;Wt=Tt,Tt=_n}var hn=Je.srcPos=Wt.position(),Yt=Je.tgtPos=Tt.position(),Dn=Je.srcW=Wt.outerWidth(),ir=Je.srcH=Wt.outerHeight(),vr=Je.tgtW=Tt.outerWidth(),Nn=Je.tgtH=Tt.outerHeight(),pr=Je.srcShape=k.nodeShapes[m.getNodeShape(Wt)],Er=Je.tgtShape=k.nodeShapes[m.getNodeShape(Tt)];Je.dirCounts={north:0,west:0,south:0,east:0,northwest:0,southwest:0,northeast:0,southeast:0};for(var Mr=0;Mr0){var br=O,Sr=f5(br,J7(k)),Nr=f5(br,J7(Wn)),Si=Sr;if(Nr2){var ys=f5(br,{x:Wn[2],y:Wn[3]});ys0){var G=N,Jn=f5(G,J7(k)),kr=f5(G,J7(tr)),lr=Jn;if(kr2){var Vt=f5(G,{x:tr[2],y:tr[3]});Vt=me||Ye){_e={cp:Ve,segment:st};break}}if(_e)break}var mt=_e.cp,Je=_e.segment,Lt=(me-Ee)/Je.length,Mt=Je.t1-Je.t0,ut=ve?Je.t0+Mt*Lt:Je.t1-Mt*Lt;ut=U9(0,ut,1),m=Z7(mt.p0,mt.p1,mt.p2,ut),ce=Hre(mt.p0,mt.p1,mt.p2,ut);break}case"straight":case"segments":case"haystack":{for(var Wt=0,Tt,_n,hn,Yt,Dn=S.allpts.length,ir=0;ir+3=me));ir+=2);var vr=me-_n,Nn=vr/Tt;Nn=U9(0,Nn,1),m=fZ(hn,Yt,Nn),ce=GS(hn,Yt);break}}N("labelX",Z,m.x),N("labelY",Z,m.y),N("labelAutoAngle",Z,ce)}};q("source"),q("target"),this.applyLabelDimensions(x)}},km.applyLabelDimensions=function(x){this.applyPrefixedLabelDimensions(x),x.isEdge()&&(this.applyPrefixedLabelDimensions(x,"source"),this.applyPrefixedLabelDimensions(x,"target"))},km.applyPrefixedLabelDimensions=function(x,m){var k=x._private,S=this.getLabelText(x,m),M=this.calculateLabelDimensions(x,S),O=x.pstyle("line-height").pfValue,N=x.pstyle("text-wrap").strValue,$=K2(k.rscratch,"labelWrapCachedLines",m)||[],H=N!=="wrap"?1:Math.max($.length,1),q=M.height/H,Y=q*O,Z=M.width,ce=M.height+(H-1)*(O-1)*q;J3(k.rstyle,"labelWidth",m,Z),J3(k.rscratch,"labelWidth",m,Z),J3(k.rstyle,"labelHeight",m,ce),J3(k.rscratch,"labelHeight",m,ce),J3(k.rscratch,"labelLineHeight",m,Y)},km.getLabelText=function(x,m){var k=x._private,S=m?m+"-":"",M=x.pstyle(S+"label").strValue,O=x.pstyle("text-transform").value,N=function(vr,Nn){return Nn?(J3(k.rscratch,vr,m,Nn),Nn):K2(k.rscratch,vr,m)};if(!M)return"";O=="none"||(O=="uppercase"?M=M.toUpperCase():O=="lowercase"&&(M=M.toLowerCase()));var $=x.pstyle("text-wrap").value;if($==="wrap"){var H=N("labelKey");if(H!=null&&N("labelWrapKey")===H)return N("labelWrapCachedText");for(var q="​",Y=M.split(` +`),Z=x.pstyle("text-max-width").pfValue,ce=x.pstyle("text-overflow-wrap").value,ve=ce==="anywhere",me=[],Le=/[\s\u200b]+/,_e=ve?"":" ",Ee=0;EeZ){for(var st=Be.split(Le),Ye="",mt=0;mtWt)break;Tt+=M[Yt],Yt===M.length-1&&(hn=!0)}return hn||(Tt+=_n),Tt}return M},km.getLabelJustification=function(x){var m=x.pstyle("text-justification").strValue,k=x.pstyle("text-halign").strValue;if(m==="auto")if(x.isNode())switch(k){case"left":return"right";case"right":return"left";default:return"center"}else return"center";else return m},km.calculateLabelDimensions=function(x,m){var k=this,S=ud(m,x._private.labelDimsKey),M=k.labelDimCache||(k.labelDimCache=[]),O=M[S];if(O!=null)return O;var N=0,$=x.pstyle("font-style").strValue,H=x.pstyle("font-size").pfValue,q=x.pstyle("font-family").strValue,Y=x.pstyle("font-weight").strValue,Z=this.labelCalcCanvas,ce=this.labelCalcCanvasContext;if(!Z){Z=this.labelCalcCanvas=document.createElement("canvas"),ce=this.labelCalcCanvasContext=Z.getContext("2d");var ve=Z.style;ve.position="absolute",ve.left="-9999px",ve.top="-9999px",ve.zIndex="-1",ve.visibility="hidden",ve.pointerEvents="none"}ce.font="".concat($," ").concat(Y," ").concat(H,"px ").concat(q);for(var me=0,Le=0,_e=m.split(` +`),Ee=0;Ee<_e.length;Ee++){var Be=_e[Ee],Re=ce.measureText(Be),Ve=Math.ceil(Re.width),ct=H;me=Math.max(Ve,me),Le+=ct}return me+=N,Le+=N,M[S]={width:me,height:Le}},km.calculateLabelAngle=function(x,m){var k=x._private,S=k.rscratch,M=x.isEdge(),O=m?m+"-":"",N=x.pstyle(O+"text-rotation"),$=N.strValue;return $==="none"?0:M&&$==="autorotate"?S.labelAutoAngle:$==="autorotate"?0:N.pfValue},km.calculateLabelAngles=function(x){var m=this,k=x.isEdge(),S=x._private,M=S.rscratch;M.labelAngle=m.calculateLabelAngle(x),k&&(M.sourceLabelAngle=m.calculateLabelAngle(x,"source"),M.targetLabelAngle=m.calculateLabelAngle(x,"target"))};var ez={},tz=28,nz=!1;ez.getNodeShape=function(x){var m=this,k=x.pstyle("shape").value;if(k==="cutrectangle"&&(x.width()1&&arguments[1]!==void 0?arguments[1]:!0;if(m.merge(N),$)for(var H=0;H=x.desktopTapThreshold2}var Wv=M(G);Wl&&(x.hoverData.tapholdCancelled=!0);var sy=function(){var Em=x.hoverData.dragDelta=x.hoverData.dragDelta||[];Em.length===0?(Em.push(xo[0]),Em.push(xo[1])):(Em[0]+=xo[0],Em[1]+=xo[1])};kr=!0,S(za,["mousemove","vmousemove","tapdrag"],G,{x:wr[0],y:wr[1]});var E8=function(){x.data.bgActivePosistion=void 0,x.hoverData.selecting||lr.emit({originalEvent:G,type:"boxstart",position:{x:wr[0],y:wr[1]}}),$c[4]=1,x.hoverData.selecting=!0,x.redrawHint("select",!0),x.redraw()};if(x.hoverData.which===3){if(Wl){var x5={originalEvent:G,type:"cxtdrag",position:{x:wr[0],y:wr[1]}};ba?ba.emit(x5):lr.emit(x5),x.hoverData.cxtDragged=!0,(!x.hoverData.cxtOver||za!==x.hoverData.cxtOver)&&(x.hoverData.cxtOver&&x.hoverData.cxtOver.emit({originalEvent:G,type:"cxtdragout",position:{x:wr[0],y:wr[1]}}),x.hoverData.cxtOver=za,za&&za.emit({originalEvent:G,type:"cxtdragover",position:{x:wr[0],y:wr[1]}}))}}else if(x.hoverData.dragging){if(kr=!0,lr.panningEnabled()&&lr.userPanningEnabled()){var T8;if(x.hoverData.justStartedPan){var ZS=x.hoverData.mdownPos;T8={x:(wr[0]-ZS[0])*Vt,y:(wr[1]-ZS[1])*Vt},x.hoverData.justStartedPan=!1}else T8={x:xo[0]*Vt,y:xo[1]*Vt};lr.panBy(T8),lr.emit("dragpan"),x.hoverData.dragged=!0}wr=x.projectIntoViewport(G.clientX,G.clientY)}else if($c[4]==1&&(ba==null||ba.pannable())){if(Wl){if(!x.hoverData.dragging&&lr.boxSelectionEnabled()&&(Wv||!lr.panningEnabled()||!lr.userPanningEnabled()))E8();else if(!x.hoverData.selecting&&lr.panningEnabled()&&lr.userPanningEnabled()){var k5=O(ba,x.hoverData.downs);k5&&(x.hoverData.dragging=!0,x.hoverData.justStartedPan=!0,$c[4]=0,x.data.bgActivePosistion=J7(Es),x.redrawHint("select",!0),x.redraw())}ba&&ba.pannable()&&ba.active()&&ba.unactivate()}}else{if(ba&&ba.pannable()&&ba.active()&&ba.unactivate(),(!ba||!ba.grabbed())&&za!=Sc&&(Sc&&S(Sc,["mouseout","tapdragout"],G,{x:wr[0],y:wr[1]}),za&&S(za,["mouseover","tapdragover"],G,{x:wr[0],y:wr[1]}),x.hoverData.last=za),ba)if(Wl){if(lr.boxSelectionEnabled()&&Wv)ba&&ba.grabbed()&&(_e(lh),ba.emit("freeon"),lh.emit("free"),x.dragData.didDrag&&(ba.emit("dragfreeon"),lh.emit("dragfree"))),E8();else if(ba&&ba.grabbed()&&x.nodeIsDraggable(ba)){var Qd=!x.dragData.didDrag;Qd&&x.redrawHint("eles",!0),x.dragData.didDrag=!0,x.hoverData.draggingEles||me(lh,{inDragLayer:!0});var _1={x:0,y:0};if(X(xo[0])&&X(xo[1])&&(_1.x+=xo[0],_1.y+=xo[1],Qd)){var Jd=x.hoverData.dragDelta;Jd&&X(Jd[0])&&X(Jd[1])&&(_1.x+=Jd[0],_1.y+=Jd[1])}x.hoverData.draggingEles=!0,lh.silentShift(_1).emit("position drag"),x.redrawHint("drag",!0),x.redraw()}}else sy();kr=!0}if($c[2]=wr[0],$c[3]=wr[1],kr)return G.stopPropagation&&G.stopPropagation(),G.preventDefault&&G.preventDefault(),!1}},!1);var Lt,Mt,ut;x.registerBinding(m,"mouseup",function(G){var Jn=x.hoverData.capture;if(Jn){x.hoverData.capture=!1;var kr=x.cy,lr=x.projectIntoViewport(G.clientX,G.clientY),Vt=x.selection,Hs=x.findNearestElement(lr[0],lr[1],!0,!1),wr=x.dragData.possibleDragElements,Es=x.hoverData.down,go=M(G);if(x.data.bgActivePosistion&&(x.redrawHint("select",!0),x.redraw()),x.hoverData.tapholdCancelled=!0,x.data.bgActivePosistion=void 0,Es&&Es.unactivate(),x.hoverData.which===3){var $c={originalEvent:G,type:"cxttapend",position:{x:lr[0],y:lr[1]}};if(Es?Es.emit($c):kr.emit($c),!x.hoverData.cxtDragged){var za={originalEvent:G,type:"cxttap",position:{x:lr[0],y:lr[1]}};Es?Es.emit(za):kr.emit(za)}x.hoverData.cxtDragged=!1,x.hoverData.which=null}else if(x.hoverData.which===1){if(S(Hs,["mouseup","tapend","vmouseup"],G,{x:lr[0],y:lr[1]}),!x.dragData.didDrag&&!x.hoverData.dragged&&!x.hoverData.selecting&&!x.hoverData.isOverThresholdDrag&&(S(Es,["click","tap","vclick"],G,{x:lr[0],y:lr[1]}),Mt=!1,G.timeStamp-ut<=kr.multiClickDebounceTime()?(Lt&&clearTimeout(Lt),Mt=!0,ut=null,S(Es,["dblclick","dbltap","vdblclick"],G,{x:lr[0],y:lr[1]})):(Lt=setTimeout(function(){Mt||S(Es,["oneclick","onetap","voneclick"],G,{x:lr[0],y:lr[1]})},kr.multiClickDebounceTime()),ut=G.timeStamp)),Es==null&&!x.dragData.didDrag&&!x.hoverData.selecting&&!x.hoverData.dragged&&!M(G)&&(kr.$(k).unselect(["tapunselect"]),wr.length>0&&x.redrawHint("eles",!0),x.dragData.possibleDragElements=wr=kr.collection()),Hs==Es&&!x.dragData.didDrag&&!x.hoverData.selecting&&Hs!=null&&Hs._private.selectable&&(x.hoverData.dragging||(kr.selectionType()==="additive"||go?Hs.selected()?Hs.unselect(["tapunselect"]):Hs.select(["tapselect"]):go||(kr.$(k).unmerge(Hs).unselect(["tapunselect"]),Hs.select(["tapselect"]))),x.redrawHint("eles",!0)),x.hoverData.selecting){var Sc=kr.collection(x.getAllInBox(Vt[0],Vt[1],Vt[2],Vt[3]));x.redrawHint("select",!0),Sc.length>0&&x.redrawHint("eles",!0),kr.emit({type:"boxend",originalEvent:G,position:{x:lr[0],y:lr[1]}});var ba=function(Wl){return Wl.selectable()&&!Wl.selected()};kr.selectionType()==="additive"||go||kr.$(k).unmerge(Sc).unselect(),Sc.emit("box").stdFilter(ba).select().emit("boxselect"),x.redraw()}if(x.hoverData.dragging&&(x.hoverData.dragging=!1,x.redrawHint("select",!0),x.redrawHint("eles",!0),x.redraw()),!Vt[4]){x.redrawHint("drag",!0),x.redrawHint("eles",!0);var xo=Es&&Es.grabbed();_e(wr),xo&&(Es.emit("freeon"),wr.emit("free"),x.dragData.didDrag&&(Es.emit("dragfreeon"),wr.emit("dragfree")))}}Vt[4]=0,x.hoverData.down=null,x.hoverData.cxtStarted=!1,x.hoverData.draggingEles=!1,x.hoverData.selecting=!1,x.hoverData.isOverThresholdDrag=!1,x.dragData.didDrag=!1,x.hoverData.dragged=!1,x.hoverData.dragDelta=[],x.hoverData.mdownPos=null,x.hoverData.mdownGPos=null}},!1);var Wt=function(G){if(!x.scrollingPage){var Jn=x.cy,kr=Jn.zoom(),lr=Jn.pan(),Vt=x.projectIntoViewport(G.clientX,G.clientY),Hs=[Vt[0]*kr+lr.x,Vt[1]*kr+lr.y];if(x.hoverData.draggingEles||x.hoverData.dragging||x.hoverData.cxtStarted||mt()){G.preventDefault();return}if(Jn.panningEnabled()&&Jn.userPanningEnabled()&&Jn.zoomingEnabled()&&Jn.userZoomingEnabled()){G.preventDefault(),x.data.wheelZooming=!0,clearTimeout(x.data.wheelTimeout),x.data.wheelTimeout=setTimeout(function(){x.data.wheelZooming=!1,x.redrawHint("eles",!0),x.redraw()},150);var wr;G.deltaY!=null?wr=G.deltaY/-250:G.wheelDeltaY!=null?wr=G.wheelDeltaY/1e3:wr=G.wheelDelta/1e3,wr=wr*x.wheelSensitivity;var Es=G.deltaMode===1;Es&&(wr*=33);var go=Jn.zoom()*Math.pow(10,wr);G.type==="gesturechange"&&(go=x.gestureStartZoom*G.scale),Jn.zoom({level:go,renderedPosition:{x:Hs[0],y:Hs[1]}}),Jn.emit(G.type==="gesturechange"?"pinchzoom":"scrollzoom")}}};x.registerBinding(x.container,"wheel",Wt,!0),x.registerBinding(m,"scroll",function(G){x.scrollingPage=!0,clearTimeout(x.scrollingPageTimeout),x.scrollingPageTimeout=setTimeout(function(){x.scrollingPage=!1},250)},!0),x.registerBinding(x.container,"gesturestart",function(G){x.gestureStartZoom=x.cy.zoom(),x.hasTouchStarted||G.preventDefault()},!0),x.registerBinding(x.container,"gesturechange",function(tr){x.hasTouchStarted||Wt(tr)},!0),x.registerBinding(x.container,"mouseout",function(G){var Jn=x.projectIntoViewport(G.clientX,G.clientY);x.cy.emit({originalEvent:G,type:"mouseout",position:{x:Jn[0],y:Jn[1]}})},!1),x.registerBinding(x.container,"mouseover",function(G){var Jn=x.projectIntoViewport(G.clientX,G.clientY);x.cy.emit({originalEvent:G,type:"mouseover",position:{x:Jn[0],y:Jn[1]}})},!1);var Tt,_n,hn,Yt,Dn,ir,vr,Nn,pr,Er,Mr,Cr,Or,Wn=function(G,Jn,kr,lr){return Math.sqrt((kr-G)*(kr-G)+(lr-Jn)*(lr-Jn))},br=function(G,Jn,kr,lr){return(kr-G)*(kr-G)+(lr-Jn)*(lr-Jn)},Sr;x.registerBinding(x.container,"touchstart",Sr=function(G){if(x.hasTouchStarted=!0,!!Je(G)){Be(),x.touchData.capture=!0,x.data.bgActivePosistion=void 0;var Jn=x.cy,kr=x.touchData.now,lr=x.touchData.earlier;if(G.touches[0]){var Vt=x.projectIntoViewport(G.touches[0].clientX,G.touches[0].clientY);kr[0]=Vt[0],kr[1]=Vt[1]}if(G.touches[1]){var Vt=x.projectIntoViewport(G.touches[1].clientX,G.touches[1].clientY);kr[2]=Vt[0],kr[3]=Vt[1]}if(G.touches[2]){var Vt=x.projectIntoViewport(G.touches[2].clientX,G.touches[2].clientY);kr[4]=Vt[0],kr[5]=Vt[1]}if(G.touches[1]){x.touchData.singleTouchMoved=!0,_e(x.dragData.touchDragEles);var Hs=x.findContainerClientCoords();pr=Hs[0],Er=Hs[1],Mr=Hs[2],Cr=Hs[3],Tt=G.touches[0].clientX-pr,_n=G.touches[0].clientY-Er,hn=G.touches[1].clientX-pr,Yt=G.touches[1].clientY-Er,Or=0<=Tt&&Tt<=Mr&&0<=hn&&hn<=Mr&&0<=_n&&_n<=Cr&&0<=Yt&&Yt<=Cr;var wr=Jn.pan(),Es=Jn.zoom();Dn=Wn(Tt,_n,hn,Yt),ir=br(Tt,_n,hn,Yt),vr=[(Tt+hn)/2,(_n+Yt)/2],Nn=[(vr[0]-wr.x)/Es,(vr[1]-wr.y)/Es];var go=200,$c=go*go;if(ir<$c&&!G.touches[2]){var za=x.findNearestElement(kr[0],kr[1],!0,!0),Sc=x.findNearestElement(kr[2],kr[3],!0,!0);za&&za.isNode()?(za.activate().emit({originalEvent:G,type:"cxttapstart",position:{x:kr[0],y:kr[1]}}),x.touchData.start=za):Sc&&Sc.isNode()?(Sc.activate().emit({originalEvent:G,type:"cxttapstart",position:{x:kr[0],y:kr[1]}}),x.touchData.start=Sc):Jn.emit({originalEvent:G,type:"cxttapstart",position:{x:kr[0],y:kr[1]}}),x.touchData.start&&(x.touchData.start._private.grabbed=!1),x.touchData.cxt=!0,x.touchData.cxtDragged=!1,x.data.bgActivePosistion=void 0,x.redraw();return}}if(G.touches[2])Jn.boxSelectionEnabled()&&G.preventDefault();else if(!G.touches[1]){if(G.touches[0]){var ba=x.findNearestElements(kr[0],kr[1],!0,!0),xo=ba[0];if(xo!=null&&(xo.activate(),x.touchData.start=xo,x.touchData.starts=ba,x.nodeIsGrabbable(xo))){var lh=x.dragData.touchDragEles=Jn.collection(),Wl=null;x.redrawHint("eles",!0),x.redrawHint("drag",!0),xo.selected()?(Wl=Jn.$(function(fd){return fd.selected()&&x.nodeIsGrabbable(fd)}),me(Wl,{addToList:lh})):Le(xo,{addToList:lh}),Y(xo);var Z2=function(Wv){return{originalEvent:G,type:Wv,position:{x:kr[0],y:kr[1]}}};xo.emit(Z2("grabon")),Wl?Wl.forEach(function(fd){fd.emit(Z2("grab"))}):xo.emit(Z2("grab"))}S(xo,["touchstart","tapstart","vmousedown"],G,{x:kr[0],y:kr[1]}),xo==null&&(x.data.bgActivePosistion={x:Vt[0],y:Vt[1]},x.redrawHint("select",!0),x.redraw()),x.touchData.singleTouchMoved=!1,x.touchData.singleTouchStartTime=+new Date,clearTimeout(x.touchData.tapholdTimeout),x.touchData.tapholdTimeout=setTimeout(function(){x.touchData.singleTouchMoved===!1&&!x.pinching&&!x.touchData.selecting&&S(x.touchData.start,["taphold"],G,{x:kr[0],y:kr[1]})},x.tapholdDuration)}}if(G.touches.length>=1){for(var eb=x.touchData.startPosition=[null,null,null,null,null,null],G0=0;G0=x.touchTapThreshold2}if(Jn&&x.touchData.cxt){G.preventDefault();var eb=G.touches[0].clientX-pr,G0=G.touches[0].clientY-Er,zp=G.touches[1].clientX-pr,fd=G.touches[1].clientY-Er,Wv=br(eb,G0,zp,fd),sy=Wv/ir,E8=150,x5=E8*E8,T8=1.5,ZS=T8*T8;if(sy>=ZS||Wv>=x5){x.touchData.cxt=!1,x.data.bgActivePosistion=void 0,x.redrawHint("select",!0);var k5={originalEvent:G,type:"cxttapend",position:{x:Vt[0],y:Vt[1]}};x.touchData.start?(x.touchData.start.unactivate().emit(k5),x.touchData.start=null):lr.emit(k5)}}if(Jn&&x.touchData.cxt){var k5={originalEvent:G,type:"cxtdrag",position:{x:Vt[0],y:Vt[1]}};x.data.bgActivePosistion=void 0,x.redrawHint("select",!0),x.touchData.start?x.touchData.start.emit(k5):lr.emit(k5),x.touchData.start&&(x.touchData.start._private.grabbed=!1),x.touchData.cxtDragged=!0;var Qd=x.findNearestElement(Vt[0],Vt[1],!0,!0);(!x.touchData.cxtOver||Qd!==x.touchData.cxtOver)&&(x.touchData.cxtOver&&x.touchData.cxtOver.emit({originalEvent:G,type:"cxtdragout",position:{x:Vt[0],y:Vt[1]}}),x.touchData.cxtOver=Qd,Qd&&Qd.emit({originalEvent:G,type:"cxtdragover",position:{x:Vt[0],y:Vt[1]}}))}else if(Jn&&G.touches[2]&&lr.boxSelectionEnabled())G.preventDefault(),x.data.bgActivePosistion=void 0,this.lastThreeTouch=+new Date,x.touchData.selecting||lr.emit({originalEvent:G,type:"boxstart",position:{x:Vt[0],y:Vt[1]}}),x.touchData.selecting=!0,x.touchData.didSelect=!0,kr[4]=1,!kr||kr.length===0||kr[0]===void 0?(kr[0]=(Vt[0]+Vt[2]+Vt[4])/3,kr[1]=(Vt[1]+Vt[3]+Vt[5])/3,kr[2]=(Vt[0]+Vt[2]+Vt[4])/3+1,kr[3]=(Vt[1]+Vt[3]+Vt[5])/3+1):(kr[2]=(Vt[0]+Vt[2]+Vt[4])/3,kr[3]=(Vt[1]+Vt[3]+Vt[5])/3),x.redrawHint("select",!0),x.redraw();else if(Jn&&G.touches[1]&&!x.touchData.didSelect&&lr.zoomingEnabled()&&lr.panningEnabled()&&lr.userZoomingEnabled()&&lr.userPanningEnabled()){G.preventDefault(),x.data.bgActivePosistion=void 0,x.redrawHint("select",!0);var _1=x.dragData.touchDragEles;if(_1){x.redrawHint("drag",!0);for(var Jd=0;Jd<_1.length;Jd++){var Yv=_1[Jd]._private;Yv.grabbed=!1,Yv.rscratch.inDragLayer=!1}}var Em=x.touchData.start,eb=G.touches[0].clientX-pr,G0=G.touches[0].clientY-Er,zp=G.touches[1].clientX-pr,fd=G.touches[1].clientY-Er,Lz=Wn(eb,G0,zp,fd),Lie=Lz/Dn;if(Or){var Mie=eb-Tt,e_=G0-_n,Die=zp-hn,Iie=fd-Yt,E5=(Mie+Die)/2,Mz=(e_+Iie)/2,yk=lr.zoom(),UI=yk*Lie,t_=lr.pan(),Dz=Nn[0]*yk+t_.x,Iz=Nn[1]*yk+t_.y,Oie={x:-UI/yk*(Dz-t_.x-E5)+Dz,y:-UI/yk*(Iz-t_.y-Mz)+Iz};if(Em&&Em.active()){var _1=x.dragData.touchDragEles;_e(_1),x.redrawHint("drag",!0),x.redrawHint("eles",!0),Em.unactivate().emit("freeon"),_1.emit("free"),x.dragData.didDrag&&(Em.emit("dragfreeon"),_1.emit("dragfree"))}lr.viewport({zoom:UI,pan:Oie,cancelOnFailedZoom:!0}),lr.emit("pinchzoom"),Dn=Lz,Tt=eb,_n=G0,hn=zp,Yt=fd,x.pinching=!0}if(G.touches[0]){var Es=x.projectIntoViewport(G.touches[0].clientX,G.touches[0].clientY);Vt[0]=Es[0],Vt[1]=Es[1]}if(G.touches[1]){var Es=x.projectIntoViewport(G.touches[1].clientX,G.touches[1].clientY);Vt[2]=Es[0],Vt[3]=Es[1]}if(G.touches[2]){var Es=x.projectIntoViewport(G.touches[2].clientX,G.touches[2].clientY);Vt[4]=Es[0],Vt[5]=Es[1]}}else if(G.touches[0]&&!x.touchData.didSelect){var qp=x.touchData.start,n_=x.touchData.last,Qd;if(!x.hoverData.draggingEles&&!x.swipePanning&&(Qd=x.findNearestElement(Vt[0],Vt[1],!0,!0)),Jn&&qp!=null&&G.preventDefault(),Jn&&qp!=null&&x.nodeIsDraggable(qp))if($c){var _1=x.dragData.touchDragEles,GI=!x.dragData.didDrag;GI&&me(_1,{inDragLayer:!0}),x.dragData.didDrag=!0;var Tm={x:0,y:0};if(X(za[0])&&X(za[1])&&(Tm.x+=za[0],Tm.y+=za[1],GI)){x.redrawHint("eles",!0);var Zd=x.touchData.dragDelta;Zd&&X(Zd[0])&&X(Zd[1])&&(Tm.x+=Zd[0],Tm.y+=Zd[1])}x.hoverData.draggingEles=!0,_1.silentShift(Tm).emit("position drag"),x.redrawHint("drag",!0),x.touchData.startPosition[0]==Hs[0]&&x.touchData.startPosition[1]==Hs[1]&&x.redrawHint("eles",!0),x.redraw()}else{var Zd=x.touchData.dragDelta=x.touchData.dragDelta||[];Zd.length===0?(Zd.push(za[0]),Zd.push(za[1])):(Zd[0]+=za[0],Zd[1]+=za[1])}if(S(qp||Qd,["touchmove","tapdrag","vmousemove"],G,{x:Vt[0],y:Vt[1]}),(!qp||!qp.grabbed())&&Qd!=n_&&(n_&&n_.emit({originalEvent:G,type:"tapdragout",position:{x:Vt[0],y:Vt[1]}}),Qd&&Qd.emit({originalEvent:G,type:"tapdragover",position:{x:Vt[0],y:Vt[1]}})),x.touchData.last=Qd,Jn)for(var Jd=0;Jd0&&!x.hoverData.draggingEles&&!x.swipePanning&&x.data.bgActivePosistion!=null&&(x.data.bgActivePosistion=void 0,x.redrawHint("select",!0),x.redraw())}},!1);var Si;x.registerBinding(m,"touchcancel",Si=function(G){var Jn=x.touchData.start;x.touchData.capture=!1,Jn&&Jn.unactivate()});var ys,pa,Mi,gi;if(x.registerBinding(m,"touchend",ys=function(G){var Jn=x.touchData.start,kr=x.touchData.capture;if(kr)G.touches.length===0&&(x.touchData.capture=!1),G.preventDefault();else return;var lr=x.selection;x.swipePanning=!1,x.hoverData.draggingEles=!1;var Vt=x.cy,Hs=Vt.zoom(),wr=x.touchData.now,Es=x.touchData.earlier;if(G.touches[0]){var go=x.projectIntoViewport(G.touches[0].clientX,G.touches[0].clientY);wr[0]=go[0],wr[1]=go[1]}if(G.touches[1]){var go=x.projectIntoViewport(G.touches[1].clientX,G.touches[1].clientY);wr[2]=go[0],wr[3]=go[1]}if(G.touches[2]){var go=x.projectIntoViewport(G.touches[2].clientX,G.touches[2].clientY);wr[4]=go[0],wr[5]=go[1]}Jn&&Jn.unactivate();var $c;if(x.touchData.cxt){if($c={originalEvent:G,type:"cxttapend",position:{x:wr[0],y:wr[1]}},Jn?Jn.emit($c):Vt.emit($c),!x.touchData.cxtDragged){var za={originalEvent:G,type:"cxttap",position:{x:wr[0],y:wr[1]}};Jn?Jn.emit(za):Vt.emit(za)}x.touchData.start&&(x.touchData.start._private.grabbed=!1),x.touchData.cxt=!1,x.touchData.start=null,x.redraw();return}if(!G.touches[2]&&Vt.boxSelectionEnabled()&&x.touchData.selecting){x.touchData.selecting=!1;var Sc=Vt.collection(x.getAllInBox(lr[0],lr[1],lr[2],lr[3]));lr[0]=void 0,lr[1]=void 0,lr[2]=void 0,lr[3]=void 0,lr[4]=0,x.redrawHint("select",!0),Vt.emit({type:"boxend",originalEvent:G,position:{x:wr[0],y:wr[1]}});var ba=function(x5){return x5.selectable()&&!x5.selected()};Sc.emit("box").stdFilter(ba).select().emit("boxselect"),Sc.nonempty()&&x.redrawHint("eles",!0),x.redraw()}if(Jn!=null&&Jn.unactivate(),G.touches[2])x.data.bgActivePosistion=void 0,x.redrawHint("select",!0);else if(!G.touches[1]){if(!G.touches[0]){if(!G.touches[0]){x.data.bgActivePosistion=void 0,x.redrawHint("select",!0);var xo=x.dragData.touchDragEles;if(Jn!=null){var lh=Jn._private.grabbed;_e(xo),x.redrawHint("drag",!0),x.redrawHint("eles",!0),lh&&(Jn.emit("freeon"),xo.emit("free"),x.dragData.didDrag&&(Jn.emit("dragfreeon"),xo.emit("dragfree"))),S(Jn,["touchend","tapend","vmouseup","tapdragout"],G,{x:wr[0],y:wr[1]}),Jn.unactivate(),x.touchData.start=null}else{var Wl=x.findNearestElement(wr[0],wr[1],!0,!0);S(Wl,["touchend","tapend","vmouseup","tapdragout"],G,{x:wr[0],y:wr[1]})}var Z2=x.touchData.startPosition[0]-wr[0],eb=Z2*Z2,G0=x.touchData.startPosition[1]-wr[1],zp=G0*G0,fd=eb+zp,Wv=fd*Hs*Hs;x.touchData.singleTouchMoved||(Jn||Vt.$(":selected").unselect(["tapunselect"]),S(Jn,["tap","vclick"],G,{x:wr[0],y:wr[1]}),pa=!1,G.timeStamp-gi<=Vt.multiClickDebounceTime()?(Mi&&clearTimeout(Mi),pa=!0,gi=null,S(Jn,["dbltap","vdblclick"],G,{x:wr[0],y:wr[1]})):(Mi=setTimeout(function(){pa||S(Jn,["onetap","voneclick"],G,{x:wr[0],y:wr[1]})},Vt.multiClickDebounceTime()),gi=G.timeStamp)),Jn!=null&&!x.dragData.didDrag&&Jn._private.selectable&&Wv"u"){var fs=[],Fs=function(G){return{clientX:G.clientX,clientY:G.clientY,force:1,identifier:G.pointerId,pageX:G.pageX,pageY:G.pageY,radiusX:G.width/2,radiusY:G.height/2,screenX:G.screenX,screenY:G.screenY,target:G.target}},xs=function(G){return{event:G,touch:Fs(G)}},Rs=function(G){fs.push(xs(G))},yo=function(G){for(var Jn=0;Jn0)return Nn[0]}return null},ve=Object.keys(Z),me=0;me0?ce:bj(O,N,m,k,S,M,$)},checkPoint:function(m,k,S,M,O,N,$){var H=W9(M,O),q=2*H;if(Uv(m,k,this.points,N,$,M,O-q,[0,-1],S)||Uv(m,k,this.points,N,$,M-q,O,[0,-1],S))return!0;var Y=M/2+2*S,Z=O/2+2*S,ce=[N-Y,$-Z,N-Y,$,N+Y,$,N+Y,$-Z];return!!(Yd(m,k,ce)||d5(m,k,q,q,N+M/2-H,$+O/2-H,S)||d5(m,k,q,q,N-M/2+H,$+O/2-H,S))}}},Kv.registerNodeShapes=function(){var x=this.nodeShapes={},m=this;this.generateEllipse(),this.generatePolygon("triangle",hd(3,0)),this.generateRoundPolygon("round-triangle",hd(3,0)),this.generatePolygon("rectangle",hd(4,0)),x.square=x.rectangle,this.generateRoundRectangle(),this.generateCutRectangle(),this.generateBarrel(),this.generateBottomRoundrectangle();{var k=[0,1,1,0,0,-1,-1,0];this.generatePolygon("diamond",k),this.generateRoundPolygon("round-diamond",k)}this.generatePolygon("pentagon",hd(5,0)),this.generateRoundPolygon("round-pentagon",hd(5,0)),this.generatePolygon("hexagon",hd(6,0)),this.generateRoundPolygon("round-hexagon",hd(6,0)),this.generatePolygon("heptagon",hd(7,0)),this.generateRoundPolygon("round-heptagon",hd(7,0)),this.generatePolygon("octagon",hd(8,0)),this.generateRoundPolygon("round-octagon",hd(8,0));var S=new Array(20);{var M=oI(5,0),O=oI(5,Math.PI/5),N=.5*(3-Math.sqrt(5));N*=1.57;for(var $=0;$=m.deqFastCost*Ve)break}else if(q){if(Be>=m.deqCost*ve||Be>=m.deqAvgCost*ce)break}else if(Re>=m.deqNoDrawCost*RI)break;var ct=m.deq(S,_e,Le);if(ct.length>0)for(var st=0;st0&&(m.onDeqd(S,me),!q&&m.shouldRedraw(S,me,_e,Le)&&O())},$=m.priority||nI;M.beforeRender(N,$(S))}}}},Ure=function(){function x(m){var k=arguments.length>1&&arguments[1]!==void 0?arguments[1]:X3;d(this,x),this.idsByKey=new wm,this.keyForId=new wm,this.cachesByLvl=new wm,this.lvls=[],this.getKey=m,this.doesEleInvalidateKey=k}return v(x,[{key:"getIdsFor",value:function(k){k==null&&ch("Can not get id list for null key");var S=this.idsByKey,M=this.idsByKey.get(k);return M||(M=new Q7,S.set(k,M)),M}},{key:"addIdForKey",value:function(k,S){k!=null&&this.getIdsFor(k).add(S)}},{key:"deleteIdForKey",value:function(k,S){k!=null&&this.getIdsFor(k).delete(S)}},{key:"getNumberOfIdsForKey",value:function(k){return k==null?0:this.getIdsFor(k).size}},{key:"updateKeyMappingFor",value:function(k){var S=k.id(),M=this.keyForId.get(S),O=this.getKey(k);this.deleteIdForKey(M,S),this.addIdForKey(O,S),this.keyForId.set(S,O)}},{key:"deleteKeyMappingFor",value:function(k){var S=k.id(),M=this.keyForId.get(S);this.deleteIdForKey(M,S),this.keyForId.delete(S)}},{key:"keyHasChangedFor",value:function(k){var S=k.id(),M=this.keyForId.get(S),O=this.getKey(k);return M!==O}},{key:"isInvalid",value:function(k){return this.keyHasChangedFor(k)||this.doesEleInvalidateKey(k)}},{key:"getCachesAt",value:function(k){var S=this.cachesByLvl,M=this.lvls,O=S.get(k);return O||(O=new wm,S.set(k,O),M.push(k)),O}},{key:"getCache",value:function(k,S){return this.getCachesAt(S).get(k)}},{key:"get",value:function(k,S){var M=this.getKey(k),O=this.getCache(M,S);return O!=null&&this.updateKeyMappingFor(k),O}},{key:"getForCachedKey",value:function(k,S){var M=this.keyForId.get(k.id()),O=this.getCache(M,S);return O}},{key:"hasCache",value:function(k,S){return this.getCachesAt(S).has(k)}},{key:"has",value:function(k,S){var M=this.getKey(k);return this.hasCache(M,S)}},{key:"setCache",value:function(k,S,M){M.key=k,this.getCachesAt(S).set(k,M)}},{key:"set",value:function(k,S,M){var O=this.getKey(k);this.setCache(O,S,M),this.updateKeyMappingFor(k)}},{key:"deleteCache",value:function(k,S){this.getCachesAt(S).delete(k)}},{key:"delete",value:function(k,S){var M=this.getKey(k);this.deleteCache(M,S)}},{key:"invalidateKey",value:function(k){var S=this;this.lvls.forEach(function(M){return S.deleteCache(k,M)})}},{key:"invalidate",value:function(k){var S=k.id(),M=this.keyForId.get(S);this.deleteKeyMappingFor(k);var O=this.doesEleInvalidateKey(k);return O&&this.invalidateKey(M),O||this.getNumberOfIdsForKey(M)===0}}]),x}(),cz=25,YS=50,XS=-4,jI=3,Gre=7.99,Kre=8,Wre=1024,Yre=1024,Xre=1024,Qre=.2,Jre=.8,Zre=10,eie=.15,tie=.1,nie=.9,rie=.9,iie=100,sie=1,v8={dequeue:"dequeue",downscale:"downscale",highQuality:"highQuality"},aie=q0({getKey:null,doesEleInvalidateKey:X3,drawElement:null,getBoundingBox:null,getRotationPoint:null,getRotationOffset:null,isVisible:l5,allowEdgeTxrCaching:!0,allowParentTxrCaching:!0}),dk=function(m,k){var S=this;S.renderer=m,S.onDequeues=[];var M=aie(k);yt(S,M),S.lookup=new Ure(M.getKey,M.doesEleInvalidateKey),S.setupDequeueing()},Cf=dk.prototype;Cf.reasons=v8,Cf.getTextureQueue=function(x){var m=this;return m.eleImgCaches=m.eleImgCaches||{},m.eleImgCaches[x]=m.eleImgCaches[x]||[]},Cf.getRetiredTextureQueue=function(x){var m=this,k=m.eleImgCaches.retired=m.eleImgCaches.retired||{},S=k[x]=k[x]||[];return S},Cf.getElementQueue=function(){var x=this,m=x.eleCacheQueue=x.eleCacheQueue||new V9(function(k,S){return S.reqs-k.reqs});return m},Cf.getElementKeyToQueue=function(){var x=this,m=x.eleKeyToCacheQueue=x.eleKeyToCacheQueue||{};return m},Cf.getElement=function(x,m,k,S,M){var O=this,N=this.renderer,$=N.cy.zoom(),H=this.lookup;if(!m||m.w===0||m.h===0||isNaN(m.w)||isNaN(m.h)||!x.visible()||x.removed()||!O.allowEdgeTxrCaching&&x.isEdge()||!O.allowParentTxrCaching&&x.isParent())return null;if(S==null&&(S=Math.ceil(iI($*k))),S=Gre||S>jI)return null;var q=Math.pow(2,S),Y=m.h*q,Z=m.w*q,ce=N.eleTextBiggerThanMin(x,q);if(!this.isVisible(x,ce))return null;var ve=H.get(x,S);if(ve&&ve.invalidated&&(ve.invalidated=!1,ve.texture.invalidatedWidth-=ve.width),ve)return ve;var me;if(Y<=cz?me=cz:Y<=YS?me=YS:me=Math.ceil(Y/YS)*YS,Y>Xre||Z>Yre)return null;var Le=O.getTextureQueue(me),_e=Le[Le.length-2],Ee=function(){return O.recycleTexture(me,Z)||O.addTexture(me,Z)};_e||(_e=Le[Le.length-1]),_e||(_e=Ee()),_e.width-_e.usedWidthS;Mt--)Je=O.getElement(x,m,k,Mt,v8.downscale);Lt()}else return O.queueElement(x,st.level-1),st;else{var ut;if(!Re&&!Ve&&!ct)for(var Wt=S-1;Wt>=XS;Wt--){var Tt=H.get(x,Wt);if(Tt){ut=Tt;break}}if(Be(ut))return O.queueElement(x,S),ut;_e.context.translate(_e.usedWidth,0),_e.context.scale(q,q),this.drawElement(_e.context,x,m,ce,!1),_e.context.scale(1/q,1/q),_e.context.translate(-_e.usedWidth,0)}return ve={x:_e.usedWidth,texture:_e,level:S,scale:q,width:Z,height:Y,scaledLabelShown:ce},_e.usedWidth+=Math.ceil(Z+Kre),_e.eleCaches.push(ve),H.set(x,S,ve),O.checkTextureFullness(_e),ve},Cf.invalidateElements=function(x){for(var m=0;m=Qre*x.width&&this.retireTexture(x)},Cf.checkTextureFullness=function(x){var m=this,k=m.getTextureQueue(x.height);x.usedWidth/x.width>Jre&&x.fullnessChecks>=Zre?Q3(k,x):x.fullnessChecks++},Cf.retireTexture=function(x){var m=this,k=x.height,S=m.getTextureQueue(k),M=this.lookup;Q3(S,x),x.retired=!0;for(var O=x.eleCaches,N=0;N=m)return N.retired=!1,N.usedWidth=0,N.invalidatedWidth=0,N.fullnessChecks=0,cS(N.eleCaches),N.context.setTransform(1,0,0,1,0,0),N.context.clearRect(0,0,N.width,N.height),Q3(M,N),S.push(N),N}},Cf.queueElement=function(x,m){var k=this,S=k.getElementQueue(),M=k.getElementKeyToQueue(),O=this.getKey(x),N=M[O];if(N)N.level=Math.max(N.level,m),N.eles.merge(x),N.reqs++,S.updateItem(N);else{var $={eles:x.spawn().merge(x),level:m,reqs:1,key:O};S.push($),M[O]=$}},Cf.dequeue=function(x){for(var m=this,k=m.getElementQueue(),S=m.getElementKeyToQueue(),M=[],O=m.lookup,N=0;N0;N++){var $=k.pop(),H=$.key,q=$.eles[0],Y=O.hasCache(q,$.level);if(S[H]=null,Y)continue;M.push($);var Z=m.getBoundingBox(q);m.getElement(q,Z,x,$.level,v8.dequeue)}return M},Cf.removeFromQueue=function(x){var m=this,k=m.getElementQueue(),S=m.getElementKeyToQueue(),M=this.getKey(x),O=S[M];O!=null&&(O.eles.length===1?(O.reqs=X7,k.updateItem(O),k.pop(),S[M]=null):O.eles.unmerge(x))},Cf.onDequeue=function(x){this.onDequeues.push(x)},Cf.offDequeue=function(x){Q3(this.onDequeues,x)},Cf.setupDequeueing=oz.setupDequeueing({deqRedrawThreshold:iie,deqCost:eie,deqAvgCost:tie,deqNoDrawCost:nie,deqFastCost:rie,deq:function(m,k,S){return m.dequeue(k,S)},onDeqd:function(m,k){for(var S=0;S=cie||k>QS)return null}S.validateLayersElesOrdering(k,x);var H=S.layersByLevel,q=Math.pow(2,k),Y=H[k]=H[k]||[],Z,ce=S.levelIsComplete(k,x),ve,me=function(){var Lt=function(_n){if(S.validateLayersElesOrdering(_n,x),S.levelIsComplete(_n,x))return ve=H[_n],!0},Mt=function(_n){if(!ve)for(var hn=k+_n;gk<=hn&&hn<=QS&&!Lt(hn);hn+=_n);};Mt(1),Mt(-1);for(var ut=Y.length-1;ut>=0;ut--){var Wt=Y[ut];Wt.invalid&&Q3(Y,Wt)}};if(!ce)me();else return Y;var Le=function(){if(!Z){Z=Wd();for(var Lt=0;Lthz)return null;var Wt=S.makeLayer(Z,k);if(Mt!=null){var Tt=Y.indexOf(Mt)+1;Y.splice(Tt,0,Wt)}else(Lt.insert===void 0||Lt.insert)&&Y.unshift(Wt);return Wt};if(S.skipping&&!$)return null;for(var Ee=null,Be=x.length/oie,Re=!$,Ve=0;Ve=Be||!pj(Ee.bb,ct.boundingBox()))&&(Ee=_e({insert:!0,after:Ee}),!Ee))return null;ve||Re?S.queueLayer(Ee,ct):S.drawEleInLayer(Ee,ct,k,m),Ee.eles.push(ct),Ye[k]=Ee}return ve||(Re?null:Y)},n0.getEleLevelForLayerLevel=function(x,m){return x},n0.drawEleInLayer=function(x,m,k,S){var M=this,O=this.renderer,N=x.context,$=m.boundingBox();$.w===0||$.h===0||!m.visible()||(k=M.getEleLevelForLayerLevel(k,S),O.setImgSmoothing(N,!1),O.drawCachedElement(N,m,null,null,k,fz),O.setImgSmoothing(N,!0))},n0.levelIsComplete=function(x,m){var k=this,S=k.layersByLevel[x];if(!S||S.length===0)return!1;for(var M=0,O=0;O0||N.invalid)return!1;M+=N.eles.length}return M===m.length},n0.validateLayersElesOrdering=function(x,m){var k=this.layersByLevel[x];if(k)for(var S=0;S0){m=!0;break}}return m},n0.invalidateElements=function(x){var m=this;x.length!==0&&(m.lastInvalidationTime=Bp(),!(x.length===0||!m.haveLayers())&&m.updateElementsInLayers(x,function(S,M,O){m.invalidateLayer(S)}))},n0.invalidateLayer=function(x){if(this.lastInvalidationTime=Bp(),!x.invalid){var m=x.level,k=x.eles,S=this.layersByLevel[m];Q3(S,x),x.elesQueue=[],x.invalid=!0,x.replacement&&(x.replacement.invalid=!0);for(var M=0;M3&&arguments[3]!==void 0?arguments[3]:!0,M=arguments.length>4&&arguments[4]!==void 0?arguments[4]:!0,O=arguments.length>5&&arguments[5]!==void 0?arguments[5]:!0,N=this,$=m._private.rscratch;if(!(O&&!m.visible())&&!($.badLine||$.allpts==null||isNaN($.allpts[0]))){var H;k&&(H=k,x.translate(-H.x1,-H.y1));var q=O?m.pstyle("opacity").value:1,Y=O?m.pstyle("line-opacity").value:1,Z=m.pstyle("curve-style").value,ce=m.pstyle("line-style").value,ve=m.pstyle("width").pfValue,me=m.pstyle("line-cap").value,Le=q*Y,_e=q*Y,Ee=function(){var ut=arguments.length>0&&arguments[0]!==void 0?arguments[0]:Le;Z==="straight-triangle"?(N.eleStrokeStyle(x,m,ut),N.drawEdgeTrianglePath(m,x,$.allpts)):(x.lineWidth=ve,x.lineCap=me,N.eleStrokeStyle(x,m,ut),N.drawEdgePath(m,x,$.allpts,ce),x.lineCap="butt")},Be=function(){M&&N.drawEdgeOverlay(x,m)},Re=function(){M&&N.drawEdgeUnderlay(x,m)},Ve=function(){var ut=arguments.length>0&&arguments[0]!==void 0?arguments[0]:_e;N.drawArrowheads(x,m,ut)},ct=function(){N.drawElementText(x,m,null,S)};x.lineJoin="round";var st=m.pstyle("ghost").value==="yes";if(st){var Ye=m.pstyle("ghost-offset-x").pfValue,mt=m.pstyle("ghost-offset-y").pfValue,Je=m.pstyle("ghost-opacity").value,Lt=Le*Je;x.translate(Ye,mt),Ee(Lt),Ve(Lt),x.translate(-Ye,-mt)}Re(),Ee(),Ve(),Be(),ct(),k&&x.translate(H.x1,H.y1)}};var wz=function(m){if(!["overlay","underlay"].includes(m))throw new Error("Invalid state");return function(k,S){if(S.visible()){var M=S.pstyle("".concat(m,"-opacity")).value;if(M!==0){var O=this,N=O.usePaths(),$=S._private.rscratch,H=S.pstyle("".concat(m,"-padding")).pfValue,q=2*H,Y=S.pstyle("".concat(m,"-color")).value;k.lineWidth=q,$.edgeType==="self"&&!N?k.lineCap="butt":k.lineCap="round",O.colorStrokeStyle(k,Y[0],Y[1],Y[2],M),O.drawEdgePath(S,k,$.allpts,"solid")}}}};J2.drawEdgeOverlay=wz("overlay"),J2.drawEdgeUnderlay=wz("underlay"),J2.drawEdgePath=function(x,m,k,S){var M=x._private.rscratch,O=m,N,$=!1,H=this.usePaths(),q=x.pstyle("line-dash-pattern").pfValue,Y=x.pstyle("line-dash-offset").pfValue;if(H){var Z=k.join("$"),ce=M.pathCacheKey&&M.pathCacheKey===Z;ce?(N=m=M.pathCache,$=!0):(N=m=new Path2D,M.pathCacheKey=Z,M.pathCache=N)}if(O.setLineDash)switch(S){case"dotted":O.setLineDash([1,1]);break;case"dashed":O.setLineDash(q),O.lineDashOffset=Y;break;case"solid":O.setLineDash([]);break}if(!$&&!M.badLine)switch(m.beginPath&&m.beginPath(),m.moveTo(k[0],k[1]),M.edgeType){case"bezier":case"self":case"compound":case"multibezier":for(var ve=2;ve+35&&arguments[5]!==void 0?arguments[5]:!0,N=this;if(S==null){if(O&&!N.eleTextBiggerThanMin(m))return}else if(S===!1)return;if(m.isNode()){var $=m.pstyle("label");if(!$||!$.value)return;var H=N.getLabelJustification(m);x.textAlign=H,x.textBaseline="bottom"}else{var q=m.element()._private.rscratch.badLine,Y=m.pstyle("label"),Z=m.pstyle("source-label"),ce=m.pstyle("target-label");if(q||(!Y||!Y.value)&&(!Z||!Z.value)&&(!ce||!ce.value))return;x.textAlign="center",x.textBaseline="bottom"}var ve=!k,me;k&&(me=k,x.translate(-me.x1,-me.y1)),M==null?(N.drawText(x,m,null,ve,O),m.isEdge()&&(N.drawText(x,m,"source",ve,O),N.drawText(x,m,"target",ve,O))):N.drawText(x,m,M,ve,O),k&&x.translate(me.x1,me.y1)},y5.getFontCache=function(x){var m;this.fontCaches=this.fontCaches||[];for(var k=0;k2&&arguments[2]!==void 0?arguments[2]:!0,S=m.pstyle("font-style").strValue,M=m.pstyle("font-size").pfValue+"px",O=m.pstyle("font-family").strValue,N=m.pstyle("font-weight").strValue,$=k?m.effectiveOpacity()*m.pstyle("text-opacity").value:1,H=m.pstyle("text-outline-opacity").value*$,q=m.pstyle("color").value,Y=m.pstyle("text-outline-color").value;x.font=S+" "+N+" "+M+" "+O,x.lineJoin="round",this.colorFillStyle(x,q[0],q[1],q[2],$),this.colorStrokeStyle(x,Y[0],Y[1],Y[2],H)};function zI(x,m,k,S,M){var O=arguments.length>5&&arguments[5]!==void 0?arguments[5]:5,N=arguments.length>6?arguments[6]:void 0;x.beginPath(),x.moveTo(m+O,k),x.lineTo(m+S-O,k),x.quadraticCurveTo(m+S,k,m+S,k+O),x.lineTo(m+S,k+M-O),x.quadraticCurveTo(m+S,k+M,m+S-O,k+M),x.lineTo(m+O,k+M),x.quadraticCurveTo(m,k+M,m,k+M-O),x.lineTo(m,k+O),x.quadraticCurveTo(m,k,m+O,k),x.closePath(),N?x.stroke():x.fill()}y5.getTextAngle=function(x,m){var k,S=x._private,M=S.rscratch,O=m?m+"-":"",N=x.pstyle(O+"text-rotation"),$=K2(M,"labelAngle",m);return N.strValue==="autorotate"?k=x.isEdge()?$:0:N.strValue==="none"?k=0:k=N.pfValue,k},y5.drawText=function(x,m,k){var S=arguments.length>3&&arguments[3]!==void 0?arguments[3]:!0,M=arguments.length>4&&arguments[4]!==void 0?arguments[4]:!0,O=m._private,N=O.rscratch,$=M?m.effectiveOpacity():1;if(!(M&&($===0||m.pstyle("text-opacity").value===0))){k==="main"&&(k=null);var H=K2(N,"labelX",k),q=K2(N,"labelY",k),Y,Z,ce=this.getLabelText(m,k);if(ce!=null&&ce!==""&&!isNaN(H)&&!isNaN(q)){this.setupTextStyle(x,m,M);var ve=k?k+"-":"",me=K2(N,"labelWidth",k),Le=K2(N,"labelHeight",k),_e=m.pstyle(ve+"text-margin-x").pfValue,Ee=m.pstyle(ve+"text-margin-y").pfValue,Be=m.isEdge(),Re=m.pstyle("text-halign").value,Ve=m.pstyle("text-valign").value;Be&&(Re="center",Ve="center"),H+=_e,q+=Ee;var ct;switch(S?ct=this.getTextAngle(m,k):ct=0,ct!==0&&(Y=H,Z=q,x.translate(Y,Z),x.rotate(ct),H=0,q=0),Ve){case"top":break;case"center":q+=Le/2;break;case"bottom":q+=Le;break}var st=m.pstyle("text-background-opacity").value,Ye=m.pstyle("text-border-opacity").value,mt=m.pstyle("text-border-width").pfValue,Je=m.pstyle("text-background-padding").pfValue,Lt=m.pstyle("text-background-shape").strValue,Mt=Lt.indexOf("round")===0,ut=2;if(st>0||mt>0&&Ye>0){var Wt=H-Je;switch(Re){case"left":Wt-=me;break;case"center":Wt-=me/2;break}var Tt=q-Le-Je,_n=me+2*Je,hn=Le+2*Je;if(st>0){var Yt=x.fillStyle,Dn=m.pstyle("text-background-color").value;x.fillStyle="rgba("+Dn[0]+","+Dn[1]+","+Dn[2]+","+st*$+")",Mt?zI(x,Wt,Tt,_n,hn,ut):x.fillRect(Wt,Tt,_n,hn),x.fillStyle=Yt}if(mt>0&&Ye>0){var ir=x.strokeStyle,vr=x.lineWidth,Nn=m.pstyle("text-border-color").value,pr=m.pstyle("text-border-style").value;if(x.strokeStyle="rgba("+Nn[0]+","+Nn[1]+","+Nn[2]+","+Ye*$+")",x.lineWidth=mt,x.setLineDash)switch(pr){case"dotted":x.setLineDash([1,1]);break;case"dashed":x.setLineDash([4,2]);break;case"double":x.lineWidth=mt/4,x.setLineDash([]);break;case"solid":x.setLineDash([]);break}if(Mt?zI(x,Wt,Tt,_n,hn,ut,"stroke"):x.strokeRect(Wt,Tt,_n,hn),pr==="double"){var Er=mt/2;Mt?zI(x,Wt+Er,Tt+Er,_n-Er*2,hn-Er*2,ut,"stroke"):x.strokeRect(Wt+Er,Tt+Er,_n-Er*2,hn-Er*2)}x.setLineDash&&x.setLineDash([]),x.lineWidth=vr,x.strokeStyle=ir}}var Mr=2*m.pstyle("text-outline-width").pfValue;if(Mr>0&&(x.lineWidth=Mr),m.pstyle("text-wrap").value==="wrap"){var Cr=K2(N,"labelWrapCachedLines",k),Or=K2(N,"labelLineHeight",k),Wn=me/2,br=this.getLabelJustification(m);switch(br==="auto"||(Re==="left"?br==="left"?H+=-me:br==="center"&&(H+=-Wn):Re==="center"?br==="left"?H+=-Wn:br==="right"&&(H+=Wn):Re==="right"&&(br==="center"?H+=Wn:br==="right"&&(H+=me))),Ve){case"top":q-=(Cr.length-1)*Or;break;case"center":case"bottom":q-=(Cr.length-1)*Or;break}for(var Sr=0;Sr0&&x.strokeText(Cr[Sr],H,q),x.fillText(Cr[Sr],H,q),q+=Or}else Mr>0&&x.strokeText(ce,H,q),x.fillText(ce,H,q);ct!==0&&(x.rotate(-ct),x.translate(-Y,-Z))}}};var w8={};w8.drawNode=function(x,m,k){var S=arguments.length>3&&arguments[3]!==void 0?arguments[3]:!0,M=arguments.length>4&&arguments[4]!==void 0?arguments[4]:!0,O=arguments.length>5&&arguments[5]!==void 0?arguments[5]:!0,N=this,$,H,q=m._private,Y=q.rscratch,Z=m.position();if(!(!X(Z.x)||!X(Z.y))&&!(O&&!m.visible())){var ce=O?m.effectiveOpacity():1,ve=N.usePaths(),me,Le=!1,_e=m.padding();$=m.width()+2*_e,H=m.height()+2*_e;var Ee;k&&(Ee=k,x.translate(-Ee.x1,-Ee.y1));for(var Be=m.pstyle("background-image"),Re=Be.value,Ve=new Array(Re.length),ct=new Array(Re.length),st=0,Ye=0;Ye0&&arguments[0]!==void 0?arguments[0]:Wt;N.eleFillStyle(x,m,tr)},Er=function(){var tr=arguments.length>0&&arguments[0]!==void 0?arguments[0]:hn;N.colorStrokeStyle(x,Tt[0],Tt[1],Tt[2],tr)},Mr=function(){var tr=arguments.length>0&&arguments[0]!==void 0?arguments[0]:vr;N.colorStrokeStyle(x,Dn[0],Dn[1],Dn[2],tr)},Cr=function(tr,G,Jn,kr){var lr=N.nodePathCache=N.nodePathCache||[],Vt=ld(Jn==="polygon"?Jn+","+kr.join(","):Jn,""+G,""+tr),Hs=lr[Vt],wr,Es=!1;return Hs!=null?(wr=Hs,Es=!0,Y.pathCache=wr):(wr=new Path2D,lr[Vt]=Y.pathCache=wr),{path:wr,cacheHit:Es}},Or=m.pstyle("shape").strValue,Wn=m.pstyle("shape-polygon-points").pfValue;if(ve){x.translate(Z.x,Z.y);var br=Cr($,H,Or,Wn);me=br.path,Le=br.cacheHit}var Sr=function(){if(!Le){var tr=Z;ve&&(tr={x:0,y:0}),N.nodeShapes[N.getNodeShape(m)].draw(me||x,tr.x,tr.y,$,H)}ve?x.fill(me):x.fill()},Nr=function(){for(var tr=arguments.length>0&&arguments[0]!==void 0?arguments[0]:ce,G=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!0,Jn=q.backgrounding,kr=0,lr=0;lr0&&arguments[0]!==void 0?arguments[0]:!1,G=arguments.length>1&&arguments[1]!==void 0?arguments[1]:ce;N.hasPie(m)&&(N.drawPie(x,m,G),tr&&(ve||N.nodeShapes[N.getNodeShape(m)].draw(x,Z.x,Z.y,$,H)))},ys=function(){var tr=arguments.length>0&&arguments[0]!==void 0?arguments[0]:ce,G=(Mt>0?Mt:-Mt)*tr,Jn=Mt>0?0:255;Mt!==0&&(N.colorFillStyle(x,Jn,Jn,Jn,G),ve?x.fill(me):x.fill())},pa=function(){if(ut>0){if(x.lineWidth=ut,x.lineCap="butt",x.setLineDash)switch(_n){case"dotted":x.setLineDash([1,1]);break;case"dashed":x.setLineDash([4,2]);break;case"solid":case"double":x.setLineDash([]);break}if(ve?x.stroke(me):x.stroke(),_n==="double"){x.lineWidth=ut/3;var tr=x.globalCompositeOperation;x.globalCompositeOperation="destination-out",ve?x.stroke(me):x.stroke(),x.globalCompositeOperation=tr}x.setLineDash&&x.setLineDash([])}},Mi=function(){if(Yt>0){if(x.lineWidth=Yt,x.lineCap="butt",x.setLineDash)switch(ir){case"dotted":x.setLineDash([1,1]);break;case"dashed":x.setLineDash([4,2]);break;case"solid":case"double":x.setLineDash([]);break}var tr=Z;ve&&(tr={x:0,y:0});var G=N.getNodeShape(m),Jn=($+ut+(Yt+Nn))/$,kr=(H+ut+(Yt+Nn))/H,lr=$*Jn,Vt=H*kr,Hs=N.nodeShapes[G].points,wr;if(ve){var Es=Cr(lr,Vt,G,Hs);wr=Es.path}if(G==="ellipse")N.drawEllipsePath(wr||x,tr.x,tr.y,lr,Vt);else if(["round-diamond","round-heptagon","round-hexagon","round-octagon","round-pentagon","round-polygon","round-triangle","round-tag"].includes(G)){var go=0,$c=0,za=0;G==="round-diamond"?go=(ut+Nn+Yt)*1.4:G==="round-heptagon"?(go=(ut+Nn+Yt)*1.075,za=-(ut/2+Nn+Yt)/35):G==="round-hexagon"?go=(ut+Nn+Yt)*1.12:G==="round-pentagon"?(go=(ut+Nn+Yt)*1.13,za=-(ut/2+Nn+Yt)/15):G==="round-tag"?(go=(ut+Nn+Yt)*1.12,$c=(ut/2+Yt+Nn)*.07):G==="round-triangle"&&(go=(ut+Nn+Yt)*(Math.PI/2),za=-(ut+Nn/2+Yt)/Math.PI),go!==0&&(Jn=($+go)/$,kr=(H+go)/H),N.drawRoundPolygonPath(wr||x,tr.x+$c,tr.y+za,$*Jn,H*kr,Hs)}else if(["roundrectangle","round-rectangle"].includes(G))N.drawRoundRectanglePath(wr||x,tr.x,tr.y,lr,Vt);else if(["cutrectangle","cut-rectangle"].includes(G))N.drawCutRectanglePath(wr||x,tr.x,tr.y,lr,Vt);else if(["bottomroundrectangle","bottom-round-rectangle"].includes(G))N.drawBottomRoundRectanglePath(wr||x,tr.x,tr.y,lr,Vt);else if(G==="barrel")N.drawBarrelPath(wr||x,tr.x,tr.y,lr,Vt);else if(G.startsWith("polygon")||["rhomboid","right-rhomboid","round-tag","tag","vee"].includes(G)){var Sc=(ut+Yt+Nn)/$;Hs=gS(pS(Hs,Sc)),N.drawPolygonPath(wr||x,tr.x,tr.y,$,H,Hs)}else{var ba=(ut+Yt+Nn)/$;Hs=gS(pS(Hs,-ba)),N.drawPolygonPath(wr||x,tr.x,tr.y,$,H,Hs)}if(ve?x.stroke(wr):x.stroke(),ir==="double"){x.lineWidth=ut/3;var xo=x.globalCompositeOperation;x.globalCompositeOperation="destination-out",ve?x.stroke(wr):x.stroke(),x.globalCompositeOperation=xo}x.setLineDash&&x.setLineDash([])}},gi=function(){M&&N.drawNodeOverlay(x,m,Z,$,H)},fs=function(){M&&N.drawNodeUnderlay(x,m,Z,$,H)},Fs=function(){N.drawElementText(x,m,null,S)},xs=m.pstyle("ghost").value==="yes";if(xs){var Rs=m.pstyle("ghost-offset-x").pfValue,yo=m.pstyle("ghost-offset-y").pfValue,$a=m.pstyle("ghost-opacity").value,Da=$a*ce;x.translate(Rs,yo),Mr(),Mi(),pr($a*Wt),Sr(),Nr(Da,!0),Er($a*hn),pa(),Si(Mt!==0||ut!==0),Nr(Da,!1),ys(Da),x.translate(-Rs,-yo)}ve&&x.translate(-Z.x,-Z.y),fs(),ve&&x.translate(Z.x,Z.y),Mr(),Mi(),pr(),Sr(),Nr(ce,!0),Er(),pa(),Si(Mt!==0||ut!==0),Nr(ce,!1),ys(),ve&&x.translate(-Z.x,-Z.y),Fs(),gi(),k&&x.translate(Ee.x1,Ee.y1)}};var qI=function(m){if(!["overlay","underlay"].includes(m))throw new Error("Invalid state");return function(k,S,M,O,N){var $=this;if(S.visible()){var H=S.pstyle("".concat(m,"-padding")).pfValue,q=S.pstyle("".concat(m,"-opacity")).value,Y=S.pstyle("".concat(m,"-color")).value,Z=S.pstyle("".concat(m,"-shape")).value;if(q>0){if(M=M||S.position(),O==null||N==null){var ce=S.padding();O=S.width()+2*ce,N=S.height()+2*ce}$.colorFillStyle(k,Y[0],Y[1],Y[2],q),$.nodeShapes[Z].draw(k,M.x,M.y,O+H*2,N+H*2),k.fill()}}}};w8.drawNodeOverlay=qI("overlay"),w8.drawNodeUnderlay=qI("underlay"),w8.hasPie=function(x){return x=x[0],x._private.hasPie},w8.drawPie=function(x,m,k,S){m=m[0],S=S||m.position();var M=m.cy().style(),O=m.pstyle("pie-size"),N=S.x,$=S.y,H=m.width(),q=m.height(),Y=Math.min(H,q)/2,Z=0,ce=this.usePaths();ce&&(N=0,$=0),O.units==="%"?Y=Y*O.pfValue:O.pfValue!==void 0&&(Y=O.pfValue/2);for(var ve=1;ve<=M.pieBackgroundN;ve++){var me=m.pstyle("pie-"+ve+"-background-size").value,Le=m.pstyle("pie-"+ve+"-background-color").value,_e=m.pstyle("pie-"+ve+"-background-opacity").value*k,Ee=me/100;Ee+Z>1&&(Ee=1-Z);var Be=1.5*Math.PI+2*Math.PI*Z,Re=2*Math.PI*Ee,Ve=Be+Re;me===0||Z>=1||Z+Ee>1||(x.beginPath(),x.moveTo(N,$),x.arc(N,$,Y,Be,Ve),x.closePath(),this.colorFillStyle(x,Le[0],Le[1],Le[2],_e),x.fill(),Z+=Ee)}};var qg={},xie=100;qg.getPixelRatio=function(){var x=this.data.contexts[0];if(this.forcedPixelRatio!=null)return this.forcedPixelRatio;var m=x.backingStorePixelRatio||x.webkitBackingStorePixelRatio||x.mozBackingStorePixelRatio||x.msBackingStorePixelRatio||x.oBackingStorePixelRatio||x.backingStorePixelRatio||1;return(window.devicePixelRatio||1)/m},qg.paintCache=function(x){for(var m=this.paintCaches=this.paintCaches||[],k=!0,S,M=0;MN.minMbLowQualFrames&&(N.motionBlurPxRatio=N.mbPxRBlurry)),N.clearingMotionBlur&&(N.motionBlurPxRatio=1),N.textureDrawLastFrame&&!Z&&(Y[N.NODE]=!0,Y[N.SELECT_BOX]=!0);var Be=H.style(),Re=H.zoom(),Ve=M!==void 0?M:Re,ct=H.pan(),st={x:ct.x,y:ct.y},Ye={zoom:Re,pan:{x:ct.x,y:ct.y}},mt=N.prevViewport,Je=mt===void 0||Ye.zoom!==mt.zoom||Ye.pan.x!==mt.pan.x||Ye.pan.y!==mt.pan.y;!Je&&!(Le&&!me)&&(N.motionBlurPxRatio=1),O&&(st=O),Ve*=$,st.x*=$,st.y*=$;var Lt=N.getCachedZSortedEles();function Mt(Mi,gi,fs,Fs,xs){var Rs=Mi.globalCompositeOperation;Mi.globalCompositeOperation="destination-out",N.colorFillStyle(Mi,255,255,255,N.motionBlurTransparency),Mi.fillRect(gi,fs,Fs,xs),Mi.globalCompositeOperation=Rs}function ut(Mi,gi){var fs,Fs,xs,Rs;!N.clearingMotionBlur&&(Mi===q.bufferContexts[N.MOTIONBLUR_BUFFER_NODE]||Mi===q.bufferContexts[N.MOTIONBLUR_BUFFER_DRAG])?(fs={x:ct.x*ve,y:ct.y*ve},Fs=Re*ve,xs=N.canvasWidth*ve,Rs=N.canvasHeight*ve):(fs=st,Fs=Ve,xs=N.canvasWidth,Rs=N.canvasHeight),Mi.setTransform(1,0,0,1,0,0),gi==="motionBlur"?Mt(Mi,0,0,xs,Rs):!m&&(gi===void 0||gi)&&Mi.clearRect(0,0,xs,Rs),k||(Mi.translate(fs.x,fs.y),Mi.scale(Fs,Fs)),O&&Mi.translate(O.x,O.y),M&&Mi.scale(M,M)}if(Z||(N.textureDrawLastFrame=!1),Z){if(N.textureDrawLastFrame=!0,!N.textureCache){N.textureCache={},N.textureCache.bb=H.mutableElements().boundingBox(),N.textureCache.texture=N.data.bufferCanvases[N.TEXTURE_BUFFER];var Wt=N.data.bufferContexts[N.TEXTURE_BUFFER];Wt.setTransform(1,0,0,1,0,0),Wt.clearRect(0,0,N.canvasWidth*N.textureMult,N.canvasHeight*N.textureMult),N.render({forcedContext:Wt,drawOnlyNodeLayer:!0,forcedPxRatio:$*N.textureMult});var Ye=N.textureCache.viewport={zoom:H.zoom(),pan:H.pan(),width:N.canvasWidth,height:N.canvasHeight};Ye.mpan={x:(0-Ye.pan.x)/Ye.zoom,y:(0-Ye.pan.y)/Ye.zoom}}Y[N.DRAG]=!1,Y[N.NODE]=!1;var Tt=q.contexts[N.NODE],_n=N.textureCache.texture,Ye=N.textureCache.viewport;Tt.setTransform(1,0,0,1,0,0),ce?Mt(Tt,0,0,Ye.width,Ye.height):Tt.clearRect(0,0,Ye.width,Ye.height);var hn=Be.core("outside-texture-bg-color").value,Yt=Be.core("outside-texture-bg-opacity").value;N.colorFillStyle(Tt,hn[0],hn[1],hn[2],Yt),Tt.fillRect(0,0,Ye.width,Ye.height);var Re=H.zoom();ut(Tt,!1),Tt.clearRect(Ye.mpan.x,Ye.mpan.y,Ye.width/Ye.zoom/$,Ye.height/Ye.zoom/$),Tt.drawImage(_n,Ye.mpan.x,Ye.mpan.y,Ye.width/Ye.zoom/$,Ye.height/Ye.zoom/$)}else N.textureOnViewport&&!m&&(N.textureCache=null);var Dn=H.extent(),ir=N.pinching||N.hoverData.dragging||N.swipePanning||N.data.wheelZooming||N.hoverData.draggingEles||N.cy.animated(),vr=N.hideEdgesOnViewport&&ir,Nn=[];if(Nn[N.NODE]=!Y[N.NODE]&&ce&&!N.clearedForMotionBlur[N.NODE]||N.clearingMotionBlur,Nn[N.NODE]&&(N.clearedForMotionBlur[N.NODE]=!0),Nn[N.DRAG]=!Y[N.DRAG]&&ce&&!N.clearedForMotionBlur[N.DRAG]||N.clearingMotionBlur,Nn[N.DRAG]&&(N.clearedForMotionBlur[N.DRAG]=!0),Y[N.NODE]||k||S||Nn[N.NODE]){var pr=ce&&!Nn[N.NODE]&&ve!==1,Tt=m||(pr?N.data.bufferContexts[N.MOTIONBLUR_BUFFER_NODE]:q.contexts[N.NODE]),Er=ce&&!pr?"motionBlur":void 0;ut(Tt,Er),vr?N.drawCachedNodes(Tt,Lt.nondrag,$,Dn):N.drawLayeredElements(Tt,Lt.nondrag,$,Dn),N.debug&&N.drawDebugPoints(Tt,Lt.nondrag),!k&&!ce&&(Y[N.NODE]=!1)}if(!S&&(Y[N.DRAG]||k||Nn[N.DRAG])){var pr=ce&&!Nn[N.DRAG]&&ve!==1,Tt=m||(pr?N.data.bufferContexts[N.MOTIONBLUR_BUFFER_DRAG]:q.contexts[N.DRAG]);ut(Tt,ce&&!pr?"motionBlur":void 0),vr?N.drawCachedNodes(Tt,Lt.drag,$,Dn):N.drawCachedElements(Tt,Lt.drag,$,Dn),N.debug&&N.drawDebugPoints(Tt,Lt.drag),!k&&!ce&&(Y[N.DRAG]=!1)}if(N.showFps||!S&&Y[N.SELECT_BOX]&&!k){var Tt=m||q.contexts[N.SELECT_BOX];if(ut(Tt),N.selection[4]==1&&(N.hoverData.selecting||N.touchData.selecting)){var Re=N.cy.zoom(),Mr=Be.core("selection-box-border-width").value/Re;Tt.lineWidth=Mr,Tt.fillStyle="rgba("+Be.core("selection-box-color").value[0]+","+Be.core("selection-box-color").value[1]+","+Be.core("selection-box-color").value[2]+","+Be.core("selection-box-opacity").value+")",Tt.fillRect(N.selection[0],N.selection[1],N.selection[2]-N.selection[0],N.selection[3]-N.selection[1]),Mr>0&&(Tt.strokeStyle="rgba("+Be.core("selection-box-border-color").value[0]+","+Be.core("selection-box-border-color").value[1]+","+Be.core("selection-box-border-color").value[2]+","+Be.core("selection-box-opacity").value+")",Tt.strokeRect(N.selection[0],N.selection[1],N.selection[2]-N.selection[0],N.selection[3]-N.selection[1]))}if(q.bgActivePosistion&&!N.hoverData.selecting){var Re=N.cy.zoom(),Cr=q.bgActivePosistion;Tt.fillStyle="rgba("+Be.core("active-bg-color").value[0]+","+Be.core("active-bg-color").value[1]+","+Be.core("active-bg-color").value[2]+","+Be.core("active-bg-opacity").value+")",Tt.beginPath(),Tt.arc(Cr.x,Cr.y,Be.core("active-bg-size").pfValue/Re,0,2*Math.PI),Tt.fill()}var Or=N.lastRedrawTime;if(N.showFps&&Or){Or=Math.round(Or);var Wn=Math.round(1e3/Or);Tt.setTransform(1,0,0,1,0,0),Tt.fillStyle="rgba(255, 0, 0, 0.75)",Tt.strokeStyle="rgba(255, 0, 0, 0.75)",Tt.lineWidth=1,Tt.fillText("1 frame = "+Or+" ms = "+Wn+" fps",0,20);var br=60;Tt.strokeRect(0,30,250,20),Tt.fillRect(0,30,250*Math.min(Wn/br,1),20)}k||(Y[N.SELECT_BOX]=!1)}if(ce&&ve!==1){var Sr=q.contexts[N.NODE],Nr=N.data.bufferCanvases[N.MOTIONBLUR_BUFFER_NODE],Si=q.contexts[N.DRAG],ys=N.data.bufferCanvases[N.MOTIONBLUR_BUFFER_DRAG],pa=function(gi,fs,Fs){gi.setTransform(1,0,0,1,0,0),Fs||!Ee?gi.clearRect(0,0,N.canvasWidth,N.canvasHeight):Mt(gi,0,0,N.canvasWidth,N.canvasHeight);var xs=ve;gi.drawImage(fs,0,0,N.canvasWidth*xs,N.canvasHeight*xs,0,0,N.canvasWidth,N.canvasHeight)};(Y[N.NODE]||Nn[N.NODE])&&(pa(Sr,Nr,Nn[N.NODE]),Y[N.NODE]=!1),(Y[N.DRAG]||Nn[N.DRAG])&&(pa(Si,ys,Nn[N.DRAG]),Y[N.DRAG]=!1)}N.prevViewport=Ye,N.clearingMotionBlur&&(N.clearingMotionBlur=!1,N.motionBlurCleared=!0,N.motionBlur=!0),ce&&(N.motionBlurTimeout=setTimeout(function(){N.motionBlurTimeout=null,N.clearedForMotionBlur[N.NODE]=!1,N.clearedForMotionBlur[N.DRAG]=!1,N.motionBlur=!1,N.clearingMotionBlur=!Z,N.mbFrames=0,Y[N.NODE]=!0,Y[N.DRAG]=!0,N.redraw()},xie)),m||H.emit("render")};var iy={};iy.drawPolygonPath=function(x,m,k,S,M,O){var N=S/2,$=M/2;x.beginPath&&x.beginPath(),x.moveTo(m+N*O[0],k+$*O[1]);for(var H=1;H0&&N>0){ve.clearRect(0,0,O,N),ve.globalCompositeOperation="source-over";var me=this.getCachedZSortedEles();if(x.full)ve.translate(-S.x1*q,-S.y1*q),ve.scale(q,q),this.drawElements(ve,me),ve.scale(1/q,1/q),ve.translate(S.x1*q,S.y1*q);else{var Le=m.pan(),_e={x:Le.x*q,y:Le.y*q};q*=m.zoom(),ve.translate(_e.x,_e.y),ve.scale(q,q),this.drawElements(ve,me),ve.scale(1/q,1/q),ve.translate(-_e.x,-_e.y)}x.bg&&(ve.globalCompositeOperation="destination-over",ve.fillStyle=x.bg,ve.rect(0,0,O,N),ve.fill())}return ce};function kie(x,m){for(var k=atob(x),S=new ArrayBuffer(k.length),M=new Uint8Array(S),O=0;O"u"?"undefined":u(OffscreenCanvas))!=="undefined"?k=new OffscreenCanvas(x,m):(k=document.createElement("canvas"),k.width=x,k.height=m),k},[pz,Q2,J2,bk,y5,w8,qg,iy,mk,Cz].forEach(function(x){yt(jc,x)});var $p=[{name:"null",impl:W$},{name:"base",impl:az},{name:"canvas",impl:Sz}],Eie=[{type:"layout",extensions:qre},{type:"renderer",extensions:$p}],Tie={},Cie={};function Sie(x,m,k){var S=k,M=function(mt){hu("Can not register `"+m+"` for `"+x+"` since `"+mt+"` already exists in the prototype and can not be overridden")};if(x==="core"){if(lk.prototype[m])return M(m);lk.prototype[m]=k}else if(x==="collection"){if(V0.prototype[m])return M(m);V0.prototype[m]=k}else if(x==="layout"){for(var O=function(mt){this.options=mt,k.call(this,mt),se(this._private)||(this._private={}),this._private.cy=mt.cy,this._private.listeners=[],this.createEmitter()},N=O.prototype=Object.create(k.prototype),$=[],H=0;H<$.length;H++){var q=$[H];N[q]=N[q]||function(){return this}}N.start&&!N.run?N.run=function(){return this.start(),this}:!N.start&&N.run&&(N.start=function(){return this.run(),this});var Y=k.prototype.stop;N.stop=function(){var Ye=this.options;if(Ye&&Ye.animate){var mt=this.animations;if(mt)for(var Je=0;Jej&&(this.rect.x-=(this.labelWidth-j)/2,this.setWidth(this.labelWidth)),this.labelHeight>K&&(this.labelPos=="center"?this.rect.y-=(this.labelHeight-K)/2:this.labelPos=="top"&&(this.rect.y-=this.labelHeight-K),this.setHeight(this.labelHeight))}}},P.prototype.getInclusionTreeDepth=function(){if(this.inclusionTreeDepth==b.MAX_VALUE)throw"assert failed";return this.inclusionTreeDepth},P.prototype.transform=function(F){var j=this.rect.x;j>T.WORLD_BOUNDARY?j=T.WORLD_BOUNDARY:j<-T.WORLD_BOUNDARY&&(j=-T.WORLD_BOUNDARY);var K=this.rect.y;K>T.WORLD_BOUNDARY?K=T.WORLD_BOUNDARY:K<-T.WORLD_BOUNDARY&&(K=-T.WORLD_BOUNDARY);var ee=new A(j,K),ie=F.inverseTransformPoint(ee);this.setLocation(ie.x,ie.y)},P.prototype.getLeft=function(){return this.rect.x},P.prototype.getRight=function(){return this.rect.x+this.rect.width},P.prototype.getTop=function(){return this.rect.y},P.prototype.getBottom=function(){return this.rect.y+this.rect.height},P.prototype.getParent=function(){return this.owner==null?null:this.owner.getParent()},u.exports=P},function(u,d,p){function v(b,y){b==null&&y==null?(this.x=0,this.y=0):(this.x=b,this.y=y)}v.prototype.getX=function(){return this.x},v.prototype.getY=function(){return this.y},v.prototype.setX=function(b){this.x=b},v.prototype.setY=function(b){this.y=b},v.prototype.getDifference=function(b){return new DimensionD(this.x-b.x,this.y-b.y)},v.prototype.getCopy=function(){return new v(this.x,this.y)},v.prototype.translate=function(b){return this.x+=b.width,this.y+=b.height,this},u.exports=v},function(u,d,p){var v=p(2),b=p(10),y=p(0),T=p(6),_=p(3),A=p(1),P=p(13),R=p(12),F=p(11);function j(ee,ie,oe){v.call(this,oe),this.estimatedSize=b.MIN_VALUE,this.margin=y.DEFAULT_GRAPH_MARGIN,this.edges=[],this.nodes=[],this.isConnected=!1,this.parent=ee,ie!=null&&ie instanceof T?this.graphManager=ie:ie!=null&&ie instanceof Layout&&(this.graphManager=ie.graphManager)}j.prototype=Object.create(v.prototype);for(var K in v)j[K]=v[K];j.prototype.getNodes=function(){return this.nodes},j.prototype.getEdges=function(){return this.edges},j.prototype.getGraphManager=function(){return this.graphManager},j.prototype.getParent=function(){return this.parent},j.prototype.getLeft=function(){return this.left},j.prototype.getRight=function(){return this.right},j.prototype.getTop=function(){return this.top},j.prototype.getBottom=function(){return this.bottom},j.prototype.isConnected=function(){return this.isConnected},j.prototype.add=function(ee,ie,oe){if(ie==null&&oe==null){var pe=ee;if(this.graphManager==null)throw"Graph has no graph mgr!";if(this.getNodes().indexOf(pe)>-1)throw"Node already in graph!";return pe.owner=this,this.getNodes().push(pe),pe}else{var be=ee;if(!(this.getNodes().indexOf(ie)>-1&&this.getNodes().indexOf(oe)>-1))throw"Source or target not in graph!";if(!(ie.owner==oe.owner&&ie.owner==this))throw"Both owners must be this graph!";return ie.owner!=oe.owner?null:(be.source=ie,be.target=oe,be.isInterGraph=!1,this.getEdges().push(be),ie.edges.push(be),oe!=ie&&oe.edges.push(be),be)}},j.prototype.remove=function(ee){var ie=ee;if(ee instanceof _){if(ie==null)throw"Node is null!";if(!(ie.owner!=null&&ie.owner==this))throw"Owner graph is invalid!";if(this.graphManager==null)throw"Owner graph manager is invalid!";for(var oe=ie.edges.slice(),pe,be=oe.length,ae=0;ae-1&&de>-1))throw"Source and/or target doesn't know this edge!";pe.source.edges.splice(se,1),pe.target!=pe.source&&pe.target.edges.splice(de,1);var ne=pe.source.owner.getEdges().indexOf(pe);if(ne==-1)throw"Not in owner's edge list!";pe.source.owner.getEdges().splice(ne,1)}},j.prototype.updateLeftTop=function(){for(var ee=b.MAX_VALUE,ie=b.MAX_VALUE,oe,pe,be,ae=this.getNodes(),ne=ae.length,se=0;seoe&&(ee=oe),ie>pe&&(ie=pe)}return ee==b.MAX_VALUE?null:(ae[0].getParent().paddingLeft!=null?be=ae[0].getParent().paddingLeft:be=this.margin,this.left=ie-be,this.top=ee-be,new R(this.left,this.top))},j.prototype.updateBounds=function(ee){for(var ie=b.MAX_VALUE,oe=-b.MAX_VALUE,pe=b.MAX_VALUE,be=-b.MAX_VALUE,ae,ne,se,de,X,ge=this.nodes,W=ge.length,xe=0;xeae&&(ie=ae),oese&&(pe=se),beae&&(ie=ae),oese&&(pe=se),be=this.nodes.length){var W=0;oe.forEach(function(xe){xe.owner==ee&&W++}),W==this.nodes.length&&(this.isConnected=!0)}},u.exports=j},function(u,d,p){var v,b=p(1);function y(T){v=p(5),this.layout=T,this.graphs=[],this.edges=[]}y.prototype.addRoot=function(){var T=this.layout.newGraph(),_=this.layout.newNode(null),A=this.add(T,_);return this.setRootGraph(A),this.rootGraph},y.prototype.add=function(T,_,A,P,R){if(A==null&&P==null&&R==null){if(T==null)throw"Graph is null!";if(_==null)throw"Parent node is null!";if(this.graphs.indexOf(T)>-1)throw"Graph already in this graph mgr!";if(this.graphs.push(T),T.parent!=null)throw"Already has a parent!";if(_.child!=null)throw"Already has a child!";return T.parent=_,_.child=T,T}else{R=A,P=_,A=T;var F=P.getOwner(),j=R.getOwner();if(!(F!=null&&F.getGraphManager()==this))throw"Source not in this graph mgr!";if(!(j!=null&&j.getGraphManager()==this))throw"Target not in this graph mgr!";if(F==j)return A.isInterGraph=!1,F.add(A,P,R);if(A.isInterGraph=!0,A.source=P,A.target=R,this.edges.indexOf(A)>-1)throw"Edge already in inter-graph edge list!";if(this.edges.push(A),!(A.source!=null&&A.target!=null))throw"Edge source and/or target is null!";if(!(A.source.edges.indexOf(A)==-1&&A.target.edges.indexOf(A)==-1))throw"Edge already in source and/or target incidency list!";return A.source.edges.push(A),A.target.edges.push(A),A}},y.prototype.remove=function(T){if(T instanceof v){var _=T;if(_.getGraphManager()!=this)throw"Graph not in this graph mgr";if(!(_==this.rootGraph||_.parent!=null&&_.parent.graphManager==this))throw"Invalid parent node!";var A=[];A=A.concat(_.getEdges());for(var P,R=A.length,F=0;F=T.getRight()?_[0]+=Math.min(T.getX()-y.getX(),y.getRight()-T.getRight()):T.getX()<=y.getX()&&T.getRight()>=y.getRight()&&(_[0]+=Math.min(y.getX()-T.getX(),T.getRight()-y.getRight())),y.getY()<=T.getY()&&y.getBottom()>=T.getBottom()?_[1]+=Math.min(T.getY()-y.getY(),y.getBottom()-T.getBottom()):T.getY()<=y.getY()&&T.getBottom()>=y.getBottom()&&(_[1]+=Math.min(y.getY()-T.getY(),T.getBottom()-y.getBottom()));var R=Math.abs((T.getCenterY()-y.getCenterY())/(T.getCenterX()-y.getCenterX()));T.getCenterY()===y.getCenterY()&&T.getCenterX()===y.getCenterX()&&(R=1);var F=R*_[0],j=_[1]/R;_[0]F)return _[0]=A,_[1]=K,_[2]=R,_[3]=ge,!1;if(PR)return _[0]=j,_[1]=P,_[2]=de,_[3]=F,!1;if(AR?(_[0]=ie,_[1]=oe,Fe=!0):(_[0]=ee,_[1]=K,Fe=!0):je===Se&&(A>R?(_[0]=j,_[1]=K,Fe=!0):(_[0]=pe,_[1]=oe,Fe=!0)),-Ie===Se?R>A?(_[2]=X,_[3]=ge,Pe=!0):(_[2]=de,_[3]=se,Pe=!0):Ie===Se&&(R>A?(_[2]=ne,_[3]=se,Pe=!0):(_[2]=W,_[3]=ge,Pe=!0)),Fe&&Pe)return!1;if(A>R?P>F?(Ce=this.getCardinalDirection(je,Se,4),ke=this.getCardinalDirection(Ie,Se,2)):(Ce=this.getCardinalDirection(-je,Se,3),ke=this.getCardinalDirection(-Ie,Se,1)):P>F?(Ce=this.getCardinalDirection(-je,Se,1),ke=this.getCardinalDirection(-Ie,Se,3)):(Ce=this.getCardinalDirection(je,Se,2),ke=this.getCardinalDirection(Ie,Se,4)),!Fe)switch(Ce){case 1:Ft=K,Ke=A+-ae/Se,_[0]=Ke,_[1]=Ft;break;case 2:Ke=pe,Ft=P+be*Se,_[0]=Ke,_[1]=Ft;break;case 3:Ft=oe,Ke=A+ae/Se,_[0]=Ke,_[1]=Ft;break;case 4:Ke=ie,Ft=P+-be*Se,_[0]=Ke,_[1]=Ft;break}if(!Pe)switch(ke){case 1:gn=se,Ne=R+-U/Se,_[2]=Ne,_[3]=gn;break;case 2:Ne=W,gn=F+xe*Se,_[2]=Ne,_[3]=gn;break;case 3:gn=ge,Ne=R+U/Se,_[2]=Ne,_[3]=gn;break;case 4:Ne=X,gn=F+-xe*Se,_[2]=Ne,_[3]=gn;break}}return!1},b.getCardinalDirection=function(y,T,_){return y>T?_:1+_%4},b.getIntersection=function(y,T,_,A){if(A==null)return this.getIntersection2(y,T,_);var P=y.x,R=y.y,F=T.x,j=T.y,K=_.x,ee=_.y,ie=A.x,oe=A.y,pe=void 0,be=void 0,ae=void 0,ne=void 0,se=void 0,de=void 0,X=void 0,ge=void 0,W=void 0;return ae=j-R,se=P-F,X=F*R-P*j,ne=oe-ee,de=K-ie,ge=ie*ee-K*oe,W=ae*de-ne*se,W===0?null:(pe=(se*ge-de*X)/W,be=(ne*X-ae*ge)/W,new v(pe,be))},b.angleOfVector=function(y,T,_,A){var P=void 0;return y!==_?(P=Math.atan((A-T)/(_-y)),_0?1:b<0?-1:0},v.floor=function(b){return b<0?Math.ceil(b):Math.floor(b)},v.ceil=function(b){return b<0?Math.floor(b):Math.ceil(b)},u.exports=v},function(u,d,p){function v(){}v.MAX_VALUE=2147483647,v.MIN_VALUE=-2147483648,u.exports=v},function(u,d,p){var v=function(){function P(R,F){for(var j=0;j"u"?"undefined":v(y);return y==null||T!="object"&&T!="function"},u.exports=b},function(u,d,p){function v(K){if(Array.isArray(K)){for(var ee=0,ie=Array(K.length);ee0&ⅇ){for(ae.push(se[0]);ae.length>0&ⅇ){var de=ae[0];ae.splice(0,1),be.add(de);for(var X=de.getEdges(),pe=0;pe-1&&se.splice(U,1)}be=new Set,ne=new Map}}return K},j.prototype.createDummyNodesForBendpoints=function(K){for(var ee=[],ie=K.source,oe=this.graphManager.calcLowestCommonAncestor(K.source,K.target),pe=0;pe0){for(var oe=this.edgeToDummyNodes.get(ie),pe=0;pe=0&&ee.splice(ge,1);var W=ne.getNeighborsList();W.forEach(function(Fe){if(ie.indexOf(Fe)<0){var Pe=oe.get(Fe),je=Pe-1;je==1&&de.push(Fe),oe.set(Fe,je)}})}ie=ie.concat(de),(ee.length==1||ee.length==2)&&(pe=!0,be=ee[0])}return be},j.prototype.setGraphManager=function(K){this.graphManager=K},u.exports=j},function(u,d,p){function v(){}v.seed=1,v.x=0,v.nextDouble=function(){return v.x=Math.sin(v.seed++)*1e4,v.x-Math.floor(v.x)},u.exports=v},function(u,d,p){var v=p(4);function b(y,T){this.lworldOrgX=0,this.lworldOrgY=0,this.ldeviceOrgX=0,this.ldeviceOrgY=0,this.lworldExtX=1,this.lworldExtY=1,this.ldeviceExtX=1,this.ldeviceExtY=1}b.prototype.getWorldOrgX=function(){return this.lworldOrgX},b.prototype.setWorldOrgX=function(y){this.lworldOrgX=y},b.prototype.getWorldOrgY=function(){return this.lworldOrgY},b.prototype.setWorldOrgY=function(y){this.lworldOrgY=y},b.prototype.getWorldExtX=function(){return this.lworldExtX},b.prototype.setWorldExtX=function(y){this.lworldExtX=y},b.prototype.getWorldExtY=function(){return this.lworldExtY},b.prototype.setWorldExtY=function(y){this.lworldExtY=y},b.prototype.getDeviceOrgX=function(){return this.ldeviceOrgX},b.prototype.setDeviceOrgX=function(y){this.ldeviceOrgX=y},b.prototype.getDeviceOrgY=function(){return this.ldeviceOrgY},b.prototype.setDeviceOrgY=function(y){this.ldeviceOrgY=y},b.prototype.getDeviceExtX=function(){return this.ldeviceExtX},b.prototype.setDeviceExtX=function(y){this.ldeviceExtX=y},b.prototype.getDeviceExtY=function(){return this.ldeviceExtY},b.prototype.setDeviceExtY=function(y){this.ldeviceExtY=y},b.prototype.transformX=function(y){var T=0,_=this.lworldExtX;return _!=0&&(T=this.ldeviceOrgX+(y-this.lworldOrgX)*this.ldeviceExtX/_),T},b.prototype.transformY=function(y){var T=0,_=this.lworldExtY;return _!=0&&(T=this.ldeviceOrgY+(y-this.lworldOrgY)*this.ldeviceExtY/_),T},b.prototype.inverseTransformX=function(y){var T=0,_=this.ldeviceExtX;return _!=0&&(T=this.lworldOrgX+(y-this.ldeviceOrgX)*this.lworldExtX/_),T},b.prototype.inverseTransformY=function(y){var T=0,_=this.ldeviceExtY;return _!=0&&(T=this.lworldOrgY+(y-this.ldeviceOrgY)*this.lworldExtY/_),T},b.prototype.inverseTransformPoint=function(y){var T=new v(this.inverseTransformX(y.x),this.inverseTransformY(y.y));return T},u.exports=b},function(u,d,p){function v(F){if(Array.isArray(F)){for(var j=0,K=Array(F.length);jy.ADAPTATION_LOWER_NODE_LIMIT&&(this.coolingFactor=Math.max(this.coolingFactor*y.COOLING_ADAPTATION_FACTOR,this.coolingFactor-(F-y.ADAPTATION_LOWER_NODE_LIMIT)/(y.ADAPTATION_UPPER_NODE_LIMIT-y.ADAPTATION_LOWER_NODE_LIMIT)*this.coolingFactor*(1-y.COOLING_ADAPTATION_FACTOR))),this.maxNodeDisplacement=y.MAX_NODE_DISPLACEMENT_INCREMENTAL):(F>y.ADAPTATION_LOWER_NODE_LIMIT?this.coolingFactor=Math.max(y.COOLING_ADAPTATION_FACTOR,1-(F-y.ADAPTATION_LOWER_NODE_LIMIT)/(y.ADAPTATION_UPPER_NODE_LIMIT-y.ADAPTATION_LOWER_NODE_LIMIT)*(1-y.COOLING_ADAPTATION_FACTOR)):this.coolingFactor=1,this.initialCoolingFactor=this.coolingFactor,this.maxNodeDisplacement=y.MAX_NODE_DISPLACEMENT),this.maxIterations=Math.max(this.getAllNodes().length*5,this.maxIterations),this.totalDisplacementThreshold=this.displacementThresholdPerNode*this.getAllNodes().length,this.repulsionRange=this.calcRepulsionRange()},P.prototype.calcSpringForces=function(){for(var F=this.getAllEdges(),j,K=0;K0&&arguments[0]!==void 0?arguments[0]:!0,j=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!1,K,ee,ie,oe,pe=this.getAllNodes(),be;if(this.useFRGridVariant)for(this.totalIterations%y.GRID_CALCULATION_CHECK_PERIOD==1&&F&&this.updateGrid(),be=new Set,K=0;Kae||be>ae)&&(F.gravitationForceX=-this.gravityConstant*ie,F.gravitationForceY=-this.gravityConstant*oe)):(ae=j.getEstimatedSize()*this.compoundGravityRangeFactor,(pe>ae||be>ae)&&(F.gravitationForceX=-this.gravityConstant*ie*this.compoundGravityConstant,F.gravitationForceY=-this.gravityConstant*oe*this.compoundGravityConstant))},P.prototype.isConverged=function(){var F,j=!1;return this.totalIterations>this.maxIterations/3&&(j=Math.abs(this.totalDisplacement-this.oldTotalDisplacement)<2),F=this.totalDisplacement=pe.length||ae>=pe[0].length)){for(var ne=0;neP}}]),_}();u.exports=T},function(u,d,p){var v=function(){function T(_,A){for(var P=0;P2&&arguments[2]!==void 0?arguments[2]:1,R=arguments.length>3&&arguments[3]!==void 0?arguments[3]:-1,F=arguments.length>4&&arguments[4]!==void 0?arguments[4]:-1;b(this,T),this.sequence1=_,this.sequence2=A,this.match_score=P,this.mismatch_penalty=R,this.gap_penalty=F,this.iMax=_.length+1,this.jMax=A.length+1,this.grid=new Array(this.iMax);for(var j=0;j=0;_--){var A=this.listeners[_];A.event===y&&A.callback===T&&this.listeners.splice(_,1)}},b.emit=function(y,T){for(var _=0;_A.coolingFactor*A.maxNodeDisplacement&&(this.displacementX=A.coolingFactor*A.maxNodeDisplacement*y.sign(this.displacementX)),Math.abs(this.displacementY)>A.coolingFactor*A.maxNodeDisplacement&&(this.displacementY=A.coolingFactor*A.maxNodeDisplacement*y.sign(this.displacementY)),this.child==null?this.moveBy(this.displacementX,this.displacementY):this.child.getNodes().length==0?this.moveBy(this.displacementX,this.displacementY):this.propogateDisplacementToChildren(this.displacementX,this.displacementY),A.totalDisplacement+=Math.abs(this.displacementX)+Math.abs(this.displacementY),this.springForceX=0,this.springForceY=0,this.repulsionForceX=0,this.repulsionForceY=0,this.gravitationForceX=0,this.gravitationForceY=0,this.displacementX=0,this.displacementY=0},T.prototype.propogateDisplacementToChildren=function(A,P){for(var R=this.getChild().getNodes(),F,j=0;j0)this.positionNodesRadially(se);else{this.reduceTrees(),this.graphManager.resetAllNodesToApplyGravitation();var de=new Set(this.getAllNodes()),X=this.nodesWithGravity.filter(function(ge){return de.has(ge)});this.graphManager.setAllNodesToApplyGravitation(X),this.positionNodesRandomly()}}return this.initSpringEmbedder(),this.runSpringEmbedder(),!0},ae.prototype.tick=function(){if(this.totalIterations++,this.totalIterations===this.maxIterations&&!this.isTreeGrowing&&!this.isGrowthFinished)if(this.prunedNodesAll.length>0)this.isTreeGrowing=!0;else return!0;if(this.totalIterations%R.CONVERGENCE_CHECK_PERIOD==0&&!this.isTreeGrowing&&!this.isGrowthFinished){if(this.isConverged())if(this.prunedNodesAll.length>0)this.isTreeGrowing=!0;else return!0;this.coolingCycle++,this.layoutQuality==0?this.coolingAdjuster=this.coolingCycle:this.layoutQuality==1&&(this.coolingAdjuster=this.coolingCycle/3),this.coolingFactor=Math.max(this.initialCoolingFactor-Math.pow(this.coolingCycle,Math.log(100*(this.initialCoolingFactor-this.finalTemperature))/Math.log(this.maxCoolingCycle))/100*this.coolingAdjuster,this.finalTemperature),this.animationPeriod=Math.ceil(this.initialAnimationPeriod*Math.sqrt(this.coolingFactor))}if(this.isTreeGrowing){if(this.growTreeIterations%10==0)if(this.prunedNodesAll.length>0){this.graphManager.updateBounds(),this.updateGrid(),this.growTree(this.prunedNodesAll),this.graphManager.resetAllNodesToApplyGravitation();var se=new Set(this.getAllNodes()),de=this.nodesWithGravity.filter(function(W){return se.has(W)});this.graphManager.setAllNodesToApplyGravitation(de),this.graphManager.updateBounds(),this.updateGrid(),this.coolingFactor=R.DEFAULT_COOLING_FACTOR_INCREMENTAL}else this.isTreeGrowing=!1,this.isGrowthFinished=!0;this.growTreeIterations++}if(this.isGrowthFinished){if(this.isConverged())return!0;this.afterGrowthIterations%10==0&&(this.graphManager.updateBounds(),this.updateGrid()),this.coolingFactor=R.DEFAULT_COOLING_FACTOR_INCREMENTAL*((100-this.afterGrowthIterations)/100),this.afterGrowthIterations++}var X=!this.isTreeGrowing&&!this.isGrowthFinished,ge=this.growTreeIterations%10==1&&this.isTreeGrowing||this.afterGrowthIterations%10==1&&this.isGrowthFinished;return this.totalDisplacement=0,this.graphManager.updateBounds(),this.calcSpringForces(),this.calcRepulsionForces(X,ge),this.calcGravitationalForces(),this.moveNodes(),this.animate(),!1},ae.prototype.getPositionsData=function(){for(var se=this.graphManager.getAllNodes(),de={},X=0;X1){var Fe;for(Fe=0;Fege&&(ge=Math.floor(U.y)),xe=Math.floor(U.x+P.DEFAULT_COMPONENT_SEPERATION)}this.transform(new K(F.WORLD_CENTER_X-U.x/2,F.WORLD_CENTER_Y-U.y/2))},ae.radialLayout=function(se,de,X){var ge=Math.max(this.maxDiagonalInTree(se),P.DEFAULT_RADIAL_SEPARATION);ae.branchRadialLayout(de,null,0,359,0,ge);var W=pe.calculateBounds(se),xe=new be;xe.setDeviceOrgX(W.getMinX()),xe.setDeviceOrgY(W.getMinY()),xe.setWorldOrgX(X.x),xe.setWorldOrgY(X.y);for(var U=0;U1;){var gn=Ne[0];Ne.splice(0,1);var _t=Se.indexOf(gn);_t>=0&&Se.splice(_t,1),Ke--,Ce--}de!=null?Ft=(Se.indexOf(Ne[0])+1)%Ke:Ft=0;for(var Et=Math.abs(ge-X)/Ce,Gt=Ft;ke!=Ce;Gt=++Gt%Ke){var ln=Se[Gt].getOtherEnd(se);if(ln!=de){var xt=(X+ke*Et)%360,Pt=(xt+Et)%360;ae.branchRadialLayout(ln,se,xt,Pt,W+xe,xe),ke++}}},ae.maxDiagonalInTree=function(se){for(var de=ie.MIN_VALUE,X=0;Xde&&(de=W)}return de},ae.prototype.calcRepulsionRange=function(){return 2*(this.level+1)*this.idealEdgeLength},ae.prototype.groupZeroDegreeMembers=function(){var se=this,de={};this.memberGroups={},this.idToDummyNode={};for(var X=[],ge=this.graphManager.getAllNodes(),W=0;W"u"&&(de[Fe]=[]),de[Fe]=de[Fe].concat(xe)}Object.keys(de).forEach(function(Pe){if(de[Pe].length>1){var je="DummyCompound_"+Pe;se.memberGroups[je]=de[Pe];var Ie=de[Pe][0].getParent(),Se=new _(se.graphManager);Se.id=je,Se.paddingLeft=Ie.paddingLeft||0,Se.paddingRight=Ie.paddingRight||0,Se.paddingBottom=Ie.paddingBottom||0,Se.paddingTop=Ie.paddingTop||0,se.idToDummyNode[je]=Se;var Ce=se.getGraphManager().add(se.newGraph(),Se),ke=Ie.getChild();ke.add(Se);for(var Ke=0;Ke=0;se--){var de=this.compoundOrder[se],X=de.id,ge=de.paddingLeft,W=de.paddingTop;this.adjustLocations(this.tiledMemberPack[X],de.rect.x,de.rect.y,ge,W)}},ae.prototype.repopulateZeroDegreeMembers=function(){var se=this,de=this.tiledZeroDegreePack;Object.keys(de).forEach(function(X){var ge=se.idToDummyNode[X],W=ge.paddingLeft,xe=ge.paddingTop;se.adjustLocations(de[X],ge.rect.x,ge.rect.y,W,xe)})},ae.prototype.getToBeTiled=function(se){var de=se.id;if(this.toBeTiled[de]!=null)return this.toBeTiled[de];var X=se.getChild();if(X==null)return this.toBeTiled[de]=!1,!1;for(var ge=X.getNodes(),W=0;W0)return this.toBeTiled[de]=!1,!1;if(xe.getChild()==null){this.toBeTiled[xe.id]=!1;continue}if(!this.getToBeTiled(xe))return this.toBeTiled[de]=!1,!1}return this.toBeTiled[de]=!0,!0},ae.prototype.getNodeDegree=function(se){se.id;for(var de=se.getEdges(),X=0,ge=0;gePe&&(Pe=Ie.rect.height)}X+=Pe+se.verticalPadding}},ae.prototype.tileCompoundMembers=function(se,de){var X=this;this.tiledMemberPack=[],Object.keys(se).forEach(function(ge){var W=de[ge];X.tiledMemberPack[ge]=X.tileNodes(se[ge],W.paddingLeft+W.paddingRight),W.rect.width=X.tiledMemberPack[ge].width,W.rect.height=X.tiledMemberPack[ge].height})},ae.prototype.tileNodes=function(se,de){var X=P.TILING_PADDING_VERTICAL,ge=P.TILING_PADDING_HORIZONTAL,W={rows:[],rowWidth:[],rowHeight:[],width:0,height:de,verticalPadding:X,horizontalPadding:ge};se.sort(function(Fe,Pe){return Fe.rect.width*Fe.rect.height>Pe.rect.width*Pe.rect.height?-1:Fe.rect.width*Fe.rect.height0&&(U+=se.horizontalPadding),se.rowWidth[X]=U,se.width0&&(Fe+=se.verticalPadding);var Pe=0;Fe>se.rowHeight[X]&&(Pe=se.rowHeight[X],se.rowHeight[X]=Fe,Pe=se.rowHeight[X]-Pe),se.height+=Pe,se.rows[X].push(de)},ae.prototype.getShortestRowIndex=function(se){for(var de=-1,X=Number.MAX_VALUE,ge=0;geX&&(de=ge,X=se.rowWidth[ge]);return de},ae.prototype.canAddHorizontal=function(se,de,X){var ge=this.getShortestRowIndex(se);if(ge<0)return!0;var W=se.rowWidth[ge];if(W+se.horizontalPadding+de<=se.width)return!0;var xe=0;se.rowHeight[ge]0&&(xe=X+se.verticalPadding-se.rowHeight[ge]);var U;se.width-W>=de+se.horizontalPadding?U=(se.height+xe)/(W+de+se.horizontalPadding):U=(se.height+xe)/se.width,xe=X+se.verticalPadding;var Fe;return se.widthxe&&de!=X){ge.splice(-1,1),se.rows[X].push(W),se.rowWidth[de]=se.rowWidth[de]-xe,se.rowWidth[X]=se.rowWidth[X]+xe,se.width=se.rowWidth[instance.getLongestRowIndex(se)];for(var U=Number.MIN_VALUE,Fe=0;FeU&&(U=ge[Fe].height);de>0&&(U+=se.verticalPadding);var Pe=se.rowHeight[de]+se.rowHeight[X];se.rowHeight[de]=U,se.rowHeight[X]0)for(var ke=W;ke<=xe;ke++)Ce[0]+=this.grid[ke][U-1].length+this.grid[ke][U].length-1;if(xe0)for(var ke=U;ke<=Fe;ke++)Ce[3]+=this.grid[W-1][ke].length+this.grid[W][ke].length-1;for(var Ke=ie.MAX_VALUE,Ft,Ne,gn=0;gn0){var Fe;Fe=be.getGraphManager().add(be.newGraph(),X),this.processChildrenList(Fe,de,be)}}},K.prototype.stop=function(){return this.stopped=!0,this};var ie=function(pe){pe("layout","cose-bilkent",K)};typeof cytoscape<"u"&&ie(cytoscape),d.exports=ie}])})})(dWe);var gon=dWe.exports;const pon=hC(gon),bon=12,mon=function(i,s,u,d){s.append("path").attr("id","node-"+u.id).attr("class","node-bkg node-"+i.type2Str(u.type)).attr("d",`M0 ${u.height-5} v${-u.height+2*5} q0,-5 5,-5 h${u.width-2*5} q5,0 5,5 v${u.height-5} H0 Z`),s.append("line").attr("class","node-line-"+d).attr("x1",0).attr("y1",u.height).attr("x2",u.width).attr("y2",u.height)},von=function(i,s,u){s.append("rect").attr("id","node-"+u.id).attr("class","node-bkg node-"+i.type2Str(u.type)).attr("height",u.height).attr("width",u.width)},won=function(i,s,u){const d=u.width,p=u.height,v=.15*d,b=.25*d,y=.35*d,T=.2*d;s.append("path").attr("id","node-"+u.id).attr("class","node-bkg node-"+i.type2Str(u.type)).attr("d",`M0 0 a${v},${v} 0 0,1 ${d*.25},${-1*d*.1} + a${y},${y} 1 0,1 ${d*.4},${-1*d*.1} + a${b},${b} 1 0,1 ${d*.35},${1*d*.2} + + a${v},${v} 1 0,1 ${d*.15},${1*p*.35} + a${T},${T} 1 0,1 ${-1*d*.15},${1*p*.65} + + a${b},${v} 1 0,1 ${-1*d*.25},${d*.15} + a${y},${y} 1 0,1 ${-1*d*.5},0 + a${v},${v} 1 0,1 ${-1*d*.25},${-1*d*.15} + + a${v},${v} 1 0,1 ${-1*d*.1},${-1*p*.35} + a${T},${T} 1 0,1 ${d*.1},${-1*p*.65} + + H0 V0 Z`)},yon=function(i,s,u){const d=u.width,p=u.height,v=.15*d;s.append("path").attr("id","node-"+u.id).attr("class","node-bkg node-"+i.type2Str(u.type)).attr("d",`M0 0 a${v},${v} 1 0,0 ${d*.25},${-1*p*.1} + a${v},${v} 1 0,0 ${d*.25},0 + a${v},${v} 1 0,0 ${d*.25},0 + a${v},${v} 1 0,0 ${d*.25},${1*p*.1} + + a${v},${v} 1 0,0 ${d*.15},${1*p*.33} + a${v*.8},${v*.8} 1 0,0 0,${1*p*.34} + a${v},${v} 1 0,0 ${-1*d*.15},${1*p*.33} + + a${v},${v} 1 0,0 ${-1*d*.25},${p*.15} + a${v},${v} 1 0,0 ${-1*d*.25},0 + a${v},${v} 1 0,0 ${-1*d*.25},0 + a${v},${v} 1 0,0 ${-1*d*.25},${-1*p*.15} + + a${v},${v} 1 0,0 ${-1*d*.1},${-1*p*.33} + a${v*.8},${v*.8} 1 0,0 0,${-1*p*.34} + a${v},${v} 1 0,0 ${d*.1},${-1*p*.33} + + H0 V0 Z`)},xon=function(i,s,u){s.append("circle").attr("id","node-"+u.id).attr("class","node-bkg node-"+i.type2Str(u.type)).attr("r",u.width/2)};function kon(i,s,u,d,p){return i.insert("polygon",":first-child").attr("points",d.map(function(v){return v.x+","+v.y}).join(" ")).attr("transform","translate("+(p.width-s)/2+", "+u+")")}const Eon=function(i,s,u){const d=u.height,v=d/4,b=u.width-u.padding+2*v,y=[{x:v,y:0},{x:b-v,y:0},{x:b,y:-d/2},{x:b-v,y:-d},{x:v,y:-d},{x:0,y:-d/2}];kon(s,b,d,y,u)},Ton=function(i,s,u){s.append("rect").attr("id","node-"+u.id).attr("class","node-bkg node-"+i.type2Str(u.type)).attr("height",u.height).attr("rx",u.padding).attr("ry",u.padding).attr("width",u.width)},Con=function(i,s,u,d,p){const v=p.htmlLabels,b=d%(bon-1),y=s.append("g");u.section=b;let T="section-"+b;b<0&&(T+=" section-root"),y.attr("class",(u.class?u.class+" ":"")+"mindmap-node "+T);const _=y.append("g"),A=y.append("g"),P=u.descr.replace(/()/g,` +`);JQ(A,P,{useHtmlLabels:v,width:u.width,classes:"mindmap-node-label"}),v||A.attr("dy","1em").attr("alignment-baseline","middle").attr("dominant-baseline","middle").attr("text-anchor","middle");const R=A.node().getBBox(),[F]=NC(p.fontSize);if(u.height=R.height+F*1.1*.5+u.padding,u.width=R.width+2*u.padding,u.icon)if(u.type===i.nodeType.CIRCLE)u.height+=50,u.width+=50,y.append("foreignObject").attr("height","50px").attr("width",u.width).attr("style","text-align: center;").append("div").attr("class","icon-container").append("i").attr("class","node-icon-"+b+" "+u.icon),A.attr("transform","translate("+u.width/2+", "+(u.height/2-1.5*u.padding)+")");else{u.width+=50;const j=u.height;u.height=Math.max(j,60);const K=Math.abs(u.height-j);y.append("foreignObject").attr("width","60px").attr("height",u.height).attr("style","text-align: center;margin-top:"+K/2+"px;").append("div").attr("class","icon-container").append("i").attr("class","node-icon-"+b+" "+u.icon),A.attr("transform","translate("+(25+u.width/2)+", "+(K/2+u.padding/2)+")")}else if(v){const j=(u.width-R.width)/2,K=(u.height-R.height)/2;A.attr("transform","translate("+j+", "+K+")")}else{const j=u.width/2,K=u.padding/2;A.attr("transform","translate("+j+", "+K+")")}switch(u.type){case i.nodeType.DEFAULT:mon(i,_,u,b);break;case i.nodeType.ROUNDED_RECT:Ton(i,_,u);break;case i.nodeType.RECT:von(i,_,u);break;case i.nodeType.CIRCLE:_.attr("transform","translate("+u.width/2+", "+ +u.height/2+")"),xon(i,_,u);break;case i.nodeType.CLOUD:won(i,_,u);break;case i.nodeType.BANG:yon(i,_,u);break;case i.nodeType.HEXAGON:Eon(i,_,u);break}return i.setElementForId(u.id,y),u.height},Son=function(i,s){const u=i.getElementById(s.id),d=s.x||0,p=s.y||0;u.attr("transform","translate("+d+","+p+")")};fWe.use(pon);function bWe(i,s,u,d,p){Con(i,s,u,d,p),u.children&&u.children.forEach((v,b)=>{bWe(i,s,v,d<0?b:d,p)})}function _on(i,s){s.edges().map((u,d)=>{const p=u.data();if(u[0]._private.bodyBounds){const v=u[0]._private.rscratch;Xe.trace("Edge: ",d,p),i.insert("path").attr("d",`M ${v.startX},${v.startY} L ${v.midX},${v.midY} L${v.endX},${v.endY} `).attr("class","edge section-edge-"+p.section+" edge-depth-"+p.depth)}})}function mWe(i,s,u,d){s.add({group:"nodes",data:{id:i.id.toString(),labelText:i.descr,height:i.height,width:i.width,level:d,nodeId:i.id,padding:i.padding,type:i.type},position:{x:i.x,y:i.y}}),i.children&&i.children.forEach(p=>{mWe(p,s,u,d+1),s.add({group:"edges",data:{id:`${i.id}_${p.id}`,source:i.id,target:p.id,depth:d,section:p.section}})})}function Aon(i,s){return new Promise(u=>{const d=Ir("body").append("div").attr("id","cy").attr("style","display:none"),p=fWe({container:document.getElementById("cy"),style:[{selector:"edge",style:{"curve-style":"bezier"}}]});d.remove(),mWe(i,p,s,0),p.nodes().forEach(function(v){v.layoutDimensions=()=>{const b=v.data();return{w:b.width,h:b.height}}}),p.layout({name:"cose-bilkent",quality:"proof",styleEnabled:!1,animate:!1}).run(),p.ready(v=>{Xe.info("Ready",v),u(p)})})}function Lon(i,s){s.nodes().map((u,d)=>{const p=u.data();p.x=u.position().x,p.y=u.position().y,Son(i,p);const v=i.getElementById(p.nodeId);Xe.info("Id:",d,"Position: (",u.position().x,", ",u.position().y,")",p),v.attr("transform",`translate(${u.position().x-p.width/2}, ${u.position().y-p.height/2})`),v.attr("attr",`apa-${d})`)})}const Mon={draw:async(i,s,u,d)=>{var P,R;Xe.debug(`Rendering mindmap diagram +`+i);const p=d.db,v=p.getMindmap();if(!v)return;const b=qt();b.htmlLabels=!1;const y=rR(s),T=y.append("g");T.attr("class","mindmap-edges");const _=y.append("g");_.attr("class","mindmap-nodes"),bWe(p,_,v,-1,b);const A=await Aon(v,b);_on(T,A),Lon(p,A),y9(void 0,y,((P=b.mindmap)==null?void 0:P.padding)??sh.mindmap.padding,((R=b.mindmap)==null?void 0:R.useMaxWidth)??sh.mindmap.useMaxWidth)}},Don=i=>{let s="";for(let u=0;u` + .edge { + stroke-width: 3; + } + ${Don(i)} + .section-root rect, .section-root path, .section-root circle, .section-root polygon { + fill: ${i.git0}; + } + .section-root text { + fill: ${i.gitBranchLabel0}; + } + .icon-container { + height:100%; + display: flex; + justify-content: center; + align-items: center; + } + .edge { + fill: none; + } + .mindmap-node-label { + dy: 1em; + alignment-baseline: middle; + text-anchor: middle; + dominant-baseline: middle; + text-align: center; + } +`}},Symbol.toStringTag,{value:"Module"}));var iwe=function(){var i=function(y,T,_,A){for(_=_||{},A=y.length;A--;_[y[A]]=T);return _},s=[1,9],u=[1,10],d=[1,5,10,12],p={trace:function(){},yy:{},symbols_:{error:2,start:3,SANKEY:4,NEWLINE:5,csv:6,opt_eof:7,record:8,csv_tail:9,EOF:10,"field[source]":11,COMMA:12,"field[target]":13,"field[value]":14,field:15,escaped:16,non_escaped:17,DQUOTE:18,ESCAPED_TEXT:19,NON_ESCAPED_TEXT:20,$accept:0,$end:1},terminals_:{2:"error",4:"SANKEY",5:"NEWLINE",10:"EOF",11:"field[source]",12:"COMMA",13:"field[target]",14:"field[value]",18:"DQUOTE",19:"ESCAPED_TEXT",20:"NON_ESCAPED_TEXT"},productions_:[0,[3,4],[6,2],[9,2],[9,0],[7,1],[7,0],[8,5],[15,1],[15,1],[16,3],[17,1]],performAction:function(T,_,A,P,R,F,j){var K=F.length-1;switch(R){case 7:const ee=P.findOrCreateNode(F[K-4].trim().replaceAll('""','"')),ie=P.findOrCreateNode(F[K-2].trim().replaceAll('""','"')),oe=parseFloat(F[K].trim());P.addLink(ee,ie,oe);break;case 8:case 9:case 11:this.$=F[K];break;case 10:this.$=F[K-1];break}},table:[{3:1,4:[1,2]},{1:[3]},{5:[1,3]},{6:4,8:5,15:6,16:7,17:8,18:s,20:u},{1:[2,6],7:11,10:[1,12]},i(u,[2,4],{9:13,5:[1,14]}),{12:[1,15]},i(d,[2,8]),i(d,[2,9]),{19:[1,16]},i(d,[2,11]),{1:[2,1]},{1:[2,5]},i(u,[2,2]),{6:17,8:5,15:6,16:7,17:8,18:s,20:u},{15:18,16:7,17:8,18:s,20:u},{18:[1,19]},i(u,[2,3]),{12:[1,20]},i(d,[2,10]),{15:21,16:7,17:8,18:s,20:u},i([1,5,10],[2,7])],defaultActions:{11:[2,1],12:[2,5]},parseError:function(T,_){if(_.recoverable)this.trace(T);else{var A=new Error(T);throw A.hash=_,A}},parse:function(T){var _=this,A=[0],P=[],R=[null],F=[],j=this.table,K="",ee=0,ie=0,oe=2,pe=1,be=F.slice.call(arguments,1),ae=Object.create(this.lexer),ne={yy:{}};for(var se in this.yy)Object.prototype.hasOwnProperty.call(this.yy,se)&&(ne.yy[se]=this.yy[se]);ae.setInput(T,ne.yy),ne.yy.lexer=ae,ne.yy.parser=this,typeof ae.yylloc>"u"&&(ae.yylloc={});var de=ae.yylloc;F.push(de);var X=ae.options&&ae.options.ranges;typeof ne.yy.parseError=="function"?this.parseError=ne.yy.parseError:this.parseError=Object.getPrototypeOf(this).parseError;function ge(){var Ke;return Ke=P.pop()||ae.lex()||pe,typeof Ke!="number"&&(Ke instanceof Array&&(P=Ke,Ke=P.pop()),Ke=_.symbols_[Ke]||Ke),Ke}for(var W,xe,U,Fe,Pe={},je,Ie,Se,Ce;;){if(xe=A[A.length-1],this.defaultActions[xe]?U=this.defaultActions[xe]:((W===null||typeof W>"u")&&(W=ge()),U=j[xe]&&j[xe][W]),typeof U>"u"||!U.length||!U[0]){var ke="";Ce=[];for(je in j[xe])this.terminals_[je]&&je>oe&&Ce.push("'"+this.terminals_[je]+"'");ae.showPosition?ke="Parse error on line "+(ee+1)+`: +`+ae.showPosition()+` +Expecting `+Ce.join(", ")+", got '"+(this.terminals_[W]||W)+"'":ke="Parse error on line "+(ee+1)+": Unexpected "+(W==pe?"end of input":"'"+(this.terminals_[W]||W)+"'"),this.parseError(ke,{text:ae.match,token:this.terminals_[W]||W,line:ae.yylineno,loc:de,expected:Ce})}if(U[0]instanceof Array&&U.length>1)throw new Error("Parse Error: multiple actions possible at state: "+xe+", token: "+W);switch(U[0]){case 1:A.push(W),R.push(ae.yytext),F.push(ae.yylloc),A.push(U[1]),W=null,ie=ae.yyleng,K=ae.yytext,ee=ae.yylineno,de=ae.yylloc;break;case 2:if(Ie=this.productions_[U[1]][1],Pe.$=R[R.length-Ie],Pe._$={first_line:F[F.length-(Ie||1)].first_line,last_line:F[F.length-1].last_line,first_column:F[F.length-(Ie||1)].first_column,last_column:F[F.length-1].last_column},X&&(Pe._$.range=[F[F.length-(Ie||1)].range[0],F[F.length-1].range[1]]),Fe=this.performAction.apply(Pe,[K,ie,ee,ne.yy,U[1],R,F].concat(be)),typeof Fe<"u")return Fe;Ie&&(A=A.slice(0,-1*Ie*2),R=R.slice(0,-1*Ie),F=F.slice(0,-1*Ie)),A.push(this.productions_[U[1]][0]),R.push(Pe.$),F.push(Pe._$),Se=j[A[A.length-2]][A[A.length-1]],A.push(Se);break;case 3:return!0}}return!0}},v=function(){var y={EOF:1,parseError:function(_,A){if(this.yy.parser)this.yy.parser.parseError(_,A);else throw new Error(_)},setInput:function(T,_){return this.yy=_||this.yy||{},this._input=T,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},input:function(){var T=this._input[0];this.yytext+=T,this.yyleng++,this.offset++,this.match+=T,this.matched+=T;var _=T.match(/(?:\r\n?|\n).*/g);return _?(this.yylineno++,this.yylloc.last_line++):this.yylloc.last_column++,this.options.ranges&&this.yylloc.range[1]++,this._input=this._input.slice(1),T},unput:function(T){var _=T.length,A=T.split(/(?:\r\n?|\n)/g);this._input=T+this._input,this.yytext=this.yytext.substr(0,this.yytext.length-_),this.offset-=_;var P=this.match.split(/(?:\r\n?|\n)/g);this.match=this.match.substr(0,this.match.length-1),this.matched=this.matched.substr(0,this.matched.length-1),A.length-1&&(this.yylineno-=A.length-1);var R=this.yylloc.range;return this.yylloc={first_line:this.yylloc.first_line,last_line:this.yylineno+1,first_column:this.yylloc.first_column,last_column:A?(A.length===P.length?this.yylloc.first_column:0)+P[P.length-A.length].length-A[0].length:this.yylloc.first_column-_},this.options.ranges&&(this.yylloc.range=[R[0],R[0]+this.yyleng-_]),this.yyleng=this.yytext.length,this},more:function(){return this._more=!0,this},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},less:function(T){this.unput(this.match.slice(T))},pastInput:function(){var T=this.matched.substr(0,this.matched.length-this.match.length);return(T.length>20?"...":"")+T.substr(-20).replace(/\n/g,"")},upcomingInput:function(){var T=this.match;return T.length<20&&(T+=this._input.substr(0,20-T.length)),(T.substr(0,20)+(T.length>20?"...":"")).replace(/\n/g,"")},showPosition:function(){var T=this.pastInput(),_=new Array(T.length+1).join("-");return T+this.upcomingInput()+` +`+_+"^"},test_match:function(T,_){var A,P,R;if(this.options.backtrack_lexer&&(R={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&&(R.yylloc.range=this.yylloc.range.slice(0))),P=T[0].match(/(?:\r\n?|\n).*/g),P&&(this.yylineno+=P.length),this.yylloc={first_line:this.yylloc.last_line,last_line:this.yylineno+1,first_column:this.yylloc.last_column,last_column:P?P[P.length-1].length-P[P.length-1].match(/\r?\n?/)[0].length:this.yylloc.last_column+T[0].length},this.yytext+=T[0],this.match+=T[0],this.matches=T,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(T[0].length),this.matched+=T[0],A=this.performAction.call(this,this.yy,this,_,this.conditionStack[this.conditionStack.length-1]),this.done&&this._input&&(this.done=!1),A)return A;if(this._backtrack){for(var F in R)this[F]=R[F];return!1}return!1},next:function(){if(this.done)return this.EOF;this._input||(this.done=!0);var T,_,A,P;this._more||(this.yytext="",this.match="");for(var R=this._currentRules(),F=0;F_[0].length)){if(_=A,P=F,this.options.backtrack_lexer){if(T=this.test_match(A,R[F]),T!==!1)return T;if(this._backtrack){_=!1;continue}else return!1}else if(!this.options.flex)break}return _?(T=this.test_match(_,R[P]),T!==!1?T:!1):this._input===""?this.EOF:this.parseError("Lexical error on line "+(this.yylineno+1)+`. Unrecognized text. +`+this.showPosition(),{text:"",token:null,line:this.yylineno})},lex:function(){var _=this.next();return _||this.lex()},begin:function(_){this.conditionStack.push(_)},popState:function(){var _=this.conditionStack.length-1;return _>0?this.conditionStack.pop():this.conditionStack[0]},_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},topState:function(_){return _=this.conditionStack.length-1-Math.abs(_||0),_>=0?this.conditionStack[_]:"INITIAL"},pushState:function(_){this.begin(_)},stateStackSize:function(){return this.conditionStack.length},options:{"case-insensitive":!0},performAction:function(_,A,P,R){switch(P){case 0:return this.pushState("csv"),4;case 1:return 10;case 2:return 5;case 3:return 12;case 4:return this.pushState("escaped_text"),18;case 5:return 20;case 6:return this.popState("escaped_text"),18;case 7:return 19}},rules:[/^(?:sankey-beta\b)/i,/^(?:$)/i,/^(?:((\u000D\u000A)|(\u000A)))/i,/^(?:(\u002C))/i,/^(?:(\u0022))/i,/^(?:([\u0020-\u0021\u0023-\u002B\u002D-\u007E])*)/i,/^(?:(\u0022)(?!(\u0022)))/i,/^(?:(([\u0020-\u0021\u0023-\u002B\u002D-\u007E])|(\u002C)|(\u000D)|(\u000A)|(\u0022)(\u0022))*)/i],conditions:{csv:{rules:[1,2,3,4,5,6,7],inclusive:!1},escaped_text:{rules:[6,7],inclusive:!1},INITIAL:{rules:[0,1,2,3,4,5,6,7],inclusive:!0}}};return y}();p.lexer=v;function b(){this.yy={}}return b.prototype=p,p.Parser=b,new b}();iwe.parser=iwe;const NJ=iwe;let PJ=[],BJ=[],tI={};const Oon=()=>{PJ=[],BJ=[],tI={},Pg()};class Non{constructor(s,u,d=0){this.source=s,this.target=u,this.value=d}}const Pon=(i,s,u)=>{PJ.push(new Non(i,s,u))};class Bon{constructor(s){this.ID=s}}const Fon={nodesMap:tI,getConfig:()=>qt().sankey,getNodes:()=>BJ,getLinks:()=>PJ,getGraph:()=>({nodes:BJ.map(i=>({id:i.ID})),links:PJ.map(i=>({source:i.source.ID,target:i.target.ID,value:i.value}))}),addLink:Pon,findOrCreateNode:i=>(i=ci.sanitizeText(i,qt()),tI[i]||(tI[i]=new Bon(i),BJ.push(tI[i])),tI[i]),getAccTitle:Cp,setAccTitle:Bg,getAccDescription:_p,setAccDescription:Sp,getDiagramTitle:Ap,setDiagramTitle:cm,clear:Oon};function vWe(i,s){let u;if(s===void 0)for(const d of i)d!=null&&(u=d)&&(u=d);else{let d=-1;for(let p of i)(p=s(p,++d,i))!=null&&(u=p)&&(u=p)}return u}function wWe(i,s){let u;if(s===void 0)for(const d of i)d!=null&&(u>d||u===void 0&&d>=d)&&(u=d);else{let d=-1;for(let p of i)(p=s(p,++d,i))!=null&&(u>p||u===void 0&&p>=p)&&(u=p)}return u}function swe(i,s){let u=0;if(s===void 0)for(let d of i)(d=+d)&&(u+=d);else{let d=-1;for(let p of i)(p=+s(p,++d,i))&&(u+=p)}return u}function Ron(i){return i.target.depth}function jon(i){return i.depth}function $on(i,s){return s-1-i.height}function yWe(i,s){return i.sourceLinks.length?i.depth:s-1}function zon(i){return i.targetLinks.length?i.depth:i.sourceLinks.length?wWe(i.sourceLinks,Ron)-1:0}function FJ(i){return function(){return i}}function xWe(i,s){return RJ(i.source,s.source)||i.index-s.index}function kWe(i,s){return RJ(i.target,s.target)||i.index-s.index}function RJ(i,s){return i.y0-s.y0}function awe(i){return i.value}function qon(i){return i.index}function Hon(i){return i.nodes}function Von(i){return i.links}function EWe(i,s){const u=i.get(s);if(!u)throw new Error("missing: "+s);return u}function TWe({nodes:i}){for(const s of i){let u=s.y0,d=u;for(const p of s.sourceLinks)p.y0=u+p.width/2,u+=p.width;for(const p of s.targetLinks)p.y1=d+p.width/2,d+=p.width}}function Uon(){let i=0,s=0,u=1,d=1,p=24,v=8,b,y=qon,T=yWe,_,A,P=Hon,R=Von,F=6;function j(){const Pe={nodes:P.apply(null,arguments),links:R.apply(null,arguments)};return K(Pe),ee(Pe),ie(Pe),oe(Pe),ae(Pe),TWe(Pe),Pe}j.update=function(Pe){return TWe(Pe),Pe},j.nodeId=function(Pe){return arguments.length?(y=typeof Pe=="function"?Pe:FJ(Pe),j):y},j.nodeAlign=function(Pe){return arguments.length?(T=typeof Pe=="function"?Pe:FJ(Pe),j):T},j.nodeSort=function(Pe){return arguments.length?(_=Pe,j):_},j.nodeWidth=function(Pe){return arguments.length?(p=+Pe,j):p},j.nodePadding=function(Pe){return arguments.length?(v=b=+Pe,j):v},j.nodes=function(Pe){return arguments.length?(P=typeof Pe=="function"?Pe:FJ(Pe),j):P},j.links=function(Pe){return arguments.length?(R=typeof Pe=="function"?Pe:FJ(Pe),j):R},j.linkSort=function(Pe){return arguments.length?(A=Pe,j):A},j.size=function(Pe){return arguments.length?(i=s=0,u=+Pe[0],d=+Pe[1],j):[u-i,d-s]},j.extent=function(Pe){return arguments.length?(i=+Pe[0][0],u=+Pe[1][0],s=+Pe[0][1],d=+Pe[1][1],j):[[i,s],[u,d]]},j.iterations=function(Pe){return arguments.length?(F=+Pe,j):F};function K({nodes:Pe,links:je}){for(const[Se,Ce]of Pe.entries())Ce.index=Se,Ce.sourceLinks=[],Ce.targetLinks=[];const Ie=new Map(Pe.map((Se,Ce)=>[y(Se,Ce,Pe),Se]));for(const[Se,Ce]of je.entries()){Ce.index=Se;let{source:ke,target:Ke}=Ce;typeof ke!="object"&&(ke=Ce.source=EWe(Ie,ke)),typeof Ke!="object"&&(Ke=Ce.target=EWe(Ie,Ke)),ke.sourceLinks.push(Ce),Ke.targetLinks.push(Ce)}if(A!=null)for(const{sourceLinks:Se,targetLinks:Ce}of Pe)Se.sort(A),Ce.sort(A)}function ee({nodes:Pe}){for(const je of Pe)je.value=je.fixedValue===void 0?Math.max(swe(je.sourceLinks,awe),swe(je.targetLinks,awe)):je.fixedValue}function ie({nodes:Pe}){const je=Pe.length;let Ie=new Set(Pe),Se=new Set,Ce=0;for(;Ie.size;){for(const ke of Ie){ke.depth=Ce;for(const{target:Ke}of ke.sourceLinks)Se.add(Ke)}if(++Ce>je)throw new Error("circular link");Ie=Se,Se=new Set}}function oe({nodes:Pe}){const je=Pe.length;let Ie=new Set(Pe),Se=new Set,Ce=0;for(;Ie.size;){for(const ke of Ie){ke.height=Ce;for(const{source:Ke}of ke.targetLinks)Se.add(Ke)}if(++Ce>je)throw new Error("circular link");Ie=Se,Se=new Set}}function pe({nodes:Pe}){const je=vWe(Pe,Ce=>Ce.depth)+1,Ie=(u-i-p)/(je-1),Se=new Array(je);for(const Ce of Pe){const ke=Math.max(0,Math.min(je-1,Math.floor(T.call(null,Ce,je))));Ce.layer=ke,Ce.x0=i+ke*Ie,Ce.x1=Ce.x0+p,Se[ke]?Se[ke].push(Ce):Se[ke]=[Ce]}if(_)for(const Ce of Se)Ce.sort(_);return Se}function be(Pe){const je=wWe(Pe,Ie=>(d-s-(Ie.length-1)*b)/swe(Ie,awe));for(const Ie of Pe){let Se=s;for(const Ce of Ie){Ce.y0=Se,Ce.y1=Se+Ce.value*je,Se=Ce.y1+b;for(const ke of Ce.sourceLinks)ke.width=ke.value*je}Se=(d-Se+b)/(Ie.length+1);for(let Ce=0;CeIe.length)-1)),be(je);for(let Ie=0;Ie0))continue;let gn=(Ft/Ne-Ke.y0)*je;Ke.y0+=gn,Ke.y1+=gn,W(Ke)}_===void 0&&ke.sort(RJ),de(ke,Ie)}}function se(Pe,je,Ie){for(let Se=Pe.length,Ce=Se-2;Ce>=0;--Ce){const ke=Pe[Ce];for(const Ke of ke){let Ft=0,Ne=0;for(const{target:_t,value:Et}of Ke.sourceLinks){let Gt=Et*(_t.layer-Ke.layer);Ft+=Fe(Ke,_t)*Gt,Ne+=Gt}if(!(Ne>0))continue;let gn=(Ft/Ne-Ke.y0)*je;Ke.y0+=gn,Ke.y1+=gn,W(Ke)}_===void 0&&ke.sort(RJ),de(ke,Ie)}}function de(Pe,je){const Ie=Pe.length>>1,Se=Pe[Ie];ge(Pe,Se.y0-b,Ie-1,je),X(Pe,Se.y1+b,Ie+1,je),ge(Pe,d,Pe.length-1,je),X(Pe,s,0,je)}function X(Pe,je,Ie,Se){for(;Ie1e-6&&(Ce.y0+=ke,Ce.y1+=ke),je=Ce.y1+b}}function ge(Pe,je,Ie,Se){for(;Ie>=0;--Ie){const Ce=Pe[Ie],ke=(Ce.y1-je)*Se;ke>1e-6&&(Ce.y0-=ke,Ce.y1-=ke),je=Ce.y0-b}}function W({sourceLinks:Pe,targetLinks:je}){if(A===void 0){for(const{source:{sourceLinks:Ie}}of je)Ie.sort(kWe);for(const{target:{targetLinks:Ie}}of Pe)Ie.sort(xWe)}}function xe(Pe){if(A===void 0)for(const{sourceLinks:je,targetLinks:Ie}of Pe)je.sort(kWe),Ie.sort(xWe)}function U(Pe,je){let Ie=Pe.y0-(Pe.sourceLinks.length-1)*b/2;for(const{target:Se,width:Ce}of Pe.sourceLinks){if(Se===je)break;Ie+=Ce+b}for(const{source:Se,width:Ce}of je.targetLinks){if(Se===Pe)break;Ie-=Ce}return Ie}function Fe(Pe,je){let Ie=je.y0-(je.targetLinks.length-1)*b/2;for(const{source:Se,width:Ce}of je.targetLinks){if(Se===Pe)break;Ie+=Ce+b}for(const{target:Se,width:Ce}of Pe.sourceLinks){if(Se===je)break;Ie-=Ce}return Ie}return j}var owe=Math.PI,cwe=2*owe,aS=1e-6,Gon=cwe-aS;function uwe(){this._x0=this._y0=this._x1=this._y1=null,this._=""}function CWe(){return new uwe}uwe.prototype=CWe.prototype={constructor:uwe,moveTo:function(i,s){this._+="M"+(this._x0=this._x1=+i)+","+(this._y0=this._y1=+s)},closePath:function(){this._x1!==null&&(this._x1=this._x0,this._y1=this._y0,this._+="Z")},lineTo:function(i,s){this._+="L"+(this._x1=+i)+","+(this._y1=+s)},quadraticCurveTo:function(i,s,u,d){this._+="Q"+ +i+","+ +s+","+(this._x1=+u)+","+(this._y1=+d)},bezierCurveTo:function(i,s,u,d,p,v){this._+="C"+ +i+","+ +s+","+ +u+","+ +d+","+(this._x1=+p)+","+(this._y1=+v)},arcTo:function(i,s,u,d,p){i=+i,s=+s,u=+u,d=+d,p=+p;var v=this._x1,b=this._y1,y=u-i,T=d-s,_=v-i,A=b-s,P=_*_+A*A;if(p<0)throw new Error("negative radius: "+p);if(this._x1===null)this._+="M"+(this._x1=i)+","+(this._y1=s);else if(P>aS)if(!(Math.abs(A*y-T*_)>aS)||!p)this._+="L"+(this._x1=i)+","+(this._y1=s);else{var R=u-v,F=d-b,j=y*y+T*T,K=R*R+F*F,ee=Math.sqrt(j),ie=Math.sqrt(P),oe=p*Math.tan((owe-Math.acos((j+P-K)/(2*ee*ie)))/2),pe=oe/ie,be=oe/ee;Math.abs(pe-1)>aS&&(this._+="L"+(i+pe*_)+","+(s+pe*A)),this._+="A"+p+","+p+",0,0,"+ +(A*R>_*F)+","+(this._x1=i+be*y)+","+(this._y1=s+be*T)}},arc:function(i,s,u,d,p,v){i=+i,s=+s,u=+u,v=!!v;var b=u*Math.cos(d),y=u*Math.sin(d),T=i+b,_=s+y,A=1^v,P=v?d-p:p-d;if(u<0)throw new Error("negative radius: "+u);this._x1===null?this._+="M"+T+","+_:(Math.abs(this._x1-T)>aS||Math.abs(this._y1-_)>aS)&&(this._+="L"+T+","+_),u&&(P<0&&(P=P%cwe+cwe),P>Gon?this._+="A"+u+","+u+",0,1,"+A+","+(i-b)+","+(s-y)+"A"+u+","+u+",0,1,"+A+","+(this._x1=T)+","+(this._y1=_):P>aS&&(this._+="A"+u+","+u+",0,"+ +(P>=owe)+","+A+","+(this._x1=i+u*Math.cos(p))+","+(this._y1=s+u*Math.sin(p))))},rect:function(i,s,u,d){this._+="M"+(this._x0=this._x1=+i)+","+(this._y0=this._y1=+s)+"h"+ +u+"v"+ +d+"h"+-u+"Z"},toString:function(){return this._}};function SWe(i){return function(){return i}}function Kon(i){return i[0]}function Won(i){return i[1]}var Yon=Array.prototype.slice;function Xon(i){return i.source}function Qon(i){return i.target}function Jon(i){var s=Xon,u=Qon,d=Kon,p=Won,v=null;function b(){var y,T=Yon.call(arguments),_=s.apply(this,T),A=u.apply(this,T);if(v||(v=y=CWe()),i(v,+d.apply(this,(T[0]=_,T)),+p.apply(this,T),+d.apply(this,(T[0]=A,T)),+p.apply(this,T)),y)return v=null,y+""||null}return b.source=function(y){return arguments.length?(s=y,b):s},b.target=function(y){return arguments.length?(u=y,b):u},b.x=function(y){return arguments.length?(d=typeof y=="function"?y:SWe(+y),b):d},b.y=function(y){return arguments.length?(p=typeof y=="function"?y:SWe(+y),b):p},b.context=function(y){return arguments.length?(v=y??null,b):v},b}function Zon(i,s,u,d,p){i.moveTo(s,u),i.bezierCurveTo(s=(s+d)/2,u,s,p,d,p)}function ecn(){return Jon(Zon)}function tcn(i){return[i.source.x1,i.y0]}function ncn(i){return[i.target.x0,i.y1]}function rcn(){return ecn().source(tcn).target(ncn)}const _We=class aBe{static next(s){return new aBe(s+ ++aBe.count)}constructor(s){this.id=s,this.href=`#${s}`}toString(){return"url("+this.href+")"}};_We.count=0;let AWe=_We;const icn={left:jon,right:$on,center:zon,justify:yWe},scn={draw:function(i,s,u,d){const{securityLevel:p,sankey:v}=qt(),b=Zje.sankey;let y;p==="sandbox"&&(y=Ir("#i"+s));const T=Ir(p==="sandbox"?y.nodes()[0].contentDocument.body:"body"),_=p==="sandbox"?T.select(`[id="${s}"]`):Ir(`[id="${s}"]`),A=(v==null?void 0:v.width)??b.width,P=(v==null?void 0:v.height)??b.width,R=(v==null?void 0:v.useMaxWidth)??b.useMaxWidth,F=(v==null?void 0:v.nodeAlignment)??b.nodeAlignment,j=(v==null?void 0:v.prefix)??b.prefix,K=(v==null?void 0:v.suffix)??b.suffix,ee=(v==null?void 0:v.showValues)??b.showValues,ie=d.db.getGraph(),oe=icn[F],pe=10;Uon().nodeId(ge=>ge.id).nodeWidth(pe).nodePadding(10+(ee?15:0)).nodeAlign(oe).extent([[0,0],[A,P]])(ie);const ae=_F(zFe);_.append("g").attr("class","nodes").selectAll(".node").data(ie.nodes).join("g").attr("class","node").attr("id",ge=>(ge.uid=AWe.next("node-")).id).attr("transform",function(ge){return"translate("+ge.x0+","+ge.y0+")"}).attr("x",ge=>ge.x0).attr("y",ge=>ge.y0).append("rect").attr("height",ge=>ge.y1-ge.y0).attr("width",ge=>ge.x1-ge.x0).attr("fill",ge=>ae(ge.id));const ne=({id:ge,value:W})=>ee?`${ge} +${j}${Math.round(W*100)/100}${K}`:ge;_.append("g").attr("class","node-labels").attr("font-family","sans-serif").attr("font-size",14).selectAll("text").data(ie.nodes).join("text").attr("x",ge=>ge.x0
    (ge.y1+ge.y0)/2).attr("dy",`${ee?"0":"0.35"}em`).attr("text-anchor",ge=>ge.x0(W.uid=AWe.next("linearGradient-")).id).attr("gradientUnits","userSpaceOnUse").attr("x1",W=>W.source.x1).attr("x2",W=>W.target.x0);ge.append("stop").attr("offset","0%").attr("stop-color",W=>ae(W.source.id)),ge.append("stop").attr("offset","100%").attr("stop-color",W=>ae(W.target.id))}let X;switch(de){case"gradient":X=ge=>ge.uid;break;case"source":X=ge=>ae(ge.source.id);break;case"target":X=ge=>ae(ge.target.id);break;default:X=de}se.append("path").attr("d",rcn()).attr("stroke",X).attr("stroke-width",ge=>Math.max(1,ge.width)),y9(void 0,_,0,R)}},acn=i=>i.replaceAll(/^[^\S\n\r]+|[^\S\n\r]+$/g,"").replaceAll(/([\n\r])+/g,` +`).trim(),ocn=NJ.parse.bind(NJ);NJ.parse=i=>ocn(acn(i));const ccn=Object.freeze(Object.defineProperty({__proto__:null,diagram:{parser:NJ,db:Fon,renderer:scn}},Symbol.toStringTag,{value:"Module"}));var lwe=function(){var i=function(pe,be,ae,ne){for(ae=ae||{},ne=pe.length;ne--;ae[pe[ne]]=be);return ae},s=[1,7],u=[1,13],d=[1,14],p=[1,15],v=[1,19],b=[1,16],y=[1,17],T=[1,18],_=[8,30],A=[8,21,28,29,30,31,32,40,44,47],P=[1,23],R=[1,24],F=[8,15,16,21,28,29,30,31,32,40,44,47],j=[8,15,16,21,27,28,29,30,31,32,40,44,47],K=[1,49],ee={trace:function(){},yy:{},symbols_:{error:2,spaceLines:3,SPACELINE:4,NL:5,separator:6,SPACE:7,EOF:8,start:9,BLOCK_DIAGRAM_KEY:10,document:11,stop:12,statement:13,link:14,LINK:15,START_LINK:16,LINK_LABEL:17,STR:18,nodeStatement:19,columnsStatement:20,SPACE_BLOCK:21,blockStatement:22,classDefStatement:23,cssClassStatement:24,styleStatement:25,node:26,SIZE:27,COLUMNS:28,"id-block":29,end:30,block:31,NODE_ID:32,nodeShapeNLabel:33,dirList:34,DIR:35,NODE_DSTART:36,NODE_DEND:37,BLOCK_ARROW_START:38,BLOCK_ARROW_END:39,classDef:40,CLASSDEF_ID:41,CLASSDEF_STYLEOPTS:42,DEFAULT:43,class:44,CLASSENTITY_IDS:45,STYLECLASS:46,style:47,STYLE_ENTITY_IDS:48,STYLE_DEFINITION_DATA:49,$accept:0,$end:1},terminals_:{2:"error",4:"SPACELINE",5:"NL",7:"SPACE",8:"EOF",10:"BLOCK_DIAGRAM_KEY",15:"LINK",16:"START_LINK",17:"LINK_LABEL",18:"STR",21:"SPACE_BLOCK",27:"SIZE",28:"COLUMNS",29:"id-block",30:"end",31:"block",32:"NODE_ID",35:"DIR",36:"NODE_DSTART",37:"NODE_DEND",38:"BLOCK_ARROW_START",39:"BLOCK_ARROW_END",40:"classDef",41:"CLASSDEF_ID",42:"CLASSDEF_STYLEOPTS",43:"DEFAULT",44:"class",45:"CLASSENTITY_IDS",46:"STYLECLASS",47:"style",48:"STYLE_ENTITY_IDS",49:"STYLE_DEFINITION_DATA"},productions_:[0,[3,1],[3,2],[3,2],[6,1],[6,1],[6,1],[9,3],[12,1],[12,1],[12,2],[12,2],[11,1],[11,2],[14,1],[14,4],[13,1],[13,1],[13,1],[13,1],[13,1],[13,1],[13,1],[19,3],[19,2],[19,1],[20,1],[22,4],[22,3],[26,1],[26,2],[34,1],[34,2],[33,3],[33,4],[23,3],[23,3],[24,3],[25,3]],performAction:function(be,ae,ne,se,de,X,ge){var W=X.length-1;switch(de){case 4:se.getLogger().debug("Rule: separator (NL) ");break;case 5:se.getLogger().debug("Rule: separator (Space) ");break;case 6:se.getLogger().debug("Rule: separator (EOF) ");break;case 7:se.getLogger().debug("Rule: hierarchy: ",X[W-1]),se.setHierarchy(X[W-1]);break;case 8:se.getLogger().debug("Stop NL ");break;case 9:se.getLogger().debug("Stop EOF ");break;case 10:se.getLogger().debug("Stop NL2 ");break;case 11:se.getLogger().debug("Stop EOF2 ");break;case 12:se.getLogger().debug("Rule: statement: ",X[W]),typeof X[W].length=="number"?this.$=X[W]:this.$=[X[W]];break;case 13:se.getLogger().debug("Rule: statement #2: ",X[W-1]),this.$=[X[W-1]].concat(X[W]);break;case 14:se.getLogger().debug("Rule: link: ",X[W],be),this.$={edgeTypeStr:X[W],label:""};break;case 15:se.getLogger().debug("Rule: LABEL link: ",X[W-3],X[W-1],X[W]),this.$={edgeTypeStr:X[W],label:X[W-1]};break;case 18:const xe=parseInt(X[W]),U=se.generateId();this.$={id:U,type:"space",label:"",width:xe,children:[]};break;case 23:se.getLogger().debug("Rule: (nodeStatement link node) ",X[W-2],X[W-1],X[W]," typestr: ",X[W-1].edgeTypeStr);const Fe=se.edgeStrToEdgeData(X[W-1].edgeTypeStr);this.$=[{id:X[W-2].id,label:X[W-2].label,type:X[W-2].type,directions:X[W-2].directions},{id:X[W-2].id+"-"+X[W].id,start:X[W-2].id,end:X[W].id,label:X[W-1].label,type:"edge",directions:X[W].directions,arrowTypeEnd:Fe,arrowTypeStart:"arrow_open"},{id:X[W].id,label:X[W].label,type:se.typeStr2Type(X[W].typeStr),directions:X[W].directions}];break;case 24:se.getLogger().debug("Rule: nodeStatement (abc88 node size) ",X[W-1],X[W]),this.$={id:X[W-1].id,label:X[W-1].label,type:se.typeStr2Type(X[W-1].typeStr),directions:X[W-1].directions,widthInColumns:parseInt(X[W],10)};break;case 25:se.getLogger().debug("Rule: nodeStatement (node) ",X[W]),this.$={id:X[W].id,label:X[W].label,type:se.typeStr2Type(X[W].typeStr),directions:X[W].directions,widthInColumns:1};break;case 26:se.getLogger().debug("APA123",this?this:"na"),se.getLogger().debug("COLUMNS: ",X[W]),this.$={type:"column-setting",columns:X[W]==="auto"?-1:parseInt(X[W])};break;case 27:se.getLogger().debug("Rule: id-block statement : ",X[W-2],X[W-1]),se.generateId(),this.$={...X[W-2],type:"composite",children:X[W-1]};break;case 28:se.getLogger().debug("Rule: blockStatement : ",X[W-2],X[W-1],X[W]);const Pe=se.generateId();this.$={id:Pe,type:"composite",label:"",children:X[W-1]};break;case 29:se.getLogger().debug("Rule: node (NODE_ID separator): ",X[W]),this.$={id:X[W]};break;case 30:se.getLogger().debug("Rule: node (NODE_ID nodeShapeNLabel separator): ",X[W-1],X[W]),this.$={id:X[W-1],label:X[W].label,typeStr:X[W].typeStr,directions:X[W].directions};break;case 31:se.getLogger().debug("Rule: dirList: ",X[W]),this.$=[X[W]];break;case 32:se.getLogger().debug("Rule: dirList: ",X[W-1],X[W]),this.$=[X[W-1]].concat(X[W]);break;case 33:se.getLogger().debug("Rule: nodeShapeNLabel: ",X[W-2],X[W-1],X[W]),this.$={typeStr:X[W-2]+X[W],label:X[W-1]};break;case 34:se.getLogger().debug("Rule: BLOCK_ARROW nodeShapeNLabel: ",X[W-3],X[W-2]," #3:",X[W-1],X[W]),this.$={typeStr:X[W-3]+X[W],label:X[W-2],directions:X[W-1]};break;case 35:case 36:this.$={type:"classDef",id:X[W-1].trim(),css:X[W].trim()};break;case 37:this.$={type:"applyClass",id:X[W-1].trim(),styleClass:X[W].trim()};break;case 38:this.$={type:"applyStyles",id:X[W-1].trim(),stylesStr:X[W].trim()};break}},table:[{9:1,10:[1,2]},{1:[3]},{11:3,13:4,19:5,20:6,21:s,22:8,23:9,24:10,25:11,26:12,28:u,29:d,31:p,32:v,40:b,44:y,47:T},{8:[1,20]},i(_,[2,12],{13:4,19:5,20:6,22:8,23:9,24:10,25:11,26:12,11:21,21:s,28:u,29:d,31:p,32:v,40:b,44:y,47:T}),i(A,[2,16],{14:22,15:P,16:R}),i(A,[2,17]),i(A,[2,18]),i(A,[2,19]),i(A,[2,20]),i(A,[2,21]),i(A,[2,22]),i(F,[2,25],{27:[1,25]}),i(A,[2,26]),{19:26,26:12,32:v},{11:27,13:4,19:5,20:6,21:s,22:8,23:9,24:10,25:11,26:12,28:u,29:d,31:p,32:v,40:b,44:y,47:T},{41:[1,28],43:[1,29]},{45:[1,30]},{48:[1,31]},i(j,[2,29],{33:32,36:[1,33],38:[1,34]}),{1:[2,7]},i(_,[2,13]),{26:35,32:v},{32:[2,14]},{17:[1,36]},i(F,[2,24]),{11:37,13:4,14:22,15:P,16:R,19:5,20:6,21:s,22:8,23:9,24:10,25:11,26:12,28:u,29:d,31:p,32:v,40:b,44:y,47:T},{30:[1,38]},{42:[1,39]},{42:[1,40]},{46:[1,41]},{49:[1,42]},i(j,[2,30]),{18:[1,43]},{18:[1,44]},i(F,[2,23]),{18:[1,45]},{30:[1,46]},i(A,[2,28]),i(A,[2,35]),i(A,[2,36]),i(A,[2,37]),i(A,[2,38]),{37:[1,47]},{34:48,35:K},{15:[1,50]},i(A,[2,27]),i(j,[2,33]),{39:[1,51]},{34:52,35:K,39:[2,31]},{32:[2,15]},i(j,[2,34]),{39:[2,32]}],defaultActions:{20:[2,7],23:[2,14],50:[2,15],52:[2,32]},parseError:function(be,ae){if(ae.recoverable)this.trace(be);else{var ne=new Error(be);throw ne.hash=ae,ne}},parse:function(be){var ae=this,ne=[0],se=[],de=[null],X=[],ge=this.table,W="",xe=0,U=0,Fe=2,Pe=1,je=X.slice.call(arguments,1),Ie=Object.create(this.lexer),Se={yy:{}};for(var Ce in this.yy)Object.prototype.hasOwnProperty.call(this.yy,Ce)&&(Se.yy[Ce]=this.yy[Ce]);Ie.setInput(be,Se.yy),Se.yy.lexer=Ie,Se.yy.parser=this,typeof Ie.yylloc>"u"&&(Ie.yylloc={});var ke=Ie.yylloc;X.push(ke);var Ke=Ie.options&&Ie.options.ranges;typeof Se.yy.parseError=="function"?this.parseError=Se.yy.parseError:this.parseError=Object.getPrototypeOf(this).parseError;function Ft(){var kt;return kt=se.pop()||Ie.lex()||Pe,typeof kt!="number"&&(kt instanceof Array&&(se=kt,kt=se.pop()),kt=ae.symbols_[kt]||kt),kt}for(var Ne,gn,_t,Et,Gt={},ln,xt,Pt,Qe;;){if(gn=ne[ne.length-1],this.defaultActions[gn]?_t=this.defaultActions[gn]:((Ne===null||typeof Ne>"u")&&(Ne=Ft()),_t=ge[gn]&&ge[gn][Ne]),typeof _t>"u"||!_t.length||!_t[0]){var Dt="";Qe=[];for(ln in ge[gn])this.terminals_[ln]&&ln>Fe&&Qe.push("'"+this.terminals_[ln]+"'");Ie.showPosition?Dt="Parse error on line "+(xe+1)+`: +`+Ie.showPosition()+` +Expecting `+Qe.join(", ")+", got '"+(this.terminals_[Ne]||Ne)+"'":Dt="Parse error on line "+(xe+1)+": Unexpected "+(Ne==Pe?"end of input":"'"+(this.terminals_[Ne]||Ne)+"'"),this.parseError(Dt,{text:Ie.match,token:this.terminals_[Ne]||Ne,line:Ie.yylineno,loc:ke,expected:Qe})}if(_t[0]instanceof Array&&_t.length>1)throw new Error("Parse Error: multiple actions possible at state: "+gn+", token: "+Ne);switch(_t[0]){case 1:ne.push(Ne),de.push(Ie.yytext),X.push(Ie.yylloc),ne.push(_t[1]),Ne=null,U=Ie.yyleng,W=Ie.yytext,xe=Ie.yylineno,ke=Ie.yylloc;break;case 2:if(xt=this.productions_[_t[1]][1],Gt.$=de[de.length-xt],Gt._$={first_line:X[X.length-(xt||1)].first_line,last_line:X[X.length-1].last_line,first_column:X[X.length-(xt||1)].first_column,last_column:X[X.length-1].last_column},Ke&&(Gt._$.range=[X[X.length-(xt||1)].range[0],X[X.length-1].range[1]]),Et=this.performAction.apply(Gt,[W,U,xe,Se.yy,_t[1],de,X].concat(je)),typeof Et<"u")return Et;xt&&(ne=ne.slice(0,-1*xt*2),de=de.slice(0,-1*xt),X=X.slice(0,-1*xt)),ne.push(this.productions_[_t[1]][0]),de.push(Gt.$),X.push(Gt._$),Pt=ge[ne[ne.length-2]][ne[ne.length-1]],ne.push(Pt);break;case 3:return!0}}return!0}},ie=function(){var pe={EOF:1,parseError:function(ae,ne){if(this.yy.parser)this.yy.parser.parseError(ae,ne);else throw new Error(ae)},setInput:function(be,ae){return this.yy=ae||this.yy||{},this._input=be,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},input:function(){var be=this._input[0];this.yytext+=be,this.yyleng++,this.offset++,this.match+=be,this.matched+=be;var ae=be.match(/(?:\r\n?|\n).*/g);return ae?(this.yylineno++,this.yylloc.last_line++):this.yylloc.last_column++,this.options.ranges&&this.yylloc.range[1]++,this._input=this._input.slice(1),be},unput:function(be){var ae=be.length,ne=be.split(/(?:\r\n?|\n)/g);this._input=be+this._input,this.yytext=this.yytext.substr(0,this.yytext.length-ae),this.offset-=ae;var se=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),ne.length-1&&(this.yylineno-=ne.length-1);var de=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:ne?(ne.length===se.length?this.yylloc.first_column:0)+se[se.length-ne.length].length-ne[0].length:this.yylloc.first_column-ae},this.options.ranges&&(this.yylloc.range=[de[0],de[0]+this.yyleng-ae]),this.yyleng=this.yytext.length,this},more:function(){return this._more=!0,this},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},less:function(be){this.unput(this.match.slice(be))},pastInput:function(){var be=this.matched.substr(0,this.matched.length-this.match.length);return(be.length>20?"...":"")+be.substr(-20).replace(/\n/g,"")},upcomingInput:function(){var be=this.match;return be.length<20&&(be+=this._input.substr(0,20-be.length)),(be.substr(0,20)+(be.length>20?"...":"")).replace(/\n/g,"")},showPosition:function(){var be=this.pastInput(),ae=new Array(be.length+1).join("-");return be+this.upcomingInput()+` +`+ae+"^"},test_match:function(be,ae){var ne,se,de;if(this.options.backtrack_lexer&&(de={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&&(de.yylloc.range=this.yylloc.range.slice(0))),se=be[0].match(/(?:\r\n?|\n).*/g),se&&(this.yylineno+=se.length),this.yylloc={first_line:this.yylloc.last_line,last_line:this.yylineno+1,first_column:this.yylloc.last_column,last_column:se?se[se.length-1].length-se[se.length-1].match(/\r?\n?/)[0].length:this.yylloc.last_column+be[0].length},this.yytext+=be[0],this.match+=be[0],this.matches=be,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(be[0].length),this.matched+=be[0],ne=this.performAction.call(this,this.yy,this,ae,this.conditionStack[this.conditionStack.length-1]),this.done&&this._input&&(this.done=!1),ne)return ne;if(this._backtrack){for(var X in de)this[X]=de[X];return!1}return!1},next:function(){if(this.done)return this.EOF;this._input||(this.done=!0);var be,ae,ne,se;this._more||(this.yytext="",this.match="");for(var de=this._currentRules(),X=0;Xae[0].length)){if(ae=ne,se=X,this.options.backtrack_lexer){if(be=this.test_match(ne,de[X]),be!==!1)return be;if(this._backtrack){ae=!1;continue}else return!1}else if(!this.options.flex)break}return ae?(be=this.test_match(ae,de[se]),be!==!1?be:!1):this._input===""?this.EOF:this.parseError("Lexical error on line "+(this.yylineno+1)+`. Unrecognized text. +`+this.showPosition(),{text:"",token:null,line:this.yylineno})},lex:function(){var ae=this.next();return ae||this.lex()},begin:function(ae){this.conditionStack.push(ae)},popState:function(){var ae=this.conditionStack.length-1;return ae>0?this.conditionStack.pop():this.conditionStack[0]},_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},topState:function(ae){return ae=this.conditionStack.length-1-Math.abs(ae||0),ae>=0?this.conditionStack[ae]:"INITIAL"},pushState:function(ae){this.begin(ae)},stateStackSize:function(){return this.conditionStack.length},options:{},performAction:function(ae,ne,se,de){switch(se){case 0:return 10;case 1:return ae.getLogger().debug("Found space-block"),31;case 2:return ae.getLogger().debug("Found nl-block"),31;case 3:return ae.getLogger().debug("Found space-block"),29;case 4:ae.getLogger().debug(".",ne.yytext);break;case 5:ae.getLogger().debug("_",ne.yytext);break;case 6:return 5;case 7:return ne.yytext=-1,28;case 8:return ne.yytext=ne.yytext.replace(/columns\s+/,""),ae.getLogger().debug("COLUMNS (LEX)",ne.yytext),28;case 9:this.pushState("md_string");break;case 10:return"MD_STR";case 11:this.popState();break;case 12:this.pushState("string");break;case 13:ae.getLogger().debug("LEX: POPPING STR:",ne.yytext),this.popState();break;case 14:return ae.getLogger().debug("LEX: STR end:",ne.yytext),"STR";case 15:return ne.yytext=ne.yytext.replace(/space\:/,""),ae.getLogger().debug("SPACE NUM (LEX)",ne.yytext),21;case 16:return ne.yytext="1",ae.getLogger().debug("COLUMNS (LEX)",ne.yytext),21;case 17:return 43;case 18:return"LINKSTYLE";case 19:return"INTERPOLATE";case 20:return this.pushState("CLASSDEF"),40;case 21:return this.popState(),this.pushState("CLASSDEFID"),"DEFAULT_CLASSDEF_ID";case 22:return this.popState(),this.pushState("CLASSDEFID"),41;case 23:return this.popState(),42;case 24:return this.pushState("CLASS"),44;case 25:return this.popState(),this.pushState("CLASS_STYLE"),45;case 26:return this.popState(),46;case 27:return this.pushState("STYLE_STMNT"),47;case 28:return this.popState(),this.pushState("STYLE_DEFINITION"),48;case 29:return this.popState(),49;case 30:return this.pushState("acc_title"),"acc_title";case 31:return this.popState(),"acc_title_value";case 32:return this.pushState("acc_descr"),"acc_descr";case 33:return this.popState(),"acc_descr_value";case 34:this.pushState("acc_descr_multiline");break;case 35:this.popState();break;case 36:return"acc_descr_multiline_value";case 37:return 30;case 38:return this.popState(),ae.getLogger().debug("Lex: (("),"NODE_DEND";case 39:return this.popState(),ae.getLogger().debug("Lex: (("),"NODE_DEND";case 40:return this.popState(),ae.getLogger().debug("Lex: ))"),"NODE_DEND";case 41:return this.popState(),ae.getLogger().debug("Lex: (("),"NODE_DEND";case 42:return this.popState(),ae.getLogger().debug("Lex: (("),"NODE_DEND";case 43:return this.popState(),ae.getLogger().debug("Lex: (-"),"NODE_DEND";case 44:return this.popState(),ae.getLogger().debug("Lex: -)"),"NODE_DEND";case 45:return this.popState(),ae.getLogger().debug("Lex: (("),"NODE_DEND";case 46:return this.popState(),ae.getLogger().debug("Lex: ]]"),"NODE_DEND";case 47:return this.popState(),ae.getLogger().debug("Lex: ("),"NODE_DEND";case 48:return this.popState(),ae.getLogger().debug("Lex: ])"),"NODE_DEND";case 49:return this.popState(),ae.getLogger().debug("Lex: /]"),"NODE_DEND";case 50:return this.popState(),ae.getLogger().debug("Lex: /]"),"NODE_DEND";case 51:return this.popState(),ae.getLogger().debug("Lex: )]"),"NODE_DEND";case 52:return this.popState(),ae.getLogger().debug("Lex: )"),"NODE_DEND";case 53:return this.popState(),ae.getLogger().debug("Lex: ]>"),"NODE_DEND";case 54:return this.popState(),ae.getLogger().debug("Lex: ]"),"NODE_DEND";case 55:return ae.getLogger().debug("Lexa: -)"),this.pushState("NODE"),36;case 56:return ae.getLogger().debug("Lexa: (-"),this.pushState("NODE"),36;case 57:return ae.getLogger().debug("Lexa: ))"),this.pushState("NODE"),36;case 58:return ae.getLogger().debug("Lexa: )"),this.pushState("NODE"),36;case 59:return ae.getLogger().debug("Lex: ((("),this.pushState("NODE"),36;case 60:return ae.getLogger().debug("Lexa: )"),this.pushState("NODE"),36;case 61:return ae.getLogger().debug("Lexa: )"),this.pushState("NODE"),36;case 62:return ae.getLogger().debug("Lexa: )"),this.pushState("NODE"),36;case 63:return ae.getLogger().debug("Lexc: >"),this.pushState("NODE"),36;case 64:return ae.getLogger().debug("Lexa: (["),this.pushState("NODE"),36;case 65:return ae.getLogger().debug("Lexa: )"),this.pushState("NODE"),36;case 66:return this.pushState("NODE"),36;case 67:return this.pushState("NODE"),36;case 68:return this.pushState("NODE"),36;case 69:return this.pushState("NODE"),36;case 70:return this.pushState("NODE"),36;case 71:return this.pushState("NODE"),36;case 72:return this.pushState("NODE"),36;case 73:return ae.getLogger().debug("Lexa: ["),this.pushState("NODE"),36;case 74:return this.pushState("BLOCK_ARROW"),ae.getLogger().debug("LEX ARR START"),38;case 75:return ae.getLogger().debug("Lex: NODE_ID",ne.yytext),32;case 76:return ae.getLogger().debug("Lex: EOF",ne.yytext),8;case 77:this.pushState("md_string");break;case 78:this.pushState("md_string");break;case 79:return"NODE_DESCR";case 80:this.popState();break;case 81:ae.getLogger().debug("Lex: Starting string"),this.pushState("string");break;case 82:ae.getLogger().debug("LEX ARR: Starting string"),this.pushState("string");break;case 83:return ae.getLogger().debug("LEX: NODE_DESCR:",ne.yytext),"NODE_DESCR";case 84:ae.getLogger().debug("LEX POPPING"),this.popState();break;case 85:ae.getLogger().debug("Lex: =>BAE"),this.pushState("ARROW_DIR");break;case 86:return ne.yytext=ne.yytext.replace(/^,\s*/,""),ae.getLogger().debug("Lex (right): dir:",ne.yytext),"DIR";case 87:return ne.yytext=ne.yytext.replace(/^,\s*/,""),ae.getLogger().debug("Lex (left):",ne.yytext),"DIR";case 88:return ne.yytext=ne.yytext.replace(/^,\s*/,""),ae.getLogger().debug("Lex (x):",ne.yytext),"DIR";case 89:return ne.yytext=ne.yytext.replace(/^,\s*/,""),ae.getLogger().debug("Lex (y):",ne.yytext),"DIR";case 90:return ne.yytext=ne.yytext.replace(/^,\s*/,""),ae.getLogger().debug("Lex (up):",ne.yytext),"DIR";case 91:return ne.yytext=ne.yytext.replace(/^,\s*/,""),ae.getLogger().debug("Lex (down):",ne.yytext),"DIR";case 92:return ne.yytext="]>",ae.getLogger().debug("Lex (ARROW_DIR end):",ne.yytext),this.popState(),this.popState(),"BLOCK_ARROW_END";case 93:return ae.getLogger().debug("Lex: LINK","#"+ne.yytext+"#"),15;case 94:return ae.getLogger().debug("Lex: LINK",ne.yytext),15;case 95:return ae.getLogger().debug("Lex: LINK",ne.yytext),15;case 96:return ae.getLogger().debug("Lex: LINK",ne.yytext),15;case 97:return ae.getLogger().debug("Lex: START_LINK",ne.yytext),this.pushState("LLABEL"),16;case 98:return ae.getLogger().debug("Lex: START_LINK",ne.yytext),this.pushState("LLABEL"),16;case 99:return ae.getLogger().debug("Lex: START_LINK",ne.yytext),this.pushState("LLABEL"),16;case 100:this.pushState("md_string");break;case 101:return ae.getLogger().debug("Lex: Starting string"),this.pushState("string"),"LINK_LABEL";case 102:return this.popState(),ae.getLogger().debug("Lex: LINK","#"+ne.yytext+"#"),15;case 103:return this.popState(),ae.getLogger().debug("Lex: LINK",ne.yytext),15;case 104:return this.popState(),ae.getLogger().debug("Lex: LINK",ne.yytext),15;case 105:return ae.getLogger().debug("Lex: COLON",ne.yytext),ne.yytext=ne.yytext.slice(1),27}},rules:[/^(?:block-beta\b)/,/^(?:block\s+)/,/^(?:block\n+)/,/^(?:block:)/,/^(?:[\s]+)/,/^(?:[\n]+)/,/^(?:((\u000D\u000A)|(\u000A)))/,/^(?:columns\s+auto\b)/,/^(?:columns\s+[\d]+)/,/^(?:["][`])/,/^(?:[^`"]+)/,/^(?:[`]["])/,/^(?:["])/,/^(?:["])/,/^(?:[^"]*)/,/^(?:space[:]\d+)/,/^(?:space\b)/,/^(?:default\b)/,/^(?:linkStyle\b)/,/^(?:interpolate\b)/,/^(?:classDef\s+)/,/^(?:DEFAULT\s+)/,/^(?:\w+\s+)/,/^(?:[^\n]*)/,/^(?:class\s+)/,/^(?:(\w+)+((,\s*\w+)*))/,/^(?:[^\n]*)/,/^(?:style\s+)/,/^(?:(\w+)+((,\s*\w+)*))/,/^(?:[^\n]*)/,/^(?:accTitle\s*:\s*)/,/^(?:(?!\n||)*[^\n]*)/,/^(?:accDescr\s*:\s*)/,/^(?:(?!\n||)*[^\n]*)/,/^(?:accDescr\s*\{\s*)/,/^(?:[\}])/,/^(?:[^\}]*)/,/^(?:end\b\s*)/,/^(?:\(\(\()/,/^(?:\)\)\))/,/^(?:[\)]\))/,/^(?:\}\})/,/^(?:\})/,/^(?:\(-)/,/^(?:-\))/,/^(?:\(\()/,/^(?:\]\])/,/^(?:\()/,/^(?:\]\))/,/^(?:\\\])/,/^(?:\/\])/,/^(?:\)\])/,/^(?:[\)])/,/^(?:\]>)/,/^(?:[\]])/,/^(?:-\))/,/^(?:\(-)/,/^(?:\)\))/,/^(?:\))/,/^(?:\(\(\()/,/^(?:\(\()/,/^(?:\{\{)/,/^(?:\{)/,/^(?:>)/,/^(?:\(\[)/,/^(?:\()/,/^(?:\[\[)/,/^(?:\[\|)/,/^(?:\[\()/,/^(?:\)\)\))/,/^(?:\[\\)/,/^(?:\[\/)/,/^(?:\[\\)/,/^(?:\[)/,/^(?:<\[)/,/^(?:[^\(\[\n\-\)\{\}\s\<\>:]+)/,/^(?:$)/,/^(?:["][`])/,/^(?:["][`])/,/^(?:[^`"]+)/,/^(?:[`]["])/,/^(?:["])/,/^(?:["])/,/^(?:[^"]+)/,/^(?:["])/,/^(?:\]>\s*\()/,/^(?:,?\s*right\s*)/,/^(?:,?\s*left\s*)/,/^(?:,?\s*x\s*)/,/^(?:,?\s*y\s*)/,/^(?:,?\s*up\s*)/,/^(?:,?\s*down\s*)/,/^(?:\)\s*)/,/^(?:\s*[xo<]?--+[-xo>]\s*)/,/^(?:\s*[xo<]?==+[=xo>]\s*)/,/^(?:\s*[xo<]?-?\.+-[xo>]?\s*)/,/^(?:\s*~~[\~]+\s*)/,/^(?:\s*[xo<]?--\s*)/,/^(?:\s*[xo<]?==\s*)/,/^(?:\s*[xo<]?-\.\s*)/,/^(?:["][`])/,/^(?:["])/,/^(?:\s*[xo<]?--+[-xo>]\s*)/,/^(?:\s*[xo<]?==+[=xo>]\s*)/,/^(?:\s*[xo<]?-?\.+-[xo>]?\s*)/,/^(?::\d+)/],conditions:{STYLE_DEFINITION:{rules:[29],inclusive:!1},STYLE_STMNT:{rules:[28],inclusive:!1},CLASSDEFID:{rules:[23],inclusive:!1},CLASSDEF:{rules:[21,22],inclusive:!1},CLASS_STYLE:{rules:[26],inclusive:!1},CLASS:{rules:[25],inclusive:!1},LLABEL:{rules:[100,101,102,103,104],inclusive:!1},ARROW_DIR:{rules:[86,87,88,89,90,91,92],inclusive:!1},BLOCK_ARROW:{rules:[77,82,85],inclusive:!1},NODE:{rules:[38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,78,81],inclusive:!1},md_string:{rules:[10,11,79,80],inclusive:!1},space:{rules:[],inclusive:!1},string:{rules:[13,14,83,84],inclusive:!1},acc_descr_multiline:{rules:[35,36],inclusive:!1},acc_descr:{rules:[33],inclusive:!1},acc_title:{rules:[31],inclusive:!1},INITIAL:{rules:[0,1,2,3,4,5,6,7,8,9,12,15,16,17,18,19,20,24,27,30,32,34,37,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,93,94,95,96,97,98,99,105],inclusive:!0}}};return pe}();ee.lexer=ie;function oe(){this.yy={}}return oe.prototype=ee,ee.Parser=oe,new oe}();lwe.parser=lwe;const ucn=lwe;let U2={},hwe=[],ij={};const LWe="color",MWe="fill",lcn="bgFill",DWe=",",hcn=qt();let sj={};const fcn=i=>ci.sanitizeText(i,hcn),dcn=function(i,s=""){sj[i]===void 0&&(sj[i]={id:i,styles:[],textStyles:[]});const u=sj[i];s!=null&&s.split(DWe).forEach(d=>{const p=d.replace(/([^;]*);/,"$1").trim();if(d.match(LWe)){const b=p.replace(MWe,lcn).replace(LWe,MWe);u.textStyles.push(b)}u.styles.push(p)})},gcn=function(i,s=""){const u=U2[i];s!=null&&(u.styles=s.split(DWe))},pcn=function(i,s){i.split(",").forEach(function(u){let d=U2[u];if(d===void 0){const p=u.trim();U2[p]={id:p,type:"na",children:[]},d=U2[p]}d.classes||(d.classes=[]),d.classes.push(s)})},IWe=(i,s)=>{const u=i.flat(),d=[];for(const p of u){if(p.label&&(p.label=fcn(p.label)),p.type==="classDef"){dcn(p.id,p.css);continue}if(p.type==="applyClass"){pcn(p.id,(p==null?void 0:p.styleClass)||"");continue}if(p.type==="applyStyles"){p!=null&&p.stylesStr&&gcn(p.id,p==null?void 0:p.stylesStr);continue}if(p.type==="column-setting")s.columns=p.columns||-1;else if(p.type==="edge")ij[p.id]?ij[p.id]++:ij[p.id]=1,p.id=ij[p.id]+"-"+p.id,hwe.push(p);else{p.label||(p.type==="composite"?p.label="":p.label=p.id);const v=!U2[p.id];if(v?U2[p.id]=p:(p.type!=="na"&&(U2[p.id].type=p.type),p.label!==p.id&&(U2[p.id].label=p.label)),p.children&&IWe(p.children,p),p.type==="space"){const b=p.width||1;for(let y=0;y{Xe.debug("Clear called"),Pg(),aj={id:"root",type:"composite",children:[],columns:-1},U2={root:aj},fwe=[],sj={},hwe=[],ij={}};function mcn(i){switch(Xe.debug("typeStr2Type",i),i){case"[]":return"square";case"()":return Xe.debug("we have a round"),"round";case"(())":return"circle";case">]":return"rect_left_inv_arrow";case"{}":return"diamond";case"{{}}":return"hexagon";case"([])":return"stadium";case"[[]]":return"subroutine";case"[()]":return"cylinder";case"((()))":return"doublecircle";case"[//]":return"lean_right";case"[\\\\]":return"lean_left";case"[/\\]":return"trapezoid";case"[\\/]":return"inv_trapezoid";case"<[]>":return"block_arrow";default:return"na"}}function vcn(i){switch(Xe.debug("typeStr2Type",i),i){case"==":return"thick";default:return"normal"}}function wcn(i){switch(i.trim()){case"--x":return"arrow_cross";case"--o":return"arrow_circle";default:return"arrow_point"}}let OWe=0;const ycn={getConfig:()=>Vh().block,typeStr2Type:mcn,edgeTypeStr2Type:vcn,edgeStrToEdgeData:wcn,getLogger:()=>console,getBlocksFlat:()=>[...Object.values(U2)],getBlocks:()=>fwe||[],getEdges:()=>hwe,setHierarchy:i=>{aj.children=i,IWe(i,aj),fwe=aj.children},getBlock:i=>U2[i],setBlock:i=>{U2[i.id]=i},getColumns:i=>{const s=U2[i];return s?s.columns?s.columns:s.children?s.children.length:-1:-1},getClasses:function(){return sj},clear:bcn,generateId:()=>(OWe++,"id-"+Math.random().toString(36).substr(2,12)+"-"+OWe)},jJ=(i,s)=>{const u=ARe,d=u(i,"r"),p=u(i,"g"),v=u(i,"b");return SC(d,p,v,s)},xcn=i=>`.label { + font-family: ${i.fontFamily}; + color: ${i.nodeTextColor||i.textColor}; + } + .cluster-label text { + fill: ${i.titleColor}; + } + .cluster-label span,p { + color: ${i.titleColor}; + } + + + + .label text,span,p { + fill: ${i.nodeTextColor||i.textColor}; + color: ${i.nodeTextColor||i.textColor}; + } + + .node rect, + .node circle, + .node ellipse, + .node polygon, + .node path { + fill: ${i.mainBkg}; + stroke: ${i.nodeBorder}; + stroke-width: 1px; + } + .flowchart-label text { + text-anchor: middle; + } + // .flowchart-label .text-outer-tspan { + // text-anchor: middle; + // } + // .flowchart-label .text-inner-tspan { + // text-anchor: start; + // } + + .node .label { + text-align: center; + } + .node.clickable { + cursor: pointer; + } + + .arrowheadPath { + fill: ${i.arrowheadColor}; + } + + .edgePath .path { + stroke: ${i.lineColor}; + stroke-width: 2.0px; + } + + .flowchart-link { + stroke: ${i.lineColor}; + fill: none; + } + + .edgeLabel { + background-color: ${i.edgeLabelBackground}; + rect { + opacity: 0.5; + background-color: ${i.edgeLabelBackground}; + fill: ${i.edgeLabelBackground}; + } + text-align: center; + } + + /* For html labels only */ + .labelBkg { + background-color: ${jJ(i.edgeLabelBackground,.5)}; + // background-color: + } + + .node .cluster { + // fill: ${jJ(i.mainBkg,.5)}; + fill: ${jJ(i.clusterBkg,.5)}; + stroke: ${jJ(i.clusterBorder,.2)}; + box-shadow: rgba(50, 50, 93, 0.25) 0px 13px 27px -5px, rgba(0, 0, 0, 0.3) 0px 8px 16px -8px; + stroke-width: 1px; + } + + .cluster text { + fill: ${i.titleColor}; + } + + .cluster span,p { + color: ${i.titleColor}; + } + /* .cluster div { + color: ${i.titleColor}; + } */ + + div.mermaidTooltip { + position: absolute; + text-align: center; + max-width: 200px; + padding: 2px; + font-family: ${i.fontFamily}; + font-size: 12px; + background: ${i.tertiaryColor}; + border: 1px solid ${i.border2}; + border-radius: 2px; + pointer-events: none; + z-index: 100; + } + + .flowchartTitleText { + text-anchor: middle; + font-size: 18px; + fill: ${i.textColor}; + } +`;function NWe(i,s,u=!1){var R,F,j;const d=i;let p="default";(((R=d==null?void 0:d.classes)==null?void 0:R.length)||0)>0&&(p=((d==null?void 0:d.classes)||[]).join(" ")),p=p+" flowchart-label";let v=0,b="",y;switch(d.type){case"round":v=5,b="rect";break;case"composite":v=0,b="composite",y=0;break;case"square":b="rect";break;case"diamond":b="question";break;case"hexagon":b="hexagon";break;case"block_arrow":b="block_arrow";break;case"odd":b="rect_left_inv_arrow";break;case"lean_right":b="lean_right";break;case"lean_left":b="lean_left";break;case"trapezoid":b="trapezoid";break;case"inv_trapezoid":b="inv_trapezoid";break;case"rect_left_inv_arrow":b="rect_left_inv_arrow";break;case"circle":b="circle";break;case"ellipse":b="ellipse";break;case"stadium":b="stadium";break;case"subroutine":b="subroutine";break;case"cylinder":b="cylinder";break;case"group":b="rect";break;case"doublecircle":b="doublecircle";break;default:b="rect"}const T=om((d==null?void 0:d.styles)||[]),_=d.label,A=d.size||{width:0,height:0,x:0,y:0};return{labelStyle:T.labelStyle,shape:b,labelText:_,rx:v,ry:v,class:p,style:T.style,id:d.id,directions:d.directions,width:A.width,height:A.height,x:A.x,y:A.y,positioned:u,intersect:void 0,type:d.type,padding:y??(((j=(F=Vh())==null?void 0:F.block)==null?void 0:j.padding)||0)}}async function kcn(i,s,u){const d=NWe(s,u,!1);if(d.type==="group")return;const p=await tJ(i,d),v=p.node().getBBox(),b=u.getBlock(d.id);b.size={width:v.width,height:v.height,x:0,y:0,node:p},u.setBlock(b),p.remove()}async function Ecn(i,s,u){const d=NWe(s,u,!0);u.getBlock(d.id).type!=="space"&&(await tJ(i,d),s.intersect=d==null?void 0:d.intersect,$me(d))}async function dwe(i,s,u,d){for(const p of s)await d(i,p,u),p.children&&await dwe(i,p.children,u,d)}async function Tcn(i,s,u){await dwe(i,s,u,kcn)}async function Ccn(i,s,u){await dwe(i,s,u,Ecn)}async function Scn(i,s,u,d,p){const v=new B0({multigraph:!0,compound:!0});v.setGraph({rankdir:"TB",nodesep:10,ranksep:10,marginx:8,marginy:8});for(const b of u)b.size&&v.setNode(b.id,{width:b.size.width,height:b.size.height,intersect:b.intersect});for(const b of s)if(b.start&&b.end){const y=d.getBlock(b.start),T=d.getBlock(b.end);if(y!=null&&y.size&&(T!=null&&T.size)){const _=y.size,A=T.size,P=[{x:_.x,y:_.y},{x:_.x+(A.x-_.x)/2,y:_.y+(A.y-_.y)/2},{x:A.x,y:A.y}];await IUe(i,{v:b.start,w:b.end,name:b.id},{...b,arrowTypeEnd:b.arrowTypeEnd,arrowTypeStart:b.arrowTypeStart,points:P,classes:"edge-thickness-normal edge-pattern-solid flowchart-link LS-a1 LE-b1"},void 0,"block",v,p),b.label&&(await zme(i,{...b,label:b.label,labelStyle:"stroke: #333; stroke-width: 1.5px;fill:none;",arrowTypeEnd:b.arrowTypeEnd,arrowTypeStart:b.arrowTypeStart,points:P,classes:"edge-thickness-normal edge-pattern-solid flowchart-link LS-a1 LE-b1"}),await MUe({...b,x:P[1].x,y:P[1].y},{originalPath:P}))}}}const e0=((RWe=(FWe=qt())==null?void 0:FWe.block)==null?void 0:RWe.padding)||8;function _cn(i,s){if(i===0||!Number.isInteger(i))throw new Error("Columns must be an integer !== 0.");if(s<0||!Number.isInteger(s))throw new Error("Position must be a non-negative integer."+s);if(i<0)return{px:s,py:0};if(i===1)return{px:0,py:s};const u=s%i,d=Math.floor(s/i);return{px:u,py:d}}const Acn=i=>{let s=0,u=0;for(const d of i.children){const{width:p,height:v,x:b,y}=d.size||{width:0,height:0,x:0,y:0};Xe.debug("getMaxChildSize abc95 child:",d.id,"width:",p,"height:",v,"x:",b,"y:",y,d.type),d.type!=="space"&&(p>s&&(s=p/(i.widthInColumns||1)),v>u&&(u=v))}return{width:s,height:u}};function gwe(i,s,u=0,d=0){var b,y,T,_,A,P,R,F,j,K,ee;Xe.debug("setBlockSizes abc95 (start)",i.id,(b=i==null?void 0:i.size)==null?void 0:b.x,"block width =",i==null?void 0:i.size,"sieblingWidth",u),(y=i==null?void 0:i.size)!=null&&y.width||(i.size={width:u,height:d,x:0,y:0});let p=0,v=0;if(((T=i.children)==null?void 0:T.length)>0){for(const de of i.children)gwe(de,s);const ie=Acn(i);p=ie.width,v=ie.height,Xe.debug("setBlockSizes abc95 maxWidth of",i.id,":s children is ",p,v);for(const de of i.children)de.size&&(Xe.debug(`abc95 Setting size of children of ${i.id} id=${de.id} ${p} ${v} ${de.size}`),de.size.width=p*(de.widthInColumns||1)+e0*((de.widthInColumns||1)-1),de.size.height=v,de.size.x=0,de.size.y=0,Xe.debug(`abc95 updating size of ${i.id} children child:${de.id} maxWidth:${p} maxHeight:${v}`));for(const de of i.children)gwe(de,s,p,v);const oe=i.columns||-1;let pe=0;for(const de of i.children)pe+=de.widthInColumns||1;let be=i.children.length;oe>0&&oe0?Math.min(i.children.length,oe):i.children.length;if(de>0){const X=(ne-de*e0-e0)/de;Xe.debug("abc95 (growing to fit) width",i.id,ne,(R=i.size)==null?void 0:R.width,X);for(const ge of i.children)ge.size&&(ge.size.width=X)}}i.size={width:ne,height:se,x:0,y:0}}Xe.debug("setBlockSizes abc94 (done)",i.id,(F=i==null?void 0:i.size)==null?void 0:F.x,(j=i==null?void 0:i.size)==null?void 0:j.width,(K=i==null?void 0:i.size)==null?void 0:K.y,(ee=i==null?void 0:i.size)==null?void 0:ee.height)}function PWe(i,s){var d,p,v,b,y,T,_,A,P,R,F,j,K,ee,ie,oe,pe;Xe.debug(`abc85 layout blocks (=>layoutBlocks) ${i.id} x: ${(d=i==null?void 0:i.size)==null?void 0:d.x} y: ${(p=i==null?void 0:i.size)==null?void 0:p.y} width: ${(v=i==null?void 0:i.size)==null?void 0:v.width}`);const u=i.columns||-1;if(Xe.debug("layoutBlocks columns abc95",i.id,"=>",u,i),i.children&&i.children.length>0){const be=((y=(b=i==null?void 0:i.children[0])==null?void 0:b.size)==null?void 0:y.width)||0,ae=i.children.length*be+(i.children.length-1)*e0;Xe.debug("widthOfChildren 88",ae,"posX");let ne=0;Xe.debug("abc91 block?.size?.x",i.id,(T=i==null?void 0:i.size)==null?void 0:T.x);let se=(_=i==null?void 0:i.size)!=null&&_.x?((A=i==null?void 0:i.size)==null?void 0:A.x)+(-((P=i==null?void 0:i.size)==null?void 0:P.width)/2||0):-e0,de=0;for(const X of i.children){const ge=i;if(!X.size)continue;const{width:W,height:xe}=X.size,{px:U,py:Fe}=_cn(u,ne);if(Fe!=de&&(de=Fe,se=(R=i==null?void 0:i.size)!=null&&R.x?((F=i==null?void 0:i.size)==null?void 0:F.x)+(-((j=i==null?void 0:i.size)==null?void 0:j.width)/2||0):-e0,Xe.debug("New row in layout for block",i.id," and child ",X.id,de)),Xe.debug(`abc89 layout blocks (child) id: ${X.id} Pos: ${ne} (px, py) ${U},${Fe} (${(K=ge==null?void 0:ge.size)==null?void 0:K.x},${(ee=ge==null?void 0:ge.size)==null?void 0:ee.y}) parent: ${ge.id} width: ${W}${e0}`),ge.size){const Pe=W/2;X.size.x=se+e0+Pe,Xe.debug(`abc91 layout blocks (calc) px, pyid:${X.id} startingPos=X${se} new startingPosX${X.size.x} ${Pe} padding=${e0} width=${W} halfWidth=${Pe} => x:${X.size.x} y:${X.size.y} ${X.widthInColumns} (width * (child?.w || 1)) / 2 ${W*((X==null?void 0:X.widthInColumns)||1)/2}`),se=X.size.x+Pe,X.size.y=ge.size.y-ge.size.height/2+Fe*(xe+e0)+xe/2+e0,Xe.debug(`abc88 layout blocks (calc) px, pyid:${X.id}startingPosX${se}${e0}${Pe}=>x:${X.size.x}y:${X.size.y}${X.widthInColumns}(width * (child?.w || 1)) / 2${W*((X==null?void 0:X.widthInColumns)||1)/2}`)}X.children&&PWe(X),ne+=(X==null?void 0:X.widthInColumns)||1,Xe.debug("abc88 columnsPos",X,ne)}}Xe.debug(`layout blocks (<==layoutBlocks) ${i.id} x: ${(ie=i==null?void 0:i.size)==null?void 0:ie.x} y: ${(oe=i==null?void 0:i.size)==null?void 0:oe.y} width: ${(pe=i==null?void 0:i.size)==null?void 0:pe.width}`)}function BWe(i,{minX:s,minY:u,maxX:d,maxY:p}={minX:0,minY:0,maxX:0,maxY:0}){if(i.size&&i.id!=="root"){const{x:v,y:b,width:y,height:T}=i.size;v-y/2d&&(d=v+y/2),b+T/2>p&&(p=b+T/2)}if(i.children)for(const v of i.children)({minX:s,minY:u,maxX:d,maxY:p}=BWe(v,{minX:s,minY:u,maxX:d,maxY:p}));return{minX:s,minY:u,maxX:d,maxY:p}}function Lcn(i){const s=i.getBlock("root");if(!s)return;gwe(s,i,0,0),PWe(s),Xe.debug("getBlocks",JSON.stringify(s,null,2));const{minX:u,minY:d,maxX:p,maxY:v}=BWe(s),b=v-d,y=p-u;return{x:u,y:d,width:y,height:b}}const Mcn=Object.freeze(Object.defineProperty({__proto__:null,diagram:{parser:ucn,db:ycn,renderer:{draw:async function(i,s,u,d){const{securityLevel:p,block:v}=Vh(),b=d.db;let y;p==="sandbox"&&(y=Ir("#i"+s));const T=Ir(p==="sandbox"?y.nodes()[0].contentDocument.body:"body"),_=p==="sandbox"?T.select(`[id="${s}"]`):Ir(`[id="${s}"]`);Sme(_,["point","circle","cross"],d.type,s);const P=b.getBlocks(),R=b.getBlocksFlat(),F=b.getEdges(),j=_.insert("g").attr("class","block");await Tcn(j,P,b);const K=Lcn(b);if(await Ccn(j,P,b),await Scn(j,F,R,b,s),K){const ee=K,ie=Math.max(1,Math.round(.125*(ee.width/ee.height))),oe=ee.height+ie+10,pe=ee.width+10,{useMaxWidth:be}=v;Ng(_,oe,pe,!!be),Xe.debug("Here Bounds",K,ee),_.attr("viewBox",`${ee.x-5} ${ee.y-5} ${ee.width+10} ${ee.height+10}`)}_F(zFe)},getClasses:function(i,s){return s.db.getClasses()}},styles:xcn}},Symbol.toStringTag,{value:"Module"}));return um}); diff --git a/0.6.0/js/mermaid/mindmap-definition-307c710a.js b/0.6.0/js/mermaid/mindmap-definition-307c710a.js new file mode 100644 index 0000000..8a3651c --- /dev/null +++ b/0.6.0/js/mermaid/mindmap-definition-307c710a.js @@ -0,0 +1,1177 @@ +import { l as log, c as getConfig, B as defaultConfig, d as sanitizeText, D as parseFontSize, A as selectSvgElement, o as setupGraphViewbox } from "./mermaid-6dc72991.js"; +import cytoscape from "cytoscape"; +import coseBilkent from "cytoscape-cose-bilkent"; +import { select } from "d3"; +import { a as createText } from "./createText-ca0c5216.js"; +import { isDark, lighten, darken } from "khroma"; +import "ts-dedent"; +import "dayjs"; +import "@braintree/sanitize-url"; +import "dompurify"; +import "lodash-es/memoize.js"; +import "lodash-es/merge.js"; +import "stylis"; +import "lodash-es/isEmpty.js"; +import "mdast-util-from-markdown"; +var parser = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 4], $V1 = [1, 13], $V2 = [1, 12], $V3 = [1, 15], $V4 = [1, 16], $V5 = [1, 20], $V6 = [1, 19], $V7 = [6, 7, 8], $V8 = [1, 26], $V9 = [1, 24], $Va = [1, 25], $Vb = [6, 7, 11], $Vc = [1, 6, 13, 15, 16, 19, 22], $Vd = [1, 33], $Ve = [1, 34], $Vf = [1, 6, 7, 11, 13, 15, 16, 19, 22]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "mindMap": 4, "spaceLines": 5, "SPACELINE": 6, "NL": 7, "MINDMAP": 8, "document": 9, "stop": 10, "EOF": 11, "statement": 12, "SPACELIST": 13, "node": 14, "ICON": 15, "CLASS": 16, "nodeWithId": 17, "nodeWithoutId": 18, "NODE_DSTART": 19, "NODE_DESCR": 20, "NODE_DEND": 21, "NODE_ID": 22, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 6: "SPACELINE", 7: "NL", 8: "MINDMAP", 11: "EOF", 13: "SPACELIST", 15: "ICON", 16: "CLASS", 19: "NODE_DSTART", 20: "NODE_DESCR", 21: "NODE_DEND", 22: "NODE_ID" }, + productions_: [0, [3, 1], [3, 2], [5, 1], [5, 2], [5, 2], [4, 2], [4, 3], [10, 1], [10, 1], [10, 1], [10, 2], [10, 2], [9, 3], [9, 2], [12, 2], [12, 2], [12, 2], [12, 1], [12, 1], [12, 1], [12, 1], [12, 1], [14, 1], [14, 1], [18, 3], [17, 1], [17, 4]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 6: + case 7: + return yy; + case 8: + yy.getLogger().trace("Stop NL "); + break; + case 9: + yy.getLogger().trace("Stop EOF "); + break; + case 11: + yy.getLogger().trace("Stop NL2 "); + break; + case 12: + yy.getLogger().trace("Stop EOF2 "); + break; + case 15: + yy.getLogger().info("Node: ", $$[$0].id); + yy.addNode($$[$0 - 1].length, $$[$0].id, $$[$0].descr, $$[$0].type); + break; + case 16: + yy.getLogger().trace("Icon: ", $$[$0]); + yy.decorateNode({ icon: $$[$0] }); + break; + case 17: + case 21: + yy.decorateNode({ class: $$[$0] }); + break; + case 18: + yy.getLogger().trace("SPACELIST"); + break; + case 19: + yy.getLogger().trace("Node: ", $$[$0].id); + yy.addNode(0, $$[$0].id, $$[$0].descr, $$[$0].type); + break; + case 20: + yy.decorateNode({ icon: $$[$0] }); + break; + case 25: + yy.getLogger().trace("node found ..", $$[$0 - 2]); + this.$ = { id: $$[$0 - 1], descr: $$[$0 - 1], type: yy.getType($$[$0 - 2], $$[$0]) }; + break; + case 26: + this.$ = { id: $$[$0], descr: $$[$0], type: yy.nodeType.DEFAULT }; + break; + case 27: + yy.getLogger().trace("node found ..", $$[$0 - 3]); + this.$ = { id: $$[$0 - 3], descr: $$[$0 - 1], type: yy.getType($$[$0 - 2], $$[$0]) }; + break; + } + }, + table: [{ 3: 1, 4: 2, 5: 3, 6: [1, 5], 8: $V0 }, { 1: [3] }, { 1: [2, 1] }, { 4: 6, 6: [1, 7], 7: [1, 8], 8: $V0 }, { 6: $V1, 7: [1, 10], 9: 9, 12: 11, 13: $V2, 14: 14, 15: $V3, 16: $V4, 17: 17, 18: 18, 19: $V5, 22: $V6 }, o($V7, [2, 3]), { 1: [2, 2] }, o($V7, [2, 4]), o($V7, [2, 5]), { 1: [2, 6], 6: $V1, 12: 21, 13: $V2, 14: 14, 15: $V3, 16: $V4, 17: 17, 18: 18, 19: $V5, 22: $V6 }, { 6: $V1, 9: 22, 12: 11, 13: $V2, 14: 14, 15: $V3, 16: $V4, 17: 17, 18: 18, 19: $V5, 22: $V6 }, { 6: $V8, 7: $V9, 10: 23, 11: $Va }, o($Vb, [2, 22], { 17: 17, 18: 18, 14: 27, 15: [1, 28], 16: [1, 29], 19: $V5, 22: $V6 }), o($Vb, [2, 18]), o($Vb, [2, 19]), o($Vb, [2, 20]), o($Vb, [2, 21]), o($Vb, [2, 23]), o($Vb, [2, 24]), o($Vb, [2, 26], { 19: [1, 30] }), { 20: [1, 31] }, { 6: $V8, 7: $V9, 10: 32, 11: $Va }, { 1: [2, 7], 6: $V1, 12: 21, 13: $V2, 14: 14, 15: $V3, 16: $V4, 17: 17, 18: 18, 19: $V5, 22: $V6 }, o($Vc, [2, 14], { 7: $Vd, 11: $Ve }), o($Vf, [2, 8]), o($Vf, [2, 9]), o($Vf, [2, 10]), o($Vb, [2, 15]), o($Vb, [2, 16]), o($Vb, [2, 17]), { 20: [1, 35] }, { 21: [1, 36] }, o($Vc, [2, 13], { 7: $Vd, 11: $Ve }), o($Vf, [2, 11]), o($Vf, [2, 12]), { 21: [1, 37] }, o($Vb, [2, 25]), o($Vb, [2, 27])], + defaultActions: { 2: [2, 1], 6: [2, 2] }, + parseError: function parseError(str, hash) { + if (hash.recoverable) { + this.trace(str); + } else { + var error = new Error(str); + error.hash = hash; + throw error; + } + }, + parse: function parse(input) { + var self = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex() { + var token; + token = tstack.pop() || lexer2.lex() || EOF; + if (typeof token !== "number") { + if (token instanceof Array) { + tstack = token; + token = tstack.pop(); + } + token = self.symbols_[token] || token; + } + return token; + } + var symbol, state, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state = stack[stack.length - 1]; + if (this.defaultActions[state]) { + action = this.defaultActions[state]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex(); + } + action = table[state] && table[state][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str, hash); + } else { + throw new Error(str); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch = this._input[0]; + this.yytext += ch; + this.yyleng++; + this.offset++; + this.match += ch; + this.matched += ch; + var lines = ch.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch; + }, + // unshifts one char (or a string) into the input + unput: function(ch) { + var len = ch.length; + var lines = ch.split(/(?:\r\n?|\n)/g); + this._input = ch + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next = this.match; + if (next.length < 20) { + next += this._input.substr(0, 20 - next.length); + } + return (next.substr(0, 20) + (next.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token) { + return token; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token, match, tempMatch, index; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i = 0; i < rules.length; i++) { + tempMatch = this._input.match(this.rules[rules[i]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index = i; + if (this.options.backtrack_lexer) { + token = this.test_match(tempMatch, rules[i]); + if (token !== false) { + return token; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token = this.test_match(match, rules[index]); + if (token !== false) { + return token; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + yy.getLogger().trace("Found comment", yy_.yytext); + return 6; + case 1: + return 8; + case 2: + this.begin("CLASS"); + break; + case 3: + this.popState(); + return 16; + case 4: + this.popState(); + break; + case 5: + yy.getLogger().trace("Begin icon"); + this.begin("ICON"); + break; + case 6: + yy.getLogger().trace("SPACELINE"); + return 6; + case 7: + return 7; + case 8: + return 15; + case 9: + yy.getLogger().trace("end icon"); + this.popState(); + break; + case 10: + yy.getLogger().trace("Exploding node"); + this.begin("NODE"); + return 19; + case 11: + yy.getLogger().trace("Cloud"); + this.begin("NODE"); + return 19; + case 12: + yy.getLogger().trace("Explosion Bang"); + this.begin("NODE"); + return 19; + case 13: + yy.getLogger().trace("Cloud Bang"); + this.begin("NODE"); + return 19; + case 14: + this.begin("NODE"); + return 19; + case 15: + this.begin("NODE"); + return 19; + case 16: + this.begin("NODE"); + return 19; + case 17: + this.begin("NODE"); + return 19; + case 18: + return 13; + case 19: + return 22; + case 20: + return 11; + case 21: + this.begin("NSTR2"); + break; + case 22: + return "NODE_DESCR"; + case 23: + this.popState(); + break; + case 24: + yy.getLogger().trace("Starting NSTR"); + this.begin("NSTR"); + break; + case 25: + yy.getLogger().trace("description:", yy_.yytext); + return "NODE_DESCR"; + case 26: + this.popState(); + break; + case 27: + this.popState(); + yy.getLogger().trace("node end ))"); + return "NODE_DEND"; + case 28: + this.popState(); + yy.getLogger().trace("node end )"); + return "NODE_DEND"; + case 29: + this.popState(); + yy.getLogger().trace("node end ...", yy_.yytext); + return "NODE_DEND"; + case 30: + this.popState(); + yy.getLogger().trace("node end (("); + return "NODE_DEND"; + case 31: + this.popState(); + yy.getLogger().trace("node end (-"); + return "NODE_DEND"; + case 32: + this.popState(); + yy.getLogger().trace("node end (-"); + return "NODE_DEND"; + case 33: + this.popState(); + yy.getLogger().trace("node end (("); + return "NODE_DEND"; + case 34: + this.popState(); + yy.getLogger().trace("node end (("); + return "NODE_DEND"; + case 35: + yy.getLogger().trace("Long description:", yy_.yytext); + return 20; + case 36: + yy.getLogger().trace("Long description:", yy_.yytext); + return 20; + } + }, + rules: [/^(?:\s*%%.*)/i, /^(?:mindmap\b)/i, /^(?::::)/i, /^(?:.+)/i, /^(?:\n)/i, /^(?:::icon\()/i, /^(?:[\s]+[\n])/i, /^(?:[\n]+)/i, /^(?:[^\)]+)/i, /^(?:\))/i, /^(?:-\))/i, /^(?:\(-)/i, /^(?:\)\))/i, /^(?:\))/i, /^(?:\(\()/i, /^(?:\{\{)/i, /^(?:\()/i, /^(?:\[)/i, /^(?:[\s]+)/i, /^(?:[^\(\[\n\)\{\}]+)/i, /^(?:$)/i, /^(?:["][`])/i, /^(?:[^`"]+)/i, /^(?:[`]["])/i, /^(?:["])/i, /^(?:[^"]+)/i, /^(?:["])/i, /^(?:[\)]\))/i, /^(?:[\)])/i, /^(?:[\]])/i, /^(?:\}\})/i, /^(?:\(-)/i, /^(?:-\))/i, /^(?:\(\()/i, /^(?:\()/i, /^(?:[^\)\]\(\}]+)/i, /^(?:.+(?!\(\())/i], + conditions: { "CLASS": { "rules": [3, 4], "inclusive": false }, "ICON": { "rules": [8, 9], "inclusive": false }, "NSTR2": { "rules": [22, 23], "inclusive": false }, "NSTR": { "rules": [25, 26], "inclusive": false }, "NODE": { "rules": [21, 24, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36], "inclusive": false }, "INITIAL": { "rules": [0, 1, 2, 5, 6, 7, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser() { + this.yy = {}; + } + Parser.prototype = parser2; + parser2.Parser = Parser; + return new Parser(); +}(); +parser.parser = parser; +const parser$1 = parser; +let nodes = []; +let cnt = 0; +let elements = {}; +const clear = () => { + nodes = []; + cnt = 0; + elements = {}; +}; +const getParent = function(level) { + for (let i = nodes.length - 1; i >= 0; i--) { + if (nodes[i].level < level) { + return nodes[i]; + } + } + return null; +}; +const getMindmap = () => { + return nodes.length > 0 ? nodes[0] : null; +}; +const addNode = (level, id, descr, type) => { + var _a, _b; + log.info("addNode", level, id, descr, type); + const conf = getConfig(); + let padding = ((_a = conf.mindmap) == null ? void 0 : _a.padding) ?? defaultConfig.mindmap.padding; + switch (type) { + case nodeType.ROUNDED_RECT: + case nodeType.RECT: + case nodeType.HEXAGON: + padding *= 2; + } + const node = { + id: cnt++, + nodeId: sanitizeText(id, conf), + level, + descr: sanitizeText(descr, conf), + type, + children: [], + width: ((_b = conf.mindmap) == null ? void 0 : _b.maxNodeWidth) ?? defaultConfig.mindmap.maxNodeWidth, + padding + }; + const parent = getParent(level); + if (parent) { + parent.children.push(node); + nodes.push(node); + } else { + if (nodes.length === 0) { + nodes.push(node); + } else { + throw new Error( + 'There can be only one root. No parent could be found for ("' + node.descr + '")' + ); + } + } +}; +const nodeType = { + DEFAULT: 0, + NO_BORDER: 0, + ROUNDED_RECT: 1, + RECT: 2, + CIRCLE: 3, + CLOUD: 4, + BANG: 5, + HEXAGON: 6 +}; +const getType = (startStr, endStr) => { + log.debug("In get type", startStr, endStr); + switch (startStr) { + case "[": + return nodeType.RECT; + case "(": + return endStr === ")" ? nodeType.ROUNDED_RECT : nodeType.CLOUD; + case "((": + return nodeType.CIRCLE; + case ")": + return nodeType.CLOUD; + case "))": + return nodeType.BANG; + case "{{": + return nodeType.HEXAGON; + default: + return nodeType.DEFAULT; + } +}; +const setElementForId = (id, element) => { + elements[id] = element; +}; +const decorateNode = (decoration) => { + if (!decoration) { + return; + } + const config = getConfig(); + const node = nodes[nodes.length - 1]; + if (decoration.icon) { + node.icon = sanitizeText(decoration.icon, config); + } + if (decoration.class) { + node.class = sanitizeText(decoration.class, config); + } +}; +const type2Str = (type) => { + switch (type) { + case nodeType.DEFAULT: + return "no-border"; + case nodeType.RECT: + return "rect"; + case nodeType.ROUNDED_RECT: + return "rounded-rect"; + case nodeType.CIRCLE: + return "circle"; + case nodeType.CLOUD: + return "cloud"; + case nodeType.BANG: + return "bang"; + case nodeType.HEXAGON: + return "hexgon"; + default: + return "no-border"; + } +}; +const getLogger = () => log; +const getElementById = (id) => elements[id]; +const db = { + clear, + addNode, + getMindmap, + nodeType, + getType, + setElementForId, + decorateNode, + type2Str, + getLogger, + getElementById +}; +const db$1 = db; +const MAX_SECTIONS = 12; +const defaultBkg = function(db2, elem, node, section) { + const rd = 5; + elem.append("path").attr("id", "node-" + node.id).attr("class", "node-bkg node-" + db2.type2Str(node.type)).attr( + "d", + `M0 ${node.height - rd} v${-node.height + 2 * rd} q0,-5 5,-5 h${node.width - 2 * rd} q5,0 5,5 v${node.height - rd} H0 Z` + ); + elem.append("line").attr("class", "node-line-" + section).attr("x1", 0).attr("y1", node.height).attr("x2", node.width).attr("y2", node.height); +}; +const rectBkg = function(db2, elem, node) { + elem.append("rect").attr("id", "node-" + node.id).attr("class", "node-bkg node-" + db2.type2Str(node.type)).attr("height", node.height).attr("width", node.width); +}; +const cloudBkg = function(db2, elem, node) { + const w = node.width; + const h = node.height; + const r1 = 0.15 * w; + const r2 = 0.25 * w; + const r3 = 0.35 * w; + const r4 = 0.2 * w; + elem.append("path").attr("id", "node-" + node.id).attr("class", "node-bkg node-" + db2.type2Str(node.type)).attr( + "d", + `M0 0 a${r1},${r1} 0 0,1 ${w * 0.25},${-1 * w * 0.1} + a${r3},${r3} 1 0,1 ${w * 0.4},${-1 * w * 0.1} + a${r2},${r2} 1 0,1 ${w * 0.35},${1 * w * 0.2} + + a${r1},${r1} 1 0,1 ${w * 0.15},${1 * h * 0.35} + a${r4},${r4} 1 0,1 ${-1 * w * 0.15},${1 * h * 0.65} + + a${r2},${r1} 1 0,1 ${-1 * w * 0.25},${w * 0.15} + a${r3},${r3} 1 0,1 ${-1 * w * 0.5},${0} + a${r1},${r1} 1 0,1 ${-1 * w * 0.25},${-1 * w * 0.15} + + a${r1},${r1} 1 0,1 ${-1 * w * 0.1},${-1 * h * 0.35} + a${r4},${r4} 1 0,1 ${w * 0.1},${-1 * h * 0.65} + + H0 V0 Z` + ); +}; +const bangBkg = function(db2, elem, node) { + const w = node.width; + const h = node.height; + const r = 0.15 * w; + elem.append("path").attr("id", "node-" + node.id).attr("class", "node-bkg node-" + db2.type2Str(node.type)).attr( + "d", + `M0 0 a${r},${r} 1 0,0 ${w * 0.25},${-1 * h * 0.1} + a${r},${r} 1 0,0 ${w * 0.25},${0} + a${r},${r} 1 0,0 ${w * 0.25},${0} + a${r},${r} 1 0,0 ${w * 0.25},${1 * h * 0.1} + + a${r},${r} 1 0,0 ${w * 0.15},${1 * h * 0.33} + a${r * 0.8},${r * 0.8} 1 0,0 ${0},${1 * h * 0.34} + a${r},${r} 1 0,0 ${-1 * w * 0.15},${1 * h * 0.33} + + a${r},${r} 1 0,0 ${-1 * w * 0.25},${h * 0.15} + a${r},${r} 1 0,0 ${-1 * w * 0.25},${0} + a${r},${r} 1 0,0 ${-1 * w * 0.25},${0} + a${r},${r} 1 0,0 ${-1 * w * 0.25},${-1 * h * 0.15} + + a${r},${r} 1 0,0 ${-1 * w * 0.1},${-1 * h * 0.33} + a${r * 0.8},${r * 0.8} 1 0,0 ${0},${-1 * h * 0.34} + a${r},${r} 1 0,0 ${w * 0.1},${-1 * h * 0.33} + + H0 V0 Z` + ); +}; +const circleBkg = function(db2, elem, node) { + elem.append("circle").attr("id", "node-" + node.id).attr("class", "node-bkg node-" + db2.type2Str(node.type)).attr("r", node.width / 2); +}; +function insertPolygonShape(parent, w, h, points, node) { + return parent.insert("polygon", ":first-child").attr( + "points", + points.map(function(d) { + return d.x + "," + d.y; + }).join(" ") + ).attr("transform", "translate(" + (node.width - w) / 2 + ", " + h + ")"); +} +const hexagonBkg = function(_db, elem, node) { + const h = node.height; + const f = 4; + const m = h / f; + const w = node.width - node.padding + 2 * m; + const points = [ + { x: m, y: 0 }, + { x: w - m, y: 0 }, + { x: w, y: -h / 2 }, + { x: w - m, y: -h }, + { x: m, y: -h }, + { x: 0, y: -h / 2 } + ]; + insertPolygonShape(elem, w, h, points, node); +}; +const roundedRectBkg = function(db2, elem, node) { + elem.append("rect").attr("id", "node-" + node.id).attr("class", "node-bkg node-" + db2.type2Str(node.type)).attr("height", node.height).attr("rx", node.padding).attr("ry", node.padding).attr("width", node.width); +}; +const drawNode = function(db2, elem, node, fullSection, conf) { + const htmlLabels = conf.htmlLabels; + const section = fullSection % (MAX_SECTIONS - 1); + const nodeElem = elem.append("g"); + node.section = section; + let sectionClass = "section-" + section; + if (section < 0) { + sectionClass += " section-root"; + } + nodeElem.attr("class", (node.class ? node.class + " " : "") + "mindmap-node " + sectionClass); + const bkgElem = nodeElem.append("g"); + const textElem = nodeElem.append("g"); + const description = node.descr.replace(/()/g, "\n"); + createText(textElem, description, { + useHtmlLabels: htmlLabels, + width: node.width, + classes: "mindmap-node-label" + }); + if (!htmlLabels) { + textElem.attr("dy", "1em").attr("alignment-baseline", "middle").attr("dominant-baseline", "middle").attr("text-anchor", "middle"); + } + const bbox = textElem.node().getBBox(); + const [fontSize] = parseFontSize(conf.fontSize); + node.height = bbox.height + fontSize * 1.1 * 0.5 + node.padding; + node.width = bbox.width + 2 * node.padding; + if (node.icon) { + if (node.type === db2.nodeType.CIRCLE) { + node.height += 50; + node.width += 50; + const icon = nodeElem.append("foreignObject").attr("height", "50px").attr("width", node.width).attr("style", "text-align: center;"); + icon.append("div").attr("class", "icon-container").append("i").attr("class", "node-icon-" + section + " " + node.icon); + textElem.attr( + "transform", + "translate(" + node.width / 2 + ", " + (node.height / 2 - 1.5 * node.padding) + ")" + ); + } else { + node.width += 50; + const orgHeight = node.height; + node.height = Math.max(orgHeight, 60); + const heightDiff = Math.abs(node.height - orgHeight); + const icon = nodeElem.append("foreignObject").attr("width", "60px").attr("height", node.height).attr("style", "text-align: center;margin-top:" + heightDiff / 2 + "px;"); + icon.append("div").attr("class", "icon-container").append("i").attr("class", "node-icon-" + section + " " + node.icon); + textElem.attr( + "transform", + "translate(" + (25 + node.width / 2) + ", " + (heightDiff / 2 + node.padding / 2) + ")" + ); + } + } else { + if (!htmlLabels) { + const dx = node.width / 2; + const dy = node.padding / 2; + textElem.attr("transform", "translate(" + dx + ", " + dy + ")"); + } else { + const dx = (node.width - bbox.width) / 2; + const dy = (node.height - bbox.height) / 2; + textElem.attr("transform", "translate(" + dx + ", " + dy + ")"); + } + } + switch (node.type) { + case db2.nodeType.DEFAULT: + defaultBkg(db2, bkgElem, node, section); + break; + case db2.nodeType.ROUNDED_RECT: + roundedRectBkg(db2, bkgElem, node); + break; + case db2.nodeType.RECT: + rectBkg(db2, bkgElem, node); + break; + case db2.nodeType.CIRCLE: + bkgElem.attr("transform", "translate(" + node.width / 2 + ", " + +node.height / 2 + ")"); + circleBkg(db2, bkgElem, node); + break; + case db2.nodeType.CLOUD: + cloudBkg(db2, bkgElem, node); + break; + case db2.nodeType.BANG: + bangBkg(db2, bkgElem, node); + break; + case db2.nodeType.HEXAGON: + hexagonBkg(db2, bkgElem, node); + break; + } + db2.setElementForId(node.id, nodeElem); + return node.height; +}; +const positionNode = function(db2, node) { + const nodeElem = db2.getElementById(node.id); + const x = node.x || 0; + const y = node.y || 0; + nodeElem.attr("transform", "translate(" + x + "," + y + ")"); +}; +cytoscape.use(coseBilkent); +function drawNodes(db2, svg, mindmap, section, conf) { + drawNode(db2, svg, mindmap, section, conf); + if (mindmap.children) { + mindmap.children.forEach((child, index) => { + drawNodes(db2, svg, child, section < 0 ? index : section, conf); + }); + } +} +function drawEdges(edgesEl, cy) { + cy.edges().map((edge, id) => { + const data = edge.data(); + if (edge[0]._private.bodyBounds) { + const bounds = edge[0]._private.rscratch; + log.trace("Edge: ", id, data); + edgesEl.insert("path").attr( + "d", + `M ${bounds.startX},${bounds.startY} L ${bounds.midX},${bounds.midY} L${bounds.endX},${bounds.endY} ` + ).attr("class", "edge section-edge-" + data.section + " edge-depth-" + data.depth); + } + }); +} +function addNodes(mindmap, cy, conf, level) { + cy.add({ + group: "nodes", + data: { + id: mindmap.id.toString(), + labelText: mindmap.descr, + height: mindmap.height, + width: mindmap.width, + level, + nodeId: mindmap.id, + padding: mindmap.padding, + type: mindmap.type + }, + position: { + x: mindmap.x, + y: mindmap.y + } + }); + if (mindmap.children) { + mindmap.children.forEach((child) => { + addNodes(child, cy, conf, level + 1); + cy.add({ + group: "edges", + data: { + id: `${mindmap.id}_${child.id}`, + source: mindmap.id, + target: child.id, + depth: level, + section: child.section + } + }); + }); + } +} +function layoutMindmap(node, conf) { + return new Promise((resolve) => { + const renderEl = select("body").append("div").attr("id", "cy").attr("style", "display:none"); + const cy = cytoscape({ + container: document.getElementById("cy"), + // container to render in + style: [ + { + selector: "edge", + style: { + "curve-style": "bezier" + } + } + ] + }); + renderEl.remove(); + addNodes(node, cy, conf, 0); + cy.nodes().forEach(function(n) { + n.layoutDimensions = () => { + const data = n.data(); + return { w: data.width, h: data.height }; + }; + }); + cy.layout({ + name: "cose-bilkent", + // @ts-ignore Types for cose-bilkent are not correct? + quality: "proof", + styleEnabled: false, + animate: false + }).run(); + cy.ready((e) => { + log.info("Ready", e); + resolve(cy); + }); + }); +} +function positionNodes(db2, cy) { + cy.nodes().map((node, id) => { + const data = node.data(); + data.x = node.position().x; + data.y = node.position().y; + positionNode(db2, data); + const el = db2.getElementById(data.nodeId); + log.info("Id:", id, "Position: (", node.position().x, ", ", node.position().y, ")", data); + el.attr( + "transform", + `translate(${node.position().x - data.width / 2}, ${node.position().y - data.height / 2})` + ); + el.attr("attr", `apa-${id})`); + }); +} +const draw = async (text, id, _version, diagObj) => { + var _a, _b; + log.debug("Rendering mindmap diagram\n" + text); + const db2 = diagObj.db; + const mm = db2.getMindmap(); + if (!mm) { + return; + } + const conf = getConfig(); + conf.htmlLabels = false; + const svg = selectSvgElement(id); + const edgesElem = svg.append("g"); + edgesElem.attr("class", "mindmap-edges"); + const nodesElem = svg.append("g"); + nodesElem.attr("class", "mindmap-nodes"); + drawNodes(db2, nodesElem, mm, -1, conf); + const cy = await layoutMindmap(mm, conf); + drawEdges(edgesElem, cy); + positionNodes(db2, cy); + setupGraphViewbox( + void 0, + svg, + ((_a = conf.mindmap) == null ? void 0 : _a.padding) ?? defaultConfig.mindmap.padding, + ((_b = conf.mindmap) == null ? void 0 : _b.useMaxWidth) ?? defaultConfig.mindmap.useMaxWidth + ); +}; +const renderer = { + draw +}; +const genSections = (options) => { + let sections = ""; + for (let i = 0; i < options.THEME_COLOR_LIMIT; i++) { + options["lineColor" + i] = options["lineColor" + i] || options["cScaleInv" + i]; + if (isDark(options["lineColor" + i])) { + options["lineColor" + i] = lighten(options["lineColor" + i], 20); + } else { + options["lineColor" + i] = darken(options["lineColor" + i], 20); + } + } + for (let i = 0; i < options.THEME_COLOR_LIMIT; i++) { + const sw = "" + (17 - 3 * i); + sections += ` + .section-${i - 1} rect, .section-${i - 1} path, .section-${i - 1} circle, .section-${i - 1} polygon, .section-${i - 1} path { + fill: ${options["cScale" + i]}; + } + .section-${i - 1} text { + fill: ${options["cScaleLabel" + i]}; + } + .node-icon-${i - 1} { + font-size: 40px; + color: ${options["cScaleLabel" + i]}; + } + .section-edge-${i - 1}{ + stroke: ${options["cScale" + i]}; + } + .edge-depth-${i - 1}{ + stroke-width: ${sw}; + } + .section-${i - 1} line { + stroke: ${options["cScaleInv" + i]} ; + stroke-width: 3; + } + + .disabled, .disabled circle, .disabled text { + fill: lightgray; + } + .disabled text { + fill: #efefef; + } + `; + } + return sections; +}; +const getStyles = (options) => ` + .edge { + stroke-width: 3; + } + ${genSections(options)} + .section-root rect, .section-root path, .section-root circle, .section-root polygon { + fill: ${options.git0}; + } + .section-root text { + fill: ${options.gitBranchLabel0}; + } + .icon-container { + height:100%; + display: flex; + justify-content: center; + align-items: center; + } + .edge { + fill: none; + } + .mindmap-node-label { + dy: 1em; + alignment-baseline: middle; + text-anchor: middle; + dominant-baseline: middle; + text-align: center; + } +`; +const styles = getStyles; +const diagram = { + db: db$1, + renderer, + parser: parser$1, + styles +}; +export { + diagram +}; diff --git a/0.6.0/js/mermaid/mindmap-definition-696ddea4.js b/0.6.0/js/mermaid/mindmap-definition-696ddea4.js new file mode 100644 index 0000000..5eceffc --- /dev/null +++ b/0.6.0/js/mermaid/mindmap-definition-696ddea4.js @@ -0,0 +1,32342 @@ +import { l as log, c as getConfig, W as defaultConfig, d as sanitizeText, P as commonjsGlobal, Q as getDefaultExportFromCjs, Y as parseFontSize, U as selectSvgElement, t as setupGraphViewbox, j as d3select, at as isDark, au as lighten, av as darken } from "./mermaid-dcacb631.js"; +import { a as createText } from "./createText-b70fe78a.js"; +var parser = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 4], $V1 = [1, 13], $V2 = [1, 12], $V3 = [1, 15], $V4 = [1, 16], $V5 = [1, 20], $V6 = [1, 19], $V7 = [6, 7, 8], $V8 = [1, 26], $V9 = [1, 24], $Va = [1, 25], $Vb = [6, 7, 11], $Vc = [1, 6, 13, 15, 16, 19, 22], $Vd = [1, 33], $Ve = [1, 34], $Vf = [1, 6, 7, 11, 13, 15, 16, 19, 22]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "mindMap": 4, "spaceLines": 5, "SPACELINE": 6, "NL": 7, "MINDMAP": 8, "document": 9, "stop": 10, "EOF": 11, "statement": 12, "SPACELIST": 13, "node": 14, "ICON": 15, "CLASS": 16, "nodeWithId": 17, "nodeWithoutId": 18, "NODE_DSTART": 19, "NODE_DESCR": 20, "NODE_DEND": 21, "NODE_ID": 22, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 6: "SPACELINE", 7: "NL", 8: "MINDMAP", 11: "EOF", 13: "SPACELIST", 15: "ICON", 16: "CLASS", 19: "NODE_DSTART", 20: "NODE_DESCR", 21: "NODE_DEND", 22: "NODE_ID" }, + productions_: [0, [3, 1], [3, 2], [5, 1], [5, 2], [5, 2], [4, 2], [4, 3], [10, 1], [10, 1], [10, 1], [10, 2], [10, 2], [9, 3], [9, 2], [12, 2], [12, 2], [12, 2], [12, 1], [12, 1], [12, 1], [12, 1], [12, 1], [14, 1], [14, 1], [18, 3], [17, 1], [17, 4]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 6: + case 7: + return yy; + case 8: + yy.getLogger().trace("Stop NL "); + break; + case 9: + yy.getLogger().trace("Stop EOF "); + break; + case 11: + yy.getLogger().trace("Stop NL2 "); + break; + case 12: + yy.getLogger().trace("Stop EOF2 "); + break; + case 15: + yy.getLogger().info("Node: ", $$[$0].id); + yy.addNode($$[$0 - 1].length, $$[$0].id, $$[$0].descr, $$[$0].type); + break; + case 16: + yy.getLogger().trace("Icon: ", $$[$0]); + yy.decorateNode({ icon: $$[$0] }); + break; + case 17: + case 21: + yy.decorateNode({ class: $$[$0] }); + break; + case 18: + yy.getLogger().trace("SPACELIST"); + break; + case 19: + yy.getLogger().trace("Node: ", $$[$0].id); + yy.addNode(0, $$[$0].id, $$[$0].descr, $$[$0].type); + break; + case 20: + yy.decorateNode({ icon: $$[$0] }); + break; + case 25: + yy.getLogger().trace("node found ..", $$[$0 - 2]); + this.$ = { id: $$[$0 - 1], descr: $$[$0 - 1], type: yy.getType($$[$0 - 2], $$[$0]) }; + break; + case 26: + this.$ = { id: $$[$0], descr: $$[$0], type: yy.nodeType.DEFAULT }; + break; + case 27: + yy.getLogger().trace("node found ..", $$[$0 - 3]); + this.$ = { id: $$[$0 - 3], descr: $$[$0 - 1], type: yy.getType($$[$0 - 2], $$[$0]) }; + break; + } + }, + table: [{ 3: 1, 4: 2, 5: 3, 6: [1, 5], 8: $V0 }, { 1: [3] }, { 1: [2, 1] }, { 4: 6, 6: [1, 7], 7: [1, 8], 8: $V0 }, { 6: $V1, 7: [1, 10], 9: 9, 12: 11, 13: $V2, 14: 14, 15: $V3, 16: $V4, 17: 17, 18: 18, 19: $V5, 22: $V6 }, o($V7, [2, 3]), { 1: [2, 2] }, o($V7, [2, 4]), o($V7, [2, 5]), { 1: [2, 6], 6: $V1, 12: 21, 13: $V2, 14: 14, 15: $V3, 16: $V4, 17: 17, 18: 18, 19: $V5, 22: $V6 }, { 6: $V1, 9: 22, 12: 11, 13: $V2, 14: 14, 15: $V3, 16: $V4, 17: 17, 18: 18, 19: $V5, 22: $V6 }, { 6: $V8, 7: $V9, 10: 23, 11: $Va }, o($Vb, [2, 22], { 17: 17, 18: 18, 14: 27, 15: [1, 28], 16: [1, 29], 19: $V5, 22: $V6 }), o($Vb, [2, 18]), o($Vb, [2, 19]), o($Vb, [2, 20]), o($Vb, [2, 21]), o($Vb, [2, 23]), o($Vb, [2, 24]), o($Vb, [2, 26], { 19: [1, 30] }), { 20: [1, 31] }, { 6: $V8, 7: $V9, 10: 32, 11: $Va }, { 1: [2, 7], 6: $V1, 12: 21, 13: $V2, 14: 14, 15: $V3, 16: $V4, 17: 17, 18: 18, 19: $V5, 22: $V6 }, o($Vc, [2, 14], { 7: $Vd, 11: $Ve }), o($Vf, [2, 8]), o($Vf, [2, 9]), o($Vf, [2, 10]), o($Vb, [2, 15]), o($Vb, [2, 16]), o($Vb, [2, 17]), { 20: [1, 35] }, { 21: [1, 36] }, o($Vc, [2, 13], { 7: $Vd, 11: $Ve }), o($Vf, [2, 11]), o($Vf, [2, 12]), { 21: [1, 37] }, o($Vb, [2, 25]), o($Vb, [2, 27])], + defaultActions: { 2: [2, 1], 6: [2, 2] }, + parseError: function parseError(str, hash) { + if (hash.recoverable) { + this.trace(str); + } else { + var error = new Error(str); + error.hash = hash; + throw error; + } + }, + parse: function parse(input) { + var self2 = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex() { + var token; + token = tstack.pop() || lexer2.lex() || EOF; + if (typeof token !== "number") { + if (token instanceof Array) { + tstack = token; + token = tstack.pop(); + } + token = self2.symbols_[token] || token; + } + return token; + } + var symbol, state, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state = stack[stack.length - 1]; + if (this.defaultActions[state]) { + action = this.defaultActions[state]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex(); + } + action = table[state] && table[state][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str, hash); + } else { + throw new Error(str); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch = this._input[0]; + this.yytext += ch; + this.yyleng++; + this.offset++; + this.match += ch; + this.matched += ch; + var lines = ch.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch; + }, + // unshifts one char (or a string) into the input + unput: function(ch) { + var len = ch.length; + var lines = ch.split(/(?:\r\n?|\n)/g); + this._input = ch + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next2 = this.match; + if (next2.length < 20) { + next2 += this._input.substr(0, 20 - next2.length); + } + return (next2.substr(0, 20) + (next2.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token) { + return token; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token, match, tempMatch, index; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i = 0; i < rules.length; i++) { + tempMatch = this._input.match(this.rules[rules[i]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index = i; + if (this.options.backtrack_lexer) { + token = this.test_match(tempMatch, rules[i]); + if (token !== false) { + return token; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token = this.test_match(match, rules[index]); + if (token !== false) { + return token; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + yy.getLogger().trace("Found comment", yy_.yytext); + return 6; + case 1: + return 8; + case 2: + this.begin("CLASS"); + break; + case 3: + this.popState(); + return 16; + case 4: + this.popState(); + break; + case 5: + yy.getLogger().trace("Begin icon"); + this.begin("ICON"); + break; + case 6: + yy.getLogger().trace("SPACELINE"); + return 6; + case 7: + return 7; + case 8: + return 15; + case 9: + yy.getLogger().trace("end icon"); + this.popState(); + break; + case 10: + yy.getLogger().trace("Exploding node"); + this.begin("NODE"); + return 19; + case 11: + yy.getLogger().trace("Cloud"); + this.begin("NODE"); + return 19; + case 12: + yy.getLogger().trace("Explosion Bang"); + this.begin("NODE"); + return 19; + case 13: + yy.getLogger().trace("Cloud Bang"); + this.begin("NODE"); + return 19; + case 14: + this.begin("NODE"); + return 19; + case 15: + this.begin("NODE"); + return 19; + case 16: + this.begin("NODE"); + return 19; + case 17: + this.begin("NODE"); + return 19; + case 18: + return 13; + case 19: + return 22; + case 20: + return 11; + case 21: + this.begin("NSTR2"); + break; + case 22: + return "NODE_DESCR"; + case 23: + this.popState(); + break; + case 24: + yy.getLogger().trace("Starting NSTR"); + this.begin("NSTR"); + break; + case 25: + yy.getLogger().trace("description:", yy_.yytext); + return "NODE_DESCR"; + case 26: + this.popState(); + break; + case 27: + this.popState(); + yy.getLogger().trace("node end ))"); + return "NODE_DEND"; + case 28: + this.popState(); + yy.getLogger().trace("node end )"); + return "NODE_DEND"; + case 29: + this.popState(); + yy.getLogger().trace("node end ...", yy_.yytext); + return "NODE_DEND"; + case 30: + this.popState(); + yy.getLogger().trace("node end (("); + return "NODE_DEND"; + case 31: + this.popState(); + yy.getLogger().trace("node end (-"); + return "NODE_DEND"; + case 32: + this.popState(); + yy.getLogger().trace("node end (-"); + return "NODE_DEND"; + case 33: + this.popState(); + yy.getLogger().trace("node end (("); + return "NODE_DEND"; + case 34: + this.popState(); + yy.getLogger().trace("node end (("); + return "NODE_DEND"; + case 35: + yy.getLogger().trace("Long description:", yy_.yytext); + return 20; + case 36: + yy.getLogger().trace("Long description:", yy_.yytext); + return 20; + } + }, + rules: [/^(?:\s*%%.*)/i, /^(?:mindmap\b)/i, /^(?::::)/i, /^(?:.+)/i, /^(?:\n)/i, /^(?:::icon\()/i, /^(?:[\s]+[\n])/i, /^(?:[\n]+)/i, /^(?:[^\)]+)/i, /^(?:\))/i, /^(?:-\))/i, /^(?:\(-)/i, /^(?:\)\))/i, /^(?:\))/i, /^(?:\(\()/i, /^(?:\{\{)/i, /^(?:\()/i, /^(?:\[)/i, /^(?:[\s]+)/i, /^(?:[^\(\[\n\)\{\}]+)/i, /^(?:$)/i, /^(?:["][`])/i, /^(?:[^`"]+)/i, /^(?:[`]["])/i, /^(?:["])/i, /^(?:[^"]+)/i, /^(?:["])/i, /^(?:[\)]\))/i, /^(?:[\)])/i, /^(?:[\]])/i, /^(?:\}\})/i, /^(?:\(-)/i, /^(?:-\))/i, /^(?:\(\()/i, /^(?:\()/i, /^(?:[^\)\]\(\}]+)/i, /^(?:.+(?!\(\())/i], + conditions: { "CLASS": { "rules": [3, 4], "inclusive": false }, "ICON": { "rules": [8, 9], "inclusive": false }, "NSTR2": { "rules": [22, 23], "inclusive": false }, "NSTR": { "rules": [25, 26], "inclusive": false }, "NODE": { "rules": [21, 24, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36], "inclusive": false }, "INITIAL": { "rules": [0, 1, 2, 5, 6, 7, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser() { + this.yy = {}; + } + Parser.prototype = parser2; + parser2.Parser = Parser; + return new Parser(); +}(); +parser.parser = parser; +const parser$1 = parser; +let nodes = []; +let cnt = 0; +let elements = {}; +const clear = () => { + nodes = []; + cnt = 0; + elements = {}; +}; +const getParent = function(level) { + for (let i = nodes.length - 1; i >= 0; i--) { + if (nodes[i].level < level) { + return nodes[i]; + } + } + return null; +}; +const getMindmap = () => { + return nodes.length > 0 ? nodes[0] : null; +}; +const addNode = (level, id, descr, type) => { + var _a, _b; + log.info("addNode", level, id, descr, type); + const conf = getConfig(); + let padding = ((_a = conf.mindmap) == null ? void 0 : _a.padding) ?? defaultConfig.mindmap.padding; + switch (type) { + case nodeType.ROUNDED_RECT: + case nodeType.RECT: + case nodeType.HEXAGON: + padding *= 2; + } + const node = { + id: cnt++, + nodeId: sanitizeText(id, conf), + level, + descr: sanitizeText(descr, conf), + type, + children: [], + width: ((_b = conf.mindmap) == null ? void 0 : _b.maxNodeWidth) ?? defaultConfig.mindmap.maxNodeWidth, + padding + }; + const parent = getParent(level); + if (parent) { + parent.children.push(node); + nodes.push(node); + } else { + if (nodes.length === 0) { + nodes.push(node); + } else { + throw new Error( + 'There can be only one root. No parent could be found for ("' + node.descr + '")' + ); + } + } +}; +const nodeType = { + DEFAULT: 0, + NO_BORDER: 0, + ROUNDED_RECT: 1, + RECT: 2, + CIRCLE: 3, + CLOUD: 4, + BANG: 5, + HEXAGON: 6 +}; +const getType = (startStr, endStr) => { + log.debug("In get type", startStr, endStr); + switch (startStr) { + case "[": + return nodeType.RECT; + case "(": + return endStr === ")" ? nodeType.ROUNDED_RECT : nodeType.CLOUD; + case "((": + return nodeType.CIRCLE; + case ")": + return nodeType.CLOUD; + case "))": + return nodeType.BANG; + case "{{": + return nodeType.HEXAGON; + default: + return nodeType.DEFAULT; + } +}; +const setElementForId = (id, element) => { + elements[id] = element; +}; +const decorateNode = (decoration) => { + if (!decoration) { + return; + } + const config = getConfig(); + const node = nodes[nodes.length - 1]; + if (decoration.icon) { + node.icon = sanitizeText(decoration.icon, config); + } + if (decoration.class) { + node.class = sanitizeText(decoration.class, config); + } +}; +const type2Str = (type) => { + switch (type) { + case nodeType.DEFAULT: + return "no-border"; + case nodeType.RECT: + return "rect"; + case nodeType.ROUNDED_RECT: + return "rounded-rect"; + case nodeType.CIRCLE: + return "circle"; + case nodeType.CLOUD: + return "cloud"; + case nodeType.BANG: + return "bang"; + case nodeType.HEXAGON: + return "hexgon"; + default: + return "no-border"; + } +}; +const getLogger = () => log; +const getElementById = (id) => elements[id]; +const db = { + clear, + addNode, + getMindmap, + nodeType, + getType, + setElementForId, + decorateNode, + type2Str, + getLogger, + getElementById +}; +const db$1 = db; +var cytoscape_umd = { exports: {} }; +(function(module, exports) { + (function(global, factory) { + module.exports = factory(); + })(commonjsGlobal, function() { + function _typeof(obj) { + "@babel/helpers - typeof"; + return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function(obj2) { + return typeof obj2; + } : function(obj2) { + return obj2 && "function" == typeof Symbol && obj2.constructor === Symbol && obj2 !== Symbol.prototype ? "symbol" : typeof obj2; + }, _typeof(obj); + } + function _classCallCheck(instance2, Constructor) { + if (!(instance2 instanceof Constructor)) { + throw new TypeError("Cannot call a class as a function"); + } + } + function _defineProperties(target, props) { + for (var i2 = 0; i2 < props.length; i2++) { + var descriptor = props[i2]; + descriptor.enumerable = descriptor.enumerable || false; + descriptor.configurable = true; + if ("value" in descriptor) + descriptor.writable = true; + Object.defineProperty(target, descriptor.key, descriptor); + } + } + function _createClass(Constructor, protoProps, staticProps) { + if (protoProps) + _defineProperties(Constructor.prototype, protoProps); + if (staticProps) + _defineProperties(Constructor, staticProps); + Object.defineProperty(Constructor, "prototype", { + writable: false + }); + return Constructor; + } + function _defineProperty$1(obj, key, value) { + if (key in obj) { + Object.defineProperty(obj, key, { + value, + enumerable: true, + configurable: true, + writable: true + }); + } else { + obj[key] = value; + } + return obj; + } + function _slicedToArray(arr, i2) { + return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i2) || _unsupportedIterableToArray(arr, i2) || _nonIterableRest(); + } + function _arrayWithHoles(arr) { + if (Array.isArray(arr)) + return arr; + } + function _iterableToArrayLimit(arr, i2) { + var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; + if (_i == null) + return; + var _arr = []; + var _n = true; + var _d = false; + var _s, _e; + try { + for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { + _arr.push(_s.value); + if (i2 && _arr.length === i2) + break; + } + } catch (err) { + _d = true; + _e = err; + } finally { + try { + if (!_n && _i["return"] != null) + _i["return"](); + } finally { + if (_d) + throw _e; + } + } + return _arr; + } + function _unsupportedIterableToArray(o, minLen) { + if (!o) + return; + if (typeof o === "string") + return _arrayLikeToArray(o, minLen); + var n = Object.prototype.toString.call(o).slice(8, -1); + if (n === "Object" && o.constructor) + n = o.constructor.name; + if (n === "Map" || n === "Set") + return Array.from(o); + if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) + return _arrayLikeToArray(o, minLen); + } + function _arrayLikeToArray(arr, len) { + if (len == null || len > arr.length) + len = arr.length; + for (var i2 = 0, arr2 = new Array(len); i2 < len; i2++) + arr2[i2] = arr[i2]; + return arr2; + } + function _nonIterableRest() { + throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); + } + var _window = typeof window === "undefined" ? null : window; + var navigator = _window ? _window.navigator : null; + _window ? _window.document : null; + var typeofstr = _typeof(""); + var typeofobj = _typeof({}); + var typeoffn = _typeof(function() { + }); + var typeofhtmlele = typeof HTMLElement === "undefined" ? "undefined" : _typeof(HTMLElement); + var instanceStr = function instanceStr2(obj) { + return obj && obj.instanceString && fn$6(obj.instanceString) ? obj.instanceString() : null; + }; + var string = function string2(obj) { + return obj != null && _typeof(obj) == typeofstr; + }; + var fn$6 = function fn2(obj) { + return obj != null && _typeof(obj) === typeoffn; + }; + var array = function array2(obj) { + return !elementOrCollection(obj) && (Array.isArray ? Array.isArray(obj) : obj != null && obj instanceof Array); + }; + var plainObject = function plainObject2(obj) { + return obj != null && _typeof(obj) === typeofobj && !array(obj) && obj.constructor === Object; + }; + var object = function object2(obj) { + return obj != null && _typeof(obj) === typeofobj; + }; + var number$1 = function number2(obj) { + return obj != null && _typeof(obj) === _typeof(1) && !isNaN(obj); + }; + var integer = function integer2(obj) { + return number$1(obj) && Math.floor(obj) === obj; + }; + var htmlElement = function htmlElement2(obj) { + if ("undefined" === typeofhtmlele) { + return void 0; + } else { + return null != obj && obj instanceof HTMLElement; + } + }; + var elementOrCollection = function elementOrCollection2(obj) { + return element(obj) || collection(obj); + }; + var element = function element2(obj) { + return instanceStr(obj) === "collection" && obj._private.single; + }; + var collection = function collection2(obj) { + return instanceStr(obj) === "collection" && !obj._private.single; + }; + var core = function core2(obj) { + return instanceStr(obj) === "core"; + }; + var stylesheet = function stylesheet2(obj) { + return instanceStr(obj) === "stylesheet"; + }; + var event = function event2(obj) { + return instanceStr(obj) === "event"; + }; + var emptyString = function emptyString2(obj) { + if (obj === void 0 || obj === null) { + return true; + } else if (obj === "" || obj.match(/^\s+$/)) { + return true; + } + return false; + }; + var domElement = function domElement2(obj) { + if (typeof HTMLElement === "undefined") { + return false; + } else { + return obj instanceof HTMLElement; + } + }; + var boundingBox = function boundingBox2(obj) { + return plainObject(obj) && number$1(obj.x1) && number$1(obj.x2) && number$1(obj.y1) && number$1(obj.y2); + }; + var promise = function promise2(obj) { + return object(obj) && fn$6(obj.then); + }; + var ms = function ms2() { + return navigator && navigator.userAgent.match(/msie|trident|edge/i); + }; + var memoize$1 = function memoize2(fn2, keyFn) { + if (!keyFn) { + keyFn = function keyFn2() { + if (arguments.length === 1) { + return arguments[0]; + } else if (arguments.length === 0) { + return "undefined"; + } + var args = []; + for (var i2 = 0; i2 < arguments.length; i2++) { + args.push(arguments[i2]); + } + return args.join("$"); + }; + } + var memoizedFn = function memoizedFn2() { + var self2 = this; + var args = arguments; + var ret; + var k = keyFn.apply(self2, args); + var cache2 = memoizedFn2.cache; + if (!(ret = cache2[k])) { + ret = cache2[k] = fn2.apply(self2, args); + } + return ret; + }; + memoizedFn.cache = {}; + return memoizedFn; + }; + var camel2dash = memoize$1(function(str) { + return str.replace(/([A-Z])/g, function(v) { + return "-" + v.toLowerCase(); + }); + }); + var dash2camel = memoize$1(function(str) { + return str.replace(/(-\w)/g, function(v) { + return v[1].toUpperCase(); + }); + }); + var prependCamel = memoize$1(function(prefix, str) { + return prefix + str[0].toUpperCase() + str.substring(1); + }, function(prefix, str) { + return prefix + "$" + str; + }); + var capitalize = function capitalize2(str) { + if (emptyString(str)) { + return str; + } + return str.charAt(0).toUpperCase() + str.substring(1); + }; + var number = "(?:[-+]?(?:(?:\\d+|\\d*\\.\\d+)(?:[Ee][+-]?\\d+)?))"; + var rgba = "rgb[a]?\\((" + number + "[%]?)\\s*,\\s*(" + number + "[%]?)\\s*,\\s*(" + number + "[%]?)(?:\\s*,\\s*(" + number + "))?\\)"; + var rgbaNoBackRefs = "rgb[a]?\\((?:" + number + "[%]?)\\s*,\\s*(?:" + number + "[%]?)\\s*,\\s*(?:" + number + "[%]?)(?:\\s*,\\s*(?:" + number + "))?\\)"; + var hsla = "hsl[a]?\\((" + number + ")\\s*,\\s*(" + number + "[%])\\s*,\\s*(" + number + "[%])(?:\\s*,\\s*(" + number + "))?\\)"; + var hslaNoBackRefs = "hsl[a]?\\((?:" + number + ")\\s*,\\s*(?:" + number + "[%])\\s*,\\s*(?:" + number + "[%])(?:\\s*,\\s*(?:" + number + "))?\\)"; + var hex3 = "\\#[0-9a-fA-F]{3}"; + var hex6 = "\\#[0-9a-fA-F]{6}"; + var ascending = function ascending2(a, b) { + if (a < b) { + return -1; + } else if (a > b) { + return 1; + } else { + return 0; + } + }; + var descending = function descending2(a, b) { + return -1 * ascending(a, b); + }; + var extend = Object.assign != null ? Object.assign.bind(Object) : function(tgt) { + var args = arguments; + for (var i2 = 1; i2 < args.length; i2++) { + var obj = args[i2]; + if (obj == null) { + continue; + } + var keys = Object.keys(obj); + for (var j = 0; j < keys.length; j++) { + var k = keys[j]; + tgt[k] = obj[k]; + } + } + return tgt; + }; + var hex2tuple = function hex2tuple2(hex) { + if (!(hex.length === 4 || hex.length === 7) || hex[0] !== "#") { + return; + } + var shortHex = hex.length === 4; + var r, g, b; + var base = 16; + if (shortHex) { + r = parseInt(hex[1] + hex[1], base); + g = parseInt(hex[2] + hex[2], base); + b = parseInt(hex[3] + hex[3], base); + } else { + r = parseInt(hex[1] + hex[2], base); + g = parseInt(hex[3] + hex[4], base); + b = parseInt(hex[5] + hex[6], base); + } + return [r, g, b]; + }; + var hsl2tuple = function hsl2tuple2(hsl) { + var ret; + var h, s, l, a, r, g, b; + function hue2rgb(p3, q2, t) { + if (t < 0) + t += 1; + if (t > 1) + t -= 1; + if (t < 1 / 6) + return p3 + (q2 - p3) * 6 * t; + if (t < 1 / 2) + return q2; + if (t < 2 / 3) + return p3 + (q2 - p3) * (2 / 3 - t) * 6; + return p3; + } + var m = new RegExp("^" + hsla + "$").exec(hsl); + if (m) { + h = parseInt(m[1]); + if (h < 0) { + h = (360 - -1 * h % 360) % 360; + } else if (h > 360) { + h = h % 360; + } + h /= 360; + s = parseFloat(m[2]); + if (s < 0 || s > 100) { + return; + } + s = s / 100; + l = parseFloat(m[3]); + if (l < 0 || l > 100) { + return; + } + l = l / 100; + a = m[4]; + if (a !== void 0) { + a = parseFloat(a); + if (a < 0 || a > 1) { + return; + } + } + if (s === 0) { + r = g = b = Math.round(l * 255); + } else { + var q = l < 0.5 ? l * (1 + s) : l + s - l * s; + var p2 = 2 * l - q; + r = Math.round(255 * hue2rgb(p2, q, h + 1 / 3)); + g = Math.round(255 * hue2rgb(p2, q, h)); + b = Math.round(255 * hue2rgb(p2, q, h - 1 / 3)); + } + ret = [r, g, b, a]; + } + return ret; + }; + var rgb2tuple = function rgb2tuple2(rgb) { + var ret; + var m = new RegExp("^" + rgba + "$").exec(rgb); + if (m) { + ret = []; + var isPct = []; + for (var i2 = 1; i2 <= 3; i2++) { + var channel = m[i2]; + if (channel[channel.length - 1] === "%") { + isPct[i2] = true; + } + channel = parseFloat(channel); + if (isPct[i2]) { + channel = channel / 100 * 255; + } + if (channel < 0 || channel > 255) { + return; + } + ret.push(Math.floor(channel)); + } + var atLeastOneIsPct = isPct[1] || isPct[2] || isPct[3]; + var allArePct = isPct[1] && isPct[2] && isPct[3]; + if (atLeastOneIsPct && !allArePct) { + return; + } + var alpha = m[4]; + if (alpha !== void 0) { + alpha = parseFloat(alpha); + if (alpha < 0 || alpha > 1) { + return; + } + ret.push(alpha); + } + } + return ret; + }; + var colorname2tuple = function colorname2tuple2(color) { + return colors[color.toLowerCase()]; + }; + var color2tuple = function color2tuple2(color) { + return (array(color) ? color : null) || colorname2tuple(color) || hex2tuple(color) || rgb2tuple(color) || hsl2tuple(color); + }; + var colors = { + // special colour names + transparent: [0, 0, 0, 0], + // NB alpha === 0 + // regular colours + aliceblue: [240, 248, 255], + antiquewhite: [250, 235, 215], + aqua: [0, 255, 255], + aquamarine: [127, 255, 212], + azure: [240, 255, 255], + beige: [245, 245, 220], + bisque: [255, 228, 196], + black: [0, 0, 0], + blanchedalmond: [255, 235, 205], + blue: [0, 0, 255], + blueviolet: [138, 43, 226], + brown: [165, 42, 42], + burlywood: [222, 184, 135], + cadetblue: [95, 158, 160], + chartreuse: [127, 255, 0], + chocolate: [210, 105, 30], + coral: [255, 127, 80], + cornflowerblue: [100, 149, 237], + cornsilk: [255, 248, 220], + crimson: [220, 20, 60], + cyan: [0, 255, 255], + darkblue: [0, 0, 139], + darkcyan: [0, 139, 139], + darkgoldenrod: [184, 134, 11], + darkgray: [169, 169, 169], + darkgreen: [0, 100, 0], + darkgrey: [169, 169, 169], + darkkhaki: [189, 183, 107], + darkmagenta: [139, 0, 139], + darkolivegreen: [85, 107, 47], + darkorange: [255, 140, 0], + darkorchid: [153, 50, 204], + darkred: [139, 0, 0], + darksalmon: [233, 150, 122], + darkseagreen: [143, 188, 143], + darkslateblue: [72, 61, 139], + darkslategray: [47, 79, 79], + darkslategrey: [47, 79, 79], + darkturquoise: [0, 206, 209], + darkviolet: [148, 0, 211], + deeppink: [255, 20, 147], + deepskyblue: [0, 191, 255], + dimgray: [105, 105, 105], + dimgrey: [105, 105, 105], + dodgerblue: [30, 144, 255], + firebrick: [178, 34, 34], + floralwhite: [255, 250, 240], + forestgreen: [34, 139, 34], + fuchsia: [255, 0, 255], + gainsboro: [220, 220, 220], + ghostwhite: [248, 248, 255], + gold: [255, 215, 0], + goldenrod: [218, 165, 32], + gray: [128, 128, 128], + grey: [128, 128, 128], + green: [0, 128, 0], + greenyellow: [173, 255, 47], + honeydew: [240, 255, 240], + hotpink: [255, 105, 180], + indianred: [205, 92, 92], + indigo: [75, 0, 130], + ivory: [255, 255, 240], + khaki: [240, 230, 140], + lavender: [230, 230, 250], + lavenderblush: [255, 240, 245], + lawngreen: [124, 252, 0], + lemonchiffon: [255, 250, 205], + lightblue: [173, 216, 230], + lightcoral: [240, 128, 128], + lightcyan: [224, 255, 255], + lightgoldenrodyellow: [250, 250, 210], + lightgray: [211, 211, 211], + lightgreen: [144, 238, 144], + lightgrey: [211, 211, 211], + lightpink: [255, 182, 193], + lightsalmon: [255, 160, 122], + lightseagreen: [32, 178, 170], + lightskyblue: [135, 206, 250], + lightslategray: [119, 136, 153], + lightslategrey: [119, 136, 153], + lightsteelblue: [176, 196, 222], + lightyellow: [255, 255, 224], + lime: [0, 255, 0], + limegreen: [50, 205, 50], + linen: [250, 240, 230], + magenta: [255, 0, 255], + maroon: [128, 0, 0], + mediumaquamarine: [102, 205, 170], + mediumblue: [0, 0, 205], + mediumorchid: [186, 85, 211], + mediumpurple: [147, 112, 219], + mediumseagreen: [60, 179, 113], + mediumslateblue: [123, 104, 238], + mediumspringgreen: [0, 250, 154], + mediumturquoise: [72, 209, 204], + mediumvioletred: [199, 21, 133], + midnightblue: [25, 25, 112], + mintcream: [245, 255, 250], + mistyrose: [255, 228, 225], + moccasin: [255, 228, 181], + navajowhite: [255, 222, 173], + navy: [0, 0, 128], + oldlace: [253, 245, 230], + olive: [128, 128, 0], + olivedrab: [107, 142, 35], + orange: [255, 165, 0], + orangered: [255, 69, 0], + orchid: [218, 112, 214], + palegoldenrod: [238, 232, 170], + palegreen: [152, 251, 152], + paleturquoise: [175, 238, 238], + palevioletred: [219, 112, 147], + papayawhip: [255, 239, 213], + peachpuff: [255, 218, 185], + peru: [205, 133, 63], + pink: [255, 192, 203], + plum: [221, 160, 221], + powderblue: [176, 224, 230], + purple: [128, 0, 128], + red: [255, 0, 0], + rosybrown: [188, 143, 143], + royalblue: [65, 105, 225], + saddlebrown: [139, 69, 19], + salmon: [250, 128, 114], + sandybrown: [244, 164, 96], + seagreen: [46, 139, 87], + seashell: [255, 245, 238], + sienna: [160, 82, 45], + silver: [192, 192, 192], + skyblue: [135, 206, 235], + slateblue: [106, 90, 205], + slategray: [112, 128, 144], + slategrey: [112, 128, 144], + snow: [255, 250, 250], + springgreen: [0, 255, 127], + steelblue: [70, 130, 180], + tan: [210, 180, 140], + teal: [0, 128, 128], + thistle: [216, 191, 216], + tomato: [255, 99, 71], + turquoise: [64, 224, 208], + violet: [238, 130, 238], + wheat: [245, 222, 179], + white: [255, 255, 255], + whitesmoke: [245, 245, 245], + yellow: [255, 255, 0], + yellowgreen: [154, 205, 50] + }; + var setMap = function setMap2(options) { + var obj = options.map; + var keys = options.keys; + var l = keys.length; + for (var i2 = 0; i2 < l; i2++) { + var key = keys[i2]; + if (plainObject(key)) { + throw Error("Tried to set map with object key"); + } + if (i2 < keys.length - 1) { + if (obj[key] == null) { + obj[key] = {}; + } + obj = obj[key]; + } else { + obj[key] = options.value; + } + } + }; + var getMap = function getMap2(options) { + var obj = options.map; + var keys = options.keys; + var l = keys.length; + for (var i2 = 0; i2 < l; i2++) { + var key = keys[i2]; + if (plainObject(key)) { + throw Error("Tried to get map with object key"); + } + obj = obj[key]; + if (obj == null) { + return obj; + } + } + return obj; + }; + function isObject(value) { + var type = typeof value; + return value != null && (type == "object" || type == "function"); + } + var isObject_1 = isObject; + var commonjsGlobal$1 = typeof globalThis !== "undefined" ? globalThis : typeof window !== "undefined" ? window : typeof commonjsGlobal !== "undefined" ? commonjsGlobal : typeof self !== "undefined" ? self : {}; + function createCommonjsModule(fn2, module2) { + return module2 = { exports: {} }, fn2(module2, module2.exports), module2.exports; + } + var freeGlobal = typeof commonjsGlobal$1 == "object" && commonjsGlobal$1 && commonjsGlobal$1.Object === Object && commonjsGlobal$1; + var _freeGlobal = freeGlobal; + var freeSelf = typeof self == "object" && self && self.Object === Object && self; + var root = _freeGlobal || freeSelf || Function("return this")(); + var _root = root; + var now = function() { + return _root.Date.now(); + }; + var now_1 = now; + var reWhitespace = /\s/; + function trimmedEndIndex(string2) { + var index = string2.length; + while (index-- && reWhitespace.test(string2.charAt(index))) { + } + return index; + } + var _trimmedEndIndex = trimmedEndIndex; + var reTrimStart = /^\s+/; + function baseTrim(string2) { + return string2 ? string2.slice(0, _trimmedEndIndex(string2) + 1).replace(reTrimStart, "") : string2; + } + var _baseTrim = baseTrim; + var Symbol$1 = _root.Symbol; + var _Symbol = Symbol$1; + var objectProto$5 = Object.prototype; + var hasOwnProperty$4 = objectProto$5.hasOwnProperty; + var nativeObjectToString$1 = objectProto$5.toString; + var symToStringTag$1 = _Symbol ? _Symbol.toStringTag : void 0; + function getRawTag(value) { + var isOwn = hasOwnProperty$4.call(value, symToStringTag$1), tag = value[symToStringTag$1]; + try { + value[symToStringTag$1] = void 0; + var unmasked = true; + } catch (e) { + } + var result = nativeObjectToString$1.call(value); + if (unmasked) { + if (isOwn) { + value[symToStringTag$1] = tag; + } else { + delete value[symToStringTag$1]; + } + } + return result; + } + var _getRawTag = getRawTag; + var objectProto$4 = Object.prototype; + var nativeObjectToString = objectProto$4.toString; + function objectToString(value) { + return nativeObjectToString.call(value); + } + var _objectToString = objectToString; + var nullTag = "[object Null]", undefinedTag = "[object Undefined]"; + var symToStringTag = _Symbol ? _Symbol.toStringTag : void 0; + function baseGetTag(value) { + if (value == null) { + return value === void 0 ? undefinedTag : nullTag; + } + return symToStringTag && symToStringTag in Object(value) ? _getRawTag(value) : _objectToString(value); + } + var _baseGetTag = baseGetTag; + function isObjectLike(value) { + return value != null && typeof value == "object"; + } + var isObjectLike_1 = isObjectLike; + var symbolTag = "[object Symbol]"; + function isSymbol(value) { + return typeof value == "symbol" || isObjectLike_1(value) && _baseGetTag(value) == symbolTag; + } + var isSymbol_1 = isSymbol; + var NAN = 0 / 0; + var reIsBadHex = /^[-+]0x[0-9a-f]+$/i; + var reIsBinary = /^0b[01]+$/i; + var reIsOctal = /^0o[0-7]+$/i; + var freeParseInt = parseInt; + function toNumber(value) { + if (typeof value == "number") { + return value; + } + if (isSymbol_1(value)) { + return NAN; + } + if (isObject_1(value)) { + var other = typeof value.valueOf == "function" ? value.valueOf() : value; + value = isObject_1(other) ? other + "" : other; + } + if (typeof value != "string") { + return value === 0 ? value : +value; + } + value = _baseTrim(value); + var isBinary = reIsBinary.test(value); + return isBinary || reIsOctal.test(value) ? freeParseInt(value.slice(2), isBinary ? 2 : 8) : reIsBadHex.test(value) ? NAN : +value; + } + var toNumber_1 = toNumber; + var FUNC_ERROR_TEXT$1 = "Expected a function"; + var nativeMax = Math.max, nativeMin = Math.min; + function debounce(func, wait, options) { + var lastArgs, lastThis, maxWait, result, timerId, lastCallTime, lastInvokeTime = 0, leading = false, maxing = false, trailing = true; + if (typeof func != "function") { + throw new TypeError(FUNC_ERROR_TEXT$1); + } + wait = toNumber_1(wait) || 0; + if (isObject_1(options)) { + leading = !!options.leading; + maxing = "maxWait" in options; + maxWait = maxing ? nativeMax(toNumber_1(options.maxWait) || 0, wait) : maxWait; + trailing = "trailing" in options ? !!options.trailing : trailing; + } + function invokeFunc(time) { + var args = lastArgs, thisArg = lastThis; + lastArgs = lastThis = void 0; + lastInvokeTime = time; + result = func.apply(thisArg, args); + return result; + } + function leadingEdge(time) { + lastInvokeTime = time; + timerId = setTimeout(timerExpired, wait); + return leading ? invokeFunc(time) : result; + } + function remainingWait(time) { + var timeSinceLastCall = time - lastCallTime, timeSinceLastInvoke = time - lastInvokeTime, timeWaiting = wait - timeSinceLastCall; + return maxing ? nativeMin(timeWaiting, maxWait - timeSinceLastInvoke) : timeWaiting; + } + function shouldInvoke(time) { + var timeSinceLastCall = time - lastCallTime, timeSinceLastInvoke = time - lastInvokeTime; + return lastCallTime === void 0 || timeSinceLastCall >= wait || timeSinceLastCall < 0 || maxing && timeSinceLastInvoke >= maxWait; + } + function timerExpired() { + var time = now_1(); + if (shouldInvoke(time)) { + return trailingEdge(time); + } + timerId = setTimeout(timerExpired, remainingWait(time)); + } + function trailingEdge(time) { + timerId = void 0; + if (trailing && lastArgs) { + return invokeFunc(time); + } + lastArgs = lastThis = void 0; + return result; + } + function cancel() { + if (timerId !== void 0) { + clearTimeout(timerId); + } + lastInvokeTime = 0; + lastArgs = lastCallTime = lastThis = timerId = void 0; + } + function flush() { + return timerId === void 0 ? result : trailingEdge(now_1()); + } + function debounced() { + var time = now_1(), isInvoking = shouldInvoke(time); + lastArgs = arguments; + lastThis = this; + lastCallTime = time; + if (isInvoking) { + if (timerId === void 0) { + return leadingEdge(lastCallTime); + } + if (maxing) { + clearTimeout(timerId); + timerId = setTimeout(timerExpired, wait); + return invokeFunc(lastCallTime); + } + } + if (timerId === void 0) { + timerId = setTimeout(timerExpired, wait); + } + return result; + } + debounced.cancel = cancel; + debounced.flush = flush; + return debounced; + } + var debounce_1 = debounce; + var performance = _window ? _window.performance : null; + var pnow = performance && performance.now ? function() { + return performance.now(); + } : function() { + return Date.now(); + }; + var raf = function() { + if (_window) { + if (_window.requestAnimationFrame) { + return function(fn2) { + _window.requestAnimationFrame(fn2); + }; + } else if (_window.mozRequestAnimationFrame) { + return function(fn2) { + _window.mozRequestAnimationFrame(fn2); + }; + } else if (_window.webkitRequestAnimationFrame) { + return function(fn2) { + _window.webkitRequestAnimationFrame(fn2); + }; + } else if (_window.msRequestAnimationFrame) { + return function(fn2) { + _window.msRequestAnimationFrame(fn2); + }; + } + } + return function(fn2) { + if (fn2) { + setTimeout(function() { + fn2(pnow()); + }, 1e3 / 60); + } + }; + }(); + var requestAnimationFrame2 = function requestAnimationFrame3(fn2) { + return raf(fn2); + }; + var performanceNow = pnow; + var DEFAULT_HASH_SEED = 9261; + var K = 65599; + var DEFAULT_HASH_SEED_ALT = 5381; + var hashIterableInts = function hashIterableInts2(iterator) { + var seed = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : DEFAULT_HASH_SEED; + var hash = seed; + var entry; + for (; ; ) { + entry = iterator.next(); + if (entry.done) { + break; + } + hash = hash * K + entry.value | 0; + } + return hash; + }; + var hashInt = function hashInt2(num) { + var seed = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : DEFAULT_HASH_SEED; + return seed * K + num | 0; + }; + var hashIntAlt = function hashIntAlt2(num) { + var seed = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : DEFAULT_HASH_SEED_ALT; + return (seed << 5) + seed + num | 0; + }; + var combineHashes = function combineHashes2(hash1, hash2) { + return hash1 * 2097152 + hash2; + }; + var combineHashesArray = function combineHashesArray2(hashes) { + return hashes[0] * 2097152 + hashes[1]; + }; + var hashArrays = function hashArrays2(hashes1, hashes2) { + return [hashInt(hashes1[0], hashes2[0]), hashIntAlt(hashes1[1], hashes2[1])]; + }; + var hashIntsArray = function hashIntsArray2(ints, seed) { + var entry = { + value: 0, + done: false + }; + var i2 = 0; + var length = ints.length; + var iterator = { + next: function next2() { + if (i2 < length) { + entry.value = ints[i2++]; + } else { + entry.done = true; + } + return entry; + } + }; + return hashIterableInts(iterator, seed); + }; + var hashString = function hashString2(str, seed) { + var entry = { + value: 0, + done: false + }; + var i2 = 0; + var length = str.length; + var iterator = { + next: function next2() { + if (i2 < length) { + entry.value = str.charCodeAt(i2++); + } else { + entry.done = true; + } + return entry; + } + }; + return hashIterableInts(iterator, seed); + }; + var hashStrings = function hashStrings2() { + return hashStringsArray(arguments); + }; + var hashStringsArray = function hashStringsArray2(strs) { + var hash; + for (var i2 = 0; i2 < strs.length; i2++) { + var str = strs[i2]; + if (i2 === 0) { + hash = hashString(str); + } else { + hash = hashString(str, hash); + } + } + return hash; + }; + var warningsEnabled = true; + var warnSupported = console.warn != null; + var traceSupported = console.trace != null; + var MAX_INT$1 = Number.MAX_SAFE_INTEGER || 9007199254740991; + var trueify = function trueify2() { + return true; + }; + var falsify = function falsify2() { + return false; + }; + var zeroify = function zeroify2() { + return 0; + }; + var noop$1 = function noop2() { + }; + var error = function error2(msg) { + throw new Error(msg); + }; + var warnings = function warnings2(enabled) { + if (enabled !== void 0) { + warningsEnabled = !!enabled; + } else { + return warningsEnabled; + } + }; + var warn = function warn2(msg) { + if (!warnings()) { + return; + } + if (warnSupported) { + console.warn(msg); + } else { + console.log(msg); + if (traceSupported) { + console.trace(); + } + } + }; + var clone = function clone2(obj) { + return extend({}, obj); + }; + var copy = function copy2(obj) { + if (obj == null) { + return obj; + } + if (array(obj)) { + return obj.slice(); + } else if (plainObject(obj)) { + return clone(obj); + } else { + return obj; + } + }; + var copyArray$1 = function copyArray2(arr) { + return arr.slice(); + }; + var uuid = function uuid2(a, b) { + for ( + // loop :) + b = a = ""; + // b - result , a - numeric letiable + a++ < 36; + // + b += a * 51 & 52 ? ( + // return a random number or 4 + (a ^ 15 ? ( + // generate a random number from 0 to 15 + 8 ^ Math.random() * (a ^ 20 ? 16 : 4) + ) : 4).toString(16) + ) : "-" + ) { + } + return b; + }; + var _staticEmptyObject = {}; + var staticEmptyObject = function staticEmptyObject2() { + return _staticEmptyObject; + }; + var defaults$g = function defaults2(_defaults) { + var keys = Object.keys(_defaults); + return function(opts) { + var filledOpts = {}; + for (var i2 = 0; i2 < keys.length; i2++) { + var key = keys[i2]; + var optVal = opts == null ? void 0 : opts[key]; + filledOpts[key] = optVal === void 0 ? _defaults[key] : optVal; + } + return filledOpts; + }; + }; + var removeFromArray = function removeFromArray2(arr, ele, oneCopy) { + for (var i2 = arr.length - 1; i2 >= 0; i2--) { + if (arr[i2] === ele) { + arr.splice(i2, 1); + if (oneCopy) { + break; + } + } + } + }; + var clearArray = function clearArray2(arr) { + arr.splice(0, arr.length); + }; + var push = function push2(arr, otherArr) { + for (var i2 = 0; i2 < otherArr.length; i2++) { + var el = otherArr[i2]; + arr.push(el); + } + }; + var getPrefixedProperty = function getPrefixedProperty2(obj, propName, prefix) { + if (prefix) { + propName = prependCamel(prefix, propName); + } + return obj[propName]; + }; + var setPrefixedProperty = function setPrefixedProperty2(obj, propName, prefix, value) { + if (prefix) { + propName = prependCamel(prefix, propName); + } + obj[propName] = value; + }; + var ObjectMap = /* @__PURE__ */ function() { + function ObjectMap2() { + _classCallCheck(this, ObjectMap2); + this._obj = {}; + } + _createClass(ObjectMap2, [{ + key: "set", + value: function set2(key, val) { + this._obj[key] = val; + return this; + } + }, { + key: "delete", + value: function _delete(key) { + this._obj[key] = void 0; + return this; + } + }, { + key: "clear", + value: function clear2() { + this._obj = {}; + } + }, { + key: "has", + value: function has(key) { + return this._obj[key] !== void 0; + } + }, { + key: "get", + value: function get2(key) { + return this._obj[key]; + } + }]); + return ObjectMap2; + }(); + var Map$2 = typeof Map !== "undefined" ? Map : ObjectMap; + var undef = "undefined"; + var ObjectSet = /* @__PURE__ */ function() { + function ObjectSet2(arrayOrObjectSet) { + _classCallCheck(this, ObjectSet2); + this._obj = /* @__PURE__ */ Object.create(null); + this.size = 0; + if (arrayOrObjectSet != null) { + var arr; + if (arrayOrObjectSet.instanceString != null && arrayOrObjectSet.instanceString() === this.instanceString()) { + arr = arrayOrObjectSet.toArray(); + } else { + arr = arrayOrObjectSet; + } + for (var i2 = 0; i2 < arr.length; i2++) { + this.add(arr[i2]); + } + } + } + _createClass(ObjectSet2, [{ + key: "instanceString", + value: function instanceString() { + return "set"; + } + }, { + key: "add", + value: function add(val) { + var o = this._obj; + if (o[val] !== 1) { + o[val] = 1; + this.size++; + } + } + }, { + key: "delete", + value: function _delete(val) { + var o = this._obj; + if (o[val] === 1) { + o[val] = 0; + this.size--; + } + } + }, { + key: "clear", + value: function clear2() { + this._obj = /* @__PURE__ */ Object.create(null); + } + }, { + key: "has", + value: function has(val) { + return this._obj[val] === 1; + } + }, { + key: "toArray", + value: function toArray() { + var _this = this; + return Object.keys(this._obj).filter(function(key) { + return _this.has(key); + }); + } + }, { + key: "forEach", + value: function forEach(callback, thisArg) { + return this.toArray().forEach(callback, thisArg); + } + }]); + return ObjectSet2; + }(); + var Set$1 = (typeof Set === "undefined" ? "undefined" : _typeof(Set)) !== undef ? Set : ObjectSet; + var Element = function Element2(cy, params) { + var restore = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : true; + if (cy === void 0 || params === void 0 || !core(cy)) { + error("An element must have a core reference and parameters set"); + return; + } + var group = params.group; + if (group == null) { + if (params.data && params.data.source != null && params.data.target != null) { + group = "edges"; + } else { + group = "nodes"; + } + } + if (group !== "nodes" && group !== "edges") { + error("An element must be of type `nodes` or `edges`; you specified `" + group + "`"); + return; + } + this.length = 1; + this[0] = this; + var _p = this._private = { + cy, + single: true, + // indicates this is an element + data: params.data || {}, + // data object + position: params.position || { + x: 0, + y: 0 + }, + // (x, y) position pair + autoWidth: void 0, + // width and height of nodes calculated by the renderer when set to special 'auto' value + autoHeight: void 0, + autoPadding: void 0, + compoundBoundsClean: false, + // whether the compound dimensions need to be recalculated the next time dimensions are read + listeners: [], + // array of bound listeners + group, + // string; 'nodes' or 'edges' + style: {}, + // properties as set by the style + rstyle: {}, + // properties for style sent from the renderer to the core + styleCxts: [], + // applied style contexts from the styler + styleKeys: {}, + // per-group keys of style property values + removed: true, + // whether it's inside the vis; true if removed (set true here since we call restore) + selected: params.selected ? true : false, + // whether it's selected + selectable: params.selectable === void 0 ? true : params.selectable ? true : false, + // whether it's selectable + locked: params.locked ? true : false, + // whether the element is locked (cannot be moved) + grabbed: false, + // whether the element is grabbed by the mouse; renderer sets this privately + grabbable: params.grabbable === void 0 ? true : params.grabbable ? true : false, + // whether the element can be grabbed + pannable: params.pannable === void 0 ? group === "edges" ? true : false : params.pannable ? true : false, + // whether the element has passthrough panning enabled + active: false, + // whether the element is active from user interaction + classes: new Set$1(), + // map ( className => true ) + animation: { + // object for currently-running animations + current: [], + queue: [] + }, + rscratch: {}, + // object in which the renderer can store information + scratch: params.scratch || {}, + // scratch objects + edges: [], + // array of connected edges + children: [], + // array of children + parent: params.parent && params.parent.isNode() ? params.parent : null, + // parent ref + traversalCache: {}, + // cache of output of traversal functions + backgrounding: false, + // whether background images are loading + bbCache: null, + // cache of the current bounding box + bbCacheShift: { + x: 0, + y: 0 + }, + // shift applied to cached bb to be applied on next get + bodyBounds: null, + // bounds cache of element body, w/o overlay + overlayBounds: null, + // bounds cache of element body, including overlay + labelBounds: { + // bounds cache of labels + all: null, + source: null, + target: null, + main: null + }, + arrowBounds: { + // bounds cache of edge arrows + source: null, + target: null, + "mid-source": null, + "mid-target": null + } + }; + if (_p.position.x == null) { + _p.position.x = 0; + } + if (_p.position.y == null) { + _p.position.y = 0; + } + if (params.renderedPosition) { + var rpos = params.renderedPosition; + var pan = cy.pan(); + var zoom = cy.zoom(); + _p.position = { + x: (rpos.x - pan.x) / zoom, + y: (rpos.y - pan.y) / zoom + }; + } + var classes = []; + if (array(params.classes)) { + classes = params.classes; + } else if (string(params.classes)) { + classes = params.classes.split(/\s+/); + } + for (var i2 = 0, l = classes.length; i2 < l; i2++) { + var cls = classes[i2]; + if (!cls || cls === "") { + continue; + } + _p.classes.add(cls); + } + this.createEmitter(); + var bypass = params.style || params.css; + if (bypass) { + warn("Setting a `style` bypass at element creation should be done only when absolutely necessary. Try to use the stylesheet instead."); + this.style(bypass); + } + if (restore === void 0 || restore) { + this.restore(); + } + }; + var defineSearch = function defineSearch2(params) { + params = { + bfs: params.bfs || !params.dfs, + dfs: params.dfs || !params.bfs + }; + return function searchFn(roots, fn2, directed) { + var options; + if (plainObject(roots) && !elementOrCollection(roots)) { + options = roots; + roots = options.roots || options.root; + fn2 = options.visit; + directed = options.directed; + } + directed = arguments.length === 2 && !fn$6(fn2) ? fn2 : directed; + fn2 = fn$6(fn2) ? fn2 : function() { + }; + var cy = this._private.cy; + var v = roots = string(roots) ? this.filter(roots) : roots; + var Q = []; + var connectedNodes = []; + var connectedBy = {}; + var id2depth = {}; + var V = {}; + var j = 0; + var found; + var _this$byGroup = this.byGroup(), nodes2 = _this$byGroup.nodes, edges = _this$byGroup.edges; + for (var i2 = 0; i2 < v.length; i2++) { + var vi = v[i2]; + var viId = vi.id(); + if (vi.isNode()) { + Q.unshift(vi); + if (params.bfs) { + V[viId] = true; + connectedNodes.push(vi); + } + id2depth[viId] = 0; + } + } + var _loop = function _loop2() { + var v2 = params.bfs ? Q.shift() : Q.pop(); + var vId = v2.id(); + if (params.dfs) { + if (V[vId]) { + return "continue"; + } + V[vId] = true; + connectedNodes.push(v2); + } + var depth = id2depth[vId]; + var prevEdge = connectedBy[vId]; + var src = prevEdge != null ? prevEdge.source() : null; + var tgt = prevEdge != null ? prevEdge.target() : null; + var prevNode = prevEdge == null ? void 0 : v2.same(src) ? tgt[0] : src[0]; + var ret = void 0; + ret = fn2(v2, prevEdge, prevNode, j++, depth); + if (ret === true) { + found = v2; + return "break"; + } + if (ret === false) { + return "break"; + } + var vwEdges = v2.connectedEdges().filter(function(e2) { + return (!directed || e2.source().same(v2)) && edges.has(e2); + }); + for (var _i2 = 0; _i2 < vwEdges.length; _i2++) { + var e = vwEdges[_i2]; + var w = e.connectedNodes().filter(function(n) { + return !n.same(v2) && nodes2.has(n); + }); + var wId = w.id(); + if (w.length !== 0 && !V[wId]) { + w = w[0]; + Q.push(w); + if (params.bfs) { + V[wId] = true; + connectedNodes.push(w); + } + connectedBy[wId] = e; + id2depth[wId] = id2depth[vId] + 1; + } + } + }; + while (Q.length !== 0) { + var _ret = _loop(); + if (_ret === "continue") + continue; + if (_ret === "break") + break; + } + var connectedEles = cy.collection(); + for (var _i = 0; _i < connectedNodes.length; _i++) { + var node = connectedNodes[_i]; + var edge = connectedBy[node.id()]; + if (edge != null) { + connectedEles.push(edge); + } + connectedEles.push(node); + } + return { + path: cy.collection(connectedEles), + found: cy.collection(found) + }; + }; + }; + var elesfn$v = { + breadthFirstSearch: defineSearch({ + bfs: true + }), + depthFirstSearch: defineSearch({ + dfs: true + }) + }; + elesfn$v.bfs = elesfn$v.breadthFirstSearch; + elesfn$v.dfs = elesfn$v.depthFirstSearch; + var heap$1 = createCommonjsModule(function(module2, exports2) { + (function() { + var Heap, defaultCmp, floor, heapify, heappop, heappush, heappushpop, heapreplace, insort, min2, nlargest, nsmallest, updateItem, _siftdown, _siftup; + floor = Math.floor, min2 = Math.min; + defaultCmp = function(x, y) { + if (x < y) { + return -1; + } + if (x > y) { + return 1; + } + return 0; + }; + insort = function(a, x, lo, hi, cmp) { + var mid; + if (lo == null) { + lo = 0; + } + if (cmp == null) { + cmp = defaultCmp; + } + if (lo < 0) { + throw new Error("lo must be non-negative"); + } + if (hi == null) { + hi = a.length; + } + while (lo < hi) { + mid = floor((lo + hi) / 2); + if (cmp(x, a[mid]) < 0) { + hi = mid; + } else { + lo = mid + 1; + } + } + return [].splice.apply(a, [lo, lo - lo].concat(x)), x; + }; + heappush = function(array2, item, cmp) { + if (cmp == null) { + cmp = defaultCmp; + } + array2.push(item); + return _siftdown(array2, 0, array2.length - 1, cmp); + }; + heappop = function(array2, cmp) { + var lastelt, returnitem; + if (cmp == null) { + cmp = defaultCmp; + } + lastelt = array2.pop(); + if (array2.length) { + returnitem = array2[0]; + array2[0] = lastelt; + _siftup(array2, 0, cmp); + } else { + returnitem = lastelt; + } + return returnitem; + }; + heapreplace = function(array2, item, cmp) { + var returnitem; + if (cmp == null) { + cmp = defaultCmp; + } + returnitem = array2[0]; + array2[0] = item; + _siftup(array2, 0, cmp); + return returnitem; + }; + heappushpop = function(array2, item, cmp) { + var _ref; + if (cmp == null) { + cmp = defaultCmp; + } + if (array2.length && cmp(array2[0], item) < 0) { + _ref = [array2[0], item], item = _ref[0], array2[0] = _ref[1]; + _siftup(array2, 0, cmp); + } + return item; + }; + heapify = function(array2, cmp) { + var i2, _i, _len, _ref1, _results, _results1; + if (cmp == null) { + cmp = defaultCmp; + } + _ref1 = (function() { + _results1 = []; + for (var _j = 0, _ref = floor(array2.length / 2); 0 <= _ref ? _j < _ref : _j > _ref; 0 <= _ref ? _j++ : _j--) { + _results1.push(_j); + } + return _results1; + }).apply(this).reverse(); + _results = []; + for (_i = 0, _len = _ref1.length; _i < _len; _i++) { + i2 = _ref1[_i]; + _results.push(_siftup(array2, i2, cmp)); + } + return _results; + }; + updateItem = function(array2, item, cmp) { + var pos; + if (cmp == null) { + cmp = defaultCmp; + } + pos = array2.indexOf(item); + if (pos === -1) { + return; + } + _siftdown(array2, 0, pos, cmp); + return _siftup(array2, pos, cmp); + }; + nlargest = function(array2, n, cmp) { + var elem, result, _i, _len, _ref; + if (cmp == null) { + cmp = defaultCmp; + } + result = array2.slice(0, n); + if (!result.length) { + return result; + } + heapify(result, cmp); + _ref = array2.slice(n); + for (_i = 0, _len = _ref.length; _i < _len; _i++) { + elem = _ref[_i]; + heappushpop(result, elem, cmp); + } + return result.sort(cmp).reverse(); + }; + nsmallest = function(array2, n, cmp) { + var elem, los, result, _i, _j, _len, _ref, _ref1, _results; + if (cmp == null) { + cmp = defaultCmp; + } + if (n * 10 <= array2.length) { + result = array2.slice(0, n).sort(cmp); + if (!result.length) { + return result; + } + los = result[result.length - 1]; + _ref = array2.slice(n); + for (_i = 0, _len = _ref.length; _i < _len; _i++) { + elem = _ref[_i]; + if (cmp(elem, los) < 0) { + insort(result, elem, 0, null, cmp); + result.pop(); + los = result[result.length - 1]; + } + } + return result; + } + heapify(array2, cmp); + _results = []; + for (_j = 0, _ref1 = min2(n, array2.length); 0 <= _ref1 ? _j < _ref1 : _j > _ref1; 0 <= _ref1 ? ++_j : --_j) { + _results.push(heappop(array2, cmp)); + } + return _results; + }; + _siftdown = function(array2, startpos, pos, cmp) { + var newitem, parent, parentpos; + if (cmp == null) { + cmp = defaultCmp; + } + newitem = array2[pos]; + while (pos > startpos) { + parentpos = pos - 1 >> 1; + parent = array2[parentpos]; + if (cmp(newitem, parent) < 0) { + array2[pos] = parent; + pos = parentpos; + continue; + } + break; + } + return array2[pos] = newitem; + }; + _siftup = function(array2, pos, cmp) { + var childpos, endpos, newitem, rightpos, startpos; + if (cmp == null) { + cmp = defaultCmp; + } + endpos = array2.length; + startpos = pos; + newitem = array2[pos]; + childpos = 2 * pos + 1; + while (childpos < endpos) { + rightpos = childpos + 1; + if (rightpos < endpos && !(cmp(array2[childpos], array2[rightpos]) < 0)) { + childpos = rightpos; + } + array2[pos] = array2[childpos]; + pos = childpos; + childpos = 2 * pos + 1; + } + array2[pos] = newitem; + return _siftdown(array2, startpos, pos, cmp); + }; + Heap = function() { + Heap2.push = heappush; + Heap2.pop = heappop; + Heap2.replace = heapreplace; + Heap2.pushpop = heappushpop; + Heap2.heapify = heapify; + Heap2.updateItem = updateItem; + Heap2.nlargest = nlargest; + Heap2.nsmallest = nsmallest; + function Heap2(cmp) { + this.cmp = cmp != null ? cmp : defaultCmp; + this.nodes = []; + } + Heap2.prototype.push = function(x) { + return heappush(this.nodes, x, this.cmp); + }; + Heap2.prototype.pop = function() { + return heappop(this.nodes, this.cmp); + }; + Heap2.prototype.peek = function() { + return this.nodes[0]; + }; + Heap2.prototype.contains = function(x) { + return this.nodes.indexOf(x) !== -1; + }; + Heap2.prototype.replace = function(x) { + return heapreplace(this.nodes, x, this.cmp); + }; + Heap2.prototype.pushpop = function(x) { + return heappushpop(this.nodes, x, this.cmp); + }; + Heap2.prototype.heapify = function() { + return heapify(this.nodes, this.cmp); + }; + Heap2.prototype.updateItem = function(x) { + return updateItem(this.nodes, x, this.cmp); + }; + Heap2.prototype.clear = function() { + return this.nodes = []; + }; + Heap2.prototype.empty = function() { + return this.nodes.length === 0; + }; + Heap2.prototype.size = function() { + return this.nodes.length; + }; + Heap2.prototype.clone = function() { + var heap2; + heap2 = new Heap2(); + heap2.nodes = this.nodes.slice(0); + return heap2; + }; + Heap2.prototype.toArray = function() { + return this.nodes.slice(0); + }; + Heap2.prototype.insert = Heap2.prototype.push; + Heap2.prototype.top = Heap2.prototype.peek; + Heap2.prototype.front = Heap2.prototype.peek; + Heap2.prototype.has = Heap2.prototype.contains; + Heap2.prototype.copy = Heap2.prototype.clone; + return Heap2; + }(); + (function(root2, factory) { + { + return module2.exports = factory(); + } + })(this, function() { + return Heap; + }); + }).call(commonjsGlobal$1); + }); + var heap = heap$1; + var dijkstraDefaults = defaults$g({ + root: null, + weight: function weight(edge) { + return 1; + }, + directed: false + }); + var elesfn$u = { + dijkstra: function dijkstra(options) { + if (!plainObject(options)) { + var args = arguments; + options = { + root: args[0], + weight: args[1], + directed: args[2] + }; + } + var _dijkstraDefaults = dijkstraDefaults(options), root2 = _dijkstraDefaults.root, weight = _dijkstraDefaults.weight, directed = _dijkstraDefaults.directed; + var eles = this; + var weightFn = weight; + var source = string(root2) ? this.filter(root2)[0] : root2[0]; + var dist2 = {}; + var prev = {}; + var knownDist = {}; + var _this$byGroup = this.byGroup(), nodes2 = _this$byGroup.nodes, edges = _this$byGroup.edges; + edges.unmergeBy(function(ele) { + return ele.isLoop(); + }); + var getDist2 = function getDist3(node2) { + return dist2[node2.id()]; + }; + var setDist = function setDist2(node2, d) { + dist2[node2.id()] = d; + Q.updateItem(node2); + }; + var Q = new heap(function(a, b) { + return getDist2(a) - getDist2(b); + }); + for (var i2 = 0; i2 < nodes2.length; i2++) { + var node = nodes2[i2]; + dist2[node.id()] = node.same(source) ? 0 : Infinity; + Q.push(node); + } + var distBetween = function distBetween2(u2, v2) { + var uvs = (directed ? u2.edgesTo(v2) : u2.edgesWith(v2)).intersect(edges); + var smallestDistance = Infinity; + var smallestEdge; + for (var _i = 0; _i < uvs.length; _i++) { + var edge = uvs[_i]; + var _weight = weightFn(edge); + if (_weight < smallestDistance || !smallestEdge) { + smallestDistance = _weight; + smallestEdge = edge; + } + } + return { + edge: smallestEdge, + dist: smallestDistance + }; + }; + while (Q.size() > 0) { + var u = Q.pop(); + var smalletsDist = getDist2(u); + var uid = u.id(); + knownDist[uid] = smalletsDist; + if (smalletsDist === Infinity) { + continue; + } + var neighbors = u.neighborhood().intersect(nodes2); + for (var _i2 = 0; _i2 < neighbors.length; _i2++) { + var v = neighbors[_i2]; + var vid = v.id(); + var vDist = distBetween(u, v); + var alt = smalletsDist + vDist.dist; + if (alt < getDist2(v)) { + setDist(v, alt); + prev[vid] = { + node: u, + edge: vDist.edge + }; + } + } + } + return { + distanceTo: function distanceTo(node2) { + var target = string(node2) ? nodes2.filter(node2)[0] : node2[0]; + return knownDist[target.id()]; + }, + pathTo: function pathTo(node2) { + var target = string(node2) ? nodes2.filter(node2)[0] : node2[0]; + var S = []; + var u2 = target; + var uid2 = u2.id(); + if (target.length > 0) { + S.unshift(target); + while (prev[uid2]) { + var p2 = prev[uid2]; + S.unshift(p2.edge); + S.unshift(p2.node); + u2 = p2.node; + uid2 = u2.id(); + } + } + return eles.spawn(S); + } + }; + } + }; + var elesfn$t = { + // kruskal's algorithm (finds min spanning tree, assuming undirected graph) + // implemented from pseudocode from wikipedia + kruskal: function kruskal(weightFn) { + weightFn = weightFn || function(edge2) { + return 1; + }; + var _this$byGroup = this.byGroup(), nodes2 = _this$byGroup.nodes, edges = _this$byGroup.edges; + var numNodes = nodes2.length; + var forest = new Array(numNodes); + var A = nodes2; + var findSetIndex = function findSetIndex2(ele) { + for (var i3 = 0; i3 < forest.length; i3++) { + var eles = forest[i3]; + if (eles.has(ele)) { + return i3; + } + } + }; + for (var i2 = 0; i2 < numNodes; i2++) { + forest[i2] = this.spawn(nodes2[i2]); + } + var S = edges.sort(function(a, b) { + return weightFn(a) - weightFn(b); + }); + for (var _i = 0; _i < S.length; _i++) { + var edge = S[_i]; + var u = edge.source()[0]; + var v = edge.target()[0]; + var setUIndex = findSetIndex(u); + var setVIndex = findSetIndex(v); + var setU = forest[setUIndex]; + var setV = forest[setVIndex]; + if (setUIndex !== setVIndex) { + A.merge(edge); + setU.merge(setV); + forest.splice(setVIndex, 1); + } + } + return A; + } + }; + var aStarDefaults = defaults$g({ + root: null, + goal: null, + weight: function weight(edge) { + return 1; + }, + heuristic: function heuristic(edge) { + return 0; + }, + directed: false + }); + var elesfn$s = { + // Implemented from pseudocode from wikipedia + aStar: function aStar(options) { + var cy = this.cy(); + var _aStarDefaults = aStarDefaults(options), root2 = _aStarDefaults.root, goal = _aStarDefaults.goal, heuristic = _aStarDefaults.heuristic, directed = _aStarDefaults.directed, weight = _aStarDefaults.weight; + root2 = cy.collection(root2)[0]; + goal = cy.collection(goal)[0]; + var sid = root2.id(); + var tid = goal.id(); + var gScore = {}; + var fScore = {}; + var closedSetIds = {}; + var openSet = new heap(function(a, b) { + return fScore[a.id()] - fScore[b.id()]; + }); + var openSetIds = new Set$1(); + var cameFrom = {}; + var cameFromEdge = {}; + var addToOpenSet = function addToOpenSet2(ele, id) { + openSet.push(ele); + openSetIds.add(id); + }; + var cMin, cMinId; + var popFromOpenSet = function popFromOpenSet2() { + cMin = openSet.pop(); + cMinId = cMin.id(); + openSetIds["delete"](cMinId); + }; + var isInOpenSet = function isInOpenSet2(id) { + return openSetIds.has(id); + }; + addToOpenSet(root2, sid); + gScore[sid] = 0; + fScore[sid] = heuristic(root2); + var steps = 0; + while (openSet.size() > 0) { + popFromOpenSet(); + steps++; + if (cMinId === tid) { + var path = []; + var pathNode = goal; + var pathNodeId = tid; + var pathEdge = cameFromEdge[pathNodeId]; + for (; ; ) { + path.unshift(pathNode); + if (pathEdge != null) { + path.unshift(pathEdge); + } + pathNode = cameFrom[pathNodeId]; + if (pathNode == null) { + break; + } + pathNodeId = pathNode.id(); + pathEdge = cameFromEdge[pathNodeId]; + } + return { + found: true, + distance: gScore[cMinId], + path: this.spawn(path), + steps + }; + } + closedSetIds[cMinId] = true; + var vwEdges = cMin._private.edges; + for (var i2 = 0; i2 < vwEdges.length; i2++) { + var e = vwEdges[i2]; + if (!this.hasElementWithId(e.id())) { + continue; + } + if (directed && e.data("source") !== cMinId) { + continue; + } + var wSrc = e.source(); + var wTgt = e.target(); + var w = wSrc.id() !== cMinId ? wSrc : wTgt; + var wid = w.id(); + if (!this.hasElementWithId(wid)) { + continue; + } + if (closedSetIds[wid]) { + continue; + } + var tempScore = gScore[cMinId] + weight(e); + if (!isInOpenSet(wid)) { + gScore[wid] = tempScore; + fScore[wid] = tempScore + heuristic(w); + addToOpenSet(w, wid); + cameFrom[wid] = cMin; + cameFromEdge[wid] = e; + continue; + } + if (tempScore < gScore[wid]) { + gScore[wid] = tempScore; + fScore[wid] = tempScore + heuristic(w); + cameFrom[wid] = cMin; + cameFromEdge[wid] = e; + } + } + } + return { + found: false, + distance: void 0, + path: void 0, + steps + }; + } + }; + var floydWarshallDefaults = defaults$g({ + weight: function weight(edge) { + return 1; + }, + directed: false + }); + var elesfn$r = { + // Implemented from pseudocode from wikipedia + floydWarshall: function floydWarshall(options) { + var cy = this.cy(); + var _floydWarshallDefault = floydWarshallDefaults(options), weight = _floydWarshallDefault.weight, directed = _floydWarshallDefault.directed; + var weightFn = weight; + var _this$byGroup = this.byGroup(), nodes2 = _this$byGroup.nodes, edges = _this$byGroup.edges; + var N = nodes2.length; + var Nsq = N * N; + var indexOf = function indexOf2(node) { + return nodes2.indexOf(node); + }; + var atIndex = function atIndex2(i3) { + return nodes2[i3]; + }; + var dist2 = new Array(Nsq); + for (var n = 0; n < Nsq; n++) { + var j = n % N; + var i2 = (n - j) / N; + if (i2 === j) { + dist2[n] = 0; + } else { + dist2[n] = Infinity; + } + } + var next2 = new Array(Nsq); + var edgeNext = new Array(Nsq); + for (var _i = 0; _i < edges.length; _i++) { + var edge = edges[_i]; + var src = edge.source()[0]; + var tgt = edge.target()[0]; + if (src === tgt) { + continue; + } + var s = indexOf(src); + var t = indexOf(tgt); + var st = s * N + t; + var _weight = weightFn(edge); + if (dist2[st] > _weight) { + dist2[st] = _weight; + next2[st] = t; + edgeNext[st] = edge; + } + if (!directed) { + var ts = t * N + s; + if (!directed && dist2[ts] > _weight) { + dist2[ts] = _weight; + next2[ts] = s; + edgeNext[ts] = edge; + } + } + } + for (var k = 0; k < N; k++) { + for (var _i2 = 0; _i2 < N; _i2++) { + var ik = _i2 * N + k; + for (var _j = 0; _j < N; _j++) { + var ij = _i2 * N + _j; + var kj = k * N + _j; + if (dist2[ik] + dist2[kj] < dist2[ij]) { + dist2[ij] = dist2[ik] + dist2[kj]; + next2[ij] = next2[ik]; + } + } + } + } + var getArgEle = function getArgEle2(ele) { + return (string(ele) ? cy.filter(ele) : ele)[0]; + }; + var indexOfArgEle = function indexOfArgEle2(ele) { + return indexOf(getArgEle(ele)); + }; + var res = { + distance: function distance(from, to) { + var i3 = indexOfArgEle(from); + var j2 = indexOfArgEle(to); + return dist2[i3 * N + j2]; + }, + path: function path(from, to) { + var i3 = indexOfArgEle(from); + var j2 = indexOfArgEle(to); + var fromNode = atIndex(i3); + if (i3 === j2) { + return fromNode.collection(); + } + if (next2[i3 * N + j2] == null) { + return cy.collection(); + } + var path2 = cy.collection(); + var prev = i3; + var edge2; + path2.merge(fromNode); + while (i3 !== j2) { + prev = i3; + i3 = next2[i3 * N + j2]; + edge2 = edgeNext[prev * N + i3]; + path2.merge(edge2); + path2.merge(atIndex(i3)); + } + return path2; + } + }; + return res; + } + // floydWarshall + }; + var bellmanFordDefaults = defaults$g({ + weight: function weight(edge) { + return 1; + }, + directed: false, + root: null + }); + var elesfn$q = { + // Implemented from pseudocode from wikipedia + bellmanFord: function bellmanFord(options) { + var _this = this; + var _bellmanFordDefaults = bellmanFordDefaults(options), weight = _bellmanFordDefaults.weight, directed = _bellmanFordDefaults.directed, root2 = _bellmanFordDefaults.root; + var weightFn = weight; + var eles = this; + var cy = this.cy(); + var _this$byGroup = this.byGroup(), edges = _this$byGroup.edges, nodes2 = _this$byGroup.nodes; + var numNodes = nodes2.length; + var infoMap = new Map$2(); + var hasNegativeWeightCycle = false; + var negativeWeightCycles = []; + root2 = cy.collection(root2)[0]; + edges.unmergeBy(function(edge2) { + return edge2.isLoop(); + }); + var numEdges = edges.length; + var getInfo2 = function getInfo3(node2) { + var obj = infoMap.get(node2.id()); + if (!obj) { + obj = {}; + infoMap.set(node2.id(), obj); + } + return obj; + }; + var getNodeFromTo = function getNodeFromTo2(to) { + return (string(to) ? cy.$(to) : to)[0]; + }; + var distanceTo = function distanceTo2(to) { + return getInfo2(getNodeFromTo(to)).dist; + }; + var pathTo = function pathTo2(to) { + var thisStart = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : root2; + var end = getNodeFromTo(to); + var path = []; + var node2 = end; + for (; ; ) { + if (node2 == null) { + return _this.spawn(); + } + var _getInfo = getInfo2(node2), edge2 = _getInfo.edge, pred = _getInfo.pred; + path.unshift(node2[0]); + if (node2.same(thisStart) && path.length > 0) { + break; + } + if (edge2 != null) { + path.unshift(edge2); + } + node2 = pred; + } + return eles.spawn(path); + }; + for (var i2 = 0; i2 < numNodes; i2++) { + var node = nodes2[i2]; + var info = getInfo2(node); + if (node.same(root2)) { + info.dist = 0; + } else { + info.dist = Infinity; + } + info.pred = null; + info.edge = null; + } + var replacedEdge = false; + var checkForEdgeReplacement = function checkForEdgeReplacement2(node1, node2, edge2, info1, info2, weight2) { + var dist2 = info1.dist + weight2; + if (dist2 < info2.dist && !edge2.same(info1.edge)) { + info2.dist = dist2; + info2.pred = node1; + info2.edge = edge2; + replacedEdge = true; + } + }; + for (var _i = 1; _i < numNodes; _i++) { + replacedEdge = false; + for (var e = 0; e < numEdges; e++) { + var edge = edges[e]; + var src = edge.source(); + var tgt = edge.target(); + var _weight = weightFn(edge); + var srcInfo = getInfo2(src); + var tgtInfo = getInfo2(tgt); + checkForEdgeReplacement(src, tgt, edge, srcInfo, tgtInfo, _weight); + if (!directed) { + checkForEdgeReplacement(tgt, src, edge, tgtInfo, srcInfo, _weight); + } + } + if (!replacedEdge) { + break; + } + } + if (replacedEdge) { + var negativeWeightCycleIds = []; + for (var _e = 0; _e < numEdges; _e++) { + var _edge = edges[_e]; + var _src = _edge.source(); + var _tgt = _edge.target(); + var _weight2 = weightFn(_edge); + var srcDist = getInfo2(_src).dist; + var tgtDist = getInfo2(_tgt).dist; + if (srcDist + _weight2 < tgtDist || !directed && tgtDist + _weight2 < srcDist) { + if (!hasNegativeWeightCycle) { + warn("Graph contains a negative weight cycle for Bellman-Ford"); + hasNegativeWeightCycle = true; + } + if (options.findNegativeWeightCycles !== false) { + var negativeNodes = []; + if (srcDist + _weight2 < tgtDist) { + negativeNodes.push(_src); + } + if (!directed && tgtDist + _weight2 < srcDist) { + negativeNodes.push(_tgt); + } + var numNegativeNodes = negativeNodes.length; + for (var n = 0; n < numNegativeNodes; n++) { + var start = negativeNodes[n]; + var cycle = [start]; + cycle.push(getInfo2(start).edge); + var _node = getInfo2(start).pred; + while (cycle.indexOf(_node) === -1) { + cycle.push(_node); + cycle.push(getInfo2(_node).edge); + _node = getInfo2(_node).pred; + } + cycle = cycle.slice(cycle.indexOf(_node)); + var smallestId = cycle[0].id(); + var smallestIndex = 0; + for (var c = 2; c < cycle.length; c += 2) { + if (cycle[c].id() < smallestId) { + smallestId = cycle[c].id(); + smallestIndex = c; + } + } + cycle = cycle.slice(smallestIndex).concat(cycle.slice(0, smallestIndex)); + cycle.push(cycle[0]); + var cycleId = cycle.map(function(el) { + return el.id(); + }).join(","); + if (negativeWeightCycleIds.indexOf(cycleId) === -1) { + negativeWeightCycles.push(eles.spawn(cycle)); + negativeWeightCycleIds.push(cycleId); + } + } + } else { + break; + } + } + } + } + return { + distanceTo, + pathTo, + hasNegativeWeightCycle, + negativeWeightCycles + }; + } + // bellmanFord + }; + var sqrt2 = Math.sqrt(2); + var collapse = function collapse2(edgeIndex, nodeMap, remainingEdges) { + if (remainingEdges.length === 0) { + error("Karger-Stein must be run on a connected (sub)graph"); + } + var edgeInfo = remainingEdges[edgeIndex]; + var sourceIn = edgeInfo[1]; + var targetIn = edgeInfo[2]; + var partition1 = nodeMap[sourceIn]; + var partition2 = nodeMap[targetIn]; + var newEdges = remainingEdges; + for (var i2 = newEdges.length - 1; i2 >= 0; i2--) { + var edge = newEdges[i2]; + var src = edge[1]; + var tgt = edge[2]; + if (nodeMap[src] === partition1 && nodeMap[tgt] === partition2 || nodeMap[src] === partition2 && nodeMap[tgt] === partition1) { + newEdges.splice(i2, 1); + } + } + for (var _i = 0; _i < newEdges.length; _i++) { + var _edge = newEdges[_i]; + if (_edge[1] === partition2) { + newEdges[_i] = _edge.slice(); + newEdges[_i][1] = partition1; + } else if (_edge[2] === partition2) { + newEdges[_i] = _edge.slice(); + newEdges[_i][2] = partition1; + } + } + for (var _i2 = 0; _i2 < nodeMap.length; _i2++) { + if (nodeMap[_i2] === partition2) { + nodeMap[_i2] = partition1; + } + } + return newEdges; + }; + var contractUntil = function contractUntil2(metaNodeMap, remainingEdges, size, sizeLimit) { + while (size > sizeLimit) { + var edgeIndex = Math.floor(Math.random() * remainingEdges.length); + remainingEdges = collapse(edgeIndex, metaNodeMap, remainingEdges); + size--; + } + return remainingEdges; + }; + var elesfn$p = { + // Computes the minimum cut of an undirected graph + // Returns the correct answer with high probability + kargerStein: function kargerStein() { + var _this = this; + var _this$byGroup = this.byGroup(), nodes2 = _this$byGroup.nodes, edges = _this$byGroup.edges; + edges.unmergeBy(function(edge) { + return edge.isLoop(); + }); + var numNodes = nodes2.length; + var numEdges = edges.length; + var numIter = Math.ceil(Math.pow(Math.log(numNodes) / Math.LN2, 2)); + var stopSize = Math.floor(numNodes / sqrt2); + if (numNodes < 2) { + error("At least 2 nodes are required for Karger-Stein algorithm"); + return void 0; + } + var edgeIndexes = []; + for (var i2 = 0; i2 < numEdges; i2++) { + var e = edges[i2]; + edgeIndexes.push([i2, nodes2.indexOf(e.source()), nodes2.indexOf(e.target())]); + } + var minCutSize = Infinity; + var minCutEdgeIndexes = []; + var minCutNodeMap = new Array(numNodes); + var metaNodeMap = new Array(numNodes); + var metaNodeMap2 = new Array(numNodes); + var copyNodesMap = function copyNodesMap2(from, to) { + for (var _i3 = 0; _i3 < numNodes; _i3++) { + to[_i3] = from[_i3]; + } + }; + for (var iter = 0; iter <= numIter; iter++) { + for (var _i4 = 0; _i4 < numNodes; _i4++) { + metaNodeMap[_i4] = _i4; + } + var edgesState = contractUntil(metaNodeMap, edgeIndexes.slice(), numNodes, stopSize); + var edgesState2 = edgesState.slice(); + copyNodesMap(metaNodeMap, metaNodeMap2); + var res1 = contractUntil(metaNodeMap, edgesState, stopSize, 2); + var res2 = contractUntil(metaNodeMap2, edgesState2, stopSize, 2); + if (res1.length <= res2.length && res1.length < minCutSize) { + minCutSize = res1.length; + minCutEdgeIndexes = res1; + copyNodesMap(metaNodeMap, minCutNodeMap); + } else if (res2.length <= res1.length && res2.length < minCutSize) { + minCutSize = res2.length; + minCutEdgeIndexes = res2; + copyNodesMap(metaNodeMap2, minCutNodeMap); + } + } + var cut = this.spawn(minCutEdgeIndexes.map(function(e2) { + return edges[e2[0]]; + })); + var partition1 = this.spawn(); + var partition2 = this.spawn(); + var witnessNodePartition = minCutNodeMap[0]; + for (var _i5 = 0; _i5 < minCutNodeMap.length; _i5++) { + var partitionId = minCutNodeMap[_i5]; + var node = nodes2[_i5]; + if (partitionId === witnessNodePartition) { + partition1.merge(node); + } else { + partition2.merge(node); + } + } + var constructComponent = function constructComponent2(subset) { + var component = _this.spawn(); + subset.forEach(function(node2) { + component.merge(node2); + node2.connectedEdges().forEach(function(edge) { + if (_this.contains(edge) && !cut.contains(edge)) { + component.merge(edge); + } + }); + }); + return component; + }; + var components = [constructComponent(partition1), constructComponent(partition2)]; + var ret = { + cut, + components, + // n.b. partitions are included to be compatible with the old api spec + // (could be removed in a future major version) + partition1, + partition2 + }; + return ret; + } + }; + var copyPosition = function copyPosition2(p2) { + return { + x: p2.x, + y: p2.y + }; + }; + var modelToRenderedPosition = function modelToRenderedPosition2(p2, zoom, pan) { + return { + x: p2.x * zoom + pan.x, + y: p2.y * zoom + pan.y + }; + }; + var renderedToModelPosition = function renderedToModelPosition2(p2, zoom, pan) { + return { + x: (p2.x - pan.x) / zoom, + y: (p2.y - pan.y) / zoom + }; + }; + var array2point = function array2point2(arr) { + return { + x: arr[0], + y: arr[1] + }; + }; + var min = function min2(arr) { + var begin = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : 0; + var end = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : arr.length; + var min3 = Infinity; + for (var i2 = begin; i2 < end; i2++) { + var val = arr[i2]; + if (isFinite(val)) { + min3 = Math.min(val, min3); + } + } + return min3; + }; + var max = function max2(arr) { + var begin = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : 0; + var end = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : arr.length; + var max3 = -Infinity; + for (var i2 = begin; i2 < end; i2++) { + var val = arr[i2]; + if (isFinite(val)) { + max3 = Math.max(val, max3); + } + } + return max3; + }; + var mean = function mean2(arr) { + var begin = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : 0; + var end = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : arr.length; + var total = 0; + var n = 0; + for (var i2 = begin; i2 < end; i2++) { + var val = arr[i2]; + if (isFinite(val)) { + total += val; + n++; + } + } + return total / n; + }; + var median = function median2(arr) { + var begin = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : 0; + var end = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : arr.length; + var copy2 = arguments.length > 3 && arguments[3] !== void 0 ? arguments[3] : true; + var sort = arguments.length > 4 && arguments[4] !== void 0 ? arguments[4] : true; + var includeHoles = arguments.length > 5 && arguments[5] !== void 0 ? arguments[5] : true; + if (copy2) { + arr = arr.slice(begin, end); + } else { + if (end < arr.length) { + arr.splice(end, arr.length - end); + } + if (begin > 0) { + arr.splice(0, begin); + } + } + var off = 0; + for (var i2 = arr.length - 1; i2 >= 0; i2--) { + var v = arr[i2]; + if (includeHoles) { + if (!isFinite(v)) { + arr[i2] = -Infinity; + off++; + } + } else { + arr.splice(i2, 1); + } + } + if (sort) { + arr.sort(function(a, b) { + return a - b; + }); + } + var len = arr.length; + var mid = Math.floor(len / 2); + if (len % 2 !== 0) { + return arr[mid + 1 + off]; + } else { + return (arr[mid - 1 + off] + arr[mid + off]) / 2; + } + }; + var deg2rad = function deg2rad2(deg) { + return Math.PI * deg / 180; + }; + var getAngleFromDisp = function getAngleFromDisp2(dispX, dispY) { + return Math.atan2(dispY, dispX) - Math.PI / 2; + }; + var log2 = Math.log2 || function(n) { + return Math.log(n) / Math.log(2); + }; + var signum = function signum2(x) { + if (x > 0) { + return 1; + } else if (x < 0) { + return -1; + } else { + return 0; + } + }; + var dist = function dist2(p1, p2) { + return Math.sqrt(sqdist(p1, p2)); + }; + var sqdist = function sqdist2(p1, p2) { + var dx = p2.x - p1.x; + var dy = p2.y - p1.y; + return dx * dx + dy * dy; + }; + var inPlaceSumNormalize = function inPlaceSumNormalize2(v) { + var length = v.length; + var total = 0; + for (var i2 = 0; i2 < length; i2++) { + total += v[i2]; + } + for (var _i = 0; _i < length; _i++) { + v[_i] = v[_i] / total; + } + return v; + }; + var qbezierAt = function qbezierAt2(p0, p1, p2, t) { + return (1 - t) * (1 - t) * p0 + 2 * (1 - t) * t * p1 + t * t * p2; + }; + var qbezierPtAt = function qbezierPtAt2(p0, p1, p2, t) { + return { + x: qbezierAt(p0.x, p1.x, p2.x, t), + y: qbezierAt(p0.y, p1.y, p2.y, t) + }; + }; + var lineAt = function lineAt2(p0, p1, t, d) { + var vec = { + x: p1.x - p0.x, + y: p1.y - p0.y + }; + var vecDist = dist(p0, p1); + var normVec = { + x: vec.x / vecDist, + y: vec.y / vecDist + }; + t = t == null ? 0 : t; + d = d != null ? d : t * vecDist; + return { + x: p0.x + normVec.x * d, + y: p0.y + normVec.y * d + }; + }; + var bound = function bound2(min2, val, max2) { + return Math.max(min2, Math.min(max2, val)); + }; + var makeBoundingBox = function makeBoundingBox2(bb) { + if (bb == null) { + return { + x1: Infinity, + y1: Infinity, + x2: -Infinity, + y2: -Infinity, + w: 0, + h: 0 + }; + } else if (bb.x1 != null && bb.y1 != null) { + if (bb.x2 != null && bb.y2 != null && bb.x2 >= bb.x1 && bb.y2 >= bb.y1) { + return { + x1: bb.x1, + y1: bb.y1, + x2: bb.x2, + y2: bb.y2, + w: bb.x2 - bb.x1, + h: bb.y2 - bb.y1 + }; + } else if (bb.w != null && bb.h != null && bb.w >= 0 && bb.h >= 0) { + return { + x1: bb.x1, + y1: bb.y1, + x2: bb.x1 + bb.w, + y2: bb.y1 + bb.h, + w: bb.w, + h: bb.h + }; + } + } + }; + var copyBoundingBox = function copyBoundingBox2(bb) { + return { + x1: bb.x1, + x2: bb.x2, + w: bb.w, + y1: bb.y1, + y2: bb.y2, + h: bb.h + }; + }; + var clearBoundingBox = function clearBoundingBox2(bb) { + bb.x1 = Infinity; + bb.y1 = Infinity; + bb.x2 = -Infinity; + bb.y2 = -Infinity; + bb.w = 0; + bb.h = 0; + }; + var shiftBoundingBox = function shiftBoundingBox2(bb, dx, dy) { + return { + x1: bb.x1 + dx, + x2: bb.x2 + dx, + y1: bb.y1 + dy, + y2: bb.y2 + dy, + w: bb.w, + h: bb.h + }; + }; + var updateBoundingBox = function updateBoundingBox2(bb1, bb2) { + bb1.x1 = Math.min(bb1.x1, bb2.x1); + bb1.x2 = Math.max(bb1.x2, bb2.x2); + bb1.w = bb1.x2 - bb1.x1; + bb1.y1 = Math.min(bb1.y1, bb2.y1); + bb1.y2 = Math.max(bb1.y2, bb2.y2); + bb1.h = bb1.y2 - bb1.y1; + }; + var expandBoundingBoxByPoint = function expandBoundingBoxByPoint2(bb, x, y) { + bb.x1 = Math.min(bb.x1, x); + bb.x2 = Math.max(bb.x2, x); + bb.w = bb.x2 - bb.x1; + bb.y1 = Math.min(bb.y1, y); + bb.y2 = Math.max(bb.y2, y); + bb.h = bb.y2 - bb.y1; + }; + var expandBoundingBox = function expandBoundingBox2(bb) { + var padding = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : 0; + bb.x1 -= padding; + bb.x2 += padding; + bb.y1 -= padding; + bb.y2 += padding; + bb.w = bb.x2 - bb.x1; + bb.h = bb.y2 - bb.y1; + return bb; + }; + var expandBoundingBoxSides = function expandBoundingBoxSides2(bb) { + var padding = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : [0]; + var top, right, bottom, left; + if (padding.length === 1) { + top = right = bottom = left = padding[0]; + } else if (padding.length === 2) { + top = bottom = padding[0]; + left = right = padding[1]; + } else if (padding.length === 4) { + var _padding = _slicedToArray(padding, 4); + top = _padding[0]; + right = _padding[1]; + bottom = _padding[2]; + left = _padding[3]; + } + bb.x1 -= left; + bb.x2 += right; + bb.y1 -= top; + bb.y2 += bottom; + bb.w = bb.x2 - bb.x1; + bb.h = bb.y2 - bb.y1; + return bb; + }; + var assignBoundingBox = function assignBoundingBox2(bb1, bb2) { + bb1.x1 = bb2.x1; + bb1.y1 = bb2.y1; + bb1.x2 = bb2.x2; + bb1.y2 = bb2.y2; + bb1.w = bb1.x2 - bb1.x1; + bb1.h = bb1.y2 - bb1.y1; + }; + var boundingBoxesIntersect = function boundingBoxesIntersect2(bb1, bb2) { + if (bb1.x1 > bb2.x2) { + return false; + } + if (bb2.x1 > bb1.x2) { + return false; + } + if (bb1.x2 < bb2.x1) { + return false; + } + if (bb2.x2 < bb1.x1) { + return false; + } + if (bb1.y2 < bb2.y1) { + return false; + } + if (bb2.y2 < bb1.y1) { + return false; + } + if (bb1.y1 > bb2.y2) { + return false; + } + if (bb2.y1 > bb1.y2) { + return false; + } + return true; + }; + var inBoundingBox = function inBoundingBox2(bb, x, y) { + return bb.x1 <= x && x <= bb.x2 && bb.y1 <= y && y <= bb.y2; + }; + var pointInBoundingBox = function pointInBoundingBox2(bb, pt) { + return inBoundingBox(bb, pt.x, pt.y); + }; + var boundingBoxInBoundingBox = function boundingBoxInBoundingBox2(bb1, bb2) { + return inBoundingBox(bb1, bb2.x1, bb2.y1) && inBoundingBox(bb1, bb2.x2, bb2.y2); + }; + var roundRectangleIntersectLine = function roundRectangleIntersectLine2(x, y, nodeX, nodeY, width, height, padding) { + var cornerRadius = getRoundRectangleRadius(width, height); + var halfWidth = width / 2; + var halfHeight = height / 2; + var straightLineIntersections; + { + var topStartX = nodeX - halfWidth + cornerRadius - padding; + var topStartY = nodeY - halfHeight - padding; + var topEndX = nodeX + halfWidth - cornerRadius + padding; + var topEndY = topStartY; + straightLineIntersections = finiteLinesIntersect(x, y, nodeX, nodeY, topStartX, topStartY, topEndX, topEndY, false); + if (straightLineIntersections.length > 0) { + return straightLineIntersections; + } + } + { + var rightStartX = nodeX + halfWidth + padding; + var rightStartY = nodeY - halfHeight + cornerRadius - padding; + var rightEndX = rightStartX; + var rightEndY = nodeY + halfHeight - cornerRadius + padding; + straightLineIntersections = finiteLinesIntersect(x, y, nodeX, nodeY, rightStartX, rightStartY, rightEndX, rightEndY, false); + if (straightLineIntersections.length > 0) { + return straightLineIntersections; + } + } + { + var bottomStartX = nodeX - halfWidth + cornerRadius - padding; + var bottomStartY = nodeY + halfHeight + padding; + var bottomEndX = nodeX + halfWidth - cornerRadius + padding; + var bottomEndY = bottomStartY; + straightLineIntersections = finiteLinesIntersect(x, y, nodeX, nodeY, bottomStartX, bottomStartY, bottomEndX, bottomEndY, false); + if (straightLineIntersections.length > 0) { + return straightLineIntersections; + } + } + { + var leftStartX = nodeX - halfWidth - padding; + var leftStartY = nodeY - halfHeight + cornerRadius - padding; + var leftEndX = leftStartX; + var leftEndY = nodeY + halfHeight - cornerRadius + padding; + straightLineIntersections = finiteLinesIntersect(x, y, nodeX, nodeY, leftStartX, leftStartY, leftEndX, leftEndY, false); + if (straightLineIntersections.length > 0) { + return straightLineIntersections; + } + } + var arcIntersections; + { + var topLeftCenterX = nodeX - halfWidth + cornerRadius; + var topLeftCenterY = nodeY - halfHeight + cornerRadius; + arcIntersections = intersectLineCircle(x, y, nodeX, nodeY, topLeftCenterX, topLeftCenterY, cornerRadius + padding); + if (arcIntersections.length > 0 && arcIntersections[0] <= topLeftCenterX && arcIntersections[1] <= topLeftCenterY) { + return [arcIntersections[0], arcIntersections[1]]; + } + } + { + var topRightCenterX = nodeX + halfWidth - cornerRadius; + var topRightCenterY = nodeY - halfHeight + cornerRadius; + arcIntersections = intersectLineCircle(x, y, nodeX, nodeY, topRightCenterX, topRightCenterY, cornerRadius + padding); + if (arcIntersections.length > 0 && arcIntersections[0] >= topRightCenterX && arcIntersections[1] <= topRightCenterY) { + return [arcIntersections[0], arcIntersections[1]]; + } + } + { + var bottomRightCenterX = nodeX + halfWidth - cornerRadius; + var bottomRightCenterY = nodeY + halfHeight - cornerRadius; + arcIntersections = intersectLineCircle(x, y, nodeX, nodeY, bottomRightCenterX, bottomRightCenterY, cornerRadius + padding); + if (arcIntersections.length > 0 && arcIntersections[0] >= bottomRightCenterX && arcIntersections[1] >= bottomRightCenterY) { + return [arcIntersections[0], arcIntersections[1]]; + } + } + { + var bottomLeftCenterX = nodeX - halfWidth + cornerRadius; + var bottomLeftCenterY = nodeY + halfHeight - cornerRadius; + arcIntersections = intersectLineCircle(x, y, nodeX, nodeY, bottomLeftCenterX, bottomLeftCenterY, cornerRadius + padding); + if (arcIntersections.length > 0 && arcIntersections[0] <= bottomLeftCenterX && arcIntersections[1] >= bottomLeftCenterY) { + return [arcIntersections[0], arcIntersections[1]]; + } + } + return []; + }; + var inLineVicinity = function inLineVicinity2(x, y, lx1, ly1, lx2, ly2, tolerance) { + var t = tolerance; + var x1 = Math.min(lx1, lx2); + var x2 = Math.max(lx1, lx2); + var y1 = Math.min(ly1, ly2); + var y2 = Math.max(ly1, ly2); + return x1 - t <= x && x <= x2 + t && y1 - t <= y && y <= y2 + t; + }; + var inBezierVicinity = function inBezierVicinity2(x, y, x1, y1, x2, y2, x3, y3, tolerance) { + var bb = { + x1: Math.min(x1, x3, x2) - tolerance, + x2: Math.max(x1, x3, x2) + tolerance, + y1: Math.min(y1, y3, y2) - tolerance, + y2: Math.max(y1, y3, y2) + tolerance + }; + if (x < bb.x1 || x > bb.x2 || y < bb.y1 || y > bb.y2) { + return false; + } else { + return true; + } + }; + var solveQuadratic = function solveQuadratic2(a, b, c, val) { + c -= val; + var r = b * b - 4 * a * c; + if (r < 0) { + return []; + } + var sqrtR = Math.sqrt(r); + var denom = 2 * a; + var root1 = (-b + sqrtR) / denom; + var root2 = (-b - sqrtR) / denom; + return [root1, root2]; + }; + var solveCubic = function solveCubic2(a, b, c, d, result) { + var epsilon = 1e-5; + if (a === 0) { + a = epsilon; + } + b /= a; + c /= a; + d /= a; + var discriminant, q, r, dum1, s, t, term1, r13; + q = (3 * c - b * b) / 9; + r = -(27 * d) + b * (9 * c - 2 * (b * b)); + r /= 54; + discriminant = q * q * q + r * r; + result[1] = 0; + term1 = b / 3; + if (discriminant > 0) { + s = r + Math.sqrt(discriminant); + s = s < 0 ? -Math.pow(-s, 1 / 3) : Math.pow(s, 1 / 3); + t = r - Math.sqrt(discriminant); + t = t < 0 ? -Math.pow(-t, 1 / 3) : Math.pow(t, 1 / 3); + result[0] = -term1 + s + t; + term1 += (s + t) / 2; + result[4] = result[2] = -term1; + term1 = Math.sqrt(3) * (-t + s) / 2; + result[3] = term1; + result[5] = -term1; + return; + } + result[5] = result[3] = 0; + if (discriminant === 0) { + r13 = r < 0 ? -Math.pow(-r, 1 / 3) : Math.pow(r, 1 / 3); + result[0] = -term1 + 2 * r13; + result[4] = result[2] = -(r13 + term1); + return; + } + q = -q; + dum1 = q * q * q; + dum1 = Math.acos(r / Math.sqrt(dum1)); + r13 = 2 * Math.sqrt(q); + result[0] = -term1 + r13 * Math.cos(dum1 / 3); + result[2] = -term1 + r13 * Math.cos((dum1 + 2 * Math.PI) / 3); + result[4] = -term1 + r13 * Math.cos((dum1 + 4 * Math.PI) / 3); + return; + }; + var sqdistToQuadraticBezier = function sqdistToQuadraticBezier2(x, y, x1, y1, x2, y2, x3, y3) { + var a = 1 * x1 * x1 - 4 * x1 * x2 + 2 * x1 * x3 + 4 * x2 * x2 - 4 * x2 * x3 + x3 * x3 + y1 * y1 - 4 * y1 * y2 + 2 * y1 * y3 + 4 * y2 * y2 - 4 * y2 * y3 + y3 * y3; + var b = 1 * 9 * x1 * x2 - 3 * x1 * x1 - 3 * x1 * x3 - 6 * x2 * x2 + 3 * x2 * x3 + 9 * y1 * y2 - 3 * y1 * y1 - 3 * y1 * y3 - 6 * y2 * y2 + 3 * y2 * y3; + var c = 1 * 3 * x1 * x1 - 6 * x1 * x2 + x1 * x3 - x1 * x + 2 * x2 * x2 + 2 * x2 * x - x3 * x + 3 * y1 * y1 - 6 * y1 * y2 + y1 * y3 - y1 * y + 2 * y2 * y2 + 2 * y2 * y - y3 * y; + var d = 1 * x1 * x2 - x1 * x1 + x1 * x - x2 * x + y1 * y2 - y1 * y1 + y1 * y - y2 * y; + var roots = []; + solveCubic(a, b, c, d, roots); + var zeroThreshold = 1e-7; + var params = []; + for (var index = 0; index < 6; index += 2) { + if (Math.abs(roots[index + 1]) < zeroThreshold && roots[index] >= 0 && roots[index] <= 1) { + params.push(roots[index]); + } + } + params.push(1); + params.push(0); + var minDistanceSquared = -1; + var curX, curY, distSquared; + for (var i2 = 0; i2 < params.length; i2++) { + curX = Math.pow(1 - params[i2], 2) * x1 + 2 * (1 - params[i2]) * params[i2] * x2 + params[i2] * params[i2] * x3; + curY = Math.pow(1 - params[i2], 2) * y1 + 2 * (1 - params[i2]) * params[i2] * y2 + params[i2] * params[i2] * y3; + distSquared = Math.pow(curX - x, 2) + Math.pow(curY - y, 2); + if (minDistanceSquared >= 0) { + if (distSquared < minDistanceSquared) { + minDistanceSquared = distSquared; + } + } else { + minDistanceSquared = distSquared; + } + } + return minDistanceSquared; + }; + var sqdistToFiniteLine = function sqdistToFiniteLine2(x, y, x1, y1, x2, y2) { + var offset = [x - x1, y - y1]; + var line = [x2 - x1, y2 - y1]; + var lineSq = line[0] * line[0] + line[1] * line[1]; + var hypSq = offset[0] * offset[0] + offset[1] * offset[1]; + var dotProduct = offset[0] * line[0] + offset[1] * line[1]; + var adjSq = dotProduct * dotProduct / lineSq; + if (dotProduct < 0) { + return hypSq; + } + if (adjSq > lineSq) { + return (x - x2) * (x - x2) + (y - y2) * (y - y2); + } + return hypSq - adjSq; + }; + var pointInsidePolygonPoints = function pointInsidePolygonPoints2(x, y, points) { + var x1, y1, x2, y2; + var y3; + var up = 0; + for (var i2 = 0; i2 < points.length / 2; i2++) { + x1 = points[i2 * 2]; + y1 = points[i2 * 2 + 1]; + if (i2 + 1 < points.length / 2) { + x2 = points[(i2 + 1) * 2]; + y2 = points[(i2 + 1) * 2 + 1]; + } else { + x2 = points[(i2 + 1 - points.length / 2) * 2]; + y2 = points[(i2 + 1 - points.length / 2) * 2 + 1]; + } + if (x1 == x && x2 == x) + ; + else if (x1 >= x && x >= x2 || x1 <= x && x <= x2) { + y3 = (x - x1) / (x2 - x1) * (y2 - y1) + y1; + if (y3 > y) { + up++; + } + } else { + continue; + } + } + if (up % 2 === 0) { + return false; + } else { + return true; + } + }; + var pointInsidePolygon = function pointInsidePolygon2(x, y, basePoints, centerX, centerY, width, height, direction, padding) { + var transformedPoints = new Array(basePoints.length); + var angle; + if (direction[0] != null) { + angle = Math.atan(direction[1] / direction[0]); + if (direction[0] < 0) { + angle = angle + Math.PI / 2; + } else { + angle = -angle - Math.PI / 2; + } + } else { + angle = direction; + } + var cos2 = Math.cos(-angle); + var sin2 = Math.sin(-angle); + for (var i2 = 0; i2 < transformedPoints.length / 2; i2++) { + transformedPoints[i2 * 2] = width / 2 * (basePoints[i2 * 2] * cos2 - basePoints[i2 * 2 + 1] * sin2); + transformedPoints[i2 * 2 + 1] = height / 2 * (basePoints[i2 * 2 + 1] * cos2 + basePoints[i2 * 2] * sin2); + transformedPoints[i2 * 2] += centerX; + transformedPoints[i2 * 2 + 1] += centerY; + } + var points; + if (padding > 0) { + var expandedLineSet = expandPolygon(transformedPoints, -padding); + points = joinLines(expandedLineSet); + } else { + points = transformedPoints; + } + return pointInsidePolygonPoints(x, y, points); + }; + var pointInsideRoundPolygon = function pointInsideRoundPolygon2(x, y, basePoints, centerX, centerY, width, height) { + var cutPolygonPoints = new Array(basePoints.length); + var halfW = width / 2; + var halfH = height / 2; + var cornerRadius = getRoundPolygonRadius(width, height); + var squaredCornerRadius = cornerRadius * cornerRadius; + for (var i2 = 0; i2 < basePoints.length / 4; i2++) { + var sourceUv = void 0, destUv = void 0; + if (i2 === 0) { + sourceUv = basePoints.length - 2; + } else { + sourceUv = i2 * 4 - 2; + } + destUv = i2 * 4 + 2; + var px = centerX + halfW * basePoints[i2 * 4]; + var py = centerY + halfH * basePoints[i2 * 4 + 1]; + var cosTheta = -basePoints[sourceUv] * basePoints[destUv] - basePoints[sourceUv + 1] * basePoints[destUv + 1]; + var offset = cornerRadius / Math.tan(Math.acos(cosTheta) / 2); + var cp0x = px - offset * basePoints[sourceUv]; + var cp0y = py - offset * basePoints[sourceUv + 1]; + var cp1x = px + offset * basePoints[destUv]; + var cp1y = py + offset * basePoints[destUv + 1]; + cutPolygonPoints[i2 * 4] = cp0x; + cutPolygonPoints[i2 * 4 + 1] = cp0y; + cutPolygonPoints[i2 * 4 + 2] = cp1x; + cutPolygonPoints[i2 * 4 + 3] = cp1y; + var orthx = basePoints[sourceUv + 1]; + var orthy = -basePoints[sourceUv]; + var cosAlpha = orthx * basePoints[destUv] + orthy * basePoints[destUv + 1]; + if (cosAlpha < 0) { + orthx *= -1; + orthy *= -1; + } + var cx = cp0x + orthx * cornerRadius; + var cy = cp0y + orthy * cornerRadius; + var squaredDistance = Math.pow(cx - x, 2) + Math.pow(cy - y, 2); + if (squaredDistance <= squaredCornerRadius) { + return true; + } + } + return pointInsidePolygonPoints(x, y, cutPolygonPoints); + }; + var joinLines = function joinLines2(lineSet) { + var vertices = new Array(lineSet.length / 2); + var currentLineStartX, currentLineStartY, currentLineEndX, currentLineEndY; + var nextLineStartX, nextLineStartY, nextLineEndX, nextLineEndY; + for (var i2 = 0; i2 < lineSet.length / 4; i2++) { + currentLineStartX = lineSet[i2 * 4]; + currentLineStartY = lineSet[i2 * 4 + 1]; + currentLineEndX = lineSet[i2 * 4 + 2]; + currentLineEndY = lineSet[i2 * 4 + 3]; + if (i2 < lineSet.length / 4 - 1) { + nextLineStartX = lineSet[(i2 + 1) * 4]; + nextLineStartY = lineSet[(i2 + 1) * 4 + 1]; + nextLineEndX = lineSet[(i2 + 1) * 4 + 2]; + nextLineEndY = lineSet[(i2 + 1) * 4 + 3]; + } else { + nextLineStartX = lineSet[0]; + nextLineStartY = lineSet[1]; + nextLineEndX = lineSet[2]; + nextLineEndY = lineSet[3]; + } + var intersection = finiteLinesIntersect(currentLineStartX, currentLineStartY, currentLineEndX, currentLineEndY, nextLineStartX, nextLineStartY, nextLineEndX, nextLineEndY, true); + vertices[i2 * 2] = intersection[0]; + vertices[i2 * 2 + 1] = intersection[1]; + } + return vertices; + }; + var expandPolygon = function expandPolygon2(points, pad) { + var expandedLineSet = new Array(points.length * 2); + var currentPointX, currentPointY, nextPointX, nextPointY; + for (var i2 = 0; i2 < points.length / 2; i2++) { + currentPointX = points[i2 * 2]; + currentPointY = points[i2 * 2 + 1]; + if (i2 < points.length / 2 - 1) { + nextPointX = points[(i2 + 1) * 2]; + nextPointY = points[(i2 + 1) * 2 + 1]; + } else { + nextPointX = points[0]; + nextPointY = points[1]; + } + var offsetX = nextPointY - currentPointY; + var offsetY = -(nextPointX - currentPointX); + var offsetLength = Math.sqrt(offsetX * offsetX + offsetY * offsetY); + var normalizedOffsetX = offsetX / offsetLength; + var normalizedOffsetY = offsetY / offsetLength; + expandedLineSet[i2 * 4] = currentPointX + normalizedOffsetX * pad; + expandedLineSet[i2 * 4 + 1] = currentPointY + normalizedOffsetY * pad; + expandedLineSet[i2 * 4 + 2] = nextPointX + normalizedOffsetX * pad; + expandedLineSet[i2 * 4 + 3] = nextPointY + normalizedOffsetY * pad; + } + return expandedLineSet; + }; + var intersectLineEllipse = function intersectLineEllipse2(x, y, centerX, centerY, ellipseWradius, ellipseHradius) { + var dispX = centerX - x; + var dispY = centerY - y; + dispX /= ellipseWradius; + dispY /= ellipseHradius; + var len = Math.sqrt(dispX * dispX + dispY * dispY); + var newLength = len - 1; + if (newLength < 0) { + return []; + } + var lenProportion = newLength / len; + return [(centerX - x) * lenProportion + x, (centerY - y) * lenProportion + y]; + }; + var checkInEllipse = function checkInEllipse2(x, y, width, height, centerX, centerY, padding) { + x -= centerX; + y -= centerY; + x /= width / 2 + padding; + y /= height / 2 + padding; + return x * x + y * y <= 1; + }; + var intersectLineCircle = function intersectLineCircle2(x1, y1, x2, y2, centerX, centerY, radius) { + var d = [x2 - x1, y2 - y1]; + var f = [x1 - centerX, y1 - centerY]; + var a = d[0] * d[0] + d[1] * d[1]; + var b = 2 * (f[0] * d[0] + f[1] * d[1]); + var c = f[0] * f[0] + f[1] * f[1] - radius * radius; + var discriminant = b * b - 4 * a * c; + if (discriminant < 0) { + return []; + } + var t1 = (-b + Math.sqrt(discriminant)) / (2 * a); + var t2 = (-b - Math.sqrt(discriminant)) / (2 * a); + var tMin = Math.min(t1, t2); + var tMax = Math.max(t1, t2); + var inRangeParams = []; + if (tMin >= 0 && tMin <= 1) { + inRangeParams.push(tMin); + } + if (tMax >= 0 && tMax <= 1) { + inRangeParams.push(tMax); + } + if (inRangeParams.length === 0) { + return []; + } + var nearIntersectionX = inRangeParams[0] * d[0] + x1; + var nearIntersectionY = inRangeParams[0] * d[1] + y1; + if (inRangeParams.length > 1) { + if (inRangeParams[0] == inRangeParams[1]) { + return [nearIntersectionX, nearIntersectionY]; + } else { + var farIntersectionX = inRangeParams[1] * d[0] + x1; + var farIntersectionY = inRangeParams[1] * d[1] + y1; + return [nearIntersectionX, nearIntersectionY, farIntersectionX, farIntersectionY]; + } + } else { + return [nearIntersectionX, nearIntersectionY]; + } + }; + var midOfThree = function midOfThree2(a, b, c) { + if (b <= a && a <= c || c <= a && a <= b) { + return a; + } else if (a <= b && b <= c || c <= b && b <= a) { + return b; + } else { + return c; + } + }; + var finiteLinesIntersect = function finiteLinesIntersect2(x1, y1, x2, y2, x3, y3, x4, y4, infiniteLines) { + var dx13 = x1 - x3; + var dx21 = x2 - x1; + var dx43 = x4 - x3; + var dy13 = y1 - y3; + var dy21 = y2 - y1; + var dy43 = y4 - y3; + var ua_t = dx43 * dy13 - dy43 * dx13; + var ub_t = dx21 * dy13 - dy21 * dx13; + var u_b = dy43 * dx21 - dx43 * dy21; + if (u_b !== 0) { + var ua = ua_t / u_b; + var ub = ub_t / u_b; + var flptThreshold = 1e-3; + var _min = 0 - flptThreshold; + var _max = 1 + flptThreshold; + if (_min <= ua && ua <= _max && _min <= ub && ub <= _max) { + return [x1 + ua * dx21, y1 + ua * dy21]; + } else { + if (!infiniteLines) { + return []; + } else { + return [x1 + ua * dx21, y1 + ua * dy21]; + } + } + } else { + if (ua_t === 0 || ub_t === 0) { + if (midOfThree(x1, x2, x4) === x4) { + return [x4, y4]; + } + if (midOfThree(x1, x2, x3) === x3) { + return [x3, y3]; + } + if (midOfThree(x3, x4, x2) === x2) { + return [x2, y2]; + } + return []; + } else { + return []; + } + } + }; + var polygonIntersectLine = function polygonIntersectLine2(x, y, basePoints, centerX, centerY, width, height, padding) { + var intersections = []; + var intersection; + var transformedPoints = new Array(basePoints.length); + var doTransform = true; + if (width == null) { + doTransform = false; + } + var points; + if (doTransform) { + for (var i2 = 0; i2 < transformedPoints.length / 2; i2++) { + transformedPoints[i2 * 2] = basePoints[i2 * 2] * width + centerX; + transformedPoints[i2 * 2 + 1] = basePoints[i2 * 2 + 1] * height + centerY; + } + if (padding > 0) { + var expandedLineSet = expandPolygon(transformedPoints, -padding); + points = joinLines(expandedLineSet); + } else { + points = transformedPoints; + } + } else { + points = basePoints; + } + var currentX, currentY, nextX, nextY; + for (var _i2 = 0; _i2 < points.length / 2; _i2++) { + currentX = points[_i2 * 2]; + currentY = points[_i2 * 2 + 1]; + if (_i2 < points.length / 2 - 1) { + nextX = points[(_i2 + 1) * 2]; + nextY = points[(_i2 + 1) * 2 + 1]; + } else { + nextX = points[0]; + nextY = points[1]; + } + intersection = finiteLinesIntersect(x, y, centerX, centerY, currentX, currentY, nextX, nextY); + if (intersection.length !== 0) { + intersections.push(intersection[0], intersection[1]); + } + } + return intersections; + }; + var roundPolygonIntersectLine = function roundPolygonIntersectLine2(x, y, basePoints, centerX, centerY, width, height, padding) { + var intersections = []; + var intersection; + var lines = new Array(basePoints.length); + var halfW = width / 2; + var halfH = height / 2; + var cornerRadius = getRoundPolygonRadius(width, height); + for (var i2 = 0; i2 < basePoints.length / 4; i2++) { + var sourceUv = void 0, destUv = void 0; + if (i2 === 0) { + sourceUv = basePoints.length - 2; + } else { + sourceUv = i2 * 4 - 2; + } + destUv = i2 * 4 + 2; + var px = centerX + halfW * basePoints[i2 * 4]; + var py = centerY + halfH * basePoints[i2 * 4 + 1]; + var cosTheta = -basePoints[sourceUv] * basePoints[destUv] - basePoints[sourceUv + 1] * basePoints[destUv + 1]; + var offset = cornerRadius / Math.tan(Math.acos(cosTheta) / 2); + var cp0x = px - offset * basePoints[sourceUv]; + var cp0y = py - offset * basePoints[sourceUv + 1]; + var cp1x = px + offset * basePoints[destUv]; + var cp1y = py + offset * basePoints[destUv + 1]; + if (i2 === 0) { + lines[basePoints.length - 2] = cp0x; + lines[basePoints.length - 1] = cp0y; + } else { + lines[i2 * 4 - 2] = cp0x; + lines[i2 * 4 - 1] = cp0y; + } + lines[i2 * 4] = cp1x; + lines[i2 * 4 + 1] = cp1y; + var orthx = basePoints[sourceUv + 1]; + var orthy = -basePoints[sourceUv]; + var cosAlpha = orthx * basePoints[destUv] + orthy * basePoints[destUv + 1]; + if (cosAlpha < 0) { + orthx *= -1; + orthy *= -1; + } + var cx = cp0x + orthx * cornerRadius; + var cy = cp0y + orthy * cornerRadius; + intersection = intersectLineCircle(x, y, centerX, centerY, cx, cy, cornerRadius); + if (intersection.length !== 0) { + intersections.push(intersection[0], intersection[1]); + } + } + for (var _i3 = 0; _i3 < lines.length / 4; _i3++) { + intersection = finiteLinesIntersect(x, y, centerX, centerY, lines[_i3 * 4], lines[_i3 * 4 + 1], lines[_i3 * 4 + 2], lines[_i3 * 4 + 3], false); + if (intersection.length !== 0) { + intersections.push(intersection[0], intersection[1]); + } + } + if (intersections.length > 2) { + var lowestIntersection = [intersections[0], intersections[1]]; + var lowestSquaredDistance = Math.pow(lowestIntersection[0] - x, 2) + Math.pow(lowestIntersection[1] - y, 2); + for (var _i4 = 1; _i4 < intersections.length / 2; _i4++) { + var squaredDistance = Math.pow(intersections[_i4 * 2] - x, 2) + Math.pow(intersections[_i4 * 2 + 1] - y, 2); + if (squaredDistance <= lowestSquaredDistance) { + lowestIntersection[0] = intersections[_i4 * 2]; + lowestIntersection[1] = intersections[_i4 * 2 + 1]; + lowestSquaredDistance = squaredDistance; + } + } + return lowestIntersection; + } + return intersections; + }; + var shortenIntersection = function shortenIntersection2(intersection, offset, amount) { + var disp = [intersection[0] - offset[0], intersection[1] - offset[1]]; + var length = Math.sqrt(disp[0] * disp[0] + disp[1] * disp[1]); + var lenRatio = (length - amount) / length; + if (lenRatio < 0) { + lenRatio = 1e-5; + } + return [offset[0] + lenRatio * disp[0], offset[1] + lenRatio * disp[1]]; + }; + var generateUnitNgonPointsFitToSquare = function generateUnitNgonPointsFitToSquare2(sides, rotationRadians) { + var points = generateUnitNgonPoints(sides, rotationRadians); + points = fitPolygonToSquare(points); + return points; + }; + var fitPolygonToSquare = function fitPolygonToSquare2(points) { + var x, y; + var sides = points.length / 2; + var minX = Infinity, minY = Infinity, maxX = -Infinity, maxY = -Infinity; + for (var i2 = 0; i2 < sides; i2++) { + x = points[2 * i2]; + y = points[2 * i2 + 1]; + minX = Math.min(minX, x); + maxX = Math.max(maxX, x); + minY = Math.min(minY, y); + maxY = Math.max(maxY, y); + } + var sx = 2 / (maxX - minX); + var sy = 2 / (maxY - minY); + for (var _i5 = 0; _i5 < sides; _i5++) { + x = points[2 * _i5] = points[2 * _i5] * sx; + y = points[2 * _i5 + 1] = points[2 * _i5 + 1] * sy; + minX = Math.min(minX, x); + maxX = Math.max(maxX, x); + minY = Math.min(minY, y); + maxY = Math.max(maxY, y); + } + if (minY < -1) { + for (var _i6 = 0; _i6 < sides; _i6++) { + y = points[2 * _i6 + 1] = points[2 * _i6 + 1] + (-1 - minY); + } + } + return points; + }; + var generateUnitNgonPoints = function generateUnitNgonPoints2(sides, rotationRadians) { + var increment = 1 / sides * 2 * Math.PI; + var startAngle = sides % 2 === 0 ? Math.PI / 2 + increment / 2 : Math.PI / 2; + startAngle += rotationRadians; + var points = new Array(sides * 2); + var currentAngle; + for (var i2 = 0; i2 < sides; i2++) { + currentAngle = i2 * increment + startAngle; + points[2 * i2] = Math.cos(currentAngle); + points[2 * i2 + 1] = Math.sin(-currentAngle); + } + return points; + }; + var getRoundRectangleRadius = function getRoundRectangleRadius2(width, height) { + return Math.min(width / 4, height / 4, 8); + }; + var getRoundPolygonRadius = function getRoundPolygonRadius2(width, height) { + return Math.min(width / 10, height / 10, 8); + }; + var getCutRectangleCornerLength = function getCutRectangleCornerLength2() { + return 8; + }; + var bezierPtsToQuadCoeff = function bezierPtsToQuadCoeff2(p0, p1, p2) { + return [p0 - 2 * p1 + p2, 2 * (p1 - p0), p0]; + }; + var getBarrelCurveConstants = function getBarrelCurveConstants2(width, height) { + return { + heightOffset: Math.min(15, 0.05 * height), + widthOffset: Math.min(100, 0.25 * width), + ctrlPtOffsetPct: 0.05 + }; + }; + var pageRankDefaults = defaults$g({ + dampingFactor: 0.8, + precision: 1e-6, + iterations: 200, + weight: function weight(edge) { + return 1; + } + }); + var elesfn$o = { + pageRank: function pageRank(options) { + var _pageRankDefaults = pageRankDefaults(options), dampingFactor = _pageRankDefaults.dampingFactor, precision = _pageRankDefaults.precision, iterations = _pageRankDefaults.iterations, weight = _pageRankDefaults.weight; + var cy = this._private.cy; + var _this$byGroup = this.byGroup(), nodes2 = _this$byGroup.nodes, edges = _this$byGroup.edges; + var numNodes = nodes2.length; + var numNodesSqd = numNodes * numNodes; + var numEdges = edges.length; + var matrix = new Array(numNodesSqd); + var columnSum = new Array(numNodes); + var additionalProb = (1 - dampingFactor) / numNodes; + for (var i2 = 0; i2 < numNodes; i2++) { + for (var j = 0; j < numNodes; j++) { + var n = i2 * numNodes + j; + matrix[n] = 0; + } + columnSum[i2] = 0; + } + for (var _i = 0; _i < numEdges; _i++) { + var edge = edges[_i]; + var srcId = edge.data("source"); + var tgtId = edge.data("target"); + if (srcId === tgtId) { + continue; + } + var s = nodes2.indexOfId(srcId); + var t = nodes2.indexOfId(tgtId); + var w = weight(edge); + var _n = t * numNodes + s; + matrix[_n] += w; + columnSum[s] += w; + } + var p2 = 1 / numNodes + additionalProb; + for (var _j = 0; _j < numNodes; _j++) { + if (columnSum[_j] === 0) { + for (var _i2 = 0; _i2 < numNodes; _i2++) { + var _n2 = _i2 * numNodes + _j; + matrix[_n2] = p2; + } + } else { + for (var _i3 = 0; _i3 < numNodes; _i3++) { + var _n3 = _i3 * numNodes + _j; + matrix[_n3] = matrix[_n3] / columnSum[_j] + additionalProb; + } + } + } + var eigenvector = new Array(numNodes); + var temp = new Array(numNodes); + var previous; + for (var _i4 = 0; _i4 < numNodes; _i4++) { + eigenvector[_i4] = 1; + } + for (var iter = 0; iter < iterations; iter++) { + for (var _i5 = 0; _i5 < numNodes; _i5++) { + temp[_i5] = 0; + } + for (var _i6 = 0; _i6 < numNodes; _i6++) { + for (var _j2 = 0; _j2 < numNodes; _j2++) { + var _n4 = _i6 * numNodes + _j2; + temp[_i6] += matrix[_n4] * eigenvector[_j2]; + } + } + inPlaceSumNormalize(temp); + previous = eigenvector; + eigenvector = temp; + temp = previous; + var diff = 0; + for (var _i7 = 0; _i7 < numNodes; _i7++) { + var delta = previous[_i7] - eigenvector[_i7]; + diff += delta * delta; + } + if (diff < precision) { + break; + } + } + var res = { + rank: function rank(node) { + node = cy.collection(node)[0]; + return eigenvector[nodes2.indexOf(node)]; + } + }; + return res; + } + // pageRank + }; + var defaults$f = defaults$g({ + root: null, + weight: function weight(edge) { + return 1; + }, + directed: false, + alpha: 0 + }); + var elesfn$n = { + degreeCentralityNormalized: function degreeCentralityNormalized(options) { + options = defaults$f(options); + var cy = this.cy(); + var nodes2 = this.nodes(); + var numNodes = nodes2.length; + if (!options.directed) { + var degrees = {}; + var maxDegree = 0; + for (var i2 = 0; i2 < numNodes; i2++) { + var node = nodes2[i2]; + options.root = node; + var currDegree = this.degreeCentrality(options); + if (maxDegree < currDegree.degree) { + maxDegree = currDegree.degree; + } + degrees[node.id()] = currDegree.degree; + } + return { + degree: function degree(node2) { + if (maxDegree === 0) { + return 0; + } + if (string(node2)) { + node2 = cy.filter(node2); + } + return degrees[node2.id()] / maxDegree; + } + }; + } else { + var indegrees = {}; + var outdegrees = {}; + var maxIndegree = 0; + var maxOutdegree = 0; + for (var _i = 0; _i < numNodes; _i++) { + var _node = nodes2[_i]; + var id = _node.id(); + options.root = _node; + var _currDegree = this.degreeCentrality(options); + if (maxIndegree < _currDegree.indegree) + maxIndegree = _currDegree.indegree; + if (maxOutdegree < _currDegree.outdegree) + maxOutdegree = _currDegree.outdegree; + indegrees[id] = _currDegree.indegree; + outdegrees[id] = _currDegree.outdegree; + } + return { + indegree: function indegree(node2) { + if (maxIndegree == 0) { + return 0; + } + if (string(node2)) { + node2 = cy.filter(node2); + } + return indegrees[node2.id()] / maxIndegree; + }, + outdegree: function outdegree(node2) { + if (maxOutdegree === 0) { + return 0; + } + if (string(node2)) { + node2 = cy.filter(node2); + } + return outdegrees[node2.id()] / maxOutdegree; + } + }; + } + }, + // degreeCentralityNormalized + // Implemented from the algorithm in Opsahl's paper + // "Node centrality in weighted networks: Generalizing degree and shortest paths" + // check the heading 2 "Degree" + degreeCentrality: function degreeCentrality(options) { + options = defaults$f(options); + var cy = this.cy(); + var callingEles = this; + var _options = options, root2 = _options.root, weight = _options.weight, directed = _options.directed, alpha = _options.alpha; + root2 = cy.collection(root2)[0]; + if (!directed) { + var connEdges = root2.connectedEdges().intersection(callingEles); + var k = connEdges.length; + var s = 0; + for (var i2 = 0; i2 < connEdges.length; i2++) { + s += weight(connEdges[i2]); + } + return { + degree: Math.pow(k, 1 - alpha) * Math.pow(s, alpha) + }; + } else { + var edges = root2.connectedEdges(); + var incoming = edges.filter(function(edge) { + return edge.target().same(root2) && callingEles.has(edge); + }); + var outgoing = edges.filter(function(edge) { + return edge.source().same(root2) && callingEles.has(edge); + }); + var k_in = incoming.length; + var k_out = outgoing.length; + var s_in = 0; + var s_out = 0; + for (var _i2 = 0; _i2 < incoming.length; _i2++) { + s_in += weight(incoming[_i2]); + } + for (var _i3 = 0; _i3 < outgoing.length; _i3++) { + s_out += weight(outgoing[_i3]); + } + return { + indegree: Math.pow(k_in, 1 - alpha) * Math.pow(s_in, alpha), + outdegree: Math.pow(k_out, 1 - alpha) * Math.pow(s_out, alpha) + }; + } + } + // degreeCentrality + }; + elesfn$n.dc = elesfn$n.degreeCentrality; + elesfn$n.dcn = elesfn$n.degreeCentralityNormalised = elesfn$n.degreeCentralityNormalized; + var defaults$e = defaults$g({ + harmonic: true, + weight: function weight() { + return 1; + }, + directed: false, + root: null + }); + var elesfn$m = { + closenessCentralityNormalized: function closenessCentralityNormalized(options) { + var _defaults = defaults$e(options), harmonic = _defaults.harmonic, weight = _defaults.weight, directed = _defaults.directed; + var cy = this.cy(); + var closenesses = {}; + var maxCloseness = 0; + var nodes2 = this.nodes(); + var fw = this.floydWarshall({ + weight, + directed + }); + for (var i2 = 0; i2 < nodes2.length; i2++) { + var currCloseness = 0; + var node_i = nodes2[i2]; + for (var j = 0; j < nodes2.length; j++) { + if (i2 !== j) { + var d = fw.distance(node_i, nodes2[j]); + if (harmonic) { + currCloseness += 1 / d; + } else { + currCloseness += d; + } + } + } + if (!harmonic) { + currCloseness = 1 / currCloseness; + } + if (maxCloseness < currCloseness) { + maxCloseness = currCloseness; + } + closenesses[node_i.id()] = currCloseness; + } + return { + closeness: function closeness(node) { + if (maxCloseness == 0) { + return 0; + } + if (string(node)) { + node = cy.filter(node)[0].id(); + } else { + node = node.id(); + } + return closenesses[node] / maxCloseness; + } + }; + }, + // Implemented from pseudocode from wikipedia + closenessCentrality: function closenessCentrality(options) { + var _defaults2 = defaults$e(options), root2 = _defaults2.root, weight = _defaults2.weight, directed = _defaults2.directed, harmonic = _defaults2.harmonic; + root2 = this.filter(root2)[0]; + var dijkstra = this.dijkstra({ + root: root2, + weight, + directed + }); + var totalDistance = 0; + var nodes2 = this.nodes(); + for (var i2 = 0; i2 < nodes2.length; i2++) { + var n = nodes2[i2]; + if (!n.same(root2)) { + var d = dijkstra.distanceTo(n); + if (harmonic) { + totalDistance += 1 / d; + } else { + totalDistance += d; + } + } + } + return harmonic ? totalDistance : 1 / totalDistance; + } + // closenessCentrality + }; + elesfn$m.cc = elesfn$m.closenessCentrality; + elesfn$m.ccn = elesfn$m.closenessCentralityNormalised = elesfn$m.closenessCentralityNormalized; + var defaults$d = defaults$g({ + weight: null, + directed: false + }); + var elesfn$l = { + // Implemented from the algorithm in the paper "On Variants of Shortest-Path Betweenness Centrality and their Generic Computation" by Ulrik Brandes + betweennessCentrality: function betweennessCentrality(options) { + var _defaults = defaults$d(options), directed = _defaults.directed, weight = _defaults.weight; + var weighted = weight != null; + var cy = this.cy(); + var V = this.nodes(); + var A = {}; + var _C = {}; + var max2 = 0; + var C = { + set: function set2(key, val) { + _C[key] = val; + if (val > max2) { + max2 = val; + } + }, + get: function get2(key) { + return _C[key]; + } + }; + for (var i2 = 0; i2 < V.length; i2++) { + var v = V[i2]; + var vid = v.id(); + if (directed) { + A[vid] = v.outgoers().nodes(); + } else { + A[vid] = v.openNeighborhood().nodes(); + } + C.set(vid, 0); + } + var _loop = function _loop2(s2) { + var sid = V[s2].id(); + var S = []; + var P = {}; + var g = {}; + var d = {}; + var Q = new heap(function(a, b) { + return d[a] - d[b]; + }); + for (var _i = 0; _i < V.length; _i++) { + var _vid = V[_i].id(); + P[_vid] = []; + g[_vid] = 0; + d[_vid] = Infinity; + } + g[sid] = 1; + d[sid] = 0; + Q.push(sid); + while (!Q.empty()) { + var _v = Q.pop(); + S.push(_v); + if (weighted) { + for (var j = 0; j < A[_v].length; j++) { + var w = A[_v][j]; + var vEle = cy.getElementById(_v); + var edge = void 0; + if (vEle.edgesTo(w).length > 0) { + edge = vEle.edgesTo(w)[0]; + } else { + edge = w.edgesTo(vEle)[0]; + } + var edgeWeight = weight(edge); + w = w.id(); + if (d[w] > d[_v] + edgeWeight) { + d[w] = d[_v] + edgeWeight; + if (Q.nodes.indexOf(w) < 0) { + Q.push(w); + } else { + Q.updateItem(w); + } + g[w] = 0; + P[w] = []; + } + if (d[w] == d[_v] + edgeWeight) { + g[w] = g[w] + g[_v]; + P[w].push(_v); + } + } + } else { + for (var _j = 0; _j < A[_v].length; _j++) { + var _w = A[_v][_j].id(); + if (d[_w] == Infinity) { + Q.push(_w); + d[_w] = d[_v] + 1; + } + if (d[_w] == d[_v] + 1) { + g[_w] = g[_w] + g[_v]; + P[_w].push(_v); + } + } + } + } + var e = {}; + for (var _i2 = 0; _i2 < V.length; _i2++) { + e[V[_i2].id()] = 0; + } + while (S.length > 0) { + var _w2 = S.pop(); + for (var _j2 = 0; _j2 < P[_w2].length; _j2++) { + var _v2 = P[_w2][_j2]; + e[_v2] = e[_v2] + g[_v2] / g[_w2] * (1 + e[_w2]); + } + if (_w2 != V[s2].id()) { + C.set(_w2, C.get(_w2) + e[_w2]); + } + } + }; + for (var s = 0; s < V.length; s++) { + _loop(s); + } + var ret = { + betweenness: function betweenness(node) { + var id = cy.collection(node).id(); + return C.get(id); + }, + betweennessNormalized: function betweennessNormalized(node) { + if (max2 == 0) { + return 0; + } + var id = cy.collection(node).id(); + return C.get(id) / max2; + } + }; + ret.betweennessNormalised = ret.betweennessNormalized; + return ret; + } + // betweennessCentrality + }; + elesfn$l.bc = elesfn$l.betweennessCentrality; + var defaults$c = defaults$g({ + expandFactor: 2, + // affects time of computation and cluster granularity to some extent: M * M + inflateFactor: 2, + // affects cluster granularity (the greater the value, the more clusters): M(i,j) / E(j) + multFactor: 1, + // optional self loops for each node. Use a neutral value to improve cluster computations. + maxIterations: 20, + // maximum number of iterations of the MCL algorithm in a single run + attributes: [ + // attributes/features used to group nodes, ie. similarity values between nodes + function(edge) { + return 1; + } + ] + }); + var setOptions$3 = function setOptions2(options) { + return defaults$c(options); + }; + var getSimilarity$1 = function getSimilarity2(edge, attributes) { + var total = 0; + for (var i2 = 0; i2 < attributes.length; i2++) { + total += attributes[i2](edge); + } + return total; + }; + var addLoops = function addLoops2(M, n, val) { + for (var i2 = 0; i2 < n; i2++) { + M[i2 * n + i2] = val; + } + }; + var normalize = function normalize2(M, n) { + var sum; + for (var col = 0; col < n; col++) { + sum = 0; + for (var row = 0; row < n; row++) { + sum += M[row * n + col]; + } + for (var _row = 0; _row < n; _row++) { + M[_row * n + col] = M[_row * n + col] / sum; + } + } + }; + var mmult = function mmult2(A, B, n) { + var C = new Array(n * n); + for (var i2 = 0; i2 < n; i2++) { + for (var j = 0; j < n; j++) { + C[i2 * n + j] = 0; + } + for (var k = 0; k < n; k++) { + for (var _j = 0; _j < n; _j++) { + C[i2 * n + _j] += A[i2 * n + k] * B[k * n + _j]; + } + } + } + return C; + }; + var expand = function expand2(M, n, expandFactor) { + var _M = M.slice(0); + for (var p2 = 1; p2 < expandFactor; p2++) { + M = mmult(M, _M, n); + } + return M; + }; + var inflate = function inflate2(M, n, inflateFactor) { + var _M = new Array(n * n); + for (var i2 = 0; i2 < n * n; i2++) { + _M[i2] = Math.pow(M[i2], inflateFactor); + } + normalize(_M, n); + return _M; + }; + var hasConverged = function hasConverged2(M, _M, n2, roundFactor) { + for (var i2 = 0; i2 < n2; i2++) { + var v1 = Math.round(M[i2] * Math.pow(10, roundFactor)) / Math.pow(10, roundFactor); + var v2 = Math.round(_M[i2] * Math.pow(10, roundFactor)) / Math.pow(10, roundFactor); + if (v1 !== v2) { + return false; + } + } + return true; + }; + var assign$2 = function assign2(M, n, nodes2, cy) { + var clusters = []; + for (var i2 = 0; i2 < n; i2++) { + var cluster = []; + for (var j = 0; j < n; j++) { + if (Math.round(M[i2 * n + j] * 1e3) / 1e3 > 0) { + cluster.push(nodes2[j]); + } + } + if (cluster.length !== 0) { + clusters.push(cy.collection(cluster)); + } + } + return clusters; + }; + var isDuplicate = function isDuplicate2(c1, c2) { + for (var i2 = 0; i2 < c1.length; i2++) { + if (!c2[i2] || c1[i2].id() !== c2[i2].id()) { + return false; + } + } + return true; + }; + var removeDuplicates = function removeDuplicates2(clusters) { + for (var i2 = 0; i2 < clusters.length; i2++) { + for (var j = 0; j < clusters.length; j++) { + if (i2 != j && isDuplicate(clusters[i2], clusters[j])) { + clusters.splice(j, 1); + } + } + } + return clusters; + }; + var markovClustering = function markovClustering2(options) { + var nodes2 = this.nodes(); + var edges = this.edges(); + var cy = this.cy(); + var opts = setOptions$3(options); + var id2position = {}; + for (var i2 = 0; i2 < nodes2.length; i2++) { + id2position[nodes2[i2].id()] = i2; + } + var n = nodes2.length, n2 = n * n; + var M = new Array(n2), _M; + for (var _i = 0; _i < n2; _i++) { + M[_i] = 0; + } + for (var e = 0; e < edges.length; e++) { + var edge = edges[e]; + var _i2 = id2position[edge.source().id()]; + var j = id2position[edge.target().id()]; + var sim = getSimilarity$1(edge, opts.attributes); + M[_i2 * n + j] += sim; + M[j * n + _i2] += sim; + } + addLoops(M, n, opts.multFactor); + normalize(M, n); + var isStillMoving = true; + var iterations = 0; + while (isStillMoving && iterations < opts.maxIterations) { + isStillMoving = false; + _M = expand(M, n, opts.expandFactor); + M = inflate(_M, n, opts.inflateFactor); + if (!hasConverged(M, _M, n2, 4)) { + isStillMoving = true; + } + iterations++; + } + var clusters = assign$2(M, n, nodes2, cy); + clusters = removeDuplicates(clusters); + return clusters; + }; + var markovClustering$1 = { + markovClustering, + mcl: markovClustering + }; + var identity = function identity2(x) { + return x; + }; + var absDiff = function absDiff2(p2, q) { + return Math.abs(q - p2); + }; + var addAbsDiff = function addAbsDiff2(total, p2, q) { + return total + absDiff(p2, q); + }; + var addSquaredDiff = function addSquaredDiff2(total, p2, q) { + return total + Math.pow(q - p2, 2); + }; + var sqrt = function sqrt3(x) { + return Math.sqrt(x); + }; + var maxAbsDiff = function maxAbsDiff2(currentMax, p2, q) { + return Math.max(currentMax, absDiff(p2, q)); + }; + var getDistance = function getDistance2(length, getP, getQ, init, visit) { + var post = arguments.length > 5 && arguments[5] !== void 0 ? arguments[5] : identity; + var ret = init; + var p2, q; + for (var dim = 0; dim < length; dim++) { + p2 = getP(dim); + q = getQ(dim); + ret = visit(ret, p2, q); + } + return post(ret); + }; + var distances = { + euclidean: function euclidean(length, getP, getQ) { + if (length >= 2) { + return getDistance(length, getP, getQ, 0, addSquaredDiff, sqrt); + } else { + return getDistance(length, getP, getQ, 0, addAbsDiff); + } + }, + squaredEuclidean: function squaredEuclidean(length, getP, getQ) { + return getDistance(length, getP, getQ, 0, addSquaredDiff); + }, + manhattan: function manhattan(length, getP, getQ) { + return getDistance(length, getP, getQ, 0, addAbsDiff); + }, + max: function max2(length, getP, getQ) { + return getDistance(length, getP, getQ, -Infinity, maxAbsDiff); + } + }; + distances["squared-euclidean"] = distances["squaredEuclidean"]; + distances["squaredeuclidean"] = distances["squaredEuclidean"]; + function clusteringDistance(method, length, getP, getQ, nodeP, nodeQ) { + var impl2; + if (fn$6(method)) { + impl2 = method; + } else { + impl2 = distances[method] || distances.euclidean; + } + if (length === 0 && fn$6(method)) { + return impl2(nodeP, nodeQ); + } else { + return impl2(length, getP, getQ, nodeP, nodeQ); + } + } + var defaults$b = defaults$g({ + k: 2, + m: 2, + sensitivityThreshold: 1e-4, + distance: "euclidean", + maxIterations: 10, + attributes: [], + testMode: false, + testCentroids: null + }); + var setOptions$2 = function setOptions2(options) { + return defaults$b(options); + }; + var getDist = function getDist2(type, node, centroid, attributes, mode) { + var noNodeP = mode !== "kMedoids"; + var getP = noNodeP ? function(i2) { + return centroid[i2]; + } : function(i2) { + return attributes[i2](centroid); + }; + var getQ = function getQ2(i2) { + return attributes[i2](node); + }; + var nodeP = centroid; + var nodeQ = node; + return clusteringDistance(type, attributes.length, getP, getQ, nodeP, nodeQ); + }; + var randomCentroids = function randomCentroids2(nodes2, k, attributes) { + var ndim = attributes.length; + var min2 = new Array(ndim); + var max2 = new Array(ndim); + var centroids = new Array(k); + var centroid = null; + for (var i2 = 0; i2 < ndim; i2++) { + min2[i2] = nodes2.min(attributes[i2]).value; + max2[i2] = nodes2.max(attributes[i2]).value; + } + for (var c = 0; c < k; c++) { + centroid = []; + for (var _i = 0; _i < ndim; _i++) { + centroid[_i] = Math.random() * (max2[_i] - min2[_i]) + min2[_i]; + } + centroids[c] = centroid; + } + return centroids; + }; + var classify = function classify2(node, centroids, distance, attributes, type) { + var min2 = Infinity; + var index = 0; + for (var i2 = 0; i2 < centroids.length; i2++) { + var dist2 = getDist(distance, node, centroids[i2], attributes, type); + if (dist2 < min2) { + min2 = dist2; + index = i2; + } + } + return index; + }; + var buildCluster = function buildCluster2(centroid, nodes2, assignment) { + var cluster = []; + var node = null; + for (var n = 0; n < nodes2.length; n++) { + node = nodes2[n]; + if (assignment[node.id()] === centroid) { + cluster.push(node); + } + } + return cluster; + }; + var haveValuesConverged = function haveValuesConverged2(v1, v2, sensitivityThreshold) { + return Math.abs(v2 - v1) <= sensitivityThreshold; + }; + var haveMatricesConverged = function haveMatricesConverged2(v1, v2, sensitivityThreshold) { + for (var i2 = 0; i2 < v1.length; i2++) { + for (var j = 0; j < v1[i2].length; j++) { + var diff = Math.abs(v1[i2][j] - v2[i2][j]); + if (diff > sensitivityThreshold) { + return false; + } + } + } + return true; + }; + var seenBefore = function seenBefore2(node, medoids, n) { + for (var i2 = 0; i2 < n; i2++) { + if (node === medoids[i2]) + return true; + } + return false; + }; + var randomMedoids = function randomMedoids2(nodes2, k) { + var medoids = new Array(k); + if (nodes2.length < 50) { + for (var i2 = 0; i2 < k; i2++) { + var node = nodes2[Math.floor(Math.random() * nodes2.length)]; + while (seenBefore(node, medoids, i2)) { + node = nodes2[Math.floor(Math.random() * nodes2.length)]; + } + medoids[i2] = node; + } + } else { + for (var _i2 = 0; _i2 < k; _i2++) { + medoids[_i2] = nodes2[Math.floor(Math.random() * nodes2.length)]; + } + } + return medoids; + }; + var findCost = function findCost2(potentialNewMedoid, cluster, attributes) { + var cost = 0; + for (var n = 0; n < cluster.length; n++) { + cost += getDist("manhattan", cluster[n], potentialNewMedoid, attributes, "kMedoids"); + } + return cost; + }; + var kMeans = function kMeans2(options) { + var cy = this.cy(); + var nodes2 = this.nodes(); + var node = null; + var opts = setOptions$2(options); + var clusters = new Array(opts.k); + var assignment = {}; + var centroids; + if (opts.testMode) { + if (typeof opts.testCentroids === "number") { + opts.testCentroids; + centroids = randomCentroids(nodes2, opts.k, opts.attributes); + } else if (_typeof(opts.testCentroids) === "object") { + centroids = opts.testCentroids; + } else { + centroids = randomCentroids(nodes2, opts.k, opts.attributes); + } + } else { + centroids = randomCentroids(nodes2, opts.k, opts.attributes); + } + var isStillMoving = true; + var iterations = 0; + while (isStillMoving && iterations < opts.maxIterations) { + for (var n = 0; n < nodes2.length; n++) { + node = nodes2[n]; + assignment[node.id()] = classify(node, centroids, opts.distance, opts.attributes, "kMeans"); + } + isStillMoving = false; + for (var c = 0; c < opts.k; c++) { + var cluster = buildCluster(c, nodes2, assignment); + if (cluster.length === 0) { + continue; + } + var ndim = opts.attributes.length; + var centroid = centroids[c]; + var newCentroid = new Array(ndim); + var sum = new Array(ndim); + for (var d = 0; d < ndim; d++) { + sum[d] = 0; + for (var i2 = 0; i2 < cluster.length; i2++) { + node = cluster[i2]; + sum[d] += opts.attributes[d](node); + } + newCentroid[d] = sum[d] / cluster.length; + if (!haveValuesConverged(newCentroid[d], centroid[d], opts.sensitivityThreshold)) { + isStillMoving = true; + } + } + centroids[c] = newCentroid; + clusters[c] = cy.collection(cluster); + } + iterations++; + } + return clusters; + }; + var kMedoids = function kMedoids2(options) { + var cy = this.cy(); + var nodes2 = this.nodes(); + var node = null; + var opts = setOptions$2(options); + var clusters = new Array(opts.k); + var medoids; + var assignment = {}; + var curCost; + var minCosts = new Array(opts.k); + if (opts.testMode) { + if (typeof opts.testCentroids === "number") + ; + else if (_typeof(opts.testCentroids) === "object") { + medoids = opts.testCentroids; + } else { + medoids = randomMedoids(nodes2, opts.k); + } + } else { + medoids = randomMedoids(nodes2, opts.k); + } + var isStillMoving = true; + var iterations = 0; + while (isStillMoving && iterations < opts.maxIterations) { + for (var n = 0; n < nodes2.length; n++) { + node = nodes2[n]; + assignment[node.id()] = classify(node, medoids, opts.distance, opts.attributes, "kMedoids"); + } + isStillMoving = false; + for (var m = 0; m < medoids.length; m++) { + var cluster = buildCluster(m, nodes2, assignment); + if (cluster.length === 0) { + continue; + } + minCosts[m] = findCost(medoids[m], cluster, opts.attributes); + for (var _n = 0; _n < cluster.length; _n++) { + curCost = findCost(cluster[_n], cluster, opts.attributes); + if (curCost < minCosts[m]) { + minCosts[m] = curCost; + medoids[m] = cluster[_n]; + isStillMoving = true; + } + } + clusters[m] = cy.collection(cluster); + } + iterations++; + } + return clusters; + }; + var updateCentroids = function updateCentroids2(centroids, nodes2, U, weight, opts) { + var numerator, denominator; + for (var n = 0; n < nodes2.length; n++) { + for (var c = 0; c < centroids.length; c++) { + weight[n][c] = Math.pow(U[n][c], opts.m); + } + } + for (var _c = 0; _c < centroids.length; _c++) { + for (var dim = 0; dim < opts.attributes.length; dim++) { + numerator = 0; + denominator = 0; + for (var _n2 = 0; _n2 < nodes2.length; _n2++) { + numerator += weight[_n2][_c] * opts.attributes[dim](nodes2[_n2]); + denominator += weight[_n2][_c]; + } + centroids[_c][dim] = numerator / denominator; + } + } + }; + var updateMembership = function updateMembership2(U, _U, centroids, nodes2, opts) { + for (var i2 = 0; i2 < U.length; i2++) { + _U[i2] = U[i2].slice(); + } + var sum, numerator, denominator; + var pow = 2 / (opts.m - 1); + for (var c = 0; c < centroids.length; c++) { + for (var n = 0; n < nodes2.length; n++) { + sum = 0; + for (var k = 0; k < centroids.length; k++) { + numerator = getDist(opts.distance, nodes2[n], centroids[c], opts.attributes, "cmeans"); + denominator = getDist(opts.distance, nodes2[n], centroids[k], opts.attributes, "cmeans"); + sum += Math.pow(numerator / denominator, pow); + } + U[n][c] = 1 / sum; + } + } + }; + var assign$1 = function assign2(nodes2, U, opts, cy) { + var clusters = new Array(opts.k); + for (var c = 0; c < clusters.length; c++) { + clusters[c] = []; + } + var max2; + var index; + for (var n = 0; n < U.length; n++) { + max2 = -Infinity; + index = -1; + for (var _c2 = 0; _c2 < U[0].length; _c2++) { + if (U[n][_c2] > max2) { + max2 = U[n][_c2]; + index = _c2; + } + } + clusters[index].push(nodes2[n]); + } + for (var _c3 = 0; _c3 < clusters.length; _c3++) { + clusters[_c3] = cy.collection(clusters[_c3]); + } + return clusters; + }; + var fuzzyCMeans = function fuzzyCMeans2(options) { + var cy = this.cy(); + var nodes2 = this.nodes(); + var opts = setOptions$2(options); + var clusters; + var centroids; + var U; + var _U; + var weight; + _U = new Array(nodes2.length); + for (var i2 = 0; i2 < nodes2.length; i2++) { + _U[i2] = new Array(opts.k); + } + U = new Array(nodes2.length); + for (var _i3 = 0; _i3 < nodes2.length; _i3++) { + U[_i3] = new Array(opts.k); + } + for (var _i4 = 0; _i4 < nodes2.length; _i4++) { + var total = 0; + for (var j = 0; j < opts.k; j++) { + U[_i4][j] = Math.random(); + total += U[_i4][j]; + } + for (var _j = 0; _j < opts.k; _j++) { + U[_i4][_j] = U[_i4][_j] / total; + } + } + centroids = new Array(opts.k); + for (var _i5 = 0; _i5 < opts.k; _i5++) { + centroids[_i5] = new Array(opts.attributes.length); + } + weight = new Array(nodes2.length); + for (var _i6 = 0; _i6 < nodes2.length; _i6++) { + weight[_i6] = new Array(opts.k); + } + var isStillMoving = true; + var iterations = 0; + while (isStillMoving && iterations < opts.maxIterations) { + isStillMoving = false; + updateCentroids(centroids, nodes2, U, weight, opts); + updateMembership(U, _U, centroids, nodes2, opts); + if (!haveMatricesConverged(U, _U, opts.sensitivityThreshold)) { + isStillMoving = true; + } + iterations++; + } + clusters = assign$1(nodes2, U, opts, cy); + return { + clusters, + degreeOfMembership: U + }; + }; + var kClustering = { + kMeans, + kMedoids, + fuzzyCMeans, + fcm: fuzzyCMeans + }; + var defaults$a = defaults$g({ + distance: "euclidean", + // distance metric to compare nodes + linkage: "min", + // linkage criterion : how to determine the distance between clusters of nodes + mode: "threshold", + // mode:'threshold' => clusters must be threshold distance apart + threshold: Infinity, + // the distance threshold + // mode:'dendrogram' => the nodes are organised as leaves in a tree (siblings are close), merging makes clusters + addDendrogram: false, + // whether to add the dendrogram to the graph for viz + dendrogramDepth: 0, + // depth at which dendrogram branches are merged into the returned clusters + attributes: [] + // array of attr functions + }); + var linkageAliases = { + "single": "min", + "complete": "max" + }; + var setOptions$1 = function setOptions2(options) { + var opts = defaults$a(options); + var preferredAlias = linkageAliases[opts.linkage]; + if (preferredAlias != null) { + opts.linkage = preferredAlias; + } + return opts; + }; + var mergeClosest = function mergeClosest2(clusters, index, dists, mins, opts) { + var minKey = 0; + var min2 = Infinity; + var dist2; + var attrs = opts.attributes; + var getDist2 = function getDist3(n1, n2) { + return clusteringDistance(opts.distance, attrs.length, function(i3) { + return attrs[i3](n1); + }, function(i3) { + return attrs[i3](n2); + }, n1, n2); + }; + for (var i2 = 0; i2 < clusters.length; i2++) { + var key = clusters[i2].key; + var _dist = dists[key][mins[key]]; + if (_dist < min2) { + minKey = key; + min2 = _dist; + } + } + if (opts.mode === "threshold" && min2 >= opts.threshold || opts.mode === "dendrogram" && clusters.length === 1) { + return false; + } + var c1 = index[minKey]; + var c2 = index[mins[minKey]]; + var merged; + if (opts.mode === "dendrogram") { + merged = { + left: c1, + right: c2, + key: c1.key + }; + } else { + merged = { + value: c1.value.concat(c2.value), + key: c1.key + }; + } + clusters[c1.index] = merged; + clusters.splice(c2.index, 1); + index[c1.key] = merged; + for (var _i = 0; _i < clusters.length; _i++) { + var cur = clusters[_i]; + if (c1.key === cur.key) { + dist2 = Infinity; + } else if (opts.linkage === "min") { + dist2 = dists[c1.key][cur.key]; + if (dists[c1.key][cur.key] > dists[c2.key][cur.key]) { + dist2 = dists[c2.key][cur.key]; + } + } else if (opts.linkage === "max") { + dist2 = dists[c1.key][cur.key]; + if (dists[c1.key][cur.key] < dists[c2.key][cur.key]) { + dist2 = dists[c2.key][cur.key]; + } + } else if (opts.linkage === "mean") { + dist2 = (dists[c1.key][cur.key] * c1.size + dists[c2.key][cur.key] * c2.size) / (c1.size + c2.size); + } else { + if (opts.mode === "dendrogram") + dist2 = getDist2(cur.value, c1.value); + else + dist2 = getDist2(cur.value[0], c1.value[0]); + } + dists[c1.key][cur.key] = dists[cur.key][c1.key] = dist2; + } + for (var _i2 = 0; _i2 < clusters.length; _i2++) { + var key1 = clusters[_i2].key; + if (mins[key1] === c1.key || mins[key1] === c2.key) { + var _min = key1; + for (var j = 0; j < clusters.length; j++) { + var key2 = clusters[j].key; + if (dists[key1][key2] < dists[key1][_min]) { + _min = key2; + } + } + mins[key1] = _min; + } + clusters[_i2].index = _i2; + } + c1.key = c2.key = c1.index = c2.index = null; + return true; + }; + var getAllChildren = function getAllChildren2(root2, arr, cy) { + if (!root2) + return; + if (root2.value) { + arr.push(root2.value); + } else { + if (root2.left) + getAllChildren2(root2.left, arr); + if (root2.right) + getAllChildren2(root2.right, arr); + } + }; + var buildDendrogram = function buildDendrogram2(root2, cy) { + if (!root2) + return ""; + if (root2.left && root2.right) { + var leftStr = buildDendrogram2(root2.left, cy); + var rightStr = buildDendrogram2(root2.right, cy); + var node = cy.add({ + group: "nodes", + data: { + id: leftStr + "," + rightStr + } + }); + cy.add({ + group: "edges", + data: { + source: leftStr, + target: node.id() + } + }); + cy.add({ + group: "edges", + data: { + source: rightStr, + target: node.id() + } + }); + return node.id(); + } else if (root2.value) { + return root2.value.id(); + } + }; + var buildClustersFromTree = function buildClustersFromTree2(root2, k, cy) { + if (!root2) + return []; + var left = [], right = [], leaves = []; + if (k === 0) { + if (root2.left) + getAllChildren(root2.left, left); + if (root2.right) + getAllChildren(root2.right, right); + leaves = left.concat(right); + return [cy.collection(leaves)]; + } else if (k === 1) { + if (root2.value) { + return [cy.collection(root2.value)]; + } else { + if (root2.left) + getAllChildren(root2.left, left); + if (root2.right) + getAllChildren(root2.right, right); + return [cy.collection(left), cy.collection(right)]; + } + } else { + if (root2.value) { + return [cy.collection(root2.value)]; + } else { + if (root2.left) + left = buildClustersFromTree2(root2.left, k - 1, cy); + if (root2.right) + right = buildClustersFromTree2(root2.right, k - 1, cy); + return left.concat(right); + } + } + }; + var hierarchicalClustering = function hierarchicalClustering2(options) { + var cy = this.cy(); + var nodes2 = this.nodes(); + var opts = setOptions$1(options); + var attrs = opts.attributes; + var getDist2 = function getDist3(n1, n2) { + return clusteringDistance(opts.distance, attrs.length, function(i3) { + return attrs[i3](n1); + }, function(i3) { + return attrs[i3](n2); + }, n1, n2); + }; + var clusters = []; + var dists = []; + var mins = []; + var index = []; + for (var n = 0; n < nodes2.length; n++) { + var cluster = { + value: opts.mode === "dendrogram" ? nodes2[n] : [nodes2[n]], + key: n, + index: n + }; + clusters[n] = cluster; + index[n] = cluster; + dists[n] = []; + mins[n] = 0; + } + for (var i2 = 0; i2 < clusters.length; i2++) { + for (var j = 0; j <= i2; j++) { + var dist2 = void 0; + if (opts.mode === "dendrogram") { + dist2 = i2 === j ? Infinity : getDist2(clusters[i2].value, clusters[j].value); + } else { + dist2 = i2 === j ? Infinity : getDist2(clusters[i2].value[0], clusters[j].value[0]); + } + dists[i2][j] = dist2; + dists[j][i2] = dist2; + if (dist2 < dists[i2][mins[i2]]) { + mins[i2] = j; + } + } + } + var merged = mergeClosest(clusters, index, dists, mins, opts); + while (merged) { + merged = mergeClosest(clusters, index, dists, mins, opts); + } + var retClusters; + if (opts.mode === "dendrogram") { + retClusters = buildClustersFromTree(clusters[0], opts.dendrogramDepth, cy); + if (opts.addDendrogram) + buildDendrogram(clusters[0], cy); + } else { + retClusters = new Array(clusters.length); + clusters.forEach(function(cluster2, i3) { + cluster2.key = cluster2.index = null; + retClusters[i3] = cy.collection(cluster2.value); + }); + } + return retClusters; + }; + var hierarchicalClustering$1 = { + hierarchicalClustering, + hca: hierarchicalClustering + }; + var defaults$9 = defaults$g({ + distance: "euclidean", + // distance metric to compare attributes between two nodes + preference: "median", + // suitability of a data point to serve as an exemplar + damping: 0.8, + // damping factor between [0.5, 1) + maxIterations: 1e3, + // max number of iterations to run + minIterations: 100, + // min number of iterations to run in order for clustering to stop + attributes: [ + // functions to quantify the similarity between any two points + // e.g. node => node.data('weight') + ] + }); + var setOptions = function setOptions2(options) { + var dmp = options.damping; + var pref = options.preference; + if (!(0.5 <= dmp && dmp < 1)) { + error("Damping must range on [0.5, 1). Got: ".concat(dmp)); + } + var validPrefs = ["median", "mean", "min", "max"]; + if (!(validPrefs.some(function(v) { + return v === pref; + }) || number$1(pref))) { + error("Preference must be one of [".concat(validPrefs.map(function(p2) { + return "'".concat(p2, "'"); + }).join(", "), "] or a number. Got: ").concat(pref)); + } + return defaults$9(options); + }; + var getSimilarity = function getSimilarity2(type, n1, n2, attributes) { + var attr = function attr2(n, i2) { + return attributes[i2](n); + }; + return -clusteringDistance(type, attributes.length, function(i2) { + return attr(n1, i2); + }, function(i2) { + return attr(n2, i2); + }, n1, n2); + }; + var getPreference = function getPreference2(S, preference) { + var p2 = null; + if (preference === "median") { + p2 = median(S); + } else if (preference === "mean") { + p2 = mean(S); + } else if (preference === "min") { + p2 = min(S); + } else if (preference === "max") { + p2 = max(S); + } else { + p2 = preference; + } + return p2; + }; + var findExemplars = function findExemplars2(n, R, A) { + var indices = []; + for (var i2 = 0; i2 < n; i2++) { + if (R[i2 * n + i2] + A[i2 * n + i2] > 0) { + indices.push(i2); + } + } + return indices; + }; + var assignClusters = function assignClusters2(n, S, exemplars) { + var clusters = []; + for (var i2 = 0; i2 < n; i2++) { + var index = -1; + var max2 = -Infinity; + for (var ei = 0; ei < exemplars.length; ei++) { + var e = exemplars[ei]; + if (S[i2 * n + e] > max2) { + index = e; + max2 = S[i2 * n + e]; + } + } + if (index > 0) { + clusters.push(index); + } + } + for (var _ei = 0; _ei < exemplars.length; _ei++) { + clusters[exemplars[_ei]] = exemplars[_ei]; + } + return clusters; + }; + var assign = function assign2(n, S, exemplars) { + var clusters = assignClusters(n, S, exemplars); + for (var ei = 0; ei < exemplars.length; ei++) { + var ii = []; + for (var c = 0; c < clusters.length; c++) { + if (clusters[c] === exemplars[ei]) { + ii.push(c); + } + } + var maxI = -1; + var maxSum = -Infinity; + for (var i2 = 0; i2 < ii.length; i2++) { + var sum = 0; + for (var j = 0; j < ii.length; j++) { + sum += S[ii[j] * n + ii[i2]]; + } + if (sum > maxSum) { + maxI = i2; + maxSum = sum; + } + } + exemplars[ei] = ii[maxI]; + } + clusters = assignClusters(n, S, exemplars); + return clusters; + }; + var affinityPropagation = function affinityPropagation2(options) { + var cy = this.cy(); + var nodes2 = this.nodes(); + var opts = setOptions(options); + var id2position = {}; + for (var i2 = 0; i2 < nodes2.length; i2++) { + id2position[nodes2[i2].id()] = i2; + } + var n; + var n2; + var S; + var p2; + var R; + var A; + n = nodes2.length; + n2 = n * n; + S = new Array(n2); + for (var _i = 0; _i < n2; _i++) { + S[_i] = -Infinity; + } + for (var _i2 = 0; _i2 < n; _i2++) { + for (var j = 0; j < n; j++) { + if (_i2 !== j) { + S[_i2 * n + j] = getSimilarity(opts.distance, nodes2[_i2], nodes2[j], opts.attributes); + } + } + } + p2 = getPreference(S, opts.preference); + for (var _i3 = 0; _i3 < n; _i3++) { + S[_i3 * n + _i3] = p2; + } + R = new Array(n2); + for (var _i4 = 0; _i4 < n2; _i4++) { + R[_i4] = 0; + } + A = new Array(n2); + for (var _i5 = 0; _i5 < n2; _i5++) { + A[_i5] = 0; + } + var old = new Array(n); + var Rp = new Array(n); + var se = new Array(n); + for (var _i6 = 0; _i6 < n; _i6++) { + old[_i6] = 0; + Rp[_i6] = 0; + se[_i6] = 0; + } + var e = new Array(n * opts.minIterations); + for (var _i7 = 0; _i7 < e.length; _i7++) { + e[_i7] = 0; + } + var iter; + for (iter = 0; iter < opts.maxIterations; iter++) { + for (var _i8 = 0; _i8 < n; _i8++) { + var max2 = -Infinity, max22 = -Infinity, maxI = -1, AS = 0; + for (var _j = 0; _j < n; _j++) { + old[_j] = R[_i8 * n + _j]; + AS = A[_i8 * n + _j] + S[_i8 * n + _j]; + if (AS >= max2) { + max22 = max2; + max2 = AS; + maxI = _j; + } else if (AS > max22) { + max22 = AS; + } + } + for (var _j2 = 0; _j2 < n; _j2++) { + R[_i8 * n + _j2] = (1 - opts.damping) * (S[_i8 * n + _j2] - max2) + opts.damping * old[_j2]; + } + R[_i8 * n + maxI] = (1 - opts.damping) * (S[_i8 * n + maxI] - max22) + opts.damping * old[maxI]; + } + for (var _i9 = 0; _i9 < n; _i9++) { + var sum = 0; + for (var _j3 = 0; _j3 < n; _j3++) { + old[_j3] = A[_j3 * n + _i9]; + Rp[_j3] = Math.max(0, R[_j3 * n + _i9]); + sum += Rp[_j3]; + } + sum -= Rp[_i9]; + Rp[_i9] = R[_i9 * n + _i9]; + sum += Rp[_i9]; + for (var _j4 = 0; _j4 < n; _j4++) { + A[_j4 * n + _i9] = (1 - opts.damping) * Math.min(0, sum - Rp[_j4]) + opts.damping * old[_j4]; + } + A[_i9 * n + _i9] = (1 - opts.damping) * (sum - Rp[_i9]) + opts.damping * old[_i9]; + } + var K2 = 0; + for (var _i10 = 0; _i10 < n; _i10++) { + var E = A[_i10 * n + _i10] + R[_i10 * n + _i10] > 0 ? 1 : 0; + e[iter % opts.minIterations * n + _i10] = E; + K2 += E; + } + if (K2 > 0 && (iter >= opts.minIterations - 1 || iter == opts.maxIterations - 1)) { + var _sum = 0; + for (var _i11 = 0; _i11 < n; _i11++) { + se[_i11] = 0; + for (var _j5 = 0; _j5 < opts.minIterations; _j5++) { + se[_i11] += e[_j5 * n + _i11]; + } + if (se[_i11] === 0 || se[_i11] === opts.minIterations) { + _sum++; + } + } + if (_sum === n) { + break; + } + } + } + var exemplarsIndices = findExemplars(n, R, A); + var clusterIndices = assign(n, S, exemplarsIndices); + var clusters = {}; + for (var c = 0; c < exemplarsIndices.length; c++) { + clusters[exemplarsIndices[c]] = []; + } + for (var _i12 = 0; _i12 < nodes2.length; _i12++) { + var pos = id2position[nodes2[_i12].id()]; + var clusterIndex = clusterIndices[pos]; + if (clusterIndex != null) { + clusters[clusterIndex].push(nodes2[_i12]); + } + } + var retClusters = new Array(exemplarsIndices.length); + for (var _c = 0; _c < exemplarsIndices.length; _c++) { + retClusters[_c] = cy.collection(clusters[exemplarsIndices[_c]]); + } + return retClusters; + }; + var affinityPropagation$1 = { + affinityPropagation, + ap: affinityPropagation + }; + var hierholzerDefaults = defaults$g({ + root: void 0, + directed: false + }); + var elesfn$k = { + hierholzer: function hierholzer(options) { + if (!plainObject(options)) { + var args = arguments; + options = { + root: args[0], + directed: args[1] + }; + } + var _hierholzerDefaults = hierholzerDefaults(options), root2 = _hierholzerDefaults.root, directed = _hierholzerDefaults.directed; + var eles = this; + var dflag = false; + var oddIn; + var oddOut; + var startVertex; + if (root2) + startVertex = string(root2) ? this.filter(root2)[0].id() : root2[0].id(); + var nodes2 = {}; + var edges = {}; + if (directed) { + eles.forEach(function(ele) { + var id = ele.id(); + if (ele.isNode()) { + var ind = ele.indegree(true); + var outd = ele.outdegree(true); + var d1 = ind - outd; + var d2 = outd - ind; + if (d1 == 1) { + if (oddIn) + dflag = true; + else + oddIn = id; + } else if (d2 == 1) { + if (oddOut) + dflag = true; + else + oddOut = id; + } else if (d2 > 1 || d1 > 1) { + dflag = true; + } + nodes2[id] = []; + ele.outgoers().forEach(function(e) { + if (e.isEdge()) + nodes2[id].push(e.id()); + }); + } else { + edges[id] = [void 0, ele.target().id()]; + } + }); + } else { + eles.forEach(function(ele) { + var id = ele.id(); + if (ele.isNode()) { + var d2 = ele.degree(true); + if (d2 % 2) { + if (!oddIn) + oddIn = id; + else if (!oddOut) + oddOut = id; + else + dflag = true; + } + nodes2[id] = []; + ele.connectedEdges().forEach(function(e) { + return nodes2[id].push(e.id()); + }); + } else { + edges[id] = [ele.source().id(), ele.target().id()]; + } + }); + } + var result = { + found: false, + trail: void 0 + }; + if (dflag) + return result; + else if (oddOut && oddIn) { + if (directed) { + if (startVertex && oddOut != startVertex) { + return result; + } + startVertex = oddOut; + } else { + if (startVertex && oddOut != startVertex && oddIn != startVertex) { + return result; + } else if (!startVertex) { + startVertex = oddOut; + } + } + } else { + if (!startVertex) + startVertex = eles[0].id(); + } + var walk = function walk2(v) { + var currentNode = v; + var subtour2 = [v]; + var adj, adjTail, adjHead; + while (nodes2[currentNode].length) { + adj = nodes2[currentNode].shift(); + adjTail = edges[adj][0]; + adjHead = edges[adj][1]; + if (currentNode != adjHead) { + nodes2[adjHead] = nodes2[adjHead].filter(function(e) { + return e != adj; + }); + currentNode = adjHead; + } else if (!directed && currentNode != adjTail) { + nodes2[adjTail] = nodes2[adjTail].filter(function(e) { + return e != adj; + }); + currentNode = adjTail; + } + subtour2.unshift(adj); + subtour2.unshift(currentNode); + } + return subtour2; + }; + var trail = []; + var subtour = []; + subtour = walk(startVertex); + while (subtour.length != 1) { + if (nodes2[subtour[0]].length == 0) { + trail.unshift(eles.getElementById(subtour.shift())); + trail.unshift(eles.getElementById(subtour.shift())); + } else { + subtour = walk(subtour.shift()).concat(subtour); + } + } + trail.unshift(eles.getElementById(subtour.shift())); + for (var d in nodes2) { + if (nodes2[d].length) { + return result; + } + } + result.found = true; + result.trail = this.spawn(trail, true); + return result; + } + }; + var hopcroftTarjanBiconnected = function hopcroftTarjanBiconnected2() { + var eles = this; + var nodes2 = {}; + var id = 0; + var edgeCount = 0; + var components = []; + var stack = []; + var visitedEdges = {}; + var buildComponent = function buildComponent2(x, y) { + var i2 = stack.length - 1; + var cutset = []; + var component = eles.spawn(); + while (stack[i2].x != x || stack[i2].y != y) { + cutset.push(stack.pop().edge); + i2--; + } + cutset.push(stack.pop().edge); + cutset.forEach(function(edge) { + var connectedNodes = edge.connectedNodes().intersection(eles); + component.merge(edge); + connectedNodes.forEach(function(node) { + var nodeId = node.id(); + var connectedEdges = node.connectedEdges().intersection(eles); + component.merge(node); + if (!nodes2[nodeId].cutVertex) { + component.merge(connectedEdges); + } else { + component.merge(connectedEdges.filter(function(edge2) { + return edge2.isLoop(); + })); + } + }); + }); + components.push(component); + }; + var biconnectedSearch = function biconnectedSearch2(root2, currentNode, parent) { + if (root2 === parent) + edgeCount += 1; + nodes2[currentNode] = { + id, + low: id++, + cutVertex: false + }; + var edges = eles.getElementById(currentNode).connectedEdges().intersection(eles); + if (edges.size() === 0) { + components.push(eles.spawn(eles.getElementById(currentNode))); + } else { + var sourceId, targetId, otherNodeId, edgeId; + edges.forEach(function(edge) { + sourceId = edge.source().id(); + targetId = edge.target().id(); + otherNodeId = sourceId === currentNode ? targetId : sourceId; + if (otherNodeId !== parent) { + edgeId = edge.id(); + if (!visitedEdges[edgeId]) { + visitedEdges[edgeId] = true; + stack.push({ + x: currentNode, + y: otherNodeId, + edge + }); + } + if (!(otherNodeId in nodes2)) { + biconnectedSearch2(root2, otherNodeId, currentNode); + nodes2[currentNode].low = Math.min(nodes2[currentNode].low, nodes2[otherNodeId].low); + if (nodes2[currentNode].id <= nodes2[otherNodeId].low) { + nodes2[currentNode].cutVertex = true; + buildComponent(currentNode, otherNodeId); + } + } else { + nodes2[currentNode].low = Math.min(nodes2[currentNode].low, nodes2[otherNodeId].id); + } + } + }); + } + }; + eles.forEach(function(ele) { + if (ele.isNode()) { + var nodeId = ele.id(); + if (!(nodeId in nodes2)) { + edgeCount = 0; + biconnectedSearch(nodeId, nodeId); + nodes2[nodeId].cutVertex = edgeCount > 1; + } + } + }); + var cutVertices = Object.keys(nodes2).filter(function(id2) { + return nodes2[id2].cutVertex; + }).map(function(id2) { + return eles.getElementById(id2); + }); + return { + cut: eles.spawn(cutVertices), + components + }; + }; + var hopcroftTarjanBiconnected$1 = { + hopcroftTarjanBiconnected, + htbc: hopcroftTarjanBiconnected, + htb: hopcroftTarjanBiconnected, + hopcroftTarjanBiconnectedComponents: hopcroftTarjanBiconnected + }; + var tarjanStronglyConnected = function tarjanStronglyConnected2() { + var eles = this; + var nodes2 = {}; + var index = 0; + var components = []; + var stack = []; + var cut = eles.spawn(eles); + var stronglyConnectedSearch = function stronglyConnectedSearch2(sourceNodeId) { + stack.push(sourceNodeId); + nodes2[sourceNodeId] = { + index, + low: index++, + explored: false + }; + var connectedEdges = eles.getElementById(sourceNodeId).connectedEdges().intersection(eles); + connectedEdges.forEach(function(edge) { + var targetNodeId = edge.target().id(); + if (targetNodeId !== sourceNodeId) { + if (!(targetNodeId in nodes2)) { + stronglyConnectedSearch2(targetNodeId); + } + if (!nodes2[targetNodeId].explored) { + nodes2[sourceNodeId].low = Math.min(nodes2[sourceNodeId].low, nodes2[targetNodeId].low); + } + } + }); + if (nodes2[sourceNodeId].index === nodes2[sourceNodeId].low) { + var componentNodes = eles.spawn(); + for (; ; ) { + var nodeId = stack.pop(); + componentNodes.merge(eles.getElementById(nodeId)); + nodes2[nodeId].low = nodes2[sourceNodeId].index; + nodes2[nodeId].explored = true; + if (nodeId === sourceNodeId) { + break; + } + } + var componentEdges = componentNodes.edgesWith(componentNodes); + var component = componentNodes.merge(componentEdges); + components.push(component); + cut = cut.difference(component); + } + }; + eles.forEach(function(ele) { + if (ele.isNode()) { + var nodeId = ele.id(); + if (!(nodeId in nodes2)) { + stronglyConnectedSearch(nodeId); + } + } + }); + return { + cut, + components + }; + }; + var tarjanStronglyConnected$1 = { + tarjanStronglyConnected, + tsc: tarjanStronglyConnected, + tscc: tarjanStronglyConnected, + tarjanStronglyConnectedComponents: tarjanStronglyConnected + }; + var elesfn$j = {}; + [elesfn$v, elesfn$u, elesfn$t, elesfn$s, elesfn$r, elesfn$q, elesfn$p, elesfn$o, elesfn$n, elesfn$m, elesfn$l, markovClustering$1, kClustering, hierarchicalClustering$1, affinityPropagation$1, elesfn$k, hopcroftTarjanBiconnected$1, tarjanStronglyConnected$1].forEach(function(props) { + extend(elesfn$j, props); + }); + /*! + Embeddable Minimum Strictly-Compliant Promises/A+ 1.1.1 Thenable + Copyright (c) 2013-2014 Ralf S. Engelschall (http://engelschall.com) + Licensed under The MIT License (http://opensource.org/licenses/MIT) + */ + var STATE_PENDING = 0; + var STATE_FULFILLED = 1; + var STATE_REJECTED = 2; + var api = function api2(executor) { + if (!(this instanceof api2)) + return new api2(executor); + this.id = "Thenable/1.0.7"; + this.state = STATE_PENDING; + this.fulfillValue = void 0; + this.rejectReason = void 0; + this.onFulfilled = []; + this.onRejected = []; + this.proxy = { + then: this.then.bind(this) + }; + if (typeof executor === "function") + executor.call(this, this.fulfill.bind(this), this.reject.bind(this)); + }; + api.prototype = { + /* promise resolving methods */ + fulfill: function fulfill(value) { + return deliver(this, STATE_FULFILLED, "fulfillValue", value); + }, + reject: function reject(value) { + return deliver(this, STATE_REJECTED, "rejectReason", value); + }, + /* "The then Method" [Promises/A+ 1.1, 1.2, 2.2] */ + then: function then(onFulfilled, onRejected) { + var curr = this; + var next2 = new api(); + curr.onFulfilled.push(resolver(onFulfilled, next2, "fulfill")); + curr.onRejected.push(resolver(onRejected, next2, "reject")); + execute(curr); + return next2.proxy; + } + }; + var deliver = function deliver2(curr, state, name, value) { + if (curr.state === STATE_PENDING) { + curr.state = state; + curr[name] = value; + execute(curr); + } + return curr; + }; + var execute = function execute2(curr) { + if (curr.state === STATE_FULFILLED) + execute_handlers(curr, "onFulfilled", curr.fulfillValue); + else if (curr.state === STATE_REJECTED) + execute_handlers(curr, "onRejected", curr.rejectReason); + }; + var execute_handlers = function execute_handlers2(curr, name, value) { + if (curr[name].length === 0) + return; + var handlers = curr[name]; + curr[name] = []; + var func = function func2() { + for (var i2 = 0; i2 < handlers.length; i2++) { + handlers[i2](value); + } + }; + if (typeof setImmediate === "function") + setImmediate(func); + else + setTimeout(func, 0); + }; + var resolver = function resolver2(cb, next2, method) { + return function(value) { + if (typeof cb !== "function") + next2[method].call(next2, value); + else { + var result; + try { + result = cb(value); + } catch (e) { + next2.reject(e); + return; + } + resolve(next2, result); + } + }; + }; + var resolve = function resolve2(promise2, x) { + if (promise2 === x || promise2.proxy === x) { + promise2.reject(new TypeError("cannot resolve promise with itself")); + return; + } + var then; + if (_typeof(x) === "object" && x !== null || typeof x === "function") { + try { + then = x.then; + } catch (e) { + promise2.reject(e); + return; + } + } + if (typeof then === "function") { + var resolved = false; + try { + then.call( + x, + /* resolvePromise */ + /* [Promises/A+ 2.3.3.3.1] */ + function(y) { + if (resolved) + return; + resolved = true; + if (y === x) + promise2.reject(new TypeError("circular thenable chain")); + else + resolve2(promise2, y); + }, + /* rejectPromise */ + /* [Promises/A+ 2.3.3.3.2] */ + function(r) { + if (resolved) + return; + resolved = true; + promise2.reject(r); + } + ); + } catch (e) { + if (!resolved) + promise2.reject(e); + } + return; + } + promise2.fulfill(x); + }; + api.all = function(ps) { + return new api(function(resolveAll, rejectAll) { + var vals = new Array(ps.length); + var doneCount = 0; + var fulfill = function fulfill2(i3, val) { + vals[i3] = val; + doneCount++; + if (doneCount === ps.length) { + resolveAll(vals); + } + }; + for (var i2 = 0; i2 < ps.length; i2++) { + (function(i3) { + var p2 = ps[i3]; + var isPromise = p2 != null && p2.then != null; + if (isPromise) { + p2.then(function(val2) { + fulfill(i3, val2); + }, function(err) { + rejectAll(err); + }); + } else { + var val = p2; + fulfill(i3, val); + } + })(i2); + } + }); + }; + api.resolve = function(val) { + return new api(function(resolve2, reject) { + resolve2(val); + }); + }; + api.reject = function(val) { + return new api(function(resolve2, reject) { + reject(val); + }); + }; + var Promise$1 = typeof Promise !== "undefined" ? Promise : api; + var Animation = function Animation2(target, opts, opts2) { + var isCore = core(target); + var isEle = !isCore; + var _p = this._private = extend({ + duration: 1e3 + }, opts, opts2); + _p.target = target; + _p.style = _p.style || _p.css; + _p.started = false; + _p.playing = false; + _p.hooked = false; + _p.applying = false; + _p.progress = 0; + _p.completes = []; + _p.frames = []; + if (_p.complete && fn$6(_p.complete)) { + _p.completes.push(_p.complete); + } + if (isEle) { + var pos = target.position(); + _p.startPosition = _p.startPosition || { + x: pos.x, + y: pos.y + }; + _p.startStyle = _p.startStyle || target.cy().style().getAnimationStartStyle(target, _p.style); + } + if (isCore) { + var pan = target.pan(); + _p.startPan = { + x: pan.x, + y: pan.y + }; + _p.startZoom = target.zoom(); + } + this.length = 1; + this[0] = this; + }; + var anifn = Animation.prototype; + extend(anifn, { + instanceString: function instanceString() { + return "animation"; + }, + hook: function hook() { + var _p = this._private; + if (!_p.hooked) { + var q; + var tAni = _p.target._private.animation; + if (_p.queue) { + q = tAni.queue; + } else { + q = tAni.current; + } + q.push(this); + if (elementOrCollection(_p.target)) { + _p.target.cy().addToAnimationPool(_p.target); + } + _p.hooked = true; + } + return this; + }, + play: function play() { + var _p = this._private; + if (_p.progress === 1) { + _p.progress = 0; + } + _p.playing = true; + _p.started = false; + _p.stopped = false; + this.hook(); + return this; + }, + playing: function playing() { + return this._private.playing; + }, + apply: function apply() { + var _p = this._private; + _p.applying = true; + _p.started = false; + _p.stopped = false; + this.hook(); + return this; + }, + applying: function applying() { + return this._private.applying; + }, + pause: function pause() { + var _p = this._private; + _p.playing = false; + _p.started = false; + return this; + }, + stop: function stop() { + var _p = this._private; + _p.playing = false; + _p.started = false; + _p.stopped = true; + return this; + }, + rewind: function rewind() { + return this.progress(0); + }, + fastforward: function fastforward() { + return this.progress(1); + }, + time: function time(t) { + var _p = this._private; + if (t === void 0) { + return _p.progress * _p.duration; + } else { + return this.progress(t / _p.duration); + } + }, + progress: function progress(p2) { + var _p = this._private; + var wasPlaying = _p.playing; + if (p2 === void 0) { + return _p.progress; + } else { + if (wasPlaying) { + this.pause(); + } + _p.progress = p2; + _p.started = false; + if (wasPlaying) { + this.play(); + } + } + return this; + }, + completed: function completed() { + return this._private.progress === 1; + }, + reverse: function reverse() { + var _p = this._private; + var wasPlaying = _p.playing; + if (wasPlaying) { + this.pause(); + } + _p.progress = 1 - _p.progress; + _p.started = false; + var swap = function swap2(a, b) { + var _pa = _p[a]; + if (_pa == null) { + return; + } + _p[a] = _p[b]; + _p[b] = _pa; + }; + swap("zoom", "startZoom"); + swap("pan", "startPan"); + swap("position", "startPosition"); + if (_p.style) { + for (var i2 = 0; i2 < _p.style.length; i2++) { + var prop = _p.style[i2]; + var name = prop.name; + var startStyleProp = _p.startStyle[name]; + _p.startStyle[name] = prop; + _p.style[i2] = startStyleProp; + } + } + if (wasPlaying) { + this.play(); + } + return this; + }, + promise: function promise2(type) { + var _p = this._private; + var arr; + switch (type) { + case "frame": + arr = _p.frames; + break; + default: + case "complete": + case "completed": + arr = _p.completes; + } + return new Promise$1(function(resolve2, reject) { + arr.push(function() { + resolve2(); + }); + }); + } + }); + anifn.complete = anifn.completed; + anifn.run = anifn.play; + anifn.running = anifn.playing; + var define$3 = { + animated: function animated() { + return function animatedImpl() { + var self2 = this; + var selfIsArrayLike = self2.length !== void 0; + var all = selfIsArrayLike ? self2 : [self2]; + var cy = this._private.cy || this; + if (!cy.styleEnabled()) { + return false; + } + var ele = all[0]; + if (ele) { + return ele._private.animation.current.length > 0; + } + }; + }, + // animated + clearQueue: function clearQueue() { + return function clearQueueImpl() { + var self2 = this; + var selfIsArrayLike = self2.length !== void 0; + var all = selfIsArrayLike ? self2 : [self2]; + var cy = this._private.cy || this; + if (!cy.styleEnabled()) { + return this; + } + for (var i2 = 0; i2 < all.length; i2++) { + var ele = all[i2]; + ele._private.animation.queue = []; + } + return this; + }; + }, + // clearQueue + delay: function delay() { + return function delayImpl(time, complete) { + var cy = this._private.cy || this; + if (!cy.styleEnabled()) { + return this; + } + return this.animate({ + delay: time, + duration: time, + complete + }); + }; + }, + // delay + delayAnimation: function delayAnimation() { + return function delayAnimationImpl(time, complete) { + var cy = this._private.cy || this; + if (!cy.styleEnabled()) { + return this; + } + return this.animation({ + delay: time, + duration: time, + complete + }); + }; + }, + // delay + animation: function animation() { + return function animationImpl(properties, params) { + var self2 = this; + var selfIsArrayLike = self2.length !== void 0; + var all = selfIsArrayLike ? self2 : [self2]; + var cy = this._private.cy || this; + var isCore = !selfIsArrayLike; + var isEles = !isCore; + if (!cy.styleEnabled()) { + return this; + } + var style = cy.style(); + properties = extend({}, properties, params); + var propertiesEmpty = Object.keys(properties).length === 0; + if (propertiesEmpty) { + return new Animation(all[0], properties); + } + if (properties.duration === void 0) { + properties.duration = 400; + } + switch (properties.duration) { + case "slow": + properties.duration = 600; + break; + case "fast": + properties.duration = 200; + break; + } + if (isEles) { + properties.style = style.getPropsList(properties.style || properties.css); + properties.css = void 0; + } + if (isEles && properties.renderedPosition != null) { + var rpos = properties.renderedPosition; + var pan = cy.pan(); + var zoom = cy.zoom(); + properties.position = renderedToModelPosition(rpos, zoom, pan); + } + if (isCore && properties.panBy != null) { + var panBy = properties.panBy; + var cyPan = cy.pan(); + properties.pan = { + x: cyPan.x + panBy.x, + y: cyPan.y + panBy.y + }; + } + var center = properties.center || properties.centre; + if (isCore && center != null) { + var centerPan = cy.getCenterPan(center.eles, properties.zoom); + if (centerPan != null) { + properties.pan = centerPan; + } + } + if (isCore && properties.fit != null) { + var fit = properties.fit; + var fitVp = cy.getFitViewport(fit.eles || fit.boundingBox, fit.padding); + if (fitVp != null) { + properties.pan = fitVp.pan; + properties.zoom = fitVp.zoom; + } + } + if (isCore && plainObject(properties.zoom)) { + var vp = cy.getZoomedViewport(properties.zoom); + if (vp != null) { + if (vp.zoomed) { + properties.zoom = vp.zoom; + } + if (vp.panned) { + properties.pan = vp.pan; + } + } else { + properties.zoom = null; + } + } + return new Animation(all[0], properties); + }; + }, + // animate + animate: function animate() { + return function animateImpl(properties, params) { + var self2 = this; + var selfIsArrayLike = self2.length !== void 0; + var all = selfIsArrayLike ? self2 : [self2]; + var cy = this._private.cy || this; + if (!cy.styleEnabled()) { + return this; + } + if (params) { + properties = extend({}, properties, params); + } + for (var i2 = 0; i2 < all.length; i2++) { + var ele = all[i2]; + var queue = ele.animated() && (properties.queue === void 0 || properties.queue); + var ani = ele.animation(properties, queue ? { + queue: true + } : void 0); + ani.play(); + } + return this; + }; + }, + // animate + stop: function stop() { + return function stopImpl(clearQueue, jumpToEnd) { + var self2 = this; + var selfIsArrayLike = self2.length !== void 0; + var all = selfIsArrayLike ? self2 : [self2]; + var cy = this._private.cy || this; + if (!cy.styleEnabled()) { + return this; + } + for (var i2 = 0; i2 < all.length; i2++) { + var ele = all[i2]; + var _p = ele._private; + var anis = _p.animation.current; + for (var j = 0; j < anis.length; j++) { + var ani = anis[j]; + var ani_p = ani._private; + if (jumpToEnd) { + ani_p.duration = 0; + } + } + if (clearQueue) { + _p.animation.queue = []; + } + if (!jumpToEnd) { + _p.animation.current = []; + } + } + cy.notify("draw"); + return this; + }; + } + // stop + }; + var isArray = Array.isArray; + var isArray_1 = isArray; + var reIsDeepProp = /\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/, reIsPlainProp = /^\w*$/; + function isKey(value, object2) { + if (isArray_1(value)) { + return false; + } + var type = typeof value; + if (type == "number" || type == "symbol" || type == "boolean" || value == null || isSymbol_1(value)) { + return true; + } + return reIsPlainProp.test(value) || !reIsDeepProp.test(value) || object2 != null && value in Object(object2); + } + var _isKey = isKey; + var asyncTag = "[object AsyncFunction]", funcTag = "[object Function]", genTag = "[object GeneratorFunction]", proxyTag = "[object Proxy]"; + function isFunction(value) { + if (!isObject_1(value)) { + return false; + } + var tag = _baseGetTag(value); + return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag; + } + var isFunction_1 = isFunction; + var coreJsData = _root["__core-js_shared__"]; + var _coreJsData = coreJsData; + var maskSrcKey = function() { + var uid = /[^.]+$/.exec(_coreJsData && _coreJsData.keys && _coreJsData.keys.IE_PROTO || ""); + return uid ? "Symbol(src)_1." + uid : ""; + }(); + function isMasked(func) { + return !!maskSrcKey && maskSrcKey in func; + } + var _isMasked = isMasked; + var funcProto$1 = Function.prototype; + var funcToString$1 = funcProto$1.toString; + function toSource(func) { + if (func != null) { + try { + return funcToString$1.call(func); + } catch (e) { + } + try { + return func + ""; + } catch (e) { + } + } + return ""; + } + var _toSource = toSource; + var reRegExpChar = /[\\^$.*+?()[\]{}|]/g; + var reIsHostCtor = /^\[object .+?Constructor\]$/; + var funcProto = Function.prototype, objectProto$3 = Object.prototype; + var funcToString = funcProto.toString; + var hasOwnProperty$3 = objectProto$3.hasOwnProperty; + var reIsNative = RegExp( + "^" + funcToString.call(hasOwnProperty$3).replace(reRegExpChar, "\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g, "$1.*?") + "$" + ); + function baseIsNative(value) { + if (!isObject_1(value) || _isMasked(value)) { + return false; + } + var pattern = isFunction_1(value) ? reIsNative : reIsHostCtor; + return pattern.test(_toSource(value)); + } + var _baseIsNative = baseIsNative; + function getValue$1(object2, key) { + return object2 == null ? void 0 : object2[key]; + } + var _getValue = getValue$1; + function getNative(object2, key) { + var value = _getValue(object2, key); + return _baseIsNative(value) ? value : void 0; + } + var _getNative = getNative; + var nativeCreate = _getNative(Object, "create"); + var _nativeCreate = nativeCreate; + function hashClear() { + this.__data__ = _nativeCreate ? _nativeCreate(null) : {}; + this.size = 0; + } + var _hashClear = hashClear; + function hashDelete(key) { + var result = this.has(key) && delete this.__data__[key]; + this.size -= result ? 1 : 0; + return result; + } + var _hashDelete = hashDelete; + var HASH_UNDEFINED$1 = "__lodash_hash_undefined__"; + var objectProto$2 = Object.prototype; + var hasOwnProperty$2 = objectProto$2.hasOwnProperty; + function hashGet(key) { + var data2 = this.__data__; + if (_nativeCreate) { + var result = data2[key]; + return result === HASH_UNDEFINED$1 ? void 0 : result; + } + return hasOwnProperty$2.call(data2, key) ? data2[key] : void 0; + } + var _hashGet = hashGet; + var objectProto$1 = Object.prototype; + var hasOwnProperty$1 = objectProto$1.hasOwnProperty; + function hashHas(key) { + var data2 = this.__data__; + return _nativeCreate ? data2[key] !== void 0 : hasOwnProperty$1.call(data2, key); + } + var _hashHas = hashHas; + var HASH_UNDEFINED = "__lodash_hash_undefined__"; + function hashSet(key, value) { + var data2 = this.__data__; + this.size += this.has(key) ? 0 : 1; + data2[key] = _nativeCreate && value === void 0 ? HASH_UNDEFINED : value; + return this; + } + var _hashSet = hashSet; + function Hash(entries) { + var index = -1, length = entries == null ? 0 : entries.length; + this.clear(); + while (++index < length) { + var entry = entries[index]; + this.set(entry[0], entry[1]); + } + } + Hash.prototype.clear = _hashClear; + Hash.prototype["delete"] = _hashDelete; + Hash.prototype.get = _hashGet; + Hash.prototype.has = _hashHas; + Hash.prototype.set = _hashSet; + var _Hash = Hash; + function listCacheClear() { + this.__data__ = []; + this.size = 0; + } + var _listCacheClear = listCacheClear; + function eq(value, other) { + return value === other || value !== value && other !== other; + } + var eq_1 = eq; + function assocIndexOf(array2, key) { + var length = array2.length; + while (length--) { + if (eq_1(array2[length][0], key)) { + return length; + } + } + return -1; + } + var _assocIndexOf = assocIndexOf; + var arrayProto = Array.prototype; + var splice = arrayProto.splice; + function listCacheDelete(key) { + var data2 = this.__data__, index = _assocIndexOf(data2, key); + if (index < 0) { + return false; + } + var lastIndex = data2.length - 1; + if (index == lastIndex) { + data2.pop(); + } else { + splice.call(data2, index, 1); + } + --this.size; + return true; + } + var _listCacheDelete = listCacheDelete; + function listCacheGet(key) { + var data2 = this.__data__, index = _assocIndexOf(data2, key); + return index < 0 ? void 0 : data2[index][1]; + } + var _listCacheGet = listCacheGet; + function listCacheHas(key) { + return _assocIndexOf(this.__data__, key) > -1; + } + var _listCacheHas = listCacheHas; + function listCacheSet(key, value) { + var data2 = this.__data__, index = _assocIndexOf(data2, key); + if (index < 0) { + ++this.size; + data2.push([key, value]); + } else { + data2[index][1] = value; + } + return this; + } + var _listCacheSet = listCacheSet; + function ListCache(entries) { + var index = -1, length = entries == null ? 0 : entries.length; + this.clear(); + while (++index < length) { + var entry = entries[index]; + this.set(entry[0], entry[1]); + } + } + ListCache.prototype.clear = _listCacheClear; + ListCache.prototype["delete"] = _listCacheDelete; + ListCache.prototype.get = _listCacheGet; + ListCache.prototype.has = _listCacheHas; + ListCache.prototype.set = _listCacheSet; + var _ListCache = ListCache; + var Map$1 = _getNative(_root, "Map"); + var _Map = Map$1; + function mapCacheClear() { + this.size = 0; + this.__data__ = { + "hash": new _Hash(), + "map": new (_Map || _ListCache)(), + "string": new _Hash() + }; + } + var _mapCacheClear = mapCacheClear; + function isKeyable(value) { + var type = typeof value; + return type == "string" || type == "number" || type == "symbol" || type == "boolean" ? value !== "__proto__" : value === null; + } + var _isKeyable = isKeyable; + function getMapData(map, key) { + var data2 = map.__data__; + return _isKeyable(key) ? data2[typeof key == "string" ? "string" : "hash"] : data2.map; + } + var _getMapData = getMapData; + function mapCacheDelete(key) { + var result = _getMapData(this, key)["delete"](key); + this.size -= result ? 1 : 0; + return result; + } + var _mapCacheDelete = mapCacheDelete; + function mapCacheGet(key) { + return _getMapData(this, key).get(key); + } + var _mapCacheGet = mapCacheGet; + function mapCacheHas(key) { + return _getMapData(this, key).has(key); + } + var _mapCacheHas = mapCacheHas; + function mapCacheSet(key, value) { + var data2 = _getMapData(this, key), size = data2.size; + data2.set(key, value); + this.size += data2.size == size ? 0 : 1; + return this; + } + var _mapCacheSet = mapCacheSet; + function MapCache(entries) { + var index = -1, length = entries == null ? 0 : entries.length; + this.clear(); + while (++index < length) { + var entry = entries[index]; + this.set(entry[0], entry[1]); + } + } + MapCache.prototype.clear = _mapCacheClear; + MapCache.prototype["delete"] = _mapCacheDelete; + MapCache.prototype.get = _mapCacheGet; + MapCache.prototype.has = _mapCacheHas; + MapCache.prototype.set = _mapCacheSet; + var _MapCache = MapCache; + var FUNC_ERROR_TEXT = "Expected a function"; + function memoize(func, resolver2) { + if (typeof func != "function" || resolver2 != null && typeof resolver2 != "function") { + throw new TypeError(FUNC_ERROR_TEXT); + } + var memoized = function() { + var args = arguments, key = resolver2 ? resolver2.apply(this, args) : args[0], cache2 = memoized.cache; + if (cache2.has(key)) { + return cache2.get(key); + } + var result = func.apply(this, args); + memoized.cache = cache2.set(key, result) || cache2; + return result; + }; + memoized.cache = new (memoize.Cache || _MapCache)(); + return memoized; + } + memoize.Cache = _MapCache; + var memoize_1 = memoize; + var MAX_MEMOIZE_SIZE = 500; + function memoizeCapped(func) { + var result = memoize_1(func, function(key) { + if (cache2.size === MAX_MEMOIZE_SIZE) { + cache2.clear(); + } + return key; + }); + var cache2 = result.cache; + return result; + } + var _memoizeCapped = memoizeCapped; + var rePropName = /[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g; + var reEscapeChar = /\\(\\)?/g; + var stringToPath = _memoizeCapped(function(string2) { + var result = []; + if (string2.charCodeAt(0) === 46) { + result.push(""); + } + string2.replace(rePropName, function(match2, number2, quote, subString) { + result.push(quote ? subString.replace(reEscapeChar, "$1") : number2 || match2); + }); + return result; + }); + var _stringToPath = stringToPath; + function arrayMap(array2, iteratee) { + var index = -1, length = array2 == null ? 0 : array2.length, result = Array(length); + while (++index < length) { + result[index] = iteratee(array2[index], index, array2); + } + return result; + } + var _arrayMap = arrayMap; + var INFINITY$1 = 1 / 0; + var symbolProto = _Symbol ? _Symbol.prototype : void 0, symbolToString = symbolProto ? symbolProto.toString : void 0; + function baseToString(value) { + if (typeof value == "string") { + return value; + } + if (isArray_1(value)) { + return _arrayMap(value, baseToString) + ""; + } + if (isSymbol_1(value)) { + return symbolToString ? symbolToString.call(value) : ""; + } + var result = value + ""; + return result == "0" && 1 / value == -INFINITY$1 ? "-0" : result; + } + var _baseToString = baseToString; + function toString$1(value) { + return value == null ? "" : _baseToString(value); + } + var toString_1 = toString$1; + function castPath(value, object2) { + if (isArray_1(value)) { + return value; + } + return _isKey(value, object2) ? [value] : _stringToPath(toString_1(value)); + } + var _castPath = castPath; + var INFINITY = 1 / 0; + function toKey(value) { + if (typeof value == "string" || isSymbol_1(value)) { + return value; + } + var result = value + ""; + return result == "0" && 1 / value == -INFINITY ? "-0" : result; + } + var _toKey = toKey; + function baseGet(object2, path) { + path = _castPath(path, object2); + var index = 0, length = path.length; + while (object2 != null && index < length) { + object2 = object2[_toKey(path[index++])]; + } + return index && index == length ? object2 : void 0; + } + var _baseGet = baseGet; + function get(object2, path, defaultValue) { + var result = object2 == null ? void 0 : _baseGet(object2, path); + return result === void 0 ? defaultValue : result; + } + var get_1 = get; + var defineProperty = function() { + try { + var func = _getNative(Object, "defineProperty"); + func({}, "", {}); + return func; + } catch (e) { + } + }(); + var _defineProperty = defineProperty; + function baseAssignValue(object2, key, value) { + if (key == "__proto__" && _defineProperty) { + _defineProperty(object2, key, { + "configurable": true, + "enumerable": true, + "value": value, + "writable": true + }); + } else { + object2[key] = value; + } + } + var _baseAssignValue = baseAssignValue; + var objectProto = Object.prototype; + var hasOwnProperty = objectProto.hasOwnProperty; + function assignValue(object2, key, value) { + var objValue = object2[key]; + if (!(hasOwnProperty.call(object2, key) && eq_1(objValue, value)) || value === void 0 && !(key in object2)) { + _baseAssignValue(object2, key, value); + } + } + var _assignValue = assignValue; + var MAX_SAFE_INTEGER = 9007199254740991; + var reIsUint = /^(?:0|[1-9]\d*)$/; + function isIndex(value, length) { + var type = typeof value; + length = length == null ? MAX_SAFE_INTEGER : length; + return !!length && (type == "number" || type != "symbol" && reIsUint.test(value)) && (value > -1 && value % 1 == 0 && value < length); + } + var _isIndex = isIndex; + function baseSet(object2, path, value, customizer) { + if (!isObject_1(object2)) { + return object2; + } + path = _castPath(path, object2); + var index = -1, length = path.length, lastIndex = length - 1, nested = object2; + while (nested != null && ++index < length) { + var key = _toKey(path[index]), newValue = value; + if (key === "__proto__" || key === "constructor" || key === "prototype") { + return object2; + } + if (index != lastIndex) { + var objValue = nested[key]; + newValue = customizer ? customizer(objValue, key, nested) : void 0; + if (newValue === void 0) { + newValue = isObject_1(objValue) ? objValue : _isIndex(path[index + 1]) ? [] : {}; + } + } + _assignValue(nested, key, newValue); + nested = nested[key]; + } + return object2; + } + var _baseSet = baseSet; + function set(object2, path, value) { + return object2 == null ? object2 : _baseSet(object2, path, value); + } + var set_1 = set; + function copyArray(source, array2) { + var index = -1, length = source.length; + array2 || (array2 = Array(length)); + while (++index < length) { + array2[index] = source[index]; + } + return array2; + } + var _copyArray = copyArray; + function toPath(value) { + if (isArray_1(value)) { + return _arrayMap(value, _toKey); + } + return isSymbol_1(value) ? [value] : _copyArray(_stringToPath(toString_1(value))); + } + var toPath_1 = toPath; + var define$2 = { + // access data field + data: function data2(params) { + var defaults2 = { + field: "data", + bindingEvent: "data", + allowBinding: false, + allowSetting: false, + allowGetting: false, + settingEvent: "data", + settingTriggersEvent: false, + triggerFnName: "trigger", + immutableKeys: {}, + // key => true if immutable + updateStyle: false, + beforeGet: function beforeGet(self2) { + }, + beforeSet: function beforeSet(self2, obj) { + }, + onSet: function onSet(self2) { + }, + canSet: function canSet(self2) { + return true; + } + }; + params = extend({}, defaults2, params); + return function dataImpl(name, value) { + var p2 = params; + var self2 = this; + var selfIsArrayLike = self2.length !== void 0; + var all = selfIsArrayLike ? self2 : [self2]; + var single = selfIsArrayLike ? self2[0] : self2; + if (string(name)) { + var isPathLike = name.indexOf(".") !== -1; + var path = isPathLike && toPath_1(name); + if (p2.allowGetting && value === void 0) { + var ret; + if (single) { + p2.beforeGet(single); + if (path && single._private[p2.field][name] === void 0) { + ret = get_1(single._private[p2.field], path); + } else { + ret = single._private[p2.field][name]; + } + } + return ret; + } else if (p2.allowSetting && value !== void 0) { + var valid2 = !p2.immutableKeys[name]; + if (valid2) { + var change = _defineProperty$1({}, name, value); + p2.beforeSet(self2, change); + for (var i2 = 0, l = all.length; i2 < l; i2++) { + var ele = all[i2]; + if (p2.canSet(ele)) { + if (path && single._private[p2.field][name] === void 0) { + set_1(ele._private[p2.field], path, value); + } else { + ele._private[p2.field][name] = value; + } + } + } + if (p2.updateStyle) { + self2.updateStyle(); + } + p2.onSet(self2); + if (p2.settingTriggersEvent) { + self2[p2.triggerFnName](p2.settingEvent); + } + } + } + } else if (p2.allowSetting && plainObject(name)) { + var obj = name; + var k, v; + var keys = Object.keys(obj); + p2.beforeSet(self2, obj); + for (var _i = 0; _i < keys.length; _i++) { + k = keys[_i]; + v = obj[k]; + var _valid = !p2.immutableKeys[k]; + if (_valid) { + for (var j = 0; j < all.length; j++) { + var _ele = all[j]; + if (p2.canSet(_ele)) { + _ele._private[p2.field][k] = v; + } + } + } + } + if (p2.updateStyle) { + self2.updateStyle(); + } + p2.onSet(self2); + if (p2.settingTriggersEvent) { + self2[p2.triggerFnName](p2.settingEvent); + } + } else if (p2.allowBinding && fn$6(name)) { + var fn2 = name; + self2.on(p2.bindingEvent, fn2); + } else if (p2.allowGetting && name === void 0) { + var _ret; + if (single) { + p2.beforeGet(single); + _ret = single._private[p2.field]; + } + return _ret; + } + return self2; + }; + }, + // data + // remove data field + removeData: function removeData(params) { + var defaults2 = { + field: "data", + event: "data", + triggerFnName: "trigger", + triggerEvent: false, + immutableKeys: {} + // key => true if immutable + }; + params = extend({}, defaults2, params); + return function removeDataImpl(names) { + var p2 = params; + var self2 = this; + var selfIsArrayLike = self2.length !== void 0; + var all = selfIsArrayLike ? self2 : [self2]; + if (string(names)) { + var keys = names.split(/\s+/); + var l = keys.length; + for (var i2 = 0; i2 < l; i2++) { + var key = keys[i2]; + if (emptyString(key)) { + continue; + } + var valid2 = !p2.immutableKeys[key]; + if (valid2) { + for (var i_a = 0, l_a = all.length; i_a < l_a; i_a++) { + all[i_a]._private[p2.field][key] = void 0; + } + } + } + if (p2.triggerEvent) { + self2[p2.triggerFnName](p2.event); + } + } else if (names === void 0) { + for (var _i_a = 0, _l_a = all.length; _i_a < _l_a; _i_a++) { + var _privateFields = all[_i_a]._private[p2.field]; + var _keys = Object.keys(_privateFields); + for (var _i2 = 0; _i2 < _keys.length; _i2++) { + var _key = _keys[_i2]; + var validKeyToDelete = !p2.immutableKeys[_key]; + if (validKeyToDelete) { + _privateFields[_key] = void 0; + } + } + } + if (p2.triggerEvent) { + self2[p2.triggerFnName](p2.event); + } + } + return self2; + }; + } + // removeData + }; + var define$1 = { + eventAliasesOn: function eventAliasesOn(proto) { + var p2 = proto; + p2.addListener = p2.listen = p2.bind = p2.on; + p2.unlisten = p2.unbind = p2.off = p2.removeListener; + p2.trigger = p2.emit; + p2.pon = p2.promiseOn = function(events, selector) { + var self2 = this; + var args = Array.prototype.slice.call(arguments, 0); + return new Promise$1(function(resolve2, reject) { + var callback = function callback2(e) { + self2.off.apply(self2, offArgs); + resolve2(e); + }; + var onArgs = args.concat([callback]); + var offArgs = onArgs.concat([]); + self2.on.apply(self2, onArgs); + }); + }; + } + }; + var define = {}; + [define$3, define$2, define$1].forEach(function(m) { + extend(define, m); + }); + var elesfn$i = { + animate: define.animate(), + animation: define.animation(), + animated: define.animated(), + clearQueue: define.clearQueue(), + delay: define.delay(), + delayAnimation: define.delayAnimation(), + stop: define.stop() + }; + var elesfn$h = { + classes: function classes(_classes) { + var self2 = this; + if (_classes === void 0) { + var ret = []; + self2[0]._private.classes.forEach(function(cls2) { + return ret.push(cls2); + }); + return ret; + } else if (!array(_classes)) { + _classes = (_classes || "").match(/\S+/g) || []; + } + var changed = []; + var classesSet = new Set$1(_classes); + for (var j = 0; j < self2.length; j++) { + var ele = self2[j]; + var _p = ele._private; + var eleClasses = _p.classes; + var changedEle = false; + for (var i2 = 0; i2 < _classes.length; i2++) { + var cls = _classes[i2]; + var eleHasClass = eleClasses.has(cls); + if (!eleHasClass) { + changedEle = true; + break; + } + } + if (!changedEle) { + changedEle = eleClasses.size !== _classes.length; + } + if (changedEle) { + _p.classes = classesSet; + changed.push(ele); + } + } + if (changed.length > 0) { + this.spawn(changed).updateStyle().emit("class"); + } + return self2; + }, + addClass: function addClass(classes) { + return this.toggleClass(classes, true); + }, + hasClass: function hasClass(className) { + var ele = this[0]; + return ele != null && ele._private.classes.has(className); + }, + toggleClass: function toggleClass(classes, toggle) { + if (!array(classes)) { + classes = classes.match(/\S+/g) || []; + } + var self2 = this; + var toggleUndefd = toggle === void 0; + var changed = []; + for (var i2 = 0, il = self2.length; i2 < il; i2++) { + var ele = self2[i2]; + var eleClasses = ele._private.classes; + var changedEle = false; + for (var j = 0; j < classes.length; j++) { + var cls = classes[j]; + var hasClass = eleClasses.has(cls); + var changedNow = false; + if (toggle || toggleUndefd && !hasClass) { + eleClasses.add(cls); + changedNow = true; + } else if (!toggle || toggleUndefd && hasClass) { + eleClasses["delete"](cls); + changedNow = true; + } + if (!changedEle && changedNow) { + changed.push(ele); + changedEle = true; + } + } + } + if (changed.length > 0) { + this.spawn(changed).updateStyle().emit("class"); + } + return self2; + }, + removeClass: function removeClass(classes) { + return this.toggleClass(classes, false); + }, + flashClass: function flashClass(classes, duration) { + var self2 = this; + if (duration == null) { + duration = 250; + } else if (duration === 0) { + return self2; + } + self2.addClass(classes); + setTimeout(function() { + self2.removeClass(classes); + }, duration); + return self2; + } + }; + elesfn$h.className = elesfn$h.classNames = elesfn$h.classes; + var tokens = { + metaChar: "[\\!\\\"\\#\\$\\%\\&\\'\\(\\)\\*\\+\\,\\.\\/\\:\\;\\<\\=\\>\\?\\@\\[\\]\\^\\`\\{\\|\\}\\~]", + // chars we need to escape in let names, etc + comparatorOp: "=|\\!=|>|>=|<|<=|\\$=|\\^=|\\*=", + // binary comparison op (used in data selectors) + boolOp: "\\?|\\!|\\^", + // boolean (unary) operators (used in data selectors) + string: `"(?:\\\\"|[^"])*"|'(?:\\\\'|[^'])*'`, + // string literals (used in data selectors) -- doublequotes | singlequotes + number, + // number literal (used in data selectors) --- e.g. 0.1234, 1234, 12e123 + meta: "degree|indegree|outdegree", + // allowed metadata fields (i.e. allowed functions to use from Collection) + separator: "\\s*,\\s*", + // queries are separated by commas, e.g. edge[foo = 'bar'], node.someClass + descendant: "\\s+", + child: "\\s+>\\s+", + subject: "\\$", + group: "node|edge|\\*", + directedEdge: "\\s+->\\s+", + undirectedEdge: "\\s+<->\\s+" + }; + tokens.variable = "(?:[\\w-.]|(?:\\\\" + tokens.metaChar + "))+"; + tokens.className = "(?:[\\w-]|(?:\\\\" + tokens.metaChar + "))+"; + tokens.value = tokens.string + "|" + tokens.number; + tokens.id = tokens.variable; + (function() { + var ops, op, i2; + ops = tokens.comparatorOp.split("|"); + for (i2 = 0; i2 < ops.length; i2++) { + op = ops[i2]; + tokens.comparatorOp += "|@" + op; + } + ops = tokens.comparatorOp.split("|"); + for (i2 = 0; i2 < ops.length; i2++) { + op = ops[i2]; + if (op.indexOf("!") >= 0) { + continue; + } + if (op === "=") { + continue; + } + tokens.comparatorOp += "|\\!" + op; + } + })(); + var newQuery = function newQuery2() { + return { + checks: [] + }; + }; + var Type = { + /** E.g. node */ + GROUP: 0, + /** A collection of elements */ + COLLECTION: 1, + /** A filter(ele) function */ + FILTER: 2, + /** E.g. [foo > 1] */ + DATA_COMPARE: 3, + /** E.g. [foo] */ + DATA_EXIST: 4, + /** E.g. [?foo] */ + DATA_BOOL: 5, + /** E.g. [[degree > 2]] */ + META_COMPARE: 6, + /** E.g. :selected */ + STATE: 7, + /** E.g. #foo */ + ID: 8, + /** E.g. .foo */ + CLASS: 9, + /** E.g. #foo <-> #bar */ + UNDIRECTED_EDGE: 10, + /** E.g. #foo -> #bar */ + DIRECTED_EDGE: 11, + /** E.g. $#foo -> #bar */ + NODE_SOURCE: 12, + /** E.g. #foo -> $#bar */ + NODE_TARGET: 13, + /** E.g. $#foo <-> #bar */ + NODE_NEIGHBOR: 14, + /** E.g. #foo > #bar */ + CHILD: 15, + /** E.g. #foo #bar */ + DESCENDANT: 16, + /** E.g. $#foo > #bar */ + PARENT: 17, + /** E.g. $#foo #bar */ + ANCESTOR: 18, + /** E.g. #foo > $bar > #baz */ + COMPOUND_SPLIT: 19, + /** Always matches, useful placeholder for subject in `COMPOUND_SPLIT` */ + TRUE: 20 + }; + var stateSelectors = [{ + selector: ":selected", + matches: function matches2(ele) { + return ele.selected(); + } + }, { + selector: ":unselected", + matches: function matches2(ele) { + return !ele.selected(); + } + }, { + selector: ":selectable", + matches: function matches2(ele) { + return ele.selectable(); + } + }, { + selector: ":unselectable", + matches: function matches2(ele) { + return !ele.selectable(); + } + }, { + selector: ":locked", + matches: function matches2(ele) { + return ele.locked(); + } + }, { + selector: ":unlocked", + matches: function matches2(ele) { + return !ele.locked(); + } + }, { + selector: ":visible", + matches: function matches2(ele) { + return ele.visible(); + } + }, { + selector: ":hidden", + matches: function matches2(ele) { + return !ele.visible(); + } + }, { + selector: ":transparent", + matches: function matches2(ele) { + return ele.transparent(); + } + }, { + selector: ":grabbed", + matches: function matches2(ele) { + return ele.grabbed(); + } + }, { + selector: ":free", + matches: function matches2(ele) { + return !ele.grabbed(); + } + }, { + selector: ":removed", + matches: function matches2(ele) { + return ele.removed(); + } + }, { + selector: ":inside", + matches: function matches2(ele) { + return !ele.removed(); + } + }, { + selector: ":grabbable", + matches: function matches2(ele) { + return ele.grabbable(); + } + }, { + selector: ":ungrabbable", + matches: function matches2(ele) { + return !ele.grabbable(); + } + }, { + selector: ":animated", + matches: function matches2(ele) { + return ele.animated(); + } + }, { + selector: ":unanimated", + matches: function matches2(ele) { + return !ele.animated(); + } + }, { + selector: ":parent", + matches: function matches2(ele) { + return ele.isParent(); + } + }, { + selector: ":childless", + matches: function matches2(ele) { + return ele.isChildless(); + } + }, { + selector: ":child", + matches: function matches2(ele) { + return ele.isChild(); + } + }, { + selector: ":orphan", + matches: function matches2(ele) { + return ele.isOrphan(); + } + }, { + selector: ":nonorphan", + matches: function matches2(ele) { + return ele.isChild(); + } + }, { + selector: ":compound", + matches: function matches2(ele) { + if (ele.isNode()) { + return ele.isParent(); + } else { + return ele.source().isParent() || ele.target().isParent(); + } + } + }, { + selector: ":loop", + matches: function matches2(ele) { + return ele.isLoop(); + } + }, { + selector: ":simple", + matches: function matches2(ele) { + return ele.isSimple(); + } + }, { + selector: ":active", + matches: function matches2(ele) { + return ele.active(); + } + }, { + selector: ":inactive", + matches: function matches2(ele) { + return !ele.active(); + } + }, { + selector: ":backgrounding", + matches: function matches2(ele) { + return ele.backgrounding(); + } + }, { + selector: ":nonbackgrounding", + matches: function matches2(ele) { + return !ele.backgrounding(); + } + }].sort(function(a, b) { + return descending(a.selector, b.selector); + }); + var lookup = function() { + var selToFn = {}; + var s; + for (var i2 = 0; i2 < stateSelectors.length; i2++) { + s = stateSelectors[i2]; + selToFn[s.selector] = s.matches; + } + return selToFn; + }(); + var stateSelectorMatches = function stateSelectorMatches2(sel, ele) { + return lookup[sel](ele); + }; + var stateSelectorRegex = "(" + stateSelectors.map(function(s) { + return s.selector; + }).join("|") + ")"; + var cleanMetaChars = function cleanMetaChars2(str) { + return str.replace(new RegExp("\\\\(" + tokens.metaChar + ")", "g"), function(match2, $1) { + return $1; + }); + }; + var replaceLastQuery = function replaceLastQuery2(selector, examiningQuery, replacementQuery) { + selector[selector.length - 1] = replacementQuery; + }; + var exprs = [{ + name: "group", + // just used for identifying when debugging + query: true, + regex: "(" + tokens.group + ")", + populate: function populate(selector, query, _ref) { + var _ref2 = _slicedToArray(_ref, 1), group = _ref2[0]; + query.checks.push({ + type: Type.GROUP, + value: group === "*" ? group : group + "s" + }); + } + }, { + name: "state", + query: true, + regex: stateSelectorRegex, + populate: function populate(selector, query, _ref3) { + var _ref4 = _slicedToArray(_ref3, 1), state = _ref4[0]; + query.checks.push({ + type: Type.STATE, + value: state + }); + } + }, { + name: "id", + query: true, + regex: "\\#(" + tokens.id + ")", + populate: function populate(selector, query, _ref5) { + var _ref6 = _slicedToArray(_ref5, 1), id = _ref6[0]; + query.checks.push({ + type: Type.ID, + value: cleanMetaChars(id) + }); + } + }, { + name: "className", + query: true, + regex: "\\.(" + tokens.className + ")", + populate: function populate(selector, query, _ref7) { + var _ref8 = _slicedToArray(_ref7, 1), className = _ref8[0]; + query.checks.push({ + type: Type.CLASS, + value: cleanMetaChars(className) + }); + } + }, { + name: "dataExists", + query: true, + regex: "\\[\\s*(" + tokens.variable + ")\\s*\\]", + populate: function populate(selector, query, _ref9) { + var _ref10 = _slicedToArray(_ref9, 1), variable = _ref10[0]; + query.checks.push({ + type: Type.DATA_EXIST, + field: cleanMetaChars(variable) + }); + } + }, { + name: "dataCompare", + query: true, + regex: "\\[\\s*(" + tokens.variable + ")\\s*(" + tokens.comparatorOp + ")\\s*(" + tokens.value + ")\\s*\\]", + populate: function populate(selector, query, _ref11) { + var _ref12 = _slicedToArray(_ref11, 3), variable = _ref12[0], comparatorOp = _ref12[1], value = _ref12[2]; + var valueIsString = new RegExp("^" + tokens.string + "$").exec(value) != null; + if (valueIsString) { + value = value.substring(1, value.length - 1); + } else { + value = parseFloat(value); + } + query.checks.push({ + type: Type.DATA_COMPARE, + field: cleanMetaChars(variable), + operator: comparatorOp, + value + }); + } + }, { + name: "dataBool", + query: true, + regex: "\\[\\s*(" + tokens.boolOp + ")\\s*(" + tokens.variable + ")\\s*\\]", + populate: function populate(selector, query, _ref13) { + var _ref14 = _slicedToArray(_ref13, 2), boolOp = _ref14[0], variable = _ref14[1]; + query.checks.push({ + type: Type.DATA_BOOL, + field: cleanMetaChars(variable), + operator: boolOp + }); + } + }, { + name: "metaCompare", + query: true, + regex: "\\[\\[\\s*(" + tokens.meta + ")\\s*(" + tokens.comparatorOp + ")\\s*(" + tokens.number + ")\\s*\\]\\]", + populate: function populate(selector, query, _ref15) { + var _ref16 = _slicedToArray(_ref15, 3), meta2 = _ref16[0], comparatorOp = _ref16[1], number2 = _ref16[2]; + query.checks.push({ + type: Type.META_COMPARE, + field: cleanMetaChars(meta2), + operator: comparatorOp, + value: parseFloat(number2) + }); + } + }, { + name: "nextQuery", + separator: true, + regex: tokens.separator, + populate: function populate(selector, query) { + var currentSubject = selector.currentSubject; + var edgeCount = selector.edgeCount; + var compoundCount = selector.compoundCount; + var lastQ = selector[selector.length - 1]; + if (currentSubject != null) { + lastQ.subject = currentSubject; + selector.currentSubject = null; + } + lastQ.edgeCount = edgeCount; + lastQ.compoundCount = compoundCount; + selector.edgeCount = 0; + selector.compoundCount = 0; + var nextQuery = selector[selector.length++] = newQuery(); + return nextQuery; + } + }, { + name: "directedEdge", + separator: true, + regex: tokens.directedEdge, + populate: function populate(selector, query) { + if (selector.currentSubject == null) { + var edgeQuery = newQuery(); + var source = query; + var target = newQuery(); + edgeQuery.checks.push({ + type: Type.DIRECTED_EDGE, + source, + target + }); + replaceLastQuery(selector, query, edgeQuery); + selector.edgeCount++; + return target; + } else { + var srcTgtQ = newQuery(); + var _source = query; + var _target = newQuery(); + srcTgtQ.checks.push({ + type: Type.NODE_SOURCE, + source: _source, + target: _target + }); + replaceLastQuery(selector, query, srcTgtQ); + selector.edgeCount++; + return _target; + } + } + }, { + name: "undirectedEdge", + separator: true, + regex: tokens.undirectedEdge, + populate: function populate(selector, query) { + if (selector.currentSubject == null) { + var edgeQuery = newQuery(); + var source = query; + var target = newQuery(); + edgeQuery.checks.push({ + type: Type.UNDIRECTED_EDGE, + nodes: [source, target] + }); + replaceLastQuery(selector, query, edgeQuery); + selector.edgeCount++; + return target; + } else { + var nhoodQ = newQuery(); + var node = query; + var neighbor = newQuery(); + nhoodQ.checks.push({ + type: Type.NODE_NEIGHBOR, + node, + neighbor + }); + replaceLastQuery(selector, query, nhoodQ); + return neighbor; + } + } + }, { + name: "child", + separator: true, + regex: tokens.child, + populate: function populate(selector, query) { + if (selector.currentSubject == null) { + var parentChildQuery = newQuery(); + var child = newQuery(); + var parent = selector[selector.length - 1]; + parentChildQuery.checks.push({ + type: Type.CHILD, + parent, + child + }); + replaceLastQuery(selector, query, parentChildQuery); + selector.compoundCount++; + return child; + } else if (selector.currentSubject === query) { + var compound = newQuery(); + var left = selector[selector.length - 1]; + var right = newQuery(); + var subject = newQuery(); + var _child = newQuery(); + var _parent = newQuery(); + compound.checks.push({ + type: Type.COMPOUND_SPLIT, + left, + right, + subject + }); + subject.checks = query.checks; + query.checks = [{ + type: Type.TRUE + }]; + _parent.checks.push({ + type: Type.TRUE + }); + right.checks.push({ + type: Type.PARENT, + // type is swapped on right side queries + parent: _parent, + child: _child + // empty for now + }); + replaceLastQuery(selector, left, compound); + selector.currentSubject = subject; + selector.compoundCount++; + return _child; + } else { + var _parent2 = newQuery(); + var _child2 = newQuery(); + var pcQChecks = [{ + type: Type.PARENT, + parent: _parent2, + child: _child2 + }]; + _parent2.checks = query.checks; + query.checks = pcQChecks; + selector.compoundCount++; + return _child2; + } + } + }, { + name: "descendant", + separator: true, + regex: tokens.descendant, + populate: function populate(selector, query) { + if (selector.currentSubject == null) { + var ancChQuery = newQuery(); + var descendant = newQuery(); + var ancestor = selector[selector.length - 1]; + ancChQuery.checks.push({ + type: Type.DESCENDANT, + ancestor, + descendant + }); + replaceLastQuery(selector, query, ancChQuery); + selector.compoundCount++; + return descendant; + } else if (selector.currentSubject === query) { + var compound = newQuery(); + var left = selector[selector.length - 1]; + var right = newQuery(); + var subject = newQuery(); + var _descendant = newQuery(); + var _ancestor = newQuery(); + compound.checks.push({ + type: Type.COMPOUND_SPLIT, + left, + right, + subject + }); + subject.checks = query.checks; + query.checks = [{ + type: Type.TRUE + }]; + _ancestor.checks.push({ + type: Type.TRUE + }); + right.checks.push({ + type: Type.ANCESTOR, + // type is swapped on right side queries + ancestor: _ancestor, + descendant: _descendant + // empty for now + }); + replaceLastQuery(selector, left, compound); + selector.currentSubject = subject; + selector.compoundCount++; + return _descendant; + } else { + var _ancestor2 = newQuery(); + var _descendant2 = newQuery(); + var adQChecks = [{ + type: Type.ANCESTOR, + ancestor: _ancestor2, + descendant: _descendant2 + }]; + _ancestor2.checks = query.checks; + query.checks = adQChecks; + selector.compoundCount++; + return _descendant2; + } + } + }, { + name: "subject", + modifier: true, + regex: tokens.subject, + populate: function populate(selector, query) { + if (selector.currentSubject != null && selector.currentSubject !== query) { + warn("Redefinition of subject in selector `" + selector.toString() + "`"); + return false; + } + selector.currentSubject = query; + var topQ = selector[selector.length - 1]; + var topChk = topQ.checks[0]; + var topType = topChk == null ? null : topChk.type; + if (topType === Type.DIRECTED_EDGE) { + topChk.type = Type.NODE_TARGET; + } else if (topType === Type.UNDIRECTED_EDGE) { + topChk.type = Type.NODE_NEIGHBOR; + topChk.node = topChk.nodes[1]; + topChk.neighbor = topChk.nodes[0]; + topChk.nodes = null; + } + } + }]; + exprs.forEach(function(e) { + return e.regexObj = new RegExp("^" + e.regex); + }); + var consumeExpr = function consumeExpr2(remaining) { + var expr; + var match2; + var name; + for (var j = 0; j < exprs.length; j++) { + var e = exprs[j]; + var n = e.name; + var m = remaining.match(e.regexObj); + if (m != null) { + match2 = m; + expr = e; + name = n; + var consumed = m[0]; + remaining = remaining.substring(consumed.length); + break; + } + } + return { + expr, + match: match2, + name, + remaining + }; + }; + var consumeWhitespace = function consumeWhitespace2(remaining) { + var match2 = remaining.match(/^\s+/); + if (match2) { + var consumed = match2[0]; + remaining = remaining.substring(consumed.length); + } + return remaining; + }; + var parse = function parse2(selector) { + var self2 = this; + var remaining = self2.inputText = selector; + var currentQuery = self2[0] = newQuery(); + self2.length = 1; + remaining = consumeWhitespace(remaining); + for (; ; ) { + var exprInfo = consumeExpr(remaining); + if (exprInfo.expr == null) { + warn("The selector `" + selector + "`is invalid"); + return false; + } else { + var args = exprInfo.match.slice(1); + var ret = exprInfo.expr.populate(self2, currentQuery, args); + if (ret === false) { + return false; + } else if (ret != null) { + currentQuery = ret; + } + } + remaining = exprInfo.remaining; + if (remaining.match(/^\s*$/)) { + break; + } + } + var lastQ = self2[self2.length - 1]; + if (self2.currentSubject != null) { + lastQ.subject = self2.currentSubject; + } + lastQ.edgeCount = self2.edgeCount; + lastQ.compoundCount = self2.compoundCount; + for (var i2 = 0; i2 < self2.length; i2++) { + var q = self2[i2]; + if (q.compoundCount > 0 && q.edgeCount > 0) { + warn("The selector `" + selector + "` is invalid because it uses both a compound selector and an edge selector"); + return false; + } + if (q.edgeCount > 1) { + warn("The selector `" + selector + "` is invalid because it uses multiple edge selectors"); + return false; + } else if (q.edgeCount === 1) { + warn("The selector `" + selector + "` is deprecated. Edge selectors do not take effect on changes to source and target nodes after an edge is added, for performance reasons. Use a class or data selector on edges instead, updating the class or data of an edge when your app detects a change in source or target nodes."); + } + } + return true; + }; + var toString = function toString2() { + if (this.toStringCache != null) { + return this.toStringCache; + } + var clean = function clean2(obj) { + if (obj == null) { + return ""; + } else { + return obj; + } + }; + var cleanVal = function cleanVal2(val) { + if (string(val)) { + return '"' + val + '"'; + } else { + return clean(val); + } + }; + var space = function space2(val) { + return " " + val + " "; + }; + var checkToString = function checkToString2(check, subject) { + var type = check.type, value = check.value; + switch (type) { + case Type.GROUP: { + var group = clean(value); + return group.substring(0, group.length - 1); + } + case Type.DATA_COMPARE: { + var field = check.field, operator = check.operator; + return "[" + field + space(clean(operator)) + cleanVal(value) + "]"; + } + case Type.DATA_BOOL: { + var _operator = check.operator, _field = check.field; + return "[" + clean(_operator) + _field + "]"; + } + case Type.DATA_EXIST: { + var _field2 = check.field; + return "[" + _field2 + "]"; + } + case Type.META_COMPARE: { + var _operator2 = check.operator, _field3 = check.field; + return "[[" + _field3 + space(clean(_operator2)) + cleanVal(value) + "]]"; + } + case Type.STATE: { + return value; + } + case Type.ID: { + return "#" + value; + } + case Type.CLASS: { + return "." + value; + } + case Type.PARENT: + case Type.CHILD: { + return queryToString(check.parent, subject) + space(">") + queryToString(check.child, subject); + } + case Type.ANCESTOR: + case Type.DESCENDANT: { + return queryToString(check.ancestor, subject) + " " + queryToString(check.descendant, subject); + } + case Type.COMPOUND_SPLIT: { + var lhs = queryToString(check.left, subject); + var sub = queryToString(check.subject, subject); + var rhs = queryToString(check.right, subject); + return lhs + (lhs.length > 0 ? " " : "") + sub + rhs; + } + case Type.TRUE: { + return ""; + } + } + }; + var queryToString = function queryToString2(query2, subject) { + return query2.checks.reduce(function(str2, chk, i3) { + return str2 + (subject === query2 && i3 === 0 ? "$" : "") + checkToString(chk, subject); + }, ""); + }; + var str = ""; + for (var i2 = 0; i2 < this.length; i2++) { + var query = this[i2]; + str += queryToString(query, query.subject); + if (this.length > 1 && i2 < this.length - 1) { + str += ", "; + } + } + this.toStringCache = str; + return str; + }; + var parse$1 = { + parse, + toString + }; + var valCmp = function valCmp2(fieldVal, operator, value) { + var matches2; + var isFieldStr = string(fieldVal); + var isFieldNum = number$1(fieldVal); + var isValStr = string(value); + var fieldStr, valStr; + var caseInsensitive = false; + var notExpr = false; + var isIneqCmp = false; + if (operator.indexOf("!") >= 0) { + operator = operator.replace("!", ""); + notExpr = true; + } + if (operator.indexOf("@") >= 0) { + operator = operator.replace("@", ""); + caseInsensitive = true; + } + if (isFieldStr || isValStr || caseInsensitive) { + fieldStr = !isFieldStr && !isFieldNum ? "" : "" + fieldVal; + valStr = "" + value; + } + if (caseInsensitive) { + fieldVal = fieldStr = fieldStr.toLowerCase(); + value = valStr = valStr.toLowerCase(); + } + switch (operator) { + case "*=": + matches2 = fieldStr.indexOf(valStr) >= 0; + break; + case "$=": + matches2 = fieldStr.indexOf(valStr, fieldStr.length - valStr.length) >= 0; + break; + case "^=": + matches2 = fieldStr.indexOf(valStr) === 0; + break; + case "=": + matches2 = fieldVal === value; + break; + case ">": + isIneqCmp = true; + matches2 = fieldVal > value; + break; + case ">=": + isIneqCmp = true; + matches2 = fieldVal >= value; + break; + case "<": + isIneqCmp = true; + matches2 = fieldVal < value; + break; + case "<=": + isIneqCmp = true; + matches2 = fieldVal <= value; + break; + default: + matches2 = false; + break; + } + if (notExpr && (fieldVal != null || !isIneqCmp)) { + matches2 = !matches2; + } + return matches2; + }; + var boolCmp = function boolCmp2(fieldVal, operator) { + switch (operator) { + case "?": + return fieldVal ? true : false; + case "!": + return fieldVal ? false : true; + case "^": + return fieldVal === void 0; + } + }; + var existCmp = function existCmp2(fieldVal) { + return fieldVal !== void 0; + }; + var data$1 = function data2(ele, field) { + return ele.data(field); + }; + var meta = function meta2(ele, field) { + return ele[field](); + }; + var match = []; + var matches$1 = function matches2(query, ele) { + return query.checks.every(function(chk) { + return match[chk.type](chk, ele); + }); + }; + match[Type.GROUP] = function(check, ele) { + var group = check.value; + return group === "*" || group === ele.group(); + }; + match[Type.STATE] = function(check, ele) { + var stateSelector = check.value; + return stateSelectorMatches(stateSelector, ele); + }; + match[Type.ID] = function(check, ele) { + var id = check.value; + return ele.id() === id; + }; + match[Type.CLASS] = function(check, ele) { + var cls = check.value; + return ele.hasClass(cls); + }; + match[Type.META_COMPARE] = function(check, ele) { + var field = check.field, operator = check.operator, value = check.value; + return valCmp(meta(ele, field), operator, value); + }; + match[Type.DATA_COMPARE] = function(check, ele) { + var field = check.field, operator = check.operator, value = check.value; + return valCmp(data$1(ele, field), operator, value); + }; + match[Type.DATA_BOOL] = function(check, ele) { + var field = check.field, operator = check.operator; + return boolCmp(data$1(ele, field), operator); + }; + match[Type.DATA_EXIST] = function(check, ele) { + var field = check.field; + check.operator; + return existCmp(data$1(ele, field)); + }; + match[Type.UNDIRECTED_EDGE] = function(check, ele) { + var qA = check.nodes[0]; + var qB = check.nodes[1]; + var src = ele.source(); + var tgt = ele.target(); + return matches$1(qA, src) && matches$1(qB, tgt) || matches$1(qB, src) && matches$1(qA, tgt); + }; + match[Type.NODE_NEIGHBOR] = function(check, ele) { + return matches$1(check.node, ele) && ele.neighborhood().some(function(n) { + return n.isNode() && matches$1(check.neighbor, n); + }); + }; + match[Type.DIRECTED_EDGE] = function(check, ele) { + return matches$1(check.source, ele.source()) && matches$1(check.target, ele.target()); + }; + match[Type.NODE_SOURCE] = function(check, ele) { + return matches$1(check.source, ele) && ele.outgoers().some(function(n) { + return n.isNode() && matches$1(check.target, n); + }); + }; + match[Type.NODE_TARGET] = function(check, ele) { + return matches$1(check.target, ele) && ele.incomers().some(function(n) { + return n.isNode() && matches$1(check.source, n); + }); + }; + match[Type.CHILD] = function(check, ele) { + return matches$1(check.child, ele) && matches$1(check.parent, ele.parent()); + }; + match[Type.PARENT] = function(check, ele) { + return matches$1(check.parent, ele) && ele.children().some(function(c) { + return matches$1(check.child, c); + }); + }; + match[Type.DESCENDANT] = function(check, ele) { + return matches$1(check.descendant, ele) && ele.ancestors().some(function(a) { + return matches$1(check.ancestor, a); + }); + }; + match[Type.ANCESTOR] = function(check, ele) { + return matches$1(check.ancestor, ele) && ele.descendants().some(function(d) { + return matches$1(check.descendant, d); + }); + }; + match[Type.COMPOUND_SPLIT] = function(check, ele) { + return matches$1(check.subject, ele) && matches$1(check.left, ele) && matches$1(check.right, ele); + }; + match[Type.TRUE] = function() { + return true; + }; + match[Type.COLLECTION] = function(check, ele) { + var collection2 = check.value; + return collection2.has(ele); + }; + match[Type.FILTER] = function(check, ele) { + var filter2 = check.value; + return filter2(ele); + }; + var filter = function filter2(collection2) { + var self2 = this; + if (self2.length === 1 && self2[0].checks.length === 1 && self2[0].checks[0].type === Type.ID) { + return collection2.getElementById(self2[0].checks[0].value).collection(); + } + var selectorFunction = function selectorFunction2(element2) { + for (var j = 0; j < self2.length; j++) { + var query = self2[j]; + if (matches$1(query, element2)) { + return true; + } + } + return false; + }; + if (self2.text() == null) { + selectorFunction = function selectorFunction2() { + return true; + }; + } + return collection2.filter(selectorFunction); + }; + var matches = function matches2(ele) { + var self2 = this; + for (var j = 0; j < self2.length; j++) { + var query = self2[j]; + if (matches$1(query, ele)) { + return true; + } + } + return false; + }; + var matching = { + matches, + filter + }; + var Selector = function Selector2(selector) { + this.inputText = selector; + this.currentSubject = null; + this.compoundCount = 0; + this.edgeCount = 0; + this.length = 0; + if (selector == null || string(selector) && selector.match(/^\s*$/)) + ; + else if (elementOrCollection(selector)) { + this.addQuery({ + checks: [{ + type: Type.COLLECTION, + value: selector.collection() + }] + }); + } else if (fn$6(selector)) { + this.addQuery({ + checks: [{ + type: Type.FILTER, + value: selector + }] + }); + } else if (string(selector)) { + if (!this.parse(selector)) { + this.invalid = true; + } + } else { + error("A selector must be created from a string; found "); + } + }; + var selfn = Selector.prototype; + [parse$1, matching].forEach(function(p2) { + return extend(selfn, p2); + }); + selfn.text = function() { + return this.inputText; + }; + selfn.size = function() { + return this.length; + }; + selfn.eq = function(i2) { + return this[i2]; + }; + selfn.sameText = function(otherSel) { + return !this.invalid && !otherSel.invalid && this.text() === otherSel.text(); + }; + selfn.addQuery = function(q) { + this[this.length++] = q; + }; + selfn.selector = selfn.toString; + var elesfn$g = { + allAre: function allAre(selector) { + var selObj = new Selector(selector); + return this.every(function(ele) { + return selObj.matches(ele); + }); + }, + is: function is(selector) { + var selObj = new Selector(selector); + return this.some(function(ele) { + return selObj.matches(ele); + }); + }, + some: function some(fn2, thisArg) { + for (var i2 = 0; i2 < this.length; i2++) { + var ret = !thisArg ? fn2(this[i2], i2, this) : fn2.apply(thisArg, [this[i2], i2, this]); + if (ret) { + return true; + } + } + return false; + }, + every: function every(fn2, thisArg) { + for (var i2 = 0; i2 < this.length; i2++) { + var ret = !thisArg ? fn2(this[i2], i2, this) : fn2.apply(thisArg, [this[i2], i2, this]); + if (!ret) { + return false; + } + } + return true; + }, + same: function same(collection2) { + if (this === collection2) { + return true; + } + collection2 = this.cy().collection(collection2); + var thisLength = this.length; + var collectionLength = collection2.length; + if (thisLength !== collectionLength) { + return false; + } + if (thisLength === 1) { + return this[0] === collection2[0]; + } + return this.every(function(ele) { + return collection2.hasElementWithId(ele.id()); + }); + }, + anySame: function anySame(collection2) { + collection2 = this.cy().collection(collection2); + return this.some(function(ele) { + return collection2.hasElementWithId(ele.id()); + }); + }, + allAreNeighbors: function allAreNeighbors(collection2) { + collection2 = this.cy().collection(collection2); + var nhood = this.neighborhood(); + return collection2.every(function(ele) { + return nhood.hasElementWithId(ele.id()); + }); + }, + contains: function contains(collection2) { + collection2 = this.cy().collection(collection2); + var self2 = this; + return collection2.every(function(ele) { + return self2.hasElementWithId(ele.id()); + }); + } + }; + elesfn$g.allAreNeighbours = elesfn$g.allAreNeighbors; + elesfn$g.has = elesfn$g.contains; + elesfn$g.equal = elesfn$g.equals = elesfn$g.same; + var cache = function cache2(fn2, name) { + return function traversalCache(arg1, arg2, arg3, arg4) { + var selectorOrEles = arg1; + var eles = this; + var key; + if (selectorOrEles == null) { + key = ""; + } else if (elementOrCollection(selectorOrEles) && selectorOrEles.length === 1) { + key = selectorOrEles.id(); + } + if (eles.length === 1 && key) { + var _p = eles[0]._private; + var tch = _p.traversalCache = _p.traversalCache || {}; + var ch = tch[name] = tch[name] || []; + var hash = hashString(key); + var cacheHit = ch[hash]; + if (cacheHit) { + return cacheHit; + } else { + return ch[hash] = fn2.call(eles, arg1, arg2, arg3, arg4); + } + } else { + return fn2.call(eles, arg1, arg2, arg3, arg4); + } + }; + }; + var elesfn$f = { + parent: function parent(selector) { + var parents = []; + if (this.length === 1) { + var parent2 = this[0]._private.parent; + if (parent2) { + return parent2; + } + } + for (var i2 = 0; i2 < this.length; i2++) { + var ele = this[i2]; + var _parent = ele._private.parent; + if (_parent) { + parents.push(_parent); + } + } + return this.spawn(parents, true).filter(selector); + }, + parents: function parents(selector) { + var parents2 = []; + var eles = this.parent(); + while (eles.nonempty()) { + for (var i2 = 0; i2 < eles.length; i2++) { + var ele = eles[i2]; + parents2.push(ele); + } + eles = eles.parent(); + } + return this.spawn(parents2, true).filter(selector); + }, + commonAncestors: function commonAncestors(selector) { + var ancestors; + for (var i2 = 0; i2 < this.length; i2++) { + var ele = this[i2]; + var parents = ele.parents(); + ancestors = ancestors || parents; + ancestors = ancestors.intersect(parents); + } + return ancestors.filter(selector); + }, + orphans: function orphans(selector) { + return this.stdFilter(function(ele) { + return ele.isOrphan(); + }).filter(selector); + }, + nonorphans: function nonorphans(selector) { + return this.stdFilter(function(ele) { + return ele.isChild(); + }).filter(selector); + }, + children: cache(function(selector) { + var children = []; + for (var i2 = 0; i2 < this.length; i2++) { + var ele = this[i2]; + var eleChildren = ele._private.children; + for (var j = 0; j < eleChildren.length; j++) { + children.push(eleChildren[j]); + } + } + return this.spawn(children, true).filter(selector); + }, "children"), + siblings: function siblings(selector) { + return this.parent().children().not(this).filter(selector); + }, + isParent: function isParent() { + var ele = this[0]; + if (ele) { + return ele.isNode() && ele._private.children.length !== 0; + } + }, + isChildless: function isChildless() { + var ele = this[0]; + if (ele) { + return ele.isNode() && ele._private.children.length === 0; + } + }, + isChild: function isChild() { + var ele = this[0]; + if (ele) { + return ele.isNode() && ele._private.parent != null; + } + }, + isOrphan: function isOrphan() { + var ele = this[0]; + if (ele) { + return ele.isNode() && ele._private.parent == null; + } + }, + descendants: function descendants(selector) { + var elements2 = []; + function add(eles) { + for (var i2 = 0; i2 < eles.length; i2++) { + var ele = eles[i2]; + elements2.push(ele); + if (ele.children().nonempty()) { + add(ele.children()); + } + } + } + add(this.children()); + return this.spawn(elements2, true).filter(selector); + } + }; + function forEachCompound(eles, fn2, includeSelf, recursiveStep) { + var q = []; + var did = new Set$1(); + var cy = eles.cy(); + var hasCompounds = cy.hasCompoundNodes(); + for (var i2 = 0; i2 < eles.length; i2++) { + var ele = eles[i2]; + if (includeSelf) { + q.push(ele); + } else if (hasCompounds) { + recursiveStep(q, did, ele); + } + } + while (q.length > 0) { + var _ele = q.shift(); + fn2(_ele); + did.add(_ele.id()); + if (hasCompounds) { + recursiveStep(q, did, _ele); + } + } + return eles; + } + function addChildren(q, did, ele) { + if (ele.isParent()) { + var children = ele._private.children; + for (var i2 = 0; i2 < children.length; i2++) { + var child = children[i2]; + if (!did.has(child.id())) { + q.push(child); + } + } + } + } + elesfn$f.forEachDown = function(fn2) { + var includeSelf = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : true; + return forEachCompound(this, fn2, includeSelf, addChildren); + }; + function addParent(q, did, ele) { + if (ele.isChild()) { + var parent = ele._private.parent; + if (!did.has(parent.id())) { + q.push(parent); + } + } + } + elesfn$f.forEachUp = function(fn2) { + var includeSelf = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : true; + return forEachCompound(this, fn2, includeSelf, addParent); + }; + function addParentAndChildren(q, did, ele) { + addParent(q, did, ele); + addChildren(q, did, ele); + } + elesfn$f.forEachUpAndDown = function(fn2) { + var includeSelf = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : true; + return forEachCompound(this, fn2, includeSelf, addParentAndChildren); + }; + elesfn$f.ancestors = elesfn$f.parents; + var fn$5, elesfn$e; + fn$5 = elesfn$e = { + data: define.data({ + field: "data", + bindingEvent: "data", + allowBinding: true, + allowSetting: true, + settingEvent: "data", + settingTriggersEvent: true, + triggerFnName: "trigger", + allowGetting: true, + immutableKeys: { + "id": true, + "source": true, + "target": true, + "parent": true + }, + updateStyle: true + }), + removeData: define.removeData({ + field: "data", + event: "data", + triggerFnName: "trigger", + triggerEvent: true, + immutableKeys: { + "id": true, + "source": true, + "target": true, + "parent": true + }, + updateStyle: true + }), + scratch: define.data({ + field: "scratch", + bindingEvent: "scratch", + allowBinding: true, + allowSetting: true, + settingEvent: "scratch", + settingTriggersEvent: true, + triggerFnName: "trigger", + allowGetting: true, + updateStyle: true + }), + removeScratch: define.removeData({ + field: "scratch", + event: "scratch", + triggerFnName: "trigger", + triggerEvent: true, + updateStyle: true + }), + rscratch: define.data({ + field: "rscratch", + allowBinding: false, + allowSetting: true, + settingTriggersEvent: false, + allowGetting: true + }), + removeRscratch: define.removeData({ + field: "rscratch", + triggerEvent: false + }), + id: function id() { + var ele = this[0]; + if (ele) { + return ele._private.data.id; + } + } + }; + fn$5.attr = fn$5.data; + fn$5.removeAttr = fn$5.removeData; + var data = elesfn$e; + var elesfn$d = {}; + function defineDegreeFunction(callback) { + return function(includeLoops) { + var self2 = this; + if (includeLoops === void 0) { + includeLoops = true; + } + if (self2.length === 0) { + return; + } + if (self2.isNode() && !self2.removed()) { + var degree = 0; + var node = self2[0]; + var connectedEdges = node._private.edges; + for (var i2 = 0; i2 < connectedEdges.length; i2++) { + var edge = connectedEdges[i2]; + if (!includeLoops && edge.isLoop()) { + continue; + } + degree += callback(node, edge); + } + return degree; + } else { + return; + } + }; + } + extend(elesfn$d, { + degree: defineDegreeFunction(function(node, edge) { + if (edge.source().same(edge.target())) { + return 2; + } else { + return 1; + } + }), + indegree: defineDegreeFunction(function(node, edge) { + if (edge.target().same(node)) { + return 1; + } else { + return 0; + } + }), + outdegree: defineDegreeFunction(function(node, edge) { + if (edge.source().same(node)) { + return 1; + } else { + return 0; + } + }) + }); + function defineDegreeBoundsFunction(degreeFn, callback) { + return function(includeLoops) { + var ret; + var nodes2 = this.nodes(); + for (var i2 = 0; i2 < nodes2.length; i2++) { + var ele = nodes2[i2]; + var degree = ele[degreeFn](includeLoops); + if (degree !== void 0 && (ret === void 0 || callback(degree, ret))) { + ret = degree; + } + } + return ret; + }; + } + extend(elesfn$d, { + minDegree: defineDegreeBoundsFunction("degree", function(degree, min2) { + return degree < min2; + }), + maxDegree: defineDegreeBoundsFunction("degree", function(degree, max2) { + return degree > max2; + }), + minIndegree: defineDegreeBoundsFunction("indegree", function(degree, min2) { + return degree < min2; + }), + maxIndegree: defineDegreeBoundsFunction("indegree", function(degree, max2) { + return degree > max2; + }), + minOutdegree: defineDegreeBoundsFunction("outdegree", function(degree, min2) { + return degree < min2; + }), + maxOutdegree: defineDegreeBoundsFunction("outdegree", function(degree, max2) { + return degree > max2; + }) + }); + extend(elesfn$d, { + totalDegree: function totalDegree(includeLoops) { + var total = 0; + var nodes2 = this.nodes(); + for (var i2 = 0; i2 < nodes2.length; i2++) { + total += nodes2[i2].degree(includeLoops); + } + return total; + } + }); + var fn$4, elesfn$c; + var beforePositionSet = function beforePositionSet2(eles, newPos, silent) { + for (var i2 = 0; i2 < eles.length; i2++) { + var ele = eles[i2]; + if (!ele.locked()) { + var oldPos = ele._private.position; + var delta = { + x: newPos.x != null ? newPos.x - oldPos.x : 0, + y: newPos.y != null ? newPos.y - oldPos.y : 0 + }; + if (ele.isParent() && !(delta.x === 0 && delta.y === 0)) { + ele.children().shift(delta, silent); + } + ele.dirtyBoundingBoxCache(); + } + } + }; + var positionDef = { + field: "position", + bindingEvent: "position", + allowBinding: true, + allowSetting: true, + settingEvent: "position", + settingTriggersEvent: true, + triggerFnName: "emitAndNotify", + allowGetting: true, + validKeys: ["x", "y"], + beforeGet: function beforeGet(ele) { + ele.updateCompoundBounds(); + }, + beforeSet: function beforeSet(eles, newPos) { + beforePositionSet(eles, newPos, false); + }, + onSet: function onSet(eles) { + eles.dirtyCompoundBoundsCache(); + }, + canSet: function canSet(ele) { + return !ele.locked(); + } + }; + fn$4 = elesfn$c = { + position: define.data(positionDef), + // position but no notification to renderer + silentPosition: define.data(extend({}, positionDef, { + allowBinding: false, + allowSetting: true, + settingTriggersEvent: false, + allowGetting: false, + beforeSet: function beforeSet(eles, newPos) { + beforePositionSet(eles, newPos, true); + }, + onSet: function onSet(eles) { + eles.dirtyCompoundBoundsCache(); + } + })), + positions: function positions(pos, silent) { + if (plainObject(pos)) { + if (silent) { + this.silentPosition(pos); + } else { + this.position(pos); + } + } else if (fn$6(pos)) { + var _fn = pos; + var cy = this.cy(); + cy.startBatch(); + for (var i2 = 0; i2 < this.length; i2++) { + var ele = this[i2]; + var _pos = void 0; + if (_pos = _fn(ele, i2)) { + if (silent) { + ele.silentPosition(_pos); + } else { + ele.position(_pos); + } + } + } + cy.endBatch(); + } + return this; + }, + silentPositions: function silentPositions(pos) { + return this.positions(pos, true); + }, + shift: function shift(dim, val, silent) { + var delta; + if (plainObject(dim)) { + delta = { + x: number$1(dim.x) ? dim.x : 0, + y: number$1(dim.y) ? dim.y : 0 + }; + silent = val; + } else if (string(dim) && number$1(val)) { + delta = { + x: 0, + y: 0 + }; + delta[dim] = val; + } + if (delta != null) { + var cy = this.cy(); + cy.startBatch(); + for (var i2 = 0; i2 < this.length; i2++) { + var ele = this[i2]; + if (cy.hasCompoundNodes() && ele.isChild() && ele.ancestors().anySame(this)) { + continue; + } + var pos = ele.position(); + var newPos = { + x: pos.x + delta.x, + y: pos.y + delta.y + }; + if (silent) { + ele.silentPosition(newPos); + } else { + ele.position(newPos); + } + } + cy.endBatch(); + } + return this; + }, + silentShift: function silentShift(dim, val) { + if (plainObject(dim)) { + this.shift(dim, true); + } else if (string(dim) && number$1(val)) { + this.shift(dim, val, true); + } + return this; + }, + // get/set the rendered (i.e. on screen) positon of the element + renderedPosition: function renderedPosition(dim, val) { + var ele = this[0]; + var cy = this.cy(); + var zoom = cy.zoom(); + var pan = cy.pan(); + var rpos = plainObject(dim) ? dim : void 0; + var setting = rpos !== void 0 || val !== void 0 && string(dim); + if (ele && ele.isNode()) { + if (setting) { + for (var i2 = 0; i2 < this.length; i2++) { + var _ele = this[i2]; + if (val !== void 0) { + _ele.position(dim, (val - pan[dim]) / zoom); + } else if (rpos !== void 0) { + _ele.position(renderedToModelPosition(rpos, zoom, pan)); + } + } + } else { + var pos = ele.position(); + rpos = modelToRenderedPosition(pos, zoom, pan); + if (dim === void 0) { + return rpos; + } else { + return rpos[dim]; + } + } + } else if (!setting) { + return void 0; + } + return this; + }, + // get/set the position relative to the parent + relativePosition: function relativePosition(dim, val) { + var ele = this[0]; + var cy = this.cy(); + var ppos = plainObject(dim) ? dim : void 0; + var setting = ppos !== void 0 || val !== void 0 && string(dim); + var hasCompoundNodes = cy.hasCompoundNodes(); + if (ele && ele.isNode()) { + if (setting) { + for (var i2 = 0; i2 < this.length; i2++) { + var _ele2 = this[i2]; + var parent = hasCompoundNodes ? _ele2.parent() : null; + var hasParent = parent && parent.length > 0; + var relativeToParent = hasParent; + if (hasParent) { + parent = parent[0]; + } + var origin = relativeToParent ? parent.position() : { + x: 0, + y: 0 + }; + if (val !== void 0) { + _ele2.position(dim, val + origin[dim]); + } else if (ppos !== void 0) { + _ele2.position({ + x: ppos.x + origin.x, + y: ppos.y + origin.y + }); + } + } + } else { + var pos = ele.position(); + var _parent = hasCompoundNodes ? ele.parent() : null; + var _hasParent = _parent && _parent.length > 0; + var _relativeToParent = _hasParent; + if (_hasParent) { + _parent = _parent[0]; + } + var _origin = _relativeToParent ? _parent.position() : { + x: 0, + y: 0 + }; + ppos = { + x: pos.x - _origin.x, + y: pos.y - _origin.y + }; + if (dim === void 0) { + return ppos; + } else { + return ppos[dim]; + } + } + } else if (!setting) { + return void 0; + } + return this; + } + }; + fn$4.modelPosition = fn$4.point = fn$4.position; + fn$4.modelPositions = fn$4.points = fn$4.positions; + fn$4.renderedPoint = fn$4.renderedPosition; + fn$4.relativePoint = fn$4.relativePosition; + var position = elesfn$c; + var fn$3, elesfn$b; + fn$3 = elesfn$b = {}; + elesfn$b.renderedBoundingBox = function(options) { + var bb = this.boundingBox(options); + var cy = this.cy(); + var zoom = cy.zoom(); + var pan = cy.pan(); + var x1 = bb.x1 * zoom + pan.x; + var x2 = bb.x2 * zoom + pan.x; + var y1 = bb.y1 * zoom + pan.y; + var y2 = bb.y2 * zoom + pan.y; + return { + x1, + x2, + y1, + y2, + w: x2 - x1, + h: y2 - y1 + }; + }; + elesfn$b.dirtyCompoundBoundsCache = function() { + var silent = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : false; + var cy = this.cy(); + if (!cy.styleEnabled() || !cy.hasCompoundNodes()) { + return this; + } + this.forEachUp(function(ele) { + if (ele.isParent()) { + var _p = ele._private; + _p.compoundBoundsClean = false; + _p.bbCache = null; + if (!silent) { + ele.emitAndNotify("bounds"); + } + } + }); + return this; + }; + elesfn$b.updateCompoundBounds = function() { + var force = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : false; + var cy = this.cy(); + if (!cy.styleEnabled() || !cy.hasCompoundNodes()) { + return this; + } + if (!force && cy.batching()) { + return this; + } + function update2(parent) { + if (!parent.isParent()) { + return; + } + var _p2 = parent._private; + var children = parent.children(); + var includeLabels = parent.pstyle("compound-sizing-wrt-labels").value === "include"; + var min2 = { + width: { + val: parent.pstyle("min-width").pfValue, + left: parent.pstyle("min-width-bias-left"), + right: parent.pstyle("min-width-bias-right") + }, + height: { + val: parent.pstyle("min-height").pfValue, + top: parent.pstyle("min-height-bias-top"), + bottom: parent.pstyle("min-height-bias-bottom") + } + }; + var bb = children.boundingBox({ + includeLabels, + includeOverlays: false, + // updating the compound bounds happens outside of the regular + // cache cycle (i.e. before fired events) + useCache: false + }); + var pos = _p2.position; + if (bb.w === 0 || bb.h === 0) { + bb = { + w: parent.pstyle("width").pfValue, + h: parent.pstyle("height").pfValue + }; + bb.x1 = pos.x - bb.w / 2; + bb.x2 = pos.x + bb.w / 2; + bb.y1 = pos.y - bb.h / 2; + bb.y2 = pos.y + bb.h / 2; + } + function computeBiasValues(propDiff, propBias, propBiasComplement) { + var biasDiff = 0; + var biasComplementDiff = 0; + var biasTotal = propBias + propBiasComplement; + if (propDiff > 0 && biasTotal > 0) { + biasDiff = propBias / biasTotal * propDiff; + biasComplementDiff = propBiasComplement / biasTotal * propDiff; + } + return { + biasDiff, + biasComplementDiff + }; + } + function computePaddingValues(width, height, paddingObject, relativeTo) { + if (paddingObject.units === "%") { + switch (relativeTo) { + case "width": + return width > 0 ? paddingObject.pfValue * width : 0; + case "height": + return height > 0 ? paddingObject.pfValue * height : 0; + case "average": + return width > 0 && height > 0 ? paddingObject.pfValue * (width + height) / 2 : 0; + case "min": + return width > 0 && height > 0 ? width > height ? paddingObject.pfValue * height : paddingObject.pfValue * width : 0; + case "max": + return width > 0 && height > 0 ? width > height ? paddingObject.pfValue * width : paddingObject.pfValue * height : 0; + default: + return 0; + } + } else if (paddingObject.units === "px") { + return paddingObject.pfValue; + } else { + return 0; + } + } + var leftVal = min2.width.left.value; + if (min2.width.left.units === "px" && min2.width.val > 0) { + leftVal = leftVal * 100 / min2.width.val; + } + var rightVal = min2.width.right.value; + if (min2.width.right.units === "px" && min2.width.val > 0) { + rightVal = rightVal * 100 / min2.width.val; + } + var topVal = min2.height.top.value; + if (min2.height.top.units === "px" && min2.height.val > 0) { + topVal = topVal * 100 / min2.height.val; + } + var bottomVal = min2.height.bottom.value; + if (min2.height.bottom.units === "px" && min2.height.val > 0) { + bottomVal = bottomVal * 100 / min2.height.val; + } + var widthBiasDiffs = computeBiasValues(min2.width.val - bb.w, leftVal, rightVal); + var diffLeft = widthBiasDiffs.biasDiff; + var diffRight = widthBiasDiffs.biasComplementDiff; + var heightBiasDiffs = computeBiasValues(min2.height.val - bb.h, topVal, bottomVal); + var diffTop = heightBiasDiffs.biasDiff; + var diffBottom = heightBiasDiffs.biasComplementDiff; + _p2.autoPadding = computePaddingValues(bb.w, bb.h, parent.pstyle("padding"), parent.pstyle("padding-relative-to").value); + _p2.autoWidth = Math.max(bb.w, min2.width.val); + pos.x = (-diffLeft + bb.x1 + bb.x2 + diffRight) / 2; + _p2.autoHeight = Math.max(bb.h, min2.height.val); + pos.y = (-diffTop + bb.y1 + bb.y2 + diffBottom) / 2; + } + for (var i2 = 0; i2 < this.length; i2++) { + var ele = this[i2]; + var _p = ele._private; + if (!_p.compoundBoundsClean || force) { + update2(ele); + if (!cy.batching()) { + _p.compoundBoundsClean = true; + } + } + } + return this; + }; + var noninf = function noninf2(x) { + if (x === Infinity || x === -Infinity) { + return 0; + } + return x; + }; + var updateBounds = function updateBounds2(b, x1, y1, x2, y2) { + if (x2 - x1 === 0 || y2 - y1 === 0) { + return; + } + if (x1 == null || y1 == null || x2 == null || y2 == null) { + return; + } + b.x1 = x1 < b.x1 ? x1 : b.x1; + b.x2 = x2 > b.x2 ? x2 : b.x2; + b.y1 = y1 < b.y1 ? y1 : b.y1; + b.y2 = y2 > b.y2 ? y2 : b.y2; + b.w = b.x2 - b.x1; + b.h = b.y2 - b.y1; + }; + var updateBoundsFromBox = function updateBoundsFromBox2(b, b2) { + if (b2 == null) { + return b; + } + return updateBounds(b, b2.x1, b2.y1, b2.x2, b2.y2); + }; + var prefixedProperty = function prefixedProperty2(obj, field, prefix) { + return getPrefixedProperty(obj, field, prefix); + }; + var updateBoundsFromArrow = function updateBoundsFromArrow2(bounds2, ele, prefix) { + if (ele.cy().headless()) { + return; + } + var _p = ele._private; + var rstyle = _p.rstyle; + var halfArW = rstyle.arrowWidth / 2; + var arrowType = ele.pstyle(prefix + "-arrow-shape").value; + var x; + var y; + if (arrowType !== "none") { + if (prefix === "source") { + x = rstyle.srcX; + y = rstyle.srcY; + } else if (prefix === "target") { + x = rstyle.tgtX; + y = rstyle.tgtY; + } else { + x = rstyle.midX; + y = rstyle.midY; + } + var bbs = _p.arrowBounds = _p.arrowBounds || {}; + var bb = bbs[prefix] = bbs[prefix] || {}; + bb.x1 = x - halfArW; + bb.y1 = y - halfArW; + bb.x2 = x + halfArW; + bb.y2 = y + halfArW; + bb.w = bb.x2 - bb.x1; + bb.h = bb.y2 - bb.y1; + expandBoundingBox(bb, 1); + updateBounds(bounds2, bb.x1, bb.y1, bb.x2, bb.y2); + } + }; + var updateBoundsFromLabel = function updateBoundsFromLabel2(bounds2, ele, prefix) { + if (ele.cy().headless()) { + return; + } + var prefixDash; + if (prefix) { + prefixDash = prefix + "-"; + } else { + prefixDash = ""; + } + var _p = ele._private; + var rstyle = _p.rstyle; + var label = ele.pstyle(prefixDash + "label").strValue; + if (label) { + var halign = ele.pstyle("text-halign"); + var valign = ele.pstyle("text-valign"); + var labelWidth = prefixedProperty(rstyle, "labelWidth", prefix); + var labelHeight = prefixedProperty(rstyle, "labelHeight", prefix); + var labelX = prefixedProperty(rstyle, "labelX", prefix); + var labelY = prefixedProperty(rstyle, "labelY", prefix); + var marginX = ele.pstyle(prefixDash + "text-margin-x").pfValue; + var marginY = ele.pstyle(prefixDash + "text-margin-y").pfValue; + var isEdge = ele.isEdge(); + var rotation = ele.pstyle(prefixDash + "text-rotation"); + var outlineWidth = ele.pstyle("text-outline-width").pfValue; + var borderWidth = ele.pstyle("text-border-width").pfValue; + var halfBorderWidth = borderWidth / 2; + var padding = ele.pstyle("text-background-padding").pfValue; + var marginOfError = 2; + var lh = labelHeight; + var lw = labelWidth; + var lw_2 = lw / 2; + var lh_2 = lh / 2; + var lx1, lx2, ly1, ly2; + if (isEdge) { + lx1 = labelX - lw_2; + lx2 = labelX + lw_2; + ly1 = labelY - lh_2; + ly2 = labelY + lh_2; + } else { + switch (halign.value) { + case "left": + lx1 = labelX - lw; + lx2 = labelX; + break; + case "center": + lx1 = labelX - lw_2; + lx2 = labelX + lw_2; + break; + case "right": + lx1 = labelX; + lx2 = labelX + lw; + break; + } + switch (valign.value) { + case "top": + ly1 = labelY - lh; + ly2 = labelY; + break; + case "center": + ly1 = labelY - lh_2; + ly2 = labelY + lh_2; + break; + case "bottom": + ly1 = labelY; + ly2 = labelY + lh; + break; + } + } + lx1 += marginX - Math.max(outlineWidth, halfBorderWidth) - padding - marginOfError; + lx2 += marginX + Math.max(outlineWidth, halfBorderWidth) + padding + marginOfError; + ly1 += marginY - Math.max(outlineWidth, halfBorderWidth) - padding - marginOfError; + ly2 += marginY + Math.max(outlineWidth, halfBorderWidth) + padding + marginOfError; + var bbPrefix = prefix || "main"; + var bbs = _p.labelBounds; + var bb = bbs[bbPrefix] = bbs[bbPrefix] || {}; + bb.x1 = lx1; + bb.y1 = ly1; + bb.x2 = lx2; + bb.y2 = ly2; + bb.w = lx2 - lx1; + bb.h = ly2 - ly1; + var isAutorotate = isEdge && rotation.strValue === "autorotate"; + var isPfValue = rotation.pfValue != null && rotation.pfValue !== 0; + if (isAutorotate || isPfValue) { + var theta = isAutorotate ? prefixedProperty(_p.rstyle, "labelAngle", prefix) : rotation.pfValue; + var cos2 = Math.cos(theta); + var sin2 = Math.sin(theta); + var xo = (lx1 + lx2) / 2; + var yo = (ly1 + ly2) / 2; + if (!isEdge) { + switch (halign.value) { + case "left": + xo = lx2; + break; + case "right": + xo = lx1; + break; + } + switch (valign.value) { + case "top": + yo = ly2; + break; + case "bottom": + yo = ly1; + break; + } + } + var rotate = function rotate2(x, y) { + x = x - xo; + y = y - yo; + return { + x: x * cos2 - y * sin2 + xo, + y: x * sin2 + y * cos2 + yo + }; + }; + var px1y1 = rotate(lx1, ly1); + var px1y2 = rotate(lx1, ly2); + var px2y1 = rotate(lx2, ly1); + var px2y2 = rotate(lx2, ly2); + lx1 = Math.min(px1y1.x, px1y2.x, px2y1.x, px2y2.x); + lx2 = Math.max(px1y1.x, px1y2.x, px2y1.x, px2y2.x); + ly1 = Math.min(px1y1.y, px1y2.y, px2y1.y, px2y2.y); + ly2 = Math.max(px1y1.y, px1y2.y, px2y1.y, px2y2.y); + } + var bbPrefixRot = bbPrefix + "Rot"; + var bbRot = bbs[bbPrefixRot] = bbs[bbPrefixRot] || {}; + bbRot.x1 = lx1; + bbRot.y1 = ly1; + bbRot.x2 = lx2; + bbRot.y2 = ly2; + bbRot.w = lx2 - lx1; + bbRot.h = ly2 - ly1; + updateBounds(bounds2, lx1, ly1, lx2, ly2); + updateBounds(_p.labelBounds.all, lx1, ly1, lx2, ly2); + } + return bounds2; + }; + var updateBoundsFromOutline = function updateBoundsFromOutline2(bounds2, ele) { + if (ele.cy().headless()) { + return; + } + var outlineOpacity = ele.pstyle("outline-opacity").value; + var outlineWidth = ele.pstyle("outline-width").value; + if (outlineOpacity > 0 && outlineWidth > 0) { + var outlineOffset = ele.pstyle("outline-offset").value; + var nodeShape = ele.pstyle("shape").value; + var outlineSize = outlineWidth + outlineOffset; + var scaleX = (bounds2.w + outlineSize * 2) / bounds2.w; + var scaleY = (bounds2.h + outlineSize * 2) / bounds2.h; + var xOffset = 0; + var yOffset = 0; + if (["diamond", "pentagon", "round-triangle"].includes(nodeShape)) { + scaleX = (bounds2.w + outlineSize * 2.4) / bounds2.w; + yOffset = -outlineSize / 3.6; + } else if (["concave-hexagon", "rhomboid", "right-rhomboid"].includes(nodeShape)) { + scaleX = (bounds2.w + outlineSize * 2.4) / bounds2.w; + } else if (nodeShape === "star") { + scaleX = (bounds2.w + outlineSize * 2.8) / bounds2.w; + scaleY = (bounds2.h + outlineSize * 2.6) / bounds2.h; + yOffset = -outlineSize / 3.8; + } else if (nodeShape === "triangle") { + scaleX = (bounds2.w + outlineSize * 2.8) / bounds2.w; + scaleY = (bounds2.h + outlineSize * 2.4) / bounds2.h; + yOffset = -outlineSize / 1.4; + } else if (nodeShape === "vee") { + scaleX = (bounds2.w + outlineSize * 4.4) / bounds2.w; + scaleY = (bounds2.h + outlineSize * 3.8) / bounds2.h; + yOffset = -outlineSize * 0.5; + } + var hDelta = bounds2.h * scaleY - bounds2.h; + var wDelta = bounds2.w * scaleX - bounds2.w; + expandBoundingBoxSides(bounds2, [Math.ceil(hDelta / 2), Math.ceil(wDelta / 2)]); + if (xOffset != 0 || yOffset !== 0) { + var oBounds = shiftBoundingBox(bounds2, xOffset, yOffset); + updateBoundingBox(bounds2, oBounds); + } + } + }; + var boundingBoxImpl = function boundingBoxImpl2(ele, options) { + var cy = ele._private.cy; + var styleEnabled = cy.styleEnabled(); + var headless = cy.headless(); + var bounds2 = makeBoundingBox(); + var _p = ele._private; + var isNode = ele.isNode(); + var isEdge = ele.isEdge(); + var ex1, ex2, ey1, ey2; + var x, y; + var rstyle = _p.rstyle; + var manualExpansion = isNode && styleEnabled ? ele.pstyle("bounds-expansion").pfValue : [0]; + var isDisplayed = function isDisplayed2(ele2) { + return ele2.pstyle("display").value !== "none"; + }; + var displayed = !styleEnabled || isDisplayed(ele) && (!isEdge || isDisplayed(ele.source()) && isDisplayed(ele.target())); + if (displayed) { + var overlayOpacity = 0; + var overlayPadding = 0; + if (styleEnabled && options.includeOverlays) { + overlayOpacity = ele.pstyle("overlay-opacity").value; + if (overlayOpacity !== 0) { + overlayPadding = ele.pstyle("overlay-padding").value; + } + } + var underlayOpacity = 0; + var underlayPadding = 0; + if (styleEnabled && options.includeUnderlays) { + underlayOpacity = ele.pstyle("underlay-opacity").value; + if (underlayOpacity !== 0) { + underlayPadding = ele.pstyle("underlay-padding").value; + } + } + var padding = Math.max(overlayPadding, underlayPadding); + var w = 0; + var wHalf = 0; + if (styleEnabled) { + w = ele.pstyle("width").pfValue; + wHalf = w / 2; + } + if (isNode && options.includeNodes) { + var pos = ele.position(); + x = pos.x; + y = pos.y; + var _w = ele.outerWidth(); + var halfW = _w / 2; + var h = ele.outerHeight(); + var halfH = h / 2; + ex1 = x - halfW; + ex2 = x + halfW; + ey1 = y - halfH; + ey2 = y + halfH; + updateBounds(bounds2, ex1, ey1, ex2, ey2); + if (styleEnabled && options.includeOutlines) { + updateBoundsFromOutline(bounds2, ele); + } + } else if (isEdge && options.includeEdges) { + if (styleEnabled && !headless) { + var curveStyle = ele.pstyle("curve-style").strValue; + ex1 = Math.min(rstyle.srcX, rstyle.midX, rstyle.tgtX); + ex2 = Math.max(rstyle.srcX, rstyle.midX, rstyle.tgtX); + ey1 = Math.min(rstyle.srcY, rstyle.midY, rstyle.tgtY); + ey2 = Math.max(rstyle.srcY, rstyle.midY, rstyle.tgtY); + ex1 -= wHalf; + ex2 += wHalf; + ey1 -= wHalf; + ey2 += wHalf; + updateBounds(bounds2, ex1, ey1, ex2, ey2); + if (curveStyle === "haystack") { + var hpts = rstyle.haystackPts; + if (hpts && hpts.length === 2) { + ex1 = hpts[0].x; + ey1 = hpts[0].y; + ex2 = hpts[1].x; + ey2 = hpts[1].y; + if (ex1 > ex2) { + var temp = ex1; + ex1 = ex2; + ex2 = temp; + } + if (ey1 > ey2) { + var _temp = ey1; + ey1 = ey2; + ey2 = _temp; + } + updateBounds(bounds2, ex1 - wHalf, ey1 - wHalf, ex2 + wHalf, ey2 + wHalf); + } + } else if (curveStyle === "bezier" || curveStyle === "unbundled-bezier" || curveStyle === "segments" || curveStyle === "taxi") { + var pts2; + switch (curveStyle) { + case "bezier": + case "unbundled-bezier": + pts2 = rstyle.bezierPts; + break; + case "segments": + case "taxi": + pts2 = rstyle.linePts; + break; + } + if (pts2 != null) { + for (var j = 0; j < pts2.length; j++) { + var pt = pts2[j]; + ex1 = pt.x - wHalf; + ex2 = pt.x + wHalf; + ey1 = pt.y - wHalf; + ey2 = pt.y + wHalf; + updateBounds(bounds2, ex1, ey1, ex2, ey2); + } + } + } + } else { + var n1 = ele.source(); + var n1pos = n1.position(); + var n2 = ele.target(); + var n2pos = n2.position(); + ex1 = n1pos.x; + ex2 = n2pos.x; + ey1 = n1pos.y; + ey2 = n2pos.y; + if (ex1 > ex2) { + var _temp2 = ex1; + ex1 = ex2; + ex2 = _temp2; + } + if (ey1 > ey2) { + var _temp3 = ey1; + ey1 = ey2; + ey2 = _temp3; + } + ex1 -= wHalf; + ex2 += wHalf; + ey1 -= wHalf; + ey2 += wHalf; + updateBounds(bounds2, ex1, ey1, ex2, ey2); + } + } + if (styleEnabled && options.includeEdges && isEdge) { + updateBoundsFromArrow(bounds2, ele, "mid-source"); + updateBoundsFromArrow(bounds2, ele, "mid-target"); + updateBoundsFromArrow(bounds2, ele, "source"); + updateBoundsFromArrow(bounds2, ele, "target"); + } + if (styleEnabled) { + var ghost = ele.pstyle("ghost").value === "yes"; + if (ghost) { + var gx = ele.pstyle("ghost-offset-x").pfValue; + var gy = ele.pstyle("ghost-offset-y").pfValue; + updateBounds(bounds2, bounds2.x1 + gx, bounds2.y1 + gy, bounds2.x2 + gx, bounds2.y2 + gy); + } + } + var bbBody = _p.bodyBounds = _p.bodyBounds || {}; + assignBoundingBox(bbBody, bounds2); + expandBoundingBoxSides(bbBody, manualExpansion); + expandBoundingBox(bbBody, 1); + if (styleEnabled) { + ex1 = bounds2.x1; + ex2 = bounds2.x2; + ey1 = bounds2.y1; + ey2 = bounds2.y2; + updateBounds(bounds2, ex1 - padding, ey1 - padding, ex2 + padding, ey2 + padding); + } + var bbOverlay = _p.overlayBounds = _p.overlayBounds || {}; + assignBoundingBox(bbOverlay, bounds2); + expandBoundingBoxSides(bbOverlay, manualExpansion); + expandBoundingBox(bbOverlay, 1); + var bbLabels = _p.labelBounds = _p.labelBounds || {}; + if (bbLabels.all != null) { + clearBoundingBox(bbLabels.all); + } else { + bbLabels.all = makeBoundingBox(); + } + if (styleEnabled && options.includeLabels) { + if (options.includeMainLabels) { + updateBoundsFromLabel(bounds2, ele, null); + } + if (isEdge) { + if (options.includeSourceLabels) { + updateBoundsFromLabel(bounds2, ele, "source"); + } + if (options.includeTargetLabels) { + updateBoundsFromLabel(bounds2, ele, "target"); + } + } + } + } + bounds2.x1 = noninf(bounds2.x1); + bounds2.y1 = noninf(bounds2.y1); + bounds2.x2 = noninf(bounds2.x2); + bounds2.y2 = noninf(bounds2.y2); + bounds2.w = noninf(bounds2.x2 - bounds2.x1); + bounds2.h = noninf(bounds2.y2 - bounds2.y1); + if (bounds2.w > 0 && bounds2.h > 0 && displayed) { + expandBoundingBoxSides(bounds2, manualExpansion); + expandBoundingBox(bounds2, 1); + } + return bounds2; + }; + var getKey = function getKey2(opts) { + var i2 = 0; + var tf = function tf2(val) { + return (val ? 1 : 0) << i2++; + }; + var key = 0; + key += tf(opts.incudeNodes); + key += tf(opts.includeEdges); + key += tf(opts.includeLabels); + key += tf(opts.includeMainLabels); + key += tf(opts.includeSourceLabels); + key += tf(opts.includeTargetLabels); + key += tf(opts.includeOverlays); + key += tf(opts.includeOutlines); + return key; + }; + var getBoundingBoxPosKey = function getBoundingBoxPosKey2(ele) { + if (ele.isEdge()) { + var p1 = ele.source().position(); + var p2 = ele.target().position(); + var r = function r2(x) { + return Math.round(x); + }; + return hashIntsArray([r(p1.x), r(p1.y), r(p2.x), r(p2.y)]); + } else { + return 0; + } + }; + var cachedBoundingBoxImpl = function cachedBoundingBoxImpl2(ele, opts) { + var _p = ele._private; + var bb; + var isEdge = ele.isEdge(); + var key = opts == null ? defBbOptsKey : getKey(opts); + var usingDefOpts = key === defBbOptsKey; + var currPosKey = getBoundingBoxPosKey(ele); + var isPosKeySame = _p.bbCachePosKey === currPosKey; + var useCache = opts.useCache && isPosKeySame; + var isDirty = function isDirty2(ele2) { + return ele2._private.bbCache == null || ele2._private.styleDirty; + }; + var needRecalc = !useCache || isDirty(ele) || isEdge && isDirty(ele.source()) || isDirty(ele.target()); + if (needRecalc) { + if (!isPosKeySame) { + ele.recalculateRenderedStyle(useCache); + } + bb = boundingBoxImpl(ele, defBbOpts); + _p.bbCache = bb; + _p.bbCachePosKey = currPosKey; + } else { + bb = _p.bbCache; + } + if (!usingDefOpts) { + var isNode = ele.isNode(); + bb = makeBoundingBox(); + if (opts.includeNodes && isNode || opts.includeEdges && !isNode) { + if (opts.includeOverlays) { + updateBoundsFromBox(bb, _p.overlayBounds); + } else { + updateBoundsFromBox(bb, _p.bodyBounds); + } + } + if (opts.includeLabels) { + if (opts.includeMainLabels && (!isEdge || opts.includeSourceLabels && opts.includeTargetLabels)) { + updateBoundsFromBox(bb, _p.labelBounds.all); + } else { + if (opts.includeMainLabels) { + updateBoundsFromBox(bb, _p.labelBounds.mainRot); + } + if (opts.includeSourceLabels) { + updateBoundsFromBox(bb, _p.labelBounds.sourceRot); + } + if (opts.includeTargetLabels) { + updateBoundsFromBox(bb, _p.labelBounds.targetRot); + } + } + } + bb.w = bb.x2 - bb.x1; + bb.h = bb.y2 - bb.y1; + } + return bb; + }; + var defBbOpts = { + includeNodes: true, + includeEdges: true, + includeLabels: true, + includeMainLabels: true, + includeSourceLabels: true, + includeTargetLabels: true, + includeOverlays: true, + includeUnderlays: true, + includeOutlines: true, + useCache: true + }; + var defBbOptsKey = getKey(defBbOpts); + var filledBbOpts = defaults$g(defBbOpts); + elesfn$b.boundingBox = function(options) { + var bounds2; + if (this.length === 1 && this[0]._private.bbCache != null && !this[0]._private.styleDirty && (options === void 0 || options.useCache === void 0 || options.useCache === true)) { + if (options === void 0) { + options = defBbOpts; + } else { + options = filledBbOpts(options); + } + bounds2 = cachedBoundingBoxImpl(this[0], options); + } else { + bounds2 = makeBoundingBox(); + options = options || defBbOpts; + var opts = filledBbOpts(options); + var eles = this; + var cy = eles.cy(); + var styleEnabled = cy.styleEnabled(); + if (styleEnabled) { + for (var i2 = 0; i2 < eles.length; i2++) { + var ele = eles[i2]; + var _p = ele._private; + var currPosKey = getBoundingBoxPosKey(ele); + var isPosKeySame = _p.bbCachePosKey === currPosKey; + var useCache = opts.useCache && isPosKeySame && !_p.styleDirty; + ele.recalculateRenderedStyle(useCache); + } + } + this.updateCompoundBounds(!options.useCache); + for (var _i = 0; _i < eles.length; _i++) { + var _ele = eles[_i]; + updateBoundsFromBox(bounds2, cachedBoundingBoxImpl(_ele, opts)); + } + } + bounds2.x1 = noninf(bounds2.x1); + bounds2.y1 = noninf(bounds2.y1); + bounds2.x2 = noninf(bounds2.x2); + bounds2.y2 = noninf(bounds2.y2); + bounds2.w = noninf(bounds2.x2 - bounds2.x1); + bounds2.h = noninf(bounds2.y2 - bounds2.y1); + return bounds2; + }; + elesfn$b.dirtyBoundingBoxCache = function() { + for (var i2 = 0; i2 < this.length; i2++) { + var _p = this[i2]._private; + _p.bbCache = null; + _p.bbCachePosKey = null; + _p.bodyBounds = null; + _p.overlayBounds = null; + _p.labelBounds.all = null; + _p.labelBounds.source = null; + _p.labelBounds.target = null; + _p.labelBounds.main = null; + _p.labelBounds.sourceRot = null; + _p.labelBounds.targetRot = null; + _p.labelBounds.mainRot = null; + _p.arrowBounds.source = null; + _p.arrowBounds.target = null; + _p.arrowBounds["mid-source"] = null; + _p.arrowBounds["mid-target"] = null; + } + this.emitAndNotify("bounds"); + return this; + }; + elesfn$b.boundingBoxAt = function(fn2) { + var nodes2 = this.nodes(); + var cy = this.cy(); + var hasCompoundNodes = cy.hasCompoundNodes(); + var parents = cy.collection(); + if (hasCompoundNodes) { + parents = nodes2.filter(function(node) { + return node.isParent(); + }); + nodes2 = nodes2.not(parents); + } + if (plainObject(fn2)) { + var obj = fn2; + fn2 = function fn3() { + return obj; + }; + } + var storeOldPos = function storeOldPos2(node, i2) { + return node._private.bbAtOldPos = fn2(node, i2); + }; + var getOldPos = function getOldPos2(node) { + return node._private.bbAtOldPos; + }; + cy.startBatch(); + nodes2.forEach(storeOldPos).silentPositions(fn2); + if (hasCompoundNodes) { + parents.dirtyCompoundBoundsCache(); + parents.dirtyBoundingBoxCache(); + parents.updateCompoundBounds(true); + } + var bb = copyBoundingBox(this.boundingBox({ + useCache: false + })); + nodes2.silentPositions(getOldPos); + if (hasCompoundNodes) { + parents.dirtyCompoundBoundsCache(); + parents.dirtyBoundingBoxCache(); + parents.updateCompoundBounds(true); + } + cy.endBatch(); + return bb; + }; + fn$3.boundingbox = fn$3.bb = fn$3.boundingBox; + fn$3.renderedBoundingbox = fn$3.renderedBoundingBox; + var bounds = elesfn$b; + var fn$2, elesfn$a; + fn$2 = elesfn$a = {}; + var defineDimFns = function defineDimFns2(opts) { + opts.uppercaseName = capitalize(opts.name); + opts.autoName = "auto" + opts.uppercaseName; + opts.labelName = "label" + opts.uppercaseName; + opts.outerName = "outer" + opts.uppercaseName; + opts.uppercaseOuterName = capitalize(opts.outerName); + fn$2[opts.name] = function dimImpl() { + var ele = this[0]; + var _p = ele._private; + var cy = _p.cy; + var styleEnabled = cy._private.styleEnabled; + if (ele) { + if (styleEnabled) { + if (ele.isParent()) { + ele.updateCompoundBounds(); + return _p[opts.autoName] || 0; + } + var d = ele.pstyle(opts.name); + switch (d.strValue) { + case "label": + ele.recalculateRenderedStyle(); + return _p.rstyle[opts.labelName] || 0; + default: + return d.pfValue; + } + } else { + return 1; + } + } + }; + fn$2["outer" + opts.uppercaseName] = function outerDimImpl() { + var ele = this[0]; + var _p = ele._private; + var cy = _p.cy; + var styleEnabled = cy._private.styleEnabled; + if (ele) { + if (styleEnabled) { + var dim = ele[opts.name](); + var border = ele.pstyle("border-width").pfValue; + var padding = 2 * ele.padding(); + return dim + border + padding; + } else { + return 1; + } + } + }; + fn$2["rendered" + opts.uppercaseName] = function renderedDimImpl() { + var ele = this[0]; + if (ele) { + var d = ele[opts.name](); + return d * this.cy().zoom(); + } + }; + fn$2["rendered" + opts.uppercaseOuterName] = function renderedOuterDimImpl() { + var ele = this[0]; + if (ele) { + var od = ele[opts.outerName](); + return od * this.cy().zoom(); + } + }; + }; + defineDimFns({ + name: "width" + }); + defineDimFns({ + name: "height" + }); + elesfn$a.padding = function() { + var ele = this[0]; + var _p = ele._private; + if (ele.isParent()) { + ele.updateCompoundBounds(); + if (_p.autoPadding !== void 0) { + return _p.autoPadding; + } else { + return ele.pstyle("padding").pfValue; + } + } else { + return ele.pstyle("padding").pfValue; + } + }; + elesfn$a.paddedHeight = function() { + var ele = this[0]; + return ele.height() + 2 * ele.padding(); + }; + elesfn$a.paddedWidth = function() { + var ele = this[0]; + return ele.width() + 2 * ele.padding(); + }; + var widthHeight = elesfn$a; + var ifEdge = function ifEdge2(ele, getValue2) { + if (ele.isEdge()) { + return getValue2(ele); + } + }; + var ifEdgeRenderedPosition = function ifEdgeRenderedPosition2(ele, getPoint) { + if (ele.isEdge()) { + var cy = ele.cy(); + return modelToRenderedPosition(getPoint(ele), cy.zoom(), cy.pan()); + } + }; + var ifEdgeRenderedPositions = function ifEdgeRenderedPositions2(ele, getPoints) { + if (ele.isEdge()) { + var cy = ele.cy(); + var pan = cy.pan(); + var zoom = cy.zoom(); + return getPoints(ele).map(function(p2) { + return modelToRenderedPosition(p2, zoom, pan); + }); + } + }; + var controlPoints = function controlPoints2(ele) { + return ele.renderer().getControlPoints(ele); + }; + var segmentPoints = function segmentPoints2(ele) { + return ele.renderer().getSegmentPoints(ele); + }; + var sourceEndpoint = function sourceEndpoint2(ele) { + return ele.renderer().getSourceEndpoint(ele); + }; + var targetEndpoint = function targetEndpoint2(ele) { + return ele.renderer().getTargetEndpoint(ele); + }; + var midpoint = function midpoint2(ele) { + return ele.renderer().getEdgeMidpoint(ele); + }; + var pts = { + controlPoints: { + get: controlPoints, + mult: true + }, + segmentPoints: { + get: segmentPoints, + mult: true + }, + sourceEndpoint: { + get: sourceEndpoint + }, + targetEndpoint: { + get: targetEndpoint + }, + midpoint: { + get: midpoint + } + }; + var renderedName = function renderedName2(name) { + return "rendered" + name[0].toUpperCase() + name.substr(1); + }; + var edgePoints = Object.keys(pts).reduce(function(obj, name) { + var spec = pts[name]; + var rName = renderedName(name); + obj[name] = function() { + return ifEdge(this, spec.get); + }; + if (spec.mult) { + obj[rName] = function() { + return ifEdgeRenderedPositions(this, spec.get); + }; + } else { + obj[rName] = function() { + return ifEdgeRenderedPosition(this, spec.get); + }; + } + return obj; + }, {}); + var dimensions = extend({}, position, bounds, widthHeight, edgePoints); + /*! + Event object based on jQuery events, MIT license + + https://jquery.org/license/ + https://tldrlegal.com/license/mit-license + https://github.com/jquery/jquery/blob/master/src/event.js + */ + var Event = function Event2(src, props) { + this.recycle(src, props); + }; + function returnFalse() { + return false; + } + function returnTrue() { + return true; + } + Event.prototype = { + instanceString: function instanceString() { + return "event"; + }, + recycle: function recycle(src, props) { + this.isImmediatePropagationStopped = this.isPropagationStopped = this.isDefaultPrevented = returnFalse; + if (src != null && src.preventDefault) { + this.type = src.type; + this.isDefaultPrevented = src.defaultPrevented ? returnTrue : returnFalse; + } else if (src != null && src.type) { + props = src; + } else { + this.type = src; + } + if (props != null) { + this.originalEvent = props.originalEvent; + this.type = props.type != null ? props.type : this.type; + this.cy = props.cy; + this.target = props.target; + this.position = props.position; + this.renderedPosition = props.renderedPosition; + this.namespace = props.namespace; + this.layout = props.layout; + } + if (this.cy != null && this.position != null && this.renderedPosition == null) { + var pos = this.position; + var zoom = this.cy.zoom(); + var pan = this.cy.pan(); + this.renderedPosition = { + x: pos.x * zoom + pan.x, + y: pos.y * zoom + pan.y + }; + } + this.timeStamp = src && src.timeStamp || Date.now(); + }, + preventDefault: function preventDefault() { + this.isDefaultPrevented = returnTrue; + var e = this.originalEvent; + if (!e) { + return; + } + if (e.preventDefault) { + e.preventDefault(); + } + }, + stopPropagation: function stopPropagation() { + this.isPropagationStopped = returnTrue; + var e = this.originalEvent; + if (!e) { + return; + } + if (e.stopPropagation) { + e.stopPropagation(); + } + }, + stopImmediatePropagation: function stopImmediatePropagation() { + this.isImmediatePropagationStopped = returnTrue; + this.stopPropagation(); + }, + isDefaultPrevented: returnFalse, + isPropagationStopped: returnFalse, + isImmediatePropagationStopped: returnFalse + }; + var eventRegex = /^([^.]+)(\.(?:[^.]+))?$/; + var universalNamespace = ".*"; + var defaults$8 = { + qualifierCompare: function qualifierCompare(q1, q2) { + return q1 === q2; + }, + eventMatches: function eventMatches() { + return true; + }, + addEventFields: function addEventFields() { + }, + callbackContext: function callbackContext(context) { + return context; + }, + beforeEmit: function beforeEmit() { + }, + afterEmit: function afterEmit() { + }, + bubble: function bubble() { + return false; + }, + parent: function parent() { + return null; + }, + context: null + }; + var defaultsKeys = Object.keys(defaults$8); + var emptyOpts = {}; + function Emitter() { + var opts = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : emptyOpts; + var context = arguments.length > 1 ? arguments[1] : void 0; + for (var i2 = 0; i2 < defaultsKeys.length; i2++) { + var key = defaultsKeys[i2]; + this[key] = opts[key] || defaults$8[key]; + } + this.context = context || this.context; + this.listeners = []; + this.emitting = 0; + } + var p = Emitter.prototype; + var forEachEvent = function forEachEvent2(self2, handler, events, qualifier, callback, conf, confOverrides) { + if (fn$6(qualifier)) { + callback = qualifier; + qualifier = null; + } + if (confOverrides) { + if (conf == null) { + conf = confOverrides; + } else { + conf = extend({}, conf, confOverrides); + } + } + var eventList = array(events) ? events : events.split(/\s+/); + for (var i2 = 0; i2 < eventList.length; i2++) { + var evt = eventList[i2]; + if (emptyString(evt)) { + continue; + } + var match2 = evt.match(eventRegex); + if (match2) { + var type = match2[1]; + var namespace = match2[2] ? match2[2] : null; + var ret = handler(self2, evt, type, namespace, qualifier, callback, conf); + if (ret === false) { + break; + } + } + } + }; + var makeEventObj = function makeEventObj2(self2, obj) { + self2.addEventFields(self2.context, obj); + return new Event(obj.type, obj); + }; + var forEachEventObj = function forEachEventObj2(self2, handler, events) { + if (event(events)) { + handler(self2, events); + return; + } else if (plainObject(events)) { + handler(self2, makeEventObj(self2, events)); + return; + } + var eventList = array(events) ? events : events.split(/\s+/); + for (var i2 = 0; i2 < eventList.length; i2++) { + var evt = eventList[i2]; + if (emptyString(evt)) { + continue; + } + var match2 = evt.match(eventRegex); + if (match2) { + var type = match2[1]; + var namespace = match2[2] ? match2[2] : null; + var eventObj = makeEventObj(self2, { + type, + namespace, + target: self2.context + }); + handler(self2, eventObj); + } + } + }; + p.on = p.addListener = function(events, qualifier, callback, conf, confOverrides) { + forEachEvent(this, function(self2, event2, type, namespace, qualifier2, callback2, conf2) { + if (fn$6(callback2)) { + self2.listeners.push({ + event: event2, + // full event string + callback: callback2, + // callback to run + type, + // the event type (e.g. 'click') + namespace, + // the event namespace (e.g. ".foo") + qualifier: qualifier2, + // a restriction on whether to match this emitter + conf: conf2 + // additional configuration + }); + } + }, events, qualifier, callback, conf, confOverrides); + return this; + }; + p.one = function(events, qualifier, callback, conf) { + return this.on(events, qualifier, callback, conf, { + one: true + }); + }; + p.removeListener = p.off = function(events, qualifier, callback, conf) { + var _this = this; + if (this.emitting !== 0) { + this.listeners = copyArray$1(this.listeners); + } + var listeners = this.listeners; + var _loop = function _loop2(i3) { + var listener = listeners[i3]; + forEachEvent(_this, function(self2, event2, type, namespace, qualifier2, callback2) { + if ((listener.type === type || events === "*") && (!namespace && listener.namespace !== ".*" || listener.namespace === namespace) && (!qualifier2 || self2.qualifierCompare(listener.qualifier, qualifier2)) && (!callback2 || listener.callback === callback2)) { + listeners.splice(i3, 1); + return false; + } + }, events, qualifier, callback, conf); + }; + for (var i2 = listeners.length - 1; i2 >= 0; i2--) { + _loop(i2); + } + return this; + }; + p.removeAllListeners = function() { + return this.removeListener("*"); + }; + p.emit = p.trigger = function(events, extraParams, manualCallback) { + var listeners = this.listeners; + var numListenersBeforeEmit = listeners.length; + this.emitting++; + if (!array(extraParams)) { + extraParams = [extraParams]; + } + forEachEventObj(this, function(self2, eventObj) { + if (manualCallback != null) { + listeners = [{ + event: eventObj.event, + type: eventObj.type, + namespace: eventObj.namespace, + callback: manualCallback + }]; + numListenersBeforeEmit = listeners.length; + } + var _loop2 = function _loop22(i3) { + var listener = listeners[i3]; + if (listener.type === eventObj.type && (!listener.namespace || listener.namespace === eventObj.namespace || listener.namespace === universalNamespace) && self2.eventMatches(self2.context, listener, eventObj)) { + var args = [eventObj]; + if (extraParams != null) { + push(args, extraParams); + } + self2.beforeEmit(self2.context, listener, eventObj); + if (listener.conf && listener.conf.one) { + self2.listeners = self2.listeners.filter(function(l) { + return l !== listener; + }); + } + var context = self2.callbackContext(self2.context, listener, eventObj); + var ret = listener.callback.apply(context, args); + self2.afterEmit(self2.context, listener, eventObj); + if (ret === false) { + eventObj.stopPropagation(); + eventObj.preventDefault(); + } + } + }; + for (var i2 = 0; i2 < numListenersBeforeEmit; i2++) { + _loop2(i2); + } + if (self2.bubble(self2.context) && !eventObj.isPropagationStopped()) { + self2.parent(self2.context).emit(eventObj, extraParams); + } + }, events); + this.emitting--; + return this; + }; + var emitterOptions$1 = { + qualifierCompare: function qualifierCompare(selector1, selector2) { + if (selector1 == null || selector2 == null) { + return selector1 == null && selector2 == null; + } else { + return selector1.sameText(selector2); + } + }, + eventMatches: function eventMatches(ele, listener, eventObj) { + var selector = listener.qualifier; + if (selector != null) { + return ele !== eventObj.target && element(eventObj.target) && selector.matches(eventObj.target); + } + return true; + }, + addEventFields: function addEventFields(ele, evt) { + evt.cy = ele.cy(); + evt.target = ele; + }, + callbackContext: function callbackContext(ele, listener, eventObj) { + return listener.qualifier != null ? eventObj.target : ele; + }, + beforeEmit: function beforeEmit(context, listener) { + if (listener.conf && listener.conf.once) { + listener.conf.onceCollection.removeListener(listener.event, listener.qualifier, listener.callback); + } + }, + bubble: function bubble() { + return true; + }, + parent: function parent(ele) { + return ele.isChild() ? ele.parent() : ele.cy(); + } + }; + var argSelector$1 = function argSelector2(arg) { + if (string(arg)) { + return new Selector(arg); + } else { + return arg; + } + }; + var elesfn$9 = { + createEmitter: function createEmitter() { + for (var i2 = 0; i2 < this.length; i2++) { + var ele = this[i2]; + var _p = ele._private; + if (!_p.emitter) { + _p.emitter = new Emitter(emitterOptions$1, ele); + } + } + return this; + }, + emitter: function emitter() { + return this._private.emitter; + }, + on: function on(events, selector, callback) { + var argSel = argSelector$1(selector); + for (var i2 = 0; i2 < this.length; i2++) { + var ele = this[i2]; + ele.emitter().on(events, argSel, callback); + } + return this; + }, + removeListener: function removeListener(events, selector, callback) { + var argSel = argSelector$1(selector); + for (var i2 = 0; i2 < this.length; i2++) { + var ele = this[i2]; + ele.emitter().removeListener(events, argSel, callback); + } + return this; + }, + removeAllListeners: function removeAllListeners() { + for (var i2 = 0; i2 < this.length; i2++) { + var ele = this[i2]; + ele.emitter().removeAllListeners(); + } + return this; + }, + one: function one(events, selector, callback) { + var argSel = argSelector$1(selector); + for (var i2 = 0; i2 < this.length; i2++) { + var ele = this[i2]; + ele.emitter().one(events, argSel, callback); + } + return this; + }, + once: function once(events, selector, callback) { + var argSel = argSelector$1(selector); + for (var i2 = 0; i2 < this.length; i2++) { + var ele = this[i2]; + ele.emitter().on(events, argSel, callback, { + once: true, + onceCollection: this + }); + } + }, + emit: function emit(events, extraParams) { + for (var i2 = 0; i2 < this.length; i2++) { + var ele = this[i2]; + ele.emitter().emit(events, extraParams); + } + return this; + }, + emitAndNotify: function emitAndNotify(event2, extraParams) { + if (this.length === 0) { + return; + } + this.cy().notify(event2, this); + this.emit(event2, extraParams); + return this; + } + }; + define.eventAliasesOn(elesfn$9); + var elesfn$8 = { + nodes: function nodes2(selector) { + return this.filter(function(ele) { + return ele.isNode(); + }).filter(selector); + }, + edges: function edges(selector) { + return this.filter(function(ele) { + return ele.isEdge(); + }).filter(selector); + }, + // internal helper to get nodes and edges as separate collections with single iteration over elements + byGroup: function byGroup() { + var nodes2 = this.spawn(); + var edges = this.spawn(); + for (var i2 = 0; i2 < this.length; i2++) { + var ele = this[i2]; + if (ele.isNode()) { + nodes2.push(ele); + } else { + edges.push(ele); + } + } + return { + nodes: nodes2, + edges + }; + }, + filter: function filter2(_filter, thisArg) { + if (_filter === void 0) { + return this; + } else if (string(_filter) || elementOrCollection(_filter)) { + return new Selector(_filter).filter(this); + } else if (fn$6(_filter)) { + var filterEles = this.spawn(); + var eles = this; + for (var i2 = 0; i2 < eles.length; i2++) { + var ele = eles[i2]; + var include = thisArg ? _filter.apply(thisArg, [ele, i2, eles]) : _filter(ele, i2, eles); + if (include) { + filterEles.push(ele); + } + } + return filterEles; + } + return this.spawn(); + }, + not: function not(toRemove) { + if (!toRemove) { + return this; + } else { + if (string(toRemove)) { + toRemove = this.filter(toRemove); + } + var elements2 = this.spawn(); + for (var i2 = 0; i2 < this.length; i2++) { + var element2 = this[i2]; + var remove = toRemove.has(element2); + if (!remove) { + elements2.push(element2); + } + } + return elements2; + } + }, + absoluteComplement: function absoluteComplement() { + var cy = this.cy(); + return cy.mutableElements().not(this); + }, + intersect: function intersect(other) { + if (string(other)) { + var selector = other; + return this.filter(selector); + } + var elements2 = this.spawn(); + var col1 = this; + var col2 = other; + var col1Smaller = this.length < other.length; + var colS = col1Smaller ? col1 : col2; + var colL = col1Smaller ? col2 : col1; + for (var i2 = 0; i2 < colS.length; i2++) { + var ele = colS[i2]; + if (colL.has(ele)) { + elements2.push(ele); + } + } + return elements2; + }, + xor: function xor(other) { + var cy = this._private.cy; + if (string(other)) { + other = cy.$(other); + } + var elements2 = this.spawn(); + var col1 = this; + var col2 = other; + var add = function add2(col, other2) { + for (var i2 = 0; i2 < col.length; i2++) { + var ele = col[i2]; + var id = ele._private.data.id; + var inOther = other2.hasElementWithId(id); + if (!inOther) { + elements2.push(ele); + } + } + }; + add(col1, col2); + add(col2, col1); + return elements2; + }, + diff: function diff(other) { + var cy = this._private.cy; + if (string(other)) { + other = cy.$(other); + } + var left = this.spawn(); + var right = this.spawn(); + var both = this.spawn(); + var col1 = this; + var col2 = other; + var add = function add2(col, other2, retEles) { + for (var i2 = 0; i2 < col.length; i2++) { + var ele = col[i2]; + var id = ele._private.data.id; + var inOther = other2.hasElementWithId(id); + if (inOther) { + both.merge(ele); + } else { + retEles.push(ele); + } + } + }; + add(col1, col2, left); + add(col2, col1, right); + return { + left, + right, + both + }; + }, + add: function add(toAdd) { + var cy = this._private.cy; + if (!toAdd) { + return this; + } + if (string(toAdd)) { + var selector = toAdd; + toAdd = cy.mutableElements().filter(selector); + } + var elements2 = this.spawnSelf(); + for (var i2 = 0; i2 < toAdd.length; i2++) { + var ele = toAdd[i2]; + var add2 = !this.has(ele); + if (add2) { + elements2.push(ele); + } + } + return elements2; + }, + // in place merge on calling collection + merge: function merge(toAdd) { + var _p = this._private; + var cy = _p.cy; + if (!toAdd) { + return this; + } + if (toAdd && string(toAdd)) { + var selector = toAdd; + toAdd = cy.mutableElements().filter(selector); + } + var map = _p.map; + for (var i2 = 0; i2 < toAdd.length; i2++) { + var toAddEle = toAdd[i2]; + var id = toAddEle._private.data.id; + var add = !map.has(id); + if (add) { + var index = this.length++; + this[index] = toAddEle; + map.set(id, { + ele: toAddEle, + index + }); + } + } + return this; + }, + unmergeAt: function unmergeAt(i2) { + var ele = this[i2]; + var id = ele.id(); + var _p = this._private; + var map = _p.map; + this[i2] = void 0; + map["delete"](id); + var unmergedLastEle = i2 === this.length - 1; + if (this.length > 1 && !unmergedLastEle) { + var lastEleI = this.length - 1; + var lastEle = this[lastEleI]; + var lastEleId = lastEle._private.data.id; + this[lastEleI] = void 0; + this[i2] = lastEle; + map.set(lastEleId, { + ele: lastEle, + index: i2 + }); + } + this.length--; + return this; + }, + // remove single ele in place in calling collection + unmergeOne: function unmergeOne(ele) { + ele = ele[0]; + var _p = this._private; + var id = ele._private.data.id; + var map = _p.map; + var entry = map.get(id); + if (!entry) { + return this; + } + var i2 = entry.index; + this.unmergeAt(i2); + return this; + }, + // remove eles in place on calling collection + unmerge: function unmerge(toRemove) { + var cy = this._private.cy; + if (!toRemove) { + return this; + } + if (toRemove && string(toRemove)) { + var selector = toRemove; + toRemove = cy.mutableElements().filter(selector); + } + for (var i2 = 0; i2 < toRemove.length; i2++) { + this.unmergeOne(toRemove[i2]); + } + return this; + }, + unmergeBy: function unmergeBy(toRmFn) { + for (var i2 = this.length - 1; i2 >= 0; i2--) { + var ele = this[i2]; + if (toRmFn(ele)) { + this.unmergeAt(i2); + } + } + return this; + }, + map: function map(mapFn, thisArg) { + var arr = []; + var eles = this; + for (var i2 = 0; i2 < eles.length; i2++) { + var ele = eles[i2]; + var ret = thisArg ? mapFn.apply(thisArg, [ele, i2, eles]) : mapFn(ele, i2, eles); + arr.push(ret); + } + return arr; + }, + reduce: function reduce(fn2, initialValue) { + var val = initialValue; + var eles = this; + for (var i2 = 0; i2 < eles.length; i2++) { + val = fn2(val, eles[i2], i2, eles); + } + return val; + }, + max: function max2(valFn, thisArg) { + var max3 = -Infinity; + var maxEle; + var eles = this; + for (var i2 = 0; i2 < eles.length; i2++) { + var ele = eles[i2]; + var val = thisArg ? valFn.apply(thisArg, [ele, i2, eles]) : valFn(ele, i2, eles); + if (val > max3) { + max3 = val; + maxEle = ele; + } + } + return { + value: max3, + ele: maxEle + }; + }, + min: function min2(valFn, thisArg) { + var min3 = Infinity; + var minEle; + var eles = this; + for (var i2 = 0; i2 < eles.length; i2++) { + var ele = eles[i2]; + var val = thisArg ? valFn.apply(thisArg, [ele, i2, eles]) : valFn(ele, i2, eles); + if (val < min3) { + min3 = val; + minEle = ele; + } + } + return { + value: min3, + ele: minEle + }; + } + }; + var fn$1 = elesfn$8; + fn$1["u"] = fn$1["|"] = fn$1["+"] = fn$1.union = fn$1.or = fn$1.add; + fn$1["\\"] = fn$1["!"] = fn$1["-"] = fn$1.difference = fn$1.relativeComplement = fn$1.subtract = fn$1.not; + fn$1["n"] = fn$1["&"] = fn$1["."] = fn$1.and = fn$1.intersection = fn$1.intersect; + fn$1["^"] = fn$1["(+)"] = fn$1["(-)"] = fn$1.symmetricDifference = fn$1.symdiff = fn$1.xor; + fn$1.fnFilter = fn$1.filterFn = fn$1.stdFilter = fn$1.filter; + fn$1.complement = fn$1.abscomp = fn$1.absoluteComplement; + var elesfn$7 = { + isNode: function isNode() { + return this.group() === "nodes"; + }, + isEdge: function isEdge() { + return this.group() === "edges"; + }, + isLoop: function isLoop() { + return this.isEdge() && this.source()[0] === this.target()[0]; + }, + isSimple: function isSimple() { + return this.isEdge() && this.source()[0] !== this.target()[0]; + }, + group: function group() { + var ele = this[0]; + if (ele) { + return ele._private.group; + } + } + }; + var zIndexSort = function zIndexSort2(a, b) { + var cy = a.cy(); + var hasCompoundNodes = cy.hasCompoundNodes(); + function getDepth(ele) { + var style = ele.pstyle("z-compound-depth"); + if (style.value === "auto") { + return hasCompoundNodes ? ele.zDepth() : 0; + } else if (style.value === "bottom") { + return -1; + } else if (style.value === "top") { + return MAX_INT$1; + } + return 0; + } + var depthDiff = getDepth(a) - getDepth(b); + if (depthDiff !== 0) { + return depthDiff; + } + function getEleDepth(ele) { + var style = ele.pstyle("z-index-compare"); + if (style.value === "auto") { + return ele.isNode() ? 1 : 0; + } + return 0; + } + var eleDiff = getEleDepth(a) - getEleDepth(b); + if (eleDiff !== 0) { + return eleDiff; + } + var zDiff = a.pstyle("z-index").value - b.pstyle("z-index").value; + if (zDiff !== 0) { + return zDiff; + } + return a.poolIndex() - b.poolIndex(); + }; + var elesfn$6 = { + forEach: function forEach(fn2, thisArg) { + if (fn$6(fn2)) { + var N = this.length; + for (var i2 = 0; i2 < N; i2++) { + var ele = this[i2]; + var ret = thisArg ? fn2.apply(thisArg, [ele, i2, this]) : fn2(ele, i2, this); + if (ret === false) { + break; + } + } + } + return this; + }, + toArray: function toArray() { + var array2 = []; + for (var i2 = 0; i2 < this.length; i2++) { + array2.push(this[i2]); + } + return array2; + }, + slice: function slice(start, end) { + var array2 = []; + var thisSize = this.length; + if (end == null) { + end = thisSize; + } + if (start == null) { + start = 0; + } + if (start < 0) { + start = thisSize + start; + } + if (end < 0) { + end = thisSize + end; + } + for (var i2 = start; i2 >= 0 && i2 < end && i2 < thisSize; i2++) { + array2.push(this[i2]); + } + return this.spawn(array2); + }, + size: function size() { + return this.length; + }, + eq: function eq2(i2) { + return this[i2] || this.spawn(); + }, + first: function first() { + return this[0] || this.spawn(); + }, + last: function last() { + return this[this.length - 1] || this.spawn(); + }, + empty: function empty() { + return this.length === 0; + }, + nonempty: function nonempty() { + return !this.empty(); + }, + sort: function sort(sortFn) { + if (!fn$6(sortFn)) { + return this; + } + var sorted = this.toArray().sort(sortFn); + return this.spawn(sorted); + }, + sortByZIndex: function sortByZIndex() { + return this.sort(zIndexSort); + }, + zDepth: function zDepth() { + var ele = this[0]; + if (!ele) { + return void 0; + } + var _p = ele._private; + var group = _p.group; + if (group === "nodes") { + var depth = _p.data.parent ? ele.parents().size() : 0; + if (!ele.isParent()) { + return MAX_INT$1 - 1; + } + return depth; + } else { + var src = _p.source; + var tgt = _p.target; + var srcDepth = src.zDepth(); + var tgtDepth = tgt.zDepth(); + return Math.max(srcDepth, tgtDepth, 0); + } + } + }; + elesfn$6.each = elesfn$6.forEach; + var defineSymbolIterator = function defineSymbolIterator2() { + var typeofUndef = "undefined"; + var isIteratorSupported = (typeof Symbol === "undefined" ? "undefined" : _typeof(Symbol)) != typeofUndef && _typeof(Symbol.iterator) != typeofUndef; + if (isIteratorSupported) { + elesfn$6[Symbol.iterator] = function() { + var _this = this; + var entry = { + value: void 0, + done: false + }; + var i2 = 0; + var length = this.length; + return _defineProperty$1({ + next: function next2() { + if (i2 < length) { + entry.value = _this[i2++]; + } else { + entry.value = void 0; + entry.done = true; + } + return entry; + } + }, Symbol.iterator, function() { + return this; + }); + }; + } + }; + defineSymbolIterator(); + var getLayoutDimensionOptions = defaults$g({ + nodeDimensionsIncludeLabels: false + }); + var elesfn$5 = { + // Calculates and returns node dimensions { x, y } based on options given + layoutDimensions: function layoutDimensions(options) { + options = getLayoutDimensionOptions(options); + var dims; + if (!this.takesUpSpace()) { + dims = { + w: 0, + h: 0 + }; + } else if (options.nodeDimensionsIncludeLabels) { + var bbDim = this.boundingBox(); + dims = { + w: bbDim.w, + h: bbDim.h + }; + } else { + dims = { + w: this.outerWidth(), + h: this.outerHeight() + }; + } + if (dims.w === 0 || dims.h === 0) { + dims.w = dims.h = 1; + } + return dims; + }, + // using standard layout options, apply position function (w/ or w/o animation) + layoutPositions: function layoutPositions(layout2, options, fn2) { + var nodes2 = this.nodes().filter(function(n) { + return !n.isParent(); + }); + var cy = this.cy(); + var layoutEles = options.eles; + var getMemoizeKey = function getMemoizeKey2(node2) { + return node2.id(); + }; + var fnMem = memoize$1(fn2, getMemoizeKey); + layout2.emit({ + type: "layoutstart", + layout: layout2 + }); + layout2.animations = []; + var calculateSpacing = function calculateSpacing2(spacing, nodesBb, pos) { + var center = { + x: nodesBb.x1 + nodesBb.w / 2, + y: nodesBb.y1 + nodesBb.h / 2 + }; + var spacingVector = { + // scale from center of bounding box (not necessarily 0,0) + x: (pos.x - center.x) * spacing, + y: (pos.y - center.y) * spacing + }; + return { + x: center.x + spacingVector.x, + y: center.y + spacingVector.y + }; + }; + var useSpacingFactor = options.spacingFactor && options.spacingFactor !== 1; + var spacingBb = function spacingBb2() { + if (!useSpacingFactor) { + return null; + } + var bb2 = makeBoundingBox(); + for (var i3 = 0; i3 < nodes2.length; i3++) { + var node2 = nodes2[i3]; + var pos = fnMem(node2, i3); + expandBoundingBoxByPoint(bb2, pos.x, pos.y); + } + return bb2; + }; + var bb = spacingBb(); + var getFinalPos = memoize$1(function(node2, i3) { + var newPos2 = fnMem(node2, i3); + if (useSpacingFactor) { + var spacing = Math.abs(options.spacingFactor); + newPos2 = calculateSpacing(spacing, bb, newPos2); + } + if (options.transform != null) { + newPos2 = options.transform(node2, newPos2); + } + return newPos2; + }, getMemoizeKey); + if (options.animate) { + for (var i2 = 0; i2 < nodes2.length; i2++) { + var node = nodes2[i2]; + var newPos = getFinalPos(node, i2); + var animateNode = options.animateFilter == null || options.animateFilter(node, i2); + if (animateNode) { + var ani = node.animation({ + position: newPos, + duration: options.animationDuration, + easing: options.animationEasing + }); + layout2.animations.push(ani); + } else { + node.position(newPos); + } + } + if (options.fit) { + var fitAni = cy.animation({ + fit: { + boundingBox: layoutEles.boundingBoxAt(getFinalPos), + padding: options.padding + }, + duration: options.animationDuration, + easing: options.animationEasing + }); + layout2.animations.push(fitAni); + } else if (options.zoom !== void 0 && options.pan !== void 0) { + var zoomPanAni = cy.animation({ + zoom: options.zoom, + pan: options.pan, + duration: options.animationDuration, + easing: options.animationEasing + }); + layout2.animations.push(zoomPanAni); + } + layout2.animations.forEach(function(ani2) { + return ani2.play(); + }); + layout2.one("layoutready", options.ready); + layout2.emit({ + type: "layoutready", + layout: layout2 + }); + Promise$1.all(layout2.animations.map(function(ani2) { + return ani2.promise(); + })).then(function() { + layout2.one("layoutstop", options.stop); + layout2.emit({ + type: "layoutstop", + layout: layout2 + }); + }); + } else { + nodes2.positions(getFinalPos); + if (options.fit) { + cy.fit(options.eles, options.padding); + } + if (options.zoom != null) { + cy.zoom(options.zoom); + } + if (options.pan) { + cy.pan(options.pan); + } + layout2.one("layoutready", options.ready); + layout2.emit({ + type: "layoutready", + layout: layout2 + }); + layout2.one("layoutstop", options.stop); + layout2.emit({ + type: "layoutstop", + layout: layout2 + }); + } + return this; + }, + layout: function layout2(options) { + var cy = this.cy(); + return cy.makeLayout(extend({}, options, { + eles: this + })); + } + }; + elesfn$5.createLayout = elesfn$5.makeLayout = elesfn$5.layout; + function styleCache(key, fn2, ele) { + var _p = ele._private; + var cache2 = _p.styleCache = _p.styleCache || []; + var val; + if ((val = cache2[key]) != null) { + return val; + } else { + val = cache2[key] = fn2(ele); + return val; + } + } + function cacheStyleFunction(key, fn2) { + key = hashString(key); + return function cachedStyleFunction(ele) { + return styleCache(key, fn2, ele); + }; + } + function cachePrototypeStyleFunction(key, fn2) { + key = hashString(key); + var selfFn = function selfFn2(ele) { + return fn2.call(ele); + }; + return function cachedPrototypeStyleFunction() { + var ele = this[0]; + if (ele) { + return styleCache(key, selfFn, ele); + } + }; + } + var elesfn$4 = { + recalculateRenderedStyle: function recalculateRenderedStyle(useCache) { + var cy = this.cy(); + var renderer3 = cy.renderer(); + var styleEnabled = cy.styleEnabled(); + if (renderer3 && styleEnabled) { + renderer3.recalculateRenderedStyle(this, useCache); + } + return this; + }, + dirtyStyleCache: function dirtyStyleCache() { + var cy = this.cy(); + var dirty = function dirty2(ele) { + return ele._private.styleCache = null; + }; + if (cy.hasCompoundNodes()) { + var eles; + eles = this.spawnSelf().merge(this.descendants()).merge(this.parents()); + eles.merge(eles.connectedEdges()); + eles.forEach(dirty); + } else { + this.forEach(function(ele) { + dirty(ele); + ele.connectedEdges().forEach(dirty); + }); + } + return this; + }, + // fully updates (recalculates) the style for the elements + updateStyle: function updateStyle(notifyRenderer) { + var cy = this._private.cy; + if (!cy.styleEnabled()) { + return this; + } + if (cy.batching()) { + var bEles = cy._private.batchStyleEles; + bEles.merge(this); + return this; + } + var hasCompounds = cy.hasCompoundNodes(); + var updatedEles = this; + notifyRenderer = notifyRenderer || notifyRenderer === void 0 ? true : false; + if (hasCompounds) { + updatedEles = this.spawnSelf().merge(this.descendants()).merge(this.parents()); + } + var changedEles = updatedEles; + if (notifyRenderer) { + changedEles.emitAndNotify("style"); + } else { + changedEles.emit("style"); + } + updatedEles.forEach(function(ele) { + return ele._private.styleDirty = true; + }); + return this; + }, + // private: clears dirty flag and recalculates style + cleanStyle: function cleanStyle() { + var cy = this.cy(); + if (!cy.styleEnabled()) { + return; + } + for (var i2 = 0; i2 < this.length; i2++) { + var ele = this[i2]; + if (ele._private.styleDirty) { + ele._private.styleDirty = false; + cy.style().apply(ele); + } + } + }, + // get the internal parsed style object for the specified property + parsedStyle: function parsedStyle(property) { + var includeNonDefault = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : true; + var ele = this[0]; + var cy = ele.cy(); + if (!cy.styleEnabled()) { + return; + } + if (ele) { + this.cleanStyle(); + var overriddenStyle = ele._private.style[property]; + if (overriddenStyle != null) { + return overriddenStyle; + } else if (includeNonDefault) { + return cy.style().getDefaultProperty(property); + } else { + return null; + } + } + }, + numericStyle: function numericStyle(property) { + var ele = this[0]; + if (!ele.cy().styleEnabled()) { + return; + } + if (ele) { + var pstyle = ele.pstyle(property); + return pstyle.pfValue !== void 0 ? pstyle.pfValue : pstyle.value; + } + }, + numericStyleUnits: function numericStyleUnits(property) { + var ele = this[0]; + if (!ele.cy().styleEnabled()) { + return; + } + if (ele) { + return ele.pstyle(property).units; + } + }, + // get the specified css property as a rendered value (i.e. on-screen value) + // or get the whole rendered style if no property specified (NB doesn't allow setting) + renderedStyle: function renderedStyle(property) { + var cy = this.cy(); + if (!cy.styleEnabled()) { + return this; + } + var ele = this[0]; + if (ele) { + return cy.style().getRenderedStyle(ele, property); + } + }, + // read the calculated css style of the element or override the style (via a bypass) + style: function style(name, value) { + var cy = this.cy(); + if (!cy.styleEnabled()) { + return this; + } + var updateTransitions = false; + var style2 = cy.style(); + if (plainObject(name)) { + var props = name; + style2.applyBypass(this, props, updateTransitions); + this.emitAndNotify("style"); + } else if (string(name)) { + if (value === void 0) { + var ele = this[0]; + if (ele) { + return style2.getStylePropertyValue(ele, name); + } else { + return; + } + } else { + style2.applyBypass(this, name, value, updateTransitions); + this.emitAndNotify("style"); + } + } else if (name === void 0) { + var _ele = this[0]; + if (_ele) { + return style2.getRawStyle(_ele); + } else { + return; + } + } + return this; + }, + removeStyle: function removeStyle(names) { + var cy = this.cy(); + if (!cy.styleEnabled()) { + return this; + } + var updateTransitions = false; + var style = cy.style(); + var eles = this; + if (names === void 0) { + for (var i2 = 0; i2 < eles.length; i2++) { + var ele = eles[i2]; + style.removeAllBypasses(ele, updateTransitions); + } + } else { + names = names.split(/\s+/); + for (var _i = 0; _i < eles.length; _i++) { + var _ele2 = eles[_i]; + style.removeBypasses(_ele2, names, updateTransitions); + } + } + this.emitAndNotify("style"); + return this; + }, + show: function show() { + this.css("display", "element"); + return this; + }, + hide: function hide() { + this.css("display", "none"); + return this; + }, + effectiveOpacity: function effectiveOpacity() { + var cy = this.cy(); + if (!cy.styleEnabled()) { + return 1; + } + var hasCompoundNodes = cy.hasCompoundNodes(); + var ele = this[0]; + if (ele) { + var _p = ele._private; + var parentOpacity = ele.pstyle("opacity").value; + if (!hasCompoundNodes) { + return parentOpacity; + } + var parents = !_p.data.parent ? null : ele.parents(); + if (parents) { + for (var i2 = 0; i2 < parents.length; i2++) { + var parent = parents[i2]; + var opacity = parent.pstyle("opacity").value; + parentOpacity = opacity * parentOpacity; + } + } + return parentOpacity; + } + }, + transparent: function transparent() { + var cy = this.cy(); + if (!cy.styleEnabled()) { + return false; + } + var ele = this[0]; + var hasCompoundNodes = ele.cy().hasCompoundNodes(); + if (ele) { + if (!hasCompoundNodes) { + return ele.pstyle("opacity").value === 0; + } else { + return ele.effectiveOpacity() === 0; + } + } + }, + backgrounding: function backgrounding() { + var cy = this.cy(); + if (!cy.styleEnabled()) { + return false; + } + var ele = this[0]; + return ele._private.backgrounding ? true : false; + } + }; + function checkCompound(ele, parentOk) { + var _p = ele._private; + var parents = _p.data.parent ? ele.parents() : null; + if (parents) { + for (var i2 = 0; i2 < parents.length; i2++) { + var parent = parents[i2]; + if (!parentOk(parent)) { + return false; + } + } + } + return true; + } + function defineDerivedStateFunction(specs) { + var ok = specs.ok; + var edgeOkViaNode = specs.edgeOkViaNode || specs.ok; + var parentOk = specs.parentOk || specs.ok; + return function() { + var cy = this.cy(); + if (!cy.styleEnabled()) { + return true; + } + var ele = this[0]; + var hasCompoundNodes = cy.hasCompoundNodes(); + if (ele) { + var _p = ele._private; + if (!ok(ele)) { + return false; + } + if (ele.isNode()) { + return !hasCompoundNodes || checkCompound(ele, parentOk); + } else { + var src = _p.source; + var tgt = _p.target; + return edgeOkViaNode(src) && (!hasCompoundNodes || checkCompound(src, edgeOkViaNode)) && (src === tgt || edgeOkViaNode(tgt) && (!hasCompoundNodes || checkCompound(tgt, edgeOkViaNode))); + } + } + }; + } + var eleTakesUpSpace = cacheStyleFunction("eleTakesUpSpace", function(ele) { + return ele.pstyle("display").value === "element" && ele.width() !== 0 && (ele.isNode() ? ele.height() !== 0 : true); + }); + elesfn$4.takesUpSpace = cachePrototypeStyleFunction("takesUpSpace", defineDerivedStateFunction({ + ok: eleTakesUpSpace + })); + var eleInteractive = cacheStyleFunction("eleInteractive", function(ele) { + return ele.pstyle("events").value === "yes" && ele.pstyle("visibility").value === "visible" && eleTakesUpSpace(ele); + }); + var parentInteractive = cacheStyleFunction("parentInteractive", function(parent) { + return parent.pstyle("visibility").value === "visible" && eleTakesUpSpace(parent); + }); + elesfn$4.interactive = cachePrototypeStyleFunction("interactive", defineDerivedStateFunction({ + ok: eleInteractive, + parentOk: parentInteractive, + edgeOkViaNode: eleTakesUpSpace + })); + elesfn$4.noninteractive = function() { + var ele = this[0]; + if (ele) { + return !ele.interactive(); + } + }; + var eleVisible = cacheStyleFunction("eleVisible", function(ele) { + return ele.pstyle("visibility").value === "visible" && ele.pstyle("opacity").pfValue !== 0 && eleTakesUpSpace(ele); + }); + var edgeVisibleViaNode = eleTakesUpSpace; + elesfn$4.visible = cachePrototypeStyleFunction("visible", defineDerivedStateFunction({ + ok: eleVisible, + edgeOkViaNode: edgeVisibleViaNode + })); + elesfn$4.hidden = function() { + var ele = this[0]; + if (ele) { + return !ele.visible(); + } + }; + elesfn$4.isBundledBezier = cachePrototypeStyleFunction("isBundledBezier", function() { + if (!this.cy().styleEnabled()) { + return false; + } + return !this.removed() && this.pstyle("curve-style").value === "bezier" && this.takesUpSpace(); + }); + elesfn$4.bypass = elesfn$4.css = elesfn$4.style; + elesfn$4.renderedCss = elesfn$4.renderedStyle; + elesfn$4.removeBypass = elesfn$4.removeCss = elesfn$4.removeStyle; + elesfn$4.pstyle = elesfn$4.parsedStyle; + var elesfn$3 = {}; + function defineSwitchFunction(params) { + return function() { + var args = arguments; + var changedEles = []; + if (args.length === 2) { + var data2 = args[0]; + var handler = args[1]; + this.on(params.event, data2, handler); + } else if (args.length === 1 && fn$6(args[0])) { + var _handler = args[0]; + this.on(params.event, _handler); + } else if (args.length === 0 || args.length === 1 && array(args[0])) { + var addlEvents = args.length === 1 ? args[0] : null; + for (var i2 = 0; i2 < this.length; i2++) { + var ele = this[i2]; + var able = !params.ableField || ele._private[params.ableField]; + var changed = ele._private[params.field] != params.value; + if (params.overrideAble) { + var overrideAble = params.overrideAble(ele); + if (overrideAble !== void 0) { + able = overrideAble; + if (!overrideAble) { + return this; + } + } + } + if (able) { + ele._private[params.field] = params.value; + if (changed) { + changedEles.push(ele); + } + } + } + var changedColl = this.spawn(changedEles); + changedColl.updateStyle(); + changedColl.emit(params.event); + if (addlEvents) { + changedColl.emit(addlEvents); + } + } + return this; + }; + } + function defineSwitchSet(params) { + elesfn$3[params.field] = function() { + var ele = this[0]; + if (ele) { + if (params.overrideField) { + var val = params.overrideField(ele); + if (val !== void 0) { + return val; + } + } + return ele._private[params.field]; + } + }; + elesfn$3[params.on] = defineSwitchFunction({ + event: params.on, + field: params.field, + ableField: params.ableField, + overrideAble: params.overrideAble, + value: true + }); + elesfn$3[params.off] = defineSwitchFunction({ + event: params.off, + field: params.field, + ableField: params.ableField, + overrideAble: params.overrideAble, + value: false + }); + } + defineSwitchSet({ + field: "locked", + overrideField: function overrideField(ele) { + return ele.cy().autolock() ? true : void 0; + }, + on: "lock", + off: "unlock" + }); + defineSwitchSet({ + field: "grabbable", + overrideField: function overrideField(ele) { + return ele.cy().autoungrabify() || ele.pannable() ? false : void 0; + }, + on: "grabify", + off: "ungrabify" + }); + defineSwitchSet({ + field: "selected", + ableField: "selectable", + overrideAble: function overrideAble(ele) { + return ele.cy().autounselectify() ? false : void 0; + }, + on: "select", + off: "unselect" + }); + defineSwitchSet({ + field: "selectable", + overrideField: function overrideField(ele) { + return ele.cy().autounselectify() ? false : void 0; + }, + on: "selectify", + off: "unselectify" + }); + elesfn$3.deselect = elesfn$3.unselect; + elesfn$3.grabbed = function() { + var ele = this[0]; + if (ele) { + return ele._private.grabbed; + } + }; + defineSwitchSet({ + field: "active", + on: "activate", + off: "unactivate" + }); + defineSwitchSet({ + field: "pannable", + on: "panify", + off: "unpanify" + }); + elesfn$3.inactive = function() { + var ele = this[0]; + if (ele) { + return !ele._private.active; + } + }; + var elesfn$2 = {}; + var defineDagExtremity = function defineDagExtremity2(params) { + return function dagExtremityImpl(selector) { + var eles = this; + var ret = []; + for (var i2 = 0; i2 < eles.length; i2++) { + var ele = eles[i2]; + if (!ele.isNode()) { + continue; + } + var disqualified = false; + var edges = ele.connectedEdges(); + for (var j = 0; j < edges.length; j++) { + var edge = edges[j]; + var src = edge.source(); + var tgt = edge.target(); + if (params.noIncomingEdges && tgt === ele && src !== ele || params.noOutgoingEdges && src === ele && tgt !== ele) { + disqualified = true; + break; + } + } + if (!disqualified) { + ret.push(ele); + } + } + return this.spawn(ret, true).filter(selector); + }; + }; + var defineDagOneHop = function defineDagOneHop2(params) { + return function(selector) { + var eles = this; + var oEles = []; + for (var i2 = 0; i2 < eles.length; i2++) { + var ele = eles[i2]; + if (!ele.isNode()) { + continue; + } + var edges = ele.connectedEdges(); + for (var j = 0; j < edges.length; j++) { + var edge = edges[j]; + var src = edge.source(); + var tgt = edge.target(); + if (params.outgoing && src === ele) { + oEles.push(edge); + oEles.push(tgt); + } else if (params.incoming && tgt === ele) { + oEles.push(edge); + oEles.push(src); + } + } + } + return this.spawn(oEles, true).filter(selector); + }; + }; + var defineDagAllHops = function defineDagAllHops2(params) { + return function(selector) { + var eles = this; + var sEles = []; + var sElesIds = {}; + for (; ; ) { + var next2 = params.outgoing ? eles.outgoers() : eles.incomers(); + if (next2.length === 0) { + break; + } + var newNext = false; + for (var i2 = 0; i2 < next2.length; i2++) { + var n = next2[i2]; + var nid = n.id(); + if (!sElesIds[nid]) { + sElesIds[nid] = true; + sEles.push(n); + newNext = true; + } + } + if (!newNext) { + break; + } + eles = next2; + } + return this.spawn(sEles, true).filter(selector); + }; + }; + elesfn$2.clearTraversalCache = function() { + for (var i2 = 0; i2 < this.length; i2++) { + this[i2]._private.traversalCache = null; + } + }; + extend(elesfn$2, { + // get the root nodes in the DAG + roots: defineDagExtremity({ + noIncomingEdges: true + }), + // get the leaf nodes in the DAG + leaves: defineDagExtremity({ + noOutgoingEdges: true + }), + // normally called children in graph theory + // these nodes =edges=> outgoing nodes + outgoers: cache(defineDagOneHop({ + outgoing: true + }), "outgoers"), + // aka DAG descendants + successors: defineDagAllHops({ + outgoing: true + }), + // normally called parents in graph theory + // these nodes <=edges= incoming nodes + incomers: cache(defineDagOneHop({ + incoming: true + }), "incomers"), + // aka DAG ancestors + predecessors: defineDagAllHops({ + incoming: true + }) + }); + extend(elesfn$2, { + neighborhood: cache(function(selector) { + var elements2 = []; + var nodes2 = this.nodes(); + for (var i2 = 0; i2 < nodes2.length; i2++) { + var node = nodes2[i2]; + var connectedEdges = node.connectedEdges(); + for (var j = 0; j < connectedEdges.length; j++) { + var edge = connectedEdges[j]; + var src = edge.source(); + var tgt = edge.target(); + var otherNode = node === src ? tgt : src; + if (otherNode.length > 0) { + elements2.push(otherNode[0]); + } + elements2.push(edge[0]); + } + } + return this.spawn(elements2, true).filter(selector); + }, "neighborhood"), + closedNeighborhood: function closedNeighborhood(selector) { + return this.neighborhood().add(this).filter(selector); + }, + openNeighborhood: function openNeighborhood(selector) { + return this.neighborhood(selector); + } + }); + elesfn$2.neighbourhood = elesfn$2.neighborhood; + elesfn$2.closedNeighbourhood = elesfn$2.closedNeighborhood; + elesfn$2.openNeighbourhood = elesfn$2.openNeighborhood; + extend(elesfn$2, { + source: cache(function sourceImpl(selector) { + var ele = this[0]; + var src; + if (ele) { + src = ele._private.source || ele.cy().collection(); + } + return src && selector ? src.filter(selector) : src; + }, "source"), + target: cache(function targetImpl(selector) { + var ele = this[0]; + var tgt; + if (ele) { + tgt = ele._private.target || ele.cy().collection(); + } + return tgt && selector ? tgt.filter(selector) : tgt; + }, "target"), + sources: defineSourceFunction({ + attr: "source" + }), + targets: defineSourceFunction({ + attr: "target" + }) + }); + function defineSourceFunction(params) { + return function sourceImpl(selector) { + var sources = []; + for (var i2 = 0; i2 < this.length; i2++) { + var ele = this[i2]; + var src = ele._private[params.attr]; + if (src) { + sources.push(src); + } + } + return this.spawn(sources, true).filter(selector); + }; + } + extend(elesfn$2, { + edgesWith: cache(defineEdgesWithFunction(), "edgesWith"), + edgesTo: cache(defineEdgesWithFunction({ + thisIsSrc: true + }), "edgesTo") + }); + function defineEdgesWithFunction(params) { + return function edgesWithImpl(otherNodes) { + var elements2 = []; + var cy = this._private.cy; + var p2 = params || {}; + if (string(otherNodes)) { + otherNodes = cy.$(otherNodes); + } + for (var h = 0; h < otherNodes.length; h++) { + var edges = otherNodes[h]._private.edges; + for (var i2 = 0; i2 < edges.length; i2++) { + var edge = edges[i2]; + var edgeData = edge._private.data; + var thisToOther = this.hasElementWithId(edgeData.source) && otherNodes.hasElementWithId(edgeData.target); + var otherToThis = otherNodes.hasElementWithId(edgeData.source) && this.hasElementWithId(edgeData.target); + var edgeConnectsThisAndOther = thisToOther || otherToThis; + if (!edgeConnectsThisAndOther) { + continue; + } + if (p2.thisIsSrc || p2.thisIsTgt) { + if (p2.thisIsSrc && !thisToOther) { + continue; + } + if (p2.thisIsTgt && !otherToThis) { + continue; + } + } + elements2.push(edge); + } + } + return this.spawn(elements2, true); + }; + } + extend(elesfn$2, { + connectedEdges: cache(function(selector) { + var retEles = []; + var eles = this; + for (var i2 = 0; i2 < eles.length; i2++) { + var node = eles[i2]; + if (!node.isNode()) { + continue; + } + var edges = node._private.edges; + for (var j = 0; j < edges.length; j++) { + var edge = edges[j]; + retEles.push(edge); + } + } + return this.spawn(retEles, true).filter(selector); + }, "connectedEdges"), + connectedNodes: cache(function(selector) { + var retEles = []; + var eles = this; + for (var i2 = 0; i2 < eles.length; i2++) { + var edge = eles[i2]; + if (!edge.isEdge()) { + continue; + } + retEles.push(edge.source()[0]); + retEles.push(edge.target()[0]); + } + return this.spawn(retEles, true).filter(selector); + }, "connectedNodes"), + parallelEdges: cache(defineParallelEdgesFunction(), "parallelEdges"), + codirectedEdges: cache(defineParallelEdgesFunction({ + codirected: true + }), "codirectedEdges") + }); + function defineParallelEdgesFunction(params) { + var defaults2 = { + codirected: false + }; + params = extend({}, defaults2, params); + return function parallelEdgesImpl(selector) { + var elements2 = []; + var edges = this.edges(); + var p2 = params; + for (var i2 = 0; i2 < edges.length; i2++) { + var edge1 = edges[i2]; + var edge1_p = edge1._private; + var src1 = edge1_p.source; + var srcid1 = src1._private.data.id; + var tgtid1 = edge1_p.data.target; + var srcEdges1 = src1._private.edges; + for (var j = 0; j < srcEdges1.length; j++) { + var edge2 = srcEdges1[j]; + var edge2data = edge2._private.data; + var tgtid2 = edge2data.target; + var srcid2 = edge2data.source; + var codirected = tgtid2 === tgtid1 && srcid2 === srcid1; + var oppdirected = srcid1 === tgtid2 && tgtid1 === srcid2; + if (p2.codirected && codirected || !p2.codirected && (codirected || oppdirected)) { + elements2.push(edge2); + } + } + } + return this.spawn(elements2, true).filter(selector); + }; + } + extend(elesfn$2, { + components: function components(root2) { + var self2 = this; + var cy = self2.cy(); + var visited = cy.collection(); + var unvisited = root2 == null ? self2.nodes() : root2.nodes(); + var components2 = []; + if (root2 != null && unvisited.empty()) { + unvisited = root2.sources(); + } + var visitInComponent = function visitInComponent2(node, component) { + visited.merge(node); + unvisited.unmerge(node); + component.merge(node); + }; + if (unvisited.empty()) { + return self2.spawn(); + } + var _loop = function _loop2() { + var cmpt = cy.collection(); + components2.push(cmpt); + var root3 = unvisited[0]; + visitInComponent(root3, cmpt); + self2.bfs({ + directed: false, + roots: root3, + visit: function visit(v) { + return visitInComponent(v, cmpt); + } + }); + cmpt.forEach(function(node) { + node.connectedEdges().forEach(function(e) { + if (self2.has(e) && cmpt.has(e.source()) && cmpt.has(e.target())) { + cmpt.merge(e); + } + }); + }); + }; + do { + _loop(); + } while (unvisited.length > 0); + return components2; + }, + component: function component() { + var ele = this[0]; + return ele.cy().mutableElements().components(ele)[0]; + } + }); + elesfn$2.componentsOf = elesfn$2.components; + var Collection = function Collection2(cy, elements2) { + var unique = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : false; + var removed = arguments.length > 3 && arguments[3] !== void 0 ? arguments[3] : false; + if (cy === void 0) { + error("A collection must have a reference to the core"); + return; + } + var map = new Map$2(); + var createdElements = false; + if (!elements2) { + elements2 = []; + } else if (elements2.length > 0 && plainObject(elements2[0]) && !element(elements2[0])) { + createdElements = true; + var eles = []; + var elesIds = new Set$1(); + for (var i2 = 0, l = elements2.length; i2 < l; i2++) { + var json = elements2[i2]; + if (json.data == null) { + json.data = {}; + } + var _data = json.data; + if (_data.id == null) { + _data.id = uuid(); + } else if (cy.hasElementWithId(_data.id) || elesIds.has(_data.id)) { + continue; + } + var ele = new Element(cy, json, false); + eles.push(ele); + elesIds.add(_data.id); + } + elements2 = eles; + } + this.length = 0; + for (var _i = 0, _l = elements2.length; _i < _l; _i++) { + var element$1 = elements2[_i][0]; + if (element$1 == null) { + continue; + } + var id = element$1._private.data.id; + if (!unique || !map.has(id)) { + if (unique) { + map.set(id, { + index: this.length, + ele: element$1 + }); + } + this[this.length] = element$1; + this.length++; + } + } + this._private = { + eles: this, + cy, + get map() { + if (this.lazyMap == null) { + this.rebuildMap(); + } + return this.lazyMap; + }, + set map(m) { + this.lazyMap = m; + }, + rebuildMap: function rebuildMap() { + var m = this.lazyMap = new Map$2(); + var eles2 = this.eles; + for (var _i2 = 0; _i2 < eles2.length; _i2++) { + var _ele = eles2[_i2]; + m.set(_ele.id(), { + index: _i2, + ele: _ele + }); + } + } + }; + if (unique) { + this._private.map = map; + } + if (createdElements && !removed) { + this.restore(); + } + }; + var elesfn$1 = Element.prototype = Collection.prototype = Object.create(Array.prototype); + elesfn$1.instanceString = function() { + return "collection"; + }; + elesfn$1.spawn = function(eles, unique) { + return new Collection(this.cy(), eles, unique); + }; + elesfn$1.spawnSelf = function() { + return this.spawn(this); + }; + elesfn$1.cy = function() { + return this._private.cy; + }; + elesfn$1.renderer = function() { + return this._private.cy.renderer(); + }; + elesfn$1.element = function() { + return this[0]; + }; + elesfn$1.collection = function() { + if (collection(this)) { + return this; + } else { + return new Collection(this._private.cy, [this]); + } + }; + elesfn$1.unique = function() { + return new Collection(this._private.cy, this, true); + }; + elesfn$1.hasElementWithId = function(id) { + id = "" + id; + return this._private.map.has(id); + }; + elesfn$1.getElementById = function(id) { + id = "" + id; + var cy = this._private.cy; + var entry = this._private.map.get(id); + return entry ? entry.ele : new Collection(cy); + }; + elesfn$1.$id = elesfn$1.getElementById; + elesfn$1.poolIndex = function() { + var cy = this._private.cy; + var eles = cy._private.elements; + var id = this[0]._private.data.id; + return eles._private.map.get(id).index; + }; + elesfn$1.indexOf = function(ele) { + var id = ele[0]._private.data.id; + return this._private.map.get(id).index; + }; + elesfn$1.indexOfId = function(id) { + id = "" + id; + return this._private.map.get(id).index; + }; + elesfn$1.json = function(obj) { + var ele = this.element(); + var cy = this.cy(); + if (ele == null && obj) { + return this; + } + if (ele == null) { + return void 0; + } + var p2 = ele._private; + if (plainObject(obj)) { + cy.startBatch(); + if (obj.data) { + ele.data(obj.data); + var _data2 = p2.data; + if (ele.isEdge()) { + var move = false; + var spec = {}; + var src = obj.data.source; + var tgt = obj.data.target; + if (src != null && src != _data2.source) { + spec.source = "" + src; + move = true; + } + if (tgt != null && tgt != _data2.target) { + spec.target = "" + tgt; + move = true; + } + if (move) { + ele = ele.move(spec); + } + } else { + var newParentValSpecd = "parent" in obj.data; + var parent = obj.data.parent; + if (newParentValSpecd && (parent != null || _data2.parent != null) && parent != _data2.parent) { + if (parent === void 0) { + parent = null; + } + if (parent != null) { + parent = "" + parent; + } + ele = ele.move({ + parent + }); + } + } + } + if (obj.position) { + ele.position(obj.position); + } + var checkSwitch = function checkSwitch2(k, trueFnName, falseFnName) { + var obj_k = obj[k]; + if (obj_k != null && obj_k !== p2[k]) { + if (obj_k) { + ele[trueFnName](); + } else { + ele[falseFnName](); + } + } + }; + checkSwitch("removed", "remove", "restore"); + checkSwitch("selected", "select", "unselect"); + checkSwitch("selectable", "selectify", "unselectify"); + checkSwitch("locked", "lock", "unlock"); + checkSwitch("grabbable", "grabify", "ungrabify"); + checkSwitch("pannable", "panify", "unpanify"); + if (obj.classes != null) { + ele.classes(obj.classes); + } + cy.endBatch(); + return this; + } else if (obj === void 0) { + var json = { + data: copy(p2.data), + position: copy(p2.position), + group: p2.group, + removed: p2.removed, + selected: p2.selected, + selectable: p2.selectable, + locked: p2.locked, + grabbable: p2.grabbable, + pannable: p2.pannable, + classes: null + }; + json.classes = ""; + var i2 = 0; + p2.classes.forEach(function(cls) { + return json.classes += i2++ === 0 ? cls : " " + cls; + }); + return json; + } + }; + elesfn$1.jsons = function() { + var jsons = []; + for (var i2 = 0; i2 < this.length; i2++) { + var ele = this[i2]; + var json = ele.json(); + jsons.push(json); + } + return jsons; + }; + elesfn$1.clone = function() { + var cy = this.cy(); + var elesArr = []; + for (var i2 = 0; i2 < this.length; i2++) { + var ele = this[i2]; + var json = ele.json(); + var clone2 = new Element(cy, json, false); + elesArr.push(clone2); + } + return new Collection(cy, elesArr); + }; + elesfn$1.copy = elesfn$1.clone; + elesfn$1.restore = function() { + var notifyRenderer = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : true; + var addToPool = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : true; + var self2 = this; + var cy = self2.cy(); + var cy_p = cy._private; + var nodes2 = []; + var edges = []; + var elements2; + for (var _i3 = 0, l = self2.length; _i3 < l; _i3++) { + var ele = self2[_i3]; + if (addToPool && !ele.removed()) { + continue; + } + if (ele.isNode()) { + nodes2.push(ele); + } else { + edges.push(ele); + } + } + elements2 = nodes2.concat(edges); + var i2; + var removeFromElements = function removeFromElements2() { + elements2.splice(i2, 1); + i2--; + }; + for (i2 = 0; i2 < elements2.length; i2++) { + var _ele2 = elements2[i2]; + var _private = _ele2._private; + var _data3 = _private.data; + _ele2.clearTraversalCache(); + if (!addToPool && !_private.removed) + ; + else if (_data3.id === void 0) { + _data3.id = uuid(); + } else if (number$1(_data3.id)) { + _data3.id = "" + _data3.id; + } else if (emptyString(_data3.id) || !string(_data3.id)) { + error("Can not create element with invalid string ID `" + _data3.id + "`"); + removeFromElements(); + continue; + } else if (cy.hasElementWithId(_data3.id)) { + error("Can not create second element with ID `" + _data3.id + "`"); + removeFromElements(); + continue; + } + var id = _data3.id; + if (_ele2.isNode()) { + var pos = _private.position; + if (pos.x == null) { + pos.x = 0; + } + if (pos.y == null) { + pos.y = 0; + } + } + if (_ele2.isEdge()) { + var edge = _ele2; + var fields = ["source", "target"]; + var fieldsLength = fields.length; + var badSourceOrTarget = false; + for (var j = 0; j < fieldsLength; j++) { + var field = fields[j]; + var val = _data3[field]; + if (number$1(val)) { + val = _data3[field] = "" + _data3[field]; + } + if (val == null || val === "") { + error("Can not create edge `" + id + "` with unspecified " + field); + badSourceOrTarget = true; + } else if (!cy.hasElementWithId(val)) { + error("Can not create edge `" + id + "` with nonexistant " + field + " `" + val + "`"); + badSourceOrTarget = true; + } + } + if (badSourceOrTarget) { + removeFromElements(); + continue; + } + var src = cy.getElementById(_data3.source); + var tgt = cy.getElementById(_data3.target); + if (src.same(tgt)) { + src._private.edges.push(edge); + } else { + src._private.edges.push(edge); + tgt._private.edges.push(edge); + } + edge._private.source = src; + edge._private.target = tgt; + } + _private.map = new Map$2(); + _private.map.set(id, { + ele: _ele2, + index: 0 + }); + _private.removed = false; + if (addToPool) { + cy.addToPool(_ele2); + } + } + for (var _i4 = 0; _i4 < nodes2.length; _i4++) { + var node = nodes2[_i4]; + var _data4 = node._private.data; + if (number$1(_data4.parent)) { + _data4.parent = "" + _data4.parent; + } + var parentId = _data4.parent; + var specifiedParent = parentId != null; + if (specifiedParent || node._private.parent) { + var parent = node._private.parent ? cy.collection().merge(node._private.parent) : cy.getElementById(parentId); + if (parent.empty()) { + _data4.parent = void 0; + } else if (parent[0].removed()) { + warn("Node added with missing parent, reference to parent removed"); + _data4.parent = void 0; + node._private.parent = null; + } else { + var selfAsParent = false; + var ancestor = parent; + while (!ancestor.empty()) { + if (node.same(ancestor)) { + selfAsParent = true; + _data4.parent = void 0; + break; + } + ancestor = ancestor.parent(); + } + if (!selfAsParent) { + parent[0]._private.children.push(node); + node._private.parent = parent[0]; + cy_p.hasCompoundNodes = true; + } + } + } + } + if (elements2.length > 0) { + var restored = elements2.length === self2.length ? self2 : new Collection(cy, elements2); + for (var _i5 = 0; _i5 < restored.length; _i5++) { + var _ele3 = restored[_i5]; + if (_ele3.isNode()) { + continue; + } + _ele3.parallelEdges().clearTraversalCache(); + _ele3.source().clearTraversalCache(); + _ele3.target().clearTraversalCache(); + } + var toUpdateStyle; + if (cy_p.hasCompoundNodes) { + toUpdateStyle = cy.collection().merge(restored).merge(restored.connectedNodes()).merge(restored.parent()); + } else { + toUpdateStyle = restored; + } + toUpdateStyle.dirtyCompoundBoundsCache().dirtyBoundingBoxCache().updateStyle(notifyRenderer); + if (notifyRenderer) { + restored.emitAndNotify("add"); + } else if (addToPool) { + restored.emit("add"); + } + } + return self2; + }; + elesfn$1.removed = function() { + var ele = this[0]; + return ele && ele._private.removed; + }; + elesfn$1.inside = function() { + var ele = this[0]; + return ele && !ele._private.removed; + }; + elesfn$1.remove = function() { + var notifyRenderer = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : true; + var removeFromPool = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : true; + var self2 = this; + var elesToRemove = []; + var elesToRemoveIds = {}; + var cy = self2._private.cy; + function addConnectedEdges(node) { + var edges = node._private.edges; + for (var i3 = 0; i3 < edges.length; i3++) { + add(edges[i3]); + } + } + function addChildren2(node) { + var children = node._private.children; + for (var i3 = 0; i3 < children.length; i3++) { + add(children[i3]); + } + } + function add(ele2) { + var alreadyAdded = elesToRemoveIds[ele2.id()]; + if (removeFromPool && ele2.removed() || alreadyAdded) { + return; + } else { + elesToRemoveIds[ele2.id()] = true; + } + if (ele2.isNode()) { + elesToRemove.push(ele2); + addConnectedEdges(ele2); + addChildren2(ele2); + } else { + elesToRemove.unshift(ele2); + } + } + for (var i2 = 0, l = self2.length; i2 < l; i2++) { + var ele = self2[i2]; + add(ele); + } + function removeEdgeRef(node, edge) { + var connectedEdges = node._private.edges; + removeFromArray(connectedEdges, edge); + node.clearTraversalCache(); + } + function removeParallelRef(pllEdge2) { + pllEdge2.clearTraversalCache(); + } + var alteredParents = []; + alteredParents.ids = {}; + function removeChildRef(parent2, ele2) { + ele2 = ele2[0]; + parent2 = parent2[0]; + var children = parent2._private.children; + var pid = parent2.id(); + removeFromArray(children, ele2); + ele2._private.parent = null; + if (!alteredParents.ids[pid]) { + alteredParents.ids[pid] = true; + alteredParents.push(parent2); + } + } + self2.dirtyCompoundBoundsCache(); + if (removeFromPool) { + cy.removeFromPool(elesToRemove); + } + for (var _i6 = 0; _i6 < elesToRemove.length; _i6++) { + var _ele4 = elesToRemove[_i6]; + if (_ele4.isEdge()) { + var src = _ele4.source()[0]; + var tgt = _ele4.target()[0]; + removeEdgeRef(src, _ele4); + removeEdgeRef(tgt, _ele4); + var pllEdges = _ele4.parallelEdges(); + for (var j = 0; j < pllEdges.length; j++) { + var pllEdge = pllEdges[j]; + removeParallelRef(pllEdge); + if (pllEdge.isBundledBezier()) { + pllEdge.dirtyBoundingBoxCache(); + } + } + } else { + var parent = _ele4.parent(); + if (parent.length !== 0) { + removeChildRef(parent, _ele4); + } + } + if (removeFromPool) { + _ele4._private.removed = true; + } + } + var elesStillInside = cy._private.elements; + cy._private.hasCompoundNodes = false; + for (var _i7 = 0; _i7 < elesStillInside.length; _i7++) { + var _ele5 = elesStillInside[_i7]; + if (_ele5.isParent()) { + cy._private.hasCompoundNodes = true; + break; + } + } + var removedElements = new Collection(this.cy(), elesToRemove); + if (removedElements.size() > 0) { + if (notifyRenderer) { + removedElements.emitAndNotify("remove"); + } else if (removeFromPool) { + removedElements.emit("remove"); + } + } + for (var _i8 = 0; _i8 < alteredParents.length; _i8++) { + var _ele6 = alteredParents[_i8]; + if (!removeFromPool || !_ele6.removed()) { + _ele6.updateStyle(); + } + } + return removedElements; + }; + elesfn$1.move = function(struct) { + var cy = this._private.cy; + var eles = this; + var notifyRenderer = false; + var modifyPool = false; + var toString2 = function toString3(id) { + return id == null ? id : "" + id; + }; + if (struct.source !== void 0 || struct.target !== void 0) { + var srcId = toString2(struct.source); + var tgtId = toString2(struct.target); + var srcExists = srcId != null && cy.hasElementWithId(srcId); + var tgtExists = tgtId != null && cy.hasElementWithId(tgtId); + if (srcExists || tgtExists) { + cy.batch(function() { + eles.remove(notifyRenderer, modifyPool); + eles.emitAndNotify("moveout"); + for (var i2 = 0; i2 < eles.length; i2++) { + var ele = eles[i2]; + var _data5 = ele._private.data; + if (ele.isEdge()) { + if (srcExists) { + _data5.source = srcId; + } + if (tgtExists) { + _data5.target = tgtId; + } + } + } + eles.restore(notifyRenderer, modifyPool); + }); + eles.emitAndNotify("move"); + } + } else if (struct.parent !== void 0) { + var parentId = toString2(struct.parent); + var parentExists = parentId === null || cy.hasElementWithId(parentId); + if (parentExists) { + var pidToAssign = parentId === null ? void 0 : parentId; + cy.batch(function() { + var updated = eles.remove(notifyRenderer, modifyPool); + updated.emitAndNotify("moveout"); + for (var i2 = 0; i2 < eles.length; i2++) { + var ele = eles[i2]; + var _data6 = ele._private.data; + if (ele.isNode()) { + _data6.parent = pidToAssign; + } + } + updated.restore(notifyRenderer, modifyPool); + }); + eles.emitAndNotify("move"); + } + } + return this; + }; + [elesfn$j, elesfn$i, elesfn$h, elesfn$g, elesfn$f, data, elesfn$d, dimensions, elesfn$9, elesfn$8, elesfn$7, elesfn$6, elesfn$5, elesfn$4, elesfn$3, elesfn$2].forEach(function(props) { + extend(elesfn$1, props); + }); + var corefn$9 = { + add: function add(opts) { + var elements2; + var cy = this; + if (elementOrCollection(opts)) { + var eles = opts; + if (eles._private.cy === cy) { + elements2 = eles.restore(); + } else { + var jsons = []; + for (var i2 = 0; i2 < eles.length; i2++) { + var ele = eles[i2]; + jsons.push(ele.json()); + } + elements2 = new Collection(cy, jsons); + } + } else if (array(opts)) { + var _jsons = opts; + elements2 = new Collection(cy, _jsons); + } else if (plainObject(opts) && (array(opts.nodes) || array(opts.edges))) { + var elesByGroup = opts; + var _jsons2 = []; + var grs = ["nodes", "edges"]; + for (var _i = 0, il = grs.length; _i < il; _i++) { + var group = grs[_i]; + var elesArray = elesByGroup[group]; + if (array(elesArray)) { + for (var j = 0, jl = elesArray.length; j < jl; j++) { + var json = extend({ + group + }, elesArray[j]); + _jsons2.push(json); + } + } + } + elements2 = new Collection(cy, _jsons2); + } else { + var _json = opts; + elements2 = new Element(cy, _json).collection(); + } + return elements2; + }, + remove: function remove(collection2) { + if (elementOrCollection(collection2)) + ; + else if (string(collection2)) { + var selector = collection2; + collection2 = this.$(selector); + } + return collection2.remove(); + } + }; + /*! Bezier curve function generator. Copyright Gaetan Renaudeau. MIT License: http://en.wikipedia.org/wiki/MIT_License */ + function generateCubicBezier(mX1, mY1, mX2, mY2) { + var NEWTON_ITERATIONS = 4, NEWTON_MIN_SLOPE = 1e-3, SUBDIVISION_PRECISION = 1e-7, SUBDIVISION_MAX_ITERATIONS = 10, kSplineTableSize = 11, kSampleStepSize = 1 / (kSplineTableSize - 1), float32ArraySupported = typeof Float32Array !== "undefined"; + if (arguments.length !== 4) { + return false; + } + for (var i2 = 0; i2 < 4; ++i2) { + if (typeof arguments[i2] !== "number" || isNaN(arguments[i2]) || !isFinite(arguments[i2])) { + return false; + } + } + mX1 = Math.min(mX1, 1); + mX2 = Math.min(mX2, 1); + mX1 = Math.max(mX1, 0); + mX2 = Math.max(mX2, 0); + var mSampleValues = float32ArraySupported ? new Float32Array(kSplineTableSize) : new Array(kSplineTableSize); + function A(aA1, aA2) { + return 1 - 3 * aA2 + 3 * aA1; + } + function B(aA1, aA2) { + return 3 * aA2 - 6 * aA1; + } + function C(aA1) { + return 3 * aA1; + } + function calcBezier(aT, aA1, aA2) { + return ((A(aA1, aA2) * aT + B(aA1, aA2)) * aT + C(aA1)) * aT; + } + function getSlope(aT, aA1, aA2) { + return 3 * A(aA1, aA2) * aT * aT + 2 * B(aA1, aA2) * aT + C(aA1); + } + function newtonRaphsonIterate(aX, aGuessT) { + for (var _i = 0; _i < NEWTON_ITERATIONS; ++_i) { + var currentSlope = getSlope(aGuessT, mX1, mX2); + if (currentSlope === 0) { + return aGuessT; + } + var currentX = calcBezier(aGuessT, mX1, mX2) - aX; + aGuessT -= currentX / currentSlope; + } + return aGuessT; + } + function calcSampleValues() { + for (var _i2 = 0; _i2 < kSplineTableSize; ++_i2) { + mSampleValues[_i2] = calcBezier(_i2 * kSampleStepSize, mX1, mX2); + } + } + function binarySubdivide(aX, aA, aB) { + var currentX, currentT, i3 = 0; + do { + currentT = aA + (aB - aA) / 2; + currentX = calcBezier(currentT, mX1, mX2) - aX; + if (currentX > 0) { + aB = currentT; + } else { + aA = currentT; + } + } while (Math.abs(currentX) > SUBDIVISION_PRECISION && ++i3 < SUBDIVISION_MAX_ITERATIONS); + return currentT; + } + function getTForX(aX) { + var intervalStart = 0, currentSample = 1, lastSample = kSplineTableSize - 1; + for (; currentSample !== lastSample && mSampleValues[currentSample] <= aX; ++currentSample) { + intervalStart += kSampleStepSize; + } + --currentSample; + var dist2 = (aX - mSampleValues[currentSample]) / (mSampleValues[currentSample + 1] - mSampleValues[currentSample]), guessForT = intervalStart + dist2 * kSampleStepSize, initialSlope = getSlope(guessForT, mX1, mX2); + if (initialSlope >= NEWTON_MIN_SLOPE) { + return newtonRaphsonIterate(aX, guessForT); + } else if (initialSlope === 0) { + return guessForT; + } else { + return binarySubdivide(aX, intervalStart, intervalStart + kSampleStepSize); + } + } + var _precomputed = false; + function precompute() { + _precomputed = true; + if (mX1 !== mY1 || mX2 !== mY2) { + calcSampleValues(); + } + } + var f = function f2(aX) { + if (!_precomputed) { + precompute(); + } + if (mX1 === mY1 && mX2 === mY2) { + return aX; + } + if (aX === 0) { + return 0; + } + if (aX === 1) { + return 1; + } + return calcBezier(getTForX(aX), mY1, mY2); + }; + f.getControlPoints = function() { + return [{ + x: mX1, + y: mY1 + }, { + x: mX2, + y: mY2 + }]; + }; + var str = "generateBezier(" + [mX1, mY1, mX2, mY2] + ")"; + f.toString = function() { + return str; + }; + return f; + } + /*! Runge-Kutta spring physics function generator. Adapted from Framer.js, copyright Koen Bok. MIT License: http://en.wikipedia.org/wiki/MIT_License */ + var generateSpringRK4 = function() { + function springAccelerationForState(state) { + return -state.tension * state.x - state.friction * state.v; + } + function springEvaluateStateWithDerivative(initialState, dt, derivative) { + var state = { + x: initialState.x + derivative.dx * dt, + v: initialState.v + derivative.dv * dt, + tension: initialState.tension, + friction: initialState.friction + }; + return { + dx: state.v, + dv: springAccelerationForState(state) + }; + } + function springIntegrateState(state, dt) { + var a = { + dx: state.v, + dv: springAccelerationForState(state) + }, b = springEvaluateStateWithDerivative(state, dt * 0.5, a), c = springEvaluateStateWithDerivative(state, dt * 0.5, b), d = springEvaluateStateWithDerivative(state, dt, c), dxdt = 1 / 6 * (a.dx + 2 * (b.dx + c.dx) + d.dx), dvdt = 1 / 6 * (a.dv + 2 * (b.dv + c.dv) + d.dv); + state.x = state.x + dxdt * dt; + state.v = state.v + dvdt * dt; + return state; + } + return function springRK4Factory(tension, friction, duration) { + var initState = { + x: -1, + v: 0, + tension: null, + friction: null + }, path = [0], time_lapsed = 0, tolerance = 1 / 1e4, DT = 16 / 1e3, have_duration, dt, last_state; + tension = parseFloat(tension) || 500; + friction = parseFloat(friction) || 20; + duration = duration || null; + initState.tension = tension; + initState.friction = friction; + have_duration = duration !== null; + if (have_duration) { + time_lapsed = springRK4Factory(tension, friction); + dt = time_lapsed / duration * DT; + } else { + dt = DT; + } + for (; ; ) { + last_state = springIntegrateState(last_state || initState, dt); + path.push(1 + last_state.x); + time_lapsed += 16; + if (!(Math.abs(last_state.x) > tolerance && Math.abs(last_state.v) > tolerance)) { + break; + } + } + return !have_duration ? time_lapsed : function(percentComplete) { + return path[percentComplete * (path.length - 1) | 0]; + }; + }; + }(); + var cubicBezier = function cubicBezier2(t1, p1, t2, p2) { + var bezier = generateCubicBezier(t1, p1, t2, p2); + return function(start, end, percent) { + return start + (end - start) * bezier(percent); + }; + }; + var easings = { + "linear": function linear(start, end, percent) { + return start + (end - start) * percent; + }, + // default easings + "ease": cubicBezier(0.25, 0.1, 0.25, 1), + "ease-in": cubicBezier(0.42, 0, 1, 1), + "ease-out": cubicBezier(0, 0, 0.58, 1), + "ease-in-out": cubicBezier(0.42, 0, 0.58, 1), + // sine + "ease-in-sine": cubicBezier(0.47, 0, 0.745, 0.715), + "ease-out-sine": cubicBezier(0.39, 0.575, 0.565, 1), + "ease-in-out-sine": cubicBezier(0.445, 0.05, 0.55, 0.95), + // quad + "ease-in-quad": cubicBezier(0.55, 0.085, 0.68, 0.53), + "ease-out-quad": cubicBezier(0.25, 0.46, 0.45, 0.94), + "ease-in-out-quad": cubicBezier(0.455, 0.03, 0.515, 0.955), + // cubic + "ease-in-cubic": cubicBezier(0.55, 0.055, 0.675, 0.19), + "ease-out-cubic": cubicBezier(0.215, 0.61, 0.355, 1), + "ease-in-out-cubic": cubicBezier(0.645, 0.045, 0.355, 1), + // quart + "ease-in-quart": cubicBezier(0.895, 0.03, 0.685, 0.22), + "ease-out-quart": cubicBezier(0.165, 0.84, 0.44, 1), + "ease-in-out-quart": cubicBezier(0.77, 0, 0.175, 1), + // quint + "ease-in-quint": cubicBezier(0.755, 0.05, 0.855, 0.06), + "ease-out-quint": cubicBezier(0.23, 1, 0.32, 1), + "ease-in-out-quint": cubicBezier(0.86, 0, 0.07, 1), + // expo + "ease-in-expo": cubicBezier(0.95, 0.05, 0.795, 0.035), + "ease-out-expo": cubicBezier(0.19, 1, 0.22, 1), + "ease-in-out-expo": cubicBezier(1, 0, 0, 1), + // circ + "ease-in-circ": cubicBezier(0.6, 0.04, 0.98, 0.335), + "ease-out-circ": cubicBezier(0.075, 0.82, 0.165, 1), + "ease-in-out-circ": cubicBezier(0.785, 0.135, 0.15, 0.86), + // user param easings... + "spring": function spring(tension, friction, duration) { + if (duration === 0) { + return easings.linear; + } + var spring2 = generateSpringRK4(tension, friction, duration); + return function(start, end, percent) { + return start + (end - start) * spring2(percent); + }; + }, + "cubic-bezier": cubicBezier + }; + function getEasedValue(type, start, end, percent, easingFn) { + if (percent === 1) { + return end; + } + if (start === end) { + return end; + } + var val = easingFn(start, end, percent); + if (type == null) { + return val; + } + if (type.roundValue || type.color) { + val = Math.round(val); + } + if (type.min !== void 0) { + val = Math.max(val, type.min); + } + if (type.max !== void 0) { + val = Math.min(val, type.max); + } + return val; + } + function getValue(prop, spec) { + if (prop.pfValue != null || prop.value != null) { + if (prop.pfValue != null && (spec == null || spec.type.units !== "%")) { + return prop.pfValue; + } else { + return prop.value; + } + } else { + return prop; + } + } + function ease(startProp, endProp, percent, easingFn, propSpec) { + var type = propSpec != null ? propSpec.type : null; + if (percent < 0) { + percent = 0; + } else if (percent > 1) { + percent = 1; + } + var start = getValue(startProp, propSpec); + var end = getValue(endProp, propSpec); + if (number$1(start) && number$1(end)) { + return getEasedValue(type, start, end, percent, easingFn); + } else if (array(start) && array(end)) { + var easedArr = []; + for (var i2 = 0; i2 < end.length; i2++) { + var si = start[i2]; + var ei = end[i2]; + if (si != null && ei != null) { + var val = getEasedValue(type, si, ei, percent, easingFn); + easedArr.push(val); + } else { + easedArr.push(ei); + } + } + return easedArr; + } + return void 0; + } + function step$1(self2, ani, now2, isCore) { + var isEles = !isCore; + var _p = self2._private; + var ani_p = ani._private; + var pEasing = ani_p.easing; + var startTime = ani_p.startTime; + var cy = isCore ? self2 : self2.cy(); + var style = cy.style(); + if (!ani_p.easingImpl) { + if (pEasing == null) { + ani_p.easingImpl = easings["linear"]; + } else { + var easingVals; + if (string(pEasing)) { + var easingProp = style.parse("transition-timing-function", pEasing); + easingVals = easingProp.value; + } else { + easingVals = pEasing; + } + var name, args; + if (string(easingVals)) { + name = easingVals; + args = []; + } else { + name = easingVals[1]; + args = easingVals.slice(2).map(function(n) { + return +n; + }); + } + if (args.length > 0) { + if (name === "spring") { + args.push(ani_p.duration); + } + ani_p.easingImpl = easings[name].apply(null, args); + } else { + ani_p.easingImpl = easings[name]; + } + } + } + var easing = ani_p.easingImpl; + var percent; + if (ani_p.duration === 0) { + percent = 1; + } else { + percent = (now2 - startTime) / ani_p.duration; + } + if (ani_p.applying) { + percent = ani_p.progress; + } + if (percent < 0) { + percent = 0; + } else if (percent > 1) { + percent = 1; + } + if (ani_p.delay == null) { + var startPos = ani_p.startPosition; + var endPos = ani_p.position; + if (endPos && isEles && !self2.locked()) { + var newPos = {}; + if (valid(startPos.x, endPos.x)) { + newPos.x = ease(startPos.x, endPos.x, percent, easing); + } + if (valid(startPos.y, endPos.y)) { + newPos.y = ease(startPos.y, endPos.y, percent, easing); + } + self2.position(newPos); + } + var startPan = ani_p.startPan; + var endPan = ani_p.pan; + var pan = _p.pan; + var animatingPan = endPan != null && isCore; + if (animatingPan) { + if (valid(startPan.x, endPan.x)) { + pan.x = ease(startPan.x, endPan.x, percent, easing); + } + if (valid(startPan.y, endPan.y)) { + pan.y = ease(startPan.y, endPan.y, percent, easing); + } + self2.emit("pan"); + } + var startZoom = ani_p.startZoom; + var endZoom = ani_p.zoom; + var animatingZoom = endZoom != null && isCore; + if (animatingZoom) { + if (valid(startZoom, endZoom)) { + _p.zoom = bound(_p.minZoom, ease(startZoom, endZoom, percent, easing), _p.maxZoom); + } + self2.emit("zoom"); + } + if (animatingPan || animatingZoom) { + self2.emit("viewport"); + } + var props = ani_p.style; + if (props && props.length > 0 && isEles) { + for (var i2 = 0; i2 < props.length; i2++) { + var prop = props[i2]; + var _name = prop.name; + var end = prop; + var start = ani_p.startStyle[_name]; + var propSpec = style.properties[start.name]; + var easedVal = ease(start, end, percent, easing, propSpec); + style.overrideBypass(self2, _name, easedVal); + } + self2.emit("style"); + } + } + ani_p.progress = percent; + return percent; + } + function valid(start, end) { + if (start == null || end == null) { + return false; + } + if (number$1(start) && number$1(end)) { + return true; + } else if (start && end) { + return true; + } + return false; + } + function startAnimation(self2, ani, now2, isCore) { + var ani_p = ani._private; + ani_p.started = true; + ani_p.startTime = now2 - ani_p.progress * ani_p.duration; + } + function stepAll(now2, cy) { + var eles = cy._private.aniEles; + var doneEles = []; + function stepOne(ele2, isCore) { + var _p = ele2._private; + var current = _p.animation.current; + var queue = _p.animation.queue; + var ranAnis = false; + if (current.length === 0) { + var next2 = queue.shift(); + if (next2) { + current.push(next2); + } + } + var callbacks = function callbacks2(_callbacks) { + for (var j = _callbacks.length - 1; j >= 0; j--) { + var cb = _callbacks[j]; + cb(); + } + _callbacks.splice(0, _callbacks.length); + }; + for (var i2 = current.length - 1; i2 >= 0; i2--) { + var ani = current[i2]; + var ani_p = ani._private; + if (ani_p.stopped) { + current.splice(i2, 1); + ani_p.hooked = false; + ani_p.playing = false; + ani_p.started = false; + callbacks(ani_p.frames); + continue; + } + if (!ani_p.playing && !ani_p.applying) { + continue; + } + if (ani_p.playing && ani_p.applying) { + ani_p.applying = false; + } + if (!ani_p.started) { + startAnimation(ele2, ani, now2); + } + step$1(ele2, ani, now2, isCore); + if (ani_p.applying) { + ani_p.applying = false; + } + callbacks(ani_p.frames); + if (ani_p.step != null) { + ani_p.step(now2); + } + if (ani.completed()) { + current.splice(i2, 1); + ani_p.hooked = false; + ani_p.playing = false; + ani_p.started = false; + callbacks(ani_p.completes); + } + ranAnis = true; + } + if (!isCore && current.length === 0 && queue.length === 0) { + doneEles.push(ele2); + } + return ranAnis; + } + var ranEleAni = false; + for (var e = 0; e < eles.length; e++) { + var ele = eles[e]; + var handledThisEle = stepOne(ele); + ranEleAni = ranEleAni || handledThisEle; + } + var ranCoreAni = stepOne(cy, true); + if (ranEleAni || ranCoreAni) { + if (eles.length > 0) { + cy.notify("draw", eles); + } else { + cy.notify("draw"); + } + } + eles.unmerge(doneEles); + cy.emit("step"); + } + var corefn$8 = { + // pull in animation functions + animate: define.animate(), + animation: define.animation(), + animated: define.animated(), + clearQueue: define.clearQueue(), + delay: define.delay(), + delayAnimation: define.delayAnimation(), + stop: define.stop(), + addToAnimationPool: function addToAnimationPool(eles) { + var cy = this; + if (!cy.styleEnabled()) { + return; + } + cy._private.aniEles.merge(eles); + }, + stopAnimationLoop: function stopAnimationLoop() { + this._private.animationsRunning = false; + }, + startAnimationLoop: function startAnimationLoop() { + var cy = this; + cy._private.animationsRunning = true; + if (!cy.styleEnabled()) { + return; + } + function headlessStep() { + if (!cy._private.animationsRunning) { + return; + } + requestAnimationFrame2(function animationStep(now2) { + stepAll(now2, cy); + headlessStep(); + }); + } + var renderer3 = cy.renderer(); + if (renderer3 && renderer3.beforeRender) { + renderer3.beforeRender(function rendererAnimationStep(willDraw, now2) { + stepAll(now2, cy); + }, renderer3.beforeRenderPriorities.animations); + } else { + headlessStep(); + } + } + }; + var emitterOptions = { + qualifierCompare: function qualifierCompare(selector1, selector2) { + if (selector1 == null || selector2 == null) { + return selector1 == null && selector2 == null; + } else { + return selector1.sameText(selector2); + } + }, + eventMatches: function eventMatches(cy, listener, eventObj) { + var selector = listener.qualifier; + if (selector != null) { + return cy !== eventObj.target && element(eventObj.target) && selector.matches(eventObj.target); + } + return true; + }, + addEventFields: function addEventFields(cy, evt) { + evt.cy = cy; + evt.target = cy; + }, + callbackContext: function callbackContext(cy, listener, eventObj) { + return listener.qualifier != null ? eventObj.target : cy; + } + }; + var argSelector = function argSelector2(arg) { + if (string(arg)) { + return new Selector(arg); + } else { + return arg; + } + }; + var elesfn = { + createEmitter: function createEmitter() { + var _p = this._private; + if (!_p.emitter) { + _p.emitter = new Emitter(emitterOptions, this); + } + return this; + }, + emitter: function emitter() { + return this._private.emitter; + }, + on: function on(events, selector, callback) { + this.emitter().on(events, argSelector(selector), callback); + return this; + }, + removeListener: function removeListener(events, selector, callback) { + this.emitter().removeListener(events, argSelector(selector), callback); + return this; + }, + removeAllListeners: function removeAllListeners() { + this.emitter().removeAllListeners(); + return this; + }, + one: function one(events, selector, callback) { + this.emitter().one(events, argSelector(selector), callback); + return this; + }, + once: function once(events, selector, callback) { + this.emitter().one(events, argSelector(selector), callback); + return this; + }, + emit: function emit(events, extraParams) { + this.emitter().emit(events, extraParams); + return this; + }, + emitAndNotify: function emitAndNotify(event2, eles) { + this.emit(event2); + this.notify(event2, eles); + return this; + } + }; + define.eventAliasesOn(elesfn); + var corefn$7 = { + png: function png(options) { + var renderer3 = this._private.renderer; + options = options || {}; + return renderer3.png(options); + }, + jpg: function jpg(options) { + var renderer3 = this._private.renderer; + options = options || {}; + options.bg = options.bg || "#fff"; + return renderer3.jpg(options); + } + }; + corefn$7.jpeg = corefn$7.jpg; + var corefn$6 = { + layout: function layout2(options) { + var cy = this; + if (options == null) { + error("Layout options must be specified to make a layout"); + return; + } + if (options.name == null) { + error("A `name` must be specified to make a layout"); + return; + } + var name = options.name; + var Layout2 = cy.extension("layout", name); + if (Layout2 == null) { + error("No such layout `" + name + "` found. Did you forget to import it and `cytoscape.use()` it?"); + return; + } + var eles; + if (string(options.eles)) { + eles = cy.$(options.eles); + } else { + eles = options.eles != null ? options.eles : cy.$(); + } + var layout3 = new Layout2(extend({}, options, { + cy, + eles + })); + return layout3; + } + }; + corefn$6.createLayout = corefn$6.makeLayout = corefn$6.layout; + var corefn$5 = { + notify: function notify(eventName, eventEles) { + var _p = this._private; + if (this.batching()) { + _p.batchNotifications = _p.batchNotifications || {}; + var eles = _p.batchNotifications[eventName] = _p.batchNotifications[eventName] || this.collection(); + if (eventEles != null) { + eles.merge(eventEles); + } + return; + } + if (!_p.notificationsEnabled) { + return; + } + var renderer3 = this.renderer(); + if (this.destroyed() || !renderer3) { + return; + } + renderer3.notify(eventName, eventEles); + }, + notifications: function notifications(bool) { + var p2 = this._private; + if (bool === void 0) { + return p2.notificationsEnabled; + } else { + p2.notificationsEnabled = bool ? true : false; + } + return this; + }, + noNotifications: function noNotifications(callback) { + this.notifications(false); + callback(); + this.notifications(true); + }, + batching: function batching() { + return this._private.batchCount > 0; + }, + startBatch: function startBatch() { + var _p = this._private; + if (_p.batchCount == null) { + _p.batchCount = 0; + } + if (_p.batchCount === 0) { + _p.batchStyleEles = this.collection(); + _p.batchNotifications = {}; + } + _p.batchCount++; + return this; + }, + endBatch: function endBatch() { + var _p = this._private; + if (_p.batchCount === 0) { + return this; + } + _p.batchCount--; + if (_p.batchCount === 0) { + _p.batchStyleEles.updateStyle(); + var renderer3 = this.renderer(); + Object.keys(_p.batchNotifications).forEach(function(eventName) { + var eles = _p.batchNotifications[eventName]; + if (eles.empty()) { + renderer3.notify(eventName); + } else { + renderer3.notify(eventName, eles); + } + }); + } + return this; + }, + batch: function batch(callback) { + this.startBatch(); + callback(); + this.endBatch(); + return this; + }, + // for backwards compatibility + batchData: function batchData(map) { + var cy = this; + return this.batch(function() { + var ids = Object.keys(map); + for (var i2 = 0; i2 < ids.length; i2++) { + var id = ids[i2]; + var data2 = map[id]; + var ele = cy.getElementById(id); + ele.data(data2); + } + }); + } + }; + var rendererDefaults = defaults$g({ + hideEdgesOnViewport: false, + textureOnViewport: false, + motionBlur: false, + motionBlurOpacity: 0.05, + pixelRatio: void 0, + desktopTapThreshold: 4, + touchTapThreshold: 8, + wheelSensitivity: 1, + debug: false, + showFps: false + }); + var corefn$4 = { + renderTo: function renderTo(context, zoom, pan, pxRatio) { + var r = this._private.renderer; + r.renderTo(context, zoom, pan, pxRatio); + return this; + }, + renderer: function renderer3() { + return this._private.renderer; + }, + forceRender: function forceRender() { + this.notify("draw"); + return this; + }, + resize: function resize() { + this.invalidateSize(); + this.emitAndNotify("resize"); + return this; + }, + initRenderer: function initRenderer(options) { + var cy = this; + var RendererProto = cy.extension("renderer", options.name); + if (RendererProto == null) { + error("Can not initialise: No such renderer `".concat(options.name, "` found. Did you forget to import it and `cytoscape.use()` it?")); + return; + } + if (options.wheelSensitivity !== void 0) { + warn("You have set a custom wheel sensitivity. This will make your app zoom unnaturally when using mainstream mice. You should change this value from the default only if you can guarantee that all your users will use the same hardware and OS configuration as your current machine."); + } + var rOpts = rendererDefaults(options); + rOpts.cy = cy; + cy._private.renderer = new RendererProto(rOpts); + this.notify("init"); + }, + destroyRenderer: function destroyRenderer() { + var cy = this; + cy.notify("destroy"); + var domEle = cy.container(); + if (domEle) { + domEle._cyreg = null; + while (domEle.childNodes.length > 0) { + domEle.removeChild(domEle.childNodes[0]); + } + } + cy._private.renderer = null; + cy.mutableElements().forEach(function(ele) { + var _p = ele._private; + _p.rscratch = {}; + _p.rstyle = {}; + _p.animation.current = []; + _p.animation.queue = []; + }); + }, + onRender: function onRender(fn2) { + return this.on("render", fn2); + }, + offRender: function offRender(fn2) { + return this.off("render", fn2); + } + }; + corefn$4.invalidateDimensions = corefn$4.resize; + var corefn$3 = { + // get a collection + // - empty collection on no args + // - collection of elements in the graph on selector arg + // - guarantee a returned collection when elements or collection specified + collection: function collection2(eles, opts) { + if (string(eles)) { + return this.$(eles); + } else if (elementOrCollection(eles)) { + return eles.collection(); + } else if (array(eles)) { + if (!opts) { + opts = {}; + } + return new Collection(this, eles, opts.unique, opts.removed); + } + return new Collection(this); + }, + nodes: function nodes2(selector) { + var nodes3 = this.$(function(ele) { + return ele.isNode(); + }); + if (selector) { + return nodes3.filter(selector); + } + return nodes3; + }, + edges: function edges(selector) { + var edges2 = this.$(function(ele) { + return ele.isEdge(); + }); + if (selector) { + return edges2.filter(selector); + } + return edges2; + }, + // search the graph like jQuery + $: function $(selector) { + var eles = this._private.elements; + if (selector) { + return eles.filter(selector); + } else { + return eles.spawnSelf(); + } + }, + mutableElements: function mutableElements() { + return this._private.elements; + } + }; + corefn$3.elements = corefn$3.filter = corefn$3.$; + var styfn$8 = {}; + var TRUE = "t"; + var FALSE = "f"; + styfn$8.apply = function(eles) { + var self2 = this; + var _p = self2._private; + var cy = _p.cy; + var updatedEles = cy.collection(); + for (var ie = 0; ie < eles.length; ie++) { + var ele = eles[ie]; + var cxtMeta = self2.getContextMeta(ele); + if (cxtMeta.empty) { + continue; + } + var cxtStyle = self2.getContextStyle(cxtMeta); + var app = self2.applyContextStyle(cxtMeta, cxtStyle, ele); + if (ele._private.appliedInitStyle) { + self2.updateTransitions(ele, app.diffProps); + } else { + ele._private.appliedInitStyle = true; + } + var hintsDiff = self2.updateStyleHints(ele); + if (hintsDiff) { + updatedEles.push(ele); + } + } + return updatedEles; + }; + styfn$8.getPropertiesDiff = function(oldCxtKey, newCxtKey) { + var self2 = this; + var cache2 = self2._private.propDiffs = self2._private.propDiffs || {}; + var dualCxtKey = oldCxtKey + "-" + newCxtKey; + var cachedVal = cache2[dualCxtKey]; + if (cachedVal) { + return cachedVal; + } + var diffProps = []; + var addedProp = {}; + for (var i2 = 0; i2 < self2.length; i2++) { + var cxt = self2[i2]; + var oldHasCxt = oldCxtKey[i2] === TRUE; + var newHasCxt = newCxtKey[i2] === TRUE; + var cxtHasDiffed = oldHasCxt !== newHasCxt; + var cxtHasMappedProps = cxt.mappedProperties.length > 0; + if (cxtHasDiffed || newHasCxt && cxtHasMappedProps) { + var props = void 0; + if (cxtHasDiffed && cxtHasMappedProps) { + props = cxt.properties; + } else if (cxtHasDiffed) { + props = cxt.properties; + } else if (cxtHasMappedProps) { + props = cxt.mappedProperties; + } + for (var j = 0; j < props.length; j++) { + var prop = props[j]; + var name = prop.name; + var laterCxtOverrides = false; + for (var k = i2 + 1; k < self2.length; k++) { + var laterCxt = self2[k]; + var hasLaterCxt = newCxtKey[k] === TRUE; + if (!hasLaterCxt) { + continue; + } + laterCxtOverrides = laterCxt.properties[prop.name] != null; + if (laterCxtOverrides) { + break; + } + } + if (!addedProp[name] && !laterCxtOverrides) { + addedProp[name] = true; + diffProps.push(name); + } + } + } + } + cache2[dualCxtKey] = diffProps; + return diffProps; + }; + styfn$8.getContextMeta = function(ele) { + var self2 = this; + var cxtKey = ""; + var diffProps; + var prevKey = ele._private.styleCxtKey || ""; + for (var i2 = 0; i2 < self2.length; i2++) { + var context = self2[i2]; + var contextSelectorMatches = context.selector && context.selector.matches(ele); + if (contextSelectorMatches) { + cxtKey += TRUE; + } else { + cxtKey += FALSE; + } + } + diffProps = self2.getPropertiesDiff(prevKey, cxtKey); + ele._private.styleCxtKey = cxtKey; + return { + key: cxtKey, + diffPropNames: diffProps, + empty: diffProps.length === 0 + }; + }; + styfn$8.getContextStyle = function(cxtMeta) { + var cxtKey = cxtMeta.key; + var self2 = this; + var cxtStyles = this._private.contextStyles = this._private.contextStyles || {}; + if (cxtStyles[cxtKey]) { + return cxtStyles[cxtKey]; + } + var style = { + _private: { + key: cxtKey + } + }; + for (var i2 = 0; i2 < self2.length; i2++) { + var cxt = self2[i2]; + var hasCxt = cxtKey[i2] === TRUE; + if (!hasCxt) { + continue; + } + for (var j = 0; j < cxt.properties.length; j++) { + var prop = cxt.properties[j]; + style[prop.name] = prop; + } + } + cxtStyles[cxtKey] = style; + return style; + }; + styfn$8.applyContextStyle = function(cxtMeta, cxtStyle, ele) { + var self2 = this; + var diffProps = cxtMeta.diffPropNames; + var retDiffProps = {}; + var types = self2.types; + for (var i2 = 0; i2 < diffProps.length; i2++) { + var diffPropName = diffProps[i2]; + var cxtProp = cxtStyle[diffPropName]; + var eleProp = ele.pstyle(diffPropName); + if (!cxtProp) { + if (!eleProp) { + continue; + } else if (eleProp.bypass) { + cxtProp = { + name: diffPropName, + deleteBypassed: true + }; + } else { + cxtProp = { + name: diffPropName, + "delete": true + }; + } + } + if (eleProp === cxtProp) { + continue; + } + if (cxtProp.mapped === types.fn && eleProp != null && eleProp.mapping != null && eleProp.mapping.value === cxtProp.value) { + var mapping = eleProp.mapping; + var fnValue = mapping.fnValue = cxtProp.value(ele); + if (fnValue === mapping.prevFnValue) { + continue; + } + } + var retDiffProp = retDiffProps[diffPropName] = { + prev: eleProp + }; + self2.applyParsedProperty(ele, cxtProp); + retDiffProp.next = ele.pstyle(diffPropName); + if (retDiffProp.next && retDiffProp.next.bypass) { + retDiffProp.next = retDiffProp.next.bypassed; + } + } + return { + diffProps: retDiffProps + }; + }; + styfn$8.updateStyleHints = function(ele) { + var _p = ele._private; + var self2 = this; + var propNames = self2.propertyGroupNames; + var propGrKeys = self2.propertyGroupKeys; + var propHash = function propHash2(ele2, propNames2, seedKey) { + return self2.getPropertiesHash(ele2, propNames2, seedKey); + }; + var oldStyleKey = _p.styleKey; + if (ele.removed()) { + return false; + } + var isNode = _p.group === "nodes"; + var overriddenStyles = ele._private.style; + propNames = Object.keys(overriddenStyles); + for (var i2 = 0; i2 < propGrKeys.length; i2++) { + var grKey = propGrKeys[i2]; + _p.styleKeys[grKey] = [DEFAULT_HASH_SEED, DEFAULT_HASH_SEED_ALT]; + } + var updateGrKey1 = function updateGrKey12(val, grKey2) { + return _p.styleKeys[grKey2][0] = hashInt(val, _p.styleKeys[grKey2][0]); + }; + var updateGrKey2 = function updateGrKey22(val, grKey2) { + return _p.styleKeys[grKey2][1] = hashIntAlt(val, _p.styleKeys[grKey2][1]); + }; + var updateGrKey = function updateGrKey3(val, grKey2) { + updateGrKey1(val, grKey2); + updateGrKey2(val, grKey2); + }; + var updateGrKeyWStr = function updateGrKeyWStr2(strVal, grKey2) { + for (var j = 0; j < strVal.length; j++) { + var ch = strVal.charCodeAt(j); + updateGrKey1(ch, grKey2); + updateGrKey2(ch, grKey2); + } + }; + var N = 2e9; + var cleanNum = function cleanNum2(val) { + return -128 < val && val < 128 && Math.floor(val) !== val ? N - (val * 1024 | 0) : val; + }; + for (var _i = 0; _i < propNames.length; _i++) { + var name = propNames[_i]; + var parsedProp = overriddenStyles[name]; + if (parsedProp == null) { + continue; + } + var propInfo = this.properties[name]; + var type = propInfo.type; + var _grKey = propInfo.groupKey; + var normalizedNumberVal = void 0; + if (propInfo.hashOverride != null) { + normalizedNumberVal = propInfo.hashOverride(ele, parsedProp); + } else if (parsedProp.pfValue != null) { + normalizedNumberVal = parsedProp.pfValue; + } + var numberVal = propInfo.enums == null ? parsedProp.value : null; + var haveNormNum = normalizedNumberVal != null; + var haveUnitedNum = numberVal != null; + var haveNum = haveNormNum || haveUnitedNum; + var units = parsedProp.units; + if (type.number && haveNum && !type.multiple) { + var v = haveNormNum ? normalizedNumberVal : numberVal; + updateGrKey(cleanNum(v), _grKey); + if (!haveNormNum && units != null) { + updateGrKeyWStr(units, _grKey); + } + } else { + updateGrKeyWStr(parsedProp.strValue, _grKey); + } + } + var hash = [DEFAULT_HASH_SEED, DEFAULT_HASH_SEED_ALT]; + for (var _i2 = 0; _i2 < propGrKeys.length; _i2++) { + var _grKey2 = propGrKeys[_i2]; + var grHash = _p.styleKeys[_grKey2]; + hash[0] = hashInt(grHash[0], hash[0]); + hash[1] = hashIntAlt(grHash[1], hash[1]); + } + _p.styleKey = combineHashes(hash[0], hash[1]); + var sk = _p.styleKeys; + _p.labelDimsKey = combineHashesArray(sk.labelDimensions); + var labelKeys = propHash(ele, ["label"], sk.labelDimensions); + _p.labelKey = combineHashesArray(labelKeys); + _p.labelStyleKey = combineHashesArray(hashArrays(sk.commonLabel, labelKeys)); + if (!isNode) { + var sourceLabelKeys = propHash(ele, ["source-label"], sk.labelDimensions); + _p.sourceLabelKey = combineHashesArray(sourceLabelKeys); + _p.sourceLabelStyleKey = combineHashesArray(hashArrays(sk.commonLabel, sourceLabelKeys)); + var targetLabelKeys = propHash(ele, ["target-label"], sk.labelDimensions); + _p.targetLabelKey = combineHashesArray(targetLabelKeys); + _p.targetLabelStyleKey = combineHashesArray(hashArrays(sk.commonLabel, targetLabelKeys)); + } + if (isNode) { + var _p$styleKeys = _p.styleKeys, nodeBody = _p$styleKeys.nodeBody, nodeBorder = _p$styleKeys.nodeBorder, nodeOutline = _p$styleKeys.nodeOutline, backgroundImage = _p$styleKeys.backgroundImage, compound = _p$styleKeys.compound, pie = _p$styleKeys.pie; + var nodeKeys = [nodeBody, nodeBorder, nodeOutline, backgroundImage, compound, pie].filter(function(k) { + return k != null; + }).reduce(hashArrays, [DEFAULT_HASH_SEED, DEFAULT_HASH_SEED_ALT]); + _p.nodeKey = combineHashesArray(nodeKeys); + _p.hasPie = pie != null && pie[0] !== DEFAULT_HASH_SEED && pie[1] !== DEFAULT_HASH_SEED_ALT; + } + return oldStyleKey !== _p.styleKey; + }; + styfn$8.clearStyleHints = function(ele) { + var _p = ele._private; + _p.styleCxtKey = ""; + _p.styleKeys = {}; + _p.styleKey = null; + _p.labelKey = null; + _p.labelStyleKey = null; + _p.sourceLabelKey = null; + _p.sourceLabelStyleKey = null; + _p.targetLabelKey = null; + _p.targetLabelStyleKey = null; + _p.nodeKey = null; + _p.hasPie = null; + }; + styfn$8.applyParsedProperty = function(ele, parsedProp) { + var self2 = this; + var prop = parsedProp; + var style = ele._private.style; + var flatProp; + var types = self2.types; + var type = self2.properties[prop.name].type; + var propIsBypass = prop.bypass; + var origProp = style[prop.name]; + var origPropIsBypass = origProp && origProp.bypass; + var _p = ele._private; + var flatPropMapping = "mapping"; + var getVal = function getVal2(p2) { + if (p2 == null) { + return null; + } else if (p2.pfValue != null) { + return p2.pfValue; + } else { + return p2.value; + } + }; + var checkTriggers = function checkTriggers2() { + var fromVal = getVal(origProp); + var toVal = getVal(prop); + self2.checkTriggers(ele, prop.name, fromVal, toVal); + }; + if (parsedProp.name === "curve-style" && ele.isEdge() && // loops must be bundled beziers + (parsedProp.value !== "bezier" && ele.isLoop() || // edges connected to compound nodes can not be haystacks + parsedProp.value === "haystack" && (ele.source().isParent() || ele.target().isParent()))) { + prop = parsedProp = this.parse(parsedProp.name, "bezier", propIsBypass); + } + if (prop["delete"]) { + style[prop.name] = void 0; + checkTriggers(); + return true; + } + if (prop.deleteBypassed) { + if (!origProp) { + checkTriggers(); + return true; + } else if (origProp.bypass) { + origProp.bypassed = void 0; + checkTriggers(); + return true; + } else { + return false; + } + } + if (prop.deleteBypass) { + if (!origProp) { + checkTriggers(); + return true; + } else if (origProp.bypass) { + style[prop.name] = origProp.bypassed; + checkTriggers(); + return true; + } else { + return false; + } + } + var printMappingErr = function printMappingErr2() { + warn("Do not assign mappings to elements without corresponding data (i.e. ele `" + ele.id() + "` has no mapping for property `" + prop.name + "` with data field `" + prop.field + "`); try a `[" + prop.field + "]` selector to limit scope to elements with `" + prop.field + "` defined"); + }; + switch (prop.mapped) { + case types.mapData: { + var fields = prop.field.split("."); + var fieldVal = _p.data; + for (var i2 = 0; i2 < fields.length && fieldVal; i2++) { + var field = fields[i2]; + fieldVal = fieldVal[field]; + } + if (fieldVal == null) { + printMappingErr(); + return false; + } + var percent; + if (!number$1(fieldVal)) { + warn("Do not use continuous mappers without specifying numeric data (i.e. `" + prop.field + ": " + fieldVal + "` for `" + ele.id() + "` is non-numeric)"); + return false; + } else { + var fieldWidth = prop.fieldMax - prop.fieldMin; + if (fieldWidth === 0) { + percent = 0; + } else { + percent = (fieldVal - prop.fieldMin) / fieldWidth; + } + } + if (percent < 0) { + percent = 0; + } else if (percent > 1) { + percent = 1; + } + if (type.color) { + var r1 = prop.valueMin[0]; + var r2 = prop.valueMax[0]; + var g1 = prop.valueMin[1]; + var g2 = prop.valueMax[1]; + var b1 = prop.valueMin[2]; + var b2 = prop.valueMax[2]; + var a1 = prop.valueMin[3] == null ? 1 : prop.valueMin[3]; + var a2 = prop.valueMax[3] == null ? 1 : prop.valueMax[3]; + var clr = [Math.round(r1 + (r2 - r1) * percent), Math.round(g1 + (g2 - g1) * percent), Math.round(b1 + (b2 - b1) * percent), Math.round(a1 + (a2 - a1) * percent)]; + flatProp = { + // colours are simple, so just create the flat property instead of expensive string parsing + bypass: prop.bypass, + // we're a bypass if the mapping property is a bypass + name: prop.name, + value: clr, + strValue: "rgb(" + clr[0] + ", " + clr[1] + ", " + clr[2] + ")" + }; + } else if (type.number) { + var calcValue = prop.valueMin + (prop.valueMax - prop.valueMin) * percent; + flatProp = this.parse(prop.name, calcValue, prop.bypass, flatPropMapping); + } else { + return false; + } + if (!flatProp) { + printMappingErr(); + return false; + } + flatProp.mapping = prop; + prop = flatProp; + break; + } + case types.data: { + var _fields = prop.field.split("."); + var _fieldVal = _p.data; + for (var _i3 = 0; _i3 < _fields.length && _fieldVal; _i3++) { + var _field = _fields[_i3]; + _fieldVal = _fieldVal[_field]; + } + if (_fieldVal != null) { + flatProp = this.parse(prop.name, _fieldVal, prop.bypass, flatPropMapping); + } + if (!flatProp) { + printMappingErr(); + return false; + } + flatProp.mapping = prop; + prop = flatProp; + break; + } + case types.fn: { + var fn2 = prop.value; + var fnRetVal = prop.fnValue != null ? prop.fnValue : fn2(ele); + prop.prevFnValue = fnRetVal; + if (fnRetVal == null) { + warn("Custom function mappers may not return null (i.e. `" + prop.name + "` for ele `" + ele.id() + "` is null)"); + return false; + } + flatProp = this.parse(prop.name, fnRetVal, prop.bypass, flatPropMapping); + if (!flatProp) { + warn("Custom function mappers may not return invalid values for the property type (i.e. `" + prop.name + "` for ele `" + ele.id() + "` is invalid)"); + return false; + } + flatProp.mapping = copy(prop); + prop = flatProp; + break; + } + case void 0: + break; + default: + return false; + } + if (propIsBypass) { + if (origPropIsBypass) { + prop.bypassed = origProp.bypassed; + } else { + prop.bypassed = origProp; + } + style[prop.name] = prop; + } else { + if (origPropIsBypass) { + origProp.bypassed = prop; + } else { + style[prop.name] = prop; + } + } + checkTriggers(); + return true; + }; + styfn$8.cleanElements = function(eles, keepBypasses) { + for (var i2 = 0; i2 < eles.length; i2++) { + var ele = eles[i2]; + this.clearStyleHints(ele); + ele.dirtyCompoundBoundsCache(); + ele.dirtyBoundingBoxCache(); + if (!keepBypasses) { + ele._private.style = {}; + } else { + var style = ele._private.style; + var propNames = Object.keys(style); + for (var j = 0; j < propNames.length; j++) { + var propName = propNames[j]; + var eleProp = style[propName]; + if (eleProp != null) { + if (eleProp.bypass) { + eleProp.bypassed = null; + } else { + style[propName] = null; + } + } + } + } + } + }; + styfn$8.update = function() { + var cy = this._private.cy; + var eles = cy.mutableElements(); + eles.updateStyle(); + }; + styfn$8.updateTransitions = function(ele, diffProps) { + var self2 = this; + var _p = ele._private; + var props = ele.pstyle("transition-property").value; + var duration = ele.pstyle("transition-duration").pfValue; + var delay = ele.pstyle("transition-delay").pfValue; + if (props.length > 0 && duration > 0) { + var style = {}; + var anyPrev = false; + for (var i2 = 0; i2 < props.length; i2++) { + var prop = props[i2]; + var styProp = ele.pstyle(prop); + var diffProp = diffProps[prop]; + if (!diffProp) { + continue; + } + var prevProp = diffProp.prev; + var fromProp = prevProp; + var toProp = diffProp.next != null ? diffProp.next : styProp; + var diff = false; + var initVal = void 0; + var initDt = 1e-6; + if (!fromProp) { + continue; + } + if (number$1(fromProp.pfValue) && number$1(toProp.pfValue)) { + diff = toProp.pfValue - fromProp.pfValue; + initVal = fromProp.pfValue + initDt * diff; + } else if (number$1(fromProp.value) && number$1(toProp.value)) { + diff = toProp.value - fromProp.value; + initVal = fromProp.value + initDt * diff; + } else if (array(fromProp.value) && array(toProp.value)) { + diff = fromProp.value[0] !== toProp.value[0] || fromProp.value[1] !== toProp.value[1] || fromProp.value[2] !== toProp.value[2]; + initVal = fromProp.strValue; + } + if (diff) { + style[prop] = toProp.strValue; + this.applyBypass(ele, prop, initVal); + anyPrev = true; + } + } + if (!anyPrev) { + return; + } + _p.transitioning = true; + new Promise$1(function(resolve2) { + if (delay > 0) { + ele.delayAnimation(delay).play().promise().then(resolve2); + } else { + resolve2(); + } + }).then(function() { + return ele.animation({ + style, + duration, + easing: ele.pstyle("transition-timing-function").value, + queue: false + }).play().promise(); + }).then(function() { + self2.removeBypasses(ele, props); + ele.emitAndNotify("style"); + _p.transitioning = false; + }); + } else if (_p.transitioning) { + this.removeBypasses(ele, props); + ele.emitAndNotify("style"); + _p.transitioning = false; + } + }; + styfn$8.checkTrigger = function(ele, name, fromValue, toValue, getTrigger, onTrigger) { + var prop = this.properties[name]; + var triggerCheck = getTrigger(prop); + if (triggerCheck != null && triggerCheck(fromValue, toValue)) { + onTrigger(prop); + } + }; + styfn$8.checkZOrderTrigger = function(ele, name, fromValue, toValue) { + var _this = this; + this.checkTrigger(ele, name, fromValue, toValue, function(prop) { + return prop.triggersZOrder; + }, function() { + _this._private.cy.notify("zorder", ele); + }); + }; + styfn$8.checkBoundsTrigger = function(ele, name, fromValue, toValue) { + this.checkTrigger(ele, name, fromValue, toValue, function(prop) { + return prop.triggersBounds; + }, function(prop) { + ele.dirtyCompoundBoundsCache(); + ele.dirtyBoundingBoxCache(); + if ( + // only for beziers -- so performance of other edges isn't affected + prop.triggersBoundsOfParallelBeziers && name === "curve-style" && (fromValue === "bezier" || toValue === "bezier") + ) { + ele.parallelEdges().forEach(function(pllEdge) { + if (pllEdge.isBundledBezier()) { + pllEdge.dirtyBoundingBoxCache(); + } + }); + } + if (prop.triggersBoundsOfConnectedEdges && name === "display" && (fromValue === "none" || toValue === "none")) { + ele.connectedEdges().forEach(function(edge) { + edge.dirtyBoundingBoxCache(); + }); + } + }); + }; + styfn$8.checkTriggers = function(ele, name, fromValue, toValue) { + ele.dirtyStyleCache(); + this.checkZOrderTrigger(ele, name, fromValue, toValue); + this.checkBoundsTrigger(ele, name, fromValue, toValue); + }; + var styfn$7 = {}; + styfn$7.applyBypass = function(eles, name, value, updateTransitions) { + var self2 = this; + var props = []; + var isBypass = true; + if (name === "*" || name === "**") { + if (value !== void 0) { + for (var i2 = 0; i2 < self2.properties.length; i2++) { + var prop = self2.properties[i2]; + var _name = prop.name; + var parsedProp = this.parse(_name, value, true); + if (parsedProp) { + props.push(parsedProp); + } + } + } + } else if (string(name)) { + var _parsedProp = this.parse(name, value, true); + if (_parsedProp) { + props.push(_parsedProp); + } + } else if (plainObject(name)) { + var specifiedProps = name; + updateTransitions = value; + var names = Object.keys(specifiedProps); + for (var _i = 0; _i < names.length; _i++) { + var _name2 = names[_i]; + var _value = specifiedProps[_name2]; + if (_value === void 0) { + _value = specifiedProps[dash2camel(_name2)]; + } + if (_value !== void 0) { + var _parsedProp2 = this.parse(_name2, _value, true); + if (_parsedProp2) { + props.push(_parsedProp2); + } + } + } + } else { + return false; + } + if (props.length === 0) { + return false; + } + var ret = false; + for (var _i2 = 0; _i2 < eles.length; _i2++) { + var ele = eles[_i2]; + var diffProps = {}; + var diffProp = void 0; + for (var j = 0; j < props.length; j++) { + var _prop = props[j]; + if (updateTransitions) { + var prevProp = ele.pstyle(_prop.name); + diffProp = diffProps[_prop.name] = { + prev: prevProp + }; + } + ret = this.applyParsedProperty(ele, copy(_prop)) || ret; + if (updateTransitions) { + diffProp.next = ele.pstyle(_prop.name); + } + } + if (ret) { + this.updateStyleHints(ele); + } + if (updateTransitions) { + this.updateTransitions(ele, diffProps, isBypass); + } + } + return ret; + }; + styfn$7.overrideBypass = function(eles, name, value) { + name = camel2dash(name); + for (var i2 = 0; i2 < eles.length; i2++) { + var ele = eles[i2]; + var prop = ele._private.style[name]; + var type = this.properties[name].type; + var isColor = type.color; + var isMulti = type.mutiple; + var oldValue = !prop ? null : prop.pfValue != null ? prop.pfValue : prop.value; + if (!prop || !prop.bypass) { + this.applyBypass(ele, name, value); + } else { + prop.value = value; + if (prop.pfValue != null) { + prop.pfValue = value; + } + if (isColor) { + prop.strValue = "rgb(" + value.join(",") + ")"; + } else if (isMulti) { + prop.strValue = value.join(" "); + } else { + prop.strValue = "" + value; + } + this.updateStyleHints(ele); + } + this.checkTriggers(ele, name, oldValue, value); + } + }; + styfn$7.removeAllBypasses = function(eles, updateTransitions) { + return this.removeBypasses(eles, this.propertyNames, updateTransitions); + }; + styfn$7.removeBypasses = function(eles, props, updateTransitions) { + var isBypass = true; + for (var j = 0; j < eles.length; j++) { + var ele = eles[j]; + var diffProps = {}; + for (var i2 = 0; i2 < props.length; i2++) { + var name = props[i2]; + var prop = this.properties[name]; + var prevProp = ele.pstyle(prop.name); + if (!prevProp || !prevProp.bypass) { + continue; + } + var value = ""; + var parsedProp = this.parse(name, value, true); + var diffProp = diffProps[prop.name] = { + prev: prevProp + }; + this.applyParsedProperty(ele, parsedProp); + diffProp.next = ele.pstyle(prop.name); + } + this.updateStyleHints(ele); + if (updateTransitions) { + this.updateTransitions(ele, diffProps, isBypass); + } + } + }; + var styfn$6 = {}; + styfn$6.getEmSizeInPixels = function() { + var px = this.containerCss("font-size"); + if (px != null) { + return parseFloat(px); + } else { + return 1; + } + }; + styfn$6.containerCss = function(propName) { + var cy = this._private.cy; + var domElement2 = cy.container(); + var containerWindow = cy.window(); + if (containerWindow && domElement2 && containerWindow.getComputedStyle) { + return containerWindow.getComputedStyle(domElement2).getPropertyValue(propName); + } + }; + var styfn$5 = {}; + styfn$5.getRenderedStyle = function(ele, prop) { + if (prop) { + return this.getStylePropertyValue(ele, prop, true); + } else { + return this.getRawStyle(ele, true); + } + }; + styfn$5.getRawStyle = function(ele, isRenderedVal) { + var self2 = this; + ele = ele[0]; + if (ele) { + var rstyle = {}; + for (var i2 = 0; i2 < self2.properties.length; i2++) { + var prop = self2.properties[i2]; + var val = self2.getStylePropertyValue(ele, prop.name, isRenderedVal); + if (val != null) { + rstyle[prop.name] = val; + rstyle[dash2camel(prop.name)] = val; + } + } + return rstyle; + } + }; + styfn$5.getIndexedStyle = function(ele, property, subproperty, index) { + var pstyle = ele.pstyle(property)[subproperty][index]; + return pstyle != null ? pstyle : ele.cy().style().getDefaultProperty(property)[subproperty][0]; + }; + styfn$5.getStylePropertyValue = function(ele, propName, isRenderedVal) { + var self2 = this; + ele = ele[0]; + if (ele) { + var prop = self2.properties[propName]; + if (prop.alias) { + prop = prop.pointsTo; + } + var type = prop.type; + var styleProp = ele.pstyle(prop.name); + if (styleProp) { + var value = styleProp.value, units = styleProp.units, strValue = styleProp.strValue; + if (isRenderedVal && type.number && value != null && number$1(value)) { + var zoom = ele.cy().zoom(); + var getRenderedValue = function getRenderedValue2(val) { + return val * zoom; + }; + var getValueStringWithUnits = function getValueStringWithUnits2(val, units2) { + return getRenderedValue(val) + units2; + }; + var isArrayValue = array(value); + var haveUnits = isArrayValue ? units.every(function(u) { + return u != null; + }) : units != null; + if (haveUnits) { + if (isArrayValue) { + return value.map(function(v, i2) { + return getValueStringWithUnits(v, units[i2]); + }).join(" "); + } else { + return getValueStringWithUnits(value, units); + } + } else { + if (isArrayValue) { + return value.map(function(v) { + return string(v) ? v : "" + getRenderedValue(v); + }).join(" "); + } else { + return "" + getRenderedValue(value); + } + } + } else if (strValue != null) { + return strValue; + } + } + return null; + } + }; + styfn$5.getAnimationStartStyle = function(ele, aniProps) { + var rstyle = {}; + for (var i2 = 0; i2 < aniProps.length; i2++) { + var aniProp = aniProps[i2]; + var name = aniProp.name; + var styleProp = ele.pstyle(name); + if (styleProp !== void 0) { + if (plainObject(styleProp)) { + styleProp = this.parse(name, styleProp.strValue); + } else { + styleProp = this.parse(name, styleProp); + } + } + if (styleProp) { + rstyle[name] = styleProp; + } + } + return rstyle; + }; + styfn$5.getPropsList = function(propsObj) { + var self2 = this; + var rstyle = []; + var style = propsObj; + var props = self2.properties; + if (style) { + var names = Object.keys(style); + for (var i2 = 0; i2 < names.length; i2++) { + var name = names[i2]; + var val = style[name]; + var prop = props[name] || props[camel2dash(name)]; + var styleProp = this.parse(prop.name, val); + if (styleProp) { + rstyle.push(styleProp); + } + } + } + return rstyle; + }; + styfn$5.getNonDefaultPropertiesHash = function(ele, propNames, seed) { + var hash = seed.slice(); + var name, val, strVal, chVal; + var i2, j; + for (i2 = 0; i2 < propNames.length; i2++) { + name = propNames[i2]; + val = ele.pstyle(name, false); + if (val == null) { + continue; + } else if (val.pfValue != null) { + hash[0] = hashInt(chVal, hash[0]); + hash[1] = hashIntAlt(chVal, hash[1]); + } else { + strVal = val.strValue; + for (j = 0; j < strVal.length; j++) { + chVal = strVal.charCodeAt(j); + hash[0] = hashInt(chVal, hash[0]); + hash[1] = hashIntAlt(chVal, hash[1]); + } + } + } + return hash; + }; + styfn$5.getPropertiesHash = styfn$5.getNonDefaultPropertiesHash; + var styfn$4 = {}; + styfn$4.appendFromJson = function(json) { + var style = this; + for (var i2 = 0; i2 < json.length; i2++) { + var context = json[i2]; + var selector = context.selector; + var props = context.style || context.css; + var names = Object.keys(props); + style.selector(selector); + for (var j = 0; j < names.length; j++) { + var name = names[j]; + var value = props[name]; + style.css(name, value); + } + } + return style; + }; + styfn$4.fromJson = function(json) { + var style = this; + style.resetToDefault(); + style.appendFromJson(json); + return style; + }; + styfn$4.json = function() { + var json = []; + for (var i2 = this.defaultLength; i2 < this.length; i2++) { + var cxt = this[i2]; + var selector = cxt.selector; + var props = cxt.properties; + var css = {}; + for (var j = 0; j < props.length; j++) { + var prop = props[j]; + css[prop.name] = prop.strValue; + } + json.push({ + selector: !selector ? "core" : selector.toString(), + style: css + }); + } + return json; + }; + var styfn$3 = {}; + styfn$3.appendFromString = function(string2) { + var self2 = this; + var style = this; + var remaining = "" + string2; + var selAndBlockStr; + var blockRem; + var propAndValStr; + remaining = remaining.replace(/[/][*](\s|.)+?[*][/]/g, ""); + function removeSelAndBlockFromRemaining() { + if (remaining.length > selAndBlockStr.length) { + remaining = remaining.substr(selAndBlockStr.length); + } else { + remaining = ""; + } + } + function removePropAndValFromRem() { + if (blockRem.length > propAndValStr.length) { + blockRem = blockRem.substr(propAndValStr.length); + } else { + blockRem = ""; + } + } + for (; ; ) { + var nothingLeftToParse = remaining.match(/^\s*$/); + if (nothingLeftToParse) { + break; + } + var selAndBlock = remaining.match(/^\s*((?:.|\s)+?)\s*\{((?:.|\s)+?)\}/); + if (!selAndBlock) { + warn("Halting stylesheet parsing: String stylesheet contains more to parse but no selector and block found in: " + remaining); + break; + } + selAndBlockStr = selAndBlock[0]; + var selectorStr = selAndBlock[1]; + if (selectorStr !== "core") { + var selector = new Selector(selectorStr); + if (selector.invalid) { + warn("Skipping parsing of block: Invalid selector found in string stylesheet: " + selectorStr); + removeSelAndBlockFromRemaining(); + continue; + } + } + var blockStr = selAndBlock[2]; + var invalidBlock = false; + blockRem = blockStr; + var props = []; + for (; ; ) { + var _nothingLeftToParse = blockRem.match(/^\s*$/); + if (_nothingLeftToParse) { + break; + } + var propAndVal = blockRem.match(/^\s*(.+?)\s*:\s*(.+?)(?:\s*;|\s*$)/); + if (!propAndVal) { + warn("Skipping parsing of block: Invalid formatting of style property and value definitions found in:" + blockStr); + invalidBlock = true; + break; + } + propAndValStr = propAndVal[0]; + var propStr = propAndVal[1]; + var valStr = propAndVal[2]; + var prop = self2.properties[propStr]; + if (!prop) { + warn("Skipping property: Invalid property name in: " + propAndValStr); + removePropAndValFromRem(); + continue; + } + var parsedProp = style.parse(propStr, valStr); + if (!parsedProp) { + warn("Skipping property: Invalid property definition in: " + propAndValStr); + removePropAndValFromRem(); + continue; + } + props.push({ + name: propStr, + val: valStr + }); + removePropAndValFromRem(); + } + if (invalidBlock) { + removeSelAndBlockFromRemaining(); + break; + } + style.selector(selectorStr); + for (var i2 = 0; i2 < props.length; i2++) { + var _prop = props[i2]; + style.css(_prop.name, _prop.val); + } + removeSelAndBlockFromRemaining(); + } + return style; + }; + styfn$3.fromString = function(string2) { + var style = this; + style.resetToDefault(); + style.appendFromString(string2); + return style; + }; + var styfn$2 = {}; + (function() { + var number$12 = number; + var rgba2 = rgbaNoBackRefs; + var hsla2 = hslaNoBackRefs; + var hex3$1 = hex3; + var hex6$1 = hex6; + var data2 = function data3(prefix) { + return "^" + prefix + "\\s*\\(\\s*([\\w\\.]+)\\s*\\)$"; + }; + var mapData = function mapData2(prefix) { + var mapArg = number$12 + "|\\w+|" + rgba2 + "|" + hsla2 + "|" + hex3$1 + "|" + hex6$1; + return "^" + prefix + "\\s*\\(([\\w\\.]+)\\s*\\,\\s*(" + number$12 + ")\\s*\\,\\s*(" + number$12 + ")\\s*,\\s*(" + mapArg + ")\\s*\\,\\s*(" + mapArg + ")\\)$"; + }; + var urlRegexes = [`^url\\s*\\(\\s*['"]?(.+?)['"]?\\s*\\)$`, "^(none)$", "^(.+)$"]; + styfn$2.types = { + time: { + number: true, + min: 0, + units: "s|ms", + implicitUnits: "ms" + }, + percent: { + number: true, + min: 0, + max: 100, + units: "%", + implicitUnits: "%" + }, + percentages: { + number: true, + min: 0, + max: 100, + units: "%", + implicitUnits: "%", + multiple: true + }, + zeroOneNumber: { + number: true, + min: 0, + max: 1, + unitless: true + }, + zeroOneNumbers: { + number: true, + min: 0, + max: 1, + unitless: true, + multiple: true + }, + nOneOneNumber: { + number: true, + min: -1, + max: 1, + unitless: true + }, + nonNegativeInt: { + number: true, + min: 0, + integer: true, + unitless: true + }, + nonNegativeNumber: { + number: true, + min: 0, + unitless: true + }, + position: { + enums: ["parent", "origin"] + }, + nodeSize: { + number: true, + min: 0, + enums: ["label"] + }, + number: { + number: true, + unitless: true + }, + numbers: { + number: true, + unitless: true, + multiple: true + }, + positiveNumber: { + number: true, + unitless: true, + min: 0, + strictMin: true + }, + size: { + number: true, + min: 0 + }, + bidirectionalSize: { + number: true + }, + // allows negative + bidirectionalSizeMaybePercent: { + number: true, + allowPercent: true + }, + // allows negative + bidirectionalSizes: { + number: true, + multiple: true + }, + // allows negative + sizeMaybePercent: { + number: true, + min: 0, + allowPercent: true + }, + axisDirection: { + enums: ["horizontal", "leftward", "rightward", "vertical", "upward", "downward", "auto"] + }, + paddingRelativeTo: { + enums: ["width", "height", "average", "min", "max"] + }, + bgWH: { + number: true, + min: 0, + allowPercent: true, + enums: ["auto"], + multiple: true + }, + bgPos: { + number: true, + allowPercent: true, + multiple: true + }, + bgRelativeTo: { + enums: ["inner", "include-padding"], + multiple: true + }, + bgRepeat: { + enums: ["repeat", "repeat-x", "repeat-y", "no-repeat"], + multiple: true + }, + bgFit: { + enums: ["none", "contain", "cover"], + multiple: true + }, + bgCrossOrigin: { + enums: ["anonymous", "use-credentials", "null"], + multiple: true + }, + bgClip: { + enums: ["none", "node"], + multiple: true + }, + bgContainment: { + enums: ["inside", "over"], + multiple: true + }, + color: { + color: true + }, + colors: { + color: true, + multiple: true + }, + fill: { + enums: ["solid", "linear-gradient", "radial-gradient"] + }, + bool: { + enums: ["yes", "no"] + }, + bools: { + enums: ["yes", "no"], + multiple: true + }, + lineStyle: { + enums: ["solid", "dotted", "dashed"] + }, + lineCap: { + enums: ["butt", "round", "square"] + }, + borderStyle: { + enums: ["solid", "dotted", "dashed", "double"] + }, + curveStyle: { + enums: ["bezier", "unbundled-bezier", "haystack", "segments", "straight", "straight-triangle", "taxi"] + }, + fontFamily: { + regex: '^([\\w- \\"]+(?:\\s*,\\s*[\\w- \\"]+)*)$' + }, + fontStyle: { + enums: ["italic", "normal", "oblique"] + }, + fontWeight: { + enums: ["normal", "bold", "bolder", "lighter", "100", "200", "300", "400", "500", "600", "800", "900", 100, 200, 300, 400, 500, 600, 700, 800, 900] + }, + textDecoration: { + enums: ["none", "underline", "overline", "line-through"] + }, + textTransform: { + enums: ["none", "uppercase", "lowercase"] + }, + textWrap: { + enums: ["none", "wrap", "ellipsis"] + }, + textOverflowWrap: { + enums: ["whitespace", "anywhere"] + }, + textBackgroundShape: { + enums: ["rectangle", "roundrectangle", "round-rectangle"] + }, + nodeShape: { + enums: ["rectangle", "roundrectangle", "round-rectangle", "cutrectangle", "cut-rectangle", "bottomroundrectangle", "bottom-round-rectangle", "barrel", "ellipse", "triangle", "round-triangle", "square", "pentagon", "round-pentagon", "hexagon", "round-hexagon", "concavehexagon", "concave-hexagon", "heptagon", "round-heptagon", "octagon", "round-octagon", "tag", "round-tag", "star", "diamond", "round-diamond", "vee", "rhomboid", "right-rhomboid", "polygon"] + }, + overlayShape: { + enums: ["roundrectangle", "round-rectangle", "ellipse"] + }, + compoundIncludeLabels: { + enums: ["include", "exclude"] + }, + arrowShape: { + enums: ["tee", "triangle", "triangle-tee", "circle-triangle", "triangle-cross", "triangle-backcurve", "vee", "square", "circle", "diamond", "chevron", "none"] + }, + arrowFill: { + enums: ["filled", "hollow"] + }, + arrowWidth: { + number: true, + units: "%|px|em", + implicitUnits: "px", + enums: ["match-line"] + }, + display: { + enums: ["element", "none"] + }, + visibility: { + enums: ["hidden", "visible"] + }, + zCompoundDepth: { + enums: ["bottom", "orphan", "auto", "top"] + }, + zIndexCompare: { + enums: ["auto", "manual"] + }, + valign: { + enums: ["top", "center", "bottom"] + }, + halign: { + enums: ["left", "center", "right"] + }, + justification: { + enums: ["left", "center", "right", "auto"] + }, + text: { + string: true + }, + data: { + mapping: true, + regex: data2("data") + }, + layoutData: { + mapping: true, + regex: data2("layoutData") + }, + scratch: { + mapping: true, + regex: data2("scratch") + }, + mapData: { + mapping: true, + regex: mapData("mapData") + }, + mapLayoutData: { + mapping: true, + regex: mapData("mapLayoutData") + }, + mapScratch: { + mapping: true, + regex: mapData("mapScratch") + }, + fn: { + mapping: true, + fn: true + }, + url: { + regexes: urlRegexes, + singleRegexMatchValue: true + }, + urls: { + regexes: urlRegexes, + singleRegexMatchValue: true, + multiple: true + }, + propList: { + propList: true + }, + angle: { + number: true, + units: "deg|rad", + implicitUnits: "rad" + }, + textRotation: { + number: true, + units: "deg|rad", + implicitUnits: "rad", + enums: ["none", "autorotate"] + }, + polygonPointList: { + number: true, + multiple: true, + evenMultiple: true, + min: -1, + max: 1, + unitless: true + }, + edgeDistances: { + enums: ["intersection", "node-position", "endpoints"] + }, + edgeEndpoint: { + number: true, + multiple: true, + units: "%|px|em|deg|rad", + implicitUnits: "px", + enums: ["inside-to-node", "outside-to-node", "outside-to-node-or-label", "outside-to-line", "outside-to-line-or-label"], + singleEnum: true, + validate: function validate(valArr, unitsArr) { + switch (valArr.length) { + case 2: + return unitsArr[0] !== "deg" && unitsArr[0] !== "rad" && unitsArr[1] !== "deg" && unitsArr[1] !== "rad"; + case 1: + return string(valArr[0]) || unitsArr[0] === "deg" || unitsArr[0] === "rad"; + default: + return false; + } + } + }, + easing: { + regexes: ["^(spring)\\s*\\(\\s*(" + number$12 + ")\\s*,\\s*(" + number$12 + ")\\s*\\)$", "^(cubic-bezier)\\s*\\(\\s*(" + number$12 + ")\\s*,\\s*(" + number$12 + ")\\s*,\\s*(" + number$12 + ")\\s*,\\s*(" + number$12 + ")\\s*\\)$"], + enums: ["linear", "ease", "ease-in", "ease-out", "ease-in-out", "ease-in-sine", "ease-out-sine", "ease-in-out-sine", "ease-in-quad", "ease-out-quad", "ease-in-out-quad", "ease-in-cubic", "ease-out-cubic", "ease-in-out-cubic", "ease-in-quart", "ease-out-quart", "ease-in-out-quart", "ease-in-quint", "ease-out-quint", "ease-in-out-quint", "ease-in-expo", "ease-out-expo", "ease-in-out-expo", "ease-in-circ", "ease-out-circ", "ease-in-out-circ"] + }, + gradientDirection: { + enums: [ + "to-bottom", + "to-top", + "to-left", + "to-right", + "to-bottom-right", + "to-bottom-left", + "to-top-right", + "to-top-left", + "to-right-bottom", + "to-left-bottom", + "to-right-top", + "to-left-top" + // different order + ] + }, + boundsExpansion: { + number: true, + multiple: true, + min: 0, + validate: function validate(valArr) { + var length = valArr.length; + return length === 1 || length === 2 || length === 4; + } + } + }; + var diff = { + zeroNonZero: function zeroNonZero(val1, val2) { + if ((val1 == null || val2 == null) && val1 !== val2) { + return true; + } + if (val1 == 0 && val2 != 0) { + return true; + } else if (val1 != 0 && val2 == 0) { + return true; + } else { + return false; + } + }, + any: function any(val1, val2) { + return val1 != val2; + }, + emptyNonEmpty: function emptyNonEmpty(str1, str2) { + var empty1 = emptyString(str1); + var empty2 = emptyString(str2); + return empty1 && !empty2 || !empty1 && empty2; + } + }; + var t = styfn$2.types; + var mainLabel = [{ + name: "label", + type: t.text, + triggersBounds: diff.any, + triggersZOrder: diff.emptyNonEmpty + }, { + name: "text-rotation", + type: t.textRotation, + triggersBounds: diff.any + }, { + name: "text-margin-x", + type: t.bidirectionalSize, + triggersBounds: diff.any + }, { + name: "text-margin-y", + type: t.bidirectionalSize, + triggersBounds: diff.any + }]; + var sourceLabel = [{ + name: "source-label", + type: t.text, + triggersBounds: diff.any + }, { + name: "source-text-rotation", + type: t.textRotation, + triggersBounds: diff.any + }, { + name: "source-text-margin-x", + type: t.bidirectionalSize, + triggersBounds: diff.any + }, { + name: "source-text-margin-y", + type: t.bidirectionalSize, + triggersBounds: diff.any + }, { + name: "source-text-offset", + type: t.size, + triggersBounds: diff.any + }]; + var targetLabel = [{ + name: "target-label", + type: t.text, + triggersBounds: diff.any + }, { + name: "target-text-rotation", + type: t.textRotation, + triggersBounds: diff.any + }, { + name: "target-text-margin-x", + type: t.bidirectionalSize, + triggersBounds: diff.any + }, { + name: "target-text-margin-y", + type: t.bidirectionalSize, + triggersBounds: diff.any + }, { + name: "target-text-offset", + type: t.size, + triggersBounds: diff.any + }]; + var labelDimensions = [{ + name: "font-family", + type: t.fontFamily, + triggersBounds: diff.any + }, { + name: "font-style", + type: t.fontStyle, + triggersBounds: diff.any + }, { + name: "font-weight", + type: t.fontWeight, + triggersBounds: diff.any + }, { + name: "font-size", + type: t.size, + triggersBounds: diff.any + }, { + name: "text-transform", + type: t.textTransform, + triggersBounds: diff.any + }, { + name: "text-wrap", + type: t.textWrap, + triggersBounds: diff.any + }, { + name: "text-overflow-wrap", + type: t.textOverflowWrap, + triggersBounds: diff.any + }, { + name: "text-max-width", + type: t.size, + triggersBounds: diff.any + }, { + name: "text-outline-width", + type: t.size, + triggersBounds: diff.any + }, { + name: "line-height", + type: t.positiveNumber, + triggersBounds: diff.any + }]; + var commonLabel = [{ + name: "text-valign", + type: t.valign, + triggersBounds: diff.any + }, { + name: "text-halign", + type: t.halign, + triggersBounds: diff.any + }, { + name: "color", + type: t.color + }, { + name: "text-outline-color", + type: t.color + }, { + name: "text-outline-opacity", + type: t.zeroOneNumber + }, { + name: "text-background-color", + type: t.color + }, { + name: "text-background-opacity", + type: t.zeroOneNumber + }, { + name: "text-background-padding", + type: t.size, + triggersBounds: diff.any + }, { + name: "text-border-opacity", + type: t.zeroOneNumber + }, { + name: "text-border-color", + type: t.color + }, { + name: "text-border-width", + type: t.size, + triggersBounds: diff.any + }, { + name: "text-border-style", + type: t.borderStyle, + triggersBounds: diff.any + }, { + name: "text-background-shape", + type: t.textBackgroundShape, + triggersBounds: diff.any + }, { + name: "text-justification", + type: t.justification + }]; + var behavior = [{ + name: "events", + type: t.bool, + triggersZOrder: diff.any + }, { + name: "text-events", + type: t.bool, + triggersZOrder: diff.any + }]; + var visibility = [{ + name: "display", + type: t.display, + triggersZOrder: diff.any, + triggersBounds: diff.any, + triggersBoundsOfConnectedEdges: true + }, { + name: "visibility", + type: t.visibility, + triggersZOrder: diff.any + }, { + name: "opacity", + type: t.zeroOneNumber, + triggersZOrder: diff.zeroNonZero + }, { + name: "text-opacity", + type: t.zeroOneNumber + }, { + name: "min-zoomed-font-size", + type: t.size + }, { + name: "z-compound-depth", + type: t.zCompoundDepth, + triggersZOrder: diff.any + }, { + name: "z-index-compare", + type: t.zIndexCompare, + triggersZOrder: diff.any + }, { + name: "z-index", + type: t.number, + triggersZOrder: diff.any + }]; + var overlay = [{ + name: "overlay-padding", + type: t.size, + triggersBounds: diff.any + }, { + name: "overlay-color", + type: t.color + }, { + name: "overlay-opacity", + type: t.zeroOneNumber, + triggersBounds: diff.zeroNonZero + }, { + name: "overlay-shape", + type: t.overlayShape, + triggersBounds: diff.any + }]; + var underlay = [{ + name: "underlay-padding", + type: t.size, + triggersBounds: diff.any + }, { + name: "underlay-color", + type: t.color + }, { + name: "underlay-opacity", + type: t.zeroOneNumber, + triggersBounds: diff.zeroNonZero + }, { + name: "underlay-shape", + type: t.overlayShape, + triggersBounds: diff.any + }]; + var transition = [{ + name: "transition-property", + type: t.propList + }, { + name: "transition-duration", + type: t.time + }, { + name: "transition-delay", + type: t.time + }, { + name: "transition-timing-function", + type: t.easing + }]; + var nodeSizeHashOverride = function nodeSizeHashOverride2(ele, parsedProp) { + if (parsedProp.value === "label") { + return -ele.poolIndex(); + } else { + return parsedProp.pfValue; + } + }; + var nodeBody = [{ + name: "height", + type: t.nodeSize, + triggersBounds: diff.any, + hashOverride: nodeSizeHashOverride + }, { + name: "width", + type: t.nodeSize, + triggersBounds: diff.any, + hashOverride: nodeSizeHashOverride + }, { + name: "shape", + type: t.nodeShape, + triggersBounds: diff.any + }, { + name: "shape-polygon-points", + type: t.polygonPointList, + triggersBounds: diff.any + }, { + name: "background-color", + type: t.color + }, { + name: "background-fill", + type: t.fill + }, { + name: "background-opacity", + type: t.zeroOneNumber + }, { + name: "background-blacken", + type: t.nOneOneNumber + }, { + name: "background-gradient-stop-colors", + type: t.colors + }, { + name: "background-gradient-stop-positions", + type: t.percentages + }, { + name: "background-gradient-direction", + type: t.gradientDirection + }, { + name: "padding", + type: t.sizeMaybePercent, + triggersBounds: diff.any + }, { + name: "padding-relative-to", + type: t.paddingRelativeTo, + triggersBounds: diff.any + }, { + name: "bounds-expansion", + type: t.boundsExpansion, + triggersBounds: diff.any + }]; + var nodeBorder = [{ + name: "border-color", + type: t.color + }, { + name: "border-opacity", + type: t.zeroOneNumber + }, { + name: "border-width", + type: t.size, + triggersBounds: diff.any + }, { + name: "border-style", + type: t.borderStyle + }]; + var nodeOutline = [{ + name: "outline-color", + type: t.color + }, { + name: "outline-opacity", + type: t.zeroOneNumber + }, { + name: "outline-width", + type: t.size, + triggersBounds: diff.any + }, { + name: "outline-style", + type: t.borderStyle + }, { + name: "outline-offset", + type: t.size, + triggersBounds: diff.any + }]; + var backgroundImage = [{ + name: "background-image", + type: t.urls + }, { + name: "background-image-crossorigin", + type: t.bgCrossOrigin + }, { + name: "background-image-opacity", + type: t.zeroOneNumbers + }, { + name: "background-image-containment", + type: t.bgContainment + }, { + name: "background-image-smoothing", + type: t.bools + }, { + name: "background-position-x", + type: t.bgPos + }, { + name: "background-position-y", + type: t.bgPos + }, { + name: "background-width-relative-to", + type: t.bgRelativeTo + }, { + name: "background-height-relative-to", + type: t.bgRelativeTo + }, { + name: "background-repeat", + type: t.bgRepeat + }, { + name: "background-fit", + type: t.bgFit + }, { + name: "background-clip", + type: t.bgClip + }, { + name: "background-width", + type: t.bgWH + }, { + name: "background-height", + type: t.bgWH + }, { + name: "background-offset-x", + type: t.bgPos + }, { + name: "background-offset-y", + type: t.bgPos + }]; + var compound = [{ + name: "position", + type: t.position, + triggersBounds: diff.any + }, { + name: "compound-sizing-wrt-labels", + type: t.compoundIncludeLabels, + triggersBounds: diff.any + }, { + name: "min-width", + type: t.size, + triggersBounds: diff.any + }, { + name: "min-width-bias-left", + type: t.sizeMaybePercent, + triggersBounds: diff.any + }, { + name: "min-width-bias-right", + type: t.sizeMaybePercent, + triggersBounds: diff.any + }, { + name: "min-height", + type: t.size, + triggersBounds: diff.any + }, { + name: "min-height-bias-top", + type: t.sizeMaybePercent, + triggersBounds: diff.any + }, { + name: "min-height-bias-bottom", + type: t.sizeMaybePercent, + triggersBounds: diff.any + }]; + var edgeLine = [{ + name: "line-style", + type: t.lineStyle + }, { + name: "line-color", + type: t.color + }, { + name: "line-fill", + type: t.fill + }, { + name: "line-cap", + type: t.lineCap + }, { + name: "line-opacity", + type: t.zeroOneNumber + }, { + name: "line-dash-pattern", + type: t.numbers + }, { + name: "line-dash-offset", + type: t.number + }, { + name: "line-gradient-stop-colors", + type: t.colors + }, { + name: "line-gradient-stop-positions", + type: t.percentages + }, { + name: "curve-style", + type: t.curveStyle, + triggersBounds: diff.any, + triggersBoundsOfParallelBeziers: true + }, { + name: "haystack-radius", + type: t.zeroOneNumber, + triggersBounds: diff.any + }, { + name: "source-endpoint", + type: t.edgeEndpoint, + triggersBounds: diff.any + }, { + name: "target-endpoint", + type: t.edgeEndpoint, + triggersBounds: diff.any + }, { + name: "control-point-step-size", + type: t.size, + triggersBounds: diff.any + }, { + name: "control-point-distances", + type: t.bidirectionalSizes, + triggersBounds: diff.any + }, { + name: "control-point-weights", + type: t.numbers, + triggersBounds: diff.any + }, { + name: "segment-distances", + type: t.bidirectionalSizes, + triggersBounds: diff.any + }, { + name: "segment-weights", + type: t.numbers, + triggersBounds: diff.any + }, { + name: "taxi-turn", + type: t.bidirectionalSizeMaybePercent, + triggersBounds: diff.any + }, { + name: "taxi-turn-min-distance", + type: t.size, + triggersBounds: diff.any + }, { + name: "taxi-direction", + type: t.axisDirection, + triggersBounds: diff.any + }, { + name: "edge-distances", + type: t.edgeDistances, + triggersBounds: diff.any + }, { + name: "arrow-scale", + type: t.positiveNumber, + triggersBounds: diff.any + }, { + name: "loop-direction", + type: t.angle, + triggersBounds: diff.any + }, { + name: "loop-sweep", + type: t.angle, + triggersBounds: diff.any + }, { + name: "source-distance-from-node", + type: t.size, + triggersBounds: diff.any + }, { + name: "target-distance-from-node", + type: t.size, + triggersBounds: diff.any + }]; + var ghost = [{ + name: "ghost", + type: t.bool, + triggersBounds: diff.any + }, { + name: "ghost-offset-x", + type: t.bidirectionalSize, + triggersBounds: diff.any + }, { + name: "ghost-offset-y", + type: t.bidirectionalSize, + triggersBounds: diff.any + }, { + name: "ghost-opacity", + type: t.zeroOneNumber + }]; + var core2 = [{ + name: "selection-box-color", + type: t.color + }, { + name: "selection-box-opacity", + type: t.zeroOneNumber + }, { + name: "selection-box-border-color", + type: t.color + }, { + name: "selection-box-border-width", + type: t.size + }, { + name: "active-bg-color", + type: t.color + }, { + name: "active-bg-opacity", + type: t.zeroOneNumber + }, { + name: "active-bg-size", + type: t.size + }, { + name: "outside-texture-bg-color", + type: t.color + }, { + name: "outside-texture-bg-opacity", + type: t.zeroOneNumber + }]; + var pie = []; + styfn$2.pieBackgroundN = 16; + pie.push({ + name: "pie-size", + type: t.sizeMaybePercent + }); + for (var i2 = 1; i2 <= styfn$2.pieBackgroundN; i2++) { + pie.push({ + name: "pie-" + i2 + "-background-color", + type: t.color + }); + pie.push({ + name: "pie-" + i2 + "-background-size", + type: t.percent + }); + pie.push({ + name: "pie-" + i2 + "-background-opacity", + type: t.zeroOneNumber + }); + } + var edgeArrow = []; + var arrowPrefixes = styfn$2.arrowPrefixes = ["source", "mid-source", "target", "mid-target"]; + [{ + name: "arrow-shape", + type: t.arrowShape, + triggersBounds: diff.any + }, { + name: "arrow-color", + type: t.color + }, { + name: "arrow-fill", + type: t.arrowFill + }, { + name: "arrow-width", + type: t.arrowWidth + }].forEach(function(prop2) { + arrowPrefixes.forEach(function(prefix) { + var name = prefix + "-" + prop2.name; + var type = prop2.type, triggersBounds = prop2.triggersBounds; + edgeArrow.push({ + name, + type, + triggersBounds + }); + }); + }, {}); + var props = styfn$2.properties = [].concat(behavior, transition, visibility, overlay, underlay, ghost, commonLabel, labelDimensions, mainLabel, sourceLabel, targetLabel, nodeBody, nodeBorder, nodeOutline, backgroundImage, pie, compound, edgeLine, edgeArrow, core2); + var propGroups = styfn$2.propertyGroups = { + // common to all eles + behavior, + transition, + visibility, + overlay, + underlay, + ghost, + // labels + commonLabel, + labelDimensions, + mainLabel, + sourceLabel, + targetLabel, + // node props + nodeBody, + nodeBorder, + nodeOutline, + backgroundImage, + pie, + compound, + // edge props + edgeLine, + edgeArrow, + core: core2 + }; + var propGroupNames = styfn$2.propertyGroupNames = {}; + var propGroupKeys = styfn$2.propertyGroupKeys = Object.keys(propGroups); + propGroupKeys.forEach(function(key) { + propGroupNames[key] = propGroups[key].map(function(prop2) { + return prop2.name; + }); + propGroups[key].forEach(function(prop2) { + return prop2.groupKey = key; + }); + }); + var aliases = styfn$2.aliases = [{ + name: "content", + pointsTo: "label" + }, { + name: "control-point-distance", + pointsTo: "control-point-distances" + }, { + name: "control-point-weight", + pointsTo: "control-point-weights" + }, { + name: "edge-text-rotation", + pointsTo: "text-rotation" + }, { + name: "padding-left", + pointsTo: "padding" + }, { + name: "padding-right", + pointsTo: "padding" + }, { + name: "padding-top", + pointsTo: "padding" + }, { + name: "padding-bottom", + pointsTo: "padding" + }]; + styfn$2.propertyNames = props.map(function(p2) { + return p2.name; + }); + for (var _i = 0; _i < props.length; _i++) { + var prop = props[_i]; + props[prop.name] = prop; + } + for (var _i2 = 0; _i2 < aliases.length; _i2++) { + var alias = aliases[_i2]; + var pointsToProp = props[alias.pointsTo]; + var aliasProp = { + name: alias.name, + alias: true, + pointsTo: pointsToProp + }; + props.push(aliasProp); + props[alias.name] = aliasProp; + } + })(); + styfn$2.getDefaultProperty = function(name) { + return this.getDefaultProperties()[name]; + }; + styfn$2.getDefaultProperties = function() { + var _p = this._private; + if (_p.defaultProperties != null) { + return _p.defaultProperties; + } + var rawProps = extend({ + // core props + "selection-box-color": "#ddd", + "selection-box-opacity": 0.65, + "selection-box-border-color": "#aaa", + "selection-box-border-width": 1, + "active-bg-color": "black", + "active-bg-opacity": 0.15, + "active-bg-size": 30, + "outside-texture-bg-color": "#000", + "outside-texture-bg-opacity": 0.125, + // common node/edge props + "events": "yes", + "text-events": "no", + "text-valign": "top", + "text-halign": "center", + "text-justification": "auto", + "line-height": 1, + "color": "#000", + "text-outline-color": "#000", + "text-outline-width": 0, + "text-outline-opacity": 1, + "text-opacity": 1, + "text-decoration": "none", + "text-transform": "none", + "text-wrap": "none", + "text-overflow-wrap": "whitespace", + "text-max-width": 9999, + "text-background-color": "#000", + "text-background-opacity": 0, + "text-background-shape": "rectangle", + "text-background-padding": 0, + "text-border-opacity": 0, + "text-border-width": 0, + "text-border-style": "solid", + "text-border-color": "#000", + "font-family": "Helvetica Neue, Helvetica, sans-serif", + "font-style": "normal", + "font-weight": "normal", + "font-size": 16, + "min-zoomed-font-size": 0, + "text-rotation": "none", + "source-text-rotation": "none", + "target-text-rotation": "none", + "visibility": "visible", + "display": "element", + "opacity": 1, + "z-compound-depth": "auto", + "z-index-compare": "auto", + "z-index": 0, + "label": "", + "text-margin-x": 0, + "text-margin-y": 0, + "source-label": "", + "source-text-offset": 0, + "source-text-margin-x": 0, + "source-text-margin-y": 0, + "target-label": "", + "target-text-offset": 0, + "target-text-margin-x": 0, + "target-text-margin-y": 0, + "overlay-opacity": 0, + "overlay-color": "#000", + "overlay-padding": 10, + "overlay-shape": "round-rectangle", + "underlay-opacity": 0, + "underlay-color": "#000", + "underlay-padding": 10, + "underlay-shape": "round-rectangle", + "transition-property": "none", + "transition-duration": 0, + "transition-delay": 0, + "transition-timing-function": "linear", + // node props + "background-blacken": 0, + "background-color": "#999", + "background-fill": "solid", + "background-opacity": 1, + "background-image": "none", + "background-image-crossorigin": "anonymous", + "background-image-opacity": 1, + "background-image-containment": "inside", + "background-image-smoothing": "yes", + "background-position-x": "50%", + "background-position-y": "50%", + "background-offset-x": 0, + "background-offset-y": 0, + "background-width-relative-to": "include-padding", + "background-height-relative-to": "include-padding", + "background-repeat": "no-repeat", + "background-fit": "none", + "background-clip": "node", + "background-width": "auto", + "background-height": "auto", + "border-color": "#000", + "border-opacity": 1, + "border-width": 0, + "border-style": "solid", + "outline-color": "#999", + "outline-opacity": 1, + "outline-width": 0, + "outline-offset": 0, + "outline-style": "solid", + "height": 30, + "width": 30, + "shape": "ellipse", + "shape-polygon-points": "-1, -1, 1, -1, 1, 1, -1, 1", + "bounds-expansion": 0, + // node gradient + "background-gradient-direction": "to-bottom", + "background-gradient-stop-colors": "#999", + "background-gradient-stop-positions": "0%", + // ghost props + "ghost": "no", + "ghost-offset-y": 0, + "ghost-offset-x": 0, + "ghost-opacity": 0, + // compound props + "padding": 0, + "padding-relative-to": "width", + "position": "origin", + "compound-sizing-wrt-labels": "include", + "min-width": 0, + "min-width-bias-left": 0, + "min-width-bias-right": 0, + "min-height": 0, + "min-height-bias-top": 0, + "min-height-bias-bottom": 0 + }, { + // node pie bg + "pie-size": "100%" + }, [{ + name: "pie-{{i}}-background-color", + value: "black" + }, { + name: "pie-{{i}}-background-size", + value: "0%" + }, { + name: "pie-{{i}}-background-opacity", + value: 1 + }].reduce(function(css, prop2) { + for (var i3 = 1; i3 <= styfn$2.pieBackgroundN; i3++) { + var name2 = prop2.name.replace("{{i}}", i3); + var val2 = prop2.value; + css[name2] = val2; + } + return css; + }, {}), { + // edge props + "line-style": "solid", + "line-color": "#999", + "line-fill": "solid", + "line-cap": "butt", + "line-opacity": 1, + "line-gradient-stop-colors": "#999", + "line-gradient-stop-positions": "0%", + "control-point-step-size": 40, + "control-point-weights": 0.5, + "segment-weights": 0.5, + "segment-distances": 20, + "taxi-turn": "50%", + "taxi-turn-min-distance": 10, + "taxi-direction": "auto", + "edge-distances": "intersection", + "curve-style": "haystack", + "haystack-radius": 0, + "arrow-scale": 1, + "loop-direction": "-45deg", + "loop-sweep": "-90deg", + "source-distance-from-node": 0, + "target-distance-from-node": 0, + "source-endpoint": "outside-to-node", + "target-endpoint": "outside-to-node", + "line-dash-pattern": [6, 3], + "line-dash-offset": 0 + }, [{ + name: "arrow-shape", + value: "none" + }, { + name: "arrow-color", + value: "#999" + }, { + name: "arrow-fill", + value: "filled" + }, { + name: "arrow-width", + value: 1 + }].reduce(function(css, prop2) { + styfn$2.arrowPrefixes.forEach(function(prefix) { + var name2 = prefix + "-" + prop2.name; + var val2 = prop2.value; + css[name2] = val2; + }); + return css; + }, {})); + var parsedProps = {}; + for (var i2 = 0; i2 < this.properties.length; i2++) { + var prop = this.properties[i2]; + if (prop.pointsTo) { + continue; + } + var name = prop.name; + var val = rawProps[name]; + var parsedProp = this.parse(name, val); + parsedProps[name] = parsedProp; + } + _p.defaultProperties = parsedProps; + return _p.defaultProperties; + }; + styfn$2.addDefaultStylesheet = function() { + this.selector(":parent").css({ + "shape": "rectangle", + "padding": 10, + "background-color": "#eee", + "border-color": "#ccc", + "border-width": 1 + }).selector("edge").css({ + "width": 3 + }).selector(":loop").css({ + "curve-style": "bezier" + }).selector("edge:compound").css({ + "curve-style": "bezier", + "source-endpoint": "outside-to-line", + "target-endpoint": "outside-to-line" + }).selector(":selected").css({ + "background-color": "#0169D9", + "line-color": "#0169D9", + "source-arrow-color": "#0169D9", + "target-arrow-color": "#0169D9", + "mid-source-arrow-color": "#0169D9", + "mid-target-arrow-color": "#0169D9" + }).selector(":parent:selected").css({ + "background-color": "#CCE1F9", + "border-color": "#aec8e5" + }).selector(":active").css({ + "overlay-color": "black", + "overlay-padding": 10, + "overlay-opacity": 0.25 + }); + this.defaultLength = this.length; + }; + var styfn$1 = {}; + styfn$1.parse = function(name, value, propIsBypass, propIsFlat) { + var self2 = this; + if (fn$6(value)) { + return self2.parseImplWarn(name, value, propIsBypass, propIsFlat); + } + var flatKey = propIsFlat === "mapping" || propIsFlat === true || propIsFlat === false || propIsFlat == null ? "dontcare" : propIsFlat; + var bypassKey = propIsBypass ? "t" : "f"; + var valueKey = "" + value; + var argHash = hashStrings(name, valueKey, bypassKey, flatKey); + var propCache = self2.propCache = self2.propCache || []; + var ret; + if (!(ret = propCache[argHash])) { + ret = propCache[argHash] = self2.parseImplWarn(name, value, propIsBypass, propIsFlat); + } + if (propIsBypass || propIsFlat === "mapping") { + ret = copy(ret); + if (ret) { + ret.value = copy(ret.value); + } + } + return ret; + }; + styfn$1.parseImplWarn = function(name, value, propIsBypass, propIsFlat) { + var prop = this.parseImpl(name, value, propIsBypass, propIsFlat); + if (!prop && value != null) { + warn("The style property `".concat(name, ": ").concat(value, "` is invalid")); + } + if (prop && (prop.name === "width" || prop.name === "height") && value === "label") { + warn("The style value of `label` is deprecated for `" + prop.name + "`"); + } + return prop; + }; + styfn$1.parseImpl = function(name, value, propIsBypass, propIsFlat) { + var self2 = this; + name = camel2dash(name); + var property = self2.properties[name]; + var passedValue = value; + var types = self2.types; + if (!property) { + return null; + } + if (value === void 0) { + return null; + } + if (property.alias) { + property = property.pointsTo; + name = property.name; + } + var valueIsString = string(value); + if (valueIsString) { + value = value.trim(); + } + var type = property.type; + if (!type) { + return null; + } + if (propIsBypass && (value === "" || value === null)) { + return { + name, + value, + bypass: true, + deleteBypass: true + }; + } + if (fn$6(value)) { + return { + name, + value, + strValue: "fn", + mapped: types.fn, + bypass: propIsBypass + }; + } + var data2, mapData; + if (!valueIsString || propIsFlat || value.length < 7 || value[1] !== "a") + ; + else if (value.length >= 7 && value[0] === "d" && (data2 = new RegExp(types.data.regex).exec(value))) { + if (propIsBypass) { + return false; + } + var mapped = types.data; + return { + name, + value: data2, + strValue: "" + value, + mapped, + field: data2[1], + bypass: propIsBypass + }; + } else if (value.length >= 10 && value[0] === "m" && (mapData = new RegExp(types.mapData.regex).exec(value))) { + if (propIsBypass) { + return false; + } + if (type.multiple) { + return false; + } + var _mapped = types.mapData; + if (!(type.color || type.number)) { + return false; + } + var valueMin = this.parse(name, mapData[4]); + if (!valueMin || valueMin.mapped) { + return false; + } + var valueMax = this.parse(name, mapData[5]); + if (!valueMax || valueMax.mapped) { + return false; + } + if (valueMin.pfValue === valueMax.pfValue || valueMin.strValue === valueMax.strValue) { + warn("`" + name + ": " + value + "` is not a valid mapper because the output range is zero; converting to `" + name + ": " + valueMin.strValue + "`"); + return this.parse(name, valueMin.strValue); + } else if (type.color) { + var c1 = valueMin.value; + var c2 = valueMax.value; + var same = c1[0] === c2[0] && c1[1] === c2[1] && c1[2] === c2[2] && // optional alpha + (c1[3] === c2[3] || (c1[3] == null || c1[3] === 1) && (c2[3] == null || c2[3] === 1)); + if (same) { + return false; + } + } + return { + name, + value: mapData, + strValue: "" + value, + mapped: _mapped, + field: mapData[1], + fieldMin: parseFloat(mapData[2]), + // min & max are numeric + fieldMax: parseFloat(mapData[3]), + valueMin: valueMin.value, + valueMax: valueMax.value, + bypass: propIsBypass + }; + } + if (type.multiple && propIsFlat !== "multiple") { + var vals; + if (valueIsString) { + vals = value.split(/\s+/); + } else if (array(value)) { + vals = value; + } else { + vals = [value]; + } + if (type.evenMultiple && vals.length % 2 !== 0) { + return null; + } + var valArr = []; + var unitsArr = []; + var pfValArr = []; + var strVal = ""; + var hasEnum = false; + for (var i2 = 0; i2 < vals.length; i2++) { + var p2 = self2.parse(name, vals[i2], propIsBypass, "multiple"); + hasEnum = hasEnum || string(p2.value); + valArr.push(p2.value); + pfValArr.push(p2.pfValue != null ? p2.pfValue : p2.value); + unitsArr.push(p2.units); + strVal += (i2 > 0 ? " " : "") + p2.strValue; + } + if (type.validate && !type.validate(valArr, unitsArr)) { + return null; + } + if (type.singleEnum && hasEnum) { + if (valArr.length === 1 && string(valArr[0])) { + return { + name, + value: valArr[0], + strValue: valArr[0], + bypass: propIsBypass + }; + } else { + return null; + } + } + return { + name, + value: valArr, + pfValue: pfValArr, + strValue: strVal, + bypass: propIsBypass, + units: unitsArr + }; + } + var checkEnums = function checkEnums2() { + for (var _i = 0; _i < type.enums.length; _i++) { + var en = type.enums[_i]; + if (en === value) { + return { + name, + value, + strValue: "" + value, + bypass: propIsBypass + }; + } + } + return null; + }; + if (type.number) { + var units; + var implicitUnits = "px"; + if (type.units) { + units = type.units; + } + if (type.implicitUnits) { + implicitUnits = type.implicitUnits; + } + if (!type.unitless) { + if (valueIsString) { + var unitsRegex = "px|em" + (type.allowPercent ? "|\\%" : ""); + if (units) { + unitsRegex = units; + } + var match2 = value.match("^(" + number + ")(" + unitsRegex + ")?$"); + if (match2) { + value = match2[1]; + units = match2[2] || implicitUnits; + } + } else if (!units || type.implicitUnits) { + units = implicitUnits; + } + } + value = parseFloat(value); + if (isNaN(value) && type.enums === void 0) { + return null; + } + if (isNaN(value) && type.enums !== void 0) { + value = passedValue; + return checkEnums(); + } + if (type.integer && !integer(value)) { + return null; + } + if (type.min !== void 0 && (value < type.min || type.strictMin && value === type.min) || type.max !== void 0 && (value > type.max || type.strictMax && value === type.max)) { + return null; + } + var ret = { + name, + value, + strValue: "" + value + (units ? units : ""), + units, + bypass: propIsBypass + }; + if (type.unitless || units !== "px" && units !== "em") { + ret.pfValue = value; + } else { + ret.pfValue = units === "px" || !units ? value : this.getEmSizeInPixels() * value; + } + if (units === "ms" || units === "s") { + ret.pfValue = units === "ms" ? value : 1e3 * value; + } + if (units === "deg" || units === "rad") { + ret.pfValue = units === "rad" ? value : deg2rad(value); + } + if (units === "%") { + ret.pfValue = value / 100; + } + return ret; + } else if (type.propList) { + var props = []; + var propsStr = "" + value; + if (propsStr === "none") + ; + else { + var propsSplit = propsStr.split(/\s*,\s*|\s+/); + for (var _i2 = 0; _i2 < propsSplit.length; _i2++) { + var propName = propsSplit[_i2].trim(); + if (self2.properties[propName]) { + props.push(propName); + } else { + warn("`" + propName + "` is not a valid property name"); + } + } + if (props.length === 0) { + return null; + } + } + return { + name, + value: props, + strValue: props.length === 0 ? "none" : props.join(" "), + bypass: propIsBypass + }; + } else if (type.color) { + var tuple = color2tuple(value); + if (!tuple) { + return null; + } + return { + name, + value: tuple, + pfValue: tuple, + strValue: "rgb(" + tuple[0] + "," + tuple[1] + "," + tuple[2] + ")", + // n.b. no spaces b/c of multiple support + bypass: propIsBypass + }; + } else if (type.regex || type.regexes) { + if (type.enums) { + var enumProp = checkEnums(); + if (enumProp) { + return enumProp; + } + } + var regexes = type.regexes ? type.regexes : [type.regex]; + for (var _i3 = 0; _i3 < regexes.length; _i3++) { + var regex = new RegExp(regexes[_i3]); + var m = regex.exec(value); + if (m) { + return { + name, + value: type.singleRegexMatchValue ? m[1] : m, + strValue: "" + value, + bypass: propIsBypass + }; + } + } + return null; + } else if (type.string) { + return { + name, + value: "" + value, + strValue: "" + value, + bypass: propIsBypass + }; + } else if (type.enums) { + return checkEnums(); + } else { + return null; + } + }; + var Style = function Style2(cy) { + if (!(this instanceof Style2)) { + return new Style2(cy); + } + if (!core(cy)) { + error("A style must have a core reference"); + return; + } + this._private = { + cy, + coreStyle: {} + }; + this.length = 0; + this.resetToDefault(); + }; + var styfn = Style.prototype; + styfn.instanceString = function() { + return "style"; + }; + styfn.clear = function() { + var _p = this._private; + var cy = _p.cy; + var eles = cy.elements(); + for (var i2 = 0; i2 < this.length; i2++) { + this[i2] = void 0; + } + this.length = 0; + _p.contextStyles = {}; + _p.propDiffs = {}; + this.cleanElements(eles, true); + eles.forEach(function(ele) { + var ele_p = ele[0]._private; + ele_p.styleDirty = true; + ele_p.appliedInitStyle = false; + }); + return this; + }; + styfn.resetToDefault = function() { + this.clear(); + this.addDefaultStylesheet(); + return this; + }; + styfn.core = function(propName) { + return this._private.coreStyle[propName] || this.getDefaultProperty(propName); + }; + styfn.selector = function(selectorStr) { + var selector = selectorStr === "core" ? null : new Selector(selectorStr); + var i2 = this.length++; + this[i2] = { + selector, + properties: [], + mappedProperties: [], + index: i2 + }; + return this; + }; + styfn.css = function() { + var self2 = this; + var args = arguments; + if (args.length === 1) { + var map = args[0]; + for (var i2 = 0; i2 < self2.properties.length; i2++) { + var prop = self2.properties[i2]; + var mapVal = map[prop.name]; + if (mapVal === void 0) { + mapVal = map[dash2camel(prop.name)]; + } + if (mapVal !== void 0) { + this.cssRule(prop.name, mapVal); + } + } + } else if (args.length === 2) { + this.cssRule(args[0], args[1]); + } + return this; + }; + styfn.style = styfn.css; + styfn.cssRule = function(name, value) { + var property = this.parse(name, value); + if (property) { + var i2 = this.length - 1; + this[i2].properties.push(property); + this[i2].properties[property.name] = property; + if (property.name.match(/pie-(\d+)-background-size/) && property.value) { + this._private.hasPie = true; + } + if (property.mapped) { + this[i2].mappedProperties.push(property); + } + var currentSelectorIsCore = !this[i2].selector; + if (currentSelectorIsCore) { + this._private.coreStyle[property.name] = property; + } + } + return this; + }; + styfn.append = function(style) { + if (stylesheet(style)) { + style.appendToStyle(this); + } else if (array(style)) { + this.appendFromJson(style); + } else if (string(style)) { + this.appendFromString(style); + } + return this; + }; + Style.fromJson = function(cy, json) { + var style = new Style(cy); + style.fromJson(json); + return style; + }; + Style.fromString = function(cy, string2) { + return new Style(cy).fromString(string2); + }; + [styfn$8, styfn$7, styfn$6, styfn$5, styfn$4, styfn$3, styfn$2, styfn$1].forEach(function(props) { + extend(styfn, props); + }); + Style.types = styfn.types; + Style.properties = styfn.properties; + Style.propertyGroups = styfn.propertyGroups; + Style.propertyGroupNames = styfn.propertyGroupNames; + Style.propertyGroupKeys = styfn.propertyGroupKeys; + var corefn$2 = { + style: function style(newStyle) { + if (newStyle) { + var s = this.setStyle(newStyle); + s.update(); + } + return this._private.style; + }, + setStyle: function setStyle(style) { + var _p = this._private; + if (stylesheet(style)) { + _p.style = style.generateStyle(this); + } else if (array(style)) { + _p.style = Style.fromJson(this, style); + } else if (string(style)) { + _p.style = Style.fromString(this, style); + } else { + _p.style = Style(this); + } + return _p.style; + }, + // e.g. cy.data() changed => recalc ele mappers + updateStyle: function updateStyle() { + this.mutableElements().updateStyle(); + } + }; + var defaultSelectionType = "single"; + var corefn$1 = { + autolock: function autolock(bool) { + if (bool !== void 0) { + this._private.autolock = bool ? true : false; + } else { + return this._private.autolock; + } + return this; + }, + autoungrabify: function autoungrabify(bool) { + if (bool !== void 0) { + this._private.autoungrabify = bool ? true : false; + } else { + return this._private.autoungrabify; + } + return this; + }, + autounselectify: function autounselectify(bool) { + if (bool !== void 0) { + this._private.autounselectify = bool ? true : false; + } else { + return this._private.autounselectify; + } + return this; + }, + selectionType: function selectionType(selType) { + var _p = this._private; + if (_p.selectionType == null) { + _p.selectionType = defaultSelectionType; + } + if (selType !== void 0) { + if (selType === "additive" || selType === "single") { + _p.selectionType = selType; + } + } else { + return _p.selectionType; + } + return this; + }, + panningEnabled: function panningEnabled(bool) { + if (bool !== void 0) { + this._private.panningEnabled = bool ? true : false; + } else { + return this._private.panningEnabled; + } + return this; + }, + userPanningEnabled: function userPanningEnabled(bool) { + if (bool !== void 0) { + this._private.userPanningEnabled = bool ? true : false; + } else { + return this._private.userPanningEnabled; + } + return this; + }, + zoomingEnabled: function zoomingEnabled(bool) { + if (bool !== void 0) { + this._private.zoomingEnabled = bool ? true : false; + } else { + return this._private.zoomingEnabled; + } + return this; + }, + userZoomingEnabled: function userZoomingEnabled(bool) { + if (bool !== void 0) { + this._private.userZoomingEnabled = bool ? true : false; + } else { + return this._private.userZoomingEnabled; + } + return this; + }, + boxSelectionEnabled: function boxSelectionEnabled(bool) { + if (bool !== void 0) { + this._private.boxSelectionEnabled = bool ? true : false; + } else { + return this._private.boxSelectionEnabled; + } + return this; + }, + pan: function pan() { + var args = arguments; + var pan2 = this._private.pan; + var dim, val, dims, x, y; + switch (args.length) { + case 0: + return pan2; + case 1: + if (string(args[0])) { + dim = args[0]; + return pan2[dim]; + } else if (plainObject(args[0])) { + if (!this._private.panningEnabled) { + return this; + } + dims = args[0]; + x = dims.x; + y = dims.y; + if (number$1(x)) { + pan2.x = x; + } + if (number$1(y)) { + pan2.y = y; + } + this.emit("pan viewport"); + } + break; + case 2: + if (!this._private.panningEnabled) { + return this; + } + dim = args[0]; + val = args[1]; + if ((dim === "x" || dim === "y") && number$1(val)) { + pan2[dim] = val; + } + this.emit("pan viewport"); + break; + } + this.notify("viewport"); + return this; + }, + panBy: function panBy(arg0, arg1) { + var args = arguments; + var pan = this._private.pan; + var dim, val, dims, x, y; + if (!this._private.panningEnabled) { + return this; + } + switch (args.length) { + case 1: + if (plainObject(arg0)) { + dims = args[0]; + x = dims.x; + y = dims.y; + if (number$1(x)) { + pan.x += x; + } + if (number$1(y)) { + pan.y += y; + } + this.emit("pan viewport"); + } + break; + case 2: + dim = arg0; + val = arg1; + if ((dim === "x" || dim === "y") && number$1(val)) { + pan[dim] += val; + } + this.emit("pan viewport"); + break; + } + this.notify("viewport"); + return this; + }, + fit: function fit(elements2, padding) { + var viewportState = this.getFitViewport(elements2, padding); + if (viewportState) { + var _p = this._private; + _p.zoom = viewportState.zoom; + _p.pan = viewportState.pan; + this.emit("pan zoom viewport"); + this.notify("viewport"); + } + return this; + }, + getFitViewport: function getFitViewport(elements2, padding) { + if (number$1(elements2) && padding === void 0) { + padding = elements2; + elements2 = void 0; + } + if (!this._private.panningEnabled || !this._private.zoomingEnabled) { + return; + } + var bb; + if (string(elements2)) { + var sel = elements2; + elements2 = this.$(sel); + } else if (boundingBox(elements2)) { + var bbe = elements2; + bb = { + x1: bbe.x1, + y1: bbe.y1, + x2: bbe.x2, + y2: bbe.y2 + }; + bb.w = bb.x2 - bb.x1; + bb.h = bb.y2 - bb.y1; + } else if (!elementOrCollection(elements2)) { + elements2 = this.mutableElements(); + } + if (elementOrCollection(elements2) && elements2.empty()) { + return; + } + bb = bb || elements2.boundingBox(); + var w = this.width(); + var h = this.height(); + var zoom; + padding = number$1(padding) ? padding : 0; + if (!isNaN(w) && !isNaN(h) && w > 0 && h > 0 && !isNaN(bb.w) && !isNaN(bb.h) && bb.w > 0 && bb.h > 0) { + zoom = Math.min((w - 2 * padding) / bb.w, (h - 2 * padding) / bb.h); + zoom = zoom > this._private.maxZoom ? this._private.maxZoom : zoom; + zoom = zoom < this._private.minZoom ? this._private.minZoom : zoom; + var pan = { + // now pan to middle + x: (w - zoom * (bb.x1 + bb.x2)) / 2, + y: (h - zoom * (bb.y1 + bb.y2)) / 2 + }; + return { + zoom, + pan + }; + } + return; + }, + zoomRange: function zoomRange(min2, max2) { + var _p = this._private; + if (max2 == null) { + var opts = min2; + min2 = opts.min; + max2 = opts.max; + } + if (number$1(min2) && number$1(max2) && min2 <= max2) { + _p.minZoom = min2; + _p.maxZoom = max2; + } else if (number$1(min2) && max2 === void 0 && min2 <= _p.maxZoom) { + _p.minZoom = min2; + } else if (number$1(max2) && min2 === void 0 && max2 >= _p.minZoom) { + _p.maxZoom = max2; + } + return this; + }, + minZoom: function minZoom(zoom) { + if (zoom === void 0) { + return this._private.minZoom; + } else { + return this.zoomRange({ + min: zoom + }); + } + }, + maxZoom: function maxZoom2(zoom) { + if (zoom === void 0) { + return this._private.maxZoom; + } else { + return this.zoomRange({ + max: zoom + }); + } + }, + getZoomedViewport: function getZoomedViewport(params) { + var _p = this._private; + var currentPan = _p.pan; + var currentZoom = _p.zoom; + var pos; + var zoom; + var bail = false; + if (!_p.zoomingEnabled) { + bail = true; + } + if (number$1(params)) { + zoom = params; + } else if (plainObject(params)) { + zoom = params.level; + if (params.position != null) { + pos = modelToRenderedPosition(params.position, currentZoom, currentPan); + } else if (params.renderedPosition != null) { + pos = params.renderedPosition; + } + if (pos != null && !_p.panningEnabled) { + bail = true; + } + } + zoom = zoom > _p.maxZoom ? _p.maxZoom : zoom; + zoom = zoom < _p.minZoom ? _p.minZoom : zoom; + if (bail || !number$1(zoom) || zoom === currentZoom || pos != null && (!number$1(pos.x) || !number$1(pos.y))) { + return null; + } + if (pos != null) { + var pan1 = currentPan; + var zoom1 = currentZoom; + var zoom2 = zoom; + var pan2 = { + x: -zoom2 / zoom1 * (pos.x - pan1.x) + pos.x, + y: -zoom2 / zoom1 * (pos.y - pan1.y) + pos.y + }; + return { + zoomed: true, + panned: true, + zoom: zoom2, + pan: pan2 + }; + } else { + return { + zoomed: true, + panned: false, + zoom, + pan: currentPan + }; + } + }, + zoom: function zoom(params) { + if (params === void 0) { + return this._private.zoom; + } else { + var vp = this.getZoomedViewport(params); + var _p = this._private; + if (vp == null || !vp.zoomed) { + return this; + } + _p.zoom = vp.zoom; + if (vp.panned) { + _p.pan.x = vp.pan.x; + _p.pan.y = vp.pan.y; + } + this.emit("zoom" + (vp.panned ? " pan" : "") + " viewport"); + this.notify("viewport"); + return this; + } + }, + viewport: function viewport(opts) { + var _p = this._private; + var zoomDefd = true; + var panDefd = true; + var events = []; + var zoomFailed = false; + var panFailed = false; + if (!opts) { + return this; + } + if (!number$1(opts.zoom)) { + zoomDefd = false; + } + if (!plainObject(opts.pan)) { + panDefd = false; + } + if (!zoomDefd && !panDefd) { + return this; + } + if (zoomDefd) { + var z = opts.zoom; + if (z < _p.minZoom || z > _p.maxZoom || !_p.zoomingEnabled) { + zoomFailed = true; + } else { + _p.zoom = z; + events.push("zoom"); + } + } + if (panDefd && (!zoomFailed || !opts.cancelOnFailedZoom) && _p.panningEnabled) { + var p2 = opts.pan; + if (number$1(p2.x)) { + _p.pan.x = p2.x; + panFailed = false; + } + if (number$1(p2.y)) { + _p.pan.y = p2.y; + panFailed = false; + } + if (!panFailed) { + events.push("pan"); + } + } + if (events.length > 0) { + events.push("viewport"); + this.emit(events.join(" ")); + this.notify("viewport"); + } + return this; + }, + center: function center(elements2) { + var pan = this.getCenterPan(elements2); + if (pan) { + this._private.pan = pan; + this.emit("pan viewport"); + this.notify("viewport"); + } + return this; + }, + getCenterPan: function getCenterPan(elements2, zoom) { + if (!this._private.panningEnabled) { + return; + } + if (string(elements2)) { + var selector = elements2; + elements2 = this.mutableElements().filter(selector); + } else if (!elementOrCollection(elements2)) { + elements2 = this.mutableElements(); + } + if (elements2.length === 0) { + return; + } + var bb = elements2.boundingBox(); + var w = this.width(); + var h = this.height(); + zoom = zoom === void 0 ? this._private.zoom : zoom; + var pan = { + // middle + x: (w - zoom * (bb.x1 + bb.x2)) / 2, + y: (h - zoom * (bb.y1 + bb.y2)) / 2 + }; + return pan; + }, + reset: function reset() { + if (!this._private.panningEnabled || !this._private.zoomingEnabled) { + return this; + } + this.viewport({ + pan: { + x: 0, + y: 0 + }, + zoom: 1 + }); + return this; + }, + invalidateSize: function invalidateSize() { + this._private.sizeCache = null; + }, + size: function size() { + var _p = this._private; + var container = _p.container; + var cy = this; + return _p.sizeCache = _p.sizeCache || (container ? function() { + var style = cy.window().getComputedStyle(container); + var val = function val2(name) { + return parseFloat(style.getPropertyValue(name)); + }; + return { + width: container.clientWidth - val("padding-left") - val("padding-right"), + height: container.clientHeight - val("padding-top") - val("padding-bottom") + }; + }() : { + // fallback if no container (not 0 b/c can be used for dividing etc) + width: 1, + height: 1 + }); + }, + width: function width() { + return this.size().width; + }, + height: function height() { + return this.size().height; + }, + extent: function extent() { + var pan = this._private.pan; + var zoom = this._private.zoom; + var rb = this.renderedExtent(); + var b = { + x1: (rb.x1 - pan.x) / zoom, + x2: (rb.x2 - pan.x) / zoom, + y1: (rb.y1 - pan.y) / zoom, + y2: (rb.y2 - pan.y) / zoom + }; + b.w = b.x2 - b.x1; + b.h = b.y2 - b.y1; + return b; + }, + renderedExtent: function renderedExtent() { + var width = this.width(); + var height = this.height(); + return { + x1: 0, + y1: 0, + x2: width, + y2: height, + w: width, + h: height + }; + }, + multiClickDebounceTime: function multiClickDebounceTime(_int) { + if (_int) + this._private.multiClickDebounceTime = _int; + else + return this._private.multiClickDebounceTime; + return this; + } + }; + corefn$1.centre = corefn$1.center; + corefn$1.autolockNodes = corefn$1.autolock; + corefn$1.autoungrabifyNodes = corefn$1.autoungrabify; + var fn = { + data: define.data({ + field: "data", + bindingEvent: "data", + allowBinding: true, + allowSetting: true, + settingEvent: "data", + settingTriggersEvent: true, + triggerFnName: "trigger", + allowGetting: true, + updateStyle: true + }), + removeData: define.removeData({ + field: "data", + event: "data", + triggerFnName: "trigger", + triggerEvent: true, + updateStyle: true + }), + scratch: define.data({ + field: "scratch", + bindingEvent: "scratch", + allowBinding: true, + allowSetting: true, + settingEvent: "scratch", + settingTriggersEvent: true, + triggerFnName: "trigger", + allowGetting: true, + updateStyle: true + }), + removeScratch: define.removeData({ + field: "scratch", + event: "scratch", + triggerFnName: "trigger", + triggerEvent: true, + updateStyle: true + }) + }; + fn.attr = fn.data; + fn.removeAttr = fn.removeData; + var Core = function Core2(opts) { + var cy = this; + opts = extend({}, opts); + var container = opts.container; + if (container && !htmlElement(container) && htmlElement(container[0])) { + container = container[0]; + } + var reg = container ? container._cyreg : null; + reg = reg || {}; + if (reg && reg.cy) { + reg.cy.destroy(); + reg = {}; + } + var readies = reg.readies = reg.readies || []; + if (container) { + container._cyreg = reg; + } + reg.cy = cy; + var head = _window !== void 0 && container !== void 0 && !opts.headless; + var options = opts; + options.layout = extend({ + name: head ? "grid" : "null" + }, options.layout); + options.renderer = extend({ + name: head ? "canvas" : "null" + }, options.renderer); + var defVal = function defVal2(def, val, altVal) { + if (val !== void 0) { + return val; + } else if (altVal !== void 0) { + return altVal; + } else { + return def; + } + }; + var _p = this._private = { + container, + // html dom ele container + ready: false, + // whether ready has been triggered + options, + // cached options + elements: new Collection(this), + // elements in the graph + listeners: [], + // list of listeners + aniEles: new Collection(this), + // elements being animated + data: options.data || {}, + // data for the core + scratch: {}, + // scratch object for core + layout: null, + renderer: null, + destroyed: false, + // whether destroy was called + notificationsEnabled: true, + // whether notifications are sent to the renderer + minZoom: 1e-50, + maxZoom: 1e50, + zoomingEnabled: defVal(true, options.zoomingEnabled), + userZoomingEnabled: defVal(true, options.userZoomingEnabled), + panningEnabled: defVal(true, options.panningEnabled), + userPanningEnabled: defVal(true, options.userPanningEnabled), + boxSelectionEnabled: defVal(true, options.boxSelectionEnabled), + autolock: defVal(false, options.autolock, options.autolockNodes), + autoungrabify: defVal(false, options.autoungrabify, options.autoungrabifyNodes), + autounselectify: defVal(false, options.autounselectify), + styleEnabled: options.styleEnabled === void 0 ? head : options.styleEnabled, + zoom: number$1(options.zoom) ? options.zoom : 1, + pan: { + x: plainObject(options.pan) && number$1(options.pan.x) ? options.pan.x : 0, + y: plainObject(options.pan) && number$1(options.pan.y) ? options.pan.y : 0 + }, + animation: { + // object for currently-running animations + current: [], + queue: [] + }, + hasCompoundNodes: false, + multiClickDebounceTime: defVal(250, options.multiClickDebounceTime) + }; + this.createEmitter(); + this.selectionType(options.selectionType); + this.zoomRange({ + min: options.minZoom, + max: options.maxZoom + }); + var loadExtData = function loadExtData2(extData, next2) { + var anyIsPromise = extData.some(promise); + if (anyIsPromise) { + return Promise$1.all(extData).then(next2); + } else { + next2(extData); + } + }; + if (_p.styleEnabled) { + cy.setStyle([]); + } + var rendererOptions = extend({}, options, options.renderer); + cy.initRenderer(rendererOptions); + var setElesAndLayout = function setElesAndLayout2(elements2, onload, ondone) { + cy.notifications(false); + var oldEles = cy.mutableElements(); + if (oldEles.length > 0) { + oldEles.remove(); + } + if (elements2 != null) { + if (plainObject(elements2) || array(elements2)) { + cy.add(elements2); + } + } + cy.one("layoutready", function(e) { + cy.notifications(true); + cy.emit(e); + cy.one("load", onload); + cy.emitAndNotify("load"); + }).one("layoutstop", function() { + cy.one("done", ondone); + cy.emit("done"); + }); + var layoutOpts = extend({}, cy._private.options.layout); + layoutOpts.eles = cy.elements(); + cy.layout(layoutOpts).run(); + }; + loadExtData([options.style, options.elements], function(thens) { + var initStyle = thens[0]; + var initEles = thens[1]; + if (_p.styleEnabled) { + cy.style().append(initStyle); + } + setElesAndLayout(initEles, function() { + cy.startAnimationLoop(); + _p.ready = true; + if (fn$6(options.ready)) { + cy.on("ready", options.ready); + } + for (var i2 = 0; i2 < readies.length; i2++) { + var fn2 = readies[i2]; + cy.on("ready", fn2); + } + if (reg) { + reg.readies = []; + } + cy.emit("ready"); + }, options.done); + }); + }; + var corefn = Core.prototype; + extend(corefn, { + instanceString: function instanceString() { + return "core"; + }, + isReady: function isReady() { + return this._private.ready; + }, + destroyed: function destroyed() { + return this._private.destroyed; + }, + ready: function ready(fn2) { + if (this.isReady()) { + this.emitter().emit("ready", [], fn2); + } else { + this.on("ready", fn2); + } + return this; + }, + destroy: function destroy() { + var cy = this; + if (cy.destroyed()) + return; + cy.stopAnimationLoop(); + cy.destroyRenderer(); + this.emit("destroy"); + cy._private.destroyed = true; + return cy; + }, + hasElementWithId: function hasElementWithId(id) { + return this._private.elements.hasElementWithId(id); + }, + getElementById: function getElementById2(id) { + return this._private.elements.getElementById(id); + }, + hasCompoundNodes: function hasCompoundNodes() { + return this._private.hasCompoundNodes; + }, + headless: function headless() { + return this._private.renderer.isHeadless(); + }, + styleEnabled: function styleEnabled() { + return this._private.styleEnabled; + }, + addToPool: function addToPool(eles) { + this._private.elements.merge(eles); + return this; + }, + removeFromPool: function removeFromPool(eles) { + this._private.elements.unmerge(eles); + return this; + }, + container: function container() { + return this._private.container || null; + }, + window: function window2() { + var container = this._private.container; + if (container == null) + return _window; + var ownerDocument = this._private.container.ownerDocument; + if (ownerDocument === void 0 || ownerDocument == null) { + return _window; + } + return ownerDocument.defaultView || _window; + }, + mount: function mount(container) { + if (container == null) { + return; + } + var cy = this; + var _p = cy._private; + var options = _p.options; + if (!htmlElement(container) && htmlElement(container[0])) { + container = container[0]; + } + cy.stopAnimationLoop(); + cy.destroyRenderer(); + _p.container = container; + _p.styleEnabled = true; + cy.invalidateSize(); + cy.initRenderer(extend({}, options, options.renderer, { + // allow custom renderer name to be re-used, otherwise use canvas + name: options.renderer.name === "null" ? "canvas" : options.renderer.name + })); + cy.startAnimationLoop(); + cy.style(options.style); + cy.emit("mount"); + return cy; + }, + unmount: function unmount() { + var cy = this; + cy.stopAnimationLoop(); + cy.destroyRenderer(); + cy.initRenderer({ + name: "null" + }); + cy.emit("unmount"); + return cy; + }, + options: function options() { + return copy(this._private.options); + }, + json: function json(obj) { + var cy = this; + var _p = cy._private; + var eles = cy.mutableElements(); + var getFreshRef = function getFreshRef2(ele) { + return cy.getElementById(ele.id()); + }; + if (plainObject(obj)) { + cy.startBatch(); + if (obj.elements) { + var idInJson = {}; + var updateEles = function updateEles2(jsons, gr2) { + var toAdd = []; + var toMod = []; + for (var i3 = 0; i3 < jsons.length; i3++) { + var json3 = jsons[i3]; + if (!json3.data.id) { + warn("cy.json() cannot handle elements without an ID attribute"); + continue; + } + var id = "" + json3.data.id; + var ele = cy.getElementById(id); + idInJson[id] = true; + if (ele.length !== 0) { + toMod.push({ + ele, + json: json3 + }); + } else { + if (gr2) { + json3.group = gr2; + toAdd.push(json3); + } else { + toAdd.push(json3); + } + } + } + cy.add(toAdd); + for (var _i = 0; _i < toMod.length; _i++) { + var _toMod$_i = toMod[_i], _ele = _toMod$_i.ele, _json = _toMod$_i.json; + _ele.json(_json); + } + }; + if (array(obj.elements)) { + updateEles(obj.elements); + } else { + var grs = ["nodes", "edges"]; + for (var i2 = 0; i2 < grs.length; i2++) { + var gr = grs[i2]; + var elements2 = obj.elements[gr]; + if (array(elements2)) { + updateEles(elements2, gr); + } + } + } + var parentsToRemove = cy.collection(); + eles.filter(function(ele) { + return !idInJson[ele.id()]; + }).forEach(function(ele) { + if (ele.isParent()) { + parentsToRemove.merge(ele); + } else { + ele.remove(); + } + }); + parentsToRemove.forEach(function(ele) { + return ele.children().move({ + parent: null + }); + }); + parentsToRemove.forEach(function(ele) { + return getFreshRef(ele).remove(); + }); + } + if (obj.style) { + cy.style(obj.style); + } + if (obj.zoom != null && obj.zoom !== _p.zoom) { + cy.zoom(obj.zoom); + } + if (obj.pan) { + if (obj.pan.x !== _p.pan.x || obj.pan.y !== _p.pan.y) { + cy.pan(obj.pan); + } + } + if (obj.data) { + cy.data(obj.data); + } + var fields = ["minZoom", "maxZoom", "zoomingEnabled", "userZoomingEnabled", "panningEnabled", "userPanningEnabled", "boxSelectionEnabled", "autolock", "autoungrabify", "autounselectify", "multiClickDebounceTime"]; + for (var _i2 = 0; _i2 < fields.length; _i2++) { + var f = fields[_i2]; + if (obj[f] != null) { + cy[f](obj[f]); + } + } + cy.endBatch(); + return this; + } else { + var flat = !!obj; + var json2 = {}; + if (flat) { + json2.elements = this.elements().map(function(ele) { + return ele.json(); + }); + } else { + json2.elements = {}; + eles.forEach(function(ele) { + var group = ele.group(); + if (!json2.elements[group]) { + json2.elements[group] = []; + } + json2.elements[group].push(ele.json()); + }); + } + if (this._private.styleEnabled) { + json2.style = cy.style().json(); + } + json2.data = copy(cy.data()); + var options = _p.options; + json2.zoomingEnabled = _p.zoomingEnabled; + json2.userZoomingEnabled = _p.userZoomingEnabled; + json2.zoom = _p.zoom; + json2.minZoom = _p.minZoom; + json2.maxZoom = _p.maxZoom; + json2.panningEnabled = _p.panningEnabled; + json2.userPanningEnabled = _p.userPanningEnabled; + json2.pan = copy(_p.pan); + json2.boxSelectionEnabled = _p.boxSelectionEnabled; + json2.renderer = copy(options.renderer); + json2.hideEdgesOnViewport = options.hideEdgesOnViewport; + json2.textureOnViewport = options.textureOnViewport; + json2.wheelSensitivity = options.wheelSensitivity; + json2.motionBlur = options.motionBlur; + json2.multiClickDebounceTime = options.multiClickDebounceTime; + return json2; + } + } + }); + corefn.$id = corefn.getElementById; + [corefn$9, corefn$8, elesfn, corefn$7, corefn$6, corefn$5, corefn$4, corefn$3, corefn$2, corefn$1, fn].forEach(function(props) { + extend(corefn, props); + }); + var defaults$7 = { + fit: true, + // whether to fit the viewport to the graph + directed: false, + // whether the tree is directed downwards (or edges can point in any direction if false) + padding: 30, + // padding on fit + circle: false, + // put depths in concentric circles if true, put depths top down if false + grid: false, + // whether to create an even grid into which the DAG is placed (circle:false only) + spacingFactor: 1.75, + // positive spacing factor, larger => more space between nodes (N.B. n/a if causes overlap) + boundingBox: void 0, + // constrain layout bounds; { x1, y1, x2, y2 } or { x1, y1, w, h } + avoidOverlap: true, + // prevents node overlap, may overflow boundingBox if not enough space + nodeDimensionsIncludeLabels: false, + // Excludes the label when calculating node bounding boxes for the layout algorithm + roots: void 0, + // the roots of the trees + depthSort: void 0, + // a sorting function to order nodes at equal depth. e.g. function(a, b){ return a.data('weight') - b.data('weight') } + animate: false, + // whether to transition the node positions + animationDuration: 500, + // duration of animation in ms if enabled + animationEasing: void 0, + // easing of animation if enabled, + animateFilter: function animateFilter(node, i2) { + return true; + }, + // a function that determines whether the node should be animated. All nodes animated by default on animate enabled. Non-animated nodes are positioned immediately when the layout starts + ready: void 0, + // callback on layoutready + stop: void 0, + // callback on layoutstop + transform: function transform(node, position2) { + return position2; + } + // transform a given node position. Useful for changing flow direction in discrete layouts + }; + var deprecatedOptionDefaults = { + maximal: false, + // whether to shift nodes down their natural BFS depths in order to avoid upwards edges (DAGS only); setting acyclic to true sets maximal to true also + acyclic: false + // whether the tree is acyclic and thus a node could be shifted (due to the maximal option) multiple times without causing an infinite loop; setting to true sets maximal to true also; if you are uncertain whether a tree is acyclic, set to false to avoid potential infinite loops + }; + var getInfo = function getInfo2(ele) { + return ele.scratch("breadthfirst"); + }; + var setInfo = function setInfo2(ele, obj) { + return ele.scratch("breadthfirst", obj); + }; + function BreadthFirstLayout(options) { + this.options = extend({}, defaults$7, deprecatedOptionDefaults, options); + } + BreadthFirstLayout.prototype.run = function() { + var params = this.options; + var options = params; + var cy = params.cy; + var eles = options.eles; + var nodes2 = eles.nodes().filter(function(n2) { + return !n2.isParent(); + }); + var graph = eles; + var directed = options.directed; + var maximal = options.acyclic || options.maximal || options.maximalAdjustments > 0; + var bb = makeBoundingBox(options.boundingBox ? options.boundingBox : { + x1: 0, + y1: 0, + w: cy.width(), + h: cy.height() + }); + var roots; + if (elementOrCollection(options.roots)) { + roots = options.roots; + } else if (array(options.roots)) { + var rootsArray = []; + for (var i2 = 0; i2 < options.roots.length; i2++) { + var id = options.roots[i2]; + var ele = cy.getElementById(id); + rootsArray.push(ele); + } + roots = cy.collection(rootsArray); + } else if (string(options.roots)) { + roots = cy.$(options.roots); + } else { + if (directed) { + roots = nodes2.roots(); + } else { + var components = eles.components(); + roots = cy.collection(); + var _loop = function _loop2(_i3) { + var comp = components[_i3]; + var maxDegree = comp.maxDegree(false); + var compRoots = comp.filter(function(ele2) { + return ele2.degree(false) === maxDegree; + }); + roots = roots.add(compRoots); + }; + for (var _i = 0; _i < components.length; _i++) { + _loop(_i); + } + } + } + var depths = []; + var foundByBfs = {}; + var addToDepth = function addToDepth2(ele2, d) { + if (depths[d] == null) { + depths[d] = []; + } + var i3 = depths[d].length; + depths[d].push(ele2); + setInfo(ele2, { + index: i3, + depth: d + }); + }; + var changeDepth = function changeDepth2(ele2, newDepth) { + var _getInfo = getInfo(ele2), depth = _getInfo.depth, index = _getInfo.index; + depths[depth][index] = null; + addToDepth(ele2, newDepth); + }; + graph.bfs({ + roots, + directed: options.directed, + visit: function visit(node, edge, pNode, i3, depth) { + var ele2 = node[0]; + var id2 = ele2.id(); + addToDepth(ele2, depth); + foundByBfs[id2] = true; + } + }); + var orphanNodes = []; + for (var _i2 = 0; _i2 < nodes2.length; _i2++) { + var _ele = nodes2[_i2]; + if (foundByBfs[_ele.id()]) { + continue; + } else { + orphanNodes.push(_ele); + } + } + var assignDepthsAt = function assignDepthsAt2(i3) { + var eles2 = depths[i3]; + for (var j = 0; j < eles2.length; j++) { + var _ele2 = eles2[j]; + if (_ele2 == null) { + eles2.splice(j, 1); + j--; + continue; + } + setInfo(_ele2, { + depth: i3, + index: j + }); + } + }; + var assignDepths = function assignDepths2() { + for (var _i3 = 0; _i3 < depths.length; _i3++) { + assignDepthsAt(_i3); + } + }; + var adjustMaximally = function adjustMaximally2(ele2, shifted2) { + var eInfo = getInfo(ele2); + var incomers = ele2.incomers().filter(function(el) { + return el.isNode() && eles.has(el); + }); + var maxDepth = -1; + var id2 = ele2.id(); + for (var k = 0; k < incomers.length; k++) { + var incmr = incomers[k]; + var iInfo = getInfo(incmr); + maxDepth = Math.max(maxDepth, iInfo.depth); + } + if (eInfo.depth <= maxDepth) { + if (!options.acyclic && shifted2[id2]) { + return null; + } + var newDepth = maxDepth + 1; + changeDepth(ele2, newDepth); + shifted2[id2] = newDepth; + return true; + } + return false; + }; + if (directed && maximal) { + var Q = []; + var shifted = {}; + var enqueue = function enqueue2(n2) { + return Q.push(n2); + }; + var dequeue = function dequeue2() { + return Q.shift(); + }; + nodes2.forEach(function(n2) { + return Q.push(n2); + }); + while (Q.length > 0) { + var _ele3 = dequeue(); + var didShift = adjustMaximally(_ele3, shifted); + if (didShift) { + _ele3.outgoers().filter(function(el) { + return el.isNode() && eles.has(el); + }).forEach(enqueue); + } else if (didShift === null) { + warn("Detected double maximal shift for node `" + _ele3.id() + "`. Bailing maximal adjustment due to cycle. Use `options.maximal: true` only on DAGs."); + break; + } + } + } + assignDepths(); + var minDistance = 0; + if (options.avoidOverlap) { + for (var _i4 = 0; _i4 < nodes2.length; _i4++) { + var n = nodes2[_i4]; + var nbb = n.layoutDimensions(options); + var w = nbb.w; + var h = nbb.h; + minDistance = Math.max(minDistance, w, h); + } + } + var cachedWeightedPercent = {}; + var getWeightedPercent = function getWeightedPercent2(ele2) { + if (cachedWeightedPercent[ele2.id()]) { + return cachedWeightedPercent[ele2.id()]; + } + var eleDepth = getInfo(ele2).depth; + var neighbors = ele2.neighborhood(); + var percent = 0; + var samples = 0; + for (var _i5 = 0; _i5 < neighbors.length; _i5++) { + var neighbor = neighbors[_i5]; + if (neighbor.isEdge() || neighbor.isParent() || !nodes2.has(neighbor)) { + continue; + } + var bf = getInfo(neighbor); + if (bf == null) { + continue; + } + var index = bf.index; + var depth = bf.depth; + if (index == null || depth == null) { + continue; + } + var nDepth = depths[depth].length; + if (depth < eleDepth) { + percent += index / nDepth; + samples++; + } + } + samples = Math.max(1, samples); + percent = percent / samples; + if (samples === 0) { + percent = 0; + } + cachedWeightedPercent[ele2.id()] = percent; + return percent; + }; + var sortFn = function sortFn2(a, b) { + var apct = getWeightedPercent(a); + var bpct = getWeightedPercent(b); + var diff = apct - bpct; + if (diff === 0) { + return ascending(a.id(), b.id()); + } else { + return diff; + } + }; + if (options.depthSort !== void 0) { + sortFn = options.depthSort; + } + for (var _i6 = 0; _i6 < depths.length; _i6++) { + depths[_i6].sort(sortFn); + assignDepthsAt(_i6); + } + var orphanDepth = []; + for (var _i7 = 0; _i7 < orphanNodes.length; _i7++) { + orphanDepth.push(orphanNodes[_i7]); + } + depths.unshift(orphanDepth); + assignDepths(); + var biggestDepthSize = 0; + for (var _i8 = 0; _i8 < depths.length; _i8++) { + biggestDepthSize = Math.max(depths[_i8].length, biggestDepthSize); + } + var center = { + x: bb.x1 + bb.w / 2, + y: bb.x1 + bb.h / 2 + }; + var maxDepthSize = depths.reduce(function(max2, eles2) { + return Math.max(max2, eles2.length); + }, 0); + var getPosition = function getPosition2(ele2) { + var _getInfo2 = getInfo(ele2), depth = _getInfo2.depth, index = _getInfo2.index; + var depthSize = depths[depth].length; + var distanceX = Math.max(bb.w / ((options.grid ? maxDepthSize : depthSize) + 1), minDistance); + var distanceY = Math.max(bb.h / (depths.length + 1), minDistance); + var radiusStepSize = Math.min(bb.w / 2 / depths.length, bb.h / 2 / depths.length); + radiusStepSize = Math.max(radiusStepSize, minDistance); + if (!options.circle) { + var epos = { + x: center.x + (index + 1 - (depthSize + 1) / 2) * distanceX, + y: (depth + 1) * distanceY + }; + return epos; + } else { + var radius = radiusStepSize * depth + radiusStepSize - (depths.length > 0 && depths[0].length <= 3 ? radiusStepSize / 2 : 0); + var theta = 2 * Math.PI / depths[depth].length * index; + if (depth === 0 && depths[0].length === 1) { + radius = 1; + } + return { + x: center.x + radius * Math.cos(theta), + y: center.y + radius * Math.sin(theta) + }; + } + }; + eles.nodes().layoutPositions(this, options, getPosition); + return this; + }; + var defaults$6 = { + fit: true, + // whether to fit the viewport to the graph + padding: 30, + // the padding on fit + boundingBox: void 0, + // constrain layout bounds; { x1, y1, x2, y2 } or { x1, y1, w, h } + avoidOverlap: true, + // prevents node overlap, may overflow boundingBox and radius if not enough space + nodeDimensionsIncludeLabels: false, + // Excludes the label when calculating node bounding boxes for the layout algorithm + spacingFactor: void 0, + // Applies a multiplicative factor (>0) to expand or compress the overall area that the nodes take up + radius: void 0, + // the radius of the circle + startAngle: 3 / 2 * Math.PI, + // where nodes start in radians + sweep: void 0, + // how many radians should be between the first and last node (defaults to full circle) + clockwise: true, + // whether the layout should go clockwise (true) or counterclockwise/anticlockwise (false) + sort: void 0, + // a sorting function to order the nodes; e.g. function(a, b){ return a.data('weight') - b.data('weight') } + animate: false, + // whether to transition the node positions + animationDuration: 500, + // duration of animation in ms if enabled + animationEasing: void 0, + // easing of animation if enabled + animateFilter: function animateFilter(node, i2) { + return true; + }, + // a function that determines whether the node should be animated. All nodes animated by default on animate enabled. Non-animated nodes are positioned immediately when the layout starts + ready: void 0, + // callback on layoutready + stop: void 0, + // callback on layoutstop + transform: function transform(node, position2) { + return position2; + } + // transform a given node position. Useful for changing flow direction in discrete layouts + }; + function CircleLayout(options) { + this.options = extend({}, defaults$6, options); + } + CircleLayout.prototype.run = function() { + var params = this.options; + var options = params; + var cy = params.cy; + var eles = options.eles; + var clockwise = options.counterclockwise !== void 0 ? !options.counterclockwise : options.clockwise; + var nodes2 = eles.nodes().not(":parent"); + if (options.sort) { + nodes2 = nodes2.sort(options.sort); + } + var bb = makeBoundingBox(options.boundingBox ? options.boundingBox : { + x1: 0, + y1: 0, + w: cy.width(), + h: cy.height() + }); + var center = { + x: bb.x1 + bb.w / 2, + y: bb.y1 + bb.h / 2 + }; + var sweep = options.sweep === void 0 ? 2 * Math.PI - 2 * Math.PI / nodes2.length : options.sweep; + var dTheta = sweep / Math.max(1, nodes2.length - 1); + var r; + var minDistance = 0; + for (var i2 = 0; i2 < nodes2.length; i2++) { + var n = nodes2[i2]; + var nbb = n.layoutDimensions(options); + var w = nbb.w; + var h = nbb.h; + minDistance = Math.max(minDistance, w, h); + } + if (number$1(options.radius)) { + r = options.radius; + } else if (nodes2.length <= 1) { + r = 0; + } else { + r = Math.min(bb.h, bb.w) / 2 - minDistance; + } + if (nodes2.length > 1 && options.avoidOverlap) { + minDistance *= 1.75; + var dcos = Math.cos(dTheta) - Math.cos(0); + var dsin = Math.sin(dTheta) - Math.sin(0); + var rMin = Math.sqrt(minDistance * minDistance / (dcos * dcos + dsin * dsin)); + r = Math.max(rMin, r); + } + var getPos = function getPos2(ele, i3) { + var theta = options.startAngle + i3 * dTheta * (clockwise ? 1 : -1); + var rx = r * Math.cos(theta); + var ry = r * Math.sin(theta); + var pos = { + x: center.x + rx, + y: center.y + ry + }; + return pos; + }; + eles.nodes().layoutPositions(this, options, getPos); + return this; + }; + var defaults$5 = { + fit: true, + // whether to fit the viewport to the graph + padding: 30, + // the padding on fit + startAngle: 3 / 2 * Math.PI, + // where nodes start in radians + sweep: void 0, + // how many radians should be between the first and last node (defaults to full circle) + clockwise: true, + // whether the layout should go clockwise (true) or counterclockwise/anticlockwise (false) + equidistant: false, + // whether levels have an equal radial distance betwen them, may cause bounding box overflow + minNodeSpacing: 10, + // min spacing between outside of nodes (used for radius adjustment) + boundingBox: void 0, + // constrain layout bounds; { x1, y1, x2, y2 } or { x1, y1, w, h } + avoidOverlap: true, + // prevents node overlap, may overflow boundingBox if not enough space + nodeDimensionsIncludeLabels: false, + // Excludes the label when calculating node bounding boxes for the layout algorithm + height: void 0, + // height of layout area (overrides container height) + width: void 0, + // width of layout area (overrides container width) + spacingFactor: void 0, + // Applies a multiplicative factor (>0) to expand or compress the overall area that the nodes take up + concentric: function concentric(node) { + return node.degree(); + }, + levelWidth: function levelWidth(nodes2) { + return nodes2.maxDegree() / 4; + }, + animate: false, + // whether to transition the node positions + animationDuration: 500, + // duration of animation in ms if enabled + animationEasing: void 0, + // easing of animation if enabled + animateFilter: function animateFilter(node, i2) { + return true; + }, + // a function that determines whether the node should be animated. All nodes animated by default on animate enabled. Non-animated nodes are positioned immediately when the layout starts + ready: void 0, + // callback on layoutready + stop: void 0, + // callback on layoutstop + transform: function transform(node, position2) { + return position2; + } + // transform a given node position. Useful for changing flow direction in discrete layouts + }; + function ConcentricLayout(options) { + this.options = extend({}, defaults$5, options); + } + ConcentricLayout.prototype.run = function() { + var params = this.options; + var options = params; + var clockwise = options.counterclockwise !== void 0 ? !options.counterclockwise : options.clockwise; + var cy = params.cy; + var eles = options.eles; + var nodes2 = eles.nodes().not(":parent"); + var bb = makeBoundingBox(options.boundingBox ? options.boundingBox : { + x1: 0, + y1: 0, + w: cy.width(), + h: cy.height() + }); + var center = { + x: bb.x1 + bb.w / 2, + y: bb.y1 + bb.h / 2 + }; + var nodeValues = []; + var maxNodeSize = 0; + for (var i2 = 0; i2 < nodes2.length; i2++) { + var node = nodes2[i2]; + var value = void 0; + value = options.concentric(node); + nodeValues.push({ + value, + node + }); + node._private.scratch.concentric = value; + } + nodes2.updateStyle(); + for (var _i = 0; _i < nodes2.length; _i++) { + var _node = nodes2[_i]; + var nbb = _node.layoutDimensions(options); + maxNodeSize = Math.max(maxNodeSize, nbb.w, nbb.h); + } + nodeValues.sort(function(a, b) { + return b.value - a.value; + }); + var levelWidth = options.levelWidth(nodes2); + var levels = [[]]; + var currentLevel = levels[0]; + for (var _i2 = 0; _i2 < nodeValues.length; _i2++) { + var val = nodeValues[_i2]; + if (currentLevel.length > 0) { + var diff = Math.abs(currentLevel[0].value - val.value); + if (diff >= levelWidth) { + currentLevel = []; + levels.push(currentLevel); + } + } + currentLevel.push(val); + } + var minDist = maxNodeSize + options.minNodeSpacing; + if (!options.avoidOverlap) { + var firstLvlHasMulti = levels.length > 0 && levels[0].length > 1; + var maxR = Math.min(bb.w, bb.h) / 2 - minDist; + var rStep = maxR / (levels.length + firstLvlHasMulti ? 1 : 0); + minDist = Math.min(minDist, rStep); + } + var r = 0; + for (var _i3 = 0; _i3 < levels.length; _i3++) { + var level = levels[_i3]; + var sweep = options.sweep === void 0 ? 2 * Math.PI - 2 * Math.PI / level.length : options.sweep; + var dTheta = level.dTheta = sweep / Math.max(1, level.length - 1); + if (level.length > 1 && options.avoidOverlap) { + var dcos = Math.cos(dTheta) - Math.cos(0); + var dsin = Math.sin(dTheta) - Math.sin(0); + var rMin = Math.sqrt(minDist * minDist / (dcos * dcos + dsin * dsin)); + r = Math.max(rMin, r); + } + level.r = r; + r += minDist; + } + if (options.equidistant) { + var rDeltaMax = 0; + var _r = 0; + for (var _i4 = 0; _i4 < levels.length; _i4++) { + var _level = levels[_i4]; + var rDelta = _level.r - _r; + rDeltaMax = Math.max(rDeltaMax, rDelta); + } + _r = 0; + for (var _i5 = 0; _i5 < levels.length; _i5++) { + var _level2 = levels[_i5]; + if (_i5 === 0) { + _r = _level2.r; + } + _level2.r = _r; + _r += rDeltaMax; + } + } + var pos = {}; + for (var _i6 = 0; _i6 < levels.length; _i6++) { + var _level3 = levels[_i6]; + var _dTheta = _level3.dTheta; + var _r2 = _level3.r; + for (var j = 0; j < _level3.length; j++) { + var _val = _level3[j]; + var theta = options.startAngle + (clockwise ? 1 : -1) * _dTheta * j; + var p2 = { + x: center.x + _r2 * Math.cos(theta), + y: center.y + _r2 * Math.sin(theta) + }; + pos[_val.node.id()] = p2; + } + } + eles.nodes().layoutPositions(this, options, function(ele) { + var id = ele.id(); + return pos[id]; + }); + return this; + }; + var DEBUG; + var defaults$4 = { + // Called on `layoutready` + ready: function ready() { + }, + // Called on `layoutstop` + stop: function stop() { + }, + // Whether to animate while running the layout + // true : Animate continuously as the layout is running + // false : Just show the end result + // 'end' : Animate with the end result, from the initial positions to the end positions + animate: true, + // Easing of the animation for animate:'end' + animationEasing: void 0, + // The duration of the animation for animate:'end' + animationDuration: void 0, + // A function that determines whether the node should be animated + // All nodes animated by default on animate enabled + // Non-animated nodes are positioned immediately when the layout starts + animateFilter: function animateFilter(node, i2) { + return true; + }, + // The layout animates only after this many milliseconds for animate:true + // (prevents flashing on fast runs) + animationThreshold: 250, + // Number of iterations between consecutive screen positions update + refresh: 20, + // Whether to fit the network view after when done + fit: true, + // Padding on fit + padding: 30, + // Constrain layout bounds; { x1, y1, x2, y2 } or { x1, y1, w, h } + boundingBox: void 0, + // Excludes the label when calculating node bounding boxes for the layout algorithm + nodeDimensionsIncludeLabels: false, + // Randomize the initial positions of the nodes (true) or use existing positions (false) + randomize: false, + // Extra spacing between components in non-compound graphs + componentSpacing: 40, + // Node repulsion (non overlapping) multiplier + nodeRepulsion: function nodeRepulsion2(node) { + return 2048; + }, + // Node repulsion (overlapping) multiplier + nodeOverlap: 4, + // Ideal edge (non nested) length + idealEdgeLength: function idealEdgeLength(edge) { + return 32; + }, + // Divisor to compute edge forces + edgeElasticity: function edgeElasticity(edge) { + return 32; + }, + // Nesting factor (multiplier) to compute ideal edge length for nested edges + nestingFactor: 1.2, + // Gravity force (constant) + gravity: 1, + // Maximum number of iterations to perform + numIter: 1e3, + // Initial temperature (maximum node displacement) + initialTemp: 1e3, + // Cooling factor (how the temperature is reduced between consecutive iterations + coolingFactor: 0.99, + // Lower temperature threshold (below this point the layout will end) + minTemp: 1 + }; + function CoseLayout(options) { + this.options = extend({}, defaults$4, options); + this.options.layout = this; + var nodes2 = this.options.eles.nodes(); + var edges = this.options.eles.edges(); + var notEdges = edges.filter(function(e) { + var sourceId = e.source().data("id"); + var targetId = e.target().data("id"); + var hasSource = nodes2.some(function(n) { + return n.data("id") === sourceId; + }); + var hasTarget = nodes2.some(function(n) { + return n.data("id") === targetId; + }); + return !hasSource || !hasTarget; + }); + this.options.eles = this.options.eles.not(notEdges); + } + CoseLayout.prototype.run = function() { + var options = this.options; + var cy = options.cy; + var layout2 = this; + layout2.stopped = false; + if (options.animate === true || options.animate === false) { + layout2.emit({ + type: "layoutstart", + layout: layout2 + }); + } + if (true === options.debug) { + DEBUG = true; + } else { + DEBUG = false; + } + var layoutInfo = createLayoutInfo(cy, layout2, options); + if (DEBUG) { + printLayoutInfo(layoutInfo); + } + if (options.randomize) { + randomizePositions(layoutInfo); + } + var startTime = performanceNow(); + var refresh = function refresh2() { + refreshPositions(layoutInfo, cy, options); + if (true === options.fit) { + cy.fit(options.padding); + } + }; + var mainLoop = function mainLoop2(i3) { + if (layout2.stopped || i3 >= options.numIter) { + return false; + } + step(layoutInfo, options); + layoutInfo.temperature = layoutInfo.temperature * options.coolingFactor; + if (layoutInfo.temperature < options.minTemp) { + return false; + } + return true; + }; + var done = function done2() { + if (options.animate === true || options.animate === false) { + refresh(); + layout2.one("layoutstop", options.stop); + layout2.emit({ + type: "layoutstop", + layout: layout2 + }); + } else { + var nodes2 = options.eles.nodes(); + var getScaledPos = getScaleInBoundsFn(layoutInfo, options, nodes2); + nodes2.layoutPositions(layout2, options, getScaledPos); + } + }; + var i2 = 0; + var loopRet = true; + if (options.animate === true) { + var frame = function frame2() { + var f = 0; + while (loopRet && f < options.refresh) { + loopRet = mainLoop(i2); + i2++; + f++; + } + if (!loopRet) { + separateComponents(layoutInfo, options); + done(); + } else { + var now2 = performanceNow(); + if (now2 - startTime >= options.animationThreshold) { + refresh(); + } + requestAnimationFrame2(frame2); + } + }; + frame(); + } else { + while (loopRet) { + loopRet = mainLoop(i2); + i2++; + } + separateComponents(layoutInfo, options); + done(); + } + return this; + }; + CoseLayout.prototype.stop = function() { + this.stopped = true; + if (this.thread) { + this.thread.stop(); + } + this.emit("layoutstop"); + return this; + }; + CoseLayout.prototype.destroy = function() { + if (this.thread) { + this.thread.stop(); + } + return this; + }; + var createLayoutInfo = function createLayoutInfo2(cy, layout2, options) { + var edges = options.eles.edges(); + var nodes2 = options.eles.nodes(); + var bb = makeBoundingBox(options.boundingBox ? options.boundingBox : { + x1: 0, + y1: 0, + w: cy.width(), + h: cy.height() + }); + var layoutInfo = { + isCompound: cy.hasCompoundNodes(), + layoutNodes: [], + idToIndex: {}, + nodeSize: nodes2.size(), + graphSet: [], + indexToGraph: [], + layoutEdges: [], + edgeSize: edges.size(), + temperature: options.initialTemp, + clientWidth: bb.w, + clientHeight: bb.h, + boundingBox: bb + }; + var components = options.eles.components(); + var id2cmptId = {}; + for (var i2 = 0; i2 < components.length; i2++) { + var component = components[i2]; + for (var j = 0; j < component.length; j++) { + var node = component[j]; + id2cmptId[node.id()] = i2; + } + } + for (var i2 = 0; i2 < layoutInfo.nodeSize; i2++) { + var n = nodes2[i2]; + var nbb = n.layoutDimensions(options); + var tempNode = {}; + tempNode.isLocked = n.locked(); + tempNode.id = n.data("id"); + tempNode.parentId = n.data("parent"); + tempNode.cmptId = id2cmptId[n.id()]; + tempNode.children = []; + tempNode.positionX = n.position("x"); + tempNode.positionY = n.position("y"); + tempNode.offsetX = 0; + tempNode.offsetY = 0; + tempNode.height = nbb.w; + tempNode.width = nbb.h; + tempNode.maxX = tempNode.positionX + tempNode.width / 2; + tempNode.minX = tempNode.positionX - tempNode.width / 2; + tempNode.maxY = tempNode.positionY + tempNode.height / 2; + tempNode.minY = tempNode.positionY - tempNode.height / 2; + tempNode.padLeft = parseFloat(n.style("padding")); + tempNode.padRight = parseFloat(n.style("padding")); + tempNode.padTop = parseFloat(n.style("padding")); + tempNode.padBottom = parseFloat(n.style("padding")); + tempNode.nodeRepulsion = fn$6(options.nodeRepulsion) ? options.nodeRepulsion(n) : options.nodeRepulsion; + layoutInfo.layoutNodes.push(tempNode); + layoutInfo.idToIndex[tempNode.id] = i2; + } + var queue = []; + var start = 0; + var end = -1; + var tempGraph = []; + for (var i2 = 0; i2 < layoutInfo.nodeSize; i2++) { + var n = layoutInfo.layoutNodes[i2]; + var p_id = n.parentId; + if (null != p_id) { + layoutInfo.layoutNodes[layoutInfo.idToIndex[p_id]].children.push(n.id); + } else { + queue[++end] = n.id; + tempGraph.push(n.id); + } + } + layoutInfo.graphSet.push(tempGraph); + while (start <= end) { + var node_id = queue[start++]; + var node_ix = layoutInfo.idToIndex[node_id]; + var node = layoutInfo.layoutNodes[node_ix]; + var children = node.children; + if (children.length > 0) { + layoutInfo.graphSet.push(children); + for (var i2 = 0; i2 < children.length; i2++) { + queue[++end] = children[i2]; + } + } + } + for (var i2 = 0; i2 < layoutInfo.graphSet.length; i2++) { + var graph = layoutInfo.graphSet[i2]; + for (var j = 0; j < graph.length; j++) { + var index = layoutInfo.idToIndex[graph[j]]; + layoutInfo.indexToGraph[index] = i2; + } + } + for (var i2 = 0; i2 < layoutInfo.edgeSize; i2++) { + var e = edges[i2]; + var tempEdge = {}; + tempEdge.id = e.data("id"); + tempEdge.sourceId = e.data("source"); + tempEdge.targetId = e.data("target"); + var idealLength = fn$6(options.idealEdgeLength) ? options.idealEdgeLength(e) : options.idealEdgeLength; + var elasticity = fn$6(options.edgeElasticity) ? options.edgeElasticity(e) : options.edgeElasticity; + var sourceIx = layoutInfo.idToIndex[tempEdge.sourceId]; + var targetIx = layoutInfo.idToIndex[tempEdge.targetId]; + var sourceGraph = layoutInfo.indexToGraph[sourceIx]; + var targetGraph = layoutInfo.indexToGraph[targetIx]; + if (sourceGraph != targetGraph) { + var lca = findLCA(tempEdge.sourceId, tempEdge.targetId, layoutInfo); + var lcaGraph = layoutInfo.graphSet[lca]; + var depth = 0; + var tempNode = layoutInfo.layoutNodes[sourceIx]; + while (-1 === lcaGraph.indexOf(tempNode.id)) { + tempNode = layoutInfo.layoutNodes[layoutInfo.idToIndex[tempNode.parentId]]; + depth++; + } + tempNode = layoutInfo.layoutNodes[targetIx]; + while (-1 === lcaGraph.indexOf(tempNode.id)) { + tempNode = layoutInfo.layoutNodes[layoutInfo.idToIndex[tempNode.parentId]]; + depth++; + } + idealLength *= depth * options.nestingFactor; + } + tempEdge.idealLength = idealLength; + tempEdge.elasticity = elasticity; + layoutInfo.layoutEdges.push(tempEdge); + } + return layoutInfo; + }; + var findLCA = function findLCA2(node1, node2, layoutInfo) { + var res = findLCA_aux(node1, node2, 0, layoutInfo); + if (2 > res.count) { + return 0; + } else { + return res.graph; + } + }; + var findLCA_aux = function findLCA_aux2(node1, node2, graphIx, layoutInfo) { + var graph = layoutInfo.graphSet[graphIx]; + if (-1 < graph.indexOf(node1) && -1 < graph.indexOf(node2)) { + return { + count: 2, + graph: graphIx + }; + } + var c = 0; + for (var i2 = 0; i2 < graph.length; i2++) { + var nodeId = graph[i2]; + var nodeIx = layoutInfo.idToIndex[nodeId]; + var children = layoutInfo.layoutNodes[nodeIx].children; + if (0 === children.length) { + continue; + } + var childGraphIx = layoutInfo.indexToGraph[layoutInfo.idToIndex[children[0]]]; + var result = findLCA_aux2(node1, node2, childGraphIx, layoutInfo); + if (0 === result.count) { + continue; + } else if (1 === result.count) { + c++; + if (2 === c) { + break; + } + } else { + return result; + } + } + return { + count: c, + graph: graphIx + }; + }; + var printLayoutInfo; + var randomizePositions = function randomizePositions2(layoutInfo, cy) { + var width = layoutInfo.clientWidth; + var height = layoutInfo.clientHeight; + for (var i2 = 0; i2 < layoutInfo.nodeSize; i2++) { + var n = layoutInfo.layoutNodes[i2]; + if (0 === n.children.length && !n.isLocked) { + n.positionX = Math.random() * width; + n.positionY = Math.random() * height; + } + } + }; + var getScaleInBoundsFn = function getScaleInBoundsFn2(layoutInfo, options, nodes2) { + var bb = layoutInfo.boundingBox; + var coseBB = { + x1: Infinity, + x2: -Infinity, + y1: Infinity, + y2: -Infinity + }; + if (options.boundingBox) { + nodes2.forEach(function(node) { + var lnode = layoutInfo.layoutNodes[layoutInfo.idToIndex[node.data("id")]]; + coseBB.x1 = Math.min(coseBB.x1, lnode.positionX); + coseBB.x2 = Math.max(coseBB.x2, lnode.positionX); + coseBB.y1 = Math.min(coseBB.y1, lnode.positionY); + coseBB.y2 = Math.max(coseBB.y2, lnode.positionY); + }); + coseBB.w = coseBB.x2 - coseBB.x1; + coseBB.h = coseBB.y2 - coseBB.y1; + } + return function(ele, i2) { + var lnode = layoutInfo.layoutNodes[layoutInfo.idToIndex[ele.data("id")]]; + if (options.boundingBox) { + var pctX = (lnode.positionX - coseBB.x1) / coseBB.w; + var pctY = (lnode.positionY - coseBB.y1) / coseBB.h; + return { + x: bb.x1 + pctX * bb.w, + y: bb.y1 + pctY * bb.h + }; + } else { + return { + x: lnode.positionX, + y: lnode.positionY + }; + } + }; + }; + var refreshPositions = function refreshPositions2(layoutInfo, cy, options) { + var layout2 = options.layout; + var nodes2 = options.eles.nodes(); + var getScaledPos = getScaleInBoundsFn(layoutInfo, options, nodes2); + nodes2.positions(getScaledPos); + if (true !== layoutInfo.ready) { + layoutInfo.ready = true; + layout2.one("layoutready", options.ready); + layout2.emit({ + type: "layoutready", + layout: this + }); + } + }; + var step = function step2(layoutInfo, options, _step) { + calculateNodeForces(layoutInfo, options); + calculateEdgeForces(layoutInfo); + calculateGravityForces(layoutInfo, options); + propagateForces(layoutInfo); + updatePositions(layoutInfo); + }; + var calculateNodeForces = function calculateNodeForces2(layoutInfo, options) { + for (var i2 = 0; i2 < layoutInfo.graphSet.length; i2++) { + var graph = layoutInfo.graphSet[i2]; + var numNodes = graph.length; + for (var j = 0; j < numNodes; j++) { + var node1 = layoutInfo.layoutNodes[layoutInfo.idToIndex[graph[j]]]; + for (var k = j + 1; k < numNodes; k++) { + var node2 = layoutInfo.layoutNodes[layoutInfo.idToIndex[graph[k]]]; + nodeRepulsion(node1, node2, layoutInfo, options); + } + } + } + }; + var randomDistance = function randomDistance2(max2) { + return -max2 + 2 * max2 * Math.random(); + }; + var nodeRepulsion = function nodeRepulsion2(node1, node2, layoutInfo, options) { + var cmptId1 = node1.cmptId; + var cmptId2 = node2.cmptId; + if (cmptId1 !== cmptId2 && !layoutInfo.isCompound) { + return; + } + var directionX = node2.positionX - node1.positionX; + var directionY = node2.positionY - node1.positionY; + var maxRandDist = 1; + if (0 === directionX && 0 === directionY) { + directionX = randomDistance(maxRandDist); + directionY = randomDistance(maxRandDist); + } + var overlap = nodesOverlap(node1, node2, directionX, directionY); + if (overlap > 0) { + var force = options.nodeOverlap * overlap; + var distance = Math.sqrt(directionX * directionX + directionY * directionY); + var forceX = force * directionX / distance; + var forceY = force * directionY / distance; + } else { + var point1 = findClippingPoint(node1, directionX, directionY); + var point2 = findClippingPoint(node2, -1 * directionX, -1 * directionY); + var distanceX = point2.x - point1.x; + var distanceY = point2.y - point1.y; + var distanceSqr = distanceX * distanceX + distanceY * distanceY; + var distance = Math.sqrt(distanceSqr); + var force = (node1.nodeRepulsion + node2.nodeRepulsion) / distanceSqr; + var forceX = force * distanceX / distance; + var forceY = force * distanceY / distance; + } + if (!node1.isLocked) { + node1.offsetX -= forceX; + node1.offsetY -= forceY; + } + if (!node2.isLocked) { + node2.offsetX += forceX; + node2.offsetY += forceY; + } + return; + }; + var nodesOverlap = function nodesOverlap2(node1, node2, dX, dY) { + if (dX > 0) { + var overlapX = node1.maxX - node2.minX; + } else { + var overlapX = node2.maxX - node1.minX; + } + if (dY > 0) { + var overlapY = node1.maxY - node2.minY; + } else { + var overlapY = node2.maxY - node1.minY; + } + if (overlapX >= 0 && overlapY >= 0) { + return Math.sqrt(overlapX * overlapX + overlapY * overlapY); + } else { + return 0; + } + }; + var findClippingPoint = function findClippingPoint2(node, dX, dY) { + var X = node.positionX; + var Y = node.positionY; + var H = node.height || 1; + var W = node.width || 1; + var dirSlope = dY / dX; + var nodeSlope = H / W; + var res = {}; + if (0 === dX && 0 < dY) { + res.x = X; + res.y = Y + H / 2; + return res; + } + if (0 === dX && 0 > dY) { + res.x = X; + res.y = Y + H / 2; + return res; + } + if (0 < dX && -1 * nodeSlope <= dirSlope && dirSlope <= nodeSlope) { + res.x = X + W / 2; + res.y = Y + W * dY / 2 / dX; + return res; + } + if (0 > dX && -1 * nodeSlope <= dirSlope && dirSlope <= nodeSlope) { + res.x = X - W / 2; + res.y = Y - W * dY / 2 / dX; + return res; + } + if (0 < dY && (dirSlope <= -1 * nodeSlope || dirSlope >= nodeSlope)) { + res.x = X + H * dX / 2 / dY; + res.y = Y + H / 2; + return res; + } + if (0 > dY && (dirSlope <= -1 * nodeSlope || dirSlope >= nodeSlope)) { + res.x = X - H * dX / 2 / dY; + res.y = Y - H / 2; + return res; + } + return res; + }; + var calculateEdgeForces = function calculateEdgeForces2(layoutInfo, options) { + for (var i2 = 0; i2 < layoutInfo.edgeSize; i2++) { + var edge = layoutInfo.layoutEdges[i2]; + var sourceIx = layoutInfo.idToIndex[edge.sourceId]; + var source = layoutInfo.layoutNodes[sourceIx]; + var targetIx = layoutInfo.idToIndex[edge.targetId]; + var target = layoutInfo.layoutNodes[targetIx]; + var directionX = target.positionX - source.positionX; + var directionY = target.positionY - source.positionY; + if (0 === directionX && 0 === directionY) { + continue; + } + var point1 = findClippingPoint(source, directionX, directionY); + var point2 = findClippingPoint(target, -1 * directionX, -1 * directionY); + var lx = point2.x - point1.x; + var ly = point2.y - point1.y; + var l = Math.sqrt(lx * lx + ly * ly); + var force = Math.pow(edge.idealLength - l, 2) / edge.elasticity; + if (0 !== l) { + var forceX = force * lx / l; + var forceY = force * ly / l; + } else { + var forceX = 0; + var forceY = 0; + } + if (!source.isLocked) { + source.offsetX += forceX; + source.offsetY += forceY; + } + if (!target.isLocked) { + target.offsetX -= forceX; + target.offsetY -= forceY; + } + } + }; + var calculateGravityForces = function calculateGravityForces2(layoutInfo, options) { + if (options.gravity === 0) { + return; + } + var distThreshold = 1; + for (var i2 = 0; i2 < layoutInfo.graphSet.length; i2++) { + var graph = layoutInfo.graphSet[i2]; + var numNodes = graph.length; + if (0 === i2) { + var centerX = layoutInfo.clientHeight / 2; + var centerY = layoutInfo.clientWidth / 2; + } else { + var temp = layoutInfo.layoutNodes[layoutInfo.idToIndex[graph[0]]]; + var parent = layoutInfo.layoutNodes[layoutInfo.idToIndex[temp.parentId]]; + var centerX = parent.positionX; + var centerY = parent.positionY; + } + for (var j = 0; j < numNodes; j++) { + var node = layoutInfo.layoutNodes[layoutInfo.idToIndex[graph[j]]]; + if (node.isLocked) { + continue; + } + var dx = centerX - node.positionX; + var dy = centerY - node.positionY; + var d = Math.sqrt(dx * dx + dy * dy); + if (d > distThreshold) { + var fx = options.gravity * dx / d; + var fy = options.gravity * dy / d; + node.offsetX += fx; + node.offsetY += fy; + } + } + } + }; + var propagateForces = function propagateForces2(layoutInfo, options) { + var queue = []; + var start = 0; + var end = -1; + queue.push.apply(queue, layoutInfo.graphSet[0]); + end += layoutInfo.graphSet[0].length; + while (start <= end) { + var nodeId = queue[start++]; + var nodeIndex = layoutInfo.idToIndex[nodeId]; + var node = layoutInfo.layoutNodes[nodeIndex]; + var children = node.children; + if (0 < children.length && !node.isLocked) { + var offX = node.offsetX; + var offY = node.offsetY; + for (var i2 = 0; i2 < children.length; i2++) { + var childNode = layoutInfo.layoutNodes[layoutInfo.idToIndex[children[i2]]]; + childNode.offsetX += offX; + childNode.offsetY += offY; + queue[++end] = children[i2]; + } + node.offsetX = 0; + node.offsetY = 0; + } + } + }; + var updatePositions = function updatePositions2(layoutInfo, options) { + for (var i2 = 0; i2 < layoutInfo.nodeSize; i2++) { + var n = layoutInfo.layoutNodes[i2]; + if (0 < n.children.length) { + n.maxX = void 0; + n.minX = void 0; + n.maxY = void 0; + n.minY = void 0; + } + } + for (var i2 = 0; i2 < layoutInfo.nodeSize; i2++) { + var n = layoutInfo.layoutNodes[i2]; + if (0 < n.children.length || n.isLocked) { + continue; + } + var tempForce = limitForce(n.offsetX, n.offsetY, layoutInfo.temperature); + n.positionX += tempForce.x; + n.positionY += tempForce.y; + n.offsetX = 0; + n.offsetY = 0; + n.minX = n.positionX - n.width; + n.maxX = n.positionX + n.width; + n.minY = n.positionY - n.height; + n.maxY = n.positionY + n.height; + updateAncestryBoundaries(n, layoutInfo); + } + for (var i2 = 0; i2 < layoutInfo.nodeSize; i2++) { + var n = layoutInfo.layoutNodes[i2]; + if (0 < n.children.length && !n.isLocked) { + n.positionX = (n.maxX + n.minX) / 2; + n.positionY = (n.maxY + n.minY) / 2; + n.width = n.maxX - n.minX; + n.height = n.maxY - n.minY; + } + } + }; + var limitForce = function limitForce2(forceX, forceY, max2) { + var force = Math.sqrt(forceX * forceX + forceY * forceY); + if (force > max2) { + var res = { + x: max2 * forceX / force, + y: max2 * forceY / force + }; + } else { + var res = { + x: forceX, + y: forceY + }; + } + return res; + }; + var updateAncestryBoundaries = function updateAncestryBoundaries2(node, layoutInfo) { + var parentId = node.parentId; + if (null == parentId) { + return; + } + var p2 = layoutInfo.layoutNodes[layoutInfo.idToIndex[parentId]]; + var flag = false; + if (null == p2.maxX || node.maxX + p2.padRight > p2.maxX) { + p2.maxX = node.maxX + p2.padRight; + flag = true; + } + if (null == p2.minX || node.minX - p2.padLeft < p2.minX) { + p2.minX = node.minX - p2.padLeft; + flag = true; + } + if (null == p2.maxY || node.maxY + p2.padBottom > p2.maxY) { + p2.maxY = node.maxY + p2.padBottom; + flag = true; + } + if (null == p2.minY || node.minY - p2.padTop < p2.minY) { + p2.minY = node.minY - p2.padTop; + flag = true; + } + if (flag) { + return updateAncestryBoundaries2(p2, layoutInfo); + } + return; + }; + var separateComponents = function separateComponents2(layoutInfo, options) { + var nodes2 = layoutInfo.layoutNodes; + var components = []; + for (var i2 = 0; i2 < nodes2.length; i2++) { + var node = nodes2[i2]; + var cid = node.cmptId; + var component = components[cid] = components[cid] || []; + component.push(node); + } + var totalA = 0; + for (var i2 = 0; i2 < components.length; i2++) { + var c = components[i2]; + if (!c) { + continue; + } + c.x1 = Infinity; + c.x2 = -Infinity; + c.y1 = Infinity; + c.y2 = -Infinity; + for (var j = 0; j < c.length; j++) { + var n = c[j]; + c.x1 = Math.min(c.x1, n.positionX - n.width / 2); + c.x2 = Math.max(c.x2, n.positionX + n.width / 2); + c.y1 = Math.min(c.y1, n.positionY - n.height / 2); + c.y2 = Math.max(c.y2, n.positionY + n.height / 2); + } + c.w = c.x2 - c.x1; + c.h = c.y2 - c.y1; + totalA += c.w * c.h; + } + components.sort(function(c1, c2) { + return c2.w * c2.h - c1.w * c1.h; + }); + var x = 0; + var y = 0; + var usedW = 0; + var rowH = 0; + var maxRowW = Math.sqrt(totalA) * layoutInfo.clientWidth / layoutInfo.clientHeight; + for (var i2 = 0; i2 < components.length; i2++) { + var c = components[i2]; + if (!c) { + continue; + } + for (var j = 0; j < c.length; j++) { + var n = c[j]; + if (!n.isLocked) { + n.positionX += x - c.x1; + n.positionY += y - c.y1; + } + } + x += c.w + options.componentSpacing; + usedW += c.w + options.componentSpacing; + rowH = Math.max(rowH, c.h); + if (usedW > maxRowW) { + y += rowH + options.componentSpacing; + x = 0; + usedW = 0; + rowH = 0; + } + } + }; + var defaults$3 = { + fit: true, + // whether to fit the viewport to the graph + padding: 30, + // padding used on fit + boundingBox: void 0, + // constrain layout bounds; { x1, y1, x2, y2 } or { x1, y1, w, h } + avoidOverlap: true, + // prevents node overlap, may overflow boundingBox if not enough space + avoidOverlapPadding: 10, + // extra spacing around nodes when avoidOverlap: true + nodeDimensionsIncludeLabels: false, + // Excludes the label when calculating node bounding boxes for the layout algorithm + spacingFactor: void 0, + // Applies a multiplicative factor (>0) to expand or compress the overall area that the nodes take up + condense: false, + // uses all available space on false, uses minimal space on true + rows: void 0, + // force num of rows in the grid + cols: void 0, + // force num of columns in the grid + position: function position2(node) { + }, + // returns { row, col } for element + sort: void 0, + // a sorting function to order the nodes; e.g. function(a, b){ return a.data('weight') - b.data('weight') } + animate: false, + // whether to transition the node positions + animationDuration: 500, + // duration of animation in ms if enabled + animationEasing: void 0, + // easing of animation if enabled + animateFilter: function animateFilter(node, i2) { + return true; + }, + // a function that determines whether the node should be animated. All nodes animated by default on animate enabled. Non-animated nodes are positioned immediately when the layout starts + ready: void 0, + // callback on layoutready + stop: void 0, + // callback on layoutstop + transform: function transform(node, position2) { + return position2; + } + // transform a given node position. Useful for changing flow direction in discrete layouts + }; + function GridLayout(options) { + this.options = extend({}, defaults$3, options); + } + GridLayout.prototype.run = function() { + var params = this.options; + var options = params; + var cy = params.cy; + var eles = options.eles; + var nodes2 = eles.nodes().not(":parent"); + if (options.sort) { + nodes2 = nodes2.sort(options.sort); + } + var bb = makeBoundingBox(options.boundingBox ? options.boundingBox : { + x1: 0, + y1: 0, + w: cy.width(), + h: cy.height() + }); + if (bb.h === 0 || bb.w === 0) { + eles.nodes().layoutPositions(this, options, function(ele) { + return { + x: bb.x1, + y: bb.y1 + }; + }); + } else { + var cells = nodes2.size(); + var splits = Math.sqrt(cells * bb.h / bb.w); + var rows = Math.round(splits); + var cols = Math.round(bb.w / bb.h * splits); + var small = function small2(val) { + if (val == null) { + return Math.min(rows, cols); + } else { + var min2 = Math.min(rows, cols); + if (min2 == rows) { + rows = val; + } else { + cols = val; + } + } + }; + var large = function large2(val) { + if (val == null) { + return Math.max(rows, cols); + } else { + var max2 = Math.max(rows, cols); + if (max2 == rows) { + rows = val; + } else { + cols = val; + } + } + }; + var oRows = options.rows; + var oCols = options.cols != null ? options.cols : options.columns; + if (oRows != null && oCols != null) { + rows = oRows; + cols = oCols; + } else if (oRows != null && oCols == null) { + rows = oRows; + cols = Math.ceil(cells / rows); + } else if (oRows == null && oCols != null) { + cols = oCols; + rows = Math.ceil(cells / cols); + } else if (cols * rows > cells) { + var sm = small(); + var lg = large(); + if ((sm - 1) * lg >= cells) { + small(sm - 1); + } else if ((lg - 1) * sm >= cells) { + large(lg - 1); + } + } else { + while (cols * rows < cells) { + var _sm = small(); + var _lg = large(); + if ((_lg + 1) * _sm >= cells) { + large(_lg + 1); + } else { + small(_sm + 1); + } + } + } + var cellWidth = bb.w / cols; + var cellHeight = bb.h / rows; + if (options.condense) { + cellWidth = 0; + cellHeight = 0; + } + if (options.avoidOverlap) { + for (var i2 = 0; i2 < nodes2.length; i2++) { + var node = nodes2[i2]; + var pos = node._private.position; + if (pos.x == null || pos.y == null) { + pos.x = 0; + pos.y = 0; + } + var nbb = node.layoutDimensions(options); + var p2 = options.avoidOverlapPadding; + var w = nbb.w + p2; + var h = nbb.h + p2; + cellWidth = Math.max(cellWidth, w); + cellHeight = Math.max(cellHeight, h); + } + } + var cellUsed = {}; + var used = function used2(row2, col2) { + return cellUsed["c-" + row2 + "-" + col2] ? true : false; + }; + var use = function use2(row2, col2) { + cellUsed["c-" + row2 + "-" + col2] = true; + }; + var row = 0; + var col = 0; + var moveToNextCell = function moveToNextCell2() { + col++; + if (col >= cols) { + col = 0; + row++; + } + }; + var id2manPos = {}; + for (var _i = 0; _i < nodes2.length; _i++) { + var _node = nodes2[_i]; + var rcPos = options.position(_node); + if (rcPos && (rcPos.row !== void 0 || rcPos.col !== void 0)) { + var _pos = { + row: rcPos.row, + col: rcPos.col + }; + if (_pos.col === void 0) { + _pos.col = 0; + while (used(_pos.row, _pos.col)) { + _pos.col++; + } + } else if (_pos.row === void 0) { + _pos.row = 0; + while (used(_pos.row, _pos.col)) { + _pos.row++; + } + } + id2manPos[_node.id()] = _pos; + use(_pos.row, _pos.col); + } + } + var getPos = function getPos2(element2, i3) { + var x, y; + if (element2.locked() || element2.isParent()) { + return false; + } + var rcPos2 = id2manPos[element2.id()]; + if (rcPos2) { + x = rcPos2.col * cellWidth + cellWidth / 2 + bb.x1; + y = rcPos2.row * cellHeight + cellHeight / 2 + bb.y1; + } else { + while (used(row, col)) { + moveToNextCell(); + } + x = col * cellWidth + cellWidth / 2 + bb.x1; + y = row * cellHeight + cellHeight / 2 + bb.y1; + use(row, col); + moveToNextCell(); + } + return { + x, + y + }; + }; + nodes2.layoutPositions(this, options, getPos); + } + return this; + }; + var defaults$2 = { + ready: function ready() { + }, + // on layoutready + stop: function stop() { + } + // on layoutstop + }; + function NullLayout(options) { + this.options = extend({}, defaults$2, options); + } + NullLayout.prototype.run = function() { + var options = this.options; + var eles = options.eles; + var layout2 = this; + options.cy; + layout2.emit("layoutstart"); + eles.nodes().positions(function() { + return { + x: 0, + y: 0 + }; + }); + layout2.one("layoutready", options.ready); + layout2.emit("layoutready"); + layout2.one("layoutstop", options.stop); + layout2.emit("layoutstop"); + return this; + }; + NullLayout.prototype.stop = function() { + return this; + }; + var defaults$1 = { + positions: void 0, + // map of (node id) => (position obj); or function(node){ return somPos; } + zoom: void 0, + // the zoom level to set (prob want fit = false if set) + pan: void 0, + // the pan level to set (prob want fit = false if set) + fit: true, + // whether to fit to viewport + padding: 30, + // padding on fit + spacingFactor: void 0, + // Applies a multiplicative factor (>0) to expand or compress the overall area that the nodes take up + animate: false, + // whether to transition the node positions + animationDuration: 500, + // duration of animation in ms if enabled + animationEasing: void 0, + // easing of animation if enabled + animateFilter: function animateFilter(node, i2) { + return true; + }, + // a function that determines whether the node should be animated. All nodes animated by default on animate enabled. Non-animated nodes are positioned immediately when the layout starts + ready: void 0, + // callback on layoutready + stop: void 0, + // callback on layoutstop + transform: function transform(node, position2) { + return position2; + } + // transform a given node position. Useful for changing flow direction in discrete layouts + }; + function PresetLayout(options) { + this.options = extend({}, defaults$1, options); + } + PresetLayout.prototype.run = function() { + var options = this.options; + var eles = options.eles; + var nodes2 = eles.nodes(); + var posIsFn = fn$6(options.positions); + function getPosition(node) { + if (options.positions == null) { + return copyPosition(node.position()); + } + if (posIsFn) { + return options.positions(node); + } + var pos = options.positions[node._private.data.id]; + if (pos == null) { + return null; + } + return pos; + } + nodes2.layoutPositions(this, options, function(node, i2) { + var position2 = getPosition(node); + if (node.locked() || position2 == null) { + return false; + } + return position2; + }); + return this; + }; + var defaults = { + fit: true, + // whether to fit to viewport + padding: 30, + // fit padding + boundingBox: void 0, + // constrain layout bounds; { x1, y1, x2, y2 } or { x1, y1, w, h } + animate: false, + // whether to transition the node positions + animationDuration: 500, + // duration of animation in ms if enabled + animationEasing: void 0, + // easing of animation if enabled + animateFilter: function animateFilter(node, i2) { + return true; + }, + // a function that determines whether the node should be animated. All nodes animated by default on animate enabled. Non-animated nodes are positioned immediately when the layout starts + ready: void 0, + // callback on layoutready + stop: void 0, + // callback on layoutstop + transform: function transform(node, position2) { + return position2; + } + // transform a given node position. Useful for changing flow direction in discrete layouts + }; + function RandomLayout(options) { + this.options = extend({}, defaults, options); + } + RandomLayout.prototype.run = function() { + var options = this.options; + var cy = options.cy; + var eles = options.eles; + var bb = makeBoundingBox(options.boundingBox ? options.boundingBox : { + x1: 0, + y1: 0, + w: cy.width(), + h: cy.height() + }); + var getPos = function getPos2(node, i2) { + return { + x: bb.x1 + Math.round(Math.random() * bb.w), + y: bb.y1 + Math.round(Math.random() * bb.h) + }; + }; + eles.nodes().layoutPositions(this, options, getPos); + return this; + }; + var layout = [{ + name: "breadthfirst", + impl: BreadthFirstLayout + }, { + name: "circle", + impl: CircleLayout + }, { + name: "concentric", + impl: ConcentricLayout + }, { + name: "cose", + impl: CoseLayout + }, { + name: "grid", + impl: GridLayout + }, { + name: "null", + impl: NullLayout + }, { + name: "preset", + impl: PresetLayout + }, { + name: "random", + impl: RandomLayout + }]; + function NullRenderer(options) { + this.options = options; + this.notifications = 0; + } + var noop = function noop2() { + }; + var throwImgErr = function throwImgErr2() { + throw new Error("A headless instance can not render images"); + }; + NullRenderer.prototype = { + recalculateRenderedStyle: noop, + notify: function notify() { + this.notifications++; + }, + init: noop, + isHeadless: function isHeadless() { + return true; + }, + png: throwImgErr, + jpg: throwImgErr + }; + var BRp$f = {}; + BRp$f.arrowShapeWidth = 0.3; + BRp$f.registerArrowShapes = function() { + var arrowShapes = this.arrowShapes = {}; + var renderer3 = this; + var bbCollide = function bbCollide2(x, y, size, angle, translation, edgeWidth, padding) { + var x1 = translation.x - size / 2 - padding; + var x2 = translation.x + size / 2 + padding; + var y1 = translation.y - size / 2 - padding; + var y2 = translation.y + size / 2 + padding; + var inside = x1 <= x && x <= x2 && y1 <= y && y <= y2; + return inside; + }; + var transform = function transform2(x, y, size, angle, translation) { + var xRotated = x * Math.cos(angle) - y * Math.sin(angle); + var yRotated = x * Math.sin(angle) + y * Math.cos(angle); + var xScaled = xRotated * size; + var yScaled = yRotated * size; + var xTranslated = xScaled + translation.x; + var yTranslated = yScaled + translation.y; + return { + x: xTranslated, + y: yTranslated + }; + }; + var transformPoints = function transformPoints2(pts2, size, angle, translation) { + var retPts = []; + for (var i2 = 0; i2 < pts2.length; i2 += 2) { + var x = pts2[i2]; + var y = pts2[i2 + 1]; + retPts.push(transform(x, y, size, angle, translation)); + } + return retPts; + }; + var pointsToArr = function pointsToArr2(pts2) { + var ret = []; + for (var i2 = 0; i2 < pts2.length; i2++) { + var p2 = pts2[i2]; + ret.push(p2.x, p2.y); + } + return ret; + }; + var standardGap = function standardGap2(edge) { + return edge.pstyle("width").pfValue * edge.pstyle("arrow-scale").pfValue * 2; + }; + var defineArrowShape = function defineArrowShape2(name, defn) { + if (string(defn)) { + defn = arrowShapes[defn]; + } + arrowShapes[name] = extend({ + name, + points: [-0.15, -0.3, 0.15, -0.3, 0.15, 0.3, -0.15, 0.3], + collide: function collide(x, y, size, angle, translation, padding) { + var points = pointsToArr(transformPoints(this.points, size + 2 * padding, angle, translation)); + var inside = pointInsidePolygonPoints(x, y, points); + return inside; + }, + roughCollide: bbCollide, + draw: function draw2(context, size, angle, translation) { + var points = transformPoints(this.points, size, angle, translation); + renderer3.arrowShapeImpl("polygon")(context, points); + }, + spacing: function spacing(edge) { + return 0; + }, + gap: standardGap + }, defn); + }; + defineArrowShape("none", { + collide: falsify, + roughCollide: falsify, + draw: noop$1, + spacing: zeroify, + gap: zeroify + }); + defineArrowShape("triangle", { + points: [-0.15, -0.3, 0, 0, 0.15, -0.3] + }); + defineArrowShape("arrow", "triangle"); + defineArrowShape("triangle-backcurve", { + points: arrowShapes["triangle"].points, + controlPoint: [0, -0.15], + roughCollide: bbCollide, + draw: function draw2(context, size, angle, translation, edgeWidth) { + var ptsTrans = transformPoints(this.points, size, angle, translation); + var ctrlPt = this.controlPoint; + var ctrlPtTrans = transform(ctrlPt[0], ctrlPt[1], size, angle, translation); + renderer3.arrowShapeImpl(this.name)(context, ptsTrans, ctrlPtTrans); + }, + gap: function gap(edge) { + return standardGap(edge) * 0.8; + } + }); + defineArrowShape("triangle-tee", { + points: [0, 0, 0.15, -0.3, -0.15, -0.3, 0, 0], + pointsTee: [-0.15, -0.4, -0.15, -0.5, 0.15, -0.5, 0.15, -0.4], + collide: function collide(x, y, size, angle, translation, edgeWidth, padding) { + var triPts = pointsToArr(transformPoints(this.points, size + 2 * padding, angle, translation)); + var teePts = pointsToArr(transformPoints(this.pointsTee, size + 2 * padding, angle, translation)); + var inside = pointInsidePolygonPoints(x, y, triPts) || pointInsidePolygonPoints(x, y, teePts); + return inside; + }, + draw: function draw2(context, size, angle, translation, edgeWidth) { + var triPts = transformPoints(this.points, size, angle, translation); + var teePts = transformPoints(this.pointsTee, size, angle, translation); + renderer3.arrowShapeImpl(this.name)(context, triPts, teePts); + } + }); + defineArrowShape("circle-triangle", { + radius: 0.15, + pointsTr: [0, -0.15, 0.15, -0.45, -0.15, -0.45, 0, -0.15], + collide: function collide(x, y, size, angle, translation, edgeWidth, padding) { + var t = translation; + var circleInside = Math.pow(t.x - x, 2) + Math.pow(t.y - y, 2) <= Math.pow((size + 2 * padding) * this.radius, 2); + var triPts = pointsToArr(transformPoints(this.points, size + 2 * padding, angle, translation)); + return pointInsidePolygonPoints(x, y, triPts) || circleInside; + }, + draw: function draw2(context, size, angle, translation, edgeWidth) { + var triPts = transformPoints(this.pointsTr, size, angle, translation); + renderer3.arrowShapeImpl(this.name)(context, triPts, translation.x, translation.y, this.radius * size); + }, + spacing: function spacing(edge) { + return renderer3.getArrowWidth(edge.pstyle("width").pfValue, edge.pstyle("arrow-scale").value) * this.radius; + } + }); + defineArrowShape("triangle-cross", { + points: [0, 0, 0.15, -0.3, -0.15, -0.3, 0, 0], + baseCrossLinePts: [ + -0.15, + -0.4, + // first half of the rectangle + -0.15, + -0.4, + 0.15, + -0.4, + // second half of the rectangle + 0.15, + -0.4 + ], + crossLinePts: function crossLinePts(size, edgeWidth) { + var p2 = this.baseCrossLinePts.slice(); + var shiftFactor = edgeWidth / size; + var y0 = 3; + var y1 = 5; + p2[y0] = p2[y0] - shiftFactor; + p2[y1] = p2[y1] - shiftFactor; + return p2; + }, + collide: function collide(x, y, size, angle, translation, edgeWidth, padding) { + var triPts = pointsToArr(transformPoints(this.points, size + 2 * padding, angle, translation)); + var teePts = pointsToArr(transformPoints(this.crossLinePts(size, edgeWidth), size + 2 * padding, angle, translation)); + var inside = pointInsidePolygonPoints(x, y, triPts) || pointInsidePolygonPoints(x, y, teePts); + return inside; + }, + draw: function draw2(context, size, angle, translation, edgeWidth) { + var triPts = transformPoints(this.points, size, angle, translation); + var crossLinePts = transformPoints(this.crossLinePts(size, edgeWidth), size, angle, translation); + renderer3.arrowShapeImpl(this.name)(context, triPts, crossLinePts); + } + }); + defineArrowShape("vee", { + points: [-0.15, -0.3, 0, 0, 0.15, -0.3, 0, -0.15], + gap: function gap(edge) { + return standardGap(edge) * 0.525; + } + }); + defineArrowShape("circle", { + radius: 0.15, + collide: function collide(x, y, size, angle, translation, edgeWidth, padding) { + var t = translation; + var inside = Math.pow(t.x - x, 2) + Math.pow(t.y - y, 2) <= Math.pow((size + 2 * padding) * this.radius, 2); + return inside; + }, + draw: function draw2(context, size, angle, translation, edgeWidth) { + renderer3.arrowShapeImpl(this.name)(context, translation.x, translation.y, this.radius * size); + }, + spacing: function spacing(edge) { + return renderer3.getArrowWidth(edge.pstyle("width").pfValue, edge.pstyle("arrow-scale").value) * this.radius; + } + }); + defineArrowShape("tee", { + points: [-0.15, 0, -0.15, -0.1, 0.15, -0.1, 0.15, 0], + spacing: function spacing(edge) { + return 1; + }, + gap: function gap(edge) { + return 1; + } + }); + defineArrowShape("square", { + points: [-0.15, 0, 0.15, 0, 0.15, -0.3, -0.15, -0.3] + }); + defineArrowShape("diamond", { + points: [-0.15, -0.15, 0, -0.3, 0.15, -0.15, 0, 0], + gap: function gap(edge) { + return edge.pstyle("width").pfValue * edge.pstyle("arrow-scale").value; + } + }); + defineArrowShape("chevron", { + points: [0, 0, -0.15, -0.15, -0.1, -0.2, 0, -0.1, 0.1, -0.2, 0.15, -0.15], + gap: function gap(edge) { + return 0.95 * edge.pstyle("width").pfValue * edge.pstyle("arrow-scale").value; + } + }); + }; + var BRp$e = {}; + BRp$e.projectIntoViewport = function(clientX, clientY) { + var cy = this.cy; + var offsets = this.findContainerClientCoords(); + var offsetLeft = offsets[0]; + var offsetTop = offsets[1]; + var scale = offsets[4]; + var pan = cy.pan(); + var zoom = cy.zoom(); + var x = ((clientX - offsetLeft) / scale - pan.x) / zoom; + var y = ((clientY - offsetTop) / scale - pan.y) / zoom; + return [x, y]; + }; + BRp$e.findContainerClientCoords = function() { + if (this.containerBB) { + return this.containerBB; + } + var container = this.container; + var rect = container.getBoundingClientRect(); + var style = this.cy.window().getComputedStyle(container); + var styleValue = function styleValue2(name) { + return parseFloat(style.getPropertyValue(name)); + }; + var padding = { + left: styleValue("padding-left"), + right: styleValue("padding-right"), + top: styleValue("padding-top"), + bottom: styleValue("padding-bottom") + }; + var border = { + left: styleValue("border-left-width"), + right: styleValue("border-right-width"), + top: styleValue("border-top-width"), + bottom: styleValue("border-bottom-width") + }; + var clientWidth = container.clientWidth; + var clientHeight = container.clientHeight; + var paddingHor = padding.left + padding.right; + var paddingVer = padding.top + padding.bottom; + var borderHor = border.left + border.right; + var scale = rect.width / (clientWidth + borderHor); + var unscaledW = clientWidth - paddingHor; + var unscaledH = clientHeight - paddingVer; + var left = rect.left + padding.left + border.left; + var top = rect.top + padding.top + border.top; + return this.containerBB = [left, top, unscaledW, unscaledH, scale]; + }; + BRp$e.invalidateContainerClientCoordsCache = function() { + this.containerBB = null; + }; + BRp$e.findNearestElement = function(x, y, interactiveElementsOnly, isTouch) { + return this.findNearestElements(x, y, interactiveElementsOnly, isTouch)[0]; + }; + BRp$e.findNearestElements = function(x, y, interactiveElementsOnly, isTouch) { + var self2 = this; + var r = this; + var eles = r.getCachedZSortedEles(); + var near = []; + var zoom = r.cy.zoom(); + var hasCompounds = r.cy.hasCompoundNodes(); + var edgeThreshold = (isTouch ? 24 : 8) / zoom; + var nodeThreshold = (isTouch ? 8 : 2) / zoom; + var labelThreshold = (isTouch ? 8 : 2) / zoom; + var minSqDist = Infinity; + var nearEdge; + var nearNode; + if (interactiveElementsOnly) { + eles = eles.interactive; + } + function addEle(ele2, sqDist) { + if (ele2.isNode()) { + if (nearNode) { + return; + } else { + nearNode = ele2; + near.push(ele2); + } + } + if (ele2.isEdge() && (sqDist == null || sqDist < minSqDist)) { + if (nearEdge) { + if (nearEdge.pstyle("z-compound-depth").value === ele2.pstyle("z-compound-depth").value && nearEdge.pstyle("z-compound-depth").value === ele2.pstyle("z-compound-depth").value) { + for (var i3 = 0; i3 < near.length; i3++) { + if (near[i3].isEdge()) { + near[i3] = ele2; + nearEdge = ele2; + minSqDist = sqDist != null ? sqDist : minSqDist; + break; + } + } + } + } else { + near.push(ele2); + nearEdge = ele2; + minSqDist = sqDist != null ? sqDist : minSqDist; + } + } + } + function checkNode(node) { + var width = node.outerWidth() + 2 * nodeThreshold; + var height = node.outerHeight() + 2 * nodeThreshold; + var hw = width / 2; + var hh = height / 2; + var pos = node.position(); + if (pos.x - hw <= x && x <= pos.x + hw && pos.y - hh <= y && y <= pos.y + hh) { + var shape = r.nodeShapes[self2.getNodeShape(node)]; + if (shape.checkPoint(x, y, 0, width, height, pos.x, pos.y)) { + addEle(node, 0); + return true; + } + } + } + function checkEdge(edge) { + var _p = edge._private; + var rs = _p.rscratch; + var styleWidth = edge.pstyle("width").pfValue; + var scale = edge.pstyle("arrow-scale").value; + var width = styleWidth / 2 + edgeThreshold; + var widthSq = width * width; + var width2 = width * 2; + var src = _p.source; + var tgt = _p.target; + var sqDist; + if (rs.edgeType === "segments" || rs.edgeType === "straight" || rs.edgeType === "haystack") { + var pts2 = rs.allpts; + for (var i3 = 0; i3 + 3 < pts2.length; i3 += 2) { + if (inLineVicinity(x, y, pts2[i3], pts2[i3 + 1], pts2[i3 + 2], pts2[i3 + 3], width2) && widthSq > (sqDist = sqdistToFiniteLine(x, y, pts2[i3], pts2[i3 + 1], pts2[i3 + 2], pts2[i3 + 3]))) { + addEle(edge, sqDist); + return true; + } + } + } else if (rs.edgeType === "bezier" || rs.edgeType === "multibezier" || rs.edgeType === "self" || rs.edgeType === "compound") { + var pts2 = rs.allpts; + for (var i3 = 0; i3 + 5 < rs.allpts.length; i3 += 4) { + if (inBezierVicinity(x, y, pts2[i3], pts2[i3 + 1], pts2[i3 + 2], pts2[i3 + 3], pts2[i3 + 4], pts2[i3 + 5], width2) && widthSq > (sqDist = sqdistToQuadraticBezier(x, y, pts2[i3], pts2[i3 + 1], pts2[i3 + 2], pts2[i3 + 3], pts2[i3 + 4], pts2[i3 + 5]))) { + addEle(edge, sqDist); + return true; + } + } + } + var src = src || _p.source; + var tgt = tgt || _p.target; + var arSize = self2.getArrowWidth(styleWidth, scale); + var arrows = [{ + name: "source", + x: rs.arrowStartX, + y: rs.arrowStartY, + angle: rs.srcArrowAngle + }, { + name: "target", + x: rs.arrowEndX, + y: rs.arrowEndY, + angle: rs.tgtArrowAngle + }, { + name: "mid-source", + x: rs.midX, + y: rs.midY, + angle: rs.midsrcArrowAngle + }, { + name: "mid-target", + x: rs.midX, + y: rs.midY, + angle: rs.midtgtArrowAngle + }]; + for (var i3 = 0; i3 < arrows.length; i3++) { + var ar = arrows[i3]; + var shape = r.arrowShapes[edge.pstyle(ar.name + "-arrow-shape").value]; + var edgeWidth = edge.pstyle("width").pfValue; + if (shape.roughCollide(x, y, arSize, ar.angle, { + x: ar.x, + y: ar.y + }, edgeWidth, edgeThreshold) && shape.collide(x, y, arSize, ar.angle, { + x: ar.x, + y: ar.y + }, edgeWidth, edgeThreshold)) { + addEle(edge); + return true; + } + } + if (hasCompounds && near.length > 0) { + checkNode(src); + checkNode(tgt); + } + } + function preprop(obj, name, pre) { + return getPrefixedProperty(obj, name, pre); + } + function checkLabel(ele2, prefix) { + var _p = ele2._private; + var th = labelThreshold; + var prefixDash; + if (prefix) { + prefixDash = prefix + "-"; + } else { + prefixDash = ""; + } + ele2.boundingBox(); + var bb = _p.labelBounds[prefix || "main"]; + var text = ele2.pstyle(prefixDash + "label").value; + var eventsEnabled = ele2.pstyle("text-events").strValue === "yes"; + if (!eventsEnabled || !text) { + return; + } + var lx = preprop(_p.rscratch, "labelX", prefix); + var ly = preprop(_p.rscratch, "labelY", prefix); + var theta = preprop(_p.rscratch, "labelAngle", prefix); + var ox = ele2.pstyle(prefixDash + "text-margin-x").pfValue; + var oy = ele2.pstyle(prefixDash + "text-margin-y").pfValue; + var lx1 = bb.x1 - th - ox; + var lx2 = bb.x2 + th - ox; + var ly1 = bb.y1 - th - oy; + var ly2 = bb.y2 + th - oy; + if (theta) { + var cos2 = Math.cos(theta); + var sin2 = Math.sin(theta); + var rotate = function rotate2(x2, y2) { + x2 = x2 - lx; + y2 = y2 - ly; + return { + x: x2 * cos2 - y2 * sin2 + lx, + y: x2 * sin2 + y2 * cos2 + ly + }; + }; + var px1y1 = rotate(lx1, ly1); + var px1y2 = rotate(lx1, ly2); + var px2y1 = rotate(lx2, ly1); + var px2y2 = rotate(lx2, ly2); + var points = [ + // with the margin added after the rotation is applied + px1y1.x + ox, + px1y1.y + oy, + px2y1.x + ox, + px2y1.y + oy, + px2y2.x + ox, + px2y2.y + oy, + px1y2.x + ox, + px1y2.y + oy + ]; + if (pointInsidePolygonPoints(x, y, points)) { + addEle(ele2); + return true; + } + } else { + if (inBoundingBox(bb, x, y)) { + addEle(ele2); + return true; + } + } + } + for (var i2 = eles.length - 1; i2 >= 0; i2--) { + var ele = eles[i2]; + if (ele.isNode()) { + checkNode(ele) || checkLabel(ele); + } else { + checkEdge(ele) || checkLabel(ele) || checkLabel(ele, "source") || checkLabel(ele, "target"); + } + } + return near; + }; + BRp$e.getAllInBox = function(x1, y1, x2, y2) { + var eles = this.getCachedZSortedEles().interactive; + var box = []; + var x1c = Math.min(x1, x2); + var x2c = Math.max(x1, x2); + var y1c = Math.min(y1, y2); + var y2c = Math.max(y1, y2); + x1 = x1c; + x2 = x2c; + y1 = y1c; + y2 = y2c; + var boxBb = makeBoundingBox({ + x1, + y1, + x2, + y2 + }); + for (var e = 0; e < eles.length; e++) { + var ele = eles[e]; + if (ele.isNode()) { + var node = ele; + var nodeBb = node.boundingBox({ + includeNodes: true, + includeEdges: false, + includeLabels: false + }); + if (boundingBoxesIntersect(boxBb, nodeBb) && !boundingBoxInBoundingBox(nodeBb, boxBb)) { + box.push(node); + } + } else { + var edge = ele; + var _p = edge._private; + var rs = _p.rscratch; + if (rs.startX != null && rs.startY != null && !inBoundingBox(boxBb, rs.startX, rs.startY)) { + continue; + } + if (rs.endX != null && rs.endY != null && !inBoundingBox(boxBb, rs.endX, rs.endY)) { + continue; + } + if (rs.edgeType === "bezier" || rs.edgeType === "multibezier" || rs.edgeType === "self" || rs.edgeType === "compound" || rs.edgeType === "segments" || rs.edgeType === "haystack") { + var pts2 = _p.rstyle.bezierPts || _p.rstyle.linePts || _p.rstyle.haystackPts; + var allInside = true; + for (var i2 = 0; i2 < pts2.length; i2++) { + if (!pointInBoundingBox(boxBb, pts2[i2])) { + allInside = false; + break; + } + } + if (allInside) { + box.push(edge); + } + } else if (rs.edgeType === "haystack" || rs.edgeType === "straight") { + box.push(edge); + } + } + } + return box; + }; + var BRp$d = {}; + BRp$d.calculateArrowAngles = function(edge) { + var rs = edge._private.rscratch; + var isHaystack = rs.edgeType === "haystack"; + var isBezier = rs.edgeType === "bezier"; + var isMultibezier = rs.edgeType === "multibezier"; + var isSegments = rs.edgeType === "segments"; + var isCompound = rs.edgeType === "compound"; + var isSelf = rs.edgeType === "self"; + var dispX, dispY; + var startX, startY, endX, endY, midX, midY; + if (isHaystack) { + startX = rs.haystackPts[0]; + startY = rs.haystackPts[1]; + endX = rs.haystackPts[2]; + endY = rs.haystackPts[3]; + } else { + startX = rs.arrowStartX; + startY = rs.arrowStartY; + endX = rs.arrowEndX; + endY = rs.arrowEndY; + } + midX = rs.midX; + midY = rs.midY; + if (isSegments) { + dispX = startX - rs.segpts[0]; + dispY = startY - rs.segpts[1]; + } else if (isMultibezier || isCompound || isSelf || isBezier) { + var pts2 = rs.allpts; + var bX = qbezierAt(pts2[0], pts2[2], pts2[4], 0.1); + var bY = qbezierAt(pts2[1], pts2[3], pts2[5], 0.1); + dispX = startX - bX; + dispY = startY - bY; + } else { + dispX = startX - midX; + dispY = startY - midY; + } + rs.srcArrowAngle = getAngleFromDisp(dispX, dispY); + var midX = rs.midX; + var midY = rs.midY; + if (isHaystack) { + midX = (startX + endX) / 2; + midY = (startY + endY) / 2; + } + dispX = endX - startX; + dispY = endY - startY; + if (isSegments) { + var pts2 = rs.allpts; + if (pts2.length / 2 % 2 === 0) { + var i2 = pts2.length / 2; + var i1 = i2 - 2; + dispX = pts2[i2] - pts2[i1]; + dispY = pts2[i2 + 1] - pts2[i1 + 1]; + } else { + var i2 = pts2.length / 2 - 1; + var i1 = i2 - 2; + var i3 = i2 + 2; + dispX = pts2[i2] - pts2[i1]; + dispY = pts2[i2 + 1] - pts2[i1 + 1]; + } + } else if (isMultibezier || isCompound || isSelf) { + var pts2 = rs.allpts; + var cpts = rs.ctrlpts; + var bp0x, bp0y; + var bp1x, bp1y; + if (cpts.length / 2 % 2 === 0) { + var p0 = pts2.length / 2 - 1; + var ic = p0 + 2; + var p1 = ic + 2; + bp0x = qbezierAt(pts2[p0], pts2[ic], pts2[p1], 0); + bp0y = qbezierAt(pts2[p0 + 1], pts2[ic + 1], pts2[p1 + 1], 0); + bp1x = qbezierAt(pts2[p0], pts2[ic], pts2[p1], 1e-4); + bp1y = qbezierAt(pts2[p0 + 1], pts2[ic + 1], pts2[p1 + 1], 1e-4); + } else { + var ic = pts2.length / 2 - 1; + var p0 = ic - 2; + var p1 = ic + 2; + bp0x = qbezierAt(pts2[p0], pts2[ic], pts2[p1], 0.4999); + bp0y = qbezierAt(pts2[p0 + 1], pts2[ic + 1], pts2[p1 + 1], 0.4999); + bp1x = qbezierAt(pts2[p0], pts2[ic], pts2[p1], 0.5); + bp1y = qbezierAt(pts2[p0 + 1], pts2[ic + 1], pts2[p1 + 1], 0.5); + } + dispX = bp1x - bp0x; + dispY = bp1y - bp0y; + } + rs.midtgtArrowAngle = getAngleFromDisp(dispX, dispY); + rs.midDispX = dispX; + rs.midDispY = dispY; + dispX *= -1; + dispY *= -1; + if (isSegments) { + var pts2 = rs.allpts; + if (pts2.length / 2 % 2 === 0) + ; + else { + var i2 = pts2.length / 2 - 1; + var i3 = i2 + 2; + dispX = -(pts2[i3] - pts2[i2]); + dispY = -(pts2[i3 + 1] - pts2[i2 + 1]); + } + } + rs.midsrcArrowAngle = getAngleFromDisp(dispX, dispY); + if (isSegments) { + dispX = endX - rs.segpts[rs.segpts.length - 2]; + dispY = endY - rs.segpts[rs.segpts.length - 1]; + } else if (isMultibezier || isCompound || isSelf || isBezier) { + var pts2 = rs.allpts; + var l = pts2.length; + var bX = qbezierAt(pts2[l - 6], pts2[l - 4], pts2[l - 2], 0.9); + var bY = qbezierAt(pts2[l - 5], pts2[l - 3], pts2[l - 1], 0.9); + dispX = endX - bX; + dispY = endY - bY; + } else { + dispX = endX - midX; + dispY = endY - midY; + } + rs.tgtArrowAngle = getAngleFromDisp(dispX, dispY); + }; + BRp$d.getArrowWidth = BRp$d.getArrowHeight = function(edgeWidth, scale) { + var cache2 = this.arrowWidthCache = this.arrowWidthCache || {}; + var cachedVal = cache2[edgeWidth + ", " + scale]; + if (cachedVal) { + return cachedVal; + } + cachedVal = Math.max(Math.pow(edgeWidth * 13.37, 0.9), 29) * scale; + cache2[edgeWidth + ", " + scale] = cachedVal; + return cachedVal; + }; + var BRp$c = {}; + BRp$c.findMidptPtsEtc = function(edge, pairInfo) { + var posPts = pairInfo.posPts, intersectionPts = pairInfo.intersectionPts, vectorNormInverse = pairInfo.vectorNormInverse; + var midptPts; + var srcManEndpt = edge.pstyle("source-endpoint"); + var tgtManEndpt = edge.pstyle("target-endpoint"); + var haveManualEndPts = srcManEndpt.units != null && tgtManEndpt.units != null; + var recalcVectorNormInverse = function recalcVectorNormInverse2(x12, y12, x22, y22) { + var dy = y22 - y12; + var dx = x22 - x12; + var l = Math.sqrt(dx * dx + dy * dy); + return { + x: -dy / l, + y: dx / l + }; + }; + var edgeDistances = edge.pstyle("edge-distances").value; + switch (edgeDistances) { + case "node-position": + midptPts = posPts; + break; + case "intersection": + midptPts = intersectionPts; + break; + case "endpoints": { + if (haveManualEndPts) { + var _this$manualEndptToPx = this.manualEndptToPx(edge.source()[0], srcManEndpt), _this$manualEndptToPx2 = _slicedToArray(_this$manualEndptToPx, 2), x1 = _this$manualEndptToPx2[0], y1 = _this$manualEndptToPx2[1]; + var _this$manualEndptToPx3 = this.manualEndptToPx(edge.target()[0], tgtManEndpt), _this$manualEndptToPx4 = _slicedToArray(_this$manualEndptToPx3, 2), x2 = _this$manualEndptToPx4[0], y2 = _this$manualEndptToPx4[1]; + var endPts = { + x1, + y1, + x2, + y2 + }; + vectorNormInverse = recalcVectorNormInverse(x1, y1, x2, y2); + midptPts = endPts; + } else { + warn("Edge ".concat(edge.id(), " has edge-distances:endpoints specified without manual endpoints specified via source-endpoint and target-endpoint. Falling back on edge-distances:intersection (default).")); + midptPts = intersectionPts; + } + break; + } + } + return { + midptPts, + vectorNormInverse + }; + }; + BRp$c.findHaystackPoints = function(edges) { + for (var i2 = 0; i2 < edges.length; i2++) { + var edge = edges[i2]; + var _p = edge._private; + var rs = _p.rscratch; + if (!rs.haystack) { + var angle = Math.random() * 2 * Math.PI; + rs.source = { + x: Math.cos(angle), + y: Math.sin(angle) + }; + angle = Math.random() * 2 * Math.PI; + rs.target = { + x: Math.cos(angle), + y: Math.sin(angle) + }; + } + var src = _p.source; + var tgt = _p.target; + var srcPos = src.position(); + var tgtPos = tgt.position(); + var srcW = src.width(); + var tgtW = tgt.width(); + var srcH = src.height(); + var tgtH = tgt.height(); + var radius = edge.pstyle("haystack-radius").value; + var halfRadius = radius / 2; + rs.haystackPts = rs.allpts = [rs.source.x * srcW * halfRadius + srcPos.x, rs.source.y * srcH * halfRadius + srcPos.y, rs.target.x * tgtW * halfRadius + tgtPos.x, rs.target.y * tgtH * halfRadius + tgtPos.y]; + rs.midX = (rs.allpts[0] + rs.allpts[2]) / 2; + rs.midY = (rs.allpts[1] + rs.allpts[3]) / 2; + rs.edgeType = "haystack"; + rs.haystack = true; + this.storeEdgeProjections(edge); + this.calculateArrowAngles(edge); + this.recalculateEdgeLabelProjections(edge); + this.calculateLabelAngles(edge); + } + }; + BRp$c.findSegmentsPoints = function(edge, pairInfo) { + var rs = edge._private.rscratch; + var segmentWs = edge.pstyle("segment-weights"); + var segmentDs = edge.pstyle("segment-distances"); + var segmentsN = Math.min(segmentWs.pfValue.length, segmentDs.pfValue.length); + rs.edgeType = "segments"; + rs.segpts = []; + for (var s = 0; s < segmentsN; s++) { + var w = segmentWs.pfValue[s]; + var d = segmentDs.pfValue[s]; + var w1 = 1 - w; + var w2 = w; + var _this$findMidptPtsEtc = this.findMidptPtsEtc(edge, pairInfo), midptPts = _this$findMidptPtsEtc.midptPts, vectorNormInverse = _this$findMidptPtsEtc.vectorNormInverse; + var adjustedMidpt = { + x: midptPts.x1 * w1 + midptPts.x2 * w2, + y: midptPts.y1 * w1 + midptPts.y2 * w2 + }; + rs.segpts.push(adjustedMidpt.x + vectorNormInverse.x * d, adjustedMidpt.y + vectorNormInverse.y * d); + } + }; + BRp$c.findLoopPoints = function(edge, pairInfo, i2, edgeIsUnbundled) { + var rs = edge._private.rscratch; + var dirCounts = pairInfo.dirCounts, srcPos = pairInfo.srcPos; + var ctrlptDists = edge.pstyle("control-point-distances"); + var ctrlptDist = ctrlptDists ? ctrlptDists.pfValue[0] : void 0; + var loopDir = edge.pstyle("loop-direction").pfValue; + var loopSwp = edge.pstyle("loop-sweep").pfValue; + var stepSize = edge.pstyle("control-point-step-size").pfValue; + rs.edgeType = "self"; + var j = i2; + var loopDist = stepSize; + if (edgeIsUnbundled) { + j = 0; + loopDist = ctrlptDist; + } + var loopAngle = loopDir - Math.PI / 2; + var outAngle = loopAngle - loopSwp / 2; + var inAngle = loopAngle + loopSwp / 2; + var dc = String(loopDir + "_" + loopSwp); + j = dirCounts[dc] === void 0 ? dirCounts[dc] = 0 : ++dirCounts[dc]; + rs.ctrlpts = [srcPos.x + Math.cos(outAngle) * 1.4 * loopDist * (j / 3 + 1), srcPos.y + Math.sin(outAngle) * 1.4 * loopDist * (j / 3 + 1), srcPos.x + Math.cos(inAngle) * 1.4 * loopDist * (j / 3 + 1), srcPos.y + Math.sin(inAngle) * 1.4 * loopDist * (j / 3 + 1)]; + }; + BRp$c.findCompoundLoopPoints = function(edge, pairInfo, i2, edgeIsUnbundled) { + var rs = edge._private.rscratch; + rs.edgeType = "compound"; + var srcPos = pairInfo.srcPos, tgtPos = pairInfo.tgtPos, srcW = pairInfo.srcW, srcH = pairInfo.srcH, tgtW = pairInfo.tgtW, tgtH = pairInfo.tgtH; + var stepSize = edge.pstyle("control-point-step-size").pfValue; + var ctrlptDists = edge.pstyle("control-point-distances"); + var ctrlptDist = ctrlptDists ? ctrlptDists.pfValue[0] : void 0; + var j = i2; + var loopDist = stepSize; + if (edgeIsUnbundled) { + j = 0; + loopDist = ctrlptDist; + } + var loopW = 50; + var loopaPos = { + x: srcPos.x - srcW / 2, + y: srcPos.y - srcH / 2 + }; + var loopbPos = { + x: tgtPos.x - tgtW / 2, + y: tgtPos.y - tgtH / 2 + }; + var loopPos = { + x: Math.min(loopaPos.x, loopbPos.x), + y: Math.min(loopaPos.y, loopbPos.y) + }; + var minCompoundStretch = 0.5; + var compoundStretchA = Math.max(minCompoundStretch, Math.log(srcW * 0.01)); + var compoundStretchB = Math.max(minCompoundStretch, Math.log(tgtW * 0.01)); + rs.ctrlpts = [loopPos.x, loopPos.y - (1 + Math.pow(loopW, 1.12) / 100) * loopDist * (j / 3 + 1) * compoundStretchA, loopPos.x - (1 + Math.pow(loopW, 1.12) / 100) * loopDist * (j / 3 + 1) * compoundStretchB, loopPos.y]; + }; + BRp$c.findStraightEdgePoints = function(edge) { + edge._private.rscratch.edgeType = "straight"; + }; + BRp$c.findBezierPoints = function(edge, pairInfo, i2, edgeIsUnbundled, edgeIsSwapped) { + var rs = edge._private.rscratch; + var stepSize = edge.pstyle("control-point-step-size").pfValue; + var ctrlptDists = edge.pstyle("control-point-distances"); + var ctrlptWs = edge.pstyle("control-point-weights"); + var bezierN = ctrlptDists && ctrlptWs ? Math.min(ctrlptDists.value.length, ctrlptWs.value.length) : 1; + var ctrlptDist = ctrlptDists ? ctrlptDists.pfValue[0] : void 0; + var ctrlptWeight = ctrlptWs.value[0]; + var multi = edgeIsUnbundled; + rs.edgeType = multi ? "multibezier" : "bezier"; + rs.ctrlpts = []; + for (var b = 0; b < bezierN; b++) { + var normctrlptDist = (0.5 - pairInfo.eles.length / 2 + i2) * stepSize * (edgeIsSwapped ? -1 : 1); + var manctrlptDist = void 0; + var sign = signum(normctrlptDist); + if (multi) { + ctrlptDist = ctrlptDists ? ctrlptDists.pfValue[b] : stepSize; + ctrlptWeight = ctrlptWs.value[b]; + } + if (edgeIsUnbundled) { + manctrlptDist = ctrlptDist; + } else { + manctrlptDist = ctrlptDist !== void 0 ? sign * ctrlptDist : void 0; + } + var distanceFromMidpoint = manctrlptDist !== void 0 ? manctrlptDist : normctrlptDist; + var w1 = 1 - ctrlptWeight; + var w2 = ctrlptWeight; + var _this$findMidptPtsEtc2 = this.findMidptPtsEtc(edge, pairInfo), midptPts = _this$findMidptPtsEtc2.midptPts, vectorNormInverse = _this$findMidptPtsEtc2.vectorNormInverse; + var adjustedMidpt = { + x: midptPts.x1 * w1 + midptPts.x2 * w2, + y: midptPts.y1 * w1 + midptPts.y2 * w2 + }; + rs.ctrlpts.push(adjustedMidpt.x + vectorNormInverse.x * distanceFromMidpoint, adjustedMidpt.y + vectorNormInverse.y * distanceFromMidpoint); + } + }; + BRp$c.findTaxiPoints = function(edge, pairInfo) { + var rs = edge._private.rscratch; + rs.edgeType = "segments"; + var VERTICAL = "vertical"; + var HORIZONTAL = "horizontal"; + var LEFTWARD = "leftward"; + var RIGHTWARD = "rightward"; + var DOWNWARD = "downward"; + var UPWARD = "upward"; + var AUTO = "auto"; + var posPts = pairInfo.posPts, srcW = pairInfo.srcW, srcH = pairInfo.srcH, tgtW = pairInfo.tgtW, tgtH = pairInfo.tgtH; + var edgeDistances = edge.pstyle("edge-distances").value; + var dIncludesNodeBody = edgeDistances !== "node-position"; + var taxiDir = edge.pstyle("taxi-direction").value; + var rawTaxiDir = taxiDir; + var taxiTurn = edge.pstyle("taxi-turn"); + var turnIsPercent = taxiTurn.units === "%"; + var taxiTurnPfVal = taxiTurn.pfValue; + var turnIsNegative = taxiTurnPfVal < 0; + var minD = edge.pstyle("taxi-turn-min-distance").pfValue; + var dw = dIncludesNodeBody ? (srcW + tgtW) / 2 : 0; + var dh = dIncludesNodeBody ? (srcH + tgtH) / 2 : 0; + var pdx = posPts.x2 - posPts.x1; + var pdy = posPts.y2 - posPts.y1; + var subDWH = function subDWH2(dxy, dwh) { + if (dxy > 0) { + return Math.max(dxy - dwh, 0); + } else { + return Math.min(dxy + dwh, 0); + } + }; + var dx = subDWH(pdx, dw); + var dy = subDWH(pdy, dh); + var isExplicitDir = false; + if (rawTaxiDir === AUTO) { + taxiDir = Math.abs(dx) > Math.abs(dy) ? HORIZONTAL : VERTICAL; + } else if (rawTaxiDir === UPWARD || rawTaxiDir === DOWNWARD) { + taxiDir = VERTICAL; + isExplicitDir = true; + } else if (rawTaxiDir === LEFTWARD || rawTaxiDir === RIGHTWARD) { + taxiDir = HORIZONTAL; + isExplicitDir = true; + } + var isVert = taxiDir === VERTICAL; + var l = isVert ? dy : dx; + var pl = isVert ? pdy : pdx; + var sgnL = signum(pl); + var forcedDir = false; + if (!(isExplicitDir && (turnIsPercent || turnIsNegative)) && (rawTaxiDir === DOWNWARD && pl < 0 || rawTaxiDir === UPWARD && pl > 0 || rawTaxiDir === LEFTWARD && pl > 0 || rawTaxiDir === RIGHTWARD && pl < 0)) { + sgnL *= -1; + l = sgnL * Math.abs(l); + forcedDir = true; + } + var d; + if (turnIsPercent) { + var p2 = taxiTurnPfVal < 0 ? 1 + taxiTurnPfVal : taxiTurnPfVal; + d = p2 * l; + } else { + var k = taxiTurnPfVal < 0 ? l : 0; + d = k + taxiTurnPfVal * sgnL; + } + var getIsTooClose = function getIsTooClose2(d2) { + return Math.abs(d2) < minD || Math.abs(d2) >= Math.abs(l); + }; + var isTooCloseSrc = getIsTooClose(d); + var isTooCloseTgt = getIsTooClose(Math.abs(l) - Math.abs(d)); + var isTooClose = isTooCloseSrc || isTooCloseTgt; + if (isTooClose && !forcedDir) { + if (isVert) { + var lShapeInsideSrc = Math.abs(pl) <= srcH / 2; + var lShapeInsideTgt = Math.abs(pdx) <= tgtW / 2; + if (lShapeInsideSrc) { + var x = (posPts.x1 + posPts.x2) / 2; + var y1 = posPts.y1, y2 = posPts.y2; + rs.segpts = [x, y1, x, y2]; + } else if (lShapeInsideTgt) { + var y = (posPts.y1 + posPts.y2) / 2; + var x1 = posPts.x1, x2 = posPts.x2; + rs.segpts = [x1, y, x2, y]; + } else { + rs.segpts = [posPts.x1, posPts.y2]; + } + } else { + var _lShapeInsideSrc = Math.abs(pl) <= srcW / 2; + var _lShapeInsideTgt = Math.abs(pdy) <= tgtH / 2; + if (_lShapeInsideSrc) { + var _y = (posPts.y1 + posPts.y2) / 2; + var _x = posPts.x1, _x2 = posPts.x2; + rs.segpts = [_x, _y, _x2, _y]; + } else if (_lShapeInsideTgt) { + var _x3 = (posPts.x1 + posPts.x2) / 2; + var _y2 = posPts.y1, _y3 = posPts.y2; + rs.segpts = [_x3, _y2, _x3, _y3]; + } else { + rs.segpts = [posPts.x2, posPts.y1]; + } + } + } else { + if (isVert) { + var _y4 = posPts.y1 + d + (dIncludesNodeBody ? srcH / 2 * sgnL : 0); + var _x4 = posPts.x1, _x5 = posPts.x2; + rs.segpts = [_x4, _y4, _x5, _y4]; + } else { + var _x6 = posPts.x1 + d + (dIncludesNodeBody ? srcW / 2 * sgnL : 0); + var _y5 = posPts.y1, _y6 = posPts.y2; + rs.segpts = [_x6, _y5, _x6, _y6]; + } + } + }; + BRp$c.tryToCorrectInvalidPoints = function(edge, pairInfo) { + var rs = edge._private.rscratch; + if (rs.edgeType === "bezier") { + var srcPos = pairInfo.srcPos, tgtPos = pairInfo.tgtPos, srcW = pairInfo.srcW, srcH = pairInfo.srcH, tgtW = pairInfo.tgtW, tgtH = pairInfo.tgtH, srcShape = pairInfo.srcShape, tgtShape = pairInfo.tgtShape; + var badStart = !number$1(rs.startX) || !number$1(rs.startY); + var badAStart = !number$1(rs.arrowStartX) || !number$1(rs.arrowStartY); + var badEnd = !number$1(rs.endX) || !number$1(rs.endY); + var badAEnd = !number$1(rs.arrowEndX) || !number$1(rs.arrowEndY); + var minCpADistFactor = 3; + var arrowW = this.getArrowWidth(edge.pstyle("width").pfValue, edge.pstyle("arrow-scale").value) * this.arrowShapeWidth; + var minCpADist = minCpADistFactor * arrowW; + var startACpDist = dist({ + x: rs.ctrlpts[0], + y: rs.ctrlpts[1] + }, { + x: rs.startX, + y: rs.startY + }); + var closeStartACp = startACpDist < minCpADist; + var endACpDist = dist({ + x: rs.ctrlpts[0], + y: rs.ctrlpts[1] + }, { + x: rs.endX, + y: rs.endY + }); + var closeEndACp = endACpDist < minCpADist; + var overlapping = false; + if (badStart || badAStart || closeStartACp) { + overlapping = true; + var cpD = { + // delta + x: rs.ctrlpts[0] - srcPos.x, + y: rs.ctrlpts[1] - srcPos.y + }; + var cpL = Math.sqrt(cpD.x * cpD.x + cpD.y * cpD.y); + var cpM = { + // normalised delta + x: cpD.x / cpL, + y: cpD.y / cpL + }; + var radius = Math.max(srcW, srcH); + var cpProj = { + // *2 radius guarantees outside shape + x: rs.ctrlpts[0] + cpM.x * 2 * radius, + y: rs.ctrlpts[1] + cpM.y * 2 * radius + }; + var srcCtrlPtIntn = srcShape.intersectLine(srcPos.x, srcPos.y, srcW, srcH, cpProj.x, cpProj.y, 0); + if (closeStartACp) { + rs.ctrlpts[0] = rs.ctrlpts[0] + cpM.x * (minCpADist - startACpDist); + rs.ctrlpts[1] = rs.ctrlpts[1] + cpM.y * (minCpADist - startACpDist); + } else { + rs.ctrlpts[0] = srcCtrlPtIntn[0] + cpM.x * minCpADist; + rs.ctrlpts[1] = srcCtrlPtIntn[1] + cpM.y * minCpADist; + } + } + if (badEnd || badAEnd || closeEndACp) { + overlapping = true; + var _cpD = { + // delta + x: rs.ctrlpts[0] - tgtPos.x, + y: rs.ctrlpts[1] - tgtPos.y + }; + var _cpL = Math.sqrt(_cpD.x * _cpD.x + _cpD.y * _cpD.y); + var _cpM = { + // normalised delta + x: _cpD.x / _cpL, + y: _cpD.y / _cpL + }; + var _radius = Math.max(srcW, srcH); + var _cpProj = { + // *2 radius guarantees outside shape + x: rs.ctrlpts[0] + _cpM.x * 2 * _radius, + y: rs.ctrlpts[1] + _cpM.y * 2 * _radius + }; + var tgtCtrlPtIntn = tgtShape.intersectLine(tgtPos.x, tgtPos.y, tgtW, tgtH, _cpProj.x, _cpProj.y, 0); + if (closeEndACp) { + rs.ctrlpts[0] = rs.ctrlpts[0] + _cpM.x * (minCpADist - endACpDist); + rs.ctrlpts[1] = rs.ctrlpts[1] + _cpM.y * (minCpADist - endACpDist); + } else { + rs.ctrlpts[0] = tgtCtrlPtIntn[0] + _cpM.x * minCpADist; + rs.ctrlpts[1] = tgtCtrlPtIntn[1] + _cpM.y * minCpADist; + } + } + if (overlapping) { + this.findEndpoints(edge); + } + } + }; + BRp$c.storeAllpts = function(edge) { + var rs = edge._private.rscratch; + if (rs.edgeType === "multibezier" || rs.edgeType === "bezier" || rs.edgeType === "self" || rs.edgeType === "compound") { + rs.allpts = []; + rs.allpts.push(rs.startX, rs.startY); + for (var b = 0; b + 1 < rs.ctrlpts.length; b += 2) { + rs.allpts.push(rs.ctrlpts[b], rs.ctrlpts[b + 1]); + if (b + 3 < rs.ctrlpts.length) { + rs.allpts.push((rs.ctrlpts[b] + rs.ctrlpts[b + 2]) / 2, (rs.ctrlpts[b + 1] + rs.ctrlpts[b + 3]) / 2); + } + } + rs.allpts.push(rs.endX, rs.endY); + var m, mt; + if (rs.ctrlpts.length / 2 % 2 === 0) { + m = rs.allpts.length / 2 - 1; + rs.midX = rs.allpts[m]; + rs.midY = rs.allpts[m + 1]; + } else { + m = rs.allpts.length / 2 - 3; + mt = 0.5; + rs.midX = qbezierAt(rs.allpts[m], rs.allpts[m + 2], rs.allpts[m + 4], mt); + rs.midY = qbezierAt(rs.allpts[m + 1], rs.allpts[m + 3], rs.allpts[m + 5], mt); + } + } else if (rs.edgeType === "straight") { + rs.allpts = [rs.startX, rs.startY, rs.endX, rs.endY]; + rs.midX = (rs.startX + rs.endX + rs.arrowStartX + rs.arrowEndX) / 4; + rs.midY = (rs.startY + rs.endY + rs.arrowStartY + rs.arrowEndY) / 4; + } else if (rs.edgeType === "segments") { + rs.allpts = []; + rs.allpts.push(rs.startX, rs.startY); + rs.allpts.push.apply(rs.allpts, rs.segpts); + rs.allpts.push(rs.endX, rs.endY); + if (rs.segpts.length % 4 === 0) { + var i2 = rs.segpts.length / 2; + var i1 = i2 - 2; + rs.midX = (rs.segpts[i1] + rs.segpts[i2]) / 2; + rs.midY = (rs.segpts[i1 + 1] + rs.segpts[i2 + 1]) / 2; + } else { + var _i = rs.segpts.length / 2 - 1; + rs.midX = rs.segpts[_i]; + rs.midY = rs.segpts[_i + 1]; + } + } + }; + BRp$c.checkForInvalidEdgeWarning = function(edge) { + var rs = edge[0]._private.rscratch; + if (rs.nodesOverlap || number$1(rs.startX) && number$1(rs.startY) && number$1(rs.endX) && number$1(rs.endY)) { + rs.loggedErr = false; + } else { + if (!rs.loggedErr) { + rs.loggedErr = true; + warn("Edge `" + edge.id() + "` has invalid endpoints and so it is impossible to draw. Adjust your edge style (e.g. control points) accordingly or use an alternative edge type. This is expected behaviour when the source node and the target node overlap."); + } + } + }; + BRp$c.findEdgeControlPoints = function(edges) { + var _this = this; + if (!edges || edges.length === 0) { + return; + } + var r = this; + var cy = r.cy; + var hasCompounds = cy.hasCompoundNodes(); + var hashTable = { + map: new Map$2(), + get: function get2(pairId2) { + var map2 = this.map.get(pairId2[0]); + if (map2 != null) { + return map2.get(pairId2[1]); + } else { + return null; + } + }, + set: function set2(pairId2, val) { + var map2 = this.map.get(pairId2[0]); + if (map2 == null) { + map2 = new Map$2(); + this.map.set(pairId2[0], map2); + } + map2.set(pairId2[1], val); + } + }; + var pairIds = []; + var haystackEdges = []; + for (var i2 = 0; i2 < edges.length; i2++) { + var edge = edges[i2]; + var _p = edge._private; + var curveStyle = edge.pstyle("curve-style").value; + if (edge.removed() || !edge.takesUpSpace()) { + continue; + } + if (curveStyle === "haystack") { + haystackEdges.push(edge); + continue; + } + var edgeIsUnbundled = curveStyle === "unbundled-bezier" || curveStyle === "segments" || curveStyle === "straight" || curveStyle === "straight-triangle" || curveStyle === "taxi"; + var edgeIsBezier = curveStyle === "unbundled-bezier" || curveStyle === "bezier"; + var src = _p.source; + var tgt = _p.target; + var srcIndex = src.poolIndex(); + var tgtIndex = tgt.poolIndex(); + var pairId = [srcIndex, tgtIndex].sort(); + var tableEntry = hashTable.get(pairId); + if (tableEntry == null) { + tableEntry = { + eles: [] + }; + hashTable.set(pairId, tableEntry); + pairIds.push(pairId); + } + tableEntry.eles.push(edge); + if (edgeIsUnbundled) { + tableEntry.hasUnbundled = true; + } + if (edgeIsBezier) { + tableEntry.hasBezier = true; + } + } + var _loop = function _loop2(p3) { + var pairId2 = pairIds[p3]; + var pairInfo = hashTable.get(pairId2); + var swappedpairInfo = void 0; + if (!pairInfo.hasUnbundled) { + var pllEdges = pairInfo.eles[0].parallelEdges().filter(function(e) { + return e.isBundledBezier(); + }); + clearArray(pairInfo.eles); + pllEdges.forEach(function(edge2) { + return pairInfo.eles.push(edge2); + }); + pairInfo.eles.sort(function(edge1, edge2) { + return edge1.poolIndex() - edge2.poolIndex(); + }); + } + var firstEdge = pairInfo.eles[0]; + var src2 = firstEdge.source(); + var tgt2 = firstEdge.target(); + if (src2.poolIndex() > tgt2.poolIndex()) { + var temp = src2; + src2 = tgt2; + tgt2 = temp; + } + var srcPos = pairInfo.srcPos = src2.position(); + var tgtPos = pairInfo.tgtPos = tgt2.position(); + var srcW = pairInfo.srcW = src2.outerWidth(); + var srcH = pairInfo.srcH = src2.outerHeight(); + var tgtW = pairInfo.tgtW = tgt2.outerWidth(); + var tgtH = pairInfo.tgtH = tgt2.outerHeight(); + var srcShape = pairInfo.srcShape = r.nodeShapes[_this.getNodeShape(src2)]; + var tgtShape = pairInfo.tgtShape = r.nodeShapes[_this.getNodeShape(tgt2)]; + pairInfo.dirCounts = { + "north": 0, + "west": 0, + "south": 0, + "east": 0, + "northwest": 0, + "southwest": 0, + "northeast": 0, + "southeast": 0 + }; + for (var _i2 = 0; _i2 < pairInfo.eles.length; _i2++) { + var _edge = pairInfo.eles[_i2]; + var rs = _edge[0]._private.rscratch; + var _curveStyle = _edge.pstyle("curve-style").value; + var _edgeIsUnbundled = _curveStyle === "unbundled-bezier" || _curveStyle === "segments" || _curveStyle === "taxi"; + var edgeIsSwapped = !src2.same(_edge.source()); + if (!pairInfo.calculatedIntersection && src2 !== tgt2 && (pairInfo.hasBezier || pairInfo.hasUnbundled)) { + pairInfo.calculatedIntersection = true; + var srcOutside = srcShape.intersectLine(srcPos.x, srcPos.y, srcW, srcH, tgtPos.x, tgtPos.y, 0); + var srcIntn = pairInfo.srcIntn = srcOutside; + var tgtOutside = tgtShape.intersectLine(tgtPos.x, tgtPos.y, tgtW, tgtH, srcPos.x, srcPos.y, 0); + var tgtIntn = pairInfo.tgtIntn = tgtOutside; + var intersectionPts = pairInfo.intersectionPts = { + x1: srcOutside[0], + x2: tgtOutside[0], + y1: srcOutside[1], + y2: tgtOutside[1] + }; + var posPts = pairInfo.posPts = { + x1: srcPos.x, + x2: tgtPos.x, + y1: srcPos.y, + y2: tgtPos.y + }; + var dy = tgtOutside[1] - srcOutside[1]; + var dx = tgtOutside[0] - srcOutside[0]; + var l = Math.sqrt(dx * dx + dy * dy); + var vector = pairInfo.vector = { + x: dx, + y: dy + }; + var vectorNorm = pairInfo.vectorNorm = { + x: vector.x / l, + y: vector.y / l + }; + var vectorNormInverse = { + x: -vectorNorm.y, + y: vectorNorm.x + }; + pairInfo.nodesOverlap = !number$1(l) || tgtShape.checkPoint(srcOutside[0], srcOutside[1], 0, tgtW, tgtH, tgtPos.x, tgtPos.y) || srcShape.checkPoint(tgtOutside[0], tgtOutside[1], 0, srcW, srcH, srcPos.x, srcPos.y); + pairInfo.vectorNormInverse = vectorNormInverse; + swappedpairInfo = { + nodesOverlap: pairInfo.nodesOverlap, + dirCounts: pairInfo.dirCounts, + calculatedIntersection: true, + hasBezier: pairInfo.hasBezier, + hasUnbundled: pairInfo.hasUnbundled, + eles: pairInfo.eles, + srcPos: tgtPos, + tgtPos: srcPos, + srcW: tgtW, + srcH: tgtH, + tgtW: srcW, + tgtH: srcH, + srcIntn: tgtIntn, + tgtIntn: srcIntn, + srcShape: tgtShape, + tgtShape: srcShape, + posPts: { + x1: posPts.x2, + y1: posPts.y2, + x2: posPts.x1, + y2: posPts.y1 + }, + intersectionPts: { + x1: intersectionPts.x2, + y1: intersectionPts.y2, + x2: intersectionPts.x1, + y2: intersectionPts.y1 + }, + vector: { + x: -vector.x, + y: -vector.y + }, + vectorNorm: { + x: -vectorNorm.x, + y: -vectorNorm.y + }, + vectorNormInverse: { + x: -vectorNormInverse.x, + y: -vectorNormInverse.y + } + }; + } + var passedPairInfo = edgeIsSwapped ? swappedpairInfo : pairInfo; + rs.nodesOverlap = passedPairInfo.nodesOverlap; + rs.srcIntn = passedPairInfo.srcIntn; + rs.tgtIntn = passedPairInfo.tgtIntn; + if (hasCompounds && (src2.isParent() || src2.isChild() || tgt2.isParent() || tgt2.isChild()) && (src2.parents().anySame(tgt2) || tgt2.parents().anySame(src2) || src2.same(tgt2) && src2.isParent())) { + _this.findCompoundLoopPoints(_edge, passedPairInfo, _i2, _edgeIsUnbundled); + } else if (src2 === tgt2) { + _this.findLoopPoints(_edge, passedPairInfo, _i2, _edgeIsUnbundled); + } else if (_curveStyle === "segments") { + _this.findSegmentsPoints(_edge, passedPairInfo); + } else if (_curveStyle === "taxi") { + _this.findTaxiPoints(_edge, passedPairInfo); + } else if (_curveStyle === "straight" || !_edgeIsUnbundled && pairInfo.eles.length % 2 === 1 && _i2 === Math.floor(pairInfo.eles.length / 2)) { + _this.findStraightEdgePoints(_edge); + } else { + _this.findBezierPoints(_edge, passedPairInfo, _i2, _edgeIsUnbundled, edgeIsSwapped); + } + _this.findEndpoints(_edge); + _this.tryToCorrectInvalidPoints(_edge, passedPairInfo); + _this.checkForInvalidEdgeWarning(_edge); + _this.storeAllpts(_edge); + _this.storeEdgeProjections(_edge); + _this.calculateArrowAngles(_edge); + _this.recalculateEdgeLabelProjections(_edge); + _this.calculateLabelAngles(_edge); + } + }; + for (var p2 = 0; p2 < pairIds.length; p2++) { + _loop(p2); + } + this.findHaystackPoints(haystackEdges); + }; + function getPts(pts2) { + var retPts = []; + if (pts2 == null) { + return; + } + for (var i2 = 0; i2 < pts2.length; i2 += 2) { + var x = pts2[i2]; + var y = pts2[i2 + 1]; + retPts.push({ + x, + y + }); + } + return retPts; + } + BRp$c.getSegmentPoints = function(edge) { + var rs = edge[0]._private.rscratch; + var type = rs.edgeType; + if (type === "segments") { + this.recalculateRenderedStyle(edge); + return getPts(rs.segpts); + } + }; + BRp$c.getControlPoints = function(edge) { + var rs = edge[0]._private.rscratch; + var type = rs.edgeType; + if (type === "bezier" || type === "multibezier" || type === "self" || type === "compound") { + this.recalculateRenderedStyle(edge); + return getPts(rs.ctrlpts); + } + }; + BRp$c.getEdgeMidpoint = function(edge) { + var rs = edge[0]._private.rscratch; + this.recalculateRenderedStyle(edge); + return { + x: rs.midX, + y: rs.midY + }; + }; + var BRp$b = {}; + BRp$b.manualEndptToPx = function(node, prop) { + var r = this; + var npos = node.position(); + var w = node.outerWidth(); + var h = node.outerHeight(); + if (prop.value.length === 2) { + var p2 = [prop.pfValue[0], prop.pfValue[1]]; + if (prop.units[0] === "%") { + p2[0] = p2[0] * w; + } + if (prop.units[1] === "%") { + p2[1] = p2[1] * h; + } + p2[0] += npos.x; + p2[1] += npos.y; + return p2; + } else { + var angle = prop.pfValue[0]; + angle = -Math.PI / 2 + angle; + var l = 2 * Math.max(w, h); + var _p = [npos.x + Math.cos(angle) * l, npos.y + Math.sin(angle) * l]; + return r.nodeShapes[this.getNodeShape(node)].intersectLine(npos.x, npos.y, w, h, _p[0], _p[1], 0); + } + }; + BRp$b.findEndpoints = function(edge) { + var r = this; + var intersect; + var source = edge.source()[0]; + var target = edge.target()[0]; + var srcPos = source.position(); + var tgtPos = target.position(); + var tgtArShape = edge.pstyle("target-arrow-shape").value; + var srcArShape = edge.pstyle("source-arrow-shape").value; + var tgtDist = edge.pstyle("target-distance-from-node").pfValue; + var srcDist = edge.pstyle("source-distance-from-node").pfValue; + var curveStyle = edge.pstyle("curve-style").value; + var rs = edge._private.rscratch; + var et = rs.edgeType; + var taxi = curveStyle === "taxi"; + var self2 = et === "self" || et === "compound"; + var bezier = et === "bezier" || et === "multibezier" || self2; + var multi = et !== "bezier"; + var lines = et === "straight" || et === "segments"; + var segments = et === "segments"; + var hasEndpts = bezier || multi || lines; + var overrideEndpts = self2 || taxi; + var srcManEndpt = edge.pstyle("source-endpoint"); + var srcManEndptVal = overrideEndpts ? "outside-to-node" : srcManEndpt.value; + var tgtManEndpt = edge.pstyle("target-endpoint"); + var tgtManEndptVal = overrideEndpts ? "outside-to-node" : tgtManEndpt.value; + rs.srcManEndpt = srcManEndpt; + rs.tgtManEndpt = tgtManEndpt; + var p1; + var p2; + var p1_i; + var p2_i; + if (bezier) { + var cpStart = [rs.ctrlpts[0], rs.ctrlpts[1]]; + var cpEnd = multi ? [rs.ctrlpts[rs.ctrlpts.length - 2], rs.ctrlpts[rs.ctrlpts.length - 1]] : cpStart; + p1 = cpEnd; + p2 = cpStart; + } else if (lines) { + var srcArrowFromPt = !segments ? [tgtPos.x, tgtPos.y] : rs.segpts.slice(0, 2); + var tgtArrowFromPt = !segments ? [srcPos.x, srcPos.y] : rs.segpts.slice(rs.segpts.length - 2); + p1 = tgtArrowFromPt; + p2 = srcArrowFromPt; + } + if (tgtManEndptVal === "inside-to-node") { + intersect = [tgtPos.x, tgtPos.y]; + } else if (tgtManEndpt.units) { + intersect = this.manualEndptToPx(target, tgtManEndpt); + } else if (tgtManEndptVal === "outside-to-line") { + intersect = rs.tgtIntn; + } else { + if (tgtManEndptVal === "outside-to-node" || tgtManEndptVal === "outside-to-node-or-label") { + p1_i = p1; + } else if (tgtManEndptVal === "outside-to-line" || tgtManEndptVal === "outside-to-line-or-label") { + p1_i = [srcPos.x, srcPos.y]; + } + intersect = r.nodeShapes[this.getNodeShape(target)].intersectLine(tgtPos.x, tgtPos.y, target.outerWidth(), target.outerHeight(), p1_i[0], p1_i[1], 0); + if (tgtManEndptVal === "outside-to-node-or-label" || tgtManEndptVal === "outside-to-line-or-label") { + var trs = target._private.rscratch; + var lw = trs.labelWidth; + var lh = trs.labelHeight; + var lx = trs.labelX; + var ly = trs.labelY; + var lw2 = lw / 2; + var lh2 = lh / 2; + var va = target.pstyle("text-valign").value; + if (va === "top") { + ly -= lh2; + } else if (va === "bottom") { + ly += lh2; + } + var ha = target.pstyle("text-halign").value; + if (ha === "left") { + lx -= lw2; + } else if (ha === "right") { + lx += lw2; + } + var labelIntersect = polygonIntersectLine(p1_i[0], p1_i[1], [lx - lw2, ly - lh2, lx + lw2, ly - lh2, lx + lw2, ly + lh2, lx - lw2, ly + lh2], tgtPos.x, tgtPos.y); + if (labelIntersect.length > 0) { + var refPt = srcPos; + var intSqdist = sqdist(refPt, array2point(intersect)); + var labIntSqdist = sqdist(refPt, array2point(labelIntersect)); + var minSqDist = intSqdist; + if (labIntSqdist < intSqdist) { + intersect = labelIntersect; + minSqDist = labIntSqdist; + } + if (labelIntersect.length > 2) { + var labInt2SqDist = sqdist(refPt, { + x: labelIntersect[2], + y: labelIntersect[3] + }); + if (labInt2SqDist < minSqDist) { + intersect = [labelIntersect[2], labelIntersect[3]]; + } + } + } + } + } + var arrowEnd = shortenIntersection(intersect, p1, r.arrowShapes[tgtArShape].spacing(edge) + tgtDist); + var edgeEnd = shortenIntersection(intersect, p1, r.arrowShapes[tgtArShape].gap(edge) + tgtDist); + rs.endX = edgeEnd[0]; + rs.endY = edgeEnd[1]; + rs.arrowEndX = arrowEnd[0]; + rs.arrowEndY = arrowEnd[1]; + if (srcManEndptVal === "inside-to-node") { + intersect = [srcPos.x, srcPos.y]; + } else if (srcManEndpt.units) { + intersect = this.manualEndptToPx(source, srcManEndpt); + } else if (srcManEndptVal === "outside-to-line") { + intersect = rs.srcIntn; + } else { + if (srcManEndptVal === "outside-to-node" || srcManEndptVal === "outside-to-node-or-label") { + p2_i = p2; + } else if (srcManEndptVal === "outside-to-line" || srcManEndptVal === "outside-to-line-or-label") { + p2_i = [tgtPos.x, tgtPos.y]; + } + intersect = r.nodeShapes[this.getNodeShape(source)].intersectLine(srcPos.x, srcPos.y, source.outerWidth(), source.outerHeight(), p2_i[0], p2_i[1], 0); + if (srcManEndptVal === "outside-to-node-or-label" || srcManEndptVal === "outside-to-line-or-label") { + var srs = source._private.rscratch; + var _lw = srs.labelWidth; + var _lh = srs.labelHeight; + var _lx = srs.labelX; + var _ly = srs.labelY; + var _lw2 = _lw / 2; + var _lh2 = _lh / 2; + var _va = source.pstyle("text-valign").value; + if (_va === "top") { + _ly -= _lh2; + } else if (_va === "bottom") { + _ly += _lh2; + } + var _ha = source.pstyle("text-halign").value; + if (_ha === "left") { + _lx -= _lw2; + } else if (_ha === "right") { + _lx += _lw2; + } + var _labelIntersect = polygonIntersectLine(p2_i[0], p2_i[1], [_lx - _lw2, _ly - _lh2, _lx + _lw2, _ly - _lh2, _lx + _lw2, _ly + _lh2, _lx - _lw2, _ly + _lh2], srcPos.x, srcPos.y); + if (_labelIntersect.length > 0) { + var _refPt = tgtPos; + var _intSqdist = sqdist(_refPt, array2point(intersect)); + var _labIntSqdist = sqdist(_refPt, array2point(_labelIntersect)); + var _minSqDist = _intSqdist; + if (_labIntSqdist < _intSqdist) { + intersect = [_labelIntersect[0], _labelIntersect[1]]; + _minSqDist = _labIntSqdist; + } + if (_labelIntersect.length > 2) { + var _labInt2SqDist = sqdist(_refPt, { + x: _labelIntersect[2], + y: _labelIntersect[3] + }); + if (_labInt2SqDist < _minSqDist) { + intersect = [_labelIntersect[2], _labelIntersect[3]]; + } + } + } + } + } + var arrowStart = shortenIntersection(intersect, p2, r.arrowShapes[srcArShape].spacing(edge) + srcDist); + var edgeStart = shortenIntersection(intersect, p2, r.arrowShapes[srcArShape].gap(edge) + srcDist); + rs.startX = edgeStart[0]; + rs.startY = edgeStart[1]; + rs.arrowStartX = arrowStart[0]; + rs.arrowStartY = arrowStart[1]; + if (hasEndpts) { + if (!number$1(rs.startX) || !number$1(rs.startY) || !number$1(rs.endX) || !number$1(rs.endY)) { + rs.badLine = true; + } else { + rs.badLine = false; + } + } + }; + BRp$b.getSourceEndpoint = function(edge) { + var rs = edge[0]._private.rscratch; + this.recalculateRenderedStyle(edge); + switch (rs.edgeType) { + case "haystack": + return { + x: rs.haystackPts[0], + y: rs.haystackPts[1] + }; + default: + return { + x: rs.arrowStartX, + y: rs.arrowStartY + }; + } + }; + BRp$b.getTargetEndpoint = function(edge) { + var rs = edge[0]._private.rscratch; + this.recalculateRenderedStyle(edge); + switch (rs.edgeType) { + case "haystack": + return { + x: rs.haystackPts[2], + y: rs.haystackPts[3] + }; + default: + return { + x: rs.arrowEndX, + y: rs.arrowEndY + }; + } + }; + var BRp$a = {}; + function pushBezierPts(r, edge, pts2) { + var qbezierAt$1 = function qbezierAt$12(p1, p22, p3, t) { + return qbezierAt(p1, p22, p3, t); + }; + var _p = edge._private; + var bpts = _p.rstyle.bezierPts; + for (var i2 = 0; i2 < r.bezierProjPcts.length; i2++) { + var p2 = r.bezierProjPcts[i2]; + bpts.push({ + x: qbezierAt$1(pts2[0], pts2[2], pts2[4], p2), + y: qbezierAt$1(pts2[1], pts2[3], pts2[5], p2) + }); + } + } + BRp$a.storeEdgeProjections = function(edge) { + var _p = edge._private; + var rs = _p.rscratch; + var et = rs.edgeType; + _p.rstyle.bezierPts = null; + _p.rstyle.linePts = null; + _p.rstyle.haystackPts = null; + if (et === "multibezier" || et === "bezier" || et === "self" || et === "compound") { + _p.rstyle.bezierPts = []; + for (var i2 = 0; i2 + 5 < rs.allpts.length; i2 += 4) { + pushBezierPts(this, edge, rs.allpts.slice(i2, i2 + 6)); + } + } else if (et === "segments") { + var lpts = _p.rstyle.linePts = []; + for (var i2 = 0; i2 + 1 < rs.allpts.length; i2 += 2) { + lpts.push({ + x: rs.allpts[i2], + y: rs.allpts[i2 + 1] + }); + } + } else if (et === "haystack") { + var hpts = rs.haystackPts; + _p.rstyle.haystackPts = [{ + x: hpts[0], + y: hpts[1] + }, { + x: hpts[2], + y: hpts[3] + }]; + } + _p.rstyle.arrowWidth = this.getArrowWidth(edge.pstyle("width").pfValue, edge.pstyle("arrow-scale").value) * this.arrowShapeWidth; + }; + BRp$a.recalculateEdgeProjections = function(edges) { + this.findEdgeControlPoints(edges); + }; + var BRp$9 = {}; + BRp$9.recalculateNodeLabelProjection = function(node) { + var content = node.pstyle("label").strValue; + if (emptyString(content)) { + return; + } + var textX, textY; + var _p = node._private; + var nodeWidth = node.width(); + var nodeHeight = node.height(); + var padding = node.padding(); + var nodePos = node.position(); + var textHalign = node.pstyle("text-halign").strValue; + var textValign = node.pstyle("text-valign").strValue; + var rs = _p.rscratch; + var rstyle = _p.rstyle; + switch (textHalign) { + case "left": + textX = nodePos.x - nodeWidth / 2 - padding; + break; + case "right": + textX = nodePos.x + nodeWidth / 2 + padding; + break; + default: + textX = nodePos.x; + } + switch (textValign) { + case "top": + textY = nodePos.y - nodeHeight / 2 - padding; + break; + case "bottom": + textY = nodePos.y + nodeHeight / 2 + padding; + break; + default: + textY = nodePos.y; + } + rs.labelX = textX; + rs.labelY = textY; + rstyle.labelX = textX; + rstyle.labelY = textY; + this.calculateLabelAngles(node); + this.applyLabelDimensions(node); + }; + var lineAngleFromDelta = function lineAngleFromDelta2(dx, dy) { + var angle = Math.atan(dy / dx); + if (dx === 0 && angle < 0) { + angle = angle * -1; + } + return angle; + }; + var lineAngle = function lineAngle2(p0, p1) { + var dx = p1.x - p0.x; + var dy = p1.y - p0.y; + return lineAngleFromDelta(dx, dy); + }; + var bezierAngle = function bezierAngle2(p0, p1, p2, t) { + var t0 = bound(0, t - 1e-3, 1); + var t1 = bound(0, t + 1e-3, 1); + var lp0 = qbezierPtAt(p0, p1, p2, t0); + var lp1 = qbezierPtAt(p0, p1, p2, t1); + return lineAngle(lp0, lp1); + }; + BRp$9.recalculateEdgeLabelProjections = function(edge) { + var p2; + var _p = edge._private; + var rs = _p.rscratch; + var r = this; + var content = { + mid: edge.pstyle("label").strValue, + source: edge.pstyle("source-label").strValue, + target: edge.pstyle("target-label").strValue + }; + if (content.mid || content.source || content.target) + ; + else { + return; + } + p2 = { + x: rs.midX, + y: rs.midY + }; + var setRs = function setRs2(propName, prefix, value) { + setPrefixedProperty(_p.rscratch, propName, prefix, value); + setPrefixedProperty(_p.rstyle, propName, prefix, value); + }; + setRs("labelX", null, p2.x); + setRs("labelY", null, p2.y); + var midAngle = lineAngleFromDelta(rs.midDispX, rs.midDispY); + setRs("labelAutoAngle", null, midAngle); + var createControlPointInfo = function createControlPointInfo2() { + if (createControlPointInfo2.cache) { + return createControlPointInfo2.cache; + } + var ctrlpts = []; + for (var i2 = 0; i2 + 5 < rs.allpts.length; i2 += 4) { + var p0 = { + x: rs.allpts[i2], + y: rs.allpts[i2 + 1] + }; + var p1 = { + x: rs.allpts[i2 + 2], + y: rs.allpts[i2 + 3] + }; + var p22 = { + x: rs.allpts[i2 + 4], + y: rs.allpts[i2 + 5] + }; + ctrlpts.push({ + p0, + p1, + p2: p22, + startDist: 0, + length: 0, + segments: [] + }); + } + var bpts = _p.rstyle.bezierPts; + var nProjs = r.bezierProjPcts.length; + function addSegment(cp2, p02, p12, t0, t1) { + var length = dist(p02, p12); + var prevSegment = cp2.segments[cp2.segments.length - 1]; + var segment = { + p0: p02, + p1: p12, + t0, + t1, + startDist: prevSegment ? prevSegment.startDist + prevSegment.length : 0, + length + }; + cp2.segments.push(segment); + cp2.length += length; + } + for (var _i = 0; _i < ctrlpts.length; _i++) { + var cp = ctrlpts[_i]; + var prevCp = ctrlpts[_i - 1]; + if (prevCp) { + cp.startDist = prevCp.startDist + prevCp.length; + } + addSegment(cp, cp.p0, bpts[_i * nProjs], 0, r.bezierProjPcts[0]); + for (var j = 0; j < nProjs - 1; j++) { + addSegment(cp, bpts[_i * nProjs + j], bpts[_i * nProjs + j + 1], r.bezierProjPcts[j], r.bezierProjPcts[j + 1]); + } + addSegment(cp, bpts[_i * nProjs + nProjs - 1], cp.p2, r.bezierProjPcts[nProjs - 1], 1); + } + return createControlPointInfo2.cache = ctrlpts; + }; + var calculateEndProjection = function calculateEndProjection2(prefix) { + var angle; + var isSrc = prefix === "source"; + if (!content[prefix]) { + return; + } + var offset = edge.pstyle(prefix + "-text-offset").pfValue; + switch (rs.edgeType) { + case "self": + case "compound": + case "bezier": + case "multibezier": { + var cps = createControlPointInfo(); + var selected; + var startDist = 0; + var totalDist = 0; + for (var i2 = 0; i2 < cps.length; i2++) { + var _cp = cps[isSrc ? i2 : cps.length - 1 - i2]; + for (var j = 0; j < _cp.segments.length; j++) { + var _seg = _cp.segments[isSrc ? j : _cp.segments.length - 1 - j]; + var lastSeg = i2 === cps.length - 1 && j === _cp.segments.length - 1; + startDist = totalDist; + totalDist += _seg.length; + if (totalDist >= offset || lastSeg) { + selected = { + cp: _cp, + segment: _seg + }; + break; + } + } + if (selected) { + break; + } + } + var cp = selected.cp; + var seg = selected.segment; + var tSegment = (offset - startDist) / seg.length; + var segDt = seg.t1 - seg.t0; + var t = isSrc ? seg.t0 + segDt * tSegment : seg.t1 - segDt * tSegment; + t = bound(0, t, 1); + p2 = qbezierPtAt(cp.p0, cp.p1, cp.p2, t); + angle = bezierAngle(cp.p0, cp.p1, cp.p2, t); + break; + } + case "straight": + case "segments": + case "haystack": { + var d = 0, di, d0; + var p0, p1; + var l = rs.allpts.length; + for (var _i2 = 0; _i2 + 3 < l; _i2 += 2) { + if (isSrc) { + p0 = { + x: rs.allpts[_i2], + y: rs.allpts[_i2 + 1] + }; + p1 = { + x: rs.allpts[_i2 + 2], + y: rs.allpts[_i2 + 3] + }; + } else { + p0 = { + x: rs.allpts[l - 2 - _i2], + y: rs.allpts[l - 1 - _i2] + }; + p1 = { + x: rs.allpts[l - 4 - _i2], + y: rs.allpts[l - 3 - _i2] + }; + } + di = dist(p0, p1); + d0 = d; + d += di; + if (d >= offset) { + break; + } + } + var pD = offset - d0; + var _t = pD / di; + _t = bound(0, _t, 1); + p2 = lineAt(p0, p1, _t); + angle = lineAngle(p0, p1); + break; + } + } + setRs("labelX", prefix, p2.x); + setRs("labelY", prefix, p2.y); + setRs("labelAutoAngle", prefix, angle); + }; + calculateEndProjection("source"); + calculateEndProjection("target"); + this.applyLabelDimensions(edge); + }; + BRp$9.applyLabelDimensions = function(ele) { + this.applyPrefixedLabelDimensions(ele); + if (ele.isEdge()) { + this.applyPrefixedLabelDimensions(ele, "source"); + this.applyPrefixedLabelDimensions(ele, "target"); + } + }; + BRp$9.applyPrefixedLabelDimensions = function(ele, prefix) { + var _p = ele._private; + var text = this.getLabelText(ele, prefix); + var labelDims = this.calculateLabelDimensions(ele, text); + var lineHeight = ele.pstyle("line-height").pfValue; + var textWrap = ele.pstyle("text-wrap").strValue; + var lines = getPrefixedProperty(_p.rscratch, "labelWrapCachedLines", prefix) || []; + var numLines = textWrap !== "wrap" ? 1 : Math.max(lines.length, 1); + var normPerLineHeight = labelDims.height / numLines; + var labelLineHeight = normPerLineHeight * lineHeight; + var width = labelDims.width; + var height = labelDims.height + (numLines - 1) * (lineHeight - 1) * normPerLineHeight; + setPrefixedProperty(_p.rstyle, "labelWidth", prefix, width); + setPrefixedProperty(_p.rscratch, "labelWidth", prefix, width); + setPrefixedProperty(_p.rstyle, "labelHeight", prefix, height); + setPrefixedProperty(_p.rscratch, "labelHeight", prefix, height); + setPrefixedProperty(_p.rscratch, "labelLineHeight", prefix, labelLineHeight); + }; + BRp$9.getLabelText = function(ele, prefix) { + var _p = ele._private; + var pfd = prefix ? prefix + "-" : ""; + var text = ele.pstyle(pfd + "label").strValue; + var textTransform = ele.pstyle("text-transform").value; + var rscratch = function rscratch2(propName, value) { + if (value) { + setPrefixedProperty(_p.rscratch, propName, prefix, value); + return value; + } else { + return getPrefixedProperty(_p.rscratch, propName, prefix); + } + }; + if (!text) { + return ""; + } + if (textTransform == "none") + ; + else if (textTransform == "uppercase") { + text = text.toUpperCase(); + } else if (textTransform == "lowercase") { + text = text.toLowerCase(); + } + var wrapStyle = ele.pstyle("text-wrap").value; + if (wrapStyle === "wrap") { + var labelKey = rscratch("labelKey"); + if (labelKey != null && rscratch("labelWrapKey") === labelKey) { + return rscratch("labelWrapCachedText"); + } + var zwsp = "​"; + var lines = text.split("\n"); + var maxW = ele.pstyle("text-max-width").pfValue; + var overflow = ele.pstyle("text-overflow-wrap").value; + var overflowAny = overflow === "anywhere"; + var wrappedLines = []; + var wordsRegex = /[\s\u200b]+/; + var wordSeparator = overflowAny ? "" : " "; + for (var l = 0; l < lines.length; l++) { + var line = lines[l]; + var lineDims = this.calculateLabelDimensions(ele, line); + var lineW = lineDims.width; + if (overflowAny) { + var processedLine = line.split("").join(zwsp); + line = processedLine; + } + if (lineW > maxW) { + var words = line.split(wordsRegex); + var subline = ""; + for (var w = 0; w < words.length; w++) { + var word = words[w]; + var testLine = subline.length === 0 ? word : subline + wordSeparator + word; + var testDims = this.calculateLabelDimensions(ele, testLine); + var testW = testDims.width; + if (testW <= maxW) { + subline += word + wordSeparator; + } else { + if (subline) { + wrappedLines.push(subline); + } + subline = word + wordSeparator; + } + } + if (!subline.match(/^[\s\u200b]+$/)) { + wrappedLines.push(subline); + } + } else { + wrappedLines.push(line); + } + } + rscratch("labelWrapCachedLines", wrappedLines); + text = rscratch("labelWrapCachedText", wrappedLines.join("\n")); + rscratch("labelWrapKey", labelKey); + } else if (wrapStyle === "ellipsis") { + var _maxW = ele.pstyle("text-max-width").pfValue; + var ellipsized = ""; + var ellipsis = "…"; + var incLastCh = false; + if (this.calculateLabelDimensions(ele, text).width < _maxW) { + return text; + } + for (var i2 = 0; i2 < text.length; i2++) { + var widthWithNextCh = this.calculateLabelDimensions(ele, ellipsized + text[i2] + ellipsis).width; + if (widthWithNextCh > _maxW) { + break; + } + ellipsized += text[i2]; + if (i2 === text.length - 1) { + incLastCh = true; + } + } + if (!incLastCh) { + ellipsized += ellipsis; + } + return ellipsized; + } + return text; + }; + BRp$9.getLabelJustification = function(ele) { + var justification = ele.pstyle("text-justification").strValue; + var textHalign = ele.pstyle("text-halign").strValue; + if (justification === "auto") { + if (ele.isNode()) { + switch (textHalign) { + case "left": + return "right"; + case "right": + return "left"; + default: + return "center"; + } + } else { + return "center"; + } + } else { + return justification; + } + }; + BRp$9.calculateLabelDimensions = function(ele, text) { + var r = this; + var cacheKey = hashString(text, ele._private.labelDimsKey); + var cache2 = r.labelDimCache || (r.labelDimCache = []); + var existingVal = cache2[cacheKey]; + if (existingVal != null) { + return existingVal; + } + var padding = 0; + var fStyle = ele.pstyle("font-style").strValue; + var size = ele.pstyle("font-size").pfValue; + var family = ele.pstyle("font-family").strValue; + var weight = ele.pstyle("font-weight").strValue; + var canvas = this.labelCalcCanvas; + var c2d = this.labelCalcCanvasContext; + if (!canvas) { + canvas = this.labelCalcCanvas = document.createElement("canvas"); + c2d = this.labelCalcCanvasContext = canvas.getContext("2d"); + var ds = canvas.style; + ds.position = "absolute"; + ds.left = "-9999px"; + ds.top = "-9999px"; + ds.zIndex = "-1"; + ds.visibility = "hidden"; + ds.pointerEvents = "none"; + } + c2d.font = "".concat(fStyle, " ").concat(weight, " ").concat(size, "px ").concat(family); + var width = 0; + var height = 0; + var lines = text.split("\n"); + for (var i2 = 0; i2 < lines.length; i2++) { + var line = lines[i2]; + var metrics = c2d.measureText(line); + var w = Math.ceil(metrics.width); + var h = size; + width = Math.max(w, width); + height += h; + } + width += padding; + height += padding; + return cache2[cacheKey] = { + width, + height + }; + }; + BRp$9.calculateLabelAngle = function(ele, prefix) { + var _p = ele._private; + var rs = _p.rscratch; + var isEdge = ele.isEdge(); + var prefixDash = prefix ? prefix + "-" : ""; + var rot = ele.pstyle(prefixDash + "text-rotation"); + var rotStr = rot.strValue; + if (rotStr === "none") { + return 0; + } else if (isEdge && rotStr === "autorotate") { + return rs.labelAutoAngle; + } else if (rotStr === "autorotate") { + return 0; + } else { + return rot.pfValue; + } + }; + BRp$9.calculateLabelAngles = function(ele) { + var r = this; + var isEdge = ele.isEdge(); + var _p = ele._private; + var rs = _p.rscratch; + rs.labelAngle = r.calculateLabelAngle(ele); + if (isEdge) { + rs.sourceLabelAngle = r.calculateLabelAngle(ele, "source"); + rs.targetLabelAngle = r.calculateLabelAngle(ele, "target"); + } + }; + var BRp$8 = {}; + var TOO_SMALL_CUT_RECT = 28; + var warnedCutRect = false; + BRp$8.getNodeShape = function(node) { + var r = this; + var shape = node.pstyle("shape").value; + if (shape === "cutrectangle" && (node.width() < TOO_SMALL_CUT_RECT || node.height() < TOO_SMALL_CUT_RECT)) { + if (!warnedCutRect) { + warn("The `cutrectangle` node shape can not be used at small sizes so `rectangle` is used instead"); + warnedCutRect = true; + } + return "rectangle"; + } + if (node.isParent()) { + if (shape === "rectangle" || shape === "roundrectangle" || shape === "round-rectangle" || shape === "cutrectangle" || shape === "cut-rectangle" || shape === "barrel") { + return shape; + } else { + return "rectangle"; + } + } + if (shape === "polygon") { + var points = node.pstyle("shape-polygon-points").value; + return r.nodeShapes.makePolygon(points).name; + } + return shape; + }; + var BRp$7 = {}; + BRp$7.registerCalculationListeners = function() { + var cy = this.cy; + var elesToUpdate = cy.collection(); + var r = this; + var enqueue = function enqueue2(eles) { + var dirtyStyleCaches = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : true; + elesToUpdate.merge(eles); + if (dirtyStyleCaches) { + for (var i2 = 0; i2 < eles.length; i2++) { + var ele = eles[i2]; + var _p = ele._private; + var rstyle = _p.rstyle; + rstyle.clean = false; + rstyle.cleanConnected = false; + } + } + }; + r.binder(cy).on("bounds.* dirty.*", function onDirtyBounds(e) { + var ele = e.target; + enqueue(ele); + }).on("style.* background.*", function onDirtyStyle(e) { + var ele = e.target; + enqueue(ele, false); + }); + var updateEleCalcs = function updateEleCalcs2(willDraw) { + if (willDraw) { + var fns = r.onUpdateEleCalcsFns; + elesToUpdate.cleanStyle(); + for (var i2 = 0; i2 < elesToUpdate.length; i2++) { + var ele = elesToUpdate[i2]; + var rstyle = ele._private.rstyle; + if (ele.isNode() && !rstyle.cleanConnected) { + enqueue(ele.connectedEdges()); + rstyle.cleanConnected = true; + } + } + if (fns) { + for (var _i = 0; _i < fns.length; _i++) { + var fn2 = fns[_i]; + fn2(willDraw, elesToUpdate); + } + } + r.recalculateRenderedStyle(elesToUpdate); + elesToUpdate = cy.collection(); + } + }; + r.flushRenderedStyleQueue = function() { + updateEleCalcs(true); + }; + r.beforeRender(updateEleCalcs, r.beforeRenderPriorities.eleCalcs); + }; + BRp$7.onUpdateEleCalcs = function(fn2) { + var fns = this.onUpdateEleCalcsFns = this.onUpdateEleCalcsFns || []; + fns.push(fn2); + }; + BRp$7.recalculateRenderedStyle = function(eles, useCache) { + var isCleanConnected = function isCleanConnected2(ele2) { + return ele2._private.rstyle.cleanConnected; + }; + var edges = []; + var nodes2 = []; + if (this.destroyed) { + return; + } + if (useCache === void 0) { + useCache = true; + } + for (var i2 = 0; i2 < eles.length; i2++) { + var ele = eles[i2]; + var _p = ele._private; + var rstyle = _p.rstyle; + if (ele.isEdge() && (!isCleanConnected(ele.source()) || !isCleanConnected(ele.target()))) { + rstyle.clean = false; + } + if (useCache && rstyle.clean || ele.removed()) { + continue; + } + if (ele.pstyle("display").value === "none") { + continue; + } + if (_p.group === "nodes") { + nodes2.push(ele); + } else { + edges.push(ele); + } + rstyle.clean = true; + } + for (var _i2 = 0; _i2 < nodes2.length; _i2++) { + var _ele = nodes2[_i2]; + var _p2 = _ele._private; + var _rstyle = _p2.rstyle; + var pos = _ele.position(); + this.recalculateNodeLabelProjection(_ele); + _rstyle.nodeX = pos.x; + _rstyle.nodeY = pos.y; + _rstyle.nodeW = _ele.pstyle("width").pfValue; + _rstyle.nodeH = _ele.pstyle("height").pfValue; + } + this.recalculateEdgeProjections(edges); + for (var _i3 = 0; _i3 < edges.length; _i3++) { + var _ele2 = edges[_i3]; + var _p3 = _ele2._private; + var _rstyle2 = _p3.rstyle; + var rs = _p3.rscratch; + _rstyle2.srcX = rs.arrowStartX; + _rstyle2.srcY = rs.arrowStartY; + _rstyle2.tgtX = rs.arrowEndX; + _rstyle2.tgtY = rs.arrowEndY; + _rstyle2.midX = rs.midX; + _rstyle2.midY = rs.midY; + _rstyle2.labelAngle = rs.labelAngle; + _rstyle2.sourceLabelAngle = rs.sourceLabelAngle; + _rstyle2.targetLabelAngle = rs.targetLabelAngle; + } + }; + var BRp$6 = {}; + BRp$6.updateCachedGrabbedEles = function() { + var eles = this.cachedZSortedEles; + if (!eles) { + return; + } + eles.drag = []; + eles.nondrag = []; + var grabTargets = []; + for (var i2 = 0; i2 < eles.length; i2++) { + var ele = eles[i2]; + var rs = ele._private.rscratch; + if (ele.grabbed() && !ele.isParent()) { + grabTargets.push(ele); + } else if (rs.inDragLayer) { + eles.drag.push(ele); + } else { + eles.nondrag.push(ele); + } + } + for (var i2 = 0; i2 < grabTargets.length; i2++) { + var ele = grabTargets[i2]; + eles.drag.push(ele); + } + }; + BRp$6.invalidateCachedZSortedEles = function() { + this.cachedZSortedEles = null; + }; + BRp$6.getCachedZSortedEles = function(forceRecalc) { + if (forceRecalc || !this.cachedZSortedEles) { + var eles = this.cy.mutableElements().toArray(); + eles.sort(zIndexSort); + eles.interactive = eles.filter(function(ele) { + return ele.interactive(); + }); + this.cachedZSortedEles = eles; + this.updateCachedGrabbedEles(); + } else { + eles = this.cachedZSortedEles; + } + return eles; + }; + var BRp$5 = {}; + [BRp$e, BRp$d, BRp$c, BRp$b, BRp$a, BRp$9, BRp$8, BRp$7, BRp$6].forEach(function(props) { + extend(BRp$5, props); + }); + var BRp$4 = {}; + BRp$4.getCachedImage = function(url, crossOrigin, onLoad) { + var r = this; + var imageCache = r.imageCache = r.imageCache || {}; + var cache2 = imageCache[url]; + if (cache2) { + if (!cache2.image.complete) { + cache2.image.addEventListener("load", onLoad); + } + return cache2.image; + } else { + cache2 = imageCache[url] = imageCache[url] || {}; + var image = cache2.image = new Image(); + image.addEventListener("load", onLoad); + image.addEventListener("error", function() { + image.error = true; + }); + var dataUriPrefix = "data:"; + var isDataUri = url.substring(0, dataUriPrefix.length).toLowerCase() === dataUriPrefix; + if (!isDataUri) { + crossOrigin = crossOrigin === "null" ? null : crossOrigin; + image.crossOrigin = crossOrigin; + } + image.src = url; + return image; + } + }; + var BRp$3 = {}; + BRp$3.registerBinding = function(target, event2, handler, useCapture) { + var args = Array.prototype.slice.apply(arguments, [1]); + var b = this.binder(target); + return b.on.apply(b, args); + }; + BRp$3.binder = function(tgt) { + var r = this; + var containerWindow = r.cy.window(); + var tgtIsDom = tgt === containerWindow || tgt === containerWindow.document || tgt === containerWindow.document.body || domElement(tgt); + if (r.supportsPassiveEvents == null) { + var supportsPassive = false; + try { + var opts = Object.defineProperty({}, "passive", { + get: function get2() { + supportsPassive = true; + return true; + } + }); + containerWindow.addEventListener("test", null, opts); + } catch (err) { + } + r.supportsPassiveEvents = supportsPassive; + } + var on = function on2(event2, handler, useCapture) { + var args = Array.prototype.slice.call(arguments); + if (tgtIsDom && r.supportsPassiveEvents) { + args[2] = { + capture: useCapture != null ? useCapture : false, + passive: false, + once: false + }; + } + r.bindings.push({ + target: tgt, + args + }); + (tgt.addEventListener || tgt.on).apply(tgt, args); + return this; + }; + return { + on, + addEventListener: on, + addListener: on, + bind: on + }; + }; + BRp$3.nodeIsDraggable = function(node) { + return node && node.isNode() && !node.locked() && node.grabbable(); + }; + BRp$3.nodeIsGrabbable = function(node) { + return this.nodeIsDraggable(node) && node.interactive(); + }; + BRp$3.load = function() { + var r = this; + var containerWindow = r.cy.window(); + var isSelected = function isSelected2(ele) { + return ele.selected(); + }; + var triggerEvents = function triggerEvents2(target, names, e, position2) { + if (target == null) { + target = r.cy; + } + for (var i2 = 0; i2 < names.length; i2++) { + var name = names[i2]; + target.emit({ + originalEvent: e, + type: name, + position: position2 + }); + } + }; + var isMultSelKeyDown = function isMultSelKeyDown2(e) { + return e.shiftKey || e.metaKey || e.ctrlKey; + }; + var allowPanningPassthrough = function allowPanningPassthrough2(down, downs) { + var allowPassthrough = true; + if (r.cy.hasCompoundNodes() && down && down.pannable()) { + for (var i2 = 0; downs && i2 < downs.length; i2++) { + var down = downs[i2]; + if (down.isNode() && down.isParent() && !down.pannable()) { + allowPassthrough = false; + break; + } + } + } else { + allowPassthrough = true; + } + return allowPassthrough; + }; + var setGrabbed = function setGrabbed2(ele) { + ele[0]._private.grabbed = true; + }; + var setFreed = function setFreed2(ele) { + ele[0]._private.grabbed = false; + }; + var setInDragLayer = function setInDragLayer2(ele) { + ele[0]._private.rscratch.inDragLayer = true; + }; + var setOutDragLayer = function setOutDragLayer2(ele) { + ele[0]._private.rscratch.inDragLayer = false; + }; + var setGrabTarget = function setGrabTarget2(ele) { + ele[0]._private.rscratch.isGrabTarget = true; + }; + var removeGrabTarget = function removeGrabTarget2(ele) { + ele[0]._private.rscratch.isGrabTarget = false; + }; + var addToDragList = function addToDragList2(ele, opts) { + var list = opts.addToList; + var listHasEle = list.has(ele); + if (!listHasEle && ele.grabbable() && !ele.locked()) { + list.merge(ele); + setGrabbed(ele); + } + }; + var addDescendantsToDrag = function addDescendantsToDrag2(node, opts) { + if (!node.cy().hasCompoundNodes()) { + return; + } + if (opts.inDragLayer == null && opts.addToList == null) { + return; + } + var innerNodes = node.descendants(); + if (opts.inDragLayer) { + innerNodes.forEach(setInDragLayer); + innerNodes.connectedEdges().forEach(setInDragLayer); + } + if (opts.addToList) { + addToDragList(innerNodes, opts); + } + }; + var addNodesToDrag = function addNodesToDrag2(nodes2, opts) { + opts = opts || {}; + var hasCompoundNodes = nodes2.cy().hasCompoundNodes(); + if (opts.inDragLayer) { + nodes2.forEach(setInDragLayer); + nodes2.neighborhood().stdFilter(function(ele) { + return !hasCompoundNodes || ele.isEdge(); + }).forEach(setInDragLayer); + } + if (opts.addToList) { + nodes2.forEach(function(ele) { + addToDragList(ele, opts); + }); + } + addDescendantsToDrag(nodes2, opts); + updateAncestorsInDragLayer(nodes2, { + inDragLayer: opts.inDragLayer + }); + r.updateCachedGrabbedEles(); + }; + var addNodeToDrag = addNodesToDrag; + var freeDraggedElements = function freeDraggedElements2(grabbedEles) { + if (!grabbedEles) { + return; + } + r.getCachedZSortedEles().forEach(function(ele) { + setFreed(ele); + setOutDragLayer(ele); + removeGrabTarget(ele); + }); + r.updateCachedGrabbedEles(); + }; + var updateAncestorsInDragLayer = function updateAncestorsInDragLayer2(node, opts) { + if (opts.inDragLayer == null && opts.addToList == null) { + return; + } + if (!node.cy().hasCompoundNodes()) { + return; + } + var parent = node.ancestors().orphans(); + if (parent.same(node)) { + return; + } + var nodes2 = parent.descendants().spawnSelf().merge(parent).unmerge(node).unmerge(node.descendants()); + var edges = nodes2.connectedEdges(); + if (opts.inDragLayer) { + edges.forEach(setInDragLayer); + nodes2.forEach(setInDragLayer); + } + if (opts.addToList) { + nodes2.forEach(function(ele) { + addToDragList(ele, opts); + }); + } + }; + var blurActiveDomElement = function blurActiveDomElement2() { + if (document.activeElement != null && document.activeElement.blur != null) { + document.activeElement.blur(); + } + }; + var haveMutationsApi = typeof MutationObserver !== "undefined"; + var haveResizeObserverApi = typeof ResizeObserver !== "undefined"; + if (haveMutationsApi) { + r.removeObserver = new MutationObserver(function(mutns) { + for (var i2 = 0; i2 < mutns.length; i2++) { + var mutn = mutns[i2]; + var rNodes = mutn.removedNodes; + if (rNodes) { + for (var j = 0; j < rNodes.length; j++) { + var rNode = rNodes[j]; + if (rNode === r.container) { + r.destroy(); + break; + } + } + } + } + }); + if (r.container.parentNode) { + r.removeObserver.observe(r.container.parentNode, { + childList: true + }); + } + } else { + r.registerBinding(r.container, "DOMNodeRemoved", function(e) { + r.destroy(); + }); + } + var onResize = debounce_1(function() { + r.cy.resize(); + }, 100); + if (haveMutationsApi) { + r.styleObserver = new MutationObserver(onResize); + r.styleObserver.observe(r.container, { + attributes: true + }); + } + r.registerBinding(containerWindow, "resize", onResize); + if (haveResizeObserverApi) { + r.resizeObserver = new ResizeObserver(onResize); + r.resizeObserver.observe(r.container); + } + var forEachUp = function forEachUp2(domEle, fn2) { + while (domEle != null) { + fn2(domEle); + domEle = domEle.parentNode; + } + }; + var invalidateCoords = function invalidateCoords2() { + r.invalidateContainerClientCoordsCache(); + }; + forEachUp(r.container, function(domEle) { + r.registerBinding(domEle, "transitionend", invalidateCoords); + r.registerBinding(domEle, "animationend", invalidateCoords); + r.registerBinding(domEle, "scroll", invalidateCoords); + }); + r.registerBinding(r.container, "contextmenu", function(e) { + e.preventDefault(); + }); + var inBoxSelection = function inBoxSelection2() { + return r.selection[4] !== 0; + }; + var eventInContainer = function eventInContainer2(e) { + var containerPageCoords = r.findContainerClientCoords(); + var x = containerPageCoords[0]; + var y = containerPageCoords[1]; + var width = containerPageCoords[2]; + var height = containerPageCoords[3]; + var positions = e.touches ? e.touches : [e]; + var atLeastOnePosInside = false; + for (var i2 = 0; i2 < positions.length; i2++) { + var p2 = positions[i2]; + if (x <= p2.clientX && p2.clientX <= x + width && y <= p2.clientY && p2.clientY <= y + height) { + atLeastOnePosInside = true; + break; + } + } + if (!atLeastOnePosInside) { + return false; + } + var container = r.container; + var target = e.target; + var tParent = target.parentNode; + var containerIsTarget = false; + while (tParent) { + if (tParent === container) { + containerIsTarget = true; + break; + } + tParent = tParent.parentNode; + } + if (!containerIsTarget) { + return false; + } + return true; + }; + r.registerBinding(r.container, "mousedown", function mousedownHandler(e) { + if (!eventInContainer(e)) { + return; + } + e.preventDefault(); + blurActiveDomElement(); + r.hoverData.capture = true; + r.hoverData.which = e.which; + var cy = r.cy; + var gpos = [e.clientX, e.clientY]; + var pos = r.projectIntoViewport(gpos[0], gpos[1]); + var select = r.selection; + var nears = r.findNearestElements(pos[0], pos[1], true, false); + var near = nears[0]; + var draggedElements = r.dragData.possibleDragElements; + r.hoverData.mdownPos = pos; + r.hoverData.mdownGPos = gpos; + var checkForTaphold = function checkForTaphold2() { + r.hoverData.tapholdCancelled = false; + clearTimeout(r.hoverData.tapholdTimeout); + r.hoverData.tapholdTimeout = setTimeout(function() { + if (r.hoverData.tapholdCancelled) { + return; + } else { + var ele = r.hoverData.down; + if (ele) { + ele.emit({ + originalEvent: e, + type: "taphold", + position: { + x: pos[0], + y: pos[1] + } + }); + } else { + cy.emit({ + originalEvent: e, + type: "taphold", + position: { + x: pos[0], + y: pos[1] + } + }); + } + } + }, r.tapholdDuration); + }; + if (e.which == 3) { + r.hoverData.cxtStarted = true; + var cxtEvt = { + originalEvent: e, + type: "cxttapstart", + position: { + x: pos[0], + y: pos[1] + } + }; + if (near) { + near.activate(); + near.emit(cxtEvt); + r.hoverData.down = near; + } else { + cy.emit(cxtEvt); + } + r.hoverData.downTime = (/* @__PURE__ */ new Date()).getTime(); + r.hoverData.cxtDragged = false; + } else if (e.which == 1) { + if (near) { + near.activate(); + } + { + if (near != null) { + if (r.nodeIsGrabbable(near)) { + var makeEvent = function makeEvent2(type) { + return { + originalEvent: e, + type, + position: { + x: pos[0], + y: pos[1] + } + }; + }; + var triggerGrab = function triggerGrab2(ele) { + ele.emit(makeEvent("grab")); + }; + setGrabTarget(near); + if (!near.selected()) { + draggedElements = r.dragData.possibleDragElements = cy.collection(); + addNodeToDrag(near, { + addToList: draggedElements + }); + near.emit(makeEvent("grabon")).emit(makeEvent("grab")); + } else { + draggedElements = r.dragData.possibleDragElements = cy.collection(); + var selectedNodes = cy.$(function(ele) { + return ele.isNode() && ele.selected() && r.nodeIsGrabbable(ele); + }); + addNodesToDrag(selectedNodes, { + addToList: draggedElements + }); + near.emit(makeEvent("grabon")); + selectedNodes.forEach(triggerGrab); + } + r.redrawHint("eles", true); + r.redrawHint("drag", true); + } + } + r.hoverData.down = near; + r.hoverData.downs = nears; + r.hoverData.downTime = (/* @__PURE__ */ new Date()).getTime(); + } + triggerEvents(near, ["mousedown", "tapstart", "vmousedown"], e, { + x: pos[0], + y: pos[1] + }); + if (near == null) { + select[4] = 1; + r.data.bgActivePosistion = { + x: pos[0], + y: pos[1] + }; + r.redrawHint("select", true); + r.redraw(); + } else if (near.pannable()) { + select[4] = 1; + } + checkForTaphold(); + } + select[0] = select[2] = pos[0]; + select[1] = select[3] = pos[1]; + }, false); + r.registerBinding(containerWindow, "mousemove", function mousemoveHandler(e) { + var capture = r.hoverData.capture; + if (!capture && !eventInContainer(e)) { + return; + } + var preventDefault = false; + var cy = r.cy; + var zoom = cy.zoom(); + var gpos = [e.clientX, e.clientY]; + var pos = r.projectIntoViewport(gpos[0], gpos[1]); + var mdownPos = r.hoverData.mdownPos; + var mdownGPos = r.hoverData.mdownGPos; + var select = r.selection; + var near = null; + if (!r.hoverData.draggingEles && !r.hoverData.dragging && !r.hoverData.selecting) { + near = r.findNearestElement(pos[0], pos[1], true, false); + } + var last = r.hoverData.last; + var down = r.hoverData.down; + var disp = [pos[0] - select[2], pos[1] - select[3]]; + var draggedElements = r.dragData.possibleDragElements; + var isOverThresholdDrag; + if (mdownGPos) { + var dx = gpos[0] - mdownGPos[0]; + var dx2 = dx * dx; + var dy = gpos[1] - mdownGPos[1]; + var dy2 = dy * dy; + var dist2 = dx2 + dy2; + r.hoverData.isOverThresholdDrag = isOverThresholdDrag = dist2 >= r.desktopTapThreshold2; + } + var multSelKeyDown = isMultSelKeyDown(e); + if (isOverThresholdDrag) { + r.hoverData.tapholdCancelled = true; + } + var updateDragDelta = function updateDragDelta2() { + var dragDelta2 = r.hoverData.dragDelta = r.hoverData.dragDelta || []; + if (dragDelta2.length === 0) { + dragDelta2.push(disp[0]); + dragDelta2.push(disp[1]); + } else { + dragDelta2[0] += disp[0]; + dragDelta2[1] += disp[1]; + } + }; + preventDefault = true; + triggerEvents(near, ["mousemove", "vmousemove", "tapdrag"], e, { + x: pos[0], + y: pos[1] + }); + var goIntoBoxMode = function goIntoBoxMode2() { + r.data.bgActivePosistion = void 0; + if (!r.hoverData.selecting) { + cy.emit({ + originalEvent: e, + type: "boxstart", + position: { + x: pos[0], + y: pos[1] + } + }); + } + select[4] = 1; + r.hoverData.selecting = true; + r.redrawHint("select", true); + r.redraw(); + }; + if (r.hoverData.which === 3) { + if (isOverThresholdDrag) { + var cxtEvt = { + originalEvent: e, + type: "cxtdrag", + position: { + x: pos[0], + y: pos[1] + } + }; + if (down) { + down.emit(cxtEvt); + } else { + cy.emit(cxtEvt); + } + r.hoverData.cxtDragged = true; + if (!r.hoverData.cxtOver || near !== r.hoverData.cxtOver) { + if (r.hoverData.cxtOver) { + r.hoverData.cxtOver.emit({ + originalEvent: e, + type: "cxtdragout", + position: { + x: pos[0], + y: pos[1] + } + }); + } + r.hoverData.cxtOver = near; + if (near) { + near.emit({ + originalEvent: e, + type: "cxtdragover", + position: { + x: pos[0], + y: pos[1] + } + }); + } + } + } + } else if (r.hoverData.dragging) { + preventDefault = true; + if (cy.panningEnabled() && cy.userPanningEnabled()) { + var deltaP; + if (r.hoverData.justStartedPan) { + var mdPos = r.hoverData.mdownPos; + deltaP = { + x: (pos[0] - mdPos[0]) * zoom, + y: (pos[1] - mdPos[1]) * zoom + }; + r.hoverData.justStartedPan = false; + } else { + deltaP = { + x: disp[0] * zoom, + y: disp[1] * zoom + }; + } + cy.panBy(deltaP); + cy.emit("dragpan"); + r.hoverData.dragged = true; + } + pos = r.projectIntoViewport(e.clientX, e.clientY); + } else if (select[4] == 1 && (down == null || down.pannable())) { + if (isOverThresholdDrag) { + if (!r.hoverData.dragging && cy.boxSelectionEnabled() && (multSelKeyDown || !cy.panningEnabled() || !cy.userPanningEnabled())) { + goIntoBoxMode(); + } else if (!r.hoverData.selecting && cy.panningEnabled() && cy.userPanningEnabled()) { + var allowPassthrough = allowPanningPassthrough(down, r.hoverData.downs); + if (allowPassthrough) { + r.hoverData.dragging = true; + r.hoverData.justStartedPan = true; + select[4] = 0; + r.data.bgActivePosistion = array2point(mdownPos); + r.redrawHint("select", true); + r.redraw(); + } + } + if (down && down.pannable() && down.active()) { + down.unactivate(); + } + } + } else { + if (down && down.pannable() && down.active()) { + down.unactivate(); + } + if ((!down || !down.grabbed()) && near != last) { + if (last) { + triggerEvents(last, ["mouseout", "tapdragout"], e, { + x: pos[0], + y: pos[1] + }); + } + if (near) { + triggerEvents(near, ["mouseover", "tapdragover"], e, { + x: pos[0], + y: pos[1] + }); + } + r.hoverData.last = near; + } + if (down) { + if (isOverThresholdDrag) { + if (cy.boxSelectionEnabled() && multSelKeyDown) { + if (down && down.grabbed()) { + freeDraggedElements(draggedElements); + down.emit("freeon"); + draggedElements.emit("free"); + if (r.dragData.didDrag) { + down.emit("dragfreeon"); + draggedElements.emit("dragfree"); + } + } + goIntoBoxMode(); + } else if (down && down.grabbed() && r.nodeIsDraggable(down)) { + var justStartedDrag = !r.dragData.didDrag; + if (justStartedDrag) { + r.redrawHint("eles", true); + } + r.dragData.didDrag = true; + if (!r.hoverData.draggingEles) { + addNodesToDrag(draggedElements, { + inDragLayer: true + }); + } + var totalShift = { + x: 0, + y: 0 + }; + if (number$1(disp[0]) && number$1(disp[1])) { + totalShift.x += disp[0]; + totalShift.y += disp[1]; + if (justStartedDrag) { + var dragDelta = r.hoverData.dragDelta; + if (dragDelta && number$1(dragDelta[0]) && number$1(dragDelta[1])) { + totalShift.x += dragDelta[0]; + totalShift.y += dragDelta[1]; + } + } + } + r.hoverData.draggingEles = true; + draggedElements.silentShift(totalShift).emit("position drag"); + r.redrawHint("drag", true); + r.redraw(); + } + } else { + updateDragDelta(); + } + } + preventDefault = true; + } + select[2] = pos[0]; + select[3] = pos[1]; + if (preventDefault) { + if (e.stopPropagation) + e.stopPropagation(); + if (e.preventDefault) + e.preventDefault(); + return false; + } + }, false); + var clickTimeout, didDoubleClick, prevClickTimeStamp; + r.registerBinding(containerWindow, "mouseup", function mouseupHandler(e) { + var capture = r.hoverData.capture; + if (!capture) { + return; + } + r.hoverData.capture = false; + var cy = r.cy; + var pos = r.projectIntoViewport(e.clientX, e.clientY); + var select = r.selection; + var near = r.findNearestElement(pos[0], pos[1], true, false); + var draggedElements = r.dragData.possibleDragElements; + var down = r.hoverData.down; + var multSelKeyDown = isMultSelKeyDown(e); + if (r.data.bgActivePosistion) { + r.redrawHint("select", true); + r.redraw(); + } + r.hoverData.tapholdCancelled = true; + r.data.bgActivePosistion = void 0; + if (down) { + down.unactivate(); + } + if (r.hoverData.which === 3) { + var cxtEvt = { + originalEvent: e, + type: "cxttapend", + position: { + x: pos[0], + y: pos[1] + } + }; + if (down) { + down.emit(cxtEvt); + } else { + cy.emit(cxtEvt); + } + if (!r.hoverData.cxtDragged) { + var cxtTap = { + originalEvent: e, + type: "cxttap", + position: { + x: pos[0], + y: pos[1] + } + }; + if (down) { + down.emit(cxtTap); + } else { + cy.emit(cxtTap); + } + } + r.hoverData.cxtDragged = false; + r.hoverData.which = null; + } else if (r.hoverData.which === 1) { + triggerEvents(near, ["mouseup", "tapend", "vmouseup"], e, { + x: pos[0], + y: pos[1] + }); + if (!r.dragData.didDrag && // didn't move a node around + !r.hoverData.dragged && // didn't pan + !r.hoverData.selecting && // not box selection + !r.hoverData.isOverThresholdDrag) { + triggerEvents(down, ["click", "tap", "vclick"], e, { + x: pos[0], + y: pos[1] + }); + didDoubleClick = false; + if (e.timeStamp - prevClickTimeStamp <= cy.multiClickDebounceTime()) { + clickTimeout && clearTimeout(clickTimeout); + didDoubleClick = true; + prevClickTimeStamp = null; + triggerEvents(down, ["dblclick", "dbltap", "vdblclick"], e, { + x: pos[0], + y: pos[1] + }); + } else { + clickTimeout = setTimeout(function() { + if (didDoubleClick) + return; + triggerEvents(down, ["oneclick", "onetap", "voneclick"], e, { + x: pos[0], + y: pos[1] + }); + }, cy.multiClickDebounceTime()); + prevClickTimeStamp = e.timeStamp; + } + } + if (down == null && !r.dragData.didDrag && !r.hoverData.selecting && !r.hoverData.dragged && !isMultSelKeyDown(e)) { + cy.$(isSelected).unselect(["tapunselect"]); + if (draggedElements.length > 0) { + r.redrawHint("eles", true); + } + r.dragData.possibleDragElements = draggedElements = cy.collection(); + } + if (near == down && !r.dragData.didDrag && !r.hoverData.selecting) { + if (near != null && near._private.selectable) { + if (r.hoverData.dragging) + ; + else if (cy.selectionType() === "additive" || multSelKeyDown) { + if (near.selected()) { + near.unselect(["tapunselect"]); + } else { + near.select(["tapselect"]); + } + } else { + if (!multSelKeyDown) { + cy.$(isSelected).unmerge(near).unselect(["tapunselect"]); + near.select(["tapselect"]); + } + } + r.redrawHint("eles", true); + } + } + if (r.hoverData.selecting) { + var box = cy.collection(r.getAllInBox(select[0], select[1], select[2], select[3])); + r.redrawHint("select", true); + if (box.length > 0) { + r.redrawHint("eles", true); + } + cy.emit({ + type: "boxend", + originalEvent: e, + position: { + x: pos[0], + y: pos[1] + } + }); + var eleWouldBeSelected = function eleWouldBeSelected2(ele) { + return ele.selectable() && !ele.selected(); + }; + if (cy.selectionType() === "additive") { + box.emit("box").stdFilter(eleWouldBeSelected).select().emit("boxselect"); + } else { + if (!multSelKeyDown) { + cy.$(isSelected).unmerge(box).unselect(); + } + box.emit("box").stdFilter(eleWouldBeSelected).select().emit("boxselect"); + } + r.redraw(); + } + if (r.hoverData.dragging) { + r.hoverData.dragging = false; + r.redrawHint("select", true); + r.redrawHint("eles", true); + r.redraw(); + } + if (!select[4]) { + r.redrawHint("drag", true); + r.redrawHint("eles", true); + var downWasGrabbed = down && down.grabbed(); + freeDraggedElements(draggedElements); + if (downWasGrabbed) { + down.emit("freeon"); + draggedElements.emit("free"); + if (r.dragData.didDrag) { + down.emit("dragfreeon"); + draggedElements.emit("dragfree"); + } + } + } + } + select[4] = 0; + r.hoverData.down = null; + r.hoverData.cxtStarted = false; + r.hoverData.draggingEles = false; + r.hoverData.selecting = false; + r.hoverData.isOverThresholdDrag = false; + r.dragData.didDrag = false; + r.hoverData.dragged = false; + r.hoverData.dragDelta = []; + r.hoverData.mdownPos = null; + r.hoverData.mdownGPos = null; + }, false); + var wheelHandler = function wheelHandler2(e) { + if (r.scrollingPage) { + return; + } + var cy = r.cy; + var zoom = cy.zoom(); + var pan = cy.pan(); + var pos = r.projectIntoViewport(e.clientX, e.clientY); + var rpos = [pos[0] * zoom + pan.x, pos[1] * zoom + pan.y]; + if (r.hoverData.draggingEles || r.hoverData.dragging || r.hoverData.cxtStarted || inBoxSelection()) { + e.preventDefault(); + return; + } + if (cy.panningEnabled() && cy.userPanningEnabled() && cy.zoomingEnabled() && cy.userZoomingEnabled()) { + e.preventDefault(); + r.data.wheelZooming = true; + clearTimeout(r.data.wheelTimeout); + r.data.wheelTimeout = setTimeout(function() { + r.data.wheelZooming = false; + r.redrawHint("eles", true); + r.redraw(); + }, 150); + var diff; + if (e.deltaY != null) { + diff = e.deltaY / -250; + } else if (e.wheelDeltaY != null) { + diff = e.wheelDeltaY / 1e3; + } else { + diff = e.wheelDelta / 1e3; + } + diff = diff * r.wheelSensitivity; + var needsWheelFix = e.deltaMode === 1; + if (needsWheelFix) { + diff *= 33; + } + var newZoom = cy.zoom() * Math.pow(10, diff); + if (e.type === "gesturechange") { + newZoom = r.gestureStartZoom * e.scale; + } + cy.zoom({ + level: newZoom, + renderedPosition: { + x: rpos[0], + y: rpos[1] + } + }); + cy.emit(e.type === "gesturechange" ? "pinchzoom" : "scrollzoom"); + } + }; + r.registerBinding(r.container, "wheel", wheelHandler, true); + r.registerBinding(containerWindow, "scroll", function scrollHandler(e) { + r.scrollingPage = true; + clearTimeout(r.scrollingPageTimeout); + r.scrollingPageTimeout = setTimeout(function() { + r.scrollingPage = false; + }, 250); + }, true); + r.registerBinding(r.container, "gesturestart", function gestureStartHandler(e) { + r.gestureStartZoom = r.cy.zoom(); + if (!r.hasTouchStarted) { + e.preventDefault(); + } + }, true); + r.registerBinding(r.container, "gesturechange", function(e) { + if (!r.hasTouchStarted) { + wheelHandler(e); + } + }, true); + r.registerBinding(r.container, "mouseout", function mouseOutHandler(e) { + var pos = r.projectIntoViewport(e.clientX, e.clientY); + r.cy.emit({ + originalEvent: e, + type: "mouseout", + position: { + x: pos[0], + y: pos[1] + } + }); + }, false); + r.registerBinding(r.container, "mouseover", function mouseOverHandler(e) { + var pos = r.projectIntoViewport(e.clientX, e.clientY); + r.cy.emit({ + originalEvent: e, + type: "mouseover", + position: { + x: pos[0], + y: pos[1] + } + }); + }, false); + var f1x1, f1y1, f2x1, f2y1; + var distance1, distance1Sq; + var center1, modelCenter1; + var offsetLeft, offsetTop; + var containerWidth, containerHeight; + var twoFingersStartInside; + var distance = function distance2(x1, y1, x2, y2) { + return Math.sqrt((x2 - x1) * (x2 - x1) + (y2 - y1) * (y2 - y1)); + }; + var distanceSq = function distanceSq2(x1, y1, x2, y2) { + return (x2 - x1) * (x2 - x1) + (y2 - y1) * (y2 - y1); + }; + var touchstartHandler; + r.registerBinding(r.container, "touchstart", touchstartHandler = function touchstartHandler2(e) { + r.hasTouchStarted = true; + if (!eventInContainer(e)) { + return; + } + blurActiveDomElement(); + r.touchData.capture = true; + r.data.bgActivePosistion = void 0; + var cy = r.cy; + var now2 = r.touchData.now; + var earlier = r.touchData.earlier; + if (e.touches[0]) { + var pos = r.projectIntoViewport(e.touches[0].clientX, e.touches[0].clientY); + now2[0] = pos[0]; + now2[1] = pos[1]; + } + if (e.touches[1]) { + var pos = r.projectIntoViewport(e.touches[1].clientX, e.touches[1].clientY); + now2[2] = pos[0]; + now2[3] = pos[1]; + } + if (e.touches[2]) { + var pos = r.projectIntoViewport(e.touches[2].clientX, e.touches[2].clientY); + now2[4] = pos[0]; + now2[5] = pos[1]; + } + if (e.touches[1]) { + r.touchData.singleTouchMoved = true; + freeDraggedElements(r.dragData.touchDragEles); + var offsets = r.findContainerClientCoords(); + offsetLeft = offsets[0]; + offsetTop = offsets[1]; + containerWidth = offsets[2]; + containerHeight = offsets[3]; + f1x1 = e.touches[0].clientX - offsetLeft; + f1y1 = e.touches[0].clientY - offsetTop; + f2x1 = e.touches[1].clientX - offsetLeft; + f2y1 = e.touches[1].clientY - offsetTop; + twoFingersStartInside = 0 <= f1x1 && f1x1 <= containerWidth && 0 <= f2x1 && f2x1 <= containerWidth && 0 <= f1y1 && f1y1 <= containerHeight && 0 <= f2y1 && f2y1 <= containerHeight; + var pan = cy.pan(); + var zoom = cy.zoom(); + distance1 = distance(f1x1, f1y1, f2x1, f2y1); + distance1Sq = distanceSq(f1x1, f1y1, f2x1, f2y1); + center1 = [(f1x1 + f2x1) / 2, (f1y1 + f2y1) / 2]; + modelCenter1 = [(center1[0] - pan.x) / zoom, (center1[1] - pan.y) / zoom]; + var cxtDistThreshold = 200; + var cxtDistThresholdSq = cxtDistThreshold * cxtDistThreshold; + if (distance1Sq < cxtDistThresholdSq && !e.touches[2]) { + var near1 = r.findNearestElement(now2[0], now2[1], true, true); + var near2 = r.findNearestElement(now2[2], now2[3], true, true); + if (near1 && near1.isNode()) { + near1.activate().emit({ + originalEvent: e, + type: "cxttapstart", + position: { + x: now2[0], + y: now2[1] + } + }); + r.touchData.start = near1; + } else if (near2 && near2.isNode()) { + near2.activate().emit({ + originalEvent: e, + type: "cxttapstart", + position: { + x: now2[0], + y: now2[1] + } + }); + r.touchData.start = near2; + } else { + cy.emit({ + originalEvent: e, + type: "cxttapstart", + position: { + x: now2[0], + y: now2[1] + } + }); + } + if (r.touchData.start) { + r.touchData.start._private.grabbed = false; + } + r.touchData.cxt = true; + r.touchData.cxtDragged = false; + r.data.bgActivePosistion = void 0; + r.redraw(); + return; + } + } + if (e.touches[2]) { + if (cy.boxSelectionEnabled()) { + e.preventDefault(); + } + } else if (e.touches[1]) + ; + else if (e.touches[0]) { + var nears = r.findNearestElements(now2[0], now2[1], true, true); + var near = nears[0]; + if (near != null) { + near.activate(); + r.touchData.start = near; + r.touchData.starts = nears; + if (r.nodeIsGrabbable(near)) { + var draggedEles = r.dragData.touchDragEles = cy.collection(); + var selectedNodes = null; + r.redrawHint("eles", true); + r.redrawHint("drag", true); + if (near.selected()) { + selectedNodes = cy.$(function(ele) { + return ele.selected() && r.nodeIsGrabbable(ele); + }); + addNodesToDrag(selectedNodes, { + addToList: draggedEles + }); + } else { + addNodeToDrag(near, { + addToList: draggedEles + }); + } + setGrabTarget(near); + var makeEvent = function makeEvent2(type) { + return { + originalEvent: e, + type, + position: { + x: now2[0], + y: now2[1] + } + }; + }; + near.emit(makeEvent("grabon")); + if (selectedNodes) { + selectedNodes.forEach(function(n) { + n.emit(makeEvent("grab")); + }); + } else { + near.emit(makeEvent("grab")); + } + } + } + triggerEvents(near, ["touchstart", "tapstart", "vmousedown"], e, { + x: now2[0], + y: now2[1] + }); + if (near == null) { + r.data.bgActivePosistion = { + x: pos[0], + y: pos[1] + }; + r.redrawHint("select", true); + r.redraw(); + } + r.touchData.singleTouchMoved = false; + r.touchData.singleTouchStartTime = +/* @__PURE__ */ new Date(); + clearTimeout(r.touchData.tapholdTimeout); + r.touchData.tapholdTimeout = setTimeout(function() { + if (r.touchData.singleTouchMoved === false && !r.pinching && !r.touchData.selecting) { + triggerEvents(r.touchData.start, ["taphold"], e, { + x: now2[0], + y: now2[1] + }); + } + }, r.tapholdDuration); + } + if (e.touches.length >= 1) { + var sPos = r.touchData.startPosition = [null, null, null, null, null, null]; + for (var i2 = 0; i2 < now2.length; i2++) { + sPos[i2] = earlier[i2] = now2[i2]; + } + var touch0 = e.touches[0]; + r.touchData.startGPosition = [touch0.clientX, touch0.clientY]; + } + }, false); + var touchmoveHandler; + r.registerBinding(window, "touchmove", touchmoveHandler = function touchmoveHandler2(e) { + var capture = r.touchData.capture; + if (!capture && !eventInContainer(e)) { + return; + } + var select = r.selection; + var cy = r.cy; + var now2 = r.touchData.now; + var earlier = r.touchData.earlier; + var zoom = cy.zoom(); + if (e.touches[0]) { + var pos = r.projectIntoViewport(e.touches[0].clientX, e.touches[0].clientY); + now2[0] = pos[0]; + now2[1] = pos[1]; + } + if (e.touches[1]) { + var pos = r.projectIntoViewport(e.touches[1].clientX, e.touches[1].clientY); + now2[2] = pos[0]; + now2[3] = pos[1]; + } + if (e.touches[2]) { + var pos = r.projectIntoViewport(e.touches[2].clientX, e.touches[2].clientY); + now2[4] = pos[0]; + now2[5] = pos[1]; + } + var startGPos = r.touchData.startGPosition; + var isOverThresholdDrag; + if (capture && e.touches[0] && startGPos) { + var disp = []; + for (var j = 0; j < now2.length; j++) { + disp[j] = now2[j] - earlier[j]; + } + var dx = e.touches[0].clientX - startGPos[0]; + var dx2 = dx * dx; + var dy = e.touches[0].clientY - startGPos[1]; + var dy2 = dy * dy; + var dist2 = dx2 + dy2; + isOverThresholdDrag = dist2 >= r.touchTapThreshold2; + } + if (capture && r.touchData.cxt) { + e.preventDefault(); + var f1x2 = e.touches[0].clientX - offsetLeft, f1y2 = e.touches[0].clientY - offsetTop; + var f2x2 = e.touches[1].clientX - offsetLeft, f2y2 = e.touches[1].clientY - offsetTop; + var distance2Sq = distanceSq(f1x2, f1y2, f2x2, f2y2); + var factorSq = distance2Sq / distance1Sq; + var distThreshold = 150; + var distThresholdSq = distThreshold * distThreshold; + var factorThreshold = 1.5; + var factorThresholdSq = factorThreshold * factorThreshold; + if (factorSq >= factorThresholdSq || distance2Sq >= distThresholdSq) { + r.touchData.cxt = false; + r.data.bgActivePosistion = void 0; + r.redrawHint("select", true); + var cxtEvt = { + originalEvent: e, + type: "cxttapend", + position: { + x: now2[0], + y: now2[1] + } + }; + if (r.touchData.start) { + r.touchData.start.unactivate().emit(cxtEvt); + r.touchData.start = null; + } else { + cy.emit(cxtEvt); + } + } + } + if (capture && r.touchData.cxt) { + var cxtEvt = { + originalEvent: e, + type: "cxtdrag", + position: { + x: now2[0], + y: now2[1] + } + }; + r.data.bgActivePosistion = void 0; + r.redrawHint("select", true); + if (r.touchData.start) { + r.touchData.start.emit(cxtEvt); + } else { + cy.emit(cxtEvt); + } + if (r.touchData.start) { + r.touchData.start._private.grabbed = false; + } + r.touchData.cxtDragged = true; + var near = r.findNearestElement(now2[0], now2[1], true, true); + if (!r.touchData.cxtOver || near !== r.touchData.cxtOver) { + if (r.touchData.cxtOver) { + r.touchData.cxtOver.emit({ + originalEvent: e, + type: "cxtdragout", + position: { + x: now2[0], + y: now2[1] + } + }); + } + r.touchData.cxtOver = near; + if (near) { + near.emit({ + originalEvent: e, + type: "cxtdragover", + position: { + x: now2[0], + y: now2[1] + } + }); + } + } + } else if (capture && e.touches[2] && cy.boxSelectionEnabled()) { + e.preventDefault(); + r.data.bgActivePosistion = void 0; + this.lastThreeTouch = +/* @__PURE__ */ new Date(); + if (!r.touchData.selecting) { + cy.emit({ + originalEvent: e, + type: "boxstart", + position: { + x: now2[0], + y: now2[1] + } + }); + } + r.touchData.selecting = true; + r.touchData.didSelect = true; + select[4] = 1; + if (!select || select.length === 0 || select[0] === void 0) { + select[0] = (now2[0] + now2[2] + now2[4]) / 3; + select[1] = (now2[1] + now2[3] + now2[5]) / 3; + select[2] = (now2[0] + now2[2] + now2[4]) / 3 + 1; + select[3] = (now2[1] + now2[3] + now2[5]) / 3 + 1; + } else { + select[2] = (now2[0] + now2[2] + now2[4]) / 3; + select[3] = (now2[1] + now2[3] + now2[5]) / 3; + } + r.redrawHint("select", true); + r.redraw(); + } else if (capture && e.touches[1] && !r.touchData.didSelect && cy.zoomingEnabled() && cy.panningEnabled() && cy.userZoomingEnabled() && cy.userPanningEnabled()) { + e.preventDefault(); + r.data.bgActivePosistion = void 0; + r.redrawHint("select", true); + var draggedEles = r.dragData.touchDragEles; + if (draggedEles) { + r.redrawHint("drag", true); + for (var i2 = 0; i2 < draggedEles.length; i2++) { + var de_p = draggedEles[i2]._private; + de_p.grabbed = false; + de_p.rscratch.inDragLayer = false; + } + } + var _start = r.touchData.start; + var f1x2 = e.touches[0].clientX - offsetLeft, f1y2 = e.touches[0].clientY - offsetTop; + var f2x2 = e.touches[1].clientX - offsetLeft, f2y2 = e.touches[1].clientY - offsetTop; + var distance2 = distance(f1x2, f1y2, f2x2, f2y2); + var factor = distance2 / distance1; + if (twoFingersStartInside) { + var df1x = f1x2 - f1x1; + var df1y = f1y2 - f1y1; + var df2x = f2x2 - f2x1; + var df2y = f2y2 - f2y1; + var tx = (df1x + df2x) / 2; + var ty = (df1y + df2y) / 2; + var zoom1 = cy.zoom(); + var zoom2 = zoom1 * factor; + var pan1 = cy.pan(); + var ctrx = modelCenter1[0] * zoom1 + pan1.x; + var ctry = modelCenter1[1] * zoom1 + pan1.y; + var pan2 = { + x: -zoom2 / zoom1 * (ctrx - pan1.x - tx) + ctrx, + y: -zoom2 / zoom1 * (ctry - pan1.y - ty) + ctry + }; + if (_start && _start.active()) { + var draggedEles = r.dragData.touchDragEles; + freeDraggedElements(draggedEles); + r.redrawHint("drag", true); + r.redrawHint("eles", true); + _start.unactivate().emit("freeon"); + draggedEles.emit("free"); + if (r.dragData.didDrag) { + _start.emit("dragfreeon"); + draggedEles.emit("dragfree"); + } + } + cy.viewport({ + zoom: zoom2, + pan: pan2, + cancelOnFailedZoom: true + }); + cy.emit("pinchzoom"); + distance1 = distance2; + f1x1 = f1x2; + f1y1 = f1y2; + f2x1 = f2x2; + f2y1 = f2y2; + r.pinching = true; + } + if (e.touches[0]) { + var pos = r.projectIntoViewport(e.touches[0].clientX, e.touches[0].clientY); + now2[0] = pos[0]; + now2[1] = pos[1]; + } + if (e.touches[1]) { + var pos = r.projectIntoViewport(e.touches[1].clientX, e.touches[1].clientY); + now2[2] = pos[0]; + now2[3] = pos[1]; + } + if (e.touches[2]) { + var pos = r.projectIntoViewport(e.touches[2].clientX, e.touches[2].clientY); + now2[4] = pos[0]; + now2[5] = pos[1]; + } + } else if (e.touches[0] && !r.touchData.didSelect) { + var start = r.touchData.start; + var last = r.touchData.last; + var near; + if (!r.hoverData.draggingEles && !r.swipePanning) { + near = r.findNearestElement(now2[0], now2[1], true, true); + } + if (capture && start != null) { + e.preventDefault(); + } + if (capture && start != null && r.nodeIsDraggable(start)) { + if (isOverThresholdDrag) { + var draggedEles = r.dragData.touchDragEles; + var justStartedDrag = !r.dragData.didDrag; + if (justStartedDrag) { + addNodesToDrag(draggedEles, { + inDragLayer: true + }); + } + r.dragData.didDrag = true; + var totalShift = { + x: 0, + y: 0 + }; + if (number$1(disp[0]) && number$1(disp[1])) { + totalShift.x += disp[0]; + totalShift.y += disp[1]; + if (justStartedDrag) { + r.redrawHint("eles", true); + var dragDelta = r.touchData.dragDelta; + if (dragDelta && number$1(dragDelta[0]) && number$1(dragDelta[1])) { + totalShift.x += dragDelta[0]; + totalShift.y += dragDelta[1]; + } + } + } + r.hoverData.draggingEles = true; + draggedEles.silentShift(totalShift).emit("position drag"); + r.redrawHint("drag", true); + if (r.touchData.startPosition[0] == earlier[0] && r.touchData.startPosition[1] == earlier[1]) { + r.redrawHint("eles", true); + } + r.redraw(); + } else { + var dragDelta = r.touchData.dragDelta = r.touchData.dragDelta || []; + if (dragDelta.length === 0) { + dragDelta.push(disp[0]); + dragDelta.push(disp[1]); + } else { + dragDelta[0] += disp[0]; + dragDelta[1] += disp[1]; + } + } + } + { + triggerEvents(start || near, ["touchmove", "tapdrag", "vmousemove"], e, { + x: now2[0], + y: now2[1] + }); + if ((!start || !start.grabbed()) && near != last) { + if (last) { + last.emit({ + originalEvent: e, + type: "tapdragout", + position: { + x: now2[0], + y: now2[1] + } + }); + } + if (near) { + near.emit({ + originalEvent: e, + type: "tapdragover", + position: { + x: now2[0], + y: now2[1] + } + }); + } + } + r.touchData.last = near; + } + if (capture) { + for (var i2 = 0; i2 < now2.length; i2++) { + if (now2[i2] && r.touchData.startPosition[i2] && isOverThresholdDrag) { + r.touchData.singleTouchMoved = true; + } + } + } + if (capture && (start == null || start.pannable()) && cy.panningEnabled() && cy.userPanningEnabled()) { + var allowPassthrough = allowPanningPassthrough(start, r.touchData.starts); + if (allowPassthrough) { + e.preventDefault(); + if (!r.data.bgActivePosistion) { + r.data.bgActivePosistion = array2point(r.touchData.startPosition); + } + if (r.swipePanning) { + cy.panBy({ + x: disp[0] * zoom, + y: disp[1] * zoom + }); + cy.emit("dragpan"); + } else if (isOverThresholdDrag) { + r.swipePanning = true; + cy.panBy({ + x: dx * zoom, + y: dy * zoom + }); + cy.emit("dragpan"); + if (start) { + start.unactivate(); + r.redrawHint("select", true); + r.touchData.start = null; + } + } + } + var pos = r.projectIntoViewport(e.touches[0].clientX, e.touches[0].clientY); + now2[0] = pos[0]; + now2[1] = pos[1]; + } + } + for (var j = 0; j < now2.length; j++) { + earlier[j] = now2[j]; + } + if (capture && e.touches.length > 0 && !r.hoverData.draggingEles && !r.swipePanning && r.data.bgActivePosistion != null) { + r.data.bgActivePosistion = void 0; + r.redrawHint("select", true); + r.redraw(); + } + }, false); + var touchcancelHandler; + r.registerBinding(containerWindow, "touchcancel", touchcancelHandler = function touchcancelHandler2(e) { + var start = r.touchData.start; + r.touchData.capture = false; + if (start) { + start.unactivate(); + } + }); + var touchendHandler, didDoubleTouch, touchTimeout, prevTouchTimeStamp; + r.registerBinding(containerWindow, "touchend", touchendHandler = function touchendHandler2(e) { + var start = r.touchData.start; + var capture = r.touchData.capture; + if (capture) { + if (e.touches.length === 0) { + r.touchData.capture = false; + } + e.preventDefault(); + } else { + return; + } + var select = r.selection; + r.swipePanning = false; + r.hoverData.draggingEles = false; + var cy = r.cy; + var zoom = cy.zoom(); + var now2 = r.touchData.now; + var earlier = r.touchData.earlier; + if (e.touches[0]) { + var pos = r.projectIntoViewport(e.touches[0].clientX, e.touches[0].clientY); + now2[0] = pos[0]; + now2[1] = pos[1]; + } + if (e.touches[1]) { + var pos = r.projectIntoViewport(e.touches[1].clientX, e.touches[1].clientY); + now2[2] = pos[0]; + now2[3] = pos[1]; + } + if (e.touches[2]) { + var pos = r.projectIntoViewport(e.touches[2].clientX, e.touches[2].clientY); + now2[4] = pos[0]; + now2[5] = pos[1]; + } + if (start) { + start.unactivate(); + } + var ctxTapend; + if (r.touchData.cxt) { + ctxTapend = { + originalEvent: e, + type: "cxttapend", + position: { + x: now2[0], + y: now2[1] + } + }; + if (start) { + start.emit(ctxTapend); + } else { + cy.emit(ctxTapend); + } + if (!r.touchData.cxtDragged) { + var ctxTap = { + originalEvent: e, + type: "cxttap", + position: { + x: now2[0], + y: now2[1] + } + }; + if (start) { + start.emit(ctxTap); + } else { + cy.emit(ctxTap); + } + } + if (r.touchData.start) { + r.touchData.start._private.grabbed = false; + } + r.touchData.cxt = false; + r.touchData.start = null; + r.redraw(); + return; + } + if (!e.touches[2] && cy.boxSelectionEnabled() && r.touchData.selecting) { + r.touchData.selecting = false; + var box = cy.collection(r.getAllInBox(select[0], select[1], select[2], select[3])); + select[0] = void 0; + select[1] = void 0; + select[2] = void 0; + select[3] = void 0; + select[4] = 0; + r.redrawHint("select", true); + cy.emit({ + type: "boxend", + originalEvent: e, + position: { + x: now2[0], + y: now2[1] + } + }); + var eleWouldBeSelected = function eleWouldBeSelected2(ele) { + return ele.selectable() && !ele.selected(); + }; + box.emit("box").stdFilter(eleWouldBeSelected).select().emit("boxselect"); + if (box.nonempty()) { + r.redrawHint("eles", true); + } + r.redraw(); + } + if (start != null) { + start.unactivate(); + } + if (e.touches[2]) { + r.data.bgActivePosistion = void 0; + r.redrawHint("select", true); + } else if (e.touches[1]) + ; + else if (e.touches[0]) + ; + else if (!e.touches[0]) { + r.data.bgActivePosistion = void 0; + r.redrawHint("select", true); + var draggedEles = r.dragData.touchDragEles; + if (start != null) { + var startWasGrabbed = start._private.grabbed; + freeDraggedElements(draggedEles); + r.redrawHint("drag", true); + r.redrawHint("eles", true); + if (startWasGrabbed) { + start.emit("freeon"); + draggedEles.emit("free"); + if (r.dragData.didDrag) { + start.emit("dragfreeon"); + draggedEles.emit("dragfree"); + } + } + triggerEvents(start, ["touchend", "tapend", "vmouseup", "tapdragout"], e, { + x: now2[0], + y: now2[1] + }); + start.unactivate(); + r.touchData.start = null; + } else { + var near = r.findNearestElement(now2[0], now2[1], true, true); + triggerEvents(near, ["touchend", "tapend", "vmouseup", "tapdragout"], e, { + x: now2[0], + y: now2[1] + }); + } + var dx = r.touchData.startPosition[0] - now2[0]; + var dx2 = dx * dx; + var dy = r.touchData.startPosition[1] - now2[1]; + var dy2 = dy * dy; + var dist2 = dx2 + dy2; + var rdist2 = dist2 * zoom * zoom; + if (!r.touchData.singleTouchMoved) { + if (!start) { + cy.$(":selected").unselect(["tapunselect"]); + } + triggerEvents(start, ["tap", "vclick"], e, { + x: now2[0], + y: now2[1] + }); + didDoubleTouch = false; + if (e.timeStamp - prevTouchTimeStamp <= cy.multiClickDebounceTime()) { + touchTimeout && clearTimeout(touchTimeout); + didDoubleTouch = true; + prevTouchTimeStamp = null; + triggerEvents(start, ["dbltap", "vdblclick"], e, { + x: now2[0], + y: now2[1] + }); + } else { + touchTimeout = setTimeout(function() { + if (didDoubleTouch) + return; + triggerEvents(start, ["onetap", "voneclick"], e, { + x: now2[0], + y: now2[1] + }); + }, cy.multiClickDebounceTime()); + prevTouchTimeStamp = e.timeStamp; + } + } + if (start != null && !r.dragData.didDrag && start._private.selectable && rdist2 < r.touchTapThreshold2 && !r.pinching) { + if (cy.selectionType() === "single") { + cy.$(isSelected).unmerge(start).unselect(["tapunselect"]); + start.select(["tapselect"]); + } else { + if (start.selected()) { + start.unselect(["tapunselect"]); + } else { + start.select(["tapselect"]); + } + } + r.redrawHint("eles", true); + } + r.touchData.singleTouchMoved = true; + } + for (var j = 0; j < now2.length; j++) { + earlier[j] = now2[j]; + } + r.dragData.didDrag = false; + if (e.touches.length === 0) { + r.touchData.dragDelta = []; + r.touchData.startPosition = [null, null, null, null, null, null]; + r.touchData.startGPosition = null; + r.touchData.didSelect = false; + } + if (e.touches.length < 2) { + if (e.touches.length === 1) { + r.touchData.startGPosition = [e.touches[0].clientX, e.touches[0].clientY]; + } + r.pinching = false; + r.redrawHint("eles", true); + r.redraw(); + } + }, false); + if (typeof TouchEvent === "undefined") { + var pointers = []; + var makeTouch = function makeTouch2(e) { + return { + clientX: e.clientX, + clientY: e.clientY, + force: 1, + identifier: e.pointerId, + pageX: e.pageX, + pageY: e.pageY, + radiusX: e.width / 2, + radiusY: e.height / 2, + screenX: e.screenX, + screenY: e.screenY, + target: e.target + }; + }; + var makePointer = function makePointer2(e) { + return { + event: e, + touch: makeTouch(e) + }; + }; + var addPointer = function addPointer2(e) { + pointers.push(makePointer(e)); + }; + var removePointer = function removePointer2(e) { + for (var i2 = 0; i2 < pointers.length; i2++) { + var p2 = pointers[i2]; + if (p2.event.pointerId === e.pointerId) { + pointers.splice(i2, 1); + return; + } + } + }; + var updatePointer = function updatePointer2(e) { + var p2 = pointers.filter(function(p3) { + return p3.event.pointerId === e.pointerId; + })[0]; + p2.event = e; + p2.touch = makeTouch(e); + }; + var addTouchesToEvent = function addTouchesToEvent2(e) { + e.touches = pointers.map(function(p2) { + return p2.touch; + }); + }; + var pointerIsMouse = function pointerIsMouse2(e) { + return e.pointerType === "mouse" || e.pointerType === 4; + }; + r.registerBinding(r.container, "pointerdown", function(e) { + if (pointerIsMouse(e)) { + return; + } + e.preventDefault(); + addPointer(e); + addTouchesToEvent(e); + touchstartHandler(e); + }); + r.registerBinding(r.container, "pointerup", function(e) { + if (pointerIsMouse(e)) { + return; + } + removePointer(e); + addTouchesToEvent(e); + touchendHandler(e); + }); + r.registerBinding(r.container, "pointercancel", function(e) { + if (pointerIsMouse(e)) { + return; + } + removePointer(e); + addTouchesToEvent(e); + touchcancelHandler(e); + }); + r.registerBinding(r.container, "pointermove", function(e) { + if (pointerIsMouse(e)) { + return; + } + e.preventDefault(); + updatePointer(e); + addTouchesToEvent(e); + touchmoveHandler(e); + }); + } + }; + var BRp$2 = {}; + BRp$2.generatePolygon = function(name, points) { + return this.nodeShapes[name] = { + renderer: this, + name, + points, + draw: function draw2(context, centerX, centerY, width, height) { + this.renderer.nodeShapeImpl("polygon", context, centerX, centerY, width, height, this.points); + }, + intersectLine: function intersectLine(nodeX, nodeY, width, height, x, y, padding) { + return polygonIntersectLine(x, y, this.points, nodeX, nodeY, width / 2, height / 2, padding); + }, + checkPoint: function checkPoint(x, y, padding, width, height, centerX, centerY) { + return pointInsidePolygon(x, y, this.points, centerX, centerY, width, height, [0, -1], padding); + } + }; + }; + BRp$2.generateEllipse = function() { + return this.nodeShapes["ellipse"] = { + renderer: this, + name: "ellipse", + draw: function draw2(context, centerX, centerY, width, height) { + this.renderer.nodeShapeImpl(this.name, context, centerX, centerY, width, height); + }, + intersectLine: function intersectLine(nodeX, nodeY, width, height, x, y, padding) { + return intersectLineEllipse(x, y, nodeX, nodeY, width / 2 + padding, height / 2 + padding); + }, + checkPoint: function checkPoint(x, y, padding, width, height, centerX, centerY) { + return checkInEllipse(x, y, width, height, centerX, centerY, padding); + } + }; + }; + BRp$2.generateRoundPolygon = function(name, points) { + var allPoints = new Array(points.length * 2); + for (var i2 = 0; i2 < points.length / 2; i2++) { + var sourceIndex = i2 * 2; + var destIndex = void 0; + if (i2 < points.length / 2 - 1) { + destIndex = (i2 + 1) * 2; + } else { + destIndex = 0; + } + allPoints[i2 * 4] = points[sourceIndex]; + allPoints[i2 * 4 + 1] = points[sourceIndex + 1]; + var xDest = points[destIndex] - points[sourceIndex]; + var yDest = points[destIndex + 1] - points[sourceIndex + 1]; + var norm = Math.sqrt(xDest * xDest + yDest * yDest); + allPoints[i2 * 4 + 2] = xDest / norm; + allPoints[i2 * 4 + 3] = yDest / norm; + } + return this.nodeShapes[name] = { + renderer: this, + name, + points: allPoints, + draw: function draw2(context, centerX, centerY, width, height) { + this.renderer.nodeShapeImpl("round-polygon", context, centerX, centerY, width, height, this.points); + }, + intersectLine: function intersectLine(nodeX, nodeY, width, height, x, y, padding) { + return roundPolygonIntersectLine(x, y, this.points, nodeX, nodeY, width, height); + }, + checkPoint: function checkPoint(x, y, padding, width, height, centerX, centerY) { + return pointInsideRoundPolygon(x, y, this.points, centerX, centerY, width, height); + } + }; + }; + BRp$2.generateRoundRectangle = function() { + return this.nodeShapes["round-rectangle"] = this.nodeShapes["roundrectangle"] = { + renderer: this, + name: "round-rectangle", + points: generateUnitNgonPointsFitToSquare(4, 0), + draw: function draw2(context, centerX, centerY, width, height) { + this.renderer.nodeShapeImpl(this.name, context, centerX, centerY, width, height); + }, + intersectLine: function intersectLine(nodeX, nodeY, width, height, x, y, padding) { + return roundRectangleIntersectLine(x, y, nodeX, nodeY, width, height, padding); + }, + checkPoint: function checkPoint(x, y, padding, width, height, centerX, centerY) { + var cornerRadius = getRoundRectangleRadius(width, height); + var diam = cornerRadius * 2; + if (pointInsidePolygon(x, y, this.points, centerX, centerY, width, height - diam, [0, -1], padding)) { + return true; + } + if (pointInsidePolygon(x, y, this.points, centerX, centerY, width - diam, height, [0, -1], padding)) { + return true; + } + if (checkInEllipse(x, y, diam, diam, centerX - width / 2 + cornerRadius, centerY - height / 2 + cornerRadius, padding)) { + return true; + } + if (checkInEllipse(x, y, diam, diam, centerX + width / 2 - cornerRadius, centerY - height / 2 + cornerRadius, padding)) { + return true; + } + if (checkInEllipse(x, y, diam, diam, centerX + width / 2 - cornerRadius, centerY + height / 2 - cornerRadius, padding)) { + return true; + } + if (checkInEllipse(x, y, diam, diam, centerX - width / 2 + cornerRadius, centerY + height / 2 - cornerRadius, padding)) { + return true; + } + return false; + } + }; + }; + BRp$2.generateCutRectangle = function() { + return this.nodeShapes["cut-rectangle"] = this.nodeShapes["cutrectangle"] = { + renderer: this, + name: "cut-rectangle", + cornerLength: getCutRectangleCornerLength(), + points: generateUnitNgonPointsFitToSquare(4, 0), + draw: function draw2(context, centerX, centerY, width, height) { + this.renderer.nodeShapeImpl(this.name, context, centerX, centerY, width, height); + }, + generateCutTrianglePts: function generateCutTrianglePts(width, height, centerX, centerY) { + var cl = this.cornerLength; + var hh = height / 2; + var hw = width / 2; + var xBegin = centerX - hw; + var xEnd = centerX + hw; + var yBegin = centerY - hh; + var yEnd = centerY + hh; + return { + topLeft: [xBegin, yBegin + cl, xBegin + cl, yBegin, xBegin + cl, yBegin + cl], + topRight: [xEnd - cl, yBegin, xEnd, yBegin + cl, xEnd - cl, yBegin + cl], + bottomRight: [xEnd, yEnd - cl, xEnd - cl, yEnd, xEnd - cl, yEnd - cl], + bottomLeft: [xBegin + cl, yEnd, xBegin, yEnd - cl, xBegin + cl, yEnd - cl] + }; + }, + intersectLine: function intersectLine(nodeX, nodeY, width, height, x, y, padding) { + var cPts = this.generateCutTrianglePts(width + 2 * padding, height + 2 * padding, nodeX, nodeY); + var pts2 = [].concat.apply([], [cPts.topLeft.splice(0, 4), cPts.topRight.splice(0, 4), cPts.bottomRight.splice(0, 4), cPts.bottomLeft.splice(0, 4)]); + return polygonIntersectLine(x, y, pts2, nodeX, nodeY); + }, + checkPoint: function checkPoint(x, y, padding, width, height, centerX, centerY) { + if (pointInsidePolygon(x, y, this.points, centerX, centerY, width, height - 2 * this.cornerLength, [0, -1], padding)) { + return true; + } + if (pointInsidePolygon(x, y, this.points, centerX, centerY, width - 2 * this.cornerLength, height, [0, -1], padding)) { + return true; + } + var cutTrianglePts = this.generateCutTrianglePts(width, height, centerX, centerY); + return pointInsidePolygonPoints(x, y, cutTrianglePts.topLeft) || pointInsidePolygonPoints(x, y, cutTrianglePts.topRight) || pointInsidePolygonPoints(x, y, cutTrianglePts.bottomRight) || pointInsidePolygonPoints(x, y, cutTrianglePts.bottomLeft); + } + }; + }; + BRp$2.generateBarrel = function() { + return this.nodeShapes["barrel"] = { + renderer: this, + name: "barrel", + points: generateUnitNgonPointsFitToSquare(4, 0), + draw: function draw2(context, centerX, centerY, width, height) { + this.renderer.nodeShapeImpl(this.name, context, centerX, centerY, width, height); + }, + intersectLine: function intersectLine(nodeX, nodeY, width, height, x, y, padding) { + var t0 = 0.15; + var t1 = 0.5; + var t2 = 0.85; + var bPts = this.generateBarrelBezierPts(width + 2 * padding, height + 2 * padding, nodeX, nodeY); + var approximateBarrelCurvePts = function approximateBarrelCurvePts2(pts3) { + var m0 = qbezierPtAt({ + x: pts3[0], + y: pts3[1] + }, { + x: pts3[2], + y: pts3[3] + }, { + x: pts3[4], + y: pts3[5] + }, t0); + var m1 = qbezierPtAt({ + x: pts3[0], + y: pts3[1] + }, { + x: pts3[2], + y: pts3[3] + }, { + x: pts3[4], + y: pts3[5] + }, t1); + var m2 = qbezierPtAt({ + x: pts3[0], + y: pts3[1] + }, { + x: pts3[2], + y: pts3[3] + }, { + x: pts3[4], + y: pts3[5] + }, t2); + return [pts3[0], pts3[1], m0.x, m0.y, m1.x, m1.y, m2.x, m2.y, pts3[4], pts3[5]]; + }; + var pts2 = [].concat(approximateBarrelCurvePts(bPts.topLeft), approximateBarrelCurvePts(bPts.topRight), approximateBarrelCurvePts(bPts.bottomRight), approximateBarrelCurvePts(bPts.bottomLeft)); + return polygonIntersectLine(x, y, pts2, nodeX, nodeY); + }, + generateBarrelBezierPts: function generateBarrelBezierPts(width, height, centerX, centerY) { + var hh = height / 2; + var hw = width / 2; + var xBegin = centerX - hw; + var xEnd = centerX + hw; + var yBegin = centerY - hh; + var yEnd = centerY + hh; + var curveConstants = getBarrelCurveConstants(width, height); + var hOffset = curveConstants.heightOffset; + var wOffset = curveConstants.widthOffset; + var ctrlPtXOffset = curveConstants.ctrlPtOffsetPct * width; + var pts2 = { + topLeft: [xBegin, yBegin + hOffset, xBegin + ctrlPtXOffset, yBegin, xBegin + wOffset, yBegin], + topRight: [xEnd - wOffset, yBegin, xEnd - ctrlPtXOffset, yBegin, xEnd, yBegin + hOffset], + bottomRight: [xEnd, yEnd - hOffset, xEnd - ctrlPtXOffset, yEnd, xEnd - wOffset, yEnd], + bottomLeft: [xBegin + wOffset, yEnd, xBegin + ctrlPtXOffset, yEnd, xBegin, yEnd - hOffset] + }; + pts2.topLeft.isTop = true; + pts2.topRight.isTop = true; + pts2.bottomLeft.isBottom = true; + pts2.bottomRight.isBottom = true; + return pts2; + }, + checkPoint: function checkPoint(x, y, padding, width, height, centerX, centerY) { + var curveConstants = getBarrelCurveConstants(width, height); + var hOffset = curveConstants.heightOffset; + var wOffset = curveConstants.widthOffset; + if (pointInsidePolygon(x, y, this.points, centerX, centerY, width, height - 2 * hOffset, [0, -1], padding)) { + return true; + } + if (pointInsidePolygon(x, y, this.points, centerX, centerY, width - 2 * wOffset, height, [0, -1], padding)) { + return true; + } + var barrelCurvePts = this.generateBarrelBezierPts(width, height, centerX, centerY); + var getCurveT = function getCurveT2(x2, y3, curvePts) { + var x0 = curvePts[4]; + var x1 = curvePts[2]; + var x22 = curvePts[0]; + var y02 = curvePts[5]; + var y22 = curvePts[1]; + var xMin = Math.min(x0, x22); + var xMax = Math.max(x0, x22); + var yMin = Math.min(y02, y22); + var yMax = Math.max(y02, y22); + if (xMin <= x2 && x2 <= xMax && yMin <= y3 && y3 <= yMax) { + var coeff = bezierPtsToQuadCoeff(x0, x1, x22); + var roots = solveQuadratic(coeff[0], coeff[1], coeff[2], x2); + var validRoots = roots.filter(function(r) { + return 0 <= r && r <= 1; + }); + if (validRoots.length > 0) { + return validRoots[0]; + } + } + return null; + }; + var curveRegions = Object.keys(barrelCurvePts); + for (var i2 = 0; i2 < curveRegions.length; i2++) { + var corner = curveRegions[i2]; + var cornerPts = barrelCurvePts[corner]; + var t = getCurveT(x, y, cornerPts); + if (t == null) { + continue; + } + var y0 = cornerPts[5]; + var y1 = cornerPts[3]; + var y2 = cornerPts[1]; + var bezY = qbezierAt(y0, y1, y2, t); + if (cornerPts.isTop && bezY <= y) { + return true; + } + if (cornerPts.isBottom && y <= bezY) { + return true; + } + } + return false; + } + }; + }; + BRp$2.generateBottomRoundrectangle = function() { + return this.nodeShapes["bottom-round-rectangle"] = this.nodeShapes["bottomroundrectangle"] = { + renderer: this, + name: "bottom-round-rectangle", + points: generateUnitNgonPointsFitToSquare(4, 0), + draw: function draw2(context, centerX, centerY, width, height) { + this.renderer.nodeShapeImpl(this.name, context, centerX, centerY, width, height); + }, + intersectLine: function intersectLine(nodeX, nodeY, width, height, x, y, padding) { + var topStartX = nodeX - (width / 2 + padding); + var topStartY = nodeY - (height / 2 + padding); + var topEndY = topStartY; + var topEndX = nodeX + (width / 2 + padding); + var topIntersections = finiteLinesIntersect(x, y, nodeX, nodeY, topStartX, topStartY, topEndX, topEndY, false); + if (topIntersections.length > 0) { + return topIntersections; + } + return roundRectangleIntersectLine(x, y, nodeX, nodeY, width, height, padding); + }, + checkPoint: function checkPoint(x, y, padding, width, height, centerX, centerY) { + var cornerRadius = getRoundRectangleRadius(width, height); + var diam = 2 * cornerRadius; + if (pointInsidePolygon(x, y, this.points, centerX, centerY, width, height - diam, [0, -1], padding)) { + return true; + } + if (pointInsidePolygon(x, y, this.points, centerX, centerY, width - diam, height, [0, -1], padding)) { + return true; + } + var outerWidth = width / 2 + 2 * padding; + var outerHeight = height / 2 + 2 * padding; + var points = [centerX - outerWidth, centerY - outerHeight, centerX - outerWidth, centerY, centerX + outerWidth, centerY, centerX + outerWidth, centerY - outerHeight]; + if (pointInsidePolygonPoints(x, y, points)) { + return true; + } + if (checkInEllipse(x, y, diam, diam, centerX + width / 2 - cornerRadius, centerY + height / 2 - cornerRadius, padding)) { + return true; + } + if (checkInEllipse(x, y, diam, diam, centerX - width / 2 + cornerRadius, centerY + height / 2 - cornerRadius, padding)) { + return true; + } + return false; + } + }; + }; + BRp$2.registerNodeShapes = function() { + var nodeShapes = this.nodeShapes = {}; + var renderer3 = this; + this.generateEllipse(); + this.generatePolygon("triangle", generateUnitNgonPointsFitToSquare(3, 0)); + this.generateRoundPolygon("round-triangle", generateUnitNgonPointsFitToSquare(3, 0)); + this.generatePolygon("rectangle", generateUnitNgonPointsFitToSquare(4, 0)); + nodeShapes["square"] = nodeShapes["rectangle"]; + this.generateRoundRectangle(); + this.generateCutRectangle(); + this.generateBarrel(); + this.generateBottomRoundrectangle(); + { + var diamondPoints = [0, 1, 1, 0, 0, -1, -1, 0]; + this.generatePolygon("diamond", diamondPoints); + this.generateRoundPolygon("round-diamond", diamondPoints); + } + this.generatePolygon("pentagon", generateUnitNgonPointsFitToSquare(5, 0)); + this.generateRoundPolygon("round-pentagon", generateUnitNgonPointsFitToSquare(5, 0)); + this.generatePolygon("hexagon", generateUnitNgonPointsFitToSquare(6, 0)); + this.generateRoundPolygon("round-hexagon", generateUnitNgonPointsFitToSquare(6, 0)); + this.generatePolygon("heptagon", generateUnitNgonPointsFitToSquare(7, 0)); + this.generateRoundPolygon("round-heptagon", generateUnitNgonPointsFitToSquare(7, 0)); + this.generatePolygon("octagon", generateUnitNgonPointsFitToSquare(8, 0)); + this.generateRoundPolygon("round-octagon", generateUnitNgonPointsFitToSquare(8, 0)); + var star5Points = new Array(20); + { + var outerPoints = generateUnitNgonPoints(5, 0); + var innerPoints = generateUnitNgonPoints(5, Math.PI / 5); + var innerRadius = 0.5 * (3 - Math.sqrt(5)); + innerRadius *= 1.57; + for (var i2 = 0; i2 < innerPoints.length / 2; i2++) { + innerPoints[i2 * 2] *= innerRadius; + innerPoints[i2 * 2 + 1] *= innerRadius; + } + for (var i2 = 0; i2 < 20 / 4; i2++) { + star5Points[i2 * 4] = outerPoints[i2 * 2]; + star5Points[i2 * 4 + 1] = outerPoints[i2 * 2 + 1]; + star5Points[i2 * 4 + 2] = innerPoints[i2 * 2]; + star5Points[i2 * 4 + 3] = innerPoints[i2 * 2 + 1]; + } + } + star5Points = fitPolygonToSquare(star5Points); + this.generatePolygon("star", star5Points); + this.generatePolygon("vee", [-1, -1, 0, -0.333, 1, -1, 0, 1]); + this.generatePolygon("rhomboid", [-1, -1, 0.333, -1, 1, 1, -0.333, 1]); + this.generatePolygon("right-rhomboid", [-0.333, -1, 1, -1, 0.333, 1, -1, 1]); + this.nodeShapes["concavehexagon"] = this.generatePolygon("concave-hexagon", [-1, -0.95, -0.75, 0, -1, 0.95, 1, 0.95, 0.75, 0, 1, -0.95]); + { + var tagPoints = [-1, -1, 0.25, -1, 1, 0, 0.25, 1, -1, 1]; + this.generatePolygon("tag", tagPoints); + this.generateRoundPolygon("round-tag", tagPoints); + } + nodeShapes.makePolygon = function(points) { + var key = points.join("$"); + var name = "polygon-" + key; + var shape; + if (shape = this[name]) { + return shape; + } + return renderer3.generatePolygon(name, points); + }; + }; + var BRp$1 = {}; + BRp$1.timeToRender = function() { + return this.redrawTotalTime / this.redrawCount; + }; + BRp$1.redraw = function(options) { + options = options || staticEmptyObject(); + var r = this; + if (r.averageRedrawTime === void 0) { + r.averageRedrawTime = 0; + } + if (r.lastRedrawTime === void 0) { + r.lastRedrawTime = 0; + } + if (r.lastDrawTime === void 0) { + r.lastDrawTime = 0; + } + r.requestedFrame = true; + r.renderOptions = options; + }; + BRp$1.beforeRender = function(fn2, priority) { + if (this.destroyed) { + return; + } + if (priority == null) { + error("Priority is not optional for beforeRender"); + } + var cbs = this.beforeRenderCallbacks; + cbs.push({ + fn: fn2, + priority + }); + cbs.sort(function(a, b) { + return b.priority - a.priority; + }); + }; + var beforeRenderCallbacks = function beforeRenderCallbacks2(r, willDraw, startTime) { + var cbs = r.beforeRenderCallbacks; + for (var i2 = 0; i2 < cbs.length; i2++) { + cbs[i2].fn(willDraw, startTime); + } + }; + BRp$1.startRenderLoop = function() { + var r = this; + var cy = r.cy; + if (r.renderLoopStarted) { + return; + } else { + r.renderLoopStarted = true; + } + var renderFn = function renderFn2(requestTime) { + if (r.destroyed) { + return; + } + if (cy.batching()) + ; + else if (r.requestedFrame && !r.skipFrame) { + beforeRenderCallbacks(r, true, requestTime); + var startTime = performanceNow(); + r.render(r.renderOptions); + var endTime = r.lastDrawTime = performanceNow(); + if (r.averageRedrawTime === void 0) { + r.averageRedrawTime = endTime - startTime; + } + if (r.redrawCount === void 0) { + r.redrawCount = 0; + } + r.redrawCount++; + if (r.redrawTotalTime === void 0) { + r.redrawTotalTime = 0; + } + var duration = endTime - startTime; + r.redrawTotalTime += duration; + r.lastRedrawTime = duration; + r.averageRedrawTime = r.averageRedrawTime / 2 + duration / 2; + r.requestedFrame = false; + } else { + beforeRenderCallbacks(r, false, requestTime); + } + r.skipFrame = false; + requestAnimationFrame2(renderFn2); + }; + requestAnimationFrame2(renderFn); + }; + var BaseRenderer = function BaseRenderer2(options) { + this.init(options); + }; + var BR = BaseRenderer; + var BRp = BR.prototype; + BRp.clientFunctions = ["redrawHint", "render", "renderTo", "matchCanvasSize", "nodeShapeImpl", "arrowShapeImpl"]; + BRp.init = function(options) { + var r = this; + r.options = options; + r.cy = options.cy; + var ctr = r.container = options.cy.container(); + var containerWindow = r.cy.window(); + if (containerWindow) { + var document2 = containerWindow.document; + var head = document2.head; + var stylesheetId = "__________cytoscape_stylesheet"; + var className = "__________cytoscape_container"; + var stylesheetAlreadyExists = document2.getElementById(stylesheetId) != null; + if (ctr.className.indexOf(className) < 0) { + ctr.className = (ctr.className || "") + " " + className; + } + if (!stylesheetAlreadyExists) { + var stylesheet2 = document2.createElement("style"); + stylesheet2.id = stylesheetId; + stylesheet2.textContent = "." + className + " { position: relative; }"; + head.insertBefore(stylesheet2, head.children[0]); + } + var computedStyle = containerWindow.getComputedStyle(ctr); + var position2 = computedStyle.getPropertyValue("position"); + if (position2 === "static") { + warn("A Cytoscape container has style position:static and so can not use UI extensions properly"); + } + } + r.selection = [void 0, void 0, void 0, void 0, 0]; + r.bezierProjPcts = [0.05, 0.225, 0.4, 0.5, 0.6, 0.775, 0.95]; + r.hoverData = { + down: null, + last: null, + downTime: null, + triggerMode: null, + dragging: false, + initialPan: [null, null], + capture: false + }; + r.dragData = { + possibleDragElements: [] + }; + r.touchData = { + start: null, + capture: false, + // These 3 fields related to tap, taphold events + startPosition: [null, null, null, null, null, null], + singleTouchStartTime: null, + singleTouchMoved: true, + now: [null, null, null, null, null, null], + earlier: [null, null, null, null, null, null] + }; + r.redraws = 0; + r.showFps = options.showFps; + r.debug = options.debug; + r.hideEdgesOnViewport = options.hideEdgesOnViewport; + r.textureOnViewport = options.textureOnViewport; + r.wheelSensitivity = options.wheelSensitivity; + r.motionBlurEnabled = options.motionBlur; + r.forcedPixelRatio = number$1(options.pixelRatio) ? options.pixelRatio : null; + r.motionBlur = options.motionBlur; + r.motionBlurOpacity = options.motionBlurOpacity; + r.motionBlurTransparency = 1 - r.motionBlurOpacity; + r.motionBlurPxRatio = 1; + r.mbPxRBlurry = 1; + r.minMbLowQualFrames = 4; + r.fullQualityMb = false; + r.clearedForMotionBlur = []; + r.desktopTapThreshold = options.desktopTapThreshold; + r.desktopTapThreshold2 = options.desktopTapThreshold * options.desktopTapThreshold; + r.touchTapThreshold = options.touchTapThreshold; + r.touchTapThreshold2 = options.touchTapThreshold * options.touchTapThreshold; + r.tapholdDuration = 500; + r.bindings = []; + r.beforeRenderCallbacks = []; + r.beforeRenderPriorities = { + // higher priority execs before lower one + animations: 400, + eleCalcs: 300, + eleTxrDeq: 200, + lyrTxrDeq: 150, + lyrTxrSkip: 100 + }; + r.registerNodeShapes(); + r.registerArrowShapes(); + r.registerCalculationListeners(); + }; + BRp.notify = function(eventName, eles) { + var r = this; + var cy = r.cy; + if (this.destroyed) { + return; + } + if (eventName === "init") { + r.load(); + return; + } + if (eventName === "destroy") { + r.destroy(); + return; + } + if (eventName === "add" || eventName === "remove" || eventName === "move" && cy.hasCompoundNodes() || eventName === "load" || eventName === "zorder" || eventName === "mount") { + r.invalidateCachedZSortedEles(); + } + if (eventName === "viewport") { + r.redrawHint("select", true); + } + if (eventName === "load" || eventName === "resize" || eventName === "mount") { + r.invalidateContainerClientCoordsCache(); + r.matchCanvasSize(r.container); + } + r.redrawHint("eles", true); + r.redrawHint("drag", true); + this.startRenderLoop(); + this.redraw(); + }; + BRp.destroy = function() { + var r = this; + r.destroyed = true; + r.cy.stopAnimationLoop(); + for (var i2 = 0; i2 < r.bindings.length; i2++) { + var binding = r.bindings[i2]; + var b = binding; + var tgt = b.target; + (tgt.off || tgt.removeEventListener).apply(tgt, b.args); + } + r.bindings = []; + r.beforeRenderCallbacks = []; + r.onUpdateEleCalcsFns = []; + if (r.removeObserver) { + r.removeObserver.disconnect(); + } + if (r.styleObserver) { + r.styleObserver.disconnect(); + } + if (r.resizeObserver) { + r.resizeObserver.disconnect(); + } + if (r.labelCalcDiv) { + try { + document.body.removeChild(r.labelCalcDiv); + } catch (e) { + } + } + }; + BRp.isHeadless = function() { + return false; + }; + [BRp$f, BRp$5, BRp$4, BRp$3, BRp$2, BRp$1].forEach(function(props) { + extend(BRp, props); + }); + var fullFpsTime = 1e3 / 60; + var defs = { + setupDequeueing: function setupDequeueing(opts) { + return function setupDequeueingImpl() { + var self2 = this; + var r = this.renderer; + if (self2.dequeueingSetup) { + return; + } else { + self2.dequeueingSetup = true; + } + var queueRedraw = debounce_1(function() { + r.redrawHint("eles", true); + r.redrawHint("drag", true); + r.redraw(); + }, opts.deqRedrawThreshold); + var dequeue = function dequeue2(willDraw, frameStartTime) { + var startTime = performanceNow(); + var avgRenderTime = r.averageRedrawTime; + var renderTime = r.lastRedrawTime; + var deqd = []; + var extent = r.cy.extent(); + var pixelRatio = r.getPixelRatio(); + if (!willDraw) { + r.flushRenderedStyleQueue(); + } + while (true) { + var now2 = performanceNow(); + var duration = now2 - startTime; + var frameDuration = now2 - frameStartTime; + if (renderTime < fullFpsTime) { + var timeAvailable = fullFpsTime - (willDraw ? avgRenderTime : 0); + if (frameDuration >= opts.deqFastCost * timeAvailable) { + break; + } + } else { + if (willDraw) { + if (duration >= opts.deqCost * renderTime || duration >= opts.deqAvgCost * avgRenderTime) { + break; + } + } else if (frameDuration >= opts.deqNoDrawCost * fullFpsTime) { + break; + } + } + var thisDeqd = opts.deq(self2, pixelRatio, extent); + if (thisDeqd.length > 0) { + for (var i2 = 0; i2 < thisDeqd.length; i2++) { + deqd.push(thisDeqd[i2]); + } + } else { + break; + } + } + if (deqd.length > 0) { + opts.onDeqd(self2, deqd); + if (!willDraw && opts.shouldRedraw(self2, deqd, pixelRatio, extent)) { + queueRedraw(); + } + } + }; + var priority = opts.priority || noop$1; + r.beforeRender(dequeue, priority(self2)); + }; + } + }; + var ElementTextureCacheLookup = /* @__PURE__ */ function() { + function ElementTextureCacheLookup2(getKey2) { + var doesEleInvalidateKey = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : falsify; + _classCallCheck(this, ElementTextureCacheLookup2); + this.idsByKey = new Map$2(); + this.keyForId = new Map$2(); + this.cachesByLvl = new Map$2(); + this.lvls = []; + this.getKey = getKey2; + this.doesEleInvalidateKey = doesEleInvalidateKey; + } + _createClass(ElementTextureCacheLookup2, [{ + key: "getIdsFor", + value: function getIdsFor(key) { + if (key == null) { + error("Can not get id list for null key"); + } + var idsByKey = this.idsByKey; + var ids = this.idsByKey.get(key); + if (!ids) { + ids = new Set$1(); + idsByKey.set(key, ids); + } + return ids; + } + }, { + key: "addIdForKey", + value: function addIdForKey(key, id) { + if (key != null) { + this.getIdsFor(key).add(id); + } + } + }, { + key: "deleteIdForKey", + value: function deleteIdForKey(key, id) { + if (key != null) { + this.getIdsFor(key)["delete"](id); + } + } + }, { + key: "getNumberOfIdsForKey", + value: function getNumberOfIdsForKey(key) { + if (key == null) { + return 0; + } else { + return this.getIdsFor(key).size; + } + } + }, { + key: "updateKeyMappingFor", + value: function updateKeyMappingFor(ele) { + var id = ele.id(); + var prevKey = this.keyForId.get(id); + var currKey = this.getKey(ele); + this.deleteIdForKey(prevKey, id); + this.addIdForKey(currKey, id); + this.keyForId.set(id, currKey); + } + }, { + key: "deleteKeyMappingFor", + value: function deleteKeyMappingFor(ele) { + var id = ele.id(); + var prevKey = this.keyForId.get(id); + this.deleteIdForKey(prevKey, id); + this.keyForId["delete"](id); + } + }, { + key: "keyHasChangedFor", + value: function keyHasChangedFor(ele) { + var id = ele.id(); + var prevKey = this.keyForId.get(id); + var newKey = this.getKey(ele); + return prevKey !== newKey; + } + }, { + key: "isInvalid", + value: function isInvalid(ele) { + return this.keyHasChangedFor(ele) || this.doesEleInvalidateKey(ele); + } + }, { + key: "getCachesAt", + value: function getCachesAt(lvl) { + var cachesByLvl = this.cachesByLvl, lvls = this.lvls; + var caches = cachesByLvl.get(lvl); + if (!caches) { + caches = new Map$2(); + cachesByLvl.set(lvl, caches); + lvls.push(lvl); + } + return caches; + } + }, { + key: "getCache", + value: function getCache(key, lvl) { + return this.getCachesAt(lvl).get(key); + } + }, { + key: "get", + value: function get2(ele, lvl) { + var key = this.getKey(ele); + var cache2 = this.getCache(key, lvl); + if (cache2 != null) { + this.updateKeyMappingFor(ele); + } + return cache2; + } + }, { + key: "getForCachedKey", + value: function getForCachedKey(ele, lvl) { + var key = this.keyForId.get(ele.id()); + var cache2 = this.getCache(key, lvl); + return cache2; + } + }, { + key: "hasCache", + value: function hasCache(key, lvl) { + return this.getCachesAt(lvl).has(key); + } + }, { + key: "has", + value: function has(ele, lvl) { + var key = this.getKey(ele); + return this.hasCache(key, lvl); + } + }, { + key: "setCache", + value: function setCache(key, lvl, cache2) { + cache2.key = key; + this.getCachesAt(lvl).set(key, cache2); + } + }, { + key: "set", + value: function set2(ele, lvl, cache2) { + var key = this.getKey(ele); + this.setCache(key, lvl, cache2); + this.updateKeyMappingFor(ele); + } + }, { + key: "deleteCache", + value: function deleteCache(key, lvl) { + this.getCachesAt(lvl)["delete"](key); + } + }, { + key: "delete", + value: function _delete(ele, lvl) { + var key = this.getKey(ele); + this.deleteCache(key, lvl); + } + }, { + key: "invalidateKey", + value: function invalidateKey(key) { + var _this = this; + this.lvls.forEach(function(lvl) { + return _this.deleteCache(key, lvl); + }); + } + // returns true if no other eles reference the invalidated cache (n.b. other eles may need the cache with the same key) + }, { + key: "invalidate", + value: function invalidate(ele) { + var id = ele.id(); + var key = this.keyForId.get(id); + this.deleteKeyMappingFor(ele); + var entireKeyInvalidated = this.doesEleInvalidateKey(ele); + if (entireKeyInvalidated) { + this.invalidateKey(key); + } + return entireKeyInvalidated || this.getNumberOfIdsForKey(key) === 0; + } + }]); + return ElementTextureCacheLookup2; + }(); + var minTxrH = 25; + var txrStepH = 50; + var minLvl$1 = -4; + var maxLvl$1 = 3; + var maxZoom$1 = 7.99; + var eleTxrSpacing = 8; + var defTxrWidth = 1024; + var maxTxrW = 1024; + var maxTxrH = 1024; + var minUtility = 0.2; + var maxFullness = 0.8; + var maxFullnessChecks = 10; + var deqCost$1 = 0.15; + var deqAvgCost$1 = 0.1; + var deqNoDrawCost$1 = 0.9; + var deqFastCost$1 = 0.9; + var deqRedrawThreshold$1 = 100; + var maxDeqSize$1 = 1; + var getTxrReasons = { + dequeue: "dequeue", + downscale: "downscale", + highQuality: "highQuality" + }; + var initDefaults = defaults$g({ + getKey: null, + doesEleInvalidateKey: falsify, + drawElement: null, + getBoundingBox: null, + getRotationPoint: null, + getRotationOffset: null, + isVisible: trueify, + allowEdgeTxrCaching: true, + allowParentTxrCaching: true + }); + var ElementTextureCache = function ElementTextureCache2(renderer3, initOptions) { + var self2 = this; + self2.renderer = renderer3; + self2.onDequeues = []; + var opts = initDefaults(initOptions); + extend(self2, opts); + self2.lookup = new ElementTextureCacheLookup(opts.getKey, opts.doesEleInvalidateKey); + self2.setupDequeueing(); + }; + var ETCp = ElementTextureCache.prototype; + ETCp.reasons = getTxrReasons; + ETCp.getTextureQueue = function(txrH) { + var self2 = this; + self2.eleImgCaches = self2.eleImgCaches || {}; + return self2.eleImgCaches[txrH] = self2.eleImgCaches[txrH] || []; + }; + ETCp.getRetiredTextureQueue = function(txrH) { + var self2 = this; + var rtxtrQs = self2.eleImgCaches.retired = self2.eleImgCaches.retired || {}; + var rtxtrQ = rtxtrQs[txrH] = rtxtrQs[txrH] || []; + return rtxtrQ; + }; + ETCp.getElementQueue = function() { + var self2 = this; + var q = self2.eleCacheQueue = self2.eleCacheQueue || new heap(function(a, b) { + return b.reqs - a.reqs; + }); + return q; + }; + ETCp.getElementKeyToQueue = function() { + var self2 = this; + var k2q = self2.eleKeyToCacheQueue = self2.eleKeyToCacheQueue || {}; + return k2q; + }; + ETCp.getElement = function(ele, bb, pxRatio, lvl, reason) { + var self2 = this; + var r = this.renderer; + var zoom = r.cy.zoom(); + var lookup2 = this.lookup; + if (!bb || bb.w === 0 || bb.h === 0 || isNaN(bb.w) || isNaN(bb.h) || !ele.visible() || ele.removed()) { + return null; + } + if (!self2.allowEdgeTxrCaching && ele.isEdge() || !self2.allowParentTxrCaching && ele.isParent()) { + return null; + } + if (lvl == null) { + lvl = Math.ceil(log2(zoom * pxRatio)); + } + if (lvl < minLvl$1) { + lvl = minLvl$1; + } else if (zoom >= maxZoom$1 || lvl > maxLvl$1) { + return null; + } + var scale = Math.pow(2, lvl); + var eleScaledH = bb.h * scale; + var eleScaledW = bb.w * scale; + var scaledLabelShown = r.eleTextBiggerThanMin(ele, scale); + if (!this.isVisible(ele, scaledLabelShown)) { + return null; + } + var eleCache = lookup2.get(ele, lvl); + if (eleCache && eleCache.invalidated) { + eleCache.invalidated = false; + eleCache.texture.invalidatedWidth -= eleCache.width; + } + if (eleCache) { + return eleCache; + } + var txrH; + if (eleScaledH <= minTxrH) { + txrH = minTxrH; + } else if (eleScaledH <= txrStepH) { + txrH = txrStepH; + } else { + txrH = Math.ceil(eleScaledH / txrStepH) * txrStepH; + } + if (eleScaledH > maxTxrH || eleScaledW > maxTxrW) { + return null; + } + var txrQ = self2.getTextureQueue(txrH); + var txr = txrQ[txrQ.length - 2]; + var addNewTxr = function addNewTxr2() { + return self2.recycleTexture(txrH, eleScaledW) || self2.addTexture(txrH, eleScaledW); + }; + if (!txr) { + txr = txrQ[txrQ.length - 1]; + } + if (!txr) { + txr = addNewTxr(); + } + if (txr.width - txr.usedWidth < eleScaledW) { + txr = addNewTxr(); + } + var scalableFrom = function scalableFrom2(otherCache) { + return otherCache && otherCache.scaledLabelShown === scaledLabelShown; + }; + var deqing = reason && reason === getTxrReasons.dequeue; + var highQualityReq = reason && reason === getTxrReasons.highQuality; + var downscaleReq = reason && reason === getTxrReasons.downscale; + var higherCache; + for (var l = lvl + 1; l <= maxLvl$1; l++) { + var c = lookup2.get(ele, l); + if (c) { + higherCache = c; + break; + } + } + var oneUpCache = higherCache && higherCache.level === lvl + 1 ? higherCache : null; + var downscale = function downscale2() { + txr.context.drawImage(oneUpCache.texture.canvas, oneUpCache.x, 0, oneUpCache.width, oneUpCache.height, txr.usedWidth, 0, eleScaledW, eleScaledH); + }; + txr.context.setTransform(1, 0, 0, 1, 0, 0); + txr.context.clearRect(txr.usedWidth, 0, eleScaledW, txrH); + if (scalableFrom(oneUpCache)) { + downscale(); + } else if (scalableFrom(higherCache)) { + if (highQualityReq) { + for (var _l = higherCache.level; _l > lvl; _l--) { + oneUpCache = self2.getElement(ele, bb, pxRatio, _l, getTxrReasons.downscale); + } + downscale(); + } else { + self2.queueElement(ele, higherCache.level - 1); + return higherCache; + } + } else { + var lowerCache; + if (!deqing && !highQualityReq && !downscaleReq) { + for (var _l2 = lvl - 1; _l2 >= minLvl$1; _l2--) { + var _c = lookup2.get(ele, _l2); + if (_c) { + lowerCache = _c; + break; + } + } + } + if (scalableFrom(lowerCache)) { + self2.queueElement(ele, lvl); + return lowerCache; + } + txr.context.translate(txr.usedWidth, 0); + txr.context.scale(scale, scale); + this.drawElement(txr.context, ele, bb, scaledLabelShown, false); + txr.context.scale(1 / scale, 1 / scale); + txr.context.translate(-txr.usedWidth, 0); + } + eleCache = { + x: txr.usedWidth, + texture: txr, + level: lvl, + scale, + width: eleScaledW, + height: eleScaledH, + scaledLabelShown + }; + txr.usedWidth += Math.ceil(eleScaledW + eleTxrSpacing); + txr.eleCaches.push(eleCache); + lookup2.set(ele, lvl, eleCache); + self2.checkTextureFullness(txr); + return eleCache; + }; + ETCp.invalidateElements = function(eles) { + for (var i2 = 0; i2 < eles.length; i2++) { + this.invalidateElement(eles[i2]); + } + }; + ETCp.invalidateElement = function(ele) { + var self2 = this; + var lookup2 = self2.lookup; + var caches = []; + var invalid = lookup2.isInvalid(ele); + if (!invalid) { + return; + } + for (var lvl = minLvl$1; lvl <= maxLvl$1; lvl++) { + var cache2 = lookup2.getForCachedKey(ele, lvl); + if (cache2) { + caches.push(cache2); + } + } + var noOtherElesUseCache = lookup2.invalidate(ele); + if (noOtherElesUseCache) { + for (var i2 = 0; i2 < caches.length; i2++) { + var _cache = caches[i2]; + var txr = _cache.texture; + txr.invalidatedWidth += _cache.width; + _cache.invalidated = true; + self2.checkTextureUtility(txr); + } + } + self2.removeFromQueue(ele); + }; + ETCp.checkTextureUtility = function(txr) { + if (txr.invalidatedWidth >= minUtility * txr.width) { + this.retireTexture(txr); + } + }; + ETCp.checkTextureFullness = function(txr) { + var self2 = this; + var txrQ = self2.getTextureQueue(txr.height); + if (txr.usedWidth / txr.width > maxFullness && txr.fullnessChecks >= maxFullnessChecks) { + removeFromArray(txrQ, txr); + } else { + txr.fullnessChecks++; + } + }; + ETCp.retireTexture = function(txr) { + var self2 = this; + var txrH = txr.height; + var txrQ = self2.getTextureQueue(txrH); + var lookup2 = this.lookup; + removeFromArray(txrQ, txr); + txr.retired = true; + var eleCaches = txr.eleCaches; + for (var i2 = 0; i2 < eleCaches.length; i2++) { + var eleCache = eleCaches[i2]; + lookup2.deleteCache(eleCache.key, eleCache.level); + } + clearArray(eleCaches); + var rtxtrQ = self2.getRetiredTextureQueue(txrH); + rtxtrQ.push(txr); + }; + ETCp.addTexture = function(txrH, minW) { + var self2 = this; + var txrQ = self2.getTextureQueue(txrH); + var txr = {}; + txrQ.push(txr); + txr.eleCaches = []; + txr.height = txrH; + txr.width = Math.max(defTxrWidth, minW); + txr.usedWidth = 0; + txr.invalidatedWidth = 0; + txr.fullnessChecks = 0; + txr.canvas = self2.renderer.makeOffscreenCanvas(txr.width, txr.height); + txr.context = txr.canvas.getContext("2d"); + return txr; + }; + ETCp.recycleTexture = function(txrH, minW) { + var self2 = this; + var txrQ = self2.getTextureQueue(txrH); + var rtxtrQ = self2.getRetiredTextureQueue(txrH); + for (var i2 = 0; i2 < rtxtrQ.length; i2++) { + var txr = rtxtrQ[i2]; + if (txr.width >= minW) { + txr.retired = false; + txr.usedWidth = 0; + txr.invalidatedWidth = 0; + txr.fullnessChecks = 0; + clearArray(txr.eleCaches); + txr.context.setTransform(1, 0, 0, 1, 0, 0); + txr.context.clearRect(0, 0, txr.width, txr.height); + removeFromArray(rtxtrQ, txr); + txrQ.push(txr); + return txr; + } + } + }; + ETCp.queueElement = function(ele, lvl) { + var self2 = this; + var q = self2.getElementQueue(); + var k2q = self2.getElementKeyToQueue(); + var key = this.getKey(ele); + var existingReq = k2q[key]; + if (existingReq) { + existingReq.level = Math.max(existingReq.level, lvl); + existingReq.eles.merge(ele); + existingReq.reqs++; + q.updateItem(existingReq); + } else { + var req = { + eles: ele.spawn().merge(ele), + level: lvl, + reqs: 1, + key + }; + q.push(req); + k2q[key] = req; + } + }; + ETCp.dequeue = function(pxRatio) { + var self2 = this; + var q = self2.getElementQueue(); + var k2q = self2.getElementKeyToQueue(); + var dequeued = []; + var lookup2 = self2.lookup; + for (var i2 = 0; i2 < maxDeqSize$1; i2++) { + if (q.size() > 0) { + var req = q.pop(); + var key = req.key; + var ele = req.eles[0]; + var cacheExists = lookup2.hasCache(ele, req.level); + k2q[key] = null; + if (cacheExists) { + continue; + } + dequeued.push(req); + var bb = self2.getBoundingBox(ele); + self2.getElement(ele, bb, pxRatio, req.level, getTxrReasons.dequeue); + } else { + break; + } + } + return dequeued; + }; + ETCp.removeFromQueue = function(ele) { + var self2 = this; + var q = self2.getElementQueue(); + var k2q = self2.getElementKeyToQueue(); + var key = this.getKey(ele); + var req = k2q[key]; + if (req != null) { + if (req.eles.length === 1) { + req.reqs = MAX_INT$1; + q.updateItem(req); + q.pop(); + k2q[key] = null; + } else { + req.eles.unmerge(ele); + } + } + }; + ETCp.onDequeue = function(fn2) { + this.onDequeues.push(fn2); + }; + ETCp.offDequeue = function(fn2) { + removeFromArray(this.onDequeues, fn2); + }; + ETCp.setupDequeueing = defs.setupDequeueing({ + deqRedrawThreshold: deqRedrawThreshold$1, + deqCost: deqCost$1, + deqAvgCost: deqAvgCost$1, + deqNoDrawCost: deqNoDrawCost$1, + deqFastCost: deqFastCost$1, + deq: function deq(self2, pxRatio, extent) { + return self2.dequeue(pxRatio, extent); + }, + onDeqd: function onDeqd(self2, deqd) { + for (var i2 = 0; i2 < self2.onDequeues.length; i2++) { + var fn2 = self2.onDequeues[i2]; + fn2(deqd); + } + }, + shouldRedraw: function shouldRedraw(self2, deqd, pxRatio, extent) { + for (var i2 = 0; i2 < deqd.length; i2++) { + var eles = deqd[i2].eles; + for (var j = 0; j < eles.length; j++) { + var bb = eles[j].boundingBox(); + if (boundingBoxesIntersect(bb, extent)) { + return true; + } + } + } + return false; + }, + priority: function priority(self2) { + return self2.renderer.beforeRenderPriorities.eleTxrDeq; + } + }); + var defNumLayers = 1; + var minLvl = -4; + var maxLvl = 2; + var maxZoom = 3.99; + var deqRedrawThreshold = 50; + var refineEleDebounceTime = 50; + var deqCost = 0.15; + var deqAvgCost = 0.1; + var deqNoDrawCost = 0.9; + var deqFastCost = 0.9; + var maxDeqSize = 1; + var invalidThreshold = 250; + var maxLayerArea = 4e3 * 4e3; + var useHighQualityEleTxrReqs = true; + var LayeredTextureCache = function LayeredTextureCache2(renderer3) { + var self2 = this; + var r = self2.renderer = renderer3; + var cy = r.cy; + self2.layersByLevel = {}; + self2.firstGet = true; + self2.lastInvalidationTime = performanceNow() - 2 * invalidThreshold; + self2.skipping = false; + self2.eleTxrDeqs = cy.collection(); + self2.scheduleElementRefinement = debounce_1(function() { + self2.refineElementTextures(self2.eleTxrDeqs); + self2.eleTxrDeqs.unmerge(self2.eleTxrDeqs); + }, refineEleDebounceTime); + r.beforeRender(function(willDraw, now2) { + if (now2 - self2.lastInvalidationTime <= invalidThreshold) { + self2.skipping = true; + } else { + self2.skipping = false; + } + }, r.beforeRenderPriorities.lyrTxrSkip); + var qSort = function qSort2(a, b) { + return b.reqs - a.reqs; + }; + self2.layersQueue = new heap(qSort); + self2.setupDequeueing(); + }; + var LTCp = LayeredTextureCache.prototype; + var layerIdPool = 0; + var MAX_INT = Math.pow(2, 53) - 1; + LTCp.makeLayer = function(bb, lvl) { + var scale = Math.pow(2, lvl); + var w = Math.ceil(bb.w * scale); + var h = Math.ceil(bb.h * scale); + var canvas = this.renderer.makeOffscreenCanvas(w, h); + var layer = { + id: layerIdPool = ++layerIdPool % MAX_INT, + bb, + level: lvl, + width: w, + height: h, + canvas, + context: canvas.getContext("2d"), + eles: [], + elesQueue: [], + reqs: 0 + }; + var cxt = layer.context; + var dx = -layer.bb.x1; + var dy = -layer.bb.y1; + cxt.scale(scale, scale); + cxt.translate(dx, dy); + return layer; + }; + LTCp.getLayers = function(eles, pxRatio, lvl) { + var self2 = this; + var r = self2.renderer; + var cy = r.cy; + var zoom = cy.zoom(); + var firstGet = self2.firstGet; + self2.firstGet = false; + if (lvl == null) { + lvl = Math.ceil(log2(zoom * pxRatio)); + if (lvl < minLvl) { + lvl = minLvl; + } else if (zoom >= maxZoom || lvl > maxLvl) { + return null; + } + } + self2.validateLayersElesOrdering(lvl, eles); + var layersByLvl = self2.layersByLevel; + var scale = Math.pow(2, lvl); + var layers = layersByLvl[lvl] = layersByLvl[lvl] || []; + var bb; + var lvlComplete = self2.levelIsComplete(lvl, eles); + var tmpLayers; + var checkTempLevels = function checkTempLevels2() { + var canUseAsTmpLvl = function canUseAsTmpLvl2(l) { + self2.validateLayersElesOrdering(l, eles); + if (self2.levelIsComplete(l, eles)) { + tmpLayers = layersByLvl[l]; + return true; + } + }; + var checkLvls = function checkLvls2(dir) { + if (tmpLayers) { + return; + } + for (var l = lvl + dir; minLvl <= l && l <= maxLvl; l += dir) { + if (canUseAsTmpLvl(l)) { + break; + } + } + }; + checkLvls(1); + checkLvls(-1); + for (var i3 = layers.length - 1; i3 >= 0; i3--) { + var layer2 = layers[i3]; + if (layer2.invalid) { + removeFromArray(layers, layer2); + } + } + }; + if (!lvlComplete) { + checkTempLevels(); + } else { + return layers; + } + var getBb = function getBb2() { + if (!bb) { + bb = makeBoundingBox(); + for (var i3 = 0; i3 < eles.length; i3++) { + updateBoundingBox(bb, eles[i3].boundingBox()); + } + } + return bb; + }; + var makeLayer = function makeLayer2(opts) { + opts = opts || {}; + var after = opts.after; + getBb(); + var area = bb.w * scale * (bb.h * scale); + if (area > maxLayerArea) { + return null; + } + var layer2 = self2.makeLayer(bb, lvl); + if (after != null) { + var index = layers.indexOf(after) + 1; + layers.splice(index, 0, layer2); + } else if (opts.insert === void 0 || opts.insert) { + layers.unshift(layer2); + } + return layer2; + }; + if (self2.skipping && !firstGet) { + return null; + } + var layer = null; + var maxElesPerLayer = eles.length / defNumLayers; + var allowLazyQueueing = !firstGet; + for (var i2 = 0; i2 < eles.length; i2++) { + var ele = eles[i2]; + var rs = ele._private.rscratch; + var caches = rs.imgLayerCaches = rs.imgLayerCaches || {}; + var existingLayer = caches[lvl]; + if (existingLayer) { + layer = existingLayer; + continue; + } + if (!layer || layer.eles.length >= maxElesPerLayer || !boundingBoxInBoundingBox(layer.bb, ele.boundingBox())) { + layer = makeLayer({ + insert: true, + after: layer + }); + if (!layer) { + return null; + } + } + if (tmpLayers || allowLazyQueueing) { + self2.queueLayer(layer, ele); + } else { + self2.drawEleInLayer(layer, ele, lvl, pxRatio); + } + layer.eles.push(ele); + caches[lvl] = layer; + } + if (tmpLayers) { + return tmpLayers; + } + if (allowLazyQueueing) { + return null; + } + return layers; + }; + LTCp.getEleLevelForLayerLevel = function(lvl, pxRatio) { + return lvl; + }; + LTCp.drawEleInLayer = function(layer, ele, lvl, pxRatio) { + var self2 = this; + var r = this.renderer; + var context = layer.context; + var bb = ele.boundingBox(); + if (bb.w === 0 || bb.h === 0 || !ele.visible()) { + return; + } + lvl = self2.getEleLevelForLayerLevel(lvl, pxRatio); + { + r.setImgSmoothing(context, false); + } + { + r.drawCachedElement(context, ele, null, null, lvl, useHighQualityEleTxrReqs); + } + { + r.setImgSmoothing(context, true); + } + }; + LTCp.levelIsComplete = function(lvl, eles) { + var self2 = this; + var layers = self2.layersByLevel[lvl]; + if (!layers || layers.length === 0) { + return false; + } + var numElesInLayers = 0; + for (var i2 = 0; i2 < layers.length; i2++) { + var layer = layers[i2]; + if (layer.reqs > 0) { + return false; + } + if (layer.invalid) { + return false; + } + numElesInLayers += layer.eles.length; + } + if (numElesInLayers !== eles.length) { + return false; + } + return true; + }; + LTCp.validateLayersElesOrdering = function(lvl, eles) { + var layers = this.layersByLevel[lvl]; + if (!layers) { + return; + } + for (var i2 = 0; i2 < layers.length; i2++) { + var layer = layers[i2]; + var offset = -1; + for (var j = 0; j < eles.length; j++) { + if (layer.eles[0] === eles[j]) { + offset = j; + break; + } + } + if (offset < 0) { + this.invalidateLayer(layer); + continue; + } + var o = offset; + for (var j = 0; j < layer.eles.length; j++) { + if (layer.eles[j] !== eles[o + j]) { + this.invalidateLayer(layer); + break; + } + } + } + }; + LTCp.updateElementsInLayers = function(eles, update2) { + var self2 = this; + var isEles = element(eles[0]); + for (var i2 = 0; i2 < eles.length; i2++) { + var req = isEles ? null : eles[i2]; + var ele = isEles ? eles[i2] : eles[i2].ele; + var rs = ele._private.rscratch; + var caches = rs.imgLayerCaches = rs.imgLayerCaches || {}; + for (var l = minLvl; l <= maxLvl; l++) { + var layer = caches[l]; + if (!layer) { + continue; + } + if (req && self2.getEleLevelForLayerLevel(layer.level) !== req.level) { + continue; + } + update2(layer, ele, req); + } + } + }; + LTCp.haveLayers = function() { + var self2 = this; + var haveLayers = false; + for (var l = minLvl; l <= maxLvl; l++) { + var layers = self2.layersByLevel[l]; + if (layers && layers.length > 0) { + haveLayers = true; + break; + } + } + return haveLayers; + }; + LTCp.invalidateElements = function(eles) { + var self2 = this; + if (eles.length === 0) { + return; + } + self2.lastInvalidationTime = performanceNow(); + if (eles.length === 0 || !self2.haveLayers()) { + return; + } + self2.updateElementsInLayers(eles, function invalAssocLayers(layer, ele, req) { + self2.invalidateLayer(layer); + }); + }; + LTCp.invalidateLayer = function(layer) { + this.lastInvalidationTime = performanceNow(); + if (layer.invalid) { + return; + } + var lvl = layer.level; + var eles = layer.eles; + var layers = this.layersByLevel[lvl]; + removeFromArray(layers, layer); + layer.elesQueue = []; + layer.invalid = true; + if (layer.replacement) { + layer.replacement.invalid = true; + } + for (var i2 = 0; i2 < eles.length; i2++) { + var caches = eles[i2]._private.rscratch.imgLayerCaches; + if (caches) { + caches[lvl] = null; + } + } + }; + LTCp.refineElementTextures = function(eles) { + var self2 = this; + self2.updateElementsInLayers(eles, function refineEachEle(layer, ele, req) { + var rLyr = layer.replacement; + if (!rLyr) { + rLyr = layer.replacement = self2.makeLayer(layer.bb, layer.level); + rLyr.replaces = layer; + rLyr.eles = layer.eles; + } + if (!rLyr.reqs) { + for (var i2 = 0; i2 < rLyr.eles.length; i2++) { + self2.queueLayer(rLyr, rLyr.eles[i2]); + } + } + }); + }; + LTCp.enqueueElementRefinement = function(ele) { + this.eleTxrDeqs.merge(ele); + this.scheduleElementRefinement(); + }; + LTCp.queueLayer = function(layer, ele) { + var self2 = this; + var q = self2.layersQueue; + var elesQ = layer.elesQueue; + var hasId = elesQ.hasId = elesQ.hasId || {}; + if (layer.replacement) { + return; + } + if (ele) { + if (hasId[ele.id()]) { + return; + } + elesQ.push(ele); + hasId[ele.id()] = true; + } + if (layer.reqs) { + layer.reqs++; + q.updateItem(layer); + } else { + layer.reqs = 1; + q.push(layer); + } + }; + LTCp.dequeue = function(pxRatio) { + var self2 = this; + var q = self2.layersQueue; + var deqd = []; + var eleDeqs = 0; + while (eleDeqs < maxDeqSize) { + if (q.size() === 0) { + break; + } + var layer = q.peek(); + if (layer.replacement) { + q.pop(); + continue; + } + if (layer.replaces && layer !== layer.replaces.replacement) { + q.pop(); + continue; + } + if (layer.invalid) { + q.pop(); + continue; + } + var ele = layer.elesQueue.shift(); + if (ele) { + self2.drawEleInLayer(layer, ele, layer.level, pxRatio); + eleDeqs++; + } + if (deqd.length === 0) { + deqd.push(true); + } + if (layer.elesQueue.length === 0) { + q.pop(); + layer.reqs = 0; + if (layer.replaces) { + self2.applyLayerReplacement(layer); + } + self2.requestRedraw(); + } + } + return deqd; + }; + LTCp.applyLayerReplacement = function(layer) { + var self2 = this; + var layersInLevel = self2.layersByLevel[layer.level]; + var replaced = layer.replaces; + var index = layersInLevel.indexOf(replaced); + if (index < 0 || replaced.invalid) { + return; + } + layersInLevel[index] = layer; + for (var i2 = 0; i2 < layer.eles.length; i2++) { + var _p = layer.eles[i2]._private; + var cache2 = _p.imgLayerCaches = _p.imgLayerCaches || {}; + if (cache2) { + cache2[layer.level] = layer; + } + } + self2.requestRedraw(); + }; + LTCp.requestRedraw = debounce_1(function() { + var r = this.renderer; + r.redrawHint("eles", true); + r.redrawHint("drag", true); + r.redraw(); + }, 100); + LTCp.setupDequeueing = defs.setupDequeueing({ + deqRedrawThreshold, + deqCost, + deqAvgCost, + deqNoDrawCost, + deqFastCost, + deq: function deq(self2, pxRatio) { + return self2.dequeue(pxRatio); + }, + onDeqd: noop$1, + shouldRedraw: trueify, + priority: function priority(self2) { + return self2.renderer.beforeRenderPriorities.lyrTxrDeq; + } + }); + var CRp$a = {}; + var impl; + function polygon(context, points) { + for (var i2 = 0; i2 < points.length; i2++) { + var pt = points[i2]; + context.lineTo(pt.x, pt.y); + } + } + function triangleBackcurve(context, points, controlPoint) { + var firstPt; + for (var i2 = 0; i2 < points.length; i2++) { + var pt = points[i2]; + if (i2 === 0) { + firstPt = pt; + } + context.lineTo(pt.x, pt.y); + } + context.quadraticCurveTo(controlPoint.x, controlPoint.y, firstPt.x, firstPt.y); + } + function triangleTee(context, trianglePoints, teePoints) { + if (context.beginPath) { + context.beginPath(); + } + var triPts = trianglePoints; + for (var i2 = 0; i2 < triPts.length; i2++) { + var pt = triPts[i2]; + context.lineTo(pt.x, pt.y); + } + var teePts = teePoints; + var firstTeePt = teePoints[0]; + context.moveTo(firstTeePt.x, firstTeePt.y); + for (var i2 = 1; i2 < teePts.length; i2++) { + var pt = teePts[i2]; + context.lineTo(pt.x, pt.y); + } + if (context.closePath) { + context.closePath(); + } + } + function circleTriangle(context, trianglePoints, rx, ry, r) { + if (context.beginPath) { + context.beginPath(); + } + context.arc(rx, ry, r, 0, Math.PI * 2, false); + var triPts = trianglePoints; + var firstTrPt = triPts[0]; + context.moveTo(firstTrPt.x, firstTrPt.y); + for (var i2 = 0; i2 < triPts.length; i2++) { + var pt = triPts[i2]; + context.lineTo(pt.x, pt.y); + } + if (context.closePath) { + context.closePath(); + } + } + function circle(context, rx, ry, r) { + context.arc(rx, ry, r, 0, Math.PI * 2, false); + } + CRp$a.arrowShapeImpl = function(name) { + return (impl || (impl = { + "polygon": polygon, + "triangle-backcurve": triangleBackcurve, + "triangle-tee": triangleTee, + "circle-triangle": circleTriangle, + "triangle-cross": triangleTee, + "circle": circle + }))[name]; + }; + var CRp$9 = {}; + CRp$9.drawElement = function(context, ele, shiftToOriginWithBb, showLabel, showOverlay, showOpacity) { + var r = this; + if (ele.isNode()) { + r.drawNode(context, ele, shiftToOriginWithBb, showLabel, showOverlay, showOpacity); + } else { + r.drawEdge(context, ele, shiftToOriginWithBb, showLabel, showOverlay, showOpacity); + } + }; + CRp$9.drawElementOverlay = function(context, ele) { + var r = this; + if (ele.isNode()) { + r.drawNodeOverlay(context, ele); + } else { + r.drawEdgeOverlay(context, ele); + } + }; + CRp$9.drawElementUnderlay = function(context, ele) { + var r = this; + if (ele.isNode()) { + r.drawNodeUnderlay(context, ele); + } else { + r.drawEdgeUnderlay(context, ele); + } + }; + CRp$9.drawCachedElementPortion = function(context, ele, eleTxrCache, pxRatio, lvl, reason, getRotation, getOpacity2) { + var r = this; + var bb = eleTxrCache.getBoundingBox(ele); + if (bb.w === 0 || bb.h === 0) { + return; + } + var eleCache = eleTxrCache.getElement(ele, bb, pxRatio, lvl, reason); + if (eleCache != null) { + var opacity = getOpacity2(r, ele); + if (opacity === 0) { + return; + } + var theta = getRotation(r, ele); + var x1 = bb.x1, y1 = bb.y1, w = bb.w, h = bb.h; + var x, y, sx, sy, smooth; + if (theta !== 0) { + var rotPt = eleTxrCache.getRotationPoint(ele); + sx = rotPt.x; + sy = rotPt.y; + context.translate(sx, sy); + context.rotate(theta); + smooth = r.getImgSmoothing(context); + if (!smooth) { + r.setImgSmoothing(context, true); + } + var off = eleTxrCache.getRotationOffset(ele); + x = off.x; + y = off.y; + } else { + x = x1; + y = y1; + } + var oldGlobalAlpha; + if (opacity !== 1) { + oldGlobalAlpha = context.globalAlpha; + context.globalAlpha = oldGlobalAlpha * opacity; + } + context.drawImage(eleCache.texture.canvas, eleCache.x, 0, eleCache.width, eleCache.height, x, y, w, h); + if (opacity !== 1) { + context.globalAlpha = oldGlobalAlpha; + } + if (theta !== 0) { + context.rotate(-theta); + context.translate(-sx, -sy); + if (!smooth) { + r.setImgSmoothing(context, false); + } + } + } else { + eleTxrCache.drawElement(context, ele); + } + }; + var getZeroRotation = function getZeroRotation2() { + return 0; + }; + var getLabelRotation = function getLabelRotation2(r, ele) { + return r.getTextAngle(ele, null); + }; + var getSourceLabelRotation = function getSourceLabelRotation2(r, ele) { + return r.getTextAngle(ele, "source"); + }; + var getTargetLabelRotation = function getTargetLabelRotation2(r, ele) { + return r.getTextAngle(ele, "target"); + }; + var getOpacity = function getOpacity2(r, ele) { + return ele.effectiveOpacity(); + }; + var getTextOpacity = function getTextOpacity2(e, ele) { + return ele.pstyle("text-opacity").pfValue * ele.effectiveOpacity(); + }; + CRp$9.drawCachedElement = function(context, ele, pxRatio, extent, lvl, requestHighQuality) { + var r = this; + var _r$data = r.data, eleTxrCache = _r$data.eleTxrCache, lblTxrCache = _r$data.lblTxrCache, slbTxrCache = _r$data.slbTxrCache, tlbTxrCache = _r$data.tlbTxrCache; + var bb = ele.boundingBox(); + var reason = requestHighQuality === true ? eleTxrCache.reasons.highQuality : null; + if (bb.w === 0 || bb.h === 0 || !ele.visible()) { + return; + } + if (!extent || boundingBoxesIntersect(bb, extent)) { + var isEdge = ele.isEdge(); + var badLine = ele.element()._private.rscratch.badLine; + r.drawElementUnderlay(context, ele); + r.drawCachedElementPortion(context, ele, eleTxrCache, pxRatio, lvl, reason, getZeroRotation, getOpacity); + if (!isEdge || !badLine) { + r.drawCachedElementPortion(context, ele, lblTxrCache, pxRatio, lvl, reason, getLabelRotation, getTextOpacity); + } + if (isEdge && !badLine) { + r.drawCachedElementPortion(context, ele, slbTxrCache, pxRatio, lvl, reason, getSourceLabelRotation, getTextOpacity); + r.drawCachedElementPortion(context, ele, tlbTxrCache, pxRatio, lvl, reason, getTargetLabelRotation, getTextOpacity); + } + r.drawElementOverlay(context, ele); + } + }; + CRp$9.drawElements = function(context, eles) { + var r = this; + for (var i2 = 0; i2 < eles.length; i2++) { + var ele = eles[i2]; + r.drawElement(context, ele); + } + }; + CRp$9.drawCachedElements = function(context, eles, pxRatio, extent) { + var r = this; + for (var i2 = 0; i2 < eles.length; i2++) { + var ele = eles[i2]; + r.drawCachedElement(context, ele, pxRatio, extent); + } + }; + CRp$9.drawCachedNodes = function(context, eles, pxRatio, extent) { + var r = this; + for (var i2 = 0; i2 < eles.length; i2++) { + var ele = eles[i2]; + if (!ele.isNode()) { + continue; + } + r.drawCachedElement(context, ele, pxRatio, extent); + } + }; + CRp$9.drawLayeredElements = function(context, eles, pxRatio, extent) { + var r = this; + var layers = r.data.lyrTxrCache.getLayers(eles, pxRatio); + if (layers) { + for (var i2 = 0; i2 < layers.length; i2++) { + var layer = layers[i2]; + var bb = layer.bb; + if (bb.w === 0 || bb.h === 0) { + continue; + } + context.drawImage(layer.canvas, bb.x1, bb.y1, bb.w, bb.h); + } + } else { + r.drawCachedElements(context, eles, pxRatio, extent); + } + }; + var CRp$8 = {}; + CRp$8.drawEdge = function(context, edge, shiftToOriginWithBb) { + var drawLabel = arguments.length > 3 && arguments[3] !== void 0 ? arguments[3] : true; + var shouldDrawOverlay = arguments.length > 4 && arguments[4] !== void 0 ? arguments[4] : true; + var shouldDrawOpacity = arguments.length > 5 && arguments[5] !== void 0 ? arguments[5] : true; + var r = this; + var rs = edge._private.rscratch; + if (shouldDrawOpacity && !edge.visible()) { + return; + } + if (rs.badLine || rs.allpts == null || isNaN(rs.allpts[0])) { + return; + } + var bb; + if (shiftToOriginWithBb) { + bb = shiftToOriginWithBb; + context.translate(-bb.x1, -bb.y1); + } + var opacity = shouldDrawOpacity ? edge.pstyle("opacity").value : 1; + var lineOpacity = shouldDrawOpacity ? edge.pstyle("line-opacity").value : 1; + var curveStyle = edge.pstyle("curve-style").value; + var lineStyle = edge.pstyle("line-style").value; + var edgeWidth = edge.pstyle("width").pfValue; + var lineCap = edge.pstyle("line-cap").value; + var effectiveLineOpacity = opacity * lineOpacity; + var effectiveArrowOpacity = opacity * lineOpacity; + var drawLine = function drawLine2() { + var strokeOpacity = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : effectiveLineOpacity; + if (curveStyle === "straight-triangle") { + r.eleStrokeStyle(context, edge, strokeOpacity); + r.drawEdgeTrianglePath(edge, context, rs.allpts); + } else { + context.lineWidth = edgeWidth; + context.lineCap = lineCap; + r.eleStrokeStyle(context, edge, strokeOpacity); + r.drawEdgePath(edge, context, rs.allpts, lineStyle); + context.lineCap = "butt"; + } + }; + var drawOverlay = function drawOverlay2() { + if (!shouldDrawOverlay) { + return; + } + r.drawEdgeOverlay(context, edge); + }; + var drawUnderlay = function drawUnderlay2() { + if (!shouldDrawOverlay) { + return; + } + r.drawEdgeUnderlay(context, edge); + }; + var drawArrows = function drawArrows2() { + var arrowOpacity = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : effectiveArrowOpacity; + r.drawArrowheads(context, edge, arrowOpacity); + }; + var drawText = function drawText2() { + r.drawElementText(context, edge, null, drawLabel); + }; + context.lineJoin = "round"; + var ghost = edge.pstyle("ghost").value === "yes"; + if (ghost) { + var gx = edge.pstyle("ghost-offset-x").pfValue; + var gy = edge.pstyle("ghost-offset-y").pfValue; + var ghostOpacity = edge.pstyle("ghost-opacity").value; + var effectiveGhostOpacity = effectiveLineOpacity * ghostOpacity; + context.translate(gx, gy); + drawLine(effectiveGhostOpacity); + drawArrows(effectiveGhostOpacity); + context.translate(-gx, -gy); + } + drawUnderlay(); + drawLine(); + drawArrows(); + drawOverlay(); + drawText(); + if (shiftToOriginWithBb) { + context.translate(bb.x1, bb.y1); + } + }; + var drawEdgeOverlayUnderlay = function drawEdgeOverlayUnderlay2(overlayOrUnderlay) { + if (!["overlay", "underlay"].includes(overlayOrUnderlay)) { + throw new Error("Invalid state"); + } + return function(context, edge) { + if (!edge.visible()) { + return; + } + var opacity = edge.pstyle("".concat(overlayOrUnderlay, "-opacity")).value; + if (opacity === 0) { + return; + } + var r = this; + var usePaths = r.usePaths(); + var rs = edge._private.rscratch; + var padding = edge.pstyle("".concat(overlayOrUnderlay, "-padding")).pfValue; + var width = 2 * padding; + var color = edge.pstyle("".concat(overlayOrUnderlay, "-color")).value; + context.lineWidth = width; + if (rs.edgeType === "self" && !usePaths) { + context.lineCap = "butt"; + } else { + context.lineCap = "round"; + } + r.colorStrokeStyle(context, color[0], color[1], color[2], opacity); + r.drawEdgePath(edge, context, rs.allpts, "solid"); + }; + }; + CRp$8.drawEdgeOverlay = drawEdgeOverlayUnderlay("overlay"); + CRp$8.drawEdgeUnderlay = drawEdgeOverlayUnderlay("underlay"); + CRp$8.drawEdgePath = function(edge, context, pts2, type) { + var rs = edge._private.rscratch; + var canvasCxt = context; + var path; + var pathCacheHit = false; + var usePaths = this.usePaths(); + var lineDashPattern = edge.pstyle("line-dash-pattern").pfValue; + var lineDashOffset = edge.pstyle("line-dash-offset").pfValue; + if (usePaths) { + var pathCacheKey = pts2.join("$"); + var keyMatches = rs.pathCacheKey && rs.pathCacheKey === pathCacheKey; + if (keyMatches) { + path = context = rs.pathCache; + pathCacheHit = true; + } else { + path = context = new Path2D(); + rs.pathCacheKey = pathCacheKey; + rs.pathCache = path; + } + } + if (canvasCxt.setLineDash) { + switch (type) { + case "dotted": + canvasCxt.setLineDash([1, 1]); + break; + case "dashed": + canvasCxt.setLineDash(lineDashPattern); + canvasCxt.lineDashOffset = lineDashOffset; + break; + case "solid": + canvasCxt.setLineDash([]); + break; + } + } + if (!pathCacheHit && !rs.badLine) { + if (context.beginPath) { + context.beginPath(); + } + context.moveTo(pts2[0], pts2[1]); + switch (rs.edgeType) { + case "bezier": + case "self": + case "compound": + case "multibezier": + for (var i2 = 2; i2 + 3 < pts2.length; i2 += 4) { + context.quadraticCurveTo(pts2[i2], pts2[i2 + 1], pts2[i2 + 2], pts2[i2 + 3]); + } + break; + case "straight": + case "segments": + case "haystack": + for (var _i = 2; _i + 1 < pts2.length; _i += 2) { + context.lineTo(pts2[_i], pts2[_i + 1]); + } + break; + } + } + context = canvasCxt; + if (usePaths) { + context.stroke(path); + } else { + context.stroke(); + } + if (context.setLineDash) { + context.setLineDash([]); + } + }; + CRp$8.drawEdgeTrianglePath = function(edge, context, pts2) { + context.fillStyle = context.strokeStyle; + var edgeWidth = edge.pstyle("width").pfValue; + for (var i2 = 0; i2 + 1 < pts2.length; i2 += 2) { + var vector = [pts2[i2 + 2] - pts2[i2], pts2[i2 + 3] - pts2[i2 + 1]]; + var length = Math.sqrt(vector[0] * vector[0] + vector[1] * vector[1]); + var normal = [vector[1] / length, -vector[0] / length]; + var triangleHead = [normal[0] * edgeWidth / 2, normal[1] * edgeWidth / 2]; + context.beginPath(); + context.moveTo(pts2[i2] - triangleHead[0], pts2[i2 + 1] - triangleHead[1]); + context.lineTo(pts2[i2] + triangleHead[0], pts2[i2 + 1] + triangleHead[1]); + context.lineTo(pts2[i2 + 2], pts2[i2 + 3]); + context.closePath(); + context.fill(); + } + }; + CRp$8.drawArrowheads = function(context, edge, opacity) { + var rs = edge._private.rscratch; + var isHaystack = rs.edgeType === "haystack"; + if (!isHaystack) { + this.drawArrowhead(context, edge, "source", rs.arrowStartX, rs.arrowStartY, rs.srcArrowAngle, opacity); + } + this.drawArrowhead(context, edge, "mid-target", rs.midX, rs.midY, rs.midtgtArrowAngle, opacity); + this.drawArrowhead(context, edge, "mid-source", rs.midX, rs.midY, rs.midsrcArrowAngle, opacity); + if (!isHaystack) { + this.drawArrowhead(context, edge, "target", rs.arrowEndX, rs.arrowEndY, rs.tgtArrowAngle, opacity); + } + }; + CRp$8.drawArrowhead = function(context, edge, prefix, x, y, angle, opacity) { + if (isNaN(x) || x == null || isNaN(y) || y == null || isNaN(angle) || angle == null) { + return; + } + var self2 = this; + var arrowShape = edge.pstyle(prefix + "-arrow-shape").value; + if (arrowShape === "none") { + return; + } + var arrowClearFill = edge.pstyle(prefix + "-arrow-fill").value === "hollow" ? "both" : "filled"; + var arrowFill = edge.pstyle(prefix + "-arrow-fill").value; + var edgeWidth = edge.pstyle("width").pfValue; + var pArrowWidth = edge.pstyle(prefix + "-arrow-width"); + var arrowWidth = pArrowWidth.value === "match-line" ? edgeWidth : pArrowWidth.pfValue; + if (pArrowWidth.units === "%") + arrowWidth *= edgeWidth; + var edgeOpacity = edge.pstyle("opacity").value; + if (opacity === void 0) { + opacity = edgeOpacity; + } + var gco = context.globalCompositeOperation; + if (opacity !== 1 || arrowFill === "hollow") { + context.globalCompositeOperation = "destination-out"; + self2.colorFillStyle(context, 255, 255, 255, 1); + self2.colorStrokeStyle(context, 255, 255, 255, 1); + self2.drawArrowShape(edge, context, arrowClearFill, edgeWidth, arrowShape, arrowWidth, x, y, angle); + context.globalCompositeOperation = gco; + } + var color = edge.pstyle(prefix + "-arrow-color").value; + self2.colorFillStyle(context, color[0], color[1], color[2], opacity); + self2.colorStrokeStyle(context, color[0], color[1], color[2], opacity); + self2.drawArrowShape(edge, context, arrowFill, edgeWidth, arrowShape, arrowWidth, x, y, angle); + }; + CRp$8.drawArrowShape = function(edge, context, fill, edgeWidth, shape, shapeWidth, x, y, angle) { + var r = this; + var usePaths = this.usePaths() && shape !== "triangle-cross"; + var pathCacheHit = false; + var path; + var canvasContext = context; + var translation = { + x, + y + }; + var scale = edge.pstyle("arrow-scale").value; + var size = this.getArrowWidth(edgeWidth, scale); + var shapeImpl = r.arrowShapes[shape]; + if (usePaths) { + var cache2 = r.arrowPathCache = r.arrowPathCache || []; + var key = hashString(shape); + var cachedPath = cache2[key]; + if (cachedPath != null) { + path = context = cachedPath; + pathCacheHit = true; + } else { + path = context = new Path2D(); + cache2[key] = path; + } + } + if (!pathCacheHit) { + if (context.beginPath) { + context.beginPath(); + } + if (usePaths) { + shapeImpl.draw(context, 1, 0, { + x: 0, + y: 0 + }, 1); + } else { + shapeImpl.draw(context, size, angle, translation, edgeWidth); + } + if (context.closePath) { + context.closePath(); + } + } + context = canvasContext; + if (usePaths) { + context.translate(x, y); + context.rotate(angle); + context.scale(size, size); + } + if (fill === "filled" || fill === "both") { + if (usePaths) { + context.fill(path); + } else { + context.fill(); + } + } + if (fill === "hollow" || fill === "both") { + context.lineWidth = shapeWidth / (usePaths ? size : 1); + context.lineJoin = "miter"; + if (usePaths) { + context.stroke(path); + } else { + context.stroke(); + } + } + if (usePaths) { + context.scale(1 / size, 1 / size); + context.rotate(-angle); + context.translate(-x, -y); + } + }; + var CRp$7 = {}; + CRp$7.safeDrawImage = function(context, img, ix, iy, iw, ih, x, y, w, h) { + if (iw <= 0 || ih <= 0 || w <= 0 || h <= 0) { + return; + } + try { + context.drawImage(img, ix, iy, iw, ih, x, y, w, h); + } catch (e) { + warn(e); + } + }; + CRp$7.drawInscribedImage = function(context, img, node, index, nodeOpacity) { + var r = this; + var pos = node.position(); + var nodeX = pos.x; + var nodeY = pos.y; + var styleObj = node.cy().style(); + var getIndexedStyle = styleObj.getIndexedStyle.bind(styleObj); + var fit = getIndexedStyle(node, "background-fit", "value", index); + var repeat = getIndexedStyle(node, "background-repeat", "value", index); + var nodeW = node.width(); + var nodeH = node.height(); + var paddingX2 = node.padding() * 2; + var nodeTW = nodeW + (getIndexedStyle(node, "background-width-relative-to", "value", index) === "inner" ? 0 : paddingX2); + var nodeTH = nodeH + (getIndexedStyle(node, "background-height-relative-to", "value", index) === "inner" ? 0 : paddingX2); + var rs = node._private.rscratch; + var clip = getIndexedStyle(node, "background-clip", "value", index); + var shouldClip = clip === "node"; + var imgOpacity = getIndexedStyle(node, "background-image-opacity", "value", index) * nodeOpacity; + var smooth = getIndexedStyle(node, "background-image-smoothing", "value", index); + var imgW = img.width || img.cachedW; + var imgH = img.height || img.cachedH; + if (null == imgW || null == imgH) { + document.body.appendChild(img); + imgW = img.cachedW = img.width || img.offsetWidth; + imgH = img.cachedH = img.height || img.offsetHeight; + document.body.removeChild(img); + } + var w = imgW; + var h = imgH; + if (getIndexedStyle(node, "background-width", "value", index) !== "auto") { + if (getIndexedStyle(node, "background-width", "units", index) === "%") { + w = getIndexedStyle(node, "background-width", "pfValue", index) * nodeTW; + } else { + w = getIndexedStyle(node, "background-width", "pfValue", index); + } + } + if (getIndexedStyle(node, "background-height", "value", index) !== "auto") { + if (getIndexedStyle(node, "background-height", "units", index) === "%") { + h = getIndexedStyle(node, "background-height", "pfValue", index) * nodeTH; + } else { + h = getIndexedStyle(node, "background-height", "pfValue", index); + } + } + if (w === 0 || h === 0) { + return; + } + if (fit === "contain") { + var scale = Math.min(nodeTW / w, nodeTH / h); + w *= scale; + h *= scale; + } else if (fit === "cover") { + var scale = Math.max(nodeTW / w, nodeTH / h); + w *= scale; + h *= scale; + } + var x = nodeX - nodeTW / 2; + var posXUnits = getIndexedStyle(node, "background-position-x", "units", index); + var posXPfVal = getIndexedStyle(node, "background-position-x", "pfValue", index); + if (posXUnits === "%") { + x += (nodeTW - w) * posXPfVal; + } else { + x += posXPfVal; + } + var offXUnits = getIndexedStyle(node, "background-offset-x", "units", index); + var offXPfVal = getIndexedStyle(node, "background-offset-x", "pfValue", index); + if (offXUnits === "%") { + x += (nodeTW - w) * offXPfVal; + } else { + x += offXPfVal; + } + var y = nodeY - nodeTH / 2; + var posYUnits = getIndexedStyle(node, "background-position-y", "units", index); + var posYPfVal = getIndexedStyle(node, "background-position-y", "pfValue", index); + if (posYUnits === "%") { + y += (nodeTH - h) * posYPfVal; + } else { + y += posYPfVal; + } + var offYUnits = getIndexedStyle(node, "background-offset-y", "units", index); + var offYPfVal = getIndexedStyle(node, "background-offset-y", "pfValue", index); + if (offYUnits === "%") { + y += (nodeTH - h) * offYPfVal; + } else { + y += offYPfVal; + } + if (rs.pathCache) { + x -= nodeX; + y -= nodeY; + nodeX = 0; + nodeY = 0; + } + var gAlpha = context.globalAlpha; + context.globalAlpha = imgOpacity; + var smoothingEnabled = r.getImgSmoothing(context); + var isSmoothingSwitched = false; + if (smooth === "no" && smoothingEnabled) { + r.setImgSmoothing(context, false); + isSmoothingSwitched = true; + } else if (smooth === "yes" && !smoothingEnabled) { + r.setImgSmoothing(context, true); + isSmoothingSwitched = true; + } + if (repeat === "no-repeat") { + if (shouldClip) { + context.save(); + if (rs.pathCache) { + context.clip(rs.pathCache); + } else { + r.nodeShapes[r.getNodeShape(node)].draw(context, nodeX, nodeY, nodeTW, nodeTH); + context.clip(); + } + } + r.safeDrawImage(context, img, 0, 0, imgW, imgH, x, y, w, h); + if (shouldClip) { + context.restore(); + } + } else { + var pattern = context.createPattern(img, repeat); + context.fillStyle = pattern; + r.nodeShapes[r.getNodeShape(node)].draw(context, nodeX, nodeY, nodeTW, nodeTH); + context.translate(x, y); + context.fill(); + context.translate(-x, -y); + } + context.globalAlpha = gAlpha; + if (isSmoothingSwitched) { + r.setImgSmoothing(context, smoothingEnabled); + } + }; + var CRp$6 = {}; + CRp$6.eleTextBiggerThanMin = function(ele, scale) { + if (!scale) { + var zoom = ele.cy().zoom(); + var pxRatio = this.getPixelRatio(); + var lvl = Math.ceil(log2(zoom * pxRatio)); + scale = Math.pow(2, lvl); + } + var computedSize = ele.pstyle("font-size").pfValue * scale; + var minSize = ele.pstyle("min-zoomed-font-size").pfValue; + if (computedSize < minSize) { + return false; + } + return true; + }; + CRp$6.drawElementText = function(context, ele, shiftToOriginWithBb, force, prefix) { + var useEleOpacity = arguments.length > 5 && arguments[5] !== void 0 ? arguments[5] : true; + var r = this; + if (force == null) { + if (useEleOpacity && !r.eleTextBiggerThanMin(ele)) { + return; + } + } else if (force === false) { + return; + } + if (ele.isNode()) { + var label = ele.pstyle("label"); + if (!label || !label.value) { + return; + } + var justification = r.getLabelJustification(ele); + context.textAlign = justification; + context.textBaseline = "bottom"; + } else { + var badLine = ele.element()._private.rscratch.badLine; + var _label = ele.pstyle("label"); + var srcLabel = ele.pstyle("source-label"); + var tgtLabel = ele.pstyle("target-label"); + if (badLine || (!_label || !_label.value) && (!srcLabel || !srcLabel.value) && (!tgtLabel || !tgtLabel.value)) { + return; + } + context.textAlign = "center"; + context.textBaseline = "bottom"; + } + var applyRotation = !shiftToOriginWithBb; + var bb; + if (shiftToOriginWithBb) { + bb = shiftToOriginWithBb; + context.translate(-bb.x1, -bb.y1); + } + if (prefix == null) { + r.drawText(context, ele, null, applyRotation, useEleOpacity); + if (ele.isEdge()) { + r.drawText(context, ele, "source", applyRotation, useEleOpacity); + r.drawText(context, ele, "target", applyRotation, useEleOpacity); + } + } else { + r.drawText(context, ele, prefix, applyRotation, useEleOpacity); + } + if (shiftToOriginWithBb) { + context.translate(bb.x1, bb.y1); + } + }; + CRp$6.getFontCache = function(context) { + var cache2; + this.fontCaches = this.fontCaches || []; + for (var i2 = 0; i2 < this.fontCaches.length; i2++) { + cache2 = this.fontCaches[i2]; + if (cache2.context === context) { + return cache2; + } + } + cache2 = { + context + }; + this.fontCaches.push(cache2); + return cache2; + }; + CRp$6.setupTextStyle = function(context, ele) { + var useEleOpacity = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : true; + var labelStyle = ele.pstyle("font-style").strValue; + var labelSize = ele.pstyle("font-size").pfValue + "px"; + var labelFamily = ele.pstyle("font-family").strValue; + var labelWeight = ele.pstyle("font-weight").strValue; + var opacity = useEleOpacity ? ele.effectiveOpacity() * ele.pstyle("text-opacity").value : 1; + var outlineOpacity = ele.pstyle("text-outline-opacity").value * opacity; + var color = ele.pstyle("color").value; + var outlineColor = ele.pstyle("text-outline-color").value; + context.font = labelStyle + " " + labelWeight + " " + labelSize + " " + labelFamily; + context.lineJoin = "round"; + this.colorFillStyle(context, color[0], color[1], color[2], opacity); + this.colorStrokeStyle(context, outlineColor[0], outlineColor[1], outlineColor[2], outlineOpacity); + }; + function roundRect(ctx, x, y, width, height) { + var radius = arguments.length > 5 && arguments[5] !== void 0 ? arguments[5] : 5; + var stroke = arguments.length > 6 ? arguments[6] : void 0; + ctx.beginPath(); + ctx.moveTo(x + radius, y); + ctx.lineTo(x + width - radius, y); + ctx.quadraticCurveTo(x + width, y, x + width, y + radius); + ctx.lineTo(x + width, y + height - radius); + ctx.quadraticCurveTo(x + width, y + height, x + width - radius, y + height); + ctx.lineTo(x + radius, y + height); + ctx.quadraticCurveTo(x, y + height, x, y + height - radius); + ctx.lineTo(x, y + radius); + ctx.quadraticCurveTo(x, y, x + radius, y); + ctx.closePath(); + if (stroke) + ctx.stroke(); + else + ctx.fill(); + } + CRp$6.getTextAngle = function(ele, prefix) { + var theta; + var _p = ele._private; + var rscratch = _p.rscratch; + var pdash = prefix ? prefix + "-" : ""; + var rotation = ele.pstyle(pdash + "text-rotation"); + var textAngle = getPrefixedProperty(rscratch, "labelAngle", prefix); + if (rotation.strValue === "autorotate") { + theta = ele.isEdge() ? textAngle : 0; + } else if (rotation.strValue === "none") { + theta = 0; + } else { + theta = rotation.pfValue; + } + return theta; + }; + CRp$6.drawText = function(context, ele, prefix) { + var applyRotation = arguments.length > 3 && arguments[3] !== void 0 ? arguments[3] : true; + var useEleOpacity = arguments.length > 4 && arguments[4] !== void 0 ? arguments[4] : true; + var _p = ele._private; + var rscratch = _p.rscratch; + var parentOpacity = useEleOpacity ? ele.effectiveOpacity() : 1; + if (useEleOpacity && (parentOpacity === 0 || ele.pstyle("text-opacity").value === 0)) { + return; + } + if (prefix === "main") { + prefix = null; + } + var textX = getPrefixedProperty(rscratch, "labelX", prefix); + var textY = getPrefixedProperty(rscratch, "labelY", prefix); + var orgTextX, orgTextY; + var text = this.getLabelText(ele, prefix); + if (text != null && text !== "" && !isNaN(textX) && !isNaN(textY)) { + this.setupTextStyle(context, ele, useEleOpacity); + var pdash = prefix ? prefix + "-" : ""; + var textW = getPrefixedProperty(rscratch, "labelWidth", prefix); + var textH = getPrefixedProperty(rscratch, "labelHeight", prefix); + var marginX = ele.pstyle(pdash + "text-margin-x").pfValue; + var marginY = ele.pstyle(pdash + "text-margin-y").pfValue; + var isEdge = ele.isEdge(); + var halign = ele.pstyle("text-halign").value; + var valign = ele.pstyle("text-valign").value; + if (isEdge) { + halign = "center"; + valign = "center"; + } + textX += marginX; + textY += marginY; + var theta; + if (!applyRotation) { + theta = 0; + } else { + theta = this.getTextAngle(ele, prefix); + } + if (theta !== 0) { + orgTextX = textX; + orgTextY = textY; + context.translate(orgTextX, orgTextY); + context.rotate(theta); + textX = 0; + textY = 0; + } + switch (valign) { + case "top": + break; + case "center": + textY += textH / 2; + break; + case "bottom": + textY += textH; + break; + } + var backgroundOpacity = ele.pstyle("text-background-opacity").value; + var borderOpacity = ele.pstyle("text-border-opacity").value; + var textBorderWidth = ele.pstyle("text-border-width").pfValue; + var backgroundPadding = ele.pstyle("text-background-padding").pfValue; + var styleShape = ele.pstyle("text-background-shape").strValue; + var rounded = styleShape.indexOf("round") === 0; + var roundRadius = 2; + if (backgroundOpacity > 0 || textBorderWidth > 0 && borderOpacity > 0) { + var bgX = textX - backgroundPadding; + switch (halign) { + case "left": + bgX -= textW; + break; + case "center": + bgX -= textW / 2; + break; + } + var bgY = textY - textH - backgroundPadding; + var bgW = textW + 2 * backgroundPadding; + var bgH = textH + 2 * backgroundPadding; + if (backgroundOpacity > 0) { + var textFill = context.fillStyle; + var textBackgroundColor = ele.pstyle("text-background-color").value; + context.fillStyle = "rgba(" + textBackgroundColor[0] + "," + textBackgroundColor[1] + "," + textBackgroundColor[2] + "," + backgroundOpacity * parentOpacity + ")"; + if (rounded) { + roundRect(context, bgX, bgY, bgW, bgH, roundRadius); + } else { + context.fillRect(bgX, bgY, bgW, bgH); + } + context.fillStyle = textFill; + } + if (textBorderWidth > 0 && borderOpacity > 0) { + var textStroke = context.strokeStyle; + var textLineWidth = context.lineWidth; + var textBorderColor = ele.pstyle("text-border-color").value; + var textBorderStyle = ele.pstyle("text-border-style").value; + context.strokeStyle = "rgba(" + textBorderColor[0] + "," + textBorderColor[1] + "," + textBorderColor[2] + "," + borderOpacity * parentOpacity + ")"; + context.lineWidth = textBorderWidth; + if (context.setLineDash) { + switch (textBorderStyle) { + case "dotted": + context.setLineDash([1, 1]); + break; + case "dashed": + context.setLineDash([4, 2]); + break; + case "double": + context.lineWidth = textBorderWidth / 4; + context.setLineDash([]); + break; + case "solid": + context.setLineDash([]); + break; + } + } + if (rounded) { + roundRect(context, bgX, bgY, bgW, bgH, roundRadius, "stroke"); + } else { + context.strokeRect(bgX, bgY, bgW, bgH); + } + if (textBorderStyle === "double") { + var whiteWidth = textBorderWidth / 2; + if (rounded) { + roundRect(context, bgX + whiteWidth, bgY + whiteWidth, bgW - whiteWidth * 2, bgH - whiteWidth * 2, roundRadius, "stroke"); + } else { + context.strokeRect(bgX + whiteWidth, bgY + whiteWidth, bgW - whiteWidth * 2, bgH - whiteWidth * 2); + } + } + if (context.setLineDash) { + context.setLineDash([]); + } + context.lineWidth = textLineWidth; + context.strokeStyle = textStroke; + } + } + var lineWidth = 2 * ele.pstyle("text-outline-width").pfValue; + if (lineWidth > 0) { + context.lineWidth = lineWidth; + } + if (ele.pstyle("text-wrap").value === "wrap") { + var lines = getPrefixedProperty(rscratch, "labelWrapCachedLines", prefix); + var lineHeight = getPrefixedProperty(rscratch, "labelLineHeight", prefix); + var halfTextW = textW / 2; + var justification = this.getLabelJustification(ele); + if (justification === "auto") + ; + else if (halign === "left") { + if (justification === "left") { + textX += -textW; + } else if (justification === "center") { + textX += -halfTextW; + } + } else if (halign === "center") { + if (justification === "left") { + textX += -halfTextW; + } else if (justification === "right") { + textX += halfTextW; + } + } else if (halign === "right") { + if (justification === "center") { + textX += halfTextW; + } else if (justification === "right") { + textX += textW; + } + } + switch (valign) { + case "top": + textY -= (lines.length - 1) * lineHeight; + break; + case "center": + case "bottom": + textY -= (lines.length - 1) * lineHeight; + break; + } + for (var l = 0; l < lines.length; l++) { + if (lineWidth > 0) { + context.strokeText(lines[l], textX, textY); + } + context.fillText(lines[l], textX, textY); + textY += lineHeight; + } + } else { + if (lineWidth > 0) { + context.strokeText(text, textX, textY); + } + context.fillText(text, textX, textY); + } + if (theta !== 0) { + context.rotate(-theta); + context.translate(-orgTextX, -orgTextY); + } + } + }; + var CRp$5 = {}; + CRp$5.drawNode = function(context, node, shiftToOriginWithBb) { + var drawLabel = arguments.length > 3 && arguments[3] !== void 0 ? arguments[3] : true; + var shouldDrawOverlay = arguments.length > 4 && arguments[4] !== void 0 ? arguments[4] : true; + var shouldDrawOpacity = arguments.length > 5 && arguments[5] !== void 0 ? arguments[5] : true; + var r = this; + var nodeWidth, nodeHeight; + var _p = node._private; + var rs = _p.rscratch; + var pos = node.position(); + if (!number$1(pos.x) || !number$1(pos.y)) { + return; + } + if (shouldDrawOpacity && !node.visible()) { + return; + } + var eleOpacity = shouldDrawOpacity ? node.effectiveOpacity() : 1; + var usePaths = r.usePaths(); + var path; + var pathCacheHit = false; + var padding = node.padding(); + nodeWidth = node.width() + 2 * padding; + nodeHeight = node.height() + 2 * padding; + var bb; + if (shiftToOriginWithBb) { + bb = shiftToOriginWithBb; + context.translate(-bb.x1, -bb.y1); + } + var bgImgProp = node.pstyle("background-image"); + var urls = bgImgProp.value; + var urlDefined = new Array(urls.length); + var image = new Array(urls.length); + var numImages = 0; + for (var i2 = 0; i2 < urls.length; i2++) { + var url = urls[i2]; + var defd = urlDefined[i2] = url != null && url !== "none"; + if (defd) { + var bgImgCrossOrigin = node.cy().style().getIndexedStyle(node, "background-image-crossorigin", "value", i2); + numImages++; + image[i2] = r.getCachedImage(url, bgImgCrossOrigin, function() { + _p.backgroundTimestamp = Date.now(); + node.emitAndNotify("background"); + }); + } + } + var darkness = node.pstyle("background-blacken").value; + var borderWidth = node.pstyle("border-width").pfValue; + var bgOpacity = node.pstyle("background-opacity").value * eleOpacity; + var borderColor = node.pstyle("border-color").value; + var borderStyle = node.pstyle("border-style").value; + var borderOpacity = node.pstyle("border-opacity").value * eleOpacity; + var outlineWidth = node.pstyle("outline-width").pfValue; + var outlineColor = node.pstyle("outline-color").value; + var outlineStyle = node.pstyle("outline-style").value; + var outlineOpacity = node.pstyle("outline-opacity").value * eleOpacity; + var outlineOffset = node.pstyle("outline-offset").value; + context.lineJoin = "miter"; + var setupShapeColor = function setupShapeColor2() { + var bgOpy = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : bgOpacity; + r.eleFillStyle(context, node, bgOpy); + }; + var setupBorderColor = function setupBorderColor2() { + var bdrOpy = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : borderOpacity; + r.colorStrokeStyle(context, borderColor[0], borderColor[1], borderColor[2], bdrOpy); + }; + var setupOutlineColor = function setupOutlineColor2() { + var otlnOpy = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : outlineOpacity; + r.colorStrokeStyle(context, outlineColor[0], outlineColor[1], outlineColor[2], otlnOpy); + }; + var getPath = function getPath2(width, height, shape, points) { + var pathCache = r.nodePathCache = r.nodePathCache || []; + var key = hashStrings(shape === "polygon" ? shape + "," + points.join(",") : shape, "" + height, "" + width); + var cachedPath = pathCache[key]; + var path2; + var cacheHit = false; + if (cachedPath != null) { + path2 = cachedPath; + cacheHit = true; + rs.pathCache = path2; + } else { + path2 = new Path2D(); + pathCache[key] = rs.pathCache = path2; + } + return { + path: path2, + cacheHit + }; + }; + var styleShape = node.pstyle("shape").strValue; + var shapePts = node.pstyle("shape-polygon-points").pfValue; + if (usePaths) { + context.translate(pos.x, pos.y); + var shapePath = getPath(nodeWidth, nodeHeight, styleShape, shapePts); + path = shapePath.path; + pathCacheHit = shapePath.cacheHit; + } + var drawShape = function drawShape2() { + if (!pathCacheHit) { + var npos = pos; + if (usePaths) { + npos = { + x: 0, + y: 0 + }; + } + r.nodeShapes[r.getNodeShape(node)].draw(path || context, npos.x, npos.y, nodeWidth, nodeHeight); + } + if (usePaths) { + context.fill(path); + } else { + context.fill(); + } + }; + var drawImages = function drawImages2() { + var nodeOpacity = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : eleOpacity; + var inside = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : true; + var prevBging = _p.backgrounding; + var totalCompleted = 0; + for (var _i = 0; _i < image.length; _i++) { + var bgContainment = node.cy().style().getIndexedStyle(node, "background-image-containment", "value", _i); + if (inside && bgContainment === "over" || !inside && bgContainment === "inside") { + totalCompleted++; + continue; + } + if (urlDefined[_i] && image[_i].complete && !image[_i].error) { + totalCompleted++; + r.drawInscribedImage(context, image[_i], node, _i, nodeOpacity); + } + } + _p.backgrounding = !(totalCompleted === numImages); + if (prevBging !== _p.backgrounding) { + node.updateStyle(false); + } + }; + var drawPie = function drawPie2() { + var redrawShape = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : false; + var pieOpacity = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : eleOpacity; + if (r.hasPie(node)) { + r.drawPie(context, node, pieOpacity); + if (redrawShape) { + if (!usePaths) { + r.nodeShapes[r.getNodeShape(node)].draw(context, pos.x, pos.y, nodeWidth, nodeHeight); + } + } + } + }; + var darken2 = function darken3() { + var darkenOpacity = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : eleOpacity; + var opacity = (darkness > 0 ? darkness : -darkness) * darkenOpacity; + var c = darkness > 0 ? 0 : 255; + if (darkness !== 0) { + r.colorFillStyle(context, c, c, c, opacity); + if (usePaths) { + context.fill(path); + } else { + context.fill(); + } + } + }; + var drawBorder = function drawBorder2() { + if (borderWidth > 0) { + context.lineWidth = borderWidth; + context.lineCap = "butt"; + if (context.setLineDash) { + switch (borderStyle) { + case "dotted": + context.setLineDash([1, 1]); + break; + case "dashed": + context.setLineDash([4, 2]); + break; + case "solid": + case "double": + context.setLineDash([]); + break; + } + } + if (usePaths) { + context.stroke(path); + } else { + context.stroke(); + } + if (borderStyle === "double") { + context.lineWidth = borderWidth / 3; + var gco = context.globalCompositeOperation; + context.globalCompositeOperation = "destination-out"; + if (usePaths) { + context.stroke(path); + } else { + context.stroke(); + } + context.globalCompositeOperation = gco; + } + if (context.setLineDash) { + context.setLineDash([]); + } + } + }; + var drawOutline = function drawOutline2() { + if (outlineWidth > 0) { + context.lineWidth = outlineWidth; + context.lineCap = "butt"; + if (context.setLineDash) { + switch (outlineStyle) { + case "dotted": + context.setLineDash([1, 1]); + break; + case "dashed": + context.setLineDash([4, 2]); + break; + case "solid": + case "double": + context.setLineDash([]); + break; + } + } + var npos = pos; + if (usePaths) { + npos = { + x: 0, + y: 0 + }; + } + var shape = r.getNodeShape(node); + var scaleX = (nodeWidth + borderWidth + (outlineWidth + outlineOffset)) / nodeWidth; + var scaleY = (nodeHeight + borderWidth + (outlineWidth + outlineOffset)) / nodeHeight; + var sWidth = nodeWidth * scaleX; + var sHeight = nodeHeight * scaleY; + var points = r.nodeShapes[shape].points; + var _path; + if (usePaths) { + var outlinePath = getPath(sWidth, sHeight, shape, points); + _path = outlinePath.path; + } + if (shape === "ellipse") { + r.drawEllipsePath(_path || context, npos.x, npos.y, sWidth, sHeight); + } else if (["round-diamond", "round-heptagon", "round-hexagon", "round-octagon", "round-pentagon", "round-polygon", "round-triangle", "round-tag"].includes(shape)) { + var sMult = 0; + var offsetX = 0; + var offsetY = 0; + if (shape === "round-diamond") { + sMult = (borderWidth + outlineOffset + outlineWidth) * 1.4; + } else if (shape === "round-heptagon") { + sMult = (borderWidth + outlineOffset + outlineWidth) * 1.075; + offsetY = -(borderWidth / 2 + outlineOffset + outlineWidth) / 35; + } else if (shape === "round-hexagon") { + sMult = (borderWidth + outlineOffset + outlineWidth) * 1.12; + } else if (shape === "round-pentagon") { + sMult = (borderWidth + outlineOffset + outlineWidth) * 1.13; + offsetY = -(borderWidth / 2 + outlineOffset + outlineWidth) / 15; + } else if (shape === "round-tag") { + sMult = (borderWidth + outlineOffset + outlineWidth) * 1.12; + offsetX = (borderWidth / 2 + outlineWidth + outlineOffset) * 0.07; + } else if (shape === "round-triangle") { + sMult = (borderWidth + outlineOffset + outlineWidth) * (Math.PI / 2); + offsetY = -(borderWidth + outlineOffset / 2 + outlineWidth) / Math.PI; + } + if (sMult !== 0) { + scaleX = (nodeWidth + sMult) / nodeWidth; + scaleY = (nodeHeight + sMult) / nodeHeight; + } + r.drawRoundPolygonPath(_path || context, npos.x + offsetX, npos.y + offsetY, nodeWidth * scaleX, nodeHeight * scaleY, points); + } else if (["roundrectangle", "round-rectangle"].includes(shape)) { + r.drawRoundRectanglePath(_path || context, npos.x, npos.y, sWidth, sHeight); + } else if (["cutrectangle", "cut-rectangle"].includes(shape)) { + r.drawCutRectanglePath(_path || context, npos.x, npos.y, sWidth, sHeight); + } else if (["bottomroundrectangle", "bottom-round-rectangle"].includes(shape)) { + r.drawBottomRoundRectanglePath(_path || context, npos.x, npos.y, sWidth, sHeight); + } else if (shape === "barrel") { + r.drawBarrelPath(_path || context, npos.x, npos.y, sWidth, sHeight); + } else if (shape.startsWith("polygon") || ["rhomboid", "right-rhomboid", "round-tag", "tag", "vee"].includes(shape)) { + var pad = (borderWidth + outlineWidth + outlineOffset) / nodeWidth; + points = joinLines(expandPolygon(points, pad)); + r.drawPolygonPath(_path || context, npos.x, npos.y, nodeWidth, nodeHeight, points); + } else { + var _pad = (borderWidth + outlineWidth + outlineOffset) / nodeWidth; + points = joinLines(expandPolygon(points, -_pad)); + r.drawPolygonPath(_path || context, npos.x, npos.y, nodeWidth, nodeHeight, points); + } + if (usePaths) { + context.stroke(_path); + } else { + context.stroke(); + } + if (outlineStyle === "double") { + context.lineWidth = borderWidth / 3; + var gco = context.globalCompositeOperation; + context.globalCompositeOperation = "destination-out"; + if (usePaths) { + context.stroke(_path); + } else { + context.stroke(); + } + context.globalCompositeOperation = gco; + } + if (context.setLineDash) { + context.setLineDash([]); + } + } + }; + var drawOverlay = function drawOverlay2() { + if (shouldDrawOverlay) { + r.drawNodeOverlay(context, node, pos, nodeWidth, nodeHeight); + } + }; + var drawUnderlay = function drawUnderlay2() { + if (shouldDrawOverlay) { + r.drawNodeUnderlay(context, node, pos, nodeWidth, nodeHeight); + } + }; + var drawText = function drawText2() { + r.drawElementText(context, node, null, drawLabel); + }; + var ghost = node.pstyle("ghost").value === "yes"; + if (ghost) { + var gx = node.pstyle("ghost-offset-x").pfValue; + var gy = node.pstyle("ghost-offset-y").pfValue; + var ghostOpacity = node.pstyle("ghost-opacity").value; + var effGhostOpacity = ghostOpacity * eleOpacity; + context.translate(gx, gy); + setupOutlineColor(); + drawOutline(); + setupShapeColor(ghostOpacity * bgOpacity); + drawShape(); + drawImages(effGhostOpacity, true); + setupBorderColor(ghostOpacity * borderOpacity); + drawBorder(); + drawPie(darkness !== 0 || borderWidth !== 0); + drawImages(effGhostOpacity, false); + darken2(effGhostOpacity); + context.translate(-gx, -gy); + } + if (usePaths) { + context.translate(-pos.x, -pos.y); + } + drawUnderlay(); + if (usePaths) { + context.translate(pos.x, pos.y); + } + setupOutlineColor(); + drawOutline(); + setupShapeColor(); + drawShape(); + drawImages(eleOpacity, true); + setupBorderColor(); + drawBorder(); + drawPie(darkness !== 0 || borderWidth !== 0); + drawImages(eleOpacity, false); + darken2(); + if (usePaths) { + context.translate(-pos.x, -pos.y); + } + drawText(); + drawOverlay(); + if (shiftToOriginWithBb) { + context.translate(bb.x1, bb.y1); + } + }; + var drawNodeOverlayUnderlay = function drawNodeOverlayUnderlay2(overlayOrUnderlay) { + if (!["overlay", "underlay"].includes(overlayOrUnderlay)) { + throw new Error("Invalid state"); + } + return function(context, node, pos, nodeWidth, nodeHeight) { + var r = this; + if (!node.visible()) { + return; + } + var padding = node.pstyle("".concat(overlayOrUnderlay, "-padding")).pfValue; + var opacity = node.pstyle("".concat(overlayOrUnderlay, "-opacity")).value; + var color = node.pstyle("".concat(overlayOrUnderlay, "-color")).value; + var shape = node.pstyle("".concat(overlayOrUnderlay, "-shape")).value; + if (opacity > 0) { + pos = pos || node.position(); + if (nodeWidth == null || nodeHeight == null) { + var _padding = node.padding(); + nodeWidth = node.width() + 2 * _padding; + nodeHeight = node.height() + 2 * _padding; + } + r.colorFillStyle(context, color[0], color[1], color[2], opacity); + r.nodeShapes[shape].draw(context, pos.x, pos.y, nodeWidth + padding * 2, nodeHeight + padding * 2); + context.fill(); + } + }; + }; + CRp$5.drawNodeOverlay = drawNodeOverlayUnderlay("overlay"); + CRp$5.drawNodeUnderlay = drawNodeOverlayUnderlay("underlay"); + CRp$5.hasPie = function(node) { + node = node[0]; + return node._private.hasPie; + }; + CRp$5.drawPie = function(context, node, nodeOpacity, pos) { + node = node[0]; + pos = pos || node.position(); + var cyStyle = node.cy().style(); + var pieSize = node.pstyle("pie-size"); + var x = pos.x; + var y = pos.y; + var nodeW = node.width(); + var nodeH = node.height(); + var radius = Math.min(nodeW, nodeH) / 2; + var lastPercent = 0; + var usePaths = this.usePaths(); + if (usePaths) { + x = 0; + y = 0; + } + if (pieSize.units === "%") { + radius = radius * pieSize.pfValue; + } else if (pieSize.pfValue !== void 0) { + radius = pieSize.pfValue / 2; + } + for (var i2 = 1; i2 <= cyStyle.pieBackgroundN; i2++) { + var size = node.pstyle("pie-" + i2 + "-background-size").value; + var color = node.pstyle("pie-" + i2 + "-background-color").value; + var opacity = node.pstyle("pie-" + i2 + "-background-opacity").value * nodeOpacity; + var percent = size / 100; + if (percent + lastPercent > 1) { + percent = 1 - lastPercent; + } + var angleStart = 1.5 * Math.PI + 2 * Math.PI * lastPercent; + var angleDelta = 2 * Math.PI * percent; + var angleEnd = angleStart + angleDelta; + if (size === 0 || lastPercent >= 1 || lastPercent + percent > 1) { + continue; + } + context.beginPath(); + context.moveTo(x, y); + context.arc(x, y, radius, angleStart, angleEnd); + context.closePath(); + this.colorFillStyle(context, color[0], color[1], color[2], opacity); + context.fill(); + lastPercent += percent; + } + }; + var CRp$4 = {}; + var motionBlurDelay = 100; + CRp$4.getPixelRatio = function() { + var context = this.data.contexts[0]; + if (this.forcedPixelRatio != null) { + return this.forcedPixelRatio; + } + var backingStore = context.backingStorePixelRatio || context.webkitBackingStorePixelRatio || context.mozBackingStorePixelRatio || context.msBackingStorePixelRatio || context.oBackingStorePixelRatio || context.backingStorePixelRatio || 1; + return (window.devicePixelRatio || 1) / backingStore; + }; + CRp$4.paintCache = function(context) { + var caches = this.paintCaches = this.paintCaches || []; + var needToCreateCache = true; + var cache2; + for (var i2 = 0; i2 < caches.length; i2++) { + cache2 = caches[i2]; + if (cache2.context === context) { + needToCreateCache = false; + break; + } + } + if (needToCreateCache) { + cache2 = { + context + }; + caches.push(cache2); + } + return cache2; + }; + CRp$4.createGradientStyleFor = function(context, shapeStyleName, ele, fill, opacity) { + var gradientStyle; + var usePaths = this.usePaths(); + var colors2 = ele.pstyle(shapeStyleName + "-gradient-stop-colors").value, positions = ele.pstyle(shapeStyleName + "-gradient-stop-positions").pfValue; + if (fill === "radial-gradient") { + if (ele.isEdge()) { + var start = ele.sourceEndpoint(), end = ele.targetEndpoint(), mid = ele.midpoint(); + var d1 = dist(start, mid); + var d2 = dist(end, mid); + gradientStyle = context.createRadialGradient(mid.x, mid.y, 0, mid.x, mid.y, Math.max(d1, d2)); + } else { + var pos = usePaths ? { + x: 0, + y: 0 + } : ele.position(), width = ele.paddedWidth(), height = ele.paddedHeight(); + gradientStyle = context.createRadialGradient(pos.x, pos.y, 0, pos.x, pos.y, Math.max(width, height)); + } + } else { + if (ele.isEdge()) { + var _start = ele.sourceEndpoint(), _end = ele.targetEndpoint(); + gradientStyle = context.createLinearGradient(_start.x, _start.y, _end.x, _end.y); + } else { + var _pos = usePaths ? { + x: 0, + y: 0 + } : ele.position(), _width = ele.paddedWidth(), _height = ele.paddedHeight(), halfWidth = _width / 2, halfHeight = _height / 2; + var direction = ele.pstyle("background-gradient-direction").value; + switch (direction) { + case "to-bottom": + gradientStyle = context.createLinearGradient(_pos.x, _pos.y - halfHeight, _pos.x, _pos.y + halfHeight); + break; + case "to-top": + gradientStyle = context.createLinearGradient(_pos.x, _pos.y + halfHeight, _pos.x, _pos.y - halfHeight); + break; + case "to-left": + gradientStyle = context.createLinearGradient(_pos.x + halfWidth, _pos.y, _pos.x - halfWidth, _pos.y); + break; + case "to-right": + gradientStyle = context.createLinearGradient(_pos.x - halfWidth, _pos.y, _pos.x + halfWidth, _pos.y); + break; + case "to-bottom-right": + case "to-right-bottom": + gradientStyle = context.createLinearGradient(_pos.x - halfWidth, _pos.y - halfHeight, _pos.x + halfWidth, _pos.y + halfHeight); + break; + case "to-top-right": + case "to-right-top": + gradientStyle = context.createLinearGradient(_pos.x - halfWidth, _pos.y + halfHeight, _pos.x + halfWidth, _pos.y - halfHeight); + break; + case "to-bottom-left": + case "to-left-bottom": + gradientStyle = context.createLinearGradient(_pos.x + halfWidth, _pos.y - halfHeight, _pos.x - halfWidth, _pos.y + halfHeight); + break; + case "to-top-left": + case "to-left-top": + gradientStyle = context.createLinearGradient(_pos.x + halfWidth, _pos.y + halfHeight, _pos.x - halfWidth, _pos.y - halfHeight); + break; + } + } + } + if (!gradientStyle) + return null; + var hasPositions = positions.length === colors2.length; + var length = colors2.length; + for (var i2 = 0; i2 < length; i2++) { + gradientStyle.addColorStop(hasPositions ? positions[i2] : i2 / (length - 1), "rgba(" + colors2[i2][0] + "," + colors2[i2][1] + "," + colors2[i2][2] + "," + opacity + ")"); + } + return gradientStyle; + }; + CRp$4.gradientFillStyle = function(context, ele, fill, opacity) { + var gradientStyle = this.createGradientStyleFor(context, "background", ele, fill, opacity); + if (!gradientStyle) + return null; + context.fillStyle = gradientStyle; + }; + CRp$4.colorFillStyle = function(context, r, g, b, a) { + context.fillStyle = "rgba(" + r + "," + g + "," + b + "," + a + ")"; + }; + CRp$4.eleFillStyle = function(context, ele, opacity) { + var backgroundFill = ele.pstyle("background-fill").value; + if (backgroundFill === "linear-gradient" || backgroundFill === "radial-gradient") { + this.gradientFillStyle(context, ele, backgroundFill, opacity); + } else { + var backgroundColor = ele.pstyle("background-color").value; + this.colorFillStyle(context, backgroundColor[0], backgroundColor[1], backgroundColor[2], opacity); + } + }; + CRp$4.gradientStrokeStyle = function(context, ele, fill, opacity) { + var gradientStyle = this.createGradientStyleFor(context, "line", ele, fill, opacity); + if (!gradientStyle) + return null; + context.strokeStyle = gradientStyle; + }; + CRp$4.colorStrokeStyle = function(context, r, g, b, a) { + context.strokeStyle = "rgba(" + r + "," + g + "," + b + "," + a + ")"; + }; + CRp$4.eleStrokeStyle = function(context, ele, opacity) { + var lineFill = ele.pstyle("line-fill").value; + if (lineFill === "linear-gradient" || lineFill === "radial-gradient") { + this.gradientStrokeStyle(context, ele, lineFill, opacity); + } else { + var lineColor = ele.pstyle("line-color").value; + this.colorStrokeStyle(context, lineColor[0], lineColor[1], lineColor[2], opacity); + } + }; + CRp$4.matchCanvasSize = function(container) { + var r = this; + var data2 = r.data; + var bb = r.findContainerClientCoords(); + var width = bb[2]; + var height = bb[3]; + var pixelRatio = r.getPixelRatio(); + var mbPxRatio = r.motionBlurPxRatio; + if (container === r.data.bufferCanvases[r.MOTIONBLUR_BUFFER_NODE] || container === r.data.bufferCanvases[r.MOTIONBLUR_BUFFER_DRAG]) { + pixelRatio = mbPxRatio; + } + var canvasWidth = width * pixelRatio; + var canvasHeight = height * pixelRatio; + var canvas; + if (canvasWidth === r.canvasWidth && canvasHeight === r.canvasHeight) { + return; + } + r.fontCaches = null; + var canvasContainer = data2.canvasContainer; + canvasContainer.style.width = width + "px"; + canvasContainer.style.height = height + "px"; + for (var i2 = 0; i2 < r.CANVAS_LAYERS; i2++) { + canvas = data2.canvases[i2]; + canvas.width = canvasWidth; + canvas.height = canvasHeight; + canvas.style.width = width + "px"; + canvas.style.height = height + "px"; + } + for (var i2 = 0; i2 < r.BUFFER_COUNT; i2++) { + canvas = data2.bufferCanvases[i2]; + canvas.width = canvasWidth; + canvas.height = canvasHeight; + canvas.style.width = width + "px"; + canvas.style.height = height + "px"; + } + r.textureMult = 1; + if (pixelRatio <= 1) { + canvas = data2.bufferCanvases[r.TEXTURE_BUFFER]; + r.textureMult = 2; + canvas.width = canvasWidth * r.textureMult; + canvas.height = canvasHeight * r.textureMult; + } + r.canvasWidth = canvasWidth; + r.canvasHeight = canvasHeight; + }; + CRp$4.renderTo = function(cxt, zoom, pan, pxRatio) { + this.render({ + forcedContext: cxt, + forcedZoom: zoom, + forcedPan: pan, + drawAllLayers: true, + forcedPxRatio: pxRatio + }); + }; + CRp$4.render = function(options) { + options = options || staticEmptyObject(); + var forcedContext = options.forcedContext; + var drawAllLayers = options.drawAllLayers; + var drawOnlyNodeLayer = options.drawOnlyNodeLayer; + var forcedZoom = options.forcedZoom; + var forcedPan = options.forcedPan; + var r = this; + var pixelRatio = options.forcedPxRatio === void 0 ? this.getPixelRatio() : options.forcedPxRatio; + var cy = r.cy; + var data2 = r.data; + var needDraw = data2.canvasNeedsRedraw; + var textureDraw = r.textureOnViewport && !forcedContext && (r.pinching || r.hoverData.dragging || r.swipePanning || r.data.wheelZooming); + var motionBlur = options.motionBlur !== void 0 ? options.motionBlur : r.motionBlur; + var mbPxRatio = r.motionBlurPxRatio; + var hasCompoundNodes = cy.hasCompoundNodes(); + var inNodeDragGesture = r.hoverData.draggingEles; + var inBoxSelection = r.hoverData.selecting || r.touchData.selecting ? true : false; + motionBlur = motionBlur && !forcedContext && r.motionBlurEnabled && !inBoxSelection; + var motionBlurFadeEffect = motionBlur; + if (!forcedContext) { + if (r.prevPxRatio !== pixelRatio) { + r.invalidateContainerClientCoordsCache(); + r.matchCanvasSize(r.container); + r.redrawHint("eles", true); + r.redrawHint("drag", true); + } + r.prevPxRatio = pixelRatio; + } + if (!forcedContext && r.motionBlurTimeout) { + clearTimeout(r.motionBlurTimeout); + } + if (motionBlur) { + if (r.mbFrames == null) { + r.mbFrames = 0; + } + r.mbFrames++; + if (r.mbFrames < 3) { + motionBlurFadeEffect = false; + } + if (r.mbFrames > r.minMbLowQualFrames) { + r.motionBlurPxRatio = r.mbPxRBlurry; + } + } + if (r.clearingMotionBlur) { + r.motionBlurPxRatio = 1; + } + if (r.textureDrawLastFrame && !textureDraw) { + needDraw[r.NODE] = true; + needDraw[r.SELECT_BOX] = true; + } + var style = cy.style(); + var zoom = cy.zoom(); + var effectiveZoom = forcedZoom !== void 0 ? forcedZoom : zoom; + var pan = cy.pan(); + var effectivePan = { + x: pan.x, + y: pan.y + }; + var vp = { + zoom, + pan: { + x: pan.x, + y: pan.y + } + }; + var prevVp = r.prevViewport; + var viewportIsDiff = prevVp === void 0 || vp.zoom !== prevVp.zoom || vp.pan.x !== prevVp.pan.x || vp.pan.y !== prevVp.pan.y; + if (!viewportIsDiff && !(inNodeDragGesture && !hasCompoundNodes)) { + r.motionBlurPxRatio = 1; + } + if (forcedPan) { + effectivePan = forcedPan; + } + effectiveZoom *= pixelRatio; + effectivePan.x *= pixelRatio; + effectivePan.y *= pixelRatio; + var eles = r.getCachedZSortedEles(); + function mbclear(context2, x, y, w, h) { + var gco = context2.globalCompositeOperation; + context2.globalCompositeOperation = "destination-out"; + r.colorFillStyle(context2, 255, 255, 255, r.motionBlurTransparency); + context2.fillRect(x, y, w, h); + context2.globalCompositeOperation = gco; + } + function setContextTransform(context2, clear3) { + var ePan, eZoom, w, h; + if (!r.clearingMotionBlur && (context2 === data2.bufferContexts[r.MOTIONBLUR_BUFFER_NODE] || context2 === data2.bufferContexts[r.MOTIONBLUR_BUFFER_DRAG])) { + ePan = { + x: pan.x * mbPxRatio, + y: pan.y * mbPxRatio + }; + eZoom = zoom * mbPxRatio; + w = r.canvasWidth * mbPxRatio; + h = r.canvasHeight * mbPxRatio; + } else { + ePan = effectivePan; + eZoom = effectiveZoom; + w = r.canvasWidth; + h = r.canvasHeight; + } + context2.setTransform(1, 0, 0, 1, 0, 0); + if (clear3 === "motionBlur") { + mbclear(context2, 0, 0, w, h); + } else if (!forcedContext && (clear3 === void 0 || clear3)) { + context2.clearRect(0, 0, w, h); + } + if (!drawAllLayers) { + context2.translate(ePan.x, ePan.y); + context2.scale(eZoom, eZoom); + } + if (forcedPan) { + context2.translate(forcedPan.x, forcedPan.y); + } + if (forcedZoom) { + context2.scale(forcedZoom, forcedZoom); + } + } + if (!textureDraw) { + r.textureDrawLastFrame = false; + } + if (textureDraw) { + r.textureDrawLastFrame = true; + if (!r.textureCache) { + r.textureCache = {}; + r.textureCache.bb = cy.mutableElements().boundingBox(); + r.textureCache.texture = r.data.bufferCanvases[r.TEXTURE_BUFFER]; + var cxt = r.data.bufferContexts[r.TEXTURE_BUFFER]; + cxt.setTransform(1, 0, 0, 1, 0, 0); + cxt.clearRect(0, 0, r.canvasWidth * r.textureMult, r.canvasHeight * r.textureMult); + r.render({ + forcedContext: cxt, + drawOnlyNodeLayer: true, + forcedPxRatio: pixelRatio * r.textureMult + }); + var vp = r.textureCache.viewport = { + zoom: cy.zoom(), + pan: cy.pan(), + width: r.canvasWidth, + height: r.canvasHeight + }; + vp.mpan = { + x: (0 - vp.pan.x) / vp.zoom, + y: (0 - vp.pan.y) / vp.zoom + }; + } + needDraw[r.DRAG] = false; + needDraw[r.NODE] = false; + var context = data2.contexts[r.NODE]; + var texture = r.textureCache.texture; + var vp = r.textureCache.viewport; + context.setTransform(1, 0, 0, 1, 0, 0); + if (motionBlur) { + mbclear(context, 0, 0, vp.width, vp.height); + } else { + context.clearRect(0, 0, vp.width, vp.height); + } + var outsideBgColor = style.core("outside-texture-bg-color").value; + var outsideBgOpacity = style.core("outside-texture-bg-opacity").value; + r.colorFillStyle(context, outsideBgColor[0], outsideBgColor[1], outsideBgColor[2], outsideBgOpacity); + context.fillRect(0, 0, vp.width, vp.height); + var zoom = cy.zoom(); + setContextTransform(context, false); + context.clearRect(vp.mpan.x, vp.mpan.y, vp.width / vp.zoom / pixelRatio, vp.height / vp.zoom / pixelRatio); + context.drawImage(texture, vp.mpan.x, vp.mpan.y, vp.width / vp.zoom / pixelRatio, vp.height / vp.zoom / pixelRatio); + } else if (r.textureOnViewport && !forcedContext) { + r.textureCache = null; + } + var extent = cy.extent(); + var vpManip = r.pinching || r.hoverData.dragging || r.swipePanning || r.data.wheelZooming || r.hoverData.draggingEles || r.cy.animated(); + var hideEdges = r.hideEdgesOnViewport && vpManip; + var needMbClear = []; + needMbClear[r.NODE] = !needDraw[r.NODE] && motionBlur && !r.clearedForMotionBlur[r.NODE] || r.clearingMotionBlur; + if (needMbClear[r.NODE]) { + r.clearedForMotionBlur[r.NODE] = true; + } + needMbClear[r.DRAG] = !needDraw[r.DRAG] && motionBlur && !r.clearedForMotionBlur[r.DRAG] || r.clearingMotionBlur; + if (needMbClear[r.DRAG]) { + r.clearedForMotionBlur[r.DRAG] = true; + } + if (needDraw[r.NODE] || drawAllLayers || drawOnlyNodeLayer || needMbClear[r.NODE]) { + var useBuffer = motionBlur && !needMbClear[r.NODE] && mbPxRatio !== 1; + var context = forcedContext || (useBuffer ? r.data.bufferContexts[r.MOTIONBLUR_BUFFER_NODE] : data2.contexts[r.NODE]); + var clear2 = motionBlur && !useBuffer ? "motionBlur" : void 0; + setContextTransform(context, clear2); + if (hideEdges) { + r.drawCachedNodes(context, eles.nondrag, pixelRatio, extent); + } else { + r.drawLayeredElements(context, eles.nondrag, pixelRatio, extent); + } + if (r.debug) { + r.drawDebugPoints(context, eles.nondrag); + } + if (!drawAllLayers && !motionBlur) { + needDraw[r.NODE] = false; + } + } + if (!drawOnlyNodeLayer && (needDraw[r.DRAG] || drawAllLayers || needMbClear[r.DRAG])) { + var useBuffer = motionBlur && !needMbClear[r.DRAG] && mbPxRatio !== 1; + var context = forcedContext || (useBuffer ? r.data.bufferContexts[r.MOTIONBLUR_BUFFER_DRAG] : data2.contexts[r.DRAG]); + setContextTransform(context, motionBlur && !useBuffer ? "motionBlur" : void 0); + if (hideEdges) { + r.drawCachedNodes(context, eles.drag, pixelRatio, extent); + } else { + r.drawCachedElements(context, eles.drag, pixelRatio, extent); + } + if (r.debug) { + r.drawDebugPoints(context, eles.drag); + } + if (!drawAllLayers && !motionBlur) { + needDraw[r.DRAG] = false; + } + } + if (r.showFps || !drawOnlyNodeLayer && needDraw[r.SELECT_BOX] && !drawAllLayers) { + var context = forcedContext || data2.contexts[r.SELECT_BOX]; + setContextTransform(context); + if (r.selection[4] == 1 && (r.hoverData.selecting || r.touchData.selecting)) { + var zoom = r.cy.zoom(); + var borderWidth = style.core("selection-box-border-width").value / zoom; + context.lineWidth = borderWidth; + context.fillStyle = "rgba(" + style.core("selection-box-color").value[0] + "," + style.core("selection-box-color").value[1] + "," + style.core("selection-box-color").value[2] + "," + style.core("selection-box-opacity").value + ")"; + context.fillRect(r.selection[0], r.selection[1], r.selection[2] - r.selection[0], r.selection[3] - r.selection[1]); + if (borderWidth > 0) { + context.strokeStyle = "rgba(" + style.core("selection-box-border-color").value[0] + "," + style.core("selection-box-border-color").value[1] + "," + style.core("selection-box-border-color").value[2] + "," + style.core("selection-box-opacity").value + ")"; + context.strokeRect(r.selection[0], r.selection[1], r.selection[2] - r.selection[0], r.selection[3] - r.selection[1]); + } + } + if (data2.bgActivePosistion && !r.hoverData.selecting) { + var zoom = r.cy.zoom(); + var pos = data2.bgActivePosistion; + context.fillStyle = "rgba(" + style.core("active-bg-color").value[0] + "," + style.core("active-bg-color").value[1] + "," + style.core("active-bg-color").value[2] + "," + style.core("active-bg-opacity").value + ")"; + context.beginPath(); + context.arc(pos.x, pos.y, style.core("active-bg-size").pfValue / zoom, 0, 2 * Math.PI); + context.fill(); + } + var timeToRender = r.lastRedrawTime; + if (r.showFps && timeToRender) { + timeToRender = Math.round(timeToRender); + var fps = Math.round(1e3 / timeToRender); + context.setTransform(1, 0, 0, 1, 0, 0); + context.fillStyle = "rgba(255, 0, 0, 0.75)"; + context.strokeStyle = "rgba(255, 0, 0, 0.75)"; + context.lineWidth = 1; + context.fillText("1 frame = " + timeToRender + " ms = " + fps + " fps", 0, 20); + var maxFps = 60; + context.strokeRect(0, 30, 250, 20); + context.fillRect(0, 30, 250 * Math.min(fps / maxFps, 1), 20); + } + if (!drawAllLayers) { + needDraw[r.SELECT_BOX] = false; + } + } + if (motionBlur && mbPxRatio !== 1) { + var cxtNode = data2.contexts[r.NODE]; + var txtNode = r.data.bufferCanvases[r.MOTIONBLUR_BUFFER_NODE]; + var cxtDrag = data2.contexts[r.DRAG]; + var txtDrag = r.data.bufferCanvases[r.MOTIONBLUR_BUFFER_DRAG]; + var drawMotionBlur = function drawMotionBlur2(cxt2, txt, needClear) { + cxt2.setTransform(1, 0, 0, 1, 0, 0); + if (needClear || !motionBlurFadeEffect) { + cxt2.clearRect(0, 0, r.canvasWidth, r.canvasHeight); + } else { + mbclear(cxt2, 0, 0, r.canvasWidth, r.canvasHeight); + } + var pxr = mbPxRatio; + cxt2.drawImage( + txt, + // img + 0, + 0, + // sx, sy + r.canvasWidth * pxr, + r.canvasHeight * pxr, + // sw, sh + 0, + 0, + // x, y + r.canvasWidth, + r.canvasHeight + // w, h + ); + }; + if (needDraw[r.NODE] || needMbClear[r.NODE]) { + drawMotionBlur(cxtNode, txtNode, needMbClear[r.NODE]); + needDraw[r.NODE] = false; + } + if (needDraw[r.DRAG] || needMbClear[r.DRAG]) { + drawMotionBlur(cxtDrag, txtDrag, needMbClear[r.DRAG]); + needDraw[r.DRAG] = false; + } + } + r.prevViewport = vp; + if (r.clearingMotionBlur) { + r.clearingMotionBlur = false; + r.motionBlurCleared = true; + r.motionBlur = true; + } + if (motionBlur) { + r.motionBlurTimeout = setTimeout(function() { + r.motionBlurTimeout = null; + r.clearedForMotionBlur[r.NODE] = false; + r.clearedForMotionBlur[r.DRAG] = false; + r.motionBlur = false; + r.clearingMotionBlur = !textureDraw; + r.mbFrames = 0; + needDraw[r.NODE] = true; + needDraw[r.DRAG] = true; + r.redraw(); + }, motionBlurDelay); + } + if (!forcedContext) { + cy.emit("render"); + } + }; + var CRp$3 = {}; + CRp$3.drawPolygonPath = function(context, x, y, width, height, points) { + var halfW = width / 2; + var halfH = height / 2; + if (context.beginPath) { + context.beginPath(); + } + context.moveTo(x + halfW * points[0], y + halfH * points[1]); + for (var i2 = 1; i2 < points.length / 2; i2++) { + context.lineTo(x + halfW * points[i2 * 2], y + halfH * points[i2 * 2 + 1]); + } + context.closePath(); + }; + CRp$3.drawRoundPolygonPath = function(context, x, y, width, height, points) { + var halfW = width / 2; + var halfH = height / 2; + var cornerRadius = getRoundPolygonRadius(width, height); + if (context.beginPath) { + context.beginPath(); + } + for (var _i = 0; _i < points.length / 4; _i++) { + var sourceUv = void 0, destUv = void 0; + if (_i === 0) { + sourceUv = points.length - 2; + } else { + sourceUv = _i * 4 - 2; + } + destUv = _i * 4 + 2; + var px = x + halfW * points[_i * 4]; + var py = y + halfH * points[_i * 4 + 1]; + var cosTheta = -points[sourceUv] * points[destUv] - points[sourceUv + 1] * points[destUv + 1]; + var offset = cornerRadius / Math.tan(Math.acos(cosTheta) / 2); + var cp0x = px - offset * points[sourceUv]; + var cp0y = py - offset * points[sourceUv + 1]; + var cp1x = px + offset * points[destUv]; + var cp1y = py + offset * points[destUv + 1]; + if (_i === 0) { + context.moveTo(cp0x, cp0y); + } else { + context.lineTo(cp0x, cp0y); + } + context.arcTo(px, py, cp1x, cp1y, cornerRadius); + } + context.closePath(); + }; + CRp$3.drawRoundRectanglePath = function(context, x, y, width, height) { + var halfWidth = width / 2; + var halfHeight = height / 2; + var cornerRadius = getRoundRectangleRadius(width, height); + if (context.beginPath) { + context.beginPath(); + } + context.moveTo(x, y - halfHeight); + context.arcTo(x + halfWidth, y - halfHeight, x + halfWidth, y, cornerRadius); + context.arcTo(x + halfWidth, y + halfHeight, x, y + halfHeight, cornerRadius); + context.arcTo(x - halfWidth, y + halfHeight, x - halfWidth, y, cornerRadius); + context.arcTo(x - halfWidth, y - halfHeight, x, y - halfHeight, cornerRadius); + context.lineTo(x, y - halfHeight); + context.closePath(); + }; + CRp$3.drawBottomRoundRectanglePath = function(context, x, y, width, height) { + var halfWidth = width / 2; + var halfHeight = height / 2; + var cornerRadius = getRoundRectangleRadius(width, height); + if (context.beginPath) { + context.beginPath(); + } + context.moveTo(x, y - halfHeight); + context.lineTo(x + halfWidth, y - halfHeight); + context.lineTo(x + halfWidth, y); + context.arcTo(x + halfWidth, y + halfHeight, x, y + halfHeight, cornerRadius); + context.arcTo(x - halfWidth, y + halfHeight, x - halfWidth, y, cornerRadius); + context.lineTo(x - halfWidth, y - halfHeight); + context.lineTo(x, y - halfHeight); + context.closePath(); + }; + CRp$3.drawCutRectanglePath = function(context, x, y, width, height) { + var halfWidth = width / 2; + var halfHeight = height / 2; + var cornerLength = getCutRectangleCornerLength(); + if (context.beginPath) { + context.beginPath(); + } + context.moveTo(x - halfWidth + cornerLength, y - halfHeight); + context.lineTo(x + halfWidth - cornerLength, y - halfHeight); + context.lineTo(x + halfWidth, y - halfHeight + cornerLength); + context.lineTo(x + halfWidth, y + halfHeight - cornerLength); + context.lineTo(x + halfWidth - cornerLength, y + halfHeight); + context.lineTo(x - halfWidth + cornerLength, y + halfHeight); + context.lineTo(x - halfWidth, y + halfHeight - cornerLength); + context.lineTo(x - halfWidth, y - halfHeight + cornerLength); + context.closePath(); + }; + CRp$3.drawBarrelPath = function(context, x, y, width, height) { + var halfWidth = width / 2; + var halfHeight = height / 2; + var xBegin = x - halfWidth; + var xEnd = x + halfWidth; + var yBegin = y - halfHeight; + var yEnd = y + halfHeight; + var barrelCurveConstants = getBarrelCurveConstants(width, height); + var wOffset = barrelCurveConstants.widthOffset; + var hOffset = barrelCurveConstants.heightOffset; + var ctrlPtXOffset = barrelCurveConstants.ctrlPtOffsetPct * wOffset; + if (context.beginPath) { + context.beginPath(); + } + context.moveTo(xBegin, yBegin + hOffset); + context.lineTo(xBegin, yEnd - hOffset); + context.quadraticCurveTo(xBegin + ctrlPtXOffset, yEnd, xBegin + wOffset, yEnd); + context.lineTo(xEnd - wOffset, yEnd); + context.quadraticCurveTo(xEnd - ctrlPtXOffset, yEnd, xEnd, yEnd - hOffset); + context.lineTo(xEnd, yBegin + hOffset); + context.quadraticCurveTo(xEnd - ctrlPtXOffset, yBegin, xEnd - wOffset, yBegin); + context.lineTo(xBegin + wOffset, yBegin); + context.quadraticCurveTo(xBegin + ctrlPtXOffset, yBegin, xBegin, yBegin + hOffset); + context.closePath(); + }; + var sin0 = Math.sin(0); + var cos0 = Math.cos(0); + var sin = {}; + var cos = {}; + var ellipseStepSize = Math.PI / 40; + for (var i = 0 * Math.PI; i < 2 * Math.PI; i += ellipseStepSize) { + sin[i] = Math.sin(i); + cos[i] = Math.cos(i); + } + CRp$3.drawEllipsePath = function(context, centerX, centerY, width, height) { + if (context.beginPath) { + context.beginPath(); + } + if (context.ellipse) { + context.ellipse(centerX, centerY, width / 2, height / 2, 0, 0, 2 * Math.PI); + } else { + var xPos, yPos; + var rw = width / 2; + var rh = height / 2; + for (var i2 = 0 * Math.PI; i2 < 2 * Math.PI; i2 += ellipseStepSize) { + xPos = centerX - rw * sin[i2] * sin0 + rw * cos[i2] * cos0; + yPos = centerY + rh * cos[i2] * sin0 + rh * sin[i2] * cos0; + if (i2 === 0) { + context.moveTo(xPos, yPos); + } else { + context.lineTo(xPos, yPos); + } + } + } + context.closePath(); + }; + var CRp$2 = {}; + CRp$2.createBuffer = function(w, h) { + var buffer = document.createElement("canvas"); + buffer.width = w; + buffer.height = h; + return [buffer, buffer.getContext("2d")]; + }; + CRp$2.bufferCanvasImage = function(options) { + var cy = this.cy; + var eles = cy.mutableElements(); + var bb = eles.boundingBox(); + var ctrRect = this.findContainerClientCoords(); + var width = options.full ? Math.ceil(bb.w) : ctrRect[2]; + var height = options.full ? Math.ceil(bb.h) : ctrRect[3]; + var specdMaxDims = number$1(options.maxWidth) || number$1(options.maxHeight); + var pxRatio = this.getPixelRatio(); + var scale = 1; + if (options.scale !== void 0) { + width *= options.scale; + height *= options.scale; + scale = options.scale; + } else if (specdMaxDims) { + var maxScaleW = Infinity; + var maxScaleH = Infinity; + if (number$1(options.maxWidth)) { + maxScaleW = scale * options.maxWidth / width; + } + if (number$1(options.maxHeight)) { + maxScaleH = scale * options.maxHeight / height; + } + scale = Math.min(maxScaleW, maxScaleH); + width *= scale; + height *= scale; + } + if (!specdMaxDims) { + width *= pxRatio; + height *= pxRatio; + scale *= pxRatio; + } + var buffCanvas = document.createElement("canvas"); + buffCanvas.width = width; + buffCanvas.height = height; + buffCanvas.style.width = width + "px"; + buffCanvas.style.height = height + "px"; + var buffCxt = buffCanvas.getContext("2d"); + if (width > 0 && height > 0) { + buffCxt.clearRect(0, 0, width, height); + buffCxt.globalCompositeOperation = "source-over"; + var zsortedEles = this.getCachedZSortedEles(); + if (options.full) { + buffCxt.translate(-bb.x1 * scale, -bb.y1 * scale); + buffCxt.scale(scale, scale); + this.drawElements(buffCxt, zsortedEles); + buffCxt.scale(1 / scale, 1 / scale); + buffCxt.translate(bb.x1 * scale, bb.y1 * scale); + } else { + var pan = cy.pan(); + var translation = { + x: pan.x * scale, + y: pan.y * scale + }; + scale *= cy.zoom(); + buffCxt.translate(translation.x, translation.y); + buffCxt.scale(scale, scale); + this.drawElements(buffCxt, zsortedEles); + buffCxt.scale(1 / scale, 1 / scale); + buffCxt.translate(-translation.x, -translation.y); + } + if (options.bg) { + buffCxt.globalCompositeOperation = "destination-over"; + buffCxt.fillStyle = options.bg; + buffCxt.rect(0, 0, width, height); + buffCxt.fill(); + } + } + return buffCanvas; + }; + function b64ToBlob(b64, mimeType) { + var bytes = atob(b64); + var buff = new ArrayBuffer(bytes.length); + var buffUint8 = new Uint8Array(buff); + for (var i2 = 0; i2 < bytes.length; i2++) { + buffUint8[i2] = bytes.charCodeAt(i2); + } + return new Blob([buff], { + type: mimeType + }); + } + function b64UriToB64(b64uri) { + var i2 = b64uri.indexOf(","); + return b64uri.substr(i2 + 1); + } + function output(options, canvas, mimeType) { + var getB64Uri = function getB64Uri2() { + return canvas.toDataURL(mimeType, options.quality); + }; + switch (options.output) { + case "blob-promise": + return new Promise$1(function(resolve2, reject) { + try { + canvas.toBlob(function(blob) { + if (blob != null) { + resolve2(blob); + } else { + reject(new Error("`canvas.toBlob()` sent a null value in its callback")); + } + }, mimeType, options.quality); + } catch (err) { + reject(err); + } + }); + case "blob": + return b64ToBlob(b64UriToB64(getB64Uri()), mimeType); + case "base64": + return b64UriToB64(getB64Uri()); + case "base64uri": + default: + return getB64Uri(); + } + } + CRp$2.png = function(options) { + return output(options, this.bufferCanvasImage(options), "image/png"); + }; + CRp$2.jpg = function(options) { + return output(options, this.bufferCanvasImage(options), "image/jpeg"); + }; + var CRp$1 = {}; + CRp$1.nodeShapeImpl = function(name, context, centerX, centerY, width, height, points) { + switch (name) { + case "ellipse": + return this.drawEllipsePath(context, centerX, centerY, width, height); + case "polygon": + return this.drawPolygonPath(context, centerX, centerY, width, height, points); + case "round-polygon": + return this.drawRoundPolygonPath(context, centerX, centerY, width, height, points); + case "roundrectangle": + case "round-rectangle": + return this.drawRoundRectanglePath(context, centerX, centerY, width, height); + case "cutrectangle": + case "cut-rectangle": + return this.drawCutRectanglePath(context, centerX, centerY, width, height); + case "bottomroundrectangle": + case "bottom-round-rectangle": + return this.drawBottomRoundRectanglePath(context, centerX, centerY, width, height); + case "barrel": + return this.drawBarrelPath(context, centerX, centerY, width, height); + } + }; + var CR = CanvasRenderer; + var CRp = CanvasRenderer.prototype; + CRp.CANVAS_LAYERS = 3; + CRp.SELECT_BOX = 0; + CRp.DRAG = 1; + CRp.NODE = 2; + CRp.BUFFER_COUNT = 3; + CRp.TEXTURE_BUFFER = 0; + CRp.MOTIONBLUR_BUFFER_NODE = 1; + CRp.MOTIONBLUR_BUFFER_DRAG = 2; + function CanvasRenderer(options) { + var r = this; + r.data = { + canvases: new Array(CRp.CANVAS_LAYERS), + contexts: new Array(CRp.CANVAS_LAYERS), + canvasNeedsRedraw: new Array(CRp.CANVAS_LAYERS), + bufferCanvases: new Array(CRp.BUFFER_COUNT), + bufferContexts: new Array(CRp.CANVAS_LAYERS) + }; + var tapHlOffAttr = "-webkit-tap-highlight-color"; + var tapHlOffStyle = "rgba(0,0,0,0)"; + r.data.canvasContainer = document.createElement("div"); + var containerStyle = r.data.canvasContainer.style; + r.data.canvasContainer.style[tapHlOffAttr] = tapHlOffStyle; + containerStyle.position = "relative"; + containerStyle.zIndex = "0"; + containerStyle.overflow = "hidden"; + var container = options.cy.container(); + container.appendChild(r.data.canvasContainer); + container.style[tapHlOffAttr] = tapHlOffStyle; + var styleMap = { + "-webkit-user-select": "none", + "-moz-user-select": "-moz-none", + "user-select": "none", + "-webkit-tap-highlight-color": "rgba(0,0,0,0)", + "outline-style": "none" + }; + if (ms()) { + styleMap["-ms-touch-action"] = "none"; + styleMap["touch-action"] = "none"; + } + for (var i2 = 0; i2 < CRp.CANVAS_LAYERS; i2++) { + var canvas = r.data.canvases[i2] = document.createElement("canvas"); + r.data.contexts[i2] = canvas.getContext("2d"); + Object.keys(styleMap).forEach(function(k) { + canvas.style[k] = styleMap[k]; + }); + canvas.style.position = "absolute"; + canvas.setAttribute("data-id", "layer" + i2); + canvas.style.zIndex = String(CRp.CANVAS_LAYERS - i2); + r.data.canvasContainer.appendChild(canvas); + r.data.canvasNeedsRedraw[i2] = false; + } + r.data.topCanvas = r.data.canvases[0]; + r.data.canvases[CRp.NODE].setAttribute("data-id", "layer" + CRp.NODE + "-node"); + r.data.canvases[CRp.SELECT_BOX].setAttribute("data-id", "layer" + CRp.SELECT_BOX + "-selectbox"); + r.data.canvases[CRp.DRAG].setAttribute("data-id", "layer" + CRp.DRAG + "-drag"); + for (var i2 = 0; i2 < CRp.BUFFER_COUNT; i2++) { + r.data.bufferCanvases[i2] = document.createElement("canvas"); + r.data.bufferContexts[i2] = r.data.bufferCanvases[i2].getContext("2d"); + r.data.bufferCanvases[i2].style.position = "absolute"; + r.data.bufferCanvases[i2].setAttribute("data-id", "buffer" + i2); + r.data.bufferCanvases[i2].style.zIndex = String(-i2 - 1); + r.data.bufferCanvases[i2].style.visibility = "hidden"; + } + r.pathsEnabled = true; + var emptyBb = makeBoundingBox(); + var getBoxCenter = function getBoxCenter2(bb) { + return { + x: (bb.x1 + bb.x2) / 2, + y: (bb.y1 + bb.y2) / 2 + }; + }; + var getCenterOffset = function getCenterOffset2(bb) { + return { + x: -bb.w / 2, + y: -bb.h / 2 + }; + }; + var backgroundTimestampHasChanged = function backgroundTimestampHasChanged2(ele) { + var _p = ele[0]._private; + var same = _p.oldBackgroundTimestamp === _p.backgroundTimestamp; + return !same; + }; + var getStyleKey = function getStyleKey2(ele) { + return ele[0]._private.nodeKey; + }; + var getLabelKey = function getLabelKey2(ele) { + return ele[0]._private.labelStyleKey; + }; + var getSourceLabelKey = function getSourceLabelKey2(ele) { + return ele[0]._private.sourceLabelStyleKey; + }; + var getTargetLabelKey = function getTargetLabelKey2(ele) { + return ele[0]._private.targetLabelStyleKey; + }; + var drawElement = function drawElement2(context, ele, bb, scaledLabelShown, useEleOpacity) { + return r.drawElement(context, ele, bb, false, false, useEleOpacity); + }; + var drawLabel = function drawLabel2(context, ele, bb, scaledLabelShown, useEleOpacity) { + return r.drawElementText(context, ele, bb, scaledLabelShown, "main", useEleOpacity); + }; + var drawSourceLabel = function drawSourceLabel2(context, ele, bb, scaledLabelShown, useEleOpacity) { + return r.drawElementText(context, ele, bb, scaledLabelShown, "source", useEleOpacity); + }; + var drawTargetLabel = function drawTargetLabel2(context, ele, bb, scaledLabelShown, useEleOpacity) { + return r.drawElementText(context, ele, bb, scaledLabelShown, "target", useEleOpacity); + }; + var getElementBox = function getElementBox2(ele) { + ele.boundingBox(); + return ele[0]._private.bodyBounds; + }; + var getLabelBox = function getLabelBox2(ele) { + ele.boundingBox(); + return ele[0]._private.labelBounds.main || emptyBb; + }; + var getSourceLabelBox = function getSourceLabelBox2(ele) { + ele.boundingBox(); + return ele[0]._private.labelBounds.source || emptyBb; + }; + var getTargetLabelBox = function getTargetLabelBox2(ele) { + ele.boundingBox(); + return ele[0]._private.labelBounds.target || emptyBb; + }; + var isLabelVisibleAtScale = function isLabelVisibleAtScale2(ele, scaledLabelShown) { + return scaledLabelShown; + }; + var getElementRotationPoint = function getElementRotationPoint2(ele) { + return getBoxCenter(getElementBox(ele)); + }; + var addTextMargin = function addTextMargin2(prefix, pt, ele) { + var pre = prefix ? prefix + "-" : ""; + return { + x: pt.x + ele.pstyle(pre + "text-margin-x").pfValue, + y: pt.y + ele.pstyle(pre + "text-margin-y").pfValue + }; + }; + var getRsPt = function getRsPt2(ele, x, y) { + var rs = ele[0]._private.rscratch; + return { + x: rs[x], + y: rs[y] + }; + }; + var getLabelRotationPoint = function getLabelRotationPoint2(ele) { + return addTextMargin("", getRsPt(ele, "labelX", "labelY"), ele); + }; + var getSourceLabelRotationPoint = function getSourceLabelRotationPoint2(ele) { + return addTextMargin("source", getRsPt(ele, "sourceLabelX", "sourceLabelY"), ele); + }; + var getTargetLabelRotationPoint = function getTargetLabelRotationPoint2(ele) { + return addTextMargin("target", getRsPt(ele, "targetLabelX", "targetLabelY"), ele); + }; + var getElementRotationOffset = function getElementRotationOffset2(ele) { + return getCenterOffset(getElementBox(ele)); + }; + var getSourceLabelRotationOffset = function getSourceLabelRotationOffset2(ele) { + return getCenterOffset(getSourceLabelBox(ele)); + }; + var getTargetLabelRotationOffset = function getTargetLabelRotationOffset2(ele) { + return getCenterOffset(getTargetLabelBox(ele)); + }; + var getLabelRotationOffset = function getLabelRotationOffset2(ele) { + var bb = getLabelBox(ele); + var p2 = getCenterOffset(getLabelBox(ele)); + if (ele.isNode()) { + switch (ele.pstyle("text-halign").value) { + case "left": + p2.x = -bb.w; + break; + case "right": + p2.x = 0; + break; + } + switch (ele.pstyle("text-valign").value) { + case "top": + p2.y = -bb.h; + break; + case "bottom": + p2.y = 0; + break; + } + } + return p2; + }; + var eleTxrCache = r.data.eleTxrCache = new ElementTextureCache(r, { + getKey: getStyleKey, + doesEleInvalidateKey: backgroundTimestampHasChanged, + drawElement, + getBoundingBox: getElementBox, + getRotationPoint: getElementRotationPoint, + getRotationOffset: getElementRotationOffset, + allowEdgeTxrCaching: false, + allowParentTxrCaching: false + }); + var lblTxrCache = r.data.lblTxrCache = new ElementTextureCache(r, { + getKey: getLabelKey, + drawElement: drawLabel, + getBoundingBox: getLabelBox, + getRotationPoint: getLabelRotationPoint, + getRotationOffset: getLabelRotationOffset, + isVisible: isLabelVisibleAtScale + }); + var slbTxrCache = r.data.slbTxrCache = new ElementTextureCache(r, { + getKey: getSourceLabelKey, + drawElement: drawSourceLabel, + getBoundingBox: getSourceLabelBox, + getRotationPoint: getSourceLabelRotationPoint, + getRotationOffset: getSourceLabelRotationOffset, + isVisible: isLabelVisibleAtScale + }); + var tlbTxrCache = r.data.tlbTxrCache = new ElementTextureCache(r, { + getKey: getTargetLabelKey, + drawElement: drawTargetLabel, + getBoundingBox: getTargetLabelBox, + getRotationPoint: getTargetLabelRotationPoint, + getRotationOffset: getTargetLabelRotationOffset, + isVisible: isLabelVisibleAtScale + }); + var lyrTxrCache = r.data.lyrTxrCache = new LayeredTextureCache(r); + r.onUpdateEleCalcs(function invalidateTextureCaches(willDraw, eles) { + eleTxrCache.invalidateElements(eles); + lblTxrCache.invalidateElements(eles); + slbTxrCache.invalidateElements(eles); + tlbTxrCache.invalidateElements(eles); + lyrTxrCache.invalidateElements(eles); + for (var _i = 0; _i < eles.length; _i++) { + var _p = eles[_i]._private; + _p.oldBackgroundTimestamp = _p.backgroundTimestamp; + } + }); + var refineInLayers = function refineInLayers2(reqs) { + for (var i3 = 0; i3 < reqs.length; i3++) { + lyrTxrCache.enqueueElementRefinement(reqs[i3].ele); + } + }; + eleTxrCache.onDequeue(refineInLayers); + lblTxrCache.onDequeue(refineInLayers); + slbTxrCache.onDequeue(refineInLayers); + tlbTxrCache.onDequeue(refineInLayers); + } + CRp.redrawHint = function(group, bool) { + var r = this; + switch (group) { + case "eles": + r.data.canvasNeedsRedraw[CRp.NODE] = bool; + break; + case "drag": + r.data.canvasNeedsRedraw[CRp.DRAG] = bool; + break; + case "select": + r.data.canvasNeedsRedraw[CRp.SELECT_BOX] = bool; + break; + } + }; + var pathsImpld = typeof Path2D !== "undefined"; + CRp.path2dEnabled = function(on) { + if (on === void 0) { + return this.pathsEnabled; + } + this.pathsEnabled = on ? true : false; + }; + CRp.usePaths = function() { + return pathsImpld && this.pathsEnabled; + }; + CRp.setImgSmoothing = function(context, bool) { + if (context.imageSmoothingEnabled != null) { + context.imageSmoothingEnabled = bool; + } else { + context.webkitImageSmoothingEnabled = bool; + context.mozImageSmoothingEnabled = bool; + context.msImageSmoothingEnabled = bool; + } + }; + CRp.getImgSmoothing = function(context) { + if (context.imageSmoothingEnabled != null) { + return context.imageSmoothingEnabled; + } else { + return context.webkitImageSmoothingEnabled || context.mozImageSmoothingEnabled || context.msImageSmoothingEnabled; + } + }; + CRp.makeOffscreenCanvas = function(width, height) { + var canvas; + if ((typeof OffscreenCanvas === "undefined" ? "undefined" : _typeof(OffscreenCanvas)) !== "undefined") { + canvas = new OffscreenCanvas(width, height); + } else { + canvas = document.createElement("canvas"); + canvas.width = width; + canvas.height = height; + } + return canvas; + }; + [CRp$a, CRp$9, CRp$8, CRp$7, CRp$6, CRp$5, CRp$4, CRp$3, CRp$2, CRp$1].forEach(function(props) { + extend(CRp, props); + }); + var renderer2 = [{ + name: "null", + impl: NullRenderer + }, { + name: "base", + impl: BR + }, { + name: "canvas", + impl: CR + }]; + var incExts = [{ + type: "layout", + extensions: layout + }, { + type: "renderer", + extensions: renderer2 + }]; + var extensions = {}; + var modules = {}; + function setExtension(type, name, registrant) { + var ext = registrant; + var overrideErr = function overrideErr2(field) { + warn("Can not register `" + name + "` for `" + type + "` since `" + field + "` already exists in the prototype and can not be overridden"); + }; + if (type === "core") { + if (Core.prototype[name]) { + return overrideErr(name); + } else { + Core.prototype[name] = registrant; + } + } else if (type === "collection") { + if (Collection.prototype[name]) { + return overrideErr(name); + } else { + Collection.prototype[name] = registrant; + } + } else if (type === "layout") { + var Layout2 = function Layout3(options) { + this.options = options; + registrant.call(this, options); + if (!plainObject(this._private)) { + this._private = {}; + } + this._private.cy = options.cy; + this._private.listeners = []; + this.createEmitter(); + }; + var layoutProto = Layout2.prototype = Object.create(registrant.prototype); + var optLayoutFns = []; + for (var i2 = 0; i2 < optLayoutFns.length; i2++) { + var fnName = optLayoutFns[i2]; + layoutProto[fnName] = layoutProto[fnName] || function() { + return this; + }; + } + if (layoutProto.start && !layoutProto.run) { + layoutProto.run = function() { + this.start(); + return this; + }; + } else if (!layoutProto.start && layoutProto.run) { + layoutProto.start = function() { + this.run(); + return this; + }; + } + var regStop = registrant.prototype.stop; + layoutProto.stop = function() { + var opts = this.options; + if (opts && opts.animate) { + var anis = this.animations; + if (anis) { + for (var _i = 0; _i < anis.length; _i++) { + anis[_i].stop(); + } + } + } + if (regStop) { + regStop.call(this); + } else { + this.emit("layoutstop"); + } + return this; + }; + if (!layoutProto.destroy) { + layoutProto.destroy = function() { + return this; + }; + } + layoutProto.cy = function() { + return this._private.cy; + }; + var getCy = function getCy2(layout2) { + return layout2._private.cy; + }; + var emitterOpts = { + addEventFields: function addEventFields(layout2, evt) { + evt.layout = layout2; + evt.cy = getCy(layout2); + evt.target = layout2; + }, + bubble: function bubble() { + return true; + }, + parent: function parent(layout2) { + return getCy(layout2); + } + }; + extend(layoutProto, { + createEmitter: function createEmitter() { + this._private.emitter = new Emitter(emitterOpts, this); + return this; + }, + emitter: function emitter() { + return this._private.emitter; + }, + on: function on(evt, cb) { + this.emitter().on(evt, cb); + return this; + }, + one: function one(evt, cb) { + this.emitter().one(evt, cb); + return this; + }, + once: function once(evt, cb) { + this.emitter().one(evt, cb); + return this; + }, + removeListener: function removeListener(evt, cb) { + this.emitter().removeListener(evt, cb); + return this; + }, + removeAllListeners: function removeAllListeners() { + this.emitter().removeAllListeners(); + return this; + }, + emit: function emit(evt, params) { + this.emitter().emit(evt, params); + return this; + } + }); + define.eventAliasesOn(layoutProto); + ext = Layout2; + } else if (type === "renderer" && name !== "null" && name !== "base") { + var BaseRenderer2 = getExtension("renderer", "base"); + var bProto = BaseRenderer2.prototype; + var RegistrantRenderer = registrant; + var rProto = registrant.prototype; + var Renderer = function Renderer2() { + BaseRenderer2.apply(this, arguments); + RegistrantRenderer.apply(this, arguments); + }; + var proto = Renderer.prototype; + for (var pName in bProto) { + var pVal = bProto[pName]; + var existsInR = rProto[pName] != null; + if (existsInR) { + return overrideErr(pName); + } + proto[pName] = pVal; + } + for (var _pName in rProto) { + proto[_pName] = rProto[_pName]; + } + bProto.clientFunctions.forEach(function(name2) { + proto[name2] = proto[name2] || function() { + error("Renderer does not implement `renderer." + name2 + "()` on its prototype"); + }; + }); + ext = Renderer; + } else if (type === "__proto__" || type === "constructor" || type === "prototype") { + return error(type + " is an illegal type to be registered, possibly lead to prototype pollutions"); + } + return setMap({ + map: extensions, + keys: [type, name], + value: ext + }); + } + function getExtension(type, name) { + return getMap({ + map: extensions, + keys: [type, name] + }); + } + function setModule(type, name, moduleType, moduleName, registrant) { + return setMap({ + map: modules, + keys: [type, name, moduleType, moduleName], + value: registrant + }); + } + function getModule(type, name, moduleType, moduleName) { + return getMap({ + map: modules, + keys: [type, name, moduleType, moduleName] + }); + } + var extension = function extension2() { + if (arguments.length === 2) { + return getExtension.apply(null, arguments); + } else if (arguments.length === 3) { + return setExtension.apply(null, arguments); + } else if (arguments.length === 4) { + return getModule.apply(null, arguments); + } else if (arguments.length === 5) { + return setModule.apply(null, arguments); + } else { + error("Invalid extension access syntax"); + } + }; + Core.prototype.extension = extension; + incExts.forEach(function(group) { + group.extensions.forEach(function(ext) { + setExtension(group.type, ext.name, ext.impl); + }); + }); + var Stylesheet = function Stylesheet2() { + if (!(this instanceof Stylesheet2)) { + return new Stylesheet2(); + } + this.length = 0; + }; + var sheetfn = Stylesheet.prototype; + sheetfn.instanceString = function() { + return "stylesheet"; + }; + sheetfn.selector = function(selector) { + var i2 = this.length++; + this[i2] = { + selector, + properties: [] + }; + return this; + }; + sheetfn.css = function(name, value) { + var i2 = this.length - 1; + if (string(name)) { + this[i2].properties.push({ + name, + value + }); + } else if (plainObject(name)) { + var map = name; + var propNames = Object.keys(map); + for (var j = 0; j < propNames.length; j++) { + var key = propNames[j]; + var mapVal = map[key]; + if (mapVal == null) { + continue; + } + var prop = Style.properties[key] || Style.properties[dash2camel(key)]; + if (prop == null) { + continue; + } + var _name = prop.name; + var _value = mapVal; + this[i2].properties.push({ + name: _name, + value: _value + }); + } + } + return this; + }; + sheetfn.style = sheetfn.css; + sheetfn.generateStyle = function(cy) { + var style = new Style(cy); + return this.appendToStyle(style); + }; + sheetfn.appendToStyle = function(style) { + for (var i2 = 0; i2 < this.length; i2++) { + var context = this[i2]; + var selector = context.selector; + var props = context.properties; + style.selector(selector); + for (var j = 0; j < props.length; j++) { + var prop = props[j]; + style.css(prop.name, prop.value); + } + } + return style; + }; + var version = "3.28.1"; + var cytoscape2 = function cytoscape3(options) { + if (options === void 0) { + options = {}; + } + if (plainObject(options)) { + return new Core(options); + } else if (string(options)) { + return extension.apply(extension, arguments); + } + }; + cytoscape2.use = function(ext) { + var args = Array.prototype.slice.call(arguments, 1); + args.unshift(cytoscape2); + ext.apply(null, args); + return this; + }; + cytoscape2.warnings = function(bool) { + return warnings(bool); + }; + cytoscape2.version = version; + cytoscape2.stylesheet = cytoscape2.Stylesheet = Stylesheet; + return cytoscape2; + }); +})(cytoscape_umd); +var cytoscape_umdExports = cytoscape_umd.exports; +const cytoscape$1 = /* @__PURE__ */ getDefaultExportFromCjs(cytoscape_umdExports); +var cytoscapeCoseBilkent = { exports: {} }; +var coseBase = { exports: {} }; +var layoutBase = { exports: {} }; +var hasRequiredLayoutBase; +function requireLayoutBase() { + if (hasRequiredLayoutBase) + return layoutBase.exports; + hasRequiredLayoutBase = 1; + (function(module, exports) { + (function webpackUniversalModuleDefinition(root, factory) { + module.exports = factory(); + })(commonjsGlobal, function() { + return ( + /******/ + function(modules) { + var installedModules = {}; + function __webpack_require__(moduleId) { + if (installedModules[moduleId]) { + return installedModules[moduleId].exports; + } + var module2 = installedModules[moduleId] = { + /******/ + i: moduleId, + /******/ + l: false, + /******/ + exports: {} + /******/ + }; + modules[moduleId].call(module2.exports, module2, module2.exports, __webpack_require__); + module2.l = true; + return module2.exports; + } + __webpack_require__.m = modules; + __webpack_require__.c = installedModules; + __webpack_require__.i = function(value) { + return value; + }; + __webpack_require__.d = function(exports2, name, getter) { + if (!__webpack_require__.o(exports2, name)) { + Object.defineProperty(exports2, name, { + /******/ + configurable: false, + /******/ + enumerable: true, + /******/ + get: getter + /******/ + }); + } + }; + __webpack_require__.n = function(module2) { + var getter = module2 && module2.__esModule ? ( + /******/ + function getDefault() { + return module2["default"]; + } + ) : ( + /******/ + function getModuleExports() { + return module2; + } + ); + __webpack_require__.d(getter, "a", getter); + return getter; + }; + __webpack_require__.o = function(object, property) { + return Object.prototype.hasOwnProperty.call(object, property); + }; + __webpack_require__.p = ""; + return __webpack_require__(__webpack_require__.s = 26); + }([ + /* 0 */ + /***/ + function(module2, exports2, __webpack_require__) { + function LayoutConstants() { + } + LayoutConstants.QUALITY = 1; + LayoutConstants.DEFAULT_CREATE_BENDS_AS_NEEDED = false; + LayoutConstants.DEFAULT_INCREMENTAL = false; + LayoutConstants.DEFAULT_ANIMATION_ON_LAYOUT = true; + LayoutConstants.DEFAULT_ANIMATION_DURING_LAYOUT = false; + LayoutConstants.DEFAULT_ANIMATION_PERIOD = 50; + LayoutConstants.DEFAULT_UNIFORM_LEAF_NODE_SIZES = false; + LayoutConstants.DEFAULT_GRAPH_MARGIN = 15; + LayoutConstants.NODE_DIMENSIONS_INCLUDE_LABELS = false; + LayoutConstants.SIMPLE_NODE_SIZE = 40; + LayoutConstants.SIMPLE_NODE_HALF_SIZE = LayoutConstants.SIMPLE_NODE_SIZE / 2; + LayoutConstants.EMPTY_COMPOUND_NODE_SIZE = 40; + LayoutConstants.MIN_EDGE_LENGTH = 1; + LayoutConstants.WORLD_BOUNDARY = 1e6; + LayoutConstants.INITIAL_WORLD_BOUNDARY = LayoutConstants.WORLD_BOUNDARY / 1e3; + LayoutConstants.WORLD_CENTER_X = 1200; + LayoutConstants.WORLD_CENTER_Y = 900; + module2.exports = LayoutConstants; + }, + /* 1 */ + /***/ + function(module2, exports2, __webpack_require__) { + var LGraphObject = __webpack_require__(2); + var IGeometry = __webpack_require__(8); + var IMath = __webpack_require__(9); + function LEdge(source, target, vEdge) { + LGraphObject.call(this, vEdge); + this.isOverlapingSourceAndTarget = false; + this.vGraphObject = vEdge; + this.bendpoints = []; + this.source = source; + this.target = target; + } + LEdge.prototype = Object.create(LGraphObject.prototype); + for (var prop in LGraphObject) { + LEdge[prop] = LGraphObject[prop]; + } + LEdge.prototype.getSource = function() { + return this.source; + }; + LEdge.prototype.getTarget = function() { + return this.target; + }; + LEdge.prototype.isInterGraph = function() { + return this.isInterGraph; + }; + LEdge.prototype.getLength = function() { + return this.length; + }; + LEdge.prototype.isOverlapingSourceAndTarget = function() { + return this.isOverlapingSourceAndTarget; + }; + LEdge.prototype.getBendpoints = function() { + return this.bendpoints; + }; + LEdge.prototype.getLca = function() { + return this.lca; + }; + LEdge.prototype.getSourceInLca = function() { + return this.sourceInLca; + }; + LEdge.prototype.getTargetInLca = function() { + return this.targetInLca; + }; + LEdge.prototype.getOtherEnd = function(node) { + if (this.source === node) { + return this.target; + } else if (this.target === node) { + return this.source; + } else { + throw "Node is not incident with this edge"; + } + }; + LEdge.prototype.getOtherEndInGraph = function(node, graph) { + var otherEnd = this.getOtherEnd(node); + var root = graph.getGraphManager().getRoot(); + while (true) { + if (otherEnd.getOwner() == graph) { + return otherEnd; + } + if (otherEnd.getOwner() == root) { + break; + } + otherEnd = otherEnd.getOwner().getParent(); + } + return null; + }; + LEdge.prototype.updateLength = function() { + var clipPointCoordinates = new Array(4); + this.isOverlapingSourceAndTarget = IGeometry.getIntersection(this.target.getRect(), this.source.getRect(), clipPointCoordinates); + if (!this.isOverlapingSourceAndTarget) { + this.lengthX = clipPointCoordinates[0] - clipPointCoordinates[2]; + this.lengthY = clipPointCoordinates[1] - clipPointCoordinates[3]; + if (Math.abs(this.lengthX) < 1) { + this.lengthX = IMath.sign(this.lengthX); + } + if (Math.abs(this.lengthY) < 1) { + this.lengthY = IMath.sign(this.lengthY); + } + this.length = Math.sqrt(this.lengthX * this.lengthX + this.lengthY * this.lengthY); + } + }; + LEdge.prototype.updateLengthSimple = function() { + this.lengthX = this.target.getCenterX() - this.source.getCenterX(); + this.lengthY = this.target.getCenterY() - this.source.getCenterY(); + if (Math.abs(this.lengthX) < 1) { + this.lengthX = IMath.sign(this.lengthX); + } + if (Math.abs(this.lengthY) < 1) { + this.lengthY = IMath.sign(this.lengthY); + } + this.length = Math.sqrt(this.lengthX * this.lengthX + this.lengthY * this.lengthY); + }; + module2.exports = LEdge; + }, + /* 2 */ + /***/ + function(module2, exports2, __webpack_require__) { + function LGraphObject(vGraphObject) { + this.vGraphObject = vGraphObject; + } + module2.exports = LGraphObject; + }, + /* 3 */ + /***/ + function(module2, exports2, __webpack_require__) { + var LGraphObject = __webpack_require__(2); + var Integer = __webpack_require__(10); + var RectangleD = __webpack_require__(13); + var LayoutConstants = __webpack_require__(0); + var RandomSeed = __webpack_require__(16); + var PointD = __webpack_require__(4); + function LNode(gm, loc, size, vNode) { + if (size == null && vNode == null) { + vNode = loc; + } + LGraphObject.call(this, vNode); + if (gm.graphManager != null) + gm = gm.graphManager; + this.estimatedSize = Integer.MIN_VALUE; + this.inclusionTreeDepth = Integer.MAX_VALUE; + this.vGraphObject = vNode; + this.edges = []; + this.graphManager = gm; + if (size != null && loc != null) + this.rect = new RectangleD(loc.x, loc.y, size.width, size.height); + else + this.rect = new RectangleD(); + } + LNode.prototype = Object.create(LGraphObject.prototype); + for (var prop in LGraphObject) { + LNode[prop] = LGraphObject[prop]; + } + LNode.prototype.getEdges = function() { + return this.edges; + }; + LNode.prototype.getChild = function() { + return this.child; + }; + LNode.prototype.getOwner = function() { + return this.owner; + }; + LNode.prototype.getWidth = function() { + return this.rect.width; + }; + LNode.prototype.setWidth = function(width) { + this.rect.width = width; + }; + LNode.prototype.getHeight = function() { + return this.rect.height; + }; + LNode.prototype.setHeight = function(height) { + this.rect.height = height; + }; + LNode.prototype.getCenterX = function() { + return this.rect.x + this.rect.width / 2; + }; + LNode.prototype.getCenterY = function() { + return this.rect.y + this.rect.height / 2; + }; + LNode.prototype.getCenter = function() { + return new PointD(this.rect.x + this.rect.width / 2, this.rect.y + this.rect.height / 2); + }; + LNode.prototype.getLocation = function() { + return new PointD(this.rect.x, this.rect.y); + }; + LNode.prototype.getRect = function() { + return this.rect; + }; + LNode.prototype.getDiagonal = function() { + return Math.sqrt(this.rect.width * this.rect.width + this.rect.height * this.rect.height); + }; + LNode.prototype.getHalfTheDiagonal = function() { + return Math.sqrt(this.rect.height * this.rect.height + this.rect.width * this.rect.width) / 2; + }; + LNode.prototype.setRect = function(upperLeft, dimension) { + this.rect.x = upperLeft.x; + this.rect.y = upperLeft.y; + this.rect.width = dimension.width; + this.rect.height = dimension.height; + }; + LNode.prototype.setCenter = function(cx, cy) { + this.rect.x = cx - this.rect.width / 2; + this.rect.y = cy - this.rect.height / 2; + }; + LNode.prototype.setLocation = function(x, y) { + this.rect.x = x; + this.rect.y = y; + }; + LNode.prototype.moveBy = function(dx, dy) { + this.rect.x += dx; + this.rect.y += dy; + }; + LNode.prototype.getEdgeListToNode = function(to) { + var edgeList = []; + var self2 = this; + self2.edges.forEach(function(edge) { + if (edge.target == to) { + if (edge.source != self2) + throw "Incorrect edge source!"; + edgeList.push(edge); + } + }); + return edgeList; + }; + LNode.prototype.getEdgesBetween = function(other) { + var edgeList = []; + var self2 = this; + self2.edges.forEach(function(edge) { + if (!(edge.source == self2 || edge.target == self2)) + throw "Incorrect edge source and/or target"; + if (edge.target == other || edge.source == other) { + edgeList.push(edge); + } + }); + return edgeList; + }; + LNode.prototype.getNeighborsList = function() { + var neighbors = /* @__PURE__ */ new Set(); + var self2 = this; + self2.edges.forEach(function(edge) { + if (edge.source == self2) { + neighbors.add(edge.target); + } else { + if (edge.target != self2) { + throw "Incorrect incidency!"; + } + neighbors.add(edge.source); + } + }); + return neighbors; + }; + LNode.prototype.withChildren = function() { + var withNeighborsList = /* @__PURE__ */ new Set(); + var childNode; + var children; + withNeighborsList.add(this); + if (this.child != null) { + var nodes2 = this.child.getNodes(); + for (var i = 0; i < nodes2.length; i++) { + childNode = nodes2[i]; + children = childNode.withChildren(); + children.forEach(function(node) { + withNeighborsList.add(node); + }); + } + } + return withNeighborsList; + }; + LNode.prototype.getNoOfChildren = function() { + var noOfChildren = 0; + var childNode; + if (this.child == null) { + noOfChildren = 1; + } else { + var nodes2 = this.child.getNodes(); + for (var i = 0; i < nodes2.length; i++) { + childNode = nodes2[i]; + noOfChildren += childNode.getNoOfChildren(); + } + } + if (noOfChildren == 0) { + noOfChildren = 1; + } + return noOfChildren; + }; + LNode.prototype.getEstimatedSize = function() { + if (this.estimatedSize == Integer.MIN_VALUE) { + throw "assert failed"; + } + return this.estimatedSize; + }; + LNode.prototype.calcEstimatedSize = function() { + if (this.child == null) { + return this.estimatedSize = (this.rect.width + this.rect.height) / 2; + } else { + this.estimatedSize = this.child.calcEstimatedSize(); + this.rect.width = this.estimatedSize; + this.rect.height = this.estimatedSize; + return this.estimatedSize; + } + }; + LNode.prototype.scatter = function() { + var randomCenterX; + var randomCenterY; + var minX = -LayoutConstants.INITIAL_WORLD_BOUNDARY; + var maxX = LayoutConstants.INITIAL_WORLD_BOUNDARY; + randomCenterX = LayoutConstants.WORLD_CENTER_X + RandomSeed.nextDouble() * (maxX - minX) + minX; + var minY = -LayoutConstants.INITIAL_WORLD_BOUNDARY; + var maxY = LayoutConstants.INITIAL_WORLD_BOUNDARY; + randomCenterY = LayoutConstants.WORLD_CENTER_Y + RandomSeed.nextDouble() * (maxY - minY) + minY; + this.rect.x = randomCenterX; + this.rect.y = randomCenterY; + }; + LNode.prototype.updateBounds = function() { + if (this.getChild() == null) { + throw "assert failed"; + } + if (this.getChild().getNodes().length != 0) { + var childGraph = this.getChild(); + childGraph.updateBounds(true); + this.rect.x = childGraph.getLeft(); + this.rect.y = childGraph.getTop(); + this.setWidth(childGraph.getRight() - childGraph.getLeft()); + this.setHeight(childGraph.getBottom() - childGraph.getTop()); + if (LayoutConstants.NODE_DIMENSIONS_INCLUDE_LABELS) { + var width = childGraph.getRight() - childGraph.getLeft(); + var height = childGraph.getBottom() - childGraph.getTop(); + if (this.labelWidth > width) { + this.rect.x -= (this.labelWidth - width) / 2; + this.setWidth(this.labelWidth); + } + if (this.labelHeight > height) { + if (this.labelPos == "center") { + this.rect.y -= (this.labelHeight - height) / 2; + } else if (this.labelPos == "top") { + this.rect.y -= this.labelHeight - height; + } + this.setHeight(this.labelHeight); + } + } + } + }; + LNode.prototype.getInclusionTreeDepth = function() { + if (this.inclusionTreeDepth == Integer.MAX_VALUE) { + throw "assert failed"; + } + return this.inclusionTreeDepth; + }; + LNode.prototype.transform = function(trans) { + var left = this.rect.x; + if (left > LayoutConstants.WORLD_BOUNDARY) { + left = LayoutConstants.WORLD_BOUNDARY; + } else if (left < -LayoutConstants.WORLD_BOUNDARY) { + left = -LayoutConstants.WORLD_BOUNDARY; + } + var top = this.rect.y; + if (top > LayoutConstants.WORLD_BOUNDARY) { + top = LayoutConstants.WORLD_BOUNDARY; + } else if (top < -LayoutConstants.WORLD_BOUNDARY) { + top = -LayoutConstants.WORLD_BOUNDARY; + } + var leftTop = new PointD(left, top); + var vLeftTop = trans.inverseTransformPoint(leftTop); + this.setLocation(vLeftTop.x, vLeftTop.y); + }; + LNode.prototype.getLeft = function() { + return this.rect.x; + }; + LNode.prototype.getRight = function() { + return this.rect.x + this.rect.width; + }; + LNode.prototype.getTop = function() { + return this.rect.y; + }; + LNode.prototype.getBottom = function() { + return this.rect.y + this.rect.height; + }; + LNode.prototype.getParent = function() { + if (this.owner == null) { + return null; + } + return this.owner.getParent(); + }; + module2.exports = LNode; + }, + /* 4 */ + /***/ + function(module2, exports2, __webpack_require__) { + function PointD(x, y) { + if (x == null && y == null) { + this.x = 0; + this.y = 0; + } else { + this.x = x; + this.y = y; + } + } + PointD.prototype.getX = function() { + return this.x; + }; + PointD.prototype.getY = function() { + return this.y; + }; + PointD.prototype.setX = function(x) { + this.x = x; + }; + PointD.prototype.setY = function(y) { + this.y = y; + }; + PointD.prototype.getDifference = function(pt) { + return new DimensionD(this.x - pt.x, this.y - pt.y); + }; + PointD.prototype.getCopy = function() { + return new PointD(this.x, this.y); + }; + PointD.prototype.translate = function(dim) { + this.x += dim.width; + this.y += dim.height; + return this; + }; + module2.exports = PointD; + }, + /* 5 */ + /***/ + function(module2, exports2, __webpack_require__) { + var LGraphObject = __webpack_require__(2); + var Integer = __webpack_require__(10); + var LayoutConstants = __webpack_require__(0); + var LGraphManager = __webpack_require__(6); + var LNode = __webpack_require__(3); + var LEdge = __webpack_require__(1); + var RectangleD = __webpack_require__(13); + var Point2 = __webpack_require__(12); + var LinkedList = __webpack_require__(11); + function LGraph(parent, obj2, vGraph) { + LGraphObject.call(this, vGraph); + this.estimatedSize = Integer.MIN_VALUE; + this.margin = LayoutConstants.DEFAULT_GRAPH_MARGIN; + this.edges = []; + this.nodes = []; + this.isConnected = false; + this.parent = parent; + if (obj2 != null && obj2 instanceof LGraphManager) { + this.graphManager = obj2; + } else if (obj2 != null && obj2 instanceof Layout) { + this.graphManager = obj2.graphManager; + } + } + LGraph.prototype = Object.create(LGraphObject.prototype); + for (var prop in LGraphObject) { + LGraph[prop] = LGraphObject[prop]; + } + LGraph.prototype.getNodes = function() { + return this.nodes; + }; + LGraph.prototype.getEdges = function() { + return this.edges; + }; + LGraph.prototype.getGraphManager = function() { + return this.graphManager; + }; + LGraph.prototype.getParent = function() { + return this.parent; + }; + LGraph.prototype.getLeft = function() { + return this.left; + }; + LGraph.prototype.getRight = function() { + return this.right; + }; + LGraph.prototype.getTop = function() { + return this.top; + }; + LGraph.prototype.getBottom = function() { + return this.bottom; + }; + LGraph.prototype.isConnected = function() { + return this.isConnected; + }; + LGraph.prototype.add = function(obj1, sourceNode, targetNode) { + if (sourceNode == null && targetNode == null) { + var newNode = obj1; + if (this.graphManager == null) { + throw "Graph has no graph mgr!"; + } + if (this.getNodes().indexOf(newNode) > -1) { + throw "Node already in graph!"; + } + newNode.owner = this; + this.getNodes().push(newNode); + return newNode; + } else { + var newEdge = obj1; + if (!(this.getNodes().indexOf(sourceNode) > -1 && this.getNodes().indexOf(targetNode) > -1)) { + throw "Source or target not in graph!"; + } + if (!(sourceNode.owner == targetNode.owner && sourceNode.owner == this)) { + throw "Both owners must be this graph!"; + } + if (sourceNode.owner != targetNode.owner) { + return null; + } + newEdge.source = sourceNode; + newEdge.target = targetNode; + newEdge.isInterGraph = false; + this.getEdges().push(newEdge); + sourceNode.edges.push(newEdge); + if (targetNode != sourceNode) { + targetNode.edges.push(newEdge); + } + return newEdge; + } + }; + LGraph.prototype.remove = function(obj) { + var node = obj; + if (obj instanceof LNode) { + if (node == null) { + throw "Node is null!"; + } + if (!(node.owner != null && node.owner == this)) { + throw "Owner graph is invalid!"; + } + if (this.graphManager == null) { + throw "Owner graph manager is invalid!"; + } + var edgesToBeRemoved = node.edges.slice(); + var edge; + var s = edgesToBeRemoved.length; + for (var i = 0; i < s; i++) { + edge = edgesToBeRemoved[i]; + if (edge.isInterGraph) { + this.graphManager.remove(edge); + } else { + edge.source.owner.remove(edge); + } + } + var index = this.nodes.indexOf(node); + if (index == -1) { + throw "Node not in owner node list!"; + } + this.nodes.splice(index, 1); + } else if (obj instanceof LEdge) { + var edge = obj; + if (edge == null) { + throw "Edge is null!"; + } + if (!(edge.source != null && edge.target != null)) { + throw "Source and/or target is null!"; + } + if (!(edge.source.owner != null && edge.target.owner != null && edge.source.owner == this && edge.target.owner == this)) { + throw "Source and/or target owner is invalid!"; + } + var sourceIndex = edge.source.edges.indexOf(edge); + var targetIndex = edge.target.edges.indexOf(edge); + if (!(sourceIndex > -1 && targetIndex > -1)) { + throw "Source and/or target doesn't know this edge!"; + } + edge.source.edges.splice(sourceIndex, 1); + if (edge.target != edge.source) { + edge.target.edges.splice(targetIndex, 1); + } + var index = edge.source.owner.getEdges().indexOf(edge); + if (index == -1) { + throw "Not in owner's edge list!"; + } + edge.source.owner.getEdges().splice(index, 1); + } + }; + LGraph.prototype.updateLeftTop = function() { + var top = Integer.MAX_VALUE; + var left = Integer.MAX_VALUE; + var nodeTop; + var nodeLeft; + var margin; + var nodes2 = this.getNodes(); + var s = nodes2.length; + for (var i = 0; i < s; i++) { + var lNode = nodes2[i]; + nodeTop = lNode.getTop(); + nodeLeft = lNode.getLeft(); + if (top > nodeTop) { + top = nodeTop; + } + if (left > nodeLeft) { + left = nodeLeft; + } + } + if (top == Integer.MAX_VALUE) { + return null; + } + if (nodes2[0].getParent().paddingLeft != void 0) { + margin = nodes2[0].getParent().paddingLeft; + } else { + margin = this.margin; + } + this.left = left - margin; + this.top = top - margin; + return new Point2(this.left, this.top); + }; + LGraph.prototype.updateBounds = function(recursive) { + var left = Integer.MAX_VALUE; + var right = -Integer.MAX_VALUE; + var top = Integer.MAX_VALUE; + var bottom = -Integer.MAX_VALUE; + var nodeLeft; + var nodeRight; + var nodeTop; + var nodeBottom; + var margin; + var nodes2 = this.nodes; + var s = nodes2.length; + for (var i = 0; i < s; i++) { + var lNode = nodes2[i]; + if (recursive && lNode.child != null) { + lNode.updateBounds(); + } + nodeLeft = lNode.getLeft(); + nodeRight = lNode.getRight(); + nodeTop = lNode.getTop(); + nodeBottom = lNode.getBottom(); + if (left > nodeLeft) { + left = nodeLeft; + } + if (right < nodeRight) { + right = nodeRight; + } + if (top > nodeTop) { + top = nodeTop; + } + if (bottom < nodeBottom) { + bottom = nodeBottom; + } + } + var boundingRect = new RectangleD(left, top, right - left, bottom - top); + if (left == Integer.MAX_VALUE) { + this.left = this.parent.getLeft(); + this.right = this.parent.getRight(); + this.top = this.parent.getTop(); + this.bottom = this.parent.getBottom(); + } + if (nodes2[0].getParent().paddingLeft != void 0) { + margin = nodes2[0].getParent().paddingLeft; + } else { + margin = this.margin; + } + this.left = boundingRect.x - margin; + this.right = boundingRect.x + boundingRect.width + margin; + this.top = boundingRect.y - margin; + this.bottom = boundingRect.y + boundingRect.height + margin; + }; + LGraph.calculateBounds = function(nodes2) { + var left = Integer.MAX_VALUE; + var right = -Integer.MAX_VALUE; + var top = Integer.MAX_VALUE; + var bottom = -Integer.MAX_VALUE; + var nodeLeft; + var nodeRight; + var nodeTop; + var nodeBottom; + var s = nodes2.length; + for (var i = 0; i < s; i++) { + var lNode = nodes2[i]; + nodeLeft = lNode.getLeft(); + nodeRight = lNode.getRight(); + nodeTop = lNode.getTop(); + nodeBottom = lNode.getBottom(); + if (left > nodeLeft) { + left = nodeLeft; + } + if (right < nodeRight) { + right = nodeRight; + } + if (top > nodeTop) { + top = nodeTop; + } + if (bottom < nodeBottom) { + bottom = nodeBottom; + } + } + var boundingRect = new RectangleD(left, top, right - left, bottom - top); + return boundingRect; + }; + LGraph.prototype.getInclusionTreeDepth = function() { + if (this == this.graphManager.getRoot()) { + return 1; + } else { + return this.parent.getInclusionTreeDepth(); + } + }; + LGraph.prototype.getEstimatedSize = function() { + if (this.estimatedSize == Integer.MIN_VALUE) { + throw "assert failed"; + } + return this.estimatedSize; + }; + LGraph.prototype.calcEstimatedSize = function() { + var size = 0; + var nodes2 = this.nodes; + var s = nodes2.length; + for (var i = 0; i < s; i++) { + var lNode = nodes2[i]; + size += lNode.calcEstimatedSize(); + } + if (size == 0) { + this.estimatedSize = LayoutConstants.EMPTY_COMPOUND_NODE_SIZE; + } else { + this.estimatedSize = size / Math.sqrt(this.nodes.length); + } + return this.estimatedSize; + }; + LGraph.prototype.updateConnected = function() { + var self2 = this; + if (this.nodes.length == 0) { + this.isConnected = true; + return; + } + var queue = new LinkedList(); + var visited = /* @__PURE__ */ new Set(); + var currentNode = this.nodes[0]; + var neighborEdges; + var currentNeighbor; + var childrenOfNode = currentNode.withChildren(); + childrenOfNode.forEach(function(node) { + queue.push(node); + visited.add(node); + }); + while (queue.length !== 0) { + currentNode = queue.shift(); + neighborEdges = currentNode.getEdges(); + var size = neighborEdges.length; + for (var i = 0; i < size; i++) { + var neighborEdge = neighborEdges[i]; + currentNeighbor = neighborEdge.getOtherEndInGraph(currentNode, this); + if (currentNeighbor != null && !visited.has(currentNeighbor)) { + var childrenOfNeighbor = currentNeighbor.withChildren(); + childrenOfNeighbor.forEach(function(node) { + queue.push(node); + visited.add(node); + }); + } + } + } + this.isConnected = false; + if (visited.size >= this.nodes.length) { + var noOfVisitedInThisGraph = 0; + visited.forEach(function(visitedNode) { + if (visitedNode.owner == self2) { + noOfVisitedInThisGraph++; + } + }); + if (noOfVisitedInThisGraph == this.nodes.length) { + this.isConnected = true; + } + } + }; + module2.exports = LGraph; + }, + /* 6 */ + /***/ + function(module2, exports2, __webpack_require__) { + var LGraph; + var LEdge = __webpack_require__(1); + function LGraphManager(layout) { + LGraph = __webpack_require__(5); + this.layout = layout; + this.graphs = []; + this.edges = []; + } + LGraphManager.prototype.addRoot = function() { + var ngraph = this.layout.newGraph(); + var nnode = this.layout.newNode(null); + var root = this.add(ngraph, nnode); + this.setRootGraph(root); + return this.rootGraph; + }; + LGraphManager.prototype.add = function(newGraph, parentNode, newEdge, sourceNode, targetNode) { + if (newEdge == null && sourceNode == null && targetNode == null) { + if (newGraph == null) { + throw "Graph is null!"; + } + if (parentNode == null) { + throw "Parent node is null!"; + } + if (this.graphs.indexOf(newGraph) > -1) { + throw "Graph already in this graph mgr!"; + } + this.graphs.push(newGraph); + if (newGraph.parent != null) { + throw "Already has a parent!"; + } + if (parentNode.child != null) { + throw "Already has a child!"; + } + newGraph.parent = parentNode; + parentNode.child = newGraph; + return newGraph; + } else { + targetNode = newEdge; + sourceNode = parentNode; + newEdge = newGraph; + var sourceGraph = sourceNode.getOwner(); + var targetGraph = targetNode.getOwner(); + if (!(sourceGraph != null && sourceGraph.getGraphManager() == this)) { + throw "Source not in this graph mgr!"; + } + if (!(targetGraph != null && targetGraph.getGraphManager() == this)) { + throw "Target not in this graph mgr!"; + } + if (sourceGraph == targetGraph) { + newEdge.isInterGraph = false; + return sourceGraph.add(newEdge, sourceNode, targetNode); + } else { + newEdge.isInterGraph = true; + newEdge.source = sourceNode; + newEdge.target = targetNode; + if (this.edges.indexOf(newEdge) > -1) { + throw "Edge already in inter-graph edge list!"; + } + this.edges.push(newEdge); + if (!(newEdge.source != null && newEdge.target != null)) { + throw "Edge source and/or target is null!"; + } + if (!(newEdge.source.edges.indexOf(newEdge) == -1 && newEdge.target.edges.indexOf(newEdge) == -1)) { + throw "Edge already in source and/or target incidency list!"; + } + newEdge.source.edges.push(newEdge); + newEdge.target.edges.push(newEdge); + return newEdge; + } + } + }; + LGraphManager.prototype.remove = function(lObj) { + if (lObj instanceof LGraph) { + var graph = lObj; + if (graph.getGraphManager() != this) { + throw "Graph not in this graph mgr"; + } + if (!(graph == this.rootGraph || graph.parent != null && graph.parent.graphManager == this)) { + throw "Invalid parent node!"; + } + var edgesToBeRemoved = []; + edgesToBeRemoved = edgesToBeRemoved.concat(graph.getEdges()); + var edge; + var s = edgesToBeRemoved.length; + for (var i = 0; i < s; i++) { + edge = edgesToBeRemoved[i]; + graph.remove(edge); + } + var nodesToBeRemoved = []; + nodesToBeRemoved = nodesToBeRemoved.concat(graph.getNodes()); + var node; + s = nodesToBeRemoved.length; + for (var i = 0; i < s; i++) { + node = nodesToBeRemoved[i]; + graph.remove(node); + } + if (graph == this.rootGraph) { + this.setRootGraph(null); + } + var index = this.graphs.indexOf(graph); + this.graphs.splice(index, 1); + graph.parent = null; + } else if (lObj instanceof LEdge) { + edge = lObj; + if (edge == null) { + throw "Edge is null!"; + } + if (!edge.isInterGraph) { + throw "Not an inter-graph edge!"; + } + if (!(edge.source != null && edge.target != null)) { + throw "Source and/or target is null!"; + } + if (!(edge.source.edges.indexOf(edge) != -1 && edge.target.edges.indexOf(edge) != -1)) { + throw "Source and/or target doesn't know this edge!"; + } + var index = edge.source.edges.indexOf(edge); + edge.source.edges.splice(index, 1); + index = edge.target.edges.indexOf(edge); + edge.target.edges.splice(index, 1); + if (!(edge.source.owner != null && edge.source.owner.getGraphManager() != null)) { + throw "Edge owner graph or owner graph manager is null!"; + } + if (edge.source.owner.getGraphManager().edges.indexOf(edge) == -1) { + throw "Not in owner graph manager's edge list!"; + } + var index = edge.source.owner.getGraphManager().edges.indexOf(edge); + edge.source.owner.getGraphManager().edges.splice(index, 1); + } + }; + LGraphManager.prototype.updateBounds = function() { + this.rootGraph.updateBounds(true); + }; + LGraphManager.prototype.getGraphs = function() { + return this.graphs; + }; + LGraphManager.prototype.getAllNodes = function() { + if (this.allNodes == null) { + var nodeList = []; + var graphs = this.getGraphs(); + var s = graphs.length; + for (var i = 0; i < s; i++) { + nodeList = nodeList.concat(graphs[i].getNodes()); + } + this.allNodes = nodeList; + } + return this.allNodes; + }; + LGraphManager.prototype.resetAllNodes = function() { + this.allNodes = null; + }; + LGraphManager.prototype.resetAllEdges = function() { + this.allEdges = null; + }; + LGraphManager.prototype.resetAllNodesToApplyGravitation = function() { + this.allNodesToApplyGravitation = null; + }; + LGraphManager.prototype.getAllEdges = function() { + if (this.allEdges == null) { + var edgeList = []; + var graphs = this.getGraphs(); + graphs.length; + for (var i = 0; i < graphs.length; i++) { + edgeList = edgeList.concat(graphs[i].getEdges()); + } + edgeList = edgeList.concat(this.edges); + this.allEdges = edgeList; + } + return this.allEdges; + }; + LGraphManager.prototype.getAllNodesToApplyGravitation = function() { + return this.allNodesToApplyGravitation; + }; + LGraphManager.prototype.setAllNodesToApplyGravitation = function(nodeList) { + if (this.allNodesToApplyGravitation != null) { + throw "assert failed"; + } + this.allNodesToApplyGravitation = nodeList; + }; + LGraphManager.prototype.getRoot = function() { + return this.rootGraph; + }; + LGraphManager.prototype.setRootGraph = function(graph) { + if (graph.getGraphManager() != this) { + throw "Root not in this graph mgr!"; + } + this.rootGraph = graph; + if (graph.parent == null) { + graph.parent = this.layout.newNode("Root node"); + } + }; + LGraphManager.prototype.getLayout = function() { + return this.layout; + }; + LGraphManager.prototype.isOneAncestorOfOther = function(firstNode, secondNode) { + if (!(firstNode != null && secondNode != null)) { + throw "assert failed"; + } + if (firstNode == secondNode) { + return true; + } + var ownerGraph = firstNode.getOwner(); + var parentNode; + do { + parentNode = ownerGraph.getParent(); + if (parentNode == null) { + break; + } + if (parentNode == secondNode) { + return true; + } + ownerGraph = parentNode.getOwner(); + if (ownerGraph == null) { + break; + } + } while (true); + ownerGraph = secondNode.getOwner(); + do { + parentNode = ownerGraph.getParent(); + if (parentNode == null) { + break; + } + if (parentNode == firstNode) { + return true; + } + ownerGraph = parentNode.getOwner(); + if (ownerGraph == null) { + break; + } + } while (true); + return false; + }; + LGraphManager.prototype.calcLowestCommonAncestors = function() { + var edge; + var sourceNode; + var targetNode; + var sourceAncestorGraph; + var targetAncestorGraph; + var edges = this.getAllEdges(); + var s = edges.length; + for (var i = 0; i < s; i++) { + edge = edges[i]; + sourceNode = edge.source; + targetNode = edge.target; + edge.lca = null; + edge.sourceInLca = sourceNode; + edge.targetInLca = targetNode; + if (sourceNode == targetNode) { + edge.lca = sourceNode.getOwner(); + continue; + } + sourceAncestorGraph = sourceNode.getOwner(); + while (edge.lca == null) { + edge.targetInLca = targetNode; + targetAncestorGraph = targetNode.getOwner(); + while (edge.lca == null) { + if (targetAncestorGraph == sourceAncestorGraph) { + edge.lca = targetAncestorGraph; + break; + } + if (targetAncestorGraph == this.rootGraph) { + break; + } + if (edge.lca != null) { + throw "assert failed"; + } + edge.targetInLca = targetAncestorGraph.getParent(); + targetAncestorGraph = edge.targetInLca.getOwner(); + } + if (sourceAncestorGraph == this.rootGraph) { + break; + } + if (edge.lca == null) { + edge.sourceInLca = sourceAncestorGraph.getParent(); + sourceAncestorGraph = edge.sourceInLca.getOwner(); + } + } + if (edge.lca == null) { + throw "assert failed"; + } + } + }; + LGraphManager.prototype.calcLowestCommonAncestor = function(firstNode, secondNode) { + if (firstNode == secondNode) { + return firstNode.getOwner(); + } + var firstOwnerGraph = firstNode.getOwner(); + do { + if (firstOwnerGraph == null) { + break; + } + var secondOwnerGraph = secondNode.getOwner(); + do { + if (secondOwnerGraph == null) { + break; + } + if (secondOwnerGraph == firstOwnerGraph) { + return secondOwnerGraph; + } + secondOwnerGraph = secondOwnerGraph.getParent().getOwner(); + } while (true); + firstOwnerGraph = firstOwnerGraph.getParent().getOwner(); + } while (true); + return firstOwnerGraph; + }; + LGraphManager.prototype.calcInclusionTreeDepths = function(graph, depth) { + if (graph == null && depth == null) { + graph = this.rootGraph; + depth = 1; + } + var node; + var nodes2 = graph.getNodes(); + var s = nodes2.length; + for (var i = 0; i < s; i++) { + node = nodes2[i]; + node.inclusionTreeDepth = depth; + if (node.child != null) { + this.calcInclusionTreeDepths(node.child, depth + 1); + } + } + }; + LGraphManager.prototype.includesInvalidEdge = function() { + var edge; + var s = this.edges.length; + for (var i = 0; i < s; i++) { + edge = this.edges[i]; + if (this.isOneAncestorOfOther(edge.source, edge.target)) { + return true; + } + } + return false; + }; + module2.exports = LGraphManager; + }, + /* 7 */ + /***/ + function(module2, exports2, __webpack_require__) { + var LayoutConstants = __webpack_require__(0); + function FDLayoutConstants() { + } + for (var prop in LayoutConstants) { + FDLayoutConstants[prop] = LayoutConstants[prop]; + } + FDLayoutConstants.MAX_ITERATIONS = 2500; + FDLayoutConstants.DEFAULT_EDGE_LENGTH = 50; + FDLayoutConstants.DEFAULT_SPRING_STRENGTH = 0.45; + FDLayoutConstants.DEFAULT_REPULSION_STRENGTH = 4500; + FDLayoutConstants.DEFAULT_GRAVITY_STRENGTH = 0.4; + FDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_STRENGTH = 1; + FDLayoutConstants.DEFAULT_GRAVITY_RANGE_FACTOR = 3.8; + FDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_RANGE_FACTOR = 1.5; + FDLayoutConstants.DEFAULT_USE_SMART_IDEAL_EDGE_LENGTH_CALCULATION = true; + FDLayoutConstants.DEFAULT_USE_SMART_REPULSION_RANGE_CALCULATION = true; + FDLayoutConstants.DEFAULT_COOLING_FACTOR_INCREMENTAL = 0.3; + FDLayoutConstants.COOLING_ADAPTATION_FACTOR = 0.33; + FDLayoutConstants.ADAPTATION_LOWER_NODE_LIMIT = 1e3; + FDLayoutConstants.ADAPTATION_UPPER_NODE_LIMIT = 5e3; + FDLayoutConstants.MAX_NODE_DISPLACEMENT_INCREMENTAL = 100; + FDLayoutConstants.MAX_NODE_DISPLACEMENT = FDLayoutConstants.MAX_NODE_DISPLACEMENT_INCREMENTAL * 3; + FDLayoutConstants.MIN_REPULSION_DIST = FDLayoutConstants.DEFAULT_EDGE_LENGTH / 10; + FDLayoutConstants.CONVERGENCE_CHECK_PERIOD = 100; + FDLayoutConstants.PER_LEVEL_IDEAL_EDGE_LENGTH_FACTOR = 0.1; + FDLayoutConstants.MIN_EDGE_LENGTH = 1; + FDLayoutConstants.GRID_CALCULATION_CHECK_PERIOD = 10; + module2.exports = FDLayoutConstants; + }, + /* 8 */ + /***/ + function(module2, exports2, __webpack_require__) { + var Point2 = __webpack_require__(12); + function IGeometry() { + } + IGeometry.calcSeparationAmount = function(rectA, rectB, overlapAmount, separationBuffer) { + if (!rectA.intersects(rectB)) { + throw "assert failed"; + } + var directions = new Array(2); + this.decideDirectionsForOverlappingNodes(rectA, rectB, directions); + overlapAmount[0] = Math.min(rectA.getRight(), rectB.getRight()) - Math.max(rectA.x, rectB.x); + overlapAmount[1] = Math.min(rectA.getBottom(), rectB.getBottom()) - Math.max(rectA.y, rectB.y); + if (rectA.getX() <= rectB.getX() && rectA.getRight() >= rectB.getRight()) { + overlapAmount[0] += Math.min(rectB.getX() - rectA.getX(), rectA.getRight() - rectB.getRight()); + } else if (rectB.getX() <= rectA.getX() && rectB.getRight() >= rectA.getRight()) { + overlapAmount[0] += Math.min(rectA.getX() - rectB.getX(), rectB.getRight() - rectA.getRight()); + } + if (rectA.getY() <= rectB.getY() && rectA.getBottom() >= rectB.getBottom()) { + overlapAmount[1] += Math.min(rectB.getY() - rectA.getY(), rectA.getBottom() - rectB.getBottom()); + } else if (rectB.getY() <= rectA.getY() && rectB.getBottom() >= rectA.getBottom()) { + overlapAmount[1] += Math.min(rectA.getY() - rectB.getY(), rectB.getBottom() - rectA.getBottom()); + } + var slope = Math.abs((rectB.getCenterY() - rectA.getCenterY()) / (rectB.getCenterX() - rectA.getCenterX())); + if (rectB.getCenterY() === rectA.getCenterY() && rectB.getCenterX() === rectA.getCenterX()) { + slope = 1; + } + var moveByY = slope * overlapAmount[0]; + var moveByX = overlapAmount[1] / slope; + if (overlapAmount[0] < moveByX) { + moveByX = overlapAmount[0]; + } else { + moveByY = overlapAmount[1]; + } + overlapAmount[0] = -1 * directions[0] * (moveByX / 2 + separationBuffer); + overlapAmount[1] = -1 * directions[1] * (moveByY / 2 + separationBuffer); + }; + IGeometry.decideDirectionsForOverlappingNodes = function(rectA, rectB, directions) { + if (rectA.getCenterX() < rectB.getCenterX()) { + directions[0] = -1; + } else { + directions[0] = 1; + } + if (rectA.getCenterY() < rectB.getCenterY()) { + directions[1] = -1; + } else { + directions[1] = 1; + } + }; + IGeometry.getIntersection2 = function(rectA, rectB, result) { + var p1x = rectA.getCenterX(); + var p1y = rectA.getCenterY(); + var p2x = rectB.getCenterX(); + var p2y = rectB.getCenterY(); + if (rectA.intersects(rectB)) { + result[0] = p1x; + result[1] = p1y; + result[2] = p2x; + result[3] = p2y; + return true; + } + var topLeftAx = rectA.getX(); + var topLeftAy = rectA.getY(); + var topRightAx = rectA.getRight(); + var bottomLeftAx = rectA.getX(); + var bottomLeftAy = rectA.getBottom(); + var bottomRightAx = rectA.getRight(); + var halfWidthA = rectA.getWidthHalf(); + var halfHeightA = rectA.getHeightHalf(); + var topLeftBx = rectB.getX(); + var topLeftBy = rectB.getY(); + var topRightBx = rectB.getRight(); + var bottomLeftBx = rectB.getX(); + var bottomLeftBy = rectB.getBottom(); + var bottomRightBx = rectB.getRight(); + var halfWidthB = rectB.getWidthHalf(); + var halfHeightB = rectB.getHeightHalf(); + var clipPointAFound = false; + var clipPointBFound = false; + if (p1x === p2x) { + if (p1y > p2y) { + result[0] = p1x; + result[1] = topLeftAy; + result[2] = p2x; + result[3] = bottomLeftBy; + return false; + } else if (p1y < p2y) { + result[0] = p1x; + result[1] = bottomLeftAy; + result[2] = p2x; + result[3] = topLeftBy; + return false; + } else + ; + } else if (p1y === p2y) { + if (p1x > p2x) { + result[0] = topLeftAx; + result[1] = p1y; + result[2] = topRightBx; + result[3] = p2y; + return false; + } else if (p1x < p2x) { + result[0] = topRightAx; + result[1] = p1y; + result[2] = topLeftBx; + result[3] = p2y; + return false; + } else + ; + } else { + var slopeA = rectA.height / rectA.width; + var slopeB = rectB.height / rectB.width; + var slopePrime = (p2y - p1y) / (p2x - p1x); + var cardinalDirectionA = void 0; + var cardinalDirectionB = void 0; + var tempPointAx = void 0; + var tempPointAy = void 0; + var tempPointBx = void 0; + var tempPointBy = void 0; + if (-slopeA === slopePrime) { + if (p1x > p2x) { + result[0] = bottomLeftAx; + result[1] = bottomLeftAy; + clipPointAFound = true; + } else { + result[0] = topRightAx; + result[1] = topLeftAy; + clipPointAFound = true; + } + } else if (slopeA === slopePrime) { + if (p1x > p2x) { + result[0] = topLeftAx; + result[1] = topLeftAy; + clipPointAFound = true; + } else { + result[0] = bottomRightAx; + result[1] = bottomLeftAy; + clipPointAFound = true; + } + } + if (-slopeB === slopePrime) { + if (p2x > p1x) { + result[2] = bottomLeftBx; + result[3] = bottomLeftBy; + clipPointBFound = true; + } else { + result[2] = topRightBx; + result[3] = topLeftBy; + clipPointBFound = true; + } + } else if (slopeB === slopePrime) { + if (p2x > p1x) { + result[2] = topLeftBx; + result[3] = topLeftBy; + clipPointBFound = true; + } else { + result[2] = bottomRightBx; + result[3] = bottomLeftBy; + clipPointBFound = true; + } + } + if (clipPointAFound && clipPointBFound) { + return false; + } + if (p1x > p2x) { + if (p1y > p2y) { + cardinalDirectionA = this.getCardinalDirection(slopeA, slopePrime, 4); + cardinalDirectionB = this.getCardinalDirection(slopeB, slopePrime, 2); + } else { + cardinalDirectionA = this.getCardinalDirection(-slopeA, slopePrime, 3); + cardinalDirectionB = this.getCardinalDirection(-slopeB, slopePrime, 1); + } + } else { + if (p1y > p2y) { + cardinalDirectionA = this.getCardinalDirection(-slopeA, slopePrime, 1); + cardinalDirectionB = this.getCardinalDirection(-slopeB, slopePrime, 3); + } else { + cardinalDirectionA = this.getCardinalDirection(slopeA, slopePrime, 2); + cardinalDirectionB = this.getCardinalDirection(slopeB, slopePrime, 4); + } + } + if (!clipPointAFound) { + switch (cardinalDirectionA) { + case 1: + tempPointAy = topLeftAy; + tempPointAx = p1x + -halfHeightA / slopePrime; + result[0] = tempPointAx; + result[1] = tempPointAy; + break; + case 2: + tempPointAx = bottomRightAx; + tempPointAy = p1y + halfWidthA * slopePrime; + result[0] = tempPointAx; + result[1] = tempPointAy; + break; + case 3: + tempPointAy = bottomLeftAy; + tempPointAx = p1x + halfHeightA / slopePrime; + result[0] = tempPointAx; + result[1] = tempPointAy; + break; + case 4: + tempPointAx = bottomLeftAx; + tempPointAy = p1y + -halfWidthA * slopePrime; + result[0] = tempPointAx; + result[1] = tempPointAy; + break; + } + } + if (!clipPointBFound) { + switch (cardinalDirectionB) { + case 1: + tempPointBy = topLeftBy; + tempPointBx = p2x + -halfHeightB / slopePrime; + result[2] = tempPointBx; + result[3] = tempPointBy; + break; + case 2: + tempPointBx = bottomRightBx; + tempPointBy = p2y + halfWidthB * slopePrime; + result[2] = tempPointBx; + result[3] = tempPointBy; + break; + case 3: + tempPointBy = bottomLeftBy; + tempPointBx = p2x + halfHeightB / slopePrime; + result[2] = tempPointBx; + result[3] = tempPointBy; + break; + case 4: + tempPointBx = bottomLeftBx; + tempPointBy = p2y + -halfWidthB * slopePrime; + result[2] = tempPointBx; + result[3] = tempPointBy; + break; + } + } + } + return false; + }; + IGeometry.getCardinalDirection = function(slope, slopePrime, line) { + if (slope > slopePrime) { + return line; + } else { + return 1 + line % 4; + } + }; + IGeometry.getIntersection = function(s1, s2, f1, f2) { + if (f2 == null) { + return this.getIntersection2(s1, s2, f1); + } + var x1 = s1.x; + var y1 = s1.y; + var x2 = s2.x; + var y2 = s2.y; + var x3 = f1.x; + var y3 = f1.y; + var x4 = f2.x; + var y4 = f2.y; + var x = void 0, y = void 0; + var a1 = void 0, a2 = void 0, b1 = void 0, b2 = void 0, c1 = void 0, c2 = void 0; + var denom = void 0; + a1 = y2 - y1; + b1 = x1 - x2; + c1 = x2 * y1 - x1 * y2; + a2 = y4 - y3; + b2 = x3 - x4; + c2 = x4 * y3 - x3 * y4; + denom = a1 * b2 - a2 * b1; + if (denom === 0) { + return null; + } + x = (b1 * c2 - b2 * c1) / denom; + y = (a2 * c1 - a1 * c2) / denom; + return new Point2(x, y); + }; + IGeometry.angleOfVector = function(Cx, Cy, Nx, Ny) { + var C_angle = void 0; + if (Cx !== Nx) { + C_angle = Math.atan((Ny - Cy) / (Nx - Cx)); + if (Nx < Cx) { + C_angle += Math.PI; + } else if (Ny < Cy) { + C_angle += this.TWO_PI; + } + } else if (Ny < Cy) { + C_angle = this.ONE_AND_HALF_PI; + } else { + C_angle = this.HALF_PI; + } + return C_angle; + }; + IGeometry.doIntersect = function(p1, p2, p3, p4) { + var a = p1.x; + var b = p1.y; + var c = p2.x; + var d = p2.y; + var p = p3.x; + var q = p3.y; + var r = p4.x; + var s = p4.y; + var det = (c - a) * (s - q) - (r - p) * (d - b); + if (det === 0) { + return false; + } else { + var lambda = ((s - q) * (r - a) + (p - r) * (s - b)) / det; + var gamma = ((b - d) * (r - a) + (c - a) * (s - b)) / det; + return 0 < lambda && lambda < 1 && 0 < gamma && gamma < 1; + } + }; + IGeometry.HALF_PI = 0.5 * Math.PI; + IGeometry.ONE_AND_HALF_PI = 1.5 * Math.PI; + IGeometry.TWO_PI = 2 * Math.PI; + IGeometry.THREE_PI = 3 * Math.PI; + module2.exports = IGeometry; + }, + /* 9 */ + /***/ + function(module2, exports2, __webpack_require__) { + function IMath() { + } + IMath.sign = function(value) { + if (value > 0) { + return 1; + } else if (value < 0) { + return -1; + } else { + return 0; + } + }; + IMath.floor = function(value) { + return value < 0 ? Math.ceil(value) : Math.floor(value); + }; + IMath.ceil = function(value) { + return value < 0 ? Math.floor(value) : Math.ceil(value); + }; + module2.exports = IMath; + }, + /* 10 */ + /***/ + function(module2, exports2, __webpack_require__) { + function Integer() { + } + Integer.MAX_VALUE = 2147483647; + Integer.MIN_VALUE = -2147483648; + module2.exports = Integer; + }, + /* 11 */ + /***/ + function(module2, exports2, __webpack_require__) { + var _createClass = function() { + function defineProperties(target, props) { + for (var i = 0; i < props.length; i++) { + var descriptor = props[i]; + descriptor.enumerable = descriptor.enumerable || false; + descriptor.configurable = true; + if ("value" in descriptor) + descriptor.writable = true; + Object.defineProperty(target, descriptor.key, descriptor); + } + } + return function(Constructor, protoProps, staticProps) { + if (protoProps) + defineProperties(Constructor.prototype, protoProps); + if (staticProps) + defineProperties(Constructor, staticProps); + return Constructor; + }; + }(); + function _classCallCheck(instance2, Constructor) { + if (!(instance2 instanceof Constructor)) { + throw new TypeError("Cannot call a class as a function"); + } + } + var nodeFrom = function nodeFrom2(value) { + return { value, next: null, prev: null }; + }; + var add = function add2(prev, node, next2, list) { + if (prev !== null) { + prev.next = node; + } else { + list.head = node; + } + if (next2 !== null) { + next2.prev = node; + } else { + list.tail = node; + } + node.prev = prev; + node.next = next2; + list.length++; + return node; + }; + var _remove = function _remove2(node, list) { + var prev = node.prev, next2 = node.next; + if (prev !== null) { + prev.next = next2; + } else { + list.head = next2; + } + if (next2 !== null) { + next2.prev = prev; + } else { + list.tail = prev; + } + node.prev = node.next = null; + list.length--; + return node; + }; + var LinkedList = function() { + function LinkedList2(vals) { + var _this = this; + _classCallCheck(this, LinkedList2); + this.length = 0; + this.head = null; + this.tail = null; + if (vals != null) { + vals.forEach(function(v) { + return _this.push(v); + }); + } + } + _createClass(LinkedList2, [{ + key: "size", + value: function size() { + return this.length; + } + }, { + key: "insertBefore", + value: function insertBefore(val, otherNode) { + return add(otherNode.prev, nodeFrom(val), otherNode, this); + } + }, { + key: "insertAfter", + value: function insertAfter(val, otherNode) { + return add(otherNode, nodeFrom(val), otherNode.next, this); + } + }, { + key: "insertNodeBefore", + value: function insertNodeBefore(newNode, otherNode) { + return add(otherNode.prev, newNode, otherNode, this); + } + }, { + key: "insertNodeAfter", + value: function insertNodeAfter(newNode, otherNode) { + return add(otherNode, newNode, otherNode.next, this); + } + }, { + key: "push", + value: function push(val) { + return add(this.tail, nodeFrom(val), null, this); + } + }, { + key: "unshift", + value: function unshift(val) { + return add(null, nodeFrom(val), this.head, this); + } + }, { + key: "remove", + value: function remove(node) { + return _remove(node, this); + } + }, { + key: "pop", + value: function pop() { + return _remove(this.tail, this).value; + } + }, { + key: "popNode", + value: function popNode() { + return _remove(this.tail, this); + } + }, { + key: "shift", + value: function shift() { + return _remove(this.head, this).value; + } + }, { + key: "shiftNode", + value: function shiftNode() { + return _remove(this.head, this); + } + }, { + key: "get_object_at", + value: function get_object_at(index) { + if (index <= this.length()) { + var i = 1; + var current = this.head; + while (i < index) { + current = current.next; + i++; + } + return current.value; + } + } + }, { + key: "set_object_at", + value: function set_object_at(index, value) { + if (index <= this.length()) { + var i = 1; + var current = this.head; + while (i < index) { + current = current.next; + i++; + } + current.value = value; + } + } + }]); + return LinkedList2; + }(); + module2.exports = LinkedList; + }, + /* 12 */ + /***/ + function(module2, exports2, __webpack_require__) { + function Point2(x, y, p) { + this.x = null; + this.y = null; + if (x == null && y == null && p == null) { + this.x = 0; + this.y = 0; + } else if (typeof x == "number" && typeof y == "number" && p == null) { + this.x = x; + this.y = y; + } else if (x.constructor.name == "Point" && y == null && p == null) { + p = x; + this.x = p.x; + this.y = p.y; + } + } + Point2.prototype.getX = function() { + return this.x; + }; + Point2.prototype.getY = function() { + return this.y; + }; + Point2.prototype.getLocation = function() { + return new Point2(this.x, this.y); + }; + Point2.prototype.setLocation = function(x, y, p) { + if (x.constructor.name == "Point" && y == null && p == null) { + p = x; + this.setLocation(p.x, p.y); + } else if (typeof x == "number" && typeof y == "number" && p == null) { + if (parseInt(x) == x && parseInt(y) == y) { + this.move(x, y); + } else { + this.x = Math.floor(x + 0.5); + this.y = Math.floor(y + 0.5); + } + } + }; + Point2.prototype.move = function(x, y) { + this.x = x; + this.y = y; + }; + Point2.prototype.translate = function(dx, dy) { + this.x += dx; + this.y += dy; + }; + Point2.prototype.equals = function(obj) { + if (obj.constructor.name == "Point") { + var pt = obj; + return this.x == pt.x && this.y == pt.y; + } + return this == obj; + }; + Point2.prototype.toString = function() { + return new Point2().constructor.name + "[x=" + this.x + ",y=" + this.y + "]"; + }; + module2.exports = Point2; + }, + /* 13 */ + /***/ + function(module2, exports2, __webpack_require__) { + function RectangleD(x, y, width, height) { + this.x = 0; + this.y = 0; + this.width = 0; + this.height = 0; + if (x != null && y != null && width != null && height != null) { + this.x = x; + this.y = y; + this.width = width; + this.height = height; + } + } + RectangleD.prototype.getX = function() { + return this.x; + }; + RectangleD.prototype.setX = function(x) { + this.x = x; + }; + RectangleD.prototype.getY = function() { + return this.y; + }; + RectangleD.prototype.setY = function(y) { + this.y = y; + }; + RectangleD.prototype.getWidth = function() { + return this.width; + }; + RectangleD.prototype.setWidth = function(width) { + this.width = width; + }; + RectangleD.prototype.getHeight = function() { + return this.height; + }; + RectangleD.prototype.setHeight = function(height) { + this.height = height; + }; + RectangleD.prototype.getRight = function() { + return this.x + this.width; + }; + RectangleD.prototype.getBottom = function() { + return this.y + this.height; + }; + RectangleD.prototype.intersects = function(a) { + if (this.getRight() < a.x) { + return false; + } + if (this.getBottom() < a.y) { + return false; + } + if (a.getRight() < this.x) { + return false; + } + if (a.getBottom() < this.y) { + return false; + } + return true; + }; + RectangleD.prototype.getCenterX = function() { + return this.x + this.width / 2; + }; + RectangleD.prototype.getMinX = function() { + return this.getX(); + }; + RectangleD.prototype.getMaxX = function() { + return this.getX() + this.width; + }; + RectangleD.prototype.getCenterY = function() { + return this.y + this.height / 2; + }; + RectangleD.prototype.getMinY = function() { + return this.getY(); + }; + RectangleD.prototype.getMaxY = function() { + return this.getY() + this.height; + }; + RectangleD.prototype.getWidthHalf = function() { + return this.width / 2; + }; + RectangleD.prototype.getHeightHalf = function() { + return this.height / 2; + }; + module2.exports = RectangleD; + }, + /* 14 */ + /***/ + function(module2, exports2, __webpack_require__) { + var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function(obj) { + return typeof obj; + } : function(obj) { + return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; + }; + function UniqueIDGeneretor() { + } + UniqueIDGeneretor.lastID = 0; + UniqueIDGeneretor.createID = function(obj) { + if (UniqueIDGeneretor.isPrimitive(obj)) { + return obj; + } + if (obj.uniqueID != null) { + return obj.uniqueID; + } + obj.uniqueID = UniqueIDGeneretor.getString(); + UniqueIDGeneretor.lastID++; + return obj.uniqueID; + }; + UniqueIDGeneretor.getString = function(id) { + if (id == null) + id = UniqueIDGeneretor.lastID; + return "Object#" + id; + }; + UniqueIDGeneretor.isPrimitive = function(arg) { + var type = typeof arg === "undefined" ? "undefined" : _typeof(arg); + return arg == null || type != "object" && type != "function"; + }; + module2.exports = UniqueIDGeneretor; + }, + /* 15 */ + /***/ + function(module2, exports2, __webpack_require__) { + function _toConsumableArray(arr) { + if (Array.isArray(arr)) { + for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { + arr2[i] = arr[i]; + } + return arr2; + } else { + return Array.from(arr); + } + } + var LayoutConstants = __webpack_require__(0); + var LGraphManager = __webpack_require__(6); + var LNode = __webpack_require__(3); + var LEdge = __webpack_require__(1); + var LGraph = __webpack_require__(5); + var PointD = __webpack_require__(4); + var Transform = __webpack_require__(17); + var Emitter = __webpack_require__(27); + function Layout2(isRemoteUse) { + Emitter.call(this); + this.layoutQuality = LayoutConstants.QUALITY; + this.createBendsAsNeeded = LayoutConstants.DEFAULT_CREATE_BENDS_AS_NEEDED; + this.incremental = LayoutConstants.DEFAULT_INCREMENTAL; + this.animationOnLayout = LayoutConstants.DEFAULT_ANIMATION_ON_LAYOUT; + this.animationDuringLayout = LayoutConstants.DEFAULT_ANIMATION_DURING_LAYOUT; + this.animationPeriod = LayoutConstants.DEFAULT_ANIMATION_PERIOD; + this.uniformLeafNodeSizes = LayoutConstants.DEFAULT_UNIFORM_LEAF_NODE_SIZES; + this.edgeToDummyNodes = /* @__PURE__ */ new Map(); + this.graphManager = new LGraphManager(this); + this.isLayoutFinished = false; + this.isSubLayout = false; + this.isRemoteUse = false; + if (isRemoteUse != null) { + this.isRemoteUse = isRemoteUse; + } + } + Layout2.RANDOM_SEED = 1; + Layout2.prototype = Object.create(Emitter.prototype); + Layout2.prototype.getGraphManager = function() { + return this.graphManager; + }; + Layout2.prototype.getAllNodes = function() { + return this.graphManager.getAllNodes(); + }; + Layout2.prototype.getAllEdges = function() { + return this.graphManager.getAllEdges(); + }; + Layout2.prototype.getAllNodesToApplyGravitation = function() { + return this.graphManager.getAllNodesToApplyGravitation(); + }; + Layout2.prototype.newGraphManager = function() { + var gm = new LGraphManager(this); + this.graphManager = gm; + return gm; + }; + Layout2.prototype.newGraph = function(vGraph) { + return new LGraph(null, this.graphManager, vGraph); + }; + Layout2.prototype.newNode = function(vNode) { + return new LNode(this.graphManager, vNode); + }; + Layout2.prototype.newEdge = function(vEdge) { + return new LEdge(null, null, vEdge); + }; + Layout2.prototype.checkLayoutSuccess = function() { + return this.graphManager.getRoot() == null || this.graphManager.getRoot().getNodes().length == 0 || this.graphManager.includesInvalidEdge(); + }; + Layout2.prototype.runLayout = function() { + this.isLayoutFinished = false; + if (this.tilingPreLayout) { + this.tilingPreLayout(); + } + this.initParameters(); + var isLayoutSuccessfull; + if (this.checkLayoutSuccess()) { + isLayoutSuccessfull = false; + } else { + isLayoutSuccessfull = this.layout(); + } + if (LayoutConstants.ANIMATE === "during") { + return false; + } + if (isLayoutSuccessfull) { + if (!this.isSubLayout) { + this.doPostLayout(); + } + } + if (this.tilingPostLayout) { + this.tilingPostLayout(); + } + this.isLayoutFinished = true; + return isLayoutSuccessfull; + }; + Layout2.prototype.doPostLayout = function() { + if (!this.incremental) { + this.transform(); + } + this.update(); + }; + Layout2.prototype.update2 = function() { + if (this.createBendsAsNeeded) { + this.createBendpointsFromDummyNodes(); + this.graphManager.resetAllEdges(); + } + if (!this.isRemoteUse) { + var allEdges = this.graphManager.getAllEdges(); + for (var i = 0; i < allEdges.length; i++) { + allEdges[i]; + } + var nodes2 = this.graphManager.getRoot().getNodes(); + for (var i = 0; i < nodes2.length; i++) { + nodes2[i]; + } + this.update(this.graphManager.getRoot()); + } + }; + Layout2.prototype.update = function(obj) { + if (obj == null) { + this.update2(); + } else if (obj instanceof LNode) { + var node = obj; + if (node.getChild() != null) { + var nodes2 = node.getChild().getNodes(); + for (var i = 0; i < nodes2.length; i++) { + update(nodes2[i]); + } + } + if (node.vGraphObject != null) { + var vNode = node.vGraphObject; + vNode.update(node); + } + } else if (obj instanceof LEdge) { + var edge = obj; + if (edge.vGraphObject != null) { + var vEdge = edge.vGraphObject; + vEdge.update(edge); + } + } else if (obj instanceof LGraph) { + var graph = obj; + if (graph.vGraphObject != null) { + var vGraph = graph.vGraphObject; + vGraph.update(graph); + } + } + }; + Layout2.prototype.initParameters = function() { + if (!this.isSubLayout) { + this.layoutQuality = LayoutConstants.QUALITY; + this.animationDuringLayout = LayoutConstants.DEFAULT_ANIMATION_DURING_LAYOUT; + this.animationPeriod = LayoutConstants.DEFAULT_ANIMATION_PERIOD; + this.animationOnLayout = LayoutConstants.DEFAULT_ANIMATION_ON_LAYOUT; + this.incremental = LayoutConstants.DEFAULT_INCREMENTAL; + this.createBendsAsNeeded = LayoutConstants.DEFAULT_CREATE_BENDS_AS_NEEDED; + this.uniformLeafNodeSizes = LayoutConstants.DEFAULT_UNIFORM_LEAF_NODE_SIZES; + } + if (this.animationDuringLayout) { + this.animationOnLayout = false; + } + }; + Layout2.prototype.transform = function(newLeftTop) { + if (newLeftTop == void 0) { + this.transform(new PointD(0, 0)); + } else { + var trans = new Transform(); + var leftTop = this.graphManager.getRoot().updateLeftTop(); + if (leftTop != null) { + trans.setWorldOrgX(newLeftTop.x); + trans.setWorldOrgY(newLeftTop.y); + trans.setDeviceOrgX(leftTop.x); + trans.setDeviceOrgY(leftTop.y); + var nodes2 = this.getAllNodes(); + var node; + for (var i = 0; i < nodes2.length; i++) { + node = nodes2[i]; + node.transform(trans); + } + } + } + }; + Layout2.prototype.positionNodesRandomly = function(graph) { + if (graph == void 0) { + this.positionNodesRandomly(this.getGraphManager().getRoot()); + this.getGraphManager().getRoot().updateBounds(true); + } else { + var lNode; + var childGraph; + var nodes2 = graph.getNodes(); + for (var i = 0; i < nodes2.length; i++) { + lNode = nodes2[i]; + childGraph = lNode.getChild(); + if (childGraph == null) { + lNode.scatter(); + } else if (childGraph.getNodes().length == 0) { + lNode.scatter(); + } else { + this.positionNodesRandomly(childGraph); + lNode.updateBounds(); + } + } + } + }; + Layout2.prototype.getFlatForest = function() { + var flatForest = []; + var isForest = true; + var allNodes = this.graphManager.getRoot().getNodes(); + var isFlat = true; + for (var i = 0; i < allNodes.length; i++) { + if (allNodes[i].getChild() != null) { + isFlat = false; + } + } + if (!isFlat) { + return flatForest; + } + var visited = /* @__PURE__ */ new Set(); + var toBeVisited = []; + var parents = /* @__PURE__ */ new Map(); + var unProcessedNodes = []; + unProcessedNodes = unProcessedNodes.concat(allNodes); + while (unProcessedNodes.length > 0 && isForest) { + toBeVisited.push(unProcessedNodes[0]); + while (toBeVisited.length > 0 && isForest) { + var currentNode = toBeVisited[0]; + toBeVisited.splice(0, 1); + visited.add(currentNode); + var neighborEdges = currentNode.getEdges(); + for (var i = 0; i < neighborEdges.length; i++) { + var currentNeighbor = neighborEdges[i].getOtherEnd(currentNode); + if (parents.get(currentNode) != currentNeighbor) { + if (!visited.has(currentNeighbor)) { + toBeVisited.push(currentNeighbor); + parents.set(currentNeighbor, currentNode); + } else { + isForest = false; + break; + } + } + } + } + if (!isForest) { + flatForest = []; + } else { + var temp = [].concat(_toConsumableArray(visited)); + flatForest.push(temp); + for (var i = 0; i < temp.length; i++) { + var value = temp[i]; + var index = unProcessedNodes.indexOf(value); + if (index > -1) { + unProcessedNodes.splice(index, 1); + } + } + visited = /* @__PURE__ */ new Set(); + parents = /* @__PURE__ */ new Map(); + } + } + return flatForest; + }; + Layout2.prototype.createDummyNodesForBendpoints = function(edge) { + var dummyNodes = []; + var prev = edge.source; + var graph = this.graphManager.calcLowestCommonAncestor(edge.source, edge.target); + for (var i = 0; i < edge.bendpoints.length; i++) { + var dummyNode = this.newNode(null); + dummyNode.setRect(new Point(0, 0), new Dimension(1, 1)); + graph.add(dummyNode); + var dummyEdge = this.newEdge(null); + this.graphManager.add(dummyEdge, prev, dummyNode); + dummyNodes.add(dummyNode); + prev = dummyNode; + } + var dummyEdge = this.newEdge(null); + this.graphManager.add(dummyEdge, prev, edge.target); + this.edgeToDummyNodes.set(edge, dummyNodes); + if (edge.isInterGraph()) { + this.graphManager.remove(edge); + } else { + graph.remove(edge); + } + return dummyNodes; + }; + Layout2.prototype.createBendpointsFromDummyNodes = function() { + var edges = []; + edges = edges.concat(this.graphManager.getAllEdges()); + edges = [].concat(_toConsumableArray(this.edgeToDummyNodes.keys())).concat(edges); + for (var k = 0; k < edges.length; k++) { + var lEdge = edges[k]; + if (lEdge.bendpoints.length > 0) { + var path = this.edgeToDummyNodes.get(lEdge); + for (var i = 0; i < path.length; i++) { + var dummyNode = path[i]; + var p = new PointD(dummyNode.getCenterX(), dummyNode.getCenterY()); + var ebp = lEdge.bendpoints.get(i); + ebp.x = p.x; + ebp.y = p.y; + dummyNode.getOwner().remove(dummyNode); + } + this.graphManager.add(lEdge, lEdge.source, lEdge.target); + } + } + }; + Layout2.transform = function(sliderValue, defaultValue, minDiv, maxMul) { + if (minDiv != void 0 && maxMul != void 0) { + var value = defaultValue; + if (sliderValue <= 50) { + var minValue = defaultValue / minDiv; + value -= (defaultValue - minValue) / 50 * (50 - sliderValue); + } else { + var maxValue = defaultValue * maxMul; + value += (maxValue - defaultValue) / 50 * (sliderValue - 50); + } + return value; + } else { + var a, b; + if (sliderValue <= 50) { + a = 9 * defaultValue / 500; + b = defaultValue / 10; + } else { + a = 9 * defaultValue / 50; + b = -8 * defaultValue; + } + return a * sliderValue + b; + } + }; + Layout2.findCenterOfTree = function(nodes2) { + var list = []; + list = list.concat(nodes2); + var removedNodes = []; + var remainingDegrees = /* @__PURE__ */ new Map(); + var foundCenter = false; + var centerNode = null; + if (list.length == 1 || list.length == 2) { + foundCenter = true; + centerNode = list[0]; + } + for (var i = 0; i < list.length; i++) { + var node = list[i]; + var degree = node.getNeighborsList().size; + remainingDegrees.set(node, node.getNeighborsList().size); + if (degree == 1) { + removedNodes.push(node); + } + } + var tempList = []; + tempList = tempList.concat(removedNodes); + while (!foundCenter) { + var tempList2 = []; + tempList2 = tempList2.concat(tempList); + tempList = []; + for (var i = 0; i < list.length; i++) { + var node = list[i]; + var index = list.indexOf(node); + if (index >= 0) { + list.splice(index, 1); + } + var neighbours = node.getNeighborsList(); + neighbours.forEach(function(neighbour) { + if (removedNodes.indexOf(neighbour) < 0) { + var otherDegree = remainingDegrees.get(neighbour); + var newDegree = otherDegree - 1; + if (newDegree == 1) { + tempList.push(neighbour); + } + remainingDegrees.set(neighbour, newDegree); + } + }); + } + removedNodes = removedNodes.concat(tempList); + if (list.length == 1 || list.length == 2) { + foundCenter = true; + centerNode = list[0]; + } + } + return centerNode; + }; + Layout2.prototype.setGraphManager = function(gm) { + this.graphManager = gm; + }; + module2.exports = Layout2; + }, + /* 16 */ + /***/ + function(module2, exports2, __webpack_require__) { + function RandomSeed() { + } + RandomSeed.seed = 1; + RandomSeed.x = 0; + RandomSeed.nextDouble = function() { + RandomSeed.x = Math.sin(RandomSeed.seed++) * 1e4; + return RandomSeed.x - Math.floor(RandomSeed.x); + }; + module2.exports = RandomSeed; + }, + /* 17 */ + /***/ + function(module2, exports2, __webpack_require__) { + var PointD = __webpack_require__(4); + function Transform(x, y) { + this.lworldOrgX = 0; + this.lworldOrgY = 0; + this.ldeviceOrgX = 0; + this.ldeviceOrgY = 0; + this.lworldExtX = 1; + this.lworldExtY = 1; + this.ldeviceExtX = 1; + this.ldeviceExtY = 1; + } + Transform.prototype.getWorldOrgX = function() { + return this.lworldOrgX; + }; + Transform.prototype.setWorldOrgX = function(wox) { + this.lworldOrgX = wox; + }; + Transform.prototype.getWorldOrgY = function() { + return this.lworldOrgY; + }; + Transform.prototype.setWorldOrgY = function(woy) { + this.lworldOrgY = woy; + }; + Transform.prototype.getWorldExtX = function() { + return this.lworldExtX; + }; + Transform.prototype.setWorldExtX = function(wex) { + this.lworldExtX = wex; + }; + Transform.prototype.getWorldExtY = function() { + return this.lworldExtY; + }; + Transform.prototype.setWorldExtY = function(wey) { + this.lworldExtY = wey; + }; + Transform.prototype.getDeviceOrgX = function() { + return this.ldeviceOrgX; + }; + Transform.prototype.setDeviceOrgX = function(dox) { + this.ldeviceOrgX = dox; + }; + Transform.prototype.getDeviceOrgY = function() { + return this.ldeviceOrgY; + }; + Transform.prototype.setDeviceOrgY = function(doy) { + this.ldeviceOrgY = doy; + }; + Transform.prototype.getDeviceExtX = function() { + return this.ldeviceExtX; + }; + Transform.prototype.setDeviceExtX = function(dex) { + this.ldeviceExtX = dex; + }; + Transform.prototype.getDeviceExtY = function() { + return this.ldeviceExtY; + }; + Transform.prototype.setDeviceExtY = function(dey) { + this.ldeviceExtY = dey; + }; + Transform.prototype.transformX = function(x) { + var xDevice = 0; + var worldExtX = this.lworldExtX; + if (worldExtX != 0) { + xDevice = this.ldeviceOrgX + (x - this.lworldOrgX) * this.ldeviceExtX / worldExtX; + } + return xDevice; + }; + Transform.prototype.transformY = function(y) { + var yDevice = 0; + var worldExtY = this.lworldExtY; + if (worldExtY != 0) { + yDevice = this.ldeviceOrgY + (y - this.lworldOrgY) * this.ldeviceExtY / worldExtY; + } + return yDevice; + }; + Transform.prototype.inverseTransformX = function(x) { + var xWorld = 0; + var deviceExtX = this.ldeviceExtX; + if (deviceExtX != 0) { + xWorld = this.lworldOrgX + (x - this.ldeviceOrgX) * this.lworldExtX / deviceExtX; + } + return xWorld; + }; + Transform.prototype.inverseTransformY = function(y) { + var yWorld = 0; + var deviceExtY = this.ldeviceExtY; + if (deviceExtY != 0) { + yWorld = this.lworldOrgY + (y - this.ldeviceOrgY) * this.lworldExtY / deviceExtY; + } + return yWorld; + }; + Transform.prototype.inverseTransformPoint = function(inPoint) { + var outPoint = new PointD(this.inverseTransformX(inPoint.x), this.inverseTransformY(inPoint.y)); + return outPoint; + }; + module2.exports = Transform; + }, + /* 18 */ + /***/ + function(module2, exports2, __webpack_require__) { + function _toConsumableArray(arr) { + if (Array.isArray(arr)) { + for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { + arr2[i] = arr[i]; + } + return arr2; + } else { + return Array.from(arr); + } + } + var Layout2 = __webpack_require__(15); + var FDLayoutConstants = __webpack_require__(7); + var LayoutConstants = __webpack_require__(0); + var IGeometry = __webpack_require__(8); + var IMath = __webpack_require__(9); + function FDLayout() { + Layout2.call(this); + this.useSmartIdealEdgeLengthCalculation = FDLayoutConstants.DEFAULT_USE_SMART_IDEAL_EDGE_LENGTH_CALCULATION; + this.idealEdgeLength = FDLayoutConstants.DEFAULT_EDGE_LENGTH; + this.springConstant = FDLayoutConstants.DEFAULT_SPRING_STRENGTH; + this.repulsionConstant = FDLayoutConstants.DEFAULT_REPULSION_STRENGTH; + this.gravityConstant = FDLayoutConstants.DEFAULT_GRAVITY_STRENGTH; + this.compoundGravityConstant = FDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_STRENGTH; + this.gravityRangeFactor = FDLayoutConstants.DEFAULT_GRAVITY_RANGE_FACTOR; + this.compoundGravityRangeFactor = FDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_RANGE_FACTOR; + this.displacementThresholdPerNode = 3 * FDLayoutConstants.DEFAULT_EDGE_LENGTH / 100; + this.coolingFactor = FDLayoutConstants.DEFAULT_COOLING_FACTOR_INCREMENTAL; + this.initialCoolingFactor = FDLayoutConstants.DEFAULT_COOLING_FACTOR_INCREMENTAL; + this.totalDisplacement = 0; + this.oldTotalDisplacement = 0; + this.maxIterations = FDLayoutConstants.MAX_ITERATIONS; + } + FDLayout.prototype = Object.create(Layout2.prototype); + for (var prop in Layout2) { + FDLayout[prop] = Layout2[prop]; + } + FDLayout.prototype.initParameters = function() { + Layout2.prototype.initParameters.call(this, arguments); + this.totalIterations = 0; + this.notAnimatedIterations = 0; + this.useFRGridVariant = FDLayoutConstants.DEFAULT_USE_SMART_REPULSION_RANGE_CALCULATION; + this.grid = []; + }; + FDLayout.prototype.calcIdealEdgeLengths = function() { + var edge; + var lcaDepth; + var source; + var target; + var sizeOfSourceInLca; + var sizeOfTargetInLca; + var allEdges = this.getGraphManager().getAllEdges(); + for (var i = 0; i < allEdges.length; i++) { + edge = allEdges[i]; + edge.idealLength = this.idealEdgeLength; + if (edge.isInterGraph) { + source = edge.getSource(); + target = edge.getTarget(); + sizeOfSourceInLca = edge.getSourceInLca().getEstimatedSize(); + sizeOfTargetInLca = edge.getTargetInLca().getEstimatedSize(); + if (this.useSmartIdealEdgeLengthCalculation) { + edge.idealLength += sizeOfSourceInLca + sizeOfTargetInLca - 2 * LayoutConstants.SIMPLE_NODE_SIZE; + } + lcaDepth = edge.getLca().getInclusionTreeDepth(); + edge.idealLength += FDLayoutConstants.DEFAULT_EDGE_LENGTH * FDLayoutConstants.PER_LEVEL_IDEAL_EDGE_LENGTH_FACTOR * (source.getInclusionTreeDepth() + target.getInclusionTreeDepth() - 2 * lcaDepth); + } + } + }; + FDLayout.prototype.initSpringEmbedder = function() { + var s = this.getAllNodes().length; + if (this.incremental) { + if (s > FDLayoutConstants.ADAPTATION_LOWER_NODE_LIMIT) { + this.coolingFactor = Math.max(this.coolingFactor * FDLayoutConstants.COOLING_ADAPTATION_FACTOR, this.coolingFactor - (s - FDLayoutConstants.ADAPTATION_LOWER_NODE_LIMIT) / (FDLayoutConstants.ADAPTATION_UPPER_NODE_LIMIT - FDLayoutConstants.ADAPTATION_LOWER_NODE_LIMIT) * this.coolingFactor * (1 - FDLayoutConstants.COOLING_ADAPTATION_FACTOR)); + } + this.maxNodeDisplacement = FDLayoutConstants.MAX_NODE_DISPLACEMENT_INCREMENTAL; + } else { + if (s > FDLayoutConstants.ADAPTATION_LOWER_NODE_LIMIT) { + this.coolingFactor = Math.max(FDLayoutConstants.COOLING_ADAPTATION_FACTOR, 1 - (s - FDLayoutConstants.ADAPTATION_LOWER_NODE_LIMIT) / (FDLayoutConstants.ADAPTATION_UPPER_NODE_LIMIT - FDLayoutConstants.ADAPTATION_LOWER_NODE_LIMIT) * (1 - FDLayoutConstants.COOLING_ADAPTATION_FACTOR)); + } else { + this.coolingFactor = 1; + } + this.initialCoolingFactor = this.coolingFactor; + this.maxNodeDisplacement = FDLayoutConstants.MAX_NODE_DISPLACEMENT; + } + this.maxIterations = Math.max(this.getAllNodes().length * 5, this.maxIterations); + this.totalDisplacementThreshold = this.displacementThresholdPerNode * this.getAllNodes().length; + this.repulsionRange = this.calcRepulsionRange(); + }; + FDLayout.prototype.calcSpringForces = function() { + var lEdges = this.getAllEdges(); + var edge; + for (var i = 0; i < lEdges.length; i++) { + edge = lEdges[i]; + this.calcSpringForce(edge, edge.idealLength); + } + }; + FDLayout.prototype.calcRepulsionForces = function() { + var gridUpdateAllowed = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : true; + var forceToNodeSurroundingUpdate = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : false; + var i, j; + var nodeA, nodeB; + var lNodes = this.getAllNodes(); + var processedNodeSet; + if (this.useFRGridVariant) { + if (this.totalIterations % FDLayoutConstants.GRID_CALCULATION_CHECK_PERIOD == 1 && gridUpdateAllowed) { + this.updateGrid(); + } + processedNodeSet = /* @__PURE__ */ new Set(); + for (i = 0; i < lNodes.length; i++) { + nodeA = lNodes[i]; + this.calculateRepulsionForceOfANode(nodeA, processedNodeSet, gridUpdateAllowed, forceToNodeSurroundingUpdate); + processedNodeSet.add(nodeA); + } + } else { + for (i = 0; i < lNodes.length; i++) { + nodeA = lNodes[i]; + for (j = i + 1; j < lNodes.length; j++) { + nodeB = lNodes[j]; + if (nodeA.getOwner() != nodeB.getOwner()) { + continue; + } + this.calcRepulsionForce(nodeA, nodeB); + } + } + } + }; + FDLayout.prototype.calcGravitationalForces = function() { + var node; + var lNodes = this.getAllNodesToApplyGravitation(); + for (var i = 0; i < lNodes.length; i++) { + node = lNodes[i]; + this.calcGravitationalForce(node); + } + }; + FDLayout.prototype.moveNodes = function() { + var lNodes = this.getAllNodes(); + var node; + for (var i = 0; i < lNodes.length; i++) { + node = lNodes[i]; + node.move(); + } + }; + FDLayout.prototype.calcSpringForce = function(edge, idealLength) { + var sourceNode = edge.getSource(); + var targetNode = edge.getTarget(); + var length; + var springForce; + var springForceX; + var springForceY; + if (this.uniformLeafNodeSizes && sourceNode.getChild() == null && targetNode.getChild() == null) { + edge.updateLengthSimple(); + } else { + edge.updateLength(); + if (edge.isOverlapingSourceAndTarget) { + return; + } + } + length = edge.getLength(); + if (length == 0) + return; + springForce = this.springConstant * (length - idealLength); + springForceX = springForce * (edge.lengthX / length); + springForceY = springForce * (edge.lengthY / length); + sourceNode.springForceX += springForceX; + sourceNode.springForceY += springForceY; + targetNode.springForceX -= springForceX; + targetNode.springForceY -= springForceY; + }; + FDLayout.prototype.calcRepulsionForce = function(nodeA, nodeB) { + var rectA = nodeA.getRect(); + var rectB = nodeB.getRect(); + var overlapAmount = new Array(2); + var clipPoints = new Array(4); + var distanceX; + var distanceY; + var distanceSquared; + var distance; + var repulsionForce; + var repulsionForceX; + var repulsionForceY; + if (rectA.intersects(rectB)) { + IGeometry.calcSeparationAmount(rectA, rectB, overlapAmount, FDLayoutConstants.DEFAULT_EDGE_LENGTH / 2); + repulsionForceX = 2 * overlapAmount[0]; + repulsionForceY = 2 * overlapAmount[1]; + var childrenConstant = nodeA.noOfChildren * nodeB.noOfChildren / (nodeA.noOfChildren + nodeB.noOfChildren); + nodeA.repulsionForceX -= childrenConstant * repulsionForceX; + nodeA.repulsionForceY -= childrenConstant * repulsionForceY; + nodeB.repulsionForceX += childrenConstant * repulsionForceX; + nodeB.repulsionForceY += childrenConstant * repulsionForceY; + } else { + if (this.uniformLeafNodeSizes && nodeA.getChild() == null && nodeB.getChild() == null) { + distanceX = rectB.getCenterX() - rectA.getCenterX(); + distanceY = rectB.getCenterY() - rectA.getCenterY(); + } else { + IGeometry.getIntersection(rectA, rectB, clipPoints); + distanceX = clipPoints[2] - clipPoints[0]; + distanceY = clipPoints[3] - clipPoints[1]; + } + if (Math.abs(distanceX) < FDLayoutConstants.MIN_REPULSION_DIST) { + distanceX = IMath.sign(distanceX) * FDLayoutConstants.MIN_REPULSION_DIST; + } + if (Math.abs(distanceY) < FDLayoutConstants.MIN_REPULSION_DIST) { + distanceY = IMath.sign(distanceY) * FDLayoutConstants.MIN_REPULSION_DIST; + } + distanceSquared = distanceX * distanceX + distanceY * distanceY; + distance = Math.sqrt(distanceSquared); + repulsionForce = this.repulsionConstant * nodeA.noOfChildren * nodeB.noOfChildren / distanceSquared; + repulsionForceX = repulsionForce * distanceX / distance; + repulsionForceY = repulsionForce * distanceY / distance; + nodeA.repulsionForceX -= repulsionForceX; + nodeA.repulsionForceY -= repulsionForceY; + nodeB.repulsionForceX += repulsionForceX; + nodeB.repulsionForceY += repulsionForceY; + } + }; + FDLayout.prototype.calcGravitationalForce = function(node) { + var ownerGraph; + var ownerCenterX; + var ownerCenterY; + var distanceX; + var distanceY; + var absDistanceX; + var absDistanceY; + var estimatedSize; + ownerGraph = node.getOwner(); + ownerCenterX = (ownerGraph.getRight() + ownerGraph.getLeft()) / 2; + ownerCenterY = (ownerGraph.getTop() + ownerGraph.getBottom()) / 2; + distanceX = node.getCenterX() - ownerCenterX; + distanceY = node.getCenterY() - ownerCenterY; + absDistanceX = Math.abs(distanceX) + node.getWidth() / 2; + absDistanceY = Math.abs(distanceY) + node.getHeight() / 2; + if (node.getOwner() == this.graphManager.getRoot()) { + estimatedSize = ownerGraph.getEstimatedSize() * this.gravityRangeFactor; + if (absDistanceX > estimatedSize || absDistanceY > estimatedSize) { + node.gravitationForceX = -this.gravityConstant * distanceX; + node.gravitationForceY = -this.gravityConstant * distanceY; + } + } else { + estimatedSize = ownerGraph.getEstimatedSize() * this.compoundGravityRangeFactor; + if (absDistanceX > estimatedSize || absDistanceY > estimatedSize) { + node.gravitationForceX = -this.gravityConstant * distanceX * this.compoundGravityConstant; + node.gravitationForceY = -this.gravityConstant * distanceY * this.compoundGravityConstant; + } + } + }; + FDLayout.prototype.isConverged = function() { + var converged; + var oscilating = false; + if (this.totalIterations > this.maxIterations / 3) { + oscilating = Math.abs(this.totalDisplacement - this.oldTotalDisplacement) < 2; + } + converged = this.totalDisplacement < this.totalDisplacementThreshold; + this.oldTotalDisplacement = this.totalDisplacement; + return converged || oscilating; + }; + FDLayout.prototype.animate = function() { + if (this.animationDuringLayout && !this.isSubLayout) { + if (this.notAnimatedIterations == this.animationPeriod) { + this.update(); + this.notAnimatedIterations = 0; + } else { + this.notAnimatedIterations++; + } + } + }; + FDLayout.prototype.calcNoOfChildrenForAllNodes = function() { + var node; + var allNodes = this.graphManager.getAllNodes(); + for (var i = 0; i < allNodes.length; i++) { + node = allNodes[i]; + node.noOfChildren = node.getNoOfChildren(); + } + }; + FDLayout.prototype.calcGrid = function(graph) { + var sizeX = 0; + var sizeY = 0; + sizeX = parseInt(Math.ceil((graph.getRight() - graph.getLeft()) / this.repulsionRange)); + sizeY = parseInt(Math.ceil((graph.getBottom() - graph.getTop()) / this.repulsionRange)); + var grid = new Array(sizeX); + for (var i = 0; i < sizeX; i++) { + grid[i] = new Array(sizeY); + } + for (var i = 0; i < sizeX; i++) { + for (var j = 0; j < sizeY; j++) { + grid[i][j] = new Array(); + } + } + return grid; + }; + FDLayout.prototype.addNodeToGrid = function(v, left, top) { + var startX = 0; + var finishX = 0; + var startY = 0; + var finishY = 0; + startX = parseInt(Math.floor((v.getRect().x - left) / this.repulsionRange)); + finishX = parseInt(Math.floor((v.getRect().width + v.getRect().x - left) / this.repulsionRange)); + startY = parseInt(Math.floor((v.getRect().y - top) / this.repulsionRange)); + finishY = parseInt(Math.floor((v.getRect().height + v.getRect().y - top) / this.repulsionRange)); + for (var i = startX; i <= finishX; i++) { + for (var j = startY; j <= finishY; j++) { + this.grid[i][j].push(v); + v.setGridCoordinates(startX, finishX, startY, finishY); + } + } + }; + FDLayout.prototype.updateGrid = function() { + var i; + var nodeA; + var lNodes = this.getAllNodes(); + this.grid = this.calcGrid(this.graphManager.getRoot()); + for (i = 0; i < lNodes.length; i++) { + nodeA = lNodes[i]; + this.addNodeToGrid(nodeA, this.graphManager.getRoot().getLeft(), this.graphManager.getRoot().getTop()); + } + }; + FDLayout.prototype.calculateRepulsionForceOfANode = function(nodeA, processedNodeSet, gridUpdateAllowed, forceToNodeSurroundingUpdate) { + if (this.totalIterations % FDLayoutConstants.GRID_CALCULATION_CHECK_PERIOD == 1 && gridUpdateAllowed || forceToNodeSurroundingUpdate) { + var surrounding = /* @__PURE__ */ new Set(); + nodeA.surrounding = new Array(); + var nodeB; + var grid = this.grid; + for (var i = nodeA.startX - 1; i < nodeA.finishX + 2; i++) { + for (var j = nodeA.startY - 1; j < nodeA.finishY + 2; j++) { + if (!(i < 0 || j < 0 || i >= grid.length || j >= grid[0].length)) { + for (var k = 0; k < grid[i][j].length; k++) { + nodeB = grid[i][j][k]; + if (nodeA.getOwner() != nodeB.getOwner() || nodeA == nodeB) { + continue; + } + if (!processedNodeSet.has(nodeB) && !surrounding.has(nodeB)) { + var distanceX = Math.abs(nodeA.getCenterX() - nodeB.getCenterX()) - (nodeA.getWidth() / 2 + nodeB.getWidth() / 2); + var distanceY = Math.abs(nodeA.getCenterY() - nodeB.getCenterY()) - (nodeA.getHeight() / 2 + nodeB.getHeight() / 2); + if (distanceX <= this.repulsionRange && distanceY <= this.repulsionRange) { + surrounding.add(nodeB); + } + } + } + } + } + } + nodeA.surrounding = [].concat(_toConsumableArray(surrounding)); + } + for (i = 0; i < nodeA.surrounding.length; i++) { + this.calcRepulsionForce(nodeA, nodeA.surrounding[i]); + } + }; + FDLayout.prototype.calcRepulsionRange = function() { + return 0; + }; + module2.exports = FDLayout; + }, + /* 19 */ + /***/ + function(module2, exports2, __webpack_require__) { + var LEdge = __webpack_require__(1); + var FDLayoutConstants = __webpack_require__(7); + function FDLayoutEdge(source, target, vEdge) { + LEdge.call(this, source, target, vEdge); + this.idealLength = FDLayoutConstants.DEFAULT_EDGE_LENGTH; + } + FDLayoutEdge.prototype = Object.create(LEdge.prototype); + for (var prop in LEdge) { + FDLayoutEdge[prop] = LEdge[prop]; + } + module2.exports = FDLayoutEdge; + }, + /* 20 */ + /***/ + function(module2, exports2, __webpack_require__) { + var LNode = __webpack_require__(3); + function FDLayoutNode(gm, loc, size, vNode) { + LNode.call(this, gm, loc, size, vNode); + this.springForceX = 0; + this.springForceY = 0; + this.repulsionForceX = 0; + this.repulsionForceY = 0; + this.gravitationForceX = 0; + this.gravitationForceY = 0; + this.displacementX = 0; + this.displacementY = 0; + this.startX = 0; + this.finishX = 0; + this.startY = 0; + this.finishY = 0; + this.surrounding = []; + } + FDLayoutNode.prototype = Object.create(LNode.prototype); + for (var prop in LNode) { + FDLayoutNode[prop] = LNode[prop]; + } + FDLayoutNode.prototype.setGridCoordinates = function(_startX, _finishX, _startY, _finishY) { + this.startX = _startX; + this.finishX = _finishX; + this.startY = _startY; + this.finishY = _finishY; + }; + module2.exports = FDLayoutNode; + }, + /* 21 */ + /***/ + function(module2, exports2, __webpack_require__) { + function DimensionD2(width, height) { + this.width = 0; + this.height = 0; + if (width !== null && height !== null) { + this.height = height; + this.width = width; + } + } + DimensionD2.prototype.getWidth = function() { + return this.width; + }; + DimensionD2.prototype.setWidth = function(width) { + this.width = width; + }; + DimensionD2.prototype.getHeight = function() { + return this.height; + }; + DimensionD2.prototype.setHeight = function(height) { + this.height = height; + }; + module2.exports = DimensionD2; + }, + /* 22 */ + /***/ + function(module2, exports2, __webpack_require__) { + var UniqueIDGeneretor = __webpack_require__(14); + function HashMap() { + this.map = {}; + this.keys = []; + } + HashMap.prototype.put = function(key, value) { + var theId = UniqueIDGeneretor.createID(key); + if (!this.contains(theId)) { + this.map[theId] = value; + this.keys.push(key); + } + }; + HashMap.prototype.contains = function(key) { + UniqueIDGeneretor.createID(key); + return this.map[key] != null; + }; + HashMap.prototype.get = function(key) { + var theId = UniqueIDGeneretor.createID(key); + return this.map[theId]; + }; + HashMap.prototype.keySet = function() { + return this.keys; + }; + module2.exports = HashMap; + }, + /* 23 */ + /***/ + function(module2, exports2, __webpack_require__) { + var UniqueIDGeneretor = __webpack_require__(14); + function HashSet() { + this.set = {}; + } + HashSet.prototype.add = function(obj) { + var theId = UniqueIDGeneretor.createID(obj); + if (!this.contains(theId)) + this.set[theId] = obj; + }; + HashSet.prototype.remove = function(obj) { + delete this.set[UniqueIDGeneretor.createID(obj)]; + }; + HashSet.prototype.clear = function() { + this.set = {}; + }; + HashSet.prototype.contains = function(obj) { + return this.set[UniqueIDGeneretor.createID(obj)] == obj; + }; + HashSet.prototype.isEmpty = function() { + return this.size() === 0; + }; + HashSet.prototype.size = function() { + return Object.keys(this.set).length; + }; + HashSet.prototype.addAllTo = function(list) { + var keys = Object.keys(this.set); + var length = keys.length; + for (var i = 0; i < length; i++) { + list.push(this.set[keys[i]]); + } + }; + HashSet.prototype.size = function() { + return Object.keys(this.set).length; + }; + HashSet.prototype.addAll = function(list) { + var s = list.length; + for (var i = 0; i < s; i++) { + var v = list[i]; + this.add(v); + } + }; + module2.exports = HashSet; + }, + /* 24 */ + /***/ + function(module2, exports2, __webpack_require__) { + var _createClass = function() { + function defineProperties(target, props) { + for (var i = 0; i < props.length; i++) { + var descriptor = props[i]; + descriptor.enumerable = descriptor.enumerable || false; + descriptor.configurable = true; + if ("value" in descriptor) + descriptor.writable = true; + Object.defineProperty(target, descriptor.key, descriptor); + } + } + return function(Constructor, protoProps, staticProps) { + if (protoProps) + defineProperties(Constructor.prototype, protoProps); + if (staticProps) + defineProperties(Constructor, staticProps); + return Constructor; + }; + }(); + function _classCallCheck(instance2, Constructor) { + if (!(instance2 instanceof Constructor)) { + throw new TypeError("Cannot call a class as a function"); + } + } + var LinkedList = __webpack_require__(11); + var Quicksort = function() { + function Quicksort2(A, compareFunction) { + _classCallCheck(this, Quicksort2); + if (compareFunction !== null || compareFunction !== void 0) + this.compareFunction = this._defaultCompareFunction; + var length = void 0; + if (A instanceof LinkedList) + length = A.size(); + else + length = A.length; + this._quicksort(A, 0, length - 1); + } + _createClass(Quicksort2, [{ + key: "_quicksort", + value: function _quicksort(A, p, r) { + if (p < r) { + var q = this._partition(A, p, r); + this._quicksort(A, p, q); + this._quicksort(A, q + 1, r); + } + } + }, { + key: "_partition", + value: function _partition(A, p, r) { + var x = this._get(A, p); + var i = p; + var j = r; + while (true) { + while (this.compareFunction(x, this._get(A, j))) { + j--; + } + while (this.compareFunction(this._get(A, i), x)) { + i++; + } + if (i < j) { + this._swap(A, i, j); + i++; + j--; + } else + return j; + } + } + }, { + key: "_get", + value: function _get(object, index) { + if (object instanceof LinkedList) + return object.get_object_at(index); + else + return object[index]; + } + }, { + key: "_set", + value: function _set(object, index, value) { + if (object instanceof LinkedList) + object.set_object_at(index, value); + else + object[index] = value; + } + }, { + key: "_swap", + value: function _swap(A, i, j) { + var temp = this._get(A, i); + this._set(A, i, this._get(A, j)); + this._set(A, j, temp); + } + }, { + key: "_defaultCompareFunction", + value: function _defaultCompareFunction(a, b) { + return b > a; + } + }]); + return Quicksort2; + }(); + module2.exports = Quicksort; + }, + /* 25 */ + /***/ + function(module2, exports2, __webpack_require__) { + var _createClass = function() { + function defineProperties(target, props) { + for (var i = 0; i < props.length; i++) { + var descriptor = props[i]; + descriptor.enumerable = descriptor.enumerable || false; + descriptor.configurable = true; + if ("value" in descriptor) + descriptor.writable = true; + Object.defineProperty(target, descriptor.key, descriptor); + } + } + return function(Constructor, protoProps, staticProps) { + if (protoProps) + defineProperties(Constructor.prototype, protoProps); + if (staticProps) + defineProperties(Constructor, staticProps); + return Constructor; + }; + }(); + function _classCallCheck(instance2, Constructor) { + if (!(instance2 instanceof Constructor)) { + throw new TypeError("Cannot call a class as a function"); + } + } + var NeedlemanWunsch = function() { + function NeedlemanWunsch2(sequence1, sequence2) { + var match_score = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : 1; + var mismatch_penalty = arguments.length > 3 && arguments[3] !== void 0 ? arguments[3] : -1; + var gap_penalty = arguments.length > 4 && arguments[4] !== void 0 ? arguments[4] : -1; + _classCallCheck(this, NeedlemanWunsch2); + this.sequence1 = sequence1; + this.sequence2 = sequence2; + this.match_score = match_score; + this.mismatch_penalty = mismatch_penalty; + this.gap_penalty = gap_penalty; + this.iMax = sequence1.length + 1; + this.jMax = sequence2.length + 1; + this.grid = new Array(this.iMax); + for (var i = 0; i < this.iMax; i++) { + this.grid[i] = new Array(this.jMax); + for (var j = 0; j < this.jMax; j++) { + this.grid[i][j] = 0; + } + } + this.tracebackGrid = new Array(this.iMax); + for (var _i = 0; _i < this.iMax; _i++) { + this.tracebackGrid[_i] = new Array(this.jMax); + for (var _j = 0; _j < this.jMax; _j++) { + this.tracebackGrid[_i][_j] = [null, null, null]; + } + } + this.alignments = []; + this.score = -1; + this.computeGrids(); + } + _createClass(NeedlemanWunsch2, [{ + key: "getScore", + value: function getScore() { + return this.score; + } + }, { + key: "getAlignments", + value: function getAlignments() { + return this.alignments; + } + // Main dynamic programming procedure + }, { + key: "computeGrids", + value: function computeGrids() { + for (var j = 1; j < this.jMax; j++) { + this.grid[0][j] = this.grid[0][j - 1] + this.gap_penalty; + this.tracebackGrid[0][j] = [false, false, true]; + } + for (var i = 1; i < this.iMax; i++) { + this.grid[i][0] = this.grid[i - 1][0] + this.gap_penalty; + this.tracebackGrid[i][0] = [false, true, false]; + } + for (var _i2 = 1; _i2 < this.iMax; _i2++) { + for (var _j2 = 1; _j2 < this.jMax; _j2++) { + var diag = void 0; + if (this.sequence1[_i2 - 1] === this.sequence2[_j2 - 1]) + diag = this.grid[_i2 - 1][_j2 - 1] + this.match_score; + else + diag = this.grid[_i2 - 1][_j2 - 1] + this.mismatch_penalty; + var up = this.grid[_i2 - 1][_j2] + this.gap_penalty; + var left = this.grid[_i2][_j2 - 1] + this.gap_penalty; + var maxOf = [diag, up, left]; + var indices = this.arrayAllMaxIndexes(maxOf); + this.grid[_i2][_j2] = maxOf[indices[0]]; + this.tracebackGrid[_i2][_j2] = [indices.includes(0), indices.includes(1), indices.includes(2)]; + } + } + this.score = this.grid[this.iMax - 1][this.jMax - 1]; + } + // Gets all possible valid sequence combinations + }, { + key: "alignmentTraceback", + value: function alignmentTraceback() { + var inProcessAlignments = []; + inProcessAlignments.push({ + pos: [this.sequence1.length, this.sequence2.length], + seq1: "", + seq2: "" + }); + while (inProcessAlignments[0]) { + var current = inProcessAlignments[0]; + var directions = this.tracebackGrid[current.pos[0]][current.pos[1]]; + if (directions[0]) { + inProcessAlignments.push({ + pos: [current.pos[0] - 1, current.pos[1] - 1], + seq1: this.sequence1[current.pos[0] - 1] + current.seq1, + seq2: this.sequence2[current.pos[1] - 1] + current.seq2 + }); + } + if (directions[1]) { + inProcessAlignments.push({ + pos: [current.pos[0] - 1, current.pos[1]], + seq1: this.sequence1[current.pos[0] - 1] + current.seq1, + seq2: "-" + current.seq2 + }); + } + if (directions[2]) { + inProcessAlignments.push({ + pos: [current.pos[0], current.pos[1] - 1], + seq1: "-" + current.seq1, + seq2: this.sequence2[current.pos[1] - 1] + current.seq2 + }); + } + if (current.pos[0] === 0 && current.pos[1] === 0) + this.alignments.push({ + sequence1: current.seq1, + sequence2: current.seq2 + }); + inProcessAlignments.shift(); + } + return this.alignments; + } + // Helper Functions + }, { + key: "getAllIndexes", + value: function getAllIndexes(arr, val) { + var indexes = [], i = -1; + while ((i = arr.indexOf(val, i + 1)) !== -1) { + indexes.push(i); + } + return indexes; + } + }, { + key: "arrayAllMaxIndexes", + value: function arrayAllMaxIndexes(array) { + return this.getAllIndexes(array, Math.max.apply(null, array)); + } + }]); + return NeedlemanWunsch2; + }(); + module2.exports = NeedlemanWunsch; + }, + /* 26 */ + /***/ + function(module2, exports2, __webpack_require__) { + var layoutBase2 = function layoutBase3() { + return; + }; + layoutBase2.FDLayout = __webpack_require__(18); + layoutBase2.FDLayoutConstants = __webpack_require__(7); + layoutBase2.FDLayoutEdge = __webpack_require__(19); + layoutBase2.FDLayoutNode = __webpack_require__(20); + layoutBase2.DimensionD = __webpack_require__(21); + layoutBase2.HashMap = __webpack_require__(22); + layoutBase2.HashSet = __webpack_require__(23); + layoutBase2.IGeometry = __webpack_require__(8); + layoutBase2.IMath = __webpack_require__(9); + layoutBase2.Integer = __webpack_require__(10); + layoutBase2.Point = __webpack_require__(12); + layoutBase2.PointD = __webpack_require__(4); + layoutBase2.RandomSeed = __webpack_require__(16); + layoutBase2.RectangleD = __webpack_require__(13); + layoutBase2.Transform = __webpack_require__(17); + layoutBase2.UniqueIDGeneretor = __webpack_require__(14); + layoutBase2.Quicksort = __webpack_require__(24); + layoutBase2.LinkedList = __webpack_require__(11); + layoutBase2.LGraphObject = __webpack_require__(2); + layoutBase2.LGraph = __webpack_require__(5); + layoutBase2.LEdge = __webpack_require__(1); + layoutBase2.LGraphManager = __webpack_require__(6); + layoutBase2.LNode = __webpack_require__(3); + layoutBase2.Layout = __webpack_require__(15); + layoutBase2.LayoutConstants = __webpack_require__(0); + layoutBase2.NeedlemanWunsch = __webpack_require__(25); + module2.exports = layoutBase2; + }, + /* 27 */ + /***/ + function(module2, exports2, __webpack_require__) { + function Emitter() { + this.listeners = []; + } + var p = Emitter.prototype; + p.addListener = function(event, callback) { + this.listeners.push({ + event, + callback + }); + }; + p.removeListener = function(event, callback) { + for (var i = this.listeners.length; i >= 0; i--) { + var l = this.listeners[i]; + if (l.event === event && l.callback === callback) { + this.listeners.splice(i, 1); + } + } + }; + p.emit = function(event, data) { + for (var i = 0; i < this.listeners.length; i++) { + var l = this.listeners[i]; + if (event === l.event) { + l.callback(data); + } + } + }; + module2.exports = Emitter; + } + /******/ + ]) + ); + }); + })(layoutBase); + return layoutBase.exports; +} +var hasRequiredCoseBase; +function requireCoseBase() { + if (hasRequiredCoseBase) + return coseBase.exports; + hasRequiredCoseBase = 1; + (function(module, exports) { + (function webpackUniversalModuleDefinition(root, factory) { + module.exports = factory(requireLayoutBase()); + })(commonjsGlobal, function(__WEBPACK_EXTERNAL_MODULE_0__) { + return ( + /******/ + function(modules) { + var installedModules = {}; + function __webpack_require__(moduleId) { + if (installedModules[moduleId]) { + return installedModules[moduleId].exports; + } + var module2 = installedModules[moduleId] = { + /******/ + i: moduleId, + /******/ + l: false, + /******/ + exports: {} + /******/ + }; + modules[moduleId].call(module2.exports, module2, module2.exports, __webpack_require__); + module2.l = true; + return module2.exports; + } + __webpack_require__.m = modules; + __webpack_require__.c = installedModules; + __webpack_require__.i = function(value) { + return value; + }; + __webpack_require__.d = function(exports2, name, getter) { + if (!__webpack_require__.o(exports2, name)) { + Object.defineProperty(exports2, name, { + /******/ + configurable: false, + /******/ + enumerable: true, + /******/ + get: getter + /******/ + }); + } + }; + __webpack_require__.n = function(module2) { + var getter = module2 && module2.__esModule ? ( + /******/ + function getDefault() { + return module2["default"]; + } + ) : ( + /******/ + function getModuleExports() { + return module2; + } + ); + __webpack_require__.d(getter, "a", getter); + return getter; + }; + __webpack_require__.o = function(object, property) { + return Object.prototype.hasOwnProperty.call(object, property); + }; + __webpack_require__.p = ""; + return __webpack_require__(__webpack_require__.s = 7); + }([ + /* 0 */ + /***/ + function(module2, exports2) { + module2.exports = __WEBPACK_EXTERNAL_MODULE_0__; + }, + /* 1 */ + /***/ + function(module2, exports2, __webpack_require__) { + var FDLayoutConstants = __webpack_require__(0).FDLayoutConstants; + function CoSEConstants() { + } + for (var prop in FDLayoutConstants) { + CoSEConstants[prop] = FDLayoutConstants[prop]; + } + CoSEConstants.DEFAULT_USE_MULTI_LEVEL_SCALING = false; + CoSEConstants.DEFAULT_RADIAL_SEPARATION = FDLayoutConstants.DEFAULT_EDGE_LENGTH; + CoSEConstants.DEFAULT_COMPONENT_SEPERATION = 60; + CoSEConstants.TILE = true; + CoSEConstants.TILING_PADDING_VERTICAL = 10; + CoSEConstants.TILING_PADDING_HORIZONTAL = 10; + CoSEConstants.TREE_REDUCTION_ON_INCREMENTAL = false; + module2.exports = CoSEConstants; + }, + /* 2 */ + /***/ + function(module2, exports2, __webpack_require__) { + var FDLayoutEdge = __webpack_require__(0).FDLayoutEdge; + function CoSEEdge(source, target, vEdge) { + FDLayoutEdge.call(this, source, target, vEdge); + } + CoSEEdge.prototype = Object.create(FDLayoutEdge.prototype); + for (var prop in FDLayoutEdge) { + CoSEEdge[prop] = FDLayoutEdge[prop]; + } + module2.exports = CoSEEdge; + }, + /* 3 */ + /***/ + function(module2, exports2, __webpack_require__) { + var LGraph = __webpack_require__(0).LGraph; + function CoSEGraph(parent, graphMgr, vGraph) { + LGraph.call(this, parent, graphMgr, vGraph); + } + CoSEGraph.prototype = Object.create(LGraph.prototype); + for (var prop in LGraph) { + CoSEGraph[prop] = LGraph[prop]; + } + module2.exports = CoSEGraph; + }, + /* 4 */ + /***/ + function(module2, exports2, __webpack_require__) { + var LGraphManager = __webpack_require__(0).LGraphManager; + function CoSEGraphManager(layout) { + LGraphManager.call(this, layout); + } + CoSEGraphManager.prototype = Object.create(LGraphManager.prototype); + for (var prop in LGraphManager) { + CoSEGraphManager[prop] = LGraphManager[prop]; + } + module2.exports = CoSEGraphManager; + }, + /* 5 */ + /***/ + function(module2, exports2, __webpack_require__) { + var FDLayoutNode = __webpack_require__(0).FDLayoutNode; + var IMath = __webpack_require__(0).IMath; + function CoSENode(gm, loc, size, vNode) { + FDLayoutNode.call(this, gm, loc, size, vNode); + } + CoSENode.prototype = Object.create(FDLayoutNode.prototype); + for (var prop in FDLayoutNode) { + CoSENode[prop] = FDLayoutNode[prop]; + } + CoSENode.prototype.move = function() { + var layout = this.graphManager.getLayout(); + this.displacementX = layout.coolingFactor * (this.springForceX + this.repulsionForceX + this.gravitationForceX) / this.noOfChildren; + this.displacementY = layout.coolingFactor * (this.springForceY + this.repulsionForceY + this.gravitationForceY) / this.noOfChildren; + if (Math.abs(this.displacementX) > layout.coolingFactor * layout.maxNodeDisplacement) { + this.displacementX = layout.coolingFactor * layout.maxNodeDisplacement * IMath.sign(this.displacementX); + } + if (Math.abs(this.displacementY) > layout.coolingFactor * layout.maxNodeDisplacement) { + this.displacementY = layout.coolingFactor * layout.maxNodeDisplacement * IMath.sign(this.displacementY); + } + if (this.child == null) { + this.moveBy(this.displacementX, this.displacementY); + } else if (this.child.getNodes().length == 0) { + this.moveBy(this.displacementX, this.displacementY); + } else { + this.propogateDisplacementToChildren(this.displacementX, this.displacementY); + } + layout.totalDisplacement += Math.abs(this.displacementX) + Math.abs(this.displacementY); + this.springForceX = 0; + this.springForceY = 0; + this.repulsionForceX = 0; + this.repulsionForceY = 0; + this.gravitationForceX = 0; + this.gravitationForceY = 0; + this.displacementX = 0; + this.displacementY = 0; + }; + CoSENode.prototype.propogateDisplacementToChildren = function(dX, dY) { + var nodes2 = this.getChild().getNodes(); + var node; + for (var i = 0; i < nodes2.length; i++) { + node = nodes2[i]; + if (node.getChild() == null) { + node.moveBy(dX, dY); + node.displacementX += dX; + node.displacementY += dY; + } else { + node.propogateDisplacementToChildren(dX, dY); + } + } + }; + CoSENode.prototype.setPred1 = function(pred12) { + this.pred1 = pred12; + }; + CoSENode.prototype.getPred1 = function() { + return pred1; + }; + CoSENode.prototype.getPred2 = function() { + return pred2; + }; + CoSENode.prototype.setNext = function(next2) { + this.next = next2; + }; + CoSENode.prototype.getNext = function() { + return next; + }; + CoSENode.prototype.setProcessed = function(processed2) { + this.processed = processed2; + }; + CoSENode.prototype.isProcessed = function() { + return processed; + }; + module2.exports = CoSENode; + }, + /* 6 */ + /***/ + function(module2, exports2, __webpack_require__) { + var FDLayout = __webpack_require__(0).FDLayout; + var CoSEGraphManager = __webpack_require__(4); + var CoSEGraph = __webpack_require__(3); + var CoSENode = __webpack_require__(5); + var CoSEEdge = __webpack_require__(2); + var CoSEConstants = __webpack_require__(1); + var FDLayoutConstants = __webpack_require__(0).FDLayoutConstants; + var LayoutConstants = __webpack_require__(0).LayoutConstants; + var Point2 = __webpack_require__(0).Point; + var PointD = __webpack_require__(0).PointD; + var Layout2 = __webpack_require__(0).Layout; + var Integer = __webpack_require__(0).Integer; + var IGeometry = __webpack_require__(0).IGeometry; + var LGraph = __webpack_require__(0).LGraph; + var Transform = __webpack_require__(0).Transform; + function CoSELayout() { + FDLayout.call(this); + this.toBeTiled = {}; + } + CoSELayout.prototype = Object.create(FDLayout.prototype); + for (var prop in FDLayout) { + CoSELayout[prop] = FDLayout[prop]; + } + CoSELayout.prototype.newGraphManager = function() { + var gm = new CoSEGraphManager(this); + this.graphManager = gm; + return gm; + }; + CoSELayout.prototype.newGraph = function(vGraph) { + return new CoSEGraph(null, this.graphManager, vGraph); + }; + CoSELayout.prototype.newNode = function(vNode) { + return new CoSENode(this.graphManager, vNode); + }; + CoSELayout.prototype.newEdge = function(vEdge) { + return new CoSEEdge(null, null, vEdge); + }; + CoSELayout.prototype.initParameters = function() { + FDLayout.prototype.initParameters.call(this, arguments); + if (!this.isSubLayout) { + if (CoSEConstants.DEFAULT_EDGE_LENGTH < 10) { + this.idealEdgeLength = 10; + } else { + this.idealEdgeLength = CoSEConstants.DEFAULT_EDGE_LENGTH; + } + this.useSmartIdealEdgeLengthCalculation = CoSEConstants.DEFAULT_USE_SMART_IDEAL_EDGE_LENGTH_CALCULATION; + this.springConstant = FDLayoutConstants.DEFAULT_SPRING_STRENGTH; + this.repulsionConstant = FDLayoutConstants.DEFAULT_REPULSION_STRENGTH; + this.gravityConstant = FDLayoutConstants.DEFAULT_GRAVITY_STRENGTH; + this.compoundGravityConstant = FDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_STRENGTH; + this.gravityRangeFactor = FDLayoutConstants.DEFAULT_GRAVITY_RANGE_FACTOR; + this.compoundGravityRangeFactor = FDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_RANGE_FACTOR; + this.prunedNodesAll = []; + this.growTreeIterations = 0; + this.afterGrowthIterations = 0; + this.isTreeGrowing = false; + this.isGrowthFinished = false; + this.coolingCycle = 0; + this.maxCoolingCycle = this.maxIterations / FDLayoutConstants.CONVERGENCE_CHECK_PERIOD; + this.finalTemperature = FDLayoutConstants.CONVERGENCE_CHECK_PERIOD / this.maxIterations; + this.coolingAdjuster = 1; + } + }; + CoSELayout.prototype.layout = function() { + var createBendsAsNeeded = LayoutConstants.DEFAULT_CREATE_BENDS_AS_NEEDED; + if (createBendsAsNeeded) { + this.createBendpoints(); + this.graphManager.resetAllEdges(); + } + this.level = 0; + return this.classicLayout(); + }; + CoSELayout.prototype.classicLayout = function() { + this.nodesWithGravity = this.calculateNodesToApplyGravitationTo(); + this.graphManager.setAllNodesToApplyGravitation(this.nodesWithGravity); + this.calcNoOfChildrenForAllNodes(); + this.graphManager.calcLowestCommonAncestors(); + this.graphManager.calcInclusionTreeDepths(); + this.graphManager.getRoot().calcEstimatedSize(); + this.calcIdealEdgeLengths(); + if (!this.incremental) { + var forest = this.getFlatForest(); + if (forest.length > 0) { + this.positionNodesRadially(forest); + } else { + this.reduceTrees(); + this.graphManager.resetAllNodesToApplyGravitation(); + var allNodes = new Set(this.getAllNodes()); + var intersection = this.nodesWithGravity.filter(function(x) { + return allNodes.has(x); + }); + this.graphManager.setAllNodesToApplyGravitation(intersection); + this.positionNodesRandomly(); + } + } else { + if (CoSEConstants.TREE_REDUCTION_ON_INCREMENTAL) { + this.reduceTrees(); + this.graphManager.resetAllNodesToApplyGravitation(); + var allNodes = new Set(this.getAllNodes()); + var intersection = this.nodesWithGravity.filter(function(x) { + return allNodes.has(x); + }); + this.graphManager.setAllNodesToApplyGravitation(intersection); + } + } + this.initSpringEmbedder(); + this.runSpringEmbedder(); + return true; + }; + CoSELayout.prototype.tick = function() { + this.totalIterations++; + if (this.totalIterations === this.maxIterations && !this.isTreeGrowing && !this.isGrowthFinished) { + if (this.prunedNodesAll.length > 0) { + this.isTreeGrowing = true; + } else { + return true; + } + } + if (this.totalIterations % FDLayoutConstants.CONVERGENCE_CHECK_PERIOD == 0 && !this.isTreeGrowing && !this.isGrowthFinished) { + if (this.isConverged()) { + if (this.prunedNodesAll.length > 0) { + this.isTreeGrowing = true; + } else { + return true; + } + } + this.coolingCycle++; + if (this.layoutQuality == 0) { + this.coolingAdjuster = this.coolingCycle; + } else if (this.layoutQuality == 1) { + this.coolingAdjuster = this.coolingCycle / 3; + } + this.coolingFactor = Math.max(this.initialCoolingFactor - Math.pow(this.coolingCycle, Math.log(100 * (this.initialCoolingFactor - this.finalTemperature)) / Math.log(this.maxCoolingCycle)) / 100 * this.coolingAdjuster, this.finalTemperature); + this.animationPeriod = Math.ceil(this.initialAnimationPeriod * Math.sqrt(this.coolingFactor)); + } + if (this.isTreeGrowing) { + if (this.growTreeIterations % 10 == 0) { + if (this.prunedNodesAll.length > 0) { + this.graphManager.updateBounds(); + this.updateGrid(); + this.growTree(this.prunedNodesAll); + this.graphManager.resetAllNodesToApplyGravitation(); + var allNodes = new Set(this.getAllNodes()); + var intersection = this.nodesWithGravity.filter(function(x) { + return allNodes.has(x); + }); + this.graphManager.setAllNodesToApplyGravitation(intersection); + this.graphManager.updateBounds(); + this.updateGrid(); + this.coolingFactor = FDLayoutConstants.DEFAULT_COOLING_FACTOR_INCREMENTAL; + } else { + this.isTreeGrowing = false; + this.isGrowthFinished = true; + } + } + this.growTreeIterations++; + } + if (this.isGrowthFinished) { + if (this.isConverged()) { + return true; + } + if (this.afterGrowthIterations % 10 == 0) { + this.graphManager.updateBounds(); + this.updateGrid(); + } + this.coolingFactor = FDLayoutConstants.DEFAULT_COOLING_FACTOR_INCREMENTAL * ((100 - this.afterGrowthIterations) / 100); + this.afterGrowthIterations++; + } + var gridUpdateAllowed = !this.isTreeGrowing && !this.isGrowthFinished; + var forceToNodeSurroundingUpdate = this.growTreeIterations % 10 == 1 && this.isTreeGrowing || this.afterGrowthIterations % 10 == 1 && this.isGrowthFinished; + this.totalDisplacement = 0; + this.graphManager.updateBounds(); + this.calcSpringForces(); + this.calcRepulsionForces(gridUpdateAllowed, forceToNodeSurroundingUpdate); + this.calcGravitationalForces(); + this.moveNodes(); + this.animate(); + return false; + }; + CoSELayout.prototype.getPositionsData = function() { + var allNodes = this.graphManager.getAllNodes(); + var pData = {}; + for (var i = 0; i < allNodes.length; i++) { + var rect = allNodes[i].rect; + var id = allNodes[i].id; + pData[id] = { + id, + x: rect.getCenterX(), + y: rect.getCenterY(), + w: rect.width, + h: rect.height + }; + } + return pData; + }; + CoSELayout.prototype.runSpringEmbedder = function() { + this.initialAnimationPeriod = 25; + this.animationPeriod = this.initialAnimationPeriod; + var layoutEnded = false; + if (FDLayoutConstants.ANIMATE === "during") { + this.emit("layoutstarted"); + } else { + while (!layoutEnded) { + layoutEnded = this.tick(); + } + this.graphManager.updateBounds(); + } + }; + CoSELayout.prototype.calculateNodesToApplyGravitationTo = function() { + var nodeList = []; + var graph; + var graphs = this.graphManager.getGraphs(); + var size = graphs.length; + var i; + for (i = 0; i < size; i++) { + graph = graphs[i]; + graph.updateConnected(); + if (!graph.isConnected) { + nodeList = nodeList.concat(graph.getNodes()); + } + } + return nodeList; + }; + CoSELayout.prototype.createBendpoints = function() { + var edges = []; + edges = edges.concat(this.graphManager.getAllEdges()); + var visited = /* @__PURE__ */ new Set(); + var i; + for (i = 0; i < edges.length; i++) { + var edge = edges[i]; + if (!visited.has(edge)) { + var source = edge.getSource(); + var target = edge.getTarget(); + if (source == target) { + edge.getBendpoints().push(new PointD()); + edge.getBendpoints().push(new PointD()); + this.createDummyNodesForBendpoints(edge); + visited.add(edge); + } else { + var edgeList = []; + edgeList = edgeList.concat(source.getEdgeListToNode(target)); + edgeList = edgeList.concat(target.getEdgeListToNode(source)); + if (!visited.has(edgeList[0])) { + if (edgeList.length > 1) { + var k; + for (k = 0; k < edgeList.length; k++) { + var multiEdge = edgeList[k]; + multiEdge.getBendpoints().push(new PointD()); + this.createDummyNodesForBendpoints(multiEdge); + } + } + edgeList.forEach(function(edge2) { + visited.add(edge2); + }); + } + } + } + if (visited.size == edges.length) { + break; + } + } + }; + CoSELayout.prototype.positionNodesRadially = function(forest) { + var currentStartingPoint = new Point2(0, 0); + var numberOfColumns = Math.ceil(Math.sqrt(forest.length)); + var height = 0; + var currentY = 0; + var currentX = 0; + var point = new PointD(0, 0); + for (var i = 0; i < forest.length; i++) { + if (i % numberOfColumns == 0) { + currentX = 0; + currentY = height; + if (i != 0) { + currentY += CoSEConstants.DEFAULT_COMPONENT_SEPERATION; + } + height = 0; + } + var tree = forest[i]; + var centerNode = Layout2.findCenterOfTree(tree); + currentStartingPoint.x = currentX; + currentStartingPoint.y = currentY; + point = CoSELayout.radialLayout(tree, centerNode, currentStartingPoint); + if (point.y > height) { + height = Math.floor(point.y); + } + currentX = Math.floor(point.x + CoSEConstants.DEFAULT_COMPONENT_SEPERATION); + } + this.transform(new PointD(LayoutConstants.WORLD_CENTER_X - point.x / 2, LayoutConstants.WORLD_CENTER_Y - point.y / 2)); + }; + CoSELayout.radialLayout = function(tree, centerNode, startingPoint) { + var radialSep = Math.max(this.maxDiagonalInTree(tree), CoSEConstants.DEFAULT_RADIAL_SEPARATION); + CoSELayout.branchRadialLayout(centerNode, null, 0, 359, 0, radialSep); + var bounds = LGraph.calculateBounds(tree); + var transform = new Transform(); + transform.setDeviceOrgX(bounds.getMinX()); + transform.setDeviceOrgY(bounds.getMinY()); + transform.setWorldOrgX(startingPoint.x); + transform.setWorldOrgY(startingPoint.y); + for (var i = 0; i < tree.length; i++) { + var node = tree[i]; + node.transform(transform); + } + var bottomRight = new PointD(bounds.getMaxX(), bounds.getMaxY()); + return transform.inverseTransformPoint(bottomRight); + }; + CoSELayout.branchRadialLayout = function(node, parentOfNode, startAngle, endAngle, distance, radialSeparation) { + var halfInterval = (endAngle - startAngle + 1) / 2; + if (halfInterval < 0) { + halfInterval += 180; + } + var nodeAngle = (halfInterval + startAngle) % 360; + var teta = nodeAngle * IGeometry.TWO_PI / 360; + var x_ = distance * Math.cos(teta); + var y_ = distance * Math.sin(teta); + node.setCenter(x_, y_); + var neighborEdges = []; + neighborEdges = neighborEdges.concat(node.getEdges()); + var childCount = neighborEdges.length; + if (parentOfNode != null) { + childCount--; + } + var branchCount = 0; + var incEdgesCount = neighborEdges.length; + var startIndex; + var edges = node.getEdgesBetween(parentOfNode); + while (edges.length > 1) { + var temp = edges[0]; + edges.splice(0, 1); + var index = neighborEdges.indexOf(temp); + if (index >= 0) { + neighborEdges.splice(index, 1); + } + incEdgesCount--; + childCount--; + } + if (parentOfNode != null) { + startIndex = (neighborEdges.indexOf(edges[0]) + 1) % incEdgesCount; + } else { + startIndex = 0; + } + var stepAngle = Math.abs(endAngle - startAngle) / childCount; + for (var i = startIndex; branchCount != childCount; i = ++i % incEdgesCount) { + var currentNeighbor = neighborEdges[i].getOtherEnd(node); + if (currentNeighbor == parentOfNode) { + continue; + } + var childStartAngle = (startAngle + branchCount * stepAngle) % 360; + var childEndAngle = (childStartAngle + stepAngle) % 360; + CoSELayout.branchRadialLayout(currentNeighbor, node, childStartAngle, childEndAngle, distance + radialSeparation, radialSeparation); + branchCount++; + } + }; + CoSELayout.maxDiagonalInTree = function(tree) { + var maxDiagonal = Integer.MIN_VALUE; + for (var i = 0; i < tree.length; i++) { + var node = tree[i]; + var diagonal = node.getDiagonal(); + if (diagonal > maxDiagonal) { + maxDiagonal = diagonal; + } + } + return maxDiagonal; + }; + CoSELayout.prototype.calcRepulsionRange = function() { + return 2 * (this.level + 1) * this.idealEdgeLength; + }; + CoSELayout.prototype.groupZeroDegreeMembers = function() { + var self2 = this; + var tempMemberGroups = {}; + this.memberGroups = {}; + this.idToDummyNode = {}; + var zeroDegree = []; + var allNodes = this.graphManager.getAllNodes(); + for (var i = 0; i < allNodes.length; i++) { + var node = allNodes[i]; + var parent = node.getParent(); + if (this.getNodeDegreeWithChildren(node) === 0 && (parent.id == void 0 || !this.getToBeTiled(parent))) { + zeroDegree.push(node); + } + } + for (var i = 0; i < zeroDegree.length; i++) { + var node = zeroDegree[i]; + var p_id = node.getParent().id; + if (typeof tempMemberGroups[p_id] === "undefined") + tempMemberGroups[p_id] = []; + tempMemberGroups[p_id] = tempMemberGroups[p_id].concat(node); + } + Object.keys(tempMemberGroups).forEach(function(p_id2) { + if (tempMemberGroups[p_id2].length > 1) { + var dummyCompoundId = "DummyCompound_" + p_id2; + self2.memberGroups[dummyCompoundId] = tempMemberGroups[p_id2]; + var parent2 = tempMemberGroups[p_id2][0].getParent(); + var dummyCompound = new CoSENode(self2.graphManager); + dummyCompound.id = dummyCompoundId; + dummyCompound.paddingLeft = parent2.paddingLeft || 0; + dummyCompound.paddingRight = parent2.paddingRight || 0; + dummyCompound.paddingBottom = parent2.paddingBottom || 0; + dummyCompound.paddingTop = parent2.paddingTop || 0; + self2.idToDummyNode[dummyCompoundId] = dummyCompound; + var dummyParentGraph = self2.getGraphManager().add(self2.newGraph(), dummyCompound); + var parentGraph = parent2.getChild(); + parentGraph.add(dummyCompound); + for (var i2 = 0; i2 < tempMemberGroups[p_id2].length; i2++) { + var node2 = tempMemberGroups[p_id2][i2]; + parentGraph.remove(node2); + dummyParentGraph.add(node2); + } + } + }); + }; + CoSELayout.prototype.clearCompounds = function() { + var childGraphMap = {}; + var idToNode = {}; + this.performDFSOnCompounds(); + for (var i = 0; i < this.compoundOrder.length; i++) { + idToNode[this.compoundOrder[i].id] = this.compoundOrder[i]; + childGraphMap[this.compoundOrder[i].id] = [].concat(this.compoundOrder[i].getChild().getNodes()); + this.graphManager.remove(this.compoundOrder[i].getChild()); + this.compoundOrder[i].child = null; + } + this.graphManager.resetAllNodes(); + this.tileCompoundMembers(childGraphMap, idToNode); + }; + CoSELayout.prototype.clearZeroDegreeMembers = function() { + var self2 = this; + var tiledZeroDegreePack = this.tiledZeroDegreePack = []; + Object.keys(this.memberGroups).forEach(function(id) { + var compoundNode = self2.idToDummyNode[id]; + tiledZeroDegreePack[id] = self2.tileNodes(self2.memberGroups[id], compoundNode.paddingLeft + compoundNode.paddingRight); + compoundNode.rect.width = tiledZeroDegreePack[id].width; + compoundNode.rect.height = tiledZeroDegreePack[id].height; + }); + }; + CoSELayout.prototype.repopulateCompounds = function() { + for (var i = this.compoundOrder.length - 1; i >= 0; i--) { + var lCompoundNode = this.compoundOrder[i]; + var id = lCompoundNode.id; + var horizontalMargin = lCompoundNode.paddingLeft; + var verticalMargin = lCompoundNode.paddingTop; + this.adjustLocations(this.tiledMemberPack[id], lCompoundNode.rect.x, lCompoundNode.rect.y, horizontalMargin, verticalMargin); + } + }; + CoSELayout.prototype.repopulateZeroDegreeMembers = function() { + var self2 = this; + var tiledPack = this.tiledZeroDegreePack; + Object.keys(tiledPack).forEach(function(id) { + var compoundNode = self2.idToDummyNode[id]; + var horizontalMargin = compoundNode.paddingLeft; + var verticalMargin = compoundNode.paddingTop; + self2.adjustLocations(tiledPack[id], compoundNode.rect.x, compoundNode.rect.y, horizontalMargin, verticalMargin); + }); + }; + CoSELayout.prototype.getToBeTiled = function(node) { + var id = node.id; + if (this.toBeTiled[id] != null) { + return this.toBeTiled[id]; + } + var childGraph = node.getChild(); + if (childGraph == null) { + this.toBeTiled[id] = false; + return false; + } + var children = childGraph.getNodes(); + for (var i = 0; i < children.length; i++) { + var theChild = children[i]; + if (this.getNodeDegree(theChild) > 0) { + this.toBeTiled[id] = false; + return false; + } + if (theChild.getChild() == null) { + this.toBeTiled[theChild.id] = false; + continue; + } + if (!this.getToBeTiled(theChild)) { + this.toBeTiled[id] = false; + return false; + } + } + this.toBeTiled[id] = true; + return true; + }; + CoSELayout.prototype.getNodeDegree = function(node) { + node.id; + var edges = node.getEdges(); + var degree = 0; + for (var i = 0; i < edges.length; i++) { + var edge = edges[i]; + if (edge.getSource().id !== edge.getTarget().id) { + degree = degree + 1; + } + } + return degree; + }; + CoSELayout.prototype.getNodeDegreeWithChildren = function(node) { + var degree = this.getNodeDegree(node); + if (node.getChild() == null) { + return degree; + } + var children = node.getChild().getNodes(); + for (var i = 0; i < children.length; i++) { + var child = children[i]; + degree += this.getNodeDegreeWithChildren(child); + } + return degree; + }; + CoSELayout.prototype.performDFSOnCompounds = function() { + this.compoundOrder = []; + this.fillCompexOrderByDFS(this.graphManager.getRoot().getNodes()); + }; + CoSELayout.prototype.fillCompexOrderByDFS = function(children) { + for (var i = 0; i < children.length; i++) { + var child = children[i]; + if (child.getChild() != null) { + this.fillCompexOrderByDFS(child.getChild().getNodes()); + } + if (this.getToBeTiled(child)) { + this.compoundOrder.push(child); + } + } + }; + CoSELayout.prototype.adjustLocations = function(organization, x, y, compoundHorizontalMargin, compoundVerticalMargin) { + x += compoundHorizontalMargin; + y += compoundVerticalMargin; + var left = x; + for (var i = 0; i < organization.rows.length; i++) { + var row = organization.rows[i]; + x = left; + var maxHeight = 0; + for (var j = 0; j < row.length; j++) { + var lnode = row[j]; + lnode.rect.x = x; + lnode.rect.y = y; + x += lnode.rect.width + organization.horizontalPadding; + if (lnode.rect.height > maxHeight) + maxHeight = lnode.rect.height; + } + y += maxHeight + organization.verticalPadding; + } + }; + CoSELayout.prototype.tileCompoundMembers = function(childGraphMap, idToNode) { + var self2 = this; + this.tiledMemberPack = []; + Object.keys(childGraphMap).forEach(function(id) { + var compoundNode = idToNode[id]; + self2.tiledMemberPack[id] = self2.tileNodes(childGraphMap[id], compoundNode.paddingLeft + compoundNode.paddingRight); + compoundNode.rect.width = self2.tiledMemberPack[id].width; + compoundNode.rect.height = self2.tiledMemberPack[id].height; + }); + }; + CoSELayout.prototype.tileNodes = function(nodes2, minWidth) { + var verticalPadding = CoSEConstants.TILING_PADDING_VERTICAL; + var horizontalPadding = CoSEConstants.TILING_PADDING_HORIZONTAL; + var organization = { + rows: [], + rowWidth: [], + rowHeight: [], + width: 0, + height: minWidth, + // assume minHeight equals to minWidth + verticalPadding, + horizontalPadding + }; + nodes2.sort(function(n1, n2) { + if (n1.rect.width * n1.rect.height > n2.rect.width * n2.rect.height) + return -1; + if (n1.rect.width * n1.rect.height < n2.rect.width * n2.rect.height) + return 1; + return 0; + }); + for (var i = 0; i < nodes2.length; i++) { + var lNode = nodes2[i]; + if (organization.rows.length == 0) { + this.insertNodeToRow(organization, lNode, 0, minWidth); + } else if (this.canAddHorizontal(organization, lNode.rect.width, lNode.rect.height)) { + this.insertNodeToRow(organization, lNode, this.getShortestRowIndex(organization), minWidth); + } else { + this.insertNodeToRow(organization, lNode, organization.rows.length, minWidth); + } + this.shiftToLastRow(organization); + } + return organization; + }; + CoSELayout.prototype.insertNodeToRow = function(organization, node, rowIndex, minWidth) { + var minCompoundSize = minWidth; + if (rowIndex == organization.rows.length) { + var secondDimension = []; + organization.rows.push(secondDimension); + organization.rowWidth.push(minCompoundSize); + organization.rowHeight.push(0); + } + var w = organization.rowWidth[rowIndex] + node.rect.width; + if (organization.rows[rowIndex].length > 0) { + w += organization.horizontalPadding; + } + organization.rowWidth[rowIndex] = w; + if (organization.width < w) { + organization.width = w; + } + var h = node.rect.height; + if (rowIndex > 0) + h += organization.verticalPadding; + var extraHeight = 0; + if (h > organization.rowHeight[rowIndex]) { + extraHeight = organization.rowHeight[rowIndex]; + organization.rowHeight[rowIndex] = h; + extraHeight = organization.rowHeight[rowIndex] - extraHeight; + } + organization.height += extraHeight; + organization.rows[rowIndex].push(node); + }; + CoSELayout.prototype.getShortestRowIndex = function(organization) { + var r = -1; + var min = Number.MAX_VALUE; + for (var i = 0; i < organization.rows.length; i++) { + if (organization.rowWidth[i] < min) { + r = i; + min = organization.rowWidth[i]; + } + } + return r; + }; + CoSELayout.prototype.getLongestRowIndex = function(organization) { + var r = -1; + var max = Number.MIN_VALUE; + for (var i = 0; i < organization.rows.length; i++) { + if (organization.rowWidth[i] > max) { + r = i; + max = organization.rowWidth[i]; + } + } + return r; + }; + CoSELayout.prototype.canAddHorizontal = function(organization, extraWidth, extraHeight) { + var sri = this.getShortestRowIndex(organization); + if (sri < 0) { + return true; + } + var min = organization.rowWidth[sri]; + if (min + organization.horizontalPadding + extraWidth <= organization.width) + return true; + var hDiff = 0; + if (organization.rowHeight[sri] < extraHeight) { + if (sri > 0) + hDiff = extraHeight + organization.verticalPadding - organization.rowHeight[sri]; + } + var add_to_row_ratio; + if (organization.width - min >= extraWidth + organization.horizontalPadding) { + add_to_row_ratio = (organization.height + hDiff) / (min + extraWidth + organization.horizontalPadding); + } else { + add_to_row_ratio = (organization.height + hDiff) / organization.width; + } + hDiff = extraHeight + organization.verticalPadding; + var add_new_row_ratio; + if (organization.width < extraWidth) { + add_new_row_ratio = (organization.height + hDiff) / extraWidth; + } else { + add_new_row_ratio = (organization.height + hDiff) / organization.width; + } + if (add_new_row_ratio < 1) + add_new_row_ratio = 1 / add_new_row_ratio; + if (add_to_row_ratio < 1) + add_to_row_ratio = 1 / add_to_row_ratio; + return add_to_row_ratio < add_new_row_ratio; + }; + CoSELayout.prototype.shiftToLastRow = function(organization) { + var longest = this.getLongestRowIndex(organization); + var last = organization.rowWidth.length - 1; + var row = organization.rows[longest]; + var node = row[row.length - 1]; + var diff = node.width + organization.horizontalPadding; + if (organization.width - organization.rowWidth[last] > diff && longest != last) { + row.splice(-1, 1); + organization.rows[last].push(node); + organization.rowWidth[longest] = organization.rowWidth[longest] - diff; + organization.rowWidth[last] = organization.rowWidth[last] + diff; + organization.width = organization.rowWidth[instance.getLongestRowIndex(organization)]; + var maxHeight = Number.MIN_VALUE; + for (var i = 0; i < row.length; i++) { + if (row[i].height > maxHeight) + maxHeight = row[i].height; + } + if (longest > 0) + maxHeight += organization.verticalPadding; + var prevTotal = organization.rowHeight[longest] + organization.rowHeight[last]; + organization.rowHeight[longest] = maxHeight; + if (organization.rowHeight[last] < node.height + organization.verticalPadding) + organization.rowHeight[last] = node.height + organization.verticalPadding; + var finalTotal = organization.rowHeight[longest] + organization.rowHeight[last]; + organization.height += finalTotal - prevTotal; + this.shiftToLastRow(organization); + } + }; + CoSELayout.prototype.tilingPreLayout = function() { + if (CoSEConstants.TILE) { + this.groupZeroDegreeMembers(); + this.clearCompounds(); + this.clearZeroDegreeMembers(); + } + }; + CoSELayout.prototype.tilingPostLayout = function() { + if (CoSEConstants.TILE) { + this.repopulateZeroDegreeMembers(); + this.repopulateCompounds(); + } + }; + CoSELayout.prototype.reduceTrees = function() { + var prunedNodesAll = []; + var containsLeaf = true; + var node; + while (containsLeaf) { + var allNodes = this.graphManager.getAllNodes(); + var prunedNodesInStepTemp = []; + containsLeaf = false; + for (var i = 0; i < allNodes.length; i++) { + node = allNodes[i]; + if (node.getEdges().length == 1 && !node.getEdges()[0].isInterGraph && node.getChild() == null) { + prunedNodesInStepTemp.push([node, node.getEdges()[0], node.getOwner()]); + containsLeaf = true; + } + } + if (containsLeaf == true) { + var prunedNodesInStep = []; + for (var j = 0; j < prunedNodesInStepTemp.length; j++) { + if (prunedNodesInStepTemp[j][0].getEdges().length == 1) { + prunedNodesInStep.push(prunedNodesInStepTemp[j]); + prunedNodesInStepTemp[j][0].getOwner().remove(prunedNodesInStepTemp[j][0]); + } + } + prunedNodesAll.push(prunedNodesInStep); + this.graphManager.resetAllNodes(); + this.graphManager.resetAllEdges(); + } + } + this.prunedNodesAll = prunedNodesAll; + }; + CoSELayout.prototype.growTree = function(prunedNodesAll) { + var lengthOfPrunedNodesInStep = prunedNodesAll.length; + var prunedNodesInStep = prunedNodesAll[lengthOfPrunedNodesInStep - 1]; + var nodeData; + for (var i = 0; i < prunedNodesInStep.length; i++) { + nodeData = prunedNodesInStep[i]; + this.findPlaceforPrunedNode(nodeData); + nodeData[2].add(nodeData[0]); + nodeData[2].add(nodeData[1], nodeData[1].source, nodeData[1].target); + } + prunedNodesAll.splice(prunedNodesAll.length - 1, 1); + this.graphManager.resetAllNodes(); + this.graphManager.resetAllEdges(); + }; + CoSELayout.prototype.findPlaceforPrunedNode = function(nodeData) { + var gridForPrunedNode; + var nodeToConnect; + var prunedNode = nodeData[0]; + if (prunedNode == nodeData[1].source) { + nodeToConnect = nodeData[1].target; + } else { + nodeToConnect = nodeData[1].source; + } + var startGridX = nodeToConnect.startX; + var finishGridX = nodeToConnect.finishX; + var startGridY = nodeToConnect.startY; + var finishGridY = nodeToConnect.finishY; + var upNodeCount = 0; + var downNodeCount = 0; + var rightNodeCount = 0; + var leftNodeCount = 0; + var controlRegions = [upNodeCount, rightNodeCount, downNodeCount, leftNodeCount]; + if (startGridY > 0) { + for (var i = startGridX; i <= finishGridX; i++) { + controlRegions[0] += this.grid[i][startGridY - 1].length + this.grid[i][startGridY].length - 1; + } + } + if (finishGridX < this.grid.length - 1) { + for (var i = startGridY; i <= finishGridY; i++) { + controlRegions[1] += this.grid[finishGridX + 1][i].length + this.grid[finishGridX][i].length - 1; + } + } + if (finishGridY < this.grid[0].length - 1) { + for (var i = startGridX; i <= finishGridX; i++) { + controlRegions[2] += this.grid[i][finishGridY + 1].length + this.grid[i][finishGridY].length - 1; + } + } + if (startGridX > 0) { + for (var i = startGridY; i <= finishGridY; i++) { + controlRegions[3] += this.grid[startGridX - 1][i].length + this.grid[startGridX][i].length - 1; + } + } + var min = Integer.MAX_VALUE; + var minCount; + var minIndex; + for (var j = 0; j < controlRegions.length; j++) { + if (controlRegions[j] < min) { + min = controlRegions[j]; + minCount = 1; + minIndex = j; + } else if (controlRegions[j] == min) { + minCount++; + } + } + if (minCount == 3 && min == 0) { + if (controlRegions[0] == 0 && controlRegions[1] == 0 && controlRegions[2] == 0) { + gridForPrunedNode = 1; + } else if (controlRegions[0] == 0 && controlRegions[1] == 0 && controlRegions[3] == 0) { + gridForPrunedNode = 0; + } else if (controlRegions[0] == 0 && controlRegions[2] == 0 && controlRegions[3] == 0) { + gridForPrunedNode = 3; + } else if (controlRegions[1] == 0 && controlRegions[2] == 0 && controlRegions[3] == 0) { + gridForPrunedNode = 2; + } + } else if (minCount == 2 && min == 0) { + var random = Math.floor(Math.random() * 2); + if (controlRegions[0] == 0 && controlRegions[1] == 0) { + if (random == 0) { + gridForPrunedNode = 0; + } else { + gridForPrunedNode = 1; + } + } else if (controlRegions[0] == 0 && controlRegions[2] == 0) { + if (random == 0) { + gridForPrunedNode = 0; + } else { + gridForPrunedNode = 2; + } + } else if (controlRegions[0] == 0 && controlRegions[3] == 0) { + if (random == 0) { + gridForPrunedNode = 0; + } else { + gridForPrunedNode = 3; + } + } else if (controlRegions[1] == 0 && controlRegions[2] == 0) { + if (random == 0) { + gridForPrunedNode = 1; + } else { + gridForPrunedNode = 2; + } + } else if (controlRegions[1] == 0 && controlRegions[3] == 0) { + if (random == 0) { + gridForPrunedNode = 1; + } else { + gridForPrunedNode = 3; + } + } else { + if (random == 0) { + gridForPrunedNode = 2; + } else { + gridForPrunedNode = 3; + } + } + } else if (minCount == 4 && min == 0) { + var random = Math.floor(Math.random() * 4); + gridForPrunedNode = random; + } else { + gridForPrunedNode = minIndex; + } + if (gridForPrunedNode == 0) { + prunedNode.setCenter(nodeToConnect.getCenterX(), nodeToConnect.getCenterY() - nodeToConnect.getHeight() / 2 - FDLayoutConstants.DEFAULT_EDGE_LENGTH - prunedNode.getHeight() / 2); + } else if (gridForPrunedNode == 1) { + prunedNode.setCenter(nodeToConnect.getCenterX() + nodeToConnect.getWidth() / 2 + FDLayoutConstants.DEFAULT_EDGE_LENGTH + prunedNode.getWidth() / 2, nodeToConnect.getCenterY()); + } else if (gridForPrunedNode == 2) { + prunedNode.setCenter(nodeToConnect.getCenterX(), nodeToConnect.getCenterY() + nodeToConnect.getHeight() / 2 + FDLayoutConstants.DEFAULT_EDGE_LENGTH + prunedNode.getHeight() / 2); + } else { + prunedNode.setCenter(nodeToConnect.getCenterX() - nodeToConnect.getWidth() / 2 - FDLayoutConstants.DEFAULT_EDGE_LENGTH - prunedNode.getWidth() / 2, nodeToConnect.getCenterY()); + } + }; + module2.exports = CoSELayout; + }, + /* 7 */ + /***/ + function(module2, exports2, __webpack_require__) { + var coseBase2 = {}; + coseBase2.layoutBase = __webpack_require__(0); + coseBase2.CoSEConstants = __webpack_require__(1); + coseBase2.CoSEEdge = __webpack_require__(2); + coseBase2.CoSEGraph = __webpack_require__(3); + coseBase2.CoSEGraphManager = __webpack_require__(4); + coseBase2.CoSELayout = __webpack_require__(6); + coseBase2.CoSENode = __webpack_require__(5); + module2.exports = coseBase2; + } + /******/ + ]) + ); + }); + })(coseBase); + return coseBase.exports; +} +(function(module, exports) { + (function webpackUniversalModuleDefinition(root, factory) { + module.exports = factory(requireCoseBase()); + })(commonjsGlobal, function(__WEBPACK_EXTERNAL_MODULE_0__) { + return ( + /******/ + function(modules) { + var installedModules = {}; + function __webpack_require__(moduleId) { + if (installedModules[moduleId]) { + return installedModules[moduleId].exports; + } + var module2 = installedModules[moduleId] = { + /******/ + i: moduleId, + /******/ + l: false, + /******/ + exports: {} + /******/ + }; + modules[moduleId].call(module2.exports, module2, module2.exports, __webpack_require__); + module2.l = true; + return module2.exports; + } + __webpack_require__.m = modules; + __webpack_require__.c = installedModules; + __webpack_require__.i = function(value) { + return value; + }; + __webpack_require__.d = function(exports2, name, getter) { + if (!__webpack_require__.o(exports2, name)) { + Object.defineProperty(exports2, name, { + /******/ + configurable: false, + /******/ + enumerable: true, + /******/ + get: getter + /******/ + }); + } + }; + __webpack_require__.n = function(module2) { + var getter = module2 && module2.__esModule ? ( + /******/ + function getDefault() { + return module2["default"]; + } + ) : ( + /******/ + function getModuleExports() { + return module2; + } + ); + __webpack_require__.d(getter, "a", getter); + return getter; + }; + __webpack_require__.o = function(object, property) { + return Object.prototype.hasOwnProperty.call(object, property); + }; + __webpack_require__.p = ""; + return __webpack_require__(__webpack_require__.s = 1); + }([ + /* 0 */ + /***/ + function(module2, exports2) { + module2.exports = __WEBPACK_EXTERNAL_MODULE_0__; + }, + /* 1 */ + /***/ + function(module2, exports2, __webpack_require__) { + var LayoutConstants = __webpack_require__(0).layoutBase.LayoutConstants; + var FDLayoutConstants = __webpack_require__(0).layoutBase.FDLayoutConstants; + var CoSEConstants = __webpack_require__(0).CoSEConstants; + var CoSELayout = __webpack_require__(0).CoSELayout; + var CoSENode = __webpack_require__(0).CoSENode; + var PointD = __webpack_require__(0).layoutBase.PointD; + var DimensionD2 = __webpack_require__(0).layoutBase.DimensionD; + var defaults = { + // Called on `layoutready` + ready: function ready() { + }, + // Called on `layoutstop` + stop: function stop() { + }, + // 'draft', 'default' or 'proof" + // - 'draft' fast cooling rate + // - 'default' moderate cooling rate + // - "proof" slow cooling rate + quality: "default", + // include labels in node dimensions + nodeDimensionsIncludeLabels: false, + // number of ticks per frame; higher is faster but more jerky + refresh: 30, + // Whether to fit the network view after when done + fit: true, + // Padding on fit + padding: 10, + // Whether to enable incremental mode + randomize: true, + // Node repulsion (non overlapping) multiplier + nodeRepulsion: 4500, + // Ideal edge (non nested) length + idealEdgeLength: 50, + // Divisor to compute edge forces + edgeElasticity: 0.45, + // Nesting factor (multiplier) to compute ideal edge length for nested edges + nestingFactor: 0.1, + // Gravity force (constant) + gravity: 0.25, + // Maximum number of iterations to perform + numIter: 2500, + // For enabling tiling + tile: true, + // Type of layout animation. The option set is {'during', 'end', false} + animate: "end", + // Duration for animate:end + animationDuration: 500, + // Represents the amount of the vertical space to put between the zero degree members during the tiling operation(can also be a function) + tilingPaddingVertical: 10, + // Represents the amount of the horizontal space to put between the zero degree members during the tiling operation(can also be a function) + tilingPaddingHorizontal: 10, + // Gravity range (constant) for compounds + gravityRangeCompound: 1.5, + // Gravity force (constant) for compounds + gravityCompound: 1, + // Gravity range (constant) + gravityRange: 3.8, + // Initial cooling factor for incremental layout + initialEnergyOnIncremental: 0.5 + }; + function extend(defaults2, options) { + var obj = {}; + for (var i in defaults2) { + obj[i] = defaults2[i]; + } + for (var i in options) { + obj[i] = options[i]; + } + return obj; + } + function _CoSELayout(_options) { + this.options = extend(defaults, _options); + getUserOptions(this.options); + } + var getUserOptions = function getUserOptions2(options) { + if (options.nodeRepulsion != null) + CoSEConstants.DEFAULT_REPULSION_STRENGTH = FDLayoutConstants.DEFAULT_REPULSION_STRENGTH = options.nodeRepulsion; + if (options.idealEdgeLength != null) + CoSEConstants.DEFAULT_EDGE_LENGTH = FDLayoutConstants.DEFAULT_EDGE_LENGTH = options.idealEdgeLength; + if (options.edgeElasticity != null) + CoSEConstants.DEFAULT_SPRING_STRENGTH = FDLayoutConstants.DEFAULT_SPRING_STRENGTH = options.edgeElasticity; + if (options.nestingFactor != null) + CoSEConstants.PER_LEVEL_IDEAL_EDGE_LENGTH_FACTOR = FDLayoutConstants.PER_LEVEL_IDEAL_EDGE_LENGTH_FACTOR = options.nestingFactor; + if (options.gravity != null) + CoSEConstants.DEFAULT_GRAVITY_STRENGTH = FDLayoutConstants.DEFAULT_GRAVITY_STRENGTH = options.gravity; + if (options.numIter != null) + CoSEConstants.MAX_ITERATIONS = FDLayoutConstants.MAX_ITERATIONS = options.numIter; + if (options.gravityRange != null) + CoSEConstants.DEFAULT_GRAVITY_RANGE_FACTOR = FDLayoutConstants.DEFAULT_GRAVITY_RANGE_FACTOR = options.gravityRange; + if (options.gravityCompound != null) + CoSEConstants.DEFAULT_COMPOUND_GRAVITY_STRENGTH = FDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_STRENGTH = options.gravityCompound; + if (options.gravityRangeCompound != null) + CoSEConstants.DEFAULT_COMPOUND_GRAVITY_RANGE_FACTOR = FDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_RANGE_FACTOR = options.gravityRangeCompound; + if (options.initialEnergyOnIncremental != null) + CoSEConstants.DEFAULT_COOLING_FACTOR_INCREMENTAL = FDLayoutConstants.DEFAULT_COOLING_FACTOR_INCREMENTAL = options.initialEnergyOnIncremental; + if (options.quality == "draft") + LayoutConstants.QUALITY = 0; + else if (options.quality == "proof") + LayoutConstants.QUALITY = 2; + else + LayoutConstants.QUALITY = 1; + CoSEConstants.NODE_DIMENSIONS_INCLUDE_LABELS = FDLayoutConstants.NODE_DIMENSIONS_INCLUDE_LABELS = LayoutConstants.NODE_DIMENSIONS_INCLUDE_LABELS = options.nodeDimensionsIncludeLabels; + CoSEConstants.DEFAULT_INCREMENTAL = FDLayoutConstants.DEFAULT_INCREMENTAL = LayoutConstants.DEFAULT_INCREMENTAL = !options.randomize; + CoSEConstants.ANIMATE = FDLayoutConstants.ANIMATE = LayoutConstants.ANIMATE = options.animate; + CoSEConstants.TILE = options.tile; + CoSEConstants.TILING_PADDING_VERTICAL = typeof options.tilingPaddingVertical === "function" ? options.tilingPaddingVertical.call() : options.tilingPaddingVertical; + CoSEConstants.TILING_PADDING_HORIZONTAL = typeof options.tilingPaddingHorizontal === "function" ? options.tilingPaddingHorizontal.call() : options.tilingPaddingHorizontal; + }; + _CoSELayout.prototype.run = function() { + var ready; + var frameId; + var options = this.options; + this.idToLNode = {}; + var layout = this.layout = new CoSELayout(); + var self2 = this; + self2.stopped = false; + this.cy = this.options.cy; + this.cy.trigger({ type: "layoutstart", layout: this }); + var gm = layout.newGraphManager(); + this.gm = gm; + var nodes2 = this.options.eles.nodes(); + var edges = this.options.eles.edges(); + this.root = gm.addRoot(); + this.processChildrenList(this.root, this.getTopMostNodes(nodes2), layout); + for (var i = 0; i < edges.length; i++) { + var edge = edges[i]; + var sourceNode = this.idToLNode[edge.data("source")]; + var targetNode = this.idToLNode[edge.data("target")]; + if (sourceNode !== targetNode && sourceNode.getEdgesBetween(targetNode).length == 0) { + var e1 = gm.add(layout.newEdge(), sourceNode, targetNode); + e1.id = edge.id(); + } + } + var getPositions = function getPositions2(ele, i2) { + if (typeof ele === "number") { + ele = i2; + } + var theId = ele.data("id"); + var lNode = self2.idToLNode[theId]; + return { + x: lNode.getRect().getCenterX(), + y: lNode.getRect().getCenterY() + }; + }; + var iterateAnimated = function iterateAnimated2() { + var afterReposition = function afterReposition2() { + if (options.fit) { + options.cy.fit(options.eles, options.padding); + } + if (!ready) { + ready = true; + self2.cy.one("layoutready", options.ready); + self2.cy.trigger({ type: "layoutready", layout: self2 }); + } + }; + var ticksPerFrame = self2.options.refresh; + var isDone; + for (var i2 = 0; i2 < ticksPerFrame && !isDone; i2++) { + isDone = self2.stopped || self2.layout.tick(); + } + if (isDone) { + if (layout.checkLayoutSuccess() && !layout.isSubLayout) { + layout.doPostLayout(); + } + if (layout.tilingPostLayout) { + layout.tilingPostLayout(); + } + layout.isLayoutFinished = true; + self2.options.eles.nodes().positions(getPositions); + afterReposition(); + self2.cy.one("layoutstop", self2.options.stop); + self2.cy.trigger({ type: "layoutstop", layout: self2 }); + if (frameId) { + cancelAnimationFrame(frameId); + } + ready = false; + return; + } + var animationData = self2.layout.getPositionsData(); + options.eles.nodes().positions(function(ele, i3) { + if (typeof ele === "number") { + ele = i3; + } + if (!ele.isParent()) { + var theId = ele.id(); + var pNode = animationData[theId]; + var temp = ele; + while (pNode == null) { + pNode = animationData[temp.data("parent")] || animationData["DummyCompound_" + temp.data("parent")]; + animationData[theId] = pNode; + temp = temp.parent()[0]; + if (temp == void 0) { + break; + } + } + if (pNode != null) { + return { + x: pNode.x, + y: pNode.y + }; + } else { + return { + x: ele.position("x"), + y: ele.position("y") + }; + } + } + }); + afterReposition(); + frameId = requestAnimationFrame(iterateAnimated2); + }; + layout.addListener("layoutstarted", function() { + if (self2.options.animate === "during") { + frameId = requestAnimationFrame(iterateAnimated); + } + }); + layout.runLayout(); + if (this.options.animate !== "during") { + self2.options.eles.nodes().not(":parent").layoutPositions(self2, self2.options, getPositions); + ready = false; + } + return this; + }; + _CoSELayout.prototype.getTopMostNodes = function(nodes2) { + var nodesMap = {}; + for (var i = 0; i < nodes2.length; i++) { + nodesMap[nodes2[i].id()] = true; + } + var roots = nodes2.filter(function(ele, i2) { + if (typeof ele === "number") { + ele = i2; + } + var parent = ele.parent()[0]; + while (parent != null) { + if (nodesMap[parent.id()]) { + return false; + } + parent = parent.parent()[0]; + } + return true; + }); + return roots; + }; + _CoSELayout.prototype.processChildrenList = function(parent, children, layout) { + var size = children.length; + for (var i = 0; i < size; i++) { + var theChild = children[i]; + var children_of_children = theChild.children(); + var theNode; + var dimensions = theChild.layoutDimensions({ + nodeDimensionsIncludeLabels: this.options.nodeDimensionsIncludeLabels + }); + if (theChild.outerWidth() != null && theChild.outerHeight() != null) { + theNode = parent.add(new CoSENode(layout.graphManager, new PointD(theChild.position("x") - dimensions.w / 2, theChild.position("y") - dimensions.h / 2), new DimensionD2(parseFloat(dimensions.w), parseFloat(dimensions.h)))); + } else { + theNode = parent.add(new CoSENode(this.graphManager)); + } + theNode.id = theChild.data("id"); + theNode.paddingLeft = parseInt(theChild.css("padding")); + theNode.paddingTop = parseInt(theChild.css("padding")); + theNode.paddingRight = parseInt(theChild.css("padding")); + theNode.paddingBottom = parseInt(theChild.css("padding")); + if (this.options.nodeDimensionsIncludeLabels) { + if (theChild.isParent()) { + var labelWidth = theChild.boundingBox({ includeLabels: true, includeNodes: false }).w; + var labelHeight = theChild.boundingBox({ includeLabels: true, includeNodes: false }).h; + var labelPos = theChild.css("text-halign"); + theNode.labelWidth = labelWidth; + theNode.labelHeight = labelHeight; + theNode.labelPos = labelPos; + } + } + this.idToLNode[theChild.data("id")] = theNode; + if (isNaN(theNode.rect.x)) { + theNode.rect.x = 0; + } + if (isNaN(theNode.rect.y)) { + theNode.rect.y = 0; + } + if (children_of_children != null && children_of_children.length > 0) { + var theNewGraph; + theNewGraph = layout.getGraphManager().add(layout.newGraph(), theNode); + this.processChildrenList(theNewGraph, children_of_children, layout); + } + } + }; + _CoSELayout.prototype.stop = function() { + this.stopped = true; + return this; + }; + var register = function register2(cytoscape2) { + cytoscape2("layout", "cose-bilkent", _CoSELayout); + }; + if (typeof cytoscape !== "undefined") { + register(cytoscape); + } + module2.exports = register; + } + /******/ + ]) + ); + }); +})(cytoscapeCoseBilkent); +var cytoscapeCoseBilkentExports = cytoscapeCoseBilkent.exports; +const coseBilkent = /* @__PURE__ */ getDefaultExportFromCjs(cytoscapeCoseBilkentExports); +const MAX_SECTIONS = 12; +const defaultBkg = function(db2, elem, node, section) { + const rd = 5; + elem.append("path").attr("id", "node-" + node.id).attr("class", "node-bkg node-" + db2.type2Str(node.type)).attr( + "d", + `M0 ${node.height - rd} v${-node.height + 2 * rd} q0,-5 5,-5 h${node.width - 2 * rd} q5,0 5,5 v${node.height - rd} H0 Z` + ); + elem.append("line").attr("class", "node-line-" + section).attr("x1", 0).attr("y1", node.height).attr("x2", node.width).attr("y2", node.height); +}; +const rectBkg = function(db2, elem, node) { + elem.append("rect").attr("id", "node-" + node.id).attr("class", "node-bkg node-" + db2.type2Str(node.type)).attr("height", node.height).attr("width", node.width); +}; +const cloudBkg = function(db2, elem, node) { + const w = node.width; + const h = node.height; + const r1 = 0.15 * w; + const r2 = 0.25 * w; + const r3 = 0.35 * w; + const r4 = 0.2 * w; + elem.append("path").attr("id", "node-" + node.id).attr("class", "node-bkg node-" + db2.type2Str(node.type)).attr( + "d", + `M0 0 a${r1},${r1} 0 0,1 ${w * 0.25},${-1 * w * 0.1} + a${r3},${r3} 1 0,1 ${w * 0.4},${-1 * w * 0.1} + a${r2},${r2} 1 0,1 ${w * 0.35},${1 * w * 0.2} + + a${r1},${r1} 1 0,1 ${w * 0.15},${1 * h * 0.35} + a${r4},${r4} 1 0,1 ${-1 * w * 0.15},${1 * h * 0.65} + + a${r2},${r1} 1 0,1 ${-1 * w * 0.25},${w * 0.15} + a${r3},${r3} 1 0,1 ${-1 * w * 0.5},${0} + a${r1},${r1} 1 0,1 ${-1 * w * 0.25},${-1 * w * 0.15} + + a${r1},${r1} 1 0,1 ${-1 * w * 0.1},${-1 * h * 0.35} + a${r4},${r4} 1 0,1 ${w * 0.1},${-1 * h * 0.65} + + H0 V0 Z` + ); +}; +const bangBkg = function(db2, elem, node) { + const w = node.width; + const h = node.height; + const r = 0.15 * w; + elem.append("path").attr("id", "node-" + node.id).attr("class", "node-bkg node-" + db2.type2Str(node.type)).attr( + "d", + `M0 0 a${r},${r} 1 0,0 ${w * 0.25},${-1 * h * 0.1} + a${r},${r} 1 0,0 ${w * 0.25},${0} + a${r},${r} 1 0,0 ${w * 0.25},${0} + a${r},${r} 1 0,0 ${w * 0.25},${1 * h * 0.1} + + a${r},${r} 1 0,0 ${w * 0.15},${1 * h * 0.33} + a${r * 0.8},${r * 0.8} 1 0,0 ${0},${1 * h * 0.34} + a${r},${r} 1 0,0 ${-1 * w * 0.15},${1 * h * 0.33} + + a${r},${r} 1 0,0 ${-1 * w * 0.25},${h * 0.15} + a${r},${r} 1 0,0 ${-1 * w * 0.25},${0} + a${r},${r} 1 0,0 ${-1 * w * 0.25},${0} + a${r},${r} 1 0,0 ${-1 * w * 0.25},${-1 * h * 0.15} + + a${r},${r} 1 0,0 ${-1 * w * 0.1},${-1 * h * 0.33} + a${r * 0.8},${r * 0.8} 1 0,0 ${0},${-1 * h * 0.34} + a${r},${r} 1 0,0 ${w * 0.1},${-1 * h * 0.33} + + H0 V0 Z` + ); +}; +const circleBkg = function(db2, elem, node) { + elem.append("circle").attr("id", "node-" + node.id).attr("class", "node-bkg node-" + db2.type2Str(node.type)).attr("r", node.width / 2); +}; +function insertPolygonShape(parent, w, h, points, node) { + return parent.insert("polygon", ":first-child").attr( + "points", + points.map(function(d) { + return d.x + "," + d.y; + }).join(" ") + ).attr("transform", "translate(" + (node.width - w) / 2 + ", " + h + ")"); +} +const hexagonBkg = function(_db, elem, node) { + const h = node.height; + const f = 4; + const m = h / f; + const w = node.width - node.padding + 2 * m; + const points = [ + { x: m, y: 0 }, + { x: w - m, y: 0 }, + { x: w, y: -h / 2 }, + { x: w - m, y: -h }, + { x: m, y: -h }, + { x: 0, y: -h / 2 } + ]; + insertPolygonShape(elem, w, h, points, node); +}; +const roundedRectBkg = function(db2, elem, node) { + elem.append("rect").attr("id", "node-" + node.id).attr("class", "node-bkg node-" + db2.type2Str(node.type)).attr("height", node.height).attr("rx", node.padding).attr("ry", node.padding).attr("width", node.width); +}; +const drawNode = function(db2, elem, node, fullSection, conf) { + const htmlLabels = conf.htmlLabels; + const section = fullSection % (MAX_SECTIONS - 1); + const nodeElem = elem.append("g"); + node.section = section; + let sectionClass = "section-" + section; + if (section < 0) { + sectionClass += " section-root"; + } + nodeElem.attr("class", (node.class ? node.class + " " : "") + "mindmap-node " + sectionClass); + const bkgElem = nodeElem.append("g"); + const textElem = nodeElem.append("g"); + const description = node.descr.replace(/()/g, "\n"); + createText(textElem, description, { + useHtmlLabels: htmlLabels, + width: node.width, + classes: "mindmap-node-label" + }); + if (!htmlLabels) { + textElem.attr("dy", "1em").attr("alignment-baseline", "middle").attr("dominant-baseline", "middle").attr("text-anchor", "middle"); + } + const bbox = textElem.node().getBBox(); + const [fontSize] = parseFontSize(conf.fontSize); + node.height = bbox.height + fontSize * 1.1 * 0.5 + node.padding; + node.width = bbox.width + 2 * node.padding; + if (node.icon) { + if (node.type === db2.nodeType.CIRCLE) { + node.height += 50; + node.width += 50; + const icon = nodeElem.append("foreignObject").attr("height", "50px").attr("width", node.width).attr("style", "text-align: center;"); + icon.append("div").attr("class", "icon-container").append("i").attr("class", "node-icon-" + section + " " + node.icon); + textElem.attr( + "transform", + "translate(" + node.width / 2 + ", " + (node.height / 2 - 1.5 * node.padding) + ")" + ); + } else { + node.width += 50; + const orgHeight = node.height; + node.height = Math.max(orgHeight, 60); + const heightDiff = Math.abs(node.height - orgHeight); + const icon = nodeElem.append("foreignObject").attr("width", "60px").attr("height", node.height).attr("style", "text-align: center;margin-top:" + heightDiff / 2 + "px;"); + icon.append("div").attr("class", "icon-container").append("i").attr("class", "node-icon-" + section + " " + node.icon); + textElem.attr( + "transform", + "translate(" + (25 + node.width / 2) + ", " + (heightDiff / 2 + node.padding / 2) + ")" + ); + } + } else { + if (!htmlLabels) { + const dx = node.width / 2; + const dy = node.padding / 2; + textElem.attr("transform", "translate(" + dx + ", " + dy + ")"); + } else { + const dx = (node.width - bbox.width) / 2; + const dy = (node.height - bbox.height) / 2; + textElem.attr("transform", "translate(" + dx + ", " + dy + ")"); + } + } + switch (node.type) { + case db2.nodeType.DEFAULT: + defaultBkg(db2, bkgElem, node, section); + break; + case db2.nodeType.ROUNDED_RECT: + roundedRectBkg(db2, bkgElem, node); + break; + case db2.nodeType.RECT: + rectBkg(db2, bkgElem, node); + break; + case db2.nodeType.CIRCLE: + bkgElem.attr("transform", "translate(" + node.width / 2 + ", " + +node.height / 2 + ")"); + circleBkg(db2, bkgElem, node); + break; + case db2.nodeType.CLOUD: + cloudBkg(db2, bkgElem, node); + break; + case db2.nodeType.BANG: + bangBkg(db2, bkgElem, node); + break; + case db2.nodeType.HEXAGON: + hexagonBkg(db2, bkgElem, node); + break; + } + db2.setElementForId(node.id, nodeElem); + return node.height; +}; +const positionNode = function(db2, node) { + const nodeElem = db2.getElementById(node.id); + const x = node.x || 0; + const y = node.y || 0; + nodeElem.attr("transform", "translate(" + x + "," + y + ")"); +}; +cytoscape$1.use(coseBilkent); +function drawNodes(db2, svg, mindmap, section, conf) { + drawNode(db2, svg, mindmap, section, conf); + if (mindmap.children) { + mindmap.children.forEach((child, index) => { + drawNodes(db2, svg, child, section < 0 ? index : section, conf); + }); + } +} +function drawEdges(edgesEl, cy) { + cy.edges().map((edge, id) => { + const data = edge.data(); + if (edge[0]._private.bodyBounds) { + const bounds = edge[0]._private.rscratch; + log.trace("Edge: ", id, data); + edgesEl.insert("path").attr( + "d", + `M ${bounds.startX},${bounds.startY} L ${bounds.midX},${bounds.midY} L${bounds.endX},${bounds.endY} ` + ).attr("class", "edge section-edge-" + data.section + " edge-depth-" + data.depth); + } + }); +} +function addNodes(mindmap, cy, conf, level) { + cy.add({ + group: "nodes", + data: { + id: mindmap.id.toString(), + labelText: mindmap.descr, + height: mindmap.height, + width: mindmap.width, + level, + nodeId: mindmap.id, + padding: mindmap.padding, + type: mindmap.type + }, + position: { + x: mindmap.x, + y: mindmap.y + } + }); + if (mindmap.children) { + mindmap.children.forEach((child) => { + addNodes(child, cy, conf, level + 1); + cy.add({ + group: "edges", + data: { + id: `${mindmap.id}_${child.id}`, + source: mindmap.id, + target: child.id, + depth: level, + section: child.section + } + }); + }); + } +} +function layoutMindmap(node, conf) { + return new Promise((resolve) => { + const renderEl = d3select("body").append("div").attr("id", "cy").attr("style", "display:none"); + const cy = cytoscape$1({ + container: document.getElementById("cy"), + // container to render in + style: [ + { + selector: "edge", + style: { + "curve-style": "bezier" + } + } + ] + }); + renderEl.remove(); + addNodes(node, cy, conf, 0); + cy.nodes().forEach(function(n) { + n.layoutDimensions = () => { + const data = n.data(); + return { w: data.width, h: data.height }; + }; + }); + cy.layout({ + name: "cose-bilkent", + // @ts-ignore Types for cose-bilkent are not correct? + quality: "proof", + styleEnabled: false, + animate: false + }).run(); + cy.ready((e) => { + log.info("Ready", e); + resolve(cy); + }); + }); +} +function positionNodes(db2, cy) { + cy.nodes().map((node, id) => { + const data = node.data(); + data.x = node.position().x; + data.y = node.position().y; + positionNode(db2, data); + const el = db2.getElementById(data.nodeId); + log.info("Id:", id, "Position: (", node.position().x, ", ", node.position().y, ")", data); + el.attr( + "transform", + `translate(${node.position().x - data.width / 2}, ${node.position().y - data.height / 2})` + ); + el.attr("attr", `apa-${id})`); + }); +} +const draw = async (text, id, _version, diagObj) => { + var _a, _b; + log.debug("Rendering mindmap diagram\n" + text); + const db2 = diagObj.db; + const mm = db2.getMindmap(); + if (!mm) { + return; + } + const conf = getConfig(); + conf.htmlLabels = false; + const svg = selectSvgElement(id); + const edgesElem = svg.append("g"); + edgesElem.attr("class", "mindmap-edges"); + const nodesElem = svg.append("g"); + nodesElem.attr("class", "mindmap-nodes"); + drawNodes(db2, nodesElem, mm, -1, conf); + const cy = await layoutMindmap(mm, conf); + drawEdges(edgesElem, cy); + positionNodes(db2, cy); + setupGraphViewbox( + void 0, + svg, + ((_a = conf.mindmap) == null ? void 0 : _a.padding) ?? defaultConfig.mindmap.padding, + ((_b = conf.mindmap) == null ? void 0 : _b.useMaxWidth) ?? defaultConfig.mindmap.useMaxWidth + ); +}; +const renderer = { + draw +}; +const genSections = (options) => { + let sections = ""; + for (let i = 0; i < options.THEME_COLOR_LIMIT; i++) { + options["lineColor" + i] = options["lineColor" + i] || options["cScaleInv" + i]; + if (isDark(options["lineColor" + i])) { + options["lineColor" + i] = lighten(options["lineColor" + i], 20); + } else { + options["lineColor" + i] = darken(options["lineColor" + i], 20); + } + } + for (let i = 0; i < options.THEME_COLOR_LIMIT; i++) { + const sw = "" + (17 - 3 * i); + sections += ` + .section-${i - 1} rect, .section-${i - 1} path, .section-${i - 1} circle, .section-${i - 1} polygon, .section-${i - 1} path { + fill: ${options["cScale" + i]}; + } + .section-${i - 1} text { + fill: ${options["cScaleLabel" + i]}; + } + .node-icon-${i - 1} { + font-size: 40px; + color: ${options["cScaleLabel" + i]}; + } + .section-edge-${i - 1}{ + stroke: ${options["cScale" + i]}; + } + .edge-depth-${i - 1}{ + stroke-width: ${sw}; + } + .section-${i - 1} line { + stroke: ${options["cScaleInv" + i]} ; + stroke-width: 3; + } + + .disabled, .disabled circle, .disabled text { + fill: lightgray; + } + .disabled text { + fill: #efefef; + } + `; + } + return sections; +}; +const getStyles = (options) => ` + .edge { + stroke-width: 3; + } + ${genSections(options)} + .section-root rect, .section-root path, .section-root circle, .section-root polygon { + fill: ${options.git0}; + } + .section-root text { + fill: ${options.gitBranchLabel0}; + } + .icon-container { + height:100%; + display: flex; + justify-content: center; + align-items: center; + } + .edge { + fill: none; + } + .mindmap-node-label { + dy: 1em; + alignment-baseline: middle; + text-anchor: middle; + dominant-baseline: middle; + text-align: center; + } +`; +const styles = getStyles; +const diagram = { + db: db$1, + renderer, + parser: parser$1, + styles +}; +export { + diagram +}; diff --git a/0.6.0/js/mermaid/mindmap-definition-9399c7e6.js b/0.6.0/js/mermaid/mindmap-definition-9399c7e6.js new file mode 100644 index 0000000..e435604 --- /dev/null +++ b/0.6.0/js/mermaid/mindmap-definition-9399c7e6.js @@ -0,0 +1,18760 @@ +import { l as qr, c as Ji, W as ti, d as ri, P as Ca, Q as $l, Y as pp, U as yp, t as mp, j as bp, at as Ep, au as wp, av as xp } from "./mermaid-9f2aa176.js"; +import { a as Tp } from "./createText-03b82060.js"; +var Qi = function() { + var de = function(ee, H, te, S) { + for (te = te || {}, S = ee.length; S--; te[ee[S]] = H) + ; + return te; + }, Pe = [1, 4], _ = [1, 13], fe = [1, 12], Q = [1, 15], C = [1, 16], T = [1, 20], x = [1, 19], I = [6, 7, 8], z = [1, 26], Y = [1, 24], P = [1, 25], Z = [6, 7, 11], A = [1, 6, 13, 15, 16, 19, 22], $ = [1, 33], U = [1, 34], J = [1, 6, 7, 11, 13, 15, 16, 19, 22], ne = { + trace: function() { + }, + yy: {}, + symbols_: { error: 2, start: 3, mindMap: 4, spaceLines: 5, SPACELINE: 6, NL: 7, MINDMAP: 8, document: 9, stop: 10, EOF: 11, statement: 12, SPACELIST: 13, node: 14, ICON: 15, CLASS: 16, nodeWithId: 17, nodeWithoutId: 18, NODE_DSTART: 19, NODE_DESCR: 20, NODE_DEND: 21, NODE_ID: 22, $accept: 0, $end: 1 }, + terminals_: { 2: "error", 6: "SPACELINE", 7: "NL", 8: "MINDMAP", 11: "EOF", 13: "SPACELIST", 15: "ICON", 16: "CLASS", 19: "NODE_DSTART", 20: "NODE_DESCR", 21: "NODE_DEND", 22: "NODE_ID" }, + productions_: [0, [3, 1], [3, 2], [5, 1], [5, 2], [5, 2], [4, 2], [4, 3], [10, 1], [10, 1], [10, 1], [10, 2], [10, 2], [9, 3], [9, 2], [12, 2], [12, 2], [12, 2], [12, 1], [12, 1], [12, 1], [12, 1], [12, 1], [14, 1], [14, 1], [18, 3], [17, 1], [17, 4]], + performAction: function(H, te, S, V, R, q, ve) { + var pe = q.length - 1; + switch (R) { + case 6: + case 7: + return V; + case 8: + V.getLogger().trace("Stop NL "); + break; + case 9: + V.getLogger().trace("Stop EOF "); + break; + case 11: + V.getLogger().trace("Stop NL2 "); + break; + case 12: + V.getLogger().trace("Stop EOF2 "); + break; + case 15: + V.getLogger().info("Node: ", q[pe].id), V.addNode(q[pe - 1].length, q[pe].id, q[pe].descr, q[pe].type); + break; + case 16: + V.getLogger().trace("Icon: ", q[pe]), V.decorateNode({ icon: q[pe] }); + break; + case 17: + case 21: + V.decorateNode({ class: q[pe] }); + break; + case 18: + V.getLogger().trace("SPACELIST"); + break; + case 19: + V.getLogger().trace("Node: ", q[pe].id), V.addNode(0, q[pe].id, q[pe].descr, q[pe].type); + break; + case 20: + V.decorateNode({ icon: q[pe] }); + break; + case 25: + V.getLogger().trace("node found ..", q[pe - 2]), this.$ = { id: q[pe - 1], descr: q[pe - 1], type: V.getType(q[pe - 2], q[pe]) }; + break; + case 26: + this.$ = { id: q[pe], descr: q[pe], type: V.nodeType.DEFAULT }; + break; + case 27: + V.getLogger().trace("node found ..", q[pe - 3]), this.$ = { id: q[pe - 3], descr: q[pe - 1], type: V.getType(q[pe - 2], q[pe]) }; + break; + } + }, + table: [{ 3: 1, 4: 2, 5: 3, 6: [1, 5], 8: Pe }, { 1: [3] }, { 1: [2, 1] }, { 4: 6, 6: [1, 7], 7: [1, 8], 8: Pe }, { 6: _, 7: [1, 10], 9: 9, 12: 11, 13: fe, 14: 14, 15: Q, 16: C, 17: 17, 18: 18, 19: T, 22: x }, de(I, [2, 3]), { 1: [2, 2] }, de(I, [2, 4]), de(I, [2, 5]), { 1: [2, 6], 6: _, 12: 21, 13: fe, 14: 14, 15: Q, 16: C, 17: 17, 18: 18, 19: T, 22: x }, { 6: _, 9: 22, 12: 11, 13: fe, 14: 14, 15: Q, 16: C, 17: 17, 18: 18, 19: T, 22: x }, { 6: z, 7: Y, 10: 23, 11: P }, de(Z, [2, 22], { 17: 17, 18: 18, 14: 27, 15: [1, 28], 16: [1, 29], 19: T, 22: x }), de(Z, [2, 18]), de(Z, [2, 19]), de(Z, [2, 20]), de(Z, [2, 21]), de(Z, [2, 23]), de(Z, [2, 24]), de(Z, [2, 26], { 19: [1, 30] }), { 20: [1, 31] }, { 6: z, 7: Y, 10: 32, 11: P }, { 1: [2, 7], 6: _, 12: 21, 13: fe, 14: 14, 15: Q, 16: C, 17: 17, 18: 18, 19: T, 22: x }, de(A, [2, 14], { 7: $, 11: U }), de(J, [2, 8]), de(J, [2, 9]), de(J, [2, 10]), de(Z, [2, 15]), de(Z, [2, 16]), de(Z, [2, 17]), { 20: [1, 35] }, { 21: [1, 36] }, de(A, [2, 13], { 7: $, 11: U }), de(J, [2, 11]), de(J, [2, 12]), { 21: [1, 37] }, de(Z, [2, 25]), de(Z, [2, 27])], + defaultActions: { 2: [2, 1], 6: [2, 2] }, + parseError: function(H, te) { + if (te.recoverable) + this.trace(H); + else { + var S = new Error(H); + throw S.hash = te, S; + } + }, + parse: function(H) { + var te = this, S = [0], V = [], R = [null], q = [], ve = this.table, pe = "", Ae = 0, Ne = 0, Ye = 2, at = 1, dt = q.slice.call(arguments, 1), Re = Object.create(this.lexer), Ve = { yy: {} }; + for (var Ze in this.yy) + Object.prototype.hasOwnProperty.call(this.yy, Ze) && (Ve.yy[Ze] = this.yy[Ze]); + Re.setInput(H, Ve.yy), Ve.yy.lexer = Re, Ve.yy.parser = this, typeof Re.yylloc > "u" && (Re.yylloc = {}); + var nt = Re.yylloc; + q.push(nt); + var ht = Re.options && Re.options.ranges; + typeof Ve.yy.parseError == "function" ? this.parseError = Ve.yy.parseError : this.parseError = Object.getPrototypeOf(this).parseError; + function it() { + var jt; + return jt = V.pop() || Re.lex() || at, typeof jt != "number" && (jt instanceof Array && (V = jt, jt = V.pop()), jt = te.symbols_[jt] || jt), jt; + } + for (var tt, yt, Et, Pt, gt = {}, dr, qt, nn, Kr; ; ) { + if (yt = S[S.length - 1], this.defaultActions[yt] ? Et = this.defaultActions[yt] : ((tt === null || typeof tt > "u") && (tt = it()), Et = ve[yt] && ve[yt][tt]), typeof Et > "u" || !Et.length || !Et[0]) { + var Da = ""; + Kr = []; + for (dr in ve[yt]) + this.terminals_[dr] && dr > Ye && Kr.push("'" + this.terminals_[dr] + "'"); + Re.showPosition ? Da = "Parse error on line " + (Ae + 1) + `: +` + Re.showPosition() + ` +Expecting ` + Kr.join(", ") + ", got '" + (this.terminals_[tt] || tt) + "'" : Da = "Parse error on line " + (Ae + 1) + ": Unexpected " + (tt == at ? "end of input" : "'" + (this.terminals_[tt] || tt) + "'"), this.parseError(Da, { + text: Re.match, + token: this.terminals_[tt] || tt, + line: Re.yylineno, + loc: nt, + expected: Kr + }); + } + if (Et[0] instanceof Array && Et.length > 1) + throw new Error("Parse Error: multiple actions possible at state: " + yt + ", token: " + tt); + switch (Et[0]) { + case 1: + S.push(tt), R.push(Re.yytext), q.push(Re.yylloc), S.push(Et[1]), tt = null, Ne = Re.yyleng, pe = Re.yytext, Ae = Re.yylineno, nt = Re.yylloc; + break; + case 2: + if (qt = this.productions_[Et[1]][1], gt.$ = R[R.length - qt], gt._$ = { + first_line: q[q.length - (qt || 1)].first_line, + last_line: q[q.length - 1].last_line, + first_column: q[q.length - (qt || 1)].first_column, + last_column: q[q.length - 1].last_column + }, ht && (gt._$.range = [ + q[q.length - (qt || 1)].range[0], + q[q.length - 1].range[1] + ]), Pt = this.performAction.apply(gt, [ + pe, + Ne, + Ae, + Ve.yy, + Et[1], + R, + q + ].concat(dt)), typeof Pt < "u") + return Pt; + qt && (S = S.slice(0, -1 * qt * 2), R = R.slice(0, -1 * qt), q = q.slice(0, -1 * qt)), S.push(this.productions_[Et[1]][0]), R.push(gt.$), q.push(gt._$), nn = ve[S[S.length - 2]][S[S.length - 1]], S.push(nn); + break; + case 3: + return !0; + } + } + return !0; + } + }, le = function() { + var ee = { + EOF: 1, + parseError: function(te, S) { + if (this.yy.parser) + this.yy.parser.parseError(te, S); + else + throw new Error(te); + }, + // resets the lexer, sets new input + setInput: function(H, te) { + return this.yy = te || this.yy || {}, this._input = H, 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 H = this._input[0]; + this.yytext += H, this.yyleng++, this.offset++, this.match += H, this.matched += H; + var te = H.match(/(?:\r\n?|\n).*/g); + return te ? (this.yylineno++, this.yylloc.last_line++) : this.yylloc.last_column++, this.options.ranges && this.yylloc.range[1]++, this._input = this._input.slice(1), H; + }, + // unshifts one char (or a string) into the input + unput: function(H) { + var te = H.length, S = H.split(/(?:\r\n?|\n)/g); + this._input = H + this._input, this.yytext = this.yytext.substr(0, this.yytext.length - te), this.offset -= te; + var V = 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), S.length - 1 && (this.yylineno -= S.length - 1); + var R = 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: S ? (S.length === V.length ? this.yylloc.first_column : 0) + V[V.length - S.length].length - S[0].length : this.yylloc.first_column - te + }, this.options.ranges && (this.yylloc.range = [R[0], R[0] + this.yyleng - te]), 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(H) { + this.unput(this.match.slice(H)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var H = this.matched.substr(0, this.matched.length - this.match.length); + return (H.length > 20 ? "..." : "") + H.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var H = this.match; + return H.length < 20 && (H += this._input.substr(0, 20 - H.length)), (H.substr(0, 20) + (H.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var H = this.pastInput(), te = new Array(H.length + 1).join("-"); + return H + this.upcomingInput() + ` +` + te + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(H, te) { + var S, V, R; + if (this.options.backtrack_lexer && (R = { + 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 && (R.yylloc.range = this.yylloc.range.slice(0))), V = H[0].match(/(?:\r\n?|\n).*/g), V && (this.yylineno += V.length), this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: V ? V[V.length - 1].length - V[V.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + H[0].length + }, this.yytext += H[0], this.match += H[0], this.matches = H, 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(H[0].length), this.matched += H[0], S = this.performAction.call(this, this.yy, this, te, this.conditionStack[this.conditionStack.length - 1]), this.done && this._input && (this.done = !1), S) + return S; + if (this._backtrack) { + for (var q in R) + this[q] = R[q]; + return !1; + } + return !1; + }, + // return next match in input + next: function() { + if (this.done) + return this.EOF; + this._input || (this.done = !0); + var H, te, S, V; + this._more || (this.yytext = "", this.match = ""); + for (var R = this._currentRules(), q = 0; q < R.length; q++) + if (S = this._input.match(this.rules[R[q]]), S && (!te || S[0].length > te[0].length)) { + if (te = S, V = q, this.options.backtrack_lexer) { + if (H = this.test_match(S, R[q]), H !== !1) + return H; + if (this._backtrack) { + te = !1; + continue; + } else + return !1; + } else if (!this.options.flex) + break; + } + return te ? (H = this.test_match(te, R[V]), H !== !1 ? H : !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 te = this.next(); + return te || this.lex(); + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function(te) { + this.conditionStack.push(te); + }, + // pop the previously active lexer condition state off the condition stack + popState: function() { + var te = this.conditionStack.length - 1; + return te > 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(te) { + return te = this.conditionStack.length - 1 - Math.abs(te || 0), te >= 0 ? this.conditionStack[te] : "INITIAL"; + }, + // alias for begin(condition) + pushState: function(te) { + this.begin(te); + }, + // return the number of states currently on the stack + stateStackSize: function() { + return this.conditionStack.length; + }, + options: { "case-insensitive": !0 }, + performAction: function(te, S, V, R) { + switch (V) { + case 0: + return te.getLogger().trace("Found comment", S.yytext), 6; + case 1: + return 8; + case 2: + this.begin("CLASS"); + break; + case 3: + return this.popState(), 16; + case 4: + this.popState(); + break; + case 5: + te.getLogger().trace("Begin icon"), this.begin("ICON"); + break; + case 6: + return te.getLogger().trace("SPACELINE"), 6; + case 7: + return 7; + case 8: + return 15; + case 9: + te.getLogger().trace("end icon"), this.popState(); + break; + case 10: + return te.getLogger().trace("Exploding node"), this.begin("NODE"), 19; + case 11: + return te.getLogger().trace("Cloud"), this.begin("NODE"), 19; + case 12: + return te.getLogger().trace("Explosion Bang"), this.begin("NODE"), 19; + case 13: + return te.getLogger().trace("Cloud Bang"), this.begin("NODE"), 19; + case 14: + return this.begin("NODE"), 19; + case 15: + return this.begin("NODE"), 19; + case 16: + return this.begin("NODE"), 19; + case 17: + return this.begin("NODE"), 19; + case 18: + return 13; + case 19: + return 22; + case 20: + return 11; + case 21: + this.begin("NSTR2"); + break; + case 22: + return "NODE_DESCR"; + case 23: + this.popState(); + break; + case 24: + te.getLogger().trace("Starting NSTR"), this.begin("NSTR"); + break; + case 25: + return te.getLogger().trace("description:", S.yytext), "NODE_DESCR"; + case 26: + this.popState(); + break; + case 27: + return this.popState(), te.getLogger().trace("node end ))"), "NODE_DEND"; + case 28: + return this.popState(), te.getLogger().trace("node end )"), "NODE_DEND"; + case 29: + return this.popState(), te.getLogger().trace("node end ...", S.yytext), "NODE_DEND"; + case 30: + return this.popState(), te.getLogger().trace("node end (("), "NODE_DEND"; + case 31: + return this.popState(), te.getLogger().trace("node end (-"), "NODE_DEND"; + case 32: + return this.popState(), te.getLogger().trace("node end (-"), "NODE_DEND"; + case 33: + return this.popState(), te.getLogger().trace("node end (("), "NODE_DEND"; + case 34: + return this.popState(), te.getLogger().trace("node end (("), "NODE_DEND"; + case 35: + return te.getLogger().trace("Long description:", S.yytext), 20; + case 36: + return te.getLogger().trace("Long description:", S.yytext), 20; + } + }, + rules: [/^(?:\s*%%.*)/i, /^(?:mindmap\b)/i, /^(?::::)/i, /^(?:.+)/i, /^(?:\n)/i, /^(?:::icon\()/i, /^(?:[\s]+[\n])/i, /^(?:[\n]+)/i, /^(?:[^\)]+)/i, /^(?:\))/i, /^(?:-\))/i, /^(?:\(-)/i, /^(?:\)\))/i, /^(?:\))/i, /^(?:\(\()/i, /^(?:\{\{)/i, /^(?:\()/i, /^(?:\[)/i, /^(?:[\s]+)/i, /^(?:[^\(\[\n\)\{\}]+)/i, /^(?:$)/i, /^(?:["][`])/i, /^(?:[^`"]+)/i, /^(?:[`]["])/i, /^(?:["])/i, /^(?:[^"]+)/i, /^(?:["])/i, /^(?:[\)]\))/i, /^(?:[\)])/i, /^(?:[\]])/i, /^(?:\}\})/i, /^(?:\(-)/i, /^(?:-\))/i, /^(?:\(\()/i, /^(?:\()/i, /^(?:[^\)\]\(\}]+)/i, /^(?:.+(?!\(\())/i], + conditions: { CLASS: { rules: [3, 4], inclusive: !1 }, ICON: { rules: [8, 9], inclusive: !1 }, NSTR2: { rules: [22, 23], inclusive: !1 }, NSTR: { rules: [25, 26], inclusive: !1 }, NODE: { rules: [21, 24, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36], inclusive: !1 }, INITIAL: { rules: [0, 1, 2, 5, 6, 7, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20], inclusive: !0 } } + }; + return ee; + }(); + ne.lexer = le; + function j() { + this.yy = {}; + } + return j.prototype = ne, ne.Parser = j, new j(); +}(); +Qi.parser = Qi; +const Cp = Qi; +let or = [], _l = 0, ji = {}; +const Dp = () => { + or = [], _l = 0, ji = {}; +}, Sp = function(de) { + for (let Pe = or.length - 1; Pe >= 0; Pe--) + if (or[Pe].level < de) + return or[Pe]; + return null; +}, Lp = () => or.length > 0 ? or[0] : null, Ap = (de, Pe, _, fe) => { + var I, z; + qr.info("addNode", de, Pe, _, fe); + const Q = Ji(); + let C = ((I = Q.mindmap) == null ? void 0 : I.padding) ?? ti.mindmap.padding; + switch (fe) { + case St.ROUNDED_RECT: + case St.RECT: + case St.HEXAGON: + C *= 2; + } + const T = { + id: _l++, + nodeId: ri(Pe, Q), + level: de, + descr: ri(_, Q), + type: fe, + children: [], + width: ((z = Q.mindmap) == null ? void 0 : z.maxNodeWidth) ?? ti.mindmap.maxNodeWidth, + padding: C + }, x = Sp(de); + if (x) + x.children.push(T), or.push(T); + else if (or.length === 0) + or.push(T); + else + throw new Error( + 'There can be only one root. No parent could be found for ("' + T.descr + '")' + ); +}, St = { + DEFAULT: 0, + NO_BORDER: 0, + ROUNDED_RECT: 1, + RECT: 2, + CIRCLE: 3, + CLOUD: 4, + BANG: 5, + HEXAGON: 6 +}, Op = (de, Pe) => { + switch (qr.debug("In get type", de, Pe), de) { + case "[": + return St.RECT; + case "(": + return Pe === ")" ? St.ROUNDED_RECT : St.CLOUD; + case "((": + return St.CIRCLE; + case ")": + return St.CLOUD; + case "))": + return St.BANG; + case "{{": + return St.HEXAGON; + default: + return St.DEFAULT; + } +}, Np = (de, Pe) => { + ji[de] = Pe; +}, Ip = (de) => { + if (!de) + return; + const Pe = Ji(), _ = or[or.length - 1]; + de.icon && (_.icon = ri(de.icon, Pe)), de.class && (_.class = ri(de.class, Pe)); +}, Mp = (de) => { + switch (de) { + case St.DEFAULT: + return "no-border"; + case St.RECT: + return "rect"; + case St.ROUNDED_RECT: + return "rounded-rect"; + case St.CIRCLE: + return "circle"; + case St.CLOUD: + return "cloud"; + case St.BANG: + return "bang"; + case St.HEXAGON: + return "hexgon"; + default: + return "no-border"; + } +}, Rp = () => qr, kp = (de) => ji[de], Pp = { + clear: Dp, + addNode: Ap, + getMindmap: Lp, + nodeType: St, + getType: Op, + setElementForId: Np, + decorateNode: Ip, + type2Str: Mp, + getLogger: Rp, + getElementById: kp +}, Bp = Pp; +var Yl = { exports: {} }; +(function(de, Pe) { + (function(_, fe) { + de.exports = fe(); + })(Ca, function() { + function _(t) { + "@babel/helpers - typeof"; + return _ = typeof Symbol == "function" && typeof Symbol.iterator == "symbol" ? function(e) { + return typeof e; + } : function(e) { + return e && typeof Symbol == "function" && e.constructor === Symbol && e !== Symbol.prototype ? "symbol" : typeof e; + }, _(t); + } + function fe(t, e) { + if (!(t instanceof e)) + throw new TypeError("Cannot call a class as a function"); + } + function Q(t, e) { + for (var r = 0; r < e.length; r++) { + var a = e[r]; + a.enumerable = a.enumerable || !1, a.configurable = !0, "value" in a && (a.writable = !0), Object.defineProperty(t, a.key, a); + } + } + function C(t, e, r) { + return e && Q(t.prototype, e), r && Q(t, r), Object.defineProperty(t, "prototype", { + writable: !1 + }), t; + } + function T(t, e, r) { + return e in t ? Object.defineProperty(t, e, { + value: r, + enumerable: !0, + configurable: !0, + writable: !0 + }) : t[e] = r, t; + } + function x(t, e) { + return I(t) || z(t, e) || Y(t, e) || Z(); + } + function I(t) { + if (Array.isArray(t)) + return t; + } + function z(t, e) { + var r = t == null ? null : typeof Symbol < "u" && t[Symbol.iterator] || t["@@iterator"]; + if (r != null) { + var a = [], n = !0, i = !1, s, o; + try { + for (r = r.call(t); !(n = (s = r.next()).done) && (a.push(s.value), !(e && a.length === e)); n = !0) + ; + } catch (u) { + i = !0, o = u; + } finally { + try { + !n && r.return != null && r.return(); + } finally { + if (i) + throw o; + } + } + return a; + } + } + function Y(t, e) { + if (t) { + if (typeof t == "string") + return P(t, e); + var r = Object.prototype.toString.call(t).slice(8, -1); + if (r === "Object" && t.constructor && (r = t.constructor.name), r === "Map" || r === "Set") + return Array.from(t); + if (r === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r)) + return P(t, e); + } + } + function P(t, e) { + (e == null || e > t.length) && (e = t.length); + for (var r = 0, a = new Array(e); r < e; r++) + a[r] = t[r]; + return a; + } + function Z() { + throw new TypeError(`Invalid attempt to destructure non-iterable instance. +In order to be iterable, non-array objects must have a [Symbol.iterator]() method.`); + } + var A = typeof window > "u" ? null : window, $ = A ? A.navigator : null; + A && A.document; + var U = _(""), J = _({}), ne = _(function() { + }), le = typeof HTMLElement > "u" ? "undefined" : _(HTMLElement), j = function(e) { + return e && e.instanceString && H(e.instanceString) ? e.instanceString() : null; + }, ee = function(e) { + return e != null && _(e) == U; + }, H = function(e) { + return e != null && _(e) === ne; + }, te = function(e) { + return !pe(e) && (Array.isArray ? Array.isArray(e) : e != null && e instanceof Array); + }, S = function(e) { + return e != null && _(e) === J && !te(e) && e.constructor === Object; + }, V = function(e) { + return e != null && _(e) === J; + }, R = function(e) { + return e != null && _(e) === _(1) && !isNaN(e); + }, q = function(e) { + return R(e) && Math.floor(e) === e; + }, ve = function(e) { + if (le !== "undefined") + return e != null && e instanceof HTMLElement; + }, pe = function(e) { + return Ae(e) || Ne(e); + }, Ae = function(e) { + return j(e) === "collection" && e._private.single; + }, Ne = function(e) { + return j(e) === "collection" && !e._private.single; + }, Ye = function(e) { + return j(e) === "core"; + }, at = function(e) { + return j(e) === "stylesheet"; + }, dt = function(e) { + return j(e) === "event"; + }, Re = function(e) { + return e == null ? !0 : !!(e === "" || e.match(/^\s+$/)); + }, Ve = function(e) { + return typeof HTMLElement > "u" ? !1 : e instanceof HTMLElement; + }, Ze = function(e) { + return S(e) && R(e.x1) && R(e.x2) && R(e.y1) && R(e.y2); + }, nt = function(e) { + return V(e) && H(e.then); + }, ht = function() { + return $ && $.userAgent.match(/msie|trident|edge/i); + }, it = function(e, r) { + r || (r = function() { + if (arguments.length === 1) + return arguments[0]; + if (arguments.length === 0) + return "undefined"; + for (var i = [], s = 0; s < arguments.length; s++) + i.push(arguments[s]); + return i.join("$"); + }); + var a = function n() { + var i = this, s = arguments, o, u = r.apply(i, s), l = n.cache; + return (o = l[u]) || (o = l[u] = e.apply(i, s)), o; + }; + return a.cache = {}, a; + }, tt = it(function(t) { + return t.replace(/([A-Z])/g, function(e) { + return "-" + e.toLowerCase(); + }); + }), yt = it(function(t) { + return t.replace(/(-\w)/g, function(e) { + return e[1].toUpperCase(); + }); + }), Et = it(function(t, e) { + return t + e[0].toUpperCase() + e.substring(1); + }, function(t, e) { + return t + "$" + e; + }), Pt = function(e) { + return Re(e) ? e : e.charAt(0).toUpperCase() + e.substring(1); + }, gt = "(?:[-+]?(?:(?:\\d+|\\d*\\.\\d+)(?:[Ee][+-]?\\d+)?))", dr = "rgb[a]?\\((" + gt + "[%]?)\\s*,\\s*(" + gt + "[%]?)\\s*,\\s*(" + gt + "[%]?)(?:\\s*,\\s*(" + gt + "))?\\)", qt = "rgb[a]?\\((?:" + gt + "[%]?)\\s*,\\s*(?:" + gt + "[%]?)\\s*,\\s*(?:" + gt + "[%]?)(?:\\s*,\\s*(?:" + gt + "))?\\)", nn = "hsl[a]?\\((" + gt + ")\\s*,\\s*(" + gt + "[%])\\s*,\\s*(" + gt + "[%])(?:\\s*,\\s*(" + gt + "))?\\)", Kr = "hsl[a]?\\((?:" + gt + ")\\s*,\\s*(?:" + gt + "[%])\\s*,\\s*(?:" + gt + "[%])(?:\\s*,\\s*(?:" + gt + "))?\\)", Da = "\\#[0-9a-fA-F]{3}", jt = "\\#[0-9a-fA-F]{6}", es = function(e, r) { + return e < r ? -1 : e > r ? 1 : 0; + }, Kl = function(e, r) { + return -1 * es(e, r); + }, He = Object.assign != null ? Object.assign.bind(Object) : function(t) { + for (var e = arguments, r = 1; r < e.length; r++) { + var a = e[r]; + if (a != null) + for (var n = Object.keys(a), i = 0; i < n.length; i++) { + var s = n[i]; + t[s] = a[s]; + } + } + return t; + }, Zl = function(e) { + if (!(!(e.length === 4 || e.length === 7) || e[0] !== "#")) { + var r = e.length === 4, a, n, i, s = 16; + return r ? (a = parseInt(e[1] + e[1], s), n = parseInt(e[2] + e[2], s), i = parseInt(e[3] + e[3], s)) : (a = parseInt(e[1] + e[2], s), n = parseInt(e[3] + e[4], s), i = parseInt(e[5] + e[6], s)), [a, n, i]; + } + }, Ql = function(e) { + var r, a, n, i, s, o, u, l; + function f(c, y, p) { + return p < 0 && (p += 1), p > 1 && (p -= 1), p < 1 / 6 ? c + (y - c) * 6 * p : p < 1 / 2 ? y : p < 2 / 3 ? c + (y - c) * (2 / 3 - p) * 6 : c; + } + var h = new RegExp("^" + nn + "$").exec(e); + if (h) { + if (a = parseInt(h[1]), a < 0 ? a = (360 - -1 * a % 360) % 360 : a > 360 && (a = a % 360), a /= 360, n = parseFloat(h[2]), n < 0 || n > 100 || (n = n / 100, i = parseFloat(h[3]), i < 0 || i > 100) || (i = i / 100, s = h[4], s !== void 0 && (s = parseFloat(s), s < 0 || s > 1))) + return; + if (n === 0) + o = u = l = Math.round(i * 255); + else { + var v = i < 0.5 ? i * (1 + n) : i + n - i * n, d = 2 * i - v; + o = Math.round(255 * f(d, v, a + 1 / 3)), u = Math.round(255 * f(d, v, a)), l = Math.round(255 * f(d, v, a - 1 / 3)); + } + r = [o, u, l, s]; + } + return r; + }, Jl = function(e) { + var r, a = new RegExp("^" + dr + "$").exec(e); + if (a) { + r = []; + for (var n = [], i = 1; i <= 3; i++) { + var s = a[i]; + if (s[s.length - 1] === "%" && (n[i] = !0), s = parseFloat(s), n[i] && (s = s / 100 * 255), s < 0 || s > 255) + return; + r.push(Math.floor(s)); + } + var o = n[1] || n[2] || n[3], u = n[1] && n[2] && n[3]; + if (o && !u) + return; + var l = a[4]; + if (l !== void 0) { + if (l = parseFloat(l), l < 0 || l > 1) + return; + r.push(l); + } + } + return r; + }, jl = function(e) { + return tu[e.toLowerCase()]; + }, eu = function(e) { + return (te(e) ? e : null) || jl(e) || Zl(e) || Jl(e) || Ql(e); + }, tu = { + // special colour names + transparent: [0, 0, 0, 0], + // NB alpha === 0 + // regular colours + aliceblue: [240, 248, 255], + antiquewhite: [250, 235, 215], + aqua: [0, 255, 255], + aquamarine: [127, 255, 212], + azure: [240, 255, 255], + beige: [245, 245, 220], + bisque: [255, 228, 196], + black: [0, 0, 0], + blanchedalmond: [255, 235, 205], + blue: [0, 0, 255], + blueviolet: [138, 43, 226], + brown: [165, 42, 42], + burlywood: [222, 184, 135], + cadetblue: [95, 158, 160], + chartreuse: [127, 255, 0], + chocolate: [210, 105, 30], + coral: [255, 127, 80], + cornflowerblue: [100, 149, 237], + cornsilk: [255, 248, 220], + crimson: [220, 20, 60], + cyan: [0, 255, 255], + darkblue: [0, 0, 139], + darkcyan: [0, 139, 139], + darkgoldenrod: [184, 134, 11], + darkgray: [169, 169, 169], + darkgreen: [0, 100, 0], + darkgrey: [169, 169, 169], + darkkhaki: [189, 183, 107], + darkmagenta: [139, 0, 139], + darkolivegreen: [85, 107, 47], + darkorange: [255, 140, 0], + darkorchid: [153, 50, 204], + darkred: [139, 0, 0], + darksalmon: [233, 150, 122], + darkseagreen: [143, 188, 143], + darkslateblue: [72, 61, 139], + darkslategray: [47, 79, 79], + darkslategrey: [47, 79, 79], + darkturquoise: [0, 206, 209], + darkviolet: [148, 0, 211], + deeppink: [255, 20, 147], + deepskyblue: [0, 191, 255], + dimgray: [105, 105, 105], + dimgrey: [105, 105, 105], + dodgerblue: [30, 144, 255], + firebrick: [178, 34, 34], + floralwhite: [255, 250, 240], + forestgreen: [34, 139, 34], + fuchsia: [255, 0, 255], + gainsboro: [220, 220, 220], + ghostwhite: [248, 248, 255], + gold: [255, 215, 0], + goldenrod: [218, 165, 32], + gray: [128, 128, 128], + grey: [128, 128, 128], + green: [0, 128, 0], + greenyellow: [173, 255, 47], + honeydew: [240, 255, 240], + hotpink: [255, 105, 180], + indianred: [205, 92, 92], + indigo: [75, 0, 130], + ivory: [255, 255, 240], + khaki: [240, 230, 140], + lavender: [230, 230, 250], + lavenderblush: [255, 240, 245], + lawngreen: [124, 252, 0], + lemonchiffon: [255, 250, 205], + lightblue: [173, 216, 230], + lightcoral: [240, 128, 128], + lightcyan: [224, 255, 255], + lightgoldenrodyellow: [250, 250, 210], + lightgray: [211, 211, 211], + lightgreen: [144, 238, 144], + lightgrey: [211, 211, 211], + lightpink: [255, 182, 193], + lightsalmon: [255, 160, 122], + lightseagreen: [32, 178, 170], + lightskyblue: [135, 206, 250], + lightslategray: [119, 136, 153], + lightslategrey: [119, 136, 153], + lightsteelblue: [176, 196, 222], + lightyellow: [255, 255, 224], + lime: [0, 255, 0], + limegreen: [50, 205, 50], + linen: [250, 240, 230], + magenta: [255, 0, 255], + maroon: [128, 0, 0], + mediumaquamarine: [102, 205, 170], + mediumblue: [0, 0, 205], + mediumorchid: [186, 85, 211], + mediumpurple: [147, 112, 219], + mediumseagreen: [60, 179, 113], + mediumslateblue: [123, 104, 238], + mediumspringgreen: [0, 250, 154], + mediumturquoise: [72, 209, 204], + mediumvioletred: [199, 21, 133], + midnightblue: [25, 25, 112], + mintcream: [245, 255, 250], + mistyrose: [255, 228, 225], + moccasin: [255, 228, 181], + navajowhite: [255, 222, 173], + navy: [0, 0, 128], + oldlace: [253, 245, 230], + olive: [128, 128, 0], + olivedrab: [107, 142, 35], + orange: [255, 165, 0], + orangered: [255, 69, 0], + orchid: [218, 112, 214], + palegoldenrod: [238, 232, 170], + palegreen: [152, 251, 152], + paleturquoise: [175, 238, 238], + palevioletred: [219, 112, 147], + papayawhip: [255, 239, 213], + peachpuff: [255, 218, 185], + peru: [205, 133, 63], + pink: [255, 192, 203], + plum: [221, 160, 221], + powderblue: [176, 224, 230], + purple: [128, 0, 128], + red: [255, 0, 0], + rosybrown: [188, 143, 143], + royalblue: [65, 105, 225], + saddlebrown: [139, 69, 19], + salmon: [250, 128, 114], + sandybrown: [244, 164, 96], + seagreen: [46, 139, 87], + seashell: [255, 245, 238], + sienna: [160, 82, 45], + silver: [192, 192, 192], + skyblue: [135, 206, 235], + slateblue: [106, 90, 205], + slategray: [112, 128, 144], + slategrey: [112, 128, 144], + snow: [255, 250, 250], + springgreen: [0, 255, 127], + steelblue: [70, 130, 180], + tan: [210, 180, 140], + teal: [0, 128, 128], + thistle: [216, 191, 216], + tomato: [255, 99, 71], + turquoise: [64, 224, 208], + violet: [238, 130, 238], + wheat: [245, 222, 179], + white: [255, 255, 255], + whitesmoke: [245, 245, 245], + yellow: [255, 255, 0], + yellowgreen: [154, 205, 50] + }, ts = function(e) { + for (var r = e.map, a = e.keys, n = a.length, i = 0; i < n; i++) { + var s = a[i]; + if (S(s)) + throw Error("Tried to set map with object key"); + i < a.length - 1 ? (r[s] == null && (r[s] = {}), r = r[s]) : r[s] = e.value; + } + }, rs = function(e) { + for (var r = e.map, a = e.keys, n = a.length, i = 0; i < n; i++) { + var s = a[i]; + if (S(s)) + throw Error("Tried to get map with object key"); + if (r = r[s], r == null) + return r; + } + return r; + }; + function ru(t) { + var e = typeof t; + return t != null && (e == "object" || e == "function"); + } + var kr = ru, Sa = typeof globalThis < "u" ? globalThis : typeof window < "u" ? window : typeof Ca < "u" ? Ca : typeof self < "u" ? self : {}; + function au(t, e) { + return e = { exports: {} }, t(e, e.exports), e.exports; + } + var nu = typeof Sa == "object" && Sa && Sa.Object === Object && Sa, iu = nu, su = typeof self == "object" && self && self.Object === Object && self, ou = iu || su || Function("return this")(), sn = ou, lu = function() { + return sn.Date.now(); + }, ai = lu, uu = /\s/; + function fu(t) { + for (var e = t.length; e-- && uu.test(t.charAt(e)); ) + ; + return e; + } + var hu = fu, vu = /^\s+/; + function cu(t) { + return t && t.slice(0, hu(t) + 1).replace(vu, ""); + } + var du = cu, gu = sn.Symbol, Zr = gu, as = Object.prototype, pu = as.hasOwnProperty, yu = as.toString, La = Zr ? Zr.toStringTag : void 0; + function mu(t) { + var e = pu.call(t, La), r = t[La]; + try { + t[La] = void 0; + var a = !0; + } catch { + } + var n = yu.call(t); + return a && (e ? t[La] = r : delete t[La]), n; + } + var bu = mu, Eu = Object.prototype, wu = Eu.toString; + function xu(t) { + return wu.call(t); + } + var Tu = xu, Cu = "[object Null]", Du = "[object Undefined]", ns = Zr ? Zr.toStringTag : void 0; + function Su(t) { + return t == null ? t === void 0 ? Du : Cu : ns && ns in Object(t) ? bu(t) : Tu(t); + } + var is = Su; + function Lu(t) { + return t != null && typeof t == "object"; + } + var Au = Lu, Ou = "[object Symbol]"; + function Nu(t) { + return typeof t == "symbol" || Au(t) && is(t) == Ou; + } + var Aa = Nu, ss = 0 / 0, Iu = /^[-+]0x[0-9a-f]+$/i, Mu = /^0b[01]+$/i, Ru = /^0o[0-7]+$/i, ku = parseInt; + function Pu(t) { + if (typeof t == "number") + return t; + if (Aa(t)) + return ss; + if (kr(t)) { + var e = typeof t.valueOf == "function" ? t.valueOf() : t; + t = kr(e) ? e + "" : e; + } + if (typeof t != "string") + return t === 0 ? t : +t; + t = du(t); + var r = Mu.test(t); + return r || Ru.test(t) ? ku(t.slice(2), r ? 2 : 8) : Iu.test(t) ? ss : +t; + } + var os = Pu, Bu = "Expected a function", Fu = Math.max, Gu = Math.min; + function zu(t, e, r) { + var a, n, i, s, o, u, l = 0, f = !1, h = !1, v = !0; + if (typeof t != "function") + throw new TypeError(Bu); + e = os(e) || 0, kr(r) && (f = !!r.leading, h = "maxWait" in r, i = h ? Fu(os(r.maxWait) || 0, e) : i, v = "trailing" in r ? !!r.trailing : v); + function d(L) { + var w = a, k = n; + return a = n = void 0, l = L, s = t.apply(k, w), s; + } + function c(L) { + return l = L, o = setTimeout(g, e), f ? d(L) : s; + } + function y(L) { + var w = L - u, k = L - l, D = e - w; + return h ? Gu(D, i - k) : D; + } + function p(L) { + var w = L - u, k = L - l; + return u === void 0 || w >= e || w < 0 || h && k >= i; + } + function g() { + var L = ai(); + if (p(L)) + return m(L); + o = setTimeout(g, y(L)); + } + function m(L) { + return o = void 0, v && a ? d(L) : (a = n = void 0, s); + } + function b() { + o !== void 0 && clearTimeout(o), l = 0, a = u = n = o = void 0; + } + function E() { + return o === void 0 ? s : m(ai()); + } + function M() { + var L = ai(), w = p(L); + if (a = arguments, n = this, u = L, w) { + if (o === void 0) + return c(u); + if (h) + return clearTimeout(o), o = setTimeout(g, e), d(u); + } + return o === void 0 && (o = setTimeout(g, e)), s; + } + return M.cancel = b, M.flush = E, M; + } + var on = zu, ni = A ? A.performance : null, ls = ni && ni.now ? function() { + return ni.now(); + } : function() { + return Date.now(); + }, Vu = function() { + if (A) { + if (A.requestAnimationFrame) + return function(t) { + A.requestAnimationFrame(t); + }; + if (A.mozRequestAnimationFrame) + return function(t) { + A.mozRequestAnimationFrame(t); + }; + if (A.webkitRequestAnimationFrame) + return function(t) { + A.webkitRequestAnimationFrame(t); + }; + if (A.msRequestAnimationFrame) + return function(t) { + A.msRequestAnimationFrame(t); + }; + } + return function(t) { + t && setTimeout(function() { + t(ls()); + }, 1e3 / 60); + }; + }(), ln = function(e) { + return Vu(e); + }, gr = ls, Qr = 9261, us = 65599, Oa = 5381, fs = function(e) { + for (var r = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : Qr, a = r, n; n = e.next(), !n.done; ) + a = a * us + n.value | 0; + return a; + }, Na = function(e) { + var r = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : Qr; + return r * us + e | 0; + }, Ia = function(e) { + var r = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : Oa; + return (r << 5) + r + e | 0; + }, Uu = function(e, r) { + return e * 2097152 + r; + }, wr = function(e) { + return e[0] * 2097152 + e[1]; + }, un = function(e, r) { + return [Na(e[0], r[0]), Ia(e[1], r[1])]; + }, $u = function(e, r) { + var a = { + value: 0, + done: !1 + }, n = 0, i = e.length, s = { + next: function() { + return n < i ? a.value = e[n++] : a.done = !0, a; + } + }; + return fs(s, r); + }, Pr = function(e, r) { + var a = { + value: 0, + done: !1 + }, n = 0, i = e.length, s = { + next: function() { + return n < i ? a.value = e.charCodeAt(n++) : a.done = !0, a; + } + }; + return fs(s, r); + }, hs = function() { + return _u(arguments); + }, _u = function(e) { + for (var r, a = 0; a < e.length; a++) { + var n = e[a]; + a === 0 ? r = Pr(n) : r = Pr(n, r); + } + return r; + }, vs = !0, Yu = console.warn != null, Hu = console.trace != null, ii = Number.MAX_SAFE_INTEGER || 9007199254740991, cs = function() { + return !0; + }, fn = function() { + return !1; + }, ds = function() { + return 0; + }, si = function() { + }, xt = function(e) { + throw new Error(e); + }, gs = function(e) { + if (e !== void 0) + vs = !!e; + else + return vs; + }, vt = function(e) { + gs() && (Yu ? console.warn(e) : (console.log(e), Hu && console.trace())); + }, Xu = function(e) { + return He({}, e); + }, lr = function(e) { + return e == null ? e : te(e) ? e.slice() : S(e) ? Xu(e) : e; + }, Wu = function(e) { + return e.slice(); + }, ps = function(e, r) { + for ( + // loop :) + r = e = ""; + // b - result , a - numeric letiable + e++ < 36; + // + r += e * 51 & 52 ? ( + // return a random number or 4 + (e ^ 15 ? ( + // generate a random number from 0 to 15 + 8 ^ Math.random() * (e ^ 20 ? 16 : 4) + ) : 4).toString(16) + ) : "-" + ) + ; + return r; + }, qu = {}, ys = function() { + return qu; + }, At = function(e) { + var r = Object.keys(e); + return function(a) { + for (var n = {}, i = 0; i < r.length; i++) { + var s = r[i], o = a == null ? void 0 : a[s]; + n[s] = o === void 0 ? e[s] : o; + } + return n; + }; + }, xr = function(e, r, a) { + for (var n = e.length - 1; n >= 0 && !(e[n] === r && (e.splice(n, 1), a)); n--) + ; + }, oi = function(e) { + e.splice(0, e.length); + }, Ku = function(e, r) { + for (var a = 0; a < r.length; a++) { + var n = r[a]; + e.push(n); + } + }, er = function(e, r, a) { + return a && (r = Et(a, r)), e[r]; + }, Tr = function(e, r, a, n) { + a && (r = Et(a, r)), e[r] = n; + }, Zu = /* @__PURE__ */ function() { + function t() { + fe(this, t), this._obj = {}; + } + return C(t, [{ + key: "set", + value: function(r, a) { + return this._obj[r] = a, this; + } + }, { + key: "delete", + value: function(r) { + return this._obj[r] = void 0, this; + } + }, { + key: "clear", + value: function() { + this._obj = {}; + } + }, { + key: "has", + value: function(r) { + return this._obj[r] !== void 0; + } + }, { + key: "get", + value: function(r) { + return this._obj[r]; + } + }]), t; + }(), ur = typeof Map < "u" ? Map : Zu, Qu = "undefined", Ju = /* @__PURE__ */ function() { + function t(e) { + if (fe(this, t), this._obj = /* @__PURE__ */ Object.create(null), this.size = 0, e != null) { + var r; + e.instanceString != null && e.instanceString() === this.instanceString() ? r = e.toArray() : r = e; + for (var a = 0; a < r.length; a++) + this.add(r[a]); + } + } + return C(t, [{ + key: "instanceString", + value: function() { + return "set"; + } + }, { + key: "add", + value: function(r) { + var a = this._obj; + a[r] !== 1 && (a[r] = 1, this.size++); + } + }, { + key: "delete", + value: function(r) { + var a = this._obj; + a[r] === 1 && (a[r] = 0, this.size--); + } + }, { + key: "clear", + value: function() { + this._obj = /* @__PURE__ */ Object.create(null); + } + }, { + key: "has", + value: function(r) { + return this._obj[r] === 1; + } + }, { + key: "toArray", + value: function() { + var r = this; + return Object.keys(this._obj).filter(function(a) { + return r.has(a); + }); + } + }, { + key: "forEach", + value: function(r, a) { + return this.toArray().forEach(r, a); + } + }]), t; + }(), Jr = (typeof Set > "u" ? "undefined" : _(Set)) !== Qu ? Set : Ju, hn = function(e, r) { + var a = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : !0; + if (e === void 0 || r === void 0 || !Ye(e)) { + xt("An element must have a core reference and parameters set"); + return; + } + var n = r.group; + if (n == null && (r.data && r.data.source != null && r.data.target != null ? n = "edges" : n = "nodes"), n !== "nodes" && n !== "edges") { + xt("An element must be of type `nodes` or `edges`; you specified `" + n + "`"); + return; + } + this.length = 1, this[0] = this; + var i = this._private = { + cy: e, + single: !0, + // indicates this is an element + data: r.data || {}, + // data object + position: r.position || { + x: 0, + y: 0 + }, + // (x, y) position pair + autoWidth: void 0, + // width and height of nodes calculated by the renderer when set to special 'auto' value + autoHeight: void 0, + autoPadding: void 0, + compoundBoundsClean: !1, + // whether the compound dimensions need to be recalculated the next time dimensions are read + listeners: [], + // array of bound listeners + group: n, + // string; 'nodes' or 'edges' + style: {}, + // properties as set by the style + rstyle: {}, + // properties for style sent from the renderer to the core + styleCxts: [], + // applied style contexts from the styler + styleKeys: {}, + // per-group keys of style property values + removed: !0, + // whether it's inside the vis; true if removed (set true here since we call restore) + selected: !!r.selected, + // whether it's selected + selectable: r.selectable === void 0 ? !0 : !!r.selectable, + // whether it's selectable + locked: !!r.locked, + // whether the element is locked (cannot be moved) + grabbed: !1, + // whether the element is grabbed by the mouse; renderer sets this privately + grabbable: r.grabbable === void 0 ? !0 : !!r.grabbable, + // whether the element can be grabbed + pannable: r.pannable === void 0 ? n === "edges" : !!r.pannable, + // whether the element has passthrough panning enabled + active: !1, + // whether the element is active from user interaction + classes: new Jr(), + // map ( className => true ) + animation: { + // object for currently-running animations + current: [], + queue: [] + }, + rscratch: {}, + // object in which the renderer can store information + scratch: r.scratch || {}, + // scratch objects + edges: [], + // array of connected edges + children: [], + // array of children + parent: r.parent && r.parent.isNode() ? r.parent : null, + // parent ref + traversalCache: {}, + // cache of output of traversal functions + backgrounding: !1, + // whether background images are loading + bbCache: null, + // cache of the current bounding box + bbCacheShift: { + x: 0, + y: 0 + }, + // shift applied to cached bb to be applied on next get + bodyBounds: null, + // bounds cache of element body, w/o overlay + overlayBounds: null, + // bounds cache of element body, including overlay + labelBounds: { + // bounds cache of labels + all: null, + source: null, + target: null, + main: null + }, + arrowBounds: { + // bounds cache of edge arrows + source: null, + target: null, + "mid-source": null, + "mid-target": null + } + }; + if (i.position.x == null && (i.position.x = 0), i.position.y == null && (i.position.y = 0), r.renderedPosition) { + var s = r.renderedPosition, o = e.pan(), u = e.zoom(); + i.position = { + x: (s.x - o.x) / u, + y: (s.y - o.y) / u + }; + } + var l = []; + te(r.classes) ? l = r.classes : ee(r.classes) && (l = r.classes.split(/\s+/)); + for (var f = 0, h = l.length; f < h; f++) { + var v = l[f]; + !v || v === "" || i.classes.add(v); + } + this.createEmitter(); + var d = r.style || r.css; + d && (vt("Setting a `style` bypass at element creation should be done only when absolutely necessary. Try to use the stylesheet instead."), this.style(d)), (a === void 0 || a) && this.restore(); + }, ms = function(e) { + return e = { + bfs: e.bfs || !e.dfs, + dfs: e.dfs || !e.bfs + }, function(a, n, i) { + var s; + S(a) && !pe(a) && (s = a, a = s.roots || s.root, n = s.visit, i = s.directed), i = arguments.length === 2 && !H(n) ? n : i, n = H(n) ? n : function() { + }; + for (var o = this._private.cy, u = a = ee(a) ? this.filter(a) : a, l = [], f = [], h = {}, v = {}, d = {}, c = 0, y, p = this.byGroup(), g = p.nodes, m = p.edges, b = 0; b < u.length; b++) { + var E = u[b], M = E.id(); + E.isNode() && (l.unshift(E), e.bfs && (d[M] = !0, f.push(E)), v[M] = 0); + } + for (var L = function() { + var X = e.bfs ? l.shift() : l.pop(), B = X.id(); + if (e.dfs) { + if (d[B]) + return "continue"; + d[B] = !0, f.push(X); + } + var re = v[B], K = h[B], W = K != null ? K.source() : null, ae = K != null ? K.target() : null, ue = K == null ? void 0 : X.same(W) ? ae[0] : W[0], me = void 0; + if (me = n(X, K, ue, c++, re), me === !0) + return y = X, "break"; + if (me === !1) + return "break"; + for (var ie = X.connectedEdges().filter(function(De) { + return (!i || De.source().same(X)) && m.has(De); + }), ge = 0; ge < ie.length; ge++) { + var Ee = ie[ge], Ce = Ee.connectedNodes().filter(function(De) { + return !De.same(X) && g.has(De); + }), we = Ce.id(); + Ce.length !== 0 && !d[we] && (Ce = Ce[0], l.push(Ce), e.bfs && (d[we] = !0, f.push(Ce)), h[we] = Ee, v[we] = v[B] + 1); + } + }; l.length !== 0; ) { + var w = L(); + if (w !== "continue" && w === "break") + break; + } + for (var k = o.collection(), D = 0; D < f.length; D++) { + var F = f[D], G = h[F.id()]; + G != null && k.push(G), k.push(F); + } + return { + path: o.collection(k), + found: o.collection(y) + }; + }; + }, Ma = { + breadthFirstSearch: ms({ + bfs: !0 + }), + depthFirstSearch: ms({ + dfs: !0 + }) + }; + Ma.bfs = Ma.breadthFirstSearch, Ma.dfs = Ma.depthFirstSearch; + var ju = au(function(t, e) { + (function() { + var r, a, n, i, s, o, u, l, f, h, v, d, c, y, p; + n = Math.floor, h = Math.min, a = function(g, m) { + return g < m ? -1 : g > m ? 1 : 0; + }, f = function(g, m, b, E, M) { + var L; + if (b == null && (b = 0), M == null && (M = a), b < 0) + throw new Error("lo must be non-negative"); + for (E == null && (E = g.length); b < E; ) + L = n((b + E) / 2), M(m, g[L]) < 0 ? E = L : b = L + 1; + return [].splice.apply(g, [b, b - b].concat(m)), m; + }, o = function(g, m, b) { + return b == null && (b = a), g.push(m), y(g, 0, g.length - 1, b); + }, s = function(g, m) { + var b, E; + return m == null && (m = a), b = g.pop(), g.length ? (E = g[0], g[0] = b, p(g, 0, m)) : E = b, E; + }, l = function(g, m, b) { + var E; + return b == null && (b = a), E = g[0], g[0] = m, p(g, 0, b), E; + }, u = function(g, m, b) { + var E; + return b == null && (b = a), g.length && b(g[0], m) < 0 && (E = [g[0], m], m = E[0], g[0] = E[1], p(g, 0, b)), m; + }, i = function(g, m) { + var b, E, M, L, w, k; + for (m == null && (m = a), L = (function() { + k = []; + for (var D = 0, F = n(g.length / 2); 0 <= F ? D < F : D > F; 0 <= F ? D++ : D--) + k.push(D); + return k; + }).apply(this).reverse(), w = [], E = 0, M = L.length; E < M; E++) + b = L[E], w.push(p(g, b, m)); + return w; + }, c = function(g, m, b) { + var E; + if (b == null && (b = a), E = g.indexOf(m), E !== -1) + return y(g, 0, E, b), p(g, E, b); + }, v = function(g, m, b) { + var E, M, L, w, k; + if (b == null && (b = a), M = g.slice(0, m), !M.length) + return M; + for (i(M, b), k = g.slice(m), L = 0, w = k.length; L < w; L++) + E = k[L], u(M, E, b); + return M.sort(b).reverse(); + }, d = function(g, m, b) { + var E, M, L, w, k, D, F, G, N; + if (b == null && (b = a), m * 10 <= g.length) { + if (L = g.slice(0, m).sort(b), !L.length) + return L; + for (M = L[L.length - 1], F = g.slice(m), w = 0, D = F.length; w < D; w++) + E = F[w], b(E, M) < 0 && (f(L, E, 0, null, b), L.pop(), M = L[L.length - 1]); + return L; + } + for (i(g, b), N = [], k = 0, G = h(m, g.length); 0 <= G ? k < G : k > G; 0 <= G ? ++k : --k) + N.push(s(g, b)); + return N; + }, y = function(g, m, b, E) { + var M, L, w; + for (E == null && (E = a), M = g[b]; b > m; ) { + if (w = b - 1 >> 1, L = g[w], E(M, L) < 0) { + g[b] = L, b = w; + continue; + } + break; + } + return g[b] = M; + }, p = function(g, m, b) { + var E, M, L, w, k; + for (b == null && (b = a), M = g.length, k = m, L = g[m], E = 2 * m + 1; E < M; ) + w = E + 1, w < M && !(b(g[E], g[w]) < 0) && (E = w), g[m] = g[E], m = E, E = 2 * m + 1; + return g[m] = L, y(g, k, m, b); + }, r = function() { + g.push = o, g.pop = s, g.replace = l, g.pushpop = u, g.heapify = i, g.updateItem = c, g.nlargest = v, g.nsmallest = d; + function g(m) { + this.cmp = m ?? a, this.nodes = []; + } + return g.prototype.push = function(m) { + return o(this.nodes, m, this.cmp); + }, g.prototype.pop = function() { + return s(this.nodes, this.cmp); + }, g.prototype.peek = function() { + return this.nodes[0]; + }, g.prototype.contains = function(m) { + return this.nodes.indexOf(m) !== -1; + }, g.prototype.replace = function(m) { + return l(this.nodes, m, this.cmp); + }, g.prototype.pushpop = function(m) { + return u(this.nodes, m, this.cmp); + }, g.prototype.heapify = function() { + return i(this.nodes, this.cmp); + }, g.prototype.updateItem = function(m) { + return c(this.nodes, m, this.cmp); + }, g.prototype.clear = function() { + return this.nodes = []; + }, g.prototype.empty = function() { + return this.nodes.length === 0; + }, g.prototype.size = function() { + return this.nodes.length; + }, g.prototype.clone = function() { + var m; + return m = new g(), m.nodes = this.nodes.slice(0), m; + }, g.prototype.toArray = function() { + return this.nodes.slice(0); + }, g.prototype.insert = g.prototype.push, g.prototype.top = g.prototype.peek, g.prototype.front = g.prototype.peek, g.prototype.has = g.prototype.contains, g.prototype.copy = g.prototype.clone, g; + }(), function(g, m) { + return t.exports = m(); + }(this, function() { + return r; + }); + }).call(Sa); + }), Ra = ju, ef = At({ + root: null, + weight: function(e) { + return 1; + }, + directed: !1 + }), tf = { + dijkstra: function(e) { + if (!S(e)) { + var r = arguments; + e = { + root: r[0], + weight: r[1], + directed: r[2] + }; + } + var a = ef(e), n = a.root, i = a.weight, s = a.directed, o = this, u = i, l = ee(n) ? this.filter(n)[0] : n[0], f = {}, h = {}, v = {}, d = this.byGroup(), c = d.nodes, y = d.edges; + y.unmergeBy(function(re) { + return re.isLoop(); + }); + for (var p = function(K) { + return f[K.id()]; + }, g = function(K, W) { + f[K.id()] = W, m.updateItem(K); + }, m = new Ra(function(re, K) { + return p(re) - p(K); + }), b = 0; b < c.length; b++) { + var E = c[b]; + f[E.id()] = E.same(l) ? 0 : 1 / 0, m.push(E); + } + for (var M = function(K, W) { + for (var ae = (s ? K.edgesTo(W) : K.edgesWith(W)).intersect(y), ue = 1 / 0, me, ie = 0; ie < ae.length; ie++) { + var ge = ae[ie], Ee = u(ge); + (Ee < ue || !me) && (ue = Ee, me = ge); + } + return { + edge: me, + dist: ue + }; + }; m.size() > 0; ) { + var L = m.pop(), w = p(L), k = L.id(); + if (v[k] = w, w !== 1 / 0) + for (var D = L.neighborhood().intersect(c), F = 0; F < D.length; F++) { + var G = D[F], N = G.id(), X = M(L, G), B = w + X.dist; + B < p(G) && (g(G, B), h[N] = { + node: L, + edge: X.edge + }); + } + } + return { + distanceTo: function(K) { + var W = ee(K) ? c.filter(K)[0] : K[0]; + return v[W.id()]; + }, + pathTo: function(K) { + var W = ee(K) ? c.filter(K)[0] : K[0], ae = [], ue = W, me = ue.id(); + if (W.length > 0) + for (ae.unshift(W); h[me]; ) { + var ie = h[me]; + ae.unshift(ie.edge), ae.unshift(ie.node), ue = ie.node, me = ue.id(); + } + return o.spawn(ae); + } + }; + } + }, rf = { + // kruskal's algorithm (finds min spanning tree, assuming undirected graph) + // implemented from pseudocode from wikipedia + kruskal: function(e) { + e = e || function(b) { + return 1; + }; + for (var r = this.byGroup(), a = r.nodes, n = r.edges, i = a.length, s = new Array(i), o = a, u = function(E) { + for (var M = 0; M < s.length; M++) { + var L = s[M]; + if (L.has(E)) + return M; + } + }, l = 0; l < i; l++) + s[l] = this.spawn(a[l]); + for (var f = n.sort(function(b, E) { + return e(b) - e(E); + }), h = 0; h < f.length; h++) { + var v = f[h], d = v.source()[0], c = v.target()[0], y = u(d), p = u(c), g = s[y], m = s[p]; + y !== p && (o.merge(v), g.merge(m), s.splice(p, 1)); + } + return o; + } + }, af = At({ + root: null, + goal: null, + weight: function(e) { + return 1; + }, + heuristic: function(e) { + return 0; + }, + directed: !1 + }), nf = { + // Implemented from pseudocode from wikipedia + aStar: function(e) { + var r = this.cy(), a = af(e), n = a.root, i = a.goal, s = a.heuristic, o = a.directed, u = a.weight; + n = r.collection(n)[0], i = r.collection(i)[0]; + var l = n.id(), f = i.id(), h = {}, v = {}, d = {}, c = new Ra(function(me, ie) { + return v[me.id()] - v[ie.id()]; + }), y = new Jr(), p = {}, g = {}, m = function(ie, ge) { + c.push(ie), y.add(ge); + }, b, E, M = function() { + b = c.pop(), E = b.id(), y.delete(E); + }, L = function(ie) { + return y.has(ie); + }; + m(n, l), h[l] = 0, v[l] = s(n); + for (var w = 0; c.size() > 0; ) { + if (M(), w++, E === f) { + for (var k = [], D = i, F = f, G = g[F]; k.unshift(D), G != null && k.unshift(G), D = p[F], D != null; ) + F = D.id(), G = g[F]; + return { + found: !0, + distance: h[E], + path: this.spawn(k), + steps: w + }; + } + d[E] = !0; + for (var N = b._private.edges, X = 0; X < N.length; X++) { + var B = N[X]; + if (this.hasElementWithId(B.id()) && !(o && B.data("source") !== E)) { + var re = B.source(), K = B.target(), W = re.id() !== E ? re : K, ae = W.id(); + if (this.hasElementWithId(ae) && !d[ae]) { + var ue = h[E] + u(B); + if (!L(ae)) { + h[ae] = ue, v[ae] = ue + s(W), m(W, ae), p[ae] = b, g[ae] = B; + continue; + } + ue < h[ae] && (h[ae] = ue, v[ae] = ue + s(W), p[ae] = b, g[ae] = B); + } + } + } + } + return { + found: !1, + distance: void 0, + path: void 0, + steps: w + }; + } + }, sf = At({ + weight: function(e) { + return 1; + }, + directed: !1 + }), of = { + // Implemented from pseudocode from wikipedia + floydWarshall: function(e) { + for (var r = this.cy(), a = sf(e), n = a.weight, i = a.directed, s = n, o = this.byGroup(), u = o.nodes, l = o.edges, f = u.length, h = f * f, v = function(Ee) { + return u.indexOf(Ee); + }, d = function(Ee) { + return u[Ee]; + }, c = new Array(h), y = 0; y < h; y++) { + var p = y % f, g = (y - p) / f; + g === p ? c[y] = 0 : c[y] = 1 / 0; + } + for (var m = new Array(h), b = new Array(h), E = 0; E < l.length; E++) { + var M = l[E], L = M.source()[0], w = M.target()[0]; + if (L !== w) { + var k = v(L), D = v(w), F = k * f + D, G = s(M); + if (c[F] > G && (c[F] = G, m[F] = D, b[F] = M), !i) { + var N = D * f + k; + !i && c[N] > G && (c[N] = G, m[N] = k, b[N] = M); + } + } + } + for (var X = 0; X < f; X++) + for (var B = 0; B < f; B++) + for (var re = B * f + X, K = 0; K < f; K++) { + var W = B * f + K, ae = X * f + K; + c[re] + c[ae] < c[W] && (c[W] = c[re] + c[ae], m[W] = m[re]); + } + var ue = function(Ee) { + return (ee(Ee) ? r.filter(Ee) : Ee)[0]; + }, me = function(Ee) { + return v(ue(Ee)); + }, ie = { + distance: function(Ee, Ce) { + var we = me(Ee), De = me(Ce); + return c[we * f + De]; + }, + path: function(Ee, Ce) { + var we = me(Ee), De = me(Ce), se = d(we); + if (we === De) + return se.collection(); + if (m[we * f + De] == null) + return r.collection(); + var xe = r.collection(), Le = we, Se; + for (xe.merge(se); we !== De; ) + Le = we, we = m[we * f + De], Se = b[Le * f + we], xe.merge(Se), xe.merge(d(we)); + return xe; + } + }; + return ie; + } + // floydWarshall + }, lf = At({ + weight: function(e) { + return 1; + }, + directed: !1, + root: null + }), uf = { + // Implemented from pseudocode from wikipedia + bellmanFord: function(e) { + var r = this, a = lf(e), n = a.weight, i = a.directed, s = a.root, o = n, u = this, l = this.cy(), f = this.byGroup(), h = f.edges, v = f.nodes, d = v.length, c = new ur(), y = !1, p = []; + s = l.collection(s)[0], h.unmergeBy(function(ze) { + return ze.isLoop(); + }); + for (var g = h.length, m = function(Be) { + var $e = c.get(Be.id()); + return $e || ($e = {}, c.set(Be.id(), $e)), $e; + }, b = function(Be) { + return (ee(Be) ? l.$(Be) : Be)[0]; + }, E = function(Be) { + return m(b(Be)).dist; + }, M = function(Be) { + for (var $e = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : s, rt = b(Be), je = [], We = rt; ; ) { + if (We == null) + return r.spawn(); + var et = m(We), he = et.edge, O = et.pred; + if (je.unshift(We[0]), We.same($e) && je.length > 0) + break; + he != null && je.unshift(he), We = O; + } + return u.spawn(je); + }, L = 0; L < d; L++) { + var w = v[L], k = m(w); + w.same(s) ? k.dist = 0 : k.dist = 1 / 0, k.pred = null, k.edge = null; + } + for (var D = !1, F = function(Be, $e, rt, je, We, et) { + var he = je.dist + et; + he < We.dist && !rt.same(je.edge) && (We.dist = he, We.pred = Be, We.edge = rt, D = !0); + }, G = 1; G < d; G++) { + D = !1; + for (var N = 0; N < g; N++) { + var X = h[N], B = X.source(), re = X.target(), K = o(X), W = m(B), ae = m(re); + F(B, re, X, W, ae, K), i || F(re, B, X, ae, W, K); + } + if (!D) + break; + } + if (D) + for (var ue = [], me = 0; me < g; me++) { + var ie = h[me], ge = ie.source(), Ee = ie.target(), Ce = o(ie), we = m(ge).dist, De = m(Ee).dist; + if (we + Ce < De || !i && De + Ce < we) + if (y || (vt("Graph contains a negative weight cycle for Bellman-Ford"), y = !0), e.findNegativeWeightCycles !== !1) { + var se = []; + we + Ce < De && se.push(ge), !i && De + Ce < we && se.push(Ee); + for (var xe = se.length, Le = 0; Le < xe; Le++) { + var Se = se[Le], Oe = [Se]; + Oe.push(m(Se).edge); + for (var Fe = m(Se).pred; Oe.indexOf(Fe) === -1; ) + Oe.push(Fe), Oe.push(m(Fe).edge), Fe = m(Fe).pred; + Oe = Oe.slice(Oe.indexOf(Fe)); + for (var Xe = Oe[0].id(), Ie = 0, Me = 2; Me < Oe.length; Me += 2) + Oe[Me].id() < Xe && (Xe = Oe[Me].id(), Ie = Me); + Oe = Oe.slice(Ie).concat(Oe.slice(0, Ie)), Oe.push(Oe[0]); + var Ue = Oe.map(function(ze) { + return ze.id(); + }).join(","); + ue.indexOf(Ue) === -1 && (p.push(u.spawn(Oe)), ue.push(Ue)); + } + } else + break; + } + return { + distanceTo: E, + pathTo: M, + hasNegativeWeightCycle: y, + negativeWeightCycles: p + }; + } + // bellmanFord + }, ff = Math.sqrt(2), hf = function(e, r, a) { + a.length === 0 && xt("Karger-Stein must be run on a connected (sub)graph"); + for (var n = a[e], i = n[1], s = n[2], o = r[i], u = r[s], l = a, f = l.length - 1; f >= 0; f--) { + var h = l[f], v = h[1], d = h[2]; + (r[v] === o && r[d] === u || r[v] === u && r[d] === o) && l.splice(f, 1); + } + for (var c = 0; c < l.length; c++) { + var y = l[c]; + y[1] === u ? (l[c] = y.slice(), l[c][1] = o) : y[2] === u && (l[c] = y.slice(), l[c][2] = o); + } + for (var p = 0; p < r.length; p++) + r[p] === u && (r[p] = o); + return l; + }, li = function(e, r, a, n) { + for (; a > n; ) { + var i = Math.floor(Math.random() * r.length); + r = hf(i, e, r), a--; + } + return r; + }, vf = { + // Computes the minimum cut of an undirected graph + // Returns the correct answer with high probability + kargerStein: function() { + var e = this, r = this.byGroup(), a = r.nodes, n = r.edges; + n.unmergeBy(function(ae) { + return ae.isLoop(); + }); + var i = a.length, s = n.length, o = Math.ceil(Math.pow(Math.log(i) / Math.LN2, 2)), u = Math.floor(i / ff); + if (i < 2) { + xt("At least 2 nodes are required for Karger-Stein algorithm"); + return; + } + for (var l = [], f = 0; f < s; f++) { + var h = n[f]; + l.push([f, a.indexOf(h.source()), a.indexOf(h.target())]); + } + for (var v = 1 / 0, d = [], c = new Array(i), y = new Array(i), p = new Array(i), g = function(ue, me) { + for (var ie = 0; ie < i; ie++) + me[ie] = ue[ie]; + }, m = 0; m <= o; m++) { + for (var b = 0; b < i; b++) + y[b] = b; + var E = li(y, l.slice(), i, u), M = E.slice(); + g(y, p); + var L = li(y, E, u, 2), w = li(p, M, u, 2); + L.length <= w.length && L.length < v ? (v = L.length, d = L, g(y, c)) : w.length <= L.length && w.length < v && (v = w.length, d = w, g(p, c)); + } + for (var k = this.spawn(d.map(function(ae) { + return n[ae[0]]; + })), D = this.spawn(), F = this.spawn(), G = c[0], N = 0; N < c.length; N++) { + var X = c[N], B = a[N]; + X === G ? D.merge(B) : F.merge(B); + } + var re = function(ue) { + var me = e.spawn(); + return ue.forEach(function(ie) { + me.merge(ie), ie.connectedEdges().forEach(function(ge) { + e.contains(ge) && !k.contains(ge) && me.merge(ge); + }); + }), me; + }, K = [re(D), re(F)], W = { + cut: k, + components: K, + // n.b. partitions are included to be compatible with the old api spec + // (could be removed in a future major version) + partition1: D, + partition2: F + }; + return W; + } + }, cf = function(e) { + return { + x: e.x, + y: e.y + }; + }, vn = function(e, r, a) { + return { + x: e.x * r + a.x, + y: e.y * r + a.y + }; + }, bs = function(e, r, a) { + return { + x: (e.x - a.x) / r, + y: (e.y - a.y) / r + }; + }, jr = function(e) { + return { + x: e[0], + y: e[1] + }; + }, df = function(e) { + for (var r = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : 0, a = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : e.length, n = 1 / 0, i = r; i < a; i++) { + var s = e[i]; + isFinite(s) && (n = Math.min(s, n)); + } + return n; + }, gf = function(e) { + for (var r = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : 0, a = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : e.length, n = -1 / 0, i = r; i < a; i++) { + var s = e[i]; + isFinite(s) && (n = Math.max(s, n)); + } + return n; + }, pf = function(e) { + for (var r = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : 0, a = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : e.length, n = 0, i = 0, s = r; s < a; s++) { + var o = e[s]; + isFinite(o) && (n += o, i++); + } + return n / i; + }, yf = function(e) { + var r = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : 0, a = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : e.length, n = arguments.length > 3 && arguments[3] !== void 0 ? arguments[3] : !0, i = arguments.length > 4 && arguments[4] !== void 0 ? arguments[4] : !0, s = arguments.length > 5 && arguments[5] !== void 0 ? arguments[5] : !0; + n ? e = e.slice(r, a) : (a < e.length && e.splice(a, e.length - a), r > 0 && e.splice(0, r)); + for (var o = 0, u = e.length - 1; u >= 0; u--) { + var l = e[u]; + s ? isFinite(l) || (e[u] = -1 / 0, o++) : e.splice(u, 1); + } + i && e.sort(function(v, d) { + return v - d; + }); + var f = e.length, h = Math.floor(f / 2); + return f % 2 !== 0 ? e[h + 1 + o] : (e[h - 1 + o] + e[h + o]) / 2; + }, mf = function(e) { + return Math.PI * e / 180; + }, cn = function(e, r) { + return Math.atan2(r, e) - Math.PI / 2; + }, ui = Math.log2 || function(t) { + return Math.log(t) / Math.log(2); + }, Es = function(e) { + return e > 0 ? 1 : e < 0 ? -1 : 0; + }, Br = function(e, r) { + return Math.sqrt(Fr(e, r)); + }, Fr = function(e, r) { + var a = r.x - e.x, n = r.y - e.y; + return a * a + n * n; + }, bf = function(e) { + for (var r = e.length, a = 0, n = 0; n < r; n++) + a += e[n]; + for (var i = 0; i < r; i++) + e[i] = e[i] / a; + return e; + }, Lt = function(e, r, a, n) { + return (1 - n) * (1 - n) * e + 2 * (1 - n) * n * r + n * n * a; + }, ea = function(e, r, a, n) { + return { + x: Lt(e.x, r.x, a.x, n), + y: Lt(e.y, r.y, a.y, n) + }; + }, Ef = function(e, r, a, n) { + var i = { + x: r.x - e.x, + y: r.y - e.y + }, s = Br(e, r), o = { + x: i.x / s, + y: i.y / s + }; + return a = a ?? 0, n = n ?? a * s, { + x: e.x + o.x * n, + y: e.y + o.y * n + }; + }, ka = function(e, r, a) { + return Math.max(e, Math.min(a, r)); + }, Yt = function(e) { + if (e == null) + return { + x1: 1 / 0, + y1: 1 / 0, + x2: -1 / 0, + y2: -1 / 0, + w: 0, + h: 0 + }; + if (e.x1 != null && e.y1 != null) { + if (e.x2 != null && e.y2 != null && e.x2 >= e.x1 && e.y2 >= e.y1) + return { + x1: e.x1, + y1: e.y1, + x2: e.x2, + y2: e.y2, + w: e.x2 - e.x1, + h: e.y2 - e.y1 + }; + if (e.w != null && e.h != null && e.w >= 0 && e.h >= 0) + return { + x1: e.x1, + y1: e.y1, + x2: e.x1 + e.w, + y2: e.y1 + e.h, + w: e.w, + h: e.h + }; + } + }, wf = function(e) { + return { + x1: e.x1, + x2: e.x2, + w: e.w, + y1: e.y1, + y2: e.y2, + h: e.h + }; + }, xf = function(e) { + e.x1 = 1 / 0, e.y1 = 1 / 0, e.x2 = -1 / 0, e.y2 = -1 / 0, e.w = 0, e.h = 0; + }, Tf = function(e, r, a) { + return { + x1: e.x1 + r, + x2: e.x2 + r, + y1: e.y1 + a, + y2: e.y2 + a, + w: e.w, + h: e.h + }; + }, ws = function(e, r) { + e.x1 = Math.min(e.x1, r.x1), e.x2 = Math.max(e.x2, r.x2), e.w = e.x2 - e.x1, e.y1 = Math.min(e.y1, r.y1), e.y2 = Math.max(e.y2, r.y2), e.h = e.y2 - e.y1; + }, Cf = function(e, r, a) { + e.x1 = Math.min(e.x1, r), e.x2 = Math.max(e.x2, r), e.w = e.x2 - e.x1, e.y1 = Math.min(e.y1, a), e.y2 = Math.max(e.y2, a), e.h = e.y2 - e.y1; + }, dn = function(e) { + var r = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : 0; + return e.x1 -= r, e.x2 += r, e.y1 -= r, e.y2 += r, e.w = e.x2 - e.x1, e.h = e.y2 - e.y1, e; + }, gn = function(e) { + var r = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : [0], a, n, i, s; + if (r.length === 1) + a = n = i = s = r[0]; + else if (r.length === 2) + a = i = r[0], s = n = r[1]; + else if (r.length === 4) { + var o = x(r, 4); + a = o[0], n = o[1], i = o[2], s = o[3]; + } + return e.x1 -= s, e.x2 += n, e.y1 -= a, e.y2 += i, e.w = e.x2 - e.x1, e.h = e.y2 - e.y1, e; + }, xs = function(e, r) { + e.x1 = r.x1, e.y1 = r.y1, e.x2 = r.x2, e.y2 = r.y2, e.w = e.x2 - e.x1, e.h = e.y2 - e.y1; + }, fi = function(e, r) { + return !(e.x1 > r.x2 || r.x1 > e.x2 || e.x2 < r.x1 || r.x2 < e.x1 || e.y2 < r.y1 || r.y2 < e.y1 || e.y1 > r.y2 || r.y1 > e.y2); + }, ta = function(e, r, a) { + return e.x1 <= r && r <= e.x2 && e.y1 <= a && a <= e.y2; + }, Df = function(e, r) { + return ta(e, r.x, r.y); + }, Ts = function(e, r) { + return ta(e, r.x1, r.y1) && ta(e, r.x2, r.y2); + }, Cs = function(e, r, a, n, i, s, o) { + var u = Fa(i, s), l = i / 2, f = s / 2, h; + { + var v = a - l + u - o, d = n - f - o, c = a + l - u + o, y = d; + if (h = Cr(e, r, a, n, v, d, c, y, !1), h.length > 0) + return h; + } + { + var p = a + l + o, g = n - f + u - o, m = p, b = n + f - u + o; + if (h = Cr(e, r, a, n, p, g, m, b, !1), h.length > 0) + return h; + } + { + var E = a - l + u - o, M = n + f + o, L = a + l - u + o, w = M; + if (h = Cr(e, r, a, n, E, M, L, w, !1), h.length > 0) + return h; + } + { + var k = a - l - o, D = n - f + u - o, F = k, G = n + f - u + o; + if (h = Cr(e, r, a, n, k, D, F, G, !1), h.length > 0) + return h; + } + var N; + { + var X = a - l + u, B = n - f + u; + if (N = Pa(e, r, a, n, X, B, u + o), N.length > 0 && N[0] <= X && N[1] <= B) + return [N[0], N[1]]; + } + { + var re = a + l - u, K = n - f + u; + if (N = Pa(e, r, a, n, re, K, u + o), N.length > 0 && N[0] >= re && N[1] <= K) + return [N[0], N[1]]; + } + { + var W = a + l - u, ae = n + f - u; + if (N = Pa(e, r, a, n, W, ae, u + o), N.length > 0 && N[0] >= W && N[1] >= ae) + return [N[0], N[1]]; + } + { + var ue = a - l + u, me = n + f - u; + if (N = Pa(e, r, a, n, ue, me, u + o), N.length > 0 && N[0] <= ue && N[1] >= me) + return [N[0], N[1]]; + } + return []; + }, Sf = function(e, r, a, n, i, s, o) { + var u = o, l = Math.min(a, i), f = Math.max(a, i), h = Math.min(n, s), v = Math.max(n, s); + return l - u <= e && e <= f + u && h - u <= r && r <= v + u; + }, Lf = function(e, r, a, n, i, s, o, u, l) { + var f = { + x1: Math.min(a, o, i) - l, + x2: Math.max(a, o, i) + l, + y1: Math.min(n, u, s) - l, + y2: Math.max(n, u, s) + l + }; + return !(e < f.x1 || e > f.x2 || r < f.y1 || r > f.y2); + }, Af = function(e, r, a, n) { + a -= n; + var i = r * r - 4 * e * a; + if (i < 0) + return []; + var s = Math.sqrt(i), o = 2 * e, u = (-r + s) / o, l = (-r - s) / o; + return [u, l]; + }, Of = function(e, r, a, n, i) { + var s = 1e-5; + e === 0 && (e = s), r /= e, a /= e, n /= e; + var o, u, l, f, h, v, d, c; + if (u = (3 * a - r * r) / 9, l = -(27 * n) + r * (9 * a - 2 * (r * r)), l /= 54, o = u * u * u + l * l, i[1] = 0, d = r / 3, o > 0) { + h = l + Math.sqrt(o), h = h < 0 ? -Math.pow(-h, 1 / 3) : Math.pow(h, 1 / 3), v = l - Math.sqrt(o), v = v < 0 ? -Math.pow(-v, 1 / 3) : Math.pow(v, 1 / 3), i[0] = -d + h + v, d += (h + v) / 2, i[4] = i[2] = -d, d = Math.sqrt(3) * (-v + h) / 2, i[3] = d, i[5] = -d; + return; + } + if (i[5] = i[3] = 0, o === 0) { + c = l < 0 ? -Math.pow(-l, 1 / 3) : Math.pow(l, 1 / 3), i[0] = -d + 2 * c, i[4] = i[2] = -(c + d); + return; + } + u = -u, f = u * u * u, f = Math.acos(l / Math.sqrt(f)), c = 2 * Math.sqrt(u), i[0] = -d + c * Math.cos(f / 3), i[2] = -d + c * Math.cos((f + 2 * Math.PI) / 3), i[4] = -d + c * Math.cos((f + 4 * Math.PI) / 3); + }, Nf = function(e, r, a, n, i, s, o, u) { + var l = 1 * a * a - 4 * a * i + 2 * a * o + 4 * i * i - 4 * i * o + o * o + n * n - 4 * n * s + 2 * n * u + 4 * s * s - 4 * s * u + u * u, f = 1 * 9 * a * i - 3 * a * a - 3 * a * o - 6 * i * i + 3 * i * o + 9 * n * s - 3 * n * n - 3 * n * u - 6 * s * s + 3 * s * u, h = 1 * 3 * a * a - 6 * a * i + a * o - a * e + 2 * i * i + 2 * i * e - o * e + 3 * n * n - 6 * n * s + n * u - n * r + 2 * s * s + 2 * s * r - u * r, v = 1 * a * i - a * a + a * e - i * e + n * s - n * n + n * r - s * r, d = []; + Of(l, f, h, v, d); + for (var c = 1e-7, y = [], p = 0; p < 6; p += 2) + Math.abs(d[p + 1]) < c && d[p] >= 0 && d[p] <= 1 && y.push(d[p]); + y.push(1), y.push(0); + for (var g = -1, m, b, E, M = 0; M < y.length; M++) + m = Math.pow(1 - y[M], 2) * a + 2 * (1 - y[M]) * y[M] * i + y[M] * y[M] * o, b = Math.pow(1 - y[M], 2) * n + 2 * (1 - y[M]) * y[M] * s + y[M] * y[M] * u, E = Math.pow(m - e, 2) + Math.pow(b - r, 2), g >= 0 ? E < g && (g = E) : g = E; + return g; + }, If = function(e, r, a, n, i, s) { + var o = [e - a, r - n], u = [i - a, s - n], l = u[0] * u[0] + u[1] * u[1], f = o[0] * o[0] + o[1] * o[1], h = o[0] * u[0] + o[1] * u[1], v = h * h / l; + return h < 0 ? f : v > l ? (e - i) * (e - i) + (r - s) * (r - s) : f - v; + }, Ht = function(e, r, a) { + for (var n, i, s, o, u, l = 0, f = 0; f < a.length / 2; f++) + if (n = a[f * 2], i = a[f * 2 + 1], f + 1 < a.length / 2 ? (s = a[(f + 1) * 2], o = a[(f + 1) * 2 + 1]) : (s = a[(f + 1 - a.length / 2) * 2], o = a[(f + 1 - a.length / 2) * 2 + 1]), !(n == e && s == e)) + if (n >= e && e >= s || n <= e && e <= s) + u = (e - n) / (s - n) * (o - i) + i, u > r && l++; + else + continue; + return l % 2 !== 0; + }, pr = function(e, r, a, n, i, s, o, u, l) { + var f = new Array(a.length), h; + u[0] != null ? (h = Math.atan(u[1] / u[0]), u[0] < 0 ? h = h + Math.PI / 2 : h = -h - Math.PI / 2) : h = u; + for (var v = Math.cos(-h), d = Math.sin(-h), c = 0; c < f.length / 2; c++) + f[c * 2] = s / 2 * (a[c * 2] * v - a[c * 2 + 1] * d), f[c * 2 + 1] = o / 2 * (a[c * 2 + 1] * v + a[c * 2] * d), f[c * 2] += n, f[c * 2 + 1] += i; + var y; + if (l > 0) { + var p = yn(f, -l); + y = pn(p); + } else + y = f; + return Ht(e, r, y); + }, Mf = function(e, r, a, n, i, s, o) { + for (var u = new Array(a.length), l = s / 2, f = o / 2, h = ci(s, o), v = h * h, d = 0; d < a.length / 4; d++) { + var c = void 0, y = void 0; + d === 0 ? c = a.length - 2 : c = d * 4 - 2, y = d * 4 + 2; + var p = n + l * a[d * 4], g = i + f * a[d * 4 + 1], m = -a[c] * a[y] - a[c + 1] * a[y + 1], b = h / Math.tan(Math.acos(m) / 2), E = p - b * a[c], M = g - b * a[c + 1], L = p + b * a[y], w = g + b * a[y + 1]; + u[d * 4] = E, u[d * 4 + 1] = M, u[d * 4 + 2] = L, u[d * 4 + 3] = w; + var k = a[c + 1], D = -a[c], F = k * a[y] + D * a[y + 1]; + F < 0 && (k *= -1, D *= -1); + var G = E + k * h, N = M + D * h, X = Math.pow(G - e, 2) + Math.pow(N - r, 2); + if (X <= v) + return !0; + } + return Ht(e, r, u); + }, pn = function(e) { + for (var r = new Array(e.length / 2), a, n, i, s, o, u, l, f, h = 0; h < e.length / 4; h++) { + a = e[h * 4], n = e[h * 4 + 1], i = e[h * 4 + 2], s = e[h * 4 + 3], h < e.length / 4 - 1 ? (o = e[(h + 1) * 4], u = e[(h + 1) * 4 + 1], l = e[(h + 1) * 4 + 2], f = e[(h + 1) * 4 + 3]) : (o = e[0], u = e[1], l = e[2], f = e[3]); + var v = Cr(a, n, i, s, o, u, l, f, !0); + r[h * 2] = v[0], r[h * 2 + 1] = v[1]; + } + return r; + }, yn = function(e, r) { + for (var a = new Array(e.length * 2), n, i, s, o, u = 0; u < e.length / 2; u++) { + n = e[u * 2], i = e[u * 2 + 1], u < e.length / 2 - 1 ? (s = e[(u + 1) * 2], o = e[(u + 1) * 2 + 1]) : (s = e[0], o = e[1]); + var l = o - i, f = -(s - n), h = Math.sqrt(l * l + f * f), v = l / h, d = f / h; + a[u * 4] = n + v * r, a[u * 4 + 1] = i + d * r, a[u * 4 + 2] = s + v * r, a[u * 4 + 3] = o + d * r; + } + return a; + }, Rf = function(e, r, a, n, i, s) { + var o = a - e, u = n - r; + o /= i, u /= s; + var l = Math.sqrt(o * o + u * u), f = l - 1; + if (f < 0) + return []; + var h = f / l; + return [(a - e) * h + e, (n - r) * h + r]; + }, Gr = function(e, r, a, n, i, s, o) { + return e -= i, r -= s, e /= a / 2 + o, r /= n / 2 + o, e * e + r * r <= 1; + }, Pa = function(e, r, a, n, i, s, o) { + var u = [a - e, n - r], l = [e - i, r - s], f = u[0] * u[0] + u[1] * u[1], h = 2 * (l[0] * u[0] + l[1] * u[1]), v = l[0] * l[0] + l[1] * l[1] - o * o, d = h * h - 4 * f * v; + if (d < 0) + return []; + var c = (-h + Math.sqrt(d)) / (2 * f), y = (-h - Math.sqrt(d)) / (2 * f), p = Math.min(c, y), g = Math.max(c, y), m = []; + if (p >= 0 && p <= 1 && m.push(p), g >= 0 && g <= 1 && m.push(g), m.length === 0) + return []; + var b = m[0] * u[0] + e, E = m[0] * u[1] + r; + if (m.length > 1) { + if (m[0] == m[1]) + return [b, E]; + var M = m[1] * u[0] + e, L = m[1] * u[1] + r; + return [b, E, M, L]; + } else + return [b, E]; + }, hi = function(e, r, a) { + return r <= e && e <= a || a <= e && e <= r ? e : e <= r && r <= a || a <= r && r <= e ? r : a; + }, Cr = function(e, r, a, n, i, s, o, u, l) { + var f = e - i, h = a - e, v = o - i, d = r - s, c = n - r, y = u - s, p = v * d - y * f, g = h * d - c * f, m = y * h - v * c; + if (m !== 0) { + var b = p / m, E = g / m, M = 1e-3, L = 0 - M, w = 1 + M; + return L <= b && b <= w && L <= E && E <= w ? [e + b * h, r + b * c] : l ? [e + b * h, r + b * c] : []; + } else + return p === 0 || g === 0 ? hi(e, a, o) === o ? [o, u] : hi(e, a, i) === i ? [i, s] : hi(i, o, a) === a ? [a, n] : [] : []; + }, Ba = function(e, r, a, n, i, s, o, u) { + var l = [], f, h = new Array(a.length), v = !0; + s == null && (v = !1); + var d; + if (v) { + for (var c = 0; c < h.length / 2; c++) + h[c * 2] = a[c * 2] * s + n, h[c * 2 + 1] = a[c * 2 + 1] * o + i; + if (u > 0) { + var y = yn(h, -u); + d = pn(y); + } else + d = h; + } else + d = a; + for (var p, g, m, b, E = 0; E < d.length / 2; E++) + p = d[E * 2], g = d[E * 2 + 1], E < d.length / 2 - 1 ? (m = d[(E + 1) * 2], b = d[(E + 1) * 2 + 1]) : (m = d[0], b = d[1]), f = Cr(e, r, n, i, p, g, m, b), f.length !== 0 && l.push(f[0], f[1]); + return l; + }, kf = function(e, r, a, n, i, s, o, u) { + for (var l = [], f, h = new Array(a.length), v = s / 2, d = o / 2, c = ci(s, o), y = 0; y < a.length / 4; y++) { + var p = void 0, g = void 0; + y === 0 ? p = a.length - 2 : p = y * 4 - 2, g = y * 4 + 2; + var m = n + v * a[y * 4], b = i + d * a[y * 4 + 1], E = -a[p] * a[g] - a[p + 1] * a[g + 1], M = c / Math.tan(Math.acos(E) / 2), L = m - M * a[p], w = b - M * a[p + 1], k = m + M * a[g], D = b + M * a[g + 1]; + y === 0 ? (h[a.length - 2] = L, h[a.length - 1] = w) : (h[y * 4 - 2] = L, h[y * 4 - 1] = w), h[y * 4] = k, h[y * 4 + 1] = D; + var F = a[p + 1], G = -a[p], N = F * a[g] + G * a[g + 1]; + N < 0 && (F *= -1, G *= -1); + var X = L + F * c, B = w + G * c; + f = Pa(e, r, n, i, X, B, c), f.length !== 0 && l.push(f[0], f[1]); + } + for (var re = 0; re < h.length / 4; re++) + f = Cr(e, r, n, i, h[re * 4], h[re * 4 + 1], h[re * 4 + 2], h[re * 4 + 3], !1), f.length !== 0 && l.push(f[0], f[1]); + if (l.length > 2) { + for (var K = [l[0], l[1]], W = Math.pow(K[0] - e, 2) + Math.pow(K[1] - r, 2), ae = 1; ae < l.length / 2; ae++) { + var ue = Math.pow(l[ae * 2] - e, 2) + Math.pow(l[ae * 2 + 1] - r, 2); + ue <= W && (K[0] = l[ae * 2], K[1] = l[ae * 2 + 1], W = ue); + } + return K; + } + return l; + }, mn = function(e, r, a) { + var n = [e[0] - r[0], e[1] - r[1]], i = Math.sqrt(n[0] * n[0] + n[1] * n[1]), s = (i - a) / i; + return s < 0 && (s = 1e-5), [r[0] + s * n[0], r[1] + s * n[1]]; + }, $t = function(e, r) { + var a = vi(e, r); + return a = Ds(a), a; + }, Ds = function(e) { + for (var r, a, n = e.length / 2, i = 1 / 0, s = 1 / 0, o = -1 / 0, u = -1 / 0, l = 0; l < n; l++) + r = e[2 * l], a = e[2 * l + 1], i = Math.min(i, r), o = Math.max(o, r), s = Math.min(s, a), u = Math.max(u, a); + for (var f = 2 / (o - i), h = 2 / (u - s), v = 0; v < n; v++) + r = e[2 * v] = e[2 * v] * f, a = e[2 * v + 1] = e[2 * v + 1] * h, i = Math.min(i, r), o = Math.max(o, r), s = Math.min(s, a), u = Math.max(u, a); + if (s < -1) + for (var d = 0; d < n; d++) + a = e[2 * d + 1] = e[2 * d + 1] + (-1 - s); + return e; + }, vi = function(e, r) { + var a = 1 / e * 2 * Math.PI, n = e % 2 === 0 ? Math.PI / 2 + a / 2 : Math.PI / 2; + n += r; + for (var i = new Array(e * 2), s, o = 0; o < e; o++) + s = o * a + n, i[2 * o] = Math.cos(s), i[2 * o + 1] = Math.sin(-s); + return i; + }, Fa = function(e, r) { + return Math.min(e / 4, r / 4, 8); + }, ci = function(e, r) { + return Math.min(e / 10, r / 10, 8); + }, Ss = function() { + return 8; + }, Pf = function(e, r, a) { + return [e - 2 * r + a, 2 * (r - e), e]; + }, di = function(e, r) { + return { + heightOffset: Math.min(15, 0.05 * r), + widthOffset: Math.min(100, 0.25 * e), + ctrlPtOffsetPct: 0.05 + }; + }, Bf = At({ + dampingFactor: 0.8, + precision: 1e-6, + iterations: 200, + weight: function(e) { + return 1; + } + }), Ff = { + pageRank: function(e) { + for (var r = Bf(e), a = r.dampingFactor, n = r.precision, i = r.iterations, s = r.weight, o = this._private.cy, u = this.byGroup(), l = u.nodes, f = u.edges, h = l.length, v = h * h, d = f.length, c = new Array(v), y = new Array(h), p = (1 - a) / h, g = 0; g < h; g++) { + for (var m = 0; m < h; m++) { + var b = g * h + m; + c[b] = 0; + } + y[g] = 0; + } + for (var E = 0; E < d; E++) { + var M = f[E], L = M.data("source"), w = M.data("target"); + if (L !== w) { + var k = l.indexOfId(L), D = l.indexOfId(w), F = s(M), G = D * h + k; + c[G] += F, y[k] += F; + } + } + for (var N = 1 / h + p, X = 0; X < h; X++) + if (y[X] === 0) + for (var B = 0; B < h; B++) { + var re = B * h + X; + c[re] = N; + } + else + for (var K = 0; K < h; K++) { + var W = K * h + X; + c[W] = c[W] / y[X] + p; + } + for (var ae = new Array(h), ue = new Array(h), me, ie = 0; ie < h; ie++) + ae[ie] = 1; + for (var ge = 0; ge < i; ge++) { + for (var Ee = 0; Ee < h; Ee++) + ue[Ee] = 0; + for (var Ce = 0; Ce < h; Ce++) + for (var we = 0; we < h; we++) { + var De = Ce * h + we; + ue[Ce] += c[De] * ae[we]; + } + bf(ue), me = ae, ae = ue, ue = me; + for (var se = 0, xe = 0; xe < h; xe++) { + var Le = me[xe] - ae[xe]; + se += Le * Le; + } + if (se < n) + break; + } + var Se = { + rank: function(Fe) { + return Fe = o.collection(Fe)[0], ae[l.indexOf(Fe)]; + } + }; + return Se; + } + // pageRank + }, Ls = At({ + root: null, + weight: function(e) { + return 1; + }, + directed: !1, + alpha: 0 + }), ra = { + degreeCentralityNormalized: function(e) { + e = Ls(e); + var r = this.cy(), a = this.nodes(), n = a.length; + if (e.directed) { + for (var f = {}, h = {}, v = 0, d = 0, c = 0; c < n; c++) { + var y = a[c], p = y.id(); + e.root = y; + var g = this.degreeCentrality(e); + v < g.indegree && (v = g.indegree), d < g.outdegree && (d = g.outdegree), f[p] = g.indegree, h[p] = g.outdegree; + } + return { + indegree: function(b) { + return v == 0 ? 0 : (ee(b) && (b = r.filter(b)), f[b.id()] / v); + }, + outdegree: function(b) { + return d === 0 ? 0 : (ee(b) && (b = r.filter(b)), h[b.id()] / d); + } + }; + } else { + for (var i = {}, s = 0, o = 0; o < n; o++) { + var u = a[o]; + e.root = u; + var l = this.degreeCentrality(e); + s < l.degree && (s = l.degree), i[u.id()] = l.degree; + } + return { + degree: function(b) { + return s === 0 ? 0 : (ee(b) && (b = r.filter(b)), i[b.id()] / s); + } + }; + } + }, + // degreeCentralityNormalized + // Implemented from the algorithm in Opsahl's paper + // "Node centrality in weighted networks: Generalizing degree and shortest paths" + // check the heading 2 "Degree" + degreeCentrality: function(e) { + e = Ls(e); + var r = this.cy(), a = this, n = e, i = n.root, s = n.weight, o = n.directed, u = n.alpha; + if (i = r.collection(i)[0], o) { + for (var d = i.connectedEdges(), c = d.filter(function(L) { + return L.target().same(i) && a.has(L); + }), y = d.filter(function(L) { + return L.source().same(i) && a.has(L); + }), p = c.length, g = y.length, m = 0, b = 0, E = 0; E < c.length; E++) + m += s(c[E]); + for (var M = 0; M < y.length; M++) + b += s(y[M]); + return { + indegree: Math.pow(p, 1 - u) * Math.pow(m, u), + outdegree: Math.pow(g, 1 - u) * Math.pow(b, u) + }; + } else { + for (var l = i.connectedEdges().intersection(a), f = l.length, h = 0, v = 0; v < l.length; v++) + h += s(l[v]); + return { + degree: Math.pow(f, 1 - u) * Math.pow(h, u) + }; + } + } + // degreeCentrality + }; + ra.dc = ra.degreeCentrality, ra.dcn = ra.degreeCentralityNormalised = ra.degreeCentralityNormalized; + var As = At({ + harmonic: !0, + weight: function() { + return 1; + }, + directed: !1, + root: null + }), aa = { + closenessCentralityNormalized: function(e) { + for (var r = As(e), a = r.harmonic, n = r.weight, i = r.directed, s = this.cy(), o = {}, u = 0, l = this.nodes(), f = this.floydWarshall({ + weight: n, + directed: i + }), h = 0; h < l.length; h++) { + for (var v = 0, d = l[h], c = 0; c < l.length; c++) + if (h !== c) { + var y = f.distance(d, l[c]); + a ? v += 1 / y : v += y; + } + a || (v = 1 / v), u < v && (u = v), o[d.id()] = v; + } + return { + closeness: function(g) { + return u == 0 ? 0 : (ee(g) ? g = s.filter(g)[0].id() : g = g.id(), o[g] / u); + } + }; + }, + // Implemented from pseudocode from wikipedia + closenessCentrality: function(e) { + var r = As(e), a = r.root, n = r.weight, i = r.directed, s = r.harmonic; + a = this.filter(a)[0]; + for (var o = this.dijkstra({ + root: a, + weight: n, + directed: i + }), u = 0, l = this.nodes(), f = 0; f < l.length; f++) { + var h = l[f]; + if (!h.same(a)) { + var v = o.distanceTo(h); + s ? u += 1 / v : u += v; + } + } + return s ? u : 1 / u; + } + // closenessCentrality + }; + aa.cc = aa.closenessCentrality, aa.ccn = aa.closenessCentralityNormalised = aa.closenessCentralityNormalized; + var Gf = At({ + weight: null, + directed: !1 + }), gi = { + // Implemented from the algorithm in the paper "On Variants of Shortest-Path Betweenness Centrality and their Generic Computation" by Ulrik Brandes + betweennessCentrality: function(e) { + for (var r = Gf(e), a = r.directed, n = r.weight, i = n != null, s = this.cy(), o = this.nodes(), u = {}, l = {}, f = 0, h = { + set: function(b, E) { + l[b] = E, E > f && (f = E); + }, + get: function(b) { + return l[b]; + } + }, v = 0; v < o.length; v++) { + var d = o[v], c = d.id(); + a ? u[c] = d.outgoers().nodes() : u[c] = d.openNeighborhood().nodes(), h.set(c, 0); + } + for (var y = function(b) { + for (var E = o[b].id(), M = [], L = {}, w = {}, k = {}, D = new Ra(function(we, De) { + return k[we] - k[De]; + }), F = 0; F < o.length; F++) { + var G = o[F].id(); + L[G] = [], w[G] = 0, k[G] = 1 / 0; + } + for (w[E] = 1, k[E] = 0, D.push(E); !D.empty(); ) { + var N = D.pop(); + if (M.push(N), i) + for (var X = 0; X < u[N].length; X++) { + var B = u[N][X], re = s.getElementById(N), K = void 0; + re.edgesTo(B).length > 0 ? K = re.edgesTo(B)[0] : K = B.edgesTo(re)[0]; + var W = n(K); + B = B.id(), k[B] > k[N] + W && (k[B] = k[N] + W, D.nodes.indexOf(B) < 0 ? D.push(B) : D.updateItem(B), w[B] = 0, L[B] = []), k[B] == k[N] + W && (w[B] = w[B] + w[N], L[B].push(N)); + } + else + for (var ae = 0; ae < u[N].length; ae++) { + var ue = u[N][ae].id(); + k[ue] == 1 / 0 && (D.push(ue), k[ue] = k[N] + 1), k[ue] == k[N] + 1 && (w[ue] = w[ue] + w[N], L[ue].push(N)); + } + } + for (var me = {}, ie = 0; ie < o.length; ie++) + me[o[ie].id()] = 0; + for (; M.length > 0; ) { + for (var ge = M.pop(), Ee = 0; Ee < L[ge].length; Ee++) { + var Ce = L[ge][Ee]; + me[Ce] = me[Ce] + w[Ce] / w[ge] * (1 + me[ge]); + } + ge != o[b].id() && h.set(ge, h.get(ge) + me[ge]); + } + }, p = 0; p < o.length; p++) + y(p); + var g = { + betweenness: function(b) { + var E = s.collection(b).id(); + return h.get(E); + }, + betweennessNormalized: function(b) { + if (f == 0) + return 0; + var E = s.collection(b).id(); + return h.get(E) / f; + } + }; + return g.betweennessNormalised = g.betweennessNormalized, g; + } + // betweennessCentrality + }; + gi.bc = gi.betweennessCentrality; + var zf = At({ + expandFactor: 2, + // affects time of computation and cluster granularity to some extent: M * M + inflateFactor: 2, + // affects cluster granularity (the greater the value, the more clusters): M(i,j) / E(j) + multFactor: 1, + // optional self loops for each node. Use a neutral value to improve cluster computations. + maxIterations: 20, + // maximum number of iterations of the MCL algorithm in a single run + attributes: [ + // attributes/features used to group nodes, ie. similarity values between nodes + function(t) { + return 1; + } + ] + }), Vf = function(e) { + return zf(e); + }, Uf = function(e, r) { + for (var a = 0, n = 0; n < r.length; n++) + a += r[n](e); + return a; + }, $f = function(e, r, a) { + for (var n = 0; n < r; n++) + e[n * r + n] = a; + }, Os = function(e, r) { + for (var a, n = 0; n < r; n++) { + a = 0; + for (var i = 0; i < r; i++) + a += e[i * r + n]; + for (var s = 0; s < r; s++) + e[s * r + n] = e[s * r + n] / a; + } + }, _f = function(e, r, a) { + for (var n = new Array(a * a), i = 0; i < a; i++) { + for (var s = 0; s < a; s++) + n[i * a + s] = 0; + for (var o = 0; o < a; o++) + for (var u = 0; u < a; u++) + n[i * a + u] += e[i * a + o] * r[o * a + u]; + } + return n; + }, Yf = function(e, r, a) { + for (var n = e.slice(0), i = 1; i < a; i++) + e = _f(e, n, r); + return e; + }, Hf = function(e, r, a) { + for (var n = new Array(r * r), i = 0; i < r * r; i++) + n[i] = Math.pow(e[i], a); + return Os(n, r), n; + }, Xf = function(e, r, a, n) { + for (var i = 0; i < a; i++) { + var s = Math.round(e[i] * Math.pow(10, n)) / Math.pow(10, n), o = Math.round(r[i] * Math.pow(10, n)) / Math.pow(10, n); + if (s !== o) + return !1; + } + return !0; + }, Wf = function(e, r, a, n) { + for (var i = [], s = 0; s < r; s++) { + for (var o = [], u = 0; u < r; u++) + Math.round(e[s * r + u] * 1e3) / 1e3 > 0 && o.push(a[u]); + o.length !== 0 && i.push(n.collection(o)); + } + return i; + }, qf = function(e, r) { + for (var a = 0; a < e.length; a++) + if (!r[a] || e[a].id() !== r[a].id()) + return !1; + return !0; + }, Kf = function(e) { + for (var r = 0; r < e.length; r++) + for (var a = 0; a < e.length; a++) + r != a && qf(e[r], e[a]) && e.splice(a, 1); + return e; + }, Ns = function(e) { + for (var r = this.nodes(), a = this.edges(), n = this.cy(), i = Vf(e), s = {}, o = 0; o < r.length; o++) + s[r[o].id()] = o; + for (var u = r.length, l = u * u, f = new Array(l), h, v = 0; v < l; v++) + f[v] = 0; + for (var d = 0; d < a.length; d++) { + var c = a[d], y = s[c.source().id()], p = s[c.target().id()], g = Uf(c, i.attributes); + f[y * u + p] += g, f[p * u + y] += g; + } + $f(f, u, i.multFactor), Os(f, u); + for (var m = !0, b = 0; m && b < i.maxIterations; ) + m = !1, h = Yf(f, u, i.expandFactor), f = Hf(h, u, i.inflateFactor), Xf(f, h, l, 4) || (m = !0), b++; + var E = Wf(f, u, r, n); + return E = Kf(E), E; + }, Zf = { + markovClustering: Ns, + mcl: Ns + }, Qf = function(e) { + return e; + }, Is = function(e, r) { + return Math.abs(r - e); + }, Ms = function(e, r, a) { + return e + Is(r, a); + }, Rs = function(e, r, a) { + return e + Math.pow(a - r, 2); + }, Jf = function(e) { + return Math.sqrt(e); + }, jf = function(e, r, a) { + return Math.max(e, Is(r, a)); + }, Ga = function(e, r, a, n, i) { + for (var s = arguments.length > 5 && arguments[5] !== void 0 ? arguments[5] : Qf, o = n, u, l, f = 0; f < e; f++) + u = r(f), l = a(f), o = i(o, u, l); + return s(o); + }, na = { + euclidean: function(e, r, a) { + return e >= 2 ? Ga(e, r, a, 0, Rs, Jf) : Ga(e, r, a, 0, Ms); + }, + squaredEuclidean: function(e, r, a) { + return Ga(e, r, a, 0, Rs); + }, + manhattan: function(e, r, a) { + return Ga(e, r, a, 0, Ms); + }, + max: function(e, r, a) { + return Ga(e, r, a, -1 / 0, jf); + } + }; + na["squared-euclidean"] = na.squaredEuclidean, na.squaredeuclidean = na.squaredEuclidean; + function bn(t, e, r, a, n, i) { + var s; + return H(t) ? s = t : s = na[t] || na.euclidean, e === 0 && H(t) ? s(n, i) : s(e, r, a, n, i); + } + var eh = At({ + k: 2, + m: 2, + sensitivityThreshold: 1e-4, + distance: "euclidean", + maxIterations: 10, + attributes: [], + testMode: !1, + testCentroids: null + }), pi = function(e) { + return eh(e); + }, En = function(e, r, a, n, i) { + var s = i !== "kMedoids", o = s ? function(h) { + return a[h]; + } : function(h) { + return n[h](a); + }, u = function(v) { + return n[v](r); + }, l = a, f = r; + return bn(e, n.length, o, u, l, f); + }, yi = function(e, r, a) { + for (var n = a.length, i = new Array(n), s = new Array(n), o = new Array(r), u = null, l = 0; l < n; l++) + i[l] = e.min(a[l]).value, s[l] = e.max(a[l]).value; + for (var f = 0; f < r; f++) { + u = []; + for (var h = 0; h < n; h++) + u[h] = Math.random() * (s[h] - i[h]) + i[h]; + o[f] = u; + } + return o; + }, ks = function(e, r, a, n, i) { + for (var s = 1 / 0, o = 0, u = 0; u < r.length; u++) { + var l = En(a, e, r[u], n, i); + l < s && (s = l, o = u); + } + return o; + }, Ps = function(e, r, a) { + for (var n = [], i = null, s = 0; s < r.length; s++) + i = r[s], a[i.id()] === e && n.push(i); + return n; + }, th = function(e, r, a) { + return Math.abs(r - e) <= a; + }, rh = function(e, r, a) { + for (var n = 0; n < e.length; n++) + for (var i = 0; i < e[n].length; i++) { + var s = Math.abs(e[n][i] - r[n][i]); + if (s > a) + return !1; + } + return !0; + }, ah = function(e, r, a) { + for (var n = 0; n < a; n++) + if (e === r[n]) + return !0; + return !1; + }, Bs = function(e, r) { + var a = new Array(r); + if (e.length < 50) + for (var n = 0; n < r; n++) { + for (var i = e[Math.floor(Math.random() * e.length)]; ah(i, a, n); ) + i = e[Math.floor(Math.random() * e.length)]; + a[n] = i; + } + else + for (var s = 0; s < r; s++) + a[s] = e[Math.floor(Math.random() * e.length)]; + return a; + }, Fs = function(e, r, a) { + for (var n = 0, i = 0; i < r.length; i++) + n += En("manhattan", r[i], e, a, "kMedoids"); + return n; + }, nh = function(e) { + var r = this.cy(), a = this.nodes(), n = null, i = pi(e), s = new Array(i.k), o = {}, u; + i.testMode ? typeof i.testCentroids == "number" ? (i.testCentroids, u = yi(a, i.k, i.attributes)) : _(i.testCentroids) === "object" ? u = i.testCentroids : u = yi(a, i.k, i.attributes) : u = yi(a, i.k, i.attributes); + for (var l = !0, f = 0; l && f < i.maxIterations; ) { + for (var h = 0; h < a.length; h++) + n = a[h], o[n.id()] = ks(n, u, i.distance, i.attributes, "kMeans"); + l = !1; + for (var v = 0; v < i.k; v++) { + var d = Ps(v, a, o); + if (d.length !== 0) { + for (var c = i.attributes.length, y = u[v], p = new Array(c), g = new Array(c), m = 0; m < c; m++) { + g[m] = 0; + for (var b = 0; b < d.length; b++) + n = d[b], g[m] += i.attributes[m](n); + p[m] = g[m] / d.length, th(p[m], y[m], i.sensitivityThreshold) || (l = !0); + } + u[v] = p, s[v] = r.collection(d); + } + } + f++; + } + return s; + }, ih = function(e) { + var r = this.cy(), a = this.nodes(), n = null, i = pi(e), s = new Array(i.k), o, u = {}, l, f = new Array(i.k); + i.testMode ? typeof i.testCentroids == "number" || (_(i.testCentroids) === "object" ? o = i.testCentroids : o = Bs(a, i.k)) : o = Bs(a, i.k); + for (var h = !0, v = 0; h && v < i.maxIterations; ) { + for (var d = 0; d < a.length; d++) + n = a[d], u[n.id()] = ks(n, o, i.distance, i.attributes, "kMedoids"); + h = !1; + for (var c = 0; c < o.length; c++) { + var y = Ps(c, a, u); + if (y.length !== 0) { + f[c] = Fs(o[c], y, i.attributes); + for (var p = 0; p < y.length; p++) + l = Fs(y[p], y, i.attributes), l < f[c] && (f[c] = l, o[c] = y[p], h = !0); + s[c] = r.collection(y); + } + } + v++; + } + return s; + }, sh = function(e, r, a, n, i) { + for (var s, o, u = 0; u < r.length; u++) + for (var l = 0; l < e.length; l++) + n[u][l] = Math.pow(a[u][l], i.m); + for (var f = 0; f < e.length; f++) + for (var h = 0; h < i.attributes.length; h++) { + s = 0, o = 0; + for (var v = 0; v < r.length; v++) + s += n[v][f] * i.attributes[h](r[v]), o += n[v][f]; + e[f][h] = s / o; + } + }, oh = function(e, r, a, n, i) { + for (var s = 0; s < e.length; s++) + r[s] = e[s].slice(); + for (var o, u, l, f = 2 / (i.m - 1), h = 0; h < a.length; h++) + for (var v = 0; v < n.length; v++) { + o = 0; + for (var d = 0; d < a.length; d++) + u = En(i.distance, n[v], a[h], i.attributes, "cmeans"), l = En(i.distance, n[v], a[d], i.attributes, "cmeans"), o += Math.pow(u / l, f); + e[v][h] = 1 / o; + } + }, lh = function(e, r, a, n) { + for (var i = new Array(a.k), s = 0; s < i.length; s++) + i[s] = []; + for (var o, u, l = 0; l < r.length; l++) { + o = -1 / 0, u = -1; + for (var f = 0; f < r[0].length; f++) + r[l][f] > o && (o = r[l][f], u = f); + i[u].push(e[l]); + } + for (var h = 0; h < i.length; h++) + i[h] = n.collection(i[h]); + return i; + }, Gs = function(e) { + var r = this.cy(), a = this.nodes(), n = pi(e), i, s, o, u, l; + u = new Array(a.length); + for (var f = 0; f < a.length; f++) + u[f] = new Array(n.k); + o = new Array(a.length); + for (var h = 0; h < a.length; h++) + o[h] = new Array(n.k); + for (var v = 0; v < a.length; v++) { + for (var d = 0, c = 0; c < n.k; c++) + o[v][c] = Math.random(), d += o[v][c]; + for (var y = 0; y < n.k; y++) + o[v][y] = o[v][y] / d; + } + s = new Array(n.k); + for (var p = 0; p < n.k; p++) + s[p] = new Array(n.attributes.length); + l = new Array(a.length); + for (var g = 0; g < a.length; g++) + l[g] = new Array(n.k); + for (var m = !0, b = 0; m && b < n.maxIterations; ) + m = !1, sh(s, a, o, l, n), oh(o, u, s, a, n), rh(o, u, n.sensitivityThreshold) || (m = !0), b++; + return i = lh(a, o, n, r), { + clusters: i, + degreeOfMembership: o + }; + }, uh = { + kMeans: nh, + kMedoids: ih, + fuzzyCMeans: Gs, + fcm: Gs + }, fh = At({ + distance: "euclidean", + // distance metric to compare nodes + linkage: "min", + // linkage criterion : how to determine the distance between clusters of nodes + mode: "threshold", + // mode:'threshold' => clusters must be threshold distance apart + threshold: 1 / 0, + // the distance threshold + // mode:'dendrogram' => the nodes are organised as leaves in a tree (siblings are close), merging makes clusters + addDendrogram: !1, + // whether to add the dendrogram to the graph for viz + dendrogramDepth: 0, + // depth at which dendrogram branches are merged into the returned clusters + attributes: [] + // array of attr functions + }), hh = { + single: "min", + complete: "max" + }, vh = function(e) { + var r = fh(e), a = hh[r.linkage]; + return a != null && (r.linkage = a), r; + }, zs = function(e, r, a, n, i) { + for (var s = 0, o = 1 / 0, u, l = i.attributes, f = function(D, F) { + return bn(i.distance, l.length, function(G) { + return l[G](D); + }, function(G) { + return l[G](F); + }, D, F); + }, h = 0; h < e.length; h++) { + var v = e[h].key, d = a[v][n[v]]; + d < o && (s = v, o = d); + } + if (i.mode === "threshold" && o >= i.threshold || i.mode === "dendrogram" && e.length === 1) + return !1; + var c = r[s], y = r[n[s]], p; + i.mode === "dendrogram" ? p = { + left: c, + right: y, + key: c.key + } : p = { + value: c.value.concat(y.value), + key: c.key + }, e[c.index] = p, e.splice(y.index, 1), r[c.key] = p; + for (var g = 0; g < e.length; g++) { + var m = e[g]; + c.key === m.key ? u = 1 / 0 : i.linkage === "min" ? (u = a[c.key][m.key], a[c.key][m.key] > a[y.key][m.key] && (u = a[y.key][m.key])) : i.linkage === "max" ? (u = a[c.key][m.key], a[c.key][m.key] < a[y.key][m.key] && (u = a[y.key][m.key])) : i.linkage === "mean" ? u = (a[c.key][m.key] * c.size + a[y.key][m.key] * y.size) / (c.size + y.size) : i.mode === "dendrogram" ? u = f(m.value, c.value) : u = f(m.value[0], c.value[0]), a[c.key][m.key] = a[m.key][c.key] = u; + } + for (var b = 0; b < e.length; b++) { + var E = e[b].key; + if (n[E] === c.key || n[E] === y.key) { + for (var M = E, L = 0; L < e.length; L++) { + var w = e[L].key; + a[E][w] < a[E][M] && (M = w); + } + n[E] = M; + } + e[b].index = b; + } + return c.key = y.key = c.index = y.index = null, !0; + }, wn = function t(e, r, a) { + e && (e.value ? r.push(e.value) : (e.left && t(e.left, r), e.right && t(e.right, r))); + }, ch = function t(e, r) { + if (!e) + return ""; + if (e.left && e.right) { + var a = t(e.left, r), n = t(e.right, r), i = r.add({ + group: "nodes", + data: { + id: a + "," + n + } + }); + return r.add({ + group: "edges", + data: { + source: a, + target: i.id() + } + }), r.add({ + group: "edges", + data: { + source: n, + target: i.id() + } + }), i.id(); + } else if (e.value) + return e.value.id(); + }, dh = function t(e, r, a) { + if (!e) + return []; + var n = [], i = [], s = []; + return r === 0 ? (e.left && wn(e.left, n), e.right && wn(e.right, i), s = n.concat(i), [a.collection(s)]) : r === 1 ? e.value ? [a.collection(e.value)] : (e.left && wn(e.left, n), e.right && wn(e.right, i), [a.collection(n), a.collection(i)]) : e.value ? [a.collection(e.value)] : (e.left && (n = t(e.left, r - 1, a)), e.right && (i = t(e.right, r - 1, a)), n.concat(i)); + }, Vs = function(e) { + for (var r = this.cy(), a = this.nodes(), n = vh(e), i = n.attributes, s = function(b, E) { + return bn(n.distance, i.length, function(M) { + return i[M](b); + }, function(M) { + return i[M](E); + }, b, E); + }, o = [], u = [], l = [], f = [], h = 0; h < a.length; h++) { + var v = { + value: n.mode === "dendrogram" ? a[h] : [a[h]], + key: h, + index: h + }; + o[h] = v, f[h] = v, u[h] = [], l[h] = 0; + } + for (var d = 0; d < o.length; d++) + for (var c = 0; c <= d; c++) { + var y = void 0; + n.mode === "dendrogram" ? y = d === c ? 1 / 0 : s(o[d].value, o[c].value) : y = d === c ? 1 / 0 : s(o[d].value[0], o[c].value[0]), u[d][c] = y, u[c][d] = y, y < u[d][l[d]] && (l[d] = c); + } + for (var p = zs(o, f, u, l, n); p; ) + p = zs(o, f, u, l, n); + var g; + return n.mode === "dendrogram" ? (g = dh(o[0], n.dendrogramDepth, r), n.addDendrogram && ch(o[0], r)) : (g = new Array(o.length), o.forEach(function(m, b) { + m.key = m.index = null, g[b] = r.collection(m.value); + })), g; + }, gh = { + hierarchicalClustering: Vs, + hca: Vs + }, ph = At({ + distance: "euclidean", + // distance metric to compare attributes between two nodes + preference: "median", + // suitability of a data point to serve as an exemplar + damping: 0.8, + // damping factor between [0.5, 1) + maxIterations: 1e3, + // max number of iterations to run + minIterations: 100, + // min number of iterations to run in order for clustering to stop + attributes: [ + // functions to quantify the similarity between any two points + // e.g. node => node.data('weight') + ] + }), yh = function(e) { + var r = e.damping, a = e.preference; + 0.5 <= r && r < 1 || xt("Damping must range on [0.5, 1). Got: ".concat(r)); + var n = ["median", "mean", "min", "max"]; + return n.some(function(i) { + return i === a; + }) || R(a) || xt("Preference must be one of [".concat(n.map(function(i) { + return "'".concat(i, "'"); + }).join(", "), "] or a number. Got: ").concat(a)), ph(e); + }, mh = function(e, r, a, n) { + var i = function(o, u) { + return n[u](o); + }; + return -bn(e, n.length, function(s) { + return i(r, s); + }, function(s) { + return i(a, s); + }, r, a); + }, bh = function(e, r) { + var a = null; + return r === "median" ? a = yf(e) : r === "mean" ? a = pf(e) : r === "min" ? a = df(e) : r === "max" ? a = gf(e) : a = r, a; + }, Eh = function(e, r, a) { + for (var n = [], i = 0; i < e; i++) + r[i * e + i] + a[i * e + i] > 0 && n.push(i); + return n; + }, Us = function(e, r, a) { + for (var n = [], i = 0; i < e; i++) { + for (var s = -1, o = -1 / 0, u = 0; u < a.length; u++) { + var l = a[u]; + r[i * e + l] > o && (s = l, o = r[i * e + l]); + } + s > 0 && n.push(s); + } + for (var f = 0; f < a.length; f++) + n[a[f]] = a[f]; + return n; + }, wh = function(e, r, a) { + for (var n = Us(e, r, a), i = 0; i < a.length; i++) { + for (var s = [], o = 0; o < n.length; o++) + n[o] === a[i] && s.push(o); + for (var u = -1, l = -1 / 0, f = 0; f < s.length; f++) { + for (var h = 0, v = 0; v < s.length; v++) + h += r[s[v] * e + s[f]]; + h > l && (u = f, l = h); + } + a[i] = s[u]; + } + return n = Us(e, r, a), n; + }, $s = function(e) { + for (var r = this.cy(), a = this.nodes(), n = yh(e), i = {}, s = 0; s < a.length; s++) + i[a[s].id()] = s; + var o, u, l, f, h, v; + o = a.length, u = o * o, l = new Array(u); + for (var d = 0; d < u; d++) + l[d] = -1 / 0; + for (var c = 0; c < o; c++) + for (var y = 0; y < o; y++) + c !== y && (l[c * o + y] = mh(n.distance, a[c], a[y], n.attributes)); + f = bh(l, n.preference); + for (var p = 0; p < o; p++) + l[p * o + p] = f; + h = new Array(u); + for (var g = 0; g < u; g++) + h[g] = 0; + v = new Array(u); + for (var m = 0; m < u; m++) + v[m] = 0; + for (var b = new Array(o), E = new Array(o), M = new Array(o), L = 0; L < o; L++) + b[L] = 0, E[L] = 0, M[L] = 0; + for (var w = new Array(o * n.minIterations), k = 0; k < w.length; k++) + w[k] = 0; + var D; + for (D = 0; D < n.maxIterations; D++) { + for (var F = 0; F < o; F++) { + for (var G = -1 / 0, N = -1 / 0, X = -1, B = 0, re = 0; re < o; re++) + b[re] = h[F * o + re], B = v[F * o + re] + l[F * o + re], B >= G ? (N = G, G = B, X = re) : B > N && (N = B); + for (var K = 0; K < o; K++) + h[F * o + K] = (1 - n.damping) * (l[F * o + K] - G) + n.damping * b[K]; + h[F * o + X] = (1 - n.damping) * (l[F * o + X] - N) + n.damping * b[X]; + } + for (var W = 0; W < o; W++) { + for (var ae = 0, ue = 0; ue < o; ue++) + b[ue] = v[ue * o + W], E[ue] = Math.max(0, h[ue * o + W]), ae += E[ue]; + ae -= E[W], E[W] = h[W * o + W], ae += E[W]; + for (var me = 0; me < o; me++) + v[me * o + W] = (1 - n.damping) * Math.min(0, ae - E[me]) + n.damping * b[me]; + v[W * o + W] = (1 - n.damping) * (ae - E[W]) + n.damping * b[W]; + } + for (var ie = 0, ge = 0; ge < o; ge++) { + var Ee = v[ge * o + ge] + h[ge * o + ge] > 0 ? 1 : 0; + w[D % n.minIterations * o + ge] = Ee, ie += Ee; + } + if (ie > 0 && (D >= n.minIterations - 1 || D == n.maxIterations - 1)) { + for (var Ce = 0, we = 0; we < o; we++) { + M[we] = 0; + for (var De = 0; De < n.minIterations; De++) + M[we] += w[De * o + we]; + (M[we] === 0 || M[we] === n.minIterations) && Ce++; + } + if (Ce === o) + break; + } + } + for (var se = Eh(o, h, v), xe = wh(o, l, se), Le = {}, Se = 0; Se < se.length; Se++) + Le[se[Se]] = []; + for (var Oe = 0; Oe < a.length; Oe++) { + var Fe = i[a[Oe].id()], Xe = xe[Fe]; + Xe != null && Le[Xe].push(a[Oe]); + } + for (var Ie = new Array(se.length), Me = 0; Me < se.length; Me++) + Ie[Me] = r.collection(Le[se[Me]]); + return Ie; + }, xh = { + affinityPropagation: $s, + ap: $s + }, Th = At({ + root: void 0, + directed: !1 + }), Ch = { + hierholzer: function(e) { + if (!S(e)) { + var r = arguments; + e = { + root: r[0], + directed: r[1] + }; + } + var a = Th(e), n = a.root, i = a.directed, s = this, o = !1, u, l, f; + n && (f = ee(n) ? this.filter(n)[0].id() : n[0].id()); + var h = {}, v = {}; + i ? s.forEach(function(m) { + var b = m.id(); + if (m.isNode()) { + var E = m.indegree(!0), M = m.outdegree(!0), L = E - M, w = M - E; + L == 1 ? u ? o = !0 : u = b : w == 1 ? l ? o = !0 : l = b : (w > 1 || L > 1) && (o = !0), h[b] = [], m.outgoers().forEach(function(k) { + k.isEdge() && h[b].push(k.id()); + }); + } else + v[b] = [void 0, m.target().id()]; + }) : s.forEach(function(m) { + var b = m.id(); + if (m.isNode()) { + var E = m.degree(!0); + E % 2 && (u ? l ? o = !0 : l = b : u = b), h[b] = [], m.connectedEdges().forEach(function(M) { + return h[b].push(M.id()); + }); + } else + v[b] = [m.source().id(), m.target().id()]; + }); + var d = { + found: !1, + trail: void 0 + }; + if (o) + return d; + if (l && u) + if (i) { + if (f && l != f) + return d; + f = l; + } else { + if (f && l != f && u != f) + return d; + f || (f = l); + } + else + f || (f = s[0].id()); + var c = function(b) { + for (var E = b, M = [b], L, w, k; h[E].length; ) + L = h[E].shift(), w = v[L][0], k = v[L][1], E != k ? (h[k] = h[k].filter(function(D) { + return D != L; + }), E = k) : !i && E != w && (h[w] = h[w].filter(function(D) { + return D != L; + }), E = w), M.unshift(L), M.unshift(E); + return M; + }, y = [], p = []; + for (p = c(f); p.length != 1; ) + h[p[0]].length == 0 ? (y.unshift(s.getElementById(p.shift())), y.unshift(s.getElementById(p.shift()))) : p = c(p.shift()).concat(p); + y.unshift(s.getElementById(p.shift())); + for (var g in h) + if (h[g].length) + return d; + return d.found = !0, d.trail = this.spawn(y, !0), d; + } + }, xn = function() { + var e = this, r = {}, a = 0, n = 0, i = [], s = [], o = {}, u = function(v, d) { + for (var c = s.length - 1, y = [], p = e.spawn(); s[c].x != v || s[c].y != d; ) + y.push(s.pop().edge), c--; + y.push(s.pop().edge), y.forEach(function(g) { + var m = g.connectedNodes().intersection(e); + p.merge(g), m.forEach(function(b) { + var E = b.id(), M = b.connectedEdges().intersection(e); + p.merge(b), r[E].cutVertex ? p.merge(M.filter(function(L) { + return L.isLoop(); + })) : p.merge(M); + }); + }), i.push(p); + }, l = function h(v, d, c) { + v === c && (n += 1), r[d] = { + id: a, + low: a++, + cutVertex: !1 + }; + var y = e.getElementById(d).connectedEdges().intersection(e); + if (y.size() === 0) + i.push(e.spawn(e.getElementById(d))); + else { + var p, g, m, b; + y.forEach(function(E) { + p = E.source().id(), g = E.target().id(), m = p === d ? g : p, m !== c && (b = E.id(), o[b] || (o[b] = !0, s.push({ + x: d, + y: m, + edge: E + })), m in r ? r[d].low = Math.min(r[d].low, r[m].id) : (h(v, m, d), r[d].low = Math.min(r[d].low, r[m].low), r[d].id <= r[m].low && (r[d].cutVertex = !0, u(d, m)))); + }); + } + }; + e.forEach(function(h) { + if (h.isNode()) { + var v = h.id(); + v in r || (n = 0, l(v, v), r[v].cutVertex = n > 1); + } + }); + var f = Object.keys(r).filter(function(h) { + return r[h].cutVertex; + }).map(function(h) { + return e.getElementById(h); + }); + return { + cut: e.spawn(f), + components: i + }; + }, Dh = { + hopcroftTarjanBiconnected: xn, + htbc: xn, + htb: xn, + hopcroftTarjanBiconnectedComponents: xn + }, Tn = function() { + var e = this, r = {}, a = 0, n = [], i = [], s = e.spawn(e), o = function u(l) { + i.push(l), r[l] = { + index: a, + low: a++, + explored: !1 + }; + var f = e.getElementById(l).connectedEdges().intersection(e); + if (f.forEach(function(y) { + var p = y.target().id(); + p !== l && (p in r || u(p), r[p].explored || (r[l].low = Math.min(r[l].low, r[p].low))); + }), r[l].index === r[l].low) { + for (var h = e.spawn(); ; ) { + var v = i.pop(); + if (h.merge(e.getElementById(v)), r[v].low = r[l].index, r[v].explored = !0, v === l) + break; + } + var d = h.edgesWith(h), c = h.merge(d); + n.push(c), s = s.difference(c); + } + }; + return e.forEach(function(u) { + if (u.isNode()) { + var l = u.id(); + l in r || o(l); + } + }), { + cut: s, + components: n + }; + }, Sh = { + tarjanStronglyConnected: Tn, + tsc: Tn, + tscc: Tn, + tarjanStronglyConnectedComponents: Tn + }, _s = {}; + [Ma, tf, rf, nf, of, uf, vf, Ff, ra, aa, gi, Zf, uh, gh, xh, Ch, Dh, Sh].forEach(function(t) { + He(_s, t); + }); + /*! + Embeddable Minimum Strictly-Compliant Promises/A+ 1.1.1 Thenable + Copyright (c) 2013-2014 Ralf S. Engelschall (http://engelschall.com) + Licensed under The MIT License (http://opensource.org/licenses/MIT) + */ + var Ys = 0, Hs = 1, Xs = 2, yr = function t(e) { + if (!(this instanceof t)) + return new t(e); + this.id = "Thenable/1.0.7", this.state = Ys, this.fulfillValue = void 0, this.rejectReason = void 0, this.onFulfilled = [], this.onRejected = [], this.proxy = { + then: this.then.bind(this) + }, typeof e == "function" && e.call(this, this.fulfill.bind(this), this.reject.bind(this)); + }; + yr.prototype = { + /* promise resolving methods */ + fulfill: function(e) { + return Ws(this, Hs, "fulfillValue", e); + }, + reject: function(e) { + return Ws(this, Xs, "rejectReason", e); + }, + /* "The then Method" [Promises/A+ 1.1, 1.2, 2.2] */ + then: function(e, r) { + var a = this, n = new yr(); + return a.onFulfilled.push(Zs(e, n, "fulfill")), a.onRejected.push(Zs(r, n, "reject")), qs(a), n.proxy; + } + }; + var Ws = function(e, r, a, n) { + return e.state === Ys && (e.state = r, e[a] = n, qs(e)), e; + }, qs = function(e) { + e.state === Hs ? Ks(e, "onFulfilled", e.fulfillValue) : e.state === Xs && Ks(e, "onRejected", e.rejectReason); + }, Ks = function(e, r, a) { + if (e[r].length !== 0) { + var n = e[r]; + e[r] = []; + var i = function() { + for (var o = 0; o < n.length; o++) + n[o](a); + }; + typeof setImmediate == "function" ? setImmediate(i) : setTimeout(i, 0); + } + }, Zs = function(e, r, a) { + return function(n) { + if (typeof e != "function") + r[a].call(r, n); + else { + var i; + try { + i = e(n); + } catch (s) { + r.reject(s); + return; + } + Lh(r, i); + } + }; + }, Lh = function t(e, r) { + if (e === r || e.proxy === r) { + e.reject(new TypeError("cannot resolve promise with itself")); + return; + } + var a; + if (_(r) === "object" && r !== null || typeof r == "function") + try { + a = r.then; + } catch (i) { + e.reject(i); + return; + } + if (typeof a == "function") { + var n = !1; + try { + a.call( + r, + /* resolvePromise */ + /* [Promises/A+ 2.3.3.3.1] */ + function(i) { + n || (n = !0, i === r ? e.reject(new TypeError("circular thenable chain")) : t(e, i)); + }, + /* rejectPromise */ + /* [Promises/A+ 2.3.3.3.2] */ + function(i) { + n || (n = !0, e.reject(i)); + } + ); + } catch (i) { + n || e.reject(i); + } + return; + } + e.fulfill(r); + }; + yr.all = function(t) { + return new yr(function(e, r) { + for (var a = new Array(t.length), n = 0, i = function(u, l) { + a[u] = l, n++, n === t.length && e(a); + }, s = 0; s < t.length; s++) + (function(o) { + var u = t[o], l = u != null && u.then != null; + if (l) + u.then(function(h) { + i(o, h); + }, function(h) { + r(h); + }); + else { + var f = u; + i(o, f); + } + })(s); + }); + }, yr.resolve = function(t) { + return new yr(function(e, r) { + e(t); + }); + }, yr.reject = function(t) { + return new yr(function(e, r) { + r(t); + }); + }; + var ia = typeof Promise < "u" ? Promise : yr, mi = function(e, r, a) { + var n = Ye(e), i = !n, s = this._private = He({ + duration: 1e3 + }, r, a); + if (s.target = e, s.style = s.style || s.css, s.started = !1, s.playing = !1, s.hooked = !1, s.applying = !1, s.progress = 0, s.completes = [], s.frames = [], s.complete && H(s.complete) && s.completes.push(s.complete), i) { + var o = e.position(); + s.startPosition = s.startPosition || { + x: o.x, + y: o.y + }, s.startStyle = s.startStyle || e.cy().style().getAnimationStartStyle(e, s.style); + } + if (n) { + var u = e.pan(); + s.startPan = { + x: u.x, + y: u.y + }, s.startZoom = e.zoom(); + } + this.length = 1, this[0] = this; + }, zr = mi.prototype; + He(zr, { + instanceString: function() { + return "animation"; + }, + hook: function() { + var e = this._private; + if (!e.hooked) { + var r, a = e.target._private.animation; + e.queue ? r = a.queue : r = a.current, r.push(this), pe(e.target) && e.target.cy().addToAnimationPool(e.target), e.hooked = !0; + } + return this; + }, + play: function() { + var e = this._private; + return e.progress === 1 && (e.progress = 0), e.playing = !0, e.started = !1, e.stopped = !1, this.hook(), this; + }, + playing: function() { + return this._private.playing; + }, + apply: function() { + var e = this._private; + return e.applying = !0, e.started = !1, e.stopped = !1, this.hook(), this; + }, + applying: function() { + return this._private.applying; + }, + pause: function() { + var e = this._private; + return e.playing = !1, e.started = !1, this; + }, + stop: function() { + var e = this._private; + return e.playing = !1, e.started = !1, e.stopped = !0, this; + }, + rewind: function() { + return this.progress(0); + }, + fastforward: function() { + return this.progress(1); + }, + time: function(e) { + var r = this._private; + return e === void 0 ? r.progress * r.duration : this.progress(e / r.duration); + }, + progress: function(e) { + var r = this._private, a = r.playing; + return e === void 0 ? r.progress : (a && this.pause(), r.progress = e, r.started = !1, a && this.play(), this); + }, + completed: function() { + return this._private.progress === 1; + }, + reverse: function() { + var e = this._private, r = e.playing; + r && this.pause(), e.progress = 1 - e.progress, e.started = !1; + var a = function(l, f) { + var h = e[l]; + h != null && (e[l] = e[f], e[f] = h); + }; + if (a("zoom", "startZoom"), a("pan", "startPan"), a("position", "startPosition"), e.style) + for (var n = 0; n < e.style.length; n++) { + var i = e.style[n], s = i.name, o = e.startStyle[s]; + e.startStyle[s] = i, e.style[n] = o; + } + return r && this.play(), this; + }, + promise: function(e) { + var r = this._private, a; + switch (e) { + case "frame": + a = r.frames; + break; + default: + case "complete": + case "completed": + a = r.completes; + } + return new ia(function(n, i) { + a.push(function() { + n(); + }); + }); + } + }), zr.complete = zr.completed, zr.run = zr.play, zr.running = zr.playing; + var Ah = { + animated: function() { + return function() { + var r = this, a = r.length !== void 0, n = a ? r : [r], i = this._private.cy || this; + if (!i.styleEnabled()) + return !1; + var s = n[0]; + if (s) + return s._private.animation.current.length > 0; + }; + }, + // animated + clearQueue: function() { + return function() { + var r = this, a = r.length !== void 0, n = a ? r : [r], i = this._private.cy || this; + if (!i.styleEnabled()) + return this; + for (var s = 0; s < n.length; s++) { + var o = n[s]; + o._private.animation.queue = []; + } + return this; + }; + }, + // clearQueue + delay: function() { + return function(r, a) { + var n = this._private.cy || this; + return n.styleEnabled() ? this.animate({ + delay: r, + duration: r, + complete: a + }) : this; + }; + }, + // delay + delayAnimation: function() { + return function(r, a) { + var n = this._private.cy || this; + return n.styleEnabled() ? this.animation({ + delay: r, + duration: r, + complete: a + }) : this; + }; + }, + // delay + animation: function() { + return function(r, a) { + var n = this, i = n.length !== void 0, s = i ? n : [n], o = this._private.cy || this, u = !i, l = !u; + if (!o.styleEnabled()) + return this; + var f = o.style(); + r = He({}, r, a); + var h = Object.keys(r).length === 0; + if (h) + return new mi(s[0], r); + switch (r.duration === void 0 && (r.duration = 400), r.duration) { + case "slow": + r.duration = 600; + break; + case "fast": + r.duration = 200; + break; + } + if (l && (r.style = f.getPropsList(r.style || r.css), r.css = void 0), l && r.renderedPosition != null) { + var v = r.renderedPosition, d = o.pan(), c = o.zoom(); + r.position = bs(v, c, d); + } + if (u && r.panBy != null) { + var y = r.panBy, p = o.pan(); + r.pan = { + x: p.x + y.x, + y: p.y + y.y + }; + } + var g = r.center || r.centre; + if (u && g != null) { + var m = o.getCenterPan(g.eles, r.zoom); + m != null && (r.pan = m); + } + if (u && r.fit != null) { + var b = r.fit, E = o.getFitViewport(b.eles || b.boundingBox, b.padding); + E != null && (r.pan = E.pan, r.zoom = E.zoom); + } + if (u && S(r.zoom)) { + var M = o.getZoomedViewport(r.zoom); + M != null ? (M.zoomed && (r.zoom = M.zoom), M.panned && (r.pan = M.pan)) : r.zoom = null; + } + return new mi(s[0], r); + }; + }, + // animate + animate: function() { + return function(r, a) { + var n = this, i = n.length !== void 0, s = i ? n : [n], o = this._private.cy || this; + if (!o.styleEnabled()) + return this; + a && (r = He({}, r, a)); + for (var u = 0; u < s.length; u++) { + var l = s[u], f = l.animated() && (r.queue === void 0 || r.queue), h = l.animation(r, f ? { + queue: !0 + } : void 0); + h.play(); + } + return this; + }; + }, + // animate + stop: function() { + return function(r, a) { + var n = this, i = n.length !== void 0, s = i ? n : [n], o = this._private.cy || this; + if (!o.styleEnabled()) + return this; + for (var u = 0; u < s.length; u++) { + for (var l = s[u], f = l._private, h = f.animation.current, v = 0; v < h.length; v++) { + var d = h[v], c = d._private; + a && (c.duration = 0); + } + r && (f.animation.queue = []), a || (f.animation.current = []); + } + return o.notify("draw"), this; + }; + } + // stop + }, Oh = Array.isArray, Cn = Oh, Nh = /\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/, Ih = /^\w*$/; + function Mh(t, e) { + if (Cn(t)) + return !1; + var r = typeof t; + return r == "number" || r == "symbol" || r == "boolean" || t == null || Aa(t) ? !0 : Ih.test(t) || !Nh.test(t) || e != null && t in Object(e); + } + var Rh = Mh, kh = "[object AsyncFunction]", Ph = "[object Function]", Bh = "[object GeneratorFunction]", Fh = "[object Proxy]"; + function Gh(t) { + if (!kr(t)) + return !1; + var e = is(t); + return e == Ph || e == Bh || e == kh || e == Fh; + } + var zh = Gh, Vh = sn["__core-js_shared__"], bi = Vh, Qs = function() { + var t = /[^.]+$/.exec(bi && bi.keys && bi.keys.IE_PROTO || ""); + return t ? "Symbol(src)_1." + t : ""; + }(); + function Uh(t) { + return !!Qs && Qs in t; + } + var $h = Uh, _h = Function.prototype, Yh = _h.toString; + function Hh(t) { + if (t != null) { + try { + return Yh.call(t); + } catch { + } + try { + return t + ""; + } catch { + } + } + return ""; + } + var Xh = Hh, Wh = /[\\^$.*+?()[\]{}|]/g, qh = /^\[object .+?Constructor\]$/, Kh = Function.prototype, Zh = Object.prototype, Qh = Kh.toString, Jh = Zh.hasOwnProperty, jh = RegExp( + "^" + Qh.call(Jh).replace(Wh, "\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g, "$1.*?") + "$" + ); + function ev(t) { + if (!kr(t) || $h(t)) + return !1; + var e = zh(t) ? jh : qh; + return e.test(Xh(t)); + } + var tv = ev; + function rv(t, e) { + return t == null ? void 0 : t[e]; + } + var av = rv; + function nv(t, e) { + var r = av(t, e); + return tv(r) ? r : void 0; + } + var Ei = nv, iv = Ei(Object, "create"), za = iv; + function sv() { + this.__data__ = za ? za(null) : {}, this.size = 0; + } + var ov = sv; + function lv(t) { + var e = this.has(t) && delete this.__data__[t]; + return this.size -= e ? 1 : 0, e; + } + var uv = lv, fv = "__lodash_hash_undefined__", hv = Object.prototype, vv = hv.hasOwnProperty; + function cv(t) { + var e = this.__data__; + if (za) { + var r = e[t]; + return r === fv ? void 0 : r; + } + return vv.call(e, t) ? e[t] : void 0; + } + var dv = cv, gv = Object.prototype, pv = gv.hasOwnProperty; + function yv(t) { + var e = this.__data__; + return za ? e[t] !== void 0 : pv.call(e, t); + } + var mv = yv, bv = "__lodash_hash_undefined__"; + function Ev(t, e) { + var r = this.__data__; + return this.size += this.has(t) ? 0 : 1, r[t] = za && e === void 0 ? bv : e, this; + } + var wv = Ev; + function sa(t) { + var e = -1, r = t == null ? 0 : t.length; + for (this.clear(); ++e < r; ) { + var a = t[e]; + this.set(a[0], a[1]); + } + } + sa.prototype.clear = ov, sa.prototype.delete = uv, sa.prototype.get = dv, sa.prototype.has = mv, sa.prototype.set = wv; + var Js = sa; + function xv() { + this.__data__ = [], this.size = 0; + } + var Tv = xv; + function Cv(t, e) { + return t === e || t !== t && e !== e; + } + var js = Cv; + function Dv(t, e) { + for (var r = t.length; r--; ) + if (js(t[r][0], e)) + return r; + return -1; + } + var Dn = Dv, Sv = Array.prototype, Lv = Sv.splice; + function Av(t) { + var e = this.__data__, r = Dn(e, t); + if (r < 0) + return !1; + var a = e.length - 1; + return r == a ? e.pop() : Lv.call(e, r, 1), --this.size, !0; + } + var Ov = Av; + function Nv(t) { + var e = this.__data__, r = Dn(e, t); + return r < 0 ? void 0 : e[r][1]; + } + var Iv = Nv; + function Mv(t) { + return Dn(this.__data__, t) > -1; + } + var Rv = Mv; + function kv(t, e) { + var r = this.__data__, a = Dn(r, t); + return a < 0 ? (++this.size, r.push([t, e])) : r[a][1] = e, this; + } + var Pv = kv; + function oa(t) { + var e = -1, r = t == null ? 0 : t.length; + for (this.clear(); ++e < r; ) { + var a = t[e]; + this.set(a[0], a[1]); + } + } + oa.prototype.clear = Tv, oa.prototype.delete = Ov, oa.prototype.get = Iv, oa.prototype.has = Rv, oa.prototype.set = Pv; + var Bv = oa, Fv = Ei(sn, "Map"), Gv = Fv; + function zv() { + this.size = 0, this.__data__ = { + hash: new Js(), + map: new (Gv || Bv)(), + string: new Js() + }; + } + var Vv = zv; + function Uv(t) { + var e = typeof t; + return e == "string" || e == "number" || e == "symbol" || e == "boolean" ? t !== "__proto__" : t === null; + } + var $v = Uv; + function _v(t, e) { + var r = t.__data__; + return $v(e) ? r[typeof e == "string" ? "string" : "hash"] : r.map; + } + var Sn = _v; + function Yv(t) { + var e = Sn(this, t).delete(t); + return this.size -= e ? 1 : 0, e; + } + var Hv = Yv; + function Xv(t) { + return Sn(this, t).get(t); + } + var Wv = Xv; + function qv(t) { + return Sn(this, t).has(t); + } + var Kv = qv; + function Zv(t, e) { + var r = Sn(this, t), a = r.size; + return r.set(t, e), this.size += r.size == a ? 0 : 1, this; + } + var Qv = Zv; + function la(t) { + var e = -1, r = t == null ? 0 : t.length; + for (this.clear(); ++e < r; ) { + var a = t[e]; + this.set(a[0], a[1]); + } + } + la.prototype.clear = Vv, la.prototype.delete = Hv, la.prototype.get = Wv, la.prototype.has = Kv, la.prototype.set = Qv; + var eo = la, Jv = "Expected a function"; + function wi(t, e) { + if (typeof t != "function" || e != null && typeof e != "function") + throw new TypeError(Jv); + var r = function() { + var a = arguments, n = e ? e.apply(this, a) : a[0], i = r.cache; + if (i.has(n)) + return i.get(n); + var s = t.apply(this, a); + return r.cache = i.set(n, s) || i, s; + }; + return r.cache = new (wi.Cache || eo)(), r; + } + wi.Cache = eo; + var jv = wi, ec = 500; + function tc(t) { + var e = jv(t, function(a) { + return r.size === ec && r.clear(), a; + }), r = e.cache; + return e; + } + var rc = tc, ac = /[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g, nc = /\\(\\)?/g, ic = rc(function(t) { + var e = []; + return t.charCodeAt(0) === 46 && e.push(""), t.replace(ac, function(r, a, n, i) { + e.push(n ? i.replace(nc, "$1") : a || r); + }), e; + }), to = ic; + function sc(t, e) { + for (var r = -1, a = t == null ? 0 : t.length, n = Array(a); ++r < a; ) + n[r] = e(t[r], r, t); + return n; + } + var ro = sc, oc = 1 / 0, ao = Zr ? Zr.prototype : void 0, no = ao ? ao.toString : void 0; + function io(t) { + if (typeof t == "string") + return t; + if (Cn(t)) + return ro(t, io) + ""; + if (Aa(t)) + return no ? no.call(t) : ""; + var e = t + ""; + return e == "0" && 1 / t == -oc ? "-0" : e; + } + var lc = io; + function uc(t) { + return t == null ? "" : lc(t); + } + var so = uc; + function fc(t, e) { + return Cn(t) ? t : Rh(t, e) ? [t] : to(so(t)); + } + var oo = fc, hc = 1 / 0; + function vc(t) { + if (typeof t == "string" || Aa(t)) + return t; + var e = t + ""; + return e == "0" && 1 / t == -hc ? "-0" : e; + } + var xi = vc; + function cc(t, e) { + e = oo(e, t); + for (var r = 0, a = e.length; t != null && r < a; ) + t = t[xi(e[r++])]; + return r && r == a ? t : void 0; + } + var dc = cc; + function gc(t, e, r) { + var a = t == null ? void 0 : dc(t, e); + return a === void 0 ? r : a; + } + var pc = gc, yc = function() { + try { + var t = Ei(Object, "defineProperty"); + return t({}, "", {}), t; + } catch { + } + }(), lo = yc; + function mc(t, e, r) { + e == "__proto__" && lo ? lo(t, e, { + configurable: !0, + enumerable: !0, + value: r, + writable: !0 + }) : t[e] = r; + } + var bc = mc, Ec = Object.prototype, wc = Ec.hasOwnProperty; + function xc(t, e, r) { + var a = t[e]; + (!(wc.call(t, e) && js(a, r)) || r === void 0 && !(e in t)) && bc(t, e, r); + } + var Tc = xc, Cc = 9007199254740991, Dc = /^(?:0|[1-9]\d*)$/; + function Sc(t, e) { + var r = typeof t; + return e = e ?? Cc, !!e && (r == "number" || r != "symbol" && Dc.test(t)) && t > -1 && t % 1 == 0 && t < e; + } + var Lc = Sc; + function Ac(t, e, r, a) { + if (!kr(t)) + return t; + e = oo(e, t); + for (var n = -1, i = e.length, s = i - 1, o = t; o != null && ++n < i; ) { + var u = xi(e[n]), l = r; + if (u === "__proto__" || u === "constructor" || u === "prototype") + return t; + if (n != s) { + var f = o[u]; + l = a ? a(f, u, o) : void 0, l === void 0 && (l = kr(f) ? f : Lc(e[n + 1]) ? [] : {}); + } + Tc(o, u, l), o = o[u]; + } + return t; + } + var Oc = Ac; + function Nc(t, e, r) { + return t == null ? t : Oc(t, e, r); + } + var Ic = Nc; + function Mc(t, e) { + var r = -1, a = t.length; + for (e || (e = Array(a)); ++r < a; ) + e[r] = t[r]; + return e; + } + var Rc = Mc; + function kc(t) { + return Cn(t) ? ro(t, xi) : Aa(t) ? [t] : Rc(to(so(t))); + } + var Pc = kc, Bc = { + // access data field + data: function(e) { + var r = { + field: "data", + bindingEvent: "data", + allowBinding: !1, + allowSetting: !1, + allowGetting: !1, + settingEvent: "data", + settingTriggersEvent: !1, + triggerFnName: "trigger", + immutableKeys: {}, + // key => true if immutable + updateStyle: !1, + beforeGet: function(n) { + }, + beforeSet: function(n, i) { + }, + onSet: function(n) { + }, + canSet: function(n) { + return !0; + } + }; + return e = He({}, r, e), function(n, i) { + var s = e, o = this, u = o.length !== void 0, l = u ? o : [o], f = u ? o[0] : o; + if (ee(n)) { + var h = n.indexOf(".") !== -1, v = h && Pc(n); + if (s.allowGetting && i === void 0) { + var d; + return f && (s.beforeGet(f), v && f._private[s.field][n] === void 0 ? d = pc(f._private[s.field], v) : d = f._private[s.field][n]), d; + } else if (s.allowSetting && i !== void 0) { + var c = !s.immutableKeys[n]; + if (c) { + var y = T({}, n, i); + s.beforeSet(o, y); + for (var p = 0, g = l.length; p < g; p++) { + var m = l[p]; + s.canSet(m) && (v && f._private[s.field][n] === void 0 ? Ic(m._private[s.field], v, i) : m._private[s.field][n] = i); + } + s.updateStyle && o.updateStyle(), s.onSet(o), s.settingTriggersEvent && o[s.triggerFnName](s.settingEvent); + } + } + } else if (s.allowSetting && S(n)) { + var b = n, E, M, L = Object.keys(b); + s.beforeSet(o, b); + for (var w = 0; w < L.length; w++) { + E = L[w], M = b[E]; + var k = !s.immutableKeys[E]; + if (k) + for (var D = 0; D < l.length; D++) { + var F = l[D]; + s.canSet(F) && (F._private[s.field][E] = M); + } + } + s.updateStyle && o.updateStyle(), s.onSet(o), s.settingTriggersEvent && o[s.triggerFnName](s.settingEvent); + } else if (s.allowBinding && H(n)) { + var G = n; + o.on(s.bindingEvent, G); + } else if (s.allowGetting && n === void 0) { + var N; + return f && (s.beforeGet(f), N = f._private[s.field]), N; + } + return o; + }; + }, + // data + // remove data field + removeData: function(e) { + var r = { + field: "data", + event: "data", + triggerFnName: "trigger", + triggerEvent: !1, + immutableKeys: {} + // key => true if immutable + }; + return e = He({}, r, e), function(n) { + var i = e, s = this, o = s.length !== void 0, u = o ? s : [s]; + if (ee(n)) { + for (var l = n.split(/\s+/), f = l.length, h = 0; h < f; h++) { + var v = l[h]; + if (!Re(v)) { + var d = !i.immutableKeys[v]; + if (d) + for (var c = 0, y = u.length; c < y; c++) + u[c]._private[i.field][v] = void 0; + } + } + i.triggerEvent && s[i.triggerFnName](i.event); + } else if (n === void 0) { + for (var p = 0, g = u.length; p < g; p++) + for (var m = u[p]._private[i.field], b = Object.keys(m), E = 0; E < b.length; E++) { + var M = b[E], L = !i.immutableKeys[M]; + L && (m[M] = void 0); + } + i.triggerEvent && s[i.triggerFnName](i.event); + } + return s; + }; + } + // removeData + }, Fc = { + eventAliasesOn: function(e) { + var r = e; + r.addListener = r.listen = r.bind = r.on, r.unlisten = r.unbind = r.off = r.removeListener, r.trigger = r.emit, r.pon = r.promiseOn = function(a, n) { + var i = this, s = Array.prototype.slice.call(arguments, 0); + return new ia(function(o, u) { + var l = function(d) { + i.off.apply(i, h), o(d); + }, f = s.concat([l]), h = f.concat([]); + i.on.apply(i, f); + }); + }; + } + }, ct = {}; + [Ah, Bc, Fc].forEach(function(t) { + He(ct, t); + }); + var Gc = { + animate: ct.animate(), + animation: ct.animation(), + animated: ct.animated(), + clearQueue: ct.clearQueue(), + delay: ct.delay(), + delayAnimation: ct.delayAnimation(), + stop: ct.stop() + }, Ln = { + classes: function(e) { + var r = this; + if (e === void 0) { + var a = []; + return r[0]._private.classes.forEach(function(c) { + return a.push(c); + }), a; + } else + te(e) || (e = (e || "").match(/\S+/g) || []); + for (var n = [], i = new Jr(e), s = 0; s < r.length; s++) { + for (var o = r[s], u = o._private, l = u.classes, f = !1, h = 0; h < e.length; h++) { + var v = e[h], d = l.has(v); + if (!d) { + f = !0; + break; + } + } + f || (f = l.size !== e.length), f && (u.classes = i, n.push(o)); + } + return n.length > 0 && this.spawn(n).updateStyle().emit("class"), r; + }, + addClass: function(e) { + return this.toggleClass(e, !0); + }, + hasClass: function(e) { + var r = this[0]; + return r != null && r._private.classes.has(e); + }, + toggleClass: function(e, r) { + te(e) || (e = e.match(/\S+/g) || []); + for (var a = this, n = r === void 0, i = [], s = 0, o = a.length; s < o; s++) + for (var u = a[s], l = u._private.classes, f = !1, h = 0; h < e.length; h++) { + var v = e[h], d = l.has(v), c = !1; + r || n && !d ? (l.add(v), c = !0) : (!r || n && d) && (l.delete(v), c = !0), !f && c && (i.push(u), f = !0); + } + return i.length > 0 && this.spawn(i).updateStyle().emit("class"), a; + }, + removeClass: function(e) { + return this.toggleClass(e, !1); + }, + flashClass: function(e, r) { + var a = this; + if (r == null) + r = 250; + else if (r === 0) + return a; + return a.addClass(e), setTimeout(function() { + a.removeClass(e); + }, r), a; + } + }; + Ln.className = Ln.classNames = Ln.classes; + var st = { + metaChar: "[\\!\\\"\\#\\$\\%\\&\\'\\(\\)\\*\\+\\,\\.\\/\\:\\;\\<\\=\\>\\?\\@\\[\\]\\^\\`\\{\\|\\}\\~]", + // chars we need to escape in let names, etc + comparatorOp: "=|\\!=|>|>=|<|<=|\\$=|\\^=|\\*=", + // binary comparison op (used in data selectors) + boolOp: "\\?|\\!|\\^", + // boolean (unary) operators (used in data selectors) + string: `"(?:\\\\"|[^"])*"|'(?:\\\\'|[^'])*'`, + // string literals (used in data selectors) -- doublequotes | singlequotes + number: gt, + // number literal (used in data selectors) --- e.g. 0.1234, 1234, 12e123 + meta: "degree|indegree|outdegree", + // allowed metadata fields (i.e. allowed functions to use from Collection) + separator: "\\s*,\\s*", + // queries are separated by commas, e.g. edge[foo = 'bar'], node.someClass + descendant: "\\s+", + child: "\\s+>\\s+", + subject: "\\$", + group: "node|edge|\\*", + directedEdge: "\\s+->\\s+", + undirectedEdge: "\\s+<->\\s+" + }; + st.variable = "(?:[\\w-.]|(?:\\\\" + st.metaChar + "))+", st.className = "(?:[\\w-]|(?:\\\\" + st.metaChar + "))+", st.value = st.string + "|" + st.number, st.id = st.variable, function() { + var t, e, r; + for (t = st.comparatorOp.split("|"), r = 0; r < t.length; r++) + e = t[r], st.comparatorOp += "|@" + e; + for (t = st.comparatorOp.split("|"), r = 0; r < t.length; r++) + e = t[r], !(e.indexOf("!") >= 0) && e !== "=" && (st.comparatorOp += "|\\!" + e); + }(); + var pt = function() { + return { + checks: [] + }; + }, ke = { + /** E.g. node */ + GROUP: 0, + /** A collection of elements */ + COLLECTION: 1, + /** A filter(ele) function */ + FILTER: 2, + /** E.g. [foo > 1] */ + DATA_COMPARE: 3, + /** E.g. [foo] */ + DATA_EXIST: 4, + /** E.g. [?foo] */ + DATA_BOOL: 5, + /** E.g. [[degree > 2]] */ + META_COMPARE: 6, + /** E.g. :selected */ + STATE: 7, + /** E.g. #foo */ + ID: 8, + /** E.g. .foo */ + CLASS: 9, + /** E.g. #foo <-> #bar */ + UNDIRECTED_EDGE: 10, + /** E.g. #foo -> #bar */ + DIRECTED_EDGE: 11, + /** E.g. $#foo -> #bar */ + NODE_SOURCE: 12, + /** E.g. #foo -> $#bar */ + NODE_TARGET: 13, + /** E.g. $#foo <-> #bar */ + NODE_NEIGHBOR: 14, + /** E.g. #foo > #bar */ + CHILD: 15, + /** E.g. #foo #bar */ + DESCENDANT: 16, + /** E.g. $#foo > #bar */ + PARENT: 17, + /** E.g. $#foo #bar */ + ANCESTOR: 18, + /** E.g. #foo > $bar > #baz */ + COMPOUND_SPLIT: 19, + /** Always matches, useful placeholder for subject in `COMPOUND_SPLIT` */ + TRUE: 20 + }, Ti = [{ + selector: ":selected", + matches: function(e) { + return e.selected(); + } + }, { + selector: ":unselected", + matches: function(e) { + return !e.selected(); + } + }, { + selector: ":selectable", + matches: function(e) { + return e.selectable(); + } + }, { + selector: ":unselectable", + matches: function(e) { + return !e.selectable(); + } + }, { + selector: ":locked", + matches: function(e) { + return e.locked(); + } + }, { + selector: ":unlocked", + matches: function(e) { + return !e.locked(); + } + }, { + selector: ":visible", + matches: function(e) { + return e.visible(); + } + }, { + selector: ":hidden", + matches: function(e) { + return !e.visible(); + } + }, { + selector: ":transparent", + matches: function(e) { + return e.transparent(); + } + }, { + selector: ":grabbed", + matches: function(e) { + return e.grabbed(); + } + }, { + selector: ":free", + matches: function(e) { + return !e.grabbed(); + } + }, { + selector: ":removed", + matches: function(e) { + return e.removed(); + } + }, { + selector: ":inside", + matches: function(e) { + return !e.removed(); + } + }, { + selector: ":grabbable", + matches: function(e) { + return e.grabbable(); + } + }, { + selector: ":ungrabbable", + matches: function(e) { + return !e.grabbable(); + } + }, { + selector: ":animated", + matches: function(e) { + return e.animated(); + } + }, { + selector: ":unanimated", + matches: function(e) { + return !e.animated(); + } + }, { + selector: ":parent", + matches: function(e) { + return e.isParent(); + } + }, { + selector: ":childless", + matches: function(e) { + return e.isChildless(); + } + }, { + selector: ":child", + matches: function(e) { + return e.isChild(); + } + }, { + selector: ":orphan", + matches: function(e) { + return e.isOrphan(); + } + }, { + selector: ":nonorphan", + matches: function(e) { + return e.isChild(); + } + }, { + selector: ":compound", + matches: function(e) { + return e.isNode() ? e.isParent() : e.source().isParent() || e.target().isParent(); + } + }, { + selector: ":loop", + matches: function(e) { + return e.isLoop(); + } + }, { + selector: ":simple", + matches: function(e) { + return e.isSimple(); + } + }, { + selector: ":active", + matches: function(e) { + return e.active(); + } + }, { + selector: ":inactive", + matches: function(e) { + return !e.active(); + } + }, { + selector: ":backgrounding", + matches: function(e) { + return e.backgrounding(); + } + }, { + selector: ":nonbackgrounding", + matches: function(e) { + return !e.backgrounding(); + } + }].sort(function(t, e) { + return Kl(t.selector, e.selector); + }), zc = function() { + for (var t = {}, e, r = 0; r < Ti.length; r++) + e = Ti[r], t[e.selector] = e.matches; + return t; + }(), Vc = function(e, r) { + return zc[e](r); + }, Uc = "(" + Ti.map(function(t) { + return t.selector; + }).join("|") + ")", ua = function(e) { + return e.replace(new RegExp("\\\\(" + st.metaChar + ")", "g"), function(r, a) { + return a; + }); + }, Dr = function(e, r, a) { + e[e.length - 1] = a; + }, Ci = [{ + name: "group", + // just used for identifying when debugging + query: !0, + regex: "(" + st.group + ")", + populate: function(e, r, a) { + var n = x(a, 1), i = n[0]; + r.checks.push({ + type: ke.GROUP, + value: i === "*" ? i : i + "s" + }); + } + }, { + name: "state", + query: !0, + regex: Uc, + populate: function(e, r, a) { + var n = x(a, 1), i = n[0]; + r.checks.push({ + type: ke.STATE, + value: i + }); + } + }, { + name: "id", + query: !0, + regex: "\\#(" + st.id + ")", + populate: function(e, r, a) { + var n = x(a, 1), i = n[0]; + r.checks.push({ + type: ke.ID, + value: ua(i) + }); + } + }, { + name: "className", + query: !0, + regex: "\\.(" + st.className + ")", + populate: function(e, r, a) { + var n = x(a, 1), i = n[0]; + r.checks.push({ + type: ke.CLASS, + value: ua(i) + }); + } + }, { + name: "dataExists", + query: !0, + regex: "\\[\\s*(" + st.variable + ")\\s*\\]", + populate: function(e, r, a) { + var n = x(a, 1), i = n[0]; + r.checks.push({ + type: ke.DATA_EXIST, + field: ua(i) + }); + } + }, { + name: "dataCompare", + query: !0, + regex: "\\[\\s*(" + st.variable + ")\\s*(" + st.comparatorOp + ")\\s*(" + st.value + ")\\s*\\]", + populate: function(e, r, a) { + var n = x(a, 3), i = n[0], s = n[1], o = n[2], u = new RegExp("^" + st.string + "$").exec(o) != null; + u ? o = o.substring(1, o.length - 1) : o = parseFloat(o), r.checks.push({ + type: ke.DATA_COMPARE, + field: ua(i), + operator: s, + value: o + }); + } + }, { + name: "dataBool", + query: !0, + regex: "\\[\\s*(" + st.boolOp + ")\\s*(" + st.variable + ")\\s*\\]", + populate: function(e, r, a) { + var n = x(a, 2), i = n[0], s = n[1]; + r.checks.push({ + type: ke.DATA_BOOL, + field: ua(s), + operator: i + }); + } + }, { + name: "metaCompare", + query: !0, + regex: "\\[\\[\\s*(" + st.meta + ")\\s*(" + st.comparatorOp + ")\\s*(" + st.number + ")\\s*\\]\\]", + populate: function(e, r, a) { + var n = x(a, 3), i = n[0], s = n[1], o = n[2]; + r.checks.push({ + type: ke.META_COMPARE, + field: ua(i), + operator: s, + value: parseFloat(o) + }); + } + }, { + name: "nextQuery", + separator: !0, + regex: st.separator, + populate: function(e, r) { + var a = e.currentSubject, n = e.edgeCount, i = e.compoundCount, s = e[e.length - 1]; + a != null && (s.subject = a, e.currentSubject = null), s.edgeCount = n, s.compoundCount = i, e.edgeCount = 0, e.compoundCount = 0; + var o = e[e.length++] = pt(); + return o; + } + }, { + name: "directedEdge", + separator: !0, + regex: st.directedEdge, + populate: function(e, r) { + if (e.currentSubject == null) { + var a = pt(), n = r, i = pt(); + return a.checks.push({ + type: ke.DIRECTED_EDGE, + source: n, + target: i + }), Dr(e, r, a), e.edgeCount++, i; + } else { + var s = pt(), o = r, u = pt(); + return s.checks.push({ + type: ke.NODE_SOURCE, + source: o, + target: u + }), Dr(e, r, s), e.edgeCount++, u; + } + } + }, { + name: "undirectedEdge", + separator: !0, + regex: st.undirectedEdge, + populate: function(e, r) { + if (e.currentSubject == null) { + var a = pt(), n = r, i = pt(); + return a.checks.push({ + type: ke.UNDIRECTED_EDGE, + nodes: [n, i] + }), Dr(e, r, a), e.edgeCount++, i; + } else { + var s = pt(), o = r, u = pt(); + return s.checks.push({ + type: ke.NODE_NEIGHBOR, + node: o, + neighbor: u + }), Dr(e, r, s), u; + } + } + }, { + name: "child", + separator: !0, + regex: st.child, + populate: function(e, r) { + if (e.currentSubject == null) { + var a = pt(), n = pt(), i = e[e.length - 1]; + return a.checks.push({ + type: ke.CHILD, + parent: i, + child: n + }), Dr(e, r, a), e.compoundCount++, n; + } else if (e.currentSubject === r) { + var s = pt(), o = e[e.length - 1], u = pt(), l = pt(), f = pt(), h = pt(); + return s.checks.push({ + type: ke.COMPOUND_SPLIT, + left: o, + right: u, + subject: l + }), l.checks = r.checks, r.checks = [{ + type: ke.TRUE + }], h.checks.push({ + type: ke.TRUE + }), u.checks.push({ + type: ke.PARENT, + // type is swapped on right side queries + parent: h, + child: f + // empty for now + }), Dr(e, o, s), e.currentSubject = l, e.compoundCount++, f; + } else { + var v = pt(), d = pt(), c = [{ + type: ke.PARENT, + parent: v, + child: d + }]; + return v.checks = r.checks, r.checks = c, e.compoundCount++, d; + } + } + }, { + name: "descendant", + separator: !0, + regex: st.descendant, + populate: function(e, r) { + if (e.currentSubject == null) { + var a = pt(), n = pt(), i = e[e.length - 1]; + return a.checks.push({ + type: ke.DESCENDANT, + ancestor: i, + descendant: n + }), Dr(e, r, a), e.compoundCount++, n; + } else if (e.currentSubject === r) { + var s = pt(), o = e[e.length - 1], u = pt(), l = pt(), f = pt(), h = pt(); + return s.checks.push({ + type: ke.COMPOUND_SPLIT, + left: o, + right: u, + subject: l + }), l.checks = r.checks, r.checks = [{ + type: ke.TRUE + }], h.checks.push({ + type: ke.TRUE + }), u.checks.push({ + type: ke.ANCESTOR, + // type is swapped on right side queries + ancestor: h, + descendant: f + // empty for now + }), Dr(e, o, s), e.currentSubject = l, e.compoundCount++, f; + } else { + var v = pt(), d = pt(), c = [{ + type: ke.ANCESTOR, + ancestor: v, + descendant: d + }]; + return v.checks = r.checks, r.checks = c, e.compoundCount++, d; + } + } + }, { + name: "subject", + modifier: !0, + regex: st.subject, + populate: function(e, r) { + if (e.currentSubject != null && e.currentSubject !== r) + return vt("Redefinition of subject in selector `" + e.toString() + "`"), !1; + e.currentSubject = r; + var a = e[e.length - 1], n = a.checks[0], i = n == null ? null : n.type; + i === ke.DIRECTED_EDGE ? n.type = ke.NODE_TARGET : i === ke.UNDIRECTED_EDGE && (n.type = ke.NODE_NEIGHBOR, n.node = n.nodes[1], n.neighbor = n.nodes[0], n.nodes = null); + } + }]; + Ci.forEach(function(t) { + return t.regexObj = new RegExp("^" + t.regex); + }); + var $c = function(e) { + for (var r, a, n, i = 0; i < Ci.length; i++) { + var s = Ci[i], o = s.name, u = e.match(s.regexObj); + if (u != null) { + a = u, r = s, n = o; + var l = u[0]; + e = e.substring(l.length); + break; + } + } + return { + expr: r, + match: a, + name: n, + remaining: e + }; + }, _c = function(e) { + var r = e.match(/^\s+/); + if (r) { + var a = r[0]; + e = e.substring(a.length); + } + return e; + }, Yc = function(e) { + var r = this, a = r.inputText = e, n = r[0] = pt(); + for (r.length = 1, a = _c(a); ; ) { + var i = $c(a); + if (i.expr == null) + return vt("The selector `" + e + "`is invalid"), !1; + var s = i.match.slice(1), o = i.expr.populate(r, n, s); + if (o === !1) + return !1; + if (o != null && (n = o), a = i.remaining, a.match(/^\s*$/)) + break; + } + var u = r[r.length - 1]; + r.currentSubject != null && (u.subject = r.currentSubject), u.edgeCount = r.edgeCount, u.compoundCount = r.compoundCount; + for (var l = 0; l < r.length; l++) { + var f = r[l]; + if (f.compoundCount > 0 && f.edgeCount > 0) + return vt("The selector `" + e + "` is invalid because it uses both a compound selector and an edge selector"), !1; + if (f.edgeCount > 1) + return vt("The selector `" + e + "` is invalid because it uses multiple edge selectors"), !1; + f.edgeCount === 1 && vt("The selector `" + e + "` is deprecated. Edge selectors do not take effect on changes to source and target nodes after an edge is added, for performance reasons. Use a class or data selector on edges instead, updating the class or data of an edge when your app detects a change in source or target nodes."); + } + return !0; + }, Hc = function() { + if (this.toStringCache != null) + return this.toStringCache; + for (var e = function(f) { + return f ?? ""; + }, r = function(f) { + return ee(f) ? '"' + f + '"' : e(f); + }, a = function(f) { + return " " + f + " "; + }, n = function(f, h) { + var v = f.type, d = f.value; + switch (v) { + case ke.GROUP: { + var c = e(d); + return c.substring(0, c.length - 1); + } + case ke.DATA_COMPARE: { + var y = f.field, p = f.operator; + return "[" + y + a(e(p)) + r(d) + "]"; + } + case ke.DATA_BOOL: { + var g = f.operator, m = f.field; + return "[" + e(g) + m + "]"; + } + case ke.DATA_EXIST: { + var b = f.field; + return "[" + b + "]"; + } + case ke.META_COMPARE: { + var E = f.operator, M = f.field; + return "[[" + M + a(e(E)) + r(d) + "]]"; + } + case ke.STATE: + return d; + case ke.ID: + return "#" + d; + case ke.CLASS: + return "." + d; + case ke.PARENT: + case ke.CHILD: + return i(f.parent, h) + a(">") + i(f.child, h); + case ke.ANCESTOR: + case ke.DESCENDANT: + return i(f.ancestor, h) + " " + i(f.descendant, h); + case ke.COMPOUND_SPLIT: { + var L = i(f.left, h), w = i(f.subject, h), k = i(f.right, h); + return L + (L.length > 0 ? " " : "") + w + k; + } + case ke.TRUE: + return ""; + } + }, i = function(f, h) { + return f.checks.reduce(function(v, d, c) { + return v + (h === f && c === 0 ? "$" : "") + n(d, h); + }, ""); + }, s = "", o = 0; o < this.length; o++) { + var u = this[o]; + s += i(u, u.subject), this.length > 1 && o < this.length - 1 && (s += ", "); + } + return this.toStringCache = s, s; + }, Xc = { + parse: Yc, + toString: Hc + }, uo = function(e, r, a) { + var n, i = ee(e), s = R(e), o = ee(a), u, l, f = !1, h = !1, v = !1; + switch (r.indexOf("!") >= 0 && (r = r.replace("!", ""), h = !0), r.indexOf("@") >= 0 && (r = r.replace("@", ""), f = !0), (i || o || f) && (u = !i && !s ? "" : "" + e, l = "" + a), f && (e = u = u.toLowerCase(), a = l = l.toLowerCase()), r) { + case "*=": + n = u.indexOf(l) >= 0; + break; + case "$=": + n = u.indexOf(l, u.length - l.length) >= 0; + break; + case "^=": + n = u.indexOf(l) === 0; + break; + case "=": + n = e === a; + break; + case ">": + v = !0, n = e > a; + break; + case ">=": + v = !0, n = e >= a; + break; + case "<": + v = !0, n = e < a; + break; + case "<=": + v = !0, n = e <= a; + break; + default: + n = !1; + break; + } + return h && (e != null || !v) && (n = !n), n; + }, Wc = function(e, r) { + switch (r) { + case "?": + return !!e; + case "!": + return !e; + case "^": + return e === void 0; + } + }, qc = function(e) { + return e !== void 0; + }, Di = function(e, r) { + return e.data(r); + }, Kc = function(e, r) { + return e[r](); + }, Tt = [], wt = function(e, r) { + return e.checks.every(function(a) { + return Tt[a.type](a, r); + }); + }; + Tt[ke.GROUP] = function(t, e) { + var r = t.value; + return r === "*" || r === e.group(); + }, Tt[ke.STATE] = function(t, e) { + var r = t.value; + return Vc(r, e); + }, Tt[ke.ID] = function(t, e) { + var r = t.value; + return e.id() === r; + }, Tt[ke.CLASS] = function(t, e) { + var r = t.value; + return e.hasClass(r); + }, Tt[ke.META_COMPARE] = function(t, e) { + var r = t.field, a = t.operator, n = t.value; + return uo(Kc(e, r), a, n); + }, Tt[ke.DATA_COMPARE] = function(t, e) { + var r = t.field, a = t.operator, n = t.value; + return uo(Di(e, r), a, n); + }, Tt[ke.DATA_BOOL] = function(t, e) { + var r = t.field, a = t.operator; + return Wc(Di(e, r), a); + }, Tt[ke.DATA_EXIST] = function(t, e) { + var r = t.field; + return t.operator, qc(Di(e, r)); + }, Tt[ke.UNDIRECTED_EDGE] = function(t, e) { + var r = t.nodes[0], a = t.nodes[1], n = e.source(), i = e.target(); + return wt(r, n) && wt(a, i) || wt(a, n) && wt(r, i); + }, Tt[ke.NODE_NEIGHBOR] = function(t, e) { + return wt(t.node, e) && e.neighborhood().some(function(r) { + return r.isNode() && wt(t.neighbor, r); + }); + }, Tt[ke.DIRECTED_EDGE] = function(t, e) { + return wt(t.source, e.source()) && wt(t.target, e.target()); + }, Tt[ke.NODE_SOURCE] = function(t, e) { + return wt(t.source, e) && e.outgoers().some(function(r) { + return r.isNode() && wt(t.target, r); + }); + }, Tt[ke.NODE_TARGET] = function(t, e) { + return wt(t.target, e) && e.incomers().some(function(r) { + return r.isNode() && wt(t.source, r); + }); + }, Tt[ke.CHILD] = function(t, e) { + return wt(t.child, e) && wt(t.parent, e.parent()); + }, Tt[ke.PARENT] = function(t, e) { + return wt(t.parent, e) && e.children().some(function(r) { + return wt(t.child, r); + }); + }, Tt[ke.DESCENDANT] = function(t, e) { + return wt(t.descendant, e) && e.ancestors().some(function(r) { + return wt(t.ancestor, r); + }); + }, Tt[ke.ANCESTOR] = function(t, e) { + return wt(t.ancestor, e) && e.descendants().some(function(r) { + return wt(t.descendant, r); + }); + }, Tt[ke.COMPOUND_SPLIT] = function(t, e) { + return wt(t.subject, e) && wt(t.left, e) && wt(t.right, e); + }, Tt[ke.TRUE] = function() { + return !0; + }, Tt[ke.COLLECTION] = function(t, e) { + var r = t.value; + return r.has(e); + }, Tt[ke.FILTER] = function(t, e) { + var r = t.value; + return r(e); + }; + var Zc = function(e) { + var r = this; + if (r.length === 1 && r[0].checks.length === 1 && r[0].checks[0].type === ke.ID) + return e.getElementById(r[0].checks[0].value).collection(); + var a = function(i) { + for (var s = 0; s < r.length; s++) { + var o = r[s]; + if (wt(o, i)) + return !0; + } + return !1; + }; + return r.text() == null && (a = function() { + return !0; + }), e.filter(a); + }, Qc = function(e) { + for (var r = this, a = 0; a < r.length; a++) { + var n = r[a]; + if (wt(n, e)) + return !0; + } + return !1; + }, Jc = { + matches: Qc, + filter: Zc + }, Sr = function(e) { + this.inputText = e, this.currentSubject = null, this.compoundCount = 0, this.edgeCount = 0, this.length = 0, e == null || ee(e) && e.match(/^\s*$/) || (pe(e) ? this.addQuery({ + checks: [{ + type: ke.COLLECTION, + value: e.collection() + }] + }) : H(e) ? this.addQuery({ + checks: [{ + type: ke.FILTER, + value: e + }] + }) : ee(e) ? this.parse(e) || (this.invalid = !0) : xt("A selector must be created from a string; found ")); + }, Lr = Sr.prototype; + [Xc, Jc].forEach(function(t) { + return He(Lr, t); + }), Lr.text = function() { + return this.inputText; + }, Lr.size = function() { + return this.length; + }, Lr.eq = function(t) { + return this[t]; + }, Lr.sameText = function(t) { + return !this.invalid && !t.invalid && this.text() === t.text(); + }, Lr.addQuery = function(t) { + this[this.length++] = t; + }, Lr.selector = Lr.toString; + var Ar = { + allAre: function(e) { + var r = new Sr(e); + return this.every(function(a) { + return r.matches(a); + }); + }, + is: function(e) { + var r = new Sr(e); + return this.some(function(a) { + return r.matches(a); + }); + }, + some: function(e, r) { + for (var a = 0; a < this.length; a++) { + var n = r ? e.apply(r, [this[a], a, this]) : e(this[a], a, this); + if (n) + return !0; + } + return !1; + }, + every: function(e, r) { + for (var a = 0; a < this.length; a++) { + var n = r ? e.apply(r, [this[a], a, this]) : e(this[a], a, this); + if (!n) + return !1; + } + return !0; + }, + same: function(e) { + if (this === e) + return !0; + e = this.cy().collection(e); + var r = this.length, a = e.length; + return r !== a ? !1 : r === 1 ? this[0] === e[0] : this.every(function(n) { + return e.hasElementWithId(n.id()); + }); + }, + anySame: function(e) { + return e = this.cy().collection(e), this.some(function(r) { + return e.hasElementWithId(r.id()); + }); + }, + allAreNeighbors: function(e) { + e = this.cy().collection(e); + var r = this.neighborhood(); + return e.every(function(a) { + return r.hasElementWithId(a.id()); + }); + }, + contains: function(e) { + e = this.cy().collection(e); + var r = this; + return e.every(function(a) { + return r.hasElementWithId(a.id()); + }); + } + }; + Ar.allAreNeighbours = Ar.allAreNeighbors, Ar.has = Ar.contains, Ar.equal = Ar.equals = Ar.same; + var Zt = function(e, r) { + return function(n, i, s, o) { + var u = n, l = this, f; + if (u == null ? f = "" : pe(u) && u.length === 1 && (f = u.id()), l.length === 1 && f) { + var h = l[0]._private, v = h.traversalCache = h.traversalCache || {}, d = v[r] = v[r] || [], c = Pr(f), y = d[c]; + return y || (d[c] = e.call(l, n, i, s, o)); + } else + return e.call(l, n, i, s, o); + }; + }, fa = { + parent: function(e) { + var r = []; + if (this.length === 1) { + var a = this[0]._private.parent; + if (a) + return a; + } + for (var n = 0; n < this.length; n++) { + var i = this[n], s = i._private.parent; + s && r.push(s); + } + return this.spawn(r, !0).filter(e); + }, + parents: function(e) { + for (var r = [], a = this.parent(); a.nonempty(); ) { + for (var n = 0; n < a.length; n++) { + var i = a[n]; + r.push(i); + } + a = a.parent(); + } + return this.spawn(r, !0).filter(e); + }, + commonAncestors: function(e) { + for (var r, a = 0; a < this.length; a++) { + var n = this[a], i = n.parents(); + r = r || i, r = r.intersect(i); + } + return r.filter(e); + }, + orphans: function(e) { + return this.stdFilter(function(r) { + return r.isOrphan(); + }).filter(e); + }, + nonorphans: function(e) { + return this.stdFilter(function(r) { + return r.isChild(); + }).filter(e); + }, + children: Zt(function(t) { + for (var e = [], r = 0; r < this.length; r++) + for (var a = this[r], n = a._private.children, i = 0; i < n.length; i++) + e.push(n[i]); + return this.spawn(e, !0).filter(t); + }, "children"), + siblings: function(e) { + return this.parent().children().not(this).filter(e); + }, + isParent: function() { + var e = this[0]; + if (e) + return e.isNode() && e._private.children.length !== 0; + }, + isChildless: function() { + var e = this[0]; + if (e) + return e.isNode() && e._private.children.length === 0; + }, + isChild: function() { + var e = this[0]; + if (e) + return e.isNode() && e._private.parent != null; + }, + isOrphan: function() { + var e = this[0]; + if (e) + return e.isNode() && e._private.parent == null; + }, + descendants: function(e) { + var r = []; + function a(n) { + for (var i = 0; i < n.length; i++) { + var s = n[i]; + r.push(s), s.children().nonempty() && a(s.children()); + } + } + return a(this.children()), this.spawn(r, !0).filter(e); + } + }; + function Si(t, e, r, a) { + for (var n = [], i = new Jr(), s = t.cy(), o = s.hasCompoundNodes(), u = 0; u < t.length; u++) { + var l = t[u]; + r ? n.push(l) : o && a(n, i, l); + } + for (; n.length > 0; ) { + var f = n.shift(); + e(f), i.add(f.id()), o && a(n, i, f); + } + return t; + } + function fo(t, e, r) { + if (r.isParent()) + for (var a = r._private.children, n = 0; n < a.length; n++) { + var i = a[n]; + e.has(i.id()) || t.push(i); + } + } + fa.forEachDown = function(t) { + var e = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : !0; + return Si(this, t, e, fo); + }; + function ho(t, e, r) { + if (r.isChild()) { + var a = r._private.parent; + e.has(a.id()) || t.push(a); + } + } + fa.forEachUp = function(t) { + var e = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : !0; + return Si(this, t, e, ho); + }; + function jc(t, e, r) { + ho(t, e, r), fo(t, e, r); + } + fa.forEachUpAndDown = function(t) { + var e = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : !0; + return Si(this, t, e, jc); + }, fa.ancestors = fa.parents; + var Va, vo; + Va = vo = { + data: ct.data({ + field: "data", + bindingEvent: "data", + allowBinding: !0, + allowSetting: !0, + settingEvent: "data", + settingTriggersEvent: !0, + triggerFnName: "trigger", + allowGetting: !0, + immutableKeys: { + id: !0, + source: !0, + target: !0, + parent: !0 + }, + updateStyle: !0 + }), + removeData: ct.removeData({ + field: "data", + event: "data", + triggerFnName: "trigger", + triggerEvent: !0, + immutableKeys: { + id: !0, + source: !0, + target: !0, + parent: !0 + }, + updateStyle: !0 + }), + scratch: ct.data({ + field: "scratch", + bindingEvent: "scratch", + allowBinding: !0, + allowSetting: !0, + settingEvent: "scratch", + settingTriggersEvent: !0, + triggerFnName: "trigger", + allowGetting: !0, + updateStyle: !0 + }), + removeScratch: ct.removeData({ + field: "scratch", + event: "scratch", + triggerFnName: "trigger", + triggerEvent: !0, + updateStyle: !0 + }), + rscratch: ct.data({ + field: "rscratch", + allowBinding: !1, + allowSetting: !0, + settingTriggersEvent: !1, + allowGetting: !0 + }), + removeRscratch: ct.removeData({ + field: "rscratch", + triggerEvent: !1 + }), + id: function() { + var e = this[0]; + if (e) + return e._private.data.id; + } + }, Va.attr = Va.data, Va.removeAttr = Va.removeData; + var ed = vo, An = {}; + function Li(t) { + return function(e) { + var r = this; + if (e === void 0 && (e = !0), r.length !== 0) + if (r.isNode() && !r.removed()) { + for (var a = 0, n = r[0], i = n._private.edges, s = 0; s < i.length; s++) { + var o = i[s]; + !e && o.isLoop() || (a += t(n, o)); + } + return a; + } else + return; + }; + } + He(An, { + degree: Li(function(t, e) { + return e.source().same(e.target()) ? 2 : 1; + }), + indegree: Li(function(t, e) { + return e.target().same(t) ? 1 : 0; + }), + outdegree: Li(function(t, e) { + return e.source().same(t) ? 1 : 0; + }) + }); + function ha(t, e) { + return function(r) { + for (var a, n = this.nodes(), i = 0; i < n.length; i++) { + var s = n[i], o = s[t](r); + o !== void 0 && (a === void 0 || e(o, a)) && (a = o); + } + return a; + }; + } + He(An, { + minDegree: ha("degree", function(t, e) { + return t < e; + }), + maxDegree: ha("degree", function(t, e) { + return t > e; + }), + minIndegree: ha("indegree", function(t, e) { + return t < e; + }), + maxIndegree: ha("indegree", function(t, e) { + return t > e; + }), + minOutdegree: ha("outdegree", function(t, e) { + return t < e; + }), + maxOutdegree: ha("outdegree", function(t, e) { + return t > e; + }) + }), He(An, { + totalDegree: function(e) { + for (var r = 0, a = this.nodes(), n = 0; n < a.length; n++) + r += a[n].degree(e); + return r; + } + }); + var tr, co, go = function(e, r, a) { + for (var n = 0; n < e.length; n++) { + var i = e[n]; + if (!i.locked()) { + var s = i._private.position, o = { + x: r.x != null ? r.x - s.x : 0, + y: r.y != null ? r.y - s.y : 0 + }; + i.isParent() && !(o.x === 0 && o.y === 0) && i.children().shift(o, a), i.dirtyBoundingBoxCache(); + } + } + }, po = { + field: "position", + bindingEvent: "position", + allowBinding: !0, + allowSetting: !0, + settingEvent: "position", + settingTriggersEvent: !0, + triggerFnName: "emitAndNotify", + allowGetting: !0, + validKeys: ["x", "y"], + beforeGet: function(e) { + e.updateCompoundBounds(); + }, + beforeSet: function(e, r) { + go(e, r, !1); + }, + onSet: function(e) { + e.dirtyCompoundBoundsCache(); + }, + canSet: function(e) { + return !e.locked(); + } + }; + tr = co = { + position: ct.data(po), + // position but no notification to renderer + silentPosition: ct.data(He({}, po, { + allowBinding: !1, + allowSetting: !0, + settingTriggersEvent: !1, + allowGetting: !1, + beforeSet: function(e, r) { + go(e, r, !0); + }, + onSet: function(e) { + e.dirtyCompoundBoundsCache(); + } + })), + positions: function(e, r) { + if (S(e)) + r ? this.silentPosition(e) : this.position(e); + else if (H(e)) { + var a = e, n = this.cy(); + n.startBatch(); + for (var i = 0; i < this.length; i++) { + var s = this[i], o = void 0; + (o = a(s, i)) && (r ? s.silentPosition(o) : s.position(o)); + } + n.endBatch(); + } + return this; + }, + silentPositions: function(e) { + return this.positions(e, !0); + }, + shift: function(e, r, a) { + var n; + if (S(e) ? (n = { + x: R(e.x) ? e.x : 0, + y: R(e.y) ? e.y : 0 + }, a = r) : ee(e) && R(r) && (n = { + x: 0, + y: 0 + }, n[e] = r), n != null) { + var i = this.cy(); + i.startBatch(); + for (var s = 0; s < this.length; s++) { + var o = this[s]; + if (!(i.hasCompoundNodes() && o.isChild() && o.ancestors().anySame(this))) { + var u = o.position(), l = { + x: u.x + n.x, + y: u.y + n.y + }; + a ? o.silentPosition(l) : o.position(l); + } + } + i.endBatch(); + } + return this; + }, + silentShift: function(e, r) { + return S(e) ? this.shift(e, !0) : ee(e) && R(r) && this.shift(e, r, !0), this; + }, + // get/set the rendered (i.e. on screen) positon of the element + renderedPosition: function(e, r) { + var a = this[0], n = this.cy(), i = n.zoom(), s = n.pan(), o = S(e) ? e : void 0, u = o !== void 0 || r !== void 0 && ee(e); + if (a && a.isNode()) + if (u) + for (var l = 0; l < this.length; l++) { + var f = this[l]; + r !== void 0 ? f.position(e, (r - s[e]) / i) : o !== void 0 && f.position(bs(o, i, s)); + } + else { + var h = a.position(); + return o = vn(h, i, s), e === void 0 ? o : o[e]; + } + else if (!u) + return; + return this; + }, + // get/set the position relative to the parent + relativePosition: function(e, r) { + var a = this[0], n = this.cy(), i = S(e) ? e : void 0, s = i !== void 0 || r !== void 0 && ee(e), o = n.hasCompoundNodes(); + if (a && a.isNode()) + if (s) + for (var u = 0; u < this.length; u++) { + var l = this[u], f = o ? l.parent() : null, h = f && f.length > 0, v = h; + h && (f = f[0]); + var d = v ? f.position() : { + x: 0, + y: 0 + }; + r !== void 0 ? l.position(e, r + d[e]) : i !== void 0 && l.position({ + x: i.x + d.x, + y: i.y + d.y + }); + } + else { + var c = a.position(), y = o ? a.parent() : null, p = y && y.length > 0, g = p; + p && (y = y[0]); + var m = g ? y.position() : { + x: 0, + y: 0 + }; + return i = { + x: c.x - m.x, + y: c.y - m.y + }, e === void 0 ? i : i[e]; + } + else if (!s) + return; + return this; + } + }, tr.modelPosition = tr.point = tr.position, tr.modelPositions = tr.points = tr.positions, tr.renderedPoint = tr.renderedPosition, tr.relativePoint = tr.relativePosition; + var td = co, va, Or; + va = Or = {}, Or.renderedBoundingBox = function(t) { + var e = this.boundingBox(t), r = this.cy(), a = r.zoom(), n = r.pan(), i = e.x1 * a + n.x, s = e.x2 * a + n.x, o = e.y1 * a + n.y, u = e.y2 * a + n.y; + return { + x1: i, + x2: s, + y1: o, + y2: u, + w: s - i, + h: u - o + }; + }, Or.dirtyCompoundBoundsCache = function() { + var t = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : !1, e = this.cy(); + return !e.styleEnabled() || !e.hasCompoundNodes() ? this : (this.forEachUp(function(r) { + if (r.isParent()) { + var a = r._private; + a.compoundBoundsClean = !1, a.bbCache = null, t || r.emitAndNotify("bounds"); + } + }), this); + }, Or.updateCompoundBounds = function() { + var t = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : !1, e = this.cy(); + if (!e.styleEnabled() || !e.hasCompoundNodes()) + return this; + if (!t && e.batching()) + return this; + function r(s) { + if (!s.isParent()) + return; + var o = s._private, u = s.children(), l = s.pstyle("compound-sizing-wrt-labels").value === "include", f = { + width: { + val: s.pstyle("min-width").pfValue, + left: s.pstyle("min-width-bias-left"), + right: s.pstyle("min-width-bias-right") + }, + height: { + val: s.pstyle("min-height").pfValue, + top: s.pstyle("min-height-bias-top"), + bottom: s.pstyle("min-height-bias-bottom") + } + }, h = u.boundingBox({ + includeLabels: l, + includeOverlays: !1, + // updating the compound bounds happens outside of the regular + // cache cycle (i.e. before fired events) + useCache: !1 + }), v = o.position; + (h.w === 0 || h.h === 0) && (h = { + w: s.pstyle("width").pfValue, + h: s.pstyle("height").pfValue + }, h.x1 = v.x - h.w / 2, h.x2 = v.x + h.w / 2, h.y1 = v.y - h.h / 2, h.y2 = v.y + h.h / 2); + function d(D, F, G) { + var N = 0, X = 0, B = F + G; + return D > 0 && B > 0 && (N = F / B * D, X = G / B * D), { + biasDiff: N, + biasComplementDiff: X + }; + } + function c(D, F, G, N) { + if (G.units === "%") + switch (N) { + case "width": + return D > 0 ? G.pfValue * D : 0; + case "height": + return F > 0 ? G.pfValue * F : 0; + case "average": + return D > 0 && F > 0 ? G.pfValue * (D + F) / 2 : 0; + case "min": + return D > 0 && F > 0 ? D > F ? G.pfValue * F : G.pfValue * D : 0; + case "max": + return D > 0 && F > 0 ? D > F ? G.pfValue * D : G.pfValue * F : 0; + default: + return 0; + } + else + return G.units === "px" ? G.pfValue : 0; + } + var y = f.width.left.value; + f.width.left.units === "px" && f.width.val > 0 && (y = y * 100 / f.width.val); + var p = f.width.right.value; + f.width.right.units === "px" && f.width.val > 0 && (p = p * 100 / f.width.val); + var g = f.height.top.value; + f.height.top.units === "px" && f.height.val > 0 && (g = g * 100 / f.height.val); + var m = f.height.bottom.value; + f.height.bottom.units === "px" && f.height.val > 0 && (m = m * 100 / f.height.val); + var b = d(f.width.val - h.w, y, p), E = b.biasDiff, M = b.biasComplementDiff, L = d(f.height.val - h.h, g, m), w = L.biasDiff, k = L.biasComplementDiff; + o.autoPadding = c(h.w, h.h, s.pstyle("padding"), s.pstyle("padding-relative-to").value), o.autoWidth = Math.max(h.w, f.width.val), v.x = (-E + h.x1 + h.x2 + M) / 2, o.autoHeight = Math.max(h.h, f.height.val), v.y = (-w + h.y1 + h.y2 + k) / 2; + } + for (var a = 0; a < this.length; a++) { + var n = this[a], i = n._private; + (!i.compoundBoundsClean || t) && (r(n), e.batching() || (i.compoundBoundsClean = !0)); + } + return this; + }; + var Qt = function(e) { + return e === 1 / 0 || e === -1 / 0 ? 0 : e; + }, rr = function(e, r, a, n, i) { + n - r === 0 || i - a === 0 || r == null || a == null || n == null || i == null || (e.x1 = r < e.x1 ? r : e.x1, e.x2 = n > e.x2 ? n : e.x2, e.y1 = a < e.y1 ? a : e.y1, e.y2 = i > e.y2 ? i : e.y2, e.w = e.x2 - e.x1, e.h = e.y2 - e.y1); + }, Vr = function(e, r) { + return r == null ? e : rr(e, r.x1, r.y1, r.x2, r.y2); + }, Ua = function(e, r, a) { + return er(e, r, a); + }, On = function(e, r, a) { + if (!r.cy().headless()) { + var n = r._private, i = n.rstyle, s = i.arrowWidth / 2, o = r.pstyle(a + "-arrow-shape").value, u, l; + if (o !== "none") { + a === "source" ? (u = i.srcX, l = i.srcY) : a === "target" ? (u = i.tgtX, l = i.tgtY) : (u = i.midX, l = i.midY); + var f = n.arrowBounds = n.arrowBounds || {}, h = f[a] = f[a] || {}; + h.x1 = u - s, h.y1 = l - s, h.x2 = u + s, h.y2 = l + s, h.w = h.x2 - h.x1, h.h = h.y2 - h.y1, dn(h, 1), rr(e, h.x1, h.y1, h.x2, h.y2); + } + } + }, Ai = function(e, r, a) { + if (!r.cy().headless()) { + var n; + a ? n = a + "-" : n = ""; + var i = r._private, s = i.rstyle, o = r.pstyle(n + "label").strValue; + if (o) { + var u = r.pstyle("text-halign"), l = r.pstyle("text-valign"), f = Ua(s, "labelWidth", a), h = Ua(s, "labelHeight", a), v = Ua(s, "labelX", a), d = Ua(s, "labelY", a), c = r.pstyle(n + "text-margin-x").pfValue, y = r.pstyle(n + "text-margin-y").pfValue, p = r.isEdge(), g = r.pstyle(n + "text-rotation"), m = r.pstyle("text-outline-width").pfValue, b = r.pstyle("text-border-width").pfValue, E = b / 2, M = r.pstyle("text-background-padding").pfValue, L = 2, w = h, k = f, D = k / 2, F = w / 2, G, N, X, B; + if (p) + G = v - D, N = v + D, X = d - F, B = d + F; + else { + switch (u.value) { + case "left": + G = v - k, N = v; + break; + case "center": + G = v - D, N = v + D; + break; + case "right": + G = v, N = v + k; + break; + } + switch (l.value) { + case "top": + X = d - w, B = d; + break; + case "center": + X = d - F, B = d + F; + break; + case "bottom": + X = d, B = d + w; + break; + } + } + G += c - Math.max(m, E) - M - L, N += c + Math.max(m, E) + M + L, X += y - Math.max(m, E) - M - L, B += y + Math.max(m, E) + M + L; + var re = a || "main", K = i.labelBounds, W = K[re] = K[re] || {}; + W.x1 = G, W.y1 = X, W.x2 = N, W.y2 = B, W.w = N - G, W.h = B - X; + var ae = p && g.strValue === "autorotate", ue = g.pfValue != null && g.pfValue !== 0; + if (ae || ue) { + var me = ae ? Ua(i.rstyle, "labelAngle", a) : g.pfValue, ie = Math.cos(me), ge = Math.sin(me), Ee = (G + N) / 2, Ce = (X + B) / 2; + if (!p) { + switch (u.value) { + case "left": + Ee = N; + break; + case "right": + Ee = G; + break; + } + switch (l.value) { + case "top": + Ce = B; + break; + case "bottom": + Ce = X; + break; + } + } + var we = function(Xe, Ie) { + return Xe = Xe - Ee, Ie = Ie - Ce, { + x: Xe * ie - Ie * ge + Ee, + y: Xe * ge + Ie * ie + Ce + }; + }, De = we(G, X), se = we(G, B), xe = we(N, X), Le = we(N, B); + G = Math.min(De.x, se.x, xe.x, Le.x), N = Math.max(De.x, se.x, xe.x, Le.x), X = Math.min(De.y, se.y, xe.y, Le.y), B = Math.max(De.y, se.y, xe.y, Le.y); + } + var Se = re + "Rot", Oe = K[Se] = K[Se] || {}; + Oe.x1 = G, Oe.y1 = X, Oe.x2 = N, Oe.y2 = B, Oe.w = N - G, Oe.h = B - X, rr(e, G, X, N, B), rr(i.labelBounds.all, G, X, N, B); + } + return e; + } + }, rd = function(e, r) { + if (!r.cy().headless()) { + var a = r.pstyle("outline-opacity").value, n = r.pstyle("outline-width").value; + if (a > 0 && n > 0) { + var i = r.pstyle("outline-offset").value, s = r.pstyle("shape").value, o = n + i, u = (e.w + o * 2) / e.w, l = (e.h + o * 2) / e.h, f = 0, h = 0; + ["diamond", "pentagon", "round-triangle"].includes(s) ? (u = (e.w + o * 2.4) / e.w, h = -o / 3.6) : ["concave-hexagon", "rhomboid", "right-rhomboid"].includes(s) ? u = (e.w + o * 2.4) / e.w : s === "star" ? (u = (e.w + o * 2.8) / e.w, l = (e.h + o * 2.6) / e.h, h = -o / 3.8) : s === "triangle" ? (u = (e.w + o * 2.8) / e.w, l = (e.h + o * 2.4) / e.h, h = -o / 1.4) : s === "vee" && (u = (e.w + o * 4.4) / e.w, l = (e.h + o * 3.8) / e.h, h = -o * 0.5); + var v = e.h * l - e.h, d = e.w * u - e.w; + if (gn(e, [Math.ceil(v / 2), Math.ceil(d / 2)]), f != 0 || h !== 0) { + var c = Tf(e, f, h); + ws(e, c); + } + } + } + }, ad = function(e, r) { + var a = e._private.cy, n = a.styleEnabled(), i = a.headless(), s = Yt(), o = e._private, u = e.isNode(), l = e.isEdge(), f, h, v, d, c, y, p = o.rstyle, g = u && n ? e.pstyle("bounds-expansion").pfValue : [0], m = function(Ue) { + return Ue.pstyle("display").value !== "none"; + }, b = !n || m(e) && (!l || m(e.source()) && m(e.target())); + if (b) { + var E = 0, M = 0; + n && r.includeOverlays && (E = e.pstyle("overlay-opacity").value, E !== 0 && (M = e.pstyle("overlay-padding").value)); + var L = 0, w = 0; + n && r.includeUnderlays && (L = e.pstyle("underlay-opacity").value, L !== 0 && (w = e.pstyle("underlay-padding").value)); + var k = Math.max(M, w), D = 0, F = 0; + if (n && (D = e.pstyle("width").pfValue, F = D / 2), u && r.includeNodes) { + var G = e.position(); + c = G.x, y = G.y; + var N = e.outerWidth(), X = N / 2, B = e.outerHeight(), re = B / 2; + f = c - X, h = c + X, v = y - re, d = y + re, rr(s, f, v, h, d), n && r.includeOutlines && rd(s, e); + } else if (l && r.includeEdges) + if (n && !i) { + var K = e.pstyle("curve-style").strValue; + if (f = Math.min(p.srcX, p.midX, p.tgtX), h = Math.max(p.srcX, p.midX, p.tgtX), v = Math.min(p.srcY, p.midY, p.tgtY), d = Math.max(p.srcY, p.midY, p.tgtY), f -= F, h += F, v -= F, d += F, rr(s, f, v, h, d), K === "haystack") { + var W = p.haystackPts; + if (W && W.length === 2) { + if (f = W[0].x, v = W[0].y, h = W[1].x, d = W[1].y, f > h) { + var ae = f; + f = h, h = ae; + } + if (v > d) { + var ue = v; + v = d, d = ue; + } + rr(s, f - F, v - F, h + F, d + F); + } + } else if (K === "bezier" || K === "unbundled-bezier" || K === "segments" || K === "taxi") { + var me; + switch (K) { + case "bezier": + case "unbundled-bezier": + me = p.bezierPts; + break; + case "segments": + case "taxi": + me = p.linePts; + break; + } + if (me != null) + for (var ie = 0; ie < me.length; ie++) { + var ge = me[ie]; + f = ge.x - F, h = ge.x + F, v = ge.y - F, d = ge.y + F, rr(s, f, v, h, d); + } + } + } else { + var Ee = e.source(), Ce = Ee.position(), we = e.target(), De = we.position(); + if (f = Ce.x, h = De.x, v = Ce.y, d = De.y, f > h) { + var se = f; + f = h, h = se; + } + if (v > d) { + var xe = v; + v = d, d = xe; + } + f -= F, h += F, v -= F, d += F, rr(s, f, v, h, d); + } + if (n && r.includeEdges && l && (On(s, e, "mid-source"), On(s, e, "mid-target"), On(s, e, "source"), On(s, e, "target")), n) { + var Le = e.pstyle("ghost").value === "yes"; + if (Le) { + var Se = e.pstyle("ghost-offset-x").pfValue, Oe = e.pstyle("ghost-offset-y").pfValue; + rr(s, s.x1 + Se, s.y1 + Oe, s.x2 + Se, s.y2 + Oe); + } + } + var Fe = o.bodyBounds = o.bodyBounds || {}; + xs(Fe, s), gn(Fe, g), dn(Fe, 1), n && (f = s.x1, h = s.x2, v = s.y1, d = s.y2, rr(s, f - k, v - k, h + k, d + k)); + var Xe = o.overlayBounds = o.overlayBounds || {}; + xs(Xe, s), gn(Xe, g), dn(Xe, 1); + var Ie = o.labelBounds = o.labelBounds || {}; + Ie.all != null ? xf(Ie.all) : Ie.all = Yt(), n && r.includeLabels && (r.includeMainLabels && Ai(s, e, null), l && (r.includeSourceLabels && Ai(s, e, "source"), r.includeTargetLabels && Ai(s, e, "target"))); + } + return s.x1 = Qt(s.x1), s.y1 = Qt(s.y1), s.x2 = Qt(s.x2), s.y2 = Qt(s.y2), s.w = Qt(s.x2 - s.x1), s.h = Qt(s.y2 - s.y1), s.w > 0 && s.h > 0 && b && (gn(s, g), dn(s, 1)), s; + }, yo = function(e) { + var r = 0, a = function(s) { + return (s ? 1 : 0) << r++; + }, n = 0; + return n += a(e.incudeNodes), n += a(e.includeEdges), n += a(e.includeLabels), n += a(e.includeMainLabels), n += a(e.includeSourceLabels), n += a(e.includeTargetLabels), n += a(e.includeOverlays), n += a(e.includeOutlines), n; + }, mo = function(e) { + if (e.isEdge()) { + var r = e.source().position(), a = e.target().position(), n = function(s) { + return Math.round(s); + }; + return $u([n(r.x), n(r.y), n(a.x), n(a.y)]); + } else + return 0; + }, bo = function(e, r) { + var a = e._private, n, i = e.isEdge(), s = r == null ? Eo : yo(r), o = s === Eo, u = mo(e), l = a.bbCachePosKey === u, f = r.useCache && l, h = function(y) { + return y._private.bbCache == null || y._private.styleDirty; + }, v = !f || h(e) || i && h(e.source()) || h(e.target()); + if (v ? (l || e.recalculateRenderedStyle(f), n = ad(e, $a), a.bbCache = n, a.bbCachePosKey = u) : n = a.bbCache, !o) { + var d = e.isNode(); + n = Yt(), (r.includeNodes && d || r.includeEdges && !d) && (r.includeOverlays ? Vr(n, a.overlayBounds) : Vr(n, a.bodyBounds)), r.includeLabels && (r.includeMainLabels && (!i || r.includeSourceLabels && r.includeTargetLabels) ? Vr(n, a.labelBounds.all) : (r.includeMainLabels && Vr(n, a.labelBounds.mainRot), r.includeSourceLabels && Vr(n, a.labelBounds.sourceRot), r.includeTargetLabels && Vr(n, a.labelBounds.targetRot))), n.w = n.x2 - n.x1, n.h = n.y2 - n.y1; + } + return n; + }, $a = { + includeNodes: !0, + includeEdges: !0, + includeLabels: !0, + includeMainLabels: !0, + includeSourceLabels: !0, + includeTargetLabels: !0, + includeOverlays: !0, + includeUnderlays: !0, + includeOutlines: !0, + useCache: !0 + }, Eo = yo($a), wo = At($a); + Or.boundingBox = function(t) { + var e; + if (this.length === 1 && this[0]._private.bbCache != null && !this[0]._private.styleDirty && (t === void 0 || t.useCache === void 0 || t.useCache === !0)) + t === void 0 ? t = $a : t = wo(t), e = bo(this[0], t); + else { + e = Yt(), t = t || $a; + var r = wo(t), a = this, n = a.cy(), i = n.styleEnabled(); + if (i) + for (var s = 0; s < a.length; s++) { + var o = a[s], u = o._private, l = mo(o), f = u.bbCachePosKey === l, h = r.useCache && f && !u.styleDirty; + o.recalculateRenderedStyle(h); + } + this.updateCompoundBounds(!t.useCache); + for (var v = 0; v < a.length; v++) { + var d = a[v]; + Vr(e, bo(d, r)); + } + } + return e.x1 = Qt(e.x1), e.y1 = Qt(e.y1), e.x2 = Qt(e.x2), e.y2 = Qt(e.y2), e.w = Qt(e.x2 - e.x1), e.h = Qt(e.y2 - e.y1), e; + }, Or.dirtyBoundingBoxCache = function() { + for (var t = 0; t < this.length; t++) { + var e = this[t]._private; + e.bbCache = null, e.bbCachePosKey = null, e.bodyBounds = null, e.overlayBounds = null, e.labelBounds.all = null, e.labelBounds.source = null, e.labelBounds.target = null, e.labelBounds.main = null, e.labelBounds.sourceRot = null, e.labelBounds.targetRot = null, e.labelBounds.mainRot = null, e.arrowBounds.source = null, e.arrowBounds.target = null, e.arrowBounds["mid-source"] = null, e.arrowBounds["mid-target"] = null; + } + return this.emitAndNotify("bounds"), this; + }, Or.boundingBoxAt = function(t) { + var e = this.nodes(), r = this.cy(), a = r.hasCompoundNodes(), n = r.collection(); + if (a && (n = e.filter(function(l) { + return l.isParent(); + }), e = e.not(n)), S(t)) { + var i = t; + t = function() { + return i; + }; + } + var s = function(f, h) { + return f._private.bbAtOldPos = t(f, h); + }, o = function(f) { + return f._private.bbAtOldPos; + }; + r.startBatch(), e.forEach(s).silentPositions(t), a && (n.dirtyCompoundBoundsCache(), n.dirtyBoundingBoxCache(), n.updateCompoundBounds(!0)); + var u = wf(this.boundingBox({ + useCache: !1 + })); + return e.silentPositions(o), a && (n.dirtyCompoundBoundsCache(), n.dirtyBoundingBoxCache(), n.updateCompoundBounds(!0)), r.endBatch(), u; + }, va.boundingbox = va.bb = va.boundingBox, va.renderedBoundingbox = va.renderedBoundingBox; + var nd = Or, _a, Ya; + _a = Ya = {}; + var xo = function(e) { + e.uppercaseName = Pt(e.name), e.autoName = "auto" + e.uppercaseName, e.labelName = "label" + e.uppercaseName, e.outerName = "outer" + e.uppercaseName, e.uppercaseOuterName = Pt(e.outerName), _a[e.name] = function() { + var a = this[0], n = a._private, i = n.cy, s = i._private.styleEnabled; + if (a) + if (s) { + if (a.isParent()) + return a.updateCompoundBounds(), n[e.autoName] || 0; + var o = a.pstyle(e.name); + switch (o.strValue) { + case "label": + return a.recalculateRenderedStyle(), n.rstyle[e.labelName] || 0; + default: + return o.pfValue; + } + } else + return 1; + }, _a["outer" + e.uppercaseName] = function() { + var a = this[0], n = a._private, i = n.cy, s = i._private.styleEnabled; + if (a) + if (s) { + var o = a[e.name](), u = a.pstyle("border-width").pfValue, l = 2 * a.padding(); + return o + u + l; + } else + return 1; + }, _a["rendered" + e.uppercaseName] = function() { + var a = this[0]; + if (a) { + var n = a[e.name](); + return n * this.cy().zoom(); + } + }, _a["rendered" + e.uppercaseOuterName] = function() { + var a = this[0]; + if (a) { + var n = a[e.outerName](); + return n * this.cy().zoom(); + } + }; + }; + xo({ + name: "width" + }), xo({ + name: "height" + }), Ya.padding = function() { + var t = this[0], e = t._private; + return t.isParent() ? (t.updateCompoundBounds(), e.autoPadding !== void 0 ? e.autoPadding : t.pstyle("padding").pfValue) : t.pstyle("padding").pfValue; + }, Ya.paddedHeight = function() { + var t = this[0]; + return t.height() + 2 * t.padding(); + }, Ya.paddedWidth = function() { + var t = this[0]; + return t.width() + 2 * t.padding(); + }; + var id = Ya, sd = function(e, r) { + if (e.isEdge()) + return r(e); + }, od = function(e, r) { + if (e.isEdge()) { + var a = e.cy(); + return vn(r(e), a.zoom(), a.pan()); + } + }, ld = function(e, r) { + if (e.isEdge()) { + var a = e.cy(), n = a.pan(), i = a.zoom(); + return r(e).map(function(s) { + return vn(s, i, n); + }); + } + }, ud = function(e) { + return e.renderer().getControlPoints(e); + }, fd = function(e) { + return e.renderer().getSegmentPoints(e); + }, hd = function(e) { + return e.renderer().getSourceEndpoint(e); + }, vd = function(e) { + return e.renderer().getTargetEndpoint(e); + }, cd = function(e) { + return e.renderer().getEdgeMidpoint(e); + }, To = { + controlPoints: { + get: ud, + mult: !0 + }, + segmentPoints: { + get: fd, + mult: !0 + }, + sourceEndpoint: { + get: hd + }, + targetEndpoint: { + get: vd + }, + midpoint: { + get: cd + } + }, dd = function(e) { + return "rendered" + e[0].toUpperCase() + e.substr(1); + }, gd = Object.keys(To).reduce(function(t, e) { + var r = To[e], a = dd(e); + return t[e] = function() { + return sd(this, r.get); + }, r.mult ? t[a] = function() { + return ld(this, r.get); + } : t[a] = function() { + return od(this, r.get); + }, t; + }, {}), pd = He({}, td, nd, id, gd); + /*! + Event object based on jQuery events, MIT license + + https://jquery.org/license/ + https://tldrlegal.com/license/mit-license + https://github.com/jquery/jquery/blob/master/src/event.js + */ + var Co = function(e, r) { + this.recycle(e, r); + }; + function Ha() { + return !1; + } + function Nn() { + return !0; + } + Co.prototype = { + instanceString: function() { + return "event"; + }, + recycle: function(e, r) { + if (this.isImmediatePropagationStopped = this.isPropagationStopped = this.isDefaultPrevented = Ha, e != null && e.preventDefault ? (this.type = e.type, this.isDefaultPrevented = e.defaultPrevented ? Nn : Ha) : e != null && e.type ? r = e : this.type = e, r != null && (this.originalEvent = r.originalEvent, this.type = r.type != null ? r.type : this.type, this.cy = r.cy, this.target = r.target, this.position = r.position, this.renderedPosition = r.renderedPosition, this.namespace = r.namespace, this.layout = r.layout), this.cy != null && this.position != null && this.renderedPosition == null) { + var a = this.position, n = this.cy.zoom(), i = this.cy.pan(); + this.renderedPosition = { + x: a.x * n + i.x, + y: a.y * n + i.y + }; + } + this.timeStamp = e && e.timeStamp || Date.now(); + }, + preventDefault: function() { + this.isDefaultPrevented = Nn; + var e = this.originalEvent; + e && e.preventDefault && e.preventDefault(); + }, + stopPropagation: function() { + this.isPropagationStopped = Nn; + var e = this.originalEvent; + e && e.stopPropagation && e.stopPropagation(); + }, + stopImmediatePropagation: function() { + this.isImmediatePropagationStopped = Nn, this.stopPropagation(); + }, + isDefaultPrevented: Ha, + isPropagationStopped: Ha, + isImmediatePropagationStopped: Ha + }; + var Do = /^([^.]+)(\.(?:[^.]+))?$/, yd = ".*", So = { + qualifierCompare: function(e, r) { + return e === r; + }, + eventMatches: function() { + return !0; + }, + addEventFields: function() { + }, + callbackContext: function(e) { + return e; + }, + beforeEmit: function() { + }, + afterEmit: function() { + }, + bubble: function() { + return !1; + }, + parent: function() { + return null; + }, + context: null + }, Lo = Object.keys(So), md = {}; + function In() { + for (var t = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : md, e = arguments.length > 1 ? arguments[1] : void 0, r = 0; r < Lo.length; r++) { + var a = Lo[r]; + this[a] = t[a] || So[a]; + } + this.context = e || this.context, this.listeners = [], this.emitting = 0; + } + var Nr = In.prototype, Ao = function(e, r, a, n, i, s, o) { + H(n) && (i = n, n = null), o && (s == null ? s = o : s = He({}, s, o)); + for (var u = te(a) ? a : a.split(/\s+/), l = 0; l < u.length; l++) { + var f = u[l]; + if (!Re(f)) { + var h = f.match(Do); + if (h) { + var v = h[1], d = h[2] ? h[2] : null, c = r(e, f, v, d, n, i, s); + if (c === !1) + break; + } + } + } + }, Oo = function(e, r) { + return e.addEventFields(e.context, r), new Co(r.type, r); + }, bd = function(e, r, a) { + if (dt(a)) { + r(e, a); + return; + } else if (S(a)) { + r(e, Oo(e, a)); + return; + } + for (var n = te(a) ? a : a.split(/\s+/), i = 0; i < n.length; i++) { + var s = n[i]; + if (!Re(s)) { + var o = s.match(Do); + if (o) { + var u = o[1], l = o[2] ? o[2] : null, f = Oo(e, { + type: u, + namespace: l, + target: e.context + }); + r(e, f); + } + } + } + }; + Nr.on = Nr.addListener = function(t, e, r, a, n) { + return Ao(this, function(i, s, o, u, l, f, h) { + H(f) && i.listeners.push({ + event: s, + // full event string + callback: f, + // callback to run + type: o, + // the event type (e.g. 'click') + namespace: u, + // the event namespace (e.g. ".foo") + qualifier: l, + // a restriction on whether to match this emitter + conf: h + // additional configuration + }); + }, t, e, r, a, n), this; + }, Nr.one = function(t, e, r, a) { + return this.on(t, e, r, a, { + one: !0 + }); + }, Nr.removeListener = Nr.off = function(t, e, r, a) { + var n = this; + this.emitting !== 0 && (this.listeners = Wu(this.listeners)); + for (var i = this.listeners, s = function(l) { + var f = i[l]; + Ao(n, function(h, v, d, c, y, p) { + if ((f.type === d || t === "*") && (!c && f.namespace !== ".*" || f.namespace === c) && (!y || h.qualifierCompare(f.qualifier, y)) && (!p || f.callback === p)) + return i.splice(l, 1), !1; + }, t, e, r, a); + }, o = i.length - 1; o >= 0; o--) + s(o); + return this; + }, Nr.removeAllListeners = function() { + return this.removeListener("*"); + }, Nr.emit = Nr.trigger = function(t, e, r) { + var a = this.listeners, n = a.length; + return this.emitting++, te(e) || (e = [e]), bd(this, function(i, s) { + r != null && (a = [{ + event: s.event, + type: s.type, + namespace: s.namespace, + callback: r + }], n = a.length); + for (var o = function(f) { + var h = a[f]; + if (h.type === s.type && (!h.namespace || h.namespace === s.namespace || h.namespace === yd) && i.eventMatches(i.context, h, s)) { + var v = [s]; + e != null && Ku(v, e), i.beforeEmit(i.context, h, s), h.conf && h.conf.one && (i.listeners = i.listeners.filter(function(y) { + return y !== h; + })); + var d = i.callbackContext(i.context, h, s), c = h.callback.apply(d, v); + i.afterEmit(i.context, h, s), c === !1 && (s.stopPropagation(), s.preventDefault()); + } + }, u = 0; u < n; u++) + o(u); + i.bubble(i.context) && !s.isPropagationStopped() && i.parent(i.context).emit(s, e); + }, t), this.emitting--, this; + }; + var Ed = { + qualifierCompare: function(e, r) { + return e == null || r == null ? e == null && r == null : e.sameText(r); + }, + eventMatches: function(e, r, a) { + var n = r.qualifier; + return n != null ? e !== a.target && Ae(a.target) && n.matches(a.target) : !0; + }, + addEventFields: function(e, r) { + r.cy = e.cy(), r.target = e; + }, + callbackContext: function(e, r, a) { + return r.qualifier != null ? a.target : e; + }, + beforeEmit: function(e, r) { + r.conf && r.conf.once && r.conf.onceCollection.removeListener(r.event, r.qualifier, r.callback); + }, + bubble: function() { + return !0; + }, + parent: function(e) { + return e.isChild() ? e.parent() : e.cy(); + } + }, Mn = function(e) { + return ee(e) ? new Sr(e) : e; + }, No = { + createEmitter: function() { + for (var e = 0; e < this.length; e++) { + var r = this[e], a = r._private; + a.emitter || (a.emitter = new In(Ed, r)); + } + return this; + }, + emitter: function() { + return this._private.emitter; + }, + on: function(e, r, a) { + for (var n = Mn(r), i = 0; i < this.length; i++) { + var s = this[i]; + s.emitter().on(e, n, a); + } + return this; + }, + removeListener: function(e, r, a) { + for (var n = Mn(r), i = 0; i < this.length; i++) { + var s = this[i]; + s.emitter().removeListener(e, n, a); + } + return this; + }, + removeAllListeners: function() { + for (var e = 0; e < this.length; e++) { + var r = this[e]; + r.emitter().removeAllListeners(); + } + return this; + }, + one: function(e, r, a) { + for (var n = Mn(r), i = 0; i < this.length; i++) { + var s = this[i]; + s.emitter().one(e, n, a); + } + return this; + }, + once: function(e, r, a) { + for (var n = Mn(r), i = 0; i < this.length; i++) { + var s = this[i]; + s.emitter().on(e, n, a, { + once: !0, + onceCollection: this + }); + } + }, + emit: function(e, r) { + for (var a = 0; a < this.length; a++) { + var n = this[a]; + n.emitter().emit(e, r); + } + return this; + }, + emitAndNotify: function(e, r) { + if (this.length !== 0) + return this.cy().notify(e, this), this.emit(e, r), this; + } + }; + ct.eventAliasesOn(No); + var Io = { + nodes: function(e) { + return this.filter(function(r) { + return r.isNode(); + }).filter(e); + }, + edges: function(e) { + return this.filter(function(r) { + return r.isEdge(); + }).filter(e); + }, + // internal helper to get nodes and edges as separate collections with single iteration over elements + byGroup: function() { + for (var e = this.spawn(), r = this.spawn(), a = 0; a < this.length; a++) { + var n = this[a]; + n.isNode() ? e.push(n) : r.push(n); + } + return { + nodes: e, + edges: r + }; + }, + filter: function(e, r) { + if (e === void 0) + return this; + if (ee(e) || pe(e)) + return new Sr(e).filter(this); + if (H(e)) { + for (var a = this.spawn(), n = this, i = 0; i < n.length; i++) { + var s = n[i], o = r ? e.apply(r, [s, i, n]) : e(s, i, n); + o && a.push(s); + } + return a; + } + return this.spawn(); + }, + not: function(e) { + if (e) { + ee(e) && (e = this.filter(e)); + for (var r = this.spawn(), a = 0; a < this.length; a++) { + var n = this[a], i = e.has(n); + i || r.push(n); + } + return r; + } else + return this; + }, + absoluteComplement: function() { + var e = this.cy(); + return e.mutableElements().not(this); + }, + intersect: function(e) { + if (ee(e)) { + var r = e; + return this.filter(r); + } + for (var a = this.spawn(), n = this, i = e, s = this.length < e.length, o = s ? n : i, u = s ? i : n, l = 0; l < o.length; l++) { + var f = o[l]; + u.has(f) && a.push(f); + } + return a; + }, + xor: function(e) { + var r = this._private.cy; + ee(e) && (e = r.$(e)); + var a = this.spawn(), n = this, i = e, s = function(u, l) { + for (var f = 0; f < u.length; f++) { + var h = u[f], v = h._private.data.id, d = l.hasElementWithId(v); + d || a.push(h); + } + }; + return s(n, i), s(i, n), a; + }, + diff: function(e) { + var r = this._private.cy; + ee(e) && (e = r.$(e)); + var a = this.spawn(), n = this.spawn(), i = this.spawn(), s = this, o = e, u = function(f, h, v) { + for (var d = 0; d < f.length; d++) { + var c = f[d], y = c._private.data.id, p = h.hasElementWithId(y); + p ? i.merge(c) : v.push(c); + } + }; + return u(s, o, a), u(o, s, n), { + left: a, + right: n, + both: i + }; + }, + add: function(e) { + var r = this._private.cy; + if (!e) + return this; + if (ee(e)) { + var a = e; + e = r.mutableElements().filter(a); + } + for (var n = this.spawnSelf(), i = 0; i < e.length; i++) { + var s = e[i], o = !this.has(s); + o && n.push(s); + } + return n; + }, + // in place merge on calling collection + merge: function(e) { + var r = this._private, a = r.cy; + if (!e) + return this; + if (e && ee(e)) { + var n = e; + e = a.mutableElements().filter(n); + } + for (var i = r.map, s = 0; s < e.length; s++) { + var o = e[s], u = o._private.data.id, l = !i.has(u); + if (l) { + var f = this.length++; + this[f] = o, i.set(u, { + ele: o, + index: f + }); + } + } + return this; + }, + unmergeAt: function(e) { + var r = this[e], a = r.id(), n = this._private, i = n.map; + this[e] = void 0, i.delete(a); + var s = e === this.length - 1; + if (this.length > 1 && !s) { + var o = this.length - 1, u = this[o], l = u._private.data.id; + this[o] = void 0, this[e] = u, i.set(l, { + ele: u, + index: e + }); + } + return this.length--, this; + }, + // remove single ele in place in calling collection + unmergeOne: function(e) { + e = e[0]; + var r = this._private, a = e._private.data.id, n = r.map, i = n.get(a); + if (!i) + return this; + var s = i.index; + return this.unmergeAt(s), this; + }, + // remove eles in place on calling collection + unmerge: function(e) { + var r = this._private.cy; + if (!e) + return this; + if (e && ee(e)) { + var a = e; + e = r.mutableElements().filter(a); + } + for (var n = 0; n < e.length; n++) + this.unmergeOne(e[n]); + return this; + }, + unmergeBy: function(e) { + for (var r = this.length - 1; r >= 0; r--) { + var a = this[r]; + e(a) && this.unmergeAt(r); + } + return this; + }, + map: function(e, r) { + for (var a = [], n = this, i = 0; i < n.length; i++) { + var s = n[i], o = r ? e.apply(r, [s, i, n]) : e(s, i, n); + a.push(o); + } + return a; + }, + reduce: function(e, r) { + for (var a = r, n = this, i = 0; i < n.length; i++) + a = e(a, n[i], i, n); + return a; + }, + max: function(e, r) { + for (var a = -1 / 0, n, i = this, s = 0; s < i.length; s++) { + var o = i[s], u = r ? e.apply(r, [o, s, i]) : e(o, s, i); + u > a && (a = u, n = o); + } + return { + value: a, + ele: n + }; + }, + min: function(e, r) { + for (var a = 1 / 0, n, i = this, s = 0; s < i.length; s++) { + var o = i[s], u = r ? e.apply(r, [o, s, i]) : e(o, s, i); + u < a && (a = u, n = o); + } + return { + value: a, + ele: n + }; + } + }, lt = Io; + lt.u = lt["|"] = lt["+"] = lt.union = lt.or = lt.add, lt["\\"] = lt["!"] = lt["-"] = lt.difference = lt.relativeComplement = lt.subtract = lt.not, lt.n = lt["&"] = lt["."] = lt.and = lt.intersection = lt.intersect, lt["^"] = lt["(+)"] = lt["(-)"] = lt.symmetricDifference = lt.symdiff = lt.xor, lt.fnFilter = lt.filterFn = lt.stdFilter = lt.filter, lt.complement = lt.abscomp = lt.absoluteComplement; + var wd = { + isNode: function() { + return this.group() === "nodes"; + }, + isEdge: function() { + return this.group() === "edges"; + }, + isLoop: function() { + return this.isEdge() && this.source()[0] === this.target()[0]; + }, + isSimple: function() { + return this.isEdge() && this.source()[0] !== this.target()[0]; + }, + group: function() { + var e = this[0]; + if (e) + return e._private.group; + } + }, Mo = function(e, r) { + var a = e.cy(), n = a.hasCompoundNodes(); + function i(f) { + var h = f.pstyle("z-compound-depth"); + return h.value === "auto" ? n ? f.zDepth() : 0 : h.value === "bottom" ? -1 : h.value === "top" ? ii : 0; + } + var s = i(e) - i(r); + if (s !== 0) + return s; + function o(f) { + var h = f.pstyle("z-index-compare"); + return h.value === "auto" && f.isNode() ? 1 : 0; + } + var u = o(e) - o(r); + if (u !== 0) + return u; + var l = e.pstyle("z-index").value - r.pstyle("z-index").value; + return l !== 0 ? l : e.poolIndex() - r.poolIndex(); + }, Rn = { + forEach: function(e, r) { + if (H(e)) + for (var a = this.length, n = 0; n < a; n++) { + var i = this[n], s = r ? e.apply(r, [i, n, this]) : e(i, n, this); + if (s === !1) + break; + } + return this; + }, + toArray: function() { + for (var e = [], r = 0; r < this.length; r++) + e.push(this[r]); + return e; + }, + slice: function(e, r) { + var a = [], n = this.length; + r == null && (r = n), e == null && (e = 0), e < 0 && (e = n + e), r < 0 && (r = n + r); + for (var i = e; i >= 0 && i < r && i < n; i++) + a.push(this[i]); + return this.spawn(a); + }, + size: function() { + return this.length; + }, + eq: function(e) { + return this[e] || this.spawn(); + }, + first: function() { + return this[0] || this.spawn(); + }, + last: function() { + return this[this.length - 1] || this.spawn(); + }, + empty: function() { + return this.length === 0; + }, + nonempty: function() { + return !this.empty(); + }, + sort: function(e) { + if (!H(e)) + return this; + var r = this.toArray().sort(e); + return this.spawn(r); + }, + sortByZIndex: function() { + return this.sort(Mo); + }, + zDepth: function() { + var e = this[0]; + if (e) { + var r = e._private, a = r.group; + if (a === "nodes") { + var n = r.data.parent ? e.parents().size() : 0; + return e.isParent() ? n : ii - 1; + } else { + var i = r.source, s = r.target, o = i.zDepth(), u = s.zDepth(); + return Math.max(o, u, 0); + } + } + } + }; + Rn.each = Rn.forEach; + var xd = function() { + var e = "undefined", r = (typeof Symbol > "u" ? "undefined" : _(Symbol)) != e && _(Symbol.iterator) != e; + r && (Rn[Symbol.iterator] = function() { + var a = this, n = { + value: void 0, + done: !1 + }, i = 0, s = this.length; + return T({ + next: function() { + return i < s ? n.value = a[i++] : (n.value = void 0, n.done = !0), n; + } + }, Symbol.iterator, function() { + return this; + }); + }); + }; + xd(); + var Td = At({ + nodeDimensionsIncludeLabels: !1 + }), kn = { + // Calculates and returns node dimensions { x, y } based on options given + layoutDimensions: function(e) { + e = Td(e); + var r; + if (!this.takesUpSpace()) + r = { + w: 0, + h: 0 + }; + else if (e.nodeDimensionsIncludeLabels) { + var a = this.boundingBox(); + r = { + w: a.w, + h: a.h + }; + } else + r = { + w: this.outerWidth(), + h: this.outerHeight() + }; + return (r.w === 0 || r.h === 0) && (r.w = r.h = 1), r; + }, + // using standard layout options, apply position function (w/ or w/o animation) + layoutPositions: function(e, r, a) { + var n = this.nodes().filter(function(M) { + return !M.isParent(); + }), i = this.cy(), s = r.eles, o = function(L) { + return L.id(); + }, u = it(a, o); + e.emit({ + type: "layoutstart", + layout: e + }), e.animations = []; + var l = function(L, w, k) { + var D = { + x: w.x1 + w.w / 2, + y: w.y1 + w.h / 2 + }, F = { + // scale from center of bounding box (not necessarily 0,0) + x: (k.x - D.x) * L, + y: (k.y - D.y) * L + }; + return { + x: D.x + F.x, + y: D.y + F.y + }; + }, f = r.spacingFactor && r.spacingFactor !== 1, h = function() { + if (!f) + return null; + for (var L = Yt(), w = 0; w < n.length; w++) { + var k = n[w], D = u(k, w); + Cf(L, D.x, D.y); + } + return L; + }, v = h(), d = it(function(M, L) { + var w = u(M, L); + if (f) { + var k = Math.abs(r.spacingFactor); + w = l(k, v, w); + } + return r.transform != null && (w = r.transform(M, w)), w; + }, o); + if (r.animate) { + for (var c = 0; c < n.length; c++) { + var y = n[c], p = d(y, c), g = r.animateFilter == null || r.animateFilter(y, c); + if (g) { + var m = y.animation({ + position: p, + duration: r.animationDuration, + easing: r.animationEasing + }); + e.animations.push(m); + } else + y.position(p); + } + if (r.fit) { + var b = i.animation({ + fit: { + boundingBox: s.boundingBoxAt(d), + padding: r.padding + }, + duration: r.animationDuration, + easing: r.animationEasing + }); + e.animations.push(b); + } else if (r.zoom !== void 0 && r.pan !== void 0) { + var E = i.animation({ + zoom: r.zoom, + pan: r.pan, + duration: r.animationDuration, + easing: r.animationEasing + }); + e.animations.push(E); + } + e.animations.forEach(function(M) { + return M.play(); + }), e.one("layoutready", r.ready), e.emit({ + type: "layoutready", + layout: e + }), ia.all(e.animations.map(function(M) { + return M.promise(); + })).then(function() { + e.one("layoutstop", r.stop), e.emit({ + type: "layoutstop", + layout: e + }); + }); + } else + n.positions(d), r.fit && i.fit(r.eles, r.padding), r.zoom != null && i.zoom(r.zoom), r.pan && i.pan(r.pan), e.one("layoutready", r.ready), e.emit({ + type: "layoutready", + layout: e + }), e.one("layoutstop", r.stop), e.emit({ + type: "layoutstop", + layout: e + }); + return this; + }, + layout: function(e) { + var r = this.cy(); + return r.makeLayout(He({}, e, { + eles: this + })); + } + }; + kn.createLayout = kn.makeLayout = kn.layout; + function Ro(t, e, r) { + var a = r._private, n = a.styleCache = a.styleCache || [], i; + return (i = n[t]) != null || (i = n[t] = e(r)), i; + } + function Pn(t, e) { + return t = Pr(t), function(a) { + return Ro(t, e, a); + }; + } + function Bn(t, e) { + t = Pr(t); + var r = function(n) { + return e.call(n); + }; + return function() { + var n = this[0]; + if (n) + return Ro(t, r, n); + }; + } + var Ot = { + recalculateRenderedStyle: function(e) { + var r = this.cy(), a = r.renderer(), n = r.styleEnabled(); + return a && n && a.recalculateRenderedStyle(this, e), this; + }, + dirtyStyleCache: function() { + var e = this.cy(), r = function(i) { + return i._private.styleCache = null; + }; + if (e.hasCompoundNodes()) { + var a; + a = this.spawnSelf().merge(this.descendants()).merge(this.parents()), a.merge(a.connectedEdges()), a.forEach(r); + } else + this.forEach(function(n) { + r(n), n.connectedEdges().forEach(r); + }); + return this; + }, + // fully updates (recalculates) the style for the elements + updateStyle: function(e) { + var r = this._private.cy; + if (!r.styleEnabled()) + return this; + if (r.batching()) { + var a = r._private.batchStyleEles; + return a.merge(this), this; + } + var n = r.hasCompoundNodes(), i = this; + e = !!(e || e === void 0), n && (i = this.spawnSelf().merge(this.descendants()).merge(this.parents())); + var s = i; + return e ? s.emitAndNotify("style") : s.emit("style"), i.forEach(function(o) { + return o._private.styleDirty = !0; + }), this; + }, + // private: clears dirty flag and recalculates style + cleanStyle: function() { + var e = this.cy(); + if (e.styleEnabled()) + for (var r = 0; r < this.length; r++) { + var a = this[r]; + a._private.styleDirty && (a._private.styleDirty = !1, e.style().apply(a)); + } + }, + // get the internal parsed style object for the specified property + parsedStyle: function(e) { + var r = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : !0, a = this[0], n = a.cy(); + if (n.styleEnabled() && a) { + this.cleanStyle(); + var i = a._private.style[e]; + return i ?? (r ? n.style().getDefaultProperty(e) : null); + } + }, + numericStyle: function(e) { + var r = this[0]; + if (r.cy().styleEnabled() && r) { + var a = r.pstyle(e); + return a.pfValue !== void 0 ? a.pfValue : a.value; + } + }, + numericStyleUnits: function(e) { + var r = this[0]; + if (r.cy().styleEnabled() && r) + return r.pstyle(e).units; + }, + // get the specified css property as a rendered value (i.e. on-screen value) + // or get the whole rendered style if no property specified (NB doesn't allow setting) + renderedStyle: function(e) { + var r = this.cy(); + if (!r.styleEnabled()) + return this; + var a = this[0]; + if (a) + return r.style().getRenderedStyle(a, e); + }, + // read the calculated css style of the element or override the style (via a bypass) + style: function(e, r) { + var a = this.cy(); + if (!a.styleEnabled()) + return this; + var n = !1, i = a.style(); + if (S(e)) { + var s = e; + i.applyBypass(this, s, n), this.emitAndNotify("style"); + } else if (ee(e)) + if (r === void 0) { + var o = this[0]; + return o ? i.getStylePropertyValue(o, e) : void 0; + } else + i.applyBypass(this, e, r, n), this.emitAndNotify("style"); + else if (e === void 0) { + var u = this[0]; + return u ? i.getRawStyle(u) : void 0; + } + return this; + }, + removeStyle: function(e) { + var r = this.cy(); + if (!r.styleEnabled()) + return this; + var a = !1, n = r.style(), i = this; + if (e === void 0) + for (var s = 0; s < i.length; s++) { + var o = i[s]; + n.removeAllBypasses(o, a); + } + else { + e = e.split(/\s+/); + for (var u = 0; u < i.length; u++) { + var l = i[u]; + n.removeBypasses(l, e, a); + } + } + return this.emitAndNotify("style"), this; + }, + show: function() { + return this.css("display", "element"), this; + }, + hide: function() { + return this.css("display", "none"), this; + }, + effectiveOpacity: function() { + var e = this.cy(); + if (!e.styleEnabled()) + return 1; + var r = e.hasCompoundNodes(), a = this[0]; + if (a) { + var n = a._private, i = a.pstyle("opacity").value; + if (!r) + return i; + var s = n.data.parent ? a.parents() : null; + if (s) + for (var o = 0; o < s.length; o++) { + var u = s[o], l = u.pstyle("opacity").value; + i = l * i; + } + return i; + } + }, + transparent: function() { + var e = this.cy(); + if (!e.styleEnabled()) + return !1; + var r = this[0], a = r.cy().hasCompoundNodes(); + if (r) + return a ? r.effectiveOpacity() === 0 : r.pstyle("opacity").value === 0; + }, + backgrounding: function() { + var e = this.cy(); + if (!e.styleEnabled()) + return !1; + var r = this[0]; + return !!r._private.backgrounding; + } + }; + function Oi(t, e) { + var r = t._private, a = r.data.parent ? t.parents() : null; + if (a) + for (var n = 0; n < a.length; n++) { + var i = a[n]; + if (!e(i)) + return !1; + } + return !0; + } + function Ni(t) { + var e = t.ok, r = t.edgeOkViaNode || t.ok, a = t.parentOk || t.ok; + return function() { + var n = this.cy(); + if (!n.styleEnabled()) + return !0; + var i = this[0], s = n.hasCompoundNodes(); + if (i) { + var o = i._private; + if (!e(i)) + return !1; + if (i.isNode()) + return !s || Oi(i, a); + var u = o.source, l = o.target; + return r(u) && (!s || Oi(u, r)) && (u === l || r(l) && (!s || Oi(l, r))); + } + }; + } + var ca = Pn("eleTakesUpSpace", function(t) { + return t.pstyle("display").value === "element" && t.width() !== 0 && (t.isNode() ? t.height() !== 0 : !0); + }); + Ot.takesUpSpace = Bn("takesUpSpace", Ni({ + ok: ca + })); + var Cd = Pn("eleInteractive", function(t) { + return t.pstyle("events").value === "yes" && t.pstyle("visibility").value === "visible" && ca(t); + }), Dd = Pn("parentInteractive", function(t) { + return t.pstyle("visibility").value === "visible" && ca(t); + }); + Ot.interactive = Bn("interactive", Ni({ + ok: Cd, + parentOk: Dd, + edgeOkViaNode: ca + })), Ot.noninteractive = function() { + var t = this[0]; + if (t) + return !t.interactive(); + }; + var Sd = Pn("eleVisible", function(t) { + return t.pstyle("visibility").value === "visible" && t.pstyle("opacity").pfValue !== 0 && ca(t); + }), Ld = ca; + Ot.visible = Bn("visible", Ni({ + ok: Sd, + edgeOkViaNode: Ld + })), Ot.hidden = function() { + var t = this[0]; + if (t) + return !t.visible(); + }, Ot.isBundledBezier = Bn("isBundledBezier", function() { + return this.cy().styleEnabled() ? !this.removed() && this.pstyle("curve-style").value === "bezier" && this.takesUpSpace() : !1; + }), Ot.bypass = Ot.css = Ot.style, Ot.renderedCss = Ot.renderedStyle, Ot.removeBypass = Ot.removeCss = Ot.removeStyle, Ot.pstyle = Ot.parsedStyle; + var Ir = {}; + function ko(t) { + return function() { + var e = arguments, r = []; + if (e.length === 2) { + var a = e[0], n = e[1]; + this.on(t.event, a, n); + } else if (e.length === 1 && H(e[0])) { + var i = e[0]; + this.on(t.event, i); + } else if (e.length === 0 || e.length === 1 && te(e[0])) { + for (var s = e.length === 1 ? e[0] : null, o = 0; o < this.length; o++) { + var u = this[o], l = !t.ableField || u._private[t.ableField], f = u._private[t.field] != t.value; + if (t.overrideAble) { + var h = t.overrideAble(u); + if (h !== void 0 && (l = h, !h)) + return this; + } + l && (u._private[t.field] = t.value, f && r.push(u)); + } + var v = this.spawn(r); + v.updateStyle(), v.emit(t.event), s && v.emit(s); + } + return this; + }; + } + function da(t) { + Ir[t.field] = function() { + var e = this[0]; + if (e) { + if (t.overrideField) { + var r = t.overrideField(e); + if (r !== void 0) + return r; + } + return e._private[t.field]; + } + }, Ir[t.on] = ko({ + event: t.on, + field: t.field, + ableField: t.ableField, + overrideAble: t.overrideAble, + value: !0 + }), Ir[t.off] = ko({ + event: t.off, + field: t.field, + ableField: t.ableField, + overrideAble: t.overrideAble, + value: !1 + }); + } + da({ + field: "locked", + overrideField: function(e) { + return e.cy().autolock() ? !0 : void 0; + }, + on: "lock", + off: "unlock" + }), da({ + field: "grabbable", + overrideField: function(e) { + return e.cy().autoungrabify() || e.pannable() ? !1 : void 0; + }, + on: "grabify", + off: "ungrabify" + }), da({ + field: "selected", + ableField: "selectable", + overrideAble: function(e) { + return e.cy().autounselectify() ? !1 : void 0; + }, + on: "select", + off: "unselect" + }), da({ + field: "selectable", + overrideField: function(e) { + return e.cy().autounselectify() ? !1 : void 0; + }, + on: "selectify", + off: "unselectify" + }), Ir.deselect = Ir.unselect, Ir.grabbed = function() { + var t = this[0]; + if (t) + return t._private.grabbed; + }, da({ + field: "active", + on: "activate", + off: "unactivate" + }), da({ + field: "pannable", + on: "panify", + off: "unpanify" + }), Ir.inactive = function() { + var t = this[0]; + if (t) + return !t._private.active; + }; + var Bt = {}, Po = function(e) { + return function(a) { + for (var n = this, i = [], s = 0; s < n.length; s++) { + var o = n[s]; + if (o.isNode()) { + for (var u = !1, l = o.connectedEdges(), f = 0; f < l.length; f++) { + var h = l[f], v = h.source(), d = h.target(); + if (e.noIncomingEdges && d === o && v !== o || e.noOutgoingEdges && v === o && d !== o) { + u = !0; + break; + } + } + u || i.push(o); + } + } + return this.spawn(i, !0).filter(a); + }; + }, Bo = function(e) { + return function(r) { + for (var a = this, n = [], i = 0; i < a.length; i++) { + var s = a[i]; + if (s.isNode()) + for (var o = s.connectedEdges(), u = 0; u < o.length; u++) { + var l = o[u], f = l.source(), h = l.target(); + e.outgoing && f === s ? (n.push(l), n.push(h)) : e.incoming && h === s && (n.push(l), n.push(f)); + } + } + return this.spawn(n, !0).filter(r); + }; + }, Fo = function(e) { + return function(r) { + for (var a = this, n = [], i = {}; ; ) { + var s = e.outgoing ? a.outgoers() : a.incomers(); + if (s.length === 0) + break; + for (var o = !1, u = 0; u < s.length; u++) { + var l = s[u], f = l.id(); + i[f] || (i[f] = !0, n.push(l), o = !0); + } + if (!o) + break; + a = s; + } + return this.spawn(n, !0).filter(r); + }; + }; + Bt.clearTraversalCache = function() { + for (var t = 0; t < this.length; t++) + this[t]._private.traversalCache = null; + }, He(Bt, { + // get the root nodes in the DAG + roots: Po({ + noIncomingEdges: !0 + }), + // get the leaf nodes in the DAG + leaves: Po({ + noOutgoingEdges: !0 + }), + // normally called children in graph theory + // these nodes =edges=> outgoing nodes + outgoers: Zt(Bo({ + outgoing: !0 + }), "outgoers"), + // aka DAG descendants + successors: Fo({ + outgoing: !0 + }), + // normally called parents in graph theory + // these nodes <=edges= incoming nodes + incomers: Zt(Bo({ + incoming: !0 + }), "incomers"), + // aka DAG ancestors + predecessors: Fo({ + incoming: !0 + }) + }), He(Bt, { + neighborhood: Zt(function(t) { + for (var e = [], r = this.nodes(), a = 0; a < r.length; a++) + for (var n = r[a], i = n.connectedEdges(), s = 0; s < i.length; s++) { + var o = i[s], u = o.source(), l = o.target(), f = n === u ? l : u; + f.length > 0 && e.push(f[0]), e.push(o[0]); + } + return this.spawn(e, !0).filter(t); + }, "neighborhood"), + closedNeighborhood: function(e) { + return this.neighborhood().add(this).filter(e); + }, + openNeighborhood: function(e) { + return this.neighborhood(e); + } + }), Bt.neighbourhood = Bt.neighborhood, Bt.closedNeighbourhood = Bt.closedNeighborhood, Bt.openNeighbourhood = Bt.openNeighborhood, He(Bt, { + source: Zt(function(e) { + var r = this[0], a; + return r && (a = r._private.source || r.cy().collection()), a && e ? a.filter(e) : a; + }, "source"), + target: Zt(function(e) { + var r = this[0], a; + return r && (a = r._private.target || r.cy().collection()), a && e ? a.filter(e) : a; + }, "target"), + sources: Go({ + attr: "source" + }), + targets: Go({ + attr: "target" + }) + }); + function Go(t) { + return function(r) { + for (var a = [], n = 0; n < this.length; n++) { + var i = this[n], s = i._private[t.attr]; + s && a.push(s); + } + return this.spawn(a, !0).filter(r); + }; + } + He(Bt, { + edgesWith: Zt(zo(), "edgesWith"), + edgesTo: Zt(zo({ + thisIsSrc: !0 + }), "edgesTo") + }); + function zo(t) { + return function(r) { + var a = [], n = this._private.cy, i = t || {}; + ee(r) && (r = n.$(r)); + for (var s = 0; s < r.length; s++) + for (var o = r[s]._private.edges, u = 0; u < o.length; u++) { + var l = o[u], f = l._private.data, h = this.hasElementWithId(f.source) && r.hasElementWithId(f.target), v = r.hasElementWithId(f.source) && this.hasElementWithId(f.target), d = h || v; + d && ((i.thisIsSrc || i.thisIsTgt) && (i.thisIsSrc && !h || i.thisIsTgt && !v) || a.push(l)); + } + return this.spawn(a, !0); + }; + } + He(Bt, { + connectedEdges: Zt(function(t) { + for (var e = [], r = this, a = 0; a < r.length; a++) { + var n = r[a]; + if (n.isNode()) + for (var i = n._private.edges, s = 0; s < i.length; s++) { + var o = i[s]; + e.push(o); + } + } + return this.spawn(e, !0).filter(t); + }, "connectedEdges"), + connectedNodes: Zt(function(t) { + for (var e = [], r = this, a = 0; a < r.length; a++) { + var n = r[a]; + n.isEdge() && (e.push(n.source()[0]), e.push(n.target()[0])); + } + return this.spawn(e, !0).filter(t); + }, "connectedNodes"), + parallelEdges: Zt(Vo(), "parallelEdges"), + codirectedEdges: Zt(Vo({ + codirected: !0 + }), "codirectedEdges") + }); + function Vo(t) { + var e = { + codirected: !1 + }; + return t = He({}, e, t), function(a) { + for (var n = [], i = this.edges(), s = t, o = 0; o < i.length; o++) + for (var u = i[o], l = u._private, f = l.source, h = f._private.data.id, v = l.data.target, d = f._private.edges, c = 0; c < d.length; c++) { + var y = d[c], p = y._private.data, g = p.target, m = p.source, b = g === v && m === h, E = h === g && v === m; + (s.codirected && b || !s.codirected && (b || E)) && n.push(y); + } + return this.spawn(n, !0).filter(a); + }; + } + He(Bt, { + components: function(e) { + var r = this, a = r.cy(), n = a.collection(), i = e == null ? r.nodes() : e.nodes(), s = []; + e != null && i.empty() && (i = e.sources()); + var o = function(f, h) { + n.merge(f), i.unmerge(f), h.merge(f); + }; + if (i.empty()) + return r.spawn(); + var u = function() { + var f = a.collection(); + s.push(f); + var h = i[0]; + o(h, f), r.bfs({ + directed: !1, + roots: h, + visit: function(d) { + return o(d, f); + } + }), f.forEach(function(v) { + v.connectedEdges().forEach(function(d) { + r.has(d) && f.has(d.source()) && f.has(d.target()) && f.merge(d); + }); + }); + }; + do + u(); + while (i.length > 0); + return s; + }, + component: function() { + var e = this[0]; + return e.cy().mutableElements().components(e)[0]; + } + }), Bt.componentsOf = Bt.components; + var Nt = function(e, r) { + var a = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : !1, n = arguments.length > 3 && arguments[3] !== void 0 ? arguments[3] : !1; + if (e === void 0) { + xt("A collection must have a reference to the core"); + return; + } + var i = new ur(), s = !1; + if (!r) + r = []; + else if (r.length > 0 && S(r[0]) && !Ae(r[0])) { + s = !0; + for (var o = [], u = new Jr(), l = 0, f = r.length; l < f; l++) { + var h = r[l]; + h.data == null && (h.data = {}); + var v = h.data; + if (v.id == null) + v.id = ps(); + else if (e.hasElementWithId(v.id) || u.has(v.id)) + continue; + var d = new hn(e, h, !1); + o.push(d), u.add(v.id); + } + r = o; + } + this.length = 0; + for (var c = 0, y = r.length; c < y; c++) { + var p = r[c][0]; + if (p != null) { + var g = p._private.data.id; + (!a || !i.has(g)) && (a && i.set(g, { + index: this.length, + ele: p + }), this[this.length] = p, this.length++); + } + } + this._private = { + eles: this, + cy: e, + get map() { + return this.lazyMap == null && this.rebuildMap(), this.lazyMap; + }, + set map(m) { + this.lazyMap = m; + }, + rebuildMap: function() { + for (var b = this.lazyMap = new ur(), E = this.eles, M = 0; M < E.length; M++) { + var L = E[M]; + b.set(L.id(), { + index: M, + ele: L + }); + } + } + }, a && (this._private.map = i), s && !n && this.restore(); + }, mt = hn.prototype = Nt.prototype = Object.create(Array.prototype); + mt.instanceString = function() { + return "collection"; + }, mt.spawn = function(t, e) { + return new Nt(this.cy(), t, e); + }, mt.spawnSelf = function() { + return this.spawn(this); + }, mt.cy = function() { + return this._private.cy; + }, mt.renderer = function() { + return this._private.cy.renderer(); + }, mt.element = function() { + return this[0]; + }, mt.collection = function() { + return Ne(this) ? this : new Nt(this._private.cy, [this]); + }, mt.unique = function() { + return new Nt(this._private.cy, this, !0); + }, mt.hasElementWithId = function(t) { + return t = "" + t, this._private.map.has(t); + }, mt.getElementById = function(t) { + t = "" + t; + var e = this._private.cy, r = this._private.map.get(t); + return r ? r.ele : new Nt(e); + }, mt.$id = mt.getElementById, mt.poolIndex = function() { + var t = this._private.cy, e = t._private.elements, r = this[0]._private.data.id; + return e._private.map.get(r).index; + }, mt.indexOf = function(t) { + var e = t[0]._private.data.id; + return this._private.map.get(e).index; + }, mt.indexOfId = function(t) { + return t = "" + t, this._private.map.get(t).index; + }, mt.json = function(t) { + var e = this.element(), r = this.cy(); + if (e == null && t) + return this; + if (e != null) { + var a = e._private; + if (S(t)) { + if (r.startBatch(), t.data) { + e.data(t.data); + var n = a.data; + if (e.isEdge()) { + var i = !1, s = {}, o = t.data.source, u = t.data.target; + o != null && o != n.source && (s.source = "" + o, i = !0), u != null && u != n.target && (s.target = "" + u, i = !0), i && (e = e.move(s)); + } else { + var l = "parent" in t.data, f = t.data.parent; + l && (f != null || n.parent != null) && f != n.parent && (f === void 0 && (f = null), f != null && (f = "" + f), e = e.move({ + parent: f + })); + } + } + t.position && e.position(t.position); + var h = function(y, p, g) { + var m = t[y]; + m != null && m !== a[y] && (m ? e[p]() : e[g]()); + }; + return h("removed", "remove", "restore"), h("selected", "select", "unselect"), h("selectable", "selectify", "unselectify"), h("locked", "lock", "unlock"), h("grabbable", "grabify", "ungrabify"), h("pannable", "panify", "unpanify"), t.classes != null && e.classes(t.classes), r.endBatch(), this; + } else if (t === void 0) { + var v = { + data: lr(a.data), + position: lr(a.position), + group: a.group, + removed: a.removed, + selected: a.selected, + selectable: a.selectable, + locked: a.locked, + grabbable: a.grabbable, + pannable: a.pannable, + classes: null + }; + v.classes = ""; + var d = 0; + return a.classes.forEach(function(c) { + return v.classes += d++ === 0 ? c : " " + c; + }), v; + } + } + }, mt.jsons = function() { + for (var t = [], e = 0; e < this.length; e++) { + var r = this[e], a = r.json(); + t.push(a); + } + return t; + }, mt.clone = function() { + for (var t = this.cy(), e = [], r = 0; r < this.length; r++) { + var a = this[r], n = a.json(), i = new hn(t, n, !1); + e.push(i); + } + return new Nt(t, e); + }, mt.copy = mt.clone, mt.restore = function() { + for (var t = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : !0, e = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : !0, r = this, a = r.cy(), n = a._private, i = [], s = [], o, u = 0, l = r.length; u < l; u++) { + var f = r[u]; + e && !f.removed() || (f.isNode() ? i.push(f) : s.push(f)); + } + o = i.concat(s); + var h, v = function() { + o.splice(h, 1), h--; + }; + for (h = 0; h < o.length; h++) { + var d = o[h], c = d._private, y = c.data; + if (d.clearTraversalCache(), !(!e && !c.removed)) { + if (y.id === void 0) + y.id = ps(); + else if (R(y.id)) + y.id = "" + y.id; + else if (Re(y.id) || !ee(y.id)) { + xt("Can not create element with invalid string ID `" + y.id + "`"), v(); + continue; + } else if (a.hasElementWithId(y.id)) { + xt("Can not create second element with ID `" + y.id + "`"), v(); + continue; + } + } + var p = y.id; + if (d.isNode()) { + var g = c.position; + g.x == null && (g.x = 0), g.y == null && (g.y = 0); + } + if (d.isEdge()) { + for (var m = d, b = ["source", "target"], E = b.length, M = !1, L = 0; L < E; L++) { + var w = b[L], k = y[w]; + R(k) && (k = y[w] = "" + y[w]), k == null || k === "" ? (xt("Can not create edge `" + p + "` with unspecified " + w), M = !0) : a.hasElementWithId(k) || (xt("Can not create edge `" + p + "` with nonexistant " + w + " `" + k + "`"), M = !0); + } + if (M) { + v(); + continue; + } + var D = a.getElementById(y.source), F = a.getElementById(y.target); + D.same(F) ? D._private.edges.push(m) : (D._private.edges.push(m), F._private.edges.push(m)), m._private.source = D, m._private.target = F; + } + c.map = new ur(), c.map.set(p, { + ele: d, + index: 0 + }), c.removed = !1, e && a.addToPool(d); + } + for (var G = 0; G < i.length; G++) { + var N = i[G], X = N._private.data; + R(X.parent) && (X.parent = "" + X.parent); + var B = X.parent, re = B != null; + if (re || N._private.parent) { + var K = N._private.parent ? a.collection().merge(N._private.parent) : a.getElementById(B); + if (K.empty()) + X.parent = void 0; + else if (K[0].removed()) + vt("Node added with missing parent, reference to parent removed"), X.parent = void 0, N._private.parent = null; + else { + for (var W = !1, ae = K; !ae.empty(); ) { + if (N.same(ae)) { + W = !0, X.parent = void 0; + break; + } + ae = ae.parent(); + } + W || (K[0]._private.children.push(N), N._private.parent = K[0], n.hasCompoundNodes = !0); + } + } + } + if (o.length > 0) { + for (var ue = o.length === r.length ? r : new Nt(a, o), me = 0; me < ue.length; me++) { + var ie = ue[me]; + ie.isNode() || (ie.parallelEdges().clearTraversalCache(), ie.source().clearTraversalCache(), ie.target().clearTraversalCache()); + } + var ge; + n.hasCompoundNodes ? ge = a.collection().merge(ue).merge(ue.connectedNodes()).merge(ue.parent()) : ge = ue, ge.dirtyCompoundBoundsCache().dirtyBoundingBoxCache().updateStyle(t), t ? ue.emitAndNotify("add") : e && ue.emit("add"); + } + return r; + }, mt.removed = function() { + var t = this[0]; + return t && t._private.removed; + }, mt.inside = function() { + var t = this[0]; + return t && !t._private.removed; + }, mt.remove = function() { + var t = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : !0, e = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : !0, r = this, a = [], n = {}, i = r._private.cy; + function s(B) { + for (var re = B._private.edges, K = 0; K < re.length; K++) + u(re[K]); + } + function o(B) { + for (var re = B._private.children, K = 0; K < re.length; K++) + u(re[K]); + } + function u(B) { + var re = n[B.id()]; + e && B.removed() || re || (n[B.id()] = !0, B.isNode() ? (a.push(B), s(B), o(B)) : a.unshift(B)); + } + for (var l = 0, f = r.length; l < f; l++) { + var h = r[l]; + u(h); + } + function v(B, re) { + var K = B._private.edges; + xr(K, re), B.clearTraversalCache(); + } + function d(B) { + B.clearTraversalCache(); + } + var c = []; + c.ids = {}; + function y(B, re) { + re = re[0], B = B[0]; + var K = B._private.children, W = B.id(); + xr(K, re), re._private.parent = null, c.ids[W] || (c.ids[W] = !0, c.push(B)); + } + r.dirtyCompoundBoundsCache(), e && i.removeFromPool(a); + for (var p = 0; p < a.length; p++) { + var g = a[p]; + if (g.isEdge()) { + var m = g.source()[0], b = g.target()[0]; + v(m, g), v(b, g); + for (var E = g.parallelEdges(), M = 0; M < E.length; M++) { + var L = E[M]; + d(L), L.isBundledBezier() && L.dirtyBoundingBoxCache(); + } + } else { + var w = g.parent(); + w.length !== 0 && y(w, g); + } + e && (g._private.removed = !0); + } + var k = i._private.elements; + i._private.hasCompoundNodes = !1; + for (var D = 0; D < k.length; D++) { + var F = k[D]; + if (F.isParent()) { + i._private.hasCompoundNodes = !0; + break; + } + } + var G = new Nt(this.cy(), a); + G.size() > 0 && (t ? G.emitAndNotify("remove") : e && G.emit("remove")); + for (var N = 0; N < c.length; N++) { + var X = c[N]; + (!e || !X.removed()) && X.updateStyle(); + } + return G; + }, mt.move = function(t) { + var e = this._private.cy, r = this, a = !1, n = !1, i = function(c) { + return c == null ? c : "" + c; + }; + if (t.source !== void 0 || t.target !== void 0) { + var s = i(t.source), o = i(t.target), u = s != null && e.hasElementWithId(s), l = o != null && e.hasElementWithId(o); + (u || l) && (e.batch(function() { + r.remove(a, n), r.emitAndNotify("moveout"); + for (var d = 0; d < r.length; d++) { + var c = r[d], y = c._private.data; + c.isEdge() && (u && (y.source = s), l && (y.target = o)); + } + r.restore(a, n); + }), r.emitAndNotify("move")); + } else if (t.parent !== void 0) { + var f = i(t.parent), h = f === null || e.hasElementWithId(f); + if (h) { + var v = f === null ? void 0 : f; + e.batch(function() { + var d = r.remove(a, n); + d.emitAndNotify("moveout"); + for (var c = 0; c < r.length; c++) { + var y = r[c], p = y._private.data; + y.isNode() && (p.parent = v); + } + d.restore(a, n); + }), r.emitAndNotify("move"); + } + } + return this; + }, [_s, Gc, Ln, Ar, fa, ed, An, pd, No, Io, wd, Rn, kn, Ot, Ir, Bt].forEach(function(t) { + He(mt, t); + }); + var Ad = { + add: function(e) { + var r, a = this; + if (pe(e)) { + var n = e; + if (n._private.cy === a) + r = n.restore(); + else { + for (var i = [], s = 0; s < n.length; s++) { + var o = n[s]; + i.push(o.json()); + } + r = new Nt(a, i); + } + } else if (te(e)) { + var u = e; + r = new Nt(a, u); + } else if (S(e) && (te(e.nodes) || te(e.edges))) { + for (var l = e, f = [], h = ["nodes", "edges"], v = 0, d = h.length; v < d; v++) { + var c = h[v], y = l[c]; + if (te(y)) + for (var p = 0, g = y.length; p < g; p++) { + var m = He({ + group: c + }, y[p]); + f.push(m); + } + } + r = new Nt(a, f); + } else { + var b = e; + r = new hn(a, b).collection(); + } + return r; + }, + remove: function(e) { + if (!pe(e)) { + if (ee(e)) { + var r = e; + e = this.$(r); + } + } + return e.remove(); + } + }; + /*! Bezier curve function generator. Copyright Gaetan Renaudeau. MIT License: http://en.wikipedia.org/wiki/MIT_License */ + function Od(t, e, r, a) { + var n = 4, i = 1e-3, s = 1e-7, o = 10, u = 11, l = 1 / (u - 1), f = typeof Float32Array < "u"; + if (arguments.length !== 4) + return !1; + for (var h = 0; h < 4; ++h) + if (typeof arguments[h] != "number" || isNaN(arguments[h]) || !isFinite(arguments[h])) + return !1; + t = Math.min(t, 1), r = Math.min(r, 1), t = Math.max(t, 0), r = Math.max(r, 0); + var v = f ? new Float32Array(u) : new Array(u); + function d(F, G) { + return 1 - 3 * G + 3 * F; + } + function c(F, G) { + return 3 * G - 6 * F; + } + function y(F) { + return 3 * F; + } + function p(F, G, N) { + return ((d(G, N) * F + c(G, N)) * F + y(G)) * F; + } + function g(F, G, N) { + return 3 * d(G, N) * F * F + 2 * c(G, N) * F + y(G); + } + function m(F, G) { + for (var N = 0; N < n; ++N) { + var X = g(G, t, r); + if (X === 0) + return G; + var B = p(G, t, r) - F; + G -= B / X; + } + return G; + } + function b() { + for (var F = 0; F < u; ++F) + v[F] = p(F * l, t, r); + } + function E(F, G, N) { + var X, B, re = 0; + do + B = G + (N - G) / 2, X = p(B, t, r) - F, X > 0 ? N = B : G = B; + while (Math.abs(X) > s && ++re < o); + return B; + } + function M(F) { + for (var G = 0, N = 1, X = u - 1; N !== X && v[N] <= F; ++N) + G += l; + --N; + var B = (F - v[N]) / (v[N + 1] - v[N]), re = G + B * l, K = g(re, t, r); + return K >= i ? m(F, re) : K === 0 ? re : E(F, G, G + l); + } + var L = !1; + function w() { + L = !0, (t !== e || r !== a) && b(); + } + var k = function(G) { + return L || w(), t === e && r === a ? G : G === 0 ? 0 : G === 1 ? 1 : p(M(G), e, a); + }; + k.getControlPoints = function() { + return [{ + x: t, + y: e + }, { + x: r, + y: a + }]; + }; + var D = "generateBezier(" + [t, e, r, a] + ")"; + return k.toString = function() { + return D; + }, k; + } + /*! Runge-Kutta spring physics function generator. Adapted from Framer.js, copyright Koen Bok. MIT License: http://en.wikipedia.org/wiki/MIT_License */ + var Nd = function() { + function t(a) { + return -a.tension * a.x - a.friction * a.v; + } + function e(a, n, i) { + var s = { + x: a.x + i.dx * n, + v: a.v + i.dv * n, + tension: a.tension, + friction: a.friction + }; + return { + dx: s.v, + dv: t(s) + }; + } + function r(a, n) { + var i = { + dx: a.v, + dv: t(a) + }, s = e(a, n * 0.5, i), o = e(a, n * 0.5, s), u = e(a, n, o), l = 1 / 6 * (i.dx + 2 * (s.dx + o.dx) + u.dx), f = 1 / 6 * (i.dv + 2 * (s.dv + o.dv) + u.dv); + return a.x = a.x + l * n, a.v = a.v + f * n, a; + } + return function a(n, i, s) { + var o = { + x: -1, + v: 0, + tension: null, + friction: null + }, u = [0], l = 0, f = 1 / 1e4, h = 16 / 1e3, v, d, c; + for (n = parseFloat(n) || 500, i = parseFloat(i) || 20, s = s || null, o.tension = n, o.friction = i, v = s !== null, v ? (l = a(n, i), d = l / s * h) : d = h; c = r(c || o, d), u.push(1 + c.x), l += 16, Math.abs(c.x) > f && Math.abs(c.v) > f; ) + ; + return v ? function(y) { + return u[y * (u.length - 1) | 0]; + } : l; + }; + }(), bt = function(e, r, a, n) { + var i = Od(e, r, a, n); + return function(s, o, u) { + return s + (o - s) * i(u); + }; + }, Fn = { + linear: function(e, r, a) { + return e + (r - e) * a; + }, + // default easings + ease: bt(0.25, 0.1, 0.25, 1), + "ease-in": bt(0.42, 0, 1, 1), + "ease-out": bt(0, 0, 0.58, 1), + "ease-in-out": bt(0.42, 0, 0.58, 1), + // sine + "ease-in-sine": bt(0.47, 0, 0.745, 0.715), + "ease-out-sine": bt(0.39, 0.575, 0.565, 1), + "ease-in-out-sine": bt(0.445, 0.05, 0.55, 0.95), + // quad + "ease-in-quad": bt(0.55, 0.085, 0.68, 0.53), + "ease-out-quad": bt(0.25, 0.46, 0.45, 0.94), + "ease-in-out-quad": bt(0.455, 0.03, 0.515, 0.955), + // cubic + "ease-in-cubic": bt(0.55, 0.055, 0.675, 0.19), + "ease-out-cubic": bt(0.215, 0.61, 0.355, 1), + "ease-in-out-cubic": bt(0.645, 0.045, 0.355, 1), + // quart + "ease-in-quart": bt(0.895, 0.03, 0.685, 0.22), + "ease-out-quart": bt(0.165, 0.84, 0.44, 1), + "ease-in-out-quart": bt(0.77, 0, 0.175, 1), + // quint + "ease-in-quint": bt(0.755, 0.05, 0.855, 0.06), + "ease-out-quint": bt(0.23, 1, 0.32, 1), + "ease-in-out-quint": bt(0.86, 0, 0.07, 1), + // expo + "ease-in-expo": bt(0.95, 0.05, 0.795, 0.035), + "ease-out-expo": bt(0.19, 1, 0.22, 1), + "ease-in-out-expo": bt(1, 0, 0, 1), + // circ + "ease-in-circ": bt(0.6, 0.04, 0.98, 0.335), + "ease-out-circ": bt(0.075, 0.82, 0.165, 1), + "ease-in-out-circ": bt(0.785, 0.135, 0.15, 0.86), + // user param easings... + spring: function(e, r, a) { + if (a === 0) + return Fn.linear; + var n = Nd(e, r, a); + return function(i, s, o) { + return i + (s - i) * n(o); + }; + }, + "cubic-bezier": bt + }; + function Uo(t, e, r, a, n) { + if (a === 1 || e === r) + return r; + var i = n(e, r, a); + return t == null || ((t.roundValue || t.color) && (i = Math.round(i)), t.min !== void 0 && (i = Math.max(i, t.min)), t.max !== void 0 && (i = Math.min(i, t.max))), i; + } + function $o(t, e) { + return t.pfValue != null || t.value != null ? t.pfValue != null && (e == null || e.type.units !== "%") ? t.pfValue : t.value : t; + } + function ga(t, e, r, a, n) { + var i = n != null ? n.type : null; + r < 0 ? r = 0 : r > 1 && (r = 1); + var s = $o(t, n), o = $o(e, n); + if (R(s) && R(o)) + return Uo(i, s, o, r, a); + if (te(s) && te(o)) { + for (var u = [], l = 0; l < o.length; l++) { + var f = s[l], h = o[l]; + if (f != null && h != null) { + var v = Uo(i, f, h, r, a); + u.push(v); + } else + u.push(h); + } + return u; + } + } + function Id(t, e, r, a) { + var n = !a, i = t._private, s = e._private, o = s.easing, u = s.startTime, l = a ? t : t.cy(), f = l.style(); + if (!s.easingImpl) + if (o == null) + s.easingImpl = Fn.linear; + else { + var h; + if (ee(o)) { + var v = f.parse("transition-timing-function", o); + h = v.value; + } else + h = o; + var d, c; + ee(h) ? (d = h, c = []) : (d = h[1], c = h.slice(2).map(function(ue) { + return +ue; + })), c.length > 0 ? (d === "spring" && c.push(s.duration), s.easingImpl = Fn[d].apply(null, c)) : s.easingImpl = Fn[d]; + } + var y = s.easingImpl, p; + if (s.duration === 0 ? p = 1 : p = (r - u) / s.duration, s.applying && (p = s.progress), p < 0 ? p = 0 : p > 1 && (p = 1), s.delay == null) { + var g = s.startPosition, m = s.position; + if (m && n && !t.locked()) { + var b = {}; + Xa(g.x, m.x) && (b.x = ga(g.x, m.x, p, y)), Xa(g.y, m.y) && (b.y = ga(g.y, m.y, p, y)), t.position(b); + } + var E = s.startPan, M = s.pan, L = i.pan, w = M != null && a; + w && (Xa(E.x, M.x) && (L.x = ga(E.x, M.x, p, y)), Xa(E.y, M.y) && (L.y = ga(E.y, M.y, p, y)), t.emit("pan")); + var k = s.startZoom, D = s.zoom, F = D != null && a; + F && (Xa(k, D) && (i.zoom = ka(i.minZoom, ga(k, D, p, y), i.maxZoom)), t.emit("zoom")), (w || F) && t.emit("viewport"); + var G = s.style; + if (G && G.length > 0 && n) { + for (var N = 0; N < G.length; N++) { + var X = G[N], B = X.name, re = X, K = s.startStyle[B], W = f.properties[K.name], ae = ga(K, re, p, y, W); + f.overrideBypass(t, B, ae); + } + t.emit("style"); + } + } + return s.progress = p, p; + } + function Xa(t, e) { + return t == null || e == null ? !1 : R(t) && R(e) ? !0 : !!(t && e); + } + function Md(t, e, r, a) { + var n = e._private; + n.started = !0, n.startTime = r - n.progress * n.duration; + } + function _o(t, e) { + var r = e._private.aniEles, a = []; + function n(f, h) { + var v = f._private, d = v.animation.current, c = v.animation.queue, y = !1; + if (d.length === 0) { + var p = c.shift(); + p && d.push(p); + } + for (var g = function(L) { + for (var w = L.length - 1; w >= 0; w--) { + var k = L[w]; + k(); + } + L.splice(0, L.length); + }, m = d.length - 1; m >= 0; m--) { + var b = d[m], E = b._private; + if (E.stopped) { + d.splice(m, 1), E.hooked = !1, E.playing = !1, E.started = !1, g(E.frames); + continue; + } + !E.playing && !E.applying || (E.playing && E.applying && (E.applying = !1), E.started || Md(f, b, t), Id(f, b, t, h), E.applying && (E.applying = !1), g(E.frames), E.step != null && E.step(t), b.completed() && (d.splice(m, 1), E.hooked = !1, E.playing = !1, E.started = !1, g(E.completes)), y = !0); + } + return !h && d.length === 0 && c.length === 0 && a.push(f), y; + } + for (var i = !1, s = 0; s < r.length; s++) { + var o = r[s], u = n(o); + i = i || u; + } + var l = n(e, !0); + (i || l) && (r.length > 0 ? e.notify("draw", r) : e.notify("draw")), r.unmerge(a), e.emit("step"); + } + var Rd = { + // pull in animation functions + animate: ct.animate(), + animation: ct.animation(), + animated: ct.animated(), + clearQueue: ct.clearQueue(), + delay: ct.delay(), + delayAnimation: ct.delayAnimation(), + stop: ct.stop(), + addToAnimationPool: function(e) { + var r = this; + r.styleEnabled() && r._private.aniEles.merge(e); + }, + stopAnimationLoop: function() { + this._private.animationsRunning = !1; + }, + startAnimationLoop: function() { + var e = this; + if (e._private.animationsRunning = !0, !e.styleEnabled()) + return; + function r() { + e._private.animationsRunning && ln(function(i) { + _o(i, e), r(); + }); + } + var a = e.renderer(); + a && a.beforeRender ? a.beforeRender(function(i, s) { + _o(s, e); + }, a.beforeRenderPriorities.animations) : r(); + } + }, kd = { + qualifierCompare: function(e, r) { + return e == null || r == null ? e == null && r == null : e.sameText(r); + }, + eventMatches: function(e, r, a) { + var n = r.qualifier; + return n != null ? e !== a.target && Ae(a.target) && n.matches(a.target) : !0; + }, + addEventFields: function(e, r) { + r.cy = e, r.target = e; + }, + callbackContext: function(e, r, a) { + return r.qualifier != null ? a.target : e; + } + }, Gn = function(e) { + return ee(e) ? new Sr(e) : e; + }, Yo = { + createEmitter: function() { + var e = this._private; + return e.emitter || (e.emitter = new In(kd, this)), this; + }, + emitter: function() { + return this._private.emitter; + }, + on: function(e, r, a) { + return this.emitter().on(e, Gn(r), a), this; + }, + removeListener: function(e, r, a) { + return this.emitter().removeListener(e, Gn(r), a), this; + }, + removeAllListeners: function() { + return this.emitter().removeAllListeners(), this; + }, + one: function(e, r, a) { + return this.emitter().one(e, Gn(r), a), this; + }, + once: function(e, r, a) { + return this.emitter().one(e, Gn(r), a), this; + }, + emit: function(e, r) { + return this.emitter().emit(e, r), this; + }, + emitAndNotify: function(e, r) { + return this.emit(e), this.notify(e, r), this; + } + }; + ct.eventAliasesOn(Yo); + var Ii = { + png: function(e) { + var r = this._private.renderer; + return e = e || {}, r.png(e); + }, + jpg: function(e) { + var r = this._private.renderer; + return e = e || {}, e.bg = e.bg || "#fff", r.jpg(e); + } + }; + Ii.jpeg = Ii.jpg; + var zn = { + layout: function(e) { + var r = this; + if (e == null) { + xt("Layout options must be specified to make a layout"); + return; + } + if (e.name == null) { + xt("A `name` must be specified to make a layout"); + return; + } + var a = e.name, n = r.extension("layout", a); + if (n == null) { + xt("No such layout `" + a + "` found. Did you forget to import it and `cytoscape.use()` it?"); + return; + } + var i; + ee(e.eles) ? i = r.$(e.eles) : i = e.eles != null ? e.eles : r.$(); + var s = new n(He({}, e, { + cy: r, + eles: i + })); + return s; + } + }; + zn.createLayout = zn.makeLayout = zn.layout; + var Pd = { + notify: function(e, r) { + var a = this._private; + if (this.batching()) { + a.batchNotifications = a.batchNotifications || {}; + var n = a.batchNotifications[e] = a.batchNotifications[e] || this.collection(); + r != null && n.merge(r); + return; + } + if (a.notificationsEnabled) { + var i = this.renderer(); + this.destroyed() || !i || i.notify(e, r); + } + }, + notifications: function(e) { + var r = this._private; + return e === void 0 ? r.notificationsEnabled : (r.notificationsEnabled = !!e, this); + }, + noNotifications: function(e) { + this.notifications(!1), e(), this.notifications(!0); + }, + batching: function() { + return this._private.batchCount > 0; + }, + startBatch: function() { + var e = this._private; + return e.batchCount == null && (e.batchCount = 0), e.batchCount === 0 && (e.batchStyleEles = this.collection(), e.batchNotifications = {}), e.batchCount++, this; + }, + endBatch: function() { + var e = this._private; + if (e.batchCount === 0) + return this; + if (e.batchCount--, e.batchCount === 0) { + e.batchStyleEles.updateStyle(); + var r = this.renderer(); + Object.keys(e.batchNotifications).forEach(function(a) { + var n = e.batchNotifications[a]; + n.empty() ? r.notify(a) : r.notify(a, n); + }); + } + return this; + }, + batch: function(e) { + return this.startBatch(), e(), this.endBatch(), this; + }, + // for backwards compatibility + batchData: function(e) { + var r = this; + return this.batch(function() { + for (var a = Object.keys(e), n = 0; n < a.length; n++) { + var i = a[n], s = e[i], o = r.getElementById(i); + o.data(s); + } + }); + } + }, Bd = At({ + hideEdgesOnViewport: !1, + textureOnViewport: !1, + motionBlur: !1, + motionBlurOpacity: 0.05, + pixelRatio: void 0, + desktopTapThreshold: 4, + touchTapThreshold: 8, + wheelSensitivity: 1, + debug: !1, + showFps: !1 + }), Mi = { + renderTo: function(e, r, a, n) { + var i = this._private.renderer; + return i.renderTo(e, r, a, n), this; + }, + renderer: function() { + return this._private.renderer; + }, + forceRender: function() { + return this.notify("draw"), this; + }, + resize: function() { + return this.invalidateSize(), this.emitAndNotify("resize"), this; + }, + initRenderer: function(e) { + var r = this, a = r.extension("renderer", e.name); + if (a == null) { + xt("Can not initialise: No such renderer `".concat(e.name, "` found. Did you forget to import it and `cytoscape.use()` it?")); + return; + } + e.wheelSensitivity !== void 0 && vt("You have set a custom wheel sensitivity. This will make your app zoom unnaturally when using mainstream mice. You should change this value from the default only if you can guarantee that all your users will use the same hardware and OS configuration as your current machine."); + var n = Bd(e); + n.cy = r, r._private.renderer = new a(n), this.notify("init"); + }, + destroyRenderer: function() { + var e = this; + e.notify("destroy"); + var r = e.container(); + if (r) + for (r._cyreg = null; r.childNodes.length > 0; ) + r.removeChild(r.childNodes[0]); + e._private.renderer = null, e.mutableElements().forEach(function(a) { + var n = a._private; + n.rscratch = {}, n.rstyle = {}, n.animation.current = [], n.animation.queue = []; + }); + }, + onRender: function(e) { + return this.on("render", e); + }, + offRender: function(e) { + return this.off("render", e); + } + }; + Mi.invalidateDimensions = Mi.resize; + var Vn = { + // get a collection + // - empty collection on no args + // - collection of elements in the graph on selector arg + // - guarantee a returned collection when elements or collection specified + collection: function(e, r) { + return ee(e) ? this.$(e) : pe(e) ? e.collection() : te(e) ? (r || (r = {}), new Nt(this, e, r.unique, r.removed)) : new Nt(this); + }, + nodes: function(e) { + var r = this.$(function(a) { + return a.isNode(); + }); + return e ? r.filter(e) : r; + }, + edges: function(e) { + var r = this.$(function(a) { + return a.isEdge(); + }); + return e ? r.filter(e) : r; + }, + // search the graph like jQuery + $: function(e) { + var r = this._private.elements; + return e ? r.filter(e) : r.spawnSelf(); + }, + mutableElements: function() { + return this._private.elements; + } + }; + Vn.elements = Vn.filter = Vn.$; + var Ft = {}, Wa = "t", Fd = "f"; + Ft.apply = function(t) { + for (var e = this, r = e._private, a = r.cy, n = a.collection(), i = 0; i < t.length; i++) { + var s = t[i], o = e.getContextMeta(s); + if (!o.empty) { + var u = e.getContextStyle(o), l = e.applyContextStyle(o, u, s); + s._private.appliedInitStyle ? e.updateTransitions(s, l.diffProps) : s._private.appliedInitStyle = !0; + var f = e.updateStyleHints(s); + f && n.push(s); + } + } + return n; + }, Ft.getPropertiesDiff = function(t, e) { + var r = this, a = r._private.propDiffs = r._private.propDiffs || {}, n = t + "-" + e, i = a[n]; + if (i) + return i; + for (var s = [], o = {}, u = 0; u < r.length; u++) { + var l = r[u], f = t[u] === Wa, h = e[u] === Wa, v = f !== h, d = l.mappedProperties.length > 0; + if (v || h && d) { + var c = void 0; + v && d || v ? c = l.properties : d && (c = l.mappedProperties); + for (var y = 0; y < c.length; y++) { + for (var p = c[y], g = p.name, m = !1, b = u + 1; b < r.length; b++) { + var E = r[b], M = e[b] === Wa; + if (M && (m = E.properties[p.name] != null, m)) + break; + } + !o[g] && !m && (o[g] = !0, s.push(g)); + } + } + } + return a[n] = s, s; + }, Ft.getContextMeta = function(t) { + for (var e = this, r = "", a, n = t._private.styleCxtKey || "", i = 0; i < e.length; i++) { + var s = e[i], o = s.selector && s.selector.matches(t); + o ? r += Wa : r += Fd; + } + return a = e.getPropertiesDiff(n, r), t._private.styleCxtKey = r, { + key: r, + diffPropNames: a, + empty: a.length === 0 + }; + }, Ft.getContextStyle = function(t) { + var e = t.key, r = this, a = this._private.contextStyles = this._private.contextStyles || {}; + if (a[e]) + return a[e]; + for (var n = { + _private: { + key: e + } + }, i = 0; i < r.length; i++) { + var s = r[i], o = e[i] === Wa; + if (o) + for (var u = 0; u < s.properties.length; u++) { + var l = s.properties[u]; + n[l.name] = l; + } + } + return a[e] = n, n; + }, Ft.applyContextStyle = function(t, e, r) { + for (var a = this, n = t.diffPropNames, i = {}, s = a.types, o = 0; o < n.length; o++) { + var u = n[o], l = e[u], f = r.pstyle(u); + if (!l) + if (f) + f.bypass ? l = { + name: u, + deleteBypassed: !0 + } : l = { + name: u, + delete: !0 + }; + else + continue; + if (f !== l) { + if (l.mapped === s.fn && f != null && f.mapping != null && f.mapping.value === l.value) { + var h = f.mapping, v = h.fnValue = l.value(r); + if (v === h.prevFnValue) + continue; + } + var d = i[u] = { + prev: f + }; + a.applyParsedProperty(r, l), d.next = r.pstyle(u), d.next && d.next.bypass && (d.next = d.next.bypassed); + } + } + return { + diffProps: i + }; + }, Ft.updateStyleHints = function(t) { + var e = t._private, r = this, a = r.propertyGroupNames, n = r.propertyGroupKeys, i = function(Oe, Fe, Xe) { + return r.getPropertiesHash(Oe, Fe, Xe); + }, s = e.styleKey; + if (t.removed()) + return !1; + var o = e.group === "nodes", u = t._private.style; + a = Object.keys(u); + for (var l = 0; l < n.length; l++) { + var f = n[l]; + e.styleKeys[f] = [Qr, Oa]; + } + for (var h = function(Oe, Fe) { + return e.styleKeys[Fe][0] = Na(Oe, e.styleKeys[Fe][0]); + }, v = function(Oe, Fe) { + return e.styleKeys[Fe][1] = Ia(Oe, e.styleKeys[Fe][1]); + }, d = function(Oe, Fe) { + h(Oe, Fe), v(Oe, Fe); + }, c = function(Oe, Fe) { + for (var Xe = 0; Xe < Oe.length; Xe++) { + var Ie = Oe.charCodeAt(Xe); + h(Ie, Fe), v(Ie, Fe); + } + }, y = 2e9, p = function(Oe) { + return -128 < Oe && Oe < 128 && Math.floor(Oe) !== Oe ? y - (Oe * 1024 | 0) : Oe; + }, g = 0; g < a.length; g++) { + var m = a[g], b = u[m]; + if (b != null) { + var E = this.properties[m], M = E.type, L = E.groupKey, w = void 0; + E.hashOverride != null ? w = E.hashOverride(t, b) : b.pfValue != null && (w = b.pfValue); + var k = E.enums == null ? b.value : null, D = w != null, F = k != null, G = D || F, N = b.units; + if (M.number && G && !M.multiple) { + var X = D ? w : k; + d(p(X), L), !D && N != null && c(N, L); + } else + c(b.strValue, L); + } + } + for (var B = [Qr, Oa], re = 0; re < n.length; re++) { + var K = n[re], W = e.styleKeys[K]; + B[0] = Na(W[0], B[0]), B[1] = Ia(W[1], B[1]); + } + e.styleKey = Uu(B[0], B[1]); + var ae = e.styleKeys; + e.labelDimsKey = wr(ae.labelDimensions); + var ue = i(t, ["label"], ae.labelDimensions); + if (e.labelKey = wr(ue), e.labelStyleKey = wr(un(ae.commonLabel, ue)), !o) { + var me = i(t, ["source-label"], ae.labelDimensions); + e.sourceLabelKey = wr(me), e.sourceLabelStyleKey = wr(un(ae.commonLabel, me)); + var ie = i(t, ["target-label"], ae.labelDimensions); + e.targetLabelKey = wr(ie), e.targetLabelStyleKey = wr(un(ae.commonLabel, ie)); + } + if (o) { + var ge = e.styleKeys, Ee = ge.nodeBody, Ce = ge.nodeBorder, we = ge.nodeOutline, De = ge.backgroundImage, se = ge.compound, xe = ge.pie, Le = [Ee, Ce, we, De, se, xe].filter(function(Se) { + return Se != null; + }).reduce(un, [Qr, Oa]); + e.nodeKey = wr(Le), e.hasPie = xe != null && xe[0] !== Qr && xe[1] !== Oa; + } + return s !== e.styleKey; + }, Ft.clearStyleHints = function(t) { + var e = t._private; + e.styleCxtKey = "", e.styleKeys = {}, e.styleKey = null, e.labelKey = null, e.labelStyleKey = null, e.sourceLabelKey = null, e.sourceLabelStyleKey = null, e.targetLabelKey = null, e.targetLabelStyleKey = null, e.nodeKey = null, e.hasPie = null; + }, Ft.applyParsedProperty = function(t, e) { + var r = this, a = e, n = t._private.style, i, s = r.types, o = r.properties[a.name].type, u = a.bypass, l = n[a.name], f = l && l.bypass, h = t._private, v = "mapping", d = function(Ee) { + return Ee == null ? null : Ee.pfValue != null ? Ee.pfValue : Ee.value; + }, c = function() { + var Ee = d(l), Ce = d(a); + r.checkTriggers(t, a.name, Ee, Ce); + }; + if (e.name === "curve-style" && t.isEdge() && // loops must be bundled beziers + (e.value !== "bezier" && t.isLoop() || // edges connected to compound nodes can not be haystacks + e.value === "haystack" && (t.source().isParent() || t.target().isParent())) && (a = e = this.parse(e.name, "bezier", u)), a.delete) + return n[a.name] = void 0, c(), !0; + if (a.deleteBypassed) + return l ? l.bypass ? (l.bypassed = void 0, c(), !0) : !1 : (c(), !0); + if (a.deleteBypass) + return l ? l.bypass ? (n[a.name] = l.bypassed, c(), !0) : !1 : (c(), !0); + var y = function() { + vt("Do not assign mappings to elements without corresponding data (i.e. ele `" + t.id() + "` has no mapping for property `" + a.name + "` with data field `" + a.field + "`); try a `[" + a.field + "]` selector to limit scope to elements with `" + a.field + "` defined"); + }; + switch (a.mapped) { + case s.mapData: { + for (var p = a.field.split("."), g = h.data, m = 0; m < p.length && g; m++) { + var b = p[m]; + g = g[b]; + } + if (g == null) + return y(), !1; + var E; + if (R(g)) { + var M = a.fieldMax - a.fieldMin; + M === 0 ? E = 0 : E = (g - a.fieldMin) / M; + } else + return vt("Do not use continuous mappers without specifying numeric data (i.e. `" + a.field + ": " + g + "` for `" + t.id() + "` is non-numeric)"), !1; + if (E < 0 ? E = 0 : E > 1 && (E = 1), o.color) { + var L = a.valueMin[0], w = a.valueMax[0], k = a.valueMin[1], D = a.valueMax[1], F = a.valueMin[2], G = a.valueMax[2], N = a.valueMin[3] == null ? 1 : a.valueMin[3], X = a.valueMax[3] == null ? 1 : a.valueMax[3], B = [Math.round(L + (w - L) * E), Math.round(k + (D - k) * E), Math.round(F + (G - F) * E), Math.round(N + (X - N) * E)]; + i = { + // colours are simple, so just create the flat property instead of expensive string parsing + bypass: a.bypass, + // we're a bypass if the mapping property is a bypass + name: a.name, + value: B, + strValue: "rgb(" + B[0] + ", " + B[1] + ", " + B[2] + ")" + }; + } else if (o.number) { + var re = a.valueMin + (a.valueMax - a.valueMin) * E; + i = this.parse(a.name, re, a.bypass, v); + } else + return !1; + if (!i) + return y(), !1; + i.mapping = a, a = i; + break; + } + case s.data: { + for (var K = a.field.split("."), W = h.data, ae = 0; ae < K.length && W; ae++) { + var ue = K[ae]; + W = W[ue]; + } + if (W != null && (i = this.parse(a.name, W, a.bypass, v)), !i) + return y(), !1; + i.mapping = a, a = i; + break; + } + case s.fn: { + var me = a.value, ie = a.fnValue != null ? a.fnValue : me(t); + if (a.prevFnValue = ie, ie == null) + return vt("Custom function mappers may not return null (i.e. `" + a.name + "` for ele `" + t.id() + "` is null)"), !1; + if (i = this.parse(a.name, ie, a.bypass, v), !i) + return vt("Custom function mappers may not return invalid values for the property type (i.e. `" + a.name + "` for ele `" + t.id() + "` is invalid)"), !1; + i.mapping = lr(a), a = i; + break; + } + case void 0: + break; + default: + return !1; + } + return u ? (f ? a.bypassed = l.bypassed : a.bypassed = l, n[a.name] = a) : f ? l.bypassed = a : n[a.name] = a, c(), !0; + }, Ft.cleanElements = function(t, e) { + for (var r = 0; r < t.length; r++) { + var a = t[r]; + if (this.clearStyleHints(a), a.dirtyCompoundBoundsCache(), a.dirtyBoundingBoxCache(), !e) + a._private.style = {}; + else + for (var n = a._private.style, i = Object.keys(n), s = 0; s < i.length; s++) { + var o = i[s], u = n[o]; + u != null && (u.bypass ? u.bypassed = null : n[o] = null); + } + } + }, Ft.update = function() { + var t = this._private.cy, e = t.mutableElements(); + e.updateStyle(); + }, Ft.updateTransitions = function(t, e) { + var r = this, a = t._private, n = t.pstyle("transition-property").value, i = t.pstyle("transition-duration").pfValue, s = t.pstyle("transition-delay").pfValue; + if (n.length > 0 && i > 0) { + for (var o = {}, u = !1, l = 0; l < n.length; l++) { + var f = n[l], h = t.pstyle(f), v = e[f]; + if (v) { + var d = v.prev, c = d, y = v.next != null ? v.next : h, p = !1, g = void 0, m = 1e-6; + c && (R(c.pfValue) && R(y.pfValue) ? (p = y.pfValue - c.pfValue, g = c.pfValue + m * p) : R(c.value) && R(y.value) ? (p = y.value - c.value, g = c.value + m * p) : te(c.value) && te(y.value) && (p = c.value[0] !== y.value[0] || c.value[1] !== y.value[1] || c.value[2] !== y.value[2], g = c.strValue), p && (o[f] = y.strValue, this.applyBypass(t, f, g), u = !0)); + } + } + if (!u) + return; + a.transitioning = !0, new ia(function(b) { + s > 0 ? t.delayAnimation(s).play().promise().then(b) : b(); + }).then(function() { + return t.animation({ + style: o, + duration: i, + easing: t.pstyle("transition-timing-function").value, + queue: !1 + }).play().promise(); + }).then(function() { + r.removeBypasses(t, n), t.emitAndNotify("style"), a.transitioning = !1; + }); + } else + a.transitioning && (this.removeBypasses(t, n), t.emitAndNotify("style"), a.transitioning = !1); + }, Ft.checkTrigger = function(t, e, r, a, n, i) { + var s = this.properties[e], o = n(s); + o != null && o(r, a) && i(s); + }, Ft.checkZOrderTrigger = function(t, e, r, a) { + var n = this; + this.checkTrigger(t, e, r, a, function(i) { + return i.triggersZOrder; + }, function() { + n._private.cy.notify("zorder", t); + }); + }, Ft.checkBoundsTrigger = function(t, e, r, a) { + this.checkTrigger(t, e, r, a, function(n) { + return n.triggersBounds; + }, function(n) { + t.dirtyCompoundBoundsCache(), t.dirtyBoundingBoxCache(), // only for beziers -- so performance of other edges isn't affected + n.triggersBoundsOfParallelBeziers && e === "curve-style" && (r === "bezier" || a === "bezier") && t.parallelEdges().forEach(function(i) { + i.isBundledBezier() && i.dirtyBoundingBoxCache(); + }), n.triggersBoundsOfConnectedEdges && e === "display" && (r === "none" || a === "none") && t.connectedEdges().forEach(function(i) { + i.dirtyBoundingBoxCache(); + }); + }); + }, Ft.checkTriggers = function(t, e, r, a) { + t.dirtyStyleCache(), this.checkZOrderTrigger(t, e, r, a), this.checkBoundsTrigger(t, e, r, a); + }; + var qa = {}; + qa.applyBypass = function(t, e, r, a) { + var n = this, i = [], s = !0; + if (e === "*" || e === "**") { + if (r !== void 0) + for (var o = 0; o < n.properties.length; o++) { + var u = n.properties[o], l = u.name, f = this.parse(l, r, !0); + f && i.push(f); + } + } else if (ee(e)) { + var h = this.parse(e, r, !0); + h && i.push(h); + } else if (S(e)) { + var v = e; + a = r; + for (var d = Object.keys(v), c = 0; c < d.length; c++) { + var y = d[c], p = v[y]; + if (p === void 0 && (p = v[yt(y)]), p !== void 0) { + var g = this.parse(y, p, !0); + g && i.push(g); + } + } + } else + return !1; + if (i.length === 0) + return !1; + for (var m = !1, b = 0; b < t.length; b++) { + for (var E = t[b], M = {}, L = void 0, w = 0; w < i.length; w++) { + var k = i[w]; + if (a) { + var D = E.pstyle(k.name); + L = M[k.name] = { + prev: D + }; + } + m = this.applyParsedProperty(E, lr(k)) || m, a && (L.next = E.pstyle(k.name)); + } + m && this.updateStyleHints(E), a && this.updateTransitions(E, M, s); + } + return m; + }, qa.overrideBypass = function(t, e, r) { + e = tt(e); + for (var a = 0; a < t.length; a++) { + var n = t[a], i = n._private.style[e], s = this.properties[e].type, o = s.color, u = s.mutiple, l = i ? i.pfValue != null ? i.pfValue : i.value : null; + !i || !i.bypass ? this.applyBypass(n, e, r) : (i.value = r, i.pfValue != null && (i.pfValue = r), o ? i.strValue = "rgb(" + r.join(",") + ")" : u ? i.strValue = r.join(" ") : i.strValue = "" + r, this.updateStyleHints(n)), this.checkTriggers(n, e, l, r); + } + }, qa.removeAllBypasses = function(t, e) { + return this.removeBypasses(t, this.propertyNames, e); + }, qa.removeBypasses = function(t, e, r) { + for (var a = !0, n = 0; n < t.length; n++) { + for (var i = t[n], s = {}, o = 0; o < e.length; o++) { + var u = e[o], l = this.properties[u], f = i.pstyle(l.name); + if (!(!f || !f.bypass)) { + var h = "", v = this.parse(u, h, !0), d = s[l.name] = { + prev: f + }; + this.applyParsedProperty(i, v), d.next = i.pstyle(l.name); + } + } + this.updateStyleHints(i), r && this.updateTransitions(i, s, a); + } + }; + var Ri = {}; + Ri.getEmSizeInPixels = function() { + var t = this.containerCss("font-size"); + return t != null ? parseFloat(t) : 1; + }, Ri.containerCss = function(t) { + var e = this._private.cy, r = e.container(), a = e.window(); + if (a && r && a.getComputedStyle) + return a.getComputedStyle(r).getPropertyValue(t); + }; + var fr = {}; + fr.getRenderedStyle = function(t, e) { + return e ? this.getStylePropertyValue(t, e, !0) : this.getRawStyle(t, !0); + }, fr.getRawStyle = function(t, e) { + var r = this; + if (t = t[0], t) { + for (var a = {}, n = 0; n < r.properties.length; n++) { + var i = r.properties[n], s = r.getStylePropertyValue(t, i.name, e); + s != null && (a[i.name] = s, a[yt(i.name)] = s); + } + return a; + } + }, fr.getIndexedStyle = function(t, e, r, a) { + var n = t.pstyle(e)[r][a]; + return n ?? t.cy().style().getDefaultProperty(e)[r][0]; + }, fr.getStylePropertyValue = function(t, e, r) { + var a = this; + if (t = t[0], t) { + var n = a.properties[e]; + n.alias && (n = n.pointsTo); + var i = n.type, s = t.pstyle(n.name); + if (s) { + var o = s.value, u = s.units, l = s.strValue; + if (r && i.number && o != null && R(o)) { + var f = t.cy().zoom(), h = function(p) { + return p * f; + }, v = function(p, g) { + return h(p) + g; + }, d = te(o), c = d ? u.every(function(y) { + return y != null; + }) : u != null; + return c ? d ? o.map(function(y, p) { + return v(y, u[p]); + }).join(" ") : v(o, u) : d ? o.map(function(y) { + return ee(y) ? y : "" + h(y); + }).join(" ") : "" + h(o); + } else if (l != null) + return l; + } + return null; + } + }, fr.getAnimationStartStyle = function(t, e) { + for (var r = {}, a = 0; a < e.length; a++) { + var n = e[a], i = n.name, s = t.pstyle(i); + s !== void 0 && (S(s) ? s = this.parse(i, s.strValue) : s = this.parse(i, s)), s && (r[i] = s); + } + return r; + }, fr.getPropsList = function(t) { + var e = this, r = [], a = t, n = e.properties; + if (a) + for (var i = Object.keys(a), s = 0; s < i.length; s++) { + var o = i[s], u = a[o], l = n[o] || n[tt(o)], f = this.parse(l.name, u); + f && r.push(f); + } + return r; + }, fr.getNonDefaultPropertiesHash = function(t, e, r) { + var a = r.slice(), n, i, s, o, u, l; + for (u = 0; u < e.length; u++) + if (n = e[u], i = t.pstyle(n, !1), i != null) + if (i.pfValue != null) + a[0] = Na(o, a[0]), a[1] = Ia(o, a[1]); + else + for (s = i.strValue, l = 0; l < s.length; l++) + o = s.charCodeAt(l), a[0] = Na(o, a[0]), a[1] = Ia(o, a[1]); + return a; + }, fr.getPropertiesHash = fr.getNonDefaultPropertiesHash; + var Un = {}; + Un.appendFromJson = function(t) { + for (var e = this, r = 0; r < t.length; r++) { + var a = t[r], n = a.selector, i = a.style || a.css, s = Object.keys(i); + e.selector(n); + for (var o = 0; o < s.length; o++) { + var u = s[o], l = i[u]; + e.css(u, l); + } + } + return e; + }, Un.fromJson = function(t) { + var e = this; + return e.resetToDefault(), e.appendFromJson(t), e; + }, Un.json = function() { + for (var t = [], e = this.defaultLength; e < this.length; e++) { + for (var r = this[e], a = r.selector, n = r.properties, i = {}, s = 0; s < n.length; s++) { + var o = n[s]; + i[o.name] = o.strValue; + } + t.push({ + selector: a ? a.toString() : "core", + style: i + }); + } + return t; + }; + var ki = {}; + ki.appendFromString = function(t) { + var e = this, r = this, a = "" + t, n, i, s; + a = a.replace(/[/][*](\s|.)+?[*][/]/g, ""); + function o() { + a.length > n.length ? a = a.substr(n.length) : a = ""; + } + function u() { + i.length > s.length ? i = i.substr(s.length) : i = ""; + } + for (; ; ) { + var l = a.match(/^\s*$/); + if (l) + break; + var f = a.match(/^\s*((?:.|\s)+?)\s*\{((?:.|\s)+?)\}/); + if (!f) { + vt("Halting stylesheet parsing: String stylesheet contains more to parse but no selector and block found in: " + a); + break; + } + n = f[0]; + var h = f[1]; + if (h !== "core") { + var v = new Sr(h); + if (v.invalid) { + vt("Skipping parsing of block: Invalid selector found in string stylesheet: " + h), o(); + continue; + } + } + var d = f[2], c = !1; + i = d; + for (var y = []; ; ) { + var p = i.match(/^\s*$/); + if (p) + break; + var g = i.match(/^\s*(.+?)\s*:\s*(.+?)(?:\s*;|\s*$)/); + if (!g) { + vt("Skipping parsing of block: Invalid formatting of style property and value definitions found in:" + d), c = !0; + break; + } + s = g[0]; + var m = g[1], b = g[2], E = e.properties[m]; + if (!E) { + vt("Skipping property: Invalid property name in: " + s), u(); + continue; + } + var M = r.parse(m, b); + if (!M) { + vt("Skipping property: Invalid property definition in: " + s), u(); + continue; + } + y.push({ + name: m, + val: b + }), u(); + } + if (c) { + o(); + break; + } + r.selector(h); + for (var L = 0; L < y.length; L++) { + var w = y[L]; + r.css(w.name, w.val); + } + o(); + } + return r; + }, ki.fromString = function(t) { + var e = this; + return e.resetToDefault(), e.appendFromString(t), e; + }; + var It = {}; + (function() { + var t = gt, e = qt, r = Kr, a = Da, n = jt, i = function(Le) { + return "^" + Le + "\\s*\\(\\s*([\\w\\.]+)\\s*\\)$"; + }, s = function(Le) { + var Se = t + "|\\w+|" + e + "|" + r + "|" + a + "|" + n; + return "^" + Le + "\\s*\\(([\\w\\.]+)\\s*\\,\\s*(" + t + ")\\s*\\,\\s*(" + t + ")\\s*,\\s*(" + Se + ")\\s*\\,\\s*(" + Se + ")\\)$"; + }, o = [`^url\\s*\\(\\s*['"]?(.+?)['"]?\\s*\\)$`, "^(none)$", "^(.+)$"]; + It.types = { + time: { + number: !0, + min: 0, + units: "s|ms", + implicitUnits: "ms" + }, + percent: { + number: !0, + min: 0, + max: 100, + units: "%", + implicitUnits: "%" + }, + percentages: { + number: !0, + min: 0, + max: 100, + units: "%", + implicitUnits: "%", + multiple: !0 + }, + zeroOneNumber: { + number: !0, + min: 0, + max: 1, + unitless: !0 + }, + zeroOneNumbers: { + number: !0, + min: 0, + max: 1, + unitless: !0, + multiple: !0 + }, + nOneOneNumber: { + number: !0, + min: -1, + max: 1, + unitless: !0 + }, + nonNegativeInt: { + number: !0, + min: 0, + integer: !0, + unitless: !0 + }, + nonNegativeNumber: { + number: !0, + min: 0, + unitless: !0 + }, + position: { + enums: ["parent", "origin"] + }, + nodeSize: { + number: !0, + min: 0, + enums: ["label"] + }, + number: { + number: !0, + unitless: !0 + }, + numbers: { + number: !0, + unitless: !0, + multiple: !0 + }, + positiveNumber: { + number: !0, + unitless: !0, + min: 0, + strictMin: !0 + }, + size: { + number: !0, + min: 0 + }, + bidirectionalSize: { + number: !0 + }, + // allows negative + bidirectionalSizeMaybePercent: { + number: !0, + allowPercent: !0 + }, + // allows negative + bidirectionalSizes: { + number: !0, + multiple: !0 + }, + // allows negative + sizeMaybePercent: { + number: !0, + min: 0, + allowPercent: !0 + }, + axisDirection: { + enums: ["horizontal", "leftward", "rightward", "vertical", "upward", "downward", "auto"] + }, + paddingRelativeTo: { + enums: ["width", "height", "average", "min", "max"] + }, + bgWH: { + number: !0, + min: 0, + allowPercent: !0, + enums: ["auto"], + multiple: !0 + }, + bgPos: { + number: !0, + allowPercent: !0, + multiple: !0 + }, + bgRelativeTo: { + enums: ["inner", "include-padding"], + multiple: !0 + }, + bgRepeat: { + enums: ["repeat", "repeat-x", "repeat-y", "no-repeat"], + multiple: !0 + }, + bgFit: { + enums: ["none", "contain", "cover"], + multiple: !0 + }, + bgCrossOrigin: { + enums: ["anonymous", "use-credentials", "null"], + multiple: !0 + }, + bgClip: { + enums: ["none", "node"], + multiple: !0 + }, + bgContainment: { + enums: ["inside", "over"], + multiple: !0 + }, + color: { + color: !0 + }, + colors: { + color: !0, + multiple: !0 + }, + fill: { + enums: ["solid", "linear-gradient", "radial-gradient"] + }, + bool: { + enums: ["yes", "no"] + }, + bools: { + enums: ["yes", "no"], + multiple: !0 + }, + lineStyle: { + enums: ["solid", "dotted", "dashed"] + }, + lineCap: { + enums: ["butt", "round", "square"] + }, + borderStyle: { + enums: ["solid", "dotted", "dashed", "double"] + }, + curveStyle: { + enums: ["bezier", "unbundled-bezier", "haystack", "segments", "straight", "straight-triangle", "taxi"] + }, + fontFamily: { + regex: '^([\\w- \\"]+(?:\\s*,\\s*[\\w- \\"]+)*)$' + }, + fontStyle: { + enums: ["italic", "normal", "oblique"] + }, + fontWeight: { + enums: ["normal", "bold", "bolder", "lighter", "100", "200", "300", "400", "500", "600", "800", "900", 100, 200, 300, 400, 500, 600, 700, 800, 900] + }, + textDecoration: { + enums: ["none", "underline", "overline", "line-through"] + }, + textTransform: { + enums: ["none", "uppercase", "lowercase"] + }, + textWrap: { + enums: ["none", "wrap", "ellipsis"] + }, + textOverflowWrap: { + enums: ["whitespace", "anywhere"] + }, + textBackgroundShape: { + enums: ["rectangle", "roundrectangle", "round-rectangle"] + }, + nodeShape: { + enums: ["rectangle", "roundrectangle", "round-rectangle", "cutrectangle", "cut-rectangle", "bottomroundrectangle", "bottom-round-rectangle", "barrel", "ellipse", "triangle", "round-triangle", "square", "pentagon", "round-pentagon", "hexagon", "round-hexagon", "concavehexagon", "concave-hexagon", "heptagon", "round-heptagon", "octagon", "round-octagon", "tag", "round-tag", "star", "diamond", "round-diamond", "vee", "rhomboid", "right-rhomboid", "polygon"] + }, + overlayShape: { + enums: ["roundrectangle", "round-rectangle", "ellipse"] + }, + compoundIncludeLabels: { + enums: ["include", "exclude"] + }, + arrowShape: { + enums: ["tee", "triangle", "triangle-tee", "circle-triangle", "triangle-cross", "triangle-backcurve", "vee", "square", "circle", "diamond", "chevron", "none"] + }, + arrowFill: { + enums: ["filled", "hollow"] + }, + arrowWidth: { + number: !0, + units: "%|px|em", + implicitUnits: "px", + enums: ["match-line"] + }, + display: { + enums: ["element", "none"] + }, + visibility: { + enums: ["hidden", "visible"] + }, + zCompoundDepth: { + enums: ["bottom", "orphan", "auto", "top"] + }, + zIndexCompare: { + enums: ["auto", "manual"] + }, + valign: { + enums: ["top", "center", "bottom"] + }, + halign: { + enums: ["left", "center", "right"] + }, + justification: { + enums: ["left", "center", "right", "auto"] + }, + text: { + string: !0 + }, + data: { + mapping: !0, + regex: i("data") + }, + layoutData: { + mapping: !0, + regex: i("layoutData") + }, + scratch: { + mapping: !0, + regex: i("scratch") + }, + mapData: { + mapping: !0, + regex: s("mapData") + }, + mapLayoutData: { + mapping: !0, + regex: s("mapLayoutData") + }, + mapScratch: { + mapping: !0, + regex: s("mapScratch") + }, + fn: { + mapping: !0, + fn: !0 + }, + url: { + regexes: o, + singleRegexMatchValue: !0 + }, + urls: { + regexes: o, + singleRegexMatchValue: !0, + multiple: !0 + }, + propList: { + propList: !0 + }, + angle: { + number: !0, + units: "deg|rad", + implicitUnits: "rad" + }, + textRotation: { + number: !0, + units: "deg|rad", + implicitUnits: "rad", + enums: ["none", "autorotate"] + }, + polygonPointList: { + number: !0, + multiple: !0, + evenMultiple: !0, + min: -1, + max: 1, + unitless: !0 + }, + edgeDistances: { + enums: ["intersection", "node-position", "endpoints"] + }, + edgeEndpoint: { + number: !0, + multiple: !0, + units: "%|px|em|deg|rad", + implicitUnits: "px", + enums: ["inside-to-node", "outside-to-node", "outside-to-node-or-label", "outside-to-line", "outside-to-line-or-label"], + singleEnum: !0, + validate: function(Le, Se) { + switch (Le.length) { + case 2: + return Se[0] !== "deg" && Se[0] !== "rad" && Se[1] !== "deg" && Se[1] !== "rad"; + case 1: + return ee(Le[0]) || Se[0] === "deg" || Se[0] === "rad"; + default: + return !1; + } + } + }, + easing: { + regexes: ["^(spring)\\s*\\(\\s*(" + t + ")\\s*,\\s*(" + t + ")\\s*\\)$", "^(cubic-bezier)\\s*\\(\\s*(" + t + ")\\s*,\\s*(" + t + ")\\s*,\\s*(" + t + ")\\s*,\\s*(" + t + ")\\s*\\)$"], + enums: ["linear", "ease", "ease-in", "ease-out", "ease-in-out", "ease-in-sine", "ease-out-sine", "ease-in-out-sine", "ease-in-quad", "ease-out-quad", "ease-in-out-quad", "ease-in-cubic", "ease-out-cubic", "ease-in-out-cubic", "ease-in-quart", "ease-out-quart", "ease-in-out-quart", "ease-in-quint", "ease-out-quint", "ease-in-out-quint", "ease-in-expo", "ease-out-expo", "ease-in-out-expo", "ease-in-circ", "ease-out-circ", "ease-in-out-circ"] + }, + gradientDirection: { + enums: [ + "to-bottom", + "to-top", + "to-left", + "to-right", + "to-bottom-right", + "to-bottom-left", + "to-top-right", + "to-top-left", + "to-right-bottom", + "to-left-bottom", + "to-right-top", + "to-left-top" + // different order + ] + }, + boundsExpansion: { + number: !0, + multiple: !0, + min: 0, + validate: function(Le) { + var Se = Le.length; + return Se === 1 || Se === 2 || Se === 4; + } + } + }; + var u = { + zeroNonZero: function(Le, Se) { + return (Le == null || Se == null) && Le !== Se || Le == 0 && Se != 0 ? !0 : Le != 0 && Se == 0; + }, + any: function(Le, Se) { + return Le != Se; + }, + emptyNonEmpty: function(Le, Se) { + var Oe = Re(Le), Fe = Re(Se); + return Oe && !Fe || !Oe && Fe; + } + }, l = It.types, f = [{ + name: "label", + type: l.text, + triggersBounds: u.any, + triggersZOrder: u.emptyNonEmpty + }, { + name: "text-rotation", + type: l.textRotation, + triggersBounds: u.any + }, { + name: "text-margin-x", + type: l.bidirectionalSize, + triggersBounds: u.any + }, { + name: "text-margin-y", + type: l.bidirectionalSize, + triggersBounds: u.any + }], h = [{ + name: "source-label", + type: l.text, + triggersBounds: u.any + }, { + name: "source-text-rotation", + type: l.textRotation, + triggersBounds: u.any + }, { + name: "source-text-margin-x", + type: l.bidirectionalSize, + triggersBounds: u.any + }, { + name: "source-text-margin-y", + type: l.bidirectionalSize, + triggersBounds: u.any + }, { + name: "source-text-offset", + type: l.size, + triggersBounds: u.any + }], v = [{ + name: "target-label", + type: l.text, + triggersBounds: u.any + }, { + name: "target-text-rotation", + type: l.textRotation, + triggersBounds: u.any + }, { + name: "target-text-margin-x", + type: l.bidirectionalSize, + triggersBounds: u.any + }, { + name: "target-text-margin-y", + type: l.bidirectionalSize, + triggersBounds: u.any + }, { + name: "target-text-offset", + type: l.size, + triggersBounds: u.any + }], d = [{ + name: "font-family", + type: l.fontFamily, + triggersBounds: u.any + }, { + name: "font-style", + type: l.fontStyle, + triggersBounds: u.any + }, { + name: "font-weight", + type: l.fontWeight, + triggersBounds: u.any + }, { + name: "font-size", + type: l.size, + triggersBounds: u.any + }, { + name: "text-transform", + type: l.textTransform, + triggersBounds: u.any + }, { + name: "text-wrap", + type: l.textWrap, + triggersBounds: u.any + }, { + name: "text-overflow-wrap", + type: l.textOverflowWrap, + triggersBounds: u.any + }, { + name: "text-max-width", + type: l.size, + triggersBounds: u.any + }, { + name: "text-outline-width", + type: l.size, + triggersBounds: u.any + }, { + name: "line-height", + type: l.positiveNumber, + triggersBounds: u.any + }], c = [{ + name: "text-valign", + type: l.valign, + triggersBounds: u.any + }, { + name: "text-halign", + type: l.halign, + triggersBounds: u.any + }, { + name: "color", + type: l.color + }, { + name: "text-outline-color", + type: l.color + }, { + name: "text-outline-opacity", + type: l.zeroOneNumber + }, { + name: "text-background-color", + type: l.color + }, { + name: "text-background-opacity", + type: l.zeroOneNumber + }, { + name: "text-background-padding", + type: l.size, + triggersBounds: u.any + }, { + name: "text-border-opacity", + type: l.zeroOneNumber + }, { + name: "text-border-color", + type: l.color + }, { + name: "text-border-width", + type: l.size, + triggersBounds: u.any + }, { + name: "text-border-style", + type: l.borderStyle, + triggersBounds: u.any + }, { + name: "text-background-shape", + type: l.textBackgroundShape, + triggersBounds: u.any + }, { + name: "text-justification", + type: l.justification + }], y = [{ + name: "events", + type: l.bool, + triggersZOrder: u.any + }, { + name: "text-events", + type: l.bool, + triggersZOrder: u.any + }], p = [{ + name: "display", + type: l.display, + triggersZOrder: u.any, + triggersBounds: u.any, + triggersBoundsOfConnectedEdges: !0 + }, { + name: "visibility", + type: l.visibility, + triggersZOrder: u.any + }, { + name: "opacity", + type: l.zeroOneNumber, + triggersZOrder: u.zeroNonZero + }, { + name: "text-opacity", + type: l.zeroOneNumber + }, { + name: "min-zoomed-font-size", + type: l.size + }, { + name: "z-compound-depth", + type: l.zCompoundDepth, + triggersZOrder: u.any + }, { + name: "z-index-compare", + type: l.zIndexCompare, + triggersZOrder: u.any + }, { + name: "z-index", + type: l.number, + triggersZOrder: u.any + }], g = [{ + name: "overlay-padding", + type: l.size, + triggersBounds: u.any + }, { + name: "overlay-color", + type: l.color + }, { + name: "overlay-opacity", + type: l.zeroOneNumber, + triggersBounds: u.zeroNonZero + }, { + name: "overlay-shape", + type: l.overlayShape, + triggersBounds: u.any + }], m = [{ + name: "underlay-padding", + type: l.size, + triggersBounds: u.any + }, { + name: "underlay-color", + type: l.color + }, { + name: "underlay-opacity", + type: l.zeroOneNumber, + triggersBounds: u.zeroNonZero + }, { + name: "underlay-shape", + type: l.overlayShape, + triggersBounds: u.any + }], b = [{ + name: "transition-property", + type: l.propList + }, { + name: "transition-duration", + type: l.time + }, { + name: "transition-delay", + type: l.time + }, { + name: "transition-timing-function", + type: l.easing + }], E = function(Le, Se) { + return Se.value === "label" ? -Le.poolIndex() : Se.pfValue; + }, M = [{ + name: "height", + type: l.nodeSize, + triggersBounds: u.any, + hashOverride: E + }, { + name: "width", + type: l.nodeSize, + triggersBounds: u.any, + hashOverride: E + }, { + name: "shape", + type: l.nodeShape, + triggersBounds: u.any + }, { + name: "shape-polygon-points", + type: l.polygonPointList, + triggersBounds: u.any + }, { + name: "background-color", + type: l.color + }, { + name: "background-fill", + type: l.fill + }, { + name: "background-opacity", + type: l.zeroOneNumber + }, { + name: "background-blacken", + type: l.nOneOneNumber + }, { + name: "background-gradient-stop-colors", + type: l.colors + }, { + name: "background-gradient-stop-positions", + type: l.percentages + }, { + name: "background-gradient-direction", + type: l.gradientDirection + }, { + name: "padding", + type: l.sizeMaybePercent, + triggersBounds: u.any + }, { + name: "padding-relative-to", + type: l.paddingRelativeTo, + triggersBounds: u.any + }, { + name: "bounds-expansion", + type: l.boundsExpansion, + triggersBounds: u.any + }], L = [{ + name: "border-color", + type: l.color + }, { + name: "border-opacity", + type: l.zeroOneNumber + }, { + name: "border-width", + type: l.size, + triggersBounds: u.any + }, { + name: "border-style", + type: l.borderStyle + }], w = [{ + name: "outline-color", + type: l.color + }, { + name: "outline-opacity", + type: l.zeroOneNumber + }, { + name: "outline-width", + type: l.size, + triggersBounds: u.any + }, { + name: "outline-style", + type: l.borderStyle + }, { + name: "outline-offset", + type: l.size, + triggersBounds: u.any + }], k = [{ + name: "background-image", + type: l.urls + }, { + name: "background-image-crossorigin", + type: l.bgCrossOrigin + }, { + name: "background-image-opacity", + type: l.zeroOneNumbers + }, { + name: "background-image-containment", + type: l.bgContainment + }, { + name: "background-image-smoothing", + type: l.bools + }, { + name: "background-position-x", + type: l.bgPos + }, { + name: "background-position-y", + type: l.bgPos + }, { + name: "background-width-relative-to", + type: l.bgRelativeTo + }, { + name: "background-height-relative-to", + type: l.bgRelativeTo + }, { + name: "background-repeat", + type: l.bgRepeat + }, { + name: "background-fit", + type: l.bgFit + }, { + name: "background-clip", + type: l.bgClip + }, { + name: "background-width", + type: l.bgWH + }, { + name: "background-height", + type: l.bgWH + }, { + name: "background-offset-x", + type: l.bgPos + }, { + name: "background-offset-y", + type: l.bgPos + }], D = [{ + name: "position", + type: l.position, + triggersBounds: u.any + }, { + name: "compound-sizing-wrt-labels", + type: l.compoundIncludeLabels, + triggersBounds: u.any + }, { + name: "min-width", + type: l.size, + triggersBounds: u.any + }, { + name: "min-width-bias-left", + type: l.sizeMaybePercent, + triggersBounds: u.any + }, { + name: "min-width-bias-right", + type: l.sizeMaybePercent, + triggersBounds: u.any + }, { + name: "min-height", + type: l.size, + triggersBounds: u.any + }, { + name: "min-height-bias-top", + type: l.sizeMaybePercent, + triggersBounds: u.any + }, { + name: "min-height-bias-bottom", + type: l.sizeMaybePercent, + triggersBounds: u.any + }], F = [{ + name: "line-style", + type: l.lineStyle + }, { + name: "line-color", + type: l.color + }, { + name: "line-fill", + type: l.fill + }, { + name: "line-cap", + type: l.lineCap + }, { + name: "line-opacity", + type: l.zeroOneNumber + }, { + name: "line-dash-pattern", + type: l.numbers + }, { + name: "line-dash-offset", + type: l.number + }, { + name: "line-gradient-stop-colors", + type: l.colors + }, { + name: "line-gradient-stop-positions", + type: l.percentages + }, { + name: "curve-style", + type: l.curveStyle, + triggersBounds: u.any, + triggersBoundsOfParallelBeziers: !0 + }, { + name: "haystack-radius", + type: l.zeroOneNumber, + triggersBounds: u.any + }, { + name: "source-endpoint", + type: l.edgeEndpoint, + triggersBounds: u.any + }, { + name: "target-endpoint", + type: l.edgeEndpoint, + triggersBounds: u.any + }, { + name: "control-point-step-size", + type: l.size, + triggersBounds: u.any + }, { + name: "control-point-distances", + type: l.bidirectionalSizes, + triggersBounds: u.any + }, { + name: "control-point-weights", + type: l.numbers, + triggersBounds: u.any + }, { + name: "segment-distances", + type: l.bidirectionalSizes, + triggersBounds: u.any + }, { + name: "segment-weights", + type: l.numbers, + triggersBounds: u.any + }, { + name: "taxi-turn", + type: l.bidirectionalSizeMaybePercent, + triggersBounds: u.any + }, { + name: "taxi-turn-min-distance", + type: l.size, + triggersBounds: u.any + }, { + name: "taxi-direction", + type: l.axisDirection, + triggersBounds: u.any + }, { + name: "edge-distances", + type: l.edgeDistances, + triggersBounds: u.any + }, { + name: "arrow-scale", + type: l.positiveNumber, + triggersBounds: u.any + }, { + name: "loop-direction", + type: l.angle, + triggersBounds: u.any + }, { + name: "loop-sweep", + type: l.angle, + triggersBounds: u.any + }, { + name: "source-distance-from-node", + type: l.size, + triggersBounds: u.any + }, { + name: "target-distance-from-node", + type: l.size, + triggersBounds: u.any + }], G = [{ + name: "ghost", + type: l.bool, + triggersBounds: u.any + }, { + name: "ghost-offset-x", + type: l.bidirectionalSize, + triggersBounds: u.any + }, { + name: "ghost-offset-y", + type: l.bidirectionalSize, + triggersBounds: u.any + }, { + name: "ghost-opacity", + type: l.zeroOneNumber + }], N = [{ + name: "selection-box-color", + type: l.color + }, { + name: "selection-box-opacity", + type: l.zeroOneNumber + }, { + name: "selection-box-border-color", + type: l.color + }, { + name: "selection-box-border-width", + type: l.size + }, { + name: "active-bg-color", + type: l.color + }, { + name: "active-bg-opacity", + type: l.zeroOneNumber + }, { + name: "active-bg-size", + type: l.size + }, { + name: "outside-texture-bg-color", + type: l.color + }, { + name: "outside-texture-bg-opacity", + type: l.zeroOneNumber + }], X = []; + It.pieBackgroundN = 16, X.push({ + name: "pie-size", + type: l.sizeMaybePercent + }); + for (var B = 1; B <= It.pieBackgroundN; B++) + X.push({ + name: "pie-" + B + "-background-color", + type: l.color + }), X.push({ + name: "pie-" + B + "-background-size", + type: l.percent + }), X.push({ + name: "pie-" + B + "-background-opacity", + type: l.zeroOneNumber + }); + var re = [], K = It.arrowPrefixes = ["source", "mid-source", "target", "mid-target"]; + [{ + name: "arrow-shape", + type: l.arrowShape, + triggersBounds: u.any + }, { + name: "arrow-color", + type: l.color + }, { + name: "arrow-fill", + type: l.arrowFill + }, { + name: "arrow-width", + type: l.arrowWidth + }].forEach(function(xe) { + K.forEach(function(Le) { + var Se = Le + "-" + xe.name, Oe = xe.type, Fe = xe.triggersBounds; + re.push({ + name: Se, + type: Oe, + triggersBounds: Fe + }); + }); + }, {}); + var W = It.properties = [].concat(y, b, p, g, m, G, c, d, f, h, v, M, L, w, k, X, D, F, re, N), ae = It.propertyGroups = { + // common to all eles + behavior: y, + transition: b, + visibility: p, + overlay: g, + underlay: m, + ghost: G, + // labels + commonLabel: c, + labelDimensions: d, + mainLabel: f, + sourceLabel: h, + targetLabel: v, + // node props + nodeBody: M, + nodeBorder: L, + nodeOutline: w, + backgroundImage: k, + pie: X, + compound: D, + // edge props + edgeLine: F, + edgeArrow: re, + core: N + }, ue = It.propertyGroupNames = {}, me = It.propertyGroupKeys = Object.keys(ae); + me.forEach(function(xe) { + ue[xe] = ae[xe].map(function(Le) { + return Le.name; + }), ae[xe].forEach(function(Le) { + return Le.groupKey = xe; + }); + }); + var ie = It.aliases = [{ + name: "content", + pointsTo: "label" + }, { + name: "control-point-distance", + pointsTo: "control-point-distances" + }, { + name: "control-point-weight", + pointsTo: "control-point-weights" + }, { + name: "edge-text-rotation", + pointsTo: "text-rotation" + }, { + name: "padding-left", + pointsTo: "padding" + }, { + name: "padding-right", + pointsTo: "padding" + }, { + name: "padding-top", + pointsTo: "padding" + }, { + name: "padding-bottom", + pointsTo: "padding" + }]; + It.propertyNames = W.map(function(xe) { + return xe.name; + }); + for (var ge = 0; ge < W.length; ge++) { + var Ee = W[ge]; + W[Ee.name] = Ee; + } + for (var Ce = 0; Ce < ie.length; Ce++) { + var we = ie[Ce], De = W[we.pointsTo], se = { + name: we.name, + alias: !0, + pointsTo: De + }; + W.push(se), W[we.name] = se; + } + })(), It.getDefaultProperty = function(t) { + return this.getDefaultProperties()[t]; + }, It.getDefaultProperties = function() { + var t = this._private; + if (t.defaultProperties != null) + return t.defaultProperties; + for (var e = He({ + // core props + "selection-box-color": "#ddd", + "selection-box-opacity": 0.65, + "selection-box-border-color": "#aaa", + "selection-box-border-width": 1, + "active-bg-color": "black", + "active-bg-opacity": 0.15, + "active-bg-size": 30, + "outside-texture-bg-color": "#000", + "outside-texture-bg-opacity": 0.125, + // common node/edge props + events: "yes", + "text-events": "no", + "text-valign": "top", + "text-halign": "center", + "text-justification": "auto", + "line-height": 1, + color: "#000", + "text-outline-color": "#000", + "text-outline-width": 0, + "text-outline-opacity": 1, + "text-opacity": 1, + "text-decoration": "none", + "text-transform": "none", + "text-wrap": "none", + "text-overflow-wrap": "whitespace", + "text-max-width": 9999, + "text-background-color": "#000", + "text-background-opacity": 0, + "text-background-shape": "rectangle", + "text-background-padding": 0, + "text-border-opacity": 0, + "text-border-width": 0, + "text-border-style": "solid", + "text-border-color": "#000", + "font-family": "Helvetica Neue, Helvetica, sans-serif", + "font-style": "normal", + "font-weight": "normal", + "font-size": 16, + "min-zoomed-font-size": 0, + "text-rotation": "none", + "source-text-rotation": "none", + "target-text-rotation": "none", + visibility: "visible", + display: "element", + opacity: 1, + "z-compound-depth": "auto", + "z-index-compare": "auto", + "z-index": 0, + label: "", + "text-margin-x": 0, + "text-margin-y": 0, + "source-label": "", + "source-text-offset": 0, + "source-text-margin-x": 0, + "source-text-margin-y": 0, + "target-label": "", + "target-text-offset": 0, + "target-text-margin-x": 0, + "target-text-margin-y": 0, + "overlay-opacity": 0, + "overlay-color": "#000", + "overlay-padding": 10, + "overlay-shape": "round-rectangle", + "underlay-opacity": 0, + "underlay-color": "#000", + "underlay-padding": 10, + "underlay-shape": "round-rectangle", + "transition-property": "none", + "transition-duration": 0, + "transition-delay": 0, + "transition-timing-function": "linear", + // node props + "background-blacken": 0, + "background-color": "#999", + "background-fill": "solid", + "background-opacity": 1, + "background-image": "none", + "background-image-crossorigin": "anonymous", + "background-image-opacity": 1, + "background-image-containment": "inside", + "background-image-smoothing": "yes", + "background-position-x": "50%", + "background-position-y": "50%", + "background-offset-x": 0, + "background-offset-y": 0, + "background-width-relative-to": "include-padding", + "background-height-relative-to": "include-padding", + "background-repeat": "no-repeat", + "background-fit": "none", + "background-clip": "node", + "background-width": "auto", + "background-height": "auto", + "border-color": "#000", + "border-opacity": 1, + "border-width": 0, + "border-style": "solid", + "outline-color": "#999", + "outline-opacity": 1, + "outline-width": 0, + "outline-offset": 0, + "outline-style": "solid", + height: 30, + width: 30, + shape: "ellipse", + "shape-polygon-points": "-1, -1, 1, -1, 1, 1, -1, 1", + "bounds-expansion": 0, + // node gradient + "background-gradient-direction": "to-bottom", + "background-gradient-stop-colors": "#999", + "background-gradient-stop-positions": "0%", + // ghost props + ghost: "no", + "ghost-offset-y": 0, + "ghost-offset-x": 0, + "ghost-opacity": 0, + // compound props + padding: 0, + "padding-relative-to": "width", + position: "origin", + "compound-sizing-wrt-labels": "include", + "min-width": 0, + "min-width-bias-left": 0, + "min-width-bias-right": 0, + "min-height": 0, + "min-height-bias-top": 0, + "min-height-bias-bottom": 0 + }, { + // node pie bg + "pie-size": "100%" + }, [{ + name: "pie-{{i}}-background-color", + value: "black" + }, { + name: "pie-{{i}}-background-size", + value: "0%" + }, { + name: "pie-{{i}}-background-opacity", + value: 1 + }].reduce(function(u, l) { + for (var f = 1; f <= It.pieBackgroundN; f++) { + var h = l.name.replace("{{i}}", f), v = l.value; + u[h] = v; + } + return u; + }, {}), { + // edge props + "line-style": "solid", + "line-color": "#999", + "line-fill": "solid", + "line-cap": "butt", + "line-opacity": 1, + "line-gradient-stop-colors": "#999", + "line-gradient-stop-positions": "0%", + "control-point-step-size": 40, + "control-point-weights": 0.5, + "segment-weights": 0.5, + "segment-distances": 20, + "taxi-turn": "50%", + "taxi-turn-min-distance": 10, + "taxi-direction": "auto", + "edge-distances": "intersection", + "curve-style": "haystack", + "haystack-radius": 0, + "arrow-scale": 1, + "loop-direction": "-45deg", + "loop-sweep": "-90deg", + "source-distance-from-node": 0, + "target-distance-from-node": 0, + "source-endpoint": "outside-to-node", + "target-endpoint": "outside-to-node", + "line-dash-pattern": [6, 3], + "line-dash-offset": 0 + }, [{ + name: "arrow-shape", + value: "none" + }, { + name: "arrow-color", + value: "#999" + }, { + name: "arrow-fill", + value: "filled" + }, { + name: "arrow-width", + value: 1 + }].reduce(function(u, l) { + return It.arrowPrefixes.forEach(function(f) { + var h = f + "-" + l.name, v = l.value; + u[h] = v; + }), u; + }, {})), r = {}, a = 0; a < this.properties.length; a++) { + var n = this.properties[a]; + if (!n.pointsTo) { + var i = n.name, s = e[i], o = this.parse(i, s); + r[i] = o; + } + } + return t.defaultProperties = r, t.defaultProperties; + }, It.addDefaultStylesheet = function() { + this.selector(":parent").css({ + shape: "rectangle", + padding: 10, + "background-color": "#eee", + "border-color": "#ccc", + "border-width": 1 + }).selector("edge").css({ + width: 3 + }).selector(":loop").css({ + "curve-style": "bezier" + }).selector("edge:compound").css({ + "curve-style": "bezier", + "source-endpoint": "outside-to-line", + "target-endpoint": "outside-to-line" + }).selector(":selected").css({ + "background-color": "#0169D9", + "line-color": "#0169D9", + "source-arrow-color": "#0169D9", + "target-arrow-color": "#0169D9", + "mid-source-arrow-color": "#0169D9", + "mid-target-arrow-color": "#0169D9" + }).selector(":parent:selected").css({ + "background-color": "#CCE1F9", + "border-color": "#aec8e5" + }).selector(":active").css({ + "overlay-color": "black", + "overlay-padding": 10, + "overlay-opacity": 0.25 + }), this.defaultLength = this.length; + }; + var $n = {}; + $n.parse = function(t, e, r, a) { + var n = this; + if (H(e)) + return n.parseImplWarn(t, e, r, a); + var i = a === "mapping" || a === !0 || a === !1 || a == null ? "dontcare" : a, s = r ? "t" : "f", o = "" + e, u = hs(t, o, s, i), l = n.propCache = n.propCache || [], f; + return (f = l[u]) || (f = l[u] = n.parseImplWarn(t, e, r, a)), (r || a === "mapping") && (f = lr(f), f && (f.value = lr(f.value))), f; + }, $n.parseImplWarn = function(t, e, r, a) { + var n = this.parseImpl(t, e, r, a); + return !n && e != null && vt("The style property `".concat(t, ": ").concat(e, "` is invalid")), n && (n.name === "width" || n.name === "height") && e === "label" && vt("The style value of `label` is deprecated for `" + n.name + "`"), n; + }, $n.parseImpl = function(t, e, r, a) { + var n = this; + t = tt(t); + var i = n.properties[t], s = e, o = n.types; + if (!i || e === void 0) + return null; + i.alias && (i = i.pointsTo, t = i.name); + var u = ee(e); + u && (e = e.trim()); + var l = i.type; + if (!l) + return null; + if (r && (e === "" || e === null)) + return { + name: t, + value: e, + bypass: !0, + deleteBypass: !0 + }; + if (H(e)) + return { + name: t, + value: e, + strValue: "fn", + mapped: o.fn, + bypass: r + }; + var f, h; + if (!(!u || a || e.length < 7 || e[1] !== "a")) { + if (e.length >= 7 && e[0] === "d" && (f = new RegExp(o.data.regex).exec(e))) { + if (r) + return !1; + var v = o.data; + return { + name: t, + value: f, + strValue: "" + e, + mapped: v, + field: f[1], + bypass: r + }; + } else if (e.length >= 10 && e[0] === "m" && (h = new RegExp(o.mapData.regex).exec(e))) { + if (r || l.multiple) + return !1; + var d = o.mapData; + if (!(l.color || l.number)) + return !1; + var c = this.parse(t, h[4]); + if (!c || c.mapped) + return !1; + var y = this.parse(t, h[5]); + if (!y || y.mapped) + return !1; + if (c.pfValue === y.pfValue || c.strValue === y.strValue) + return vt("`" + t + ": " + e + "` is not a valid mapper because the output range is zero; converting to `" + t + ": " + c.strValue + "`"), this.parse(t, c.strValue); + if (l.color) { + var p = c.value, g = y.value, m = p[0] === g[0] && p[1] === g[1] && p[2] === g[2] && // optional alpha + (p[3] === g[3] || (p[3] == null || p[3] === 1) && (g[3] == null || g[3] === 1)); + if (m) + return !1; + } + return { + name: t, + value: h, + strValue: "" + e, + mapped: d, + field: h[1], + fieldMin: parseFloat(h[2]), + // min & max are numeric + fieldMax: parseFloat(h[3]), + valueMin: c.value, + valueMax: y.value, + bypass: r + }; + } + } + if (l.multiple && a !== "multiple") { + var b; + if (u ? b = e.split(/\s+/) : te(e) ? b = e : b = [e], l.evenMultiple && b.length % 2 !== 0) + return null; + for (var E = [], M = [], L = [], w = "", k = !1, D = 0; D < b.length; D++) { + var F = n.parse(t, b[D], r, "multiple"); + k = k || ee(F.value), E.push(F.value), L.push(F.pfValue != null ? F.pfValue : F.value), M.push(F.units), w += (D > 0 ? " " : "") + F.strValue; + } + return l.validate && !l.validate(E, M) ? null : l.singleEnum && k ? E.length === 1 && ee(E[0]) ? { + name: t, + value: E[0], + strValue: E[0], + bypass: r + } : null : { + name: t, + value: E, + pfValue: L, + strValue: w, + bypass: r, + units: M + }; + } + var G = function() { + for (var Le = 0; Le < l.enums.length; Le++) { + var Se = l.enums[Le]; + if (Se === e) + return { + name: t, + value: e, + strValue: "" + e, + bypass: r + }; + } + return null; + }; + if (l.number) { + var N, X = "px"; + if (l.units && (N = l.units), l.implicitUnits && (X = l.implicitUnits), !l.unitless) + if (u) { + var B = "px|em" + (l.allowPercent ? "|\\%" : ""); + N && (B = N); + var re = e.match("^(" + gt + ")(" + B + ")?$"); + re && (e = re[1], N = re[2] || X); + } else + (!N || l.implicitUnits) && (N = X); + if (e = parseFloat(e), isNaN(e) && l.enums === void 0) + return null; + if (isNaN(e) && l.enums !== void 0) + return e = s, G(); + if (l.integer && !q(e) || l.min !== void 0 && (e < l.min || l.strictMin && e === l.min) || l.max !== void 0 && (e > l.max || l.strictMax && e === l.max)) + return null; + var K = { + name: t, + value: e, + strValue: "" + e + (N || ""), + units: N, + bypass: r + }; + return l.unitless || N !== "px" && N !== "em" ? K.pfValue = e : K.pfValue = N === "px" || !N ? e : this.getEmSizeInPixels() * e, (N === "ms" || N === "s") && (K.pfValue = N === "ms" ? e : 1e3 * e), (N === "deg" || N === "rad") && (K.pfValue = N === "rad" ? e : mf(e)), N === "%" && (K.pfValue = e / 100), K; + } else if (l.propList) { + var W = [], ae = "" + e; + if (ae !== "none") { + for (var ue = ae.split(/\s*,\s*|\s+/), me = 0; me < ue.length; me++) { + var ie = ue[me].trim(); + n.properties[ie] ? W.push(ie) : vt("`" + ie + "` is not a valid property name"); + } + if (W.length === 0) + return null; + } + return { + name: t, + value: W, + strValue: W.length === 0 ? "none" : W.join(" "), + bypass: r + }; + } else if (l.color) { + var ge = eu(e); + return ge ? { + name: t, + value: ge, + pfValue: ge, + strValue: "rgb(" + ge[0] + "," + ge[1] + "," + ge[2] + ")", + // n.b. no spaces b/c of multiple support + bypass: r + } : null; + } else if (l.regex || l.regexes) { + if (l.enums) { + var Ee = G(); + if (Ee) + return Ee; + } + for (var Ce = l.regexes ? l.regexes : [l.regex], we = 0; we < Ce.length; we++) { + var De = new RegExp(Ce[we]), se = De.exec(e); + if (se) + return { + name: t, + value: l.singleRegexMatchValue ? se[1] : se, + strValue: "" + e, + bypass: r + }; + } + return null; + } else + return l.string ? { + name: t, + value: "" + e, + strValue: "" + e, + bypass: r + } : l.enums ? G() : null; + }; + var Gt = function t(e) { + if (!(this instanceof t)) + return new t(e); + if (!Ye(e)) { + xt("A style must have a core reference"); + return; + } + this._private = { + cy: e, + coreStyle: {} + }, this.length = 0, this.resetToDefault(); + }, zt = Gt.prototype; + zt.instanceString = function() { + return "style"; + }, zt.clear = function() { + for (var t = this._private, e = t.cy, r = e.elements(), a = 0; a < this.length; a++) + this[a] = void 0; + return this.length = 0, t.contextStyles = {}, t.propDiffs = {}, this.cleanElements(r, !0), r.forEach(function(n) { + var i = n[0]._private; + i.styleDirty = !0, i.appliedInitStyle = !1; + }), this; + }, zt.resetToDefault = function() { + return this.clear(), this.addDefaultStylesheet(), this; + }, zt.core = function(t) { + return this._private.coreStyle[t] || this.getDefaultProperty(t); + }, zt.selector = function(t) { + var e = t === "core" ? null : new Sr(t), r = this.length++; + return this[r] = { + selector: e, + properties: [], + mappedProperties: [], + index: r + }, this; + }, zt.css = function() { + var t = this, e = arguments; + if (e.length === 1) + for (var r = e[0], a = 0; a < t.properties.length; a++) { + var n = t.properties[a], i = r[n.name]; + i === void 0 && (i = r[yt(n.name)]), i !== void 0 && this.cssRule(n.name, i); + } + else + e.length === 2 && this.cssRule(e[0], e[1]); + return this; + }, zt.style = zt.css, zt.cssRule = function(t, e) { + var r = this.parse(t, e); + if (r) { + var a = this.length - 1; + this[a].properties.push(r), this[a].properties[r.name] = r, r.name.match(/pie-(\d+)-background-size/) && r.value && (this._private.hasPie = !0), r.mapped && this[a].mappedProperties.push(r); + var n = !this[a].selector; + n && (this._private.coreStyle[r.name] = r); + } + return this; + }, zt.append = function(t) { + return at(t) ? t.appendToStyle(this) : te(t) ? this.appendFromJson(t) : ee(t) && this.appendFromString(t), this; + }, Gt.fromJson = function(t, e) { + var r = new Gt(t); + return r.fromJson(e), r; + }, Gt.fromString = function(t, e) { + return new Gt(t).fromString(e); + }, [Ft, qa, Ri, fr, Un, ki, It, $n].forEach(function(t) { + He(zt, t); + }), Gt.types = zt.types, Gt.properties = zt.properties, Gt.propertyGroups = zt.propertyGroups, Gt.propertyGroupNames = zt.propertyGroupNames, Gt.propertyGroupKeys = zt.propertyGroupKeys; + var Gd = { + style: function(e) { + if (e) { + var r = this.setStyle(e); + r.update(); + } + return this._private.style; + }, + setStyle: function(e) { + var r = this._private; + return at(e) ? r.style = e.generateStyle(this) : te(e) ? r.style = Gt.fromJson(this, e) : ee(e) ? r.style = Gt.fromString(this, e) : r.style = Gt(this), r.style; + }, + // e.g. cy.data() changed => recalc ele mappers + updateStyle: function() { + this.mutableElements().updateStyle(); + } + }, zd = "single", Ur = { + autolock: function(e) { + if (e !== void 0) + this._private.autolock = !!e; + else + return this._private.autolock; + return this; + }, + autoungrabify: function(e) { + if (e !== void 0) + this._private.autoungrabify = !!e; + else + return this._private.autoungrabify; + return this; + }, + autounselectify: function(e) { + if (e !== void 0) + this._private.autounselectify = !!e; + else + return this._private.autounselectify; + return this; + }, + selectionType: function(e) { + var r = this._private; + if (r.selectionType == null && (r.selectionType = zd), e !== void 0) + (e === "additive" || e === "single") && (r.selectionType = e); + else + return r.selectionType; + return this; + }, + panningEnabled: function(e) { + if (e !== void 0) + this._private.panningEnabled = !!e; + else + return this._private.panningEnabled; + return this; + }, + userPanningEnabled: function(e) { + if (e !== void 0) + this._private.userPanningEnabled = !!e; + else + return this._private.userPanningEnabled; + return this; + }, + zoomingEnabled: function(e) { + if (e !== void 0) + this._private.zoomingEnabled = !!e; + else + return this._private.zoomingEnabled; + return this; + }, + userZoomingEnabled: function(e) { + if (e !== void 0) + this._private.userZoomingEnabled = !!e; + else + return this._private.userZoomingEnabled; + return this; + }, + boxSelectionEnabled: function(e) { + if (e !== void 0) + this._private.boxSelectionEnabled = !!e; + else + return this._private.boxSelectionEnabled; + return this; + }, + pan: function() { + var e = arguments, r = this._private.pan, a, n, i, s, o; + switch (e.length) { + case 0: + return r; + case 1: + if (ee(e[0])) + return a = e[0], r[a]; + if (S(e[0])) { + if (!this._private.panningEnabled) + return this; + i = e[0], s = i.x, o = i.y, R(s) && (r.x = s), R(o) && (r.y = o), this.emit("pan viewport"); + } + break; + case 2: + if (!this._private.panningEnabled) + return this; + a = e[0], n = e[1], (a === "x" || a === "y") && R(n) && (r[a] = n), this.emit("pan viewport"); + break; + } + return this.notify("viewport"), this; + }, + panBy: function(e, r) { + var a = arguments, n = this._private.pan, i, s, o, u, l; + if (!this._private.panningEnabled) + return this; + switch (a.length) { + case 1: + S(e) && (o = a[0], u = o.x, l = o.y, R(u) && (n.x += u), R(l) && (n.y += l), this.emit("pan viewport")); + break; + case 2: + i = e, s = r, (i === "x" || i === "y") && R(s) && (n[i] += s), this.emit("pan viewport"); + break; + } + return this.notify("viewport"), this; + }, + fit: function(e, r) { + var a = this.getFitViewport(e, r); + if (a) { + var n = this._private; + n.zoom = a.zoom, n.pan = a.pan, this.emit("pan zoom viewport"), this.notify("viewport"); + } + return this; + }, + getFitViewport: function(e, r) { + if (R(e) && r === void 0 && (r = e, e = void 0), !(!this._private.panningEnabled || !this._private.zoomingEnabled)) { + var a; + if (ee(e)) { + var n = e; + e = this.$(n); + } else if (Ze(e)) { + var i = e; + a = { + x1: i.x1, + y1: i.y1, + x2: i.x2, + y2: i.y2 + }, a.w = a.x2 - a.x1, a.h = a.y2 - a.y1; + } else + pe(e) || (e = this.mutableElements()); + if (!(pe(e) && e.empty())) { + a = a || e.boundingBox(); + var s = this.width(), o = this.height(), u; + if (r = R(r) ? r : 0, !isNaN(s) && !isNaN(o) && s > 0 && o > 0 && !isNaN(a.w) && !isNaN(a.h) && a.w > 0 && a.h > 0) { + u = Math.min((s - 2 * r) / a.w, (o - 2 * r) / a.h), u = u > this._private.maxZoom ? this._private.maxZoom : u, u = u < this._private.minZoom ? this._private.minZoom : u; + var l = { + // now pan to middle + x: (s - u * (a.x1 + a.x2)) / 2, + y: (o - u * (a.y1 + a.y2)) / 2 + }; + return { + zoom: u, + pan: l + }; + } + } + } + }, + zoomRange: function(e, r) { + var a = this._private; + if (r == null) { + var n = e; + e = n.min, r = n.max; + } + return R(e) && R(r) && e <= r ? (a.minZoom = e, a.maxZoom = r) : R(e) && r === void 0 && e <= a.maxZoom ? a.minZoom = e : R(r) && e === void 0 && r >= a.minZoom && (a.maxZoom = r), this; + }, + minZoom: function(e) { + return e === void 0 ? this._private.minZoom : this.zoomRange({ + min: e + }); + }, + maxZoom: function(e) { + return e === void 0 ? this._private.maxZoom : this.zoomRange({ + max: e + }); + }, + getZoomedViewport: function(e) { + var r = this._private, a = r.pan, n = r.zoom, i, s, o = !1; + if (r.zoomingEnabled || (o = !0), R(e) ? s = e : S(e) && (s = e.level, e.position != null ? i = vn(e.position, n, a) : e.renderedPosition != null && (i = e.renderedPosition), i != null && !r.panningEnabled && (o = !0)), s = s > r.maxZoom ? r.maxZoom : s, s = s < r.minZoom ? r.minZoom : s, o || !R(s) || s === n || i != null && (!R(i.x) || !R(i.y))) + return null; + if (i != null) { + var u = a, l = n, f = s, h = { + x: -f / l * (i.x - u.x) + i.x, + y: -f / l * (i.y - u.y) + i.y + }; + return { + zoomed: !0, + panned: !0, + zoom: f, + pan: h + }; + } else + return { + zoomed: !0, + panned: !1, + zoom: s, + pan: a + }; + }, + zoom: function(e) { + if (e === void 0) + return this._private.zoom; + var r = this.getZoomedViewport(e), a = this._private; + return r == null || !r.zoomed ? this : (a.zoom = r.zoom, r.panned && (a.pan.x = r.pan.x, a.pan.y = r.pan.y), this.emit("zoom" + (r.panned ? " pan" : "") + " viewport"), this.notify("viewport"), this); + }, + viewport: function(e) { + var r = this._private, a = !0, n = !0, i = [], s = !1, o = !1; + if (!e) + return this; + if (R(e.zoom) || (a = !1), S(e.pan) || (n = !1), !a && !n) + return this; + if (a) { + var u = e.zoom; + u < r.minZoom || u > r.maxZoom || !r.zoomingEnabled ? s = !0 : (r.zoom = u, i.push("zoom")); + } + if (n && (!s || !e.cancelOnFailedZoom) && r.panningEnabled) { + var l = e.pan; + R(l.x) && (r.pan.x = l.x, o = !1), R(l.y) && (r.pan.y = l.y, o = !1), o || i.push("pan"); + } + return i.length > 0 && (i.push("viewport"), this.emit(i.join(" ")), this.notify("viewport")), this; + }, + center: function(e) { + var r = this.getCenterPan(e); + return r && (this._private.pan = r, this.emit("pan viewport"), this.notify("viewport")), this; + }, + getCenterPan: function(e, r) { + if (this._private.panningEnabled) { + if (ee(e)) { + var a = e; + e = this.mutableElements().filter(a); + } else + pe(e) || (e = this.mutableElements()); + if (e.length !== 0) { + var n = e.boundingBox(), i = this.width(), s = this.height(); + r = r === void 0 ? this._private.zoom : r; + var o = { + // middle + x: (i - r * (n.x1 + n.x2)) / 2, + y: (s - r * (n.y1 + n.y2)) / 2 + }; + return o; + } + } + }, + reset: function() { + return !this._private.panningEnabled || !this._private.zoomingEnabled ? this : (this.viewport({ + pan: { + x: 0, + y: 0 + }, + zoom: 1 + }), this); + }, + invalidateSize: function() { + this._private.sizeCache = null; + }, + size: function() { + var e = this._private, r = e.container, a = this; + return e.sizeCache = e.sizeCache || (r ? function() { + var n = a.window().getComputedStyle(r), i = function(o) { + return parseFloat(n.getPropertyValue(o)); + }; + return { + width: r.clientWidth - i("padding-left") - i("padding-right"), + height: r.clientHeight - i("padding-top") - i("padding-bottom") + }; + }() : { + // fallback if no container (not 0 b/c can be used for dividing etc) + width: 1, + height: 1 + }); + }, + width: function() { + return this.size().width; + }, + height: function() { + return this.size().height; + }, + extent: function() { + var e = this._private.pan, r = this._private.zoom, a = this.renderedExtent(), n = { + x1: (a.x1 - e.x) / r, + x2: (a.x2 - e.x) / r, + y1: (a.y1 - e.y) / r, + y2: (a.y2 - e.y) / r + }; + return n.w = n.x2 - n.x1, n.h = n.y2 - n.y1, n; + }, + renderedExtent: function() { + var e = this.width(), r = this.height(); + return { + x1: 0, + y1: 0, + x2: e, + y2: r, + w: e, + h: r + }; + }, + multiClickDebounceTime: function(e) { + if (e) + this._private.multiClickDebounceTime = e; + else + return this._private.multiClickDebounceTime; + return this; + } + }; + Ur.centre = Ur.center, Ur.autolockNodes = Ur.autolock, Ur.autoungrabifyNodes = Ur.autoungrabify; + var Ka = { + data: ct.data({ + field: "data", + bindingEvent: "data", + allowBinding: !0, + allowSetting: !0, + settingEvent: "data", + settingTriggersEvent: !0, + triggerFnName: "trigger", + allowGetting: !0, + updateStyle: !0 + }), + removeData: ct.removeData({ + field: "data", + event: "data", + triggerFnName: "trigger", + triggerEvent: !0, + updateStyle: !0 + }), + scratch: ct.data({ + field: "scratch", + bindingEvent: "scratch", + allowBinding: !0, + allowSetting: !0, + settingEvent: "scratch", + settingTriggersEvent: !0, + triggerFnName: "trigger", + allowGetting: !0, + updateStyle: !0 + }), + removeScratch: ct.removeData({ + field: "scratch", + event: "scratch", + triggerFnName: "trigger", + triggerEvent: !0, + updateStyle: !0 + }) + }; + Ka.attr = Ka.data, Ka.removeAttr = Ka.removeData; + var Za = function(e) { + var r = this; + e = He({}, e); + var a = e.container; + a && !ve(a) && ve(a[0]) && (a = a[0]); + var n = a ? a._cyreg : null; + n = n || {}, n && n.cy && (n.cy.destroy(), n = {}); + var i = n.readies = n.readies || []; + a && (a._cyreg = n), n.cy = r; + var s = A !== void 0 && a !== void 0 && !e.headless, o = e; + o.layout = He({ + name: s ? "grid" : "null" + }, o.layout), o.renderer = He({ + name: s ? "canvas" : "null" + }, o.renderer); + var u = function(c, y, p) { + return y !== void 0 ? y : p !== void 0 ? p : c; + }, l = this._private = { + container: a, + // html dom ele container + ready: !1, + // whether ready has been triggered + options: o, + // cached options + elements: new Nt(this), + // elements in the graph + listeners: [], + // list of listeners + aniEles: new Nt(this), + // elements being animated + data: o.data || {}, + // data for the core + scratch: {}, + // scratch object for core + layout: null, + renderer: null, + destroyed: !1, + // whether destroy was called + notificationsEnabled: !0, + // whether notifications are sent to the renderer + minZoom: 1e-50, + maxZoom: 1e50, + zoomingEnabled: u(!0, o.zoomingEnabled), + userZoomingEnabled: u(!0, o.userZoomingEnabled), + panningEnabled: u(!0, o.panningEnabled), + userPanningEnabled: u(!0, o.userPanningEnabled), + boxSelectionEnabled: u(!0, o.boxSelectionEnabled), + autolock: u(!1, o.autolock, o.autolockNodes), + autoungrabify: u(!1, o.autoungrabify, o.autoungrabifyNodes), + autounselectify: u(!1, o.autounselectify), + styleEnabled: o.styleEnabled === void 0 ? s : o.styleEnabled, + zoom: R(o.zoom) ? o.zoom : 1, + pan: { + x: S(o.pan) && R(o.pan.x) ? o.pan.x : 0, + y: S(o.pan) && R(o.pan.y) ? o.pan.y : 0 + }, + animation: { + // object for currently-running animations + current: [], + queue: [] + }, + hasCompoundNodes: !1, + multiClickDebounceTime: u(250, o.multiClickDebounceTime) + }; + this.createEmitter(), this.selectionType(o.selectionType), this.zoomRange({ + min: o.minZoom, + max: o.maxZoom + }); + var f = function(c, y) { + var p = c.some(nt); + if (p) + return ia.all(c).then(y); + y(c); + }; + l.styleEnabled && r.setStyle([]); + var h = He({}, o, o.renderer); + r.initRenderer(h); + var v = function(c, y, p) { + r.notifications(!1); + var g = r.mutableElements(); + g.length > 0 && g.remove(), c != null && (S(c) || te(c)) && r.add(c), r.one("layoutready", function(b) { + r.notifications(!0), r.emit(b), r.one("load", y), r.emitAndNotify("load"); + }).one("layoutstop", function() { + r.one("done", p), r.emit("done"); + }); + var m = He({}, r._private.options.layout); + m.eles = r.elements(), r.layout(m).run(); + }; + f([o.style, o.elements], function(d) { + var c = d[0], y = d[1]; + l.styleEnabled && r.style().append(c), v(y, function() { + r.startAnimationLoop(), l.ready = !0, H(o.ready) && r.on("ready", o.ready); + for (var p = 0; p < i.length; p++) { + var g = i[p]; + r.on("ready", g); + } + n && (n.readies = []), r.emit("ready"); + }, o.done); + }); + }, _n = Za.prototype; + He(_n, { + instanceString: function() { + return "core"; + }, + isReady: function() { + return this._private.ready; + }, + destroyed: function() { + return this._private.destroyed; + }, + ready: function(e) { + return this.isReady() ? this.emitter().emit("ready", [], e) : this.on("ready", e), this; + }, + destroy: function() { + var e = this; + if (!e.destroyed()) + return e.stopAnimationLoop(), e.destroyRenderer(), this.emit("destroy"), e._private.destroyed = !0, e; + }, + hasElementWithId: function(e) { + return this._private.elements.hasElementWithId(e); + }, + getElementById: function(e) { + return this._private.elements.getElementById(e); + }, + hasCompoundNodes: function() { + return this._private.hasCompoundNodes; + }, + headless: function() { + return this._private.renderer.isHeadless(); + }, + styleEnabled: function() { + return this._private.styleEnabled; + }, + addToPool: function(e) { + return this._private.elements.merge(e), this; + }, + removeFromPool: function(e) { + return this._private.elements.unmerge(e), this; + }, + container: function() { + return this._private.container || null; + }, + window: function() { + var e = this._private.container; + if (e == null) + return A; + var r = this._private.container.ownerDocument; + return r === void 0 || r == null ? A : r.defaultView || A; + }, + mount: function(e) { + if (e != null) { + var r = this, a = r._private, n = a.options; + return !ve(e) && ve(e[0]) && (e = e[0]), r.stopAnimationLoop(), r.destroyRenderer(), a.container = e, a.styleEnabled = !0, r.invalidateSize(), r.initRenderer(He({}, n, n.renderer, { + // allow custom renderer name to be re-used, otherwise use canvas + name: n.renderer.name === "null" ? "canvas" : n.renderer.name + })), r.startAnimationLoop(), r.style(n.style), r.emit("mount"), r; + } + }, + unmount: function() { + var e = this; + return e.stopAnimationLoop(), e.destroyRenderer(), e.initRenderer({ + name: "null" + }), e.emit("unmount"), e; + }, + options: function() { + return lr(this._private.options); + }, + json: function(e) { + var r = this, a = r._private, n = r.mutableElements(), i = function(E) { + return r.getElementById(E.id()); + }; + if (S(e)) { + if (r.startBatch(), e.elements) { + var s = {}, o = function(E, M) { + for (var L = [], w = [], k = 0; k < E.length; k++) { + var D = E[k]; + if (!D.data.id) { + vt("cy.json() cannot handle elements without an ID attribute"); + continue; + } + var F = "" + D.data.id, G = r.getElementById(F); + s[F] = !0, G.length !== 0 ? w.push({ + ele: G, + json: D + }) : (M && (D.group = M), L.push(D)); + } + r.add(L); + for (var N = 0; N < w.length; N++) { + var X = w[N], B = X.ele, re = X.json; + B.json(re); + } + }; + if (te(e.elements)) + o(e.elements); + else + for (var u = ["nodes", "edges"], l = 0; l < u.length; l++) { + var f = u[l], h = e.elements[f]; + te(h) && o(h, f); + } + var v = r.collection(); + n.filter(function(b) { + return !s[b.id()]; + }).forEach(function(b) { + b.isParent() ? v.merge(b) : b.remove(); + }), v.forEach(function(b) { + return b.children().move({ + parent: null + }); + }), v.forEach(function(b) { + return i(b).remove(); + }); + } + e.style && r.style(e.style), e.zoom != null && e.zoom !== a.zoom && r.zoom(e.zoom), e.pan && (e.pan.x !== a.pan.x || e.pan.y !== a.pan.y) && r.pan(e.pan), e.data && r.data(e.data); + for (var d = ["minZoom", "maxZoom", "zoomingEnabled", "userZoomingEnabled", "panningEnabled", "userPanningEnabled", "boxSelectionEnabled", "autolock", "autoungrabify", "autounselectify", "multiClickDebounceTime"], c = 0; c < d.length; c++) { + var y = d[c]; + e[y] != null && r[y](e[y]); + } + return r.endBatch(), this; + } else { + var p = !!e, g = {}; + p ? g.elements = this.elements().map(function(b) { + return b.json(); + }) : (g.elements = {}, n.forEach(function(b) { + var E = b.group(); + g.elements[E] || (g.elements[E] = []), g.elements[E].push(b.json()); + })), this._private.styleEnabled && (g.style = r.style().json()), g.data = lr(r.data()); + var m = a.options; + return g.zoomingEnabled = a.zoomingEnabled, g.userZoomingEnabled = a.userZoomingEnabled, g.zoom = a.zoom, g.minZoom = a.minZoom, g.maxZoom = a.maxZoom, g.panningEnabled = a.panningEnabled, g.userPanningEnabled = a.userPanningEnabled, g.pan = lr(a.pan), g.boxSelectionEnabled = a.boxSelectionEnabled, g.renderer = lr(m.renderer), g.hideEdgesOnViewport = m.hideEdgesOnViewport, g.textureOnViewport = m.textureOnViewport, g.wheelSensitivity = m.wheelSensitivity, g.motionBlur = m.motionBlur, g.multiClickDebounceTime = m.multiClickDebounceTime, g; + } + } + }), _n.$id = _n.getElementById, [Ad, Rd, Yo, Ii, zn, Pd, Mi, Vn, Gd, Ur, Ka].forEach(function(t) { + He(_n, t); + }); + var Vd = { + fit: !0, + // whether to fit the viewport to the graph + directed: !1, + // whether the tree is directed downwards (or edges can point in any direction if false) + padding: 30, + // padding on fit + circle: !1, + // put depths in concentric circles if true, put depths top down if false + grid: !1, + // whether to create an even grid into which the DAG is placed (circle:false only) + spacingFactor: 1.75, + // positive spacing factor, larger => more space between nodes (N.B. n/a if causes overlap) + boundingBox: void 0, + // constrain layout bounds; { x1, y1, x2, y2 } or { x1, y1, w, h } + avoidOverlap: !0, + // prevents node overlap, may overflow boundingBox if not enough space + nodeDimensionsIncludeLabels: !1, + // Excludes the label when calculating node bounding boxes for the layout algorithm + roots: void 0, + // the roots of the trees + depthSort: void 0, + // a sorting function to order nodes at equal depth. e.g. function(a, b){ return a.data('weight') - b.data('weight') } + animate: !1, + // whether to transition the node positions + animationDuration: 500, + // duration of animation in ms if enabled + animationEasing: void 0, + // easing of animation if enabled, + animateFilter: function(e, r) { + return !0; + }, + // a function that determines whether the node should be animated. All nodes animated by default on animate enabled. Non-animated nodes are positioned immediately when the layout starts + ready: void 0, + // callback on layoutready + stop: void 0, + // callback on layoutstop + transform: function(e, r) { + return r; + } + // transform a given node position. Useful for changing flow direction in discrete layouts + }, Ud = { + maximal: !1, + // whether to shift nodes down their natural BFS depths in order to avoid upwards edges (DAGS only); setting acyclic to true sets maximal to true also + acyclic: !1 + // whether the tree is acyclic and thus a node could be shifted (due to the maximal option) multiple times without causing an infinite loop; setting to true sets maximal to true also; if you are uncertain whether a tree is acyclic, set to false to avoid potential infinite loops + }, pa = function(e) { + return e.scratch("breadthfirst"); + }, Ho = function(e, r) { + return e.scratch("breadthfirst", r); + }; + function Xo(t) { + this.options = He({}, Vd, Ud, t); + } + Xo.prototype.run = function() { + var t = this.options, e = t, r = t.cy, a = e.eles, n = a.nodes().filter(function(Ie) { + return !Ie.isParent(); + }), i = a, s = e.directed, o = e.acyclic || e.maximal || e.maximalAdjustments > 0, u = Yt(e.boundingBox ? e.boundingBox : { + x1: 0, + y1: 0, + w: r.width(), + h: r.height() + }), l; + if (pe(e.roots)) + l = e.roots; + else if (te(e.roots)) { + for (var f = [], h = 0; h < e.roots.length; h++) { + var v = e.roots[h], d = r.getElementById(v); + f.push(d); + } + l = r.collection(f); + } else if (ee(e.roots)) + l = r.$(e.roots); + else if (s) + l = n.roots(); + else { + var c = a.components(); + l = r.collection(); + for (var y = function(Me) { + var Ue = c[Me], ze = Ue.maxDegree(!1), Be = Ue.filter(function($e) { + return $e.degree(!1) === ze; + }); + l = l.add(Be); + }, p = 0; p < c.length; p++) + y(p); + } + var g = [], m = {}, b = function(Me, Ue) { + g[Ue] == null && (g[Ue] = []); + var ze = g[Ue].length; + g[Ue].push(Me), Ho(Me, { + index: ze, + depth: Ue + }); + }, E = function(Me, Ue) { + var ze = pa(Me), Be = ze.depth, $e = ze.index; + g[Be][$e] = null, b(Me, Ue); + }; + i.bfs({ + roots: l, + directed: e.directed, + visit: function(Me, Ue, ze, Be, $e) { + var rt = Me[0], je = rt.id(); + b(rt, $e), m[je] = !0; + } + }); + for (var M = [], L = 0; L < n.length; L++) { + var w = n[L]; + m[w.id()] || M.push(w); + } + var k = function(Me) { + for (var Ue = g[Me], ze = 0; ze < Ue.length; ze++) { + var Be = Ue[ze]; + if (Be == null) { + Ue.splice(ze, 1), ze--; + continue; + } + Ho(Be, { + depth: Me, + index: ze + }); + } + }, D = function() { + for (var Me = 0; Me < g.length; Me++) + k(Me); + }, F = function(Me, Ue) { + for (var ze = pa(Me), Be = Me.incomers().filter(function(O) { + return O.isNode() && a.has(O); + }), $e = -1, rt = Me.id(), je = 0; je < Be.length; je++) { + var We = Be[je], et = pa(We); + $e = Math.max($e, et.depth); + } + if (ze.depth <= $e) { + if (!e.acyclic && Ue[rt]) + return null; + var he = $e + 1; + return E(Me, he), Ue[rt] = he, !0; + } + return !1; + }; + if (s && o) { + var G = [], N = {}, X = function(Me) { + return G.push(Me); + }, B = function() { + return G.shift(); + }; + for (n.forEach(function(Ie) { + return G.push(Ie); + }); G.length > 0; ) { + var re = B(), K = F(re, N); + if (K) + re.outgoers().filter(function(Ie) { + return Ie.isNode() && a.has(Ie); + }).forEach(X); + else if (K === null) { + vt("Detected double maximal shift for node `" + re.id() + "`. Bailing maximal adjustment due to cycle. Use `options.maximal: true` only on DAGs."); + break; + } + } + } + D(); + var W = 0; + if (e.avoidOverlap) + for (var ae = 0; ae < n.length; ae++) { + var ue = n[ae], me = ue.layoutDimensions(e), ie = me.w, ge = me.h; + W = Math.max(W, ie, ge); + } + var Ee = {}, Ce = function(Me) { + if (Ee[Me.id()]) + return Ee[Me.id()]; + for (var Ue = pa(Me).depth, ze = Me.neighborhood(), Be = 0, $e = 0, rt = 0; rt < ze.length; rt++) { + var je = ze[rt]; + if (!(je.isEdge() || je.isParent() || !n.has(je))) { + var We = pa(je); + if (We != null) { + var et = We.index, he = We.depth; + if (!(et == null || he == null)) { + var O = g[he].length; + he < Ue && (Be += et / O, $e++); + } + } + } + } + return $e = Math.max(1, $e), Be = Be / $e, $e === 0 && (Be = 0), Ee[Me.id()] = Be, Be; + }, we = function(Me, Ue) { + var ze = Ce(Me), Be = Ce(Ue), $e = ze - Be; + return $e === 0 ? es(Me.id(), Ue.id()) : $e; + }; + e.depthSort !== void 0 && (we = e.depthSort); + for (var De = 0; De < g.length; De++) + g[De].sort(we), k(De); + for (var se = [], xe = 0; xe < M.length; xe++) + se.push(M[xe]); + g.unshift(se), D(); + for (var Le = 0, Se = 0; Se < g.length; Se++) + Le = Math.max(g[Se].length, Le); + var Oe = { + x: u.x1 + u.w / 2, + y: u.x1 + u.h / 2 + }, Fe = g.reduce(function(Ie, Me) { + return Math.max(Ie, Me.length); + }, 0), Xe = function(Me) { + var Ue = pa(Me), ze = Ue.depth, Be = Ue.index, $e = g[ze].length, rt = Math.max(u.w / ((e.grid ? Fe : $e) + 1), W), je = Math.max(u.h / (g.length + 1), W), We = Math.min(u.w / 2 / g.length, u.h / 2 / g.length); + if (We = Math.max(We, W), e.circle) { + var he = We * ze + We - (g.length > 0 && g[0].length <= 3 ? We / 2 : 0), O = 2 * Math.PI / g[ze].length * Be; + return ze === 0 && g[0].length === 1 && (he = 1), { + x: Oe.x + he * Math.cos(O), + y: Oe.y + he * Math.sin(O) + }; + } else { + var et = { + x: Oe.x + (Be + 1 - ($e + 1) / 2) * rt, + y: (ze + 1) * je + }; + return et; + } + }; + return a.nodes().layoutPositions(this, e, Xe), this; + }; + var $d = { + fit: !0, + // whether to fit the viewport to the graph + padding: 30, + // the padding on fit + boundingBox: void 0, + // constrain layout bounds; { x1, y1, x2, y2 } or { x1, y1, w, h } + avoidOverlap: !0, + // prevents node overlap, may overflow boundingBox and radius if not enough space + nodeDimensionsIncludeLabels: !1, + // Excludes the label when calculating node bounding boxes for the layout algorithm + spacingFactor: void 0, + // Applies a multiplicative factor (>0) to expand or compress the overall area that the nodes take up + radius: void 0, + // the radius of the circle + startAngle: 3 / 2 * Math.PI, + // where nodes start in radians + sweep: void 0, + // how many radians should be between the first and last node (defaults to full circle) + clockwise: !0, + // whether the layout should go clockwise (true) or counterclockwise/anticlockwise (false) + sort: void 0, + // a sorting function to order the nodes; e.g. function(a, b){ return a.data('weight') - b.data('weight') } + animate: !1, + // whether to transition the node positions + animationDuration: 500, + // duration of animation in ms if enabled + animationEasing: void 0, + // easing of animation if enabled + animateFilter: function(e, r) { + return !0; + }, + // a function that determines whether the node should be animated. All nodes animated by default on animate enabled. Non-animated nodes are positioned immediately when the layout starts + ready: void 0, + // callback on layoutready + stop: void 0, + // callback on layoutstop + transform: function(e, r) { + return r; + } + // transform a given node position. Useful for changing flow direction in discrete layouts + }; + function Wo(t) { + this.options = He({}, $d, t); + } + Wo.prototype.run = function() { + var t = this.options, e = t, r = t.cy, a = e.eles, n = e.counterclockwise !== void 0 ? !e.counterclockwise : e.clockwise, i = a.nodes().not(":parent"); + e.sort && (i = i.sort(e.sort)); + for (var s = Yt(e.boundingBox ? e.boundingBox : { + x1: 0, + y1: 0, + w: r.width(), + h: r.height() + }), o = { + x: s.x1 + s.w / 2, + y: s.y1 + s.h / 2 + }, u = e.sweep === void 0 ? 2 * Math.PI - 2 * Math.PI / i.length : e.sweep, l = u / Math.max(1, i.length - 1), f, h = 0, v = 0; v < i.length; v++) { + var d = i[v], c = d.layoutDimensions(e), y = c.w, p = c.h; + h = Math.max(h, y, p); + } + if (R(e.radius) ? f = e.radius : i.length <= 1 ? f = 0 : f = Math.min(s.h, s.w) / 2 - h, i.length > 1 && e.avoidOverlap) { + h *= 1.75; + var g = Math.cos(l) - Math.cos(0), m = Math.sin(l) - Math.sin(0), b = Math.sqrt(h * h / (g * g + m * m)); + f = Math.max(b, f); + } + var E = function(L, w) { + var k = e.startAngle + w * l * (n ? 1 : -1), D = f * Math.cos(k), F = f * Math.sin(k), G = { + x: o.x + D, + y: o.y + F + }; + return G; + }; + return a.nodes().layoutPositions(this, e, E), this; + }; + var _d = { + fit: !0, + // whether to fit the viewport to the graph + padding: 30, + // the padding on fit + startAngle: 3 / 2 * Math.PI, + // where nodes start in radians + sweep: void 0, + // how many radians should be between the first and last node (defaults to full circle) + clockwise: !0, + // whether the layout should go clockwise (true) or counterclockwise/anticlockwise (false) + equidistant: !1, + // whether levels have an equal radial distance betwen them, may cause bounding box overflow + minNodeSpacing: 10, + // min spacing between outside of nodes (used for radius adjustment) + boundingBox: void 0, + // constrain layout bounds; { x1, y1, x2, y2 } or { x1, y1, w, h } + avoidOverlap: !0, + // prevents node overlap, may overflow boundingBox if not enough space + nodeDimensionsIncludeLabels: !1, + // Excludes the label when calculating node bounding boxes for the layout algorithm + height: void 0, + // height of layout area (overrides container height) + width: void 0, + // width of layout area (overrides container width) + spacingFactor: void 0, + // Applies a multiplicative factor (>0) to expand or compress the overall area that the nodes take up + concentric: function(e) { + return e.degree(); + }, + levelWidth: function(e) { + return e.maxDegree() / 4; + }, + animate: !1, + // whether to transition the node positions + animationDuration: 500, + // duration of animation in ms if enabled + animationEasing: void 0, + // easing of animation if enabled + animateFilter: function(e, r) { + return !0; + }, + // a function that determines whether the node should be animated. All nodes animated by default on animate enabled. Non-animated nodes are positioned immediately when the layout starts + ready: void 0, + // callback on layoutready + stop: void 0, + // callback on layoutstop + transform: function(e, r) { + return r; + } + // transform a given node position. Useful for changing flow direction in discrete layouts + }; + function qo(t) { + this.options = He({}, _d, t); + } + qo.prototype.run = function() { + for (var t = this.options, e = t, r = e.counterclockwise !== void 0 ? !e.counterclockwise : e.clockwise, a = t.cy, n = e.eles, i = n.nodes().not(":parent"), s = Yt(e.boundingBox ? e.boundingBox : { + x1: 0, + y1: 0, + w: a.width(), + h: a.height() + }), o = { + x: s.x1 + s.w / 2, + y: s.y1 + s.h / 2 + }, u = [], l = 0, f = 0; f < i.length; f++) { + var h = i[f], v = void 0; + v = e.concentric(h), u.push({ + value: v, + node: h + }), h._private.scratch.concentric = v; + } + i.updateStyle(); + for (var d = 0; d < i.length; d++) { + var c = i[d], y = c.layoutDimensions(e); + l = Math.max(l, y.w, y.h); + } + u.sort(function(Ie, Me) { + return Me.value - Ie.value; + }); + for (var p = e.levelWidth(i), g = [[]], m = g[0], b = 0; b < u.length; b++) { + var E = u[b]; + if (m.length > 0) { + var M = Math.abs(m[0].value - E.value); + M >= p && (m = [], g.push(m)); + } + m.push(E); + } + var L = l + e.minNodeSpacing; + if (!e.avoidOverlap) { + var w = g.length > 0 && g[0].length > 1, k = Math.min(s.w, s.h) / 2 - L, D = k / (g.length + w ? 1 : 0); + L = Math.min(L, D); + } + for (var F = 0, G = 0; G < g.length; G++) { + var N = g[G], X = e.sweep === void 0 ? 2 * Math.PI - 2 * Math.PI / N.length : e.sweep, B = N.dTheta = X / Math.max(1, N.length - 1); + if (N.length > 1 && e.avoidOverlap) { + var re = Math.cos(B) - Math.cos(0), K = Math.sin(B) - Math.sin(0), W = Math.sqrt(L * L / (re * re + K * K)); + F = Math.max(W, F); + } + N.r = F, F += L; + } + if (e.equidistant) { + for (var ae = 0, ue = 0, me = 0; me < g.length; me++) { + var ie = g[me], ge = ie.r - ue; + ae = Math.max(ae, ge); + } + ue = 0; + for (var Ee = 0; Ee < g.length; Ee++) { + var Ce = g[Ee]; + Ee === 0 && (ue = Ce.r), Ce.r = ue, ue += ae; + } + } + for (var we = {}, De = 0; De < g.length; De++) + for (var se = g[De], xe = se.dTheta, Le = se.r, Se = 0; Se < se.length; Se++) { + var Oe = se[Se], Fe = e.startAngle + (r ? 1 : -1) * xe * Se, Xe = { + x: o.x + Le * Math.cos(Fe), + y: o.y + Le * Math.sin(Fe) + }; + we[Oe.node.id()] = Xe; + } + return n.nodes().layoutPositions(this, e, function(Ie) { + var Me = Ie.id(); + return we[Me]; + }), this; + }; + var Pi, Yd = { + // Called on `layoutready` + ready: function() { + }, + // Called on `layoutstop` + stop: function() { + }, + // Whether to animate while running the layout + // true : Animate continuously as the layout is running + // false : Just show the end result + // 'end' : Animate with the end result, from the initial positions to the end positions + animate: !0, + // Easing of the animation for animate:'end' + animationEasing: void 0, + // The duration of the animation for animate:'end' + animationDuration: void 0, + // A function that determines whether the node should be animated + // All nodes animated by default on animate enabled + // Non-animated nodes are positioned immediately when the layout starts + animateFilter: function(e, r) { + return !0; + }, + // The layout animates only after this many milliseconds for animate:true + // (prevents flashing on fast runs) + animationThreshold: 250, + // Number of iterations between consecutive screen positions update + refresh: 20, + // Whether to fit the network view after when done + fit: !0, + // Padding on fit + padding: 30, + // Constrain layout bounds; { x1, y1, x2, y2 } or { x1, y1, w, h } + boundingBox: void 0, + // Excludes the label when calculating node bounding boxes for the layout algorithm + nodeDimensionsIncludeLabels: !1, + // Randomize the initial positions of the nodes (true) or use existing positions (false) + randomize: !1, + // Extra spacing between components in non-compound graphs + componentSpacing: 40, + // Node repulsion (non overlapping) multiplier + nodeRepulsion: function(e) { + return 2048; + }, + // Node repulsion (overlapping) multiplier + nodeOverlap: 4, + // Ideal edge (non nested) length + idealEdgeLength: function(e) { + return 32; + }, + // Divisor to compute edge forces + edgeElasticity: function(e) { + return 32; + }, + // Nesting factor (multiplier) to compute ideal edge length for nested edges + nestingFactor: 1.2, + // Gravity force (constant) + gravity: 1, + // Maximum number of iterations to perform + numIter: 1e3, + // Initial temperature (maximum node displacement) + initialTemp: 1e3, + // Cooling factor (how the temperature is reduced between consecutive iterations + coolingFactor: 0.99, + // Lower temperature threshold (below this point the layout will end) + minTemp: 1 + }; + function Yn(t) { + this.options = He({}, Yd, t), this.options.layout = this; + var e = this.options.eles.nodes(), r = this.options.eles.edges(), a = r.filter(function(n) { + var i = n.source().data("id"), s = n.target().data("id"), o = e.some(function(l) { + return l.data("id") === i; + }), u = e.some(function(l) { + return l.data("id") === s; + }); + return !o || !u; + }); + this.options.eles = this.options.eles.not(a); + } + Yn.prototype.run = function() { + var t = this.options, e = t.cy, r = this; + r.stopped = !1, (t.animate === !0 || t.animate === !1) && r.emit({ + type: "layoutstart", + layout: r + }), t.debug === !0 ? Pi = !0 : Pi = !1; + var a = Hd(e, r, t); + Pi && qd(a), t.randomize && Kd(a); + var n = gr(), i = function() { + Zd(a, e, t), t.fit === !0 && e.fit(t.padding); + }, s = function(v) { + return !(r.stopped || v >= t.numIter || (Qd(a, t), a.temperature = a.temperature * t.coolingFactor, a.temperature < t.minTemp)); + }, o = function() { + if (t.animate === !0 || t.animate === !1) + i(), r.one("layoutstop", t.stop), r.emit({ + type: "layoutstop", + layout: r + }); + else { + var v = t.eles.nodes(), d = Ko(a, t, v); + v.layoutPositions(r, t, d); + } + }, u = 0, l = !0; + if (t.animate === !0) { + var f = function h() { + for (var v = 0; l && v < t.refresh; ) + l = s(u), u++, v++; + if (!l) + Qo(a, t), o(); + else { + var d = gr(); + d - n >= t.animationThreshold && i(), ln(h); + } + }; + f(); + } else { + for (; l; ) + l = s(u), u++; + Qo(a, t), o(); + } + return this; + }, Yn.prototype.stop = function() { + return this.stopped = !0, this.thread && this.thread.stop(), this.emit("layoutstop"), this; + }, Yn.prototype.destroy = function() { + return this.thread && this.thread.stop(), this; + }; + var Hd = function(e, r, a) { + for (var n = a.eles.edges(), i = a.eles.nodes(), s = Yt(a.boundingBox ? a.boundingBox : { + x1: 0, + y1: 0, + w: e.width(), + h: e.height() + }), o = { + isCompound: e.hasCompoundNodes(), + layoutNodes: [], + idToIndex: {}, + nodeSize: i.size(), + graphSet: [], + indexToGraph: [], + layoutEdges: [], + edgeSize: n.size(), + temperature: a.initialTemp, + clientWidth: s.w, + clientHeight: s.h, + boundingBox: s + }, u = a.eles.components(), l = {}, f = 0; f < u.length; f++) + for (var h = u[f], v = 0; v < h.length; v++) { + var d = h[v]; + l[d.id()] = f; + } + for (var f = 0; f < o.nodeSize; f++) { + var c = i[f], y = c.layoutDimensions(a), p = {}; + p.isLocked = c.locked(), p.id = c.data("id"), p.parentId = c.data("parent"), p.cmptId = l[c.id()], p.children = [], p.positionX = c.position("x"), p.positionY = c.position("y"), p.offsetX = 0, p.offsetY = 0, p.height = y.w, p.width = y.h, p.maxX = p.positionX + p.width / 2, p.minX = p.positionX - p.width / 2, p.maxY = p.positionY + p.height / 2, p.minY = p.positionY - p.height / 2, p.padLeft = parseFloat(c.style("padding")), p.padRight = parseFloat(c.style("padding")), p.padTop = parseFloat(c.style("padding")), p.padBottom = parseFloat(c.style("padding")), p.nodeRepulsion = H(a.nodeRepulsion) ? a.nodeRepulsion(c) : a.nodeRepulsion, o.layoutNodes.push(p), o.idToIndex[p.id] = f; + } + for (var g = [], m = 0, b = -1, E = [], f = 0; f < o.nodeSize; f++) { + var c = o.layoutNodes[f], M = c.parentId; + M != null ? o.layoutNodes[o.idToIndex[M]].children.push(c.id) : (g[++b] = c.id, E.push(c.id)); + } + for (o.graphSet.push(E); m <= b; ) { + var L = g[m++], w = o.idToIndex[L], d = o.layoutNodes[w], k = d.children; + if (k.length > 0) { + o.graphSet.push(k); + for (var f = 0; f < k.length; f++) + g[++b] = k[f]; + } + } + for (var f = 0; f < o.graphSet.length; f++) + for (var D = o.graphSet[f], v = 0; v < D.length; v++) { + var F = o.idToIndex[D[v]]; + o.indexToGraph[F] = f; + } + for (var f = 0; f < o.edgeSize; f++) { + var G = n[f], N = {}; + N.id = G.data("id"), N.sourceId = G.data("source"), N.targetId = G.data("target"); + var X = H(a.idealEdgeLength) ? a.idealEdgeLength(G) : a.idealEdgeLength, B = H(a.edgeElasticity) ? a.edgeElasticity(G) : a.edgeElasticity, re = o.idToIndex[N.sourceId], K = o.idToIndex[N.targetId], W = o.indexToGraph[re], ae = o.indexToGraph[K]; + if (W != ae) { + for (var ue = Xd(N.sourceId, N.targetId, o), me = o.graphSet[ue], ie = 0, p = o.layoutNodes[re]; me.indexOf(p.id) === -1; ) + p = o.layoutNodes[o.idToIndex[p.parentId]], ie++; + for (p = o.layoutNodes[K]; me.indexOf(p.id) === -1; ) + p = o.layoutNodes[o.idToIndex[p.parentId]], ie++; + X *= ie * a.nestingFactor; + } + N.idealLength = X, N.elasticity = B, o.layoutEdges.push(N); + } + return o; + }, Xd = function(e, r, a) { + var n = Wd(e, r, 0, a); + return 2 > n.count ? 0 : n.graph; + }, Wd = function t(e, r, a, n) { + var i = n.graphSet[a]; + if (-1 < i.indexOf(e) && -1 < i.indexOf(r)) + return { + count: 2, + graph: a + }; + for (var s = 0, o = 0; o < i.length; o++) { + var u = i[o], l = n.idToIndex[u], f = n.layoutNodes[l].children; + if (f.length !== 0) { + var h = n.indexToGraph[n.idToIndex[f[0]]], v = t(e, r, h, n); + if (v.count !== 0) + if (v.count === 1) { + if (s++, s === 2) + break; + } else + return v; + } + } + return { + count: s, + graph: a + }; + }, qd, Kd = function(e, r) { + for (var a = e.clientWidth, n = e.clientHeight, i = 0; i < e.nodeSize; i++) { + var s = e.layoutNodes[i]; + s.children.length === 0 && !s.isLocked && (s.positionX = Math.random() * a, s.positionY = Math.random() * n); + } + }, Ko = function(e, r, a) { + var n = e.boundingBox, i = { + x1: 1 / 0, + x2: -1 / 0, + y1: 1 / 0, + y2: -1 / 0 + }; + return r.boundingBox && (a.forEach(function(s) { + var o = e.layoutNodes[e.idToIndex[s.data("id")]]; + i.x1 = Math.min(i.x1, o.positionX), i.x2 = Math.max(i.x2, o.positionX), i.y1 = Math.min(i.y1, o.positionY), i.y2 = Math.max(i.y2, o.positionY); + }), i.w = i.x2 - i.x1, i.h = i.y2 - i.y1), function(s, o) { + var u = e.layoutNodes[e.idToIndex[s.data("id")]]; + if (r.boundingBox) { + var l = (u.positionX - i.x1) / i.w, f = (u.positionY - i.y1) / i.h; + return { + x: n.x1 + l * n.w, + y: n.y1 + f * n.h + }; + } else + return { + x: u.positionX, + y: u.positionY + }; + }; + }, Zd = function(e, r, a) { + var n = a.layout, i = a.eles.nodes(), s = Ko(e, a, i); + i.positions(s), e.ready !== !0 && (e.ready = !0, n.one("layoutready", a.ready), n.emit({ + type: "layoutready", + layout: this + })); + }, Qd = function(e, r, a) { + Jd(e, r), tg(e), rg(e, r), ag(e), ng(e); + }, Jd = function(e, r) { + for (var a = 0; a < e.graphSet.length; a++) + for (var n = e.graphSet[a], i = n.length, s = 0; s < i; s++) + for (var o = e.layoutNodes[e.idToIndex[n[s]]], u = s + 1; u < i; u++) { + var l = e.layoutNodes[e.idToIndex[n[u]]]; + jd(o, l, e, r); + } + }, Zo = function(e) { + return -e + 2 * e * Math.random(); + }, jd = function(e, r, a, n) { + var i = e.cmptId, s = r.cmptId; + if (!(i !== s && !a.isCompound)) { + var o = r.positionX - e.positionX, u = r.positionY - e.positionY, l = 1; + o === 0 && u === 0 && (o = Zo(l), u = Zo(l)); + var f = eg(e, r, o, u); + if (f > 0) + var h = n.nodeOverlap * f, v = Math.sqrt(o * o + u * u), d = h * o / v, c = h * u / v; + else + var y = Hn(e, o, u), p = Hn(r, -1 * o, -1 * u), g = p.x - y.x, m = p.y - y.y, b = g * g + m * m, v = Math.sqrt(b), h = (e.nodeRepulsion + r.nodeRepulsion) / b, d = h * g / v, c = h * m / v; + e.isLocked || (e.offsetX -= d, e.offsetY -= c), r.isLocked || (r.offsetX += d, r.offsetY += c); + } + }, eg = function(e, r, a, n) { + if (a > 0) + var i = e.maxX - r.minX; + else + var i = r.maxX - e.minX; + if (n > 0) + var s = e.maxY - r.minY; + else + var s = r.maxY - e.minY; + return i >= 0 && s >= 0 ? Math.sqrt(i * i + s * s) : 0; + }, Hn = function(e, r, a) { + var n = e.positionX, i = e.positionY, s = e.height || 1, o = e.width || 1, u = a / r, l = s / o, f = {}; + return r === 0 && 0 < a || r === 0 && 0 > a ? (f.x = n, f.y = i + s / 2, f) : 0 < r && -1 * l <= u && u <= l ? (f.x = n + o / 2, f.y = i + o * a / 2 / r, f) : 0 > r && -1 * l <= u && u <= l ? (f.x = n - o / 2, f.y = i - o * a / 2 / r, f) : 0 < a && (u <= -1 * l || u >= l) ? (f.x = n + s * r / 2 / a, f.y = i + s / 2, f) : (0 > a && (u <= -1 * l || u >= l) && (f.x = n - s * r / 2 / a, f.y = i - s / 2), f); + }, tg = function(e, r) { + for (var a = 0; a < e.edgeSize; a++) { + var n = e.layoutEdges[a], i = e.idToIndex[n.sourceId], s = e.layoutNodes[i], o = e.idToIndex[n.targetId], u = e.layoutNodes[o], l = u.positionX - s.positionX, f = u.positionY - s.positionY; + if (!(l === 0 && f === 0)) { + var h = Hn(s, l, f), v = Hn(u, -1 * l, -1 * f), d = v.x - h.x, c = v.y - h.y, y = Math.sqrt(d * d + c * c), p = Math.pow(n.idealLength - y, 2) / n.elasticity; + if (y !== 0) + var g = p * d / y, m = p * c / y; + else + var g = 0, m = 0; + s.isLocked || (s.offsetX += g, s.offsetY += m), u.isLocked || (u.offsetX -= g, u.offsetY -= m); + } + } + }, rg = function(e, r) { + if (r.gravity !== 0) + for (var a = 1, n = 0; n < e.graphSet.length; n++) { + var i = e.graphSet[n], s = i.length; + if (n === 0) + var o = e.clientHeight / 2, u = e.clientWidth / 2; + else + var l = e.layoutNodes[e.idToIndex[i[0]]], f = e.layoutNodes[e.idToIndex[l.parentId]], o = f.positionX, u = f.positionY; + for (var h = 0; h < s; h++) { + var v = e.layoutNodes[e.idToIndex[i[h]]]; + if (!v.isLocked) { + var d = o - v.positionX, c = u - v.positionY, y = Math.sqrt(d * d + c * c); + if (y > a) { + var p = r.gravity * d / y, g = r.gravity * c / y; + v.offsetX += p, v.offsetY += g; + } + } + } + } + }, ag = function(e, r) { + var a = [], n = 0, i = -1; + for (a.push.apply(a, e.graphSet[0]), i += e.graphSet[0].length; n <= i; ) { + var s = a[n++], o = e.idToIndex[s], u = e.layoutNodes[o], l = u.children; + if (0 < l.length && !u.isLocked) { + for (var f = u.offsetX, h = u.offsetY, v = 0; v < l.length; v++) { + var d = e.layoutNodes[e.idToIndex[l[v]]]; + d.offsetX += f, d.offsetY += h, a[++i] = l[v]; + } + u.offsetX = 0, u.offsetY = 0; + } + } + }, ng = function(e, r) { + for (var a = 0; a < e.nodeSize; a++) { + var n = e.layoutNodes[a]; + 0 < n.children.length && (n.maxX = void 0, n.minX = void 0, n.maxY = void 0, n.minY = void 0); + } + for (var a = 0; a < e.nodeSize; a++) { + var n = e.layoutNodes[a]; + if (!(0 < n.children.length || n.isLocked)) { + var i = ig(n.offsetX, n.offsetY, e.temperature); + n.positionX += i.x, n.positionY += i.y, n.offsetX = 0, n.offsetY = 0, n.minX = n.positionX - n.width, n.maxX = n.positionX + n.width, n.minY = n.positionY - n.height, n.maxY = n.positionY + n.height, sg(n, e); + } + } + for (var a = 0; a < e.nodeSize; a++) { + var n = e.layoutNodes[a]; + 0 < n.children.length && !n.isLocked && (n.positionX = (n.maxX + n.minX) / 2, n.positionY = (n.maxY + n.minY) / 2, n.width = n.maxX - n.minX, n.height = n.maxY - n.minY); + } + }, ig = function(e, r, a) { + var n = Math.sqrt(e * e + r * r); + if (n > a) + var i = { + x: a * e / n, + y: a * r / n + }; + else + var i = { + x: e, + y: r + }; + return i; + }, sg = function t(e, r) { + var a = e.parentId; + if (a != null) { + var n = r.layoutNodes[r.idToIndex[a]], i = !1; + if ((n.maxX == null || e.maxX + n.padRight > n.maxX) && (n.maxX = e.maxX + n.padRight, i = !0), (n.minX == null || e.minX - n.padLeft < n.minX) && (n.minX = e.minX - n.padLeft, i = !0), (n.maxY == null || e.maxY + n.padBottom > n.maxY) && (n.maxY = e.maxY + n.padBottom, i = !0), (n.minY == null || e.minY - n.padTop < n.minY) && (n.minY = e.minY - n.padTop, i = !0), i) + return t(n, r); + } + }, Qo = function(e, r) { + for (var a = e.layoutNodes, n = [], i = 0; i < a.length; i++) { + var s = a[i], o = s.cmptId, u = n[o] = n[o] || []; + u.push(s); + } + for (var l = 0, i = 0; i < n.length; i++) { + var f = n[i]; + if (f) { + f.x1 = 1 / 0, f.x2 = -1 / 0, f.y1 = 1 / 0, f.y2 = -1 / 0; + for (var h = 0; h < f.length; h++) { + var v = f[h]; + f.x1 = Math.min(f.x1, v.positionX - v.width / 2), f.x2 = Math.max(f.x2, v.positionX + v.width / 2), f.y1 = Math.min(f.y1, v.positionY - v.height / 2), f.y2 = Math.max(f.y2, v.positionY + v.height / 2); + } + f.w = f.x2 - f.x1, f.h = f.y2 - f.y1, l += f.w * f.h; + } + } + n.sort(function(m, b) { + return b.w * b.h - m.w * m.h; + }); + for (var d = 0, c = 0, y = 0, p = 0, g = Math.sqrt(l) * e.clientWidth / e.clientHeight, i = 0; i < n.length; i++) { + var f = n[i]; + if (f) { + for (var h = 0; h < f.length; h++) { + var v = f[h]; + v.isLocked || (v.positionX += d - f.x1, v.positionY += c - f.y1); + } + d += f.w + r.componentSpacing, y += f.w + r.componentSpacing, p = Math.max(p, f.h), y > g && (c += p + r.componentSpacing, d = 0, y = 0, p = 0); + } + } + }, og = { + fit: !0, + // whether to fit the viewport to the graph + padding: 30, + // padding used on fit + boundingBox: void 0, + // constrain layout bounds; { x1, y1, x2, y2 } or { x1, y1, w, h } + avoidOverlap: !0, + // prevents node overlap, may overflow boundingBox if not enough space + avoidOverlapPadding: 10, + // extra spacing around nodes when avoidOverlap: true + nodeDimensionsIncludeLabels: !1, + // Excludes the label when calculating node bounding boxes for the layout algorithm + spacingFactor: void 0, + // Applies a multiplicative factor (>0) to expand or compress the overall area that the nodes take up + condense: !1, + // uses all available space on false, uses minimal space on true + rows: void 0, + // force num of rows in the grid + cols: void 0, + // force num of columns in the grid + position: function(e) { + }, + // returns { row, col } for element + sort: void 0, + // a sorting function to order the nodes; e.g. function(a, b){ return a.data('weight') - b.data('weight') } + animate: !1, + // whether to transition the node positions + animationDuration: 500, + // duration of animation in ms if enabled + animationEasing: void 0, + // easing of animation if enabled + animateFilter: function(e, r) { + return !0; + }, + // a function that determines whether the node should be animated. All nodes animated by default on animate enabled. Non-animated nodes are positioned immediately when the layout starts + ready: void 0, + // callback on layoutready + stop: void 0, + // callback on layoutstop + transform: function(e, r) { + return r; + } + // transform a given node position. Useful for changing flow direction in discrete layouts + }; + function Jo(t) { + this.options = He({}, og, t); + } + Jo.prototype.run = function() { + var t = this.options, e = t, r = t.cy, a = e.eles, n = a.nodes().not(":parent"); + e.sort && (n = n.sort(e.sort)); + var i = Yt(e.boundingBox ? e.boundingBox : { + x1: 0, + y1: 0, + w: r.width(), + h: r.height() + }); + if (i.h === 0 || i.w === 0) + a.nodes().layoutPositions(this, e, function(Ee) { + return { + x: i.x1, + y: i.y1 + }; + }); + else { + var s = n.size(), o = Math.sqrt(s * i.h / i.w), u = Math.round(o), l = Math.round(i.w / i.h * o), f = function(Ce) { + if (Ce == null) + return Math.min(u, l); + var we = Math.min(u, l); + we == u ? u = Ce : l = Ce; + }, h = function(Ce) { + if (Ce == null) + return Math.max(u, l); + var we = Math.max(u, l); + we == u ? u = Ce : l = Ce; + }, v = e.rows, d = e.cols != null ? e.cols : e.columns; + if (v != null && d != null) + u = v, l = d; + else if (v != null && d == null) + u = v, l = Math.ceil(s / u); + else if (v == null && d != null) + l = d, u = Math.ceil(s / l); + else if (l * u > s) { + var c = f(), y = h(); + (c - 1) * y >= s ? f(c - 1) : (y - 1) * c >= s && h(y - 1); + } else + for (; l * u < s; ) { + var p = f(), g = h(); + (g + 1) * p >= s ? h(g + 1) : f(p + 1); + } + var m = i.w / l, b = i.h / u; + if (e.condense && (m = 0, b = 0), e.avoidOverlap) + for (var E = 0; E < n.length; E++) { + var M = n[E], L = M._private.position; + (L.x == null || L.y == null) && (L.x = 0, L.y = 0); + var w = M.layoutDimensions(e), k = e.avoidOverlapPadding, D = w.w + k, F = w.h + k; + m = Math.max(m, D), b = Math.max(b, F); + } + for (var G = {}, N = function(Ce, we) { + return !!G["c-" + Ce + "-" + we]; + }, X = function(Ce, we) { + G["c-" + Ce + "-" + we] = !0; + }, B = 0, re = 0, K = function() { + re++, re >= l && (re = 0, B++); + }, W = {}, ae = 0; ae < n.length; ae++) { + var ue = n[ae], me = e.position(ue); + if (me && (me.row !== void 0 || me.col !== void 0)) { + var ie = { + row: me.row, + col: me.col + }; + if (ie.col === void 0) + for (ie.col = 0; N(ie.row, ie.col); ) + ie.col++; + else if (ie.row === void 0) + for (ie.row = 0; N(ie.row, ie.col); ) + ie.row++; + W[ue.id()] = ie, X(ie.row, ie.col); + } + } + var ge = function(Ce, we) { + var De, se; + if (Ce.locked() || Ce.isParent()) + return !1; + var xe = W[Ce.id()]; + if (xe) + De = xe.col * m + m / 2 + i.x1, se = xe.row * b + b / 2 + i.y1; + else { + for (; N(B, re); ) + K(); + De = re * m + m / 2 + i.x1, se = B * b + b / 2 + i.y1, X(B, re), K(); + } + return { + x: De, + y: se + }; + }; + n.layoutPositions(this, e, ge); + } + return this; + }; + var lg = { + ready: function() { + }, + // on layoutready + stop: function() { + } + // on layoutstop + }; + function Bi(t) { + this.options = He({}, lg, t); + } + Bi.prototype.run = function() { + var t = this.options, e = t.eles, r = this; + return t.cy, r.emit("layoutstart"), e.nodes().positions(function() { + return { + x: 0, + y: 0 + }; + }), r.one("layoutready", t.ready), r.emit("layoutready"), r.one("layoutstop", t.stop), r.emit("layoutstop"), this; + }, Bi.prototype.stop = function() { + return this; + }; + var ug = { + positions: void 0, + // map of (node id) => (position obj); or function(node){ return somPos; } + zoom: void 0, + // the zoom level to set (prob want fit = false if set) + pan: void 0, + // the pan level to set (prob want fit = false if set) + fit: !0, + // whether to fit to viewport + padding: 30, + // padding on fit + spacingFactor: void 0, + // Applies a multiplicative factor (>0) to expand or compress the overall area that the nodes take up + animate: !1, + // whether to transition the node positions + animationDuration: 500, + // duration of animation in ms if enabled + animationEasing: void 0, + // easing of animation if enabled + animateFilter: function(e, r) { + return !0; + }, + // a function that determines whether the node should be animated. All nodes animated by default on animate enabled. Non-animated nodes are positioned immediately when the layout starts + ready: void 0, + // callback on layoutready + stop: void 0, + // callback on layoutstop + transform: function(e, r) { + return r; + } + // transform a given node position. Useful for changing flow direction in discrete layouts + }; + function jo(t) { + this.options = He({}, ug, t); + } + jo.prototype.run = function() { + var t = this.options, e = t.eles, r = e.nodes(), a = H(t.positions); + function n(i) { + if (t.positions == null) + return cf(i.position()); + if (a) + return t.positions(i); + var s = t.positions[i._private.data.id]; + return s ?? null; + } + return r.layoutPositions(this, t, function(i, s) { + var o = n(i); + return i.locked() || o == null ? !1 : o; + }), this; + }; + var fg = { + fit: !0, + // whether to fit to viewport + padding: 30, + // fit padding + boundingBox: void 0, + // constrain layout bounds; { x1, y1, x2, y2 } or { x1, y1, w, h } + animate: !1, + // whether to transition the node positions + animationDuration: 500, + // duration of animation in ms if enabled + animationEasing: void 0, + // easing of animation if enabled + animateFilter: function(e, r) { + return !0; + }, + // a function that determines whether the node should be animated. All nodes animated by default on animate enabled. Non-animated nodes are positioned immediately when the layout starts + ready: void 0, + // callback on layoutready + stop: void 0, + // callback on layoutstop + transform: function(e, r) { + return r; + } + // transform a given node position. Useful for changing flow direction in discrete layouts + }; + function el(t) { + this.options = He({}, fg, t); + } + el.prototype.run = function() { + var t = this.options, e = t.cy, r = t.eles, a = Yt(t.boundingBox ? t.boundingBox : { + x1: 0, + y1: 0, + w: e.width(), + h: e.height() + }), n = function(s, o) { + return { + x: a.x1 + Math.round(Math.random() * a.w), + y: a.y1 + Math.round(Math.random() * a.h) + }; + }; + return r.nodes().layoutPositions(this, t, n), this; + }; + var hg = [{ + name: "breadthfirst", + impl: Xo + }, { + name: "circle", + impl: Wo + }, { + name: "concentric", + impl: qo + }, { + name: "cose", + impl: Yn + }, { + name: "grid", + impl: Jo + }, { + name: "null", + impl: Bi + }, { + name: "preset", + impl: jo + }, { + name: "random", + impl: el + }]; + function tl(t) { + this.options = t, this.notifications = 0; + } + var rl = function() { + }, al = function() { + throw new Error("A headless instance can not render images"); + }; + tl.prototype = { + recalculateRenderedStyle: rl, + notify: function() { + this.notifications++; + }, + init: rl, + isHeadless: function() { + return !0; + }, + png: al, + jpg: al + }; + var Fi = {}; + Fi.arrowShapeWidth = 0.3, Fi.registerArrowShapes = function() { + var t = this.arrowShapes = {}, e = this, r = function(l, f, h, v, d, c, y) { + var p = d.x - h / 2 - y, g = d.x + h / 2 + y, m = d.y - h / 2 - y, b = d.y + h / 2 + y, E = p <= l && l <= g && m <= f && f <= b; + return E; + }, a = function(l, f, h, v, d) { + var c = l * Math.cos(v) - f * Math.sin(v), y = l * Math.sin(v) + f * Math.cos(v), p = c * h, g = y * h, m = p + d.x, b = g + d.y; + return { + x: m, + y: b + }; + }, n = function(l, f, h, v) { + for (var d = [], c = 0; c < l.length; c += 2) { + var y = l[c], p = l[c + 1]; + d.push(a(y, p, f, h, v)); + } + return d; + }, i = function(l) { + for (var f = [], h = 0; h < l.length; h++) { + var v = l[h]; + f.push(v.x, v.y); + } + return f; + }, s = function(l) { + return l.pstyle("width").pfValue * l.pstyle("arrow-scale").pfValue * 2; + }, o = function(l, f) { + ee(f) && (f = t[f]), t[l] = He({ + name: l, + points: [-0.15, -0.3, 0.15, -0.3, 0.15, 0.3, -0.15, 0.3], + collide: function(v, d, c, y, p, g) { + var m = i(n(this.points, c + 2 * g, y, p)), b = Ht(v, d, m); + return b; + }, + roughCollide: r, + draw: function(v, d, c, y) { + var p = n(this.points, d, c, y); + e.arrowShapeImpl("polygon")(v, p); + }, + spacing: function(v) { + return 0; + }, + gap: s + }, f); + }; + o("none", { + collide: fn, + roughCollide: fn, + draw: si, + spacing: ds, + gap: ds + }), o("triangle", { + points: [-0.15, -0.3, 0, 0, 0.15, -0.3] + }), o("arrow", "triangle"), o("triangle-backcurve", { + points: t.triangle.points, + controlPoint: [0, -0.15], + roughCollide: r, + draw: function(l, f, h, v, d) { + var c = n(this.points, f, h, v), y = this.controlPoint, p = a(y[0], y[1], f, h, v); + e.arrowShapeImpl(this.name)(l, c, p); + }, + gap: function(l) { + return s(l) * 0.8; + } + }), o("triangle-tee", { + points: [0, 0, 0.15, -0.3, -0.15, -0.3, 0, 0], + pointsTee: [-0.15, -0.4, -0.15, -0.5, 0.15, -0.5, 0.15, -0.4], + collide: function(l, f, h, v, d, c, y) { + var p = i(n(this.points, h + 2 * y, v, d)), g = i(n(this.pointsTee, h + 2 * y, v, d)), m = Ht(l, f, p) || Ht(l, f, g); + return m; + }, + draw: function(l, f, h, v, d) { + var c = n(this.points, f, h, v), y = n(this.pointsTee, f, h, v); + e.arrowShapeImpl(this.name)(l, c, y); + } + }), o("circle-triangle", { + radius: 0.15, + pointsTr: [0, -0.15, 0.15, -0.45, -0.15, -0.45, 0, -0.15], + collide: function(l, f, h, v, d, c, y) { + var p = d, g = Math.pow(p.x - l, 2) + Math.pow(p.y - f, 2) <= Math.pow((h + 2 * y) * this.radius, 2), m = i(n(this.points, h + 2 * y, v, d)); + return Ht(l, f, m) || g; + }, + draw: function(l, f, h, v, d) { + var c = n(this.pointsTr, f, h, v); + e.arrowShapeImpl(this.name)(l, c, v.x, v.y, this.radius * f); + }, + spacing: function(l) { + return e.getArrowWidth(l.pstyle("width").pfValue, l.pstyle("arrow-scale").value) * this.radius; + } + }), o("triangle-cross", { + points: [0, 0, 0.15, -0.3, -0.15, -0.3, 0, 0], + baseCrossLinePts: [ + -0.15, + -0.4, + // first half of the rectangle + -0.15, + -0.4, + 0.15, + -0.4, + // second half of the rectangle + 0.15, + -0.4 + ], + crossLinePts: function(l, f) { + var h = this.baseCrossLinePts.slice(), v = f / l, d = 3, c = 5; + return h[d] = h[d] - v, h[c] = h[c] - v, h; + }, + collide: function(l, f, h, v, d, c, y) { + var p = i(n(this.points, h + 2 * y, v, d)), g = i(n(this.crossLinePts(h, c), h + 2 * y, v, d)), m = Ht(l, f, p) || Ht(l, f, g); + return m; + }, + draw: function(l, f, h, v, d) { + var c = n(this.points, f, h, v), y = n(this.crossLinePts(f, d), f, h, v); + e.arrowShapeImpl(this.name)(l, c, y); + } + }), o("vee", { + points: [-0.15, -0.3, 0, 0, 0.15, -0.3, 0, -0.15], + gap: function(l) { + return s(l) * 0.525; + } + }), o("circle", { + radius: 0.15, + collide: function(l, f, h, v, d, c, y) { + var p = d, g = Math.pow(p.x - l, 2) + Math.pow(p.y - f, 2) <= Math.pow((h + 2 * y) * this.radius, 2); + return g; + }, + draw: function(l, f, h, v, d) { + e.arrowShapeImpl(this.name)(l, v.x, v.y, this.radius * f); + }, + spacing: function(l) { + return e.getArrowWidth(l.pstyle("width").pfValue, l.pstyle("arrow-scale").value) * this.radius; + } + }), o("tee", { + points: [-0.15, 0, -0.15, -0.1, 0.15, -0.1, 0.15, 0], + spacing: function(l) { + return 1; + }, + gap: function(l) { + return 1; + } + }), o("square", { + points: [-0.15, 0, 0.15, 0, 0.15, -0.3, -0.15, -0.3] + }), o("diamond", { + points: [-0.15, -0.15, 0, -0.3, 0.15, -0.15, 0, 0], + gap: function(l) { + return l.pstyle("width").pfValue * l.pstyle("arrow-scale").value; + } + }), o("chevron", { + points: [0, 0, -0.15, -0.15, -0.1, -0.2, 0, -0.1, 0.1, -0.2, 0.15, -0.15], + gap: function(l) { + return 0.95 * l.pstyle("width").pfValue * l.pstyle("arrow-scale").value; + } + }); + }; + var $r = {}; + $r.projectIntoViewport = function(t, e) { + var r = this.cy, a = this.findContainerClientCoords(), n = a[0], i = a[1], s = a[4], o = r.pan(), u = r.zoom(), l = ((t - n) / s - o.x) / u, f = ((e - i) / s - o.y) / u; + return [l, f]; + }, $r.findContainerClientCoords = function() { + if (this.containerBB) + return this.containerBB; + var t = this.container, e = t.getBoundingClientRect(), r = this.cy.window().getComputedStyle(t), a = function(g) { + return parseFloat(r.getPropertyValue(g)); + }, n = { + left: a("padding-left"), + right: a("padding-right"), + top: a("padding-top"), + bottom: a("padding-bottom") + }, i = { + left: a("border-left-width"), + right: a("border-right-width"), + top: a("border-top-width"), + bottom: a("border-bottom-width") + }, s = t.clientWidth, o = t.clientHeight, u = n.left + n.right, l = n.top + n.bottom, f = i.left + i.right, h = e.width / (s + f), v = s - u, d = o - l, c = e.left + n.left + i.left, y = e.top + n.top + i.top; + return this.containerBB = [c, y, v, d, h]; + }, $r.invalidateContainerClientCoordsCache = function() { + this.containerBB = null; + }, $r.findNearestElement = function(t, e, r, a) { + return this.findNearestElements(t, e, r, a)[0]; + }, $r.findNearestElements = function(t, e, r, a) { + var n = this, i = this, s = i.getCachedZSortedEles(), o = [], u = i.cy.zoom(), l = i.cy.hasCompoundNodes(), f = (a ? 24 : 8) / u, h = (a ? 8 : 2) / u, v = (a ? 8 : 2) / u, d = 1 / 0, c, y; + r && (s = s.interactive); + function p(w, k) { + if (w.isNode()) { + if (y) + return; + y = w, o.push(w); + } + if (w.isEdge() && (k == null || k < d)) + if (c) { + if (c.pstyle("z-compound-depth").value === w.pstyle("z-compound-depth").value && c.pstyle("z-compound-depth").value === w.pstyle("z-compound-depth").value) { + for (var D = 0; D < o.length; D++) + if (o[D].isEdge()) { + o[D] = w, c = w, d = k ?? d; + break; + } + } + } else + o.push(w), c = w, d = k ?? d; + } + function g(w) { + var k = w.outerWidth() + 2 * h, D = w.outerHeight() + 2 * h, F = k / 2, G = D / 2, N = w.position(); + if (N.x - F <= t && t <= N.x + F && N.y - G <= e && e <= N.y + G) { + var X = i.nodeShapes[n.getNodeShape(w)]; + if (X.checkPoint(t, e, 0, k, D, N.x, N.y)) + return p(w, 0), !0; + } + } + function m(w) { + var k = w._private, D = k.rscratch, F = w.pstyle("width").pfValue, G = w.pstyle("arrow-scale").value, N = F / 2 + f, X = N * N, B = N * 2, ae = k.source, ue = k.target, re; + if (D.edgeType === "segments" || D.edgeType === "straight" || D.edgeType === "haystack") { + for (var K = D.allpts, W = 0; W + 3 < K.length; W += 2) + if (Sf(t, e, K[W], K[W + 1], K[W + 2], K[W + 3], B) && X > (re = If(t, e, K[W], K[W + 1], K[W + 2], K[W + 3]))) + return p(w, re), !0; + } else if (D.edgeType === "bezier" || D.edgeType === "multibezier" || D.edgeType === "self" || D.edgeType === "compound") { + for (var K = D.allpts, W = 0; W + 5 < D.allpts.length; W += 4) + if (Lf(t, e, K[W], K[W + 1], K[W + 2], K[W + 3], K[W + 4], K[W + 5], B) && X > (re = Nf(t, e, K[W], K[W + 1], K[W + 2], K[W + 3], K[W + 4], K[W + 5]))) + return p(w, re), !0; + } + for (var ae = ae || k.source, ue = ue || k.target, me = n.getArrowWidth(F, G), ie = [{ + name: "source", + x: D.arrowStartX, + y: D.arrowStartY, + angle: D.srcArrowAngle + }, { + name: "target", + x: D.arrowEndX, + y: D.arrowEndY, + angle: D.tgtArrowAngle + }, { + name: "mid-source", + x: D.midX, + y: D.midY, + angle: D.midsrcArrowAngle + }, { + name: "mid-target", + x: D.midX, + y: D.midY, + angle: D.midtgtArrowAngle + }], W = 0; W < ie.length; W++) { + var ge = ie[W], Ee = i.arrowShapes[w.pstyle(ge.name + "-arrow-shape").value], Ce = w.pstyle("width").pfValue; + if (Ee.roughCollide(t, e, me, ge.angle, { + x: ge.x, + y: ge.y + }, Ce, f) && Ee.collide(t, e, me, ge.angle, { + x: ge.x, + y: ge.y + }, Ce, f)) + return p(w), !0; + } + l && o.length > 0 && (g(ae), g(ue)); + } + function b(w, k, D) { + return er(w, k, D); + } + function E(w, k) { + var D = w._private, F = v, G; + k ? G = k + "-" : G = "", w.boundingBox(); + var N = D.labelBounds[k || "main"], X = w.pstyle(G + "label").value, B = w.pstyle("text-events").strValue === "yes"; + if (!(!B || !X)) { + var re = b(D.rscratch, "labelX", k), K = b(D.rscratch, "labelY", k), W = b(D.rscratch, "labelAngle", k), ae = w.pstyle(G + "text-margin-x").pfValue, ue = w.pstyle(G + "text-margin-y").pfValue, me = N.x1 - F - ae, ie = N.x2 + F - ae, ge = N.y1 - F - ue, Ee = N.y2 + F - ue; + if (W) { + var Ce = Math.cos(W), we = Math.sin(W), De = function(Xe, Ie) { + return Xe = Xe - re, Ie = Ie - K, { + x: Xe * Ce - Ie * we + re, + y: Xe * we + Ie * Ce + K + }; + }, se = De(me, ge), xe = De(me, Ee), Le = De(ie, ge), Se = De(ie, Ee), Oe = [ + // with the margin added after the rotation is applied + se.x + ae, + se.y + ue, + Le.x + ae, + Le.y + ue, + Se.x + ae, + Se.y + ue, + xe.x + ae, + xe.y + ue + ]; + if (Ht(t, e, Oe)) + return p(w), !0; + } else if (ta(N, t, e)) + return p(w), !0; + } + } + for (var M = s.length - 1; M >= 0; M--) { + var L = s[M]; + L.isNode() ? g(L) || E(L) : m(L) || E(L) || E(L, "source") || E(L, "target"); + } + return o; + }, $r.getAllInBox = function(t, e, r, a) { + var n = this.getCachedZSortedEles().interactive, i = [], s = Math.min(t, r), o = Math.max(t, r), u = Math.min(e, a), l = Math.max(e, a); + t = s, r = o, e = u, a = l; + for (var f = Yt({ + x1: t, + y1: e, + x2: r, + y2: a + }), h = 0; h < n.length; h++) { + var v = n[h]; + if (v.isNode()) { + var d = v, c = d.boundingBox({ + includeNodes: !0, + includeEdges: !1, + includeLabels: !1 + }); + fi(f, c) && !Ts(c, f) && i.push(d); + } else { + var y = v, p = y._private, g = p.rscratch; + if (g.startX != null && g.startY != null && !ta(f, g.startX, g.startY) || g.endX != null && g.endY != null && !ta(f, g.endX, g.endY)) + continue; + if (g.edgeType === "bezier" || g.edgeType === "multibezier" || g.edgeType === "self" || g.edgeType === "compound" || g.edgeType === "segments" || g.edgeType === "haystack") { + for (var m = p.rstyle.bezierPts || p.rstyle.linePts || p.rstyle.haystackPts, b = !0, E = 0; E < m.length; E++) + if (!Df(f, m[E])) { + b = !1; + break; + } + b && i.push(y); + } else + (g.edgeType === "haystack" || g.edgeType === "straight") && i.push(y); + } + } + return i; + }; + var Xn = {}; + Xn.calculateArrowAngles = function(t) { + var e = t._private.rscratch, r = e.edgeType === "haystack", a = e.edgeType === "bezier", n = e.edgeType === "multibezier", i = e.edgeType === "segments", s = e.edgeType === "compound", o = e.edgeType === "self", u, l, f, h, v, d, g, m; + if (r ? (f = e.haystackPts[0], h = e.haystackPts[1], v = e.haystackPts[2], d = e.haystackPts[3]) : (f = e.arrowStartX, h = e.arrowStartY, v = e.arrowEndX, d = e.arrowEndY), g = e.midX, m = e.midY, i) + u = f - e.segpts[0], l = h - e.segpts[1]; + else if (n || s || o || a) { + var c = e.allpts, y = Lt(c[0], c[2], c[4], 0.1), p = Lt(c[1], c[3], c[5], 0.1); + u = f - y, l = h - p; + } else + u = f - g, l = h - m; + e.srcArrowAngle = cn(u, l); + var g = e.midX, m = e.midY; + if (r && (g = (f + v) / 2, m = (h + d) / 2), u = v - f, l = d - h, i) { + var c = e.allpts; + if (c.length / 2 % 2 === 0) { + var b = c.length / 2, E = b - 2; + u = c[b] - c[E], l = c[b + 1] - c[E + 1]; + } else { + var b = c.length / 2 - 1, E = b - 2, M = b + 2; + u = c[b] - c[E], l = c[b + 1] - c[E + 1]; + } + } else if (n || s || o) { + var c = e.allpts, L = e.ctrlpts, w, k, D, F; + if (L.length / 2 % 2 === 0) { + var G = c.length / 2 - 1, N = G + 2, X = N + 2; + w = Lt(c[G], c[N], c[X], 0), k = Lt(c[G + 1], c[N + 1], c[X + 1], 0), D = Lt(c[G], c[N], c[X], 1e-4), F = Lt(c[G + 1], c[N + 1], c[X + 1], 1e-4); + } else { + var N = c.length / 2 - 1, G = N - 2, X = N + 2; + w = Lt(c[G], c[N], c[X], 0.4999), k = Lt(c[G + 1], c[N + 1], c[X + 1], 0.4999), D = Lt(c[G], c[N], c[X], 0.5), F = Lt(c[G + 1], c[N + 1], c[X + 1], 0.5); + } + u = D - w, l = F - k; + } + if (e.midtgtArrowAngle = cn(u, l), e.midDispX = u, e.midDispY = l, u *= -1, l *= -1, i) { + var c = e.allpts; + if (c.length / 2 % 2 !== 0) { + var b = c.length / 2 - 1, M = b + 2; + u = -(c[M] - c[b]), l = -(c[M + 1] - c[b + 1]); + } + } + if (e.midsrcArrowAngle = cn(u, l), i) + u = v - e.segpts[e.segpts.length - 2], l = d - e.segpts[e.segpts.length - 1]; + else if (n || s || o || a) { + var c = e.allpts, B = c.length, y = Lt(c[B - 6], c[B - 4], c[B - 2], 0.9), p = Lt(c[B - 5], c[B - 3], c[B - 1], 0.9); + u = v - y, l = d - p; + } else + u = v - g, l = d - m; + e.tgtArrowAngle = cn(u, l); + }, Xn.getArrowWidth = Xn.getArrowHeight = function(t, e) { + var r = this.arrowWidthCache = this.arrowWidthCache || {}, a = r[t + ", " + e]; + return a || (a = Math.max(Math.pow(t * 13.37, 0.9), 29) * e, r[t + ", " + e] = a, a); + }; + var Vt = {}; + Vt.findMidptPtsEtc = function(t, e) { + var r = e.posPts, a = e.intersectionPts, n = e.vectorNormInverse, i, s = t.pstyle("source-endpoint"), o = t.pstyle("target-endpoint"), u = s.units != null && o.units != null, l = function(M, L, w, k) { + var D = k - L, F = w - M, G = Math.sqrt(F * F + D * D); + return { + x: -D / G, + y: F / G + }; + }, f = t.pstyle("edge-distances").value; + switch (f) { + case "node-position": + i = r; + break; + case "intersection": + i = a; + break; + case "endpoints": { + if (u) { + var h = this.manualEndptToPx(t.source()[0], s), v = x(h, 2), d = v[0], c = v[1], y = this.manualEndptToPx(t.target()[0], o), p = x(y, 2), g = p[0], m = p[1], b = { + x1: d, + y1: c, + x2: g, + y2: m + }; + n = l(d, c, g, m), i = b; + } else + vt("Edge ".concat(t.id(), " has edge-distances:endpoints specified without manual endpoints specified via source-endpoint and target-endpoint. Falling back on edge-distances:intersection (default).")), i = a; + break; + } + } + return { + midptPts: i, + vectorNormInverse: n + }; + }, Vt.findHaystackPoints = function(t) { + for (var e = 0; e < t.length; e++) { + var r = t[e], a = r._private, n = a.rscratch; + if (!n.haystack) { + var i = Math.random() * 2 * Math.PI; + n.source = { + x: Math.cos(i), + y: Math.sin(i) + }, i = Math.random() * 2 * Math.PI, n.target = { + x: Math.cos(i), + y: Math.sin(i) + }; + } + var s = a.source, o = a.target, u = s.position(), l = o.position(), f = s.width(), h = o.width(), v = s.height(), d = o.height(), c = r.pstyle("haystack-radius").value, y = c / 2; + n.haystackPts = n.allpts = [n.source.x * f * y + u.x, n.source.y * v * y + u.y, n.target.x * h * y + l.x, n.target.y * d * y + l.y], n.midX = (n.allpts[0] + n.allpts[2]) / 2, n.midY = (n.allpts[1] + n.allpts[3]) / 2, n.edgeType = "haystack", n.haystack = !0, this.storeEdgeProjections(r), this.calculateArrowAngles(r), this.recalculateEdgeLabelProjections(r), this.calculateLabelAngles(r); + } + }, Vt.findSegmentsPoints = function(t, e) { + var r = t._private.rscratch, a = t.pstyle("segment-weights"), n = t.pstyle("segment-distances"), i = Math.min(a.pfValue.length, n.pfValue.length); + r.edgeType = "segments", r.segpts = []; + for (var s = 0; s < i; s++) { + var o = a.pfValue[s], u = n.pfValue[s], l = 1 - o, f = o, h = this.findMidptPtsEtc(t, e), v = h.midptPts, d = h.vectorNormInverse, c = { + x: v.x1 * l + v.x2 * f, + y: v.y1 * l + v.y2 * f + }; + r.segpts.push(c.x + d.x * u, c.y + d.y * u); + } + }, Vt.findLoopPoints = function(t, e, r, a) { + var n = t._private.rscratch, i = e.dirCounts, s = e.srcPos, o = t.pstyle("control-point-distances"), u = o ? o.pfValue[0] : void 0, l = t.pstyle("loop-direction").pfValue, f = t.pstyle("loop-sweep").pfValue, h = t.pstyle("control-point-step-size").pfValue; + n.edgeType = "self"; + var v = r, d = h; + a && (v = 0, d = u); + var c = l - Math.PI / 2, y = c - f / 2, p = c + f / 2, g = l + "_" + f; + v = i[g] === void 0 ? i[g] = 0 : ++i[g], n.ctrlpts = [s.x + Math.cos(y) * 1.4 * d * (v / 3 + 1), s.y + Math.sin(y) * 1.4 * d * (v / 3 + 1), s.x + Math.cos(p) * 1.4 * d * (v / 3 + 1), s.y + Math.sin(p) * 1.4 * d * (v / 3 + 1)]; + }, Vt.findCompoundLoopPoints = function(t, e, r, a) { + var n = t._private.rscratch; + n.edgeType = "compound"; + var i = e.srcPos, s = e.tgtPos, o = e.srcW, u = e.srcH, l = e.tgtW, f = e.tgtH, h = t.pstyle("control-point-step-size").pfValue, v = t.pstyle("control-point-distances"), d = v ? v.pfValue[0] : void 0, c = r, y = h; + a && (c = 0, y = d); + var p = 50, g = { + x: i.x - o / 2, + y: i.y - u / 2 + }, m = { + x: s.x - l / 2, + y: s.y - f / 2 + }, b = { + x: Math.min(g.x, m.x), + y: Math.min(g.y, m.y) + }, E = 0.5, M = Math.max(E, Math.log(o * 0.01)), L = Math.max(E, Math.log(l * 0.01)); + n.ctrlpts = [b.x, b.y - (1 + Math.pow(p, 1.12) / 100) * y * (c / 3 + 1) * M, b.x - (1 + Math.pow(p, 1.12) / 100) * y * (c / 3 + 1) * L, b.y]; + }, Vt.findStraightEdgePoints = function(t) { + t._private.rscratch.edgeType = "straight"; + }, Vt.findBezierPoints = function(t, e, r, a, n) { + var i = t._private.rscratch, s = t.pstyle("control-point-step-size").pfValue, o = t.pstyle("control-point-distances"), u = t.pstyle("control-point-weights"), l = o && u ? Math.min(o.value.length, u.value.length) : 1, f = o ? o.pfValue[0] : void 0, h = u.value[0], v = a; + i.edgeType = v ? "multibezier" : "bezier", i.ctrlpts = []; + for (var d = 0; d < l; d++) { + var c = (0.5 - e.eles.length / 2 + r) * s * (n ? -1 : 1), y = void 0, p = Es(c); + v && (f = o ? o.pfValue[d] : s, h = u.value[d]), a ? y = f : y = f !== void 0 ? p * f : void 0; + var g = y !== void 0 ? y : c, m = 1 - h, b = h, E = this.findMidptPtsEtc(t, e), M = E.midptPts, L = E.vectorNormInverse, w = { + x: M.x1 * m + M.x2 * b, + y: M.y1 * m + M.y2 * b + }; + i.ctrlpts.push(w.x + L.x * g, w.y + L.y * g); + } + }, Vt.findTaxiPoints = function(t, e) { + var r = t._private.rscratch; + r.edgeType = "segments"; + var a = "vertical", n = "horizontal", i = "leftward", s = "rightward", o = "downward", u = "upward", l = "auto", f = e.posPts, h = e.srcW, v = e.srcH, d = e.tgtW, c = e.tgtH, y = t.pstyle("edge-distances").value, p = y !== "node-position", g = t.pstyle("taxi-direction").value, m = g, b = t.pstyle("taxi-turn"), E = b.units === "%", M = b.pfValue, L = M < 0, w = t.pstyle("taxi-turn-min-distance").pfValue, k = p ? (h + d) / 2 : 0, D = p ? (v + c) / 2 : 0, F = f.x2 - f.x1, G = f.y2 - f.y1, N = function(be, Ge) { + return be > 0 ? Math.max(be - Ge, 0) : Math.min(be + Ge, 0); + }, X = N(F, k), B = N(G, D), re = !1; + m === l ? g = Math.abs(X) > Math.abs(B) ? n : a : m === u || m === o ? (g = a, re = !0) : (m === i || m === s) && (g = n, re = !0); + var K = g === a, W = K ? B : X, ae = K ? G : F, ue = Es(ae), me = !1; + !(re && (E || L)) && (m === o && ae < 0 || m === u && ae > 0 || m === i && ae > 0 || m === s && ae < 0) && (ue *= -1, W = ue * Math.abs(W), me = !0); + var ie; + if (E) { + var ge = M < 0 ? 1 + M : M; + ie = ge * W; + } else { + var Ee = M < 0 ? W : 0; + ie = Ee + M * ue; + } + var Ce = function(be) { + return Math.abs(be) < w || Math.abs(be) >= Math.abs(W); + }, we = Ce(ie), De = Ce(Math.abs(W) - Math.abs(ie)), se = we || De; + if (se && !me) + if (K) { + var xe = Math.abs(ae) <= v / 2, Le = Math.abs(F) <= d / 2; + if (xe) { + var Se = (f.x1 + f.x2) / 2, Oe = f.y1, Fe = f.y2; + r.segpts = [Se, Oe, Se, Fe]; + } else if (Le) { + var Xe = (f.y1 + f.y2) / 2, Ie = f.x1, Me = f.x2; + r.segpts = [Ie, Xe, Me, Xe]; + } else + r.segpts = [f.x1, f.y2]; + } else { + var Ue = Math.abs(ae) <= h / 2, ze = Math.abs(G) <= c / 2; + if (Ue) { + var Be = (f.y1 + f.y2) / 2, $e = f.x1, rt = f.x2; + r.segpts = [$e, Be, rt, Be]; + } else if (ze) { + var je = (f.x1 + f.x2) / 2, We = f.y1, et = f.y2; + r.segpts = [je, We, je, et]; + } else + r.segpts = [f.x2, f.y1]; + } + else if (K) { + var he = f.y1 + ie + (p ? v / 2 * ue : 0), O = f.x1, oe = f.x2; + r.segpts = [O, he, oe, he]; + } else { + var Te = f.x1 + ie + (p ? h / 2 * ue : 0), ce = f.y1, ye = f.y2; + r.segpts = [Te, ce, Te, ye]; + } + }, Vt.tryToCorrectInvalidPoints = function(t, e) { + var r = t._private.rscratch; + if (r.edgeType === "bezier") { + var a = e.srcPos, n = e.tgtPos, i = e.srcW, s = e.srcH, o = e.tgtW, u = e.tgtH, l = e.srcShape, f = e.tgtShape, h = !R(r.startX) || !R(r.startY), v = !R(r.arrowStartX) || !R(r.arrowStartY), d = !R(r.endX) || !R(r.endY), c = !R(r.arrowEndX) || !R(r.arrowEndY), y = 3, p = this.getArrowWidth(t.pstyle("width").pfValue, t.pstyle("arrow-scale").value) * this.arrowShapeWidth, g = y * p, m = Br({ + x: r.ctrlpts[0], + y: r.ctrlpts[1] + }, { + x: r.startX, + y: r.startY + }), b = m < g, E = Br({ + x: r.ctrlpts[0], + y: r.ctrlpts[1] + }, { + x: r.endX, + y: r.endY + }), M = E < g, L = !1; + if (h || v || b) { + L = !0; + var w = { + // delta + x: r.ctrlpts[0] - a.x, + y: r.ctrlpts[1] - a.y + }, k = Math.sqrt(w.x * w.x + w.y * w.y), D = { + // normalised delta + x: w.x / k, + y: w.y / k + }, F = Math.max(i, s), G = { + // *2 radius guarantees outside shape + x: r.ctrlpts[0] + D.x * 2 * F, + y: r.ctrlpts[1] + D.y * 2 * F + }, N = l.intersectLine(a.x, a.y, i, s, G.x, G.y, 0); + b ? (r.ctrlpts[0] = r.ctrlpts[0] + D.x * (g - m), r.ctrlpts[1] = r.ctrlpts[1] + D.y * (g - m)) : (r.ctrlpts[0] = N[0] + D.x * g, r.ctrlpts[1] = N[1] + D.y * g); + } + if (d || c || M) { + L = !0; + var X = { + // delta + x: r.ctrlpts[0] - n.x, + y: r.ctrlpts[1] - n.y + }, B = Math.sqrt(X.x * X.x + X.y * X.y), re = { + // normalised delta + x: X.x / B, + y: X.y / B + }, K = Math.max(i, s), W = { + // *2 radius guarantees outside shape + x: r.ctrlpts[0] + re.x * 2 * K, + y: r.ctrlpts[1] + re.y * 2 * K + }, ae = f.intersectLine(n.x, n.y, o, u, W.x, W.y, 0); + M ? (r.ctrlpts[0] = r.ctrlpts[0] + re.x * (g - E), r.ctrlpts[1] = r.ctrlpts[1] + re.y * (g - E)) : (r.ctrlpts[0] = ae[0] + re.x * g, r.ctrlpts[1] = ae[1] + re.y * g); + } + L && this.findEndpoints(t); + } + }, Vt.storeAllpts = function(t) { + var e = t._private.rscratch; + if (e.edgeType === "multibezier" || e.edgeType === "bezier" || e.edgeType === "self" || e.edgeType === "compound") { + e.allpts = [], e.allpts.push(e.startX, e.startY); + for (var r = 0; r + 1 < e.ctrlpts.length; r += 2) + e.allpts.push(e.ctrlpts[r], e.ctrlpts[r + 1]), r + 3 < e.ctrlpts.length && e.allpts.push((e.ctrlpts[r] + e.ctrlpts[r + 2]) / 2, (e.ctrlpts[r + 1] + e.ctrlpts[r + 3]) / 2); + e.allpts.push(e.endX, e.endY); + var a, n; + e.ctrlpts.length / 2 % 2 === 0 ? (a = e.allpts.length / 2 - 1, e.midX = e.allpts[a], e.midY = e.allpts[a + 1]) : (a = e.allpts.length / 2 - 3, n = 0.5, e.midX = Lt(e.allpts[a], e.allpts[a + 2], e.allpts[a + 4], n), e.midY = Lt(e.allpts[a + 1], e.allpts[a + 3], e.allpts[a + 5], n)); + } else if (e.edgeType === "straight") + e.allpts = [e.startX, e.startY, e.endX, e.endY], e.midX = (e.startX + e.endX + e.arrowStartX + e.arrowEndX) / 4, e.midY = (e.startY + e.endY + e.arrowStartY + e.arrowEndY) / 4; + else if (e.edgeType === "segments") + if (e.allpts = [], e.allpts.push(e.startX, e.startY), e.allpts.push.apply(e.allpts, e.segpts), e.allpts.push(e.endX, e.endY), e.segpts.length % 4 === 0) { + var i = e.segpts.length / 2, s = i - 2; + e.midX = (e.segpts[s] + e.segpts[i]) / 2, e.midY = (e.segpts[s + 1] + e.segpts[i + 1]) / 2; + } else { + var o = e.segpts.length / 2 - 1; + e.midX = e.segpts[o], e.midY = e.segpts[o + 1]; + } + }, Vt.checkForInvalidEdgeWarning = function(t) { + var e = t[0]._private.rscratch; + e.nodesOverlap || R(e.startX) && R(e.startY) && R(e.endX) && R(e.endY) ? e.loggedErr = !1 : e.loggedErr || (e.loggedErr = !0, vt("Edge `" + t.id() + "` has invalid endpoints and so it is impossible to draw. Adjust your edge style (e.g. control points) accordingly or use an alternative edge type. This is expected behaviour when the source node and the target node overlap.")); + }, Vt.findEdgeControlPoints = function(t) { + var e = this; + if (!(!t || t.length === 0)) { + for (var r = this, a = r.cy, n = a.hasCompoundNodes(), i = { + map: new ur(), + get: function(w) { + var k = this.map.get(w[0]); + return k != null ? k.get(w[1]) : null; + }, + set: function(w, k) { + var D = this.map.get(w[0]); + D == null && (D = new ur(), this.map.set(w[0], D)), D.set(w[1], k); + } + }, s = [], o = [], u = 0; u < t.length; u++) { + var l = t[u], f = l._private, h = l.pstyle("curve-style").value; + if (!(l.removed() || !l.takesUpSpace())) { + if (h === "haystack") { + o.push(l); + continue; + } + var v = h === "unbundled-bezier" || h === "segments" || h === "straight" || h === "straight-triangle" || h === "taxi", d = h === "unbundled-bezier" || h === "bezier", c = f.source, y = f.target, p = c.poolIndex(), g = y.poolIndex(), m = [p, g].sort(), b = i.get(m); + b == null && (b = { + eles: [] + }, i.set(m, b), s.push(m)), b.eles.push(l), v && (b.hasUnbundled = !0), d && (b.hasBezier = !0); + } + } + for (var E = function(w) { + var k = s[w], D = i.get(k), F = void 0; + if (!D.hasUnbundled) { + var G = D.eles[0].parallelEdges().filter(function(et) { + return et.isBundledBezier(); + }); + oi(D.eles), G.forEach(function(et) { + return D.eles.push(et); + }), D.eles.sort(function(et, he) { + return et.poolIndex() - he.poolIndex(); + }); + } + var N = D.eles[0], X = N.source(), B = N.target(); + if (X.poolIndex() > B.poolIndex()) { + var re = X; + X = B, B = re; + } + var K = D.srcPos = X.position(), W = D.tgtPos = B.position(), ae = D.srcW = X.outerWidth(), ue = D.srcH = X.outerHeight(), me = D.tgtW = B.outerWidth(), ie = D.tgtH = B.outerHeight(), ge = D.srcShape = r.nodeShapes[e.getNodeShape(X)], Ee = D.tgtShape = r.nodeShapes[e.getNodeShape(B)]; + D.dirCounts = { + north: 0, + west: 0, + south: 0, + east: 0, + northwest: 0, + southwest: 0, + northeast: 0, + southeast: 0 + }; + for (var Ce = 0; Ce < D.eles.length; Ce++) { + var we = D.eles[Ce], De = we[0]._private.rscratch, se = we.pstyle("curve-style").value, xe = se === "unbundled-bezier" || se === "segments" || se === "taxi", Le = !X.same(we.source()); + if (!D.calculatedIntersection && X !== B && (D.hasBezier || D.hasUnbundled)) { + D.calculatedIntersection = !0; + var Se = ge.intersectLine(K.x, K.y, ae, ue, W.x, W.y, 0), Oe = D.srcIntn = Se, Fe = Ee.intersectLine(W.x, W.y, me, ie, K.x, K.y, 0), Xe = D.tgtIntn = Fe, Ie = D.intersectionPts = { + x1: Se[0], + x2: Fe[0], + y1: Se[1], + y2: Fe[1] + }, Me = D.posPts = { + x1: K.x, + x2: W.x, + y1: K.y, + y2: W.y + }, Ue = Fe[1] - Se[1], ze = Fe[0] - Se[0], Be = Math.sqrt(ze * ze + Ue * Ue), $e = D.vector = { + x: ze, + y: Ue + }, rt = D.vectorNorm = { + x: $e.x / Be, + y: $e.y / Be + }, je = { + x: -rt.y, + y: rt.x + }; + D.nodesOverlap = !R(Be) || Ee.checkPoint(Se[0], Se[1], 0, me, ie, W.x, W.y) || ge.checkPoint(Fe[0], Fe[1], 0, ae, ue, K.x, K.y), D.vectorNormInverse = je, F = { + nodesOverlap: D.nodesOverlap, + dirCounts: D.dirCounts, + calculatedIntersection: !0, + hasBezier: D.hasBezier, + hasUnbundled: D.hasUnbundled, + eles: D.eles, + srcPos: W, + tgtPos: K, + srcW: me, + srcH: ie, + tgtW: ae, + tgtH: ue, + srcIntn: Xe, + tgtIntn: Oe, + srcShape: Ee, + tgtShape: ge, + posPts: { + x1: Me.x2, + y1: Me.y2, + x2: Me.x1, + y2: Me.y1 + }, + intersectionPts: { + x1: Ie.x2, + y1: Ie.y2, + x2: Ie.x1, + y2: Ie.y1 + }, + vector: { + x: -$e.x, + y: -$e.y + }, + vectorNorm: { + x: -rt.x, + y: -rt.y + }, + vectorNormInverse: { + x: -je.x, + y: -je.y + } + }; + } + var We = Le ? F : D; + De.nodesOverlap = We.nodesOverlap, De.srcIntn = We.srcIntn, De.tgtIntn = We.tgtIntn, n && (X.isParent() || X.isChild() || B.isParent() || B.isChild()) && (X.parents().anySame(B) || B.parents().anySame(X) || X.same(B) && X.isParent()) ? e.findCompoundLoopPoints(we, We, Ce, xe) : X === B ? e.findLoopPoints(we, We, Ce, xe) : se === "segments" ? e.findSegmentsPoints(we, We) : se === "taxi" ? e.findTaxiPoints(we, We) : se === "straight" || !xe && D.eles.length % 2 === 1 && Ce === Math.floor(D.eles.length / 2) ? e.findStraightEdgePoints(we) : e.findBezierPoints(we, We, Ce, xe, Le), e.findEndpoints(we), e.tryToCorrectInvalidPoints(we, We), e.checkForInvalidEdgeWarning(we), e.storeAllpts(we), e.storeEdgeProjections(we), e.calculateArrowAngles(we), e.recalculateEdgeLabelProjections(we), e.calculateLabelAngles(we); + } + }, M = 0; M < s.length; M++) + E(M); + this.findHaystackPoints(o); + } + }; + function nl(t) { + var e = []; + if (t != null) { + for (var r = 0; r < t.length; r += 2) { + var a = t[r], n = t[r + 1]; + e.push({ + x: a, + y: n + }); + } + return e; + } + } + Vt.getSegmentPoints = function(t) { + var e = t[0]._private.rscratch, r = e.edgeType; + if (r === "segments") + return this.recalculateRenderedStyle(t), nl(e.segpts); + }, Vt.getControlPoints = function(t) { + var e = t[0]._private.rscratch, r = e.edgeType; + if (r === "bezier" || r === "multibezier" || r === "self" || r === "compound") + return this.recalculateRenderedStyle(t), nl(e.ctrlpts); + }, Vt.getEdgeMidpoint = function(t) { + var e = t[0]._private.rscratch; + return this.recalculateRenderedStyle(t), { + x: e.midX, + y: e.midY + }; + }; + var Qa = {}; + Qa.manualEndptToPx = function(t, e) { + var r = this, a = t.position(), n = t.outerWidth(), i = t.outerHeight(); + if (e.value.length === 2) { + var s = [e.pfValue[0], e.pfValue[1]]; + return e.units[0] === "%" && (s[0] = s[0] * n), e.units[1] === "%" && (s[1] = s[1] * i), s[0] += a.x, s[1] += a.y, s; + } else { + var o = e.pfValue[0]; + o = -Math.PI / 2 + o; + var u = 2 * Math.max(n, i), l = [a.x + Math.cos(o) * u, a.y + Math.sin(o) * u]; + return r.nodeShapes[this.getNodeShape(t)].intersectLine(a.x, a.y, n, i, l[0], l[1], 0); + } + }, Qa.findEndpoints = function(t) { + var e = this, r, a = t.source()[0], n = t.target()[0], i = a.position(), s = n.position(), o = t.pstyle("target-arrow-shape").value, u = t.pstyle("source-arrow-shape").value, l = t.pstyle("target-distance-from-node").pfValue, f = t.pstyle("source-distance-from-node").pfValue, h = t.pstyle("curve-style").value, v = t._private.rscratch, d = v.edgeType, c = h === "taxi", y = d === "self" || d === "compound", p = d === "bezier" || d === "multibezier" || y, g = d !== "bezier", m = d === "straight" || d === "segments", b = d === "segments", E = p || g || m, M = y || c, L = t.pstyle("source-endpoint"), w = M ? "outside-to-node" : L.value, k = t.pstyle("target-endpoint"), D = M ? "outside-to-node" : k.value; + v.srcManEndpt = L, v.tgtManEndpt = k; + var F, G, N, X; + if (p) { + var B = [v.ctrlpts[0], v.ctrlpts[1]], re = g ? [v.ctrlpts[v.ctrlpts.length - 2], v.ctrlpts[v.ctrlpts.length - 1]] : B; + F = re, G = B; + } else if (m) { + var K = b ? v.segpts.slice(0, 2) : [s.x, s.y], W = b ? v.segpts.slice(v.segpts.length - 2) : [i.x, i.y]; + F = W, G = K; + } + if (D === "inside-to-node") + r = [s.x, s.y]; + else if (k.units) + r = this.manualEndptToPx(n, k); + else if (D === "outside-to-line") + r = v.tgtIntn; + else if (D === "outside-to-node" || D === "outside-to-node-or-label" ? N = F : (D === "outside-to-line" || D === "outside-to-line-or-label") && (N = [i.x, i.y]), r = e.nodeShapes[this.getNodeShape(n)].intersectLine(s.x, s.y, n.outerWidth(), n.outerHeight(), N[0], N[1], 0), D === "outside-to-node-or-label" || D === "outside-to-line-or-label") { + var ae = n._private.rscratch, ue = ae.labelWidth, me = ae.labelHeight, ie = ae.labelX, ge = ae.labelY, Ee = ue / 2, Ce = me / 2, we = n.pstyle("text-valign").value; + we === "top" ? ge -= Ce : we === "bottom" && (ge += Ce); + var De = n.pstyle("text-halign").value; + De === "left" ? ie -= Ee : De === "right" && (ie += Ee); + var se = Ba(N[0], N[1], [ie - Ee, ge - Ce, ie + Ee, ge - Ce, ie + Ee, ge + Ce, ie - Ee, ge + Ce], s.x, s.y); + if (se.length > 0) { + var xe = i, Le = Fr(xe, jr(r)), Se = Fr(xe, jr(se)), Oe = Le; + if (Se < Le && (r = se, Oe = Se), se.length > 2) { + var Fe = Fr(xe, { + x: se[2], + y: se[3] + }); + Fe < Oe && (r = [se[2], se[3]]); + } + } + } + var Xe = mn(r, F, e.arrowShapes[o].spacing(t) + l), Ie = mn(r, F, e.arrowShapes[o].gap(t) + l); + if (v.endX = Ie[0], v.endY = Ie[1], v.arrowEndX = Xe[0], v.arrowEndY = Xe[1], w === "inside-to-node") + r = [i.x, i.y]; + else if (L.units) + r = this.manualEndptToPx(a, L); + else if (w === "outside-to-line") + r = v.srcIntn; + else if (w === "outside-to-node" || w === "outside-to-node-or-label" ? X = G : (w === "outside-to-line" || w === "outside-to-line-or-label") && (X = [s.x, s.y]), r = e.nodeShapes[this.getNodeShape(a)].intersectLine(i.x, i.y, a.outerWidth(), a.outerHeight(), X[0], X[1], 0), w === "outside-to-node-or-label" || w === "outside-to-line-or-label") { + var Me = a._private.rscratch, Ue = Me.labelWidth, ze = Me.labelHeight, Be = Me.labelX, $e = Me.labelY, rt = Ue / 2, je = ze / 2, We = a.pstyle("text-valign").value; + We === "top" ? $e -= je : We === "bottom" && ($e += je); + var et = a.pstyle("text-halign").value; + et === "left" ? Be -= rt : et === "right" && (Be += rt); + var he = Ba(X[0], X[1], [Be - rt, $e - je, Be + rt, $e - je, Be + rt, $e + je, Be - rt, $e + je], i.x, i.y); + if (he.length > 0) { + var O = s, oe = Fr(O, jr(r)), Te = Fr(O, jr(he)), ce = oe; + if (Te < oe && (r = [he[0], he[1]], ce = Te), he.length > 2) { + var ye = Fr(O, { + x: he[2], + y: he[3] + }); + ye < ce && (r = [he[2], he[3]]); + } + } + } + var _e = mn(r, G, e.arrowShapes[u].spacing(t) + f), be = mn(r, G, e.arrowShapes[u].gap(t) + f); + v.startX = be[0], v.startY = be[1], v.arrowStartX = _e[0], v.arrowStartY = _e[1], E && (!R(v.startX) || !R(v.startY) || !R(v.endX) || !R(v.endY) ? v.badLine = !0 : v.badLine = !1); + }, Qa.getSourceEndpoint = function(t) { + var e = t[0]._private.rscratch; + switch (this.recalculateRenderedStyle(t), e.edgeType) { + case "haystack": + return { + x: e.haystackPts[0], + y: e.haystackPts[1] + }; + default: + return { + x: e.arrowStartX, + y: e.arrowStartY + }; + } + }, Qa.getTargetEndpoint = function(t) { + var e = t[0]._private.rscratch; + switch (this.recalculateRenderedStyle(t), e.edgeType) { + case "haystack": + return { + x: e.haystackPts[2], + y: e.haystackPts[3] + }; + default: + return { + x: e.arrowEndX, + y: e.arrowEndY + }; + } + }; + var Gi = {}; + function vg(t, e, r) { + for (var a = function(l, f, h, v) { + return Lt(l, f, h, v); + }, n = e._private, i = n.rstyle.bezierPts, s = 0; s < t.bezierProjPcts.length; s++) { + var o = t.bezierProjPcts[s]; + i.push({ + x: a(r[0], r[2], r[4], o), + y: a(r[1], r[3], r[5], o) + }); + } + } + Gi.storeEdgeProjections = function(t) { + var e = t._private, r = e.rscratch, a = r.edgeType; + if (e.rstyle.bezierPts = null, e.rstyle.linePts = null, e.rstyle.haystackPts = null, a === "multibezier" || a === "bezier" || a === "self" || a === "compound") { + e.rstyle.bezierPts = []; + for (var n = 0; n + 5 < r.allpts.length; n += 4) + vg(this, t, r.allpts.slice(n, n + 6)); + } else if (a === "segments") + for (var i = e.rstyle.linePts = [], n = 0; n + 1 < r.allpts.length; n += 2) + i.push({ + x: r.allpts[n], + y: r.allpts[n + 1] + }); + else if (a === "haystack") { + var s = r.haystackPts; + e.rstyle.haystackPts = [{ + x: s[0], + y: s[1] + }, { + x: s[2], + y: s[3] + }]; + } + e.rstyle.arrowWidth = this.getArrowWidth(t.pstyle("width").pfValue, t.pstyle("arrow-scale").value) * this.arrowShapeWidth; + }, Gi.recalculateEdgeProjections = function(t) { + this.findEdgeControlPoints(t); + }; + var hr = {}; + hr.recalculateNodeLabelProjection = function(t) { + var e = t.pstyle("label").strValue; + if (!Re(e)) { + var r, a, n = t._private, i = t.width(), s = t.height(), o = t.padding(), u = t.position(), l = t.pstyle("text-halign").strValue, f = t.pstyle("text-valign").strValue, h = n.rscratch, v = n.rstyle; + switch (l) { + case "left": + r = u.x - i / 2 - o; + break; + case "right": + r = u.x + i / 2 + o; + break; + default: + r = u.x; + } + switch (f) { + case "top": + a = u.y - s / 2 - o; + break; + case "bottom": + a = u.y + s / 2 + o; + break; + default: + a = u.y; + } + h.labelX = r, h.labelY = a, v.labelX = r, v.labelY = a, this.calculateLabelAngles(t), this.applyLabelDimensions(t); + } + }; + var il = function(e, r) { + var a = Math.atan(r / e); + return e === 0 && a < 0 && (a = a * -1), a; + }, sl = function(e, r) { + var a = r.x - e.x, n = r.y - e.y; + return il(a, n); + }, cg = function(e, r, a, n) { + var i = ka(0, n - 1e-3, 1), s = ka(0, n + 1e-3, 1), o = ea(e, r, a, i), u = ea(e, r, a, s); + return sl(o, u); + }; + hr.recalculateEdgeLabelProjections = function(t) { + var e, r = t._private, a = r.rscratch, n = this, i = { + mid: t.pstyle("label").strValue, + source: t.pstyle("source-label").strValue, + target: t.pstyle("target-label").strValue + }; + if (i.mid || i.source || i.target) { + e = { + x: a.midX, + y: a.midY + }; + var s = function(h, v, d) { + Tr(r.rscratch, h, v, d), Tr(r.rstyle, h, v, d); + }; + s("labelX", null, e.x), s("labelY", null, e.y); + var o = il(a.midDispX, a.midDispY); + s("labelAutoAngle", null, o); + var u = function f() { + if (f.cache) + return f.cache; + for (var h = [], v = 0; v + 5 < a.allpts.length; v += 4) { + var d = { + x: a.allpts[v], + y: a.allpts[v + 1] + }, c = { + x: a.allpts[v + 2], + y: a.allpts[v + 3] + }, y = { + x: a.allpts[v + 4], + y: a.allpts[v + 5] + }; + h.push({ + p0: d, + p1: c, + p2: y, + startDist: 0, + length: 0, + segments: [] + }); + } + var p = r.rstyle.bezierPts, g = n.bezierProjPcts.length; + function m(w, k, D, F, G) { + var N = Br(k, D), X = w.segments[w.segments.length - 1], B = { + p0: k, + p1: D, + t0: F, + t1: G, + startDist: X ? X.startDist + X.length : 0, + length: N + }; + w.segments.push(B), w.length += N; + } + for (var b = 0; b < h.length; b++) { + var E = h[b], M = h[b - 1]; + M && (E.startDist = M.startDist + M.length), m(E, E.p0, p[b * g], 0, n.bezierProjPcts[0]); + for (var L = 0; L < g - 1; L++) + m(E, p[b * g + L], p[b * g + L + 1], n.bezierProjPcts[L], n.bezierProjPcts[L + 1]); + m(E, p[b * g + g - 1], E.p2, n.bezierProjPcts[g - 1], 1); + } + return f.cache = h; + }, l = function(h) { + var v, d = h === "source"; + if (i[h]) { + var c = t.pstyle(h + "-text-offset").pfValue; + switch (a.edgeType) { + case "self": + case "compound": + case "bezier": + case "multibezier": { + for (var y = u(), p, g = 0, m = 0, b = 0; b < y.length; b++) { + for (var E = y[d ? b : y.length - 1 - b], M = 0; M < E.segments.length; M++) { + var L = E.segments[d ? M : E.segments.length - 1 - M], w = b === y.length - 1 && M === E.segments.length - 1; + if (g = m, m += L.length, m >= c || w) { + p = { + cp: E, + segment: L + }; + break; + } + } + if (p) + break; + } + var k = p.cp, D = p.segment, F = (c - g) / D.length, G = D.t1 - D.t0, N = d ? D.t0 + G * F : D.t1 - G * F; + N = ka(0, N, 1), e = ea(k.p0, k.p1, k.p2, N), v = cg(k.p0, k.p1, k.p2, N); + break; + } + case "straight": + case "segments": + case "haystack": { + for (var X = 0, B, re, K, W, ae = a.allpts.length, ue = 0; ue + 3 < ae && (d ? (K = { + x: a.allpts[ue], + y: a.allpts[ue + 1] + }, W = { + x: a.allpts[ue + 2], + y: a.allpts[ue + 3] + }) : (K = { + x: a.allpts[ae - 2 - ue], + y: a.allpts[ae - 1 - ue] + }, W = { + x: a.allpts[ae - 4 - ue], + y: a.allpts[ae - 3 - ue] + }), B = Br(K, W), re = X, X += B, !(X >= c)); ue += 2) + ; + var me = c - re, ie = me / B; + ie = ka(0, ie, 1), e = Ef(K, W, ie), v = sl(K, W); + break; + } + } + s("labelX", h, e.x), s("labelY", h, e.y), s("labelAutoAngle", h, v); + } + }; + l("source"), l("target"), this.applyLabelDimensions(t); + } + }, hr.applyLabelDimensions = function(t) { + this.applyPrefixedLabelDimensions(t), t.isEdge() && (this.applyPrefixedLabelDimensions(t, "source"), this.applyPrefixedLabelDimensions(t, "target")); + }, hr.applyPrefixedLabelDimensions = function(t, e) { + var r = t._private, a = this.getLabelText(t, e), n = this.calculateLabelDimensions(t, a), i = t.pstyle("line-height").pfValue, s = t.pstyle("text-wrap").strValue, o = er(r.rscratch, "labelWrapCachedLines", e) || [], u = s !== "wrap" ? 1 : Math.max(o.length, 1), l = n.height / u, f = l * i, h = n.width, v = n.height + (u - 1) * (i - 1) * l; + Tr(r.rstyle, "labelWidth", e, h), Tr(r.rscratch, "labelWidth", e, h), Tr(r.rstyle, "labelHeight", e, v), Tr(r.rscratch, "labelHeight", e, v), Tr(r.rscratch, "labelLineHeight", e, f); + }, hr.getLabelText = function(t, e) { + var r = t._private, a = e ? e + "-" : "", n = t.pstyle(a + "label").strValue, i = t.pstyle("text-transform").value, s = function(me, ie) { + return ie ? (Tr(r.rscratch, me, e, ie), ie) : er(r.rscratch, me, e); + }; + if (!n) + return ""; + i == "none" || (i == "uppercase" ? n = n.toUpperCase() : i == "lowercase" && (n = n.toLowerCase())); + var o = t.pstyle("text-wrap").value; + if (o === "wrap") { + var u = s("labelKey"); + if (u != null && s("labelWrapKey") === u) + return s("labelWrapCachedText"); + for (var l = "​", f = n.split(` +`), h = t.pstyle("text-max-width").pfValue, v = t.pstyle("text-overflow-wrap").value, d = v === "anywhere", c = [], y = /[\s\u200b]+/, p = d ? "" : " ", g = 0; g < f.length; g++) { + var m = f[g], b = this.calculateLabelDimensions(t, m), E = b.width; + if (d) { + var M = m.split("").join(l); + m = M; + } + if (E > h) { + for (var L = m.split(y), w = "", k = 0; k < L.length; k++) { + var D = L[k], F = w.length === 0 ? D : w + p + D, G = this.calculateLabelDimensions(t, F), N = G.width; + N <= h ? w += D + p : (w && c.push(w), w = D + p); + } + w.match(/^[\s\u200b]+$/) || c.push(w); + } else + c.push(m); + } + s("labelWrapCachedLines", c), n = s("labelWrapCachedText", c.join(` +`)), s("labelWrapKey", u); + } else if (o === "ellipsis") { + var X = t.pstyle("text-max-width").pfValue, B = "", re = "…", K = !1; + if (this.calculateLabelDimensions(t, n).width < X) + return n; + for (var W = 0; W < n.length; W++) { + var ae = this.calculateLabelDimensions(t, B + n[W] + re).width; + if (ae > X) + break; + B += n[W], W === n.length - 1 && (K = !0); + } + return K || (B += re), B; + } + return n; + }, hr.getLabelJustification = function(t) { + var e = t.pstyle("text-justification").strValue, r = t.pstyle("text-halign").strValue; + if (e === "auto") + if (t.isNode()) + switch (r) { + case "left": + return "right"; + case "right": + return "left"; + default: + return "center"; + } + else + return "center"; + else + return e; + }, hr.calculateLabelDimensions = function(t, e) { + var r = this, a = Pr(e, t._private.labelDimsKey), n = r.labelDimCache || (r.labelDimCache = []), i = n[a]; + if (i != null) + return i; + var s = 0, o = t.pstyle("font-style").strValue, u = t.pstyle("font-size").pfValue, l = t.pstyle("font-family").strValue, f = t.pstyle("font-weight").strValue, h = this.labelCalcCanvas, v = this.labelCalcCanvasContext; + if (!h) { + h = this.labelCalcCanvas = document.createElement("canvas"), v = this.labelCalcCanvasContext = h.getContext("2d"); + var d = h.style; + d.position = "absolute", d.left = "-9999px", d.top = "-9999px", d.zIndex = "-1", d.visibility = "hidden", d.pointerEvents = "none"; + } + v.font = "".concat(o, " ").concat(f, " ").concat(u, "px ").concat(l); + for (var c = 0, y = 0, p = e.split(` +`), g = 0; g < p.length; g++) { + var m = p[g], b = v.measureText(m), E = Math.ceil(b.width), M = u; + c = Math.max(E, c), y += M; + } + return c += s, y += s, n[a] = { + width: c, + height: y + }; + }, hr.calculateLabelAngle = function(t, e) { + var r = t._private, a = r.rscratch, n = t.isEdge(), i = e ? e + "-" : "", s = t.pstyle(i + "text-rotation"), o = s.strValue; + return o === "none" ? 0 : n && o === "autorotate" ? a.labelAutoAngle : o === "autorotate" ? 0 : s.pfValue; + }, hr.calculateLabelAngles = function(t) { + var e = this, r = t.isEdge(), a = t._private, n = a.rscratch; + n.labelAngle = e.calculateLabelAngle(t), r && (n.sourceLabelAngle = e.calculateLabelAngle(t, "source"), n.targetLabelAngle = e.calculateLabelAngle(t, "target")); + }; + var ol = {}, ll = 28, ul = !1; + ol.getNodeShape = function(t) { + var e = this, r = t.pstyle("shape").value; + if (r === "cutrectangle" && (t.width() < ll || t.height() < ll)) + return ul || (vt("The `cutrectangle` node shape can not be used at small sizes so `rectangle` is used instead"), ul = !0), "rectangle"; + if (t.isParent()) + return r === "rectangle" || r === "roundrectangle" || r === "round-rectangle" || r === "cutrectangle" || r === "cut-rectangle" || r === "barrel" ? r : "rectangle"; + if (r === "polygon") { + var a = t.pstyle("shape-polygon-points").value; + return e.nodeShapes.makePolygon(a).name; + } + return r; + }; + var Wn = {}; + Wn.registerCalculationListeners = function() { + var t = this.cy, e = t.collection(), r = this, a = function(s) { + var o = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : !0; + if (e.merge(s), o) + for (var u = 0; u < s.length; u++) { + var l = s[u], f = l._private, h = f.rstyle; + h.clean = !1, h.cleanConnected = !1; + } + }; + r.binder(t).on("bounds.* dirty.*", function(s) { + var o = s.target; + a(o); + }).on("style.* background.*", function(s) { + var o = s.target; + a(o, !1); + }); + var n = function(s) { + if (s) { + var o = r.onUpdateEleCalcsFns; + e.cleanStyle(); + for (var u = 0; u < e.length; u++) { + var l = e[u], f = l._private.rstyle; + l.isNode() && !f.cleanConnected && (a(l.connectedEdges()), f.cleanConnected = !0); + } + if (o) + for (var h = 0; h < o.length; h++) { + var v = o[h]; + v(s, e); + } + r.recalculateRenderedStyle(e), e = t.collection(); + } + }; + r.flushRenderedStyleQueue = function() { + n(!0); + }, r.beforeRender(n, r.beforeRenderPriorities.eleCalcs); + }, Wn.onUpdateEleCalcs = function(t) { + var e = this.onUpdateEleCalcsFns = this.onUpdateEleCalcsFns || []; + e.push(t); + }, Wn.recalculateRenderedStyle = function(t, e) { + var r = function(E) { + return E._private.rstyle.cleanConnected; + }, a = [], n = []; + if (!this.destroyed) { + e === void 0 && (e = !0); + for (var i = 0; i < t.length; i++) { + var s = t[i], o = s._private, u = o.rstyle; + s.isEdge() && (!r(s.source()) || !r(s.target())) && (u.clean = !1), !(e && u.clean || s.removed()) && s.pstyle("display").value !== "none" && (o.group === "nodes" ? n.push(s) : a.push(s), u.clean = !0); + } + for (var l = 0; l < n.length; l++) { + var f = n[l], h = f._private, v = h.rstyle, d = f.position(); + this.recalculateNodeLabelProjection(f), v.nodeX = d.x, v.nodeY = d.y, v.nodeW = f.pstyle("width").pfValue, v.nodeH = f.pstyle("height").pfValue; + } + this.recalculateEdgeProjections(a); + for (var c = 0; c < a.length; c++) { + var y = a[c], p = y._private, g = p.rstyle, m = p.rscratch; + g.srcX = m.arrowStartX, g.srcY = m.arrowStartY, g.tgtX = m.arrowEndX, g.tgtY = m.arrowEndY, g.midX = m.midX, g.midY = m.midY, g.labelAngle = m.labelAngle, g.sourceLabelAngle = m.sourceLabelAngle, g.targetLabelAngle = m.targetLabelAngle; + } + } + }; + var qn = {}; + qn.updateCachedGrabbedEles = function() { + var t = this.cachedZSortedEles; + if (t) { + t.drag = [], t.nondrag = []; + for (var e = [], r = 0; r < t.length; r++) { + var a = t[r], n = a._private.rscratch; + a.grabbed() && !a.isParent() ? e.push(a) : n.inDragLayer ? t.drag.push(a) : t.nondrag.push(a); + } + for (var r = 0; r < e.length; r++) { + var a = e[r]; + t.drag.push(a); + } + } + }, qn.invalidateCachedZSortedEles = function() { + this.cachedZSortedEles = null; + }, qn.getCachedZSortedEles = function(t) { + if (t || !this.cachedZSortedEles) { + var e = this.cy.mutableElements().toArray(); + e.sort(Mo), e.interactive = e.filter(function(r) { + return r.interactive(); + }), this.cachedZSortedEles = e, this.updateCachedGrabbedEles(); + } else + e = this.cachedZSortedEles; + return e; + }; + var fl = {}; + [$r, Xn, Vt, Qa, Gi, hr, ol, Wn, qn].forEach(function(t) { + He(fl, t); + }); + var hl = {}; + hl.getCachedImage = function(t, e, r) { + var a = this, n = a.imageCache = a.imageCache || {}, i = n[t]; + if (i) + return i.image.complete || i.image.addEventListener("load", r), i.image; + i = n[t] = n[t] || {}; + var s = i.image = new Image(); + s.addEventListener("load", r), s.addEventListener("error", function() { + s.error = !0; + }); + var o = "data:", u = t.substring(0, o.length).toLowerCase() === o; + return u || (e = e === "null" ? null : e, s.crossOrigin = e), s.src = t, s; + }; + var ya = {}; + ya.registerBinding = function(t, e, r, a) { + var n = Array.prototype.slice.apply(arguments, [1]), i = this.binder(t); + return i.on.apply(i, n); + }, ya.binder = function(t) { + var e = this, r = e.cy.window(), a = t === r || t === r.document || t === r.document.body || Ve(t); + if (e.supportsPassiveEvents == null) { + var n = !1; + try { + var i = Object.defineProperty({}, "passive", { + get: function() { + return n = !0, !0; + } + }); + r.addEventListener("test", null, i); + } catch { + } + e.supportsPassiveEvents = n; + } + var s = function(u, l, f) { + var h = Array.prototype.slice.call(arguments); + return a && e.supportsPassiveEvents && (h[2] = { + capture: f ?? !1, + passive: !1, + once: !1 + }), e.bindings.push({ + target: t, + args: h + }), (t.addEventListener || t.on).apply(t, h), this; + }; + return { + on: s, + addEventListener: s, + addListener: s, + bind: s + }; + }, ya.nodeIsDraggable = function(t) { + return t && t.isNode() && !t.locked() && t.grabbable(); + }, ya.nodeIsGrabbable = function(t) { + return this.nodeIsDraggable(t) && t.interactive(); + }, ya.load = function() { + var t = this, e = t.cy.window(), r = function(O) { + return O.selected(); + }, a = function(O, oe, Te, ce) { + O == null && (O = t.cy); + for (var ye = 0; ye < oe.length; ye++) { + var _e = oe[ye]; + O.emit({ + originalEvent: Te, + type: _e, + position: ce + }); + } + }, n = function(O) { + return O.shiftKey || O.metaKey || O.ctrlKey; + }, i = function(O, oe) { + var Te = !0; + if (t.cy.hasCompoundNodes() && O && O.pannable()) + for (var ce = 0; oe && ce < oe.length; ce++) { + var O = oe[ce]; + if (O.isNode() && O.isParent() && !O.pannable()) { + Te = !1; + break; + } + } + else + Te = !0; + return Te; + }, s = function(O) { + O[0]._private.grabbed = !0; + }, o = function(O) { + O[0]._private.grabbed = !1; + }, u = function(O) { + O[0]._private.rscratch.inDragLayer = !0; + }, l = function(O) { + O[0]._private.rscratch.inDragLayer = !1; + }, f = function(O) { + O[0]._private.rscratch.isGrabTarget = !0; + }, h = function(O) { + O[0]._private.rscratch.isGrabTarget = !1; + }, v = function(O, oe) { + var Te = oe.addToList, ce = Te.has(O); + !ce && O.grabbable() && !O.locked() && (Te.merge(O), s(O)); + }, d = function(O, oe) { + if (O.cy().hasCompoundNodes() && !(oe.inDragLayer == null && oe.addToList == null)) { + var Te = O.descendants(); + oe.inDragLayer && (Te.forEach(u), Te.connectedEdges().forEach(u)), oe.addToList && v(Te, oe); + } + }, c = function(O, oe) { + oe = oe || {}; + var Te = O.cy().hasCompoundNodes(); + oe.inDragLayer && (O.forEach(u), O.neighborhood().stdFilter(function(ce) { + return !Te || ce.isEdge(); + }).forEach(u)), oe.addToList && O.forEach(function(ce) { + v(ce, oe); + }), d(O, oe), g(O, { + inDragLayer: oe.inDragLayer + }), t.updateCachedGrabbedEles(); + }, y = c, p = function(O) { + O && (t.getCachedZSortedEles().forEach(function(oe) { + o(oe), l(oe), h(oe); + }), t.updateCachedGrabbedEles()); + }, g = function(O, oe) { + if (!(oe.inDragLayer == null && oe.addToList == null) && O.cy().hasCompoundNodes()) { + var Te = O.ancestors().orphans(); + if (!Te.same(O)) { + var ce = Te.descendants().spawnSelf().merge(Te).unmerge(O).unmerge(O.descendants()), ye = ce.connectedEdges(); + oe.inDragLayer && (ye.forEach(u), ce.forEach(u)), oe.addToList && ce.forEach(function(_e) { + v(_e, oe); + }); + } + } + }, m = function() { + document.activeElement != null && document.activeElement.blur != null && document.activeElement.blur(); + }, b = typeof MutationObserver < "u", E = typeof ResizeObserver < "u"; + b ? (t.removeObserver = new MutationObserver(function(he) { + for (var O = 0; O < he.length; O++) { + var oe = he[O], Te = oe.removedNodes; + if (Te) + for (var ce = 0; ce < Te.length; ce++) { + var ye = Te[ce]; + if (ye === t.container) { + t.destroy(); + break; + } + } + } + }), t.container.parentNode && t.removeObserver.observe(t.container.parentNode, { + childList: !0 + })) : t.registerBinding(t.container, "DOMNodeRemoved", function(he) { + t.destroy(); + }); + var M = on(function() { + t.cy.resize(); + }, 100); + b && (t.styleObserver = new MutationObserver(M), t.styleObserver.observe(t.container, { + attributes: !0 + })), t.registerBinding(e, "resize", M), E && (t.resizeObserver = new ResizeObserver(M), t.resizeObserver.observe(t.container)); + var L = function(O, oe) { + for (; O != null; ) + oe(O), O = O.parentNode; + }, w = function() { + t.invalidateContainerClientCoordsCache(); + }; + L(t.container, function(he) { + t.registerBinding(he, "transitionend", w), t.registerBinding(he, "animationend", w), t.registerBinding(he, "scroll", w); + }), t.registerBinding(t.container, "contextmenu", function(he) { + he.preventDefault(); + }); + var k = function() { + return t.selection[4] !== 0; + }, D = function(O) { + for (var oe = t.findContainerClientCoords(), Te = oe[0], ce = oe[1], ye = oe[2], _e = oe[3], be = O.touches ? O.touches : [O], Ge = !1, Qe = 0; Qe < be.length; Qe++) { + var ft = be[Qe]; + if (Te <= ft.clientX && ft.clientX <= Te + ye && ce <= ft.clientY && ft.clientY <= ce + _e) { + Ge = !0; + break; + } + } + if (!Ge) + return !1; + for (var qe = t.container, ot = O.target, Ke = ot.parentNode, Je = !1; Ke; ) { + if (Ke === qe) { + Je = !0; + break; + } + Ke = Ke.parentNode; + } + return !!Je; + }; + t.registerBinding(t.container, "mousedown", function(O) { + if (D(O)) { + O.preventDefault(), m(), t.hoverData.capture = !0, t.hoverData.which = O.which; + var oe = t.cy, Te = [O.clientX, O.clientY], ce = t.projectIntoViewport(Te[0], Te[1]), ye = t.selection, _e = t.findNearestElements(ce[0], ce[1], !0, !1), be = _e[0], Ge = t.dragData.possibleDragElements; + t.hoverData.mdownPos = ce, t.hoverData.mdownGPos = Te; + var Qe = function() { + t.hoverData.tapholdCancelled = !1, clearTimeout(t.hoverData.tapholdTimeout), t.hoverData.tapholdTimeout = setTimeout(function() { + if (!t.hoverData.tapholdCancelled) { + var Ct = t.hoverData.down; + Ct ? Ct.emit({ + originalEvent: O, + type: "taphold", + position: { + x: ce[0], + y: ce[1] + } + }) : oe.emit({ + originalEvent: O, + type: "taphold", + position: { + x: ce[0], + y: ce[1] + } + }); + } + }, t.tapholdDuration); + }; + if (O.which == 3) { + t.hoverData.cxtStarted = !0; + var ft = { + originalEvent: O, + type: "cxttapstart", + position: { + x: ce[0], + y: ce[1] + } + }; + be ? (be.activate(), be.emit(ft), t.hoverData.down = be) : oe.emit(ft), t.hoverData.downTime = (/* @__PURE__ */ new Date()).getTime(), t.hoverData.cxtDragged = !1; + } else if (O.which == 1) { + be && be.activate(); + { + if (be != null && t.nodeIsGrabbable(be)) { + var qe = function(Ct) { + return { + originalEvent: O, + type: Ct, + position: { + x: ce[0], + y: ce[1] + } + }; + }, ot = function(Ct) { + Ct.emit(qe("grab")); + }; + if (f(be), !be.selected()) + Ge = t.dragData.possibleDragElements = oe.collection(), y(be, { + addToList: Ge + }), be.emit(qe("grabon")).emit(qe("grab")); + else { + Ge = t.dragData.possibleDragElements = oe.collection(); + var Ke = oe.$(function(Je) { + return Je.isNode() && Je.selected() && t.nodeIsGrabbable(Je); + }); + c(Ke, { + addToList: Ge + }), be.emit(qe("grabon")), Ke.forEach(ot); + } + t.redrawHint("eles", !0), t.redrawHint("drag", !0); + } + t.hoverData.down = be, t.hoverData.downs = _e, t.hoverData.downTime = (/* @__PURE__ */ new Date()).getTime(); + } + a(be, ["mousedown", "tapstart", "vmousedown"], O, { + x: ce[0], + y: ce[1] + }), be == null ? (ye[4] = 1, t.data.bgActivePosistion = { + x: ce[0], + y: ce[1] + }, t.redrawHint("select", !0), t.redraw()) : be.pannable() && (ye[4] = 1), Qe(); + } + ye[0] = ye[2] = ce[0], ye[1] = ye[3] = ce[1]; + } + }, !1), t.registerBinding(e, "mousemove", function(O) { + var oe = t.hoverData.capture; + if (!(!oe && !D(O))) { + var Te = !1, ce = t.cy, ye = ce.zoom(), _e = [O.clientX, O.clientY], be = t.projectIntoViewport(_e[0], _e[1]), Ge = t.hoverData.mdownPos, Qe = t.hoverData.mdownGPos, ft = t.selection, qe = null; + !t.hoverData.draggingEles && !t.hoverData.dragging && !t.hoverData.selecting && (qe = t.findNearestElement(be[0], be[1], !0, !1)); + var ot = t.hoverData.last, Ke = t.hoverData.down, Je = [be[0] - ft[2], be[1] - ft[3]], Ct = t.dragData.possibleDragElements, Rt; + if (Qe) { + var ar = _e[0] - Qe[0], nr = ar * ar, kt = _e[1] - Qe[1], Jt = kt * kt, _t = nr + Jt; + t.hoverData.isOverThresholdDrag = Rt = _t >= t.desktopTapThreshold2; + } + var Er = n(O); + Rt && (t.hoverData.tapholdCancelled = !0); + var Rr = function() { + var cr = t.hoverData.dragDelta = t.hoverData.dragDelta || []; + cr.length === 0 ? (cr.push(Je[0]), cr.push(Je[1])) : (cr[0] += Je[0], cr[1] += Je[1]); + }; + Te = !0, a(qe, ["mousemove", "vmousemove", "tapdrag"], O, { + x: be[0], + y: be[1] + }); + var xa = function() { + t.data.bgActivePosistion = void 0, t.hoverData.selecting || ce.emit({ + originalEvent: O, + type: "boxstart", + position: { + x: be[0], + y: be[1] + } + }), ft[4] = 1, t.hoverData.selecting = !0, t.redrawHint("select", !0), t.redraw(); + }; + if (t.hoverData.which === 3) { + if (Rt) { + var Xr = { + originalEvent: O, + type: "cxtdrag", + position: { + x: be[0], + y: be[1] + } + }; + Ke ? Ke.emit(Xr) : ce.emit(Xr), t.hoverData.cxtDragged = !0, (!t.hoverData.cxtOver || qe !== t.hoverData.cxtOver) && (t.hoverData.cxtOver && t.hoverData.cxtOver.emit({ + originalEvent: O, + type: "cxtdragout", + position: { + x: be[0], + y: be[1] + } + }), t.hoverData.cxtOver = qe, qe && qe.emit({ + originalEvent: O, + type: "cxtdragover", + position: { + x: be[0], + y: be[1] + } + })); + } + } else if (t.hoverData.dragging) { + if (Te = !0, ce.panningEnabled() && ce.userPanningEnabled()) { + var Ta; + if (t.hoverData.justStartedPan) { + var Jn = t.hoverData.mdownPos; + Ta = { + x: (be[0] - Jn[0]) * ye, + y: (be[1] - Jn[1]) * ye + }, t.hoverData.justStartedPan = !1; + } else + Ta = { + x: Je[0] * ye, + y: Je[1] * ye + }; + ce.panBy(Ta), ce.emit("dragpan"), t.hoverData.dragged = !0; + } + be = t.projectIntoViewport(O.clientX, O.clientY); + } else if (ft[4] == 1 && (Ke == null || Ke.pannable())) { + if (Rt) { + if (!t.hoverData.dragging && ce.boxSelectionEnabled() && (Er || !ce.panningEnabled() || !ce.userPanningEnabled())) + xa(); + else if (!t.hoverData.selecting && ce.panningEnabled() && ce.userPanningEnabled()) { + var Wr = i(Ke, t.hoverData.downs); + Wr && (t.hoverData.dragging = !0, t.hoverData.justStartedPan = !0, ft[4] = 0, t.data.bgActivePosistion = jr(Ge), t.redrawHint("select", !0), t.redraw()); + } + Ke && Ke.pannable() && Ke.active() && Ke.unactivate(); + } + } else { + if (Ke && Ke.pannable() && Ke.active() && Ke.unactivate(), (!Ke || !Ke.grabbed()) && qe != ot && (ot && a(ot, ["mouseout", "tapdragout"], O, { + x: be[0], + y: be[1] + }), qe && a(qe, ["mouseover", "tapdragover"], O, { + x: be[0], + y: be[1] + }), t.hoverData.last = qe), Ke) + if (Rt) { + if (ce.boxSelectionEnabled() && Er) + Ke && Ke.grabbed() && (p(Ct), Ke.emit("freeon"), Ct.emit("free"), t.dragData.didDrag && (Ke.emit("dragfreeon"), Ct.emit("dragfree"))), xa(); + else if (Ke && Ke.grabbed() && t.nodeIsDraggable(Ke)) { + var Xt = !t.dragData.didDrag; + Xt && t.redrawHint("eles", !0), t.dragData.didDrag = !0, t.hoverData.draggingEles || c(Ct, { + inDragLayer: !0 + }); + var Ut = { + x: 0, + y: 0 + }; + if (R(Je[0]) && R(Je[1]) && (Ut.x += Je[0], Ut.y += Je[1], Xt)) { + var Wt = t.hoverData.dragDelta; + Wt && R(Wt[0]) && R(Wt[1]) && (Ut.x += Wt[0], Ut.y += Wt[1]); + } + t.hoverData.draggingEles = !0, Ct.silentShift(Ut).emit("position drag"), t.redrawHint("drag", !0), t.redraw(); + } + } else + Rr(); + Te = !0; + } + if (ft[2] = be[0], ft[3] = be[1], Te) + return O.stopPropagation && O.stopPropagation(), O.preventDefault && O.preventDefault(), !1; + } + }, !1); + var F, G, N; + t.registerBinding(e, "mouseup", function(O) { + var oe = t.hoverData.capture; + if (oe) { + t.hoverData.capture = !1; + var Te = t.cy, ce = t.projectIntoViewport(O.clientX, O.clientY), ye = t.selection, _e = t.findNearestElement(ce[0], ce[1], !0, !1), be = t.dragData.possibleDragElements, Ge = t.hoverData.down, Qe = n(O); + if (t.data.bgActivePosistion && (t.redrawHint("select", !0), t.redraw()), t.hoverData.tapholdCancelled = !0, t.data.bgActivePosistion = void 0, Ge && Ge.unactivate(), t.hoverData.which === 3) { + var ft = { + originalEvent: O, + type: "cxttapend", + position: { + x: ce[0], + y: ce[1] + } + }; + if (Ge ? Ge.emit(ft) : Te.emit(ft), !t.hoverData.cxtDragged) { + var qe = { + originalEvent: O, + type: "cxttap", + position: { + x: ce[0], + y: ce[1] + } + }; + Ge ? Ge.emit(qe) : Te.emit(qe); + } + t.hoverData.cxtDragged = !1, t.hoverData.which = null; + } else if (t.hoverData.which === 1) { + if (a(_e, ["mouseup", "tapend", "vmouseup"], O, { + x: ce[0], + y: ce[1] + }), !t.dragData.didDrag && // didn't move a node around + !t.hoverData.dragged && // didn't pan + !t.hoverData.selecting && // not box selection + !t.hoverData.isOverThresholdDrag && (a(Ge, ["click", "tap", "vclick"], O, { + x: ce[0], + y: ce[1] + }), G = !1, O.timeStamp - N <= Te.multiClickDebounceTime() ? (F && clearTimeout(F), G = !0, N = null, a(Ge, ["dblclick", "dbltap", "vdblclick"], O, { + x: ce[0], + y: ce[1] + })) : (F = setTimeout(function() { + G || a(Ge, ["oneclick", "onetap", "voneclick"], O, { + x: ce[0], + y: ce[1] + }); + }, Te.multiClickDebounceTime()), N = O.timeStamp)), Ge == null && !t.dragData.didDrag && !t.hoverData.selecting && !t.hoverData.dragged && !n(O) && (Te.$(r).unselect(["tapunselect"]), be.length > 0 && t.redrawHint("eles", !0), t.dragData.possibleDragElements = be = Te.collection()), _e == Ge && !t.dragData.didDrag && !t.hoverData.selecting && _e != null && _e._private.selectable && (t.hoverData.dragging || (Te.selectionType() === "additive" || Qe ? _e.selected() ? _e.unselect(["tapunselect"]) : _e.select(["tapselect"]) : Qe || (Te.$(r).unmerge(_e).unselect(["tapunselect"]), _e.select(["tapselect"]))), t.redrawHint("eles", !0)), t.hoverData.selecting) { + var ot = Te.collection(t.getAllInBox(ye[0], ye[1], ye[2], ye[3])); + t.redrawHint("select", !0), ot.length > 0 && t.redrawHint("eles", !0), Te.emit({ + type: "boxend", + originalEvent: O, + position: { + x: ce[0], + y: ce[1] + } + }); + var Ke = function(Rt) { + return Rt.selectable() && !Rt.selected(); + }; + Te.selectionType() === "additive" || Qe || Te.$(r).unmerge(ot).unselect(), ot.emit("box").stdFilter(Ke).select().emit("boxselect"), t.redraw(); + } + if (t.hoverData.dragging && (t.hoverData.dragging = !1, t.redrawHint("select", !0), t.redrawHint("eles", !0), t.redraw()), !ye[4]) { + t.redrawHint("drag", !0), t.redrawHint("eles", !0); + var Je = Ge && Ge.grabbed(); + p(be), Je && (Ge.emit("freeon"), be.emit("free"), t.dragData.didDrag && (Ge.emit("dragfreeon"), be.emit("dragfree"))); + } + } + ye[4] = 0, t.hoverData.down = null, t.hoverData.cxtStarted = !1, t.hoverData.draggingEles = !1, t.hoverData.selecting = !1, t.hoverData.isOverThresholdDrag = !1, t.dragData.didDrag = !1, t.hoverData.dragged = !1, t.hoverData.dragDelta = [], t.hoverData.mdownPos = null, t.hoverData.mdownGPos = null; + } + }, !1); + var X = function(O) { + if (!t.scrollingPage) { + var oe = t.cy, Te = oe.zoom(), ce = oe.pan(), ye = t.projectIntoViewport(O.clientX, O.clientY), _e = [ye[0] * Te + ce.x, ye[1] * Te + ce.y]; + if (t.hoverData.draggingEles || t.hoverData.dragging || t.hoverData.cxtStarted || k()) { + O.preventDefault(); + return; + } + if (oe.panningEnabled() && oe.userPanningEnabled() && oe.zoomingEnabled() && oe.userZoomingEnabled()) { + O.preventDefault(), t.data.wheelZooming = !0, clearTimeout(t.data.wheelTimeout), t.data.wheelTimeout = setTimeout(function() { + t.data.wheelZooming = !1, t.redrawHint("eles", !0), t.redraw(); + }, 150); + var be; + O.deltaY != null ? be = O.deltaY / -250 : O.wheelDeltaY != null ? be = O.wheelDeltaY / 1e3 : be = O.wheelDelta / 1e3, be = be * t.wheelSensitivity; + var Ge = O.deltaMode === 1; + Ge && (be *= 33); + var Qe = oe.zoom() * Math.pow(10, be); + O.type === "gesturechange" && (Qe = t.gestureStartZoom * O.scale), oe.zoom({ + level: Qe, + renderedPosition: { + x: _e[0], + y: _e[1] + } + }), oe.emit(O.type === "gesturechange" ? "pinchzoom" : "scrollzoom"); + } + } + }; + t.registerBinding(t.container, "wheel", X, !0), t.registerBinding(e, "scroll", function(O) { + t.scrollingPage = !0, clearTimeout(t.scrollingPageTimeout), t.scrollingPageTimeout = setTimeout(function() { + t.scrollingPage = !1; + }, 250); + }, !0), t.registerBinding(t.container, "gesturestart", function(O) { + t.gestureStartZoom = t.cy.zoom(), t.hasTouchStarted || O.preventDefault(); + }, !0), t.registerBinding(t.container, "gesturechange", function(he) { + t.hasTouchStarted || X(he); + }, !0), t.registerBinding(t.container, "mouseout", function(O) { + var oe = t.projectIntoViewport(O.clientX, O.clientY); + t.cy.emit({ + originalEvent: O, + type: "mouseout", + position: { + x: oe[0], + y: oe[1] + } + }); + }, !1), t.registerBinding(t.container, "mouseover", function(O) { + var oe = t.projectIntoViewport(O.clientX, O.clientY); + t.cy.emit({ + originalEvent: O, + type: "mouseover", + position: { + x: oe[0], + y: oe[1] + } + }); + }, !1); + var B, re, K, W, ae, ue, me, ie, ge, Ee, Ce, we, De, se = function(O, oe, Te, ce) { + return Math.sqrt((Te - O) * (Te - O) + (ce - oe) * (ce - oe)); + }, xe = function(O, oe, Te, ce) { + return (Te - O) * (Te - O) + (ce - oe) * (ce - oe); + }, Le; + t.registerBinding(t.container, "touchstart", Le = function(O) { + if (t.hasTouchStarted = !0, !!D(O)) { + m(), t.touchData.capture = !0, t.data.bgActivePosistion = void 0; + var oe = t.cy, Te = t.touchData.now, ce = t.touchData.earlier; + if (O.touches[0]) { + var ye = t.projectIntoViewport(O.touches[0].clientX, O.touches[0].clientY); + Te[0] = ye[0], Te[1] = ye[1]; + } + if (O.touches[1]) { + var ye = t.projectIntoViewport(O.touches[1].clientX, O.touches[1].clientY); + Te[2] = ye[0], Te[3] = ye[1]; + } + if (O.touches[2]) { + var ye = t.projectIntoViewport(O.touches[2].clientX, O.touches[2].clientY); + Te[4] = ye[0], Te[5] = ye[1]; + } + if (O.touches[1]) { + t.touchData.singleTouchMoved = !0, p(t.dragData.touchDragEles); + var _e = t.findContainerClientCoords(); + ge = _e[0], Ee = _e[1], Ce = _e[2], we = _e[3], B = O.touches[0].clientX - ge, re = O.touches[0].clientY - Ee, K = O.touches[1].clientX - ge, W = O.touches[1].clientY - Ee, De = 0 <= B && B <= Ce && 0 <= K && K <= Ce && 0 <= re && re <= we && 0 <= W && W <= we; + var be = oe.pan(), Ge = oe.zoom(); + ae = se(B, re, K, W), ue = xe(B, re, K, W), me = [(B + K) / 2, (re + W) / 2], ie = [(me[0] - be.x) / Ge, (me[1] - be.y) / Ge]; + var Qe = 200, ft = Qe * Qe; + if (ue < ft && !O.touches[2]) { + var qe = t.findNearestElement(Te[0], Te[1], !0, !0), ot = t.findNearestElement(Te[2], Te[3], !0, !0); + qe && qe.isNode() ? (qe.activate().emit({ + originalEvent: O, + type: "cxttapstart", + position: { + x: Te[0], + y: Te[1] + } + }), t.touchData.start = qe) : ot && ot.isNode() ? (ot.activate().emit({ + originalEvent: O, + type: "cxttapstart", + position: { + x: Te[0], + y: Te[1] + } + }), t.touchData.start = ot) : oe.emit({ + originalEvent: O, + type: "cxttapstart", + position: { + x: Te[0], + y: Te[1] + } + }), t.touchData.start && (t.touchData.start._private.grabbed = !1), t.touchData.cxt = !0, t.touchData.cxtDragged = !1, t.data.bgActivePosistion = void 0, t.redraw(); + return; + } + } + if (O.touches[2]) + oe.boxSelectionEnabled() && O.preventDefault(); + else if (!O.touches[1]) { + if (O.touches[0]) { + var Ke = t.findNearestElements(Te[0], Te[1], !0, !0), Je = Ke[0]; + if (Je != null && (Je.activate(), t.touchData.start = Je, t.touchData.starts = Ke, t.nodeIsGrabbable(Je))) { + var Ct = t.dragData.touchDragEles = oe.collection(), Rt = null; + t.redrawHint("eles", !0), t.redrawHint("drag", !0), Je.selected() ? (Rt = oe.$(function(_t) { + return _t.selected() && t.nodeIsGrabbable(_t); + }), c(Rt, { + addToList: Ct + })) : y(Je, { + addToList: Ct + }), f(Je); + var ar = function(Er) { + return { + originalEvent: O, + type: Er, + position: { + x: Te[0], + y: Te[1] + } + }; + }; + Je.emit(ar("grabon")), Rt ? Rt.forEach(function(_t) { + _t.emit(ar("grab")); + }) : Je.emit(ar("grab")); + } + a(Je, ["touchstart", "tapstart", "vmousedown"], O, { + x: Te[0], + y: Te[1] + }), Je == null && (t.data.bgActivePosistion = { + x: ye[0], + y: ye[1] + }, t.redrawHint("select", !0), t.redraw()), t.touchData.singleTouchMoved = !1, t.touchData.singleTouchStartTime = +/* @__PURE__ */ new Date(), clearTimeout(t.touchData.tapholdTimeout), t.touchData.tapholdTimeout = setTimeout(function() { + t.touchData.singleTouchMoved === !1 && !t.pinching && !t.touchData.selecting && a(t.touchData.start, ["taphold"], O, { + x: Te[0], + y: Te[1] + }); + }, t.tapholdDuration); + } + } + if (O.touches.length >= 1) { + for (var nr = t.touchData.startPosition = [null, null, null, null, null, null], kt = 0; kt < Te.length; kt++) + nr[kt] = ce[kt] = Te[kt]; + var Jt = O.touches[0]; + t.touchData.startGPosition = [Jt.clientX, Jt.clientY]; + } + } + }, !1); + var Se; + t.registerBinding(window, "touchmove", Se = function(O) { + var oe = t.touchData.capture; + if (!(!oe && !D(O))) { + var Te = t.selection, ce = t.cy, ye = t.touchData.now, _e = t.touchData.earlier, be = ce.zoom(); + if (O.touches[0]) { + var Ge = t.projectIntoViewport(O.touches[0].clientX, O.touches[0].clientY); + ye[0] = Ge[0], ye[1] = Ge[1]; + } + if (O.touches[1]) { + var Ge = t.projectIntoViewport(O.touches[1].clientX, O.touches[1].clientY); + ye[2] = Ge[0], ye[3] = Ge[1]; + } + if (O.touches[2]) { + var Ge = t.projectIntoViewport(O.touches[2].clientX, O.touches[2].clientY); + ye[4] = Ge[0], ye[5] = Ge[1]; + } + var Qe = t.touchData.startGPosition, ft; + if (oe && O.touches[0] && Qe) { + for (var qe = [], ot = 0; ot < ye.length; ot++) + qe[ot] = ye[ot] - _e[ot]; + var Ke = O.touches[0].clientX - Qe[0], Je = Ke * Ke, Ct = O.touches[0].clientY - Qe[1], Rt = Ct * Ct, ar = Je + Rt; + ft = ar >= t.touchTapThreshold2; + } + if (oe && t.touchData.cxt) { + O.preventDefault(); + var nr = O.touches[0].clientX - ge, kt = O.touches[0].clientY - Ee, Jt = O.touches[1].clientX - ge, _t = O.touches[1].clientY - Ee, Er = xe(nr, kt, Jt, _t), Rr = Er / ue, xa = 150, Xr = xa * xa, Ta = 1.5, Jn = Ta * Ta; + if (Rr >= Jn || Er >= Xr) { + t.touchData.cxt = !1, t.data.bgActivePosistion = void 0, t.redrawHint("select", !0); + var Wr = { + originalEvent: O, + type: "cxttapend", + position: { + x: ye[0], + y: ye[1] + } + }; + t.touchData.start ? (t.touchData.start.unactivate().emit(Wr), t.touchData.start = null) : ce.emit(Wr); + } + } + if (oe && t.touchData.cxt) { + var Wr = { + originalEvent: O, + type: "cxtdrag", + position: { + x: ye[0], + y: ye[1] + } + }; + t.data.bgActivePosistion = void 0, t.redrawHint("select", !0), t.touchData.start ? t.touchData.start.emit(Wr) : ce.emit(Wr), t.touchData.start && (t.touchData.start._private.grabbed = !1), t.touchData.cxtDragged = !0; + var Xt = t.findNearestElement(ye[0], ye[1], !0, !0); + (!t.touchData.cxtOver || Xt !== t.touchData.cxtOver) && (t.touchData.cxtOver && t.touchData.cxtOver.emit({ + originalEvent: O, + type: "cxtdragout", + position: { + x: ye[0], + y: ye[1] + } + }), t.touchData.cxtOver = Xt, Xt && Xt.emit({ + originalEvent: O, + type: "cxtdragover", + position: { + x: ye[0], + y: ye[1] + } + })); + } else if (oe && O.touches[2] && ce.boxSelectionEnabled()) + O.preventDefault(), t.data.bgActivePosistion = void 0, this.lastThreeTouch = +/* @__PURE__ */ new Date(), t.touchData.selecting || ce.emit({ + originalEvent: O, + type: "boxstart", + position: { + x: ye[0], + y: ye[1] + } + }), t.touchData.selecting = !0, t.touchData.didSelect = !0, Te[4] = 1, !Te || Te.length === 0 || Te[0] === void 0 ? (Te[0] = (ye[0] + ye[2] + ye[4]) / 3, Te[1] = (ye[1] + ye[3] + ye[5]) / 3, Te[2] = (ye[0] + ye[2] + ye[4]) / 3 + 1, Te[3] = (ye[1] + ye[3] + ye[5]) / 3 + 1) : (Te[2] = (ye[0] + ye[2] + ye[4]) / 3, Te[3] = (ye[1] + ye[3] + ye[5]) / 3), t.redrawHint("select", !0), t.redraw(); + else if (oe && O.touches[1] && !t.touchData.didSelect && ce.zoomingEnabled() && ce.panningEnabled() && ce.userZoomingEnabled() && ce.userPanningEnabled()) { + O.preventDefault(), t.data.bgActivePosistion = void 0, t.redrawHint("select", !0); + var Ut = t.dragData.touchDragEles; + if (Ut) { + t.redrawHint("drag", !0); + for (var Wt = 0; Wt < Ut.length; Wt++) { + var jn = Ut[Wt]._private; + jn.grabbed = !1, jn.rscratch.inDragLayer = !1; + } + } + var cr = t.touchData.start, nr = O.touches[0].clientX - ge, kt = O.touches[0].clientY - Ee, Jt = O.touches[1].clientX - ge, _t = O.touches[1].clientY - Ee, Bl = se(nr, kt, Jt, _t), op = Bl / ae; + if (De) { + var lp = nr - B, up = kt - re, fp = Jt - K, hp = _t - W, vp = (lp + fp) / 2, cp = (up + hp) / 2, rn = ce.zoom(), Wi = rn * op, ei = ce.pan(), Fl = ie[0] * rn + ei.x, Gl = ie[1] * rn + ei.y, dp = { + x: -Wi / rn * (Fl - ei.x - vp) + Fl, + y: -Wi / rn * (Gl - ei.y - cp) + Gl + }; + if (cr && cr.active()) { + var Ut = t.dragData.touchDragEles; + p(Ut), t.redrawHint("drag", !0), t.redrawHint("eles", !0), cr.unactivate().emit("freeon"), Ut.emit("free"), t.dragData.didDrag && (cr.emit("dragfreeon"), Ut.emit("dragfree")); + } + ce.viewport({ + zoom: Wi, + pan: dp, + cancelOnFailedZoom: !0 + }), ce.emit("pinchzoom"), ae = Bl, B = nr, re = kt, K = Jt, W = _t, t.pinching = !0; + } + if (O.touches[0]) { + var Ge = t.projectIntoViewport(O.touches[0].clientX, O.touches[0].clientY); + ye[0] = Ge[0], ye[1] = Ge[1]; + } + if (O.touches[1]) { + var Ge = t.projectIntoViewport(O.touches[1].clientX, O.touches[1].clientY); + ye[2] = Ge[0], ye[3] = Ge[1]; + } + if (O.touches[2]) { + var Ge = t.projectIntoViewport(O.touches[2].clientX, O.touches[2].clientY); + ye[4] = Ge[0], ye[5] = Ge[1]; + } + } else if (O.touches[0] && !t.touchData.didSelect) { + var ir = t.touchData.start, qi = t.touchData.last, Xt; + if (!t.hoverData.draggingEles && !t.swipePanning && (Xt = t.findNearestElement(ye[0], ye[1], !0, !0)), oe && ir != null && O.preventDefault(), oe && ir != null && t.nodeIsDraggable(ir)) + if (ft) { + var Ut = t.dragData.touchDragEles, zl = !t.dragData.didDrag; + zl && c(Ut, { + inDragLayer: !0 + }), t.dragData.didDrag = !0; + var an = { + x: 0, + y: 0 + }; + if (R(qe[0]) && R(qe[1]) && (an.x += qe[0], an.y += qe[1], zl)) { + t.redrawHint("eles", !0); + var sr = t.touchData.dragDelta; + sr && R(sr[0]) && R(sr[1]) && (an.x += sr[0], an.y += sr[1]); + } + t.hoverData.draggingEles = !0, Ut.silentShift(an).emit("position drag"), t.redrawHint("drag", !0), t.touchData.startPosition[0] == _e[0] && t.touchData.startPosition[1] == _e[1] && t.redrawHint("eles", !0), t.redraw(); + } else { + var sr = t.touchData.dragDelta = t.touchData.dragDelta || []; + sr.length === 0 ? (sr.push(qe[0]), sr.push(qe[1])) : (sr[0] += qe[0], sr[1] += qe[1]); + } + if (a(ir || Xt, ["touchmove", "tapdrag", "vmousemove"], O, { + x: ye[0], + y: ye[1] + }), (!ir || !ir.grabbed()) && Xt != qi && (qi && qi.emit({ + originalEvent: O, + type: "tapdragout", + position: { + x: ye[0], + y: ye[1] + } + }), Xt && Xt.emit({ + originalEvent: O, + type: "tapdragover", + position: { + x: ye[0], + y: ye[1] + } + })), t.touchData.last = Xt, oe) + for (var Wt = 0; Wt < ye.length; Wt++) + ye[Wt] && t.touchData.startPosition[Wt] && ft && (t.touchData.singleTouchMoved = !0); + if (oe && (ir == null || ir.pannable()) && ce.panningEnabled() && ce.userPanningEnabled()) { + var gp = i(ir, t.touchData.starts); + gp && (O.preventDefault(), t.data.bgActivePosistion || (t.data.bgActivePosistion = jr(t.touchData.startPosition)), t.swipePanning ? (ce.panBy({ + x: qe[0] * be, + y: qe[1] * be + }), ce.emit("dragpan")) : ft && (t.swipePanning = !0, ce.panBy({ + x: Ke * be, + y: Ct * be + }), ce.emit("dragpan"), ir && (ir.unactivate(), t.redrawHint("select", !0), t.touchData.start = null))); + var Ge = t.projectIntoViewport(O.touches[0].clientX, O.touches[0].clientY); + ye[0] = Ge[0], ye[1] = Ge[1]; + } + } + for (var ot = 0; ot < ye.length; ot++) + _e[ot] = ye[ot]; + oe && O.touches.length > 0 && !t.hoverData.draggingEles && !t.swipePanning && t.data.bgActivePosistion != null && (t.data.bgActivePosistion = void 0, t.redrawHint("select", !0), t.redraw()); + } + }, !1); + var Oe; + t.registerBinding(e, "touchcancel", Oe = function(O) { + var oe = t.touchData.start; + t.touchData.capture = !1, oe && oe.unactivate(); + }); + var Fe, Xe, Ie, Me; + if (t.registerBinding(e, "touchend", Fe = function(O) { + var oe = t.touchData.start, Te = t.touchData.capture; + if (Te) + O.touches.length === 0 && (t.touchData.capture = !1), O.preventDefault(); + else + return; + var ce = t.selection; + t.swipePanning = !1, t.hoverData.draggingEles = !1; + var ye = t.cy, _e = ye.zoom(), be = t.touchData.now, Ge = t.touchData.earlier; + if (O.touches[0]) { + var Qe = t.projectIntoViewport(O.touches[0].clientX, O.touches[0].clientY); + be[0] = Qe[0], be[1] = Qe[1]; + } + if (O.touches[1]) { + var Qe = t.projectIntoViewport(O.touches[1].clientX, O.touches[1].clientY); + be[2] = Qe[0], be[3] = Qe[1]; + } + if (O.touches[2]) { + var Qe = t.projectIntoViewport(O.touches[2].clientX, O.touches[2].clientY); + be[4] = Qe[0], be[5] = Qe[1]; + } + oe && oe.unactivate(); + var ft; + if (t.touchData.cxt) { + if (ft = { + originalEvent: O, + type: "cxttapend", + position: { + x: be[0], + y: be[1] + } + }, oe ? oe.emit(ft) : ye.emit(ft), !t.touchData.cxtDragged) { + var qe = { + originalEvent: O, + type: "cxttap", + position: { + x: be[0], + y: be[1] + } + }; + oe ? oe.emit(qe) : ye.emit(qe); + } + t.touchData.start && (t.touchData.start._private.grabbed = !1), t.touchData.cxt = !1, t.touchData.start = null, t.redraw(); + return; + } + if (!O.touches[2] && ye.boxSelectionEnabled() && t.touchData.selecting) { + t.touchData.selecting = !1; + var ot = ye.collection(t.getAllInBox(ce[0], ce[1], ce[2], ce[3])); + ce[0] = void 0, ce[1] = void 0, ce[2] = void 0, ce[3] = void 0, ce[4] = 0, t.redrawHint("select", !0), ye.emit({ + type: "boxend", + originalEvent: O, + position: { + x: be[0], + y: be[1] + } + }); + var Ke = function(Xr) { + return Xr.selectable() && !Xr.selected(); + }; + ot.emit("box").stdFilter(Ke).select().emit("boxselect"), ot.nonempty() && t.redrawHint("eles", !0), t.redraw(); + } + if (oe != null && oe.unactivate(), O.touches[2]) + t.data.bgActivePosistion = void 0, t.redrawHint("select", !0); + else if (!O.touches[1]) { + if (!O.touches[0]) { + if (!O.touches[0]) { + t.data.bgActivePosistion = void 0, t.redrawHint("select", !0); + var Je = t.dragData.touchDragEles; + if (oe != null) { + var Ct = oe._private.grabbed; + p(Je), t.redrawHint("drag", !0), t.redrawHint("eles", !0), Ct && (oe.emit("freeon"), Je.emit("free"), t.dragData.didDrag && (oe.emit("dragfreeon"), Je.emit("dragfree"))), a(oe, ["touchend", "tapend", "vmouseup", "tapdragout"], O, { + x: be[0], + y: be[1] + }), oe.unactivate(), t.touchData.start = null; + } else { + var Rt = t.findNearestElement(be[0], be[1], !0, !0); + a(Rt, ["touchend", "tapend", "vmouseup", "tapdragout"], O, { + x: be[0], + y: be[1] + }); + } + var ar = t.touchData.startPosition[0] - be[0], nr = ar * ar, kt = t.touchData.startPosition[1] - be[1], Jt = kt * kt, _t = nr + Jt, Er = _t * _e * _e; + t.touchData.singleTouchMoved || (oe || ye.$(":selected").unselect(["tapunselect"]), a(oe, ["tap", "vclick"], O, { + x: be[0], + y: be[1] + }), Xe = !1, O.timeStamp - Me <= ye.multiClickDebounceTime() ? (Ie && clearTimeout(Ie), Xe = !0, Me = null, a(oe, ["dbltap", "vdblclick"], O, { + x: be[0], + y: be[1] + })) : (Ie = setTimeout(function() { + Xe || a(oe, ["onetap", "voneclick"], O, { + x: be[0], + y: be[1] + }); + }, ye.multiClickDebounceTime()), Me = O.timeStamp)), oe != null && !t.dragData.didDrag && oe._private.selectable && Er < t.touchTapThreshold2 && !t.pinching && (ye.selectionType() === "single" ? (ye.$(r).unmerge(oe).unselect(["tapunselect"]), oe.select(["tapselect"])) : oe.selected() ? oe.unselect(["tapunselect"]) : oe.select(["tapselect"]), t.redrawHint("eles", !0)), t.touchData.singleTouchMoved = !0; + } + } + } + for (var Rr = 0; Rr < be.length; Rr++) + Ge[Rr] = be[Rr]; + t.dragData.didDrag = !1, O.touches.length === 0 && (t.touchData.dragDelta = [], t.touchData.startPosition = [null, null, null, null, null, null], t.touchData.startGPosition = null, t.touchData.didSelect = !1), O.touches.length < 2 && (O.touches.length === 1 && (t.touchData.startGPosition = [O.touches[0].clientX, O.touches[0].clientY]), t.pinching = !1, t.redrawHint("eles", !0), t.redraw()); + }, !1), typeof TouchEvent > "u") { + var Ue = [], ze = function(O) { + return { + clientX: O.clientX, + clientY: O.clientY, + force: 1, + identifier: O.pointerId, + pageX: O.pageX, + pageY: O.pageY, + radiusX: O.width / 2, + radiusY: O.height / 2, + screenX: O.screenX, + screenY: O.screenY, + target: O.target + }; + }, Be = function(O) { + return { + event: O, + touch: ze(O) + }; + }, $e = function(O) { + Ue.push(Be(O)); + }, rt = function(O) { + for (var oe = 0; oe < Ue.length; oe++) { + var Te = Ue[oe]; + if (Te.event.pointerId === O.pointerId) { + Ue.splice(oe, 1); + return; + } + } + }, je = function(O) { + var oe = Ue.filter(function(Te) { + return Te.event.pointerId === O.pointerId; + })[0]; + oe.event = O, oe.touch = ze(O); + }, We = function(O) { + O.touches = Ue.map(function(oe) { + return oe.touch; + }); + }, et = function(O) { + return O.pointerType === "mouse" || O.pointerType === 4; + }; + t.registerBinding(t.container, "pointerdown", function(he) { + et(he) || (he.preventDefault(), $e(he), We(he), Le(he)); + }), t.registerBinding(t.container, "pointerup", function(he) { + et(he) || (rt(he), We(he), Fe(he)); + }), t.registerBinding(t.container, "pointercancel", function(he) { + et(he) || (rt(he), We(he), Oe(he)); + }), t.registerBinding(t.container, "pointermove", function(he) { + et(he) || (he.preventDefault(), je(he), We(he), Se(he)); + }); + } + }; + var mr = {}; + mr.generatePolygon = function(t, e) { + return this.nodeShapes[t] = { + renderer: this, + name: t, + points: e, + draw: function(a, n, i, s, o) { + this.renderer.nodeShapeImpl("polygon", a, n, i, s, o, this.points); + }, + intersectLine: function(a, n, i, s, o, u, l) { + return Ba(o, u, this.points, a, n, i / 2, s / 2, l); + }, + checkPoint: function(a, n, i, s, o, u, l) { + return pr(a, n, this.points, u, l, s, o, [0, -1], i); + } + }; + }, mr.generateEllipse = function() { + return this.nodeShapes.ellipse = { + renderer: this, + name: "ellipse", + draw: function(e, r, a, n, i) { + this.renderer.nodeShapeImpl(this.name, e, r, a, n, i); + }, + intersectLine: function(e, r, a, n, i, s, o) { + return Rf(i, s, e, r, a / 2 + o, n / 2 + o); + }, + checkPoint: function(e, r, a, n, i, s, o) { + return Gr(e, r, n, i, s, o, a); + } + }; + }, mr.generateRoundPolygon = function(t, e) { + for (var r = new Array(e.length * 2), a = 0; a < e.length / 2; a++) { + var n = a * 2, i = void 0; + a < e.length / 2 - 1 ? i = (a + 1) * 2 : i = 0, r[a * 4] = e[n], r[a * 4 + 1] = e[n + 1]; + var s = e[i] - e[n], o = e[i + 1] - e[n + 1], u = Math.sqrt(s * s + o * o); + r[a * 4 + 2] = s / u, r[a * 4 + 3] = o / u; + } + return this.nodeShapes[t] = { + renderer: this, + name: t, + points: r, + draw: function(f, h, v, d, c) { + this.renderer.nodeShapeImpl("round-polygon", f, h, v, d, c, this.points); + }, + intersectLine: function(f, h, v, d, c, y, p) { + return kf(c, y, this.points, f, h, v, d); + }, + checkPoint: function(f, h, v, d, c, y, p) { + return Mf(f, h, this.points, y, p, d, c); + } + }; + }, mr.generateRoundRectangle = function() { + return this.nodeShapes["round-rectangle"] = this.nodeShapes.roundrectangle = { + renderer: this, + name: "round-rectangle", + points: $t(4, 0), + draw: function(e, r, a, n, i) { + this.renderer.nodeShapeImpl(this.name, e, r, a, n, i); + }, + intersectLine: function(e, r, a, n, i, s, o) { + return Cs(i, s, e, r, a, n, o); + }, + checkPoint: function(e, r, a, n, i, s, o) { + var u = Fa(n, i), l = u * 2; + return !!(pr(e, r, this.points, s, o, n, i - l, [0, -1], a) || pr(e, r, this.points, s, o, n - l, i, [0, -1], a) || Gr(e, r, l, l, s - n / 2 + u, o - i / 2 + u, a) || Gr(e, r, l, l, s + n / 2 - u, o - i / 2 + u, a) || Gr(e, r, l, l, s + n / 2 - u, o + i / 2 - u, a) || Gr(e, r, l, l, s - n / 2 + u, o + i / 2 - u, a)); + } + }; + }, mr.generateCutRectangle = function() { + return this.nodeShapes["cut-rectangle"] = this.nodeShapes.cutrectangle = { + renderer: this, + name: "cut-rectangle", + cornerLength: Ss(), + points: $t(4, 0), + draw: function(e, r, a, n, i) { + this.renderer.nodeShapeImpl(this.name, e, r, a, n, i); + }, + generateCutTrianglePts: function(e, r, a, n) { + var i = this.cornerLength, s = r / 2, o = e / 2, u = a - o, l = a + o, f = n - s, h = n + s; + return { + topLeft: [u, f + i, u + i, f, u + i, f + i], + topRight: [l - i, f, l, f + i, l - i, f + i], + bottomRight: [l, h - i, l - i, h, l - i, h - i], + bottomLeft: [u + i, h, u, h - i, u + i, h - i] + }; + }, + intersectLine: function(e, r, a, n, i, s, o) { + var u = this.generateCutTrianglePts(a + 2 * o, n + 2 * o, e, r), l = [].concat.apply([], [u.topLeft.splice(0, 4), u.topRight.splice(0, 4), u.bottomRight.splice(0, 4), u.bottomLeft.splice(0, 4)]); + return Ba(i, s, l, e, r); + }, + checkPoint: function(e, r, a, n, i, s, o) { + if (pr(e, r, this.points, s, o, n, i - 2 * this.cornerLength, [0, -1], a) || pr(e, r, this.points, s, o, n - 2 * this.cornerLength, i, [0, -1], a)) + return !0; + var u = this.generateCutTrianglePts(n, i, s, o); + return Ht(e, r, u.topLeft) || Ht(e, r, u.topRight) || Ht(e, r, u.bottomRight) || Ht(e, r, u.bottomLeft); + } + }; + }, mr.generateBarrel = function() { + return this.nodeShapes.barrel = { + renderer: this, + name: "barrel", + points: $t(4, 0), + draw: function(e, r, a, n, i) { + this.renderer.nodeShapeImpl(this.name, e, r, a, n, i); + }, + intersectLine: function(e, r, a, n, i, s, o) { + var u = 0.15, l = 0.5, f = 0.85, h = this.generateBarrelBezierPts(a + 2 * o, n + 2 * o, e, r), v = function(y) { + var p = ea({ + x: y[0], + y: y[1] + }, { + x: y[2], + y: y[3] + }, { + x: y[4], + y: y[5] + }, u), g = ea({ + x: y[0], + y: y[1] + }, { + x: y[2], + y: y[3] + }, { + x: y[4], + y: y[5] + }, l), m = ea({ + x: y[0], + y: y[1] + }, { + x: y[2], + y: y[3] + }, { + x: y[4], + y: y[5] + }, f); + return [y[0], y[1], p.x, p.y, g.x, g.y, m.x, m.y, y[4], y[5]]; + }, d = [].concat(v(h.topLeft), v(h.topRight), v(h.bottomRight), v(h.bottomLeft)); + return Ba(i, s, d, e, r); + }, + generateBarrelBezierPts: function(e, r, a, n) { + var i = r / 2, s = e / 2, o = a - s, u = a + s, l = n - i, f = n + i, h = di(e, r), v = h.heightOffset, d = h.widthOffset, c = h.ctrlPtOffsetPct * e, y = { + topLeft: [o, l + v, o + c, l, o + d, l], + topRight: [u - d, l, u - c, l, u, l + v], + bottomRight: [u, f - v, u - c, f, u - d, f], + bottomLeft: [o + d, f, o + c, f, o, f - v] + }; + return y.topLeft.isTop = !0, y.topRight.isTop = !0, y.bottomLeft.isBottom = !0, y.bottomRight.isBottom = !0, y; + }, + checkPoint: function(e, r, a, n, i, s, o) { + var u = di(n, i), l = u.heightOffset, f = u.widthOffset; + if (pr(e, r, this.points, s, o, n, i - 2 * l, [0, -1], a) || pr(e, r, this.points, s, o, n - 2 * f, i, [0, -1], a)) + return !0; + for (var h = this.generateBarrelBezierPts(n, i, s, o), v = function(w, k, D) { + var F = D[4], G = D[2], N = D[0], X = D[5], B = D[1], re = Math.min(F, N), K = Math.max(F, N), W = Math.min(X, B), ae = Math.max(X, B); + if (re <= w && w <= K && W <= k && k <= ae) { + var ue = Pf(F, G, N), me = Af(ue[0], ue[1], ue[2], w), ie = me.filter(function(ge) { + return 0 <= ge && ge <= 1; + }); + if (ie.length > 0) + return ie[0]; + } + return null; + }, d = Object.keys(h), c = 0; c < d.length; c++) { + var y = d[c], p = h[y], g = v(e, r, p); + if (g != null) { + var m = p[5], b = p[3], E = p[1], M = Lt(m, b, E, g); + if (p.isTop && M <= r || p.isBottom && r <= M) + return !0; + } + } + return !1; + } + }; + }, mr.generateBottomRoundrectangle = function() { + return this.nodeShapes["bottom-round-rectangle"] = this.nodeShapes.bottomroundrectangle = { + renderer: this, + name: "bottom-round-rectangle", + points: $t(4, 0), + draw: function(e, r, a, n, i) { + this.renderer.nodeShapeImpl(this.name, e, r, a, n, i); + }, + intersectLine: function(e, r, a, n, i, s, o) { + var u = e - (a / 2 + o), l = r - (n / 2 + o), f = l, h = e + (a / 2 + o), v = Cr(i, s, e, r, u, l, h, f, !1); + return v.length > 0 ? v : Cs(i, s, e, r, a, n, o); + }, + checkPoint: function(e, r, a, n, i, s, o) { + var u = Fa(n, i), l = 2 * u; + if (pr(e, r, this.points, s, o, n, i - l, [0, -1], a) || pr(e, r, this.points, s, o, n - l, i, [0, -1], a)) + return !0; + var f = n / 2 + 2 * a, h = i / 2 + 2 * a, v = [s - f, o - h, s - f, o, s + f, o, s + f, o - h]; + return !!(Ht(e, r, v) || Gr(e, r, l, l, s + n / 2 - u, o + i / 2 - u, a) || Gr(e, r, l, l, s - n / 2 + u, o + i / 2 - u, a)); + } + }; + }, mr.registerNodeShapes = function() { + var t = this.nodeShapes = {}, e = this; + this.generateEllipse(), this.generatePolygon("triangle", $t(3, 0)), this.generateRoundPolygon("round-triangle", $t(3, 0)), this.generatePolygon("rectangle", $t(4, 0)), t.square = t.rectangle, this.generateRoundRectangle(), this.generateCutRectangle(), this.generateBarrel(), this.generateBottomRoundrectangle(); + { + var r = [0, 1, 1, 0, 0, -1, -1, 0]; + this.generatePolygon("diamond", r), this.generateRoundPolygon("round-diamond", r); + } + this.generatePolygon("pentagon", $t(5, 0)), this.generateRoundPolygon("round-pentagon", $t(5, 0)), this.generatePolygon("hexagon", $t(6, 0)), this.generateRoundPolygon("round-hexagon", $t(6, 0)), this.generatePolygon("heptagon", $t(7, 0)), this.generateRoundPolygon("round-heptagon", $t(7, 0)), this.generatePolygon("octagon", $t(8, 0)), this.generateRoundPolygon("round-octagon", $t(8, 0)); + var a = new Array(20); + { + var n = vi(5, 0), i = vi(5, Math.PI / 5), s = 0.5 * (3 - Math.sqrt(5)); + s *= 1.57; + for (var o = 0; o < i.length / 2; o++) + i[o * 2] *= s, i[o * 2 + 1] *= s; + for (var o = 0; o < 20 / 4; o++) + a[o * 4] = n[o * 2], a[o * 4 + 1] = n[o * 2 + 1], a[o * 4 + 2] = i[o * 2], a[o * 4 + 3] = i[o * 2 + 1]; + } + a = Ds(a), this.generatePolygon("star", a), this.generatePolygon("vee", [-1, -1, 0, -0.333, 1, -1, 0, 1]), this.generatePolygon("rhomboid", [-1, -1, 0.333, -1, 1, 1, -0.333, 1]), this.generatePolygon("right-rhomboid", [-0.333, -1, 1, -1, 0.333, 1, -1, 1]), this.nodeShapes.concavehexagon = this.generatePolygon("concave-hexagon", [-1, -0.95, -0.75, 0, -1, 0.95, 1, 0.95, 0.75, 0, 1, -0.95]); + { + var u = [-1, -1, 0.25, -1, 1, 0, 0.25, 1, -1, 1]; + this.generatePolygon("tag", u), this.generateRoundPolygon("round-tag", u); + } + t.makePolygon = function(l) { + var f = l.join("$"), h = "polygon-" + f, v; + return (v = this[h]) ? v : e.generatePolygon(h, l); + }; + }; + var Ja = {}; + Ja.timeToRender = function() { + return this.redrawTotalTime / this.redrawCount; + }, Ja.redraw = function(t) { + t = t || ys(); + var e = this; + e.averageRedrawTime === void 0 && (e.averageRedrawTime = 0), e.lastRedrawTime === void 0 && (e.lastRedrawTime = 0), e.lastDrawTime === void 0 && (e.lastDrawTime = 0), e.requestedFrame = !0, e.renderOptions = t; + }, Ja.beforeRender = function(t, e) { + if (!this.destroyed) { + e == null && xt("Priority is not optional for beforeRender"); + var r = this.beforeRenderCallbacks; + r.push({ + fn: t, + priority: e + }), r.sort(function(a, n) { + return n.priority - a.priority; + }); + } + }; + var vl = function(e, r, a) { + for (var n = e.beforeRenderCallbacks, i = 0; i < n.length; i++) + n[i].fn(r, a); + }; + Ja.startRenderLoop = function() { + var t = this, e = t.cy; + if (!t.renderLoopStarted) { + t.renderLoopStarted = !0; + var r = function a(n) { + if (!t.destroyed) { + if (!e.batching()) + if (t.requestedFrame && !t.skipFrame) { + vl(t, !0, n); + var i = gr(); + t.render(t.renderOptions); + var s = t.lastDrawTime = gr(); + t.averageRedrawTime === void 0 && (t.averageRedrawTime = s - i), t.redrawCount === void 0 && (t.redrawCount = 0), t.redrawCount++, t.redrawTotalTime === void 0 && (t.redrawTotalTime = 0); + var o = s - i; + t.redrawTotalTime += o, t.lastRedrawTime = o, t.averageRedrawTime = t.averageRedrawTime / 2 + o / 2, t.requestedFrame = !1; + } else + vl(t, !1, n); + t.skipFrame = !1, ln(a); + } + }; + ln(r); + } + }; + var dg = function(e) { + this.init(e); + }, cl = dg, ma = cl.prototype; + ma.clientFunctions = ["redrawHint", "render", "renderTo", "matchCanvasSize", "nodeShapeImpl", "arrowShapeImpl"], ma.init = function(t) { + var e = this; + e.options = t, e.cy = t.cy; + var r = e.container = t.cy.container(), a = e.cy.window(); + if (a) { + var n = a.document, i = n.head, s = "__________cytoscape_stylesheet", o = "__________cytoscape_container", u = n.getElementById(s) != null; + if (r.className.indexOf(o) < 0 && (r.className = (r.className || "") + " " + o), !u) { + var l = n.createElement("style"); + l.id = s, l.textContent = "." + o + " { position: relative; }", i.insertBefore(l, i.children[0]); + } + var f = a.getComputedStyle(r), h = f.getPropertyValue("position"); + h === "static" && vt("A Cytoscape container has style position:static and so can not use UI extensions properly"); + } + e.selection = [void 0, void 0, void 0, void 0, 0], e.bezierProjPcts = [0.05, 0.225, 0.4, 0.5, 0.6, 0.775, 0.95], e.hoverData = { + down: null, + last: null, + downTime: null, + triggerMode: null, + dragging: !1, + initialPan: [null, null], + capture: !1 + }, e.dragData = { + possibleDragElements: [] + }, e.touchData = { + start: null, + capture: !1, + // These 3 fields related to tap, taphold events + startPosition: [null, null, null, null, null, null], + singleTouchStartTime: null, + singleTouchMoved: !0, + now: [null, null, null, null, null, null], + earlier: [null, null, null, null, null, null] + }, e.redraws = 0, e.showFps = t.showFps, e.debug = t.debug, e.hideEdgesOnViewport = t.hideEdgesOnViewport, e.textureOnViewport = t.textureOnViewport, e.wheelSensitivity = t.wheelSensitivity, e.motionBlurEnabled = t.motionBlur, e.forcedPixelRatio = R(t.pixelRatio) ? t.pixelRatio : null, e.motionBlur = t.motionBlur, e.motionBlurOpacity = t.motionBlurOpacity, e.motionBlurTransparency = 1 - e.motionBlurOpacity, e.motionBlurPxRatio = 1, e.mbPxRBlurry = 1, e.minMbLowQualFrames = 4, e.fullQualityMb = !1, e.clearedForMotionBlur = [], e.desktopTapThreshold = t.desktopTapThreshold, e.desktopTapThreshold2 = t.desktopTapThreshold * t.desktopTapThreshold, e.touchTapThreshold = t.touchTapThreshold, e.touchTapThreshold2 = t.touchTapThreshold * t.touchTapThreshold, e.tapholdDuration = 500, e.bindings = [], e.beforeRenderCallbacks = [], e.beforeRenderPriorities = { + // higher priority execs before lower one + animations: 400, + eleCalcs: 300, + eleTxrDeq: 200, + lyrTxrDeq: 150, + lyrTxrSkip: 100 + }, e.registerNodeShapes(), e.registerArrowShapes(), e.registerCalculationListeners(); + }, ma.notify = function(t, e) { + var r = this, a = r.cy; + if (!this.destroyed) { + if (t === "init") { + r.load(); + return; + } + if (t === "destroy") { + r.destroy(); + return; + } + (t === "add" || t === "remove" || t === "move" && a.hasCompoundNodes() || t === "load" || t === "zorder" || t === "mount") && r.invalidateCachedZSortedEles(), t === "viewport" && r.redrawHint("select", !0), (t === "load" || t === "resize" || t === "mount") && (r.invalidateContainerClientCoordsCache(), r.matchCanvasSize(r.container)), r.redrawHint("eles", !0), r.redrawHint("drag", !0), this.startRenderLoop(), this.redraw(); + } + }, ma.destroy = function() { + var t = this; + t.destroyed = !0, t.cy.stopAnimationLoop(); + for (var e = 0; e < t.bindings.length; e++) { + var r = t.bindings[e], a = r, n = a.target; + (n.off || n.removeEventListener).apply(n, a.args); + } + if (t.bindings = [], t.beforeRenderCallbacks = [], t.onUpdateEleCalcsFns = [], t.removeObserver && t.removeObserver.disconnect(), t.styleObserver && t.styleObserver.disconnect(), t.resizeObserver && t.resizeObserver.disconnect(), t.labelCalcDiv) + try { + document.body.removeChild(t.labelCalcDiv); + } catch { + } + }, ma.isHeadless = function() { + return !1; + }, [Fi, fl, hl, ya, mr, Ja].forEach(function(t) { + He(ma, t); + }); + var zi = 1e3 / 60, dl = { + setupDequeueing: function(e) { + return function() { + var a = this, n = this.renderer; + if (!a.dequeueingSetup) { + a.dequeueingSetup = !0; + var i = on(function() { + n.redrawHint("eles", !0), n.redrawHint("drag", !0), n.redraw(); + }, e.deqRedrawThreshold), s = function(l, f) { + var h = gr(), v = n.averageRedrawTime, d = n.lastRedrawTime, c = [], y = n.cy.extent(), p = n.getPixelRatio(); + for (l || n.flushRenderedStyleQueue(); ; ) { + var g = gr(), m = g - h, b = g - f; + if (d < zi) { + var E = zi - (l ? v : 0); + if (b >= e.deqFastCost * E) + break; + } else if (l) { + if (m >= e.deqCost * d || m >= e.deqAvgCost * v) + break; + } else if (b >= e.deqNoDrawCost * zi) + break; + var M = e.deq(a, p, y); + if (M.length > 0) + for (var L = 0; L < M.length; L++) + c.push(M[L]); + else + break; + } + c.length > 0 && (e.onDeqd(a, c), !l && e.shouldRedraw(a, c, p, y) && i()); + }, o = e.priority || si; + n.beforeRender(s, o(a)); + } + }; + } + }, gg = /* @__PURE__ */ function() { + function t(e) { + var r = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : fn; + fe(this, t), this.idsByKey = new ur(), this.keyForId = new ur(), this.cachesByLvl = new ur(), this.lvls = [], this.getKey = e, this.doesEleInvalidateKey = r; + } + return C(t, [{ + key: "getIdsFor", + value: function(r) { + r == null && xt("Can not get id list for null key"); + var a = this.idsByKey, n = this.idsByKey.get(r); + return n || (n = new Jr(), a.set(r, n)), n; + } + }, { + key: "addIdForKey", + value: function(r, a) { + r != null && this.getIdsFor(r).add(a); + } + }, { + key: "deleteIdForKey", + value: function(r, a) { + r != null && this.getIdsFor(r).delete(a); + } + }, { + key: "getNumberOfIdsForKey", + value: function(r) { + return r == null ? 0 : this.getIdsFor(r).size; + } + }, { + key: "updateKeyMappingFor", + value: function(r) { + var a = r.id(), n = this.keyForId.get(a), i = this.getKey(r); + this.deleteIdForKey(n, a), this.addIdForKey(i, a), this.keyForId.set(a, i); + } + }, { + key: "deleteKeyMappingFor", + value: function(r) { + var a = r.id(), n = this.keyForId.get(a); + this.deleteIdForKey(n, a), this.keyForId.delete(a); + } + }, { + key: "keyHasChangedFor", + value: function(r) { + var a = r.id(), n = this.keyForId.get(a), i = this.getKey(r); + return n !== i; + } + }, { + key: "isInvalid", + value: function(r) { + return this.keyHasChangedFor(r) || this.doesEleInvalidateKey(r); + } + }, { + key: "getCachesAt", + value: function(r) { + var a = this.cachesByLvl, n = this.lvls, i = a.get(r); + return i || (i = new ur(), a.set(r, i), n.push(r)), i; + } + }, { + key: "getCache", + value: function(r, a) { + return this.getCachesAt(a).get(r); + } + }, { + key: "get", + value: function(r, a) { + var n = this.getKey(r), i = this.getCache(n, a); + return i != null && this.updateKeyMappingFor(r), i; + } + }, { + key: "getForCachedKey", + value: function(r, a) { + var n = this.keyForId.get(r.id()), i = this.getCache(n, a); + return i; + } + }, { + key: "hasCache", + value: function(r, a) { + return this.getCachesAt(a).has(r); + } + }, { + key: "has", + value: function(r, a) { + var n = this.getKey(r); + return this.hasCache(n, a); + } + }, { + key: "setCache", + value: function(r, a, n) { + n.key = r, this.getCachesAt(a).set(r, n); + } + }, { + key: "set", + value: function(r, a, n) { + var i = this.getKey(r); + this.setCache(i, a, n), this.updateKeyMappingFor(r); + } + }, { + key: "deleteCache", + value: function(r, a) { + this.getCachesAt(a).delete(r); + } + }, { + key: "delete", + value: function(r, a) { + var n = this.getKey(r); + this.deleteCache(n, a); + } + }, { + key: "invalidateKey", + value: function(r) { + var a = this; + this.lvls.forEach(function(n) { + return a.deleteCache(r, n); + }); + } + // returns true if no other eles reference the invalidated cache (n.b. other eles may need the cache with the same key) + }, { + key: "invalidate", + value: function(r) { + var a = r.id(), n = this.keyForId.get(a); + this.deleteKeyMappingFor(r); + var i = this.doesEleInvalidateKey(r); + return i && this.invalidateKey(n), i || this.getNumberOfIdsForKey(n) === 0; + } + }]), t; + }(), gl = 25, Kn = 50, Zn = -4, Vi = 3, pg = 7.99, yg = 8, mg = 1024, bg = 1024, Eg = 1024, wg = 0.2, xg = 0.8, Tg = 10, Cg = 0.15, Dg = 0.1, Sg = 0.9, Lg = 0.9, Ag = 100, Og = 1, ba = { + dequeue: "dequeue", + downscale: "downscale", + highQuality: "highQuality" + }, Ng = At({ + getKey: null, + doesEleInvalidateKey: fn, + drawElement: null, + getBoundingBox: null, + getRotationPoint: null, + getRotationOffset: null, + isVisible: cs, + allowEdgeTxrCaching: !0, + allowParentTxrCaching: !0 + }), ja = function(e, r) { + var a = this; + a.renderer = e, a.onDequeues = []; + var n = Ng(r); + He(a, n), a.lookup = new gg(n.getKey, n.doesEleInvalidateKey), a.setupDequeueing(); + }, Dt = ja.prototype; + Dt.reasons = ba, Dt.getTextureQueue = function(t) { + var e = this; + return e.eleImgCaches = e.eleImgCaches || {}, e.eleImgCaches[t] = e.eleImgCaches[t] || []; + }, Dt.getRetiredTextureQueue = function(t) { + var e = this, r = e.eleImgCaches.retired = e.eleImgCaches.retired || {}, a = r[t] = r[t] || []; + return a; + }, Dt.getElementQueue = function() { + var t = this, e = t.eleCacheQueue = t.eleCacheQueue || new Ra(function(r, a) { + return a.reqs - r.reqs; + }); + return e; + }, Dt.getElementKeyToQueue = function() { + var t = this, e = t.eleKeyToCacheQueue = t.eleKeyToCacheQueue || {}; + return e; + }, Dt.getElement = function(t, e, r, a, n) { + var i = this, s = this.renderer, o = s.cy.zoom(), u = this.lookup; + if (!e || e.w === 0 || e.h === 0 || isNaN(e.w) || isNaN(e.h) || !t.visible() || t.removed() || !i.allowEdgeTxrCaching && t.isEdge() || !i.allowParentTxrCaching && t.isParent()) + return null; + if (a == null && (a = Math.ceil(ui(o * r))), a < Zn) + a = Zn; + else if (o >= pg || a > Vi) + return null; + var l = Math.pow(2, a), f = e.h * l, h = e.w * l, v = s.eleTextBiggerThanMin(t, l); + if (!this.isVisible(t, v)) + return null; + var d = u.get(t, a); + if (d && d.invalidated && (d.invalidated = !1, d.texture.invalidatedWidth -= d.width), d) + return d; + var c; + if (f <= gl ? c = gl : f <= Kn ? c = Kn : c = Math.ceil(f / Kn) * Kn, f > Eg || h > bg) + return null; + var y = i.getTextureQueue(c), p = y[y.length - 2], g = function() { + return i.recycleTexture(c, h) || i.addTexture(c, h); + }; + p || (p = y[y.length - 1]), p || (p = g()), p.width - p.usedWidth < h && (p = g()); + for (var m = function(K) { + return K && K.scaledLabelShown === v; + }, b = n && n === ba.dequeue, E = n && n === ba.highQuality, M = n && n === ba.downscale, L, w = a + 1; w <= Vi; w++) { + var k = u.get(t, w); + if (k) { + L = k; + break; + } + } + var D = L && L.level === a + 1 ? L : null, F = function() { + p.context.drawImage(D.texture.canvas, D.x, 0, D.width, D.height, p.usedWidth, 0, h, f); + }; + if (p.context.setTransform(1, 0, 0, 1, 0, 0), p.context.clearRect(p.usedWidth, 0, h, c), m(D)) + F(); + else if (m(L)) + if (E) { + for (var G = L.level; G > a; G--) + D = i.getElement(t, e, r, G, ba.downscale); + F(); + } else + return i.queueElement(t, L.level - 1), L; + else { + var N; + if (!b && !E && !M) + for (var X = a - 1; X >= Zn; X--) { + var B = u.get(t, X); + if (B) { + N = B; + break; + } + } + if (m(N)) + return i.queueElement(t, a), N; + p.context.translate(p.usedWidth, 0), p.context.scale(l, l), this.drawElement(p.context, t, e, v, !1), p.context.scale(1 / l, 1 / l), p.context.translate(-p.usedWidth, 0); + } + return d = { + x: p.usedWidth, + texture: p, + level: a, + scale: l, + width: h, + height: f, + scaledLabelShown: v + }, p.usedWidth += Math.ceil(h + yg), p.eleCaches.push(d), u.set(t, a, d), i.checkTextureFullness(p), d; + }, Dt.invalidateElements = function(t) { + for (var e = 0; e < t.length; e++) + this.invalidateElement(t[e]); + }, Dt.invalidateElement = function(t) { + var e = this, r = e.lookup, a = [], n = r.isInvalid(t); + if (n) { + for (var i = Zn; i <= Vi; i++) { + var s = r.getForCachedKey(t, i); + s && a.push(s); + } + var o = r.invalidate(t); + if (o) + for (var u = 0; u < a.length; u++) { + var l = a[u], f = l.texture; + f.invalidatedWidth += l.width, l.invalidated = !0, e.checkTextureUtility(f); + } + e.removeFromQueue(t); + } + }, Dt.checkTextureUtility = function(t) { + t.invalidatedWidth >= wg * t.width && this.retireTexture(t); + }, Dt.checkTextureFullness = function(t) { + var e = this, r = e.getTextureQueue(t.height); + t.usedWidth / t.width > xg && t.fullnessChecks >= Tg ? xr(r, t) : t.fullnessChecks++; + }, Dt.retireTexture = function(t) { + var e = this, r = t.height, a = e.getTextureQueue(r), n = this.lookup; + xr(a, t), t.retired = !0; + for (var i = t.eleCaches, s = 0; s < i.length; s++) { + var o = i[s]; + n.deleteCache(o.key, o.level); + } + oi(i); + var u = e.getRetiredTextureQueue(r); + u.push(t); + }, Dt.addTexture = function(t, e) { + var r = this, a = r.getTextureQueue(t), n = {}; + return a.push(n), n.eleCaches = [], n.height = t, n.width = Math.max(mg, e), n.usedWidth = 0, n.invalidatedWidth = 0, n.fullnessChecks = 0, n.canvas = r.renderer.makeOffscreenCanvas(n.width, n.height), n.context = n.canvas.getContext("2d"), n; + }, Dt.recycleTexture = function(t, e) { + for (var r = this, a = r.getTextureQueue(t), n = r.getRetiredTextureQueue(t), i = 0; i < n.length; i++) { + var s = n[i]; + if (s.width >= e) + return s.retired = !1, s.usedWidth = 0, s.invalidatedWidth = 0, s.fullnessChecks = 0, oi(s.eleCaches), s.context.setTransform(1, 0, 0, 1, 0, 0), s.context.clearRect(0, 0, s.width, s.height), xr(n, s), a.push(s), s; + } + }, Dt.queueElement = function(t, e) { + var r = this, a = r.getElementQueue(), n = r.getElementKeyToQueue(), i = this.getKey(t), s = n[i]; + if (s) + s.level = Math.max(s.level, e), s.eles.merge(t), s.reqs++, a.updateItem(s); + else { + var o = { + eles: t.spawn().merge(t), + level: e, + reqs: 1, + key: i + }; + a.push(o), n[i] = o; + } + }, Dt.dequeue = function(t) { + for (var e = this, r = e.getElementQueue(), a = e.getElementKeyToQueue(), n = [], i = e.lookup, s = 0; s < Og && r.size() > 0; s++) { + var o = r.pop(), u = o.key, l = o.eles[0], f = i.hasCache(l, o.level); + if (a[u] = null, f) + continue; + n.push(o); + var h = e.getBoundingBox(l); + e.getElement(l, h, t, o.level, ba.dequeue); + } + return n; + }, Dt.removeFromQueue = function(t) { + var e = this, r = e.getElementQueue(), a = e.getElementKeyToQueue(), n = this.getKey(t), i = a[n]; + i != null && (i.eles.length === 1 ? (i.reqs = ii, r.updateItem(i), r.pop(), a[n] = null) : i.eles.unmerge(t)); + }, Dt.onDequeue = function(t) { + this.onDequeues.push(t); + }, Dt.offDequeue = function(t) { + xr(this.onDequeues, t); + }, Dt.setupDequeueing = dl.setupDequeueing({ + deqRedrawThreshold: Ag, + deqCost: Cg, + deqAvgCost: Dg, + deqNoDrawCost: Sg, + deqFastCost: Lg, + deq: function(e, r, a) { + return e.dequeue(r, a); + }, + onDeqd: function(e, r) { + for (var a = 0; a < e.onDequeues.length; a++) { + var n = e.onDequeues[a]; + n(r); + } + }, + shouldRedraw: function(e, r, a, n) { + for (var i = 0; i < r.length; i++) + for (var s = r[i].eles, o = 0; o < s.length; o++) { + var u = s[o].boundingBox(); + if (fi(u, n)) + return !0; + } + return !1; + }, + priority: function(e) { + return e.renderer.beforeRenderPriorities.eleTxrDeq; + } + }); + var Ig = 1, en = -4, Qn = 2, Mg = 3.99, Rg = 50, kg = 50, Pg = 0.15, Bg = 0.1, Fg = 0.9, Gg = 0.9, zg = 1, pl = 250, Vg = 4e3 * 4e3, Ug = !0, yl = function(e) { + var r = this, a = r.renderer = e, n = a.cy; + r.layersByLevel = {}, r.firstGet = !0, r.lastInvalidationTime = gr() - 2 * pl, r.skipping = !1, r.eleTxrDeqs = n.collection(), r.scheduleElementRefinement = on(function() { + r.refineElementTextures(r.eleTxrDeqs), r.eleTxrDeqs.unmerge(r.eleTxrDeqs); + }, kg), a.beforeRender(function(s, o) { + o - r.lastInvalidationTime <= pl ? r.skipping = !0 : r.skipping = !1; + }, a.beforeRenderPriorities.lyrTxrSkip); + var i = function(o, u) { + return u.reqs - o.reqs; + }; + r.layersQueue = new Ra(i), r.setupDequeueing(); + }, Mt = yl.prototype, ml = 0, $g = Math.pow(2, 53) - 1; + Mt.makeLayer = function(t, e) { + var r = Math.pow(2, e), a = Math.ceil(t.w * r), n = Math.ceil(t.h * r), i = this.renderer.makeOffscreenCanvas(a, n), s = { + id: ml = ++ml % $g, + bb: t, + level: e, + width: a, + height: n, + canvas: i, + context: i.getContext("2d"), + eles: [], + elesQueue: [], + reqs: 0 + }, o = s.context, u = -s.bb.x1, l = -s.bb.y1; + return o.scale(r, r), o.translate(u, l), s; + }, Mt.getLayers = function(t, e, r) { + var a = this, n = a.renderer, i = n.cy, s = i.zoom(), o = a.firstGet; + if (a.firstGet = !1, r == null) { + if (r = Math.ceil(ui(s * e)), r < en) + r = en; + else if (s >= Mg || r > Qn) + return null; + } + a.validateLayersElesOrdering(r, t); + var u = a.layersByLevel, l = Math.pow(2, r), f = u[r] = u[r] || [], h, v = a.levelIsComplete(r, t), d, c = function() { + var F = function(re) { + if (a.validateLayersElesOrdering(re, t), a.levelIsComplete(re, t)) + return d = u[re], !0; + }, G = function(re) { + if (!d) + for (var K = r + re; en <= K && K <= Qn && !F(K); K += re) + ; + }; + G(1), G(-1); + for (var N = f.length - 1; N >= 0; N--) { + var X = f[N]; + X.invalid && xr(f, X); + } + }; + if (!v) + c(); + else + return f; + var y = function() { + if (!h) { + h = Yt(); + for (var F = 0; F < t.length; F++) + ws(h, t[F].boundingBox()); + } + return h; + }, p = function(F) { + F = F || {}; + var G = F.after; + y(); + var N = h.w * l * (h.h * l); + if (N > Vg) + return null; + var X = a.makeLayer(h, r); + if (G != null) { + var B = f.indexOf(G) + 1; + f.splice(B, 0, X); + } else + (F.insert === void 0 || F.insert) && f.unshift(X); + return X; + }; + if (a.skipping && !o) + return null; + for (var g = null, m = t.length / Ig, b = !o, E = 0; E < t.length; E++) { + var M = t[E], L = M._private.rscratch, w = L.imgLayerCaches = L.imgLayerCaches || {}, k = w[r]; + if (k) { + g = k; + continue; + } + if ((!g || g.eles.length >= m || !Ts(g.bb, M.boundingBox())) && (g = p({ + insert: !0, + after: g + }), !g)) + return null; + d || b ? a.queueLayer(g, M) : a.drawEleInLayer(g, M, r, e), g.eles.push(M), w[r] = g; + } + return d || (b ? null : f); + }, Mt.getEleLevelForLayerLevel = function(t, e) { + return t; + }, Mt.drawEleInLayer = function(t, e, r, a) { + var n = this, i = this.renderer, s = t.context, o = e.boundingBox(); + o.w === 0 || o.h === 0 || !e.visible() || (r = n.getEleLevelForLayerLevel(r, a), i.setImgSmoothing(s, !1), i.drawCachedElement(s, e, null, null, r, Ug), i.setImgSmoothing(s, !0)); + }, Mt.levelIsComplete = function(t, e) { + var r = this, a = r.layersByLevel[t]; + if (!a || a.length === 0) + return !1; + for (var n = 0, i = 0; i < a.length; i++) { + var s = a[i]; + if (s.reqs > 0 || s.invalid) + return !1; + n += s.eles.length; + } + return n === e.length; + }, Mt.validateLayersElesOrdering = function(t, e) { + var r = this.layersByLevel[t]; + if (r) + for (var a = 0; a < r.length; a++) { + for (var n = r[a], i = -1, s = 0; s < e.length; s++) + if (n.eles[0] === e[s]) { + i = s; + break; + } + if (i < 0) { + this.invalidateLayer(n); + continue; + } + for (var o = i, s = 0; s < n.eles.length; s++) + if (n.eles[s] !== e[o + s]) { + this.invalidateLayer(n); + break; + } + } + }, Mt.updateElementsInLayers = function(t, e) { + for (var r = this, a = Ae(t[0]), n = 0; n < t.length; n++) + for (var i = a ? null : t[n], s = a ? t[n] : t[n].ele, o = s._private.rscratch, u = o.imgLayerCaches = o.imgLayerCaches || {}, l = en; l <= Qn; l++) { + var f = u[l]; + f && (i && r.getEleLevelForLayerLevel(f.level) !== i.level || e(f, s, i)); + } + }, Mt.haveLayers = function() { + for (var t = this, e = !1, r = en; r <= Qn; r++) { + var a = t.layersByLevel[r]; + if (a && a.length > 0) { + e = !0; + break; + } + } + return e; + }, Mt.invalidateElements = function(t) { + var e = this; + t.length !== 0 && (e.lastInvalidationTime = gr(), !(t.length === 0 || !e.haveLayers()) && e.updateElementsInLayers(t, function(a, n, i) { + e.invalidateLayer(a); + })); + }, Mt.invalidateLayer = function(t) { + if (this.lastInvalidationTime = gr(), !t.invalid) { + var e = t.level, r = t.eles, a = this.layersByLevel[e]; + xr(a, t), t.elesQueue = [], t.invalid = !0, t.replacement && (t.replacement.invalid = !0); + for (var n = 0; n < r.length; n++) { + var i = r[n]._private.rscratch.imgLayerCaches; + i && (i[e] = null); + } + } + }, Mt.refineElementTextures = function(t) { + var e = this; + e.updateElementsInLayers(t, function(a, n, i) { + var s = a.replacement; + if (s || (s = a.replacement = e.makeLayer(a.bb, a.level), s.replaces = a, s.eles = a.eles), !s.reqs) + for (var o = 0; o < s.eles.length; o++) + e.queueLayer(s, s.eles[o]); + }); + }, Mt.enqueueElementRefinement = function(t) { + this.eleTxrDeqs.merge(t), this.scheduleElementRefinement(); + }, Mt.queueLayer = function(t, e) { + var r = this, a = r.layersQueue, n = t.elesQueue, i = n.hasId = n.hasId || {}; + if (!t.replacement) { + if (e) { + if (i[e.id()]) + return; + n.push(e), i[e.id()] = !0; + } + t.reqs ? (t.reqs++, a.updateItem(t)) : (t.reqs = 1, a.push(t)); + } + }, Mt.dequeue = function(t) { + for (var e = this, r = e.layersQueue, a = [], n = 0; n < zg && r.size() !== 0; ) { + var i = r.peek(); + if (i.replacement) { + r.pop(); + continue; + } + if (i.replaces && i !== i.replaces.replacement) { + r.pop(); + continue; + } + if (i.invalid) { + r.pop(); + continue; + } + var s = i.elesQueue.shift(); + s && (e.drawEleInLayer(i, s, i.level, t), n++), a.length === 0 && a.push(!0), i.elesQueue.length === 0 && (r.pop(), i.reqs = 0, i.replaces && e.applyLayerReplacement(i), e.requestRedraw()); + } + return a; + }, Mt.applyLayerReplacement = function(t) { + var e = this, r = e.layersByLevel[t.level], a = t.replaces, n = r.indexOf(a); + if (!(n < 0 || a.invalid)) { + r[n] = t; + for (var i = 0; i < t.eles.length; i++) { + var s = t.eles[i]._private, o = s.imgLayerCaches = s.imgLayerCaches || {}; + o && (o[t.level] = t); + } + e.requestRedraw(); + } + }, Mt.requestRedraw = on(function() { + var t = this.renderer; + t.redrawHint("eles", !0), t.redrawHint("drag", !0), t.redraw(); + }, 100), Mt.setupDequeueing = dl.setupDequeueing({ + deqRedrawThreshold: Rg, + deqCost: Pg, + deqAvgCost: Bg, + deqNoDrawCost: Fg, + deqFastCost: Gg, + deq: function(e, r) { + return e.dequeue(r); + }, + onDeqd: si, + shouldRedraw: cs, + priority: function(e) { + return e.renderer.beforeRenderPriorities.lyrTxrDeq; + } + }); + var bl = {}, El; + function _g(t, e) { + for (var r = 0; r < e.length; r++) { + var a = e[r]; + t.lineTo(a.x, a.y); + } + } + function Yg(t, e, r) { + for (var a, n = 0; n < e.length; n++) { + var i = e[n]; + n === 0 && (a = i), t.lineTo(i.x, i.y); + } + t.quadraticCurveTo(r.x, r.y, a.x, a.y); + } + function wl(t, e, r) { + t.beginPath && t.beginPath(); + for (var a = e, n = 0; n < a.length; n++) { + var i = a[n]; + t.lineTo(i.x, i.y); + } + var s = r, o = r[0]; + t.moveTo(o.x, o.y); + for (var n = 1; n < s.length; n++) { + var i = s[n]; + t.lineTo(i.x, i.y); + } + t.closePath && t.closePath(); + } + function Hg(t, e, r, a, n) { + t.beginPath && t.beginPath(), t.arc(r, a, n, 0, Math.PI * 2, !1); + var i = e, s = i[0]; + t.moveTo(s.x, s.y); + for (var o = 0; o < i.length; o++) { + var u = i[o]; + t.lineTo(u.x, u.y); + } + t.closePath && t.closePath(); + } + function Xg(t, e, r, a) { + t.arc(e, r, a, 0, Math.PI * 2, !1); + } + bl.arrowShapeImpl = function(t) { + return (El || (El = { + polygon: _g, + "triangle-backcurve": Yg, + "triangle-tee": wl, + "circle-triangle": Hg, + "triangle-cross": wl, + circle: Xg + }))[t]; + }; + var vr = {}; + vr.drawElement = function(t, e, r, a, n, i) { + var s = this; + e.isNode() ? s.drawNode(t, e, r, a, n, i) : s.drawEdge(t, e, r, a, n, i); + }, vr.drawElementOverlay = function(t, e) { + var r = this; + e.isNode() ? r.drawNodeOverlay(t, e) : r.drawEdgeOverlay(t, e); + }, vr.drawElementUnderlay = function(t, e) { + var r = this; + e.isNode() ? r.drawNodeUnderlay(t, e) : r.drawEdgeUnderlay(t, e); + }, vr.drawCachedElementPortion = function(t, e, r, a, n, i, s, o) { + var u = this, l = r.getBoundingBox(e); + if (!(l.w === 0 || l.h === 0)) { + var f = r.getElement(e, l, a, n, i); + if (f != null) { + var h = o(u, e); + if (h === 0) + return; + var v = s(u, e), d = l.x1, c = l.y1, y = l.w, p = l.h, g, m, b, E, M; + if (v !== 0) { + var L = r.getRotationPoint(e); + b = L.x, E = L.y, t.translate(b, E), t.rotate(v), M = u.getImgSmoothing(t), M || u.setImgSmoothing(t, !0); + var w = r.getRotationOffset(e); + g = w.x, m = w.y; + } else + g = d, m = c; + var k; + h !== 1 && (k = t.globalAlpha, t.globalAlpha = k * h), t.drawImage(f.texture.canvas, f.x, 0, f.width, f.height, g, m, y, p), h !== 1 && (t.globalAlpha = k), v !== 0 && (t.rotate(-v), t.translate(-b, -E), M || u.setImgSmoothing(t, !1)); + } else + r.drawElement(t, e); + } + }; + var Wg = function() { + return 0; + }, qg = function(e, r) { + return e.getTextAngle(r, null); + }, Kg = function(e, r) { + return e.getTextAngle(r, "source"); + }, Zg = function(e, r) { + return e.getTextAngle(r, "target"); + }, Qg = function(e, r) { + return r.effectiveOpacity(); + }, Ui = function(e, r) { + return r.pstyle("text-opacity").pfValue * r.effectiveOpacity(); + }; + vr.drawCachedElement = function(t, e, r, a, n, i) { + var s = this, o = s.data, u = o.eleTxrCache, l = o.lblTxrCache, f = o.slbTxrCache, h = o.tlbTxrCache, v = e.boundingBox(), d = i === !0 ? u.reasons.highQuality : null; + if (!(v.w === 0 || v.h === 0 || !e.visible()) && (!a || fi(v, a))) { + var c = e.isEdge(), y = e.element()._private.rscratch.badLine; + s.drawElementUnderlay(t, e), s.drawCachedElementPortion(t, e, u, r, n, d, Wg, Qg), (!c || !y) && s.drawCachedElementPortion(t, e, l, r, n, d, qg, Ui), c && !y && (s.drawCachedElementPortion(t, e, f, r, n, d, Kg, Ui), s.drawCachedElementPortion(t, e, h, r, n, d, Zg, Ui)), s.drawElementOverlay(t, e); + } + }, vr.drawElements = function(t, e) { + for (var r = this, a = 0; a < e.length; a++) { + var n = e[a]; + r.drawElement(t, n); + } + }, vr.drawCachedElements = function(t, e, r, a) { + for (var n = this, i = 0; i < e.length; i++) { + var s = e[i]; + n.drawCachedElement(t, s, r, a); + } + }, vr.drawCachedNodes = function(t, e, r, a) { + for (var n = this, i = 0; i < e.length; i++) { + var s = e[i]; + s.isNode() && n.drawCachedElement(t, s, r, a); + } + }, vr.drawLayeredElements = function(t, e, r, a) { + var n = this, i = n.data.lyrTxrCache.getLayers(e, r); + if (i) + for (var s = 0; s < i.length; s++) { + var o = i[s], u = o.bb; + u.w === 0 || u.h === 0 || t.drawImage(o.canvas, u.x1, u.y1, u.w, u.h); + } + else + n.drawCachedElements(t, e, r, a); + }; + var br = {}; + br.drawEdge = function(t, e, r) { + var a = arguments.length > 3 && arguments[3] !== void 0 ? arguments[3] : !0, n = arguments.length > 4 && arguments[4] !== void 0 ? arguments[4] : !0, i = arguments.length > 5 && arguments[5] !== void 0 ? arguments[5] : !0, s = this, o = e._private.rscratch; + if (!(i && !e.visible()) && !(o.badLine || o.allpts == null || isNaN(o.allpts[0]))) { + var u; + r && (u = r, t.translate(-u.x1, -u.y1)); + var l = i ? e.pstyle("opacity").value : 1, f = i ? e.pstyle("line-opacity").value : 1, h = e.pstyle("curve-style").value, v = e.pstyle("line-style").value, d = e.pstyle("width").pfValue, c = e.pstyle("line-cap").value, y = l * f, p = l * f, g = function() { + var N = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : y; + h === "straight-triangle" ? (s.eleStrokeStyle(t, e, N), s.drawEdgeTrianglePath(e, t, o.allpts)) : (t.lineWidth = d, t.lineCap = c, s.eleStrokeStyle(t, e, N), s.drawEdgePath(e, t, o.allpts, v), t.lineCap = "butt"); + }, m = function() { + n && s.drawEdgeOverlay(t, e); + }, b = function() { + n && s.drawEdgeUnderlay(t, e); + }, E = function() { + var N = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : p; + s.drawArrowheads(t, e, N); + }, M = function() { + s.drawElementText(t, e, null, a); + }; + t.lineJoin = "round"; + var L = e.pstyle("ghost").value === "yes"; + if (L) { + var w = e.pstyle("ghost-offset-x").pfValue, k = e.pstyle("ghost-offset-y").pfValue, D = e.pstyle("ghost-opacity").value, F = y * D; + t.translate(w, k), g(F), E(F), t.translate(-w, -k); + } + b(), g(), E(), m(), M(), r && t.translate(u.x1, u.y1); + } + }; + var xl = function(e) { + if (!["overlay", "underlay"].includes(e)) + throw new Error("Invalid state"); + return function(r, a) { + if (a.visible()) { + var n = a.pstyle("".concat(e, "-opacity")).value; + if (n !== 0) { + var i = this, s = i.usePaths(), o = a._private.rscratch, u = a.pstyle("".concat(e, "-padding")).pfValue, l = 2 * u, f = a.pstyle("".concat(e, "-color")).value; + r.lineWidth = l, o.edgeType === "self" && !s ? r.lineCap = "butt" : r.lineCap = "round", i.colorStrokeStyle(r, f[0], f[1], f[2], n), i.drawEdgePath(a, r, o.allpts, "solid"); + } + } + }; + }; + br.drawEdgeOverlay = xl("overlay"), br.drawEdgeUnderlay = xl("underlay"), br.drawEdgePath = function(t, e, r, a) { + var n = t._private.rscratch, i = e, s, o = !1, u = this.usePaths(), l = t.pstyle("line-dash-pattern").pfValue, f = t.pstyle("line-dash-offset").pfValue; + if (u) { + var h = r.join("$"), v = n.pathCacheKey && n.pathCacheKey === h; + v ? (s = e = n.pathCache, o = !0) : (s = e = new Path2D(), n.pathCacheKey = h, n.pathCache = s); + } + if (i.setLineDash) + switch (a) { + case "dotted": + i.setLineDash([1, 1]); + break; + case "dashed": + i.setLineDash(l), i.lineDashOffset = f; + break; + case "solid": + i.setLineDash([]); + break; + } + if (!o && !n.badLine) + switch (e.beginPath && e.beginPath(), e.moveTo(r[0], r[1]), n.edgeType) { + case "bezier": + case "self": + case "compound": + case "multibezier": + for (var d = 2; d + 3 < r.length; d += 4) + e.quadraticCurveTo(r[d], r[d + 1], r[d + 2], r[d + 3]); + break; + case "straight": + case "segments": + case "haystack": + for (var c = 2; c + 1 < r.length; c += 2) + e.lineTo(r[c], r[c + 1]); + break; + } + e = i, u ? e.stroke(s) : e.stroke(), e.setLineDash && e.setLineDash([]); + }, br.drawEdgeTrianglePath = function(t, e, r) { + e.fillStyle = e.strokeStyle; + for (var a = t.pstyle("width").pfValue, n = 0; n + 1 < r.length; n += 2) { + var i = [r[n + 2] - r[n], r[n + 3] - r[n + 1]], s = Math.sqrt(i[0] * i[0] + i[1] * i[1]), o = [i[1] / s, -i[0] / s], u = [o[0] * a / 2, o[1] * a / 2]; + e.beginPath(), e.moveTo(r[n] - u[0], r[n + 1] - u[1]), e.lineTo(r[n] + u[0], r[n + 1] + u[1]), e.lineTo(r[n + 2], r[n + 3]), e.closePath(), e.fill(); + } + }, br.drawArrowheads = function(t, e, r) { + var a = e._private.rscratch, n = a.edgeType === "haystack"; + n || this.drawArrowhead(t, e, "source", a.arrowStartX, a.arrowStartY, a.srcArrowAngle, r), this.drawArrowhead(t, e, "mid-target", a.midX, a.midY, a.midtgtArrowAngle, r), this.drawArrowhead(t, e, "mid-source", a.midX, a.midY, a.midsrcArrowAngle, r), n || this.drawArrowhead(t, e, "target", a.arrowEndX, a.arrowEndY, a.tgtArrowAngle, r); + }, br.drawArrowhead = function(t, e, r, a, n, i, s) { + if (!(isNaN(a) || a == null || isNaN(n) || n == null || isNaN(i) || i == null)) { + var o = this, u = e.pstyle(r + "-arrow-shape").value; + if (u !== "none") { + var l = e.pstyle(r + "-arrow-fill").value === "hollow" ? "both" : "filled", f = e.pstyle(r + "-arrow-fill").value, h = e.pstyle("width").pfValue, v = e.pstyle(r + "-arrow-width"), d = v.value === "match-line" ? h : v.pfValue; + v.units === "%" && (d *= h); + var c = e.pstyle("opacity").value; + s === void 0 && (s = c); + var y = t.globalCompositeOperation; + (s !== 1 || f === "hollow") && (t.globalCompositeOperation = "destination-out", o.colorFillStyle(t, 255, 255, 255, 1), o.colorStrokeStyle(t, 255, 255, 255, 1), o.drawArrowShape(e, t, l, h, u, d, a, n, i), t.globalCompositeOperation = y); + var p = e.pstyle(r + "-arrow-color").value; + o.colorFillStyle(t, p[0], p[1], p[2], s), o.colorStrokeStyle(t, p[0], p[1], p[2], s), o.drawArrowShape(e, t, f, h, u, d, a, n, i); + } + } + }, br.drawArrowShape = function(t, e, r, a, n, i, s, o, u) { + var l = this, f = this.usePaths() && n !== "triangle-cross", h = !1, v, d = e, c = { + x: s, + y: o + }, y = t.pstyle("arrow-scale").value, p = this.getArrowWidth(a, y), g = l.arrowShapes[n]; + if (f) { + var m = l.arrowPathCache = l.arrowPathCache || [], b = Pr(n), E = m[b]; + E != null ? (v = e = E, h = !0) : (v = e = new Path2D(), m[b] = v); + } + h || (e.beginPath && e.beginPath(), f ? g.draw(e, 1, 0, { + x: 0, + y: 0 + }, 1) : g.draw(e, p, u, c, a), e.closePath && e.closePath()), e = d, f && (e.translate(s, o), e.rotate(u), e.scale(p, p)), (r === "filled" || r === "both") && (f ? e.fill(v) : e.fill()), (r === "hollow" || r === "both") && (e.lineWidth = i / (f ? p : 1), e.lineJoin = "miter", f ? e.stroke(v) : e.stroke()), f && (e.scale(1 / p, 1 / p), e.rotate(-u), e.translate(-s, -o)); + }; + var $i = {}; + $i.safeDrawImage = function(t, e, r, a, n, i, s, o, u, l) { + if (!(n <= 0 || i <= 0 || u <= 0 || l <= 0)) + try { + t.drawImage(e, r, a, n, i, s, o, u, l); + } catch (f) { + vt(f); + } + }, $i.drawInscribedImage = function(t, e, r, a, n) { + var i = this, s = r.position(), o = s.x, u = s.y, l = r.cy().style(), f = l.getIndexedStyle.bind(l), h = f(r, "background-fit", "value", a), v = f(r, "background-repeat", "value", a), d = r.width(), c = r.height(), y = r.padding() * 2, p = d + (f(r, "background-width-relative-to", "value", a) === "inner" ? 0 : y), g = c + (f(r, "background-height-relative-to", "value", a) === "inner" ? 0 : y), m = r._private.rscratch, b = f(r, "background-clip", "value", a), E = b === "node", M = f(r, "background-image-opacity", "value", a) * n, L = f(r, "background-image-smoothing", "value", a), w = e.width || e.cachedW, k = e.height || e.cachedH; + (w == null || k == null) && (document.body.appendChild(e), w = e.cachedW = e.width || e.offsetWidth, k = e.cachedH = e.height || e.offsetHeight, document.body.removeChild(e)); + var D = w, F = k; + if (f(r, "background-width", "value", a) !== "auto" && (f(r, "background-width", "units", a) === "%" ? D = f(r, "background-width", "pfValue", a) * p : D = f(r, "background-width", "pfValue", a)), f(r, "background-height", "value", a) !== "auto" && (f(r, "background-height", "units", a) === "%" ? F = f(r, "background-height", "pfValue", a) * g : F = f(r, "background-height", "pfValue", a)), !(D === 0 || F === 0)) { + if (h === "contain") { + var G = Math.min(p / D, g / F); + D *= G, F *= G; + } else if (h === "cover") { + var G = Math.max(p / D, g / F); + D *= G, F *= G; + } + var N = o - p / 2, X = f(r, "background-position-x", "units", a), B = f(r, "background-position-x", "pfValue", a); + X === "%" ? N += (p - D) * B : N += B; + var re = f(r, "background-offset-x", "units", a), K = f(r, "background-offset-x", "pfValue", a); + re === "%" ? N += (p - D) * K : N += K; + var W = u - g / 2, ae = f(r, "background-position-y", "units", a), ue = f(r, "background-position-y", "pfValue", a); + ae === "%" ? W += (g - F) * ue : W += ue; + var me = f(r, "background-offset-y", "units", a), ie = f(r, "background-offset-y", "pfValue", a); + me === "%" ? W += (g - F) * ie : W += ie, m.pathCache && (N -= o, W -= u, o = 0, u = 0); + var ge = t.globalAlpha; + t.globalAlpha = M; + var Ee = i.getImgSmoothing(t), Ce = !1; + if (L === "no" && Ee ? (i.setImgSmoothing(t, !1), Ce = !0) : L === "yes" && !Ee && (i.setImgSmoothing(t, !0), Ce = !0), v === "no-repeat") + E && (t.save(), m.pathCache ? t.clip(m.pathCache) : (i.nodeShapes[i.getNodeShape(r)].draw(t, o, u, p, g), t.clip())), i.safeDrawImage(t, e, 0, 0, w, k, N, W, D, F), E && t.restore(); + else { + var we = t.createPattern(e, v); + t.fillStyle = we, i.nodeShapes[i.getNodeShape(r)].draw(t, o, u, p, g), t.translate(N, W), t.fill(), t.translate(-N, -W); + } + t.globalAlpha = ge, Ce && i.setImgSmoothing(t, Ee); + } + }; + var _r = {}; + _r.eleTextBiggerThanMin = function(t, e) { + if (!e) { + var r = t.cy().zoom(), a = this.getPixelRatio(), n = Math.ceil(ui(r * a)); + e = Math.pow(2, n); + } + var i = t.pstyle("font-size").pfValue * e, s = t.pstyle("min-zoomed-font-size").pfValue; + return !(i < s); + }, _r.drawElementText = function(t, e, r, a, n) { + var i = arguments.length > 5 && arguments[5] !== void 0 ? arguments[5] : !0, s = this; + if (a == null) { + if (i && !s.eleTextBiggerThanMin(e)) + return; + } else if (a === !1) + return; + if (e.isNode()) { + var o = e.pstyle("label"); + if (!o || !o.value) + return; + var u = s.getLabelJustification(e); + t.textAlign = u, t.textBaseline = "bottom"; + } else { + var l = e.element()._private.rscratch.badLine, f = e.pstyle("label"), h = e.pstyle("source-label"), v = e.pstyle("target-label"); + if (l || (!f || !f.value) && (!h || !h.value) && (!v || !v.value)) + return; + t.textAlign = "center", t.textBaseline = "bottom"; + } + var d = !r, c; + r && (c = r, t.translate(-c.x1, -c.y1)), n == null ? (s.drawText(t, e, null, d, i), e.isEdge() && (s.drawText(t, e, "source", d, i), s.drawText(t, e, "target", d, i))) : s.drawText(t, e, n, d, i), r && t.translate(c.x1, c.y1); + }, _r.getFontCache = function(t) { + var e; + this.fontCaches = this.fontCaches || []; + for (var r = 0; r < this.fontCaches.length; r++) + if (e = this.fontCaches[r], e.context === t) + return e; + return e = { + context: t + }, this.fontCaches.push(e), e; + }, _r.setupTextStyle = function(t, e) { + var r = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : !0, a = e.pstyle("font-style").strValue, n = e.pstyle("font-size").pfValue + "px", i = e.pstyle("font-family").strValue, s = e.pstyle("font-weight").strValue, o = r ? e.effectiveOpacity() * e.pstyle("text-opacity").value : 1, u = e.pstyle("text-outline-opacity").value * o, l = e.pstyle("color").value, f = e.pstyle("text-outline-color").value; + t.font = a + " " + s + " " + n + " " + i, t.lineJoin = "round", this.colorFillStyle(t, l[0], l[1], l[2], o), this.colorStrokeStyle(t, f[0], f[1], f[2], u); + }; + function _i(t, e, r, a, n) { + var i = arguments.length > 5 && arguments[5] !== void 0 ? arguments[5] : 5, s = arguments.length > 6 ? arguments[6] : void 0; + t.beginPath(), t.moveTo(e + i, r), t.lineTo(e + a - i, r), t.quadraticCurveTo(e + a, r, e + a, r + i), t.lineTo(e + a, r + n - i), t.quadraticCurveTo(e + a, r + n, e + a - i, r + n), t.lineTo(e + i, r + n), t.quadraticCurveTo(e, r + n, e, r + n - i), t.lineTo(e, r + i), t.quadraticCurveTo(e, r, e + i, r), t.closePath(), s ? t.stroke() : t.fill(); + } + _r.getTextAngle = function(t, e) { + var r, a = t._private, n = a.rscratch, i = e ? e + "-" : "", s = t.pstyle(i + "text-rotation"), o = er(n, "labelAngle", e); + return s.strValue === "autorotate" ? r = t.isEdge() ? o : 0 : s.strValue === "none" ? r = 0 : r = s.pfValue, r; + }, _r.drawText = function(t, e, r) { + var a = arguments.length > 3 && arguments[3] !== void 0 ? arguments[3] : !0, n = arguments.length > 4 && arguments[4] !== void 0 ? arguments[4] : !0, i = e._private, s = i.rscratch, o = n ? e.effectiveOpacity() : 1; + if (!(n && (o === 0 || e.pstyle("text-opacity").value === 0))) { + r === "main" && (r = null); + var u = er(s, "labelX", r), l = er(s, "labelY", r), f, h, v = this.getLabelText(e, r); + if (v != null && v !== "" && !isNaN(u) && !isNaN(l)) { + this.setupTextStyle(t, e, n); + var d = r ? r + "-" : "", c = er(s, "labelWidth", r), y = er(s, "labelHeight", r), p = e.pstyle(d + "text-margin-x").pfValue, g = e.pstyle(d + "text-margin-y").pfValue, m = e.isEdge(), b = e.pstyle("text-halign").value, E = e.pstyle("text-valign").value; + m && (b = "center", E = "center"), u += p, l += g; + var M; + switch (a ? M = this.getTextAngle(e, r) : M = 0, M !== 0 && (f = u, h = l, t.translate(f, h), t.rotate(M), u = 0, l = 0), E) { + case "top": + break; + case "center": + l += y / 2; + break; + case "bottom": + l += y; + break; + } + var L = e.pstyle("text-background-opacity").value, w = e.pstyle("text-border-opacity").value, k = e.pstyle("text-border-width").pfValue, D = e.pstyle("text-background-padding").pfValue, F = e.pstyle("text-background-shape").strValue, G = F.indexOf("round") === 0, N = 2; + if (L > 0 || k > 0 && w > 0) { + var X = u - D; + switch (b) { + case "left": + X -= c; + break; + case "center": + X -= c / 2; + break; + } + var B = l - y - D, re = c + 2 * D, K = y + 2 * D; + if (L > 0) { + var W = t.fillStyle, ae = e.pstyle("text-background-color").value; + t.fillStyle = "rgba(" + ae[0] + "," + ae[1] + "," + ae[2] + "," + L * o + ")", G ? _i(t, X, B, re, K, N) : t.fillRect(X, B, re, K), t.fillStyle = W; + } + if (k > 0 && w > 0) { + var ue = t.strokeStyle, me = t.lineWidth, ie = e.pstyle("text-border-color").value, ge = e.pstyle("text-border-style").value; + if (t.strokeStyle = "rgba(" + ie[0] + "," + ie[1] + "," + ie[2] + "," + w * o + ")", t.lineWidth = k, t.setLineDash) + switch (ge) { + case "dotted": + t.setLineDash([1, 1]); + break; + case "dashed": + t.setLineDash([4, 2]); + break; + case "double": + t.lineWidth = k / 4, t.setLineDash([]); + break; + case "solid": + t.setLineDash([]); + break; + } + if (G ? _i(t, X, B, re, K, N, "stroke") : t.strokeRect(X, B, re, K), ge === "double") { + var Ee = k / 2; + G ? _i(t, X + Ee, B + Ee, re - Ee * 2, K - Ee * 2, N, "stroke") : t.strokeRect(X + Ee, B + Ee, re - Ee * 2, K - Ee * 2); + } + t.setLineDash && t.setLineDash([]), t.lineWidth = me, t.strokeStyle = ue; + } + } + var Ce = 2 * e.pstyle("text-outline-width").pfValue; + if (Ce > 0 && (t.lineWidth = Ce), e.pstyle("text-wrap").value === "wrap") { + var we = er(s, "labelWrapCachedLines", r), De = er(s, "labelLineHeight", r), se = c / 2, xe = this.getLabelJustification(e); + switch (xe === "auto" || (b === "left" ? xe === "left" ? u += -c : xe === "center" && (u += -se) : b === "center" ? xe === "left" ? u += -se : xe === "right" && (u += se) : b === "right" && (xe === "center" ? u += se : xe === "right" && (u += c))), E) { + case "top": + l -= (we.length - 1) * De; + break; + case "center": + case "bottom": + l -= (we.length - 1) * De; + break; + } + for (var Le = 0; Le < we.length; Le++) + Ce > 0 && t.strokeText(we[Le], u, l), t.fillText(we[Le], u, l), l += De; + } else + Ce > 0 && t.strokeText(v, u, l), t.fillText(v, u, l); + M !== 0 && (t.rotate(-M), t.translate(-f, -h)); + } + } + }; + var Ea = {}; + Ea.drawNode = function(t, e, r) { + var a = arguments.length > 3 && arguments[3] !== void 0 ? arguments[3] : !0, n = arguments.length > 4 && arguments[4] !== void 0 ? arguments[4] : !0, i = arguments.length > 5 && arguments[5] !== void 0 ? arguments[5] : !0, s = this, o, u, l = e._private, f = l.rscratch, h = e.position(); + if (!(!R(h.x) || !R(h.y)) && !(i && !e.visible())) { + var v = i ? e.effectiveOpacity() : 1, d = s.usePaths(), c, y = !1, p = e.padding(); + o = e.width() + 2 * p, u = e.height() + 2 * p; + var g; + r && (g = r, t.translate(-g.x1, -g.y1)); + for (var m = e.pstyle("background-image"), b = m.value, E = new Array(b.length), M = new Array(b.length), L = 0, w = 0; w < b.length; w++) { + var k = b[w], D = E[w] = k != null && k !== "none"; + if (D) { + var F = e.cy().style().getIndexedStyle(e, "background-image-crossorigin", "value", w); + L++, M[w] = s.getCachedImage(k, F, function() { + l.backgroundTimestamp = Date.now(), e.emitAndNotify("background"); + }); + } + } + var G = e.pstyle("background-blacken").value, N = e.pstyle("border-width").pfValue, X = e.pstyle("background-opacity").value * v, B = e.pstyle("border-color").value, re = e.pstyle("border-style").value, K = e.pstyle("border-opacity").value * v, W = e.pstyle("outline-width").pfValue, ae = e.pstyle("outline-color").value, ue = e.pstyle("outline-style").value, me = e.pstyle("outline-opacity").value * v, ie = e.pstyle("outline-offset").value; + t.lineJoin = "miter"; + var ge = function() { + var he = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : X; + s.eleFillStyle(t, e, he); + }, Ee = function() { + var he = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : K; + s.colorStrokeStyle(t, B[0], B[1], B[2], he); + }, Ce = function() { + var he = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : me; + s.colorStrokeStyle(t, ae[0], ae[1], ae[2], he); + }, we = function(he, O, oe, Te) { + var ce = s.nodePathCache = s.nodePathCache || [], ye = hs(oe === "polygon" ? oe + "," + Te.join(",") : oe, "" + O, "" + he), _e = ce[ye], be, Ge = !1; + return _e != null ? (be = _e, Ge = !0, f.pathCache = be) : (be = new Path2D(), ce[ye] = f.pathCache = be), { + path: be, + cacheHit: Ge + }; + }, De = e.pstyle("shape").strValue, se = e.pstyle("shape-polygon-points").pfValue; + if (d) { + t.translate(h.x, h.y); + var xe = we(o, u, De, se); + c = xe.path, y = xe.cacheHit; + } + var Le = function() { + if (!y) { + var he = h; + d && (he = { + x: 0, + y: 0 + }), s.nodeShapes[s.getNodeShape(e)].draw(c || t, he.x, he.y, o, u); + } + d ? t.fill(c) : t.fill(); + }, Se = function() { + for (var he = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : v, O = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : !0, oe = l.backgrounding, Te = 0, ce = 0; ce < M.length; ce++) { + var ye = e.cy().style().getIndexedStyle(e, "background-image-containment", "value", ce); + if (O && ye === "over" || !O && ye === "inside") { + Te++; + continue; + } + E[ce] && M[ce].complete && !M[ce].error && (Te++, s.drawInscribedImage(t, M[ce], e, ce, he)); + } + l.backgrounding = Te !== L, oe !== l.backgrounding && e.updateStyle(!1); + }, Oe = function() { + var he = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : !1, O = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : v; + s.hasPie(e) && (s.drawPie(t, e, O), he && (d || s.nodeShapes[s.getNodeShape(e)].draw(t, h.x, h.y, o, u))); + }, Fe = function() { + var he = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : v, O = (G > 0 ? G : -G) * he, oe = G > 0 ? 0 : 255; + G !== 0 && (s.colorFillStyle(t, oe, oe, oe, O), d ? t.fill(c) : t.fill()); + }, Xe = function() { + if (N > 0) { + if (t.lineWidth = N, t.lineCap = "butt", t.setLineDash) + switch (re) { + case "dotted": + t.setLineDash([1, 1]); + break; + case "dashed": + t.setLineDash([4, 2]); + break; + case "solid": + case "double": + t.setLineDash([]); + break; + } + if (d ? t.stroke(c) : t.stroke(), re === "double") { + t.lineWidth = N / 3; + var he = t.globalCompositeOperation; + t.globalCompositeOperation = "destination-out", d ? t.stroke(c) : t.stroke(), t.globalCompositeOperation = he; + } + t.setLineDash && t.setLineDash([]); + } + }, Ie = function() { + if (W > 0) { + if (t.lineWidth = W, t.lineCap = "butt", t.setLineDash) + switch (ue) { + case "dotted": + t.setLineDash([1, 1]); + break; + case "dashed": + t.setLineDash([4, 2]); + break; + case "solid": + case "double": + t.setLineDash([]); + break; + } + var he = h; + d && (he = { + x: 0, + y: 0 + }); + var O = s.getNodeShape(e), oe = (o + N + (W + ie)) / o, Te = (u + N + (W + ie)) / u, ce = o * oe, ye = u * Te, _e = s.nodeShapes[O].points, be; + if (d) { + var Ge = we(ce, ye, O, _e); + be = Ge.path; + } + if (O === "ellipse") + s.drawEllipsePath(be || t, he.x, he.y, ce, ye); + else if (["round-diamond", "round-heptagon", "round-hexagon", "round-octagon", "round-pentagon", "round-polygon", "round-triangle", "round-tag"].includes(O)) { + var Qe = 0, ft = 0, qe = 0; + O === "round-diamond" ? Qe = (N + ie + W) * 1.4 : O === "round-heptagon" ? (Qe = (N + ie + W) * 1.075, qe = -(N / 2 + ie + W) / 35) : O === "round-hexagon" ? Qe = (N + ie + W) * 1.12 : O === "round-pentagon" ? (Qe = (N + ie + W) * 1.13, qe = -(N / 2 + ie + W) / 15) : O === "round-tag" ? (Qe = (N + ie + W) * 1.12, ft = (N / 2 + W + ie) * 0.07) : O === "round-triangle" && (Qe = (N + ie + W) * (Math.PI / 2), qe = -(N + ie / 2 + W) / Math.PI), Qe !== 0 && (oe = (o + Qe) / o, Te = (u + Qe) / u), s.drawRoundPolygonPath(be || t, he.x + ft, he.y + qe, o * oe, u * Te, _e); + } else if (["roundrectangle", "round-rectangle"].includes(O)) + s.drawRoundRectanglePath(be || t, he.x, he.y, ce, ye); + else if (["cutrectangle", "cut-rectangle"].includes(O)) + s.drawCutRectanglePath(be || t, he.x, he.y, ce, ye); + else if (["bottomroundrectangle", "bottom-round-rectangle"].includes(O)) + s.drawBottomRoundRectanglePath(be || t, he.x, he.y, ce, ye); + else if (O === "barrel") + s.drawBarrelPath(be || t, he.x, he.y, ce, ye); + else if (O.startsWith("polygon") || ["rhomboid", "right-rhomboid", "round-tag", "tag", "vee"].includes(O)) { + var ot = (N + W + ie) / o; + _e = pn(yn(_e, ot)), s.drawPolygonPath(be || t, he.x, he.y, o, u, _e); + } else { + var Ke = (N + W + ie) / o; + _e = pn(yn(_e, -Ke)), s.drawPolygonPath(be || t, he.x, he.y, o, u, _e); + } + if (d ? t.stroke(be) : t.stroke(), ue === "double") { + t.lineWidth = N / 3; + var Je = t.globalCompositeOperation; + t.globalCompositeOperation = "destination-out", d ? t.stroke(be) : t.stroke(), t.globalCompositeOperation = Je; + } + t.setLineDash && t.setLineDash([]); + } + }, Me = function() { + n && s.drawNodeOverlay(t, e, h, o, u); + }, Ue = function() { + n && s.drawNodeUnderlay(t, e, h, o, u); + }, ze = function() { + s.drawElementText(t, e, null, a); + }, Be = e.pstyle("ghost").value === "yes"; + if (Be) { + var $e = e.pstyle("ghost-offset-x").pfValue, rt = e.pstyle("ghost-offset-y").pfValue, je = e.pstyle("ghost-opacity").value, We = je * v; + t.translate($e, rt), Ce(), Ie(), ge(je * X), Le(), Se(We, !0), Ee(je * K), Xe(), Oe(G !== 0 || N !== 0), Se(We, !1), Fe(We), t.translate(-$e, -rt); + } + d && t.translate(-h.x, -h.y), Ue(), d && t.translate(h.x, h.y), Ce(), Ie(), ge(), Le(), Se(v, !0), Ee(), Xe(), Oe(G !== 0 || N !== 0), Se(v, !1), Fe(), d && t.translate(-h.x, -h.y), ze(), Me(), r && t.translate(g.x1, g.y1); + } + }; + var Tl = function(e) { + if (!["overlay", "underlay"].includes(e)) + throw new Error("Invalid state"); + return function(r, a, n, i, s) { + var o = this; + if (a.visible()) { + var u = a.pstyle("".concat(e, "-padding")).pfValue, l = a.pstyle("".concat(e, "-opacity")).value, f = a.pstyle("".concat(e, "-color")).value, h = a.pstyle("".concat(e, "-shape")).value; + if (l > 0) { + if (n = n || a.position(), i == null || s == null) { + var v = a.padding(); + i = a.width() + 2 * v, s = a.height() + 2 * v; + } + o.colorFillStyle(r, f[0], f[1], f[2], l), o.nodeShapes[h].draw(r, n.x, n.y, i + u * 2, s + u * 2), r.fill(); + } + } + }; + }; + Ea.drawNodeOverlay = Tl("overlay"), Ea.drawNodeUnderlay = Tl("underlay"), Ea.hasPie = function(t) { + return t = t[0], t._private.hasPie; + }, Ea.drawPie = function(t, e, r, a) { + e = e[0], a = a || e.position(); + var n = e.cy().style(), i = e.pstyle("pie-size"), s = a.x, o = a.y, u = e.width(), l = e.height(), f = Math.min(u, l) / 2, h = 0, v = this.usePaths(); + v && (s = 0, o = 0), i.units === "%" ? f = f * i.pfValue : i.pfValue !== void 0 && (f = i.pfValue / 2); + for (var d = 1; d <= n.pieBackgroundN; d++) { + var c = e.pstyle("pie-" + d + "-background-size").value, y = e.pstyle("pie-" + d + "-background-color").value, p = e.pstyle("pie-" + d + "-background-opacity").value * r, g = c / 100; + g + h > 1 && (g = 1 - h); + var m = 1.5 * Math.PI + 2 * Math.PI * h, b = 2 * Math.PI * g, E = m + b; + c === 0 || h >= 1 || h + g > 1 || (t.beginPath(), t.moveTo(s, o), t.arc(s, o, f, m, E), t.closePath(), this.colorFillStyle(t, y[0], y[1], y[2], p), t.fill(), h += g); + } + }; + var Kt = {}, Jg = 100; + Kt.getPixelRatio = function() { + var t = this.data.contexts[0]; + if (this.forcedPixelRatio != null) + return this.forcedPixelRatio; + var e = t.backingStorePixelRatio || t.webkitBackingStorePixelRatio || t.mozBackingStorePixelRatio || t.msBackingStorePixelRatio || t.oBackingStorePixelRatio || t.backingStorePixelRatio || 1; + return (window.devicePixelRatio || 1) / e; + }, Kt.paintCache = function(t) { + for (var e = this.paintCaches = this.paintCaches || [], r = !0, a, n = 0; n < e.length; n++) + if (a = e[n], a.context === t) { + r = !1; + break; + } + return r && (a = { + context: t + }, e.push(a)), a; + }, Kt.createGradientStyleFor = function(t, e, r, a, n) { + var i, s = this.usePaths(), o = r.pstyle(e + "-gradient-stop-colors").value, u = r.pstyle(e + "-gradient-stop-positions").pfValue; + if (a === "radial-gradient") + if (r.isEdge()) { + var l = r.sourceEndpoint(), f = r.targetEndpoint(), h = r.midpoint(), v = Br(l, h), d = Br(f, h); + i = t.createRadialGradient(h.x, h.y, 0, h.x, h.y, Math.max(v, d)); + } else { + var c = s ? { + x: 0, + y: 0 + } : r.position(), y = r.paddedWidth(), p = r.paddedHeight(); + i = t.createRadialGradient(c.x, c.y, 0, c.x, c.y, Math.max(y, p)); + } + else if (r.isEdge()) { + var g = r.sourceEndpoint(), m = r.targetEndpoint(); + i = t.createLinearGradient(g.x, g.y, m.x, m.y); + } else { + var b = s ? { + x: 0, + y: 0 + } : r.position(), E = r.paddedWidth(), M = r.paddedHeight(), L = E / 2, w = M / 2, k = r.pstyle("background-gradient-direction").value; + switch (k) { + case "to-bottom": + i = t.createLinearGradient(b.x, b.y - w, b.x, b.y + w); + break; + case "to-top": + i = t.createLinearGradient(b.x, b.y + w, b.x, b.y - w); + break; + case "to-left": + i = t.createLinearGradient(b.x + L, b.y, b.x - L, b.y); + break; + case "to-right": + i = t.createLinearGradient(b.x - L, b.y, b.x + L, b.y); + break; + case "to-bottom-right": + case "to-right-bottom": + i = t.createLinearGradient(b.x - L, b.y - w, b.x + L, b.y + w); + break; + case "to-top-right": + case "to-right-top": + i = t.createLinearGradient(b.x - L, b.y + w, b.x + L, b.y - w); + break; + case "to-bottom-left": + case "to-left-bottom": + i = t.createLinearGradient(b.x + L, b.y - w, b.x - L, b.y + w); + break; + case "to-top-left": + case "to-left-top": + i = t.createLinearGradient(b.x + L, b.y + w, b.x - L, b.y - w); + break; + } + } + if (!i) + return null; + for (var D = u.length === o.length, F = o.length, G = 0; G < F; G++) + i.addColorStop(D ? u[G] : G / (F - 1), "rgba(" + o[G][0] + "," + o[G][1] + "," + o[G][2] + "," + n + ")"); + return i; + }, Kt.gradientFillStyle = function(t, e, r, a) { + var n = this.createGradientStyleFor(t, "background", e, r, a); + if (!n) + return null; + t.fillStyle = n; + }, Kt.colorFillStyle = function(t, e, r, a, n) { + t.fillStyle = "rgba(" + e + "," + r + "," + a + "," + n + ")"; + }, Kt.eleFillStyle = function(t, e, r) { + var a = e.pstyle("background-fill").value; + if (a === "linear-gradient" || a === "radial-gradient") + this.gradientFillStyle(t, e, a, r); + else { + var n = e.pstyle("background-color").value; + this.colorFillStyle(t, n[0], n[1], n[2], r); + } + }, Kt.gradientStrokeStyle = function(t, e, r, a) { + var n = this.createGradientStyleFor(t, "line", e, r, a); + if (!n) + return null; + t.strokeStyle = n; + }, Kt.colorStrokeStyle = function(t, e, r, a, n) { + t.strokeStyle = "rgba(" + e + "," + r + "," + a + "," + n + ")"; + }, Kt.eleStrokeStyle = function(t, e, r) { + var a = e.pstyle("line-fill").value; + if (a === "linear-gradient" || a === "radial-gradient") + this.gradientStrokeStyle(t, e, a, r); + else { + var n = e.pstyle("line-color").value; + this.colorStrokeStyle(t, n[0], n[1], n[2], r); + } + }, Kt.matchCanvasSize = function(t) { + var e = this, r = e.data, a = e.findContainerClientCoords(), n = a[2], i = a[3], s = e.getPixelRatio(), o = e.motionBlurPxRatio; + (t === e.data.bufferCanvases[e.MOTIONBLUR_BUFFER_NODE] || t === e.data.bufferCanvases[e.MOTIONBLUR_BUFFER_DRAG]) && (s = o); + var u = n * s, l = i * s, f; + if (!(u === e.canvasWidth && l === e.canvasHeight)) { + e.fontCaches = null; + var h = r.canvasContainer; + h.style.width = n + "px", h.style.height = i + "px"; + for (var v = 0; v < e.CANVAS_LAYERS; v++) + f = r.canvases[v], f.width = u, f.height = l, f.style.width = n + "px", f.style.height = i + "px"; + for (var v = 0; v < e.BUFFER_COUNT; v++) + f = r.bufferCanvases[v], f.width = u, f.height = l, f.style.width = n + "px", f.style.height = i + "px"; + e.textureMult = 1, s <= 1 && (f = r.bufferCanvases[e.TEXTURE_BUFFER], e.textureMult = 2, f.width = u * e.textureMult, f.height = l * e.textureMult), e.canvasWidth = u, e.canvasHeight = l; + } + }, Kt.renderTo = function(t, e, r, a) { + this.render({ + forcedContext: t, + forcedZoom: e, + forcedPan: r, + drawAllLayers: !0, + forcedPxRatio: a + }); + }, Kt.render = function(t) { + t = t || ys(); + var e = t.forcedContext, r = t.drawAllLayers, a = t.drawOnlyNodeLayer, n = t.forcedZoom, i = t.forcedPan, s = this, o = t.forcedPxRatio === void 0 ? this.getPixelRatio() : t.forcedPxRatio, u = s.cy, l = s.data, f = l.canvasNeedsRedraw, h = s.textureOnViewport && !e && (s.pinching || s.hoverData.dragging || s.swipePanning || s.data.wheelZooming), v = t.motionBlur !== void 0 ? t.motionBlur : s.motionBlur, d = s.motionBlurPxRatio, c = u.hasCompoundNodes(), y = s.hoverData.draggingEles, p = !!(s.hoverData.selecting || s.touchData.selecting); + v = v && !e && s.motionBlurEnabled && !p; + var g = v; + e || (s.prevPxRatio !== o && (s.invalidateContainerClientCoordsCache(), s.matchCanvasSize(s.container), s.redrawHint("eles", !0), s.redrawHint("drag", !0)), s.prevPxRatio = o), !e && s.motionBlurTimeout && clearTimeout(s.motionBlurTimeout), v && (s.mbFrames == null && (s.mbFrames = 0), s.mbFrames++, s.mbFrames < 3 && (g = !1), s.mbFrames > s.minMbLowQualFrames && (s.motionBlurPxRatio = s.mbPxRBlurry)), s.clearingMotionBlur && (s.motionBlurPxRatio = 1), s.textureDrawLastFrame && !h && (f[s.NODE] = !0, f[s.SELECT_BOX] = !0); + var m = u.style(), b = u.zoom(), E = n !== void 0 ? n : b, M = u.pan(), L = { + x: M.x, + y: M.y + }, w = { + zoom: b, + pan: { + x: M.x, + y: M.y + } + }, k = s.prevViewport, D = k === void 0 || w.zoom !== k.zoom || w.pan.x !== k.pan.x || w.pan.y !== k.pan.y; + !D && !(y && !c) && (s.motionBlurPxRatio = 1), i && (L = i), E *= o, L.x *= o, L.y *= o; + var F = s.getCachedZSortedEles(); + function G(Ie, Me, Ue, ze, Be) { + var $e = Ie.globalCompositeOperation; + Ie.globalCompositeOperation = "destination-out", s.colorFillStyle(Ie, 255, 255, 255, s.motionBlurTransparency), Ie.fillRect(Me, Ue, ze, Be), Ie.globalCompositeOperation = $e; + } + function N(Ie, Me) { + var Ue, ze, Be, $e; + !s.clearingMotionBlur && (Ie === l.bufferContexts[s.MOTIONBLUR_BUFFER_NODE] || Ie === l.bufferContexts[s.MOTIONBLUR_BUFFER_DRAG]) ? (Ue = { + x: M.x * d, + y: M.y * d + }, ze = b * d, Be = s.canvasWidth * d, $e = s.canvasHeight * d) : (Ue = L, ze = E, Be = s.canvasWidth, $e = s.canvasHeight), Ie.setTransform(1, 0, 0, 1, 0, 0), Me === "motionBlur" ? G(Ie, 0, 0, Be, $e) : !e && (Me === void 0 || Me) && Ie.clearRect(0, 0, Be, $e), r || (Ie.translate(Ue.x, Ue.y), Ie.scale(ze, ze)), i && Ie.translate(i.x, i.y), n && Ie.scale(n, n); + } + if (h || (s.textureDrawLastFrame = !1), h) { + if (s.textureDrawLastFrame = !0, !s.textureCache) { + s.textureCache = {}, s.textureCache.bb = u.mutableElements().boundingBox(), s.textureCache.texture = s.data.bufferCanvases[s.TEXTURE_BUFFER]; + var X = s.data.bufferContexts[s.TEXTURE_BUFFER]; + X.setTransform(1, 0, 0, 1, 0, 0), X.clearRect(0, 0, s.canvasWidth * s.textureMult, s.canvasHeight * s.textureMult), s.render({ + forcedContext: X, + drawOnlyNodeLayer: !0, + forcedPxRatio: o * s.textureMult + }); + var w = s.textureCache.viewport = { + zoom: u.zoom(), + pan: u.pan(), + width: s.canvasWidth, + height: s.canvasHeight + }; + w.mpan = { + x: (0 - w.pan.x) / w.zoom, + y: (0 - w.pan.y) / w.zoom + }; + } + f[s.DRAG] = !1, f[s.NODE] = !1; + var B = l.contexts[s.NODE], re = s.textureCache.texture, w = s.textureCache.viewport; + B.setTransform(1, 0, 0, 1, 0, 0), v ? G(B, 0, 0, w.width, w.height) : B.clearRect(0, 0, w.width, w.height); + var K = m.core("outside-texture-bg-color").value, W = m.core("outside-texture-bg-opacity").value; + s.colorFillStyle(B, K[0], K[1], K[2], W), B.fillRect(0, 0, w.width, w.height); + var b = u.zoom(); + N(B, !1), B.clearRect(w.mpan.x, w.mpan.y, w.width / w.zoom / o, w.height / w.zoom / o), B.drawImage(re, w.mpan.x, w.mpan.y, w.width / w.zoom / o, w.height / w.zoom / o); + } else + s.textureOnViewport && !e && (s.textureCache = null); + var ae = u.extent(), ue = s.pinching || s.hoverData.dragging || s.swipePanning || s.data.wheelZooming || s.hoverData.draggingEles || s.cy.animated(), me = s.hideEdgesOnViewport && ue, ie = []; + if (ie[s.NODE] = !f[s.NODE] && v && !s.clearedForMotionBlur[s.NODE] || s.clearingMotionBlur, ie[s.NODE] && (s.clearedForMotionBlur[s.NODE] = !0), ie[s.DRAG] = !f[s.DRAG] && v && !s.clearedForMotionBlur[s.DRAG] || s.clearingMotionBlur, ie[s.DRAG] && (s.clearedForMotionBlur[s.DRAG] = !0), f[s.NODE] || r || a || ie[s.NODE]) { + var ge = v && !ie[s.NODE] && d !== 1, B = e || (ge ? s.data.bufferContexts[s.MOTIONBLUR_BUFFER_NODE] : l.contexts[s.NODE]), Ee = v && !ge ? "motionBlur" : void 0; + N(B, Ee), me ? s.drawCachedNodes(B, F.nondrag, o, ae) : s.drawLayeredElements(B, F.nondrag, o, ae), s.debug && s.drawDebugPoints(B, F.nondrag), !r && !v && (f[s.NODE] = !1); + } + if (!a && (f[s.DRAG] || r || ie[s.DRAG])) { + var ge = v && !ie[s.DRAG] && d !== 1, B = e || (ge ? s.data.bufferContexts[s.MOTIONBLUR_BUFFER_DRAG] : l.contexts[s.DRAG]); + N(B, v && !ge ? "motionBlur" : void 0), me ? s.drawCachedNodes(B, F.drag, o, ae) : s.drawCachedElements(B, F.drag, o, ae), s.debug && s.drawDebugPoints(B, F.drag), !r && !v && (f[s.DRAG] = !1); + } + if (s.showFps || !a && f[s.SELECT_BOX] && !r) { + var B = e || l.contexts[s.SELECT_BOX]; + if (N(B), s.selection[4] == 1 && (s.hoverData.selecting || s.touchData.selecting)) { + var b = s.cy.zoom(), Ce = m.core("selection-box-border-width").value / b; + B.lineWidth = Ce, B.fillStyle = "rgba(" + m.core("selection-box-color").value[0] + "," + m.core("selection-box-color").value[1] + "," + m.core("selection-box-color").value[2] + "," + m.core("selection-box-opacity").value + ")", B.fillRect(s.selection[0], s.selection[1], s.selection[2] - s.selection[0], s.selection[3] - s.selection[1]), Ce > 0 && (B.strokeStyle = "rgba(" + m.core("selection-box-border-color").value[0] + "," + m.core("selection-box-border-color").value[1] + "," + m.core("selection-box-border-color").value[2] + "," + m.core("selection-box-opacity").value + ")", B.strokeRect(s.selection[0], s.selection[1], s.selection[2] - s.selection[0], s.selection[3] - s.selection[1])); + } + if (l.bgActivePosistion && !s.hoverData.selecting) { + var b = s.cy.zoom(), we = l.bgActivePosistion; + B.fillStyle = "rgba(" + m.core("active-bg-color").value[0] + "," + m.core("active-bg-color").value[1] + "," + m.core("active-bg-color").value[2] + "," + m.core("active-bg-opacity").value + ")", B.beginPath(), B.arc(we.x, we.y, m.core("active-bg-size").pfValue / b, 0, 2 * Math.PI), B.fill(); + } + var De = s.lastRedrawTime; + if (s.showFps && De) { + De = Math.round(De); + var se = Math.round(1e3 / De); + B.setTransform(1, 0, 0, 1, 0, 0), B.fillStyle = "rgba(255, 0, 0, 0.75)", B.strokeStyle = "rgba(255, 0, 0, 0.75)", B.lineWidth = 1, B.fillText("1 frame = " + De + " ms = " + se + " fps", 0, 20); + var xe = 60; + B.strokeRect(0, 30, 250, 20), B.fillRect(0, 30, 250 * Math.min(se / xe, 1), 20); + } + r || (f[s.SELECT_BOX] = !1); + } + if (v && d !== 1) { + var Le = l.contexts[s.NODE], Se = s.data.bufferCanvases[s.MOTIONBLUR_BUFFER_NODE], Oe = l.contexts[s.DRAG], Fe = s.data.bufferCanvases[s.MOTIONBLUR_BUFFER_DRAG], Xe = function(Me, Ue, ze) { + Me.setTransform(1, 0, 0, 1, 0, 0), ze || !g ? Me.clearRect(0, 0, s.canvasWidth, s.canvasHeight) : G(Me, 0, 0, s.canvasWidth, s.canvasHeight); + var Be = d; + Me.drawImage( + Ue, + // img + 0, + 0, + // sx, sy + s.canvasWidth * Be, + s.canvasHeight * Be, + // sw, sh + 0, + 0, + // x, y + s.canvasWidth, + s.canvasHeight + // w, h + ); + }; + (f[s.NODE] || ie[s.NODE]) && (Xe(Le, Se, ie[s.NODE]), f[s.NODE] = !1), (f[s.DRAG] || ie[s.DRAG]) && (Xe(Oe, Fe, ie[s.DRAG]), f[s.DRAG] = !1); + } + s.prevViewport = w, s.clearingMotionBlur && (s.clearingMotionBlur = !1, s.motionBlurCleared = !0, s.motionBlur = !0), v && (s.motionBlurTimeout = setTimeout(function() { + s.motionBlurTimeout = null, s.clearedForMotionBlur[s.NODE] = !1, s.clearedForMotionBlur[s.DRAG] = !1, s.motionBlur = !1, s.clearingMotionBlur = !h, s.mbFrames = 0, f[s.NODE] = !0, f[s.DRAG] = !0, s.redraw(); + }, Jg)), e || u.emit("render"); + }; + var Mr = {}; + Mr.drawPolygonPath = function(t, e, r, a, n, i) { + var s = a / 2, o = n / 2; + t.beginPath && t.beginPath(), t.moveTo(e + s * i[0], r + o * i[1]); + for (var u = 1; u < i.length / 2; u++) + t.lineTo(e + s * i[u * 2], r + o * i[u * 2 + 1]); + t.closePath(); + }, Mr.drawRoundPolygonPath = function(t, e, r, a, n, i) { + var s = a / 2, o = n / 2, u = ci(a, n); + t.beginPath && t.beginPath(); + for (var l = 0; l < i.length / 4; l++) { + var f = void 0, h = void 0; + l === 0 ? f = i.length - 2 : f = l * 4 - 2, h = l * 4 + 2; + var v = e + s * i[l * 4], d = r + o * i[l * 4 + 1], c = -i[f] * i[h] - i[f + 1] * i[h + 1], y = u / Math.tan(Math.acos(c) / 2), p = v - y * i[f], g = d - y * i[f + 1], m = v + y * i[h], b = d + y * i[h + 1]; + l === 0 ? t.moveTo(p, g) : t.lineTo(p, g), t.arcTo(v, d, m, b, u); + } + t.closePath(); + }, Mr.drawRoundRectanglePath = function(t, e, r, a, n) { + var i = a / 2, s = n / 2, o = Fa(a, n); + t.beginPath && t.beginPath(), t.moveTo(e, r - s), t.arcTo(e + i, r - s, e + i, r, o), t.arcTo(e + i, r + s, e, r + s, o), t.arcTo(e - i, r + s, e - i, r, o), t.arcTo(e - i, r - s, e, r - s, o), t.lineTo(e, r - s), t.closePath(); + }, Mr.drawBottomRoundRectanglePath = function(t, e, r, a, n) { + var i = a / 2, s = n / 2, o = Fa(a, n); + t.beginPath && t.beginPath(), t.moveTo(e, r - s), t.lineTo(e + i, r - s), t.lineTo(e + i, r), t.arcTo(e + i, r + s, e, r + s, o), t.arcTo(e - i, r + s, e - i, r, o), t.lineTo(e - i, r - s), t.lineTo(e, r - s), t.closePath(); + }, Mr.drawCutRectanglePath = function(t, e, r, a, n) { + var i = a / 2, s = n / 2, o = Ss(); + t.beginPath && t.beginPath(), t.moveTo(e - i + o, r - s), t.lineTo(e + i - o, r - s), t.lineTo(e + i, r - s + o), t.lineTo(e + i, r + s - o), t.lineTo(e + i - o, r + s), t.lineTo(e - i + o, r + s), t.lineTo(e - i, r + s - o), t.lineTo(e - i, r - s + o), t.closePath(); + }, Mr.drawBarrelPath = function(t, e, r, a, n) { + var i = a / 2, s = n / 2, o = e - i, u = e + i, l = r - s, f = r + s, h = di(a, n), v = h.widthOffset, d = h.heightOffset, c = h.ctrlPtOffsetPct * v; + t.beginPath && t.beginPath(), t.moveTo(o, l + d), t.lineTo(o, f - d), t.quadraticCurveTo(o + c, f, o + v, f), t.lineTo(u - v, f), t.quadraticCurveTo(u - c, f, u, f - d), t.lineTo(u, l + d), t.quadraticCurveTo(u - c, l, u - v, l), t.lineTo(o + v, l), t.quadraticCurveTo(o + c, l, o, l + d), t.closePath(); + }; + for (var Cl = Math.sin(0), Dl = Math.cos(0), Yi = {}, Hi = {}, Sl = Math.PI / 40, wa = 0 * Math.PI; wa < 2 * Math.PI; wa += Sl) + Yi[wa] = Math.sin(wa), Hi[wa] = Math.cos(wa); + Mr.drawEllipsePath = function(t, e, r, a, n) { + if (t.beginPath && t.beginPath(), t.ellipse) + t.ellipse(e, r, a / 2, n / 2, 0, 0, 2 * Math.PI); + else + for (var i, s, o = a / 2, u = n / 2, l = 0 * Math.PI; l < 2 * Math.PI; l += Sl) + i = e - o * Yi[l] * Cl + o * Hi[l] * Dl, s = r + u * Hi[l] * Cl + u * Yi[l] * Dl, l === 0 ? t.moveTo(i, s) : t.lineTo(i, s); + t.closePath(); + }; + var tn = {}; + tn.createBuffer = function(t, e) { + var r = document.createElement("canvas"); + return r.width = t, r.height = e, [r, r.getContext("2d")]; + }, tn.bufferCanvasImage = function(t) { + var e = this.cy, r = e.mutableElements(), a = r.boundingBox(), n = this.findContainerClientCoords(), i = t.full ? Math.ceil(a.w) : n[2], s = t.full ? Math.ceil(a.h) : n[3], o = R(t.maxWidth) || R(t.maxHeight), u = this.getPixelRatio(), l = 1; + if (t.scale !== void 0) + i *= t.scale, s *= t.scale, l = t.scale; + else if (o) { + var f = 1 / 0, h = 1 / 0; + R(t.maxWidth) && (f = l * t.maxWidth / i), R(t.maxHeight) && (h = l * t.maxHeight / s), l = Math.min(f, h), i *= l, s *= l; + } + o || (i *= u, s *= u, l *= u); + var v = document.createElement("canvas"); + v.width = i, v.height = s, v.style.width = i + "px", v.style.height = s + "px"; + var d = v.getContext("2d"); + if (i > 0 && s > 0) { + d.clearRect(0, 0, i, s), d.globalCompositeOperation = "source-over"; + var c = this.getCachedZSortedEles(); + if (t.full) + d.translate(-a.x1 * l, -a.y1 * l), d.scale(l, l), this.drawElements(d, c), d.scale(1 / l, 1 / l), d.translate(a.x1 * l, a.y1 * l); + else { + var y = e.pan(), p = { + x: y.x * l, + y: y.y * l + }; + l *= e.zoom(), d.translate(p.x, p.y), d.scale(l, l), this.drawElements(d, c), d.scale(1 / l, 1 / l), d.translate(-p.x, -p.y); + } + t.bg && (d.globalCompositeOperation = "destination-over", d.fillStyle = t.bg, d.rect(0, 0, i, s), d.fill()); + } + return v; + }; + function jg(t, e) { + for (var r = atob(t), a = new ArrayBuffer(r.length), n = new Uint8Array(a), i = 0; i < r.length; i++) + n[i] = r.charCodeAt(i); + return new Blob([a], { + type: e + }); + } + function Ll(t) { + var e = t.indexOf(","); + return t.substr(e + 1); + } + function Al(t, e, r) { + var a = function() { + return e.toDataURL(r, t.quality); + }; + switch (t.output) { + case "blob-promise": + return new ia(function(n, i) { + try { + e.toBlob(function(s) { + s != null ? n(s) : i(new Error("`canvas.toBlob()` sent a null value in its callback")); + }, r, t.quality); + } catch (s) { + i(s); + } + }); + case "blob": + return jg(Ll(a()), r); + case "base64": + return Ll(a()); + case "base64uri": + default: + return a(); + } + } + tn.png = function(t) { + return Al(t, this.bufferCanvasImage(t), "image/png"); + }, tn.jpg = function(t) { + return Al(t, this.bufferCanvasImage(t), "image/jpeg"); + }; + var Ol = {}; + Ol.nodeShapeImpl = function(t, e, r, a, n, i, s) { + switch (t) { + case "ellipse": + return this.drawEllipsePath(e, r, a, n, i); + case "polygon": + return this.drawPolygonPath(e, r, a, n, i, s); + case "round-polygon": + return this.drawRoundPolygonPath(e, r, a, n, i, s); + case "roundrectangle": + case "round-rectangle": + return this.drawRoundRectanglePath(e, r, a, n, i); + case "cutrectangle": + case "cut-rectangle": + return this.drawCutRectanglePath(e, r, a, n, i); + case "bottomroundrectangle": + case "bottom-round-rectangle": + return this.drawBottomRoundRectanglePath(e, r, a, n, i); + case "barrel": + return this.drawBarrelPath(e, r, a, n, i); + } + }; + var ep = Nl, ut = Nl.prototype; + ut.CANVAS_LAYERS = 3, ut.SELECT_BOX = 0, ut.DRAG = 1, ut.NODE = 2, ut.BUFFER_COUNT = 3, ut.TEXTURE_BUFFER = 0, ut.MOTIONBLUR_BUFFER_NODE = 1, ut.MOTIONBLUR_BUFFER_DRAG = 2; + function Nl(t) { + var e = this; + e.data = { + canvases: new Array(ut.CANVAS_LAYERS), + contexts: new Array(ut.CANVAS_LAYERS), + canvasNeedsRedraw: new Array(ut.CANVAS_LAYERS), + bufferCanvases: new Array(ut.BUFFER_COUNT), + bufferContexts: new Array(ut.CANVAS_LAYERS) + }; + var r = "-webkit-tap-highlight-color", a = "rgba(0,0,0,0)"; + e.data.canvasContainer = document.createElement("div"); + var n = e.data.canvasContainer.style; + e.data.canvasContainer.style[r] = a, n.position = "relative", n.zIndex = "0", n.overflow = "hidden"; + var i = t.cy.container(); + i.appendChild(e.data.canvasContainer), i.style[r] = a; + var s = { + "-webkit-user-select": "none", + "-moz-user-select": "-moz-none", + "user-select": "none", + "-webkit-tap-highlight-color": "rgba(0,0,0,0)", + "outline-style": "none" + }; + ht() && (s["-ms-touch-action"] = "none", s["touch-action"] = "none"); + for (var o = 0; o < ut.CANVAS_LAYERS; o++) { + var u = e.data.canvases[o] = document.createElement("canvas"); + e.data.contexts[o] = u.getContext("2d"), Object.keys(s).forEach(function(De) { + u.style[De] = s[De]; + }), u.style.position = "absolute", u.setAttribute("data-id", "layer" + o), u.style.zIndex = String(ut.CANVAS_LAYERS - o), e.data.canvasContainer.appendChild(u), e.data.canvasNeedsRedraw[o] = !1; + } + e.data.topCanvas = e.data.canvases[0], e.data.canvases[ut.NODE].setAttribute("data-id", "layer" + ut.NODE + "-node"), e.data.canvases[ut.SELECT_BOX].setAttribute("data-id", "layer" + ut.SELECT_BOX + "-selectbox"), e.data.canvases[ut.DRAG].setAttribute("data-id", "layer" + ut.DRAG + "-drag"); + for (var o = 0; o < ut.BUFFER_COUNT; o++) + e.data.bufferCanvases[o] = document.createElement("canvas"), e.data.bufferContexts[o] = e.data.bufferCanvases[o].getContext("2d"), e.data.bufferCanvases[o].style.position = "absolute", e.data.bufferCanvases[o].setAttribute("data-id", "buffer" + o), e.data.bufferCanvases[o].style.zIndex = String(-o - 1), e.data.bufferCanvases[o].style.visibility = "hidden"; + e.pathsEnabled = !0; + var l = Yt(), f = function(se) { + return { + x: (se.x1 + se.x2) / 2, + y: (se.y1 + se.y2) / 2 + }; + }, h = function(se) { + return { + x: -se.w / 2, + y: -se.h / 2 + }; + }, v = function(se) { + var xe = se[0]._private, Le = xe.oldBackgroundTimestamp === xe.backgroundTimestamp; + return !Le; + }, d = function(se) { + return se[0]._private.nodeKey; + }, c = function(se) { + return se[0]._private.labelStyleKey; + }, y = function(se) { + return se[0]._private.sourceLabelStyleKey; + }, p = function(se) { + return se[0]._private.targetLabelStyleKey; + }, g = function(se, xe, Le, Se, Oe) { + return e.drawElement(se, xe, Le, !1, !1, Oe); + }, m = function(se, xe, Le, Se, Oe) { + return e.drawElementText(se, xe, Le, Se, "main", Oe); + }, b = function(se, xe, Le, Se, Oe) { + return e.drawElementText(se, xe, Le, Se, "source", Oe); + }, E = function(se, xe, Le, Se, Oe) { + return e.drawElementText(se, xe, Le, Se, "target", Oe); + }, M = function(se) { + return se.boundingBox(), se[0]._private.bodyBounds; + }, L = function(se) { + return se.boundingBox(), se[0]._private.labelBounds.main || l; + }, w = function(se) { + return se.boundingBox(), se[0]._private.labelBounds.source || l; + }, k = function(se) { + return se.boundingBox(), se[0]._private.labelBounds.target || l; + }, D = function(se, xe) { + return xe; + }, F = function(se) { + return f(M(se)); + }, G = function(se, xe, Le) { + var Se = se ? se + "-" : ""; + return { + x: xe.x + Le.pstyle(Se + "text-margin-x").pfValue, + y: xe.y + Le.pstyle(Se + "text-margin-y").pfValue + }; + }, N = function(se, xe, Le) { + var Se = se[0]._private.rscratch; + return { + x: Se[xe], + y: Se[Le] + }; + }, X = function(se) { + return G("", N(se, "labelX", "labelY"), se); + }, B = function(se) { + return G("source", N(se, "sourceLabelX", "sourceLabelY"), se); + }, re = function(se) { + return G("target", N(se, "targetLabelX", "targetLabelY"), se); + }, K = function(se) { + return h(M(se)); + }, W = function(se) { + return h(w(se)); + }, ae = function(se) { + return h(k(se)); + }, ue = function(se) { + var xe = L(se), Le = h(L(se)); + if (se.isNode()) { + switch (se.pstyle("text-halign").value) { + case "left": + Le.x = -xe.w; + break; + case "right": + Le.x = 0; + break; + } + switch (se.pstyle("text-valign").value) { + case "top": + Le.y = -xe.h; + break; + case "bottom": + Le.y = 0; + break; + } + } + return Le; + }, me = e.data.eleTxrCache = new ja(e, { + getKey: d, + doesEleInvalidateKey: v, + drawElement: g, + getBoundingBox: M, + getRotationPoint: F, + getRotationOffset: K, + allowEdgeTxrCaching: !1, + allowParentTxrCaching: !1 + }), ie = e.data.lblTxrCache = new ja(e, { + getKey: c, + drawElement: m, + getBoundingBox: L, + getRotationPoint: X, + getRotationOffset: ue, + isVisible: D + }), ge = e.data.slbTxrCache = new ja(e, { + getKey: y, + drawElement: b, + getBoundingBox: w, + getRotationPoint: B, + getRotationOffset: W, + isVisible: D + }), Ee = e.data.tlbTxrCache = new ja(e, { + getKey: p, + drawElement: E, + getBoundingBox: k, + getRotationPoint: re, + getRotationOffset: ae, + isVisible: D + }), Ce = e.data.lyrTxrCache = new yl(e); + e.onUpdateEleCalcs(function(se, xe) { + me.invalidateElements(xe), ie.invalidateElements(xe), ge.invalidateElements(xe), Ee.invalidateElements(xe), Ce.invalidateElements(xe); + for (var Le = 0; Le < xe.length; Le++) { + var Se = xe[Le]._private; + Se.oldBackgroundTimestamp = Se.backgroundTimestamp; + } + }); + var we = function(se) { + for (var xe = 0; xe < se.length; xe++) + Ce.enqueueElementRefinement(se[xe].ele); + }; + me.onDequeue(we), ie.onDequeue(we), ge.onDequeue(we), Ee.onDequeue(we); + } + ut.redrawHint = function(t, e) { + var r = this; + switch (t) { + case "eles": + r.data.canvasNeedsRedraw[ut.NODE] = e; + break; + case "drag": + r.data.canvasNeedsRedraw[ut.DRAG] = e; + break; + case "select": + r.data.canvasNeedsRedraw[ut.SELECT_BOX] = e; + break; + } + }; + var tp = typeof Path2D < "u"; + ut.path2dEnabled = function(t) { + if (t === void 0) + return this.pathsEnabled; + this.pathsEnabled = !!t; + }, ut.usePaths = function() { + return tp && this.pathsEnabled; + }, ut.setImgSmoothing = function(t, e) { + t.imageSmoothingEnabled != null ? t.imageSmoothingEnabled = e : (t.webkitImageSmoothingEnabled = e, t.mozImageSmoothingEnabled = e, t.msImageSmoothingEnabled = e); + }, ut.getImgSmoothing = function(t) { + return t.imageSmoothingEnabled != null ? t.imageSmoothingEnabled : t.webkitImageSmoothingEnabled || t.mozImageSmoothingEnabled || t.msImageSmoothingEnabled; + }, ut.makeOffscreenCanvas = function(t, e) { + var r; + return (typeof OffscreenCanvas > "u" ? "undefined" : _(OffscreenCanvas)) !== "undefined" ? r = new OffscreenCanvas(t, e) : (r = document.createElement("canvas"), r.width = t, r.height = e), r; + }, [bl, vr, br, $i, _r, Ea, Kt, Mr, tn, Ol].forEach(function(t) { + He(ut, t); + }); + var rp = [{ + name: "null", + impl: tl + }, { + name: "base", + impl: cl + }, { + name: "canvas", + impl: ep + }], ap = [{ + type: "layout", + extensions: hg + }, { + type: "renderer", + extensions: rp + }], Il = {}, Ml = {}; + function Rl(t, e, r) { + var a = r, n = function(k) { + vt("Can not register `" + e + "` for `" + t + "` since `" + k + "` already exists in the prototype and can not be overridden"); + }; + if (t === "core") { + if (Za.prototype[e]) + return n(e); + Za.prototype[e] = r; + } else if (t === "collection") { + if (Nt.prototype[e]) + return n(e); + Nt.prototype[e] = r; + } else if (t === "layout") { + for (var i = function(k) { + this.options = k, r.call(this, k), S(this._private) || (this._private = {}), this._private.cy = k.cy, this._private.listeners = [], this.createEmitter(); + }, s = i.prototype = Object.create(r.prototype), o = [], u = 0; u < o.length; u++) { + var l = o[u]; + s[l] = s[l] || function() { + return this; + }; + } + s.start && !s.run ? s.run = function() { + return this.start(), this; + } : !s.start && s.run && (s.start = function() { + return this.run(), this; + }); + var f = r.prototype.stop; + s.stop = function() { + var w = this.options; + if (w && w.animate) { + var k = this.animations; + if (k) + for (var D = 0; D < k.length; D++) + k[D].stop(); + } + return f ? f.call(this) : this.emit("layoutstop"), this; + }, s.destroy || (s.destroy = function() { + return this; + }), s.cy = function() { + return this._private.cy; + }; + var h = function(k) { + return k._private.cy; + }, v = { + addEventFields: function(k, D) { + D.layout = k, D.cy = h(k), D.target = k; + }, + bubble: function() { + return !0; + }, + parent: function(k) { + return h(k); + } + }; + He(s, { + createEmitter: function() { + return this._private.emitter = new In(v, this), this; + }, + emitter: function() { + return this._private.emitter; + }, + on: function(k, D) { + return this.emitter().on(k, D), this; + }, + one: function(k, D) { + return this.emitter().one(k, D), this; + }, + once: function(k, D) { + return this.emitter().one(k, D), this; + }, + removeListener: function(k, D) { + return this.emitter().removeListener(k, D), this; + }, + removeAllListeners: function() { + return this.emitter().removeAllListeners(), this; + }, + emit: function(k, D) { + return this.emitter().emit(k, D), this; + } + }), ct.eventAliasesOn(s), a = i; + } else if (t === "renderer" && e !== "null" && e !== "base") { + var d = kl("renderer", "base"), c = d.prototype, y = r, p = r.prototype, g = function() { + d.apply(this, arguments), y.apply(this, arguments); + }, m = g.prototype; + for (var b in c) { + var E = c[b], M = p[b] != null; + if (M) + return n(b); + m[b] = E; + } + for (var L in p) + m[L] = p[L]; + c.clientFunctions.forEach(function(w) { + m[w] = m[w] || function() { + xt("Renderer does not implement `renderer." + w + "()` on its prototype"); + }; + }), a = g; + } else if (t === "__proto__" || t === "constructor" || t === "prototype") + return xt(t + " is an illegal type to be registered, possibly lead to prototype pollutions"); + return ts({ + map: Il, + keys: [t, e], + value: a + }); + } + function kl(t, e) { + return rs({ + map: Il, + keys: [t, e] + }); + } + function np(t, e, r, a, n) { + return ts({ + map: Ml, + keys: [t, e, r, a], + value: n + }); + } + function ip(t, e, r, a) { + return rs({ + map: Ml, + keys: [t, e, r, a] + }); + } + var Xi = function() { + if (arguments.length === 2) + return kl.apply(null, arguments); + if (arguments.length === 3) + return Rl.apply(null, arguments); + if (arguments.length === 4) + return ip.apply(null, arguments); + if (arguments.length === 5) + return np.apply(null, arguments); + xt("Invalid extension access syntax"); + }; + Za.prototype.extension = Xi, ap.forEach(function(t) { + t.extensions.forEach(function(e) { + Rl(t.type, e.name, e.impl); + }); + }); + var Pl = function t() { + if (!(this instanceof t)) + return new t(); + this.length = 0; + }, Yr = Pl.prototype; + Yr.instanceString = function() { + return "stylesheet"; + }, Yr.selector = function(t) { + var e = this.length++; + return this[e] = { + selector: t, + properties: [] + }, this; + }, Yr.css = function(t, e) { + var r = this.length - 1; + if (ee(t)) + this[r].properties.push({ + name: t, + value: e + }); + else if (S(t)) + for (var a = t, n = Object.keys(a), i = 0; i < n.length; i++) { + var s = n[i], o = a[s]; + if (o != null) { + var u = Gt.properties[s] || Gt.properties[yt(s)]; + if (u != null) { + var l = u.name, f = o; + this[r].properties.push({ + name: l, + value: f + }); + } + } + } + return this; + }, Yr.style = Yr.css, Yr.generateStyle = function(t) { + var e = new Gt(t); + return this.appendToStyle(e); + }, Yr.appendToStyle = function(t) { + for (var e = 0; e < this.length; e++) { + var r = this[e], a = r.selector, n = r.properties; + t.selector(a); + for (var i = 0; i < n.length; i++) { + var s = n[i]; + t.css(s.name, s.value); + } + } + return t; + }; + var sp = "3.28.1", Hr = function(e) { + if (e === void 0 && (e = {}), S(e)) + return new Za(e); + if (ee(e)) + return Xi.apply(Xi, arguments); + }; + return Hr.use = function(t) { + var e = Array.prototype.slice.call(arguments, 1); + return e.unshift(Hr), t.apply(null, e), this; + }, Hr.warnings = function(t) { + return gs(t); + }, Hr.version = sp, Hr.stylesheet = Hr.Stylesheet = Pl, Hr; + }); +})(Yl); +var Fp = Yl.exports; +const Hl = /* @__PURE__ */ $l(Fp); +var Xl = { exports: {} }, Ki = { exports: {} }, Zi = { exports: {} }, Vl; +function Gp() { + return Vl || (Vl = 1, function(de, Pe) { + (function(fe, Q) { + de.exports = Q(); + })(Ca, function() { + return ( + /******/ + function(_) { + var fe = {}; + function Q(C) { + if (fe[C]) + return fe[C].exports; + var T = fe[C] = { + /******/ + i: C, + /******/ + l: !1, + /******/ + exports: {} + /******/ + }; + return _[C].call(T.exports, T, T.exports, Q), T.l = !0, T.exports; + } + return Q.m = _, Q.c = fe, Q.i = function(C) { + return C; + }, Q.d = function(C, T, x) { + Q.o(C, T) || Object.defineProperty(C, T, { + /******/ + configurable: !1, + /******/ + enumerable: !0, + /******/ + get: x + /******/ + }); + }, Q.n = function(C) { + var T = C && C.__esModule ? ( + /******/ + function() { + return C.default; + } + ) : ( + /******/ + function() { + return C; + } + ); + return Q.d(T, "a", T), T; + }, Q.o = function(C, T) { + return Object.prototype.hasOwnProperty.call(C, T); + }, Q.p = "", Q(Q.s = 26); + }([ + /* 0 */ + /***/ + function(_, fe, Q) { + function C() { + } + C.QUALITY = 1, C.DEFAULT_CREATE_BENDS_AS_NEEDED = !1, C.DEFAULT_INCREMENTAL = !1, C.DEFAULT_ANIMATION_ON_LAYOUT = !0, C.DEFAULT_ANIMATION_DURING_LAYOUT = !1, C.DEFAULT_ANIMATION_PERIOD = 50, C.DEFAULT_UNIFORM_LEAF_NODE_SIZES = !1, C.DEFAULT_GRAPH_MARGIN = 15, C.NODE_DIMENSIONS_INCLUDE_LABELS = !1, C.SIMPLE_NODE_SIZE = 40, C.SIMPLE_NODE_HALF_SIZE = C.SIMPLE_NODE_SIZE / 2, C.EMPTY_COMPOUND_NODE_SIZE = 40, C.MIN_EDGE_LENGTH = 1, C.WORLD_BOUNDARY = 1e6, C.INITIAL_WORLD_BOUNDARY = C.WORLD_BOUNDARY / 1e3, C.WORLD_CENTER_X = 1200, C.WORLD_CENTER_Y = 900, _.exports = C; + }, + /* 1 */ + /***/ + function(_, fe, Q) { + var C = Q(2), T = Q(8), x = Q(9); + function I(Y, P, Z) { + C.call(this, Z), this.isOverlapingSourceAndTarget = !1, this.vGraphObject = Z, this.bendpoints = [], this.source = Y, this.target = P; + } + I.prototype = Object.create(C.prototype); + for (var z in C) + I[z] = C[z]; + I.prototype.getSource = function() { + return this.source; + }, I.prototype.getTarget = function() { + return this.target; + }, I.prototype.isInterGraph = function() { + return this.isInterGraph; + }, I.prototype.getLength = function() { + return this.length; + }, I.prototype.isOverlapingSourceAndTarget = function() { + return this.isOverlapingSourceAndTarget; + }, I.prototype.getBendpoints = function() { + return this.bendpoints; + }, I.prototype.getLca = function() { + return this.lca; + }, I.prototype.getSourceInLca = function() { + return this.sourceInLca; + }, I.prototype.getTargetInLca = function() { + return this.targetInLca; + }, I.prototype.getOtherEnd = function(Y) { + if (this.source === Y) + return this.target; + if (this.target === Y) + return this.source; + throw "Node is not incident with this edge"; + }, I.prototype.getOtherEndInGraph = function(Y, P) { + for (var Z = this.getOtherEnd(Y), A = P.getGraphManager().getRoot(); ; ) { + if (Z.getOwner() == P) + return Z; + if (Z.getOwner() == A) + break; + Z = Z.getOwner().getParent(); + } + return null; + }, I.prototype.updateLength = function() { + var Y = new Array(4); + this.isOverlapingSourceAndTarget = T.getIntersection(this.target.getRect(), this.source.getRect(), Y), this.isOverlapingSourceAndTarget || (this.lengthX = Y[0] - Y[2], this.lengthY = Y[1] - Y[3], Math.abs(this.lengthX) < 1 && (this.lengthX = x.sign(this.lengthX)), Math.abs(this.lengthY) < 1 && (this.lengthY = x.sign(this.lengthY)), this.length = Math.sqrt(this.lengthX * this.lengthX + this.lengthY * this.lengthY)); + }, I.prototype.updateLengthSimple = function() { + this.lengthX = this.target.getCenterX() - this.source.getCenterX(), this.lengthY = this.target.getCenterY() - this.source.getCenterY(), Math.abs(this.lengthX) < 1 && (this.lengthX = x.sign(this.lengthX)), Math.abs(this.lengthY) < 1 && (this.lengthY = x.sign(this.lengthY)), this.length = Math.sqrt(this.lengthX * this.lengthX + this.lengthY * this.lengthY); + }, _.exports = I; + }, + /* 2 */ + /***/ + function(_, fe, Q) { + function C(T) { + this.vGraphObject = T; + } + _.exports = C; + }, + /* 3 */ + /***/ + function(_, fe, Q) { + var C = Q(2), T = Q(10), x = Q(13), I = Q(0), z = Q(16), Y = Q(4); + function P(A, $, U, J) { + U == null && J == null && (J = $), C.call(this, J), A.graphManager != null && (A = A.graphManager), this.estimatedSize = T.MIN_VALUE, this.inclusionTreeDepth = T.MAX_VALUE, this.vGraphObject = J, this.edges = [], this.graphManager = A, U != null && $ != null ? this.rect = new x($.x, $.y, U.width, U.height) : this.rect = new x(); + } + P.prototype = Object.create(C.prototype); + for (var Z in C) + P[Z] = C[Z]; + P.prototype.getEdges = function() { + return this.edges; + }, P.prototype.getChild = function() { + return this.child; + }, P.prototype.getOwner = function() { + return this.owner; + }, P.prototype.getWidth = function() { + return this.rect.width; + }, P.prototype.setWidth = function(A) { + this.rect.width = A; + }, P.prototype.getHeight = function() { + return this.rect.height; + }, P.prototype.setHeight = function(A) { + this.rect.height = A; + }, P.prototype.getCenterX = function() { + return this.rect.x + this.rect.width / 2; + }, P.prototype.getCenterY = function() { + return this.rect.y + this.rect.height / 2; + }, P.prototype.getCenter = function() { + return new Y(this.rect.x + this.rect.width / 2, this.rect.y + this.rect.height / 2); + }, P.prototype.getLocation = function() { + return new Y(this.rect.x, this.rect.y); + }, P.prototype.getRect = function() { + return this.rect; + }, P.prototype.getDiagonal = function() { + return Math.sqrt(this.rect.width * this.rect.width + this.rect.height * this.rect.height); + }, P.prototype.getHalfTheDiagonal = function() { + return Math.sqrt(this.rect.height * this.rect.height + this.rect.width * this.rect.width) / 2; + }, P.prototype.setRect = function(A, $) { + this.rect.x = A.x, this.rect.y = A.y, this.rect.width = $.width, this.rect.height = $.height; + }, P.prototype.setCenter = function(A, $) { + this.rect.x = A - this.rect.width / 2, this.rect.y = $ - this.rect.height / 2; + }, P.prototype.setLocation = function(A, $) { + this.rect.x = A, this.rect.y = $; + }, P.prototype.moveBy = function(A, $) { + this.rect.x += A, this.rect.y += $; + }, P.prototype.getEdgeListToNode = function(A) { + var $ = [], U = this; + return U.edges.forEach(function(J) { + if (J.target == A) { + if (J.source != U) + throw "Incorrect edge source!"; + $.push(J); + } + }), $; + }, P.prototype.getEdgesBetween = function(A) { + var $ = [], U = this; + return U.edges.forEach(function(J) { + if (!(J.source == U || J.target == U)) + throw "Incorrect edge source and/or target"; + (J.target == A || J.source == A) && $.push(J); + }), $; + }, P.prototype.getNeighborsList = function() { + var A = /* @__PURE__ */ new Set(), $ = this; + return $.edges.forEach(function(U) { + if (U.source == $) + A.add(U.target); + else { + if (U.target != $) + throw "Incorrect incidency!"; + A.add(U.source); + } + }), A; + }, P.prototype.withChildren = function() { + var A = /* @__PURE__ */ new Set(), $, U; + if (A.add(this), this.child != null) + for (var J = this.child.getNodes(), ne = 0; ne < J.length; ne++) + $ = J[ne], U = $.withChildren(), U.forEach(function(le) { + A.add(le); + }); + return A; + }, P.prototype.getNoOfChildren = function() { + var A = 0, $; + if (this.child == null) + A = 1; + else + for (var U = this.child.getNodes(), J = 0; J < U.length; J++) + $ = U[J], A += $.getNoOfChildren(); + return A == 0 && (A = 1), A; + }, P.prototype.getEstimatedSize = function() { + if (this.estimatedSize == T.MIN_VALUE) + throw "assert failed"; + return this.estimatedSize; + }, P.prototype.calcEstimatedSize = function() { + return this.child == null ? this.estimatedSize = (this.rect.width + this.rect.height) / 2 : (this.estimatedSize = this.child.calcEstimatedSize(), this.rect.width = this.estimatedSize, this.rect.height = this.estimatedSize, this.estimatedSize); + }, P.prototype.scatter = function() { + var A, $, U = -I.INITIAL_WORLD_BOUNDARY, J = I.INITIAL_WORLD_BOUNDARY; + A = I.WORLD_CENTER_X + z.nextDouble() * (J - U) + U; + var ne = -I.INITIAL_WORLD_BOUNDARY, le = I.INITIAL_WORLD_BOUNDARY; + $ = I.WORLD_CENTER_Y + z.nextDouble() * (le - ne) + ne, this.rect.x = A, this.rect.y = $; + }, P.prototype.updateBounds = function() { + if (this.getChild() == null) + throw "assert failed"; + if (this.getChild().getNodes().length != 0) { + var A = this.getChild(); + if (A.updateBounds(!0), this.rect.x = A.getLeft(), this.rect.y = A.getTop(), this.setWidth(A.getRight() - A.getLeft()), this.setHeight(A.getBottom() - A.getTop()), I.NODE_DIMENSIONS_INCLUDE_LABELS) { + var $ = A.getRight() - A.getLeft(), U = A.getBottom() - A.getTop(); + this.labelWidth > $ && (this.rect.x -= (this.labelWidth - $) / 2, this.setWidth(this.labelWidth)), this.labelHeight > U && (this.labelPos == "center" ? this.rect.y -= (this.labelHeight - U) / 2 : this.labelPos == "top" && (this.rect.y -= this.labelHeight - U), this.setHeight(this.labelHeight)); + } + } + }, P.prototype.getInclusionTreeDepth = function() { + if (this.inclusionTreeDepth == T.MAX_VALUE) + throw "assert failed"; + return this.inclusionTreeDepth; + }, P.prototype.transform = function(A) { + var $ = this.rect.x; + $ > I.WORLD_BOUNDARY ? $ = I.WORLD_BOUNDARY : $ < -I.WORLD_BOUNDARY && ($ = -I.WORLD_BOUNDARY); + var U = this.rect.y; + U > I.WORLD_BOUNDARY ? U = I.WORLD_BOUNDARY : U < -I.WORLD_BOUNDARY && (U = -I.WORLD_BOUNDARY); + var J = new Y($, U), ne = A.inverseTransformPoint(J); + this.setLocation(ne.x, ne.y); + }, P.prototype.getLeft = function() { + return this.rect.x; + }, P.prototype.getRight = function() { + return this.rect.x + this.rect.width; + }, P.prototype.getTop = function() { + return this.rect.y; + }, P.prototype.getBottom = function() { + return this.rect.y + this.rect.height; + }, P.prototype.getParent = function() { + return this.owner == null ? null : this.owner.getParent(); + }, _.exports = P; + }, + /* 4 */ + /***/ + function(_, fe, Q) { + function C(T, x) { + T == null && x == null ? (this.x = 0, this.y = 0) : (this.x = T, this.y = x); + } + C.prototype.getX = function() { + return this.x; + }, C.prototype.getY = function() { + return this.y; + }, C.prototype.setX = function(T) { + this.x = T; + }, C.prototype.setY = function(T) { + this.y = T; + }, C.prototype.getDifference = function(T) { + return new DimensionD(this.x - T.x, this.y - T.y); + }, C.prototype.getCopy = function() { + return new C(this.x, this.y); + }, C.prototype.translate = function(T) { + return this.x += T.width, this.y += T.height, this; + }, _.exports = C; + }, + /* 5 */ + /***/ + function(_, fe, Q) { + var C = Q(2), T = Q(10), x = Q(0), I = Q(6), z = Q(3), Y = Q(1), P = Q(13), Z = Q(12), A = Q(11); + function $(J, ne, le) { + C.call(this, le), this.estimatedSize = T.MIN_VALUE, this.margin = x.DEFAULT_GRAPH_MARGIN, this.edges = [], this.nodes = [], this.isConnected = !1, this.parent = J, ne != null && ne instanceof I ? this.graphManager = ne : ne != null && ne instanceof Layout && (this.graphManager = ne.graphManager); + } + $.prototype = Object.create(C.prototype); + for (var U in C) + $[U] = C[U]; + $.prototype.getNodes = function() { + return this.nodes; + }, $.prototype.getEdges = function() { + return this.edges; + }, $.prototype.getGraphManager = function() { + return this.graphManager; + }, $.prototype.getParent = function() { + return this.parent; + }, $.prototype.getLeft = function() { + return this.left; + }, $.prototype.getRight = function() { + return this.right; + }, $.prototype.getTop = function() { + return this.top; + }, $.prototype.getBottom = function() { + return this.bottom; + }, $.prototype.isConnected = function() { + return this.isConnected; + }, $.prototype.add = function(J, ne, le) { + if (ne == null && le == null) { + var j = J; + if (this.graphManager == null) + throw "Graph has no graph mgr!"; + if (this.getNodes().indexOf(j) > -1) + throw "Node already in graph!"; + return j.owner = this, this.getNodes().push(j), j; + } else { + var ee = J; + if (!(this.getNodes().indexOf(ne) > -1 && this.getNodes().indexOf(le) > -1)) + throw "Source or target not in graph!"; + if (!(ne.owner == le.owner && ne.owner == this)) + throw "Both owners must be this graph!"; + return ne.owner != le.owner ? null : (ee.source = ne, ee.target = le, ee.isInterGraph = !1, this.getEdges().push(ee), ne.edges.push(ee), le != ne && le.edges.push(ee), ee); + } + }, $.prototype.remove = function(J) { + var ne = J; + if (J instanceof z) { + if (ne == null) + throw "Node is null!"; + if (!(ne.owner != null && ne.owner == this)) + throw "Owner graph is invalid!"; + if (this.graphManager == null) + throw "Owner graph manager is invalid!"; + for (var le = ne.edges.slice(), j, ee = le.length, H = 0; H < ee; H++) + j = le[H], j.isInterGraph ? this.graphManager.remove(j) : j.source.owner.remove(j); + var te = this.nodes.indexOf(ne); + if (te == -1) + throw "Node not in owner node list!"; + this.nodes.splice(te, 1); + } else if (J instanceof Y) { + var j = J; + if (j == null) + throw "Edge is null!"; + if (!(j.source != null && j.target != null)) + throw "Source and/or target is null!"; + if (!(j.source.owner != null && j.target.owner != null && j.source.owner == this && j.target.owner == this)) + throw "Source and/or target owner is invalid!"; + var S = j.source.edges.indexOf(j), V = j.target.edges.indexOf(j); + if (!(S > -1 && V > -1)) + throw "Source and/or target doesn't know this edge!"; + j.source.edges.splice(S, 1), j.target != j.source && j.target.edges.splice(V, 1); + var te = j.source.owner.getEdges().indexOf(j); + if (te == -1) + throw "Not in owner's edge list!"; + j.source.owner.getEdges().splice(te, 1); + } + }, $.prototype.updateLeftTop = function() { + for (var J = T.MAX_VALUE, ne = T.MAX_VALUE, le, j, ee, H = this.getNodes(), te = H.length, S = 0; S < te; S++) { + var V = H[S]; + le = V.getTop(), j = V.getLeft(), J > le && (J = le), ne > j && (ne = j); + } + return J == T.MAX_VALUE ? null : (H[0].getParent().paddingLeft != null ? ee = H[0].getParent().paddingLeft : ee = this.margin, this.left = ne - ee, this.top = J - ee, new Z(this.left, this.top)); + }, $.prototype.updateBounds = function(J) { + for (var ne = T.MAX_VALUE, le = -T.MAX_VALUE, j = T.MAX_VALUE, ee = -T.MAX_VALUE, H, te, S, V, R, q = this.nodes, ve = q.length, pe = 0; pe < ve; pe++) { + var Ae = q[pe]; + J && Ae.child != null && Ae.updateBounds(), H = Ae.getLeft(), te = Ae.getRight(), S = Ae.getTop(), V = Ae.getBottom(), ne > H && (ne = H), le < te && (le = te), j > S && (j = S), ee < V && (ee = V); + } + var Ne = new P(ne, j, le - ne, ee - j); + ne == T.MAX_VALUE && (this.left = this.parent.getLeft(), this.right = this.parent.getRight(), this.top = this.parent.getTop(), this.bottom = this.parent.getBottom()), q[0].getParent().paddingLeft != null ? R = q[0].getParent().paddingLeft : R = this.margin, this.left = Ne.x - R, this.right = Ne.x + Ne.width + R, this.top = Ne.y - R, this.bottom = Ne.y + Ne.height + R; + }, $.calculateBounds = function(J) { + for (var ne = T.MAX_VALUE, le = -T.MAX_VALUE, j = T.MAX_VALUE, ee = -T.MAX_VALUE, H, te, S, V, R = J.length, q = 0; q < R; q++) { + var ve = J[q]; + H = ve.getLeft(), te = ve.getRight(), S = ve.getTop(), V = ve.getBottom(), ne > H && (ne = H), le < te && (le = te), j > S && (j = S), ee < V && (ee = V); + } + var pe = new P(ne, j, le - ne, ee - j); + return pe; + }, $.prototype.getInclusionTreeDepth = function() { + return this == this.graphManager.getRoot() ? 1 : this.parent.getInclusionTreeDepth(); + }, $.prototype.getEstimatedSize = function() { + if (this.estimatedSize == T.MIN_VALUE) + throw "assert failed"; + return this.estimatedSize; + }, $.prototype.calcEstimatedSize = function() { + for (var J = 0, ne = this.nodes, le = ne.length, j = 0; j < le; j++) { + var ee = ne[j]; + J += ee.calcEstimatedSize(); + } + return J == 0 ? this.estimatedSize = x.EMPTY_COMPOUND_NODE_SIZE : this.estimatedSize = J / Math.sqrt(this.nodes.length), this.estimatedSize; + }, $.prototype.updateConnected = function() { + var J = this; + if (this.nodes.length == 0) { + this.isConnected = !0; + return; + } + var ne = new A(), le = /* @__PURE__ */ new Set(), j = this.nodes[0], ee, H, te = j.withChildren(); + for (te.forEach(function(pe) { + ne.push(pe), le.add(pe); + }); ne.length !== 0; ) { + j = ne.shift(), ee = j.getEdges(); + for (var S = ee.length, V = 0; V < S; V++) { + var R = ee[V]; + if (H = R.getOtherEndInGraph(j, this), H != null && !le.has(H)) { + var q = H.withChildren(); + q.forEach(function(pe) { + ne.push(pe), le.add(pe); + }); + } + } + } + if (this.isConnected = !1, le.size >= this.nodes.length) { + var ve = 0; + le.forEach(function(pe) { + pe.owner == J && ve++; + }), ve == this.nodes.length && (this.isConnected = !0); + } + }, _.exports = $; + }, + /* 6 */ + /***/ + function(_, fe, Q) { + var C, T = Q(1); + function x(I) { + C = Q(5), this.layout = I, this.graphs = [], this.edges = []; + } + x.prototype.addRoot = function() { + var I = this.layout.newGraph(), z = this.layout.newNode(null), Y = this.add(I, z); + return this.setRootGraph(Y), this.rootGraph; + }, x.prototype.add = function(I, z, Y, P, Z) { + if (Y == null && P == null && Z == null) { + if (I == null) + throw "Graph is null!"; + if (z == null) + throw "Parent node is null!"; + if (this.graphs.indexOf(I) > -1) + throw "Graph already in this graph mgr!"; + if (this.graphs.push(I), I.parent != null) + throw "Already has a parent!"; + if (z.child != null) + throw "Already has a child!"; + return I.parent = z, z.child = I, I; + } else { + Z = Y, P = z, Y = I; + var A = P.getOwner(), $ = Z.getOwner(); + if (!(A != null && A.getGraphManager() == this)) + throw "Source not in this graph mgr!"; + if (!($ != null && $.getGraphManager() == this)) + throw "Target not in this graph mgr!"; + if (A == $) + return Y.isInterGraph = !1, A.add(Y, P, Z); + if (Y.isInterGraph = !0, Y.source = P, Y.target = Z, this.edges.indexOf(Y) > -1) + throw "Edge already in inter-graph edge list!"; + if (this.edges.push(Y), !(Y.source != null && Y.target != null)) + throw "Edge source and/or target is null!"; + if (!(Y.source.edges.indexOf(Y) == -1 && Y.target.edges.indexOf(Y) == -1)) + throw "Edge already in source and/or target incidency list!"; + return Y.source.edges.push(Y), Y.target.edges.push(Y), Y; + } + }, x.prototype.remove = function(I) { + if (I instanceof C) { + var z = I; + if (z.getGraphManager() != this) + throw "Graph not in this graph mgr"; + if (!(z == this.rootGraph || z.parent != null && z.parent.graphManager == this)) + throw "Invalid parent node!"; + var Y = []; + Y = Y.concat(z.getEdges()); + for (var P, Z = Y.length, A = 0; A < Z; A++) + P = Y[A], z.remove(P); + var $ = []; + $ = $.concat(z.getNodes()); + var U; + Z = $.length; + for (var A = 0; A < Z; A++) + U = $[A], z.remove(U); + z == this.rootGraph && this.setRootGraph(null); + var J = this.graphs.indexOf(z); + this.graphs.splice(J, 1), z.parent = null; + } else if (I instanceof T) { + if (P = I, P == null) + throw "Edge is null!"; + if (!P.isInterGraph) + throw "Not an inter-graph edge!"; + if (!(P.source != null && P.target != null)) + throw "Source and/or target is null!"; + if (!(P.source.edges.indexOf(P) != -1 && P.target.edges.indexOf(P) != -1)) + throw "Source and/or target doesn't know this edge!"; + var J = P.source.edges.indexOf(P); + if (P.source.edges.splice(J, 1), J = P.target.edges.indexOf(P), P.target.edges.splice(J, 1), !(P.source.owner != null && P.source.owner.getGraphManager() != null)) + throw "Edge owner graph or owner graph manager is null!"; + if (P.source.owner.getGraphManager().edges.indexOf(P) == -1) + throw "Not in owner graph manager's edge list!"; + var J = P.source.owner.getGraphManager().edges.indexOf(P); + P.source.owner.getGraphManager().edges.splice(J, 1); + } + }, x.prototype.updateBounds = function() { + this.rootGraph.updateBounds(!0); + }, x.prototype.getGraphs = function() { + return this.graphs; + }, x.prototype.getAllNodes = function() { + if (this.allNodes == null) { + for (var I = [], z = this.getGraphs(), Y = z.length, P = 0; P < Y; P++) + I = I.concat(z[P].getNodes()); + this.allNodes = I; + } + return this.allNodes; + }, x.prototype.resetAllNodes = function() { + this.allNodes = null; + }, x.prototype.resetAllEdges = function() { + this.allEdges = null; + }, x.prototype.resetAllNodesToApplyGravitation = function() { + this.allNodesToApplyGravitation = null; + }, x.prototype.getAllEdges = function() { + if (this.allEdges == null) { + var I = [], z = this.getGraphs(); + z.length; + for (var Y = 0; Y < z.length; Y++) + I = I.concat(z[Y].getEdges()); + I = I.concat(this.edges), this.allEdges = I; + } + return this.allEdges; + }, x.prototype.getAllNodesToApplyGravitation = function() { + return this.allNodesToApplyGravitation; + }, x.prototype.setAllNodesToApplyGravitation = function(I) { + if (this.allNodesToApplyGravitation != null) + throw "assert failed"; + this.allNodesToApplyGravitation = I; + }, x.prototype.getRoot = function() { + return this.rootGraph; + }, x.prototype.setRootGraph = function(I) { + if (I.getGraphManager() != this) + throw "Root not in this graph mgr!"; + this.rootGraph = I, I.parent == null && (I.parent = this.layout.newNode("Root node")); + }, x.prototype.getLayout = function() { + return this.layout; + }, x.prototype.isOneAncestorOfOther = function(I, z) { + if (!(I != null && z != null)) + throw "assert failed"; + if (I == z) + return !0; + var Y = I.getOwner(), P; + do { + if (P = Y.getParent(), P == null) + break; + if (P == z) + return !0; + if (Y = P.getOwner(), Y == null) + break; + } while (!0); + Y = z.getOwner(); + do { + if (P = Y.getParent(), P == null) + break; + if (P == I) + return !0; + if (Y = P.getOwner(), Y == null) + break; + } while (!0); + return !1; + }, x.prototype.calcLowestCommonAncestors = function() { + for (var I, z, Y, P, Z, A = this.getAllEdges(), $ = A.length, U = 0; U < $; U++) { + if (I = A[U], z = I.source, Y = I.target, I.lca = null, I.sourceInLca = z, I.targetInLca = Y, z == Y) { + I.lca = z.getOwner(); + continue; + } + for (P = z.getOwner(); I.lca == null; ) { + for (I.targetInLca = Y, Z = Y.getOwner(); I.lca == null; ) { + if (Z == P) { + I.lca = Z; + break; + } + if (Z == this.rootGraph) + break; + if (I.lca != null) + throw "assert failed"; + I.targetInLca = Z.getParent(), Z = I.targetInLca.getOwner(); + } + if (P == this.rootGraph) + break; + I.lca == null && (I.sourceInLca = P.getParent(), P = I.sourceInLca.getOwner()); + } + if (I.lca == null) + throw "assert failed"; + } + }, x.prototype.calcLowestCommonAncestor = function(I, z) { + if (I == z) + return I.getOwner(); + var Y = I.getOwner(); + do { + if (Y == null) + break; + var P = z.getOwner(); + do { + if (P == null) + break; + if (P == Y) + return P; + P = P.getParent().getOwner(); + } while (!0); + Y = Y.getParent().getOwner(); + } while (!0); + return Y; + }, x.prototype.calcInclusionTreeDepths = function(I, z) { + I == null && z == null && (I = this.rootGraph, z = 1); + for (var Y, P = I.getNodes(), Z = P.length, A = 0; A < Z; A++) + Y = P[A], Y.inclusionTreeDepth = z, Y.child != null && this.calcInclusionTreeDepths(Y.child, z + 1); + }, x.prototype.includesInvalidEdge = function() { + for (var I, z = this.edges.length, Y = 0; Y < z; Y++) + if (I = this.edges[Y], this.isOneAncestorOfOther(I.source, I.target)) + return !0; + return !1; + }, _.exports = x; + }, + /* 7 */ + /***/ + function(_, fe, Q) { + var C = Q(0); + function T() { + } + for (var x in C) + T[x] = C[x]; + T.MAX_ITERATIONS = 2500, T.DEFAULT_EDGE_LENGTH = 50, T.DEFAULT_SPRING_STRENGTH = 0.45, T.DEFAULT_REPULSION_STRENGTH = 4500, T.DEFAULT_GRAVITY_STRENGTH = 0.4, T.DEFAULT_COMPOUND_GRAVITY_STRENGTH = 1, T.DEFAULT_GRAVITY_RANGE_FACTOR = 3.8, T.DEFAULT_COMPOUND_GRAVITY_RANGE_FACTOR = 1.5, T.DEFAULT_USE_SMART_IDEAL_EDGE_LENGTH_CALCULATION = !0, T.DEFAULT_USE_SMART_REPULSION_RANGE_CALCULATION = !0, T.DEFAULT_COOLING_FACTOR_INCREMENTAL = 0.3, T.COOLING_ADAPTATION_FACTOR = 0.33, T.ADAPTATION_LOWER_NODE_LIMIT = 1e3, T.ADAPTATION_UPPER_NODE_LIMIT = 5e3, T.MAX_NODE_DISPLACEMENT_INCREMENTAL = 100, T.MAX_NODE_DISPLACEMENT = T.MAX_NODE_DISPLACEMENT_INCREMENTAL * 3, T.MIN_REPULSION_DIST = T.DEFAULT_EDGE_LENGTH / 10, T.CONVERGENCE_CHECK_PERIOD = 100, T.PER_LEVEL_IDEAL_EDGE_LENGTH_FACTOR = 0.1, T.MIN_EDGE_LENGTH = 1, T.GRID_CALCULATION_CHECK_PERIOD = 10, _.exports = T; + }, + /* 8 */ + /***/ + function(_, fe, Q) { + var C = Q(12); + function T() { + } + T.calcSeparationAmount = function(x, I, z, Y) { + if (!x.intersects(I)) + throw "assert failed"; + var P = new Array(2); + this.decideDirectionsForOverlappingNodes(x, I, P), z[0] = Math.min(x.getRight(), I.getRight()) - Math.max(x.x, I.x), z[1] = Math.min(x.getBottom(), I.getBottom()) - Math.max(x.y, I.y), x.getX() <= I.getX() && x.getRight() >= I.getRight() ? z[0] += Math.min(I.getX() - x.getX(), x.getRight() - I.getRight()) : I.getX() <= x.getX() && I.getRight() >= x.getRight() && (z[0] += Math.min(x.getX() - I.getX(), I.getRight() - x.getRight())), x.getY() <= I.getY() && x.getBottom() >= I.getBottom() ? z[1] += Math.min(I.getY() - x.getY(), x.getBottom() - I.getBottom()) : I.getY() <= x.getY() && I.getBottom() >= x.getBottom() && (z[1] += Math.min(x.getY() - I.getY(), I.getBottom() - x.getBottom())); + var Z = Math.abs((I.getCenterY() - x.getCenterY()) / (I.getCenterX() - x.getCenterX())); + I.getCenterY() === x.getCenterY() && I.getCenterX() === x.getCenterX() && (Z = 1); + var A = Z * z[0], $ = z[1] / Z; + z[0] < $ ? $ = z[0] : A = z[1], z[0] = -1 * P[0] * ($ / 2 + Y), z[1] = -1 * P[1] * (A / 2 + Y); + }, T.decideDirectionsForOverlappingNodes = function(x, I, z) { + x.getCenterX() < I.getCenterX() ? z[0] = -1 : z[0] = 1, x.getCenterY() < I.getCenterY() ? z[1] = -1 : z[1] = 1; + }, T.getIntersection2 = function(x, I, z) { + var Y = x.getCenterX(), P = x.getCenterY(), Z = I.getCenterX(), A = I.getCenterY(); + if (x.intersects(I)) + return z[0] = Y, z[1] = P, z[2] = Z, z[3] = A, !0; + var $ = x.getX(), U = x.getY(), J = x.getRight(), ne = x.getX(), le = x.getBottom(), j = x.getRight(), ee = x.getWidthHalf(), H = x.getHeightHalf(), te = I.getX(), S = I.getY(), V = I.getRight(), R = I.getX(), q = I.getBottom(), ve = I.getRight(), pe = I.getWidthHalf(), Ae = I.getHeightHalf(), Ne = !1, Ye = !1; + if (Y === Z) { + if (P > A) + return z[0] = Y, z[1] = U, z[2] = Z, z[3] = q, !1; + if (P < A) + return z[0] = Y, z[1] = le, z[2] = Z, z[3] = S, !1; + } else if (P === A) { + if (Y > Z) + return z[0] = $, z[1] = P, z[2] = V, z[3] = A, !1; + if (Y < Z) + return z[0] = J, z[1] = P, z[2] = te, z[3] = A, !1; + } else { + var at = x.height / x.width, dt = I.height / I.width, Re = (A - P) / (Z - Y), Ve = void 0, Ze = void 0, nt = void 0, ht = void 0, it = void 0, tt = void 0; + if (-at === Re ? Y > Z ? (z[0] = ne, z[1] = le, Ne = !0) : (z[0] = J, z[1] = U, Ne = !0) : at === Re && (Y > Z ? (z[0] = $, z[1] = U, Ne = !0) : (z[0] = j, z[1] = le, Ne = !0)), -dt === Re ? Z > Y ? (z[2] = R, z[3] = q, Ye = !0) : (z[2] = V, z[3] = S, Ye = !0) : dt === Re && (Z > Y ? (z[2] = te, z[3] = S, Ye = !0) : (z[2] = ve, z[3] = q, Ye = !0)), Ne && Ye) + return !1; + if (Y > Z ? P > A ? (Ve = this.getCardinalDirection(at, Re, 4), Ze = this.getCardinalDirection(dt, Re, 2)) : (Ve = this.getCardinalDirection(-at, Re, 3), Ze = this.getCardinalDirection(-dt, Re, 1)) : P > A ? (Ve = this.getCardinalDirection(-at, Re, 1), Ze = this.getCardinalDirection(-dt, Re, 3)) : (Ve = this.getCardinalDirection(at, Re, 2), Ze = this.getCardinalDirection(dt, Re, 4)), !Ne) + switch (Ve) { + case 1: + ht = U, nt = Y + -H / Re, z[0] = nt, z[1] = ht; + break; + case 2: + nt = j, ht = P + ee * Re, z[0] = nt, z[1] = ht; + break; + case 3: + ht = le, nt = Y + H / Re, z[0] = nt, z[1] = ht; + break; + case 4: + nt = ne, ht = P + -ee * Re, z[0] = nt, z[1] = ht; + break; + } + if (!Ye) + switch (Ze) { + case 1: + tt = S, it = Z + -Ae / Re, z[2] = it, z[3] = tt; + break; + case 2: + it = ve, tt = A + pe * Re, z[2] = it, z[3] = tt; + break; + case 3: + tt = q, it = Z + Ae / Re, z[2] = it, z[3] = tt; + break; + case 4: + it = R, tt = A + -pe * Re, z[2] = it, z[3] = tt; + break; + } + } + return !1; + }, T.getCardinalDirection = function(x, I, z) { + return x > I ? z : 1 + z % 4; + }, T.getIntersection = function(x, I, z, Y) { + if (Y == null) + return this.getIntersection2(x, I, z); + var P = x.x, Z = x.y, A = I.x, $ = I.y, U = z.x, J = z.y, ne = Y.x, le = Y.y, j = void 0, ee = void 0, H = void 0, te = void 0, S = void 0, V = void 0, R = void 0, q = void 0, ve = void 0; + return H = $ - Z, S = P - A, R = A * Z - P * $, te = le - J, V = U - ne, q = ne * J - U * le, ve = H * V - te * S, ve === 0 ? null : (j = (S * q - V * R) / ve, ee = (te * R - H * q) / ve, new C(j, ee)); + }, T.angleOfVector = function(x, I, z, Y) { + var P = void 0; + return x !== z ? (P = Math.atan((Y - I) / (z - x)), z < x ? P += Math.PI : Y < I && (P += this.TWO_PI)) : Y < I ? P = this.ONE_AND_HALF_PI : P = this.HALF_PI, P; + }, T.doIntersect = function(x, I, z, Y) { + var P = x.x, Z = x.y, A = I.x, $ = I.y, U = z.x, J = z.y, ne = Y.x, le = Y.y, j = (A - P) * (le - J) - (ne - U) * ($ - Z); + if (j === 0) + return !1; + var ee = ((le - J) * (ne - P) + (U - ne) * (le - Z)) / j, H = ((Z - $) * (ne - P) + (A - P) * (le - Z)) / j; + return 0 < ee && ee < 1 && 0 < H && H < 1; + }, T.HALF_PI = 0.5 * Math.PI, T.ONE_AND_HALF_PI = 1.5 * Math.PI, T.TWO_PI = 2 * Math.PI, T.THREE_PI = 3 * Math.PI, _.exports = T; + }, + /* 9 */ + /***/ + function(_, fe, Q) { + function C() { + } + C.sign = function(T) { + return T > 0 ? 1 : T < 0 ? -1 : 0; + }, C.floor = function(T) { + return T < 0 ? Math.ceil(T) : Math.floor(T); + }, C.ceil = function(T) { + return T < 0 ? Math.floor(T) : Math.ceil(T); + }, _.exports = C; + }, + /* 10 */ + /***/ + function(_, fe, Q) { + function C() { + } + C.MAX_VALUE = 2147483647, C.MIN_VALUE = -2147483648, _.exports = C; + }, + /* 11 */ + /***/ + function(_, fe, Q) { + var C = function() { + function P(Z, A) { + for (var $ = 0; $ < A.length; $++) { + var U = A[$]; + U.enumerable = U.enumerable || !1, U.configurable = !0, "value" in U && (U.writable = !0), Object.defineProperty(Z, U.key, U); + } + } + return function(Z, A, $) { + return A && P(Z.prototype, A), $ && P(Z, $), Z; + }; + }(); + function T(P, Z) { + if (!(P instanceof Z)) + throw new TypeError("Cannot call a class as a function"); + } + var x = function(Z) { + return { value: Z, next: null, prev: null }; + }, I = function(Z, A, $, U) { + return Z !== null ? Z.next = A : U.head = A, $ !== null ? $.prev = A : U.tail = A, A.prev = Z, A.next = $, U.length++, A; + }, z = function(Z, A) { + var $ = Z.prev, U = Z.next; + return $ !== null ? $.next = U : A.head = U, U !== null ? U.prev = $ : A.tail = $, Z.prev = Z.next = null, A.length--, Z; + }, Y = function() { + function P(Z) { + var A = this; + T(this, P), this.length = 0, this.head = null, this.tail = null, Z != null && Z.forEach(function($) { + return A.push($); + }); + } + return C(P, [{ + key: "size", + value: function() { + return this.length; + } + }, { + key: "insertBefore", + value: function(A, $) { + return I($.prev, x(A), $, this); + } + }, { + key: "insertAfter", + value: function(A, $) { + return I($, x(A), $.next, this); + } + }, { + key: "insertNodeBefore", + value: function(A, $) { + return I($.prev, A, $, this); + } + }, { + key: "insertNodeAfter", + value: function(A, $) { + return I($, A, $.next, this); + } + }, { + key: "push", + value: function(A) { + return I(this.tail, x(A), null, this); + } + }, { + key: "unshift", + value: function(A) { + return I(null, x(A), this.head, this); + } + }, { + key: "remove", + value: function(A) { + return z(A, this); + } + }, { + key: "pop", + value: function() { + return z(this.tail, this).value; + } + }, { + key: "popNode", + value: function() { + return z(this.tail, this); + } + }, { + key: "shift", + value: function() { + return z(this.head, this).value; + } + }, { + key: "shiftNode", + value: function() { + return z(this.head, this); + } + }, { + key: "get_object_at", + value: function(A) { + if (A <= this.length()) { + for (var $ = 1, U = this.head; $ < A; ) + U = U.next, $++; + return U.value; + } + } + }, { + key: "set_object_at", + value: function(A, $) { + if (A <= this.length()) { + for (var U = 1, J = this.head; U < A; ) + J = J.next, U++; + J.value = $; + } + } + }]), P; + }(); + _.exports = Y; + }, + /* 12 */ + /***/ + function(_, fe, Q) { + function C(T, x, I) { + this.x = null, this.y = null, T == null && x == null && I == null ? (this.x = 0, this.y = 0) : typeof T == "number" && typeof x == "number" && I == null ? (this.x = T, this.y = x) : T.constructor.name == "Point" && x == null && I == null && (I = T, this.x = I.x, this.y = I.y); + } + C.prototype.getX = function() { + return this.x; + }, C.prototype.getY = function() { + return this.y; + }, C.prototype.getLocation = function() { + return new C(this.x, this.y); + }, C.prototype.setLocation = function(T, x, I) { + T.constructor.name == "Point" && x == null && I == null ? (I = T, this.setLocation(I.x, I.y)) : typeof T == "number" && typeof x == "number" && I == null && (parseInt(T) == T && parseInt(x) == x ? this.move(T, x) : (this.x = Math.floor(T + 0.5), this.y = Math.floor(x + 0.5))); + }, C.prototype.move = function(T, x) { + this.x = T, this.y = x; + }, C.prototype.translate = function(T, x) { + this.x += T, this.y += x; + }, C.prototype.equals = function(T) { + if (T.constructor.name == "Point") { + var x = T; + return this.x == x.x && this.y == x.y; + } + return this == T; + }, C.prototype.toString = function() { + return new C().constructor.name + "[x=" + this.x + ",y=" + this.y + "]"; + }, _.exports = C; + }, + /* 13 */ + /***/ + function(_, fe, Q) { + function C(T, x, I, z) { + this.x = 0, this.y = 0, this.width = 0, this.height = 0, T != null && x != null && I != null && z != null && (this.x = T, this.y = x, this.width = I, this.height = z); + } + C.prototype.getX = function() { + return this.x; + }, C.prototype.setX = function(T) { + this.x = T; + }, C.prototype.getY = function() { + return this.y; + }, C.prototype.setY = function(T) { + this.y = T; + }, C.prototype.getWidth = function() { + return this.width; + }, C.prototype.setWidth = function(T) { + this.width = T; + }, C.prototype.getHeight = function() { + return this.height; + }, C.prototype.setHeight = function(T) { + this.height = T; + }, C.prototype.getRight = function() { + return this.x + this.width; + }, C.prototype.getBottom = function() { + return this.y + this.height; + }, C.prototype.intersects = function(T) { + return !(this.getRight() < T.x || this.getBottom() < T.y || T.getRight() < this.x || T.getBottom() < this.y); + }, C.prototype.getCenterX = function() { + return this.x + this.width / 2; + }, C.prototype.getMinX = function() { + return this.getX(); + }, C.prototype.getMaxX = function() { + return this.getX() + this.width; + }, C.prototype.getCenterY = function() { + return this.y + this.height / 2; + }, C.prototype.getMinY = function() { + return this.getY(); + }, C.prototype.getMaxY = function() { + return this.getY() + this.height; + }, C.prototype.getWidthHalf = function() { + return this.width / 2; + }, C.prototype.getHeightHalf = function() { + return this.height / 2; + }, _.exports = C; + }, + /* 14 */ + /***/ + function(_, fe, Q) { + var C = typeof Symbol == "function" && typeof Symbol.iterator == "symbol" ? function(x) { + return typeof x; + } : function(x) { + return x && typeof Symbol == "function" && x.constructor === Symbol && x !== Symbol.prototype ? "symbol" : typeof x; + }; + function T() { + } + T.lastID = 0, T.createID = function(x) { + return T.isPrimitive(x) ? x : (x.uniqueID != null || (x.uniqueID = T.getString(), T.lastID++), x.uniqueID); + }, T.getString = function(x) { + return x == null && (x = T.lastID), "Object#" + x; + }, T.isPrimitive = function(x) { + var I = typeof x > "u" ? "undefined" : C(x); + return x == null || I != "object" && I != "function"; + }, _.exports = T; + }, + /* 15 */ + /***/ + function(_, fe, Q) { + function C(U) { + if (Array.isArray(U)) { + for (var J = 0, ne = Array(U.length); J < U.length; J++) + ne[J] = U[J]; + return ne; + } else + return Array.from(U); + } + var T = Q(0), x = Q(6), I = Q(3), z = Q(1), Y = Q(5), P = Q(4), Z = Q(17), A = Q(27); + function $(U) { + A.call(this), this.layoutQuality = T.QUALITY, this.createBendsAsNeeded = T.DEFAULT_CREATE_BENDS_AS_NEEDED, this.incremental = T.DEFAULT_INCREMENTAL, this.animationOnLayout = T.DEFAULT_ANIMATION_ON_LAYOUT, this.animationDuringLayout = T.DEFAULT_ANIMATION_DURING_LAYOUT, this.animationPeriod = T.DEFAULT_ANIMATION_PERIOD, this.uniformLeafNodeSizes = T.DEFAULT_UNIFORM_LEAF_NODE_SIZES, this.edgeToDummyNodes = /* @__PURE__ */ new Map(), this.graphManager = new x(this), this.isLayoutFinished = !1, this.isSubLayout = !1, this.isRemoteUse = !1, U != null && (this.isRemoteUse = U); + } + $.RANDOM_SEED = 1, $.prototype = Object.create(A.prototype), $.prototype.getGraphManager = function() { + return this.graphManager; + }, $.prototype.getAllNodes = function() { + return this.graphManager.getAllNodes(); + }, $.prototype.getAllEdges = function() { + return this.graphManager.getAllEdges(); + }, $.prototype.getAllNodesToApplyGravitation = function() { + return this.graphManager.getAllNodesToApplyGravitation(); + }, $.prototype.newGraphManager = function() { + var U = new x(this); + return this.graphManager = U, U; + }, $.prototype.newGraph = function(U) { + return new Y(null, this.graphManager, U); + }, $.prototype.newNode = function(U) { + return new I(this.graphManager, U); + }, $.prototype.newEdge = function(U) { + return new z(null, null, U); + }, $.prototype.checkLayoutSuccess = function() { + return this.graphManager.getRoot() == null || this.graphManager.getRoot().getNodes().length == 0 || this.graphManager.includesInvalidEdge(); + }, $.prototype.runLayout = function() { + this.isLayoutFinished = !1, this.tilingPreLayout && this.tilingPreLayout(), this.initParameters(); + var U; + return this.checkLayoutSuccess() ? U = !1 : U = this.layout(), T.ANIMATE === "during" ? !1 : (U && (this.isSubLayout || this.doPostLayout()), this.tilingPostLayout && this.tilingPostLayout(), this.isLayoutFinished = !0, U); + }, $.prototype.doPostLayout = function() { + this.incremental || this.transform(), this.update(); + }, $.prototype.update2 = function() { + if (this.createBendsAsNeeded && (this.createBendpointsFromDummyNodes(), this.graphManager.resetAllEdges()), !this.isRemoteUse) { + for (var U = this.graphManager.getAllEdges(), J = 0; J < U.length; J++) + U[J]; + for (var ne = this.graphManager.getRoot().getNodes(), J = 0; J < ne.length; J++) + ne[J]; + this.update(this.graphManager.getRoot()); + } + }, $.prototype.update = function(U) { + if (U == null) + this.update2(); + else if (U instanceof I) { + var J = U; + if (J.getChild() != null) + for (var ne = J.getChild().getNodes(), le = 0; le < ne.length; le++) + update(ne[le]); + if (J.vGraphObject != null) { + var j = J.vGraphObject; + j.update(J); + } + } else if (U instanceof z) { + var ee = U; + if (ee.vGraphObject != null) { + var H = ee.vGraphObject; + H.update(ee); + } + } else if (U instanceof Y) { + var te = U; + if (te.vGraphObject != null) { + var S = te.vGraphObject; + S.update(te); + } + } + }, $.prototype.initParameters = function() { + this.isSubLayout || (this.layoutQuality = T.QUALITY, this.animationDuringLayout = T.DEFAULT_ANIMATION_DURING_LAYOUT, this.animationPeriod = T.DEFAULT_ANIMATION_PERIOD, this.animationOnLayout = T.DEFAULT_ANIMATION_ON_LAYOUT, this.incremental = T.DEFAULT_INCREMENTAL, this.createBendsAsNeeded = T.DEFAULT_CREATE_BENDS_AS_NEEDED, this.uniformLeafNodeSizes = T.DEFAULT_UNIFORM_LEAF_NODE_SIZES), this.animationDuringLayout && (this.animationOnLayout = !1); + }, $.prototype.transform = function(U) { + if (U == null) + this.transform(new P(0, 0)); + else { + var J = new Z(), ne = this.graphManager.getRoot().updateLeftTop(); + if (ne != null) { + J.setWorldOrgX(U.x), J.setWorldOrgY(U.y), J.setDeviceOrgX(ne.x), J.setDeviceOrgY(ne.y); + for (var le = this.getAllNodes(), j, ee = 0; ee < le.length; ee++) + j = le[ee], j.transform(J); + } + } + }, $.prototype.positionNodesRandomly = function(U) { + if (U == null) + this.positionNodesRandomly(this.getGraphManager().getRoot()), this.getGraphManager().getRoot().updateBounds(!0); + else + for (var J, ne, le = U.getNodes(), j = 0; j < le.length; j++) + J = le[j], ne = J.getChild(), ne == null || ne.getNodes().length == 0 ? J.scatter() : (this.positionNodesRandomly(ne), J.updateBounds()); + }, $.prototype.getFlatForest = function() { + for (var U = [], J = !0, ne = this.graphManager.getRoot().getNodes(), le = !0, j = 0; j < ne.length; j++) + ne[j].getChild() != null && (le = !1); + if (!le) + return U; + var ee = /* @__PURE__ */ new Set(), H = [], te = /* @__PURE__ */ new Map(), S = []; + for (S = S.concat(ne); S.length > 0 && J; ) { + for (H.push(S[0]); H.length > 0 && J; ) { + var V = H[0]; + H.splice(0, 1), ee.add(V); + for (var R = V.getEdges(), j = 0; j < R.length; j++) { + var q = R[j].getOtherEnd(V); + if (te.get(V) != q) + if (!ee.has(q)) + H.push(q), te.set(q, V); + else { + J = !1; + break; + } + } + } + if (!J) + U = []; + else { + var ve = [].concat(C(ee)); + U.push(ve); + for (var j = 0; j < ve.length; j++) { + var pe = ve[j], Ae = S.indexOf(pe); + Ae > -1 && S.splice(Ae, 1); + } + ee = /* @__PURE__ */ new Set(), te = /* @__PURE__ */ new Map(); + } + } + return U; + }, $.prototype.createDummyNodesForBendpoints = function(U) { + for (var J = [], ne = U.source, le = this.graphManager.calcLowestCommonAncestor(U.source, U.target), j = 0; j < U.bendpoints.length; j++) { + var ee = this.newNode(null); + ee.setRect(new Point(0, 0), new Dimension(1, 1)), le.add(ee); + var H = this.newEdge(null); + this.graphManager.add(H, ne, ee), J.add(ee), ne = ee; + } + var H = this.newEdge(null); + return this.graphManager.add(H, ne, U.target), this.edgeToDummyNodes.set(U, J), U.isInterGraph() ? this.graphManager.remove(U) : le.remove(U), J; + }, $.prototype.createBendpointsFromDummyNodes = function() { + var U = []; + U = U.concat(this.graphManager.getAllEdges()), U = [].concat(C(this.edgeToDummyNodes.keys())).concat(U); + for (var J = 0; J < U.length; J++) { + var ne = U[J]; + if (ne.bendpoints.length > 0) { + for (var le = this.edgeToDummyNodes.get(ne), j = 0; j < le.length; j++) { + var ee = le[j], H = new P(ee.getCenterX(), ee.getCenterY()), te = ne.bendpoints.get(j); + te.x = H.x, te.y = H.y, ee.getOwner().remove(ee); + } + this.graphManager.add(ne, ne.source, ne.target); + } + } + }, $.transform = function(U, J, ne, le) { + if (ne != null && le != null) { + var j = J; + if (U <= 50) { + var ee = J / ne; + j -= (J - ee) / 50 * (50 - U); + } else { + var H = J * le; + j += (H - J) / 50 * (U - 50); + } + return j; + } else { + var te, S; + return U <= 50 ? (te = 9 * J / 500, S = J / 10) : (te = 9 * J / 50, S = -8 * J), te * U + S; + } + }, $.findCenterOfTree = function(U) { + var J = []; + J = J.concat(U); + var ne = [], le = /* @__PURE__ */ new Map(), j = !1, ee = null; + (J.length == 1 || J.length == 2) && (j = !0, ee = J[0]); + for (var H = 0; H < J.length; H++) { + var te = J[H], S = te.getNeighborsList().size; + le.set(te, te.getNeighborsList().size), S == 1 && ne.push(te); + } + var V = []; + for (V = V.concat(ne); !j; ) { + var R = []; + R = R.concat(V), V = []; + for (var H = 0; H < J.length; H++) { + var te = J[H], q = J.indexOf(te); + q >= 0 && J.splice(q, 1); + var ve = te.getNeighborsList(); + ve.forEach(function(Ne) { + if (ne.indexOf(Ne) < 0) { + var Ye = le.get(Ne), at = Ye - 1; + at == 1 && V.push(Ne), le.set(Ne, at); + } + }); + } + ne = ne.concat(V), (J.length == 1 || J.length == 2) && (j = !0, ee = J[0]); + } + return ee; + }, $.prototype.setGraphManager = function(U) { + this.graphManager = U; + }, _.exports = $; + }, + /* 16 */ + /***/ + function(_, fe, Q) { + function C() { + } + C.seed = 1, C.x = 0, C.nextDouble = function() { + return C.x = Math.sin(C.seed++) * 1e4, C.x - Math.floor(C.x); + }, _.exports = C; + }, + /* 17 */ + /***/ + function(_, fe, Q) { + var C = Q(4); + function T(x, I) { + this.lworldOrgX = 0, this.lworldOrgY = 0, this.ldeviceOrgX = 0, this.ldeviceOrgY = 0, this.lworldExtX = 1, this.lworldExtY = 1, this.ldeviceExtX = 1, this.ldeviceExtY = 1; + } + T.prototype.getWorldOrgX = function() { + return this.lworldOrgX; + }, T.prototype.setWorldOrgX = function(x) { + this.lworldOrgX = x; + }, T.prototype.getWorldOrgY = function() { + return this.lworldOrgY; + }, T.prototype.setWorldOrgY = function(x) { + this.lworldOrgY = x; + }, T.prototype.getWorldExtX = function() { + return this.lworldExtX; + }, T.prototype.setWorldExtX = function(x) { + this.lworldExtX = x; + }, T.prototype.getWorldExtY = function() { + return this.lworldExtY; + }, T.prototype.setWorldExtY = function(x) { + this.lworldExtY = x; + }, T.prototype.getDeviceOrgX = function() { + return this.ldeviceOrgX; + }, T.prototype.setDeviceOrgX = function(x) { + this.ldeviceOrgX = x; + }, T.prototype.getDeviceOrgY = function() { + return this.ldeviceOrgY; + }, T.prototype.setDeviceOrgY = function(x) { + this.ldeviceOrgY = x; + }, T.prototype.getDeviceExtX = function() { + return this.ldeviceExtX; + }, T.prototype.setDeviceExtX = function(x) { + this.ldeviceExtX = x; + }, T.prototype.getDeviceExtY = function() { + return this.ldeviceExtY; + }, T.prototype.setDeviceExtY = function(x) { + this.ldeviceExtY = x; + }, T.prototype.transformX = function(x) { + var I = 0, z = this.lworldExtX; + return z != 0 && (I = this.ldeviceOrgX + (x - this.lworldOrgX) * this.ldeviceExtX / z), I; + }, T.prototype.transformY = function(x) { + var I = 0, z = this.lworldExtY; + return z != 0 && (I = this.ldeviceOrgY + (x - this.lworldOrgY) * this.ldeviceExtY / z), I; + }, T.prototype.inverseTransformX = function(x) { + var I = 0, z = this.ldeviceExtX; + return z != 0 && (I = this.lworldOrgX + (x - this.ldeviceOrgX) * this.lworldExtX / z), I; + }, T.prototype.inverseTransformY = function(x) { + var I = 0, z = this.ldeviceExtY; + return z != 0 && (I = this.lworldOrgY + (x - this.ldeviceOrgY) * this.lworldExtY / z), I; + }, T.prototype.inverseTransformPoint = function(x) { + var I = new C(this.inverseTransformX(x.x), this.inverseTransformY(x.y)); + return I; + }, _.exports = T; + }, + /* 18 */ + /***/ + function(_, fe, Q) { + function C(A) { + if (Array.isArray(A)) { + for (var $ = 0, U = Array(A.length); $ < A.length; $++) + U[$] = A[$]; + return U; + } else + return Array.from(A); + } + var T = Q(15), x = Q(7), I = Q(0), z = Q(8), Y = Q(9); + function P() { + T.call(this), this.useSmartIdealEdgeLengthCalculation = x.DEFAULT_USE_SMART_IDEAL_EDGE_LENGTH_CALCULATION, this.idealEdgeLength = x.DEFAULT_EDGE_LENGTH, this.springConstant = x.DEFAULT_SPRING_STRENGTH, this.repulsionConstant = x.DEFAULT_REPULSION_STRENGTH, this.gravityConstant = x.DEFAULT_GRAVITY_STRENGTH, this.compoundGravityConstant = x.DEFAULT_COMPOUND_GRAVITY_STRENGTH, this.gravityRangeFactor = x.DEFAULT_GRAVITY_RANGE_FACTOR, this.compoundGravityRangeFactor = x.DEFAULT_COMPOUND_GRAVITY_RANGE_FACTOR, this.displacementThresholdPerNode = 3 * x.DEFAULT_EDGE_LENGTH / 100, this.coolingFactor = x.DEFAULT_COOLING_FACTOR_INCREMENTAL, this.initialCoolingFactor = x.DEFAULT_COOLING_FACTOR_INCREMENTAL, this.totalDisplacement = 0, this.oldTotalDisplacement = 0, this.maxIterations = x.MAX_ITERATIONS; + } + P.prototype = Object.create(T.prototype); + for (var Z in T) + P[Z] = T[Z]; + P.prototype.initParameters = function() { + T.prototype.initParameters.call(this, arguments), this.totalIterations = 0, this.notAnimatedIterations = 0, this.useFRGridVariant = x.DEFAULT_USE_SMART_REPULSION_RANGE_CALCULATION, this.grid = []; + }, P.prototype.calcIdealEdgeLengths = function() { + for (var A, $, U, J, ne, le, j = this.getGraphManager().getAllEdges(), ee = 0; ee < j.length; ee++) + A = j[ee], A.idealLength = this.idealEdgeLength, A.isInterGraph && (U = A.getSource(), J = A.getTarget(), ne = A.getSourceInLca().getEstimatedSize(), le = A.getTargetInLca().getEstimatedSize(), this.useSmartIdealEdgeLengthCalculation && (A.idealLength += ne + le - 2 * I.SIMPLE_NODE_SIZE), $ = A.getLca().getInclusionTreeDepth(), A.idealLength += x.DEFAULT_EDGE_LENGTH * x.PER_LEVEL_IDEAL_EDGE_LENGTH_FACTOR * (U.getInclusionTreeDepth() + J.getInclusionTreeDepth() - 2 * $)); + }, P.prototype.initSpringEmbedder = function() { + var A = this.getAllNodes().length; + this.incremental ? (A > x.ADAPTATION_LOWER_NODE_LIMIT && (this.coolingFactor = Math.max(this.coolingFactor * x.COOLING_ADAPTATION_FACTOR, this.coolingFactor - (A - x.ADAPTATION_LOWER_NODE_LIMIT) / (x.ADAPTATION_UPPER_NODE_LIMIT - x.ADAPTATION_LOWER_NODE_LIMIT) * this.coolingFactor * (1 - x.COOLING_ADAPTATION_FACTOR))), this.maxNodeDisplacement = x.MAX_NODE_DISPLACEMENT_INCREMENTAL) : (A > x.ADAPTATION_LOWER_NODE_LIMIT ? this.coolingFactor = Math.max(x.COOLING_ADAPTATION_FACTOR, 1 - (A - x.ADAPTATION_LOWER_NODE_LIMIT) / (x.ADAPTATION_UPPER_NODE_LIMIT - x.ADAPTATION_LOWER_NODE_LIMIT) * (1 - x.COOLING_ADAPTATION_FACTOR)) : this.coolingFactor = 1, this.initialCoolingFactor = this.coolingFactor, this.maxNodeDisplacement = x.MAX_NODE_DISPLACEMENT), this.maxIterations = Math.max(this.getAllNodes().length * 5, this.maxIterations), this.totalDisplacementThreshold = this.displacementThresholdPerNode * this.getAllNodes().length, this.repulsionRange = this.calcRepulsionRange(); + }, P.prototype.calcSpringForces = function() { + for (var A = this.getAllEdges(), $, U = 0; U < A.length; U++) + $ = A[U], this.calcSpringForce($, $.idealLength); + }, P.prototype.calcRepulsionForces = function() { + var A = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : !0, $ = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : !1, U, J, ne, le, j = this.getAllNodes(), ee; + if (this.useFRGridVariant) + for (this.totalIterations % x.GRID_CALCULATION_CHECK_PERIOD == 1 && A && this.updateGrid(), ee = /* @__PURE__ */ new Set(), U = 0; U < j.length; U++) + ne = j[U], this.calculateRepulsionForceOfANode(ne, ee, A, $), ee.add(ne); + else + for (U = 0; U < j.length; U++) + for (ne = j[U], J = U + 1; J < j.length; J++) + le = j[J], ne.getOwner() == le.getOwner() && this.calcRepulsionForce(ne, le); + }, P.prototype.calcGravitationalForces = function() { + for (var A, $ = this.getAllNodesToApplyGravitation(), U = 0; U < $.length; U++) + A = $[U], this.calcGravitationalForce(A); + }, P.prototype.moveNodes = function() { + for (var A = this.getAllNodes(), $, U = 0; U < A.length; U++) + $ = A[U], $.move(); + }, P.prototype.calcSpringForce = function(A, $) { + var U = A.getSource(), J = A.getTarget(), ne, le, j, ee; + if (this.uniformLeafNodeSizes && U.getChild() == null && J.getChild() == null) + A.updateLengthSimple(); + else if (A.updateLength(), A.isOverlapingSourceAndTarget) + return; + ne = A.getLength(), ne != 0 && (le = this.springConstant * (ne - $), j = le * (A.lengthX / ne), ee = le * (A.lengthY / ne), U.springForceX += j, U.springForceY += ee, J.springForceX -= j, J.springForceY -= ee); + }, P.prototype.calcRepulsionForce = function(A, $) { + var U = A.getRect(), J = $.getRect(), ne = new Array(2), le = new Array(4), j, ee, H, te, S, V, R; + if (U.intersects(J)) { + z.calcSeparationAmount(U, J, ne, x.DEFAULT_EDGE_LENGTH / 2), V = 2 * ne[0], R = 2 * ne[1]; + var q = A.noOfChildren * $.noOfChildren / (A.noOfChildren + $.noOfChildren); + A.repulsionForceX -= q * V, A.repulsionForceY -= q * R, $.repulsionForceX += q * V, $.repulsionForceY += q * R; + } else + this.uniformLeafNodeSizes && A.getChild() == null && $.getChild() == null ? (j = J.getCenterX() - U.getCenterX(), ee = J.getCenterY() - U.getCenterY()) : (z.getIntersection(U, J, le), j = le[2] - le[0], ee = le[3] - le[1]), Math.abs(j) < x.MIN_REPULSION_DIST && (j = Y.sign(j) * x.MIN_REPULSION_DIST), Math.abs(ee) < x.MIN_REPULSION_DIST && (ee = Y.sign(ee) * x.MIN_REPULSION_DIST), H = j * j + ee * ee, te = Math.sqrt(H), S = this.repulsionConstant * A.noOfChildren * $.noOfChildren / H, V = S * j / te, R = S * ee / te, A.repulsionForceX -= V, A.repulsionForceY -= R, $.repulsionForceX += V, $.repulsionForceY += R; + }, P.prototype.calcGravitationalForce = function(A) { + var $, U, J, ne, le, j, ee, H; + $ = A.getOwner(), U = ($.getRight() + $.getLeft()) / 2, J = ($.getTop() + $.getBottom()) / 2, ne = A.getCenterX() - U, le = A.getCenterY() - J, j = Math.abs(ne) + A.getWidth() / 2, ee = Math.abs(le) + A.getHeight() / 2, A.getOwner() == this.graphManager.getRoot() ? (H = $.getEstimatedSize() * this.gravityRangeFactor, (j > H || ee > H) && (A.gravitationForceX = -this.gravityConstant * ne, A.gravitationForceY = -this.gravityConstant * le)) : (H = $.getEstimatedSize() * this.compoundGravityRangeFactor, (j > H || ee > H) && (A.gravitationForceX = -this.gravityConstant * ne * this.compoundGravityConstant, A.gravitationForceY = -this.gravityConstant * le * this.compoundGravityConstant)); + }, P.prototype.isConverged = function() { + var A, $ = !1; + return this.totalIterations > this.maxIterations / 3 && ($ = Math.abs(this.totalDisplacement - this.oldTotalDisplacement) < 2), A = this.totalDisplacement < this.totalDisplacementThreshold, this.oldTotalDisplacement = this.totalDisplacement, A || $; + }, P.prototype.animate = function() { + this.animationDuringLayout && !this.isSubLayout && (this.notAnimatedIterations == this.animationPeriod ? (this.update(), this.notAnimatedIterations = 0) : this.notAnimatedIterations++); + }, P.prototype.calcNoOfChildrenForAllNodes = function() { + for (var A, $ = this.graphManager.getAllNodes(), U = 0; U < $.length; U++) + A = $[U], A.noOfChildren = A.getNoOfChildren(); + }, P.prototype.calcGrid = function(A) { + var $ = 0, U = 0; + $ = parseInt(Math.ceil((A.getRight() - A.getLeft()) / this.repulsionRange)), U = parseInt(Math.ceil((A.getBottom() - A.getTop()) / this.repulsionRange)); + for (var J = new Array($), ne = 0; ne < $; ne++) + J[ne] = new Array(U); + for (var ne = 0; ne < $; ne++) + for (var le = 0; le < U; le++) + J[ne][le] = new Array(); + return J; + }, P.prototype.addNodeToGrid = function(A, $, U) { + var J = 0, ne = 0, le = 0, j = 0; + J = parseInt(Math.floor((A.getRect().x - $) / this.repulsionRange)), ne = parseInt(Math.floor((A.getRect().width + A.getRect().x - $) / this.repulsionRange)), le = parseInt(Math.floor((A.getRect().y - U) / this.repulsionRange)), j = parseInt(Math.floor((A.getRect().height + A.getRect().y - U) / this.repulsionRange)); + for (var ee = J; ee <= ne; ee++) + for (var H = le; H <= j; H++) + this.grid[ee][H].push(A), A.setGridCoordinates(J, ne, le, j); + }, P.prototype.updateGrid = function() { + var A, $, U = this.getAllNodes(); + for (this.grid = this.calcGrid(this.graphManager.getRoot()), A = 0; A < U.length; A++) + $ = U[A], this.addNodeToGrid($, this.graphManager.getRoot().getLeft(), this.graphManager.getRoot().getTop()); + }, P.prototype.calculateRepulsionForceOfANode = function(A, $, U, J) { + if (this.totalIterations % x.GRID_CALCULATION_CHECK_PERIOD == 1 && U || J) { + var ne = /* @__PURE__ */ new Set(); + A.surrounding = new Array(); + for (var le, j = this.grid, ee = A.startX - 1; ee < A.finishX + 2; ee++) + for (var H = A.startY - 1; H < A.finishY + 2; H++) + if (!(ee < 0 || H < 0 || ee >= j.length || H >= j[0].length)) { + for (var te = 0; te < j[ee][H].length; te++) + if (le = j[ee][H][te], !(A.getOwner() != le.getOwner() || A == le) && !$.has(le) && !ne.has(le)) { + var S = Math.abs(A.getCenterX() - le.getCenterX()) - (A.getWidth() / 2 + le.getWidth() / 2), V = Math.abs(A.getCenterY() - le.getCenterY()) - (A.getHeight() / 2 + le.getHeight() / 2); + S <= this.repulsionRange && V <= this.repulsionRange && ne.add(le); + } + } + A.surrounding = [].concat(C(ne)); + } + for (ee = 0; ee < A.surrounding.length; ee++) + this.calcRepulsionForce(A, A.surrounding[ee]); + }, P.prototype.calcRepulsionRange = function() { + return 0; + }, _.exports = P; + }, + /* 19 */ + /***/ + function(_, fe, Q) { + var C = Q(1), T = Q(7); + function x(z, Y, P) { + C.call(this, z, Y, P), this.idealLength = T.DEFAULT_EDGE_LENGTH; + } + x.prototype = Object.create(C.prototype); + for (var I in C) + x[I] = C[I]; + _.exports = x; + }, + /* 20 */ + /***/ + function(_, fe, Q) { + var C = Q(3); + function T(I, z, Y, P) { + C.call(this, I, z, Y, P), this.springForceX = 0, this.springForceY = 0, this.repulsionForceX = 0, this.repulsionForceY = 0, this.gravitationForceX = 0, this.gravitationForceY = 0, this.displacementX = 0, this.displacementY = 0, this.startX = 0, this.finishX = 0, this.startY = 0, this.finishY = 0, this.surrounding = []; + } + T.prototype = Object.create(C.prototype); + for (var x in C) + T[x] = C[x]; + T.prototype.setGridCoordinates = function(I, z, Y, P) { + this.startX = I, this.finishX = z, this.startY = Y, this.finishY = P; + }, _.exports = T; + }, + /* 21 */ + /***/ + function(_, fe, Q) { + function C(T, x) { + this.width = 0, this.height = 0, T !== null && x !== null && (this.height = x, this.width = T); + } + C.prototype.getWidth = function() { + return this.width; + }, C.prototype.setWidth = function(T) { + this.width = T; + }, C.prototype.getHeight = function() { + return this.height; + }, C.prototype.setHeight = function(T) { + this.height = T; + }, _.exports = C; + }, + /* 22 */ + /***/ + function(_, fe, Q) { + var C = Q(14); + function T() { + this.map = {}, this.keys = []; + } + T.prototype.put = function(x, I) { + var z = C.createID(x); + this.contains(z) || (this.map[z] = I, this.keys.push(x)); + }, T.prototype.contains = function(x) { + return C.createID(x), this.map[x] != null; + }, T.prototype.get = function(x) { + var I = C.createID(x); + return this.map[I]; + }, T.prototype.keySet = function() { + return this.keys; + }, _.exports = T; + }, + /* 23 */ + /***/ + function(_, fe, Q) { + var C = Q(14); + function T() { + this.set = {}; + } + T.prototype.add = function(x) { + var I = C.createID(x); + this.contains(I) || (this.set[I] = x); + }, T.prototype.remove = function(x) { + delete this.set[C.createID(x)]; + }, T.prototype.clear = function() { + this.set = {}; + }, T.prototype.contains = function(x) { + return this.set[C.createID(x)] == x; + }, T.prototype.isEmpty = function() { + return this.size() === 0; + }, T.prototype.size = function() { + return Object.keys(this.set).length; + }, T.prototype.addAllTo = function(x) { + for (var I = Object.keys(this.set), z = I.length, Y = 0; Y < z; Y++) + x.push(this.set[I[Y]]); + }, T.prototype.size = function() { + return Object.keys(this.set).length; + }, T.prototype.addAll = function(x) { + for (var I = x.length, z = 0; z < I; z++) { + var Y = x[z]; + this.add(Y); + } + }, _.exports = T; + }, + /* 24 */ + /***/ + function(_, fe, Q) { + var C = function() { + function z(Y, P) { + for (var Z = 0; Z < P.length; Z++) { + var A = P[Z]; + A.enumerable = A.enumerable || !1, A.configurable = !0, "value" in A && (A.writable = !0), Object.defineProperty(Y, A.key, A); + } + } + return function(Y, P, Z) { + return P && z(Y.prototype, P), Z && z(Y, Z), Y; + }; + }(); + function T(z, Y) { + if (!(z instanceof Y)) + throw new TypeError("Cannot call a class as a function"); + } + var x = Q(11), I = function() { + function z(Y, P) { + T(this, z), (P !== null || P !== void 0) && (this.compareFunction = this._defaultCompareFunction); + var Z = void 0; + Y instanceof x ? Z = Y.size() : Z = Y.length, this._quicksort(Y, 0, Z - 1); + } + return C(z, [{ + key: "_quicksort", + value: function(P, Z, A) { + if (Z < A) { + var $ = this._partition(P, Z, A); + this._quicksort(P, Z, $), this._quicksort(P, $ + 1, A); + } + } + }, { + key: "_partition", + value: function(P, Z, A) { + for (var $ = this._get(P, Z), U = Z, J = A; ; ) { + for (; this.compareFunction($, this._get(P, J)); ) + J--; + for (; this.compareFunction(this._get(P, U), $); ) + U++; + if (U < J) + this._swap(P, U, J), U++, J--; + else + return J; + } + } + }, { + key: "_get", + value: function(P, Z) { + return P instanceof x ? P.get_object_at(Z) : P[Z]; + } + }, { + key: "_set", + value: function(P, Z, A) { + P instanceof x ? P.set_object_at(Z, A) : P[Z] = A; + } + }, { + key: "_swap", + value: function(P, Z, A) { + var $ = this._get(P, Z); + this._set(P, Z, this._get(P, A)), this._set(P, A, $); + } + }, { + key: "_defaultCompareFunction", + value: function(P, Z) { + return Z > P; + } + }]), z; + }(); + _.exports = I; + }, + /* 25 */ + /***/ + function(_, fe, Q) { + var C = function() { + function I(z, Y) { + for (var P = 0; P < Y.length; P++) { + var Z = Y[P]; + Z.enumerable = Z.enumerable || !1, Z.configurable = !0, "value" in Z && (Z.writable = !0), Object.defineProperty(z, Z.key, Z); + } + } + return function(z, Y, P) { + return Y && I(z.prototype, Y), P && I(z, P), z; + }; + }(); + function T(I, z) { + if (!(I instanceof z)) + throw new TypeError("Cannot call a class as a function"); + } + var x = function() { + function I(z, Y) { + var P = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : 1, Z = arguments.length > 3 && arguments[3] !== void 0 ? arguments[3] : -1, A = arguments.length > 4 && arguments[4] !== void 0 ? arguments[4] : -1; + T(this, I), this.sequence1 = z, this.sequence2 = Y, this.match_score = P, this.mismatch_penalty = Z, this.gap_penalty = A, this.iMax = z.length + 1, this.jMax = Y.length + 1, this.grid = new Array(this.iMax); + for (var $ = 0; $ < this.iMax; $++) { + this.grid[$] = new Array(this.jMax); + for (var U = 0; U < this.jMax; U++) + this.grid[$][U] = 0; + } + this.tracebackGrid = new Array(this.iMax); + for (var J = 0; J < this.iMax; J++) { + this.tracebackGrid[J] = new Array(this.jMax); + for (var ne = 0; ne < this.jMax; ne++) + this.tracebackGrid[J][ne] = [null, null, null]; + } + this.alignments = [], this.score = -1, this.computeGrids(); + } + return C(I, [{ + key: "getScore", + value: function() { + return this.score; + } + }, { + key: "getAlignments", + value: function() { + return this.alignments; + } + // Main dynamic programming procedure + }, { + key: "computeGrids", + value: function() { + for (var Y = 1; Y < this.jMax; Y++) + this.grid[0][Y] = this.grid[0][Y - 1] + this.gap_penalty, this.tracebackGrid[0][Y] = [!1, !1, !0]; + for (var P = 1; P < this.iMax; P++) + this.grid[P][0] = this.grid[P - 1][0] + this.gap_penalty, this.tracebackGrid[P][0] = [!1, !0, !1]; + for (var Z = 1; Z < this.iMax; Z++) + for (var A = 1; A < this.jMax; A++) { + var $ = void 0; + this.sequence1[Z - 1] === this.sequence2[A - 1] ? $ = this.grid[Z - 1][A - 1] + this.match_score : $ = this.grid[Z - 1][A - 1] + this.mismatch_penalty; + var U = this.grid[Z - 1][A] + this.gap_penalty, J = this.grid[Z][A - 1] + this.gap_penalty, ne = [$, U, J], le = this.arrayAllMaxIndexes(ne); + this.grid[Z][A] = ne[le[0]], this.tracebackGrid[Z][A] = [le.includes(0), le.includes(1), le.includes(2)]; + } + this.score = this.grid[this.iMax - 1][this.jMax - 1]; + } + // Gets all possible valid sequence combinations + }, { + key: "alignmentTraceback", + value: function() { + var Y = []; + for (Y.push({ + pos: [this.sequence1.length, this.sequence2.length], + seq1: "", + seq2: "" + }); Y[0]; ) { + var P = Y[0], Z = this.tracebackGrid[P.pos[0]][P.pos[1]]; + Z[0] && Y.push({ + pos: [P.pos[0] - 1, P.pos[1] - 1], + seq1: this.sequence1[P.pos[0] - 1] + P.seq1, + seq2: this.sequence2[P.pos[1] - 1] + P.seq2 + }), Z[1] && Y.push({ + pos: [P.pos[0] - 1, P.pos[1]], + seq1: this.sequence1[P.pos[0] - 1] + P.seq1, + seq2: "-" + P.seq2 + }), Z[2] && Y.push({ + pos: [P.pos[0], P.pos[1] - 1], + seq1: "-" + P.seq1, + seq2: this.sequence2[P.pos[1] - 1] + P.seq2 + }), P.pos[0] === 0 && P.pos[1] === 0 && this.alignments.push({ + sequence1: P.seq1, + sequence2: P.seq2 + }), Y.shift(); + } + return this.alignments; + } + // Helper Functions + }, { + key: "getAllIndexes", + value: function(Y, P) { + for (var Z = [], A = -1; (A = Y.indexOf(P, A + 1)) !== -1; ) + Z.push(A); + return Z; + } + }, { + key: "arrayAllMaxIndexes", + value: function(Y) { + return this.getAllIndexes(Y, Math.max.apply(null, Y)); + } + }]), I; + }(); + _.exports = x; + }, + /* 26 */ + /***/ + function(_, fe, Q) { + var C = function() { + }; + C.FDLayout = Q(18), C.FDLayoutConstants = Q(7), C.FDLayoutEdge = Q(19), C.FDLayoutNode = Q(20), C.DimensionD = Q(21), C.HashMap = Q(22), C.HashSet = Q(23), C.IGeometry = Q(8), C.IMath = Q(9), C.Integer = Q(10), C.Point = Q(12), C.PointD = Q(4), C.RandomSeed = Q(16), C.RectangleD = Q(13), C.Transform = Q(17), C.UniqueIDGeneretor = Q(14), C.Quicksort = Q(24), C.LinkedList = Q(11), C.LGraphObject = Q(2), C.LGraph = Q(5), C.LEdge = Q(1), C.LGraphManager = Q(6), C.LNode = Q(3), C.Layout = Q(15), C.LayoutConstants = Q(0), C.NeedlemanWunsch = Q(25), _.exports = C; + }, + /* 27 */ + /***/ + function(_, fe, Q) { + function C() { + this.listeners = []; + } + var T = C.prototype; + T.addListener = function(x, I) { + this.listeners.push({ + event: x, + callback: I + }); + }, T.removeListener = function(x, I) { + for (var z = this.listeners.length; z >= 0; z--) { + var Y = this.listeners[z]; + Y.event === x && Y.callback === I && this.listeners.splice(z, 1); + } + }, T.emit = function(x, I) { + for (var z = 0; z < this.listeners.length; z++) { + var Y = this.listeners[z]; + x === Y.event && Y.callback(I); + } + }, _.exports = C; + } + /******/ + ]) + ); + }); + }(Zi)), Zi.exports; +} +var Ul; +function zp() { + return Ul || (Ul = 1, function(de, Pe) { + (function(fe, Q) { + de.exports = Q(Gp()); + })(Ca, function(_) { + return ( + /******/ + function(fe) { + var Q = {}; + function C(T) { + if (Q[T]) + return Q[T].exports; + var x = Q[T] = { + /******/ + i: T, + /******/ + l: !1, + /******/ + exports: {} + /******/ + }; + return fe[T].call(x.exports, x, x.exports, C), x.l = !0, x.exports; + } + return C.m = fe, C.c = Q, C.i = function(T) { + return T; + }, C.d = function(T, x, I) { + C.o(T, x) || Object.defineProperty(T, x, { + /******/ + configurable: !1, + /******/ + enumerable: !0, + /******/ + get: I + /******/ + }); + }, C.n = function(T) { + var x = T && T.__esModule ? ( + /******/ + function() { + return T.default; + } + ) : ( + /******/ + function() { + return T; + } + ); + return C.d(x, "a", x), x; + }, C.o = function(T, x) { + return Object.prototype.hasOwnProperty.call(T, x); + }, C.p = "", C(C.s = 7); + }([ + /* 0 */ + /***/ + function(fe, Q) { + fe.exports = _; + }, + /* 1 */ + /***/ + function(fe, Q, C) { + var T = C(0).FDLayoutConstants; + function x() { + } + for (var I in T) + x[I] = T[I]; + x.DEFAULT_USE_MULTI_LEVEL_SCALING = !1, x.DEFAULT_RADIAL_SEPARATION = T.DEFAULT_EDGE_LENGTH, x.DEFAULT_COMPONENT_SEPERATION = 60, x.TILE = !0, x.TILING_PADDING_VERTICAL = 10, x.TILING_PADDING_HORIZONTAL = 10, x.TREE_REDUCTION_ON_INCREMENTAL = !1, fe.exports = x; + }, + /* 2 */ + /***/ + function(fe, Q, C) { + var T = C(0).FDLayoutEdge; + function x(z, Y, P) { + T.call(this, z, Y, P); + } + x.prototype = Object.create(T.prototype); + for (var I in T) + x[I] = T[I]; + fe.exports = x; + }, + /* 3 */ + /***/ + function(fe, Q, C) { + var T = C(0).LGraph; + function x(z, Y, P) { + T.call(this, z, Y, P); + } + x.prototype = Object.create(T.prototype); + for (var I in T) + x[I] = T[I]; + fe.exports = x; + }, + /* 4 */ + /***/ + function(fe, Q, C) { + var T = C(0).LGraphManager; + function x(z) { + T.call(this, z); + } + x.prototype = Object.create(T.prototype); + for (var I in T) + x[I] = T[I]; + fe.exports = x; + }, + /* 5 */ + /***/ + function(fe, Q, C) { + var T = C(0).FDLayoutNode, x = C(0).IMath; + function I(Y, P, Z, A) { + T.call(this, Y, P, Z, A); + } + I.prototype = Object.create(T.prototype); + for (var z in T) + I[z] = T[z]; + I.prototype.move = function() { + var Y = this.graphManager.getLayout(); + this.displacementX = Y.coolingFactor * (this.springForceX + this.repulsionForceX + this.gravitationForceX) / this.noOfChildren, this.displacementY = Y.coolingFactor * (this.springForceY + this.repulsionForceY + this.gravitationForceY) / this.noOfChildren, Math.abs(this.displacementX) > Y.coolingFactor * Y.maxNodeDisplacement && (this.displacementX = Y.coolingFactor * Y.maxNodeDisplacement * x.sign(this.displacementX)), Math.abs(this.displacementY) > Y.coolingFactor * Y.maxNodeDisplacement && (this.displacementY = Y.coolingFactor * Y.maxNodeDisplacement * x.sign(this.displacementY)), this.child == null ? this.moveBy(this.displacementX, this.displacementY) : this.child.getNodes().length == 0 ? this.moveBy(this.displacementX, this.displacementY) : this.propogateDisplacementToChildren(this.displacementX, this.displacementY), Y.totalDisplacement += Math.abs(this.displacementX) + Math.abs(this.displacementY), this.springForceX = 0, this.springForceY = 0, this.repulsionForceX = 0, this.repulsionForceY = 0, this.gravitationForceX = 0, this.gravitationForceY = 0, this.displacementX = 0, this.displacementY = 0; + }, I.prototype.propogateDisplacementToChildren = function(Y, P) { + for (var Z = this.getChild().getNodes(), A, $ = 0; $ < Z.length; $++) + A = Z[$], A.getChild() == null ? (A.moveBy(Y, P), A.displacementX += Y, A.displacementY += P) : A.propogateDisplacementToChildren(Y, P); + }, I.prototype.setPred1 = function(Y) { + this.pred1 = Y; + }, I.prototype.getPred1 = function() { + return pred1; + }, I.prototype.getPred2 = function() { + return pred2; + }, I.prototype.setNext = function(Y) { + this.next = Y; + }, I.prototype.getNext = function() { + return next; + }, I.prototype.setProcessed = function(Y) { + this.processed = Y; + }, I.prototype.isProcessed = function() { + return processed; + }, fe.exports = I; + }, + /* 6 */ + /***/ + function(fe, Q, C) { + var T = C(0).FDLayout, x = C(4), I = C(3), z = C(5), Y = C(2), P = C(1), Z = C(0).FDLayoutConstants, A = C(0).LayoutConstants, $ = C(0).Point, U = C(0).PointD, J = C(0).Layout, ne = C(0).Integer, le = C(0).IGeometry, j = C(0).LGraph, ee = C(0).Transform; + function H() { + T.call(this), this.toBeTiled = {}; + } + H.prototype = Object.create(T.prototype); + for (var te in T) + H[te] = T[te]; + H.prototype.newGraphManager = function() { + var S = new x(this); + return this.graphManager = S, S; + }, H.prototype.newGraph = function(S) { + return new I(null, this.graphManager, S); + }, H.prototype.newNode = function(S) { + return new z(this.graphManager, S); + }, H.prototype.newEdge = function(S) { + return new Y(null, null, S); + }, H.prototype.initParameters = function() { + T.prototype.initParameters.call(this, arguments), this.isSubLayout || (P.DEFAULT_EDGE_LENGTH < 10 ? this.idealEdgeLength = 10 : this.idealEdgeLength = P.DEFAULT_EDGE_LENGTH, this.useSmartIdealEdgeLengthCalculation = P.DEFAULT_USE_SMART_IDEAL_EDGE_LENGTH_CALCULATION, this.springConstant = Z.DEFAULT_SPRING_STRENGTH, this.repulsionConstant = Z.DEFAULT_REPULSION_STRENGTH, this.gravityConstant = Z.DEFAULT_GRAVITY_STRENGTH, this.compoundGravityConstant = Z.DEFAULT_COMPOUND_GRAVITY_STRENGTH, this.gravityRangeFactor = Z.DEFAULT_GRAVITY_RANGE_FACTOR, this.compoundGravityRangeFactor = Z.DEFAULT_COMPOUND_GRAVITY_RANGE_FACTOR, this.prunedNodesAll = [], this.growTreeIterations = 0, this.afterGrowthIterations = 0, this.isTreeGrowing = !1, this.isGrowthFinished = !1, this.coolingCycle = 0, this.maxCoolingCycle = this.maxIterations / Z.CONVERGENCE_CHECK_PERIOD, this.finalTemperature = Z.CONVERGENCE_CHECK_PERIOD / this.maxIterations, this.coolingAdjuster = 1); + }, H.prototype.layout = function() { + var S = A.DEFAULT_CREATE_BENDS_AS_NEEDED; + return S && (this.createBendpoints(), this.graphManager.resetAllEdges()), this.level = 0, this.classicLayout(); + }, H.prototype.classicLayout = function() { + if (this.nodesWithGravity = this.calculateNodesToApplyGravitationTo(), this.graphManager.setAllNodesToApplyGravitation(this.nodesWithGravity), this.calcNoOfChildrenForAllNodes(), this.graphManager.calcLowestCommonAncestors(), this.graphManager.calcInclusionTreeDepths(), this.graphManager.getRoot().calcEstimatedSize(), this.calcIdealEdgeLengths(), this.incremental) { + if (P.TREE_REDUCTION_ON_INCREMENTAL) { + this.reduceTrees(), this.graphManager.resetAllNodesToApplyGravitation(); + var V = new Set(this.getAllNodes()), R = this.nodesWithGravity.filter(function(pe) { + return V.has(pe); + }); + this.graphManager.setAllNodesToApplyGravitation(R); + } + } else { + var S = this.getFlatForest(); + if (S.length > 0) + this.positionNodesRadially(S); + else { + this.reduceTrees(), this.graphManager.resetAllNodesToApplyGravitation(); + var V = new Set(this.getAllNodes()), R = this.nodesWithGravity.filter(function(q) { + return V.has(q); + }); + this.graphManager.setAllNodesToApplyGravitation(R), this.positionNodesRandomly(); + } + } + return this.initSpringEmbedder(), this.runSpringEmbedder(), !0; + }, H.prototype.tick = function() { + if (this.totalIterations++, this.totalIterations === this.maxIterations && !this.isTreeGrowing && !this.isGrowthFinished) + if (this.prunedNodesAll.length > 0) + this.isTreeGrowing = !0; + else + return !0; + if (this.totalIterations % Z.CONVERGENCE_CHECK_PERIOD == 0 && !this.isTreeGrowing && !this.isGrowthFinished) { + if (this.isConverged()) + if (this.prunedNodesAll.length > 0) + this.isTreeGrowing = !0; + else + return !0; + this.coolingCycle++, this.layoutQuality == 0 ? this.coolingAdjuster = this.coolingCycle : this.layoutQuality == 1 && (this.coolingAdjuster = this.coolingCycle / 3), this.coolingFactor = Math.max(this.initialCoolingFactor - Math.pow(this.coolingCycle, Math.log(100 * (this.initialCoolingFactor - this.finalTemperature)) / Math.log(this.maxCoolingCycle)) / 100 * this.coolingAdjuster, this.finalTemperature), this.animationPeriod = Math.ceil(this.initialAnimationPeriod * Math.sqrt(this.coolingFactor)); + } + if (this.isTreeGrowing) { + if (this.growTreeIterations % 10 == 0) + if (this.prunedNodesAll.length > 0) { + this.graphManager.updateBounds(), this.updateGrid(), this.growTree(this.prunedNodesAll), this.graphManager.resetAllNodesToApplyGravitation(); + var S = new Set(this.getAllNodes()), V = this.nodesWithGravity.filter(function(ve) { + return S.has(ve); + }); + this.graphManager.setAllNodesToApplyGravitation(V), this.graphManager.updateBounds(), this.updateGrid(), this.coolingFactor = Z.DEFAULT_COOLING_FACTOR_INCREMENTAL; + } else + this.isTreeGrowing = !1, this.isGrowthFinished = !0; + this.growTreeIterations++; + } + if (this.isGrowthFinished) { + if (this.isConverged()) + return !0; + this.afterGrowthIterations % 10 == 0 && (this.graphManager.updateBounds(), this.updateGrid()), this.coolingFactor = Z.DEFAULT_COOLING_FACTOR_INCREMENTAL * ((100 - this.afterGrowthIterations) / 100), this.afterGrowthIterations++; + } + var R = !this.isTreeGrowing && !this.isGrowthFinished, q = this.growTreeIterations % 10 == 1 && this.isTreeGrowing || this.afterGrowthIterations % 10 == 1 && this.isGrowthFinished; + return this.totalDisplacement = 0, this.graphManager.updateBounds(), this.calcSpringForces(), this.calcRepulsionForces(R, q), this.calcGravitationalForces(), this.moveNodes(), this.animate(), !1; + }, H.prototype.getPositionsData = function() { + for (var S = this.graphManager.getAllNodes(), V = {}, R = 0; R < S.length; R++) { + var q = S[R].rect, ve = S[R].id; + V[ve] = { + id: ve, + x: q.getCenterX(), + y: q.getCenterY(), + w: q.width, + h: q.height + }; + } + return V; + }, H.prototype.runSpringEmbedder = function() { + this.initialAnimationPeriod = 25, this.animationPeriod = this.initialAnimationPeriod; + var S = !1; + if (Z.ANIMATE === "during") + this.emit("layoutstarted"); + else { + for (; !S; ) + S = this.tick(); + this.graphManager.updateBounds(); + } + }, H.prototype.calculateNodesToApplyGravitationTo = function() { + var S = [], V, R = this.graphManager.getGraphs(), q = R.length, ve; + for (ve = 0; ve < q; ve++) + V = R[ve], V.updateConnected(), V.isConnected || (S = S.concat(V.getNodes())); + return S; + }, H.prototype.createBendpoints = function() { + var S = []; + S = S.concat(this.graphManager.getAllEdges()); + var V = /* @__PURE__ */ new Set(), R; + for (R = 0; R < S.length; R++) { + var q = S[R]; + if (!V.has(q)) { + var ve = q.getSource(), pe = q.getTarget(); + if (ve == pe) + q.getBendpoints().push(new U()), q.getBendpoints().push(new U()), this.createDummyNodesForBendpoints(q), V.add(q); + else { + var Ae = []; + if (Ae = Ae.concat(ve.getEdgeListToNode(pe)), Ae = Ae.concat(pe.getEdgeListToNode(ve)), !V.has(Ae[0])) { + if (Ae.length > 1) { + var Ne; + for (Ne = 0; Ne < Ae.length; Ne++) { + var Ye = Ae[Ne]; + Ye.getBendpoints().push(new U()), this.createDummyNodesForBendpoints(Ye); + } + } + Ae.forEach(function(at) { + V.add(at); + }); + } + } + } + if (V.size == S.length) + break; + } + }, H.prototype.positionNodesRadially = function(S) { + for (var V = new $(0, 0), R = Math.ceil(Math.sqrt(S.length)), q = 0, ve = 0, pe = 0, Ae = new U(0, 0), Ne = 0; Ne < S.length; Ne++) { + Ne % R == 0 && (pe = 0, ve = q, Ne != 0 && (ve += P.DEFAULT_COMPONENT_SEPERATION), q = 0); + var Ye = S[Ne], at = J.findCenterOfTree(Ye); + V.x = pe, V.y = ve, Ae = H.radialLayout(Ye, at, V), Ae.y > q && (q = Math.floor(Ae.y)), pe = Math.floor(Ae.x + P.DEFAULT_COMPONENT_SEPERATION); + } + this.transform(new U(A.WORLD_CENTER_X - Ae.x / 2, A.WORLD_CENTER_Y - Ae.y / 2)); + }, H.radialLayout = function(S, V, R) { + var q = Math.max(this.maxDiagonalInTree(S), P.DEFAULT_RADIAL_SEPARATION); + H.branchRadialLayout(V, null, 0, 359, 0, q); + var ve = j.calculateBounds(S), pe = new ee(); + pe.setDeviceOrgX(ve.getMinX()), pe.setDeviceOrgY(ve.getMinY()), pe.setWorldOrgX(R.x), pe.setWorldOrgY(R.y); + for (var Ae = 0; Ae < S.length; Ae++) { + var Ne = S[Ae]; + Ne.transform(pe); + } + var Ye = new U(ve.getMaxX(), ve.getMaxY()); + return pe.inverseTransformPoint(Ye); + }, H.branchRadialLayout = function(S, V, R, q, ve, pe) { + var Ae = (q - R + 1) / 2; + Ae < 0 && (Ae += 180); + var Ne = (Ae + R) % 360, Ye = Ne * le.TWO_PI / 360, at = ve * Math.cos(Ye), dt = ve * Math.sin(Ye); + S.setCenter(at, dt); + var Re = []; + Re = Re.concat(S.getEdges()); + var Ve = Re.length; + V != null && Ve--; + for (var Ze = 0, nt = Re.length, ht, it = S.getEdgesBetween(V); it.length > 1; ) { + var tt = it[0]; + it.splice(0, 1); + var yt = Re.indexOf(tt); + yt >= 0 && Re.splice(yt, 1), nt--, Ve--; + } + V != null ? ht = (Re.indexOf(it[0]) + 1) % nt : ht = 0; + for (var Et = Math.abs(q - R) / Ve, Pt = ht; Ze != Ve; Pt = ++Pt % nt) { + var gt = Re[Pt].getOtherEnd(S); + if (gt != V) { + var dr = (R + Ze * Et) % 360, qt = (dr + Et) % 360; + H.branchRadialLayout(gt, S, dr, qt, ve + pe, pe), Ze++; + } + } + }, H.maxDiagonalInTree = function(S) { + for (var V = ne.MIN_VALUE, R = 0; R < S.length; R++) { + var q = S[R], ve = q.getDiagonal(); + ve > V && (V = ve); + } + return V; + }, H.prototype.calcRepulsionRange = function() { + return 2 * (this.level + 1) * this.idealEdgeLength; + }, H.prototype.groupZeroDegreeMembers = function() { + var S = this, V = {}; + this.memberGroups = {}, this.idToDummyNode = {}; + for (var R = [], q = this.graphManager.getAllNodes(), ve = 0; ve < q.length; ve++) { + var pe = q[ve], Ae = pe.getParent(); + this.getNodeDegreeWithChildren(pe) === 0 && (Ae.id == null || !this.getToBeTiled(Ae)) && R.push(pe); + } + for (var ve = 0; ve < R.length; ve++) { + var pe = R[ve], Ne = pe.getParent().id; + typeof V[Ne] > "u" && (V[Ne] = []), V[Ne] = V[Ne].concat(pe); + } + Object.keys(V).forEach(function(Ye) { + if (V[Ye].length > 1) { + var at = "DummyCompound_" + Ye; + S.memberGroups[at] = V[Ye]; + var dt = V[Ye][0].getParent(), Re = new z(S.graphManager); + Re.id = at, Re.paddingLeft = dt.paddingLeft || 0, Re.paddingRight = dt.paddingRight || 0, Re.paddingBottom = dt.paddingBottom || 0, Re.paddingTop = dt.paddingTop || 0, S.idToDummyNode[at] = Re; + var Ve = S.getGraphManager().add(S.newGraph(), Re), Ze = dt.getChild(); + Ze.add(Re); + for (var nt = 0; nt < V[Ye].length; nt++) { + var ht = V[Ye][nt]; + Ze.remove(ht), Ve.add(ht); + } + } + }); + }, H.prototype.clearCompounds = function() { + var S = {}, V = {}; + this.performDFSOnCompounds(); + for (var R = 0; R < this.compoundOrder.length; R++) + V[this.compoundOrder[R].id] = this.compoundOrder[R], S[this.compoundOrder[R].id] = [].concat(this.compoundOrder[R].getChild().getNodes()), this.graphManager.remove(this.compoundOrder[R].getChild()), this.compoundOrder[R].child = null; + this.graphManager.resetAllNodes(), this.tileCompoundMembers(S, V); + }, H.prototype.clearZeroDegreeMembers = function() { + var S = this, V = this.tiledZeroDegreePack = []; + Object.keys(this.memberGroups).forEach(function(R) { + var q = S.idToDummyNode[R]; + V[R] = S.tileNodes(S.memberGroups[R], q.paddingLeft + q.paddingRight), q.rect.width = V[R].width, q.rect.height = V[R].height; + }); + }, H.prototype.repopulateCompounds = function() { + for (var S = this.compoundOrder.length - 1; S >= 0; S--) { + var V = this.compoundOrder[S], R = V.id, q = V.paddingLeft, ve = V.paddingTop; + this.adjustLocations(this.tiledMemberPack[R], V.rect.x, V.rect.y, q, ve); + } + }, H.prototype.repopulateZeroDegreeMembers = function() { + var S = this, V = this.tiledZeroDegreePack; + Object.keys(V).forEach(function(R) { + var q = S.idToDummyNode[R], ve = q.paddingLeft, pe = q.paddingTop; + S.adjustLocations(V[R], q.rect.x, q.rect.y, ve, pe); + }); + }, H.prototype.getToBeTiled = function(S) { + var V = S.id; + if (this.toBeTiled[V] != null) + return this.toBeTiled[V]; + var R = S.getChild(); + if (R == null) + return this.toBeTiled[V] = !1, !1; + for (var q = R.getNodes(), ve = 0; ve < q.length; ve++) { + var pe = q[ve]; + if (this.getNodeDegree(pe) > 0) + return this.toBeTiled[V] = !1, !1; + if (pe.getChild() == null) { + this.toBeTiled[pe.id] = !1; + continue; + } + if (!this.getToBeTiled(pe)) + return this.toBeTiled[V] = !1, !1; + } + return this.toBeTiled[V] = !0, !0; + }, H.prototype.getNodeDegree = function(S) { + S.id; + for (var V = S.getEdges(), R = 0, q = 0; q < V.length; q++) { + var ve = V[q]; + ve.getSource().id !== ve.getTarget().id && (R = R + 1); + } + return R; + }, H.prototype.getNodeDegreeWithChildren = function(S) { + var V = this.getNodeDegree(S); + if (S.getChild() == null) + return V; + for (var R = S.getChild().getNodes(), q = 0; q < R.length; q++) { + var ve = R[q]; + V += this.getNodeDegreeWithChildren(ve); + } + return V; + }, H.prototype.performDFSOnCompounds = function() { + this.compoundOrder = [], this.fillCompexOrderByDFS(this.graphManager.getRoot().getNodes()); + }, H.prototype.fillCompexOrderByDFS = function(S) { + for (var V = 0; V < S.length; V++) { + var R = S[V]; + R.getChild() != null && this.fillCompexOrderByDFS(R.getChild().getNodes()), this.getToBeTiled(R) && this.compoundOrder.push(R); + } + }, H.prototype.adjustLocations = function(S, V, R, q, ve) { + V += q, R += ve; + for (var pe = V, Ae = 0; Ae < S.rows.length; Ae++) { + var Ne = S.rows[Ae]; + V = pe; + for (var Ye = 0, at = 0; at < Ne.length; at++) { + var dt = Ne[at]; + dt.rect.x = V, dt.rect.y = R, V += dt.rect.width + S.horizontalPadding, dt.rect.height > Ye && (Ye = dt.rect.height); + } + R += Ye + S.verticalPadding; + } + }, H.prototype.tileCompoundMembers = function(S, V) { + var R = this; + this.tiledMemberPack = [], Object.keys(S).forEach(function(q) { + var ve = V[q]; + R.tiledMemberPack[q] = R.tileNodes(S[q], ve.paddingLeft + ve.paddingRight), ve.rect.width = R.tiledMemberPack[q].width, ve.rect.height = R.tiledMemberPack[q].height; + }); + }, H.prototype.tileNodes = function(S, V) { + var R = P.TILING_PADDING_VERTICAL, q = P.TILING_PADDING_HORIZONTAL, ve = { + rows: [], + rowWidth: [], + rowHeight: [], + width: 0, + height: V, + // assume minHeight equals to minWidth + verticalPadding: R, + horizontalPadding: q + }; + S.sort(function(Ne, Ye) { + return Ne.rect.width * Ne.rect.height > Ye.rect.width * Ye.rect.height ? -1 : Ne.rect.width * Ne.rect.height < Ye.rect.width * Ye.rect.height ? 1 : 0; + }); + for (var pe = 0; pe < S.length; pe++) { + var Ae = S[pe]; + ve.rows.length == 0 ? this.insertNodeToRow(ve, Ae, 0, V) : this.canAddHorizontal(ve, Ae.rect.width, Ae.rect.height) ? this.insertNodeToRow(ve, Ae, this.getShortestRowIndex(ve), V) : this.insertNodeToRow(ve, Ae, ve.rows.length, V), this.shiftToLastRow(ve); + } + return ve; + }, H.prototype.insertNodeToRow = function(S, V, R, q) { + var ve = q; + if (R == S.rows.length) { + var pe = []; + S.rows.push(pe), S.rowWidth.push(ve), S.rowHeight.push(0); + } + var Ae = S.rowWidth[R] + V.rect.width; + S.rows[R].length > 0 && (Ae += S.horizontalPadding), S.rowWidth[R] = Ae, S.width < Ae && (S.width = Ae); + var Ne = V.rect.height; + R > 0 && (Ne += S.verticalPadding); + var Ye = 0; + Ne > S.rowHeight[R] && (Ye = S.rowHeight[R], S.rowHeight[R] = Ne, Ye = S.rowHeight[R] - Ye), S.height += Ye, S.rows[R].push(V); + }, H.prototype.getShortestRowIndex = function(S) { + for (var V = -1, R = Number.MAX_VALUE, q = 0; q < S.rows.length; q++) + S.rowWidth[q] < R && (V = q, R = S.rowWidth[q]); + return V; + }, H.prototype.getLongestRowIndex = function(S) { + for (var V = -1, R = Number.MIN_VALUE, q = 0; q < S.rows.length; q++) + S.rowWidth[q] > R && (V = q, R = S.rowWidth[q]); + return V; + }, H.prototype.canAddHorizontal = function(S, V, R) { + var q = this.getShortestRowIndex(S); + if (q < 0) + return !0; + var ve = S.rowWidth[q]; + if (ve + S.horizontalPadding + V <= S.width) + return !0; + var pe = 0; + S.rowHeight[q] < R && q > 0 && (pe = R + S.verticalPadding - S.rowHeight[q]); + var Ae; + S.width - ve >= V + S.horizontalPadding ? Ae = (S.height + pe) / (ve + V + S.horizontalPadding) : Ae = (S.height + pe) / S.width, pe = R + S.verticalPadding; + var Ne; + return S.width < V ? Ne = (S.height + pe) / V : Ne = (S.height + pe) / S.width, Ne < 1 && (Ne = 1 / Ne), Ae < 1 && (Ae = 1 / Ae), Ae < Ne; + }, H.prototype.shiftToLastRow = function(S) { + var V = this.getLongestRowIndex(S), R = S.rowWidth.length - 1, q = S.rows[V], ve = q[q.length - 1], pe = ve.width + S.horizontalPadding; + if (S.width - S.rowWidth[R] > pe && V != R) { + q.splice(-1, 1), S.rows[R].push(ve), S.rowWidth[V] = S.rowWidth[V] - pe, S.rowWidth[R] = S.rowWidth[R] + pe, S.width = S.rowWidth[instance.getLongestRowIndex(S)]; + for (var Ae = Number.MIN_VALUE, Ne = 0; Ne < q.length; Ne++) + q[Ne].height > Ae && (Ae = q[Ne].height); + V > 0 && (Ae += S.verticalPadding); + var Ye = S.rowHeight[V] + S.rowHeight[R]; + S.rowHeight[V] = Ae, S.rowHeight[R] < ve.height + S.verticalPadding && (S.rowHeight[R] = ve.height + S.verticalPadding); + var at = S.rowHeight[V] + S.rowHeight[R]; + S.height += at - Ye, this.shiftToLastRow(S); + } + }, H.prototype.tilingPreLayout = function() { + P.TILE && (this.groupZeroDegreeMembers(), this.clearCompounds(), this.clearZeroDegreeMembers()); + }, H.prototype.tilingPostLayout = function() { + P.TILE && (this.repopulateZeroDegreeMembers(), this.repopulateCompounds()); + }, H.prototype.reduceTrees = function() { + for (var S = [], V = !0, R; V; ) { + var q = this.graphManager.getAllNodes(), ve = []; + V = !1; + for (var pe = 0; pe < q.length; pe++) + R = q[pe], R.getEdges().length == 1 && !R.getEdges()[0].isInterGraph && R.getChild() == null && (ve.push([R, R.getEdges()[0], R.getOwner()]), V = !0); + if (V == !0) { + for (var Ae = [], Ne = 0; Ne < ve.length; Ne++) + ve[Ne][0].getEdges().length == 1 && (Ae.push(ve[Ne]), ve[Ne][0].getOwner().remove(ve[Ne][0])); + S.push(Ae), this.graphManager.resetAllNodes(), this.graphManager.resetAllEdges(); + } + } + this.prunedNodesAll = S; + }, H.prototype.growTree = function(S) { + for (var V = S.length, R = S[V - 1], q, ve = 0; ve < R.length; ve++) + q = R[ve], this.findPlaceforPrunedNode(q), q[2].add(q[0]), q[2].add(q[1], q[1].source, q[1].target); + S.splice(S.length - 1, 1), this.graphManager.resetAllNodes(), this.graphManager.resetAllEdges(); + }, H.prototype.findPlaceforPrunedNode = function(S) { + var V, R, q = S[0]; + q == S[1].source ? R = S[1].target : R = S[1].source; + var ve = R.startX, pe = R.finishX, Ae = R.startY, Ne = R.finishY, Ye = 0, at = 0, dt = 0, Re = 0, Ve = [Ye, dt, at, Re]; + if (Ae > 0) + for (var Ze = ve; Ze <= pe; Ze++) + Ve[0] += this.grid[Ze][Ae - 1].length + this.grid[Ze][Ae].length - 1; + if (pe < this.grid.length - 1) + for (var Ze = Ae; Ze <= Ne; Ze++) + Ve[1] += this.grid[pe + 1][Ze].length + this.grid[pe][Ze].length - 1; + if (Ne < this.grid[0].length - 1) + for (var Ze = ve; Ze <= pe; Ze++) + Ve[2] += this.grid[Ze][Ne + 1].length + this.grid[Ze][Ne].length - 1; + if (ve > 0) + for (var Ze = Ae; Ze <= Ne; Ze++) + Ve[3] += this.grid[ve - 1][Ze].length + this.grid[ve][Ze].length - 1; + for (var nt = ne.MAX_VALUE, ht, it, tt = 0; tt < Ve.length; tt++) + Ve[tt] < nt ? (nt = Ve[tt], ht = 1, it = tt) : Ve[tt] == nt && ht++; + if (ht == 3 && nt == 0) + Ve[0] == 0 && Ve[1] == 0 && Ve[2] == 0 ? V = 1 : Ve[0] == 0 && Ve[1] == 0 && Ve[3] == 0 ? V = 0 : Ve[0] == 0 && Ve[2] == 0 && Ve[3] == 0 ? V = 3 : Ve[1] == 0 && Ve[2] == 0 && Ve[3] == 0 && (V = 2); + else if (ht == 2 && nt == 0) { + var yt = Math.floor(Math.random() * 2); + Ve[0] == 0 && Ve[1] == 0 ? yt == 0 ? V = 0 : V = 1 : Ve[0] == 0 && Ve[2] == 0 ? yt == 0 ? V = 0 : V = 2 : Ve[0] == 0 && Ve[3] == 0 ? yt == 0 ? V = 0 : V = 3 : Ve[1] == 0 && Ve[2] == 0 ? yt == 0 ? V = 1 : V = 2 : Ve[1] == 0 && Ve[3] == 0 ? yt == 0 ? V = 1 : V = 3 : yt == 0 ? V = 2 : V = 3; + } else if (ht == 4 && nt == 0) { + var yt = Math.floor(Math.random() * 4); + V = yt; + } else + V = it; + V == 0 ? q.setCenter(R.getCenterX(), R.getCenterY() - R.getHeight() / 2 - Z.DEFAULT_EDGE_LENGTH - q.getHeight() / 2) : V == 1 ? q.setCenter(R.getCenterX() + R.getWidth() / 2 + Z.DEFAULT_EDGE_LENGTH + q.getWidth() / 2, R.getCenterY()) : V == 2 ? q.setCenter(R.getCenterX(), R.getCenterY() + R.getHeight() / 2 + Z.DEFAULT_EDGE_LENGTH + q.getHeight() / 2) : q.setCenter(R.getCenterX() - R.getWidth() / 2 - Z.DEFAULT_EDGE_LENGTH - q.getWidth() / 2, R.getCenterY()); + }, fe.exports = H; + }, + /* 7 */ + /***/ + function(fe, Q, C) { + var T = {}; + T.layoutBase = C(0), T.CoSEConstants = C(1), T.CoSEEdge = C(2), T.CoSEGraph = C(3), T.CoSEGraphManager = C(4), T.CoSELayout = C(6), T.CoSENode = C(5), fe.exports = T; + } + /******/ + ]) + ); + }); + }(Ki)), Ki.exports; +} +(function(de, Pe) { + (function(fe, Q) { + de.exports = Q(zp()); + })(Ca, function(_) { + return ( + /******/ + function(fe) { + var Q = {}; + function C(T) { + if (Q[T]) + return Q[T].exports; + var x = Q[T] = { + /******/ + i: T, + /******/ + l: !1, + /******/ + exports: {} + /******/ + }; + return fe[T].call(x.exports, x, x.exports, C), x.l = !0, x.exports; + } + return C.m = fe, C.c = Q, C.i = function(T) { + return T; + }, C.d = function(T, x, I) { + C.o(T, x) || Object.defineProperty(T, x, { + /******/ + configurable: !1, + /******/ + enumerable: !0, + /******/ + get: I + /******/ + }); + }, C.n = function(T) { + var x = T && T.__esModule ? ( + /******/ + function() { + return T.default; + } + ) : ( + /******/ + function() { + return T; + } + ); + return C.d(x, "a", x), x; + }, C.o = function(T, x) { + return Object.prototype.hasOwnProperty.call(T, x); + }, C.p = "", C(C.s = 1); + }([ + /* 0 */ + /***/ + function(fe, Q) { + fe.exports = _; + }, + /* 1 */ + /***/ + function(fe, Q, C) { + var T = C(0).layoutBase.LayoutConstants, x = C(0).layoutBase.FDLayoutConstants, I = C(0).CoSEConstants, z = C(0).CoSELayout, Y = C(0).CoSENode, P = C(0).layoutBase.PointD, Z = C(0).layoutBase.DimensionD, A = { + // Called on `layoutready` + ready: function() { + }, + // Called on `layoutstop` + stop: function() { + }, + // 'draft', 'default' or 'proof" + // - 'draft' fast cooling rate + // - 'default' moderate cooling rate + // - "proof" slow cooling rate + quality: "default", + // include labels in node dimensions + nodeDimensionsIncludeLabels: !1, + // number of ticks per frame; higher is faster but more jerky + refresh: 30, + // Whether to fit the network view after when done + fit: !0, + // Padding on fit + padding: 10, + // Whether to enable incremental mode + randomize: !0, + // Node repulsion (non overlapping) multiplier + nodeRepulsion: 4500, + // Ideal edge (non nested) length + idealEdgeLength: 50, + // Divisor to compute edge forces + edgeElasticity: 0.45, + // Nesting factor (multiplier) to compute ideal edge length for nested edges + nestingFactor: 0.1, + // Gravity force (constant) + gravity: 0.25, + // Maximum number of iterations to perform + numIter: 2500, + // For enabling tiling + tile: !0, + // Type of layout animation. The option set is {'during', 'end', false} + animate: "end", + // Duration for animate:end + animationDuration: 500, + // Represents the amount of the vertical space to put between the zero degree members during the tiling operation(can also be a function) + tilingPaddingVertical: 10, + // Represents the amount of the horizontal space to put between the zero degree members during the tiling operation(can also be a function) + tilingPaddingHorizontal: 10, + // Gravity range (constant) for compounds + gravityRangeCompound: 1.5, + // Gravity force (constant) for compounds + gravityCompound: 1, + // Gravity range (constant) + gravityRange: 3.8, + // Initial cooling factor for incremental layout + initialEnergyOnIncremental: 0.5 + }; + function $(le, j) { + var ee = {}; + for (var H in le) + ee[H] = le[H]; + for (var H in j) + ee[H] = j[H]; + return ee; + } + function U(le) { + this.options = $(A, le), J(this.options); + } + var J = function(j) { + j.nodeRepulsion != null && (I.DEFAULT_REPULSION_STRENGTH = x.DEFAULT_REPULSION_STRENGTH = j.nodeRepulsion), j.idealEdgeLength != null && (I.DEFAULT_EDGE_LENGTH = x.DEFAULT_EDGE_LENGTH = j.idealEdgeLength), j.edgeElasticity != null && (I.DEFAULT_SPRING_STRENGTH = x.DEFAULT_SPRING_STRENGTH = j.edgeElasticity), j.nestingFactor != null && (I.PER_LEVEL_IDEAL_EDGE_LENGTH_FACTOR = x.PER_LEVEL_IDEAL_EDGE_LENGTH_FACTOR = j.nestingFactor), j.gravity != null && (I.DEFAULT_GRAVITY_STRENGTH = x.DEFAULT_GRAVITY_STRENGTH = j.gravity), j.numIter != null && (I.MAX_ITERATIONS = x.MAX_ITERATIONS = j.numIter), j.gravityRange != null && (I.DEFAULT_GRAVITY_RANGE_FACTOR = x.DEFAULT_GRAVITY_RANGE_FACTOR = j.gravityRange), j.gravityCompound != null && (I.DEFAULT_COMPOUND_GRAVITY_STRENGTH = x.DEFAULT_COMPOUND_GRAVITY_STRENGTH = j.gravityCompound), j.gravityRangeCompound != null && (I.DEFAULT_COMPOUND_GRAVITY_RANGE_FACTOR = x.DEFAULT_COMPOUND_GRAVITY_RANGE_FACTOR = j.gravityRangeCompound), j.initialEnergyOnIncremental != null && (I.DEFAULT_COOLING_FACTOR_INCREMENTAL = x.DEFAULT_COOLING_FACTOR_INCREMENTAL = j.initialEnergyOnIncremental), j.quality == "draft" ? T.QUALITY = 0 : j.quality == "proof" ? T.QUALITY = 2 : T.QUALITY = 1, I.NODE_DIMENSIONS_INCLUDE_LABELS = x.NODE_DIMENSIONS_INCLUDE_LABELS = T.NODE_DIMENSIONS_INCLUDE_LABELS = j.nodeDimensionsIncludeLabels, I.DEFAULT_INCREMENTAL = x.DEFAULT_INCREMENTAL = T.DEFAULT_INCREMENTAL = !j.randomize, I.ANIMATE = x.ANIMATE = T.ANIMATE = j.animate, I.TILE = j.tile, I.TILING_PADDING_VERTICAL = typeof j.tilingPaddingVertical == "function" ? j.tilingPaddingVertical.call() : j.tilingPaddingVertical, I.TILING_PADDING_HORIZONTAL = typeof j.tilingPaddingHorizontal == "function" ? j.tilingPaddingHorizontal.call() : j.tilingPaddingHorizontal; + }; + U.prototype.run = function() { + var le, j, ee = this.options; + this.idToLNode = {}; + var H = this.layout = new z(), te = this; + te.stopped = !1, this.cy = this.options.cy, this.cy.trigger({ type: "layoutstart", layout: this }); + var S = H.newGraphManager(); + this.gm = S; + var V = this.options.eles.nodes(), R = this.options.eles.edges(); + this.root = S.addRoot(), this.processChildrenList(this.root, this.getTopMostNodes(V), H); + for (var q = 0; q < R.length; q++) { + var ve = R[q], pe = this.idToLNode[ve.data("source")], Ae = this.idToLNode[ve.data("target")]; + if (pe !== Ae && pe.getEdgesBetween(Ae).length == 0) { + var Ne = S.add(H.newEdge(), pe, Ae); + Ne.id = ve.id(); + } + } + var Ye = function(Re, Ve) { + typeof Re == "number" && (Re = Ve); + var Ze = Re.data("id"), nt = te.idToLNode[Ze]; + return { + x: nt.getRect().getCenterX(), + y: nt.getRect().getCenterY() + }; + }, at = function dt() { + for (var Re = function() { + ee.fit && ee.cy.fit(ee.eles, ee.padding), le || (le = !0, te.cy.one("layoutready", ee.ready), te.cy.trigger({ type: "layoutready", layout: te })); + }, Ve = te.options.refresh, Ze, nt = 0; nt < Ve && !Ze; nt++) + Ze = te.stopped || te.layout.tick(); + if (Ze) { + H.checkLayoutSuccess() && !H.isSubLayout && H.doPostLayout(), H.tilingPostLayout && H.tilingPostLayout(), H.isLayoutFinished = !0, te.options.eles.nodes().positions(Ye), Re(), te.cy.one("layoutstop", te.options.stop), te.cy.trigger({ type: "layoutstop", layout: te }), j && cancelAnimationFrame(j), le = !1; + return; + } + var ht = te.layout.getPositionsData(); + ee.eles.nodes().positions(function(it, tt) { + if (typeof it == "number" && (it = tt), !it.isParent()) { + for (var yt = it.id(), Et = ht[yt], Pt = it; Et == null && (Et = ht[Pt.data("parent")] || ht["DummyCompound_" + Pt.data("parent")], ht[yt] = Et, Pt = Pt.parent()[0], Pt != null); ) + ; + return Et != null ? { + x: Et.x, + y: Et.y + } : { + x: it.position("x"), + y: it.position("y") + }; + } + }), Re(), j = requestAnimationFrame(dt); + }; + return H.addListener("layoutstarted", function() { + te.options.animate === "during" && (j = requestAnimationFrame(at)); + }), H.runLayout(), this.options.animate !== "during" && (te.options.eles.nodes().not(":parent").layoutPositions(te, te.options, Ye), le = !1), this; + }, U.prototype.getTopMostNodes = function(le) { + for (var j = {}, ee = 0; ee < le.length; ee++) + j[le[ee].id()] = !0; + var H = le.filter(function(te, S) { + typeof te == "number" && (te = S); + for (var V = te.parent()[0]; V != null; ) { + if (j[V.id()]) + return !1; + V = V.parent()[0]; + } + return !0; + }); + return H; + }, U.prototype.processChildrenList = function(le, j, ee) { + for (var H = j.length, te = 0; te < H; te++) { + var S = j[te], V = S.children(), R, q = S.layoutDimensions({ + nodeDimensionsIncludeLabels: this.options.nodeDimensionsIncludeLabels + }); + if (S.outerWidth() != null && S.outerHeight() != null ? R = le.add(new Y(ee.graphManager, new P(S.position("x") - q.w / 2, S.position("y") - q.h / 2), new Z(parseFloat(q.w), parseFloat(q.h)))) : R = le.add(new Y(this.graphManager)), R.id = S.data("id"), R.paddingLeft = parseInt(S.css("padding")), R.paddingTop = parseInt(S.css("padding")), R.paddingRight = parseInt(S.css("padding")), R.paddingBottom = parseInt(S.css("padding")), this.options.nodeDimensionsIncludeLabels && S.isParent()) { + var ve = S.boundingBox({ includeLabels: !0, includeNodes: !1 }).w, pe = S.boundingBox({ includeLabels: !0, includeNodes: !1 }).h, Ae = S.css("text-halign"); + R.labelWidth = ve, R.labelHeight = pe, R.labelPos = Ae; + } + if (this.idToLNode[S.data("id")] = R, isNaN(R.rect.x) && (R.rect.x = 0), isNaN(R.rect.y) && (R.rect.y = 0), V != null && V.length > 0) { + var Ne; + Ne = ee.getGraphManager().add(ee.newGraph(), R), this.processChildrenList(Ne, V, ee); + } + } + }, U.prototype.stop = function() { + return this.stopped = !0, this; + }; + var ne = function(j) { + j("layout", "cose-bilkent", U); + }; + typeof cytoscape < "u" && ne(cytoscape), fe.exports = ne; + } + /******/ + ]) + ); + }); +})(Xl); +var Vp = Xl.exports; +const Up = /* @__PURE__ */ $l(Vp), $p = 12, _p = function(de, Pe, _, fe) { + Pe.append("path").attr("id", "node-" + _.id).attr("class", "node-bkg node-" + de.type2Str(_.type)).attr( + "d", + `M0 ${_.height - 5} v${-_.height + 2 * 5} q0,-5 5,-5 h${_.width - 2 * 5} q5,0 5,5 v${_.height - 5} H0 Z` + ), Pe.append("line").attr("class", "node-line-" + fe).attr("x1", 0).attr("y1", _.height).attr("x2", _.width).attr("y2", _.height); +}, Yp = function(de, Pe, _) { + Pe.append("rect").attr("id", "node-" + _.id).attr("class", "node-bkg node-" + de.type2Str(_.type)).attr("height", _.height).attr("width", _.width); +}, Hp = function(de, Pe, _) { + const fe = _.width, Q = _.height, C = 0.15 * fe, T = 0.25 * fe, x = 0.35 * fe, I = 0.2 * fe; + Pe.append("path").attr("id", "node-" + _.id).attr("class", "node-bkg node-" + de.type2Str(_.type)).attr( + "d", + `M0 0 a${C},${C} 0 0,1 ${fe * 0.25},${-1 * fe * 0.1} + a${x},${x} 1 0,1 ${fe * 0.4},${-1 * fe * 0.1} + a${T},${T} 1 0,1 ${fe * 0.35},${1 * fe * 0.2} + + a${C},${C} 1 0,1 ${fe * 0.15},${1 * Q * 0.35} + a${I},${I} 1 0,1 ${-1 * fe * 0.15},${1 * Q * 0.65} + + a${T},${C} 1 0,1 ${-1 * fe * 0.25},${fe * 0.15} + a${x},${x} 1 0,1 ${-1 * fe * 0.5},0 + a${C},${C} 1 0,1 ${-1 * fe * 0.25},${-1 * fe * 0.15} + + a${C},${C} 1 0,1 ${-1 * fe * 0.1},${-1 * Q * 0.35} + a${I},${I} 1 0,1 ${fe * 0.1},${-1 * Q * 0.65} + + H0 V0 Z` + ); +}, Xp = function(de, Pe, _) { + const fe = _.width, Q = _.height, C = 0.15 * fe; + Pe.append("path").attr("id", "node-" + _.id).attr("class", "node-bkg node-" + de.type2Str(_.type)).attr( + "d", + `M0 0 a${C},${C} 1 0,0 ${fe * 0.25},${-1 * Q * 0.1} + a${C},${C} 1 0,0 ${fe * 0.25},0 + a${C},${C} 1 0,0 ${fe * 0.25},0 + a${C},${C} 1 0,0 ${fe * 0.25},${1 * Q * 0.1} + + a${C},${C} 1 0,0 ${fe * 0.15},${1 * Q * 0.33} + a${C * 0.8},${C * 0.8} 1 0,0 0,${1 * Q * 0.34} + a${C},${C} 1 0,0 ${-1 * fe * 0.15},${1 * Q * 0.33} + + a${C},${C} 1 0,0 ${-1 * fe * 0.25},${Q * 0.15} + a${C},${C} 1 0,0 ${-1 * fe * 0.25},0 + a${C},${C} 1 0,0 ${-1 * fe * 0.25},0 + a${C},${C} 1 0,0 ${-1 * fe * 0.25},${-1 * Q * 0.15} + + a${C},${C} 1 0,0 ${-1 * fe * 0.1},${-1 * Q * 0.33} + a${C * 0.8},${C * 0.8} 1 0,0 0,${-1 * Q * 0.34} + a${C},${C} 1 0,0 ${fe * 0.1},${-1 * Q * 0.33} + + H0 V0 Z` + ); +}, Wp = function(de, Pe, _) { + Pe.append("circle").attr("id", "node-" + _.id).attr("class", "node-bkg node-" + de.type2Str(_.type)).attr("r", _.width / 2); +}; +function qp(de, Pe, _, fe, Q) { + return de.insert("polygon", ":first-child").attr( + "points", + fe.map(function(C) { + return C.x + "," + C.y; + }).join(" ") + ).attr("transform", "translate(" + (Q.width - Pe) / 2 + ", " + _ + ")"); +} +const Kp = function(de, Pe, _) { + const fe = _.height, C = fe / 4, T = _.width - _.padding + 2 * C, x = [ + { x: C, y: 0 }, + { x: T - C, y: 0 }, + { x: T, y: -fe / 2 }, + { x: T - C, y: -fe }, + { x: C, y: -fe }, + { x: 0, y: -fe / 2 } + ]; + qp(Pe, T, fe, x, _); +}, Zp = function(de, Pe, _) { + Pe.append("rect").attr("id", "node-" + _.id).attr("class", "node-bkg node-" + de.type2Str(_.type)).attr("height", _.height).attr("rx", _.padding).attr("ry", _.padding).attr("width", _.width); +}, Qp = function(de, Pe, _, fe, Q) { + const C = Q.htmlLabels, T = fe % ($p - 1), x = Pe.append("g"); + _.section = T; + let I = "section-" + T; + T < 0 && (I += " section-root"), x.attr("class", (_.class ? _.class + " " : "") + "mindmap-node " + I); + const z = x.append("g"), Y = x.append("g"), P = _.descr.replace(/()/g, ` +`); + Tp(Y, P, { + useHtmlLabels: C, + width: _.width, + classes: "mindmap-node-label" + }), C || Y.attr("dy", "1em").attr("alignment-baseline", "middle").attr("dominant-baseline", "middle").attr("text-anchor", "middle"); + const Z = Y.node().getBBox(), [A] = pp(Q.fontSize); + if (_.height = Z.height + A * 1.1 * 0.5 + _.padding, _.width = Z.width + 2 * _.padding, _.icon) + if (_.type === de.nodeType.CIRCLE) + _.height += 50, _.width += 50, x.append("foreignObject").attr("height", "50px").attr("width", _.width).attr("style", "text-align: center;").append("div").attr("class", "icon-container").append("i").attr("class", "node-icon-" + T + " " + _.icon), Y.attr( + "transform", + "translate(" + _.width / 2 + ", " + (_.height / 2 - 1.5 * _.padding) + ")" + ); + else { + _.width += 50; + const $ = _.height; + _.height = Math.max($, 60); + const U = Math.abs(_.height - $); + x.append("foreignObject").attr("width", "60px").attr("height", _.height).attr("style", "text-align: center;margin-top:" + U / 2 + "px;").append("div").attr("class", "icon-container").append("i").attr("class", "node-icon-" + T + " " + _.icon), Y.attr( + "transform", + "translate(" + (25 + _.width / 2) + ", " + (U / 2 + _.padding / 2) + ")" + ); + } + else if (C) { + const $ = (_.width - Z.width) / 2, U = (_.height - Z.height) / 2; + Y.attr("transform", "translate(" + $ + ", " + U + ")"); + } else { + const $ = _.width / 2, U = _.padding / 2; + Y.attr("transform", "translate(" + $ + ", " + U + ")"); + } + switch (_.type) { + case de.nodeType.DEFAULT: + _p(de, z, _, T); + break; + case de.nodeType.ROUNDED_RECT: + Zp(de, z, _); + break; + case de.nodeType.RECT: + Yp(de, z, _); + break; + case de.nodeType.CIRCLE: + z.attr("transform", "translate(" + _.width / 2 + ", " + +_.height / 2 + ")"), Wp(de, z, _); + break; + case de.nodeType.CLOUD: + Hp(de, z, _); + break; + case de.nodeType.BANG: + Xp(de, z, _); + break; + case de.nodeType.HEXAGON: + Kp(de, z, _); + break; + } + return de.setElementForId(_.id, x), _.height; +}, Jp = function(de, Pe) { + const _ = de.getElementById(Pe.id), fe = Pe.x || 0, Q = Pe.y || 0; + _.attr("transform", "translate(" + fe + "," + Q + ")"); +}; +Hl.use(Up); +function Wl(de, Pe, _, fe, Q) { + Qp(de, Pe, _, fe, Q), _.children && _.children.forEach((C, T) => { + Wl(de, Pe, C, fe < 0 ? T : fe, Q); + }); +} +function jp(de, Pe) { + Pe.edges().map((_, fe) => { + const Q = _.data(); + if (_[0]._private.bodyBounds) { + const C = _[0]._private.rscratch; + qr.trace("Edge: ", fe, Q), de.insert("path").attr( + "d", + `M ${C.startX},${C.startY} L ${C.midX},${C.midY} L${C.endX},${C.endY} ` + ).attr("class", "edge section-edge-" + Q.section + " edge-depth-" + Q.depth); + } + }); +} +function ql(de, Pe, _, fe) { + Pe.add({ + group: "nodes", + data: { + id: de.id.toString(), + labelText: de.descr, + height: de.height, + width: de.width, + level: fe, + nodeId: de.id, + padding: de.padding, + type: de.type + }, + position: { + x: de.x, + y: de.y + } + }), de.children && de.children.forEach((Q) => { + ql(Q, Pe, _, fe + 1), Pe.add({ + group: "edges", + data: { + id: `${de.id}_${Q.id}`, + source: de.id, + target: Q.id, + depth: fe, + section: Q.section + } + }); + }); +} +function ey(de, Pe) { + return new Promise((_) => { + const fe = bp("body").append("div").attr("id", "cy").attr("style", "display:none"), Q = Hl({ + container: document.getElementById("cy"), + // container to render in + style: [ + { + selector: "edge", + style: { + "curve-style": "bezier" + } + } + ] + }); + fe.remove(), ql(de, Q, Pe, 0), Q.nodes().forEach(function(C) { + C.layoutDimensions = () => { + const T = C.data(); + return { w: T.width, h: T.height }; + }; + }), Q.layout({ + name: "cose-bilkent", + // @ts-ignore Types for cose-bilkent are not correct? + quality: "proof", + styleEnabled: !1, + animate: !1 + }).run(), Q.ready((C) => { + qr.info("Ready", C), _(Q); + }); + }); +} +function ty(de, Pe) { + Pe.nodes().map((_, fe) => { + const Q = _.data(); + Q.x = _.position().x, Q.y = _.position().y, Jp(de, Q); + const C = de.getElementById(Q.nodeId); + qr.info("Id:", fe, "Position: (", _.position().x, ", ", _.position().y, ")", Q), C.attr( + "transform", + `translate(${_.position().x - Q.width / 2}, ${_.position().y - Q.height / 2})` + ), C.attr("attr", `apa-${fe})`); + }); +} +const ry = async (de, Pe, _, fe) => { + var P, Z; + qr.debug(`Rendering mindmap diagram +` + de); + const Q = fe.db, C = Q.getMindmap(); + if (!C) + return; + const T = Ji(); + T.htmlLabels = !1; + const x = yp(Pe), I = x.append("g"); + I.attr("class", "mindmap-edges"); + const z = x.append("g"); + z.attr("class", "mindmap-nodes"), Wl(Q, z, C, -1, T); + const Y = await ey(C, T); + jp(I, Y), ty(Q, Y), mp( + void 0, + x, + ((P = T.mindmap) == null ? void 0 : P.padding) ?? ti.mindmap.padding, + ((Z = T.mindmap) == null ? void 0 : Z.useMaxWidth) ?? ti.mindmap.useMaxWidth + ); +}, ay = { + draw: ry +}, ny = (de) => { + let Pe = ""; + for (let _ = 0; _ < de.THEME_COLOR_LIMIT; _++) + de["lineColor" + _] = de["lineColor" + _] || de["cScaleInv" + _], Ep(de["lineColor" + _]) ? de["lineColor" + _] = wp(de["lineColor" + _], 20) : de["lineColor" + _] = xp(de["lineColor" + _], 20); + for (let _ = 0; _ < de.THEME_COLOR_LIMIT; _++) { + const fe = "" + (17 - 3 * _); + Pe += ` + .section-${_ - 1} rect, .section-${_ - 1} path, .section-${_ - 1} circle, .section-${_ - 1} polygon, .section-${_ - 1} path { + fill: ${de["cScale" + _]}; + } + .section-${_ - 1} text { + fill: ${de["cScaleLabel" + _]}; + } + .node-icon-${_ - 1} { + font-size: 40px; + color: ${de["cScaleLabel" + _]}; + } + .section-edge-${_ - 1}{ + stroke: ${de["cScale" + _]}; + } + .edge-depth-${_ - 1}{ + stroke-width: ${fe}; + } + .section-${_ - 1} line { + stroke: ${de["cScaleInv" + _]} ; + stroke-width: 3; + } + + .disabled, .disabled circle, .disabled text { + fill: lightgray; + } + .disabled text { + fill: #efefef; + } + `; + } + return Pe; +}, iy = (de) => ` + .edge { + stroke-width: 3; + } + ${ny(de)} + .section-root rect, .section-root path, .section-root circle, .section-root polygon { + fill: ${de.git0}; + } + .section-root text { + fill: ${de.gitBranchLabel0}; + } + .icon-container { + height:100%; + display: flex; + justify-content: center; + align-items: center; + } + .edge { + fill: none; + } + .mindmap-node-label { + dy: 1em; + alignment-baseline: middle; + text-anchor: middle; + dominant-baseline: middle; + text-align: center; + } +`, sy = iy, uy = { + db: Bp, + renderer: ay, + parser: Cp, + styles: sy +}; +export { + uy as diagram +}; diff --git a/0.6.0/js/mermaid/ordinal-475e0c0c.js b/0.6.0/js/mermaid/ordinal-475e0c0c.js new file mode 100644 index 0000000..65afcfd --- /dev/null +++ b/0.6.0/js/mermaid/ordinal-475e0c0c.js @@ -0,0 +1,82 @@ +import { i as initRange } from "./init-cc95ec8e.js"; +class InternMap extends Map { + constructor(entries, key = keyof) { + super(); + Object.defineProperties(this, { _intern: { value: /* @__PURE__ */ new Map() }, _key: { value: key } }); + if (entries != null) + for (const [key2, value] of entries) + this.set(key2, value); + } + get(key) { + return super.get(intern_get(this, key)); + } + has(key) { + return super.has(intern_get(this, key)); + } + set(key, value) { + return super.set(intern_set(this, key), value); + } + delete(key) { + return super.delete(intern_delete(this, key)); + } +} +function intern_get({ _intern, _key }, value) { + const key = _key(value); + return _intern.has(key) ? _intern.get(key) : value; +} +function intern_set({ _intern, _key }, value) { + const key = _key(value); + if (_intern.has(key)) + return _intern.get(key); + _intern.set(key, value); + return value; +} +function intern_delete({ _intern, _key }, value) { + const key = _key(value); + if (_intern.has(key)) { + value = _intern.get(key); + _intern.delete(key); + } + return value; +} +function keyof(value) { + return value !== null && typeof value === "object" ? value.valueOf() : value; +} +const implicit = Symbol("implicit"); +function ordinal() { + var index = new InternMap(), domain = [], range = [], unknown = implicit; + function scale(d) { + let i = index.get(d); + if (i === void 0) { + if (unknown !== implicit) + return unknown; + index.set(d, i = domain.push(d) - 1); + } + return range[i % range.length]; + } + scale.domain = function(_) { + if (!arguments.length) + return domain.slice(); + domain = [], index = new InternMap(); + for (const value of _) { + if (index.has(value)) + continue; + index.set(value, domain.push(value) - 1); + } + return scale; + }; + scale.range = function(_) { + return arguments.length ? (range = Array.from(_), scale) : range.slice(); + }; + scale.unknown = function(_) { + return arguments.length ? (unknown = _, scale) : unknown; + }; + scale.copy = function() { + return ordinal(domain, range).unknown(unknown); + }; + initRange.apply(scale, arguments); + return scale; +} +export { + ordinal as o +}; diff --git a/0.6.0/js/mermaid/ordinal-5695958c.js b/0.6.0/js/mermaid/ordinal-5695958c.js new file mode 100644 index 0000000..db7d157 --- /dev/null +++ b/0.6.0/js/mermaid/ordinal-5695958c.js @@ -0,0 +1,65 @@ +import { i as a } from "./init-f9637058.js"; +class o extends Map { + constructor(n, t = g) { + if (super(), Object.defineProperties(this, { _intern: { value: /* @__PURE__ */ new Map() }, _key: { value: t } }), n != null) + for (const [r, s] of n) + this.set(r, s); + } + get(n) { + return super.get(c(this, n)); + } + has(n) { + return super.has(c(this, n)); + } + set(n, t) { + return super.set(l(this, n), t); + } + delete(n) { + return super.delete(p(this, n)); + } +} +function c({ _intern: e, _key: n }, t) { + const r = n(t); + return e.has(r) ? e.get(r) : t; +} +function l({ _intern: e, _key: n }, t) { + const r = n(t); + return e.has(r) ? e.get(r) : (e.set(r, t), t); +} +function p({ _intern: e, _key: n }, t) { + const r = n(t); + return e.has(r) && (t = e.get(r), e.delete(r)), t; +} +function g(e) { + return e !== null && typeof e == "object" ? e.valueOf() : e; +} +const f = Symbol("implicit"); +function h() { + var e = new o(), n = [], t = [], r = f; + function s(u) { + let i = e.get(u); + if (i === void 0) { + if (r !== f) + return r; + e.set(u, i = n.push(u) - 1); + } + return t[i % t.length]; + } + return s.domain = function(u) { + if (!arguments.length) + return n.slice(); + n = [], e = new o(); + for (const i of u) + e.has(i) || e.set(i, n.push(i) - 1); + return s; + }, s.range = function(u) { + return arguments.length ? (t = Array.from(u), s) : t.slice(); + }, s.unknown = function(u) { + return arguments.length ? (r = u, s) : r; + }, s.copy = function() { + return h(n, t).unknown(r); + }, a.apply(s, arguments), s; +} +export { + h as o +}; diff --git a/0.6.0/js/mermaid/path-39bad7e2.js b/0.6.0/js/mermaid/path-39bad7e2.js new file mode 100644 index 0000000..16a7b94 --- /dev/null +++ b/0.6.0/js/mermaid/path-39bad7e2.js @@ -0,0 +1,118 @@ +const pi = Math.PI, tau = 2 * pi, epsilon = 1e-6, tauEpsilon = tau - epsilon; +function append(strings) { + this._ += strings[0]; + for (let i = 1, n = strings.length; i < n; ++i) { + this._ += arguments[i] + strings[i]; + } +} +function appendRound(digits) { + let d = Math.floor(digits); + if (!(d >= 0)) + throw new Error(`invalid digits: ${digits}`); + if (d > 15) + return append; + const k = 10 ** d; + return function(strings) { + this._ += strings[0]; + for (let i = 1, n = strings.length; i < n; ++i) { + this._ += Math.round(arguments[i] * k) / k + strings[i]; + } + }; +} +class Path { + constructor(digits) { + this._x0 = this._y0 = // start of current subpath + this._x1 = this._y1 = null; + this._ = ""; + this._append = digits == null ? append : appendRound(digits); + } + moveTo(x, y) { + this._append`M${this._x0 = this._x1 = +x},${this._y0 = this._y1 = +y}`; + } + closePath() { + if (this._x1 !== null) { + this._x1 = this._x0, this._y1 = this._y0; + this._append`Z`; + } + } + lineTo(x, y) { + this._append`L${this._x1 = +x},${this._y1 = +y}`; + } + quadraticCurveTo(x1, y1, x, y) { + this._append`Q${+x1},${+y1},${this._x1 = +x},${this._y1 = +y}`; + } + bezierCurveTo(x1, y1, x2, y2, x, y) { + this._append`C${+x1},${+y1},${+x2},${+y2},${this._x1 = +x},${this._y1 = +y}`; + } + arcTo(x1, y1, x2, y2, r) { + x1 = +x1, y1 = +y1, x2 = +x2, y2 = +y2, r = +r; + if (r < 0) + throw new Error(`negative radius: ${r}`); + let x0 = this._x1, y0 = this._y1, x21 = x2 - x1, y21 = y2 - y1, x01 = x0 - x1, y01 = y0 - y1, l01_2 = x01 * x01 + y01 * y01; + if (this._x1 === null) { + this._append`M${this._x1 = x1},${this._y1 = y1}`; + } else if (!(l01_2 > epsilon)) + ; + else if (!(Math.abs(y01 * x21 - y21 * x01) > epsilon) || !r) { + this._append`L${this._x1 = x1},${this._y1 = y1}`; + } else { + let x20 = x2 - x0, y20 = y2 - y0, l21_2 = x21 * x21 + y21 * y21, l20_2 = x20 * x20 + y20 * y20, l21 = Math.sqrt(l21_2), l01 = Math.sqrt(l01_2), l = r * Math.tan((pi - Math.acos((l21_2 + l01_2 - l20_2) / (2 * l21 * l01))) / 2), t01 = l / l01, t21 = l / l21; + if (Math.abs(t01 - 1) > epsilon) { + this._append`L${x1 + t01 * x01},${y1 + t01 * y01}`; + } + this._append`A${r},${r},0,0,${+(y01 * x20 > x01 * y20)},${this._x1 = x1 + t21 * x21},${this._y1 = y1 + t21 * y21}`; + } + } + arc(x, y, r, a0, a1, ccw) { + x = +x, y = +y, r = +r, ccw = !!ccw; + if (r < 0) + throw new Error(`negative radius: ${r}`); + let dx = r * Math.cos(a0), dy = r * Math.sin(a0), x0 = x + dx, y0 = y + dy, cw = 1 ^ ccw, da = ccw ? a0 - a1 : a1 - a0; + if (this._x1 === null) { + this._append`M${x0},${y0}`; + } else if (Math.abs(this._x1 - x0) > epsilon || Math.abs(this._y1 - y0) > epsilon) { + this._append`L${x0},${y0}`; + } + if (!r) + return; + if (da < 0) + da = da % tau + tau; + if (da > tauEpsilon) { + this._append`A${r},${r},0,1,${cw},${x - dx},${y - dy}A${r},${r},0,1,${cw},${this._x1 = x0},${this._y1 = y0}`; + } else if (da > epsilon) { + this._append`A${r},${r},0,${+(da >= pi)},${cw},${this._x1 = x + r * Math.cos(a1)},${this._y1 = y + r * Math.sin(a1)}`; + } + } + rect(x, y, w, h) { + this._append`M${this._x0 = this._x1 = +x},${this._y0 = this._y1 = +y}h${w = +w}v${+h}h${-w}Z`; + } + toString() { + return this._; + } +} +function constant(x) { + return function constant2() { + return x; + }; +} +function withPath(shape) { + let digits = 3; + shape.digits = function(_) { + if (!arguments.length) + return digits; + if (_ == null) { + digits = null; + } else { + const d = Math.floor(_); + if (!(d >= 0)) + throw new RangeError(`invalid digits: ${_}`); + digits = d; + } + return shape; + }; + return () => new Path(digits); +} +export { + constant as c, + withPath as w +}; diff --git a/0.6.0/js/mermaid/path-428ebac9.js b/0.6.0/js/mermaid/path-428ebac9.js new file mode 100644 index 0000000..3f6ad85 --- /dev/null +++ b/0.6.0/js/mermaid/path-428ebac9.js @@ -0,0 +1,91 @@ +const c = Math.PI, x = 2 * c, u = 1e-6, m = x - u; +function E(e) { + this._ += e[0]; + for (let t = 1, h = e.length; t < h; ++t) + this._ += arguments[t] + e[t]; +} +function A(e) { + let t = Math.floor(e); + if (!(t >= 0)) + throw new Error(`invalid digits: ${e}`); + if (t > 15) + return E; + const h = 10 ** t; + return function(i) { + this._ += i[0]; + for (let s = 1, n = i.length; s < n; ++s) + this._ += Math.round(arguments[s] * h) / h + i[s]; + }; +} +class L { + constructor(t) { + this._x0 = this._y0 = // start of current subpath + this._x1 = this._y1 = null, this._ = "", this._append = t == null ? E : A(t); + } + moveTo(t, h) { + this._append`M${this._x0 = this._x1 = +t},${this._y0 = this._y1 = +h}`; + } + closePath() { + this._x1 !== null && (this._x1 = this._x0, this._y1 = this._y0, this._append`Z`); + } + lineTo(t, h) { + this._append`L${this._x1 = +t},${this._y1 = +h}`; + } + quadraticCurveTo(t, h, i, s) { + this._append`Q${+t},${+h},${this._x1 = +i},${this._y1 = +s}`; + } + bezierCurveTo(t, h, i, s, n, $) { + this._append`C${+t},${+h},${+i},${+s},${this._x1 = +n},${this._y1 = +$}`; + } + arcTo(t, h, i, s, n) { + if (t = +t, h = +h, i = +i, s = +s, n = +n, n < 0) + throw new Error(`negative radius: ${n}`); + let $ = this._x1, r = this._y1, p = i - t, l = s - h, _ = $ - t, o = r - h, a = _ * _ + o * o; + if (this._x1 === null) + this._append`M${this._x1 = t},${this._y1 = h}`; + else if (a > u) + if (!(Math.abs(o * p - l * _) > u) || !n) + this._append`L${this._x1 = t},${this._y1 = h}`; + else { + let d = i - $, f = s - r, y = p * p + l * l, T = d * d + f * f, g = Math.sqrt(y), v = Math.sqrt(a), w = n * Math.tan((c - Math.acos((y + a - T) / (2 * g * v))) / 2), M = w / v, b = w / g; + Math.abs(M - 1) > u && this._append`L${t + M * _},${h + M * o}`, this._append`A${n},${n},0,0,${+(o * d > _ * f)},${this._x1 = t + b * p},${this._y1 = h + b * l}`; + } + } + arc(t, h, i, s, n, $) { + if (t = +t, h = +h, i = +i, $ = !!$, i < 0) + throw new Error(`negative radius: ${i}`); + let r = i * Math.cos(s), p = i * Math.sin(s), l = t + r, _ = h + p, o = 1 ^ $, a = $ ? s - n : n - s; + this._x1 === null ? this._append`M${l},${_}` : (Math.abs(this._x1 - l) > u || Math.abs(this._y1 - _) > u) && this._append`L${l},${_}`, i && (a < 0 && (a = a % x + x), a > m ? this._append`A${i},${i},0,1,${o},${t - r},${h - p}A${i},${i},0,1,${o},${this._x1 = l},${this._y1 = _}` : a > u && this._append`A${i},${i},0,${+(a >= c)},${o},${this._x1 = t + i * Math.cos(n)},${this._y1 = h + i * Math.sin(n)}`); + } + rect(t, h, i, s) { + this._append`M${this._x0 = this._x1 = +t},${this._y0 = this._y1 = +h}h${i = +i}v${+s}h${-i}Z`; + } + toString() { + return this._; + } +} +function P(e) { + return function() { + return e; + }; +} +function q(e) { + let t = 3; + return e.digits = function(h) { + if (!arguments.length) + return t; + if (h == null) + t = null; + else { + const i = Math.floor(h); + if (!(i >= 0)) + throw new RangeError(`invalid digits: ${h}`); + t = i; + } + return e; + }, () => new L(t); +} +export { + P as c, + q as w +}; diff --git a/0.6.0/js/mermaid/pieDiagram-828dae43.js b/0.6.0/js/mermaid/pieDiagram-828dae43.js new file mode 100644 index 0000000..6be14d9 --- /dev/null +++ b/0.6.0/js/mermaid/pieDiagram-828dae43.js @@ -0,0 +1,502 @@ +import { V as H, W as at, C as lt, D as ct, s as ot, g as ht, b as ut, a as yt, E as ft, d as pt, c as et, l as it, X as gt, U as dt, Y as mt, k as _t } from "./mermaid-9f2aa176.js"; +import { d as tt } from "./arc-d1f6357e.js"; +import { o as xt } from "./ordinal-5695958c.js"; +import { a as kt } from "./array-2ff2c7a6.js"; +import { c as F } from "./path-428ebac9.js"; +import "./init-f9637058.js"; +function vt(e, u) { + return u < e ? -1 : u > e ? 1 : u >= e ? 0 : NaN; +} +function bt(e) { + return e; +} +function St() { + var e = bt, u = vt, E = null, p = F(0), g = F(H), A = F(0); + function y(a) { + var l, d = (a = kt(a)).length, m, I, $ = 0, _ = new Array(d), v = new Array(d), o = +p.apply(this, arguments), T = Math.min(H, Math.max(-H, g.apply(this, arguments) - o)), O, w = Math.min(Math.abs(T) / d, A.apply(this, arguments)), b = w * (T < 0 ? -1 : 1), t; + for (l = 0; l < d; ++l) + (t = v[_[l] = l] = +e(a[l], l, a)) > 0 && ($ += t); + for (u != null ? _.sort(function(i, n) { + return u(v[i], v[n]); + }) : E != null && _.sort(function(i, n) { + return E(a[i], a[n]); + }), l = 0, I = $ ? (T - d * b) / $ : 0; l < d; ++l, o = O) + m = _[l], t = v[m], O = o + (t > 0 ? t * I : 0) + b, v[m] = { + data: a[m], + index: l, + value: t, + startAngle: o, + endAngle: O, + padAngle: w + }; + return v; + } + return y.value = function(a) { + return arguments.length ? (e = typeof a == "function" ? a : F(+a), y) : e; + }, y.sortValues = function(a) { + return arguments.length ? (u = a, E = null, y) : u; + }, y.sort = function(a) { + return arguments.length ? (E = a, u = null, y) : E; + }, y.startAngle = function(a) { + return arguments.length ? (p = typeof a == "function" ? a : F(+a), y) : p; + }, y.endAngle = function(a) { + return arguments.length ? (g = typeof a == "function" ? a : F(+a), y) : g; + }, y.padAngle = function(a) { + return arguments.length ? (A = typeof a == "function" ? a : F(+a), y) : A; + }, y; +} +var J = function() { + var e = function(b, t, i, n) { + for (i = i || {}, n = b.length; n--; i[b[n]] = t) + ; + return i; + }, u = [1, 3], E = [1, 4], p = [1, 5], g = [1, 6], A = [1, 10, 12, 14, 16, 18, 19, 20, 21, 22], y = [2, 4], a = [1, 5, 10, 12, 14, 16, 18, 19, 20, 21, 22], l = [20, 21, 22], d = [2, 7], m = [1, 12], I = [1, 13], $ = [1, 14], _ = [1, 15], v = [1, 16], o = [1, 17], T = { + trace: function() { + }, + yy: {}, + symbols_: { error: 2, start: 3, eol: 4, PIE: 5, document: 6, showData: 7, line: 8, statement: 9, txt: 10, value: 11, title: 12, title_value: 13, acc_title: 14, acc_title_value: 15, acc_descr: 16, acc_descr_value: 17, acc_descr_multiline_value: 18, section: 19, NEWLINE: 20, ";": 21, EOF: 22, $accept: 0, $end: 1 }, + terminals_: { 2: "error", 5: "PIE", 7: "showData", 10: "txt", 11: "value", 12: "title", 13: "title_value", 14: "acc_title", 15: "acc_title_value", 16: "acc_descr", 17: "acc_descr_value", 18: "acc_descr_multiline_value", 19: "section", 20: "NEWLINE", 21: ";", 22: "EOF" }, + productions_: [0, [3, 2], [3, 2], [3, 3], [6, 0], [6, 2], [8, 2], [9, 0], [9, 2], [9, 2], [9, 2], [9, 2], [9, 1], [9, 1], [4, 1], [4, 1], [4, 1]], + performAction: function(t, i, n, r, c, s, V) { + var x = s.length - 1; + switch (c) { + case 3: + r.setShowData(!0); + break; + case 6: + this.$ = s[x - 1]; + break; + case 8: + r.addSection(s[x - 1], r.cleanupValue(s[x])); + break; + case 9: + this.$ = s[x].trim(), r.setDiagramTitle(this.$); + break; + case 10: + this.$ = s[x].trim(), r.setAccTitle(this.$); + break; + case 11: + case 12: + this.$ = s[x].trim(), r.setAccDescription(this.$); + break; + case 13: + r.addSection(s[x].substr(8)), this.$ = s[x].substr(8); + break; + } + }, + table: [{ 3: 1, 4: 2, 5: u, 20: E, 21: p, 22: g }, { 1: [3] }, { 3: 7, 4: 2, 5: u, 20: E, 21: p, 22: g }, e(A, y, { 6: 8, 7: [1, 9] }), e(a, [2, 14]), e(a, [2, 15]), e(a, [2, 16]), { 1: [2, 1] }, e(l, d, { 8: 10, 9: 11, 1: [2, 2], 10: m, 12: I, 14: $, 16: _, 18: v, 19: o }), e(A, y, { 6: 18 }), e(A, [2, 5]), { 4: 19, 20: E, 21: p, 22: g }, { 11: [1, 20] }, { 13: [1, 21] }, { 15: [1, 22] }, { 17: [1, 23] }, e(l, [2, 12]), e(l, [2, 13]), e(l, d, { 8: 10, 9: 11, 1: [2, 3], 10: m, 12: I, 14: $, 16: _, 18: v, 19: o }), e(A, [2, 6]), e(l, [2, 8]), e(l, [2, 9]), e(l, [2, 10]), e(l, [2, 11])], + defaultActions: { 7: [2, 1] }, + parseError: function(t, i) { + if (i.recoverable) + this.trace(t); + else { + var n = new Error(t); + throw n.hash = i, n; + } + }, + parse: function(t) { + var i = this, n = [0], r = [], c = [null], s = [], V = this.table, x = "", f = 0, P = 0, R = 2, M = 1, Y = s.slice.call(arguments, 1), h = Object.create(this.lexer), N = { yy: {} }; + for (var B in this.yy) + Object.prototype.hasOwnProperty.call(this.yy, B) && (N.yy[B] = this.yy[B]); + h.setInput(t, N.yy), N.yy.lexer = h, N.yy.parser = this, typeof h.yylloc > "u" && (h.yylloc = {}); + var X = h.yylloc; + s.push(X); + var st = h.options && h.options.ranges; + typeof N.yy.parseError == "function" ? this.parseError = N.yy.parseError : this.parseError = Object.getPrototypeOf(this).parseError; + function rt() { + var C; + return C = r.pop() || h.lex() || M, typeof C != "number" && (C instanceof Array && (r = C, C = r.pop()), C = i.symbols_[C] || C), C; + } + for (var k, L, S, Z, z = {}, W, D, Q, j; ; ) { + if (L = n[n.length - 1], this.defaultActions[L] ? S = this.defaultActions[L] : ((k === null || typeof k > "u") && (k = rt()), S = V[L] && V[L][k]), typeof S > "u" || !S.length || !S[0]) { + var q = ""; + j = []; + for (W in V[L]) + this.terminals_[W] && W > R && j.push("'" + this.terminals_[W] + "'"); + h.showPosition ? q = "Parse error on line " + (f + 1) + `: +` + h.showPosition() + ` +Expecting ` + j.join(", ") + ", got '" + (this.terminals_[k] || k) + "'" : q = "Parse error on line " + (f + 1) + ": Unexpected " + (k == M ? "end of input" : "'" + (this.terminals_[k] || k) + "'"), this.parseError(q, { + text: h.match, + token: this.terminals_[k] || k, + line: h.yylineno, + loc: X, + expected: j + }); + } + if (S[0] instanceof Array && S.length > 1) + throw new Error("Parse Error: multiple actions possible at state: " + L + ", token: " + k); + switch (S[0]) { + case 1: + n.push(k), c.push(h.yytext), s.push(h.yylloc), n.push(S[1]), k = null, P = h.yyleng, x = h.yytext, f = h.yylineno, X = h.yylloc; + break; + case 2: + if (D = this.productions_[S[1]][1], z.$ = c[c.length - D], z._$ = { + first_line: s[s.length - (D || 1)].first_line, + last_line: s[s.length - 1].last_line, + first_column: s[s.length - (D || 1)].first_column, + last_column: s[s.length - 1].last_column + }, st && (z._$.range = [ + s[s.length - (D || 1)].range[0], + s[s.length - 1].range[1] + ]), Z = this.performAction.apply(z, [ + x, + P, + f, + N.yy, + S[1], + c, + s + ].concat(Y)), typeof Z < "u") + return Z; + D && (n = n.slice(0, -1 * D * 2), c = c.slice(0, -1 * D), s = s.slice(0, -1 * D)), n.push(this.productions_[S[1]][0]), c.push(z.$), s.push(z._$), Q = V[n[n.length - 2]][n[n.length - 1]], n.push(Q); + break; + case 3: + return !0; + } + } + return !0; + } + }, O = function() { + var b = { + EOF: 1, + parseError: function(i, n) { + if (this.yy.parser) + this.yy.parser.parseError(i, n); + else + throw new Error(i); + }, + // resets the lexer, sets new input + setInput: function(t, i) { + return this.yy = i || this.yy || {}, this._input = t, 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 t = this._input[0]; + this.yytext += t, this.yyleng++, this.offset++, this.match += t, this.matched += t; + var i = t.match(/(?:\r\n?|\n).*/g); + return i ? (this.yylineno++, this.yylloc.last_line++) : this.yylloc.last_column++, this.options.ranges && this.yylloc.range[1]++, this._input = this._input.slice(1), t; + }, + // unshifts one char (or a string) into the input + unput: function(t) { + var i = t.length, n = t.split(/(?:\r\n?|\n)/g); + this._input = t + this._input, this.yytext = this.yytext.substr(0, this.yytext.length - i), this.offset -= i; + var r = 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), n.length - 1 && (this.yylineno -= n.length - 1); + var c = 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: n ? (n.length === r.length ? this.yylloc.first_column : 0) + r[r.length - n.length].length - n[0].length : this.yylloc.first_column - i + }, this.options.ranges && (this.yylloc.range = [c[0], c[0] + this.yyleng - i]), 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(t) { + this.unput(this.match.slice(t)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var t = this.matched.substr(0, this.matched.length - this.match.length); + return (t.length > 20 ? "..." : "") + t.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var t = this.match; + return t.length < 20 && (t += this._input.substr(0, 20 - t.length)), (t.substr(0, 20) + (t.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var t = this.pastInput(), i = new Array(t.length + 1).join("-"); + return t + this.upcomingInput() + ` +` + i + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(t, i) { + var n, r, c; + if (this.options.backtrack_lexer && (c = { + 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 && (c.yylloc.range = this.yylloc.range.slice(0))), r = t[0].match(/(?:\r\n?|\n).*/g), r && (this.yylineno += r.length), this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: r ? r[r.length - 1].length - r[r.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + t[0].length + }, this.yytext += t[0], this.match += t[0], this.matches = t, 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(t[0].length), this.matched += t[0], n = this.performAction.call(this, this.yy, this, i, this.conditionStack[this.conditionStack.length - 1]), this.done && this._input && (this.done = !1), n) + return n; + if (this._backtrack) { + for (var s in c) + this[s] = c[s]; + return !1; + } + return !1; + }, + // return next match in input + next: function() { + if (this.done) + return this.EOF; + this._input || (this.done = !0); + var t, i, n, r; + this._more || (this.yytext = "", this.match = ""); + for (var c = this._currentRules(), s = 0; s < c.length; s++) + if (n = this._input.match(this.rules[c[s]]), n && (!i || n[0].length > i[0].length)) { + if (i = n, r = s, this.options.backtrack_lexer) { + if (t = this.test_match(n, c[s]), t !== !1) + return t; + if (this._backtrack) { + i = !1; + continue; + } else + return !1; + } else if (!this.options.flex) + break; + } + return i ? (t = this.test_match(i, c[r]), t !== !1 ? t : !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 i = this.next(); + return i || this.lex(); + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function(i) { + this.conditionStack.push(i); + }, + // pop the previously active lexer condition state off the condition stack + popState: function() { + var i = this.conditionStack.length - 1; + return i > 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(i) { + return i = this.conditionStack.length - 1 - Math.abs(i || 0), i >= 0 ? this.conditionStack[i] : "INITIAL"; + }, + // alias for begin(condition) + pushState: function(i) { + this.begin(i); + }, + // return the number of states currently on the stack + stateStackSize: function() { + return this.conditionStack.length; + }, + options: { "case-insensitive": !0 }, + performAction: function(i, n, r, c) { + switch (r) { + case 0: + break; + case 1: + break; + case 2: + return 20; + case 3: + break; + case 4: + break; + case 5: + return this.begin("title"), 12; + case 6: + return this.popState(), "title_value"; + case 7: + return this.begin("acc_title"), 14; + case 8: + return this.popState(), "acc_title_value"; + case 9: + return this.begin("acc_descr"), 16; + case 10: + return this.popState(), "acc_descr_value"; + case 11: + this.begin("acc_descr_multiline"); + break; + case 12: + this.popState(); + break; + case 13: + return "acc_descr_multiline_value"; + case 14: + this.begin("string"); + break; + case 15: + this.popState(); + break; + case 16: + return "txt"; + case 17: + return 5; + case 18: + return 7; + case 19: + return "value"; + case 20: + return 22; + } + }, + rules: [/^(?:%%(?!\{)[^\n]*)/i, /^(?:[^\}]%%[^\n]*)/i, /^(?:[\n\r]+)/i, /^(?:%%[^\n]*)/i, /^(?:[\s]+)/i, /^(?:title\b)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accTitle\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*\{\s*)/i, /^(?:[\}])/i, /^(?:[^\}]*)/i, /^(?:["])/i, /^(?:["])/i, /^(?:[^"]*)/i, /^(?:pie\b)/i, /^(?:showData\b)/i, /^(?::[\s]*[\d]+(?:\.[\d]+)?)/i, /^(?:$)/i], + conditions: { acc_descr_multiline: { rules: [12, 13], inclusive: !1 }, acc_descr: { rules: [10], inclusive: !1 }, acc_title: { rules: [8], inclusive: !1 }, title: { rules: [6], inclusive: !1 }, string: { rules: [15, 16], inclusive: !1 }, INITIAL: { rules: [0, 1, 2, 3, 4, 5, 7, 9, 11, 14, 17, 18, 19, 20], inclusive: !0 } } + }; + return b; + }(); + T.lexer = O; + function w() { + this.yy = {}; + } + return w.prototype = T, T.Parser = w, new w(); +}(); +J.parser = J; +const Et = J, nt = at.pie, G = { + sections: {}, + showData: !1, + config: nt +}; +let U = G.sections, K = G.showData; +const At = structuredClone(nt), wt = () => structuredClone(At), $t = () => { + U = structuredClone(G.sections), K = G.showData, ft(); +}, Tt = (e, u) => { + e = pt(e, et()), U[e] === void 0 && (U[e] = u, it.debug(`added new section: ${e}, with value: ${u}`)); +}, It = () => U, Dt = (e) => (e.substring(0, 1) === ":" && (e = e.substring(1).trim()), Number(e.trim())), Ct = (e) => { + K = e; +}, Ot = () => K, Vt = { + getConfig: wt, + clear: $t, + setDiagramTitle: lt, + getDiagramTitle: ct, + setAccTitle: ot, + getAccTitle: ht, + setAccDescription: ut, + getAccDescription: yt, + addSection: Tt, + getSections: It, + cleanupValue: Dt, + setShowData: Ct, + getShowData: Ot +}, Pt = (e) => ` + .pieCircle{ + stroke: ${e.pieStrokeColor}; + stroke-width : ${e.pieStrokeWidth}; + opacity : ${e.pieOpacity}; + } + .pieOuterCircle{ + stroke: ${e.pieOuterStrokeColor}; + stroke-width: ${e.pieOuterStrokeWidth}; + fill: none; + } + .pieTitleText { + text-anchor: middle; + font-size: ${e.pieTitleTextSize}; + fill: ${e.pieTitleTextColor}; + font-family: ${e.fontFamily}; + } + .slice { + font-family: ${e.fontFamily}; + fill: ${e.pieSectionTextColor}; + font-size:${e.pieSectionTextSize}; + // fill: white; + } + .legend text { + fill: ${e.pieLegendTextColor}; + font-family: ${e.fontFamily}; + font-size: ${e.pieLegendTextSize}; + } +`, Nt = Pt, Lt = (e) => { + const u = Object.entries(e).map((p) => ({ + label: p[0], + value: p[1] + })).sort((p, g) => g.value - p.value); + return St().value( + (p) => p.value + )(u); +}, Ft = (e, u, E, p) => { + it.debug(`rendering pie chart +` + e); + const g = p.db, A = et(), y = gt(g.getConfig(), A.pie), a = 40, l = 18, d = 4, m = 450, I = m, $ = dt(u), _ = $.append("g"), v = g.getSections(); + _.attr("transform", "translate(" + I / 2 + "," + m / 2 + ")"); + const { themeVariables: o } = A; + let [T] = mt(o.pieOuterStrokeWidth); + T ?? (T = 2); + const O = y.textPosition, w = Math.min(I, m) / 2 - a, b = tt().innerRadius(0).outerRadius(w), t = tt().innerRadius(w * O).outerRadius(w * O); + _.append("circle").attr("cx", 0).attr("cy", 0).attr("r", w + T / 2).attr("class", "pieOuterCircle"); + const i = Lt(v), n = [ + o.pie1, + o.pie2, + o.pie3, + o.pie4, + o.pie5, + o.pie6, + o.pie7, + o.pie8, + o.pie9, + o.pie10, + o.pie11, + o.pie12 + ], r = xt(n); + _.selectAll("mySlices").data(i).enter().append("path").attr("d", b).attr("fill", (f) => r(f.data.label)).attr("class", "pieCircle"); + let c = 0; + Object.keys(v).forEach((f) => { + c += v[f]; + }), _.selectAll("mySlices").data(i).enter().append("text").text((f) => (f.data.value / c * 100).toFixed(0) + "%").attr("transform", (f) => "translate(" + t.centroid(f) + ")").style("text-anchor", "middle").attr("class", "slice"), _.append("text").text(g.getDiagramTitle()).attr("x", 0).attr("y", -(m - 50) / 2).attr("class", "pieTitleText"); + const s = _.selectAll(".legend").data(r.domain()).enter().append("g").attr("class", "legend").attr("transform", (f, P) => { + const R = l + d, M = R * r.domain().length / 2, Y = 12 * l, h = P * R - M; + return "translate(" + Y + "," + h + ")"; + }); + s.append("rect").attr("width", l).attr("height", l).style("fill", r).style("stroke", r), s.data(i).append("text").attr("x", l + d).attr("y", l - d).text((f) => { + const { label: P, value: R } = f.data; + return g.getShowData() ? `${P} [${R}]` : P; + }); + const V = Math.max( + ...s.selectAll("text").nodes().map((f) => (f == null ? void 0 : f.getBoundingClientRect().width) ?? 0) + ), x = I + a + l + d + V; + $.attr("viewBox", `0 0 ${x} ${m}`), _t($, m, x, y.useMaxWidth); +}, Rt = { draw: Ft }, Yt = { + parser: Et, + db: Vt, + renderer: Rt, + styles: Nt +}; +export { + Yt as diagram +}; diff --git a/0.6.0/js/mermaid/pieDiagram-bb1d19e5.js b/0.6.0/js/mermaid/pieDiagram-bb1d19e5.js new file mode 100644 index 0000000..658e2b0 --- /dev/null +++ b/0.6.0/js/mermaid/pieDiagram-bb1d19e5.js @@ -0,0 +1,722 @@ +import { B as defaultConfig, q as setDiagramTitle, t as getDiagramTitle, s as setAccTitle, g as getAccTitle, b as setAccDescription, a as getAccDescription, v as clear$1, d as sanitizeText, c as getConfig$1, l as log, C as cleanAndMerge, A as selectSvgElement, D as parseFontSize, i as configureSvgSize } from "./mermaid-6dc72991.js"; +import { arc, scaleOrdinal, pie } from "d3"; +import "ts-dedent"; +import "dayjs"; +import "@braintree/sanitize-url"; +import "dompurify"; +import "khroma"; +import "lodash-es/memoize.js"; +import "lodash-es/merge.js"; +import "stylis"; +import "lodash-es/isEmpty.js"; +var parser = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 3], $V1 = [1, 4], $V2 = [1, 5], $V3 = [1, 6], $V4 = [1, 10, 12, 14, 16, 18, 19, 20, 21, 22], $V5 = [2, 4], $V6 = [1, 5, 10, 12, 14, 16, 18, 19, 20, 21, 22], $V7 = [20, 21, 22], $V8 = [2, 7], $V9 = [1, 12], $Va = [1, 13], $Vb = [1, 14], $Vc = [1, 15], $Vd = [1, 16], $Ve = [1, 17]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "eol": 4, "PIE": 5, "document": 6, "showData": 7, "line": 8, "statement": 9, "txt": 10, "value": 11, "title": 12, "title_value": 13, "acc_title": 14, "acc_title_value": 15, "acc_descr": 16, "acc_descr_value": 17, "acc_descr_multiline_value": 18, "section": 19, "NEWLINE": 20, ";": 21, "EOF": 22, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 5: "PIE", 7: "showData", 10: "txt", 11: "value", 12: "title", 13: "title_value", 14: "acc_title", 15: "acc_title_value", 16: "acc_descr", 17: "acc_descr_value", 18: "acc_descr_multiline_value", 19: "section", 20: "NEWLINE", 21: ";", 22: "EOF" }, + productions_: [0, [3, 2], [3, 2], [3, 3], [6, 0], [6, 2], [8, 2], [9, 0], [9, 2], [9, 2], [9, 2], [9, 2], [9, 1], [9, 1], [4, 1], [4, 1], [4, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 3: + yy.setShowData(true); + break; + case 6: + this.$ = $$[$0 - 1]; + break; + case 8: + yy.addSection($$[$0 - 1], yy.cleanupValue($$[$0])); + break; + case 9: + this.$ = $$[$0].trim(); + yy.setDiagramTitle(this.$); + break; + case 10: + this.$ = $$[$0].trim(); + yy.setAccTitle(this.$); + break; + case 11: + case 12: + this.$ = $$[$0].trim(); + yy.setAccDescription(this.$); + break; + case 13: + yy.addSection($$[$0].substr(8)); + this.$ = $$[$0].substr(8); + break; + } + }, + table: [{ 3: 1, 4: 2, 5: $V0, 20: $V1, 21: $V2, 22: $V3 }, { 1: [3] }, { 3: 7, 4: 2, 5: $V0, 20: $V1, 21: $V2, 22: $V3 }, o($V4, $V5, { 6: 8, 7: [1, 9] }), o($V6, [2, 14]), o($V6, [2, 15]), o($V6, [2, 16]), { 1: [2, 1] }, o($V7, $V8, { 8: 10, 9: 11, 1: [2, 2], 10: $V9, 12: $Va, 14: $Vb, 16: $Vc, 18: $Vd, 19: $Ve }), o($V4, $V5, { 6: 18 }), o($V4, [2, 5]), { 4: 19, 20: $V1, 21: $V2, 22: $V3 }, { 11: [1, 20] }, { 13: [1, 21] }, { 15: [1, 22] }, { 17: [1, 23] }, o($V7, [2, 12]), o($V7, [2, 13]), o($V7, $V8, { 8: 10, 9: 11, 1: [2, 3], 10: $V9, 12: $Va, 14: $Vb, 16: $Vc, 18: $Vd, 19: $Ve }), o($V4, [2, 6]), o($V7, [2, 8]), o($V7, [2, 9]), o($V7, [2, 10]), o($V7, [2, 11])], + defaultActions: { 7: [2, 1] }, + parseError: function parseError(str, hash) { + if (hash.recoverable) { + this.trace(str); + } else { + var error = new Error(str); + error.hash = hash; + throw error; + } + }, + parse: function parse(input) { + var self = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex() { + var token; + token = tstack.pop() || lexer2.lex() || EOF; + if (typeof token !== "number") { + if (token instanceof Array) { + tstack = token; + token = tstack.pop(); + } + token = self.symbols_[token] || token; + } + return token; + } + var symbol, state, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state = stack[stack.length - 1]; + if (this.defaultActions[state]) { + action = this.defaultActions[state]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex(); + } + action = table[state] && table[state][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str, hash); + } else { + throw new Error(str); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch = this._input[0]; + this.yytext += ch; + this.yyleng++; + this.offset++; + this.match += ch; + this.matched += ch; + var lines = ch.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch; + }, + // unshifts one char (or a string) into the input + unput: function(ch) { + var len = ch.length; + var lines = ch.split(/(?:\r\n?|\n)/g); + this._input = ch + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next = this.match; + if (next.length < 20) { + next += this._input.substr(0, 20 - next.length); + } + return (next.substr(0, 20) + (next.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token) { + return token; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token, match, tempMatch, index; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i = 0; i < rules.length; i++) { + tempMatch = this._input.match(this.rules[rules[i]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index = i; + if (this.options.backtrack_lexer) { + token = this.test_match(tempMatch, rules[i]); + if (token !== false) { + return token; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token = this.test_match(match, rules[index]); + if (token !== false) { + return token; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + break; + case 1: + break; + case 2: + return 20; + case 3: + break; + case 4: + break; + case 5: + this.begin("title"); + return 12; + case 6: + this.popState(); + return "title_value"; + case 7: + this.begin("acc_title"); + return 14; + case 8: + this.popState(); + return "acc_title_value"; + case 9: + this.begin("acc_descr"); + return 16; + case 10: + this.popState(); + return "acc_descr_value"; + case 11: + this.begin("acc_descr_multiline"); + break; + case 12: + this.popState(); + break; + case 13: + return "acc_descr_multiline_value"; + case 14: + this.begin("string"); + break; + case 15: + this.popState(); + break; + case 16: + return "txt"; + case 17: + return 5; + case 18: + return 7; + case 19: + return "value"; + case 20: + return 22; + } + }, + rules: [/^(?:%%(?!\{)[^\n]*)/i, /^(?:[^\}]%%[^\n]*)/i, /^(?:[\n\r]+)/i, /^(?:%%[^\n]*)/i, /^(?:[\s]+)/i, /^(?:title\b)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accTitle\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*\{\s*)/i, /^(?:[\}])/i, /^(?:[^\}]*)/i, /^(?:["])/i, /^(?:["])/i, /^(?:[^"]*)/i, /^(?:pie\b)/i, /^(?:showData\b)/i, /^(?::[\s]*[\d]+(?:\.[\d]+)?)/i, /^(?:$)/i], + conditions: { "acc_descr_multiline": { "rules": [12, 13], "inclusive": false }, "acc_descr": { "rules": [10], "inclusive": false }, "acc_title": { "rules": [8], "inclusive": false }, "title": { "rules": [6], "inclusive": false }, "string": { "rules": [15, 16], "inclusive": false }, "INITIAL": { "rules": [0, 1, 2, 3, 4, 5, 7, 9, 11, 14, 17, 18, 19, 20], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser() { + this.yy = {}; + } + Parser.prototype = parser2; + parser2.Parser = Parser; + return new Parser(); +}(); +parser.parser = parser; +const parser$1 = parser; +const DEFAULT_PIE_CONFIG = defaultConfig.pie; +const DEFAULT_PIE_DB = { + sections: {}, + showData: false, + config: DEFAULT_PIE_CONFIG +}; +let sections = DEFAULT_PIE_DB.sections; +let showData = DEFAULT_PIE_DB.showData; +const config = structuredClone(DEFAULT_PIE_CONFIG); +const getConfig = () => structuredClone(config); +const clear = () => { + sections = structuredClone(DEFAULT_PIE_DB.sections); + showData = DEFAULT_PIE_DB.showData; + clear$1(); +}; +const addSection = (label, value) => { + label = sanitizeText(label, getConfig$1()); + if (sections[label] === void 0) { + sections[label] = value; + log.debug(`added new section: ${label}, with value: ${value}`); + } +}; +const getSections = () => sections; +const cleanupValue = (value) => { + if (value.substring(0, 1) === ":") { + value = value.substring(1).trim(); + } + return Number(value.trim()); +}; +const setShowData = (toggle) => { + showData = toggle; +}; +const getShowData = () => showData; +const db = { + getConfig, + clear, + setDiagramTitle, + getDiagramTitle, + setAccTitle, + getAccTitle, + setAccDescription, + getAccDescription, + addSection, + getSections, + cleanupValue, + setShowData, + getShowData +}; +const getStyles = (options) => ` + .pieCircle{ + stroke: ${options.pieStrokeColor}; + stroke-width : ${options.pieStrokeWidth}; + opacity : ${options.pieOpacity}; + } + .pieOuterCircle{ + stroke: ${options.pieOuterStrokeColor}; + stroke-width: ${options.pieOuterStrokeWidth}; + fill: none; + } + .pieTitleText { + text-anchor: middle; + font-size: ${options.pieTitleTextSize}; + fill: ${options.pieTitleTextColor}; + font-family: ${options.fontFamily}; + } + .slice { + font-family: ${options.fontFamily}; + fill: ${options.pieSectionTextColor}; + font-size:${options.pieSectionTextSize}; + // fill: white; + } + .legend text { + fill: ${options.pieLegendTextColor}; + font-family: ${options.fontFamily}; + font-size: ${options.pieLegendTextSize}; + } +`; +const styles = getStyles; +const createPieArcs = (sections2) => { + const pieData = Object.entries(sections2).map((element) => { + return { + label: element[0], + value: element[1] + }; + }).sort((a, b) => { + return b.value - a.value; + }); + const pie$1 = pie().value( + (d3Section) => d3Section.value + ); + return pie$1(pieData); +}; +const draw = (text, id, _version, diagObj) => { + log.debug("rendering pie chart\n" + text); + const db2 = diagObj.db; + const globalConfig = getConfig$1(); + const pieConfig = cleanAndMerge(db2.getConfig(), globalConfig.pie); + const MARGIN = 40; + const LEGEND_RECT_SIZE = 18; + const LEGEND_SPACING = 4; + const height = 450; + const pieWidth = height; + const svg = selectSvgElement(id); + const group = svg.append("g"); + const sections2 = db2.getSections(); + group.attr("transform", "translate(" + pieWidth / 2 + "," + height / 2 + ")"); + const { themeVariables } = globalConfig; + let [outerStrokeWidth] = parseFontSize(themeVariables.pieOuterStrokeWidth); + outerStrokeWidth ?? (outerStrokeWidth = 2); + const textPosition = pieConfig.textPosition; + const radius = Math.min(pieWidth, height) / 2 - MARGIN; + const arcGenerator = arc().innerRadius(0).outerRadius(radius); + const labelArcGenerator = arc().innerRadius(radius * textPosition).outerRadius(radius * textPosition); + group.append("circle").attr("cx", 0).attr("cy", 0).attr("r", radius + outerStrokeWidth / 2).attr("class", "pieOuterCircle"); + const arcs = createPieArcs(sections2); + const myGeneratedColors = [ + themeVariables.pie1, + themeVariables.pie2, + themeVariables.pie3, + themeVariables.pie4, + themeVariables.pie5, + themeVariables.pie6, + themeVariables.pie7, + themeVariables.pie8, + themeVariables.pie9, + themeVariables.pie10, + themeVariables.pie11, + themeVariables.pie12 + ]; + const color = scaleOrdinal(myGeneratedColors); + group.selectAll("mySlices").data(arcs).enter().append("path").attr("d", arcGenerator).attr("fill", (datum) => { + return color(datum.data.label); + }).attr("class", "pieCircle"); + let sum = 0; + Object.keys(sections2).forEach((key) => { + sum += sections2[key]; + }); + group.selectAll("mySlices").data(arcs).enter().append("text").text((datum) => { + return (datum.data.value / sum * 100).toFixed(0) + "%"; + }).attr("transform", (datum) => { + return "translate(" + labelArcGenerator.centroid(datum) + ")"; + }).style("text-anchor", "middle").attr("class", "slice"); + group.append("text").text(db2.getDiagramTitle()).attr("x", 0).attr("y", -(height - 50) / 2).attr("class", "pieTitleText"); + const legend = group.selectAll(".legend").data(color.domain()).enter().append("g").attr("class", "legend").attr("transform", (_datum, index) => { + const height2 = LEGEND_RECT_SIZE + LEGEND_SPACING; + const offset = height2 * color.domain().length / 2; + const horizontal = 12 * LEGEND_RECT_SIZE; + const vertical = index * height2 - offset; + return "translate(" + horizontal + "," + vertical + ")"; + }); + legend.append("rect").attr("width", LEGEND_RECT_SIZE).attr("height", LEGEND_RECT_SIZE).style("fill", color).style("stroke", color); + legend.data(arcs).append("text").attr("x", LEGEND_RECT_SIZE + LEGEND_SPACING).attr("y", LEGEND_RECT_SIZE - LEGEND_SPACING).text((datum) => { + const { label, value } = datum.data; + if (db2.getShowData()) { + return `${label} [${value}]`; + } + return label; + }); + const longestTextWidth = Math.max( + ...legend.selectAll("text").nodes().map((node) => (node == null ? void 0 : node.getBoundingClientRect().width) ?? 0) + ); + const totalWidth = pieWidth + MARGIN + LEGEND_RECT_SIZE + LEGEND_SPACING + longestTextWidth; + svg.attr("viewBox", `0 0 ${totalWidth} ${height}`); + configureSvgSize(svg, height, totalWidth, pieConfig.useMaxWidth); +}; +const renderer = { draw }; +const diagram = { + parser: parser$1, + db, + renderer, + styles +}; +export { + diagram +}; diff --git a/0.6.0/js/mermaid/pieDiagram-e854eaf0.js b/0.6.0/js/mermaid/pieDiagram-e854eaf0.js new file mode 100644 index 0000000..59a09dc --- /dev/null +++ b/0.6.0/js/mermaid/pieDiagram-e854eaf0.js @@ -0,0 +1,772 @@ +import { V as tau, W as defaultConfig, C as setDiagramTitle, D as getDiagramTitle, s as setAccTitle, g as getAccTitle, b as setAccDescription, a as getAccDescription, E as clear$1, d as sanitizeText, c as getConfig$1, l as log, X as cleanAndMerge, U as selectSvgElement, Y as parseFontSize, k as configureSvgSize } from "./mermaid-dcacb631.js"; +import { d as d3arc } from "./arc-c0f908ab.js"; +import { o as ordinal } from "./ordinal-475e0c0c.js"; +import { a as array } from "./array-b7dcf730.js"; +import { c as constant } from "./path-39bad7e2.js"; +import "./init-cc95ec8e.js"; +function descending(a, b) { + return b < a ? -1 : b > a ? 1 : b >= a ? 0 : NaN; +} +function identity(d) { + return d; +} +function d3pie() { + var value = identity, sortValues = descending, sort = null, startAngle = constant(0), endAngle = constant(tau), padAngle = constant(0); + function pie(data) { + var i, n = (data = array(data)).length, j, k, sum = 0, index = new Array(n), arcs = new Array(n), a0 = +startAngle.apply(this, arguments), da = Math.min(tau, Math.max(-tau, endAngle.apply(this, arguments) - a0)), a1, p = Math.min(Math.abs(da) / n, padAngle.apply(this, arguments)), pa = p * (da < 0 ? -1 : 1), v; + for (i = 0; i < n; ++i) { + if ((v = arcs[index[i] = i] = +value(data[i], i, data)) > 0) { + sum += v; + } + } + if (sortValues != null) + index.sort(function(i2, j2) { + return sortValues(arcs[i2], arcs[j2]); + }); + else if (sort != null) + index.sort(function(i2, j2) { + return sort(data[i2], data[j2]); + }); + for (i = 0, k = sum ? (da - n * pa) / sum : 0; i < n; ++i, a0 = a1) { + j = index[i], v = arcs[j], a1 = a0 + (v > 0 ? v * k : 0) + pa, arcs[j] = { + data: data[j], + index: i, + value: v, + startAngle: a0, + endAngle: a1, + padAngle: p + }; + } + return arcs; + } + pie.value = function(_) { + return arguments.length ? (value = typeof _ === "function" ? _ : constant(+_), pie) : value; + }; + pie.sortValues = function(_) { + return arguments.length ? (sortValues = _, sort = null, pie) : sortValues; + }; + pie.sort = function(_) { + return arguments.length ? (sort = _, sortValues = null, pie) : sort; + }; + pie.startAngle = function(_) { + return arguments.length ? (startAngle = typeof _ === "function" ? _ : constant(+_), pie) : startAngle; + }; + pie.endAngle = function(_) { + return arguments.length ? (endAngle = typeof _ === "function" ? _ : constant(+_), pie) : endAngle; + }; + pie.padAngle = function(_) { + return arguments.length ? (padAngle = typeof _ === "function" ? _ : constant(+_), pie) : padAngle; + }; + return pie; +} +var parser = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 3], $V1 = [1, 4], $V2 = [1, 5], $V3 = [1, 6], $V4 = [1, 10, 12, 14, 16, 18, 19, 20, 21, 22], $V5 = [2, 4], $V6 = [1, 5, 10, 12, 14, 16, 18, 19, 20, 21, 22], $V7 = [20, 21, 22], $V8 = [2, 7], $V9 = [1, 12], $Va = [1, 13], $Vb = [1, 14], $Vc = [1, 15], $Vd = [1, 16], $Ve = [1, 17]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "eol": 4, "PIE": 5, "document": 6, "showData": 7, "line": 8, "statement": 9, "txt": 10, "value": 11, "title": 12, "title_value": 13, "acc_title": 14, "acc_title_value": 15, "acc_descr": 16, "acc_descr_value": 17, "acc_descr_multiline_value": 18, "section": 19, "NEWLINE": 20, ";": 21, "EOF": 22, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 5: "PIE", 7: "showData", 10: "txt", 11: "value", 12: "title", 13: "title_value", 14: "acc_title", 15: "acc_title_value", 16: "acc_descr", 17: "acc_descr_value", 18: "acc_descr_multiline_value", 19: "section", 20: "NEWLINE", 21: ";", 22: "EOF" }, + productions_: [0, [3, 2], [3, 2], [3, 3], [6, 0], [6, 2], [8, 2], [9, 0], [9, 2], [9, 2], [9, 2], [9, 2], [9, 1], [9, 1], [4, 1], [4, 1], [4, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 3: + yy.setShowData(true); + break; + case 6: + this.$ = $$[$0 - 1]; + break; + case 8: + yy.addSection($$[$0 - 1], yy.cleanupValue($$[$0])); + break; + case 9: + this.$ = $$[$0].trim(); + yy.setDiagramTitle(this.$); + break; + case 10: + this.$ = $$[$0].trim(); + yy.setAccTitle(this.$); + break; + case 11: + case 12: + this.$ = $$[$0].trim(); + yy.setAccDescription(this.$); + break; + case 13: + yy.addSection($$[$0].substr(8)); + this.$ = $$[$0].substr(8); + break; + } + }, + table: [{ 3: 1, 4: 2, 5: $V0, 20: $V1, 21: $V2, 22: $V3 }, { 1: [3] }, { 3: 7, 4: 2, 5: $V0, 20: $V1, 21: $V2, 22: $V3 }, o($V4, $V5, { 6: 8, 7: [1, 9] }), o($V6, [2, 14]), o($V6, [2, 15]), o($V6, [2, 16]), { 1: [2, 1] }, o($V7, $V8, { 8: 10, 9: 11, 1: [2, 2], 10: $V9, 12: $Va, 14: $Vb, 16: $Vc, 18: $Vd, 19: $Ve }), o($V4, $V5, { 6: 18 }), o($V4, [2, 5]), { 4: 19, 20: $V1, 21: $V2, 22: $V3 }, { 11: [1, 20] }, { 13: [1, 21] }, { 15: [1, 22] }, { 17: [1, 23] }, o($V7, [2, 12]), o($V7, [2, 13]), o($V7, $V8, { 8: 10, 9: 11, 1: [2, 3], 10: $V9, 12: $Va, 14: $Vb, 16: $Vc, 18: $Vd, 19: $Ve }), o($V4, [2, 6]), o($V7, [2, 8]), o($V7, [2, 9]), o($V7, [2, 10]), o($V7, [2, 11])], + defaultActions: { 7: [2, 1] }, + parseError: function parseError(str, hash) { + if (hash.recoverable) { + this.trace(str); + } else { + var error = new Error(str); + error.hash = hash; + throw error; + } + }, + parse: function parse(input) { + var self = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex() { + var token; + token = tstack.pop() || lexer2.lex() || EOF; + if (typeof token !== "number") { + if (token instanceof Array) { + tstack = token; + token = tstack.pop(); + } + token = self.symbols_[token] || token; + } + return token; + } + var symbol, state, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state = stack[stack.length - 1]; + if (this.defaultActions[state]) { + action = this.defaultActions[state]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex(); + } + action = table[state] && table[state][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str, hash); + } else { + throw new Error(str); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch = this._input[0]; + this.yytext += ch; + this.yyleng++; + this.offset++; + this.match += ch; + this.matched += ch; + var lines = ch.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch; + }, + // unshifts one char (or a string) into the input + unput: function(ch) { + var len = ch.length; + var lines = ch.split(/(?:\r\n?|\n)/g); + this._input = ch + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next = this.match; + if (next.length < 20) { + next += this._input.substr(0, 20 - next.length); + } + return (next.substr(0, 20) + (next.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token) { + return token; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token, match, tempMatch, index; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i = 0; i < rules.length; i++) { + tempMatch = this._input.match(this.rules[rules[i]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index = i; + if (this.options.backtrack_lexer) { + token = this.test_match(tempMatch, rules[i]); + if (token !== false) { + return token; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token = this.test_match(match, rules[index]); + if (token !== false) { + return token; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + break; + case 1: + break; + case 2: + return 20; + case 3: + break; + case 4: + break; + case 5: + this.begin("title"); + return 12; + case 6: + this.popState(); + return "title_value"; + case 7: + this.begin("acc_title"); + return 14; + case 8: + this.popState(); + return "acc_title_value"; + case 9: + this.begin("acc_descr"); + return 16; + case 10: + this.popState(); + return "acc_descr_value"; + case 11: + this.begin("acc_descr_multiline"); + break; + case 12: + this.popState(); + break; + case 13: + return "acc_descr_multiline_value"; + case 14: + this.begin("string"); + break; + case 15: + this.popState(); + break; + case 16: + return "txt"; + case 17: + return 5; + case 18: + return 7; + case 19: + return "value"; + case 20: + return 22; + } + }, + rules: [/^(?:%%(?!\{)[^\n]*)/i, /^(?:[^\}]%%[^\n]*)/i, /^(?:[\n\r]+)/i, /^(?:%%[^\n]*)/i, /^(?:[\s]+)/i, /^(?:title\b)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accTitle\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*\{\s*)/i, /^(?:[\}])/i, /^(?:[^\}]*)/i, /^(?:["])/i, /^(?:["])/i, /^(?:[^"]*)/i, /^(?:pie\b)/i, /^(?:showData\b)/i, /^(?::[\s]*[\d]+(?:\.[\d]+)?)/i, /^(?:$)/i], + conditions: { "acc_descr_multiline": { "rules": [12, 13], "inclusive": false }, "acc_descr": { "rules": [10], "inclusive": false }, "acc_title": { "rules": [8], "inclusive": false }, "title": { "rules": [6], "inclusive": false }, "string": { "rules": [15, 16], "inclusive": false }, "INITIAL": { "rules": [0, 1, 2, 3, 4, 5, 7, 9, 11, 14, 17, 18, 19, 20], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser() { + this.yy = {}; + } + Parser.prototype = parser2; + parser2.Parser = Parser; + return new Parser(); +}(); +parser.parser = parser; +const parser$1 = parser; +const DEFAULT_PIE_CONFIG = defaultConfig.pie; +const DEFAULT_PIE_DB = { + sections: {}, + showData: false, + config: DEFAULT_PIE_CONFIG +}; +let sections = DEFAULT_PIE_DB.sections; +let showData = DEFAULT_PIE_DB.showData; +const config = structuredClone(DEFAULT_PIE_CONFIG); +const getConfig = () => structuredClone(config); +const clear = () => { + sections = structuredClone(DEFAULT_PIE_DB.sections); + showData = DEFAULT_PIE_DB.showData; + clear$1(); +}; +const addSection = (label, value) => { + label = sanitizeText(label, getConfig$1()); + if (sections[label] === void 0) { + sections[label] = value; + log.debug(`added new section: ${label}, with value: ${value}`); + } +}; +const getSections = () => sections; +const cleanupValue = (value) => { + if (value.substring(0, 1) === ":") { + value = value.substring(1).trim(); + } + return Number(value.trim()); +}; +const setShowData = (toggle) => { + showData = toggle; +}; +const getShowData = () => showData; +const db = { + getConfig, + clear, + setDiagramTitle, + getDiagramTitle, + setAccTitle, + getAccTitle, + setAccDescription, + getAccDescription, + addSection, + getSections, + cleanupValue, + setShowData, + getShowData +}; +const getStyles = (options) => ` + .pieCircle{ + stroke: ${options.pieStrokeColor}; + stroke-width : ${options.pieStrokeWidth}; + opacity : ${options.pieOpacity}; + } + .pieOuterCircle{ + stroke: ${options.pieOuterStrokeColor}; + stroke-width: ${options.pieOuterStrokeWidth}; + fill: none; + } + .pieTitleText { + text-anchor: middle; + font-size: ${options.pieTitleTextSize}; + fill: ${options.pieTitleTextColor}; + font-family: ${options.fontFamily}; + } + .slice { + font-family: ${options.fontFamily}; + fill: ${options.pieSectionTextColor}; + font-size:${options.pieSectionTextSize}; + // fill: white; + } + .legend text { + fill: ${options.pieLegendTextColor}; + font-family: ${options.fontFamily}; + font-size: ${options.pieLegendTextSize}; + } +`; +const styles = getStyles; +const createPieArcs = (sections2) => { + const pieData = Object.entries(sections2).map((element) => { + return { + label: element[0], + value: element[1] + }; + }).sort((a, b) => { + return b.value - a.value; + }); + const pie = d3pie().value( + (d3Section) => d3Section.value + ); + return pie(pieData); +}; +const draw = (text, id, _version, diagObj) => { + log.debug("rendering pie chart\n" + text); + const db2 = diagObj.db; + const globalConfig = getConfig$1(); + const pieConfig = cleanAndMerge(db2.getConfig(), globalConfig.pie); + const MARGIN = 40; + const LEGEND_RECT_SIZE = 18; + const LEGEND_SPACING = 4; + const height = 450; + const pieWidth = height; + const svg = selectSvgElement(id); + const group = svg.append("g"); + const sections2 = db2.getSections(); + group.attr("transform", "translate(" + pieWidth / 2 + "," + height / 2 + ")"); + const { themeVariables } = globalConfig; + let [outerStrokeWidth] = parseFontSize(themeVariables.pieOuterStrokeWidth); + outerStrokeWidth ?? (outerStrokeWidth = 2); + const textPosition = pieConfig.textPosition; + const radius = Math.min(pieWidth, height) / 2 - MARGIN; + const arcGenerator = d3arc().innerRadius(0).outerRadius(radius); + const labelArcGenerator = d3arc().innerRadius(radius * textPosition).outerRadius(radius * textPosition); + group.append("circle").attr("cx", 0).attr("cy", 0).attr("r", radius + outerStrokeWidth / 2).attr("class", "pieOuterCircle"); + const arcs = createPieArcs(sections2); + const myGeneratedColors = [ + themeVariables.pie1, + themeVariables.pie2, + themeVariables.pie3, + themeVariables.pie4, + themeVariables.pie5, + themeVariables.pie6, + themeVariables.pie7, + themeVariables.pie8, + themeVariables.pie9, + themeVariables.pie10, + themeVariables.pie11, + themeVariables.pie12 + ]; + const color = ordinal(myGeneratedColors); + group.selectAll("mySlices").data(arcs).enter().append("path").attr("d", arcGenerator).attr("fill", (datum) => { + return color(datum.data.label); + }).attr("class", "pieCircle"); + let sum = 0; + Object.keys(sections2).forEach((key) => { + sum += sections2[key]; + }); + group.selectAll("mySlices").data(arcs).enter().append("text").text((datum) => { + return (datum.data.value / sum * 100).toFixed(0) + "%"; + }).attr("transform", (datum) => { + return "translate(" + labelArcGenerator.centroid(datum) + ")"; + }).style("text-anchor", "middle").attr("class", "slice"); + group.append("text").text(db2.getDiagramTitle()).attr("x", 0).attr("y", -(height - 50) / 2).attr("class", "pieTitleText"); + const legend = group.selectAll(".legend").data(color.domain()).enter().append("g").attr("class", "legend").attr("transform", (_datum, index) => { + const height2 = LEGEND_RECT_SIZE + LEGEND_SPACING; + const offset = height2 * color.domain().length / 2; + const horizontal = 12 * LEGEND_RECT_SIZE; + const vertical = index * height2 - offset; + return "translate(" + horizontal + "," + vertical + ")"; + }); + legend.append("rect").attr("width", LEGEND_RECT_SIZE).attr("height", LEGEND_RECT_SIZE).style("fill", color).style("stroke", color); + legend.data(arcs).append("text").attr("x", LEGEND_RECT_SIZE + LEGEND_SPACING).attr("y", LEGEND_RECT_SIZE - LEGEND_SPACING).text((datum) => { + const { label, value } = datum.data; + if (db2.getShowData()) { + return `${label} [${value}]`; + } + return label; + }); + const longestTextWidth = Math.max( + ...legend.selectAll("text").nodes().map((node) => (node == null ? void 0 : node.getBoundingClientRect().width) ?? 0) + ); + const totalWidth = pieWidth + MARGIN + LEGEND_RECT_SIZE + LEGEND_SPACING + longestTextWidth; + svg.attr("viewBox", `0 0 ${totalWidth} ${height}`); + configureSvgSize(svg, height, totalWidth, pieConfig.useMaxWidth); +}; +const renderer = { draw }; +const diagram = { + parser: parser$1, + db, + renderer, + styles +}; +export { + diagram +}; diff --git a/0.6.0/js/mermaid/quadrantDiagram-25a9848b.js b/0.6.0/js/mermaid/quadrantDiagram-25a9848b.js new file mode 100644 index 0000000..53699f1 --- /dev/null +++ b/0.6.0/js/mermaid/quadrantDiagram-25a9848b.js @@ -0,0 +1,1199 @@ +import { Z as getThemeVariables, W as defaultConfig, l as log, s as setAccTitle, g as getAccTitle, C as setDiagramTitle, D as getDiagramTitle, a as getAccDescription, b as setAccDescription, c as getConfig, E as clear$1, d as sanitizeText, j as d3select, k as configureSvgSize } from "./mermaid-dcacb631.js"; +import { l as linear } from "./linear-0ad15847.js"; +import "./init-cc95ec8e.js"; +var parser = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 3], $V1 = [1, 4], $V2 = [1, 5], $V3 = [1, 6], $V4 = [1, 7], $V5 = [1, 5, 13, 15, 17, 19, 20, 25, 27, 28, 29, 30, 31, 32, 33, 34, 37, 38, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50], $V6 = [1, 5, 6, 13, 15, 17, 19, 20, 25, 27, 28, 29, 30, 31, 32, 33, 34, 37, 38, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50], $V7 = [32, 33, 34], $V8 = [2, 7], $V9 = [1, 13], $Va = [1, 17], $Vb = [1, 18], $Vc = [1, 19], $Vd = [1, 20], $Ve = [1, 21], $Vf = [1, 22], $Vg = [1, 23], $Vh = [1, 24], $Vi = [1, 25], $Vj = [1, 26], $Vk = [1, 27], $Vl = [1, 30], $Vm = [1, 31], $Vn = [1, 32], $Vo = [1, 33], $Vp = [1, 34], $Vq = [1, 35], $Vr = [1, 36], $Vs = [1, 37], $Vt = [1, 38], $Vu = [1, 39], $Vv = [1, 40], $Vw = [1, 41], $Vx = [1, 42], $Vy = [1, 57], $Vz = [1, 58], $VA = [5, 22, 26, 32, 33, 34, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "eol": 4, "SPACE": 5, "QUADRANT": 6, "document": 7, "line": 8, "statement": 9, "axisDetails": 10, "quadrantDetails": 11, "points": 12, "title": 13, "title_value": 14, "acc_title": 15, "acc_title_value": 16, "acc_descr": 17, "acc_descr_value": 18, "acc_descr_multiline_value": 19, "section": 20, "text": 21, "point_start": 22, "point_x": 23, "point_y": 24, "X-AXIS": 25, "AXIS-TEXT-DELIMITER": 26, "Y-AXIS": 27, "QUADRANT_1": 28, "QUADRANT_2": 29, "QUADRANT_3": 30, "QUADRANT_4": 31, "NEWLINE": 32, "SEMI": 33, "EOF": 34, "alphaNumToken": 35, "textNoTagsToken": 36, "STR": 37, "MD_STR": 38, "alphaNum": 39, "PUNCTUATION": 40, "AMP": 41, "NUM": 42, "ALPHA": 43, "COMMA": 44, "PLUS": 45, "EQUALS": 46, "MULT": 47, "DOT": 48, "BRKT": 49, "UNDERSCORE": 50, "MINUS": 51, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 5: "SPACE", 6: "QUADRANT", 13: "title", 14: "title_value", 15: "acc_title", 16: "acc_title_value", 17: "acc_descr", 18: "acc_descr_value", 19: "acc_descr_multiline_value", 20: "section", 22: "point_start", 23: "point_x", 24: "point_y", 25: "X-AXIS", 26: "AXIS-TEXT-DELIMITER", 27: "Y-AXIS", 28: "QUADRANT_1", 29: "QUADRANT_2", 30: "QUADRANT_3", 31: "QUADRANT_4", 32: "NEWLINE", 33: "SEMI", 34: "EOF", 37: "STR", 38: "MD_STR", 40: "PUNCTUATION", 41: "AMP", 42: "NUM", 43: "ALPHA", 44: "COMMA", 45: "PLUS", 46: "EQUALS", 47: "MULT", 48: "DOT", 49: "BRKT", 50: "UNDERSCORE", 51: "MINUS" }, + productions_: [0, [3, 2], [3, 2], [3, 2], [7, 0], [7, 2], [8, 2], [9, 0], [9, 2], [9, 1], [9, 1], [9, 1], [9, 2], [9, 2], [9, 2], [9, 1], [9, 1], [12, 4], [10, 4], [10, 3], [10, 2], [10, 4], [10, 3], [10, 2], [11, 2], [11, 2], [11, 2], [11, 2], [4, 1], [4, 1], [4, 1], [21, 1], [21, 2], [21, 1], [21, 1], [39, 1], [39, 2], [35, 1], [35, 1], [35, 1], [35, 1], [35, 1], [35, 1], [35, 1], [35, 1], [35, 1], [35, 1], [35, 1], [36, 1], [36, 1], [36, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 12: + this.$ = $$[$0].trim(); + yy.setDiagramTitle(this.$); + break; + case 13: + this.$ = $$[$0].trim(); + yy.setAccTitle(this.$); + break; + case 14: + case 15: + this.$ = $$[$0].trim(); + yy.setAccDescription(this.$); + break; + case 16: + yy.addSection($$[$0].substr(8)); + this.$ = $$[$0].substr(8); + break; + case 17: + yy.addPoint($$[$0 - 3], $$[$0 - 1], $$[$0]); + break; + case 18: + yy.setXAxisLeftText($$[$0 - 2]); + yy.setXAxisRightText($$[$0]); + break; + case 19: + $$[$0 - 1].text += " ⟶ "; + yy.setXAxisLeftText($$[$0 - 1]); + break; + case 20: + yy.setXAxisLeftText($$[$0]); + break; + case 21: + yy.setYAxisBottomText($$[$0 - 2]); + yy.setYAxisTopText($$[$0]); + break; + case 22: + $$[$0 - 1].text += " ⟶ "; + yy.setYAxisBottomText($$[$0 - 1]); + break; + case 23: + yy.setYAxisBottomText($$[$0]); + break; + case 24: + yy.setQuadrant1Text($$[$0]); + break; + case 25: + yy.setQuadrant2Text($$[$0]); + break; + case 26: + yy.setQuadrant3Text($$[$0]); + break; + case 27: + yy.setQuadrant4Text($$[$0]); + break; + case 31: + this.$ = { text: $$[$0], type: "text" }; + break; + case 32: + this.$ = { text: $$[$0 - 1].text + "" + $$[$0], type: $$[$0 - 1].type }; + break; + case 33: + this.$ = { text: $$[$0], type: "text" }; + break; + case 34: + this.$ = { text: $$[$0], type: "markdown" }; + break; + case 35: + this.$ = $$[$0]; + break; + case 36: + this.$ = $$[$0 - 1] + "" + $$[$0]; + break; + } + }, + table: [{ 3: 1, 4: 2, 5: $V0, 6: $V1, 32: $V2, 33: $V3, 34: $V4 }, { 1: [3] }, { 3: 8, 4: 2, 5: $V0, 6: $V1, 32: $V2, 33: $V3, 34: $V4 }, { 3: 9, 4: 2, 5: $V0, 6: $V1, 32: $V2, 33: $V3, 34: $V4 }, o($V5, [2, 4], { 7: 10 }), o($V6, [2, 28]), o($V6, [2, 29]), o($V6, [2, 30]), { 1: [2, 1] }, { 1: [2, 2] }, o($V7, $V8, { 8: 11, 9: 12, 10: 14, 11: 15, 12: 16, 21: 28, 35: 29, 1: [2, 3], 5: $V9, 13: $Va, 15: $Vb, 17: $Vc, 19: $Vd, 20: $Ve, 25: $Vf, 27: $Vg, 28: $Vh, 29: $Vi, 30: $Vj, 31: $Vk, 37: $Vl, 38: $Vm, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx }), o($V5, [2, 5]), { 4: 43, 32: $V2, 33: $V3, 34: $V4 }, o($V7, $V8, { 10: 14, 11: 15, 12: 16, 21: 28, 35: 29, 9: 44, 5: $V9, 13: $Va, 15: $Vb, 17: $Vc, 19: $Vd, 20: $Ve, 25: $Vf, 27: $Vg, 28: $Vh, 29: $Vi, 30: $Vj, 31: $Vk, 37: $Vl, 38: $Vm, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx }), o($V7, [2, 9]), o($V7, [2, 10]), o($V7, [2, 11]), { 14: [1, 45] }, { 16: [1, 46] }, { 18: [1, 47] }, o($V7, [2, 15]), o($V7, [2, 16]), { 21: 48, 35: 29, 37: $Vl, 38: $Vm, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx }, { 21: 49, 35: 29, 37: $Vl, 38: $Vm, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx }, { 21: 50, 35: 29, 37: $Vl, 38: $Vm, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx }, { 21: 51, 35: 29, 37: $Vl, 38: $Vm, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx }, { 21: 52, 35: 29, 37: $Vl, 38: $Vm, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx }, { 21: 53, 35: 29, 37: $Vl, 38: $Vm, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx }, { 5: $Vy, 22: [1, 54], 35: 56, 36: 55, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx, 51: $Vz }, o($VA, [2, 31]), o($VA, [2, 33]), o($VA, [2, 34]), o($VA, [2, 37]), o($VA, [2, 38]), o($VA, [2, 39]), o($VA, [2, 40]), o($VA, [2, 41]), o($VA, [2, 42]), o($VA, [2, 43]), o($VA, [2, 44]), o($VA, [2, 45]), o($VA, [2, 46]), o($VA, [2, 47]), o($V5, [2, 6]), o($V7, [2, 8]), o($V7, [2, 12]), o($V7, [2, 13]), o($V7, [2, 14]), o($V7, [2, 20], { 36: 55, 35: 56, 5: $Vy, 26: [1, 59], 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx, 51: $Vz }), o($V7, [2, 23], { 36: 55, 35: 56, 5: $Vy, 26: [1, 60], 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx, 51: $Vz }), o($V7, [2, 24], { 36: 55, 35: 56, 5: $Vy, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx, 51: $Vz }), o($V7, [2, 25], { 36: 55, 35: 56, 5: $Vy, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx, 51: $Vz }), o($V7, [2, 26], { 36: 55, 35: 56, 5: $Vy, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx, 51: $Vz }), o($V7, [2, 27], { 36: 55, 35: 56, 5: $Vy, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx, 51: $Vz }), { 23: [1, 61] }, o($VA, [2, 32]), o($VA, [2, 48]), o($VA, [2, 49]), o($VA, [2, 50]), o($V7, [2, 19], { 35: 29, 21: 62, 37: $Vl, 38: $Vm, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx }), o($V7, [2, 22], { 35: 29, 21: 63, 37: $Vl, 38: $Vm, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx }), { 24: [1, 64] }, o($V7, [2, 18], { 36: 55, 35: 56, 5: $Vy, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx, 51: $Vz }), o($V7, [2, 21], { 36: 55, 35: 56, 5: $Vy, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx, 51: $Vz }), o($V7, [2, 17])], + defaultActions: { 8: [2, 1], 9: [2, 2] }, + parseError: function parseError(str, hash) { + if (hash.recoverable) { + this.trace(str); + } else { + var error = new Error(str); + error.hash = hash; + throw error; + } + }, + parse: function parse(input) { + var self = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex() { + var token; + token = tstack.pop() || lexer2.lex() || EOF; + if (typeof token !== "number") { + if (token instanceof Array) { + tstack = token; + token = tstack.pop(); + } + token = self.symbols_[token] || token; + } + return token; + } + var symbol, state, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state = stack[stack.length - 1]; + if (this.defaultActions[state]) { + action = this.defaultActions[state]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex(); + } + action = table[state] && table[state][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str, hash); + } else { + throw new Error(str); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch = this._input[0]; + this.yytext += ch; + this.yyleng++; + this.offset++; + this.match += ch; + this.matched += ch; + var lines = ch.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch; + }, + // unshifts one char (or a string) into the input + unput: function(ch) { + var len = ch.length; + var lines = ch.split(/(?:\r\n?|\n)/g); + this._input = ch + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next = this.match; + if (next.length < 20) { + next += this._input.substr(0, 20 - next.length); + } + return (next.substr(0, 20) + (next.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token) { + return token; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token, match, tempMatch, index; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i = 0; i < rules.length; i++) { + tempMatch = this._input.match(this.rules[rules[i]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index = i; + if (this.options.backtrack_lexer) { + token = this.test_match(tempMatch, rules[i]); + if (token !== false) { + return token; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token = this.test_match(match, rules[index]); + if (token !== false) { + return token; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + break; + case 1: + break; + case 2: + return 32; + case 3: + break; + case 4: + this.begin("title"); + return 13; + case 5: + this.popState(); + return "title_value"; + case 6: + this.begin("acc_title"); + return 15; + case 7: + this.popState(); + return "acc_title_value"; + case 8: + this.begin("acc_descr"); + return 17; + case 9: + this.popState(); + return "acc_descr_value"; + case 10: + this.begin("acc_descr_multiline"); + break; + case 11: + this.popState(); + break; + case 12: + return "acc_descr_multiline_value"; + case 13: + return 25; + case 14: + return 27; + case 15: + return 26; + case 16: + return 28; + case 17: + return 29; + case 18: + return 30; + case 19: + return 31; + case 20: + this.begin("md_string"); + break; + case 21: + return "MD_STR"; + case 22: + this.popState(); + break; + case 23: + this.begin("string"); + break; + case 24: + this.popState(); + break; + case 25: + return "STR"; + case 26: + this.begin("point_start"); + return 22; + case 27: + this.begin("point_x"); + return 23; + case 28: + this.popState(); + break; + case 29: + this.popState(); + this.begin("point_y"); + break; + case 30: + this.popState(); + return 24; + case 31: + return 6; + case 32: + return 43; + case 33: + return "COLON"; + case 34: + return 45; + case 35: + return 44; + case 36: + return 46; + case 37: + return 46; + case 38: + return 47; + case 39: + return 49; + case 40: + return 50; + case 41: + return 48; + case 42: + return 41; + case 43: + return 51; + case 44: + return 42; + case 45: + return 5; + case 46: + return 33; + case 47: + return 40; + case 48: + return 34; + } + }, + rules: [/^(?:%%(?!\{)[^\n]*)/i, /^(?:[^\}]%%[^\n]*)/i, /^(?:[\n\r]+)/i, /^(?:%%[^\n]*)/i, /^(?:title\b)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accTitle\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*\{\s*)/i, /^(?:[\}])/i, /^(?:[^\}]*)/i, /^(?: *x-axis *)/i, /^(?: *y-axis *)/i, /^(?: *--+> *)/i, /^(?: *quadrant-1 *)/i, /^(?: *quadrant-2 *)/i, /^(?: *quadrant-3 *)/i, /^(?: *quadrant-4 *)/i, /^(?:["][`])/i, /^(?:[^`"]+)/i, /^(?:[`]["])/i, /^(?:["])/i, /^(?:["])/i, /^(?:[^"]*)/i, /^(?:\s*:\s*\[\s*)/i, /^(?:(1)|(0(.\d+)?))/i, /^(?:\s*\] *)/i, /^(?:\s*,\s*)/i, /^(?:(1)|(0(.\d+)?))/i, /^(?: *quadrantChart *)/i, /^(?:[A-Za-z]+)/i, /^(?::)/i, /^(?:\+)/i, /^(?:,)/i, /^(?:=)/i, /^(?:=)/i, /^(?:\*)/i, /^(?:#)/i, /^(?:[\_])/i, /^(?:\.)/i, /^(?:&)/i, /^(?:-)/i, /^(?:[0-9]+)/i, /^(?:\s)/i, /^(?:;)/i, /^(?:[!"#$%&'*+,-.`?\\_/])/i, /^(?:$)/i], + conditions: { "point_y": { "rules": [30], "inclusive": false }, "point_x": { "rules": [29], "inclusive": false }, "point_start": { "rules": [27, 28], "inclusive": false }, "acc_descr_multiline": { "rules": [11, 12], "inclusive": false }, "acc_descr": { "rules": [9], "inclusive": false }, "acc_title": { "rules": [7], "inclusive": false }, "title": { "rules": [5], "inclusive": false }, "md_string": { "rules": [21, 22], "inclusive": false }, "string": { "rules": [24, 25], "inclusive": false }, "INITIAL": { "rules": [0, 1, 2, 3, 4, 6, 8, 10, 13, 14, 15, 16, 17, 18, 19, 20, 23, 26, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser() { + this.yy = {}; + } + Parser.prototype = parser2; + parser2.Parser = Parser; + return new Parser(); +}(); +parser.parser = parser; +const parser$1 = parser; +const defaultThemeVariables = getThemeVariables(); +class QuadrantBuilder { + constructor() { + this.config = this.getDefaultConfig(); + this.themeConfig = this.getDefaultThemeConfig(); + this.data = this.getDefaultData(); + } + getDefaultData() { + return { + titleText: "", + quadrant1Text: "", + quadrant2Text: "", + quadrant3Text: "", + quadrant4Text: "", + xAxisLeftText: "", + xAxisRightText: "", + yAxisBottomText: "", + yAxisTopText: "", + points: [] + }; + } + getDefaultConfig() { + var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r; + return { + showXAxis: true, + showYAxis: true, + showTitle: true, + chartHeight: ((_a = defaultConfig.quadrantChart) == null ? void 0 : _a.chartWidth) || 500, + chartWidth: ((_b = defaultConfig.quadrantChart) == null ? void 0 : _b.chartHeight) || 500, + titlePadding: ((_c = defaultConfig.quadrantChart) == null ? void 0 : _c.titlePadding) || 10, + titleFontSize: ((_d = defaultConfig.quadrantChart) == null ? void 0 : _d.titleFontSize) || 20, + quadrantPadding: ((_e = defaultConfig.quadrantChart) == null ? void 0 : _e.quadrantPadding) || 5, + xAxisLabelPadding: ((_f = defaultConfig.quadrantChart) == null ? void 0 : _f.xAxisLabelPadding) || 5, + yAxisLabelPadding: ((_g = defaultConfig.quadrantChart) == null ? void 0 : _g.yAxisLabelPadding) || 5, + xAxisLabelFontSize: ((_h = defaultConfig.quadrantChart) == null ? void 0 : _h.xAxisLabelFontSize) || 16, + yAxisLabelFontSize: ((_i = defaultConfig.quadrantChart) == null ? void 0 : _i.yAxisLabelFontSize) || 16, + quadrantLabelFontSize: ((_j = defaultConfig.quadrantChart) == null ? void 0 : _j.quadrantLabelFontSize) || 16, + quadrantTextTopPadding: ((_k = defaultConfig.quadrantChart) == null ? void 0 : _k.quadrantTextTopPadding) || 5, + pointTextPadding: ((_l = defaultConfig.quadrantChart) == null ? void 0 : _l.pointTextPadding) || 5, + pointLabelFontSize: ((_m = defaultConfig.quadrantChart) == null ? void 0 : _m.pointLabelFontSize) || 12, + pointRadius: ((_n = defaultConfig.quadrantChart) == null ? void 0 : _n.pointRadius) || 5, + xAxisPosition: ((_o = defaultConfig.quadrantChart) == null ? void 0 : _o.xAxisPosition) || "top", + yAxisPosition: ((_p = defaultConfig.quadrantChart) == null ? void 0 : _p.yAxisPosition) || "left", + quadrantInternalBorderStrokeWidth: ((_q = defaultConfig.quadrantChart) == null ? void 0 : _q.quadrantInternalBorderStrokeWidth) || 1, + quadrantExternalBorderStrokeWidth: ((_r = defaultConfig.quadrantChart) == null ? void 0 : _r.quadrantExternalBorderStrokeWidth) || 2 + }; + } + getDefaultThemeConfig() { + return { + quadrant1Fill: defaultThemeVariables.quadrant1Fill, + quadrant2Fill: defaultThemeVariables.quadrant2Fill, + quadrant3Fill: defaultThemeVariables.quadrant3Fill, + quadrant4Fill: defaultThemeVariables.quadrant4Fill, + quadrant1TextFill: defaultThemeVariables.quadrant1TextFill, + quadrant2TextFill: defaultThemeVariables.quadrant2TextFill, + quadrant3TextFill: defaultThemeVariables.quadrant3TextFill, + quadrant4TextFill: defaultThemeVariables.quadrant4TextFill, + quadrantPointFill: defaultThemeVariables.quadrantPointFill, + quadrantPointTextFill: defaultThemeVariables.quadrantPointTextFill, + quadrantXAxisTextFill: defaultThemeVariables.quadrantXAxisTextFill, + quadrantYAxisTextFill: defaultThemeVariables.quadrantYAxisTextFill, + quadrantTitleFill: defaultThemeVariables.quadrantTitleFill, + quadrantInternalBorderStrokeFill: defaultThemeVariables.quadrantInternalBorderStrokeFill, + quadrantExternalBorderStrokeFill: defaultThemeVariables.quadrantExternalBorderStrokeFill + }; + } + clear() { + this.config = this.getDefaultConfig(); + this.themeConfig = this.getDefaultThemeConfig(); + this.data = this.getDefaultData(); + log.info("clear called"); + } + setData(data) { + this.data = { ...this.data, ...data }; + } + addPoints(points) { + this.data.points = [...points, ...this.data.points]; + } + setConfig(config2) { + log.trace("setConfig called with: ", config2); + this.config = { ...this.config, ...config2 }; + } + setThemeConfig(themeConfig) { + log.trace("setThemeConfig called with: ", themeConfig); + this.themeConfig = { ...this.themeConfig, ...themeConfig }; + } + calculateSpace(xAxisPosition, showXAxis, showYAxis, showTitle) { + const xAxisSpaceCalculation = this.config.xAxisLabelPadding * 2 + this.config.xAxisLabelFontSize; + const xAxisSpace = { + top: xAxisPosition === "top" && showXAxis ? xAxisSpaceCalculation : 0, + bottom: xAxisPosition === "bottom" && showXAxis ? xAxisSpaceCalculation : 0 + }; + const yAxisSpaceCalculation = this.config.yAxisLabelPadding * 2 + this.config.yAxisLabelFontSize; + const yAxisSpace = { + left: this.config.yAxisPosition === "left" && showYAxis ? yAxisSpaceCalculation : 0, + right: this.config.yAxisPosition === "right" && showYAxis ? yAxisSpaceCalculation : 0 + }; + const titleSpaceCalculation = this.config.titleFontSize + this.config.titlePadding * 2; + const titleSpace = { + top: showTitle ? titleSpaceCalculation : 0 + }; + const quadrantLeft = this.config.quadrantPadding + yAxisSpace.left; + const quadrantTop = this.config.quadrantPadding + xAxisSpace.top + titleSpace.top; + const quadrantWidth = this.config.chartWidth - this.config.quadrantPadding * 2 - yAxisSpace.left - yAxisSpace.right; + const quadrantHeight = this.config.chartHeight - this.config.quadrantPadding * 2 - xAxisSpace.top - xAxisSpace.bottom - titleSpace.top; + const quadrantHalfWidth = quadrantWidth / 2; + const quadrantHalfHeight = quadrantHeight / 2; + const quadrantSpace = { + quadrantLeft, + quadrantTop, + quadrantWidth, + quadrantHalfWidth, + quadrantHeight, + quadrantHalfHeight + }; + return { + xAxisSpace, + yAxisSpace, + titleSpace, + quadrantSpace + }; + } + getAxisLabels(xAxisPosition, showXAxis, showYAxis, spaceData) { + const { quadrantSpace, titleSpace } = spaceData; + const { + quadrantHalfHeight, + quadrantHeight, + quadrantLeft, + quadrantHalfWidth, + quadrantTop, + quadrantWidth + } = quadrantSpace; + const drawXAxisLabelsInMiddle = Boolean(this.data.xAxisRightText); + const drawYAxisLabelsInMiddle = Boolean(this.data.yAxisTopText); + const axisLabels = []; + if (this.data.xAxisLeftText && showXAxis) { + axisLabels.push({ + text: this.data.xAxisLeftText, + fill: this.themeConfig.quadrantXAxisTextFill, + x: quadrantLeft + (drawXAxisLabelsInMiddle ? quadrantHalfWidth / 2 : 0), + y: xAxisPosition === "top" ? this.config.xAxisLabelPadding + titleSpace.top : this.config.xAxisLabelPadding + quadrantTop + quadrantHeight + this.config.quadrantPadding, + fontSize: this.config.xAxisLabelFontSize, + verticalPos: drawXAxisLabelsInMiddle ? "center" : "left", + horizontalPos: "top", + rotation: 0 + }); + } + if (this.data.xAxisRightText && showXAxis) { + axisLabels.push({ + text: this.data.xAxisRightText, + fill: this.themeConfig.quadrantXAxisTextFill, + x: quadrantLeft + quadrantHalfWidth + (drawXAxisLabelsInMiddle ? quadrantHalfWidth / 2 : 0), + y: xAxisPosition === "top" ? this.config.xAxisLabelPadding + titleSpace.top : this.config.xAxisLabelPadding + quadrantTop + quadrantHeight + this.config.quadrantPadding, + fontSize: this.config.xAxisLabelFontSize, + verticalPos: drawXAxisLabelsInMiddle ? "center" : "left", + horizontalPos: "top", + rotation: 0 + }); + } + if (this.data.yAxisBottomText && showYAxis) { + axisLabels.push({ + text: this.data.yAxisBottomText, + fill: this.themeConfig.quadrantYAxisTextFill, + x: this.config.yAxisPosition === "left" ? this.config.yAxisLabelPadding : this.config.yAxisLabelPadding + quadrantLeft + quadrantWidth + this.config.quadrantPadding, + y: quadrantTop + quadrantHeight - (drawYAxisLabelsInMiddle ? quadrantHalfHeight / 2 : 0), + fontSize: this.config.yAxisLabelFontSize, + verticalPos: drawYAxisLabelsInMiddle ? "center" : "left", + horizontalPos: "top", + rotation: -90 + }); + } + if (this.data.yAxisTopText && showYAxis) { + axisLabels.push({ + text: this.data.yAxisTopText, + fill: this.themeConfig.quadrantYAxisTextFill, + x: this.config.yAxisPosition === "left" ? this.config.yAxisLabelPadding : this.config.yAxisLabelPadding + quadrantLeft + quadrantWidth + this.config.quadrantPadding, + y: quadrantTop + quadrantHalfHeight - (drawYAxisLabelsInMiddle ? quadrantHalfHeight / 2 : 0), + fontSize: this.config.yAxisLabelFontSize, + verticalPos: drawYAxisLabelsInMiddle ? "center" : "left", + horizontalPos: "top", + rotation: -90 + }); + } + return axisLabels; + } + getQuadrants(spaceData) { + const { quadrantSpace } = spaceData; + const { quadrantHalfHeight, quadrantLeft, quadrantHalfWidth, quadrantTop } = quadrantSpace; + const quadrants = [ + { + text: { + text: this.data.quadrant1Text, + fill: this.themeConfig.quadrant1TextFill, + x: 0, + y: 0, + fontSize: this.config.quadrantLabelFontSize, + verticalPos: "center", + horizontalPos: "middle", + rotation: 0 + }, + x: quadrantLeft + quadrantHalfWidth, + y: quadrantTop, + width: quadrantHalfWidth, + height: quadrantHalfHeight, + fill: this.themeConfig.quadrant1Fill + }, + { + text: { + text: this.data.quadrant2Text, + fill: this.themeConfig.quadrant2TextFill, + x: 0, + y: 0, + fontSize: this.config.quadrantLabelFontSize, + verticalPos: "center", + horizontalPos: "middle", + rotation: 0 + }, + x: quadrantLeft, + y: quadrantTop, + width: quadrantHalfWidth, + height: quadrantHalfHeight, + fill: this.themeConfig.quadrant2Fill + }, + { + text: { + text: this.data.quadrant3Text, + fill: this.themeConfig.quadrant3TextFill, + x: 0, + y: 0, + fontSize: this.config.quadrantLabelFontSize, + verticalPos: "center", + horizontalPos: "middle", + rotation: 0 + }, + x: quadrantLeft, + y: quadrantTop + quadrantHalfHeight, + width: quadrantHalfWidth, + height: quadrantHalfHeight, + fill: this.themeConfig.quadrant3Fill + }, + { + text: { + text: this.data.quadrant4Text, + fill: this.themeConfig.quadrant4TextFill, + x: 0, + y: 0, + fontSize: this.config.quadrantLabelFontSize, + verticalPos: "center", + horizontalPos: "middle", + rotation: 0 + }, + x: quadrantLeft + quadrantHalfWidth, + y: quadrantTop + quadrantHalfHeight, + width: quadrantHalfWidth, + height: quadrantHalfHeight, + fill: this.themeConfig.quadrant4Fill + } + ]; + for (const quadrant of quadrants) { + quadrant.text.x = quadrant.x + quadrant.width / 2; + if (this.data.points.length === 0) { + quadrant.text.y = quadrant.y + quadrant.height / 2; + quadrant.text.horizontalPos = "middle"; + } else { + quadrant.text.y = quadrant.y + this.config.quadrantTextTopPadding; + quadrant.text.horizontalPos = "top"; + } + } + return quadrants; + } + getQuadrantPoints(spaceData) { + const { quadrantSpace } = spaceData; + const { quadrantHeight, quadrantLeft, quadrantTop, quadrantWidth } = quadrantSpace; + const xAxis = linear().domain([0, 1]).range([quadrantLeft, quadrantWidth + quadrantLeft]); + const yAxis = linear().domain([0, 1]).range([quadrantHeight + quadrantTop, quadrantTop]); + const points = this.data.points.map((point) => { + const props = { + x: xAxis(point.x), + y: yAxis(point.y), + fill: this.themeConfig.quadrantPointFill, + radius: this.config.pointRadius, + text: { + text: point.text, + fill: this.themeConfig.quadrantPointTextFill, + x: xAxis(point.x), + y: yAxis(point.y) + this.config.pointTextPadding, + verticalPos: "center", + horizontalPos: "top", + fontSize: this.config.pointLabelFontSize, + rotation: 0 + } + }; + return props; + }); + return points; + } + getBorders(spaceData) { + const halfExternalBorderWidth = this.config.quadrantExternalBorderStrokeWidth / 2; + const { quadrantSpace } = spaceData; + const { + quadrantHalfHeight, + quadrantHeight, + quadrantLeft, + quadrantHalfWidth, + quadrantTop, + quadrantWidth + } = quadrantSpace; + const borderLines = [ + // top border + { + strokeFill: this.themeConfig.quadrantExternalBorderStrokeFill, + strokeWidth: this.config.quadrantExternalBorderStrokeWidth, + x1: quadrantLeft - halfExternalBorderWidth, + y1: quadrantTop, + x2: quadrantLeft + quadrantWidth + halfExternalBorderWidth, + y2: quadrantTop + }, + // right border + { + strokeFill: this.themeConfig.quadrantExternalBorderStrokeFill, + strokeWidth: this.config.quadrantExternalBorderStrokeWidth, + x1: quadrantLeft + quadrantWidth, + y1: quadrantTop + halfExternalBorderWidth, + x2: quadrantLeft + quadrantWidth, + y2: quadrantTop + quadrantHeight - halfExternalBorderWidth + }, + // bottom border + { + strokeFill: this.themeConfig.quadrantExternalBorderStrokeFill, + strokeWidth: this.config.quadrantExternalBorderStrokeWidth, + x1: quadrantLeft - halfExternalBorderWidth, + y1: quadrantTop + quadrantHeight, + x2: quadrantLeft + quadrantWidth + halfExternalBorderWidth, + y2: quadrantTop + quadrantHeight + }, + // left border + { + strokeFill: this.themeConfig.quadrantExternalBorderStrokeFill, + strokeWidth: this.config.quadrantExternalBorderStrokeWidth, + x1: quadrantLeft, + y1: quadrantTop + halfExternalBorderWidth, + x2: quadrantLeft, + y2: quadrantTop + quadrantHeight - halfExternalBorderWidth + }, + // vertical inner border + { + strokeFill: this.themeConfig.quadrantInternalBorderStrokeFill, + strokeWidth: this.config.quadrantInternalBorderStrokeWidth, + x1: quadrantLeft + quadrantHalfWidth, + y1: quadrantTop + halfExternalBorderWidth, + x2: quadrantLeft + quadrantHalfWidth, + y2: quadrantTop + quadrantHeight - halfExternalBorderWidth + }, + // horizontal inner border + { + strokeFill: this.themeConfig.quadrantInternalBorderStrokeFill, + strokeWidth: this.config.quadrantInternalBorderStrokeWidth, + x1: quadrantLeft + halfExternalBorderWidth, + y1: quadrantTop + quadrantHalfHeight, + x2: quadrantLeft + quadrantWidth - halfExternalBorderWidth, + y2: quadrantTop + quadrantHalfHeight + } + ]; + return borderLines; + } + getTitle(showTitle) { + if (showTitle) { + return { + text: this.data.titleText, + fill: this.themeConfig.quadrantTitleFill, + fontSize: this.config.titleFontSize, + horizontalPos: "top", + verticalPos: "center", + rotation: 0, + y: this.config.titlePadding, + x: this.config.chartWidth / 2 + }; + } + return; + } + build() { + const showXAxis = this.config.showXAxis && !!(this.data.xAxisLeftText || this.data.xAxisRightText); + const showYAxis = this.config.showYAxis && !!(this.data.yAxisTopText || this.data.yAxisBottomText); + const showTitle = this.config.showTitle && !!this.data.titleText; + const xAxisPosition = this.data.points.length > 0 ? "bottom" : this.config.xAxisPosition; + const calculatedSpace = this.calculateSpace(xAxisPosition, showXAxis, showYAxis, showTitle); + return { + points: this.getQuadrantPoints(calculatedSpace), + quadrants: this.getQuadrants(calculatedSpace), + axisLabels: this.getAxisLabels(xAxisPosition, showXAxis, showYAxis, calculatedSpace), + borderLines: this.getBorders(calculatedSpace), + title: this.getTitle(showTitle) + }; + } +} +const config = getConfig(); +function textSanitizer(text) { + return sanitizeText(text.trim(), config); +} +const quadrantBuilder = new QuadrantBuilder(); +function setQuadrant1Text(textObj) { + quadrantBuilder.setData({ quadrant1Text: textSanitizer(textObj.text) }); +} +function setQuadrant2Text(textObj) { + quadrantBuilder.setData({ quadrant2Text: textSanitizer(textObj.text) }); +} +function setQuadrant3Text(textObj) { + quadrantBuilder.setData({ quadrant3Text: textSanitizer(textObj.text) }); +} +function setQuadrant4Text(textObj) { + quadrantBuilder.setData({ quadrant4Text: textSanitizer(textObj.text) }); +} +function setXAxisLeftText(textObj) { + quadrantBuilder.setData({ xAxisLeftText: textSanitizer(textObj.text) }); +} +function setXAxisRightText(textObj) { + quadrantBuilder.setData({ xAxisRightText: textSanitizer(textObj.text) }); +} +function setYAxisTopText(textObj) { + quadrantBuilder.setData({ yAxisTopText: textSanitizer(textObj.text) }); +} +function setYAxisBottomText(textObj) { + quadrantBuilder.setData({ yAxisBottomText: textSanitizer(textObj.text) }); +} +function addPoint(textObj, x, y) { + quadrantBuilder.addPoints([{ x, y, text: textSanitizer(textObj.text) }]); +} +function setWidth(width) { + quadrantBuilder.setConfig({ chartWidth: width }); +} +function setHeight(height) { + quadrantBuilder.setConfig({ chartHeight: height }); +} +function getQuadrantData() { + const config2 = getConfig(); + const { themeVariables, quadrantChart: quadrantChartConfig } = config2; + if (quadrantChartConfig) { + quadrantBuilder.setConfig(quadrantChartConfig); + } + quadrantBuilder.setThemeConfig({ + quadrant1Fill: themeVariables.quadrant1Fill, + quadrant2Fill: themeVariables.quadrant2Fill, + quadrant3Fill: themeVariables.quadrant3Fill, + quadrant4Fill: themeVariables.quadrant4Fill, + quadrant1TextFill: themeVariables.quadrant1TextFill, + quadrant2TextFill: themeVariables.quadrant2TextFill, + quadrant3TextFill: themeVariables.quadrant3TextFill, + quadrant4TextFill: themeVariables.quadrant4TextFill, + quadrantPointFill: themeVariables.quadrantPointFill, + quadrantPointTextFill: themeVariables.quadrantPointTextFill, + quadrantXAxisTextFill: themeVariables.quadrantXAxisTextFill, + quadrantYAxisTextFill: themeVariables.quadrantYAxisTextFill, + quadrantExternalBorderStrokeFill: themeVariables.quadrantExternalBorderStrokeFill, + quadrantInternalBorderStrokeFill: themeVariables.quadrantInternalBorderStrokeFill, + quadrantTitleFill: themeVariables.quadrantTitleFill + }); + quadrantBuilder.setData({ titleText: getDiagramTitle() }); + return quadrantBuilder.build(); +} +const clear = function() { + quadrantBuilder.clear(); + clear$1(); +}; +const db = { + setWidth, + setHeight, + setQuadrant1Text, + setQuadrant2Text, + setQuadrant3Text, + setQuadrant4Text, + setXAxisLeftText, + setXAxisRightText, + setYAxisTopText, + setYAxisBottomText, + addPoint, + getQuadrantData, + clear, + setAccTitle, + getAccTitle, + setDiagramTitle, + getDiagramTitle, + getAccDescription, + setAccDescription +}; +const draw = (txt, id, _version, diagObj) => { + var _a, _b, _c; + function getDominantBaseLine(horizontalPos) { + return horizontalPos === "top" ? "hanging" : "middle"; + } + function getTextAnchor(verticalPos) { + return verticalPos === "left" ? "start" : "middle"; + } + function getTransformation(data) { + return `translate(${data.x}, ${data.y}) rotate(${data.rotation || 0})`; + } + const conf = getConfig(); + log.debug("Rendering quadrant chart\n" + txt); + const securityLevel = conf.securityLevel; + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = d3select("#i" + id); + } + const root = securityLevel === "sandbox" ? d3select(sandboxElement.nodes()[0].contentDocument.body) : d3select("body"); + const svg = root.select(`[id="${id}"]`); + const group = svg.append("g").attr("class", "main"); + const width = ((_a = conf.quadrantChart) == null ? void 0 : _a.chartWidth) || 500; + const height = ((_b = conf.quadrantChart) == null ? void 0 : _b.chartHeight) || 500; + configureSvgSize(svg, height, width, ((_c = conf.quadrantChart) == null ? void 0 : _c.useMaxWidth) || true); + svg.attr("viewBox", "0 0 " + width + " " + height); + diagObj.db.setHeight(height); + diagObj.db.setWidth(width); + const quadrantData = diagObj.db.getQuadrantData(); + const quadrantsGroup = group.append("g").attr("class", "quadrants"); + const borderGroup = group.append("g").attr("class", "border"); + const dataPointGroup = group.append("g").attr("class", "data-points"); + const labelGroup = group.append("g").attr("class", "labels"); + const titleGroup = group.append("g").attr("class", "title"); + if (quadrantData.title) { + titleGroup.append("text").attr("x", 0).attr("y", 0).attr("fill", quadrantData.title.fill).attr("font-size", quadrantData.title.fontSize).attr("dominant-baseline", getDominantBaseLine(quadrantData.title.horizontalPos)).attr("text-anchor", getTextAnchor(quadrantData.title.verticalPos)).attr("transform", getTransformation(quadrantData.title)).text(quadrantData.title.text); + } + if (quadrantData.borderLines) { + borderGroup.selectAll("line").data(quadrantData.borderLines).enter().append("line").attr("x1", (data) => data.x1).attr("y1", (data) => data.y1).attr("x2", (data) => data.x2).attr("y2", (data) => data.y2).style("stroke", (data) => data.strokeFill).style("stroke-width", (data) => data.strokeWidth); + } + const quadrants = quadrantsGroup.selectAll("g.quadrant").data(quadrantData.quadrants).enter().append("g").attr("class", "quadrant"); + quadrants.append("rect").attr("x", (data) => data.x).attr("y", (data) => data.y).attr("width", (data) => data.width).attr("height", (data) => data.height).attr("fill", (data) => data.fill); + quadrants.append("text").attr("x", 0).attr("y", 0).attr("fill", (data) => data.text.fill).attr("font-size", (data) => data.text.fontSize).attr( + "dominant-baseline", + (data) => getDominantBaseLine(data.text.horizontalPos) + ).attr("text-anchor", (data) => getTextAnchor(data.text.verticalPos)).attr("transform", (data) => getTransformation(data.text)).text((data) => data.text.text); + const labels = labelGroup.selectAll("g.label").data(quadrantData.axisLabels).enter().append("g").attr("class", "label"); + labels.append("text").attr("x", 0).attr("y", 0).text((data) => data.text).attr("fill", (data) => data.fill).attr("font-size", (data) => data.fontSize).attr("dominant-baseline", (data) => getDominantBaseLine(data.horizontalPos)).attr("text-anchor", (data) => getTextAnchor(data.verticalPos)).attr("transform", (data) => getTransformation(data)); + const dataPoints = dataPointGroup.selectAll("g.data-point").data(quadrantData.points).enter().append("g").attr("class", "data-point"); + dataPoints.append("circle").attr("cx", (data) => data.x).attr("cy", (data) => data.y).attr("r", (data) => data.radius).attr("fill", (data) => data.fill); + dataPoints.append("text").attr("x", 0).attr("y", 0).text((data) => data.text.text).attr("fill", (data) => data.text.fill).attr("font-size", (data) => data.text.fontSize).attr( + "dominant-baseline", + (data) => getDominantBaseLine(data.text.horizontalPos) + ).attr("text-anchor", (data) => getTextAnchor(data.text.verticalPos)).attr("transform", (data) => getTransformation(data.text)); +}; +const renderer = { + draw +}; +const diagram = { + parser: parser$1, + db, + renderer, + styles: () => "" +}; +export { + diagram +}; diff --git a/0.6.0/js/mermaid/quadrantDiagram-5fa00455.js b/0.6.0/js/mermaid/quadrantDiagram-5fa00455.js new file mode 100644 index 0000000..8b93854 --- /dev/null +++ b/0.6.0/js/mermaid/quadrantDiagram-5fa00455.js @@ -0,0 +1,904 @@ +import { Z as vt, W as E, l as lt, s as Lt, g as Ct, C as zt, D as bt, a as Et, b as Dt, c as yt, E as It, d as Bt, j as gt, k as wt } from "./mermaid-9f2aa176.js"; +import { l as At } from "./linear-9bcf74c4.js"; +import "./init-f9637058.js"; +var pt = function() { + var e = function($, n, r, o) { + for (r = r || {}, o = $.length; o--; r[$[o]] = n) + ; + return r; + }, s = [1, 3], c = [1, 4], x = [1, 5], f = [1, 6], d = [1, 7], l = [1, 5, 13, 15, 17, 19, 20, 25, 27, 28, 29, 30, 31, 32, 33, 34, 37, 38, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50], g = [1, 5, 6, 13, 15, 17, 19, 20, 25, 27, 28, 29, 30, 31, 32, 33, 34, 37, 38, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50], i = [32, 33, 34], q = [2, 7], b = [1, 13], D = [1, 17], w = [1, 18], I = [1, 19], B = [1, 20], p = [1, 21], H = [1, 22], G = [1, 23], K = [1, 24], at = [1, 25], nt = [1, 26], et = [1, 27], Q = [1, 30], N = [1, 31], T = [1, 32], m = [1, 33], A = [1, 34], t = [1, 35], _ = [1, 36], S = [1, 37], k = [1, 38], F = [1, 39], P = [1, 40], v = [1, 41], L = [1, 42], M = [1, 57], X = [1, 58], C = [5, 22, 26, 32, 33, 34, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51], ht = { + trace: function() { + }, + yy: {}, + symbols_: { error: 2, start: 3, eol: 4, SPACE: 5, QUADRANT: 6, document: 7, line: 8, statement: 9, axisDetails: 10, quadrantDetails: 11, points: 12, title: 13, title_value: 14, acc_title: 15, acc_title_value: 16, acc_descr: 17, acc_descr_value: 18, acc_descr_multiline_value: 19, section: 20, text: 21, point_start: 22, point_x: 23, point_y: 24, "X-AXIS": 25, "AXIS-TEXT-DELIMITER": 26, "Y-AXIS": 27, QUADRANT_1: 28, QUADRANT_2: 29, QUADRANT_3: 30, QUADRANT_4: 31, NEWLINE: 32, SEMI: 33, EOF: 34, alphaNumToken: 35, textNoTagsToken: 36, STR: 37, MD_STR: 38, alphaNum: 39, PUNCTUATION: 40, AMP: 41, NUM: 42, ALPHA: 43, COMMA: 44, PLUS: 45, EQUALS: 46, MULT: 47, DOT: 48, BRKT: 49, UNDERSCORE: 50, MINUS: 51, $accept: 0, $end: 1 }, + terminals_: { 2: "error", 5: "SPACE", 6: "QUADRANT", 13: "title", 14: "title_value", 15: "acc_title", 16: "acc_title_value", 17: "acc_descr", 18: "acc_descr_value", 19: "acc_descr_multiline_value", 20: "section", 22: "point_start", 23: "point_x", 24: "point_y", 25: "X-AXIS", 26: "AXIS-TEXT-DELIMITER", 27: "Y-AXIS", 28: "QUADRANT_1", 29: "QUADRANT_2", 30: "QUADRANT_3", 31: "QUADRANT_4", 32: "NEWLINE", 33: "SEMI", 34: "EOF", 37: "STR", 38: "MD_STR", 40: "PUNCTUATION", 41: "AMP", 42: "NUM", 43: "ALPHA", 44: "COMMA", 45: "PLUS", 46: "EQUALS", 47: "MULT", 48: "DOT", 49: "BRKT", 50: "UNDERSCORE", 51: "MINUS" }, + productions_: [0, [3, 2], [3, 2], [3, 2], [7, 0], [7, 2], [8, 2], [9, 0], [9, 2], [9, 1], [9, 1], [9, 1], [9, 2], [9, 2], [9, 2], [9, 1], [9, 1], [12, 4], [10, 4], [10, 3], [10, 2], [10, 4], [10, 3], [10, 2], [11, 2], [11, 2], [11, 2], [11, 2], [4, 1], [4, 1], [4, 1], [21, 1], [21, 2], [21, 1], [21, 1], [39, 1], [39, 2], [35, 1], [35, 1], [35, 1], [35, 1], [35, 1], [35, 1], [35, 1], [35, 1], [35, 1], [35, 1], [35, 1], [36, 1], [36, 1], [36, 1]], + performAction: function(n, r, o, h, y, a, it) { + var u = a.length - 1; + switch (y) { + case 12: + this.$ = a[u].trim(), h.setDiagramTitle(this.$); + break; + case 13: + this.$ = a[u].trim(), h.setAccTitle(this.$); + break; + case 14: + case 15: + this.$ = a[u].trim(), h.setAccDescription(this.$); + break; + case 16: + h.addSection(a[u].substr(8)), this.$ = a[u].substr(8); + break; + case 17: + h.addPoint(a[u - 3], a[u - 1], a[u]); + break; + case 18: + h.setXAxisLeftText(a[u - 2]), h.setXAxisRightText(a[u]); + break; + case 19: + a[u - 1].text += " ⟶ ", h.setXAxisLeftText(a[u - 1]); + break; + case 20: + h.setXAxisLeftText(a[u]); + break; + case 21: + h.setYAxisBottomText(a[u - 2]), h.setYAxisTopText(a[u]); + break; + case 22: + a[u - 1].text += " ⟶ ", h.setYAxisBottomText(a[u - 1]); + break; + case 23: + h.setYAxisBottomText(a[u]); + break; + case 24: + h.setQuadrant1Text(a[u]); + break; + case 25: + h.setQuadrant2Text(a[u]); + break; + case 26: + h.setQuadrant3Text(a[u]); + break; + case 27: + h.setQuadrant4Text(a[u]); + break; + case 31: + this.$ = { text: a[u], type: "text" }; + break; + case 32: + this.$ = { text: a[u - 1].text + "" + a[u], type: a[u - 1].type }; + break; + case 33: + this.$ = { text: a[u], type: "text" }; + break; + case 34: + this.$ = { text: a[u], type: "markdown" }; + break; + case 35: + this.$ = a[u]; + break; + case 36: + this.$ = a[u - 1] + "" + a[u]; + break; + } + }, + table: [{ 3: 1, 4: 2, 5: s, 6: c, 32: x, 33: f, 34: d }, { 1: [3] }, { 3: 8, 4: 2, 5: s, 6: c, 32: x, 33: f, 34: d }, { 3: 9, 4: 2, 5: s, 6: c, 32: x, 33: f, 34: d }, e(l, [2, 4], { 7: 10 }), e(g, [2, 28]), e(g, [2, 29]), e(g, [2, 30]), { 1: [2, 1] }, { 1: [2, 2] }, e(i, q, { 8: 11, 9: 12, 10: 14, 11: 15, 12: 16, 21: 28, 35: 29, 1: [2, 3], 5: b, 13: D, 15: w, 17: I, 19: B, 20: p, 25: H, 27: G, 28: K, 29: at, 30: nt, 31: et, 37: Q, 38: N, 40: T, 41: m, 42: A, 43: t, 44: _, 45: S, 46: k, 47: F, 48: P, 49: v, 50: L }), e(l, [2, 5]), { 4: 43, 32: x, 33: f, 34: d }, e(i, q, { 10: 14, 11: 15, 12: 16, 21: 28, 35: 29, 9: 44, 5: b, 13: D, 15: w, 17: I, 19: B, 20: p, 25: H, 27: G, 28: K, 29: at, 30: nt, 31: et, 37: Q, 38: N, 40: T, 41: m, 42: A, 43: t, 44: _, 45: S, 46: k, 47: F, 48: P, 49: v, 50: L }), e(i, [2, 9]), e(i, [2, 10]), e(i, [2, 11]), { 14: [1, 45] }, { 16: [1, 46] }, { 18: [1, 47] }, e(i, [2, 15]), e(i, [2, 16]), { 21: 48, 35: 29, 37: Q, 38: N, 40: T, 41: m, 42: A, 43: t, 44: _, 45: S, 46: k, 47: F, 48: P, 49: v, 50: L }, { 21: 49, 35: 29, 37: Q, 38: N, 40: T, 41: m, 42: A, 43: t, 44: _, 45: S, 46: k, 47: F, 48: P, 49: v, 50: L }, { 21: 50, 35: 29, 37: Q, 38: N, 40: T, 41: m, 42: A, 43: t, 44: _, 45: S, 46: k, 47: F, 48: P, 49: v, 50: L }, { 21: 51, 35: 29, 37: Q, 38: N, 40: T, 41: m, 42: A, 43: t, 44: _, 45: S, 46: k, 47: F, 48: P, 49: v, 50: L }, { 21: 52, 35: 29, 37: Q, 38: N, 40: T, 41: m, 42: A, 43: t, 44: _, 45: S, 46: k, 47: F, 48: P, 49: v, 50: L }, { 21: 53, 35: 29, 37: Q, 38: N, 40: T, 41: m, 42: A, 43: t, 44: _, 45: S, 46: k, 47: F, 48: P, 49: v, 50: L }, { 5: M, 22: [1, 54], 35: 56, 36: 55, 40: T, 41: m, 42: A, 43: t, 44: _, 45: S, 46: k, 47: F, 48: P, 49: v, 50: L, 51: X }, e(C, [2, 31]), e(C, [2, 33]), e(C, [2, 34]), e(C, [2, 37]), e(C, [2, 38]), e(C, [2, 39]), e(C, [2, 40]), e(C, [2, 41]), e(C, [2, 42]), e(C, [2, 43]), e(C, [2, 44]), e(C, [2, 45]), e(C, [2, 46]), e(C, [2, 47]), e(l, [2, 6]), e(i, [2, 8]), e(i, [2, 12]), e(i, [2, 13]), e(i, [2, 14]), e(i, [2, 20], { 36: 55, 35: 56, 5: M, 26: [1, 59], 40: T, 41: m, 42: A, 43: t, 44: _, 45: S, 46: k, 47: F, 48: P, 49: v, 50: L, 51: X }), e(i, [2, 23], { 36: 55, 35: 56, 5: M, 26: [1, 60], 40: T, 41: m, 42: A, 43: t, 44: _, 45: S, 46: k, 47: F, 48: P, 49: v, 50: L, 51: X }), e(i, [2, 24], { 36: 55, 35: 56, 5: M, 40: T, 41: m, 42: A, 43: t, 44: _, 45: S, 46: k, 47: F, 48: P, 49: v, 50: L, 51: X }), e(i, [2, 25], { 36: 55, 35: 56, 5: M, 40: T, 41: m, 42: A, 43: t, 44: _, 45: S, 46: k, 47: F, 48: P, 49: v, 50: L, 51: X }), e(i, [2, 26], { 36: 55, 35: 56, 5: M, 40: T, 41: m, 42: A, 43: t, 44: _, 45: S, 46: k, 47: F, 48: P, 49: v, 50: L, 51: X }), e(i, [2, 27], { 36: 55, 35: 56, 5: M, 40: T, 41: m, 42: A, 43: t, 44: _, 45: S, 46: k, 47: F, 48: P, 49: v, 50: L, 51: X }), { 23: [1, 61] }, e(C, [2, 32]), e(C, [2, 48]), e(C, [2, 49]), e(C, [2, 50]), e(i, [2, 19], { 35: 29, 21: 62, 37: Q, 38: N, 40: T, 41: m, 42: A, 43: t, 44: _, 45: S, 46: k, 47: F, 48: P, 49: v, 50: L }), e(i, [2, 22], { 35: 29, 21: 63, 37: Q, 38: N, 40: T, 41: m, 42: A, 43: t, 44: _, 45: S, 46: k, 47: F, 48: P, 49: v, 50: L }), { 24: [1, 64] }, e(i, [2, 18], { 36: 55, 35: 56, 5: M, 40: T, 41: m, 42: A, 43: t, 44: _, 45: S, 46: k, 47: F, 48: P, 49: v, 50: L, 51: X }), e(i, [2, 21], { 36: 55, 35: 56, 5: M, 40: T, 41: m, 42: A, 43: t, 44: _, 45: S, 46: k, 47: F, 48: P, 49: v, 50: L, 51: X }), e(i, [2, 17])], + defaultActions: { 8: [2, 1], 9: [2, 2] }, + parseError: function(n, r) { + if (r.recoverable) + this.trace(n); + else { + var o = new Error(n); + throw o.hash = r, o; + } + }, + parse: function(n) { + var r = this, o = [0], h = [], y = [null], a = [], it = this.table, u = "", st = 0, qt = 0, St = 2, Tt = 1, kt = a.slice.call(arguments, 1), z = Object.create(this.lexer), Z = { yy: {} }; + for (var dt in this.yy) + Object.prototype.hasOwnProperty.call(this.yy, dt) && (Z.yy[dt] = this.yy[dt]); + z.setInput(n, Z.yy), Z.yy.lexer = z, Z.yy.parser = this, typeof z.yylloc > "u" && (z.yylloc = {}); + var ut = z.yylloc; + a.push(ut); + var Ft = z.options && z.options.ranges; + typeof Z.yy.parseError == "function" ? this.parseError = Z.yy.parseError : this.parseError = Object.getPrototypeOf(this).parseError; + function Pt() { + var Y; + return Y = h.pop() || z.lex() || Tt, typeof Y != "number" && (Y instanceof Array && (h = Y, Y = h.pop()), Y = r.symbols_[Y] || Y), Y; + } + for (var W, J, U, xt, tt = {}, rt, O, mt, ot; ; ) { + if (J = o[o.length - 1], this.defaultActions[J] ? U = this.defaultActions[J] : ((W === null || typeof W > "u") && (W = Pt()), U = it[J] && it[J][W]), typeof U > "u" || !U.length || !U[0]) { + var ft = ""; + ot = []; + for (rt in it[J]) + this.terminals_[rt] && rt > St && ot.push("'" + this.terminals_[rt] + "'"); + z.showPosition ? ft = "Parse error on line " + (st + 1) + `: +` + z.showPosition() + ` +Expecting ` + ot.join(", ") + ", got '" + (this.terminals_[W] || W) + "'" : ft = "Parse error on line " + (st + 1) + ": Unexpected " + (W == Tt ? "end of input" : "'" + (this.terminals_[W] || W) + "'"), this.parseError(ft, { + text: z.match, + token: this.terminals_[W] || W, + line: z.yylineno, + loc: ut, + expected: ot + }); + } + if (U[0] instanceof Array && U.length > 1) + throw new Error("Parse Error: multiple actions possible at state: " + J + ", token: " + W); + switch (U[0]) { + case 1: + o.push(W), y.push(z.yytext), a.push(z.yylloc), o.push(U[1]), W = null, qt = z.yyleng, u = z.yytext, st = z.yylineno, ut = z.yylloc; + break; + case 2: + if (O = this.productions_[U[1]][1], tt.$ = y[y.length - O], tt._$ = { + first_line: a[a.length - (O || 1)].first_line, + last_line: a[a.length - 1].last_line, + first_column: a[a.length - (O || 1)].first_column, + last_column: a[a.length - 1].last_column + }, Ft && (tt._$.range = [ + a[a.length - (O || 1)].range[0], + a[a.length - 1].range[1] + ]), xt = this.performAction.apply(tt, [ + u, + qt, + st, + Z.yy, + U[1], + y, + a + ].concat(kt)), typeof xt < "u") + return xt; + O && (o = o.slice(0, -1 * O * 2), y = y.slice(0, -1 * O), a = a.slice(0, -1 * O)), o.push(this.productions_[U[1]][0]), y.push(tt.$), a.push(tt._$), mt = it[o[o.length - 2]][o[o.length - 1]], o.push(mt); + break; + case 3: + return !0; + } + } + return !0; + } + }, _t = function() { + var $ = { + EOF: 1, + parseError: function(r, o) { + if (this.yy.parser) + this.yy.parser.parseError(r, o); + else + throw new Error(r); + }, + // resets the lexer, sets new input + setInput: function(n, r) { + return this.yy = r || this.yy || {}, this._input = n, 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 n = this._input[0]; + this.yytext += n, this.yyleng++, this.offset++, this.match += n, this.matched += n; + var r = n.match(/(?:\r\n?|\n).*/g); + return r ? (this.yylineno++, this.yylloc.last_line++) : this.yylloc.last_column++, this.options.ranges && this.yylloc.range[1]++, this._input = this._input.slice(1), n; + }, + // unshifts one char (or a string) into the input + unput: function(n) { + var r = n.length, o = n.split(/(?:\r\n?|\n)/g); + this._input = n + this._input, this.yytext = this.yytext.substr(0, this.yytext.length - r), this.offset -= r; + var h = 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), o.length - 1 && (this.yylineno -= o.length - 1); + var y = 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: o ? (o.length === h.length ? this.yylloc.first_column : 0) + h[h.length - o.length].length - o[0].length : this.yylloc.first_column - r + }, this.options.ranges && (this.yylloc.range = [y[0], y[0] + this.yyleng - r]), 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(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var n = this.matched.substr(0, this.matched.length - this.match.length); + return (n.length > 20 ? "..." : "") + n.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var n = this.match; + return n.length < 20 && (n += this._input.substr(0, 20 - n.length)), (n.substr(0, 20) + (n.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var n = this.pastInput(), r = new Array(n.length + 1).join("-"); + return n + this.upcomingInput() + ` +` + r + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(n, r) { + var o, h, y; + if (this.options.backtrack_lexer && (y = { + 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 && (y.yylloc.range = this.yylloc.range.slice(0))), h = n[0].match(/(?:\r\n?|\n).*/g), h && (this.yylineno += h.length), this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: h ? h[h.length - 1].length - h[h.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + n[0].length + }, this.yytext += n[0], this.match += n[0], this.matches = n, 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(n[0].length), this.matched += n[0], o = this.performAction.call(this, this.yy, this, r, this.conditionStack[this.conditionStack.length - 1]), this.done && this._input && (this.done = !1), o) + return o; + if (this._backtrack) { + for (var a in y) + this[a] = y[a]; + return !1; + } + return !1; + }, + // return next match in input + next: function() { + if (this.done) + return this.EOF; + this._input || (this.done = !0); + var n, r, o, h; + this._more || (this.yytext = "", this.match = ""); + for (var y = this._currentRules(), a = 0; a < y.length; a++) + if (o = this._input.match(this.rules[y[a]]), o && (!r || o[0].length > r[0].length)) { + if (r = o, h = a, this.options.backtrack_lexer) { + if (n = this.test_match(o, y[a]), n !== !1) + return n; + if (this._backtrack) { + r = !1; + continue; + } else + return !1; + } else if (!this.options.flex) + break; + } + return r ? (n = this.test_match(r, y[h]), n !== !1 ? n : !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 r = this.next(); + return r || this.lex(); + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function(r) { + this.conditionStack.push(r); + }, + // pop the previously active lexer condition state off the condition stack + popState: function() { + var r = this.conditionStack.length - 1; + return r > 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(r) { + return r = this.conditionStack.length - 1 - Math.abs(r || 0), r >= 0 ? this.conditionStack[r] : "INITIAL"; + }, + // alias for begin(condition) + pushState: function(r) { + this.begin(r); + }, + // return the number of states currently on the stack + stateStackSize: function() { + return this.conditionStack.length; + }, + options: { "case-insensitive": !0 }, + performAction: function(r, o, h, y) { + switch (h) { + case 0: + break; + case 1: + break; + case 2: + return 32; + case 3: + break; + case 4: + return this.begin("title"), 13; + case 5: + return this.popState(), "title_value"; + case 6: + return this.begin("acc_title"), 15; + case 7: + return this.popState(), "acc_title_value"; + case 8: + return this.begin("acc_descr"), 17; + case 9: + return this.popState(), "acc_descr_value"; + case 10: + this.begin("acc_descr_multiline"); + break; + case 11: + this.popState(); + break; + case 12: + return "acc_descr_multiline_value"; + case 13: + return 25; + case 14: + return 27; + case 15: + return 26; + case 16: + return 28; + case 17: + return 29; + case 18: + return 30; + case 19: + return 31; + case 20: + this.begin("md_string"); + break; + case 21: + return "MD_STR"; + case 22: + this.popState(); + break; + case 23: + this.begin("string"); + break; + case 24: + this.popState(); + break; + case 25: + return "STR"; + case 26: + return this.begin("point_start"), 22; + case 27: + return this.begin("point_x"), 23; + case 28: + this.popState(); + break; + case 29: + this.popState(), this.begin("point_y"); + break; + case 30: + return this.popState(), 24; + case 31: + return 6; + case 32: + return 43; + case 33: + return "COLON"; + case 34: + return 45; + case 35: + return 44; + case 36: + return 46; + case 37: + return 46; + case 38: + return 47; + case 39: + return 49; + case 40: + return 50; + case 41: + return 48; + case 42: + return 41; + case 43: + return 51; + case 44: + return 42; + case 45: + return 5; + case 46: + return 33; + case 47: + return 40; + case 48: + return 34; + } + }, + rules: [/^(?:%%(?!\{)[^\n]*)/i, /^(?:[^\}]%%[^\n]*)/i, /^(?:[\n\r]+)/i, /^(?:%%[^\n]*)/i, /^(?:title\b)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accTitle\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*\{\s*)/i, /^(?:[\}])/i, /^(?:[^\}]*)/i, /^(?: *x-axis *)/i, /^(?: *y-axis *)/i, /^(?: *--+> *)/i, /^(?: *quadrant-1 *)/i, /^(?: *quadrant-2 *)/i, /^(?: *quadrant-3 *)/i, /^(?: *quadrant-4 *)/i, /^(?:["][`])/i, /^(?:[^`"]+)/i, /^(?:[`]["])/i, /^(?:["])/i, /^(?:["])/i, /^(?:[^"]*)/i, /^(?:\s*:\s*\[\s*)/i, /^(?:(1)|(0(.\d+)?))/i, /^(?:\s*\] *)/i, /^(?:\s*,\s*)/i, /^(?:(1)|(0(.\d+)?))/i, /^(?: *quadrantChart *)/i, /^(?:[A-Za-z]+)/i, /^(?::)/i, /^(?:\+)/i, /^(?:,)/i, /^(?:=)/i, /^(?:=)/i, /^(?:\*)/i, /^(?:#)/i, /^(?:[\_])/i, /^(?:\.)/i, /^(?:&)/i, /^(?:-)/i, /^(?:[0-9]+)/i, /^(?:\s)/i, /^(?:;)/i, /^(?:[!"#$%&'*+,-.`?\\_/])/i, /^(?:$)/i], + conditions: { point_y: { rules: [30], inclusive: !1 }, point_x: { rules: [29], inclusive: !1 }, point_start: { rules: [27, 28], inclusive: !1 }, acc_descr_multiline: { rules: [11, 12], inclusive: !1 }, acc_descr: { rules: [9], inclusive: !1 }, acc_title: { rules: [7], inclusive: !1 }, title: { rules: [5], inclusive: !1 }, md_string: { rules: [21, 22], inclusive: !1 }, string: { rules: [24, 25], inclusive: !1 }, INITIAL: { rules: [0, 1, 2, 3, 4, 6, 8, 10, 13, 14, 15, 16, 17, 18, 19, 20, 23, 26, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48], inclusive: !0 } } + }; + return $; + }(); + ht.lexer = _t; + function ct() { + this.yy = {}; + } + return ct.prototype = ht, ht.Parser = ct, new ct(); +}(); +pt.parser = pt; +const Rt = pt, V = vt(); +class Vt { + constructor() { + this.config = this.getDefaultConfig(), this.themeConfig = this.getDefaultThemeConfig(), this.data = this.getDefaultData(); + } + getDefaultData() { + return { + titleText: "", + quadrant1Text: "", + quadrant2Text: "", + quadrant3Text: "", + quadrant4Text: "", + xAxisLeftText: "", + xAxisRightText: "", + yAxisBottomText: "", + yAxisTopText: "", + points: [] + }; + } + getDefaultConfig() { + var s, c, x, f, d, l, g, i, q, b, D, w, I, B, p, H, G, K; + return { + showXAxis: !0, + showYAxis: !0, + showTitle: !0, + chartHeight: ((s = E.quadrantChart) == null ? void 0 : s.chartWidth) || 500, + chartWidth: ((c = E.quadrantChart) == null ? void 0 : c.chartHeight) || 500, + titlePadding: ((x = E.quadrantChart) == null ? void 0 : x.titlePadding) || 10, + titleFontSize: ((f = E.quadrantChart) == null ? void 0 : f.titleFontSize) || 20, + quadrantPadding: ((d = E.quadrantChart) == null ? void 0 : d.quadrantPadding) || 5, + xAxisLabelPadding: ((l = E.quadrantChart) == null ? void 0 : l.xAxisLabelPadding) || 5, + yAxisLabelPadding: ((g = E.quadrantChart) == null ? void 0 : g.yAxisLabelPadding) || 5, + xAxisLabelFontSize: ((i = E.quadrantChart) == null ? void 0 : i.xAxisLabelFontSize) || 16, + yAxisLabelFontSize: ((q = E.quadrantChart) == null ? void 0 : q.yAxisLabelFontSize) || 16, + quadrantLabelFontSize: ((b = E.quadrantChart) == null ? void 0 : b.quadrantLabelFontSize) || 16, + quadrantTextTopPadding: ((D = E.quadrantChart) == null ? void 0 : D.quadrantTextTopPadding) || 5, + pointTextPadding: ((w = E.quadrantChart) == null ? void 0 : w.pointTextPadding) || 5, + pointLabelFontSize: ((I = E.quadrantChart) == null ? void 0 : I.pointLabelFontSize) || 12, + pointRadius: ((B = E.quadrantChart) == null ? void 0 : B.pointRadius) || 5, + xAxisPosition: ((p = E.quadrantChart) == null ? void 0 : p.xAxisPosition) || "top", + yAxisPosition: ((H = E.quadrantChart) == null ? void 0 : H.yAxisPosition) || "left", + quadrantInternalBorderStrokeWidth: ((G = E.quadrantChart) == null ? void 0 : G.quadrantInternalBorderStrokeWidth) || 1, + quadrantExternalBorderStrokeWidth: ((K = E.quadrantChart) == null ? void 0 : K.quadrantExternalBorderStrokeWidth) || 2 + }; + } + getDefaultThemeConfig() { + return { + quadrant1Fill: V.quadrant1Fill, + quadrant2Fill: V.quadrant2Fill, + quadrant3Fill: V.quadrant3Fill, + quadrant4Fill: V.quadrant4Fill, + quadrant1TextFill: V.quadrant1TextFill, + quadrant2TextFill: V.quadrant2TextFill, + quadrant3TextFill: V.quadrant3TextFill, + quadrant4TextFill: V.quadrant4TextFill, + quadrantPointFill: V.quadrantPointFill, + quadrantPointTextFill: V.quadrantPointTextFill, + quadrantXAxisTextFill: V.quadrantXAxisTextFill, + quadrantYAxisTextFill: V.quadrantYAxisTextFill, + quadrantTitleFill: V.quadrantTitleFill, + quadrantInternalBorderStrokeFill: V.quadrantInternalBorderStrokeFill, + quadrantExternalBorderStrokeFill: V.quadrantExternalBorderStrokeFill + }; + } + clear() { + this.config = this.getDefaultConfig(), this.themeConfig = this.getDefaultThemeConfig(), this.data = this.getDefaultData(), lt.info("clear called"); + } + setData(s) { + this.data = { ...this.data, ...s }; + } + addPoints(s) { + this.data.points = [...s, ...this.data.points]; + } + setConfig(s) { + lt.trace("setConfig called with: ", s), this.config = { ...this.config, ...s }; + } + setThemeConfig(s) { + lt.trace("setThemeConfig called with: ", s), this.themeConfig = { ...this.themeConfig, ...s }; + } + calculateSpace(s, c, x, f) { + const d = this.config.xAxisLabelPadding * 2 + this.config.xAxisLabelFontSize, l = { + top: s === "top" && c ? d : 0, + bottom: s === "bottom" && c ? d : 0 + }, g = this.config.yAxisLabelPadding * 2 + this.config.yAxisLabelFontSize, i = { + left: this.config.yAxisPosition === "left" && x ? g : 0, + right: this.config.yAxisPosition === "right" && x ? g : 0 + }, q = this.config.titleFontSize + this.config.titlePadding * 2, b = { + top: f ? q : 0 + }, D = this.config.quadrantPadding + i.left, w = this.config.quadrantPadding + l.top + b.top, I = this.config.chartWidth - this.config.quadrantPadding * 2 - i.left - i.right, B = this.config.chartHeight - this.config.quadrantPadding * 2 - l.top - l.bottom - b.top, p = I / 2, H = B / 2; + return { + xAxisSpace: l, + yAxisSpace: i, + titleSpace: b, + quadrantSpace: { + quadrantLeft: D, + quadrantTop: w, + quadrantWidth: I, + quadrantHalfWidth: p, + quadrantHeight: B, + quadrantHalfHeight: H + } + }; + } + getAxisLabels(s, c, x, f) { + const { quadrantSpace: d, titleSpace: l } = f, { + quadrantHalfHeight: g, + quadrantHeight: i, + quadrantLeft: q, + quadrantHalfWidth: b, + quadrantTop: D, + quadrantWidth: w + } = d, I = !!this.data.xAxisRightText, B = !!this.data.yAxisTopText, p = []; + return this.data.xAxisLeftText && c && p.push({ + text: this.data.xAxisLeftText, + fill: this.themeConfig.quadrantXAxisTextFill, + x: q + (I ? b / 2 : 0), + y: s === "top" ? this.config.xAxisLabelPadding + l.top : this.config.xAxisLabelPadding + D + i + this.config.quadrantPadding, + fontSize: this.config.xAxisLabelFontSize, + verticalPos: I ? "center" : "left", + horizontalPos: "top", + rotation: 0 + }), this.data.xAxisRightText && c && p.push({ + text: this.data.xAxisRightText, + fill: this.themeConfig.quadrantXAxisTextFill, + x: q + b + (I ? b / 2 : 0), + y: s === "top" ? this.config.xAxisLabelPadding + l.top : this.config.xAxisLabelPadding + D + i + this.config.quadrantPadding, + fontSize: this.config.xAxisLabelFontSize, + verticalPos: I ? "center" : "left", + horizontalPos: "top", + rotation: 0 + }), this.data.yAxisBottomText && x && p.push({ + text: this.data.yAxisBottomText, + fill: this.themeConfig.quadrantYAxisTextFill, + x: this.config.yAxisPosition === "left" ? this.config.yAxisLabelPadding : this.config.yAxisLabelPadding + q + w + this.config.quadrantPadding, + y: D + i - (B ? g / 2 : 0), + fontSize: this.config.yAxisLabelFontSize, + verticalPos: B ? "center" : "left", + horizontalPos: "top", + rotation: -90 + }), this.data.yAxisTopText && x && p.push({ + text: this.data.yAxisTopText, + fill: this.themeConfig.quadrantYAxisTextFill, + x: this.config.yAxisPosition === "left" ? this.config.yAxisLabelPadding : this.config.yAxisLabelPadding + q + w + this.config.quadrantPadding, + y: D + g - (B ? g / 2 : 0), + fontSize: this.config.yAxisLabelFontSize, + verticalPos: B ? "center" : "left", + horizontalPos: "top", + rotation: -90 + }), p; + } + getQuadrants(s) { + const { quadrantSpace: c } = s, { quadrantHalfHeight: x, quadrantLeft: f, quadrantHalfWidth: d, quadrantTop: l } = c, g = [ + { + text: { + text: this.data.quadrant1Text, + fill: this.themeConfig.quadrant1TextFill, + x: 0, + y: 0, + fontSize: this.config.quadrantLabelFontSize, + verticalPos: "center", + horizontalPos: "middle", + rotation: 0 + }, + x: f + d, + y: l, + width: d, + height: x, + fill: this.themeConfig.quadrant1Fill + }, + { + text: { + text: this.data.quadrant2Text, + fill: this.themeConfig.quadrant2TextFill, + x: 0, + y: 0, + fontSize: this.config.quadrantLabelFontSize, + verticalPos: "center", + horizontalPos: "middle", + rotation: 0 + }, + x: f, + y: l, + width: d, + height: x, + fill: this.themeConfig.quadrant2Fill + }, + { + text: { + text: this.data.quadrant3Text, + fill: this.themeConfig.quadrant3TextFill, + x: 0, + y: 0, + fontSize: this.config.quadrantLabelFontSize, + verticalPos: "center", + horizontalPos: "middle", + rotation: 0 + }, + x: f, + y: l + x, + width: d, + height: x, + fill: this.themeConfig.quadrant3Fill + }, + { + text: { + text: this.data.quadrant4Text, + fill: this.themeConfig.quadrant4TextFill, + x: 0, + y: 0, + fontSize: this.config.quadrantLabelFontSize, + verticalPos: "center", + horizontalPos: "middle", + rotation: 0 + }, + x: f + d, + y: l + x, + width: d, + height: x, + fill: this.themeConfig.quadrant4Fill + } + ]; + for (const i of g) + i.text.x = i.x + i.width / 2, this.data.points.length === 0 ? (i.text.y = i.y + i.height / 2, i.text.horizontalPos = "middle") : (i.text.y = i.y + this.config.quadrantTextTopPadding, i.text.horizontalPos = "top"); + return g; + } + getQuadrantPoints(s) { + const { quadrantSpace: c } = s, { quadrantHeight: x, quadrantLeft: f, quadrantTop: d, quadrantWidth: l } = c, g = At().domain([0, 1]).range([f, l + f]), i = At().domain([0, 1]).range([x + d, d]); + return this.data.points.map((b) => ({ + x: g(b.x), + y: i(b.y), + fill: this.themeConfig.quadrantPointFill, + radius: this.config.pointRadius, + text: { + text: b.text, + fill: this.themeConfig.quadrantPointTextFill, + x: g(b.x), + y: i(b.y) + this.config.pointTextPadding, + verticalPos: "center", + horizontalPos: "top", + fontSize: this.config.pointLabelFontSize, + rotation: 0 + } + })); + } + getBorders(s) { + const c = this.config.quadrantExternalBorderStrokeWidth / 2, { quadrantSpace: x } = s, { + quadrantHalfHeight: f, + quadrantHeight: d, + quadrantLeft: l, + quadrantHalfWidth: g, + quadrantTop: i, + quadrantWidth: q + } = x; + return [ + // top border + { + strokeFill: this.themeConfig.quadrantExternalBorderStrokeFill, + strokeWidth: this.config.quadrantExternalBorderStrokeWidth, + x1: l - c, + y1: i, + x2: l + q + c, + y2: i + }, + // right border + { + strokeFill: this.themeConfig.quadrantExternalBorderStrokeFill, + strokeWidth: this.config.quadrantExternalBorderStrokeWidth, + x1: l + q, + y1: i + c, + x2: l + q, + y2: i + d - c + }, + // bottom border + { + strokeFill: this.themeConfig.quadrantExternalBorderStrokeFill, + strokeWidth: this.config.quadrantExternalBorderStrokeWidth, + x1: l - c, + y1: i + d, + x2: l + q + c, + y2: i + d + }, + // left border + { + strokeFill: this.themeConfig.quadrantExternalBorderStrokeFill, + strokeWidth: this.config.quadrantExternalBorderStrokeWidth, + x1: l, + y1: i + c, + x2: l, + y2: i + d - c + }, + // vertical inner border + { + strokeFill: this.themeConfig.quadrantInternalBorderStrokeFill, + strokeWidth: this.config.quadrantInternalBorderStrokeWidth, + x1: l + g, + y1: i + c, + x2: l + g, + y2: i + d - c + }, + // horizontal inner border + { + strokeFill: this.themeConfig.quadrantInternalBorderStrokeFill, + strokeWidth: this.config.quadrantInternalBorderStrokeWidth, + x1: l + c, + y1: i + f, + x2: l + q - c, + y2: i + f + } + ]; + } + getTitle(s) { + if (s) + return { + text: this.data.titleText, + fill: this.themeConfig.quadrantTitleFill, + fontSize: this.config.titleFontSize, + horizontalPos: "top", + verticalPos: "center", + rotation: 0, + y: this.config.titlePadding, + x: this.config.chartWidth / 2 + }; + } + build() { + const s = this.config.showXAxis && !!(this.data.xAxisLeftText || this.data.xAxisRightText), c = this.config.showYAxis && !!(this.data.yAxisTopText || this.data.yAxisBottomText), x = this.config.showTitle && !!this.data.titleText, f = this.data.points.length > 0 ? "bottom" : this.config.xAxisPosition, d = this.calculateSpace(f, s, c, x); + return { + points: this.getQuadrantPoints(d), + quadrants: this.getQuadrants(d), + axisLabels: this.getAxisLabels(f, s, c, d), + borderLines: this.getBorders(d), + title: this.getTitle(x) + }; + } +} +const Wt = yt(); +function j(e) { + return Bt(e.trim(), Wt); +} +const R = new Vt(); +function Nt(e) { + R.setData({ quadrant1Text: j(e.text) }); +} +function Ut(e) { + R.setData({ quadrant2Text: j(e.text) }); +} +function Qt(e) { + R.setData({ quadrant3Text: j(e.text) }); +} +function Ht(e) { + R.setData({ quadrant4Text: j(e.text) }); +} +function Mt(e) { + R.setData({ xAxisLeftText: j(e.text) }); +} +function Xt(e) { + R.setData({ xAxisRightText: j(e.text) }); +} +function Ot(e) { + R.setData({ yAxisTopText: j(e.text) }); +} +function Yt(e) { + R.setData({ yAxisBottomText: j(e.text) }); +} +function jt(e, s, c) { + R.addPoints([{ x: s, y: c, text: j(e.text) }]); +} +function Gt(e) { + R.setConfig({ chartWidth: e }); +} +function $t(e) { + R.setConfig({ chartHeight: e }); +} +function Kt() { + const e = yt(), { themeVariables: s, quadrantChart: c } = e; + return c && R.setConfig(c), R.setThemeConfig({ + quadrant1Fill: s.quadrant1Fill, + quadrant2Fill: s.quadrant2Fill, + quadrant3Fill: s.quadrant3Fill, + quadrant4Fill: s.quadrant4Fill, + quadrant1TextFill: s.quadrant1TextFill, + quadrant2TextFill: s.quadrant2TextFill, + quadrant3TextFill: s.quadrant3TextFill, + quadrant4TextFill: s.quadrant4TextFill, + quadrantPointFill: s.quadrantPointFill, + quadrantPointTextFill: s.quadrantPointTextFill, + quadrantXAxisTextFill: s.quadrantXAxisTextFill, + quadrantYAxisTextFill: s.quadrantYAxisTextFill, + quadrantExternalBorderStrokeFill: s.quadrantExternalBorderStrokeFill, + quadrantInternalBorderStrokeFill: s.quadrantInternalBorderStrokeFill, + quadrantTitleFill: s.quadrantTitleFill + }), R.setData({ titleText: bt() }), R.build(); +} +const Zt = function() { + R.clear(), It(); +}, Jt = { + setWidth: Gt, + setHeight: $t, + setQuadrant1Text: Nt, + setQuadrant2Text: Ut, + setQuadrant3Text: Qt, + setQuadrant4Text: Ht, + setXAxisLeftText: Mt, + setXAxisRightText: Xt, + setYAxisTopText: Ot, + setYAxisBottomText: Yt, + addPoint: jt, + getQuadrantData: Kt, + clear: Zt, + setAccTitle: Lt, + getAccTitle: Ct, + setDiagramTitle: zt, + getDiagramTitle: bt, + getAccDescription: Et, + setAccDescription: Dt +}, te = (e, s, c, x) => { + var T, m, A; + function f(t) { + return t === "top" ? "hanging" : "middle"; + } + function d(t) { + return t === "left" ? "start" : "middle"; + } + function l(t) { + return `translate(${t.x}, ${t.y}) rotate(${t.rotation || 0})`; + } + const g = yt(); + lt.debug(`Rendering quadrant chart +` + e); + const i = g.securityLevel; + let q; + i === "sandbox" && (q = gt("#i" + s)); + const D = (i === "sandbox" ? gt(q.nodes()[0].contentDocument.body) : gt("body")).select(`[id="${s}"]`), w = D.append("g").attr("class", "main"), I = ((T = g.quadrantChart) == null ? void 0 : T.chartWidth) || 500, B = ((m = g.quadrantChart) == null ? void 0 : m.chartHeight) || 500; + wt(D, B, I, ((A = g.quadrantChart) == null ? void 0 : A.useMaxWidth) || !0), D.attr("viewBox", "0 0 " + I + " " + B), x.db.setHeight(B), x.db.setWidth(I); + const p = x.db.getQuadrantData(), H = w.append("g").attr("class", "quadrants"), G = w.append("g").attr("class", "border"), K = w.append("g").attr("class", "data-points"), at = w.append("g").attr("class", "labels"), nt = w.append("g").attr("class", "title"); + p.title && nt.append("text").attr("x", 0).attr("y", 0).attr("fill", p.title.fill).attr("font-size", p.title.fontSize).attr("dominant-baseline", f(p.title.horizontalPos)).attr("text-anchor", d(p.title.verticalPos)).attr("transform", l(p.title)).text(p.title.text), p.borderLines && G.selectAll("line").data(p.borderLines).enter().append("line").attr("x1", (t) => t.x1).attr("y1", (t) => t.y1).attr("x2", (t) => t.x2).attr("y2", (t) => t.y2).style("stroke", (t) => t.strokeFill).style("stroke-width", (t) => t.strokeWidth); + const et = H.selectAll("g.quadrant").data(p.quadrants).enter().append("g").attr("class", "quadrant"); + et.append("rect").attr("x", (t) => t.x).attr("y", (t) => t.y).attr("width", (t) => t.width).attr("height", (t) => t.height).attr("fill", (t) => t.fill), et.append("text").attr("x", 0).attr("y", 0).attr("fill", (t) => t.text.fill).attr("font-size", (t) => t.text.fontSize).attr( + "dominant-baseline", + (t) => f(t.text.horizontalPos) + ).attr("text-anchor", (t) => d(t.text.verticalPos)).attr("transform", (t) => l(t.text)).text((t) => t.text.text), at.selectAll("g.label").data(p.axisLabels).enter().append("g").attr("class", "label").append("text").attr("x", 0).attr("y", 0).text((t) => t.text).attr("fill", (t) => t.fill).attr("font-size", (t) => t.fontSize).attr("dominant-baseline", (t) => f(t.horizontalPos)).attr("text-anchor", (t) => d(t.verticalPos)).attr("transform", (t) => l(t)); + const N = K.selectAll("g.data-point").data(p.points).enter().append("g").attr("class", "data-point"); + N.append("circle").attr("cx", (t) => t.x).attr("cy", (t) => t.y).attr("r", (t) => t.radius).attr("fill", (t) => t.fill), N.append("text").attr("x", 0).attr("y", 0).text((t) => t.text.text).attr("fill", (t) => t.text.fill).attr("font-size", (t) => t.text.fontSize).attr( + "dominant-baseline", + (t) => f(t.text.horizontalPos) + ).attr("text-anchor", (t) => d(t.text.verticalPos)).attr("transform", (t) => l(t.text)); +}, ee = { + draw: te +}, se = { + parser: Rt, + db: Jt, + renderer: ee, + styles: () => "" +}; +export { + se as diagram +}; diff --git a/0.6.0/js/mermaid/quadrantDiagram-c759a472.js b/0.6.0/js/mermaid/quadrantDiagram-c759a472.js new file mode 100644 index 0000000..6964be9 --- /dev/null +++ b/0.6.0/js/mermaid/quadrantDiagram-c759a472.js @@ -0,0 +1,1207 @@ +import { E as getThemeVariables, B as defaultConfig, l as log, s as setAccTitle, g as getAccTitle, q as setDiagramTitle, t as getDiagramTitle, a as getAccDescription, b as setAccDescription, c as getConfig, v as clear$1, d as sanitizeText, i as configureSvgSize } from "./mermaid-6dc72991.js"; +import { scaleLinear, select } from "d3"; +import "ts-dedent"; +import "dayjs"; +import "@braintree/sanitize-url"; +import "dompurify"; +import "khroma"; +import "lodash-es/memoize.js"; +import "lodash-es/merge.js"; +import "stylis"; +import "lodash-es/isEmpty.js"; +var parser = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 3], $V1 = [1, 4], $V2 = [1, 5], $V3 = [1, 6], $V4 = [1, 7], $V5 = [1, 5, 13, 15, 17, 19, 20, 25, 27, 28, 29, 30, 31, 32, 33, 34, 37, 38, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50], $V6 = [1, 5, 6, 13, 15, 17, 19, 20, 25, 27, 28, 29, 30, 31, 32, 33, 34, 37, 38, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50], $V7 = [32, 33, 34], $V8 = [2, 7], $V9 = [1, 13], $Va = [1, 17], $Vb = [1, 18], $Vc = [1, 19], $Vd = [1, 20], $Ve = [1, 21], $Vf = [1, 22], $Vg = [1, 23], $Vh = [1, 24], $Vi = [1, 25], $Vj = [1, 26], $Vk = [1, 27], $Vl = [1, 30], $Vm = [1, 31], $Vn = [1, 32], $Vo = [1, 33], $Vp = [1, 34], $Vq = [1, 35], $Vr = [1, 36], $Vs = [1, 37], $Vt = [1, 38], $Vu = [1, 39], $Vv = [1, 40], $Vw = [1, 41], $Vx = [1, 42], $Vy = [1, 57], $Vz = [1, 58], $VA = [5, 22, 26, 32, 33, 34, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "eol": 4, "SPACE": 5, "QUADRANT": 6, "document": 7, "line": 8, "statement": 9, "axisDetails": 10, "quadrantDetails": 11, "points": 12, "title": 13, "title_value": 14, "acc_title": 15, "acc_title_value": 16, "acc_descr": 17, "acc_descr_value": 18, "acc_descr_multiline_value": 19, "section": 20, "text": 21, "point_start": 22, "point_x": 23, "point_y": 24, "X-AXIS": 25, "AXIS-TEXT-DELIMITER": 26, "Y-AXIS": 27, "QUADRANT_1": 28, "QUADRANT_2": 29, "QUADRANT_3": 30, "QUADRANT_4": 31, "NEWLINE": 32, "SEMI": 33, "EOF": 34, "alphaNumToken": 35, "textNoTagsToken": 36, "STR": 37, "MD_STR": 38, "alphaNum": 39, "PUNCTUATION": 40, "AMP": 41, "NUM": 42, "ALPHA": 43, "COMMA": 44, "PLUS": 45, "EQUALS": 46, "MULT": 47, "DOT": 48, "BRKT": 49, "UNDERSCORE": 50, "MINUS": 51, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 5: "SPACE", 6: "QUADRANT", 13: "title", 14: "title_value", 15: "acc_title", 16: "acc_title_value", 17: "acc_descr", 18: "acc_descr_value", 19: "acc_descr_multiline_value", 20: "section", 22: "point_start", 23: "point_x", 24: "point_y", 25: "X-AXIS", 26: "AXIS-TEXT-DELIMITER", 27: "Y-AXIS", 28: "QUADRANT_1", 29: "QUADRANT_2", 30: "QUADRANT_3", 31: "QUADRANT_4", 32: "NEWLINE", 33: "SEMI", 34: "EOF", 37: "STR", 38: "MD_STR", 40: "PUNCTUATION", 41: "AMP", 42: "NUM", 43: "ALPHA", 44: "COMMA", 45: "PLUS", 46: "EQUALS", 47: "MULT", 48: "DOT", 49: "BRKT", 50: "UNDERSCORE", 51: "MINUS" }, + productions_: [0, [3, 2], [3, 2], [3, 2], [7, 0], [7, 2], [8, 2], [9, 0], [9, 2], [9, 1], [9, 1], [9, 1], [9, 2], [9, 2], [9, 2], [9, 1], [9, 1], [12, 4], [10, 4], [10, 3], [10, 2], [10, 4], [10, 3], [10, 2], [11, 2], [11, 2], [11, 2], [11, 2], [4, 1], [4, 1], [4, 1], [21, 1], [21, 2], [21, 1], [21, 1], [39, 1], [39, 2], [35, 1], [35, 1], [35, 1], [35, 1], [35, 1], [35, 1], [35, 1], [35, 1], [35, 1], [35, 1], [35, 1], [36, 1], [36, 1], [36, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 12: + this.$ = $$[$0].trim(); + yy.setDiagramTitle(this.$); + break; + case 13: + this.$ = $$[$0].trim(); + yy.setAccTitle(this.$); + break; + case 14: + case 15: + this.$ = $$[$0].trim(); + yy.setAccDescription(this.$); + break; + case 16: + yy.addSection($$[$0].substr(8)); + this.$ = $$[$0].substr(8); + break; + case 17: + yy.addPoint($$[$0 - 3], $$[$0 - 1], $$[$0]); + break; + case 18: + yy.setXAxisLeftText($$[$0 - 2]); + yy.setXAxisRightText($$[$0]); + break; + case 19: + $$[$0 - 1].text += " ⟶ "; + yy.setXAxisLeftText($$[$0 - 1]); + break; + case 20: + yy.setXAxisLeftText($$[$0]); + break; + case 21: + yy.setYAxisBottomText($$[$0 - 2]); + yy.setYAxisTopText($$[$0]); + break; + case 22: + $$[$0 - 1].text += " ⟶ "; + yy.setYAxisBottomText($$[$0 - 1]); + break; + case 23: + yy.setYAxisBottomText($$[$0]); + break; + case 24: + yy.setQuadrant1Text($$[$0]); + break; + case 25: + yy.setQuadrant2Text($$[$0]); + break; + case 26: + yy.setQuadrant3Text($$[$0]); + break; + case 27: + yy.setQuadrant4Text($$[$0]); + break; + case 31: + this.$ = { text: $$[$0], type: "text" }; + break; + case 32: + this.$ = { text: $$[$0 - 1].text + "" + $$[$0], type: $$[$0 - 1].type }; + break; + case 33: + this.$ = { text: $$[$0], type: "text" }; + break; + case 34: + this.$ = { text: $$[$0], type: "markdown" }; + break; + case 35: + this.$ = $$[$0]; + break; + case 36: + this.$ = $$[$0 - 1] + "" + $$[$0]; + break; + } + }, + table: [{ 3: 1, 4: 2, 5: $V0, 6: $V1, 32: $V2, 33: $V3, 34: $V4 }, { 1: [3] }, { 3: 8, 4: 2, 5: $V0, 6: $V1, 32: $V2, 33: $V3, 34: $V4 }, { 3: 9, 4: 2, 5: $V0, 6: $V1, 32: $V2, 33: $V3, 34: $V4 }, o($V5, [2, 4], { 7: 10 }), o($V6, [2, 28]), o($V6, [2, 29]), o($V6, [2, 30]), { 1: [2, 1] }, { 1: [2, 2] }, o($V7, $V8, { 8: 11, 9: 12, 10: 14, 11: 15, 12: 16, 21: 28, 35: 29, 1: [2, 3], 5: $V9, 13: $Va, 15: $Vb, 17: $Vc, 19: $Vd, 20: $Ve, 25: $Vf, 27: $Vg, 28: $Vh, 29: $Vi, 30: $Vj, 31: $Vk, 37: $Vl, 38: $Vm, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx }), o($V5, [2, 5]), { 4: 43, 32: $V2, 33: $V3, 34: $V4 }, o($V7, $V8, { 10: 14, 11: 15, 12: 16, 21: 28, 35: 29, 9: 44, 5: $V9, 13: $Va, 15: $Vb, 17: $Vc, 19: $Vd, 20: $Ve, 25: $Vf, 27: $Vg, 28: $Vh, 29: $Vi, 30: $Vj, 31: $Vk, 37: $Vl, 38: $Vm, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx }), o($V7, [2, 9]), o($V7, [2, 10]), o($V7, [2, 11]), { 14: [1, 45] }, { 16: [1, 46] }, { 18: [1, 47] }, o($V7, [2, 15]), o($V7, [2, 16]), { 21: 48, 35: 29, 37: $Vl, 38: $Vm, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx }, { 21: 49, 35: 29, 37: $Vl, 38: $Vm, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx }, { 21: 50, 35: 29, 37: $Vl, 38: $Vm, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx }, { 21: 51, 35: 29, 37: $Vl, 38: $Vm, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx }, { 21: 52, 35: 29, 37: $Vl, 38: $Vm, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx }, { 21: 53, 35: 29, 37: $Vl, 38: $Vm, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx }, { 5: $Vy, 22: [1, 54], 35: 56, 36: 55, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx, 51: $Vz }, o($VA, [2, 31]), o($VA, [2, 33]), o($VA, [2, 34]), o($VA, [2, 37]), o($VA, [2, 38]), o($VA, [2, 39]), o($VA, [2, 40]), o($VA, [2, 41]), o($VA, [2, 42]), o($VA, [2, 43]), o($VA, [2, 44]), o($VA, [2, 45]), o($VA, [2, 46]), o($VA, [2, 47]), o($V5, [2, 6]), o($V7, [2, 8]), o($V7, [2, 12]), o($V7, [2, 13]), o($V7, [2, 14]), o($V7, [2, 20], { 36: 55, 35: 56, 5: $Vy, 26: [1, 59], 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx, 51: $Vz }), o($V7, [2, 23], { 36: 55, 35: 56, 5: $Vy, 26: [1, 60], 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx, 51: $Vz }), o($V7, [2, 24], { 36: 55, 35: 56, 5: $Vy, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx, 51: $Vz }), o($V7, [2, 25], { 36: 55, 35: 56, 5: $Vy, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx, 51: $Vz }), o($V7, [2, 26], { 36: 55, 35: 56, 5: $Vy, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx, 51: $Vz }), o($V7, [2, 27], { 36: 55, 35: 56, 5: $Vy, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx, 51: $Vz }), { 23: [1, 61] }, o($VA, [2, 32]), o($VA, [2, 48]), o($VA, [2, 49]), o($VA, [2, 50]), o($V7, [2, 19], { 35: 29, 21: 62, 37: $Vl, 38: $Vm, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx }), o($V7, [2, 22], { 35: 29, 21: 63, 37: $Vl, 38: $Vm, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx }), { 24: [1, 64] }, o($V7, [2, 18], { 36: 55, 35: 56, 5: $Vy, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx, 51: $Vz }), o($V7, [2, 21], { 36: 55, 35: 56, 5: $Vy, 40: $Vn, 41: $Vo, 42: $Vp, 43: $Vq, 44: $Vr, 45: $Vs, 46: $Vt, 47: $Vu, 48: $Vv, 49: $Vw, 50: $Vx, 51: $Vz }), o($V7, [2, 17])], + defaultActions: { 8: [2, 1], 9: [2, 2] }, + parseError: function parseError(str, hash) { + if (hash.recoverable) { + this.trace(str); + } else { + var error = new Error(str); + error.hash = hash; + throw error; + } + }, + parse: function parse(input) { + var self = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex() { + var token; + token = tstack.pop() || lexer2.lex() || EOF; + if (typeof token !== "number") { + if (token instanceof Array) { + tstack = token; + token = tstack.pop(); + } + token = self.symbols_[token] || token; + } + return token; + } + var symbol, state, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state = stack[stack.length - 1]; + if (this.defaultActions[state]) { + action = this.defaultActions[state]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex(); + } + action = table[state] && table[state][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str, hash); + } else { + throw new Error(str); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch = this._input[0]; + this.yytext += ch; + this.yyleng++; + this.offset++; + this.match += ch; + this.matched += ch; + var lines = ch.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch; + }, + // unshifts one char (or a string) into the input + unput: function(ch) { + var len = ch.length; + var lines = ch.split(/(?:\r\n?|\n)/g); + this._input = ch + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next = this.match; + if (next.length < 20) { + next += this._input.substr(0, 20 - next.length); + } + return (next.substr(0, 20) + (next.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token) { + return token; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token, match, tempMatch, index; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i = 0; i < rules.length; i++) { + tempMatch = this._input.match(this.rules[rules[i]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index = i; + if (this.options.backtrack_lexer) { + token = this.test_match(tempMatch, rules[i]); + if (token !== false) { + return token; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token = this.test_match(match, rules[index]); + if (token !== false) { + return token; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + break; + case 1: + break; + case 2: + return 32; + case 3: + break; + case 4: + this.begin("title"); + return 13; + case 5: + this.popState(); + return "title_value"; + case 6: + this.begin("acc_title"); + return 15; + case 7: + this.popState(); + return "acc_title_value"; + case 8: + this.begin("acc_descr"); + return 17; + case 9: + this.popState(); + return "acc_descr_value"; + case 10: + this.begin("acc_descr_multiline"); + break; + case 11: + this.popState(); + break; + case 12: + return "acc_descr_multiline_value"; + case 13: + return 25; + case 14: + return 27; + case 15: + return 26; + case 16: + return 28; + case 17: + return 29; + case 18: + return 30; + case 19: + return 31; + case 20: + this.begin("md_string"); + break; + case 21: + return "MD_STR"; + case 22: + this.popState(); + break; + case 23: + this.begin("string"); + break; + case 24: + this.popState(); + break; + case 25: + return "STR"; + case 26: + this.begin("point_start"); + return 22; + case 27: + this.begin("point_x"); + return 23; + case 28: + this.popState(); + break; + case 29: + this.popState(); + this.begin("point_y"); + break; + case 30: + this.popState(); + return 24; + case 31: + return 6; + case 32: + return 43; + case 33: + return "COLON"; + case 34: + return 45; + case 35: + return 44; + case 36: + return 46; + case 37: + return 46; + case 38: + return 47; + case 39: + return 49; + case 40: + return 50; + case 41: + return 48; + case 42: + return 41; + case 43: + return 51; + case 44: + return 42; + case 45: + return 5; + case 46: + return 33; + case 47: + return 40; + case 48: + return 34; + } + }, + rules: [/^(?:%%(?!\{)[^\n]*)/i, /^(?:[^\}]%%[^\n]*)/i, /^(?:[\n\r]+)/i, /^(?:%%[^\n]*)/i, /^(?:title\b)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accTitle\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*\{\s*)/i, /^(?:[\}])/i, /^(?:[^\}]*)/i, /^(?: *x-axis *)/i, /^(?: *y-axis *)/i, /^(?: *--+> *)/i, /^(?: *quadrant-1 *)/i, /^(?: *quadrant-2 *)/i, /^(?: *quadrant-3 *)/i, /^(?: *quadrant-4 *)/i, /^(?:["][`])/i, /^(?:[^`"]+)/i, /^(?:[`]["])/i, /^(?:["])/i, /^(?:["])/i, /^(?:[^"]*)/i, /^(?:\s*:\s*\[\s*)/i, /^(?:(1)|(0(.\d+)?))/i, /^(?:\s*\] *)/i, /^(?:\s*,\s*)/i, /^(?:(1)|(0(.\d+)?))/i, /^(?: *quadrantChart *)/i, /^(?:[A-Za-z]+)/i, /^(?::)/i, /^(?:\+)/i, /^(?:,)/i, /^(?:=)/i, /^(?:=)/i, /^(?:\*)/i, /^(?:#)/i, /^(?:[\_])/i, /^(?:\.)/i, /^(?:&)/i, /^(?:-)/i, /^(?:[0-9]+)/i, /^(?:\s)/i, /^(?:;)/i, /^(?:[!"#$%&'*+,-.`?\\_/])/i, /^(?:$)/i], + conditions: { "point_y": { "rules": [30], "inclusive": false }, "point_x": { "rules": [29], "inclusive": false }, "point_start": { "rules": [27, 28], "inclusive": false }, "acc_descr_multiline": { "rules": [11, 12], "inclusive": false }, "acc_descr": { "rules": [9], "inclusive": false }, "acc_title": { "rules": [7], "inclusive": false }, "title": { "rules": [5], "inclusive": false }, "md_string": { "rules": [21, 22], "inclusive": false }, "string": { "rules": [24, 25], "inclusive": false }, "INITIAL": { "rules": [0, 1, 2, 3, 4, 6, 8, 10, 13, 14, 15, 16, 17, 18, 19, 20, 23, 26, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser() { + this.yy = {}; + } + Parser.prototype = parser2; + parser2.Parser = Parser; + return new Parser(); +}(); +parser.parser = parser; +const parser$1 = parser; +const defaultThemeVariables = getThemeVariables(); +class QuadrantBuilder { + constructor() { + this.config = this.getDefaultConfig(); + this.themeConfig = this.getDefaultThemeConfig(); + this.data = this.getDefaultData(); + } + getDefaultData() { + return { + titleText: "", + quadrant1Text: "", + quadrant2Text: "", + quadrant3Text: "", + quadrant4Text: "", + xAxisLeftText: "", + xAxisRightText: "", + yAxisBottomText: "", + yAxisTopText: "", + points: [] + }; + } + getDefaultConfig() { + var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r; + return { + showXAxis: true, + showYAxis: true, + showTitle: true, + chartHeight: ((_a = defaultConfig.quadrantChart) == null ? void 0 : _a.chartWidth) || 500, + chartWidth: ((_b = defaultConfig.quadrantChart) == null ? void 0 : _b.chartHeight) || 500, + titlePadding: ((_c = defaultConfig.quadrantChart) == null ? void 0 : _c.titlePadding) || 10, + titleFontSize: ((_d = defaultConfig.quadrantChart) == null ? void 0 : _d.titleFontSize) || 20, + quadrantPadding: ((_e = defaultConfig.quadrantChart) == null ? void 0 : _e.quadrantPadding) || 5, + xAxisLabelPadding: ((_f = defaultConfig.quadrantChart) == null ? void 0 : _f.xAxisLabelPadding) || 5, + yAxisLabelPadding: ((_g = defaultConfig.quadrantChart) == null ? void 0 : _g.yAxisLabelPadding) || 5, + xAxisLabelFontSize: ((_h = defaultConfig.quadrantChart) == null ? void 0 : _h.xAxisLabelFontSize) || 16, + yAxisLabelFontSize: ((_i = defaultConfig.quadrantChart) == null ? void 0 : _i.yAxisLabelFontSize) || 16, + quadrantLabelFontSize: ((_j = defaultConfig.quadrantChart) == null ? void 0 : _j.quadrantLabelFontSize) || 16, + quadrantTextTopPadding: ((_k = defaultConfig.quadrantChart) == null ? void 0 : _k.quadrantTextTopPadding) || 5, + pointTextPadding: ((_l = defaultConfig.quadrantChart) == null ? void 0 : _l.pointTextPadding) || 5, + pointLabelFontSize: ((_m = defaultConfig.quadrantChart) == null ? void 0 : _m.pointLabelFontSize) || 12, + pointRadius: ((_n = defaultConfig.quadrantChart) == null ? void 0 : _n.pointRadius) || 5, + xAxisPosition: ((_o = defaultConfig.quadrantChart) == null ? void 0 : _o.xAxisPosition) || "top", + yAxisPosition: ((_p = defaultConfig.quadrantChart) == null ? void 0 : _p.yAxisPosition) || "left", + quadrantInternalBorderStrokeWidth: ((_q = defaultConfig.quadrantChart) == null ? void 0 : _q.quadrantInternalBorderStrokeWidth) || 1, + quadrantExternalBorderStrokeWidth: ((_r = defaultConfig.quadrantChart) == null ? void 0 : _r.quadrantExternalBorderStrokeWidth) || 2 + }; + } + getDefaultThemeConfig() { + return { + quadrant1Fill: defaultThemeVariables.quadrant1Fill, + quadrant2Fill: defaultThemeVariables.quadrant2Fill, + quadrant3Fill: defaultThemeVariables.quadrant3Fill, + quadrant4Fill: defaultThemeVariables.quadrant4Fill, + quadrant1TextFill: defaultThemeVariables.quadrant1TextFill, + quadrant2TextFill: defaultThemeVariables.quadrant2TextFill, + quadrant3TextFill: defaultThemeVariables.quadrant3TextFill, + quadrant4TextFill: defaultThemeVariables.quadrant4TextFill, + quadrantPointFill: defaultThemeVariables.quadrantPointFill, + quadrantPointTextFill: defaultThemeVariables.quadrantPointTextFill, + quadrantXAxisTextFill: defaultThemeVariables.quadrantXAxisTextFill, + quadrantYAxisTextFill: defaultThemeVariables.quadrantYAxisTextFill, + quadrantTitleFill: defaultThemeVariables.quadrantTitleFill, + quadrantInternalBorderStrokeFill: defaultThemeVariables.quadrantInternalBorderStrokeFill, + quadrantExternalBorderStrokeFill: defaultThemeVariables.quadrantExternalBorderStrokeFill + }; + } + clear() { + this.config = this.getDefaultConfig(); + this.themeConfig = this.getDefaultThemeConfig(); + this.data = this.getDefaultData(); + log.info("clear called"); + } + setData(data) { + this.data = { ...this.data, ...data }; + } + addPoints(points) { + this.data.points = [...points, ...this.data.points]; + } + setConfig(config2) { + log.trace("setConfig called with: ", config2); + this.config = { ...this.config, ...config2 }; + } + setThemeConfig(themeConfig) { + log.trace("setThemeConfig called with: ", themeConfig); + this.themeConfig = { ...this.themeConfig, ...themeConfig }; + } + calculateSpace(xAxisPosition, showXAxis, showYAxis, showTitle) { + const xAxisSpaceCalculation = this.config.xAxisLabelPadding * 2 + this.config.xAxisLabelFontSize; + const xAxisSpace = { + top: xAxisPosition === "top" && showXAxis ? xAxisSpaceCalculation : 0, + bottom: xAxisPosition === "bottom" && showXAxis ? xAxisSpaceCalculation : 0 + }; + const yAxisSpaceCalculation = this.config.yAxisLabelPadding * 2 + this.config.yAxisLabelFontSize; + const yAxisSpace = { + left: this.config.yAxisPosition === "left" && showYAxis ? yAxisSpaceCalculation : 0, + right: this.config.yAxisPosition === "right" && showYAxis ? yAxisSpaceCalculation : 0 + }; + const titleSpaceCalculation = this.config.titleFontSize + this.config.titlePadding * 2; + const titleSpace = { + top: showTitle ? titleSpaceCalculation : 0 + }; + const quadrantLeft = this.config.quadrantPadding + yAxisSpace.left; + const quadrantTop = this.config.quadrantPadding + xAxisSpace.top + titleSpace.top; + const quadrantWidth = this.config.chartWidth - this.config.quadrantPadding * 2 - yAxisSpace.left - yAxisSpace.right; + const quadrantHeight = this.config.chartHeight - this.config.quadrantPadding * 2 - xAxisSpace.top - xAxisSpace.bottom - titleSpace.top; + const quadrantHalfWidth = quadrantWidth / 2; + const quadrantHalfHeight = quadrantHeight / 2; + const quadrantSpace = { + quadrantLeft, + quadrantTop, + quadrantWidth, + quadrantHalfWidth, + quadrantHeight, + quadrantHalfHeight + }; + return { + xAxisSpace, + yAxisSpace, + titleSpace, + quadrantSpace + }; + } + getAxisLabels(xAxisPosition, showXAxis, showYAxis, spaceData) { + const { quadrantSpace, titleSpace } = spaceData; + const { + quadrantHalfHeight, + quadrantHeight, + quadrantLeft, + quadrantHalfWidth, + quadrantTop, + quadrantWidth + } = quadrantSpace; + const drawXAxisLabelsInMiddle = Boolean(this.data.xAxisRightText); + const drawYAxisLabelsInMiddle = Boolean(this.data.yAxisTopText); + const axisLabels = []; + if (this.data.xAxisLeftText && showXAxis) { + axisLabels.push({ + text: this.data.xAxisLeftText, + fill: this.themeConfig.quadrantXAxisTextFill, + x: quadrantLeft + (drawXAxisLabelsInMiddle ? quadrantHalfWidth / 2 : 0), + y: xAxisPosition === "top" ? this.config.xAxisLabelPadding + titleSpace.top : this.config.xAxisLabelPadding + quadrantTop + quadrantHeight + this.config.quadrantPadding, + fontSize: this.config.xAxisLabelFontSize, + verticalPos: drawXAxisLabelsInMiddle ? "center" : "left", + horizontalPos: "top", + rotation: 0 + }); + } + if (this.data.xAxisRightText && showXAxis) { + axisLabels.push({ + text: this.data.xAxisRightText, + fill: this.themeConfig.quadrantXAxisTextFill, + x: quadrantLeft + quadrantHalfWidth + (drawXAxisLabelsInMiddle ? quadrantHalfWidth / 2 : 0), + y: xAxisPosition === "top" ? this.config.xAxisLabelPadding + titleSpace.top : this.config.xAxisLabelPadding + quadrantTop + quadrantHeight + this.config.quadrantPadding, + fontSize: this.config.xAxisLabelFontSize, + verticalPos: drawXAxisLabelsInMiddle ? "center" : "left", + horizontalPos: "top", + rotation: 0 + }); + } + if (this.data.yAxisBottomText && showYAxis) { + axisLabels.push({ + text: this.data.yAxisBottomText, + fill: this.themeConfig.quadrantYAxisTextFill, + x: this.config.yAxisPosition === "left" ? this.config.yAxisLabelPadding : this.config.yAxisLabelPadding + quadrantLeft + quadrantWidth + this.config.quadrantPadding, + y: quadrantTop + quadrantHeight - (drawYAxisLabelsInMiddle ? quadrantHalfHeight / 2 : 0), + fontSize: this.config.yAxisLabelFontSize, + verticalPos: drawYAxisLabelsInMiddle ? "center" : "left", + horizontalPos: "top", + rotation: -90 + }); + } + if (this.data.yAxisTopText && showYAxis) { + axisLabels.push({ + text: this.data.yAxisTopText, + fill: this.themeConfig.quadrantYAxisTextFill, + x: this.config.yAxisPosition === "left" ? this.config.yAxisLabelPadding : this.config.yAxisLabelPadding + quadrantLeft + quadrantWidth + this.config.quadrantPadding, + y: quadrantTop + quadrantHalfHeight - (drawYAxisLabelsInMiddle ? quadrantHalfHeight / 2 : 0), + fontSize: this.config.yAxisLabelFontSize, + verticalPos: drawYAxisLabelsInMiddle ? "center" : "left", + horizontalPos: "top", + rotation: -90 + }); + } + return axisLabels; + } + getQuadrants(spaceData) { + const { quadrantSpace } = spaceData; + const { quadrantHalfHeight, quadrantLeft, quadrantHalfWidth, quadrantTop } = quadrantSpace; + const quadrants = [ + { + text: { + text: this.data.quadrant1Text, + fill: this.themeConfig.quadrant1TextFill, + x: 0, + y: 0, + fontSize: this.config.quadrantLabelFontSize, + verticalPos: "center", + horizontalPos: "middle", + rotation: 0 + }, + x: quadrantLeft + quadrantHalfWidth, + y: quadrantTop, + width: quadrantHalfWidth, + height: quadrantHalfHeight, + fill: this.themeConfig.quadrant1Fill + }, + { + text: { + text: this.data.quadrant2Text, + fill: this.themeConfig.quadrant2TextFill, + x: 0, + y: 0, + fontSize: this.config.quadrantLabelFontSize, + verticalPos: "center", + horizontalPos: "middle", + rotation: 0 + }, + x: quadrantLeft, + y: quadrantTop, + width: quadrantHalfWidth, + height: quadrantHalfHeight, + fill: this.themeConfig.quadrant2Fill + }, + { + text: { + text: this.data.quadrant3Text, + fill: this.themeConfig.quadrant3TextFill, + x: 0, + y: 0, + fontSize: this.config.quadrantLabelFontSize, + verticalPos: "center", + horizontalPos: "middle", + rotation: 0 + }, + x: quadrantLeft, + y: quadrantTop + quadrantHalfHeight, + width: quadrantHalfWidth, + height: quadrantHalfHeight, + fill: this.themeConfig.quadrant3Fill + }, + { + text: { + text: this.data.quadrant4Text, + fill: this.themeConfig.quadrant4TextFill, + x: 0, + y: 0, + fontSize: this.config.quadrantLabelFontSize, + verticalPos: "center", + horizontalPos: "middle", + rotation: 0 + }, + x: quadrantLeft + quadrantHalfWidth, + y: quadrantTop + quadrantHalfHeight, + width: quadrantHalfWidth, + height: quadrantHalfHeight, + fill: this.themeConfig.quadrant4Fill + } + ]; + for (const quadrant of quadrants) { + quadrant.text.x = quadrant.x + quadrant.width / 2; + if (this.data.points.length === 0) { + quadrant.text.y = quadrant.y + quadrant.height / 2; + quadrant.text.horizontalPos = "middle"; + } else { + quadrant.text.y = quadrant.y + this.config.quadrantTextTopPadding; + quadrant.text.horizontalPos = "top"; + } + } + return quadrants; + } + getQuadrantPoints(spaceData) { + const { quadrantSpace } = spaceData; + const { quadrantHeight, quadrantLeft, quadrantTop, quadrantWidth } = quadrantSpace; + const xAxis = scaleLinear().domain([0, 1]).range([quadrantLeft, quadrantWidth + quadrantLeft]); + const yAxis = scaleLinear().domain([0, 1]).range([quadrantHeight + quadrantTop, quadrantTop]); + const points = this.data.points.map((point) => { + const props = { + x: xAxis(point.x), + y: yAxis(point.y), + fill: this.themeConfig.quadrantPointFill, + radius: this.config.pointRadius, + text: { + text: point.text, + fill: this.themeConfig.quadrantPointTextFill, + x: xAxis(point.x), + y: yAxis(point.y) + this.config.pointTextPadding, + verticalPos: "center", + horizontalPos: "top", + fontSize: this.config.pointLabelFontSize, + rotation: 0 + } + }; + return props; + }); + return points; + } + getBorders(spaceData) { + const halfExternalBorderWidth = this.config.quadrantExternalBorderStrokeWidth / 2; + const { quadrantSpace } = spaceData; + const { + quadrantHalfHeight, + quadrantHeight, + quadrantLeft, + quadrantHalfWidth, + quadrantTop, + quadrantWidth + } = quadrantSpace; + const borderLines = [ + // top border + { + strokeFill: this.themeConfig.quadrantExternalBorderStrokeFill, + strokeWidth: this.config.quadrantExternalBorderStrokeWidth, + x1: quadrantLeft - halfExternalBorderWidth, + y1: quadrantTop, + x2: quadrantLeft + quadrantWidth + halfExternalBorderWidth, + y2: quadrantTop + }, + // right border + { + strokeFill: this.themeConfig.quadrantExternalBorderStrokeFill, + strokeWidth: this.config.quadrantExternalBorderStrokeWidth, + x1: quadrantLeft + quadrantWidth, + y1: quadrantTop + halfExternalBorderWidth, + x2: quadrantLeft + quadrantWidth, + y2: quadrantTop + quadrantHeight - halfExternalBorderWidth + }, + // bottom border + { + strokeFill: this.themeConfig.quadrantExternalBorderStrokeFill, + strokeWidth: this.config.quadrantExternalBorderStrokeWidth, + x1: quadrantLeft - halfExternalBorderWidth, + y1: quadrantTop + quadrantHeight, + x2: quadrantLeft + quadrantWidth + halfExternalBorderWidth, + y2: quadrantTop + quadrantHeight + }, + // left border + { + strokeFill: this.themeConfig.quadrantExternalBorderStrokeFill, + strokeWidth: this.config.quadrantExternalBorderStrokeWidth, + x1: quadrantLeft, + y1: quadrantTop + halfExternalBorderWidth, + x2: quadrantLeft, + y2: quadrantTop + quadrantHeight - halfExternalBorderWidth + }, + // vertical inner border + { + strokeFill: this.themeConfig.quadrantInternalBorderStrokeFill, + strokeWidth: this.config.quadrantInternalBorderStrokeWidth, + x1: quadrantLeft + quadrantHalfWidth, + y1: quadrantTop + halfExternalBorderWidth, + x2: quadrantLeft + quadrantHalfWidth, + y2: quadrantTop + quadrantHeight - halfExternalBorderWidth + }, + // horizontal inner border + { + strokeFill: this.themeConfig.quadrantInternalBorderStrokeFill, + strokeWidth: this.config.quadrantInternalBorderStrokeWidth, + x1: quadrantLeft + halfExternalBorderWidth, + y1: quadrantTop + quadrantHalfHeight, + x2: quadrantLeft + quadrantWidth - halfExternalBorderWidth, + y2: quadrantTop + quadrantHalfHeight + } + ]; + return borderLines; + } + getTitle(showTitle) { + if (showTitle) { + return { + text: this.data.titleText, + fill: this.themeConfig.quadrantTitleFill, + fontSize: this.config.titleFontSize, + horizontalPos: "top", + verticalPos: "center", + rotation: 0, + y: this.config.titlePadding, + x: this.config.chartWidth / 2 + }; + } + return; + } + build() { + const showXAxis = this.config.showXAxis && !!(this.data.xAxisLeftText || this.data.xAxisRightText); + const showYAxis = this.config.showYAxis && !!(this.data.yAxisTopText || this.data.yAxisBottomText); + const showTitle = this.config.showTitle && !!this.data.titleText; + const xAxisPosition = this.data.points.length > 0 ? "bottom" : this.config.xAxisPosition; + const calculatedSpace = this.calculateSpace(xAxisPosition, showXAxis, showYAxis, showTitle); + return { + points: this.getQuadrantPoints(calculatedSpace), + quadrants: this.getQuadrants(calculatedSpace), + axisLabels: this.getAxisLabels(xAxisPosition, showXAxis, showYAxis, calculatedSpace), + borderLines: this.getBorders(calculatedSpace), + title: this.getTitle(showTitle) + }; + } +} +const config = getConfig(); +function textSanitizer(text) { + return sanitizeText(text.trim(), config); +} +const quadrantBuilder = new QuadrantBuilder(); +function setQuadrant1Text(textObj) { + quadrantBuilder.setData({ quadrant1Text: textSanitizer(textObj.text) }); +} +function setQuadrant2Text(textObj) { + quadrantBuilder.setData({ quadrant2Text: textSanitizer(textObj.text) }); +} +function setQuadrant3Text(textObj) { + quadrantBuilder.setData({ quadrant3Text: textSanitizer(textObj.text) }); +} +function setQuadrant4Text(textObj) { + quadrantBuilder.setData({ quadrant4Text: textSanitizer(textObj.text) }); +} +function setXAxisLeftText(textObj) { + quadrantBuilder.setData({ xAxisLeftText: textSanitizer(textObj.text) }); +} +function setXAxisRightText(textObj) { + quadrantBuilder.setData({ xAxisRightText: textSanitizer(textObj.text) }); +} +function setYAxisTopText(textObj) { + quadrantBuilder.setData({ yAxisTopText: textSanitizer(textObj.text) }); +} +function setYAxisBottomText(textObj) { + quadrantBuilder.setData({ yAxisBottomText: textSanitizer(textObj.text) }); +} +function addPoint(textObj, x, y) { + quadrantBuilder.addPoints([{ x, y, text: textSanitizer(textObj.text) }]); +} +function setWidth(width) { + quadrantBuilder.setConfig({ chartWidth: width }); +} +function setHeight(height) { + quadrantBuilder.setConfig({ chartHeight: height }); +} +function getQuadrantData() { + const config2 = getConfig(); + const { themeVariables, quadrantChart: quadrantChartConfig } = config2; + if (quadrantChartConfig) { + quadrantBuilder.setConfig(quadrantChartConfig); + } + quadrantBuilder.setThemeConfig({ + quadrant1Fill: themeVariables.quadrant1Fill, + quadrant2Fill: themeVariables.quadrant2Fill, + quadrant3Fill: themeVariables.quadrant3Fill, + quadrant4Fill: themeVariables.quadrant4Fill, + quadrant1TextFill: themeVariables.quadrant1TextFill, + quadrant2TextFill: themeVariables.quadrant2TextFill, + quadrant3TextFill: themeVariables.quadrant3TextFill, + quadrant4TextFill: themeVariables.quadrant4TextFill, + quadrantPointFill: themeVariables.quadrantPointFill, + quadrantPointTextFill: themeVariables.quadrantPointTextFill, + quadrantXAxisTextFill: themeVariables.quadrantXAxisTextFill, + quadrantYAxisTextFill: themeVariables.quadrantYAxisTextFill, + quadrantExternalBorderStrokeFill: themeVariables.quadrantExternalBorderStrokeFill, + quadrantInternalBorderStrokeFill: themeVariables.quadrantInternalBorderStrokeFill, + quadrantTitleFill: themeVariables.quadrantTitleFill + }); + quadrantBuilder.setData({ titleText: getDiagramTitle() }); + return quadrantBuilder.build(); +} +const clear = function() { + quadrantBuilder.clear(); + clear$1(); +}; +const db = { + setWidth, + setHeight, + setQuadrant1Text, + setQuadrant2Text, + setQuadrant3Text, + setQuadrant4Text, + setXAxisLeftText, + setXAxisRightText, + setYAxisTopText, + setYAxisBottomText, + addPoint, + getQuadrantData, + clear, + setAccTitle, + getAccTitle, + setDiagramTitle, + getDiagramTitle, + getAccDescription, + setAccDescription +}; +const draw = (txt, id, _version, diagObj) => { + var _a, _b, _c; + function getDominantBaseLine(horizontalPos) { + return horizontalPos === "top" ? "hanging" : "middle"; + } + function getTextAnchor(verticalPos) { + return verticalPos === "left" ? "start" : "middle"; + } + function getTransformation(data) { + return `translate(${data.x}, ${data.y}) rotate(${data.rotation || 0})`; + } + const conf = getConfig(); + log.debug("Rendering quadrant chart\n" + txt); + const securityLevel = conf.securityLevel; + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = select("#i" + id); + } + const root = securityLevel === "sandbox" ? select(sandboxElement.nodes()[0].contentDocument.body) : select("body"); + const svg = root.select(`[id="${id}"]`); + const group = svg.append("g").attr("class", "main"); + const width = ((_a = conf.quadrantChart) == null ? void 0 : _a.chartWidth) || 500; + const height = ((_b = conf.quadrantChart) == null ? void 0 : _b.chartHeight) || 500; + configureSvgSize(svg, height, width, ((_c = conf.quadrantChart) == null ? void 0 : _c.useMaxWidth) || true); + svg.attr("viewBox", "0 0 " + width + " " + height); + diagObj.db.setHeight(height); + diagObj.db.setWidth(width); + const quadrantData = diagObj.db.getQuadrantData(); + const quadrantsGroup = group.append("g").attr("class", "quadrants"); + const borderGroup = group.append("g").attr("class", "border"); + const dataPointGroup = group.append("g").attr("class", "data-points"); + const labelGroup = group.append("g").attr("class", "labels"); + const titleGroup = group.append("g").attr("class", "title"); + if (quadrantData.title) { + titleGroup.append("text").attr("x", 0).attr("y", 0).attr("fill", quadrantData.title.fill).attr("font-size", quadrantData.title.fontSize).attr("dominant-baseline", getDominantBaseLine(quadrantData.title.horizontalPos)).attr("text-anchor", getTextAnchor(quadrantData.title.verticalPos)).attr("transform", getTransformation(quadrantData.title)).text(quadrantData.title.text); + } + if (quadrantData.borderLines) { + borderGroup.selectAll("line").data(quadrantData.borderLines).enter().append("line").attr("x1", (data) => data.x1).attr("y1", (data) => data.y1).attr("x2", (data) => data.x2).attr("y2", (data) => data.y2).style("stroke", (data) => data.strokeFill).style("stroke-width", (data) => data.strokeWidth); + } + const quadrants = quadrantsGroup.selectAll("g.quadrant").data(quadrantData.quadrants).enter().append("g").attr("class", "quadrant"); + quadrants.append("rect").attr("x", (data) => data.x).attr("y", (data) => data.y).attr("width", (data) => data.width).attr("height", (data) => data.height).attr("fill", (data) => data.fill); + quadrants.append("text").attr("x", 0).attr("y", 0).attr("fill", (data) => data.text.fill).attr("font-size", (data) => data.text.fontSize).attr( + "dominant-baseline", + (data) => getDominantBaseLine(data.text.horizontalPos) + ).attr("text-anchor", (data) => getTextAnchor(data.text.verticalPos)).attr("transform", (data) => getTransformation(data.text)).text((data) => data.text.text); + const labels = labelGroup.selectAll("g.label").data(quadrantData.axisLabels).enter().append("g").attr("class", "label"); + labels.append("text").attr("x", 0).attr("y", 0).text((data) => data.text).attr("fill", (data) => data.fill).attr("font-size", (data) => data.fontSize).attr("dominant-baseline", (data) => getDominantBaseLine(data.horizontalPos)).attr("text-anchor", (data) => getTextAnchor(data.verticalPos)).attr("transform", (data) => getTransformation(data)); + const dataPoints = dataPointGroup.selectAll("g.data-point").data(quadrantData.points).enter().append("g").attr("class", "data-point"); + dataPoints.append("circle").attr("cx", (data) => data.x).attr("cy", (data) => data.y).attr("r", (data) => data.radius).attr("fill", (data) => data.fill); + dataPoints.append("text").attr("x", 0).attr("y", 0).text((data) => data.text.text).attr("fill", (data) => data.text.fill).attr("font-size", (data) => data.text.fontSize).attr( + "dominant-baseline", + (data) => getDominantBaseLine(data.text.horizontalPos) + ).attr("text-anchor", (data) => getTextAnchor(data.text.verticalPos)).attr("transform", (data) => getTransformation(data.text)); +}; +const renderer = { + draw +}; +const diagram = { + parser: parser$1, + db, + renderer, + styles: () => "" +}; +export { + diagram +}; diff --git a/0.6.0/js/mermaid/requirementDiagram-03163dc4.js b/0.6.0/js/mermaid/requirementDiagram-03163dc4.js new file mode 100644 index 0000000..cd69034 --- /dev/null +++ b/0.6.0/js/mermaid/requirementDiagram-03163dc4.js @@ -0,0 +1,769 @@ +import { c as Te, s as Ce, g as Fe, b as Me, a as De, l as Ne, E as Pe, j as oe, k as Ye, f as ke } from "./mermaid-9f2aa176.js"; +import { G as Ue } from "./graph-0ee63739.js"; +import { l as Be } from "./layout-fd473db2.js"; +import { l as Qe } from "./line-24d93f1b.js"; +import "./array-2ff2c7a6.js"; +import "./path-428ebac9.js"; +var ce = function() { + var e = function(V, i, r, a) { + for (r = r || {}, a = V.length; a--; r[V[a]] = i) + ; + return r; + }, t = [1, 3], l = [1, 4], c = [1, 5], u = [1, 6], d = [5, 6, 8, 9, 11, 13, 31, 32, 33, 34, 35, 36, 44, 62, 63], f = [1, 18], h = [2, 7], o = [1, 22], E = [1, 23], R = [1, 24], A = [1, 25], T = [1, 26], N = [1, 27], w = [1, 20], k = [1, 28], x = [1, 29], F = [62, 63], de = [5, 8, 9, 11, 13, 31, 32, 33, 34, 35, 36, 44, 51, 53, 62, 63], fe = [1, 47], pe = [1, 48], ye = [1, 49], _e = [1, 50], Ee = [1, 51], ge = [1, 52], Re = [1, 53], O = [53, 54], M = [1, 64], D = [1, 60], P = [1, 61], Y = [1, 62], U = [1, 63], B = [1, 65], j = [1, 69], z = [1, 70], X = [1, 67], J = [1, 68], m = [5, 8, 9, 11, 13, 31, 32, 33, 34, 35, 36, 44, 62, 63], ie = { + trace: function() { + }, + yy: {}, + symbols_: { error: 2, start: 3, directive: 4, NEWLINE: 5, RD: 6, diagram: 7, EOF: 8, acc_title: 9, acc_title_value: 10, acc_descr: 11, acc_descr_value: 12, acc_descr_multiline_value: 13, requirementDef: 14, elementDef: 15, relationshipDef: 16, requirementType: 17, requirementName: 18, STRUCT_START: 19, requirementBody: 20, ID: 21, COLONSEP: 22, id: 23, TEXT: 24, text: 25, RISK: 26, riskLevel: 27, VERIFYMTHD: 28, verifyType: 29, STRUCT_STOP: 30, REQUIREMENT: 31, FUNCTIONAL_REQUIREMENT: 32, INTERFACE_REQUIREMENT: 33, PERFORMANCE_REQUIREMENT: 34, PHYSICAL_REQUIREMENT: 35, DESIGN_CONSTRAINT: 36, LOW_RISK: 37, MED_RISK: 38, HIGH_RISK: 39, VERIFY_ANALYSIS: 40, VERIFY_DEMONSTRATION: 41, VERIFY_INSPECTION: 42, VERIFY_TEST: 43, ELEMENT: 44, elementName: 45, elementBody: 46, TYPE: 47, type: 48, DOCREF: 49, ref: 50, END_ARROW_L: 51, relationship: 52, LINE: 53, END_ARROW_R: 54, CONTAINS: 55, COPIES: 56, DERIVES: 57, SATISFIES: 58, VERIFIES: 59, REFINES: 60, TRACES: 61, unqString: 62, qString: 63, $accept: 0, $end: 1 }, + terminals_: { 2: "error", 5: "NEWLINE", 6: "RD", 8: "EOF", 9: "acc_title", 10: "acc_title_value", 11: "acc_descr", 12: "acc_descr_value", 13: "acc_descr_multiline_value", 19: "STRUCT_START", 21: "ID", 22: "COLONSEP", 24: "TEXT", 26: "RISK", 28: "VERIFYMTHD", 30: "STRUCT_STOP", 31: "REQUIREMENT", 32: "FUNCTIONAL_REQUIREMENT", 33: "INTERFACE_REQUIREMENT", 34: "PERFORMANCE_REQUIREMENT", 35: "PHYSICAL_REQUIREMENT", 36: "DESIGN_CONSTRAINT", 37: "LOW_RISK", 38: "MED_RISK", 39: "HIGH_RISK", 40: "VERIFY_ANALYSIS", 41: "VERIFY_DEMONSTRATION", 42: "VERIFY_INSPECTION", 43: "VERIFY_TEST", 44: "ELEMENT", 47: "TYPE", 49: "DOCREF", 51: "END_ARROW_L", 53: "LINE", 54: "END_ARROW_R", 55: "CONTAINS", 56: "COPIES", 57: "DERIVES", 58: "SATISFIES", 59: "VERIFIES", 60: "REFINES", 61: "TRACES", 62: "unqString", 63: "qString" }, + productions_: [0, [3, 3], [3, 2], [3, 4], [4, 2], [4, 2], [4, 1], [7, 0], [7, 2], [7, 2], [7, 2], [7, 2], [7, 2], [14, 5], [20, 5], [20, 5], [20, 5], [20, 5], [20, 2], [20, 1], [17, 1], [17, 1], [17, 1], [17, 1], [17, 1], [17, 1], [27, 1], [27, 1], [27, 1], [29, 1], [29, 1], [29, 1], [29, 1], [15, 5], [46, 5], [46, 5], [46, 2], [46, 1], [16, 5], [16, 5], [52, 1], [52, 1], [52, 1], [52, 1], [52, 1], [52, 1], [52, 1], [18, 1], [18, 1], [23, 1], [23, 1], [25, 1], [25, 1], [45, 1], [45, 1], [48, 1], [48, 1], [50, 1], [50, 1]], + performAction: function(i, r, a, n, p, s, W) { + var _ = s.length - 1; + switch (p) { + case 4: + this.$ = s[_].trim(), n.setAccTitle(this.$); + break; + case 5: + case 6: + this.$ = s[_].trim(), n.setAccDescription(this.$); + break; + case 7: + this.$ = []; + break; + case 13: + n.addRequirement(s[_ - 3], s[_ - 4]); + break; + case 14: + n.setNewReqId(s[_ - 2]); + break; + case 15: + n.setNewReqText(s[_ - 2]); + break; + case 16: + n.setNewReqRisk(s[_ - 2]); + break; + case 17: + n.setNewReqVerifyMethod(s[_ - 2]); + break; + case 20: + this.$ = n.RequirementType.REQUIREMENT; + break; + case 21: + this.$ = n.RequirementType.FUNCTIONAL_REQUIREMENT; + break; + case 22: + this.$ = n.RequirementType.INTERFACE_REQUIREMENT; + break; + case 23: + this.$ = n.RequirementType.PERFORMANCE_REQUIREMENT; + break; + case 24: + this.$ = n.RequirementType.PHYSICAL_REQUIREMENT; + break; + case 25: + this.$ = n.RequirementType.DESIGN_CONSTRAINT; + break; + case 26: + this.$ = n.RiskLevel.LOW_RISK; + break; + case 27: + this.$ = n.RiskLevel.MED_RISK; + break; + case 28: + this.$ = n.RiskLevel.HIGH_RISK; + break; + case 29: + this.$ = n.VerifyType.VERIFY_ANALYSIS; + break; + case 30: + this.$ = n.VerifyType.VERIFY_DEMONSTRATION; + break; + case 31: + this.$ = n.VerifyType.VERIFY_INSPECTION; + break; + case 32: + this.$ = n.VerifyType.VERIFY_TEST; + break; + case 33: + n.addElement(s[_ - 3]); + break; + case 34: + n.setNewElementType(s[_ - 2]); + break; + case 35: + n.setNewElementDocRef(s[_ - 2]); + break; + case 38: + n.addRelationship(s[_ - 2], s[_], s[_ - 4]); + break; + case 39: + n.addRelationship(s[_ - 2], s[_ - 4], s[_]); + break; + case 40: + this.$ = n.Relationships.CONTAINS; + break; + case 41: + this.$ = n.Relationships.COPIES; + break; + case 42: + this.$ = n.Relationships.DERIVES; + break; + case 43: + this.$ = n.Relationships.SATISFIES; + break; + case 44: + this.$ = n.Relationships.VERIFIES; + break; + case 45: + this.$ = n.Relationships.REFINES; + break; + case 46: + this.$ = n.Relationships.TRACES; + break; + } + }, + table: [{ 3: 1, 4: 2, 6: t, 9: l, 11: c, 13: u }, { 1: [3] }, { 3: 8, 4: 2, 5: [1, 7], 6: t, 9: l, 11: c, 13: u }, { 5: [1, 9] }, { 10: [1, 10] }, { 12: [1, 11] }, e(d, [2, 6]), { 3: 12, 4: 2, 6: t, 9: l, 11: c, 13: u }, { 1: [2, 2] }, { 4: 17, 5: f, 7: 13, 8: h, 9: l, 11: c, 13: u, 14: 14, 15: 15, 16: 16, 17: 19, 23: 21, 31: o, 32: E, 33: R, 34: A, 35: T, 36: N, 44: w, 62: k, 63: x }, e(d, [2, 4]), e(d, [2, 5]), { 1: [2, 1] }, { 8: [1, 30] }, { 4: 17, 5: f, 7: 31, 8: h, 9: l, 11: c, 13: u, 14: 14, 15: 15, 16: 16, 17: 19, 23: 21, 31: o, 32: E, 33: R, 34: A, 35: T, 36: N, 44: w, 62: k, 63: x }, { 4: 17, 5: f, 7: 32, 8: h, 9: l, 11: c, 13: u, 14: 14, 15: 15, 16: 16, 17: 19, 23: 21, 31: o, 32: E, 33: R, 34: A, 35: T, 36: N, 44: w, 62: k, 63: x }, { 4: 17, 5: f, 7: 33, 8: h, 9: l, 11: c, 13: u, 14: 14, 15: 15, 16: 16, 17: 19, 23: 21, 31: o, 32: E, 33: R, 34: A, 35: T, 36: N, 44: w, 62: k, 63: x }, { 4: 17, 5: f, 7: 34, 8: h, 9: l, 11: c, 13: u, 14: 14, 15: 15, 16: 16, 17: 19, 23: 21, 31: o, 32: E, 33: R, 34: A, 35: T, 36: N, 44: w, 62: k, 63: x }, { 4: 17, 5: f, 7: 35, 8: h, 9: l, 11: c, 13: u, 14: 14, 15: 15, 16: 16, 17: 19, 23: 21, 31: o, 32: E, 33: R, 34: A, 35: T, 36: N, 44: w, 62: k, 63: x }, { 18: 36, 62: [1, 37], 63: [1, 38] }, { 45: 39, 62: [1, 40], 63: [1, 41] }, { 51: [1, 42], 53: [1, 43] }, e(F, [2, 20]), e(F, [2, 21]), e(F, [2, 22]), e(F, [2, 23]), e(F, [2, 24]), e(F, [2, 25]), e(de, [2, 49]), e(de, [2, 50]), { 1: [2, 3] }, { 8: [2, 8] }, { 8: [2, 9] }, { 8: [2, 10] }, { 8: [2, 11] }, { 8: [2, 12] }, { 19: [1, 44] }, { 19: [2, 47] }, { 19: [2, 48] }, { 19: [1, 45] }, { 19: [2, 53] }, { 19: [2, 54] }, { 52: 46, 55: fe, 56: pe, 57: ye, 58: _e, 59: Ee, 60: ge, 61: Re }, { 52: 54, 55: fe, 56: pe, 57: ye, 58: _e, 59: Ee, 60: ge, 61: Re }, { 5: [1, 55] }, { 5: [1, 56] }, { 53: [1, 57] }, e(O, [2, 40]), e(O, [2, 41]), e(O, [2, 42]), e(O, [2, 43]), e(O, [2, 44]), e(O, [2, 45]), e(O, [2, 46]), { 54: [1, 58] }, { 5: M, 20: 59, 21: D, 24: P, 26: Y, 28: U, 30: B }, { 5: j, 30: z, 46: 66, 47: X, 49: J }, { 23: 71, 62: k, 63: x }, { 23: 72, 62: k, 63: x }, e(m, [2, 13]), { 22: [1, 73] }, { 22: [1, 74] }, { 22: [1, 75] }, { 22: [1, 76] }, { 5: M, 20: 77, 21: D, 24: P, 26: Y, 28: U, 30: B }, e(m, [2, 19]), e(m, [2, 33]), { 22: [1, 78] }, { 22: [1, 79] }, { 5: j, 30: z, 46: 80, 47: X, 49: J }, e(m, [2, 37]), e(m, [2, 38]), e(m, [2, 39]), { 23: 81, 62: k, 63: x }, { 25: 82, 62: [1, 83], 63: [1, 84] }, { 27: 85, 37: [1, 86], 38: [1, 87], 39: [1, 88] }, { 29: 89, 40: [1, 90], 41: [1, 91], 42: [1, 92], 43: [1, 93] }, e(m, [2, 18]), { 48: 94, 62: [1, 95], 63: [1, 96] }, { 50: 97, 62: [1, 98], 63: [1, 99] }, e(m, [2, 36]), { 5: [1, 100] }, { 5: [1, 101] }, { 5: [2, 51] }, { 5: [2, 52] }, { 5: [1, 102] }, { 5: [2, 26] }, { 5: [2, 27] }, { 5: [2, 28] }, { 5: [1, 103] }, { 5: [2, 29] }, { 5: [2, 30] }, { 5: [2, 31] }, { 5: [2, 32] }, { 5: [1, 104] }, { 5: [2, 55] }, { 5: [2, 56] }, { 5: [1, 105] }, { 5: [2, 57] }, { 5: [2, 58] }, { 5: M, 20: 106, 21: D, 24: P, 26: Y, 28: U, 30: B }, { 5: M, 20: 107, 21: D, 24: P, 26: Y, 28: U, 30: B }, { 5: M, 20: 108, 21: D, 24: P, 26: Y, 28: U, 30: B }, { 5: M, 20: 109, 21: D, 24: P, 26: Y, 28: U, 30: B }, { 5: j, 30: z, 46: 110, 47: X, 49: J }, { 5: j, 30: z, 46: 111, 47: X, 49: J }, e(m, [2, 14]), e(m, [2, 15]), e(m, [2, 16]), e(m, [2, 17]), e(m, [2, 34]), e(m, [2, 35])], + defaultActions: { 8: [2, 2], 12: [2, 1], 30: [2, 3], 31: [2, 8], 32: [2, 9], 33: [2, 10], 34: [2, 11], 35: [2, 12], 37: [2, 47], 38: [2, 48], 40: [2, 53], 41: [2, 54], 83: [2, 51], 84: [2, 52], 86: [2, 26], 87: [2, 27], 88: [2, 28], 90: [2, 29], 91: [2, 30], 92: [2, 31], 93: [2, 32], 95: [2, 55], 96: [2, 56], 98: [2, 57], 99: [2, 58] }, + parseError: function(i, r) { + if (r.recoverable) + this.trace(i); + else { + var a = new Error(i); + throw a.hash = r, a; + } + }, + parse: function(i) { + var r = this, a = [0], n = [], p = [null], s = [], W = this.table, _ = "", Z = 0, me = 0, Ve = 2, Ie = 1, qe = s.slice.call(arguments, 1), g = Object.create(this.lexer), L = { yy: {} }; + for (var re in this.yy) + Object.prototype.hasOwnProperty.call(this.yy, re) && (L.yy[re] = this.yy[re]); + g.setInput(i, L.yy), L.yy.lexer = g, L.yy.parser = this, typeof g.yylloc > "u" && (g.yylloc = {}); + var se = g.yylloc; + s.push(se); + var Oe = g.options && g.options.ranges; + typeof L.yy.parseError == "function" ? this.parseError = L.yy.parseError : this.parseError = Object.getPrototypeOf(this).parseError; + function Le() { + var v; + return v = n.pop() || g.lex() || Ie, typeof v != "number" && (v instanceof Array && (n = v, v = n.pop()), v = r.symbols_[v] || v), v; + } + for (var I, C, S, ae, Q = {}, ee, $, be, te; ; ) { + if (C = a[a.length - 1], this.defaultActions[C] ? S = this.defaultActions[C] : ((I === null || typeof I > "u") && (I = Le()), S = W[C] && W[C][I]), typeof S > "u" || !S.length || !S[0]) { + var le = ""; + te = []; + for (ee in W[C]) + this.terminals_[ee] && ee > Ve && te.push("'" + this.terminals_[ee] + "'"); + g.showPosition ? le = "Parse error on line " + (Z + 1) + `: +` + g.showPosition() + ` +Expecting ` + te.join(", ") + ", got '" + (this.terminals_[I] || I) + "'" : le = "Parse error on line " + (Z + 1) + ": Unexpected " + (I == Ie ? "end of input" : "'" + (this.terminals_[I] || I) + "'"), this.parseError(le, { + text: g.match, + token: this.terminals_[I] || I, + line: g.yylineno, + loc: se, + expected: te + }); + } + if (S[0] instanceof Array && S.length > 1) + throw new Error("Parse Error: multiple actions possible at state: " + C + ", token: " + I); + switch (S[0]) { + case 1: + a.push(I), p.push(g.yytext), s.push(g.yylloc), a.push(S[1]), I = null, me = g.yyleng, _ = g.yytext, Z = g.yylineno, se = g.yylloc; + break; + case 2: + if ($ = this.productions_[S[1]][1], Q.$ = p[p.length - $], Q._$ = { + first_line: s[s.length - ($ || 1)].first_line, + last_line: s[s.length - 1].last_line, + first_column: s[s.length - ($ || 1)].first_column, + last_column: s[s.length - 1].last_column + }, Oe && (Q._$.range = [ + s[s.length - ($ || 1)].range[0], + s[s.length - 1].range[1] + ]), ae = this.performAction.apply(Q, [ + _, + me, + Z, + L.yy, + S[1], + p, + s + ].concat(qe)), typeof ae < "u") + return ae; + $ && (a = a.slice(0, -1 * $ * 2), p = p.slice(0, -1 * $), s = s.slice(0, -1 * $)), a.push(this.productions_[S[1]][0]), p.push(Q.$), s.push(Q._$), be = W[a[a.length - 2]][a[a.length - 1]], a.push(be); + break; + case 3: + return !0; + } + } + return !0; + } + }, ve = function() { + var V = { + EOF: 1, + parseError: function(r, a) { + if (this.yy.parser) + this.yy.parser.parseError(r, a); + else + throw new Error(r); + }, + // resets the lexer, sets new input + setInput: function(i, r) { + return this.yy = r || this.yy || {}, this._input = i, 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 i = this._input[0]; + this.yytext += i, this.yyleng++, this.offset++, this.match += i, this.matched += i; + var r = i.match(/(?:\r\n?|\n).*/g); + return r ? (this.yylineno++, this.yylloc.last_line++) : this.yylloc.last_column++, this.options.ranges && this.yylloc.range[1]++, this._input = this._input.slice(1), i; + }, + // unshifts one char (or a string) into the input + unput: function(i) { + var r = i.length, a = i.split(/(?:\r\n?|\n)/g); + this._input = i + this._input, this.yytext = this.yytext.substr(0, this.yytext.length - r), this.offset -= r; + var n = this.match.split(/(?:\r\n?|\n)/g); + this.match = this.match.substr(0, this.match.length - 1), this.matched = this.matched.substr(0, this.matched.length - 1), a.length - 1 && (this.yylineno -= a.length - 1); + var p = this.yylloc.range; + return this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: a ? (a.length === n.length ? this.yylloc.first_column : 0) + n[n.length - a.length].length - a[0].length : this.yylloc.first_column - r + }, this.options.ranges && (this.yylloc.range = [p[0], p[0] + this.yyleng - r]), 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(i) { + this.unput(this.match.slice(i)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var i = this.matched.substr(0, this.matched.length - this.match.length); + return (i.length > 20 ? "..." : "") + i.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var i = this.match; + return i.length < 20 && (i += this._input.substr(0, 20 - i.length)), (i.substr(0, 20) + (i.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var i = this.pastInput(), r = new Array(i.length + 1).join("-"); + return i + this.upcomingInput() + ` +` + r + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(i, r) { + var a, n, p; + if (this.options.backtrack_lexer && (p = { + 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 && (p.yylloc.range = this.yylloc.range.slice(0))), n = i[0].match(/(?:\r\n?|\n).*/g), n && (this.yylineno += n.length), this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: n ? n[n.length - 1].length - n[n.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + i[0].length + }, this.yytext += i[0], this.match += i[0], this.matches = i, 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(i[0].length), this.matched += i[0], a = this.performAction.call(this, this.yy, this, r, this.conditionStack[this.conditionStack.length - 1]), this.done && this._input && (this.done = !1), a) + return a; + if (this._backtrack) { + for (var s in p) + this[s] = p[s]; + return !1; + } + return !1; + }, + // return next match in input + next: function() { + if (this.done) + return this.EOF; + this._input || (this.done = !0); + var i, r, a, n; + this._more || (this.yytext = "", this.match = ""); + for (var p = this._currentRules(), s = 0; s < p.length; s++) + if (a = this._input.match(this.rules[p[s]]), a && (!r || a[0].length > r[0].length)) { + if (r = a, n = s, this.options.backtrack_lexer) { + if (i = this.test_match(a, p[s]), i !== !1) + return i; + if (this._backtrack) { + r = !1; + continue; + } else + return !1; + } else if (!this.options.flex) + break; + } + return r ? (i = this.test_match(r, p[n]), i !== !1 ? i : !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 r = this.next(); + return r || this.lex(); + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function(r) { + this.conditionStack.push(r); + }, + // pop the previously active lexer condition state off the condition stack + popState: function() { + var r = this.conditionStack.length - 1; + return r > 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(r) { + return r = this.conditionStack.length - 1 - Math.abs(r || 0), r >= 0 ? this.conditionStack[r] : "INITIAL"; + }, + // alias for begin(condition) + pushState: function(r) { + this.begin(r); + }, + // return the number of states currently on the stack + stateStackSize: function() { + return this.conditionStack.length; + }, + options: { "case-insensitive": !0 }, + performAction: function(r, a, n, p) { + switch (n) { + case 0: + return "title"; + case 1: + return this.begin("acc_title"), 9; + case 2: + return this.popState(), "acc_title_value"; + case 3: + return this.begin("acc_descr"), 11; + case 4: + return this.popState(), "acc_descr_value"; + case 5: + this.begin("acc_descr_multiline"); + break; + case 6: + this.popState(); + break; + case 7: + return "acc_descr_multiline_value"; + case 8: + return 5; + case 9: + break; + case 10: + break; + case 11: + break; + case 12: + return 8; + case 13: + return 6; + case 14: + return 19; + case 15: + return 30; + case 16: + return 22; + case 17: + return 21; + case 18: + return 24; + case 19: + return 26; + case 20: + return 28; + case 21: + return 31; + case 22: + return 32; + case 23: + return 33; + case 24: + return 34; + case 25: + return 35; + case 26: + return 36; + case 27: + return 37; + case 28: + return 38; + case 29: + return 39; + case 30: + return 40; + case 31: + return 41; + case 32: + return 42; + case 33: + return 43; + case 34: + return 44; + case 35: + return 55; + case 36: + return 56; + case 37: + return 57; + case 38: + return 58; + case 39: + return 59; + case 40: + return 60; + case 41: + return 61; + case 42: + return 47; + case 43: + return 49; + case 44: + return 51; + case 45: + return 54; + case 46: + return 53; + case 47: + this.begin("string"); + break; + case 48: + this.popState(); + break; + case 49: + return "qString"; + case 50: + return a.yytext = a.yytext.trim(), 62; + } + }, + rules: [/^(?:title\s[^#\n;]+)/i, /^(?:accTitle\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*\{\s*)/i, /^(?:[\}])/i, /^(?:[^\}]*)/i, /^(?:(\r?\n)+)/i, /^(?:\s+)/i, /^(?:#[^\n]*)/i, /^(?:%[^\n]*)/i, /^(?:$)/i, /^(?:requirementDiagram\b)/i, /^(?:\{)/i, /^(?:\})/i, /^(?::)/i, /^(?:id\b)/i, /^(?:text\b)/i, /^(?:risk\b)/i, /^(?:verifyMethod\b)/i, /^(?:requirement\b)/i, /^(?:functionalRequirement\b)/i, /^(?:interfaceRequirement\b)/i, /^(?:performanceRequirement\b)/i, /^(?:physicalRequirement\b)/i, /^(?:designConstraint\b)/i, /^(?:low\b)/i, /^(?:medium\b)/i, /^(?:high\b)/i, /^(?:analysis\b)/i, /^(?:demonstration\b)/i, /^(?:inspection\b)/i, /^(?:test\b)/i, /^(?:element\b)/i, /^(?:contains\b)/i, /^(?:copies\b)/i, /^(?:derives\b)/i, /^(?:satisfies\b)/i, /^(?:verifies\b)/i, /^(?:refines\b)/i, /^(?:traces\b)/i, /^(?:type\b)/i, /^(?:docref\b)/i, /^(?:<-)/i, /^(?:->)/i, /^(?:-)/i, /^(?:["])/i, /^(?:["])/i, /^(?:[^"]*)/i, /^(?:[\w][^\r\n\{\<\>\-\=]*)/i], + conditions: { acc_descr_multiline: { rules: [6, 7], inclusive: !1 }, acc_descr: { rules: [4], inclusive: !1 }, acc_title: { rules: [2], inclusive: !1 }, unqString: { rules: [], inclusive: !1 }, token: { rules: [], inclusive: !1 }, string: { rules: [48, 49], inclusive: !1 }, INITIAL: { rules: [0, 1, 3, 5, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 50], inclusive: !0 } } + }; + return V; + }(); + ie.lexer = ve; + function ne() { + this.yy = {}; + } + return ne.prototype = ie, ie.Parser = ne, new ne(); +}(); +ce.parser = ce; +const He = ce; +let ue = [], b = {}, K = {}, q = {}, G = {}; +const We = { + REQUIREMENT: "Requirement", + FUNCTIONAL_REQUIREMENT: "Functional Requirement", + INTERFACE_REQUIREMENT: "Interface Requirement", + PERFORMANCE_REQUIREMENT: "Performance Requirement", + PHYSICAL_REQUIREMENT: "Physical Requirement", + DESIGN_CONSTRAINT: "Design Constraint" +}, Ke = { + LOW_RISK: "Low", + MED_RISK: "Medium", + HIGH_RISK: "High" +}, Ge = { + VERIFY_ANALYSIS: "Analysis", + VERIFY_DEMONSTRATION: "Demonstration", + VERIFY_INSPECTION: "Inspection", + VERIFY_TEST: "Test" +}, je = { + CONTAINS: "contains", + COPIES: "copies", + DERIVES: "derives", + SATISFIES: "satisfies", + VERIFIES: "verifies", + REFINES: "refines", + TRACES: "traces" +}, ze = (e, t) => (K[e] === void 0 && (K[e] = { + name: e, + type: t, + id: b.id, + text: b.text, + risk: b.risk, + verifyMethod: b.verifyMethod +}), b = {}, K[e]), Xe = () => K, Je = (e) => { + b !== void 0 && (b.id = e); +}, Ze = (e) => { + b !== void 0 && (b.text = e); +}, et = (e) => { + b !== void 0 && (b.risk = e); +}, tt = (e) => { + b !== void 0 && (b.verifyMethod = e); +}, it = (e) => (G[e] === void 0 && (G[e] = { + name: e, + type: q.type, + docRef: q.docRef +}, Ne.info("Added new requirement: ", e)), q = {}, G[e]), nt = () => G, rt = (e) => { + q !== void 0 && (q.type = e); +}, st = (e) => { + q !== void 0 && (q.docRef = e); +}, at = (e, t, l) => { + ue.push({ + type: e, + src: t, + dst: l + }); +}, lt = () => ue, ot = () => { + ue = [], b = {}, K = {}, q = {}, G = {}, Pe(); +}, ct = { + RequirementType: We, + RiskLevel: Ke, + VerifyType: Ge, + Relationships: je, + getConfig: () => Te().req, + addRequirement: ze, + getRequirements: Xe, + setNewReqId: Je, + setNewReqText: Ze, + setNewReqRisk: et, + setNewReqVerifyMethod: tt, + setAccTitle: Ce, + getAccTitle: Fe, + setAccDescription: Me, + getAccDescription: De, + addElement: it, + getElements: nt, + setNewElementType: rt, + setNewElementDocRef: st, + addRelationship: at, + getRelationships: lt, + clear: ot +}, ht = (e) => ` + + marker { + fill: ${e.relationColor}; + stroke: ${e.relationColor}; + } + + marker.cross { + stroke: ${e.lineColor}; + } + + svg { + font-family: ${e.fontFamily}; + font-size: ${e.fontSize}; + } + + .reqBox { + fill: ${e.requirementBackground}; + fill-opacity: 1.0; + stroke: ${e.requirementBorderColor}; + stroke-width: ${e.requirementBorderSize}; + } + + .reqTitle, .reqLabel{ + fill: ${e.requirementTextColor}; + } + .reqLabelBox { + fill: ${e.relationLabelBackground}; + fill-opacity: 1.0; + } + + .req-title-line { + stroke: ${e.requirementBorderColor}; + stroke-width: ${e.requirementBorderSize}; + } + .relationshipLine { + stroke: ${e.relationColor}; + stroke-width: 1; + } + .relationshipLabel { + fill: ${e.relationLabelColor}; + } + +`, ut = ht, he = { + CONTAINS: "contains", + ARROW: "arrow" +}, dt = (e, t) => { + let l = e.append("defs").append("marker").attr("id", he.CONTAINS + "_line_ending").attr("refX", 0).attr("refY", t.line_height / 2).attr("markerWidth", t.line_height).attr("markerHeight", t.line_height).attr("orient", "auto").append("g"); + l.append("circle").attr("cx", t.line_height / 2).attr("cy", t.line_height / 2).attr("r", t.line_height / 2).attr("fill", "none"), l.append("line").attr("x1", 0).attr("x2", t.line_height).attr("y1", t.line_height / 2).attr("y2", t.line_height / 2).attr("stroke-width", 1), l.append("line").attr("y1", 0).attr("y2", t.line_height).attr("x1", t.line_height / 2).attr("x2", t.line_height / 2).attr("stroke-width", 1), e.append("defs").append("marker").attr("id", he.ARROW + "_line_ending").attr("refX", t.line_height).attr("refY", 0.5 * t.line_height).attr("markerWidth", t.line_height).attr("markerHeight", t.line_height).attr("orient", "auto").append("path").attr( + "d", + `M0,0 + L${t.line_height},${t.line_height / 2} + M${t.line_height},${t.line_height / 2} + L0,${t.line_height}` + ).attr("stroke-width", 1); +}, xe = { + ReqMarkers: he, + insertLineEndings: dt +}; +let y = {}, Se = 0; +const Ae = (e, t) => e.insert("rect", "#" + t).attr("class", "req reqBox").attr("x", 0).attr("y", 0).attr("width", y.rect_min_width + "px").attr("height", y.rect_min_height + "px"), we = (e, t, l) => { + let c = y.rect_min_width / 2, u = e.append("text").attr("class", "req reqLabel reqTitle").attr("id", t).attr("x", c).attr("y", y.rect_padding).attr("dominant-baseline", "hanging"), d = 0; + l.forEach((E) => { + d == 0 ? u.append("tspan").attr("text-anchor", "middle").attr("x", y.rect_min_width / 2).attr("dy", 0).text(E) : u.append("tspan").attr("text-anchor", "middle").attr("x", y.rect_min_width / 2).attr("dy", y.line_height * 0.75).text(E), d++; + }); + let f = 1.5 * y.rect_padding, h = d * y.line_height * 0.75, o = f + h; + return e.append("line").attr("class", "req-title-line").attr("x1", "0").attr("x2", y.rect_min_width).attr("y1", o).attr("y2", o), { + titleNode: u, + y: o + }; +}, $e = (e, t, l, c) => { + let u = e.append("text").attr("class", "req reqLabel").attr("id", t).attr("x", y.rect_padding).attr("y", c).attr("dominant-baseline", "hanging"), d = 0; + const f = 30; + let h = []; + return l.forEach((o) => { + let E = o.length; + for (; E > f && d < 3; ) { + let R = o.substring(0, f); + o = o.substring(f, o.length), E = o.length, h[h.length] = R, d++; + } + if (d == 3) { + let R = h[h.length - 1]; + h[h.length - 1] = R.substring(0, R.length - 4) + "..."; + } else + h[h.length] = o; + d = 0; + }), h.forEach((o) => { + u.append("tspan").attr("x", y.rect_padding).attr("dy", y.line_height).text(o); + }), u; +}, ft = (e, t, l, c) => { + const u = t.node().getTotalLength(), d = t.node().getPointAtLength(u * 0.5), f = "rel" + Se; + Se++; + const o = e.append("text").attr("class", "req relationshipLabel").attr("id", f).attr("x", d.x).attr("y", d.y).attr("text-anchor", "middle").attr("dominant-baseline", "middle").text(c).node().getBBox(); + e.insert("rect", "#" + f).attr("class", "req reqLabelBox").attr("x", d.x - o.width / 2).attr("y", d.y - o.height / 2).attr("width", o.width).attr("height", o.height).attr("fill", "white").attr("fill-opacity", "85%"); +}, pt = function(e, t, l, c, u) { + const d = l.edge(H(t.src), H(t.dst)), f = Qe().x(function(o) { + return o.x; + }).y(function(o) { + return o.y; + }), h = e.insert("path", "#" + c).attr("class", "er relationshipLine").attr("d", f(d.points)).attr("fill", "none"); + t.type == u.db.Relationships.CONTAINS ? h.attr( + "marker-start", + "url(" + ke.getUrl(y.arrowMarkerAbsolute) + "#" + t.type + "_line_ending)" + ) : (h.attr("stroke-dasharray", "10,7"), h.attr( + "marker-end", + "url(" + ke.getUrl(y.arrowMarkerAbsolute) + "#" + xe.ReqMarkers.ARROW + "_line_ending)" + )), ft(e, h, y, `<<${t.type}>>`); +}, yt = (e, t, l) => { + Object.keys(e).forEach((c) => { + let u = e[c]; + c = H(c), Ne.info("Added new requirement: ", c); + const d = l.append("g").attr("id", c), f = "req-" + c, h = Ae(d, f); + let o = we(d, c + "_title", [ + `<<${u.type}>>`, + `${u.name}` + ]); + $e( + d, + c + "_body", + [ + `Id: ${u.id}`, + `Text: ${u.text}`, + `Risk: ${u.risk}`, + `Verification: ${u.verifyMethod}` + ], + o.y + ); + const E = h.node().getBBox(); + t.setNode(c, { + width: E.width, + height: E.height, + shape: "rect", + id: c + }); + }); +}, _t = (e, t, l) => { + Object.keys(e).forEach((c) => { + let u = e[c]; + const d = H(c), f = l.append("g").attr("id", d), h = "element-" + d, o = Ae(f, h); + let E = we(f, h + "_title", ["<>", `${c}`]); + $e( + f, + h + "_body", + [`Type: ${u.type || "Not Specified"}`, `Doc Ref: ${u.docRef || "None"}`], + E.y + ); + const R = o.node().getBBox(); + t.setNode(d, { + width: R.width, + height: R.height, + shape: "rect", + id: d + }); + }); +}, Et = (e, t) => (e.forEach(function(l) { + let c = H(l.src), u = H(l.dst); + t.setEdge(c, u, { relationship: l }); +}), e), gt = function(e, t) { + t.nodes().forEach(function(l) { + l !== void 0 && t.node(l) !== void 0 && (e.select("#" + l), e.select("#" + l).attr( + "transform", + "translate(" + (t.node(l).x - t.node(l).width / 2) + "," + (t.node(l).y - t.node(l).height / 2) + " )" + )); + }); +}, H = (e) => e.replace(/\s/g, "").replace(/\./g, "_"), Rt = (e, t, l, c) => { + y = Te().requirement; + const u = y.securityLevel; + let d; + u === "sandbox" && (d = oe("#i" + t)); + const h = (u === "sandbox" ? oe(d.nodes()[0].contentDocument.body) : oe("body")).select(`[id='${t}']`); + xe.insertLineEndings(h, y); + const o = new Ue({ + multigraph: !1, + compound: !1, + directed: !0 + }).setGraph({ + rankdir: y.layoutDirection, + marginx: 20, + marginy: 20, + nodesep: 100, + edgesep: 100, + ranksep: 100 + }).setDefaultEdgeLabel(function() { + return {}; + }); + let E = c.db.getRequirements(), R = c.db.getElements(), A = c.db.getRelationships(); + yt(E, o, h), _t(R, o, h), Et(A, o), Be(o), gt(h, o), A.forEach(function(x) { + pt(h, x, o, t, c); + }); + const T = y.rect_padding, N = h.node().getBBox(), w = N.width + T * 2, k = N.height + T * 2; + Ye(h, k, w, y.useMaxWidth), h.attr("viewBox", `${N.x - T} ${N.y - T} ${w} ${k}`); +}, mt = { + draw: Rt +}, xt = { + parser: He, + db: ct, + renderer: mt, + styles: ut +}; +export { + xt as diagram +}; diff --git a/0.6.0/js/mermaid/requirementDiagram-87253d64.js b/0.6.0/js/mermaid/requirementDiagram-87253d64.js new file mode 100644 index 0000000..c8a0363 --- /dev/null +++ b/0.6.0/js/mermaid/requirementDiagram-87253d64.js @@ -0,0 +1,1098 @@ +import { c as getConfig, s as setAccTitle, g as getAccTitle, b as setAccDescription, a as getAccDescription, l as log, v as clear$1, i as configureSvgSize, e as common } from "./mermaid-6dc72991.js"; +import { select, line } from "d3"; +import { layout } from "dagre-d3-es/src/dagre/index.js"; +import * as graphlib from "dagre-d3-es/src/graphlib/index.js"; +import "ts-dedent"; +import "dayjs"; +import "@braintree/sanitize-url"; +import "dompurify"; +import "khroma"; +import "lodash-es/memoize.js"; +import "lodash-es/merge.js"; +import "stylis"; +import "lodash-es/isEmpty.js"; +var parser = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 3], $V1 = [1, 4], $V2 = [1, 5], $V3 = [1, 6], $V4 = [5, 6, 8, 9, 11, 13, 31, 32, 33, 34, 35, 36, 44, 62, 63], $V5 = [1, 18], $V6 = [2, 7], $V7 = [1, 22], $V8 = [1, 23], $V9 = [1, 24], $Va = [1, 25], $Vb = [1, 26], $Vc = [1, 27], $Vd = [1, 20], $Ve = [1, 28], $Vf = [1, 29], $Vg = [62, 63], $Vh = [5, 8, 9, 11, 13, 31, 32, 33, 34, 35, 36, 44, 51, 53, 62, 63], $Vi = [1, 47], $Vj = [1, 48], $Vk = [1, 49], $Vl = [1, 50], $Vm = [1, 51], $Vn = [1, 52], $Vo = [1, 53], $Vp = [53, 54], $Vq = [1, 64], $Vr = [1, 60], $Vs = [1, 61], $Vt = [1, 62], $Vu = [1, 63], $Vv = [1, 65], $Vw = [1, 69], $Vx = [1, 70], $Vy = [1, 67], $Vz = [1, 68], $VA = [5, 8, 9, 11, 13, 31, 32, 33, 34, 35, 36, 44, 62, 63]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "directive": 4, "NEWLINE": 5, "RD": 6, "diagram": 7, "EOF": 8, "acc_title": 9, "acc_title_value": 10, "acc_descr": 11, "acc_descr_value": 12, "acc_descr_multiline_value": 13, "requirementDef": 14, "elementDef": 15, "relationshipDef": 16, "requirementType": 17, "requirementName": 18, "STRUCT_START": 19, "requirementBody": 20, "ID": 21, "COLONSEP": 22, "id": 23, "TEXT": 24, "text": 25, "RISK": 26, "riskLevel": 27, "VERIFYMTHD": 28, "verifyType": 29, "STRUCT_STOP": 30, "REQUIREMENT": 31, "FUNCTIONAL_REQUIREMENT": 32, "INTERFACE_REQUIREMENT": 33, "PERFORMANCE_REQUIREMENT": 34, "PHYSICAL_REQUIREMENT": 35, "DESIGN_CONSTRAINT": 36, "LOW_RISK": 37, "MED_RISK": 38, "HIGH_RISK": 39, "VERIFY_ANALYSIS": 40, "VERIFY_DEMONSTRATION": 41, "VERIFY_INSPECTION": 42, "VERIFY_TEST": 43, "ELEMENT": 44, "elementName": 45, "elementBody": 46, "TYPE": 47, "type": 48, "DOCREF": 49, "ref": 50, "END_ARROW_L": 51, "relationship": 52, "LINE": 53, "END_ARROW_R": 54, "CONTAINS": 55, "COPIES": 56, "DERIVES": 57, "SATISFIES": 58, "VERIFIES": 59, "REFINES": 60, "TRACES": 61, "unqString": 62, "qString": 63, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 5: "NEWLINE", 6: "RD", 8: "EOF", 9: "acc_title", 10: "acc_title_value", 11: "acc_descr", 12: "acc_descr_value", 13: "acc_descr_multiline_value", 19: "STRUCT_START", 21: "ID", 22: "COLONSEP", 24: "TEXT", 26: "RISK", 28: "VERIFYMTHD", 30: "STRUCT_STOP", 31: "REQUIREMENT", 32: "FUNCTIONAL_REQUIREMENT", 33: "INTERFACE_REQUIREMENT", 34: "PERFORMANCE_REQUIREMENT", 35: "PHYSICAL_REQUIREMENT", 36: "DESIGN_CONSTRAINT", 37: "LOW_RISK", 38: "MED_RISK", 39: "HIGH_RISK", 40: "VERIFY_ANALYSIS", 41: "VERIFY_DEMONSTRATION", 42: "VERIFY_INSPECTION", 43: "VERIFY_TEST", 44: "ELEMENT", 47: "TYPE", 49: "DOCREF", 51: "END_ARROW_L", 53: "LINE", 54: "END_ARROW_R", 55: "CONTAINS", 56: "COPIES", 57: "DERIVES", 58: "SATISFIES", 59: "VERIFIES", 60: "REFINES", 61: "TRACES", 62: "unqString", 63: "qString" }, + productions_: [0, [3, 3], [3, 2], [3, 4], [4, 2], [4, 2], [4, 1], [7, 0], [7, 2], [7, 2], [7, 2], [7, 2], [7, 2], [14, 5], [20, 5], [20, 5], [20, 5], [20, 5], [20, 2], [20, 1], [17, 1], [17, 1], [17, 1], [17, 1], [17, 1], [17, 1], [27, 1], [27, 1], [27, 1], [29, 1], [29, 1], [29, 1], [29, 1], [15, 5], [46, 5], [46, 5], [46, 2], [46, 1], [16, 5], [16, 5], [52, 1], [52, 1], [52, 1], [52, 1], [52, 1], [52, 1], [52, 1], [18, 1], [18, 1], [23, 1], [23, 1], [25, 1], [25, 1], [45, 1], [45, 1], [48, 1], [48, 1], [50, 1], [50, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 4: + this.$ = $$[$0].trim(); + yy.setAccTitle(this.$); + break; + case 5: + case 6: + this.$ = $$[$0].trim(); + yy.setAccDescription(this.$); + break; + case 7: + this.$ = []; + break; + case 13: + yy.addRequirement($$[$0 - 3], $$[$0 - 4]); + break; + case 14: + yy.setNewReqId($$[$0 - 2]); + break; + case 15: + yy.setNewReqText($$[$0 - 2]); + break; + case 16: + yy.setNewReqRisk($$[$0 - 2]); + break; + case 17: + yy.setNewReqVerifyMethod($$[$0 - 2]); + break; + case 20: + this.$ = yy.RequirementType.REQUIREMENT; + break; + case 21: + this.$ = yy.RequirementType.FUNCTIONAL_REQUIREMENT; + break; + case 22: + this.$ = yy.RequirementType.INTERFACE_REQUIREMENT; + break; + case 23: + this.$ = yy.RequirementType.PERFORMANCE_REQUIREMENT; + break; + case 24: + this.$ = yy.RequirementType.PHYSICAL_REQUIREMENT; + break; + case 25: + this.$ = yy.RequirementType.DESIGN_CONSTRAINT; + break; + case 26: + this.$ = yy.RiskLevel.LOW_RISK; + break; + case 27: + this.$ = yy.RiskLevel.MED_RISK; + break; + case 28: + this.$ = yy.RiskLevel.HIGH_RISK; + break; + case 29: + this.$ = yy.VerifyType.VERIFY_ANALYSIS; + break; + case 30: + this.$ = yy.VerifyType.VERIFY_DEMONSTRATION; + break; + case 31: + this.$ = yy.VerifyType.VERIFY_INSPECTION; + break; + case 32: + this.$ = yy.VerifyType.VERIFY_TEST; + break; + case 33: + yy.addElement($$[$0 - 3]); + break; + case 34: + yy.setNewElementType($$[$0 - 2]); + break; + case 35: + yy.setNewElementDocRef($$[$0 - 2]); + break; + case 38: + yy.addRelationship($$[$0 - 2], $$[$0], $$[$0 - 4]); + break; + case 39: + yy.addRelationship($$[$0 - 2], $$[$0 - 4], $$[$0]); + break; + case 40: + this.$ = yy.Relationships.CONTAINS; + break; + case 41: + this.$ = yy.Relationships.COPIES; + break; + case 42: + this.$ = yy.Relationships.DERIVES; + break; + case 43: + this.$ = yy.Relationships.SATISFIES; + break; + case 44: + this.$ = yy.Relationships.VERIFIES; + break; + case 45: + this.$ = yy.Relationships.REFINES; + break; + case 46: + this.$ = yy.Relationships.TRACES; + break; + } + }, + table: [{ 3: 1, 4: 2, 6: $V0, 9: $V1, 11: $V2, 13: $V3 }, { 1: [3] }, { 3: 8, 4: 2, 5: [1, 7], 6: $V0, 9: $V1, 11: $V2, 13: $V3 }, { 5: [1, 9] }, { 10: [1, 10] }, { 12: [1, 11] }, o($V4, [2, 6]), { 3: 12, 4: 2, 6: $V0, 9: $V1, 11: $V2, 13: $V3 }, { 1: [2, 2] }, { 4: 17, 5: $V5, 7: 13, 8: $V6, 9: $V1, 11: $V2, 13: $V3, 14: 14, 15: 15, 16: 16, 17: 19, 23: 21, 31: $V7, 32: $V8, 33: $V9, 34: $Va, 35: $Vb, 36: $Vc, 44: $Vd, 62: $Ve, 63: $Vf }, o($V4, [2, 4]), o($V4, [2, 5]), { 1: [2, 1] }, { 8: [1, 30] }, { 4: 17, 5: $V5, 7: 31, 8: $V6, 9: $V1, 11: $V2, 13: $V3, 14: 14, 15: 15, 16: 16, 17: 19, 23: 21, 31: $V7, 32: $V8, 33: $V9, 34: $Va, 35: $Vb, 36: $Vc, 44: $Vd, 62: $Ve, 63: $Vf }, { 4: 17, 5: $V5, 7: 32, 8: $V6, 9: $V1, 11: $V2, 13: $V3, 14: 14, 15: 15, 16: 16, 17: 19, 23: 21, 31: $V7, 32: $V8, 33: $V9, 34: $Va, 35: $Vb, 36: $Vc, 44: $Vd, 62: $Ve, 63: $Vf }, { 4: 17, 5: $V5, 7: 33, 8: $V6, 9: $V1, 11: $V2, 13: $V3, 14: 14, 15: 15, 16: 16, 17: 19, 23: 21, 31: $V7, 32: $V8, 33: $V9, 34: $Va, 35: $Vb, 36: $Vc, 44: $Vd, 62: $Ve, 63: $Vf }, { 4: 17, 5: $V5, 7: 34, 8: $V6, 9: $V1, 11: $V2, 13: $V3, 14: 14, 15: 15, 16: 16, 17: 19, 23: 21, 31: $V7, 32: $V8, 33: $V9, 34: $Va, 35: $Vb, 36: $Vc, 44: $Vd, 62: $Ve, 63: $Vf }, { 4: 17, 5: $V5, 7: 35, 8: $V6, 9: $V1, 11: $V2, 13: $V3, 14: 14, 15: 15, 16: 16, 17: 19, 23: 21, 31: $V7, 32: $V8, 33: $V9, 34: $Va, 35: $Vb, 36: $Vc, 44: $Vd, 62: $Ve, 63: $Vf }, { 18: 36, 62: [1, 37], 63: [1, 38] }, { 45: 39, 62: [1, 40], 63: [1, 41] }, { 51: [1, 42], 53: [1, 43] }, o($Vg, [2, 20]), o($Vg, [2, 21]), o($Vg, [2, 22]), o($Vg, [2, 23]), o($Vg, [2, 24]), o($Vg, [2, 25]), o($Vh, [2, 49]), o($Vh, [2, 50]), { 1: [2, 3] }, { 8: [2, 8] }, { 8: [2, 9] }, { 8: [2, 10] }, { 8: [2, 11] }, { 8: [2, 12] }, { 19: [1, 44] }, { 19: [2, 47] }, { 19: [2, 48] }, { 19: [1, 45] }, { 19: [2, 53] }, { 19: [2, 54] }, { 52: 46, 55: $Vi, 56: $Vj, 57: $Vk, 58: $Vl, 59: $Vm, 60: $Vn, 61: $Vo }, { 52: 54, 55: $Vi, 56: $Vj, 57: $Vk, 58: $Vl, 59: $Vm, 60: $Vn, 61: $Vo }, { 5: [1, 55] }, { 5: [1, 56] }, { 53: [1, 57] }, o($Vp, [2, 40]), o($Vp, [2, 41]), o($Vp, [2, 42]), o($Vp, [2, 43]), o($Vp, [2, 44]), o($Vp, [2, 45]), o($Vp, [2, 46]), { 54: [1, 58] }, { 5: $Vq, 20: 59, 21: $Vr, 24: $Vs, 26: $Vt, 28: $Vu, 30: $Vv }, { 5: $Vw, 30: $Vx, 46: 66, 47: $Vy, 49: $Vz }, { 23: 71, 62: $Ve, 63: $Vf }, { 23: 72, 62: $Ve, 63: $Vf }, o($VA, [2, 13]), { 22: [1, 73] }, { 22: [1, 74] }, { 22: [1, 75] }, { 22: [1, 76] }, { 5: $Vq, 20: 77, 21: $Vr, 24: $Vs, 26: $Vt, 28: $Vu, 30: $Vv }, o($VA, [2, 19]), o($VA, [2, 33]), { 22: [1, 78] }, { 22: [1, 79] }, { 5: $Vw, 30: $Vx, 46: 80, 47: $Vy, 49: $Vz }, o($VA, [2, 37]), o($VA, [2, 38]), o($VA, [2, 39]), { 23: 81, 62: $Ve, 63: $Vf }, { 25: 82, 62: [1, 83], 63: [1, 84] }, { 27: 85, 37: [1, 86], 38: [1, 87], 39: [1, 88] }, { 29: 89, 40: [1, 90], 41: [1, 91], 42: [1, 92], 43: [1, 93] }, o($VA, [2, 18]), { 48: 94, 62: [1, 95], 63: [1, 96] }, { 50: 97, 62: [1, 98], 63: [1, 99] }, o($VA, [2, 36]), { 5: [1, 100] }, { 5: [1, 101] }, { 5: [2, 51] }, { 5: [2, 52] }, { 5: [1, 102] }, { 5: [2, 26] }, { 5: [2, 27] }, { 5: [2, 28] }, { 5: [1, 103] }, { 5: [2, 29] }, { 5: [2, 30] }, { 5: [2, 31] }, { 5: [2, 32] }, { 5: [1, 104] }, { 5: [2, 55] }, { 5: [2, 56] }, { 5: [1, 105] }, { 5: [2, 57] }, { 5: [2, 58] }, { 5: $Vq, 20: 106, 21: $Vr, 24: $Vs, 26: $Vt, 28: $Vu, 30: $Vv }, { 5: $Vq, 20: 107, 21: $Vr, 24: $Vs, 26: $Vt, 28: $Vu, 30: $Vv }, { 5: $Vq, 20: 108, 21: $Vr, 24: $Vs, 26: $Vt, 28: $Vu, 30: $Vv }, { 5: $Vq, 20: 109, 21: $Vr, 24: $Vs, 26: $Vt, 28: $Vu, 30: $Vv }, { 5: $Vw, 30: $Vx, 46: 110, 47: $Vy, 49: $Vz }, { 5: $Vw, 30: $Vx, 46: 111, 47: $Vy, 49: $Vz }, o($VA, [2, 14]), o($VA, [2, 15]), o($VA, [2, 16]), o($VA, [2, 17]), o($VA, [2, 34]), o($VA, [2, 35])], + defaultActions: { 8: [2, 2], 12: [2, 1], 30: [2, 3], 31: [2, 8], 32: [2, 9], 33: [2, 10], 34: [2, 11], 35: [2, 12], 37: [2, 47], 38: [2, 48], 40: [2, 53], 41: [2, 54], 83: [2, 51], 84: [2, 52], 86: [2, 26], 87: [2, 27], 88: [2, 28], 90: [2, 29], 91: [2, 30], 92: [2, 31], 93: [2, 32], 95: [2, 55], 96: [2, 56], 98: [2, 57], 99: [2, 58] }, + parseError: function parseError(str, hash) { + if (hash.recoverable) { + this.trace(str); + } else { + var error = new Error(str); + error.hash = hash; + throw error; + } + }, + parse: function parse(input) { + var self = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex() { + var token; + token = tstack.pop() || lexer2.lex() || EOF; + if (typeof token !== "number") { + if (token instanceof Array) { + tstack = token; + token = tstack.pop(); + } + token = self.symbols_[token] || token; + } + return token; + } + var symbol, state, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state = stack[stack.length - 1]; + if (this.defaultActions[state]) { + action = this.defaultActions[state]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex(); + } + action = table[state] && table[state][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str, hash); + } else { + throw new Error(str); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch = this._input[0]; + this.yytext += ch; + this.yyleng++; + this.offset++; + this.match += ch; + this.matched += ch; + var lines = ch.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch; + }, + // unshifts one char (or a string) into the input + unput: function(ch) { + var len = ch.length; + var lines = ch.split(/(?:\r\n?|\n)/g); + this._input = ch + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next = this.match; + if (next.length < 20) { + next += this._input.substr(0, 20 - next.length); + } + return (next.substr(0, 20) + (next.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token) { + return token; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token, match, tempMatch, index; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i = 0; i < rules.length; i++) { + tempMatch = this._input.match(this.rules[rules[i]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index = i; + if (this.options.backtrack_lexer) { + token = this.test_match(tempMatch, rules[i]); + if (token !== false) { + return token; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token = this.test_match(match, rules[index]); + if (token !== false) { + return token; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + return "title"; + case 1: + this.begin("acc_title"); + return 9; + case 2: + this.popState(); + return "acc_title_value"; + case 3: + this.begin("acc_descr"); + return 11; + case 4: + this.popState(); + return "acc_descr_value"; + case 5: + this.begin("acc_descr_multiline"); + break; + case 6: + this.popState(); + break; + case 7: + return "acc_descr_multiline_value"; + case 8: + return 5; + case 9: + break; + case 10: + break; + case 11: + break; + case 12: + return 8; + case 13: + return 6; + case 14: + return 19; + case 15: + return 30; + case 16: + return 22; + case 17: + return 21; + case 18: + return 24; + case 19: + return 26; + case 20: + return 28; + case 21: + return 31; + case 22: + return 32; + case 23: + return 33; + case 24: + return 34; + case 25: + return 35; + case 26: + return 36; + case 27: + return 37; + case 28: + return 38; + case 29: + return 39; + case 30: + return 40; + case 31: + return 41; + case 32: + return 42; + case 33: + return 43; + case 34: + return 44; + case 35: + return 55; + case 36: + return 56; + case 37: + return 57; + case 38: + return 58; + case 39: + return 59; + case 40: + return 60; + case 41: + return 61; + case 42: + return 47; + case 43: + return 49; + case 44: + return 51; + case 45: + return 54; + case 46: + return 53; + case 47: + this.begin("string"); + break; + case 48: + this.popState(); + break; + case 49: + return "qString"; + case 50: + yy_.yytext = yy_.yytext.trim(); + return 62; + } + }, + rules: [/^(?:title\s[^#\n;]+)/i, /^(?:accTitle\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*\{\s*)/i, /^(?:[\}])/i, /^(?:[^\}]*)/i, /^(?:(\r?\n)+)/i, /^(?:\s+)/i, /^(?:#[^\n]*)/i, /^(?:%[^\n]*)/i, /^(?:$)/i, /^(?:requirementDiagram\b)/i, /^(?:\{)/i, /^(?:\})/i, /^(?::)/i, /^(?:id\b)/i, /^(?:text\b)/i, /^(?:risk\b)/i, /^(?:verifyMethod\b)/i, /^(?:requirement\b)/i, /^(?:functionalRequirement\b)/i, /^(?:interfaceRequirement\b)/i, /^(?:performanceRequirement\b)/i, /^(?:physicalRequirement\b)/i, /^(?:designConstraint\b)/i, /^(?:low\b)/i, /^(?:medium\b)/i, /^(?:high\b)/i, /^(?:analysis\b)/i, /^(?:demonstration\b)/i, /^(?:inspection\b)/i, /^(?:test\b)/i, /^(?:element\b)/i, /^(?:contains\b)/i, /^(?:copies\b)/i, /^(?:derives\b)/i, /^(?:satisfies\b)/i, /^(?:verifies\b)/i, /^(?:refines\b)/i, /^(?:traces\b)/i, /^(?:type\b)/i, /^(?:docref\b)/i, /^(?:<-)/i, /^(?:->)/i, /^(?:-)/i, /^(?:["])/i, /^(?:["])/i, /^(?:[^"]*)/i, /^(?:[\w][^\r\n\{\<\>\-\=]*)/i], + conditions: { "acc_descr_multiline": { "rules": [6, 7], "inclusive": false }, "acc_descr": { "rules": [4], "inclusive": false }, "acc_title": { "rules": [2], "inclusive": false }, "unqString": { "rules": [], "inclusive": false }, "token": { "rules": [], "inclusive": false }, "string": { "rules": [48, 49], "inclusive": false }, "INITIAL": { "rules": [0, 1, 3, 5, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 50], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser() { + this.yy = {}; + } + Parser.prototype = parser2; + parser2.Parser = Parser; + return new Parser(); +}(); +parser.parser = parser; +const parser$1 = parser; +let relations = []; +let latestRequirement = {}; +let requirements = {}; +let latestElement = {}; +let elements = {}; +const RequirementType = { + REQUIREMENT: "Requirement", + FUNCTIONAL_REQUIREMENT: "Functional Requirement", + INTERFACE_REQUIREMENT: "Interface Requirement", + PERFORMANCE_REQUIREMENT: "Performance Requirement", + PHYSICAL_REQUIREMENT: "Physical Requirement", + DESIGN_CONSTRAINT: "Design Constraint" +}; +const RiskLevel = { + LOW_RISK: "Low", + MED_RISK: "Medium", + HIGH_RISK: "High" +}; +const VerifyType = { + VERIFY_ANALYSIS: "Analysis", + VERIFY_DEMONSTRATION: "Demonstration", + VERIFY_INSPECTION: "Inspection", + VERIFY_TEST: "Test" +}; +const Relationships = { + CONTAINS: "contains", + COPIES: "copies", + DERIVES: "derives", + SATISFIES: "satisfies", + VERIFIES: "verifies", + REFINES: "refines", + TRACES: "traces" +}; +const addRequirement = (name, type) => { + if (requirements[name] === void 0) { + requirements[name] = { + name, + type, + id: latestRequirement.id, + text: latestRequirement.text, + risk: latestRequirement.risk, + verifyMethod: latestRequirement.verifyMethod + }; + } + latestRequirement = {}; + return requirements[name]; +}; +const getRequirements = () => requirements; +const setNewReqId = (id) => { + if (latestRequirement !== void 0) { + latestRequirement.id = id; + } +}; +const setNewReqText = (text) => { + if (latestRequirement !== void 0) { + latestRequirement.text = text; + } +}; +const setNewReqRisk = (risk) => { + if (latestRequirement !== void 0) { + latestRequirement.risk = risk; + } +}; +const setNewReqVerifyMethod = (verifyMethod) => { + if (latestRequirement !== void 0) { + latestRequirement.verifyMethod = verifyMethod; + } +}; +const addElement = (name) => { + if (elements[name] === void 0) { + elements[name] = { + name, + type: latestElement.type, + docRef: latestElement.docRef + }; + log.info("Added new requirement: ", name); + } + latestElement = {}; + return elements[name]; +}; +const getElements = () => elements; +const setNewElementType = (type) => { + if (latestElement !== void 0) { + latestElement.type = type; + } +}; +const setNewElementDocRef = (docRef) => { + if (latestElement !== void 0) { + latestElement.docRef = docRef; + } +}; +const addRelationship = (type, src, dst) => { + relations.push({ + type, + src, + dst + }); +}; +const getRelationships = () => relations; +const clear = () => { + relations = []; + latestRequirement = {}; + requirements = {}; + latestElement = {}; + elements = {}; + clear$1(); +}; +const db = { + RequirementType, + RiskLevel, + VerifyType, + Relationships, + getConfig: () => getConfig().req, + addRequirement, + getRequirements, + setNewReqId, + setNewReqText, + setNewReqRisk, + setNewReqVerifyMethod, + setAccTitle, + getAccTitle, + setAccDescription, + getAccDescription, + addElement, + getElements, + setNewElementType, + setNewElementDocRef, + addRelationship, + getRelationships, + clear +}; +const getStyles = (options) => ` + + marker { + fill: ${options.relationColor}; + stroke: ${options.relationColor}; + } + + marker.cross { + stroke: ${options.lineColor}; + } + + svg { + font-family: ${options.fontFamily}; + font-size: ${options.fontSize}; + } + + .reqBox { + fill: ${options.requirementBackground}; + fill-opacity: 1.0; + stroke: ${options.requirementBorderColor}; + stroke-width: ${options.requirementBorderSize}; + } + + .reqTitle, .reqLabel{ + fill: ${options.requirementTextColor}; + } + .reqLabelBox { + fill: ${options.relationLabelBackground}; + fill-opacity: 1.0; + } + + .req-title-line { + stroke: ${options.requirementBorderColor}; + stroke-width: ${options.requirementBorderSize}; + } + .relationshipLine { + stroke: ${options.relationColor}; + stroke-width: 1; + } + .relationshipLabel { + fill: ${options.relationLabelColor}; + } + +`; +const styles = getStyles; +const ReqMarkers = { + CONTAINS: "contains", + ARROW: "arrow" +}; +const insertLineEndings = (parentNode, conf2) => { + let containsNode = parentNode.append("defs").append("marker").attr("id", ReqMarkers.CONTAINS + "_line_ending").attr("refX", 0).attr("refY", conf2.line_height / 2).attr("markerWidth", conf2.line_height).attr("markerHeight", conf2.line_height).attr("orient", "auto").append("g"); + containsNode.append("circle").attr("cx", conf2.line_height / 2).attr("cy", conf2.line_height / 2).attr("r", conf2.line_height / 2).attr("fill", "none"); + containsNode.append("line").attr("x1", 0).attr("x2", conf2.line_height).attr("y1", conf2.line_height / 2).attr("y2", conf2.line_height / 2).attr("stroke-width", 1); + containsNode.append("line").attr("y1", 0).attr("y2", conf2.line_height).attr("x1", conf2.line_height / 2).attr("x2", conf2.line_height / 2).attr("stroke-width", 1); + parentNode.append("defs").append("marker").attr("id", ReqMarkers.ARROW + "_line_ending").attr("refX", conf2.line_height).attr("refY", 0.5 * conf2.line_height).attr("markerWidth", conf2.line_height).attr("markerHeight", conf2.line_height).attr("orient", "auto").append("path").attr( + "d", + `M0,0 + L${conf2.line_height},${conf2.line_height / 2} + M${conf2.line_height},${conf2.line_height / 2} + L0,${conf2.line_height}` + ).attr("stroke-width", 1); +}; +const markers = { + ReqMarkers, + insertLineEndings +}; +let conf = {}; +let relCnt = 0; +const newRectNode = (parentNode, id) => { + return parentNode.insert("rect", "#" + id).attr("class", "req reqBox").attr("x", 0).attr("y", 0).attr("width", conf.rect_min_width + "px").attr("height", conf.rect_min_height + "px"); +}; +const newTitleNode = (parentNode, id, txts) => { + let x = conf.rect_min_width / 2; + let title = parentNode.append("text").attr("class", "req reqLabel reqTitle").attr("id", id).attr("x", x).attr("y", conf.rect_padding).attr("dominant-baseline", "hanging"); + let i = 0; + txts.forEach((textStr) => { + if (i == 0) { + title.append("tspan").attr("text-anchor", "middle").attr("x", conf.rect_min_width / 2).attr("dy", 0).text(textStr); + } else { + title.append("tspan").attr("text-anchor", "middle").attr("x", conf.rect_min_width / 2).attr("dy", conf.line_height * 0.75).text(textStr); + } + i++; + }); + let yPadding = 1.5 * conf.rect_padding; + let linePadding = i * conf.line_height * 0.75; + let totalY = yPadding + linePadding; + parentNode.append("line").attr("class", "req-title-line").attr("x1", "0").attr("x2", conf.rect_min_width).attr("y1", totalY).attr("y2", totalY); + return { + titleNode: title, + y: totalY + }; +}; +const newBodyNode = (parentNode, id, txts, yStart) => { + let body = parentNode.append("text").attr("class", "req reqLabel").attr("id", id).attr("x", conf.rect_padding).attr("y", yStart).attr("dominant-baseline", "hanging"); + let currentRow = 0; + const charLimit = 30; + let wrappedTxts = []; + txts.forEach((textStr) => { + let currentTextLen = textStr.length; + while (currentTextLen > charLimit && currentRow < 3) { + let firstPart = textStr.substring(0, charLimit); + textStr = textStr.substring(charLimit, textStr.length); + currentTextLen = textStr.length; + wrappedTxts[wrappedTxts.length] = firstPart; + currentRow++; + } + if (currentRow == 3) { + let lastStr = wrappedTxts[wrappedTxts.length - 1]; + wrappedTxts[wrappedTxts.length - 1] = lastStr.substring(0, lastStr.length - 4) + "..."; + } else { + wrappedTxts[wrappedTxts.length] = textStr; + } + currentRow = 0; + }); + wrappedTxts.forEach((textStr) => { + body.append("tspan").attr("x", conf.rect_padding).attr("dy", conf.line_height).text(textStr); + }); + return body; +}; +const addEdgeLabel = (parentNode, svgPath, conf2, txt) => { + const len = svgPath.node().getTotalLength(); + const labelPoint = svgPath.node().getPointAtLength(len * 0.5); + const labelId = "rel" + relCnt; + relCnt++; + const labelNode = parentNode.append("text").attr("class", "req relationshipLabel").attr("id", labelId).attr("x", labelPoint.x).attr("y", labelPoint.y).attr("text-anchor", "middle").attr("dominant-baseline", "middle").text(txt); + const labelBBox = labelNode.node().getBBox(); + parentNode.insert("rect", "#" + labelId).attr("class", "req reqLabelBox").attr("x", labelPoint.x - labelBBox.width / 2).attr("y", labelPoint.y - labelBBox.height / 2).attr("width", labelBBox.width).attr("height", labelBBox.height).attr("fill", "white").attr("fill-opacity", "85%"); +}; +const drawRelationshipFromLayout = function(svg, rel, g, insert, diagObj) { + const edge = g.edge(elementString(rel.src), elementString(rel.dst)); + const lineFunction = line().x(function(d) { + return d.x; + }).y(function(d) { + return d.y; + }); + const svgPath = svg.insert("path", "#" + insert).attr("class", "er relationshipLine").attr("d", lineFunction(edge.points)).attr("fill", "none"); + if (rel.type == diagObj.db.Relationships.CONTAINS) { + svgPath.attr( + "marker-start", + "url(" + common.getUrl(conf.arrowMarkerAbsolute) + "#" + rel.type + "_line_ending)" + ); + } else { + svgPath.attr("stroke-dasharray", "10,7"); + svgPath.attr( + "marker-end", + "url(" + common.getUrl(conf.arrowMarkerAbsolute) + "#" + markers.ReqMarkers.ARROW + "_line_ending)" + ); + } + addEdgeLabel(svg, svgPath, conf, `<<${rel.type}>>`); + return; +}; +const drawReqs = (reqs, graph, svgNode) => { + Object.keys(reqs).forEach((reqName) => { + let req = reqs[reqName]; + reqName = elementString(reqName); + log.info("Added new requirement: ", reqName); + const groupNode = svgNode.append("g").attr("id", reqName); + const textId = "req-" + reqName; + const rectNode = newRectNode(groupNode, textId); + let titleNodeInfo = newTitleNode(groupNode, reqName + "_title", [ + `<<${req.type}>>`, + `${req.name}` + ]); + newBodyNode( + groupNode, + reqName + "_body", + [ + `Id: ${req.id}`, + `Text: ${req.text}`, + `Risk: ${req.risk}`, + `Verification: ${req.verifyMethod}` + ], + titleNodeInfo.y + ); + const rectBBox = rectNode.node().getBBox(); + graph.setNode(reqName, { + width: rectBBox.width, + height: rectBBox.height, + shape: "rect", + id: reqName + }); + }); +}; +const drawElements = (els, graph, svgNode) => { + Object.keys(els).forEach((elName) => { + let el = els[elName]; + const id = elementString(elName); + const groupNode = svgNode.append("g").attr("id", id); + const textId = "element-" + id; + const rectNode = newRectNode(groupNode, textId); + let titleNodeInfo = newTitleNode(groupNode, textId + "_title", [`<>`, `${elName}`]); + newBodyNode( + groupNode, + textId + "_body", + [`Type: ${el.type || "Not Specified"}`, `Doc Ref: ${el.docRef || "None"}`], + titleNodeInfo.y + ); + const rectBBox = rectNode.node().getBBox(); + graph.setNode(id, { + width: rectBBox.width, + height: rectBBox.height, + shape: "rect", + id + }); + }); +}; +const addRelationships = (relationships, g) => { + relationships.forEach(function(r) { + let src = elementString(r.src); + let dst = elementString(r.dst); + g.setEdge(src, dst, { relationship: r }); + }); + return relationships; +}; +const adjustEntities = function(svgNode, graph) { + graph.nodes().forEach(function(v) { + if (v !== void 0 && graph.node(v) !== void 0) { + svgNode.select("#" + v); + svgNode.select("#" + v).attr( + "transform", + "translate(" + (graph.node(v).x - graph.node(v).width / 2) + "," + (graph.node(v).y - graph.node(v).height / 2) + " )" + ); + } + }); + return; +}; +const elementString = (str) => { + return str.replace(/\s/g, "").replace(/\./g, "_"); +}; +const draw = (text, id, _version, diagObj) => { + conf = getConfig().requirement; + const securityLevel = conf.securityLevel; + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = select("#i" + id); + } + const root = securityLevel === "sandbox" ? select(sandboxElement.nodes()[0].contentDocument.body) : select("body"); + const svg = root.select(`[id='${id}']`); + markers.insertLineEndings(svg, conf); + const g = new graphlib.Graph({ + multigraph: false, + compound: false, + directed: true + }).setGraph({ + rankdir: conf.layoutDirection, + marginx: 20, + marginy: 20, + nodesep: 100, + edgesep: 100, + ranksep: 100 + }).setDefaultEdgeLabel(function() { + return {}; + }); + let requirements2 = diagObj.db.getRequirements(); + let elements2 = diagObj.db.getElements(); + let relationships = diagObj.db.getRelationships(); + drawReqs(requirements2, g, svg); + drawElements(elements2, g, svg); + addRelationships(relationships, g); + layout(g); + adjustEntities(svg, g); + relationships.forEach(function(rel) { + drawRelationshipFromLayout(svg, rel, g, id, diagObj); + }); + const padding = conf.rect_padding; + const svgBounds = svg.node().getBBox(); + const width = svgBounds.width + padding * 2; + const height = svgBounds.height + padding * 2; + configureSvgSize(svg, height, width, conf.useMaxWidth); + svg.attr("viewBox", `${svgBounds.x - padding} ${svgBounds.y - padding} ${width} ${height}`); +}; +const renderer = { + draw +}; +const diagram = { + parser: parser$1, + db, + renderer, + styles +}; +export { + diagram +}; diff --git a/0.6.0/js/mermaid/requirementDiagram-a721e157.js b/0.6.0/js/mermaid/requirementDiagram-a721e157.js new file mode 100644 index 0000000..45f6c7c --- /dev/null +++ b/0.6.0/js/mermaid/requirementDiagram-a721e157.js @@ -0,0 +1,1091 @@ +import { c as getConfig, s as setAccTitle, g as getAccTitle, b as setAccDescription, a as getAccDescription, l as log, E as clear$1, j as d3select, k as configureSvgSize, f as common } from "./mermaid-dcacb631.js"; +import { G as Graph } from "./graph-fe24fab6.js"; +import { l as layout } from "./layout-163b9689.js"; +import { l as line } from "./line-87f517ef.js"; +import "./array-b7dcf730.js"; +import "./path-39bad7e2.js"; +var parser = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 3], $V1 = [1, 4], $V2 = [1, 5], $V3 = [1, 6], $V4 = [5, 6, 8, 9, 11, 13, 31, 32, 33, 34, 35, 36, 44, 62, 63], $V5 = [1, 18], $V6 = [2, 7], $V7 = [1, 22], $V8 = [1, 23], $V9 = [1, 24], $Va = [1, 25], $Vb = [1, 26], $Vc = [1, 27], $Vd = [1, 20], $Ve = [1, 28], $Vf = [1, 29], $Vg = [62, 63], $Vh = [5, 8, 9, 11, 13, 31, 32, 33, 34, 35, 36, 44, 51, 53, 62, 63], $Vi = [1, 47], $Vj = [1, 48], $Vk = [1, 49], $Vl = [1, 50], $Vm = [1, 51], $Vn = [1, 52], $Vo = [1, 53], $Vp = [53, 54], $Vq = [1, 64], $Vr = [1, 60], $Vs = [1, 61], $Vt = [1, 62], $Vu = [1, 63], $Vv = [1, 65], $Vw = [1, 69], $Vx = [1, 70], $Vy = [1, 67], $Vz = [1, 68], $VA = [5, 8, 9, 11, 13, 31, 32, 33, 34, 35, 36, 44, 62, 63]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "directive": 4, "NEWLINE": 5, "RD": 6, "diagram": 7, "EOF": 8, "acc_title": 9, "acc_title_value": 10, "acc_descr": 11, "acc_descr_value": 12, "acc_descr_multiline_value": 13, "requirementDef": 14, "elementDef": 15, "relationshipDef": 16, "requirementType": 17, "requirementName": 18, "STRUCT_START": 19, "requirementBody": 20, "ID": 21, "COLONSEP": 22, "id": 23, "TEXT": 24, "text": 25, "RISK": 26, "riskLevel": 27, "VERIFYMTHD": 28, "verifyType": 29, "STRUCT_STOP": 30, "REQUIREMENT": 31, "FUNCTIONAL_REQUIREMENT": 32, "INTERFACE_REQUIREMENT": 33, "PERFORMANCE_REQUIREMENT": 34, "PHYSICAL_REQUIREMENT": 35, "DESIGN_CONSTRAINT": 36, "LOW_RISK": 37, "MED_RISK": 38, "HIGH_RISK": 39, "VERIFY_ANALYSIS": 40, "VERIFY_DEMONSTRATION": 41, "VERIFY_INSPECTION": 42, "VERIFY_TEST": 43, "ELEMENT": 44, "elementName": 45, "elementBody": 46, "TYPE": 47, "type": 48, "DOCREF": 49, "ref": 50, "END_ARROW_L": 51, "relationship": 52, "LINE": 53, "END_ARROW_R": 54, "CONTAINS": 55, "COPIES": 56, "DERIVES": 57, "SATISFIES": 58, "VERIFIES": 59, "REFINES": 60, "TRACES": 61, "unqString": 62, "qString": 63, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 5: "NEWLINE", 6: "RD", 8: "EOF", 9: "acc_title", 10: "acc_title_value", 11: "acc_descr", 12: "acc_descr_value", 13: "acc_descr_multiline_value", 19: "STRUCT_START", 21: "ID", 22: "COLONSEP", 24: "TEXT", 26: "RISK", 28: "VERIFYMTHD", 30: "STRUCT_STOP", 31: "REQUIREMENT", 32: "FUNCTIONAL_REQUIREMENT", 33: "INTERFACE_REQUIREMENT", 34: "PERFORMANCE_REQUIREMENT", 35: "PHYSICAL_REQUIREMENT", 36: "DESIGN_CONSTRAINT", 37: "LOW_RISK", 38: "MED_RISK", 39: "HIGH_RISK", 40: "VERIFY_ANALYSIS", 41: "VERIFY_DEMONSTRATION", 42: "VERIFY_INSPECTION", 43: "VERIFY_TEST", 44: "ELEMENT", 47: "TYPE", 49: "DOCREF", 51: "END_ARROW_L", 53: "LINE", 54: "END_ARROW_R", 55: "CONTAINS", 56: "COPIES", 57: "DERIVES", 58: "SATISFIES", 59: "VERIFIES", 60: "REFINES", 61: "TRACES", 62: "unqString", 63: "qString" }, + productions_: [0, [3, 3], [3, 2], [3, 4], [4, 2], [4, 2], [4, 1], [7, 0], [7, 2], [7, 2], [7, 2], [7, 2], [7, 2], [14, 5], [20, 5], [20, 5], [20, 5], [20, 5], [20, 2], [20, 1], [17, 1], [17, 1], [17, 1], [17, 1], [17, 1], [17, 1], [27, 1], [27, 1], [27, 1], [29, 1], [29, 1], [29, 1], [29, 1], [15, 5], [46, 5], [46, 5], [46, 2], [46, 1], [16, 5], [16, 5], [52, 1], [52, 1], [52, 1], [52, 1], [52, 1], [52, 1], [52, 1], [18, 1], [18, 1], [23, 1], [23, 1], [25, 1], [25, 1], [45, 1], [45, 1], [48, 1], [48, 1], [50, 1], [50, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 4: + this.$ = $$[$0].trim(); + yy.setAccTitle(this.$); + break; + case 5: + case 6: + this.$ = $$[$0].trim(); + yy.setAccDescription(this.$); + break; + case 7: + this.$ = []; + break; + case 13: + yy.addRequirement($$[$0 - 3], $$[$0 - 4]); + break; + case 14: + yy.setNewReqId($$[$0 - 2]); + break; + case 15: + yy.setNewReqText($$[$0 - 2]); + break; + case 16: + yy.setNewReqRisk($$[$0 - 2]); + break; + case 17: + yy.setNewReqVerifyMethod($$[$0 - 2]); + break; + case 20: + this.$ = yy.RequirementType.REQUIREMENT; + break; + case 21: + this.$ = yy.RequirementType.FUNCTIONAL_REQUIREMENT; + break; + case 22: + this.$ = yy.RequirementType.INTERFACE_REQUIREMENT; + break; + case 23: + this.$ = yy.RequirementType.PERFORMANCE_REQUIREMENT; + break; + case 24: + this.$ = yy.RequirementType.PHYSICAL_REQUIREMENT; + break; + case 25: + this.$ = yy.RequirementType.DESIGN_CONSTRAINT; + break; + case 26: + this.$ = yy.RiskLevel.LOW_RISK; + break; + case 27: + this.$ = yy.RiskLevel.MED_RISK; + break; + case 28: + this.$ = yy.RiskLevel.HIGH_RISK; + break; + case 29: + this.$ = yy.VerifyType.VERIFY_ANALYSIS; + break; + case 30: + this.$ = yy.VerifyType.VERIFY_DEMONSTRATION; + break; + case 31: + this.$ = yy.VerifyType.VERIFY_INSPECTION; + break; + case 32: + this.$ = yy.VerifyType.VERIFY_TEST; + break; + case 33: + yy.addElement($$[$0 - 3]); + break; + case 34: + yy.setNewElementType($$[$0 - 2]); + break; + case 35: + yy.setNewElementDocRef($$[$0 - 2]); + break; + case 38: + yy.addRelationship($$[$0 - 2], $$[$0], $$[$0 - 4]); + break; + case 39: + yy.addRelationship($$[$0 - 2], $$[$0 - 4], $$[$0]); + break; + case 40: + this.$ = yy.Relationships.CONTAINS; + break; + case 41: + this.$ = yy.Relationships.COPIES; + break; + case 42: + this.$ = yy.Relationships.DERIVES; + break; + case 43: + this.$ = yy.Relationships.SATISFIES; + break; + case 44: + this.$ = yy.Relationships.VERIFIES; + break; + case 45: + this.$ = yy.Relationships.REFINES; + break; + case 46: + this.$ = yy.Relationships.TRACES; + break; + } + }, + table: [{ 3: 1, 4: 2, 6: $V0, 9: $V1, 11: $V2, 13: $V3 }, { 1: [3] }, { 3: 8, 4: 2, 5: [1, 7], 6: $V0, 9: $V1, 11: $V2, 13: $V3 }, { 5: [1, 9] }, { 10: [1, 10] }, { 12: [1, 11] }, o($V4, [2, 6]), { 3: 12, 4: 2, 6: $V0, 9: $V1, 11: $V2, 13: $V3 }, { 1: [2, 2] }, { 4: 17, 5: $V5, 7: 13, 8: $V6, 9: $V1, 11: $V2, 13: $V3, 14: 14, 15: 15, 16: 16, 17: 19, 23: 21, 31: $V7, 32: $V8, 33: $V9, 34: $Va, 35: $Vb, 36: $Vc, 44: $Vd, 62: $Ve, 63: $Vf }, o($V4, [2, 4]), o($V4, [2, 5]), { 1: [2, 1] }, { 8: [1, 30] }, { 4: 17, 5: $V5, 7: 31, 8: $V6, 9: $V1, 11: $V2, 13: $V3, 14: 14, 15: 15, 16: 16, 17: 19, 23: 21, 31: $V7, 32: $V8, 33: $V9, 34: $Va, 35: $Vb, 36: $Vc, 44: $Vd, 62: $Ve, 63: $Vf }, { 4: 17, 5: $V5, 7: 32, 8: $V6, 9: $V1, 11: $V2, 13: $V3, 14: 14, 15: 15, 16: 16, 17: 19, 23: 21, 31: $V7, 32: $V8, 33: $V9, 34: $Va, 35: $Vb, 36: $Vc, 44: $Vd, 62: $Ve, 63: $Vf }, { 4: 17, 5: $V5, 7: 33, 8: $V6, 9: $V1, 11: $V2, 13: $V3, 14: 14, 15: 15, 16: 16, 17: 19, 23: 21, 31: $V7, 32: $V8, 33: $V9, 34: $Va, 35: $Vb, 36: $Vc, 44: $Vd, 62: $Ve, 63: $Vf }, { 4: 17, 5: $V5, 7: 34, 8: $V6, 9: $V1, 11: $V2, 13: $V3, 14: 14, 15: 15, 16: 16, 17: 19, 23: 21, 31: $V7, 32: $V8, 33: $V9, 34: $Va, 35: $Vb, 36: $Vc, 44: $Vd, 62: $Ve, 63: $Vf }, { 4: 17, 5: $V5, 7: 35, 8: $V6, 9: $V1, 11: $V2, 13: $V3, 14: 14, 15: 15, 16: 16, 17: 19, 23: 21, 31: $V7, 32: $V8, 33: $V9, 34: $Va, 35: $Vb, 36: $Vc, 44: $Vd, 62: $Ve, 63: $Vf }, { 18: 36, 62: [1, 37], 63: [1, 38] }, { 45: 39, 62: [1, 40], 63: [1, 41] }, { 51: [1, 42], 53: [1, 43] }, o($Vg, [2, 20]), o($Vg, [2, 21]), o($Vg, [2, 22]), o($Vg, [2, 23]), o($Vg, [2, 24]), o($Vg, [2, 25]), o($Vh, [2, 49]), o($Vh, [2, 50]), { 1: [2, 3] }, { 8: [2, 8] }, { 8: [2, 9] }, { 8: [2, 10] }, { 8: [2, 11] }, { 8: [2, 12] }, { 19: [1, 44] }, { 19: [2, 47] }, { 19: [2, 48] }, { 19: [1, 45] }, { 19: [2, 53] }, { 19: [2, 54] }, { 52: 46, 55: $Vi, 56: $Vj, 57: $Vk, 58: $Vl, 59: $Vm, 60: $Vn, 61: $Vo }, { 52: 54, 55: $Vi, 56: $Vj, 57: $Vk, 58: $Vl, 59: $Vm, 60: $Vn, 61: $Vo }, { 5: [1, 55] }, { 5: [1, 56] }, { 53: [1, 57] }, o($Vp, [2, 40]), o($Vp, [2, 41]), o($Vp, [2, 42]), o($Vp, [2, 43]), o($Vp, [2, 44]), o($Vp, [2, 45]), o($Vp, [2, 46]), { 54: [1, 58] }, { 5: $Vq, 20: 59, 21: $Vr, 24: $Vs, 26: $Vt, 28: $Vu, 30: $Vv }, { 5: $Vw, 30: $Vx, 46: 66, 47: $Vy, 49: $Vz }, { 23: 71, 62: $Ve, 63: $Vf }, { 23: 72, 62: $Ve, 63: $Vf }, o($VA, [2, 13]), { 22: [1, 73] }, { 22: [1, 74] }, { 22: [1, 75] }, { 22: [1, 76] }, { 5: $Vq, 20: 77, 21: $Vr, 24: $Vs, 26: $Vt, 28: $Vu, 30: $Vv }, o($VA, [2, 19]), o($VA, [2, 33]), { 22: [1, 78] }, { 22: [1, 79] }, { 5: $Vw, 30: $Vx, 46: 80, 47: $Vy, 49: $Vz }, o($VA, [2, 37]), o($VA, [2, 38]), o($VA, [2, 39]), { 23: 81, 62: $Ve, 63: $Vf }, { 25: 82, 62: [1, 83], 63: [1, 84] }, { 27: 85, 37: [1, 86], 38: [1, 87], 39: [1, 88] }, { 29: 89, 40: [1, 90], 41: [1, 91], 42: [1, 92], 43: [1, 93] }, o($VA, [2, 18]), { 48: 94, 62: [1, 95], 63: [1, 96] }, { 50: 97, 62: [1, 98], 63: [1, 99] }, o($VA, [2, 36]), { 5: [1, 100] }, { 5: [1, 101] }, { 5: [2, 51] }, { 5: [2, 52] }, { 5: [1, 102] }, { 5: [2, 26] }, { 5: [2, 27] }, { 5: [2, 28] }, { 5: [1, 103] }, { 5: [2, 29] }, { 5: [2, 30] }, { 5: [2, 31] }, { 5: [2, 32] }, { 5: [1, 104] }, { 5: [2, 55] }, { 5: [2, 56] }, { 5: [1, 105] }, { 5: [2, 57] }, { 5: [2, 58] }, { 5: $Vq, 20: 106, 21: $Vr, 24: $Vs, 26: $Vt, 28: $Vu, 30: $Vv }, { 5: $Vq, 20: 107, 21: $Vr, 24: $Vs, 26: $Vt, 28: $Vu, 30: $Vv }, { 5: $Vq, 20: 108, 21: $Vr, 24: $Vs, 26: $Vt, 28: $Vu, 30: $Vv }, { 5: $Vq, 20: 109, 21: $Vr, 24: $Vs, 26: $Vt, 28: $Vu, 30: $Vv }, { 5: $Vw, 30: $Vx, 46: 110, 47: $Vy, 49: $Vz }, { 5: $Vw, 30: $Vx, 46: 111, 47: $Vy, 49: $Vz }, o($VA, [2, 14]), o($VA, [2, 15]), o($VA, [2, 16]), o($VA, [2, 17]), o($VA, [2, 34]), o($VA, [2, 35])], + defaultActions: { 8: [2, 2], 12: [2, 1], 30: [2, 3], 31: [2, 8], 32: [2, 9], 33: [2, 10], 34: [2, 11], 35: [2, 12], 37: [2, 47], 38: [2, 48], 40: [2, 53], 41: [2, 54], 83: [2, 51], 84: [2, 52], 86: [2, 26], 87: [2, 27], 88: [2, 28], 90: [2, 29], 91: [2, 30], 92: [2, 31], 93: [2, 32], 95: [2, 55], 96: [2, 56], 98: [2, 57], 99: [2, 58] }, + parseError: function parseError(str, hash) { + if (hash.recoverable) { + this.trace(str); + } else { + var error = new Error(str); + error.hash = hash; + throw error; + } + }, + parse: function parse(input) { + var self = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex() { + var token; + token = tstack.pop() || lexer2.lex() || EOF; + if (typeof token !== "number") { + if (token instanceof Array) { + tstack = token; + token = tstack.pop(); + } + token = self.symbols_[token] || token; + } + return token; + } + var symbol, state, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state = stack[stack.length - 1]; + if (this.defaultActions[state]) { + action = this.defaultActions[state]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex(); + } + action = table[state] && table[state][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str, hash); + } else { + throw new Error(str); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch = this._input[0]; + this.yytext += ch; + this.yyleng++; + this.offset++; + this.match += ch; + this.matched += ch; + var lines = ch.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch; + }, + // unshifts one char (or a string) into the input + unput: function(ch) { + var len = ch.length; + var lines = ch.split(/(?:\r\n?|\n)/g); + this._input = ch + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next = this.match; + if (next.length < 20) { + next += this._input.substr(0, 20 - next.length); + } + return (next.substr(0, 20) + (next.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token) { + return token; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token, match, tempMatch, index; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i = 0; i < rules.length; i++) { + tempMatch = this._input.match(this.rules[rules[i]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index = i; + if (this.options.backtrack_lexer) { + token = this.test_match(tempMatch, rules[i]); + if (token !== false) { + return token; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token = this.test_match(match, rules[index]); + if (token !== false) { + return token; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + return "title"; + case 1: + this.begin("acc_title"); + return 9; + case 2: + this.popState(); + return "acc_title_value"; + case 3: + this.begin("acc_descr"); + return 11; + case 4: + this.popState(); + return "acc_descr_value"; + case 5: + this.begin("acc_descr_multiline"); + break; + case 6: + this.popState(); + break; + case 7: + return "acc_descr_multiline_value"; + case 8: + return 5; + case 9: + break; + case 10: + break; + case 11: + break; + case 12: + return 8; + case 13: + return 6; + case 14: + return 19; + case 15: + return 30; + case 16: + return 22; + case 17: + return 21; + case 18: + return 24; + case 19: + return 26; + case 20: + return 28; + case 21: + return 31; + case 22: + return 32; + case 23: + return 33; + case 24: + return 34; + case 25: + return 35; + case 26: + return 36; + case 27: + return 37; + case 28: + return 38; + case 29: + return 39; + case 30: + return 40; + case 31: + return 41; + case 32: + return 42; + case 33: + return 43; + case 34: + return 44; + case 35: + return 55; + case 36: + return 56; + case 37: + return 57; + case 38: + return 58; + case 39: + return 59; + case 40: + return 60; + case 41: + return 61; + case 42: + return 47; + case 43: + return 49; + case 44: + return 51; + case 45: + return 54; + case 46: + return 53; + case 47: + this.begin("string"); + break; + case 48: + this.popState(); + break; + case 49: + return "qString"; + case 50: + yy_.yytext = yy_.yytext.trim(); + return 62; + } + }, + rules: [/^(?:title\s[^#\n;]+)/i, /^(?:accTitle\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*\{\s*)/i, /^(?:[\}])/i, /^(?:[^\}]*)/i, /^(?:(\r?\n)+)/i, /^(?:\s+)/i, /^(?:#[^\n]*)/i, /^(?:%[^\n]*)/i, /^(?:$)/i, /^(?:requirementDiagram\b)/i, /^(?:\{)/i, /^(?:\})/i, /^(?::)/i, /^(?:id\b)/i, /^(?:text\b)/i, /^(?:risk\b)/i, /^(?:verifyMethod\b)/i, /^(?:requirement\b)/i, /^(?:functionalRequirement\b)/i, /^(?:interfaceRequirement\b)/i, /^(?:performanceRequirement\b)/i, /^(?:physicalRequirement\b)/i, /^(?:designConstraint\b)/i, /^(?:low\b)/i, /^(?:medium\b)/i, /^(?:high\b)/i, /^(?:analysis\b)/i, /^(?:demonstration\b)/i, /^(?:inspection\b)/i, /^(?:test\b)/i, /^(?:element\b)/i, /^(?:contains\b)/i, /^(?:copies\b)/i, /^(?:derives\b)/i, /^(?:satisfies\b)/i, /^(?:verifies\b)/i, /^(?:refines\b)/i, /^(?:traces\b)/i, /^(?:type\b)/i, /^(?:docref\b)/i, /^(?:<-)/i, /^(?:->)/i, /^(?:-)/i, /^(?:["])/i, /^(?:["])/i, /^(?:[^"]*)/i, /^(?:[\w][^\r\n\{\<\>\-\=]*)/i], + conditions: { "acc_descr_multiline": { "rules": [6, 7], "inclusive": false }, "acc_descr": { "rules": [4], "inclusive": false }, "acc_title": { "rules": [2], "inclusive": false }, "unqString": { "rules": [], "inclusive": false }, "token": { "rules": [], "inclusive": false }, "string": { "rules": [48, 49], "inclusive": false }, "INITIAL": { "rules": [0, 1, 3, 5, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 50], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser() { + this.yy = {}; + } + Parser.prototype = parser2; + parser2.Parser = Parser; + return new Parser(); +}(); +parser.parser = parser; +const parser$1 = parser; +let relations = []; +let latestRequirement = {}; +let requirements = {}; +let latestElement = {}; +let elements = {}; +const RequirementType = { + REQUIREMENT: "Requirement", + FUNCTIONAL_REQUIREMENT: "Functional Requirement", + INTERFACE_REQUIREMENT: "Interface Requirement", + PERFORMANCE_REQUIREMENT: "Performance Requirement", + PHYSICAL_REQUIREMENT: "Physical Requirement", + DESIGN_CONSTRAINT: "Design Constraint" +}; +const RiskLevel = { + LOW_RISK: "Low", + MED_RISK: "Medium", + HIGH_RISK: "High" +}; +const VerifyType = { + VERIFY_ANALYSIS: "Analysis", + VERIFY_DEMONSTRATION: "Demonstration", + VERIFY_INSPECTION: "Inspection", + VERIFY_TEST: "Test" +}; +const Relationships = { + CONTAINS: "contains", + COPIES: "copies", + DERIVES: "derives", + SATISFIES: "satisfies", + VERIFIES: "verifies", + REFINES: "refines", + TRACES: "traces" +}; +const addRequirement = (name, type) => { + if (requirements[name] === void 0) { + requirements[name] = { + name, + type, + id: latestRequirement.id, + text: latestRequirement.text, + risk: latestRequirement.risk, + verifyMethod: latestRequirement.verifyMethod + }; + } + latestRequirement = {}; + return requirements[name]; +}; +const getRequirements = () => requirements; +const setNewReqId = (id) => { + if (latestRequirement !== void 0) { + latestRequirement.id = id; + } +}; +const setNewReqText = (text) => { + if (latestRequirement !== void 0) { + latestRequirement.text = text; + } +}; +const setNewReqRisk = (risk) => { + if (latestRequirement !== void 0) { + latestRequirement.risk = risk; + } +}; +const setNewReqVerifyMethod = (verifyMethod) => { + if (latestRequirement !== void 0) { + latestRequirement.verifyMethod = verifyMethod; + } +}; +const addElement = (name) => { + if (elements[name] === void 0) { + elements[name] = { + name, + type: latestElement.type, + docRef: latestElement.docRef + }; + log.info("Added new requirement: ", name); + } + latestElement = {}; + return elements[name]; +}; +const getElements = () => elements; +const setNewElementType = (type) => { + if (latestElement !== void 0) { + latestElement.type = type; + } +}; +const setNewElementDocRef = (docRef) => { + if (latestElement !== void 0) { + latestElement.docRef = docRef; + } +}; +const addRelationship = (type, src, dst) => { + relations.push({ + type, + src, + dst + }); +}; +const getRelationships = () => relations; +const clear = () => { + relations = []; + latestRequirement = {}; + requirements = {}; + latestElement = {}; + elements = {}; + clear$1(); +}; +const db = { + RequirementType, + RiskLevel, + VerifyType, + Relationships, + getConfig: () => getConfig().req, + addRequirement, + getRequirements, + setNewReqId, + setNewReqText, + setNewReqRisk, + setNewReqVerifyMethod, + setAccTitle, + getAccTitle, + setAccDescription, + getAccDescription, + addElement, + getElements, + setNewElementType, + setNewElementDocRef, + addRelationship, + getRelationships, + clear +}; +const getStyles = (options) => ` + + marker { + fill: ${options.relationColor}; + stroke: ${options.relationColor}; + } + + marker.cross { + stroke: ${options.lineColor}; + } + + svg { + font-family: ${options.fontFamily}; + font-size: ${options.fontSize}; + } + + .reqBox { + fill: ${options.requirementBackground}; + fill-opacity: 1.0; + stroke: ${options.requirementBorderColor}; + stroke-width: ${options.requirementBorderSize}; + } + + .reqTitle, .reqLabel{ + fill: ${options.requirementTextColor}; + } + .reqLabelBox { + fill: ${options.relationLabelBackground}; + fill-opacity: 1.0; + } + + .req-title-line { + stroke: ${options.requirementBorderColor}; + stroke-width: ${options.requirementBorderSize}; + } + .relationshipLine { + stroke: ${options.relationColor}; + stroke-width: 1; + } + .relationshipLabel { + fill: ${options.relationLabelColor}; + } + +`; +const styles = getStyles; +const ReqMarkers = { + CONTAINS: "contains", + ARROW: "arrow" +}; +const insertLineEndings = (parentNode, conf2) => { + let containsNode = parentNode.append("defs").append("marker").attr("id", ReqMarkers.CONTAINS + "_line_ending").attr("refX", 0).attr("refY", conf2.line_height / 2).attr("markerWidth", conf2.line_height).attr("markerHeight", conf2.line_height).attr("orient", "auto").append("g"); + containsNode.append("circle").attr("cx", conf2.line_height / 2).attr("cy", conf2.line_height / 2).attr("r", conf2.line_height / 2).attr("fill", "none"); + containsNode.append("line").attr("x1", 0).attr("x2", conf2.line_height).attr("y1", conf2.line_height / 2).attr("y2", conf2.line_height / 2).attr("stroke-width", 1); + containsNode.append("line").attr("y1", 0).attr("y2", conf2.line_height).attr("x1", conf2.line_height / 2).attr("x2", conf2.line_height / 2).attr("stroke-width", 1); + parentNode.append("defs").append("marker").attr("id", ReqMarkers.ARROW + "_line_ending").attr("refX", conf2.line_height).attr("refY", 0.5 * conf2.line_height).attr("markerWidth", conf2.line_height).attr("markerHeight", conf2.line_height).attr("orient", "auto").append("path").attr( + "d", + `M0,0 + L${conf2.line_height},${conf2.line_height / 2} + M${conf2.line_height},${conf2.line_height / 2} + L0,${conf2.line_height}` + ).attr("stroke-width", 1); +}; +const markers = { + ReqMarkers, + insertLineEndings +}; +let conf = {}; +let relCnt = 0; +const newRectNode = (parentNode, id) => { + return parentNode.insert("rect", "#" + id).attr("class", "req reqBox").attr("x", 0).attr("y", 0).attr("width", conf.rect_min_width + "px").attr("height", conf.rect_min_height + "px"); +}; +const newTitleNode = (parentNode, id, txts) => { + let x = conf.rect_min_width / 2; + let title = parentNode.append("text").attr("class", "req reqLabel reqTitle").attr("id", id).attr("x", x).attr("y", conf.rect_padding).attr("dominant-baseline", "hanging"); + let i = 0; + txts.forEach((textStr) => { + if (i == 0) { + title.append("tspan").attr("text-anchor", "middle").attr("x", conf.rect_min_width / 2).attr("dy", 0).text(textStr); + } else { + title.append("tspan").attr("text-anchor", "middle").attr("x", conf.rect_min_width / 2).attr("dy", conf.line_height * 0.75).text(textStr); + } + i++; + }); + let yPadding = 1.5 * conf.rect_padding; + let linePadding = i * conf.line_height * 0.75; + let totalY = yPadding + linePadding; + parentNode.append("line").attr("class", "req-title-line").attr("x1", "0").attr("x2", conf.rect_min_width).attr("y1", totalY).attr("y2", totalY); + return { + titleNode: title, + y: totalY + }; +}; +const newBodyNode = (parentNode, id, txts, yStart) => { + let body = parentNode.append("text").attr("class", "req reqLabel").attr("id", id).attr("x", conf.rect_padding).attr("y", yStart).attr("dominant-baseline", "hanging"); + let currentRow = 0; + const charLimit = 30; + let wrappedTxts = []; + txts.forEach((textStr) => { + let currentTextLen = textStr.length; + while (currentTextLen > charLimit && currentRow < 3) { + let firstPart = textStr.substring(0, charLimit); + textStr = textStr.substring(charLimit, textStr.length); + currentTextLen = textStr.length; + wrappedTxts[wrappedTxts.length] = firstPart; + currentRow++; + } + if (currentRow == 3) { + let lastStr = wrappedTxts[wrappedTxts.length - 1]; + wrappedTxts[wrappedTxts.length - 1] = lastStr.substring(0, lastStr.length - 4) + "..."; + } else { + wrappedTxts[wrappedTxts.length] = textStr; + } + currentRow = 0; + }); + wrappedTxts.forEach((textStr) => { + body.append("tspan").attr("x", conf.rect_padding).attr("dy", conf.line_height).text(textStr); + }); + return body; +}; +const addEdgeLabel = (parentNode, svgPath, conf2, txt) => { + const len = svgPath.node().getTotalLength(); + const labelPoint = svgPath.node().getPointAtLength(len * 0.5); + const labelId = "rel" + relCnt; + relCnt++; + const labelNode = parentNode.append("text").attr("class", "req relationshipLabel").attr("id", labelId).attr("x", labelPoint.x).attr("y", labelPoint.y).attr("text-anchor", "middle").attr("dominant-baseline", "middle").text(txt); + const labelBBox = labelNode.node().getBBox(); + parentNode.insert("rect", "#" + labelId).attr("class", "req reqLabelBox").attr("x", labelPoint.x - labelBBox.width / 2).attr("y", labelPoint.y - labelBBox.height / 2).attr("width", labelBBox.width).attr("height", labelBBox.height).attr("fill", "white").attr("fill-opacity", "85%"); +}; +const drawRelationshipFromLayout = function(svg, rel, g, insert, diagObj) { + const edge = g.edge(elementString(rel.src), elementString(rel.dst)); + const lineFunction = line().x(function(d) { + return d.x; + }).y(function(d) { + return d.y; + }); + const svgPath = svg.insert("path", "#" + insert).attr("class", "er relationshipLine").attr("d", lineFunction(edge.points)).attr("fill", "none"); + if (rel.type == diagObj.db.Relationships.CONTAINS) { + svgPath.attr( + "marker-start", + "url(" + common.getUrl(conf.arrowMarkerAbsolute) + "#" + rel.type + "_line_ending)" + ); + } else { + svgPath.attr("stroke-dasharray", "10,7"); + svgPath.attr( + "marker-end", + "url(" + common.getUrl(conf.arrowMarkerAbsolute) + "#" + markers.ReqMarkers.ARROW + "_line_ending)" + ); + } + addEdgeLabel(svg, svgPath, conf, `<<${rel.type}>>`); + return; +}; +const drawReqs = (reqs, graph, svgNode) => { + Object.keys(reqs).forEach((reqName) => { + let req = reqs[reqName]; + reqName = elementString(reqName); + log.info("Added new requirement: ", reqName); + const groupNode = svgNode.append("g").attr("id", reqName); + const textId = "req-" + reqName; + const rectNode = newRectNode(groupNode, textId); + let titleNodeInfo = newTitleNode(groupNode, reqName + "_title", [ + `<<${req.type}>>`, + `${req.name}` + ]); + newBodyNode( + groupNode, + reqName + "_body", + [ + `Id: ${req.id}`, + `Text: ${req.text}`, + `Risk: ${req.risk}`, + `Verification: ${req.verifyMethod}` + ], + titleNodeInfo.y + ); + const rectBBox = rectNode.node().getBBox(); + graph.setNode(reqName, { + width: rectBBox.width, + height: rectBBox.height, + shape: "rect", + id: reqName + }); + }); +}; +const drawElements = (els, graph, svgNode) => { + Object.keys(els).forEach((elName) => { + let el = els[elName]; + const id = elementString(elName); + const groupNode = svgNode.append("g").attr("id", id); + const textId = "element-" + id; + const rectNode = newRectNode(groupNode, textId); + let titleNodeInfo = newTitleNode(groupNode, textId + "_title", [`<>`, `${elName}`]); + newBodyNode( + groupNode, + textId + "_body", + [`Type: ${el.type || "Not Specified"}`, `Doc Ref: ${el.docRef || "None"}`], + titleNodeInfo.y + ); + const rectBBox = rectNode.node().getBBox(); + graph.setNode(id, { + width: rectBBox.width, + height: rectBBox.height, + shape: "rect", + id + }); + }); +}; +const addRelationships = (relationships, g) => { + relationships.forEach(function(r) { + let src = elementString(r.src); + let dst = elementString(r.dst); + g.setEdge(src, dst, { relationship: r }); + }); + return relationships; +}; +const adjustEntities = function(svgNode, graph) { + graph.nodes().forEach(function(v) { + if (v !== void 0 && graph.node(v) !== void 0) { + svgNode.select("#" + v); + svgNode.select("#" + v).attr( + "transform", + "translate(" + (graph.node(v).x - graph.node(v).width / 2) + "," + (graph.node(v).y - graph.node(v).height / 2) + " )" + ); + } + }); + return; +}; +const elementString = (str) => { + return str.replace(/\s/g, "").replace(/\./g, "_"); +}; +const draw = (text, id, _version, diagObj) => { + conf = getConfig().requirement; + const securityLevel = conf.securityLevel; + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = d3select("#i" + id); + } + const root = securityLevel === "sandbox" ? d3select(sandboxElement.nodes()[0].contentDocument.body) : d3select("body"); + const svg = root.select(`[id='${id}']`); + markers.insertLineEndings(svg, conf); + const g = new Graph({ + multigraph: false, + compound: false, + directed: true + }).setGraph({ + rankdir: conf.layoutDirection, + marginx: 20, + marginy: 20, + nodesep: 100, + edgesep: 100, + ranksep: 100 + }).setDefaultEdgeLabel(function() { + return {}; + }); + let requirements2 = diagObj.db.getRequirements(); + let elements2 = diagObj.db.getElements(); + let relationships = diagObj.db.getRelationships(); + drawReqs(requirements2, g, svg); + drawElements(elements2, g, svg); + addRelationships(relationships, g); + layout(g); + adjustEntities(svg, g); + relationships.forEach(function(rel) { + drawRelationshipFromLayout(svg, rel, g, id, diagObj); + }); + const padding = conf.rect_padding; + const svgBounds = svg.node().getBBox(); + const width = svgBounds.width + padding * 2; + const height = svgBounds.height + padding * 2; + configureSvgSize(svg, height, width, conf.useMaxWidth); + svg.attr("viewBox", `${svgBounds.x - padding} ${svgBounds.y - padding} ${width} ${height}`); +}; +const renderer = { + draw +}; +const diagram = { + parser: parser$1, + db, + renderer, + styles +}; +export { + diagram +}; diff --git a/0.6.0/js/mermaid/sankeyDiagram-33525efb.js b/0.6.0/js/mermaid/sankeyDiagram-33525efb.js new file mode 100644 index 0000000..b218580 --- /dev/null +++ b/0.6.0/js/mermaid/sankeyDiagram-33525efb.js @@ -0,0 +1,1198 @@ +import { c as getConfig, g as getAccTitle, s as setAccTitle, a as getAccDescription, b as setAccDescription, D as getDiagramTitle, C as setDiagramTitle, E as clear$1, f as common, ar as defaultConfig, j as d3select, t as setupGraphViewbox } from "./mermaid-dcacb631.js"; +import { o as ordinal } from "./ordinal-475e0c0c.js"; +import { d as d3schemeTableau10 } from "./Tableau10-31042135.js"; +import "./init-cc95ec8e.js"; +var parser = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 9], $V1 = [1, 10], $V2 = [1, 5, 10, 12]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "SANKEY": 4, "NEWLINE": 5, "csv": 6, "opt_eof": 7, "record": 8, "csv_tail": 9, "EOF": 10, "field[source]": 11, "COMMA": 12, "field[target]": 13, "field[value]": 14, "field": 15, "escaped": 16, "non_escaped": 17, "DQUOTE": 18, "ESCAPED_TEXT": 19, "NON_ESCAPED_TEXT": 20, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 4: "SANKEY", 5: "NEWLINE", 10: "EOF", 11: "field[source]", 12: "COMMA", 13: "field[target]", 14: "field[value]", 18: "DQUOTE", 19: "ESCAPED_TEXT", 20: "NON_ESCAPED_TEXT" }, + productions_: [0, [3, 4], [6, 2], [9, 2], [9, 0], [7, 1], [7, 0], [8, 5], [15, 1], [15, 1], [16, 3], [17, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 7: + const source = yy.findOrCreateNode($$[$0 - 4].trim().replaceAll('""', '"')); + const target = yy.findOrCreateNode($$[$0 - 2].trim().replaceAll('""', '"')); + const value2 = parseFloat($$[$0].trim()); + yy.addLink(source, target, value2); + break; + case 8: + case 9: + case 11: + this.$ = $$[$0]; + break; + case 10: + this.$ = $$[$0 - 1]; + break; + } + }, + table: [{ 3: 1, 4: [1, 2] }, { 1: [3] }, { 5: [1, 3] }, { 6: 4, 8: 5, 15: 6, 16: 7, 17: 8, 18: $V0, 20: $V1 }, { 1: [2, 6], 7: 11, 10: [1, 12] }, o($V1, [2, 4], { 9: 13, 5: [1, 14] }), { 12: [1, 15] }, o($V2, [2, 8]), o($V2, [2, 9]), { 19: [1, 16] }, o($V2, [2, 11]), { 1: [2, 1] }, { 1: [2, 5] }, o($V1, [2, 2]), { 6: 17, 8: 5, 15: 6, 16: 7, 17: 8, 18: $V0, 20: $V1 }, { 15: 18, 16: 7, 17: 8, 18: $V0, 20: $V1 }, { 18: [1, 19] }, o($V1, [2, 3]), { 12: [1, 20] }, o($V2, [2, 10]), { 15: 21, 16: 7, 17: 8, 18: $V0, 20: $V1 }, o([1, 5, 10], [2, 7])], + defaultActions: { 11: [2, 1], 12: [2, 5] }, + parseError: function parseError(str, hash) { + if (hash.recoverable) { + this.trace(str); + } else { + var error = new Error(str); + error.hash = hash; + throw error; + } + }, + parse: function parse(input) { + var self = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex() { + var token; + token = tstack.pop() || lexer2.lex() || EOF; + if (typeof token !== "number") { + if (token instanceof Array) { + tstack = token; + token = tstack.pop(); + } + token = self.symbols_[token] || token; + } + return token; + } + var symbol, state, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state = stack[stack.length - 1]; + if (this.defaultActions[state]) { + action = this.defaultActions[state]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex(); + } + action = table[state] && table[state][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str, hash); + } else { + throw new Error(str); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch = this._input[0]; + this.yytext += ch; + this.yyleng++; + this.offset++; + this.match += ch; + this.matched += ch; + var lines = ch.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch; + }, + // unshifts one char (or a string) into the input + unput: function(ch) { + var len = ch.length; + var lines = ch.split(/(?:\r\n?|\n)/g); + this._input = ch + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next = this.match; + if (next.length < 20) { + next += this._input.substr(0, 20 - next.length); + } + return (next.substr(0, 20) + (next.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token) { + return token; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token, match, tempMatch, index; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i = 0; i < rules.length; i++) { + tempMatch = this._input.match(this.rules[rules[i]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index = i; + if (this.options.backtrack_lexer) { + token = this.test_match(tempMatch, rules[i]); + if (token !== false) { + return token; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token = this.test_match(match, rules[index]); + if (token !== false) { + return token; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + this.pushState("csv"); + return 4; + case 1: + return 10; + case 2: + return 5; + case 3: + return 12; + case 4: + this.pushState("escaped_text"); + return 18; + case 5: + return 20; + case 6: + this.popState("escaped_text"); + return 18; + case 7: + return 19; + } + }, + rules: [/^(?:sankey-beta\b)/i, /^(?:$)/i, /^(?:((\u000D\u000A)|(\u000A)))/i, /^(?:(\u002C))/i, /^(?:(\u0022))/i, /^(?:([\u0020-\u0021\u0023-\u002B\u002D-\u007E])*)/i, /^(?:(\u0022)(?!(\u0022)))/i, /^(?:(([\u0020-\u0021\u0023-\u002B\u002D-\u007E])|(\u002C)|(\u000D)|(\u000A)|(\u0022)(\u0022))*)/i], + conditions: { "csv": { "rules": [1, 2, 3, 4, 5, 6, 7], "inclusive": false }, "escaped_text": { "rules": [6, 7], "inclusive": false }, "INITIAL": { "rules": [0, 1, 2, 3, 4, 5, 6, 7], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser() { + this.yy = {}; + } + Parser.prototype = parser2; + parser2.Parser = Parser; + return new Parser(); +}(); +parser.parser = parser; +const parser$1 = parser; +let links = []; +let nodes = []; +let nodesMap = {}; +const clear = () => { + links = []; + nodes = []; + nodesMap = {}; + clear$1(); +}; +class SankeyLink { + constructor(source, target, value2 = 0) { + this.source = source; + this.target = target; + this.value = value2; + } +} +const addLink = (source, target, value2) => { + links.push(new SankeyLink(source, target, value2)); +}; +class SankeyNode { + constructor(ID) { + this.ID = ID; + } +} +const findOrCreateNode = (ID) => { + ID = common.sanitizeText(ID, getConfig()); + if (!nodesMap[ID]) { + nodesMap[ID] = new SankeyNode(ID); + nodes.push(nodesMap[ID]); + } + return nodesMap[ID]; +}; +const getNodes = () => nodes; +const getLinks = () => links; +const getGraph = () => ({ + nodes: nodes.map((node) => ({ id: node.ID })), + links: links.map((link2) => ({ + source: link2.source.ID, + target: link2.target.ID, + value: link2.value + })) +}); +const db = { + nodesMap, + getConfig: () => getConfig().sankey, + getNodes, + getLinks, + getGraph, + addLink, + findOrCreateNode, + getAccTitle, + setAccTitle, + getAccDescription, + setAccDescription, + getDiagramTitle, + setDiagramTitle, + clear +}; +function max(values, valueof) { + let max2; + if (valueof === void 0) { + for (const value2 of values) { + if (value2 != null && (max2 < value2 || max2 === void 0 && value2 >= value2)) { + max2 = value2; + } + } + } else { + let index = -1; + for (let value2 of values) { + if ((value2 = valueof(value2, ++index, values)) != null && (max2 < value2 || max2 === void 0 && value2 >= value2)) { + max2 = value2; + } + } + } + return max2; +} +function min(values, valueof) { + let min2; + if (valueof === void 0) { + for (const value2 of values) { + if (value2 != null && (min2 > value2 || min2 === void 0 && value2 >= value2)) { + min2 = value2; + } + } + } else { + let index = -1; + for (let value2 of values) { + if ((value2 = valueof(value2, ++index, values)) != null && (min2 > value2 || min2 === void 0 && value2 >= value2)) { + min2 = value2; + } + } + } + return min2; +} +function sum(values, valueof) { + let sum2 = 0; + if (valueof === void 0) { + for (let value2 of values) { + if (value2 = +value2) { + sum2 += value2; + } + } + } else { + let index = -1; + for (let value2 of values) { + if (value2 = +valueof(value2, ++index, values)) { + sum2 += value2; + } + } + } + return sum2; +} +function targetDepth(d) { + return d.target.depth; +} +function left(node) { + return node.depth; +} +function right(node, n) { + return n - 1 - node.height; +} +function justify(node, n) { + return node.sourceLinks.length ? node.depth : n - 1; +} +function center(node) { + return node.targetLinks.length ? node.depth : node.sourceLinks.length ? min(node.sourceLinks, targetDepth) - 1 : 0; +} +function constant$1(x2) { + return function() { + return x2; + }; +} +function ascendingSourceBreadth(a, b) { + return ascendingBreadth(a.source, b.source) || a.index - b.index; +} +function ascendingTargetBreadth(a, b) { + return ascendingBreadth(a.target, b.target) || a.index - b.index; +} +function ascendingBreadth(a, b) { + return a.y0 - b.y0; +} +function value(d) { + return d.value; +} +function defaultId(d) { + return d.index; +} +function defaultNodes(graph) { + return graph.nodes; +} +function defaultLinks(graph) { + return graph.links; +} +function find(nodeById, id) { + const node = nodeById.get(id); + if (!node) + throw new Error("missing: " + id); + return node; +} +function computeLinkBreadths({ nodes: nodes2 }) { + for (const node of nodes2) { + let y0 = node.y0; + let y1 = y0; + for (const link2 of node.sourceLinks) { + link2.y0 = y0 + link2.width / 2; + y0 += link2.width; + } + for (const link2 of node.targetLinks) { + link2.y1 = y1 + link2.width / 2; + y1 += link2.width; + } + } +} +function Sankey() { + let x0 = 0, y0 = 0, x1 = 1, y1 = 1; + let dx = 24; + let dy = 8, py; + let id = defaultId; + let align = justify; + let sort; + let linkSort; + let nodes2 = defaultNodes; + let links2 = defaultLinks; + let iterations = 6; + function sankey() { + const graph = { nodes: nodes2.apply(null, arguments), links: links2.apply(null, arguments) }; + computeNodeLinks(graph); + computeNodeValues(graph); + computeNodeDepths(graph); + computeNodeHeights(graph); + computeNodeBreadths(graph); + computeLinkBreadths(graph); + return graph; + } + sankey.update = function(graph) { + computeLinkBreadths(graph); + return graph; + }; + sankey.nodeId = function(_) { + return arguments.length ? (id = typeof _ === "function" ? _ : constant$1(_), sankey) : id; + }; + sankey.nodeAlign = function(_) { + return arguments.length ? (align = typeof _ === "function" ? _ : constant$1(_), sankey) : align; + }; + sankey.nodeSort = function(_) { + return arguments.length ? (sort = _, sankey) : sort; + }; + sankey.nodeWidth = function(_) { + return arguments.length ? (dx = +_, sankey) : dx; + }; + sankey.nodePadding = function(_) { + return arguments.length ? (dy = py = +_, sankey) : dy; + }; + sankey.nodes = function(_) { + return arguments.length ? (nodes2 = typeof _ === "function" ? _ : constant$1(_), sankey) : nodes2; + }; + sankey.links = function(_) { + return arguments.length ? (links2 = typeof _ === "function" ? _ : constant$1(_), sankey) : links2; + }; + sankey.linkSort = function(_) { + return arguments.length ? (linkSort = _, sankey) : linkSort; + }; + sankey.size = function(_) { + return arguments.length ? (x0 = y0 = 0, x1 = +_[0], y1 = +_[1], sankey) : [x1 - x0, y1 - y0]; + }; + sankey.extent = function(_) { + return arguments.length ? (x0 = +_[0][0], x1 = +_[1][0], y0 = +_[0][1], y1 = +_[1][1], sankey) : [[x0, y0], [x1, y1]]; + }; + sankey.iterations = function(_) { + return arguments.length ? (iterations = +_, sankey) : iterations; + }; + function computeNodeLinks({ nodes: nodes3, links: links3 }) { + for (const [i, node] of nodes3.entries()) { + node.index = i; + node.sourceLinks = []; + node.targetLinks = []; + } + const nodeById = new Map(nodes3.map((d, i) => [id(d, i, nodes3), d])); + for (const [i, link2] of links3.entries()) { + link2.index = i; + let { source, target } = link2; + if (typeof source !== "object") + source = link2.source = find(nodeById, source); + if (typeof target !== "object") + target = link2.target = find(nodeById, target); + source.sourceLinks.push(link2); + target.targetLinks.push(link2); + } + if (linkSort != null) { + for (const { sourceLinks, targetLinks } of nodes3) { + sourceLinks.sort(linkSort); + targetLinks.sort(linkSort); + } + } + } + function computeNodeValues({ nodes: nodes3 }) { + for (const node of nodes3) { + node.value = node.fixedValue === void 0 ? Math.max(sum(node.sourceLinks, value), sum(node.targetLinks, value)) : node.fixedValue; + } + } + function computeNodeDepths({ nodes: nodes3 }) { + const n = nodes3.length; + let current = new Set(nodes3); + let next = /* @__PURE__ */ new Set(); + let x2 = 0; + while (current.size) { + for (const node of current) { + node.depth = x2; + for (const { target } of node.sourceLinks) { + next.add(target); + } + } + if (++x2 > n) + throw new Error("circular link"); + current = next; + next = /* @__PURE__ */ new Set(); + } + } + function computeNodeHeights({ nodes: nodes3 }) { + const n = nodes3.length; + let current = new Set(nodes3); + let next = /* @__PURE__ */ new Set(); + let x2 = 0; + while (current.size) { + for (const node of current) { + node.height = x2; + for (const { source } of node.targetLinks) { + next.add(source); + } + } + if (++x2 > n) + throw new Error("circular link"); + current = next; + next = /* @__PURE__ */ new Set(); + } + } + function computeNodeLayers({ nodes: nodes3 }) { + const x2 = max(nodes3, (d) => d.depth) + 1; + const kx = (x1 - x0 - dx) / (x2 - 1); + const columns = new Array(x2); + for (const node of nodes3) { + const i = Math.max(0, Math.min(x2 - 1, Math.floor(align.call(null, node, x2)))); + node.layer = i; + node.x0 = x0 + i * kx; + node.x1 = node.x0 + dx; + if (columns[i]) + columns[i].push(node); + else + columns[i] = [node]; + } + if (sort) + for (const column of columns) { + column.sort(sort); + } + return columns; + } + function initializeNodeBreadths(columns) { + const ky = min(columns, (c) => (y1 - y0 - (c.length - 1) * py) / sum(c, value)); + for (const nodes3 of columns) { + let y2 = y0; + for (const node of nodes3) { + node.y0 = y2; + node.y1 = y2 + node.value * ky; + y2 = node.y1 + py; + for (const link2 of node.sourceLinks) { + link2.width = link2.value * ky; + } + } + y2 = (y1 - y2 + py) / (nodes3.length + 1); + for (let i = 0; i < nodes3.length; ++i) { + const node = nodes3[i]; + node.y0 += y2 * (i + 1); + node.y1 += y2 * (i + 1); + } + reorderLinks(nodes3); + } + } + function computeNodeBreadths(graph) { + const columns = computeNodeLayers(graph); + py = Math.min(dy, (y1 - y0) / (max(columns, (c) => c.length) - 1)); + initializeNodeBreadths(columns); + for (let i = 0; i < iterations; ++i) { + const alpha = Math.pow(0.99, i); + const beta = Math.max(1 - alpha, (i + 1) / iterations); + relaxRightToLeft(columns, alpha, beta); + relaxLeftToRight(columns, alpha, beta); + } + } + function relaxLeftToRight(columns, alpha, beta) { + for (let i = 1, n = columns.length; i < n; ++i) { + const column = columns[i]; + for (const target of column) { + let y2 = 0; + let w = 0; + for (const { source, value: value2 } of target.targetLinks) { + let v = value2 * (target.layer - source.layer); + y2 += targetTop(source, target) * v; + w += v; + } + if (!(w > 0)) + continue; + let dy2 = (y2 / w - target.y0) * alpha; + target.y0 += dy2; + target.y1 += dy2; + reorderNodeLinks(target); + } + if (sort === void 0) + column.sort(ascendingBreadth); + resolveCollisions(column, beta); + } + } + function relaxRightToLeft(columns, alpha, beta) { + for (let n = columns.length, i = n - 2; i >= 0; --i) { + const column = columns[i]; + for (const source of column) { + let y2 = 0; + let w = 0; + for (const { target, value: value2 } of source.sourceLinks) { + let v = value2 * (target.layer - source.layer); + y2 += sourceTop(source, target) * v; + w += v; + } + if (!(w > 0)) + continue; + let dy2 = (y2 / w - source.y0) * alpha; + source.y0 += dy2; + source.y1 += dy2; + reorderNodeLinks(source); + } + if (sort === void 0) + column.sort(ascendingBreadth); + resolveCollisions(column, beta); + } + } + function resolveCollisions(nodes3, alpha) { + const i = nodes3.length >> 1; + const subject = nodes3[i]; + resolveCollisionsBottomToTop(nodes3, subject.y0 - py, i - 1, alpha); + resolveCollisionsTopToBottom(nodes3, subject.y1 + py, i + 1, alpha); + resolveCollisionsBottomToTop(nodes3, y1, nodes3.length - 1, alpha); + resolveCollisionsTopToBottom(nodes3, y0, 0, alpha); + } + function resolveCollisionsTopToBottom(nodes3, y2, i, alpha) { + for (; i < nodes3.length; ++i) { + const node = nodes3[i]; + const dy2 = (y2 - node.y0) * alpha; + if (dy2 > 1e-6) + node.y0 += dy2, node.y1 += dy2; + y2 = node.y1 + py; + } + } + function resolveCollisionsBottomToTop(nodes3, y2, i, alpha) { + for (; i >= 0; --i) { + const node = nodes3[i]; + const dy2 = (node.y1 - y2) * alpha; + if (dy2 > 1e-6) + node.y0 -= dy2, node.y1 -= dy2; + y2 = node.y0 - py; + } + } + function reorderNodeLinks({ sourceLinks, targetLinks }) { + if (linkSort === void 0) { + for (const { source: { sourceLinks: sourceLinks2 } } of targetLinks) { + sourceLinks2.sort(ascendingTargetBreadth); + } + for (const { target: { targetLinks: targetLinks2 } } of sourceLinks) { + targetLinks2.sort(ascendingSourceBreadth); + } + } + } + function reorderLinks(nodes3) { + if (linkSort === void 0) { + for (const { sourceLinks, targetLinks } of nodes3) { + sourceLinks.sort(ascendingTargetBreadth); + targetLinks.sort(ascendingSourceBreadth); + } + } + } + function targetTop(source, target) { + let y2 = source.y0 - (source.sourceLinks.length - 1) * py / 2; + for (const { target: node, width } of source.sourceLinks) { + if (node === target) + break; + y2 += width + py; + } + for (const { source: node, width } of target.targetLinks) { + if (node === source) + break; + y2 -= width; + } + return y2; + } + function sourceTop(source, target) { + let y2 = target.y0 - (target.targetLinks.length - 1) * py / 2; + for (const { source: node, width } of target.targetLinks) { + if (node === source) + break; + y2 += width + py; + } + for (const { target: node, width } of source.sourceLinks) { + if (node === target) + break; + y2 -= width; + } + return y2; + } + return sankey; +} +var pi = Math.PI, tau = 2 * pi, epsilon = 1e-6, tauEpsilon = tau - epsilon; +function Path() { + this._x0 = this._y0 = // start of current subpath + this._x1 = this._y1 = null; + this._ = ""; +} +function path() { + return new Path(); +} +Path.prototype = path.prototype = { + constructor: Path, + moveTo: function(x2, y2) { + this._ += "M" + (this._x0 = this._x1 = +x2) + "," + (this._y0 = this._y1 = +y2); + }, + closePath: function() { + if (this._x1 !== null) { + this._x1 = this._x0, this._y1 = this._y0; + this._ += "Z"; + } + }, + lineTo: function(x2, y2) { + this._ += "L" + (this._x1 = +x2) + "," + (this._y1 = +y2); + }, + quadraticCurveTo: function(x1, y1, x2, y2) { + this._ += "Q" + +x1 + "," + +y1 + "," + (this._x1 = +x2) + "," + (this._y1 = +y2); + }, + bezierCurveTo: function(x1, y1, x2, y2, x3, y3) { + this._ += "C" + +x1 + "," + +y1 + "," + +x2 + "," + +y2 + "," + (this._x1 = +x3) + "," + (this._y1 = +y3); + }, + arcTo: function(x1, y1, x2, y2, r) { + x1 = +x1, y1 = +y1, x2 = +x2, y2 = +y2, r = +r; + var x0 = this._x1, y0 = this._y1, x21 = x2 - x1, y21 = y2 - y1, x01 = x0 - x1, y01 = y0 - y1, l01_2 = x01 * x01 + y01 * y01; + if (r < 0) + throw new Error("negative radius: " + r); + if (this._x1 === null) { + this._ += "M" + (this._x1 = x1) + "," + (this._y1 = y1); + } else if (!(l01_2 > epsilon)) + ; + else if (!(Math.abs(y01 * x21 - y21 * x01) > epsilon) || !r) { + this._ += "L" + (this._x1 = x1) + "," + (this._y1 = y1); + } else { + var x20 = x2 - x0, y20 = y2 - y0, l21_2 = x21 * x21 + y21 * y21, l20_2 = x20 * x20 + y20 * y20, l21 = Math.sqrt(l21_2), l01 = Math.sqrt(l01_2), l = r * Math.tan((pi - Math.acos((l21_2 + l01_2 - l20_2) / (2 * l21 * l01))) / 2), t01 = l / l01, t21 = l / l21; + if (Math.abs(t01 - 1) > epsilon) { + this._ += "L" + (x1 + t01 * x01) + "," + (y1 + t01 * y01); + } + this._ += "A" + r + "," + r + ",0,0," + +(y01 * x20 > x01 * y20) + "," + (this._x1 = x1 + t21 * x21) + "," + (this._y1 = y1 + t21 * y21); + } + }, + arc: function(x2, y2, r, a0, a1, ccw) { + x2 = +x2, y2 = +y2, r = +r, ccw = !!ccw; + var dx = r * Math.cos(a0), dy = r * Math.sin(a0), x0 = x2 + dx, y0 = y2 + dy, cw = 1 ^ ccw, da = ccw ? a0 - a1 : a1 - a0; + if (r < 0) + throw new Error("negative radius: " + r); + if (this._x1 === null) { + this._ += "M" + x0 + "," + y0; + } else if (Math.abs(this._x1 - x0) > epsilon || Math.abs(this._y1 - y0) > epsilon) { + this._ += "L" + x0 + "," + y0; + } + if (!r) + return; + if (da < 0) + da = da % tau + tau; + if (da > tauEpsilon) { + this._ += "A" + r + "," + r + ",0,1," + cw + "," + (x2 - dx) + "," + (y2 - dy) + "A" + r + "," + r + ",0,1," + cw + "," + (this._x1 = x0) + "," + (this._y1 = y0); + } else if (da > epsilon) { + this._ += "A" + r + "," + r + ",0," + +(da >= pi) + "," + cw + "," + (this._x1 = x2 + r * Math.cos(a1)) + "," + (this._y1 = y2 + r * Math.sin(a1)); + } + }, + rect: function(x2, y2, w, h) { + this._ += "M" + (this._x0 = this._x1 = +x2) + "," + (this._y0 = this._y1 = +y2) + "h" + +w + "v" + +h + "h" + -w + "Z"; + }, + toString: function() { + return this._; + } +}; +function constant(x2) { + return function constant2() { + return x2; + }; +} +function x(p) { + return p[0]; +} +function y(p) { + return p[1]; +} +var slice = Array.prototype.slice; +function linkSource(d) { + return d.source; +} +function linkTarget(d) { + return d.target; +} +function link(curve) { + var source = linkSource, target = linkTarget, x$1 = x, y$1 = y, context = null; + function link2() { + var buffer, argv = slice.call(arguments), s = source.apply(this, argv), t = target.apply(this, argv); + if (!context) + context = buffer = path(); + curve(context, +x$1.apply(this, (argv[0] = s, argv)), +y$1.apply(this, argv), +x$1.apply(this, (argv[0] = t, argv)), +y$1.apply(this, argv)); + if (buffer) + return context = null, buffer + "" || null; + } + link2.source = function(_) { + return arguments.length ? (source = _, link2) : source; + }; + link2.target = function(_) { + return arguments.length ? (target = _, link2) : target; + }; + link2.x = function(_) { + return arguments.length ? (x$1 = typeof _ === "function" ? _ : constant(+_), link2) : x$1; + }; + link2.y = function(_) { + return arguments.length ? (y$1 = typeof _ === "function" ? _ : constant(+_), link2) : y$1; + }; + link2.context = function(_) { + return arguments.length ? (context = _ == null ? null : _, link2) : context; + }; + return link2; +} +function curveHorizontal(context, x0, y0, x1, y1) { + context.moveTo(x0, y0); + context.bezierCurveTo(x0 = (x0 + x1) / 2, y0, x0, y1, x1, y1); +} +function linkHorizontal() { + return link(curveHorizontal); +} +function horizontalSource(d) { + return [d.source.x1, d.y0]; +} +function horizontalTarget(d) { + return [d.target.x0, d.y1]; +} +function d3SankeyLinkHorizontal() { + return linkHorizontal().source(horizontalSource).target(horizontalTarget); +} +const _Uid = class _Uid2 { + static next(name) { + return new _Uid2(name + ++_Uid2.count); + } + constructor(id) { + this.id = id; + this.href = `#${id}`; + } + toString() { + return "url(" + this.href + ")"; + } +}; +_Uid.count = 0; +let Uid = _Uid; +const alignmentsMap = { + left, + right, + center, + justify +}; +const draw = function(text, id, _version, diagObj) { + const { securityLevel, sankey: conf } = getConfig(); + const defaultSankeyConfig = defaultConfig.sankey; + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = d3select("#i" + id); + } + const root = securityLevel === "sandbox" ? d3select(sandboxElement.nodes()[0].contentDocument.body) : d3select("body"); + const svg = securityLevel === "sandbox" ? root.select(`[id="${id}"]`) : d3select(`[id="${id}"]`); + const width = (conf == null ? void 0 : conf.width) ?? defaultSankeyConfig.width; + const height = (conf == null ? void 0 : conf.height) ?? defaultSankeyConfig.width; + const useMaxWidth = (conf == null ? void 0 : conf.useMaxWidth) ?? defaultSankeyConfig.useMaxWidth; + const nodeAlignment = (conf == null ? void 0 : conf.nodeAlignment) ?? defaultSankeyConfig.nodeAlignment; + const prefix = (conf == null ? void 0 : conf.prefix) ?? defaultSankeyConfig.prefix; + const suffix = (conf == null ? void 0 : conf.suffix) ?? defaultSankeyConfig.suffix; + const showValues = (conf == null ? void 0 : conf.showValues) ?? defaultSankeyConfig.showValues; + const graph = diagObj.db.getGraph(); + const nodeAlign = alignmentsMap[nodeAlignment]; + const nodeWidth = 10; + const sankey = Sankey().nodeId((d) => d.id).nodeWidth(nodeWidth).nodePadding(10 + (showValues ? 15 : 0)).nodeAlign(nodeAlign).extent([ + [0, 0], + [width, height] + ]); + sankey(graph); + const colorScheme = ordinal(d3schemeTableau10); + svg.append("g").attr("class", "nodes").selectAll(".node").data(graph.nodes).join("g").attr("class", "node").attr("id", (d) => (d.uid = Uid.next("node-")).id).attr("transform", function(d) { + return "translate(" + d.x0 + "," + d.y0 + ")"; + }).attr("x", (d) => d.x0).attr("y", (d) => d.y0).append("rect").attr("height", (d) => { + return d.y1 - d.y0; + }).attr("width", (d) => d.x1 - d.x0).attr("fill", (d) => colorScheme(d.id)); + const getText = ({ id: id2, value: value2 }) => { + if (!showValues) { + return id2; + } + return `${id2} +${prefix}${Math.round(value2 * 100) / 100}${suffix}`; + }; + svg.append("g").attr("class", "node-labels").attr("font-family", "sans-serif").attr("font-size", 14).selectAll("text").data(graph.nodes).join("text").attr("x", (d) => d.x0 < width / 2 ? d.x1 + 6 : d.x0 - 6).attr("y", (d) => (d.y1 + d.y0) / 2).attr("dy", `${showValues ? "0" : "0.35"}em`).attr("text-anchor", (d) => d.x0 < width / 2 ? "start" : "end").text(getText); + const link2 = svg.append("g").attr("class", "links").attr("fill", "none").attr("stroke-opacity", 0.5).selectAll(".link").data(graph.links).join("g").attr("class", "link").style("mix-blend-mode", "multiply"); + const linkColor = (conf == null ? void 0 : conf.linkColor) || "gradient"; + if (linkColor === "gradient") { + const gradient = link2.append("linearGradient").attr("id", (d) => (d.uid = Uid.next("linearGradient-")).id).attr("gradientUnits", "userSpaceOnUse").attr("x1", (d) => d.source.x1).attr("x2", (d) => d.target.x0); + gradient.append("stop").attr("offset", "0%").attr("stop-color", (d) => colorScheme(d.source.id)); + gradient.append("stop").attr("offset", "100%").attr("stop-color", (d) => colorScheme(d.target.id)); + } + let coloring; + switch (linkColor) { + case "gradient": + coloring = (d) => d.uid; + break; + case "source": + coloring = (d) => colorScheme(d.source.id); + break; + case "target": + coloring = (d) => colorScheme(d.target.id); + break; + default: + coloring = linkColor; + } + link2.append("path").attr("d", d3SankeyLinkHorizontal()).attr("stroke", coloring).attr("stroke-width", (d) => Math.max(1, d.width)); + setupGraphViewbox(void 0, svg, 0, useMaxWidth); +}; +const renderer = { + draw +}; +const prepareTextForParsing = (text) => { + const textToParse = text.replaceAll(/^[^\S\n\r]+|[^\S\n\r]+$/g, "").replaceAll(/([\n\r])+/g, "\n").trim(); + return textToParse; +}; +const originalParse = parser$1.parse.bind(parser$1); +parser$1.parse = (text) => originalParse(prepareTextForParsing(text)); +const diagram = { + parser: parser$1, + db, + renderer +}; +export { + diagram +}; diff --git a/0.6.0/js/mermaid/sankeyDiagram-52ec8976.js b/0.6.0/js/mermaid/sankeyDiagram-52ec8976.js new file mode 100644 index 0000000..c30db0d --- /dev/null +++ b/0.6.0/js/mermaid/sankeyDiagram-52ec8976.js @@ -0,0 +1,818 @@ +import { c as rt, g as mt, s as kt, a as _t, b as xt, D as vt, C as bt, E as wt, f as St, ar as Lt, j as G, t as Et } from "./mermaid-9f2aa176.js"; +import { o as At } from "./ordinal-5695958c.js"; +import { d as Tt } from "./Tableau10-558cc280.js"; +import "./init-f9637058.js"; +var tt = function() { + var t = function(m, i, o, c) { + for (o = o || {}, c = m.length; c--; o[m[c]] = i) + ; + return o; + }, n = [1, 9], s = [1, 10], a = [1, 5, 10, 12], u = { + trace: function() { + }, + yy: {}, + symbols_: { error: 2, start: 3, SANKEY: 4, NEWLINE: 5, csv: 6, opt_eof: 7, record: 8, csv_tail: 9, EOF: 10, "field[source]": 11, COMMA: 12, "field[target]": 13, "field[value]": 14, field: 15, escaped: 16, non_escaped: 17, DQUOTE: 18, ESCAPED_TEXT: 19, NON_ESCAPED_TEXT: 20, $accept: 0, $end: 1 }, + terminals_: { 2: "error", 4: "SANKEY", 5: "NEWLINE", 10: "EOF", 11: "field[source]", 12: "COMMA", 13: "field[target]", 14: "field[value]", 18: "DQUOTE", 19: "ESCAPED_TEXT", 20: "NON_ESCAPED_TEXT" }, + productions_: [0, [3, 4], [6, 2], [9, 2], [9, 0], [7, 1], [7, 0], [8, 5], [15, 1], [15, 1], [16, 3], [17, 1]], + performAction: function(i, o, c, k, b, d, x) { + var E = d.length - 1; + switch (b) { + case 7: + const L = k.findOrCreateNode(d[E - 4].trim().replaceAll('""', '"')), A = k.findOrCreateNode(d[E - 2].trim().replaceAll('""', '"')), N = parseFloat(d[E].trim()); + k.addLink(L, A, N); + break; + case 8: + case 9: + case 11: + this.$ = d[E]; + break; + case 10: + this.$ = d[E - 1]; + break; + } + }, + table: [{ 3: 1, 4: [1, 2] }, { 1: [3] }, { 5: [1, 3] }, { 6: 4, 8: 5, 15: 6, 16: 7, 17: 8, 18: n, 20: s }, { 1: [2, 6], 7: 11, 10: [1, 12] }, t(s, [2, 4], { 9: 13, 5: [1, 14] }), { 12: [1, 15] }, t(a, [2, 8]), t(a, [2, 9]), { 19: [1, 16] }, t(a, [2, 11]), { 1: [2, 1] }, { 1: [2, 5] }, t(s, [2, 2]), { 6: 17, 8: 5, 15: 6, 16: 7, 17: 8, 18: n, 20: s }, { 15: 18, 16: 7, 17: 8, 18: n, 20: s }, { 18: [1, 19] }, t(s, [2, 3]), { 12: [1, 20] }, t(a, [2, 10]), { 15: 21, 16: 7, 17: 8, 18: n, 20: s }, t([1, 5, 10], [2, 7])], + defaultActions: { 11: [2, 1], 12: [2, 5] }, + parseError: function(i, o) { + if (o.recoverable) + this.trace(i); + else { + var c = new Error(i); + throw c.hash = o, c; + } + }, + parse: function(i) { + var o = this, c = [0], k = [], b = [null], d = [], x = this.table, E = "", L = 0, A = 0, N = 2, C = 1, j = d.slice.call(arguments, 1), S = Object.create(this.lexer), M = { yy: {} }; + for (var $ in this.yy) + Object.prototype.hasOwnProperty.call(this.yy, $) && (M.yy[$] = this.yy[$]); + S.setInput(i, M.yy), M.yy.lexer = S, M.yy.parser = this, typeof S.yylloc > "u" && (S.yylloc = {}); + var P = S.yylloc; + d.push(P); + var I = S.options && S.options.ranges; + typeof M.yy.parseError == "function" ? this.parseError = M.yy.parseError : this.parseError = Object.getPrototypeOf(this).parseError; + function g() { + var v; + return v = k.pop() || S.lex() || C, typeof v != "number" && (v instanceof Array && (k = v, v = k.pop()), v = o.symbols_[v] || v), v; + } + for (var w, O, T, V, e = {}, f, l, h, r; ; ) { + if (O = c[c.length - 1], this.defaultActions[O] ? T = this.defaultActions[O] : ((w === null || typeof w > "u") && (w = g()), T = x[O] && x[O][w]), typeof T > "u" || !T.length || !T[0]) { + var _ = ""; + r = []; + for (f in x[O]) + this.terminals_[f] && f > N && r.push("'" + this.terminals_[f] + "'"); + S.showPosition ? _ = "Parse error on line " + (L + 1) + `: +` + S.showPosition() + ` +Expecting ` + r.join(", ") + ", got '" + (this.terminals_[w] || w) + "'" : _ = "Parse error on line " + (L + 1) + ": Unexpected " + (w == C ? "end of input" : "'" + (this.terminals_[w] || w) + "'"), this.parseError(_, { + text: S.match, + token: this.terminals_[w] || w, + line: S.yylineno, + loc: P, + expected: r + }); + } + if (T[0] instanceof Array && T.length > 1) + throw new Error("Parse Error: multiple actions possible at state: " + O + ", token: " + w); + switch (T[0]) { + case 1: + c.push(w), b.push(S.yytext), d.push(S.yylloc), c.push(T[1]), w = null, A = S.yyleng, E = S.yytext, L = S.yylineno, P = S.yylloc; + break; + case 2: + if (l = this.productions_[T[1]][1], e.$ = b[b.length - l], e._$ = { + first_line: d[d.length - (l || 1)].first_line, + last_line: d[d.length - 1].last_line, + first_column: d[d.length - (l || 1)].first_column, + last_column: d[d.length - 1].last_column + }, I && (e._$.range = [ + d[d.length - (l || 1)].range[0], + d[d.length - 1].range[1] + ]), V = this.performAction.apply(e, [ + E, + A, + L, + M.yy, + T[1], + b, + d + ].concat(j)), typeof V < "u") + return V; + l && (c = c.slice(0, -1 * l * 2), b = b.slice(0, -1 * l), d = d.slice(0, -1 * l)), c.push(this.productions_[T[1]][0]), b.push(e.$), d.push(e._$), h = x[c[c.length - 2]][c[c.length - 1]], c.push(h); + break; + case 3: + return !0; + } + } + return !0; + } + }, y = function() { + var m = { + EOF: 1, + parseError: function(o, c) { + if (this.yy.parser) + this.yy.parser.parseError(o, c); + else + throw new Error(o); + }, + // resets the lexer, sets new input + setInput: function(i, o) { + return this.yy = o || this.yy || {}, this._input = i, 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 i = this._input[0]; + this.yytext += i, this.yyleng++, this.offset++, this.match += i, this.matched += i; + var o = i.match(/(?:\r\n?|\n).*/g); + return o ? (this.yylineno++, this.yylloc.last_line++) : this.yylloc.last_column++, this.options.ranges && this.yylloc.range[1]++, this._input = this._input.slice(1), i; + }, + // unshifts one char (or a string) into the input + unput: function(i) { + var o = i.length, c = i.split(/(?:\r\n?|\n)/g); + this._input = i + this._input, this.yytext = this.yytext.substr(0, this.yytext.length - o), this.offset -= o; + var k = 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), c.length - 1 && (this.yylineno -= c.length - 1); + var b = 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: c ? (c.length === k.length ? this.yylloc.first_column : 0) + k[k.length - c.length].length - c[0].length : this.yylloc.first_column - o + }, this.options.ranges && (this.yylloc.range = [b[0], b[0] + this.yyleng - o]), 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(i) { + this.unput(this.match.slice(i)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var i = this.matched.substr(0, this.matched.length - this.match.length); + return (i.length > 20 ? "..." : "") + i.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var i = this.match; + return i.length < 20 && (i += this._input.substr(0, 20 - i.length)), (i.substr(0, 20) + (i.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var i = this.pastInput(), o = new Array(i.length + 1).join("-"); + return i + this.upcomingInput() + ` +` + o + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(i, o) { + var c, k, b; + if (this.options.backtrack_lexer && (b = { + 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 && (b.yylloc.range = this.yylloc.range.slice(0))), k = i[0].match(/(?:\r\n?|\n).*/g), k && (this.yylineno += k.length), this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: k ? k[k.length - 1].length - k[k.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + i[0].length + }, this.yytext += i[0], this.match += i[0], this.matches = i, 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(i[0].length), this.matched += i[0], c = this.performAction.call(this, this.yy, this, o, this.conditionStack[this.conditionStack.length - 1]), this.done && this._input && (this.done = !1), c) + return c; + if (this._backtrack) { + for (var d in b) + this[d] = b[d]; + return !1; + } + return !1; + }, + // return next match in input + next: function() { + if (this.done) + return this.EOF; + this._input || (this.done = !0); + var i, o, c, k; + this._more || (this.yytext = "", this.match = ""); + for (var b = this._currentRules(), d = 0; d < b.length; d++) + if (c = this._input.match(this.rules[b[d]]), c && (!o || c[0].length > o[0].length)) { + if (o = c, k = d, this.options.backtrack_lexer) { + if (i = this.test_match(c, b[d]), i !== !1) + return i; + if (this._backtrack) { + o = !1; + continue; + } else + return !1; + } else if (!this.options.flex) + break; + } + return o ? (i = this.test_match(o, b[k]), i !== !1 ? i : !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 o = this.next(); + return o || this.lex(); + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function(o) { + this.conditionStack.push(o); + }, + // pop the previously active lexer condition state off the condition stack + popState: function() { + var o = this.conditionStack.length - 1; + return o > 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(o) { + return o = this.conditionStack.length - 1 - Math.abs(o || 0), o >= 0 ? this.conditionStack[o] : "INITIAL"; + }, + // alias for begin(condition) + pushState: function(o) { + this.begin(o); + }, + // return the number of states currently on the stack + stateStackSize: function() { + return this.conditionStack.length; + }, + options: { "case-insensitive": !0 }, + performAction: function(o, c, k, b) { + switch (k) { + case 0: + return this.pushState("csv"), 4; + case 1: + return 10; + case 2: + return 5; + case 3: + return 12; + case 4: + return this.pushState("escaped_text"), 18; + case 5: + return 20; + case 6: + return this.popState("escaped_text"), 18; + case 7: + return 19; + } + }, + rules: [/^(?:sankey-beta\b)/i, /^(?:$)/i, /^(?:((\u000D\u000A)|(\u000A)))/i, /^(?:(\u002C))/i, /^(?:(\u0022))/i, /^(?:([\u0020-\u0021\u0023-\u002B\u002D-\u007E])*)/i, /^(?:(\u0022)(?!(\u0022)))/i, /^(?:(([\u0020-\u0021\u0023-\u002B\u002D-\u007E])|(\u002C)|(\u000D)|(\u000A)|(\u0022)(\u0022))*)/i], + conditions: { csv: { rules: [1, 2, 3, 4, 5, 6, 7], inclusive: !1 }, escaped_text: { rules: [6, 7], inclusive: !1 }, INITIAL: { rules: [0, 1, 2, 3, 4, 5, 6, 7], inclusive: !0 } } + }; + return m; + }(); + u.lexer = y; + function p() { + this.yy = {}; + } + return p.prototype = u, u.Parser = p, new p(); +}(); +tt.parser = tt; +const H = tt; +let q = [], Q = [], B = {}; +const Mt = () => { + q = [], Q = [], B = {}, wt(); +}; +class Nt { + constructor(n, s, a = 0) { + this.source = n, this.target = s, this.value = a; + } +} +const Ct = (t, n, s) => { + q.push(new Nt(t, n, s)); +}; +class Pt { + constructor(n) { + this.ID = n; + } +} +const It = (t) => (t = St.sanitizeText(t, rt()), B[t] || (B[t] = new Pt(t), Q.push(B[t])), B[t]), Ot = () => Q, $t = () => q, jt = () => ({ + nodes: Q.map((t) => ({ id: t.ID })), + links: q.map((t) => ({ + source: t.source.ID, + target: t.target.ID, + value: t.value + })) +}), zt = { + nodesMap: B, + getConfig: () => rt().sankey, + getNodes: Ot, + getLinks: $t, + getGraph: jt, + addLink: Ct, + findOrCreateNode: It, + getAccTitle: mt, + setAccTitle: kt, + getAccDescription: _t, + setAccDescription: xt, + getDiagramTitle: vt, + setDiagramTitle: bt, + clear: Mt +}; +function ot(t, n) { + let s; + if (n === void 0) + for (const a of t) + a != null && (s < a || s === void 0 && a >= a) && (s = a); + else { + let a = -1; + for (let u of t) + (u = n(u, ++a, t)) != null && (s < u || s === void 0 && u >= u) && (s = u); + } + return s; +} +function yt(t, n) { + let s; + if (n === void 0) + for (const a of t) + a != null && (s > a || s === void 0 && a >= a) && (s = a); + else { + let a = -1; + for (let u of t) + (u = n(u, ++a, t)) != null && (s > u || s === void 0 && u >= u) && (s = u); + } + return s; +} +function Z(t, n) { + let s = 0; + if (n === void 0) + for (let a of t) + (a = +a) && (s += a); + else { + let a = -1; + for (let u of t) + (u = +n(u, ++a, t)) && (s += u); + } + return s; +} +function Dt(t) { + return t.target.depth; +} +function Bt(t) { + return t.depth; +} +function Vt(t, n) { + return n - 1 - t.height; +} +function dt(t, n) { + return t.sourceLinks.length ? t.depth : n - 1; +} +function Rt(t) { + return t.targetLinks.length ? t.depth : t.sourceLinks.length ? yt(t.sourceLinks, Dt) - 1 : 0; +} +function Y(t) { + return function() { + return t; + }; +} +function lt(t, n) { + return X(t.source, n.source) || t.index - n.index; +} +function at(t, n) { + return X(t.target, n.target) || t.index - n.index; +} +function X(t, n) { + return t.y0 - n.y0; +} +function J(t) { + return t.value; +} +function Ut(t) { + return t.index; +} +function Ft(t) { + return t.nodes; +} +function Wt(t) { + return t.links; +} +function ct(t, n) { + const s = t.get(n); + if (!s) + throw new Error("missing: " + n); + return s; +} +function ut({ nodes: t }) { + for (const n of t) { + let s = n.y0, a = s; + for (const u of n.sourceLinks) + u.y0 = s + u.width / 2, s += u.width; + for (const u of n.targetLinks) + u.y1 = a + u.width / 2, a += u.width; + } +} +function Gt() { + let t = 0, n = 0, s = 1, a = 1, u = 24, y = 8, p, m = Ut, i = dt, o, c, k = Ft, b = Wt, d = 6; + function x() { + const e = { nodes: k.apply(null, arguments), links: b.apply(null, arguments) }; + return E(e), L(e), A(e), N(e), S(e), ut(e), e; + } + x.update = function(e) { + return ut(e), e; + }, x.nodeId = function(e) { + return arguments.length ? (m = typeof e == "function" ? e : Y(e), x) : m; + }, x.nodeAlign = function(e) { + return arguments.length ? (i = typeof e == "function" ? e : Y(e), x) : i; + }, x.nodeSort = function(e) { + return arguments.length ? (o = e, x) : o; + }, x.nodeWidth = function(e) { + return arguments.length ? (u = +e, x) : u; + }, x.nodePadding = function(e) { + return arguments.length ? (y = p = +e, x) : y; + }, x.nodes = function(e) { + return arguments.length ? (k = typeof e == "function" ? e : Y(e), x) : k; + }, x.links = function(e) { + return arguments.length ? (b = typeof e == "function" ? e : Y(e), x) : b; + }, x.linkSort = function(e) { + return arguments.length ? (c = e, x) : c; + }, x.size = function(e) { + return arguments.length ? (t = n = 0, s = +e[0], a = +e[1], x) : [s - t, a - n]; + }, x.extent = function(e) { + return arguments.length ? (t = +e[0][0], s = +e[1][0], n = +e[0][1], a = +e[1][1], x) : [[t, n], [s, a]]; + }, x.iterations = function(e) { + return arguments.length ? (d = +e, x) : d; + }; + function E({ nodes: e, links: f }) { + for (const [h, r] of e.entries()) + r.index = h, r.sourceLinks = [], r.targetLinks = []; + const l = new Map(e.map((h, r) => [m(h, r, e), h])); + for (const [h, r] of f.entries()) { + r.index = h; + let { source: _, target: v } = r; + typeof _ != "object" && (_ = r.source = ct(l, _)), typeof v != "object" && (v = r.target = ct(l, v)), _.sourceLinks.push(r), v.targetLinks.push(r); + } + if (c != null) + for (const { sourceLinks: h, targetLinks: r } of e) + h.sort(c), r.sort(c); + } + function L({ nodes: e }) { + for (const f of e) + f.value = f.fixedValue === void 0 ? Math.max(Z(f.sourceLinks, J), Z(f.targetLinks, J)) : f.fixedValue; + } + function A({ nodes: e }) { + const f = e.length; + let l = new Set(e), h = /* @__PURE__ */ new Set(), r = 0; + for (; l.size; ) { + for (const _ of l) { + _.depth = r; + for (const { target: v } of _.sourceLinks) + h.add(v); + } + if (++r > f) + throw new Error("circular link"); + l = h, h = /* @__PURE__ */ new Set(); + } + } + function N({ nodes: e }) { + const f = e.length; + let l = new Set(e), h = /* @__PURE__ */ new Set(), r = 0; + for (; l.size; ) { + for (const _ of l) { + _.height = r; + for (const { source: v } of _.targetLinks) + h.add(v); + } + if (++r > f) + throw new Error("circular link"); + l = h, h = /* @__PURE__ */ new Set(); + } + } + function C({ nodes: e }) { + const f = ot(e, (r) => r.depth) + 1, l = (s - t - u) / (f - 1), h = new Array(f); + for (const r of e) { + const _ = Math.max(0, Math.min(f - 1, Math.floor(i.call(null, r, f)))); + r.layer = _, r.x0 = t + _ * l, r.x1 = r.x0 + u, h[_] ? h[_].push(r) : h[_] = [r]; + } + if (o) + for (const r of h) + r.sort(o); + return h; + } + function j(e) { + const f = yt(e, (l) => (a - n - (l.length - 1) * p) / Z(l, J)); + for (const l of e) { + let h = n; + for (const r of l) { + r.y0 = h, r.y1 = h + r.value * f, h = r.y1 + p; + for (const _ of r.sourceLinks) + _.width = _.value * f; + } + h = (a - h + p) / (l.length + 1); + for (let r = 0; r < l.length; ++r) { + const _ = l[r]; + _.y0 += h * (r + 1), _.y1 += h * (r + 1); + } + O(l); + } + } + function S(e) { + const f = C(e); + p = Math.min(y, (a - n) / (ot(f, (l) => l.length) - 1)), j(f); + for (let l = 0; l < d; ++l) { + const h = Math.pow(0.99, l), r = Math.max(1 - h, (l + 1) / d); + $(f, h, r), M(f, h, r); + } + } + function M(e, f, l) { + for (let h = 1, r = e.length; h < r; ++h) { + const _ = e[h]; + for (const v of _) { + let R = 0, z = 0; + for (const { source: F, value: K } of v.targetLinks) { + let W = K * (v.layer - F.layer); + R += T(F, v) * W, z += W; + } + if (!(z > 0)) + continue; + let U = (R / z - v.y0) * f; + v.y0 += U, v.y1 += U, w(v); + } + o === void 0 && _.sort(X), P(_, l); + } + } + function $(e, f, l) { + for (let h = e.length, r = h - 2; r >= 0; --r) { + const _ = e[r]; + for (const v of _) { + let R = 0, z = 0; + for (const { target: F, value: K } of v.sourceLinks) { + let W = K * (F.layer - v.layer); + R += V(v, F) * W, z += W; + } + if (!(z > 0)) + continue; + let U = (R / z - v.y0) * f; + v.y0 += U, v.y1 += U, w(v); + } + o === void 0 && _.sort(X), P(_, l); + } + } + function P(e, f) { + const l = e.length >> 1, h = e[l]; + g(e, h.y0 - p, l - 1, f), I(e, h.y1 + p, l + 1, f), g(e, a, e.length - 1, f), I(e, n, 0, f); + } + function I(e, f, l, h) { + for (; l < e.length; ++l) { + const r = e[l], _ = (f - r.y0) * h; + _ > 1e-6 && (r.y0 += _, r.y1 += _), f = r.y1 + p; + } + } + function g(e, f, l, h) { + for (; l >= 0; --l) { + const r = e[l], _ = (r.y1 - f) * h; + _ > 1e-6 && (r.y0 -= _, r.y1 -= _), f = r.y0 - p; + } + } + function w({ sourceLinks: e, targetLinks: f }) { + if (c === void 0) { + for (const { source: { sourceLinks: l } } of f) + l.sort(at); + for (const { target: { targetLinks: l } } of e) + l.sort(lt); + } + } + function O(e) { + if (c === void 0) + for (const { sourceLinks: f, targetLinks: l } of e) + f.sort(at), l.sort(lt); + } + function T(e, f) { + let l = e.y0 - (e.sourceLinks.length - 1) * p / 2; + for (const { target: h, width: r } of e.sourceLinks) { + if (h === f) + break; + l += r + p; + } + for (const { source: h, width: r } of f.targetLinks) { + if (h === e) + break; + l -= r; + } + return l; + } + function V(e, f) { + let l = f.y0 - (f.targetLinks.length - 1) * p / 2; + for (const { source: h, width: r } of f.targetLinks) { + if (h === e) + break; + l += r + p; + } + for (const { target: h, width: r } of e.sourceLinks) { + if (h === f) + break; + l -= r; + } + return l; + } + return x; +} +var et = Math.PI, nt = 2 * et, D = 1e-6, Yt = nt - D; +function it() { + this._x0 = this._y0 = // start of current subpath + this._x1 = this._y1 = null, this._ = ""; +} +function gt() { + return new it(); +} +it.prototype = gt.prototype = { + constructor: it, + moveTo: function(t, n) { + this._ += "M" + (this._x0 = this._x1 = +t) + "," + (this._y0 = this._y1 = +n); + }, + closePath: function() { + this._x1 !== null && (this._x1 = this._x0, this._y1 = this._y0, this._ += "Z"); + }, + lineTo: function(t, n) { + this._ += "L" + (this._x1 = +t) + "," + (this._y1 = +n); + }, + quadraticCurveTo: function(t, n, s, a) { + this._ += "Q" + +t + "," + +n + "," + (this._x1 = +s) + "," + (this._y1 = +a); + }, + bezierCurveTo: function(t, n, s, a, u, y) { + this._ += "C" + +t + "," + +n + "," + +s + "," + +a + "," + (this._x1 = +u) + "," + (this._y1 = +y); + }, + arcTo: function(t, n, s, a, u) { + t = +t, n = +n, s = +s, a = +a, u = +u; + var y = this._x1, p = this._y1, m = s - t, i = a - n, o = y - t, c = p - n, k = o * o + c * c; + if (u < 0) + throw new Error("negative radius: " + u); + if (this._x1 === null) + this._ += "M" + (this._x1 = t) + "," + (this._y1 = n); + else if (k > D) + if (!(Math.abs(c * m - i * o) > D) || !u) + this._ += "L" + (this._x1 = t) + "," + (this._y1 = n); + else { + var b = s - y, d = a - p, x = m * m + i * i, E = b * b + d * d, L = Math.sqrt(x), A = Math.sqrt(k), N = u * Math.tan((et - Math.acos((x + k - E) / (2 * L * A))) / 2), C = N / A, j = N / L; + Math.abs(C - 1) > D && (this._ += "L" + (t + C * o) + "," + (n + C * c)), this._ += "A" + u + "," + u + ",0,0," + +(c * b > o * d) + "," + (this._x1 = t + j * m) + "," + (this._y1 = n + j * i); + } + }, + arc: function(t, n, s, a, u, y) { + t = +t, n = +n, s = +s, y = !!y; + var p = s * Math.cos(a), m = s * Math.sin(a), i = t + p, o = n + m, c = 1 ^ y, k = y ? a - u : u - a; + if (s < 0) + throw new Error("negative radius: " + s); + this._x1 === null ? this._ += "M" + i + "," + o : (Math.abs(this._x1 - i) > D || Math.abs(this._y1 - o) > D) && (this._ += "L" + i + "," + o), s && (k < 0 && (k = k % nt + nt), k > Yt ? this._ += "A" + s + "," + s + ",0,1," + c + "," + (t - p) + "," + (n - m) + "A" + s + "," + s + ",0,1," + c + "," + (this._x1 = i) + "," + (this._y1 = o) : k > D && (this._ += "A" + s + "," + s + ",0," + +(k >= et) + "," + c + "," + (this._x1 = t + s * Math.cos(u)) + "," + (this._y1 = n + s * Math.sin(u)))); + }, + rect: function(t, n, s, a) { + this._ += "M" + (this._x0 = this._x1 = +t) + "," + (this._y0 = this._y1 = +n) + "h" + +s + "v" + +a + "h" + -s + "Z"; + }, + toString: function() { + return this._; + } +}; +function ht(t) { + return function() { + return t; + }; +} +function Ht(t) { + return t[0]; +} +function Xt(t) { + return t[1]; +} +var qt = Array.prototype.slice; +function Qt(t) { + return t.source; +} +function Kt(t) { + return t.target; +} +function Zt(t) { + var n = Qt, s = Kt, a = Ht, u = Xt, y = null; + function p() { + var m, i = qt.call(arguments), o = n.apply(this, i), c = s.apply(this, i); + if (y || (y = m = gt()), t(y, +a.apply(this, (i[0] = o, i)), +u.apply(this, i), +a.apply(this, (i[0] = c, i)), +u.apply(this, i)), m) + return y = null, m + "" || null; + } + return p.source = function(m) { + return arguments.length ? (n = m, p) : n; + }, p.target = function(m) { + return arguments.length ? (s = m, p) : s; + }, p.x = function(m) { + return arguments.length ? (a = typeof m == "function" ? m : ht(+m), p) : a; + }, p.y = function(m) { + return arguments.length ? (u = typeof m == "function" ? m : ht(+m), p) : u; + }, p.context = function(m) { + return arguments.length ? (y = m ?? null, p) : y; + }, p; +} +function Jt(t, n, s, a, u) { + t.moveTo(n, s), t.bezierCurveTo(n = (n + a) / 2, s, n, u, a, u); +} +function te() { + return Zt(Jt); +} +function ee(t) { + return [t.source.x1, t.y0]; +} +function ne(t) { + return [t.target.x0, t.y1]; +} +function ie() { + return te().source(ee).target(ne); +} +const pt = class st { + static next(n) { + return new st(n + ++st.count); + } + constructor(n) { + this.id = n, this.href = `#${n}`; + } + toString() { + return "url(" + this.href + ")"; + } +}; +pt.count = 0; +let ft = pt; +const se = { + left: Bt, + right: Vt, + center: Rt, + justify: dt +}, re = function(t, n, s, a) { + const { securityLevel: u, sankey: y } = rt(), p = Lt.sankey; + let m; + u === "sandbox" && (m = G("#i" + n)); + const i = u === "sandbox" ? G(m.nodes()[0].contentDocument.body) : G("body"), o = u === "sandbox" ? i.select(`[id="${n}"]`) : G(`[id="${n}"]`), c = (y == null ? void 0 : y.width) ?? p.width, k = (y == null ? void 0 : y.height) ?? p.width, b = (y == null ? void 0 : y.useMaxWidth) ?? p.useMaxWidth, d = (y == null ? void 0 : y.nodeAlignment) ?? p.nodeAlignment, x = (y == null ? void 0 : y.prefix) ?? p.prefix, E = (y == null ? void 0 : y.suffix) ?? p.suffix, L = (y == null ? void 0 : y.showValues) ?? p.showValues, A = a.db.getGraph(), N = se[d], C = 10; + Gt().nodeId((g) => g.id).nodeWidth(C).nodePadding(10 + (L ? 15 : 0)).nodeAlign(N).extent([ + [0, 0], + [c, k] + ])(A); + const S = At(Tt); + o.append("g").attr("class", "nodes").selectAll(".node").data(A.nodes).join("g").attr("class", "node").attr("id", (g) => (g.uid = ft.next("node-")).id).attr("transform", function(g) { + return "translate(" + g.x0 + "," + g.y0 + ")"; + }).attr("x", (g) => g.x0).attr("y", (g) => g.y0).append("rect").attr("height", (g) => g.y1 - g.y0).attr("width", (g) => g.x1 - g.x0).attr("fill", (g) => S(g.id)); + const M = ({ id: g, value: w }) => L ? `${g} +${x}${Math.round(w * 100) / 100}${E}` : g; + o.append("g").attr("class", "node-labels").attr("font-family", "sans-serif").attr("font-size", 14).selectAll("text").data(A.nodes).join("text").attr("x", (g) => g.x0 < c / 2 ? g.x1 + 6 : g.x0 - 6).attr("y", (g) => (g.y1 + g.y0) / 2).attr("dy", `${L ? "0" : "0.35"}em`).attr("text-anchor", (g) => g.x0 < c / 2 ? "start" : "end").text(M); + const $ = o.append("g").attr("class", "links").attr("fill", "none").attr("stroke-opacity", 0.5).selectAll(".link").data(A.links).join("g").attr("class", "link").style("mix-blend-mode", "multiply"), P = (y == null ? void 0 : y.linkColor) || "gradient"; + if (P === "gradient") { + const g = $.append("linearGradient").attr("id", (w) => (w.uid = ft.next("linearGradient-")).id).attr("gradientUnits", "userSpaceOnUse").attr("x1", (w) => w.source.x1).attr("x2", (w) => w.target.x0); + g.append("stop").attr("offset", "0%").attr("stop-color", (w) => S(w.source.id)), g.append("stop").attr("offset", "100%").attr("stop-color", (w) => S(w.target.id)); + } + let I; + switch (P) { + case "gradient": + I = (g) => g.uid; + break; + case "source": + I = (g) => S(g.source.id); + break; + case "target": + I = (g) => S(g.target.id); + break; + default: + I = P; + } + $.append("path").attr("d", ie()).attr("stroke", I).attr("stroke-width", (g) => Math.max(1, g.width)), Et(void 0, o, 0, b); +}, oe = { + draw: re +}, le = (t) => t.replaceAll(/^[^\S\n\r]+|[^\S\n\r]+$/g, "").replaceAll(/([\n\r])+/g, ` +`).trim(), ae = H.parse.bind(H); +H.parse = (t) => ae(le(t)); +const ye = { + parser: H, + db: zt, + renderer: oe +}; +export { + ye as diagram +}; diff --git a/0.6.0/js/mermaid/sankeyDiagram-707fac0f.js b/0.6.0/js/mermaid/sankeyDiagram-707fac0f.js new file mode 100644 index 0000000..c31d3fb --- /dev/null +++ b/0.6.0/js/mermaid/sankeyDiagram-707fac0f.js @@ -0,0 +1,660 @@ +import { c as getConfig, g as getAccTitle, s as setAccTitle, a as getAccDescription, b as setAccDescription, t as getDiagramTitle, q as setDiagramTitle, v as clear$1, e as common, K as defaultConfig, o as setupGraphViewbox } from "./mermaid-6dc72991.js"; +import { select, scaleOrdinal, schemeTableau10 } from "d3"; +import { sankey, sankeyLinkHorizontal, sankeyLeft, sankeyRight, sankeyCenter, sankeyJustify } from "d3-sankey"; +import "ts-dedent"; +import "dayjs"; +import "@braintree/sanitize-url"; +import "dompurify"; +import "khroma"; +import "lodash-es/memoize.js"; +import "lodash-es/merge.js"; +import "stylis"; +import "lodash-es/isEmpty.js"; +var parser = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 9], $V1 = [1, 10], $V2 = [1, 5, 10, 12]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "SANKEY": 4, "NEWLINE": 5, "csv": 6, "opt_eof": 7, "record": 8, "csv_tail": 9, "EOF": 10, "field[source]": 11, "COMMA": 12, "field[target]": 13, "field[value]": 14, "field": 15, "escaped": 16, "non_escaped": 17, "DQUOTE": 18, "ESCAPED_TEXT": 19, "NON_ESCAPED_TEXT": 20, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 4: "SANKEY", 5: "NEWLINE", 10: "EOF", 11: "field[source]", 12: "COMMA", 13: "field[target]", 14: "field[value]", 18: "DQUOTE", 19: "ESCAPED_TEXT", 20: "NON_ESCAPED_TEXT" }, + productions_: [0, [3, 4], [6, 2], [9, 2], [9, 0], [7, 1], [7, 0], [8, 5], [15, 1], [15, 1], [16, 3], [17, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 7: + const source = yy.findOrCreateNode($$[$0 - 4].trim().replaceAll('""', '"')); + const target = yy.findOrCreateNode($$[$0 - 2].trim().replaceAll('""', '"')); + const value = parseFloat($$[$0].trim()); + yy.addLink(source, target, value); + break; + case 8: + case 9: + case 11: + this.$ = $$[$0]; + break; + case 10: + this.$ = $$[$0 - 1]; + break; + } + }, + table: [{ 3: 1, 4: [1, 2] }, { 1: [3] }, { 5: [1, 3] }, { 6: 4, 8: 5, 15: 6, 16: 7, 17: 8, 18: $V0, 20: $V1 }, { 1: [2, 6], 7: 11, 10: [1, 12] }, o($V1, [2, 4], { 9: 13, 5: [1, 14] }), { 12: [1, 15] }, o($V2, [2, 8]), o($V2, [2, 9]), { 19: [1, 16] }, o($V2, [2, 11]), { 1: [2, 1] }, { 1: [2, 5] }, o($V1, [2, 2]), { 6: 17, 8: 5, 15: 6, 16: 7, 17: 8, 18: $V0, 20: $V1 }, { 15: 18, 16: 7, 17: 8, 18: $V0, 20: $V1 }, { 18: [1, 19] }, o($V1, [2, 3]), { 12: [1, 20] }, o($V2, [2, 10]), { 15: 21, 16: 7, 17: 8, 18: $V0, 20: $V1 }, o([1, 5, 10], [2, 7])], + defaultActions: { 11: [2, 1], 12: [2, 5] }, + parseError: function parseError(str, hash) { + if (hash.recoverable) { + this.trace(str); + } else { + var error = new Error(str); + error.hash = hash; + throw error; + } + }, + parse: function parse(input) { + var self = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex() { + var token; + token = tstack.pop() || lexer2.lex() || EOF; + if (typeof token !== "number") { + if (token instanceof Array) { + tstack = token; + token = tstack.pop(); + } + token = self.symbols_[token] || token; + } + return token; + } + var symbol, state, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state = stack[stack.length - 1]; + if (this.defaultActions[state]) { + action = this.defaultActions[state]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex(); + } + action = table[state] && table[state][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str, hash); + } else { + throw new Error(str); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch = this._input[0]; + this.yytext += ch; + this.yyleng++; + this.offset++; + this.match += ch; + this.matched += ch; + var lines = ch.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch; + }, + // unshifts one char (or a string) into the input + unput: function(ch) { + var len = ch.length; + var lines = ch.split(/(?:\r\n?|\n)/g); + this._input = ch + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next = this.match; + if (next.length < 20) { + next += this._input.substr(0, 20 - next.length); + } + return (next.substr(0, 20) + (next.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token) { + return token; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token, match, tempMatch, index; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i = 0; i < rules.length; i++) { + tempMatch = this._input.match(this.rules[rules[i]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index = i; + if (this.options.backtrack_lexer) { + token = this.test_match(tempMatch, rules[i]); + if (token !== false) { + return token; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token = this.test_match(match, rules[index]); + if (token !== false) { + return token; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + this.pushState("csv"); + return 4; + case 1: + return 10; + case 2: + return 5; + case 3: + return 12; + case 4: + this.pushState("escaped_text"); + return 18; + case 5: + return 20; + case 6: + this.popState("escaped_text"); + return 18; + case 7: + return 19; + } + }, + rules: [/^(?:sankey-beta\b)/i, /^(?:$)/i, /^(?:((\u000D\u000A)|(\u000A)))/i, /^(?:(\u002C))/i, /^(?:(\u0022))/i, /^(?:([\u0020-\u0021\u0023-\u002B\u002D-\u007E])*)/i, /^(?:(\u0022)(?!(\u0022)))/i, /^(?:(([\u0020-\u0021\u0023-\u002B\u002D-\u007E])|(\u002C)|(\u000D)|(\u000A)|(\u0022)(\u0022))*)/i], + conditions: { "csv": { "rules": [1, 2, 3, 4, 5, 6, 7], "inclusive": false }, "escaped_text": { "rules": [6, 7], "inclusive": false }, "INITIAL": { "rules": [0, 1, 2, 3, 4, 5, 6, 7], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser() { + this.yy = {}; + } + Parser.prototype = parser2; + parser2.Parser = Parser; + return new Parser(); +}(); +parser.parser = parser; +const parser$1 = parser; +let links = []; +let nodes = []; +let nodesMap = {}; +const clear = () => { + links = []; + nodes = []; + nodesMap = {}; + clear$1(); +}; +class SankeyLink { + constructor(source, target, value = 0) { + this.source = source; + this.target = target; + this.value = value; + } +} +const addLink = (source, target, value) => { + links.push(new SankeyLink(source, target, value)); +}; +class SankeyNode { + constructor(ID) { + this.ID = ID; + } +} +const findOrCreateNode = (ID) => { + ID = common.sanitizeText(ID, getConfig()); + if (!nodesMap[ID]) { + nodesMap[ID] = new SankeyNode(ID); + nodes.push(nodesMap[ID]); + } + return nodesMap[ID]; +}; +const getNodes = () => nodes; +const getLinks = () => links; +const getGraph = () => ({ + nodes: nodes.map((node) => ({ id: node.ID })), + links: links.map((link) => ({ + source: link.source.ID, + target: link.target.ID, + value: link.value + })) +}); +const db = { + nodesMap, + getConfig: () => getConfig().sankey, + getNodes, + getLinks, + getGraph, + addLink, + findOrCreateNode, + getAccTitle, + setAccTitle, + getAccDescription, + setAccDescription, + getDiagramTitle, + setDiagramTitle, + clear +}; +const _Uid = class _Uid2 { + static next(name) { + return new _Uid2(name + ++_Uid2.count); + } + constructor(id) { + this.id = id; + this.href = `#${id}`; + } + toString() { + return "url(" + this.href + ")"; + } +}; +_Uid.count = 0; +let Uid = _Uid; +const alignmentsMap = { + left: sankeyLeft, + right: sankeyRight, + center: sankeyCenter, + justify: sankeyJustify +}; +const draw = function(text, id, _version, diagObj) { + const { securityLevel, sankey: conf } = getConfig(); + const defaultSankeyConfig = defaultConfig.sankey; + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = select("#i" + id); + } + const root = securityLevel === "sandbox" ? select(sandboxElement.nodes()[0].contentDocument.body) : select("body"); + const svg = securityLevel === "sandbox" ? root.select(`[id="${id}"]`) : select(`[id="${id}"]`); + const width = (conf == null ? void 0 : conf.width) ?? defaultSankeyConfig.width; + const height = (conf == null ? void 0 : conf.height) ?? defaultSankeyConfig.width; + const useMaxWidth = (conf == null ? void 0 : conf.useMaxWidth) ?? defaultSankeyConfig.useMaxWidth; + const nodeAlignment = (conf == null ? void 0 : conf.nodeAlignment) ?? defaultSankeyConfig.nodeAlignment; + const prefix = (conf == null ? void 0 : conf.prefix) ?? defaultSankeyConfig.prefix; + const suffix = (conf == null ? void 0 : conf.suffix) ?? defaultSankeyConfig.suffix; + const showValues = (conf == null ? void 0 : conf.showValues) ?? defaultSankeyConfig.showValues; + const graph = diagObj.db.getGraph(); + const nodeAlign = alignmentsMap[nodeAlignment]; + const nodeWidth = 10; + const sankey$1 = sankey().nodeId((d) => d.id).nodeWidth(nodeWidth).nodePadding(10 + (showValues ? 15 : 0)).nodeAlign(nodeAlign).extent([ + [0, 0], + [width, height] + ]); + sankey$1(graph); + const colorScheme = scaleOrdinal(schemeTableau10); + svg.append("g").attr("class", "nodes").selectAll(".node").data(graph.nodes).join("g").attr("class", "node").attr("id", (d) => (d.uid = Uid.next("node-")).id).attr("transform", function(d) { + return "translate(" + d.x0 + "," + d.y0 + ")"; + }).attr("x", (d) => d.x0).attr("y", (d) => d.y0).append("rect").attr("height", (d) => { + return d.y1 - d.y0; + }).attr("width", (d) => d.x1 - d.x0).attr("fill", (d) => colorScheme(d.id)); + const getText = ({ id: id2, value }) => { + if (!showValues) { + return id2; + } + return `${id2} +${prefix}${Math.round(value * 100) / 100}${suffix}`; + }; + svg.append("g").attr("class", "node-labels").attr("font-family", "sans-serif").attr("font-size", 14).selectAll("text").data(graph.nodes).join("text").attr("x", (d) => d.x0 < width / 2 ? d.x1 + 6 : d.x0 - 6).attr("y", (d) => (d.y1 + d.y0) / 2).attr("dy", `${showValues ? "0" : "0.35"}em`).attr("text-anchor", (d) => d.x0 < width / 2 ? "start" : "end").text(getText); + const link = svg.append("g").attr("class", "links").attr("fill", "none").attr("stroke-opacity", 0.5).selectAll(".link").data(graph.links).join("g").attr("class", "link").style("mix-blend-mode", "multiply"); + const linkColor = (conf == null ? void 0 : conf.linkColor) || "gradient"; + if (linkColor === "gradient") { + const gradient = link.append("linearGradient").attr("id", (d) => (d.uid = Uid.next("linearGradient-")).id).attr("gradientUnits", "userSpaceOnUse").attr("x1", (d) => d.source.x1).attr("x2", (d) => d.target.x0); + gradient.append("stop").attr("offset", "0%").attr("stop-color", (d) => colorScheme(d.source.id)); + gradient.append("stop").attr("offset", "100%").attr("stop-color", (d) => colorScheme(d.target.id)); + } + let coloring; + switch (linkColor) { + case "gradient": + coloring = (d) => d.uid; + break; + case "source": + coloring = (d) => colorScheme(d.source.id); + break; + case "target": + coloring = (d) => colorScheme(d.target.id); + break; + default: + coloring = linkColor; + } + link.append("path").attr("d", sankeyLinkHorizontal()).attr("stroke", coloring).attr("stroke-width", (d) => Math.max(1, d.width)); + setupGraphViewbox(void 0, svg, 0, useMaxWidth); +}; +const renderer = { + draw +}; +const prepareTextForParsing = (text) => { + const textToParse = text.replaceAll(/^[^\S\n\r]+|[^\S\n\r]+$/g, "").replaceAll(/([\n\r])+/g, "\n").trim(); + return textToParse; +}; +const originalParse = parser$1.parse.bind(parser$1); +parser$1.parse = (text) => originalParse(prepareTextForParsing(text)); +const diagram = { + parser: parser$1, + db, + renderer +}; +export { + diagram +}; diff --git a/0.6.0/js/mermaid/sequenceDiagram-6894f283.js b/0.6.0/js/mermaid/sequenceDiagram-6894f283.js new file mode 100644 index 0000000..7d0c52a --- /dev/null +++ b/0.6.0/js/mermaid/sequenceDiagram-6894f283.js @@ -0,0 +1,3346 @@ +import { g as getAccTitle, t as getDiagramTitle, q as setDiagramTitle, c as getConfig, s as setAccTitle, b as setAccDescription, a as getAccDescription, v as clear$1, l as log, d as sanitizeText, e as common, D as parseFontSize, G as hasKatex, r as renderKatex, F as getConfig$1, Z as ZERO_WIDTH_SPACE, H as calculateMathMLDimensions, f as assignWithDepth, i as configureSvgSize, u as utils } from "./mermaid-6dc72991.js"; +import { select } from "d3"; +import { d as drawRect$1, a as drawBackgroundRect$1, b as drawEmbeddedImage, c as drawImage, e as getTextObj$1, g as getNoteRect$1 } from "./svgDrawCommon-5e1cfd1d.js"; +import { sanitizeUrl } from "@braintree/sanitize-url"; +import "ts-dedent"; +import "dayjs"; +import "dompurify"; +import "khroma"; +import "lodash-es/memoize.js"; +import "lodash-es/merge.js"; +import "stylis"; +import "lodash-es/isEmpty.js"; +var parser = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 2], $V1 = [1, 3], $V2 = [1, 4], $V3 = [2, 4], $V4 = [1, 9], $V5 = [1, 11], $V6 = [1, 13], $V7 = [1, 14], $V8 = [1, 16], $V9 = [1, 17], $Va = [1, 18], $Vb = [1, 24], $Vc = [1, 25], $Vd = [1, 26], $Ve = [1, 27], $Vf = [1, 28], $Vg = [1, 29], $Vh = [1, 30], $Vi = [1, 31], $Vj = [1, 32], $Vk = [1, 33], $Vl = [1, 34], $Vm = [1, 35], $Vn = [1, 36], $Vo = [1, 37], $Vp = [1, 38], $Vq = [1, 39], $Vr = [1, 41], $Vs = [1, 42], $Vt = [1, 43], $Vu = [1, 44], $Vv = [1, 45], $Vw = [1, 46], $Vx = [1, 4, 5, 13, 14, 16, 18, 21, 23, 29, 30, 31, 33, 35, 36, 37, 38, 39, 41, 43, 44, 46, 47, 48, 49, 50, 52, 53, 54, 59, 60, 61, 62, 70], $Vy = [4, 5, 16, 50, 52, 53], $Vz = [4, 5, 13, 14, 16, 18, 21, 23, 29, 30, 31, 33, 35, 36, 37, 38, 39, 41, 43, 44, 46, 50, 52, 53, 54, 59, 60, 61, 62, 70], $VA = [4, 5, 13, 14, 16, 18, 21, 23, 29, 30, 31, 33, 35, 36, 37, 38, 39, 41, 43, 44, 46, 49, 50, 52, 53, 54, 59, 60, 61, 62, 70], $VB = [4, 5, 13, 14, 16, 18, 21, 23, 29, 30, 31, 33, 35, 36, 37, 38, 39, 41, 43, 44, 46, 48, 50, 52, 53, 54, 59, 60, 61, 62, 70], $VC = [4, 5, 13, 14, 16, 18, 21, 23, 29, 30, 31, 33, 35, 36, 37, 38, 39, 41, 43, 44, 46, 47, 50, 52, 53, 54, 59, 60, 61, 62, 70], $VD = [68, 69, 70], $VE = [1, 120]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "SPACE": 4, "NEWLINE": 5, "SD": 6, "document": 7, "line": 8, "statement": 9, "box_section": 10, "box_line": 11, "participant_statement": 12, "create": 13, "box": 14, "restOfLine": 15, "end": 16, "signal": 17, "autonumber": 18, "NUM": 19, "off": 20, "activate": 21, "actor": 22, "deactivate": 23, "note_statement": 24, "links_statement": 25, "link_statement": 26, "properties_statement": 27, "details_statement": 28, "title": 29, "legacy_title": 30, "acc_title": 31, "acc_title_value": 32, "acc_descr": 33, "acc_descr_value": 34, "acc_descr_multiline_value": 35, "loop": 36, "rect": 37, "opt": 38, "alt": 39, "else_sections": 40, "par": 41, "par_sections": 42, "par_over": 43, "critical": 44, "option_sections": 45, "break": 46, "option": 47, "and": 48, "else": 49, "participant": 50, "AS": 51, "participant_actor": 52, "destroy": 53, "note": 54, "placement": 55, "text2": 56, "over": 57, "actor_pair": 58, "links": 59, "link": 60, "properties": 61, "details": 62, "spaceList": 63, ",": 64, "left_of": 65, "right_of": 66, "signaltype": 67, "+": 68, "-": 69, "ACTOR": 70, "SOLID_OPEN_ARROW": 71, "DOTTED_OPEN_ARROW": 72, "SOLID_ARROW": 73, "DOTTED_ARROW": 74, "SOLID_CROSS": 75, "DOTTED_CROSS": 76, "SOLID_POINT": 77, "DOTTED_POINT": 78, "TXT": 79, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 4: "SPACE", 5: "NEWLINE", 6: "SD", 13: "create", 14: "box", 15: "restOfLine", 16: "end", 18: "autonumber", 19: "NUM", 20: "off", 21: "activate", 23: "deactivate", 29: "title", 30: "legacy_title", 31: "acc_title", 32: "acc_title_value", 33: "acc_descr", 34: "acc_descr_value", 35: "acc_descr_multiline_value", 36: "loop", 37: "rect", 38: "opt", 39: "alt", 41: "par", 43: "par_over", 44: "critical", 46: "break", 47: "option", 48: "and", 49: "else", 50: "participant", 51: "AS", 52: "participant_actor", 53: "destroy", 54: "note", 57: "over", 59: "links", 60: "link", 61: "properties", 62: "details", 64: ",", 65: "left_of", 66: "right_of", 68: "+", 69: "-", 70: "ACTOR", 71: "SOLID_OPEN_ARROW", 72: "DOTTED_OPEN_ARROW", 73: "SOLID_ARROW", 74: "DOTTED_ARROW", 75: "SOLID_CROSS", 76: "DOTTED_CROSS", 77: "SOLID_POINT", 78: "DOTTED_POINT", 79: "TXT" }, + productions_: [0, [3, 2], [3, 2], [3, 2], [7, 0], [7, 2], [8, 2], [8, 1], [8, 1], [10, 0], [10, 2], [11, 2], [11, 1], [11, 1], [9, 1], [9, 2], [9, 4], [9, 2], [9, 4], [9, 3], [9, 3], [9, 2], [9, 3], [9, 3], [9, 2], [9, 2], [9, 2], [9, 2], [9, 2], [9, 1], [9, 1], [9, 2], [9, 2], [9, 1], [9, 4], [9, 4], [9, 4], [9, 4], [9, 4], [9, 4], [9, 4], [9, 4], [45, 1], [45, 4], [42, 1], [42, 4], [40, 1], [40, 4], [12, 5], [12, 3], [12, 5], [12, 3], [12, 3], [24, 4], [24, 4], [25, 3], [26, 3], [27, 3], [28, 3], [63, 2], [63, 1], [58, 3], [58, 1], [55, 1], [55, 1], [17, 5], [17, 5], [17, 4], [22, 1], [67, 1], [67, 1], [67, 1], [67, 1], [67, 1], [67, 1], [67, 1], [67, 1], [56, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 3: + yy.apply($$[$0]); + return $$[$0]; + case 4: + case 9: + this.$ = []; + break; + case 5: + case 10: + $$[$0 - 1].push($$[$0]); + this.$ = $$[$0 - 1]; + break; + case 6: + case 7: + case 11: + case 12: + this.$ = $$[$0]; + break; + case 8: + case 13: + this.$ = []; + break; + case 15: + $$[$0].type = "createParticipant"; + this.$ = $$[$0]; + break; + case 16: + $$[$0 - 1].unshift({ type: "boxStart", boxData: yy.parseBoxData($$[$0 - 2]) }); + $$[$0 - 1].push({ type: "boxEnd", boxText: $$[$0 - 2] }); + this.$ = $$[$0 - 1]; + break; + case 18: + this.$ = { type: "sequenceIndex", sequenceIndex: Number($$[$0 - 2]), sequenceIndexStep: Number($$[$0 - 1]), sequenceVisible: true, signalType: yy.LINETYPE.AUTONUMBER }; + break; + case 19: + this.$ = { type: "sequenceIndex", sequenceIndex: Number($$[$0 - 1]), sequenceIndexStep: 1, sequenceVisible: true, signalType: yy.LINETYPE.AUTONUMBER }; + break; + case 20: + this.$ = { type: "sequenceIndex", sequenceVisible: false, signalType: yy.LINETYPE.AUTONUMBER }; + break; + case 21: + this.$ = { type: "sequenceIndex", sequenceVisible: true, signalType: yy.LINETYPE.AUTONUMBER }; + break; + case 22: + this.$ = { type: "activeStart", signalType: yy.LINETYPE.ACTIVE_START, actor: $$[$0 - 1] }; + break; + case 23: + this.$ = { type: "activeEnd", signalType: yy.LINETYPE.ACTIVE_END, actor: $$[$0 - 1] }; + break; + case 29: + yy.setDiagramTitle($$[$0].substring(6)); + this.$ = $$[$0].substring(6); + break; + case 30: + yy.setDiagramTitle($$[$0].substring(7)); + this.$ = $$[$0].substring(7); + break; + case 31: + this.$ = $$[$0].trim(); + yy.setAccTitle(this.$); + break; + case 32: + case 33: + this.$ = $$[$0].trim(); + yy.setAccDescription(this.$); + break; + case 34: + $$[$0 - 1].unshift({ type: "loopStart", loopText: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.LOOP_START }); + $$[$0 - 1].push({ type: "loopEnd", loopText: $$[$0 - 2], signalType: yy.LINETYPE.LOOP_END }); + this.$ = $$[$0 - 1]; + break; + case 35: + $$[$0 - 1].unshift({ type: "rectStart", color: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.RECT_START }); + $$[$0 - 1].push({ type: "rectEnd", color: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.RECT_END }); + this.$ = $$[$0 - 1]; + break; + case 36: + $$[$0 - 1].unshift({ type: "optStart", optText: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.OPT_START }); + $$[$0 - 1].push({ type: "optEnd", optText: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.OPT_END }); + this.$ = $$[$0 - 1]; + break; + case 37: + $$[$0 - 1].unshift({ type: "altStart", altText: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.ALT_START }); + $$[$0 - 1].push({ type: "altEnd", signalType: yy.LINETYPE.ALT_END }); + this.$ = $$[$0 - 1]; + break; + case 38: + $$[$0 - 1].unshift({ type: "parStart", parText: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.PAR_START }); + $$[$0 - 1].push({ type: "parEnd", signalType: yy.LINETYPE.PAR_END }); + this.$ = $$[$0 - 1]; + break; + case 39: + $$[$0 - 1].unshift({ type: "parStart", parText: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.PAR_OVER_START }); + $$[$0 - 1].push({ type: "parEnd", signalType: yy.LINETYPE.PAR_END }); + this.$ = $$[$0 - 1]; + break; + case 40: + $$[$0 - 1].unshift({ type: "criticalStart", criticalText: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.CRITICAL_START }); + $$[$0 - 1].push({ type: "criticalEnd", signalType: yy.LINETYPE.CRITICAL_END }); + this.$ = $$[$0 - 1]; + break; + case 41: + $$[$0 - 1].unshift({ type: "breakStart", breakText: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.BREAK_START }); + $$[$0 - 1].push({ type: "breakEnd", optText: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.BREAK_END }); + this.$ = $$[$0 - 1]; + break; + case 43: + this.$ = $$[$0 - 3].concat([{ type: "option", optionText: yy.parseMessage($$[$0 - 1]), signalType: yy.LINETYPE.CRITICAL_OPTION }, $$[$0]]); + break; + case 45: + this.$ = $$[$0 - 3].concat([{ type: "and", parText: yy.parseMessage($$[$0 - 1]), signalType: yy.LINETYPE.PAR_AND }, $$[$0]]); + break; + case 47: + this.$ = $$[$0 - 3].concat([{ type: "else", altText: yy.parseMessage($$[$0 - 1]), signalType: yy.LINETYPE.ALT_ELSE }, $$[$0]]); + break; + case 48: + $$[$0 - 3].draw = "participant"; + $$[$0 - 3].type = "addParticipant"; + $$[$0 - 3].description = yy.parseMessage($$[$0 - 1]); + this.$ = $$[$0 - 3]; + break; + case 49: + $$[$0 - 1].draw = "participant"; + $$[$0 - 1].type = "addParticipant"; + this.$ = $$[$0 - 1]; + break; + case 50: + $$[$0 - 3].draw = "actor"; + $$[$0 - 3].type = "addParticipant"; + $$[$0 - 3].description = yy.parseMessage($$[$0 - 1]); + this.$ = $$[$0 - 3]; + break; + case 51: + $$[$0 - 1].draw = "actor"; + $$[$0 - 1].type = "addParticipant"; + this.$ = $$[$0 - 1]; + break; + case 52: + $$[$0 - 1].type = "destroyParticipant"; + this.$ = $$[$0 - 1]; + break; + case 53: + this.$ = [$$[$0 - 1], { type: "addNote", placement: $$[$0 - 2], actor: $$[$0 - 1].actor, text: $$[$0] }]; + break; + case 54: + $$[$0 - 2] = [].concat($$[$0 - 1], $$[$0 - 1]).slice(0, 2); + $$[$0 - 2][0] = $$[$0 - 2][0].actor; + $$[$0 - 2][1] = $$[$0 - 2][1].actor; + this.$ = [$$[$0 - 1], { type: "addNote", placement: yy.PLACEMENT.OVER, actor: $$[$0 - 2].slice(0, 2), text: $$[$0] }]; + break; + case 55: + this.$ = [$$[$0 - 1], { type: "addLinks", actor: $$[$0 - 1].actor, text: $$[$0] }]; + break; + case 56: + this.$ = [$$[$0 - 1], { type: "addALink", actor: $$[$0 - 1].actor, text: $$[$0] }]; + break; + case 57: + this.$ = [$$[$0 - 1], { type: "addProperties", actor: $$[$0 - 1].actor, text: $$[$0] }]; + break; + case 58: + this.$ = [$$[$0 - 1], { type: "addDetails", actor: $$[$0 - 1].actor, text: $$[$0] }]; + break; + case 61: + this.$ = [$$[$0 - 2], $$[$0]]; + break; + case 62: + this.$ = $$[$0]; + break; + case 63: + this.$ = yy.PLACEMENT.LEFTOF; + break; + case 64: + this.$ = yy.PLACEMENT.RIGHTOF; + break; + case 65: + this.$ = [ + $$[$0 - 4], + $$[$0 - 1], + { type: "addMessage", from: $$[$0 - 4].actor, to: $$[$0 - 1].actor, signalType: $$[$0 - 3], msg: $$[$0], activate: true }, + { type: "activeStart", signalType: yy.LINETYPE.ACTIVE_START, actor: $$[$0 - 1] } + ]; + break; + case 66: + this.$ = [ + $$[$0 - 4], + $$[$0 - 1], + { type: "addMessage", from: $$[$0 - 4].actor, to: $$[$0 - 1].actor, signalType: $$[$0 - 3], msg: $$[$0] }, + { type: "activeEnd", signalType: yy.LINETYPE.ACTIVE_END, actor: $$[$0 - 4] } + ]; + break; + case 67: + this.$ = [$$[$0 - 3], $$[$0 - 1], { type: "addMessage", from: $$[$0 - 3].actor, to: $$[$0 - 1].actor, signalType: $$[$0 - 2], msg: $$[$0] }]; + break; + case 68: + this.$ = { type: "addParticipant", actor: $$[$0] }; + break; + case 69: + this.$ = yy.LINETYPE.SOLID_OPEN; + break; + case 70: + this.$ = yy.LINETYPE.DOTTED_OPEN; + break; + case 71: + this.$ = yy.LINETYPE.SOLID; + break; + case 72: + this.$ = yy.LINETYPE.DOTTED; + break; + case 73: + this.$ = yy.LINETYPE.SOLID_CROSS; + break; + case 74: + this.$ = yy.LINETYPE.DOTTED_CROSS; + break; + case 75: + this.$ = yy.LINETYPE.SOLID_POINT; + break; + case 76: + this.$ = yy.LINETYPE.DOTTED_POINT; + break; + case 77: + this.$ = yy.parseMessage($$[$0].trim().substring(1)); + break; + } + }, + table: [{ 3: 1, 4: $V0, 5: $V1, 6: $V2 }, { 1: [3] }, { 3: 5, 4: $V0, 5: $V1, 6: $V2 }, { 3: 6, 4: $V0, 5: $V1, 6: $V2 }, o([1, 4, 5, 13, 14, 18, 21, 23, 29, 30, 31, 33, 35, 36, 37, 38, 39, 41, 43, 44, 46, 50, 52, 53, 54, 59, 60, 61, 62, 70], $V3, { 7: 7 }), { 1: [2, 1] }, { 1: [2, 2] }, { 1: [2, 3], 4: $V4, 5: $V5, 8: 8, 9: 10, 12: 12, 13: $V6, 14: $V7, 17: 15, 18: $V8, 21: $V9, 22: 40, 23: $Va, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: $Vb, 30: $Vc, 31: $Vd, 33: $Ve, 35: $Vf, 36: $Vg, 37: $Vh, 38: $Vi, 39: $Vj, 41: $Vk, 43: $Vl, 44: $Vm, 46: $Vn, 50: $Vo, 52: $Vp, 53: $Vq, 54: $Vr, 59: $Vs, 60: $Vt, 61: $Vu, 62: $Vv, 70: $Vw }, o($Vx, [2, 5]), { 9: 47, 12: 12, 13: $V6, 14: $V7, 17: 15, 18: $V8, 21: $V9, 22: 40, 23: $Va, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: $Vb, 30: $Vc, 31: $Vd, 33: $Ve, 35: $Vf, 36: $Vg, 37: $Vh, 38: $Vi, 39: $Vj, 41: $Vk, 43: $Vl, 44: $Vm, 46: $Vn, 50: $Vo, 52: $Vp, 53: $Vq, 54: $Vr, 59: $Vs, 60: $Vt, 61: $Vu, 62: $Vv, 70: $Vw }, o($Vx, [2, 7]), o($Vx, [2, 8]), o($Vx, [2, 14]), { 12: 48, 50: $Vo, 52: $Vp, 53: $Vq }, { 15: [1, 49] }, { 5: [1, 50] }, { 5: [1, 53], 19: [1, 51], 20: [1, 52] }, { 22: 54, 70: $Vw }, { 22: 55, 70: $Vw }, { 5: [1, 56] }, { 5: [1, 57] }, { 5: [1, 58] }, { 5: [1, 59] }, { 5: [1, 60] }, o($Vx, [2, 29]), o($Vx, [2, 30]), { 32: [1, 61] }, { 34: [1, 62] }, o($Vx, [2, 33]), { 15: [1, 63] }, { 15: [1, 64] }, { 15: [1, 65] }, { 15: [1, 66] }, { 15: [1, 67] }, { 15: [1, 68] }, { 15: [1, 69] }, { 15: [1, 70] }, { 22: 71, 70: $Vw }, { 22: 72, 70: $Vw }, { 22: 73, 70: $Vw }, { 67: 74, 71: [1, 75], 72: [1, 76], 73: [1, 77], 74: [1, 78], 75: [1, 79], 76: [1, 80], 77: [1, 81], 78: [1, 82] }, { 55: 83, 57: [1, 84], 65: [1, 85], 66: [1, 86] }, { 22: 87, 70: $Vw }, { 22: 88, 70: $Vw }, { 22: 89, 70: $Vw }, { 22: 90, 70: $Vw }, o([5, 51, 64, 71, 72, 73, 74, 75, 76, 77, 78, 79], [2, 68]), o($Vx, [2, 6]), o($Vx, [2, 15]), o($Vy, [2, 9], { 10: 91 }), o($Vx, [2, 17]), { 5: [1, 93], 19: [1, 92] }, { 5: [1, 94] }, o($Vx, [2, 21]), { 5: [1, 95] }, { 5: [1, 96] }, o($Vx, [2, 24]), o($Vx, [2, 25]), o($Vx, [2, 26]), o($Vx, [2, 27]), o($Vx, [2, 28]), o($Vx, [2, 31]), o($Vx, [2, 32]), o($Vz, $V3, { 7: 97 }), o($Vz, $V3, { 7: 98 }), o($Vz, $V3, { 7: 99 }), o($VA, $V3, { 40: 100, 7: 101 }), o($VB, $V3, { 42: 102, 7: 103 }), o($VB, $V3, { 7: 103, 42: 104 }), o($VC, $V3, { 45: 105, 7: 106 }), o($Vz, $V3, { 7: 107 }), { 5: [1, 109], 51: [1, 108] }, { 5: [1, 111], 51: [1, 110] }, { 5: [1, 112] }, { 22: 115, 68: [1, 113], 69: [1, 114], 70: $Vw }, o($VD, [2, 69]), o($VD, [2, 70]), o($VD, [2, 71]), o($VD, [2, 72]), o($VD, [2, 73]), o($VD, [2, 74]), o($VD, [2, 75]), o($VD, [2, 76]), { 22: 116, 70: $Vw }, { 22: 118, 58: 117, 70: $Vw }, { 70: [2, 63] }, { 70: [2, 64] }, { 56: 119, 79: $VE }, { 56: 121, 79: $VE }, { 56: 122, 79: $VE }, { 56: 123, 79: $VE }, { 4: [1, 126], 5: [1, 128], 11: 125, 12: 127, 16: [1, 124], 50: $Vo, 52: $Vp, 53: $Vq }, { 5: [1, 129] }, o($Vx, [2, 19]), o($Vx, [2, 20]), o($Vx, [2, 22]), o($Vx, [2, 23]), { 4: $V4, 5: $V5, 8: 8, 9: 10, 12: 12, 13: $V6, 14: $V7, 16: [1, 130], 17: 15, 18: $V8, 21: $V9, 22: 40, 23: $Va, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: $Vb, 30: $Vc, 31: $Vd, 33: $Ve, 35: $Vf, 36: $Vg, 37: $Vh, 38: $Vi, 39: $Vj, 41: $Vk, 43: $Vl, 44: $Vm, 46: $Vn, 50: $Vo, 52: $Vp, 53: $Vq, 54: $Vr, 59: $Vs, 60: $Vt, 61: $Vu, 62: $Vv, 70: $Vw }, { 4: $V4, 5: $V5, 8: 8, 9: 10, 12: 12, 13: $V6, 14: $V7, 16: [1, 131], 17: 15, 18: $V8, 21: $V9, 22: 40, 23: $Va, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: $Vb, 30: $Vc, 31: $Vd, 33: $Ve, 35: $Vf, 36: $Vg, 37: $Vh, 38: $Vi, 39: $Vj, 41: $Vk, 43: $Vl, 44: $Vm, 46: $Vn, 50: $Vo, 52: $Vp, 53: $Vq, 54: $Vr, 59: $Vs, 60: $Vt, 61: $Vu, 62: $Vv, 70: $Vw }, { 4: $V4, 5: $V5, 8: 8, 9: 10, 12: 12, 13: $V6, 14: $V7, 16: [1, 132], 17: 15, 18: $V8, 21: $V9, 22: 40, 23: $Va, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: $Vb, 30: $Vc, 31: $Vd, 33: $Ve, 35: $Vf, 36: $Vg, 37: $Vh, 38: $Vi, 39: $Vj, 41: $Vk, 43: $Vl, 44: $Vm, 46: $Vn, 50: $Vo, 52: $Vp, 53: $Vq, 54: $Vr, 59: $Vs, 60: $Vt, 61: $Vu, 62: $Vv, 70: $Vw }, { 16: [1, 133] }, { 4: $V4, 5: $V5, 8: 8, 9: 10, 12: 12, 13: $V6, 14: $V7, 16: [2, 46], 17: 15, 18: $V8, 21: $V9, 22: 40, 23: $Va, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: $Vb, 30: $Vc, 31: $Vd, 33: $Ve, 35: $Vf, 36: $Vg, 37: $Vh, 38: $Vi, 39: $Vj, 41: $Vk, 43: $Vl, 44: $Vm, 46: $Vn, 49: [1, 134], 50: $Vo, 52: $Vp, 53: $Vq, 54: $Vr, 59: $Vs, 60: $Vt, 61: $Vu, 62: $Vv, 70: $Vw }, { 16: [1, 135] }, { 4: $V4, 5: $V5, 8: 8, 9: 10, 12: 12, 13: $V6, 14: $V7, 16: [2, 44], 17: 15, 18: $V8, 21: $V9, 22: 40, 23: $Va, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: $Vb, 30: $Vc, 31: $Vd, 33: $Ve, 35: $Vf, 36: $Vg, 37: $Vh, 38: $Vi, 39: $Vj, 41: $Vk, 43: $Vl, 44: $Vm, 46: $Vn, 48: [1, 136], 50: $Vo, 52: $Vp, 53: $Vq, 54: $Vr, 59: $Vs, 60: $Vt, 61: $Vu, 62: $Vv, 70: $Vw }, { 16: [1, 137] }, { 16: [1, 138] }, { 4: $V4, 5: $V5, 8: 8, 9: 10, 12: 12, 13: $V6, 14: $V7, 16: [2, 42], 17: 15, 18: $V8, 21: $V9, 22: 40, 23: $Va, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: $Vb, 30: $Vc, 31: $Vd, 33: $Ve, 35: $Vf, 36: $Vg, 37: $Vh, 38: $Vi, 39: $Vj, 41: $Vk, 43: $Vl, 44: $Vm, 46: $Vn, 47: [1, 139], 50: $Vo, 52: $Vp, 53: $Vq, 54: $Vr, 59: $Vs, 60: $Vt, 61: $Vu, 62: $Vv, 70: $Vw }, { 4: $V4, 5: $V5, 8: 8, 9: 10, 12: 12, 13: $V6, 14: $V7, 16: [1, 140], 17: 15, 18: $V8, 21: $V9, 22: 40, 23: $Va, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: $Vb, 30: $Vc, 31: $Vd, 33: $Ve, 35: $Vf, 36: $Vg, 37: $Vh, 38: $Vi, 39: $Vj, 41: $Vk, 43: $Vl, 44: $Vm, 46: $Vn, 50: $Vo, 52: $Vp, 53: $Vq, 54: $Vr, 59: $Vs, 60: $Vt, 61: $Vu, 62: $Vv, 70: $Vw }, { 15: [1, 141] }, o($Vx, [2, 49]), { 15: [1, 142] }, o($Vx, [2, 51]), o($Vx, [2, 52]), { 22: 143, 70: $Vw }, { 22: 144, 70: $Vw }, { 56: 145, 79: $VE }, { 56: 146, 79: $VE }, { 56: 147, 79: $VE }, { 64: [1, 148], 79: [2, 62] }, { 5: [2, 55] }, { 5: [2, 77] }, { 5: [2, 56] }, { 5: [2, 57] }, { 5: [2, 58] }, o($Vx, [2, 16]), o($Vy, [2, 10]), { 12: 149, 50: $Vo, 52: $Vp, 53: $Vq }, o($Vy, [2, 12]), o($Vy, [2, 13]), o($Vx, [2, 18]), o($Vx, [2, 34]), o($Vx, [2, 35]), o($Vx, [2, 36]), o($Vx, [2, 37]), { 15: [1, 150] }, o($Vx, [2, 38]), { 15: [1, 151] }, o($Vx, [2, 39]), o($Vx, [2, 40]), { 15: [1, 152] }, o($Vx, [2, 41]), { 5: [1, 153] }, { 5: [1, 154] }, { 56: 155, 79: $VE }, { 56: 156, 79: $VE }, { 5: [2, 67] }, { 5: [2, 53] }, { 5: [2, 54] }, { 22: 157, 70: $Vw }, o($Vy, [2, 11]), o($VA, $V3, { 7: 101, 40: 158 }), o($VB, $V3, { 7: 103, 42: 159 }), o($VC, $V3, { 7: 106, 45: 160 }), o($Vx, [2, 48]), o($Vx, [2, 50]), { 5: [2, 65] }, { 5: [2, 66] }, { 79: [2, 61] }, { 16: [2, 47] }, { 16: [2, 45] }, { 16: [2, 43] }], + defaultActions: { 5: [2, 1], 6: [2, 2], 85: [2, 63], 86: [2, 64], 119: [2, 55], 120: [2, 77], 121: [2, 56], 122: [2, 57], 123: [2, 58], 145: [2, 67], 146: [2, 53], 147: [2, 54], 155: [2, 65], 156: [2, 66], 157: [2, 61], 158: [2, 47], 159: [2, 45], 160: [2, 43] }, + parseError: function parseError(str, hash) { + if (hash.recoverable) { + this.trace(str); + } else { + var error = new Error(str); + error.hash = hash; + throw error; + } + }, + parse: function parse(input) { + var self = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex() { + var token; + token = tstack.pop() || lexer2.lex() || EOF; + if (typeof token !== "number") { + if (token instanceof Array) { + tstack = token; + token = tstack.pop(); + } + token = self.symbols_[token] || token; + } + return token; + } + var symbol, state2, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state2 = stack[stack.length - 1]; + if (this.defaultActions[state2]) { + action = this.defaultActions[state2]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex(); + } + action = table[state2] && table[state2][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state2]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state2 + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str, hash); + } else { + throw new Error(str); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch = this._input[0]; + this.yytext += ch; + this.yyleng++; + this.offset++; + this.match += ch; + this.matched += ch; + var lines = ch.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch; + }, + // unshifts one char (or a string) into the input + unput: function(ch) { + var len = ch.length; + var lines = ch.split(/(?:\r\n?|\n)/g); + this._input = ch + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next = this.match; + if (next.length < 20) { + next += this._input.substr(0, 20 - next.length); + } + return (next.substr(0, 20) + (next.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token) { + return token; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token, match, tempMatch, index; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i = 0; i < rules.length; i++) { + tempMatch = this._input.match(this.rules[rules[i]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index = i; + if (this.options.backtrack_lexer) { + token = this.test_match(tempMatch, rules[i]); + if (token !== false) { + return token; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token = this.test_match(match, rules[index]); + if (token !== false) { + return token; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + return 5; + case 1: + break; + case 2: + break; + case 3: + break; + case 4: + break; + case 5: + break; + case 6: + return 19; + case 7: + this.begin("LINE"); + return 14; + case 8: + this.begin("ID"); + return 50; + case 9: + this.begin("ID"); + return 52; + case 10: + return 13; + case 11: + this.begin("ID"); + return 53; + case 12: + yy_.yytext = yy_.yytext.trim(); + this.begin("ALIAS"); + return 70; + case 13: + this.popState(); + this.popState(); + this.begin("LINE"); + return 51; + case 14: + this.popState(); + this.popState(); + return 5; + case 15: + this.begin("LINE"); + return 36; + case 16: + this.begin("LINE"); + return 37; + case 17: + this.begin("LINE"); + return 38; + case 18: + this.begin("LINE"); + return 39; + case 19: + this.begin("LINE"); + return 49; + case 20: + this.begin("LINE"); + return 41; + case 21: + this.begin("LINE"); + return 43; + case 22: + this.begin("LINE"); + return 48; + case 23: + this.begin("LINE"); + return 44; + case 24: + this.begin("LINE"); + return 47; + case 25: + this.begin("LINE"); + return 46; + case 26: + this.popState(); + return 15; + case 27: + return 16; + case 28: + return 65; + case 29: + return 66; + case 30: + return 59; + case 31: + return 60; + case 32: + return 61; + case 33: + return 62; + case 34: + return 57; + case 35: + return 54; + case 36: + this.begin("ID"); + return 21; + case 37: + this.begin("ID"); + return 23; + case 38: + return 29; + case 39: + return 30; + case 40: + this.begin("acc_title"); + return 31; + case 41: + this.popState(); + return "acc_title_value"; + case 42: + this.begin("acc_descr"); + return 33; + case 43: + this.popState(); + return "acc_descr_value"; + case 44: + this.begin("acc_descr_multiline"); + break; + case 45: + this.popState(); + break; + case 46: + return "acc_descr_multiline_value"; + case 47: + return 6; + case 48: + return 18; + case 49: + return 20; + case 50: + return 64; + case 51: + return 5; + case 52: + yy_.yytext = yy_.yytext.trim(); + return 70; + case 53: + return 73; + case 54: + return 74; + case 55: + return 71; + case 56: + return 72; + case 57: + return 75; + case 58: + return 76; + case 59: + return 77; + case 60: + return 78; + case 61: + return 79; + case 62: + return 68; + case 63: + return 69; + case 64: + return 5; + case 65: + return "INVALID"; + } + }, + rules: [/^(?:[\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, /^(?:create\b)/i, /^(?:destroy\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, /^(?:par_over\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": [45, 46], "inclusive": false }, "acc_descr": { "rules": [43], "inclusive": false }, "acc_title": { "rules": [41], "inclusive": false }, "ID": { "rules": [2, 3, 12], "inclusive": false }, "ALIAS": { "rules": [2, 3, 13, 14], "inclusive": false }, "LINE": { "rules": [2, 3, 26], "inclusive": false }, "INITIAL": { "rules": [0, 1, 3, 4, 5, 6, 7, 8, 9, 10, 11, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 42, 44, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser() { + this.yy = {}; + } + Parser.prototype = parser2; + parser2.Parser = Parser; + return new Parser(); +}(); +parser.parser = parser; +const parser$1 = parser; +class ImperativeState { + /** + * @param init - Function that creates the default state. + */ + constructor(init) { + this.init = init; + this.records = this.init(); + } + reset() { + this.records = this.init(); + } +} +const state = new ImperativeState(() => ({ + prevActor: void 0, + actors: {}, + createdActors: {}, + destroyedActors: {}, + boxes: [], + messages: [], + notes: [], + sequenceNumbersEnabled: false, + wrapEnabled: void 0, + currentBox: void 0, + lastCreated: void 0, + lastDestroyed: void 0 +})); +const addBox = function(data) { + state.records.boxes.push({ + name: data.text, + wrap: data.wrap === void 0 && autoWrap() || !!data.wrap, + fill: data.color, + actorKeys: [] + }); + state.records.currentBox = state.records.boxes.slice(-1)[0]; +}; +const addActor = function(id, name, description, type) { + let assignedBox = state.records.currentBox; + const old = state.records.actors[id]; + if (old) { + if (state.records.currentBox && old.box && state.records.currentBox !== old.box) { + throw new Error( + "A same participant should only be defined in one Box: " + old.name + " can't be in '" + old.box.name + "' and in '" + state.records.currentBox.name + "' at the same time." + ); + } + assignedBox = old.box ? old.box : state.records.currentBox; + old.box = assignedBox; + if (old && name === old.name && description == null) { + return; + } + } + if (description == null || description.text == null) { + description = { text: name, wrap: null, type }; + } + if (type == null || description.text == null) { + description = { text: name, wrap: null, type }; + } + state.records.actors[id] = { + box: assignedBox, + name, + description: description.text, + wrap: description.wrap === void 0 && autoWrap() || !!description.wrap, + prevActor: state.records.prevActor, + links: {}, + properties: {}, + actorCnt: null, + rectData: null, + type: type || "participant" + }; + if (state.records.prevActor && state.records.actors[state.records.prevActor]) { + state.records.actors[state.records.prevActor].nextActor = id; + } + if (state.records.currentBox) { + state.records.currentBox.actorKeys.push(id); + } + state.records.prevActor = id; +}; +const activationCount = (part) => { + let i; + let count = 0; + for (i = 0; i < state.records.messages.length; i++) { + if (state.records.messages[i].type === LINETYPE.ACTIVE_START && state.records.messages[i].from.actor === part) { + count++; + } + if (state.records.messages[i].type === LINETYPE.ACTIVE_END && state.records.messages[i].from.actor === part) { + count--; + } + } + return count; +}; +const addMessage = function(idFrom, idTo, message, answer) { + state.records.messages.push({ + from: idFrom, + to: idTo, + message: message.text, + wrap: message.wrap === void 0 && autoWrap() || !!message.wrap, + answer + }); +}; +const addSignal = function(idFrom, idTo, message = { text: void 0, wrap: void 0 }, messageType, activate = false) { + if (messageType === LINETYPE.ACTIVE_END) { + const cnt = activationCount(idFrom.actor); + if (cnt < 1) { + let error = new Error("Trying to inactivate an inactive participant (" + idFrom.actor + ")"); + error.hash = { + text: "->>-", + token: "->>-", + line: "1", + loc: { first_line: 1, last_line: 1, first_column: 1, last_column: 1 }, + expected: ["'ACTIVE_PARTICIPANT'"] + }; + throw error; + } + } + state.records.messages.push({ + from: idFrom, + to: idTo, + message: message.text, + wrap: message.wrap === void 0 && autoWrap() || !!message.wrap, + type: messageType, + activate + }); + return true; +}; +const hasAtLeastOneBox = function() { + return state.records.boxes.length > 0; +}; +const hasAtLeastOneBoxWithTitle = function() { + return state.records.boxes.some((b) => b.name); +}; +const getMessages = function() { + return state.records.messages; +}; +const getBoxes = function() { + return state.records.boxes; +}; +const getActors = function() { + return state.records.actors; +}; +const getCreatedActors = function() { + return state.records.createdActors; +}; +const getDestroyedActors = function() { + return state.records.destroyedActors; +}; +const getActor = function(id) { + return state.records.actors[id]; +}; +const getActorKeys = function() { + return Object.keys(state.records.actors); +}; +const enableSequenceNumbers = function() { + state.records.sequenceNumbersEnabled = true; +}; +const disableSequenceNumbers = function() { + state.records.sequenceNumbersEnabled = false; +}; +const showSequenceNumbers = () => state.records.sequenceNumbersEnabled; +const setWrap = function(wrapSetting) { + state.records.wrapEnabled = wrapSetting; +}; +const autoWrap = () => { + if (state.records.wrapEnabled !== void 0) { + return state.records.wrapEnabled; + } + return getConfig().sequence.wrap; +}; +const clear = function() { + state.reset(); + clear$1(); +}; +const parseMessage = function(str) { + const _str = str.trim(); + const message = { + text: _str.replace(/^:?(?:no)?wrap:/, "").trim(), + wrap: _str.match(/^:?wrap:/) !== null ? true : _str.match(/^:?nowrap:/) !== null ? false : void 0 + }; + log.debug("parseMessage:", message); + return message; +}; +const parseBoxData = function(str) { + const match = str.match(/^((?:rgba?|hsla?)\s*\(.*\)|\w*)(.*)$/); + let color = match != null && match[1] ? match[1].trim() : "transparent"; + let title = match != null && match[2] ? match[2].trim() : void 0; + if (window && window.CSS) { + if (!window.CSS.supports("color", color)) { + color = "transparent"; + title = str.trim(); + } + } else { + const style = new Option().style; + style.color = color; + if (style.color !== color) { + color = "transparent"; + title = str.trim(); + } + } + return { + color, + text: title !== void 0 ? sanitizeText(title.replace(/^:?(?:no)?wrap:/, ""), getConfig()) : void 0, + wrap: title !== void 0 ? title.match(/^:?wrap:/) !== null ? true : title.match(/^:?nowrap:/) !== null ? false : void 0 : void 0 + }; +}; +const LINETYPE = { + 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, + PAR_OVER_START: 32 +}; +const ARROWTYPE = { + FILLED: 0, + OPEN: 1 +}; +const PLACEMENT = { + LEFTOF: 0, + RIGHTOF: 1, + OVER: 2 +}; +const addNote = function(actor, placement, message) { + const note = { + actor, + placement, + message: message.text, + wrap: message.wrap === void 0 && autoWrap() || !!message.wrap + }; + const actors = [].concat(actor, actor); + state.records.notes.push(note); + state.records.messages.push({ + from: actors[0], + to: actors[1], + message: message.text, + wrap: message.wrap === void 0 && autoWrap() || !!message.wrap, + type: LINETYPE.NOTE, + placement + }); +}; +const addLinks = function(actorId, text) { + const actor = getActor(actorId); + try { + let sanitizedText = sanitizeText(text.text, getConfig()); + sanitizedText = sanitizedText.replace(/&/g, "&"); + sanitizedText = sanitizedText.replace(/=/g, "="); + const links = JSON.parse(sanitizedText); + insertLinks(actor, links); + } catch (e) { + log.error("error while parsing actor link text", e); + } +}; +const addALink = function(actorId, text) { + const actor = getActor(actorId); + try { + const links = {}; + let sanitizedText = sanitizeText(text.text, getConfig()); + var sep = sanitizedText.indexOf("@"); + sanitizedText = sanitizedText.replace(/&/g, "&"); + sanitizedText = sanitizedText.replace(/=/g, "="); + var label = sanitizedText.slice(0, sep - 1).trim(); + var link = sanitizedText.slice(sep + 1).trim(); + links[label] = link; + insertLinks(actor, links); + } catch (e) { + log.error("error while parsing actor link text", e); + } +}; +function insertLinks(actor, links) { + if (actor.links == null) { + actor.links = links; + } else { + for (let key in links) { + actor.links[key] = links[key]; + } + } +} +const addProperties = function(actorId, text) { + const actor = getActor(actorId); + try { + let sanitizedText = sanitizeText(text.text, getConfig()); + const properties = JSON.parse(sanitizedText); + insertProperties(actor, properties); + } catch (e) { + log.error("error while parsing actor properties text", e); + } +}; +function insertProperties(actor, properties) { + if (actor.properties == null) { + actor.properties = properties; + } else { + for (let key in properties) { + actor.properties[key] = properties[key]; + } + } +} +function boxEnd() { + state.records.currentBox = void 0; +} +const addDetails = function(actorId, text) { + const actor = getActor(actorId); + const elem = document.getElementById(text.text); + try { + const text2 = elem.innerHTML; + const details = JSON.parse(text2); + if (details["properties"]) { + insertProperties(actor, details["properties"]); + } + if (details["links"]) { + insertLinks(actor, details["links"]); + } + } catch (e) { + log.error("error while parsing actor details text", e); + } +}; +const getActorProperty = function(actor, key) { + if (actor !== void 0 && actor.properties !== void 0) { + return actor.properties[key]; + } + return void 0; +}; +const apply = function(param) { + if (Array.isArray(param)) { + param.forEach(function(item) { + apply(item); + }); + } else { + switch (param.type) { + case "sequenceIndex": + state.records.messages.push({ + from: void 0, + to: void 0, + message: { + start: param.sequenceIndex, + step: param.sequenceIndexStep, + visible: param.sequenceVisible + }, + wrap: false, + type: param.signalType + }); + break; + case "addParticipant": + addActor(param.actor, param.actor, param.description, param.draw); + break; + case "createParticipant": + if (state.records.actors[param.actor]) { + throw new Error( + "It is not possible to have actors with the same id, even if one is destroyed before the next is created. Use 'AS' aliases to simulate the behavior" + ); + } + state.records.lastCreated = param.actor; + addActor(param.actor, param.actor, param.description, param.draw); + state.records.createdActors[param.actor] = state.records.messages.length; + break; + case "destroyParticipant": + state.records.lastDestroyed = param.actor; + state.records.destroyedActors[param.actor] = state.records.messages.length; + break; + case "activeStart": + addSignal(param.actor, void 0, void 0, param.signalType); + break; + case "activeEnd": + addSignal(param.actor, void 0, void 0, param.signalType); + break; + case "addNote": + addNote(param.actor, param.placement, param.text); + break; + case "addLinks": + addLinks(param.actor, param.text); + break; + case "addALink": + addALink(param.actor, param.text); + break; + case "addProperties": + addProperties(param.actor, param.text); + break; + case "addDetails": + addDetails(param.actor, param.text); + break; + case "addMessage": + if (state.records.lastCreated) { + if (param.to !== state.records.lastCreated) { + throw new Error( + "The created participant " + state.records.lastCreated + " does not have an associated creating message after its declaration. Please check the sequence diagram." + ); + } else { + state.records.lastCreated = void 0; + } + } else if (state.records.lastDestroyed) { + if (param.to !== state.records.lastDestroyed && param.from !== state.records.lastDestroyed) { + throw new Error( + "The destroyed participant " + state.records.lastDestroyed + " does not have an associated destroying message after its declaration. Please check the sequence diagram." + ); + } else { + state.records.lastDestroyed = void 0; + } + } + addSignal(param.from, param.to, param.msg, param.signalType, param.activate); + break; + case "boxStart": + addBox(param.boxData); + break; + case "boxEnd": + boxEnd(); + break; + case "loopStart": + addSignal(void 0, void 0, param.loopText, param.signalType); + break; + case "loopEnd": + addSignal(void 0, void 0, void 0, param.signalType); + break; + case "rectStart": + addSignal(void 0, void 0, param.color, param.signalType); + break; + case "rectEnd": + addSignal(void 0, void 0, void 0, param.signalType); + break; + case "optStart": + addSignal(void 0, void 0, param.optText, param.signalType); + break; + case "optEnd": + addSignal(void 0, void 0, void 0, param.signalType); + break; + case "altStart": + addSignal(void 0, void 0, param.altText, param.signalType); + break; + case "else": + addSignal(void 0, void 0, param.altText, param.signalType); + break; + case "altEnd": + addSignal(void 0, void 0, void 0, param.signalType); + break; + case "setAccTitle": + setAccTitle(param.text); + break; + case "parStart": + addSignal(void 0, void 0, param.parText, param.signalType); + break; + case "and": + addSignal(void 0, void 0, param.parText, param.signalType); + break; + case "parEnd": + addSignal(void 0, void 0, void 0, param.signalType); + break; + case "criticalStart": + addSignal(void 0, void 0, param.criticalText, param.signalType); + break; + case "option": + addSignal(void 0, void 0, param.optionText, param.signalType); + break; + case "criticalEnd": + addSignal(void 0, void 0, void 0, param.signalType); + break; + case "breakStart": + addSignal(void 0, void 0, param.breakText, param.signalType); + break; + case "breakEnd": + addSignal(void 0, void 0, void 0, param.signalType); + break; + } + } +}; +const db = { + addActor, + addMessage, + addSignal, + addLinks, + addDetails, + addProperties, + autoWrap, + setWrap, + enableSequenceNumbers, + disableSequenceNumbers, + showSequenceNumbers, + getMessages, + getActors, + getCreatedActors, + getDestroyedActors, + getActor, + getActorKeys, + getActorProperty, + getAccTitle, + getBoxes, + getDiagramTitle, + setDiagramTitle, + getConfig: () => getConfig().sequence, + clear, + parseMessage, + parseBoxData, + LINETYPE, + ARROWTYPE, + PLACEMENT, + addNote, + setAccTitle, + apply, + setAccDescription, + getAccDescription, + hasAtLeastOneBox, + hasAtLeastOneBoxWithTitle +}; +const getStyles = (options) => `.actor { + stroke: ${options.actorBorder}; + fill: ${options.actorBkg}; + } + + text.actor > tspan { + fill: ${options.actorTextColor}; + stroke: none; + } + + .actor-line { + stroke: ${options.actorLineColor}; + } + + .messageLine0 { + stroke-width: 1.5; + stroke-dasharray: none; + stroke: ${options.signalColor}; + } + + .messageLine1 { + stroke-width: 1.5; + stroke-dasharray: 2, 2; + stroke: ${options.signalColor}; + } + + #arrowhead path { + fill: ${options.signalColor}; + stroke: ${options.signalColor}; + } + + .sequenceNumber { + fill: ${options.sequenceNumberColor}; + } + + #sequencenumber { + fill: ${options.signalColor}; + } + + #crosshead path { + fill: ${options.signalColor}; + stroke: ${options.signalColor}; + } + + .messageText { + fill: ${options.signalTextColor}; + stroke: none; + } + + .labelBox { + stroke: ${options.labelBoxBorderColor}; + fill: ${options.labelBoxBkgColor}; + } + + .labelText, .labelText > tspan { + fill: ${options.labelTextColor}; + stroke: none; + } + + .loopText, .loopText > tspan { + fill: ${options.loopTextColor}; + stroke: none; + } + + .loopLine { + stroke-width: 2px; + stroke-dasharray: 2, 2; + stroke: ${options.labelBoxBorderColor}; + fill: ${options.labelBoxBorderColor}; + } + + .note { + //stroke: #decc93; + stroke: ${options.noteBorderColor}; + fill: ${options.noteBkgColor}; + } + + .noteText, .noteText > tspan { + fill: ${options.noteTextColor}; + stroke: none; + } + + .activation0 { + fill: ${options.activationBkgColor}; + stroke: ${options.activationBorderColor}; + } + + .activation1 { + fill: ${options.activationBkgColor}; + stroke: ${options.activationBorderColor}; + } + + .activation2 { + fill: ${options.activationBkgColor}; + stroke: ${options.activationBorderColor}; + } + + .actorPopupMenu { + position: absolute; + } + + .actorPopupMenuPanel { + position: absolute; + fill: ${options.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: ${options.actorBorder}; + fill: ${options.actorBkg}; + } + .actor-man circle, line { + stroke: ${options.actorBorder}; + fill: ${options.actorBkg}; + stroke-width: 2px; + } +`; +const styles = getStyles; +const ACTOR_TYPE_WIDTH = 18 * 2; +const TOP_ACTOR_CLASS = "actor-top"; +const BOTTOM_ACTOR_CLASS = "actor-bottom"; +const drawRect = function(elem, rectData) { + return drawRect$1(elem, rectData); +}; +const drawPopup = function(elem, actor, minMenuWidth, textAttrs, forceMenus) { + if (actor.links === void 0 || actor.links === null || Object.keys(actor.links).length === 0) { + return { height: 0, width: 0 }; + } + const links = actor.links; + const actorCnt2 = actor.actorCnt; + const rectData = actor.rectData; + var displayValue = "none"; + if (forceMenus) { + displayValue = "block !important"; + } + const g = elem.append("g"); + g.attr("id", "actor" + actorCnt2 + "_popup"); + g.attr("class", "actorPopupMenu"); + g.attr("display", displayValue); + var actorClass = ""; + if (rectData.class !== void 0) { + actorClass = " " + rectData.class; + } + let menuWidth = rectData.width > minMenuWidth ? rectData.width : minMenuWidth; + const rectElem = g.append("rect"); + rectElem.attr("class", "actorPopupMenuPanel" + actorClass); + rectElem.attr("x", rectData.x); + rectElem.attr("y", rectData.height); + rectElem.attr("fill", rectData.fill); + rectElem.attr("stroke", rectData.stroke); + rectElem.attr("width", menuWidth); + rectElem.attr("height", rectData.height); + rectElem.attr("rx", rectData.rx); + rectElem.attr("ry", rectData.ry); + if (links != null) { + var linkY = 20; + for (let key in links) { + var linkElem = g.append("a"); + var sanitizedLink = sanitizeUrl(links[key]); + linkElem.attr("xlink:href", sanitizedLink); + linkElem.attr("target", "_blank"); + _drawMenuItemTextCandidateFunc(textAttrs)( + key, + linkElem, + rectData.x + 10, + rectData.height + linkY, + menuWidth, + 20, + { class: "actor" }, + textAttrs + ); + linkY += 30; + } + } + rectElem.attr("height", linkY); + return { height: rectData.height + linkY, width: menuWidth }; +}; +const popupMenuToggle = function(popId) { + return "var pu = document.getElementById('" + popId + "'); if (pu != null) { pu.style.display = pu.style.display == 'block' ? 'none' : 'block'; }"; +}; +const drawKatex = async function(elem, textData, msgModel = null) { + let textElem = elem.append("foreignObject"); + const lines = await renderKatex(textData.text, getConfig$1()); + const divElem = textElem.append("xhtml:div").attr("style", "width: fit-content;").attr("xmlns", "http://www.w3.org/1999/xhtml").html(lines); + const dim = divElem.node().getBoundingClientRect(); + textElem.attr("height", Math.round(dim.height)).attr("width", Math.round(dim.width)); + if (textData.class === "noteText") { + const rectElem = elem.node().firstChild; + rectElem.setAttribute("height", dim.height + 2 * textData.textMargin); + const rectDim = rectElem.getBBox(); + textElem.attr("x", Math.round(rectDim.x + rectDim.width / 2 - dim.width / 2)).attr("y", Math.round(rectDim.y + rectDim.height / 2 - dim.height / 2)); + } else if (msgModel) { + let { startx, stopx, starty } = msgModel; + if (startx > stopx) { + const temp = startx; + startx = stopx; + stopx = temp; + } + textElem.attr("x", Math.round(startx + Math.abs(startx - stopx) / 2 - dim.width / 2)); + if (textData.class === "loopText") { + textElem.attr("y", Math.round(starty)); + } else { + textElem.attr("y", Math.round(starty - dim.height)); + } + } + return [textElem]; +}; +const drawText = function(elem, textData) { + let prevTextHeight = 0; + let textHeight = 0; + const lines = textData.text.split(common.lineBreakRegex); + const [_textFontSize, _textFontSizePx] = parseFontSize(textData.fontSize); + let textElems = []; + let dy = 0; + let yfunc = () => textData.y; + if (textData.valign !== void 0 && textData.textMargin !== void 0 && textData.textMargin > 0) { + switch (textData.valign) { + case "top": + case "start": + yfunc = () => Math.round(textData.y + textData.textMargin); + break; + case "middle": + case "center": + yfunc = () => Math.round(textData.y + (prevTextHeight + textHeight + textData.textMargin) / 2); + break; + case "bottom": + case "end": + yfunc = () => Math.round( + textData.y + (prevTextHeight + textHeight + 2 * textData.textMargin) - textData.textMargin + ); + break; + } + } + if (textData.anchor !== void 0 && textData.textMargin !== void 0 && textData.width !== void 0) { + switch (textData.anchor) { + case "left": + case "start": + textData.x = Math.round(textData.x + textData.textMargin); + textData.anchor = "start"; + textData.dominantBaseline = "middle"; + textData.alignmentBaseline = "middle"; + break; + case "middle": + case "center": + textData.x = Math.round(textData.x + textData.width / 2); + textData.anchor = "middle"; + textData.dominantBaseline = "middle"; + textData.alignmentBaseline = "middle"; + break; + case "right": + case "end": + textData.x = Math.round(textData.x + textData.width - textData.textMargin); + textData.anchor = "end"; + textData.dominantBaseline = "middle"; + textData.alignmentBaseline = "middle"; + break; + } + } + for (let [i, line] of lines.entries()) { + if (textData.textMargin !== void 0 && textData.textMargin === 0 && _textFontSize !== void 0) { + dy = i * _textFontSize; + } + const textElem = elem.append("text"); + textElem.attr("x", textData.x); + textElem.attr("y", yfunc()); + if (textData.anchor !== void 0) { + textElem.attr("text-anchor", textData.anchor).attr("dominant-baseline", textData.dominantBaseline).attr("alignment-baseline", textData.alignmentBaseline); + } + if (textData.fontFamily !== void 0) { + textElem.style("font-family", textData.fontFamily); + } + if (_textFontSizePx !== void 0) { + textElem.style("font-size", _textFontSizePx); + } + if (textData.fontWeight !== void 0) { + textElem.style("font-weight", textData.fontWeight); + } + if (textData.fill !== void 0) { + textElem.attr("fill", textData.fill); + } + if (textData.class !== void 0) { + textElem.attr("class", textData.class); + } + if (textData.dy !== void 0) { + textElem.attr("dy", textData.dy); + } else if (dy !== 0) { + textElem.attr("dy", dy); + } + const text = line || ZERO_WIDTH_SPACE; + if (textData.tspan) { + const span = textElem.append("tspan"); + span.attr("x", textData.x); + if (textData.fill !== void 0) { + span.attr("fill", textData.fill); + } + span.text(text); + } else { + textElem.text(text); + } + if (textData.valign !== void 0 && textData.textMargin !== void 0 && textData.textMargin > 0) { + textHeight += (textElem._groups || textElem)[0][0].getBBox().height; + prevTextHeight = textHeight; + } + textElems.push(textElem); + } + return textElems; +}; +const drawLabel = function(elem, txtObject) { + function genPoints(x, y, width, height, cut) { + return x + "," + y + " " + (x + width) + "," + y + " " + (x + width) + "," + (y + height - cut) + " " + (x + width - cut * 1.2) + "," + (y + height) + " " + x + "," + (y + height); + } + const polygon = elem.append("polygon"); + polygon.attr("points", genPoints(txtObject.x, txtObject.y, txtObject.width, txtObject.height, 7)); + polygon.attr("class", "labelBox"); + txtObject.y = txtObject.y + txtObject.height / 2; + drawText(elem, txtObject); + return polygon; +}; +let actorCnt = -1; +const fixLifeLineHeights = (diagram2, actors, actorKeys, conf2) => { + if (!diagram2.select) { + return; + } + actorKeys.forEach((actorKey) => { + const actor = actors[actorKey]; + const actorDOM = diagram2.select("#actor" + actor.actorCnt); + if (!conf2.mirrorActors && actor.stopy) { + actorDOM.attr("y2", actor.stopy + actor.height / 2); + } else if (conf2.mirrorActors) { + actorDOM.attr("y2", actor.stopy); + } + }); +}; +const drawActorTypeParticipant = async function(elem, actor, conf2, isFooter) { + const actorY = isFooter ? actor.stopy : actor.starty; + const center = actor.x + actor.width / 2; + const centerY = actorY + 5; + const boxplusLineGroup = elem.append("g").lower(); + var g = boxplusLineGroup; + if (!isFooter) { + actorCnt++; + if (Object.keys(actor.links || {}).length && !conf2.forceMenus) { + g.attr("onclick", popupMenuToggle(`actor${actorCnt}_popup`)).attr("cursor", "pointer"); + } + g.append("line").attr("id", "actor" + actorCnt).attr("x1", center).attr("y1", centerY).attr("x2", center).attr("y2", 2e3).attr("class", "actor-line").attr("class", "200").attr("stroke-width", "0.5px").attr("stroke", "#999"); + g = boxplusLineGroup.append("g"); + actor.actorCnt = actorCnt; + if (actor.links != null) { + g.attr("id", "root-" + actorCnt); + } + } + const rect = getNoteRect$1(); + var cssclass = "actor"; + if (actor.properties != null && actor.properties["class"]) { + cssclass = actor.properties["class"]; + } else { + rect.fill = "#eaeaea"; + } + if (isFooter) { + cssclass += ` ${BOTTOM_ACTOR_CLASS}`; + } else { + cssclass += ` ${TOP_ACTOR_CLASS}`; + } + rect.x = actor.x; + rect.y = actorY; + rect.width = actor.width; + rect.height = actor.height; + rect.class = cssclass; + rect.rx = 3; + rect.ry = 3; + rect.name = actor.name; + const rectElem = drawRect(g, rect); + actor.rectData = rect; + if (actor.properties != null && actor.properties["icon"]) { + const iconSrc = actor.properties["icon"].trim(); + if (iconSrc.charAt(0) === "@") { + drawEmbeddedImage(g, rect.x + rect.width - 20, rect.y + 10, iconSrc.substr(1)); + } else { + drawImage(g, rect.x + rect.width - 20, rect.y + 10, iconSrc); + } + } + await _drawTextCandidateFunc(conf2, hasKatex(actor.description))( + actor.description, + g, + rect.x, + rect.y, + rect.width, + rect.height, + { class: "actor" }, + conf2 + ); + let height = actor.height; + if (rectElem.node) { + const bounds2 = rectElem.node().getBBox(); + actor.height = bounds2.height; + height = bounds2.height; + } + return height; +}; +const drawActorTypeActor = async function(elem, actor, conf2, isFooter) { + const actorY = isFooter ? actor.stopy : actor.starty; + const center = actor.x + actor.width / 2; + const centerY = actorY + 80; + elem.lower(); + if (!isFooter) { + actorCnt++; + elem.append("line").attr("id", "actor" + actorCnt).attr("x1", center).attr("y1", centerY).attr("x2", center).attr("y2", 2e3).attr("class", "actor-line").attr("class", "200").attr("stroke-width", "0.5px").attr("stroke", "#999"); + actor.actorCnt = actorCnt; + } + const actElem = elem.append("g"); + let cssClass = "actor-man"; + if (isFooter) { + cssClass += ` ${BOTTOM_ACTOR_CLASS}`; + } else { + cssClass += ` ${TOP_ACTOR_CLASS}`; + } + actElem.attr("class", cssClass); + actElem.attr("name", actor.name); + const rect = getNoteRect$1(); + rect.x = actor.x; + rect.y = actorY; + rect.fill = "#eaeaea"; + rect.width = actor.width; + rect.height = actor.height; + rect.class = "actor"; + rect.rx = 3; + rect.ry = 3; + actElem.append("line").attr("id", "actor-man-torso" + actorCnt).attr("x1", center).attr("y1", actorY + 25).attr("x2", center).attr("y2", actorY + 45); + actElem.append("line").attr("id", "actor-man-arms" + actorCnt).attr("x1", center - ACTOR_TYPE_WIDTH / 2).attr("y1", actorY + 33).attr("x2", center + ACTOR_TYPE_WIDTH / 2).attr("y2", actorY + 33); + actElem.append("line").attr("x1", center - ACTOR_TYPE_WIDTH / 2).attr("y1", actorY + 60).attr("x2", center).attr("y2", actorY + 45); + actElem.append("line").attr("x1", center).attr("y1", actorY + 45).attr("x2", center + ACTOR_TYPE_WIDTH / 2 - 2).attr("y2", actorY + 60); + const circle = actElem.append("circle"); + circle.attr("cx", actor.x + actor.width / 2); + circle.attr("cy", actorY + 10); + circle.attr("r", 15); + circle.attr("width", actor.width); + circle.attr("height", actor.height); + const bounds2 = actElem.node().getBBox(); + actor.height = bounds2.height; + await _drawTextCandidateFunc(conf2, hasKatex(actor.description))( + actor.description, + actElem, + rect.x, + rect.y + 35, + rect.width, + rect.height, + { class: "actor" }, + conf2 + ); + return actor.height; +}; +const drawActor = async function(elem, actor, conf2, isFooter) { + switch (actor.type) { + case "actor": + return await drawActorTypeActor(elem, actor, conf2, isFooter); + case "participant": + return await drawActorTypeParticipant(elem, actor, conf2, isFooter); + } +}; +const drawBox = async function(elem, box, conf2) { + const boxplusTextGroup = elem.append("g"); + const g = boxplusTextGroup; + drawBackgroundRect(g, box); + if (box.name) { + await _drawTextCandidateFunc(conf2)( + box.name, + g, + box.x, + box.y + (box.textMaxHeight || 0) / 2, + box.width, + 0, + { class: "text" }, + conf2 + ); + } + g.lower(); +}; +const anchorElement = function(elem) { + return elem.append("g"); +}; +const drawActivation = function(elem, bounds2, verticalPos, conf2, actorActivations2) { + const rect = getNoteRect$1(); + const g = bounds2.anchored; + rect.x = bounds2.startx; + rect.y = bounds2.starty; + rect.class = "activation" + actorActivations2 % 3; + rect.width = bounds2.stopx - bounds2.startx; + rect.height = verticalPos - bounds2.starty; + drawRect(g, rect); +}; +const drawLoop = async function(elem, loopModel, labelText, conf2) { + const { + boxMargin, + boxTextMargin, + labelBoxHeight, + labelBoxWidth, + messageFontFamily: fontFamily, + messageFontSize: fontSize, + messageFontWeight: fontWeight + } = conf2; + const g = elem.append("g"); + const drawLoopLine = function(startx, starty, stopx, stopy) { + return g.append("line").attr("x1", startx).attr("y1", starty).attr("x2", stopx).attr("y2", stopy).attr("class", "loopLine"); + }; + drawLoopLine(loopModel.startx, loopModel.starty, loopModel.stopx, loopModel.starty); + drawLoopLine(loopModel.stopx, loopModel.starty, loopModel.stopx, loopModel.stopy); + drawLoopLine(loopModel.startx, loopModel.stopy, loopModel.stopx, loopModel.stopy); + drawLoopLine(loopModel.startx, loopModel.starty, loopModel.startx, loopModel.stopy); + if (loopModel.sections !== void 0) { + loopModel.sections.forEach(function(item) { + drawLoopLine(loopModel.startx, item.y, loopModel.stopx, item.y).style( + "stroke-dasharray", + "3, 3" + ); + }); + } + let txt = getTextObj$1(); + txt.text = labelText; + txt.x = loopModel.startx; + txt.y = loopModel.starty; + txt.fontFamily = fontFamily; + txt.fontSize = fontSize; + txt.fontWeight = fontWeight; + txt.anchor = "middle"; + txt.valign = "middle"; + txt.tspan = false; + txt.width = labelBoxWidth || 50; + txt.height = labelBoxHeight || 20; + txt.textMargin = boxTextMargin; + txt.class = "labelText"; + drawLabel(g, txt); + txt = getTextObj(); + txt.text = loopModel.title; + txt.x = loopModel.startx + labelBoxWidth / 2 + (loopModel.stopx - loopModel.startx) / 2; + txt.y = loopModel.starty + boxMargin + boxTextMargin; + txt.anchor = "middle"; + txt.valign = "middle"; + txt.textMargin = boxTextMargin; + txt.class = "loopText"; + txt.fontFamily = fontFamily; + txt.fontSize = fontSize; + txt.fontWeight = fontWeight; + txt.wrap = true; + let textElem = hasKatex(txt.text) ? await drawKatex(g, txt, loopModel) : drawText(g, txt); + if (loopModel.sectionTitles !== void 0) { + for (const [idx, item] of Object.entries(loopModel.sectionTitles)) { + if (item.message) { + txt.text = item.message; + txt.x = loopModel.startx + (loopModel.stopx - loopModel.startx) / 2; + txt.y = loopModel.sections[idx].y + boxMargin + boxTextMargin; + txt.class = "loopText"; + txt.anchor = "middle"; + txt.valign = "middle"; + txt.tspan = false; + txt.fontFamily = fontFamily; + txt.fontSize = fontSize; + txt.fontWeight = fontWeight; + txt.wrap = loopModel.wrap; + if (hasKatex(txt.text)) { + loopModel.starty = loopModel.sections[idx].y; + await drawKatex(g, txt, loopModel); + } else { + drawText(g, txt); + } + let sectionHeight = Math.round( + textElem.map((te) => (te._groups || te)[0][0].getBBox().height).reduce((acc, curr) => acc + curr) + ); + loopModel.sections[idx].height += sectionHeight - (boxMargin + boxTextMargin); + } + } + } + loopModel.height = Math.round(loopModel.stopy - loopModel.starty); + return g; +}; +const drawBackgroundRect = function(elem, bounds2) { + drawBackgroundRect$1(elem, bounds2); +}; +const insertDatabaseIcon = function(elem) { + elem.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-.047.148-.048.143-.049.139-.049.136-.05.131-.05.126-.05.123-.051.118-.052.114-.051.11-.052.106-.052.101-.052.096-.052.092-.052.088-.053.083-.051.079-.052.074-.052.07-.051.065-.051.06-.051.056-.05.051-.05.023-.024.023-.025.021-.024.02-.024.019-.024.018-.024.017-.024.015-.023.014-.024.013-.023.012-.023.01-.023.01-.022.008-.022.006-.022.006-.022.004-.022.004-.021.001-.021.001-.021v-4.127l-.077.055-.08.053-.083.054-.085.053-.087.052-.09.052-.093.051-.095.05-.097.05-.1.049-.102.049-.105.048-.106.047-.109.047-.111.046-.114.045-.115.045-.118.044-.12.043-.122.042-.124.042-.126.041-.128.04-.13.04-.132.038-.134.038-.135.037-.138.037-.139.035-.142.035-.143.034-.144.033-.147.032-.148.031-.15.03-.151.03-.153.029-.154.027-.156.027-.158.026-.159.025-.161.024-.162.023-.163.022-.165.021-.166.02-.167.019-.169.018-.169.017-.171.016-.173.015-.173.014-.175.013-.175.012-.177.011-.178.01-.179.008-.179.008-.181.006-.182.005-.182.004-.184.003-.184.002h-.37l-.184-.002-.184-.003-.182-.004-.182-.005-.181-.006-.179-.008-.179-.008-.178-.01-.176-.011-.176-.012-.175-.013-.173-.014-.172-.015-.171-.016-.17-.017-.169-.018-.167-.019-.166-.02-.165-.021-.163-.022-.162-.023-.161-.024-.159-.025-.157-.026-.156-.027-.155-.027-.153-.029-.151-.03-.15-.03-.148-.031-.146-.032-.145-.033-.143-.034-.141-.035-.14-.035-.137-.037-.136-.037-.134-.038-.132-.038-.13-.04-.128-.04-.126-.041-.124-.042-.122-.042-.12-.044-.117-.043-.116-.045-.113-.045-.112-.046-.109-.047-.106-.047-.105-.048-.102-.049-.1-.049-.097-.05-.095-.05-.093-.052-.09-.051-.087-.052-.085-.053-.083-.054-.08-.054-.077-.054v4.127zm0-5.654v.011l.001.021.003.021.004.021.005.022.006.022.007.022.009.022.01.022.011.023.012.023.013.023.015.024.016.023.017.024.018.024.019.024.021.024.022.024.023.025.024.024.052.05.056.05.061.05.066.051.07.051.075.052.079.051.084.052.088.052.092.052.097.052.102.052.105.052.11.051.114.051.119.052.123.05.127.051.131.05.135.049.139.049.144.048.147.048.152.047.155.046.16.045.163.045.167.044.171.042.176.042.178.04.183.04.187.038.19.037.194.036.197.034.202.033.204.032.209.03.212.028.216.027.219.025.222.024.226.022.23.02.233.018.236.016.24.014.243.012.246.01.249.008.253.006.256.003.259.001.26-.001.257-.003.254-.006.25-.008.247-.01.244-.012.241-.015.237-.016.233-.018.231-.02.226-.022.224-.024.22-.025.216-.027.212-.029.21-.03.205-.032.202-.033.198-.035.194-.036.191-.037.187-.039.183-.039.179-.041.175-.042.172-.043.168-.044.163-.045.16-.045.155-.047.152-.047.148-.048.143-.048.139-.05.136-.049.131-.05.126-.051.123-.051.118-.051.114-.052.11-.052.106-.052.101-.052.096-.052.092-.052.088-.052.083-.052.079-.052.074-.051.07-.052.065-.051.06-.05.056-.051.051-.049.023-.025.023-.024.021-.025.02-.024.019-.024.018-.024.017-.024.015-.023.014-.023.013-.024.012-.022.01-.023.01-.023.008-.022.006-.022.006-.022.004-.021.004-.022.001-.021.001-.021v-4.139l-.077.054-.08.054-.083.054-.085.052-.087.053-.09.051-.093.051-.095.051-.097.05-.1.049-.102.049-.105.048-.106.047-.109.047-.111.046-.114.045-.115.044-.118.044-.12.044-.122.042-.124.042-.126.041-.128.04-.13.039-.132.039-.134.038-.135.037-.138.036-.139.036-.142.035-.143.033-.144.033-.147.033-.148.031-.15.03-.151.03-.153.028-.154.028-.156.027-.158.026-.159.025-.161.024-.162.023-.163.022-.165.021-.166.02-.167.019-.169.018-.169.017-.171.016-.173.015-.173.014-.175.013-.175.012-.177.011-.178.009-.179.009-.179.007-.181.007-.182.005-.182.004-.184.003-.184.002h-.37l-.184-.002-.184-.003-.182-.004-.182-.005-.181-.007-.179-.007-.179-.009-.178-.009-.176-.011-.176-.012-.175-.013-.173-.014-.172-.015-.171-.016-.17-.017-.169-.018-.167-.019-.166-.02-.165-.021-.163-.022-.162-.023-.161-.024-.159-.025-.157-.026-.156-.027-.155-.028-.153-.028-.151-.03-.15-.03-.148-.031-.146-.033-.145-.033-.143-.033-.141-.035-.14-.036-.137-.036-.136-.037-.134-.038-.132-.039-.13-.039-.128-.04-.126-.041-.124-.042-.122-.043-.12-.043-.117-.044-.116-.044-.113-.046-.112-.046-.109-.046-.106-.047-.105-.048-.102-.049-.1-.049-.097-.05-.095-.051-.093-.051-.09-.051-.087-.053-.085-.052-.083-.054-.08-.054-.077-.054v4.139zm0-5.666v.011l.001.02.003.022.004.021.005.022.006.021.007.022.009.023.01.022.011.023.012.023.013.023.015.023.016.024.017.024.018.023.019.024.021.025.022.024.023.024.024.025.052.05.056.05.061.05.066.051.07.051.075.052.079.051.084.052.088.052.092.052.097.052.102.052.105.051.11.052.114.051.119.051.123.051.127.05.131.05.135.05.139.049.144.048.147.048.152.047.155.046.16.045.163.045.167.043.171.043.176.042.178.04.183.04.187.038.19.037.194.036.197.034.202.033.204.032.209.03.212.028.216.027.219.025.222.024.226.021.23.02.233.018.236.017.24.014.243.012.246.01.249.008.253.006.256.003.259.001.26-.001.257-.003.254-.006.25-.008.247-.01.244-.013.241-.014.237-.016.233-.018.231-.02.226-.022.224-.024.22-.025.216-.027.212-.029.21-.03.205-.032.202-.033.198-.035.194-.036.191-.037.187-.039.183-.039.179-.041.175-.042.172-.043.168-.044.163-.045.16-.045.155-.047.152-.047.148-.048.143-.049.139-.049.136-.049.131-.051.126-.05.123-.051.118-.052.114-.051.11-.052.106-.052.101-.052.096-.052.092-.052.088-.052.083-.052.079-.052.074-.052.07-.051.065-.051.06-.051.056-.05.051-.049.023-.025.023-.025.021-.024.02-.024.019-.024.018-.024.017-.024.015-.023.014-.024.013-.023.012-.023.01-.022.01-.023.008-.022.006-.022.006-.022.004-.022.004-.021.001-.021.001-.021v-4.153l-.077.054-.08.054-.083.053-.085.053-.087.053-.09.051-.093.051-.095.051-.097.05-.1.049-.102.048-.105.048-.106.048-.109.046-.111.046-.114.046-.115.044-.118.044-.12.043-.122.043-.124.042-.126.041-.128.04-.13.039-.132.039-.134.038-.135.037-.138.036-.139.036-.142.034-.143.034-.144.033-.147.032-.148.032-.15.03-.151.03-.153.028-.154.028-.156.027-.158.026-.159.024-.161.024-.162.023-.163.023-.165.021-.166.02-.167.019-.169.018-.169.017-.171.016-.173.015-.173.014-.175.013-.175.012-.177.01-.178.01-.179.009-.179.007-.181.006-.182.006-.182.004-.184.003-.184.001-.185.001-.185-.001-.184-.001-.184-.003-.182-.004-.182-.006-.181-.006-.179-.007-.179-.009-.178-.01-.176-.01-.176-.012-.175-.013-.173-.014-.172-.015-.171-.016-.17-.017-.169-.018-.167-.019-.166-.02-.165-.021-.163-.023-.162-.023-.161-.024-.159-.024-.157-.026-.156-.027-.155-.028-.153-.028-.151-.03-.15-.03-.148-.032-.146-.032-.145-.033-.143-.034-.141-.034-.14-.036-.137-.036-.136-.037-.134-.038-.132-.039-.13-.039-.128-.041-.126-.041-.124-.041-.122-.043-.12-.043-.117-.044-.116-.044-.113-.046-.112-.046-.109-.046-.106-.048-.105-.048-.102-.048-.1-.05-.097-.049-.095-.051-.093-.051-.09-.052-.087-.052-.085-.053-.083-.053-.08-.054-.077-.054v4.153zm8.74-8.179l-.257.004-.254.005-.25.008-.247.011-.244.012-.241.014-.237.016-.233.018-.231.021-.226.022-.224.023-.22.026-.216.027-.212.028-.21.031-.205.032-.202.033-.198.034-.194.036-.191.038-.187.038-.183.04-.179.041-.175.042-.172.043-.168.043-.163.045-.16.046-.155.046-.152.048-.148.048-.143.048-.139.049-.136.05-.131.05-.126.051-.123.051-.118.051-.114.052-.11.052-.106.052-.101.052-.096.052-.092.052-.088.052-.083.052-.079.052-.074.051-.07.052-.065.051-.06.05-.056.05-.051.05-.023.025-.023.024-.021.024-.02.025-.019.024-.018.024-.017.023-.015.024-.014.023-.013.023-.012.023-.01.023-.01.022-.008.022-.006.023-.006.021-.004.022-.004.021-.001.021-.001.021.001.021.001.021.004.021.004.022.006.021.006.023.008.022.01.022.01.023.012.023.013.023.014.023.015.024.017.023.018.024.019.024.02.025.021.024.023.024.023.025.051.05.056.05.06.05.065.051.07.052.074.051.079.052.083.052.088.052.092.052.096.052.101.052.106.052.11.052.114.052.118.051.123.051.126.051.131.05.136.05.139.049.143.048.148.048.152.048.155.046.16.046.163.045.168.043.172.043.175.042.179.041.183.04.187.038.191.038.194.036.198.034.202.033.205.032.21.031.212.028.216.027.22.026.224.023.226.022.231.021.233.018.237.016.241.014.244.012.247.011.25.008.254.005.257.004.26.001.26-.001.257-.004.254-.005.25-.008.247-.011.244-.012.241-.014.237-.016.233-.018.231-.021.226-.022.224-.023.22-.026.216-.027.212-.028.21-.031.205-.032.202-.033.198-.034.194-.036.191-.038.187-.038.183-.04.179-.041.175-.042.172-.043.168-.043.163-.045.16-.046.155-.046.152-.048.148-.048.143-.048.139-.049.136-.05.131-.05.126-.051.123-.051.118-.051.114-.052.11-.052.106-.052.101-.052.096-.052.092-.052.088-.052.083-.052.079-.052.074-.051.07-.052.065-.051.06-.05.056-.05.051-.05.023-.025.023-.024.021-.024.02-.025.019-.024.018-.024.017-.023.015-.024.014-.023.013-.023.012-.023.01-.023.01-.022.008-.022.006-.023.006-.021.004-.022.004-.021.001-.021.001-.021-.001-.021-.001-.021-.004-.021-.004-.022-.006-.021-.006-.023-.008-.022-.01-.022-.01-.023-.012-.023-.013-.023-.014-.023-.015-.024-.017-.023-.018-.024-.019-.024-.02-.025-.021-.024-.023-.024-.023-.025-.051-.05-.056-.05-.06-.05-.065-.051-.07-.052-.074-.051-.079-.052-.083-.052-.088-.052-.092-.052-.096-.052-.101-.052-.106-.052-.11-.052-.114-.052-.118-.051-.123-.051-.126-.051-.131-.05-.136-.05-.139-.049-.143-.048-.148-.048-.152-.048-.155-.046-.16-.046-.163-.045-.168-.043-.172-.043-.175-.042-.179-.041-.183-.04-.187-.038-.191-.038-.194-.036-.198-.034-.202-.033-.205-.032-.21-.031-.212-.028-.216-.027-.22-.026-.224-.023-.226-.022-.231-.021-.233-.018-.237-.016-.241-.014-.244-.012-.247-.011-.25-.008-.254-.005-.257-.004-.26-.001-.26.001z" + ); +}; +const insertComputerIcon = function(elem) { + elem.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" + ); +}; +const insertClockIcon = function(elem) { + elem.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" + ); +}; +const insertArrowHead = function(elem) { + elem.append("defs").append("marker").attr("id", "arrowhead").attr("refX", 7.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"); +}; +const insertArrowFilledHead = function(elem) { + elem.append("defs").append("marker").attr("id", "filled-head").attr("refX", 15.5).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"); +}; +const insertSequenceNumber = function(elem) { + elem.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); +}; +const insertArrowCrossHead = function(elem) { + const defs = elem.append("defs"); + const marker = defs.append("marker").attr("id", "crosshead").attr("markerWidth", 15).attr("markerHeight", 8).attr("orient", "auto").attr("refX", 4).attr("refY", 4.5); + marker.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"); +}; +const getTextObj = 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: true, + valign: void 0 + }; +}; +const getNoteRect = function() { + return { + x: 0, + y: 0, + fill: "#EDF2AE", + stroke: "#666", + width: 100, + anchor: "start", + height: 100, + rx: 0, + ry: 0 + }; +}; +const _drawTextCandidateFunc = function() { + function byText(content, g, x, y, width, height, textAttrs) { + const text = g.append("text").attr("x", x + width / 2).attr("y", y + height / 2 + 5).style("text-anchor", "middle").text(content); + _setTextAttrs(text, textAttrs); + } + function byTspan(content, g, x, y, width, height, textAttrs, conf2) { + const { actorFontSize, actorFontFamily, actorFontWeight } = conf2; + const [_actorFontSize, _actorFontSizePx] = parseFontSize(actorFontSize); + const lines = content.split(common.lineBreakRegex); + for (let i = 0; i < lines.length; i++) { + const dy = i * _actorFontSize - _actorFontSize * (lines.length - 1) / 2; + const text = g.append("text").attr("x", x + width / 2).attr("y", y).style("text-anchor", "middle").style("font-size", _actorFontSizePx).style("font-weight", actorFontWeight).style("font-family", actorFontFamily); + text.append("tspan").attr("x", x + width / 2).attr("dy", dy).text(lines[i]); + text.attr("y", y + height / 2).attr("dominant-baseline", "central").attr("alignment-baseline", "central"); + _setTextAttrs(text, textAttrs); + } + } + function byFo(content, g, x, y, width, height, textAttrs, conf2) { + const s = g.append("switch"); + const f = s.append("foreignObject").attr("x", x).attr("y", y).attr("width", width).attr("height", height); + const text = f.append("xhtml:div").style("display", "table").style("height", "100%").style("width", "100%"); + text.append("div").style("display", "table-cell").style("text-align", "center").style("vertical-align", "middle").text(content); + byTspan(content, s, x, y, width, height, textAttrs, conf2); + _setTextAttrs(text, textAttrs); + } + async function byKatex(content, g, x, y, width, height, textAttrs, conf2) { + const dim = await calculateMathMLDimensions(content, getConfig$1()); + const s = g.append("switch"); + const f = s.append("foreignObject").attr("x", x + width / 2 - dim.width / 2).attr("y", y + height / 2 - dim.height / 2).attr("width", dim.width).attr("height", dim.height); + const text = f.append("xhtml:div").style("height", "100%").style("width", "100%"); + text.append("div").style("text-align", "center").style("vertical-align", "middle").html(await renderKatex(content, getConfig$1())); + byTspan(content, s, x, y, width, height, textAttrs, conf2); + _setTextAttrs(text, textAttrs); + } + function _setTextAttrs(toText, fromTextAttrsDict) { + for (const key in fromTextAttrsDict) { + if (fromTextAttrsDict.hasOwnProperty(key)) { + toText.attr(key, fromTextAttrsDict[key]); + } + } + } + return function(conf2, hasKatex2 = false) { + if (hasKatex2) { + return byKatex; + } + return conf2.textPlacement === "fo" ? byFo : conf2.textPlacement === "old" ? byText : byTspan; + }; +}(); +const _drawMenuItemTextCandidateFunc = function() { + function byText(content, g, x, y, width, height, textAttrs) { + const text = g.append("text").attr("x", x).attr("y", y).style("text-anchor", "start").text(content); + _setTextAttrs(text, textAttrs); + } + function byTspan(content, g, x, y, width, height, textAttrs, conf2) { + const { actorFontSize, actorFontFamily, actorFontWeight } = conf2; + const lines = content.split(common.lineBreakRegex); + for (let i = 0; i < lines.length; i++) { + const dy = i * actorFontSize - actorFontSize * (lines.length - 1) / 2; + const text = g.append("text").attr("x", x).attr("y", y).style("text-anchor", "start").style("font-size", actorFontSize).style("font-weight", actorFontWeight).style("font-family", actorFontFamily); + text.append("tspan").attr("x", x).attr("dy", dy).text(lines[i]); + text.attr("y", y + height / 2).attr("dominant-baseline", "central").attr("alignment-baseline", "central"); + _setTextAttrs(text, textAttrs); + } + } + function byFo(content, g, x, y, width, height, textAttrs, conf2) { + const s = g.append("switch"); + const f = s.append("foreignObject").attr("x", x).attr("y", y).attr("width", width).attr("height", height); + const text = f.append("xhtml:div").style("display", "table").style("height", "100%").style("width", "100%"); + text.append("div").style("display", "table-cell").style("text-align", "center").style("vertical-align", "middle").text(content); + byTspan(content, s, x, y, width, height, textAttrs, conf2); + _setTextAttrs(text, textAttrs); + } + function _setTextAttrs(toText, fromTextAttrsDict) { + for (const key in fromTextAttrsDict) { + if (fromTextAttrsDict.hasOwnProperty(key)) { + toText.attr(key, fromTextAttrsDict[key]); + } + } + } + return function(conf2) { + return conf2.textPlacement === "fo" ? byFo : conf2.textPlacement === "old" ? byText : byTspan; + }; +}(); +const svgDraw = { + drawRect, + drawText, + drawLabel, + drawActor, + drawBox, + drawPopup, + anchorElement, + drawActivation, + drawLoop, + drawBackgroundRect, + insertArrowHead, + insertArrowFilledHead, + insertSequenceNumber, + insertArrowCrossHead, + insertDatabaseIcon, + insertComputerIcon, + insertClockIcon, + getTextObj, + getNoteRect, + fixLifeLineHeights, + sanitizeUrl +}; +let conf = {}; +const bounds = { + 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((actor) => actor.height || 0) + ) + (this.loops.length === 0 ? 0 : this.loops.map((it) => it.height || 0).reduce((acc, h) => acc + h)) + (this.messages.length === 0 ? 0 : this.messages.map((it) => it.height || 0).reduce((acc, h) => acc + h)) + (this.notes.length === 0 ? 0 : this.notes.map((it) => it.height || 0).reduce((acc, h) => acc + h)); + }, + clear: function() { + this.actors = []; + this.boxes = []; + this.loops = []; + this.messages = []; + this.notes = []; + }, + addBox: function(boxModel) { + this.boxes.push(boxModel); + }, + addActor: function(actorModel) { + this.actors.push(actorModel); + }, + addLoop: function(loopModel) { + this.loops.push(loopModel); + }, + addMessage: function(msgModel) { + this.messages.push(msgModel); + }, + addNote: function(noteModel) { + this.notes.push(noteModel); + }, + 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; + setConf(getConfig()); + }, + updateVal: function(obj, key, val, fun) { + if (obj[key] === void 0) { + obj[key] = val; + } else { + obj[key] = fun(val, obj[key]); + } + }, + updateBounds: function(startx, starty, stopx, stopy) { + const _self = this; + let cnt = 0; + function updateFn(type) { + return function updateItemBounds(item) { + cnt++; + const n = _self.sequenceItems.length - cnt + 1; + _self.updateVal(item, "starty", starty - n * conf.boxMargin, Math.min); + _self.updateVal(item, "stopy", stopy + n * conf.boxMargin, Math.max); + _self.updateVal(bounds.data, "startx", startx - n * conf.boxMargin, Math.min); + _self.updateVal(bounds.data, "stopx", stopx + n * conf.boxMargin, Math.max); + if (!(type === "activation")) { + _self.updateVal(item, "startx", startx - n * conf.boxMargin, Math.min); + _self.updateVal(item, "stopx", stopx + n * conf.boxMargin, Math.max); + _self.updateVal(bounds.data, "starty", starty - n * conf.boxMargin, Math.min); + _self.updateVal(bounds.data, "stopy", stopy + n * conf.boxMargin, Math.max); + } + }; + } + this.sequenceItems.forEach(updateFn()); + this.activations.forEach(updateFn("activation")); + }, + insert: function(startx, starty, stopx, stopy) { + const _startx = common.getMin(startx, stopx); + const _stopx = common.getMax(startx, stopx); + const _starty = common.getMin(starty, stopy); + const _stopy = common.getMax(starty, stopy); + this.updateVal(bounds.data, "startx", _startx, Math.min); + this.updateVal(bounds.data, "starty", _starty, Math.min); + this.updateVal(bounds.data, "stopx", _stopx, Math.max); + this.updateVal(bounds.data, "stopy", _stopy, Math.max); + this.updateBounds(_startx, _starty, _stopx, _stopy); + }, + newActivation: function(message, diagram2, actors) { + const actorRect = actors[message.from.actor]; + const stackedSize = actorActivations(message.from.actor).length || 0; + const x = actorRect.x + actorRect.width / 2 + (stackedSize - 1) * conf.activationWidth / 2; + this.activations.push({ + startx: x, + starty: this.verticalPos + 2, + stopx: x + conf.activationWidth, + stopy: void 0, + actor: message.from.actor, + anchored: svgDraw.anchorElement(diagram2) + }); + }, + endActivation: function(message) { + const lastActorActivationIdx = this.activations.map(function(activation) { + return activation.actor; + }).lastIndexOf(message.from.actor); + return this.activations.splice(lastActorActivationIdx, 1)[0]; + }, + createLoop: function(title = { message: void 0, wrap: false, width: void 0 }, fill) { + return { + startx: void 0, + starty: this.verticalPos, + stopx: void 0, + stopy: void 0, + title: title.message, + wrap: title.wrap, + width: title.width, + height: 0, + fill + }; + }, + newLoop: function(title = { message: void 0, wrap: false, width: void 0 }, fill) { + this.sequenceItems.push(this.createLoop(title, fill)); + }, + endLoop: function() { + return this.sequenceItems.pop(); + }, + isLoopOverlap: function() { + return this.sequenceItems.length ? this.sequenceItems[this.sequenceItems.length - 1].overlap : false; + }, + addSectionToLoop: function(message) { + const loop = this.sequenceItems.pop(); + loop.sections = loop.sections || []; + loop.sectionTitles = loop.sectionTitles || []; + loop.sections.push({ y: bounds.getVerticalPos(), height: 0 }); + loop.sectionTitles.push(message); + this.sequenceItems.push(loop); + }, + saveVerticalPos: function() { + if (this.isLoopOverlap()) { + this.savedVerticalPos = this.verticalPos; + } + }, + resetVerticalPos: function() { + if (this.isLoopOverlap()) { + this.verticalPos = this.savedVerticalPos; + } + }, + bumpVerticalPos: function(bump) { + this.verticalPos = this.verticalPos + bump; + this.data.stopy = common.getMax(this.data.stopy, this.verticalPos); + }, + getVerticalPos: function() { + return this.verticalPos; + }, + getBounds: function() { + return { bounds: this.data, models: this.models }; + } +}; +const drawNote = async function(elem, noteModel) { + bounds.bumpVerticalPos(conf.boxMargin); + noteModel.height = conf.boxMargin; + noteModel.starty = bounds.getVerticalPos(); + const rect = getNoteRect$1(); + rect.x = noteModel.startx; + rect.y = noteModel.starty; + rect.width = noteModel.width || conf.width; + rect.class = "note"; + const g = elem.append("g"); + const rectElem = svgDraw.drawRect(g, rect); + const textObj = getTextObj$1(); + textObj.x = noteModel.startx; + textObj.y = noteModel.starty; + textObj.width = rect.width; + textObj.dy = "1em"; + textObj.text = noteModel.message; + textObj.class = "noteText"; + textObj.fontFamily = conf.noteFontFamily; + textObj.fontSize = conf.noteFontSize; + textObj.fontWeight = conf.noteFontWeight; + textObj.anchor = conf.noteAlign; + textObj.textMargin = conf.noteMargin; + textObj.valign = "center"; + const textElem = hasKatex(textObj.text) ? await drawKatex(g, textObj) : drawText(g, textObj); + const textHeight = Math.round( + textElem.map((te) => (te._groups || te)[0][0].getBBox().height).reduce((acc, curr) => acc + curr) + ); + rectElem.attr("height", textHeight + 2 * conf.noteMargin); + noteModel.height += textHeight + 2 * conf.noteMargin; + bounds.bumpVerticalPos(textHeight + 2 * conf.noteMargin); + noteModel.stopy = noteModel.starty + textHeight + 2 * conf.noteMargin; + noteModel.stopx = noteModel.startx + rect.width; + bounds.insert(noteModel.startx, noteModel.starty, noteModel.stopx, noteModel.stopy); + bounds.models.addNote(noteModel); +}; +const messageFont = (cnf) => { + return { + fontFamily: cnf.messageFontFamily, + fontSize: cnf.messageFontSize, + fontWeight: cnf.messageFontWeight + }; +}; +const noteFont = (cnf) => { + return { + fontFamily: cnf.noteFontFamily, + fontSize: cnf.noteFontSize, + fontWeight: cnf.noteFontWeight + }; +}; +const actorFont = (cnf) => { + return { + fontFamily: cnf.actorFontFamily, + fontSize: cnf.actorFontSize, + fontWeight: cnf.actorFontWeight + }; +}; +async function boundMessage(_diagram, msgModel) { + bounds.bumpVerticalPos(10); + const { startx, stopx, message } = msgModel; + const lines = common.splitBreaks(message).length; + const isKatexMsg = hasKatex(message); + const textDims = isKatexMsg ? await calculateMathMLDimensions(message, getConfig()) : utils.calculateTextDimensions(message, messageFont(conf)); + if (!isKatexMsg) { + const lineHeight = textDims.height / lines; + msgModel.height += lineHeight; + bounds.bumpVerticalPos(lineHeight); + } + let lineStartY; + let totalOffset = textDims.height - 10; + const textWidth = textDims.width; + if (startx === stopx) { + lineStartY = bounds.getVerticalPos() + totalOffset; + if (!conf.rightAngles) { + totalOffset += conf.boxMargin; + lineStartY = bounds.getVerticalPos() + totalOffset; + } + totalOffset += 30; + const dx = common.getMax(textWidth / 2, conf.width / 2); + bounds.insert( + startx - dx, + bounds.getVerticalPos() - 10 + totalOffset, + stopx + dx, + bounds.getVerticalPos() + 30 + totalOffset + ); + } else { + totalOffset += conf.boxMargin; + lineStartY = bounds.getVerticalPos() + totalOffset; + bounds.insert(startx, lineStartY - 10, stopx, lineStartY); + } + bounds.bumpVerticalPos(totalOffset); + msgModel.height += totalOffset; + msgModel.stopy = msgModel.starty + msgModel.height; + bounds.insert(msgModel.fromBounds, msgModel.starty, msgModel.toBounds, msgModel.stopy); + return lineStartY; +} +const drawMessage = async function(diagram2, msgModel, lineStartY, diagObj) { + const { startx, stopx, starty, message, type, sequenceIndex, sequenceVisible } = msgModel; + const textDims = utils.calculateTextDimensions(message, messageFont(conf)); + const textObj = getTextObj$1(); + textObj.x = startx; + textObj.y = starty + 10; + textObj.width = stopx - startx; + textObj.class = "messageText"; + textObj.dy = "1em"; + textObj.text = message; + textObj.fontFamily = conf.messageFontFamily; + textObj.fontSize = conf.messageFontSize; + textObj.fontWeight = conf.messageFontWeight; + textObj.anchor = conf.messageAlign; + textObj.valign = "center"; + textObj.textMargin = conf.wrapPadding; + textObj.tspan = false; + hasKatex(textObj.text) ? await drawKatex(diagram2, textObj, { startx, stopx, starty: lineStartY }) : drawText(diagram2, textObj); + const textWidth = textDims.width; + let line; + if (startx === stopx) { + if (conf.rightAngles) { + line = diagram2.append("path").attr( + "d", + `M ${startx},${lineStartY} H ${startx + common.getMax(conf.width / 2, textWidth / 2)} V ${lineStartY + 25} H ${startx}` + ); + } else { + line = diagram2.append("path").attr( + "d", + "M " + startx + "," + lineStartY + " C " + (startx + 60) + "," + (lineStartY - 10) + " " + (startx + 60) + "," + (lineStartY + 30) + " " + startx + "," + (lineStartY + 20) + ); + } + } else { + line = diagram2.append("line"); + line.attr("x1", startx); + line.attr("y1", lineStartY); + line.attr("x2", stopx); + line.attr("y2", lineStartY); + } + if (type === diagObj.db.LINETYPE.DOTTED || type === diagObj.db.LINETYPE.DOTTED_CROSS || type === diagObj.db.LINETYPE.DOTTED_POINT || type === diagObj.db.LINETYPE.DOTTED_OPEN) { + line.style("stroke-dasharray", "3, 3"); + line.attr("class", "messageLine1"); + } else { + line.attr("class", "messageLine0"); + } + let url = ""; + if (conf.arrowMarkerAbsolute) { + url = window.location.protocol + "//" + window.location.host + window.location.pathname + window.location.search; + url = url.replace(/\(/g, "\\("); + url = url.replace(/\)/g, "\\)"); + } + line.attr("stroke-width", 2); + line.attr("stroke", "none"); + line.style("fill", "none"); + if (type === diagObj.db.LINETYPE.SOLID || type === diagObj.db.LINETYPE.DOTTED) { + line.attr("marker-end", "url(" + url + "#arrowhead)"); + } + if (type === diagObj.db.LINETYPE.SOLID_POINT || type === diagObj.db.LINETYPE.DOTTED_POINT) { + line.attr("marker-end", "url(" + url + "#filled-head)"); + } + if (type === diagObj.db.LINETYPE.SOLID_CROSS || type === diagObj.db.LINETYPE.DOTTED_CROSS) { + line.attr("marker-end", "url(" + url + "#crosshead)"); + } + if (sequenceVisible || conf.showSequenceNumbers) { + line.attr("marker-start", "url(" + url + "#sequencenumber)"); + diagram2.append("text").attr("x", startx).attr("y", lineStartY + 4).attr("font-family", "sans-serif").attr("font-size", "12px").attr("text-anchor", "middle").attr("class", "sequenceNumber").text(sequenceIndex); + } +}; +const addActorRenderingData = async function(diagram2, actors, createdActors, actorKeys, verticalPos, messages, isFooter) { + let prevWidth = 0; + let prevMargin = 0; + let prevBox = void 0; + let maxHeight = 0; + for (const actorKey of actorKeys) { + const actor = actors[actorKey]; + const box = actor.box; + if (prevBox && prevBox != box) { + if (!isFooter) { + bounds.models.addBox(prevBox); + } + prevMargin += conf.boxMargin + prevBox.margin; + } + if (box && box != prevBox) { + if (!isFooter) { + box.x = prevWidth + prevMargin; + box.y = verticalPos; + } + prevMargin += box.margin; + } + actor.width = actor.width || conf.width; + actor.height = common.getMax(actor.height || conf.height, conf.height); + actor.margin = actor.margin || conf.actorMargin; + maxHeight = common.getMax(maxHeight, actor.height); + if (createdActors[actor.name]) { + prevMargin += actor.width / 2; + } + actor.x = prevWidth + prevMargin; + actor.starty = bounds.getVerticalPos(); + bounds.insert(actor.x, verticalPos, actor.x + actor.width, actor.height); + prevWidth += actor.width + prevMargin; + if (actor.box) { + actor.box.width = prevWidth + box.margin - actor.box.x; + } + prevMargin = actor.margin; + prevBox = actor.box; + bounds.models.addActor(actor); + } + if (prevBox && !isFooter) { + bounds.models.addBox(prevBox); + } + bounds.bumpVerticalPos(maxHeight); +}; +const drawActors = async function(diagram2, actors, actorKeys, isFooter) { + if (!isFooter) { + for (const actorKey of actorKeys) { + const actor = actors[actorKey]; + await svgDraw.drawActor(diagram2, actor, conf, false); + } + } else { + let maxHeight = 0; + bounds.bumpVerticalPos(conf.boxMargin * 2); + for (const actorKey of actorKeys) { + const actor = actors[actorKey]; + if (!actor.stopy) { + actor.stopy = bounds.getVerticalPos(); + } + const height = await svgDraw.drawActor(diagram2, actor, conf, true); + maxHeight = common.getMax(maxHeight, height); + } + bounds.bumpVerticalPos(maxHeight + conf.boxMargin); + } +}; +const drawActorsPopup = function(diagram2, actors, actorKeys, doc) { + let maxHeight = 0; + let maxWidth = 0; + for (const actorKey of actorKeys) { + const actor = actors[actorKey]; + const minMenuWidth = getRequiredPopupWidth(actor); + const menuDimensions = svgDraw.drawPopup( + diagram2, + actor, + minMenuWidth, + conf, + conf.forceMenus, + doc + ); + if (menuDimensions.height > maxHeight) { + maxHeight = menuDimensions.height; + } + if (menuDimensions.width + actor.x > maxWidth) { + maxWidth = menuDimensions.width + actor.x; + } + } + return { maxHeight, maxWidth }; +}; +const setConf = function(cnf) { + assignWithDepth(conf, cnf); + if (cnf.fontFamily) { + conf.actorFontFamily = conf.noteFontFamily = conf.messageFontFamily = cnf.fontFamily; + } + if (cnf.fontSize) { + conf.actorFontSize = conf.noteFontSize = conf.messageFontSize = cnf.fontSize; + } + if (cnf.fontWeight) { + conf.actorFontWeight = conf.noteFontWeight = conf.messageFontWeight = cnf.fontWeight; + } +}; +const actorActivations = function(actor) { + return bounds.activations.filter(function(activation) { + return activation.actor === actor; + }); +}; +const activationBounds = function(actor, actors) { + const actorObj = actors[actor]; + const activations = actorActivations(actor); + const left = activations.reduce(function(acc, activation) { + return common.getMin(acc, activation.startx); + }, actorObj.x + actorObj.width / 2 - 1); + const right = activations.reduce(function(acc, activation) { + return common.getMax(acc, activation.stopx); + }, actorObj.x + actorObj.width / 2 + 1); + return [left, right]; +}; +function adjustLoopHeightForWrap(loopWidths, msg, preMargin, postMargin, addLoopFn) { + bounds.bumpVerticalPos(preMargin); + let heightAdjust = postMargin; + if (msg.id && msg.message && loopWidths[msg.id]) { + const loopWidth = loopWidths[msg.id].width; + const textConf = messageFont(conf); + msg.message = utils.wrapLabel(`[${msg.message}]`, loopWidth - 2 * conf.wrapPadding, textConf); + msg.width = loopWidth; + msg.wrap = true; + const textDims = utils.calculateTextDimensions(msg.message, textConf); + const totalOffset = common.getMax(textDims.height, conf.labelBoxHeight); + heightAdjust = postMargin + totalOffset; + log.debug(`${totalOffset} - ${msg.message}`); + } + addLoopFn(msg); + bounds.bumpVerticalPos(heightAdjust); +} +function adjustCreatedDestroyedData(msg, msgModel, lineStartY, index, actors, createdActors, destroyedActors) { + function receiverAdjustment(actor, adjustment) { + if (actor.x < actors[msg.from].x) { + bounds.insert( + msgModel.stopx - adjustment, + msgModel.starty, + msgModel.startx, + msgModel.stopy + actor.height / 2 + conf.noteMargin + ); + msgModel.stopx = msgModel.stopx + adjustment; + } else { + bounds.insert( + msgModel.startx, + msgModel.starty, + msgModel.stopx + adjustment, + msgModel.stopy + actor.height / 2 + conf.noteMargin + ); + msgModel.stopx = msgModel.stopx - adjustment; + } + } + function senderAdjustment(actor, adjustment) { + if (actor.x < actors[msg.to].x) { + bounds.insert( + msgModel.startx - adjustment, + msgModel.starty, + msgModel.stopx, + msgModel.stopy + actor.height / 2 + conf.noteMargin + ); + msgModel.startx = msgModel.startx + adjustment; + } else { + bounds.insert( + msgModel.stopx, + msgModel.starty, + msgModel.startx + adjustment, + msgModel.stopy + actor.height / 2 + conf.noteMargin + ); + msgModel.startx = msgModel.startx - adjustment; + } + } + if (createdActors[msg.to] == index) { + const actor = actors[msg.to]; + const adjustment = actor.type == "actor" ? ACTOR_TYPE_WIDTH / 2 + 3 : actor.width / 2 + 3; + receiverAdjustment(actor, adjustment); + actor.starty = lineStartY - actor.height / 2; + bounds.bumpVerticalPos(actor.height / 2); + } else if (destroyedActors[msg.from] == index) { + const actor = actors[msg.from]; + if (conf.mirrorActors) { + const adjustment = actor.type == "actor" ? ACTOR_TYPE_WIDTH / 2 : actor.width / 2; + senderAdjustment(actor, adjustment); + } + actor.stopy = lineStartY - actor.height / 2; + bounds.bumpVerticalPos(actor.height / 2); + } else if (destroyedActors[msg.to] == index) { + const actor = actors[msg.to]; + if (conf.mirrorActors) { + const adjustment = actor.type == "actor" ? ACTOR_TYPE_WIDTH / 2 + 3 : actor.width / 2 + 3; + receiverAdjustment(actor, adjustment); + } + actor.stopy = lineStartY - actor.height / 2; + bounds.bumpVerticalPos(actor.height / 2); + } +} +const draw = async function(_text, id, _version, diagObj) { + const { securityLevel, sequence } = getConfig(); + conf = sequence; + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = select("#i" + id); + } + const root = securityLevel === "sandbox" ? select(sandboxElement.nodes()[0].contentDocument.body) : select("body"); + const doc = securityLevel === "sandbox" ? sandboxElement.nodes()[0].contentDocument : document; + bounds.init(); + log.debug(diagObj.db); + const diagram2 = securityLevel === "sandbox" ? root.select(`[id="${id}"]`) : select(`[id="${id}"]`); + const actors = diagObj.db.getActors(); + const createdActors = diagObj.db.getCreatedActors(); + const destroyedActors = diagObj.db.getDestroyedActors(); + const boxes = diagObj.db.getBoxes(); + let actorKeys = diagObj.db.getActorKeys(); + const messages = diagObj.db.getMessages(); + const title = diagObj.db.getDiagramTitle(); + const hasBoxes = diagObj.db.hasAtLeastOneBox(); + const hasBoxTitles = diagObj.db.hasAtLeastOneBoxWithTitle(); + const maxMessageWidthPerActor = await getMaxMessageWidthPerActor(actors, messages, diagObj); + conf.height = await calculateActorMargins(actors, maxMessageWidthPerActor, boxes); + svgDraw.insertComputerIcon(diagram2); + svgDraw.insertDatabaseIcon(diagram2); + svgDraw.insertClockIcon(diagram2); + if (hasBoxes) { + bounds.bumpVerticalPos(conf.boxMargin); + if (hasBoxTitles) { + bounds.bumpVerticalPos(boxes[0].textMaxHeight); + } + } + if (conf.hideUnusedParticipants === true) { + const newActors = /* @__PURE__ */ new Set(); + messages.forEach((message) => { + newActors.add(message.from); + newActors.add(message.to); + }); + actorKeys = actorKeys.filter((actorKey) => newActors.has(actorKey)); + } + await addActorRenderingData(diagram2, actors, createdActors, actorKeys, 0, messages, false); + const loopWidths = await calculateLoopBounds(messages, actors, maxMessageWidthPerActor, diagObj); + svgDraw.insertArrowHead(diagram2); + svgDraw.insertArrowCrossHead(diagram2); + svgDraw.insertArrowFilledHead(diagram2); + svgDraw.insertSequenceNumber(diagram2); + function activeEnd(msg, verticalPos) { + const activationData = bounds.endActivation(msg); + if (activationData.starty + 18 > verticalPos) { + activationData.starty = verticalPos - 6; + verticalPos += 12; + } + svgDraw.drawActivation( + diagram2, + activationData, + verticalPos, + conf, + actorActivations(msg.from.actor).length + ); + bounds.insert(activationData.startx, verticalPos - 10, activationData.stopx, verticalPos); + } + let sequenceIndex = 1; + let sequenceIndexStep = 1; + const messagesToDraw = []; + const backgrounds = []; + let index = 0; + for (const msg of messages) { + let loopModel, noteModel, msgModel; + switch (msg.type) { + case diagObj.db.LINETYPE.NOTE: + bounds.resetVerticalPos(); + noteModel = msg.noteModel; + await drawNote(diagram2, noteModel); + break; + case diagObj.db.LINETYPE.ACTIVE_START: + bounds.newActivation(msg, diagram2, actors); + break; + case diagObj.db.LINETYPE.ACTIVE_END: + activeEnd(msg, bounds.getVerticalPos()); + break; + case diagObj.db.LINETYPE.LOOP_START: + adjustLoopHeightForWrap( + loopWidths, + msg, + conf.boxMargin, + conf.boxMargin + conf.boxTextMargin, + (message) => bounds.newLoop(message) + ); + break; + case diagObj.db.LINETYPE.LOOP_END: + loopModel = bounds.endLoop(); + await svgDraw.drawLoop(diagram2, loopModel, "loop", conf); + bounds.bumpVerticalPos(loopModel.stopy - bounds.getVerticalPos()); + bounds.models.addLoop(loopModel); + break; + case diagObj.db.LINETYPE.RECT_START: + adjustLoopHeightForWrap( + loopWidths, + msg, + conf.boxMargin, + conf.boxMargin, + (message) => bounds.newLoop(void 0, message.message) + ); + break; + case diagObj.db.LINETYPE.RECT_END: + loopModel = bounds.endLoop(); + backgrounds.push(loopModel); + bounds.models.addLoop(loopModel); + bounds.bumpVerticalPos(loopModel.stopy - bounds.getVerticalPos()); + break; + case diagObj.db.LINETYPE.OPT_START: + adjustLoopHeightForWrap( + loopWidths, + msg, + conf.boxMargin, + conf.boxMargin + conf.boxTextMargin, + (message) => bounds.newLoop(message) + ); + break; + case diagObj.db.LINETYPE.OPT_END: + loopModel = bounds.endLoop(); + await svgDraw.drawLoop(diagram2, loopModel, "opt", conf); + bounds.bumpVerticalPos(loopModel.stopy - bounds.getVerticalPos()); + bounds.models.addLoop(loopModel); + break; + case diagObj.db.LINETYPE.ALT_START: + adjustLoopHeightForWrap( + loopWidths, + msg, + conf.boxMargin, + conf.boxMargin + conf.boxTextMargin, + (message) => bounds.newLoop(message) + ); + break; + case diagObj.db.LINETYPE.ALT_ELSE: + adjustLoopHeightForWrap( + loopWidths, + msg, + conf.boxMargin + conf.boxTextMargin, + conf.boxMargin, + (message) => bounds.addSectionToLoop(message) + ); + break; + case diagObj.db.LINETYPE.ALT_END: + loopModel = bounds.endLoop(); + await svgDraw.drawLoop(diagram2, loopModel, "alt", conf); + bounds.bumpVerticalPos(loopModel.stopy - bounds.getVerticalPos()); + bounds.models.addLoop(loopModel); + break; + case diagObj.db.LINETYPE.PAR_START: + case diagObj.db.LINETYPE.PAR_OVER_START: + adjustLoopHeightForWrap( + loopWidths, + msg, + conf.boxMargin, + conf.boxMargin + conf.boxTextMargin, + (message) => bounds.newLoop(message) + ); + bounds.saveVerticalPos(); + break; + case diagObj.db.LINETYPE.PAR_AND: + adjustLoopHeightForWrap( + loopWidths, + msg, + conf.boxMargin + conf.boxTextMargin, + conf.boxMargin, + (message) => bounds.addSectionToLoop(message) + ); + break; + case diagObj.db.LINETYPE.PAR_END: + loopModel = bounds.endLoop(); + await svgDraw.drawLoop(diagram2, loopModel, "par", conf); + bounds.bumpVerticalPos(loopModel.stopy - bounds.getVerticalPos()); + bounds.models.addLoop(loopModel); + break; + case diagObj.db.LINETYPE.AUTONUMBER: + sequenceIndex = msg.message.start || sequenceIndex; + sequenceIndexStep = msg.message.step || sequenceIndexStep; + if (msg.message.visible) { + diagObj.db.enableSequenceNumbers(); + } else { + diagObj.db.disableSequenceNumbers(); + } + break; + case diagObj.db.LINETYPE.CRITICAL_START: + adjustLoopHeightForWrap( + loopWidths, + msg, + conf.boxMargin, + conf.boxMargin + conf.boxTextMargin, + (message) => bounds.newLoop(message) + ); + break; + case diagObj.db.LINETYPE.CRITICAL_OPTION: + adjustLoopHeightForWrap( + loopWidths, + msg, + conf.boxMargin + conf.boxTextMargin, + conf.boxMargin, + (message) => bounds.addSectionToLoop(message) + ); + break; + case diagObj.db.LINETYPE.CRITICAL_END: + loopModel = bounds.endLoop(); + await svgDraw.drawLoop(diagram2, loopModel, "critical", conf); + bounds.bumpVerticalPos(loopModel.stopy - bounds.getVerticalPos()); + bounds.models.addLoop(loopModel); + break; + case diagObj.db.LINETYPE.BREAK_START: + adjustLoopHeightForWrap( + loopWidths, + msg, + conf.boxMargin, + conf.boxMargin + conf.boxTextMargin, + (message) => bounds.newLoop(message) + ); + break; + case diagObj.db.LINETYPE.BREAK_END: + loopModel = bounds.endLoop(); + await svgDraw.drawLoop(diagram2, loopModel, "break", conf); + bounds.bumpVerticalPos(loopModel.stopy - bounds.getVerticalPos()); + bounds.models.addLoop(loopModel); + break; + default: + try { + msgModel = msg.msgModel; + msgModel.starty = bounds.getVerticalPos(); + msgModel.sequenceIndex = sequenceIndex; + msgModel.sequenceVisible = diagObj.db.showSequenceNumbers(); + const lineStartY = await boundMessage(diagram2, msgModel); + adjustCreatedDestroyedData( + msg, + msgModel, + lineStartY, + index, + actors, + createdActors, + destroyedActors + ); + messagesToDraw.push({ messageModel: msgModel, lineStartY }); + bounds.models.addMessage(msgModel); + } catch (e) { + log.error("error while drawing message", e); + } + } + if ([ + diagObj.db.LINETYPE.SOLID_OPEN, + diagObj.db.LINETYPE.DOTTED_OPEN, + diagObj.db.LINETYPE.SOLID, + diagObj.db.LINETYPE.DOTTED, + diagObj.db.LINETYPE.SOLID_CROSS, + diagObj.db.LINETYPE.DOTTED_CROSS, + diagObj.db.LINETYPE.SOLID_POINT, + diagObj.db.LINETYPE.DOTTED_POINT + ].includes(msg.type)) { + sequenceIndex = sequenceIndex + sequenceIndexStep; + } + index++; + } + log.debug("createdActors", createdActors); + log.debug("destroyedActors", destroyedActors); + await drawActors(diagram2, actors, actorKeys, false); + for (const e of messagesToDraw) { + await drawMessage(diagram2, e.messageModel, e.lineStartY, diagObj); + } + if (conf.mirrorActors) { + await drawActors(diagram2, actors, actorKeys, true); + } + backgrounds.forEach((e) => svgDraw.drawBackgroundRect(diagram2, e)); + fixLifeLineHeights(diagram2, actors, actorKeys, conf); + for (const box2 of bounds.models.boxes) { + box2.height = bounds.getVerticalPos() - box2.y; + bounds.insert(box2.x, box2.y, box2.x + box2.width, box2.height); + box2.startx = box2.x; + box2.starty = box2.y; + box2.stopx = box2.startx + box2.width; + box2.stopy = box2.starty + box2.height; + box2.stroke = "rgb(0,0,0, 0.5)"; + await svgDraw.drawBox(diagram2, box2, conf); + } + if (hasBoxes) { + bounds.bumpVerticalPos(conf.boxMargin); + } + const requiredBoxSize = drawActorsPopup(diagram2, actors, actorKeys, doc); + const { bounds: box } = bounds.getBounds(); + let boxHeight = box.stopy - box.starty; + if (boxHeight < requiredBoxSize.maxHeight) { + boxHeight = requiredBoxSize.maxHeight; + } + let height = boxHeight + 2 * conf.diagramMarginY; + if (conf.mirrorActors) { + height = height - conf.boxMargin + conf.bottomMarginAdj; + } + let boxWidth = box.stopx - box.startx; + if (boxWidth < requiredBoxSize.maxWidth) { + boxWidth = requiredBoxSize.maxWidth; + } + const width = boxWidth + 2 * conf.diagramMarginX; + if (title) { + diagram2.append("text").text(title).attr("x", (box.stopx - box.startx) / 2 - 2 * conf.diagramMarginX).attr("y", -25); + } + configureSvgSize(diagram2, height, width, conf.useMaxWidth); + const extraVertForTitle = title ? 40 : 0; + diagram2.attr( + "viewBox", + box.startx - conf.diagramMarginX + " -" + (conf.diagramMarginY + extraVertForTitle) + " " + width + " " + (height + extraVertForTitle) + ); + log.debug(`models:`, bounds.models); +}; +async function getMaxMessageWidthPerActor(actors, messages, diagObj) { + const maxMessageWidthPerActor = {}; + for (const msg of messages) { + if (actors[msg.to] && actors[msg.from]) { + const actor = actors[msg.to]; + if (msg.placement === diagObj.db.PLACEMENT.LEFTOF && !actor.prevActor) { + continue; + } + if (msg.placement === diagObj.db.PLACEMENT.RIGHTOF && !actor.nextActor) { + continue; + } + const isNote = msg.placement !== void 0; + const isMessage = !isNote; + const textFont = isNote ? noteFont(conf) : messageFont(conf); + const wrappedMessage = msg.wrap ? utils.wrapLabel(msg.message, conf.width - 2 * conf.wrapPadding, textFont) : msg.message; + const messageDimensions = hasKatex(wrappedMessage) ? await calculateMathMLDimensions(msg.message, getConfig()) : utils.calculateTextDimensions(wrappedMessage, textFont); + const messageWidth = messageDimensions.width + 2 * conf.wrapPadding; + if (isMessage && msg.from === actor.nextActor) { + maxMessageWidthPerActor[msg.to] = common.getMax( + maxMessageWidthPerActor[msg.to] || 0, + messageWidth + ); + } else if (isMessage && msg.from === actor.prevActor) { + maxMessageWidthPerActor[msg.from] = common.getMax( + maxMessageWidthPerActor[msg.from] || 0, + messageWidth + ); + } else if (isMessage && msg.from === msg.to) { + maxMessageWidthPerActor[msg.from] = common.getMax( + maxMessageWidthPerActor[msg.from] || 0, + messageWidth / 2 + ); + maxMessageWidthPerActor[msg.to] = common.getMax( + maxMessageWidthPerActor[msg.to] || 0, + messageWidth / 2 + ); + } else if (msg.placement === diagObj.db.PLACEMENT.RIGHTOF) { + maxMessageWidthPerActor[msg.from] = common.getMax( + maxMessageWidthPerActor[msg.from] || 0, + messageWidth + ); + } else if (msg.placement === diagObj.db.PLACEMENT.LEFTOF) { + maxMessageWidthPerActor[actor.prevActor] = common.getMax( + maxMessageWidthPerActor[actor.prevActor] || 0, + messageWidth + ); + } else if (msg.placement === diagObj.db.PLACEMENT.OVER) { + if (actor.prevActor) { + maxMessageWidthPerActor[actor.prevActor] = common.getMax( + maxMessageWidthPerActor[actor.prevActor] || 0, + messageWidth / 2 + ); + } + if (actor.nextActor) { + maxMessageWidthPerActor[msg.from] = common.getMax( + maxMessageWidthPerActor[msg.from] || 0, + messageWidth / 2 + ); + } + } + } + } + log.debug("maxMessageWidthPerActor:", maxMessageWidthPerActor); + return maxMessageWidthPerActor; +} +const getRequiredPopupWidth = function(actor) { + let requiredPopupWidth = 0; + const textFont = actorFont(conf); + for (const key in actor.links) { + const labelDimensions = utils.calculateTextDimensions(key, textFont); + const labelWidth = labelDimensions.width + 2 * conf.wrapPadding + 2 * conf.boxMargin; + if (requiredPopupWidth < labelWidth) { + requiredPopupWidth = labelWidth; + } + } + return requiredPopupWidth; +}; +async function calculateActorMargins(actors, actorToMessageWidth, boxes) { + let maxHeight = 0; + for (const prop of Object.keys(actors)) { + const actor = actors[prop]; + if (actor.wrap) { + actor.description = utils.wrapLabel( + actor.description, + conf.width - 2 * conf.wrapPadding, + actorFont(conf) + ); + } + const actDims = hasKatex(actor.description) ? await calculateMathMLDimensions(actor.description, getConfig()) : utils.calculateTextDimensions(actor.description, actorFont(conf)); + actor.width = actor.wrap ? conf.width : common.getMax(conf.width, actDims.width + 2 * conf.wrapPadding); + actor.height = actor.wrap ? common.getMax(actDims.height, conf.height) : conf.height; + maxHeight = common.getMax(maxHeight, actor.height); + } + for (const actorKey in actorToMessageWidth) { + const actor = actors[actorKey]; + if (!actor) { + continue; + } + const nextActor = actors[actor.nextActor]; + if (!nextActor) { + const messageWidth2 = actorToMessageWidth[actorKey]; + const actorWidth2 = messageWidth2 + conf.actorMargin - actor.width / 2; + actor.margin = common.getMax(actorWidth2, conf.actorMargin); + continue; + } + const messageWidth = actorToMessageWidth[actorKey]; + const actorWidth = messageWidth + conf.actorMargin - actor.width / 2 - nextActor.width / 2; + actor.margin = common.getMax(actorWidth, conf.actorMargin); + } + let maxBoxHeight = 0; + boxes.forEach((box) => { + const textFont = messageFont(conf); + let totalWidth = box.actorKeys.reduce((total, aKey) => { + return total += actors[aKey].width + (actors[aKey].margin || 0); + }, 0); + totalWidth -= 2 * conf.boxTextMargin; + if (box.wrap) { + box.name = utils.wrapLabel(box.name, totalWidth - 2 * conf.wrapPadding, textFont); + } + const boxMsgDimensions = utils.calculateTextDimensions(box.name, textFont); + maxBoxHeight = common.getMax(boxMsgDimensions.height, maxBoxHeight); + const minWidth = common.getMax(totalWidth, boxMsgDimensions.width + 2 * conf.wrapPadding); + box.margin = conf.boxTextMargin; + if (totalWidth < minWidth) { + const missing = (minWidth - totalWidth) / 2; + box.margin += missing; + } + }); + boxes.forEach((box) => box.textMaxHeight = maxBoxHeight); + return common.getMax(maxHeight, conf.height); +} +const buildNoteModel = async function(msg, actors, diagObj) { + const startx = actors[msg.from].x; + const stopx = actors[msg.to].x; + const shouldWrap = msg.wrap && msg.message; + let textDimensions = hasKatex(msg.message) ? await calculateMathMLDimensions(msg.message, getConfig()) : utils.calculateTextDimensions( + shouldWrap ? utils.wrapLabel(msg.message, conf.width, noteFont(conf)) : msg.message, + noteFont(conf) + ); + const noteModel = { + width: shouldWrap ? conf.width : common.getMax(conf.width, textDimensions.width + 2 * conf.noteMargin), + height: 0, + startx: actors[msg.from].x, + stopx: 0, + starty: 0, + stopy: 0, + message: msg.message + }; + if (msg.placement === diagObj.db.PLACEMENT.RIGHTOF) { + noteModel.width = shouldWrap ? common.getMax(conf.width, textDimensions.width) : common.getMax( + actors[msg.from].width / 2 + actors[msg.to].width / 2, + textDimensions.width + 2 * conf.noteMargin + ); + noteModel.startx = startx + (actors[msg.from].width + conf.actorMargin) / 2; + } else if (msg.placement === diagObj.db.PLACEMENT.LEFTOF) { + noteModel.width = shouldWrap ? common.getMax(conf.width, textDimensions.width + 2 * conf.noteMargin) : common.getMax( + actors[msg.from].width / 2 + actors[msg.to].width / 2, + textDimensions.width + 2 * conf.noteMargin + ); + noteModel.startx = startx - noteModel.width + (actors[msg.from].width - conf.actorMargin) / 2; + } else if (msg.to === msg.from) { + textDimensions = utils.calculateTextDimensions( + shouldWrap ? utils.wrapLabel( + msg.message, + common.getMax(conf.width, actors[msg.from].width), + noteFont(conf) + ) : msg.message, + noteFont(conf) + ); + noteModel.width = shouldWrap ? common.getMax(conf.width, actors[msg.from].width) : common.getMax( + actors[msg.from].width, + conf.width, + textDimensions.width + 2 * conf.noteMargin + ); + noteModel.startx = startx + (actors[msg.from].width - noteModel.width) / 2; + } else { + noteModel.width = Math.abs(startx + actors[msg.from].width / 2 - (stopx + actors[msg.to].width / 2)) + conf.actorMargin; + noteModel.startx = startx < stopx ? startx + actors[msg.from].width / 2 - conf.actorMargin / 2 : stopx + actors[msg.to].width / 2 - conf.actorMargin / 2; + } + if (shouldWrap) { + noteModel.message = utils.wrapLabel( + msg.message, + noteModel.width - 2 * conf.wrapPadding, + noteFont(conf) + ); + } + log.debug( + `NM:[${noteModel.startx},${noteModel.stopx},${noteModel.starty},${noteModel.stopy}:${noteModel.width},${noteModel.height}=${msg.message}]` + ); + return noteModel; +}; +const buildMessageModel = function(msg, actors, diagObj) { + if (![ + diagObj.db.LINETYPE.SOLID_OPEN, + diagObj.db.LINETYPE.DOTTED_OPEN, + diagObj.db.LINETYPE.SOLID, + diagObj.db.LINETYPE.DOTTED, + diagObj.db.LINETYPE.SOLID_CROSS, + diagObj.db.LINETYPE.DOTTED_CROSS, + diagObj.db.LINETYPE.SOLID_POINT, + diagObj.db.LINETYPE.DOTTED_POINT + ].includes(msg.type)) { + return {}; + } + const [fromLeft, fromRight] = activationBounds(msg.from, actors); + const [toLeft, toRight] = activationBounds(msg.to, actors); + const isArrowToRight = fromLeft <= toLeft; + const startx = isArrowToRight ? fromRight : fromLeft; + let stopx = isArrowToRight ? toLeft : toRight; + const isArrowToActivation = Math.abs(toLeft - toRight) > 2; + const adjustValue = (value) => { + return isArrowToRight ? -value : value; + }; + if (msg.from === msg.to) { + stopx = startx; + } else { + if (msg.activate && !isArrowToActivation) { + stopx += adjustValue(conf.activationWidth / 2 - 1); + } + if (![diagObj.db.LINETYPE.SOLID_OPEN, diagObj.db.LINETYPE.DOTTED_OPEN].includes(msg.type)) { + stopx += adjustValue(3); + } + } + const allBounds = [fromLeft, fromRight, toLeft, toRight]; + const boundedWidth = Math.abs(startx - stopx); + if (msg.wrap && msg.message) { + msg.message = utils.wrapLabel( + msg.message, + common.getMax(boundedWidth + 2 * conf.wrapPadding, conf.width), + messageFont(conf) + ); + } + const msgDims = utils.calculateTextDimensions(msg.message, messageFont(conf)); + return { + width: common.getMax( + msg.wrap ? 0 : msgDims.width + 2 * conf.wrapPadding, + boundedWidth + 2 * conf.wrapPadding, + conf.width + ), + height: 0, + startx, + stopx, + starty: 0, + stopy: 0, + message: msg.message, + type: msg.type, + wrap: msg.wrap, + fromBounds: Math.min.apply(null, allBounds), + toBounds: Math.max.apply(null, allBounds) + }; +}; +const calculateLoopBounds = async function(messages, actors, _maxWidthPerActor, diagObj) { + const loops = {}; + const stack = []; + let current, noteModel, msgModel; + for (const msg of messages) { + msg.id = utils.random({ length: 10 }); + switch (msg.type) { + case diagObj.db.LINETYPE.LOOP_START: + case diagObj.db.LINETYPE.ALT_START: + case diagObj.db.LINETYPE.OPT_START: + case diagObj.db.LINETYPE.PAR_START: + case diagObj.db.LINETYPE.PAR_OVER_START: + case diagObj.db.LINETYPE.CRITICAL_START: + case diagObj.db.LINETYPE.BREAK_START: + stack.push({ + id: msg.id, + msg: msg.message, + from: Number.MAX_SAFE_INTEGER, + to: Number.MIN_SAFE_INTEGER, + width: 0 + }); + break; + case diagObj.db.LINETYPE.ALT_ELSE: + case diagObj.db.LINETYPE.PAR_AND: + case diagObj.db.LINETYPE.CRITICAL_OPTION: + if (msg.message) { + current = stack.pop(); + loops[current.id] = current; + loops[msg.id] = current; + stack.push(current); + } + break; + case diagObj.db.LINETYPE.LOOP_END: + case diagObj.db.LINETYPE.ALT_END: + case diagObj.db.LINETYPE.OPT_END: + case diagObj.db.LINETYPE.PAR_END: + case diagObj.db.LINETYPE.CRITICAL_END: + case diagObj.db.LINETYPE.BREAK_END: + current = stack.pop(); + loops[current.id] = current; + break; + case diagObj.db.LINETYPE.ACTIVE_START: + { + const actorRect = actors[msg.from ? msg.from.actor : msg.to.actor]; + const stackedSize = actorActivations(msg.from ? msg.from.actor : msg.to.actor).length; + const x = actorRect.x + actorRect.width / 2 + (stackedSize - 1) * conf.activationWidth / 2; + const toAdd = { + startx: x, + stopx: x + conf.activationWidth, + actor: msg.from.actor, + enabled: true + }; + bounds.activations.push(toAdd); + } + break; + case diagObj.db.LINETYPE.ACTIVE_END: + { + const lastActorActivationIdx = bounds.activations.map((a) => a.actor).lastIndexOf(msg.from.actor); + delete bounds.activations.splice(lastActorActivationIdx, 1)[0]; + } + break; + } + const isNote = msg.placement !== void 0; + if (isNote) { + noteModel = await buildNoteModel(msg, actors, diagObj); + msg.noteModel = noteModel; + stack.forEach((stk) => { + current = stk; + current.from = common.getMin(current.from, noteModel.startx); + current.to = common.getMax(current.to, noteModel.startx + noteModel.width); + current.width = common.getMax(current.width, Math.abs(current.from - current.to)) - conf.labelBoxWidth; + }); + } else { + msgModel = buildMessageModel(msg, actors, diagObj); + msg.msgModel = msgModel; + if (msgModel.startx && msgModel.stopx && stack.length > 0) { + stack.forEach((stk) => { + current = stk; + if (msgModel.startx === msgModel.stopx) { + const from = actors[msg.from]; + const to = actors[msg.to]; + current.from = common.getMin( + from.x - msgModel.width / 2, + from.x - from.width / 2, + current.from + ); + current.to = common.getMax( + to.x + msgModel.width / 2, + to.x + from.width / 2, + current.to + ); + current.width = common.getMax(current.width, Math.abs(current.to - current.from)) - conf.labelBoxWidth; + } else { + current.from = common.getMin(msgModel.startx, current.from); + current.to = common.getMax(msgModel.stopx, current.to); + current.width = common.getMax(current.width, msgModel.width) - conf.labelBoxWidth; + } + }); + } + } + } + bounds.activations = []; + log.debug("Loop type widths:", loops); + return loops; +}; +const renderer = { + bounds, + drawActors, + drawActorsPopup, + setConf, + draw +}; +const diagram = { + parser: parser$1, + db, + renderer, + styles, + init: ({ wrap }) => { + db.setWrap(wrap); + } +}; +export { + diagram +}; diff --git a/0.6.0/js/mermaid/sequenceDiagram-9813c129.js b/0.6.0/js/mermaid/sequenceDiagram-9813c129.js new file mode 100644 index 0000000..75e7cff --- /dev/null +++ b/0.6.0/js/mermaid/sequenceDiagram-9813c129.js @@ -0,0 +1,3336 @@ +import { g as getAccTitle, D as getDiagramTitle, C as setDiagramTitle, c as getConfig, s as setAccTitle, b as setAccDescription, a as getAccDescription, E as clear$1, l as log, d as sanitizeText, e as dist, f as common, Y as parseFontSize, a4 as hasKatex, r as renderKatex, _ as getConfig$1, a5 as ZERO_WIDTH_SPACE, a6 as calculateMathMLDimensions, h as assignWithDepth, j as d3select, k as configureSvgSize, A as utils } from "./mermaid-dcacb631.js"; +import { d as drawRect$1, a as drawBackgroundRect$1, b as drawEmbeddedImage, c as drawImage, e as getTextObj$1, g as getNoteRect$1 } from "./svgDrawCommon-d6ab583c.js"; +var parser = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 2], $V1 = [1, 3], $V2 = [1, 4], $V3 = [2, 4], $V4 = [1, 9], $V5 = [1, 11], $V6 = [1, 13], $V7 = [1, 14], $V8 = [1, 16], $V9 = [1, 17], $Va = [1, 18], $Vb = [1, 24], $Vc = [1, 25], $Vd = [1, 26], $Ve = [1, 27], $Vf = [1, 28], $Vg = [1, 29], $Vh = [1, 30], $Vi = [1, 31], $Vj = [1, 32], $Vk = [1, 33], $Vl = [1, 34], $Vm = [1, 35], $Vn = [1, 36], $Vo = [1, 37], $Vp = [1, 38], $Vq = [1, 39], $Vr = [1, 41], $Vs = [1, 42], $Vt = [1, 43], $Vu = [1, 44], $Vv = [1, 45], $Vw = [1, 46], $Vx = [1, 4, 5, 13, 14, 16, 18, 21, 23, 29, 30, 31, 33, 35, 36, 37, 38, 39, 41, 43, 44, 46, 47, 48, 49, 50, 52, 53, 54, 59, 60, 61, 62, 70], $Vy = [4, 5, 16, 50, 52, 53], $Vz = [4, 5, 13, 14, 16, 18, 21, 23, 29, 30, 31, 33, 35, 36, 37, 38, 39, 41, 43, 44, 46, 50, 52, 53, 54, 59, 60, 61, 62, 70], $VA = [4, 5, 13, 14, 16, 18, 21, 23, 29, 30, 31, 33, 35, 36, 37, 38, 39, 41, 43, 44, 46, 49, 50, 52, 53, 54, 59, 60, 61, 62, 70], $VB = [4, 5, 13, 14, 16, 18, 21, 23, 29, 30, 31, 33, 35, 36, 37, 38, 39, 41, 43, 44, 46, 48, 50, 52, 53, 54, 59, 60, 61, 62, 70], $VC = [4, 5, 13, 14, 16, 18, 21, 23, 29, 30, 31, 33, 35, 36, 37, 38, 39, 41, 43, 44, 46, 47, 50, 52, 53, 54, 59, 60, 61, 62, 70], $VD = [68, 69, 70], $VE = [1, 120]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "SPACE": 4, "NEWLINE": 5, "SD": 6, "document": 7, "line": 8, "statement": 9, "box_section": 10, "box_line": 11, "participant_statement": 12, "create": 13, "box": 14, "restOfLine": 15, "end": 16, "signal": 17, "autonumber": 18, "NUM": 19, "off": 20, "activate": 21, "actor": 22, "deactivate": 23, "note_statement": 24, "links_statement": 25, "link_statement": 26, "properties_statement": 27, "details_statement": 28, "title": 29, "legacy_title": 30, "acc_title": 31, "acc_title_value": 32, "acc_descr": 33, "acc_descr_value": 34, "acc_descr_multiline_value": 35, "loop": 36, "rect": 37, "opt": 38, "alt": 39, "else_sections": 40, "par": 41, "par_sections": 42, "par_over": 43, "critical": 44, "option_sections": 45, "break": 46, "option": 47, "and": 48, "else": 49, "participant": 50, "AS": 51, "participant_actor": 52, "destroy": 53, "note": 54, "placement": 55, "text2": 56, "over": 57, "actor_pair": 58, "links": 59, "link": 60, "properties": 61, "details": 62, "spaceList": 63, ",": 64, "left_of": 65, "right_of": 66, "signaltype": 67, "+": 68, "-": 69, "ACTOR": 70, "SOLID_OPEN_ARROW": 71, "DOTTED_OPEN_ARROW": 72, "SOLID_ARROW": 73, "DOTTED_ARROW": 74, "SOLID_CROSS": 75, "DOTTED_CROSS": 76, "SOLID_POINT": 77, "DOTTED_POINT": 78, "TXT": 79, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 4: "SPACE", 5: "NEWLINE", 6: "SD", 13: "create", 14: "box", 15: "restOfLine", 16: "end", 18: "autonumber", 19: "NUM", 20: "off", 21: "activate", 23: "deactivate", 29: "title", 30: "legacy_title", 31: "acc_title", 32: "acc_title_value", 33: "acc_descr", 34: "acc_descr_value", 35: "acc_descr_multiline_value", 36: "loop", 37: "rect", 38: "opt", 39: "alt", 41: "par", 43: "par_over", 44: "critical", 46: "break", 47: "option", 48: "and", 49: "else", 50: "participant", 51: "AS", 52: "participant_actor", 53: "destroy", 54: "note", 57: "over", 59: "links", 60: "link", 61: "properties", 62: "details", 64: ",", 65: "left_of", 66: "right_of", 68: "+", 69: "-", 70: "ACTOR", 71: "SOLID_OPEN_ARROW", 72: "DOTTED_OPEN_ARROW", 73: "SOLID_ARROW", 74: "DOTTED_ARROW", 75: "SOLID_CROSS", 76: "DOTTED_CROSS", 77: "SOLID_POINT", 78: "DOTTED_POINT", 79: "TXT" }, + productions_: [0, [3, 2], [3, 2], [3, 2], [7, 0], [7, 2], [8, 2], [8, 1], [8, 1], [10, 0], [10, 2], [11, 2], [11, 1], [11, 1], [9, 1], [9, 2], [9, 4], [9, 2], [9, 4], [9, 3], [9, 3], [9, 2], [9, 3], [9, 3], [9, 2], [9, 2], [9, 2], [9, 2], [9, 2], [9, 1], [9, 1], [9, 2], [9, 2], [9, 1], [9, 4], [9, 4], [9, 4], [9, 4], [9, 4], [9, 4], [9, 4], [9, 4], [45, 1], [45, 4], [42, 1], [42, 4], [40, 1], [40, 4], [12, 5], [12, 3], [12, 5], [12, 3], [12, 3], [24, 4], [24, 4], [25, 3], [26, 3], [27, 3], [28, 3], [63, 2], [63, 1], [58, 3], [58, 1], [55, 1], [55, 1], [17, 5], [17, 5], [17, 4], [22, 1], [67, 1], [67, 1], [67, 1], [67, 1], [67, 1], [67, 1], [67, 1], [67, 1], [56, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 3: + yy.apply($$[$0]); + return $$[$0]; + case 4: + case 9: + this.$ = []; + break; + case 5: + case 10: + $$[$0 - 1].push($$[$0]); + this.$ = $$[$0 - 1]; + break; + case 6: + case 7: + case 11: + case 12: + this.$ = $$[$0]; + break; + case 8: + case 13: + this.$ = []; + break; + case 15: + $$[$0].type = "createParticipant"; + this.$ = $$[$0]; + break; + case 16: + $$[$0 - 1].unshift({ type: "boxStart", boxData: yy.parseBoxData($$[$0 - 2]) }); + $$[$0 - 1].push({ type: "boxEnd", boxText: $$[$0 - 2] }); + this.$ = $$[$0 - 1]; + break; + case 18: + this.$ = { type: "sequenceIndex", sequenceIndex: Number($$[$0 - 2]), sequenceIndexStep: Number($$[$0 - 1]), sequenceVisible: true, signalType: yy.LINETYPE.AUTONUMBER }; + break; + case 19: + this.$ = { type: "sequenceIndex", sequenceIndex: Number($$[$0 - 1]), sequenceIndexStep: 1, sequenceVisible: true, signalType: yy.LINETYPE.AUTONUMBER }; + break; + case 20: + this.$ = { type: "sequenceIndex", sequenceVisible: false, signalType: yy.LINETYPE.AUTONUMBER }; + break; + case 21: + this.$ = { type: "sequenceIndex", sequenceVisible: true, signalType: yy.LINETYPE.AUTONUMBER }; + break; + case 22: + this.$ = { type: "activeStart", signalType: yy.LINETYPE.ACTIVE_START, actor: $$[$0 - 1] }; + break; + case 23: + this.$ = { type: "activeEnd", signalType: yy.LINETYPE.ACTIVE_END, actor: $$[$0 - 1] }; + break; + case 29: + yy.setDiagramTitle($$[$0].substring(6)); + this.$ = $$[$0].substring(6); + break; + case 30: + yy.setDiagramTitle($$[$0].substring(7)); + this.$ = $$[$0].substring(7); + break; + case 31: + this.$ = $$[$0].trim(); + yy.setAccTitle(this.$); + break; + case 32: + case 33: + this.$ = $$[$0].trim(); + yy.setAccDescription(this.$); + break; + case 34: + $$[$0 - 1].unshift({ type: "loopStart", loopText: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.LOOP_START }); + $$[$0 - 1].push({ type: "loopEnd", loopText: $$[$0 - 2], signalType: yy.LINETYPE.LOOP_END }); + this.$ = $$[$0 - 1]; + break; + case 35: + $$[$0 - 1].unshift({ type: "rectStart", color: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.RECT_START }); + $$[$0 - 1].push({ type: "rectEnd", color: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.RECT_END }); + this.$ = $$[$0 - 1]; + break; + case 36: + $$[$0 - 1].unshift({ type: "optStart", optText: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.OPT_START }); + $$[$0 - 1].push({ type: "optEnd", optText: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.OPT_END }); + this.$ = $$[$0 - 1]; + break; + case 37: + $$[$0 - 1].unshift({ type: "altStart", altText: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.ALT_START }); + $$[$0 - 1].push({ type: "altEnd", signalType: yy.LINETYPE.ALT_END }); + this.$ = $$[$0 - 1]; + break; + case 38: + $$[$0 - 1].unshift({ type: "parStart", parText: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.PAR_START }); + $$[$0 - 1].push({ type: "parEnd", signalType: yy.LINETYPE.PAR_END }); + this.$ = $$[$0 - 1]; + break; + case 39: + $$[$0 - 1].unshift({ type: "parStart", parText: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.PAR_OVER_START }); + $$[$0 - 1].push({ type: "parEnd", signalType: yy.LINETYPE.PAR_END }); + this.$ = $$[$0 - 1]; + break; + case 40: + $$[$0 - 1].unshift({ type: "criticalStart", criticalText: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.CRITICAL_START }); + $$[$0 - 1].push({ type: "criticalEnd", signalType: yy.LINETYPE.CRITICAL_END }); + this.$ = $$[$0 - 1]; + break; + case 41: + $$[$0 - 1].unshift({ type: "breakStart", breakText: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.BREAK_START }); + $$[$0 - 1].push({ type: "breakEnd", optText: yy.parseMessage($$[$0 - 2]), signalType: yy.LINETYPE.BREAK_END }); + this.$ = $$[$0 - 1]; + break; + case 43: + this.$ = $$[$0 - 3].concat([{ type: "option", optionText: yy.parseMessage($$[$0 - 1]), signalType: yy.LINETYPE.CRITICAL_OPTION }, $$[$0]]); + break; + case 45: + this.$ = $$[$0 - 3].concat([{ type: "and", parText: yy.parseMessage($$[$0 - 1]), signalType: yy.LINETYPE.PAR_AND }, $$[$0]]); + break; + case 47: + this.$ = $$[$0 - 3].concat([{ type: "else", altText: yy.parseMessage($$[$0 - 1]), signalType: yy.LINETYPE.ALT_ELSE }, $$[$0]]); + break; + case 48: + $$[$0 - 3].draw = "participant"; + $$[$0 - 3].type = "addParticipant"; + $$[$0 - 3].description = yy.parseMessage($$[$0 - 1]); + this.$ = $$[$0 - 3]; + break; + case 49: + $$[$0 - 1].draw = "participant"; + $$[$0 - 1].type = "addParticipant"; + this.$ = $$[$0 - 1]; + break; + case 50: + $$[$0 - 3].draw = "actor"; + $$[$0 - 3].type = "addParticipant"; + $$[$0 - 3].description = yy.parseMessage($$[$0 - 1]); + this.$ = $$[$0 - 3]; + break; + case 51: + $$[$0 - 1].draw = "actor"; + $$[$0 - 1].type = "addParticipant"; + this.$ = $$[$0 - 1]; + break; + case 52: + $$[$0 - 1].type = "destroyParticipant"; + this.$ = $$[$0 - 1]; + break; + case 53: + this.$ = [$$[$0 - 1], { type: "addNote", placement: $$[$0 - 2], actor: $$[$0 - 1].actor, text: $$[$0] }]; + break; + case 54: + $$[$0 - 2] = [].concat($$[$0 - 1], $$[$0 - 1]).slice(0, 2); + $$[$0 - 2][0] = $$[$0 - 2][0].actor; + $$[$0 - 2][1] = $$[$0 - 2][1].actor; + this.$ = [$$[$0 - 1], { type: "addNote", placement: yy.PLACEMENT.OVER, actor: $$[$0 - 2].slice(0, 2), text: $$[$0] }]; + break; + case 55: + this.$ = [$$[$0 - 1], { type: "addLinks", actor: $$[$0 - 1].actor, text: $$[$0] }]; + break; + case 56: + this.$ = [$$[$0 - 1], { type: "addALink", actor: $$[$0 - 1].actor, text: $$[$0] }]; + break; + case 57: + this.$ = [$$[$0 - 1], { type: "addProperties", actor: $$[$0 - 1].actor, text: $$[$0] }]; + break; + case 58: + this.$ = [$$[$0 - 1], { type: "addDetails", actor: $$[$0 - 1].actor, text: $$[$0] }]; + break; + case 61: + this.$ = [$$[$0 - 2], $$[$0]]; + break; + case 62: + this.$ = $$[$0]; + break; + case 63: + this.$ = yy.PLACEMENT.LEFTOF; + break; + case 64: + this.$ = yy.PLACEMENT.RIGHTOF; + break; + case 65: + this.$ = [ + $$[$0 - 4], + $$[$0 - 1], + { type: "addMessage", from: $$[$0 - 4].actor, to: $$[$0 - 1].actor, signalType: $$[$0 - 3], msg: $$[$0], activate: true }, + { type: "activeStart", signalType: yy.LINETYPE.ACTIVE_START, actor: $$[$0 - 1] } + ]; + break; + case 66: + this.$ = [ + $$[$0 - 4], + $$[$0 - 1], + { type: "addMessage", from: $$[$0 - 4].actor, to: $$[$0 - 1].actor, signalType: $$[$0 - 3], msg: $$[$0] }, + { type: "activeEnd", signalType: yy.LINETYPE.ACTIVE_END, actor: $$[$0 - 4] } + ]; + break; + case 67: + this.$ = [$$[$0 - 3], $$[$0 - 1], { type: "addMessage", from: $$[$0 - 3].actor, to: $$[$0 - 1].actor, signalType: $$[$0 - 2], msg: $$[$0] }]; + break; + case 68: + this.$ = { type: "addParticipant", actor: $$[$0] }; + break; + case 69: + this.$ = yy.LINETYPE.SOLID_OPEN; + break; + case 70: + this.$ = yy.LINETYPE.DOTTED_OPEN; + break; + case 71: + this.$ = yy.LINETYPE.SOLID; + break; + case 72: + this.$ = yy.LINETYPE.DOTTED; + break; + case 73: + this.$ = yy.LINETYPE.SOLID_CROSS; + break; + case 74: + this.$ = yy.LINETYPE.DOTTED_CROSS; + break; + case 75: + this.$ = yy.LINETYPE.SOLID_POINT; + break; + case 76: + this.$ = yy.LINETYPE.DOTTED_POINT; + break; + case 77: + this.$ = yy.parseMessage($$[$0].trim().substring(1)); + break; + } + }, + table: [{ 3: 1, 4: $V0, 5: $V1, 6: $V2 }, { 1: [3] }, { 3: 5, 4: $V0, 5: $V1, 6: $V2 }, { 3: 6, 4: $V0, 5: $V1, 6: $V2 }, o([1, 4, 5, 13, 14, 18, 21, 23, 29, 30, 31, 33, 35, 36, 37, 38, 39, 41, 43, 44, 46, 50, 52, 53, 54, 59, 60, 61, 62, 70], $V3, { 7: 7 }), { 1: [2, 1] }, { 1: [2, 2] }, { 1: [2, 3], 4: $V4, 5: $V5, 8: 8, 9: 10, 12: 12, 13: $V6, 14: $V7, 17: 15, 18: $V8, 21: $V9, 22: 40, 23: $Va, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: $Vb, 30: $Vc, 31: $Vd, 33: $Ve, 35: $Vf, 36: $Vg, 37: $Vh, 38: $Vi, 39: $Vj, 41: $Vk, 43: $Vl, 44: $Vm, 46: $Vn, 50: $Vo, 52: $Vp, 53: $Vq, 54: $Vr, 59: $Vs, 60: $Vt, 61: $Vu, 62: $Vv, 70: $Vw }, o($Vx, [2, 5]), { 9: 47, 12: 12, 13: $V6, 14: $V7, 17: 15, 18: $V8, 21: $V9, 22: 40, 23: $Va, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: $Vb, 30: $Vc, 31: $Vd, 33: $Ve, 35: $Vf, 36: $Vg, 37: $Vh, 38: $Vi, 39: $Vj, 41: $Vk, 43: $Vl, 44: $Vm, 46: $Vn, 50: $Vo, 52: $Vp, 53: $Vq, 54: $Vr, 59: $Vs, 60: $Vt, 61: $Vu, 62: $Vv, 70: $Vw }, o($Vx, [2, 7]), o($Vx, [2, 8]), o($Vx, [2, 14]), { 12: 48, 50: $Vo, 52: $Vp, 53: $Vq }, { 15: [1, 49] }, { 5: [1, 50] }, { 5: [1, 53], 19: [1, 51], 20: [1, 52] }, { 22: 54, 70: $Vw }, { 22: 55, 70: $Vw }, { 5: [1, 56] }, { 5: [1, 57] }, { 5: [1, 58] }, { 5: [1, 59] }, { 5: [1, 60] }, o($Vx, [2, 29]), o($Vx, [2, 30]), { 32: [1, 61] }, { 34: [1, 62] }, o($Vx, [2, 33]), { 15: [1, 63] }, { 15: [1, 64] }, { 15: [1, 65] }, { 15: [1, 66] }, { 15: [1, 67] }, { 15: [1, 68] }, { 15: [1, 69] }, { 15: [1, 70] }, { 22: 71, 70: $Vw }, { 22: 72, 70: $Vw }, { 22: 73, 70: $Vw }, { 67: 74, 71: [1, 75], 72: [1, 76], 73: [1, 77], 74: [1, 78], 75: [1, 79], 76: [1, 80], 77: [1, 81], 78: [1, 82] }, { 55: 83, 57: [1, 84], 65: [1, 85], 66: [1, 86] }, { 22: 87, 70: $Vw }, { 22: 88, 70: $Vw }, { 22: 89, 70: $Vw }, { 22: 90, 70: $Vw }, o([5, 51, 64, 71, 72, 73, 74, 75, 76, 77, 78, 79], [2, 68]), o($Vx, [2, 6]), o($Vx, [2, 15]), o($Vy, [2, 9], { 10: 91 }), o($Vx, [2, 17]), { 5: [1, 93], 19: [1, 92] }, { 5: [1, 94] }, o($Vx, [2, 21]), { 5: [1, 95] }, { 5: [1, 96] }, o($Vx, [2, 24]), o($Vx, [2, 25]), o($Vx, [2, 26]), o($Vx, [2, 27]), o($Vx, [2, 28]), o($Vx, [2, 31]), o($Vx, [2, 32]), o($Vz, $V3, { 7: 97 }), o($Vz, $V3, { 7: 98 }), o($Vz, $V3, { 7: 99 }), o($VA, $V3, { 40: 100, 7: 101 }), o($VB, $V3, { 42: 102, 7: 103 }), o($VB, $V3, { 7: 103, 42: 104 }), o($VC, $V3, { 45: 105, 7: 106 }), o($Vz, $V3, { 7: 107 }), { 5: [1, 109], 51: [1, 108] }, { 5: [1, 111], 51: [1, 110] }, { 5: [1, 112] }, { 22: 115, 68: [1, 113], 69: [1, 114], 70: $Vw }, o($VD, [2, 69]), o($VD, [2, 70]), o($VD, [2, 71]), o($VD, [2, 72]), o($VD, [2, 73]), o($VD, [2, 74]), o($VD, [2, 75]), o($VD, [2, 76]), { 22: 116, 70: $Vw }, { 22: 118, 58: 117, 70: $Vw }, { 70: [2, 63] }, { 70: [2, 64] }, { 56: 119, 79: $VE }, { 56: 121, 79: $VE }, { 56: 122, 79: $VE }, { 56: 123, 79: $VE }, { 4: [1, 126], 5: [1, 128], 11: 125, 12: 127, 16: [1, 124], 50: $Vo, 52: $Vp, 53: $Vq }, { 5: [1, 129] }, o($Vx, [2, 19]), o($Vx, [2, 20]), o($Vx, [2, 22]), o($Vx, [2, 23]), { 4: $V4, 5: $V5, 8: 8, 9: 10, 12: 12, 13: $V6, 14: $V7, 16: [1, 130], 17: 15, 18: $V8, 21: $V9, 22: 40, 23: $Va, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: $Vb, 30: $Vc, 31: $Vd, 33: $Ve, 35: $Vf, 36: $Vg, 37: $Vh, 38: $Vi, 39: $Vj, 41: $Vk, 43: $Vl, 44: $Vm, 46: $Vn, 50: $Vo, 52: $Vp, 53: $Vq, 54: $Vr, 59: $Vs, 60: $Vt, 61: $Vu, 62: $Vv, 70: $Vw }, { 4: $V4, 5: $V5, 8: 8, 9: 10, 12: 12, 13: $V6, 14: $V7, 16: [1, 131], 17: 15, 18: $V8, 21: $V9, 22: 40, 23: $Va, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: $Vb, 30: $Vc, 31: $Vd, 33: $Ve, 35: $Vf, 36: $Vg, 37: $Vh, 38: $Vi, 39: $Vj, 41: $Vk, 43: $Vl, 44: $Vm, 46: $Vn, 50: $Vo, 52: $Vp, 53: $Vq, 54: $Vr, 59: $Vs, 60: $Vt, 61: $Vu, 62: $Vv, 70: $Vw }, { 4: $V4, 5: $V5, 8: 8, 9: 10, 12: 12, 13: $V6, 14: $V7, 16: [1, 132], 17: 15, 18: $V8, 21: $V9, 22: 40, 23: $Va, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: $Vb, 30: $Vc, 31: $Vd, 33: $Ve, 35: $Vf, 36: $Vg, 37: $Vh, 38: $Vi, 39: $Vj, 41: $Vk, 43: $Vl, 44: $Vm, 46: $Vn, 50: $Vo, 52: $Vp, 53: $Vq, 54: $Vr, 59: $Vs, 60: $Vt, 61: $Vu, 62: $Vv, 70: $Vw }, { 16: [1, 133] }, { 4: $V4, 5: $V5, 8: 8, 9: 10, 12: 12, 13: $V6, 14: $V7, 16: [2, 46], 17: 15, 18: $V8, 21: $V9, 22: 40, 23: $Va, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: $Vb, 30: $Vc, 31: $Vd, 33: $Ve, 35: $Vf, 36: $Vg, 37: $Vh, 38: $Vi, 39: $Vj, 41: $Vk, 43: $Vl, 44: $Vm, 46: $Vn, 49: [1, 134], 50: $Vo, 52: $Vp, 53: $Vq, 54: $Vr, 59: $Vs, 60: $Vt, 61: $Vu, 62: $Vv, 70: $Vw }, { 16: [1, 135] }, { 4: $V4, 5: $V5, 8: 8, 9: 10, 12: 12, 13: $V6, 14: $V7, 16: [2, 44], 17: 15, 18: $V8, 21: $V9, 22: 40, 23: $Va, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: $Vb, 30: $Vc, 31: $Vd, 33: $Ve, 35: $Vf, 36: $Vg, 37: $Vh, 38: $Vi, 39: $Vj, 41: $Vk, 43: $Vl, 44: $Vm, 46: $Vn, 48: [1, 136], 50: $Vo, 52: $Vp, 53: $Vq, 54: $Vr, 59: $Vs, 60: $Vt, 61: $Vu, 62: $Vv, 70: $Vw }, { 16: [1, 137] }, { 16: [1, 138] }, { 4: $V4, 5: $V5, 8: 8, 9: 10, 12: 12, 13: $V6, 14: $V7, 16: [2, 42], 17: 15, 18: $V8, 21: $V9, 22: 40, 23: $Va, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: $Vb, 30: $Vc, 31: $Vd, 33: $Ve, 35: $Vf, 36: $Vg, 37: $Vh, 38: $Vi, 39: $Vj, 41: $Vk, 43: $Vl, 44: $Vm, 46: $Vn, 47: [1, 139], 50: $Vo, 52: $Vp, 53: $Vq, 54: $Vr, 59: $Vs, 60: $Vt, 61: $Vu, 62: $Vv, 70: $Vw }, { 4: $V4, 5: $V5, 8: 8, 9: 10, 12: 12, 13: $V6, 14: $V7, 16: [1, 140], 17: 15, 18: $V8, 21: $V9, 22: 40, 23: $Va, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: $Vb, 30: $Vc, 31: $Vd, 33: $Ve, 35: $Vf, 36: $Vg, 37: $Vh, 38: $Vi, 39: $Vj, 41: $Vk, 43: $Vl, 44: $Vm, 46: $Vn, 50: $Vo, 52: $Vp, 53: $Vq, 54: $Vr, 59: $Vs, 60: $Vt, 61: $Vu, 62: $Vv, 70: $Vw }, { 15: [1, 141] }, o($Vx, [2, 49]), { 15: [1, 142] }, o($Vx, [2, 51]), o($Vx, [2, 52]), { 22: 143, 70: $Vw }, { 22: 144, 70: $Vw }, { 56: 145, 79: $VE }, { 56: 146, 79: $VE }, { 56: 147, 79: $VE }, { 64: [1, 148], 79: [2, 62] }, { 5: [2, 55] }, { 5: [2, 77] }, { 5: [2, 56] }, { 5: [2, 57] }, { 5: [2, 58] }, o($Vx, [2, 16]), o($Vy, [2, 10]), { 12: 149, 50: $Vo, 52: $Vp, 53: $Vq }, o($Vy, [2, 12]), o($Vy, [2, 13]), o($Vx, [2, 18]), o($Vx, [2, 34]), o($Vx, [2, 35]), o($Vx, [2, 36]), o($Vx, [2, 37]), { 15: [1, 150] }, o($Vx, [2, 38]), { 15: [1, 151] }, o($Vx, [2, 39]), o($Vx, [2, 40]), { 15: [1, 152] }, o($Vx, [2, 41]), { 5: [1, 153] }, { 5: [1, 154] }, { 56: 155, 79: $VE }, { 56: 156, 79: $VE }, { 5: [2, 67] }, { 5: [2, 53] }, { 5: [2, 54] }, { 22: 157, 70: $Vw }, o($Vy, [2, 11]), o($VA, $V3, { 7: 101, 40: 158 }), o($VB, $V3, { 7: 103, 42: 159 }), o($VC, $V3, { 7: 106, 45: 160 }), o($Vx, [2, 48]), o($Vx, [2, 50]), { 5: [2, 65] }, { 5: [2, 66] }, { 79: [2, 61] }, { 16: [2, 47] }, { 16: [2, 45] }, { 16: [2, 43] }], + defaultActions: { 5: [2, 1], 6: [2, 2], 85: [2, 63], 86: [2, 64], 119: [2, 55], 120: [2, 77], 121: [2, 56], 122: [2, 57], 123: [2, 58], 145: [2, 67], 146: [2, 53], 147: [2, 54], 155: [2, 65], 156: [2, 66], 157: [2, 61], 158: [2, 47], 159: [2, 45], 160: [2, 43] }, + parseError: function parseError(str, hash) { + if (hash.recoverable) { + this.trace(str); + } else { + var error = new Error(str); + error.hash = hash; + throw error; + } + }, + parse: function parse(input) { + var self = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex() { + var token; + token = tstack.pop() || lexer2.lex() || EOF; + if (typeof token !== "number") { + if (token instanceof Array) { + tstack = token; + token = tstack.pop(); + } + token = self.symbols_[token] || token; + } + return token; + } + var symbol, state2, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state2 = stack[stack.length - 1]; + if (this.defaultActions[state2]) { + action = this.defaultActions[state2]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex(); + } + action = table[state2] && table[state2][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state2]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state2 + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str, hash); + } else { + throw new Error(str); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch = this._input[0]; + this.yytext += ch; + this.yyleng++; + this.offset++; + this.match += ch; + this.matched += ch; + var lines = ch.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch; + }, + // unshifts one char (or a string) into the input + unput: function(ch) { + var len = ch.length; + var lines = ch.split(/(?:\r\n?|\n)/g); + this._input = ch + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next = this.match; + if (next.length < 20) { + next += this._input.substr(0, 20 - next.length); + } + return (next.substr(0, 20) + (next.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token) { + return token; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token, match, tempMatch, index; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i = 0; i < rules.length; i++) { + tempMatch = this._input.match(this.rules[rules[i]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index = i; + if (this.options.backtrack_lexer) { + token = this.test_match(tempMatch, rules[i]); + if (token !== false) { + return token; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token = this.test_match(match, rules[index]); + if (token !== false) { + return token; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + return 5; + case 1: + break; + case 2: + break; + case 3: + break; + case 4: + break; + case 5: + break; + case 6: + return 19; + case 7: + this.begin("LINE"); + return 14; + case 8: + this.begin("ID"); + return 50; + case 9: + this.begin("ID"); + return 52; + case 10: + return 13; + case 11: + this.begin("ID"); + return 53; + case 12: + yy_.yytext = yy_.yytext.trim(); + this.begin("ALIAS"); + return 70; + case 13: + this.popState(); + this.popState(); + this.begin("LINE"); + return 51; + case 14: + this.popState(); + this.popState(); + return 5; + case 15: + this.begin("LINE"); + return 36; + case 16: + this.begin("LINE"); + return 37; + case 17: + this.begin("LINE"); + return 38; + case 18: + this.begin("LINE"); + return 39; + case 19: + this.begin("LINE"); + return 49; + case 20: + this.begin("LINE"); + return 41; + case 21: + this.begin("LINE"); + return 43; + case 22: + this.begin("LINE"); + return 48; + case 23: + this.begin("LINE"); + return 44; + case 24: + this.begin("LINE"); + return 47; + case 25: + this.begin("LINE"); + return 46; + case 26: + this.popState(); + return 15; + case 27: + return 16; + case 28: + return 65; + case 29: + return 66; + case 30: + return 59; + case 31: + return 60; + case 32: + return 61; + case 33: + return 62; + case 34: + return 57; + case 35: + return 54; + case 36: + this.begin("ID"); + return 21; + case 37: + this.begin("ID"); + return 23; + case 38: + return 29; + case 39: + return 30; + case 40: + this.begin("acc_title"); + return 31; + case 41: + this.popState(); + return "acc_title_value"; + case 42: + this.begin("acc_descr"); + return 33; + case 43: + this.popState(); + return "acc_descr_value"; + case 44: + this.begin("acc_descr_multiline"); + break; + case 45: + this.popState(); + break; + case 46: + return "acc_descr_multiline_value"; + case 47: + return 6; + case 48: + return 18; + case 49: + return 20; + case 50: + return 64; + case 51: + return 5; + case 52: + yy_.yytext = yy_.yytext.trim(); + return 70; + case 53: + return 73; + case 54: + return 74; + case 55: + return 71; + case 56: + return 72; + case 57: + return 75; + case 58: + return 76; + case 59: + return 77; + case 60: + return 78; + case 61: + return 79; + case 62: + return 68; + case 63: + return 69; + case 64: + return 5; + case 65: + return "INVALID"; + } + }, + rules: [/^(?:[\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, /^(?:create\b)/i, /^(?:destroy\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, /^(?:par_over\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": [45, 46], "inclusive": false }, "acc_descr": { "rules": [43], "inclusive": false }, "acc_title": { "rules": [41], "inclusive": false }, "ID": { "rules": [2, 3, 12], "inclusive": false }, "ALIAS": { "rules": [2, 3, 13, 14], "inclusive": false }, "LINE": { "rules": [2, 3, 26], "inclusive": false }, "INITIAL": { "rules": [0, 1, 3, 4, 5, 6, 7, 8, 9, 10, 11, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 42, 44, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser() { + this.yy = {}; + } + Parser.prototype = parser2; + parser2.Parser = Parser; + return new Parser(); +}(); +parser.parser = parser; +const parser$1 = parser; +class ImperativeState { + /** + * @param init - Function that creates the default state. + */ + constructor(init) { + this.init = init; + this.records = this.init(); + } + reset() { + this.records = this.init(); + } +} +const state = new ImperativeState(() => ({ + prevActor: void 0, + actors: {}, + createdActors: {}, + destroyedActors: {}, + boxes: [], + messages: [], + notes: [], + sequenceNumbersEnabled: false, + wrapEnabled: void 0, + currentBox: void 0, + lastCreated: void 0, + lastDestroyed: void 0 +})); +const addBox = function(data) { + state.records.boxes.push({ + name: data.text, + wrap: data.wrap === void 0 && autoWrap() || !!data.wrap, + fill: data.color, + actorKeys: [] + }); + state.records.currentBox = state.records.boxes.slice(-1)[0]; +}; +const addActor = function(id, name, description, type) { + let assignedBox = state.records.currentBox; + const old = state.records.actors[id]; + if (old) { + if (state.records.currentBox && old.box && state.records.currentBox !== old.box) { + throw new Error( + "A same participant should only be defined in one Box: " + old.name + " can't be in '" + old.box.name + "' and in '" + state.records.currentBox.name + "' at the same time." + ); + } + assignedBox = old.box ? old.box : state.records.currentBox; + old.box = assignedBox; + if (old && name === old.name && description == null) { + return; + } + } + if (description == null || description.text == null) { + description = { text: name, wrap: null, type }; + } + if (type == null || description.text == null) { + description = { text: name, wrap: null, type }; + } + state.records.actors[id] = { + box: assignedBox, + name, + description: description.text, + wrap: description.wrap === void 0 && autoWrap() || !!description.wrap, + prevActor: state.records.prevActor, + links: {}, + properties: {}, + actorCnt: null, + rectData: null, + type: type || "participant" + }; + if (state.records.prevActor && state.records.actors[state.records.prevActor]) { + state.records.actors[state.records.prevActor].nextActor = id; + } + if (state.records.currentBox) { + state.records.currentBox.actorKeys.push(id); + } + state.records.prevActor = id; +}; +const activationCount = (part) => { + let i; + let count = 0; + for (i = 0; i < state.records.messages.length; i++) { + if (state.records.messages[i].type === LINETYPE.ACTIVE_START && state.records.messages[i].from.actor === part) { + count++; + } + if (state.records.messages[i].type === LINETYPE.ACTIVE_END && state.records.messages[i].from.actor === part) { + count--; + } + } + return count; +}; +const addMessage = function(idFrom, idTo, message, answer) { + state.records.messages.push({ + from: idFrom, + to: idTo, + message: message.text, + wrap: message.wrap === void 0 && autoWrap() || !!message.wrap, + answer + }); +}; +const addSignal = function(idFrom, idTo, message = { text: void 0, wrap: void 0 }, messageType, activate = false) { + if (messageType === LINETYPE.ACTIVE_END) { + const cnt = activationCount(idFrom.actor); + if (cnt < 1) { + let error = new Error("Trying to inactivate an inactive participant (" + idFrom.actor + ")"); + error.hash = { + text: "->>-", + token: "->>-", + line: "1", + loc: { first_line: 1, last_line: 1, first_column: 1, last_column: 1 }, + expected: ["'ACTIVE_PARTICIPANT'"] + }; + throw error; + } + } + state.records.messages.push({ + from: idFrom, + to: idTo, + message: message.text, + wrap: message.wrap === void 0 && autoWrap() || !!message.wrap, + type: messageType, + activate + }); + return true; +}; +const hasAtLeastOneBox = function() { + return state.records.boxes.length > 0; +}; +const hasAtLeastOneBoxWithTitle = function() { + return state.records.boxes.some((b) => b.name); +}; +const getMessages = function() { + return state.records.messages; +}; +const getBoxes = function() { + return state.records.boxes; +}; +const getActors = function() { + return state.records.actors; +}; +const getCreatedActors = function() { + return state.records.createdActors; +}; +const getDestroyedActors = function() { + return state.records.destroyedActors; +}; +const getActor = function(id) { + return state.records.actors[id]; +}; +const getActorKeys = function() { + return Object.keys(state.records.actors); +}; +const enableSequenceNumbers = function() { + state.records.sequenceNumbersEnabled = true; +}; +const disableSequenceNumbers = function() { + state.records.sequenceNumbersEnabled = false; +}; +const showSequenceNumbers = () => state.records.sequenceNumbersEnabled; +const setWrap = function(wrapSetting) { + state.records.wrapEnabled = wrapSetting; +}; +const autoWrap = () => { + if (state.records.wrapEnabled !== void 0) { + return state.records.wrapEnabled; + } + return getConfig().sequence.wrap; +}; +const clear = function() { + state.reset(); + clear$1(); +}; +const parseMessage = function(str) { + const _str = str.trim(); + const message = { + text: _str.replace(/^:?(?:no)?wrap:/, "").trim(), + wrap: _str.match(/^:?wrap:/) !== null ? true : _str.match(/^:?nowrap:/) !== null ? false : void 0 + }; + log.debug("parseMessage:", message); + return message; +}; +const parseBoxData = function(str) { + const match = str.match(/^((?:rgba?|hsla?)\s*\(.*\)|\w*)(.*)$/); + let color = match != null && match[1] ? match[1].trim() : "transparent"; + let title = match != null && match[2] ? match[2].trim() : void 0; + if (window && window.CSS) { + if (!window.CSS.supports("color", color)) { + color = "transparent"; + title = str.trim(); + } + } else { + const style = new Option().style; + style.color = color; + if (style.color !== color) { + color = "transparent"; + title = str.trim(); + } + } + return { + color, + text: title !== void 0 ? sanitizeText(title.replace(/^:?(?:no)?wrap:/, ""), getConfig()) : void 0, + wrap: title !== void 0 ? title.match(/^:?wrap:/) !== null ? true : title.match(/^:?nowrap:/) !== null ? false : void 0 : void 0 + }; +}; +const LINETYPE = { + 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, + PAR_OVER_START: 32 +}; +const ARROWTYPE = { + FILLED: 0, + OPEN: 1 +}; +const PLACEMENT = { + LEFTOF: 0, + RIGHTOF: 1, + OVER: 2 +}; +const addNote = function(actor, placement, message) { + const note = { + actor, + placement, + message: message.text, + wrap: message.wrap === void 0 && autoWrap() || !!message.wrap + }; + const actors = [].concat(actor, actor); + state.records.notes.push(note); + state.records.messages.push({ + from: actors[0], + to: actors[1], + message: message.text, + wrap: message.wrap === void 0 && autoWrap() || !!message.wrap, + type: LINETYPE.NOTE, + placement + }); +}; +const addLinks = function(actorId, text) { + const actor = getActor(actorId); + try { + let sanitizedText = sanitizeText(text.text, getConfig()); + sanitizedText = sanitizedText.replace(/&/g, "&"); + sanitizedText = sanitizedText.replace(/=/g, "="); + const links = JSON.parse(sanitizedText); + insertLinks(actor, links); + } catch (e) { + log.error("error while parsing actor link text", e); + } +}; +const addALink = function(actorId, text) { + const actor = getActor(actorId); + try { + const links = {}; + let sanitizedText = sanitizeText(text.text, getConfig()); + var sep = sanitizedText.indexOf("@"); + sanitizedText = sanitizedText.replace(/&/g, "&"); + sanitizedText = sanitizedText.replace(/=/g, "="); + var label = sanitizedText.slice(0, sep - 1).trim(); + var link = sanitizedText.slice(sep + 1).trim(); + links[label] = link; + insertLinks(actor, links); + } catch (e) { + log.error("error while parsing actor link text", e); + } +}; +function insertLinks(actor, links) { + if (actor.links == null) { + actor.links = links; + } else { + for (let key in links) { + actor.links[key] = links[key]; + } + } +} +const addProperties = function(actorId, text) { + const actor = getActor(actorId); + try { + let sanitizedText = sanitizeText(text.text, getConfig()); + const properties = JSON.parse(sanitizedText); + insertProperties(actor, properties); + } catch (e) { + log.error("error while parsing actor properties text", e); + } +}; +function insertProperties(actor, properties) { + if (actor.properties == null) { + actor.properties = properties; + } else { + for (let key in properties) { + actor.properties[key] = properties[key]; + } + } +} +function boxEnd() { + state.records.currentBox = void 0; +} +const addDetails = function(actorId, text) { + const actor = getActor(actorId); + const elem = document.getElementById(text.text); + try { + const text2 = elem.innerHTML; + const details = JSON.parse(text2); + if (details["properties"]) { + insertProperties(actor, details["properties"]); + } + if (details["links"]) { + insertLinks(actor, details["links"]); + } + } catch (e) { + log.error("error while parsing actor details text", e); + } +}; +const getActorProperty = function(actor, key) { + if (actor !== void 0 && actor.properties !== void 0) { + return actor.properties[key]; + } + return void 0; +}; +const apply = function(param) { + if (Array.isArray(param)) { + param.forEach(function(item) { + apply(item); + }); + } else { + switch (param.type) { + case "sequenceIndex": + state.records.messages.push({ + from: void 0, + to: void 0, + message: { + start: param.sequenceIndex, + step: param.sequenceIndexStep, + visible: param.sequenceVisible + }, + wrap: false, + type: param.signalType + }); + break; + case "addParticipant": + addActor(param.actor, param.actor, param.description, param.draw); + break; + case "createParticipant": + if (state.records.actors[param.actor]) { + throw new Error( + "It is not possible to have actors with the same id, even if one is destroyed before the next is created. Use 'AS' aliases to simulate the behavior" + ); + } + state.records.lastCreated = param.actor; + addActor(param.actor, param.actor, param.description, param.draw); + state.records.createdActors[param.actor] = state.records.messages.length; + break; + case "destroyParticipant": + state.records.lastDestroyed = param.actor; + state.records.destroyedActors[param.actor] = state.records.messages.length; + break; + case "activeStart": + addSignal(param.actor, void 0, void 0, param.signalType); + break; + case "activeEnd": + addSignal(param.actor, void 0, void 0, param.signalType); + break; + case "addNote": + addNote(param.actor, param.placement, param.text); + break; + case "addLinks": + addLinks(param.actor, param.text); + break; + case "addALink": + addALink(param.actor, param.text); + break; + case "addProperties": + addProperties(param.actor, param.text); + break; + case "addDetails": + addDetails(param.actor, param.text); + break; + case "addMessage": + if (state.records.lastCreated) { + if (param.to !== state.records.lastCreated) { + throw new Error( + "The created participant " + state.records.lastCreated + " does not have an associated creating message after its declaration. Please check the sequence diagram." + ); + } else { + state.records.lastCreated = void 0; + } + } else if (state.records.lastDestroyed) { + if (param.to !== state.records.lastDestroyed && param.from !== state.records.lastDestroyed) { + throw new Error( + "The destroyed participant " + state.records.lastDestroyed + " does not have an associated destroying message after its declaration. Please check the sequence diagram." + ); + } else { + state.records.lastDestroyed = void 0; + } + } + addSignal(param.from, param.to, param.msg, param.signalType, param.activate); + break; + case "boxStart": + addBox(param.boxData); + break; + case "boxEnd": + boxEnd(); + break; + case "loopStart": + addSignal(void 0, void 0, param.loopText, param.signalType); + break; + case "loopEnd": + addSignal(void 0, void 0, void 0, param.signalType); + break; + case "rectStart": + addSignal(void 0, void 0, param.color, param.signalType); + break; + case "rectEnd": + addSignal(void 0, void 0, void 0, param.signalType); + break; + case "optStart": + addSignal(void 0, void 0, param.optText, param.signalType); + break; + case "optEnd": + addSignal(void 0, void 0, void 0, param.signalType); + break; + case "altStart": + addSignal(void 0, void 0, param.altText, param.signalType); + break; + case "else": + addSignal(void 0, void 0, param.altText, param.signalType); + break; + case "altEnd": + addSignal(void 0, void 0, void 0, param.signalType); + break; + case "setAccTitle": + setAccTitle(param.text); + break; + case "parStart": + addSignal(void 0, void 0, param.parText, param.signalType); + break; + case "and": + addSignal(void 0, void 0, param.parText, param.signalType); + break; + case "parEnd": + addSignal(void 0, void 0, void 0, param.signalType); + break; + case "criticalStart": + addSignal(void 0, void 0, param.criticalText, param.signalType); + break; + case "option": + addSignal(void 0, void 0, param.optionText, param.signalType); + break; + case "criticalEnd": + addSignal(void 0, void 0, void 0, param.signalType); + break; + case "breakStart": + addSignal(void 0, void 0, param.breakText, param.signalType); + break; + case "breakEnd": + addSignal(void 0, void 0, void 0, param.signalType); + break; + } + } +}; +const db = { + addActor, + addMessage, + addSignal, + addLinks, + addDetails, + addProperties, + autoWrap, + setWrap, + enableSequenceNumbers, + disableSequenceNumbers, + showSequenceNumbers, + getMessages, + getActors, + getCreatedActors, + getDestroyedActors, + getActor, + getActorKeys, + getActorProperty, + getAccTitle, + getBoxes, + getDiagramTitle, + setDiagramTitle, + getConfig: () => getConfig().sequence, + clear, + parseMessage, + parseBoxData, + LINETYPE, + ARROWTYPE, + PLACEMENT, + addNote, + setAccTitle, + apply, + setAccDescription, + getAccDescription, + hasAtLeastOneBox, + hasAtLeastOneBoxWithTitle +}; +const getStyles = (options) => `.actor { + stroke: ${options.actorBorder}; + fill: ${options.actorBkg}; + } + + text.actor > tspan { + fill: ${options.actorTextColor}; + stroke: none; + } + + .actor-line { + stroke: ${options.actorLineColor}; + } + + .messageLine0 { + stroke-width: 1.5; + stroke-dasharray: none; + stroke: ${options.signalColor}; + } + + .messageLine1 { + stroke-width: 1.5; + stroke-dasharray: 2, 2; + stroke: ${options.signalColor}; + } + + #arrowhead path { + fill: ${options.signalColor}; + stroke: ${options.signalColor}; + } + + .sequenceNumber { + fill: ${options.sequenceNumberColor}; + } + + #sequencenumber { + fill: ${options.signalColor}; + } + + #crosshead path { + fill: ${options.signalColor}; + stroke: ${options.signalColor}; + } + + .messageText { + fill: ${options.signalTextColor}; + stroke: none; + } + + .labelBox { + stroke: ${options.labelBoxBorderColor}; + fill: ${options.labelBoxBkgColor}; + } + + .labelText, .labelText > tspan { + fill: ${options.labelTextColor}; + stroke: none; + } + + .loopText, .loopText > tspan { + fill: ${options.loopTextColor}; + stroke: none; + } + + .loopLine { + stroke-width: 2px; + stroke-dasharray: 2, 2; + stroke: ${options.labelBoxBorderColor}; + fill: ${options.labelBoxBorderColor}; + } + + .note { + //stroke: #decc93; + stroke: ${options.noteBorderColor}; + fill: ${options.noteBkgColor}; + } + + .noteText, .noteText > tspan { + fill: ${options.noteTextColor}; + stroke: none; + } + + .activation0 { + fill: ${options.activationBkgColor}; + stroke: ${options.activationBorderColor}; + } + + .activation1 { + fill: ${options.activationBkgColor}; + stroke: ${options.activationBorderColor}; + } + + .activation2 { + fill: ${options.activationBkgColor}; + stroke: ${options.activationBorderColor}; + } + + .actorPopupMenu { + position: absolute; + } + + .actorPopupMenuPanel { + position: absolute; + fill: ${options.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: ${options.actorBorder}; + fill: ${options.actorBkg}; + } + .actor-man circle, line { + stroke: ${options.actorBorder}; + fill: ${options.actorBkg}; + stroke-width: 2px; + } +`; +const styles = getStyles; +const ACTOR_TYPE_WIDTH = 18 * 2; +const TOP_ACTOR_CLASS = "actor-top"; +const BOTTOM_ACTOR_CLASS = "actor-bottom"; +const drawRect = function(elem, rectData) { + return drawRect$1(elem, rectData); +}; +const drawPopup = function(elem, actor, minMenuWidth, textAttrs, forceMenus) { + if (actor.links === void 0 || actor.links === null || Object.keys(actor.links).length === 0) { + return { height: 0, width: 0 }; + } + const links = actor.links; + const actorCnt2 = actor.actorCnt; + const rectData = actor.rectData; + var displayValue = "none"; + if (forceMenus) { + displayValue = "block !important"; + } + const g = elem.append("g"); + g.attr("id", "actor" + actorCnt2 + "_popup"); + g.attr("class", "actorPopupMenu"); + g.attr("display", displayValue); + var actorClass = ""; + if (rectData.class !== void 0) { + actorClass = " " + rectData.class; + } + let menuWidth = rectData.width > minMenuWidth ? rectData.width : minMenuWidth; + const rectElem = g.append("rect"); + rectElem.attr("class", "actorPopupMenuPanel" + actorClass); + rectElem.attr("x", rectData.x); + rectElem.attr("y", rectData.height); + rectElem.attr("fill", rectData.fill); + rectElem.attr("stroke", rectData.stroke); + rectElem.attr("width", menuWidth); + rectElem.attr("height", rectData.height); + rectElem.attr("rx", rectData.rx); + rectElem.attr("ry", rectData.ry); + if (links != null) { + var linkY = 20; + for (let key in links) { + var linkElem = g.append("a"); + var sanitizedLink = dist.sanitizeUrl(links[key]); + linkElem.attr("xlink:href", sanitizedLink); + linkElem.attr("target", "_blank"); + _drawMenuItemTextCandidateFunc(textAttrs)( + key, + linkElem, + rectData.x + 10, + rectData.height + linkY, + menuWidth, + 20, + { class: "actor" }, + textAttrs + ); + linkY += 30; + } + } + rectElem.attr("height", linkY); + return { height: rectData.height + linkY, width: menuWidth }; +}; +const popupMenuToggle = function(popId) { + return "var pu = document.getElementById('" + popId + "'); if (pu != null) { pu.style.display = pu.style.display == 'block' ? 'none' : 'block'; }"; +}; +const drawKatex = async function(elem, textData, msgModel = null) { + let textElem = elem.append("foreignObject"); + const lines = await renderKatex(textData.text, getConfig$1()); + const divElem = textElem.append("xhtml:div").attr("style", "width: fit-content;").attr("xmlns", "http://www.w3.org/1999/xhtml").html(lines); + const dim = divElem.node().getBoundingClientRect(); + textElem.attr("height", Math.round(dim.height)).attr("width", Math.round(dim.width)); + if (textData.class === "noteText") { + const rectElem = elem.node().firstChild; + rectElem.setAttribute("height", dim.height + 2 * textData.textMargin); + const rectDim = rectElem.getBBox(); + textElem.attr("x", Math.round(rectDim.x + rectDim.width / 2 - dim.width / 2)).attr("y", Math.round(rectDim.y + rectDim.height / 2 - dim.height / 2)); + } else if (msgModel) { + let { startx, stopx, starty } = msgModel; + if (startx > stopx) { + const temp = startx; + startx = stopx; + stopx = temp; + } + textElem.attr("x", Math.round(startx + Math.abs(startx - stopx) / 2 - dim.width / 2)); + if (textData.class === "loopText") { + textElem.attr("y", Math.round(starty)); + } else { + textElem.attr("y", Math.round(starty - dim.height)); + } + } + return [textElem]; +}; +const drawText = function(elem, textData) { + let prevTextHeight = 0; + let textHeight = 0; + const lines = textData.text.split(common.lineBreakRegex); + const [_textFontSize, _textFontSizePx] = parseFontSize(textData.fontSize); + let textElems = []; + let dy = 0; + let yfunc = () => textData.y; + if (textData.valign !== void 0 && textData.textMargin !== void 0 && textData.textMargin > 0) { + switch (textData.valign) { + case "top": + case "start": + yfunc = () => Math.round(textData.y + textData.textMargin); + break; + case "middle": + case "center": + yfunc = () => Math.round(textData.y + (prevTextHeight + textHeight + textData.textMargin) / 2); + break; + case "bottom": + case "end": + yfunc = () => Math.round( + textData.y + (prevTextHeight + textHeight + 2 * textData.textMargin) - textData.textMargin + ); + break; + } + } + if (textData.anchor !== void 0 && textData.textMargin !== void 0 && textData.width !== void 0) { + switch (textData.anchor) { + case "left": + case "start": + textData.x = Math.round(textData.x + textData.textMargin); + textData.anchor = "start"; + textData.dominantBaseline = "middle"; + textData.alignmentBaseline = "middle"; + break; + case "middle": + case "center": + textData.x = Math.round(textData.x + textData.width / 2); + textData.anchor = "middle"; + textData.dominantBaseline = "middle"; + textData.alignmentBaseline = "middle"; + break; + case "right": + case "end": + textData.x = Math.round(textData.x + textData.width - textData.textMargin); + textData.anchor = "end"; + textData.dominantBaseline = "middle"; + textData.alignmentBaseline = "middle"; + break; + } + } + for (let [i, line] of lines.entries()) { + if (textData.textMargin !== void 0 && textData.textMargin === 0 && _textFontSize !== void 0) { + dy = i * _textFontSize; + } + const textElem = elem.append("text"); + textElem.attr("x", textData.x); + textElem.attr("y", yfunc()); + if (textData.anchor !== void 0) { + textElem.attr("text-anchor", textData.anchor).attr("dominant-baseline", textData.dominantBaseline).attr("alignment-baseline", textData.alignmentBaseline); + } + if (textData.fontFamily !== void 0) { + textElem.style("font-family", textData.fontFamily); + } + if (_textFontSizePx !== void 0) { + textElem.style("font-size", _textFontSizePx); + } + if (textData.fontWeight !== void 0) { + textElem.style("font-weight", textData.fontWeight); + } + if (textData.fill !== void 0) { + textElem.attr("fill", textData.fill); + } + if (textData.class !== void 0) { + textElem.attr("class", textData.class); + } + if (textData.dy !== void 0) { + textElem.attr("dy", textData.dy); + } else if (dy !== 0) { + textElem.attr("dy", dy); + } + const text = line || ZERO_WIDTH_SPACE; + if (textData.tspan) { + const span = textElem.append("tspan"); + span.attr("x", textData.x); + if (textData.fill !== void 0) { + span.attr("fill", textData.fill); + } + span.text(text); + } else { + textElem.text(text); + } + if (textData.valign !== void 0 && textData.textMargin !== void 0 && textData.textMargin > 0) { + textHeight += (textElem._groups || textElem)[0][0].getBBox().height; + prevTextHeight = textHeight; + } + textElems.push(textElem); + } + return textElems; +}; +const drawLabel = function(elem, txtObject) { + function genPoints(x, y, width, height, cut) { + return x + "," + y + " " + (x + width) + "," + y + " " + (x + width) + "," + (y + height - cut) + " " + (x + width - cut * 1.2) + "," + (y + height) + " " + x + "," + (y + height); + } + const polygon = elem.append("polygon"); + polygon.attr("points", genPoints(txtObject.x, txtObject.y, txtObject.width, txtObject.height, 7)); + polygon.attr("class", "labelBox"); + txtObject.y = txtObject.y + txtObject.height / 2; + drawText(elem, txtObject); + return polygon; +}; +let actorCnt = -1; +const fixLifeLineHeights = (diagram2, actors, actorKeys, conf2) => { + if (!diagram2.select) { + return; + } + actorKeys.forEach((actorKey) => { + const actor = actors[actorKey]; + const actorDOM = diagram2.select("#actor" + actor.actorCnt); + if (!conf2.mirrorActors && actor.stopy) { + actorDOM.attr("y2", actor.stopy + actor.height / 2); + } else if (conf2.mirrorActors) { + actorDOM.attr("y2", actor.stopy); + } + }); +}; +const drawActorTypeParticipant = async function(elem, actor, conf2, isFooter) { + const actorY = isFooter ? actor.stopy : actor.starty; + const center = actor.x + actor.width / 2; + const centerY = actorY + 5; + const boxplusLineGroup = elem.append("g").lower(); + var g = boxplusLineGroup; + if (!isFooter) { + actorCnt++; + if (Object.keys(actor.links || {}).length && !conf2.forceMenus) { + g.attr("onclick", popupMenuToggle(`actor${actorCnt}_popup`)).attr("cursor", "pointer"); + } + g.append("line").attr("id", "actor" + actorCnt).attr("x1", center).attr("y1", centerY).attr("x2", center).attr("y2", 2e3).attr("class", "actor-line").attr("class", "200").attr("stroke-width", "0.5px").attr("stroke", "#999"); + g = boxplusLineGroup.append("g"); + actor.actorCnt = actorCnt; + if (actor.links != null) { + g.attr("id", "root-" + actorCnt); + } + } + const rect = getNoteRect$1(); + var cssclass = "actor"; + if (actor.properties != null && actor.properties["class"]) { + cssclass = actor.properties["class"]; + } else { + rect.fill = "#eaeaea"; + } + if (isFooter) { + cssclass += ` ${BOTTOM_ACTOR_CLASS}`; + } else { + cssclass += ` ${TOP_ACTOR_CLASS}`; + } + rect.x = actor.x; + rect.y = actorY; + rect.width = actor.width; + rect.height = actor.height; + rect.class = cssclass; + rect.rx = 3; + rect.ry = 3; + rect.name = actor.name; + const rectElem = drawRect(g, rect); + actor.rectData = rect; + if (actor.properties != null && actor.properties["icon"]) { + const iconSrc = actor.properties["icon"].trim(); + if (iconSrc.charAt(0) === "@") { + drawEmbeddedImage(g, rect.x + rect.width - 20, rect.y + 10, iconSrc.substr(1)); + } else { + drawImage(g, rect.x + rect.width - 20, rect.y + 10, iconSrc); + } + } + await _drawTextCandidateFunc(conf2, hasKatex(actor.description))( + actor.description, + g, + rect.x, + rect.y, + rect.width, + rect.height, + { class: "actor" }, + conf2 + ); + let height = actor.height; + if (rectElem.node) { + const bounds2 = rectElem.node().getBBox(); + actor.height = bounds2.height; + height = bounds2.height; + } + return height; +}; +const drawActorTypeActor = async function(elem, actor, conf2, isFooter) { + const actorY = isFooter ? actor.stopy : actor.starty; + const center = actor.x + actor.width / 2; + const centerY = actorY + 80; + elem.lower(); + if (!isFooter) { + actorCnt++; + elem.append("line").attr("id", "actor" + actorCnt).attr("x1", center).attr("y1", centerY).attr("x2", center).attr("y2", 2e3).attr("class", "actor-line").attr("class", "200").attr("stroke-width", "0.5px").attr("stroke", "#999"); + actor.actorCnt = actorCnt; + } + const actElem = elem.append("g"); + let cssClass = "actor-man"; + if (isFooter) { + cssClass += ` ${BOTTOM_ACTOR_CLASS}`; + } else { + cssClass += ` ${TOP_ACTOR_CLASS}`; + } + actElem.attr("class", cssClass); + actElem.attr("name", actor.name); + const rect = getNoteRect$1(); + rect.x = actor.x; + rect.y = actorY; + rect.fill = "#eaeaea"; + rect.width = actor.width; + rect.height = actor.height; + rect.class = "actor"; + rect.rx = 3; + rect.ry = 3; + actElem.append("line").attr("id", "actor-man-torso" + actorCnt).attr("x1", center).attr("y1", actorY + 25).attr("x2", center).attr("y2", actorY + 45); + actElem.append("line").attr("id", "actor-man-arms" + actorCnt).attr("x1", center - ACTOR_TYPE_WIDTH / 2).attr("y1", actorY + 33).attr("x2", center + ACTOR_TYPE_WIDTH / 2).attr("y2", actorY + 33); + actElem.append("line").attr("x1", center - ACTOR_TYPE_WIDTH / 2).attr("y1", actorY + 60).attr("x2", center).attr("y2", actorY + 45); + actElem.append("line").attr("x1", center).attr("y1", actorY + 45).attr("x2", center + ACTOR_TYPE_WIDTH / 2 - 2).attr("y2", actorY + 60); + const circle = actElem.append("circle"); + circle.attr("cx", actor.x + actor.width / 2); + circle.attr("cy", actorY + 10); + circle.attr("r", 15); + circle.attr("width", actor.width); + circle.attr("height", actor.height); + const bounds2 = actElem.node().getBBox(); + actor.height = bounds2.height; + await _drawTextCandidateFunc(conf2, hasKatex(actor.description))( + actor.description, + actElem, + rect.x, + rect.y + 35, + rect.width, + rect.height, + { class: "actor" }, + conf2 + ); + return actor.height; +}; +const drawActor = async function(elem, actor, conf2, isFooter) { + switch (actor.type) { + case "actor": + return await drawActorTypeActor(elem, actor, conf2, isFooter); + case "participant": + return await drawActorTypeParticipant(elem, actor, conf2, isFooter); + } +}; +const drawBox = async function(elem, box, conf2) { + const boxplusTextGroup = elem.append("g"); + const g = boxplusTextGroup; + drawBackgroundRect(g, box); + if (box.name) { + await _drawTextCandidateFunc(conf2)( + box.name, + g, + box.x, + box.y + (box.textMaxHeight || 0) / 2, + box.width, + 0, + { class: "text" }, + conf2 + ); + } + g.lower(); +}; +const anchorElement = function(elem) { + return elem.append("g"); +}; +const drawActivation = function(elem, bounds2, verticalPos, conf2, actorActivations2) { + const rect = getNoteRect$1(); + const g = bounds2.anchored; + rect.x = bounds2.startx; + rect.y = bounds2.starty; + rect.class = "activation" + actorActivations2 % 3; + rect.width = bounds2.stopx - bounds2.startx; + rect.height = verticalPos - bounds2.starty; + drawRect(g, rect); +}; +const drawLoop = async function(elem, loopModel, labelText, conf2) { + const { + boxMargin, + boxTextMargin, + labelBoxHeight, + labelBoxWidth, + messageFontFamily: fontFamily, + messageFontSize: fontSize, + messageFontWeight: fontWeight + } = conf2; + const g = elem.append("g"); + const drawLoopLine = function(startx, starty, stopx, stopy) { + return g.append("line").attr("x1", startx).attr("y1", starty).attr("x2", stopx).attr("y2", stopy).attr("class", "loopLine"); + }; + drawLoopLine(loopModel.startx, loopModel.starty, loopModel.stopx, loopModel.starty); + drawLoopLine(loopModel.stopx, loopModel.starty, loopModel.stopx, loopModel.stopy); + drawLoopLine(loopModel.startx, loopModel.stopy, loopModel.stopx, loopModel.stopy); + drawLoopLine(loopModel.startx, loopModel.starty, loopModel.startx, loopModel.stopy); + if (loopModel.sections !== void 0) { + loopModel.sections.forEach(function(item) { + drawLoopLine(loopModel.startx, item.y, loopModel.stopx, item.y).style( + "stroke-dasharray", + "3, 3" + ); + }); + } + let txt = getTextObj$1(); + txt.text = labelText; + txt.x = loopModel.startx; + txt.y = loopModel.starty; + txt.fontFamily = fontFamily; + txt.fontSize = fontSize; + txt.fontWeight = fontWeight; + txt.anchor = "middle"; + txt.valign = "middle"; + txt.tspan = false; + txt.width = labelBoxWidth || 50; + txt.height = labelBoxHeight || 20; + txt.textMargin = boxTextMargin; + txt.class = "labelText"; + drawLabel(g, txt); + txt = getTextObj(); + txt.text = loopModel.title; + txt.x = loopModel.startx + labelBoxWidth / 2 + (loopModel.stopx - loopModel.startx) / 2; + txt.y = loopModel.starty + boxMargin + boxTextMargin; + txt.anchor = "middle"; + txt.valign = "middle"; + txt.textMargin = boxTextMargin; + txt.class = "loopText"; + txt.fontFamily = fontFamily; + txt.fontSize = fontSize; + txt.fontWeight = fontWeight; + txt.wrap = true; + let textElem = hasKatex(txt.text) ? await drawKatex(g, txt, loopModel) : drawText(g, txt); + if (loopModel.sectionTitles !== void 0) { + for (const [idx, item] of Object.entries(loopModel.sectionTitles)) { + if (item.message) { + txt.text = item.message; + txt.x = loopModel.startx + (loopModel.stopx - loopModel.startx) / 2; + txt.y = loopModel.sections[idx].y + boxMargin + boxTextMargin; + txt.class = "loopText"; + txt.anchor = "middle"; + txt.valign = "middle"; + txt.tspan = false; + txt.fontFamily = fontFamily; + txt.fontSize = fontSize; + txt.fontWeight = fontWeight; + txt.wrap = loopModel.wrap; + if (hasKatex(txt.text)) { + loopModel.starty = loopModel.sections[idx].y; + await drawKatex(g, txt, loopModel); + } else { + drawText(g, txt); + } + let sectionHeight = Math.round( + textElem.map((te) => (te._groups || te)[0][0].getBBox().height).reduce((acc, curr) => acc + curr) + ); + loopModel.sections[idx].height += sectionHeight - (boxMargin + boxTextMargin); + } + } + } + loopModel.height = Math.round(loopModel.stopy - loopModel.starty); + return g; +}; +const drawBackgroundRect = function(elem, bounds2) { + drawBackgroundRect$1(elem, bounds2); +}; +const insertDatabaseIcon = function(elem) { + elem.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-.047.148-.048.143-.049.139-.049.136-.05.131-.05.126-.05.123-.051.118-.052.114-.051.11-.052.106-.052.101-.052.096-.052.092-.052.088-.053.083-.051.079-.052.074-.052.07-.051.065-.051.06-.051.056-.05.051-.05.023-.024.023-.025.021-.024.02-.024.019-.024.018-.024.017-.024.015-.023.014-.024.013-.023.012-.023.01-.023.01-.022.008-.022.006-.022.006-.022.004-.022.004-.021.001-.021.001-.021v-4.127l-.077.055-.08.053-.083.054-.085.053-.087.052-.09.052-.093.051-.095.05-.097.05-.1.049-.102.049-.105.048-.106.047-.109.047-.111.046-.114.045-.115.045-.118.044-.12.043-.122.042-.124.042-.126.041-.128.04-.13.04-.132.038-.134.038-.135.037-.138.037-.139.035-.142.035-.143.034-.144.033-.147.032-.148.031-.15.03-.151.03-.153.029-.154.027-.156.027-.158.026-.159.025-.161.024-.162.023-.163.022-.165.021-.166.02-.167.019-.169.018-.169.017-.171.016-.173.015-.173.014-.175.013-.175.012-.177.011-.178.01-.179.008-.179.008-.181.006-.182.005-.182.004-.184.003-.184.002h-.37l-.184-.002-.184-.003-.182-.004-.182-.005-.181-.006-.179-.008-.179-.008-.178-.01-.176-.011-.176-.012-.175-.013-.173-.014-.172-.015-.171-.016-.17-.017-.169-.018-.167-.019-.166-.02-.165-.021-.163-.022-.162-.023-.161-.024-.159-.025-.157-.026-.156-.027-.155-.027-.153-.029-.151-.03-.15-.03-.148-.031-.146-.032-.145-.033-.143-.034-.141-.035-.14-.035-.137-.037-.136-.037-.134-.038-.132-.038-.13-.04-.128-.04-.126-.041-.124-.042-.122-.042-.12-.044-.117-.043-.116-.045-.113-.045-.112-.046-.109-.047-.106-.047-.105-.048-.102-.049-.1-.049-.097-.05-.095-.05-.093-.052-.09-.051-.087-.052-.085-.053-.083-.054-.08-.054-.077-.054v4.127zm0-5.654v.011l.001.021.003.021.004.021.005.022.006.022.007.022.009.022.01.022.011.023.012.023.013.023.015.024.016.023.017.024.018.024.019.024.021.024.022.024.023.025.024.024.052.05.056.05.061.05.066.051.07.051.075.052.079.051.084.052.088.052.092.052.097.052.102.052.105.052.11.051.114.051.119.052.123.05.127.051.131.05.135.049.139.049.144.048.147.048.152.047.155.046.16.045.163.045.167.044.171.042.176.042.178.04.183.04.187.038.19.037.194.036.197.034.202.033.204.032.209.03.212.028.216.027.219.025.222.024.226.022.23.02.233.018.236.016.24.014.243.012.246.01.249.008.253.006.256.003.259.001.26-.001.257-.003.254-.006.25-.008.247-.01.244-.012.241-.015.237-.016.233-.018.231-.02.226-.022.224-.024.22-.025.216-.027.212-.029.21-.03.205-.032.202-.033.198-.035.194-.036.191-.037.187-.039.183-.039.179-.041.175-.042.172-.043.168-.044.163-.045.16-.045.155-.047.152-.047.148-.048.143-.048.139-.05.136-.049.131-.05.126-.051.123-.051.118-.051.114-.052.11-.052.106-.052.101-.052.096-.052.092-.052.088-.052.083-.052.079-.052.074-.051.07-.052.065-.051.06-.05.056-.051.051-.049.023-.025.023-.024.021-.025.02-.024.019-.024.018-.024.017-.024.015-.023.014-.023.013-.024.012-.022.01-.023.01-.023.008-.022.006-.022.006-.022.004-.021.004-.022.001-.021.001-.021v-4.139l-.077.054-.08.054-.083.054-.085.052-.087.053-.09.051-.093.051-.095.051-.097.05-.1.049-.102.049-.105.048-.106.047-.109.047-.111.046-.114.045-.115.044-.118.044-.12.044-.122.042-.124.042-.126.041-.128.04-.13.039-.132.039-.134.038-.135.037-.138.036-.139.036-.142.035-.143.033-.144.033-.147.033-.148.031-.15.03-.151.03-.153.028-.154.028-.156.027-.158.026-.159.025-.161.024-.162.023-.163.022-.165.021-.166.02-.167.019-.169.018-.169.017-.171.016-.173.015-.173.014-.175.013-.175.012-.177.011-.178.009-.179.009-.179.007-.181.007-.182.005-.182.004-.184.003-.184.002h-.37l-.184-.002-.184-.003-.182-.004-.182-.005-.181-.007-.179-.007-.179-.009-.178-.009-.176-.011-.176-.012-.175-.013-.173-.014-.172-.015-.171-.016-.17-.017-.169-.018-.167-.019-.166-.02-.165-.021-.163-.022-.162-.023-.161-.024-.159-.025-.157-.026-.156-.027-.155-.028-.153-.028-.151-.03-.15-.03-.148-.031-.146-.033-.145-.033-.143-.033-.141-.035-.14-.036-.137-.036-.136-.037-.134-.038-.132-.039-.13-.039-.128-.04-.126-.041-.124-.042-.122-.043-.12-.043-.117-.044-.116-.044-.113-.046-.112-.046-.109-.046-.106-.047-.105-.048-.102-.049-.1-.049-.097-.05-.095-.051-.093-.051-.09-.051-.087-.053-.085-.052-.083-.054-.08-.054-.077-.054v4.139zm0-5.666v.011l.001.02.003.022.004.021.005.022.006.021.007.022.009.023.01.022.011.023.012.023.013.023.015.023.016.024.017.024.018.023.019.024.021.025.022.024.023.024.024.025.052.05.056.05.061.05.066.051.07.051.075.052.079.051.084.052.088.052.092.052.097.052.102.052.105.051.11.052.114.051.119.051.123.051.127.05.131.05.135.05.139.049.144.048.147.048.152.047.155.046.16.045.163.045.167.043.171.043.176.042.178.04.183.04.187.038.19.037.194.036.197.034.202.033.204.032.209.03.212.028.216.027.219.025.222.024.226.021.23.02.233.018.236.017.24.014.243.012.246.01.249.008.253.006.256.003.259.001.26-.001.257-.003.254-.006.25-.008.247-.01.244-.013.241-.014.237-.016.233-.018.231-.02.226-.022.224-.024.22-.025.216-.027.212-.029.21-.03.205-.032.202-.033.198-.035.194-.036.191-.037.187-.039.183-.039.179-.041.175-.042.172-.043.168-.044.163-.045.16-.045.155-.047.152-.047.148-.048.143-.049.139-.049.136-.049.131-.051.126-.05.123-.051.118-.052.114-.051.11-.052.106-.052.101-.052.096-.052.092-.052.088-.052.083-.052.079-.052.074-.052.07-.051.065-.051.06-.051.056-.05.051-.049.023-.025.023-.025.021-.024.02-.024.019-.024.018-.024.017-.024.015-.023.014-.024.013-.023.012-.023.01-.022.01-.023.008-.022.006-.022.006-.022.004-.022.004-.021.001-.021.001-.021v-4.153l-.077.054-.08.054-.083.053-.085.053-.087.053-.09.051-.093.051-.095.051-.097.05-.1.049-.102.048-.105.048-.106.048-.109.046-.111.046-.114.046-.115.044-.118.044-.12.043-.122.043-.124.042-.126.041-.128.04-.13.039-.132.039-.134.038-.135.037-.138.036-.139.036-.142.034-.143.034-.144.033-.147.032-.148.032-.15.03-.151.03-.153.028-.154.028-.156.027-.158.026-.159.024-.161.024-.162.023-.163.023-.165.021-.166.02-.167.019-.169.018-.169.017-.171.016-.173.015-.173.014-.175.013-.175.012-.177.01-.178.01-.179.009-.179.007-.181.006-.182.006-.182.004-.184.003-.184.001-.185.001-.185-.001-.184-.001-.184-.003-.182-.004-.182-.006-.181-.006-.179-.007-.179-.009-.178-.01-.176-.01-.176-.012-.175-.013-.173-.014-.172-.015-.171-.016-.17-.017-.169-.018-.167-.019-.166-.02-.165-.021-.163-.023-.162-.023-.161-.024-.159-.024-.157-.026-.156-.027-.155-.028-.153-.028-.151-.03-.15-.03-.148-.032-.146-.032-.145-.033-.143-.034-.141-.034-.14-.036-.137-.036-.136-.037-.134-.038-.132-.039-.13-.039-.128-.041-.126-.041-.124-.041-.122-.043-.12-.043-.117-.044-.116-.044-.113-.046-.112-.046-.109-.046-.106-.048-.105-.048-.102-.048-.1-.05-.097-.049-.095-.051-.093-.051-.09-.052-.087-.052-.085-.053-.083-.053-.08-.054-.077-.054v4.153zm8.74-8.179l-.257.004-.254.005-.25.008-.247.011-.244.012-.241.014-.237.016-.233.018-.231.021-.226.022-.224.023-.22.026-.216.027-.212.028-.21.031-.205.032-.202.033-.198.034-.194.036-.191.038-.187.038-.183.04-.179.041-.175.042-.172.043-.168.043-.163.045-.16.046-.155.046-.152.048-.148.048-.143.048-.139.049-.136.05-.131.05-.126.051-.123.051-.118.051-.114.052-.11.052-.106.052-.101.052-.096.052-.092.052-.088.052-.083.052-.079.052-.074.051-.07.052-.065.051-.06.05-.056.05-.051.05-.023.025-.023.024-.021.024-.02.025-.019.024-.018.024-.017.023-.015.024-.014.023-.013.023-.012.023-.01.023-.01.022-.008.022-.006.023-.006.021-.004.022-.004.021-.001.021-.001.021.001.021.001.021.004.021.004.022.006.021.006.023.008.022.01.022.01.023.012.023.013.023.014.023.015.024.017.023.018.024.019.024.02.025.021.024.023.024.023.025.051.05.056.05.06.05.065.051.07.052.074.051.079.052.083.052.088.052.092.052.096.052.101.052.106.052.11.052.114.052.118.051.123.051.126.051.131.05.136.05.139.049.143.048.148.048.152.048.155.046.16.046.163.045.168.043.172.043.175.042.179.041.183.04.187.038.191.038.194.036.198.034.202.033.205.032.21.031.212.028.216.027.22.026.224.023.226.022.231.021.233.018.237.016.241.014.244.012.247.011.25.008.254.005.257.004.26.001.26-.001.257-.004.254-.005.25-.008.247-.011.244-.012.241-.014.237-.016.233-.018.231-.021.226-.022.224-.023.22-.026.216-.027.212-.028.21-.031.205-.032.202-.033.198-.034.194-.036.191-.038.187-.038.183-.04.179-.041.175-.042.172-.043.168-.043.163-.045.16-.046.155-.046.152-.048.148-.048.143-.048.139-.049.136-.05.131-.05.126-.051.123-.051.118-.051.114-.052.11-.052.106-.052.101-.052.096-.052.092-.052.088-.052.083-.052.079-.052.074-.051.07-.052.065-.051.06-.05.056-.05.051-.05.023-.025.023-.024.021-.024.02-.025.019-.024.018-.024.017-.023.015-.024.014-.023.013-.023.012-.023.01-.023.01-.022.008-.022.006-.023.006-.021.004-.022.004-.021.001-.021.001-.021-.001-.021-.001-.021-.004-.021-.004-.022-.006-.021-.006-.023-.008-.022-.01-.022-.01-.023-.012-.023-.013-.023-.014-.023-.015-.024-.017-.023-.018-.024-.019-.024-.02-.025-.021-.024-.023-.024-.023-.025-.051-.05-.056-.05-.06-.05-.065-.051-.07-.052-.074-.051-.079-.052-.083-.052-.088-.052-.092-.052-.096-.052-.101-.052-.106-.052-.11-.052-.114-.052-.118-.051-.123-.051-.126-.051-.131-.05-.136-.05-.139-.049-.143-.048-.148-.048-.152-.048-.155-.046-.16-.046-.163-.045-.168-.043-.172-.043-.175-.042-.179-.041-.183-.04-.187-.038-.191-.038-.194-.036-.198-.034-.202-.033-.205-.032-.21-.031-.212-.028-.216-.027-.22-.026-.224-.023-.226-.022-.231-.021-.233-.018-.237-.016-.241-.014-.244-.012-.247-.011-.25-.008-.254-.005-.257-.004-.26-.001-.26.001z" + ); +}; +const insertComputerIcon = function(elem) { + elem.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" + ); +}; +const insertClockIcon = function(elem) { + elem.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" + ); +}; +const insertArrowHead = function(elem) { + elem.append("defs").append("marker").attr("id", "arrowhead").attr("refX", 7.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"); +}; +const insertArrowFilledHead = function(elem) { + elem.append("defs").append("marker").attr("id", "filled-head").attr("refX", 15.5).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"); +}; +const insertSequenceNumber = function(elem) { + elem.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); +}; +const insertArrowCrossHead = function(elem) { + const defs = elem.append("defs"); + const marker = defs.append("marker").attr("id", "crosshead").attr("markerWidth", 15).attr("markerHeight", 8).attr("orient", "auto").attr("refX", 4).attr("refY", 4.5); + marker.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"); +}; +const getTextObj = 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: true, + valign: void 0 + }; +}; +const getNoteRect = function() { + return { + x: 0, + y: 0, + fill: "#EDF2AE", + stroke: "#666", + width: 100, + anchor: "start", + height: 100, + rx: 0, + ry: 0 + }; +}; +const _drawTextCandidateFunc = function() { + function byText(content, g, x, y, width, height, textAttrs) { + const text = g.append("text").attr("x", x + width / 2).attr("y", y + height / 2 + 5).style("text-anchor", "middle").text(content); + _setTextAttrs(text, textAttrs); + } + function byTspan(content, g, x, y, width, height, textAttrs, conf2) { + const { actorFontSize, actorFontFamily, actorFontWeight } = conf2; + const [_actorFontSize, _actorFontSizePx] = parseFontSize(actorFontSize); + const lines = content.split(common.lineBreakRegex); + for (let i = 0; i < lines.length; i++) { + const dy = i * _actorFontSize - _actorFontSize * (lines.length - 1) / 2; + const text = g.append("text").attr("x", x + width / 2).attr("y", y).style("text-anchor", "middle").style("font-size", _actorFontSizePx).style("font-weight", actorFontWeight).style("font-family", actorFontFamily); + text.append("tspan").attr("x", x + width / 2).attr("dy", dy).text(lines[i]); + text.attr("y", y + height / 2).attr("dominant-baseline", "central").attr("alignment-baseline", "central"); + _setTextAttrs(text, textAttrs); + } + } + function byFo(content, g, x, y, width, height, textAttrs, conf2) { + const s = g.append("switch"); + const f = s.append("foreignObject").attr("x", x).attr("y", y).attr("width", width).attr("height", height); + const text = f.append("xhtml:div").style("display", "table").style("height", "100%").style("width", "100%"); + text.append("div").style("display", "table-cell").style("text-align", "center").style("vertical-align", "middle").text(content); + byTspan(content, s, x, y, width, height, textAttrs, conf2); + _setTextAttrs(text, textAttrs); + } + async function byKatex(content, g, x, y, width, height, textAttrs, conf2) { + const dim = await calculateMathMLDimensions(content, getConfig$1()); + const s = g.append("switch"); + const f = s.append("foreignObject").attr("x", x + width / 2 - dim.width / 2).attr("y", y + height / 2 - dim.height / 2).attr("width", dim.width).attr("height", dim.height); + const text = f.append("xhtml:div").style("height", "100%").style("width", "100%"); + text.append("div").style("text-align", "center").style("vertical-align", "middle").html(await renderKatex(content, getConfig$1())); + byTspan(content, s, x, y, width, height, textAttrs, conf2); + _setTextAttrs(text, textAttrs); + } + function _setTextAttrs(toText, fromTextAttrsDict) { + for (const key in fromTextAttrsDict) { + if (fromTextAttrsDict.hasOwnProperty(key)) { + toText.attr(key, fromTextAttrsDict[key]); + } + } + } + return function(conf2, hasKatex2 = false) { + if (hasKatex2) { + return byKatex; + } + return conf2.textPlacement === "fo" ? byFo : conf2.textPlacement === "old" ? byText : byTspan; + }; +}(); +const _drawMenuItemTextCandidateFunc = function() { + function byText(content, g, x, y, width, height, textAttrs) { + const text = g.append("text").attr("x", x).attr("y", y).style("text-anchor", "start").text(content); + _setTextAttrs(text, textAttrs); + } + function byTspan(content, g, x, y, width, height, textAttrs, conf2) { + const { actorFontSize, actorFontFamily, actorFontWeight } = conf2; + const lines = content.split(common.lineBreakRegex); + for (let i = 0; i < lines.length; i++) { + const dy = i * actorFontSize - actorFontSize * (lines.length - 1) / 2; + const text = g.append("text").attr("x", x).attr("y", y).style("text-anchor", "start").style("font-size", actorFontSize).style("font-weight", actorFontWeight).style("font-family", actorFontFamily); + text.append("tspan").attr("x", x).attr("dy", dy).text(lines[i]); + text.attr("y", y + height / 2).attr("dominant-baseline", "central").attr("alignment-baseline", "central"); + _setTextAttrs(text, textAttrs); + } + } + function byFo(content, g, x, y, width, height, textAttrs, conf2) { + const s = g.append("switch"); + const f = s.append("foreignObject").attr("x", x).attr("y", y).attr("width", width).attr("height", height); + const text = f.append("xhtml:div").style("display", "table").style("height", "100%").style("width", "100%"); + text.append("div").style("display", "table-cell").style("text-align", "center").style("vertical-align", "middle").text(content); + byTspan(content, s, x, y, width, height, textAttrs, conf2); + _setTextAttrs(text, textAttrs); + } + function _setTextAttrs(toText, fromTextAttrsDict) { + for (const key in fromTextAttrsDict) { + if (fromTextAttrsDict.hasOwnProperty(key)) { + toText.attr(key, fromTextAttrsDict[key]); + } + } + } + return function(conf2) { + return conf2.textPlacement === "fo" ? byFo : conf2.textPlacement === "old" ? byText : byTspan; + }; +}(); +const svgDraw = { + drawRect, + drawText, + drawLabel, + drawActor, + drawBox, + drawPopup, + anchorElement, + drawActivation, + drawLoop, + drawBackgroundRect, + insertArrowHead, + insertArrowFilledHead, + insertSequenceNumber, + insertArrowCrossHead, + insertDatabaseIcon, + insertComputerIcon, + insertClockIcon, + getTextObj, + getNoteRect, + fixLifeLineHeights, + sanitizeUrl: dist.sanitizeUrl +}; +let conf = {}; +const bounds = { + 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((actor) => actor.height || 0) + ) + (this.loops.length === 0 ? 0 : this.loops.map((it) => it.height || 0).reduce((acc, h) => acc + h)) + (this.messages.length === 0 ? 0 : this.messages.map((it) => it.height || 0).reduce((acc, h) => acc + h)) + (this.notes.length === 0 ? 0 : this.notes.map((it) => it.height || 0).reduce((acc, h) => acc + h)); + }, + clear: function() { + this.actors = []; + this.boxes = []; + this.loops = []; + this.messages = []; + this.notes = []; + }, + addBox: function(boxModel) { + this.boxes.push(boxModel); + }, + addActor: function(actorModel) { + this.actors.push(actorModel); + }, + addLoop: function(loopModel) { + this.loops.push(loopModel); + }, + addMessage: function(msgModel) { + this.messages.push(msgModel); + }, + addNote: function(noteModel) { + this.notes.push(noteModel); + }, + 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; + setConf(getConfig()); + }, + updateVal: function(obj, key, val, fun) { + if (obj[key] === void 0) { + obj[key] = val; + } else { + obj[key] = fun(val, obj[key]); + } + }, + updateBounds: function(startx, starty, stopx, stopy) { + const _self = this; + let cnt = 0; + function updateFn(type) { + return function updateItemBounds(item) { + cnt++; + const n = _self.sequenceItems.length - cnt + 1; + _self.updateVal(item, "starty", starty - n * conf.boxMargin, Math.min); + _self.updateVal(item, "stopy", stopy + n * conf.boxMargin, Math.max); + _self.updateVal(bounds.data, "startx", startx - n * conf.boxMargin, Math.min); + _self.updateVal(bounds.data, "stopx", stopx + n * conf.boxMargin, Math.max); + if (!(type === "activation")) { + _self.updateVal(item, "startx", startx - n * conf.boxMargin, Math.min); + _self.updateVal(item, "stopx", stopx + n * conf.boxMargin, Math.max); + _self.updateVal(bounds.data, "starty", starty - n * conf.boxMargin, Math.min); + _self.updateVal(bounds.data, "stopy", stopy + n * conf.boxMargin, Math.max); + } + }; + } + this.sequenceItems.forEach(updateFn()); + this.activations.forEach(updateFn("activation")); + }, + insert: function(startx, starty, stopx, stopy) { + const _startx = common.getMin(startx, stopx); + const _stopx = common.getMax(startx, stopx); + const _starty = common.getMin(starty, stopy); + const _stopy = common.getMax(starty, stopy); + this.updateVal(bounds.data, "startx", _startx, Math.min); + this.updateVal(bounds.data, "starty", _starty, Math.min); + this.updateVal(bounds.data, "stopx", _stopx, Math.max); + this.updateVal(bounds.data, "stopy", _stopy, Math.max); + this.updateBounds(_startx, _starty, _stopx, _stopy); + }, + newActivation: function(message, diagram2, actors) { + const actorRect = actors[message.from.actor]; + const stackedSize = actorActivations(message.from.actor).length || 0; + const x = actorRect.x + actorRect.width / 2 + (stackedSize - 1) * conf.activationWidth / 2; + this.activations.push({ + startx: x, + starty: this.verticalPos + 2, + stopx: x + conf.activationWidth, + stopy: void 0, + actor: message.from.actor, + anchored: svgDraw.anchorElement(diagram2) + }); + }, + endActivation: function(message) { + const lastActorActivationIdx = this.activations.map(function(activation) { + return activation.actor; + }).lastIndexOf(message.from.actor); + return this.activations.splice(lastActorActivationIdx, 1)[0]; + }, + createLoop: function(title = { message: void 0, wrap: false, width: void 0 }, fill) { + return { + startx: void 0, + starty: this.verticalPos, + stopx: void 0, + stopy: void 0, + title: title.message, + wrap: title.wrap, + width: title.width, + height: 0, + fill + }; + }, + newLoop: function(title = { message: void 0, wrap: false, width: void 0 }, fill) { + this.sequenceItems.push(this.createLoop(title, fill)); + }, + endLoop: function() { + return this.sequenceItems.pop(); + }, + isLoopOverlap: function() { + return this.sequenceItems.length ? this.sequenceItems[this.sequenceItems.length - 1].overlap : false; + }, + addSectionToLoop: function(message) { + const loop = this.sequenceItems.pop(); + loop.sections = loop.sections || []; + loop.sectionTitles = loop.sectionTitles || []; + loop.sections.push({ y: bounds.getVerticalPos(), height: 0 }); + loop.sectionTitles.push(message); + this.sequenceItems.push(loop); + }, + saveVerticalPos: function() { + if (this.isLoopOverlap()) { + this.savedVerticalPos = this.verticalPos; + } + }, + resetVerticalPos: function() { + if (this.isLoopOverlap()) { + this.verticalPos = this.savedVerticalPos; + } + }, + bumpVerticalPos: function(bump) { + this.verticalPos = this.verticalPos + bump; + this.data.stopy = common.getMax(this.data.stopy, this.verticalPos); + }, + getVerticalPos: function() { + return this.verticalPos; + }, + getBounds: function() { + return { bounds: this.data, models: this.models }; + } +}; +const drawNote = async function(elem, noteModel) { + bounds.bumpVerticalPos(conf.boxMargin); + noteModel.height = conf.boxMargin; + noteModel.starty = bounds.getVerticalPos(); + const rect = getNoteRect$1(); + rect.x = noteModel.startx; + rect.y = noteModel.starty; + rect.width = noteModel.width || conf.width; + rect.class = "note"; + const g = elem.append("g"); + const rectElem = svgDraw.drawRect(g, rect); + const textObj = getTextObj$1(); + textObj.x = noteModel.startx; + textObj.y = noteModel.starty; + textObj.width = rect.width; + textObj.dy = "1em"; + textObj.text = noteModel.message; + textObj.class = "noteText"; + textObj.fontFamily = conf.noteFontFamily; + textObj.fontSize = conf.noteFontSize; + textObj.fontWeight = conf.noteFontWeight; + textObj.anchor = conf.noteAlign; + textObj.textMargin = conf.noteMargin; + textObj.valign = "center"; + const textElem = hasKatex(textObj.text) ? await drawKatex(g, textObj) : drawText(g, textObj); + const textHeight = Math.round( + textElem.map((te) => (te._groups || te)[0][0].getBBox().height).reduce((acc, curr) => acc + curr) + ); + rectElem.attr("height", textHeight + 2 * conf.noteMargin); + noteModel.height += textHeight + 2 * conf.noteMargin; + bounds.bumpVerticalPos(textHeight + 2 * conf.noteMargin); + noteModel.stopy = noteModel.starty + textHeight + 2 * conf.noteMargin; + noteModel.stopx = noteModel.startx + rect.width; + bounds.insert(noteModel.startx, noteModel.starty, noteModel.stopx, noteModel.stopy); + bounds.models.addNote(noteModel); +}; +const messageFont = (cnf) => { + return { + fontFamily: cnf.messageFontFamily, + fontSize: cnf.messageFontSize, + fontWeight: cnf.messageFontWeight + }; +}; +const noteFont = (cnf) => { + return { + fontFamily: cnf.noteFontFamily, + fontSize: cnf.noteFontSize, + fontWeight: cnf.noteFontWeight + }; +}; +const actorFont = (cnf) => { + return { + fontFamily: cnf.actorFontFamily, + fontSize: cnf.actorFontSize, + fontWeight: cnf.actorFontWeight + }; +}; +async function boundMessage(_diagram, msgModel) { + bounds.bumpVerticalPos(10); + const { startx, stopx, message } = msgModel; + const lines = common.splitBreaks(message).length; + const isKatexMsg = hasKatex(message); + const textDims = isKatexMsg ? await calculateMathMLDimensions(message, getConfig()) : utils.calculateTextDimensions(message, messageFont(conf)); + if (!isKatexMsg) { + const lineHeight = textDims.height / lines; + msgModel.height += lineHeight; + bounds.bumpVerticalPos(lineHeight); + } + let lineStartY; + let totalOffset = textDims.height - 10; + const textWidth = textDims.width; + if (startx === stopx) { + lineStartY = bounds.getVerticalPos() + totalOffset; + if (!conf.rightAngles) { + totalOffset += conf.boxMargin; + lineStartY = bounds.getVerticalPos() + totalOffset; + } + totalOffset += 30; + const dx = common.getMax(textWidth / 2, conf.width / 2); + bounds.insert( + startx - dx, + bounds.getVerticalPos() - 10 + totalOffset, + stopx + dx, + bounds.getVerticalPos() + 30 + totalOffset + ); + } else { + totalOffset += conf.boxMargin; + lineStartY = bounds.getVerticalPos() + totalOffset; + bounds.insert(startx, lineStartY - 10, stopx, lineStartY); + } + bounds.bumpVerticalPos(totalOffset); + msgModel.height += totalOffset; + msgModel.stopy = msgModel.starty + msgModel.height; + bounds.insert(msgModel.fromBounds, msgModel.starty, msgModel.toBounds, msgModel.stopy); + return lineStartY; +} +const drawMessage = async function(diagram2, msgModel, lineStartY, diagObj) { + const { startx, stopx, starty, message, type, sequenceIndex, sequenceVisible } = msgModel; + const textDims = utils.calculateTextDimensions(message, messageFont(conf)); + const textObj = getTextObj$1(); + textObj.x = startx; + textObj.y = starty + 10; + textObj.width = stopx - startx; + textObj.class = "messageText"; + textObj.dy = "1em"; + textObj.text = message; + textObj.fontFamily = conf.messageFontFamily; + textObj.fontSize = conf.messageFontSize; + textObj.fontWeight = conf.messageFontWeight; + textObj.anchor = conf.messageAlign; + textObj.valign = "center"; + textObj.textMargin = conf.wrapPadding; + textObj.tspan = false; + hasKatex(textObj.text) ? await drawKatex(diagram2, textObj, { startx, stopx, starty: lineStartY }) : drawText(diagram2, textObj); + const textWidth = textDims.width; + let line; + if (startx === stopx) { + if (conf.rightAngles) { + line = diagram2.append("path").attr( + "d", + `M ${startx},${lineStartY} H ${startx + common.getMax(conf.width / 2, textWidth / 2)} V ${lineStartY + 25} H ${startx}` + ); + } else { + line = diagram2.append("path").attr( + "d", + "M " + startx + "," + lineStartY + " C " + (startx + 60) + "," + (lineStartY - 10) + " " + (startx + 60) + "," + (lineStartY + 30) + " " + startx + "," + (lineStartY + 20) + ); + } + } else { + line = diagram2.append("line"); + line.attr("x1", startx); + line.attr("y1", lineStartY); + line.attr("x2", stopx); + line.attr("y2", lineStartY); + } + if (type === diagObj.db.LINETYPE.DOTTED || type === diagObj.db.LINETYPE.DOTTED_CROSS || type === diagObj.db.LINETYPE.DOTTED_POINT || type === diagObj.db.LINETYPE.DOTTED_OPEN) { + line.style("stroke-dasharray", "3, 3"); + line.attr("class", "messageLine1"); + } else { + line.attr("class", "messageLine0"); + } + let url = ""; + if (conf.arrowMarkerAbsolute) { + url = window.location.protocol + "//" + window.location.host + window.location.pathname + window.location.search; + url = url.replace(/\(/g, "\\("); + url = url.replace(/\)/g, "\\)"); + } + line.attr("stroke-width", 2); + line.attr("stroke", "none"); + line.style("fill", "none"); + if (type === diagObj.db.LINETYPE.SOLID || type === diagObj.db.LINETYPE.DOTTED) { + line.attr("marker-end", "url(" + url + "#arrowhead)"); + } + if (type === diagObj.db.LINETYPE.SOLID_POINT || type === diagObj.db.LINETYPE.DOTTED_POINT) { + line.attr("marker-end", "url(" + url + "#filled-head)"); + } + if (type === diagObj.db.LINETYPE.SOLID_CROSS || type === diagObj.db.LINETYPE.DOTTED_CROSS) { + line.attr("marker-end", "url(" + url + "#crosshead)"); + } + if (sequenceVisible || conf.showSequenceNumbers) { + line.attr("marker-start", "url(" + url + "#sequencenumber)"); + diagram2.append("text").attr("x", startx).attr("y", lineStartY + 4).attr("font-family", "sans-serif").attr("font-size", "12px").attr("text-anchor", "middle").attr("class", "sequenceNumber").text(sequenceIndex); + } +}; +const addActorRenderingData = async function(diagram2, actors, createdActors, actorKeys, verticalPos, messages, isFooter) { + let prevWidth = 0; + let prevMargin = 0; + let prevBox = void 0; + let maxHeight = 0; + for (const actorKey of actorKeys) { + const actor = actors[actorKey]; + const box = actor.box; + if (prevBox && prevBox != box) { + if (!isFooter) { + bounds.models.addBox(prevBox); + } + prevMargin += conf.boxMargin + prevBox.margin; + } + if (box && box != prevBox) { + if (!isFooter) { + box.x = prevWidth + prevMargin; + box.y = verticalPos; + } + prevMargin += box.margin; + } + actor.width = actor.width || conf.width; + actor.height = common.getMax(actor.height || conf.height, conf.height); + actor.margin = actor.margin || conf.actorMargin; + maxHeight = common.getMax(maxHeight, actor.height); + if (createdActors[actor.name]) { + prevMargin += actor.width / 2; + } + actor.x = prevWidth + prevMargin; + actor.starty = bounds.getVerticalPos(); + bounds.insert(actor.x, verticalPos, actor.x + actor.width, actor.height); + prevWidth += actor.width + prevMargin; + if (actor.box) { + actor.box.width = prevWidth + box.margin - actor.box.x; + } + prevMargin = actor.margin; + prevBox = actor.box; + bounds.models.addActor(actor); + } + if (prevBox && !isFooter) { + bounds.models.addBox(prevBox); + } + bounds.bumpVerticalPos(maxHeight); +}; +const drawActors = async function(diagram2, actors, actorKeys, isFooter) { + if (!isFooter) { + for (const actorKey of actorKeys) { + const actor = actors[actorKey]; + await svgDraw.drawActor(diagram2, actor, conf, false); + } + } else { + let maxHeight = 0; + bounds.bumpVerticalPos(conf.boxMargin * 2); + for (const actorKey of actorKeys) { + const actor = actors[actorKey]; + if (!actor.stopy) { + actor.stopy = bounds.getVerticalPos(); + } + const height = await svgDraw.drawActor(diagram2, actor, conf, true); + maxHeight = common.getMax(maxHeight, height); + } + bounds.bumpVerticalPos(maxHeight + conf.boxMargin); + } +}; +const drawActorsPopup = function(diagram2, actors, actorKeys, doc) { + let maxHeight = 0; + let maxWidth = 0; + for (const actorKey of actorKeys) { + const actor = actors[actorKey]; + const minMenuWidth = getRequiredPopupWidth(actor); + const menuDimensions = svgDraw.drawPopup( + diagram2, + actor, + minMenuWidth, + conf, + conf.forceMenus, + doc + ); + if (menuDimensions.height > maxHeight) { + maxHeight = menuDimensions.height; + } + if (menuDimensions.width + actor.x > maxWidth) { + maxWidth = menuDimensions.width + actor.x; + } + } + return { maxHeight, maxWidth }; +}; +const setConf = function(cnf) { + assignWithDepth(conf, cnf); + if (cnf.fontFamily) { + conf.actorFontFamily = conf.noteFontFamily = conf.messageFontFamily = cnf.fontFamily; + } + if (cnf.fontSize) { + conf.actorFontSize = conf.noteFontSize = conf.messageFontSize = cnf.fontSize; + } + if (cnf.fontWeight) { + conf.actorFontWeight = conf.noteFontWeight = conf.messageFontWeight = cnf.fontWeight; + } +}; +const actorActivations = function(actor) { + return bounds.activations.filter(function(activation) { + return activation.actor === actor; + }); +}; +const activationBounds = function(actor, actors) { + const actorObj = actors[actor]; + const activations = actorActivations(actor); + const left = activations.reduce(function(acc, activation) { + return common.getMin(acc, activation.startx); + }, actorObj.x + actorObj.width / 2 - 1); + const right = activations.reduce(function(acc, activation) { + return common.getMax(acc, activation.stopx); + }, actorObj.x + actorObj.width / 2 + 1); + return [left, right]; +}; +function adjustLoopHeightForWrap(loopWidths, msg, preMargin, postMargin, addLoopFn) { + bounds.bumpVerticalPos(preMargin); + let heightAdjust = postMargin; + if (msg.id && msg.message && loopWidths[msg.id]) { + const loopWidth = loopWidths[msg.id].width; + const textConf = messageFont(conf); + msg.message = utils.wrapLabel(`[${msg.message}]`, loopWidth - 2 * conf.wrapPadding, textConf); + msg.width = loopWidth; + msg.wrap = true; + const textDims = utils.calculateTextDimensions(msg.message, textConf); + const totalOffset = common.getMax(textDims.height, conf.labelBoxHeight); + heightAdjust = postMargin + totalOffset; + log.debug(`${totalOffset} - ${msg.message}`); + } + addLoopFn(msg); + bounds.bumpVerticalPos(heightAdjust); +} +function adjustCreatedDestroyedData(msg, msgModel, lineStartY, index, actors, createdActors, destroyedActors) { + function receiverAdjustment(actor, adjustment) { + if (actor.x < actors[msg.from].x) { + bounds.insert( + msgModel.stopx - adjustment, + msgModel.starty, + msgModel.startx, + msgModel.stopy + actor.height / 2 + conf.noteMargin + ); + msgModel.stopx = msgModel.stopx + adjustment; + } else { + bounds.insert( + msgModel.startx, + msgModel.starty, + msgModel.stopx + adjustment, + msgModel.stopy + actor.height / 2 + conf.noteMargin + ); + msgModel.stopx = msgModel.stopx - adjustment; + } + } + function senderAdjustment(actor, adjustment) { + if (actor.x < actors[msg.to].x) { + bounds.insert( + msgModel.startx - adjustment, + msgModel.starty, + msgModel.stopx, + msgModel.stopy + actor.height / 2 + conf.noteMargin + ); + msgModel.startx = msgModel.startx + adjustment; + } else { + bounds.insert( + msgModel.stopx, + msgModel.starty, + msgModel.startx + adjustment, + msgModel.stopy + actor.height / 2 + conf.noteMargin + ); + msgModel.startx = msgModel.startx - adjustment; + } + } + if (createdActors[msg.to] == index) { + const actor = actors[msg.to]; + const adjustment = actor.type == "actor" ? ACTOR_TYPE_WIDTH / 2 + 3 : actor.width / 2 + 3; + receiverAdjustment(actor, adjustment); + actor.starty = lineStartY - actor.height / 2; + bounds.bumpVerticalPos(actor.height / 2); + } else if (destroyedActors[msg.from] == index) { + const actor = actors[msg.from]; + if (conf.mirrorActors) { + const adjustment = actor.type == "actor" ? ACTOR_TYPE_WIDTH / 2 : actor.width / 2; + senderAdjustment(actor, adjustment); + } + actor.stopy = lineStartY - actor.height / 2; + bounds.bumpVerticalPos(actor.height / 2); + } else if (destroyedActors[msg.to] == index) { + const actor = actors[msg.to]; + if (conf.mirrorActors) { + const adjustment = actor.type == "actor" ? ACTOR_TYPE_WIDTH / 2 + 3 : actor.width / 2 + 3; + receiverAdjustment(actor, adjustment); + } + actor.stopy = lineStartY - actor.height / 2; + bounds.bumpVerticalPos(actor.height / 2); + } +} +const draw = async function(_text, id, _version, diagObj) { + const { securityLevel, sequence } = getConfig(); + conf = sequence; + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = d3select("#i" + id); + } + const root = securityLevel === "sandbox" ? d3select(sandboxElement.nodes()[0].contentDocument.body) : d3select("body"); + const doc = securityLevel === "sandbox" ? sandboxElement.nodes()[0].contentDocument : document; + bounds.init(); + log.debug(diagObj.db); + const diagram2 = securityLevel === "sandbox" ? root.select(`[id="${id}"]`) : d3select(`[id="${id}"]`); + const actors = diagObj.db.getActors(); + const createdActors = diagObj.db.getCreatedActors(); + const destroyedActors = diagObj.db.getDestroyedActors(); + const boxes = diagObj.db.getBoxes(); + let actorKeys = diagObj.db.getActorKeys(); + const messages = diagObj.db.getMessages(); + const title = diagObj.db.getDiagramTitle(); + const hasBoxes = diagObj.db.hasAtLeastOneBox(); + const hasBoxTitles = diagObj.db.hasAtLeastOneBoxWithTitle(); + const maxMessageWidthPerActor = await getMaxMessageWidthPerActor(actors, messages, diagObj); + conf.height = await calculateActorMargins(actors, maxMessageWidthPerActor, boxes); + svgDraw.insertComputerIcon(diagram2); + svgDraw.insertDatabaseIcon(diagram2); + svgDraw.insertClockIcon(diagram2); + if (hasBoxes) { + bounds.bumpVerticalPos(conf.boxMargin); + if (hasBoxTitles) { + bounds.bumpVerticalPos(boxes[0].textMaxHeight); + } + } + if (conf.hideUnusedParticipants === true) { + const newActors = /* @__PURE__ */ new Set(); + messages.forEach((message) => { + newActors.add(message.from); + newActors.add(message.to); + }); + actorKeys = actorKeys.filter((actorKey) => newActors.has(actorKey)); + } + await addActorRenderingData(diagram2, actors, createdActors, actorKeys, 0, messages, false); + const loopWidths = await calculateLoopBounds(messages, actors, maxMessageWidthPerActor, diagObj); + svgDraw.insertArrowHead(diagram2); + svgDraw.insertArrowCrossHead(diagram2); + svgDraw.insertArrowFilledHead(diagram2); + svgDraw.insertSequenceNumber(diagram2); + function activeEnd(msg, verticalPos) { + const activationData = bounds.endActivation(msg); + if (activationData.starty + 18 > verticalPos) { + activationData.starty = verticalPos - 6; + verticalPos += 12; + } + svgDraw.drawActivation( + diagram2, + activationData, + verticalPos, + conf, + actorActivations(msg.from.actor).length + ); + bounds.insert(activationData.startx, verticalPos - 10, activationData.stopx, verticalPos); + } + let sequenceIndex = 1; + let sequenceIndexStep = 1; + const messagesToDraw = []; + const backgrounds = []; + let index = 0; + for (const msg of messages) { + let loopModel, noteModel, msgModel; + switch (msg.type) { + case diagObj.db.LINETYPE.NOTE: + bounds.resetVerticalPos(); + noteModel = msg.noteModel; + await drawNote(diagram2, noteModel); + break; + case diagObj.db.LINETYPE.ACTIVE_START: + bounds.newActivation(msg, diagram2, actors); + break; + case diagObj.db.LINETYPE.ACTIVE_END: + activeEnd(msg, bounds.getVerticalPos()); + break; + case diagObj.db.LINETYPE.LOOP_START: + adjustLoopHeightForWrap( + loopWidths, + msg, + conf.boxMargin, + conf.boxMargin + conf.boxTextMargin, + (message) => bounds.newLoop(message) + ); + break; + case diagObj.db.LINETYPE.LOOP_END: + loopModel = bounds.endLoop(); + await svgDraw.drawLoop(diagram2, loopModel, "loop", conf); + bounds.bumpVerticalPos(loopModel.stopy - bounds.getVerticalPos()); + bounds.models.addLoop(loopModel); + break; + case diagObj.db.LINETYPE.RECT_START: + adjustLoopHeightForWrap( + loopWidths, + msg, + conf.boxMargin, + conf.boxMargin, + (message) => bounds.newLoop(void 0, message.message) + ); + break; + case diagObj.db.LINETYPE.RECT_END: + loopModel = bounds.endLoop(); + backgrounds.push(loopModel); + bounds.models.addLoop(loopModel); + bounds.bumpVerticalPos(loopModel.stopy - bounds.getVerticalPos()); + break; + case diagObj.db.LINETYPE.OPT_START: + adjustLoopHeightForWrap( + loopWidths, + msg, + conf.boxMargin, + conf.boxMargin + conf.boxTextMargin, + (message) => bounds.newLoop(message) + ); + break; + case diagObj.db.LINETYPE.OPT_END: + loopModel = bounds.endLoop(); + await svgDraw.drawLoop(diagram2, loopModel, "opt", conf); + bounds.bumpVerticalPos(loopModel.stopy - bounds.getVerticalPos()); + bounds.models.addLoop(loopModel); + break; + case diagObj.db.LINETYPE.ALT_START: + adjustLoopHeightForWrap( + loopWidths, + msg, + conf.boxMargin, + conf.boxMargin + conf.boxTextMargin, + (message) => bounds.newLoop(message) + ); + break; + case diagObj.db.LINETYPE.ALT_ELSE: + adjustLoopHeightForWrap( + loopWidths, + msg, + conf.boxMargin + conf.boxTextMargin, + conf.boxMargin, + (message) => bounds.addSectionToLoop(message) + ); + break; + case diagObj.db.LINETYPE.ALT_END: + loopModel = bounds.endLoop(); + await svgDraw.drawLoop(diagram2, loopModel, "alt", conf); + bounds.bumpVerticalPos(loopModel.stopy - bounds.getVerticalPos()); + bounds.models.addLoop(loopModel); + break; + case diagObj.db.LINETYPE.PAR_START: + case diagObj.db.LINETYPE.PAR_OVER_START: + adjustLoopHeightForWrap( + loopWidths, + msg, + conf.boxMargin, + conf.boxMargin + conf.boxTextMargin, + (message) => bounds.newLoop(message) + ); + bounds.saveVerticalPos(); + break; + case diagObj.db.LINETYPE.PAR_AND: + adjustLoopHeightForWrap( + loopWidths, + msg, + conf.boxMargin + conf.boxTextMargin, + conf.boxMargin, + (message) => bounds.addSectionToLoop(message) + ); + break; + case diagObj.db.LINETYPE.PAR_END: + loopModel = bounds.endLoop(); + await svgDraw.drawLoop(diagram2, loopModel, "par", conf); + bounds.bumpVerticalPos(loopModel.stopy - bounds.getVerticalPos()); + bounds.models.addLoop(loopModel); + break; + case diagObj.db.LINETYPE.AUTONUMBER: + sequenceIndex = msg.message.start || sequenceIndex; + sequenceIndexStep = msg.message.step || sequenceIndexStep; + if (msg.message.visible) { + diagObj.db.enableSequenceNumbers(); + } else { + diagObj.db.disableSequenceNumbers(); + } + break; + case diagObj.db.LINETYPE.CRITICAL_START: + adjustLoopHeightForWrap( + loopWidths, + msg, + conf.boxMargin, + conf.boxMargin + conf.boxTextMargin, + (message) => bounds.newLoop(message) + ); + break; + case diagObj.db.LINETYPE.CRITICAL_OPTION: + adjustLoopHeightForWrap( + loopWidths, + msg, + conf.boxMargin + conf.boxTextMargin, + conf.boxMargin, + (message) => bounds.addSectionToLoop(message) + ); + break; + case diagObj.db.LINETYPE.CRITICAL_END: + loopModel = bounds.endLoop(); + await svgDraw.drawLoop(diagram2, loopModel, "critical", conf); + bounds.bumpVerticalPos(loopModel.stopy - bounds.getVerticalPos()); + bounds.models.addLoop(loopModel); + break; + case diagObj.db.LINETYPE.BREAK_START: + adjustLoopHeightForWrap( + loopWidths, + msg, + conf.boxMargin, + conf.boxMargin + conf.boxTextMargin, + (message) => bounds.newLoop(message) + ); + break; + case diagObj.db.LINETYPE.BREAK_END: + loopModel = bounds.endLoop(); + await svgDraw.drawLoop(diagram2, loopModel, "break", conf); + bounds.bumpVerticalPos(loopModel.stopy - bounds.getVerticalPos()); + bounds.models.addLoop(loopModel); + break; + default: + try { + msgModel = msg.msgModel; + msgModel.starty = bounds.getVerticalPos(); + msgModel.sequenceIndex = sequenceIndex; + msgModel.sequenceVisible = diagObj.db.showSequenceNumbers(); + const lineStartY = await boundMessage(diagram2, msgModel); + adjustCreatedDestroyedData( + msg, + msgModel, + lineStartY, + index, + actors, + createdActors, + destroyedActors + ); + messagesToDraw.push({ messageModel: msgModel, lineStartY }); + bounds.models.addMessage(msgModel); + } catch (e) { + log.error("error while drawing message", e); + } + } + if ([ + diagObj.db.LINETYPE.SOLID_OPEN, + diagObj.db.LINETYPE.DOTTED_OPEN, + diagObj.db.LINETYPE.SOLID, + diagObj.db.LINETYPE.DOTTED, + diagObj.db.LINETYPE.SOLID_CROSS, + diagObj.db.LINETYPE.DOTTED_CROSS, + diagObj.db.LINETYPE.SOLID_POINT, + diagObj.db.LINETYPE.DOTTED_POINT + ].includes(msg.type)) { + sequenceIndex = sequenceIndex + sequenceIndexStep; + } + index++; + } + log.debug("createdActors", createdActors); + log.debug("destroyedActors", destroyedActors); + await drawActors(diagram2, actors, actorKeys, false); + for (const e of messagesToDraw) { + await drawMessage(diagram2, e.messageModel, e.lineStartY, diagObj); + } + if (conf.mirrorActors) { + await drawActors(diagram2, actors, actorKeys, true); + } + backgrounds.forEach((e) => svgDraw.drawBackgroundRect(diagram2, e)); + fixLifeLineHeights(diagram2, actors, actorKeys, conf); + for (const box2 of bounds.models.boxes) { + box2.height = bounds.getVerticalPos() - box2.y; + bounds.insert(box2.x, box2.y, box2.x + box2.width, box2.height); + box2.startx = box2.x; + box2.starty = box2.y; + box2.stopx = box2.startx + box2.width; + box2.stopy = box2.starty + box2.height; + box2.stroke = "rgb(0,0,0, 0.5)"; + await svgDraw.drawBox(diagram2, box2, conf); + } + if (hasBoxes) { + bounds.bumpVerticalPos(conf.boxMargin); + } + const requiredBoxSize = drawActorsPopup(diagram2, actors, actorKeys, doc); + const { bounds: box } = bounds.getBounds(); + let boxHeight = box.stopy - box.starty; + if (boxHeight < requiredBoxSize.maxHeight) { + boxHeight = requiredBoxSize.maxHeight; + } + let height = boxHeight + 2 * conf.diagramMarginY; + if (conf.mirrorActors) { + height = height - conf.boxMargin + conf.bottomMarginAdj; + } + let boxWidth = box.stopx - box.startx; + if (boxWidth < requiredBoxSize.maxWidth) { + boxWidth = requiredBoxSize.maxWidth; + } + const width = boxWidth + 2 * conf.diagramMarginX; + if (title) { + diagram2.append("text").text(title).attr("x", (box.stopx - box.startx) / 2 - 2 * conf.diagramMarginX).attr("y", -25); + } + configureSvgSize(diagram2, height, width, conf.useMaxWidth); + const extraVertForTitle = title ? 40 : 0; + diagram2.attr( + "viewBox", + box.startx - conf.diagramMarginX + " -" + (conf.diagramMarginY + extraVertForTitle) + " " + width + " " + (height + extraVertForTitle) + ); + log.debug(`models:`, bounds.models); +}; +async function getMaxMessageWidthPerActor(actors, messages, diagObj) { + const maxMessageWidthPerActor = {}; + for (const msg of messages) { + if (actors[msg.to] && actors[msg.from]) { + const actor = actors[msg.to]; + if (msg.placement === diagObj.db.PLACEMENT.LEFTOF && !actor.prevActor) { + continue; + } + if (msg.placement === diagObj.db.PLACEMENT.RIGHTOF && !actor.nextActor) { + continue; + } + const isNote = msg.placement !== void 0; + const isMessage = !isNote; + const textFont = isNote ? noteFont(conf) : messageFont(conf); + const wrappedMessage = msg.wrap ? utils.wrapLabel(msg.message, conf.width - 2 * conf.wrapPadding, textFont) : msg.message; + const messageDimensions = hasKatex(wrappedMessage) ? await calculateMathMLDimensions(msg.message, getConfig()) : utils.calculateTextDimensions(wrappedMessage, textFont); + const messageWidth = messageDimensions.width + 2 * conf.wrapPadding; + if (isMessage && msg.from === actor.nextActor) { + maxMessageWidthPerActor[msg.to] = common.getMax( + maxMessageWidthPerActor[msg.to] || 0, + messageWidth + ); + } else if (isMessage && msg.from === actor.prevActor) { + maxMessageWidthPerActor[msg.from] = common.getMax( + maxMessageWidthPerActor[msg.from] || 0, + messageWidth + ); + } else if (isMessage && msg.from === msg.to) { + maxMessageWidthPerActor[msg.from] = common.getMax( + maxMessageWidthPerActor[msg.from] || 0, + messageWidth / 2 + ); + maxMessageWidthPerActor[msg.to] = common.getMax( + maxMessageWidthPerActor[msg.to] || 0, + messageWidth / 2 + ); + } else if (msg.placement === diagObj.db.PLACEMENT.RIGHTOF) { + maxMessageWidthPerActor[msg.from] = common.getMax( + maxMessageWidthPerActor[msg.from] || 0, + messageWidth + ); + } else if (msg.placement === diagObj.db.PLACEMENT.LEFTOF) { + maxMessageWidthPerActor[actor.prevActor] = common.getMax( + maxMessageWidthPerActor[actor.prevActor] || 0, + messageWidth + ); + } else if (msg.placement === diagObj.db.PLACEMENT.OVER) { + if (actor.prevActor) { + maxMessageWidthPerActor[actor.prevActor] = common.getMax( + maxMessageWidthPerActor[actor.prevActor] || 0, + messageWidth / 2 + ); + } + if (actor.nextActor) { + maxMessageWidthPerActor[msg.from] = common.getMax( + maxMessageWidthPerActor[msg.from] || 0, + messageWidth / 2 + ); + } + } + } + } + log.debug("maxMessageWidthPerActor:", maxMessageWidthPerActor); + return maxMessageWidthPerActor; +} +const getRequiredPopupWidth = function(actor) { + let requiredPopupWidth = 0; + const textFont = actorFont(conf); + for (const key in actor.links) { + const labelDimensions = utils.calculateTextDimensions(key, textFont); + const labelWidth = labelDimensions.width + 2 * conf.wrapPadding + 2 * conf.boxMargin; + if (requiredPopupWidth < labelWidth) { + requiredPopupWidth = labelWidth; + } + } + return requiredPopupWidth; +}; +async function calculateActorMargins(actors, actorToMessageWidth, boxes) { + let maxHeight = 0; + for (const prop of Object.keys(actors)) { + const actor = actors[prop]; + if (actor.wrap) { + actor.description = utils.wrapLabel( + actor.description, + conf.width - 2 * conf.wrapPadding, + actorFont(conf) + ); + } + const actDims = hasKatex(actor.description) ? await calculateMathMLDimensions(actor.description, getConfig()) : utils.calculateTextDimensions(actor.description, actorFont(conf)); + actor.width = actor.wrap ? conf.width : common.getMax(conf.width, actDims.width + 2 * conf.wrapPadding); + actor.height = actor.wrap ? common.getMax(actDims.height, conf.height) : conf.height; + maxHeight = common.getMax(maxHeight, actor.height); + } + for (const actorKey in actorToMessageWidth) { + const actor = actors[actorKey]; + if (!actor) { + continue; + } + const nextActor = actors[actor.nextActor]; + if (!nextActor) { + const messageWidth2 = actorToMessageWidth[actorKey]; + const actorWidth2 = messageWidth2 + conf.actorMargin - actor.width / 2; + actor.margin = common.getMax(actorWidth2, conf.actorMargin); + continue; + } + const messageWidth = actorToMessageWidth[actorKey]; + const actorWidth = messageWidth + conf.actorMargin - actor.width / 2 - nextActor.width / 2; + actor.margin = common.getMax(actorWidth, conf.actorMargin); + } + let maxBoxHeight = 0; + boxes.forEach((box) => { + const textFont = messageFont(conf); + let totalWidth = box.actorKeys.reduce((total, aKey) => { + return total += actors[aKey].width + (actors[aKey].margin || 0); + }, 0); + totalWidth -= 2 * conf.boxTextMargin; + if (box.wrap) { + box.name = utils.wrapLabel(box.name, totalWidth - 2 * conf.wrapPadding, textFont); + } + const boxMsgDimensions = utils.calculateTextDimensions(box.name, textFont); + maxBoxHeight = common.getMax(boxMsgDimensions.height, maxBoxHeight); + const minWidth = common.getMax(totalWidth, boxMsgDimensions.width + 2 * conf.wrapPadding); + box.margin = conf.boxTextMargin; + if (totalWidth < minWidth) { + const missing = (minWidth - totalWidth) / 2; + box.margin += missing; + } + }); + boxes.forEach((box) => box.textMaxHeight = maxBoxHeight); + return common.getMax(maxHeight, conf.height); +} +const buildNoteModel = async function(msg, actors, diagObj) { + const startx = actors[msg.from].x; + const stopx = actors[msg.to].x; + const shouldWrap = msg.wrap && msg.message; + let textDimensions = hasKatex(msg.message) ? await calculateMathMLDimensions(msg.message, getConfig()) : utils.calculateTextDimensions( + shouldWrap ? utils.wrapLabel(msg.message, conf.width, noteFont(conf)) : msg.message, + noteFont(conf) + ); + const noteModel = { + width: shouldWrap ? conf.width : common.getMax(conf.width, textDimensions.width + 2 * conf.noteMargin), + height: 0, + startx: actors[msg.from].x, + stopx: 0, + starty: 0, + stopy: 0, + message: msg.message + }; + if (msg.placement === diagObj.db.PLACEMENT.RIGHTOF) { + noteModel.width = shouldWrap ? common.getMax(conf.width, textDimensions.width) : common.getMax( + actors[msg.from].width / 2 + actors[msg.to].width / 2, + textDimensions.width + 2 * conf.noteMargin + ); + noteModel.startx = startx + (actors[msg.from].width + conf.actorMargin) / 2; + } else if (msg.placement === diagObj.db.PLACEMENT.LEFTOF) { + noteModel.width = shouldWrap ? common.getMax(conf.width, textDimensions.width + 2 * conf.noteMargin) : common.getMax( + actors[msg.from].width / 2 + actors[msg.to].width / 2, + textDimensions.width + 2 * conf.noteMargin + ); + noteModel.startx = startx - noteModel.width + (actors[msg.from].width - conf.actorMargin) / 2; + } else if (msg.to === msg.from) { + textDimensions = utils.calculateTextDimensions( + shouldWrap ? utils.wrapLabel( + msg.message, + common.getMax(conf.width, actors[msg.from].width), + noteFont(conf) + ) : msg.message, + noteFont(conf) + ); + noteModel.width = shouldWrap ? common.getMax(conf.width, actors[msg.from].width) : common.getMax( + actors[msg.from].width, + conf.width, + textDimensions.width + 2 * conf.noteMargin + ); + noteModel.startx = startx + (actors[msg.from].width - noteModel.width) / 2; + } else { + noteModel.width = Math.abs(startx + actors[msg.from].width / 2 - (stopx + actors[msg.to].width / 2)) + conf.actorMargin; + noteModel.startx = startx < stopx ? startx + actors[msg.from].width / 2 - conf.actorMargin / 2 : stopx + actors[msg.to].width / 2 - conf.actorMargin / 2; + } + if (shouldWrap) { + noteModel.message = utils.wrapLabel( + msg.message, + noteModel.width - 2 * conf.wrapPadding, + noteFont(conf) + ); + } + log.debug( + `NM:[${noteModel.startx},${noteModel.stopx},${noteModel.starty},${noteModel.stopy}:${noteModel.width},${noteModel.height}=${msg.message}]` + ); + return noteModel; +}; +const buildMessageModel = function(msg, actors, diagObj) { + if (![ + diagObj.db.LINETYPE.SOLID_OPEN, + diagObj.db.LINETYPE.DOTTED_OPEN, + diagObj.db.LINETYPE.SOLID, + diagObj.db.LINETYPE.DOTTED, + diagObj.db.LINETYPE.SOLID_CROSS, + diagObj.db.LINETYPE.DOTTED_CROSS, + diagObj.db.LINETYPE.SOLID_POINT, + diagObj.db.LINETYPE.DOTTED_POINT + ].includes(msg.type)) { + return {}; + } + const [fromLeft, fromRight] = activationBounds(msg.from, actors); + const [toLeft, toRight] = activationBounds(msg.to, actors); + const isArrowToRight = fromLeft <= toLeft; + const startx = isArrowToRight ? fromRight : fromLeft; + let stopx = isArrowToRight ? toLeft : toRight; + const isArrowToActivation = Math.abs(toLeft - toRight) > 2; + const adjustValue = (value) => { + return isArrowToRight ? -value : value; + }; + if (msg.from === msg.to) { + stopx = startx; + } else { + if (msg.activate && !isArrowToActivation) { + stopx += adjustValue(conf.activationWidth / 2 - 1); + } + if (![diagObj.db.LINETYPE.SOLID_OPEN, diagObj.db.LINETYPE.DOTTED_OPEN].includes(msg.type)) { + stopx += adjustValue(3); + } + } + const allBounds = [fromLeft, fromRight, toLeft, toRight]; + const boundedWidth = Math.abs(startx - stopx); + if (msg.wrap && msg.message) { + msg.message = utils.wrapLabel( + msg.message, + common.getMax(boundedWidth + 2 * conf.wrapPadding, conf.width), + messageFont(conf) + ); + } + const msgDims = utils.calculateTextDimensions(msg.message, messageFont(conf)); + return { + width: common.getMax( + msg.wrap ? 0 : msgDims.width + 2 * conf.wrapPadding, + boundedWidth + 2 * conf.wrapPadding, + conf.width + ), + height: 0, + startx, + stopx, + starty: 0, + stopy: 0, + message: msg.message, + type: msg.type, + wrap: msg.wrap, + fromBounds: Math.min.apply(null, allBounds), + toBounds: Math.max.apply(null, allBounds) + }; +}; +const calculateLoopBounds = async function(messages, actors, _maxWidthPerActor, diagObj) { + const loops = {}; + const stack = []; + let current, noteModel, msgModel; + for (const msg of messages) { + msg.id = utils.random({ length: 10 }); + switch (msg.type) { + case diagObj.db.LINETYPE.LOOP_START: + case diagObj.db.LINETYPE.ALT_START: + case diagObj.db.LINETYPE.OPT_START: + case diagObj.db.LINETYPE.PAR_START: + case diagObj.db.LINETYPE.PAR_OVER_START: + case diagObj.db.LINETYPE.CRITICAL_START: + case diagObj.db.LINETYPE.BREAK_START: + stack.push({ + id: msg.id, + msg: msg.message, + from: Number.MAX_SAFE_INTEGER, + to: Number.MIN_SAFE_INTEGER, + width: 0 + }); + break; + case diagObj.db.LINETYPE.ALT_ELSE: + case diagObj.db.LINETYPE.PAR_AND: + case diagObj.db.LINETYPE.CRITICAL_OPTION: + if (msg.message) { + current = stack.pop(); + loops[current.id] = current; + loops[msg.id] = current; + stack.push(current); + } + break; + case diagObj.db.LINETYPE.LOOP_END: + case diagObj.db.LINETYPE.ALT_END: + case diagObj.db.LINETYPE.OPT_END: + case diagObj.db.LINETYPE.PAR_END: + case diagObj.db.LINETYPE.CRITICAL_END: + case diagObj.db.LINETYPE.BREAK_END: + current = stack.pop(); + loops[current.id] = current; + break; + case diagObj.db.LINETYPE.ACTIVE_START: + { + const actorRect = actors[msg.from ? msg.from.actor : msg.to.actor]; + const stackedSize = actorActivations(msg.from ? msg.from.actor : msg.to.actor).length; + const x = actorRect.x + actorRect.width / 2 + (stackedSize - 1) * conf.activationWidth / 2; + const toAdd = { + startx: x, + stopx: x + conf.activationWidth, + actor: msg.from.actor, + enabled: true + }; + bounds.activations.push(toAdd); + } + break; + case diagObj.db.LINETYPE.ACTIVE_END: + { + const lastActorActivationIdx = bounds.activations.map((a) => a.actor).lastIndexOf(msg.from.actor); + delete bounds.activations.splice(lastActorActivationIdx, 1)[0]; + } + break; + } + const isNote = msg.placement !== void 0; + if (isNote) { + noteModel = await buildNoteModel(msg, actors, diagObj); + msg.noteModel = noteModel; + stack.forEach((stk) => { + current = stk; + current.from = common.getMin(current.from, noteModel.startx); + current.to = common.getMax(current.to, noteModel.startx + noteModel.width); + current.width = common.getMax(current.width, Math.abs(current.from - current.to)) - conf.labelBoxWidth; + }); + } else { + msgModel = buildMessageModel(msg, actors, diagObj); + msg.msgModel = msgModel; + if (msgModel.startx && msgModel.stopx && stack.length > 0) { + stack.forEach((stk) => { + current = stk; + if (msgModel.startx === msgModel.stopx) { + const from = actors[msg.from]; + const to = actors[msg.to]; + current.from = common.getMin( + from.x - msgModel.width / 2, + from.x - from.width / 2, + current.from + ); + current.to = common.getMax( + to.x + msgModel.width / 2, + to.x + from.width / 2, + current.to + ); + current.width = common.getMax(current.width, Math.abs(current.to - current.from)) - conf.labelBoxWidth; + } else { + current.from = common.getMin(msgModel.startx, current.from); + current.to = common.getMax(msgModel.stopx, current.to); + current.width = common.getMax(current.width, msgModel.width) - conf.labelBoxWidth; + } + }); + } + } + } + bounds.activations = []; + log.debug("Loop type widths:", loops); + return loops; +}; +const renderer = { + bounds, + drawActors, + drawActorsPopup, + setConf, + draw +}; +const diagram = { + parser: parser$1, + db, + renderer, + styles, + init: ({ wrap }) => { + db.setWrap(wrap); + } +}; +export { + diagram +}; diff --git a/0.6.0/js/mermaid/sequenceDiagram-b517d154.js b/0.6.0/js/mermaid/sequenceDiagram-b517d154.js new file mode 100644 index 0000000..1a87856 --- /dev/null +++ b/0.6.0/js/mermaid/sequenceDiagram-b517d154.js @@ -0,0 +1,2234 @@ +import { g as we, D as _e, C as ke, c as st, s as $t, b as Pe, a as Le, E as Ie, l as X, d as Nt, e as te, f as _, Y as ee, a4 as at, r as se, _ as Bt, a5 as Ae, a6 as wt, h as Ne, j as It, k as ve, A as B } from "./mermaid-9f2aa176.js"; +import { d as Se, a as Me, b as Re, c as Ce, e as zt, g as vt } from "./svgDrawCommon-ecc5f780.js"; +var Yt = function() { + var t = function(ht, w, P, I) { + for (P = P || {}, I = ht.length; I--; P[ht[I]] = w) + ; + return P; + }, e = [1, 2], c = [1, 3], s = [1, 4], r = [2, 4], i = [1, 9], o = [1, 11], l = [1, 13], u = [1, 14], n = [1, 16], x = [1, 17], T = [1, 18], p = [1, 24], g = [1, 25], m = [1, 26], k = [1, 27], A = [1, 28], V = [1, 29], S = [1, 30], O = [1, 31], R = [1, 32], q = [1, 33], z = [1, 34], J = [1, 35], $ = [1, 36], H = [1, 37], U = [1, 38], F = [1, 39], W = [1, 41], Z = [1, 42], K = [1, 43], Q = [1, 44], tt = [1, 45], v = [1, 46], y = [1, 4, 5, 13, 14, 16, 18, 21, 23, 29, 30, 31, 33, 35, 36, 37, 38, 39, 41, 43, 44, 46, 47, 48, 49, 50, 52, 53, 54, 59, 60, 61, 62, 70], L = [4, 5, 16, 50, 52, 53], j = [4, 5, 13, 14, 16, 18, 21, 23, 29, 30, 31, 33, 35, 36, 37, 38, 39, 41, 43, 44, 46, 50, 52, 53, 54, 59, 60, 61, 62, 70], nt = [4, 5, 13, 14, 16, 18, 21, 23, 29, 30, 31, 33, 35, 36, 37, 38, 39, 41, 43, 44, 46, 49, 50, 52, 53, 54, 59, 60, 61, 62, 70], N = [4, 5, 13, 14, 16, 18, 21, 23, 29, 30, 31, 33, 35, 36, 37, 38, 39, 41, 43, 44, 46, 48, 50, 52, 53, 54, 59, 60, 61, 62, 70], Gt = [4, 5, 13, 14, 16, 18, 21, 23, 29, 30, 31, 33, 35, 36, 37, 38, 39, 41, 43, 44, 46, 47, 50, 52, 53, 54, 59, 60, 61, 62, 70], dt = [68, 69, 70], ot = [1, 120], Mt = { + trace: function() { + }, + yy: {}, + symbols_: { error: 2, start: 3, SPACE: 4, NEWLINE: 5, SD: 6, document: 7, line: 8, statement: 9, box_section: 10, box_line: 11, participant_statement: 12, create: 13, box: 14, restOfLine: 15, end: 16, signal: 17, autonumber: 18, NUM: 19, off: 20, activate: 21, actor: 22, deactivate: 23, note_statement: 24, links_statement: 25, link_statement: 26, properties_statement: 27, details_statement: 28, title: 29, legacy_title: 30, acc_title: 31, acc_title_value: 32, acc_descr: 33, acc_descr_value: 34, acc_descr_multiline_value: 35, loop: 36, rect: 37, opt: 38, alt: 39, else_sections: 40, par: 41, par_sections: 42, par_over: 43, critical: 44, option_sections: 45, break: 46, option: 47, and: 48, else: 49, participant: 50, AS: 51, participant_actor: 52, destroy: 53, note: 54, placement: 55, text2: 56, over: 57, actor_pair: 58, links: 59, link: 60, properties: 61, details: 62, spaceList: 63, ",": 64, left_of: 65, right_of: 66, signaltype: 67, "+": 68, "-": 69, ACTOR: 70, SOLID_OPEN_ARROW: 71, DOTTED_OPEN_ARROW: 72, SOLID_ARROW: 73, DOTTED_ARROW: 74, SOLID_CROSS: 75, DOTTED_CROSS: 76, SOLID_POINT: 77, DOTTED_POINT: 78, TXT: 79, $accept: 0, $end: 1 }, + terminals_: { 2: "error", 4: "SPACE", 5: "NEWLINE", 6: "SD", 13: "create", 14: "box", 15: "restOfLine", 16: "end", 18: "autonumber", 19: "NUM", 20: "off", 21: "activate", 23: "deactivate", 29: "title", 30: "legacy_title", 31: "acc_title", 32: "acc_title_value", 33: "acc_descr", 34: "acc_descr_value", 35: "acc_descr_multiline_value", 36: "loop", 37: "rect", 38: "opt", 39: "alt", 41: "par", 43: "par_over", 44: "critical", 46: "break", 47: "option", 48: "and", 49: "else", 50: "participant", 51: "AS", 52: "participant_actor", 53: "destroy", 54: "note", 57: "over", 59: "links", 60: "link", 61: "properties", 62: "details", 64: ",", 65: "left_of", 66: "right_of", 68: "+", 69: "-", 70: "ACTOR", 71: "SOLID_OPEN_ARROW", 72: "DOTTED_OPEN_ARROW", 73: "SOLID_ARROW", 74: "DOTTED_ARROW", 75: "SOLID_CROSS", 76: "DOTTED_CROSS", 77: "SOLID_POINT", 78: "DOTTED_POINT", 79: "TXT" }, + productions_: [0, [3, 2], [3, 2], [3, 2], [7, 0], [7, 2], [8, 2], [8, 1], [8, 1], [10, 0], [10, 2], [11, 2], [11, 1], [11, 1], [9, 1], [9, 2], [9, 4], [9, 2], [9, 4], [9, 3], [9, 3], [9, 2], [9, 3], [9, 3], [9, 2], [9, 2], [9, 2], [9, 2], [9, 2], [9, 1], [9, 1], [9, 2], [9, 2], [9, 1], [9, 4], [9, 4], [9, 4], [9, 4], [9, 4], [9, 4], [9, 4], [9, 4], [45, 1], [45, 4], [42, 1], [42, 4], [40, 1], [40, 4], [12, 5], [12, 3], [12, 5], [12, 3], [12, 3], [24, 4], [24, 4], [25, 3], [26, 3], [27, 3], [28, 3], [63, 2], [63, 1], [58, 3], [58, 1], [55, 1], [55, 1], [17, 5], [17, 5], [17, 4], [22, 1], [67, 1], [67, 1], [67, 1], [67, 1], [67, 1], [67, 1], [67, 1], [67, 1], [56, 1]], + performAction: function(w, P, I, b, M, d, Et) { + var h = d.length - 1; + switch (M) { + case 3: + return b.apply(d[h]), d[h]; + case 4: + case 9: + this.$ = []; + break; + case 5: + case 10: + d[h - 1].push(d[h]), this.$ = d[h - 1]; + break; + case 6: + case 7: + case 11: + case 12: + this.$ = d[h]; + break; + case 8: + case 13: + this.$ = []; + break; + case 15: + d[h].type = "createParticipant", this.$ = d[h]; + break; + case 16: + d[h - 1].unshift({ type: "boxStart", boxData: b.parseBoxData(d[h - 2]) }), d[h - 1].push({ type: "boxEnd", boxText: d[h - 2] }), this.$ = d[h - 1]; + break; + case 18: + this.$ = { type: "sequenceIndex", sequenceIndex: Number(d[h - 2]), sequenceIndexStep: Number(d[h - 1]), sequenceVisible: !0, signalType: b.LINETYPE.AUTONUMBER }; + break; + case 19: + this.$ = { type: "sequenceIndex", sequenceIndex: Number(d[h - 1]), sequenceIndexStep: 1, sequenceVisible: !0, signalType: b.LINETYPE.AUTONUMBER }; + break; + case 20: + this.$ = { type: "sequenceIndex", sequenceVisible: !1, signalType: b.LINETYPE.AUTONUMBER }; + break; + case 21: + this.$ = { type: "sequenceIndex", sequenceVisible: !0, signalType: b.LINETYPE.AUTONUMBER }; + break; + case 22: + this.$ = { type: "activeStart", signalType: b.LINETYPE.ACTIVE_START, actor: d[h - 1] }; + break; + case 23: + this.$ = { type: "activeEnd", signalType: b.LINETYPE.ACTIVE_END, actor: d[h - 1] }; + break; + case 29: + b.setDiagramTitle(d[h].substring(6)), this.$ = d[h].substring(6); + break; + case 30: + b.setDiagramTitle(d[h].substring(7)), this.$ = d[h].substring(7); + break; + case 31: + this.$ = d[h].trim(), b.setAccTitle(this.$); + break; + case 32: + case 33: + this.$ = d[h].trim(), b.setAccDescription(this.$); + break; + case 34: + d[h - 1].unshift({ type: "loopStart", loopText: b.parseMessage(d[h - 2]), signalType: b.LINETYPE.LOOP_START }), d[h - 1].push({ type: "loopEnd", loopText: d[h - 2], signalType: b.LINETYPE.LOOP_END }), this.$ = d[h - 1]; + break; + case 35: + d[h - 1].unshift({ type: "rectStart", color: b.parseMessage(d[h - 2]), signalType: b.LINETYPE.RECT_START }), d[h - 1].push({ type: "rectEnd", color: b.parseMessage(d[h - 2]), signalType: b.LINETYPE.RECT_END }), this.$ = d[h - 1]; + break; + case 36: + d[h - 1].unshift({ type: "optStart", optText: b.parseMessage(d[h - 2]), signalType: b.LINETYPE.OPT_START }), d[h - 1].push({ type: "optEnd", optText: b.parseMessage(d[h - 2]), signalType: b.LINETYPE.OPT_END }), this.$ = d[h - 1]; + break; + case 37: + d[h - 1].unshift({ type: "altStart", altText: b.parseMessage(d[h - 2]), signalType: b.LINETYPE.ALT_START }), d[h - 1].push({ type: "altEnd", signalType: b.LINETYPE.ALT_END }), this.$ = d[h - 1]; + break; + case 38: + d[h - 1].unshift({ type: "parStart", parText: b.parseMessage(d[h - 2]), signalType: b.LINETYPE.PAR_START }), d[h - 1].push({ type: "parEnd", signalType: b.LINETYPE.PAR_END }), this.$ = d[h - 1]; + break; + case 39: + d[h - 1].unshift({ type: "parStart", parText: b.parseMessage(d[h - 2]), signalType: b.LINETYPE.PAR_OVER_START }), d[h - 1].push({ type: "parEnd", signalType: b.LINETYPE.PAR_END }), this.$ = d[h - 1]; + break; + case 40: + d[h - 1].unshift({ type: "criticalStart", criticalText: b.parseMessage(d[h - 2]), signalType: b.LINETYPE.CRITICAL_START }), d[h - 1].push({ type: "criticalEnd", signalType: b.LINETYPE.CRITICAL_END }), this.$ = d[h - 1]; + break; + case 41: + d[h - 1].unshift({ type: "breakStart", breakText: b.parseMessage(d[h - 2]), signalType: b.LINETYPE.BREAK_START }), d[h - 1].push({ type: "breakEnd", optText: b.parseMessage(d[h - 2]), signalType: b.LINETYPE.BREAK_END }), this.$ = d[h - 1]; + break; + case 43: + this.$ = d[h - 3].concat([{ type: "option", optionText: b.parseMessage(d[h - 1]), signalType: b.LINETYPE.CRITICAL_OPTION }, d[h]]); + break; + case 45: + this.$ = d[h - 3].concat([{ type: "and", parText: b.parseMessage(d[h - 1]), signalType: b.LINETYPE.PAR_AND }, d[h]]); + break; + case 47: + this.$ = d[h - 3].concat([{ type: "else", altText: b.parseMessage(d[h - 1]), signalType: b.LINETYPE.ALT_ELSE }, d[h]]); + break; + case 48: + d[h - 3].draw = "participant", d[h - 3].type = "addParticipant", d[h - 3].description = b.parseMessage(d[h - 1]), this.$ = d[h - 3]; + break; + case 49: + d[h - 1].draw = "participant", d[h - 1].type = "addParticipant", this.$ = d[h - 1]; + break; + case 50: + d[h - 3].draw = "actor", d[h - 3].type = "addParticipant", d[h - 3].description = b.parseMessage(d[h - 1]), this.$ = d[h - 3]; + break; + case 51: + d[h - 1].draw = "actor", d[h - 1].type = "addParticipant", this.$ = d[h - 1]; + break; + case 52: + d[h - 1].type = "destroyParticipant", this.$ = d[h - 1]; + break; + case 53: + this.$ = [d[h - 1], { type: "addNote", placement: d[h - 2], actor: d[h - 1].actor, text: d[h] }]; + break; + case 54: + d[h - 2] = [].concat(d[h - 1], d[h - 1]).slice(0, 2), d[h - 2][0] = d[h - 2][0].actor, d[h - 2][1] = d[h - 2][1].actor, this.$ = [d[h - 1], { type: "addNote", placement: b.PLACEMENT.OVER, actor: d[h - 2].slice(0, 2), text: d[h] }]; + break; + case 55: + this.$ = [d[h - 1], { type: "addLinks", actor: d[h - 1].actor, text: d[h] }]; + break; + case 56: + this.$ = [d[h - 1], { type: "addALink", actor: d[h - 1].actor, text: d[h] }]; + break; + case 57: + this.$ = [d[h - 1], { type: "addProperties", actor: d[h - 1].actor, text: d[h] }]; + break; + case 58: + this.$ = [d[h - 1], { type: "addDetails", actor: d[h - 1].actor, text: d[h] }]; + break; + case 61: + this.$ = [d[h - 2], d[h]]; + break; + case 62: + this.$ = d[h]; + break; + case 63: + this.$ = b.PLACEMENT.LEFTOF; + break; + case 64: + this.$ = b.PLACEMENT.RIGHTOF; + break; + case 65: + this.$ = [ + d[h - 4], + d[h - 1], + { type: "addMessage", from: d[h - 4].actor, to: d[h - 1].actor, signalType: d[h - 3], msg: d[h], activate: !0 }, + { type: "activeStart", signalType: b.LINETYPE.ACTIVE_START, actor: d[h - 1] } + ]; + break; + case 66: + this.$ = [ + d[h - 4], + d[h - 1], + { type: "addMessage", from: d[h - 4].actor, to: d[h - 1].actor, signalType: d[h - 3], msg: d[h] }, + { type: "activeEnd", signalType: b.LINETYPE.ACTIVE_END, actor: d[h - 4] } + ]; + break; + case 67: + this.$ = [d[h - 3], d[h - 1], { type: "addMessage", from: d[h - 3].actor, to: d[h - 1].actor, signalType: d[h - 2], msg: d[h] }]; + break; + case 68: + this.$ = { type: "addParticipant", actor: d[h] }; + break; + case 69: + this.$ = b.LINETYPE.SOLID_OPEN; + break; + case 70: + this.$ = b.LINETYPE.DOTTED_OPEN; + break; + case 71: + this.$ = b.LINETYPE.SOLID; + break; + case 72: + this.$ = b.LINETYPE.DOTTED; + break; + case 73: + this.$ = b.LINETYPE.SOLID_CROSS; + break; + case 74: + this.$ = b.LINETYPE.DOTTED_CROSS; + break; + case 75: + this.$ = b.LINETYPE.SOLID_POINT; + break; + case 76: + this.$ = b.LINETYPE.DOTTED_POINT; + break; + case 77: + this.$ = b.parseMessage(d[h].trim().substring(1)); + break; + } + }, + table: [{ 3: 1, 4: e, 5: c, 6: s }, { 1: [3] }, { 3: 5, 4: e, 5: c, 6: s }, { 3: 6, 4: e, 5: c, 6: s }, t([1, 4, 5, 13, 14, 18, 21, 23, 29, 30, 31, 33, 35, 36, 37, 38, 39, 41, 43, 44, 46, 50, 52, 53, 54, 59, 60, 61, 62, 70], r, { 7: 7 }), { 1: [2, 1] }, { 1: [2, 2] }, { 1: [2, 3], 4: i, 5: o, 8: 8, 9: 10, 12: 12, 13: l, 14: u, 17: 15, 18: n, 21: x, 22: 40, 23: T, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: p, 30: g, 31: m, 33: k, 35: A, 36: V, 37: S, 38: O, 39: R, 41: q, 43: z, 44: J, 46: $, 50: H, 52: U, 53: F, 54: W, 59: Z, 60: K, 61: Q, 62: tt, 70: v }, t(y, [2, 5]), { 9: 47, 12: 12, 13: l, 14: u, 17: 15, 18: n, 21: x, 22: 40, 23: T, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: p, 30: g, 31: m, 33: k, 35: A, 36: V, 37: S, 38: O, 39: R, 41: q, 43: z, 44: J, 46: $, 50: H, 52: U, 53: F, 54: W, 59: Z, 60: K, 61: Q, 62: tt, 70: v }, t(y, [2, 7]), t(y, [2, 8]), t(y, [2, 14]), { 12: 48, 50: H, 52: U, 53: F }, { 15: [1, 49] }, { 5: [1, 50] }, { 5: [1, 53], 19: [1, 51], 20: [1, 52] }, { 22: 54, 70: v }, { 22: 55, 70: v }, { 5: [1, 56] }, { 5: [1, 57] }, { 5: [1, 58] }, { 5: [1, 59] }, { 5: [1, 60] }, t(y, [2, 29]), t(y, [2, 30]), { 32: [1, 61] }, { 34: [1, 62] }, t(y, [2, 33]), { 15: [1, 63] }, { 15: [1, 64] }, { 15: [1, 65] }, { 15: [1, 66] }, { 15: [1, 67] }, { 15: [1, 68] }, { 15: [1, 69] }, { 15: [1, 70] }, { 22: 71, 70: v }, { 22: 72, 70: v }, { 22: 73, 70: v }, { 67: 74, 71: [1, 75], 72: [1, 76], 73: [1, 77], 74: [1, 78], 75: [1, 79], 76: [1, 80], 77: [1, 81], 78: [1, 82] }, { 55: 83, 57: [1, 84], 65: [1, 85], 66: [1, 86] }, { 22: 87, 70: v }, { 22: 88, 70: v }, { 22: 89, 70: v }, { 22: 90, 70: v }, t([5, 51, 64, 71, 72, 73, 74, 75, 76, 77, 78, 79], [2, 68]), t(y, [2, 6]), t(y, [2, 15]), t(L, [2, 9], { 10: 91 }), t(y, [2, 17]), { 5: [1, 93], 19: [1, 92] }, { 5: [1, 94] }, t(y, [2, 21]), { 5: [1, 95] }, { 5: [1, 96] }, t(y, [2, 24]), t(y, [2, 25]), t(y, [2, 26]), t(y, [2, 27]), t(y, [2, 28]), t(y, [2, 31]), t(y, [2, 32]), t(j, r, { 7: 97 }), t(j, r, { 7: 98 }), t(j, r, { 7: 99 }), t(nt, r, { 40: 100, 7: 101 }), t(N, r, { 42: 102, 7: 103 }), t(N, r, { 7: 103, 42: 104 }), t(Gt, r, { 45: 105, 7: 106 }), t(j, r, { 7: 107 }), { 5: [1, 109], 51: [1, 108] }, { 5: [1, 111], 51: [1, 110] }, { 5: [1, 112] }, { 22: 115, 68: [1, 113], 69: [1, 114], 70: v }, t(dt, [2, 69]), t(dt, [2, 70]), t(dt, [2, 71]), t(dt, [2, 72]), t(dt, [2, 73]), t(dt, [2, 74]), t(dt, [2, 75]), t(dt, [2, 76]), { 22: 116, 70: v }, { 22: 118, 58: 117, 70: v }, { 70: [2, 63] }, { 70: [2, 64] }, { 56: 119, 79: ot }, { 56: 121, 79: ot }, { 56: 122, 79: ot }, { 56: 123, 79: ot }, { 4: [1, 126], 5: [1, 128], 11: 125, 12: 127, 16: [1, 124], 50: H, 52: U, 53: F }, { 5: [1, 129] }, t(y, [2, 19]), t(y, [2, 20]), t(y, [2, 22]), t(y, [2, 23]), { 4: i, 5: o, 8: 8, 9: 10, 12: 12, 13: l, 14: u, 16: [1, 130], 17: 15, 18: n, 21: x, 22: 40, 23: T, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: p, 30: g, 31: m, 33: k, 35: A, 36: V, 37: S, 38: O, 39: R, 41: q, 43: z, 44: J, 46: $, 50: H, 52: U, 53: F, 54: W, 59: Z, 60: K, 61: Q, 62: tt, 70: v }, { 4: i, 5: o, 8: 8, 9: 10, 12: 12, 13: l, 14: u, 16: [1, 131], 17: 15, 18: n, 21: x, 22: 40, 23: T, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: p, 30: g, 31: m, 33: k, 35: A, 36: V, 37: S, 38: O, 39: R, 41: q, 43: z, 44: J, 46: $, 50: H, 52: U, 53: F, 54: W, 59: Z, 60: K, 61: Q, 62: tt, 70: v }, { 4: i, 5: o, 8: 8, 9: 10, 12: 12, 13: l, 14: u, 16: [1, 132], 17: 15, 18: n, 21: x, 22: 40, 23: T, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: p, 30: g, 31: m, 33: k, 35: A, 36: V, 37: S, 38: O, 39: R, 41: q, 43: z, 44: J, 46: $, 50: H, 52: U, 53: F, 54: W, 59: Z, 60: K, 61: Q, 62: tt, 70: v }, { 16: [1, 133] }, { 4: i, 5: o, 8: 8, 9: 10, 12: 12, 13: l, 14: u, 16: [2, 46], 17: 15, 18: n, 21: x, 22: 40, 23: T, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: p, 30: g, 31: m, 33: k, 35: A, 36: V, 37: S, 38: O, 39: R, 41: q, 43: z, 44: J, 46: $, 49: [1, 134], 50: H, 52: U, 53: F, 54: W, 59: Z, 60: K, 61: Q, 62: tt, 70: v }, { 16: [1, 135] }, { 4: i, 5: o, 8: 8, 9: 10, 12: 12, 13: l, 14: u, 16: [2, 44], 17: 15, 18: n, 21: x, 22: 40, 23: T, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: p, 30: g, 31: m, 33: k, 35: A, 36: V, 37: S, 38: O, 39: R, 41: q, 43: z, 44: J, 46: $, 48: [1, 136], 50: H, 52: U, 53: F, 54: W, 59: Z, 60: K, 61: Q, 62: tt, 70: v }, { 16: [1, 137] }, { 16: [1, 138] }, { 4: i, 5: o, 8: 8, 9: 10, 12: 12, 13: l, 14: u, 16: [2, 42], 17: 15, 18: n, 21: x, 22: 40, 23: T, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: p, 30: g, 31: m, 33: k, 35: A, 36: V, 37: S, 38: O, 39: R, 41: q, 43: z, 44: J, 46: $, 47: [1, 139], 50: H, 52: U, 53: F, 54: W, 59: Z, 60: K, 61: Q, 62: tt, 70: v }, { 4: i, 5: o, 8: 8, 9: 10, 12: 12, 13: l, 14: u, 16: [1, 140], 17: 15, 18: n, 21: x, 22: 40, 23: T, 24: 19, 25: 20, 26: 21, 27: 22, 28: 23, 29: p, 30: g, 31: m, 33: k, 35: A, 36: V, 37: S, 38: O, 39: R, 41: q, 43: z, 44: J, 46: $, 50: H, 52: U, 53: F, 54: W, 59: Z, 60: K, 61: Q, 62: tt, 70: v }, { 15: [1, 141] }, t(y, [2, 49]), { 15: [1, 142] }, t(y, [2, 51]), t(y, [2, 52]), { 22: 143, 70: v }, { 22: 144, 70: v }, { 56: 145, 79: ot }, { 56: 146, 79: ot }, { 56: 147, 79: ot }, { 64: [1, 148], 79: [2, 62] }, { 5: [2, 55] }, { 5: [2, 77] }, { 5: [2, 56] }, { 5: [2, 57] }, { 5: [2, 58] }, t(y, [2, 16]), t(L, [2, 10]), { 12: 149, 50: H, 52: U, 53: F }, t(L, [2, 12]), t(L, [2, 13]), t(y, [2, 18]), t(y, [2, 34]), t(y, [2, 35]), t(y, [2, 36]), t(y, [2, 37]), { 15: [1, 150] }, t(y, [2, 38]), { 15: [1, 151] }, t(y, [2, 39]), t(y, [2, 40]), { 15: [1, 152] }, t(y, [2, 41]), { 5: [1, 153] }, { 5: [1, 154] }, { 56: 155, 79: ot }, { 56: 156, 79: ot }, { 5: [2, 67] }, { 5: [2, 53] }, { 5: [2, 54] }, { 22: 157, 70: v }, t(L, [2, 11]), t(nt, r, { 7: 101, 40: 158 }), t(N, r, { 7: 103, 42: 159 }), t(Gt, r, { 7: 106, 45: 160 }), t(y, [2, 48]), t(y, [2, 50]), { 5: [2, 65] }, { 5: [2, 66] }, { 79: [2, 61] }, { 16: [2, 47] }, { 16: [2, 45] }, { 16: [2, 43] }], + defaultActions: { 5: [2, 1], 6: [2, 2], 85: [2, 63], 86: [2, 64], 119: [2, 55], 120: [2, 77], 121: [2, 56], 122: [2, 57], 123: [2, 58], 145: [2, 67], 146: [2, 53], 147: [2, 54], 155: [2, 65], 156: [2, 66], 157: [2, 61], 158: [2, 47], 159: [2, 45], 160: [2, 43] }, + parseError: function(w, P) { + if (P.recoverable) + this.trace(w); + else { + var I = new Error(w); + throw I.hash = P, I; + } + }, + parse: function(w) { + var P = this, I = [0], b = [], M = [null], d = [], Et = this.table, h = "", kt = 0, Xt = 0, Te = 2, Jt = 1, be = d.slice.call(arguments, 1), Y = Object.create(this.lexer), ut = { yy: {} }; + for (var Ct in this.yy) + Object.prototype.hasOwnProperty.call(this.yy, Ct) && (ut.yy[Ct] = this.yy[Ct]); + Y.setInput(w, ut.yy), ut.yy.lexer = Y, ut.yy.parser = this, typeof Y.yylloc > "u" && (Y.yylloc = {}); + var Dt = Y.yylloc; + d.push(Dt); + var Ee = Y.options && Y.options.ranges; + typeof ut.yy.parseError == "function" ? this.parseError = ut.yy.parseError : this.parseError = Object.getPrototypeOf(this).parseError; + function me() { + var lt; + return lt = b.pop() || Y.lex() || Jt, typeof lt != "number" && (lt instanceof Array && (b = lt, lt = b.pop()), lt = P.symbols_[lt] || lt), lt; + } + for (var G, pt, et, Vt, yt = {}, Pt, ct, Zt, Lt; ; ) { + if (pt = I[I.length - 1], this.defaultActions[pt] ? et = this.defaultActions[pt] : ((G === null || typeof G > "u") && (G = me()), et = Et[pt] && Et[pt][G]), typeof et > "u" || !et.length || !et[0]) { + var Ot = ""; + Lt = []; + for (Pt in Et[pt]) + this.terminals_[Pt] && Pt > Te && Lt.push("'" + this.terminals_[Pt] + "'"); + Y.showPosition ? Ot = "Parse error on line " + (kt + 1) + `: +` + Y.showPosition() + ` +Expecting ` + Lt.join(", ") + ", got '" + (this.terminals_[G] || G) + "'" : Ot = "Parse error on line " + (kt + 1) + ": Unexpected " + (G == Jt ? "end of input" : "'" + (this.terminals_[G] || G) + "'"), this.parseError(Ot, { + text: Y.match, + token: this.terminals_[G] || G, + line: Y.yylineno, + loc: Dt, + expected: Lt + }); + } + if (et[0] instanceof Array && et.length > 1) + throw new Error("Parse Error: multiple actions possible at state: " + pt + ", token: " + G); + switch (et[0]) { + case 1: + I.push(G), M.push(Y.yytext), d.push(Y.yylloc), I.push(et[1]), G = null, Xt = Y.yyleng, h = Y.yytext, kt = Y.yylineno, Dt = Y.yylloc; + break; + case 2: + if (ct = this.productions_[et[1]][1], yt.$ = M[M.length - ct], yt._$ = { + first_line: d[d.length - (ct || 1)].first_line, + last_line: d[d.length - 1].last_line, + first_column: d[d.length - (ct || 1)].first_column, + last_column: d[d.length - 1].last_column + }, Ee && (yt._$.range = [ + d[d.length - (ct || 1)].range[0], + d[d.length - 1].range[1] + ]), Vt = this.performAction.apply(yt, [ + h, + Xt, + kt, + ut.yy, + et[1], + M, + d + ].concat(be)), typeof Vt < "u") + return Vt; + ct && (I = I.slice(0, -1 * ct * 2), M = M.slice(0, -1 * ct), d = d.slice(0, -1 * ct)), I.push(this.productions_[et[1]][0]), M.push(yt.$), d.push(yt._$), Zt = Et[I[I.length - 2]][I[I.length - 1]], I.push(Zt); + break; + case 3: + return !0; + } + } + return !0; + } + }, ye = function() { + var ht = { + EOF: 1, + parseError: function(P, I) { + if (this.yy.parser) + this.yy.parser.parseError(P, I); + else + throw new Error(P); + }, + // resets the lexer, sets new input + setInput: function(w, P) { + return this.yy = P || this.yy || {}, this._input = w, 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 w = this._input[0]; + this.yytext += w, this.yyleng++, this.offset++, this.match += w, this.matched += w; + var P = w.match(/(?:\r\n?|\n).*/g); + return P ? (this.yylineno++, this.yylloc.last_line++) : this.yylloc.last_column++, this.options.ranges && this.yylloc.range[1]++, this._input = this._input.slice(1), w; + }, + // unshifts one char (or a string) into the input + unput: function(w) { + var P = w.length, I = w.split(/(?:\r\n?|\n)/g); + this._input = w + this._input, this.yytext = this.yytext.substr(0, this.yytext.length - P), this.offset -= P; + var b = 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), I.length - 1 && (this.yylineno -= I.length - 1); + var M = 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: I ? (I.length === b.length ? this.yylloc.first_column : 0) + b[b.length - I.length].length - I[0].length : this.yylloc.first_column - P + }, this.options.ranges && (this.yylloc.range = [M[0], M[0] + this.yyleng - P]), 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(w) { + this.unput(this.match.slice(w)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var w = this.matched.substr(0, this.matched.length - this.match.length); + return (w.length > 20 ? "..." : "") + w.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var w = this.match; + return w.length < 20 && (w += this._input.substr(0, 20 - w.length)), (w.substr(0, 20) + (w.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var w = this.pastInput(), P = new Array(w.length + 1).join("-"); + return w + this.upcomingInput() + ` +` + P + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(w, P) { + var I, b, M; + if (this.options.backtrack_lexer && (M = { + 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 && (M.yylloc.range = this.yylloc.range.slice(0))), b = w[0].match(/(?:\r\n?|\n).*/g), b && (this.yylineno += b.length), this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: b ? b[b.length - 1].length - b[b.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + w[0].length + }, this.yytext += w[0], this.match += w[0], this.matches = w, 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(w[0].length), this.matched += w[0], I = this.performAction.call(this, this.yy, this, P, this.conditionStack[this.conditionStack.length - 1]), this.done && this._input && (this.done = !1), I) + return I; + if (this._backtrack) { + for (var d in M) + this[d] = M[d]; + return !1; + } + return !1; + }, + // return next match in input + next: function() { + if (this.done) + return this.EOF; + this._input || (this.done = !0); + var w, P, I, b; + this._more || (this.yytext = "", this.match = ""); + for (var M = this._currentRules(), d = 0; d < M.length; d++) + if (I = this._input.match(this.rules[M[d]]), I && (!P || I[0].length > P[0].length)) { + if (P = I, b = d, this.options.backtrack_lexer) { + if (w = this.test_match(I, M[d]), w !== !1) + return w; + if (this._backtrack) { + P = !1; + continue; + } else + return !1; + } else if (!this.options.flex) + break; + } + return P ? (w = this.test_match(P, M[b]), w !== !1 ? w : !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 P = this.next(); + return P || this.lex(); + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function(P) { + this.conditionStack.push(P); + }, + // pop the previously active lexer condition state off the condition stack + popState: function() { + var P = this.conditionStack.length - 1; + return P > 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(P) { + return P = this.conditionStack.length - 1 - Math.abs(P || 0), P >= 0 ? this.conditionStack[P] : "INITIAL"; + }, + // alias for begin(condition) + pushState: function(P) { + this.begin(P); + }, + // return the number of states currently on the stack + stateStackSize: function() { + return this.conditionStack.length; + }, + options: { "case-insensitive": !0 }, + performAction: function(P, I, b, M) { + switch (b) { + case 0: + return 5; + case 1: + break; + case 2: + break; + case 3: + break; + case 4: + break; + case 5: + break; + case 6: + return 19; + case 7: + return this.begin("LINE"), 14; + case 8: + return this.begin("ID"), 50; + case 9: + return this.begin("ID"), 52; + case 10: + return 13; + case 11: + return this.begin("ID"), 53; + case 12: + return I.yytext = I.yytext.trim(), this.begin("ALIAS"), 70; + case 13: + return this.popState(), this.popState(), this.begin("LINE"), 51; + case 14: + return this.popState(), this.popState(), 5; + case 15: + return this.begin("LINE"), 36; + case 16: + return this.begin("LINE"), 37; + case 17: + return this.begin("LINE"), 38; + case 18: + return this.begin("LINE"), 39; + case 19: + return this.begin("LINE"), 49; + case 20: + return this.begin("LINE"), 41; + case 21: + return this.begin("LINE"), 43; + case 22: + return this.begin("LINE"), 48; + case 23: + return this.begin("LINE"), 44; + case 24: + return this.begin("LINE"), 47; + case 25: + return this.begin("LINE"), 46; + case 26: + return this.popState(), 15; + case 27: + return 16; + case 28: + return 65; + case 29: + return 66; + case 30: + return 59; + case 31: + return 60; + case 32: + return 61; + case 33: + return 62; + case 34: + return 57; + case 35: + return 54; + case 36: + return this.begin("ID"), 21; + case 37: + return this.begin("ID"), 23; + case 38: + return 29; + case 39: + return 30; + case 40: + return this.begin("acc_title"), 31; + case 41: + return this.popState(), "acc_title_value"; + case 42: + return this.begin("acc_descr"), 33; + case 43: + return this.popState(), "acc_descr_value"; + case 44: + this.begin("acc_descr_multiline"); + break; + case 45: + this.popState(); + break; + case 46: + return "acc_descr_multiline_value"; + case 47: + return 6; + case 48: + return 18; + case 49: + return 20; + case 50: + return 64; + case 51: + return 5; + case 52: + return I.yytext = I.yytext.trim(), 70; + case 53: + return 73; + case 54: + return 74; + case 55: + return 71; + case 56: + return 72; + case 57: + return 75; + case 58: + return 76; + case 59: + return 77; + case 60: + return 78; + case 61: + return 79; + case 62: + return 68; + case 63: + return 69; + case 64: + return 5; + case 65: + return "INVALID"; + } + }, + rules: [/^(?:[\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, /^(?:create\b)/i, /^(?:destroy\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, /^(?:par_over\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: [45, 46], inclusive: !1 }, acc_descr: { rules: [43], inclusive: !1 }, acc_title: { rules: [41], inclusive: !1 }, ID: { rules: [2, 3, 12], inclusive: !1 }, ALIAS: { rules: [2, 3, 13, 14], inclusive: !1 }, LINE: { rules: [2, 3, 26], inclusive: !1 }, INITIAL: { rules: [0, 1, 3, 4, 5, 6, 7, 8, 9, 10, 11, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 42, 44, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65], inclusive: !0 } } + }; + return ht; + }(); + Mt.lexer = ye; + function Rt() { + this.yy = {}; + } + return Rt.prototype = Mt, Mt.Parser = Rt, new Rt(); +}(); +Yt.parser = Yt; +const De = Yt; +class Ve { + /** + * @param init - Function that creates the default state. + */ + constructor(e) { + this.init = e, this.records = this.init(); + } + reset() { + this.records = this.init(); + } +} +const E = new Ve(() => ({ + prevActor: void 0, + actors: {}, + createdActors: {}, + destroyedActors: {}, + boxes: [], + messages: [], + notes: [], + sequenceNumbersEnabled: !1, + wrapEnabled: void 0, + currentBox: void 0, + lastCreated: void 0, + lastDestroyed: void 0 +})), Oe = function(t) { + E.records.boxes.push({ + name: t.text, + wrap: t.wrap === void 0 && gt() || !!t.wrap, + fill: t.color, + actorKeys: [] + }), E.records.currentBox = E.records.boxes.slice(-1)[0]; +}, Ft = function(t, e, c, s) { + let r = E.records.currentBox; + const i = E.records.actors[t]; + if (i) { + if (E.records.currentBox && i.box && E.records.currentBox !== i.box) + throw new Error( + "A same participant should only be defined in one Box: " + i.name + " can't be in '" + i.box.name + "' and in '" + E.records.currentBox.name + "' at the same time." + ); + if (r = i.box ? i.box : E.records.currentBox, i.box = r, i && e === i.name && c == null) + return; + } + (c == null || c.text == null) && (c = { text: e, wrap: null, type: s }), (s == null || c.text == null) && (c = { text: e, wrap: null, type: s }), E.records.actors[t] = { + box: r, + name: e, + description: c.text, + wrap: c.wrap === void 0 && gt() || !!c.wrap, + prevActor: E.records.prevActor, + links: {}, + properties: {}, + actorCnt: null, + rectData: null, + type: s || "participant" + }, E.records.prevActor && E.records.actors[E.records.prevActor] && (E.records.actors[E.records.prevActor].nextActor = t), E.records.currentBox && E.records.currentBox.actorKeys.push(t), E.records.prevActor = t; +}, Be = (t) => { + let e, c = 0; + for (e = 0; e < E.records.messages.length; e++) + E.records.messages[e].type === mt.ACTIVE_START && E.records.messages[e].from.actor === t && c++, E.records.messages[e].type === mt.ACTIVE_END && E.records.messages[e].from.actor === t && c--; + return c; +}, Ye = function(t, e, c, s) { + E.records.messages.push({ + from: t, + to: e, + message: c.text, + wrap: c.wrap === void 0 && gt() || !!c.wrap, + answer: s + }); +}, C = function(t, e, c = { text: void 0, wrap: void 0 }, s, r = !1) { + if (s === mt.ACTIVE_END && Be(t.actor) < 1) { + let o = new Error("Trying to inactivate an inactive participant (" + t.actor + ")"); + throw o.hash = { + text: "->>-", + token: "->>-", + line: "1", + loc: { first_line: 1, last_line: 1, first_column: 1, last_column: 1 }, + expected: ["'ACTIVE_PARTICIPANT'"] + }, o; + } + return E.records.messages.push({ + from: t, + to: e, + message: c.text, + wrap: c.wrap === void 0 && gt() || !!c.wrap, + type: s, + activate: r + }), !0; +}, Fe = function() { + return E.records.boxes.length > 0; +}, We = function() { + return E.records.boxes.some((t) => t.name); +}, qe = function() { + return E.records.messages; +}, ze = function() { + return E.records.boxes; +}, He = function() { + return E.records.actors; +}, Ue = function() { + return E.records.createdActors; +}, Ke = function() { + return E.records.destroyedActors; +}, _t = function(t) { + return E.records.actors[t]; +}, Ge = function() { + return Object.keys(E.records.actors); +}, Xe = function() { + E.records.sequenceNumbersEnabled = !0; +}, Je = function() { + E.records.sequenceNumbersEnabled = !1; +}, Ze = () => E.records.sequenceNumbersEnabled, Qe = function(t) { + E.records.wrapEnabled = t; +}, gt = () => E.records.wrapEnabled !== void 0 ? E.records.wrapEnabled : st().sequence.wrap, je = function() { + E.reset(), Ie(); +}, $e = function(t) { + const e = t.trim(), c = { + text: e.replace(/^:?(?:no)?wrap:/, "").trim(), + wrap: e.match(/^:?wrap:/) !== null ? !0 : e.match(/^:?nowrap:/) !== null ? !1 : void 0 + }; + return X.debug("parseMessage:", c), c; +}, t0 = function(t) { + const e = t.match(/^((?:rgba?|hsla?)\s*\(.*\)|\w*)(.*)$/); + let c = e != null && e[1] ? e[1].trim() : "transparent", s = e != null && e[2] ? e[2].trim() : void 0; + if (window && window.CSS) + window.CSS.supports("color", c) || (c = "transparent", s = t.trim()); + else { + const r = new Option().style; + r.color = c, r.color !== c && (c = "transparent", s = t.trim()); + } + return { + color: c, + text: s !== void 0 ? Nt(s.replace(/^:?(?:no)?wrap:/, ""), st()) : void 0, + wrap: s !== void 0 ? s.match(/^:?wrap:/) !== null ? !0 : s.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, + PAR_OVER_START: 32 +}, e0 = { + FILLED: 0, + OPEN: 1 +}, s0 = { + LEFTOF: 0, + RIGHTOF: 1, + OVER: 2 +}, ne = function(t, e, c) { + const s = { + actor: t, + placement: e, + message: c.text, + wrap: c.wrap === void 0 && gt() || !!c.wrap + }, r = [].concat(t, t); + E.records.notes.push(s), E.records.messages.push({ + from: r[0], + to: r[1], + message: c.text, + wrap: c.wrap === void 0 && gt() || !!c.wrap, + type: mt.NOTE, + placement: e + }); +}, re = function(t, e) { + const c = _t(t); + try { + let s = Nt(e.text, st()); + s = s.replace(/&/g, "&"), s = s.replace(/=/g, "="); + const r = JSON.parse(s); + Ht(c, r); + } catch (s) { + X.error("error while parsing actor link text", s); + } +}, n0 = function(t, e) { + const c = _t(t); + try { + const o = {}; + let l = Nt(e.text, st()); + var s = l.indexOf("@"); + l = l.replace(/&/g, "&"), l = l.replace(/=/g, "="); + var r = l.slice(0, s - 1).trim(), i = l.slice(s + 1).trim(); + o[r] = i, Ht(c, o); + } catch (o) { + X.error("error while parsing actor link text", o); + } +}; +function Ht(t, e) { + if (t.links == null) + t.links = e; + else + for (let c in e) + t.links[c] = e[c]; +} +const ie = function(t, e) { + const c = _t(t); + try { + let s = Nt(e.text, st()); + const r = JSON.parse(s); + ae(c, r); + } catch (s) { + X.error("error while parsing actor properties text", s); + } +}; +function ae(t, e) { + if (t.properties == null) + t.properties = e; + else + for (let c in e) + t.properties[c] = e[c]; +} +function r0() { + E.records.currentBox = void 0; +} +const oe = function(t, e) { + const c = _t(t), s = document.getElementById(e.text); + try { + const r = s.innerHTML, i = JSON.parse(r); + i.properties && ae(c, i.properties), i.links && Ht(c, i.links); + } catch (r) { + X.error("error while parsing actor details text", r); + } +}, i0 = function(t, e) { + if (t !== void 0 && t.properties !== void 0) + return t.properties[e]; +}, ce = function(t) { + if (Array.isArray(t)) + t.forEach(function(e) { + ce(e); + }); + else + switch (t.type) { + case "sequenceIndex": + E.records.messages.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, t.draw); + break; + case "createParticipant": + if (E.records.actors[t.actor]) + throw new Error( + "It is not possible to have actors with the same id, even if one is destroyed before the next is created. Use 'AS' aliases to simulate the behavior" + ); + E.records.lastCreated = t.actor, Ft(t.actor, t.actor, t.description, t.draw), E.records.createdActors[t.actor] = E.records.messages.length; + break; + case "destroyParticipant": + E.records.lastDestroyed = t.actor, E.records.destroyedActors[t.actor] = E.records.messages.length; + break; + case "activeStart": + C(t.actor, void 0, void 0, t.signalType); + break; + case "activeEnd": + C(t.actor, void 0, void 0, t.signalType); + break; + case "addNote": + ne(t.actor, t.placement, t.text); + break; + case "addLinks": + re(t.actor, t.text); + break; + case "addALink": + n0(t.actor, t.text); + break; + case "addProperties": + ie(t.actor, t.text); + break; + case "addDetails": + oe(t.actor, t.text); + break; + case "addMessage": + if (E.records.lastCreated) { + if (t.to !== E.records.lastCreated) + throw new Error( + "The created participant " + E.records.lastCreated + " does not have an associated creating message after its declaration. Please check the sequence diagram." + ); + E.records.lastCreated = void 0; + } else if (E.records.lastDestroyed) { + if (t.to !== E.records.lastDestroyed && t.from !== E.records.lastDestroyed) + throw new Error( + "The destroyed participant " + E.records.lastDestroyed + " does not have an associated destroying message after its declaration. Please check the sequence diagram." + ); + E.records.lastDestroyed = void 0; + } + C(t.from, t.to, t.msg, t.signalType, t.activate); + break; + case "boxStart": + Oe(t.boxData); + break; + case "boxEnd": + r0(); + break; + case "loopStart": + C(void 0, void 0, t.loopText, t.signalType); + break; + case "loopEnd": + C(void 0, void 0, void 0, t.signalType); + break; + case "rectStart": + C(void 0, void 0, t.color, t.signalType); + break; + case "rectEnd": + C(void 0, void 0, void 0, t.signalType); + break; + case "optStart": + C(void 0, void 0, t.optText, t.signalType); + break; + case "optEnd": + C(void 0, void 0, void 0, t.signalType); + break; + case "altStart": + C(void 0, void 0, t.altText, t.signalType); + break; + case "else": + C(void 0, void 0, t.altText, t.signalType); + break; + case "altEnd": + C(void 0, void 0, void 0, t.signalType); + break; + case "setAccTitle": + $t(t.text); + break; + case "parStart": + C(void 0, void 0, t.parText, t.signalType); + break; + case "and": + C(void 0, void 0, t.parText, t.signalType); + break; + case "parEnd": + C(void 0, void 0, void 0, t.signalType); + break; + case "criticalStart": + C(void 0, void 0, t.criticalText, t.signalType); + break; + case "option": + C(void 0, void 0, t.optionText, t.signalType); + break; + case "criticalEnd": + C(void 0, void 0, void 0, t.signalType); + break; + case "breakStart": + C(void 0, void 0, t.breakText, t.signalType); + break; + case "breakEnd": + C(void 0, void 0, void 0, t.signalType); + break; + } +}, Qt = { + addActor: Ft, + addMessage: Ye, + addSignal: C, + addLinks: re, + addDetails: oe, + addProperties: ie, + autoWrap: gt, + setWrap: Qe, + enableSequenceNumbers: Xe, + disableSequenceNumbers: Je, + showSequenceNumbers: Ze, + getMessages: qe, + getActors: He, + getCreatedActors: Ue, + getDestroyedActors: Ke, + getActor: _t, + getActorKeys: Ge, + getActorProperty: i0, + getAccTitle: we, + getBoxes: ze, + getDiagramTitle: _e, + setDiagramTitle: ke, + getConfig: () => st().sequence, + clear: je, + parseMessage: $e, + parseBoxData: t0, + LINETYPE: mt, + ARROWTYPE: e0, + PLACEMENT: s0, + addNote: ne, + setAccTitle: $t, + apply: ce, + setAccDescription: Pe, + getAccDescription: Le, + hasAtLeastOneBox: Fe, + hasAtLeastOneBoxWithTitle: We +}, a0 = (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; + } +`, o0 = a0, ft = 18 * 2, le = "actor-top", de = "actor-bottom", Ut = function(t, e) { + return Se(t, e); +}, c0 = function(t, e, c, s, r) { + if (e.links === void 0 || e.links === null || Object.keys(e.links).length === 0) + return { height: 0, width: 0 }; + const i = e.links, o = e.actorCnt, l = e.rectData; + var u = "none"; + r && (u = "block !important"); + const n = t.append("g"); + n.attr("id", "actor" + o + "_popup"), n.attr("class", "actorPopupMenu"), n.attr("display", u); + var x = ""; + l.class !== void 0 && (x = " " + l.class); + let T = l.width > c ? l.width : c; + const p = n.append("rect"); + if (p.attr("class", "actorPopupMenuPanel" + x), p.attr("x", l.x), p.attr("y", l.height), p.attr("fill", l.fill), p.attr("stroke", l.stroke), p.attr("width", T), p.attr("height", l.height), p.attr("rx", l.rx), p.attr("ry", l.ry), i != null) { + var g = 20; + for (let A in i) { + var m = n.append("a"), k = te.sanitizeUrl(i[A]); + m.attr("xlink:href", k), m.attr("target", "_blank"), P0(s)( + A, + m, + l.x + 10, + l.height + g, + T, + 20, + { class: "actor" }, + s + ), g += 30; + } + } + return p.attr("height", g), { height: l.height + g, width: T }; +}, l0 = function(t) { + return "var pu = document.getElementById('" + t + "'); if (pu != null) { pu.style.display = pu.style.display == 'block' ? 'none' : 'block'; }"; +}, At = async function(t, e, c = null) { + let s = t.append("foreignObject"); + const r = await se(e.text, Bt()), o = s.append("xhtml:div").attr("style", "width: fit-content;").attr("xmlns", "http://www.w3.org/1999/xhtml").html(r).node().getBoundingClientRect(); + if (s.attr("height", Math.round(o.height)).attr("width", Math.round(o.width)), e.class === "noteText") { + const l = t.node().firstChild; + l.setAttribute("height", o.height + 2 * e.textMargin); + const u = l.getBBox(); + s.attr("x", Math.round(u.x + u.width / 2 - o.width / 2)).attr("y", Math.round(u.y + u.height / 2 - o.height / 2)); + } else if (c) { + let { startx: l, stopx: u, starty: n } = c; + if (l > u) { + const x = l; + l = u, u = x; + } + s.attr("x", Math.round(l + Math.abs(l - u) / 2 - o.width / 2)), e.class === "loopText" ? s.attr("y", Math.round(n)) : s.attr("y", Math.round(n - o.height)); + } + return [s]; +}, bt = function(t, e) { + let c = 0, s = 0; + const r = e.text.split(_.lineBreakRegex), [i, o] = ee(e.fontSize); + let l = [], u = 0, n = () => e.y; + if (e.valign !== void 0 && e.textMargin !== void 0 && e.textMargin > 0) + switch (e.valign) { + case "top": + case "start": + n = () => Math.round(e.y + e.textMargin); + break; + case "middle": + case "center": + n = () => Math.round(e.y + (c + s + e.textMargin) / 2); + break; + case "bottom": + case "end": + n = () => Math.round( + e.y + (c + s + 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 [x, T] of r.entries()) { + e.textMargin !== void 0 && e.textMargin === 0 && i !== void 0 && (u = x * i); + const p = t.append("text"); + p.attr("x", e.x), p.attr("y", n()), 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); + const g = T || Ae; + if (e.tspan) { + const m = p.append("tspan"); + m.attr("x", e.x), e.fill !== void 0 && m.attr("fill", e.fill), m.text(g); + } else + p.text(g); + e.valign !== void 0 && e.textMargin !== void 0 && e.textMargin > 0 && (s += (p._groups || p)[0][0].getBBox().height, c = s), l.push(p); + } + return l; +}, he = function(t, e) { + function c(r, i, o, l, u) { + return r + "," + i + " " + (r + o) + "," + i + " " + (r + o) + "," + (i + l - u) + " " + (r + o - u * 1.2) + "," + (i + l) + " " + r + "," + (i + l); + } + const s = t.append("polygon"); + return s.attr("points", c(e.x, e.y, e.width, e.height, 7)), s.attr("class", "labelBox"), e.y = e.y + e.height / 2, bt(t, e), s; +}; +let it = -1; +const ue = (t, e, c, s) => { + t.select && c.forEach((r) => { + const i = e[r], o = t.select("#actor" + i.actorCnt); + !s.mirrorActors && i.stopy ? o.attr("y2", i.stopy + i.height / 2) : s.mirrorActors && o.attr("y2", i.stopy); + }); +}, d0 = async function(t, e, c, s) { + const r = s ? e.stopy : e.starty, i = e.x + e.width / 2, o = r + 5, l = t.append("g").lower(); + var u = l; + s || (it++, Object.keys(e.links || {}).length && !c.forceMenus && u.attr("onclick", l0(`actor${it}_popup`)).attr("cursor", "pointer"), u.append("line").attr("id", "actor" + it).attr("x1", i).attr("y1", o).attr("x2", i).attr("y2", 2e3).attr("class", "actor-line").attr("class", "200").attr("stroke-width", "0.5px").attr("stroke", "#999"), u = l.append("g"), e.actorCnt = it, e.links != null && u.attr("id", "root-" + it)); + const n = vt(); + var x = "actor"; + e.properties != null && e.properties.class ? x = e.properties.class : n.fill = "#eaeaea", s ? x += ` ${de}` : x += ` ${le}`, n.x = e.x, n.y = r, n.width = e.width, n.height = e.height, n.class = x, n.rx = 3, n.ry = 3, n.name = e.name; + const T = Ut(u, n); + if (e.rectData = n, e.properties != null && e.properties.icon) { + const g = e.properties.icon.trim(); + g.charAt(0) === "@" ? Re(u, n.x + n.width - 20, n.y + 10, g.substr(1)) : Ce(u, n.x + n.width - 20, n.y + 10, g); + } + await Kt(c, at(e.description))( + e.description, + u, + n.x, + n.y, + n.width, + n.height, + { class: "actor" }, + c + ); + let p = e.height; + if (T.node) { + const g = T.node().getBBox(); + e.height = g.height, p = g.height; + } + return p; +}, h0 = async function(t, e, c, s) { + const r = s ? e.stopy : e.starty, i = e.x + e.width / 2, o = r + 80; + t.lower(), s || (it++, t.append("line").attr("id", "actor" + it).attr("x1", i).attr("y1", o).attr("x2", i).attr("y2", 2e3).attr("class", "actor-line").attr("class", "200").attr("stroke-width", "0.5px").attr("stroke", "#999"), e.actorCnt = it); + const l = t.append("g"); + let u = "actor-man"; + s ? u += ` ${de}` : u += ` ${le}`, l.attr("class", u), l.attr("name", e.name); + const n = vt(); + n.x = e.x, n.y = r, n.fill = "#eaeaea", n.width = e.width, n.height = e.height, n.class = "actor", n.rx = 3, n.ry = 3, l.append("line").attr("id", "actor-man-torso" + it).attr("x1", i).attr("y1", r + 25).attr("x2", i).attr("y2", r + 45), l.append("line").attr("id", "actor-man-arms" + it).attr("x1", i - ft / 2).attr("y1", r + 33).attr("x2", i + ft / 2).attr("y2", r + 33), l.append("line").attr("x1", i - ft / 2).attr("y1", r + 60).attr("x2", i).attr("y2", r + 45), l.append("line").attr("x1", i).attr("y1", r + 45).attr("x2", i + ft / 2 - 2).attr("y2", r + 60); + const x = l.append("circle"); + x.attr("cx", e.x + e.width / 2), x.attr("cy", r + 10), x.attr("r", 15), x.attr("width", e.width), x.attr("height", e.height); + const T = l.node().getBBox(); + return e.height = T.height, await Kt(c, at(e.description))( + e.description, + l, + n.x, + n.y + 35, + n.width, + n.height, + { class: "actor" }, + c + ), e.height; +}, u0 = async function(t, e, c, s) { + switch (e.type) { + case "actor": + return await h0(t, e, c, s); + case "participant": + return await d0(t, e, c, s); + } +}, p0 = async function(t, e, c) { + const r = t.append("g"); + pe(r, e), e.name && await Kt(c)( + e.name, + r, + e.x, + e.y + (e.textMaxHeight || 0) / 2, + e.width, + 0, + { class: "text" }, + c + ), r.lower(); +}, f0 = function(t) { + return t.append("g"); +}, g0 = function(t, e, c, s, r) { + const i = vt(), o = e.anchored; + i.x = e.startx, i.y = e.starty, i.class = "activation" + r % 3, i.width = e.stopx - e.startx, i.height = c - e.starty, Ut(o, i); +}, x0 = async function(t, e, c, s) { + const { + boxMargin: r, + boxTextMargin: i, + labelBoxHeight: o, + labelBoxWidth: l, + messageFontFamily: u, + messageFontSize: n, + messageFontWeight: x + } = s, T = t.append("g"), p = function(k, A, V, S) { + return T.append("line").attr("x1", k).attr("y1", A).attr("x2", V).attr("y2", S).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(k) { + p(e.startx, k.y, e.stopx, k.y).style( + "stroke-dasharray", + "3, 3" + ); + }); + let g = zt(); + g.text = c, g.x = e.startx, g.y = e.starty, g.fontFamily = u, g.fontSize = n, g.fontWeight = x, g.anchor = "middle", g.valign = "middle", g.tspan = !1, g.width = l || 50, g.height = o || 20, g.textMargin = i, g.class = "labelText", he(T, g), g = fe(), g.text = e.title, g.x = e.startx + l / 2 + (e.stopx - e.startx) / 2, g.y = e.starty + r + i, g.anchor = "middle", g.valign = "middle", g.textMargin = i, g.class = "loopText", g.fontFamily = u, g.fontSize = n, g.fontWeight = x, g.wrap = !0; + let m = at(g.text) ? await At(T, g, e) : bt(T, g); + if (e.sectionTitles !== void 0) { + for (const [k, A] of Object.entries(e.sectionTitles)) + if (A.message) { + g.text = A.message, g.x = e.startx + (e.stopx - e.startx) / 2, g.y = e.sections[k].y + r + i, g.class = "loopText", g.anchor = "middle", g.valign = "middle", g.tspan = !1, g.fontFamily = u, g.fontSize = n, g.fontWeight = x, g.wrap = e.wrap, at(g.text) ? (e.starty = e.sections[k].y, await At(T, g, e)) : bt(T, g); + let V = Math.round( + m.map((S) => (S._groups || S)[0][0].getBBox().height).reduce((S, O) => S + O) + ); + e.sections[k].height += V - (r + i); + } + } + return e.height = Math.round(e.stopy - e.starty), T; +}, pe = function(t, e) { + Me(t, e); +}, y0 = 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-.047.148-.048.143-.049.139-.049.136-.05.131-.05.126-.05.123-.051.118-.052.114-.051.11-.052.106-.052.101-.052.096-.052.092-.052.088-.053.083-.051.079-.052.074-.052.07-.051.065-.051.06-.051.056-.05.051-.05.023-.024.023-.025.021-.024.02-.024.019-.024.018-.024.017-.024.015-.023.014-.024.013-.023.012-.023.01-.023.01-.022.008-.022.006-.022.006-.022.004-.022.004-.021.001-.021.001-.021v-4.127l-.077.055-.08.053-.083.054-.085.053-.087.052-.09.052-.093.051-.095.05-.097.05-.1.049-.102.049-.105.048-.106.047-.109.047-.111.046-.114.045-.115.045-.118.044-.12.043-.122.042-.124.042-.126.041-.128.04-.13.04-.132.038-.134.038-.135.037-.138.037-.139.035-.142.035-.143.034-.144.033-.147.032-.148.031-.15.03-.151.03-.153.029-.154.027-.156.027-.158.026-.159.025-.161.024-.162.023-.163.022-.165.021-.166.02-.167.019-.169.018-.169.017-.171.016-.173.015-.173.014-.175.013-.175.012-.177.011-.178.01-.179.008-.179.008-.181.006-.182.005-.182.004-.184.003-.184.002h-.37l-.184-.002-.184-.003-.182-.004-.182-.005-.181-.006-.179-.008-.179-.008-.178-.01-.176-.011-.176-.012-.175-.013-.173-.014-.172-.015-.171-.016-.17-.017-.169-.018-.167-.019-.166-.02-.165-.021-.163-.022-.162-.023-.161-.024-.159-.025-.157-.026-.156-.027-.155-.027-.153-.029-.151-.03-.15-.03-.148-.031-.146-.032-.145-.033-.143-.034-.141-.035-.14-.035-.137-.037-.136-.037-.134-.038-.132-.038-.13-.04-.128-.04-.126-.041-.124-.042-.122-.042-.12-.044-.117-.043-.116-.045-.113-.045-.112-.046-.109-.047-.106-.047-.105-.048-.102-.049-.1-.049-.097-.05-.095-.05-.093-.052-.09-.051-.087-.052-.085-.053-.083-.054-.08-.054-.077-.054v4.127zm0-5.654v.011l.001.021.003.021.004.021.005.022.006.022.007.022.009.022.01.022.011.023.012.023.013.023.015.024.016.023.017.024.018.024.019.024.021.024.022.024.023.025.024.024.052.05.056.05.061.05.066.051.07.051.075.052.079.051.084.052.088.052.092.052.097.052.102.052.105.052.11.051.114.051.119.052.123.05.127.051.131.05.135.049.139.049.144.048.147.048.152.047.155.046.16.045.163.045.167.044.171.042.176.042.178.04.183.04.187.038.19.037.194.036.197.034.202.033.204.032.209.03.212.028.216.027.219.025.222.024.226.022.23.02.233.018.236.016.24.014.243.012.246.01.249.008.253.006.256.003.259.001.26-.001.257-.003.254-.006.25-.008.247-.01.244-.012.241-.015.237-.016.233-.018.231-.02.226-.022.224-.024.22-.025.216-.027.212-.029.21-.03.205-.032.202-.033.198-.035.194-.036.191-.037.187-.039.183-.039.179-.041.175-.042.172-.043.168-.044.163-.045.16-.045.155-.047.152-.047.148-.048.143-.048.139-.05.136-.049.131-.05.126-.051.123-.051.118-.051.114-.052.11-.052.106-.052.101-.052.096-.052.092-.052.088-.052.083-.052.079-.052.074-.051.07-.052.065-.051.06-.05.056-.051.051-.049.023-.025.023-.024.021-.025.02-.024.019-.024.018-.024.017-.024.015-.023.014-.023.013-.024.012-.022.01-.023.01-.023.008-.022.006-.022.006-.022.004-.021.004-.022.001-.021.001-.021v-4.139l-.077.054-.08.054-.083.054-.085.052-.087.053-.09.051-.093.051-.095.051-.097.05-.1.049-.102.049-.105.048-.106.047-.109.047-.111.046-.114.045-.115.044-.118.044-.12.044-.122.042-.124.042-.126.041-.128.04-.13.039-.132.039-.134.038-.135.037-.138.036-.139.036-.142.035-.143.033-.144.033-.147.033-.148.031-.15.03-.151.03-.153.028-.154.028-.156.027-.158.026-.159.025-.161.024-.162.023-.163.022-.165.021-.166.02-.167.019-.169.018-.169.017-.171.016-.173.015-.173.014-.175.013-.175.012-.177.011-.178.009-.179.009-.179.007-.181.007-.182.005-.182.004-.184.003-.184.002h-.37l-.184-.002-.184-.003-.182-.004-.182-.005-.181-.007-.179-.007-.179-.009-.178-.009-.176-.011-.176-.012-.175-.013-.173-.014-.172-.015-.171-.016-.17-.017-.169-.018-.167-.019-.166-.02-.165-.021-.163-.022-.162-.023-.161-.024-.159-.025-.157-.026-.156-.027-.155-.028-.153-.028-.151-.03-.15-.03-.148-.031-.146-.033-.145-.033-.143-.033-.141-.035-.14-.036-.137-.036-.136-.037-.134-.038-.132-.039-.13-.039-.128-.04-.126-.041-.124-.042-.122-.043-.12-.043-.117-.044-.116-.044-.113-.046-.112-.046-.109-.046-.106-.047-.105-.048-.102-.049-.1-.049-.097-.05-.095-.051-.093-.051-.09-.051-.087-.053-.085-.052-.083-.054-.08-.054-.077-.054v4.139zm0-5.666v.011l.001.02.003.022.004.021.005.022.006.021.007.022.009.023.01.022.011.023.012.023.013.023.015.023.016.024.017.024.018.023.019.024.021.025.022.024.023.024.024.025.052.05.056.05.061.05.066.051.07.051.075.052.079.051.084.052.088.052.092.052.097.052.102.052.105.051.11.052.114.051.119.051.123.051.127.05.131.05.135.05.139.049.144.048.147.048.152.047.155.046.16.045.163.045.167.043.171.043.176.042.178.04.183.04.187.038.19.037.194.036.197.034.202.033.204.032.209.03.212.028.216.027.219.025.222.024.226.021.23.02.233.018.236.017.24.014.243.012.246.01.249.008.253.006.256.003.259.001.26-.001.257-.003.254-.006.25-.008.247-.01.244-.013.241-.014.237-.016.233-.018.231-.02.226-.022.224-.024.22-.025.216-.027.212-.029.21-.03.205-.032.202-.033.198-.035.194-.036.191-.037.187-.039.183-.039.179-.041.175-.042.172-.043.168-.044.163-.045.16-.045.155-.047.152-.047.148-.048.143-.049.139-.049.136-.049.131-.051.126-.05.123-.051.118-.052.114-.051.11-.052.106-.052.101-.052.096-.052.092-.052.088-.052.083-.052.079-.052.074-.052.07-.051.065-.051.06-.051.056-.05.051-.049.023-.025.023-.025.021-.024.02-.024.019-.024.018-.024.017-.024.015-.023.014-.024.013-.023.012-.023.01-.022.01-.023.008-.022.006-.022.006-.022.004-.022.004-.021.001-.021.001-.021v-4.153l-.077.054-.08.054-.083.053-.085.053-.087.053-.09.051-.093.051-.095.051-.097.05-.1.049-.102.048-.105.048-.106.048-.109.046-.111.046-.114.046-.115.044-.118.044-.12.043-.122.043-.124.042-.126.041-.128.04-.13.039-.132.039-.134.038-.135.037-.138.036-.139.036-.142.034-.143.034-.144.033-.147.032-.148.032-.15.03-.151.03-.153.028-.154.028-.156.027-.158.026-.159.024-.161.024-.162.023-.163.023-.165.021-.166.02-.167.019-.169.018-.169.017-.171.016-.173.015-.173.014-.175.013-.175.012-.177.01-.178.01-.179.009-.179.007-.181.006-.182.006-.182.004-.184.003-.184.001-.185.001-.185-.001-.184-.001-.184-.003-.182-.004-.182-.006-.181-.006-.179-.007-.179-.009-.178-.01-.176-.01-.176-.012-.175-.013-.173-.014-.172-.015-.171-.016-.17-.017-.169-.018-.167-.019-.166-.02-.165-.021-.163-.023-.162-.023-.161-.024-.159-.024-.157-.026-.156-.027-.155-.028-.153-.028-.151-.03-.15-.03-.148-.032-.146-.032-.145-.033-.143-.034-.141-.034-.14-.036-.137-.036-.136-.037-.134-.038-.132-.039-.13-.039-.128-.041-.126-.041-.124-.041-.122-.043-.12-.043-.117-.044-.116-.044-.113-.046-.112-.046-.109-.046-.106-.048-.105-.048-.102-.048-.1-.05-.097-.049-.095-.051-.093-.051-.09-.052-.087-.052-.085-.053-.083-.053-.08-.054-.077-.054v4.153zm8.74-8.179l-.257.004-.254.005-.25.008-.247.011-.244.012-.241.014-.237.016-.233.018-.231.021-.226.022-.224.023-.22.026-.216.027-.212.028-.21.031-.205.032-.202.033-.198.034-.194.036-.191.038-.187.038-.183.04-.179.041-.175.042-.172.043-.168.043-.163.045-.16.046-.155.046-.152.048-.148.048-.143.048-.139.049-.136.05-.131.05-.126.051-.123.051-.118.051-.114.052-.11.052-.106.052-.101.052-.096.052-.092.052-.088.052-.083.052-.079.052-.074.051-.07.052-.065.051-.06.05-.056.05-.051.05-.023.025-.023.024-.021.024-.02.025-.019.024-.018.024-.017.023-.015.024-.014.023-.013.023-.012.023-.01.023-.01.022-.008.022-.006.023-.006.021-.004.022-.004.021-.001.021-.001.021.001.021.001.021.004.021.004.022.006.021.006.023.008.022.01.022.01.023.012.023.013.023.014.023.015.024.017.023.018.024.019.024.02.025.021.024.023.024.023.025.051.05.056.05.06.05.065.051.07.052.074.051.079.052.083.052.088.052.092.052.096.052.101.052.106.052.11.052.114.052.118.051.123.051.126.051.131.05.136.05.139.049.143.048.148.048.152.048.155.046.16.046.163.045.168.043.172.043.175.042.179.041.183.04.187.038.191.038.194.036.198.034.202.033.205.032.21.031.212.028.216.027.22.026.224.023.226.022.231.021.233.018.237.016.241.014.244.012.247.011.25.008.254.005.257.004.26.001.26-.001.257-.004.254-.005.25-.008.247-.011.244-.012.241-.014.237-.016.233-.018.231-.021.226-.022.224-.023.22-.026.216-.027.212-.028.21-.031.205-.032.202-.033.198-.034.194-.036.191-.038.187-.038.183-.04.179-.041.175-.042.172-.043.168-.043.163-.045.16-.046.155-.046.152-.048.148-.048.143-.048.139-.049.136-.05.131-.05.126-.051.123-.051.118-.051.114-.052.11-.052.106-.052.101-.052.096-.052.092-.052.088-.052.083-.052.079-.052.074-.051.07-.052.065-.051.06-.05.056-.05.051-.05.023-.025.023-.024.021-.024.02-.025.019-.024.018-.024.017-.023.015-.024.014-.023.013-.023.012-.023.01-.023.01-.022.008-.022.006-.023.006-.021.004-.022.004-.021.001-.021.001-.021-.001-.021-.001-.021-.004-.021-.004-.022-.006-.021-.006-.023-.008-.022-.01-.022-.01-.023-.012-.023-.013-.023-.014-.023-.015-.024-.017-.023-.018-.024-.019-.024-.02-.025-.021-.024-.023-.024-.023-.025-.051-.05-.056-.05-.06-.05-.065-.051-.07-.052-.074-.051-.079-.052-.083-.052-.088-.052-.092-.052-.096-.052-.101-.052-.106-.052-.11-.052-.114-.052-.118-.051-.123-.051-.126-.051-.131-.05-.136-.05-.139-.049-.143-.048-.148-.048-.152-.048-.155-.046-.16-.046-.163-.045-.168-.043-.172-.043-.175-.042-.179-.041-.183-.04-.187-.038-.191-.038-.194-.036-.198-.034-.202-.033-.205-.032-.21-.031-.212-.028-.216-.027-.22-.026-.224-.023-.226-.022-.231-.021-.233-.018-.237-.016-.241-.014-.244-.012-.247-.011-.25-.008-.254-.005-.257-.004-.26-.001-.26.001z" + ); +}, 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" + ); +}, b0 = 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" + ); +}, E0 = function(t) { + t.append("defs").append("marker").attr("id", "arrowhead").attr("refX", 7.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"); +}, m0 = function(t) { + t.append("defs").append("marker").attr("id", "filled-head").attr("refX", 15.5).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"); +}, w0 = 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); +}, _0 = function(t) { + t.append("defs").append("marker").attr("id", "crosshead").attr("markerWidth", 15).attr("markerHeight", 8).attr("orient", "auto").attr("refX", 4).attr("refY", 4.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"); +}, fe = 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 + }; +}, k0 = function() { + return { + x: 0, + y: 0, + fill: "#EDF2AE", + stroke: "#666", + width: 100, + anchor: "start", + height: 100, + rx: 0, + ry: 0 + }; +}, Kt = function() { + function t(i, o, l, u, n, x, T) { + const p = o.append("text").attr("x", l + n / 2).attr("y", u + x / 2 + 5).style("text-anchor", "middle").text(i); + r(p, T); + } + function e(i, o, l, u, n, x, T, p) { + const { actorFontSize: g, actorFontFamily: m, actorFontWeight: k } = p, [A, V] = ee(g), S = i.split(_.lineBreakRegex); + for (let O = 0; O < S.length; O++) { + const R = O * A - A * (S.length - 1) / 2, q = o.append("text").attr("x", l + n / 2).attr("y", u).style("text-anchor", "middle").style("font-size", V).style("font-weight", k).style("font-family", m); + q.append("tspan").attr("x", l + n / 2).attr("dy", R).text(S[O]), q.attr("y", u + x / 2).attr("dominant-baseline", "central").attr("alignment-baseline", "central"), r(q, T); + } + } + function c(i, o, l, u, n, x, T, p) { + const g = o.append("switch"), k = g.append("foreignObject").attr("x", l).attr("y", u).attr("width", n).attr("height", x).append("xhtml:div").style("display", "table").style("height", "100%").style("width", "100%"); + k.append("div").style("display", "table-cell").style("text-align", "center").style("vertical-align", "middle").text(i), e(i, g, l, u, n, x, T, p), r(k, T); + } + async function s(i, o, l, u, n, x, T, p) { + const g = await wt(i, Bt()), m = o.append("switch"), A = m.append("foreignObject").attr("x", l + n / 2 - g.width / 2).attr("y", u + x / 2 - g.height / 2).attr("width", g.width).attr("height", g.height).append("xhtml:div").style("height", "100%").style("width", "100%"); + A.append("div").style("text-align", "center").style("vertical-align", "middle").html(await se(i, Bt())), e(i, m, l, u, n, x, T, p), r(A, T); + } + function r(i, o) { + for (const l in o) + o.hasOwnProperty(l) && i.attr(l, o[l]); + } + return function(i, o = !1) { + return o ? s : i.textPlacement === "fo" ? c : i.textPlacement === "old" ? t : e; + }; +}(), P0 = function() { + function t(r, i, o, l, u, n, x) { + const T = i.append("text").attr("x", o).attr("y", l).style("text-anchor", "start").text(r); + s(T, x); + } + function e(r, i, o, l, u, n, x, T) { + const { actorFontSize: p, actorFontFamily: g, actorFontWeight: m } = T, k = r.split(_.lineBreakRegex); + for (let A = 0; A < k.length; A++) { + const V = A * p - p * (k.length - 1) / 2, S = i.append("text").attr("x", o).attr("y", l).style("text-anchor", "start").style("font-size", p).style("font-weight", m).style("font-family", g); + S.append("tspan").attr("x", o).attr("dy", V).text(k[A]), S.attr("y", l + n / 2).attr("dominant-baseline", "central").attr("alignment-baseline", "central"), s(S, x); + } + } + function c(r, i, o, l, u, n, x, T) { + const p = i.append("switch"), m = p.append("foreignObject").attr("x", o).attr("y", l).attr("width", u).attr("height", n).append("xhtml:div").style("display", "table").style("height", "100%").style("width", "100%"); + m.append("div").style("display", "table-cell").style("text-align", "center").style("vertical-align", "middle").text(r), e(r, p, o, l, u, n, x, T), s(m, x); + } + function s(r, i) { + for (const o in i) + i.hasOwnProperty(o) && r.attr(o, i[o]); + } + return function(r) { + return r.textPlacement === "fo" ? c : r.textPlacement === "old" ? t : e; + }; +}(), D = { + drawRect: Ut, + drawText: bt, + drawLabel: he, + drawActor: u0, + drawBox: p0, + drawPopup: c0, + anchorElement: f0, + drawActivation: g0, + drawLoop: x0, + drawBackgroundRect: pe, + insertArrowHead: E0, + insertArrowFilledHead: m0, + insertSequenceNumber: w0, + insertArrowCrossHead: _0, + insertDatabaseIcon: y0, + insertComputerIcon: T0, + insertClockIcon: b0, + getTextObj: fe, + getNoteRect: k0, + fixLifeLineHeights: ue, + sanitizeUrl: te.sanitizeUrl +}; +let a = {}; +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(st()); + }, + updateVal: function(t, e, c, s) { + t[e] === void 0 ? t[e] = c : t[e] = s(c, t[e]); + }, + updateBounds: function(t, e, c, s) { + const r = this; + let i = 0; + function o(l) { + return function(n) { + i++; + const x = r.sequenceItems.length - i + 1; + r.updateVal(n, "starty", e - x * a.boxMargin, Math.min), r.updateVal(n, "stopy", s + x * a.boxMargin, Math.max), r.updateVal(f.data, "startx", t - x * a.boxMargin, Math.min), r.updateVal(f.data, "stopx", c + x * a.boxMargin, Math.max), l !== "activation" && (r.updateVal(n, "startx", t - x * a.boxMargin, Math.min), r.updateVal(n, "stopx", c + x * a.boxMargin, Math.max), r.updateVal(f.data, "starty", e - x * a.boxMargin, Math.min), r.updateVal(f.data, "stopy", s + x * a.boxMargin, Math.max)); + }; + } + this.sequenceItems.forEach(o()), this.activations.forEach(o("activation")); + }, + insert: function(t, e, c, s) { + const r = _.getMin(t, c), i = _.getMax(t, c), o = _.getMin(e, s), l = _.getMax(e, s); + this.updateVal(f.data, "startx", r, Math.min), this.updateVal(f.data, "starty", o, Math.min), this.updateVal(f.data, "stopx", i, Math.max), this.updateVal(f.data, "stopy", l, Math.max), this.updateBounds(r, o, i, l); + }, + newActivation: function(t, e, c) { + const s = c[t.from.actor], r = St(t.from.actor).length || 0, i = s.x + s.width / 2 + (r - 1) * a.activationWidth / 2; + this.activations.push({ + startx: i, + starty: this.verticalPos + 2, + stopx: i + a.activationWidth, + stopy: void 0, + actor: t.from.actor, + anchored: D.anchorElement(e) + }); + }, + endActivation: function(t) { + const e = this.activations.map(function(c) { + return c.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(); + }, + isLoopOverlap: function() { + return this.sequenceItems.length ? this.sequenceItems[this.sequenceItems.length - 1].overlap : !1; + }, + 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); + }, + saveVerticalPos: function() { + this.isLoopOverlap() && (this.savedVerticalPos = this.verticalPos); + }, + resetVerticalPos: function() { + this.isLoopOverlap() && (this.verticalPos = this.savedVerticalPos); + }, + bumpVerticalPos: function(t) { + this.verticalPos = this.verticalPos + t, this.data.stopy = _.getMax(this.data.stopy, this.verticalPos); + }, + getVerticalPos: function() { + return this.verticalPos; + }, + getBounds: function() { + return { bounds: this.data, models: this.models }; + } +}, L0 = async function(t, e) { + f.bumpVerticalPos(a.boxMargin), e.height = a.boxMargin, e.starty = f.getVerticalPos(); + const c = vt(); + c.x = e.startx, c.y = e.starty, c.width = e.width || a.width, c.class = "note"; + const s = t.append("g"), r = D.drawRect(s, c), i = zt(); + i.x = e.startx, i.y = e.starty, i.width = c.width, i.dy = "1em", i.text = e.message, i.class = "noteText", i.fontFamily = a.noteFontFamily, i.fontSize = a.noteFontSize, i.fontWeight = a.noteFontWeight, i.anchor = a.noteAlign, i.textMargin = a.noteMargin, i.valign = "center"; + const o = at(i.text) ? await At(s, i) : bt(s, i), l = Math.round( + o.map((u) => (u._groups || u)[0][0].getBBox().height).reduce((u, n) => u + n) + ); + r.attr("height", l + 2 * a.noteMargin), e.height += l + 2 * a.noteMargin, f.bumpVerticalPos(l + 2 * a.noteMargin), e.stopy = e.starty + l + 2 * a.noteMargin, e.stopx = e.startx + c.width, f.insert(e.startx, e.starty, e.stopx, e.stopy), f.models.addNote(e); +}, xt = (t) => ({ + fontFamily: t.messageFontFamily, + fontSize: t.messageFontSize, + fontWeight: t.messageFontWeight +}), Tt = (t) => ({ + fontFamily: t.noteFontFamily, + fontSize: t.noteFontSize, + fontWeight: t.noteFontWeight +}), Wt = (t) => ({ + fontFamily: t.actorFontFamily, + fontSize: t.actorFontSize, + fontWeight: t.actorFontWeight +}); +async function I0(t, e) { + f.bumpVerticalPos(10); + const { startx: c, stopx: s, message: r } = e, i = _.splitBreaks(r).length, o = at(r), l = o ? await wt(r, st()) : B.calculateTextDimensions(r, xt(a)); + if (!o) { + const T = l.height / i; + e.height += T, f.bumpVerticalPos(T); + } + let u, n = l.height - 10; + const x = l.width; + if (c === s) { + u = f.getVerticalPos() + n, a.rightAngles || (n += a.boxMargin, u = f.getVerticalPos() + n), n += 30; + const T = _.getMax(x / 2, a.width / 2); + f.insert( + c - T, + f.getVerticalPos() - 10 + n, + s + T, + f.getVerticalPos() + 30 + n + ); + } else + n += a.boxMargin, u = f.getVerticalPos() + n, f.insert(c, u - 10, s, u); + return f.bumpVerticalPos(n), e.height += n, e.stopy = e.starty + e.height, f.insert(e.fromBounds, e.starty, e.toBounds, e.stopy), u; +} +const A0 = async function(t, e, c, s) { + const { startx: r, stopx: i, starty: o, message: l, type: u, sequenceIndex: n, sequenceVisible: x } = e, T = B.calculateTextDimensions(l, xt(a)), p = zt(); + p.x = r, p.y = o + 10, p.width = i - r, p.class = "messageText", p.dy = "1em", p.text = l, p.fontFamily = a.messageFontFamily, p.fontSize = a.messageFontSize, p.fontWeight = a.messageFontWeight, p.anchor = a.messageAlign, p.valign = "center", p.textMargin = a.wrapPadding, p.tspan = !1, at(p.text) ? await At(t, p, { startx: r, stopx: i, starty: c }) : bt(t, p); + const g = T.width; + let m; + r === i ? a.rightAngles ? m = t.append("path").attr( + "d", + `M ${r},${c} H ${r + _.getMax(a.width / 2, g / 2)} V ${c + 25} H ${r}` + ) : m = t.append("path").attr( + "d", + "M " + r + "," + c + " C " + (r + 60) + "," + (c - 10) + " " + (r + 60) + "," + (c + 30) + " " + r + "," + (c + 20) + ) : (m = t.append("line"), m.attr("x1", r), m.attr("y1", c), m.attr("x2", i), m.attr("y2", c)), u === s.db.LINETYPE.DOTTED || u === s.db.LINETYPE.DOTTED_CROSS || u === s.db.LINETYPE.DOTTED_POINT || u === s.db.LINETYPE.DOTTED_OPEN ? (m.style("stroke-dasharray", "3, 3"), m.attr("class", "messageLine1")) : m.attr("class", "messageLine0"); + let k = ""; + a.arrowMarkerAbsolute && (k = window.location.protocol + "//" + window.location.host + window.location.pathname + window.location.search, k = k.replace(/\(/g, "\\("), k = k.replace(/\)/g, "\\)")), m.attr("stroke-width", 2), m.attr("stroke", "none"), m.style("fill", "none"), (u === s.db.LINETYPE.SOLID || u === s.db.LINETYPE.DOTTED) && m.attr("marker-end", "url(" + k + "#arrowhead)"), (u === s.db.LINETYPE.SOLID_POINT || u === s.db.LINETYPE.DOTTED_POINT) && m.attr("marker-end", "url(" + k + "#filled-head)"), (u === s.db.LINETYPE.SOLID_CROSS || u === s.db.LINETYPE.DOTTED_CROSS) && m.attr("marker-end", "url(" + k + "#crosshead)"), (x || a.showSequenceNumbers) && (m.attr("marker-start", "url(" + k + "#sequencenumber)"), t.append("text").attr("x", r).attr("y", c + 4).attr("font-family", "sans-serif").attr("font-size", "12px").attr("text-anchor", "middle").attr("class", "sequenceNumber").text(n)); +}, N0 = async function(t, e, c, s, r, i, o) { + let l = 0, u = 0, n, x = 0; + for (const T of s) { + const p = e[T], g = p.box; + n && n != g && (o || f.models.addBox(n), u += a.boxMargin + n.margin), g && g != n && (o || (g.x = l + u, g.y = r), u += g.margin), p.width = p.width || a.width, p.height = _.getMax(p.height || a.height, a.height), p.margin = p.margin || a.actorMargin, x = _.getMax(x, p.height), c[p.name] && (u += p.width / 2), p.x = l + u, p.starty = f.getVerticalPos(), f.insert(p.x, r, p.x + p.width, p.height), l += p.width + u, p.box && (p.box.width = l + g.margin - p.box.x), u = p.margin, n = p.box, f.models.addActor(p); + } + n && !o && f.models.addBox(n), f.bumpVerticalPos(x); +}, qt = async function(t, e, c, s) { + if (s) { + let r = 0; + f.bumpVerticalPos(a.boxMargin * 2); + for (const i of c) { + const o = e[i]; + o.stopy || (o.stopy = f.getVerticalPos()); + const l = await D.drawActor(t, o, a, !0); + r = _.getMax(r, l); + } + f.bumpVerticalPos(r + a.boxMargin); + } else + for (const r of c) { + const i = e[r]; + await D.drawActor(t, i, a, !1); + } +}, ge = function(t, e, c, s) { + let r = 0, i = 0; + for (const o of c) { + const l = e[o], u = R0(l), n = D.drawPopup( + t, + l, + u, + a, + a.forceMenus, + s + ); + n.height > r && (r = n.height), n.width + l.x > i && (i = n.width + l.x); + } + return { maxHeight: r, maxWidth: i }; +}, xe = function(t) { + Ne(a, t), t.fontFamily && (a.actorFontFamily = a.noteFontFamily = a.messageFontFamily = t.fontFamily), t.fontSize && (a.actorFontSize = a.noteFontSize = a.messageFontSize = t.fontSize), t.fontWeight && (a.actorFontWeight = a.noteFontWeight = a.messageFontWeight = t.fontWeight); +}, St = function(t) { + return f.activations.filter(function(e) { + return e.actor === t; + }); +}, jt = function(t, e) { + const c = e[t], s = St(t), r = s.reduce(function(o, l) { + return _.getMin(o, l.startx); + }, c.x + c.width / 2 - 1), i = s.reduce(function(o, l) { + return _.getMax(o, l.stopx); + }, c.x + c.width / 2 + 1); + return [r, i]; +}; +function rt(t, e, c, s, r) { + f.bumpVerticalPos(c); + let i = s; + if (e.id && e.message && t[e.id]) { + const o = t[e.id].width, l = xt(a); + e.message = B.wrapLabel(`[${e.message}]`, o - 2 * a.wrapPadding, l), e.width = o, e.wrap = !0; + const u = B.calculateTextDimensions(e.message, l), n = _.getMax(u.height, a.labelBoxHeight); + i = s + n, X.debug(`${n} - ${e.message}`); + } + r(e), f.bumpVerticalPos(i); +} +function v0(t, e, c, s, r, i, o) { + function l(n, x) { + n.x < r[t.from].x ? (f.insert( + e.stopx - x, + e.starty, + e.startx, + e.stopy + n.height / 2 + a.noteMargin + ), e.stopx = e.stopx + x) : (f.insert( + e.startx, + e.starty, + e.stopx + x, + e.stopy + n.height / 2 + a.noteMargin + ), e.stopx = e.stopx - x); + } + function u(n, x) { + n.x < r[t.to].x ? (f.insert( + e.startx - x, + e.starty, + e.stopx, + e.stopy + n.height / 2 + a.noteMargin + ), e.startx = e.startx + x) : (f.insert( + e.stopx, + e.starty, + e.startx + x, + e.stopy + n.height / 2 + a.noteMargin + ), e.startx = e.startx - x); + } + if (i[t.to] == s) { + const n = r[t.to], x = n.type == "actor" ? ft / 2 + 3 : n.width / 2 + 3; + l(n, x), n.starty = c - n.height / 2, f.bumpVerticalPos(n.height / 2); + } else if (o[t.from] == s) { + const n = r[t.from]; + if (a.mirrorActors) { + const x = n.type == "actor" ? ft / 2 : n.width / 2; + u(n, x); + } + n.stopy = c - n.height / 2, f.bumpVerticalPos(n.height / 2); + } else if (o[t.to] == s) { + const n = r[t.to]; + if (a.mirrorActors) { + const x = n.type == "actor" ? ft / 2 + 3 : n.width / 2 + 3; + l(n, x); + } + n.stopy = c - n.height / 2, f.bumpVerticalPos(n.height / 2); + } +} +const S0 = async function(t, e, c, s) { + const { securityLevel: r, sequence: i } = st(); + a = i; + let o; + r === "sandbox" && (o = It("#i" + e)); + const l = r === "sandbox" ? It(o.nodes()[0].contentDocument.body) : It("body"), u = r === "sandbox" ? o.nodes()[0].contentDocument : document; + f.init(), X.debug(s.db); + const n = r === "sandbox" ? l.select(`[id="${e}"]`) : It(`[id="${e}"]`), x = s.db.getActors(), T = s.db.getCreatedActors(), p = s.db.getDestroyedActors(), g = s.db.getBoxes(); + let m = s.db.getActorKeys(); + const k = s.db.getMessages(), A = s.db.getDiagramTitle(), V = s.db.hasAtLeastOneBox(), S = s.db.hasAtLeastOneBoxWithTitle(), O = await M0(x, k, s); + if (a.height = await C0(x, O, g), D.insertComputerIcon(n), D.insertDatabaseIcon(n), D.insertClockIcon(n), V && (f.bumpVerticalPos(a.boxMargin), S && f.bumpVerticalPos(g[0].textMaxHeight)), a.hideUnusedParticipants === !0) { + const y = /* @__PURE__ */ new Set(); + k.forEach((L) => { + y.add(L.from), y.add(L.to); + }), m = m.filter((L) => y.has(L)); + } + await N0(n, x, T, m, 0, k, !1); + const R = await O0(k, x, O, s); + D.insertArrowHead(n), D.insertArrowCrossHead(n), D.insertArrowFilledHead(n), D.insertSequenceNumber(n); + function q(y, L) { + const j = f.endActivation(y); + j.starty + 18 > L && (j.starty = L - 6, L += 12), D.drawActivation( + n, + j, + L, + a, + St(y.from.actor).length + ), f.insert(j.startx, L - 10, j.stopx, L); + } + let z = 1, J = 1; + const $ = [], H = []; + let U = 0; + for (const y of k) { + let L, j, nt; + switch (y.type) { + case s.db.LINETYPE.NOTE: + f.resetVerticalPos(), j = y.noteModel, await L0(n, j); + break; + case s.db.LINETYPE.ACTIVE_START: + f.newActivation(y, n, x); + break; + case s.db.LINETYPE.ACTIVE_END: + q(y, f.getVerticalPos()); + break; + case s.db.LINETYPE.LOOP_START: + rt( + R, + y, + a.boxMargin, + a.boxMargin + a.boxTextMargin, + (N) => f.newLoop(N) + ); + break; + case s.db.LINETYPE.LOOP_END: + L = f.endLoop(), await D.drawLoop(n, L, "loop", a), f.bumpVerticalPos(L.stopy - f.getVerticalPos()), f.models.addLoop(L); + break; + case s.db.LINETYPE.RECT_START: + rt( + R, + y, + a.boxMargin, + a.boxMargin, + (N) => f.newLoop(void 0, N.message) + ); + break; + case s.db.LINETYPE.RECT_END: + L = f.endLoop(), H.push(L), f.models.addLoop(L), f.bumpVerticalPos(L.stopy - f.getVerticalPos()); + break; + case s.db.LINETYPE.OPT_START: + rt( + R, + y, + a.boxMargin, + a.boxMargin + a.boxTextMargin, + (N) => f.newLoop(N) + ); + break; + case s.db.LINETYPE.OPT_END: + L = f.endLoop(), await D.drawLoop(n, L, "opt", a), f.bumpVerticalPos(L.stopy - f.getVerticalPos()), f.models.addLoop(L); + break; + case s.db.LINETYPE.ALT_START: + rt( + R, + y, + a.boxMargin, + a.boxMargin + a.boxTextMargin, + (N) => f.newLoop(N) + ); + break; + case s.db.LINETYPE.ALT_ELSE: + rt( + R, + y, + a.boxMargin + a.boxTextMargin, + a.boxMargin, + (N) => f.addSectionToLoop(N) + ); + break; + case s.db.LINETYPE.ALT_END: + L = f.endLoop(), await D.drawLoop(n, L, "alt", a), f.bumpVerticalPos(L.stopy - f.getVerticalPos()), f.models.addLoop(L); + break; + case s.db.LINETYPE.PAR_START: + case s.db.LINETYPE.PAR_OVER_START: + rt( + R, + y, + a.boxMargin, + a.boxMargin + a.boxTextMargin, + (N) => f.newLoop(N) + ), f.saveVerticalPos(); + break; + case s.db.LINETYPE.PAR_AND: + rt( + R, + y, + a.boxMargin + a.boxTextMargin, + a.boxMargin, + (N) => f.addSectionToLoop(N) + ); + break; + case s.db.LINETYPE.PAR_END: + L = f.endLoop(), await D.drawLoop(n, L, "par", a), f.bumpVerticalPos(L.stopy - f.getVerticalPos()), f.models.addLoop(L); + break; + case s.db.LINETYPE.AUTONUMBER: + z = y.message.start || z, J = y.message.step || J, y.message.visible ? s.db.enableSequenceNumbers() : s.db.disableSequenceNumbers(); + break; + case s.db.LINETYPE.CRITICAL_START: + rt( + R, + y, + a.boxMargin, + a.boxMargin + a.boxTextMargin, + (N) => f.newLoop(N) + ); + break; + case s.db.LINETYPE.CRITICAL_OPTION: + rt( + R, + y, + a.boxMargin + a.boxTextMargin, + a.boxMargin, + (N) => f.addSectionToLoop(N) + ); + break; + case s.db.LINETYPE.CRITICAL_END: + L = f.endLoop(), await D.drawLoop(n, L, "critical", a), f.bumpVerticalPos(L.stopy - f.getVerticalPos()), f.models.addLoop(L); + break; + case s.db.LINETYPE.BREAK_START: + rt( + R, + y, + a.boxMargin, + a.boxMargin + a.boxTextMargin, + (N) => f.newLoop(N) + ); + break; + case s.db.LINETYPE.BREAK_END: + L = f.endLoop(), await D.drawLoop(n, L, "break", a), f.bumpVerticalPos(L.stopy - f.getVerticalPos()), f.models.addLoop(L); + break; + default: + try { + nt = y.msgModel, nt.starty = f.getVerticalPos(), nt.sequenceIndex = z, nt.sequenceVisible = s.db.showSequenceNumbers(); + const N = await I0(n, nt); + v0( + y, + nt, + N, + U, + x, + T, + p + ), $.push({ messageModel: nt, lineStartY: N }), f.models.addMessage(nt); + } catch (N) { + X.error("error while drawing message", N); + } + } + [ + 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(y.type) && (z = z + J), U++; + } + X.debug("createdActors", T), X.debug("destroyedActors", p), await qt(n, x, m, !1); + for (const y of $) + await A0(n, y.messageModel, y.lineStartY, s); + a.mirrorActors && await qt(n, x, m, !0), H.forEach((y) => D.drawBackgroundRect(n, y)), ue(n, x, m, a); + for (const y of f.models.boxes) + y.height = f.getVerticalPos() - y.y, f.insert(y.x, y.y, y.x + y.width, y.height), y.startx = y.x, y.starty = y.y, y.stopx = y.startx + y.width, y.stopy = y.starty + y.height, y.stroke = "rgb(0,0,0, 0.5)", await D.drawBox(n, y, a); + V && f.bumpVerticalPos(a.boxMargin); + const F = ge(n, x, m, u), { bounds: W } = f.getBounds(); + let Z = W.stopy - W.starty; + Z < F.maxHeight && (Z = F.maxHeight); + let K = Z + 2 * a.diagramMarginY; + a.mirrorActors && (K = K - a.boxMargin + a.bottomMarginAdj); + let Q = W.stopx - W.startx; + Q < F.maxWidth && (Q = F.maxWidth); + const tt = Q + 2 * a.diagramMarginX; + A && n.append("text").text(A).attr("x", (W.stopx - W.startx) / 2 - 2 * a.diagramMarginX).attr("y", -25), ve(n, K, tt, a.useMaxWidth); + const v = A ? 40 : 0; + n.attr( + "viewBox", + W.startx - a.diagramMarginX + " -" + (a.diagramMarginY + v) + " " + tt + " " + (K + v) + ), X.debug("models:", f.models); +}; +async function M0(t, e, c) { + const s = {}; + for (const r of e) + if (t[r.to] && t[r.from]) { + const i = t[r.to]; + if (r.placement === c.db.PLACEMENT.LEFTOF && !i.prevActor || r.placement === c.db.PLACEMENT.RIGHTOF && !i.nextActor) + continue; + const o = r.placement !== void 0, l = !o, u = o ? Tt(a) : xt(a), n = r.wrap ? B.wrapLabel(r.message, a.width - 2 * a.wrapPadding, u) : r.message, T = (at(n) ? await wt(r.message, st()) : B.calculateTextDimensions(n, u)).width + 2 * a.wrapPadding; + l && r.from === i.nextActor ? s[r.to] = _.getMax( + s[r.to] || 0, + T + ) : l && r.from === i.prevActor ? s[r.from] = _.getMax( + s[r.from] || 0, + T + ) : l && r.from === r.to ? (s[r.from] = _.getMax( + s[r.from] || 0, + T / 2 + ), s[r.to] = _.getMax( + s[r.to] || 0, + T / 2 + )) : r.placement === c.db.PLACEMENT.RIGHTOF ? s[r.from] = _.getMax( + s[r.from] || 0, + T + ) : r.placement === c.db.PLACEMENT.LEFTOF ? s[i.prevActor] = _.getMax( + s[i.prevActor] || 0, + T + ) : r.placement === c.db.PLACEMENT.OVER && (i.prevActor && (s[i.prevActor] = _.getMax( + s[i.prevActor] || 0, + T / 2 + )), i.nextActor && (s[r.from] = _.getMax( + s[r.from] || 0, + T / 2 + ))); + } + return X.debug("maxMessageWidthPerActor:", s), s; +} +const R0 = function(t) { + let e = 0; + const c = Wt(a); + for (const s in t.links) { + const i = B.calculateTextDimensions(s, c).width + 2 * a.wrapPadding + 2 * a.boxMargin; + e < i && (e = i); + } + return e; +}; +async function C0(t, e, c) { + let s = 0; + for (const i of Object.keys(t)) { + const o = t[i]; + o.wrap && (o.description = B.wrapLabel( + o.description, + a.width - 2 * a.wrapPadding, + Wt(a) + )); + const l = at(o.description) ? await wt(o.description, st()) : B.calculateTextDimensions(o.description, Wt(a)); + o.width = o.wrap ? a.width : _.getMax(a.width, l.width + 2 * a.wrapPadding), o.height = o.wrap ? _.getMax(l.height, a.height) : a.height, s = _.getMax(s, o.height); + } + for (const i in e) { + const o = t[i]; + if (!o) + continue; + const l = t[o.nextActor]; + if (!l) { + const T = e[i] + a.actorMargin - o.width / 2; + o.margin = _.getMax(T, a.actorMargin); + continue; + } + const n = e[i] + a.actorMargin - o.width / 2 - l.width / 2; + o.margin = _.getMax(n, a.actorMargin); + } + let r = 0; + return c.forEach((i) => { + const o = xt(a); + let l = i.actorKeys.reduce((x, T) => x += t[T].width + (t[T].margin || 0), 0); + l -= 2 * a.boxTextMargin, i.wrap && (i.name = B.wrapLabel(i.name, l - 2 * a.wrapPadding, o)); + const u = B.calculateTextDimensions(i.name, o); + r = _.getMax(u.height, r); + const n = _.getMax(l, u.width + 2 * a.wrapPadding); + if (i.margin = a.boxTextMargin, l < n) { + const x = (n - l) / 2; + i.margin += x; + } + }), c.forEach((i) => i.textMaxHeight = r), _.getMax(s, a.height); +} +const D0 = async function(t, e, c) { + const s = e[t.from].x, r = e[t.to].x, i = t.wrap && t.message; + let o = at(t.message) ? await wt(t.message, st()) : B.calculateTextDimensions( + i ? B.wrapLabel(t.message, a.width, Tt(a)) : t.message, + Tt(a) + ); + const l = { + width: i ? a.width : _.getMax(a.width, o.width + 2 * a.noteMargin), + height: 0, + startx: e[t.from].x, + stopx: 0, + starty: 0, + stopy: 0, + message: t.message + }; + return t.placement === c.db.PLACEMENT.RIGHTOF ? (l.width = i ? _.getMax(a.width, o.width) : _.getMax( + e[t.from].width / 2 + e[t.to].width / 2, + o.width + 2 * a.noteMargin + ), l.startx = s + (e[t.from].width + a.actorMargin) / 2) : t.placement === c.db.PLACEMENT.LEFTOF ? (l.width = i ? _.getMax(a.width, o.width + 2 * a.noteMargin) : _.getMax( + e[t.from].width / 2 + e[t.to].width / 2, + o.width + 2 * a.noteMargin + ), l.startx = s - l.width + (e[t.from].width - a.actorMargin) / 2) : t.to === t.from ? (o = B.calculateTextDimensions( + i ? B.wrapLabel( + t.message, + _.getMax(a.width, e[t.from].width), + Tt(a) + ) : t.message, + Tt(a) + ), l.width = i ? _.getMax(a.width, e[t.from].width) : _.getMax( + e[t.from].width, + a.width, + o.width + 2 * a.noteMargin + ), l.startx = s + (e[t.from].width - l.width) / 2) : (l.width = Math.abs(s + e[t.from].width / 2 - (r + e[t.to].width / 2)) + a.actorMargin, l.startx = s < r ? s + e[t.from].width / 2 - a.actorMargin / 2 : r + e[t.to].width / 2 - a.actorMargin / 2), i && (l.message = B.wrapLabel( + t.message, + l.width - 2 * a.wrapPadding, + Tt(a) + )), X.debug( + `NM:[${l.startx},${l.stopx},${l.starty},${l.stopy}:${l.width},${l.height}=${t.message}]` + ), l; +}, V0 = function(t, e, c) { + if (![ + c.db.LINETYPE.SOLID_OPEN, + c.db.LINETYPE.DOTTED_OPEN, + c.db.LINETYPE.SOLID, + c.db.LINETYPE.DOTTED, + c.db.LINETYPE.SOLID_CROSS, + c.db.LINETYPE.DOTTED_CROSS, + c.db.LINETYPE.SOLID_POINT, + c.db.LINETYPE.DOTTED_POINT + ].includes(t.type)) + return {}; + const [s, r] = jt(t.from, e), [i, o] = jt(t.to, e), l = s <= i, u = l ? r : s; + let n = l ? i : o; + const x = Math.abs(i - o) > 2, T = (k) => l ? -k : k; + t.from === t.to ? n = u : (t.activate && !x && (n += T(a.activationWidth / 2 - 1)), [c.db.LINETYPE.SOLID_OPEN, c.db.LINETYPE.DOTTED_OPEN].includes(t.type) || (n += T(3))); + const p = [s, r, i, o], g = Math.abs(u - n); + t.wrap && t.message && (t.message = B.wrapLabel( + t.message, + _.getMax(g + 2 * a.wrapPadding, a.width), + xt(a) + )); + const m = B.calculateTextDimensions(t.message, xt(a)); + return { + width: _.getMax( + t.wrap ? 0 : m.width + 2 * a.wrapPadding, + g + 2 * a.wrapPadding, + a.width + ), + height: 0, + startx: u, + stopx: n, + starty: 0, + stopy: 0, + message: t.message, + type: t.type, + wrap: t.wrap, + fromBounds: Math.min.apply(null, p), + toBounds: Math.max.apply(null, p) + }; +}, O0 = async function(t, e, c, s) { + const r = {}, i = []; + let o, l, u; + for (const n of t) { + switch (n.id = B.random({ length: 10 }), n.type) { + case s.db.LINETYPE.LOOP_START: + case s.db.LINETYPE.ALT_START: + case s.db.LINETYPE.OPT_START: + case s.db.LINETYPE.PAR_START: + case s.db.LINETYPE.PAR_OVER_START: + case s.db.LINETYPE.CRITICAL_START: + case s.db.LINETYPE.BREAK_START: + i.push({ + id: n.id, + msg: n.message, + from: Number.MAX_SAFE_INTEGER, + to: Number.MIN_SAFE_INTEGER, + width: 0 + }); + break; + case s.db.LINETYPE.ALT_ELSE: + case s.db.LINETYPE.PAR_AND: + case s.db.LINETYPE.CRITICAL_OPTION: + n.message && (o = i.pop(), r[o.id] = o, r[n.id] = o, i.push(o)); + break; + case s.db.LINETYPE.LOOP_END: + case s.db.LINETYPE.ALT_END: + case s.db.LINETYPE.OPT_END: + case s.db.LINETYPE.PAR_END: + case s.db.LINETYPE.CRITICAL_END: + case s.db.LINETYPE.BREAK_END: + o = i.pop(), r[o.id] = o; + break; + case s.db.LINETYPE.ACTIVE_START: + { + const T = e[n.from ? n.from.actor : n.to.actor], p = St(n.from ? n.from.actor : n.to.actor).length, g = T.x + T.width / 2 + (p - 1) * a.activationWidth / 2, m = { + startx: g, + stopx: g + a.activationWidth, + actor: n.from.actor, + enabled: !0 + }; + f.activations.push(m); + } + break; + case s.db.LINETYPE.ACTIVE_END: + { + const T = f.activations.map((p) => p.actor).lastIndexOf(n.from.actor); + delete f.activations.splice(T, 1)[0]; + } + break; + } + n.placement !== void 0 ? (l = await D0(n, e, s), n.noteModel = l, i.forEach((T) => { + o = T, o.from = _.getMin(o.from, l.startx), o.to = _.getMax(o.to, l.startx + l.width), o.width = _.getMax(o.width, Math.abs(o.from - o.to)) - a.labelBoxWidth; + })) : (u = V0(n, e, s), n.msgModel = u, u.startx && u.stopx && i.length > 0 && i.forEach((T) => { + if (o = T, u.startx === u.stopx) { + const p = e[n.from], g = e[n.to]; + o.from = _.getMin( + p.x - u.width / 2, + p.x - p.width / 2, + o.from + ), o.to = _.getMax( + g.x + u.width / 2, + g.x + p.width / 2, + o.to + ), o.width = _.getMax(o.width, Math.abs(o.to - o.from)) - a.labelBoxWidth; + } else + o.from = _.getMin(u.startx, o.from), o.to = _.getMax(u.stopx, o.to), o.width = _.getMax(o.width, u.width) - a.labelBoxWidth; + })); + } + return f.activations = [], X.debug("Loop type widths:", r), r; +}, B0 = { + bounds: f, + drawActors: qt, + drawActorsPopup: ge, + setConf: xe, + draw: S0 +}, W0 = { + parser: De, + db: Qt, + renderer: B0, + styles: o0, + init: ({ wrap: t }) => { + Qt.setWrap(t); + } +}; +export { + W0 as diagram +}; diff --git a/0.6.0/js/mermaid/stateDiagram-5dee940d.js b/0.6.0/js/mermaid/stateDiagram-5dee940d.js new file mode 100644 index 0000000..551c82f --- /dev/null +++ b/0.6.0/js/mermaid/stateDiagram-5dee940d.js @@ -0,0 +1,474 @@ +import { d as db, p as parser, s as styles } from "./styles-0784dbeb.js"; +import { line, curveBasis, select } from "d3"; +import { layout } from "dagre-d3-es/src/dagre/index.js"; +import * as graphlib from "dagre-d3-es/src/graphlib/index.js"; +import { c as getConfig, u as utils, e as common, l as log, i as configureSvgSize } from "./mermaid-6dc72991.js"; +import "ts-dedent"; +import "dayjs"; +import "@braintree/sanitize-url"; +import "dompurify"; +import "khroma"; +import "lodash-es/memoize.js"; +import "lodash-es/merge.js"; +import "stylis"; +import "lodash-es/isEmpty.js"; +const idCache = {}; +const set = (key, val) => { + idCache[key] = val; +}; +const get = (k) => idCache[k]; +const keys = () => Object.keys(idCache); +const size = () => keys().length; +const idCache$1 = { + get, + set, + keys, + size +}; +const drawStartState = (g) => g.append("circle").attr("class", "start-state").attr("r", getConfig().state.sizeUnit).attr("cx", getConfig().state.padding + getConfig().state.sizeUnit).attr("cy", getConfig().state.padding + getConfig().state.sizeUnit); +const drawDivider = (g) => g.append("line").style("stroke", "grey").style("stroke-dasharray", "3").attr("x1", getConfig().state.textHeight).attr("class", "divider").attr("x2", getConfig().state.textHeight * 2).attr("y1", 0).attr("y2", 0); +const drawSimpleState = (g, stateDef) => { + const state = g.append("text").attr("x", 2 * getConfig().state.padding).attr("y", getConfig().state.textHeight + 2 * getConfig().state.padding).attr("font-size", getConfig().state.fontSize).attr("class", "state-title").text(stateDef.id); + const classBox = state.node().getBBox(); + g.insert("rect", ":first-child").attr("x", getConfig().state.padding).attr("y", getConfig().state.padding).attr("width", classBox.width + 2 * getConfig().state.padding).attr("height", classBox.height + 2 * getConfig().state.padding).attr("rx", getConfig().state.radius); + return state; +}; +const drawDescrState = (g, stateDef) => { + const addTspan = function(textEl, txt, isFirst2) { + const tSpan = textEl.append("tspan").attr("x", 2 * getConfig().state.padding).text(txt); + if (!isFirst2) { + tSpan.attr("dy", getConfig().state.textHeight); + } + }; + const title = g.append("text").attr("x", 2 * getConfig().state.padding).attr("y", getConfig().state.textHeight + 1.3 * getConfig().state.padding).attr("font-size", getConfig().state.fontSize).attr("class", "state-title").text(stateDef.descriptions[0]); + const titleBox = title.node().getBBox(); + const titleHeight = titleBox.height; + const description = g.append("text").attr("x", getConfig().state.padding).attr( + "y", + titleHeight + getConfig().state.padding * 0.4 + getConfig().state.dividerMargin + getConfig().state.textHeight + ).attr("class", "state-description"); + let isFirst = true; + let isSecond = true; + stateDef.descriptions.forEach(function(descr) { + if (!isFirst) { + addTspan(description, descr, isSecond); + isSecond = false; + } + isFirst = false; + }); + const descrLine = g.append("line").attr("x1", getConfig().state.padding).attr("y1", getConfig().state.padding + titleHeight + getConfig().state.dividerMargin / 2).attr("y2", getConfig().state.padding + titleHeight + getConfig().state.dividerMargin / 2).attr("class", "descr-divider"); + const descrBox = description.node().getBBox(); + const width = Math.max(descrBox.width, titleBox.width); + descrLine.attr("x2", width + 3 * getConfig().state.padding); + g.insert("rect", ":first-child").attr("x", getConfig().state.padding).attr("y", getConfig().state.padding).attr("width", width + 2 * getConfig().state.padding).attr("height", descrBox.height + titleHeight + 2 * getConfig().state.padding).attr("rx", getConfig().state.radius); + return g; +}; +const addTitleAndBox = (g, stateDef, altBkg) => { + const pad = getConfig().state.padding; + const dblPad = 2 * getConfig().state.padding; + const orgBox = g.node().getBBox(); + const orgWidth = orgBox.width; + const orgX = orgBox.x; + const title = g.append("text").attr("x", 0).attr("y", getConfig().state.titleShift).attr("font-size", getConfig().state.fontSize).attr("class", "state-title").text(stateDef.id); + const titleBox = title.node().getBBox(); + const titleWidth = titleBox.width + dblPad; + let width = Math.max(titleWidth, orgWidth); + if (width === orgWidth) { + width = width + dblPad; + } + let startX; + const graphBox = g.node().getBBox(); + if (stateDef.doc) + ; + startX = orgX - pad; + if (titleWidth > orgWidth) { + startX = (orgWidth - width) / 2 + pad; + } + if (Math.abs(orgX - graphBox.x) < pad && titleWidth > orgWidth) { + startX = orgX - (titleWidth - orgWidth) / 2; + } + const lineY = 1 - getConfig().state.textHeight; + g.insert("rect", ":first-child").attr("x", startX).attr("y", lineY).attr("class", altBkg ? "alt-composit" : "composit").attr("width", width).attr( + "height", + graphBox.height + getConfig().state.textHeight + getConfig().state.titleShift + 1 + ).attr("rx", "0"); + title.attr("x", startX + pad); + if (titleWidth <= orgWidth) { + title.attr("x", orgX + (width - dblPad) / 2 - titleWidth / 2 + pad); + } + g.insert("rect", ":first-child").attr("x", startX).attr( + "y", + getConfig().state.titleShift - getConfig().state.textHeight - getConfig().state.padding + ).attr("width", width).attr("height", getConfig().state.textHeight * 3).attr("rx", getConfig().state.radius); + g.insert("rect", ":first-child").attr("x", startX).attr( + "y", + getConfig().state.titleShift - getConfig().state.textHeight - getConfig().state.padding + ).attr("width", width).attr("height", graphBox.height + 3 + 2 * getConfig().state.textHeight).attr("rx", getConfig().state.radius); + return g; +}; +const drawEndState = (g) => { + g.append("circle").attr("class", "end-state-outer").attr("r", getConfig().state.sizeUnit + getConfig().state.miniPadding).attr( + "cx", + getConfig().state.padding + getConfig().state.sizeUnit + getConfig().state.miniPadding + ).attr( + "cy", + getConfig().state.padding + getConfig().state.sizeUnit + getConfig().state.miniPadding + ); + return g.append("circle").attr("class", "end-state-inner").attr("r", getConfig().state.sizeUnit).attr("cx", getConfig().state.padding + getConfig().state.sizeUnit + 2).attr("cy", getConfig().state.padding + getConfig().state.sizeUnit + 2); +}; +const drawForkJoinState = (g, stateDef) => { + let width = getConfig().state.forkWidth; + let height = getConfig().state.forkHeight; + if (stateDef.parentId) { + let tmp = width; + width = height; + height = tmp; + } + return g.append("rect").style("stroke", "black").style("fill", "black").attr("width", width).attr("height", height).attr("x", getConfig().state.padding).attr("y", getConfig().state.padding); +}; +const _drawLongText = (_text, x, y, g) => { + let textHeight = 0; + const textElem = g.append("text"); + textElem.style("text-anchor", "start"); + textElem.attr("class", "noteText"); + let text = _text.replace(/\r\n/g, "
    "); + text = text.replace(/\n/g, "
    "); + const lines = text.split(common.lineBreakRegex); + let tHeight = 1.25 * getConfig().state.noteMargin; + for (const line2 of lines) { + const txt = line2.trim(); + if (txt.length > 0) { + const span = textElem.append("tspan"); + span.text(txt); + if (tHeight === 0) { + const textBounds = span.node().getBBox(); + tHeight += textBounds.height; + } + textHeight += tHeight; + span.attr("x", x + getConfig().state.noteMargin); + span.attr("y", y + textHeight + 1.25 * getConfig().state.noteMargin); + } + } + return { textWidth: textElem.node().getBBox().width, textHeight }; +}; +const drawNote = (text, g) => { + g.attr("class", "state-note"); + const note = g.append("rect").attr("x", 0).attr("y", getConfig().state.padding); + const rectElem = g.append("g"); + const { textWidth, textHeight } = _drawLongText(text, 0, 0, rectElem); + note.attr("height", textHeight + 2 * getConfig().state.noteMargin); + note.attr("width", textWidth + getConfig().state.noteMargin * 2); + return note; +}; +const drawState = function(elem, stateDef) { + const id = stateDef.id; + const stateInfo = { + id, + label: stateDef.id, + width: 0, + height: 0 + }; + const g = elem.append("g").attr("id", id).attr("class", "stateGroup"); + if (stateDef.type === "start") { + drawStartState(g); + } + if (stateDef.type === "end") { + drawEndState(g); + } + if (stateDef.type === "fork" || stateDef.type === "join") { + drawForkJoinState(g, stateDef); + } + if (stateDef.type === "note") { + drawNote(stateDef.note.text, g); + } + if (stateDef.type === "divider") { + drawDivider(g); + } + if (stateDef.type === "default" && stateDef.descriptions.length === 0) { + drawSimpleState(g, stateDef); + } + if (stateDef.type === "default" && stateDef.descriptions.length > 0) { + drawDescrState(g, stateDef); + } + const stateBox = g.node().getBBox(); + stateInfo.width = stateBox.width + 2 * getConfig().state.padding; + stateInfo.height = stateBox.height + 2 * getConfig().state.padding; + idCache$1.set(id, stateInfo); + return stateInfo; +}; +let edgeCount = 0; +const drawEdge = function(elem, path, relation) { + const getRelationType = function(type) { + switch (type) { + case db.relationType.AGGREGATION: + return "aggregation"; + case db.relationType.EXTENSION: + return "extension"; + case db.relationType.COMPOSITION: + return "composition"; + case db.relationType.DEPENDENCY: + return "dependency"; + } + }; + path.points = path.points.filter((p) => !Number.isNaN(p.y)); + const lineData = path.points; + const lineFunction = line().x(function(d) { + return d.x; + }).y(function(d) { + return d.y; + }).curve(curveBasis); + const svgPath = elem.append("path").attr("d", lineFunction(lineData)).attr("id", "edge" + edgeCount).attr("class", "transition"); + let url = ""; + if (getConfig().state.arrowMarkerAbsolute) { + url = window.location.protocol + "//" + window.location.host + window.location.pathname + window.location.search; + url = url.replace(/\(/g, "\\("); + url = url.replace(/\)/g, "\\)"); + } + svgPath.attr( + "marker-end", + "url(" + url + "#" + getRelationType(db.relationType.DEPENDENCY) + "End)" + ); + if (relation.title !== void 0) { + const label = elem.append("g").attr("class", "stateLabel"); + const { x, y } = utils.calcLabelPosition(path.points); + const rows = common.getRows(relation.title); + let titleHeight = 0; + const titleRows = []; + let maxWidth = 0; + let minX = 0; + for (let i = 0; i <= rows.length; i++) { + const title = label.append("text").attr("text-anchor", "middle").text(rows[i]).attr("x", x).attr("y", y + titleHeight); + const boundsTmp = title.node().getBBox(); + maxWidth = Math.max(maxWidth, boundsTmp.width); + minX = Math.min(minX, boundsTmp.x); + log.info(boundsTmp.x, x, y + titleHeight); + if (titleHeight === 0) { + const titleBox = title.node().getBBox(); + titleHeight = titleBox.height; + log.info("Title height", titleHeight, y); + } + titleRows.push(title); + } + let boxHeight = titleHeight * rows.length; + if (rows.length > 1) { + const heightAdj = (rows.length - 1) * titleHeight * 0.5; + titleRows.forEach((title, i) => title.attr("y", y + i * titleHeight - heightAdj)); + boxHeight = titleHeight * rows.length; + } + const bounds = label.node().getBBox(); + label.insert("rect", ":first-child").attr("class", "box").attr("x", x - maxWidth / 2 - getConfig().state.padding / 2).attr("y", y - boxHeight / 2 - getConfig().state.padding / 2 - 3.5).attr("width", maxWidth + getConfig().state.padding).attr("height", boxHeight + getConfig().state.padding); + log.info(bounds); + } + edgeCount++; +}; +let conf; +const transformationLog = {}; +const setConf = function() { +}; +const insertMarkers = function(elem) { + elem.append("defs").append("marker").attr("id", "dependencyEnd").attr("refX", 19).attr("refY", 7).attr("markerWidth", 20).attr("markerHeight", 28).attr("orient", "auto").append("path").attr("d", "M 19,7 L9,13 L14,7 L9,1 Z"); +}; +const draw = function(text, id, _version, diagObj) { + conf = getConfig().state; + const securityLevel = getConfig().securityLevel; + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = select("#i" + id); + } + const root = securityLevel === "sandbox" ? select(sandboxElement.nodes()[0].contentDocument.body) : select("body"); + const doc = securityLevel === "sandbox" ? sandboxElement.nodes()[0].contentDocument : document; + log.debug("Rendering diagram " + text); + const diagram2 = root.select(`[id='${id}']`); + insertMarkers(diagram2); + const rootDoc = diagObj.db.getRootDoc(); + renderDoc(rootDoc, diagram2, void 0, false, root, doc, diagObj); + const padding = conf.padding; + const bounds = diagram2.node().getBBox(); + const width = bounds.width + padding * 2; + const height = bounds.height + padding * 2; + const svgWidth = width * 1.75; + configureSvgSize(diagram2, height, svgWidth, conf.useMaxWidth); + diagram2.attr( + "viewBox", + `${bounds.x - conf.padding} ${bounds.y - conf.padding} ` + width + " " + height + ); +}; +const getLabelWidth = (text) => { + return text ? text.length * conf.fontSizeFactor : 1; +}; +const renderDoc = (doc, diagram2, parentId, altBkg, root, domDocument, diagObj) => { + const graph = new graphlib.Graph({ + compound: true, + multigraph: true + }); + let i; + let edgeFreeDoc = true; + for (i = 0; i < doc.length; i++) { + if (doc[i].stmt === "relation") { + edgeFreeDoc = false; + break; + } + } + if (parentId) { + graph.setGraph({ + rankdir: "LR", + multigraph: true, + compound: true, + // acyclicer: 'greedy', + ranker: "tight-tree", + ranksep: edgeFreeDoc ? 1 : conf.edgeLengthFactor, + nodeSep: edgeFreeDoc ? 1 : 50, + isMultiGraph: true + // ranksep: 5, + // nodesep: 1 + }); + } else { + graph.setGraph({ + rankdir: "TB", + multigraph: true, + compound: true, + // isCompound: true, + // acyclicer: 'greedy', + // ranker: 'longest-path' + ranksep: edgeFreeDoc ? 1 : conf.edgeLengthFactor, + nodeSep: edgeFreeDoc ? 1 : 50, + ranker: "tight-tree", + // ranker: 'network-simplex' + isMultiGraph: true + }); + } + graph.setDefaultEdgeLabel(function() { + return {}; + }); + diagObj.db.extract(doc); + const states = diagObj.db.getStates(); + const relations = diagObj.db.getRelations(); + const keys2 = Object.keys(states); + for (const key of keys2) { + const stateDef = states[key]; + if (parentId) { + stateDef.parentId = parentId; + } + let node; + if (stateDef.doc) { + let sub = diagram2.append("g").attr("id", stateDef.id).attr("class", "stateGroup"); + node = renderDoc(stateDef.doc, sub, stateDef.id, !altBkg, root, domDocument, diagObj); + { + sub = addTitleAndBox(sub, stateDef, altBkg); + let boxBounds = sub.node().getBBox(); + node.width = boxBounds.width; + node.height = boxBounds.height + conf.padding / 2; + transformationLog[stateDef.id] = { y: conf.compositTitleSize }; + } + } else { + node = drawState(diagram2, stateDef); + } + if (stateDef.note) { + const noteDef = { + descriptions: [], + id: stateDef.id + "-note", + note: stateDef.note, + type: "note" + }; + const note = drawState(diagram2, noteDef); + if (stateDef.note.position === "left of") { + graph.setNode(node.id + "-note", note); + graph.setNode(node.id, node); + } else { + graph.setNode(node.id, node); + graph.setNode(node.id + "-note", note); + } + graph.setParent(node.id, node.id + "-group"); + graph.setParent(node.id + "-note", node.id + "-group"); + } else { + graph.setNode(node.id, node); + } + } + log.debug("Count=", graph.nodeCount(), graph); + let cnt = 0; + relations.forEach(function(relation) { + cnt++; + log.debug("Setting edge", relation); + graph.setEdge( + relation.id1, + relation.id2, + { + relation, + width: getLabelWidth(relation.title), + height: conf.labelHeight * common.getRows(relation.title).length, + labelpos: "c" + }, + "id" + cnt + ); + }); + layout(graph); + log.debug("Graph after layout", graph.nodes()); + const svgElem = diagram2.node(); + graph.nodes().forEach(function(v) { + if (v !== void 0 && graph.node(v) !== void 0) { + log.warn("Node " + v + ": " + JSON.stringify(graph.node(v))); + root.select("#" + svgElem.id + " #" + v).attr( + "transform", + "translate(" + (graph.node(v).x - graph.node(v).width / 2) + "," + (graph.node(v).y + (transformationLog[v] ? transformationLog[v].y : 0) - graph.node(v).height / 2) + " )" + ); + root.select("#" + svgElem.id + " #" + v).attr("data-x-shift", graph.node(v).x - graph.node(v).width / 2); + const dividers = domDocument.querySelectorAll("#" + svgElem.id + " #" + v + " .divider"); + dividers.forEach((divider) => { + const parent = divider.parentElement; + let pWidth = 0; + let pShift = 0; + if (parent) { + if (parent.parentElement) { + pWidth = parent.parentElement.getBBox().width; + } + pShift = parseInt(parent.getAttribute("data-x-shift"), 10); + if (Number.isNaN(pShift)) { + pShift = 0; + } + } + divider.setAttribute("x1", 0 - pShift + 8); + divider.setAttribute("x2", pWidth - pShift - 8); + }); + } else { + log.debug("No Node " + v + ": " + JSON.stringify(graph.node(v))); + } + }); + let stateBox = svgElem.getBBox(); + graph.edges().forEach(function(e) { + if (e !== void 0 && graph.edge(e) !== void 0) { + log.debug("Edge " + e.v + " -> " + e.w + ": " + JSON.stringify(graph.edge(e))); + drawEdge(diagram2, graph.edge(e), graph.edge(e).relation); + } + }); + stateBox = svgElem.getBBox(); + const stateInfo = { + id: parentId ? parentId : "root", + label: parentId ? parentId : "root", + width: 0, + height: 0 + }; + stateInfo.width = stateBox.width + 2 * conf.padding; + stateInfo.height = stateBox.height + 2 * conf.padding; + log.debug("Doc rendered", stateInfo, graph); + return stateInfo; +}; +const renderer = { + setConf, + draw +}; +const diagram = { + parser, + db, + renderer, + styles, + init: (cnf) => { + if (!cnf.state) { + cnf.state = {}; + } + cnf.state.arrowMarkerAbsolute = cnf.arrowMarkerAbsolute; + db.clear(); + } +}; +export { + diagram +}; diff --git a/0.6.0/js/mermaid/stateDiagram-5ec31577.js b/0.6.0/js/mermaid/stateDiagram-5ec31577.js new file mode 100644 index 0000000..b0979b3 --- /dev/null +++ b/0.6.0/js/mermaid/stateDiagram-5ec31577.js @@ -0,0 +1,467 @@ +import { d as db, p as parser, s as styles } from "./styles-f80da881.js"; +import { c as getConfig, F as curveBasis, A as utils, f as common, l as log, j as d3select, k as configureSvgSize } from "./mermaid-dcacb631.js"; +import { G as Graph } from "./graph-fe24fab6.js"; +import { l as layout } from "./layout-163b9689.js"; +import { l as line } from "./line-87f517ef.js"; +import "./array-b7dcf730.js"; +import "./path-39bad7e2.js"; +const idCache = {}; +const set = (key, val) => { + idCache[key] = val; +}; +const get = (k) => idCache[k]; +const keys = () => Object.keys(idCache); +const size = () => keys().length; +const idCache$1 = { + get, + set, + keys, + size +}; +const drawStartState = (g) => g.append("circle").attr("class", "start-state").attr("r", getConfig().state.sizeUnit).attr("cx", getConfig().state.padding + getConfig().state.sizeUnit).attr("cy", getConfig().state.padding + getConfig().state.sizeUnit); +const drawDivider = (g) => g.append("line").style("stroke", "grey").style("stroke-dasharray", "3").attr("x1", getConfig().state.textHeight).attr("class", "divider").attr("x2", getConfig().state.textHeight * 2).attr("y1", 0).attr("y2", 0); +const drawSimpleState = (g, stateDef) => { + const state = g.append("text").attr("x", 2 * getConfig().state.padding).attr("y", getConfig().state.textHeight + 2 * getConfig().state.padding).attr("font-size", getConfig().state.fontSize).attr("class", "state-title").text(stateDef.id); + const classBox = state.node().getBBox(); + g.insert("rect", ":first-child").attr("x", getConfig().state.padding).attr("y", getConfig().state.padding).attr("width", classBox.width + 2 * getConfig().state.padding).attr("height", classBox.height + 2 * getConfig().state.padding).attr("rx", getConfig().state.radius); + return state; +}; +const drawDescrState = (g, stateDef) => { + const addTspan = function(textEl, txt, isFirst2) { + const tSpan = textEl.append("tspan").attr("x", 2 * getConfig().state.padding).text(txt); + if (!isFirst2) { + tSpan.attr("dy", getConfig().state.textHeight); + } + }; + const title = g.append("text").attr("x", 2 * getConfig().state.padding).attr("y", getConfig().state.textHeight + 1.3 * getConfig().state.padding).attr("font-size", getConfig().state.fontSize).attr("class", "state-title").text(stateDef.descriptions[0]); + const titleBox = title.node().getBBox(); + const titleHeight = titleBox.height; + const description = g.append("text").attr("x", getConfig().state.padding).attr( + "y", + titleHeight + getConfig().state.padding * 0.4 + getConfig().state.dividerMargin + getConfig().state.textHeight + ).attr("class", "state-description"); + let isFirst = true; + let isSecond = true; + stateDef.descriptions.forEach(function(descr) { + if (!isFirst) { + addTspan(description, descr, isSecond); + isSecond = false; + } + isFirst = false; + }); + const descrLine = g.append("line").attr("x1", getConfig().state.padding).attr("y1", getConfig().state.padding + titleHeight + getConfig().state.dividerMargin / 2).attr("y2", getConfig().state.padding + titleHeight + getConfig().state.dividerMargin / 2).attr("class", "descr-divider"); + const descrBox = description.node().getBBox(); + const width = Math.max(descrBox.width, titleBox.width); + descrLine.attr("x2", width + 3 * getConfig().state.padding); + g.insert("rect", ":first-child").attr("x", getConfig().state.padding).attr("y", getConfig().state.padding).attr("width", width + 2 * getConfig().state.padding).attr("height", descrBox.height + titleHeight + 2 * getConfig().state.padding).attr("rx", getConfig().state.radius); + return g; +}; +const addTitleAndBox = (g, stateDef, altBkg) => { + const pad = getConfig().state.padding; + const dblPad = 2 * getConfig().state.padding; + const orgBox = g.node().getBBox(); + const orgWidth = orgBox.width; + const orgX = orgBox.x; + const title = g.append("text").attr("x", 0).attr("y", getConfig().state.titleShift).attr("font-size", getConfig().state.fontSize).attr("class", "state-title").text(stateDef.id); + const titleBox = title.node().getBBox(); + const titleWidth = titleBox.width + dblPad; + let width = Math.max(titleWidth, orgWidth); + if (width === orgWidth) { + width = width + dblPad; + } + let startX; + const graphBox = g.node().getBBox(); + if (stateDef.doc) + ; + startX = orgX - pad; + if (titleWidth > orgWidth) { + startX = (orgWidth - width) / 2 + pad; + } + if (Math.abs(orgX - graphBox.x) < pad && titleWidth > orgWidth) { + startX = orgX - (titleWidth - orgWidth) / 2; + } + const lineY = 1 - getConfig().state.textHeight; + g.insert("rect", ":first-child").attr("x", startX).attr("y", lineY).attr("class", altBkg ? "alt-composit" : "composit").attr("width", width).attr( + "height", + graphBox.height + getConfig().state.textHeight + getConfig().state.titleShift + 1 + ).attr("rx", "0"); + title.attr("x", startX + pad); + if (titleWidth <= orgWidth) { + title.attr("x", orgX + (width - dblPad) / 2 - titleWidth / 2 + pad); + } + g.insert("rect", ":first-child").attr("x", startX).attr( + "y", + getConfig().state.titleShift - getConfig().state.textHeight - getConfig().state.padding + ).attr("width", width).attr("height", getConfig().state.textHeight * 3).attr("rx", getConfig().state.radius); + g.insert("rect", ":first-child").attr("x", startX).attr( + "y", + getConfig().state.titleShift - getConfig().state.textHeight - getConfig().state.padding + ).attr("width", width).attr("height", graphBox.height + 3 + 2 * getConfig().state.textHeight).attr("rx", getConfig().state.radius); + return g; +}; +const drawEndState = (g) => { + g.append("circle").attr("class", "end-state-outer").attr("r", getConfig().state.sizeUnit + getConfig().state.miniPadding).attr( + "cx", + getConfig().state.padding + getConfig().state.sizeUnit + getConfig().state.miniPadding + ).attr( + "cy", + getConfig().state.padding + getConfig().state.sizeUnit + getConfig().state.miniPadding + ); + return g.append("circle").attr("class", "end-state-inner").attr("r", getConfig().state.sizeUnit).attr("cx", getConfig().state.padding + getConfig().state.sizeUnit + 2).attr("cy", getConfig().state.padding + getConfig().state.sizeUnit + 2); +}; +const drawForkJoinState = (g, stateDef) => { + let width = getConfig().state.forkWidth; + let height = getConfig().state.forkHeight; + if (stateDef.parentId) { + let tmp = width; + width = height; + height = tmp; + } + return g.append("rect").style("stroke", "black").style("fill", "black").attr("width", width).attr("height", height).attr("x", getConfig().state.padding).attr("y", getConfig().state.padding); +}; +const _drawLongText = (_text, x, y, g) => { + let textHeight = 0; + const textElem = g.append("text"); + textElem.style("text-anchor", "start"); + textElem.attr("class", "noteText"); + let text = _text.replace(/\r\n/g, "
    "); + text = text.replace(/\n/g, "
    "); + const lines = text.split(common.lineBreakRegex); + let tHeight = 1.25 * getConfig().state.noteMargin; + for (const line2 of lines) { + const txt = line2.trim(); + if (txt.length > 0) { + const span = textElem.append("tspan"); + span.text(txt); + if (tHeight === 0) { + const textBounds = span.node().getBBox(); + tHeight += textBounds.height; + } + textHeight += tHeight; + span.attr("x", x + getConfig().state.noteMargin); + span.attr("y", y + textHeight + 1.25 * getConfig().state.noteMargin); + } + } + return { textWidth: textElem.node().getBBox().width, textHeight }; +}; +const drawNote = (text, g) => { + g.attr("class", "state-note"); + const note = g.append("rect").attr("x", 0).attr("y", getConfig().state.padding); + const rectElem = g.append("g"); + const { textWidth, textHeight } = _drawLongText(text, 0, 0, rectElem); + note.attr("height", textHeight + 2 * getConfig().state.noteMargin); + note.attr("width", textWidth + getConfig().state.noteMargin * 2); + return note; +}; +const drawState = function(elem, stateDef) { + const id = stateDef.id; + const stateInfo = { + id, + label: stateDef.id, + width: 0, + height: 0 + }; + const g = elem.append("g").attr("id", id).attr("class", "stateGroup"); + if (stateDef.type === "start") { + drawStartState(g); + } + if (stateDef.type === "end") { + drawEndState(g); + } + if (stateDef.type === "fork" || stateDef.type === "join") { + drawForkJoinState(g, stateDef); + } + if (stateDef.type === "note") { + drawNote(stateDef.note.text, g); + } + if (stateDef.type === "divider") { + drawDivider(g); + } + if (stateDef.type === "default" && stateDef.descriptions.length === 0) { + drawSimpleState(g, stateDef); + } + if (stateDef.type === "default" && stateDef.descriptions.length > 0) { + drawDescrState(g, stateDef); + } + const stateBox = g.node().getBBox(); + stateInfo.width = stateBox.width + 2 * getConfig().state.padding; + stateInfo.height = stateBox.height + 2 * getConfig().state.padding; + idCache$1.set(id, stateInfo); + return stateInfo; +}; +let edgeCount = 0; +const drawEdge = function(elem, path, relation) { + const getRelationType = function(type) { + switch (type) { + case db.relationType.AGGREGATION: + return "aggregation"; + case db.relationType.EXTENSION: + return "extension"; + case db.relationType.COMPOSITION: + return "composition"; + case db.relationType.DEPENDENCY: + return "dependency"; + } + }; + path.points = path.points.filter((p) => !Number.isNaN(p.y)); + const lineData = path.points; + const lineFunction = line().x(function(d) { + return d.x; + }).y(function(d) { + return d.y; + }).curve(curveBasis); + const svgPath = elem.append("path").attr("d", lineFunction(lineData)).attr("id", "edge" + edgeCount).attr("class", "transition"); + let url = ""; + if (getConfig().state.arrowMarkerAbsolute) { + url = window.location.protocol + "//" + window.location.host + window.location.pathname + window.location.search; + url = url.replace(/\(/g, "\\("); + url = url.replace(/\)/g, "\\)"); + } + svgPath.attr( + "marker-end", + "url(" + url + "#" + getRelationType(db.relationType.DEPENDENCY) + "End)" + ); + if (relation.title !== void 0) { + const label = elem.append("g").attr("class", "stateLabel"); + const { x, y } = utils.calcLabelPosition(path.points); + const rows = common.getRows(relation.title); + let titleHeight = 0; + const titleRows = []; + let maxWidth = 0; + let minX = 0; + for (let i = 0; i <= rows.length; i++) { + const title = label.append("text").attr("text-anchor", "middle").text(rows[i]).attr("x", x).attr("y", y + titleHeight); + const boundsTmp = title.node().getBBox(); + maxWidth = Math.max(maxWidth, boundsTmp.width); + minX = Math.min(minX, boundsTmp.x); + log.info(boundsTmp.x, x, y + titleHeight); + if (titleHeight === 0) { + const titleBox = title.node().getBBox(); + titleHeight = titleBox.height; + log.info("Title height", titleHeight, y); + } + titleRows.push(title); + } + let boxHeight = titleHeight * rows.length; + if (rows.length > 1) { + const heightAdj = (rows.length - 1) * titleHeight * 0.5; + titleRows.forEach((title, i) => title.attr("y", y + i * titleHeight - heightAdj)); + boxHeight = titleHeight * rows.length; + } + const bounds = label.node().getBBox(); + label.insert("rect", ":first-child").attr("class", "box").attr("x", x - maxWidth / 2 - getConfig().state.padding / 2).attr("y", y - boxHeight / 2 - getConfig().state.padding / 2 - 3.5).attr("width", maxWidth + getConfig().state.padding).attr("height", boxHeight + getConfig().state.padding); + log.info(bounds); + } + edgeCount++; +}; +let conf; +const transformationLog = {}; +const setConf = function() { +}; +const insertMarkers = function(elem) { + elem.append("defs").append("marker").attr("id", "dependencyEnd").attr("refX", 19).attr("refY", 7).attr("markerWidth", 20).attr("markerHeight", 28).attr("orient", "auto").append("path").attr("d", "M 19,7 L9,13 L14,7 L9,1 Z"); +}; +const draw = function(text, id, _version, diagObj) { + conf = getConfig().state; + const securityLevel = getConfig().securityLevel; + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = d3select("#i" + id); + } + const root = securityLevel === "sandbox" ? d3select(sandboxElement.nodes()[0].contentDocument.body) : d3select("body"); + const doc = securityLevel === "sandbox" ? sandboxElement.nodes()[0].contentDocument : document; + log.debug("Rendering diagram " + text); + const diagram2 = root.select(`[id='${id}']`); + insertMarkers(diagram2); + const rootDoc = diagObj.db.getRootDoc(); + renderDoc(rootDoc, diagram2, void 0, false, root, doc, diagObj); + const padding = conf.padding; + const bounds = diagram2.node().getBBox(); + const width = bounds.width + padding * 2; + const height = bounds.height + padding * 2; + const svgWidth = width * 1.75; + configureSvgSize(diagram2, height, svgWidth, conf.useMaxWidth); + diagram2.attr( + "viewBox", + `${bounds.x - conf.padding} ${bounds.y - conf.padding} ` + width + " " + height + ); +}; +const getLabelWidth = (text) => { + return text ? text.length * conf.fontSizeFactor : 1; +}; +const renderDoc = (doc, diagram2, parentId, altBkg, root, domDocument, diagObj) => { + const graph = new Graph({ + compound: true, + multigraph: true + }); + let i; + let edgeFreeDoc = true; + for (i = 0; i < doc.length; i++) { + if (doc[i].stmt === "relation") { + edgeFreeDoc = false; + break; + } + } + if (parentId) { + graph.setGraph({ + rankdir: "LR", + multigraph: true, + compound: true, + // acyclicer: 'greedy', + ranker: "tight-tree", + ranksep: edgeFreeDoc ? 1 : conf.edgeLengthFactor, + nodeSep: edgeFreeDoc ? 1 : 50, + isMultiGraph: true + // ranksep: 5, + // nodesep: 1 + }); + } else { + graph.setGraph({ + rankdir: "TB", + multigraph: true, + compound: true, + // isCompound: true, + // acyclicer: 'greedy', + // ranker: 'longest-path' + ranksep: edgeFreeDoc ? 1 : conf.edgeLengthFactor, + nodeSep: edgeFreeDoc ? 1 : 50, + ranker: "tight-tree", + // ranker: 'network-simplex' + isMultiGraph: true + }); + } + graph.setDefaultEdgeLabel(function() { + return {}; + }); + diagObj.db.extract(doc); + const states = diagObj.db.getStates(); + const relations = diagObj.db.getRelations(); + const keys2 = Object.keys(states); + for (const key of keys2) { + const stateDef = states[key]; + if (parentId) { + stateDef.parentId = parentId; + } + let node; + if (stateDef.doc) { + let sub = diagram2.append("g").attr("id", stateDef.id).attr("class", "stateGroup"); + node = renderDoc(stateDef.doc, sub, stateDef.id, !altBkg, root, domDocument, diagObj); + { + sub = addTitleAndBox(sub, stateDef, altBkg); + let boxBounds = sub.node().getBBox(); + node.width = boxBounds.width; + node.height = boxBounds.height + conf.padding / 2; + transformationLog[stateDef.id] = { y: conf.compositTitleSize }; + } + } else { + node = drawState(diagram2, stateDef); + } + if (stateDef.note) { + const noteDef = { + descriptions: [], + id: stateDef.id + "-note", + note: stateDef.note, + type: "note" + }; + const note = drawState(diagram2, noteDef); + if (stateDef.note.position === "left of") { + graph.setNode(node.id + "-note", note); + graph.setNode(node.id, node); + } else { + graph.setNode(node.id, node); + graph.setNode(node.id + "-note", note); + } + graph.setParent(node.id, node.id + "-group"); + graph.setParent(node.id + "-note", node.id + "-group"); + } else { + graph.setNode(node.id, node); + } + } + log.debug("Count=", graph.nodeCount(), graph); + let cnt = 0; + relations.forEach(function(relation) { + cnt++; + log.debug("Setting edge", relation); + graph.setEdge( + relation.id1, + relation.id2, + { + relation, + width: getLabelWidth(relation.title), + height: conf.labelHeight * common.getRows(relation.title).length, + labelpos: "c" + }, + "id" + cnt + ); + }); + layout(graph); + log.debug("Graph after layout", graph.nodes()); + const svgElem = diagram2.node(); + graph.nodes().forEach(function(v) { + if (v !== void 0 && graph.node(v) !== void 0) { + log.warn("Node " + v + ": " + JSON.stringify(graph.node(v))); + root.select("#" + svgElem.id + " #" + v).attr( + "transform", + "translate(" + (graph.node(v).x - graph.node(v).width / 2) + "," + (graph.node(v).y + (transformationLog[v] ? transformationLog[v].y : 0) - graph.node(v).height / 2) + " )" + ); + root.select("#" + svgElem.id + " #" + v).attr("data-x-shift", graph.node(v).x - graph.node(v).width / 2); + const dividers = domDocument.querySelectorAll("#" + svgElem.id + " #" + v + " .divider"); + dividers.forEach((divider) => { + const parent = divider.parentElement; + let pWidth = 0; + let pShift = 0; + if (parent) { + if (parent.parentElement) { + pWidth = parent.parentElement.getBBox().width; + } + pShift = parseInt(parent.getAttribute("data-x-shift"), 10); + if (Number.isNaN(pShift)) { + pShift = 0; + } + } + divider.setAttribute("x1", 0 - pShift + 8); + divider.setAttribute("x2", pWidth - pShift - 8); + }); + } else { + log.debug("No Node " + v + ": " + JSON.stringify(graph.node(v))); + } + }); + let stateBox = svgElem.getBBox(); + graph.edges().forEach(function(e) { + if (e !== void 0 && graph.edge(e) !== void 0) { + log.debug("Edge " + e.v + " -> " + e.w + ": " + JSON.stringify(graph.edge(e))); + drawEdge(diagram2, graph.edge(e), graph.edge(e).relation); + } + }); + stateBox = svgElem.getBBox(); + const stateInfo = { + id: parentId ? parentId : "root", + label: parentId ? parentId : "root", + width: 0, + height: 0 + }; + stateInfo.width = stateBox.width + 2 * conf.padding; + stateInfo.height = stateBox.height + 2 * conf.padding; + log.debug("Doc rendered", stateInfo, graph); + return stateInfo; +}; +const renderer = { + setConf, + draw +}; +const diagram = { + parser, + db, + renderer, + styles, + init: (cnf) => { + if (!cnf.state) { + cnf.state = {}; + } + cnf.state.arrowMarkerAbsolute = cnf.arrowMarkerAbsolute; + db.clear(); + } +}; +export { + diagram +}; diff --git a/0.6.0/js/mermaid/stateDiagram-fca82b5b.js b/0.6.0/js/mermaid/stateDiagram-fca82b5b.js new file mode 100644 index 0000000..49516d5 --- /dev/null +++ b/0.6.0/js/mermaid/stateDiagram-fca82b5b.js @@ -0,0 +1,275 @@ +import { d as N, p as C, s as R } from "./styles-cacbff60.js"; +import { c as t, F as U, A as F, f as T, l as b, j as H, k as O } from "./mermaid-9f2aa176.js"; +import { G as X } from "./graph-0ee63739.js"; +import { l as J } from "./layout-fd473db2.js"; +import { l as Y } from "./line-24d93f1b.js"; +import "./array-2ff2c7a6.js"; +import "./path-428ebac9.js"; +const L = {}, $ = (e, i) => { + L[e] = i; +}, v = (e) => L[e], P = () => Object.keys(L), I = () => P().length, _ = { + get: v, + set: $, + keys: P, + size: I +}, j = (e) => e.append("circle").attr("class", "start-state").attr("r", t().state.sizeUnit).attr("cx", t().state.padding + t().state.sizeUnit).attr("cy", t().state.padding + t().state.sizeUnit), q = (e) => e.append("line").style("stroke", "grey").style("stroke-dasharray", "3").attr("x1", t().state.textHeight).attr("class", "divider").attr("x2", t().state.textHeight * 2).attr("y1", 0).attr("y2", 0), Z = (e, i) => { + const o = e.append("text").attr("x", 2 * t().state.padding).attr("y", t().state.textHeight + 2 * t().state.padding).attr("font-size", t().state.fontSize).attr("class", "state-title").text(i.id), d = o.node().getBBox(); + return e.insert("rect", ":first-child").attr("x", t().state.padding).attr("y", t().state.padding).attr("width", d.width + 2 * t().state.padding).attr("height", d.height + 2 * t().state.padding).attr("rx", t().state.radius), o; +}, K = (e, i) => { + const o = function(l, m, w) { + const k = l.append("tspan").attr("x", 2 * t().state.padding).text(m); + w || k.attr("dy", t().state.textHeight); + }, s = e.append("text").attr("x", 2 * t().state.padding).attr("y", t().state.textHeight + 1.3 * t().state.padding).attr("font-size", t().state.fontSize).attr("class", "state-title").text(i.descriptions[0]).node().getBBox(), g = s.height, p = e.append("text").attr("x", t().state.padding).attr( + "y", + g + t().state.padding * 0.4 + t().state.dividerMargin + t().state.textHeight + ).attr("class", "state-description"); + let a = !0, r = !0; + i.descriptions.forEach(function(l) { + a || (o(p, l, r), r = !1), a = !1; + }); + const y = e.append("line").attr("x1", t().state.padding).attr("y1", t().state.padding + g + t().state.dividerMargin / 2).attr("y2", t().state.padding + g + t().state.dividerMargin / 2).attr("class", "descr-divider"), x = p.node().getBBox(), c = Math.max(x.width, s.width); + return y.attr("x2", c + 3 * t().state.padding), e.insert("rect", ":first-child").attr("x", t().state.padding).attr("y", t().state.padding).attr("width", c + 2 * t().state.padding).attr("height", x.height + g + 2 * t().state.padding).attr("rx", t().state.radius), e; +}, Q = (e, i, o) => { + const d = t().state.padding, s = 2 * t().state.padding, g = e.node().getBBox(), p = g.width, a = g.x, r = e.append("text").attr("x", 0).attr("y", t().state.titleShift).attr("font-size", t().state.fontSize).attr("class", "state-title").text(i.id), x = r.node().getBBox().width + s; + let c = Math.max(x, p); + c === p && (c = c + s); + let l; + const m = e.node().getBBox(); + i.doc, l = a - d, x > p && (l = (p - c) / 2 + d), Math.abs(a - m.x) < d && x > p && (l = a - (x - p) / 2); + const w = 1 - t().state.textHeight; + return e.insert("rect", ":first-child").attr("x", l).attr("y", w).attr("class", o ? "alt-composit" : "composit").attr("width", c).attr( + "height", + m.height + t().state.textHeight + t().state.titleShift + 1 + ).attr("rx", "0"), r.attr("x", l + d), x <= p && r.attr("x", a + (c - s) / 2 - x / 2 + d), e.insert("rect", ":first-child").attr("x", l).attr( + "y", + t().state.titleShift - t().state.textHeight - t().state.padding + ).attr("width", c).attr("height", t().state.textHeight * 3).attr("rx", t().state.radius), e.insert("rect", ":first-child").attr("x", l).attr( + "y", + t().state.titleShift - t().state.textHeight - t().state.padding + ).attr("width", c).attr("height", m.height + 3 + 2 * t().state.textHeight).attr("rx", t().state.radius), e; +}, V = (e) => (e.append("circle").attr("class", "end-state-outer").attr("r", t().state.sizeUnit + t().state.miniPadding).attr( + "cx", + t().state.padding + t().state.sizeUnit + t().state.miniPadding +).attr( + "cy", + t().state.padding + t().state.sizeUnit + t().state.miniPadding +), e.append("circle").attr("class", "end-state-inner").attr("r", t().state.sizeUnit).attr("cx", t().state.padding + t().state.sizeUnit + 2).attr("cy", t().state.padding + t().state.sizeUnit + 2)), D = (e, i) => { + let o = t().state.forkWidth, d = t().state.forkHeight; + if (i.parentId) { + let s = o; + o = d, d = s; + } + return e.append("rect").style("stroke", "black").style("fill", "black").attr("width", o).attr("height", d).attr("x", t().state.padding).attr("y", t().state.padding); +}, tt = (e, i, o, d) => { + let s = 0; + const g = d.append("text"); + g.style("text-anchor", "start"), g.attr("class", "noteText"); + let p = e.replace(/\r\n/g, "
    "); + p = p.replace(/\n/g, "
    "); + const a = p.split(T.lineBreakRegex); + let r = 1.25 * t().state.noteMargin; + for (const y of a) { + const x = y.trim(); + if (x.length > 0) { + const c = g.append("tspan"); + if (c.text(x), r === 0) { + const l = c.node().getBBox(); + r += l.height; + } + s += r, c.attr("x", i + t().state.noteMargin), c.attr("y", o + s + 1.25 * t().state.noteMargin); + } + } + return { textWidth: g.node().getBBox().width, textHeight: s }; +}, et = (e, i) => { + i.attr("class", "state-note"); + const o = i.append("rect").attr("x", 0).attr("y", t().state.padding), d = i.append("g"), { textWidth: s, textHeight: g } = tt(e, 0, 0, d); + return o.attr("height", g + 2 * t().state.noteMargin), o.attr("width", s + t().state.noteMargin * 2), o; +}, A = function(e, i) { + const o = i.id, d = { + id: o, + label: i.id, + width: 0, + height: 0 + }, s = e.append("g").attr("id", o).attr("class", "stateGroup"); + i.type === "start" && j(s), i.type === "end" && V(s), (i.type === "fork" || i.type === "join") && D(s, i), i.type === "note" && et(i.note.text, s), i.type === "divider" && q(s), i.type === "default" && i.descriptions.length === 0 && Z(s, i), i.type === "default" && i.descriptions.length > 0 && K(s, i); + const g = s.node().getBBox(); + return d.width = g.width + 2 * t().state.padding, d.height = g.height + 2 * t().state.padding, _.set(o, d), d; +}; +let G = 0; +const at = function(e, i, o) { + const d = function(r) { + switch (r) { + case N.relationType.AGGREGATION: + return "aggregation"; + case N.relationType.EXTENSION: + return "extension"; + case N.relationType.COMPOSITION: + return "composition"; + case N.relationType.DEPENDENCY: + return "dependency"; + } + }; + i.points = i.points.filter((r) => !Number.isNaN(r.y)); + const s = i.points, g = Y().x(function(r) { + return r.x; + }).y(function(r) { + return r.y; + }).curve(U), p = e.append("path").attr("d", g(s)).attr("id", "edge" + G).attr("class", "transition"); + let a = ""; + if (t().state.arrowMarkerAbsolute && (a = window.location.protocol + "//" + window.location.host + window.location.pathname + window.location.search, a = a.replace(/\(/g, "\\("), a = a.replace(/\)/g, "\\)")), p.attr( + "marker-end", + "url(" + a + "#" + d(N.relationType.DEPENDENCY) + "End)" + ), o.title !== void 0) { + const r = e.append("g").attr("class", "stateLabel"), { x: y, y: x } = F.calcLabelPosition(i.points), c = T.getRows(o.title); + let l = 0; + const m = []; + let w = 0, k = 0; + for (let u = 0; u <= c.length; u++) { + const h = r.append("text").attr("text-anchor", "middle").text(c[u]).attr("x", y).attr("y", x + l), f = h.node().getBBox(); + w = Math.max(w, f.width), k = Math.min(k, f.x), b.info(f.x, y, x + l), l === 0 && (l = h.node().getBBox().height, b.info("Title height", l, x)), m.push(h); + } + let E = l * c.length; + if (c.length > 1) { + const u = (c.length - 1) * l * 0.5; + m.forEach((h, f) => h.attr("y", x + f * l - u)), E = l * c.length; + } + const n = r.node().getBBox(); + r.insert("rect", ":first-child").attr("class", "box").attr("x", y - w / 2 - t().state.padding / 2).attr("y", x - E / 2 - t().state.padding / 2 - 3.5).attr("width", w + t().state.padding).attr("height", E + t().state.padding), b.info(n); + } + G++; +}; +let B; +const z = {}, it = function() { +}, nt = function(e) { + e.append("defs").append("marker").attr("id", "dependencyEnd").attr("refX", 19).attr("refY", 7).attr("markerWidth", 20).attr("markerHeight", 28).attr("orient", "auto").append("path").attr("d", "M 19,7 L9,13 L14,7 L9,1 Z"); +}, st = function(e, i, o, d) { + B = t().state; + const s = t().securityLevel; + let g; + s === "sandbox" && (g = H("#i" + i)); + const p = s === "sandbox" ? H(g.nodes()[0].contentDocument.body) : H("body"), a = s === "sandbox" ? g.nodes()[0].contentDocument : document; + b.debug("Rendering diagram " + e); + const r = p.select(`[id='${i}']`); + nt(r); + const y = d.db.getRootDoc(); + W(y, r, void 0, !1, p, a, d); + const x = B.padding, c = r.node().getBBox(), l = c.width + x * 2, m = c.height + x * 2, w = l * 1.75; + O(r, m, w, B.useMaxWidth), r.attr( + "viewBox", + `${c.x - B.padding} ${c.y - B.padding} ` + l + " " + m + ); +}, rt = (e) => e ? e.length * B.fontSizeFactor : 1, W = (e, i, o, d, s, g, p) => { + const a = new X({ + compound: !0, + multigraph: !0 + }); + let r, y = !0; + for (r = 0; r < e.length; r++) + if (e[r].stmt === "relation") { + y = !1; + break; + } + o ? a.setGraph({ + rankdir: "LR", + multigraph: !0, + compound: !0, + // acyclicer: 'greedy', + ranker: "tight-tree", + ranksep: y ? 1 : B.edgeLengthFactor, + nodeSep: y ? 1 : 50, + isMultiGraph: !0 + // ranksep: 5, + // nodesep: 1 + }) : a.setGraph({ + rankdir: "TB", + multigraph: !0, + compound: !0, + // isCompound: true, + // acyclicer: 'greedy', + // ranker: 'longest-path' + ranksep: y ? 1 : B.edgeLengthFactor, + nodeSep: y ? 1 : 50, + ranker: "tight-tree", + // ranker: 'network-simplex' + isMultiGraph: !0 + }), a.setDefaultEdgeLabel(function() { + return {}; + }), p.db.extract(e); + const x = p.db.getStates(), c = p.db.getRelations(), l = Object.keys(x); + for (const n of l) { + const u = x[n]; + o && (u.parentId = o); + let h; + if (u.doc) { + let f = i.append("g").attr("id", u.id).attr("class", "stateGroup"); + h = W(u.doc, f, u.id, !d, s, g, p); + { + f = Q(f, u, d); + let S = f.node().getBBox(); + h.width = S.width, h.height = S.height + B.padding / 2, z[u.id] = { y: B.compositTitleSize }; + } + } else + h = A(i, u); + if (u.note) { + const f = { + descriptions: [], + id: u.id + "-note", + note: u.note, + type: "note" + }, S = A(i, f); + u.note.position === "left of" ? (a.setNode(h.id + "-note", S), a.setNode(h.id, h)) : (a.setNode(h.id, h), a.setNode(h.id + "-note", S)), a.setParent(h.id, h.id + "-group"), a.setParent(h.id + "-note", h.id + "-group"); + } else + a.setNode(h.id, h); + } + b.debug("Count=", a.nodeCount(), a); + let m = 0; + c.forEach(function(n) { + m++, b.debug("Setting edge", n), a.setEdge( + n.id1, + n.id2, + { + relation: n, + width: rt(n.title), + height: B.labelHeight * T.getRows(n.title).length, + labelpos: "c" + }, + "id" + m + ); + }), J(a), b.debug("Graph after layout", a.nodes()); + const w = i.node(); + a.nodes().forEach(function(n) { + n !== void 0 && a.node(n) !== void 0 ? (b.warn("Node " + n + ": " + JSON.stringify(a.node(n))), s.select("#" + w.id + " #" + n).attr( + "transform", + "translate(" + (a.node(n).x - a.node(n).width / 2) + "," + (a.node(n).y + (z[n] ? z[n].y : 0) - a.node(n).height / 2) + " )" + ), s.select("#" + w.id + " #" + n).attr("data-x-shift", a.node(n).x - a.node(n).width / 2), g.querySelectorAll("#" + w.id + " #" + n + " .divider").forEach((h) => { + const f = h.parentElement; + let S = 0, M = 0; + f && (f.parentElement && (S = f.parentElement.getBBox().width), M = parseInt(f.getAttribute("data-x-shift"), 10), Number.isNaN(M) && (M = 0)), h.setAttribute("x1", 0 - M + 8), h.setAttribute("x2", S - M - 8); + })) : b.debug("No Node " + n + ": " + JSON.stringify(a.node(n))); + }); + let k = w.getBBox(); + a.edges().forEach(function(n) { + n !== void 0 && a.edge(n) !== void 0 && (b.debug("Edge " + n.v + " -> " + n.w + ": " + JSON.stringify(a.edge(n))), at(i, a.edge(n), a.edge(n).relation)); + }), k = w.getBBox(); + const E = { + id: o || "root", + label: o || "root", + width: 0, + height: 0 + }; + return E.width = k.width + 2 * B.padding, E.height = k.height + 2 * B.padding, b.debug("Doc rendered", E, a), E; +}, ot = { + setConf: it, + draw: st +}, ut = { + parser: C, + db: N, + renderer: ot, + styles: R, + init: (e) => { + e.state || (e.state = {}), e.state.arrowMarkerAbsolute = e.arrowMarkerAbsolute, N.clear(); + } +}; +export { + ut as diagram +}; diff --git a/0.6.0/js/mermaid/stateDiagram-v2-1992cada.js b/0.6.0/js/mermaid/stateDiagram-v2-1992cada.js new file mode 100644 index 0000000..d138490 --- /dev/null +++ b/0.6.0/js/mermaid/stateDiagram-v2-1992cada.js @@ -0,0 +1,333 @@ +import { D as DEFAULT_STATE_TYPE, a as DIVIDER_TYPE, S as STMT_RELATION, b as STMT_STATE, c as DEFAULT_NESTED_DOC_DIR, p as parser, d as db, s as styles } from "./styles-0784dbeb.js"; +import * as graphlib from "dagre-d3-es/src/graphlib/index.js"; +import { select } from "d3"; +import { l as log, c as getConfig, u as utils, i as configureSvgSize, e as common } from "./mermaid-6dc72991.js"; +import { r as render } from "./index-01f381cb.js"; +import "ts-dedent"; +import "dayjs"; +import "@braintree/sanitize-url"; +import "dompurify"; +import "khroma"; +import "lodash-es/memoize.js"; +import "lodash-es/merge.js"; +import "stylis"; +import "lodash-es/isEmpty.js"; +import "dagre-d3-es/src/dagre/index.js"; +import "dagre-d3-es/src/graphlib/json.js"; +import "./edges-066a5561.js"; +import "./createText-ca0c5216.js"; +import "mdast-util-from-markdown"; +const SHAPE_STATE = "rect"; +const SHAPE_STATE_WITH_DESC = "rectWithTitle"; +const SHAPE_START = "start"; +const SHAPE_END = "end"; +const SHAPE_DIVIDER = "divider"; +const SHAPE_GROUP = "roundedWithTitle"; +const SHAPE_NOTE = "note"; +const SHAPE_NOTEGROUP = "noteGroup"; +const CSS_DIAGRAM = "statediagram"; +const CSS_STATE = "state"; +const CSS_DIAGRAM_STATE = `${CSS_DIAGRAM}-${CSS_STATE}`; +const CSS_EDGE = "transition"; +const CSS_NOTE = "note"; +const CSS_NOTE_EDGE = "note-edge"; +const CSS_EDGE_NOTE_EDGE = `${CSS_EDGE} ${CSS_NOTE_EDGE}`; +const CSS_DIAGRAM_NOTE = `${CSS_DIAGRAM}-${CSS_NOTE}`; +const CSS_CLUSTER = "cluster"; +const CSS_DIAGRAM_CLUSTER = `${CSS_DIAGRAM}-${CSS_CLUSTER}`; +const CSS_CLUSTER_ALT = "cluster-alt"; +const CSS_DIAGRAM_CLUSTER_ALT = `${CSS_DIAGRAM}-${CSS_CLUSTER_ALT}`; +const PARENT = "parent"; +const NOTE = "note"; +const DOMID_STATE = "state"; +const DOMID_TYPE_SPACER = "----"; +const NOTE_ID = `${DOMID_TYPE_SPACER}${NOTE}`; +const PARENT_ID = `${DOMID_TYPE_SPACER}${PARENT}`; +const G_EDGE_STYLE = "fill:none"; +const G_EDGE_ARROWHEADSTYLE = "fill: #333"; +const G_EDGE_LABELPOS = "c"; +const G_EDGE_LABELTYPE = "text"; +const G_EDGE_THICKNESS = "normal"; +let nodeDb = {}; +let graphItemCount = 0; +const setConf = function(cnf) { + const keys = Object.keys(cnf); + for (const key of keys) { + cnf[key]; + } +}; +const getClasses = function(text, diagramObj) { + diagramObj.db.extract(diagramObj.db.getRootDocV2()); + return diagramObj.db.getClasses(); +}; +function getClassesFromDbInfo(dbInfoItem) { + if (dbInfoItem === void 0 || dbInfoItem === null) { + return ""; + } else { + if (dbInfoItem.classes) { + return dbInfoItem.classes.join(" "); + } else { + return ""; + } + } +} +function stateDomId(itemId = "", counter = 0, type = "", typeSpacer = DOMID_TYPE_SPACER) { + const typeStr = type !== null && type.length > 0 ? `${typeSpacer}${type}` : ""; + return `${DOMID_STATE}-${itemId}${typeStr}-${counter}`; +} +const setupNode = (g, parent, parsedItem, diagramStates, diagramDb, altFlag) => { + const itemId = parsedItem.id; + const classStr = getClassesFromDbInfo(diagramStates[itemId]); + if (itemId !== "root") { + let shape = SHAPE_STATE; + if (parsedItem.start === true) { + shape = SHAPE_START; + } + if (parsedItem.start === false) { + shape = SHAPE_END; + } + if (parsedItem.type !== DEFAULT_STATE_TYPE) { + shape = parsedItem.type; + } + if (!nodeDb[itemId]) { + nodeDb[itemId] = { + id: itemId, + shape, + description: common.sanitizeText(itemId, getConfig()), + classes: `${classStr} ${CSS_DIAGRAM_STATE}` + }; + } + const newNode = nodeDb[itemId]; + if (parsedItem.description) { + if (Array.isArray(newNode.description)) { + newNode.shape = SHAPE_STATE_WITH_DESC; + newNode.description.push(parsedItem.description); + } else { + if (newNode.description.length > 0) { + newNode.shape = SHAPE_STATE_WITH_DESC; + if (newNode.description === itemId) { + newNode.description = [parsedItem.description]; + } else { + newNode.description = [newNode.description, parsedItem.description]; + } + } else { + newNode.shape = SHAPE_STATE; + newNode.description = parsedItem.description; + } + } + newNode.description = common.sanitizeTextOrArray(newNode.description, getConfig()); + } + if (newNode.description.length === 1 && newNode.shape === SHAPE_STATE_WITH_DESC) { + newNode.shape = SHAPE_STATE; + } + if (!newNode.type && parsedItem.doc) { + log.info("Setting cluster for ", itemId, getDir(parsedItem)); + newNode.type = "group"; + newNode.dir = getDir(parsedItem); + newNode.shape = parsedItem.type === DIVIDER_TYPE ? SHAPE_DIVIDER : SHAPE_GROUP; + newNode.classes = newNode.classes + " " + CSS_DIAGRAM_CLUSTER + " " + (altFlag ? CSS_DIAGRAM_CLUSTER_ALT : ""); + } + const nodeData = { + labelStyle: "", + shape: newNode.shape, + labelText: newNode.description, + // typeof newNode.description === 'object' + // ? newNode.description[0] + // : newNode.description, + classes: newNode.classes, + style: "", + //styles.style, + id: itemId, + dir: newNode.dir, + domId: stateDomId(itemId, graphItemCount), + type: newNode.type, + padding: 15 + //getConfig().flowchart.padding + }; + nodeData.centerLabel = true; + if (parsedItem.note) { + const noteData = { + labelStyle: "", + shape: SHAPE_NOTE, + labelText: parsedItem.note.text, + classes: CSS_DIAGRAM_NOTE, + // useHtmlLabels: false, + style: "", + // styles.style, + id: itemId + NOTE_ID + "-" + graphItemCount, + domId: stateDomId(itemId, graphItemCount, NOTE), + type: newNode.type, + padding: 15 + //getConfig().flowchart.padding + }; + const groupData = { + labelStyle: "", + shape: SHAPE_NOTEGROUP, + labelText: parsedItem.note.text, + classes: newNode.classes, + style: "", + // styles.style, + id: itemId + PARENT_ID, + domId: stateDomId(itemId, graphItemCount, PARENT), + type: "group", + padding: 0 + //getConfig().flowchart.padding + }; + graphItemCount++; + const parentNodeId = itemId + PARENT_ID; + g.setNode(parentNodeId, groupData); + g.setNode(noteData.id, noteData); + g.setNode(itemId, nodeData); + g.setParent(itemId, parentNodeId); + g.setParent(noteData.id, parentNodeId); + let from = itemId; + let to = noteData.id; + if (parsedItem.note.position === "left of") { + from = noteData.id; + to = itemId; + } + g.setEdge(from, to, { + arrowhead: "none", + arrowType: "", + style: G_EDGE_STYLE, + labelStyle: "", + classes: CSS_EDGE_NOTE_EDGE, + arrowheadStyle: G_EDGE_ARROWHEADSTYLE, + labelpos: G_EDGE_LABELPOS, + labelType: G_EDGE_LABELTYPE, + thickness: G_EDGE_THICKNESS + }); + } else { + g.setNode(itemId, nodeData); + } + } + if (parent && parent.id !== "root") { + log.trace("Setting node ", itemId, " to be child of its parent ", parent.id); + g.setParent(itemId, parent.id); + } + if (parsedItem.doc) { + log.trace("Adding nodes children "); + setupDoc(g, parsedItem, parsedItem.doc, diagramStates, diagramDb, !altFlag); + } +}; +const setupDoc = (g, parentParsedItem, doc, diagramStates, diagramDb, altFlag) => { + log.trace("items", doc); + doc.forEach((item) => { + switch (item.stmt) { + case STMT_STATE: + setupNode(g, parentParsedItem, item, diagramStates, diagramDb, altFlag); + break; + case DEFAULT_STATE_TYPE: + setupNode(g, parentParsedItem, item, diagramStates, diagramDb, altFlag); + break; + case STMT_RELATION: + { + setupNode(g, parentParsedItem, item.state1, diagramStates, diagramDb, altFlag); + setupNode(g, parentParsedItem, item.state2, diagramStates, diagramDb, altFlag); + const edgeData = { + id: "edge" + graphItemCount, + arrowhead: "normal", + arrowTypeEnd: "arrow_barb", + style: G_EDGE_STYLE, + labelStyle: "", + label: common.sanitizeText(item.description, getConfig()), + arrowheadStyle: G_EDGE_ARROWHEADSTYLE, + labelpos: G_EDGE_LABELPOS, + labelType: G_EDGE_LABELTYPE, + thickness: G_EDGE_THICKNESS, + classes: CSS_EDGE + }; + g.setEdge(item.state1.id, item.state2.id, edgeData, graphItemCount); + graphItemCount++; + } + break; + } + }); +}; +const getDir = (parsedItem, defaultDir = DEFAULT_NESTED_DOC_DIR) => { + let dir = defaultDir; + if (parsedItem.doc) { + for (let i = 0; i < parsedItem.doc.length; i++) { + const parsedItemDoc = parsedItem.doc[i]; + if (parsedItemDoc.stmt === "dir") { + dir = parsedItemDoc.value; + } + } + } + return dir; +}; +const draw = async function(text, id, _version, diag) { + log.info("Drawing state diagram (v2)", id); + nodeDb = {}; + diag.db.getDirection(); + const { securityLevel, state: conf } = getConfig(); + const nodeSpacing = conf.nodeSpacing || 50; + const rankSpacing = conf.rankSpacing || 50; + log.info(diag.db.getRootDocV2()); + diag.db.extract(diag.db.getRootDocV2()); + log.info(diag.db.getRootDocV2()); + const diagramStates = diag.db.getStates(); + const g = new graphlib.Graph({ + multigraph: true, + compound: true + }).setGraph({ + rankdir: getDir(diag.db.getRootDocV2()), + nodesep: nodeSpacing, + ranksep: rankSpacing, + marginx: 8, + marginy: 8 + }).setDefaultEdgeLabel(function() { + return {}; + }); + setupNode(g, void 0, diag.db.getRootDocV2(), diagramStates, diag.db, true); + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = select("#i" + id); + } + const root = securityLevel === "sandbox" ? select(sandboxElement.nodes()[0].contentDocument.body) : select("body"); + const svg = root.select(`[id="${id}"]`); + const element = root.select("#" + id + " g"); + await render(element, g, ["barb"], CSS_DIAGRAM, id); + const padding = 8; + utils.insertTitle(svg, "statediagramTitleText", conf.titleTopMargin, diag.db.getDiagramTitle()); + const bounds = svg.node().getBBox(); + const width = bounds.width + padding * 2; + const height = bounds.height + padding * 2; + svg.attr("class", CSS_DIAGRAM); + const svgBounds = svg.node().getBBox(); + configureSvgSize(svg, height, width, conf.useMaxWidth); + const vBox = `${svgBounds.x - padding} ${svgBounds.y - padding} ${width} ${height}`; + log.debug(`viewBox ${vBox}`); + svg.attr("viewBox", vBox); + const labels = document.querySelectorAll('[id="' + id + '"] .edgeLabel .label'); + for (const label of labels) { + const dim = label.getBBox(); + const rect = document.createElementNS("http://www.w3.org/2000/svg", SHAPE_STATE); + rect.setAttribute("rx", 0); + rect.setAttribute("ry", 0); + rect.setAttribute("width", dim.width); + rect.setAttribute("height", dim.height); + label.insertBefore(rect, label.firstChild); + } +}; +const renderer = { + setConf, + getClasses, + draw +}; +const diagram = { + parser, + db, + renderer, + styles, + init: (cnf) => { + if (!cnf.state) { + cnf.state = {}; + } + cnf.state.arrowMarkerAbsolute = cnf.arrowMarkerAbsolute; + db.clear(); + } +}; +export { + diagram +}; diff --git a/0.6.0/js/mermaid/stateDiagram-v2-992e82a1.js b/0.6.0/js/mermaid/stateDiagram-v2-992e82a1.js new file mode 100644 index 0000000..c8cad46 --- /dev/null +++ b/0.6.0/js/mermaid/stateDiagram-v2-992e82a1.js @@ -0,0 +1,325 @@ +import { D as DEFAULT_STATE_TYPE, a as DIVIDER_TYPE, S as STMT_RELATION, b as STMT_STATE, c as DEFAULT_NESTED_DOC_DIR, p as parser, d as db, s as styles } from "./styles-f80da881.js"; +import { G as Graph } from "./graph-fe24fab6.js"; +import { l as log, c as getConfig, j as d3select, A as utils, k as configureSvgSize, f as common } from "./mermaid-dcacb631.js"; +import { r as render } from "./index-fc479858.js"; +import "./layout-163b9689.js"; +import "./clone-9ea6bfeb.js"; +import "./edges-ce5cfb7c.js"; +import "./createText-b70fe78a.js"; +import "./line-87f517ef.js"; +import "./array-b7dcf730.js"; +import "./path-39bad7e2.js"; +const SHAPE_STATE = "rect"; +const SHAPE_STATE_WITH_DESC = "rectWithTitle"; +const SHAPE_START = "start"; +const SHAPE_END = "end"; +const SHAPE_DIVIDER = "divider"; +const SHAPE_GROUP = "roundedWithTitle"; +const SHAPE_NOTE = "note"; +const SHAPE_NOTEGROUP = "noteGroup"; +const CSS_DIAGRAM = "statediagram"; +const CSS_STATE = "state"; +const CSS_DIAGRAM_STATE = `${CSS_DIAGRAM}-${CSS_STATE}`; +const CSS_EDGE = "transition"; +const CSS_NOTE = "note"; +const CSS_NOTE_EDGE = "note-edge"; +const CSS_EDGE_NOTE_EDGE = `${CSS_EDGE} ${CSS_NOTE_EDGE}`; +const CSS_DIAGRAM_NOTE = `${CSS_DIAGRAM}-${CSS_NOTE}`; +const CSS_CLUSTER = "cluster"; +const CSS_DIAGRAM_CLUSTER = `${CSS_DIAGRAM}-${CSS_CLUSTER}`; +const CSS_CLUSTER_ALT = "cluster-alt"; +const CSS_DIAGRAM_CLUSTER_ALT = `${CSS_DIAGRAM}-${CSS_CLUSTER_ALT}`; +const PARENT = "parent"; +const NOTE = "note"; +const DOMID_STATE = "state"; +const DOMID_TYPE_SPACER = "----"; +const NOTE_ID = `${DOMID_TYPE_SPACER}${NOTE}`; +const PARENT_ID = `${DOMID_TYPE_SPACER}${PARENT}`; +const G_EDGE_STYLE = "fill:none"; +const G_EDGE_ARROWHEADSTYLE = "fill: #333"; +const G_EDGE_LABELPOS = "c"; +const G_EDGE_LABELTYPE = "text"; +const G_EDGE_THICKNESS = "normal"; +let nodeDb = {}; +let graphItemCount = 0; +const setConf = function(cnf) { + const keys = Object.keys(cnf); + for (const key of keys) { + cnf[key]; + } +}; +const getClasses = function(text, diagramObj) { + diagramObj.db.extract(diagramObj.db.getRootDocV2()); + return diagramObj.db.getClasses(); +}; +function getClassesFromDbInfo(dbInfoItem) { + if (dbInfoItem === void 0 || dbInfoItem === null) { + return ""; + } else { + if (dbInfoItem.classes) { + return dbInfoItem.classes.join(" "); + } else { + return ""; + } + } +} +function stateDomId(itemId = "", counter = 0, type = "", typeSpacer = DOMID_TYPE_SPACER) { + const typeStr = type !== null && type.length > 0 ? `${typeSpacer}${type}` : ""; + return `${DOMID_STATE}-${itemId}${typeStr}-${counter}`; +} +const setupNode = (g, parent, parsedItem, diagramStates, diagramDb, altFlag) => { + const itemId = parsedItem.id; + const classStr = getClassesFromDbInfo(diagramStates[itemId]); + if (itemId !== "root") { + let shape = SHAPE_STATE; + if (parsedItem.start === true) { + shape = SHAPE_START; + } + if (parsedItem.start === false) { + shape = SHAPE_END; + } + if (parsedItem.type !== DEFAULT_STATE_TYPE) { + shape = parsedItem.type; + } + if (!nodeDb[itemId]) { + nodeDb[itemId] = { + id: itemId, + shape, + description: common.sanitizeText(itemId, getConfig()), + classes: `${classStr} ${CSS_DIAGRAM_STATE}` + }; + } + const newNode = nodeDb[itemId]; + if (parsedItem.description) { + if (Array.isArray(newNode.description)) { + newNode.shape = SHAPE_STATE_WITH_DESC; + newNode.description.push(parsedItem.description); + } else { + if (newNode.description.length > 0) { + newNode.shape = SHAPE_STATE_WITH_DESC; + if (newNode.description === itemId) { + newNode.description = [parsedItem.description]; + } else { + newNode.description = [newNode.description, parsedItem.description]; + } + } else { + newNode.shape = SHAPE_STATE; + newNode.description = parsedItem.description; + } + } + newNode.description = common.sanitizeTextOrArray(newNode.description, getConfig()); + } + if (newNode.description.length === 1 && newNode.shape === SHAPE_STATE_WITH_DESC) { + newNode.shape = SHAPE_STATE; + } + if (!newNode.type && parsedItem.doc) { + log.info("Setting cluster for ", itemId, getDir(parsedItem)); + newNode.type = "group"; + newNode.dir = getDir(parsedItem); + newNode.shape = parsedItem.type === DIVIDER_TYPE ? SHAPE_DIVIDER : SHAPE_GROUP; + newNode.classes = newNode.classes + " " + CSS_DIAGRAM_CLUSTER + " " + (altFlag ? CSS_DIAGRAM_CLUSTER_ALT : ""); + } + const nodeData = { + labelStyle: "", + shape: newNode.shape, + labelText: newNode.description, + // typeof newNode.description === 'object' + // ? newNode.description[0] + // : newNode.description, + classes: newNode.classes, + style: "", + //styles.style, + id: itemId, + dir: newNode.dir, + domId: stateDomId(itemId, graphItemCount), + type: newNode.type, + padding: 15 + //getConfig().flowchart.padding + }; + nodeData.centerLabel = true; + if (parsedItem.note) { + const noteData = { + labelStyle: "", + shape: SHAPE_NOTE, + labelText: parsedItem.note.text, + classes: CSS_DIAGRAM_NOTE, + // useHtmlLabels: false, + style: "", + // styles.style, + id: itemId + NOTE_ID + "-" + graphItemCount, + domId: stateDomId(itemId, graphItemCount, NOTE), + type: newNode.type, + padding: 15 + //getConfig().flowchart.padding + }; + const groupData = { + labelStyle: "", + shape: SHAPE_NOTEGROUP, + labelText: parsedItem.note.text, + classes: newNode.classes, + style: "", + // styles.style, + id: itemId + PARENT_ID, + domId: stateDomId(itemId, graphItemCount, PARENT), + type: "group", + padding: 0 + //getConfig().flowchart.padding + }; + graphItemCount++; + const parentNodeId = itemId + PARENT_ID; + g.setNode(parentNodeId, groupData); + g.setNode(noteData.id, noteData); + g.setNode(itemId, nodeData); + g.setParent(itemId, parentNodeId); + g.setParent(noteData.id, parentNodeId); + let from = itemId; + let to = noteData.id; + if (parsedItem.note.position === "left of") { + from = noteData.id; + to = itemId; + } + g.setEdge(from, to, { + arrowhead: "none", + arrowType: "", + style: G_EDGE_STYLE, + labelStyle: "", + classes: CSS_EDGE_NOTE_EDGE, + arrowheadStyle: G_EDGE_ARROWHEADSTYLE, + labelpos: G_EDGE_LABELPOS, + labelType: G_EDGE_LABELTYPE, + thickness: G_EDGE_THICKNESS + }); + } else { + g.setNode(itemId, nodeData); + } + } + if (parent && parent.id !== "root") { + log.trace("Setting node ", itemId, " to be child of its parent ", parent.id); + g.setParent(itemId, parent.id); + } + if (parsedItem.doc) { + log.trace("Adding nodes children "); + setupDoc(g, parsedItem, parsedItem.doc, diagramStates, diagramDb, !altFlag); + } +}; +const setupDoc = (g, parentParsedItem, doc, diagramStates, diagramDb, altFlag) => { + log.trace("items", doc); + doc.forEach((item) => { + switch (item.stmt) { + case STMT_STATE: + setupNode(g, parentParsedItem, item, diagramStates, diagramDb, altFlag); + break; + case DEFAULT_STATE_TYPE: + setupNode(g, parentParsedItem, item, diagramStates, diagramDb, altFlag); + break; + case STMT_RELATION: + { + setupNode(g, parentParsedItem, item.state1, diagramStates, diagramDb, altFlag); + setupNode(g, parentParsedItem, item.state2, diagramStates, diagramDb, altFlag); + const edgeData = { + id: "edge" + graphItemCount, + arrowhead: "normal", + arrowTypeEnd: "arrow_barb", + style: G_EDGE_STYLE, + labelStyle: "", + label: common.sanitizeText(item.description, getConfig()), + arrowheadStyle: G_EDGE_ARROWHEADSTYLE, + labelpos: G_EDGE_LABELPOS, + labelType: G_EDGE_LABELTYPE, + thickness: G_EDGE_THICKNESS, + classes: CSS_EDGE + }; + g.setEdge(item.state1.id, item.state2.id, edgeData, graphItemCount); + graphItemCount++; + } + break; + } + }); +}; +const getDir = (parsedItem, defaultDir = DEFAULT_NESTED_DOC_DIR) => { + let dir = defaultDir; + if (parsedItem.doc) { + for (let i = 0; i < parsedItem.doc.length; i++) { + const parsedItemDoc = parsedItem.doc[i]; + if (parsedItemDoc.stmt === "dir") { + dir = parsedItemDoc.value; + } + } + } + return dir; +}; +const draw = async function(text, id, _version, diag) { + log.info("Drawing state diagram (v2)", id); + nodeDb = {}; + diag.db.getDirection(); + const { securityLevel, state: conf } = getConfig(); + const nodeSpacing = conf.nodeSpacing || 50; + const rankSpacing = conf.rankSpacing || 50; + log.info(diag.db.getRootDocV2()); + diag.db.extract(diag.db.getRootDocV2()); + log.info(diag.db.getRootDocV2()); + const diagramStates = diag.db.getStates(); + const g = new Graph({ + multigraph: true, + compound: true + }).setGraph({ + rankdir: getDir(diag.db.getRootDocV2()), + nodesep: nodeSpacing, + ranksep: rankSpacing, + marginx: 8, + marginy: 8 + }).setDefaultEdgeLabel(function() { + return {}; + }); + setupNode(g, void 0, diag.db.getRootDocV2(), diagramStates, diag.db, true); + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = d3select("#i" + id); + } + const root = securityLevel === "sandbox" ? d3select(sandboxElement.nodes()[0].contentDocument.body) : d3select("body"); + const svg = root.select(`[id="${id}"]`); + const element = root.select("#" + id + " g"); + await render(element, g, ["barb"], CSS_DIAGRAM, id); + const padding = 8; + utils.insertTitle(svg, "statediagramTitleText", conf.titleTopMargin, diag.db.getDiagramTitle()); + const bounds = svg.node().getBBox(); + const width = bounds.width + padding * 2; + const height = bounds.height + padding * 2; + svg.attr("class", CSS_DIAGRAM); + const svgBounds = svg.node().getBBox(); + configureSvgSize(svg, height, width, conf.useMaxWidth); + const vBox = `${svgBounds.x - padding} ${svgBounds.y - padding} ${width} ${height}`; + log.debug(`viewBox ${vBox}`); + svg.attr("viewBox", vBox); + const labels = document.querySelectorAll('[id="' + id + '"] .edgeLabel .label'); + for (const label of labels) { + const dim = label.getBBox(); + const rect = document.createElementNS("http://www.w3.org/2000/svg", SHAPE_STATE); + rect.setAttribute("rx", 0); + rect.setAttribute("ry", 0); + rect.setAttribute("width", dim.width); + rect.setAttribute("height", dim.height); + label.insertBefore(rect, label.firstChild); + } +}; +const renderer = { + setConf, + getClasses, + draw +}; +const diagram = { + parser, + db, + renderer, + styles, + init: (cnf) => { + if (!cnf.state) { + cnf.state = {}; + } + cnf.state.arrowMarkerAbsolute = cnf.arrowMarkerAbsolute; + db.clear(); + } +}; +export { + diagram +}; diff --git a/0.6.0/js/mermaid/stateDiagram-v2-ed04200a.js b/0.6.0/js/mermaid/stateDiagram-v2-ed04200a.js new file mode 100644 index 0000000..09cf27b --- /dev/null +++ b/0.6.0/js/mermaid/stateDiagram-v2-ed04200a.js @@ -0,0 +1,190 @@ +import { D as H, a as J, S as Q, b as X, c as Z, p as F, d as M, s as I } from "./styles-cacbff60.js"; +import { G as tt } from "./graph-0ee63739.js"; +import { l as E, c as g, j as $, A as et, k as ot, f as w } from "./mermaid-9f2aa176.js"; +import { r as st } from "./index-bb6d8841.js"; +import "./layout-fd473db2.js"; +import "./clone-afc2f047.js"; +import "./edges-16357fde.js"; +import "./createText-03b82060.js"; +import "./line-24d93f1b.js"; +import "./array-2ff2c7a6.js"; +import "./path-428ebac9.js"; +const h = "rect", C = "rectWithTitle", nt = "start", ct = "end", it = "divider", rt = "roundedWithTitle", lt = "note", at = "noteGroup", _ = "statediagram", dt = "state", Et = `${_}-${dt}`, U = "transition", St = "note", Tt = "note-edge", pt = `${U} ${Tt}`, _t = `${_}-${St}`, ut = "cluster", ft = `${_}-${ut}`, Dt = "cluster-alt", bt = `${_}-${Dt}`, V = "parent", Y = "note", At = "state", N = "----", ht = `${N}${Y}`, v = `${N}${V}`, W = "fill:none", m = "fill: #333", z = "c", j = "text", q = "normal"; +let y = {}, d = 0; +const yt = function(t) { + const n = Object.keys(t); + for (const e of n) + t[e]; +}, gt = function(t, n) { + return n.db.extract(n.db.getRootDocV2()), n.db.getClasses(); +}; +function xt(t) { + return t == null ? "" : t.classes ? t.classes.join(" ") : ""; +} +function R(t = "", n = 0, e = "", c = N) { + const i = e !== null && e.length > 0 ? `${c}${e}` : ""; + return `${At}-${t}${i}-${n}`; +} +const A = (t, n, e, c, i, r) => { + const o = e.id, u = xt(c[o]); + if (o !== "root") { + let T = h; + e.start === !0 && (T = nt), e.start === !1 && (T = ct), e.type !== H && (T = e.type), y[o] || (y[o] = { + id: o, + shape: T, + description: w.sanitizeText(o, g()), + classes: `${u} ${Et}` + }); + const s = y[o]; + e.description && (Array.isArray(s.description) ? (s.shape = C, s.description.push(e.description)) : s.description.length > 0 ? (s.shape = C, s.description === o ? s.description = [e.description] : s.description = [s.description, e.description]) : (s.shape = h, s.description = e.description), s.description = w.sanitizeTextOrArray(s.description, g())), s.description.length === 1 && s.shape === C && (s.shape = h), !s.type && e.doc && (E.info("Setting cluster for ", o, G(e)), s.type = "group", s.dir = G(e), s.shape = e.type === J ? it : rt, s.classes = s.classes + " " + ft + " " + (r ? bt : "")); + const p = { + labelStyle: "", + shape: s.shape, + labelText: s.description, + // typeof newNode.description === 'object' + // ? newNode.description[0] + // : newNode.description, + classes: s.classes, + style: "", + //styles.style, + id: o, + dir: s.dir, + domId: R(o, d), + type: s.type, + padding: 15 + //getConfig().flowchart.padding + }; + if (p.centerLabel = !0, e.note) { + const l = { + labelStyle: "", + shape: lt, + labelText: e.note.text, + classes: _t, + // useHtmlLabels: false, + style: "", + // styles.style, + id: o + ht + "-" + d, + domId: R(o, d, Y), + type: s.type, + padding: 15 + //getConfig().flowchart.padding + }, a = { + labelStyle: "", + shape: at, + labelText: e.note.text, + classes: s.classes, + style: "", + // styles.style, + id: o + v, + domId: R(o, d, V), + type: "group", + padding: 0 + //getConfig().flowchart.padding + }; + d++; + const f = o + v; + t.setNode(f, a), t.setNode(l.id, l), t.setNode(o, p), t.setParent(o, f), t.setParent(l.id, f); + let S = o, D = l.id; + e.note.position === "left of" && (S = l.id, D = o), t.setEdge(S, D, { + arrowhead: "none", + arrowType: "", + style: W, + labelStyle: "", + classes: pt, + arrowheadStyle: m, + labelpos: z, + labelType: j, + thickness: q + }); + } else + t.setNode(o, p); + } + n && n.id !== "root" && (E.trace("Setting node ", o, " to be child of its parent ", n.id), t.setParent(o, n.id)), e.doc && (E.trace("Adding nodes children "), $t(t, e, e.doc, c, i, !r)); +}, $t = (t, n, e, c, i, r) => { + E.trace("items", e), e.forEach((o) => { + switch (o.stmt) { + case X: + A(t, n, o, c, i, r); + break; + case H: + A(t, n, o, c, i, r); + break; + case Q: + { + A(t, n, o.state1, c, i, r), A(t, n, o.state2, c, i, r); + const u = { + id: "edge" + d, + arrowhead: "normal", + arrowTypeEnd: "arrow_barb", + style: W, + labelStyle: "", + label: w.sanitizeText(o.description, g()), + arrowheadStyle: m, + labelpos: z, + labelType: j, + thickness: q, + classes: U + }; + t.setEdge(o.state1.id, o.state2.id, u, d), d++; + } + break; + } + }); +}, G = (t, n = Z) => { + let e = n; + if (t.doc) + for (let c = 0; c < t.doc.length; c++) { + const i = t.doc[c]; + i.stmt === "dir" && (e = i.value); + } + return e; +}, Ct = async function(t, n, e, c) { + E.info("Drawing state diagram (v2)", n), y = {}, c.db.getDirection(); + const { securityLevel: i, state: r } = g(), o = r.nodeSpacing || 50, u = r.rankSpacing || 50; + E.info(c.db.getRootDocV2()), c.db.extract(c.db.getRootDocV2()), E.info(c.db.getRootDocV2()); + const T = c.db.getStates(), s = new tt({ + multigraph: !0, + compound: !0 + }).setGraph({ + rankdir: G(c.db.getRootDocV2()), + nodesep: o, + ranksep: u, + marginx: 8, + marginy: 8 + }).setDefaultEdgeLabel(function() { + return {}; + }); + A(s, void 0, c.db.getRootDocV2(), T, c.db, !0); + let p; + i === "sandbox" && (p = $("#i" + n)); + const l = i === "sandbox" ? $(p.nodes()[0].contentDocument.body) : $("body"), a = l.select(`[id="${n}"]`), f = l.select("#" + n + " g"); + await st(f, s, ["barb"], _, n); + const S = 8; + et.insertTitle(a, "statediagramTitleText", r.titleTopMargin, c.db.getDiagramTitle()); + const D = a.node().getBBox(), L = D.width + S * 2, P = D.height + S * 2; + a.attr("class", _); + const O = a.node().getBBox(); + ot(a, P, L, r.useMaxWidth); + const k = `${O.x - S} ${O.y - S} ${L} ${P}`; + E.debug(`viewBox ${k}`), a.attr("viewBox", k); + const K = document.querySelectorAll('[id="' + n + '"] .edgeLabel .label'); + for (const x of K) { + const B = x.getBBox(), b = document.createElementNS("http://www.w3.org/2000/svg", h); + b.setAttribute("rx", 0), b.setAttribute("ry", 0), b.setAttribute("width", B.width), b.setAttribute("height", B.height), x.insertBefore(b, x.firstChild); + } +}, Rt = { + setConf: yt, + getClasses: gt, + draw: Ct +}, Ut = { + parser: F, + db: M, + renderer: Rt, + styles: I, + init: (t) => { + t.state || (t.state = {}), t.state.arrowMarkerAbsolute = t.arrowMarkerAbsolute, M.clear(); + } +}; +export { + Ut as diagram +}; diff --git a/0.6.0/js/mermaid/styles-0784dbeb.js b/0.6.0/js/mermaid/styles-0784dbeb.js new file mode 100644 index 0000000..34065a7 --- /dev/null +++ b/0.6.0/js/mermaid/styles-0784dbeb.js @@ -0,0 +1,1363 @@ +import { c as getConfig, g as getAccTitle, s as setAccTitle, a as getAccDescription, b as setAccDescription, q as setDiagramTitle, t as getDiagramTitle, l as log, e as common, v as clear$1, I as generateId } from "./mermaid-6dc72991.js"; +var parser = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 2], $V1 = [1, 3], $V2 = [1, 4], $V3 = [2, 4], $V4 = [1, 9], $V5 = [1, 11], $V6 = [1, 15], $V7 = [1, 16], $V8 = [1, 17], $V9 = [1, 18], $Va = [1, 30], $Vb = [1, 19], $Vc = [1, 20], $Vd = [1, 21], $Ve = [1, 22], $Vf = [1, 23], $Vg = [1, 25], $Vh = [1, 26], $Vi = [1, 27], $Vj = [1, 28], $Vk = [1, 29], $Vl = [1, 32], $Vm = [1, 33], $Vn = [1, 34], $Vo = [1, 35], $Vp = [1, 31], $Vq = [1, 4, 5, 15, 16, 18, 20, 21, 23, 24, 25, 26, 27, 28, 32, 34, 36, 37, 41, 44, 45, 46, 47, 50], $Vr = [1, 4, 5, 13, 14, 15, 16, 18, 20, 21, 23, 24, 25, 26, 27, 28, 32, 34, 36, 37, 41, 44, 45, 46, 47, 50], $Vs = [4, 5, 15, 16, 18, 20, 21, 23, 24, 25, 26, 27, 28, 32, 34, 36, 37, 41, 44, 45, 46, 47, 50]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "SPACE": 4, "NL": 5, "SD": 6, "document": 7, "line": 8, "statement": 9, "classDefStatement": 10, "cssClassStatement": 11, "idStatement": 12, "DESCR": 13, "-->": 14, "HIDE_EMPTY": 15, "scale": 16, "WIDTH": 17, "COMPOSIT_STATE": 18, "STRUCT_START": 19, "STRUCT_STOP": 20, "STATE_DESCR": 21, "AS": 22, "ID": 23, "FORK": 24, "JOIN": 25, "CHOICE": 26, "CONCURRENT": 27, "note": 28, "notePosition": 29, "NOTE_TEXT": 30, "direction": 31, "acc_title": 32, "acc_title_value": 33, "acc_descr": 34, "acc_descr_value": 35, "acc_descr_multiline_value": 36, "classDef": 37, "CLASSDEF_ID": 38, "CLASSDEF_STYLEOPTS": 39, "DEFAULT": 40, "class": 41, "CLASSENTITY_IDS": 42, "STYLECLASS": 43, "direction_tb": 44, "direction_bt": 45, "direction_rl": 46, "direction_lr": 47, "eol": 48, ";": 49, "EDGE_STATE": 50, "STYLE_SEPARATOR": 51, "left_of": 52, "right_of": 53, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 4: "SPACE", 5: "NL", 6: "SD", 13: "DESCR", 14: "-->", 15: "HIDE_EMPTY", 16: "scale", 17: "WIDTH", 18: "COMPOSIT_STATE", 19: "STRUCT_START", 20: "STRUCT_STOP", 21: "STATE_DESCR", 22: "AS", 23: "ID", 24: "FORK", 25: "JOIN", 26: "CHOICE", 27: "CONCURRENT", 28: "note", 30: "NOTE_TEXT", 32: "acc_title", 33: "acc_title_value", 34: "acc_descr", 35: "acc_descr_value", 36: "acc_descr_multiline_value", 37: "classDef", 38: "CLASSDEF_ID", 39: "CLASSDEF_STYLEOPTS", 40: "DEFAULT", 41: "class", 42: "CLASSENTITY_IDS", 43: "STYLECLASS", 44: "direction_tb", 45: "direction_bt", 46: "direction_rl", 47: "direction_lr", 49: ";", 50: "EDGE_STATE", 51: "STYLE_SEPARATOR", 52: "left_of", 53: "right_of" }, + productions_: [0, [3, 2], [3, 2], [3, 2], [7, 0], [7, 2], [8, 2], [8, 1], [8, 1], [9, 1], [9, 1], [9, 1], [9, 2], [9, 3], [9, 4], [9, 1], [9, 2], [9, 1], [9, 4], [9, 3], [9, 6], [9, 1], [9, 1], [9, 1], [9, 1], [9, 4], [9, 4], [9, 1], [9, 2], [9, 2], [9, 1], [10, 3], [10, 3], [11, 3], [31, 1], [31, 1], [31, 1], [31, 1], [48, 1], [48, 1], [12, 1], [12, 1], [12, 3], [12, 3], [29, 1], [29, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 3: + yy.setRootDoc($$[$0]); + return $$[$0]; + case 4: + this.$ = []; + break; + case 5: + if ($$[$0] != "nl") { + $$[$0 - 1].push($$[$0]); + this.$ = $$[$0 - 1]; + } + break; + case 6: + case 7: + this.$ = $$[$0]; + break; + case 8: + this.$ = "nl"; + break; + case 11: + this.$ = $$[$0]; + break; + case 12: + const stateStmt = $$[$0 - 1]; + stateStmt.description = yy.trimColon($$[$0]); + this.$ = stateStmt; + break; + case 13: + this.$ = { stmt: "relation", state1: $$[$0 - 2], state2: $$[$0] }; + break; + case 14: + const relDescription = yy.trimColon($$[$0]); + this.$ = { stmt: "relation", state1: $$[$0 - 3], state2: $$[$0 - 1], description: relDescription }; + break; + case 18: + this.$ = { stmt: "state", id: $$[$0 - 3], type: "default", description: "", doc: $$[$0 - 1] }; + break; + case 19: + var id = $$[$0]; + var description = $$[$0 - 2].trim(); + if ($$[$0].match(":")) { + var parts = $$[$0].split(":"); + id = parts[0]; + description = [description, parts[1]]; + } + this.$ = { stmt: "state", id, type: "default", description }; + break; + case 20: + this.$ = { stmt: "state", id: $$[$0 - 3], type: "default", description: $$[$0 - 5], doc: $$[$0 - 1] }; + break; + case 21: + this.$ = { stmt: "state", id: $$[$0], type: "fork" }; + break; + case 22: + this.$ = { stmt: "state", id: $$[$0], type: "join" }; + break; + case 23: + this.$ = { stmt: "state", id: $$[$0], type: "choice" }; + break; + case 24: + this.$ = { stmt: "state", id: yy.getDividerId(), type: "divider" }; + break; + case 25: + this.$ = { stmt: "state", id: $$[$0 - 1].trim(), note: { position: $$[$0 - 2].trim(), text: $$[$0].trim() } }; + break; + case 28: + this.$ = $$[$0].trim(); + yy.setAccTitle(this.$); + break; + case 29: + case 30: + this.$ = $$[$0].trim(); + yy.setAccDescription(this.$); + break; + case 31: + case 32: + this.$ = { stmt: "classDef", id: $$[$0 - 1].trim(), classes: $$[$0].trim() }; + break; + case 33: + this.$ = { stmt: "applyClass", id: $$[$0 - 1].trim(), styleClass: $$[$0].trim() }; + break; + case 34: + yy.setDirection("TB"); + this.$ = { stmt: "dir", value: "TB" }; + break; + case 35: + yy.setDirection("BT"); + this.$ = { stmt: "dir", value: "BT" }; + break; + case 36: + yy.setDirection("RL"); + this.$ = { stmt: "dir", value: "RL" }; + break; + case 37: + yy.setDirection("LR"); + this.$ = { stmt: "dir", value: "LR" }; + break; + case 40: + case 41: + this.$ = { stmt: "state", id: $$[$0].trim(), type: "default", description: "" }; + break; + case 42: + this.$ = { stmt: "state", id: $$[$0 - 2].trim(), classes: [$$[$0].trim()], type: "default", description: "" }; + break; + case 43: + this.$ = { stmt: "state", id: $$[$0 - 2].trim(), classes: [$$[$0].trim()], type: "default", description: "" }; + break; + } + }, + table: [{ 3: 1, 4: $V0, 5: $V1, 6: $V2 }, { 1: [3] }, { 3: 5, 4: $V0, 5: $V1, 6: $V2 }, { 3: 6, 4: $V0, 5: $V1, 6: $V2 }, o([1, 4, 5, 15, 16, 18, 21, 23, 24, 25, 26, 27, 28, 32, 34, 36, 37, 41, 44, 45, 46, 47, 50], $V3, { 7: 7 }), { 1: [2, 1] }, { 1: [2, 2] }, { 1: [2, 3], 4: $V4, 5: $V5, 8: 8, 9: 10, 10: 12, 11: 13, 12: 14, 15: $V6, 16: $V7, 18: $V8, 21: $V9, 23: $Va, 24: $Vb, 25: $Vc, 26: $Vd, 27: $Ve, 28: $Vf, 31: 24, 32: $Vg, 34: $Vh, 36: $Vi, 37: $Vj, 41: $Vk, 44: $Vl, 45: $Vm, 46: $Vn, 47: $Vo, 50: $Vp }, o($Vq, [2, 5]), { 9: 36, 10: 12, 11: 13, 12: 14, 15: $V6, 16: $V7, 18: $V8, 21: $V9, 23: $Va, 24: $Vb, 25: $Vc, 26: $Vd, 27: $Ve, 28: $Vf, 31: 24, 32: $Vg, 34: $Vh, 36: $Vi, 37: $Vj, 41: $Vk, 44: $Vl, 45: $Vm, 46: $Vn, 47: $Vo, 50: $Vp }, o($Vq, [2, 7]), o($Vq, [2, 8]), o($Vq, [2, 9]), o($Vq, [2, 10]), o($Vq, [2, 11], { 13: [1, 37], 14: [1, 38] }), o($Vq, [2, 15]), { 17: [1, 39] }, o($Vq, [2, 17], { 19: [1, 40] }), { 22: [1, 41] }, o($Vq, [2, 21]), o($Vq, [2, 22]), o($Vq, [2, 23]), o($Vq, [2, 24]), { 29: 42, 30: [1, 43], 52: [1, 44], 53: [1, 45] }, o($Vq, [2, 27]), { 33: [1, 46] }, { 35: [1, 47] }, o($Vq, [2, 30]), { 38: [1, 48], 40: [1, 49] }, { 42: [1, 50] }, o($Vr, [2, 40], { 51: [1, 51] }), o($Vr, [2, 41], { 51: [1, 52] }), o($Vq, [2, 34]), o($Vq, [2, 35]), o($Vq, [2, 36]), o($Vq, [2, 37]), o($Vq, [2, 6]), o($Vq, [2, 12]), { 12: 53, 23: $Va, 50: $Vp }, o($Vq, [2, 16]), o($Vs, $V3, { 7: 54 }), { 23: [1, 55] }, { 23: [1, 56] }, { 22: [1, 57] }, { 23: [2, 44] }, { 23: [2, 45] }, o($Vq, [2, 28]), o($Vq, [2, 29]), { 39: [1, 58] }, { 39: [1, 59] }, { 43: [1, 60] }, { 23: [1, 61] }, { 23: [1, 62] }, o($Vq, [2, 13], { 13: [1, 63] }), { 4: $V4, 5: $V5, 8: 8, 9: 10, 10: 12, 11: 13, 12: 14, 15: $V6, 16: $V7, 18: $V8, 20: [1, 64], 21: $V9, 23: $Va, 24: $Vb, 25: $Vc, 26: $Vd, 27: $Ve, 28: $Vf, 31: 24, 32: $Vg, 34: $Vh, 36: $Vi, 37: $Vj, 41: $Vk, 44: $Vl, 45: $Vm, 46: $Vn, 47: $Vo, 50: $Vp }, o($Vq, [2, 19], { 19: [1, 65] }), { 30: [1, 66] }, { 23: [1, 67] }, o($Vq, [2, 31]), o($Vq, [2, 32]), o($Vq, [2, 33]), o($Vr, [2, 42]), o($Vr, [2, 43]), o($Vq, [2, 14]), o($Vq, [2, 18]), o($Vs, $V3, { 7: 68 }), o($Vq, [2, 25]), o($Vq, [2, 26]), { 4: $V4, 5: $V5, 8: 8, 9: 10, 10: 12, 11: 13, 12: 14, 15: $V6, 16: $V7, 18: $V8, 20: [1, 69], 21: $V9, 23: $Va, 24: $Vb, 25: $Vc, 26: $Vd, 27: $Ve, 28: $Vf, 31: 24, 32: $Vg, 34: $Vh, 36: $Vi, 37: $Vj, 41: $Vk, 44: $Vl, 45: $Vm, 46: $Vn, 47: $Vo, 50: $Vp }, o($Vq, [2, 20])], + defaultActions: { 5: [2, 1], 6: [2, 2], 44: [2, 44], 45: [2, 45] }, + parseError: function parseError(str, hash) { + if (hash.recoverable) { + this.trace(str); + } else { + var error = new Error(str); + error.hash = hash; + throw error; + } + }, + parse: function parse(input) { + var self = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex() { + var token; + token = tstack.pop() || lexer2.lex() || EOF; + if (typeof token !== "number") { + if (token instanceof Array) { + tstack = token; + token = tstack.pop(); + } + token = self.symbols_[token] || token; + } + return token; + } + var symbol, state, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state = stack[stack.length - 1]; + if (this.defaultActions[state]) { + action = this.defaultActions[state]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex(); + } + action = table[state] && table[state][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str, hash); + } else { + throw new Error(str); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch = this._input[0]; + this.yytext += ch; + this.yyleng++; + this.offset++; + this.match += ch; + this.matched += ch; + var lines = ch.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch; + }, + // unshifts one char (or a string) into the input + unput: function(ch) { + var len = ch.length; + var lines = ch.split(/(?:\r\n?|\n)/g); + this._input = ch + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next = this.match; + if (next.length < 20) { + next += this._input.substr(0, 20 - next.length); + } + return (next.substr(0, 20) + (next.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token) { + return token; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token, match, tempMatch, index; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i = 0; i < rules.length; i++) { + tempMatch = this._input.match(this.rules[rules[i]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index = i; + if (this.options.backtrack_lexer) { + token = this.test_match(tempMatch, rules[i]); + if (token !== false) { + return token; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token = this.test_match(match, rules[index]); + if (token !== false) { + return token; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + return 40; + case 1: + return 44; + case 2: + return 45; + case 3: + return 46; + case 4: + return 47; + case 5: + break; + case 6: + break; + case 7: + return 5; + case 8: + break; + case 9: + break; + case 10: + break; + case 11: + break; + case 12: + this.pushState("SCALE"); + return 16; + case 13: + return 17; + case 14: + this.popState(); + break; + case 15: + this.begin("acc_title"); + return 32; + case 16: + this.popState(); + return "acc_title_value"; + case 17: + this.begin("acc_descr"); + return 34; + case 18: + this.popState(); + return "acc_descr_value"; + case 19: + this.begin("acc_descr_multiline"); + break; + case 20: + this.popState(); + break; + case 21: + return "acc_descr_multiline_value"; + case 22: + this.pushState("CLASSDEF"); + return 37; + case 23: + this.popState(); + this.pushState("CLASSDEFID"); + return "DEFAULT_CLASSDEF_ID"; + case 24: + this.popState(); + this.pushState("CLASSDEFID"); + return 38; + case 25: + this.popState(); + return 39; + case 26: + this.pushState("CLASS"); + return 41; + case 27: + this.popState(); + this.pushState("CLASS_STYLE"); + return 42; + case 28: + this.popState(); + return 43; + case 29: + this.pushState("SCALE"); + return 16; + case 30: + return 17; + case 31: + this.popState(); + break; + case 32: + this.pushState("STATE"); + break; + case 33: + this.popState(); + yy_.yytext = yy_.yytext.slice(0, -8).trim(); + return 24; + case 34: + this.popState(); + yy_.yytext = yy_.yytext.slice(0, -8).trim(); + return 25; + case 35: + this.popState(); + yy_.yytext = yy_.yytext.slice(0, -10).trim(); + return 26; + case 36: + this.popState(); + yy_.yytext = yy_.yytext.slice(0, -8).trim(); + return 24; + case 37: + this.popState(); + yy_.yytext = yy_.yytext.slice(0, -8).trim(); + return 25; + case 38: + this.popState(); + yy_.yytext = yy_.yytext.slice(0, -10).trim(); + return 26; + case 39: + return 44; + case 40: + return 45; + case 41: + return 46; + case 42: + return 47; + case 43: + this.pushState("STATE_STRING"); + break; + case 44: + this.pushState("STATE_ID"); + return "AS"; + case 45: + this.popState(); + return "ID"; + case 46: + this.popState(); + break; + case 47: + return "STATE_DESCR"; + case 48: + return 18; + case 49: + this.popState(); + break; + case 50: + this.popState(); + this.pushState("struct"); + return 19; + case 51: + break; + case 52: + this.popState(); + return 20; + case 53: + break; + case 54: + this.begin("NOTE"); + return 28; + case 55: + this.popState(); + this.pushState("NOTE_ID"); + return 52; + case 56: + this.popState(); + this.pushState("NOTE_ID"); + return 53; + case 57: + this.popState(); + this.pushState("FLOATING_NOTE"); + break; + case 58: + this.popState(); + this.pushState("FLOATING_NOTE_ID"); + return "AS"; + case 59: + break; + case 60: + return "NOTE_TEXT"; + case 61: + this.popState(); + return "ID"; + case 62: + this.popState(); + this.pushState("NOTE_TEXT"); + return 23; + case 63: + this.popState(); + yy_.yytext = yy_.yytext.substr(2).trim(); + return 30; + case 64: + this.popState(); + yy_.yytext = yy_.yytext.slice(0, -8).trim(); + return 30; + case 65: + return 6; + case 66: + return 6; + case 67: + return 15; + case 68: + return 50; + case 69: + return 23; + case 70: + yy_.yytext = yy_.yytext.trim(); + return 13; + case 71: + return 14; + case 72: + return 27; + case 73: + return 51; + case 74: + return 5; + case 75: + return "INVALID"; + } + }, + rules: [/^(?:default\b)/i, /^(?:.*direction\s+TB[^\n]*)/i, /^(?:.*direction\s+BT[^\n]*)/i, /^(?:.*direction\s+RL[^\n]*)/i, /^(?:.*direction\s+LR[^\n]*)/i, /^(?:%%(?!\{)[^\n]*)/i, /^(?:[^\}]%%[^\n]*)/i, /^(?:[\n]+)/i, /^(?:[\s]+)/i, /^(?:((?!\n)\s)+)/i, /^(?:#[^\n]*)/i, /^(?:%[^\n]*)/i, /^(?:scale\s+)/i, /^(?:\d+)/i, /^(?:\s+width\b)/i, /^(?:accTitle\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*\{\s*)/i, /^(?:[\}])/i, /^(?:[^\}]*)/i, /^(?:classDef\s+)/i, /^(?:DEFAULT\s+)/i, /^(?:\w+\s+)/i, /^(?:[^\n]*)/i, /^(?:class\s+)/i, /^(?:(\w+)+((,\s*\w+)*))/i, /^(?:[^\n]*)/i, /^(?:scale\s+)/i, /^(?:\d+)/i, /^(?:\s+width\b)/i, /^(?:state\s+)/i, /^(?:.*<>)/i, /^(?:.*<>)/i, /^(?:.*<>)/i, /^(?:.*\[\[fork\]\])/i, /^(?:.*\[\[join\]\])/i, /^(?:.*\[\[choice\]\])/i, /^(?:.*direction\s+TB[^\n]*)/i, /^(?:.*direction\s+BT[^\n]*)/i, /^(?:.*direction\s+RL[^\n]*)/i, /^(?:.*direction\s+LR[^\n]*)/i, /^(?:["])/i, /^(?:\s*as\s+)/i, /^(?:[^\n\{]*)/i, /^(?:["])/i, /^(?:[^"]*)/i, /^(?:[^\n\s\{]+)/i, /^(?:\n)/i, /^(?:\{)/i, /^(?:%%(?!\{)[^\n]*)/i, /^(?:\})/i, /^(?:[\n])/i, /^(?:note\s+)/i, /^(?:left of\b)/i, /^(?:right of\b)/i, /^(?:")/i, /^(?:\s*as\s*)/i, /^(?:["])/i, /^(?:[^"]*)/i, /^(?:[^\n]*)/i, /^(?:\s*[^:\n\s\-]+)/i, /^(?:\s*:[^:\n;]+)/i, /^(?:[\s\S]*?end note\b)/i, /^(?:stateDiagram\s+)/i, /^(?:stateDiagram-v2\s+)/i, /^(?:hide empty description\b)/i, /^(?:\[\*\])/i, /^(?:[^:\n\s\-\{]+)/i, /^(?:\s*:[^:\n;]+)/i, /^(?:-->)/i, /^(?:--)/i, /^(?::::)/i, /^(?:$)/i, /^(?:.)/i], + conditions: { "LINE": { "rules": [9, 10], "inclusive": false }, "struct": { "rules": [9, 10, 22, 26, 32, 39, 40, 41, 42, 51, 52, 53, 54, 68, 69, 70, 71, 72], "inclusive": false }, "FLOATING_NOTE_ID": { "rules": [61], "inclusive": false }, "FLOATING_NOTE": { "rules": [58, 59, 60], "inclusive": false }, "NOTE_TEXT": { "rules": [63, 64], "inclusive": false }, "NOTE_ID": { "rules": [62], "inclusive": false }, "NOTE": { "rules": [55, 56, 57], "inclusive": false }, "CLASS_STYLE": { "rules": [28], "inclusive": false }, "CLASS": { "rules": [27], "inclusive": false }, "CLASSDEFID": { "rules": [25], "inclusive": false }, "CLASSDEF": { "rules": [23, 24], "inclusive": false }, "acc_descr_multiline": { "rules": [20, 21], "inclusive": false }, "acc_descr": { "rules": [18], "inclusive": false }, "acc_title": { "rules": [16], "inclusive": false }, "SCALE": { "rules": [13, 14, 30, 31], "inclusive": false }, "ALIAS": { "rules": [], "inclusive": false }, "STATE_ID": { "rules": [45], "inclusive": false }, "STATE_STRING": { "rules": [46, 47], "inclusive": false }, "FORK_STATE": { "rules": [], "inclusive": false }, "STATE": { "rules": [9, 10, 33, 34, 35, 36, 37, 38, 43, 44, 48, 49, 50], "inclusive": false }, "ID": { "rules": [9, 10], "inclusive": false }, "INITIAL": { "rules": [0, 1, 2, 3, 4, 5, 6, 7, 8, 10, 11, 12, 15, 17, 19, 22, 26, 29, 32, 50, 54, 65, 66, 67, 68, 69, 70, 71, 73, 74, 75], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser() { + this.yy = {}; + } + Parser.prototype = parser2; + parser2.Parser = Parser; + return new Parser(); +}(); +parser.parser = parser; +const parser$1 = parser; +const DEFAULT_DIAGRAM_DIRECTION = "LR"; +const DEFAULT_NESTED_DOC_DIR = "TB"; +const STMT_STATE = "state"; +const STMT_RELATION = "relation"; +const STMT_CLASSDEF = "classDef"; +const STMT_APPLYCLASS = "applyClass"; +const DEFAULT_STATE_TYPE = "default"; +const DIVIDER_TYPE = "divider"; +const START_NODE = "[*]"; +const START_TYPE = "start"; +const END_NODE = START_NODE; +const END_TYPE = "end"; +const COLOR_KEYWORD = "color"; +const FILL_KEYWORD = "fill"; +const BG_FILL = "bgFill"; +const STYLECLASS_SEP = ","; +function newClassesList() { + return {}; +} +let direction = DEFAULT_DIAGRAM_DIRECTION; +let rootDoc = []; +let classes = newClassesList(); +const newDoc = () => { + return { + relations: [], + states: {}, + documents: {} + }; +}; +let documents = { + root: newDoc() +}; +let currentDocument = documents.root; +let startEndCount = 0; +let dividerCnt = 0; +const lineType = { + LINE: 0, + DOTTED_LINE: 1 +}; +const relationType = { + AGGREGATION: 0, + EXTENSION: 1, + COMPOSITION: 2, + DEPENDENCY: 3 +}; +const clone = (o) => JSON.parse(JSON.stringify(o)); +const setRootDoc = (o) => { + log.info("Setting root doc", o); + rootDoc = o; +}; +const getRootDoc = () => rootDoc; +const docTranslator = (parent, node, first) => { + if (node.stmt === STMT_RELATION) { + docTranslator(parent, node.state1, true); + docTranslator(parent, node.state2, false); + } else { + if (node.stmt === STMT_STATE) { + if (node.id === "[*]") { + node.id = first ? parent.id + "_start" : parent.id + "_end"; + node.start = first; + } else { + node.id = node.id.trim(); + } + } + if (node.doc) { + const doc = []; + let currentDoc = []; + let i; + for (i = 0; i < node.doc.length; i++) { + if (node.doc[i].type === DIVIDER_TYPE) { + const newNode = clone(node.doc[i]); + newNode.doc = clone(currentDoc); + doc.push(newNode); + currentDoc = []; + } else { + currentDoc.push(node.doc[i]); + } + } + if (doc.length > 0 && currentDoc.length > 0) { + const newNode = { + stmt: STMT_STATE, + id: generateId(), + type: "divider", + doc: clone(currentDoc) + }; + doc.push(clone(newNode)); + node.doc = doc; + } + node.doc.forEach((docNode) => docTranslator(node, docNode, true)); + } + } +}; +const getRootDocV2 = () => { + docTranslator({ id: "root" }, { id: "root", doc: rootDoc }, true); + return { id: "root", doc: rootDoc }; +}; +const extract = (_doc) => { + let doc; + if (_doc.doc) { + doc = _doc.doc; + } else { + doc = _doc; + } + log.info(doc); + clear(true); + log.info("Extract", doc); + doc.forEach((item) => { + switch (item.stmt) { + case STMT_STATE: + addState( + item.id.trim(), + item.type, + item.doc, + item.description, + item.note, + item.classes, + item.styles, + item.textStyles + ); + break; + case STMT_RELATION: + addRelation(item.state1, item.state2, item.description); + break; + case STMT_CLASSDEF: + addStyleClass(item.id.trim(), item.classes); + break; + case STMT_APPLYCLASS: + setCssClass(item.id.trim(), item.styleClass); + break; + } + }); +}; +const addState = function(id, type = DEFAULT_STATE_TYPE, doc = null, descr = null, note = null, classes2 = null, styles2 = null, textStyles = null) { + const trimmedId = id == null ? void 0 : id.trim(); + if (currentDocument.states[trimmedId] === void 0) { + log.info("Adding state ", trimmedId, descr); + currentDocument.states[trimmedId] = { + id: trimmedId, + descriptions: [], + type, + doc, + note, + classes: [], + styles: [], + textStyles: [] + }; + } else { + if (!currentDocument.states[trimmedId].doc) { + currentDocument.states[trimmedId].doc = doc; + } + if (!currentDocument.states[trimmedId].type) { + currentDocument.states[trimmedId].type = type; + } + } + if (descr) { + log.info("Setting state description", trimmedId, descr); + if (typeof descr === "string") { + addDescription(trimmedId, descr.trim()); + } + if (typeof descr === "object") { + descr.forEach((des) => addDescription(trimmedId, des.trim())); + } + } + if (note) { + currentDocument.states[trimmedId].note = note; + currentDocument.states[trimmedId].note.text = common.sanitizeText( + currentDocument.states[trimmedId].note.text, + getConfig() + ); + } + if (classes2) { + log.info("Setting state classes", trimmedId, classes2); + const classesList = typeof classes2 === "string" ? [classes2] : classes2; + classesList.forEach((cssClass) => setCssClass(trimmedId, cssClass.trim())); + } + if (styles2) { + log.info("Setting state styles", trimmedId, styles2); + const stylesList = typeof styles2 === "string" ? [styles2] : styles2; + stylesList.forEach((style) => setStyle(trimmedId, style.trim())); + } + if (textStyles) { + log.info("Setting state styles", trimmedId, styles2); + const textStylesList = typeof textStyles === "string" ? [textStyles] : textStyles; + textStylesList.forEach((textStyle) => setTextStyle(trimmedId, textStyle.trim())); + } +}; +const clear = function(saveCommon) { + documents = { + root: newDoc() + }; + currentDocument = documents.root; + startEndCount = 0; + classes = newClassesList(); + if (!saveCommon) { + clear$1(); + } +}; +const getState = function(id) { + return currentDocument.states[id]; +}; +const getStates = function() { + return currentDocument.states; +}; +const logDocuments = function() { + log.info("Documents = ", documents); +}; +const getRelations = function() { + return currentDocument.relations; +}; +function startIdIfNeeded(id = "") { + let fixedId = id; + if (id === START_NODE) { + startEndCount++; + fixedId = `${START_TYPE}${startEndCount}`; + } + return fixedId; +} +function startTypeIfNeeded(id = "", type = DEFAULT_STATE_TYPE) { + return id === START_NODE ? START_TYPE : type; +} +function endIdIfNeeded(id = "") { + let fixedId = id; + if (id === END_NODE) { + startEndCount++; + fixedId = `${END_TYPE}${startEndCount}`; + } + return fixedId; +} +function endTypeIfNeeded(id = "", type = DEFAULT_STATE_TYPE) { + return id === END_NODE ? END_TYPE : type; +} +function addRelationObjs(item1, item2, relationTitle) { + let id1 = startIdIfNeeded(item1.id.trim()); + let type1 = startTypeIfNeeded(item1.id.trim(), item1.type); + let id2 = startIdIfNeeded(item2.id.trim()); + let type2 = startTypeIfNeeded(item2.id.trim(), item2.type); + addState( + id1, + type1, + item1.doc, + item1.description, + item1.note, + item1.classes, + item1.styles, + item1.textStyles + ); + addState( + id2, + type2, + item2.doc, + item2.description, + item2.note, + item2.classes, + item2.styles, + item2.textStyles + ); + currentDocument.relations.push({ + id1, + id2, + relationTitle: common.sanitizeText(relationTitle, getConfig()) + }); +} +const addRelation = function(item1, item2, title) { + if (typeof item1 === "object") { + addRelationObjs(item1, item2, title); + } else { + const id1 = startIdIfNeeded(item1.trim()); + const type1 = startTypeIfNeeded(item1); + const id2 = endIdIfNeeded(item2.trim()); + const type2 = endTypeIfNeeded(item2); + addState(id1, type1); + addState(id2, type2); + currentDocument.relations.push({ + id1, + id2, + title: common.sanitizeText(title, getConfig()) + }); + } +}; +const addDescription = function(id, descr) { + const theState = currentDocument.states[id]; + const _descr = descr.startsWith(":") ? descr.replace(":", "").trim() : descr; + theState.descriptions.push(common.sanitizeText(_descr, getConfig())); +}; +const cleanupLabel = function(label) { + if (label.substring(0, 1) === ":") { + return label.substr(2).trim(); + } else { + return label.trim(); + } +}; +const getDividerId = () => { + dividerCnt++; + return "divider-id-" + dividerCnt; +}; +const addStyleClass = function(id, styleAttributes = "") { + if (classes[id] === void 0) { + classes[id] = { id, styles: [], textStyles: [] }; + } + const foundClass = classes[id]; + if (styleAttributes !== void 0 && styleAttributes !== null) { + styleAttributes.split(STYLECLASS_SEP).forEach((attrib) => { + const fixedAttrib = attrib.replace(/([^;]*);/, "$1").trim(); + if (attrib.match(COLOR_KEYWORD)) { + const newStyle1 = fixedAttrib.replace(FILL_KEYWORD, BG_FILL); + const newStyle2 = newStyle1.replace(COLOR_KEYWORD, FILL_KEYWORD); + foundClass.textStyles.push(newStyle2); + } + foundClass.styles.push(fixedAttrib); + }); + } +}; +const getClasses = function() { + return classes; +}; +const setCssClass = function(itemIds, cssClassName) { + itemIds.split(",").forEach(function(id) { + let foundState = getState(id); + if (foundState === void 0) { + const trimmedId = id.trim(); + addState(trimmedId); + foundState = getState(trimmedId); + } + foundState.classes.push(cssClassName); + }); +}; +const setStyle = function(itemId, styleText) { + const item = getState(itemId); + if (item !== void 0) { + item.textStyles.push(styleText); + } +}; +const setTextStyle = function(itemId, cssClassName) { + const item = getState(itemId); + if (item !== void 0) { + item.textStyles.push(cssClassName); + } +}; +const getDirection = () => direction; +const setDirection = (dir) => { + direction = dir; +}; +const trimColon = (str) => str && str[0] === ":" ? str.substr(1).trim() : str.trim(); +const db = { + getConfig: () => getConfig().state, + addState, + clear, + getState, + getStates, + getRelations, + getClasses, + getDirection, + addRelation, + getDividerId, + setDirection, + cleanupLabel, + lineType, + relationType, + logDocuments, + getRootDoc, + setRootDoc, + getRootDocV2, + extract, + trimColon, + getAccTitle, + setAccTitle, + getAccDescription, + setAccDescription, + addStyleClass, + setCssClass, + addDescription, + setDiagramTitle, + getDiagramTitle +}; +const getStyles = (options) => ` +defs #statediagram-barbEnd { + fill: ${options.transitionColor}; + stroke: ${options.transitionColor}; + } +g.stateGroup text { + fill: ${options.nodeBorder}; + stroke: none; + font-size: 10px; +} +g.stateGroup text { + fill: ${options.textColor}; + stroke: none; + font-size: 10px; + +} +g.stateGroup .state-title { + font-weight: bolder; + fill: ${options.stateLabelColor}; +} + +g.stateGroup rect { + fill: ${options.mainBkg}; + stroke: ${options.nodeBorder}; +} + +g.stateGroup line { + stroke: ${options.lineColor}; + stroke-width: 1; +} + +.transition { + stroke: ${options.transitionColor}; + stroke-width: 1; + fill: none; +} + +.stateGroup .composit { + fill: ${options.background}; + border-bottom: 1px +} + +.stateGroup .alt-composit { + fill: #e0e0e0; + border-bottom: 1px +} + +.state-note { + stroke: ${options.noteBorderColor}; + fill: ${options.noteBkgColor}; + + text { + fill: ${options.noteTextColor}; + stroke: none; + font-size: 10px; + } +} + +.stateLabel .box { + stroke: none; + stroke-width: 0; + fill: ${options.mainBkg}; + opacity: 0.5; +} + +.edgeLabel .label rect { + fill: ${options.labelBackgroundColor}; + opacity: 0.5; +} +.edgeLabel .label text { + fill: ${options.transitionLabelColor || options.tertiaryTextColor}; +} +.label div .edgeLabel { + color: ${options.transitionLabelColor || options.tertiaryTextColor}; +} + +.stateLabel text { + fill: ${options.stateLabelColor}; + font-size: 10px; + font-weight: bold; +} + +.node circle.state-start { + fill: ${options.specialStateColor}; + stroke: ${options.specialStateColor}; +} + +.node .fork-join { + fill: ${options.specialStateColor}; + stroke: ${options.specialStateColor}; +} + +.node circle.state-end { + fill: ${options.innerEndBackground}; + stroke: ${options.background}; + stroke-width: 1.5 +} +.end-state-inner { + fill: ${options.compositeBackground || options.background}; + // stroke: ${options.background}; + stroke-width: 1.5 +} + +.node rect { + fill: ${options.stateBkg || options.mainBkg}; + stroke: ${options.stateBorder || options.nodeBorder}; + stroke-width: 1px; +} +.node polygon { + fill: ${options.mainBkg}; + stroke: ${options.stateBorder || options.nodeBorder};; + stroke-width: 1px; +} +#statediagram-barbEnd { + fill: ${options.lineColor}; +} + +.statediagram-cluster rect { + fill: ${options.compositeTitleBackground}; + stroke: ${options.stateBorder || options.nodeBorder}; + stroke-width: 1px; +} + +.cluster-label, .nodeLabel { + color: ${options.stateLabelColor}; +} + +.statediagram-cluster rect.outer { + rx: 5px; + ry: 5px; +} +.statediagram-state .divider { + stroke: ${options.stateBorder || options.nodeBorder}; +} + +.statediagram-state .title-state { + rx: 5px; + ry: 5px; +} +.statediagram-cluster.statediagram-cluster .inner { + fill: ${options.compositeBackground || options.background}; +} +.statediagram-cluster.statediagram-cluster-alt .inner { + fill: ${options.altBackground ? options.altBackground : "#efefef"}; +} + +.statediagram-cluster .inner { + rx:0; + ry:0; +} + +.statediagram-state rect.basic { + rx: 5px; + ry: 5px; +} +.statediagram-state rect.divider { + stroke-dasharray: 10,10; + fill: ${options.altBackground ? options.altBackground : "#efefef"}; +} + +.note-edge { + stroke-dasharray: 5; +} + +.statediagram-note rect { + fill: ${options.noteBkgColor}; + stroke: ${options.noteBorderColor}; + stroke-width: 1px; + rx: 0; + ry: 0; +} +.statediagram-note rect { + fill: ${options.noteBkgColor}; + stroke: ${options.noteBorderColor}; + stroke-width: 1px; + rx: 0; + ry: 0; +} + +.statediagram-note text { + fill: ${options.noteTextColor}; +} + +.statediagram-note .nodeLabel { + color: ${options.noteTextColor}; +} +.statediagram .edgeLabel { + color: red; // ${options.noteTextColor}; +} + +#dependencyStart, #dependencyEnd { + fill: ${options.lineColor}; + stroke: ${options.lineColor}; + stroke-width: 1; +} + +.statediagramTitleText { + text-anchor: middle; + font-size: 18px; + fill: ${options.textColor}; +} +`; +const styles = getStyles; +export { + DEFAULT_STATE_TYPE as D, + STMT_RELATION as S, + DIVIDER_TYPE as a, + STMT_STATE as b, + DEFAULT_NESTED_DOC_DIR as c, + db as d, + parser$1 as p, + styles as s +}; diff --git a/0.6.0/js/mermaid/styles-11e81fdd.js b/0.6.0/js/mermaid/styles-11e81fdd.js new file mode 100644 index 0000000..432f301 --- /dev/null +++ b/0.6.0/js/mermaid/styles-11e81fdd.js @@ -0,0 +1,1089 @@ +import { d as ut, c as F, G as Re, s as rt, g as at, a as lt, b as ct, C as ot, D as ht, f as v, E as At, l as pt, A as We, j as z } from "./mermaid-9f2aa176.js"; +var Ve = function() { + var e = function(x, u, a, h) { + for (a = a || {}, h = x.length; h--; a[x[h]] = u) + ; + return a; + }, i = [1, 17], r = [1, 18], l = [1, 19], o = [1, 39], A = [1, 40], g = [1, 25], D = [1, 23], B = [1, 24], _ = [1, 31], fe = [1, 32], de = [1, 33], Ee = [1, 34], Ce = [1, 35], me = [1, 36], be = [1, 26], ge = [1, 27], ke = [1, 28], Te = [1, 29], d = [1, 43], Fe = [1, 30], E = [1, 42], C = [1, 44], m = [1, 41], k = [1, 45], ye = [1, 9], c = [1, 8, 9], Y = [1, 56], j = [1, 57], Q = [1, 58], X = [1, 59], H = [1, 60], De = [1, 61], Be = [1, 62], W = [1, 8, 9, 39], Ge = [1, 74], M = [1, 8, 9, 12, 13, 21, 37, 39, 42, 59, 60, 61, 62, 63, 64, 65, 70, 72], q = [1, 8, 9, 12, 13, 19, 21, 37, 39, 42, 46, 59, 60, 61, 62, 63, 64, 65, 70, 72, 74, 80, 95, 97, 98], J = [13, 74, 80, 95, 97, 98], G = [13, 64, 65, 74, 80, 95, 97, 98], Ue = [13, 59, 60, 61, 62, 63, 74, 80, 95, 97, 98], _e = [1, 93], Z = [1, 110], $ = [1, 108], ee = [1, 102], te = [1, 103], se = [1, 104], ie = [1, 105], ne = [1, 106], ue = [1, 107], re = [1, 109], Se = [1, 8, 9, 37, 39, 42], ae = [1, 8, 9, 21], ze = [1, 8, 9, 78], S = [1, 8, 9, 21, 73, 74, 78, 80, 81, 82, 83, 84, 85], Ne = { + trace: function() { + }, + yy: {}, + symbols_: { error: 2, start: 3, mermaidDoc: 4, statements: 5, graphConfig: 6, CLASS_DIAGRAM: 7, NEWLINE: 8, EOF: 9, statement: 10, classLabel: 11, SQS: 12, STR: 13, SQE: 14, namespaceName: 15, alphaNumToken: 16, className: 17, classLiteralName: 18, GENERICTYPE: 19, relationStatement: 20, LABEL: 21, namespaceStatement: 22, classStatement: 23, memberStatement: 24, annotationStatement: 25, clickStatement: 26, styleStatement: 27, cssClassStatement: 28, noteStatement: 29, direction: 30, acc_title: 31, acc_title_value: 32, acc_descr: 33, acc_descr_value: 34, acc_descr_multiline_value: 35, namespaceIdentifier: 36, STRUCT_START: 37, classStatements: 38, STRUCT_STOP: 39, NAMESPACE: 40, classIdentifier: 41, STYLE_SEPARATOR: 42, members: 43, CLASS: 44, ANNOTATION_START: 45, ANNOTATION_END: 46, MEMBER: 47, SEPARATOR: 48, relation: 49, NOTE_FOR: 50, noteText: 51, NOTE: 52, direction_tb: 53, direction_bt: 54, direction_rl: 55, direction_lr: 56, relationType: 57, lineType: 58, AGGREGATION: 59, EXTENSION: 60, COMPOSITION: 61, DEPENDENCY: 62, LOLLIPOP: 63, LINE: 64, DOTTED_LINE: 65, CALLBACK: 66, LINK: 67, LINK_TARGET: 68, CLICK: 69, CALLBACK_NAME: 70, CALLBACK_ARGS: 71, HREF: 72, STYLE: 73, ALPHA: 74, stylesOpt: 75, CSSCLASS: 76, style: 77, COMMA: 78, styleComponent: 79, NUM: 80, COLON: 81, UNIT: 82, SPACE: 83, BRKT: 84, PCT: 85, commentToken: 86, textToken: 87, graphCodeTokens: 88, textNoTagsToken: 89, TAGSTART: 90, TAGEND: 91, "==": 92, "--": 93, DEFAULT: 94, MINUS: 95, keywords: 96, UNICODE_TEXT: 97, BQUOTE_STR: 98, $accept: 0, $end: 1 }, + terminals_: { 2: "error", 7: "CLASS_DIAGRAM", 8: "NEWLINE", 9: "EOF", 12: "SQS", 13: "STR", 14: "SQE", 19: "GENERICTYPE", 21: "LABEL", 31: "acc_title", 32: "acc_title_value", 33: "acc_descr", 34: "acc_descr_value", 35: "acc_descr_multiline_value", 37: "STRUCT_START", 39: "STRUCT_STOP", 40: "NAMESPACE", 42: "STYLE_SEPARATOR", 44: "CLASS", 45: "ANNOTATION_START", 46: "ANNOTATION_END", 47: "MEMBER", 48: "SEPARATOR", 50: "NOTE_FOR", 52: "NOTE", 53: "direction_tb", 54: "direction_bt", 55: "direction_rl", 56: "direction_lr", 59: "AGGREGATION", 60: "EXTENSION", 61: "COMPOSITION", 62: "DEPENDENCY", 63: "LOLLIPOP", 64: "LINE", 65: "DOTTED_LINE", 66: "CALLBACK", 67: "LINK", 68: "LINK_TARGET", 69: "CLICK", 70: "CALLBACK_NAME", 71: "CALLBACK_ARGS", 72: "HREF", 73: "STYLE", 74: "ALPHA", 76: "CSSCLASS", 78: "COMMA", 80: "NUM", 81: "COLON", 82: "UNIT", 83: "SPACE", 84: "BRKT", 85: "PCT", 88: "graphCodeTokens", 90: "TAGSTART", 91: "TAGEND", 92: "==", 93: "--", 94: "DEFAULT", 95: "MINUS", 96: "keywords", 97: "UNICODE_TEXT", 98: "BQUOTE_STR" }, + productions_: [0, [3, 1], [3, 1], [4, 1], [6, 4], [5, 1], [5, 2], [5, 3], [11, 3], [15, 1], [15, 2], [17, 1], [17, 1], [17, 2], [17, 2], [17, 2], [10, 1], [10, 2], [10, 1], [10, 1], [10, 1], [10, 1], [10, 1], [10, 1], [10, 1], [10, 1], [10, 1], [10, 2], [10, 2], [10, 1], [22, 4], [22, 5], [36, 2], [38, 1], [38, 2], [38, 3], [23, 1], [23, 3], [23, 4], [23, 6], [41, 2], [41, 3], [25, 4], [43, 1], [43, 2], [24, 1], [24, 2], [24, 1], [24, 1], [20, 3], [20, 4], [20, 4], [20, 5], [29, 3], [29, 2], [30, 1], [30, 1], [30, 1], [30, 1], [49, 3], [49, 2], [49, 2], [49, 1], [57, 1], [57, 1], [57, 1], [57, 1], [57, 1], [58, 1], [58, 1], [26, 3], [26, 4], [26, 3], [26, 4], [26, 4], [26, 5], [26, 3], [26, 4], [26, 4], [26, 5], [26, 4], [26, 5], [26, 5], [26, 6], [27, 3], [28, 3], [75, 1], [75, 3], [77, 1], [77, 2], [79, 1], [79, 1], [79, 1], [79, 1], [79, 1], [79, 1], [79, 1], [79, 1], [79, 1], [86, 1], [86, 1], [87, 1], [87, 1], [87, 1], [87, 1], [87, 1], [87, 1], [87, 1], [89, 1], [89, 1], [89, 1], [89, 1], [16, 1], [16, 1], [16, 1], [16, 1], [18, 1], [51, 1]], + performAction: function(u, a, h, n, f, t, U) { + var s = t.length - 1; + switch (f) { + case 8: + this.$ = t[s - 1]; + break; + case 9: + case 11: + case 12: + this.$ = t[s]; + break; + case 10: + case 13: + this.$ = t[s - 1] + t[s]; + break; + case 14: + case 15: + this.$ = t[s - 1] + "~" + t[s] + "~"; + break; + case 16: + n.addRelation(t[s]); + break; + case 17: + t[s - 1].title = n.cleanupLabel(t[s]), n.addRelation(t[s - 1]); + break; + case 27: + this.$ = t[s].trim(), n.setAccTitle(this.$); + break; + case 28: + case 29: + this.$ = t[s].trim(), n.setAccDescription(this.$); + break; + case 30: + n.addClassesToNamespace(t[s - 3], t[s - 1]); + break; + case 31: + n.addClassesToNamespace(t[s - 4], t[s - 1]); + break; + case 32: + this.$ = t[s], n.addNamespace(t[s]); + break; + case 33: + this.$ = [t[s]]; + break; + case 34: + this.$ = [t[s - 1]]; + break; + case 35: + t[s].unshift(t[s - 2]), this.$ = t[s]; + break; + case 37: + n.setCssClass(t[s - 2], t[s]); + break; + case 38: + n.addMembers(t[s - 3], t[s - 1]); + break; + case 39: + n.setCssClass(t[s - 5], t[s - 3]), n.addMembers(t[s - 5], t[s - 1]); + break; + case 40: + this.$ = t[s], n.addClass(t[s]); + break; + case 41: + this.$ = t[s - 1], n.addClass(t[s - 1]), n.setClassLabel(t[s - 1], t[s]); + break; + case 42: + n.addAnnotation(t[s], t[s - 2]); + break; + case 43: + this.$ = [t[s]]; + break; + case 44: + t[s].push(t[s - 1]), this.$ = t[s]; + break; + case 45: + break; + case 46: + n.addMember(t[s - 1], n.cleanupLabel(t[s])); + break; + case 47: + break; + case 48: + break; + case 49: + this.$ = { id1: t[s - 2], id2: t[s], relation: t[s - 1], relationTitle1: "none", relationTitle2: "none" }; + break; + case 50: + this.$ = { id1: t[s - 3], id2: t[s], relation: t[s - 1], relationTitle1: t[s - 2], relationTitle2: "none" }; + break; + case 51: + this.$ = { id1: t[s - 3], id2: t[s], relation: t[s - 2], relationTitle1: "none", relationTitle2: t[s - 1] }; + break; + case 52: + this.$ = { id1: t[s - 4], id2: t[s], relation: t[s - 2], relationTitle1: t[s - 3], relationTitle2: t[s - 1] }; + break; + case 53: + n.addNote(t[s], t[s - 1]); + break; + case 54: + n.addNote(t[s]); + break; + case 55: + n.setDirection("TB"); + break; + case 56: + n.setDirection("BT"); + break; + case 57: + n.setDirection("RL"); + break; + case 58: + n.setDirection("LR"); + break; + case 59: + this.$ = { type1: t[s - 2], type2: t[s], lineType: t[s - 1] }; + break; + case 60: + this.$ = { type1: "none", type2: t[s], lineType: t[s - 1] }; + break; + case 61: + this.$ = { type1: t[s - 1], type2: "none", lineType: t[s] }; + break; + case 62: + this.$ = { type1: "none", type2: "none", lineType: t[s] }; + break; + case 63: + this.$ = n.relationType.AGGREGATION; + break; + case 64: + this.$ = n.relationType.EXTENSION; + break; + case 65: + this.$ = n.relationType.COMPOSITION; + break; + case 66: + this.$ = n.relationType.DEPENDENCY; + break; + case 67: + this.$ = n.relationType.LOLLIPOP; + break; + case 68: + this.$ = n.lineType.LINE; + break; + case 69: + this.$ = n.lineType.DOTTED_LINE; + break; + case 70: + case 76: + this.$ = t[s - 2], n.setClickEvent(t[s - 1], t[s]); + break; + case 71: + case 77: + this.$ = t[s - 3], n.setClickEvent(t[s - 2], t[s - 1]), n.setTooltip(t[s - 2], t[s]); + break; + case 72: + this.$ = t[s - 2], n.setLink(t[s - 1], t[s]); + break; + case 73: + this.$ = t[s - 3], n.setLink(t[s - 2], t[s - 1], t[s]); + break; + case 74: + this.$ = t[s - 3], n.setLink(t[s - 2], t[s - 1]), n.setTooltip(t[s - 2], t[s]); + break; + case 75: + this.$ = t[s - 4], n.setLink(t[s - 3], t[s - 2], t[s]), n.setTooltip(t[s - 3], t[s - 1]); + break; + case 78: + this.$ = t[s - 3], n.setClickEvent(t[s - 2], t[s - 1], t[s]); + break; + case 79: + this.$ = t[s - 4], n.setClickEvent(t[s - 3], t[s - 2], t[s - 1]), n.setTooltip(t[s - 3], t[s]); + break; + case 80: + this.$ = t[s - 3], n.setLink(t[s - 2], t[s]); + break; + case 81: + this.$ = t[s - 4], n.setLink(t[s - 3], t[s - 1], t[s]); + break; + case 82: + this.$ = t[s - 4], n.setLink(t[s - 3], t[s - 1]), n.setTooltip(t[s - 3], t[s]); + break; + case 83: + this.$ = t[s - 5], n.setLink(t[s - 4], t[s - 2], t[s]), n.setTooltip(t[s - 4], t[s - 1]); + break; + case 84: + this.$ = t[s - 2], n.setCssStyle(t[s - 1], t[s]); + break; + case 85: + n.setCssClass(t[s - 1], t[s]); + break; + case 86: + this.$ = [t[s]]; + break; + case 87: + t[s - 2].push(t[s]), this.$ = t[s - 2]; + break; + case 89: + this.$ = t[s - 1] + t[s]; + break; + } + }, + table: [{ 3: 1, 4: 2, 5: 3, 6: 4, 7: [1, 6], 10: 5, 16: 37, 17: 20, 18: 38, 20: 7, 22: 8, 23: 9, 24: 10, 25: 11, 26: 12, 27: 13, 28: 14, 29: 15, 30: 16, 31: i, 33: r, 35: l, 36: 21, 40: o, 41: 22, 44: A, 45: g, 47: D, 48: B, 50: _, 52: fe, 53: de, 54: Ee, 55: Ce, 56: me, 66: be, 67: ge, 69: ke, 73: Te, 74: d, 76: Fe, 80: E, 95: C, 97: m, 98: k }, { 1: [3] }, { 1: [2, 1] }, { 1: [2, 2] }, { 1: [2, 3] }, e(ye, [2, 5], { 8: [1, 46] }), { 8: [1, 47] }, e(c, [2, 16], { 21: [1, 48] }), e(c, [2, 18]), e(c, [2, 19]), e(c, [2, 20]), e(c, [2, 21]), e(c, [2, 22]), e(c, [2, 23]), e(c, [2, 24]), e(c, [2, 25]), e(c, [2, 26]), { 32: [1, 49] }, { 34: [1, 50] }, e(c, [2, 29]), e(c, [2, 45], { 49: 51, 57: 54, 58: 55, 13: [1, 52], 21: [1, 53], 59: Y, 60: j, 61: Q, 62: X, 63: H, 64: De, 65: Be }), { 37: [1, 63] }, e(W, [2, 36], { 37: [1, 65], 42: [1, 64] }), e(c, [2, 47]), e(c, [2, 48]), { 16: 66, 74: d, 80: E, 95: C, 97: m }, { 16: 37, 17: 67, 18: 38, 74: d, 80: E, 95: C, 97: m, 98: k }, { 16: 37, 17: 68, 18: 38, 74: d, 80: E, 95: C, 97: m, 98: k }, { 16: 37, 17: 69, 18: 38, 74: d, 80: E, 95: C, 97: m, 98: k }, { 74: [1, 70] }, { 13: [1, 71] }, { 16: 37, 17: 72, 18: 38, 74: d, 80: E, 95: C, 97: m, 98: k }, { 13: Ge, 51: 73 }, e(c, [2, 55]), e(c, [2, 56]), e(c, [2, 57]), e(c, [2, 58]), e(M, [2, 11], { 16: 37, 18: 38, 17: 75, 19: [1, 76], 74: d, 80: E, 95: C, 97: m, 98: k }), e(M, [2, 12], { 19: [1, 77] }), { 15: 78, 16: 79, 74: d, 80: E, 95: C, 97: m }, { 16: 37, 17: 80, 18: 38, 74: d, 80: E, 95: C, 97: m, 98: k }, e(q, [2, 112]), e(q, [2, 113]), e(q, [2, 114]), e(q, [2, 115]), e([1, 8, 9, 12, 13, 19, 21, 37, 39, 42, 59, 60, 61, 62, 63, 64, 65, 70, 72], [2, 116]), e(ye, [2, 6], { 10: 5, 20: 7, 22: 8, 23: 9, 24: 10, 25: 11, 26: 12, 27: 13, 28: 14, 29: 15, 30: 16, 17: 20, 36: 21, 41: 22, 16: 37, 18: 38, 5: 81, 31: i, 33: r, 35: l, 40: o, 44: A, 45: g, 47: D, 48: B, 50: _, 52: fe, 53: de, 54: Ee, 55: Ce, 56: me, 66: be, 67: ge, 69: ke, 73: Te, 74: d, 76: Fe, 80: E, 95: C, 97: m, 98: k }), { 5: 82, 10: 5, 16: 37, 17: 20, 18: 38, 20: 7, 22: 8, 23: 9, 24: 10, 25: 11, 26: 12, 27: 13, 28: 14, 29: 15, 30: 16, 31: i, 33: r, 35: l, 36: 21, 40: o, 41: 22, 44: A, 45: g, 47: D, 48: B, 50: _, 52: fe, 53: de, 54: Ee, 55: Ce, 56: me, 66: be, 67: ge, 69: ke, 73: Te, 74: d, 76: Fe, 80: E, 95: C, 97: m, 98: k }, e(c, [2, 17]), e(c, [2, 27]), e(c, [2, 28]), { 13: [1, 84], 16: 37, 17: 83, 18: 38, 74: d, 80: E, 95: C, 97: m, 98: k }, { 49: 85, 57: 54, 58: 55, 59: Y, 60: j, 61: Q, 62: X, 63: H, 64: De, 65: Be }, e(c, [2, 46]), { 58: 86, 64: De, 65: Be }, e(J, [2, 62], { 57: 87, 59: Y, 60: j, 61: Q, 62: X, 63: H }), e(G, [2, 63]), e(G, [2, 64]), e(G, [2, 65]), e(G, [2, 66]), e(G, [2, 67]), e(Ue, [2, 68]), e(Ue, [2, 69]), { 8: [1, 89], 23: 90, 38: 88, 41: 22, 44: A }, { 16: 91, 74: d, 80: E, 95: C, 97: m }, { 43: 92, 47: _e }, { 46: [1, 94] }, { 13: [1, 95] }, { 13: [1, 96] }, { 70: [1, 97], 72: [1, 98] }, { 21: Z, 73: $, 74: ee, 75: 99, 77: 100, 79: 101, 80: te, 81: se, 82: ie, 83: ne, 84: ue, 85: re }, { 74: [1, 111] }, { 13: Ge, 51: 112 }, e(c, [2, 54]), e(c, [2, 117]), e(M, [2, 13]), e(M, [2, 14]), e(M, [2, 15]), { 37: [2, 32] }, { 15: 113, 16: 79, 37: [2, 9], 74: d, 80: E, 95: C, 97: m }, e(Se, [2, 40], { 11: 114, 12: [1, 115] }), e(ye, [2, 7]), { 9: [1, 116] }, e(ae, [2, 49]), { 16: 37, 17: 117, 18: 38, 74: d, 80: E, 95: C, 97: m, 98: k }, { 13: [1, 119], 16: 37, 17: 118, 18: 38, 74: d, 80: E, 95: C, 97: m, 98: k }, e(J, [2, 61], { 57: 120, 59: Y, 60: j, 61: Q, 62: X, 63: H }), e(J, [2, 60]), { 39: [1, 121] }, { 23: 90, 38: 122, 41: 22, 44: A }, { 8: [1, 123], 39: [2, 33] }, e(W, [2, 37], { 37: [1, 124] }), { 39: [1, 125] }, { 39: [2, 43], 43: 126, 47: _e }, { 16: 37, 17: 127, 18: 38, 74: d, 80: E, 95: C, 97: m, 98: k }, e(c, [2, 70], { 13: [1, 128] }), e(c, [2, 72], { 13: [1, 130], 68: [1, 129] }), e(c, [2, 76], { 13: [1, 131], 71: [1, 132] }), { 13: [1, 133] }, e(c, [2, 84], { 78: [1, 134] }), e(ze, [2, 86], { 79: 135, 21: Z, 73: $, 74: ee, 80: te, 81: se, 82: ie, 83: ne, 84: ue, 85: re }), e(S, [2, 88]), e(S, [2, 90]), e(S, [2, 91]), e(S, [2, 92]), e(S, [2, 93]), e(S, [2, 94]), e(S, [2, 95]), e(S, [2, 96]), e(S, [2, 97]), e(S, [2, 98]), e(c, [2, 85]), e(c, [2, 53]), { 37: [2, 10] }, e(Se, [2, 41]), { 13: [1, 136] }, { 1: [2, 4] }, e(ae, [2, 51]), e(ae, [2, 50]), { 16: 37, 17: 137, 18: 38, 74: d, 80: E, 95: C, 97: m, 98: k }, e(J, [2, 59]), e(c, [2, 30]), { 39: [1, 138] }, { 23: 90, 38: 139, 39: [2, 34], 41: 22, 44: A }, { 43: 140, 47: _e }, e(W, [2, 38]), { 39: [2, 44] }, e(c, [2, 42]), e(c, [2, 71]), e(c, [2, 73]), e(c, [2, 74], { 68: [1, 141] }), e(c, [2, 77]), e(c, [2, 78], { 13: [1, 142] }), e(c, [2, 80], { 13: [1, 144], 68: [1, 143] }), { 21: Z, 73: $, 74: ee, 77: 145, 79: 101, 80: te, 81: se, 82: ie, 83: ne, 84: ue, 85: re }, e(S, [2, 89]), { 14: [1, 146] }, e(ae, [2, 52]), e(c, [2, 31]), { 39: [2, 35] }, { 39: [1, 147] }, e(c, [2, 75]), e(c, [2, 79]), e(c, [2, 81]), e(c, [2, 82], { 68: [1, 148] }), e(ze, [2, 87], { 79: 135, 21: Z, 73: $, 74: ee, 80: te, 81: se, 82: ie, 83: ne, 84: ue, 85: re }), e(Se, [2, 8]), e(W, [2, 39]), e(c, [2, 83])], + defaultActions: { 2: [2, 1], 3: [2, 2], 4: [2, 3], 78: [2, 32], 113: [2, 10], 116: [2, 4], 126: [2, 44], 139: [2, 35] }, + parseError: function(u, a) { + if (a.recoverable) + this.trace(u); + else { + var h = new Error(u); + throw h.hash = a, h; + } + }, + parse: function(u) { + var a = this, h = [0], n = [], f = [null], t = [], U = this.table, s = "", le = 0, Ke = 0, tt = 2, Ye = 1, st = t.slice.call(arguments, 1), b = Object.create(this.lexer), I = { yy: {} }; + for (var ve in this.yy) + Object.prototype.hasOwnProperty.call(this.yy, ve) && (I.yy[ve] = this.yy[ve]); + b.setInput(u, I.yy), I.yy.lexer = b, I.yy.parser = this, typeof b.yylloc > "u" && (b.yylloc = {}); + var xe = b.yylloc; + t.push(xe); + var it = b.options && b.options.ranges; + typeof I.yy.parseError == "function" ? this.parseError = I.yy.parseError : this.parseError = Object.getPrototypeOf(this).parseError; + function nt() { + var L; + return L = n.pop() || b.lex() || Ye, typeof L != "number" && (L instanceof Array && (n = L, L = n.pop()), L = a.symbols_[L] || L), L; + } + for (var T, R, y, Oe, P = {}, ce, N, je, oe; ; ) { + if (R = h[h.length - 1], this.defaultActions[R] ? y = this.defaultActions[R] : ((T === null || typeof T > "u") && (T = nt()), y = U[R] && U[R][T]), typeof y > "u" || !y.length || !y[0]) { + var Ie = ""; + oe = []; + for (ce in U[R]) + this.terminals_[ce] && ce > tt && oe.push("'" + this.terminals_[ce] + "'"); + b.showPosition ? Ie = "Parse error on line " + (le + 1) + `: +` + b.showPosition() + ` +Expecting ` + oe.join(", ") + ", got '" + (this.terminals_[T] || T) + "'" : Ie = "Parse error on line " + (le + 1) + ": Unexpected " + (T == Ye ? "end of input" : "'" + (this.terminals_[T] || T) + "'"), this.parseError(Ie, { + text: b.match, + token: this.terminals_[T] || T, + line: b.yylineno, + loc: xe, + expected: oe + }); + } + if (y[0] instanceof Array && y.length > 1) + throw new Error("Parse Error: multiple actions possible at state: " + R + ", token: " + T); + switch (y[0]) { + case 1: + h.push(T), f.push(b.yytext), t.push(b.yylloc), h.push(y[1]), T = null, Ke = b.yyleng, s = b.yytext, le = b.yylineno, xe = b.yylloc; + break; + case 2: + if (N = this.productions_[y[1]][1], P.$ = f[f.length - N], P._$ = { + first_line: t[t.length - (N || 1)].first_line, + last_line: t[t.length - 1].last_line, + first_column: t[t.length - (N || 1)].first_column, + last_column: t[t.length - 1].last_column + }, it && (P._$.range = [ + t[t.length - (N || 1)].range[0], + t[t.length - 1].range[1] + ]), Oe = this.performAction.apply(P, [ + s, + Ke, + le, + I.yy, + y[1], + f, + t + ].concat(st)), typeof Oe < "u") + return Oe; + N && (h = h.slice(0, -1 * N * 2), f = f.slice(0, -1 * N), t = t.slice(0, -1 * N)), h.push(this.productions_[y[1]][0]), f.push(P.$), t.push(P._$), je = U[h[h.length - 2]][h[h.length - 1]], h.push(je); + break; + case 3: + return !0; + } + } + return !0; + } + }, et = function() { + var x = { + EOF: 1, + parseError: function(a, h) { + if (this.yy.parser) + this.yy.parser.parseError(a, h); + else + throw new Error(a); + }, + // resets the lexer, sets new input + setInput: function(u, a) { + return this.yy = a || this.yy || {}, this._input = u, 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 u = this._input[0]; + this.yytext += u, this.yyleng++, this.offset++, this.match += u, this.matched += u; + var a = u.match(/(?:\r\n?|\n).*/g); + return a ? (this.yylineno++, this.yylloc.last_line++) : this.yylloc.last_column++, this.options.ranges && this.yylloc.range[1]++, this._input = this._input.slice(1), u; + }, + // unshifts one char (or a string) into the input + unput: function(u) { + var a = u.length, h = u.split(/(?:\r\n?|\n)/g); + this._input = u + this._input, this.yytext = this.yytext.substr(0, this.yytext.length - a), this.offset -= a; + var n = 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), h.length - 1 && (this.yylineno -= h.length - 1); + var f = 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: h ? (h.length === n.length ? this.yylloc.first_column : 0) + n[n.length - h.length].length - h[0].length : this.yylloc.first_column - a + }, this.options.ranges && (this.yylloc.range = [f[0], f[0] + this.yyleng - a]), 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(u) { + this.unput(this.match.slice(u)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var u = this.matched.substr(0, this.matched.length - this.match.length); + return (u.length > 20 ? "..." : "") + u.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var u = this.match; + return u.length < 20 && (u += this._input.substr(0, 20 - u.length)), (u.substr(0, 20) + (u.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var u = this.pastInput(), a = new Array(u.length + 1).join("-"); + return u + this.upcomingInput() + ` +` + a + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(u, a) { + var h, n, f; + if (this.options.backtrack_lexer && (f = { + 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 && (f.yylloc.range = this.yylloc.range.slice(0))), n = u[0].match(/(?:\r\n?|\n).*/g), n && (this.yylineno += n.length), this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: n ? n[n.length - 1].length - n[n.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + u[0].length + }, this.yytext += u[0], this.match += u[0], this.matches = u, 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(u[0].length), this.matched += u[0], h = this.performAction.call(this, this.yy, this, a, this.conditionStack[this.conditionStack.length - 1]), this.done && this._input && (this.done = !1), h) + return h; + if (this._backtrack) { + for (var t in f) + this[t] = f[t]; + return !1; + } + return !1; + }, + // return next match in input + next: function() { + if (this.done) + return this.EOF; + this._input || (this.done = !0); + var u, a, h, n; + this._more || (this.yytext = "", this.match = ""); + for (var f = this._currentRules(), t = 0; t < f.length; t++) + if (h = this._input.match(this.rules[f[t]]), h && (!a || h[0].length > a[0].length)) { + if (a = h, n = t, this.options.backtrack_lexer) { + if (u = this.test_match(h, f[t]), u !== !1) + return u; + if (this._backtrack) { + a = !1; + continue; + } else + return !1; + } else if (!this.options.flex) + break; + } + return a ? (u = this.test_match(a, f[n]), u !== !1 ? u : !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 a = this.next(); + return a || this.lex(); + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function(a) { + this.conditionStack.push(a); + }, + // pop the previously active lexer condition state off the condition stack + popState: function() { + var a = this.conditionStack.length - 1; + return a > 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(a) { + return a = this.conditionStack.length - 1 - Math.abs(a || 0), a >= 0 ? this.conditionStack[a] : "INITIAL"; + }, + // alias for begin(condition) + pushState: function(a) { + this.begin(a); + }, + // return the number of states currently on the stack + stateStackSize: function() { + return this.conditionStack.length; + }, + options: {}, + performAction: function(a, h, n, f) { + switch (n) { + case 0: + return 53; + case 1: + return 54; + case 2: + return 55; + case 3: + return 56; + case 4: + break; + case 5: + break; + case 6: + return this.begin("acc_title"), 31; + case 7: + return this.popState(), "acc_title_value"; + case 8: + return this.begin("acc_descr"), 33; + case 9: + return this.popState(), "acc_descr_value"; + case 10: + this.begin("acc_descr_multiline"); + break; + case 11: + this.popState(); + break; + case 12: + return "acc_descr_multiline_value"; + case 13: + return 8; + case 14: + break; + case 15: + return 7; + case 16: + return 7; + case 17: + return "EDGE_STATE"; + case 18: + this.begin("callback_name"); + break; + case 19: + this.popState(); + break; + case 20: + this.popState(), this.begin("callback_args"); + break; + case 21: + return 70; + case 22: + this.popState(); + break; + case 23: + return 71; + case 24: + this.popState(); + break; + case 25: + return "STR"; + case 26: + this.begin("string"); + break; + case 27: + return 73; + case 28: + return this.begin("namespace"), 40; + case 29: + return this.popState(), 8; + case 30: + break; + case 31: + return this.begin("namespace-body"), 37; + case 32: + return this.popState(), 39; + case 33: + return "EOF_IN_STRUCT"; + case 34: + return 8; + case 35: + break; + case 36: + return "EDGE_STATE"; + case 37: + return this.begin("class"), 44; + case 38: + return this.popState(), 8; + case 39: + break; + case 40: + return this.popState(), this.popState(), 39; + case 41: + return this.begin("class-body"), 37; + case 42: + return this.popState(), 39; + case 43: + return "EOF_IN_STRUCT"; + case 44: + return "EDGE_STATE"; + case 45: + return "OPEN_IN_STRUCT"; + case 46: + break; + case 47: + return "MEMBER"; + case 48: + return 76; + case 49: + return 66; + case 50: + return 67; + case 51: + return 69; + case 52: + return 50; + case 53: + return 52; + case 54: + return 45; + case 55: + return 46; + case 56: + return 72; + case 57: + this.popState(); + break; + case 58: + return "GENERICTYPE"; + case 59: + this.begin("generic"); + break; + case 60: + this.popState(); + break; + case 61: + return "BQUOTE_STR"; + case 62: + this.begin("bqstring"); + break; + case 63: + return 68; + case 64: + return 68; + case 65: + return 68; + case 66: + return 68; + case 67: + return 60; + case 68: + return 60; + case 69: + return 62; + case 70: + return 62; + case 71: + return 61; + case 72: + return 59; + case 73: + return 63; + case 74: + return 64; + case 75: + return 65; + case 76: + return 21; + case 77: + return 42; + case 78: + return 95; + case 79: + return "DOT"; + case 80: + return "PLUS"; + case 81: + return 81; + case 82: + return 78; + case 83: + return 84; + case 84: + return 84; + case 85: + return 85; + case 86: + return "EQUALS"; + case 87: + return "EQUALS"; + case 88: + return 74; + case 89: + return 12; + case 90: + return 14; + case 91: + return "PUNCTUATION"; + case 92: + return 80; + case 93: + return 97; + case 94: + return 83; + case 95: + return 83; + case 96: + return 9; + } + }, + rules: [/^(?:.*direction\s+TB[^\n]*)/, /^(?:.*direction\s+BT[^\n]*)/, /^(?:.*direction\s+RL[^\n]*)/, /^(?:.*direction\s+LR[^\n]*)/, /^(?:%%(?!\{)*[^\n]*(\r?\n?)+)/, /^(?:%%[^\n]*(\r?\n)*)/, /^(?:accTitle\s*:\s*)/, /^(?:(?!\n||)*[^\n]*)/, /^(?:accDescr\s*:\s*)/, /^(?:(?!\n||)*[^\n]*)/, /^(?:accDescr\s*\{\s*)/, /^(?:[\}])/, /^(?:[^\}]*)/, /^(?:\s*(\r?\n)+)/, /^(?:\s+)/, /^(?:classDiagram-v2\b)/, /^(?:classDiagram\b)/, /^(?:\[\*\])/, /^(?:call[\s]+)/, /^(?:\([\s]*\))/, /^(?:\()/, /^(?:[^(]*)/, /^(?:\))/, /^(?:[^)]*)/, /^(?:["])/, /^(?:[^"]*)/, /^(?:["])/, /^(?:style\b)/, /^(?:namespace\b)/, /^(?:\s*(\r?\n)+)/, /^(?:\s+)/, /^(?:[{])/, /^(?:[}])/, /^(?:$)/, /^(?:\s*(\r?\n)+)/, /^(?:\s+)/, /^(?:\[\*\])/, /^(?:class\b)/, /^(?:\s*(\r?\n)+)/, /^(?:\s+)/, /^(?:[}])/, /^(?:[{])/, /^(?:[}])/, /^(?:$)/, /^(?:\[\*\])/, /^(?:[{])/, /^(?:[\n])/, /^(?:[^{}\n]*)/, /^(?:cssClass\b)/, /^(?:callback\b)/, /^(?:link\b)/, /^(?:click\b)/, /^(?:note for\b)/, /^(?:note\b)/, /^(?:<<)/, /^(?:>>)/, /^(?:href\b)/, /^(?:[~])/, /^(?:[^~]*)/, /^(?:~)/, /^(?:[`])/, /^(?:[^`]+)/, /^(?:[`])/, /^(?:_self\b)/, /^(?:_blank\b)/, /^(?:_parent\b)/, /^(?:_top\b)/, /^(?:\s*<\|)/, /^(?:\s*\|>)/, /^(?:\s*>)/, /^(?:\s*<)/, /^(?:\s*\*)/, /^(?:\s*o\b)/, /^(?:\s*\(\))/, /^(?:--)/, /^(?:\.\.)/, /^(?::{1}[^:\n;]+)/, /^(?::{3})/, /^(?:-)/, /^(?:\.)/, /^(?:\+)/, /^(?::)/, /^(?:,)/, /^(?:#)/, /^(?:#)/, /^(?:%)/, /^(?:=)/, /^(?:=)/, /^(?:\w+)/, /^(?:\[)/, /^(?:\])/, /^(?:[!"#$%&'*+,-.`?\\/])/, /^(?:[0-9]+)/, /^(?:[\u00AA\u00B5\u00BA\u00C0-\u00D6\u00D8-\u00F6]|[\u00F8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377]|[\u037A-\u037D\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5]|[\u03F7-\u0481\u048A-\u0527\u0531-\u0556\u0559\u0561-\u0587\u05D0-\u05EA]|[\u05F0-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE]|[\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA]|[\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u08A0]|[\u08A2-\u08AC\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0977]|[\u0979-\u097F\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2]|[\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u0A05-\u0A0A]|[\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39]|[\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8]|[\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0B05-\u0B0C]|[\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C]|[\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99]|[\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0]|[\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C33\u0C35-\u0C39\u0C3D]|[\u0C58\u0C59\u0C60\u0C61\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3]|[\u0CB5-\u0CB9\u0CBD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D05-\u0D0C\u0D0E-\u0D10]|[\u0D12-\u0D3A\u0D3D\u0D4E\u0D60\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1]|[\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81]|[\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3]|[\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6]|[\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A]|[\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081]|[\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D]|[\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0]|[\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310]|[\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F4\u1401-\u166C]|[\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u1700-\u170C\u170E-\u1711]|[\u1720-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7]|[\u17DC\u1820-\u1877\u1880-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191C]|[\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19C1-\u19C7\u1A00-\u1A16]|[\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4B\u1B83-\u1BA0\u1BAE\u1BAF]|[\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1CE9-\u1CEC]|[\u1CEE-\u1CF1\u1CF5\u1CF6\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D]|[\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D]|[\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3]|[\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F]|[\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128]|[\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2183\u2184]|[\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3]|[\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6]|[\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE]|[\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005\u3006\u3031-\u3035\u303B\u303C]|[\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312D]|[\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FCC]|[\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B]|[\uA640-\uA66E\uA67F-\uA697\uA6A0-\uA6E5\uA717-\uA71F\uA722-\uA788]|[\uA78B-\uA78E\uA790-\uA793\uA7A0-\uA7AA\uA7F8-\uA801\uA803-\uA805]|[\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB]|[\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uAA00-\uAA28]|[\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA80-\uAAAF\uAAB1\uAAB5]|[\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4]|[\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E]|[\uABC0-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D]|[\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36]|[\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D]|[\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC]|[\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF]|[\uFFD2-\uFFD7\uFFDA-\uFFDC])/, /^(?:\s)/, /^(?:\s)/, /^(?:$)/], + conditions: { "namespace-body": { rules: [26, 32, 33, 34, 35, 36, 37, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], inclusive: !1 }, namespace: { rules: [26, 28, 29, 30, 31, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], inclusive: !1 }, "class-body": { rules: [26, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], inclusive: !1 }, class: { rules: [26, 38, 39, 40, 41, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], inclusive: !1 }, acc_descr_multiline: { rules: [11, 12, 26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], inclusive: !1 }, acc_descr: { rules: [9, 26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], inclusive: !1 }, acc_title: { rules: [7, 26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], inclusive: !1 }, callback_args: { rules: [22, 23, 26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], inclusive: !1 }, callback_name: { rules: [19, 20, 21, 26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], inclusive: !1 }, href: { rules: [26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], inclusive: !1 }, struct: { rules: [26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], inclusive: !1 }, generic: { rules: [26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], inclusive: !1 }, bqstring: { rules: [26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], inclusive: !1 }, string: { rules: [24, 25, 26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], inclusive: !1 }, INITIAL: { rules: [0, 1, 2, 3, 4, 5, 6, 8, 10, 13, 14, 15, 16, 17, 18, 26, 27, 28, 37, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96], inclusive: !0 } } + }; + return x; + }(); + Ne.lexer = et; + function Le() { + this.yy = {}; + } + return Le.prototype = Ne, Ne.Parser = Le, new Le(); +}(); +Ve.parser = Ve; +const zt = Ve, Qe = ["#", "+", "~", "-", ""]; +class Xe { + constructor(i, r) { + this.memberType = r, this.visibility = "", this.classifier = ""; + const l = ut(i, F()); + this.parseMember(l); + } + getDisplayDetails() { + let i = this.visibility + Re(this.id); + this.memberType === "method" && (i += `(${Re(this.parameters.trim())})`, this.returnType && (i += " : " + Re(this.returnType))), i = i.trim(); + const r = this.parseClassifier(); + return { + displayText: i, + cssStyle: r + }; + } + parseMember(i) { + let r = ""; + if (this.memberType === "method") { + const l = /([#+~-])?(.+)\((.*)\)([\s$*])?(.*)([$*])?/, o = i.match(l); + if (o) { + const A = o[1] ? o[1].trim() : ""; + if (Qe.includes(A) && (this.visibility = A), this.id = o[2].trim(), this.parameters = o[3] ? o[3].trim() : "", r = o[4] ? o[4].trim() : "", this.returnType = o[5] ? o[5].trim() : "", r === "") { + const g = this.returnType.substring(this.returnType.length - 1); + g.match(/[$*]/) && (r = g, this.returnType = this.returnType.substring(0, this.returnType.length - 1)); + } + } + } else { + const l = i.length, o = i.substring(0, 1), A = i.substring(l - 1); + Qe.includes(o) && (this.visibility = o), A.match(/[$*]/) && (r = A), this.id = i.substring( + this.visibility === "" ? 0 : 1, + r === "" ? l : l - 1 + ); + } + this.classifier = r; + } + parseClassifier() { + switch (this.classifier) { + case "*": + return "font-style:italic;"; + case "$": + return "text-decoration:underline;"; + default: + return ""; + } + } +} +const pe = "classId-"; +let Pe = [], p = {}, he = [], He = 0, O = {}, we = 0, K = []; +const V = (e) => v.sanitizeText(e, F()), w = function(e) { + const i = v.sanitizeText(e, F()); + let r = "", l = i; + if (i.indexOf("~") > 0) { + const o = i.split("~"); + l = V(o[0]), r = V(o[1]); + } + return { className: l, type: r }; +}, ft = function(e, i) { + const r = v.sanitizeText(e, F()); + i && (i = V(i)); + const { className: l } = w(r); + p[l].label = i; +}, Ae = function(e) { + const i = v.sanitizeText(e, F()), { className: r, type: l } = w(i); + if (Object.hasOwn(p, r)) + return; + const o = v.sanitizeText(r, F()); + p[o] = { + id: o, + type: l, + label: o, + cssClasses: [], + methods: [], + members: [], + annotations: [], + styles: [], + domId: pe + o + "-" + He + }, He++; +}, qe = function(e) { + const i = v.sanitizeText(e, F()); + if (i in p) + return p[i].domId; + throw new Error("Class not found: " + i); +}, dt = function() { + Pe = [], p = {}, he = [], K = [], K.push(Ze), O = {}, we = 0, At(); +}, Et = function(e) { + return p[e]; +}, Ct = function() { + return p; +}, mt = function() { + return Pe; +}, bt = function() { + return he; +}, gt = function(e) { + pt.debug("Adding relation: " + JSON.stringify(e)), Ae(e.id1), Ae(e.id2), e.id1 = w(e.id1).className, e.id2 = w(e.id2).className, e.relationTitle1 = v.sanitizeText(e.relationTitle1.trim(), F()), e.relationTitle2 = v.sanitizeText(e.relationTitle2.trim(), F()), Pe.push(e); +}, kt = function(e, i) { + const r = w(e).className; + p[r].annotations.push(i); +}, Je = function(e, i) { + Ae(e); + const r = w(e).className, l = p[r]; + if (typeof i == "string") { + const o = i.trim(); + o.startsWith("<<") && o.endsWith(">>") ? l.annotations.push(V(o.substring(2, o.length - 2))) : o.indexOf(")") > 0 ? l.methods.push(new Xe(o, "method")) : o && l.members.push(new Xe(o, "attribute")); + } +}, Tt = function(e, i) { + Array.isArray(i) && (i.reverse(), i.forEach((r) => Je(e, r))); +}, Ft = function(e, i) { + const r = { + id: `note${he.length}`, + class: i, + text: e + }; + he.push(r); +}, yt = function(e) { + return e.startsWith(":") && (e = e.substring(1)), V(e.trim()); +}, Me = function(e, i) { + e.split(",").forEach(function(r) { + let l = r; + r[0].match(/\d/) && (l = pe + l), p[l] !== void 0 && p[l].cssClasses.push(i); + }); +}, Dt = function(e, i) { + e.split(",").forEach(function(r) { + i !== void 0 && (p[r].tooltip = V(i)); + }); +}, Bt = function(e, i) { + return i ? O[i].classes[e].tooltip : p[e].tooltip; +}, _t = function(e, i, r) { + const l = F(); + e.split(",").forEach(function(o) { + let A = o; + o[0].match(/\d/) && (A = pe + A), p[A] !== void 0 && (p[A].link = We.formatUrl(i, l), l.securityLevel === "sandbox" ? p[A].linkTarget = "_top" : typeof r == "string" ? p[A].linkTarget = V(r) : p[A].linkTarget = "_blank"); + }), Me(e, "clickable"); +}, St = function(e, i, r) { + e.split(",").forEach(function(l) { + Nt(l, i, r), p[l].haveCallback = !0; + }), Me(e, "clickable"); +}, Nt = function(e, i, r) { + const l = v.sanitizeText(e, F()); + if (F().securityLevel !== "loose" || i === void 0) + return; + const A = l; + if (p[A] !== void 0) { + const g = qe(A); + let D = []; + if (typeof r == "string") { + D = r.split(/,(?=(?:(?:[^"]*"){2})*[^"]*$)/); + for (let B = 0; B < D.length; B++) { + let _ = D[B].trim(); + _.charAt(0) === '"' && _.charAt(_.length - 1) === '"' && (_ = _.substr(1, _.length - 2)), D[B] = _; + } + } + D.length === 0 && D.push(g), K.push(function() { + const B = document.querySelector(`[id="${g}"]`); + B !== null && B.addEventListener( + "click", + function() { + We.runFunc(i, ...D); + }, + !1 + ); + }); + } +}, Lt = function(e) { + K.forEach(function(i) { + i(e); + }); +}, vt = { + LINE: 0, + DOTTED_LINE: 1 +}, xt = { + AGGREGATION: 0, + EXTENSION: 1, + COMPOSITION: 2, + DEPENDENCY: 3, + LOLLIPOP: 4 +}, Ze = function(e) { + let i = z(".mermaidTooltip"); + (i._groups || i)[0][0] === null && (i = z("body").append("div").attr("class", "mermaidTooltip").style("opacity", 0)), z(e).select("svg").selectAll("g.node").on("mouseover", function() { + const o = z(this); + if (o.attr("title") === null) + return; + const g = this.getBoundingClientRect(); + i.transition().duration(200).style("opacity", ".9"), i.text(o.attr("title")).style("left", window.scrollX + g.left + (g.right - g.left) / 2 + "px").style("top", window.scrollY + g.top - 14 + document.body.scrollTop + "px"), i.html(i.html().replace(/<br\/>/g, "
    ")), o.classed("hover", !0); + }).on("mouseout", function() { + i.transition().duration(500).style("opacity", 0), z(this).classed("hover", !1); + }); +}; +K.push(Ze); +let $e = "TB"; +const Ot = () => $e, It = (e) => { + $e = e; +}, Rt = function(e) { + O[e] === void 0 && (O[e] = { + id: e, + classes: {}, + children: {}, + domId: pe + e + "-" + we + }, we++); +}, Vt = function(e) { + return O[e]; +}, wt = function() { + return O; +}, Pt = function(e, i) { + if (O[e] !== void 0) + for (const r of i) { + const { className: l } = w(r); + p[l].parent = e, O[e].classes[l] = p[l]; + } +}, Mt = function(e, i) { + const r = p[e]; + if (!(!i || !r)) + for (const l of i) + l.includes(",") ? r.styles.push(...l.split(",")) : r.styles.push(l); +}, Kt = { + setAccTitle: rt, + getAccTitle: at, + getAccDescription: lt, + setAccDescription: ct, + getConfig: () => F().class, + addClass: Ae, + bindFunctions: Lt, + clear: dt, + getClass: Et, + getClasses: Ct, + getNotes: bt, + addAnnotation: kt, + addNote: Ft, + getRelations: mt, + addRelation: gt, + getDirection: Ot, + setDirection: It, + addMember: Je, + addMembers: Tt, + cleanupLabel: yt, + lineType: vt, + relationType: xt, + setClickEvent: St, + setCssClass: Me, + setLink: _t, + getTooltip: Bt, + setTooltip: Dt, + lookUpDomId: qe, + setDiagramTitle: ot, + getDiagramTitle: ht, + setClassLabel: ft, + addNamespace: Rt, + addClassesToNamespace: Pt, + getNamespace: Vt, + getNamespaces: wt, + setCssStyle: Mt +}, Gt = (e) => `g.classGroup text { + fill: ${e.nodeBorder || e.classText}; + stroke: none; + font-family: ${e.fontFamily}; + font-size: 10px; + + .title { + font-weight: bolder; + } + +} + +.nodeLabel, .edgeLabel { + color: ${e.classText}; +} +.edgeLabel .label rect { + fill: ${e.mainBkg}; +} +.label text { + fill: ${e.classText}; +} +.edgeLabel .label span { + background: ${e.mainBkg}; +} + +.classTitle { + font-weight: bolder; +} +.node rect, + .node circle, + .node ellipse, + .node polygon, + .node path { + fill: ${e.mainBkg}; + stroke: ${e.nodeBorder}; + stroke-width: 1px; + } + + +.divider { + stroke: ${e.nodeBorder}; + stroke-width: 1; +} + +g.clickable { + cursor: pointer; +} + +g.classGroup rect { + fill: ${e.mainBkg}; + stroke: ${e.nodeBorder}; +} + +g.classGroup line { + stroke: ${e.nodeBorder}; + stroke-width: 1; +} + +.classLabel .box { + stroke: none; + stroke-width: 0; + fill: ${e.mainBkg}; + opacity: 0.5; +} + +.classLabel .label { + fill: ${e.nodeBorder}; + font-size: 10px; +} + +.relation { + stroke: ${e.lineColor}; + stroke-width: 1; + fill: none; +} + +.dashed-line{ + stroke-dasharray: 3; +} + +.dotted-line{ + stroke-dasharray: 1 2; +} + +#compositionStart, .composition { + fill: ${e.lineColor} !important; + stroke: ${e.lineColor} !important; + stroke-width: 1; +} + +#compositionEnd, .composition { + fill: ${e.lineColor} !important; + stroke: ${e.lineColor} !important; + stroke-width: 1; +} + +#dependencyStart, .dependency { + fill: ${e.lineColor} !important; + stroke: ${e.lineColor} !important; + stroke-width: 1; +} + +#dependencyStart, .dependency { + fill: ${e.lineColor} !important; + stroke: ${e.lineColor} !important; + stroke-width: 1; +} + +#extensionStart, .extension { + fill: transparent !important; + stroke: ${e.lineColor} !important; + stroke-width: 1; +} + +#extensionEnd, .extension { + fill: transparent !important; + stroke: ${e.lineColor} !important; + stroke-width: 1; +} + +#aggregationStart, .aggregation { + fill: transparent !important; + stroke: ${e.lineColor} !important; + stroke-width: 1; +} + +#aggregationEnd, .aggregation { + fill: transparent !important; + stroke: ${e.lineColor} !important; + stroke-width: 1; +} + +#lollipopStart, .lollipop { + fill: ${e.mainBkg} !important; + stroke: ${e.lineColor} !important; + stroke-width: 1; +} + +#lollipopEnd, .lollipop { + fill: ${e.mainBkg} !important; + stroke: ${e.lineColor} !important; + stroke-width: 1; +} + +.edgeTerminals { + font-size: 11px; + line-height: initial; +} + +.classTitleText { + text-anchor: middle; + font-size: 18px; + fill: ${e.textColor}; +} +`, Yt = Gt; +export { + Kt as d, + zt as p, + Yt as s +}; diff --git a/0.6.0/js/mermaid/styles-36a1a2e8.js b/0.6.0/js/mermaid/styles-36a1a2e8.js new file mode 100644 index 0000000..6210fed --- /dev/null +++ b/0.6.0/js/mermaid/styles-36a1a2e8.js @@ -0,0 +1,1483 @@ +import { d as sanitizeText$1, c as getConfig, G as parseGenericTypes, s as setAccTitle, g as getAccTitle, a as getAccDescription, b as setAccDescription, C as setDiagramTitle, D as getDiagramTitle, f as common, E as clear$1, l as log, A as utils, j as d3select } from "./mermaid-dcacb631.js"; +var parser = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 17], $V1 = [1, 18], $V2 = [1, 19], $V3 = [1, 39], $V4 = [1, 40], $V5 = [1, 25], $V6 = [1, 23], $V7 = [1, 24], $V8 = [1, 31], $V9 = [1, 32], $Va = [1, 33], $Vb = [1, 34], $Vc = [1, 35], $Vd = [1, 36], $Ve = [1, 26], $Vf = [1, 27], $Vg = [1, 28], $Vh = [1, 29], $Vi = [1, 43], $Vj = [1, 30], $Vk = [1, 42], $Vl = [1, 44], $Vm = [1, 41], $Vn = [1, 45], $Vo = [1, 9], $Vp = [1, 8, 9], $Vq = [1, 56], $Vr = [1, 57], $Vs = [1, 58], $Vt = [1, 59], $Vu = [1, 60], $Vv = [1, 61], $Vw = [1, 62], $Vx = [1, 8, 9, 39], $Vy = [1, 74], $Vz = [1, 8, 9, 12, 13, 21, 37, 39, 42, 59, 60, 61, 62, 63, 64, 65, 70, 72], $VA = [1, 8, 9, 12, 13, 19, 21, 37, 39, 42, 46, 59, 60, 61, 62, 63, 64, 65, 70, 72, 74, 80, 95, 97, 98], $VB = [13, 74, 80, 95, 97, 98], $VC = [13, 64, 65, 74, 80, 95, 97, 98], $VD = [13, 59, 60, 61, 62, 63, 74, 80, 95, 97, 98], $VE = [1, 93], $VF = [1, 110], $VG = [1, 108], $VH = [1, 102], $VI = [1, 103], $VJ = [1, 104], $VK = [1, 105], $VL = [1, 106], $VM = [1, 107], $VN = [1, 109], $VO = [1, 8, 9, 37, 39, 42], $VP = [1, 8, 9, 21], $VQ = [1, 8, 9, 78], $VR = [1, 8, 9, 21, 73, 74, 78, 80, 81, 82, 83, 84, 85]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "mermaidDoc": 4, "statements": 5, "graphConfig": 6, "CLASS_DIAGRAM": 7, "NEWLINE": 8, "EOF": 9, "statement": 10, "classLabel": 11, "SQS": 12, "STR": 13, "SQE": 14, "namespaceName": 15, "alphaNumToken": 16, "className": 17, "classLiteralName": 18, "GENERICTYPE": 19, "relationStatement": 20, "LABEL": 21, "namespaceStatement": 22, "classStatement": 23, "memberStatement": 24, "annotationStatement": 25, "clickStatement": 26, "styleStatement": 27, "cssClassStatement": 28, "noteStatement": 29, "direction": 30, "acc_title": 31, "acc_title_value": 32, "acc_descr": 33, "acc_descr_value": 34, "acc_descr_multiline_value": 35, "namespaceIdentifier": 36, "STRUCT_START": 37, "classStatements": 38, "STRUCT_STOP": 39, "NAMESPACE": 40, "classIdentifier": 41, "STYLE_SEPARATOR": 42, "members": 43, "CLASS": 44, "ANNOTATION_START": 45, "ANNOTATION_END": 46, "MEMBER": 47, "SEPARATOR": 48, "relation": 49, "NOTE_FOR": 50, "noteText": 51, "NOTE": 52, "direction_tb": 53, "direction_bt": 54, "direction_rl": 55, "direction_lr": 56, "relationType": 57, "lineType": 58, "AGGREGATION": 59, "EXTENSION": 60, "COMPOSITION": 61, "DEPENDENCY": 62, "LOLLIPOP": 63, "LINE": 64, "DOTTED_LINE": 65, "CALLBACK": 66, "LINK": 67, "LINK_TARGET": 68, "CLICK": 69, "CALLBACK_NAME": 70, "CALLBACK_ARGS": 71, "HREF": 72, "STYLE": 73, "ALPHA": 74, "stylesOpt": 75, "CSSCLASS": 76, "style": 77, "COMMA": 78, "styleComponent": 79, "NUM": 80, "COLON": 81, "UNIT": 82, "SPACE": 83, "BRKT": 84, "PCT": 85, "commentToken": 86, "textToken": 87, "graphCodeTokens": 88, "textNoTagsToken": 89, "TAGSTART": 90, "TAGEND": 91, "==": 92, "--": 93, "DEFAULT": 94, "MINUS": 95, "keywords": 96, "UNICODE_TEXT": 97, "BQUOTE_STR": 98, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 7: "CLASS_DIAGRAM", 8: "NEWLINE", 9: "EOF", 12: "SQS", 13: "STR", 14: "SQE", 19: "GENERICTYPE", 21: "LABEL", 31: "acc_title", 32: "acc_title_value", 33: "acc_descr", 34: "acc_descr_value", 35: "acc_descr_multiline_value", 37: "STRUCT_START", 39: "STRUCT_STOP", 40: "NAMESPACE", 42: "STYLE_SEPARATOR", 44: "CLASS", 45: "ANNOTATION_START", 46: "ANNOTATION_END", 47: "MEMBER", 48: "SEPARATOR", 50: "NOTE_FOR", 52: "NOTE", 53: "direction_tb", 54: "direction_bt", 55: "direction_rl", 56: "direction_lr", 59: "AGGREGATION", 60: "EXTENSION", 61: "COMPOSITION", 62: "DEPENDENCY", 63: "LOLLIPOP", 64: "LINE", 65: "DOTTED_LINE", 66: "CALLBACK", 67: "LINK", 68: "LINK_TARGET", 69: "CLICK", 70: "CALLBACK_NAME", 71: "CALLBACK_ARGS", 72: "HREF", 73: "STYLE", 74: "ALPHA", 76: "CSSCLASS", 78: "COMMA", 80: "NUM", 81: "COLON", 82: "UNIT", 83: "SPACE", 84: "BRKT", 85: "PCT", 88: "graphCodeTokens", 90: "TAGSTART", 91: "TAGEND", 92: "==", 93: "--", 94: "DEFAULT", 95: "MINUS", 96: "keywords", 97: "UNICODE_TEXT", 98: "BQUOTE_STR" }, + productions_: [0, [3, 1], [3, 1], [4, 1], [6, 4], [5, 1], [5, 2], [5, 3], [11, 3], [15, 1], [15, 2], [17, 1], [17, 1], [17, 2], [17, 2], [17, 2], [10, 1], [10, 2], [10, 1], [10, 1], [10, 1], [10, 1], [10, 1], [10, 1], [10, 1], [10, 1], [10, 1], [10, 2], [10, 2], [10, 1], [22, 4], [22, 5], [36, 2], [38, 1], [38, 2], [38, 3], [23, 1], [23, 3], [23, 4], [23, 6], [41, 2], [41, 3], [25, 4], [43, 1], [43, 2], [24, 1], [24, 2], [24, 1], [24, 1], [20, 3], [20, 4], [20, 4], [20, 5], [29, 3], [29, 2], [30, 1], [30, 1], [30, 1], [30, 1], [49, 3], [49, 2], [49, 2], [49, 1], [57, 1], [57, 1], [57, 1], [57, 1], [57, 1], [58, 1], [58, 1], [26, 3], [26, 4], [26, 3], [26, 4], [26, 4], [26, 5], [26, 3], [26, 4], [26, 4], [26, 5], [26, 4], [26, 5], [26, 5], [26, 6], [27, 3], [28, 3], [75, 1], [75, 3], [77, 1], [77, 2], [79, 1], [79, 1], [79, 1], [79, 1], [79, 1], [79, 1], [79, 1], [79, 1], [79, 1], [86, 1], [86, 1], [87, 1], [87, 1], [87, 1], [87, 1], [87, 1], [87, 1], [87, 1], [89, 1], [89, 1], [89, 1], [89, 1], [16, 1], [16, 1], [16, 1], [16, 1], [18, 1], [51, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 8: + this.$ = $$[$0 - 1]; + break; + case 9: + case 11: + case 12: + this.$ = $$[$0]; + break; + case 10: + case 13: + this.$ = $$[$0 - 1] + $$[$0]; + break; + case 14: + case 15: + this.$ = $$[$0 - 1] + "~" + $$[$0] + "~"; + break; + case 16: + yy.addRelation($$[$0]); + break; + case 17: + $$[$0 - 1].title = yy.cleanupLabel($$[$0]); + yy.addRelation($$[$0 - 1]); + break; + case 27: + this.$ = $$[$0].trim(); + yy.setAccTitle(this.$); + break; + case 28: + case 29: + this.$ = $$[$0].trim(); + yy.setAccDescription(this.$); + break; + case 30: + yy.addClassesToNamespace($$[$0 - 3], $$[$0 - 1]); + break; + case 31: + yy.addClassesToNamespace($$[$0 - 4], $$[$0 - 1]); + break; + case 32: + this.$ = $$[$0]; + yy.addNamespace($$[$0]); + break; + case 33: + this.$ = [$$[$0]]; + break; + case 34: + this.$ = [$$[$0 - 1]]; + break; + case 35: + $$[$0].unshift($$[$0 - 2]); + this.$ = $$[$0]; + break; + case 37: + yy.setCssClass($$[$0 - 2], $$[$0]); + break; + case 38: + yy.addMembers($$[$0 - 3], $$[$0 - 1]); + break; + case 39: + yy.setCssClass($$[$0 - 5], $$[$0 - 3]); + yy.addMembers($$[$0 - 5], $$[$0 - 1]); + break; + case 40: + this.$ = $$[$0]; + yy.addClass($$[$0]); + break; + case 41: + this.$ = $$[$0 - 1]; + yy.addClass($$[$0 - 1]); + yy.setClassLabel($$[$0 - 1], $$[$0]); + break; + case 42: + yy.addAnnotation($$[$0], $$[$0 - 2]); + break; + case 43: + this.$ = [$$[$0]]; + break; + case 44: + $$[$0].push($$[$0 - 1]); + this.$ = $$[$0]; + break; + case 45: + break; + case 46: + yy.addMember($$[$0 - 1], yy.cleanupLabel($$[$0])); + break; + case 47: + break; + case 48: + break; + case 49: + this.$ = { "id1": $$[$0 - 2], "id2": $$[$0], relation: $$[$0 - 1], relationTitle1: "none", relationTitle2: "none" }; + break; + case 50: + this.$ = { id1: $$[$0 - 3], id2: $$[$0], relation: $$[$0 - 1], relationTitle1: $$[$0 - 2], relationTitle2: "none" }; + break; + case 51: + this.$ = { id1: $$[$0 - 3], id2: $$[$0], relation: $$[$0 - 2], relationTitle1: "none", relationTitle2: $$[$0 - 1] }; + break; + case 52: + this.$ = { id1: $$[$0 - 4], id2: $$[$0], relation: $$[$0 - 2], relationTitle1: $$[$0 - 3], relationTitle2: $$[$0 - 1] }; + break; + case 53: + yy.addNote($$[$0], $$[$0 - 1]); + break; + case 54: + yy.addNote($$[$0]); + break; + case 55: + yy.setDirection("TB"); + break; + case 56: + yy.setDirection("BT"); + break; + case 57: + yy.setDirection("RL"); + break; + case 58: + yy.setDirection("LR"); + break; + case 59: + this.$ = { type1: $$[$0 - 2], type2: $$[$0], lineType: $$[$0 - 1] }; + break; + case 60: + this.$ = { type1: "none", type2: $$[$0], lineType: $$[$0 - 1] }; + break; + case 61: + this.$ = { type1: $$[$0 - 1], type2: "none", lineType: $$[$0] }; + break; + case 62: + this.$ = { type1: "none", type2: "none", lineType: $$[$0] }; + break; + case 63: + this.$ = yy.relationType.AGGREGATION; + break; + case 64: + this.$ = yy.relationType.EXTENSION; + break; + case 65: + this.$ = yy.relationType.COMPOSITION; + break; + case 66: + this.$ = yy.relationType.DEPENDENCY; + break; + case 67: + this.$ = yy.relationType.LOLLIPOP; + break; + case 68: + this.$ = yy.lineType.LINE; + break; + case 69: + this.$ = yy.lineType.DOTTED_LINE; + break; + case 70: + case 76: + this.$ = $$[$0 - 2]; + yy.setClickEvent($$[$0 - 1], $$[$0]); + break; + case 71: + case 77: + this.$ = $$[$0 - 3]; + yy.setClickEvent($$[$0 - 2], $$[$0 - 1]); + yy.setTooltip($$[$0 - 2], $$[$0]); + break; + case 72: + this.$ = $$[$0 - 2]; + yy.setLink($$[$0 - 1], $$[$0]); + break; + case 73: + this.$ = $$[$0 - 3]; + yy.setLink($$[$0 - 2], $$[$0 - 1], $$[$0]); + break; + case 74: + this.$ = $$[$0 - 3]; + yy.setLink($$[$0 - 2], $$[$0 - 1]); + yy.setTooltip($$[$0 - 2], $$[$0]); + break; + case 75: + this.$ = $$[$0 - 4]; + yy.setLink($$[$0 - 3], $$[$0 - 2], $$[$0]); + yy.setTooltip($$[$0 - 3], $$[$0 - 1]); + break; + case 78: + this.$ = $$[$0 - 3]; + yy.setClickEvent($$[$0 - 2], $$[$0 - 1], $$[$0]); + break; + case 79: + this.$ = $$[$0 - 4]; + yy.setClickEvent($$[$0 - 3], $$[$0 - 2], $$[$0 - 1]); + yy.setTooltip($$[$0 - 3], $$[$0]); + break; + case 80: + this.$ = $$[$0 - 3]; + yy.setLink($$[$0 - 2], $$[$0]); + break; + case 81: + this.$ = $$[$0 - 4]; + yy.setLink($$[$0 - 3], $$[$0 - 1], $$[$0]); + break; + case 82: + this.$ = $$[$0 - 4]; + yy.setLink($$[$0 - 3], $$[$0 - 1]); + yy.setTooltip($$[$0 - 3], $$[$0]); + break; + case 83: + this.$ = $$[$0 - 5]; + yy.setLink($$[$0 - 4], $$[$0 - 2], $$[$0]); + yy.setTooltip($$[$0 - 4], $$[$0 - 1]); + break; + case 84: + this.$ = $$[$0 - 2]; + yy.setCssStyle($$[$0 - 1], $$[$0]); + break; + case 85: + yy.setCssClass($$[$0 - 1], $$[$0]); + break; + case 86: + this.$ = [$$[$0]]; + break; + case 87: + $$[$0 - 2].push($$[$0]); + this.$ = $$[$0 - 2]; + break; + case 89: + this.$ = $$[$0 - 1] + $$[$0]; + break; + } + }, + table: [{ 3: 1, 4: 2, 5: 3, 6: 4, 7: [1, 6], 10: 5, 16: 37, 17: 20, 18: 38, 20: 7, 22: 8, 23: 9, 24: 10, 25: 11, 26: 12, 27: 13, 28: 14, 29: 15, 30: 16, 31: $V0, 33: $V1, 35: $V2, 36: 21, 40: $V3, 41: 22, 44: $V4, 45: $V5, 47: $V6, 48: $V7, 50: $V8, 52: $V9, 53: $Va, 54: $Vb, 55: $Vc, 56: $Vd, 66: $Ve, 67: $Vf, 69: $Vg, 73: $Vh, 74: $Vi, 76: $Vj, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, { 1: [3] }, { 1: [2, 1] }, { 1: [2, 2] }, { 1: [2, 3] }, o($Vo, [2, 5], { 8: [1, 46] }), { 8: [1, 47] }, o($Vp, [2, 16], { 21: [1, 48] }), o($Vp, [2, 18]), o($Vp, [2, 19]), o($Vp, [2, 20]), o($Vp, [2, 21]), o($Vp, [2, 22]), o($Vp, [2, 23]), o($Vp, [2, 24]), o($Vp, [2, 25]), o($Vp, [2, 26]), { 32: [1, 49] }, { 34: [1, 50] }, o($Vp, [2, 29]), o($Vp, [2, 45], { 49: 51, 57: 54, 58: 55, 13: [1, 52], 21: [1, 53], 59: $Vq, 60: $Vr, 61: $Vs, 62: $Vt, 63: $Vu, 64: $Vv, 65: $Vw }), { 37: [1, 63] }, o($Vx, [2, 36], { 37: [1, 65], 42: [1, 64] }), o($Vp, [2, 47]), o($Vp, [2, 48]), { 16: 66, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm }, { 16: 37, 17: 67, 18: 38, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, { 16: 37, 17: 68, 18: 38, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, { 16: 37, 17: 69, 18: 38, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, { 74: [1, 70] }, { 13: [1, 71] }, { 16: 37, 17: 72, 18: 38, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, { 13: $Vy, 51: 73 }, o($Vp, [2, 55]), o($Vp, [2, 56]), o($Vp, [2, 57]), o($Vp, [2, 58]), o($Vz, [2, 11], { 16: 37, 18: 38, 17: 75, 19: [1, 76], 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }), o($Vz, [2, 12], { 19: [1, 77] }), { 15: 78, 16: 79, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm }, { 16: 37, 17: 80, 18: 38, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, o($VA, [2, 112]), o($VA, [2, 113]), o($VA, [2, 114]), o($VA, [2, 115]), o([1, 8, 9, 12, 13, 19, 21, 37, 39, 42, 59, 60, 61, 62, 63, 64, 65, 70, 72], [2, 116]), o($Vo, [2, 6], { 10: 5, 20: 7, 22: 8, 23: 9, 24: 10, 25: 11, 26: 12, 27: 13, 28: 14, 29: 15, 30: 16, 17: 20, 36: 21, 41: 22, 16: 37, 18: 38, 5: 81, 31: $V0, 33: $V1, 35: $V2, 40: $V3, 44: $V4, 45: $V5, 47: $V6, 48: $V7, 50: $V8, 52: $V9, 53: $Va, 54: $Vb, 55: $Vc, 56: $Vd, 66: $Ve, 67: $Vf, 69: $Vg, 73: $Vh, 74: $Vi, 76: $Vj, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }), { 5: 82, 10: 5, 16: 37, 17: 20, 18: 38, 20: 7, 22: 8, 23: 9, 24: 10, 25: 11, 26: 12, 27: 13, 28: 14, 29: 15, 30: 16, 31: $V0, 33: $V1, 35: $V2, 36: 21, 40: $V3, 41: 22, 44: $V4, 45: $V5, 47: $V6, 48: $V7, 50: $V8, 52: $V9, 53: $Va, 54: $Vb, 55: $Vc, 56: $Vd, 66: $Ve, 67: $Vf, 69: $Vg, 73: $Vh, 74: $Vi, 76: $Vj, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, o($Vp, [2, 17]), o($Vp, [2, 27]), o($Vp, [2, 28]), { 13: [1, 84], 16: 37, 17: 83, 18: 38, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, { 49: 85, 57: 54, 58: 55, 59: $Vq, 60: $Vr, 61: $Vs, 62: $Vt, 63: $Vu, 64: $Vv, 65: $Vw }, o($Vp, [2, 46]), { 58: 86, 64: $Vv, 65: $Vw }, o($VB, [2, 62], { 57: 87, 59: $Vq, 60: $Vr, 61: $Vs, 62: $Vt, 63: $Vu }), o($VC, [2, 63]), o($VC, [2, 64]), o($VC, [2, 65]), o($VC, [2, 66]), o($VC, [2, 67]), o($VD, [2, 68]), o($VD, [2, 69]), { 8: [1, 89], 23: 90, 38: 88, 41: 22, 44: $V4 }, { 16: 91, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm }, { 43: 92, 47: $VE }, { 46: [1, 94] }, { 13: [1, 95] }, { 13: [1, 96] }, { 70: [1, 97], 72: [1, 98] }, { 21: $VF, 73: $VG, 74: $VH, 75: 99, 77: 100, 79: 101, 80: $VI, 81: $VJ, 82: $VK, 83: $VL, 84: $VM, 85: $VN }, { 74: [1, 111] }, { 13: $Vy, 51: 112 }, o($Vp, [2, 54]), o($Vp, [2, 117]), o($Vz, [2, 13]), o($Vz, [2, 14]), o($Vz, [2, 15]), { 37: [2, 32] }, { 15: 113, 16: 79, 37: [2, 9], 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm }, o($VO, [2, 40], { 11: 114, 12: [1, 115] }), o($Vo, [2, 7]), { 9: [1, 116] }, o($VP, [2, 49]), { 16: 37, 17: 117, 18: 38, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, { 13: [1, 119], 16: 37, 17: 118, 18: 38, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, o($VB, [2, 61], { 57: 120, 59: $Vq, 60: $Vr, 61: $Vs, 62: $Vt, 63: $Vu }), o($VB, [2, 60]), { 39: [1, 121] }, { 23: 90, 38: 122, 41: 22, 44: $V4 }, { 8: [1, 123], 39: [2, 33] }, o($Vx, [2, 37], { 37: [1, 124] }), { 39: [1, 125] }, { 39: [2, 43], 43: 126, 47: $VE }, { 16: 37, 17: 127, 18: 38, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, o($Vp, [2, 70], { 13: [1, 128] }), o($Vp, [2, 72], { 13: [1, 130], 68: [1, 129] }), o($Vp, [2, 76], { 13: [1, 131], 71: [1, 132] }), { 13: [1, 133] }, o($Vp, [2, 84], { 78: [1, 134] }), o($VQ, [2, 86], { 79: 135, 21: $VF, 73: $VG, 74: $VH, 80: $VI, 81: $VJ, 82: $VK, 83: $VL, 84: $VM, 85: $VN }), o($VR, [2, 88]), o($VR, [2, 90]), o($VR, [2, 91]), o($VR, [2, 92]), o($VR, [2, 93]), o($VR, [2, 94]), o($VR, [2, 95]), o($VR, [2, 96]), o($VR, [2, 97]), o($VR, [2, 98]), o($Vp, [2, 85]), o($Vp, [2, 53]), { 37: [2, 10] }, o($VO, [2, 41]), { 13: [1, 136] }, { 1: [2, 4] }, o($VP, [2, 51]), o($VP, [2, 50]), { 16: 37, 17: 137, 18: 38, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, o($VB, [2, 59]), o($Vp, [2, 30]), { 39: [1, 138] }, { 23: 90, 38: 139, 39: [2, 34], 41: 22, 44: $V4 }, { 43: 140, 47: $VE }, o($Vx, [2, 38]), { 39: [2, 44] }, o($Vp, [2, 42]), o($Vp, [2, 71]), o($Vp, [2, 73]), o($Vp, [2, 74], { 68: [1, 141] }), o($Vp, [2, 77]), o($Vp, [2, 78], { 13: [1, 142] }), o($Vp, [2, 80], { 13: [1, 144], 68: [1, 143] }), { 21: $VF, 73: $VG, 74: $VH, 77: 145, 79: 101, 80: $VI, 81: $VJ, 82: $VK, 83: $VL, 84: $VM, 85: $VN }, o($VR, [2, 89]), { 14: [1, 146] }, o($VP, [2, 52]), o($Vp, [2, 31]), { 39: [2, 35] }, { 39: [1, 147] }, o($Vp, [2, 75]), o($Vp, [2, 79]), o($Vp, [2, 81]), o($Vp, [2, 82], { 68: [1, 148] }), o($VQ, [2, 87], { 79: 135, 21: $VF, 73: $VG, 74: $VH, 80: $VI, 81: $VJ, 82: $VK, 83: $VL, 84: $VM, 85: $VN }), o($VO, [2, 8]), o($Vx, [2, 39]), o($Vp, [2, 83])], + defaultActions: { 2: [2, 1], 3: [2, 2], 4: [2, 3], 78: [2, 32], 113: [2, 10], 116: [2, 4], 126: [2, 44], 139: [2, 35] }, + parseError: function parseError(str, hash) { + if (hash.recoverable) { + this.trace(str); + } else { + var error = new Error(str); + error.hash = hash; + throw error; + } + }, + parse: function parse(input) { + var self = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex() { + var token; + token = tstack.pop() || lexer2.lex() || EOF; + if (typeof token !== "number") { + if (token instanceof Array) { + tstack = token; + token = tstack.pop(); + } + token = self.symbols_[token] || token; + } + return token; + } + var symbol, state, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state = stack[stack.length - 1]; + if (this.defaultActions[state]) { + action = this.defaultActions[state]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex(); + } + action = table[state] && table[state][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str, hash); + } else { + throw new Error(str); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch = this._input[0]; + this.yytext += ch; + this.yyleng++; + this.offset++; + this.match += ch; + this.matched += ch; + var lines = ch.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch; + }, + // unshifts one char (or a string) into the input + unput: function(ch) { + var len = ch.length; + var lines = ch.split(/(?:\r\n?|\n)/g); + this._input = ch + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next = this.match; + if (next.length < 20) { + next += this._input.substr(0, 20 - next.length); + } + return (next.substr(0, 20) + (next.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token) { + return token; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token, match, tempMatch, index; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i = 0; i < rules.length; i++) { + tempMatch = this._input.match(this.rules[rules[i]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index = i; + if (this.options.backtrack_lexer) { + token = this.test_match(tempMatch, rules[i]); + if (token !== false) { + return token; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token = this.test_match(match, rules[index]); + if (token !== false) { + return token; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: {}, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + return 53; + case 1: + return 54; + case 2: + return 55; + case 3: + return 56; + case 4: + break; + case 5: + break; + case 6: + this.begin("acc_title"); + return 31; + case 7: + this.popState(); + return "acc_title_value"; + case 8: + this.begin("acc_descr"); + return 33; + case 9: + this.popState(); + return "acc_descr_value"; + case 10: + this.begin("acc_descr_multiline"); + break; + case 11: + this.popState(); + break; + case 12: + return "acc_descr_multiline_value"; + case 13: + return 8; + case 14: + break; + case 15: + return 7; + case 16: + return 7; + case 17: + return "EDGE_STATE"; + case 18: + this.begin("callback_name"); + break; + case 19: + this.popState(); + break; + case 20: + this.popState(); + this.begin("callback_args"); + break; + case 21: + return 70; + case 22: + this.popState(); + break; + case 23: + return 71; + case 24: + this.popState(); + break; + case 25: + return "STR"; + case 26: + this.begin("string"); + break; + case 27: + return 73; + case 28: + this.begin("namespace"); + return 40; + case 29: + this.popState(); + return 8; + case 30: + break; + case 31: + this.begin("namespace-body"); + return 37; + case 32: + this.popState(); + return 39; + case 33: + return "EOF_IN_STRUCT"; + case 34: + return 8; + case 35: + break; + case 36: + return "EDGE_STATE"; + case 37: + this.begin("class"); + return 44; + case 38: + this.popState(); + return 8; + case 39: + break; + case 40: + this.popState(); + this.popState(); + return 39; + case 41: + this.begin("class-body"); + return 37; + case 42: + this.popState(); + return 39; + case 43: + return "EOF_IN_STRUCT"; + case 44: + return "EDGE_STATE"; + case 45: + return "OPEN_IN_STRUCT"; + case 46: + break; + case 47: + return "MEMBER"; + case 48: + return 76; + case 49: + return 66; + case 50: + return 67; + case 51: + return 69; + case 52: + return 50; + case 53: + return 52; + case 54: + return 45; + case 55: + return 46; + case 56: + return 72; + case 57: + this.popState(); + break; + case 58: + return "GENERICTYPE"; + case 59: + this.begin("generic"); + break; + case 60: + this.popState(); + break; + case 61: + return "BQUOTE_STR"; + case 62: + this.begin("bqstring"); + break; + case 63: + return 68; + case 64: + return 68; + case 65: + return 68; + case 66: + return 68; + case 67: + return 60; + case 68: + return 60; + case 69: + return 62; + case 70: + return 62; + case 71: + return 61; + case 72: + return 59; + case 73: + return 63; + case 74: + return 64; + case 75: + return 65; + case 76: + return 21; + case 77: + return 42; + case 78: + return 95; + case 79: + return "DOT"; + case 80: + return "PLUS"; + case 81: + return 81; + case 82: + return 78; + case 83: + return 84; + case 84: + return 84; + case 85: + return 85; + case 86: + return "EQUALS"; + case 87: + return "EQUALS"; + case 88: + return 74; + case 89: + return 12; + case 90: + return 14; + case 91: + return "PUNCTUATION"; + case 92: + return 80; + case 93: + return 97; + case 94: + return 83; + case 95: + return 83; + case 96: + return 9; + } + }, + rules: [/^(?:.*direction\s+TB[^\n]*)/, /^(?:.*direction\s+BT[^\n]*)/, /^(?:.*direction\s+RL[^\n]*)/, /^(?:.*direction\s+LR[^\n]*)/, /^(?:%%(?!\{)*[^\n]*(\r?\n?)+)/, /^(?:%%[^\n]*(\r?\n)*)/, /^(?:accTitle\s*:\s*)/, /^(?:(?!\n||)*[^\n]*)/, /^(?:accDescr\s*:\s*)/, /^(?:(?!\n||)*[^\n]*)/, /^(?:accDescr\s*\{\s*)/, /^(?:[\}])/, /^(?:[^\}]*)/, /^(?:\s*(\r?\n)+)/, /^(?:\s+)/, /^(?:classDiagram-v2\b)/, /^(?:classDiagram\b)/, /^(?:\[\*\])/, /^(?:call[\s]+)/, /^(?:\([\s]*\))/, /^(?:\()/, /^(?:[^(]*)/, /^(?:\))/, /^(?:[^)]*)/, /^(?:["])/, /^(?:[^"]*)/, /^(?:["])/, /^(?:style\b)/, /^(?:namespace\b)/, /^(?:\s*(\r?\n)+)/, /^(?:\s+)/, /^(?:[{])/, /^(?:[}])/, /^(?:$)/, /^(?:\s*(\r?\n)+)/, /^(?:\s+)/, /^(?:\[\*\])/, /^(?:class\b)/, /^(?:\s*(\r?\n)+)/, /^(?:\s+)/, /^(?:[}])/, /^(?:[{])/, /^(?:[}])/, /^(?:$)/, /^(?:\[\*\])/, /^(?:[{])/, /^(?:[\n])/, /^(?:[^{}\n]*)/, /^(?:cssClass\b)/, /^(?:callback\b)/, /^(?:link\b)/, /^(?:click\b)/, /^(?:note for\b)/, /^(?:note\b)/, /^(?:<<)/, /^(?:>>)/, /^(?:href\b)/, /^(?:[~])/, /^(?:[^~]*)/, /^(?:~)/, /^(?:[`])/, /^(?:[^`]+)/, /^(?:[`])/, /^(?:_self\b)/, /^(?:_blank\b)/, /^(?:_parent\b)/, /^(?:_top\b)/, /^(?:\s*<\|)/, /^(?:\s*\|>)/, /^(?:\s*>)/, /^(?:\s*<)/, /^(?:\s*\*)/, /^(?:\s*o\b)/, /^(?:\s*\(\))/, /^(?:--)/, /^(?:\.\.)/, /^(?::{1}[^:\n;]+)/, /^(?::{3})/, /^(?:-)/, /^(?:\.)/, /^(?:\+)/, /^(?::)/, /^(?:,)/, /^(?:#)/, /^(?:#)/, /^(?:%)/, /^(?:=)/, /^(?:=)/, /^(?:\w+)/, /^(?:\[)/, /^(?:\])/, /^(?:[!"#$%&'*+,-.`?\\/])/, /^(?:[0-9]+)/, /^(?:[\u00AA\u00B5\u00BA\u00C0-\u00D6\u00D8-\u00F6]|[\u00F8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377]|[\u037A-\u037D\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5]|[\u03F7-\u0481\u048A-\u0527\u0531-\u0556\u0559\u0561-\u0587\u05D0-\u05EA]|[\u05F0-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE]|[\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA]|[\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u08A0]|[\u08A2-\u08AC\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0977]|[\u0979-\u097F\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2]|[\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u0A05-\u0A0A]|[\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39]|[\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8]|[\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0B05-\u0B0C]|[\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C]|[\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99]|[\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0]|[\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C33\u0C35-\u0C39\u0C3D]|[\u0C58\u0C59\u0C60\u0C61\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3]|[\u0CB5-\u0CB9\u0CBD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D05-\u0D0C\u0D0E-\u0D10]|[\u0D12-\u0D3A\u0D3D\u0D4E\u0D60\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1]|[\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81]|[\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3]|[\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6]|[\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A]|[\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081]|[\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D]|[\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0]|[\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310]|[\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F4\u1401-\u166C]|[\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u1700-\u170C\u170E-\u1711]|[\u1720-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7]|[\u17DC\u1820-\u1877\u1880-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191C]|[\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19C1-\u19C7\u1A00-\u1A16]|[\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4B\u1B83-\u1BA0\u1BAE\u1BAF]|[\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1CE9-\u1CEC]|[\u1CEE-\u1CF1\u1CF5\u1CF6\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D]|[\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D]|[\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3]|[\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F]|[\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128]|[\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2183\u2184]|[\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3]|[\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6]|[\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE]|[\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005\u3006\u3031-\u3035\u303B\u303C]|[\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312D]|[\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FCC]|[\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B]|[\uA640-\uA66E\uA67F-\uA697\uA6A0-\uA6E5\uA717-\uA71F\uA722-\uA788]|[\uA78B-\uA78E\uA790-\uA793\uA7A0-\uA7AA\uA7F8-\uA801\uA803-\uA805]|[\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB]|[\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uAA00-\uAA28]|[\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA80-\uAAAF\uAAB1\uAAB5]|[\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4]|[\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E]|[\uABC0-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D]|[\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36]|[\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D]|[\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC]|[\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF]|[\uFFD2-\uFFD7\uFFDA-\uFFDC])/, /^(?:\s)/, /^(?:\s)/, /^(?:$)/], + conditions: { "namespace-body": { "rules": [26, 32, 33, 34, 35, 36, 37, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "namespace": { "rules": [26, 28, 29, 30, 31, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "class-body": { "rules": [26, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "class": { "rules": [26, 38, 39, 40, 41, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "acc_descr_multiline": { "rules": [11, 12, 26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "acc_descr": { "rules": [9, 26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "acc_title": { "rules": [7, 26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "callback_args": { "rules": [22, 23, 26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "callback_name": { "rules": [19, 20, 21, 26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "href": { "rules": [26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "struct": { "rules": [26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "generic": { "rules": [26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "bqstring": { "rules": [26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "string": { "rules": [24, 25, 26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "INITIAL": { "rules": [0, 1, 2, 3, 4, 5, 6, 8, 10, 13, 14, 15, 16, 17, 18, 26, 27, 28, 37, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser() { + this.yy = {}; + } + Parser.prototype = parser2; + parser2.Parser = Parser; + return new Parser(); +}(); +parser.parser = parser; +const parser$1 = parser; +const visibilityValues = ["#", "+", "~", "-", ""]; +class ClassMember { + constructor(input, memberType) { + this.memberType = memberType; + this.visibility = ""; + this.classifier = ""; + const sanitizedInput = sanitizeText$1(input, getConfig()); + this.parseMember(sanitizedInput); + } + getDisplayDetails() { + let displayText = this.visibility + parseGenericTypes(this.id); + if (this.memberType === "method") { + displayText += `(${parseGenericTypes(this.parameters.trim())})`; + if (this.returnType) { + displayText += " : " + parseGenericTypes(this.returnType); + } + } + displayText = displayText.trim(); + const cssStyle = this.parseClassifier(); + return { + displayText, + cssStyle + }; + } + parseMember(input) { + let potentialClassifier = ""; + if (this.memberType === "method") { + const methodRegEx = /([#+~-])?(.+)\((.*)\)([\s$*])?(.*)([$*])?/; + const match = input.match(methodRegEx); + if (match) { + const detectedVisibility = match[1] ? match[1].trim() : ""; + if (visibilityValues.includes(detectedVisibility)) { + this.visibility = detectedVisibility; + } + this.id = match[2].trim(); + this.parameters = match[3] ? match[3].trim() : ""; + potentialClassifier = match[4] ? match[4].trim() : ""; + this.returnType = match[5] ? match[5].trim() : ""; + if (potentialClassifier === "") { + const lastChar = this.returnType.substring(this.returnType.length - 1); + if (lastChar.match(/[$*]/)) { + potentialClassifier = lastChar; + this.returnType = this.returnType.substring(0, this.returnType.length - 1); + } + } + } + } else { + const length = input.length; + const firstChar = input.substring(0, 1); + const lastChar = input.substring(length - 1); + if (visibilityValues.includes(firstChar)) { + this.visibility = firstChar; + } + if (lastChar.match(/[$*]/)) { + potentialClassifier = lastChar; + } + this.id = input.substring( + this.visibility === "" ? 0 : 1, + potentialClassifier === "" ? length : length - 1 + ); + } + this.classifier = potentialClassifier; + } + parseClassifier() { + switch (this.classifier) { + case "*": + return "font-style:italic;"; + case "$": + return "text-decoration:underline;"; + default: + return ""; + } + } +} +const MERMAID_DOM_ID_PREFIX = "classId-"; +let relations = []; +let classes = {}; +let notes = []; +let classCounter = 0; +let namespaces = {}; +let namespaceCounter = 0; +let functions = []; +const sanitizeText = (txt) => common.sanitizeText(txt, getConfig()); +const splitClassNameAndType = function(_id) { + const id = common.sanitizeText(_id, getConfig()); + let genericType = ""; + let className = id; + if (id.indexOf("~") > 0) { + const split = id.split("~"); + className = sanitizeText(split[0]); + genericType = sanitizeText(split[1]); + } + return { className, type: genericType }; +}; +const setClassLabel = function(_id, label) { + const id = common.sanitizeText(_id, getConfig()); + if (label) { + label = sanitizeText(label); + } + const { className } = splitClassNameAndType(id); + classes[className].label = label; +}; +const addClass = function(_id) { + const id = common.sanitizeText(_id, getConfig()); + const { className, type } = splitClassNameAndType(id); + if (Object.hasOwn(classes, className)) { + return; + } + const name = common.sanitizeText(className, getConfig()); + classes[name] = { + id: name, + type, + label: name, + cssClasses: [], + methods: [], + members: [], + annotations: [], + styles: [], + domId: MERMAID_DOM_ID_PREFIX + name + "-" + classCounter + }; + classCounter++; +}; +const lookUpDomId = function(_id) { + const id = common.sanitizeText(_id, getConfig()); + if (id in classes) { + return classes[id].domId; + } + throw new Error("Class not found: " + id); +}; +const clear = function() { + relations = []; + classes = {}; + notes = []; + functions = []; + functions.push(setupToolTips); + namespaces = {}; + namespaceCounter = 0; + clear$1(); +}; +const getClass = function(id) { + return classes[id]; +}; +const getClasses = function() { + return classes; +}; +const getRelations = function() { + return relations; +}; +const getNotes = function() { + return notes; +}; +const addRelation = function(relation) { + log.debug("Adding relation: " + JSON.stringify(relation)); + addClass(relation.id1); + addClass(relation.id2); + relation.id1 = splitClassNameAndType(relation.id1).className; + relation.id2 = splitClassNameAndType(relation.id2).className; + relation.relationTitle1 = common.sanitizeText(relation.relationTitle1.trim(), getConfig()); + relation.relationTitle2 = common.sanitizeText(relation.relationTitle2.trim(), getConfig()); + relations.push(relation); +}; +const addAnnotation = function(className, annotation) { + const validatedClassName = splitClassNameAndType(className).className; + classes[validatedClassName].annotations.push(annotation); +}; +const addMember = function(className, member) { + addClass(className); + const validatedClassName = splitClassNameAndType(className).className; + const theClass = classes[validatedClassName]; + if (typeof member === "string") { + const memberString = member.trim(); + if (memberString.startsWith("<<") && memberString.endsWith(">>")) { + theClass.annotations.push(sanitizeText(memberString.substring(2, memberString.length - 2))); + } else if (memberString.indexOf(")") > 0) { + theClass.methods.push(new ClassMember(memberString, "method")); + } else if (memberString) { + theClass.members.push(new ClassMember(memberString, "attribute")); + } + } +}; +const addMembers = function(className, members) { + if (Array.isArray(members)) { + members.reverse(); + members.forEach((member) => addMember(className, member)); + } +}; +const addNote = function(text, className) { + const note = { + id: `note${notes.length}`, + class: className, + text + }; + notes.push(note); +}; +const cleanupLabel = function(label) { + if (label.startsWith(":")) { + label = label.substring(1); + } + return sanitizeText(label.trim()); +}; +const setCssClass = function(ids, className) { + ids.split(",").forEach(function(_id) { + let id = _id; + if (_id[0].match(/\d/)) { + id = MERMAID_DOM_ID_PREFIX + id; + } + if (classes[id] !== void 0) { + classes[id].cssClasses.push(className); + } + }); +}; +const setTooltip = function(ids, tooltip) { + ids.split(",").forEach(function(id) { + if (tooltip !== void 0) { + classes[id].tooltip = sanitizeText(tooltip); + } + }); +}; +const getTooltip = function(id, namespace) { + if (namespace) { + return namespaces[namespace].classes[id].tooltip; + } + return classes[id].tooltip; +}; +const setLink = function(ids, linkStr, target) { + const config = getConfig(); + ids.split(",").forEach(function(_id) { + let id = _id; + if (_id[0].match(/\d/)) { + id = MERMAID_DOM_ID_PREFIX + id; + } + if (classes[id] !== void 0) { + classes[id].link = utils.formatUrl(linkStr, config); + if (config.securityLevel === "sandbox") { + classes[id].linkTarget = "_top"; + } else if (typeof target === "string") { + classes[id].linkTarget = sanitizeText(target); + } else { + classes[id].linkTarget = "_blank"; + } + } + }); + setCssClass(ids, "clickable"); +}; +const setClickEvent = function(ids, functionName, functionArgs) { + ids.split(",").forEach(function(id) { + setClickFunc(id, functionName, functionArgs); + classes[id].haveCallback = true; + }); + setCssClass(ids, "clickable"); +}; +const setClickFunc = function(_domId, functionName, functionArgs) { + const domId = common.sanitizeText(_domId, getConfig()); + const config = getConfig(); + if (config.securityLevel !== "loose") { + return; + } + if (functionName === void 0) { + return; + } + const id = domId; + if (classes[id] !== void 0) { + const elemId = lookUpDomId(id); + let argList = []; + if (typeof functionArgs === "string") { + argList = functionArgs.split(/,(?=(?:(?:[^"]*"){2})*[^"]*$)/); + for (let i = 0; i < argList.length; i++) { + let item = argList[i].trim(); + if (item.charAt(0) === '"' && item.charAt(item.length - 1) === '"') { + item = item.substr(1, item.length - 2); + } + argList[i] = item; + } + } + if (argList.length === 0) { + argList.push(elemId); + } + functions.push(function() { + const elem = document.querySelector(`[id="${elemId}"]`); + if (elem !== null) { + elem.addEventListener( + "click", + function() { + utils.runFunc(functionName, ...argList); + }, + false + ); + } + }); + } +}; +const bindFunctions = function(element) { + functions.forEach(function(fun) { + fun(element); + }); +}; +const lineType = { + LINE: 0, + DOTTED_LINE: 1 +}; +const relationType = { + AGGREGATION: 0, + EXTENSION: 1, + COMPOSITION: 2, + DEPENDENCY: 3, + LOLLIPOP: 4 +}; +const setupToolTips = function(element) { + let tooltipElem = d3select(".mermaidTooltip"); + if ((tooltipElem._groups || tooltipElem)[0][0] === null) { + tooltipElem = d3select("body").append("div").attr("class", "mermaidTooltip").style("opacity", 0); + } + const svg = d3select(element).select("svg"); + const nodes = svg.selectAll("g.node"); + nodes.on("mouseover", function() { + const el = d3select(this); + const title = el.attr("title"); + if (title === null) { + return; + } + const rect = this.getBoundingClientRect(); + tooltipElem.transition().duration(200).style("opacity", ".9"); + tooltipElem.text(el.attr("title")).style("left", window.scrollX + rect.left + (rect.right - rect.left) / 2 + "px").style("top", window.scrollY + rect.top - 14 + document.body.scrollTop + "px"); + tooltipElem.html(tooltipElem.html().replace(/<br\/>/g, "
    ")); + el.classed("hover", true); + }).on("mouseout", function() { + tooltipElem.transition().duration(500).style("opacity", 0); + const el = d3select(this); + el.classed("hover", false); + }); +}; +functions.push(setupToolTips); +let direction = "TB"; +const getDirection = () => direction; +const setDirection = (dir) => { + direction = dir; +}; +const addNamespace = function(id) { + if (namespaces[id] !== void 0) { + return; + } + namespaces[id] = { + id, + classes: {}, + children: {}, + domId: MERMAID_DOM_ID_PREFIX + id + "-" + namespaceCounter + }; + namespaceCounter++; +}; +const getNamespace = function(name) { + return namespaces[name]; +}; +const getNamespaces = function() { + return namespaces; +}; +const addClassesToNamespace = function(id, classNames) { + if (namespaces[id] === void 0) { + return; + } + for (const name of classNames) { + const { className } = splitClassNameAndType(name); + classes[className].parent = id; + namespaces[id].classes[className] = classes[className]; + } +}; +const setCssStyle = function(id, styles2) { + const thisClass = classes[id]; + if (!styles2 || !thisClass) { + return; + } + for (const s of styles2) { + if (s.includes(",")) { + thisClass.styles.push(...s.split(",")); + } else { + thisClass.styles.push(s); + } + } +}; +const db = { + setAccTitle, + getAccTitle, + getAccDescription, + setAccDescription, + getConfig: () => getConfig().class, + addClass, + bindFunctions, + clear, + getClass, + getClasses, + getNotes, + addAnnotation, + addNote, + getRelations, + addRelation, + getDirection, + setDirection, + addMember, + addMembers, + cleanupLabel, + lineType, + relationType, + setClickEvent, + setCssClass, + setLink, + getTooltip, + setTooltip, + lookUpDomId, + setDiagramTitle, + getDiagramTitle, + setClassLabel, + addNamespace, + addClassesToNamespace, + getNamespace, + getNamespaces, + setCssStyle +}; +const getStyles = (options) => `g.classGroup text { + fill: ${options.nodeBorder || options.classText}; + stroke: none; + font-family: ${options.fontFamily}; + font-size: 10px; + + .title { + font-weight: bolder; + } + +} + +.nodeLabel, .edgeLabel { + color: ${options.classText}; +} +.edgeLabel .label rect { + fill: ${options.mainBkg}; +} +.label text { + fill: ${options.classText}; +} +.edgeLabel .label span { + background: ${options.mainBkg}; +} + +.classTitle { + font-weight: bolder; +} +.node rect, + .node circle, + .node ellipse, + .node polygon, + .node path { + fill: ${options.mainBkg}; + stroke: ${options.nodeBorder}; + stroke-width: 1px; + } + + +.divider { + stroke: ${options.nodeBorder}; + stroke-width: 1; +} + +g.clickable { + cursor: pointer; +} + +g.classGroup rect { + fill: ${options.mainBkg}; + stroke: ${options.nodeBorder}; +} + +g.classGroup line { + stroke: ${options.nodeBorder}; + stroke-width: 1; +} + +.classLabel .box { + stroke: none; + stroke-width: 0; + fill: ${options.mainBkg}; + opacity: 0.5; +} + +.classLabel .label { + fill: ${options.nodeBorder}; + font-size: 10px; +} + +.relation { + stroke: ${options.lineColor}; + stroke-width: 1; + fill: none; +} + +.dashed-line{ + stroke-dasharray: 3; +} + +.dotted-line{ + stroke-dasharray: 1 2; +} + +#compositionStart, .composition { + fill: ${options.lineColor} !important; + stroke: ${options.lineColor} !important; + stroke-width: 1; +} + +#compositionEnd, .composition { + fill: ${options.lineColor} !important; + stroke: ${options.lineColor} !important; + stroke-width: 1; +} + +#dependencyStart, .dependency { + fill: ${options.lineColor} !important; + stroke: ${options.lineColor} !important; + stroke-width: 1; +} + +#dependencyStart, .dependency { + fill: ${options.lineColor} !important; + stroke: ${options.lineColor} !important; + stroke-width: 1; +} + +#extensionStart, .extension { + fill: transparent !important; + stroke: ${options.lineColor} !important; + stroke-width: 1; +} + +#extensionEnd, .extension { + fill: transparent !important; + stroke: ${options.lineColor} !important; + stroke-width: 1; +} + +#aggregationStart, .aggregation { + fill: transparent !important; + stroke: ${options.lineColor} !important; + stroke-width: 1; +} + +#aggregationEnd, .aggregation { + fill: transparent !important; + stroke: ${options.lineColor} !important; + stroke-width: 1; +} + +#lollipopStart, .lollipop { + fill: ${options.mainBkg} !important; + stroke: ${options.lineColor} !important; + stroke-width: 1; +} + +#lollipopEnd, .lollipop { + fill: ${options.mainBkg} !important; + stroke: ${options.lineColor} !important; + stroke-width: 1; +} + +.edgeTerminals { + font-size: 11px; + line-height: initial; +} + +.classTitleText { + text-anchor: middle; + font-size: 18px; + fill: ${options.textColor}; +} +`; +const styles = getStyles; +export { + db as d, + parser$1 as p, + styles as s +}; diff --git a/0.6.0/js/mermaid/styles-483fbfea.js b/0.6.0/js/mermaid/styles-483fbfea.js new file mode 100644 index 0000000..8c417e3 --- /dev/null +++ b/0.6.0/js/mermaid/styles-483fbfea.js @@ -0,0 +1,509 @@ +import * as graphlib from "dagre-d3-es/src/graphlib/index.js"; +import { curveLinear, select, selectAll } from "d3"; +import { k as getStylesFromArray, l as log, m as evaluate, c as getConfig, e as common, r as renderKatex, n as interpolateToCurve, u as utils, o as setupGraphViewbox } from "./mermaid-6dc72991.js"; +import { r as render } from "./index-01f381cb.js"; +import { addHtmlLabel } from "dagre-d3-es/src/dagre-js/label/add-html-label.js"; +import * as khroma from "khroma"; +const conf = {}; +const setConf = function(cnf) { + const keys = Object.keys(cnf); + for (const key of keys) { + conf[key] = cnf[key]; + } +}; +const addVertices = async function(vert, g, svgId, root, doc, diagObj) { + const svg = root.select(`[id="${svgId}"]`); + const keys = Object.keys(vert); + for (const id of keys) { + const vertex = vert[id]; + let classStr = "default"; + if (vertex.classes.length > 0) { + classStr = vertex.classes.join(" "); + } + classStr = classStr + " flowchart-label"; + const styles = getStylesFromArray(vertex.styles); + let vertexText = vertex.text !== void 0 ? vertex.text : vertex.id; + let vertexNode; + log.info("vertex", vertex, vertex.labelType); + if (vertex.labelType === "markdown") { + log.info("vertex", vertex, vertex.labelType); + } else { + if (evaluate(getConfig().flowchart.htmlLabels)) { + const node = { + label: vertexText + }; + vertexNode = addHtmlLabel(svg, node).node(); + vertexNode.parentNode.removeChild(vertexNode); + } else { + const svgLabel = doc.createElementNS("http://www.w3.org/2000/svg", "text"); + svgLabel.setAttribute("style", styles.labelStyle.replace("color:", "fill:")); + const rows = vertexText.split(common.lineBreakRegex); + for (const row of rows) { + const tspan = doc.createElementNS("http://www.w3.org/2000/svg", "tspan"); + tspan.setAttributeNS("http://www.w3.org/XML/1998/namespace", "xml:space", "preserve"); + tspan.setAttribute("dy", "1em"); + tspan.setAttribute("x", "1"); + tspan.textContent = row; + svgLabel.appendChild(tspan); + } + vertexNode = svgLabel; + } + } + let radius = 0; + let _shape = ""; + switch (vertex.type) { + case "round": + radius = 5; + _shape = "rect"; + break; + case "square": + _shape = "rect"; + break; + case "diamond": + _shape = "question"; + break; + case "hexagon": + _shape = "hexagon"; + break; + case "odd": + _shape = "rect_left_inv_arrow"; + break; + case "lean_right": + _shape = "lean_right"; + break; + case "lean_left": + _shape = "lean_left"; + break; + case "trapezoid": + _shape = "trapezoid"; + break; + case "inv_trapezoid": + _shape = "inv_trapezoid"; + break; + case "odd_right": + _shape = "rect_left_inv_arrow"; + break; + case "circle": + _shape = "circle"; + break; + case "ellipse": + _shape = "ellipse"; + break; + case "stadium": + _shape = "stadium"; + break; + case "subroutine": + _shape = "subroutine"; + break; + case "cylinder": + _shape = "cylinder"; + break; + case "group": + _shape = "rect"; + break; + case "doublecircle": + _shape = "doublecircle"; + break; + default: + _shape = "rect"; + } + const labelText = await renderKatex(vertexText, getConfig()); + g.setNode(vertex.id, { + labelStyle: styles.labelStyle, + shape: _shape, + labelText, + labelType: vertex.labelType, + rx: radius, + ry: radius, + class: classStr, + style: styles.style, + id: vertex.id, + link: vertex.link, + linkTarget: vertex.linkTarget, + tooltip: diagObj.db.getTooltip(vertex.id) || "", + domId: diagObj.db.lookUpDomId(vertex.id), + haveCallback: vertex.haveCallback, + width: vertex.type === "group" ? 500 : void 0, + dir: vertex.dir, + type: vertex.type, + props: vertex.props, + padding: getConfig().flowchart.padding + }); + log.info("setNode", { + labelStyle: styles.labelStyle, + labelType: vertex.labelType, + shape: _shape, + labelText, + rx: radius, + ry: radius, + class: classStr, + style: styles.style, + id: vertex.id, + domId: diagObj.db.lookUpDomId(vertex.id), + width: vertex.type === "group" ? 500 : void 0, + type: vertex.type, + dir: vertex.dir, + props: vertex.props, + padding: getConfig().flowchart.padding + }); + } +}; +const addEdges = async function(edges, g, diagObj) { + log.info("abc78 edges = ", edges); + let cnt = 0; + let linkIdCnt = {}; + let defaultStyle; + let defaultLabelStyle; + if (edges.defaultStyle !== void 0) { + const defaultStyles = getStylesFromArray(edges.defaultStyle); + defaultStyle = defaultStyles.style; + defaultLabelStyle = defaultStyles.labelStyle; + } + for (const edge of edges) { + cnt++; + const linkIdBase = "L-" + edge.start + "-" + edge.end; + if (linkIdCnt[linkIdBase] === void 0) { + linkIdCnt[linkIdBase] = 0; + log.info("abc78 new entry", linkIdBase, linkIdCnt[linkIdBase]); + } else { + linkIdCnt[linkIdBase]++; + log.info("abc78 new entry", linkIdBase, linkIdCnt[linkIdBase]); + } + let linkId = linkIdBase + "-" + linkIdCnt[linkIdBase]; + log.info("abc78 new link id to be used is", linkIdBase, linkId, linkIdCnt[linkIdBase]); + const linkNameStart = "LS-" + edge.start; + const linkNameEnd = "LE-" + edge.end; + const edgeData = { style: "", labelStyle: "" }; + edgeData.minlen = edge.length || 1; + if (edge.type === "arrow_open") { + edgeData.arrowhead = "none"; + } else { + edgeData.arrowhead = "normal"; + } + edgeData.arrowTypeStart = "arrow_open"; + edgeData.arrowTypeEnd = "arrow_open"; + switch (edge.type) { + case "double_arrow_cross": + edgeData.arrowTypeStart = "arrow_cross"; + case "arrow_cross": + edgeData.arrowTypeEnd = "arrow_cross"; + break; + case "double_arrow_point": + edgeData.arrowTypeStart = "arrow_point"; + case "arrow_point": + edgeData.arrowTypeEnd = "arrow_point"; + break; + case "double_arrow_circle": + edgeData.arrowTypeStart = "arrow_circle"; + case "arrow_circle": + edgeData.arrowTypeEnd = "arrow_circle"; + break; + } + let style = ""; + let labelStyle = ""; + switch (edge.stroke) { + case "normal": + style = "fill:none;"; + if (defaultStyle !== void 0) { + style = defaultStyle; + } + if (defaultLabelStyle !== void 0) { + labelStyle = defaultLabelStyle; + } + edgeData.thickness = "normal"; + edgeData.pattern = "solid"; + break; + case "dotted": + edgeData.thickness = "normal"; + edgeData.pattern = "dotted"; + edgeData.style = "fill:none;stroke-width:2px;stroke-dasharray:3;"; + break; + case "thick": + edgeData.thickness = "thick"; + edgeData.pattern = "solid"; + edgeData.style = "stroke-width: 3.5px;fill:none;"; + break; + case "invisible": + edgeData.thickness = "invisible"; + edgeData.pattern = "solid"; + edgeData.style = "stroke-width: 0;fill:none;"; + break; + } + if (edge.style !== void 0) { + const styles = getStylesFromArray(edge.style); + style = styles.style; + labelStyle = styles.labelStyle; + } + edgeData.style = edgeData.style += style; + edgeData.labelStyle = edgeData.labelStyle += labelStyle; + if (edge.interpolate !== void 0) { + edgeData.curve = interpolateToCurve(edge.interpolate, curveLinear); + } else if (edges.defaultInterpolate !== void 0) { + edgeData.curve = interpolateToCurve(edges.defaultInterpolate, curveLinear); + } else { + edgeData.curve = interpolateToCurve(conf.curve, curveLinear); + } + if (edge.text === void 0) { + if (edge.style !== void 0) { + edgeData.arrowheadStyle = "fill: #333"; + } + } else { + edgeData.arrowheadStyle = "fill: #333"; + edgeData.labelpos = "c"; + } + edgeData.labelType = edge.labelType; + edgeData.label = await renderKatex(edge.text.replace(common.lineBreakRegex, "\n"), getConfig()); + if (edge.style === void 0) { + edgeData.style = edgeData.style || "stroke: #333; stroke-width: 1.5px;fill:none;"; + } + edgeData.labelStyle = edgeData.labelStyle.replace("color:", "fill:"); + edgeData.id = linkId; + edgeData.classes = "flowchart-link " + linkNameStart + " " + linkNameEnd; + g.setEdge(edge.start, edge.end, edgeData, cnt); + } +}; +const getClasses = function(text, diagObj) { + return diagObj.db.getClasses(); +}; +const draw = async function(text, id, _version, diagObj) { + log.info("Drawing flowchart"); + let dir = diagObj.db.getDirection(); + if (dir === void 0) { + dir = "TD"; + } + const { securityLevel, flowchart: conf2 } = getConfig(); + const nodeSpacing = conf2.nodeSpacing || 50; + const rankSpacing = conf2.rankSpacing || 50; + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = select("#i" + id); + } + const root = securityLevel === "sandbox" ? select(sandboxElement.nodes()[0].contentDocument.body) : select("body"); + const doc = securityLevel === "sandbox" ? sandboxElement.nodes()[0].contentDocument : document; + const g = new graphlib.Graph({ + multigraph: true, + compound: true + }).setGraph({ + rankdir: dir, + nodesep: nodeSpacing, + ranksep: rankSpacing, + marginx: 0, + marginy: 0 + }).setDefaultEdgeLabel(function() { + return {}; + }); + let subG; + const subGraphs = diagObj.db.getSubGraphs(); + log.info("Subgraphs - ", subGraphs); + for (let i2 = subGraphs.length - 1; i2 >= 0; i2--) { + subG = subGraphs[i2]; + log.info("Subgraph - ", subG); + diagObj.db.addVertex( + subG.id, + { text: subG.title, type: subG.labelType }, + "group", + void 0, + subG.classes, + subG.dir + ); + } + const vert = diagObj.db.getVertices(); + const edges = diagObj.db.getEdges(); + log.info("Edges", edges); + let i = 0; + for (i = subGraphs.length - 1; i >= 0; i--) { + subG = subGraphs[i]; + selectAll("cluster").append("text"); + for (let j = 0; j < subG.nodes.length; j++) { + log.info("Setting up subgraphs", subG.nodes[j], subG.id); + g.setParent(subG.nodes[j], subG.id); + } + } + await addVertices(vert, g, id, root, doc, diagObj); + await addEdges(edges, g); + const svg = root.select(`[id="${id}"]`); + const element = root.select("#" + id + " g"); + await render(element, g, ["point", "circle", "cross"], "flowchart", id); + utils.insertTitle(svg, "flowchartTitleText", conf2.titleTopMargin, diagObj.db.getDiagramTitle()); + setupGraphViewbox(g, svg, conf2.diagramPadding, conf2.useMaxWidth); + diagObj.db.indexNodes("subGraph" + i); + if (!conf2.htmlLabels) { + const labels = doc.querySelectorAll('[id="' + id + '"] .edgeLabel .label'); + for (const label of labels) { + const dim = label.getBBox(); + const rect = doc.createElementNS("http://www.w3.org/2000/svg", "rect"); + rect.setAttribute("rx", 0); + rect.setAttribute("ry", 0); + rect.setAttribute("width", dim.width); + rect.setAttribute("height", dim.height); + label.insertBefore(rect, label.firstChild); + } + } + const keys = Object.keys(vert); + keys.forEach(function(key) { + const vertex = vert[key]; + if (vertex.link) { + const node = select("#" + id + ' [id="' + key + '"]'); + if (node) { + const link = doc.createElementNS("http://www.w3.org/2000/svg", "a"); + link.setAttributeNS("http://www.w3.org/2000/svg", "class", vertex.classes.join(" ")); + link.setAttributeNS("http://www.w3.org/2000/svg", "href", vertex.link); + link.setAttributeNS("http://www.w3.org/2000/svg", "rel", "noopener"); + if (securityLevel === "sandbox") { + link.setAttributeNS("http://www.w3.org/2000/svg", "target", "_top"); + } else if (vertex.linkTarget) { + link.setAttributeNS("http://www.w3.org/2000/svg", "target", vertex.linkTarget); + } + const linkNode = node.insert(function() { + return link; + }, ":first-child"); + const shape = node.select(".label-container"); + if (shape) { + linkNode.append(function() { + return shape.node(); + }); + } + const label = node.select(".label"); + if (label) { + linkNode.append(function() { + return label.node(); + }); + } + } + } + }); +}; +const flowRendererV2 = { + setConf, + addVertices, + addEdges, + getClasses, + draw +}; +const fade = (color, opacity) => { + const channel = khroma.channel; + const r = channel(color, "r"); + const g = channel(color, "g"); + const b = channel(color, "b"); + return khroma.rgba(r, g, b, opacity); +}; +const getStyles = (options) => `.label { + font-family: ${options.fontFamily}; + color: ${options.nodeTextColor || options.textColor}; + } + .cluster-label text { + fill: ${options.titleColor}; + } + .cluster-label span,p { + color: ${options.titleColor}; + } + + .label text,span,p { + fill: ${options.nodeTextColor || options.textColor}; + color: ${options.nodeTextColor || options.textColor}; + } + + .node rect, + .node circle, + .node ellipse, + .node polygon, + .node path { + fill: ${options.mainBkg}; + stroke: ${options.nodeBorder}; + stroke-width: 1px; + } + .flowchart-label text { + text-anchor: middle; + } + // .flowchart-label .text-outer-tspan { + // text-anchor: middle; + // } + // .flowchart-label .text-inner-tspan { + // text-anchor: start; + // } + + .node .katex path { + fill: #000; + stroke: #000; + stroke-width: 1px; + } + + .node .label { + text-align: center; + } + .node.clickable { + cursor: pointer; + } + + .arrowheadPath { + fill: ${options.arrowheadColor}; + } + + .edgePath .path { + stroke: ${options.lineColor}; + stroke-width: 2.0px; + } + + .flowchart-link { + stroke: ${options.lineColor}; + fill: none; + } + + .edgeLabel { + background-color: ${options.edgeLabelBackground}; + rect { + opacity: 0.5; + background-color: ${options.edgeLabelBackground}; + fill: ${options.edgeLabelBackground}; + } + text-align: center; + } + + /* For html labels only */ + .labelBkg { + background-color: ${fade(options.edgeLabelBackground, 0.5)}; + // background-color: + } + + .cluster rect { + fill: ${options.clusterBkg}; + stroke: ${options.clusterBorder}; + stroke-width: 1px; + } + + .cluster text { + fill: ${options.titleColor}; + } + + .cluster span,p { + color: ${options.titleColor}; + } + /* .cluster div { + color: ${options.titleColor}; + } */ + + div.mermaidTooltip { + position: absolute; + text-align: center; + max-width: 200px; + padding: 2px; + font-family: ${options.fontFamily}; + font-size: 12px; + background: ${options.tertiaryColor}; + border: 1px solid ${options.border2}; + border-radius: 2px; + pointer-events: none; + z-index: 100; + } + + .flowchartTitleText { + text-anchor: middle; + font-size: 18px; + fill: ${options.textColor}; + } +`; +const flowStyles = getStyles; +export { + flowStyles as a, + flowRendererV2 as f +}; diff --git a/0.6.0/js/mermaid/styles-727cdd61.js b/0.6.0/js/mermaid/styles-727cdd61.js new file mode 100644 index 0000000..3926822 --- /dev/null +++ b/0.6.0/js/mermaid/styles-727cdd61.js @@ -0,0 +1,571 @@ +import { G as Graph } from "./graph-fe24fab6.js"; +import { S as Selection, v as root, x as array, y as isPlainObject, z as isFunction, o as getStylesFromArray, l as log, p as evaluate, c as getConfig, f as common, r as renderKatex, q as interpolateToCurve, n as curveLinear, j as d3select, A as utils, t as setupGraphViewbox, B as rgba } from "./mermaid-dcacb631.js"; +import { r as render } from "./index-fc479858.js"; +import { c as channel } from "./channel-f9001828.js"; +function selectAll(selector) { + return typeof selector === "string" ? new Selection([document.querySelectorAll(selector)], [document.documentElement]) : new Selection([array(selector)], root); +} +function isSubgraph(g, v) { + return !!g.children(v).length; +} +function edgeToId(e) { + return escapeId(e.v) + ":" + escapeId(e.w) + ":" + escapeId(e.name); +} +var ID_DELIM = /:/g; +function escapeId(str) { + return str ? String(str).replace(ID_DELIM, "\\:") : ""; +} +function applyStyle(dom, styleFn) { + if (styleFn) { + dom.attr("style", styleFn); + } +} +function applyClass(dom, classFn, otherClasses) { + if (classFn) { + dom.attr("class", classFn).attr("class", otherClasses + " " + dom.attr("class")); + } +} +function applyTransition(selection, g) { + var graph = g.graph(); + if (isPlainObject(graph)) { + var transition = graph.transition; + if (isFunction(transition)) { + return transition(selection); + } + } + return selection; +} +function addHtmlLabel(root2, node) { + var fo = root2.append("foreignObject").attr("width", "100000"); + var div = fo.append("xhtml:div"); + div.attr("xmlns", "http://www.w3.org/1999/xhtml"); + var label = node.label; + switch (typeof label) { + case "function": + div.insert(label); + break; + case "object": + div.insert(function() { + return label; + }); + break; + default: + div.html(label); + } + applyStyle(div, node.labelStyle); + div.style("display", "inline-block"); + div.style("white-space", "nowrap"); + var client = div.node().getBoundingClientRect(); + fo.attr("width", client.width).attr("height", client.height); + return fo; +} +const conf = {}; +const setConf = function(cnf) { + const keys = Object.keys(cnf); + for (const key of keys) { + conf[key] = cnf[key]; + } +}; +const addVertices = async function(vert, g, svgId, root2, doc, diagObj) { + const svg = root2.select(`[id="${svgId}"]`); + const keys = Object.keys(vert); + for (const id of keys) { + const vertex = vert[id]; + let classStr = "default"; + if (vertex.classes.length > 0) { + classStr = vertex.classes.join(" "); + } + classStr = classStr + " flowchart-label"; + const styles = getStylesFromArray(vertex.styles); + let vertexText = vertex.text !== void 0 ? vertex.text : vertex.id; + let vertexNode; + log.info("vertex", vertex, vertex.labelType); + if (vertex.labelType === "markdown") { + log.info("vertex", vertex, vertex.labelType); + } else { + if (evaluate(getConfig().flowchart.htmlLabels)) { + const node = { + label: vertexText + }; + vertexNode = addHtmlLabel(svg, node).node(); + vertexNode.parentNode.removeChild(vertexNode); + } else { + const svgLabel = doc.createElementNS("http://www.w3.org/2000/svg", "text"); + svgLabel.setAttribute("style", styles.labelStyle.replace("color:", "fill:")); + const rows = vertexText.split(common.lineBreakRegex); + for (const row of rows) { + const tspan = doc.createElementNS("http://www.w3.org/2000/svg", "tspan"); + tspan.setAttributeNS("http://www.w3.org/XML/1998/namespace", "xml:space", "preserve"); + tspan.setAttribute("dy", "1em"); + tspan.setAttribute("x", "1"); + tspan.textContent = row; + svgLabel.appendChild(tspan); + } + vertexNode = svgLabel; + } + } + let radius = 0; + let _shape = ""; + switch (vertex.type) { + case "round": + radius = 5; + _shape = "rect"; + break; + case "square": + _shape = "rect"; + break; + case "diamond": + _shape = "question"; + break; + case "hexagon": + _shape = "hexagon"; + break; + case "odd": + _shape = "rect_left_inv_arrow"; + break; + case "lean_right": + _shape = "lean_right"; + break; + case "lean_left": + _shape = "lean_left"; + break; + case "trapezoid": + _shape = "trapezoid"; + break; + case "inv_trapezoid": + _shape = "inv_trapezoid"; + break; + case "odd_right": + _shape = "rect_left_inv_arrow"; + break; + case "circle": + _shape = "circle"; + break; + case "ellipse": + _shape = "ellipse"; + break; + case "stadium": + _shape = "stadium"; + break; + case "subroutine": + _shape = "subroutine"; + break; + case "cylinder": + _shape = "cylinder"; + break; + case "group": + _shape = "rect"; + break; + case "doublecircle": + _shape = "doublecircle"; + break; + default: + _shape = "rect"; + } + const labelText = await renderKatex(vertexText, getConfig()); + g.setNode(vertex.id, { + labelStyle: styles.labelStyle, + shape: _shape, + labelText, + labelType: vertex.labelType, + rx: radius, + ry: radius, + class: classStr, + style: styles.style, + id: vertex.id, + link: vertex.link, + linkTarget: vertex.linkTarget, + tooltip: diagObj.db.getTooltip(vertex.id) || "", + domId: diagObj.db.lookUpDomId(vertex.id), + haveCallback: vertex.haveCallback, + width: vertex.type === "group" ? 500 : void 0, + dir: vertex.dir, + type: vertex.type, + props: vertex.props, + padding: getConfig().flowchart.padding + }); + log.info("setNode", { + labelStyle: styles.labelStyle, + labelType: vertex.labelType, + shape: _shape, + labelText, + rx: radius, + ry: radius, + class: classStr, + style: styles.style, + id: vertex.id, + domId: diagObj.db.lookUpDomId(vertex.id), + width: vertex.type === "group" ? 500 : void 0, + type: vertex.type, + dir: vertex.dir, + props: vertex.props, + padding: getConfig().flowchart.padding + }); + } +}; +const addEdges = async function(edges, g, diagObj) { + log.info("abc78 edges = ", edges); + let cnt = 0; + let linkIdCnt = {}; + let defaultStyle; + let defaultLabelStyle; + if (edges.defaultStyle !== void 0) { + const defaultStyles = getStylesFromArray(edges.defaultStyle); + defaultStyle = defaultStyles.style; + defaultLabelStyle = defaultStyles.labelStyle; + } + for (const edge of edges) { + cnt++; + const linkIdBase = "L-" + edge.start + "-" + edge.end; + if (linkIdCnt[linkIdBase] === void 0) { + linkIdCnt[linkIdBase] = 0; + log.info("abc78 new entry", linkIdBase, linkIdCnt[linkIdBase]); + } else { + linkIdCnt[linkIdBase]++; + log.info("abc78 new entry", linkIdBase, linkIdCnt[linkIdBase]); + } + let linkId = linkIdBase + "-" + linkIdCnt[linkIdBase]; + log.info("abc78 new link id to be used is", linkIdBase, linkId, linkIdCnt[linkIdBase]); + const linkNameStart = "LS-" + edge.start; + const linkNameEnd = "LE-" + edge.end; + const edgeData = { style: "", labelStyle: "" }; + edgeData.minlen = edge.length || 1; + if (edge.type === "arrow_open") { + edgeData.arrowhead = "none"; + } else { + edgeData.arrowhead = "normal"; + } + edgeData.arrowTypeStart = "arrow_open"; + edgeData.arrowTypeEnd = "arrow_open"; + switch (edge.type) { + case "double_arrow_cross": + edgeData.arrowTypeStart = "arrow_cross"; + case "arrow_cross": + edgeData.arrowTypeEnd = "arrow_cross"; + break; + case "double_arrow_point": + edgeData.arrowTypeStart = "arrow_point"; + case "arrow_point": + edgeData.arrowTypeEnd = "arrow_point"; + break; + case "double_arrow_circle": + edgeData.arrowTypeStart = "arrow_circle"; + case "arrow_circle": + edgeData.arrowTypeEnd = "arrow_circle"; + break; + } + let style = ""; + let labelStyle = ""; + switch (edge.stroke) { + case "normal": + style = "fill:none;"; + if (defaultStyle !== void 0) { + style = defaultStyle; + } + if (defaultLabelStyle !== void 0) { + labelStyle = defaultLabelStyle; + } + edgeData.thickness = "normal"; + edgeData.pattern = "solid"; + break; + case "dotted": + edgeData.thickness = "normal"; + edgeData.pattern = "dotted"; + edgeData.style = "fill:none;stroke-width:2px;stroke-dasharray:3;"; + break; + case "thick": + edgeData.thickness = "thick"; + edgeData.pattern = "solid"; + edgeData.style = "stroke-width: 3.5px;fill:none;"; + break; + case "invisible": + edgeData.thickness = "invisible"; + edgeData.pattern = "solid"; + edgeData.style = "stroke-width: 0;fill:none;"; + break; + } + if (edge.style !== void 0) { + const styles = getStylesFromArray(edge.style); + style = styles.style; + labelStyle = styles.labelStyle; + } + edgeData.style = edgeData.style += style; + edgeData.labelStyle = edgeData.labelStyle += labelStyle; + if (edge.interpolate !== void 0) { + edgeData.curve = interpolateToCurve(edge.interpolate, curveLinear); + } else if (edges.defaultInterpolate !== void 0) { + edgeData.curve = interpolateToCurve(edges.defaultInterpolate, curveLinear); + } else { + edgeData.curve = interpolateToCurve(conf.curve, curveLinear); + } + if (edge.text === void 0) { + if (edge.style !== void 0) { + edgeData.arrowheadStyle = "fill: #333"; + } + } else { + edgeData.arrowheadStyle = "fill: #333"; + edgeData.labelpos = "c"; + } + edgeData.labelType = edge.labelType; + edgeData.label = await renderKatex(edge.text.replace(common.lineBreakRegex, "\n"), getConfig()); + if (edge.style === void 0) { + edgeData.style = edgeData.style || "stroke: #333; stroke-width: 1.5px;fill:none;"; + } + edgeData.labelStyle = edgeData.labelStyle.replace("color:", "fill:"); + edgeData.id = linkId; + edgeData.classes = "flowchart-link " + linkNameStart + " " + linkNameEnd; + g.setEdge(edge.start, edge.end, edgeData, cnt); + } +}; +const getClasses = function(text, diagObj) { + return diagObj.db.getClasses(); +}; +const draw = async function(text, id, _version, diagObj) { + log.info("Drawing flowchart"); + let dir = diagObj.db.getDirection(); + if (dir === void 0) { + dir = "TD"; + } + const { securityLevel, flowchart: conf2 } = getConfig(); + const nodeSpacing = conf2.nodeSpacing || 50; + const rankSpacing = conf2.rankSpacing || 50; + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = d3select("#i" + id); + } + const root2 = securityLevel === "sandbox" ? d3select(sandboxElement.nodes()[0].contentDocument.body) : d3select("body"); + const doc = securityLevel === "sandbox" ? sandboxElement.nodes()[0].contentDocument : document; + const g = new Graph({ + multigraph: true, + compound: true + }).setGraph({ + rankdir: dir, + nodesep: nodeSpacing, + ranksep: rankSpacing, + marginx: 0, + marginy: 0 + }).setDefaultEdgeLabel(function() { + return {}; + }); + let subG; + const subGraphs = diagObj.db.getSubGraphs(); + log.info("Subgraphs - ", subGraphs); + for (let i2 = subGraphs.length - 1; i2 >= 0; i2--) { + subG = subGraphs[i2]; + log.info("Subgraph - ", subG); + diagObj.db.addVertex( + subG.id, + { text: subG.title, type: subG.labelType }, + "group", + void 0, + subG.classes, + subG.dir + ); + } + const vert = diagObj.db.getVertices(); + const edges = diagObj.db.getEdges(); + log.info("Edges", edges); + let i = 0; + for (i = subGraphs.length - 1; i >= 0; i--) { + subG = subGraphs[i]; + selectAll("cluster").append("text"); + for (let j = 0; j < subG.nodes.length; j++) { + log.info("Setting up subgraphs", subG.nodes[j], subG.id); + g.setParent(subG.nodes[j], subG.id); + } + } + await addVertices(vert, g, id, root2, doc, diagObj); + await addEdges(edges, g); + const svg = root2.select(`[id="${id}"]`); + const element = root2.select("#" + id + " g"); + await render(element, g, ["point", "circle", "cross"], "flowchart", id); + utils.insertTitle(svg, "flowchartTitleText", conf2.titleTopMargin, diagObj.db.getDiagramTitle()); + setupGraphViewbox(g, svg, conf2.diagramPadding, conf2.useMaxWidth); + diagObj.db.indexNodes("subGraph" + i); + if (!conf2.htmlLabels) { + const labels = doc.querySelectorAll('[id="' + id + '"] .edgeLabel .label'); + for (const label of labels) { + const dim = label.getBBox(); + const rect = doc.createElementNS("http://www.w3.org/2000/svg", "rect"); + rect.setAttribute("rx", 0); + rect.setAttribute("ry", 0); + rect.setAttribute("width", dim.width); + rect.setAttribute("height", dim.height); + label.insertBefore(rect, label.firstChild); + } + } + const keys = Object.keys(vert); + keys.forEach(function(key) { + const vertex = vert[key]; + if (vertex.link) { + const node = d3select("#" + id + ' [id="' + key + '"]'); + if (node) { + const link = doc.createElementNS("http://www.w3.org/2000/svg", "a"); + link.setAttributeNS("http://www.w3.org/2000/svg", "class", vertex.classes.join(" ")); + link.setAttributeNS("http://www.w3.org/2000/svg", "href", vertex.link); + link.setAttributeNS("http://www.w3.org/2000/svg", "rel", "noopener"); + if (securityLevel === "sandbox") { + link.setAttributeNS("http://www.w3.org/2000/svg", "target", "_top"); + } else if (vertex.linkTarget) { + link.setAttributeNS("http://www.w3.org/2000/svg", "target", vertex.linkTarget); + } + const linkNode = node.insert(function() { + return link; + }, ":first-child"); + const shape = node.select(".label-container"); + if (shape) { + linkNode.append(function() { + return shape.node(); + }); + } + const label = node.select(".label"); + if (label) { + linkNode.append(function() { + return label.node(); + }); + } + } + } + }); +}; +const flowRendererV2 = { + setConf, + addVertices, + addEdges, + getClasses, + draw +}; +const fade = (color, opacity) => { + const channel$1 = channel; + const r = channel$1(color, "r"); + const g = channel$1(color, "g"); + const b = channel$1(color, "b"); + return rgba(r, g, b, opacity); +}; +const getStyles = (options) => `.label { + font-family: ${options.fontFamily}; + color: ${options.nodeTextColor || options.textColor}; + } + .cluster-label text { + fill: ${options.titleColor}; + } + .cluster-label span,p { + color: ${options.titleColor}; + } + + .label text,span,p { + fill: ${options.nodeTextColor || options.textColor}; + color: ${options.nodeTextColor || options.textColor}; + } + + .node rect, + .node circle, + .node ellipse, + .node polygon, + .node path { + fill: ${options.mainBkg}; + stroke: ${options.nodeBorder}; + stroke-width: 1px; + } + .flowchart-label text { + text-anchor: middle; + } + // .flowchart-label .text-outer-tspan { + // text-anchor: middle; + // } + // .flowchart-label .text-inner-tspan { + // text-anchor: start; + // } + + .node .katex path { + fill: #000; + stroke: #000; + stroke-width: 1px; + } + + .node .label { + text-align: center; + } + .node.clickable { + cursor: pointer; + } + + .arrowheadPath { + fill: ${options.arrowheadColor}; + } + + .edgePath .path { + stroke: ${options.lineColor}; + stroke-width: 2.0px; + } + + .flowchart-link { + stroke: ${options.lineColor}; + fill: none; + } + + .edgeLabel { + background-color: ${options.edgeLabelBackground}; + rect { + opacity: 0.5; + background-color: ${options.edgeLabelBackground}; + fill: ${options.edgeLabelBackground}; + } + text-align: center; + } + + /* For html labels only */ + .labelBkg { + background-color: ${fade(options.edgeLabelBackground, 0.5)}; + // background-color: + } + + .cluster rect { + fill: ${options.clusterBkg}; + stroke: ${options.clusterBorder}; + stroke-width: 1px; + } + + .cluster text { + fill: ${options.titleColor}; + } + + .cluster span,p { + color: ${options.titleColor}; + } + /* .cluster div { + color: ${options.titleColor}; + } */ + + div.mermaidTooltip { + position: absolute; + text-align: center; + max-width: 200px; + padding: 2px; + font-family: ${options.fontFamily}; + font-size: 12px; + background: ${options.tertiaryColor}; + border: 1px solid ${options.border2}; + border-radius: 2px; + pointer-events: none; + z-index: 100; + } + + .flowchartTitleText { + text-anchor: middle; + font-size: 18px; + fill: ${options.textColor}; + } +`; +const flowStyles = getStyles; +export { + applyStyle as a, + addHtmlLabel as b, + applyTransition as c, + applyClass as d, + edgeToId as e, + flowRendererV2 as f, + flowStyles as g, + isSubgraph as i, + selectAll as s +}; diff --git a/0.6.0/js/mermaid/styles-b83b31c9.js b/0.6.0/js/mermaid/styles-b83b31c9.js new file mode 100644 index 0000000..0f1b7dd --- /dev/null +++ b/0.6.0/js/mermaid/styles-b83b31c9.js @@ -0,0 +1,1484 @@ +import { select } from "d3"; +import { d as sanitizeText$1, c as getConfig, x as parseGenericTypes, s as setAccTitle, g as getAccTitle, a as getAccDescription, b as setAccDescription, q as setDiagramTitle, t as getDiagramTitle, e as common, v as clear$1, l as log, u as utils } from "./mermaid-6dc72991.js"; +var parser = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 17], $V1 = [1, 18], $V2 = [1, 19], $V3 = [1, 39], $V4 = [1, 40], $V5 = [1, 25], $V6 = [1, 23], $V7 = [1, 24], $V8 = [1, 31], $V9 = [1, 32], $Va = [1, 33], $Vb = [1, 34], $Vc = [1, 35], $Vd = [1, 36], $Ve = [1, 26], $Vf = [1, 27], $Vg = [1, 28], $Vh = [1, 29], $Vi = [1, 43], $Vj = [1, 30], $Vk = [1, 42], $Vl = [1, 44], $Vm = [1, 41], $Vn = [1, 45], $Vo = [1, 9], $Vp = [1, 8, 9], $Vq = [1, 56], $Vr = [1, 57], $Vs = [1, 58], $Vt = [1, 59], $Vu = [1, 60], $Vv = [1, 61], $Vw = [1, 62], $Vx = [1, 8, 9, 39], $Vy = [1, 74], $Vz = [1, 8, 9, 12, 13, 21, 37, 39, 42, 59, 60, 61, 62, 63, 64, 65, 70, 72], $VA = [1, 8, 9, 12, 13, 19, 21, 37, 39, 42, 46, 59, 60, 61, 62, 63, 64, 65, 70, 72, 74, 80, 95, 97, 98], $VB = [13, 74, 80, 95, 97, 98], $VC = [13, 64, 65, 74, 80, 95, 97, 98], $VD = [13, 59, 60, 61, 62, 63, 74, 80, 95, 97, 98], $VE = [1, 93], $VF = [1, 110], $VG = [1, 108], $VH = [1, 102], $VI = [1, 103], $VJ = [1, 104], $VK = [1, 105], $VL = [1, 106], $VM = [1, 107], $VN = [1, 109], $VO = [1, 8, 9, 37, 39, 42], $VP = [1, 8, 9, 21], $VQ = [1, 8, 9, 78], $VR = [1, 8, 9, 21, 73, 74, 78, 80, 81, 82, 83, 84, 85]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "mermaidDoc": 4, "statements": 5, "graphConfig": 6, "CLASS_DIAGRAM": 7, "NEWLINE": 8, "EOF": 9, "statement": 10, "classLabel": 11, "SQS": 12, "STR": 13, "SQE": 14, "namespaceName": 15, "alphaNumToken": 16, "className": 17, "classLiteralName": 18, "GENERICTYPE": 19, "relationStatement": 20, "LABEL": 21, "namespaceStatement": 22, "classStatement": 23, "memberStatement": 24, "annotationStatement": 25, "clickStatement": 26, "styleStatement": 27, "cssClassStatement": 28, "noteStatement": 29, "direction": 30, "acc_title": 31, "acc_title_value": 32, "acc_descr": 33, "acc_descr_value": 34, "acc_descr_multiline_value": 35, "namespaceIdentifier": 36, "STRUCT_START": 37, "classStatements": 38, "STRUCT_STOP": 39, "NAMESPACE": 40, "classIdentifier": 41, "STYLE_SEPARATOR": 42, "members": 43, "CLASS": 44, "ANNOTATION_START": 45, "ANNOTATION_END": 46, "MEMBER": 47, "SEPARATOR": 48, "relation": 49, "NOTE_FOR": 50, "noteText": 51, "NOTE": 52, "direction_tb": 53, "direction_bt": 54, "direction_rl": 55, "direction_lr": 56, "relationType": 57, "lineType": 58, "AGGREGATION": 59, "EXTENSION": 60, "COMPOSITION": 61, "DEPENDENCY": 62, "LOLLIPOP": 63, "LINE": 64, "DOTTED_LINE": 65, "CALLBACK": 66, "LINK": 67, "LINK_TARGET": 68, "CLICK": 69, "CALLBACK_NAME": 70, "CALLBACK_ARGS": 71, "HREF": 72, "STYLE": 73, "ALPHA": 74, "stylesOpt": 75, "CSSCLASS": 76, "style": 77, "COMMA": 78, "styleComponent": 79, "NUM": 80, "COLON": 81, "UNIT": 82, "SPACE": 83, "BRKT": 84, "PCT": 85, "commentToken": 86, "textToken": 87, "graphCodeTokens": 88, "textNoTagsToken": 89, "TAGSTART": 90, "TAGEND": 91, "==": 92, "--": 93, "DEFAULT": 94, "MINUS": 95, "keywords": 96, "UNICODE_TEXT": 97, "BQUOTE_STR": 98, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 7: "CLASS_DIAGRAM", 8: "NEWLINE", 9: "EOF", 12: "SQS", 13: "STR", 14: "SQE", 19: "GENERICTYPE", 21: "LABEL", 31: "acc_title", 32: "acc_title_value", 33: "acc_descr", 34: "acc_descr_value", 35: "acc_descr_multiline_value", 37: "STRUCT_START", 39: "STRUCT_STOP", 40: "NAMESPACE", 42: "STYLE_SEPARATOR", 44: "CLASS", 45: "ANNOTATION_START", 46: "ANNOTATION_END", 47: "MEMBER", 48: "SEPARATOR", 50: "NOTE_FOR", 52: "NOTE", 53: "direction_tb", 54: "direction_bt", 55: "direction_rl", 56: "direction_lr", 59: "AGGREGATION", 60: "EXTENSION", 61: "COMPOSITION", 62: "DEPENDENCY", 63: "LOLLIPOP", 64: "LINE", 65: "DOTTED_LINE", 66: "CALLBACK", 67: "LINK", 68: "LINK_TARGET", 69: "CLICK", 70: "CALLBACK_NAME", 71: "CALLBACK_ARGS", 72: "HREF", 73: "STYLE", 74: "ALPHA", 76: "CSSCLASS", 78: "COMMA", 80: "NUM", 81: "COLON", 82: "UNIT", 83: "SPACE", 84: "BRKT", 85: "PCT", 88: "graphCodeTokens", 90: "TAGSTART", 91: "TAGEND", 92: "==", 93: "--", 94: "DEFAULT", 95: "MINUS", 96: "keywords", 97: "UNICODE_TEXT", 98: "BQUOTE_STR" }, + productions_: [0, [3, 1], [3, 1], [4, 1], [6, 4], [5, 1], [5, 2], [5, 3], [11, 3], [15, 1], [15, 2], [17, 1], [17, 1], [17, 2], [17, 2], [17, 2], [10, 1], [10, 2], [10, 1], [10, 1], [10, 1], [10, 1], [10, 1], [10, 1], [10, 1], [10, 1], [10, 1], [10, 2], [10, 2], [10, 1], [22, 4], [22, 5], [36, 2], [38, 1], [38, 2], [38, 3], [23, 1], [23, 3], [23, 4], [23, 6], [41, 2], [41, 3], [25, 4], [43, 1], [43, 2], [24, 1], [24, 2], [24, 1], [24, 1], [20, 3], [20, 4], [20, 4], [20, 5], [29, 3], [29, 2], [30, 1], [30, 1], [30, 1], [30, 1], [49, 3], [49, 2], [49, 2], [49, 1], [57, 1], [57, 1], [57, 1], [57, 1], [57, 1], [58, 1], [58, 1], [26, 3], [26, 4], [26, 3], [26, 4], [26, 4], [26, 5], [26, 3], [26, 4], [26, 4], [26, 5], [26, 4], [26, 5], [26, 5], [26, 6], [27, 3], [28, 3], [75, 1], [75, 3], [77, 1], [77, 2], [79, 1], [79, 1], [79, 1], [79, 1], [79, 1], [79, 1], [79, 1], [79, 1], [79, 1], [86, 1], [86, 1], [87, 1], [87, 1], [87, 1], [87, 1], [87, 1], [87, 1], [87, 1], [89, 1], [89, 1], [89, 1], [89, 1], [16, 1], [16, 1], [16, 1], [16, 1], [18, 1], [51, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 8: + this.$ = $$[$0 - 1]; + break; + case 9: + case 11: + case 12: + this.$ = $$[$0]; + break; + case 10: + case 13: + this.$ = $$[$0 - 1] + $$[$0]; + break; + case 14: + case 15: + this.$ = $$[$0 - 1] + "~" + $$[$0] + "~"; + break; + case 16: + yy.addRelation($$[$0]); + break; + case 17: + $$[$0 - 1].title = yy.cleanupLabel($$[$0]); + yy.addRelation($$[$0 - 1]); + break; + case 27: + this.$ = $$[$0].trim(); + yy.setAccTitle(this.$); + break; + case 28: + case 29: + this.$ = $$[$0].trim(); + yy.setAccDescription(this.$); + break; + case 30: + yy.addClassesToNamespace($$[$0 - 3], $$[$0 - 1]); + break; + case 31: + yy.addClassesToNamespace($$[$0 - 4], $$[$0 - 1]); + break; + case 32: + this.$ = $$[$0]; + yy.addNamespace($$[$0]); + break; + case 33: + this.$ = [$$[$0]]; + break; + case 34: + this.$ = [$$[$0 - 1]]; + break; + case 35: + $$[$0].unshift($$[$0 - 2]); + this.$ = $$[$0]; + break; + case 37: + yy.setCssClass($$[$0 - 2], $$[$0]); + break; + case 38: + yy.addMembers($$[$0 - 3], $$[$0 - 1]); + break; + case 39: + yy.setCssClass($$[$0 - 5], $$[$0 - 3]); + yy.addMembers($$[$0 - 5], $$[$0 - 1]); + break; + case 40: + this.$ = $$[$0]; + yy.addClass($$[$0]); + break; + case 41: + this.$ = $$[$0 - 1]; + yy.addClass($$[$0 - 1]); + yy.setClassLabel($$[$0 - 1], $$[$0]); + break; + case 42: + yy.addAnnotation($$[$0], $$[$0 - 2]); + break; + case 43: + this.$ = [$$[$0]]; + break; + case 44: + $$[$0].push($$[$0 - 1]); + this.$ = $$[$0]; + break; + case 45: + break; + case 46: + yy.addMember($$[$0 - 1], yy.cleanupLabel($$[$0])); + break; + case 47: + break; + case 48: + break; + case 49: + this.$ = { "id1": $$[$0 - 2], "id2": $$[$0], relation: $$[$0 - 1], relationTitle1: "none", relationTitle2: "none" }; + break; + case 50: + this.$ = { id1: $$[$0 - 3], id2: $$[$0], relation: $$[$0 - 1], relationTitle1: $$[$0 - 2], relationTitle2: "none" }; + break; + case 51: + this.$ = { id1: $$[$0 - 3], id2: $$[$0], relation: $$[$0 - 2], relationTitle1: "none", relationTitle2: $$[$0 - 1] }; + break; + case 52: + this.$ = { id1: $$[$0 - 4], id2: $$[$0], relation: $$[$0 - 2], relationTitle1: $$[$0 - 3], relationTitle2: $$[$0 - 1] }; + break; + case 53: + yy.addNote($$[$0], $$[$0 - 1]); + break; + case 54: + yy.addNote($$[$0]); + break; + case 55: + yy.setDirection("TB"); + break; + case 56: + yy.setDirection("BT"); + break; + case 57: + yy.setDirection("RL"); + break; + case 58: + yy.setDirection("LR"); + break; + case 59: + this.$ = { type1: $$[$0 - 2], type2: $$[$0], lineType: $$[$0 - 1] }; + break; + case 60: + this.$ = { type1: "none", type2: $$[$0], lineType: $$[$0 - 1] }; + break; + case 61: + this.$ = { type1: $$[$0 - 1], type2: "none", lineType: $$[$0] }; + break; + case 62: + this.$ = { type1: "none", type2: "none", lineType: $$[$0] }; + break; + case 63: + this.$ = yy.relationType.AGGREGATION; + break; + case 64: + this.$ = yy.relationType.EXTENSION; + break; + case 65: + this.$ = yy.relationType.COMPOSITION; + break; + case 66: + this.$ = yy.relationType.DEPENDENCY; + break; + case 67: + this.$ = yy.relationType.LOLLIPOP; + break; + case 68: + this.$ = yy.lineType.LINE; + break; + case 69: + this.$ = yy.lineType.DOTTED_LINE; + break; + case 70: + case 76: + this.$ = $$[$0 - 2]; + yy.setClickEvent($$[$0 - 1], $$[$0]); + break; + case 71: + case 77: + this.$ = $$[$0 - 3]; + yy.setClickEvent($$[$0 - 2], $$[$0 - 1]); + yy.setTooltip($$[$0 - 2], $$[$0]); + break; + case 72: + this.$ = $$[$0 - 2]; + yy.setLink($$[$0 - 1], $$[$0]); + break; + case 73: + this.$ = $$[$0 - 3]; + yy.setLink($$[$0 - 2], $$[$0 - 1], $$[$0]); + break; + case 74: + this.$ = $$[$0 - 3]; + yy.setLink($$[$0 - 2], $$[$0 - 1]); + yy.setTooltip($$[$0 - 2], $$[$0]); + break; + case 75: + this.$ = $$[$0 - 4]; + yy.setLink($$[$0 - 3], $$[$0 - 2], $$[$0]); + yy.setTooltip($$[$0 - 3], $$[$0 - 1]); + break; + case 78: + this.$ = $$[$0 - 3]; + yy.setClickEvent($$[$0 - 2], $$[$0 - 1], $$[$0]); + break; + case 79: + this.$ = $$[$0 - 4]; + yy.setClickEvent($$[$0 - 3], $$[$0 - 2], $$[$0 - 1]); + yy.setTooltip($$[$0 - 3], $$[$0]); + break; + case 80: + this.$ = $$[$0 - 3]; + yy.setLink($$[$0 - 2], $$[$0]); + break; + case 81: + this.$ = $$[$0 - 4]; + yy.setLink($$[$0 - 3], $$[$0 - 1], $$[$0]); + break; + case 82: + this.$ = $$[$0 - 4]; + yy.setLink($$[$0 - 3], $$[$0 - 1]); + yy.setTooltip($$[$0 - 3], $$[$0]); + break; + case 83: + this.$ = $$[$0 - 5]; + yy.setLink($$[$0 - 4], $$[$0 - 2], $$[$0]); + yy.setTooltip($$[$0 - 4], $$[$0 - 1]); + break; + case 84: + this.$ = $$[$0 - 2]; + yy.setCssStyle($$[$0 - 1], $$[$0]); + break; + case 85: + yy.setCssClass($$[$0 - 1], $$[$0]); + break; + case 86: + this.$ = [$$[$0]]; + break; + case 87: + $$[$0 - 2].push($$[$0]); + this.$ = $$[$0 - 2]; + break; + case 89: + this.$ = $$[$0 - 1] + $$[$0]; + break; + } + }, + table: [{ 3: 1, 4: 2, 5: 3, 6: 4, 7: [1, 6], 10: 5, 16: 37, 17: 20, 18: 38, 20: 7, 22: 8, 23: 9, 24: 10, 25: 11, 26: 12, 27: 13, 28: 14, 29: 15, 30: 16, 31: $V0, 33: $V1, 35: $V2, 36: 21, 40: $V3, 41: 22, 44: $V4, 45: $V5, 47: $V6, 48: $V7, 50: $V8, 52: $V9, 53: $Va, 54: $Vb, 55: $Vc, 56: $Vd, 66: $Ve, 67: $Vf, 69: $Vg, 73: $Vh, 74: $Vi, 76: $Vj, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, { 1: [3] }, { 1: [2, 1] }, { 1: [2, 2] }, { 1: [2, 3] }, o($Vo, [2, 5], { 8: [1, 46] }), { 8: [1, 47] }, o($Vp, [2, 16], { 21: [1, 48] }), o($Vp, [2, 18]), o($Vp, [2, 19]), o($Vp, [2, 20]), o($Vp, [2, 21]), o($Vp, [2, 22]), o($Vp, [2, 23]), o($Vp, [2, 24]), o($Vp, [2, 25]), o($Vp, [2, 26]), { 32: [1, 49] }, { 34: [1, 50] }, o($Vp, [2, 29]), o($Vp, [2, 45], { 49: 51, 57: 54, 58: 55, 13: [1, 52], 21: [1, 53], 59: $Vq, 60: $Vr, 61: $Vs, 62: $Vt, 63: $Vu, 64: $Vv, 65: $Vw }), { 37: [1, 63] }, o($Vx, [2, 36], { 37: [1, 65], 42: [1, 64] }), o($Vp, [2, 47]), o($Vp, [2, 48]), { 16: 66, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm }, { 16: 37, 17: 67, 18: 38, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, { 16: 37, 17: 68, 18: 38, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, { 16: 37, 17: 69, 18: 38, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, { 74: [1, 70] }, { 13: [1, 71] }, { 16: 37, 17: 72, 18: 38, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, { 13: $Vy, 51: 73 }, o($Vp, [2, 55]), o($Vp, [2, 56]), o($Vp, [2, 57]), o($Vp, [2, 58]), o($Vz, [2, 11], { 16: 37, 18: 38, 17: 75, 19: [1, 76], 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }), o($Vz, [2, 12], { 19: [1, 77] }), { 15: 78, 16: 79, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm }, { 16: 37, 17: 80, 18: 38, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, o($VA, [2, 112]), o($VA, [2, 113]), o($VA, [2, 114]), o($VA, [2, 115]), o([1, 8, 9, 12, 13, 19, 21, 37, 39, 42, 59, 60, 61, 62, 63, 64, 65, 70, 72], [2, 116]), o($Vo, [2, 6], { 10: 5, 20: 7, 22: 8, 23: 9, 24: 10, 25: 11, 26: 12, 27: 13, 28: 14, 29: 15, 30: 16, 17: 20, 36: 21, 41: 22, 16: 37, 18: 38, 5: 81, 31: $V0, 33: $V1, 35: $V2, 40: $V3, 44: $V4, 45: $V5, 47: $V6, 48: $V7, 50: $V8, 52: $V9, 53: $Va, 54: $Vb, 55: $Vc, 56: $Vd, 66: $Ve, 67: $Vf, 69: $Vg, 73: $Vh, 74: $Vi, 76: $Vj, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }), { 5: 82, 10: 5, 16: 37, 17: 20, 18: 38, 20: 7, 22: 8, 23: 9, 24: 10, 25: 11, 26: 12, 27: 13, 28: 14, 29: 15, 30: 16, 31: $V0, 33: $V1, 35: $V2, 36: 21, 40: $V3, 41: 22, 44: $V4, 45: $V5, 47: $V6, 48: $V7, 50: $V8, 52: $V9, 53: $Va, 54: $Vb, 55: $Vc, 56: $Vd, 66: $Ve, 67: $Vf, 69: $Vg, 73: $Vh, 74: $Vi, 76: $Vj, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, o($Vp, [2, 17]), o($Vp, [2, 27]), o($Vp, [2, 28]), { 13: [1, 84], 16: 37, 17: 83, 18: 38, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, { 49: 85, 57: 54, 58: 55, 59: $Vq, 60: $Vr, 61: $Vs, 62: $Vt, 63: $Vu, 64: $Vv, 65: $Vw }, o($Vp, [2, 46]), { 58: 86, 64: $Vv, 65: $Vw }, o($VB, [2, 62], { 57: 87, 59: $Vq, 60: $Vr, 61: $Vs, 62: $Vt, 63: $Vu }), o($VC, [2, 63]), o($VC, [2, 64]), o($VC, [2, 65]), o($VC, [2, 66]), o($VC, [2, 67]), o($VD, [2, 68]), o($VD, [2, 69]), { 8: [1, 89], 23: 90, 38: 88, 41: 22, 44: $V4 }, { 16: 91, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm }, { 43: 92, 47: $VE }, { 46: [1, 94] }, { 13: [1, 95] }, { 13: [1, 96] }, { 70: [1, 97], 72: [1, 98] }, { 21: $VF, 73: $VG, 74: $VH, 75: 99, 77: 100, 79: 101, 80: $VI, 81: $VJ, 82: $VK, 83: $VL, 84: $VM, 85: $VN }, { 74: [1, 111] }, { 13: $Vy, 51: 112 }, o($Vp, [2, 54]), o($Vp, [2, 117]), o($Vz, [2, 13]), o($Vz, [2, 14]), o($Vz, [2, 15]), { 37: [2, 32] }, { 15: 113, 16: 79, 37: [2, 9], 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm }, o($VO, [2, 40], { 11: 114, 12: [1, 115] }), o($Vo, [2, 7]), { 9: [1, 116] }, o($VP, [2, 49]), { 16: 37, 17: 117, 18: 38, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, { 13: [1, 119], 16: 37, 17: 118, 18: 38, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, o($VB, [2, 61], { 57: 120, 59: $Vq, 60: $Vr, 61: $Vs, 62: $Vt, 63: $Vu }), o($VB, [2, 60]), { 39: [1, 121] }, { 23: 90, 38: 122, 41: 22, 44: $V4 }, { 8: [1, 123], 39: [2, 33] }, o($Vx, [2, 37], { 37: [1, 124] }), { 39: [1, 125] }, { 39: [2, 43], 43: 126, 47: $VE }, { 16: 37, 17: 127, 18: 38, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, o($Vp, [2, 70], { 13: [1, 128] }), o($Vp, [2, 72], { 13: [1, 130], 68: [1, 129] }), o($Vp, [2, 76], { 13: [1, 131], 71: [1, 132] }), { 13: [1, 133] }, o($Vp, [2, 84], { 78: [1, 134] }), o($VQ, [2, 86], { 79: 135, 21: $VF, 73: $VG, 74: $VH, 80: $VI, 81: $VJ, 82: $VK, 83: $VL, 84: $VM, 85: $VN }), o($VR, [2, 88]), o($VR, [2, 90]), o($VR, [2, 91]), o($VR, [2, 92]), o($VR, [2, 93]), o($VR, [2, 94]), o($VR, [2, 95]), o($VR, [2, 96]), o($VR, [2, 97]), o($VR, [2, 98]), o($Vp, [2, 85]), o($Vp, [2, 53]), { 37: [2, 10] }, o($VO, [2, 41]), { 13: [1, 136] }, { 1: [2, 4] }, o($VP, [2, 51]), o($VP, [2, 50]), { 16: 37, 17: 137, 18: 38, 74: $Vi, 80: $Vk, 95: $Vl, 97: $Vm, 98: $Vn }, o($VB, [2, 59]), o($Vp, [2, 30]), { 39: [1, 138] }, { 23: 90, 38: 139, 39: [2, 34], 41: 22, 44: $V4 }, { 43: 140, 47: $VE }, o($Vx, [2, 38]), { 39: [2, 44] }, o($Vp, [2, 42]), o($Vp, [2, 71]), o($Vp, [2, 73]), o($Vp, [2, 74], { 68: [1, 141] }), o($Vp, [2, 77]), o($Vp, [2, 78], { 13: [1, 142] }), o($Vp, [2, 80], { 13: [1, 144], 68: [1, 143] }), { 21: $VF, 73: $VG, 74: $VH, 77: 145, 79: 101, 80: $VI, 81: $VJ, 82: $VK, 83: $VL, 84: $VM, 85: $VN }, o($VR, [2, 89]), { 14: [1, 146] }, o($VP, [2, 52]), o($Vp, [2, 31]), { 39: [2, 35] }, { 39: [1, 147] }, o($Vp, [2, 75]), o($Vp, [2, 79]), o($Vp, [2, 81]), o($Vp, [2, 82], { 68: [1, 148] }), o($VQ, [2, 87], { 79: 135, 21: $VF, 73: $VG, 74: $VH, 80: $VI, 81: $VJ, 82: $VK, 83: $VL, 84: $VM, 85: $VN }), o($VO, [2, 8]), o($Vx, [2, 39]), o($Vp, [2, 83])], + defaultActions: { 2: [2, 1], 3: [2, 2], 4: [2, 3], 78: [2, 32], 113: [2, 10], 116: [2, 4], 126: [2, 44], 139: [2, 35] }, + parseError: function parseError(str, hash) { + if (hash.recoverable) { + this.trace(str); + } else { + var error = new Error(str); + error.hash = hash; + throw error; + } + }, + parse: function parse(input) { + var self = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex() { + var token; + token = tstack.pop() || lexer2.lex() || EOF; + if (typeof token !== "number") { + if (token instanceof Array) { + tstack = token; + token = tstack.pop(); + } + token = self.symbols_[token] || token; + } + return token; + } + var symbol, state, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state = stack[stack.length - 1]; + if (this.defaultActions[state]) { + action = this.defaultActions[state]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex(); + } + action = table[state] && table[state][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str, hash); + } else { + throw new Error(str); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch = this._input[0]; + this.yytext += ch; + this.yyleng++; + this.offset++; + this.match += ch; + this.matched += ch; + var lines = ch.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch; + }, + // unshifts one char (or a string) into the input + unput: function(ch) { + var len = ch.length; + var lines = ch.split(/(?:\r\n?|\n)/g); + this._input = ch + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next = this.match; + if (next.length < 20) { + next += this._input.substr(0, 20 - next.length); + } + return (next.substr(0, 20) + (next.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token) { + return token; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token, match, tempMatch, index; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i = 0; i < rules.length; i++) { + tempMatch = this._input.match(this.rules[rules[i]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index = i; + if (this.options.backtrack_lexer) { + token = this.test_match(tempMatch, rules[i]); + if (token !== false) { + return token; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token = this.test_match(match, rules[index]); + if (token !== false) { + return token; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: {}, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + return 53; + case 1: + return 54; + case 2: + return 55; + case 3: + return 56; + case 4: + break; + case 5: + break; + case 6: + this.begin("acc_title"); + return 31; + case 7: + this.popState(); + return "acc_title_value"; + case 8: + this.begin("acc_descr"); + return 33; + case 9: + this.popState(); + return "acc_descr_value"; + case 10: + this.begin("acc_descr_multiline"); + break; + case 11: + this.popState(); + break; + case 12: + return "acc_descr_multiline_value"; + case 13: + return 8; + case 14: + break; + case 15: + return 7; + case 16: + return 7; + case 17: + return "EDGE_STATE"; + case 18: + this.begin("callback_name"); + break; + case 19: + this.popState(); + break; + case 20: + this.popState(); + this.begin("callback_args"); + break; + case 21: + return 70; + case 22: + this.popState(); + break; + case 23: + return 71; + case 24: + this.popState(); + break; + case 25: + return "STR"; + case 26: + this.begin("string"); + break; + case 27: + return 73; + case 28: + this.begin("namespace"); + return 40; + case 29: + this.popState(); + return 8; + case 30: + break; + case 31: + this.begin("namespace-body"); + return 37; + case 32: + this.popState(); + return 39; + case 33: + return "EOF_IN_STRUCT"; + case 34: + return 8; + case 35: + break; + case 36: + return "EDGE_STATE"; + case 37: + this.begin("class"); + return 44; + case 38: + this.popState(); + return 8; + case 39: + break; + case 40: + this.popState(); + this.popState(); + return 39; + case 41: + this.begin("class-body"); + return 37; + case 42: + this.popState(); + return 39; + case 43: + return "EOF_IN_STRUCT"; + case 44: + return "EDGE_STATE"; + case 45: + return "OPEN_IN_STRUCT"; + case 46: + break; + case 47: + return "MEMBER"; + case 48: + return 76; + case 49: + return 66; + case 50: + return 67; + case 51: + return 69; + case 52: + return 50; + case 53: + return 52; + case 54: + return 45; + case 55: + return 46; + case 56: + return 72; + case 57: + this.popState(); + break; + case 58: + return "GENERICTYPE"; + case 59: + this.begin("generic"); + break; + case 60: + this.popState(); + break; + case 61: + return "BQUOTE_STR"; + case 62: + this.begin("bqstring"); + break; + case 63: + return 68; + case 64: + return 68; + case 65: + return 68; + case 66: + return 68; + case 67: + return 60; + case 68: + return 60; + case 69: + return 62; + case 70: + return 62; + case 71: + return 61; + case 72: + return 59; + case 73: + return 63; + case 74: + return 64; + case 75: + return 65; + case 76: + return 21; + case 77: + return 42; + case 78: + return 95; + case 79: + return "DOT"; + case 80: + return "PLUS"; + case 81: + return 81; + case 82: + return 78; + case 83: + return 84; + case 84: + return 84; + case 85: + return 85; + case 86: + return "EQUALS"; + case 87: + return "EQUALS"; + case 88: + return 74; + case 89: + return 12; + case 90: + return 14; + case 91: + return "PUNCTUATION"; + case 92: + return 80; + case 93: + return 97; + case 94: + return 83; + case 95: + return 83; + case 96: + return 9; + } + }, + rules: [/^(?:.*direction\s+TB[^\n]*)/, /^(?:.*direction\s+BT[^\n]*)/, /^(?:.*direction\s+RL[^\n]*)/, /^(?:.*direction\s+LR[^\n]*)/, /^(?:%%(?!\{)*[^\n]*(\r?\n?)+)/, /^(?:%%[^\n]*(\r?\n)*)/, /^(?:accTitle\s*:\s*)/, /^(?:(?!\n||)*[^\n]*)/, /^(?:accDescr\s*:\s*)/, /^(?:(?!\n||)*[^\n]*)/, /^(?:accDescr\s*\{\s*)/, /^(?:[\}])/, /^(?:[^\}]*)/, /^(?:\s*(\r?\n)+)/, /^(?:\s+)/, /^(?:classDiagram-v2\b)/, /^(?:classDiagram\b)/, /^(?:\[\*\])/, /^(?:call[\s]+)/, /^(?:\([\s]*\))/, /^(?:\()/, /^(?:[^(]*)/, /^(?:\))/, /^(?:[^)]*)/, /^(?:["])/, /^(?:[^"]*)/, /^(?:["])/, /^(?:style\b)/, /^(?:namespace\b)/, /^(?:\s*(\r?\n)+)/, /^(?:\s+)/, /^(?:[{])/, /^(?:[}])/, /^(?:$)/, /^(?:\s*(\r?\n)+)/, /^(?:\s+)/, /^(?:\[\*\])/, /^(?:class\b)/, /^(?:\s*(\r?\n)+)/, /^(?:\s+)/, /^(?:[}])/, /^(?:[{])/, /^(?:[}])/, /^(?:$)/, /^(?:\[\*\])/, /^(?:[{])/, /^(?:[\n])/, /^(?:[^{}\n]*)/, /^(?:cssClass\b)/, /^(?:callback\b)/, /^(?:link\b)/, /^(?:click\b)/, /^(?:note for\b)/, /^(?:note\b)/, /^(?:<<)/, /^(?:>>)/, /^(?:href\b)/, /^(?:[~])/, /^(?:[^~]*)/, /^(?:~)/, /^(?:[`])/, /^(?:[^`]+)/, /^(?:[`])/, /^(?:_self\b)/, /^(?:_blank\b)/, /^(?:_parent\b)/, /^(?:_top\b)/, /^(?:\s*<\|)/, /^(?:\s*\|>)/, /^(?:\s*>)/, /^(?:\s*<)/, /^(?:\s*\*)/, /^(?:\s*o\b)/, /^(?:\s*\(\))/, /^(?:--)/, /^(?:\.\.)/, /^(?::{1}[^:\n;]+)/, /^(?::{3})/, /^(?:-)/, /^(?:\.)/, /^(?:\+)/, /^(?::)/, /^(?:,)/, /^(?:#)/, /^(?:#)/, /^(?:%)/, /^(?:=)/, /^(?:=)/, /^(?:\w+)/, /^(?:\[)/, /^(?:\])/, /^(?:[!"#$%&'*+,-.`?\\/])/, /^(?:[0-9]+)/, /^(?:[\u00AA\u00B5\u00BA\u00C0-\u00D6\u00D8-\u00F6]|[\u00F8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377]|[\u037A-\u037D\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5]|[\u03F7-\u0481\u048A-\u0527\u0531-\u0556\u0559\u0561-\u0587\u05D0-\u05EA]|[\u05F0-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE]|[\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA]|[\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u08A0]|[\u08A2-\u08AC\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0977]|[\u0979-\u097F\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2]|[\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u0A05-\u0A0A]|[\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39]|[\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8]|[\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0B05-\u0B0C]|[\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C]|[\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99]|[\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0]|[\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C33\u0C35-\u0C39\u0C3D]|[\u0C58\u0C59\u0C60\u0C61\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3]|[\u0CB5-\u0CB9\u0CBD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D05-\u0D0C\u0D0E-\u0D10]|[\u0D12-\u0D3A\u0D3D\u0D4E\u0D60\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1]|[\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81]|[\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3]|[\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6]|[\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A]|[\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081]|[\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D]|[\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0]|[\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310]|[\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F4\u1401-\u166C]|[\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u1700-\u170C\u170E-\u1711]|[\u1720-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7]|[\u17DC\u1820-\u1877\u1880-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191C]|[\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19C1-\u19C7\u1A00-\u1A16]|[\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4B\u1B83-\u1BA0\u1BAE\u1BAF]|[\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1CE9-\u1CEC]|[\u1CEE-\u1CF1\u1CF5\u1CF6\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D]|[\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D]|[\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3]|[\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F]|[\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128]|[\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2183\u2184]|[\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3]|[\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6]|[\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE]|[\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005\u3006\u3031-\u3035\u303B\u303C]|[\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312D]|[\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FCC]|[\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B]|[\uA640-\uA66E\uA67F-\uA697\uA6A0-\uA6E5\uA717-\uA71F\uA722-\uA788]|[\uA78B-\uA78E\uA790-\uA793\uA7A0-\uA7AA\uA7F8-\uA801\uA803-\uA805]|[\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB]|[\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uAA00-\uAA28]|[\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA80-\uAAAF\uAAB1\uAAB5]|[\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4]|[\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E]|[\uABC0-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D]|[\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36]|[\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D]|[\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC]|[\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF]|[\uFFD2-\uFFD7\uFFDA-\uFFDC])/, /^(?:\s)/, /^(?:\s)/, /^(?:$)/], + conditions: { "namespace-body": { "rules": [26, 32, 33, 34, 35, 36, 37, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "namespace": { "rules": [26, 28, 29, 30, 31, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "class-body": { "rules": [26, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "class": { "rules": [26, 38, 39, 40, 41, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "acc_descr_multiline": { "rules": [11, 12, 26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "acc_descr": { "rules": [9, 26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "acc_title": { "rules": [7, 26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "callback_args": { "rules": [22, 23, 26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "callback_name": { "rules": [19, 20, 21, 26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "href": { "rules": [26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "struct": { "rules": [26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "generic": { "rules": [26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "bqstring": { "rules": [26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "string": { "rules": [24, 25, 26, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 96], "inclusive": false }, "INITIAL": { "rules": [0, 1, 2, 3, 4, 5, 6, 8, 10, 13, 14, 15, 16, 17, 18, 26, 27, 28, 37, 48, 49, 50, 51, 52, 53, 54, 55, 56, 59, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser() { + this.yy = {}; + } + Parser.prototype = parser2; + parser2.Parser = Parser; + return new Parser(); +}(); +parser.parser = parser; +const parser$1 = parser; +const visibilityValues = ["#", "+", "~", "-", ""]; +class ClassMember { + constructor(input, memberType) { + this.memberType = memberType; + this.visibility = ""; + this.classifier = ""; + const sanitizedInput = sanitizeText$1(input, getConfig()); + this.parseMember(sanitizedInput); + } + getDisplayDetails() { + let displayText = this.visibility + parseGenericTypes(this.id); + if (this.memberType === "method") { + displayText += `(${parseGenericTypes(this.parameters.trim())})`; + if (this.returnType) { + displayText += " : " + parseGenericTypes(this.returnType); + } + } + displayText = displayText.trim(); + const cssStyle = this.parseClassifier(); + return { + displayText, + cssStyle + }; + } + parseMember(input) { + let potentialClassifier = ""; + if (this.memberType === "method") { + const methodRegEx = /([#+~-])?(.+)\((.*)\)([\s$*])?(.*)([$*])?/; + const match = input.match(methodRegEx); + if (match) { + const detectedVisibility = match[1] ? match[1].trim() : ""; + if (visibilityValues.includes(detectedVisibility)) { + this.visibility = detectedVisibility; + } + this.id = match[2].trim(); + this.parameters = match[3] ? match[3].trim() : ""; + potentialClassifier = match[4] ? match[4].trim() : ""; + this.returnType = match[5] ? match[5].trim() : ""; + if (potentialClassifier === "") { + const lastChar = this.returnType.substring(this.returnType.length - 1); + if (lastChar.match(/[$*]/)) { + potentialClassifier = lastChar; + this.returnType = this.returnType.substring(0, this.returnType.length - 1); + } + } + } + } else { + const length = input.length; + const firstChar = input.substring(0, 1); + const lastChar = input.substring(length - 1); + if (visibilityValues.includes(firstChar)) { + this.visibility = firstChar; + } + if (lastChar.match(/[$*]/)) { + potentialClassifier = lastChar; + } + this.id = input.substring( + this.visibility === "" ? 0 : 1, + potentialClassifier === "" ? length : length - 1 + ); + } + this.classifier = potentialClassifier; + } + parseClassifier() { + switch (this.classifier) { + case "*": + return "font-style:italic;"; + case "$": + return "text-decoration:underline;"; + default: + return ""; + } + } +} +const MERMAID_DOM_ID_PREFIX = "classId-"; +let relations = []; +let classes = {}; +let notes = []; +let classCounter = 0; +let namespaces = {}; +let namespaceCounter = 0; +let functions = []; +const sanitizeText = (txt) => common.sanitizeText(txt, getConfig()); +const splitClassNameAndType = function(_id) { + const id = common.sanitizeText(_id, getConfig()); + let genericType = ""; + let className = id; + if (id.indexOf("~") > 0) { + const split = id.split("~"); + className = sanitizeText(split[0]); + genericType = sanitizeText(split[1]); + } + return { className, type: genericType }; +}; +const setClassLabel = function(_id, label) { + const id = common.sanitizeText(_id, getConfig()); + if (label) { + label = sanitizeText(label); + } + const { className } = splitClassNameAndType(id); + classes[className].label = label; +}; +const addClass = function(_id) { + const id = common.sanitizeText(_id, getConfig()); + const { className, type } = splitClassNameAndType(id); + if (Object.hasOwn(classes, className)) { + return; + } + const name = common.sanitizeText(className, getConfig()); + classes[name] = { + id: name, + type, + label: name, + cssClasses: [], + methods: [], + members: [], + annotations: [], + styles: [], + domId: MERMAID_DOM_ID_PREFIX + name + "-" + classCounter + }; + classCounter++; +}; +const lookUpDomId = function(_id) { + const id = common.sanitizeText(_id, getConfig()); + if (id in classes) { + return classes[id].domId; + } + throw new Error("Class not found: " + id); +}; +const clear = function() { + relations = []; + classes = {}; + notes = []; + functions = []; + functions.push(setupToolTips); + namespaces = {}; + namespaceCounter = 0; + clear$1(); +}; +const getClass = function(id) { + return classes[id]; +}; +const getClasses = function() { + return classes; +}; +const getRelations = function() { + return relations; +}; +const getNotes = function() { + return notes; +}; +const addRelation = function(relation) { + log.debug("Adding relation: " + JSON.stringify(relation)); + addClass(relation.id1); + addClass(relation.id2); + relation.id1 = splitClassNameAndType(relation.id1).className; + relation.id2 = splitClassNameAndType(relation.id2).className; + relation.relationTitle1 = common.sanitizeText(relation.relationTitle1.trim(), getConfig()); + relation.relationTitle2 = common.sanitizeText(relation.relationTitle2.trim(), getConfig()); + relations.push(relation); +}; +const addAnnotation = function(className, annotation) { + const validatedClassName = splitClassNameAndType(className).className; + classes[validatedClassName].annotations.push(annotation); +}; +const addMember = function(className, member) { + addClass(className); + const validatedClassName = splitClassNameAndType(className).className; + const theClass = classes[validatedClassName]; + if (typeof member === "string") { + const memberString = member.trim(); + if (memberString.startsWith("<<") && memberString.endsWith(">>")) { + theClass.annotations.push(sanitizeText(memberString.substring(2, memberString.length - 2))); + } else if (memberString.indexOf(")") > 0) { + theClass.methods.push(new ClassMember(memberString, "method")); + } else if (memberString) { + theClass.members.push(new ClassMember(memberString, "attribute")); + } + } +}; +const addMembers = function(className, members) { + if (Array.isArray(members)) { + members.reverse(); + members.forEach((member) => addMember(className, member)); + } +}; +const addNote = function(text, className) { + const note = { + id: `note${notes.length}`, + class: className, + text + }; + notes.push(note); +}; +const cleanupLabel = function(label) { + if (label.startsWith(":")) { + label = label.substring(1); + } + return sanitizeText(label.trim()); +}; +const setCssClass = function(ids, className) { + ids.split(",").forEach(function(_id) { + let id = _id; + if (_id[0].match(/\d/)) { + id = MERMAID_DOM_ID_PREFIX + id; + } + if (classes[id] !== void 0) { + classes[id].cssClasses.push(className); + } + }); +}; +const setTooltip = function(ids, tooltip) { + ids.split(",").forEach(function(id) { + if (tooltip !== void 0) { + classes[id].tooltip = sanitizeText(tooltip); + } + }); +}; +const getTooltip = function(id, namespace) { + if (namespace) { + return namespaces[namespace].classes[id].tooltip; + } + return classes[id].tooltip; +}; +const setLink = function(ids, linkStr, target) { + const config = getConfig(); + ids.split(",").forEach(function(_id) { + let id = _id; + if (_id[0].match(/\d/)) { + id = MERMAID_DOM_ID_PREFIX + id; + } + if (classes[id] !== void 0) { + classes[id].link = utils.formatUrl(linkStr, config); + if (config.securityLevel === "sandbox") { + classes[id].linkTarget = "_top"; + } else if (typeof target === "string") { + classes[id].linkTarget = sanitizeText(target); + } else { + classes[id].linkTarget = "_blank"; + } + } + }); + setCssClass(ids, "clickable"); +}; +const setClickEvent = function(ids, functionName, functionArgs) { + ids.split(",").forEach(function(id) { + setClickFunc(id, functionName, functionArgs); + classes[id].haveCallback = true; + }); + setCssClass(ids, "clickable"); +}; +const setClickFunc = function(_domId, functionName, functionArgs) { + const domId = common.sanitizeText(_domId, getConfig()); + const config = getConfig(); + if (config.securityLevel !== "loose") { + return; + } + if (functionName === void 0) { + return; + } + const id = domId; + if (classes[id] !== void 0) { + const elemId = lookUpDomId(id); + let argList = []; + if (typeof functionArgs === "string") { + argList = functionArgs.split(/,(?=(?:(?:[^"]*"){2})*[^"]*$)/); + for (let i = 0; i < argList.length; i++) { + let item = argList[i].trim(); + if (item.charAt(0) === '"' && item.charAt(item.length - 1) === '"') { + item = item.substr(1, item.length - 2); + } + argList[i] = item; + } + } + if (argList.length === 0) { + argList.push(elemId); + } + functions.push(function() { + const elem = document.querySelector(`[id="${elemId}"]`); + if (elem !== null) { + elem.addEventListener( + "click", + function() { + utils.runFunc(functionName, ...argList); + }, + false + ); + } + }); + } +}; +const bindFunctions = function(element) { + functions.forEach(function(fun) { + fun(element); + }); +}; +const lineType = { + LINE: 0, + DOTTED_LINE: 1 +}; +const relationType = { + AGGREGATION: 0, + EXTENSION: 1, + COMPOSITION: 2, + DEPENDENCY: 3, + LOLLIPOP: 4 +}; +const setupToolTips = function(element) { + let tooltipElem = select(".mermaidTooltip"); + if ((tooltipElem._groups || tooltipElem)[0][0] === null) { + tooltipElem = select("body").append("div").attr("class", "mermaidTooltip").style("opacity", 0); + } + const svg = select(element).select("svg"); + const nodes = svg.selectAll("g.node"); + nodes.on("mouseover", function() { + const el = select(this); + const title = el.attr("title"); + if (title === null) { + return; + } + const rect = this.getBoundingClientRect(); + tooltipElem.transition().duration(200).style("opacity", ".9"); + tooltipElem.text(el.attr("title")).style("left", window.scrollX + rect.left + (rect.right - rect.left) / 2 + "px").style("top", window.scrollY + rect.top - 14 + document.body.scrollTop + "px"); + tooltipElem.html(tooltipElem.html().replace(/<br\/>/g, "
    ")); + el.classed("hover", true); + }).on("mouseout", function() { + tooltipElem.transition().duration(500).style("opacity", 0); + const el = select(this); + el.classed("hover", false); + }); +}; +functions.push(setupToolTips); +let direction = "TB"; +const getDirection = () => direction; +const setDirection = (dir) => { + direction = dir; +}; +const addNamespace = function(id) { + if (namespaces[id] !== void 0) { + return; + } + namespaces[id] = { + id, + classes: {}, + children: {}, + domId: MERMAID_DOM_ID_PREFIX + id + "-" + namespaceCounter + }; + namespaceCounter++; +}; +const getNamespace = function(name) { + return namespaces[name]; +}; +const getNamespaces = function() { + return namespaces; +}; +const addClassesToNamespace = function(id, classNames) { + if (namespaces[id] === void 0) { + return; + } + for (const name of classNames) { + const { className } = splitClassNameAndType(name); + classes[className].parent = id; + namespaces[id].classes[className] = classes[className]; + } +}; +const setCssStyle = function(id, styles2) { + const thisClass = classes[id]; + if (!styles2 || !thisClass) { + return; + } + for (const s of styles2) { + if (s.includes(",")) { + thisClass.styles.push(...s.split(",")); + } else { + thisClass.styles.push(s); + } + } +}; +const db = { + setAccTitle, + getAccTitle, + getAccDescription, + setAccDescription, + getConfig: () => getConfig().class, + addClass, + bindFunctions, + clear, + getClass, + getClasses, + getNotes, + addAnnotation, + addNote, + getRelations, + addRelation, + getDirection, + setDirection, + addMember, + addMembers, + cleanupLabel, + lineType, + relationType, + setClickEvent, + setCssClass, + setLink, + getTooltip, + setTooltip, + lookUpDomId, + setDiagramTitle, + getDiagramTitle, + setClassLabel, + addNamespace, + addClassesToNamespace, + getNamespace, + getNamespaces, + setCssStyle +}; +const getStyles = (options) => `g.classGroup text { + fill: ${options.nodeBorder || options.classText}; + stroke: none; + font-family: ${options.fontFamily}; + font-size: 10px; + + .title { + font-weight: bolder; + } + +} + +.nodeLabel, .edgeLabel { + color: ${options.classText}; +} +.edgeLabel .label rect { + fill: ${options.mainBkg}; +} +.label text { + fill: ${options.classText}; +} +.edgeLabel .label span { + background: ${options.mainBkg}; +} + +.classTitle { + font-weight: bolder; +} +.node rect, + .node circle, + .node ellipse, + .node polygon, + .node path { + fill: ${options.mainBkg}; + stroke: ${options.nodeBorder}; + stroke-width: 1px; + } + + +.divider { + stroke: ${options.nodeBorder}; + stroke-width: 1; +} + +g.clickable { + cursor: pointer; +} + +g.classGroup rect { + fill: ${options.mainBkg}; + stroke: ${options.nodeBorder}; +} + +g.classGroup line { + stroke: ${options.nodeBorder}; + stroke-width: 1; +} + +.classLabel .box { + stroke: none; + stroke-width: 0; + fill: ${options.mainBkg}; + opacity: 0.5; +} + +.classLabel .label { + fill: ${options.nodeBorder}; + font-size: 10px; +} + +.relation { + stroke: ${options.lineColor}; + stroke-width: 1; + fill: none; +} + +.dashed-line{ + stroke-dasharray: 3; +} + +.dotted-line{ + stroke-dasharray: 1 2; +} + +#compositionStart, .composition { + fill: ${options.lineColor} !important; + stroke: ${options.lineColor} !important; + stroke-width: 1; +} + +#compositionEnd, .composition { + fill: ${options.lineColor} !important; + stroke: ${options.lineColor} !important; + stroke-width: 1; +} + +#dependencyStart, .dependency { + fill: ${options.lineColor} !important; + stroke: ${options.lineColor} !important; + stroke-width: 1; +} + +#dependencyStart, .dependency { + fill: ${options.lineColor} !important; + stroke: ${options.lineColor} !important; + stroke-width: 1; +} + +#extensionStart, .extension { + fill: transparent !important; + stroke: ${options.lineColor} !important; + stroke-width: 1; +} + +#extensionEnd, .extension { + fill: transparent !important; + stroke: ${options.lineColor} !important; + stroke-width: 1; +} + +#aggregationStart, .aggregation { + fill: transparent !important; + stroke: ${options.lineColor} !important; + stroke-width: 1; +} + +#aggregationEnd, .aggregation { + fill: transparent !important; + stroke: ${options.lineColor} !important; + stroke-width: 1; +} + +#lollipopStart, .lollipop { + fill: ${options.mainBkg} !important; + stroke: ${options.lineColor} !important; + stroke-width: 1; +} + +#lollipopEnd, .lollipop { + fill: ${options.mainBkg} !important; + stroke: ${options.lineColor} !important; + stroke-width: 1; +} + +.edgeTerminals { + font-size: 11px; + line-height: initial; +} + +.classTitleText { + text-anchor: middle; + font-size: 18px; + fill: ${options.textColor}; +} +`; +const styles = getStyles; +export { + db as d, + parser$1 as p, + styles as s +}; diff --git a/0.6.0/js/mermaid/styles-cacbff60.js b/0.6.0/js/mermaid/styles-cacbff60.js new file mode 100644 index 0000000..d03fb66 --- /dev/null +++ b/0.6.0/js/mermaid/styles-cacbff60.js @@ -0,0 +1,960 @@ +import { c as Y, g as Ut, s as zt, a as Mt, b as Ht, C as Xt, D as Kt, l as D, f as ot, E as Wt, a7 as Jt } from "./mermaid-9f2aa176.js"; +var gt = function() { + var t = function(C, r, n, i) { + for (n = n || {}, i = C.length; i--; n[C[i]] = r) + ; + return n; + }, s = [1, 2], a = [1, 3], h = [1, 4], f = [2, 4], d = [1, 9], y = [1, 11], k = [1, 15], u = [1, 16], E = [1, 17], T = [1, 18], R = [1, 30], G = [1, 19], j = [1, 20], U = [1, 21], z = [1, 22], M = [1, 23], H = [1, 25], X = [1, 26], K = [1, 27], W = [1, 28], J = [1, 29], q = [1, 32], Q = [1, 33], Z = [1, 34], tt = [1, 35], w = [1, 31], c = [1, 4, 5, 15, 16, 18, 20, 21, 23, 24, 25, 26, 27, 28, 32, 34, 36, 37, 41, 44, 45, 46, 47, 50], et = [1, 4, 5, 13, 14, 15, 16, 18, 20, 21, 23, 24, 25, 26, 27, 28, 32, 34, 36, 37, 41, 44, 45, 46, 47, 50], Dt = [4, 5, 15, 16, 18, 20, 21, 23, 24, 25, 26, 27, 28, 32, 34, 36, 37, 41, 44, 45, 46, 47, 50], ht = { + trace: function() { + }, + yy: {}, + symbols_: { error: 2, start: 3, SPACE: 4, NL: 5, SD: 6, document: 7, line: 8, statement: 9, classDefStatement: 10, cssClassStatement: 11, idStatement: 12, DESCR: 13, "-->": 14, HIDE_EMPTY: 15, scale: 16, WIDTH: 17, COMPOSIT_STATE: 18, STRUCT_START: 19, STRUCT_STOP: 20, STATE_DESCR: 21, AS: 22, ID: 23, FORK: 24, JOIN: 25, CHOICE: 26, CONCURRENT: 27, note: 28, notePosition: 29, NOTE_TEXT: 30, direction: 31, acc_title: 32, acc_title_value: 33, acc_descr: 34, acc_descr_value: 35, acc_descr_multiline_value: 36, classDef: 37, CLASSDEF_ID: 38, CLASSDEF_STYLEOPTS: 39, DEFAULT: 40, class: 41, CLASSENTITY_IDS: 42, STYLECLASS: 43, direction_tb: 44, direction_bt: 45, direction_rl: 46, direction_lr: 47, eol: 48, ";": 49, EDGE_STATE: 50, STYLE_SEPARATOR: 51, left_of: 52, right_of: 53, $accept: 0, $end: 1 }, + terminals_: { 2: "error", 4: "SPACE", 5: "NL", 6: "SD", 13: "DESCR", 14: "-->", 15: "HIDE_EMPTY", 16: "scale", 17: "WIDTH", 18: "COMPOSIT_STATE", 19: "STRUCT_START", 20: "STRUCT_STOP", 21: "STATE_DESCR", 22: "AS", 23: "ID", 24: "FORK", 25: "JOIN", 26: "CHOICE", 27: "CONCURRENT", 28: "note", 30: "NOTE_TEXT", 32: "acc_title", 33: "acc_title_value", 34: "acc_descr", 35: "acc_descr_value", 36: "acc_descr_multiline_value", 37: "classDef", 38: "CLASSDEF_ID", 39: "CLASSDEF_STYLEOPTS", 40: "DEFAULT", 41: "class", 42: "CLASSENTITY_IDS", 43: "STYLECLASS", 44: "direction_tb", 45: "direction_bt", 46: "direction_rl", 47: "direction_lr", 49: ";", 50: "EDGE_STATE", 51: "STYLE_SEPARATOR", 52: "left_of", 53: "right_of" }, + productions_: [0, [3, 2], [3, 2], [3, 2], [7, 0], [7, 2], [8, 2], [8, 1], [8, 1], [9, 1], [9, 1], [9, 1], [9, 2], [9, 3], [9, 4], [9, 1], [9, 2], [9, 1], [9, 4], [9, 3], [9, 6], [9, 1], [9, 1], [9, 1], [9, 1], [9, 4], [9, 4], [9, 1], [9, 2], [9, 2], [9, 1], [10, 3], [10, 3], [11, 3], [31, 1], [31, 1], [31, 1], [31, 1], [48, 1], [48, 1], [12, 1], [12, 1], [12, 3], [12, 3], [29, 1], [29, 1]], + performAction: function(r, n, i, o, p, e, $) { + var l = e.length - 1; + switch (p) { + case 3: + return o.setRootDoc(e[l]), e[l]; + case 4: + this.$ = []; + break; + case 5: + e[l] != "nl" && (e[l - 1].push(e[l]), this.$ = e[l - 1]); + break; + case 6: + case 7: + this.$ = e[l]; + break; + case 8: + this.$ = "nl"; + break; + case 11: + this.$ = e[l]; + break; + case 12: + const B = e[l - 1]; + B.description = o.trimColon(e[l]), this.$ = B; + break; + case 13: + this.$ = { stmt: "relation", state1: e[l - 2], state2: e[l] }; + break; + case 14: + const ft = o.trimColon(e[l]); + this.$ = { stmt: "relation", state1: e[l - 3], state2: e[l - 1], description: ft }; + break; + case 18: + this.$ = { stmt: "state", id: e[l - 3], type: "default", description: "", doc: e[l - 1] }; + break; + case 19: + var A = e[l], O = e[l - 2].trim(); + if (e[l].match(":")) { + var st = e[l].split(":"); + A = st[0], O = [O, st[1]]; + } + this.$ = { stmt: "state", id: A, type: "default", description: O }; + break; + case 20: + this.$ = { stmt: "state", id: e[l - 3], type: "default", description: e[l - 5], doc: e[l - 1] }; + break; + case 21: + this.$ = { stmt: "state", id: e[l], type: "fork" }; + break; + case 22: + this.$ = { stmt: "state", id: e[l], type: "join" }; + break; + case 23: + this.$ = { stmt: "state", id: e[l], type: "choice" }; + break; + case 24: + this.$ = { stmt: "state", id: o.getDividerId(), type: "divider" }; + break; + case 25: + this.$ = { stmt: "state", id: e[l - 1].trim(), note: { position: e[l - 2].trim(), text: e[l].trim() } }; + break; + case 28: + this.$ = e[l].trim(), o.setAccTitle(this.$); + break; + case 29: + case 30: + this.$ = e[l].trim(), o.setAccDescription(this.$); + break; + case 31: + case 32: + this.$ = { stmt: "classDef", id: e[l - 1].trim(), classes: e[l].trim() }; + break; + case 33: + this.$ = { stmt: "applyClass", id: e[l - 1].trim(), styleClass: e[l].trim() }; + break; + case 34: + o.setDirection("TB"), this.$ = { stmt: "dir", value: "TB" }; + break; + case 35: + o.setDirection("BT"), this.$ = { stmt: "dir", value: "BT" }; + break; + case 36: + o.setDirection("RL"), this.$ = { stmt: "dir", value: "RL" }; + break; + case 37: + o.setDirection("LR"), this.$ = { stmt: "dir", value: "LR" }; + break; + case 40: + case 41: + this.$ = { stmt: "state", id: e[l].trim(), type: "default", description: "" }; + break; + case 42: + this.$ = { stmt: "state", id: e[l - 2].trim(), classes: [e[l].trim()], type: "default", description: "" }; + break; + case 43: + this.$ = { stmt: "state", id: e[l - 2].trim(), classes: [e[l].trim()], type: "default", description: "" }; + break; + } + }, + table: [{ 3: 1, 4: s, 5: a, 6: h }, { 1: [3] }, { 3: 5, 4: s, 5: a, 6: h }, { 3: 6, 4: s, 5: a, 6: h }, t([1, 4, 5, 15, 16, 18, 21, 23, 24, 25, 26, 27, 28, 32, 34, 36, 37, 41, 44, 45, 46, 47, 50], f, { 7: 7 }), { 1: [2, 1] }, { 1: [2, 2] }, { 1: [2, 3], 4: d, 5: y, 8: 8, 9: 10, 10: 12, 11: 13, 12: 14, 15: k, 16: u, 18: E, 21: T, 23: R, 24: G, 25: j, 26: U, 27: z, 28: M, 31: 24, 32: H, 34: X, 36: K, 37: W, 41: J, 44: q, 45: Q, 46: Z, 47: tt, 50: w }, t(c, [2, 5]), { 9: 36, 10: 12, 11: 13, 12: 14, 15: k, 16: u, 18: E, 21: T, 23: R, 24: G, 25: j, 26: U, 27: z, 28: M, 31: 24, 32: H, 34: X, 36: K, 37: W, 41: J, 44: q, 45: Q, 46: Z, 47: tt, 50: w }, t(c, [2, 7]), t(c, [2, 8]), t(c, [2, 9]), t(c, [2, 10]), t(c, [2, 11], { 13: [1, 37], 14: [1, 38] }), t(c, [2, 15]), { 17: [1, 39] }, t(c, [2, 17], { 19: [1, 40] }), { 22: [1, 41] }, t(c, [2, 21]), t(c, [2, 22]), t(c, [2, 23]), t(c, [2, 24]), { 29: 42, 30: [1, 43], 52: [1, 44], 53: [1, 45] }, t(c, [2, 27]), { 33: [1, 46] }, { 35: [1, 47] }, t(c, [2, 30]), { 38: [1, 48], 40: [1, 49] }, { 42: [1, 50] }, t(et, [2, 40], { 51: [1, 51] }), t(et, [2, 41], { 51: [1, 52] }), t(c, [2, 34]), t(c, [2, 35]), t(c, [2, 36]), t(c, [2, 37]), t(c, [2, 6]), t(c, [2, 12]), { 12: 53, 23: R, 50: w }, t(c, [2, 16]), t(Dt, f, { 7: 54 }), { 23: [1, 55] }, { 23: [1, 56] }, { 22: [1, 57] }, { 23: [2, 44] }, { 23: [2, 45] }, t(c, [2, 28]), t(c, [2, 29]), { 39: [1, 58] }, { 39: [1, 59] }, { 43: [1, 60] }, { 23: [1, 61] }, { 23: [1, 62] }, t(c, [2, 13], { 13: [1, 63] }), { 4: d, 5: y, 8: 8, 9: 10, 10: 12, 11: 13, 12: 14, 15: k, 16: u, 18: E, 20: [1, 64], 21: T, 23: R, 24: G, 25: j, 26: U, 27: z, 28: M, 31: 24, 32: H, 34: X, 36: K, 37: W, 41: J, 44: q, 45: Q, 46: Z, 47: tt, 50: w }, t(c, [2, 19], { 19: [1, 65] }), { 30: [1, 66] }, { 23: [1, 67] }, t(c, [2, 31]), t(c, [2, 32]), t(c, [2, 33]), t(et, [2, 42]), t(et, [2, 43]), t(c, [2, 14]), t(c, [2, 18]), t(Dt, f, { 7: 68 }), t(c, [2, 25]), t(c, [2, 26]), { 4: d, 5: y, 8: 8, 9: 10, 10: 12, 11: 13, 12: 14, 15: k, 16: u, 18: E, 20: [1, 69], 21: T, 23: R, 24: G, 25: j, 26: U, 27: z, 28: M, 31: 24, 32: H, 34: X, 36: K, 37: W, 41: J, 44: q, 45: Q, 46: Z, 47: tt, 50: w }, t(c, [2, 20])], + defaultActions: { 5: [2, 1], 6: [2, 2], 44: [2, 44], 45: [2, 45] }, + parseError: function(r, n) { + if (n.recoverable) + this.trace(r); + else { + var i = new Error(r); + throw i.hash = n, i; + } + }, + parse: function(r) { + var n = this, i = [0], o = [], p = [null], e = [], $ = this.table, l = "", A = 0, O = 0, st = 2, B = 1, ft = e.slice.call(arguments, 1), S = Object.create(this.lexer), L = { yy: {} }; + for (var dt in this.yy) + Object.prototype.hasOwnProperty.call(this.yy, dt) && (L.yy[dt] = this.yy[dt]); + S.setInput(r, L.yy), L.yy.lexer = S, L.yy.parser = this, typeof S.yylloc > "u" && (S.yylloc = {}); + var yt = S.yylloc; + e.push(yt); + var Gt = S.options && S.options.ranges; + typeof L.yy.parseError == "function" ? this.parseError = L.yy.parseError : this.parseError = Object.getPrototypeOf(this).parseError; + function jt() { + var x; + return x = o.pop() || S.lex() || B, typeof x != "number" && (x instanceof Array && (o = x, x = o.pop()), x = n.symbols_[x] || x), x; + } + for (var _, v, m, pt, N = {}, it, b, Ct, rt; ; ) { + if (v = i[i.length - 1], this.defaultActions[v] ? m = this.defaultActions[v] : ((_ === null || typeof _ > "u") && (_ = jt()), m = $[v] && $[v][_]), typeof m > "u" || !m.length || !m[0]) { + var St = ""; + rt = []; + for (it in $[v]) + this.terminals_[it] && it > st && rt.push("'" + this.terminals_[it] + "'"); + S.showPosition ? St = "Parse error on line " + (A + 1) + `: +` + S.showPosition() + ` +Expecting ` + rt.join(", ") + ", got '" + (this.terminals_[_] || _) + "'" : St = "Parse error on line " + (A + 1) + ": Unexpected " + (_ == B ? "end of input" : "'" + (this.terminals_[_] || _) + "'"), this.parseError(St, { + text: S.match, + token: this.terminals_[_] || _, + line: S.yylineno, + loc: yt, + expected: rt + }); + } + if (m[0] instanceof Array && m.length > 1) + throw new Error("Parse Error: multiple actions possible at state: " + v + ", token: " + _); + switch (m[0]) { + case 1: + i.push(_), p.push(S.yytext), e.push(S.yylloc), i.push(m[1]), _ = null, O = S.yyleng, l = S.yytext, A = S.yylineno, yt = S.yylloc; + break; + case 2: + if (b = this.productions_[m[1]][1], N.$ = p[p.length - b], N._$ = { + first_line: e[e.length - (b || 1)].first_line, + last_line: e[e.length - 1].last_line, + first_column: e[e.length - (b || 1)].first_column, + last_column: e[e.length - 1].last_column + }, Gt && (N._$.range = [ + e[e.length - (b || 1)].range[0], + e[e.length - 1].range[1] + ]), pt = this.performAction.apply(N, [ + l, + O, + A, + L.yy, + m[1], + p, + e + ].concat(ft)), typeof pt < "u") + return pt; + b && (i = i.slice(0, -1 * b * 2), p = p.slice(0, -1 * b), e = e.slice(0, -1 * b)), i.push(this.productions_[m[1]][0]), p.push(N.$), e.push(N._$), Ct = $[i[i.length - 2]][i[i.length - 1]], i.push(Ct); + break; + case 3: + return !0; + } + } + return !0; + } + }, Yt = function() { + var C = { + EOF: 1, + parseError: function(n, i) { + if (this.yy.parser) + this.yy.parser.parseError(n, i); + else + throw new Error(n); + }, + // resets the lexer, sets new input + setInput: function(r, n) { + return this.yy = n || this.yy || {}, this._input = r, 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 r = this._input[0]; + this.yytext += r, this.yyleng++, this.offset++, this.match += r, this.matched += r; + var n = r.match(/(?:\r\n?|\n).*/g); + return n ? (this.yylineno++, this.yylloc.last_line++) : this.yylloc.last_column++, this.options.ranges && this.yylloc.range[1]++, this._input = this._input.slice(1), r; + }, + // unshifts one char (or a string) into the input + unput: function(r) { + var n = r.length, i = r.split(/(?:\r\n?|\n)/g); + this._input = r + this._input, this.yytext = this.yytext.substr(0, this.yytext.length - n), this.offset -= n; + var o = this.match.split(/(?:\r\n?|\n)/g); + this.match = this.match.substr(0, this.match.length - 1), this.matched = this.matched.substr(0, this.matched.length - 1), i.length - 1 && (this.yylineno -= i.length - 1); + var p = 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: i ? (i.length === o.length ? this.yylloc.first_column : 0) + o[o.length - i.length].length - i[0].length : this.yylloc.first_column - n + }, this.options.ranges && (this.yylloc.range = [p[0], p[0] + this.yyleng - n]), 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(r) { + this.unput(this.match.slice(r)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var r = this.matched.substr(0, this.matched.length - this.match.length); + return (r.length > 20 ? "..." : "") + r.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var r = this.match; + return r.length < 20 && (r += this._input.substr(0, 20 - r.length)), (r.substr(0, 20) + (r.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var r = this.pastInput(), n = new Array(r.length + 1).join("-"); + return r + this.upcomingInput() + ` +` + n + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(r, n) { + var i, o, p; + if (this.options.backtrack_lexer && (p = { + 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 && (p.yylloc.range = this.yylloc.range.slice(0))), o = r[0].match(/(?:\r\n?|\n).*/g), o && (this.yylineno += o.length), this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: o ? o[o.length - 1].length - o[o.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + r[0].length + }, this.yytext += r[0], this.match += r[0], this.matches = r, 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(r[0].length), this.matched += r[0], i = this.performAction.call(this, this.yy, this, n, this.conditionStack[this.conditionStack.length - 1]), this.done && this._input && (this.done = !1), i) + return i; + if (this._backtrack) { + for (var e in p) + this[e] = p[e]; + return !1; + } + return !1; + }, + // return next match in input + next: function() { + if (this.done) + return this.EOF; + this._input || (this.done = !0); + var r, n, i, o; + this._more || (this.yytext = "", this.match = ""); + for (var p = this._currentRules(), e = 0; e < p.length; e++) + if (i = this._input.match(this.rules[p[e]]), i && (!n || i[0].length > n[0].length)) { + if (n = i, o = e, this.options.backtrack_lexer) { + if (r = this.test_match(i, p[e]), r !== !1) + return r; + if (this._backtrack) { + n = !1; + continue; + } else + return !1; + } else if (!this.options.flex) + break; + } + return n ? (r = this.test_match(n, p[o]), r !== !1 ? r : !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 n = this.next(); + return n || this.lex(); + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function(n) { + this.conditionStack.push(n); + }, + // pop the previously active lexer condition state off the condition stack + popState: function() { + var n = this.conditionStack.length - 1; + return n > 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(n) { + return n = this.conditionStack.length - 1 - Math.abs(n || 0), n >= 0 ? this.conditionStack[n] : "INITIAL"; + }, + // alias for begin(condition) + pushState: function(n) { + this.begin(n); + }, + // return the number of states currently on the stack + stateStackSize: function() { + return this.conditionStack.length; + }, + options: { "case-insensitive": !0 }, + performAction: function(n, i, o, p) { + switch (o) { + case 0: + return 40; + case 1: + return 44; + case 2: + return 45; + case 3: + return 46; + case 4: + return 47; + case 5: + break; + case 6: + break; + case 7: + return 5; + case 8: + break; + case 9: + break; + case 10: + break; + case 11: + break; + case 12: + return this.pushState("SCALE"), 16; + case 13: + return 17; + case 14: + this.popState(); + break; + case 15: + return this.begin("acc_title"), 32; + case 16: + return this.popState(), "acc_title_value"; + case 17: + return this.begin("acc_descr"), 34; + case 18: + return this.popState(), "acc_descr_value"; + case 19: + this.begin("acc_descr_multiline"); + break; + case 20: + this.popState(); + break; + case 21: + return "acc_descr_multiline_value"; + case 22: + return this.pushState("CLASSDEF"), 37; + case 23: + return this.popState(), this.pushState("CLASSDEFID"), "DEFAULT_CLASSDEF_ID"; + case 24: + return this.popState(), this.pushState("CLASSDEFID"), 38; + case 25: + return this.popState(), 39; + case 26: + return this.pushState("CLASS"), 41; + case 27: + return this.popState(), this.pushState("CLASS_STYLE"), 42; + case 28: + return this.popState(), 43; + case 29: + return this.pushState("SCALE"), 16; + case 30: + return 17; + case 31: + this.popState(); + break; + case 32: + this.pushState("STATE"); + break; + case 33: + return this.popState(), i.yytext = i.yytext.slice(0, -8).trim(), 24; + case 34: + return this.popState(), i.yytext = i.yytext.slice(0, -8).trim(), 25; + case 35: + return this.popState(), i.yytext = i.yytext.slice(0, -10).trim(), 26; + case 36: + return this.popState(), i.yytext = i.yytext.slice(0, -8).trim(), 24; + case 37: + return this.popState(), i.yytext = i.yytext.slice(0, -8).trim(), 25; + case 38: + return this.popState(), i.yytext = i.yytext.slice(0, -10).trim(), 26; + case 39: + return 44; + case 40: + return 45; + case 41: + return 46; + case 42: + return 47; + case 43: + this.pushState("STATE_STRING"); + break; + case 44: + return this.pushState("STATE_ID"), "AS"; + case 45: + return this.popState(), "ID"; + case 46: + this.popState(); + break; + case 47: + return "STATE_DESCR"; + case 48: + return 18; + case 49: + this.popState(); + break; + case 50: + return this.popState(), this.pushState("struct"), 19; + case 51: + break; + case 52: + return this.popState(), 20; + case 53: + break; + case 54: + return this.begin("NOTE"), 28; + case 55: + return this.popState(), this.pushState("NOTE_ID"), 52; + case 56: + return this.popState(), this.pushState("NOTE_ID"), 53; + case 57: + this.popState(), this.pushState("FLOATING_NOTE"); + break; + case 58: + return this.popState(), this.pushState("FLOATING_NOTE_ID"), "AS"; + case 59: + break; + case 60: + return "NOTE_TEXT"; + case 61: + return this.popState(), "ID"; + case 62: + return this.popState(), this.pushState("NOTE_TEXT"), 23; + case 63: + return this.popState(), i.yytext = i.yytext.substr(2).trim(), 30; + case 64: + return this.popState(), i.yytext = i.yytext.slice(0, -8).trim(), 30; + case 65: + return 6; + case 66: + return 6; + case 67: + return 15; + case 68: + return 50; + case 69: + return 23; + case 70: + return i.yytext = i.yytext.trim(), 13; + case 71: + return 14; + case 72: + return 27; + case 73: + return 51; + case 74: + return 5; + case 75: + return "INVALID"; + } + }, + rules: [/^(?:default\b)/i, /^(?:.*direction\s+TB[^\n]*)/i, /^(?:.*direction\s+BT[^\n]*)/i, /^(?:.*direction\s+RL[^\n]*)/i, /^(?:.*direction\s+LR[^\n]*)/i, /^(?:%%(?!\{)[^\n]*)/i, /^(?:[^\}]%%[^\n]*)/i, /^(?:[\n]+)/i, /^(?:[\s]+)/i, /^(?:((?!\n)\s)+)/i, /^(?:#[^\n]*)/i, /^(?:%[^\n]*)/i, /^(?:scale\s+)/i, /^(?:\d+)/i, /^(?:\s+width\b)/i, /^(?:accTitle\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*\{\s*)/i, /^(?:[\}])/i, /^(?:[^\}]*)/i, /^(?:classDef\s+)/i, /^(?:DEFAULT\s+)/i, /^(?:\w+\s+)/i, /^(?:[^\n]*)/i, /^(?:class\s+)/i, /^(?:(\w+)+((,\s*\w+)*))/i, /^(?:[^\n]*)/i, /^(?:scale\s+)/i, /^(?:\d+)/i, /^(?:\s+width\b)/i, /^(?:state\s+)/i, /^(?:.*<>)/i, /^(?:.*<>)/i, /^(?:.*<>)/i, /^(?:.*\[\[fork\]\])/i, /^(?:.*\[\[join\]\])/i, /^(?:.*\[\[choice\]\])/i, /^(?:.*direction\s+TB[^\n]*)/i, /^(?:.*direction\s+BT[^\n]*)/i, /^(?:.*direction\s+RL[^\n]*)/i, /^(?:.*direction\s+LR[^\n]*)/i, /^(?:["])/i, /^(?:\s*as\s+)/i, /^(?:[^\n\{]*)/i, /^(?:["])/i, /^(?:[^"]*)/i, /^(?:[^\n\s\{]+)/i, /^(?:\n)/i, /^(?:\{)/i, /^(?:%%(?!\{)[^\n]*)/i, /^(?:\})/i, /^(?:[\n])/i, /^(?:note\s+)/i, /^(?:left of\b)/i, /^(?:right of\b)/i, /^(?:")/i, /^(?:\s*as\s*)/i, /^(?:["])/i, /^(?:[^"]*)/i, /^(?:[^\n]*)/i, /^(?:\s*[^:\n\s\-]+)/i, /^(?:\s*:[^:\n;]+)/i, /^(?:[\s\S]*?end note\b)/i, /^(?:stateDiagram\s+)/i, /^(?:stateDiagram-v2\s+)/i, /^(?:hide empty description\b)/i, /^(?:\[\*\])/i, /^(?:[^:\n\s\-\{]+)/i, /^(?:\s*:[^:\n;]+)/i, /^(?:-->)/i, /^(?:--)/i, /^(?::::)/i, /^(?:$)/i, /^(?:.)/i], + conditions: { LINE: { rules: [9, 10], inclusive: !1 }, struct: { rules: [9, 10, 22, 26, 32, 39, 40, 41, 42, 51, 52, 53, 54, 68, 69, 70, 71, 72], inclusive: !1 }, FLOATING_NOTE_ID: { rules: [61], inclusive: !1 }, FLOATING_NOTE: { rules: [58, 59, 60], inclusive: !1 }, NOTE_TEXT: { rules: [63, 64], inclusive: !1 }, NOTE_ID: { rules: [62], inclusive: !1 }, NOTE: { rules: [55, 56, 57], inclusive: !1 }, CLASS_STYLE: { rules: [28], inclusive: !1 }, CLASS: { rules: [27], inclusive: !1 }, CLASSDEFID: { rules: [25], inclusive: !1 }, CLASSDEF: { rules: [23, 24], inclusive: !1 }, acc_descr_multiline: { rules: [20, 21], inclusive: !1 }, acc_descr: { rules: [18], inclusive: !1 }, acc_title: { rules: [16], inclusive: !1 }, SCALE: { rules: [13, 14, 30, 31], inclusive: !1 }, ALIAS: { rules: [], inclusive: !1 }, STATE_ID: { rules: [45], inclusive: !1 }, STATE_STRING: { rules: [46, 47], inclusive: !1 }, FORK_STATE: { rules: [], inclusive: !1 }, STATE: { rules: [9, 10, 33, 34, 35, 36, 37, 38, 43, 44, 48, 49, 50], inclusive: !1 }, ID: { rules: [9, 10], inclusive: !1 }, INITIAL: { rules: [0, 1, 2, 3, 4, 5, 6, 7, 8, 10, 11, 12, 15, 17, 19, 22, 26, 29, 32, 50, 54, 65, 66, 67, 68, 69, 70, 71, 73, 74, 75], inclusive: !0 } } + }; + return C; + }(); + ht.lexer = Yt; + function ut() { + this.yy = {}; + } + return ut.prototype = ht, ht.Parser = ut, new ut(); +}(); +gt.parser = gt; +const De = gt, qt = "LR", Ce = "TB", _t = "state", It = "relation", Qt = "classDef", Zt = "applyClass", Et = "default", te = "divider", bt = "[*]", Ot = "start", Nt = bt, Rt = "end", At = "color", Lt = "fill", ee = "bgFill", se = ","; +function wt() { + return {}; +} +let $t = qt, lt = [], P = wt(); +const Bt = () => ({ + relations: [], + states: {}, + documents: {} +}); +let ct = { + root: Bt() +}, g = ct.root, F = 0, vt = 0; +const ie = { + LINE: 0, + DOTTED_LINE: 1 +}, re = { + AGGREGATION: 0, + EXTENSION: 1, + COMPOSITION: 2, + DEPENDENCY: 3 +}, nt = (t) => JSON.parse(JSON.stringify(t)), ne = (t) => { + D.info("Setting root doc", t), lt = t; +}, ae = () => lt, at = (t, s, a) => { + if (s.stmt === It) + at(t, s.state1, !0), at(t, s.state2, !1); + else if (s.stmt === _t && (s.id === "[*]" ? (s.id = a ? t.id + "_start" : t.id + "_end", s.start = a) : s.id = s.id.trim()), s.doc) { + const h = []; + let f = [], d; + for (d = 0; d < s.doc.length; d++) + if (s.doc[d].type === te) { + const y = nt(s.doc[d]); + y.doc = nt(f), h.push(y), f = []; + } else + f.push(s.doc[d]); + if (h.length > 0 && f.length > 0) { + const y = { + stmt: _t, + id: Jt(), + type: "divider", + doc: nt(f) + }; + h.push(nt(y)), s.doc = h; + } + s.doc.forEach((y) => at(s, y, !0)); + } +}, le = () => (at({ id: "root" }, { id: "root", doc: lt }, !0), { id: "root", doc: lt }), ce = (t) => { + let s; + t.doc ? s = t.doc : s = t, D.info(s), Pt(!0), D.info("Extract", s), s.forEach((a) => { + switch (a.stmt) { + case _t: + I( + a.id.trim(), + a.type, + a.doc, + a.description, + a.note, + a.classes, + a.styles, + a.textStyles + ); + break; + case It: + Ft(a.state1, a.state2, a.description); + break; + case Qt: + Vt(a.id.trim(), a.classes); + break; + case Zt: + xt(a.id.trim(), a.styleClass); + break; + } + }); +}, I = function(t, s = Et, a = null, h = null, f = null, d = null, y = null, k = null) { + const u = t == null ? void 0 : t.trim(); + g.states[u] === void 0 ? (D.info("Adding state ", u, h), g.states[u] = { + id: u, + descriptions: [], + type: s, + doc: a, + note: f, + classes: [], + styles: [], + textStyles: [] + }) : (g.states[u].doc || (g.states[u].doc = a), g.states[u].type || (g.states[u].type = s)), h && (D.info("Setting state description", u, h), typeof h == "string" && kt(u, h.trim()), typeof h == "object" && h.forEach((E) => kt(u, E.trim()))), f && (g.states[u].note = f, g.states[u].note.text = ot.sanitizeText( + g.states[u].note.text, + Y() + )), d && (D.info("Setting state classes", u, d), (typeof d == "string" ? [d] : d).forEach((T) => xt(u, T.trim()))), y && (D.info("Setting state styles", u, y), (typeof y == "string" ? [y] : y).forEach((T) => _e(u, T.trim()))), k && (D.info("Setting state styles", u, y), (typeof k == "string" ? [k] : k).forEach((T) => me(u, T.trim()))); +}, Pt = function(t) { + ct = { + root: Bt() + }, g = ct.root, F = 0, P = wt(), t || Wt(); +}, V = function(t) { + return g.states[t]; +}, oe = function() { + return g.states; +}, he = function() { + D.info("Documents = ", ct); +}, ue = function() { + return g.relations; +}; +function mt(t = "") { + let s = t; + return t === bt && (F++, s = `${Ot}${F}`), s; +} +function Tt(t = "", s = Et) { + return t === bt ? Ot : s; +} +function fe(t = "") { + let s = t; + return t === Nt && (F++, s = `${Rt}${F}`), s; +} +function de(t = "", s = Et) { + return t === Nt ? Rt : s; +} +function ye(t, s, a) { + let h = mt(t.id.trim()), f = Tt(t.id.trim(), t.type), d = mt(s.id.trim()), y = Tt(s.id.trim(), s.type); + I( + h, + f, + t.doc, + t.description, + t.note, + t.classes, + t.styles, + t.textStyles + ), I( + d, + y, + s.doc, + s.description, + s.note, + s.classes, + s.styles, + s.textStyles + ), g.relations.push({ + id1: h, + id2: d, + relationTitle: ot.sanitizeText(a, Y()) + }); +} +const Ft = function(t, s, a) { + if (typeof t == "object") + ye(t, s, a); + else { + const h = mt(t.trim()), f = Tt(t), d = fe(s.trim()), y = de(s); + I(h, f), I(d, y), g.relations.push({ + id1: h, + id2: d, + title: ot.sanitizeText(a, Y()) + }); + } +}, kt = function(t, s) { + const a = g.states[t], h = s.startsWith(":") ? s.replace(":", "").trim() : s; + a.descriptions.push(ot.sanitizeText(h, Y())); +}, pe = function(t) { + return t.substring(0, 1) === ":" ? t.substr(2).trim() : t.trim(); +}, Se = () => (vt++, "divider-id-" + vt), Vt = function(t, s = "") { + P[t] === void 0 && (P[t] = { id: t, styles: [], textStyles: [] }); + const a = P[t]; + s != null && s.split(se).forEach((h) => { + const f = h.replace(/([^;]*);/, "$1").trim(); + if (h.match(At)) { + const y = f.replace(Lt, ee).replace(At, Lt); + a.textStyles.push(y); + } + a.styles.push(f); + }); +}, ge = function() { + return P; +}, xt = function(t, s) { + t.split(",").forEach(function(a) { + let h = V(a); + if (h === void 0) { + const f = a.trim(); + I(f), h = V(f); + } + h.classes.push(s); + }); +}, _e = function(t, s) { + const a = V(t); + a !== void 0 && a.textStyles.push(s); +}, me = function(t, s) { + const a = V(t); + a !== void 0 && a.textStyles.push(s); +}, Te = () => $t, ke = (t) => { + $t = t; +}, Ee = (t) => t && t[0] === ":" ? t.substr(1).trim() : t.trim(), Ae = { + getConfig: () => Y().state, + addState: I, + clear: Pt, + getState: V, + getStates: oe, + getRelations: ue, + getClasses: ge, + getDirection: Te, + addRelation: Ft, + getDividerId: Se, + setDirection: ke, + cleanupLabel: pe, + lineType: ie, + relationType: re, + logDocuments: he, + getRootDoc: ae, + setRootDoc: ne, + getRootDocV2: le, + extract: ce, + trimColon: Ee, + getAccTitle: Ut, + setAccTitle: zt, + getAccDescription: Mt, + setAccDescription: Ht, + addStyleClass: Vt, + setCssClass: xt, + addDescription: kt, + setDiagramTitle: Xt, + getDiagramTitle: Kt +}, be = (t) => ` +defs #statediagram-barbEnd { + fill: ${t.transitionColor}; + stroke: ${t.transitionColor}; + } +g.stateGroup text { + fill: ${t.nodeBorder}; + stroke: none; + font-size: 10px; +} +g.stateGroup text { + fill: ${t.textColor}; + stroke: none; + font-size: 10px; + +} +g.stateGroup .state-title { + font-weight: bolder; + fill: ${t.stateLabelColor}; +} + +g.stateGroup rect { + fill: ${t.mainBkg}; + stroke: ${t.nodeBorder}; +} + +g.stateGroup line { + stroke: ${t.lineColor}; + stroke-width: 1; +} + +.transition { + stroke: ${t.transitionColor}; + stroke-width: 1; + fill: none; +} + +.stateGroup .composit { + fill: ${t.background}; + border-bottom: 1px +} + +.stateGroup .alt-composit { + fill: #e0e0e0; + border-bottom: 1px +} + +.state-note { + stroke: ${t.noteBorderColor}; + fill: ${t.noteBkgColor}; + + text { + fill: ${t.noteTextColor}; + stroke: none; + font-size: 10px; + } +} + +.stateLabel .box { + stroke: none; + stroke-width: 0; + fill: ${t.mainBkg}; + opacity: 0.5; +} + +.edgeLabel .label rect { + fill: ${t.labelBackgroundColor}; + opacity: 0.5; +} +.edgeLabel .label text { + fill: ${t.transitionLabelColor || t.tertiaryTextColor}; +} +.label div .edgeLabel { + color: ${t.transitionLabelColor || t.tertiaryTextColor}; +} + +.stateLabel text { + fill: ${t.stateLabelColor}; + font-size: 10px; + font-weight: bold; +} + +.node circle.state-start { + fill: ${t.specialStateColor}; + stroke: ${t.specialStateColor}; +} + +.node .fork-join { + fill: ${t.specialStateColor}; + stroke: ${t.specialStateColor}; +} + +.node circle.state-end { + fill: ${t.innerEndBackground}; + stroke: ${t.background}; + stroke-width: 1.5 +} +.end-state-inner { + fill: ${t.compositeBackground || t.background}; + // stroke: ${t.background}; + stroke-width: 1.5 +} + +.node rect { + fill: ${t.stateBkg || t.mainBkg}; + stroke: ${t.stateBorder || t.nodeBorder}; + stroke-width: 1px; +} +.node polygon { + fill: ${t.mainBkg}; + stroke: ${t.stateBorder || t.nodeBorder};; + stroke-width: 1px; +} +#statediagram-barbEnd { + fill: ${t.lineColor}; +} + +.statediagram-cluster rect { + fill: ${t.compositeTitleBackground}; + stroke: ${t.stateBorder || t.nodeBorder}; + stroke-width: 1px; +} + +.cluster-label, .nodeLabel { + color: ${t.stateLabelColor}; +} + +.statediagram-cluster rect.outer { + rx: 5px; + ry: 5px; +} +.statediagram-state .divider { + stroke: ${t.stateBorder || t.nodeBorder}; +} + +.statediagram-state .title-state { + rx: 5px; + ry: 5px; +} +.statediagram-cluster.statediagram-cluster .inner { + fill: ${t.compositeBackground || t.background}; +} +.statediagram-cluster.statediagram-cluster-alt .inner { + fill: ${t.altBackground ? t.altBackground : "#efefef"}; +} + +.statediagram-cluster .inner { + rx:0; + ry:0; +} + +.statediagram-state rect.basic { + rx: 5px; + ry: 5px; +} +.statediagram-state rect.divider { + stroke-dasharray: 10,10; + fill: ${t.altBackground ? t.altBackground : "#efefef"}; +} + +.note-edge { + stroke-dasharray: 5; +} + +.statediagram-note rect { + fill: ${t.noteBkgColor}; + stroke: ${t.noteBorderColor}; + stroke-width: 1px; + rx: 0; + ry: 0; +} +.statediagram-note rect { + fill: ${t.noteBkgColor}; + stroke: ${t.noteBorderColor}; + stroke-width: 1px; + rx: 0; + ry: 0; +} + +.statediagram-note text { + fill: ${t.noteTextColor}; +} + +.statediagram-note .nodeLabel { + color: ${t.noteTextColor}; +} +.statediagram .edgeLabel { + color: red; // ${t.noteTextColor}; +} + +#dependencyStart, #dependencyEnd { + fill: ${t.lineColor}; + stroke: ${t.lineColor}; + stroke-width: 1; +} + +.statediagramTitleText { + text-anchor: middle; + font-size: 18px; + fill: ${t.textColor}; +} +`, Le = be; +export { + Et as D, + It as S, + te as a, + _t as b, + Ce as c, + Ae as d, + De as p, + Le as s +}; diff --git a/0.6.0/js/mermaid/styles-e75131e4.js b/0.6.0/js/mermaid/styles-e75131e4.js new file mode 100644 index 0000000..27311eb --- /dev/null +++ b/0.6.0/js/mermaid/styles-e75131e4.js @@ -0,0 +1,433 @@ +import { G as R } from "./graph-0ee63739.js"; +import { S as z, v as F, x as j, y as U, z as H, o as N, l as g, p as K, c as v, f as G, r as q, q as E, n as L, j as C, A as W, t as X, B as J } from "./mermaid-9f2aa176.js"; +import { r as Q } from "./index-bb6d8841.js"; +import { c as Y } from "./channel-ebbc4130.js"; +function Z(e) { + return typeof e == "string" ? new z([document.querySelectorAll(e)], [document.documentElement]) : new z([j(e)], F); +} +function fe(e, l) { + return !!e.children(l).length; +} +function pe(e) { + return A(e.v) + ":" + A(e.w) + ":" + A(e.name); +} +var O = /:/g; +function A(e) { + return e ? String(e).replace(O, "\\:") : ""; +} +function ee(e, l) { + l && e.attr("style", l); +} +function be(e, l, c) { + l && e.attr("class", l).attr("class", c + " " + e.attr("class")); +} +function ue(e, l) { + var c = l.graph(); + if (U(c)) { + var a = c.transition; + if (H(a)) + return a(e); + } + return e; +} +function te(e, l) { + var c = e.append("foreignObject").attr("width", "100000"), a = c.append("xhtml:div"); + a.attr("xmlns", "http://www.w3.org/1999/xhtml"); + var i = l.label; + switch (typeof i) { + case "function": + a.insert(i); + break; + case "object": + a.insert(function() { + return i; + }); + break; + default: + a.html(i); + } + ee(a, l.labelStyle), a.style("display", "inline-block"), a.style("white-space", "nowrap"); + var d = a.node().getBoundingClientRect(); + return c.attr("width", d.width).attr("height", d.height), c; +} +const P = {}, re = function(e) { + const l = Object.keys(e); + for (const c of l) + P[c] = e[c]; +}, V = async function(e, l, c, a, i, d) { + const u = a.select(`[id="${c}"]`), o = Object.keys(e); + for (const f of o) { + const r = e[f]; + let y = "default"; + r.classes.length > 0 && (y = r.classes.join(" ")), y = y + " flowchart-label"; + const w = N(r.styles); + let t = r.text !== void 0 ? r.text : r.id, s; + if (g.info("vertex", r, r.labelType), r.labelType === "markdown") + g.info("vertex", r, r.labelType); + else if (K(v().flowchart.htmlLabels)) + s = te(u, { + label: t + }).node(), s.parentNode.removeChild(s); + else { + const k = i.createElementNS("http://www.w3.org/2000/svg", "text"); + k.setAttribute("style", w.labelStyle.replace("color:", "fill:")); + const _ = t.split(G.lineBreakRegex); + for (const $ of _) { + const S = i.createElementNS("http://www.w3.org/2000/svg", "tspan"); + S.setAttributeNS("http://www.w3.org/XML/1998/namespace", "xml:space", "preserve"), S.setAttribute("dy", "1em"), S.setAttribute("x", "1"), S.textContent = $, k.appendChild(S); + } + s = k; + } + let p = 0, n = ""; + switch (r.type) { + case "round": + p = 5, n = "rect"; + break; + case "square": + n = "rect"; + break; + case "diamond": + n = "question"; + break; + case "hexagon": + n = "hexagon"; + break; + case "odd": + n = "rect_left_inv_arrow"; + break; + case "lean_right": + n = "lean_right"; + break; + case "lean_left": + n = "lean_left"; + break; + case "trapezoid": + n = "trapezoid"; + break; + case "inv_trapezoid": + n = "inv_trapezoid"; + break; + case "odd_right": + n = "rect_left_inv_arrow"; + break; + case "circle": + n = "circle"; + break; + case "ellipse": + n = "ellipse"; + break; + case "stadium": + n = "stadium"; + break; + case "subroutine": + n = "subroutine"; + break; + case "cylinder": + n = "cylinder"; + break; + case "group": + n = "rect"; + break; + case "doublecircle": + n = "doublecircle"; + break; + default: + n = "rect"; + } + const T = await q(t, v()); + l.setNode(r.id, { + labelStyle: w.labelStyle, + shape: n, + labelText: T, + labelType: r.labelType, + rx: p, + ry: p, + class: y, + style: w.style, + id: r.id, + link: r.link, + linkTarget: r.linkTarget, + tooltip: d.db.getTooltip(r.id) || "", + domId: d.db.lookUpDomId(r.id), + haveCallback: r.haveCallback, + width: r.type === "group" ? 500 : void 0, + dir: r.dir, + type: r.type, + props: r.props, + padding: v().flowchart.padding + }), g.info("setNode", { + labelStyle: w.labelStyle, + labelType: r.labelType, + shape: n, + labelText: T, + rx: p, + ry: p, + class: y, + style: w.style, + id: r.id, + domId: d.db.lookUpDomId(r.id), + width: r.type === "group" ? 500 : void 0, + type: r.type, + dir: r.dir, + props: r.props, + padding: v().flowchart.padding + }); + } +}, M = async function(e, l, c) { + g.info("abc78 edges = ", e); + let a = 0, i = {}, d, u; + if (e.defaultStyle !== void 0) { + const o = N(e.defaultStyle); + d = o.style, u = o.labelStyle; + } + for (const o of e) { + a++; + const f = "L-" + o.start + "-" + o.end; + i[f] === void 0 ? (i[f] = 0, g.info("abc78 new entry", f, i[f])) : (i[f]++, g.info("abc78 new entry", f, i[f])); + let r = f + "-" + i[f]; + g.info("abc78 new link id to be used is", f, r, i[f]); + const y = "LS-" + o.start, w = "LE-" + o.end, t = { style: "", labelStyle: "" }; + switch (t.minlen = o.length || 1, o.type === "arrow_open" ? t.arrowhead = "none" : t.arrowhead = "normal", t.arrowTypeStart = "arrow_open", t.arrowTypeEnd = "arrow_open", o.type) { + case "double_arrow_cross": + t.arrowTypeStart = "arrow_cross"; + case "arrow_cross": + t.arrowTypeEnd = "arrow_cross"; + break; + case "double_arrow_point": + t.arrowTypeStart = "arrow_point"; + case "arrow_point": + t.arrowTypeEnd = "arrow_point"; + break; + case "double_arrow_circle": + t.arrowTypeStart = "arrow_circle"; + case "arrow_circle": + t.arrowTypeEnd = "arrow_circle"; + break; + } + let s = "", p = ""; + switch (o.stroke) { + case "normal": + s = "fill:none;", d !== void 0 && (s = d), u !== void 0 && (p = u), t.thickness = "normal", t.pattern = "solid"; + break; + case "dotted": + t.thickness = "normal", t.pattern = "dotted", t.style = "fill:none;stroke-width:2px;stroke-dasharray:3;"; + break; + case "thick": + t.thickness = "thick", t.pattern = "solid", t.style = "stroke-width: 3.5px;fill:none;"; + break; + case "invisible": + t.thickness = "invisible", t.pattern = "solid", t.style = "stroke-width: 0;fill:none;"; + break; + } + if (o.style !== void 0) { + const n = N(o.style); + s = n.style, p = n.labelStyle; + } + t.style = t.style += s, t.labelStyle = t.labelStyle += p, o.interpolate !== void 0 ? t.curve = E(o.interpolate, L) : e.defaultInterpolate !== void 0 ? t.curve = E(e.defaultInterpolate, L) : t.curve = E(P.curve, L), o.text === void 0 ? o.style !== void 0 && (t.arrowheadStyle = "fill: #333") : (t.arrowheadStyle = "fill: #333", t.labelpos = "c"), t.labelType = o.labelType, t.label = await q(o.text.replace(G.lineBreakRegex, ` +`), v()), o.style === void 0 && (t.style = t.style || "stroke: #333; stroke-width: 1.5px;fill:none;"), t.labelStyle = t.labelStyle.replace("color:", "fill:"), t.id = r, t.classes = "flowchart-link " + y + " " + w, l.setEdge(o.start, o.end, t, a); + } +}, le = function(e, l) { + return l.db.getClasses(); +}, ae = async function(e, l, c, a) { + g.info("Drawing flowchart"); + let i = a.db.getDirection(); + i === void 0 && (i = "TD"); + const { securityLevel: d, flowchart: u } = v(), o = u.nodeSpacing || 50, f = u.rankSpacing || 50; + let r; + d === "sandbox" && (r = C("#i" + l)); + const y = d === "sandbox" ? C(r.nodes()[0].contentDocument.body) : C("body"), w = d === "sandbox" ? r.nodes()[0].contentDocument : document, t = new R({ + multigraph: !0, + compound: !0 + }).setGraph({ + rankdir: i, + nodesep: o, + ranksep: f, + marginx: 0, + marginy: 0 + }).setDefaultEdgeLabel(function() { + return {}; + }); + let s; + const p = a.db.getSubGraphs(); + g.info("Subgraphs - ", p); + for (let b = p.length - 1; b >= 0; b--) + s = p[b], g.info("Subgraph - ", s), a.db.addVertex( + s.id, + { text: s.title, type: s.labelType }, + "group", + void 0, + s.classes, + s.dir + ); + const n = a.db.getVertices(), T = a.db.getEdges(); + g.info("Edges", T); + let k = 0; + for (k = p.length - 1; k >= 0; k--) { + s = p[k], Z("cluster").append("text"); + for (let b = 0; b < s.nodes.length; b++) + g.info("Setting up subgraphs", s.nodes[b], s.id), t.setParent(s.nodes[b], s.id); + } + await V(n, t, l, y, w, a), await M(T, t); + const _ = y.select(`[id="${l}"]`), $ = y.select("#" + l + " g"); + if (await Q($, t, ["point", "circle", "cross"], "flowchart", l), W.insertTitle(_, "flowchartTitleText", u.titleTopMargin, a.db.getDiagramTitle()), X(t, _, u.diagramPadding, u.useMaxWidth), a.db.indexNodes("subGraph" + k), !u.htmlLabels) { + const b = w.querySelectorAll('[id="' + l + '"] .edgeLabel .label'); + for (const x of b) { + const m = x.getBBox(), h = w.createElementNS("http://www.w3.org/2000/svg", "rect"); + h.setAttribute("rx", 0), h.setAttribute("ry", 0), h.setAttribute("width", m.width), h.setAttribute("height", m.height), x.insertBefore(h, x.firstChild); + } + } + Object.keys(n).forEach(function(b) { + const x = n[b]; + if (x.link) { + const m = C("#" + l + ' [id="' + b + '"]'); + if (m) { + const h = w.createElementNS("http://www.w3.org/2000/svg", "a"); + h.setAttributeNS("http://www.w3.org/2000/svg", "class", x.classes.join(" ")), h.setAttributeNS("http://www.w3.org/2000/svg", "href", x.link), h.setAttributeNS("http://www.w3.org/2000/svg", "rel", "noopener"), d === "sandbox" ? h.setAttributeNS("http://www.w3.org/2000/svg", "target", "_top") : x.linkTarget && h.setAttributeNS("http://www.w3.org/2000/svg", "target", x.linkTarget); + const B = m.insert(function() { + return h; + }, ":first-child"), I = m.select(".label-container"); + I && B.append(function() { + return I.node(); + }); + const D = m.select(".label"); + D && B.append(function() { + return D.node(); + }); + } + } + }); +}, we = { + setConf: re, + addVertices: V, + addEdges: M, + getClasses: le, + draw: ae +}, ne = (e, l) => { + const c = Y, a = c(e, "r"), i = c(e, "g"), d = c(e, "b"); + return J(a, i, d, l); +}, oe = (e) => `.label { + font-family: ${e.fontFamily}; + color: ${e.nodeTextColor || e.textColor}; + } + .cluster-label text { + fill: ${e.titleColor}; + } + .cluster-label span,p { + color: ${e.titleColor}; + } + + .label text,span,p { + fill: ${e.nodeTextColor || e.textColor}; + color: ${e.nodeTextColor || e.textColor}; + } + + .node rect, + .node circle, + .node ellipse, + .node polygon, + .node path { + fill: ${e.mainBkg}; + stroke: ${e.nodeBorder}; + stroke-width: 1px; + } + .flowchart-label text { + text-anchor: middle; + } + // .flowchart-label .text-outer-tspan { + // text-anchor: middle; + // } + // .flowchart-label .text-inner-tspan { + // text-anchor: start; + // } + + .node .katex path { + fill: #000; + stroke: #000; + stroke-width: 1px; + } + + .node .label { + text-align: center; + } + .node.clickable { + cursor: pointer; + } + + .arrowheadPath { + fill: ${e.arrowheadColor}; + } + + .edgePath .path { + stroke: ${e.lineColor}; + stroke-width: 2.0px; + } + + .flowchart-link { + stroke: ${e.lineColor}; + fill: none; + } + + .edgeLabel { + background-color: ${e.edgeLabelBackground}; + rect { + opacity: 0.5; + background-color: ${e.edgeLabelBackground}; + fill: ${e.edgeLabelBackground}; + } + text-align: center; + } + + /* For html labels only */ + .labelBkg { + background-color: ${ne(e.edgeLabelBackground, 0.5)}; + // background-color: + } + + .cluster rect { + fill: ${e.clusterBkg}; + stroke: ${e.clusterBorder}; + stroke-width: 1px; + } + + .cluster text { + fill: ${e.titleColor}; + } + + .cluster span,p { + color: ${e.titleColor}; + } + /* .cluster div { + color: ${e.titleColor}; + } */ + + div.mermaidTooltip { + position: absolute; + text-align: center; + max-width: 200px; + padding: 2px; + font-family: ${e.fontFamily}; + font-size: 12px; + background: ${e.tertiaryColor}; + border: 1px solid ${e.border2}; + border-radius: 2px; + pointer-events: none; + z-index: 100; + } + + .flowchartTitleText { + text-anchor: middle; + font-size: 18px; + fill: ${e.textColor}; + } +`, he = oe; +export { + ee as a, + te as b, + ue as c, + be as d, + pe as e, + we as f, + he as g, + fe as i, + Z as s +}; diff --git a/0.6.0/js/mermaid/styles-f80da881.js b/0.6.0/js/mermaid/styles-f80da881.js new file mode 100644 index 0000000..6922af0 --- /dev/null +++ b/0.6.0/js/mermaid/styles-f80da881.js @@ -0,0 +1,1363 @@ +import { c as getConfig, g as getAccTitle, s as setAccTitle, a as getAccDescription, b as setAccDescription, C as setDiagramTitle, D as getDiagramTitle, l as log, f as common, E as clear$1, a7 as generateId } from "./mermaid-dcacb631.js"; +var parser = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 2], $V1 = [1, 3], $V2 = [1, 4], $V3 = [2, 4], $V4 = [1, 9], $V5 = [1, 11], $V6 = [1, 15], $V7 = [1, 16], $V8 = [1, 17], $V9 = [1, 18], $Va = [1, 30], $Vb = [1, 19], $Vc = [1, 20], $Vd = [1, 21], $Ve = [1, 22], $Vf = [1, 23], $Vg = [1, 25], $Vh = [1, 26], $Vi = [1, 27], $Vj = [1, 28], $Vk = [1, 29], $Vl = [1, 32], $Vm = [1, 33], $Vn = [1, 34], $Vo = [1, 35], $Vp = [1, 31], $Vq = [1, 4, 5, 15, 16, 18, 20, 21, 23, 24, 25, 26, 27, 28, 32, 34, 36, 37, 41, 44, 45, 46, 47, 50], $Vr = [1, 4, 5, 13, 14, 15, 16, 18, 20, 21, 23, 24, 25, 26, 27, 28, 32, 34, 36, 37, 41, 44, 45, 46, 47, 50], $Vs = [4, 5, 15, 16, 18, 20, 21, 23, 24, 25, 26, 27, 28, 32, 34, 36, 37, 41, 44, 45, 46, 47, 50]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "SPACE": 4, "NL": 5, "SD": 6, "document": 7, "line": 8, "statement": 9, "classDefStatement": 10, "cssClassStatement": 11, "idStatement": 12, "DESCR": 13, "-->": 14, "HIDE_EMPTY": 15, "scale": 16, "WIDTH": 17, "COMPOSIT_STATE": 18, "STRUCT_START": 19, "STRUCT_STOP": 20, "STATE_DESCR": 21, "AS": 22, "ID": 23, "FORK": 24, "JOIN": 25, "CHOICE": 26, "CONCURRENT": 27, "note": 28, "notePosition": 29, "NOTE_TEXT": 30, "direction": 31, "acc_title": 32, "acc_title_value": 33, "acc_descr": 34, "acc_descr_value": 35, "acc_descr_multiline_value": 36, "classDef": 37, "CLASSDEF_ID": 38, "CLASSDEF_STYLEOPTS": 39, "DEFAULT": 40, "class": 41, "CLASSENTITY_IDS": 42, "STYLECLASS": 43, "direction_tb": 44, "direction_bt": 45, "direction_rl": 46, "direction_lr": 47, "eol": 48, ";": 49, "EDGE_STATE": 50, "STYLE_SEPARATOR": 51, "left_of": 52, "right_of": 53, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 4: "SPACE", 5: "NL", 6: "SD", 13: "DESCR", 14: "-->", 15: "HIDE_EMPTY", 16: "scale", 17: "WIDTH", 18: "COMPOSIT_STATE", 19: "STRUCT_START", 20: "STRUCT_STOP", 21: "STATE_DESCR", 22: "AS", 23: "ID", 24: "FORK", 25: "JOIN", 26: "CHOICE", 27: "CONCURRENT", 28: "note", 30: "NOTE_TEXT", 32: "acc_title", 33: "acc_title_value", 34: "acc_descr", 35: "acc_descr_value", 36: "acc_descr_multiline_value", 37: "classDef", 38: "CLASSDEF_ID", 39: "CLASSDEF_STYLEOPTS", 40: "DEFAULT", 41: "class", 42: "CLASSENTITY_IDS", 43: "STYLECLASS", 44: "direction_tb", 45: "direction_bt", 46: "direction_rl", 47: "direction_lr", 49: ";", 50: "EDGE_STATE", 51: "STYLE_SEPARATOR", 52: "left_of", 53: "right_of" }, + productions_: [0, [3, 2], [3, 2], [3, 2], [7, 0], [7, 2], [8, 2], [8, 1], [8, 1], [9, 1], [9, 1], [9, 1], [9, 2], [9, 3], [9, 4], [9, 1], [9, 2], [9, 1], [9, 4], [9, 3], [9, 6], [9, 1], [9, 1], [9, 1], [9, 1], [9, 4], [9, 4], [9, 1], [9, 2], [9, 2], [9, 1], [10, 3], [10, 3], [11, 3], [31, 1], [31, 1], [31, 1], [31, 1], [48, 1], [48, 1], [12, 1], [12, 1], [12, 3], [12, 3], [29, 1], [29, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 3: + yy.setRootDoc($$[$0]); + return $$[$0]; + case 4: + this.$ = []; + break; + case 5: + if ($$[$0] != "nl") { + $$[$0 - 1].push($$[$0]); + this.$ = $$[$0 - 1]; + } + break; + case 6: + case 7: + this.$ = $$[$0]; + break; + case 8: + this.$ = "nl"; + break; + case 11: + this.$ = $$[$0]; + break; + case 12: + const stateStmt = $$[$0 - 1]; + stateStmt.description = yy.trimColon($$[$0]); + this.$ = stateStmt; + break; + case 13: + this.$ = { stmt: "relation", state1: $$[$0 - 2], state2: $$[$0] }; + break; + case 14: + const relDescription = yy.trimColon($$[$0]); + this.$ = { stmt: "relation", state1: $$[$0 - 3], state2: $$[$0 - 1], description: relDescription }; + break; + case 18: + this.$ = { stmt: "state", id: $$[$0 - 3], type: "default", description: "", doc: $$[$0 - 1] }; + break; + case 19: + var id = $$[$0]; + var description = $$[$0 - 2].trim(); + if ($$[$0].match(":")) { + var parts = $$[$0].split(":"); + id = parts[0]; + description = [description, parts[1]]; + } + this.$ = { stmt: "state", id, type: "default", description }; + break; + case 20: + this.$ = { stmt: "state", id: $$[$0 - 3], type: "default", description: $$[$0 - 5], doc: $$[$0 - 1] }; + break; + case 21: + this.$ = { stmt: "state", id: $$[$0], type: "fork" }; + break; + case 22: + this.$ = { stmt: "state", id: $$[$0], type: "join" }; + break; + case 23: + this.$ = { stmt: "state", id: $$[$0], type: "choice" }; + break; + case 24: + this.$ = { stmt: "state", id: yy.getDividerId(), type: "divider" }; + break; + case 25: + this.$ = { stmt: "state", id: $$[$0 - 1].trim(), note: { position: $$[$0 - 2].trim(), text: $$[$0].trim() } }; + break; + case 28: + this.$ = $$[$0].trim(); + yy.setAccTitle(this.$); + break; + case 29: + case 30: + this.$ = $$[$0].trim(); + yy.setAccDescription(this.$); + break; + case 31: + case 32: + this.$ = { stmt: "classDef", id: $$[$0 - 1].trim(), classes: $$[$0].trim() }; + break; + case 33: + this.$ = { stmt: "applyClass", id: $$[$0 - 1].trim(), styleClass: $$[$0].trim() }; + break; + case 34: + yy.setDirection("TB"); + this.$ = { stmt: "dir", value: "TB" }; + break; + case 35: + yy.setDirection("BT"); + this.$ = { stmt: "dir", value: "BT" }; + break; + case 36: + yy.setDirection("RL"); + this.$ = { stmt: "dir", value: "RL" }; + break; + case 37: + yy.setDirection("LR"); + this.$ = { stmt: "dir", value: "LR" }; + break; + case 40: + case 41: + this.$ = { stmt: "state", id: $$[$0].trim(), type: "default", description: "" }; + break; + case 42: + this.$ = { stmt: "state", id: $$[$0 - 2].trim(), classes: [$$[$0].trim()], type: "default", description: "" }; + break; + case 43: + this.$ = { stmt: "state", id: $$[$0 - 2].trim(), classes: [$$[$0].trim()], type: "default", description: "" }; + break; + } + }, + table: [{ 3: 1, 4: $V0, 5: $V1, 6: $V2 }, { 1: [3] }, { 3: 5, 4: $V0, 5: $V1, 6: $V2 }, { 3: 6, 4: $V0, 5: $V1, 6: $V2 }, o([1, 4, 5, 15, 16, 18, 21, 23, 24, 25, 26, 27, 28, 32, 34, 36, 37, 41, 44, 45, 46, 47, 50], $V3, { 7: 7 }), { 1: [2, 1] }, { 1: [2, 2] }, { 1: [2, 3], 4: $V4, 5: $V5, 8: 8, 9: 10, 10: 12, 11: 13, 12: 14, 15: $V6, 16: $V7, 18: $V8, 21: $V9, 23: $Va, 24: $Vb, 25: $Vc, 26: $Vd, 27: $Ve, 28: $Vf, 31: 24, 32: $Vg, 34: $Vh, 36: $Vi, 37: $Vj, 41: $Vk, 44: $Vl, 45: $Vm, 46: $Vn, 47: $Vo, 50: $Vp }, o($Vq, [2, 5]), { 9: 36, 10: 12, 11: 13, 12: 14, 15: $V6, 16: $V7, 18: $V8, 21: $V9, 23: $Va, 24: $Vb, 25: $Vc, 26: $Vd, 27: $Ve, 28: $Vf, 31: 24, 32: $Vg, 34: $Vh, 36: $Vi, 37: $Vj, 41: $Vk, 44: $Vl, 45: $Vm, 46: $Vn, 47: $Vo, 50: $Vp }, o($Vq, [2, 7]), o($Vq, [2, 8]), o($Vq, [2, 9]), o($Vq, [2, 10]), o($Vq, [2, 11], { 13: [1, 37], 14: [1, 38] }), o($Vq, [2, 15]), { 17: [1, 39] }, o($Vq, [2, 17], { 19: [1, 40] }), { 22: [1, 41] }, o($Vq, [2, 21]), o($Vq, [2, 22]), o($Vq, [2, 23]), o($Vq, [2, 24]), { 29: 42, 30: [1, 43], 52: [1, 44], 53: [1, 45] }, o($Vq, [2, 27]), { 33: [1, 46] }, { 35: [1, 47] }, o($Vq, [2, 30]), { 38: [1, 48], 40: [1, 49] }, { 42: [1, 50] }, o($Vr, [2, 40], { 51: [1, 51] }), o($Vr, [2, 41], { 51: [1, 52] }), o($Vq, [2, 34]), o($Vq, [2, 35]), o($Vq, [2, 36]), o($Vq, [2, 37]), o($Vq, [2, 6]), o($Vq, [2, 12]), { 12: 53, 23: $Va, 50: $Vp }, o($Vq, [2, 16]), o($Vs, $V3, { 7: 54 }), { 23: [1, 55] }, { 23: [1, 56] }, { 22: [1, 57] }, { 23: [2, 44] }, { 23: [2, 45] }, o($Vq, [2, 28]), o($Vq, [2, 29]), { 39: [1, 58] }, { 39: [1, 59] }, { 43: [1, 60] }, { 23: [1, 61] }, { 23: [1, 62] }, o($Vq, [2, 13], { 13: [1, 63] }), { 4: $V4, 5: $V5, 8: 8, 9: 10, 10: 12, 11: 13, 12: 14, 15: $V6, 16: $V7, 18: $V8, 20: [1, 64], 21: $V9, 23: $Va, 24: $Vb, 25: $Vc, 26: $Vd, 27: $Ve, 28: $Vf, 31: 24, 32: $Vg, 34: $Vh, 36: $Vi, 37: $Vj, 41: $Vk, 44: $Vl, 45: $Vm, 46: $Vn, 47: $Vo, 50: $Vp }, o($Vq, [2, 19], { 19: [1, 65] }), { 30: [1, 66] }, { 23: [1, 67] }, o($Vq, [2, 31]), o($Vq, [2, 32]), o($Vq, [2, 33]), o($Vr, [2, 42]), o($Vr, [2, 43]), o($Vq, [2, 14]), o($Vq, [2, 18]), o($Vs, $V3, { 7: 68 }), o($Vq, [2, 25]), o($Vq, [2, 26]), { 4: $V4, 5: $V5, 8: 8, 9: 10, 10: 12, 11: 13, 12: 14, 15: $V6, 16: $V7, 18: $V8, 20: [1, 69], 21: $V9, 23: $Va, 24: $Vb, 25: $Vc, 26: $Vd, 27: $Ve, 28: $Vf, 31: 24, 32: $Vg, 34: $Vh, 36: $Vi, 37: $Vj, 41: $Vk, 44: $Vl, 45: $Vm, 46: $Vn, 47: $Vo, 50: $Vp }, o($Vq, [2, 20])], + defaultActions: { 5: [2, 1], 6: [2, 2], 44: [2, 44], 45: [2, 45] }, + parseError: function parseError(str, hash) { + if (hash.recoverable) { + this.trace(str); + } else { + var error = new Error(str); + error.hash = hash; + throw error; + } + }, + parse: function parse(input) { + var self = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex() { + var token; + token = tstack.pop() || lexer2.lex() || EOF; + if (typeof token !== "number") { + if (token instanceof Array) { + tstack = token; + token = tstack.pop(); + } + token = self.symbols_[token] || token; + } + return token; + } + var symbol, state, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state = stack[stack.length - 1]; + if (this.defaultActions[state]) { + action = this.defaultActions[state]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex(); + } + action = table[state] && table[state][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str, hash); + } else { + throw new Error(str); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch = this._input[0]; + this.yytext += ch; + this.yyleng++; + this.offset++; + this.match += ch; + this.matched += ch; + var lines = ch.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch; + }, + // unshifts one char (or a string) into the input + unput: function(ch) { + var len = ch.length; + var lines = ch.split(/(?:\r\n?|\n)/g); + this._input = ch + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next = this.match; + if (next.length < 20) { + next += this._input.substr(0, 20 - next.length); + } + return (next.substr(0, 20) + (next.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token) { + return token; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token, match, tempMatch, index; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i = 0; i < rules.length; i++) { + tempMatch = this._input.match(this.rules[rules[i]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index = i; + if (this.options.backtrack_lexer) { + token = this.test_match(tempMatch, rules[i]); + if (token !== false) { + return token; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token = this.test_match(match, rules[index]); + if (token !== false) { + return token; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + return 40; + case 1: + return 44; + case 2: + return 45; + case 3: + return 46; + case 4: + return 47; + case 5: + break; + case 6: + break; + case 7: + return 5; + case 8: + break; + case 9: + break; + case 10: + break; + case 11: + break; + case 12: + this.pushState("SCALE"); + return 16; + case 13: + return 17; + case 14: + this.popState(); + break; + case 15: + this.begin("acc_title"); + return 32; + case 16: + this.popState(); + return "acc_title_value"; + case 17: + this.begin("acc_descr"); + return 34; + case 18: + this.popState(); + return "acc_descr_value"; + case 19: + this.begin("acc_descr_multiline"); + break; + case 20: + this.popState(); + break; + case 21: + return "acc_descr_multiline_value"; + case 22: + this.pushState("CLASSDEF"); + return 37; + case 23: + this.popState(); + this.pushState("CLASSDEFID"); + return "DEFAULT_CLASSDEF_ID"; + case 24: + this.popState(); + this.pushState("CLASSDEFID"); + return 38; + case 25: + this.popState(); + return 39; + case 26: + this.pushState("CLASS"); + return 41; + case 27: + this.popState(); + this.pushState("CLASS_STYLE"); + return 42; + case 28: + this.popState(); + return 43; + case 29: + this.pushState("SCALE"); + return 16; + case 30: + return 17; + case 31: + this.popState(); + break; + case 32: + this.pushState("STATE"); + break; + case 33: + this.popState(); + yy_.yytext = yy_.yytext.slice(0, -8).trim(); + return 24; + case 34: + this.popState(); + yy_.yytext = yy_.yytext.slice(0, -8).trim(); + return 25; + case 35: + this.popState(); + yy_.yytext = yy_.yytext.slice(0, -10).trim(); + return 26; + case 36: + this.popState(); + yy_.yytext = yy_.yytext.slice(0, -8).trim(); + return 24; + case 37: + this.popState(); + yy_.yytext = yy_.yytext.slice(0, -8).trim(); + return 25; + case 38: + this.popState(); + yy_.yytext = yy_.yytext.slice(0, -10).trim(); + return 26; + case 39: + return 44; + case 40: + return 45; + case 41: + return 46; + case 42: + return 47; + case 43: + this.pushState("STATE_STRING"); + break; + case 44: + this.pushState("STATE_ID"); + return "AS"; + case 45: + this.popState(); + return "ID"; + case 46: + this.popState(); + break; + case 47: + return "STATE_DESCR"; + case 48: + return 18; + case 49: + this.popState(); + break; + case 50: + this.popState(); + this.pushState("struct"); + return 19; + case 51: + break; + case 52: + this.popState(); + return 20; + case 53: + break; + case 54: + this.begin("NOTE"); + return 28; + case 55: + this.popState(); + this.pushState("NOTE_ID"); + return 52; + case 56: + this.popState(); + this.pushState("NOTE_ID"); + return 53; + case 57: + this.popState(); + this.pushState("FLOATING_NOTE"); + break; + case 58: + this.popState(); + this.pushState("FLOATING_NOTE_ID"); + return "AS"; + case 59: + break; + case 60: + return "NOTE_TEXT"; + case 61: + this.popState(); + return "ID"; + case 62: + this.popState(); + this.pushState("NOTE_TEXT"); + return 23; + case 63: + this.popState(); + yy_.yytext = yy_.yytext.substr(2).trim(); + return 30; + case 64: + this.popState(); + yy_.yytext = yy_.yytext.slice(0, -8).trim(); + return 30; + case 65: + return 6; + case 66: + return 6; + case 67: + return 15; + case 68: + return 50; + case 69: + return 23; + case 70: + yy_.yytext = yy_.yytext.trim(); + return 13; + case 71: + return 14; + case 72: + return 27; + case 73: + return 51; + case 74: + return 5; + case 75: + return "INVALID"; + } + }, + rules: [/^(?:default\b)/i, /^(?:.*direction\s+TB[^\n]*)/i, /^(?:.*direction\s+BT[^\n]*)/i, /^(?:.*direction\s+RL[^\n]*)/i, /^(?:.*direction\s+LR[^\n]*)/i, /^(?:%%(?!\{)[^\n]*)/i, /^(?:[^\}]%%[^\n]*)/i, /^(?:[\n]+)/i, /^(?:[\s]+)/i, /^(?:((?!\n)\s)+)/i, /^(?:#[^\n]*)/i, /^(?:%[^\n]*)/i, /^(?:scale\s+)/i, /^(?:\d+)/i, /^(?:\s+width\b)/i, /^(?:accTitle\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*\{\s*)/i, /^(?:[\}])/i, /^(?:[^\}]*)/i, /^(?:classDef\s+)/i, /^(?:DEFAULT\s+)/i, /^(?:\w+\s+)/i, /^(?:[^\n]*)/i, /^(?:class\s+)/i, /^(?:(\w+)+((,\s*\w+)*))/i, /^(?:[^\n]*)/i, /^(?:scale\s+)/i, /^(?:\d+)/i, /^(?:\s+width\b)/i, /^(?:state\s+)/i, /^(?:.*<>)/i, /^(?:.*<>)/i, /^(?:.*<>)/i, /^(?:.*\[\[fork\]\])/i, /^(?:.*\[\[join\]\])/i, /^(?:.*\[\[choice\]\])/i, /^(?:.*direction\s+TB[^\n]*)/i, /^(?:.*direction\s+BT[^\n]*)/i, /^(?:.*direction\s+RL[^\n]*)/i, /^(?:.*direction\s+LR[^\n]*)/i, /^(?:["])/i, /^(?:\s*as\s+)/i, /^(?:[^\n\{]*)/i, /^(?:["])/i, /^(?:[^"]*)/i, /^(?:[^\n\s\{]+)/i, /^(?:\n)/i, /^(?:\{)/i, /^(?:%%(?!\{)[^\n]*)/i, /^(?:\})/i, /^(?:[\n])/i, /^(?:note\s+)/i, /^(?:left of\b)/i, /^(?:right of\b)/i, /^(?:")/i, /^(?:\s*as\s*)/i, /^(?:["])/i, /^(?:[^"]*)/i, /^(?:[^\n]*)/i, /^(?:\s*[^:\n\s\-]+)/i, /^(?:\s*:[^:\n;]+)/i, /^(?:[\s\S]*?end note\b)/i, /^(?:stateDiagram\s+)/i, /^(?:stateDiagram-v2\s+)/i, /^(?:hide empty description\b)/i, /^(?:\[\*\])/i, /^(?:[^:\n\s\-\{]+)/i, /^(?:\s*:[^:\n;]+)/i, /^(?:-->)/i, /^(?:--)/i, /^(?::::)/i, /^(?:$)/i, /^(?:.)/i], + conditions: { "LINE": { "rules": [9, 10], "inclusive": false }, "struct": { "rules": [9, 10, 22, 26, 32, 39, 40, 41, 42, 51, 52, 53, 54, 68, 69, 70, 71, 72], "inclusive": false }, "FLOATING_NOTE_ID": { "rules": [61], "inclusive": false }, "FLOATING_NOTE": { "rules": [58, 59, 60], "inclusive": false }, "NOTE_TEXT": { "rules": [63, 64], "inclusive": false }, "NOTE_ID": { "rules": [62], "inclusive": false }, "NOTE": { "rules": [55, 56, 57], "inclusive": false }, "CLASS_STYLE": { "rules": [28], "inclusive": false }, "CLASS": { "rules": [27], "inclusive": false }, "CLASSDEFID": { "rules": [25], "inclusive": false }, "CLASSDEF": { "rules": [23, 24], "inclusive": false }, "acc_descr_multiline": { "rules": [20, 21], "inclusive": false }, "acc_descr": { "rules": [18], "inclusive": false }, "acc_title": { "rules": [16], "inclusive": false }, "SCALE": { "rules": [13, 14, 30, 31], "inclusive": false }, "ALIAS": { "rules": [], "inclusive": false }, "STATE_ID": { "rules": [45], "inclusive": false }, "STATE_STRING": { "rules": [46, 47], "inclusive": false }, "FORK_STATE": { "rules": [], "inclusive": false }, "STATE": { "rules": [9, 10, 33, 34, 35, 36, 37, 38, 43, 44, 48, 49, 50], "inclusive": false }, "ID": { "rules": [9, 10], "inclusive": false }, "INITIAL": { "rules": [0, 1, 2, 3, 4, 5, 6, 7, 8, 10, 11, 12, 15, 17, 19, 22, 26, 29, 32, 50, 54, 65, 66, 67, 68, 69, 70, 71, 73, 74, 75], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser() { + this.yy = {}; + } + Parser.prototype = parser2; + parser2.Parser = Parser; + return new Parser(); +}(); +parser.parser = parser; +const parser$1 = parser; +const DEFAULT_DIAGRAM_DIRECTION = "LR"; +const DEFAULT_NESTED_DOC_DIR = "TB"; +const STMT_STATE = "state"; +const STMT_RELATION = "relation"; +const STMT_CLASSDEF = "classDef"; +const STMT_APPLYCLASS = "applyClass"; +const DEFAULT_STATE_TYPE = "default"; +const DIVIDER_TYPE = "divider"; +const START_NODE = "[*]"; +const START_TYPE = "start"; +const END_NODE = START_NODE; +const END_TYPE = "end"; +const COLOR_KEYWORD = "color"; +const FILL_KEYWORD = "fill"; +const BG_FILL = "bgFill"; +const STYLECLASS_SEP = ","; +function newClassesList() { + return {}; +} +let direction = DEFAULT_DIAGRAM_DIRECTION; +let rootDoc = []; +let classes = newClassesList(); +const newDoc = () => { + return { + relations: [], + states: {}, + documents: {} + }; +}; +let documents = { + root: newDoc() +}; +let currentDocument = documents.root; +let startEndCount = 0; +let dividerCnt = 0; +const lineType = { + LINE: 0, + DOTTED_LINE: 1 +}; +const relationType = { + AGGREGATION: 0, + EXTENSION: 1, + COMPOSITION: 2, + DEPENDENCY: 3 +}; +const clone = (o) => JSON.parse(JSON.stringify(o)); +const setRootDoc = (o) => { + log.info("Setting root doc", o); + rootDoc = o; +}; +const getRootDoc = () => rootDoc; +const docTranslator = (parent, node, first) => { + if (node.stmt === STMT_RELATION) { + docTranslator(parent, node.state1, true); + docTranslator(parent, node.state2, false); + } else { + if (node.stmt === STMT_STATE) { + if (node.id === "[*]") { + node.id = first ? parent.id + "_start" : parent.id + "_end"; + node.start = first; + } else { + node.id = node.id.trim(); + } + } + if (node.doc) { + const doc = []; + let currentDoc = []; + let i; + for (i = 0; i < node.doc.length; i++) { + if (node.doc[i].type === DIVIDER_TYPE) { + const newNode = clone(node.doc[i]); + newNode.doc = clone(currentDoc); + doc.push(newNode); + currentDoc = []; + } else { + currentDoc.push(node.doc[i]); + } + } + if (doc.length > 0 && currentDoc.length > 0) { + const newNode = { + stmt: STMT_STATE, + id: generateId(), + type: "divider", + doc: clone(currentDoc) + }; + doc.push(clone(newNode)); + node.doc = doc; + } + node.doc.forEach((docNode) => docTranslator(node, docNode, true)); + } + } +}; +const getRootDocV2 = () => { + docTranslator({ id: "root" }, { id: "root", doc: rootDoc }, true); + return { id: "root", doc: rootDoc }; +}; +const extract = (_doc) => { + let doc; + if (_doc.doc) { + doc = _doc.doc; + } else { + doc = _doc; + } + log.info(doc); + clear(true); + log.info("Extract", doc); + doc.forEach((item) => { + switch (item.stmt) { + case STMT_STATE: + addState( + item.id.trim(), + item.type, + item.doc, + item.description, + item.note, + item.classes, + item.styles, + item.textStyles + ); + break; + case STMT_RELATION: + addRelation(item.state1, item.state2, item.description); + break; + case STMT_CLASSDEF: + addStyleClass(item.id.trim(), item.classes); + break; + case STMT_APPLYCLASS: + setCssClass(item.id.trim(), item.styleClass); + break; + } + }); +}; +const addState = function(id, type = DEFAULT_STATE_TYPE, doc = null, descr = null, note = null, classes2 = null, styles2 = null, textStyles = null) { + const trimmedId = id == null ? void 0 : id.trim(); + if (currentDocument.states[trimmedId] === void 0) { + log.info("Adding state ", trimmedId, descr); + currentDocument.states[trimmedId] = { + id: trimmedId, + descriptions: [], + type, + doc, + note, + classes: [], + styles: [], + textStyles: [] + }; + } else { + if (!currentDocument.states[trimmedId].doc) { + currentDocument.states[trimmedId].doc = doc; + } + if (!currentDocument.states[trimmedId].type) { + currentDocument.states[trimmedId].type = type; + } + } + if (descr) { + log.info("Setting state description", trimmedId, descr); + if (typeof descr === "string") { + addDescription(trimmedId, descr.trim()); + } + if (typeof descr === "object") { + descr.forEach((des) => addDescription(trimmedId, des.trim())); + } + } + if (note) { + currentDocument.states[trimmedId].note = note; + currentDocument.states[trimmedId].note.text = common.sanitizeText( + currentDocument.states[trimmedId].note.text, + getConfig() + ); + } + if (classes2) { + log.info("Setting state classes", trimmedId, classes2); + const classesList = typeof classes2 === "string" ? [classes2] : classes2; + classesList.forEach((cssClass) => setCssClass(trimmedId, cssClass.trim())); + } + if (styles2) { + log.info("Setting state styles", trimmedId, styles2); + const stylesList = typeof styles2 === "string" ? [styles2] : styles2; + stylesList.forEach((style) => setStyle(trimmedId, style.trim())); + } + if (textStyles) { + log.info("Setting state styles", trimmedId, styles2); + const textStylesList = typeof textStyles === "string" ? [textStyles] : textStyles; + textStylesList.forEach((textStyle) => setTextStyle(trimmedId, textStyle.trim())); + } +}; +const clear = function(saveCommon) { + documents = { + root: newDoc() + }; + currentDocument = documents.root; + startEndCount = 0; + classes = newClassesList(); + if (!saveCommon) { + clear$1(); + } +}; +const getState = function(id) { + return currentDocument.states[id]; +}; +const getStates = function() { + return currentDocument.states; +}; +const logDocuments = function() { + log.info("Documents = ", documents); +}; +const getRelations = function() { + return currentDocument.relations; +}; +function startIdIfNeeded(id = "") { + let fixedId = id; + if (id === START_NODE) { + startEndCount++; + fixedId = `${START_TYPE}${startEndCount}`; + } + return fixedId; +} +function startTypeIfNeeded(id = "", type = DEFAULT_STATE_TYPE) { + return id === START_NODE ? START_TYPE : type; +} +function endIdIfNeeded(id = "") { + let fixedId = id; + if (id === END_NODE) { + startEndCount++; + fixedId = `${END_TYPE}${startEndCount}`; + } + return fixedId; +} +function endTypeIfNeeded(id = "", type = DEFAULT_STATE_TYPE) { + return id === END_NODE ? END_TYPE : type; +} +function addRelationObjs(item1, item2, relationTitle) { + let id1 = startIdIfNeeded(item1.id.trim()); + let type1 = startTypeIfNeeded(item1.id.trim(), item1.type); + let id2 = startIdIfNeeded(item2.id.trim()); + let type2 = startTypeIfNeeded(item2.id.trim(), item2.type); + addState( + id1, + type1, + item1.doc, + item1.description, + item1.note, + item1.classes, + item1.styles, + item1.textStyles + ); + addState( + id2, + type2, + item2.doc, + item2.description, + item2.note, + item2.classes, + item2.styles, + item2.textStyles + ); + currentDocument.relations.push({ + id1, + id2, + relationTitle: common.sanitizeText(relationTitle, getConfig()) + }); +} +const addRelation = function(item1, item2, title) { + if (typeof item1 === "object") { + addRelationObjs(item1, item2, title); + } else { + const id1 = startIdIfNeeded(item1.trim()); + const type1 = startTypeIfNeeded(item1); + const id2 = endIdIfNeeded(item2.trim()); + const type2 = endTypeIfNeeded(item2); + addState(id1, type1); + addState(id2, type2); + currentDocument.relations.push({ + id1, + id2, + title: common.sanitizeText(title, getConfig()) + }); + } +}; +const addDescription = function(id, descr) { + const theState = currentDocument.states[id]; + const _descr = descr.startsWith(":") ? descr.replace(":", "").trim() : descr; + theState.descriptions.push(common.sanitizeText(_descr, getConfig())); +}; +const cleanupLabel = function(label) { + if (label.substring(0, 1) === ":") { + return label.substr(2).trim(); + } else { + return label.trim(); + } +}; +const getDividerId = () => { + dividerCnt++; + return "divider-id-" + dividerCnt; +}; +const addStyleClass = function(id, styleAttributes = "") { + if (classes[id] === void 0) { + classes[id] = { id, styles: [], textStyles: [] }; + } + const foundClass = classes[id]; + if (styleAttributes !== void 0 && styleAttributes !== null) { + styleAttributes.split(STYLECLASS_SEP).forEach((attrib) => { + const fixedAttrib = attrib.replace(/([^;]*);/, "$1").trim(); + if (attrib.match(COLOR_KEYWORD)) { + const newStyle1 = fixedAttrib.replace(FILL_KEYWORD, BG_FILL); + const newStyle2 = newStyle1.replace(COLOR_KEYWORD, FILL_KEYWORD); + foundClass.textStyles.push(newStyle2); + } + foundClass.styles.push(fixedAttrib); + }); + } +}; +const getClasses = function() { + return classes; +}; +const setCssClass = function(itemIds, cssClassName) { + itemIds.split(",").forEach(function(id) { + let foundState = getState(id); + if (foundState === void 0) { + const trimmedId = id.trim(); + addState(trimmedId); + foundState = getState(trimmedId); + } + foundState.classes.push(cssClassName); + }); +}; +const setStyle = function(itemId, styleText) { + const item = getState(itemId); + if (item !== void 0) { + item.textStyles.push(styleText); + } +}; +const setTextStyle = function(itemId, cssClassName) { + const item = getState(itemId); + if (item !== void 0) { + item.textStyles.push(cssClassName); + } +}; +const getDirection = () => direction; +const setDirection = (dir) => { + direction = dir; +}; +const trimColon = (str) => str && str[0] === ":" ? str.substr(1).trim() : str.trim(); +const db = { + getConfig: () => getConfig().state, + addState, + clear, + getState, + getStates, + getRelations, + getClasses, + getDirection, + addRelation, + getDividerId, + setDirection, + cleanupLabel, + lineType, + relationType, + logDocuments, + getRootDoc, + setRootDoc, + getRootDocV2, + extract, + trimColon, + getAccTitle, + setAccTitle, + getAccDescription, + setAccDescription, + addStyleClass, + setCssClass, + addDescription, + setDiagramTitle, + getDiagramTitle +}; +const getStyles = (options) => ` +defs #statediagram-barbEnd { + fill: ${options.transitionColor}; + stroke: ${options.transitionColor}; + } +g.stateGroup text { + fill: ${options.nodeBorder}; + stroke: none; + font-size: 10px; +} +g.stateGroup text { + fill: ${options.textColor}; + stroke: none; + font-size: 10px; + +} +g.stateGroup .state-title { + font-weight: bolder; + fill: ${options.stateLabelColor}; +} + +g.stateGroup rect { + fill: ${options.mainBkg}; + stroke: ${options.nodeBorder}; +} + +g.stateGroup line { + stroke: ${options.lineColor}; + stroke-width: 1; +} + +.transition { + stroke: ${options.transitionColor}; + stroke-width: 1; + fill: none; +} + +.stateGroup .composit { + fill: ${options.background}; + border-bottom: 1px +} + +.stateGroup .alt-composit { + fill: #e0e0e0; + border-bottom: 1px +} + +.state-note { + stroke: ${options.noteBorderColor}; + fill: ${options.noteBkgColor}; + + text { + fill: ${options.noteTextColor}; + stroke: none; + font-size: 10px; + } +} + +.stateLabel .box { + stroke: none; + stroke-width: 0; + fill: ${options.mainBkg}; + opacity: 0.5; +} + +.edgeLabel .label rect { + fill: ${options.labelBackgroundColor}; + opacity: 0.5; +} +.edgeLabel .label text { + fill: ${options.transitionLabelColor || options.tertiaryTextColor}; +} +.label div .edgeLabel { + color: ${options.transitionLabelColor || options.tertiaryTextColor}; +} + +.stateLabel text { + fill: ${options.stateLabelColor}; + font-size: 10px; + font-weight: bold; +} + +.node circle.state-start { + fill: ${options.specialStateColor}; + stroke: ${options.specialStateColor}; +} + +.node .fork-join { + fill: ${options.specialStateColor}; + stroke: ${options.specialStateColor}; +} + +.node circle.state-end { + fill: ${options.innerEndBackground}; + stroke: ${options.background}; + stroke-width: 1.5 +} +.end-state-inner { + fill: ${options.compositeBackground || options.background}; + // stroke: ${options.background}; + stroke-width: 1.5 +} + +.node rect { + fill: ${options.stateBkg || options.mainBkg}; + stroke: ${options.stateBorder || options.nodeBorder}; + stroke-width: 1px; +} +.node polygon { + fill: ${options.mainBkg}; + stroke: ${options.stateBorder || options.nodeBorder};; + stroke-width: 1px; +} +#statediagram-barbEnd { + fill: ${options.lineColor}; +} + +.statediagram-cluster rect { + fill: ${options.compositeTitleBackground}; + stroke: ${options.stateBorder || options.nodeBorder}; + stroke-width: 1px; +} + +.cluster-label, .nodeLabel { + color: ${options.stateLabelColor}; +} + +.statediagram-cluster rect.outer { + rx: 5px; + ry: 5px; +} +.statediagram-state .divider { + stroke: ${options.stateBorder || options.nodeBorder}; +} + +.statediagram-state .title-state { + rx: 5px; + ry: 5px; +} +.statediagram-cluster.statediagram-cluster .inner { + fill: ${options.compositeBackground || options.background}; +} +.statediagram-cluster.statediagram-cluster-alt .inner { + fill: ${options.altBackground ? options.altBackground : "#efefef"}; +} + +.statediagram-cluster .inner { + rx:0; + ry:0; +} + +.statediagram-state rect.basic { + rx: 5px; + ry: 5px; +} +.statediagram-state rect.divider { + stroke-dasharray: 10,10; + fill: ${options.altBackground ? options.altBackground : "#efefef"}; +} + +.note-edge { + stroke-dasharray: 5; +} + +.statediagram-note rect { + fill: ${options.noteBkgColor}; + stroke: ${options.noteBorderColor}; + stroke-width: 1px; + rx: 0; + ry: 0; +} +.statediagram-note rect { + fill: ${options.noteBkgColor}; + stroke: ${options.noteBorderColor}; + stroke-width: 1px; + rx: 0; + ry: 0; +} + +.statediagram-note text { + fill: ${options.noteTextColor}; +} + +.statediagram-note .nodeLabel { + color: ${options.noteTextColor}; +} +.statediagram .edgeLabel { + color: red; // ${options.noteTextColor}; +} + +#dependencyStart, #dependencyEnd { + fill: ${options.lineColor}; + stroke: ${options.lineColor}; + stroke-width: 1; +} + +.statediagramTitleText { + text-anchor: middle; + font-size: 18px; + fill: ${options.textColor}; +} +`; +const styles = getStyles; +export { + DEFAULT_STATE_TYPE as D, + STMT_RELATION as S, + DIVIDER_TYPE as a, + STMT_STATE as b, + DEFAULT_NESTED_DOC_DIR as c, + db as d, + parser$1 as p, + styles as s +}; diff --git a/0.6.0/js/mermaid/svgDrawCommon-5e1cfd1d.js b/0.6.0/js/mermaid/svgDrawCommon-5e1cfd1d.js new file mode 100644 index 0000000..7c91656 --- /dev/null +++ b/0.6.0/js/mermaid/svgDrawCommon-5e1cfd1d.js @@ -0,0 +1,101 @@ +import { sanitizeUrl } from "@braintree/sanitize-url"; +import { J as lineBreakRegex } from "./mermaid-6dc72991.js"; +const drawRect = (element, rectData) => { + const rectElement = element.append("rect"); + rectElement.attr("x", rectData.x); + rectElement.attr("y", rectData.y); + rectElement.attr("fill", rectData.fill); + rectElement.attr("stroke", rectData.stroke); + rectElement.attr("width", rectData.width); + rectElement.attr("height", rectData.height); + if (rectData.name) { + rectElement.attr("name", rectData.name); + } + rectData.rx !== void 0 && rectElement.attr("rx", rectData.rx); + rectData.ry !== void 0 && rectElement.attr("ry", rectData.ry); + if (rectData.attrs !== void 0) { + for (const attrKey in rectData.attrs) { + rectElement.attr(attrKey, rectData.attrs[attrKey]); + } + } + rectData.class !== void 0 && rectElement.attr("class", rectData.class); + return rectElement; +}; +const drawBackgroundRect = (element, bounds) => { + const rectData = { + x: bounds.startx, + y: bounds.starty, + width: bounds.stopx - bounds.startx, + height: bounds.stopy - bounds.starty, + fill: bounds.fill, + stroke: bounds.stroke, + class: "rect" + }; + const rectElement = drawRect(element, rectData); + rectElement.lower(); +}; +const drawText = (element, textData) => { + const nText = textData.text.replace(lineBreakRegex, " "); + const textElem = element.append("text"); + textElem.attr("x", textData.x); + textElem.attr("y", textData.y); + textElem.attr("class", "legend"); + textElem.style("text-anchor", textData.anchor); + textData.class !== void 0 && textElem.attr("class", textData.class); + const tspan = textElem.append("tspan"); + tspan.attr("x", textData.x + textData.textMargin * 2); + tspan.text(nText); + return textElem; +}; +const drawImage = (elem, x, y, link) => { + const imageElement = elem.append("image"); + imageElement.attr("x", x); + imageElement.attr("y", y); + const sanitizedLink = sanitizeUrl(link); + imageElement.attr("xlink:href", sanitizedLink); +}; +const drawEmbeddedImage = (element, x, y, link) => { + const imageElement = element.append("use"); + imageElement.attr("x", x); + imageElement.attr("y", y); + const sanitizedLink = sanitizeUrl(link); + imageElement.attr("xlink:href", `#${sanitizedLink}`); +}; +const getNoteRect = () => { + const noteRectData = { + x: 0, + y: 0, + width: 100, + height: 100, + fill: "#EDF2AE", + stroke: "#666", + anchor: "start", + rx: 0, + ry: 0 + }; + return noteRectData; +}; +const getTextObj = () => { + const testObject = { + x: 0, + y: 0, + width: 100, + height: 100, + "text-anchor": "start", + style: "#666", + textMargin: 0, + rx: 0, + ry: 0, + tspan: true + }; + return testObject; +}; +export { + drawBackgroundRect as a, + drawEmbeddedImage as b, + drawImage as c, + drawRect as d, + getTextObj as e, + drawText as f, + getNoteRect as g +}; diff --git a/0.6.0/js/mermaid/svgDrawCommon-d6ab583c.js b/0.6.0/js/mermaid/svgDrawCommon-d6ab583c.js new file mode 100644 index 0000000..7b6056a --- /dev/null +++ b/0.6.0/js/mermaid/svgDrawCommon-d6ab583c.js @@ -0,0 +1,100 @@ +import { aq as lineBreakRegex, e as dist } from "./mermaid-dcacb631.js"; +const drawRect = (element, rectData) => { + const rectElement = element.append("rect"); + rectElement.attr("x", rectData.x); + rectElement.attr("y", rectData.y); + rectElement.attr("fill", rectData.fill); + rectElement.attr("stroke", rectData.stroke); + rectElement.attr("width", rectData.width); + rectElement.attr("height", rectData.height); + if (rectData.name) { + rectElement.attr("name", rectData.name); + } + rectData.rx !== void 0 && rectElement.attr("rx", rectData.rx); + rectData.ry !== void 0 && rectElement.attr("ry", rectData.ry); + if (rectData.attrs !== void 0) { + for (const attrKey in rectData.attrs) { + rectElement.attr(attrKey, rectData.attrs[attrKey]); + } + } + rectData.class !== void 0 && rectElement.attr("class", rectData.class); + return rectElement; +}; +const drawBackgroundRect = (element, bounds) => { + const rectData = { + x: bounds.startx, + y: bounds.starty, + width: bounds.stopx - bounds.startx, + height: bounds.stopy - bounds.starty, + fill: bounds.fill, + stroke: bounds.stroke, + class: "rect" + }; + const rectElement = drawRect(element, rectData); + rectElement.lower(); +}; +const drawText = (element, textData) => { + const nText = textData.text.replace(lineBreakRegex, " "); + const textElem = element.append("text"); + textElem.attr("x", textData.x); + textElem.attr("y", textData.y); + textElem.attr("class", "legend"); + textElem.style("text-anchor", textData.anchor); + textData.class !== void 0 && textElem.attr("class", textData.class); + const tspan = textElem.append("tspan"); + tspan.attr("x", textData.x + textData.textMargin * 2); + tspan.text(nText); + return textElem; +}; +const drawImage = (elem, x, y, link) => { + const imageElement = elem.append("image"); + imageElement.attr("x", x); + imageElement.attr("y", y); + const sanitizedLink = dist.sanitizeUrl(link); + imageElement.attr("xlink:href", sanitizedLink); +}; +const drawEmbeddedImage = (element, x, y, link) => { + const imageElement = element.append("use"); + imageElement.attr("x", x); + imageElement.attr("y", y); + const sanitizedLink = dist.sanitizeUrl(link); + imageElement.attr("xlink:href", `#${sanitizedLink}`); +}; +const getNoteRect = () => { + const noteRectData = { + x: 0, + y: 0, + width: 100, + height: 100, + fill: "#EDF2AE", + stroke: "#666", + anchor: "start", + rx: 0, + ry: 0 + }; + return noteRectData; +}; +const getTextObj = () => { + const testObject = { + x: 0, + y: 0, + width: 100, + height: 100, + "text-anchor": "start", + style: "#666", + textMargin: 0, + rx: 0, + ry: 0, + tspan: true + }; + return testObject; +}; +export { + drawBackgroundRect as a, + drawEmbeddedImage as b, + drawImage as c, + drawRect as d, + getTextObj as e, + drawText as f, + getNoteRect as g +}; diff --git a/0.6.0/js/mermaid/svgDrawCommon-ecc5f780.js b/0.6.0/js/mermaid/svgDrawCommon-ecc5f780.js new file mode 100644 index 0000000..0cd094e --- /dev/null +++ b/0.6.0/js/mermaid/svgDrawCommon-ecc5f780.js @@ -0,0 +1,64 @@ +import { aq as o, e as i } from "./mermaid-9f2aa176.js"; +const l = (s, t) => { + const e = s.append("rect"); + if (e.attr("x", t.x), e.attr("y", t.y), e.attr("fill", t.fill), e.attr("stroke", t.stroke), e.attr("width", t.width), e.attr("height", t.height), t.name && e.attr("name", t.name), t.rx !== void 0 && e.attr("rx", t.rx), t.ry !== void 0 && e.attr("ry", t.ry), t.attrs !== void 0) + for (const r in t.attrs) + e.attr(r, t.attrs[r]); + return t.class !== void 0 && e.attr("class", t.class), e; +}, x = (s, t) => { + const e = { + x: t.startx, + y: t.starty, + width: t.stopx - t.startx, + height: t.stopy - t.starty, + fill: t.fill, + stroke: t.stroke, + class: "rect" + }; + l(s, e).lower(); +}, d = (s, t) => { + const e = t.text.replace(o, " "), r = s.append("text"); + r.attr("x", t.x), r.attr("y", t.y), r.attr("class", "legend"), r.style("text-anchor", t.anchor), t.class !== void 0 && r.attr("class", t.class); + const n = r.append("tspan"); + return n.attr("x", t.x + t.textMargin * 2), n.text(e), r; +}, h = (s, t, e, r) => { + const n = s.append("image"); + n.attr("x", t), n.attr("y", e); + const a = i.sanitizeUrl(r); + n.attr("xlink:href", a); +}, y = (s, t, e, r) => { + const n = s.append("use"); + n.attr("x", t), n.attr("y", e); + const a = i.sanitizeUrl(r); + n.attr("xlink:href", `#${a}`); +}, g = () => ({ + x: 0, + y: 0, + width: 100, + height: 100, + fill: "#EDF2AE", + stroke: "#666", + anchor: "start", + rx: 0, + ry: 0 +}), p = () => ({ + x: 0, + y: 0, + width: 100, + height: 100, + "text-anchor": "start", + style: "#666", + textMargin: 0, + rx: 0, + ry: 0, + tspan: !0 +}); +export { + x as a, + y as b, + h as c, + l as d, + p as e, + d as f, + g +}; diff --git a/0.6.0/js/mermaid/timeline-definition-23ce0e2e.js b/0.6.0/js/mermaid/timeline-definition-23ce0e2e.js new file mode 100644 index 0000000..db017d5 --- /dev/null +++ b/0.6.0/js/mermaid/timeline-definition-23ce0e2e.js @@ -0,0 +1,1211 @@ +import { as as commonDb, E as clear$1, j as d3select, c as getConfig, l as log, t as setupGraphViewbox, at as isDark, au as lighten, av as darken } from "./mermaid-dcacb631.js"; +import { d as d3arc } from "./arc-c0f908ab.js"; +import "./path-39bad7e2.js"; +var parser = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [6, 8, 10, 11, 12, 14, 16, 17, 20, 21], $V1 = [1, 9], $V2 = [1, 10], $V3 = [1, 11], $V4 = [1, 12], $V5 = [1, 13], $V6 = [1, 16], $V7 = [1, 17]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "timeline": 4, "document": 5, "EOF": 6, "line": 7, "SPACE": 8, "statement": 9, "NEWLINE": 10, "title": 11, "acc_title": 12, "acc_title_value": 13, "acc_descr": 14, "acc_descr_value": 15, "acc_descr_multiline_value": 16, "section": 17, "period_statement": 18, "event_statement": 19, "period": 20, "event": 21, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 4: "timeline", 6: "EOF", 8: "SPACE", 10: "NEWLINE", 11: "title", 12: "acc_title", 13: "acc_title_value", 14: "acc_descr", 15: "acc_descr_value", 16: "acc_descr_multiline_value", 17: "section", 20: "period", 21: "event" }, + productions_: [0, [3, 3], [5, 0], [5, 2], [7, 2], [7, 1], [7, 1], [7, 1], [9, 1], [9, 2], [9, 2], [9, 1], [9, 1], [9, 1], [9, 1], [18, 1], [19, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 1: + return $$[$0 - 1]; + case 2: + this.$ = []; + break; + case 3: + $$[$0 - 1].push($$[$0]); + this.$ = $$[$0 - 1]; + break; + case 4: + case 5: + this.$ = $$[$0]; + break; + case 6: + case 7: + this.$ = []; + break; + case 8: + yy.getCommonDb().setDiagramTitle($$[$0].substr(6)); + this.$ = $$[$0].substr(6); + break; + case 9: + this.$ = $$[$0].trim(); + yy.getCommonDb().setAccTitle(this.$); + break; + case 10: + case 11: + this.$ = $$[$0].trim(); + yy.getCommonDb().setAccDescription(this.$); + break; + case 12: + yy.addSection($$[$0].substr(8)); + this.$ = $$[$0].substr(8); + break; + case 15: + yy.addTask($$[$0], 0, ""); + this.$ = $$[$0]; + break; + case 16: + yy.addEvent($$[$0].substr(2)); + this.$ = $$[$0]; + break; + } + }, + table: [{ 3: 1, 4: [1, 2] }, { 1: [3] }, o($V0, [2, 2], { 5: 3 }), { 6: [1, 4], 7: 5, 8: [1, 6], 9: 7, 10: [1, 8], 11: $V1, 12: $V2, 14: $V3, 16: $V4, 17: $V5, 18: 14, 19: 15, 20: $V6, 21: $V7 }, o($V0, [2, 7], { 1: [2, 1] }), o($V0, [2, 3]), { 9: 18, 11: $V1, 12: $V2, 14: $V3, 16: $V4, 17: $V5, 18: 14, 19: 15, 20: $V6, 21: $V7 }, o($V0, [2, 5]), o($V0, [2, 6]), o($V0, [2, 8]), { 13: [1, 19] }, { 15: [1, 20] }, o($V0, [2, 11]), o($V0, [2, 12]), o($V0, [2, 13]), o($V0, [2, 14]), o($V0, [2, 15]), o($V0, [2, 16]), o($V0, [2, 4]), o($V0, [2, 9]), o($V0, [2, 10])], + defaultActions: {}, + parseError: function parseError(str, hash) { + if (hash.recoverable) { + this.trace(str); + } else { + var error = new Error(str); + error.hash = hash; + throw error; + } + }, + parse: function parse(input) { + var self = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex() { + var token; + token = tstack.pop() || lexer2.lex() || EOF; + if (typeof token !== "number") { + if (token instanceof Array) { + tstack = token; + token = tstack.pop(); + } + token = self.symbols_[token] || token; + } + return token; + } + var symbol, state, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state = stack[stack.length - 1]; + if (this.defaultActions[state]) { + action = this.defaultActions[state]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex(); + } + action = table[state] && table[state][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str, hash); + } else { + throw new Error(str); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch = this._input[0]; + this.yytext += ch; + this.yyleng++; + this.offset++; + this.match += ch; + this.matched += ch; + var lines = ch.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch; + }, + // unshifts one char (or a string) into the input + unput: function(ch) { + var len = ch.length; + var lines = ch.split(/(?:\r\n?|\n)/g); + this._input = ch + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next = this.match; + if (next.length < 20) { + next += this._input.substr(0, 20 - next.length); + } + return (next.substr(0, 20) + (next.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token) { + return token; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token, match, tempMatch, index; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i = 0; i < rules.length; i++) { + tempMatch = this._input.match(this.rules[rules[i]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index = i; + if (this.options.backtrack_lexer) { + token = this.test_match(tempMatch, rules[i]); + if (token !== false) { + return token; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token = this.test_match(match, rules[index]); + if (token !== false) { + return token; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + break; + case 1: + break; + case 2: + return 10; + case 3: + break; + case 4: + break; + case 5: + return 4; + case 6: + return 11; + case 7: + this.begin("acc_title"); + return 12; + case 8: + this.popState(); + return "acc_title_value"; + case 9: + this.begin("acc_descr"); + return 14; + case 10: + this.popState(); + return "acc_descr_value"; + case 11: + this.begin("acc_descr_multiline"); + break; + case 12: + this.popState(); + break; + case 13: + return "acc_descr_multiline_value"; + case 14: + return 17; + case 15: + return 21; + case 16: + return 20; + case 17: + return 6; + case 18: + return "INVALID"; + } + }, + rules: [/^(?:%(?!\{)[^\n]*)/i, /^(?:[^\}]%%[^\n]*)/i, /^(?:[\n]+)/i, /^(?:\s+)/i, /^(?:#[^\n]*)/i, /^(?:timeline\b)/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, /^(?:section\s[^#:\n;]+)/i, /^(?::\s[^#:\n;]+)/i, /^(?:[^#:\n;]+)/i, /^(?:$)/i, /^(?:.)/i], + conditions: { "acc_descr_multiline": { "rules": [12, 13], "inclusive": false }, "acc_descr": { "rules": [10], "inclusive": false }, "acc_title": { "rules": [8], "inclusive": false }, "INITIAL": { "rules": [0, 1, 2, 3, 4, 5, 6, 7, 9, 11, 14, 15, 16, 17, 18], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser() { + this.yy = {}; + } + Parser.prototype = parser2; + parser2.Parser = Parser; + return new Parser(); +}(); +parser.parser = parser; +const parser$1 = parser; +let currentSection = ""; +let currentTaskId = 0; +const sections = []; +const tasks = []; +const rawTasks = []; +const getCommonDb = () => commonDb; +const clear = function() { + sections.length = 0; + tasks.length = 0; + currentSection = ""; + rawTasks.length = 0; + clear$1(); +}; +const addSection = function(txt) { + currentSection = txt; + sections.push(txt); +}; +const getSections = function() { + return sections; +}; +const getTasks = function() { + let allItemsProcessed = compileTasks(); + const maxDepth = 100; + let iterationCount = 0; + while (!allItemsProcessed && iterationCount < maxDepth) { + allItemsProcessed = compileTasks(); + iterationCount++; + } + tasks.push(...rawTasks); + return tasks; +}; +const addTask = function(period, length, event) { + const rawTask = { + id: currentTaskId++, + section: currentSection, + type: currentSection, + task: period, + score: length ? length : 0, + //if event is defined, then add it the events array + events: event ? [event] : [] + }; + rawTasks.push(rawTask); +}; +const addEvent = function(event) { + const currentTask = rawTasks.find((task) => task.id === currentTaskId - 1); + currentTask.events.push(event); +}; +const addTaskOrg = function(descr) { + const newTask = { + section: currentSection, + type: currentSection, + description: descr, + task: descr, + classes: [] + }; + tasks.push(newTask); +}; +const compileTasks = function() { + const compileTask = function(pos) { + return rawTasks[pos].processed; + }; + let allProcessed = true; + for (const [i, rawTask] of rawTasks.entries()) { + compileTask(i); + allProcessed = allProcessed && rawTask.processed; + } + return allProcessed; +}; +const timelineDb = { + clear, + getCommonDb, + addSection, + getSections, + getTasks, + addTask, + addTaskOrg, + addEvent +}; +const db = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + addEvent, + addSection, + addTask, + addTaskOrg, + clear, + default: timelineDb, + getCommonDb, + getSections, + getTasks +}, Symbol.toStringTag, { value: "Module" })); +const MAX_SECTIONS = 12; +const drawRect = function(elem, rectData) { + const rectElem = elem.append("rect"); + rectElem.attr("x", rectData.x); + rectElem.attr("y", rectData.y); + rectElem.attr("fill", rectData.fill); + rectElem.attr("stroke", rectData.stroke); + rectElem.attr("width", rectData.width); + rectElem.attr("height", rectData.height); + rectElem.attr("rx", rectData.rx); + rectElem.attr("ry", rectData.ry); + if (rectData.class !== void 0) { + rectElem.attr("class", rectData.class); + } + return rectElem; +}; +const drawFace = function(element, faceData) { + const radius = 15; + const circleElement = element.append("circle").attr("cx", faceData.cx).attr("cy", faceData.cy).attr("class", "face").attr("r", radius).attr("stroke-width", 2).attr("overflow", "visible"); + const face = element.append("g"); + face.append("circle").attr("cx", faceData.cx - radius / 3).attr("cy", faceData.cy - radius / 3).attr("r", 1.5).attr("stroke-width", 2).attr("fill", "#666").attr("stroke", "#666"); + face.append("circle").attr("cx", faceData.cx + radius / 3).attr("cy", faceData.cy - radius / 3).attr("r", 1.5).attr("stroke-width", 2).attr("fill", "#666").attr("stroke", "#666"); + function smile(face2) { + const arc = d3arc().startAngle(Math.PI / 2).endAngle(3 * (Math.PI / 2)).innerRadius(radius / 2).outerRadius(radius / 2.2); + face2.append("path").attr("class", "mouth").attr("d", arc).attr("transform", "translate(" + faceData.cx + "," + (faceData.cy + 2) + ")"); + } + function sad(face2) { + const arc = d3arc().startAngle(3 * Math.PI / 2).endAngle(5 * (Math.PI / 2)).innerRadius(radius / 2).outerRadius(radius / 2.2); + face2.append("path").attr("class", "mouth").attr("d", arc).attr("transform", "translate(" + faceData.cx + "," + (faceData.cy + 7) + ")"); + } + function ambivalent(face2) { + face2.append("line").attr("class", "mouth").attr("stroke", 2).attr("x1", faceData.cx - 5).attr("y1", faceData.cy + 7).attr("x2", faceData.cx + 5).attr("y2", faceData.cy + 7).attr("class", "mouth").attr("stroke-width", "1px").attr("stroke", "#666"); + } + if (faceData.score > 3) { + smile(face); + } else if (faceData.score < 3) { + sad(face); + } else { + ambivalent(face); + } + return circleElement; +}; +const drawCircle = function(element, circleData) { + const circleElement = element.append("circle"); + circleElement.attr("cx", circleData.cx); + circleElement.attr("cy", circleData.cy); + circleElement.attr("class", "actor-" + circleData.pos); + circleElement.attr("fill", circleData.fill); + circleElement.attr("stroke", circleData.stroke); + circleElement.attr("r", circleData.r); + if (circleElement.class !== void 0) { + circleElement.attr("class", circleElement.class); + } + if (circleData.title !== void 0) { + circleElement.append("title").text(circleData.title); + } + return circleElement; +}; +const drawText = function(elem, textData) { + const nText = textData.text.replace(//gi, " "); + const textElem = elem.append("text"); + textElem.attr("x", textData.x); + textElem.attr("y", textData.y); + textElem.attr("class", "legend"); + textElem.style("text-anchor", textData.anchor); + if (textData.class !== void 0) { + textElem.attr("class", textData.class); + } + const span = textElem.append("tspan"); + span.attr("x", textData.x + textData.textMargin * 2); + span.text(nText); + return textElem; +}; +const drawLabel = function(elem, txtObject) { + function genPoints(x, y, width, height, cut) { + return x + "," + y + " " + (x + width) + "," + y + " " + (x + width) + "," + (y + height - cut) + " " + (x + width - cut * 1.2) + "," + (y + height) + " " + x + "," + (y + height); + } + const polygon = elem.append("polygon"); + polygon.attr("points", genPoints(txtObject.x, txtObject.y, 50, 20, 7)); + polygon.attr("class", "labelBox"); + txtObject.y = txtObject.y + txtObject.labelMargin; + txtObject.x = txtObject.x + 0.5 * txtObject.labelMargin; + drawText(elem, txtObject); +}; +const drawSection = function(elem, section, conf) { + const g = elem.append("g"); + const rect = getNoteRect(); + rect.x = section.x; + rect.y = section.y; + rect.fill = section.fill; + rect.width = conf.width; + rect.height = conf.height; + rect.class = "journey-section section-type-" + section.num; + rect.rx = 3; + rect.ry = 3; + drawRect(g, rect); + _drawTextCandidateFunc(conf)( + section.text, + g, + rect.x, + rect.y, + rect.width, + rect.height, + { class: "journey-section section-type-" + section.num }, + conf, + section.colour + ); +}; +let taskCount = -1; +const drawTask = function(elem, task, conf) { + const center = task.x + conf.width / 2; + const g = elem.append("g"); + taskCount++; + const maxHeight = 300 + 5 * 30; + g.append("line").attr("id", "task" + taskCount).attr("x1", center).attr("y1", task.y).attr("x2", center).attr("y2", maxHeight).attr("class", "task-line").attr("stroke-width", "1px").attr("stroke-dasharray", "4 2").attr("stroke", "#666"); + drawFace(g, { + cx: center, + cy: 300 + (5 - task.score) * 30, + score: task.score + }); + const rect = getNoteRect(); + rect.x = task.x; + rect.y = task.y; + rect.fill = task.fill; + rect.width = conf.width; + rect.height = conf.height; + rect.class = "task task-type-" + task.num; + rect.rx = 3; + rect.ry = 3; + drawRect(g, rect); + task.x + 14; + _drawTextCandidateFunc(conf)( + task.task, + g, + rect.x, + rect.y, + rect.width, + rect.height, + { class: "task" }, + conf, + task.colour + ); +}; +const drawBackgroundRect = function(elem, bounds) { + const rectElem = drawRect(elem, { + x: bounds.startx, + y: bounds.starty, + width: bounds.stopx - bounds.startx, + height: bounds.stopy - bounds.starty, + fill: bounds.fill, + class: "rect" + }); + rectElem.lower(); +}; +const getTextObj = function() { + return { + x: 0, + y: 0, + fill: void 0, + "text-anchor": "start", + width: 100, + height: 100, + textMargin: 0, + rx: 0, + ry: 0 + }; +}; +const getNoteRect = function() { + return { + x: 0, + y: 0, + width: 100, + anchor: "start", + height: 100, + rx: 0, + ry: 0 + }; +}; +const _drawTextCandidateFunc = function() { + function byText(content, g, x, y, width, height, textAttrs, colour) { + const text = g.append("text").attr("x", x + width / 2).attr("y", y + height / 2 + 5).style("font-color", colour).style("text-anchor", "middle").text(content); + _setTextAttrs(text, textAttrs); + } + function byTspan(content, g, x, y, width, height, textAttrs, conf, colour) { + const { taskFontSize, taskFontFamily } = conf; + const lines = content.split(//gi); + for (let i = 0; i < lines.length; i++) { + const dy = i * taskFontSize - taskFontSize * (lines.length - 1) / 2; + const text = g.append("text").attr("x", x + width / 2).attr("y", y).attr("fill", colour).style("text-anchor", "middle").style("font-size", taskFontSize).style("font-family", taskFontFamily); + text.append("tspan").attr("x", x + width / 2).attr("dy", dy).text(lines[i]); + text.attr("y", y + height / 2).attr("dominant-baseline", "central").attr("alignment-baseline", "central"); + _setTextAttrs(text, textAttrs); + } + } + function byFo(content, g, x, y, width, height, textAttrs, conf) { + const body = g.append("switch"); + const f = body.append("foreignObject").attr("x", x).attr("y", y).attr("width", width).attr("height", height).attr("position", "fixed"); + const text = f.append("xhtml:div").style("display", "table").style("height", "100%").style("width", "100%"); + text.append("div").attr("class", "label").style("display", "table-cell").style("text-align", "center").style("vertical-align", "middle").text(content); + byTspan(content, body, x, y, width, height, textAttrs, conf); + _setTextAttrs(text, textAttrs); + } + function _setTextAttrs(toText, fromTextAttrsDict) { + for (const key in fromTextAttrsDict) { + if (key in fromTextAttrsDict) { + toText.attr(key, fromTextAttrsDict[key]); + } + } + } + return function(conf) { + return conf.textPlacement === "fo" ? byFo : conf.textPlacement === "old" ? byText : byTspan; + }; +}(); +const initGraphics = function(graphics) { + graphics.append("defs").append("marker").attr("id", "arrowhead").attr("refX", 5).attr("refY", 2).attr("markerWidth", 6).attr("markerHeight", 4).attr("orient", "auto").append("path").attr("d", "M 0,0 V 4 L6,2 Z"); +}; +function wrap(text, width) { + text.each(function() { + var text2 = d3select(this), words = text2.text().split(/(\s+|
    )/).reverse(), word, line = [], lineHeight = 1.1, y = text2.attr("y"), dy = parseFloat(text2.attr("dy")), tspan = text2.text(null).append("tspan").attr("x", 0).attr("y", y).attr("dy", dy + "em"); + for (let j = 0; j < words.length; j++) { + word = words[words.length - 1 - j]; + line.push(word); + tspan.text(line.join(" ").trim()); + if (tspan.node().getComputedTextLength() > width || word === "
    ") { + line.pop(); + tspan.text(line.join(" ").trim()); + if (word === "
    ") { + line = [""]; + } else { + line = [word]; + } + tspan = text2.append("tspan").attr("x", 0).attr("y", y).attr("dy", lineHeight + "em").text(word); + } + } + }); +} +const drawNode = function(elem, node, fullSection, conf) { + const section = fullSection % MAX_SECTIONS - 1; + const nodeElem = elem.append("g"); + node.section = section; + nodeElem.attr( + "class", + (node.class ? node.class + " " : "") + "timeline-node " + ("section-" + section) + ); + const bkgElem = nodeElem.append("g"); + const textElem = nodeElem.append("g"); + const txt = textElem.append("text").text(node.descr).attr("dy", "1em").attr("alignment-baseline", "middle").attr("dominant-baseline", "middle").attr("text-anchor", "middle").call(wrap, node.width); + const bbox = txt.node().getBBox(); + const fontSize = conf.fontSize && conf.fontSize.replace ? conf.fontSize.replace("px", "") : conf.fontSize; + node.height = bbox.height + fontSize * 1.1 * 0.5 + node.padding; + node.height = Math.max(node.height, node.maxHeight); + node.width = node.width + 2 * node.padding; + textElem.attr("transform", "translate(" + node.width / 2 + ", " + node.padding / 2 + ")"); + defaultBkg(bkgElem, node, section); + return node; +}; +const getVirtualNodeHeight = function(elem, node, conf) { + const textElem = elem.append("g"); + const txt = textElem.append("text").text(node.descr).attr("dy", "1em").attr("alignment-baseline", "middle").attr("dominant-baseline", "middle").attr("text-anchor", "middle").call(wrap, node.width); + const bbox = txt.node().getBBox(); + const fontSize = conf.fontSize && conf.fontSize.replace ? conf.fontSize.replace("px", "") : conf.fontSize; + textElem.remove(); + return bbox.height + fontSize * 1.1 * 0.5 + node.padding; +}; +const defaultBkg = function(elem, node, section) { + const rd = 5; + elem.append("path").attr("id", "node-" + node.id).attr("class", "node-bkg node-" + node.type).attr( + "d", + `M0 ${node.height - rd} v${-node.height + 2 * rd} q0,-5 5,-5 h${node.width - 2 * rd} q5,0 5,5 v${node.height - rd} H0 Z` + ); + elem.append("line").attr("class", "node-line-" + section).attr("x1", 0).attr("y1", node.height).attr("x2", node.width).attr("y2", node.height); +}; +const svgDraw = { + drawRect, + drawCircle, + drawSection, + drawText, + drawLabel, + drawTask, + drawBackgroundRect, + getTextObj, + getNoteRect, + initGraphics, + drawNode, + getVirtualNodeHeight +}; +const draw = function(text, id, version, diagObj) { + var _a, _b; + const conf = getConfig(); + const LEFT_MARGIN = conf.leftMargin ?? 50; + log.debug("timeline", diagObj.db); + const securityLevel = conf.securityLevel; + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = d3select("#i" + id); + } + const root = securityLevel === "sandbox" ? d3select(sandboxElement.nodes()[0].contentDocument.body) : d3select("body"); + const svg = root.select("#" + id); + svg.append("g"); + const tasks2 = diagObj.db.getTasks(); + const title = diagObj.db.getCommonDb().getDiagramTitle(); + log.debug("task", tasks2); + svgDraw.initGraphics(svg); + const sections2 = diagObj.db.getSections(); + log.debug("sections", sections2); + let maxSectionHeight = 0; + let maxTaskHeight = 0; + let depthY = 0; + let sectionBeginY = 0; + let masterX = 50 + LEFT_MARGIN; + let masterY = 50; + sectionBeginY = 50; + let sectionNumber = 0; + let hasSections = true; + sections2.forEach(function(section) { + const sectionNode = { + number: sectionNumber, + descr: section, + section: sectionNumber, + width: 150, + padding: 20, + maxHeight: maxSectionHeight + }; + const sectionHeight = svgDraw.getVirtualNodeHeight(svg, sectionNode, conf); + log.debug("sectionHeight before draw", sectionHeight); + maxSectionHeight = Math.max(maxSectionHeight, sectionHeight + 20); + }); + let maxEventCount = 0; + let maxEventLineLength = 0; + log.debug("tasks.length", tasks2.length); + for (const [i, task] of tasks2.entries()) { + const taskNode = { + number: i, + descr: task, + section: task.section, + width: 150, + padding: 20, + maxHeight: maxTaskHeight + }; + const taskHeight = svgDraw.getVirtualNodeHeight(svg, taskNode, conf); + log.debug("taskHeight before draw", taskHeight); + maxTaskHeight = Math.max(maxTaskHeight, taskHeight + 20); + maxEventCount = Math.max(maxEventCount, task.events.length); + let maxEventLineLengthTemp = 0; + for (let j = 0; j < task.events.length; j++) { + const event = task.events[j]; + const eventNode = { + descr: event, + section: task.section, + number: task.section, + width: 150, + padding: 20, + maxHeight: 50 + }; + maxEventLineLengthTemp += svgDraw.getVirtualNodeHeight(svg, eventNode, conf); + } + maxEventLineLength = Math.max(maxEventLineLength, maxEventLineLengthTemp); + } + log.debug("maxSectionHeight before draw", maxSectionHeight); + log.debug("maxTaskHeight before draw", maxTaskHeight); + if (sections2 && sections2.length > 0) { + sections2.forEach((section) => { + const tasksForSection = tasks2.filter((task) => task.section === section); + const sectionNode = { + number: sectionNumber, + descr: section, + section: sectionNumber, + width: 200 * Math.max(tasksForSection.length, 1) - 50, + padding: 20, + maxHeight: maxSectionHeight + }; + log.debug("sectionNode", sectionNode); + const sectionNodeWrapper = svg.append("g"); + const node = svgDraw.drawNode(sectionNodeWrapper, sectionNode, sectionNumber, conf); + log.debug("sectionNode output", node); + sectionNodeWrapper.attr("transform", `translate(${masterX}, ${sectionBeginY})`); + masterY += maxSectionHeight + 50; + if (tasksForSection.length > 0) { + drawTasks( + svg, + tasksForSection, + sectionNumber, + masterX, + masterY, + maxTaskHeight, + conf, + maxEventCount, + maxEventLineLength, + maxSectionHeight, + false + ); + } + masterX += 200 * Math.max(tasksForSection.length, 1); + masterY = sectionBeginY; + sectionNumber++; + }); + } else { + hasSections = false; + drawTasks( + svg, + tasks2, + sectionNumber, + masterX, + masterY, + maxTaskHeight, + conf, + maxEventCount, + maxEventLineLength, + maxSectionHeight, + true + ); + } + const box = svg.node().getBBox(); + log.debug("bounds", box); + if (title) { + svg.append("text").text(title).attr("x", box.width / 2 - LEFT_MARGIN).attr("font-size", "4ex").attr("font-weight", "bold").attr("y", 20); + } + depthY = hasSections ? maxSectionHeight + maxTaskHeight + 150 : maxTaskHeight + 100; + const lineWrapper = svg.append("g").attr("class", "lineWrapper"); + lineWrapper.append("line").attr("x1", LEFT_MARGIN).attr("y1", depthY).attr("x2", box.width + 3 * LEFT_MARGIN).attr("y2", depthY).attr("stroke-width", 4).attr("stroke", "black").attr("marker-end", "url(#arrowhead)"); + setupGraphViewbox( + void 0, + svg, + ((_a = conf.timeline) == null ? void 0 : _a.padding) ?? 50, + ((_b = conf.timeline) == null ? void 0 : _b.useMaxWidth) ?? false + ); +}; +const drawTasks = function(diagram2, tasks2, sectionColor, masterX, masterY, maxTaskHeight, conf, maxEventCount, maxEventLineLength, maxSectionHeight, isWithoutSections) { + var _a; + for (const task of tasks2) { + const taskNode = { + descr: task.task, + section: sectionColor, + number: sectionColor, + width: 150, + padding: 20, + maxHeight: maxTaskHeight + }; + log.debug("taskNode", taskNode); + const taskWrapper = diagram2.append("g").attr("class", "taskWrapper"); + const node = svgDraw.drawNode(taskWrapper, taskNode, sectionColor, conf); + const taskHeight = node.height; + log.debug("taskHeight after draw", taskHeight); + taskWrapper.attr("transform", `translate(${masterX}, ${masterY})`); + maxTaskHeight = Math.max(maxTaskHeight, taskHeight); + if (task.events) { + const lineWrapper = diagram2.append("g").attr("class", "lineWrapper"); + let lineLength = maxTaskHeight; + masterY += 100; + lineLength = lineLength + drawEvents(diagram2, task.events, sectionColor, masterX, masterY, conf); + masterY -= 100; + lineWrapper.append("line").attr("x1", masterX + 190 / 2).attr("y1", masterY + maxTaskHeight).attr("x2", masterX + 190 / 2).attr( + "y2", + masterY + maxTaskHeight + (isWithoutSections ? maxTaskHeight : maxSectionHeight) + maxEventLineLength + 120 + ).attr("stroke-width", 2).attr("stroke", "black").attr("marker-end", "url(#arrowhead)").attr("stroke-dasharray", "5,5"); + } + masterX = masterX + 200; + if (isWithoutSections && !((_a = conf.timeline) == null ? void 0 : _a.disableMulticolor)) { + sectionColor++; + } + } + masterY = masterY - 10; +}; +const drawEvents = function(diagram2, events, sectionColor, masterX, masterY, conf) { + let maxEventHeight = 0; + const eventBeginY = masterY; + masterY = masterY + 100; + for (const event of events) { + const eventNode = { + descr: event, + section: sectionColor, + number: sectionColor, + width: 150, + padding: 20, + maxHeight: 50 + }; + log.debug("eventNode", eventNode); + const eventWrapper = diagram2.append("g").attr("class", "eventWrapper"); + const node = svgDraw.drawNode(eventWrapper, eventNode, sectionColor, conf); + const eventHeight = node.height; + maxEventHeight = maxEventHeight + eventHeight; + eventWrapper.attr("transform", `translate(${masterX}, ${masterY})`); + masterY = masterY + 10 + eventHeight; + } + masterY = eventBeginY; + return maxEventHeight; +}; +const renderer = { + setConf: () => { + }, + draw +}; +const genSections = (options) => { + let sections2 = ""; + for (let i = 0; i < options.THEME_COLOR_LIMIT; i++) { + options["lineColor" + i] = options["lineColor" + i] || options["cScaleInv" + i]; + if (isDark(options["lineColor" + i])) { + options["lineColor" + i] = lighten(options["lineColor" + i], 20); + } else { + options["lineColor" + i] = darken(options["lineColor" + i], 20); + } + } + for (let i = 0; i < options.THEME_COLOR_LIMIT; i++) { + const sw = "" + (17 - 3 * i); + sections2 += ` + .section-${i - 1} rect, .section-${i - 1} path, .section-${i - 1} circle, .section-${i - 1} path { + fill: ${options["cScale" + i]}; + } + .section-${i - 1} text { + fill: ${options["cScaleLabel" + i]}; + } + .node-icon-${i - 1} { + font-size: 40px; + color: ${options["cScaleLabel" + i]}; + } + .section-edge-${i - 1}{ + stroke: ${options["cScale" + i]}; + } + .edge-depth-${i - 1}{ + stroke-width: ${sw}; + } + .section-${i - 1} line { + stroke: ${options["cScaleInv" + i]} ; + stroke-width: 3; + } + + .lineWrapper line{ + stroke: ${options["cScaleLabel" + i]} ; + } + + .disabled, .disabled circle, .disabled text { + fill: lightgray; + } + .disabled text { + fill: #efefef; + } + `; + } + return sections2; +}; +const getStyles = (options) => ` + .edge { + stroke-width: 3; + } + ${genSections(options)} + .section-root rect, .section-root path, .section-root circle { + fill: ${options.git0}; + } + .section-root text { + fill: ${options.gitBranchLabel0}; + } + .icon-container { + height:100%; + display: flex; + justify-content: center; + align-items: center; + } + .edge { + fill: none; + } + .eventWrapper { + filter: brightness(120%); + } +`; +const styles = getStyles; +const diagram = { + db, + renderer, + parser: parser$1, + styles +}; +export { + diagram +}; diff --git a/0.6.0/js/mermaid/timeline-definition-4ee9bff4.js b/0.6.0/js/mermaid/timeline-definition-4ee9bff4.js new file mode 100644 index 0000000..65ab732 --- /dev/null +++ b/0.6.0/js/mermaid/timeline-definition-4ee9bff4.js @@ -0,0 +1,795 @@ +import { as as ft, E as gt, j, c as mt, l as T, t as xt, at as bt, au as kt, av as _t } from "./mermaid-9f2aa176.js"; +import { d as D } from "./arc-d1f6357e.js"; +import "./path-428ebac9.js"; +var K = function() { + var n = function(f, i, r, h) { + for (r = r || {}, h = f.length; h--; r[f[h]] = i) + ; + return r; + }, t = [6, 8, 10, 11, 12, 14, 16, 17, 20, 21], e = [1, 9], a = [1, 10], s = [1, 11], c = [1, 12], o = [1, 13], y = [1, 16], g = [1, 17], u = { + trace: function() { + }, + yy: {}, + symbols_: { error: 2, start: 3, timeline: 4, document: 5, EOF: 6, line: 7, SPACE: 8, statement: 9, NEWLINE: 10, title: 11, acc_title: 12, acc_title_value: 13, acc_descr: 14, acc_descr_value: 15, acc_descr_multiline_value: 16, section: 17, period_statement: 18, event_statement: 19, period: 20, event: 21, $accept: 0, $end: 1 }, + terminals_: { 2: "error", 4: "timeline", 6: "EOF", 8: "SPACE", 10: "NEWLINE", 11: "title", 12: "acc_title", 13: "acc_title_value", 14: "acc_descr", 15: "acc_descr_value", 16: "acc_descr_multiline_value", 17: "section", 20: "period", 21: "event" }, + productions_: [0, [3, 3], [5, 0], [5, 2], [7, 2], [7, 1], [7, 1], [7, 1], [9, 1], [9, 2], [9, 2], [9, 1], [9, 1], [9, 1], [9, 1], [18, 1], [19, 1]], + performAction: function(i, r, h, d, p, l, w) { + var x = l.length - 1; + switch (p) { + case 1: + return l[x - 1]; + case 2: + this.$ = []; + break; + case 3: + l[x - 1].push(l[x]), this.$ = l[x - 1]; + break; + case 4: + case 5: + this.$ = l[x]; + break; + case 6: + case 7: + this.$ = []; + break; + case 8: + d.getCommonDb().setDiagramTitle(l[x].substr(6)), this.$ = l[x].substr(6); + break; + case 9: + this.$ = l[x].trim(), d.getCommonDb().setAccTitle(this.$); + break; + case 10: + case 11: + this.$ = l[x].trim(), d.getCommonDb().setAccDescription(this.$); + break; + case 12: + d.addSection(l[x].substr(8)), this.$ = l[x].substr(8); + break; + case 15: + d.addTask(l[x], 0, ""), this.$ = l[x]; + break; + case 16: + d.addEvent(l[x].substr(2)), this.$ = l[x]; + break; + } + }, + table: [{ 3: 1, 4: [1, 2] }, { 1: [3] }, n(t, [2, 2], { 5: 3 }), { 6: [1, 4], 7: 5, 8: [1, 6], 9: 7, 10: [1, 8], 11: e, 12: a, 14: s, 16: c, 17: o, 18: 14, 19: 15, 20: y, 21: g }, n(t, [2, 7], { 1: [2, 1] }), n(t, [2, 3]), { 9: 18, 11: e, 12: a, 14: s, 16: c, 17: o, 18: 14, 19: 15, 20: y, 21: g }, n(t, [2, 5]), n(t, [2, 6]), n(t, [2, 8]), { 13: [1, 19] }, { 15: [1, 20] }, n(t, [2, 11]), n(t, [2, 12]), n(t, [2, 13]), n(t, [2, 14]), n(t, [2, 15]), n(t, [2, 16]), n(t, [2, 4]), n(t, [2, 9]), n(t, [2, 10])], + defaultActions: {}, + parseError: function(i, r) { + if (r.recoverable) + this.trace(i); + else { + var h = new Error(i); + throw h.hash = r, h; + } + }, + parse: function(i) { + var r = this, h = [0], d = [], p = [null], l = [], w = this.table, x = "", N = 0, A = 0, V = 2, U = 1, W = l.slice.call(arguments, 1), b = Object.create(this.lexer), S = { yy: {} }; + for (var _ in this.yy) + Object.prototype.hasOwnProperty.call(this.yy, _) && (S.yy[_] = this.yy[_]); + b.setInput(i, S.yy), S.yy.lexer = b, S.yy.parser = this, typeof b.yylloc > "u" && (b.yylloc = {}); + var I = b.yylloc; + l.push(I); + var P = b.options && b.options.ranges; + typeof S.yy.parseError == "function" ? this.parseError = S.yy.parseError : this.parseError = Object.getPrototypeOf(this).parseError; + function C() { + var M; + return M = d.pop() || b.lex() || U, typeof M != "number" && (M instanceof Array && (d = M, M = d.pop()), M = r.symbols_[M] || M), M; + } + for (var k, L, E, Z, z = {}, B, $, Y, O; ; ) { + if (L = h[h.length - 1], this.defaultActions[L] ? E = this.defaultActions[L] : ((k === null || typeof k > "u") && (k = C()), E = w[L] && w[L][k]), typeof E > "u" || !E.length || !E[0]) { + var J = ""; + O = []; + for (B in w[L]) + this.terminals_[B] && B > V && O.push("'" + this.terminals_[B] + "'"); + b.showPosition ? J = "Parse error on line " + (N + 1) + `: +` + b.showPosition() + ` +Expecting ` + O.join(", ") + ", got '" + (this.terminals_[k] || k) + "'" : J = "Parse error on line " + (N + 1) + ": Unexpected " + (k == U ? "end of input" : "'" + (this.terminals_[k] || k) + "'"), this.parseError(J, { + text: b.match, + token: this.terminals_[k] || k, + line: b.yylineno, + loc: I, + expected: O + }); + } + if (E[0] instanceof Array && E.length > 1) + throw new Error("Parse Error: multiple actions possible at state: " + L + ", token: " + k); + switch (E[0]) { + case 1: + h.push(k), p.push(b.yytext), l.push(b.yylloc), h.push(E[1]), k = null, A = b.yyleng, x = b.yytext, N = b.yylineno, I = b.yylloc; + break; + case 2: + if ($ = this.productions_[E[1]][1], z.$ = p[p.length - $], z._$ = { + first_line: l[l.length - ($ || 1)].first_line, + last_line: l[l.length - 1].last_line, + first_column: l[l.length - ($ || 1)].first_column, + last_column: l[l.length - 1].last_column + }, P && (z._$.range = [ + l[l.length - ($ || 1)].range[0], + l[l.length - 1].range[1] + ]), Z = this.performAction.apply(z, [ + x, + A, + N, + S.yy, + E[1], + p, + l + ].concat(W)), typeof Z < "u") + return Z; + $ && (h = h.slice(0, -1 * $ * 2), p = p.slice(0, -1 * $), l = l.slice(0, -1 * $)), h.push(this.productions_[E[1]][0]), p.push(z.$), l.push(z._$), Y = w[h[h.length - 2]][h[h.length - 1]], h.push(Y); + break; + case 3: + return !0; + } + } + return !0; + } + }, m = function() { + var f = { + EOF: 1, + parseError: function(r, h) { + if (this.yy.parser) + this.yy.parser.parseError(r, h); + else + throw new Error(r); + }, + // resets the lexer, sets new input + setInput: function(i, r) { + return this.yy = r || this.yy || {}, this._input = i, 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 i = this._input[0]; + this.yytext += i, this.yyleng++, this.offset++, this.match += i, this.matched += i; + var r = i.match(/(?:\r\n?|\n).*/g); + return r ? (this.yylineno++, this.yylloc.last_line++) : this.yylloc.last_column++, this.options.ranges && this.yylloc.range[1]++, this._input = this._input.slice(1), i; + }, + // unshifts one char (or a string) into the input + unput: function(i) { + var r = i.length, h = i.split(/(?:\r\n?|\n)/g); + this._input = i + this._input, this.yytext = this.yytext.substr(0, this.yytext.length - r), this.offset -= r; + var d = 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), h.length - 1 && (this.yylineno -= h.length - 1); + var p = 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: h ? (h.length === d.length ? this.yylloc.first_column : 0) + d[d.length - h.length].length - h[0].length : this.yylloc.first_column - r + }, this.options.ranges && (this.yylloc.range = [p[0], p[0] + this.yyleng - r]), 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(i) { + this.unput(this.match.slice(i)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var i = this.matched.substr(0, this.matched.length - this.match.length); + return (i.length > 20 ? "..." : "") + i.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var i = this.match; + return i.length < 20 && (i += this._input.substr(0, 20 - i.length)), (i.substr(0, 20) + (i.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var i = this.pastInput(), r = new Array(i.length + 1).join("-"); + return i + this.upcomingInput() + ` +` + r + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(i, r) { + var h, d, p; + if (this.options.backtrack_lexer && (p = { + 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 && (p.yylloc.range = this.yylloc.range.slice(0))), d = i[0].match(/(?:\r\n?|\n).*/g), d && (this.yylineno += d.length), this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: d ? d[d.length - 1].length - d[d.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + i[0].length + }, this.yytext += i[0], this.match += i[0], this.matches = i, 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(i[0].length), this.matched += i[0], h = this.performAction.call(this, this.yy, this, r, this.conditionStack[this.conditionStack.length - 1]), this.done && this._input && (this.done = !1), h) + return h; + if (this._backtrack) { + for (var l in p) + this[l] = p[l]; + return !1; + } + return !1; + }, + // return next match in input + next: function() { + if (this.done) + return this.EOF; + this._input || (this.done = !0); + var i, r, h, d; + this._more || (this.yytext = "", this.match = ""); + for (var p = this._currentRules(), l = 0; l < p.length; l++) + if (h = this._input.match(this.rules[p[l]]), h && (!r || h[0].length > r[0].length)) { + if (r = h, d = l, this.options.backtrack_lexer) { + if (i = this.test_match(h, p[l]), i !== !1) + return i; + if (this._backtrack) { + r = !1; + continue; + } else + return !1; + } else if (!this.options.flex) + break; + } + return r ? (i = this.test_match(r, p[d]), i !== !1 ? i : !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 r = this.next(); + return r || this.lex(); + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function(r) { + this.conditionStack.push(r); + }, + // pop the previously active lexer condition state off the condition stack + popState: function() { + var r = this.conditionStack.length - 1; + return r > 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(r) { + return r = this.conditionStack.length - 1 - Math.abs(r || 0), r >= 0 ? this.conditionStack[r] : "INITIAL"; + }, + // alias for begin(condition) + pushState: function(r) { + this.begin(r); + }, + // return the number of states currently on the stack + stateStackSize: function() { + return this.conditionStack.length; + }, + options: { "case-insensitive": !0 }, + performAction: function(r, h, d, p) { + switch (d) { + case 0: + break; + case 1: + break; + case 2: + return 10; + case 3: + break; + case 4: + break; + case 5: + return 4; + case 6: + return 11; + case 7: + return this.begin("acc_title"), 12; + case 8: + return this.popState(), "acc_title_value"; + case 9: + return this.begin("acc_descr"), 14; + case 10: + return this.popState(), "acc_descr_value"; + case 11: + this.begin("acc_descr_multiline"); + break; + case 12: + this.popState(); + break; + case 13: + return "acc_descr_multiline_value"; + case 14: + return 17; + case 15: + return 21; + case 16: + return 20; + case 17: + return 6; + case 18: + return "INVALID"; + } + }, + rules: [/^(?:%(?!\{)[^\n]*)/i, /^(?:[^\}]%%[^\n]*)/i, /^(?:[\n]+)/i, /^(?:\s+)/i, /^(?:#[^\n]*)/i, /^(?:timeline\b)/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, /^(?:section\s[^#:\n;]+)/i, /^(?::\s[^#:\n;]+)/i, /^(?:[^#:\n;]+)/i, /^(?:$)/i, /^(?:.)/i], + conditions: { acc_descr_multiline: { rules: [12, 13], inclusive: !1 }, acc_descr: { rules: [10], inclusive: !1 }, acc_title: { rules: [8], inclusive: !1 }, INITIAL: { rules: [0, 1, 2, 3, 4, 5, 6, 7, 9, 11, 14, 15, 16, 17, 18], inclusive: !0 } } + }; + return f; + }(); + u.lexer = m; + function v() { + this.yy = {}; + } + return v.prototype = u, u.Parser = v, new v(); +}(); +K.parser = K; +const vt = K; +let R = "", st = 0; +const Q = [], G = [], F = [], it = () => ft, rt = function() { + Q.length = 0, G.length = 0, R = "", F.length = 0, gt(); +}, at = function(n) { + R = n, Q.push(n); +}, lt = function() { + return Q; +}, ot = function() { + let n = tt(); + const t = 100; + let e = 0; + for (; !n && e < t; ) + n = tt(), e++; + return G.push(...F), G; +}, ct = function(n, t, e) { + const a = { + id: st++, + section: R, + type: R, + task: n, + score: t || 0, + //if event is defined, then add it the events array + events: e ? [e] : [] + }; + F.push(a); +}, ht = function(n) { + F.find((e) => e.id === st - 1).events.push(n); +}, dt = function(n) { + const t = { + section: R, + type: R, + description: n, + task: n, + classes: [] + }; + G.push(t); +}, tt = function() { + const n = function(e) { + return F[e].processed; + }; + let t = !0; + for (const [e, a] of F.entries()) + n(e), t = t && a.processed; + return t; +}, wt = { + clear: rt, + getCommonDb: it, + addSection: at, + getSections: lt, + getTasks: ot, + addTask: ct, + addTaskOrg: dt, + addEvent: ht +}, St = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + addEvent: ht, + addSection: at, + addTask: ct, + addTaskOrg: dt, + clear: rt, + default: wt, + getCommonDb: it, + getSections: lt, + getTasks: ot +}, Symbol.toStringTag, { value: "Module" })), Et = 12, q = function(n, t) { + const e = n.append("rect"); + return e.attr("x", t.x), e.attr("y", t.y), e.attr("fill", t.fill), e.attr("stroke", t.stroke), e.attr("width", t.width), e.attr("height", t.height), e.attr("rx", t.rx), e.attr("ry", t.ry), t.class !== void 0 && e.attr("class", t.class), e; +}, Tt = function(n, t) { + const a = n.append("circle").attr("cx", t.cx).attr("cy", t.cy).attr("class", "face").attr("r", 15).attr("stroke-width", 2).attr("overflow", "visible"), s = n.append("g"); + s.append("circle").attr("cx", t.cx - 15 / 3).attr("cy", t.cy - 15 / 3).attr("r", 1.5).attr("stroke-width", 2).attr("fill", "#666").attr("stroke", "#666"), s.append("circle").attr("cx", t.cx + 15 / 3).attr("cy", t.cy - 15 / 3).attr("r", 1.5).attr("stroke-width", 2).attr("fill", "#666").attr("stroke", "#666"); + function c(g) { + const u = D().startAngle(Math.PI / 2).endAngle(3 * (Math.PI / 2)).innerRadius(7.5).outerRadius(6.8181818181818175); + g.append("path").attr("class", "mouth").attr("d", u).attr("transform", "translate(" + t.cx + "," + (t.cy + 2) + ")"); + } + function o(g) { + const u = D().startAngle(3 * Math.PI / 2).endAngle(5 * (Math.PI / 2)).innerRadius(7.5).outerRadius(6.8181818181818175); + g.append("path").attr("class", "mouth").attr("d", u).attr("transform", "translate(" + t.cx + "," + (t.cy + 7) + ")"); + } + function y(g) { + g.append("line").attr("class", "mouth").attr("stroke", 2).attr("x1", t.cx - 5).attr("y1", t.cy + 7).attr("x2", t.cx + 5).attr("y2", t.cy + 7).attr("class", "mouth").attr("stroke-width", "1px").attr("stroke", "#666"); + } + return t.score > 3 ? c(s) : t.score < 3 ? o(s) : y(s), a; +}, It = function(n, t) { + const e = n.append("circle"); + return e.attr("cx", t.cx), e.attr("cy", t.cy), e.attr("class", "actor-" + t.pos), e.attr("fill", t.fill), e.attr("stroke", t.stroke), e.attr("r", t.r), e.class !== void 0 && e.attr("class", e.class), t.title !== void 0 && e.append("title").text(t.title), e; +}, ut = function(n, t) { + const e = t.text.replace(//gi, " "), a = n.append("text"); + a.attr("x", t.x), a.attr("y", t.y), a.attr("class", "legend"), a.style("text-anchor", t.anchor), t.class !== void 0 && a.attr("class", t.class); + const s = a.append("tspan"); + return s.attr("x", t.x + t.textMargin * 2), s.text(e), a; +}, Nt = function(n, t) { + function e(s, c, o, y, g) { + return s + "," + c + " " + (s + o) + "," + c + " " + (s + o) + "," + (c + y - g) + " " + (s + o - g * 1.2) + "," + (c + y) + " " + s + "," + (c + y); + } + const a = n.append("polygon"); + a.attr("points", e(t.x, t.y, 50, 20, 7)), a.attr("class", "labelBox"), t.y = t.y + t.labelMargin, t.x = t.x + 0.5 * t.labelMargin, ut(n, t); +}, $t = function(n, t, e) { + const a = n.append("g"), s = X(); + s.x = t.x, s.y = t.y, s.fill = t.fill, s.width = e.width, s.height = e.height, s.class = "journey-section section-type-" + t.num, s.rx = 3, s.ry = 3, q(a, s), pt(e)( + t.text, + a, + s.x, + s.y, + s.width, + s.height, + { class: "journey-section section-type-" + t.num }, + e, + t.colour + ); +}; +let et = -1; +const Mt = function(n, t, e) { + const a = t.x + e.width / 2, s = n.append("g"); + et++; + const c = 300 + 5 * 30; + s.append("line").attr("id", "task" + et).attr("x1", a).attr("y1", t.y).attr("x2", a).attr("y2", c).attr("class", "task-line").attr("stroke-width", "1px").attr("stroke-dasharray", "4 2").attr("stroke", "#666"), Tt(s, { + cx: a, + cy: 300 + (5 - t.score) * 30, + score: t.score + }); + const o = X(); + o.x = t.x, o.y = t.y, o.fill = t.fill, o.width = e.width, o.height = e.height, o.class = "task task-type-" + t.num, o.rx = 3, o.ry = 3, q(s, o), t.x + 14, pt(e)( + t.task, + s, + o.x, + o.y, + o.width, + o.height, + { class: "task" }, + e, + t.colour + ); +}, Lt = function(n, t) { + q(n, { + x: t.startx, + y: t.starty, + width: t.stopx - t.startx, + height: t.stopy - t.starty, + fill: t.fill, + class: "rect" + }).lower(); +}, At = function() { + return { + x: 0, + y: 0, + fill: void 0, + "text-anchor": "start", + width: 100, + height: 100, + textMargin: 0, + rx: 0, + ry: 0 + }; +}, X = function() { + return { + x: 0, + y: 0, + width: 100, + anchor: "start", + height: 100, + rx: 0, + ry: 0 + }; +}, pt = function() { + function n(s, c, o, y, g, u, m, v) { + const f = c.append("text").attr("x", o + g / 2).attr("y", y + u / 2 + 5).style("font-color", v).style("text-anchor", "middle").text(s); + a(f, m); + } + function t(s, c, o, y, g, u, m, v, f) { + const { taskFontSize: i, taskFontFamily: r } = v, h = s.split(//gi); + for (let d = 0; d < h.length; d++) { + const p = d * i - i * (h.length - 1) / 2, l = c.append("text").attr("x", o + g / 2).attr("y", y).attr("fill", f).style("text-anchor", "middle").style("font-size", i).style("font-family", r); + l.append("tspan").attr("x", o + g / 2).attr("dy", p).text(h[d]), l.attr("y", y + u / 2).attr("dominant-baseline", "central").attr("alignment-baseline", "central"), a(l, m); + } + } + function e(s, c, o, y, g, u, m, v) { + const f = c.append("switch"), r = f.append("foreignObject").attr("x", o).attr("y", y).attr("width", g).attr("height", u).attr("position", "fixed").append("xhtml:div").style("display", "table").style("height", "100%").style("width", "100%"); + r.append("div").attr("class", "label").style("display", "table-cell").style("text-align", "center").style("vertical-align", "middle").text(s), t(s, f, o, y, g, u, m, v), a(r, m); + } + function a(s, c) { + for (const o in c) + o in c && s.attr(o, c[o]); + } + return function(s) { + return s.textPlacement === "fo" ? e : s.textPlacement === "old" ? n : t; + }; +}(), Pt = function(n) { + n.append("defs").append("marker").attr("id", "arrowhead").attr("refX", 5).attr("refY", 2).attr("markerWidth", 6).attr("markerHeight", 4).attr("orient", "auto").append("path").attr("d", "M 0,0 V 4 L6,2 Z"); +}; +function yt(n, t) { + n.each(function() { + var e = j(this), a = e.text().split(/(\s+|
    )/).reverse(), s, c = [], o = 1.1, y = e.attr("y"), g = parseFloat(e.attr("dy")), u = e.text(null).append("tspan").attr("x", 0).attr("y", y).attr("dy", g + "em"); + for (let m = 0; m < a.length; m++) + s = a[a.length - 1 - m], c.push(s), u.text(c.join(" ").trim()), (u.node().getComputedTextLength() > t || s === "
    ") && (c.pop(), u.text(c.join(" ").trim()), s === "
    " ? c = [""] : c = [s], u = e.append("tspan").attr("x", 0).attr("y", y).attr("dy", o + "em").text(s)); + }); +} +const Ht = function(n, t, e, a) { + const s = e % Et - 1, c = n.append("g"); + t.section = s, c.attr( + "class", + (t.class ? t.class + " " : "") + "timeline-node " + ("section-" + s) + ); + const o = c.append("g"), y = c.append("g"), u = y.append("text").text(t.descr).attr("dy", "1em").attr("alignment-baseline", "middle").attr("dominant-baseline", "middle").attr("text-anchor", "middle").call(yt, t.width).node().getBBox(), m = a.fontSize && a.fontSize.replace ? a.fontSize.replace("px", "") : a.fontSize; + return t.height = u.height + m * 1.1 * 0.5 + t.padding, t.height = Math.max(t.height, t.maxHeight), t.width = t.width + 2 * t.padding, y.attr("transform", "translate(" + t.width / 2 + ", " + t.padding / 2 + ")"), zt(o, t, s), t; +}, Ct = function(n, t, e) { + const a = n.append("g"), c = a.append("text").text(t.descr).attr("dy", "1em").attr("alignment-baseline", "middle").attr("dominant-baseline", "middle").attr("text-anchor", "middle").call(yt, t.width).node().getBBox(), o = e.fontSize && e.fontSize.replace ? e.fontSize.replace("px", "") : e.fontSize; + return a.remove(), c.height + o * 1.1 * 0.5 + t.padding; +}, zt = function(n, t, e) { + n.append("path").attr("id", "node-" + t.id).attr("class", "node-bkg node-" + t.type).attr( + "d", + `M0 ${t.height - 5} v${-t.height + 2 * 5} q0,-5 5,-5 h${t.width - 2 * 5} q5,0 5,5 v${t.height - 5} H0 Z` + ), n.append("line").attr("class", "node-line-" + e).attr("x1", 0).attr("y1", t.height).attr("x2", t.width).attr("y2", t.height); +}, H = { + drawRect: q, + drawCircle: It, + drawSection: $t, + drawText: ut, + drawLabel: Nt, + drawTask: Mt, + drawBackgroundRect: Lt, + getTextObj: At, + getNoteRect: X, + initGraphics: Pt, + drawNode: Ht, + getVirtualNodeHeight: Ct +}, Rt = function(n, t, e, a) { + var W, b; + const s = mt(), c = s.leftMargin ?? 50; + T.debug("timeline", a.db); + const o = s.securityLevel; + let y; + o === "sandbox" && (y = j("#i" + t)); + const u = (o === "sandbox" ? j(y.nodes()[0].contentDocument.body) : j("body")).select("#" + t); + u.append("g"); + const m = a.db.getTasks(), v = a.db.getCommonDb().getDiagramTitle(); + T.debug("task", m), H.initGraphics(u); + const f = a.db.getSections(); + T.debug("sections", f); + let i = 0, r = 0, h = 0, d = 0, p = 50 + c, l = 50; + d = 50; + let w = 0, x = !0; + f.forEach(function(S) { + const _ = { + number: w, + descr: S, + section: w, + width: 150, + padding: 20, + maxHeight: i + }, I = H.getVirtualNodeHeight(u, _, s); + T.debug("sectionHeight before draw", I), i = Math.max(i, I + 20); + }); + let N = 0, A = 0; + T.debug("tasks.length", m.length); + for (const [S, _] of m.entries()) { + const I = { + number: S, + descr: _, + section: _.section, + width: 150, + padding: 20, + maxHeight: r + }, P = H.getVirtualNodeHeight(u, I, s); + T.debug("taskHeight before draw", P), r = Math.max(r, P + 20), N = Math.max(N, _.events.length); + let C = 0; + for (let k = 0; k < _.events.length; k++) { + const E = { + descr: _.events[k], + section: _.section, + number: _.section, + width: 150, + padding: 20, + maxHeight: 50 + }; + C += H.getVirtualNodeHeight(u, E, s); + } + A = Math.max(A, C); + } + T.debug("maxSectionHeight before draw", i), T.debug("maxTaskHeight before draw", r), f && f.length > 0 ? f.forEach((S) => { + const _ = m.filter((k) => k.section === S), I = { + number: w, + descr: S, + section: w, + width: 200 * Math.max(_.length, 1) - 50, + padding: 20, + maxHeight: i + }; + T.debug("sectionNode", I); + const P = u.append("g"), C = H.drawNode(P, I, w, s); + T.debug("sectionNode output", C), P.attr("transform", `translate(${p}, ${d})`), l += i + 50, _.length > 0 && nt( + u, + _, + w, + p, + l, + r, + s, + N, + A, + i, + !1 + ), p += 200 * Math.max(_.length, 1), l = d, w++; + }) : (x = !1, nt( + u, + m, + w, + p, + l, + r, + s, + N, + A, + i, + !0 + )); + const V = u.node().getBBox(); + T.debug("bounds", V), v && u.append("text").text(v).attr("x", V.width / 2 - c).attr("font-size", "4ex").attr("font-weight", "bold").attr("y", 20), h = x ? i + r + 150 : r + 100, u.append("g").attr("class", "lineWrapper").append("line").attr("x1", c).attr("y1", h).attr("x2", V.width + 3 * c).attr("y2", h).attr("stroke-width", 4).attr("stroke", "black").attr("marker-end", "url(#arrowhead)"), xt( + void 0, + u, + ((W = s.timeline) == null ? void 0 : W.padding) ?? 50, + ((b = s.timeline) == null ? void 0 : b.useMaxWidth) ?? !1 + ); +}, nt = function(n, t, e, a, s, c, o, y, g, u, m) { + var v; + for (const f of t) { + const i = { + descr: f.task, + section: e, + number: e, + width: 150, + padding: 20, + maxHeight: c + }; + T.debug("taskNode", i); + const r = n.append("g").attr("class", "taskWrapper"), d = H.drawNode(r, i, e, o).height; + if (T.debug("taskHeight after draw", d), r.attr("transform", `translate(${a}, ${s})`), c = Math.max(c, d), f.events) { + const p = n.append("g").attr("class", "lineWrapper"); + let l = c; + s += 100, l = l + Ft(n, f.events, e, a, s, o), s -= 100, p.append("line").attr("x1", a + 190 / 2).attr("y1", s + c).attr("x2", a + 190 / 2).attr( + "y2", + s + c + (m ? c : u) + g + 120 + ).attr("stroke-width", 2).attr("stroke", "black").attr("marker-end", "url(#arrowhead)").attr("stroke-dasharray", "5,5"); + } + a = a + 200, m && !((v = o.timeline) != null && v.disableMulticolor) && e++; + } + s = s - 10; +}, Ft = function(n, t, e, a, s, c) { + let o = 0; + const y = s; + s = s + 100; + for (const g of t) { + const u = { + descr: g, + section: e, + number: e, + width: 150, + padding: 20, + maxHeight: 50 + }; + T.debug("eventNode", u); + const m = n.append("g").attr("class", "eventWrapper"), f = H.drawNode(m, u, e, c).height; + o = o + f, m.attr("transform", `translate(${a}, ${s})`), s = s + 10 + f; + } + return s = y, o; +}, Vt = { + setConf: () => { + }, + draw: Rt +}, Wt = (n) => { + let t = ""; + for (let e = 0; e < n.THEME_COLOR_LIMIT; e++) + n["lineColor" + e] = n["lineColor" + e] || n["cScaleInv" + e], bt(n["lineColor" + e]) ? n["lineColor" + e] = kt(n["lineColor" + e], 20) : n["lineColor" + e] = _t(n["lineColor" + e], 20); + for (let e = 0; e < n.THEME_COLOR_LIMIT; e++) { + const a = "" + (17 - 3 * e); + t += ` + .section-${e - 1} rect, .section-${e - 1} path, .section-${e - 1} circle, .section-${e - 1} path { + fill: ${n["cScale" + e]}; + } + .section-${e - 1} text { + fill: ${n["cScaleLabel" + e]}; + } + .node-icon-${e - 1} { + font-size: 40px; + color: ${n["cScaleLabel" + e]}; + } + .section-edge-${e - 1}{ + stroke: ${n["cScale" + e]}; + } + .edge-depth-${e - 1}{ + stroke-width: ${a}; + } + .section-${e - 1} line { + stroke: ${n["cScaleInv" + e]} ; + stroke-width: 3; + } + + .lineWrapper line{ + stroke: ${n["cScaleLabel" + e]} ; + } + + .disabled, .disabled circle, .disabled text { + fill: lightgray; + } + .disabled text { + fill: #efefef; + } + `; + } + return t; +}, Bt = (n) => ` + .edge { + stroke-width: 3; + } + ${Wt(n)} + .section-root rect, .section-root path, .section-root circle { + fill: ${n.git0}; + } + .section-root text { + fill: ${n.gitBranchLabel0}; + } + .icon-container { + height:100%; + display: flex; + justify-content: center; + align-items: center; + } + .edge { + fill: none; + } + .eventWrapper { + filter: brightness(120%); + } +`, Ot = Bt, Ut = { + db: St, + renderer: Vt, + parser: vt, + styles: Ot +}; +export { + Ut as diagram +}; diff --git a/0.6.0/js/mermaid/timeline-definition-bf702344.js b/0.6.0/js/mermaid/timeline-definition-bf702344.js new file mode 100644 index 0000000..d36a67b --- /dev/null +++ b/0.6.0/js/mermaid/timeline-definition-bf702344.js @@ -0,0 +1,1219 @@ +import { L as commonDb, v as clear$1, c as getConfig, l as log, o as setupGraphViewbox } from "./mermaid-6dc72991.js"; +import { select, arc } from "d3"; +import { isDark, lighten, darken } from "khroma"; +import "ts-dedent"; +import "dayjs"; +import "@braintree/sanitize-url"; +import "dompurify"; +import "lodash-es/memoize.js"; +import "lodash-es/merge.js"; +import "stylis"; +import "lodash-es/isEmpty.js"; +var parser = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [6, 8, 10, 11, 12, 14, 16, 17, 20, 21], $V1 = [1, 9], $V2 = [1, 10], $V3 = [1, 11], $V4 = [1, 12], $V5 = [1, 13], $V6 = [1, 16], $V7 = [1, 17]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "timeline": 4, "document": 5, "EOF": 6, "line": 7, "SPACE": 8, "statement": 9, "NEWLINE": 10, "title": 11, "acc_title": 12, "acc_title_value": 13, "acc_descr": 14, "acc_descr_value": 15, "acc_descr_multiline_value": 16, "section": 17, "period_statement": 18, "event_statement": 19, "period": 20, "event": 21, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 4: "timeline", 6: "EOF", 8: "SPACE", 10: "NEWLINE", 11: "title", 12: "acc_title", 13: "acc_title_value", 14: "acc_descr", 15: "acc_descr_value", 16: "acc_descr_multiline_value", 17: "section", 20: "period", 21: "event" }, + productions_: [0, [3, 3], [5, 0], [5, 2], [7, 2], [7, 1], [7, 1], [7, 1], [9, 1], [9, 2], [9, 2], [9, 1], [9, 1], [9, 1], [9, 1], [18, 1], [19, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 1: + return $$[$0 - 1]; + case 2: + this.$ = []; + break; + case 3: + $$[$0 - 1].push($$[$0]); + this.$ = $$[$0 - 1]; + break; + case 4: + case 5: + this.$ = $$[$0]; + break; + case 6: + case 7: + this.$ = []; + break; + case 8: + yy.getCommonDb().setDiagramTitle($$[$0].substr(6)); + this.$ = $$[$0].substr(6); + break; + case 9: + this.$ = $$[$0].trim(); + yy.getCommonDb().setAccTitle(this.$); + break; + case 10: + case 11: + this.$ = $$[$0].trim(); + yy.getCommonDb().setAccDescription(this.$); + break; + case 12: + yy.addSection($$[$0].substr(8)); + this.$ = $$[$0].substr(8); + break; + case 15: + yy.addTask($$[$0], 0, ""); + this.$ = $$[$0]; + break; + case 16: + yy.addEvent($$[$0].substr(2)); + this.$ = $$[$0]; + break; + } + }, + table: [{ 3: 1, 4: [1, 2] }, { 1: [3] }, o($V0, [2, 2], { 5: 3 }), { 6: [1, 4], 7: 5, 8: [1, 6], 9: 7, 10: [1, 8], 11: $V1, 12: $V2, 14: $V3, 16: $V4, 17: $V5, 18: 14, 19: 15, 20: $V6, 21: $V7 }, o($V0, [2, 7], { 1: [2, 1] }), o($V0, [2, 3]), { 9: 18, 11: $V1, 12: $V2, 14: $V3, 16: $V4, 17: $V5, 18: 14, 19: 15, 20: $V6, 21: $V7 }, o($V0, [2, 5]), o($V0, [2, 6]), o($V0, [2, 8]), { 13: [1, 19] }, { 15: [1, 20] }, o($V0, [2, 11]), o($V0, [2, 12]), o($V0, [2, 13]), o($V0, [2, 14]), o($V0, [2, 15]), o($V0, [2, 16]), o($V0, [2, 4]), o($V0, [2, 9]), o($V0, [2, 10])], + defaultActions: {}, + parseError: function parseError(str, hash) { + if (hash.recoverable) { + this.trace(str); + } else { + var error = new Error(str); + error.hash = hash; + throw error; + } + }, + parse: function parse(input) { + var self = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex() { + var token; + token = tstack.pop() || lexer2.lex() || EOF; + if (typeof token !== "number") { + if (token instanceof Array) { + tstack = token; + token = tstack.pop(); + } + token = self.symbols_[token] || token; + } + return token; + } + var symbol, state, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state = stack[stack.length - 1]; + if (this.defaultActions[state]) { + action = this.defaultActions[state]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex(); + } + action = table[state] && table[state][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str, hash); + } else { + throw new Error(str); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch = this._input[0]; + this.yytext += ch; + this.yyleng++; + this.offset++; + this.match += ch; + this.matched += ch; + var lines = ch.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch; + }, + // unshifts one char (or a string) into the input + unput: function(ch) { + var len = ch.length; + var lines = ch.split(/(?:\r\n?|\n)/g); + this._input = ch + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next = this.match; + if (next.length < 20) { + next += this._input.substr(0, 20 - next.length); + } + return (next.substr(0, 20) + (next.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token) { + return token; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token, match, tempMatch, index; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i = 0; i < rules.length; i++) { + tempMatch = this._input.match(this.rules[rules[i]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index = i; + if (this.options.backtrack_lexer) { + token = this.test_match(tempMatch, rules[i]); + if (token !== false) { + return token; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token = this.test_match(match, rules[index]); + if (token !== false) { + return token; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + break; + case 1: + break; + case 2: + return 10; + case 3: + break; + case 4: + break; + case 5: + return 4; + case 6: + return 11; + case 7: + this.begin("acc_title"); + return 12; + case 8: + this.popState(); + return "acc_title_value"; + case 9: + this.begin("acc_descr"); + return 14; + case 10: + this.popState(); + return "acc_descr_value"; + case 11: + this.begin("acc_descr_multiline"); + break; + case 12: + this.popState(); + break; + case 13: + return "acc_descr_multiline_value"; + case 14: + return 17; + case 15: + return 21; + case 16: + return 20; + case 17: + return 6; + case 18: + return "INVALID"; + } + }, + rules: [/^(?:%(?!\{)[^\n]*)/i, /^(?:[^\}]%%[^\n]*)/i, /^(?:[\n]+)/i, /^(?:\s+)/i, /^(?:#[^\n]*)/i, /^(?:timeline\b)/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, /^(?:section\s[^#:\n;]+)/i, /^(?::\s[^#:\n;]+)/i, /^(?:[^#:\n;]+)/i, /^(?:$)/i, /^(?:.)/i], + conditions: { "acc_descr_multiline": { "rules": [12, 13], "inclusive": false }, "acc_descr": { "rules": [10], "inclusive": false }, "acc_title": { "rules": [8], "inclusive": false }, "INITIAL": { "rules": [0, 1, 2, 3, 4, 5, 6, 7, 9, 11, 14, 15, 16, 17, 18], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser() { + this.yy = {}; + } + Parser.prototype = parser2; + parser2.Parser = Parser; + return new Parser(); +}(); +parser.parser = parser; +const parser$1 = parser; +let currentSection = ""; +let currentTaskId = 0; +const sections = []; +const tasks = []; +const rawTasks = []; +const getCommonDb = () => commonDb; +const clear = function() { + sections.length = 0; + tasks.length = 0; + currentSection = ""; + rawTasks.length = 0; + clear$1(); +}; +const addSection = function(txt) { + currentSection = txt; + sections.push(txt); +}; +const getSections = function() { + return sections; +}; +const getTasks = function() { + let allItemsProcessed = compileTasks(); + const maxDepth = 100; + let iterationCount = 0; + while (!allItemsProcessed && iterationCount < maxDepth) { + allItemsProcessed = compileTasks(); + iterationCount++; + } + tasks.push(...rawTasks); + return tasks; +}; +const addTask = function(period, length, event) { + const rawTask = { + id: currentTaskId++, + section: currentSection, + type: currentSection, + task: period, + score: length ? length : 0, + //if event is defined, then add it the events array + events: event ? [event] : [] + }; + rawTasks.push(rawTask); +}; +const addEvent = function(event) { + const currentTask = rawTasks.find((task) => task.id === currentTaskId - 1); + currentTask.events.push(event); +}; +const addTaskOrg = function(descr) { + const newTask = { + section: currentSection, + type: currentSection, + description: descr, + task: descr, + classes: [] + }; + tasks.push(newTask); +}; +const compileTasks = function() { + const compileTask = function(pos) { + return rawTasks[pos].processed; + }; + let allProcessed = true; + for (const [i, rawTask] of rawTasks.entries()) { + compileTask(i); + allProcessed = allProcessed && rawTask.processed; + } + return allProcessed; +}; +const timelineDb = { + clear, + getCommonDb, + addSection, + getSections, + getTasks, + addTask, + addTaskOrg, + addEvent +}; +const db = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ + __proto__: null, + addEvent, + addSection, + addTask, + addTaskOrg, + clear, + default: timelineDb, + getCommonDb, + getSections, + getTasks +}, Symbol.toStringTag, { value: "Module" })); +const MAX_SECTIONS = 12; +const drawRect = function(elem, rectData) { + const rectElem = elem.append("rect"); + rectElem.attr("x", rectData.x); + rectElem.attr("y", rectData.y); + rectElem.attr("fill", rectData.fill); + rectElem.attr("stroke", rectData.stroke); + rectElem.attr("width", rectData.width); + rectElem.attr("height", rectData.height); + rectElem.attr("rx", rectData.rx); + rectElem.attr("ry", rectData.ry); + if (rectData.class !== void 0) { + rectElem.attr("class", rectData.class); + } + return rectElem; +}; +const drawFace = function(element, faceData) { + const radius = 15; + const circleElement = element.append("circle").attr("cx", faceData.cx).attr("cy", faceData.cy).attr("class", "face").attr("r", radius).attr("stroke-width", 2).attr("overflow", "visible"); + const face = element.append("g"); + face.append("circle").attr("cx", faceData.cx - radius / 3).attr("cy", faceData.cy - radius / 3).attr("r", 1.5).attr("stroke-width", 2).attr("fill", "#666").attr("stroke", "#666"); + face.append("circle").attr("cx", faceData.cx + radius / 3).attr("cy", faceData.cy - radius / 3).attr("r", 1.5).attr("stroke-width", 2).attr("fill", "#666").attr("stroke", "#666"); + function smile(face2) { + const arc$1 = arc().startAngle(Math.PI / 2).endAngle(3 * (Math.PI / 2)).innerRadius(radius / 2).outerRadius(radius / 2.2); + face2.append("path").attr("class", "mouth").attr("d", arc$1).attr("transform", "translate(" + faceData.cx + "," + (faceData.cy + 2) + ")"); + } + function sad(face2) { + const arc$1 = arc().startAngle(3 * Math.PI / 2).endAngle(5 * (Math.PI / 2)).innerRadius(radius / 2).outerRadius(radius / 2.2); + face2.append("path").attr("class", "mouth").attr("d", arc$1).attr("transform", "translate(" + faceData.cx + "," + (faceData.cy + 7) + ")"); + } + function ambivalent(face2) { + face2.append("line").attr("class", "mouth").attr("stroke", 2).attr("x1", faceData.cx - 5).attr("y1", faceData.cy + 7).attr("x2", faceData.cx + 5).attr("y2", faceData.cy + 7).attr("class", "mouth").attr("stroke-width", "1px").attr("stroke", "#666"); + } + if (faceData.score > 3) { + smile(face); + } else if (faceData.score < 3) { + sad(face); + } else { + ambivalent(face); + } + return circleElement; +}; +const drawCircle = function(element, circleData) { + const circleElement = element.append("circle"); + circleElement.attr("cx", circleData.cx); + circleElement.attr("cy", circleData.cy); + circleElement.attr("class", "actor-" + circleData.pos); + circleElement.attr("fill", circleData.fill); + circleElement.attr("stroke", circleData.stroke); + circleElement.attr("r", circleData.r); + if (circleElement.class !== void 0) { + circleElement.attr("class", circleElement.class); + } + if (circleData.title !== void 0) { + circleElement.append("title").text(circleData.title); + } + return circleElement; +}; +const drawText = function(elem, textData) { + const nText = textData.text.replace(//gi, " "); + const textElem = elem.append("text"); + textElem.attr("x", textData.x); + textElem.attr("y", textData.y); + textElem.attr("class", "legend"); + textElem.style("text-anchor", textData.anchor); + if (textData.class !== void 0) { + textElem.attr("class", textData.class); + } + const span = textElem.append("tspan"); + span.attr("x", textData.x + textData.textMargin * 2); + span.text(nText); + return textElem; +}; +const drawLabel = function(elem, txtObject) { + function genPoints(x, y, width, height, cut) { + return x + "," + y + " " + (x + width) + "," + y + " " + (x + width) + "," + (y + height - cut) + " " + (x + width - cut * 1.2) + "," + (y + height) + " " + x + "," + (y + height); + } + const polygon = elem.append("polygon"); + polygon.attr("points", genPoints(txtObject.x, txtObject.y, 50, 20, 7)); + polygon.attr("class", "labelBox"); + txtObject.y = txtObject.y + txtObject.labelMargin; + txtObject.x = txtObject.x + 0.5 * txtObject.labelMargin; + drawText(elem, txtObject); +}; +const drawSection = function(elem, section, conf) { + const g = elem.append("g"); + const rect = getNoteRect(); + rect.x = section.x; + rect.y = section.y; + rect.fill = section.fill; + rect.width = conf.width; + rect.height = conf.height; + rect.class = "journey-section section-type-" + section.num; + rect.rx = 3; + rect.ry = 3; + drawRect(g, rect); + _drawTextCandidateFunc(conf)( + section.text, + g, + rect.x, + rect.y, + rect.width, + rect.height, + { class: "journey-section section-type-" + section.num }, + conf, + section.colour + ); +}; +let taskCount = -1; +const drawTask = function(elem, task, conf) { + const center = task.x + conf.width / 2; + const g = elem.append("g"); + taskCount++; + const maxHeight = 300 + 5 * 30; + g.append("line").attr("id", "task" + taskCount).attr("x1", center).attr("y1", task.y).attr("x2", center).attr("y2", maxHeight).attr("class", "task-line").attr("stroke-width", "1px").attr("stroke-dasharray", "4 2").attr("stroke", "#666"); + drawFace(g, { + cx: center, + cy: 300 + (5 - task.score) * 30, + score: task.score + }); + const rect = getNoteRect(); + rect.x = task.x; + rect.y = task.y; + rect.fill = task.fill; + rect.width = conf.width; + rect.height = conf.height; + rect.class = "task task-type-" + task.num; + rect.rx = 3; + rect.ry = 3; + drawRect(g, rect); + task.x + 14; + _drawTextCandidateFunc(conf)( + task.task, + g, + rect.x, + rect.y, + rect.width, + rect.height, + { class: "task" }, + conf, + task.colour + ); +}; +const drawBackgroundRect = function(elem, bounds) { + const rectElem = drawRect(elem, { + x: bounds.startx, + y: bounds.starty, + width: bounds.stopx - bounds.startx, + height: bounds.stopy - bounds.starty, + fill: bounds.fill, + class: "rect" + }); + rectElem.lower(); +}; +const getTextObj = function() { + return { + x: 0, + y: 0, + fill: void 0, + "text-anchor": "start", + width: 100, + height: 100, + textMargin: 0, + rx: 0, + ry: 0 + }; +}; +const getNoteRect = function() { + return { + x: 0, + y: 0, + width: 100, + anchor: "start", + height: 100, + rx: 0, + ry: 0 + }; +}; +const _drawTextCandidateFunc = function() { + function byText(content, g, x, y, width, height, textAttrs, colour) { + const text = g.append("text").attr("x", x + width / 2).attr("y", y + height / 2 + 5).style("font-color", colour).style("text-anchor", "middle").text(content); + _setTextAttrs(text, textAttrs); + } + function byTspan(content, g, x, y, width, height, textAttrs, conf, colour) { + const { taskFontSize, taskFontFamily } = conf; + const lines = content.split(//gi); + for (let i = 0; i < lines.length; i++) { + const dy = i * taskFontSize - taskFontSize * (lines.length - 1) / 2; + const text = g.append("text").attr("x", x + width / 2).attr("y", y).attr("fill", colour).style("text-anchor", "middle").style("font-size", taskFontSize).style("font-family", taskFontFamily); + text.append("tspan").attr("x", x + width / 2).attr("dy", dy).text(lines[i]); + text.attr("y", y + height / 2).attr("dominant-baseline", "central").attr("alignment-baseline", "central"); + _setTextAttrs(text, textAttrs); + } + } + function byFo(content, g, x, y, width, height, textAttrs, conf) { + const body = g.append("switch"); + const f = body.append("foreignObject").attr("x", x).attr("y", y).attr("width", width).attr("height", height).attr("position", "fixed"); + const text = f.append("xhtml:div").style("display", "table").style("height", "100%").style("width", "100%"); + text.append("div").attr("class", "label").style("display", "table-cell").style("text-align", "center").style("vertical-align", "middle").text(content); + byTspan(content, body, x, y, width, height, textAttrs, conf); + _setTextAttrs(text, textAttrs); + } + function _setTextAttrs(toText, fromTextAttrsDict) { + for (const key in fromTextAttrsDict) { + if (key in fromTextAttrsDict) { + toText.attr(key, fromTextAttrsDict[key]); + } + } + } + return function(conf) { + return conf.textPlacement === "fo" ? byFo : conf.textPlacement === "old" ? byText : byTspan; + }; +}(); +const initGraphics = function(graphics) { + graphics.append("defs").append("marker").attr("id", "arrowhead").attr("refX", 5).attr("refY", 2).attr("markerWidth", 6).attr("markerHeight", 4).attr("orient", "auto").append("path").attr("d", "M 0,0 V 4 L6,2 Z"); +}; +function wrap(text, width) { + text.each(function() { + var text2 = select(this), words = text2.text().split(/(\s+|
    )/).reverse(), word, line = [], lineHeight = 1.1, y = text2.attr("y"), dy = parseFloat(text2.attr("dy")), tspan = text2.text(null).append("tspan").attr("x", 0).attr("y", y).attr("dy", dy + "em"); + for (let j = 0; j < words.length; j++) { + word = words[words.length - 1 - j]; + line.push(word); + tspan.text(line.join(" ").trim()); + if (tspan.node().getComputedTextLength() > width || word === "
    ") { + line.pop(); + tspan.text(line.join(" ").trim()); + if (word === "
    ") { + line = [""]; + } else { + line = [word]; + } + tspan = text2.append("tspan").attr("x", 0).attr("y", y).attr("dy", lineHeight + "em").text(word); + } + } + }); +} +const drawNode = function(elem, node, fullSection, conf) { + const section = fullSection % MAX_SECTIONS - 1; + const nodeElem = elem.append("g"); + node.section = section; + nodeElem.attr( + "class", + (node.class ? node.class + " " : "") + "timeline-node " + ("section-" + section) + ); + const bkgElem = nodeElem.append("g"); + const textElem = nodeElem.append("g"); + const txt = textElem.append("text").text(node.descr).attr("dy", "1em").attr("alignment-baseline", "middle").attr("dominant-baseline", "middle").attr("text-anchor", "middle").call(wrap, node.width); + const bbox = txt.node().getBBox(); + const fontSize = conf.fontSize && conf.fontSize.replace ? conf.fontSize.replace("px", "") : conf.fontSize; + node.height = bbox.height + fontSize * 1.1 * 0.5 + node.padding; + node.height = Math.max(node.height, node.maxHeight); + node.width = node.width + 2 * node.padding; + textElem.attr("transform", "translate(" + node.width / 2 + ", " + node.padding / 2 + ")"); + defaultBkg(bkgElem, node, section); + return node; +}; +const getVirtualNodeHeight = function(elem, node, conf) { + const textElem = elem.append("g"); + const txt = textElem.append("text").text(node.descr).attr("dy", "1em").attr("alignment-baseline", "middle").attr("dominant-baseline", "middle").attr("text-anchor", "middle").call(wrap, node.width); + const bbox = txt.node().getBBox(); + const fontSize = conf.fontSize && conf.fontSize.replace ? conf.fontSize.replace("px", "") : conf.fontSize; + textElem.remove(); + return bbox.height + fontSize * 1.1 * 0.5 + node.padding; +}; +const defaultBkg = function(elem, node, section) { + const rd = 5; + elem.append("path").attr("id", "node-" + node.id).attr("class", "node-bkg node-" + node.type).attr( + "d", + `M0 ${node.height - rd} v${-node.height + 2 * rd} q0,-5 5,-5 h${node.width - 2 * rd} q5,0 5,5 v${node.height - rd} H0 Z` + ); + elem.append("line").attr("class", "node-line-" + section).attr("x1", 0).attr("y1", node.height).attr("x2", node.width).attr("y2", node.height); +}; +const svgDraw = { + drawRect, + drawCircle, + drawSection, + drawText, + drawLabel, + drawTask, + drawBackgroundRect, + getTextObj, + getNoteRect, + initGraphics, + drawNode, + getVirtualNodeHeight +}; +const draw = function(text, id, version, diagObj) { + var _a, _b; + const conf = getConfig(); + const LEFT_MARGIN = conf.leftMargin ?? 50; + log.debug("timeline", diagObj.db); + const securityLevel = conf.securityLevel; + let sandboxElement; + if (securityLevel === "sandbox") { + sandboxElement = select("#i" + id); + } + const root = securityLevel === "sandbox" ? select(sandboxElement.nodes()[0].contentDocument.body) : select("body"); + const svg = root.select("#" + id); + svg.append("g"); + const tasks2 = diagObj.db.getTasks(); + const title = diagObj.db.getCommonDb().getDiagramTitle(); + log.debug("task", tasks2); + svgDraw.initGraphics(svg); + const sections2 = diagObj.db.getSections(); + log.debug("sections", sections2); + let maxSectionHeight = 0; + let maxTaskHeight = 0; + let depthY = 0; + let sectionBeginY = 0; + let masterX = 50 + LEFT_MARGIN; + let masterY = 50; + sectionBeginY = 50; + let sectionNumber = 0; + let hasSections = true; + sections2.forEach(function(section) { + const sectionNode = { + number: sectionNumber, + descr: section, + section: sectionNumber, + width: 150, + padding: 20, + maxHeight: maxSectionHeight + }; + const sectionHeight = svgDraw.getVirtualNodeHeight(svg, sectionNode, conf); + log.debug("sectionHeight before draw", sectionHeight); + maxSectionHeight = Math.max(maxSectionHeight, sectionHeight + 20); + }); + let maxEventCount = 0; + let maxEventLineLength = 0; + log.debug("tasks.length", tasks2.length); + for (const [i, task] of tasks2.entries()) { + const taskNode = { + number: i, + descr: task, + section: task.section, + width: 150, + padding: 20, + maxHeight: maxTaskHeight + }; + const taskHeight = svgDraw.getVirtualNodeHeight(svg, taskNode, conf); + log.debug("taskHeight before draw", taskHeight); + maxTaskHeight = Math.max(maxTaskHeight, taskHeight + 20); + maxEventCount = Math.max(maxEventCount, task.events.length); + let maxEventLineLengthTemp = 0; + for (let j = 0; j < task.events.length; j++) { + const event = task.events[j]; + const eventNode = { + descr: event, + section: task.section, + number: task.section, + width: 150, + padding: 20, + maxHeight: 50 + }; + maxEventLineLengthTemp += svgDraw.getVirtualNodeHeight(svg, eventNode, conf); + } + maxEventLineLength = Math.max(maxEventLineLength, maxEventLineLengthTemp); + } + log.debug("maxSectionHeight before draw", maxSectionHeight); + log.debug("maxTaskHeight before draw", maxTaskHeight); + if (sections2 && sections2.length > 0) { + sections2.forEach((section) => { + const tasksForSection = tasks2.filter((task) => task.section === section); + const sectionNode = { + number: sectionNumber, + descr: section, + section: sectionNumber, + width: 200 * Math.max(tasksForSection.length, 1) - 50, + padding: 20, + maxHeight: maxSectionHeight + }; + log.debug("sectionNode", sectionNode); + const sectionNodeWrapper = svg.append("g"); + const node = svgDraw.drawNode(sectionNodeWrapper, sectionNode, sectionNumber, conf); + log.debug("sectionNode output", node); + sectionNodeWrapper.attr("transform", `translate(${masterX}, ${sectionBeginY})`); + masterY += maxSectionHeight + 50; + if (tasksForSection.length > 0) { + drawTasks( + svg, + tasksForSection, + sectionNumber, + masterX, + masterY, + maxTaskHeight, + conf, + maxEventCount, + maxEventLineLength, + maxSectionHeight, + false + ); + } + masterX += 200 * Math.max(tasksForSection.length, 1); + masterY = sectionBeginY; + sectionNumber++; + }); + } else { + hasSections = false; + drawTasks( + svg, + tasks2, + sectionNumber, + masterX, + masterY, + maxTaskHeight, + conf, + maxEventCount, + maxEventLineLength, + maxSectionHeight, + true + ); + } + const box = svg.node().getBBox(); + log.debug("bounds", box); + if (title) { + svg.append("text").text(title).attr("x", box.width / 2 - LEFT_MARGIN).attr("font-size", "4ex").attr("font-weight", "bold").attr("y", 20); + } + depthY = hasSections ? maxSectionHeight + maxTaskHeight + 150 : maxTaskHeight + 100; + const lineWrapper = svg.append("g").attr("class", "lineWrapper"); + lineWrapper.append("line").attr("x1", LEFT_MARGIN).attr("y1", depthY).attr("x2", box.width + 3 * LEFT_MARGIN).attr("y2", depthY).attr("stroke-width", 4).attr("stroke", "black").attr("marker-end", "url(#arrowhead)"); + setupGraphViewbox( + void 0, + svg, + ((_a = conf.timeline) == null ? void 0 : _a.padding) ?? 50, + ((_b = conf.timeline) == null ? void 0 : _b.useMaxWidth) ?? false + ); +}; +const drawTasks = function(diagram2, tasks2, sectionColor, masterX, masterY, maxTaskHeight, conf, maxEventCount, maxEventLineLength, maxSectionHeight, isWithoutSections) { + var _a; + for (const task of tasks2) { + const taskNode = { + descr: task.task, + section: sectionColor, + number: sectionColor, + width: 150, + padding: 20, + maxHeight: maxTaskHeight + }; + log.debug("taskNode", taskNode); + const taskWrapper = diagram2.append("g").attr("class", "taskWrapper"); + const node = svgDraw.drawNode(taskWrapper, taskNode, sectionColor, conf); + const taskHeight = node.height; + log.debug("taskHeight after draw", taskHeight); + taskWrapper.attr("transform", `translate(${masterX}, ${masterY})`); + maxTaskHeight = Math.max(maxTaskHeight, taskHeight); + if (task.events) { + const lineWrapper = diagram2.append("g").attr("class", "lineWrapper"); + let lineLength = maxTaskHeight; + masterY += 100; + lineLength = lineLength + drawEvents(diagram2, task.events, sectionColor, masterX, masterY, conf); + masterY -= 100; + lineWrapper.append("line").attr("x1", masterX + 190 / 2).attr("y1", masterY + maxTaskHeight).attr("x2", masterX + 190 / 2).attr( + "y2", + masterY + maxTaskHeight + (isWithoutSections ? maxTaskHeight : maxSectionHeight) + maxEventLineLength + 120 + ).attr("stroke-width", 2).attr("stroke", "black").attr("marker-end", "url(#arrowhead)").attr("stroke-dasharray", "5,5"); + } + masterX = masterX + 200; + if (isWithoutSections && !((_a = conf.timeline) == null ? void 0 : _a.disableMulticolor)) { + sectionColor++; + } + } + masterY = masterY - 10; +}; +const drawEvents = function(diagram2, events, sectionColor, masterX, masterY, conf) { + let maxEventHeight = 0; + const eventBeginY = masterY; + masterY = masterY + 100; + for (const event of events) { + const eventNode = { + descr: event, + section: sectionColor, + number: sectionColor, + width: 150, + padding: 20, + maxHeight: 50 + }; + log.debug("eventNode", eventNode); + const eventWrapper = diagram2.append("g").attr("class", "eventWrapper"); + const node = svgDraw.drawNode(eventWrapper, eventNode, sectionColor, conf); + const eventHeight = node.height; + maxEventHeight = maxEventHeight + eventHeight; + eventWrapper.attr("transform", `translate(${masterX}, ${masterY})`); + masterY = masterY + 10 + eventHeight; + } + masterY = eventBeginY; + return maxEventHeight; +}; +const renderer = { + setConf: () => { + }, + draw +}; +const genSections = (options) => { + let sections2 = ""; + for (let i = 0; i < options.THEME_COLOR_LIMIT; i++) { + options["lineColor" + i] = options["lineColor" + i] || options["cScaleInv" + i]; + if (isDark(options["lineColor" + i])) { + options["lineColor" + i] = lighten(options["lineColor" + i], 20); + } else { + options["lineColor" + i] = darken(options["lineColor" + i], 20); + } + } + for (let i = 0; i < options.THEME_COLOR_LIMIT; i++) { + const sw = "" + (17 - 3 * i); + sections2 += ` + .section-${i - 1} rect, .section-${i - 1} path, .section-${i - 1} circle, .section-${i - 1} path { + fill: ${options["cScale" + i]}; + } + .section-${i - 1} text { + fill: ${options["cScaleLabel" + i]}; + } + .node-icon-${i - 1} { + font-size: 40px; + color: ${options["cScaleLabel" + i]}; + } + .section-edge-${i - 1}{ + stroke: ${options["cScale" + i]}; + } + .edge-depth-${i - 1}{ + stroke-width: ${sw}; + } + .section-${i - 1} line { + stroke: ${options["cScaleInv" + i]} ; + stroke-width: 3; + } + + .lineWrapper line{ + stroke: ${options["cScaleLabel" + i]} ; + } + + .disabled, .disabled circle, .disabled text { + fill: lightgray; + } + .disabled text { + fill: #efefef; + } + `; + } + return sections2; +}; +const getStyles = (options) => ` + .edge { + stroke-width: 3; + } + ${genSections(options)} + .section-root rect, .section-root path, .section-root circle { + fill: ${options.git0}; + } + .section-root text { + fill: ${options.gitBranchLabel0}; + } + .icon-container { + height:100%; + display: flex; + justify-content: center; + align-items: center; + } + .edge { + fill: none; + } + .eventWrapper { + filter: brightness(120%); + } +`; +const styles = getStyles; +const diagram = { + db, + renderer, + parser: parser$1, + styles +}; +export { + diagram +}; diff --git a/0.6.0/js/mermaid/xychartDiagram-de2e5521.js b/0.6.0/js/mermaid/xychartDiagram-de2e5521.js new file mode 100644 index 0000000..aa8194f --- /dev/null +++ b/0.6.0/js/mermaid/xychartDiagram-de2e5521.js @@ -0,0 +1,1800 @@ +import { l as log, s as setAccTitle, g as getAccTitle, C as setDiagramTitle, D as getDiagramTitle, a as getAccDescription, b as setAccDescription, Z as getThemeVariables, _ as getConfig, X as cleanAndMerge, W as defaultConfig, E as clear$1, d as sanitizeText, U as selectSvgElement, k as configureSvgSize } from "./mermaid-dcacb631.js"; +import { c as computeDimensionOfText } from "./createText-b70fe78a.js"; +import { i as initRange } from "./init-cc95ec8e.js"; +import { o as ordinal } from "./ordinal-475e0c0c.js"; +import { l as linear } from "./linear-0ad15847.js"; +import { l as line } from "./line-87f517ef.js"; +import "./array-b7dcf730.js"; +import "./path-39bad7e2.js"; +function range(start, stop, step) { + start = +start, stop = +stop, step = (n = arguments.length) < 2 ? (stop = start, start = 0, 1) : n < 3 ? 1 : +step; + var i = -1, n = Math.max(0, Math.ceil((stop - start) / step)) | 0, range2 = new Array(n); + while (++i < n) { + range2[i] = start + i * step; + } + return range2; +} +function band() { + var scale = ordinal().unknown(void 0), domain = scale.domain, ordinalRange = scale.range, r0 = 0, r1 = 1, step, bandwidth, round = false, paddingInner = 0, paddingOuter = 0, align = 0.5; + delete scale.unknown; + function rescale() { + var n = domain().length, reverse = r1 < r0, start = reverse ? r1 : r0, stop = reverse ? r0 : r1; + step = (stop - start) / Math.max(1, n - paddingInner + paddingOuter * 2); + if (round) + step = Math.floor(step); + start += (stop - start - step * (n - paddingInner)) * align; + bandwidth = step * (1 - paddingInner); + if (round) + start = Math.round(start), bandwidth = Math.round(bandwidth); + var values = range(n).map(function(i) { + return start + step * i; + }); + return ordinalRange(reverse ? values.reverse() : values); + } + scale.domain = function(_) { + return arguments.length ? (domain(_), rescale()) : domain(); + }; + scale.range = function(_) { + return arguments.length ? ([r0, r1] = _, r0 = +r0, r1 = +r1, rescale()) : [r0, r1]; + }; + scale.rangeRound = function(_) { + return [r0, r1] = _, r0 = +r0, r1 = +r1, round = true, rescale(); + }; + scale.bandwidth = function() { + return bandwidth; + }; + scale.step = function() { + return step; + }; + scale.round = function(_) { + return arguments.length ? (round = !!_, rescale()) : round; + }; + scale.padding = function(_) { + return arguments.length ? (paddingInner = Math.min(1, paddingOuter = +_), rescale()) : paddingInner; + }; + scale.paddingInner = function(_) { + return arguments.length ? (paddingInner = Math.min(1, _), rescale()) : paddingInner; + }; + scale.paddingOuter = function(_) { + return arguments.length ? (paddingOuter = +_, rescale()) : paddingOuter; + }; + scale.align = function(_) { + return arguments.length ? (align = Math.max(0, Math.min(1, _)), rescale()) : align; + }; + scale.copy = function() { + return band(domain(), [r0, r1]).round(round).paddingInner(paddingInner).paddingOuter(paddingOuter).align(align); + }; + return initRange.apply(rescale(), arguments); +} +var parser = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 10, 12, 14, 16, 18, 19, 21, 23], $V1 = [2, 6], $V2 = [1, 3], $V3 = [1, 5], $V4 = [1, 6], $V5 = [1, 7], $V6 = [1, 5, 10, 12, 14, 16, 18, 19, 21, 23, 34, 35, 36], $V7 = [1, 25], $V8 = [1, 26], $V9 = [1, 28], $Va = [1, 29], $Vb = [1, 30], $Vc = [1, 31], $Vd = [1, 32], $Ve = [1, 33], $Vf = [1, 34], $Vg = [1, 35], $Vh = [1, 36], $Vi = [1, 37], $Vj = [1, 43], $Vk = [1, 42], $Vl = [1, 47], $Vm = [1, 50], $Vn = [1, 10, 12, 14, 16, 18, 19, 21, 23, 34, 35, 36], $Vo = [1, 10, 12, 14, 16, 18, 19, 21, 23, 24, 26, 27, 28, 34, 35, 36], $Vp = [1, 10, 12, 14, 16, 18, 19, 21, 23, 24, 26, 27, 28, 34, 35, 36, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50], $Vq = [1, 64]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "eol": 4, "XYCHART": 5, "chartConfig": 6, "document": 7, "CHART_ORIENTATION": 8, "statement": 9, "title": 10, "text": 11, "X_AXIS": 12, "parseXAxis": 13, "Y_AXIS": 14, "parseYAxis": 15, "LINE": 16, "plotData": 17, "BAR": 18, "acc_title": 19, "acc_title_value": 20, "acc_descr": 21, "acc_descr_value": 22, "acc_descr_multiline_value": 23, "SQUARE_BRACES_START": 24, "commaSeparatedNumbers": 25, "SQUARE_BRACES_END": 26, "NUMBER_WITH_DECIMAL": 27, "COMMA": 28, "xAxisData": 29, "bandData": 30, "ARROW_DELIMITER": 31, "commaSeparatedTexts": 32, "yAxisData": 33, "NEWLINE": 34, "SEMI": 35, "EOF": 36, "alphaNum": 37, "STR": 38, "MD_STR": 39, "alphaNumToken": 40, "AMP": 41, "NUM": 42, "ALPHA": 43, "PLUS": 44, "EQUALS": 45, "MULT": 46, "DOT": 47, "BRKT": 48, "MINUS": 49, "UNDERSCORE": 50, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 5: "XYCHART", 8: "CHART_ORIENTATION", 10: "title", 12: "X_AXIS", 14: "Y_AXIS", 16: "LINE", 18: "BAR", 19: "acc_title", 20: "acc_title_value", 21: "acc_descr", 22: "acc_descr_value", 23: "acc_descr_multiline_value", 24: "SQUARE_BRACES_START", 26: "SQUARE_BRACES_END", 27: "NUMBER_WITH_DECIMAL", 28: "COMMA", 31: "ARROW_DELIMITER", 34: "NEWLINE", 35: "SEMI", 36: "EOF", 38: "STR", 39: "MD_STR", 41: "AMP", 42: "NUM", 43: "ALPHA", 44: "PLUS", 45: "EQUALS", 46: "MULT", 47: "DOT", 48: "BRKT", 49: "MINUS", 50: "UNDERSCORE" }, + productions_: [0, [3, 2], [3, 3], [3, 2], [3, 1], [6, 1], [7, 0], [7, 2], [9, 2], [9, 2], [9, 2], [9, 2], [9, 2], [9, 3], [9, 2], [9, 3], [9, 2], [9, 2], [9, 1], [17, 3], [25, 3], [25, 1], [13, 1], [13, 2], [13, 1], [29, 1], [29, 3], [30, 3], [32, 3], [32, 1], [15, 1], [15, 2], [15, 1], [33, 3], [4, 1], [4, 1], [4, 1], [11, 1], [11, 1], [11, 1], [37, 1], [37, 2], [40, 1], [40, 1], [40, 1], [40, 1], [40, 1], [40, 1], [40, 1], [40, 1], [40, 1], [40, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 5: + yy.setOrientation($$[$0]); + break; + case 9: + yy.setDiagramTitle($$[$0].text.trim()); + break; + case 12: + yy.setLineData({ text: "", type: "text" }, $$[$0]); + break; + case 13: + yy.setLineData($$[$0 - 1], $$[$0]); + break; + case 14: + yy.setBarData({ text: "", type: "text" }, $$[$0]); + break; + case 15: + yy.setBarData($$[$0 - 1], $$[$0]); + break; + case 16: + this.$ = $$[$0].trim(); + yy.setAccTitle(this.$); + break; + case 17: + case 18: + this.$ = $$[$0].trim(); + yy.setAccDescription(this.$); + break; + case 19: + this.$ = $$[$0 - 1]; + break; + case 20: + this.$ = [Number($$[$0 - 2]), ...$$[$0]]; + break; + case 21: + this.$ = [Number($$[$0])]; + break; + case 22: + yy.setXAxisTitle($$[$0]); + break; + case 23: + yy.setXAxisTitle($$[$0 - 1]); + break; + case 24: + yy.setXAxisTitle({ type: "text", text: "" }); + break; + case 25: + yy.setXAxisBand($$[$0]); + break; + case 26: + yy.setXAxisRangeData(Number($$[$0 - 2]), Number($$[$0])); + break; + case 27: + this.$ = $$[$0 - 1]; + break; + case 28: + this.$ = [$$[$0 - 2], ...$$[$0]]; + break; + case 29: + this.$ = [$$[$0]]; + break; + case 30: + yy.setYAxisTitle($$[$0]); + break; + case 31: + yy.setYAxisTitle($$[$0 - 1]); + break; + case 32: + yy.setYAxisTitle({ type: "text", text: "" }); + break; + case 33: + yy.setYAxisRangeData(Number($$[$0 - 2]), Number($$[$0])); + break; + case 37: + this.$ = { text: $$[$0], type: "text" }; + break; + case 38: + this.$ = { text: $$[$0], type: "text" }; + break; + case 39: + this.$ = { text: $$[$0], type: "markdown" }; + break; + case 40: + this.$ = $$[$0]; + break; + case 41: + this.$ = $$[$0 - 1] + "" + $$[$0]; + break; + } + }, + table: [o($V0, $V1, { 3: 1, 4: 2, 7: 4, 5: $V2, 34: $V3, 35: $V4, 36: $V5 }), { 1: [3] }, o($V0, $V1, { 4: 2, 7: 4, 3: 8, 5: $V2, 34: $V3, 35: $V4, 36: $V5 }), o($V0, $V1, { 4: 2, 7: 4, 6: 9, 3: 10, 5: $V2, 8: [1, 11], 34: $V3, 35: $V4, 36: $V5 }), { 1: [2, 4], 9: 12, 10: [1, 13], 12: [1, 14], 14: [1, 15], 16: [1, 16], 18: [1, 17], 19: [1, 18], 21: [1, 19], 23: [1, 20] }, o($V6, [2, 34]), o($V6, [2, 35]), o($V6, [2, 36]), { 1: [2, 1] }, o($V0, $V1, { 4: 2, 7: 4, 3: 21, 5: $V2, 34: $V3, 35: $V4, 36: $V5 }), { 1: [2, 3] }, o($V6, [2, 5]), o($V0, [2, 7], { 4: 22, 34: $V3, 35: $V4, 36: $V5 }), { 11: 23, 37: 24, 38: $V7, 39: $V8, 40: 27, 41: $V9, 42: $Va, 43: $Vb, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi }, { 11: 39, 13: 38, 24: $Vj, 27: $Vk, 29: 40, 30: 41, 37: 24, 38: $V7, 39: $V8, 40: 27, 41: $V9, 42: $Va, 43: $Vb, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi }, { 11: 45, 15: 44, 27: $Vl, 33: 46, 37: 24, 38: $V7, 39: $V8, 40: 27, 41: $V9, 42: $Va, 43: $Vb, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi }, { 11: 49, 17: 48, 24: $Vm, 37: 24, 38: $V7, 39: $V8, 40: 27, 41: $V9, 42: $Va, 43: $Vb, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi }, { 11: 52, 17: 51, 24: $Vm, 37: 24, 38: $V7, 39: $V8, 40: 27, 41: $V9, 42: $Va, 43: $Vb, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi }, { 20: [1, 53] }, { 22: [1, 54] }, o($Vn, [2, 18]), { 1: [2, 2] }, o($Vn, [2, 8]), o($Vn, [2, 9]), o($Vo, [2, 37], { 40: 55, 41: $V9, 42: $Va, 43: $Vb, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi }), o($Vo, [2, 38]), o($Vo, [2, 39]), o($Vp, [2, 40]), o($Vp, [2, 42]), o($Vp, [2, 43]), o($Vp, [2, 44]), o($Vp, [2, 45]), o($Vp, [2, 46]), o($Vp, [2, 47]), o($Vp, [2, 48]), o($Vp, [2, 49]), o($Vp, [2, 50]), o($Vp, [2, 51]), o($Vn, [2, 10]), o($Vn, [2, 22], { 30: 41, 29: 56, 24: $Vj, 27: $Vk }), o($Vn, [2, 24]), o($Vn, [2, 25]), { 31: [1, 57] }, { 11: 59, 32: 58, 37: 24, 38: $V7, 39: $V8, 40: 27, 41: $V9, 42: $Va, 43: $Vb, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi }, o($Vn, [2, 11]), o($Vn, [2, 30], { 33: 60, 27: $Vl }), o($Vn, [2, 32]), { 31: [1, 61] }, o($Vn, [2, 12]), { 17: 62, 24: $Vm }, { 25: 63, 27: $Vq }, o($Vn, [2, 14]), { 17: 65, 24: $Vm }, o($Vn, [2, 16]), o($Vn, [2, 17]), o($Vp, [2, 41]), o($Vn, [2, 23]), { 27: [1, 66] }, { 26: [1, 67] }, { 26: [2, 29], 28: [1, 68] }, o($Vn, [2, 31]), { 27: [1, 69] }, o($Vn, [2, 13]), { 26: [1, 70] }, { 26: [2, 21], 28: [1, 71] }, o($Vn, [2, 15]), o($Vn, [2, 26]), o($Vn, [2, 27]), { 11: 59, 32: 72, 37: 24, 38: $V7, 39: $V8, 40: 27, 41: $V9, 42: $Va, 43: $Vb, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi }, o($Vn, [2, 33]), o($Vn, [2, 19]), { 25: 73, 27: $Vq }, { 26: [2, 28] }, { 26: [2, 20] }], + defaultActions: { 8: [2, 1], 10: [2, 3], 21: [2, 2], 72: [2, 28], 73: [2, 20] }, + parseError: function parseError(str, hash) { + if (hash.recoverable) { + this.trace(str); + } else { + var error = new Error(str); + error.hash = hash; + throw error; + } + }, + parse: function parse(input) { + var self = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex() { + var token; + token = tstack.pop() || lexer2.lex() || EOF; + if (typeof token !== "number") { + if (token instanceof Array) { + tstack = token; + token = tstack.pop(); + } + token = self.symbols_[token] || token; + } + return token; + } + var symbol, state, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state = stack[stack.length - 1]; + if (this.defaultActions[state]) { + action = this.defaultActions[state]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex(); + } + action = table[state] && table[state][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str, hash); + } else { + throw new Error(str); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch = this._input[0]; + this.yytext += ch; + this.yyleng++; + this.offset++; + this.match += ch; + this.matched += ch; + var lines = ch.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch; + }, + // unshifts one char (or a string) into the input + unput: function(ch) { + var len = ch.length; + var lines = ch.split(/(?:\r\n?|\n)/g); + this._input = ch + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next = this.match; + if (next.length < 20) { + next += this._input.substr(0, 20 - next.length); + } + return (next.substr(0, 20) + (next.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token) { + return token; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token, match, tempMatch, index; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i = 0; i < rules.length; i++) { + tempMatch = this._input.match(this.rules[rules[i]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index = i; + if (this.options.backtrack_lexer) { + token = this.test_match(tempMatch, rules[i]); + if (token !== false) { + return token; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token = this.test_match(match, rules[index]); + if (token !== false) { + return token; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + break; + case 1: + break; + case 2: + this.popState(); + return 34; + case 3: + this.popState(); + return 34; + case 4: + return 34; + case 5: + break; + case 6: + return 10; + case 7: + this.pushState("acc_title"); + return 19; + case 8: + this.popState(); + return "acc_title_value"; + case 9: + this.pushState("acc_descr"); + return 21; + case 10: + this.popState(); + return "acc_descr_value"; + case 11: + this.pushState("acc_descr_multiline"); + break; + case 12: + this.popState(); + break; + case 13: + return "acc_descr_multiline_value"; + case 14: + return 5; + case 15: + return 8; + case 16: + this.pushState("axis_data"); + return "X_AXIS"; + case 17: + this.pushState("axis_data"); + return "Y_AXIS"; + case 18: + this.pushState("axis_band_data"); + return 24; + case 19: + return 31; + case 20: + this.pushState("data"); + return 16; + case 21: + this.pushState("data"); + return 18; + case 22: + this.pushState("data_inner"); + return 24; + case 23: + return 27; + case 24: + this.popState(); + return 26; + case 25: + this.popState(); + break; + case 26: + this.pushState("string"); + break; + case 27: + this.popState(); + break; + case 28: + return "STR"; + case 29: + return 24; + case 30: + return 26; + case 31: + return 43; + case 32: + return "COLON"; + case 33: + return 44; + case 34: + return 28; + case 35: + return 45; + case 36: + return 46; + case 37: + return 48; + case 38: + return 50; + case 39: + return 47; + case 40: + return 41; + case 41: + return 49; + case 42: + return 42; + case 43: + break; + case 44: + return 35; + case 45: + return 36; + } + }, + rules: [/^(?:%%(?!\{)[^\n]*)/i, /^(?:[^\}]%%[^\n]*)/i, /^(?:(\r?\n))/i, /^(?:(\r?\n))/i, /^(?:[\n\r]+)/i, /^(?:%%[^\n]*)/i, /^(?:title\b)/i, /^(?:accTitle\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*\{\s*)/i, /^(?:\{)/i, /^(?:[^\}]*)/i, /^(?:xychart-beta\b)/i, /^(?:(?:vertical|horizontal))/i, /^(?:x-axis\b)/i, /^(?:y-axis\b)/i, /^(?:\[)/i, /^(?:-->)/i, /^(?:line\b)/i, /^(?:bar\b)/i, /^(?:\[)/i, /^(?:[+-]?(?:\d+(?:\.\d+)?|\.\d+))/i, /^(?:\])/i, /^(?:(?:`\) \{ this\.pushState\(md_string\); \}\n\(\?:\(\?!`"\)\.\)\+ \{ return MD_STR; \}\n\(\?:`))/i, /^(?:["])/i, /^(?:["])/i, /^(?:[^"]*)/i, /^(?:\[)/i, /^(?:\])/i, /^(?:[A-Za-z]+)/i, /^(?::)/i, /^(?:\+)/i, /^(?:,)/i, /^(?:=)/i, /^(?:\*)/i, /^(?:#)/i, /^(?:[\_])/i, /^(?:\.)/i, /^(?:&)/i, /^(?:-)/i, /^(?:[0-9]+)/i, /^(?:\s+)/i, /^(?:;)/i, /^(?:$)/i], + conditions: { "data_inner": { "rules": [0, 1, 4, 5, 6, 7, 9, 11, 14, 15, 16, 17, 20, 21, 23, 24, 25, 26, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45], "inclusive": true }, "data": { "rules": [0, 1, 3, 4, 5, 6, 7, 9, 11, 14, 15, 16, 17, 20, 21, 22, 25, 26, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45], "inclusive": true }, "axis_band_data": { "rules": [0, 1, 4, 5, 6, 7, 9, 11, 14, 15, 16, 17, 20, 21, 24, 25, 26, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45], "inclusive": true }, "axis_data": { "rules": [0, 1, 2, 4, 5, 6, 7, 9, 11, 14, 15, 16, 17, 18, 19, 20, 21, 23, 25, 26, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45], "inclusive": true }, "acc_descr_multiline": { "rules": [12, 13], "inclusive": false }, "acc_descr": { "rules": [10], "inclusive": false }, "acc_title": { "rules": [8], "inclusive": false }, "title": { "rules": [], "inclusive": false }, "md_string": { "rules": [], "inclusive": false }, "string": { "rules": [27, 28], "inclusive": false }, "INITIAL": { "rules": [0, 1, 4, 5, 6, 7, 9, 11, 14, 15, 16, 17, 20, 21, 25, 26, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser() { + this.yy = {}; + } + Parser.prototype = parser2; + parser2.Parser = Parser; + return new Parser(); +}(); +parser.parser = parser; +const parser$1 = parser; +function isBarPlot(data) { + return data.type === "bar"; +} +function isBandAxisData(data) { + return data.type === "band"; +} +function isLinearAxisData(data) { + return data.type === "linear"; +} +class TextDimensionCalculatorWithFont { + constructor(parentGroup) { + this.parentGroup = parentGroup; + } + getMaxDimension(texts, fontSize) { + if (!this.parentGroup) { + return { + width: texts.reduce((acc, cur) => Math.max(cur.length, acc), 0) * fontSize, + height: fontSize + }; + } + const dimension = { + width: 0, + height: 0 + }; + const elem = this.parentGroup.append("g").attr("visibility", "hidden").attr("font-size", fontSize); + for (const t of texts) { + const bbox = computeDimensionOfText(elem, 1, t); + const width = bbox ? bbox.width : t.length * fontSize; + const height = bbox ? bbox.height : fontSize; + dimension.width = Math.max(dimension.width, width); + dimension.height = Math.max(dimension.height, height); + } + elem.remove(); + return dimension; + } +} +const BAR_WIDTH_TO_TICK_WIDTH_RATIO = 0.7; +const MAX_OUTER_PADDING_PERCENT_FOR_WRT_LABEL = 0.2; +class BaseAxis { + constructor(axisConfig, title, textDimensionCalculator, axisThemeConfig) { + this.axisConfig = axisConfig; + this.title = title; + this.textDimensionCalculator = textDimensionCalculator; + this.axisThemeConfig = axisThemeConfig; + this.boundingRect = { x: 0, y: 0, width: 0, height: 0 }; + this.axisPosition = "left"; + this.showTitle = false; + this.showLabel = false; + this.showTick = false; + this.showAxisLine = false; + this.outerPadding = 0; + this.titleTextHeight = 0; + this.labelTextHeight = 0; + this.range = [0, 10]; + this.boundingRect = { x: 0, y: 0, width: 0, height: 0 }; + this.axisPosition = "left"; + } + setRange(range2) { + this.range = range2; + if (this.axisPosition === "left" || this.axisPosition === "right") { + this.boundingRect.height = range2[1] - range2[0]; + } else { + this.boundingRect.width = range2[1] - range2[0]; + } + this.recalculateScale(); + } + getRange() { + return [this.range[0] + this.outerPadding, this.range[1] - this.outerPadding]; + } + setAxisPosition(axisPosition) { + this.axisPosition = axisPosition; + this.setRange(this.range); + } + getTickDistance() { + const range2 = this.getRange(); + return Math.abs(range2[0] - range2[1]) / this.getTickValues().length; + } + getAxisOuterPadding() { + return this.outerPadding; + } + getLabelDimension() { + return this.textDimensionCalculator.getMaxDimension( + this.getTickValues().map((tick) => tick.toString()), + this.axisConfig.labelFontSize + ); + } + recalculateOuterPaddingToDrawBar() { + if (BAR_WIDTH_TO_TICK_WIDTH_RATIO * this.getTickDistance() > this.outerPadding * 2) { + this.outerPadding = Math.floor(BAR_WIDTH_TO_TICK_WIDTH_RATIO * this.getTickDistance() / 2); + } + this.recalculateScale(); + } + calculateSpaceIfDrawnHorizontally(availableSpace) { + let availableHeight = availableSpace.height; + if (this.axisConfig.showAxisLine && availableHeight > this.axisConfig.axisLineWidth) { + availableHeight -= this.axisConfig.axisLineWidth; + this.showAxisLine = true; + } + if (this.axisConfig.showLabel) { + const spaceRequired = this.getLabelDimension(); + const maxPadding = MAX_OUTER_PADDING_PERCENT_FOR_WRT_LABEL * availableSpace.width; + this.outerPadding = Math.min(spaceRequired.width / 2, maxPadding); + const heightRequired = spaceRequired.height + this.axisConfig.labelPadding * 2; + this.labelTextHeight = spaceRequired.height; + if (heightRequired <= availableHeight) { + availableHeight -= heightRequired; + this.showLabel = true; + } + } + if (this.axisConfig.showTick && availableHeight >= this.axisConfig.tickLength) { + this.showTick = true; + availableHeight -= this.axisConfig.tickLength; + } + if (this.axisConfig.showTitle && this.title) { + const spaceRequired = this.textDimensionCalculator.getMaxDimension( + [this.title], + this.axisConfig.titleFontSize + ); + const heightRequired = spaceRequired.height + this.axisConfig.titlePadding * 2; + this.titleTextHeight = spaceRequired.height; + if (heightRequired <= availableHeight) { + availableHeight -= heightRequired; + this.showTitle = true; + } + } + this.boundingRect.width = availableSpace.width; + this.boundingRect.height = availableSpace.height - availableHeight; + } + calculateSpaceIfDrawnVertical(availableSpace) { + let availableWidth = availableSpace.width; + if (this.axisConfig.showAxisLine && availableWidth > this.axisConfig.axisLineWidth) { + availableWidth -= this.axisConfig.axisLineWidth; + this.showAxisLine = true; + } + if (this.axisConfig.showLabel) { + const spaceRequired = this.getLabelDimension(); + const maxPadding = MAX_OUTER_PADDING_PERCENT_FOR_WRT_LABEL * availableSpace.height; + this.outerPadding = Math.min(spaceRequired.height / 2, maxPadding); + const widthRequired = spaceRequired.width + this.axisConfig.labelPadding * 2; + if (widthRequired <= availableWidth) { + availableWidth -= widthRequired; + this.showLabel = true; + } + } + if (this.axisConfig.showTick && availableWidth >= this.axisConfig.tickLength) { + this.showTick = true; + availableWidth -= this.axisConfig.tickLength; + } + if (this.axisConfig.showTitle && this.title) { + const spaceRequired = this.textDimensionCalculator.getMaxDimension( + [this.title], + this.axisConfig.titleFontSize + ); + const widthRequired = spaceRequired.height + this.axisConfig.titlePadding * 2; + this.titleTextHeight = spaceRequired.height; + if (widthRequired <= availableWidth) { + availableWidth -= widthRequired; + this.showTitle = true; + } + } + this.boundingRect.width = availableSpace.width - availableWidth; + this.boundingRect.height = availableSpace.height; + } + calculateSpace(availableSpace) { + if (this.axisPosition === "left" || this.axisPosition === "right") { + this.calculateSpaceIfDrawnVertical(availableSpace); + } else { + this.calculateSpaceIfDrawnHorizontally(availableSpace); + } + this.recalculateScale(); + return { + width: this.boundingRect.width, + height: this.boundingRect.height + }; + } + setBoundingBoxXY(point) { + this.boundingRect.x = point.x; + this.boundingRect.y = point.y; + } + getDrawableElementsForLeftAxis() { + const drawableElement = []; + if (this.showAxisLine) { + const x = this.boundingRect.x + this.boundingRect.width - this.axisConfig.axisLineWidth / 2; + drawableElement.push({ + type: "path", + groupTexts: ["left-axis", "axisl-line"], + data: [ + { + path: `M ${x},${this.boundingRect.y} L ${x},${this.boundingRect.y + this.boundingRect.height} `, + strokeFill: this.axisThemeConfig.axisLineColor, + strokeWidth: this.axisConfig.axisLineWidth + } + ] + }); + } + if (this.showLabel) { + drawableElement.push({ + type: "text", + groupTexts: ["left-axis", "label"], + data: this.getTickValues().map((tick) => ({ + text: tick.toString(), + x: this.boundingRect.x + this.boundingRect.width - (this.showLabel ? this.axisConfig.labelPadding : 0) - (this.showTick ? this.axisConfig.tickLength : 0) - (this.showAxisLine ? this.axisConfig.axisLineWidth : 0), + y: this.getScaleValue(tick), + fill: this.axisThemeConfig.labelColor, + fontSize: this.axisConfig.labelFontSize, + rotation: 0, + verticalPos: "middle", + horizontalPos: "right" + })) + }); + } + if (this.showTick) { + const x = this.boundingRect.x + this.boundingRect.width - (this.showAxisLine ? this.axisConfig.axisLineWidth : 0); + drawableElement.push({ + type: "path", + groupTexts: ["left-axis", "ticks"], + data: this.getTickValues().map((tick) => ({ + path: `M ${x},${this.getScaleValue(tick)} L ${x - this.axisConfig.tickLength},${this.getScaleValue(tick)}`, + strokeFill: this.axisThemeConfig.tickColor, + strokeWidth: this.axisConfig.tickWidth + })) + }); + } + if (this.showTitle) { + drawableElement.push({ + type: "text", + groupTexts: ["left-axis", "title"], + data: [ + { + text: this.title, + x: this.boundingRect.x + this.axisConfig.titlePadding, + y: this.boundingRect.y + this.boundingRect.height / 2, + fill: this.axisThemeConfig.titleColor, + fontSize: this.axisConfig.titleFontSize, + rotation: 270, + verticalPos: "top", + horizontalPos: "center" + } + ] + }); + } + return drawableElement; + } + getDrawableElementsForBottomAxis() { + const drawableElement = []; + if (this.showAxisLine) { + const y = this.boundingRect.y + this.axisConfig.axisLineWidth / 2; + drawableElement.push({ + type: "path", + groupTexts: ["bottom-axis", "axis-line"], + data: [ + { + path: `M ${this.boundingRect.x},${y} L ${this.boundingRect.x + this.boundingRect.width},${y}`, + strokeFill: this.axisThemeConfig.axisLineColor, + strokeWidth: this.axisConfig.axisLineWidth + } + ] + }); + } + if (this.showLabel) { + drawableElement.push({ + type: "text", + groupTexts: ["bottom-axis", "label"], + data: this.getTickValues().map((tick) => ({ + text: tick.toString(), + x: this.getScaleValue(tick), + y: this.boundingRect.y + this.axisConfig.labelPadding + (this.showTick ? this.axisConfig.tickLength : 0) + (this.showAxisLine ? this.axisConfig.axisLineWidth : 0), + fill: this.axisThemeConfig.labelColor, + fontSize: this.axisConfig.labelFontSize, + rotation: 0, + verticalPos: "top", + horizontalPos: "center" + })) + }); + } + if (this.showTick) { + const y = this.boundingRect.y + (this.showAxisLine ? this.axisConfig.axisLineWidth : 0); + drawableElement.push({ + type: "path", + groupTexts: ["bottom-axis", "ticks"], + data: this.getTickValues().map((tick) => ({ + path: `M ${this.getScaleValue(tick)},${y} L ${this.getScaleValue(tick)},${y + this.axisConfig.tickLength}`, + strokeFill: this.axisThemeConfig.tickColor, + strokeWidth: this.axisConfig.tickWidth + })) + }); + } + if (this.showTitle) { + drawableElement.push({ + type: "text", + groupTexts: ["bottom-axis", "title"], + data: [ + { + text: this.title, + x: this.range[0] + (this.range[1] - this.range[0]) / 2, + y: this.boundingRect.y + this.boundingRect.height - this.axisConfig.titlePadding - this.titleTextHeight, + fill: this.axisThemeConfig.titleColor, + fontSize: this.axisConfig.titleFontSize, + rotation: 0, + verticalPos: "top", + horizontalPos: "center" + } + ] + }); + } + return drawableElement; + } + getDrawableElementsForTopAxis() { + const drawableElement = []; + if (this.showAxisLine) { + const y = this.boundingRect.y + this.boundingRect.height - this.axisConfig.axisLineWidth / 2; + drawableElement.push({ + type: "path", + groupTexts: ["top-axis", "axis-line"], + data: [ + { + path: `M ${this.boundingRect.x},${y} L ${this.boundingRect.x + this.boundingRect.width},${y}`, + strokeFill: this.axisThemeConfig.axisLineColor, + strokeWidth: this.axisConfig.axisLineWidth + } + ] + }); + } + if (this.showLabel) { + drawableElement.push({ + type: "text", + groupTexts: ["top-axis", "label"], + data: this.getTickValues().map((tick) => ({ + text: tick.toString(), + x: this.getScaleValue(tick), + y: this.boundingRect.y + (this.showTitle ? this.titleTextHeight + this.axisConfig.titlePadding * 2 : 0) + this.axisConfig.labelPadding, + fill: this.axisThemeConfig.labelColor, + fontSize: this.axisConfig.labelFontSize, + rotation: 0, + verticalPos: "top", + horizontalPos: "center" + })) + }); + } + if (this.showTick) { + const y = this.boundingRect.y; + drawableElement.push({ + type: "path", + groupTexts: ["top-axis", "ticks"], + data: this.getTickValues().map((tick) => ({ + path: `M ${this.getScaleValue(tick)},${y + this.boundingRect.height - (this.showAxisLine ? this.axisConfig.axisLineWidth : 0)} L ${this.getScaleValue(tick)},${y + this.boundingRect.height - this.axisConfig.tickLength - (this.showAxisLine ? this.axisConfig.axisLineWidth : 0)}`, + strokeFill: this.axisThemeConfig.tickColor, + strokeWidth: this.axisConfig.tickWidth + })) + }); + } + if (this.showTitle) { + drawableElement.push({ + type: "text", + groupTexts: ["top-axis", "title"], + data: [ + { + text: this.title, + x: this.boundingRect.x + this.boundingRect.width / 2, + y: this.boundingRect.y + this.axisConfig.titlePadding, + fill: this.axisThemeConfig.titleColor, + fontSize: this.axisConfig.titleFontSize, + rotation: 0, + verticalPos: "top", + horizontalPos: "center" + } + ] + }); + } + return drawableElement; + } + getDrawableElements() { + if (this.axisPosition === "left") { + return this.getDrawableElementsForLeftAxis(); + } + if (this.axisPosition === "right") { + throw Error("Drawing of right axis is not implemented"); + } + if (this.axisPosition === "bottom") { + return this.getDrawableElementsForBottomAxis(); + } + if (this.axisPosition === "top") { + return this.getDrawableElementsForTopAxis(); + } + return []; + } +} +class BandAxis extends BaseAxis { + constructor(axisConfig, axisThemeConfig, categories, title, textDimensionCalculator) { + super(axisConfig, title, textDimensionCalculator, axisThemeConfig); + this.categories = categories; + this.scale = band().domain(this.categories).range(this.getRange()); + } + setRange(range2) { + super.setRange(range2); + } + recalculateScale() { + this.scale = band().domain(this.categories).range(this.getRange()).paddingInner(1).paddingOuter(0).align(0.5); + log.trace("BandAxis axis final categories, range: ", this.categories, this.getRange()); + } + getTickValues() { + return this.categories; + } + getScaleValue(value) { + return this.scale(value) || this.getRange()[0]; + } +} +class LinearAxis extends BaseAxis { + constructor(axisConfig, axisThemeConfig, domain, title, textDimensionCalculator) { + super(axisConfig, title, textDimensionCalculator, axisThemeConfig); + this.domain = domain; + this.scale = linear().domain(this.domain).range(this.getRange()); + } + getTickValues() { + return this.scale.ticks(); + } + recalculateScale() { + const domain = [...this.domain]; + if (this.axisPosition === "left") { + domain.reverse(); + } + this.scale = linear().domain(domain).range(this.getRange()); + } + getScaleValue(value) { + return this.scale(value); + } +} +function getAxis(data, axisConfig, axisThemeConfig, tmpSVGGroup2) { + const textDimensionCalculator = new TextDimensionCalculatorWithFont(tmpSVGGroup2); + if (isBandAxisData(data)) { + return new BandAxis( + axisConfig, + axisThemeConfig, + data.categories, + data.title, + textDimensionCalculator + ); + } + return new LinearAxis( + axisConfig, + axisThemeConfig, + [data.min, data.max], + data.title, + textDimensionCalculator + ); +} +class ChartTitle { + constructor(textDimensionCalculator, chartConfig, chartData, chartThemeConfig) { + this.textDimensionCalculator = textDimensionCalculator; + this.chartConfig = chartConfig; + this.chartData = chartData; + this.chartThemeConfig = chartThemeConfig; + this.boundingRect = { + x: 0, + y: 0, + width: 0, + height: 0 + }; + this.showChartTitle = false; + } + setBoundingBoxXY(point) { + this.boundingRect.x = point.x; + this.boundingRect.y = point.y; + } + calculateSpace(availableSpace) { + const titleDimension = this.textDimensionCalculator.getMaxDimension( + [this.chartData.title], + this.chartConfig.titleFontSize + ); + const widthRequired = Math.max(titleDimension.width, availableSpace.width); + const heightRequired = titleDimension.height + 2 * this.chartConfig.titlePadding; + if (titleDimension.width <= widthRequired && titleDimension.height <= heightRequired && this.chartConfig.showTitle && this.chartData.title) { + this.boundingRect.width = widthRequired; + this.boundingRect.height = heightRequired; + this.showChartTitle = true; + } + return { + width: this.boundingRect.width, + height: this.boundingRect.height + }; + } + getDrawableElements() { + const drawableElem = []; + if (this.showChartTitle) { + drawableElem.push({ + groupTexts: ["chart-title"], + type: "text", + data: [ + { + fontSize: this.chartConfig.titleFontSize, + text: this.chartData.title, + verticalPos: "middle", + horizontalPos: "center", + x: this.boundingRect.x + this.boundingRect.width / 2, + y: this.boundingRect.y + this.boundingRect.height / 2, + fill: this.chartThemeConfig.titleColor, + rotation: 0 + } + ] + }); + } + return drawableElem; + } +} +function getChartTitleComponent(chartConfig, chartData, chartThemeConfig, tmpSVGGroup2) { + const textDimensionCalculator = new TextDimensionCalculatorWithFont(tmpSVGGroup2); + return new ChartTitle(textDimensionCalculator, chartConfig, chartData, chartThemeConfig); +} +class LinePlot { + constructor(plotData, xAxis, yAxis, orientation, plotIndex2) { + this.plotData = plotData; + this.xAxis = xAxis; + this.yAxis = yAxis; + this.orientation = orientation; + this.plotIndex = plotIndex2; + } + getDrawableElement() { + const finalData = this.plotData.data.map((d) => [ + this.xAxis.getScaleValue(d[0]), + this.yAxis.getScaleValue(d[1]) + ]); + let path; + if (this.orientation === "horizontal") { + path = line().y((d) => d[0]).x((d) => d[1])(finalData); + } else { + path = line().x((d) => d[0]).y((d) => d[1])(finalData); + } + if (!path) { + return []; + } + return [ + { + groupTexts: ["plot", `line-plot-${this.plotIndex}`], + type: "path", + data: [ + { + path, + strokeFill: this.plotData.strokeFill, + strokeWidth: this.plotData.strokeWidth + } + ] + } + ]; + } +} +class BarPlot { + constructor(barData, boundingRect, xAxis, yAxis, orientation, plotIndex2) { + this.barData = barData; + this.boundingRect = boundingRect; + this.xAxis = xAxis; + this.yAxis = yAxis; + this.orientation = orientation; + this.plotIndex = plotIndex2; + } + getDrawableElement() { + const finalData = this.barData.data.map((d) => [ + this.xAxis.getScaleValue(d[0]), + this.yAxis.getScaleValue(d[1]) + ]); + const barPaddingPercent = 0.05; + const barWidth = Math.min(this.xAxis.getAxisOuterPadding() * 2, this.xAxis.getTickDistance()) * (1 - barPaddingPercent); + const barWidthHalf = barWidth / 2; + if (this.orientation === "horizontal") { + return [ + { + groupTexts: ["plot", `bar-plot-${this.plotIndex}`], + type: "rect", + data: finalData.map((data) => ({ + x: this.boundingRect.x, + y: data[0] - barWidthHalf, + height: barWidth, + width: data[1] - this.boundingRect.x, + fill: this.barData.fill, + strokeWidth: 0, + strokeFill: this.barData.fill + })) + } + ]; + } + return [ + { + groupTexts: ["plot", `bar-plot-${this.plotIndex}`], + type: "rect", + data: finalData.map((data) => ({ + x: data[0] - barWidthHalf, + y: data[1], + width: barWidth, + height: this.boundingRect.y + this.boundingRect.height - data[1], + fill: this.barData.fill, + strokeWidth: 0, + strokeFill: this.barData.fill + })) + } + ]; + } +} +class BasePlot { + constructor(chartConfig, chartData, chartThemeConfig) { + this.chartConfig = chartConfig; + this.chartData = chartData; + this.chartThemeConfig = chartThemeConfig; + this.boundingRect = { + x: 0, + y: 0, + width: 0, + height: 0 + }; + } + setAxes(xAxis, yAxis) { + this.xAxis = xAxis; + this.yAxis = yAxis; + } + setBoundingBoxXY(point) { + this.boundingRect.x = point.x; + this.boundingRect.y = point.y; + } + calculateSpace(availableSpace) { + this.boundingRect.width = availableSpace.width; + this.boundingRect.height = availableSpace.height; + return { + width: this.boundingRect.width, + height: this.boundingRect.height + }; + } + getDrawableElements() { + if (!(this.xAxis && this.yAxis)) { + throw Error("Axes must be passed to render Plots"); + } + const drawableElem = []; + for (const [i, plot] of this.chartData.plots.entries()) { + switch (plot.type) { + case "line": + { + const linePlot = new LinePlot( + plot, + this.xAxis, + this.yAxis, + this.chartConfig.chartOrientation, + i + ); + drawableElem.push(...linePlot.getDrawableElement()); + } + break; + case "bar": + { + const barPlot = new BarPlot( + plot, + this.boundingRect, + this.xAxis, + this.yAxis, + this.chartConfig.chartOrientation, + i + ); + drawableElem.push(...barPlot.getDrawableElement()); + } + break; + } + } + return drawableElem; + } +} +function getPlotComponent(chartConfig, chartData, chartThemeConfig) { + return new BasePlot(chartConfig, chartData, chartThemeConfig); +} +class Orchestrator { + constructor(chartConfig, chartData, chartThemeConfig, tmpSVGGroup2) { + this.chartConfig = chartConfig; + this.chartData = chartData; + this.componentStore = { + title: getChartTitleComponent(chartConfig, chartData, chartThemeConfig, tmpSVGGroup2), + plot: getPlotComponent(chartConfig, chartData, chartThemeConfig), + xAxis: getAxis( + chartData.xAxis, + chartConfig.xAxis, + { + titleColor: chartThemeConfig.xAxisTitleColor, + labelColor: chartThemeConfig.xAxisLabelColor, + tickColor: chartThemeConfig.xAxisTickColor, + axisLineColor: chartThemeConfig.xAxisLineColor + }, + tmpSVGGroup2 + ), + yAxis: getAxis( + chartData.yAxis, + chartConfig.yAxis, + { + titleColor: chartThemeConfig.yAxisTitleColor, + labelColor: chartThemeConfig.yAxisLabelColor, + tickColor: chartThemeConfig.yAxisTickColor, + axisLineColor: chartThemeConfig.yAxisLineColor + }, + tmpSVGGroup2 + ) + }; + } + calculateVerticalSpace() { + let availableWidth = this.chartConfig.width; + let availableHeight = this.chartConfig.height; + let plotX = 0; + let plotY = 0; + let chartWidth = Math.floor(availableWidth * this.chartConfig.plotReservedSpacePercent / 100); + let chartHeight = Math.floor( + availableHeight * this.chartConfig.plotReservedSpacePercent / 100 + ); + let spaceUsed = this.componentStore.plot.calculateSpace({ + width: chartWidth, + height: chartHeight + }); + availableWidth -= spaceUsed.width; + availableHeight -= spaceUsed.height; + spaceUsed = this.componentStore.title.calculateSpace({ + width: this.chartConfig.width, + height: availableHeight + }); + plotY = spaceUsed.height; + availableHeight -= spaceUsed.height; + this.componentStore.xAxis.setAxisPosition("bottom"); + spaceUsed = this.componentStore.xAxis.calculateSpace({ + width: availableWidth, + height: availableHeight + }); + availableHeight -= spaceUsed.height; + this.componentStore.yAxis.setAxisPosition("left"); + spaceUsed = this.componentStore.yAxis.calculateSpace({ + width: availableWidth, + height: availableHeight + }); + plotX = spaceUsed.width; + availableWidth -= spaceUsed.width; + if (availableWidth > 0) { + chartWidth += availableWidth; + availableWidth = 0; + } + if (availableHeight > 0) { + chartHeight += availableHeight; + availableHeight = 0; + } + this.componentStore.plot.calculateSpace({ + width: chartWidth, + height: chartHeight + }); + this.componentStore.plot.setBoundingBoxXY({ x: plotX, y: plotY }); + this.componentStore.xAxis.setRange([plotX, plotX + chartWidth]); + this.componentStore.xAxis.setBoundingBoxXY({ x: plotX, y: plotY + chartHeight }); + this.componentStore.yAxis.setRange([plotY, plotY + chartHeight]); + this.componentStore.yAxis.setBoundingBoxXY({ x: 0, y: plotY }); + if (this.chartData.plots.some((p) => isBarPlot(p))) { + this.componentStore.xAxis.recalculateOuterPaddingToDrawBar(); + } + } + calculateHorizontalSpace() { + let availableWidth = this.chartConfig.width; + let availableHeight = this.chartConfig.height; + let titleYEnd = 0; + let plotX = 0; + let plotY = 0; + let chartWidth = Math.floor(availableWidth * this.chartConfig.plotReservedSpacePercent / 100); + let chartHeight = Math.floor( + availableHeight * this.chartConfig.plotReservedSpacePercent / 100 + ); + let spaceUsed = this.componentStore.plot.calculateSpace({ + width: chartWidth, + height: chartHeight + }); + availableWidth -= spaceUsed.width; + availableHeight -= spaceUsed.height; + spaceUsed = this.componentStore.title.calculateSpace({ + width: this.chartConfig.width, + height: availableHeight + }); + titleYEnd = spaceUsed.height; + availableHeight -= spaceUsed.height; + this.componentStore.xAxis.setAxisPosition("left"); + spaceUsed = this.componentStore.xAxis.calculateSpace({ + width: availableWidth, + height: availableHeight + }); + availableWidth -= spaceUsed.width; + plotX = spaceUsed.width; + this.componentStore.yAxis.setAxisPosition("top"); + spaceUsed = this.componentStore.yAxis.calculateSpace({ + width: availableWidth, + height: availableHeight + }); + availableHeight -= spaceUsed.height; + plotY = titleYEnd + spaceUsed.height; + if (availableWidth > 0) { + chartWidth += availableWidth; + availableWidth = 0; + } + if (availableHeight > 0) { + chartHeight += availableHeight; + availableHeight = 0; + } + this.componentStore.plot.calculateSpace({ + width: chartWidth, + height: chartHeight + }); + this.componentStore.plot.setBoundingBoxXY({ x: plotX, y: plotY }); + this.componentStore.yAxis.setRange([plotX, plotX + chartWidth]); + this.componentStore.yAxis.setBoundingBoxXY({ x: plotX, y: titleYEnd }); + this.componentStore.xAxis.setRange([plotY, plotY + chartHeight]); + this.componentStore.xAxis.setBoundingBoxXY({ x: 0, y: plotY }); + if (this.chartData.plots.some((p) => isBarPlot(p))) { + this.componentStore.xAxis.recalculateOuterPaddingToDrawBar(); + } + } + calculateSpace() { + if (this.chartConfig.chartOrientation === "horizontal") { + this.calculateHorizontalSpace(); + } else { + this.calculateVerticalSpace(); + } + } + getDrawableElement() { + this.calculateSpace(); + const drawableElem = []; + this.componentStore.plot.setAxes(this.componentStore.xAxis, this.componentStore.yAxis); + for (const component of Object.values(this.componentStore)) { + drawableElem.push(...component.getDrawableElements()); + } + return drawableElem; + } +} +class XYChartBuilder { + static build(config, chartData, chartThemeConfig, tmpSVGGroup2) { + const orchestrator = new Orchestrator(config, chartData, chartThemeConfig, tmpSVGGroup2); + return orchestrator.getDrawableElement(); + } +} +let plotIndex = 0; +let tmpSVGGroup; +let xyChartConfig = getChartDefaultConfig(); +let xyChartThemeConfig = getChartDefaultThemeConfig(); +let xyChartData = getChartDefaultData(); +let plotColorPalette = xyChartThemeConfig.plotColorPalette.split(",").map((color) => color.trim()); +let hasSetXAxis = false; +let hasSetYAxis = false; +function getChartDefaultThemeConfig() { + const defaultThemeVariables = getThemeVariables(); + const config = getConfig(); + return cleanAndMerge(defaultThemeVariables.xyChart, config.themeVariables.xyChart); +} +function getChartDefaultConfig() { + const config = getConfig(); + return cleanAndMerge( + defaultConfig.xyChart, + config.xyChart + ); +} +function getChartDefaultData() { + return { + yAxis: { + type: "linear", + title: "", + min: Infinity, + max: -Infinity + }, + xAxis: { + type: "band", + title: "", + categories: [] + }, + title: "", + plots: [] + }; +} +function textSanitizer(text) { + const config = getConfig(); + return sanitizeText(text.trim(), config); +} +function setTmpSVGG(SVGG) { + tmpSVGGroup = SVGG; +} +function setOrientation(orientation) { + if (orientation === "horizontal") { + xyChartConfig.chartOrientation = "horizontal"; + } else { + xyChartConfig.chartOrientation = "vertical"; + } +} +function setXAxisTitle(title) { + xyChartData.xAxis.title = textSanitizer(title.text); +} +function setXAxisRangeData(min, max) { + xyChartData.xAxis = { type: "linear", title: xyChartData.xAxis.title, min, max }; + hasSetXAxis = true; +} +function setXAxisBand(categories) { + xyChartData.xAxis = { + type: "band", + title: xyChartData.xAxis.title, + categories: categories.map((c) => textSanitizer(c.text)) + }; + hasSetXAxis = true; +} +function setYAxisTitle(title) { + xyChartData.yAxis.title = textSanitizer(title.text); +} +function setYAxisRangeData(min, max) { + xyChartData.yAxis = { type: "linear", title: xyChartData.yAxis.title, min, max }; + hasSetYAxis = true; +} +function setYAxisRangeFromPlotData(data) { + const minValue = Math.min(...data); + const maxValue = Math.max(...data); + const prevMinValue = isLinearAxisData(xyChartData.yAxis) ? xyChartData.yAxis.min : Infinity; + const prevMaxValue = isLinearAxisData(xyChartData.yAxis) ? xyChartData.yAxis.max : -Infinity; + xyChartData.yAxis = { + type: "linear", + title: xyChartData.yAxis.title, + min: Math.min(prevMinValue, minValue), + max: Math.max(prevMaxValue, maxValue) + }; +} +function transformDataWithoutCategory(data) { + let retData = []; + if (data.length === 0) { + return retData; + } + if (!hasSetXAxis) { + const prevMinValue = isLinearAxisData(xyChartData.xAxis) ? xyChartData.xAxis.min : Infinity; + const prevMaxValue = isLinearAxisData(xyChartData.xAxis) ? xyChartData.xAxis.max : -Infinity; + setXAxisRangeData(Math.min(prevMinValue, 1), Math.max(prevMaxValue, data.length)); + } + if (!hasSetYAxis) { + setYAxisRangeFromPlotData(data); + } + if (isBandAxisData(xyChartData.xAxis)) { + retData = xyChartData.xAxis.categories.map((c, i) => [c, data[i]]); + } + if (isLinearAxisData(xyChartData.xAxis)) { + const min = xyChartData.xAxis.min; + const max = xyChartData.xAxis.max; + const step = (max - min + 1) / data.length; + const categories = []; + for (let i = min; i <= max; i += step) { + categories.push(`${i}`); + } + retData = categories.map((c, i) => [c, data[i]]); + } + return retData; +} +function getPlotColorFromPalette(plotIndex2) { + return plotColorPalette[plotIndex2 === 0 ? 0 : plotIndex2 % plotColorPalette.length]; +} +function setLineData(title, data) { + const plotData = transformDataWithoutCategory(data); + xyChartData.plots.push({ + type: "line", + strokeFill: getPlotColorFromPalette(plotIndex), + strokeWidth: 2, + data: plotData + }); + plotIndex++; +} +function setBarData(title, data) { + const plotData = transformDataWithoutCategory(data); + xyChartData.plots.push({ + type: "bar", + fill: getPlotColorFromPalette(plotIndex), + data: plotData + }); + plotIndex++; +} +function getDrawableElem() { + if (xyChartData.plots.length === 0) { + throw Error("No Plot to render, please provide a plot with some data"); + } + xyChartData.title = getDiagramTitle(); + return XYChartBuilder.build(xyChartConfig, xyChartData, xyChartThemeConfig, tmpSVGGroup); +} +function getChartThemeConfig() { + return xyChartThemeConfig; +} +function getChartConfig() { + return xyChartConfig; +} +const clear = function() { + clear$1(); + plotIndex = 0; + xyChartConfig = getChartDefaultConfig(); + xyChartData = getChartDefaultData(); + xyChartThemeConfig = getChartDefaultThemeConfig(); + plotColorPalette = xyChartThemeConfig.plotColorPalette.split(",").map((color) => color.trim()); + hasSetXAxis = false; + hasSetYAxis = false; +}; +const db = { + getDrawableElem, + clear, + setAccTitle, + getAccTitle, + setDiagramTitle, + getDiagramTitle, + getAccDescription, + setAccDescription, + setOrientation, + setXAxisTitle, + setXAxisRangeData, + setXAxisBand, + setYAxisTitle, + setYAxisRangeData, + setLineData, + setBarData, + setTmpSVGG, + getChartThemeConfig, + getChartConfig +}; +const draw = (txt, id, _version, diagObj) => { + const db2 = diagObj.db; + const themeConfig = db2.getChartThemeConfig(); + const chartConfig = db2.getChartConfig(); + function getDominantBaseLine(horizontalPos) { + return horizontalPos === "top" ? "text-before-edge" : "middle"; + } + function getTextAnchor(verticalPos) { + return verticalPos === "left" ? "start" : verticalPos === "right" ? "end" : "middle"; + } + function getTextTransformation(data) { + return `translate(${data.x}, ${data.y}) rotate(${data.rotation || 0})`; + } + log.debug("Rendering xychart chart\n" + txt); + const svg = selectSvgElement(id); + const group = svg.append("g").attr("class", "main"); + const background = group.append("rect").attr("width", chartConfig.width).attr("height", chartConfig.height).attr("class", "background"); + configureSvgSize(svg, chartConfig.height, chartConfig.width, true); + svg.attr("viewBox", `0 0 ${chartConfig.width} ${chartConfig.height}`); + background.attr("fill", themeConfig.backgroundColor); + db2.setTmpSVGG(svg.append("g").attr("class", "mermaid-tmp-group")); + const shapes = db2.getDrawableElem(); + const groups = {}; + function getGroup(gList) { + let elem = group; + let prefix = ""; + for (const [i] of gList.entries()) { + let parent = group; + if (i > 0 && groups[prefix]) { + parent = groups[prefix]; + } + prefix += gList[i]; + elem = groups[prefix]; + if (!elem) { + elem = groups[prefix] = parent.append("g").attr("class", gList[i]); + } + } + return elem; + } + for (const shape of shapes) { + if (shape.data.length === 0) { + continue; + } + const shapeGroup = getGroup(shape.groupTexts); + switch (shape.type) { + case "rect": + shapeGroup.selectAll("rect").data(shape.data).enter().append("rect").attr("x", (data) => data.x).attr("y", (data) => data.y).attr("width", (data) => data.width).attr("height", (data) => data.height).attr("fill", (data) => data.fill).attr("stroke", (data) => data.strokeFill).attr("stroke-width", (data) => data.strokeWidth); + break; + case "text": + shapeGroup.selectAll("text").data(shape.data).enter().append("text").attr("x", 0).attr("y", 0).attr("fill", (data) => data.fill).attr("font-size", (data) => data.fontSize).attr("dominant-baseline", (data) => getDominantBaseLine(data.verticalPos)).attr("text-anchor", (data) => getTextAnchor(data.horizontalPos)).attr("transform", (data) => getTextTransformation(data)).text((data) => data.text); + break; + case "path": + shapeGroup.selectAll("path").data(shape.data).enter().append("path").attr("d", (data) => data.path).attr("fill", (data) => data.fill ? data.fill : "none").attr("stroke", (data) => data.strokeFill).attr("stroke-width", (data) => data.strokeWidth); + break; + } + } +}; +const renderer = { + draw +}; +const diagram = { + parser: parser$1, + db, + renderer +}; +export { + diagram +}; diff --git a/0.6.0/js/mermaid/xychartDiagram-e5e6b652.js b/0.6.0/js/mermaid/xychartDiagram-e5e6b652.js new file mode 100644 index 0000000..c761954 --- /dev/null +++ b/0.6.0/js/mermaid/xychartDiagram-e5e6b652.js @@ -0,0 +1,1284 @@ +import { l as wt, s as zt, g as Ft, C as Nt, D as St, a as Xt, b as Yt, Z as Ht, _ as ot, X as Ct, W as Ut, E as $t, d as qt, U as jt, k as Gt } from "./mermaid-9f2aa176.js"; +import { c as Qt } from "./createText-03b82060.js"; +import { i as Kt } from "./init-f9637058.js"; +import { o as Zt } from "./ordinal-5695958c.js"; +import { l as ft } from "./linear-9bcf74c4.js"; +import { l as pt } from "./line-24d93f1b.js"; +import "./array-2ff2c7a6.js"; +import "./path-428ebac9.js"; +function Jt(e, t, i) { + e = +e, t = +t, i = (n = arguments.length) < 2 ? (t = e, e = 0, 1) : n < 3 ? 1 : +i; + for (var s = -1, n = Math.max(0, Math.ceil((t - e) / i)) | 0, o = new Array(n); ++s < n; ) + o[s] = e + s * i; + return o; +} +function st() { + var e = Zt().unknown(void 0), t = e.domain, i = e.range, s = 0, n = 1, o, c, f = !1, d = 0, R = 0, _ = 0.5; + delete e.unknown; + function A() { + var m = t().length, T = n < s, S = T ? n : s, P = T ? s : n; + o = (P - S) / Math.max(1, m - d + R * 2), f && (o = Math.floor(o)), S += (P - S - o * (m - d)) * _, c = o * (1 - d), f && (S = Math.round(S), c = Math.round(c)); + var p = Jt(m).map(function(C) { + return S + o * C; + }); + return i(T ? p.reverse() : p); + } + return e.domain = function(m) { + return arguments.length ? (t(m), A()) : t(); + }, e.range = function(m) { + return arguments.length ? ([s, n] = m, s = +s, n = +n, A()) : [s, n]; + }, e.rangeRound = function(m) { + return [s, n] = m, s = +s, n = +n, f = !0, A(); + }, e.bandwidth = function() { + return c; + }, e.step = function() { + return o; + }, e.round = function(m) { + return arguments.length ? (f = !!m, A()) : f; + }, e.padding = function(m) { + return arguments.length ? (d = Math.min(1, R = +m), A()) : d; + }, e.paddingInner = function(m) { + return arguments.length ? (d = Math.min(1, m), A()) : d; + }, e.paddingOuter = function(m) { + return arguments.length ? (R = +m, A()) : R; + }, e.align = function(m) { + return arguments.length ? (_ = Math.max(0, Math.min(1, m)), A()) : _; + }, e.copy = function() { + return st(t(), [s, n]).round(f).paddingInner(d).paddingOuter(R).align(_); + }, Kt.apply(A(), arguments); +} +var nt = function() { + var e = function(V, r, l, u) { + for (l = l || {}, u = V.length; u--; l[V[u]] = r) + ; + return l; + }, t = [1, 10, 12, 14, 16, 18, 19, 21, 23], i = [2, 6], s = [1, 3], n = [1, 5], o = [1, 6], c = [1, 7], f = [1, 5, 10, 12, 14, 16, 18, 19, 21, 23, 34, 35, 36], d = [1, 25], R = [1, 26], _ = [1, 28], A = [1, 29], m = [1, 30], T = [1, 31], S = [1, 32], P = [1, 33], p = [1, 34], C = [1, 35], h = [1, 36], L = [1, 37], z = [1, 43], lt = [1, 42], ct = [1, 47], U = [1, 50], w = [1, 10, 12, 14, 16, 18, 19, 21, 23, 34, 35, 36], Q = [1, 10, 12, 14, 16, 18, 19, 21, 23, 24, 26, 27, 28, 34, 35, 36], E = [1, 10, 12, 14, 16, 18, 19, 21, 23, 24, 26, 27, 28, 34, 35, 36, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50], ut = [1, 64], K = { + trace: function() { + }, + yy: {}, + symbols_: { error: 2, start: 3, eol: 4, XYCHART: 5, chartConfig: 6, document: 7, CHART_ORIENTATION: 8, statement: 9, title: 10, text: 11, X_AXIS: 12, parseXAxis: 13, Y_AXIS: 14, parseYAxis: 15, LINE: 16, plotData: 17, BAR: 18, acc_title: 19, acc_title_value: 20, acc_descr: 21, acc_descr_value: 22, acc_descr_multiline_value: 23, SQUARE_BRACES_START: 24, commaSeparatedNumbers: 25, SQUARE_BRACES_END: 26, NUMBER_WITH_DECIMAL: 27, COMMA: 28, xAxisData: 29, bandData: 30, ARROW_DELIMITER: 31, commaSeparatedTexts: 32, yAxisData: 33, NEWLINE: 34, SEMI: 35, EOF: 36, alphaNum: 37, STR: 38, MD_STR: 39, alphaNumToken: 40, AMP: 41, NUM: 42, ALPHA: 43, PLUS: 44, EQUALS: 45, MULT: 46, DOT: 47, BRKT: 48, MINUS: 49, UNDERSCORE: 50, $accept: 0, $end: 1 }, + terminals_: { 2: "error", 5: "XYCHART", 8: "CHART_ORIENTATION", 10: "title", 12: "X_AXIS", 14: "Y_AXIS", 16: "LINE", 18: "BAR", 19: "acc_title", 20: "acc_title_value", 21: "acc_descr", 22: "acc_descr_value", 23: "acc_descr_multiline_value", 24: "SQUARE_BRACES_START", 26: "SQUARE_BRACES_END", 27: "NUMBER_WITH_DECIMAL", 28: "COMMA", 31: "ARROW_DELIMITER", 34: "NEWLINE", 35: "SEMI", 36: "EOF", 38: "STR", 39: "MD_STR", 41: "AMP", 42: "NUM", 43: "ALPHA", 44: "PLUS", 45: "EQUALS", 46: "MULT", 47: "DOT", 48: "BRKT", 49: "MINUS", 50: "UNDERSCORE" }, + productions_: [0, [3, 2], [3, 3], [3, 2], [3, 1], [6, 1], [7, 0], [7, 2], [9, 2], [9, 2], [9, 2], [9, 2], [9, 2], [9, 3], [9, 2], [9, 3], [9, 2], [9, 2], [9, 1], [17, 3], [25, 3], [25, 1], [13, 1], [13, 2], [13, 1], [29, 1], [29, 3], [30, 3], [32, 3], [32, 1], [15, 1], [15, 2], [15, 1], [33, 3], [4, 1], [4, 1], [4, 1], [11, 1], [11, 1], [11, 1], [37, 1], [37, 2], [40, 1], [40, 1], [40, 1], [40, 1], [40, 1], [40, 1], [40, 1], [40, 1], [40, 1], [40, 1]], + performAction: function(r, l, u, g, b, a, F) { + var x = a.length - 1; + switch (b) { + case 5: + g.setOrientation(a[x]); + break; + case 9: + g.setDiagramTitle(a[x].text.trim()); + break; + case 12: + g.setLineData({ text: "", type: "text" }, a[x]); + break; + case 13: + g.setLineData(a[x - 1], a[x]); + break; + case 14: + g.setBarData({ text: "", type: "text" }, a[x]); + break; + case 15: + g.setBarData(a[x - 1], a[x]); + break; + case 16: + this.$ = a[x].trim(), g.setAccTitle(this.$); + break; + case 17: + case 18: + this.$ = a[x].trim(), g.setAccDescription(this.$); + break; + case 19: + this.$ = a[x - 1]; + break; + case 20: + this.$ = [Number(a[x - 2]), ...a[x]]; + break; + case 21: + this.$ = [Number(a[x])]; + break; + case 22: + g.setXAxisTitle(a[x]); + break; + case 23: + g.setXAxisTitle(a[x - 1]); + break; + case 24: + g.setXAxisTitle({ type: "text", text: "" }); + break; + case 25: + g.setXAxisBand(a[x]); + break; + case 26: + g.setXAxisRangeData(Number(a[x - 2]), Number(a[x])); + break; + case 27: + this.$ = a[x - 1]; + break; + case 28: + this.$ = [a[x - 2], ...a[x]]; + break; + case 29: + this.$ = [a[x]]; + break; + case 30: + g.setYAxisTitle(a[x]); + break; + case 31: + g.setYAxisTitle(a[x - 1]); + break; + case 32: + g.setYAxisTitle({ type: "text", text: "" }); + break; + case 33: + g.setYAxisRangeData(Number(a[x - 2]), Number(a[x])); + break; + case 37: + this.$ = { text: a[x], type: "text" }; + break; + case 38: + this.$ = { text: a[x], type: "text" }; + break; + case 39: + this.$ = { text: a[x], type: "markdown" }; + break; + case 40: + this.$ = a[x]; + break; + case 41: + this.$ = a[x - 1] + "" + a[x]; + break; + } + }, + table: [e(t, i, { 3: 1, 4: 2, 7: 4, 5: s, 34: n, 35: o, 36: c }), { 1: [3] }, e(t, i, { 4: 2, 7: 4, 3: 8, 5: s, 34: n, 35: o, 36: c }), e(t, i, { 4: 2, 7: 4, 6: 9, 3: 10, 5: s, 8: [1, 11], 34: n, 35: o, 36: c }), { 1: [2, 4], 9: 12, 10: [1, 13], 12: [1, 14], 14: [1, 15], 16: [1, 16], 18: [1, 17], 19: [1, 18], 21: [1, 19], 23: [1, 20] }, e(f, [2, 34]), e(f, [2, 35]), e(f, [2, 36]), { 1: [2, 1] }, e(t, i, { 4: 2, 7: 4, 3: 21, 5: s, 34: n, 35: o, 36: c }), { 1: [2, 3] }, e(f, [2, 5]), e(t, [2, 7], { 4: 22, 34: n, 35: o, 36: c }), { 11: 23, 37: 24, 38: d, 39: R, 40: 27, 41: _, 42: A, 43: m, 44: T, 45: S, 46: P, 47: p, 48: C, 49: h, 50: L }, { 11: 39, 13: 38, 24: z, 27: lt, 29: 40, 30: 41, 37: 24, 38: d, 39: R, 40: 27, 41: _, 42: A, 43: m, 44: T, 45: S, 46: P, 47: p, 48: C, 49: h, 50: L }, { 11: 45, 15: 44, 27: ct, 33: 46, 37: 24, 38: d, 39: R, 40: 27, 41: _, 42: A, 43: m, 44: T, 45: S, 46: P, 47: p, 48: C, 49: h, 50: L }, { 11: 49, 17: 48, 24: U, 37: 24, 38: d, 39: R, 40: 27, 41: _, 42: A, 43: m, 44: T, 45: S, 46: P, 47: p, 48: C, 49: h, 50: L }, { 11: 52, 17: 51, 24: U, 37: 24, 38: d, 39: R, 40: 27, 41: _, 42: A, 43: m, 44: T, 45: S, 46: P, 47: p, 48: C, 49: h, 50: L }, { 20: [1, 53] }, { 22: [1, 54] }, e(w, [2, 18]), { 1: [2, 2] }, e(w, [2, 8]), e(w, [2, 9]), e(Q, [2, 37], { 40: 55, 41: _, 42: A, 43: m, 44: T, 45: S, 46: P, 47: p, 48: C, 49: h, 50: L }), e(Q, [2, 38]), e(Q, [2, 39]), e(E, [2, 40]), e(E, [2, 42]), e(E, [2, 43]), e(E, [2, 44]), e(E, [2, 45]), e(E, [2, 46]), e(E, [2, 47]), e(E, [2, 48]), e(E, [2, 49]), e(E, [2, 50]), e(E, [2, 51]), e(w, [2, 10]), e(w, [2, 22], { 30: 41, 29: 56, 24: z, 27: lt }), e(w, [2, 24]), e(w, [2, 25]), { 31: [1, 57] }, { 11: 59, 32: 58, 37: 24, 38: d, 39: R, 40: 27, 41: _, 42: A, 43: m, 44: T, 45: S, 46: P, 47: p, 48: C, 49: h, 50: L }, e(w, [2, 11]), e(w, [2, 30], { 33: 60, 27: ct }), e(w, [2, 32]), { 31: [1, 61] }, e(w, [2, 12]), { 17: 62, 24: U }, { 25: 63, 27: ut }, e(w, [2, 14]), { 17: 65, 24: U }, e(w, [2, 16]), e(w, [2, 17]), e(E, [2, 41]), e(w, [2, 23]), { 27: [1, 66] }, { 26: [1, 67] }, { 26: [2, 29], 28: [1, 68] }, e(w, [2, 31]), { 27: [1, 69] }, e(w, [2, 13]), { 26: [1, 70] }, { 26: [2, 21], 28: [1, 71] }, e(w, [2, 15]), e(w, [2, 26]), e(w, [2, 27]), { 11: 59, 32: 72, 37: 24, 38: d, 39: R, 40: 27, 41: _, 42: A, 43: m, 44: T, 45: S, 46: P, 47: p, 48: C, 49: h, 50: L }, e(w, [2, 33]), e(w, [2, 19]), { 25: 73, 27: ut }, { 26: [2, 28] }, { 26: [2, 20] }], + defaultActions: { 8: [2, 1], 10: [2, 3], 21: [2, 2], 72: [2, 28], 73: [2, 20] }, + parseError: function(r, l) { + if (l.recoverable) + this.trace(r); + else { + var u = new Error(r); + throw u.hash = l, u; + } + }, + parse: function(r) { + var l = this, u = [0], g = [], b = [null], a = [], F = this.table, x = "", $ = 0, gt = 0, Vt = 2, xt = 1, Wt = a.slice.call(arguments, 1), k = Object.create(this.lexer), W = { yy: {} }; + for (var J in this.yy) + Object.prototype.hasOwnProperty.call(this.yy, J) && (W.yy[J] = this.yy[J]); + k.setInput(r, W.yy), W.yy.lexer = k, W.yy.parser = this, typeof k.yylloc > "u" && (k.yylloc = {}); + var tt = k.yylloc; + a.push(tt); + var Bt = k.options && k.options.ranges; + typeof W.yy.parseError == "function" ? this.parseError = W.yy.parseError : this.parseError = Object.getPrototypeOf(this).parseError; + function Ot() { + var I; + return I = g.pop() || k.lex() || xt, typeof I != "number" && (I instanceof Array && (g = I, I = g.pop()), I = l.symbols_[I] || I), I; + } + for (var D, B, v, it, O = {}, q, M, dt, j; ; ) { + if (B = u[u.length - 1], this.defaultActions[B] ? v = this.defaultActions[B] : ((D === null || typeof D > "u") && (D = Ot()), v = F[B] && F[B][D]), typeof v > "u" || !v.length || !v[0]) { + var et = ""; + j = []; + for (q in F[B]) + this.terminals_[q] && q > Vt && j.push("'" + this.terminals_[q] + "'"); + k.showPosition ? et = "Parse error on line " + ($ + 1) + `: +` + k.showPosition() + ` +Expecting ` + j.join(", ") + ", got '" + (this.terminals_[D] || D) + "'" : et = "Parse error on line " + ($ + 1) + ": Unexpected " + (D == xt ? "end of input" : "'" + (this.terminals_[D] || D) + "'"), this.parseError(et, { + text: k.match, + token: this.terminals_[D] || D, + line: k.yylineno, + loc: tt, + expected: j + }); + } + if (v[0] instanceof Array && v.length > 1) + throw new Error("Parse Error: multiple actions possible at state: " + B + ", token: " + D); + switch (v[0]) { + case 1: + u.push(D), b.push(k.yytext), a.push(k.yylloc), u.push(v[1]), D = null, gt = k.yyleng, x = k.yytext, $ = k.yylineno, tt = k.yylloc; + break; + case 2: + if (M = this.productions_[v[1]][1], O.$ = b[b.length - M], O._$ = { + first_line: a[a.length - (M || 1)].first_line, + last_line: a[a.length - 1].last_line, + first_column: a[a.length - (M || 1)].first_column, + last_column: a[a.length - 1].last_column + }, Bt && (O._$.range = [ + a[a.length - (M || 1)].range[0], + a[a.length - 1].range[1] + ]), it = this.performAction.apply(O, [ + x, + gt, + $, + W.yy, + v[1], + b, + a + ].concat(Wt)), typeof it < "u") + return it; + M && (u = u.slice(0, -1 * M * 2), b = b.slice(0, -1 * M), a = a.slice(0, -1 * M)), u.push(this.productions_[v[1]][0]), b.push(O.$), a.push(O._$), dt = F[u[u.length - 2]][u[u.length - 1]], u.push(dt); + break; + case 3: + return !0; + } + } + return !0; + } + }, It = function() { + var V = { + EOF: 1, + parseError: function(l, u) { + if (this.yy.parser) + this.yy.parser.parseError(l, u); + else + throw new Error(l); + }, + // resets the lexer, sets new input + setInput: function(r, l) { + return this.yy = l || this.yy || {}, this._input = r, 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 r = this._input[0]; + this.yytext += r, this.yyleng++, this.offset++, this.match += r, this.matched += r; + var l = r.match(/(?:\r\n?|\n).*/g); + return l ? (this.yylineno++, this.yylloc.last_line++) : this.yylloc.last_column++, this.options.ranges && this.yylloc.range[1]++, this._input = this._input.slice(1), r; + }, + // unshifts one char (or a string) into the input + unput: function(r) { + var l = r.length, u = r.split(/(?:\r\n?|\n)/g); + this._input = r + this._input, this.yytext = this.yytext.substr(0, this.yytext.length - l), this.offset -= l; + 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), u.length - 1 && (this.yylineno -= u.length - 1); + var b = 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: u ? (u.length === g.length ? this.yylloc.first_column : 0) + g[g.length - u.length].length - u[0].length : this.yylloc.first_column - l + }, this.options.ranges && (this.yylloc.range = [b[0], b[0] + this.yyleng - l]), 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(r) { + this.unput(this.match.slice(r)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var r = this.matched.substr(0, this.matched.length - this.match.length); + return (r.length > 20 ? "..." : "") + r.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var r = this.match; + return r.length < 20 && (r += this._input.substr(0, 20 - r.length)), (r.substr(0, 20) + (r.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var r = this.pastInput(), l = new Array(r.length + 1).join("-"); + return r + this.upcomingInput() + ` +` + l + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(r, l) { + var u, g, b; + if (this.options.backtrack_lexer && (b = { + 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 && (b.yylloc.range = this.yylloc.range.slice(0))), g = r[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 + r[0].length + }, this.yytext += r[0], this.match += r[0], this.matches = r, 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(r[0].length), this.matched += r[0], u = this.performAction.call(this, this.yy, this, l, this.conditionStack[this.conditionStack.length - 1]), this.done && this._input && (this.done = !1), u) + return u; + if (this._backtrack) { + for (var a in b) + this[a] = b[a]; + return !1; + } + return !1; + }, + // return next match in input + next: function() { + if (this.done) + return this.EOF; + this._input || (this.done = !0); + var r, l, u, g; + this._more || (this.yytext = "", this.match = ""); + for (var b = this._currentRules(), a = 0; a < b.length; a++) + if (u = this._input.match(this.rules[b[a]]), u && (!l || u[0].length > l[0].length)) { + if (l = u, g = a, this.options.backtrack_lexer) { + if (r = this.test_match(u, b[a]), r !== !1) + return r; + if (this._backtrack) { + l = !1; + continue; + } else + return !1; + } else if (!this.options.flex) + break; + } + return l ? (r = this.test_match(l, b[g]), r !== !1 ? r : !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 l = this.next(); + return l || this.lex(); + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function(l) { + this.conditionStack.push(l); + }, + // pop the previously active lexer condition state off the condition stack + popState: function() { + var l = this.conditionStack.length - 1; + return l > 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(l) { + return l = this.conditionStack.length - 1 - Math.abs(l || 0), l >= 0 ? this.conditionStack[l] : "INITIAL"; + }, + // alias for begin(condition) + pushState: function(l) { + this.begin(l); + }, + // return the number of states currently on the stack + stateStackSize: function() { + return this.conditionStack.length; + }, + options: { "case-insensitive": !0 }, + performAction: function(l, u, g, b) { + switch (g) { + case 0: + break; + case 1: + break; + case 2: + return this.popState(), 34; + case 3: + return this.popState(), 34; + case 4: + return 34; + case 5: + break; + case 6: + return 10; + case 7: + return this.pushState("acc_title"), 19; + case 8: + return this.popState(), "acc_title_value"; + case 9: + return this.pushState("acc_descr"), 21; + case 10: + return this.popState(), "acc_descr_value"; + case 11: + this.pushState("acc_descr_multiline"); + break; + case 12: + this.popState(); + break; + case 13: + return "acc_descr_multiline_value"; + case 14: + return 5; + case 15: + return 8; + case 16: + return this.pushState("axis_data"), "X_AXIS"; + case 17: + return this.pushState("axis_data"), "Y_AXIS"; + case 18: + return this.pushState("axis_band_data"), 24; + case 19: + return 31; + case 20: + return this.pushState("data"), 16; + case 21: + return this.pushState("data"), 18; + case 22: + return this.pushState("data_inner"), 24; + case 23: + return 27; + case 24: + return this.popState(), 26; + case 25: + this.popState(); + break; + case 26: + this.pushState("string"); + break; + case 27: + this.popState(); + break; + case 28: + return "STR"; + case 29: + return 24; + case 30: + return 26; + case 31: + return 43; + case 32: + return "COLON"; + case 33: + return 44; + case 34: + return 28; + case 35: + return 45; + case 36: + return 46; + case 37: + return 48; + case 38: + return 50; + case 39: + return 47; + case 40: + return 41; + case 41: + return 49; + case 42: + return 42; + case 43: + break; + case 44: + return 35; + case 45: + return 36; + } + }, + rules: [/^(?:%%(?!\{)[^\n]*)/i, /^(?:[^\}]%%[^\n]*)/i, /^(?:(\r?\n))/i, /^(?:(\r?\n))/i, /^(?:[\n\r]+)/i, /^(?:%%[^\n]*)/i, /^(?:title\b)/i, /^(?:accTitle\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*\{\s*)/i, /^(?:\{)/i, /^(?:[^\}]*)/i, /^(?:xychart-beta\b)/i, /^(?:(?:vertical|horizontal))/i, /^(?:x-axis\b)/i, /^(?:y-axis\b)/i, /^(?:\[)/i, /^(?:-->)/i, /^(?:line\b)/i, /^(?:bar\b)/i, /^(?:\[)/i, /^(?:[+-]?(?:\d+(?:\.\d+)?|\.\d+))/i, /^(?:\])/i, /^(?:(?:`\) \{ this\.pushState\(md_string\); \}\n\(\?:\(\?!`"\)\.\)\+ \{ return MD_STR; \}\n\(\?:`))/i, /^(?:["])/i, /^(?:["])/i, /^(?:[^"]*)/i, /^(?:\[)/i, /^(?:\])/i, /^(?:[A-Za-z]+)/i, /^(?::)/i, /^(?:\+)/i, /^(?:,)/i, /^(?:=)/i, /^(?:\*)/i, /^(?:#)/i, /^(?:[\_])/i, /^(?:\.)/i, /^(?:&)/i, /^(?:-)/i, /^(?:[0-9]+)/i, /^(?:\s+)/i, /^(?:;)/i, /^(?:$)/i], + conditions: { data_inner: { rules: [0, 1, 4, 5, 6, 7, 9, 11, 14, 15, 16, 17, 20, 21, 23, 24, 25, 26, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45], inclusive: !0 }, data: { rules: [0, 1, 3, 4, 5, 6, 7, 9, 11, 14, 15, 16, 17, 20, 21, 22, 25, 26, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45], inclusive: !0 }, axis_band_data: { rules: [0, 1, 4, 5, 6, 7, 9, 11, 14, 15, 16, 17, 20, 21, 24, 25, 26, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45], inclusive: !0 }, axis_data: { rules: [0, 1, 2, 4, 5, 6, 7, 9, 11, 14, 15, 16, 17, 18, 19, 20, 21, 23, 25, 26, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45], inclusive: !0 }, acc_descr_multiline: { rules: [12, 13], inclusive: !1 }, acc_descr: { rules: [10], inclusive: !1 }, acc_title: { rules: [8], inclusive: !1 }, title: { rules: [], inclusive: !1 }, md_string: { rules: [], inclusive: !1 }, string: { rules: [27, 28], inclusive: !1 }, INITIAL: { rules: [0, 1, 4, 5, 6, 7, 9, 11, 14, 15, 16, 17, 20, 21, 25, 26, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45], inclusive: !0 } } + }; + return V; + }(); + K.lexer = It; + function Z() { + this.yy = {}; + } + return Z.prototype = K, K.Parser = Z, new Z(); +}(); +nt.parser = nt; +const ti = nt; +function mt(e) { + return e.type === "bar"; +} +function _t(e) { + return e.type === "band"; +} +function N(e) { + return e.type === "linear"; +} +class kt { + constructor(t) { + this.parentGroup = t; + } + getMaxDimension(t, i) { + if (!this.parentGroup) + return { + width: t.reduce((o, c) => Math.max(c.length, o), 0) * i, + height: i + }; + const s = { + width: 0, + height: 0 + }, n = this.parentGroup.append("g").attr("visibility", "hidden").attr("font-size", i); + for (const o of t) { + const c = Qt(n, 1, o), f = c ? c.width : o.length * i, d = c ? c.height : i; + s.width = Math.max(s.width, f), s.height = Math.max(s.height, d); + } + return n.remove(), s; + } +} +const yt = 0.7, bt = 0.2; +class Rt { + constructor(t, i, s, n) { + this.axisConfig = t, this.title = i, this.textDimensionCalculator = s, this.axisThemeConfig = n, this.boundingRect = { x: 0, y: 0, width: 0, height: 0 }, this.axisPosition = "left", this.showTitle = !1, this.showLabel = !1, this.showTick = !1, this.showAxisLine = !1, this.outerPadding = 0, this.titleTextHeight = 0, this.labelTextHeight = 0, this.range = [0, 10], this.boundingRect = { x: 0, y: 0, width: 0, height: 0 }, this.axisPosition = "left"; + } + setRange(t) { + this.range = t, this.axisPosition === "left" || this.axisPosition === "right" ? this.boundingRect.height = t[1] - t[0] : this.boundingRect.width = t[1] - t[0], this.recalculateScale(); + } + getRange() { + return [this.range[0] + this.outerPadding, this.range[1] - this.outerPadding]; + } + setAxisPosition(t) { + this.axisPosition = t, this.setRange(this.range); + } + getTickDistance() { + const t = this.getRange(); + return Math.abs(t[0] - t[1]) / this.getTickValues().length; + } + getAxisOuterPadding() { + return this.outerPadding; + } + getLabelDimension() { + return this.textDimensionCalculator.getMaxDimension( + this.getTickValues().map((t) => t.toString()), + this.axisConfig.labelFontSize + ); + } + recalculateOuterPaddingToDrawBar() { + yt * this.getTickDistance() > this.outerPadding * 2 && (this.outerPadding = Math.floor(yt * this.getTickDistance() / 2)), this.recalculateScale(); + } + calculateSpaceIfDrawnHorizontally(t) { + let i = t.height; + if (this.axisConfig.showAxisLine && i > this.axisConfig.axisLineWidth && (i -= this.axisConfig.axisLineWidth, this.showAxisLine = !0), this.axisConfig.showLabel) { + const s = this.getLabelDimension(), n = bt * t.width; + this.outerPadding = Math.min(s.width / 2, n); + const o = s.height + this.axisConfig.labelPadding * 2; + this.labelTextHeight = s.height, o <= i && (i -= o, this.showLabel = !0); + } + if (this.axisConfig.showTick && i >= this.axisConfig.tickLength && (this.showTick = !0, i -= this.axisConfig.tickLength), this.axisConfig.showTitle && this.title) { + const s = this.textDimensionCalculator.getMaxDimension( + [this.title], + this.axisConfig.titleFontSize + ), n = s.height + this.axisConfig.titlePadding * 2; + this.titleTextHeight = s.height, n <= i && (i -= n, this.showTitle = !0); + } + this.boundingRect.width = t.width, this.boundingRect.height = t.height - i; + } + calculateSpaceIfDrawnVertical(t) { + let i = t.width; + if (this.axisConfig.showAxisLine && i > this.axisConfig.axisLineWidth && (i -= this.axisConfig.axisLineWidth, this.showAxisLine = !0), this.axisConfig.showLabel) { + const s = this.getLabelDimension(), n = bt * t.height; + this.outerPadding = Math.min(s.height / 2, n); + const o = s.width + this.axisConfig.labelPadding * 2; + o <= i && (i -= o, this.showLabel = !0); + } + if (this.axisConfig.showTick && i >= this.axisConfig.tickLength && (this.showTick = !0, i -= this.axisConfig.tickLength), this.axisConfig.showTitle && this.title) { + const s = this.textDimensionCalculator.getMaxDimension( + [this.title], + this.axisConfig.titleFontSize + ), n = s.height + this.axisConfig.titlePadding * 2; + this.titleTextHeight = s.height, n <= i && (i -= n, this.showTitle = !0); + } + this.boundingRect.width = t.width - i, this.boundingRect.height = t.height; + } + calculateSpace(t) { + return this.axisPosition === "left" || this.axisPosition === "right" ? this.calculateSpaceIfDrawnVertical(t) : this.calculateSpaceIfDrawnHorizontally(t), this.recalculateScale(), { + width: this.boundingRect.width, + height: this.boundingRect.height + }; + } + setBoundingBoxXY(t) { + this.boundingRect.x = t.x, this.boundingRect.y = t.y; + } + getDrawableElementsForLeftAxis() { + const t = []; + if (this.showAxisLine) { + const i = this.boundingRect.x + this.boundingRect.width - this.axisConfig.axisLineWidth / 2; + t.push({ + type: "path", + groupTexts: ["left-axis", "axisl-line"], + data: [ + { + path: `M ${i},${this.boundingRect.y} L ${i},${this.boundingRect.y + this.boundingRect.height} `, + strokeFill: this.axisThemeConfig.axisLineColor, + strokeWidth: this.axisConfig.axisLineWidth + } + ] + }); + } + if (this.showLabel && t.push({ + type: "text", + groupTexts: ["left-axis", "label"], + data: this.getTickValues().map((i) => ({ + text: i.toString(), + x: this.boundingRect.x + this.boundingRect.width - (this.showLabel ? this.axisConfig.labelPadding : 0) - (this.showTick ? this.axisConfig.tickLength : 0) - (this.showAxisLine ? this.axisConfig.axisLineWidth : 0), + y: this.getScaleValue(i), + fill: this.axisThemeConfig.labelColor, + fontSize: this.axisConfig.labelFontSize, + rotation: 0, + verticalPos: "middle", + horizontalPos: "right" + })) + }), this.showTick) { + const i = this.boundingRect.x + this.boundingRect.width - (this.showAxisLine ? this.axisConfig.axisLineWidth : 0); + t.push({ + type: "path", + groupTexts: ["left-axis", "ticks"], + data: this.getTickValues().map((s) => ({ + path: `M ${i},${this.getScaleValue(s)} L ${i - this.axisConfig.tickLength},${this.getScaleValue(s)}`, + strokeFill: this.axisThemeConfig.tickColor, + strokeWidth: this.axisConfig.tickWidth + })) + }); + } + return this.showTitle && t.push({ + type: "text", + groupTexts: ["left-axis", "title"], + data: [ + { + text: this.title, + x: this.boundingRect.x + this.axisConfig.titlePadding, + y: this.boundingRect.y + this.boundingRect.height / 2, + fill: this.axisThemeConfig.titleColor, + fontSize: this.axisConfig.titleFontSize, + rotation: 270, + verticalPos: "top", + horizontalPos: "center" + } + ] + }), t; + } + getDrawableElementsForBottomAxis() { + const t = []; + if (this.showAxisLine) { + const i = this.boundingRect.y + this.axisConfig.axisLineWidth / 2; + t.push({ + type: "path", + groupTexts: ["bottom-axis", "axis-line"], + data: [ + { + path: `M ${this.boundingRect.x},${i} L ${this.boundingRect.x + this.boundingRect.width},${i}`, + strokeFill: this.axisThemeConfig.axisLineColor, + strokeWidth: this.axisConfig.axisLineWidth + } + ] + }); + } + if (this.showLabel && t.push({ + type: "text", + groupTexts: ["bottom-axis", "label"], + data: this.getTickValues().map((i) => ({ + text: i.toString(), + x: this.getScaleValue(i), + y: this.boundingRect.y + this.axisConfig.labelPadding + (this.showTick ? this.axisConfig.tickLength : 0) + (this.showAxisLine ? this.axisConfig.axisLineWidth : 0), + fill: this.axisThemeConfig.labelColor, + fontSize: this.axisConfig.labelFontSize, + rotation: 0, + verticalPos: "top", + horizontalPos: "center" + })) + }), this.showTick) { + const i = this.boundingRect.y + (this.showAxisLine ? this.axisConfig.axisLineWidth : 0); + t.push({ + type: "path", + groupTexts: ["bottom-axis", "ticks"], + data: this.getTickValues().map((s) => ({ + path: `M ${this.getScaleValue(s)},${i} L ${this.getScaleValue(s)},${i + this.axisConfig.tickLength}`, + strokeFill: this.axisThemeConfig.tickColor, + strokeWidth: this.axisConfig.tickWidth + })) + }); + } + return this.showTitle && t.push({ + type: "text", + groupTexts: ["bottom-axis", "title"], + data: [ + { + text: this.title, + x: this.range[0] + (this.range[1] - this.range[0]) / 2, + y: this.boundingRect.y + this.boundingRect.height - this.axisConfig.titlePadding - this.titleTextHeight, + fill: this.axisThemeConfig.titleColor, + fontSize: this.axisConfig.titleFontSize, + rotation: 0, + verticalPos: "top", + horizontalPos: "center" + } + ] + }), t; + } + getDrawableElementsForTopAxis() { + const t = []; + if (this.showAxisLine) { + const i = this.boundingRect.y + this.boundingRect.height - this.axisConfig.axisLineWidth / 2; + t.push({ + type: "path", + groupTexts: ["top-axis", "axis-line"], + data: [ + { + path: `M ${this.boundingRect.x},${i} L ${this.boundingRect.x + this.boundingRect.width},${i}`, + strokeFill: this.axisThemeConfig.axisLineColor, + strokeWidth: this.axisConfig.axisLineWidth + } + ] + }); + } + if (this.showLabel && t.push({ + type: "text", + groupTexts: ["top-axis", "label"], + data: this.getTickValues().map((i) => ({ + text: i.toString(), + x: this.getScaleValue(i), + y: this.boundingRect.y + (this.showTitle ? this.titleTextHeight + this.axisConfig.titlePadding * 2 : 0) + this.axisConfig.labelPadding, + fill: this.axisThemeConfig.labelColor, + fontSize: this.axisConfig.labelFontSize, + rotation: 0, + verticalPos: "top", + horizontalPos: "center" + })) + }), this.showTick) { + const i = this.boundingRect.y; + t.push({ + type: "path", + groupTexts: ["top-axis", "ticks"], + data: this.getTickValues().map((s) => ({ + path: `M ${this.getScaleValue(s)},${i + this.boundingRect.height - (this.showAxisLine ? this.axisConfig.axisLineWidth : 0)} L ${this.getScaleValue(s)},${i + this.boundingRect.height - this.axisConfig.tickLength - (this.showAxisLine ? this.axisConfig.axisLineWidth : 0)}`, + strokeFill: this.axisThemeConfig.tickColor, + strokeWidth: this.axisConfig.tickWidth + })) + }); + } + return this.showTitle && t.push({ + type: "text", + groupTexts: ["top-axis", "title"], + data: [ + { + text: this.title, + x: this.boundingRect.x + this.boundingRect.width / 2, + y: this.boundingRect.y + this.axisConfig.titlePadding, + fill: this.axisThemeConfig.titleColor, + fontSize: this.axisConfig.titleFontSize, + rotation: 0, + verticalPos: "top", + horizontalPos: "center" + } + ] + }), t; + } + getDrawableElements() { + if (this.axisPosition === "left") + return this.getDrawableElementsForLeftAxis(); + if (this.axisPosition === "right") + throw Error("Drawing of right axis is not implemented"); + return this.axisPosition === "bottom" ? this.getDrawableElementsForBottomAxis() : this.axisPosition === "top" ? this.getDrawableElementsForTopAxis() : []; + } +} +class ii extends Rt { + constructor(t, i, s, n, o) { + super(t, n, o, i), this.categories = s, this.scale = st().domain(this.categories).range(this.getRange()); + } + setRange(t) { + super.setRange(t); + } + recalculateScale() { + this.scale = st().domain(this.categories).range(this.getRange()).paddingInner(1).paddingOuter(0).align(0.5), wt.trace("BandAxis axis final categories, range: ", this.categories, this.getRange()); + } + getTickValues() { + return this.categories; + } + getScaleValue(t) { + return this.scale(t) || this.getRange()[0]; + } +} +class ei extends Rt { + constructor(t, i, s, n, o) { + super(t, n, o, i), this.domain = s, this.scale = ft().domain(this.domain).range(this.getRange()); + } + getTickValues() { + return this.scale.ticks(); + } + recalculateScale() { + const t = [...this.domain]; + this.axisPosition === "left" && t.reverse(), this.scale = ft().domain(t).range(this.getRange()); + } + getScaleValue(t) { + return this.scale(t); + } +} +function At(e, t, i, s) { + const n = new kt(s); + return _t(e) ? new ii( + t, + i, + e.categories, + e.title, + n + ) : new ei( + t, + i, + [e.min, e.max], + e.title, + n + ); +} +class si { + constructor(t, i, s, n) { + this.textDimensionCalculator = t, this.chartConfig = i, this.chartData = s, this.chartThemeConfig = n, this.boundingRect = { + x: 0, + y: 0, + width: 0, + height: 0 + }, this.showChartTitle = !1; + } + setBoundingBoxXY(t) { + this.boundingRect.x = t.x, this.boundingRect.y = t.y; + } + calculateSpace(t) { + const i = this.textDimensionCalculator.getMaxDimension( + [this.chartData.title], + this.chartConfig.titleFontSize + ), s = Math.max(i.width, t.width), n = i.height + 2 * this.chartConfig.titlePadding; + return i.width <= s && i.height <= n && this.chartConfig.showTitle && this.chartData.title && (this.boundingRect.width = s, this.boundingRect.height = n, this.showChartTitle = !0), { + width: this.boundingRect.width, + height: this.boundingRect.height + }; + } + getDrawableElements() { + const t = []; + return this.showChartTitle && t.push({ + groupTexts: ["chart-title"], + type: "text", + data: [ + { + fontSize: this.chartConfig.titleFontSize, + text: this.chartData.title, + verticalPos: "middle", + horizontalPos: "center", + x: this.boundingRect.x + this.boundingRect.width / 2, + y: this.boundingRect.y + this.boundingRect.height / 2, + fill: this.chartThemeConfig.titleColor, + rotation: 0 + } + ] + }), t; + } +} +function ni(e, t, i, s) { + const n = new kt(s); + return new si(n, e, t, i); +} +class ai { + constructor(t, i, s, n, o) { + this.plotData = t, this.xAxis = i, this.yAxis = s, this.orientation = n, this.plotIndex = o; + } + getDrawableElement() { + const t = this.plotData.data.map((s) => [ + this.xAxis.getScaleValue(s[0]), + this.yAxis.getScaleValue(s[1]) + ]); + let i; + return this.orientation === "horizontal" ? i = pt().y((s) => s[0]).x((s) => s[1])(t) : i = pt().x((s) => s[0]).y((s) => s[1])(t), i ? [ + { + groupTexts: ["plot", `line-plot-${this.plotIndex}`], + type: "path", + data: [ + { + path: i, + strokeFill: this.plotData.strokeFill, + strokeWidth: this.plotData.strokeWidth + } + ] + } + ] : []; + } +} +class oi { + constructor(t, i, s, n, o, c) { + this.barData = t, this.boundingRect = i, this.xAxis = s, this.yAxis = n, this.orientation = o, this.plotIndex = c; + } + getDrawableElement() { + const t = this.barData.data.map((o) => [ + this.xAxis.getScaleValue(o[0]), + this.yAxis.getScaleValue(o[1]) + ]), i = 0.05, s = Math.min(this.xAxis.getAxisOuterPadding() * 2, this.xAxis.getTickDistance()) * (1 - i), n = s / 2; + return this.orientation === "horizontal" ? [ + { + groupTexts: ["plot", `bar-plot-${this.plotIndex}`], + type: "rect", + data: t.map((o) => ({ + x: this.boundingRect.x, + y: o[0] - n, + height: s, + width: o[1] - this.boundingRect.x, + fill: this.barData.fill, + strokeWidth: 0, + strokeFill: this.barData.fill + })) + } + ] : [ + { + groupTexts: ["plot", `bar-plot-${this.plotIndex}`], + type: "rect", + data: t.map((o) => ({ + x: o[0] - n, + y: o[1], + width: s, + height: this.boundingRect.y + this.boundingRect.height - o[1], + fill: this.barData.fill, + strokeWidth: 0, + strokeFill: this.barData.fill + })) + } + ]; + } +} +class ri { + constructor(t, i, s) { + this.chartConfig = t, this.chartData = i, this.chartThemeConfig = s, this.boundingRect = { + x: 0, + y: 0, + width: 0, + height: 0 + }; + } + setAxes(t, i) { + this.xAxis = t, this.yAxis = i; + } + setBoundingBoxXY(t) { + this.boundingRect.x = t.x, this.boundingRect.y = t.y; + } + calculateSpace(t) { + return this.boundingRect.width = t.width, this.boundingRect.height = t.height, { + width: this.boundingRect.width, + height: this.boundingRect.height + }; + } + getDrawableElements() { + if (!(this.xAxis && this.yAxis)) + throw Error("Axes must be passed to render Plots"); + const t = []; + for (const [i, s] of this.chartData.plots.entries()) + switch (s.type) { + case "line": + { + const n = new ai( + s, + this.xAxis, + this.yAxis, + this.chartConfig.chartOrientation, + i + ); + t.push(...n.getDrawableElement()); + } + break; + case "bar": + { + const n = new oi( + s, + this.boundingRect, + this.xAxis, + this.yAxis, + this.chartConfig.chartOrientation, + i + ); + t.push(...n.getDrawableElement()); + } + break; + } + return t; + } +} +function hi(e, t, i) { + return new ri(e, t, i); +} +class li { + constructor(t, i, s, n) { + this.chartConfig = t, this.chartData = i, this.componentStore = { + title: ni(t, i, s, n), + plot: hi(t, i, s), + xAxis: At( + i.xAxis, + t.xAxis, + { + titleColor: s.xAxisTitleColor, + labelColor: s.xAxisLabelColor, + tickColor: s.xAxisTickColor, + axisLineColor: s.xAxisLineColor + }, + n + ), + yAxis: At( + i.yAxis, + t.yAxis, + { + titleColor: s.yAxisTitleColor, + labelColor: s.yAxisLabelColor, + tickColor: s.yAxisTickColor, + axisLineColor: s.yAxisLineColor + }, + n + ) + }; + } + calculateVerticalSpace() { + let t = this.chartConfig.width, i = this.chartConfig.height, s = 0, n = 0, o = Math.floor(t * this.chartConfig.plotReservedSpacePercent / 100), c = Math.floor( + i * this.chartConfig.plotReservedSpacePercent / 100 + ), f = this.componentStore.plot.calculateSpace({ + width: o, + height: c + }); + t -= f.width, i -= f.height, f = this.componentStore.title.calculateSpace({ + width: this.chartConfig.width, + height: i + }), n = f.height, i -= f.height, this.componentStore.xAxis.setAxisPosition("bottom"), f = this.componentStore.xAxis.calculateSpace({ + width: t, + height: i + }), i -= f.height, this.componentStore.yAxis.setAxisPosition("left"), f = this.componentStore.yAxis.calculateSpace({ + width: t, + height: i + }), s = f.width, t -= f.width, t > 0 && (o += t, t = 0), i > 0 && (c += i, i = 0), this.componentStore.plot.calculateSpace({ + width: o, + height: c + }), this.componentStore.plot.setBoundingBoxXY({ x: s, y: n }), this.componentStore.xAxis.setRange([s, s + o]), this.componentStore.xAxis.setBoundingBoxXY({ x: s, y: n + c }), this.componentStore.yAxis.setRange([n, n + c]), this.componentStore.yAxis.setBoundingBoxXY({ x: 0, y: n }), this.chartData.plots.some((d) => mt(d)) && this.componentStore.xAxis.recalculateOuterPaddingToDrawBar(); + } + calculateHorizontalSpace() { + let t = this.chartConfig.width, i = this.chartConfig.height, s = 0, n = 0, o = 0, c = Math.floor(t * this.chartConfig.plotReservedSpacePercent / 100), f = Math.floor( + i * this.chartConfig.plotReservedSpacePercent / 100 + ), d = this.componentStore.plot.calculateSpace({ + width: c, + height: f + }); + t -= d.width, i -= d.height, d = this.componentStore.title.calculateSpace({ + width: this.chartConfig.width, + height: i + }), s = d.height, i -= d.height, this.componentStore.xAxis.setAxisPosition("left"), d = this.componentStore.xAxis.calculateSpace({ + width: t, + height: i + }), t -= d.width, n = d.width, this.componentStore.yAxis.setAxisPosition("top"), d = this.componentStore.yAxis.calculateSpace({ + width: t, + height: i + }), i -= d.height, o = s + d.height, t > 0 && (c += t, t = 0), i > 0 && (f += i, i = 0), this.componentStore.plot.calculateSpace({ + width: c, + height: f + }), this.componentStore.plot.setBoundingBoxXY({ x: n, y: o }), this.componentStore.yAxis.setRange([n, n + c]), this.componentStore.yAxis.setBoundingBoxXY({ x: n, y: s }), this.componentStore.xAxis.setRange([o, o + f]), this.componentStore.xAxis.setBoundingBoxXY({ x: 0, y: o }), this.chartData.plots.some((R) => mt(R)) && this.componentStore.xAxis.recalculateOuterPaddingToDrawBar(); + } + calculateSpace() { + this.chartConfig.chartOrientation === "horizontal" ? this.calculateHorizontalSpace() : this.calculateVerticalSpace(); + } + getDrawableElement() { + this.calculateSpace(); + const t = []; + this.componentStore.plot.setAxes(this.componentStore.xAxis, this.componentStore.yAxis); + for (const i of Object.values(this.componentStore)) + t.push(...i.getDrawableElements()); + return t; + } +} +class ci { + static build(t, i, s, n) { + return new li(t, i, s, n).getDrawableElement(); + } +} +let X = 0, Tt, Y = Pt(), H = Dt(), y = Lt(), at = H.plotColorPalette.split(",").map((e) => e.trim()), G = !1, rt = !1; +function Dt() { + const e = Ht(), t = ot(); + return Ct(e.xyChart, t.themeVariables.xyChart); +} +function Pt() { + const e = ot(); + return Ct( + Ut.xyChart, + e.xyChart + ); +} +function Lt() { + return { + yAxis: { + type: "linear", + title: "", + min: 1 / 0, + max: -1 / 0 + }, + xAxis: { + type: "band", + title: "", + categories: [] + }, + title: "", + plots: [] + }; +} +function ht(e) { + const t = ot(); + return qt(e.trim(), t); +} +function ui(e) { + Tt = e; +} +function gi(e) { + e === "horizontal" ? Y.chartOrientation = "horizontal" : Y.chartOrientation = "vertical"; +} +function xi(e) { + y.xAxis.title = ht(e.text); +} +function Et(e, t) { + y.xAxis = { type: "linear", title: y.xAxis.title, min: e, max: t }, G = !0; +} +function di(e) { + y.xAxis = { + type: "band", + title: y.xAxis.title, + categories: e.map((t) => ht(t.text)) + }, G = !0; +} +function fi(e) { + y.yAxis.title = ht(e.text); +} +function pi(e, t) { + y.yAxis = { type: "linear", title: y.yAxis.title, min: e, max: t }, rt = !0; +} +function mi(e) { + const t = Math.min(...e), i = Math.max(...e), s = N(y.yAxis) ? y.yAxis.min : 1 / 0, n = N(y.yAxis) ? y.yAxis.max : -1 / 0; + y.yAxis = { + type: "linear", + title: y.yAxis.title, + min: Math.min(s, t), + max: Math.max(n, i) + }; +} +function vt(e) { + let t = []; + if (e.length === 0) + return t; + if (!G) { + const i = N(y.xAxis) ? y.xAxis.min : 1 / 0, s = N(y.xAxis) ? y.xAxis.max : -1 / 0; + Et(Math.min(i, 1), Math.max(s, e.length)); + } + if (rt || mi(e), _t(y.xAxis) && (t = y.xAxis.categories.map((i, s) => [i, e[s]])), N(y.xAxis)) { + const i = y.xAxis.min, s = y.xAxis.max, n = (s - i + 1) / e.length, o = []; + for (let c = i; c <= s; c += n) + o.push(`${c}`); + t = o.map((c, f) => [c, e[f]]); + } + return t; +} +function Mt(e) { + return at[e === 0 ? 0 : e % at.length]; +} +function yi(e, t) { + const i = vt(t); + y.plots.push({ + type: "line", + strokeFill: Mt(X), + strokeWidth: 2, + data: i + }), X++; +} +function bi(e, t) { + const i = vt(t); + y.plots.push({ + type: "bar", + fill: Mt(X), + data: i + }), X++; +} +function Ai() { + if (y.plots.length === 0) + throw Error("No Plot to render, please provide a plot with some data"); + return y.title = St(), ci.build(Y, y, H, Tt); +} +function wi() { + return H; +} +function Si() { + return Y; +} +const Ci = function() { + $t(), X = 0, Y = Pt(), y = Lt(), H = Dt(), at = H.plotColorPalette.split(",").map((e) => e.trim()), G = !1, rt = !1; +}, _i = { + getDrawableElem: Ai, + clear: Ci, + setAccTitle: zt, + getAccTitle: Ft, + setDiagramTitle: Nt, + getDiagramTitle: St, + getAccDescription: Xt, + setAccDescription: Yt, + setOrientation: gi, + setXAxisTitle: xi, + setXAxisRangeData: Et, + setXAxisBand: di, + setYAxisTitle: fi, + setYAxisRangeData: pi, + setLineData: yi, + setBarData: bi, + setTmpSVGG: ui, + getChartThemeConfig: wi, + getChartConfig: Si +}, ki = (e, t, i, s) => { + const n = s.db, o = n.getChartThemeConfig(), c = n.getChartConfig(); + function f(p) { + return p === "top" ? "text-before-edge" : "middle"; + } + function d(p) { + return p === "left" ? "start" : p === "right" ? "end" : "middle"; + } + function R(p) { + return `translate(${p.x}, ${p.y}) rotate(${p.rotation || 0})`; + } + wt.debug(`Rendering xychart chart +` + e); + const _ = jt(t), A = _.append("g").attr("class", "main"), m = A.append("rect").attr("width", c.width).attr("height", c.height).attr("class", "background"); + Gt(_, c.height, c.width, !0), _.attr("viewBox", `0 0 ${c.width} ${c.height}`), m.attr("fill", o.backgroundColor), n.setTmpSVGG(_.append("g").attr("class", "mermaid-tmp-group")); + const T = n.getDrawableElem(), S = {}; + function P(p) { + let C = A, h = ""; + for (const [L] of p.entries()) { + let z = A; + L > 0 && S[h] && (z = S[h]), h += p[L], C = S[h], C || (C = S[h] = z.append("g").attr("class", p[L])); + } + return C; + } + for (const p of T) { + if (p.data.length === 0) + continue; + const C = P(p.groupTexts); + switch (p.type) { + case "rect": + C.selectAll("rect").data(p.data).enter().append("rect").attr("x", (h) => h.x).attr("y", (h) => h.y).attr("width", (h) => h.width).attr("height", (h) => h.height).attr("fill", (h) => h.fill).attr("stroke", (h) => h.strokeFill).attr("stroke-width", (h) => h.strokeWidth); + break; + case "text": + C.selectAll("text").data(p.data).enter().append("text").attr("x", 0).attr("y", 0).attr("fill", (h) => h.fill).attr("font-size", (h) => h.fontSize).attr("dominant-baseline", (h) => f(h.verticalPos)).attr("text-anchor", (h) => d(h.horizontalPos)).attr("transform", (h) => R(h)).text((h) => h.text); + break; + case "path": + C.selectAll("path").data(p.data).enter().append("path").attr("d", (h) => h.path).attr("fill", (h) => h.fill ? h.fill : "none").attr("stroke", (h) => h.strokeFill).attr("stroke-width", (h) => h.strokeWidth); + break; + } + } +}, Ri = { + draw: ki +}, Vi = { + parser: ti, + db: _i, + renderer: Ri +}; +export { + Vi as diagram +}; diff --git a/0.6.0/js/mermaid/xychartDiagram-f11f50a6.js b/0.6.0/js/mermaid/xychartDiagram-f11f50a6.js new file mode 100644 index 0000000..31a016d --- /dev/null +++ b/0.6.0/js/mermaid/xychartDiagram-f11f50a6.js @@ -0,0 +1,1745 @@ +import { l as log, s as setAccTitle, g as getAccTitle, q as setDiagramTitle, t as getDiagramTitle, a as getAccDescription, b as setAccDescription, E as getThemeVariables, F as getConfig, C as cleanAndMerge, B as defaultConfig, v as clear$1, d as sanitizeText, A as selectSvgElement, i as configureSvgSize } from "./mermaid-6dc72991.js"; +import { c as computeDimensionOfText } from "./createText-ca0c5216.js"; +import { scaleBand, scaleLinear, line } from "d3"; +import "ts-dedent"; +import "dayjs"; +import "@braintree/sanitize-url"; +import "dompurify"; +import "khroma"; +import "lodash-es/memoize.js"; +import "lodash-es/merge.js"; +import "stylis"; +import "lodash-es/isEmpty.js"; +import "mdast-util-from-markdown"; +var parser = function() { + var o = function(k, v, o2, l) { + for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) + ; + return o2; + }, $V0 = [1, 10, 12, 14, 16, 18, 19, 21, 23], $V1 = [2, 6], $V2 = [1, 3], $V3 = [1, 5], $V4 = [1, 6], $V5 = [1, 7], $V6 = [1, 5, 10, 12, 14, 16, 18, 19, 21, 23, 34, 35, 36], $V7 = [1, 25], $V8 = [1, 26], $V9 = [1, 28], $Va = [1, 29], $Vb = [1, 30], $Vc = [1, 31], $Vd = [1, 32], $Ve = [1, 33], $Vf = [1, 34], $Vg = [1, 35], $Vh = [1, 36], $Vi = [1, 37], $Vj = [1, 43], $Vk = [1, 42], $Vl = [1, 47], $Vm = [1, 50], $Vn = [1, 10, 12, 14, 16, 18, 19, 21, 23, 34, 35, 36], $Vo = [1, 10, 12, 14, 16, 18, 19, 21, 23, 24, 26, 27, 28, 34, 35, 36], $Vp = [1, 10, 12, 14, 16, 18, 19, 21, 23, 24, 26, 27, 28, 34, 35, 36, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50], $Vq = [1, 64]; + var parser2 = { + trace: function trace() { + }, + yy: {}, + symbols_: { "error": 2, "start": 3, "eol": 4, "XYCHART": 5, "chartConfig": 6, "document": 7, "CHART_ORIENTATION": 8, "statement": 9, "title": 10, "text": 11, "X_AXIS": 12, "parseXAxis": 13, "Y_AXIS": 14, "parseYAxis": 15, "LINE": 16, "plotData": 17, "BAR": 18, "acc_title": 19, "acc_title_value": 20, "acc_descr": 21, "acc_descr_value": 22, "acc_descr_multiline_value": 23, "SQUARE_BRACES_START": 24, "commaSeparatedNumbers": 25, "SQUARE_BRACES_END": 26, "NUMBER_WITH_DECIMAL": 27, "COMMA": 28, "xAxisData": 29, "bandData": 30, "ARROW_DELIMITER": 31, "commaSeparatedTexts": 32, "yAxisData": 33, "NEWLINE": 34, "SEMI": 35, "EOF": 36, "alphaNum": 37, "STR": 38, "MD_STR": 39, "alphaNumToken": 40, "AMP": 41, "NUM": 42, "ALPHA": 43, "PLUS": 44, "EQUALS": 45, "MULT": 46, "DOT": 47, "BRKT": 48, "MINUS": 49, "UNDERSCORE": 50, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 5: "XYCHART", 8: "CHART_ORIENTATION", 10: "title", 12: "X_AXIS", 14: "Y_AXIS", 16: "LINE", 18: "BAR", 19: "acc_title", 20: "acc_title_value", 21: "acc_descr", 22: "acc_descr_value", 23: "acc_descr_multiline_value", 24: "SQUARE_BRACES_START", 26: "SQUARE_BRACES_END", 27: "NUMBER_WITH_DECIMAL", 28: "COMMA", 31: "ARROW_DELIMITER", 34: "NEWLINE", 35: "SEMI", 36: "EOF", 38: "STR", 39: "MD_STR", 41: "AMP", 42: "NUM", 43: "ALPHA", 44: "PLUS", 45: "EQUALS", 46: "MULT", 47: "DOT", 48: "BRKT", 49: "MINUS", 50: "UNDERSCORE" }, + productions_: [0, [3, 2], [3, 3], [3, 2], [3, 1], [6, 1], [7, 0], [7, 2], [9, 2], [9, 2], [9, 2], [9, 2], [9, 2], [9, 3], [9, 2], [9, 3], [9, 2], [9, 2], [9, 1], [17, 3], [25, 3], [25, 1], [13, 1], [13, 2], [13, 1], [29, 1], [29, 3], [30, 3], [32, 3], [32, 1], [15, 1], [15, 2], [15, 1], [33, 3], [4, 1], [4, 1], [4, 1], [11, 1], [11, 1], [11, 1], [37, 1], [37, 2], [40, 1], [40, 1], [40, 1], [40, 1], [40, 1], [40, 1], [40, 1], [40, 1], [40, 1], [40, 1]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) { + var $0 = $$.length - 1; + switch (yystate) { + case 5: + yy.setOrientation($$[$0]); + break; + case 9: + yy.setDiagramTitle($$[$0].text.trim()); + break; + case 12: + yy.setLineData({ text: "", type: "text" }, $$[$0]); + break; + case 13: + yy.setLineData($$[$0 - 1], $$[$0]); + break; + case 14: + yy.setBarData({ text: "", type: "text" }, $$[$0]); + break; + case 15: + yy.setBarData($$[$0 - 1], $$[$0]); + break; + case 16: + this.$ = $$[$0].trim(); + yy.setAccTitle(this.$); + break; + case 17: + case 18: + this.$ = $$[$0].trim(); + yy.setAccDescription(this.$); + break; + case 19: + this.$ = $$[$0 - 1]; + break; + case 20: + this.$ = [Number($$[$0 - 2]), ...$$[$0]]; + break; + case 21: + this.$ = [Number($$[$0])]; + break; + case 22: + yy.setXAxisTitle($$[$0]); + break; + case 23: + yy.setXAxisTitle($$[$0 - 1]); + break; + case 24: + yy.setXAxisTitle({ type: "text", text: "" }); + break; + case 25: + yy.setXAxisBand($$[$0]); + break; + case 26: + yy.setXAxisRangeData(Number($$[$0 - 2]), Number($$[$0])); + break; + case 27: + this.$ = $$[$0 - 1]; + break; + case 28: + this.$ = [$$[$0 - 2], ...$$[$0]]; + break; + case 29: + this.$ = [$$[$0]]; + break; + case 30: + yy.setYAxisTitle($$[$0]); + break; + case 31: + yy.setYAxisTitle($$[$0 - 1]); + break; + case 32: + yy.setYAxisTitle({ type: "text", text: "" }); + break; + case 33: + yy.setYAxisRangeData(Number($$[$0 - 2]), Number($$[$0])); + break; + case 37: + this.$ = { text: $$[$0], type: "text" }; + break; + case 38: + this.$ = { text: $$[$0], type: "text" }; + break; + case 39: + this.$ = { text: $$[$0], type: "markdown" }; + break; + case 40: + this.$ = $$[$0]; + break; + case 41: + this.$ = $$[$0 - 1] + "" + $$[$0]; + break; + } + }, + table: [o($V0, $V1, { 3: 1, 4: 2, 7: 4, 5: $V2, 34: $V3, 35: $V4, 36: $V5 }), { 1: [3] }, o($V0, $V1, { 4: 2, 7: 4, 3: 8, 5: $V2, 34: $V3, 35: $V4, 36: $V5 }), o($V0, $V1, { 4: 2, 7: 4, 6: 9, 3: 10, 5: $V2, 8: [1, 11], 34: $V3, 35: $V4, 36: $V5 }), { 1: [2, 4], 9: 12, 10: [1, 13], 12: [1, 14], 14: [1, 15], 16: [1, 16], 18: [1, 17], 19: [1, 18], 21: [1, 19], 23: [1, 20] }, o($V6, [2, 34]), o($V6, [2, 35]), o($V6, [2, 36]), { 1: [2, 1] }, o($V0, $V1, { 4: 2, 7: 4, 3: 21, 5: $V2, 34: $V3, 35: $V4, 36: $V5 }), { 1: [2, 3] }, o($V6, [2, 5]), o($V0, [2, 7], { 4: 22, 34: $V3, 35: $V4, 36: $V5 }), { 11: 23, 37: 24, 38: $V7, 39: $V8, 40: 27, 41: $V9, 42: $Va, 43: $Vb, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi }, { 11: 39, 13: 38, 24: $Vj, 27: $Vk, 29: 40, 30: 41, 37: 24, 38: $V7, 39: $V8, 40: 27, 41: $V9, 42: $Va, 43: $Vb, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi }, { 11: 45, 15: 44, 27: $Vl, 33: 46, 37: 24, 38: $V7, 39: $V8, 40: 27, 41: $V9, 42: $Va, 43: $Vb, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi }, { 11: 49, 17: 48, 24: $Vm, 37: 24, 38: $V7, 39: $V8, 40: 27, 41: $V9, 42: $Va, 43: $Vb, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi }, { 11: 52, 17: 51, 24: $Vm, 37: 24, 38: $V7, 39: $V8, 40: 27, 41: $V9, 42: $Va, 43: $Vb, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi }, { 20: [1, 53] }, { 22: [1, 54] }, o($Vn, [2, 18]), { 1: [2, 2] }, o($Vn, [2, 8]), o($Vn, [2, 9]), o($Vo, [2, 37], { 40: 55, 41: $V9, 42: $Va, 43: $Vb, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi }), o($Vo, [2, 38]), o($Vo, [2, 39]), o($Vp, [2, 40]), o($Vp, [2, 42]), o($Vp, [2, 43]), o($Vp, [2, 44]), o($Vp, [2, 45]), o($Vp, [2, 46]), o($Vp, [2, 47]), o($Vp, [2, 48]), o($Vp, [2, 49]), o($Vp, [2, 50]), o($Vp, [2, 51]), o($Vn, [2, 10]), o($Vn, [2, 22], { 30: 41, 29: 56, 24: $Vj, 27: $Vk }), o($Vn, [2, 24]), o($Vn, [2, 25]), { 31: [1, 57] }, { 11: 59, 32: 58, 37: 24, 38: $V7, 39: $V8, 40: 27, 41: $V9, 42: $Va, 43: $Vb, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi }, o($Vn, [2, 11]), o($Vn, [2, 30], { 33: 60, 27: $Vl }), o($Vn, [2, 32]), { 31: [1, 61] }, o($Vn, [2, 12]), { 17: 62, 24: $Vm }, { 25: 63, 27: $Vq }, o($Vn, [2, 14]), { 17: 65, 24: $Vm }, o($Vn, [2, 16]), o($Vn, [2, 17]), o($Vp, [2, 41]), o($Vn, [2, 23]), { 27: [1, 66] }, { 26: [1, 67] }, { 26: [2, 29], 28: [1, 68] }, o($Vn, [2, 31]), { 27: [1, 69] }, o($Vn, [2, 13]), { 26: [1, 70] }, { 26: [2, 21], 28: [1, 71] }, o($Vn, [2, 15]), o($Vn, [2, 26]), o($Vn, [2, 27]), { 11: 59, 32: 72, 37: 24, 38: $V7, 39: $V8, 40: 27, 41: $V9, 42: $Va, 43: $Vb, 44: $Vc, 45: $Vd, 46: $Ve, 47: $Vf, 48: $Vg, 49: $Vh, 50: $Vi }, o($Vn, [2, 33]), o($Vn, [2, 19]), { 25: 73, 27: $Vq }, { 26: [2, 28] }, { 26: [2, 20] }], + defaultActions: { 8: [2, 1], 10: [2, 3], 21: [2, 2], 72: [2, 28], 73: [2, 20] }, + parseError: function parseError(str, hash) { + if (hash.recoverable) { + this.trace(str); + } else { + var error = new Error(str); + error.hash = hash; + throw error; + } + }, + parse: function parse(input) { + var self = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1; + var args = lstack.slice.call(arguments, 1); + var lexer2 = Object.create(this.lexer); + var sharedState = { yy: {} }; + for (var k in this.yy) { + if (Object.prototype.hasOwnProperty.call(this.yy, k)) { + sharedState.yy[k] = this.yy[k]; + } + } + lexer2.setInput(input, sharedState.yy); + sharedState.yy.lexer = lexer2; + sharedState.yy.parser = this; + if (typeof lexer2.yylloc == "undefined") { + lexer2.yylloc = {}; + } + var yyloc = lexer2.yylloc; + lstack.push(yyloc); + var ranges = lexer2.options && lexer2.options.ranges; + if (typeof sharedState.yy.parseError === "function") { + this.parseError = sharedState.yy.parseError; + } else { + this.parseError = Object.getPrototypeOf(this).parseError; + } + function lex() { + var token; + token = tstack.pop() || lexer2.lex() || EOF; + if (typeof token !== "number") { + if (token instanceof Array) { + tstack = token; + token = tstack.pop(); + } + token = self.symbols_[token] || token; + } + return token; + } + var symbol, state, action, r, yyval = {}, p, len, newState, expected; + while (true) { + state = stack[stack.length - 1]; + if (this.defaultActions[state]) { + action = this.defaultActions[state]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex(); + } + action = table[state] && table[state][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + expected = []; + for (p in table[state]) { + if (this.terminals_[p] && p > TERROR) { + expected.push("'" + this.terminals_[p] + "'"); + } + } + if (lexer2.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { + text: lexer2.match, + token: this.terminals_[symbol] || symbol, + line: lexer2.yylineno, + loc: yyloc, + expected + }); + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(lexer2.yytext); + lstack.push(lexer2.yylloc); + stack.push(action[1]); + symbol = null; + { + yyleng = lexer2.yyleng; + yytext = lexer2.yytext; + yylineno = lexer2.yylineno; + yyloc = lexer2.yylloc; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { + first_line: lstack[lstack.length - (len || 1)].first_line, + last_line: lstack[lstack.length - 1].last_line, + first_column: lstack[lstack.length - (len || 1)].first_column, + last_column: lstack[lstack.length - 1].last_column + }; + if (ranges) { + yyval._$.range = [ + lstack[lstack.length - (len || 1)].range[0], + lstack[lstack.length - 1].range[1] + ]; + } + r = this.performAction.apply(yyval, [ + yytext, + yyleng, + yylineno, + sharedState.yy, + action[1], + vstack, + lstack + ].concat(args)); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + var lexer = function() { + var lexer2 = { + EOF: 1, + parseError: function parseError(str, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str, hash); + } else { + throw new Error(str); + } + }, + // resets the lexer, sets new input + setInput: function(input, yy) { + this.yy = yy || this.yy || {}; + this._input = input; + this._more = this._backtrack = this.done = false; + 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 + }; + if (this.options.ranges) { + this.yylloc.range = [0, 0]; + } + this.offset = 0; + return this; + }, + // consumes and returns one char from the input + input: function() { + var ch = this._input[0]; + this.yytext += ch; + this.yyleng++; + this.offset++; + this.match += ch; + this.matched += ch; + var lines = ch.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) { + this.yylloc.range[1]++; + } + this._input = this._input.slice(1); + return ch; + }, + // unshifts one char (or a string) into the input + unput: function(ch) { + var len = ch.length; + var lines = ch.split(/(?:\r\n?|\n)/g); + this._input = ch + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len); + this.offset -= len; + var oldLines = 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); + if (lines.length - 1) { + this.yylineno -= lines.length - 1; + } + var r = this.yylloc.range; + this.yylloc = { + first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + this.yyleng = this.yytext.length; + return this; + }, + // When called from action, caches matched text and appends it on next action + more: function() { + this._more = true; + return 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 = true; + } 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).\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + return this; + }, + // retain first n characters of the match + less: function(n) { + this.unput(this.match.slice(n)); + }, + // displays already matched input, i.e. for error messages + pastInput: function() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, ""); + }, + // displays upcoming input, i.e. for error messages + upcomingInput: function() { + var next = this.match; + if (next.length < 20) { + next += this._input.substr(0, 20 - next.length); + } + return (next.substr(0, 20) + (next.length > 20 ? "..." : "")).replace(/\n/g, ""); + }, + // displays the character position where the lexing error occurred, i.e. for error messages + showPosition: function() { + var pre = this.pastInput(); + var c = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c + "^"; + }, + // test the lexed token: return FALSE when not a match, otherwise return token + test_match: function(match, indexed_rule) { + var token, lines, backup; + if (this.options.backtrack_lexer) { + backup = { + 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 + }; + if (this.options.ranges) { + backup.yylloc.range = this.yylloc.range.slice(0); + } + } + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno += lines.length; + } + this.yylloc = { + first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length + }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._backtrack = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) { + this.done = false; + } + if (token) { + return token; + } else if (this._backtrack) { + for (var k in backup) { + this[k] = backup[k]; + } + return false; + } + return false; + }, + // return next match in input + next: function() { + if (this.done) { + return this.EOF; + } + if (!this._input) { + this.done = true; + } + var token, match, tempMatch, index; + if (!this._more) { + this.yytext = ""; + this.match = ""; + } + var rules = this._currentRules(); + for (var i = 0; i < rules.length; i++) { + tempMatch = this._input.match(this.rules[rules[i]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index = i; + if (this.options.backtrack_lexer) { + token = this.test_match(tempMatch, rules[i]); + if (token !== false) { + return token; + } else if (this._backtrack) { + match = false; + continue; + } else { + return false; + } + } else if (!this.options.flex) { + break; + } + } + } + if (match) { + token = this.test_match(match, rules[index]); + if (token !== false) { + return token; + } + return false; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), { + text: "", + token: null, + line: this.yylineno + }); + } + }, + // return next match that has a token + lex: function lex() { + var r = this.next(); + if (r) { + return r; + } else { + return this.lex(); + } + }, + // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + // pop the previously active lexer condition state off the condition stack + popState: function popState() { + var n = this.conditionStack.length - 1; + if (n > 0) { + return this.conditionStack.pop(); + } else { + return this.conditionStack[0]; + } + }, + // produce the lexer rule set which is active for the currently active lexer condition state + _currentRules: function _currentRules() { + if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + } else { + return 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 topState(n) { + n = this.conditionStack.length - 1 - Math.abs(n || 0); + if (n >= 0) { + return this.conditionStack[n]; + } else { + return "INITIAL"; + } + }, + // alias for begin(condition) + pushState: function pushState(condition) { + this.begin(condition); + }, + // return the number of states currently on the stack + stateStackSize: function stateStackSize() { + return this.conditionStack.length; + }, + options: { "case-insensitive": true }, + performAction: function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) { + switch ($avoiding_name_collisions) { + case 0: + break; + case 1: + break; + case 2: + this.popState(); + return 34; + case 3: + this.popState(); + return 34; + case 4: + return 34; + case 5: + break; + case 6: + return 10; + case 7: + this.pushState("acc_title"); + return 19; + case 8: + this.popState(); + return "acc_title_value"; + case 9: + this.pushState("acc_descr"); + return 21; + case 10: + this.popState(); + return "acc_descr_value"; + case 11: + this.pushState("acc_descr_multiline"); + break; + case 12: + this.popState(); + break; + case 13: + return "acc_descr_multiline_value"; + case 14: + return 5; + case 15: + return 8; + case 16: + this.pushState("axis_data"); + return "X_AXIS"; + case 17: + this.pushState("axis_data"); + return "Y_AXIS"; + case 18: + this.pushState("axis_band_data"); + return 24; + case 19: + return 31; + case 20: + this.pushState("data"); + return 16; + case 21: + this.pushState("data"); + return 18; + case 22: + this.pushState("data_inner"); + return 24; + case 23: + return 27; + case 24: + this.popState(); + return 26; + case 25: + this.popState(); + break; + case 26: + this.pushState("string"); + break; + case 27: + this.popState(); + break; + case 28: + return "STR"; + case 29: + return 24; + case 30: + return 26; + case 31: + return 43; + case 32: + return "COLON"; + case 33: + return 44; + case 34: + return 28; + case 35: + return 45; + case 36: + return 46; + case 37: + return 48; + case 38: + return 50; + case 39: + return 47; + case 40: + return 41; + case 41: + return 49; + case 42: + return 42; + case 43: + break; + case 44: + return 35; + case 45: + return 36; + } + }, + rules: [/^(?:%%(?!\{)[^\n]*)/i, /^(?:[^\}]%%[^\n]*)/i, /^(?:(\r?\n))/i, /^(?:(\r?\n))/i, /^(?:[\n\r]+)/i, /^(?:%%[^\n]*)/i, /^(?:title\b)/i, /^(?:accTitle\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*\{\s*)/i, /^(?:\{)/i, /^(?:[^\}]*)/i, /^(?:xychart-beta\b)/i, /^(?:(?:vertical|horizontal))/i, /^(?:x-axis\b)/i, /^(?:y-axis\b)/i, /^(?:\[)/i, /^(?:-->)/i, /^(?:line\b)/i, /^(?:bar\b)/i, /^(?:\[)/i, /^(?:[+-]?(?:\d+(?:\.\d+)?|\.\d+))/i, /^(?:\])/i, /^(?:(?:`\) \{ this\.pushState\(md_string\); \}\n\(\?:\(\?!`"\)\.\)\+ \{ return MD_STR; \}\n\(\?:`))/i, /^(?:["])/i, /^(?:["])/i, /^(?:[^"]*)/i, /^(?:\[)/i, /^(?:\])/i, /^(?:[A-Za-z]+)/i, /^(?::)/i, /^(?:\+)/i, /^(?:,)/i, /^(?:=)/i, /^(?:\*)/i, /^(?:#)/i, /^(?:[\_])/i, /^(?:\.)/i, /^(?:&)/i, /^(?:-)/i, /^(?:[0-9]+)/i, /^(?:\s+)/i, /^(?:;)/i, /^(?:$)/i], + conditions: { "data_inner": { "rules": [0, 1, 4, 5, 6, 7, 9, 11, 14, 15, 16, 17, 20, 21, 23, 24, 25, 26, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45], "inclusive": true }, "data": { "rules": [0, 1, 3, 4, 5, 6, 7, 9, 11, 14, 15, 16, 17, 20, 21, 22, 25, 26, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45], "inclusive": true }, "axis_band_data": { "rules": [0, 1, 4, 5, 6, 7, 9, 11, 14, 15, 16, 17, 20, 21, 24, 25, 26, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45], "inclusive": true }, "axis_data": { "rules": [0, 1, 2, 4, 5, 6, 7, 9, 11, 14, 15, 16, 17, 18, 19, 20, 21, 23, 25, 26, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45], "inclusive": true }, "acc_descr_multiline": { "rules": [12, 13], "inclusive": false }, "acc_descr": { "rules": [10], "inclusive": false }, "acc_title": { "rules": [8], "inclusive": false }, "title": { "rules": [], "inclusive": false }, "md_string": { "rules": [], "inclusive": false }, "string": { "rules": [27, 28], "inclusive": false }, "INITIAL": { "rules": [0, 1, 4, 5, 6, 7, 9, 11, 14, 15, 16, 17, 20, 21, 25, 26, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45], "inclusive": true } } + }; + return lexer2; + }(); + parser2.lexer = lexer; + function Parser() { + this.yy = {}; + } + Parser.prototype = parser2; + parser2.Parser = Parser; + return new Parser(); +}(); +parser.parser = parser; +const parser$1 = parser; +function isBarPlot(data) { + return data.type === "bar"; +} +function isBandAxisData(data) { + return data.type === "band"; +} +function isLinearAxisData(data) { + return data.type === "linear"; +} +class TextDimensionCalculatorWithFont { + constructor(parentGroup) { + this.parentGroup = parentGroup; + } + getMaxDimension(texts, fontSize) { + if (!this.parentGroup) { + return { + width: texts.reduce((acc, cur) => Math.max(cur.length, acc), 0) * fontSize, + height: fontSize + }; + } + const dimension = { + width: 0, + height: 0 + }; + const elem = this.parentGroup.append("g").attr("visibility", "hidden").attr("font-size", fontSize); + for (const t of texts) { + const bbox = computeDimensionOfText(elem, 1, t); + const width = bbox ? bbox.width : t.length * fontSize; + const height = bbox ? bbox.height : fontSize; + dimension.width = Math.max(dimension.width, width); + dimension.height = Math.max(dimension.height, height); + } + elem.remove(); + return dimension; + } +} +const BAR_WIDTH_TO_TICK_WIDTH_RATIO = 0.7; +const MAX_OUTER_PADDING_PERCENT_FOR_WRT_LABEL = 0.2; +class BaseAxis { + constructor(axisConfig, title, textDimensionCalculator, axisThemeConfig) { + this.axisConfig = axisConfig; + this.title = title; + this.textDimensionCalculator = textDimensionCalculator; + this.axisThemeConfig = axisThemeConfig; + this.boundingRect = { x: 0, y: 0, width: 0, height: 0 }; + this.axisPosition = "left"; + this.showTitle = false; + this.showLabel = false; + this.showTick = false; + this.showAxisLine = false; + this.outerPadding = 0; + this.titleTextHeight = 0; + this.labelTextHeight = 0; + this.range = [0, 10]; + this.boundingRect = { x: 0, y: 0, width: 0, height: 0 }; + this.axisPosition = "left"; + } + setRange(range) { + this.range = range; + if (this.axisPosition === "left" || this.axisPosition === "right") { + this.boundingRect.height = range[1] - range[0]; + } else { + this.boundingRect.width = range[1] - range[0]; + } + this.recalculateScale(); + } + getRange() { + return [this.range[0] + this.outerPadding, this.range[1] - this.outerPadding]; + } + setAxisPosition(axisPosition) { + this.axisPosition = axisPosition; + this.setRange(this.range); + } + getTickDistance() { + const range = this.getRange(); + return Math.abs(range[0] - range[1]) / this.getTickValues().length; + } + getAxisOuterPadding() { + return this.outerPadding; + } + getLabelDimension() { + return this.textDimensionCalculator.getMaxDimension( + this.getTickValues().map((tick) => tick.toString()), + this.axisConfig.labelFontSize + ); + } + recalculateOuterPaddingToDrawBar() { + if (BAR_WIDTH_TO_TICK_WIDTH_RATIO * this.getTickDistance() > this.outerPadding * 2) { + this.outerPadding = Math.floor(BAR_WIDTH_TO_TICK_WIDTH_RATIO * this.getTickDistance() / 2); + } + this.recalculateScale(); + } + calculateSpaceIfDrawnHorizontally(availableSpace) { + let availableHeight = availableSpace.height; + if (this.axisConfig.showAxisLine && availableHeight > this.axisConfig.axisLineWidth) { + availableHeight -= this.axisConfig.axisLineWidth; + this.showAxisLine = true; + } + if (this.axisConfig.showLabel) { + const spaceRequired = this.getLabelDimension(); + const maxPadding = MAX_OUTER_PADDING_PERCENT_FOR_WRT_LABEL * availableSpace.width; + this.outerPadding = Math.min(spaceRequired.width / 2, maxPadding); + const heightRequired = spaceRequired.height + this.axisConfig.labelPadding * 2; + this.labelTextHeight = spaceRequired.height; + if (heightRequired <= availableHeight) { + availableHeight -= heightRequired; + this.showLabel = true; + } + } + if (this.axisConfig.showTick && availableHeight >= this.axisConfig.tickLength) { + this.showTick = true; + availableHeight -= this.axisConfig.tickLength; + } + if (this.axisConfig.showTitle && this.title) { + const spaceRequired = this.textDimensionCalculator.getMaxDimension( + [this.title], + this.axisConfig.titleFontSize + ); + const heightRequired = spaceRequired.height + this.axisConfig.titlePadding * 2; + this.titleTextHeight = spaceRequired.height; + if (heightRequired <= availableHeight) { + availableHeight -= heightRequired; + this.showTitle = true; + } + } + this.boundingRect.width = availableSpace.width; + this.boundingRect.height = availableSpace.height - availableHeight; + } + calculateSpaceIfDrawnVertical(availableSpace) { + let availableWidth = availableSpace.width; + if (this.axisConfig.showAxisLine && availableWidth > this.axisConfig.axisLineWidth) { + availableWidth -= this.axisConfig.axisLineWidth; + this.showAxisLine = true; + } + if (this.axisConfig.showLabel) { + const spaceRequired = this.getLabelDimension(); + const maxPadding = MAX_OUTER_PADDING_PERCENT_FOR_WRT_LABEL * availableSpace.height; + this.outerPadding = Math.min(spaceRequired.height / 2, maxPadding); + const widthRequired = spaceRequired.width + this.axisConfig.labelPadding * 2; + if (widthRequired <= availableWidth) { + availableWidth -= widthRequired; + this.showLabel = true; + } + } + if (this.axisConfig.showTick && availableWidth >= this.axisConfig.tickLength) { + this.showTick = true; + availableWidth -= this.axisConfig.tickLength; + } + if (this.axisConfig.showTitle && this.title) { + const spaceRequired = this.textDimensionCalculator.getMaxDimension( + [this.title], + this.axisConfig.titleFontSize + ); + const widthRequired = spaceRequired.height + this.axisConfig.titlePadding * 2; + this.titleTextHeight = spaceRequired.height; + if (widthRequired <= availableWidth) { + availableWidth -= widthRequired; + this.showTitle = true; + } + } + this.boundingRect.width = availableSpace.width - availableWidth; + this.boundingRect.height = availableSpace.height; + } + calculateSpace(availableSpace) { + if (this.axisPosition === "left" || this.axisPosition === "right") { + this.calculateSpaceIfDrawnVertical(availableSpace); + } else { + this.calculateSpaceIfDrawnHorizontally(availableSpace); + } + this.recalculateScale(); + return { + width: this.boundingRect.width, + height: this.boundingRect.height + }; + } + setBoundingBoxXY(point) { + this.boundingRect.x = point.x; + this.boundingRect.y = point.y; + } + getDrawableElementsForLeftAxis() { + const drawableElement = []; + if (this.showAxisLine) { + const x = this.boundingRect.x + this.boundingRect.width - this.axisConfig.axisLineWidth / 2; + drawableElement.push({ + type: "path", + groupTexts: ["left-axis", "axisl-line"], + data: [ + { + path: `M ${x},${this.boundingRect.y} L ${x},${this.boundingRect.y + this.boundingRect.height} `, + strokeFill: this.axisThemeConfig.axisLineColor, + strokeWidth: this.axisConfig.axisLineWidth + } + ] + }); + } + if (this.showLabel) { + drawableElement.push({ + type: "text", + groupTexts: ["left-axis", "label"], + data: this.getTickValues().map((tick) => ({ + text: tick.toString(), + x: this.boundingRect.x + this.boundingRect.width - (this.showLabel ? this.axisConfig.labelPadding : 0) - (this.showTick ? this.axisConfig.tickLength : 0) - (this.showAxisLine ? this.axisConfig.axisLineWidth : 0), + y: this.getScaleValue(tick), + fill: this.axisThemeConfig.labelColor, + fontSize: this.axisConfig.labelFontSize, + rotation: 0, + verticalPos: "middle", + horizontalPos: "right" + })) + }); + } + if (this.showTick) { + const x = this.boundingRect.x + this.boundingRect.width - (this.showAxisLine ? this.axisConfig.axisLineWidth : 0); + drawableElement.push({ + type: "path", + groupTexts: ["left-axis", "ticks"], + data: this.getTickValues().map((tick) => ({ + path: `M ${x},${this.getScaleValue(tick)} L ${x - this.axisConfig.tickLength},${this.getScaleValue(tick)}`, + strokeFill: this.axisThemeConfig.tickColor, + strokeWidth: this.axisConfig.tickWidth + })) + }); + } + if (this.showTitle) { + drawableElement.push({ + type: "text", + groupTexts: ["left-axis", "title"], + data: [ + { + text: this.title, + x: this.boundingRect.x + this.axisConfig.titlePadding, + y: this.boundingRect.y + this.boundingRect.height / 2, + fill: this.axisThemeConfig.titleColor, + fontSize: this.axisConfig.titleFontSize, + rotation: 270, + verticalPos: "top", + horizontalPos: "center" + } + ] + }); + } + return drawableElement; + } + getDrawableElementsForBottomAxis() { + const drawableElement = []; + if (this.showAxisLine) { + const y = this.boundingRect.y + this.axisConfig.axisLineWidth / 2; + drawableElement.push({ + type: "path", + groupTexts: ["bottom-axis", "axis-line"], + data: [ + { + path: `M ${this.boundingRect.x},${y} L ${this.boundingRect.x + this.boundingRect.width},${y}`, + strokeFill: this.axisThemeConfig.axisLineColor, + strokeWidth: this.axisConfig.axisLineWidth + } + ] + }); + } + if (this.showLabel) { + drawableElement.push({ + type: "text", + groupTexts: ["bottom-axis", "label"], + data: this.getTickValues().map((tick) => ({ + text: tick.toString(), + x: this.getScaleValue(tick), + y: this.boundingRect.y + this.axisConfig.labelPadding + (this.showTick ? this.axisConfig.tickLength : 0) + (this.showAxisLine ? this.axisConfig.axisLineWidth : 0), + fill: this.axisThemeConfig.labelColor, + fontSize: this.axisConfig.labelFontSize, + rotation: 0, + verticalPos: "top", + horizontalPos: "center" + })) + }); + } + if (this.showTick) { + const y = this.boundingRect.y + (this.showAxisLine ? this.axisConfig.axisLineWidth : 0); + drawableElement.push({ + type: "path", + groupTexts: ["bottom-axis", "ticks"], + data: this.getTickValues().map((tick) => ({ + path: `M ${this.getScaleValue(tick)},${y} L ${this.getScaleValue(tick)},${y + this.axisConfig.tickLength}`, + strokeFill: this.axisThemeConfig.tickColor, + strokeWidth: this.axisConfig.tickWidth + })) + }); + } + if (this.showTitle) { + drawableElement.push({ + type: "text", + groupTexts: ["bottom-axis", "title"], + data: [ + { + text: this.title, + x: this.range[0] + (this.range[1] - this.range[0]) / 2, + y: this.boundingRect.y + this.boundingRect.height - this.axisConfig.titlePadding - this.titleTextHeight, + fill: this.axisThemeConfig.titleColor, + fontSize: this.axisConfig.titleFontSize, + rotation: 0, + verticalPos: "top", + horizontalPos: "center" + } + ] + }); + } + return drawableElement; + } + getDrawableElementsForTopAxis() { + const drawableElement = []; + if (this.showAxisLine) { + const y = this.boundingRect.y + this.boundingRect.height - this.axisConfig.axisLineWidth / 2; + drawableElement.push({ + type: "path", + groupTexts: ["top-axis", "axis-line"], + data: [ + { + path: `M ${this.boundingRect.x},${y} L ${this.boundingRect.x + this.boundingRect.width},${y}`, + strokeFill: this.axisThemeConfig.axisLineColor, + strokeWidth: this.axisConfig.axisLineWidth + } + ] + }); + } + if (this.showLabel) { + drawableElement.push({ + type: "text", + groupTexts: ["top-axis", "label"], + data: this.getTickValues().map((tick) => ({ + text: tick.toString(), + x: this.getScaleValue(tick), + y: this.boundingRect.y + (this.showTitle ? this.titleTextHeight + this.axisConfig.titlePadding * 2 : 0) + this.axisConfig.labelPadding, + fill: this.axisThemeConfig.labelColor, + fontSize: this.axisConfig.labelFontSize, + rotation: 0, + verticalPos: "top", + horizontalPos: "center" + })) + }); + } + if (this.showTick) { + const y = this.boundingRect.y; + drawableElement.push({ + type: "path", + groupTexts: ["top-axis", "ticks"], + data: this.getTickValues().map((tick) => ({ + path: `M ${this.getScaleValue(tick)},${y + this.boundingRect.height - (this.showAxisLine ? this.axisConfig.axisLineWidth : 0)} L ${this.getScaleValue(tick)},${y + this.boundingRect.height - this.axisConfig.tickLength - (this.showAxisLine ? this.axisConfig.axisLineWidth : 0)}`, + strokeFill: this.axisThemeConfig.tickColor, + strokeWidth: this.axisConfig.tickWidth + })) + }); + } + if (this.showTitle) { + drawableElement.push({ + type: "text", + groupTexts: ["top-axis", "title"], + data: [ + { + text: this.title, + x: this.boundingRect.x + this.boundingRect.width / 2, + y: this.boundingRect.y + this.axisConfig.titlePadding, + fill: this.axisThemeConfig.titleColor, + fontSize: this.axisConfig.titleFontSize, + rotation: 0, + verticalPos: "top", + horizontalPos: "center" + } + ] + }); + } + return drawableElement; + } + getDrawableElements() { + if (this.axisPosition === "left") { + return this.getDrawableElementsForLeftAxis(); + } + if (this.axisPosition === "right") { + throw Error("Drawing of right axis is not implemented"); + } + if (this.axisPosition === "bottom") { + return this.getDrawableElementsForBottomAxis(); + } + if (this.axisPosition === "top") { + return this.getDrawableElementsForTopAxis(); + } + return []; + } +} +class BandAxis extends BaseAxis { + constructor(axisConfig, axisThemeConfig, categories, title, textDimensionCalculator) { + super(axisConfig, title, textDimensionCalculator, axisThemeConfig); + this.categories = categories; + this.scale = scaleBand().domain(this.categories).range(this.getRange()); + } + setRange(range) { + super.setRange(range); + } + recalculateScale() { + this.scale = scaleBand().domain(this.categories).range(this.getRange()).paddingInner(1).paddingOuter(0).align(0.5); + log.trace("BandAxis axis final categories, range: ", this.categories, this.getRange()); + } + getTickValues() { + return this.categories; + } + getScaleValue(value) { + return this.scale(value) || this.getRange()[0]; + } +} +class LinearAxis extends BaseAxis { + constructor(axisConfig, axisThemeConfig, domain, title, textDimensionCalculator) { + super(axisConfig, title, textDimensionCalculator, axisThemeConfig); + this.domain = domain; + this.scale = scaleLinear().domain(this.domain).range(this.getRange()); + } + getTickValues() { + return this.scale.ticks(); + } + recalculateScale() { + const domain = [...this.domain]; + if (this.axisPosition === "left") { + domain.reverse(); + } + this.scale = scaleLinear().domain(domain).range(this.getRange()); + } + getScaleValue(value) { + return this.scale(value); + } +} +function getAxis(data, axisConfig, axisThemeConfig, tmpSVGGroup2) { + const textDimensionCalculator = new TextDimensionCalculatorWithFont(tmpSVGGroup2); + if (isBandAxisData(data)) { + return new BandAxis( + axisConfig, + axisThemeConfig, + data.categories, + data.title, + textDimensionCalculator + ); + } + return new LinearAxis( + axisConfig, + axisThemeConfig, + [data.min, data.max], + data.title, + textDimensionCalculator + ); +} +class ChartTitle { + constructor(textDimensionCalculator, chartConfig, chartData, chartThemeConfig) { + this.textDimensionCalculator = textDimensionCalculator; + this.chartConfig = chartConfig; + this.chartData = chartData; + this.chartThemeConfig = chartThemeConfig; + this.boundingRect = { + x: 0, + y: 0, + width: 0, + height: 0 + }; + this.showChartTitle = false; + } + setBoundingBoxXY(point) { + this.boundingRect.x = point.x; + this.boundingRect.y = point.y; + } + calculateSpace(availableSpace) { + const titleDimension = this.textDimensionCalculator.getMaxDimension( + [this.chartData.title], + this.chartConfig.titleFontSize + ); + const widthRequired = Math.max(titleDimension.width, availableSpace.width); + const heightRequired = titleDimension.height + 2 * this.chartConfig.titlePadding; + if (titleDimension.width <= widthRequired && titleDimension.height <= heightRequired && this.chartConfig.showTitle && this.chartData.title) { + this.boundingRect.width = widthRequired; + this.boundingRect.height = heightRequired; + this.showChartTitle = true; + } + return { + width: this.boundingRect.width, + height: this.boundingRect.height + }; + } + getDrawableElements() { + const drawableElem = []; + if (this.showChartTitle) { + drawableElem.push({ + groupTexts: ["chart-title"], + type: "text", + data: [ + { + fontSize: this.chartConfig.titleFontSize, + text: this.chartData.title, + verticalPos: "middle", + horizontalPos: "center", + x: this.boundingRect.x + this.boundingRect.width / 2, + y: this.boundingRect.y + this.boundingRect.height / 2, + fill: this.chartThemeConfig.titleColor, + rotation: 0 + } + ] + }); + } + return drawableElem; + } +} +function getChartTitleComponent(chartConfig, chartData, chartThemeConfig, tmpSVGGroup2) { + const textDimensionCalculator = new TextDimensionCalculatorWithFont(tmpSVGGroup2); + return new ChartTitle(textDimensionCalculator, chartConfig, chartData, chartThemeConfig); +} +class LinePlot { + constructor(plotData, xAxis, yAxis, orientation, plotIndex2) { + this.plotData = plotData; + this.xAxis = xAxis; + this.yAxis = yAxis; + this.orientation = orientation; + this.plotIndex = plotIndex2; + } + getDrawableElement() { + const finalData = this.plotData.data.map((d) => [ + this.xAxis.getScaleValue(d[0]), + this.yAxis.getScaleValue(d[1]) + ]); + let path; + if (this.orientation === "horizontal") { + path = line().y((d) => d[0]).x((d) => d[1])(finalData); + } else { + path = line().x((d) => d[0]).y((d) => d[1])(finalData); + } + if (!path) { + return []; + } + return [ + { + groupTexts: ["plot", `line-plot-${this.plotIndex}`], + type: "path", + data: [ + { + path, + strokeFill: this.plotData.strokeFill, + strokeWidth: this.plotData.strokeWidth + } + ] + } + ]; + } +} +class BarPlot { + constructor(barData, boundingRect, xAxis, yAxis, orientation, plotIndex2) { + this.barData = barData; + this.boundingRect = boundingRect; + this.xAxis = xAxis; + this.yAxis = yAxis; + this.orientation = orientation; + this.plotIndex = plotIndex2; + } + getDrawableElement() { + const finalData = this.barData.data.map((d) => [ + this.xAxis.getScaleValue(d[0]), + this.yAxis.getScaleValue(d[1]) + ]); + const barPaddingPercent = 0.05; + const barWidth = Math.min(this.xAxis.getAxisOuterPadding() * 2, this.xAxis.getTickDistance()) * (1 - barPaddingPercent); + const barWidthHalf = barWidth / 2; + if (this.orientation === "horizontal") { + return [ + { + groupTexts: ["plot", `bar-plot-${this.plotIndex}`], + type: "rect", + data: finalData.map((data) => ({ + x: this.boundingRect.x, + y: data[0] - barWidthHalf, + height: barWidth, + width: data[1] - this.boundingRect.x, + fill: this.barData.fill, + strokeWidth: 0, + strokeFill: this.barData.fill + })) + } + ]; + } + return [ + { + groupTexts: ["plot", `bar-plot-${this.plotIndex}`], + type: "rect", + data: finalData.map((data) => ({ + x: data[0] - barWidthHalf, + y: data[1], + width: barWidth, + height: this.boundingRect.y + this.boundingRect.height - data[1], + fill: this.barData.fill, + strokeWidth: 0, + strokeFill: this.barData.fill + })) + } + ]; + } +} +class BasePlot { + constructor(chartConfig, chartData, chartThemeConfig) { + this.chartConfig = chartConfig; + this.chartData = chartData; + this.chartThemeConfig = chartThemeConfig; + this.boundingRect = { + x: 0, + y: 0, + width: 0, + height: 0 + }; + } + setAxes(xAxis, yAxis) { + this.xAxis = xAxis; + this.yAxis = yAxis; + } + setBoundingBoxXY(point) { + this.boundingRect.x = point.x; + this.boundingRect.y = point.y; + } + calculateSpace(availableSpace) { + this.boundingRect.width = availableSpace.width; + this.boundingRect.height = availableSpace.height; + return { + width: this.boundingRect.width, + height: this.boundingRect.height + }; + } + getDrawableElements() { + if (!(this.xAxis && this.yAxis)) { + throw Error("Axes must be passed to render Plots"); + } + const drawableElem = []; + for (const [i, plot] of this.chartData.plots.entries()) { + switch (plot.type) { + case "line": + { + const linePlot = new LinePlot( + plot, + this.xAxis, + this.yAxis, + this.chartConfig.chartOrientation, + i + ); + drawableElem.push(...linePlot.getDrawableElement()); + } + break; + case "bar": + { + const barPlot = new BarPlot( + plot, + this.boundingRect, + this.xAxis, + this.yAxis, + this.chartConfig.chartOrientation, + i + ); + drawableElem.push(...barPlot.getDrawableElement()); + } + break; + } + } + return drawableElem; + } +} +function getPlotComponent(chartConfig, chartData, chartThemeConfig) { + return new BasePlot(chartConfig, chartData, chartThemeConfig); +} +class Orchestrator { + constructor(chartConfig, chartData, chartThemeConfig, tmpSVGGroup2) { + this.chartConfig = chartConfig; + this.chartData = chartData; + this.componentStore = { + title: getChartTitleComponent(chartConfig, chartData, chartThemeConfig, tmpSVGGroup2), + plot: getPlotComponent(chartConfig, chartData, chartThemeConfig), + xAxis: getAxis( + chartData.xAxis, + chartConfig.xAxis, + { + titleColor: chartThemeConfig.xAxisTitleColor, + labelColor: chartThemeConfig.xAxisLabelColor, + tickColor: chartThemeConfig.xAxisTickColor, + axisLineColor: chartThemeConfig.xAxisLineColor + }, + tmpSVGGroup2 + ), + yAxis: getAxis( + chartData.yAxis, + chartConfig.yAxis, + { + titleColor: chartThemeConfig.yAxisTitleColor, + labelColor: chartThemeConfig.yAxisLabelColor, + tickColor: chartThemeConfig.yAxisTickColor, + axisLineColor: chartThemeConfig.yAxisLineColor + }, + tmpSVGGroup2 + ) + }; + } + calculateVerticalSpace() { + let availableWidth = this.chartConfig.width; + let availableHeight = this.chartConfig.height; + let plotX = 0; + let plotY = 0; + let chartWidth = Math.floor(availableWidth * this.chartConfig.plotReservedSpacePercent / 100); + let chartHeight = Math.floor( + availableHeight * this.chartConfig.plotReservedSpacePercent / 100 + ); + let spaceUsed = this.componentStore.plot.calculateSpace({ + width: chartWidth, + height: chartHeight + }); + availableWidth -= spaceUsed.width; + availableHeight -= spaceUsed.height; + spaceUsed = this.componentStore.title.calculateSpace({ + width: this.chartConfig.width, + height: availableHeight + }); + plotY = spaceUsed.height; + availableHeight -= spaceUsed.height; + this.componentStore.xAxis.setAxisPosition("bottom"); + spaceUsed = this.componentStore.xAxis.calculateSpace({ + width: availableWidth, + height: availableHeight + }); + availableHeight -= spaceUsed.height; + this.componentStore.yAxis.setAxisPosition("left"); + spaceUsed = this.componentStore.yAxis.calculateSpace({ + width: availableWidth, + height: availableHeight + }); + plotX = spaceUsed.width; + availableWidth -= spaceUsed.width; + if (availableWidth > 0) { + chartWidth += availableWidth; + availableWidth = 0; + } + if (availableHeight > 0) { + chartHeight += availableHeight; + availableHeight = 0; + } + this.componentStore.plot.calculateSpace({ + width: chartWidth, + height: chartHeight + }); + this.componentStore.plot.setBoundingBoxXY({ x: plotX, y: plotY }); + this.componentStore.xAxis.setRange([plotX, plotX + chartWidth]); + this.componentStore.xAxis.setBoundingBoxXY({ x: plotX, y: plotY + chartHeight }); + this.componentStore.yAxis.setRange([plotY, plotY + chartHeight]); + this.componentStore.yAxis.setBoundingBoxXY({ x: 0, y: plotY }); + if (this.chartData.plots.some((p) => isBarPlot(p))) { + this.componentStore.xAxis.recalculateOuterPaddingToDrawBar(); + } + } + calculateHorizontalSpace() { + let availableWidth = this.chartConfig.width; + let availableHeight = this.chartConfig.height; + let titleYEnd = 0; + let plotX = 0; + let plotY = 0; + let chartWidth = Math.floor(availableWidth * this.chartConfig.plotReservedSpacePercent / 100); + let chartHeight = Math.floor( + availableHeight * this.chartConfig.plotReservedSpacePercent / 100 + ); + let spaceUsed = this.componentStore.plot.calculateSpace({ + width: chartWidth, + height: chartHeight + }); + availableWidth -= spaceUsed.width; + availableHeight -= spaceUsed.height; + spaceUsed = this.componentStore.title.calculateSpace({ + width: this.chartConfig.width, + height: availableHeight + }); + titleYEnd = spaceUsed.height; + availableHeight -= spaceUsed.height; + this.componentStore.xAxis.setAxisPosition("left"); + spaceUsed = this.componentStore.xAxis.calculateSpace({ + width: availableWidth, + height: availableHeight + }); + availableWidth -= spaceUsed.width; + plotX = spaceUsed.width; + this.componentStore.yAxis.setAxisPosition("top"); + spaceUsed = this.componentStore.yAxis.calculateSpace({ + width: availableWidth, + height: availableHeight + }); + availableHeight -= spaceUsed.height; + plotY = titleYEnd + spaceUsed.height; + if (availableWidth > 0) { + chartWidth += availableWidth; + availableWidth = 0; + } + if (availableHeight > 0) { + chartHeight += availableHeight; + availableHeight = 0; + } + this.componentStore.plot.calculateSpace({ + width: chartWidth, + height: chartHeight + }); + this.componentStore.plot.setBoundingBoxXY({ x: plotX, y: plotY }); + this.componentStore.yAxis.setRange([plotX, plotX + chartWidth]); + this.componentStore.yAxis.setBoundingBoxXY({ x: plotX, y: titleYEnd }); + this.componentStore.xAxis.setRange([plotY, plotY + chartHeight]); + this.componentStore.xAxis.setBoundingBoxXY({ x: 0, y: plotY }); + if (this.chartData.plots.some((p) => isBarPlot(p))) { + this.componentStore.xAxis.recalculateOuterPaddingToDrawBar(); + } + } + calculateSpace() { + if (this.chartConfig.chartOrientation === "horizontal") { + this.calculateHorizontalSpace(); + } else { + this.calculateVerticalSpace(); + } + } + getDrawableElement() { + this.calculateSpace(); + const drawableElem = []; + this.componentStore.plot.setAxes(this.componentStore.xAxis, this.componentStore.yAxis); + for (const component of Object.values(this.componentStore)) { + drawableElem.push(...component.getDrawableElements()); + } + return drawableElem; + } +} +class XYChartBuilder { + static build(config, chartData, chartThemeConfig, tmpSVGGroup2) { + const orchestrator = new Orchestrator(config, chartData, chartThemeConfig, tmpSVGGroup2); + return orchestrator.getDrawableElement(); + } +} +let plotIndex = 0; +let tmpSVGGroup; +let xyChartConfig = getChartDefaultConfig(); +let xyChartThemeConfig = getChartDefaultThemeConfig(); +let xyChartData = getChartDefaultData(); +let plotColorPalette = xyChartThemeConfig.plotColorPalette.split(",").map((color) => color.trim()); +let hasSetXAxis = false; +let hasSetYAxis = false; +function getChartDefaultThemeConfig() { + const defaultThemeVariables = getThemeVariables(); + const config = getConfig(); + return cleanAndMerge(defaultThemeVariables.xyChart, config.themeVariables.xyChart); +} +function getChartDefaultConfig() { + const config = getConfig(); + return cleanAndMerge( + defaultConfig.xyChart, + config.xyChart + ); +} +function getChartDefaultData() { + return { + yAxis: { + type: "linear", + title: "", + min: Infinity, + max: -Infinity + }, + xAxis: { + type: "band", + title: "", + categories: [] + }, + title: "", + plots: [] + }; +} +function textSanitizer(text) { + const config = getConfig(); + return sanitizeText(text.trim(), config); +} +function setTmpSVGG(SVGG) { + tmpSVGGroup = SVGG; +} +function setOrientation(orientation) { + if (orientation === "horizontal") { + xyChartConfig.chartOrientation = "horizontal"; + } else { + xyChartConfig.chartOrientation = "vertical"; + } +} +function setXAxisTitle(title) { + xyChartData.xAxis.title = textSanitizer(title.text); +} +function setXAxisRangeData(min, max) { + xyChartData.xAxis = { type: "linear", title: xyChartData.xAxis.title, min, max }; + hasSetXAxis = true; +} +function setXAxisBand(categories) { + xyChartData.xAxis = { + type: "band", + title: xyChartData.xAxis.title, + categories: categories.map((c) => textSanitizer(c.text)) + }; + hasSetXAxis = true; +} +function setYAxisTitle(title) { + xyChartData.yAxis.title = textSanitizer(title.text); +} +function setYAxisRangeData(min, max) { + xyChartData.yAxis = { type: "linear", title: xyChartData.yAxis.title, min, max }; + hasSetYAxis = true; +} +function setYAxisRangeFromPlotData(data) { + const minValue = Math.min(...data); + const maxValue = Math.max(...data); + const prevMinValue = isLinearAxisData(xyChartData.yAxis) ? xyChartData.yAxis.min : Infinity; + const prevMaxValue = isLinearAxisData(xyChartData.yAxis) ? xyChartData.yAxis.max : -Infinity; + xyChartData.yAxis = { + type: "linear", + title: xyChartData.yAxis.title, + min: Math.min(prevMinValue, minValue), + max: Math.max(prevMaxValue, maxValue) + }; +} +function transformDataWithoutCategory(data) { + let retData = []; + if (data.length === 0) { + return retData; + } + if (!hasSetXAxis) { + const prevMinValue = isLinearAxisData(xyChartData.xAxis) ? xyChartData.xAxis.min : Infinity; + const prevMaxValue = isLinearAxisData(xyChartData.xAxis) ? xyChartData.xAxis.max : -Infinity; + setXAxisRangeData(Math.min(prevMinValue, 1), Math.max(prevMaxValue, data.length)); + } + if (!hasSetYAxis) { + setYAxisRangeFromPlotData(data); + } + if (isBandAxisData(xyChartData.xAxis)) { + retData = xyChartData.xAxis.categories.map((c, i) => [c, data[i]]); + } + if (isLinearAxisData(xyChartData.xAxis)) { + const min = xyChartData.xAxis.min; + const max = xyChartData.xAxis.max; + const step = (max - min + 1) / data.length; + const categories = []; + for (let i = min; i <= max; i += step) { + categories.push(`${i}`); + } + retData = categories.map((c, i) => [c, data[i]]); + } + return retData; +} +function getPlotColorFromPalette(plotIndex2) { + return plotColorPalette[plotIndex2 === 0 ? 0 : plotIndex2 % plotColorPalette.length]; +} +function setLineData(title, data) { + const plotData = transformDataWithoutCategory(data); + xyChartData.plots.push({ + type: "line", + strokeFill: getPlotColorFromPalette(plotIndex), + strokeWidth: 2, + data: plotData + }); + plotIndex++; +} +function setBarData(title, data) { + const plotData = transformDataWithoutCategory(data); + xyChartData.plots.push({ + type: "bar", + fill: getPlotColorFromPalette(plotIndex), + data: plotData + }); + plotIndex++; +} +function getDrawableElem() { + if (xyChartData.plots.length === 0) { + throw Error("No Plot to render, please provide a plot with some data"); + } + xyChartData.title = getDiagramTitle(); + return XYChartBuilder.build(xyChartConfig, xyChartData, xyChartThemeConfig, tmpSVGGroup); +} +function getChartThemeConfig() { + return xyChartThemeConfig; +} +function getChartConfig() { + return xyChartConfig; +} +const clear = function() { + clear$1(); + plotIndex = 0; + xyChartConfig = getChartDefaultConfig(); + xyChartData = getChartDefaultData(); + xyChartThemeConfig = getChartDefaultThemeConfig(); + plotColorPalette = xyChartThemeConfig.plotColorPalette.split(",").map((color) => color.trim()); + hasSetXAxis = false; + hasSetYAxis = false; +}; +const db = { + getDrawableElem, + clear, + setAccTitle, + getAccTitle, + setDiagramTitle, + getDiagramTitle, + getAccDescription, + setAccDescription, + setOrientation, + setXAxisTitle, + setXAxisRangeData, + setXAxisBand, + setYAxisTitle, + setYAxisRangeData, + setLineData, + setBarData, + setTmpSVGG, + getChartThemeConfig, + getChartConfig +}; +const draw = (txt, id, _version, diagObj) => { + const db2 = diagObj.db; + const themeConfig = db2.getChartThemeConfig(); + const chartConfig = db2.getChartConfig(); + function getDominantBaseLine(horizontalPos) { + return horizontalPos === "top" ? "text-before-edge" : "middle"; + } + function getTextAnchor(verticalPos) { + return verticalPos === "left" ? "start" : verticalPos === "right" ? "end" : "middle"; + } + function getTextTransformation(data) { + return `translate(${data.x}, ${data.y}) rotate(${data.rotation || 0})`; + } + log.debug("Rendering xychart chart\n" + txt); + const svg = selectSvgElement(id); + const group = svg.append("g").attr("class", "main"); + const background = group.append("rect").attr("width", chartConfig.width).attr("height", chartConfig.height).attr("class", "background"); + configureSvgSize(svg, chartConfig.height, chartConfig.width, true); + svg.attr("viewBox", `0 0 ${chartConfig.width} ${chartConfig.height}`); + background.attr("fill", themeConfig.backgroundColor); + db2.setTmpSVGG(svg.append("g").attr("class", "mermaid-tmp-group")); + const shapes = db2.getDrawableElem(); + const groups = {}; + function getGroup(gList) { + let elem = group; + let prefix = ""; + for (const [i] of gList.entries()) { + let parent = group; + if (i > 0 && groups[prefix]) { + parent = groups[prefix]; + } + prefix += gList[i]; + elem = groups[prefix]; + if (!elem) { + elem = groups[prefix] = parent.append("g").attr("class", gList[i]); + } + } + return elem; + } + for (const shape of shapes) { + if (shape.data.length === 0) { + continue; + } + const shapeGroup = getGroup(shape.groupTexts); + switch (shape.type) { + case "rect": + shapeGroup.selectAll("rect").data(shape.data).enter().append("rect").attr("x", (data) => data.x).attr("y", (data) => data.y).attr("width", (data) => data.width).attr("height", (data) => data.height).attr("fill", (data) => data.fill).attr("stroke", (data) => data.strokeFill).attr("stroke-width", (data) => data.strokeWidth); + break; + case "text": + shapeGroup.selectAll("text").data(shape.data).enter().append("text").attr("x", 0).attr("y", 0).attr("fill", (data) => data.fill).attr("font-size", (data) => data.fontSize).attr("dominant-baseline", (data) => getDominantBaseLine(data.verticalPos)).attr("text-anchor", (data) => getTextAnchor(data.horizontalPos)).attr("transform", (data) => getTextTransformation(data)).text((data) => data.text); + break; + case "path": + shapeGroup.selectAll("path").data(shape.data).enter().append("path").attr("d", (data) => data.path).attr("fill", (data) => data.fill ? data.fill : "none").attr("stroke", (data) => data.strokeFill).attr("stroke-width", (data) => data.strokeWidth); + break; + } + } +}; +const renderer = { + draw +}; +const diagram = { + parser: parser$1, + db, + renderer +}; +export { + diagram +}; diff --git a/0.6.0/search/search_index.json b/0.6.0/search/search_index.json new file mode 100644 index 0000000..64f4dcf --- /dev/null +++ b/0.6.0/search/search_index.json @@ -0,0 +1 @@ +{"config":{"lang":["en"],"separator":"[\\s\\-]+","pipeline":["stopWordFilter"]},"docs":[{"location":"getting-started/generate-report/","title":"Generate a Report","text":"

    To generate a report, you will need to have Nix installed on the target machine.

    sudo nix run \\\n  --option experimental-features \"nix-command flakes\" \\\n  --option extra-substituters https://numtide.cachix.org \\\n  --option extra-trusted-public-keys numtide.cachix.org-1:2ps1kLBUWjxIneOy1Ik6cQjb41X0iXVXeHigGmycPPE= \\\n  github:numtide/nixos-facter -- -o facter.json\n

    Note

    In the near-future we will add nixos-facter to nixpkgs. Until then, we recommend using the Numtide Binary Cache to avoid having to build everything from scratch.

    This will scan your system and produce a JSON-based report in a file named facter.json:

    facter.json
    {\n  \"version\": 2, // (1)!\n  \"system\": \"x86_64-linux\", // (2)!\n  \"virtualisation\": \"none\", // (3)!\n  \"hardware\": { // (4)!\n    \"bios\": { ... },\n    \"bluetooth\": [ ... ],\n    \"bridge\": [ ... ],\n    \"chip_card\": [ ... ] ,\n    \"cpu\": [ ... ],\n    \"disk\": [ ... ],\n    \"graphics_card\": [ ... ],\n    \"hub\": [ ... ],\n    \"keyboard\": [ ... ],\n    \"memory\": [ ... ],\n    \"monitor\": [ ... ],\n    \"mouse\": [ ... ],\n    \"network_controller\": [ ... ],\n    \"network_interface\": [ ... ],\n    \"sound\": [ ... ],\n    \"storage_controller\": [ ... ],\n    \"system\": [ ... ],\n    \"unknown\": [ ... ],\n    \"usb_controller\": [ ... ]\n  },\n  \"smbios\": { // (5)!\n    \"bios\": { ... },\n    \"board\": { ... },\n    \"cache\": [ ... ],\n    \"chassis\": { ... },\n    \"config\": { ... },\n    \"language\": { ... },\n    \"memory_array\": [ ... ],\n    \"memory_array_mapped_address\": [ ... ],\n    \"memory_device\": [ ... ],\n    \"memory_device_mapped_address\": [ ... ],\n    \"memory_error\": [ ... ],\n    \"onboard\": [ ... ],\n    \"port_connector\": [ ... ],\n    \"processor\": [ ... ],\n    \"slot\": [ ... ],\n    \"system\": { ... }\n  }\n}\n
    1. Used to track major breaking changes in the report format.
    2. Architecture of the target machine.
    3. Indicates whether the report was generated inside a virtualised environment, and if so, what type.
    4. All the various bits of hardware that could be detected.
    5. System Management BIOS information if available.

    Download that file and continue on to the next step.

    "},{"location":"getting-started/nixos-configuration/","title":"NixOS Configuration","text":"

    Taking the facter.json file generated in the previous step, we can construct a NixOS configuration:

    FlakeNon-Flake flake.nix
    {\n  inputs = {\n    nixpkgs.url = \"github:nixos/nixpkgs/nixos-unstable\";\n    nixos-facter-modules.url = \"github:numtide/nixos-facter-modules\";\n  };\n\n  outputs =\n    inputs@{ nixpkgs, ... }:\n    let\n        inherit (nixpkgs) lib;\n    in\n    {\n      nixosConfigurations.basic = lib.nixosSystem {\n        modules = [\n\n          # enable the NixOS Facter module\n          inputs.nixos-facter-modules.nixosModules.facter\n\n          # configure the facter report\n          { config.facter.reportPath = ./facter.json; }\n\n          # Additional modules and configuration, for example:\n          #\n          # {\n          #   users.users.root.initialPassword = \"fnord23\";\n          #   boot.loader.grub.devices = lib.mkForce [ \"/dev/sda\" ];\n          #   fileSystems.\"/\".device = lib.mkDefault \"/dev/sda\";\n          # }\n          # ...\n          # Define your bootloader if you are not using grub\n          # { boot.loader.systemd-boot.enable = true; }\n        ];\n      };\n    };\n}\n
    configuration.nix
    { lib, ... }:\n{\n  imports = [\n    \"${\n      (builtins.fetchTarball { url = \"https://github.com/numtide/nixos-facter-modules/\"; })\n    }/modules/nixos/facter.nix\"\n  ];\n\n  # configure the facter report\n  config.facter.reportPath = ./facter.json;\n\n  # Additional modules and configuration, for example:\n  #\n  # config.users.users.root.initialPassword = \"fnord23\";\n  # config.boot.loader.grub.devices = lib.mkForce [ \"/dev/sda\" ];\n  # config.fileSystems.\"/\".device = lib.mkDefault \"/dev/sda\";\n  #\n  # ...\n  # Define your bootloader if you are not using grub\n  # config.boot.loader.systemd-boot.enable = true;\n}\n

    The NixOS Facter module will attempt to do the following:

    • Configure nixpkgs.hostPlatform based on the detected architecture.
    • Enable a variety of kernel modules and NixOS options related to VM and bare-metal environments based on the detected virtualisation.
    • Enable CPU microcode updates based on the detected CPU(s).
    • Ensure a variety of kernel modules are made available at boot time based on the detected (usb|firewire|storage) controllers and disks.
    • Enable a variety of kernel modules based on the detected Broadcom and Intel WiFi devices.

    Roadmap

    We continue to add to and improve nixos-facter-modules. Our eventual goal is to replace much if not all of the functionality currently provided by nixos-hardware and nixos-generate-config.

    "}]} \ No newline at end of file diff --git a/0.6.0/sitemap.xml b/0.6.0/sitemap.xml new file mode 100644 index 0000000..0854a50 --- /dev/null +++ b/0.6.0/sitemap.xml @@ -0,0 +1,15 @@ + + + + https://numtide.github.io/nixos-facter-docs/0.6.0/ + 1980-01-01 + + + https://numtide.github.io/nixos-facter-docs/0.6.0/getting-started/generate-report/ + 1980-01-01 + + + https://numtide.github.io/nixos-facter-docs/0.6.0/getting-started/nixos-configuration/ + 1980-01-01 + + \ No newline at end of file diff --git a/0.6.0/sitemap.xml.gz b/0.6.0/sitemap.xml.gz new file mode 100644 index 0000000000000000000000000000000000000000..7735bfb1d13f076fd79fc0e39e6154f9c2f1464e GIT binary patch literal 245 zcmVEN!sL>Ccpnes#QD6{KVB7P_NYnCS$*Z={)!&2v#zF)l vz8i_;DnZ~pLv;kQ!dxo-M~l18mwZogVXyqszqk3^_$$~iQ(-DJIsyOyiLQGU literal 0 HcmV?d00001 diff --git a/0.6.0/stylesheets/extra.css b/0.6.0/stylesheets/extra.css new file mode 100644 index 0000000..e69de29 diff --git a/latest b/latest index 81fd7ba..09a3acf 120000 --- a/latest +++ b/latest @@ -1 +1 @@ -v0.2.0 \ No newline at end of file +0.6.0 \ No newline at end of file diff --git a/versions.json b/versions.json index 86b439a..93fff54 100644 --- a/versions.json +++ b/versions.json @@ -4,6 +4,13 @@ "title": "main", "aliases": [] }, + { + "version": "0.6.0", + "title": "0.6.0", + "aliases": [ + "latest" + ] + }, { "version": "0.1", "title": "0.1", @@ -12,8 +19,6 @@ { "version": "v0.2.0", "title": "v0.2.0", - "aliases": [ - "latest" - ] + "aliases": [] } ]

    bc`=pmBI+ z#C(s+R@Typ!6#TI=-bF~RlSbzC>PJ}Z+O1?^@na#SBhma*u#Yi2lL|S zxM|j41~re4%BO;u!9=hNiZVfDAPAMHu`~Dn@%#v9JwVgQL~cKrZ>h*Ozoa~tdGbkb zEaQ;dxGgtPTGF~t;jl8wzRtnea09Bn`(Etb-NoBheR$4qR<6c>T`Q*$zSf-kgsr`F znWLrDpRR0EyYeZKDaT)&T2yJEQc{*N`7@9TPp+d3;`P5HIZGgKGFX+<<5hOOEBDO; zX~0n{i8LqWaQm*9Y|4>KQNI@v-G97zdsrv8_@sx#SFQwOqw-thU5xS?^s`q8HH$t4 zJ!ksUq^|JYI84KFlwJ821_!ROD8u~#H3sybR(|vKGp`t2n?_z$G_JZ$;EO}`XD>*= za+m2-Ckmr#RTJn^dmAL$n@#eiML59X=pBa#CvfJh?cwa2tTTm)E~P z$kMNDV0we9#I;wO98r)NW_LsN4X9sgmxdy1|TXiR_! za@dh5`^SwGf7(v;e0U~lfo3CQ&Wv>mBBV}3gHyx^#{o>H@mHv>IK@c%R3UR05QUSL zu^NBKM;3d62DTtsp`jqm3r&3}=p|+@4Qnu;BU$cq`^u0m+Io+EWa}HIgqIl*WmA}YI=9HdJ z^6#&u!fvfqp1oX@9R4=)9pB!JtT0FE1fi0Q|De_f zx``f#MBZc1GSQWqB&h+Hicgn$!3v=Zm(;6QcgwW4xs%$ezCM#yprKKndY^-^wDucQ z0k6357jU#Bl9RqWHj?m;Zb@U9#$JWM37=Ptu$YUm(+MA3*R>@Pa3@3$TIHP6+Q6tE zU9a|9klv_2&na9>uZMJJTzZ5fl5sL_yymm+BND;Q;m(}IAdyM4BnrdRRgON8m^W|Z zvm1sVdvenw0f$~Mvqs&yAN8uN4t*EHhk$2>hhLt~Y8MbkoZKUAB7d2P;E{xRjggts z-pGLC37E0?BSSC9g;~y|;zhsfPT|`>AX4|Us{7PbKhry$o-~WcvRia|PV5ZJD?sXL zW_+<(uQ-Mp`Cl=<3lW|UzQ0(FY%1|M#@)z7!ScNS-UUOZ71*HePi9d6)}?FDeAS*# zd4GychQ=gU_64c^7p|J5O0MMHqxuVl(o|!2rvE@F4R1}v6@xtuux@%H4hQALWsMr% zEJ4W^5zl2Yze%OnO5z`TdF=F{0z_$c58L%WdyNV0iAY&N_cG6dKNzJ!iMC|4El8<(u{&*H9BO?YJNKH}PsSns`U#YGNZl)TItJShYEA7jFVrXKj( zJ<0jCtbI3K^>>|MxEdX1noL_mFJ-7N{U7aX_dC`nnl!U$0C~y&R;?E>XM3JZshCWk zK@A;N0#bkd3~_U>kz;|YY9EN9$X!-Dy)jYB=Y+|$`8Psp{zW=_il0g)38G!93s&vw zV4FG=bUotxWO4>m{NK>{{dWB={C%XRA6LWw2IGht^ zX$No+>lG98J=2}0vjjvG!otd)Tgvvz;Ej*UXsMS`E^lM*E@otNY%b(-dY?{pw?Xvs zv@BX^_o0N0&PR<-kf#+)@wCBqt#lhqs{-^xsGpC=;(7-Fn^0BV3w{e6~`i~aZG$nrqv7Y!$ zk{hhcKpua}iSCF}1hG7oNnXVb1_I62_Q)##MhJH1lNb!vEaIr#C!`s|4RbWxm=ov+ zBy#&-qZIYtng;x;xenaR0y;CO)P0^3&!GFmK{gw@^5gZPV_psJi{R%4*&@0V!ygzP zGTHxiN@V(E6}s6Xp00(yT(t8)T$)RKyC4zWU%ta~tCdN|q@lPNp}bA9*l@F9mD!MI zEm5+Ymrc)XzI8obZOwoTsH9HWEhY`5+GC~-h9;md&&F0pJDxgG(YzgDavlcyVv6;| z3}3nP+~yXG4}WT{dW+bIc{P0hT@C2VnJYb<(SlU(mp#@}u=XH4ffS#gCpq!@m`a^<- zj?R7|PtNTwRh$bSsx*z?2K$Yu_XWWeFJ7Dn(Z6#6VuGcpt?=jxNYcCWv|qRGo{nr= z5BdB#|H3yV-k$xK;K3Oe@x|FKeU`+cute-Bw3}X-r6c5B{=c!jcBvr`LBoRJS1B;M zkc&`G1L)HWyc?9>f+Tl^BbGjplRphKn<|_x1_>y&yAQn(tvE%-jtxnxppt zM}j^WIP>nHkJ4@VL;=Zp;J^3w49GeWoBVgcYT*a4Gn(RWg7;H9l^;nGnID`~Gtx!+c*AI9cwQ(Ej?7Vi9ZY6h5Pfp?%}vpq>LT zLc{s#4FHTTAel^Nzw!4U$XUpZd8hgTmXWK(+@|n;CjCo-dJNsgk?|uWzc%A6=Y|~X z@~Y_3@sqkBCb!J_^)41m8Dg9qAIpItQoF7J7po_w*`OKY=C*)^+^(J7BoY@>_vvmzUYUiermU zb0K#5LO+bSy);$)h#}|skuY-!qP>dr_@XcWvx@f>f!9GnwzYh;9=@d>iGQ=m{#B}A z_T)4I+=jl21Nk7fLC560k!&on*?9vY+0EB5E>sOMCC zgxEUOO~#$$GrV2yP@b}wuIQ(L;8DQvtYIc=iTuK%zL|J>6a-$ms$R$sko2L83OO3$ z{B(MPg?E(JFRf+&Y6Zj7-(AQ^N*aa14600)-Y;VM!!ghbIIMp9Dy^ky+F8xZumdv2 zapCbxV_(&p;D+KQBj(}>@}|n?lkIfQ+4}%42T()w+a1w>I&3FaJ+-7RGr>2Y|7peKzB0O3p{REC*AHSj96Lj#csMZxl<8~w# zDpL{l#cr;3uH@yenrp7+;uN+Z^3ETAtx25%E|?GbmozV^-q>_8q{%7gYUSE@#cR8U zqn+#M=c##z#?`R2%j?qF|x-u^I9++mT>9kwj*ezgh#b_sHGspD<~SjtR^%5#1i)QDJjpI zaM4lG>xmflSi-3M?Am$+aTb6-uq~?Fn;k%ZE@+5iBAM|PQ`(zwxUGnjP`>}x>UARF zfQ*1!cK4{qCX{ptKL-Oes52Qlnc1dXgJO=%t$5Gt|6p<$%@ zsuHE7wn!c-mPcA1EQPNdEy%H$yG%kFJXb9r^&zd3yGOx9Ge}Z3l?#xS4<{JW9eN#A z7)}&p_tKMi9QjG3HZ}H*P|`f1pt#bf3iUsT6{n9Jo+TX}mD$sHPaMy}>4tEZ-n{yDEN{Nq-QM{vmM8)i-n+gD!b2Ii^k|j zt(WTXCU>aoP!ey(fm*&NW38F{LGXnAwzqS4<0p_}>5zvZx_fOvRoZ=VIl7D487DNM z+UpnN9#a3AXqx;^{xq;j6)dPTvwF;XOSqXXB{Dha<=~C6H}*2Nm3e|QAY4DhByC_P z^gV+l-%B)=OX3T>I{%nm8v;iVM>89CFxYmQXYCl3bx;fVJjU$uTYPN>Cf1t0KLO;F zT9KYLVmqZ_+)T3%Z*qlFcI(PamU;p-S~okUjb!e9WHG%#4}#EnpHgAQtKwspT2>Ww z8br8`c4ZKJ;yZrxG2=7#Q;C<$_FDL9(TqX;kBK1l5)=@b@($RO0ex7}T`Bykj+_Wr z&Oe$Qnf?x_liRiFCC?a8f~}iTct3uMZXtHg;E2C69PSE3-Ay`(PWt;iI(jc=pHC=V zuH{uFqTC@vz1Carzj}ZluiU=rpDL)sMCi9C=t5#ok*3b9Um78*N3wO?K2S=k=b4{6 zXdeeBT}!)YF3#s)8q2<$`(ymgnfnk2nznC-G2DyK=38v#MO?^U_iD7(>J?~Mvl0`$ zi*W=NDzuylIqBD-R;x4a(d~oWLT|mj^=iOa{1k^z?%2-S$mz_G_Fhm@H(xb_T#kh4 zmr3nJmM`Oj0wS_OI=SqJkzX>RPXp(gWb7#2=@)pcv{X5+I(WCp6F=~!Cx3~2hHod6 zf#!L&`7yK|FX~-7hLBSpOy$MUP$6F^P1%G~c~HeJ$U;q{W=TTK1YT<-*IOtg9gT{e zU^?KV^o3nY^q`8y?T@Zq_k3x@Ihv1;PV~MxvmZX#6O8RqFBOF6>`Z6pP|J0hK)S!FM-Tea5J`HOjKrkjy}CfQsZ)qW z(DF!$E;M)G`EHflb-%h^E&>H<=VMm$ar8pJoYVkO8EkD7LMXE35w<=9>22m`#YH&$ z;#;TLLtnpt&yX3*xNP366=nO>In*Vu(Nm#_agUACH5nCxJ)-9F-#USg$OF}Tmk z+^%Wz)W+n@&~D)w@jC!pm_}nAfsrsKyA-9I&^CkIA?LsGIyuKrJ&E*?DMhk(SLs1I z>H#dBpX$}Td~J4)iGO&O3gr?CBnv(^srapbthV+3Lf}dBw{O0(GW`^$iYGO>%fJ~U zO>rid-91tyeds&1KVzIj|B5kCqp4>7=AURa96-D8dCKcif4eth`ZLDxFI*6z4~twJ ztx;mMl={p3`o~AaOt-`u+SNWOnI}6&xqh5>Rs-@T2F6J5jx?#c2|!n81IT`ZmPx** z>eX-!(nu?gr)SuT{{{sp*-b0-S$sGCc1@76@VtvO{-n-lCdOGsuy;66swlw(37YuTGs$o&@~s$?^!mc~pNN+mb!7Xz=%L zxq;-9rp1=lCH^qhA=5Sm?h>=)W+V_5mxGrv&28@BD$1SM_&dPY{-hz0rjpn(x1PQ;Tm8lK43fywy@8s~^t4A;E1h``gQ6E8Vn2 zSIyfj;pdoXgqR^?t?lKSM*OQy#vD%T!P_yGP;f4$dJA&Pcb>@iVQ1`s!q5@;BrAka z<@8O77um?@7a+$QJ$cO&Xt?w(}up}YgRit@d)aw z_}K%johmTKgc_fx^bh{g!fxaH%zq{y(NvJ85lMpE>ge~0zBHzzma{AX_hZRN0$!fl zjF$u6@;HAcP||8`PN?;x0Iew)J{TaakSA4FCw=*;m6vJLLNM*sL~w5s%#pt@KE){z zfGyX_d%MsV>BOE&Y8h+ywepx}Mz4FqB^GOKB5x5c;8^txbJa-VW9_L6vs*U!>n85OuC>^TDdc=ma zeoriDOu1i9T_@s}Ym1l-cA9tc3&n+GcyMf_aC*rq>!ISq@trkag*ZAYu?)qNTs%BY zwt{7ocA}w1BN3oeY5RY}O3r376#ocbE4Q96$Mo z7RQ`>1gk;9dIFKR>zf{)TD5yje^e+)+5X*Upvv=oTrewNpJmG1i(FPKwHZX%>-{_a zC~*GNg10Wa2FWHPoJrAC0@d?~ZrTfn zgD0muDoA%y>nsx>iu%KKfb9XZ>+dIT{aS73q;qnkci7)fo24=m-qkJfrShFw<7)Vy z#+=3wzv3(u&GBShc!MxFO48L|Z^KlSg+CspczkQ_xeNkp zrCemsum0yhXnj?u(znrV3*XnoWAEdJ5Bkp`KL-(){nocw+bg?wV>tj{*MW|2O%h$NuV2Hy1|0N#X~^cIIT&jJhnc zFaL?3j-R!0ufiU+5XExTb6UOXdE+zD2BgY$#axoJ&+CF`&?*40_h1IzbLD z*;Xw`l^5*=SrMK1+zO%}T!xeNxf1xLTxg5HU)Ph9yd!;F=88<7L1F@@c+CdmLt98S z2GR>Tt)zg#%7o7f8`(<88=95>n060Be5{k!&x*)3mIKf1hTvqvc|lQ*T7w`f>Qs!W zM1IpeMOIGX#=H7MwyXc#gLwQ~#kpsiy!p@3=)ekH?>EOz z>GW=7MVyh1;|Y^kmxVgN-c~)^!O>(isewaRI;+h(Qvd0`hWeJdz6G?*FFGYG@5e>D z&C)@ieyqW~qu)+2)UavZ_Ram4%i+QDu>ZDRZb94Q<3VrMCB&Fvr?M46+6 z?jDFJEsK4QijKzbJ1)IOdOxdelG#bZdC~lOJ#A4AgmwyecqzxEgswQ1cJlWXg4gc2 z%#R;R^AKbY59f^xmiI^wY5WXfW8k{#@({pRVN%lpAjFF`jo^eNHNBXdQX*s+T?X z^w45y&YyReaoCo_Qs8>owMf78r-FW|@draBxu>WPPLX;{9C7~U3AVI4m|HqcLE^@C zbYJ=IduR@5JJ!dGeN2gTuT_9K@cEoHVcM!oqMcsJEaCK(8Y|~EjSY}y+x(W5^zSko zs};1`_-fxXRQxFBQi>%g3_U!iY`#?{dTMi8I795CPETnNAGdVn9lj#-Eu_cO?xNR+ zo2e*Phr(#hThK-54OJT4XLipt+eVIG_xJaaq1u6iO=8IDvBQ0@aJupp9+m|~&;G6V z8#z?TL0=G0)>kzClK7^azpueKlxXpMiqkLsk0(!F@b6g*`HwxjGP~bus1uM*f{vl$ znxCWFT+^_^oWzT3tizLS2CQP1JpdVqvGp3PMLs(^Vqm3yx64kcTuXeXVJSf%4%EYm zwrb@9r!%;2zf^(diU*m2zpaG)@i^A}Uf{WVeb{Numn@zRqpRj13Fc@Y9bLvB>qXt8GaW$ZLrg*u1 z-u^v1OFJ-)Z>GQZV^+qG0#WaxfB4l6Qg;G#O16{0`yQqX=BO-1pJZTmcXwChE192P zZ&Rqt#4l?tZ{;7@0*?MWTlPm^__j^h){*|#(tKooDV0`nHg7N?mCDhh_IoRN=@xsy zqvI``_fRfPr_eQh|EXdUeB*z_b|%QGw(~fDTWPV~c%bEZi&}n0M%%&lv1z!MI_6;b_d&^S{E%ymfb#8$Rk8n4;N( zpcgZhNq63>UApJ#Ln5WN5LAb!$r#h=tM!xIFDQEeK=$%!8Ly{(xjevB;@3o|C!j(i zM35KeKRL;Fj6Sfx55=9I(_as_GUxNdx#RL)_7VrnrD4Xm<4yqAQmKbc_mK2>^()gC(~!bL#{Es8tvS@ao7-rV?9Uc=sDC(E+R*}fx{UUM<<;R{fS-C z{7g`1j$?G@UA`06JG{Kb5X^;p!%*Gfu%KyWFN_ayOJj3SGJ7^Ka$+pSR!5!adU%_F zvyPF(6I=g9v{_zbeegN^6ye+O0#Xlk5~t$Od^6mKf!nC4hO(i_d}_1qx#K1TKM^yi z#)NvFjV@~O5j@-N&>Vm7!RjjiBAXSs%ggn?0#mXe846XH724|Ra@v?jap;wP1XaoX zcPm@=Z&9;u*Zq_*{q_ZxU;eN*qeKV3W+l1sqeZgcbC_q^&DYmerZgN!a7iW!C9a+X zIuQ-ka|d*KQkP#H%#{#H;)X7`m?SNrBk3?hX%_7;R1&FD+<%_+AKFpk?LDepj3%9H z4L(}f^bsyIl%#wjbYsao^zsVRiXwcpoi*~uw1dfbzEemyi@vNVPkF6>v^YPSj`351 zN<)HV%M6q0<>k>iP{laGVPR#3R)zJku-w7S&X+$q+V8{Ck=ZOf$evd~LLQd$cc8iX zA@uv3EA(I&&30Ae$m<{Q47HC9-5Vk!u6KDXKA|3ze`1fyVY`A9nzFA$qqOSde~nNgO#LvRA;VY={1t^cQ0)4q>s-BIP57h@xl_7;BX>^tmY$D zB&!JlT(UZAiPrP{dHwQVSfmxG|MQkIQY?1m%}XvhlP{(6Qb~U0uon$g?m$& zHTQhO`obudwDdftym39AWi$zIUM7O1m*M*#+VsPbvSELE+N@BNafO6KAS$fN4$z4c&d zE%Q9{)6i?Xs}~PUCFn=DB%G@CtJ}Sfqgb-SM53XAR*`=jw@J27RLq}F&AE?QxjA;v z05z3!74B$h@nouZvENKoY+M?4yi*34ecAKM@Kw744b%N~k@B@bZH|v!&aBeR&mMV^ znE?fFW-mu|ik80!@rPXg>E^Pgp*ai5x?R(M^)UGDd-B~?)yHqs%agC|FvJp_KWr9o zHgz|TkB9TpAf+S=vtm%`Z%=;M0TVZTu8x1~;r9o7kEWEI#@PY1U(LcB2KQPi6n3I1 z!4_a=hKYePWfd|Pqc4riEF{P-P0GL6f9w0{Cndw6+TnR4T$aSdx6?(=w-nv_NLX6zQrIjujWgzQ6FC;go;IRfWAf4jX%GHxy#RCn#Ef4@4#p zcolu&cU*+XHUW+~>(YEmhP=--o(J{B{B$FRO!Sj-Q?fjx35*i}=|xh!;}A=F8=*)% z%yw~<;Br5PgTy<$R~~u7aTg4hfe9ZZ?)o?`DjGu|uf|mnk9Sa9KlX-bd8R&EVX|L4 zuEjA~N%N1-2wsqVONRY4lSnUY_s6I1*aM#EO6I3%3J=CDRjUiSupUH2zc`*6x-JIM zV!p&eRhn;p(^7$otM&SQe`P({m=7zBVu=e2`$BKW1SN$HZ+YRWNToD4PUdp!5Wm$; zLrgqz|F4Lxbi z73k#txxDHhC0te=)ge41>&@O9n zF4oVs`}6H%XFf5SN{A6aOf|d=MW0RrYMGxtUjLL(I6y zZebirKBZ~?Cn!!&^`i!U>NCb`#gc{xO-#1iW7~~0TEjgP?)EHIfq@U+v#)RMnnL=go!S@qO~@|_ycK2_YA9Z(>FX&w_hF9ED?z!X=A3M<{gt?c zVVCFfXx3=E{5Aa)->{o|bK~ndY4m8{qQ9xcC6vRDTfcOLig`}@?i{q*Tb)PB8o?aM z$N{0f#S%VcS_lO4Vm)v4zTsJEU&q#S`4*pIZAv&x_x(b}0i64{C%ulMG`ZDtvZ3f@ z)ZxpwC;ax_W?y~b!K~{*hmc=^jO_}0Qn0g8vBl5a0wMI|+Wg`DjubHp+ZyhZT73vm ziVVo&pWfnl(&nDhZfNbkLq}9at=JA? zM||B7lJOCG2as6?+e7OzdkN0%I9}EK5x_TAafVqc%U6)XD#&OkE|6XN{z6USF@Mgx zIV#&qT)G@fT#pSb73}yZ_K$*U7uEUQM3l+pa88RSD_~nuuaNex@&EaEWP4ODw10)J z0gz3$YmK%aFDK<^UpJnnZ^m>o-QK_Qo9T=#sPlc^O!`i)be{&&R1vn_qLH6Hic zJy?PCk)W1Bb^AKq10Kn{78b>H4vRzT_|tH3k5ih}_Q=Wk+vP-jE5>>jI~M}j7U~<1YJ)Q~shA`;Yyk%J z3RfwywZz+Qo}NCh=Lqqt>3yUJtF0mn8>Eg|9k-kkm6l|%DUR{Wc1ng$M390#vX}${ zw6O&1a!ey{565hK!bDY{TMAP8F&Y{#t`+C`2D=5N8#SD=a=}uWN@y8g-@jgeK~+3& z!5W&A)K7W>R}%fQOeMRaYtv=LY-IaI_o1Jb!TVLEQrmdERsPO|>R7Jd{PY*p`qK*v zRuqV-Bn_fJbb-jNiuS-CwYmeVQ|q!5c5IymY3;8ubgbg*f0I;z2T|yY^bzuyp1z&{ zTdy7^gsFga0_-QzYJPrIl~x6FF(nC$TFibie%vw@{Z`mrDv1X{u-E4EBNf$!dD!RU z#zts4mOQ9!CI(iCa%5-FzF@r7PR;$7wfLjO@oJgE`bC6Z4?&>Ru<-vB$#uwcXvN=? zm4J&2y8c9zsA)vSX8ac@UDvx8*73}|XG=8`gRfBHW-|R*N^)r^^mCj^k`p4@l85?leZ-o~WY5~7TG{?3!js36K$%HPdw>Bf?BLQb;NgGLjteQ8jcd?1?h8XYeNc)Ksh(<@!ENMN3Z)0_h z<}iS$1TT3bO?Ofp>*_vV>)M3{1N97*Jr?9x+{;bpf_jmp<_-Ys+iuh!EXUcSNm_&l z$%8}A(SUJU(*YKlXcku%(>$K-aB=ng@PV?t{}+@OOa43LyBlS>ZHfQ)n@EX0^$R`M z^3lE7<})4Y_PPseW|6nQa-T*Rf^z8sNUX`g^6DOQfPJyMAc+cOf?JP*vU&gfzKC1c z@7^x*3!$d7ow|TPxztDA;nL{NMf_~%*~>73LJ&HfH=8f_-#aYQG#%(C(_Rh?l`tPl zjv>yfglPYIl=r-m38NjGOYn32=tT3H?Q*~V&hR}c+=2Li@*l;Q2+>+*ZqJ)x1-f0e z1$Zq4GTLge-nPPAx2z`6x$pZ+=sl^Yt4!>5*`q(6b%+ z1%Ig{qlitMSqOusy!f09I8|(B6J#XuKQF@Xx@WOeGnWM)BnTjwA#^Hl?O0S^x&p80 z9F@6WuK%Mb5pIwsP65Iw;1>vUtlfNEyjf-_i(h+H zRa4*8-)%bmCxY$s$2yeqf(~Z#*-3|G$tnshn|v%EAFcm{Ps!e{RzxP^@A{BGp(>$(q}-F0{}U! z*5#Sr?{LrWKFypFp38XW=gss_A>9fojE%jnWnNxSXNA?ww&TxAY(qbD$>8F)bNL5w zoIRkhmfS|^{GK(~=leJ2>aXhggN1&Sc+wWH9!PGKZ`GN?u2)0PK8^h3(EWV;o2f>I z#ZmDHb4orx5uN(m(?nFh=~V z9nJ#HvpqIHpTT{N*!l$)VxSnx4hHW94`E~tkrCp*7L}70QVRSADsjI*lyX&WG$wzB z9-R9EBlr4KX=Z^oQJi@xIhd;zLLkn zGNyetGWBWiy-2Kinzcmv-tW_j*FSss$Ds`jlG}qzXO_Tr*uM>)`%m-vpS9o-#I?O+36-#NPbUDj;~pEkiUcNfjU*sbTda`r^&A`c4v?zO~yPUOOdrJLP*pEXh>A zQ1K5Ktm79?-fn<}JhC|SVz!FC>J1v-tr)DoRb7|PX(ZJ`IN2Ch3F@yCDXq1b-|7|i zpZ#~!FLwRZ?{Hsu9ikTru5{ZFu{w{hgNvy|;0RF3vso4r(;4XeYxxOJ>bg#54?8@d z{wxs)X_>DA9UevH#q-I$?$sJP*`!*Eg^q@w(W=%gd0?+`PwFMTs?+eaOi&Kn{#Lj|>eKi#zc_sXr+ZK>Vw!UYcd z&J+{mweNSJ5ig**QoM>;YT1&w*mAv2k$;N_j-vrFA}(iu=ktE_6OcY`W`551uKJ4G zBHh6kAIwR6;;(Ic))&p-@BWo zN1K0Fm_O1Xj@_DmM$wVAR_fI7FM5I91(1vMGJ0JW^yg7JRJ36G;lqyjJ&lgVs|O{B z+rVznQ5@PXJ+A7*ZvId0g`77Gy`JS-U$@!kq@`<#D*?8sN@nff=-Sr!cE-$hA0vcK zCafoi+1f%`g6x#%@FkX)@;Cd4h3c)h-`1EDJJ#g%dvbN{`>+}~l_gtih^2Jqm>h1s ze}=|_5j?N8;P$Y{3FtQ&D7XB457ah6^BCHC30IA?e&|Matou>8Ke*Rz}<;{EQ;{6&>Vh#XiW3>+E&SD0@zWhQf1LK)KAZ z`Wt2}sEx#mQ$6a64LMg?^#s;WbqLHcfKB$zWF3=Y2DXE`C*-HgXLMnuZ}#QNkLJJ+ zeUmIDSmha|fD;B(z)#lIvm^3D@Ft!jM>KtS3_yx}3oQz~%?y zNF~kcTazb9Kk&Vg_zzP?2l4w-^SH>*av{azVrEPpf8?q8=jB#T2j3^2SYQlGkfC&h z?>5Pxa;W6K(Xh@t4x}P;H~Xcz`bO!O%=gTTx(D0K+J4Mpi!rYwGPp&X9!eScHvv}J z6H7DPl%)sf1ts+G%*D|i&~~xe&6k#h!zY((-|L{e<3r(iNY3x|kuxXz;Mk3`>iDeV-!2fc>1PP|%;N3br594g6+du8yp_32^ zN(Q&?aXh2?xOA!BoovFse)#2xA(kT>)!QjoS0Z9IX9l=j*4e$d7EyVQf(fgK0e9RM zX9O4alN+(!K%tMuT-g(l>yGUBJt?b$1M+qOgWc`e`!B-FXp(~a(v?1V;#;JR{A@f< z>a-wO-E@))qhO+JZ6ZPcgJSXv8YGWrNIfMr5ia5(R(AHY?M!O?r?<5t{p$?_58|ca;<-dWkz|BVyUQpuwb`THr2t33*@#VtB0?VP#XF-O7WSq zT$X7OVW%4v3dLWLMJ5>}h1U7ZdOYpE&d&fJUv(onp5}!3ydC1nx!=`V&;tomukt7s z_$-mW9IRO?n>w+T>yrC^Z@6}O0~2K}cUWML?_A@LQI}K>fX73zct3GO>G4kcpV}lf z7PR*)uHQs;@Z-C*SL?HMrRLcr+{lvpG6C`&w6a zhw!MV0h7wP$NF(!IQ4d<&S19i8|EC47yg%@~EAQ-6sGyFA(}Y z^M+r!Dp+M!{)`7MmaLBOqR>I(^nWFc$-v$u%utb#^la$K0fj_;MZaz9)sMFsj$F_ zcd^eWa;Y4g_fua+l10A|@5|G4;H8t9la}bW*%RLSEJ4q=*?7i@9(j^N93oafbLeHr zWFtZCBky<{{#LdmCnZZ~fptE;&MU09laL??`pd59S#;CWP;Bf^XhUUXSYnD^Pb0$H z**P)o{7J=$+Y&81&_tp>lUnp1t#?7xIGe%;)O41IDE`gsoz8C1TZ+r18a3Aq)mTU9 znBKH>X0#CktA1KN^C(#jvl(^lNjy{hxwMuH+1Y8%H2Sd2+Y7_rTh;Md6o#htACCb` z0r_B{rG+f+krRW9ZTdhXmaLw6{;w>fp~7=(ir>`YB=-zQw?eBpQl)1Amg(W|LWR@i zlf`E@gL+vQ9zON6e`yaW{@j=!EFCu<#llehioO`>7U=u}HkFGr;l{hPmTLRE^(HvxB_692Gf(-I&qIu7D#OL>2YNDy*u{iRfs1q({ zf#z5VAx7sBRb*Ko>qz+e*WaB?v_6#4fQe&eZ_oLo(z!RFr#G9L*^H;}Kq!#G*231N zdC?rCP@F~R;;?LIdabvznKnW4zeMgSD@)iWjWX;qE%1vg)3i#`^!O`XFB`$`tb#=G z8FS@ns@)GurE#H9Hz8f7gC@#%D9@Wx4en}Y6Vh6w^B_;LpIkbuM~<=A9QW>0>UqrA zN8rzneg%SOKG?3>2cm)Vp1^(I*b&zlt}=wLHo=Tr;=P_OB(lXXEEF((O^8UpS5Fm~ zrv8AuZ^cu;aSclX3&J3blxPT9>sv#84DxB8OQV1ArUUj*OT3h4dbcx{UVz9vs7N@UyzR&la?!!#;!|6F}GKbg~T=qm8EWMt2=7$H^wql7XVwRtu( z#6w>r@HayjrP4kDp1!3L+dTeUXYgr;Jr+W_=@kqC+(h4xhH$&@%S`E>$nDvqCF{eV z;?55RCY|e*42k{TFRpfHd=Q=I=Tu-yIuv7lJKsS}JI?eCA*2Mlh!|#z*4~w(c=P)f zTgC*ZdWY7uA5qAsiEo2@6iHnnm;`<8eW~~Z^4hPt^*`ni zX6w2z!F+@Wv)}!y;Ao?Pe=?xTIIh1*${K&u2`_6xZ!CZ| zf>7CbitoN%vik;WcSA%|bJ{0|-F*M}U9wx40VykjDp!!Dglu-!U(2LBn|~@5jKy~I ziLQI(LBTy!kUn8iIeK>~kfH~0ad%ui8hn3(4IYSIcry`bW!dIY>gQ;Di9HUVwyk?K zzQHS3FH$1&O|L1( z0j94SR*M}jGVEOI68}7f7>;Bmag;Y6u?0bmf`Km`96e3NmYpM_eHnUL2-=g+edBYp zgzVBj^ALRUrs`wA_CCGr$kUefR-?9auAcb(McHdl5%4ou;0~=KY!U|STSKT|{7Tyg zj*kZpp&<>N)3@72gyCuJXEOxEG#H^k>jvmsMEB}vGYkD$UQ8&u`g=6jbP{%eGG!j-=`~{nUW6ej%T&v3g z$EVfBpsStn42XR<7Qr=Y>IFKOl zH@c-rh=F@PY@b@ZE^8mXQUXE_%1D7II<}H%p`L4przg=iL*upHSyy|q$EAe z0c*d{S@Wj9SG)tnlLZ^$p_c;~+6B;@7{Bnn`rXP88 zBxM|V`_;xAxRF@+Q1eH!I2Ct^Yy4jwbuXI_@+8!SPhZ(ca7tWGH-4(ECVt11J{pV1 zO0N)egc;DAzw?*mUui}aLV;H&2~J3}oF zqKJZ>dGd=C&P9yxrWg2HLzNsYz8z*65UcqYoK%@_B^-aTS^f5j9Up+k9;Cvlbcl4> z3TiL z@vFs51iuZiyt0%?_XLoE?-%wzDB+_KpxIt~z=B}Awl?|lDf8(Phi@xJ<&ZF}b;fdJ z?W&4l%4d9y_?4;9w<(^FMi){VZ!5ff9~U90!a+SC&kJs>tOcgyGxpYCLz&6(wa??c z&c+_<=ldoG-ww^k+ZRsPXC2-#nyCBS%bT++cCqkYdphKpWfVm#?)z=HeIIp9$=SB# zwpFSO`szunN12_VlM_HM*#@Y2&qM@Q{x@u&W}CjLsUn=NjJn-%*+N5Z)eZHTXT$RA z$kOyacW22hnZ0`R=w4?+2!5cJB1VU3Mk?B)z1f-_Vv zPMt^V*`{8Th`RiobP258q=j=XC>G#WH?_Q7SCo%sAL9P)ec^E8#? zz0at52cL~v`076qSHRC*(3pe68G#^4ET(u<@KpQT_s1$AB6)5im&^3SP$TQLu)_v# zmgTp?sKuxSd-_JYMQ#F^EhnM*76_C=S!Mk|>x_v9j4dkV*hXX>q;j~s4H<|8g zkCa=|al=ME zA(;fF{9#XZETJTK$ln=z08b_$%kblD(A^drfxV8dd)xf#nfo=hWHWrOoimFG;8f`Q z=oF5i4*le0+cjvH=mG3p$fO&458X3pn39sX-rR2NI9|*2qhj*;1A19+x&^@U8@3N& zcwp%A!`LY)IO(H68e*9C?feKKbkR=gbUUN0>**$XSAbwgtyxT8xB{81=iA(X8~sP< zp1*R%ekes8vK6xR;Ydu zqj~%^+%3Y@c2)X+EhU^)Jn9=OnICuYRWXwUl)L3HG5lB*BFKQ5FOMMQiJ{$75Xo*| z#Dir*xS1od4Px@oY@XD=^&L{1{+X;OUn+ALlI6kz7)4OF)M0f(EWg8zm7by_Iybow zp-vleBsdP2lB3EX?gGKEJ~G$z9^N-S(muim`w23XwEhb4Z$Ou{a~4R{v1pRki_g6mNmm+}M%wE^{(NM<4J& zTCX%GAiTdLdvfk2QBoa|i<@mSf*k~fHwXPUEwBu!#?HBBiulah|MNuSoE(jb2Z6f{b(#&MvQXn;EM5&&0G>9*wwkj@$InjNO_A#f3&=!i|#K z90G_aL16b;$c`$(Ge4r!5H-==IW$yy2YD1_9%w1IQ-y6rjAP?kSK_#=fV3Z;04_~h zIudHXDVSi2%4S6{kRpVED28yonH0}9@ED&_zx8(JCIc@=?Hkxv!3R~96HtTqYOaQz z9UcYePX#M7kAxj_d{!`a+Zhavcs)ePSGJFTb3Z%!H480N3dpFWj|MAvM?N{ZcvV#QQ{!B>Wp@vtaP27h zB8)4ldgcas#h=alj~Ff%^&P4{db6aFOz&D`jQhoztxunaKo$yL?FJ3Q_(H|!XKG3*v! zo{wr`m}8q=PZhU=b^_NcoJA+VJx$|TKTGx>`t3@`pFPiauK6m0J^d9lR>5%#&|H<6X8dZhVU!=uMSSw~zTmBSw8}AIuQ?n5cZT^6WjPPx9y1mj z&bF6o9mx}SN+c&_A#i@>8+exW zV!83#ugE{7if7;ww?3~-gp#2JZA%~voVipM7ZjaKMwAEU7eb8X; zmASJ$M_O4Z$zo#|o!M&s~M7?LeSU*SkD{0QP85Jmke{-uf=Ogt5a7 zpEkv9iT%8TgRxdcbNj!fK&dQV)uZ2X7)=BwSa%QMHbc=Wwmt|y38T|&`|!us4QjF& zr5QoClKB47qd4$PkAMeR8Vfb_z*3;4;FN!$_Lm*ul>>+?(gE*HWAzhvU|4I$r30Fh z>*MgAmt+|}fj0w<#{~hV^+Nh*p+ix|Xg7VnR3=#_Nupt=fQ_5g=q8SK_S=x#4FA)e zGLf#QAEfqd`D&OzGm(xBu4&1{F}M_C)3cRn*;q(f#r|8c#RBo9LD1f^QB1ZuO;6l) zEokx5^)xuSywgK8{M5zLP7?r|5RI0b-CcpqV~>)d&?zZTy;bS?vo(lk=e5&kjJxGH|f@+hn(+A8+Pq}fBKAfo`XV<|v3(1Y_< zk;@?_Y|pXK=l3&D=NPa!q*V12nrZ_!AU`OZm#j(28WW~g_cOcBJr*DgWSF1)`Jl2o z=iYp;Yl)Z9us=|!^-?LiLfXl60cm`;KqlE-hO_78Y2(WI0QGLsWq{LagMNhuQqjKr`Uu=i z$=9UB;_#(%&9}I-C*J4+uPd-~3F7hM{;N?J&%Ve%`{l?m1wuqAzvAhAXxqU(zns?r zy10-iNHIK9NYwbed~=0s=M`TFGqp(bd*8!nFT?gyStkd@vXcN0Nf9^CQItyC?LxTP z*DWQi@7;@Vu3C*RU})(Fc!-Gt!{@)=@b*y>`9#a16|IR&CjbA-CP`qL$eoN1o3+IP*UX3_gb5zaSe6Y{%6>bS|Ij~@2=gG^v*EZ;dkGAUO6|o zh*9<@EE4u*HE5Qq-;It`z=YF%UIaMr=wP6}zig!rO`g7M$zcV)xNRnZ)>XnPD1`Mt z+I#Fem%NIad4hFQ5v&aTt#k#`UC07DWmv-9tN?C3V^*3QoqPipQs=s}UK+K;6VT5& z%#S5vEhH2tp)(Eu3X$}7#;3{lKQz#&PhHB5N-fJ9DL4yxsB=|ZTa>fQKuxG!_@T`*cWdX*p zSKD7s0@pS1WL22{-LLVM)aojg4;Nzh4ud8?a*RWz8wdx5#HE1QGz#rI0&@s;7STF$h$uTcFi{2U_4B@2NsA0i*J>^yJ$9>k$aF+FlKH3){2^i@%<>RMw;d&}u;KVj@ zlK^0!c>(DL9YTd|bjv!2^eeb@*QF&#S=c0dD66ErZEN%DGw@aHmQc7ixW|S)TQ5!|24nn)l*eLQxPoV{n z1k^`w^_`zL9rM*5;8tCqNcwH%Ai+{%+OrmE*5OHTb-ks}4aa6`->9!`pA4q|wNiRD zDRRF6+m}$*P_RkpVz7WL10&L*P#33+e|R*=0nRxstl+T5HI#HHh@zOAydRv&B|}Xo zkW2(24e4}Roo^~Ej4RwPY{F9&o(#|6 z;|4xpXDG+Z22+_g%#n)1%MCebh=IFA9abayGw^j-(|tNX`TX>d_KlbU?QWJ=CkAat z?Q7cK|EGNaRWUn)!C2NY17|)QHaq>kg4tS(M@Jf@Jd*Z)iOuizH-YX9?8>LQ1iUoU z5P2$n&z4zcob$5xI+viucED4egAU&Yo&nEzzAJol)FuEKkY6{qFeqB}em-Nw7eQxI z@NTQyNy#(zq9_Pz-ZTfu0*Tl~-?M9M?rrR;P*@a6%ar}ebTR zJ^$ag=m5}6$++y@AEv1Yd+gJKg3TlL1F>1`(-QS+D{_tVj{A8I8!_BYK_c4K@v0IG5Yv4cz^^1IKMy-&`t z7HuIGH8(f~(JD%osO_n0jhI41{{{kIR;yiSFDoPh#a$j3mA-R0p@+YbD8UC@xL1UH z&O;oalt$xp`(9O*PhiU7G9diL>mT|%D9f#6J7sbVWx~B<)<*E8N!+z}m*=O#Ya`e?+HtwD8(%O~b$ZZ=Z za&Tt>X?=|Ca5NqleBbiUQNV#lcDp}C$b3VY^X_TlQhX@=UsUvWqBO}stIjY)L|Va& zSy7hX6u)8_}F}nb@rgVM_O42p7MNL^`nKE{DXgSuSnFG?V;p>T6@zVIO2N z5wA<1GHerQ&_RBgp(Y@gH+K-;YWR8cKZ3MjFWP0xC#cuV;^kpK)7QR%t|$&qu@60* z^K@@wpo=c)oe1s2=X8rkO@Mt9Z_2s(b8%LngX3s=FoyAcT7h{%ChZ&skmBs+r3#XXrmm#Ax3=cN6pvF33Qc_@D7wZo4sQJJbwP(iA&LFy-zCHLCDT5EKT3|80-bK7rZ8#Wf3@ z(%1*aV&^CeNaJ%DNfvV2nmrt+=Bf1|qT@r;+vVpw-FKt=I{BiTl^>v5B39qGxke9E4&jNm{Mh$U? z_p)CbgzPOd7x~Z`F~vYmbtQe)_t5M;Afvj3)lJ;Qx*8b6`nY9+9t7Ucb?w>zHLf+v z(FaN_$&mnF9LUO{e)eWHTB+}h*r%I6ZXAqajy)r>AxP}hqw0xKN9fpSmKMM4Z*QK3ajSC+uzM(&5 z!)Jg8Mj5wxb>2`CosKbUQ28L+CM4970@5#O4D@?5BDwk;dlagoCkQ+KKaQ?5p3U#= zQ%WgP)nUeJQKhsfMPl_wi@!bS&{M@#Nqn34w?oDW|@GeIoOc4wgkAq0n{FeIb+V4VJ z{sc3|=^es4LJ3l!bKMYY+kjrb_s0yaV2|p`Ha44j7+hoIr+2BMTq_sgp(;_`NsmD# zR-UiFBTkPlnNC*S(iEfG7rA;BI)ShOCB%K1qVRA*F`F4WAkV-tRg3KUpFK+K&XVSK z9UVKI9tM=fL!4g9qO9s!z|H}+R0z8!l_jQ@P#Xyacvex9t*ElK+WlD#=1_o?z#h4$ zeJoN#@lOU&_a|3Y;yNClV^jC^O@3B;txwb_VY8Rm*<)Md_kLF-LgL7_eWa5%Lhqk19sjJOwVyW8gTLb zaYGEnjt*^uDcUp1AszhRx>m{iwY@yMntyd?Vcztf6;kvM(#oRn9$WnZ)J z^Zwk`nQo;UCfgNI0|uxR>$rR5$;s7Qxn+P3M*ko@$F}}kcAt7XLe~{&Whd45o6NTd z{KJ~Ec|(1gRJM$vg6*=nqV7yg{Cy}dQT4d?`FLu?My;jhAXowMo+h?~ZS-5&Mw+EA z91<}xt4_Ql^@5pv-FluJtjg7WL2Kb0jkGQa7Jo^Y3R{Nn2Y&I+*myUPHMutzyeE0M zPrZZWm`I(V_ok3?eWmT;>yf8HOQ8r(jLTbIdT zuY2ksvT8Hp4bjaq6YZ*$sge9)}bIKUm7RK92sU*GY4lb#}#l`jmWJoZ^ zA)9H0Zak6Ex6e0gd#dag7b4KA0N71rxVMjv!6P*<$HE8f>Rpx!=`Ch9d2`hQ-=bI3 zRyY7wE9YX9=j6q4T-)(WDcjmTt~gn1%#jVos1s%7 z=HSi8`1&TW(0AQ}G%eEfwAQ3$1+`DzV4o;RzK3+ctk2#t4plMjRLA~Brc#eGP%_r| zztH9AoQC_E%(8z+Io*BoN#}34$5;=2c6oB-%8?2*lW=pl(-7%DN>|EwJ|J2IGnS@k zP#i3Ce91Y2<7E>0>>2+t2ot7!rReRCNt(%3_s9cOZPM8TJ)OKWq~iGJ1u8D)?;NzI z(r3P?g0v$z5cp?R1m1KdFX_Cmlo{wa@k2Tjk&D(#wM?AJJn&$ZHGIKNonIk;7 zwOXm+z8h4e=kT?;53Vxv)OsH%n};i4mwY!s)qdWyV)Hk>q&+i}C+lOOHpuv#J*WR< zeS3~y7XRV&?Mj;8_O&X3-iN(+HO*^^mQ*Kx@ulCSs#DpJWzR_g@PnE{wvp~ih7KdO zLZ2vyt*M(odB_-!JafVGX4{y|N;uUZH5{Wj7AIP?r_+|x|L*blHy<8A5a|*g*4vOHM&CYLow}(>DslRZWUi)<0$Pj5ypb591T!7)PuB#Rc zHN@hmWtx_2U5OKGd_4hRGN`I^EhL)N1sMvpz_j0yj^f6oYUWkf?<#wl%(f0x@JdJ* z*HxIwBL~ye#DujE;&|19mrj9)!W+O+N^pIVkxB|A@j#J&qAv)*haMI@zN zIVG9ix>T6KLTKvyw^EG1bVppfU$tZB&G`j%q;e}=dlaNK#gOifzLu+gh(d}H2~_eu zeP9nNfjglX!!TfX<|JfsIfq_xR_R$IH}xc ziwfSCn`Qa$&{V$r*?6kuYNRrmp=@Z+$`W_%^mwdNnR*JJ#s+V*=R7t;b@*g$OK(`j ziJKDB`N`K?Yi@KSl4jJZ5SIGZj6z}IN0iJ%9P!P~1>-uNnbtwY%qr|+2KM4&^7N_i=czcY!2B?MhiG0OimG$h(;b~pbm(C>P$+}_ z>2Ew3XsLZUXWN#LpQJYzgXhVZqV+r0#b} zeB+fU+lbnoI=v;XOY)x~#HoN3%Z*zs7DJaF();YCujb9g4;Q^)EL+bug2O+KM&|qw zdX21}F`)Pz1kPl3T$xzgTKtqx`c9=$FtS@IG)lT?yHDzK`FczXa=~-Ws60pg>t7l> zy|GE^y>Yz~rp(J5R&g-cLU2XBtI_ETai;RiP1U+`ZQuOL&wzh1`nfTgt1 zPMnvT#_{cTu5)l3U~oH*ikjWBcEBPJ=Dc>kmCzn=xEcAtRvkp=FyGL_m}1xkF0PcD zpLU1iy#A$^nn%Y6BS52NO{}He8N9VK46boMq1@ZZ1YjGsItSIicyR9r?LrD+0^=ms zgoK>-+L`pcYW=5d7h3QK=ClH8-4x_-Qd(dq+)jZiQp#}cFfOwD2PMYK7Ecd*VApIm zwWw2q0rD53Ki#(AHx#5>`@IZ_zpeY^Ps3i~pA?bjGj^{l)YORrlssgVsIZiGjTQG= zb80Ktve~qLLka#MDd_rnN0!=@G4p-Cg8M)^JJMbF&_5jeZR#x{AaY<6jS`H4sMkiE zGR!qWtM}-=Uu@|0o1~!9BHq-XI9nutd}3&OF3JmeQ!u^W|dVT;2BG)e9Nt zifnvHw)}Y3Y#SU^*sNWQHsqyn<7JYeYBO(%+zpvI<)<_+H)FL4r*#`cJQ}nw-y)mN zVd+|AEjcj8#5q~yM<#%u93mSfogq)mfp4wR;q~*Fz3$~QEN}3dNTYCxllC4)zwHY! z@26YUVi;X$?GrBK&<>M}n*O9v^l=K9Z?raRCRvnOK&o<3aV{&tX-00ea%rC4ZzAbb z-HNH946^Mr`Zww8SPv2!Mp7uk##spMjdK^i|66-uzG6BTcoM$g4}zuj>byNqzm3o- zPD0w1y5IdBTRMXX_#RfQyx=eK@mmrzIrviFUHm-)(y--;GdzuX3==j#8~^+=px8v^ z^VX>}S&7QJaz_6ycHA%?HEhRmynmR52t_!#fgCR8l!drfsiE4ZGNH57;vh+ep;q_0tUmMC-r$IZ_|T`xDFs z3}NO=3+GnMo#S^Nx_WTFU;lnOtMNgEpwwPxs4nQg&cJs4s}D_?)e$p6-sW+hut zErrI2jqn*x0z2!t21Tp(o%}*w(4?(ALa^u`NjfyFC_euyi%VNA`C)JJlnG|7b7E9? zy&kv8?cnxDMonl}VbI3$e!aME2wNL34_C0zqg|pjYd*|77EJPJ7s~;YFCmSeO(N)u zt!}-^0zcH3_7X-*YQOQ4{L@{}*4NXX&kLZ826>e#%fQ%@e&oNSg$C#MSP`)`LOtx9 zQR^KyVaE=o?`Z@X^aCvQ*hw|~`A_`(y@|xXrUgNO@uQr9`8JZ@N_V(MY+Wt?Ag(N! z8TI(*t6H=c=S1QT(x|rSw4(XWxYYK}()|(-S5;OMV`!6?i^^O315M?UC6(FdTVC}} zZ*PM30OjLtBNr&VfTLTx!0U(k>@D`>1}0BGJP|3=%)Uo3HNZv#<&p^DO(AU6ai`K9 zt_A0TI_1|dhi5SZvCWUv^4PPOW5$*g4&QL75%p%NGz$Mi3jJ{)?8EP%;I1Z}D%9xj zrFuPj7mF_&8O0k@nwohp&N4IjGvB&_JR~RFS6?vhJ&WBn9UX_pDj$b;8jT)57|t1G z0{r=bp08``R5B{zKQ~9&-%H&pKrJq~zq9HV8~;O1!yhkW#rsNp_5CE3w)t~zR%i|CeBak!2dQGwlI zqX>trzUOM3)`bRss|(&V!@_5#>L@klxHDMrPc6|CpS&c4mBm7A^XmcOiq1@sG}{|D z1Z{p$QMS2cp;N}U_7y+480M7~=&A;iKXFUGW%j`hrzlC)-$FKj0m6dG$9{|3{M9OU z#W^Jmsyeci9eyt2^_ei3_xxlsH8JYlDb+T~g5=NIeD#KMu62u&yLZj!Bgb;7%{ zi;?m?=5rCaKwyx;*C@U1Dgq`cP@FITww!eXq46)VpG|QHkRl=-MbU98;3f-Bx`Qe)&W4h@ou10 zLi7&!Td+bN1>x)H^o#aD4cgoXJuWy++EjNdaSnuxe46GKI}=a}OZ&=#^=SsBV5`@$ zL~-dLt7o0Z*{vfT5;`$!=Q5VXfr{C7>}A0wL5-R3F5)%)d3J(nv2@#}psmru3c3%| ztH^Z8{5&di zr`$cN+o&-y^bNIs=zjooHi^0PDMts7MBjBMVViTzDaJ+%rK;eS!m{6IhL03@8JGL0 zP0qU9&aGK9P-dS8MiYBQ%VJB} z{?N#ndF0tre%P&GnWFo)&D(por-~>m(WsP{ZhS%%$Sw`0ZlECb{;n*Z^di1 zA|shA1PSZot)OJ-!0~}h24z}#zh)&l`}l>SBo<-U71DZT)VT`-D{ND&rpn3slmgX!`*meNLl(Kf{&bc`e_S{}qe(T?gF zOD>!OUTv~FrT5bJ_nR|by6K&rejFJ;;aT%F7vR&=e2rIqVw1C`j53%cCQBNi)Th?X ze3$D~-c_>UlFmD^5zyW`D`P*W$$7HVA&U3EpNkB}sz*;%NCPlnq<}XMash58X$KsE z91LbITxn~QlQ5h8piQB?YFQDt*-@kNbdnaLwkhS=thgZ(PmAz8}VT9C9(ZvahI4EZq);(YkXV9@D)8U}I}aTY=6>EixX@@#-&bF5Eh& zg)#jP?C&Vn<>5%Z5P>~^r9y0 zTyc8|s<4pFXf~%Mu4Y^f&#qiQ1g$gELGM%i7j5=o;yu%M5NIRxBpG=J5Vvx|Qh%yQ zB?vOZa{CH_($0(4=p|Xd=;f4ZBQ?QMN_iJ@WC_Q(R$qagDbecDFqQEcmmmM@2>ma1 zJXm2r>R?&~&*M$Gv)S#%A@JeiRiL|12e`-XP=as=N+fn7`*jr)0pO4UM|A-c?nGt~ zbA_0^+Uj^G487H#yS%T!Bn9g>FMF%NB3D|nn1!WB4qb!Tj7I3WXsSQ$LIV3~SI@}2 z^D#28+*&cqZcom`yKOp(ZHp9kRxcV8YcwnM?CyQ^DQ?ZJA+ADXCT{dbH>d;<8EVwfC|7|!dn8>YgLlF|ZX@lvcC`P7lk$PesI+kv9LfLu{~z-Il& zFDL;{Y7|dwxn~V^P^I4TnkKPsb=J& zt*l!fPnk7uZ5>ohfnVnXF2}G%g~g+yQnc2-6F9VP8pbav72a9U*M@_lAHjq*CT2rY zG>dB2`cA%^oM&{SpnjL9qo8K@w-o4^x_0tsEGX#$B;wZAGNS2IPpUb2N)hE>~o{Y!{by zqfHuF>t;Q5)Iz{!O0&b!KT58no`N0z#zz?54Ol_x^sioA^&P`+d`< zx6N)^#2PrmGd6`(T3672A;1T;O~LCZWovVUQ%aAQ{4ni~%{lB|g%0zlBWd0$-D42e zF?;Mu9M|l-#V54+_oEM8Z-GBDCWHuY#{Cd+tDHHqV)t1%-kSV3pwb1l_V(&IrZ90U zkPtBvc-@*-p#PM;0s3_=x>{LuY&04Q1z-97iJDMhzW?&X)8k2IP0|yWs1Iw(08U-` z8g+Qcr0Ouc&gql7-B7_M$~;OsL5Ab^b`aSX6l92zENW%i{2492wd%s)mHHcOWBu}h zxp5CR+PJo9f5YV8>Om>API>kg)Wh*?P~*c!_1s$)ArxC**T@dOnb>7X1`^t2!mfn# zHQuC|b%CNG-QfKnIH$#0TRM1dm6hw9i+DcFv9odmquw%m2o)E1FBsg_nHQ@krPQEJ zdW0zs-#@TK(7t9o4iAo|9a}hh$bMJ)kIBEI_;ASVajpaJ0*ki7E!AJ0od-ZDX?(8c z#jN7)>}D8=Q=+?X_Vr;&lX$J{QL?0ZEf6YHr@{?zepe(EgE@2~boq^ZDRqs0=V9zG znpI9u_eMAmDf}l62w-nu-c$Qj5b0EfVe-KILNqz3SLAF~gG1@K_bN2yk^5o>v8ck!_t}mXn44b>bk)2`U-n z?5tE-#ae4KKIY#Ka>E$<6MJ(|Hze+`2MwA0Tk7uyj|69xolG6N)|E|Gd9K=IQ>1*y8oW&_tRSL?R6(i|V%E+^`>l%dNbOSGQ^4h!>Rr zuFp&Upk&hQ`>>Nv(Ny$Jwyso3ppcgY?g3TAQv1h6_p@6!9EA6l+L0F!dKhxl#?%cV zRen70TORBNq7p4`4nA(BX`o047Vfw!ChnUb_!Q=D_)a+w_!kh9xfmARJsrBbG|+Q& zswpIQYYoGGHKNiDmUN$N*s{}bCItt@eky>Mec^p^EP2xQt5=NinRDehLlZLMpCUnB zli?}5b8L?Pr}Ocrh8SnM9iAoWoAR-FI{HCBZ7Ef#bHG{v4%2Y~tz-*_WRNTHKyBKstdNxCK$vQU`U9KuZ;dZYivDf?}r~Ln}QMcUNm~cE`KWk|Pqzb)bZdo9e_3ZPDrIvONDZ@!C{D3lP@2nPD2TiLz_yh1`S-wS z`|1p!W~P)7VaE~G^Pp%dH;hJt4ar_9p_d4AwtVV+{ibk90WFL0@;#Ah&Mgn7UZIgE z1Wi$4c3Ulvu$E7GzlfR6tzca|nbgXygiJxX=24T2OOA8xQ5!=y=IjB75GAXj-+-MJ zgO?=b4G@s90GPG{7MD7gT%~j4boXhT3!ndo{AaLwaMw@o;Mt1$-XDbbcC`sRs?We0Z{eea)X<&@}tL<`tMeM_M{nAAS_ z6Q-g-?{Pg#8RetewgKdjO~fodkbqcFTd&RA!yYwejej;-4ctoIN>YiP1~gyZlAwjW^{)s zFK5C~%ll|E_X_D$rS|9_=(Du!FKcu%AZ{**bT`^I2t1)*RFG$CvyjT&yjOEQnD@@% zQgF(6n(+d!B>&tm8Ej)OQ^uz-*G|FyBNCYSYU;cc-Qz;$E|GdHh6a$O>)v2irjypm zXEqtUdXAb2;UqzcqD)32$FHZB;xKDU5hug|h*CI&(E`KkFE6c2dp0cRa$@_Hvh(fLs{|a}4QDo4;0=dafL7k-ykB>@JuI^7V#pk6 zK9Crf2cQcNuW4({qd_5Pb*|{9%kih-k`1tPa{Bb??X*)455DE@KDP3WM1Xq2UJs>c zSiavSt3a{QA=~GJhf9msQK%ogyokWpbviS$$cC9z!Lh{7y z87d@G=iOaY|3tpqEl!!=XSFQ*RJPN6CGn`vxEkb`&TD~rK6NAw{#a9+$s{v)X7w>xv^#Ri9rxry%7Par2u0CxeOEam|_7YFqIblsiT`lzs@{^C>9D$nC?(Y~N zI=+&*jEUdnNJntTpxFv1SG9rLPxULMrg`_@YzO?;{N|kJJ8J(~`m0?%a>F2^_7ia~ z<^vg#ZU3u0&f9;VKdLh~^>cmt@nW;4hNE?0t^;gxsBYi9!PdjiQ5L-aDtrol1s+;z zG9NHrT*<#2H*jIua;f)+Z@!}ORspq%i3g+j#!bz0wl!&muhM69D3@OKsL=fqe~dlG{SulJIlJ_owr?|vbKiW*LF$M!gw-2AYPVdjms=0B`-2e zK|^g&Z>5e+>#Mikr>Yt+?m(z59s^XD zKOu~2jOtdVREde?!WE<<3_LD4==Cp2W3aqKr+aX5RpuM~Xw?nT6G;Wdep=`N7uU)8 ze-(N>uF*?BGhk5Y{>M5N5RZmHJI6!R$G)bnB~MYz&H=&NJ&f~f^o0UkJI zUebzG>H^>Co~ZkQC9^PEd%CP-V}Eyv8*y@wtaK4Y)Kh?JcAv!AE9Oyj)5Da@@~yJI zGu-DwvD^nv(?RP>bYHBjzi$(^J>!b|+|gWeepe$`Ttje@r?pRD@|q=Q9?ztIo!P~l zc`^G2g-{rs@q|^&r~`+Ke-hCCNmV7xzcpvQ&EE6BBGKjDug@zgd*mN-1iX(O0JAi9 zAh+4dZsO|FeYh-V!fxDBDp%FOMWq0iS}7)O{Zb+OeX-F$62jDJz{9`eWb74eg?Swmb%OA_gWU#_+J-jGwUM9f8d%@uQN`%s7CIc64j|L2F ze9*j>2{EWKOS_BNwR*LJ?l!wNzwB;?wAE!AUAMe;R z313@Pp^@XbqGPjmOoRVF)eDHaj?7FZ>M`t@kHGom<5!i9wUsy<)R=$SI2V>|!4q(u zHfB8F2r?)rVz`ktJziJA_L@Z|jJB4x;l1{;dMk4B?_ESVe0dkLhm#N^zJGU4rZsou z|NDqJbG?>xghV$^VA!bEZv`HC_je21N7k5@j-6;U2pI`U@XVhzt76cRu5;?7jRq>( zA(8E8guM(gH1}qo2=}12y6L}H{}D`U0hzKKHiLDC;{)%O*gjA=qGP-yt)GQC5NPfo z+t&uK(*4{G4||{U-wf$-@p0K+ zg4U08-YZwGsik-ts5Sne`H4%_FP9YsGtF(JC~Ago<8D72e`7NMQJI`|Q8N8U@qyl( zHTwEw5*ZD>m)9O#2aDPtjshSH4jAyoPIj+d6hKoMbsK?Y8$`fls&=exastqM=^(5* z9B6o0f#@*N#2juQGPXuJM3^zRJ$O{AFwNuoeWFKb+GYK{tKnvdzm2_%&1^cIs0pce zstzN{)}_8oBBknZ=|+seWR8WJcOyenu#o1IIp&)cW}4^MVpXl^`KkZ&skr(G-~5b9 zkyiJipFi2LbQZr0+-A3?3w^uzXrT#T+wBW>Cg#b`2;hr%#{LK?iZ5g8bJ1}&!mjQ{ zLyHXGnWwnj1_S|lhR-fsWUJl5XMeoJ_|q1AsgErsSy)+(8`AD}mR$hr08cunD4_@6&vuth9fg(#bo<}4=M$EtX)$RjE(^ejIt#4j!eRg zX~V2HI7pIdTIk*ftm)lIK1!*0`x2XS#!m2ULL(<;Q2F)w_1rwN5R-A;@yAN$Fj*Oy z6A1p|eyQ(`L1u(jk$G zzoxSWZ`je^Jn7@DotlMPq56XwFW<*jR>rhC=uQ{lBAc9}&4(AdiICwn2>bEoMs@nt zY)gu$c?v&0Y!FHz|6>Ky*hs}Q`v!~qj3AG7dB^Bz z^3V%>j;polA=@uSB{#X+ycGW{B_2CDNzy(A4p8c07?T5+#Pf+v+%EW6?@%TtftNXd zSx)(N>Ff-bkdwzm$u3}X`tKYizbZL#rp~PqDRVY3MwEptv|-D^Jv&Vbgw2YVK05No zsEv#S8OFvm>!QZL8T*mnQLN^aJdE8vVx2_$driKDTY+4|BA7$4txL|_yW0Ker+lz# zgV>M$u@C~@Y>edL(O^;gsqiw7OWk}lKN2F;=vGr-e}Q%m5k3*R^ng8FFzajSRYTY6 zXNvT!gxjcD+?|^JexduCP?$VNSB|s%(ovG{@os%a6u;qiJI%Wl^7o3B60o@+Cvb zB_CcF2b&?jtIU?l7+ldgT3|98Zi*b|Y3b&^^i9WgzIEWU4ozya@?GBKUar19S~YZj z?`WxCX@p{OYRK?X88mF(2XhuH61-2TL*<_nxYuG_`tO6SFR0f1VAKU;`;9jc|2DRK z112;#J%8VuFHl(O&UXo}D900f2-`<$O^QPPtZ?z&R=Hz77mhnt3iC~K~EJ?g+eX5Rj1M+R=+K0`D&;^cn) zTKUXs^XJHUVZG`^WFY7a~>3s7$&a{8s$v%PLbtJvlB#1I|vH5}b-OFAYe zkRY`~UzK*+d#`J{N_n;Wkod;q5tR-6!j#wz56=R=w%@M!*e!ieTPr(X5s1Q9&erQ-p9$nP;0Kau{?XlhGM0{4L@7)Fr0|Ji7lsOZoW90 zyFNy{zL5}?L$F`+@LQ$&7MxHM7FX3PGH|VSJ>box!gA@6FoqVS$rnws71%BCUps-@dKQ=eIER#9UnN2;Ltf+sj z=*{Mm}Xp zXJ6+Gcty8557+X#VQS4%5m7+uG$fz-YPk)hY>}Gen)9}_@rju6t*we-3miua$S=2L zN{;k6kh-?#8~f8Fit?*wF{vDW^CsvpU_YNn{AVHKiLo$G_L47h$tXXQPsF zp(h^qt&Q2-9x#n~*t4A`&h=65AoLc@EqXCo5u#ABaq)2e)Ka|h;7q(5yy{wj4awDZou$4h6X~m1 z#yux_*HmFQZRn!Ppkow#^SK3Lq`Or~6fHf?Bn8YzdtgowuS)u(PYFwP$B_UciQTEd zm#-!EoTEeEu&G~l3A+9xZ^=>TBhM1J9jQ0Z?bNw?5jS$&aRKI!UMt3?$3XHvVKap0 zK6V`(_6r$HH&E{O1vpZ!nzk*8^hESo!#2d~Co*&cX);gICy zHt?o-DP6KdUJCG}ut zl_uV&yL#E%Q|-QN$6={$N~sbP8{UXDH6x)94@FxN31#mKT^p5nED?VhV8jqMR^zM= zr-ZgZ7(8=Eiox1_nmh`cE`V!Q9X`xm{Y;8;YN03CLWf;jsR$9$`8`NU;_fxX+J~Bj zPC7vrc}dZmvFP=w_voun83SxC5z!IJ2@+$44H~udSI^g7E~nxWt+!d2G9v$8e)?X_ z+vO!{4vB<6oL^Kwp#MA{EInP%m;~ON;?}KUe|EyS z0l!W4D38nxbgz6Pk5z5;WJav@j%X`%0*NPu(fHuJL0c6%tDi748aFG4v6BJEq+Tyk zv{TD+8$--js15l)H_c%bR+tUXnFj^pADMnbg!yb~%|#^_GVI(o@>Sw{szf_KlKK1$ z^SfY{6}sF|EqP{N?HPmk^p_MHol*~;cwzZyCfgv2_oZ{APs+U2lYAiWiif7r-ge>Fr2QE8g%3W;MfycvO&{5g0tP<%t|ouZ>u&kR z;QF^xr5*(WI3z9e@#FW>^3j;#D&JebkycD4I8 zqZ-)wdd-rhKxO!vX_eIP!FVlOH{BvE)j%wLMy^sZGdLiXvJXs2|C9d*4cGaBuWZ9!k$CMXis& z0#@o4xs^JFi-(N;@;~l=?k4?13DUsy?#>QOM_AM%V2X5;%($DOqPOi+*r~on@{Z?@ z$ctABD+=#oPdZs%UYX%q)-bE4%<#(4yJg%;=;yIZySIpLUnEX%o$|((XC=<+Wg>om z#2@rBpgm?YGiL)(l_BakC5l{bkvp!0zV>9a!$MOq=fi!fF%!U*_c&34N3O1&!DARcsXHqCVq1(KL&<7RsI*pL@yYT1&#Bl98>sfDAJaEDFsJ+prV2NfVUh}Y zQ2iwWe8bQuw0D3e0G!Jv<(SNJ%U{no`gwK^W@tult!|9}0B(KvEv4Z8@W0-WHogxC zKl}M8HC4MjZV;W3CZXf0C59-!!JSc5@nUe!+g*x0JfxvjJMiB8K1Z+*2gGmR@L@^U z@8q27N+nPT`3(=Qsft>rax1RztJf_4me>6^zN6#rUBy?d7_C^X94Cfodtgm=yh+_ z`!ivnzsWss!1RoM25yfCPvzj~Io(a`+1_*}v?z^zJZ+tXNw9x$m3%my@@A=hdqnkX z*xcd`f!MsWt?B`Jyi7gJDa7EhB>Ud-;)^)}eCQNWw2i3#yvge1wHh1Wu6c_36Ic&h z5~`vPJf6}`&2;yTkTN*L#Ep{jNswU{##kg@i^1cwu8IqmX{dVJ-J~ue^>5K{Mwyr)yN&u3MT4*1i*(R z6Nl;X^F<&b8?__`j=h}}F{L6}_4y=hB!~WGV94)=&SZ8Ao>>)z-G@2ygN-D|AuoSs z^<>qTy;(Sti@JinFIDmd4aPvql(7o0mN$>@7PlZ&C+Qpv=PJ+=p3f!P_TQY~u1Ebj z{Dfst*PuFr8B z)vMxJ33RMJ5zfCZ{Y#Zh$naT)wi5vqDUZKxd zSA^F-m%-a#DBaxOwB(}EVSkHTd`~=787N^Kj>K*4mPH(ndOeI%qN_` z0_HNtN$a{TGR_kJY_UKbXmkyKb|viGF}a5BZnNKu;lBncbpr zri`qG^0bwqeqXcb{-H7|)=~u(XDTl z-(#S2F;yY6zAN}}$RQ2YMB!%$Pk`KOVf|8$f>dZ`Rb|oC^k%i6G)RYgeX?RX#da+{ zeHCBr@$4If5n=>N0a;>2mUa!9hbL2S5rQ^rSqcp&;ZHt|;^5tAj}__!cQ5|v)jpVH z<_tz=`n62zyEQtx|3IA{_BlV1*E_K6{C*~(OffEpubI0lquLp#p;gZKp=4r_v)rlR z4@*QSTL{+>L%iz|5wEYmRroA6XhuWIJ$0XcDf9q36-AprX;VE=6>H~eHAQx=)vd)> ztL+g=Lt;+(A15e0%*PcCH|bun5~ygnaT;>?v`;v?!cb`+<|<&uZj)Pbf_&vp@1_a- zs!lliv4l8^?j31lm&shM6U>mLQt*boW11%mEpK0|4PHY@h>h<&HkpoVbCG{)#j>!M zjV9W~=H5>;FN{u_XR}~>aF@~oI#9ajKhFVX0ejDbV(agxP8Vlw*{Mo&eGQH*m8h8w z-;9l44=Hj5Q~sczlAm*XTX!|yGcc*}`WpFE`-$aB3g|KGsKfI|FaU}8eP$!sd(O-e zAFSUxvpz3~rp2h!T zeO=|36p%UPB@9WiVBA&LJ0%y$@?5lE`H7oUWUGykM}&TmlBNv+N)YuV^!cTuJQp++ zX+w}T(<8M4uaBb3d9?*#gFoD|tSluq`Mw_q+=C>{*ZR9iDWbhT-CgRU`Es#upk$Y) zTw=7<%9%6VX&B#tlmr#x1HZY!k@cP5`k5l2K5G<*l?N67@+jJ_y!GFEjk(bt>2VGl3v-xP2`H}@MnVlO@V_8GSyz=0vc%z zW@iLHv7~-XnV0mL<7!*JKVi-p9gLJbIkc$c{dEM%1RXG>xFlEXb9#^X+2@_>;{%0R zCdu-)hQD6Uo}R|m|Er!u-+Fxa?dDN?&gZ<~%je4%FS*4aF?jD(pAWu>Ty4c;AZP zlV{_73233b8LvV<{=^dDFxo#IlI#Y7z0SgRSdoT1Qu_s3%amBMlAJ*$o409i4UO~F z9?Tr)dC$>Nry{=CeZ_jSqXN^{qK^|D{&iaPcgE#CbIaBk%AgLo>m(ZLek%7_9(F?x zt3d*FKBBl!l`>0=kcN7uS5TOO2GoEPT!y1x7hdJz@;c5mg>lr@9xfgb!t7qT?zeG& z>`U!NPobF~lCj-HP_uLGlij%LIR*2~O~BnEHj4F-97cy*$B>vKX_z>-!m@OHHm$RZGsF zw}`~te$|g$I{CKiEEueAQ~n=E=N(Vg|3B~$x5Z5?R#sNoEAzS+aT78w zk<5#P>^-xkYhQcsd2#LQ+WgM<_m>BMx#ym9Ua$9SJfG?VAkCd0FK0+1a9u-yIK9o( zL%o1hYRl467k~O`yJUTQ)J(`>Id0^Tlu?cm?|S8`y-rZuUM&3Swz%4x^2hB3;lY{N zLWH@l7-nZ@w-vL7LXmAII0g>1OeH1tMQ!qD4PSR<*YxY@**NOYci~;NbQF?E89YhgO-GcDQC6GWUlq zP>C#quQR>!XKcmlZhD%HE539_|JR03E)Xi{&^F5d4E=_5|LGz$fIjEd4kwobv(t!3)T&TYo-i`OYw*vVKT zL8oc^pw!NKbRSM!}+xu_SBkhil`d$;)ZK$Hlwq<+J8O|GRs*Bhi8xyQ#h zeLKIokz|X6qf&Pe<}T#4+V>ZqaXH<^YB=byuwa>^NAf-s-2QgX_E~@G-_=PX`cjn~ zRf+3@hO>3A#f|TMEM1Ysnlj2-vDf1t-JThk zQ08O-f<5wmx*rMq#jTe>flMrX>&dfMbp2@qZri@^5OO08?4(2H)>}v3meAUpD`&=0 z%*{bTM@?tOQ(Ufmex;iE)PX~w`P?^#zE5|>T28g#pB}jF`(jub7*T1b4{&xW`C#WM zh#?0c7KYr~@bMeCkqCO7{=qWfG!CnCv;UH8&H{f2ZiPHX>XkM4uT7Nw6Q}D@P5|=( z@sI~Ow#nh6t4X)5uriwB7hdrzJ~y1LxQgPPnSLiFyYx~r`=*GTTWQu$mezvuNn@2k zYq5u(O*ga{?RfoKoIu~1UekU>Pty^6-O1xruS)B(MasH+SiZ`GKX2dB51#BfMD;nd z+uJ;iIl=1rmIVL#w`Sg!AAp=*;rPXnc>CmNk4dRl3B`HVx!&7$TdFSJlcxH%baMR( zfFBe=IpPl{7fgqqJ2*({heUyl_pcaS5hV1Rv zPDJ4*kP~ugL z9;L;y_U&AQO`>P<8?Rm!Jxd}7Gd#Kk{eEyWEhoj55!3Te$^#17imni~L=~9LpxpR`Gl>GNshB66fq(`77n)@7)#;8&d z^TH}IAiAZU&!hUkFfMwQE{>2VAzHcgavTg7rW5Is#o7GARV~UH(^RwLGbL#81GtV! z;vny`heH$X+TEf_1sn~Wb6KH-axP;THkC{9VA4i|XM2@~L|Q}I_&i;ctwxfyzKh#hG*+F~&;t>7PLy z_!aoCxe{9{J5NDxw^{N~g2|$6m9D@Rr;iQl#7fh%dysHu@t@Oc)}JrAMhAKQCp0!Z z-77k6OM^?$4pXI=!`{BHMR^>L*W-D$5=y96`Iq?GV)c!tf>s z_{ArRIs$?$k)1jem0GSVEt`bN)7t?f*_Fi)77 zOiYK`J&2L%xgoR(xGWaI@)cW}?}P7wyywD4*|39Ut3l>M}ZPk4JT+(Gn zxe48z#Qi|#Y#z7iBvWU&asWRxC z?qiJ<3E=h9Wbp*i<=9a8ES@>{`%~1zme$2Fig57KeZBDG8oHDGMVm`OwI^cj=|8H+ zD1bi5mS=Hh;?kkkwxut=bmXwS3%O$70;#%vZ)xngxn*8_c`8elb}zKkoy&B9mH9%nPZY=Oy4vjPn%eV*Zy|y`V&cd+IiTq8|L+IHNoK?Cr{beZsvZDrO<-I_VDY zpSr$7A5G{01-d2o0{5q{u>ao@XqAw8x)IvygB6+lH=q-8O$NL{bz+QgAw2nV$a-Jn zq~GuP=e1oy7aYE7K2T9JsRZ8N-=l(I?d#2cX^@UA1YoWWiVuJueh9yXa9^oV#IXD1!MGzYJ0@i!=K>xh0Ii15l6i_Y_ZJQ5 z39+84&QUg`80h~!!_u@X(*LhE_L+FRci4E@*}rA~Ei`TCw z(fwr&prN&lA2zvStN%X8c(zu%#uQ2zfOH865#86lsg31TiCS@T@ddCGQomA>i+EeX zB6OB&5dD&xM1--3U2%FzI;%%h72}Q|Ex{+DD zg-Lb}GI4@#P)}W+IM^5#`DvPv!)Vk)FwN%bpQbCd)cfz++Mtu&W`#xs-}YN~;=Elf z-y;fpL8Is6eJ}hQa7(nsV|NEthnygcIIJE&viFWO{j|H7X+b1tP^tvo!N!fhm;72N z5UzN=Xa>8f28AiGno1pSz!*9*9wNS|1VQc^>Lk`YI!&eaYS>=%app-DOH{hv?^Q zoBmpK&xSuTMOfswk3RXV#pYO86n5L&Q|x!eo>OZY!hc?^b?r$Bl>+9KLs;8yjSKdm z=fzu+re^P|bWF#~0uFvQe{|}8gCm#xdr?O7zn3bKpU8a@7FHzS&8HA4bVA@{27PR2 z>wemNK#(qRa~r0+=Ju`@;kNp7wzug=qX(;ooaMRAb{2cxqRw6RHy#SHvHPs@?y&gy z;;hXC6L6wRiX*Lrb(NBemF8^2>a&kz)X}N%(SRc#StO2T`QTj-Id!P(TK#{tkuMju zq-empyF}^pF@k!b0!DZ62 zArmdLb!Vw4WaKd|ym7Fcf$)m8bT<{h@J1SPF;e`WG;8lpyBdWQR3XJB&=k4n94RCz zXgg&N-`Swi&P}S@iiVr&^PkonkYOBPrBW9qWlpD~#<(}N<2?8V4HE1XgwZ|8gbESw z?k3}HV%|K7g$|s=H|Ba_K{`0phx_0e5Z+a6%hFzN5v#I=9x=>D;&zjQCm34aAPmcUHmQj- zRtV+sK?jMJS?@~Lqgi<~*0-~*EjrR?@kV0EH?tYKC%uCDfnLC1L$B;!*{QfVR4atT zQ%p*jw6RW(84pd=QhP7#?H%J^_FTxvpbcUL#-87t1b15@l-!%y}71j3*Q)oN4OixXSzO{ zrP}#xmCyS`B-CO&M!;md`I^Tn=NK2W|LQ_s3+uebQGo#d#SHTL!24l;o)hOHYodH-z$0((#&+j^GT#&qXc0EQL=eWI z-epn#NlUKJn$q64bAeJcyJf35@1y)wX1T_gepWJ&C@lCsxP6B=yQ*_F>IrJ%WUtwA z>k2I`oq#Mc1;P>6>&CzR#}XuTPaaa&YC)7ovcx|yu2ed?4SVoVEriYG2R6b&(ucI= zDH2$Qv#CnGsWsDjes{eSGJUW8BH)0zex~(@Q@xv$8}A0P+QaxUQYZ5Oc(w4{dXKR= zlYFCPepB06&-AS(K$7jJsy~QZ#8)T=MD~G#XB6sk7t%>b4Q~(nANgW(>xatrLmT?2 zOrI_7EUiKkWKs8i;AdL9B*q{K*CBMn&C2N)mDk_?=~H;4=z4XJ4@HjHrtm2wmpI$D z^ei?!^hrAe?ZWgjbNTsi$ho;ugHkQVW!NR?+ALJ+4$PNowV2P*C9A>{NBxqv{jy;v zo0P=YR*B&C8>tpii#`pCm}H{AmH;1;BPcR@>lrBgyU((Csfi_M>3LN;?NQ6bz~Ua( z7>mS-%fzjpQ5M9XBVVLK>Xj;*c!9=05N`-y!D1J44aFdP=w6jF0bC%2zW^&mikdIX^x5N~<66 zzORY-er@;TTaU^g2HkA(Rt@F!kQg+%qV}opsl$XuvXAG*XWs^V4W<|7bFdCE@hS;8 zl$M*Rs*;O``8Oj|7Qj> zzCc$eJNb_O)9F_s*-a}Wwm;SZF3H=kRk?o->@x2${qXp-Fy>_JzT76`q|mI?MyW6{pq1H zq%}h5k;l+{RF;XPYn;KawUR?WMEPH?Z|!$q>eI_)X(Fb?+5oxK6c6HOn+y(nqKSn< zV9B4^hG8iHjbn#cQ{i4T@$)`;Ce}>m(@J3NsyFf2;Or-G;YhdQEd|v>;HEn(3#MY1 zJ$HWWk?2L*rTcZ!SFjH&Z4S`twQFh?I%@X> z294Ne(<{+j2_F5CckeL-zap6h+pW|&&{^S?nYPWt4r{K%b0GE~gLVI5`QF1N-Cq%z z5HrKD(N7QpiQhRN-kK9EKj=Ul`UC(s9pC$?Y`Tm7Uds&dL1v6=<`3xCB6N8O3(Un&9H^T->D8Nyf=;ah7q zs_xUR%FRv&Vq~$j0mL|+H_f$g^-Mn+)<5MmwO&tIl{+1Rp|XHwuY@VqX`y~k+}=$> zIUa>oxB;h`IeK(=42H;e z`)Fvse^&Fg@}tk`-KgN5c_K|HI{jVoj||crnR@f^XcMa*rLt%5MX=$a4{7|!jqsE) z#mZvgAtE-Of7wP?43)82(ZRf`5zt`??!8;_tI9`p^z3lvn;nkM{o|3J;j&Dc* zg+K)ULmCGXj%Z6k109gMP8$xw)jKGkBe#R~oPtyEz<&>pLFvCb7*)2NF$W{Cq^fP4 z1JBFH5p}Ch{$Fx@aP5k~1brdTp58`g92aJX3at=BGg31>19*{hXugU+h=--JZF~mL zqb~@=dCcYynD?G7b)c6e-bPu2`3P2r#17K^L3 zNBlhkK_?d1Ad7Ueq!Fv`PNT$44*xesem9rqsb_!GMz)2vG2`Q&nOJ*YNJ)6Szlfzefae+)Ka&UCocApX5*f5qG4=UQbVPg zrvi(n&glQeta_TQ8YcdVX>JTg!-Q|xay;S%!t%l<4reO`jIA1hf!jKC%*lZ?1XZ)X4Qv5cWd zZEFDnR$cvO_bafkRH12#LA~NxT2fYFkGs$1O*vk()AQhk_bau9#RuW!73zJdQ$ z^(vQCm#o$(?p05JF#BSG)tF34=Rg>bmvtGVn@6U8|FAqnw(P^+vHpOSd0O(DvmL#@3q1Ck?C#m(k^x)v z#i}o5+d+boO3QT8GrD$_hTT)~Ow83=^K3WPPGMG=^FZFFV**V zVL|Cq-8FUX>EgGdVeD;koru^_%HBI(Z>XP{>Ho(wYr>vxQlylGWz z#-$}i;+0`{wVPxgZ*sg@N_H=SbsBL1s-Yhq%6ZGZhuyba{5A9O>Ja6UG0RGlq@u*00?KxqTT|iCm6xJ^xS)yW4;SmS#894s6>|-na z4K5_5S28?;y+y8@^Fk>%&WAw&a_-ehm#xONjNCvw^z_~Ot?;RJL)$0Wihlq{mTkm$ zu+n66lP##wgb3MQi!1C>t=Kxop8RwGMMOjxa9$r6W3}hx9otsOHmF(2LaLUrZY=Uo zZZq*9y%BhRRFq_}O8)fcO|x5s09GVXf6ei_eMLCU5?x6v?@f-MpbAVxS&F7bP0Vd3 zZf;kz`w@N8V!;jrMRQVMdq{4^eTZO+ee6iy{Jk5)U%U2mx7KXdoUB_5j)Zq69KOEh zuP)1U{x=GvGR8VC(W8>B#2@^%gc)(6Tt56~UW0vC3uS0z{I*eHyqbEI%okk{h4UUR zs(HEk?@QprwA2k|8JB78vgL<^hW{;wTyPYIed)M5si3zjnwsbt zRo0?{LmFo;j_KOAhrEubr4$$%ScmYLixbLLXhP+gkSCA!Yo0)3-6{s>6DNU&D%ViY zW=~HNbXL?c*w1*{jeIf|8~HskTzO{kLwA4aWNZ^x02GxxQ`3lHZ@9&S;q+8@a^Xo- zddTt{alzHh)pH%@1_8qV6$|bGYxDX@p1s@f6i>iVbX=C{=4fhcIL+mK=7$H^{vAVM zC_m61>L?v>y3g;oaS*jvtnMz1JpbLLT5OEdgV(C~XtNLUnm2-yV7bT}L1$n4d9U7f z1POQ#MNS-CSDG;}bhM))jZSIY}?%HtH?c`LAn>IRX3b;Lx}-6W+3EH#|*;^VoMTXB>%S#(~2{s z93+EfN(ry-Eu@X>q7a@3US`?aYNZJxHcyI-ySaT%lC=WQ_6EWjV>7u{ow_%;oZit0hgEF?naLoDGraw$NJ$ zC``Kt1Fo?H^u$Og4Yt|W$yDz0pt+)Q7IieQ3G-=rUImU{k#H$&=3ZMYdK>4hFJ_r{ zD)#Pq$H#N-VikRGZACi$w)BqA!I>87pAE-w#ADP%?rq0fW4n9DNEv6*V*{T2`njudSLNYO*>)`*;L4nKkXZyg7znxHW+ z70>#QW-Yl?c(Yde`U$l=nN95)!A&i|G&dozEH%_rO0C!C zx#meI#|;Lp4kf*|oz-m_gZJPXDLWEM2PY^@-*psEyJ$V*EEzWF5oeA-$8Dhe0!xNn zzk|2m#LweMFU{~#Nx@ej+5N8r)l-kk(WHT3Ktuo3TrS^*zNQ&cLUsM!!mHt>bfRYe9#t z(Xf>~2{I9&&_OoTZ8|@RJ|j!v6uf`Ow&cm_eSJ%o5IeM}MUL{2jDF!iS-_O8?zYvt z#wqbZA!lsGR3*d`njY7mJrRS-C2D&+Jk(^n!RMLfD|LglUr&dWAf2~pw%)l!gU)ZP zaEzL1kzdGVeu8|5(XhV^b;7geZFR8SF-mdcB`c&Zo9^u>*8Uz_C-IE4rzX7hqa-88 z5W&xyzr$>TT6Uz?Vk~5@8Fn^kazy{htOfNbzP#@_PWP;cMgN(wYZVXWc1JmSyV>)~ zJ^9q9dP;?B?}tl2fghFb@2&!=c2P)eaCdY^E&KoS5l(N17UOAZq%vxnDjFs$X%gEj zF*aC$tgO^JDHq$f?@)+Gw z+wv0IXvGJ`(W@_<5_qa!3>q!I6`5pdk%(D|$pBiopZ{F65~QOH$G)AQ_*vl(FOJza-BfHd29z=AX|0-& zU6!Xu)!ELqso#oJ1Y=e8%hGiUJqs$|D4u?HxnoAZ z()IC0D_c;fcqXp4QY?27Rx2x1xwX3#eTUe;2Kf-G@%uf(DZyfF@z#hEUSwSKSt^U) z$}H2$h6gIX$5N2|zz2$a!7j}HYcZ?OvQN-QEJkMFNNBA!w4iDuL67^l9|DPVGul&i za;qoVeh*_|dv!Mc`+FFfYDpP1XKtBG(N{LJ)o00;#a#Vo@dYGB5V+01z^@=RY}y3h z9(or6%9>eami#sdTiqxa*?n4bjmlIT31hh0o?Cy@d_@ATC?xUb)Nie zwgGr`nI<-k9E8(j)JNb8#_9ZnbbBZLc}AYwEH99(Imd1sF`!}AfVF%ryxGIW1VR;4 ziSStmp1Nn?@m5BTU^X4y=8O@TW*%|A)`;1+3GykJyiPHu zcp?Js4jVl~!}`>o&IiS9{O%0?-sFJbKa|>lw9@)0=z~GuA2De7FScEgvw0;;m>tN4 zh;KB+aibFN{qUdrnC&}GwPdz%*U|&QXJH*-3u@Roh9?3HvgfbUB^eB&R~~5gh)Y$^ z$26=|uA`jR6L2!R$@l^z@~!Q;?4ty8**Uk)F-rnHQf<(auqq_n0cpjZ`P{adyE=Cb z{t%pgH~-H|I)ynpkh|w<17p)q#=4R+kp*yx#P5bmstx$&l_g;5YqHs)23Z-4L#iDUYJmb; zq|C{dROTD&8k&Tk^)ySE5}c=q)?qxJHg%#m!Q9C1=6IRtbGLvo^lN}tK&2C`SP{v+ zzSGeeyhoTvd7h@6F5R@QA9E4*A-o=X$<%K7lEG(ZCM%{d#+^m)QRcxX=>2S6flw#| z;11l-*8~od(?+#vWto)+gPy^vhXhG)B{K9JbYxt28Y9b&0>0{{`KbP$2|WCA0h9WT z<~?RwLGJ>JeR0C zL0+24xCx}bw&>42d{bum)4~DdaNNP|E9Ck1wQY4vU1>a5K1~7gDwbqSh1T@6_RM-i zE+#U~`?^NLM7jEQY|Gqs0St>^zFf2Ym8E=AG3cF3vC3a_KRRpP59?Qn*SpxnE}7R! zBVMg7xJS)g7!L4b_30B_w90dEGuKhKM@L!Y4(oJ${o*s)7uavS_`*!)vH5`;9gB0K zqjqAkcJe>Ob!jM{eo5wSnzAFljhEe#$ zI;>e3eTZ8WNW}qQlD3yK()pZfI=zO4E*Hb5#NUlFen|Hf+%&fCE)Xt@U?ehsXBgp58cR{ygL@84bLb z-eLFyBsl~tTD7xT-&AEg$?AFvi-a{txGJ;s^V$|+OL+n$DG+~Ck%tZ!M-xSN+F!m{ za@}M7W=uac{_6!hICZAhI>TuR@c#U!&=b-}Wocyhlx0?YX>Zk|y7|afOjn2Y6WcAj zCRY1EPUnwWO|L~kS6~b%j{e|FtegzM{-(D3_FQ#<^q&ZSrOY^%n|%8RwO8fPm)E`h zAVVHsC5SnJCHo8II*(DOhUVC_#8EciSd-72qK-%INxI|AVO<$Un9U}~lVSjGZ|MQf zSow&{Lw-v2OOR+_+9OE|a-jEfP4I?+kWfEs?YuM~`x-IZxg1$bSY5G>s}` ztsjiS*|Jq*KK`-7-8|~fnq%j%QWp7!6~I5TF^B*Ah{D%OR%+6EH2A9v&D9^hHKdTQ zEzUgmfxB)n+t@TBg#NISswKE(VDeX9IWrK-wk{ywcg%t$J<+^^6@WIj`2`r6N`q;=SUV* zaN%r&|0P@LRSX4b?R1h-vvh0iXST^>aW;f|OSXyUfyx;2F$Y+&y;YLd0O!uErz)x%NPen;D^ zDqb{9YI@(JN_6|q^qr#)5AnpL;@>ITpGn8PUcC`uHbn1`>+0_otLwqZ&r;smYu&4I zu(fp%t9cvKN%)1IKyl`hqc`VH1^ldJ-{e0)8HW158cI7ny!x@bV=JCPGfq2^5P~pn448vgOf6TqHUT-pT#;#-H$OK3UI<(ehImPP= zL<~lvtT`lE5YBr98G!yEIBBkx?xu&m(c7O61$X>+i0W>62Hs7$J$H9oPwRA@C#$*b z89@COA;ZuC)B@3|+lUi;fhS@mmRkQ(!68@`GyI_3>8b1)9S^Nj*w{+s_}`|v!j=V_ zb#}zlkNIpqgi^Y2r$9}GGfv;W;Ui|C>^>V1Ga^)FSa8tRqHs4It(oaQ!#R^#B8>}( zn+k`rGP-G3;7bWyzT1s>uWjp6q$=3bAbvHj6H=ZrmT`5%*t1ehw+`nsmJ=bo+}*yD zU|woHN*z+U6LS$H%5~q`EZa2eL58RhxqX#~LY6oX>)*U{$NdV&Jz0tLT?#VF-5GVr z_I2#ZuELV{86n7IY5ZsTl4tyMn!e{!`V>W~cYq$JTmp>++d1nipFIa;dM-SrCJ1feollw5Tq;LfGge+(UPsEZv44X+Bs)QeynC zO0|RwUEN)dnKY8Dyvi=Nd6;HfmOY{59mxy!sVG(EA2$O#rW^41OmJg#XxAg5g)8&p z1NQ~itH(lju5+UJ0(UIRr8z1zG-%}B!h93nfZMNeHF;ibAH4T3@(4T&BG2CX; z%ese4y+W@3rjqBhG8Xl*VSTx9`Y7;I{ly;ptyj@%I0 z(dJ7!>dYo&B|Ml^Xux@L^n1<)phw+PCoi?;Ed^n!LrGJytN-}=i73tT(%Mx-1|1E( zm9q&sN@}#wm;$Nx$O<#L-8}l%-ie@P<6`t=LF;GaQYYK3W|b*=AE1VHIHS@B>$di4 zIMu*Fy`D+$)m1IOCny{e6oQ$r;mr@w8iEXL2)p4KJ+ux}E~jR&MQ#AwjyX0m)LNC1 zS$$ABdjohzDB1_3J0c8i+Gb|m7RKdBv!sxN6sQ3EzhJtb_=2r~8I!`haOedjS7cVW za$;1{Hg4nWZpm!MB+~sKuQn+Jo{{k&p1y)>$L8B+nzL%$eW?DcBeAfTlM0y&8=Tg% zJ8;RI5W0eX{juz2qyy-VBgj>HBo|3}P_NibK!>{h!(MxDt*XEp%u3fe=C*umeDI&w zaEY~y6~3a+oR*}e5R%l<#!V};REJ=G?Xnpd+>wt%ey%=G7Dv?c74%3%+o`LA-|CX z;kkJ?3ZAE$#5ENQOhGNb-K{5GYSUnM#C4uLf>l|I#lXjNsd2Z5my~f+Urgs_ZOvbd zNz1dVv3`mSC3YZAqGSa8F3ulKfslvofxK_uR@)yFg~zwJg<1JTDyDf}t*p3GCnpAj zcXhv3*C*58czMD~FF%7@<=Nt1hrH}^)V6m@cuEd`)4wQzx|${$ud(ucPiM=szG^8;bhCUbWefiBoEjA4xnpcXUAyq*)+nqDjnnGC80C=yWx zTm7DxUXs~0xfutJ<954lI>lyXya`8k7`vK;n$ty_c;D(D8{4JvCwsrwUk<@03mv~F z!43}{B!vr}ao{EDorH#)1U>a~*#fhHybmi_0Q6hFK$h1C0@Rim;715%uI$qy?A+H0 z-((iW{%ctSN{PG$W1rg9whZ=Xi*mzrhiU&$WrXxvwb z1QfXQ_r@Nx0Vbb(Q#Qx)_a#_CN_ftz)0`j(Vn-FsrkkmM*(Db?C_sf_ge`W{cBeKW)S*wcVKUiR@W`!dVLHys?uMBaBZ zb@lXM642*uRzdeQQ)z0L_=fv!s7D2#X=f0RFUYi=xsY9T3@x1$?=^#z6$h%{Ao zF3n)y48k5OiyNB`;0jj8TF@``e;-G>MR=rT-}%M-_zIN3jd?~ZqKnL=YahhG@b{1U znSQ}ehs;hA9wCkA2P594GpoMrI4s(}8| zt!=J>bO=BqwDn;@+Sf_DAE+*&jJC37MowK8JvYi;@^?=>qGx$h@?h&IP2v58*wCzJ zlh9dE(QnR@gVP1fnQ^GuXabF1w;r#45` zRiwm5UY;`=YG1(i4M>Em)$XpWy#Wd!!^vC-H7V!X-m*+(i2I;%e72%%Tg3U~vOvF^ z7!u2rPcTP1nE^IMFVZG3@{pXMHjwRK8vokQf~VM+Jr(xuoVfhM)MruUa(GR}xsKE$ zhp@W>OUl0SYGij3W@>?X#qME4$(o32>kn4{TFDm0ooQfn-`*fTf=53Q_Lyc8maH5B zZ}tS!=s$}4z$LMOng}SU@pwL|(1=v+U)<74W8k`R_4x=a0dU-X!-l(Ou)5B3a<4xeih^5eF&p|fa(V3t2z7+ONcO|~YQo?4be zXJ?Z?uIfwL!*>(&?-2}g9*vl_26`!AE9Dj~b7*ewyR-VZtY;hFN4QtI2aLu&9sb1l z!-7tSw(uJ4C;ofTK+A@fPu%aPd6>t@8Q9a3<%DMFh&<*->RCXV>SMk_LH4s~XjOGN ztI_e!61ST3MO9=g*4cM|Su!M9%NezQbbt@-ulu`!+#@Ik(|o1ju@`f{aoinKl)OLI zf71~ZP2}$`=VKc0IQjxE%c6Xg@w2MOQ_C}VJQ5R;h}JB46IsG$#<3}X$9Dz5Pd2_Z zr2PvK@Mr|ZZY}UyYJPrN6i~f*e`@D}x%IT7;GCk*%>%F!d8ZPabVTP|phadsw@dP> zk=_Y`n@8F_eF*}G?DT7Zd9Ke<_-`@!`nlR~zs~oCdMiO}ZccB=r%ig6WcFaiKdo+l z1CEPm)ra5;Ya_Y$KY`pj1Oh~m#Ee1Oh#VSq6$qQ)uql|iUDwoWjmCE!D>qlFC)euq z^^ctm0o?esy^#nbA|$WX=F`JzO`j<8Yj8^b`TQ;{2Srl+)94}_2jjiOt6tyoK0%R( zTn{qOry(rdn$POrW4xH>n%{FL@&3a{%di45Gx{(|!*fkBtm1+5+1q!lFsP)aAB|Pm zJB#Vo!rbgf0HU;5(-ve}&h~2rrgz)E4`;>n$@I zRd2}o#8KEIGyE0}HnvgH{69wE@$K?p$J&xf|yr@^3zB?krR{)J>d03$yRWyi=hDz3W z0&wgML2Y8&%O-^i@S#wZtwZQ^_6&VOWOV}(jFpxqB(k`#&LLEqKmwf~H!t&qgnRBk zRAo0T>DlK zY)SC1W|!t+)IrO~$+a?6;oQaz@&m_km=Q$wYrd(pujsYGgjfHn5$ji;P#~-EXvw`V z2jFzKC>Uz0+B2^!#cFzSZqR9nMY6>h-7^rkj`eX|G|O$y{1{~?@0HhX30#e_!L2Ch zZJ@xiymlK#7^pJJq^TPoh$bEnX#IL835$G`dbwA|8;OVf1j!JpTE0{-8%x-URZ~;Y zte(ctP;zQy)%}&*8W$Du{w;ZNz~Mxd`6)*JI$Auq=fXWlY<~83MaFZR25@}z>|7I(SSokludLAG55V$F@k)QR@ zhHMiAVyfV@kquCEx)Ke2kn2NE%rtm`UPVxnpKETK21%` z?$&gzR3X2~!V6{RFYiR$Sce$q8&&9()KE|J-G%4-h&Tex7#o5^ab>d=?QozTl>i6c zhgK(-;(ZQ{R+->l@o8eVj@{-&ZBqMU-1Nn~riHqbfP>Cty0&ben=48B__$Trr6CyM zG{pALAPo8d8vM?D(`~Nv$)SiON* za$sFVpz22kaJ*{sWhBmCx7C8f4z;_YKb0bM%{x5>0{|i7B{dp2Lpla=y^%h z#lCLv#v^*`MXqV*V-%~e-|3FEf44E!J@}=7q`!899Vg9fTW#B8UJde2RUD7yBlZiF zTud*v=o@tRWJMP@$iDoa4ruz(>T$*(Ecq&%y5I9q61|sLMq}-_6HS59@+9i|wpv>| z@h)I2D6HlM)%+Q=B&xGvDFc#zI4_=D_T8~MvBCjH@-Gy8#t{|ddRSdUqsdP zx>N}v5;v5<9gFjpw6#xP3k%N)a$}44At7U~DO;6G5OeJ3tC=hns7`ZvF6Zy+1vg_GL|K7jb zGzvjQB%|*qUBO_vqp4vS7PhkTpKoAl#m%y3nme5CjpCxR3??VPhG4w!?rSd`3~nDA_5l6_R)U|50?-4^6gx6bDhJ5|al+seyoi2m;bE zLP`V)K^p1qj*$XV(p_VKbVx`|>CVxNZbpoTZG`yl{R8&Pz3aZOZ=CZvRb^}I7Rynl z0A}DfL5aYVTzB(VK@5~)Ym~Z``C{oC1$FwDYW{A6Atlf2BEDoa6h1qqLb~H8C3@Jf zXE^$RMlGMXO8oNHkJz{1EBS9uMze?_H73wrOK^OJd3-zD;_mq~3q(^1>`kC_R)x&E z?EK~?Hx=ib_tyTmXmGi(^mKiH>q}&^uA6-tt%S*ba%Hysu{$MR?0WH^_9HGeMRw&( zJA%{?WW}^Kqk_354PEs`HY$Q^>yrvk=^qbvYjaaq=y){#N|(r)G<0I0^!B?@_UjQi z2*Ro4RY26Sw`g~UlRa0xXKBxP4u1U!r1f?`yV?FKJ4HUHScgKy8C<9bd5x=`;^1mP=1eZ%sltiR20ug z;IMHOIIm{6mLd{8FGTv_bcSHO33~wjy&Bm1^vm=9mXf3SuhJkJdJdYKNa6!^M!;{0 zoH9B>KR8_5ZeW+q7mxf5Y`6Zsb>`8?;0x2n4?!|Z3hC-!TNae?H7UNrM`G{yp^fq* z%)Rpsw|eKx{q9}g_O9OjyrASzT;WjKBP5VNEphP}SVZ9u(OSM6UYJ@sDBr8iNK?#2 zV5IHfc?OiLL8+NK(Mj_#G7Z}{8T)wMc3mDsZQ%91bIap@l2Zj&)mNK*ZHFRW#Ypy`6$BYbP4$cuRF52QXZf`H~f0?*c4LWdTs>co6ACuc6gEVnW$=+W_2Yx#pcoKokcoOwCElO; zN+o}n&l2%=p6F~G^$kC$!wYPzYMKN%X9(g7Xw;zgk~1dJTbbvwdxcxC9{D=_BHTOQ z1ZHo3>?pR0Lf`MM;4nHp*A1v3WLwS=IZ(*M(+8)r1JjWdrNMoWe&+hb1{c zi~p98yJ(N~=c#c;MX5nobBBpRmJNb4x?~=GqpOKx>tvD+K$Gd^zly6C>xH+Sk%Lji zz4}|+vmaN?$SyaO_6Y~CPAtm2CdmK-sgqvgo?Uf->v@Fv z5vzB?hp{U(AQ8|DmB?|Wyf8t+BV3(^DY5&|$u;m9J-y_P+*z|$sF}vNW*c04#?SZh zq!y8lDhcCD#QA@wPwoR-3b*DJE`F#9*5q_@BW&wdvY-yt!yqcjiE?RVU9S#^VUG6>tKhLsbde>}#Z#Nzn z(c;>Q-hm1fzs;RnCg8=G{2hi2iqJXA*`-Ox%_zO6Uulo4PFf;8fuqFw27`j$9;~k# z7l`}hGFSdX)@R#;u{v0XRitj>8&$?!Mz^3fEwR%Z3eG?r1k}?Zi!%SriWPjC`Be=3uJ8aLSB8^BjY2cl=WkJicz^)3q<_jxme4$R8eMi@feC zS#}lxN9wdpvaqYsNh~}7xVdX0>&3RL7u6>`w9z}D0o6atNpOJddLic+X;CfiEbA%Gz_!T_Vrv3brKEA)rz%?V=+>h*Qw* z-gXh)WcOyK>hq(2`^NUG|CaGoTaaW&+)#0gUIn4itWQRk;wjM`lO13w>L&zVOkv+K z&76n+rq`rC*W9*lDy5UQF(;#X`z16)Pngusr#Yo=)d4H~6-{w#7_!HdiD#>lBf>mF z(Ss>_or>JPU4D;hVPu3u=NeXghG2}j@pkBsD~<3KIy+r^kKV^xAOhElUT!e{6gB{JIA^?(p;H_aoI~G z6%a!g_}pOBnW`VUY+#7aACC1iH8I>ZbTcE!sl zHIK!Yb{W69umwm!Ts)eBJ`Y3R=PfqZH(h#VR-RB`JuGy;VDSCdxGtiF_@dd-bc|cGc*hZVBtQpoVRqko zF_G`{?v?x2H;CU>htW?Y*_-!+Q?9$QvJCseFnWkTtaJP=aOpJI?rf5^Jt@ zKG*mjdTekZ4b&E@CZ2b{z8D;SeY34|nMv}H=U+wS#<`4Io?%VUJ%j@+fxiOG*~)(# za@|II><)S7oi^(=IHvS0eE*Z44q*)ezu`f2ikHIsqd2VJ*>nfsgS9yB1NQu1e-*Yg z@RURkS8J)3OMmdDip;%vr?CsFk_qzpG*C$J`1g{_6LE*n(SQcyE23>6C}W;Sj8&l7 zWT7_%%+&ER&x-fH80pm$jn4O9N{|m>PyEBcomvbf4=m$%u925eFZL%T7!*PDAzjw@D2VOZy0ffzL#32hftN1m4f5e^8#wFBKj8n` z+X0UeE#d9LQ!WY$3!jby@Hwnk3KQu0f{C^IRfiZ81l$~2{M_f(qHX<|KI zKot4T0kGo0YdOf$)ubkPo^})Dyz2)fmw+{`Hgyu8`Z^ii%jH6FPX)|K^4#veG{&r* zCcTWWzQ8Rg<`?Qj(iFHA{aL+^wbjG~gA))FuISD%gYBJ<{h){(|CI>cbPMZ zmG?jF3yRW62*}v}fS=7E#eC$Xv_M8-`XlQx&n|!UCiyxv-T>Z(j}zs z6kKu59YsFwel}gEIrj`R%&2k0!?g*x-Z^LpvfOI}C06;m@J<9<5gE$vYhMp2O`qdQ z?i$W`f7Glr%aYc|7MVE?+vaOGx+dcA7)ICM*evU z#!KFp()opn8ghs5A)B-)a+9;UYuGi5|KV0zVpjE+e^T2Q#W6OY-sX4525dfLe5iBz z45!@wQ{FI`Jch9!6bvxmO_~O)Zaf|M?N>rn9cmD)_7JQ->ZfKhMrNQdpPo_H4QJ1= z50;vW8x58ypJ%2Ayn}{<#FI++tF|UuiyDtI4P?VQ<#@FskQ!%br^?@YDtle*_mzjF z!bG9p5$-V=?lFcc2`{|LYmbOkoQ-M>7t`&K=Kup1pq3`?*4=V*0sND2zP{N9Lxm6g z;mbAdjK2ghN?K+ORCF#_e46wmL^_*T`92dk*@6IjixQPMGT}kPYDPcGw=k@nX_g+N+b>Kd#CATBga((vyL$tqV#|R?{@6(N5 zXCt`j5CeVNY$w^+(rkBhf8Hr z01r&@OdJ8PoU7+|U+x(srFs1dw{~dF9FrGc=knGy?c3JvzI$m04>1xAse6q)?N9zT zifUoe$kLI$9D_)(H6j;sFhi%tQueoqMCX)fdZRy#VM{=Bn!zFCBZl`!rIm9$E!k}* zZTxr5Dc#vmz6yO884V1i_rM}!yTi-oZ5Nqc)C?TCSdAGSQg~&+L?~d4mOdR_A|c@? zugpjjxXxaF#P=!aGHqw+t)*Qc##shLD#{HF>f53Tmg=))Vu7W1FvKvPDGF!B9a%#@ zHO9SfKA>>S2s%)* z_R}2ptc_=jrp5R>zLt;QM|5-l$4OV11}<67$*xfh%;fPdP?}k3JtV>T{tZ5GAr;@< z_(4|zYUv*D1$`|U)duId@t;Ip?_H3`ZkN8<@Sg(=ad|}OMEMLG5u3g6hJ6mUXNP*7$^t= z$>cb8Q;Y|;CWy|k%_Br`5<#K&LeCBolwE$e++Xbc&xwiZbr1UVXCy~;|8@B`93LH5V|gK+-@;#G4Qnqx zdI1TAu zn|v{bGjMB~A@O*be$M%1VQnIM673K;AbLQsnJUws*I0~D^lX=!aqdHBqV=rkGMA4_ z*UFTs8YuE)eFqwt&`)x)o;OEEx9pQ_xOmbRcWvO`yms!(3=zSlU*ew6k$t+QSee$* znli`$$NpaG$jRtJ<;TX3-VMMN*U!hqrF>C-sN)dHn}ugP3V<%{g#MRy>=F47)MCG? z3cpS&`LbMZ&1O@3WQGz6&atzjqtwEQ+{=|Tm;FTjd+!6|ExR2a(MUtjAD$8&QocXr(uC*Rj;DK4%CO5t?8R#8rcC`l%%I@RplMNRl7WB@V^@OV+ zE;^QK@<<{D{2j+px1r;gwkF2wMDz-xt@48$JWF_1*;kDnNYEmB|B0+TR#{`p=WOJL zK~hA*XRAXxtn*ibVrQu7AL73yBL+>l)_*n~4o{})*#jeeDE~e92y~309@p$QXHep| zitKdDZM?9x+uu7pj4p+=wTIWChIhM4t_EXc1IJnjCBK2C<7-gtL4W6Bj03Dz+hzmQ zjCExvC+yb+3nTC|X{|aL9V$P3){E0Jk(pY>U{$|I-1*(TA;BmxQL2r22InA0tY^th zFYjv1NoF76=)eS6%zAvibvxGEc9gi* zLdoUV=^G3QXx=EOGXj03ieJUGS2{X)nr(inHH?_AzX>c}(#6$;cU9d5;zOU~v&aUZ zd3P5jtMm(t3kz^>U-$FSngbY(hIj~*uy@GUVQ?ClRPf;|xA3^!%@1v*^P6J*A%N}| zi!u{a*3pebqmK_S6@VIWZ-#$SGW;mw(SdbXdWILQF*M}$2gb+?r4w2Ua6Ny~)Mop& zoFwO|URigL(~#_#n<3*ToX_>R_9&eq15Jumb4xdFQI5mgX={$@pT#4~z9b-j^ZjjC z&0!FNAsE2!M}`zIz+#_B^8JNqQN9<%Pf<0Q;*)h3*>WFK&QMEIOHpb@I{sD|{T$JS zN|patEaP)?G1{|z#G{!-_I#)@RXz{*vje--!2QYa#P-KgX9vyK?JT?rC^RWO~6wmLz?bYXvpE#f;+%Q2`tTSr@?g(ZJ}&QH+?cpQ>8m@9zGe}A-L9uSi3L5*oQH;As_U#DsP7SYcr^4|>>~~F^_<(keA!`&8%V~>$MFp+ zPjg&+#oExK1!crZCEe1wOuip<36p$8#6=VE~$Qrg&q9qp(nq+aR<*{JCe`8}A zxX1dHbfpm93$%HKX1e6ZmRb@iW(X{(`6nC&K04LFc!*p)$K-6~EXrHrtLtU&pt~dC zJg0f_nk$(tMndt?6uL1smZ@lJdxM*vHJQhWWp&B=l@0Fn)5D&O|LP(TnMw=f5&_qr z*bg)|TlFs!q_6_WWIM7~-djAWV$+Kh2VjqTLy36bT+)}{%3bOfi7i3)G9QU+TK3XD z(GSs!4nO$Am+Yhs5@%krUv@X|#xINm$3ChM`08!8Ji>61K%73$%O*D%AJ=*U1Dq<- zS>@Lg68d*qGTVww;KTIzeKh3yxToT+Hcmkp9~9 z=5QJz9O>NB3T9K)S`U?-#~Ugi`S)C2n%!|+GOml(S=&<|Alf3i{oBYe7ulEi!^2o` zG66>!P28j#7|aR_8^;KlqAyIv^81PuD!p|tO{On(vEOad(VcHG*fp8O5Ilk(Y@WNz zJu6~Ts|{?dv3{cViR(tU(~H;fHRA_10?o@K4u=0WYR)S%Q|kC9L8dD(f^bJ{faKBR&p!@|zoH23cFP`iX{t0O%2Q?hfK zn^MAoxWWVQfpPqRJAZ&OVcwwmR6`kYH|70!_IS{FcozljvfU7LV$pRgpZb}Uuh1)$ zi8WZ5E^e!}=oAtJQr11uz)$t&OA4SXiG~Y95$;X~R`IZi1rVN6VvToOpsbMRcQ+_~ zgLE#4!*rb2r$`rgEoKj6UB5$#fI9KDc-p@B3NiMqaigE29fxbI9+ZI#V-3dz4@M-;tnHp3^Xw`c> zXD#2Gd4gJ+)@87YcjE3PS{N`6^-ph3ZLq@+bT`G=J?{NS@-!0N(t8Q|8lfOu2iOfE z&om_36dbQAYSz*uvxtb_*(>d!XVU|Il~^*d!y`Hh8QGHn&YaD;zm_j*Gp-4vca3Rh zenq68F!p@}_RGO1b`>xJZ=cia&s``qWm_WB7W!x|o;S%rEF%xVjYp5_71z%15Il{) zNPFu67ryVYxHXsQ+ND}HVbPbBSb^9GuGwIq7VMB9K$+W*DNh|nZLfhHh`d=Wn42fx z*OpSa&Koc2?=Gnfk3RvdO150MHij}m0;w^y9{0 zl9tr|jeYi~Cz>7Y$`WYfNz$jY`HS$D1L6X_tz4@&LgHOM|EVBD#fPCYs!aV>QJ)Ba zsHGhO&@RCoq|4pO0aQ{(%zhu7%)eqa3RfI-ulasLpIl}>1bPwQCVTV^anHHp586rf zFQ;Q&i0z8z>KbwHH28_JUk!9Vm_*Xpw`*Fzta}mOZwA&BqB;tkKmQF0M?icWezPMr zNFffT&t@RZgr{0^1pN8W0Wj0hmMGf}Tfu!h%$Jr@(8gMPm|gCz z+QnNT>9(!#`BBJuA%gxni5&OrP#1jl+1bQt6mdou2QF3qb)-iiE*3%`z4pjDs``4& zRi_Y>rafQy86me9mi&V@SX{(m-rWW6W7Wk*x5nfvbj&4GT5o+k>&R&ROnaaFMyuy% z)Z>6*$9O|6Ygl$&f1qvFbwv2bIQ%`D?}BY#F{kz)`LXDA8?B4s@TaaC%)-YBb90|x zwDe9{_p^}JT2*IPL3V}SmqK9lRtq@}b#&1b!HYw;tP2W{gMmK=@$eMR6T*P!8M(z5 z8rGpakes0-tr@M#!wv^l$Q=lB$ILlL08r?Isyw>3IGtuDPyB*_)@5|o@ZhGl$MBJc z54o|sS0H@pDEn=w)>>9K4345j5?ydWc(-@v&&y5Kwm}dT7#%k4o&8s+GQ2aw6NtsS zv?_iglM8*L7GYE$#VGe2=89ik^b4jY^|y)oGrI1k3YS|S{5r9fm=Eqwlk%hN8Lxhh z@h3kSc=Gq3V)skR6epfme;J11hA-$lkWVF@c7nw51LV1M(V3m&GXC@D-9EqYHgN!C zgN=&-yF9mpSy#9$Q)>R5FpGUk9qS@X!K~=Iqz$I;Gvgj~YJ0x_03!ED+@B?EUh;Zr z=sqz2`9I37Ci>QXsB;*27CMTz#u^^^ z3#EYdu@509wry(=jsa9)1S|rb_)6$Wp=J}t#AaDGv$e<`u#?8})^peWyoJ~X#LhWF z;%k8%0)VO3z`QaAoe%Oxr_SD-w03n%VR?2dD2`EPx%k!sndYjbG=o{i>KI_<0MU{r zO=)*5n8uUWlfO=OT#{^mtX#(#X<}~!iQFBH1Fw!LtU_0b=j&B4OKgx0)Y4jQTUHO~ z8$+<ZF53RHA=2OSYNmV{gOXM3S#okA0_v!T* zCY4X_D`WUL*OA}vBymA{X2{*|OInZ9T)bO}YG`K(w>OA*559VKp~|?EdZ27&@Tvlo zA4euogDb1E*4hW@9lwAOFkW@cT|zx;`hQ~oaH3mYmiNr!M;Sv}MD;77nkHja1Q!Vs zZfCNBeBmeb^}jFl#~sImu2T}*1g}?iZ715C{jMwwD!srO&%h>RJbZ?Bb=lI%_vF1p z!JT?dL2gGI&wW^(i@Yz&>{}Y$ozw*JfG+Q&H{ZZOZO-%*Fdi@ZL0;D9>+}AiLk)ryZ-^j}myiaZr9i(Wq1-H!&yKA9w7_ zoVp%+kC2do3%3iiI*n8juQB-8PB#eM52K62<3s+tEdG1@19#8${^>WhRejTV2V&jd zvLL_B{K5#*d>}EB=yOiLAK?Kze5IZ^|EP2K{sZmT-@xynaEP*F)?!^51j%oJO-sut z30-e?uUTj<;Zh5MmcmQ^ZM_QJdieMhs)ifd98?gFd-z|J*}5i*P5?}8fE`C+)b`)7 zNhC!S{cyt3#2AGm&C+($3wQ#pKY6Z@)T7GFAk4_~_HP{JXH3R}Jf_@w(Iyq8Ys{b~wxo&L2`MVvOXlRXUv=56f&b#s6=ai?27h_r z2NTr64jhIPKulB)Dho>Rx3v%1ZRt=Yw&o~=O)W>SjrK`4mdOwh3&|*#JsFT4bZ6B6 zbL00{D;F33lv?n#vP?7Ge>-uf6yE=1U&05mI>Q_AwQ0H4^+ui)lJ)NwA;xC=JoEpD zEX&)pTBrjWUx+mSO4hcp;1=uaRJL2MIYBuACKMKVSp%4iafTjBUJYhLzc7|lE~n?b ztIO7`H7N7E&8V@i(M5PYp;jthggDIezc#mHrP4_pK5fBM)C?>UkHk^McXsr6Ir7Wh z#PgCPoxC^ByOr6|;qfx@!nC;V88Hjs7E;so2C^mFwh4lGjFI`cNH&=OANb;(bJXDB zPI`M8gv0?zRI?4;NfWOZhSD1B=CV%%yZ>C`Dd&b%E|^hke>!fA(x+su^Lpu5Y5Y*A zUg?W@G{b4yLDfZ^`7(>WWL~eso4?k#qm!$Qb|8R!J-`!Tr#x(W1~g zNbb%TsDME;6j-lVO^d5SeFr}pLY_nBPNRJOi}=3A(4%up8SwGvbpgHin}$${`@pMi zL6B;*YlAhB;!V*+2%#oc1Y<~vi3|e|w>frk&ddG`nO`aNM3l#6X6ga+2B7ngL8b}& zu*nh$T>{^)zD^>#*CPQ`OhBi@&queRM3a=O$~&0;rg-IJk@uAlrZW?3Du_yTCy`e; zc!49wuD(owH1ch$9_F^`0nR=1|#0t4@-xlZTmcad+JP_VoZ^bG738m|qu$07X?!52h8L4wHd-BOg5c=CEuEb$(NY zU@|;)QMOH$aI-bmUv=^GbegUQx%r}U+Q(d~F zaa*RXOd$LI6A32ZDlPC!%Y8K!Ya&A2F-jb5i! z>Xj^2qO6fVDykPNHTn$9;(^G4$x(^y_aSe(mqkIXuD{V+cEAfn%WTS0~ zTy#&@@b`W3aKbgocT7sLHSTPn#(pLAVH0lhL1QR|V#QH`n)s8&5Su!m4IH%Z1LGEk z>ODw4-Y`{i^RrhgDMkfYe<7-h`STo|4^!uNyB}-egMw})yvYvHc(reAPCP?2cHfrapO z-xs2y_ze`S29Ta3mmHoOcQ#CCD2%ZH|zw9V9-b3+e(ZZ(@rT??>Mi z>fwiuc%h?xG2v7%X!qAAR|~b=OXzYeZb_Qqd&XbzX#8i+!W{RQFUPg$J%<24_j9#I z!8csrJZCsW=cGSm)lvSoNCs<~)m67G@t5KgyX~zw&F*_Aub6TF?DSIi5c3kTict-- zfxR{uwL9dO5;ss^lyRyImfG#JX>I?nVPz`K{74-?IH;^VvbA;GYw?K4OZ@gq#B_K5 z$xvYR_2Mu?2-|$~Ct=@I@qQ5f-HYZ^bY_1T9r=$R;q&elb)>Xf?qtm?vU>5CTU#*e z_zp#6p;>k3XEwS4^W}c{3kh~ARPkEk)UM;XDvqc;!1>R}O?S3hpnou0$<8S2PwqFh zul}Xh8W0gSg0)!nI7wi#3#vpV#{y)}Rj_CmPt$xf~<#K6y-L>BRx9x*4n zF~jh}%ND{q>xzroD#(9sWHs=&j$-{9;3;My#8Kw-3b=K7B9&w=Na67>UDx$piEXvD(^{?r8c^sEJ6_)PUjhvF!?x7^L~6MXlnM@>%oRV!+hGxZ}35N%uVMLbY4X0SuY~-;Xc!Eh ztMk>nBi_wOWk=R<(PnQ>~`nK@u)Z zQDC54<+QYhy|h0_b$?Y8AgQK+JvOb8L5AmAw5Se=t*Iuh9NA!QixZWacq9V9`n?!$ z{56Sy_g7*Qz>OgYe(r$m*!qZt)&tX{M_dN3X^~bj4ZsAjSMQkkDN+91rA|b zd!Y}7Zy3%b2K-OJ#|AXPY-{|DGwCmn;EJu#3pFh9u}{{(*9 zAAmUS>OuHkVOfD|(H?0|n?CzU5MuG#6kwRQyMM?KZ=!Z>5sDB&Dct_)hxgaBx6d25 zyY7kOk3vftCS=susrB%)`+2pZsqos^C#d-x#IFzj>q*K-LG{{x1(m|GhKJPli3jw; z4_(Q~6 zOboaZQnOOetH+fxy7H;Z`m4K>lk|DfhJe#-Md+DO=&1P7zgdD_Sf<2=JBc-R##`$7 z2{UApRZme5@E>?)8GNZ*Q|PpOE_^9F+DPry@rvQ{W*-YvXgMh9!mvZ^h&6)lSu6+fEn^IFTco-*UsCOf3piF_E%`;j`j3skFXztB0n zLg|8Y`Tt8E`;2AIe+Lzk_pU>LaS(*zO3lXCv`NU&uYl>(+s?n?2PL1op1uY$ypHD> zFqHE1-0TaaT@u1CM#i+xrxEPtS)WPU1u3j>Nt%^aC}gEqLT1| z056!T&FD%EGxk8BnoH`ut{?o$Z)$4UuAxNvx7?Ur?+}X##dGcVaTb=-yq5OcoXRg> zC2cnr*GQ!NU41b)2~BEaLP{cT!le5;T9re{G&#S1^uoebeBF}tA}&*9 z0kp_ZIe?5U@jb-bhovrmwmZ$tRMoP6!HT0K_w$qBe3zTzDDi*pTqcM|mtc(t%XiFw zXB*aUf>tlOt{1ZHe6=VH`mc=Y`Ylk+SEuB^>pg2aN}fxQQH@YY_C_uzjyv{bwS(5~ z`4_W83WP2nMGb#_76M{vhDs~{XHc13JIhc{xk@P;bzIg6uCo1Aja^xO5KuR7`wRz* zT9rY4-jm&5BXB+IHUU!NcLTqP@HngQ#}jb8Z%n#Mwhzk@5KWR=+4-sZ9jHF$-e=C- zC9*S#YBnGqbpX}zNGnk-_KWbL@mDj>Wunh(unpxAUp%kRXj4qn7HSd@Ixg(`{i|4Y zGt}u9*fT(F?$ACC%nk+fXZO!6HeWcmUux5$uab+6#yf=}pEWL*`Wodc0eZ@`%RS`J zYl{WE)N|ak4r4g@$m0cai>v}Hn|8|d?CcC0LK))Sk^Xn4KB~lsK!&dEQDuz7 zp!d(xui?bMBt*jJWf$vfb6VvtD!B`MR0Vx259jasZnZy7`p4$gBEK2akV6hE3A&x& zGr7Qj^y;z4VSFRIp_}la?hKV(8-@^@L?jLPzb1JL~wWLkg zlnm#7KYS4o24)2UotUic_8ls@t)9)zzTviz0U51!hmI!q-vai7Se?sX`aC{Z?q^aX z06{rU!LHsXW!uhOyR|}(&{0bRX9?V8g`rM-^DK!6yAOUgmXSi_f|kZJ=nP^n!9Uj- zV_1N{HrXCa1LxfXaB@>ldmXPS7m=D$W@NTKaKN4rr+4R(gAuELw4M?RsTHbpe%EfM z)!cBEKL$ydrxZ&?4=FAoVHqX!%S*qhdwOwVSf!F@sn&^JO}6_1H7KxXD`}WH2e{pb z|M9|WB;Qdu`}uEX9MM=C#b1I&O2yqC7}GoHwfk5%s(cAdW-x#(o90)atk!8*5E|oFvvCBdgND zxG?U)1?B8z%kUW)Z+QOZY?b|PLv5@5XZ%4H#Uta|1A{=6zxkOHtBhitp-%Y;QXJZBv5FRqyQ zq4|NSE<)a;1Dg8OQtep)kanF+V>RV@AYIIS4U=wAu}PUBT~boy;3!z~nGvN}cPxwG|J{Q%7Efm9rWd%cV>{|;u1 z=-<{OV-*20`;)xY55}~2&9=gxYvVuVub?|4Nm#MK5VeB5BTNjL{g8Hb)(TtCSwkKF^ysZ7bI`aGx%e=9 zm3Hr{D*iO?dB#oa`;{atf;j}(({$1!{P{~dyR+c~uhJ)w`;yIJ<3t$JDJ(1<4C!DP za$>M{b1Kv|&@V$Zs{d+>VD@qt58l;lIk+>t>h^`bGJgSGB3e0x8m;vGW=xcji$5r5 z2te4MHUefi43V^#mt+`)*w9w0FZ%oQ=cQ$Yd~RgDP)se_b_6#tIhk;rIA5`ft2~=L zUL4)rufq@DtK5H&fYKJqjv;TFGYrNcxf3rbYmbHtN(qhm;laodxk^ipH|h2}5qtMl zkpXpeiKjr2dXPc>@Au#L^?jbH6I4;Zu{60z2TO3&H>Z5 z#I^UTF<|~&r{)fB8pS(5ZS9N4ee|Wd)*_*kvm(30D2TO+`q$ff_kI%h3_x(O%*r2o zM#oH-T9mO{tWJ*C=p?@D$%=P{eYAL69cB?gBFdibYCW7sic;5LO`WCh-9z_cotjf zRACOLtx*(uGs<0dC`0lCNmGskC86ZQ)jb2{J43A;fcgTEK*xw)esQ(GDi>s!BC}$$ zK&t>mvhj$#sSKGH~UN(PPHTMz> z?j4A1V7td1XxKyhZiER&O+sz5IceBxRJU#J*SG7>nHP!-302GI<)3s|p^*(}+1|Z^ zense(Jj@f(3zd5W31;X8T0>yn&5wHQv9bL;m1-bk!}iSqcZ0{YC%mFWoBl^NAresV zRfShuKedN!dVn&&1>)tavSb5nTYo_Wdwkv#UmRAbQZ4X;uao7TH!}aZ9#Of~Uhp>| z&fGPaL66!kTvc7<0wz2LGT4T{v^otJL;D^|$tUAE%s&N}&uN5V=Rfa(*?IPh=W|X@ z+W>w2b*R;nsiIaBpz@*rL?SaW(Jm62C9}Gc4fQu*ij;K$(Ee?4aICf z1|1~Xe~O;#RBJ?|yVO#(a{r#1k5mB)4wPOt$Wit(x)-i1O`V=>MJ#PCwf6Gp2pPTx zN+tsSpyadv413di3*%{L>qTI}N?@60GT3Mq`!K-6vFsdtK7253=cLheT$ZMamsjmF z#t|{F|4WgmaNbC!GG_I~yP%_s`!6%}i1tSZ4wbqQ-&SWA0rDIBus6pc<(T8Eg`c!1 z(MGG>J)r&9LG&^pSpPLBl08bdUE>9Cyb!NIA@)Q;W+$r*x|bR~)OIx?6!>GBqEMOW zV$hRF;}FHm9LdmeB~5cG#=U6)+~ueE{8LPjPv+s%C$*T`(69F4gP@x+-P+LHz9kW) z!b^OGv2+Qhb=_oW-W2bcQn>YK#VRqqEp{7Ly+6p%8*xn@;O|_oEIVuG&E=5-mJm(- zHVAr(CwVSS@CnoAIq*p%7VH#~iL3KtjuZI@-Ty)Fwwdc5JoEhl964ZKS=BsKr}YTk zn07DxGN}h`_OwR>6TqPi8hxmkpPzY-WdOe8U5jZ#&s*Xq?C{==pmMUj5~zg4%n7)f zb<7&1ijZswuROSdwr}_&QfEB^osqILpi7IV2k1{Qhdi_w7(Q@F>Gm#F49-h{lg@O7 z>ywsk-@7KA{?73HBRpgAA(+w(5H6j(5x4nRGu%98!_Q@UnD)Jzn^V+AZN!#op+)J( zTs1nv=@#GPS%_+4tpxzgf}LeiKuW2$;6(omsOPz~+3yl%n>O?DkosyFr=zqFmo1*adzz zu8G_uXmCc~3pjcda9>KqZl4?;Ng&o3_zimxb|4rXWtHx4N@U~7mu|%BGkt|*pmIrB z1>S}F+04*O~|U4y)mB2YL_vQnPjG83}!*;}m@Am0DRjsM#cRvWZXkX=X?ZF-bp zf2pGp-cTKIcQuu#ZHn4MJ%+-fM#hSy$Q|PU;C^HGAV>O`Tc{NoDP-)&;#s%xvMgr0 zpp7>K66W@=+3cr(5sI2g2_{blvFrd{%#)nC*NbwB&r|IAvsr`ynP-12htqUfv$ma2 z*a0%d%$*)skd={p4Ml|vn>nk^rimqh z2y{O5UFR~-BgWqNWii!cVrQ-I6QO@_(BGu+%#Tz9P-oj&f|ET}Y%=&}A95?tGD`w} z3k^qh+5k~_TEz7S(;tp+h+>6r@`!w!oo&@p&i697R5VM%^eHtTs2BFO@jIb|(PcWy zDN9PoWDa6TnD{-AS0wv35MiUZurT&T)Hi;$O@brv_4(Hdyi^#q^@0{Y7t7z-HMyV( zmf-TGl1Om{7d)V4{3V}xrYEc8Nay}KcPo!Ih(nxJVw+{f_f&h88%}aoN*_4RVPs^t zOF0S+Jr(MUdic9&7jn()k5CSTeaCa5Hqr$njkn>1tLMHA!MU*4e&g~V@(_2Sbd{S1 zIac37pbOdkiD0iblrwxX;ARxsNyy**HpAeaf8W#B3^{SH;&zA&BU3=)^b7+tD2;JzjO5S(uR-r3P_sgVG|gj$ zhY!^p|LUx^H<7?yKRW<}+YMnaiC<#p6L&fUFt2ZxNEn04|*h9769oZ1HIzSr6 z9Z0Kr2&VEF;U3gwkM72Y2G5ue$|6E3#Xce^FolZM%WHEyz@W(r$#+d}dD`0_4~0EF ziBJU3UeB=4x?*w@z~iqmY>wj#w~ouB;+yC4BhBo;dx8voWZ zhr<3-X`TC$MS0t~sb$kW!EFG6_*d8hRm8>yKDp0TbxoC1;bShoI$~W?I4+!~XsF$k zc4rR;*lo5zO>Q8^fmcS9sfo`qCDwjArVm1epk3gQ8Eg78?*yq9GCBs$27rtBZ z9ikgNsDsIEPPIU{^G)uOr@s#S`U|b?MaA{g_MraN-_OU;SC{&q@43XSUfLyF} zX!fT#wDTwVnPL(okEraAo8<;GvW+yNSw!qdV)?;%`Q&-0pt|>90G%ur`6HrjSe9o{ zZQ%DCrvyo6R|&MXkfTdc@o{2g!!^hp@*X5h@wWom#d_Iv=Xh4g1Z=5ika#jS?aX8O z>;v3;X>v~&ZK{n9r+o~c5td~1KQ25DxX_T!jK42&Wb@~T>g|B%eF!Tx&2)Z# zK9!p%Y#OCIQ@-SxWk;_nXL{>+oGPx8a>W;^L6?&OnZG|>?oZ}Vh|t(m2|awdWG6)t zs7C@%lob4qa1J;DCjk7qN<$)dW&Y_;RqwAoE1Y*f8P8so9zXr<+;)*`{H>1I!447$ zP5AAnxDxsd;KVppNf-;n#<@ow8o+&XuA$CF43Iku#(;Q&!cVi(DzW4DDeUdEphwTM zS^T40YON0ZkkdV+Pb9zVZj#|dBS7Im{f|Z>@+eugj|(A^DShO$R`Da)A2tyD>Q64} zIFZ)LZ}w@CNV0gATg9%8%l=Z0@yNGVFNj}xP<_^FF#s%2pX2N!W%C<~IPD?hukZPi z5|ag8DExcVt+gV$%<3Bnn&ZeP7ZVi7GFo8vO#z=z++ZWWl+_=TKTUKA-C8&pnEEn| z8^46f#FLv0jM6YRgQ6|TygvV&Eq6PdcV8R#HvAt)XBpSz+r@DZWuk-#f)WFyL_|cI z1*L*?NrN;}BSwu8A}S!l2&EYy(%m6lqepkwh|w@oeD;6d?d9(4b6@v4=XcKeeW|3g zXV|V6nwUZVKs5e#e(K(R;Srd=`*w3dMKiV^fhLQbmauAQaHFXu-7UuiKOX6;HNO)` zF7U?hIBP0~xOl;PS%cf(r3l|6zD?Kx`$!=liasZGeN;gct30`O!?IBsEZz}*R;b$m z3setVH_+;1iJz2h!*9B*23m}bzWq@GPz#n7=RiHZ{b*n96ZytdA!!9vRj~=BWwvXB z7v=r|5sQ){cmR|cEpot+dq5e%!ybuIf9#_x#2;gk9uC|*~9P*G)J*{VlOJ929?d!A3-4WqXNwDcZJy{7yl z3$^f*B?t&ajEqiVwe2}9RJUUU&L(BeJre_DXs{<6L-4>a^jg|6jngf;37- z@E&v=5HKD$qj@~xeElcjXzacFtx}&U$wATE$F$c^ybJau-=E>0UiiLV_&l*Y+X(YT zEr=wsU;4yD0>%>?(QL43b%JruH~s89uLy1UrykgEtgmYyhPn&5%c2LrO*5g<&a}mG zh_tokMQ(xE&d=YTNOhU51h!K%S@s>5RA#*Z(?z+vkLbSx(=rUNG!JsMsDrDR$1TA`Ht2hL|uJAPNjT|l;-9<3Gy1*6W2#@3ptIjsF#*?2O{Zj7pol1x8ahO~Z4z#r-AIbR2dRtJRR zb!HGL9>POT!d7vvglCsO>$Bcw%y;p79HOs`|JdZ>!(c&C?X$c*e8W|~*wPXZUJkGr zlu~2eCWiY(pVg1}GOebZALnAmgCxwiBBWQQ11kQhnC5a0W5BClc0LYIxKO^&O%gJj zI0w2HUsTyPxTmr? z4|yx?=~PaTmcQY0gNV|mLUy0VKv*>>iTY+YlS_bO;i~R~!q_mYS&4ZbjOM}(e8@#{ z;lov(OJKmmft)j$hpqvY{NGcaERY@RU*zo39_l1K?78B&Hs!1NyH|hi6b+zi4K)-R zz*Vc`zRCC1@gaKRp8pKyGe@1FC%;g&GRM40V&}^fe#kW^1!(%$0$>XSanam5^ge4Q zX!!eK850R=-;KS_xH3K}a1p(m_9z@_+K<=|j#yHB#Ds-CugWa3zx&&UP78(zA2eBW zbK9yR9cf7?kUdt|+^iAd>?zC)+d5p6>Ot{%{B|8eTNo;M8EYSF_;_4L4c+(xq+s2- z6<#0B^xPs`%)tUs^p--LpV*|4Vge1?1H!GS28Sl;2wc-q5GG*>-@?lReKu7+GBHwr zMOK4#d3>7YU$-}V&rN1;&As1#X~PR%A|vFquBOYNV;J8Xd$A&_ZbCg90VZAL-z^}b@TF8b?Yw$)owa88(bvOAV2I-gh zHw!E6N3L5hUtNV9AjHP}&kqesvj1(sY1mTsrs~Qo@@pk3JKR zh)G#_)hYW2t@Ypa$mU@(SRh-MvHJgekgzu-urgp=>$d)~CF7BUfkqFREtO$!TGB^A z|4?>Qem(QCWbF_u(0zs01Y0PzUUl+oH67+({>rJgC@b5i6TnURCir&=sd^2i$uC`r zxsi{1=gXc8@~?yER2tDZyx+76o44&tN9^HeVV`7&2RYzMd|Umzb6IhYFDi zFRiTYAH~?dTpHO0p8g52!?of0QgcKXj&=nax3g#bu!ar}eE$|sgCNGW!h@gwlm;rb zPnRk@9xsEl{IJt}+n$)n%qv;~m+c(leK&C)BGCAPH9plYl=V2Gd%)H624;X^Y+tIu z;w#T`dGLx8-;#PO`W5ILy%kNackp_Cvs&eLk;3FnNeNDqo%FWyGJx%HHvGtnvSt*K zm=f2&+a)A!gfZ+m2XbSJ`%+_+fVAChZJ(*WGL+r5HX3kp_<%@Yo^hrHhnL_~SCGH9 zYB%}ES>E}oUrzF?(uD7o%8JLpk&_kK7u3qfQIhQuk38<`9Du<$AscK!>3`qxl3#cS z2&bo(jR&DY0rH_wlD%VNaJD{C zJ>_o1$SUl^Jv<)ZqY{9R0eVV>C{%TN=nrW%qPKDs#|H1*BVI3|aMU(L02_-+xJY+v zGsT=19FZV&L#VI)M?O2OKWd;+yHL=HvJF$+$QZEg`1#`A;XUw%5$@@#T}~0{iPo5v z+UfwL^Hk%IJw(4cgQ{`Zz4;7C2QNQ@s1tmeRqyan1hk*ud`mV#3S^-tR-bgqSW_tI zs99iNG6LBQ_(y`BA+GD zE>>n+Il?=8^|}Bx7#x?edykdWiCu{3?ORdYJ1VFyk&*v=ni;7~L865Dbt+J}h8))u z*PX>2EWT!P=0nKsJ{2dZb0T`U-$__De7R4q%x$Dvar01y9TmnRb57Le^mVd5fAxb& zA1zq2L>BA?N|nCeoKQsDpM}svMkfd&>kK-Izf=aoH%f(}eUEZ>TDoa*hoeC_Y2tso zT5&*{Le>fRa*&s<2+l@qpMreuKc)5Gq008sRe164%=B>FoRBWaqTxwamgEoe!H|<# z<0x8(f6kVaNtm@4^m@`qU(ZOEgxeH;kE@t76_RLc!;h$L^ZKyTfi`wN{EiT9PlRny zAn)%OYb&VGOqDlIzg;xmZFF3AqA#X=^pK!9khZYV#(%2Lw5~IC*ZPy^5szPuN0zC8 zW<|-K=Aj0o!2C1M<4!QG`{%sg4-DY?ob5+XZQ_(Y$x;t9KZ51?J^j=j7vMRcqPn_S zk9`Um@w5v^cdK6~C+ul1v}Nrh3hnmX)3()aL!YhL1ka8Vh(k)?p}l0H-@;ilDplMP zMzcHXi7%BDpQ`!ceBo;}zNqgI0Bs7uQ;ho%`p3TMbFMQ~DvR;|34}(rQ`hJ`3F@bF zTWRn}p=pRPT8McG!bCy8bVp1}E1Z4i|I>l3m4)yfK#5P>VX(ltN{ZZHo9j+%as5qQ zcjHiz)*(h{QfxVEc4^0eurhJP>m|#tC!Zd4d!alE<*D;)gHcfGkOVUPYRe}F4zC@_ ze4st()D;D|fp}sx!R~`~9E!Uso-0+Z=wr&569J?(*3KzfMj8l#h|4XD)*~Ejys|L0>El8S!=h150Qn4;b+~!vo8+ zvp6<;1vCw(oaq1C=O`^IzFYp0=11Vfl626#BTsPbqZ*BE#@vZVY%Be%A??&W-N3#r`>v9fvSw z7HZ+kulmn{lywKHA;hI{KkR$Ysw&*kzY^z0h49xB7AD54H&PKAkLAAWgGz6Ix~z5N zX-ipoljuOkbuVDM%blCp%ii>gNXikmz-Ytofu0zD=sUeh2hmX=R%=R=D++VdU1+fj z;CD-t;Dy{YUi~roDc?Y~eNLmqA-(+2qo>4F=bm6>KV?lM8JEg#}VHhoP+ebwt_ z+qw5}fiut4FfRrIzSa6J3)z+W5kwMcNpl_AdZuF^%FqR*GKhgVOM4PowgGV=aym=d zA5pgINFNvHDQ)McUuhj$F>eae4`LOCEOvCy&P>V_Y~VVcFIA+%%WqZLF(q!Dlm^LU z7o3)c|D1cVIpVFF!i9^?2~19kb@>y~n$*Q4vs0v)D36K;@Pa14UN#@4A+M4}uW`@Z z3)~M^{Y2b>ZoKM;FU0ZbY>%oss0;Qu{Cc=(q+bUN`lg|e;e393-AN1NE?~rD;a;Fp zZ*48Ss-$JSmU~M}vUv6U=XflTa?Dw{k@roYgMiiC^&HO@#ggU3>15;ypm>KCF{`JI zV~uhP-iZ1JtAMI7ZyW+y5=GK>S}5+k@#sb$Nv#qJj@05#A%;4*%@NGNsqbIA%;^(> zW?nP(fI8vSeP|pT!JK+-b#o==~fEr172}J`yCs zj%7c91lILlGrw;-`OC_reyzL5FS8%#5m7Uiu*b(=EXQ{5!Z%F9lLK`C76r`pC{Ha* zhBDvwQOaf{JN!{mB71(nBi_Stq0Qn~I&CGn5x|cIGuy~vvlZGoJ6O0!>PPs{wX-M< zc&}n&eoO*h_T{n`SetFX@SY*Nh1WbtjW_a+^*23$;6QusK@g3fd$N4h*{Bw@SHPCS zdYVyL&9O@z5;dhgp|032m44 z-&tK|1$xfXw5dvi`ITeN(Vag^g6kSN@RG9;L)HAUAVAo_lh&S9>ybC#&|z37PWF9B!Mm{fD!Kh$`IVs)oG?4xnI6`d@5 zKKytHuGSqi82Enazq(sTxjn?Ni*C#(@^E#N3wb+L;Rah6aIVIk=3A}b4x@j+d3GdV z?iH2GW3NHidtmxnd0fVRZVj-zHunH=o%V6TrSAe*2H1CP#KkJm9OFl%-8yl_!-aE~ zyGW@UU>T-TQzjj4;m&OtSoS38QVgeW4V5&@32t zc=-6%p`tmNuBg7}Dqm^V2hPjWlK2l+@v6-4R%D;UmGjZ+tTa{BtBXEFfPBSdY&v5`e`<1|9>nE#uD)K$t0=YG`zb zXnTmLomU_;*dzI6DcOjQ>%?jE>Ecc9BS`47b-@fJG8v3~vF;g;*W6Y7YY$vTv~t1* z&LXAmWhljgG}jyDQt58o;EvGZ>C3ctbTSdIe5KdRf4al`1Ui~OpQLaH6dfG?6mdbU z3xB*IE`0P&4`<%0eq*^g8yk(AefgT0`4Ndn6NdI~JY~sAh*4u%teLI$17F3|{m2>M z?^)Bo=l|mQB(_SJ7gnY+_#Ak>ba#pVaTh@8nIN8hS5U*hruWc)L~kh!TKG)bLA;*_ ziT(s}zKc{u+hWc9t`BLt(b7|T3nSGxA2`)+9hjNerTU~qXjc2(@am5E#=80$0)cv_ zfiUmR*EA}Fgvx?x9sW3Pep!E0h$>Uy9(-Fy9!?zSad<#*ggLsGrm2B!{JYScP7^Pp z7MvcF)0eIY$|Yy~z5nL1>xJZ7Jkw|Rhyb#PYlPU@rWL`3s$w%Dz9qjah0Q?}E(j4&boS;_6Ws zDM5v)G#8;EXj5n_DH&T2*PINnVot!Gh@M#BrcKK`N6!>F=W}n_`hMR_{{bfE!`qzy z2JVS{aB@mGd|?#rpFVms7amCKFi&;c?;hwyBj$&IS-THYIIV-hQ+n^%C>{9`s5xOV zt1MWq%+}MF8&8WX|5m*Ce6}hIvV9C8MSl7|bHJH?4oulfw<-(f9kX7-22YUQwYW77 zSjRyHyTe5jpJK5aDAP`Mq|E%C`$BzCl390NqQ1ef*0n zPkf*Y6~&FXHJyn47Ks^8?HE^n-!~oG$COVb4WS~#&(u!nhYGX!AVTwfMv>UBvjQR*+cGy~{9tnfeepP(&^hozp0#{v2Z9u(EL zx9K43p5Gjhlj)x!pr_`jg{MUi+DVZ;CeJcfCd=3Bsi(@vSxInr+^6t5hP2Lq&6uBG z&&ZVo0X_kb9k|y5v%fEe2i~c3Uhk~`06S&~PDYe$7GIvtB>iaR{Q>6}#J$Y!HB_Yc z`+)GDFSV`hv(D5SBQZ3s6S2x;a&fW?G6>T9HNM;K{q5G=Z}d!BzgiPvO<~NAED#HD z#%twVTq*$-`MB_<=48(WUuV}?S7pu0(QdOl4Hgds!!D~$_xeo|lU%plQv)ik?ie7C zpZL;C2OCZ3HZ~9&#^T)+&s`i2jgTwYV z#(QG#8>?~Aw9xbKz;v1m>y#~y|NH~M9&w~M-No8i=Qlf~OPnXfH!Y8T&o8%!`J)4t z)~g?Y!BkTm;v&(QXU}h0ujj70WhNVKvNWo(8>wT81-Si|FVXVp+~Dvk3IVIXUm`^j z52u@P-9@iv?&awg2l34PiN51szn0s>BqQ-ftUq=KDS}(4el$+iM>sn?{B+40Lq})n zHH+~qrg7kKSV8^(>o{z8_VoMNV7*-Dj6DVS-hV5Kc?Bv={ARxA9`7990qZD4S33|7d=QM2BYNMsY9flqm`iOOV)U>5=^ z{1THK8>u}gJzqAtWUVsBK_8qEhrS;$Z?)RH1{#Ve-*|Fx$!6fC~iMnN=) zo!HTkJ&uoE=z}WGE~ZF`**$mi4(cKyhry-@B@pIO`L5iSOm7I&t<{4gNTk|{OMCxO zwgcxYD!9?at~4AFjRGe+3Jc$qzJ9>N~uKo zE$f#2&)r{XGnh~=TxWMDr=Kuqe{q=MMdw+q$@b|_i1`91o^P*uZ&Tlm>1T+?d$kQq zRn>*&C%ob3=XBgC8UB983A;T*eZgA1@w4cuBVx zjT?26`G3U_n=?fMUk3OPzw-ili39j$0qS_U@#%sN3c9zu-ZzjJw}BOUTmB#@;&^{4 zgSU8Bw_)&;d+{geTY}?)OrWY3F}u=fQvl56tk}BV7Y-*s*N~<>Gb(02QHdCO<5AT3 z?=1HOasz0N?U^sdH7m1dL#&8ABX{^~yFYN!mib9ru@)e8 z#Yu4#gj#Zr_}XM_q(^*PF&`k|C8o3G5PM_}Vf%dP5_p+d@#Gy9yRN8<+&i*g!K*{xJqpgz zWJ4JaIuc8r+Le2DwuAj;w#8dt4A=D+EX&9ryF#T_g6O!eh@l2ewlLz1nUz@Zeie?& zv9u{jVT12@$u|ajP^B%{LF#Ssl4n{+|7`cJELQ3Vgav2L+tgV2E$DT11Ao>%CACMC znibyt^yBSNR%8TUq%hOB)#%5i$rRt14hG_b9=)vaDZOX>?x_lw(+zUPkB-~TjA1Wt zCXpL+$-pxiLd-xgv3{mWr*D55Z`LY)B=7v?bqU2uE@TK}7F@nQ_Be&$E*l^9TI1yo zuhthRN`4C zQnk)<5+CUnjnHS(fex zy!W9-On;uXU-W9AE*QZ>G%w60w<+gA$gmD!iUv%{ax*d)+5bHYe)7R(Q$Zap#wVz= z1O64hv7)yKj|pLYrX8OLPpIAkhVLIl4}COcgd0}p0a8DeN4%E~+XB9W{%hP@?(7Uh zeF3MoOa$o=R`s`CX33w8SFo;bt7T3N){}=-YQL)@(>q^10(j4VD1C!O4H3ESZy4w< zzE|XCs%jRlI01C{{oDXHTMu16(Lz(EV)(WNAhwK^PP|+4eqA|iE*>-uX=wfl;YVvb3{#d=bg?Itg0btp6qAjzTdW!Fuv zLMP47vai^SKZDEkgW>d_>J*MChF_H$Pqmqdr(+n#49_T0;&B}G(s8`k9hbAqb+$Qs z>z3wNZMNQ&o)kMcSp4PFu*!TtrN;3`0+G(PrMWJ%;n?*^;^Q!+#U*Co0Pl&2N6%o7uk=jR!kA^PL<_&WtxK8OjrV z*B6%u@hcPA{nHFnQ^#>W*%LV%p>iJe9Rd+$ z`@T{0ilj0qaVJyME(_{*b-KH0tg+qYNg~h=t0q9j$H6s!5?SMjJnv>!Ti7-n@0w9d z?pSPxp;Ees#7ldZ**-JJzAokcF2e3QI!mWCbJj|2>b)=r+O6ZgTJYY^pYf{V!?LEF z-Im?%SiVqGhHt7A>fiK9>=`W$gg8WUqR3DOyj<8fvqnB$b-}XZcBy75`5aJ@X4}QH zsSM3YS40M5eQ2_?{l0m$=r%ANGahuwuJNIi!S{*o(4pqVj#w)W&nF1#eJ}WK-)?Hp z7@&JK=_^@~vwPmeIAA(i=#hL6us5A{|hT!on{M z+e5AqQ|Oc(>9ph0)O-zp&SKl2$9$G|3wKT#^tPYHS10{E%qVGrmwBQfPX4Pru;Y;!ZTxl{reySE6P#7C_@QC(;zG zGzp()gc9Le1-TRSTb1eq0l|>!vwEE1dl1N_-UHih3*BuF0{pOn3(ppeSo9la%RY$y z)d`o2?qE8ztJGJYJWa2Ss@hNAX|`Lcn7H~8gw?7wF%~UiaY%U?Gxq_cudlju^cGtR zT;F<$ks{s{(?x8ApD*=NBxVe9dCWwlzHf@w)LIhR!1&Ub)EU{FK&F2m@;&iG7;<2! zxtL2WsiY5ytn|a_T2H(OO_$}rvQAdxAKzj4y;9qZ_yxyD=`U*0f^uW3>cBYr=6Nkn z6ve)59_eU>i?|Kbi?L=aW*GDSqeZDc^o;E^qZnV)!=Lh2D3x(%;H8jyG~?6V{Rj8I z9;3D9I5R5m&#@zBZ^RfqbV?(=Gwn%76f?^sz$ZTb6xk2(qM2?-VQdxa#OxJ^rG`1O zEOg;x*n|$_Kc|k~uk@OIeci#Z?bBvd0C$pjshOLQSJ`Xgp z36bq5L*oP>@-C*RWm4xy4?%^yd@EA*M7xD`I0$D|e6|JMZOsRGb_0padLJl3?*=R( zZwNQD!Lw9R9jeDInJ>tUr4-k*zbC7<4=(mpt`s6=(1oCnG_h*LAKk3QKi{O^IlK+c z`E(}&EWGtRT${>er@w|Ev$|QbL7_!OkgNyj#Q`0*GUmSMReLoM?OR0*0+wo2#{wAl z3T}CdjX@4529p6aamKJabk+{J8+4uemUa{2#}tF|bIBz!8cx_4>}ul0Gxy`BBN z22}c|Y2~AnmUSeAS(Y-?-i&K3weaj};W*j|?{Jr&jc>~H(QKWkFI3zC=ejyY;CE*Z z0dwEQPI36q+nYUQ5YSdIG|1NtCoY&SS>}@SWHOm?jFC*wS_We|j%FWP&27f>7I+TZ za{y1{pR))e{m(_qxEluE<_FO`-eZ7TpdyfqWj331%yS}b3QWQW6d8fr2c^4lH@buc zHx!#(x5%1s49TayQ>D13t0Ov$E8*lVC+dgc=?C){#zDuq-4;|AqoUO!sulWl(kuD? z6NSxr$+R%nv5fZQYvAcffyW0>npU<|n1~H%(b+NSPA(Pl$9n7-WbTP2O^s!>bCON-)0-qXIb3>-OhMjt|e}XQye`3F1L2Ll7kBL0r}m zIzo0l_`TZFzQoPCeqcr=Ro2%2XN6h5?8?)9*@;nA6#9vF@CHQzY#JVeRgFd<|beweH<)*M`${V)l)6^<= zcdk9_ah>zS?Pe*&aS8?l}k2M}iIyye1- zmUDH7f}#~LkkZ|3dlGYiLLSob5u)n;?qqAwoed&;W}l_iJ<(ev_9&7$VHVQJbs!$Vp3ySC0^5=j4JSy}0rNH1sp+)LcGZc-(w(WFFa(Wigrskh_ejg(!&~w!Z#}vok z`Ev356BSRAP1!&Yn90PRJSaL8Aw{o6rJ^Fr?lo$}gx!;LkI!k8l|LvxP(9l|YTOlq zxF!=%hPTo*=;@QEKHk@E42w%zOLWT$DVe(*e*%XE&jdPyGlKCgWSQqTr7zdt9p7xo z+Gd-EUn*RdRW@mvW?k=|0zF(lv-WjQeD(57vDq1cVMd7=N(99=UH451N;9^d(V7_M z!qxmLMKieq+sdtzHhLKmqIc^$R0DAJTwr6{!YA4 z+j}h$GYI5~2Wm6f5{s}EV@D3ox7A?~GtZ}Z2@n;{8oocI)vqgN7%nLHSEFktz6Lk! zw_t(36paB3KnBl!BK?8stzK1H+I}bsSv8UWrIYoe!l_Txs+~$+n{AnCpZrPpM{uU- zZ>AbB>z_0~PSo2~3ZycP!6`WNXt|^_(84Imn`|>i!Gq>IOr2%n3I4cIvtdZykmZ0~ zBI5`c!>isqskI^NJKg3dZuCu5;};!12n8z1N2XEMYKE{F&UdNgj;l=!$96Pp1+>W#yDK?=5a&D4h! zYF;aEed%C&DtOkYsgO!7cFnRofRB=R!MxE89-n(U0}mP@K|Pw`V5%lws;Nxu4%%;? zhj?PG4@GVg+EXA~Tbd0kK+gl}>gic|9`WW*$T@YKACJib$ahZuaMpFUC3~zg+89FjIf-bzv8u&&{6WSJGnqP;V#LR=m@) z>Vumxawaecn=JJ)i=P_$rRSCUMIWm{!CPX4W?*EY%qDJYeDB`y#|mun_YWZJbgFPX z1__qk_Q%9TU{@Mef)n!{W5f^$%|J)bS#D&_48v~4Yd#oLjKHB{A$8Ec0B2*`pUVkq zqf=u9F28ZL6!aL?I-A&GLAM%3G=?%3IV^|)*XTYQBf+~Oq@E!O6ArKl=>PB52Qe@L zI%-tMwyOVrvuqdfcvUs~Cot~2j5u}wbwdWKl|faDF!T9$ynNW-Rq7Lx#n9?muJzEm zZ+bS!x8=$PhwTX1D^!0Zo$noZ8(vgkl=)r!y=L?a9h_}1pU+WTsuUQhlCALdFO0c% zB`;OmuE{ljpYfG;*+gPFo_~iHspJsPBJNhQlcwLV_vu%sBjDC;TG-}KRP-FXenAS$ zE#7n6Z@|aLh@MB5M~Rs zYIq$yh!Vcn6icvNOp>7z_pRD5w$MBumrI%~WzYomyHl=JiaV*^Sf`E{TcdYaB|AHc z4ZfoMYGQ3noDzL6TrMz1vdDqZKZ>smZ^(>EHu{F7p(~#wZqFnpBQIN1Wo|WV~epp)z%Kg?2?0EpO^vvBKx{|j^5$(5cz3Z}*T9J=)7rxlc|KVw5m@j-o`Mk-`My8!Ux922%!f8(3N@^`yXn4Z z)Oxz7?z-bfJ_GWYse*$$%fz12l`g`;vTX}kifg0i~R zy3O{RNhXP%=6M#=LoYDGstj%CiI|5U2E(0_ltH$Jy}0$2SEzP0Z^r{DBKXO$AjY)% zi+L2r-M|*|W06zx3|z8s+1rR8LMJWCUroNuJ#;OTF1JPMRmSKFIV%cmo*{?;d)w46 zKGz4fY!Vk&RMGRpI=jNbPB*NfG0MGV!|QV$KyJ>mX8`$<)gHT3Z^Y;-83j?> zuKMelG}S`%5iAX6=J3{ zHx5~-e>uFwnWmj}@}xWHGEO1a$Ixl4{!3iN3YtV^t%LS>MnnAFX_rNKCY87nbFu84 zd^TyjwDGlivY_v6ps&0X?uPrTRJmJ%N43JXs@NM)jlBi^zeg?aQ+rfzF~6>P0s>r& z#RLZ(VTgWHTm{JKX4~I`zkNR^iOl54Cq|o4@nTrhW-W*$iPS>+|) z+mVX(SYYXHU~fNckjO;0wZ?OJ>F;Yi?=x$LN{H`|ZvjhikB_H|HeX(6&};#nW$qxA zcJ5>z4~9UzEi?GNG_UV|}`-V(US@Ca|CgYHRfRnB8`GHG& z)@|T!t>0>U#ceBH8|wIY^&O?{Al< zjOvdqwR5hWw2jRev?u$?cj37-aOx!W9hh&c@nmg`g&w;fIAb5)&6i@IrS{Xa4|sZG zD-r}TK~TN4M!@orl(LLF2-@w|1`|t~3K&~HcXfvld2nel60d#Ekh_u(d_>ur4WJQx zn*{Uhwj()oL0oW!^3%6cPftK1z(!^?x_^#l0Z1G5rh50943^8#7_#?PrDq^Kcx#Nu;Jwuc?|`}6gR)zAa1<|(?d8||8tN3SYU zvw-M|o8nLgg#r%E8P}>X$)W8H_yE9Q=E2R-9*gk19_l&Gj*I{FZ>3A=D6&a|kp7aR z%TwikH)%XNk0+$r-oK|YqqD!`bxI|j7_}2WBK#7Yh{>H>9KNoV;>8rct|EfDhxhSg zJ&E1E0)QE6AM?_$W~E;xB#T~7T=((5^%Pd6Pz!Of6bmf#{B_Ht0BI$<;Yln_J?AZ# zqfms|$PX`?kI)l4LB~~~iH2H-`$&T6L?7_|VF*-fIKw<{R#`5hp8Pj;J{#}epAIr- z#8ZfiGiT+lWzoVKc2M$h3JXnAddT+n>POc*$Ps4??;Z1 z#8ud(W_Xm@T5?)p>$ab+L2t8?*Ezk-L$J8sWSgCaae9odv;+YI4lM7S{;3w%+5#$| zjfz3Us1(b*S+08K$ROr7Ru0eBG4)){bfXfgU4baJU5=?Bc=F{ z^g(zH|28TMVY^mf#8z#sc^%30SzWLg*%;)S?$g}IE&d0{n`{=m1NT(>#v*Gn@-UyB zd#g`Z>TreCRWR<2A#?TF#g$&PkHA~eN#mzM5an>E^^liiBy#8o*WgvVGaa%~aB@Pp z4jFMIL&|vEsBW{nJW1rtxGnq(Mul`^6D%KS1an#<%aok`Bq3fI%j1DnK(zwR-*iPS zhi0-QWqbuDvumu~I1~&7&Q@88k|6feQZx}#cifSxK!+B<9naZMWtgp#PM`8F;V{$p zL(iDJ6oKH6L{zIbq2Dxqw1Ua*+i4Qp`EmNj5v_V^)cN&snJu(LAGhAt?Rx*Kt$c;P z@J<@Jottsuhf=YtcoC}>5BhhpF27?;&vROATl~pHxk2$pKJ3WhZ6Lq*sz}!sdZ33e zt8+#oQMG2Hd>q&*wzF~soae?rB17UW&pa3)I@6yW!K)?I1-BBJvmd71leY1qb3c20 z7!RbJm!Br3uo|dxo~z4DYsHqbY8%O#JYK`JY|7%&nw zX$R-8)RUdRvoHxQX;G1Y#n3G@GynM(`rqkJ1Z4CspMfDO3(Q_%Eq3OXQL1EX`{xj` zJeL}LwC-9~tefX2nV-G!#(A_*0d4yI+swX>eEs38uGP*D%X`Iz>7Zo>pfmbAP>jNZ ze!2H-i*&5#Bryj~A6Aj@Zopcb=#_8J5YByXzso*g%UQF<%|`W^{XK`~Dad)~$o*hj zGN?mGyQc;T($Q_!F_`1-tvDw$28UAHIt#haNdvwXhl@hXcEZVy9kSL_)YF9oVfybN z$lMwc^-h=_IIm zx~b_;=yK)XU-UORMkHaqf_MG5^Rt`_XAkcq3{}SiG1G;uHus&({`J$3x9J3N8}*G4 zV`!Sjlf*k;c@u2-rGWbW*wbB{PTE;F9qrQ z5%_EbKM`>+E5k%AGbk$-8m9R_ED>31@}cx{kNeu|4=O1T-IYle*P=vb13tRBkTy;v!is-wwrW}c$C{ckV)^vlFdfOad>aCKX)i~pwfw)LqJk@_e|Nikf#Fvq`djvn97A#?luY$Pf@-99BX!^%dKB(ED3xijn-?-!ln%SAe+Q;2`|b zPip4{LnY@V4AJfKP=@gPdU?DMN$Op(Y12w37_PN)0*a&@H~Lb@HPBz@J8CRtVEB?x z9rF$%{7xz)5rhnl{4c^1zkO6u3X{Yotht2N=~dCZ6?9Sr@|rym`$`W0F^n2pya67! z!e(stpVb5xA2g$vv^TfjEzzm;`y076mAlm@7@ELpSP*Hwjd`76rM$PtWy7fnX>O-R zc3QBT)~L6ls7bmJ+r&YNEg+bBZXbUCm`H7HuzBbjvtm^`kg$_xF80^kE&18F=1Smf~8 zANb?iwjSvf4k7iG0X~4YZ)bFJEmh3FjG)BkbIyvqT`SbH5vI)?)>z|!6Bi)$JA2P#F zRm*TZzObsxsxRUNKAl(MBe;3*mGI)xzhVu1&yZ)7Tj**k=IS+3m&MxDn_KYW9YA8C zqo6U-@O4#liLz}`ne{QAzezmm98Xx*% zO1RO~n40VM!LPLom*ck!&wh4HbA_E;dC%GP|Dm=5<&?GsGi)1U9i#T`-nXo}L8l6D z2v8$0KehnQ5)8uw-t-ogj7RN!3`n`o#=}#EFCrlqK}$U;FnEEmwT~e%=%ci3rTpPN zsJQvUGMag^+)bMq*1h_}>L}J3U)oiA4#HK?(RrL}JOmY~d^OaAQ*S8j+-C zs<$LRcJ#$?gzc=}RG)^(x`On<U$ zbm>|qSqu{3`Px=Ag|KMKac}be%(&84jg*p7dJls2$!WzK=424v1msxXGPj!ELtQ5= z0bthsu)Lwz#{}zGYdrOKOk!M zWdBM&Yan2+Q;`kBD)w%6rojeJ>RS{80Ya5VYA?u-S?0(i_c@D6(W4}avb!HP)}1`dY$@zf)AN=n9(3U53ElnUdL!?RV&WkOwXgUhFD;U*U-~~ltlGy zgRxmr!S{XAy0y}4@8TC>kUd0kOus4yQe1yL%wJr87!&@)utIwU+cq#P{der&)d5N! zTsAL%;mM6oiIfr=fX?=06!?mW0Xj`uJ}`_ft$oQGCsS-XiW*~=K@AUK9OounQHjVW zy<#6qAz+99k#yB@O}=keM8N=tqDT%91wrYK4G;wB6hRQ_W^@h^m`Es0LYh&MQlndX zgfKcs*MQMuqttib-}~S5@BQ4@=f2{c>zw87@z``aES({!%l2B)qpyr>Q@1MJ1lS16W z?VlMY?>=wy*|hNpOiGhVL7`JLW-B8XByk{8nOr`Tz%%bHQ@Hky9+XXMPaZ0{P9yR& z!tlx;O>Kov`S-FU6eKadk`=7;ZY`N zwcdCyUWE=Q?G-~SqXg$`-{NjwV|8SECP^}_2>vrDcYZ|t^{;;EBid%)drlQt}iAToMu% zP)HS1M*iSX%@1)SnJd@QHxK%+ooZ|M9J*f_%TAE~sgKA5Yb3BjA_J)0u+e{0mEP%@ zs?RQWK&h3l*&FSK#F09KP|;`$vxK$J`oXv0lCzq1u<#nWpu+2f*Ifp3AEc}Pi%GD% zknACn^3~tNn~z)pIlF|>rd&RWNNsv>f*-RKwdl_Yh~u?PNhS11zVCMq-oH1NSHjb^ zCqR$k3uZAdRo5*(YI6$Yk%cMkDHP7D<+uEnWu-n!EjDCd-A~^i)r1LRkZX^({Ym zEsJAo_5bM3d+3*wnW*P@gr00{qSU=DtF{c-Sz0_*X~16`&!k>J8#Z?{ASQ`DY4{`h z-3baEu4d#f(Mluj^^-`qE)jjx2RNki#6HWp37z16c1$`Y;kd-AMAk3>7w=( zm*Lm1w`f_h0MIKv6@!~O2)N;9ZJhwW5}JsFN7L;H??7`*mj4RG-u0xIf&;37@o2U# zhbcf6mq(mvGl@DY{&1{S@_5~5tl*;1;%CQt z10g7{jDB~qZzJB2cq7tQyZF6MGD%H+G@>uABWA{ZtOFts{6PFBc^lfol?7dUn%wK% z#qOoJtQ%PL*y}n$R*-;c>TW_I?#nE_V%a8*kB~jmA7CiyvVAhob+H-bAlRF?Z#*Z( z(Y!>PYgwU0A;+FqGfWo8mx(;cj+JeGg8tn6z#5c*uDDT_Z#pI;;B%v+utM#hHO`+$ z0e$&z?GI66Kc?=0sM>x~_U|jk7xg$d}!KUcy?08 zhLvOY&pmQi_$K!7^Ue?FCLt->^tME-XRIyEb4^@rh%mG{wKJn8qq5)U7-G}eruVet z$17pktT9HJ`x0rZJrf&W!{LP=%Lgs_<`v@jgXU=Fc(}iK_srkCK#{R@}?*>Bx zCKVt9t~sY#0wQ4F^Nt_3|F~$M401@-9SoF>aOT|- z{~LCgGst&))FOV^(>0~s^wx#i>Gz~FM)_r?LM~Hb4^zuBE8mQ@UiDkiJHVAf-O4RP z_1ttjw0P15^jcQ#D~8uGchc449OZc?vpJ4&d#)Z3hfIIzG7_OezcgM}&1?MD&2L++ z3GZuqQBa5+8T2*VczwOCgTC6lV`{@+)V~#(rSoB8o83A`z_ly^V24#^!%3x&-1GJ` zb>FY~J!Zif^G_EjNwk$e{GUxAOsuGg`ONQ=*8qJ)0t0mQ9{3sn9;jTF%k#j|>CKjR zdo1%7F@xH7A>L5UH+KJ=;is=!CRq01-j}8{*xvRF7jjpwwzD62q%Le$HDQRKT3H7<3-$WGdnLBNGV z32+xE>wa4{&`Nl^<4!wyE4^BsIPj0@?cP&+L8DF}UHv&L)aWP@+!+fleRhsnttvFE zR=I|lYC@5g28YU79rJ6}4QTyMOF~I_r<#~sS-u$QQCy`t?bJYuGm4+tI~O-E2_Hv- zBESb60l`OKK3w4o4?bSP4=}*2TXK>CT%XGi0xtpob}Ihf!G^XY4m{9%zcT%-gLuf` z{XpidJ%cmsfdIaH-l(FuRpog9)h5$fRIQp9U2s?liXWAAHwR4`By`%{naw9@+e*$y zY%DA83(lL1U6l-9=X(@q2jP?5S-Bg2zsR!-%{?xm>`5xNnW|VDQfE(JUN%tOwPD^(+IoCNkvwZbMj2or<(?O2wdSeYNyiUf`!5feR^R~}2DfkN3O^bcs zke}Ytcsa_%QPO`~m~o~bAo@d(QagH>L^B9p#MHJ{?RvdU-(?pzvRa7_g2cloc*L*H z8fs2}NR{=Da0A$JeE-Jw%*~OJS0Znim)-~c3K?em$Sy+yLZ>Oy@ol1 z^i!oPKH-EINn!f-%T4ZztLpPkAJr;0lUBm1ZQOgzY_rX z(%$Ox_gMagetl}WFXamcOpH_n%#&WGC;8fLm@etm3%6Jj1B~_T%qY_n!XpQrtot(@ zfd7;u%~h!)Xw0(m%WgR7?ZMfF?YM%SMO9qGU`()I2N?f^%nuuMnFj9 z$b?QmIsW}+j=T=dQOdi?kF}IoP+5Zrun%?BsF$8M0NCKQ2vcO>V#J7Pm=^Z5n^Gzw zWF4Qy^q9hC9CaGLuQ%>}m~{ai%+f>O4IqXb8DAo3OagJpasyb9=I?S5ZM*mDWC2Qu zKejodjU0ISRY1Szu{9Bw(+7NwbN5F7tdJ%IF5)Bp-MipS$cexS74NV3qnEO>fkTkP z*d1V7qfm9C-tKa2sjK?;jq~j38uz!jqlwW1X3ZFRZS}OG2{l&%#x#= zp2H8poO5Tpa^3}iLx;V?d(be>l1WpH)7&!#XL=RUTX1a0O{p8L=Y!g8E!$InC7;^W zMzA5??`m(t=hhqiTXwe{m`#=w7LK#gr4p_TPg9I!p;D@>kBt$))(y1ETU#)tW z!o^%(FRCWi$4x2}A-YV9q%{emjo012u2bqs+4t2E(L_uzSrq7#wluVDu#-~yIy74# zSkXrN*f#$@J2z7~?K0(XOcaLaT`F_!k*`%Ab3X0vj}Fl)rW@mHc$cltpkHfKVQdn6 ze@wF|9vgA1XSt&uf?D1$SP^%QSMgy@embYQkD`PH-sSyxO<~`VzmRyXGsvwAo!}zz zvqj*CUAc9*HXT*YrV6V@bOuW@lZm{Oj}SnUJ7LWk!V^IxdEC4URi;lW>ba-q_oDJ81I^Z9rc7U9V^T*vsC>s)WqiU%Hc~zw7Qj3aD;@md;t=S_C&uzH7HP zT08dyk;Md+XUmQV2h3VI&U#wSdK!@Gbq|(hy=ESTgo3Ji({yU5;M^+10RcX3|Km@3 z?mq=}o7rdUcY0X3Llrb-l%A3DK0T+O3H=S6;KZ)2mV_0H->T%VPUxTtKWkC> z4{q&&nNHG1R87=Z10#z{)}ZH+bSk8O3K-lZFRadiWmC+dDmtqfzeW!dS7Po)eMc9mz>J)BkXz581lSzO*+`B*{T9GP`>dCwdx%-oUIkfa3)g+pvfBg zD-UXrCA{^fJOw6s)t7QZco~LUL8KpJ);*hhn(Y2j7yjgFqzIkPj-);~o@0$il@FCL z`&jx*?;NI@3ZxzPyc;uN3PVjS4Np_dmLKHS}wKZg~w34IT?vJmH-s$A7{_ z5ios-e*vr53(XM~h*ROC5+S#+caaiKS$7t-wzR@It8J?5ZtmPjh16vy#YdcxrfCay z=F4KW#Aj3O>7|#$nWOAux(`4N-z{B|x6hNJZ3p0l;kT?@g)>e}yXSGQ{ArS20gK*u zp$icZl3k~G4R8j-o7cwBACa)8C$V=p4r--&XY0YNc<&Q z8duhCT`eQ#zctb<{?Revc`yM=Bw);zs_x&NQ!R$>%a%gjIRVFB&kC4Q zQVJE%K3y3X)4$K2=Wply`vhDs2R({wl7=Ii9`iuv;o~fP!sYFm>~8_9P7#!xQ`DXVv9Kc3zVZJ^aGmeoBTJ(?O zFY0<;4jmhYh5(-hq4`RovBSXa)_N+C!p4dATc2GI#z?Uvnfz+gSTrYIxpIf+f+?xPY+Uy_oyCp6s;YE zar+Z%@t?D}^;fCK)Z&56?38bU%BtVJ-b{*RIn0ZUtj@*o%dHmrdKWJn7{`=+*O4+V zP5yKAjSI!cyO(_;Evb%=B)RsbA_OlOf^io2z2ox`MRO~`>9GO(^%RY9w*-oII;_l> zX1dCPE4O_5fXlX6Z!2w6!jDa+zAf9P&kL~Pg=eA6~~mL~@wwO-qhA#SzuWV4UeKwW;q8G$e6*<(*NkzOjeE<^_Yo*PB) zWFK6<`kAOv{~xi2f-i&SF=il*WtuubtM-J+{AeSR)QQ%n$8s&NC~CnX*eC-}-@wHe zp7<04OrJtY_yP?qG>FdE6mq}-1xgyz4o_vvY%vPQV`4kHrX{D_A^VM~W&!&(>6G6A0SwM&gx8hE*KoO$ntBT`kOc6|^y?nQmRqByM6?W~ zJ@#YOF$q44dd#uvw<_2uxs-M|C1N+e5k2!E-R^hwI}Oc1*MJkw;{1L6EUAS?Jd!95 z?KI%+@X79Xk96x)(2)+-8Edzsj_^jt|6qM#>4hHK#t*3McvFKFj-S=>4A!vLq|#0b zpYhf!k)s4*Y(#z zSa8zky00KV&YjBU2;*Gdz|JPhITEZ~CuQzLz9A`JAWtLiKwZ2k|Ag<5m3`);= zRx6Lq-C3aU>sFX@Z6!u7=V<+f*jI@k|2R#08HeWEXxWn71@8P9-C~CP(p1N9cV|h> zVh*!MH|2C7lB9aevO>KA+8Ja>FN?x@4km`P26mX!`BC9} zM>h+0Sj~{4)pmhFv=snYGle-<*CR6|Wnbu1mysZGYDUn0>z>yoA>UW=TF(~fxUn{# zd(QK23x&@?sllLDxc9pS4VfX!{OiZ12X|#HW<{b7Sx$*5?Ip(lYTvV+jVY*)t(`L2Ng_Y7G0#UI$z4_}%8m}IQsHtE*ju|`l}L6nSG&Ft zxG&uSE8H%v*MZ5F1aO}eba$7N5AKcH0M%)s7Jm9tSW^K;-R_e-t#mEQUXWfT+32qY?q@C_sz zL;=K#HQXS`vO~WLDQ45`C(25kV~R%UUOP_bbp*mf;y}U^_WU6 zK^I{nkNAhr&zq2)=y#0<-41x*{B0N^nw3s*#v%cofehqQ0-$N-GtPTjcV_8QsYL~J zmOEJCLj*1Isx4to$oJ-QPPSWt3}vxhn^P+3q3tl#$!-4^#@Se~gJ-Gz=A)V;L!_|f z4HUn(vL&&I<~TxiJr>?Xcx33@XlVGRc}~T$OrIR8R%7Jkk&*BCtXx_-?8Q_&yxQoe zXQAbLavZY@^MeTgxeYfpLZU=#SwR7-*UrJpM8nDpbv(oO{yEKr)Sim)qe3?NNT|I`FBX2%TMO=N*wYQEP&xD)96;^JqlKRZ_!_<92L?IM%G8M9X?Q>RnQgA zqM4_U&ao=8!Q$gVDBbKy-FCc78gk#?4ZV}b5k~2Y zS;||~qi9-a^f=9zDS;XgKBY&UKK0i8W>n4n7dUGdY;EBv-nvc?xSt*5E~e69-9eje2ZT1i~dbW8o|I{p6`WyBvZN7TsBX2%7)ur^VxPHjP+Kd*vF71-NY<<$ov6yvDsHD`e z=%~02AJXWNc~v>dq0#{b{LQzg$$aMr1)FiHjm%+>&W@CRdSgC#ti2T|0Ts5vpWFM* zaIX5TE2&*S`lBC5fwPbxq%b`7cSR$&T#%HM*ORH}>Tj`Fp{Kr?HpPP6?TTmCM!IC{ z@lAFlHER+t;Avc8kAr#M`fDJZwaxkPy8q0yyK{gpP8BWYH#-4V7u`QNA68iPLPy$nzG_Q-f`EkO6DhnT~07MXV%`@1*i!~fH7I_ zI$RNsRm6VsA^#2ri#0|0dqMRDAq&Sgo{DTmg4@p}BmPs6hs z8*R+e$=QtJRbUj}|28S*o*}=C&Ch0ca6^vbrmv}+)M7mK%_yEjlAqpruaj8oQOal? zVsi0M_}FU_E_jRYf0*iu*V{%40>!#+ zkrv6$6dn$K1nK31x&6{?b8K;6y=#;1vK({Ij@FKApLMoN+4q|H$a(g466#`w>nKc` zp~E%al$v5;vAY-$&xG)`=BFzxkjP2WdO^tpuSrBUHxhw9c)YKgGJnJ9;Bn{jOulA4 zySgae=p!OrduGWhTG+cA!ItIM^0Jv{1!j}H&4lI5mpGG+RP;WJ2&+ZTkozAl3vpF+ zEH7Wnq~L`HIu*a~&1w@VM0jIEUjxx>bQcOiW7;g)p0>F)ZDw7l1FwIFJGoZ3xvySm zK4~rR^iJou`vqiJ|11E+-449Sz*QD%?}6I7xL?@g9xOH% zP9DL`#(BK1DszucshERFF=ysqo8}u-d`D@?%a;pYr#6l$zJAnEM8TR>> zNAFzn;4vnwDMI~a6|?9=jo9ZhS3gj120#DdnD5wmUD%|uBf+DIr{mVP4v-zNbxHv5 z$WA9un2&4zy?%S5!ym9{ykNEZ`5)-g`4>qxwi>0QNWdsmg_1P9x6LL@90B`{pnAHE zMwjMh8_2er*b}&u0Ci2h-CDI!gNk1KvrlPT-Bx4&=%9MLh~&)REGUHa1Ow!R+SmQf zToV67a)qo&K8xNi$SE*7#@2A-_-Y@*hmsy-=HR_@DZ>HGft|y8FhJ7##9iFz4YmZ3 z$DeUE8fspq-}lNMQL{b)h{Y>0w0mS$kboqH&XR49vT=rZ_qk88o9R_6g`RT?{K;x; zMx{<9rb3joD=!ljfES@m|C}rH=tjcY9O}(hU|E7uX)$CMIESgkU0|a$Qh{Hz{!ab+ zyOEBp=cARAJG-@^%;o1#xN1k*`4Z{n5_G(%MxAIUK!)|EV-_UO(27Z`vc~-8w-wH= zx+@5i#Nq^%l*cDtI{0g#1hU{4o#rmDl_9XQEb6G+NTiiXRY-CiSd z#OR1>do)GVb*GyTL^&;(c?yNT$)yNveXi6ZO7D_Y$luj}faK(J?0s2SL(Wsj`hXhL zo7Jf#@H4|9{ni(%Q9vQ<>$a(tsfCuMXcIGDayd$T%%(k(OV7~Q(YqXaW}FKD#w`bBfi~QR0WNdudw{|E!3!Z4 zTcE^a%nvunc2aB12}wJ$D#8Tv8DX=&9VxpUYkiL*|2zAXJpP_Pa4Ys@L{o&L3DJH$ z=FtD^`gwh)N(>K5qbtWcUGr~ZbF?b>rO)J-2Lj)r0JC&W)Lz#T9UGHKNp@r0 z5y}5}c1W{doN!IflQZ*6;Tz`rRddXmu`+@j{Hi{lmw^kHn1Blol`K0g>j6AN-$_L< z^W&fylKa7kU3-Knh3?zpZ89KCLgV*w(@lb`+q@t_2;M{qmdI4^wO>$sT2ay*nmR)} zw#hHTz)+HjCzPxkzPm8YpDSNAh#h$&h|Ati<1ZQTQl=LxaW_w~zDX{F>wY%aBPcY? zZe}RIym~Fp`D<)hm@tR(wd)L1*RJ1n`$Z)2gDya)2;RN9o#WrbM1wcp^~GP~`mQ$5 z+qQzt0(L);!~%#=2#aUAbn6)39!Vfhb%Ay36Ig<0vN4eO_sqh}NrR0&vRCuf2l3vB zF9}}NWLT>Ts1Zw5+pAd2=B8f|kDB)_knsBeG4-!-C>%zCZ!nZ%N{mQ~w((6=&Xd*h z54PV}%Xim^Pn!V-Y^&k4ZX>vB@Ex(?IY^iR$+3jD*QDz0U|i)>6QJ_B4U=FD=T!I{ zYRpc?M<1LHR_{Vrl|0ea%;fO8#K5<+)4^4yqfXR$nFJL0 z$gVb+8p_s9^ZAngg)uu`X$a!1W$0H6Db_&3EOrBIlhVB7l}harpz3>^0qMmQE645H zGg_?MV#~t1aA3vJUGA%q#if7SHqFvx^W6R0SYe5CI)39UFhTag9|cKU^m8F-Fe`FP zbQt4Yp9r?0Xy`17Vrk$BBvKZa={+{afXZ`nb>RlML!(nh~jA z!TIZ+BkFzT&zKhQUe`eoz&+}#6cLFKN+BnvV}-G65fDdD7SIaRJn$39Jx)x_c+jXA zn$VzN`g9J3m}MW%S3S%Yce2$qXhSjaFjFzp3&)gG3yQMe;i3^kTsa#(c5%~(zq5vr#K(D9r{%L_T`f09b zgxB~UTz>SzpCkAt?rnz1#sPA5_?-4hY8S3R4V3rwN7Qnfl;S)Tkz|I+gnA<@^~>Z}p4Nd%LeL*0FG4qE5>3piRkrnq;$frHskdu4m5-ieFwz(5zU~CgPy`A4w&DdhLvHtI3%U>*g zd5jOPZpZB^xKNURno$^acnB$KddDvmWPodr=A6=^7Hxi$JdLf^uicnc_%rusS8ZX( z8M;KiR?Xtw7(}x;Jm@5WHqIu>U6r$|yz{!yqqvIyiRiAg4!E3D^pz$^&adHdbqDUh z)=)Ti=LW`Qh2A-@sQZDjNnd^gt3W793^8&y^u%2PT;3@kr&1p!>UCso0649f-tJrP5vZZl(m8 z#6qo#pY(r=eq|fs>2{$dUgIbJ7j`GdX}`04NLeenBa38G%XXiwQT5{wQ8j4-h7q~- za850Iw(FM#Xf=c#*Wp~u1z$9od+|`Bn}{_dUxQ*9tGDX38XHvCL)%%$;I0eRs45lw zcXyS3$bv08otSbCWNA7*HOg|YB7)Ye(KS(Z)JNchtoz3!2{WG3O#G8|D&EHGzh20# zW!y0Z3@CX|g=jCdJ<7+J2l}-~xWKR7`to2kQmk)$4`Qy7_$W>-rA#Z93%y=!pfj)h zGBh?Yi6Z#j#zp+q<13y&qb--Oa&#tv4WU`vq(sp%FnDDbTK45c+T%f?1d96X;RudC z9AkZiPMeJfo#p7cems#VyqKxhu%Y-E>`#geUka(uyRd_{mc1bMjM~?nj{g9lLapwo=ceIlT2CZWoAetlj+$Y$N??2{OPhMPF~V-SiRzl~mw2RHe%H zm*lP9;^}W`4SqUNmQ=y-X8m(_qPy9skx=d1= zVjo}*0o`B|0)J(Dp=XX$(r#^2QC6>@J09_A)ET=O-~w35*=HH*?38v%&YP=)O^tT1 zY%8}a$j5!?eg@bNkQ)e<^A(`=r!*@gF2{FbGePnYpQ6sn;`?ENNQ6|Q zVm!e2Y^WnaOCBF`vK$Fd2uXD*AP~NB_7cdU{WYtZH=q7Mz=rYSYWFYb#Slp5zc znwro~#Qp(2Y6sSe%=Zr`k@o!H+kFq$XKx3Q%J_D=l`XSRn2{32tB!q1hBfPiA}+x8 z?f_9TD7}*N<@aYGBV0f^d2mL#k5FBYNB+yfO7iZT%l5e~CPo6yq9RTY16 z3d@bQ?}wl|eHB}ER_H((#MD{P{v*H{&irJd;kohCl4RR|y9dN?RM4-zl8}IxGbaU^ z2Np|oAI>o7`-GIQwe4G1H*#GJOK|K25O)u8L?2BY+0i3LF1QDNxW!=;lVPHShy*{M zw;0F;Z-1?rJQb$&T0vK@-g+oyrw1*c%`ZKYrgh* z<`DlsRD6T@`#g0HEXj`t_UY%NzrkWmhdlROFzE2fTi{djt`<5zb^CAD0TCrj^4~Jg zfMXHbqqlaBx8%0ET+HaA$7u?+W#<%Mde(Nue8QaFyKB(b?rKjv8iO=1Wty(J2ReJU~uYrk~+!9)}v8d^6oL8=h6wo zSNQ(@prSA5dd>9)Sq-D?4(WZcmzneTxgmw}h!q^;WyAJf?s^a)5Y5qr;HHLt^OTW0 z|9F=w2+^i8qlgb3DWdZ={-W~vVovA7Y3R%6MoE!BBiVPA`nK!!moq5Ma`mywEi4KTb~yx zPw!6QQ_4X9-FPJH;o?|vPOnPZLhkHXr?c0CLU9x${@Yj(x-gaR@OWC*5bA(=a2BUx zx~4q1#@^^`_$S_1I_ki^&~=zN!r6~#1TQ80Zd5QRAtxxc+3A-|;?E0yJkU%K>w|p~yTCAj?df9h9?nn( z@Ja2px8P5}0{9PV7LtCo(XwYyMt;FhAav8mJV(VkJK0C{Lh;M)g4q|Y;3PXq71l=$ zF0NK7?sRewg_YOKG-PA_U==Nk4`k?_aqSI2*+XiT(!ASQ$}BQQ(S+8?Z~5Yn1&4l* zB#SxsBi@fuSPv*CLLE4!pkE;2KQr?hLZc%{Zgnt%Jh{a9M)c|=1x-% zTs7W>diA|K2L?o@fUd!B^II(&^IlHjb@1ohiU^MX?v~WSj2%EN*G~Sx(T#r| z&3bk*G{CB04Yv&8#BN;Fsqm*HDrrx}taND5ZEnbote@|n7QN7QbL|FR2aHin|14!j z7FIq$-DZkqrA)x{BnG6rT*$jLa(PSQ>Zj~OU+ z(9^%cYXsz@x}y5RnzF*|FR5G2{CKK;qAHKW=a69|{Mq2A^oG6V1Qbon!O_657<}^b zQxqgnDLMQlenDe-kUZ!-j<@kW2eq*Wk|J^zR!t(_8|HoYf{9;bt?sG`5RN=Taa&K4h3v~1G(%RHz3++Zp z2XI9@?O;2pbZ=CqdfS-CcY!xNMRvOl^@c&7v(k=gt>D?D>aPR$&YbjNqjZsaPc4)O zr;{u;)NR3PAA0s8Y0*uwC>Aq;OeeW9XYE$FHNBICS5lTq-!fjCC~GqOl6M1Ve`lVL zG86JsAt<+DIp;bn<5^By&H4A!80s{!9^JIXUiMT8R53-6wPU;Y7}HlcCj-L+b5v*c zOz29;c_`=94=xnVYlVbb1I;gkD?;iu_bS#BQHy%rG`OxMqMrg?+IuzywqPl7*<&tp zR!it1|FyAzk%g-k+R;sXt2sIZ=(Gn7`0gWNF1p&)}&Ok)JzQZHttHO`1@ewSVSE}#K*ylI&8dlSCkj*GiiEVK) zEq}X)&b3Qem@{*uxH>(>c!(9{OSUN1_2ga60CUfbXSezHylG|Z4?h%h_$&u$Z*Elh zm;NR8W@wy#yKsiDQ(^A{f{h4~2kt1>PDG=^2?%?C&n=5NuF%z&#mQ5IUm`MHsdz|J z1JEZT4eb?#1pH*;*K9pFXXOuEhMGe&@Ih!SZdSy0sN*a}TsL;f3IxlA-sS?>JN;5n?row|?Fyou2O0i=XJEOoL z{PoBo%X6^dN(^p;76?9y`N(zLw|`@ZHQ-y#*1a22o3ef?>rl*xYfuU_(LCa1^AjA$ zMU4rs(={^E0AhcmPw^o|UbUU`TES%paK3nLedc7ctJLCzJ##R;^Iad%f+rp_m-gs`)p`9t;+U?tbwSN zoC5EQPfVN~Vg;w@G((K=XF<15>7dFM>jz2#phK(V7gSJ54$Hkm7~gD_Bn=W4$lH)O z9d|oh-agT=b}dMoi*#WxpusD>njdmj^k#qxT6lVNgVX5tZ;T>wk;4umU{CnXv1JGd{EPPI{DRO_M^l_??Y=$RRjH3sx5{I^F1cY` zVwtmt;!5CiRAUFRXb?!eh>v9=34d>KrmNS_dV=cC+RvWc@mj3~#ZUy*zc3ZPDi+qG zZ8l3sa)g~*Ry^wLeJw77{J?*}72H(RZM$o;Hic)9Jrvoqq+~k?eC8wXQlxe2r|zRu zA@Z?%f=d38KWpLVSk`ZPzR3YgBF5)UBcrp5&9(jK%Md9rHexAsIS5-{lFqhf&X3&E zvPEaK9&i+!!PGK?&_}N~%8x<&#m;D#N{|xJfPo~K#u=O5RuTlrQ(5N3N_pUBET+gq z;D`f%-B^sI^I-r)iR7iA5x^$4zS&1D5 zWpVrGmCtEd^M(J&Zz9%^d>s>wdD_GyRDbNg2Ce*sYP}sIk3d%2{cs;23Y36VeL>-brji#Tfd7B4(^XQ68 zf5w(=9>ZAU^JcDe+g9j@f!M&z1?!NdZrx!2L$t=a{mWR?QE($q{a21T{;+k~7$ECmb@5BpBs}D2yFd+ts*_&%YuUp7PC_W3!>AQJ-ih7;$b90+jcm zg!|Cff}khP{6VQ^MuI7r^q5QFXLR!Y6A%;kwCaeaKaiL>2wc?;ll_@F62;MRm}9$D z+@_uZsbGai4Np}r)a-{%yy@-h=&@8mr&(eQBJ~6wec3Q{YTXYOuP(UuaD;9I)|MZd zH5gIDO63b)^*+P6D7(gb#t*q~f@PW)+8@W{HPha@(LMSa6)VT*pswAql62IN0Li0X^B{7 zQ^2$*NOo+(v2dDav{Fk!p5sr>@Tg8`?08`Dc!zG9hv+C}|ELaFt8UQvhmOGY2h!YD zeVn|4jv+u77%uiEs|>?xV0J1mG3i2$b?_%Sua}R+n)!zAe+?XV@m&x9 z`QM%4Iq+9{(+#)1*(DKY>FHV6r6sFNOzh4(m=de|Z1>s*&kg^&Bc$0XtTiHSR zT{;Zm zwQ1`z^3yWbGa)4TZs6Bv4(%pYr<)ClGognOO81=l8_v%W3vtsMP_6->v&6$4+F;QT zd7zY^NLp7A+G=NlPY=23tgV!l_uZrMm^Pm}@ssTFb$>2W2aV>I^-l+jUA1kEeB88e zMe%Os^$a9jtN_O6{X*_90c2v@_6lq7Y${b*^ym zgN!8I&mzWNtFFQbw)UTD_QFw|%|wa~cyhG^?GH9&o_nbe6G^*x@22u$y3G z)tta@>~O@3q*SY*NjlI?Ft2lVHN}f*WSz8=&u25hS>JmAD19URdrx@GorSBsIzHpu zOam@j2@Rd=QqR^$?^KG>#P(9%{9|4n*~l6YUKK;u>bl5a|DK1RC8~3z z4z@B?$W9JcKf>56WzAjt?-XK~yYB-@5BA@_p(@IG&6`sAo`EpR4|_rIqBoFcC$>6S z4IsBoK%^XPpU6FeyhN-)i6YK@ZrJDm&8mI@{7p=m9rH}KdlK}|qLc7C_5Sksv{f0e zx7#w8+HlfmZ{MX~A-_drduo+{F^Js~i-dCfff&K=kRl|n-cm2O&D(o^$8}iqn=aIvAy8#vfinTmBBtT^1uFdNujn4u{xtQ15PYf?XhY_GD`otTeUfOJH|k zsz}m^StVcE^?rcHRLD&A)3&XZOP8sTW%7B?{j{h9T9#qpGeT?NJSQQd6wW7p4T@=& z_T5hTe}vDi!iMtAwV#-tH&k{^r^>p4M;q)K^?2MPLQdsA0o9maL}0&^ zyR#PQ2Im9cY+d7Bwa1q_)K5qCD%n};eCkfzbD=s(IdgB`rnULDH#b4@+<0%Ky~Izc z^NK*ZA94E!Wv~X$Jmn;`L|t|XHbeFS*GCf3TV%+UdXM`rkbYA$_x#0g{0-HMt)uP% zY(m*N(C*fy@MIah2ofs-JB}am?0iR0AEFz96 z(m;3(2&qx(bv9H=c$%y2eviYEb2fwhPD!O~z^a`m`Ap6umY6iLJwpbj>Z8YFg1Jg9 zF)PcKje2o&;+esNZx!fv_IQku1@A+1Bp_2NUfEUreHzaN1rK_PIu)~I+Qs89iMyPERC`d`JfB}Fx# zsQb`zr5uyFKsbL@@N-Vh>W`vppb3tWy9+v-^m1;i$^!jOJWGmqjJv;&DMJ?mvXsDl zT7{#2Hf?a(Of$@B>ed9AR==f+{(F1hcizs)Ux{?{I3oS>5lG8;SZsVQ%3aX=Oh%);bPnxFhFCkU3_as z7n|BONHD4n$y%Eul3pDORT1c>EvYtw#^O$OCjcYu-OQh{l9F3kRm^1jTcqi#In_$%BvrS{vMaFilgY zke+>Bhwne(oy0KZ!l#YZpLi&Fw%SstBgq+@jqbUp%dDQV&i-0k^7^wB>`Go$#3A&) zTc}k0`HIdPl4K`c-q6v0tQYj-cgvqo%1X!-)@P_l(YMHzi?*%9iY9KKynS)ZJpMxV zA*81H)fYUl@+U1>k27`s$>Bwn=i7z2w-_^KF7Q%w~i?@!-*S-%BKqCcIsqHD z-)7BHzeFr2x5u}fNhsdbo^5;mKP<8}y5=5+S}g>bjqm*$g0c1`GpHVbhE$)+gTV+cDNea?=>)b{#-T{bQAZ z*`(W)WqSyZMuDIAh>j6Z08#t)2R46l79DSV4@*88X-b|TK)!YBFm?$(zXdFO#T*{r zY60n!=b?{dMc^liE)^+!vL%cxZAVv>_U})Cw!-mkF&VET)<;dg(&g)kQW#Y|fAuWH zx=S*OMdZmar;uO);?=9%+Li+5AqU3Gh%R0m8`;Ebvut$gRYlwWTi!LU>nB*tHT2;m&-aUGf7j4QZzaPLQE?vqKS>!-@k4LrWWKT6mKh^$Ywb(`=&#&czHZ+bSZwfxm= zL5`K(M2=V!%Q}rgU>Vw0E2L4?XMbz6BGg%>KhE;2_!lm?x>ep4cZnc6yE^Ga89DEs z^B)Hcrx1=^c8nc@ZmYMoq3z8(eE3_%-Xo}-Pd+f_BdH*Rgwp($D3RzSnECn@v*O&* zpIf^o5%fBCKh{k~>0Yo=4zGOR_m}=6vpwQp|CNz*mMy{=Gj?7bPEy?pqX^AR-}A2z zF;ze|Bb6`#9iY%5fAO(n$}jsb0=XIG9~yoCx!p=M#z!>0MrKkGhWrifg2T8dp%V{q zYp5Z;_ev(#=$HOAN;^i-g~(%wJ#A0Od;CTQK4{)I#$#Le!JF>mp5m1v0dLrdmF`bx zq(Y2_mKVu``p$@TIlqX-ZNaO93t;w z6gL$2Fg0HHeUKg_G0cuxvu35Y|H63fVYXwWv!v@XRhd$f`gQDEC>x1=-e0`+=!&rG zu0o}Kc&Pdo@aB3dmcE~|$q28f$>frL$XERqkgl&Z=Hn}WoF7bcHl!H%h+AQ{7=5haSA)ou zfjlve`>@x1zCQvsTS5MdTf3bY7&HxE>8%2hE1#-xsR$rEg-rdf0Q}<3sVd?-45fls zqvk1aT;}tUTvEWeB*qq;vHA}x+--tpfu7J$kku0de`1`EW^K^ zyXl3{8s+HY2CeF~xv~uk_&1Z6(fLyA=4-5Fwmrl=W}yJi`aFXyn|8kTq0Xmtyq7J(yyZF|+u)y0$h^bAm-yqD|cwpCWQDt4veE6y8D4oHWxWqUtb%Q zaJTH%pKw>DtfyI)Kc(Ni_8(u(?K7BlEcIXbued%)+;Z1LJvSb$ zM9nN|mq-7lW9%7j(df{ahRA9*1OO++XZdq|qD-7^Waqp={Z0@v;LI6VyXPgT$UNWM zBXjH1!Kx%=z zo3Es-9??b2ju2Xz zH3}rz%S8`-TTkKrX|umyN2yXw0p;58G@p~lU*bYb^t2QLIDY1TYr2KpquV#-zfr|! z*uLuf5wAA5ohoT2jB_ur;y3gVWQxKw5V*W!4rKA|ZY8biomh&qcr|&P^uCL$7WkT0 z18=Skv2XR|`g%N(MbTEzHrM|YOdOaS`K?TUHB{LV=0q~3jP(^N?0#-< zbzm32?zcN&a1wvLla5BczeBol6)`AEzQ0_Q;SOBkcK2jn3^`okm+ev-R4R3HZ)+U?YU?r3GUW`h7OKa z(q=c*662drA3~XP?W23iX{e%mhPlS#A5E;ey}cIq&ot+q=4Lf}CrFt4-^uemvaM9J zC3l*SA8&AS{*n94KPVgu3YyuzeRpM{WQF^aBGzDLxg|1#1FN#9?ASVKsKoZxP*LytA{zEA28_gM&ge5J?p8w5#&Q`9iZSz>Przkx8wY(=G zoe=za2;o@&?E7`~jsTIIZEI5G=4{>c_qEWTTk1x^mV10Pcl;(FAvzYN3;BfWoPUgREMJ*YC=u8g|jWwH0g&>e%CB*t8zN zVzSe<-Y{e2*12 zLy&un_xdbY4|%~~dV*=;hFVbsw?YcxAGO-q4>vp4!`pj?%jlmNP2Brzko>ttWcnaR zuYo$!7P_FtwfnFnCv-8aavC%zrHB7}zG7kDFiu0pvT=W0_?gNNUH6Hol7~7obOm5e zQr@;VFSsoAv<#x~`6m$5T@=~QtT&kuy+Ap(?*Ia>pDn1jxllRRVv5}w{MV-||E1S| zS}4|<+e$82a>5t2+Q~`=gZd4^tf%f8CP6wujMA7B%Y;2iAObTh)^DAhk)YR6jT=GU zYS|Twio2RM1UU^ub7SLxM?=-_H7d~~)3hi5G-XI1D3*4HL$bHiOoVEt^ST5AAAEjhb@8|rFnmtCwRQtzOZN_*0qYaNN?M;bP{b}Dnm(X= zW#N2gNrs%}EY`(bgVpvVgDXu+fbspV3H4UI^Iu#O}4ODF5SSZdCHuc z!J)>k;1Sj03+sC{#vdR5;f4*V-4(p=^>=esf#F9wYutTCVC;w4tx6h@blme@g>dJR+s?!;gW``;2LFX^w>3Xy|9l0U9en9}8i zNmqq0dwm;^oE%IQcE7grY2w~sl?+uPKO`9kVEoZ@9UI_tgvVu?Avuir4dN<=UG{b0R~XJmy+g?P`p~zRa1KS1@hru| z)!I$pO36w>MNsRuCm33+n)h;1Ss^Scup`Y}{Cd$Ha)-^=Qim=aq!NC*x&3&hIa@XZ z?Qj)_H|C623#MN4yvx^|@;`o0)`A!dhPEi0&Hj2tnmzv(56^vixM>YOz(r0OoyWJSeGALq>dmOj|^skTOOlj{D zUD0^z`?gDG+a0V8c$*{s7ZD$vgH$UR-VUGN;G%ugq#7W7Fg|`0wBlyt92zHot4jVB zI-QQP=X&YKnOprejt8B3>`oqUfz(s=;8$988>QM1tpOImLos9j zGiko)5}gz6y!wPnMf9&r@eYA;;yTABjX9I#6BG1CdAMmBcep@erN5rOJ-|bfx^TmG z2&x`Cd-yM+{7RQjTr2nM_n^?8;b+P9bN8cFu@ki>zoH-1wdZJBWcw!j5ACFOydyUd zUl7@zsow6CQHu)p=Y4J)AYW8oV{~KXmzP5|7)!tH|?ptzDy_Kf}{ zr$=D}?h%f!KTb=13w;MO75J!?OM);-hduluZfp@dv9_z9?kD|qCRZynZ28)*u>VXl z*%jC1Gwaa8M)to>^v|pTSz5-;nE~E-U@BkxO$cf6-20d^>9s-*vPZ>P=xlfYRz>9W zt+j4qy~ER%tp!F0urLikw>(77nF(*zt4=ZPMIWA#i@|n1#V)kn&;{QfMb}EJyr~6G zfEF0g%Ps9ktpwgztv~AwoputX#KNJbW*=b0y@M4B8P+gG_2ht*@a&@_=ZWWM+AvyS zZ{qLRuAzdpJ$6RL^p=y%v~k^^FN>_~wpFD6M22Sz{o?Y)6h-j@l5*ppUnDUW4V4CK zpCHvRIz39`2;#Auhf+l(O?h`8exl{qe;IBJ&{|Xg>WzM$ z@R5ML|IR;0;>d~4Ec zRvi+g42XTD@H3&s(y5|y`nEI~EHQsL{O!2E?0<~6*&~iFz~wtO4rsWzcHUkut-f-| zpiOO3_SR56_Z`px5OT4+g9!Pl>bMf%Y8AXS4cGCws=)tQfmm?J5ppN{Sa?cpY>}7^ z9SXquz*5Pe+*$Ri0XwHGo2jLS-X zx5BtM$)s+Im4c0d=5bDf2M9Zpy~~PGfNtcwk?rPG%!6a5p2#1Na@CR1Skg#H7u zE{zZPEeQj1Gisaj8$*-2mT8< zc+>rxC*~Ym$6Y7c{G?eKBgf7E6bdnN(ccF#nJ9rHd_O>WY#m3tABu;}16$saTOEO5 z*?&C)*?8 z+DcI?|6Oc06#p~zX_6z@+e5*QmawHqf&f&#d@Ym7K2!zhgW6c}YDYG2AKx9s)IEz{ zqBxDuZW4n%yJl>Kl`@y*o+Uta<6+S#*Y-tcn?>+D&8+;G_`yJTx|+UR7tz=a!@Th9 ziH0nh$KiDCpw7?L_b8mxU=P6;&T2Ih&N`yLvWhNE(}}?q*49v?ChrT339aZX#Nj$D?f&XhZUN>Gm6r3w1wJII zS+B0NS0NcHsK~oB#5XZVOz|y_*Z)fFV{x2o8Gb56BjK8E>`gyfZ2kk}9g{S1#2%)k zTWzB7x&x#iGbeN-c-<~!H~QQg08;(aC40!(Pk1B5dw5pM{4xFsK>#Sd;j>ru-@9c= z!xMn+fRz@Ioz%bn?Vu{PHYz`l>E8PDl;MtDvKLsT<8>yD-_@QwFD0=De^YUUxsZcM zBsXGdxC*PPQR|2n$J%x22zlh}`CxnV8a9VhVf1_|TslluMWF32w{vWt&p`M%8UKgf zXl`0M487rNCS@JlKl_sZX4^@ULOcWM{tYYzrO_iA*aPDFE(J) zHXDG&1pKhmam*c&VppOLV9B)QsbV=F+}a!)Z5%<*|$(f%;5zrYx}DO zj4}8I`f%|yM>vSufirT#_S>ZEuvm@xU5$?R2NeD3HCpe5dS)QEXaZ92 z-@otX#>`1s#Xe6%mN;w>Tr#UWOIO(s5mVm%|L@2|fY#lPK^83lT_5<>N1pCj;#6~C zS?pMSN#-m-S)PEHN+W< zI^AA+GSv21cF&L|(fu1WEakn>aNWk%tHJ>?d6ZB@(ZrHkRYIedR_@z{vQ74#h}glR zXg&Wa|JPADxWDE%S6BP!T2UV}m9kUt@*++iU+^&)vZ(`xp@XpLT;9P2=D$XxU$6-llc{_-o`beZ*A4%#H^3^8KxXNp-C)RN6!D_W8O zc(5#QHqm#H`7s(kb&b9bxz!bx#oWqOLVI%hntg0fc~=yzl6y z1YGk_ce&{HRO+)o;A`48#y@`=CAsP1*MD%{=s`iBpeBkr=uo zba~t8I{jm6wQY;Rk)iT%{ev_gK2*EGmP%a8#r5-h>3s!F0Ce$Z5XE`K^N$}79}5Kk zcwB&{-IBMNvKzz<;wp2@5`9M3$>8&U(l~{B0l@k78pVDXR51swXd9fP=7C{exZ=L9 zh*@nNE?c$R_f_~J^LUhl;cmRSm`IuDFLBp&*;%&R@o$e3T6Cu=x$l8J^R?qK4{4*d z8`1@=6mZF$I@!mWuM|m_-s~x+Bt@8orJJm%v4gA`7xPMtj{ICUb0)duEI#RH)wwvr{#yLA;W-`4C4d{-_goITY z1}&`uR^`_OX-#iBKcY|5@kE=5yy=J19V8Z#q@S%;J%SYL)BUAaq{kjanHR0D2DnB- zSp|Y57vR3B059-)g4jxWFBK@7dVTvhcYBzg)u8B6OSjMl(8-WA@h-6;kqc3?cTfkP z5AYPa9jCMy_%JKjPQy@y#Y|MUaPMwBx9n%f5pmwbU1pbg+rkeES7I8p_85TcBnw|^ zHV_@8i$kAC;U0;ts?*zo-t_JsADB<90=`;Ioe;txFwMRXtxHt)B|8q^Kq~vd@1NeDhHaN<;0Fu_Z{4n#Gq4-j|^UkzQ>K>^X1Xw!jw4W75yuNkiZ{`2a zMi=U5m=X}K8VsFo@OZDwD=E3YzRfw@4Z|Mjh_gh;=!am+1=xK@Tb!f`)|kW4FpYI4 zWX95vj#M$0VSvV1Og8Dv(?Ds*S~ljtrCrWGfm;7wX&r5v{ zpJ}L&eX!pkeK_iAp8>5=0{uvne!Ov4oZ1L!IV~oX& zd1j0$-2(teitigRM$BhLBLhQ;}Yy-Bi%0=v|hN&{rMk*XnWUPbit6HV+U!8M=Sx?_UbU z)a3Vy)d0EpALjii(|(yB;$Mwk%077T@9(^biyoiym$<^n;ls{z+^1ks+^V08^GR`` zfeA9h@wbw|jTR@|aFKduZZ#RkVtE@O)^_Qy)vq)DIU(J8+jym6c5bfa%+$ts4mF2=DuAR~mi>fFevb0?YvWULNKAgo5@Ye$Mvc7$7gyZd z`LFFczZ&Wc%G@4R6$JrE^_RM&TJ=v4%H`CI_;>q+Lk|1vVa-0b0SolL57CqMXplW+ zp-9_<%JxuSFJaUv$3=etn#`gnzS*?kvdSLmUQ^nI8VtFgV0LN{9*#B7Eu6BjQVrrB zrL6}AaHUY<4O%b7Lu(0+!(eVku7Qw}k+pp31kiN_h8K11*3InK0IH})LZxe0kaAlk zPQz+T09{e*4gB*Q@Mr!BPv$81?YoGXt!Wuqcp%LRky$Vw2~4B4xS^SS|-xIo2wtD z6QIOaV$(69adu1Imu;6lbnV^Ow)*c-yOGmw70B@NaGgtz9wv;3=Iq(Ou+Xo)Ptx_t zE~4fimeLLo<+G2M)*LBwoOfuZ3>3~Pi$e(J%0V?AJwZVh?M@zoian+PL4rVQNSdZs z)*e3GNjimeR!B)(Py@)O{bCDl*QSKAn%xyhjCa|=fI{&WczwA`CrXa`;UV4b0>#%9 zz3<{*ECh4?bsn6RajkpGuOB@qXB$jro$`6WSeC4RgN34}#{D=EB8G-+O$+_%feuG?G&}J_w+>549!LwF zp`el98fh{*;CDe2_HeImyfj@#bfj#9&c98R_WXJGCtMTOZ($XPlUCeXvO+{cnbX>;6n0mty zBz5FW_)6Kv!`exYPXY>IV`PZB;n-S<71ocxEbgCw(hvkWvme-vpT^%sqFDovPf-O$ zmxR$c^Za(+NFX)_&7$fV;AMDua@Pdy2nT@|r=^bIVU3~4QxqR7ojif79v+zLyx-%V z2{bL0ID*gP#4v>xbd+}ruDp5ZC7oBAL7M(LYFlTr^3~zG-Y=`2)-7AFe1nHU@i9M4 zs-(;V*!P=u1fDdXrOgh_%_OCki1*AO&~$(s&~=f$J-JdDu->&Ye79su+jokpB|4>v z)*8GZWeG%p=dEhsiQG}f>q8%ZjYAUv*b$A(HyN#&zAvy`)X(@s+eY=bXN`rE+yUz=G{I&{bLlGIyN%CUeCgM`{}U$r=R{X#|rX*96a@_Z>61wiAVz@C{Bz3R7G@N#vqz)#~7)TW=fwHtL zEm2UOMl(fnz%lPbYukxmGBct?I*{#L#>D9D6NJ-iNADsssdhDiWLL zH+$ep8j{YgH^D}deX*+-c}GiuCDz^GDYkL)*a9{hSl9y*>ezD|l_!Pv{lZw6t2!LM zz{hVeC`KhKhzvJE4=ll+M(y5YoZ$>1pn_7NO`1_?b{C$F?M)3tg;0} zgx1BQjkACOkeY-R;Anl`fxCqP3HPlNC9J@-M=9~1^HrN_=X^`>^Kf08@R~lG9?3h)}N42H~tbaSUeo1H^)uv@-T5Q z^S`pwv_6kHJr|R{z0yi@Hg*H&PSm$sNAic#*zHQIa1?3mNU>1h4D+Nd0RSP{fB(2* zXJY>2e&)wMU|h<8V;Ocd`zhWhQmSX-Z7$HR_8TwnYkY^n^-~tUO_}@L>&?{xZ8ljJ z5`7@4Zy7yd*J?c+|M0_E>!Hg#>m3#$FZxYq3b%HS zlE5s&V+o!KC}Lw+s7G<5J|5*10+Oq6ar2ql-=M9wT(hTx+d)9UnQ;0vpe@VIH@S=g zT1WQnr7RtUt;Bswd)v@&??%XQG)S}whb+e4)iZU8PEDQ6ep)!<?Q2ro~kzGR8qtwebEjQO*cZw!`_q!;%f`vks zR@enNpC@)D&rh=Xj{b&tU0s!DKZ05#w;7?12;_8{=pe7%mVDHWY*ivO0RI+>ql8Ve zeNze#&t^S6)CN6z;?|=pN>N>=YS1>KnTl(&?>V^G4T(#gEc_1EDjWgv)ubaFfQP05 zrT)z}x+rD04X=T4MP|ttcd3DK2XfPy8BBC@u(f{LjzR(c`Tk_xY|F4=gO#~YN|F+? z=2zL7>|ekd$@i`E2KqKXO@Q*NKn@^2BQ|?1@l2U8c;#WdNZc}(=E`$@XRc@l`k0}W zD`7SSI)1v>l|A(7oof>&<#pB`E?;Bl+3K!56k+1?fjYk>d!_)D;pR8;zIly`iaPw8 z>=FLo#R+`Q%)iv?w*vO(spI`?lfceiEBxt&X9axzuaievSNcp36uiA7FR)+xygLQH z{Mb3iVvz@GG~4`j;=V!}Fxy zeeXj!fMhW**#ZOS4b6Ab4szW4pvXUE;d*`^Ip-N@Oi@wUjiX%*9}c6dep|S)Mi1T8 zf7*?6sF0ZiWp-#^Q|$dMfDCR)U3)U89B7o>Wz$lb{mEK>v*;!HlJsR$w|KovSfdl~ z31-T!B)Q4fT8t@c5ZVttK*PJ%Y<9@P8~sM@BKPQ~5J8+f;aXFIGEIEXtG@7vuu$xP zJd%s@Zophu+F@t!tB>n(aqffetr)}IAqAZOQX2e|j(9+AG7qWezW%VQwWr7HT90%m z)H1399Llw_Sww&1cfc=O85yJ+VL$UOcI2C&!g^O99hVW?l!?{3l!)Z$2H-OK8m06Qe~GC@a&v1OrU~I2dIt> ztt#5Y;(8F8G3~j89fF7`URXqibe%jK8D2zoZHW4cgl9|FAHc2%UHh zP6A_=!x8Ts2pek3#NX#oI{?nQMH-8rY3Cy)T>!6yzG-|9tc2KY9&!OjMaSF0LT7JMCq=32Z9x1Fy z;RoGP;KFs?+YK&zmmxNgj^)&VDH+(u?3VL61Dj__L9Orpc9T6-QqluWU-$Yo^NRc$ z&!n_6Fg9f5zD^_%+Zmw(Xy=26vS!7DbBj91{i06uv3^fKQ<~pDQ&A-O?H+J{^InOa zRrWqObO_RIK1*bFI9`)jAw2277h}|9d7|l~$G!8!C7mwY#|}IAvtfmGF)WLiBjP** zmEYbAN4G;<6L_MYy}(R^aL{t}w~M_CIwZ`9b^0F7KY`niP58ZnVMVip-rncGj95eB z@3V$T6Pqj+Ac=7CD9l~-)V;Zm!V~{jT@6{bJ?VJjN;xoQ3@%*Xecs^m6TQ(q<%mk8 zIGH^E$3k&I!SlG6`at~j&aon$k*s6$f%Fi@@U!)3tC6_AJ@i+7cZ*s2C#TMgE7>2- zSa#UsqiH*V-Fb}PQ{b4N8SSuGR;(AX{KY7)kw6{kP_Fu+QbZl2gtzA5%YG5Z{fM6w zG6p=3zFuQqWUi(G*Xr-Nkq~0XRIUOlX@^FVd80c%E|4F6c_wg*@gAgle#hG}d-Q_l zxS^zaew)zurcnaS``Cn9)dlh+JD{T-X2SL3)!6n#!y4+tFH(Mq_YDe}iMx|QJB!#s zch5OKcv&tA1C>BS2{2i}^Cb4nHMsEP_%*({JjQnZ*svmk-B~Dfe2{rG4LFq(r@GpP zipbp(7r&3v#OHjF?#QZX%SfOlSapXz;b&i==Wd%wmI8TurdcrtZzD57@{I~Q>4(0c zdTGyd5K34Xe4f=Nd)g>aFl;jzPzMa*w=-cE-O+4)wIG|gT_!(d!awb=cW;NWbdCW3| zN$Nd-tf0b*f|}QxqI)I{vSi)DJPmLuNzdvRIu!iqwh$i0hj1znH@PZsnVsdX?wfzK zx;BtF=+h+1*#mUYF1e>&w)cvHZ{y0S+p(N4czXc8MhF*1b7X!BD5!GC^X^h8Vy=(I z=Dv2`80)Qgqly1ZM;~I%L#gqcO>W_-$_E1;)y(@LGhN_N>+GdovlUX0)2VZF+s<^* zBM-LSQ>XxT=(4c19;f^>Cgi@aqEwH3?agY%$GZ&Bi5mG@E$WFhM8j*krsW(ZjmAeT zptau0vSv~lXoUT@_d64VCd{kwZ|@n+HJ%*LcSYWafh`eUl)GL=jsWzm`4p<%4Kz_UT&1N=9>cskuE*_T!={8Psr3n<6>W?Y$G7xM|+Qcp-3G82DTmvi=+oD4J zTgvoDTUi2Kb?5j1#cDwf#x7e%vsbZQl9;IjGag*IK!F^?uGTvR48~UHBHh!H60WuU z$att+ERcg&QCcWXFAg13da_4OV5h|?dt@l=s}jNypKhE!@>uctHP_=MOB3@`5e5yms*;Bf{z@ZS-VLR*?>y;8SL&yS=2B zw$*6G2W$LWqwY>oh)*d=GHDvK?^#<=pP|hxWkg3DnyM!|ldw${`BzFIyaGHS0 zE~9cjYBBq>?xZ|amY@o;lJ)D4I~mCT8f48KSbTO+?rL`b^S)3RqVi5L%g_jwvOA{- z!b87`C9oxQ68Qjj|DHH>3n}Q-meLVPX z3WpkqHtHs91i6Z?_eTXfalaryyJzW!^G z#W!+ZOB{kPp7z~N`=$Rm(RuuOje%;CIw9gW!+6R>+F1p+yRB36{!`o|d8Tb`H(-+|*5TYA-70)A{0gYf1Vwz(?F z7l%!_OkDrVN#gso3P(lVrsFkb(K);G&2%>EOUqLhtf9dPrqUWLW3qXK3TPe|X%z^A zR&dK&gfmd6t9KZT?xpd}5h)QDILRBNy-|=@i1bN8S$Q*BX*9aJ{GqM?+VLdE;#_hh zDx%!UqxlBpQ@IA=Tm2>e>{PCSz-@^&6j=}ODA23JEZcyOAt}pnw?ke|(Yg$=i{&Ez z_EzV|oi)e4gOQv~tBS$uH?3Sf;DJ0J_m-g#xk92Y`gJ^W^qAd2Spt2B_4D-xpUU(e z2jGmR;?~*!5R)&StGyx%WF|D_pQ7|^>oL#%K@(C+eEN4ZRjO2f=Qx$jc@-oSefi~O zs0QIvgS5rP-`3zoKQ!~chJqbCJV7qoc-B`-FRl4 zbHiA0=_mXxKda?S?FdvM9%IXjqsY3kBhxcDwI#pyotPku?=Sk#T%58Nw2SiUT?d&5 z(l7b~Y(rE~jyDmAknFhZzR-OYlJ1b&hj*}{;AmL!+V{`mi&gZ~^p0(*C2GMNGryTm z2^cDP{GZAf&mw3w=grCcQ(7$58p0gO{oWvv(6$z*BVei22F-gvPFq&$UCU#_h1cDi52VquyEXFK4!@^v^h$l)ok5i~=|Q zRRep-Ny`AXekMP0r?dW#?h?EJJuvHPeOVe12Ay#$Dc7Ke<^I=SssE|tEw0n*os#vy znd8mjZnNz)SZ@!*$pVc#wmUsJ%^+mBBoZ$B8CFt`ubdD?T}Ld^ml#UDFhL~MWbpSNxLRYG$u|7KA{hKUqY6qaAyd#C2=UR zD1WP`v*x<?*nVun%3j_j;3t^nUo;ug9tp- ze`V;gOgbj_UU;_q#L@&YTWlSU;JTKs)sZ(!B^N7?NI{R6JvNH7On;c{!V>%sC=M4e zGh~EE!~QCV;Xk@lU^n#rI764NGn%<_(X# zAh8+gl;rs`x{x&NEmGimmH4gi?!I)hD`|@_y-LjwZyoR*n&ka44MF;Bh4Tp3Pk=(p z1N{*8TVz44kZxkaPA9Q{g5Q>Voxi4g87?mT%2Qv?x4=r$PZ&+qYl1A*ubXj2MAM+IH%^FvL(!HcLz{5_IM32~P%Uq=L z3(&%%m^X=q9U#ztf+arjrtA5jP96$-iQxE%NlmM&d2Tf+};STPsY+hLF~&*)ma8ay{G7_0YjA&NvkdvI$F{v+h5DDRwQ6I!4* z@~pofO=$xnm0)lb$(V8{Euw3h0vCVjwrHH`M9m8}8*6)MF3jXR8v`)HIf2>sM0)2H zq~G4#>1imIPdK)BN{Av83AQL;U`P zqsPVW^yz#f2Ktn>K{Rx{_K+PTu2*K4iBLY0#2!=wxOt6T#loEXuQs*ch7SuP-AAP> zRSUsgLH5bNZ0;pRf94dV26X=*<-+5e$ zcT0ZX_@9$WK8^`Zz_cW&vP zv>RyuJr3xQW5mU&!2MdS$6%f;jzIE)${JMpWPhu zt?@our_!?{!}_U}OA_V{*;aRp(cka5drbR~O6+u#{BrQO2+w`gEK5UQJYr*G-#5P& z6hZd(w{m4KKiKc4w8wRXuIx1e5==`KH_F0VL2SsC?MJ_*bX$ zQS_dn(gHcqFF}e$&aN5F(FXMft3mQV>q02c_FM|83@@=i-XMF`vb+7E!zwGi523z} z!CmmaU51nX65+k*G51>To>pM?_NjxoKo8OR@X5P5Z|>S~p2LPL?Y99Lkw%d!S?gc< zxFhB{j?5x&+z(Vpelrt;&PX>fIwGH2S@$wg>dKL3p)VozUYC|!j-=61@1%C$3 z&p%C#n%1l3_8R%|>tXg9rxR5i&n#xj9SW{pe(-BnGkJsb*c*dPPQ-6ZUpD^SHQXf_nfikx|`Ul zjE!AL#EePB7*DTvaMJRs4pbiQr`5#xPe+GXKQvNGzX5OmuzBGa@%1Z20nS`jDhXK5 z5q0L64N1L0rti>cxM6TaV%XJCsf%P1K(ILJ?-~Wc!3F6yqOg31Ia_Xm_p%Upi2OB! zE&^nT-0DqpIV`Ay!$aNw@DF@m{3z3bo?tBU?Hgu1h+GU+V7&SdnAxjQwBM&Zjav+D zCi!IHRUY9WGcorr<^ENxN%NJt4<7gfCVGoq4u?}}P2V>GI=KNvps}#dJ#p6eaObb_ zzo-gMXbSOFNnUz~M5@{>T24P+g>SD{>{y73 zpHmeG#JCtKvzn2{sqrwHhj{ZLTyj~HsJW?$k61Ta8`ljI3mFb+0|7FLal`26_RJ3} zw?Ai4Wdn97YP4;5>1b?n;rk%qpv1r_CKuHuR50Ruy{h2F(zbTzy$XYFFK<3Ht>s$# z#f-1qe;24Y);nRzINvM$4H`2h2;R>R4D7i31eFPJBRk>_hxQ2TwE=Bs`=Q6 zy9TeM>gH3wZk1Bwkv^kn@}wZVe`+Xk)qk(ks?KX$h|%QcP~&6R3L34FZT|jAr)JWG zmIPC=0WX$ay4TBDABJq!iF4w;4!m+JP6AtX1qK@L!{9ATyU`m8WxZs&=uy<1+yd!F zI_TvQh&UK~9D8m(d%V`hO{5RULz|n4IYqovN`Lh&It;j2#yfqhc+K|R7@FrZH+A#B z>H;!`^u1bMbzh4oks2wdUHI0dlU=t7e@9=Lgs{s+Ii zRRBQ)f?&+9RR2a4;2a4cN|S_@&Zqt%u089IAo2Bq9gM{lB#5C^4_ew7u-AQ>X^2q= z?F1vlXLzE(K&smBL(lI;-q@3_0$yjW_>}7}e-b^7{!(jab8yw1xIJ^ec$p?WZDhes z*-1!tYT4ewl75=ix$7^lgzQGf!0+PM#da|$*)d4p6jY7jBz1LY%#Pcxi`tn=Z@!(Q!`jV*g1zvuvi2zVZjFXA=5aB+TJIN36jVZ=bm4+(<3?@{WASh zG~6f!y6ioOJ~tN1BRI^`Z14al@jIgRgP_9+MV|%3sDc+SN5F&vb}WbsVF=cJiVv;_ zzc>I>og6YtI~qt!P3y{<=G>&)ffH_7MCakB7!{SWd3J@>%dXb?h(CW~Ylm5S0ycou_Q2yru{c32P zN}F_|)m7nhlEa#thf^dbX48q#@}HA)6-fJ%Po>#0*J$IRg9EoNF(kzg9b>cWR;q^e2Tmo0km?<-8mA~i;D?|`a!RN zxf#6Jm5_eRhGKkUi}>Di57i7*vas#y+r>*=E_$?Vx%Iv$MVWUxOA*H{=CqFya%r6N z)0gKXQxJwCJ~Bl=AhWAhg*=QViNba?c|wlW3LU(zGFtpqO1yD1hjT>x-eqkTJfF4W z+g`J>tD{Bw(V=t%n*edriEK+lTxrf2y%myqUvzuAPx9Zu>@V`u=&BS%x3&%>$pxbq zZ&$T#vwst-35oPf=fv*NyVDzB4@?=}!m8Y$-rSb6mD;kyy)RJ3>AKLq?)^ZKZXv6U#c(@;nhgT|3r@m3c{7K-)Ol6vRdW?UUWvz`D*~#`q@hm{k>l*wU;P3vop{1M2<2NHe|f1>X{X}D`tAHx*~B-ft`VSFoZrS! z^y1}{YSS?w)tzU_u{dZJIL`iN@}KRqSiNBIOY{}|tpM|LwzBk0P&}OT_T#LZJwa98 z!`XAl-|(2)(?9%M!IG2q&{)p>6G2`D25tpI51_ve-flbT<$QVvhF=R}?yL_r6v74u zjEb|RV&OM6GIt5@%5#DDZ+;qARmHRoQqRqS)eEU;m&_#PW4m1=5Ad2LSF`s5diY4O&YW$FQ){jL*tvuE~knn z!ht@&UBc<>Iiu--o%Q{eK3@BM=j0~*!o(`<4KZ8c>74d$fr+o8J-%0eztn=Z?_bhQ zh)K^kvE8%I0Wtd4$KPQtiQ(yaV~CtbxD&8`4{q$Ln`&9Y(|igLIarD9n6M}uLi-Fx%swDS00nr5 z_ED_qp=RI|=cXbB2R(IWb$xlgd@;U22kH`bG#eRR`f|@2_Xdw(oWNS{pSv~+G0tQ^ zF521XrIr;>h8EYF?nypek2!uqqFC&F;4AmP3ws1>Ch-4SRA2!K;+OAi!6lVQt9Oo1 zZIScshIcj0sic&XQNjJ3eG-0P z`nR*0{ha0ryD=@cD4(^&{C@GFd+_&AD*by&yT+qyw2gjTMrbj^Qte$c_{q0SY=g3s zAklhHa_*;{SVI`pDSg?01$7hMYZn{7MrPf_CVgG39e6x7w?p{As44x`Zr+|mhijsA zjI#b5rrV33$%;Km;&7px?Q$hMZ5{sV-Hm){kpYg!HMKAnC0>BSQ(zZ?M!&Z;-i{2T zY0kZmVpDUyc{!yZ#>@!BSgRT_ku_nGxELyJ1gp*Y`y|2gKwW^W{@)ln`3K!jsQ^%i zJz6}rG|)T2hD=L2%D$KNo*l0>8Cs?i4PB53b)?akK7moa(taj z_^`1>~W2@zDT@fXs8-GXFA?8WCB@f;OHt`fO4}~%Pj?>#f#aF3;&a* zJ41Y+B=5Cx#12UtKs;y+vBqQ&I0T`Ys3eF8HteWv5u9<+i#F$?91Q5r&t*5`GzuSp zfu-=K@H=CA8M^Z|-pjh&=l&%vrw9a|b-aKe5>Lo5Vv|}~M>K5%*A9QS4V(`sYGpom zGu?!*s~V8sK*-9@iUc7kOYqR6g?GGbudsmD-1>uNI%}b~YaK&St1U{Rf3>j2f9l!gRWdI7)KGNT{bruE+u# zMttsHmeAwubjd%diPamjMnIh0o#-8A<)ig+=b4&?>wG)MTFr$oUflGfNvPUxScM{3 znE21gYQWzUx>SR+M`~2?}*AxL3MhpGxo-+~yN034ns$OiveVqb7ythwW8XI_0kCWU2_>7_y zi8!@HEdJO3c84U^c9Zz*h5KQ|6wb|a{+l~u{O7(p8()E#! zGRPX@_IMm}oI4KNX=I(i(8NA<9_y6~h8a~|c`Ue7 z@bFLN%f<(CPJ>lu`V4o|;r=DMJ*r&>hF?RkHB17(GW+kTzjogrPimVny6DDmgef!j z8ndSUhCEppK-Fp2d@bBYyTtc8RPpfc7Qmbw*SlH#{;;LF_Hgj*xE{7lgNMOKr%1g& zf6C`WdhMMMe6LjYK%ORk4WkLQsz=g1)u>K2x?@`R0Vj5HVC&(TQyN>#N#3?^GqR63 zFt?Io1df6~{bj&ob)m~Kof4{y4w3%MJ|r)P$54FQT*UYFf`x3AQ%-GSJEKPMe* z!HKee(G?T!97b8XfGNMq>N&xNM5Gl;3F*=D7jS4$xJL%w6{Gj`04wMB@xc8)^aa`x ze?V#C%5^_h6UlOSMs)_FX>(b5l3(V|dC%>foTuU14;cOwJhAWt(y8Ww*?YwQ{EOoa zY`>}v8J!{NljMsHvy;jP)EyuXXzb7qA2GlR7L4@{0 z&E&Sx7t^>#&f~s@r>Sy#W9P0gs zUcR={G-})z794;FD3D73+YF9RVElwgE`*DOzl(Z~M zehbMPGD!F&;yE2}Qilg_ModuHok&RkS%%G#$Tv}7!DD;(Ux@7OjPe|VtA~Gad+_Cl z9Y=HcZO6SQFZXg*FYNGFt#e>5Id$G$NNW}LAt$N*m>X2Du0feGY1@!))=K{4>|3{l zc&^~no<$duIK;t9RU-_W0fk>G3=7VF#%QD#5V!s1lBHq-#IZ#jCf#QPi3?{PqH z0sr&FbZ|Z%nkuz^{QaK=GjsSHP{Y1m2XsCkoz!1m{G#c%Y&pULMm3+t$bHxN-jYn^ zV(jdV%aM!ZD_1b{12aMr{9^)u5=QE}7Z&V7wfSPFVz#A6;&;*Z7YCo5xA87uESd;U z?2l{ZaMYJJA${ywe$y>luIB-aEHQ>n;zM_+{uRIUx87w+AQ@-A857(#~wd*ibrDSBGS6oB}} z$dnM5bX|J#K(V}^;k*q%Ee^j+ndX^Daqq3RyR6e)EAo#WaB>j`UyDkC+Bdtwkc zxmDBA8EpoKAMN@awbFW_|+pnEf8zc;9Wb{pt+ zpM10~cC|cL;y3u+x_?W(r`?{kyX*Q;QN4O~S%VUKY?AFJvrql?YkSv>WY13kW<9u< zI~;9v$Dm$fycB~38J#DAf+?_;%i|glNCO*@PAb6xfcFW_0K>p@NZOW1DqY z7KV`CJ7$LQarz4xubojHcEKwE0JPULwr&^AWLxyKp*@!VQh` z3;+HL9RaLHV|Y5e4X`r3Vh+bdoyaRo7J8ypPY}hZaWboJKRYiH5fUvB*&0dwN%tfl z<0>3}cgEjvtx1y<;^sE8DcaZ`_+m4gk>|+JYq&thAp=bJVq>10?H%(Hx)~sHn9oQJ zU3Zu8K4l`kcS+ZjVj{C_mWc|d%_TxEpW2-M>Va$cvp!bsrXHX7sgtwMx0KDvdwS1Y zKpCDvFaO90S&uB4j2GYJ4Iub0tjxY{u7#tWQL;4my>VlutZ8+X1oXqe1X>kIT{0Zy zWs7n`>aU(%W<{u}|J$2n2mYG0$5lSZ>=j&ic8O8+5*Pu$6!aSm&{{$!kuy1$0h#wCUVZ z7NcgS=WD<7;wk)D1K(q^pK^7~4}Q*CA?S_A`lxIaKrR22gY=Pnb?w!gUb_KMn)!XQ z;Men;ni8kENp3UWlz$XQQxp_;xtz|;s&Y2s#ztSyv;ja;FNoIXf-fXMoaqXPLJliCJ0AiywQbE*jXQ zTtMN<0lcehw`6z60P?2gH44vGB3ojPzjeL0(CndgvsAWD#HnKg_TJv=CEW8>1Nk!# zbT4ZFxeY(=MjY$<*aPXHq9;w($78-C{$v+qcm5%;*M6*rfOz(YALx>-u&n<+;}Na_ z2ghk3uV;QS)7nSg?YNFeziBk&6ZceBW6Z3=a$cSR02ZNJ+S+s2`+&x99XJHZb?-Qw z_Ko1asBo8I6onFSi<2?RIOim#Z%<=5~c&BZ&@PyEDZ1dQZL<6pK>r^&%5N3UhFVLKPcI9g1`i5mK_H&O5Xb0k|Wc_te zy6-vih_hnlXLtjySG$<=pB{a84849J--m>%d^+N99@H{Py?xf7ID~|1LmZA73}uiM z-KcTEM3{N8HeT$W4d$HtM-C_x5q~f#dkT9w5dpw*F?a+3sT_gYqZdEkgR1-rkikDt zxf@pP89LQE)g6L3pVNfAjH($EQd2m=pxn4A{W1~t-o*9!;1#3oU(j=bcQR0d+XPQK z46+%qUZ6+J8{8$>a#Z1>N&PGC**e(r-0MpByaXnW`+g$_fYEDn)CRY+Si&TFy?zR9 z2Hi=0jRn)TL}**H?*Qu2Qp`K`bWs;e8SsZwn6^zjWq(bg(RP0{cmO#%YPw0!gy)*a z8!$q~jOy`>8XHfMH$^j8+RQnpUgTNs=RkF(qkqbm7K{j;MlGDZk0(sOE}?< zKT%XfTUh!5<(L}pkE&4b)BTJjbF(m_j)|YYYp3Vw;)G6x=s*?XdWej^J*vQ>TPe2B zc$-J|zk03^f7hJz7cal^-iM;?j|fo{$2TfH!wh2VhK9H}!q4h?D^DtxVqCxIAz%Fc zpkwUpJ^V!fjw{bYi;wDKNo6tf6_uQKI+79}mX3>X*?RoC%`4;mt@OH#?R4-Rjytid z`kxdOr4t}WxE|`97CdqF)4#DrzlOd*^CXR@4be>2yh#dy&}-ZYBZL*J}st3~#2DwjU&q55Y(N4mlZK(AXXuzRHU5@0rNA zzrV(3o9GD!LE}hGRIm{^V(mfSKHO zh)duzLi#(jG~*+s*4y@V#+fqInr2M?2=&Kcvu4WUHZOuy;}op3G|$mv<<`Mw?~T}U zlBzv49utMFQ#jXV4b8VVmcvwF1$7`YF$iD3KoMCAH70n)F3tSC@Aq7uF>2l|`7tgi zbnErn;%Id1W@e?mT4ypM2XeUKM|n5-ysf$V3E#Q>R`3e{K9^%1yv_d(6LwZKT;?)5T~RXa3#%hTi&+Gn5F zISkwQC$s}jM|C62nm8|*RjY3)4v4cGVR>?)EYUE>4$$(iFcY<%;L?`(TRJlst??FF zZ&wt7C?i6S@T&+a5h=l^LvhF15&k9ecbcmB%%Y2Ih+D}G6=3~U$>T2wW!|)MVGS>O z(`Y>vV^Y%|l6CIe)R7wZ&ZjFUntn*U{w8>uHYr6>tKLiPfBhJq8xydH`ZsR3%FmAc z-aa!Zp>VDtM%oiWPxvMI^pZ~Nzh7s9sR)wY!vYTQ9??|$Hn<@jUryXIa(!v zcl=`VOo)Ok1E=GLv}t^&kk$~)HBwB=t(x}dkm}Ns+l&&d9^%)~)6?P4cLF(7*%6q+ zf3wIH{&6-TrvG(dO5xZq824dK`zSTpW1$Vp?RBH?(=%2HR+5=NZt}Tdsqjo}0J+Pm z153IjTBGz*4X3W)ehy0a9Dr|*GdLsRZ3s?h=oX8(lxK7uEm9@NsL-_W)fftLKU6tOB(MVkyZzv$bks%m$8*=b$`H~P6FbrZ zf41g!-~|-Wm#$TIv|;1yjR{n{6GYTs~-x&xyGg<6_*_C0!lzd?wAMl}LTt|h zOEfI46CcCST?FscTpgnlJ<0GJW!Ms~|6sAG?J>Xu`Rf&~lsnm;iojY{a(F&YGe<>Y z72iYHI}z=_2rbg?fY`A4wDJh@bMn0vn}<<`8L|<9iey+UI7mzV!5u*R2+i!Z|EJ?I zGeGBp_J*hvjb)BDdu;G`l@Hg-jtvvgbnnovc$j|gqb}E8Przl*q;%d1UXE9ssqe(#ZOI)WDrI*eof+$C0-ao9K2u$7gnRX zVXeN2KGuYd>z$6 zo+*mw^0DMtw5#P?fP}R5y@88jJyeso_UK0NSYdI)C2Y99d^czK>J{1W%1#ZVr9(=0`T zf(SZ!(1=)fl3tF$evef0M^<`T)T#CKO83WmtY(Yj=OHc-C~MrEc@fbvpzpo1+dQUg z+BNsc(Xa_-6>u;oht|wAAS zSBWhdtK>jea0=SiJFW~Jlfs7hpq$Ns^DuoRygWtXY8>c+M>?=L)I73#2X5c$Cr4?t z%u+u$H)%gX*g_?VWmu6#PqSCVH2)+G3bP;wf_cyg3l4l5(~K}YvyweDSBi&B&oMZ6 zw61E&7678hGne&f8>Y360vCr{)5-x)DYX!SDH%chd>B8cqw($$$IiHtPkAZG>Xaa8 zp)V7eirYk8{aACs{;8-umX91?G@gV-N8RV`W#y^C(Ycme1gNCF)F zP+wJd!{vh?EnqLV`?7)3>-A zT46BV|<`PwQviF7yBktdyfhq@vBrN!9lb)*(Hx&MhSM zo8xxZ#sH)YT*e)Y)j{04!=WFIA2`=@olT*%Om3hpm;Qry@s*JfrT7-6=T-{xcTp>> zzx~MX;SHN9AlU0Q zK9)!vf_%8PyY^)718RAVp9)-<- z&|NCG^7~3YQ(;Gi!k_VPMFbvM@$57cjk?bELrO>4{m^y&)??sa_WH>fQmmletL*bC zKc?{lvS)c^ZX?DMT&303l8QsTfqS)huwYrDI>ZC1@2SFwEP~-AOYf8SRofG!_r%=p z5DN8ht)^k$c+$O8+70uj2X0J#=?SKH!l92I3oqARvIXxPACJf8s;6}2;MYk}w`>PR1Um(ALm=--sr30~DNE+noMn33`jg zTboRCdS8w4#8;GZZB{WBbbqXJJP!EHAGF&Ta@eNhBsVocPIl-PWa-#IM^mm#iI^_f zuXw%~up+P6rM{%7>^XBo++*q^?=WU4`1TMN2;ca1}=>VI)4al!we(9Ke0 zmqaXZi!fqrhy1v73UV~!9XjIrz+CW(!e!>|h~iVF$eS#9VRAl&dNh#j_#a)q2DEVd z?bF_Fokt6hPk}zmtX#LKtwCpq80f=)QqU~KSz|+UGVe)fsd;0xuHAOxghF|O)OIiR zqXOzK1jZU%9QRDG`URPF0usfEIaT2T0YWNwRM6!ChPTR_K-jNnzhBkc8~@;`Kch1f89#$O<#kOVfeM(>8-$-iZUSDI7&R} zL;#_c*@R$AvK!SO!pzAqUBvkCk)WyF>kGBGqz8x({=Z`B!jE;K}*@W6? zpLs5VL|(-io|kEz2<=_V>mzwmYjDp$%)6o+$My$UbycM0vzU?+D|pEGfC1xk1|T_< zxl13(Bg2py)Y1j_8&lWPfQZQtO!Lk?8{jZ^+C?YtAq5#AlyO>wkzJ0jlf`yp>+D@U z#w6C_X54FwIT|VgVZZ@&&8aJlJ*?@hR(E4>H=zEMcx#?rYD%i&$~-1z!IAUsnxo>A z>bpOvsi|kv^9D=r7PK3#6VWH2td0}M$4K3^d23(U+k?A)67|>52QFZ4#p-WY#bN_= z)y5u~n*W5U#-3+eH;kj;ciqIH6p$+0t3|Wk(F3e`I*)FsKU!^I2TZGMw21_2>~Ddjy+;sTL|%0-I|v0 zGCRv#wZ%hV9=U}-4L`D!S)7xC6Iiv)@tG=TYWZqC+aFYlK&y4YZp>7CRV)uX6rMeK zjU~uRA*iW5N=9pXSDu|f2#fr?vliJOXW@3uz?)0fMIsxHeYUG(!Nmo#T6BHR4sM$x zBW{8VK<`x*IoQFI48zpjZQ&^k2_H}Dgpvl;5$AtOT(o9Yz6M!ZVGs?9c;jejot5+Gb_==kzheSYEYpJ3< zh|XIEta<*?=SKK{2KcuhgKq>1eMGx{4E3RDFK{$15F);}lZAK*%4GRObOg|RHx=}w zFJ}A~e5C1cK}UbR_jRFC-?-1dIm~7aU1oYhMVhI#6A3M6x|bsT+((_D!wARvK)BQR z&O&iz_;4*)CG}aV&eIdPh2bToe%Kl3f+BcFca!z8w zGhc2Qr=dM$U3hX8zEy>0jt;dt%fH_uOls{!}Kn82e9a z_pW@OM3kW#a53X)7S{)B`U*rU5e`XZoO@deqX;P*!aZiEk3EP27>surD*DqDuN7$= zOQ*sd%nW{VJb{Ztex8Pcle_m-;jkWxeO$Wvmxoyw9$aGe;#RUf@V_8hR7leT1VwN1 zSeQXWaGmh;UFBowRnMVRWKpPF3Mjp9Kr)vrUEJoyMb=InoqxU+yi|?*or>#{Pz<*A z#G|0gwGrYz`aR<-`-DO#yLy%0an2`P#syW*Sv4$*11kI;w{vECIqF)XkOLn(HgL4I z0;{Lu8mdzI3`Sh^d5#`vk%TJBT4}Hc$2r*_pH6rZr2c+)nWeS!d?B3AbFHOl{)H5k zVF8FB%A^YHt7Kl6vzqM*)`Tmkf`pl+rFkC$U}3Jcv}3Vd$Doe32KVJgn{rFQ za@b#pCmQeAt%Nai%cX@|;8fg@Nr|WafhTySWsh%5nk|{0Hr^H@Tr5eJi0d_09EJ-| z&*Hele`aab@$X>qQ>kO(VlG9uS$^!AZjMjr!#Q$W>bRXJ_|oc`zv>Db4sO54?pF|> zKqM)MRMXn>uc#N$bIe)oe}$R4 zb=#A_!cXu%-R9u?uDc8bCz|;>rI6bkZVM%oB2U-$8ni-2qm=Q(h>GLSAu{q{yZO*w zyH)M?%(X28$SSWhBtoilwkdBBoi1K#_{con^x@?T8e975k22(S z9odB|voKYB`rL+gUsvLxi=8?KR-uPYoSd?(742jdm&b`%h*MCH9TbY; z<{@8Z4GwK}I9t%dr{`QQ3$eTMlJf^^uvJY$OC4jzT#!g6Gb*MkolS5R`tM%uiAcY5 ziuV02Ed^`&*8-e|NCrWNpOe6T*jw?(OYrfeQi9#GHBrbOyDG8Zm>izDj*(f)l%<@8 zrlX4jUQe`qY~ELWvpT16$A(yr_XZQ|BC*yG;<()#{4MZcc2~=JuIg48bI{=0gfo2v z?$WKj*cPVOIl3l_He$Vv?V%QUuI{ef$Ycfsx@|_ACI9^wh2e z!M!U2vr_p;E2>4R+)ArmmCcBZQjJd}U*>ykguuF|i8t-x%d$r+oV%JD`8h>=H@Pjn zE?pj8xQ$PtZnlRzDevs$K;rPF_%3{?f1~0EZas;_FZ*;J4YfUbepq?$ z#H^^>T8JP0>N(4K`2~)W7Ec7k`%m|s z1AD(@C5D~yE&&(u8?MQ(ar}n+PL|cQ2L+$C7l#m$=WW{lOr*s)J61#c4JJmc!%_GsnE89g-F)X3b7OL6CDq(K z)!!%5?<0l+!@oUTI<{!jpcd3^>$MU8fo=k5;AG#Mw@tL#S3H)0HncKGnAp1eD3?vJ zPzFTjoz&H1e1A; zv^^0)$-}8CpRL2b`Xvt7OZlw}4;*S=8#uLB_qenQ9v8r0Rcb`OcHyQV8b@*I=8uG? z=d9UL<=CQt9Adf-)CsEQeElc&>baE@P=u#~CL#?k_0b=(t7A;M6R&`0-&=d*H-2yS zn)vvyB$JF+NY#5^R1ELzZ2)7)WgvDC?FsF_kUk#IgX6e-q|jr1VJDkBR+o!wE1M9m z=UwtbS@X~**Eizr(;nnk#X+xQ`~q1q&hHM(zuxt&LClqcko<@OO=N*4USxiB|w zlnGS$?<7%U`B7n=xysvmYc@>O?F~9eLmK|F#s-YH^Uy>5{6f^96E_rqE*8YVqhIO|;nzLE$yH6T z{*KW$2zst%l5Y!hbXsKZ3a!K?*&HcaYu5DiGSoabSz@SX;j+6vPt)g$ii$c*8Mzxb z5_=+39{v;0{}#Ai)9#PVu}djcB4#^atJg+j!^LcF)?SxCa+P~1vIWQeWFqFOj4Aig^KCDo7xm|N(1r`+J|yr3mGAa!1g{XPpkK@M~L69%R~ zAW1%O^M2-uLzsXTbf7g23x*_QoyDXeDvAPm_ErihgIbJ{!9NYiVHW-DJYV_TI6wIm z?0;vH8hU{&{7Xbnm>6W0()s(rJ9bu=a7m!tG_S+&th?_KS7e_kzSzwFrzCwSSne5i zfQD1}Q!P&KKQ7I)nqckQHX9gHZmBvJHu5Aam3EOFt{gE#K^g1^V*DC24cC#cJ&9s828}1G)S6B?mZxw!%fXv;I-cqv{NuIM9tmC3;7V z|I;14O~a=JY0!3nveVmq;( z=civQHjb42_b-hqB*bq|N_F6K!RPAmJdFK?Se(}Ai zMO1w8RV#z+fhwC^V5WrusM<=1Ty^jc1`NGwceb0rx8Dmve!x}n)(YkCx}Sl-?{J)E z^tlw_S0@eT<;!S%J)o1EOqkwdbv0K7SJ&Grxyc@QT}#GI|Ack8iDAu8HTCL!6wd`-io|`C;v@QEz4Pqe3!A_q)_>0o7?~|9T2NiE zBfCmeRP5{kXh&=>>M&q%IHB0!dX7?bEawU@#?>ike%fZQrT$SbHDd!Yx-UI9ms(23 zxxPVAY<2`4_h4;w|6g{&K$rVpwOhjTGp3cUb}j~ZmNyB3gCU!D{7r~e@&N?XdHLUI z5c|v}-LXGi!%B(mslwCQBU@iO5M;C$mZZ-A9<8)R8R|9Q znvnFTcN`@?y@Vf3_xC?vk>yMR-dyb*11|NnO=f)i7tk@>tT!dW7TWhchpuA_VS?^d zo;}EW^dIyMd~}-@cJWlo^xR@l)b7cn>eIlTh%$=HAdN%H-~crTh{vcvM4!}rZ{F9+ zud4&siH~VcODg=`j$?|>H)(Dvj8ND^b_?S+?}TCdk1A8rdYrKfcgZDrEv;@titn4J zc%kXgZh%W-t{1xvPt5#i&ytM-2i?TJ z5;(nAR8AM0;#8`{=}qG|5H64IL9IdxtfVFd=_L*9dd_(thrX)CB|*k*>m*hfN@g?v zW!9~~;eU0B@1mt7{f`idTPKd=5M81&tQmKyUyi~d?e}JpV-Q_%y!~>K1X5(J7ZjiO zCYd*m%I~)MOMB&#Na5jfY&!r1;JT@Ff0kd*j`tL9Pxddf*6zI zb}F_XZG^Dko52HR>^d)?|K5ShTaZKTQ{0 z*Jij6x{qI($Z`QsZDp8k(`nz!+bh=nZwLhFz5g-woYa!#K{)lJQ6JseO_2%T<$lOR)9}NA0H(pZ5k6 zO~1)qC8zZN=}ETx*AnNnU;ak@I2N)F!juFdj=tzw<(y}vO2e%5|hH*4QYhFN5? zGQ)w0Z+rjE*=xKP*?UnRatmJZ80tZ8^bAWT6-W42Ht46FIla^Wjs_ z*(?u}mn2JVXhwUl{rY6LMI=Hizp$*k?+Fo+e4V!+er7^S_L{~Vp3Dl81; zZLix7BXu%WV$O(!t!9FVK)Bj;*!mOBO|VGufAM?o`rAT-&$SyhKigLGi|s9!(1M6- z)yh)1k~#OOtvulbc%H_aXHeVCI-X5E=Jy&%;kCq|RLh@rHY4y#+5p-4rL>=nJucI( zIPgA!=kMn(fX$VGn=bbq`}X7wK7#~&&*Wd&ieE6~Nd9Z`0nSQ+=B}KxLJE`_#V=8s zI4)1yE8bSg0(<6x5_2gwZZ0v^=>zys(wxtn@wM?<;@@*d@|a z9RhpayzpqgyZr?TBV4*5!1XAn@$DHi_DYDK&&Sov*F2prZqb4$g~eJw8E}WoY7fqR zZ$4$*LKwhmUjp|^OmA_Nws*4}Abi*)S*QH=V^C6E`qK{xM%#kNz*}++4>|?GY-@KI zYkQNCeN3NNiNIQV4-C_iq~Zw8I^y_pPhVd5OO5T@RRF_5f=uZh%XSVhC2RioA#duS z!5*Fsve<>l!+U!0c6*eQh^&GbgW9mlIW2(>{&2h|K9{t?8eamgRtSt2d1kW9vr+r( zFq}cT)Bhdrb^4b{{-`|(ed~F2m2lpbi^pH``ehKy*5hb4%&6>#Ss^P8*ZYyW_9tMx zz1bB0RkU8(<<81K!otakfQ-82`+8I_T`IyY_P-&eKZ~E2i-6YuGT(I{9O7io?C+|| ziU@=pr^)^u<5?bJb)U*gooJG}fI3CyFZxmz*ohSKC)zMVwCv%N^?aP2YrxB@M8dOE z%o49=p;rODSI$_1l9%#BLhy!e?R?j7Mr64-NPxOY+3lO4zp(5+M&wYz=&)P!N*@bO z{W@n;Ge6Fx>=A^kqPK%?SAoFspg%N?RCqvZip7&3AA6GC^XndiZhheX_9A|H(BM5a z`~}U9ajG*Dztz&(Z4F-Z4NNvN>)~u^x!xCfab8KZs{b=G7TITSq3SaYSNjI&Z-0DX zzWiA&76MU$HQ@x*YWV!S$n-b@Xfws)_upJfR;qM--fYJa4&1Y%$8Fwxo)NI-onTnD zNx%1LvwxG}g$Kb}mOBumDZ40A*qJ@NqMbf*Xk1XCJkx#f9%ItzV@(LGBD!Mz;>epj zN(`xnYhq@Tr~GAIeJ=6ptjOnT-hElS_(44t5e0bzc3f|>#lbsIwst#3A}S<4_ptxM zj5A291_J8Wo<^fSDL1}R#OkWv8vCI{Y0Odv2Y;M1QqxIDV0K-ER! z>fQ-PiDG~zA%vrur#>dlt5S@#e=5myA~gC=f8VP&VTD+%Rb{C_1GRZqQu*X4>t;aC z`bCYeIv}=g6Jgl#F@3u9aVVb=vOljbC+AAU&v4y^jQSncPV^em4`R9FJ3$?ZUSJf-edRV|x%Ii-4@F7*dOxzQq_J-^cX~B!E26ts2uV z25wk*_&Pey4!z=U(JmF5n*E6BEk=^s(1uw3jEpO7SZ0KsrcS-v(b%^9L!i~<&V|FT zvSPyF0*K<-NNYT@A^HNoIh-ajm5J(j7#}bO#csAq1k*xI>%yl!ee;q{zC6NFlN^?lp@-w(OC;H{E5=Pq;)f@3mKmY#~xsa_yaYxfj>I z)}{L0@8kCm-1oY#=Qz*jIVW~A&6b*U*)yJoNTvQK!~+yF`mIi{W{!FcX~^$kfJ7?R zkRo;x7|h`fb-@7;?tr3_k)uq`!jUf?AF{XrXY>bIIee(h!hGQmYLQBh-S*W$N!q!YV=*wOm z5sL5ie4R9A7z>o`*5t(Gr0?-R1@1$$ylrvOt#&2@gByh-w-YUvH%nCuf%VMuB69c0 z3$M7^xJXdM*E)(&chMp>0MczTb#_L8iVyM7v&c=P3#}sidTG9$*6tWw^H^kn08XO? zrs22|;!mE|<4oaqikDP}gsO;yR`B;J!0W3KkoK6PRNUzJTEoFgEtQyLQ=o&mK%A`) zrBvUkSXLW*6AYF${^OV%U5PwF$O}qMjaZjGvXLOKzJ0WS)cd;YA@R~8fvyH&bCU8D zr9JHR*%`%^aC3`u>yR~5$=OEFmXY zw=;HS=k`Fj9z9|6ujiPcE#vs)Q(%729|~hHgXz!IxdgI7g{PT=fx>HO>l5=Bd8GGS z>7sQuJgBOeYov(Fd^?v5EdeE6;T7rTv4`)spBjpHIk25@L3ykjT+_OErpg%mw9v)Z zW+-uI`GYNbet-~h09_{ic+39CDzHCF2Db^ zz%Y<}d*@_jx*q8G*z!Vx>n-sMcMp1Kr{LdGw?ld4`1Zex?x*5XlbD`(<@c*o^y6Hv zQGweNac()8Jop{>ll9)S*$<4XcB4WaS<{oWq}pwJygCjFPsCl*>DO=kByX#R2hE&! z(ExKHA*tU9_T=1vuY024dn7lu)-9G}ydsb8>Q$X`E{8`Yg!);gf}l zp=e^_>0?rAOjUQR)6eY#xtkWMm`c9SKKUp+Y(%7^q2$aFNzhjB*7NBoub1+st3{U>w9UMn-*XnJV# z&G!qE93DBJ*&??MSnI{08e_UCWeMWQTkzor=A`%rs#KS*QI?zZ(jN=o%J35Tf5jbe zNI^>hLf(|)d@cd4jaO>Of?UPCMRx*LNBtt+$bmUzS7Zm%8%>_L=Oa-bi@yxiYAf4I zO4{FKg6NcK*FRc5^w0?p$L+u;f(+fu*@`$`=u2q)ySiSg?0(%eE0Xso`mba8FBepi z%gkvPUIM8jAV+@oNESjGTKH8OXKSD;Cn8S~xX#Dczf*!2A03GArT*5avwETZt1c%J zD9m(6Ns!@AISa$HcZ#xjHuTa_eYF&zik@QT(z(rI9%YN+6oA&Km$xbH4y@G!mhH_C zN8WYzJ#^qXt=0%=c@a$N6;^OhS>1&j2YPLeS(NHsLnLR#tIUs-RW$}Rik%%aD3cW` zI_;rIe>H39(F^jim3LcR!(xO|u)pl*fIx|v(4DvwSLV|W&F6sAOm(&$S=cmH+P|+v} zO76bB4o#`+eI3&s^~3Pm_L>HISMH9yU~cpJV`%hF#P%lnn9srlWg%rKgeY^jbp*r? z=Q)tH4zEC-_}9Y*!5+R{4Ryo){Vx;d!+szZWnpUqMRcaTI-IjeU?Ypz8l1!3zg}S} z`J2#+l(B}_^nZ5)<^;B(`Y$->9vl9+S6%%Shtz2mp*VIQ&K4bC4(Q&s24ClcQMk>S zQATnpamT-RK_60NOw*a~^ZWnWnjY4y(**qXoVe1}{j;$h(5dNEMGFlbmh@m>q9JKL zCyDMVwb|K)%Wk`Rzj~!8rWt-?4R3T8YnGn68d7=UvGbUmNU!1v)958re*sN*(xs|4 ze|1zja0{iT+`N09-zk`vVQFpC*wBM(PO>Xj&N;z8Prdg`dG8Od4q-dp*p97@y zjA|?MG*q|BJv)?$T+${Sagr;;r6?|}a`hh)< ziB;tz#6B#sxkgNeMOi9Aj<7)si*ju>zuWAe3Ku47`wH~XSTy}f?t&odH^V^_ zi`?rQ0m8r9Hw8Kh2ZCT$4UPf^u%{zsnzX;88+If+`@U%ot|Y^IE#9ER*bI&8&1;I* zf5BMvb2YkN>R~Jc`>4cxn8;QcAA*9Q?IEe0B6PmosN` zg_BnZ)wavx;$2rgI0oPHTV#7sY1Pt~D6 zM&SnRDYyoT&!=*ZC--Zou$xaP>g!HA-3icf@gU3_i(Ea({;|^Z-%W;+F5IDKP4mm9O zMjCF~asm2*Zh5Rs#q;=1$H8bPUi~L%&tz$&wtZs6CCJ0__7e&@wDt{5mMz&q{8PPhS@`J+51-zA*1cQydcb z;V97}fI5^Cx9b8V~g%IcW$Zr4r><0B>~;F9sZ|15?yrS`+F3ybnd4zl%;gk_9)chKzDZN%|?Z;Au41yFqcGD7=$L)V}~C&R5fb%Y3V zPwKWyhh+jaSiysDK)~g`MrvRDxxh+MfHw=r_M%dF90+EQ-69Z)j)z)Htk{@h1>=tX zuj{Q5&lrY&4!%BV!L+VBYB3!a?}!~4_Fk9(w}-aL-|#d)K%clcN6Jzy+ScEC@Xr~0 zxA_NoycLmKr)@R)*fvaC>EoNc;9jB9C@-x8Is^Ud?6VH5-7jctvg6cbYWaR^q5GQ) zC$dBH=hfvEnb$VH0CC9K9gf7QqqT|9+A2!J|8a+9 zn1XOWrlLV?1P7_@2$rJm>6zxTz1w;@iFw2cw4O)&0u^j>42=<40<@_x%Fbqa)NhEN zhT>g}B)nPX>j^||GZC(PJ31)_> z&FMQ@w4~nB7NZ+cy?JBum8c3uo zfeCLEB1{eq9oOR_Vjlx@&UJNy3aANzIPExF3B?Cw|M1$J<<0(^h5*HvIDUc|6Rs)b zbM8D^T$D`E;CHiXmZ&Y*I^?=cM)3=Bl*b;&p94e+?gLAE9^aa5(5rOx1d3` zhsi;0jrBCW3$hR2^->RF8=EF;cMh-%;y#Fs%*JA}-#{bbw7AWl zX|Uh#Zz^$>K6%nMxNTE%k6#vFCO_&mwvCWAi^2%6rLjttr{v{dRy6puCJf3%>JGhlxRpjUoZqQ&LL}AogH{(O6FZJF3jy>jXrS&jv zt`V=@^h}l6pDntb*{}~J!YlP|LbW<3J0^>FUoZEz@KVS+rklfWXK70K{l$hCYVYpB zqm3Vpy1+GveB^%0!adrRg1O&Cb)lHsDp(kF&`dr`?aTI&%pT5wfH<}ud}RtgoBbV~ zV>t{_(D%yjS?OrA%a>Fan+$2N)Msbc6W`&Tt_6Nj%l=ba9VbWi>0g%%^C3)uy>!2s zk*|i;Pes{$@qgG z?Ci|Fe*A7@XUrxS+2{ez+_IbQ^#NBy?m)^y_fPeH#h6x^MWFH&LzqVin78c2{8oOw z6A8qKx66X{iLWhBycJgWb5h@u;C9ZPU+8tFApSVWFP3}x1%-_=3Y>BNnb_rZKI|zkrCfc&hS!7=gvc^zOFvW{-!N2Kqz*NCO^zd-d?nv^p2A zfXRS=vto&PT=*};bCYt|!n?j#|0U@w*wTH?ON;WcLq!7jS)T!ezvs(8I`QNfGR+Ry zmXTKey7@)+aVI{Ca5r*bi2+s@7t15+(?!Km(ZXjkxKpNzS-q-RQCVh5y3X6i|3G-$ zsF5K`Z!*i0IA>@}Rfv_+*3tk4P#mU7rsLZsy3O%lK!4Ml!QnUF&P4Ug5Z3af^Tqmm zw)R+3J-kBsg63k&Dh3jVk~uBi>jWq>&AH#SSemV6e(ZQ__lp_yu1n%H1=P+_8&i2= z{Ks#w*iXzh;Bli0$TJ3Hffu9D=uy|^A2g&?%ftm%4`E%9)6ZJ=Y-gIGlR@IydQ2|~hSMhg@ z_yI7Deo}Hu4R_=tl^Qk+`h&jytl(;T?+$SVLecTJl1a<0?>?witHle8LU-y|JEo8&J zs1hC9-3ybcSs5Hz#~!Fj+nEfxE8KqnUumAHd&zxJB)N;CSaW2$)9x{;)ZnA&E|Uf! z4*lFc{ffb^*YDBJTP;1mz4T8WZ_|8DOz-bz*zmuL;hIi7vBKpSF(Ow|Iqs3-4>anp z3#x6iv`3E!Ta@D1zJl!SD|_8}cf7u@q*!zXsY4vlVIr6gY6@$#q}QZ_*RgP`KYizq zSn5Dmk@1SOWKWyV(MQqB^|2%p4fY*aIkB*gk((KjrlF{+XTD^Fz@HdC>+5vyP6JH=E*)FW#w*9XXSg z7Ss$mDj~~Tsrnyh-bm5uMWBt!UgrLZy9QwZON-4OJvf;couvUA1snymtVxvxHVt`q z)d@^Bmef7BN=<@sxAg&p=s%w*eO`>~K;@%?rouO+zTOB5@V+pR8g)^Z153{w+j)D7 zYpy_NPL_YvXodwpooZ_OKn1#TUv2`dx>4q_Q#x>_bw+=?xlU*=;AshSJmgMc8vw0| zXQrmBEa93<$QUbYDPZo8lIxdhpaEG#@C#v+_gbs_1sn@eQZdEeW$v%AxsLnyFNyw( z>TzecyjbDh;V65=U+>B5yJz+NE%sS6YtiTORUL;ZGc-JKe;_$p730a)+^?Fn9@~XF zUNSYONxH=&{>$uN+5B|=W9Yw2h$m1t6O^69^&K>ZRa}9EMgxrETGUZZ_dY-UE!I0c zuMvXPul-bAopg6vXrG>Jme!XK9HBW1U~SS2lCi@^`K_0_3Jr$b&#b3AB!hHdo&;Q$ z{{E(w#dJx3k?il5+%hF3cN^n8lgXF&rB_h1C-+H2Y4Nka@Nx9~zfhmacNB$K={n8w z;M-+{PrIce_9c9^pOeB){?)pp zw}{uf#2Lv#L{s86(|~{DJAhY7BOgQH(o1i#s}p7QWx^w|K=qK|9fC6xZwi2My)+!i zG(yqtLj!8!`g=;_Y$%gO^?I{=ir#m)z&bon(Ui>4T$e9XbsFYRJ@*LtQep91zIkjV zWrbc-SGVt1ANb9+vs|(NxWgWuF8uYr3#`%8Ul8d*yPzu!er$FNH%z!BZ%)#@FJC#h z`7BZQr8Ar1i8vJy_r;w&jZLauJ3F?% zD*h;CuI_73L0!Tv*AHuPrCez)OC-O}m~ zQRjJARq>61BU7TX?>78FGudznL64{DKJ7Z|BHswhAP4X6ozMR9Dym73g@ui>disp# z0Yz#L6`x>UpV4O_QHKzpC0qbznik3z11d#{5KglH-fvU0FM(4NA_z$F7P_BNCg0IP zLfFvFH3TD#k3l(^2q|&alAS;RZjY{)(nxlAY zS`gc)3*+E%WxgfuuiYp65VK__1n>ni6C%dC?eif8@KeEyZ#TJTOx=e8ysuPx0S`4$ z1NlL@8F8aoJ*6(IR@fb-tNXZnQ2k+}f=)@oQKLE~@|4d}d@z$+M`1OGX)IO+V&z66 zaAFpwZ@=*Z9YvJ4xqS@!`Qh2*gN*>}(- zVsh2e_@-%e&c`VuVbP$!+F;LoW`yhK3`NFa7Y~W0r=MQa!eBzA$K!0oHv8>rkMsXj zPzg$ErQ7g$$kt5XL?34j;L77s%{v%d?~s?Z-YT|L-}WV71XaCQ)C0llT*#>)GWU_7 zSLN52le;gk7W8?-%iGGv0#fVwfKxSR(8cS#^BZMUwqq4o?ujEnWs0cW4@a_~5vMmK zzRy1LajHg`lEvRn&|fPUZtdVa{Ly1@$DgC4gpp7(XUlCb=e&RE1cw&%`|4k}bIG1w zpMthnqE6)>~;KrkvqasUT>0Akf+ec_&n#nT}qPrQft8$jDaT;3wNBzU$8FgGymLB z*1lKg6$+ZxGQxmKN1$zgqme#MQi6cjh-72~Rnzj_KmA&-mf#`ZAH=ow9$nee6c%_=sL!>E#qgM=G;U7aq-SOdy4a-Q;4NVT zsfS!&bC?}Ty4Tf1v-%+c@+=5--i4PTd^}d+RYYIAUz@%(?7*-_6QOi57Iz)w+i-EL>LBEWBun*ptUkf}<{}21? z^tA05{66H7=tGSfIsWepZ?H*p>9#v#Z*?xH^Ck?+zDSLf8O2TX7B;^Gwbv@hg=*pq zNK_$$u#=X@7i^#sxc7fbf<|)96sxS)uc>R|CbN1zX{)cs5u(%#xfITAJ)h?mVfk-Y zn%)D~Y}G7$xdmCD4LA`@aacN4sn)XFxf((D>o;Ka{@l9=sM}5u6Iy@b$Drc4MSZcE0M0U zoQ)-I`_7F7ZDHUovva0`GOaIrts=j_eM>Q<+O~X6=}CqU*^!FNt)m@7UqykmpbH$d z_w9dNfK7+!%71(o94(b!`*W1`5-$!|A4RCXFq)Z@OW8_M`p!*d`SoAK=yX$Bq z+WV@HkNVi@j4(=6@I9%b;NgMIrCDsH_TQL~Z4bMQ2rJ%&8B=ldcXC&Y(AjyXDwpn+ zqHg)4zVE=-l1R8ZWL;d~#t&v)ttD51z?1;hxvrw~ct}q|d7zy0jf7EEOYeav$%)@m zThHxh@7aeetpyKNn<_)Yv?gk!kC+wo7emU{LjKOD`prA}Bnkj-YfKe4k5w@j7nmY>0qJjn72BJpp1* zau`Fakb0gEcw)n{6Eqw39lLit^dpinps>Uh1heaq(# zE62!;mS65I^8veP@{|r1P_|-=UTNsE3_SSG?Xj{Er8dcpWk1vu{aFh73Bs3`n5Cc# zt9XUJc=IeCVorW#uh6LK!7Y}ZnU}|LV7vbIT=TJ`Q6}{+q9L3LtRvBcOqV-cUePHWk5#XxES@b8eaDL4AA=Y8 z_}>-q=H>B%Qcq7?I6S_NxoodT9E?y1W=VOUJUU$DaNsF6)rN zv*iNPuK-(&!b|lq;s$)bb`w6BgNf>8KeFzdNt@!FvIq8Zu0?hY`rT`OT&XNdl!WVt4-ZgUZgv2+~$Vw4(=hf;ADLhB1dMf zPP=}-UbE2c62>=nR!Ra=Jw53`<2^Jj?=)qlC6Y!a&K&=%l|nX#eaAn4wh-!ln}EB< zr2r(yzt)}13J}Ss_PGgulirWj`_C%pSG3Ag#BQc?0(M-|KZrRe(0eMMS|+cyD|nVfv7T*(k1fet6RYYe%eEoDGm?uUH+4*z|(6%k9_J(_h(d5d1{8` zkzCK6IGIQlHTae0$HvybY(qAULe?So2=*IKf)=Cf3pO^KKRHcY>A@S%EO#*f^!A9i zdesdYdsnE3`V$CLLz-WAucjViYx~Zq{m*V31CKUZos23D+zs0?2 z9dV=8d0%UZMl6`sFMW@t5$we_+^2W8Y0>5ov_QiW=A9)q6}xGF7?`?buS*G{USoW_ z5^qcy+u-lMaU${21X4#s>N55g*ebBTVPpPFw!P!;w;puJS`(PDsy% zy&&$X*!8Jn=lO>X#XGZ=PW*1`X62Xe+s-K5 z9VC;D<+X4{GkraDS5MEAz3y7e;U3(q95TC-!Q_>QoWFJ7Iz&x&7*0F`^`cZUbSt#q zl5d}y0f&SKi5yCqj*_taN%m!gxYd1exu;2l;TInMx2OpiGS zchO8eerv#o0FlGfIh2;j3+ zo1XxB#TRm>&8ncG+d*^cpY_liNHrd??}L0GA@w$>;stbc$Qb>owUW0H;<*$>RZ-pS z;Lk<;%u0N|gRDDF?b!Jj!T`?4-eJs=TgH>JY+8?|QmtARQNWdcr4puiozblAY5c&| ztd%qn3e|^zy}Z~`Tg6x|t&QQW*V+L%gMD)@1;BU@H8lFN_mEvJ|mh&m@!Ki;b!vc!)g>BONjr+~d~fT4oSoxxbciQA@;}s+gRE z3X{WuJ{>&bb8r2Ha83A;6XtfF*Q9VII>ea60lPTiftZ{wo1F&9JhP9@Dv(S*HaD8$ z&%I05pR)U2lv*e-nRnXa4t7F8gt1YOaG-HGmh)QbHk*uK=oKEN_XiXUueo`jg}*T( zuaf{RQ9s(we>MhKTW=MYJ*>TYxEyQ}40*7z;mYrJZ^}hD@uZHHE&CDVOxvI8!sC1YB5~i#}yN1>r3YL8wKu` z?*0PPK}00z84^VTztE&;IrSMGmCqZ?lcZtHyB$yW6NWhNpN+)dr-)+riOxk9?av1q zj}MVN5_O&W95gV0XYCsz=hxa@x}8vs*($v7R1YDb*c4|&d&c%jbJncU=OsGQK0u@9 zM>3bGfgd*S$2Ao|VF>iQJ=SadKy7Srv#4;y-1F@pa(4(YlxfSczOf^v z?`@#E^?zF)mk2*E% z0m>o%8r<~fO*O-f9vYxTrW8EqFw71HX$%u^V+x`NJa(?*cvs+_V~IHYEdMI#DJD*T ziDo9f3%^+ya6|W_*TQm5pYfs_2({x5AW387%JXO}38S>Xxq{g~-$eJ!vUuPFq5pNu7b*5N2Sx?_h?zP9ue%>F#8ThT$3F z1s?tCl$!XlMT3ll+5wUQjA`oLCydW|432*I{5x58kX1=QxouZZE!*!!^*1JZeyPln z_3=b-SMP}gEFKl>fa3hLY}L;aKO8Hyi7B`?9_*Vb@EGkUY?3$}MiqZ8k5c5Gt{24h zaZ->LHn1*;p}21SO7v zWM&Tb3s7Car!^)};ATKd-;A&2Z=qdJyPMGdlX6xJ@N1K;)>eGG^b^PM?-Aav_rm zN+~Pz&}98+Sv39ZM{Le6f?)Dd%}{e?xy9mle-N_re0FYWNxkxkr>}-eelyA@J0tXy zDHBurO8H?IeibuzBQwh22Eid8@U{c^H6BtW)v>-(R8m?x#$zF*81)bjyKoVNtDqlj z!>wdyQC2@`cu&A1hGnmlS>#-Wi479L5(nM-ua;Kva!a9J0yB#x6CvJi0qG+>HE|i8 z+s`Uh`8SLBKeftKe1sKXm4BXwE4e6Z5`q%us0STT3n!o0XR%=NUUWXJwQ zMf>+oVf9P<2UvkonxN4w#=yq$`vj}qIRb&uE8~Qam2{oTPoda*aJ2?+8htzhiF%w- zE`&Bbv5OX0i~(uiil^b-tJ8~DYzxN(3f)dKTokTej=FY@+~WP`*f#K=1i7^}b$gzOU?4^KO9ym|H?EaFTBf_Cf~N1+F{arvfFqu!xTJ%)91%0* zD-hecM}o)(9OY<Yc?(pQ+RimEIM>2Gcdp#C`IZe8BlWJ zKx!l_9jqn4fi^7t}oQ+dm8S)8b;w(+pVdNL|IPkFCyu$3o$ z<&*21IF@nQQHQpc9kK2R!;2mO1OWV}7+>Tpx(0tSttS-;ksOI*oeD?2d#wHQQ`%m^ z!A1!v7PUUo+gtCzUx=Mt(fGu+E8|r4?@VHbl9>gMIsV8O0p56|1# zFLoUy-)dcB-KcglS zY%Ex~*B<1UsaSkHcrlstxd;ES<0BhtnARt}($v4NIts-xX@ACN6BiE@ME(-vx&^b(;^@G*?G7;S1paXVH?qrkHpEqk%gRb&9u}#AA*^tO_URL$ZM=g{FK& z$2O?Tr7NH$17Q;)>)7gQH0lf1xS9T0fGGhJz}`4A_Nz=Hu-{?CrQ8VnYW$W7I8+Ij zirt#xbED~u!@_HlzL63sf7@zcMSl=Q?X_n6c{TR0(KejZaY&a83XR@1vD`jd1Owx) z4^nnVZ^KJV)bwuSM)O|AF&An*W)gs+ii^(aY4kS>S5b7nSaULN;hWVS@UXpaN2;wV5$JI( zYT`GZ{q^O2T~TYUcI6g7Oz=Xyk_K%=#eUo(;CC7nd~!F zZ5>R=A|l|PzW<_>4BfaCI4zz`$i~<=mnE|v&h1JukZ}@M5&6qZ5^-g)C}lbSqEo=$ z_+76q@~zi&w&;JoVuIBcitK^5fs~wG#wztzaURaA9ipje8k|B7~l%=R&Ko;+qu0OJHcJj z%_)Ij{rAkuwPh3ymmD65gC7V?Mc8;qUlHmgb^QEtgg<;3Xngg(m(zYmBh`N;{LXr7 zT8}ddmb`e7q!R; z@VmYwt1s@Mol}1nBtjJTu2HhoQCCk&soM(4IM|)|Z&vXW{z)(~@!?0Ghbc5k-o8!V z-SU?hqFY(yQ{iA&g>^}VtS7z*`W8^Btw_-M_w2McHPZ1K-S4}1SuUdP?vM?v+@#x zMcbY)KU~U8Dtp3XNp2_I{`BC-6W&WC@R%cr;D>8nTdrSU4&bu=cYXirnNnXj0LFa# zogt1a_>?3+g#=ECE*X8lK!?V1$0i_$8kr*qBY#l!QaRP>m5qoM=#Jiecn)6fUTExN zjhgojpaGYg+{juL%yu%wdWn@{)P6bm>2fe9OiNJHvnurbqpeZU9y}i0^PkmH+xliy zTnIR%Y5xjxk!4`5Q|VOxd#k-gFzOS$8yM|`7AP$p3I*6Lmw{$%EPwwF{2cxKLkn!LOH%z3fBd9J=t381uje8afQe( zTPDRuSSooxN04qyCmt+n>bezK`N;0b zPL5j$u)w6wwF;YaK0flwX{%GlpGi*}ar|l9#`}OY^!f#tS2m9TW=#vyndp+ry#h#4 zK9=VTF$O!eb4R9@@*PF|bzu@D`CTNI80sBw_Uh?E3|<)jrmdo>CT}bAq4bby1oPP{ zQAaGR;i7c){m*tPxylYMy+t8zuj;a1!YH+!-#bIw&cD$`sDuB`{3yliU*Ct{ua{%y zH)9u*zFXgHudw+#>1(Ev}j8bg*lUa2t7GXHJp0~GK9C-9J+Gn&;v^IbD zt+nFh^Skl>>InwS3k%h$(4RcE5SiJCUgD&o0DyZSS|?v(Ux{d!TWv$uU1qk_Q= zi3#2;t`SB4?b`ma=d$MX@qZ85tb)1m8T}cr%J%NveScjGIL_=8>xj+5i2lkG8PwNmdtyT6}j%W2G@@0bmVQH16=&Xt#*WXU}gieURRZT%!@K2+ zP$yA=&EDw~3dU(37^-J_p35c67*xc}Md<7-`*h#LtTR6KzMSt|Y~t||m*e80LDw&- zCf!{04pB!od%1edpv0?H^L>97J+Y1&sgoYOpRmWKjBm&GRfVp1w5`Eo7qLm?#BZ0E z|Gxg|`X^w7B-hstT-fzeKdpHs5j?UD2W83OgOOWLH6|^W0!IF*_%Z&_BcXOTACkMz zTD~Y^^U&>1y}R$}gG&wdx0`-EE20&Lxy!HqZAg0VuqA|UU%yNJOs50&av*9Qw0F)o zL-Qv>OwRh-1?WF3bz`j;)-}(|I26q$PF1A#;5X`O&~iRyku>v*dZ({0i`goJJ`=O} ze0T`slrX?Ka7iK-?sxnS=W4WGl%XGP2;6LN0NBDQ({z-T-b|EKGcDKc1w88j^VZ&%A`9U_xy;1eUS_#p zFU5|YfWMe};_fjCYL4{iGUbNB3s(?r6M1F4>R24-?ut%uFbOUvyKQ5-}xZw9Dt;_ zFttvX&AZcO|DPDNChtxc zAGhwoVHCevwc%f%gnh!OjoBns?GL838%Ly6c<(nzbq&nV?6gW2{0y4m@VbmMkGd5p zdq+;rPuM3-=NZR{a4;mE#A34-M%kKls)}23A)OVfjir_8C0Z%hsr}n9B<80DSWcYo zug2$cHQ0GXwPSH46p5qRNMye(H1?hrg!Ve~{I^oqr1y{H-aA#uPe1dTHlIp=@Kcjj zsL?I^^ZMT-ooAaKcyU2es_M6Go=3^Vgic{D2>iZ3I7Q8Hi~(zwKhwS1iAShJ-cKHC zE%9q?okFrQfWwS`NHvFJ@I{@07|8q#xq_i)xvZx2c4?M$rQ0n`;oxWtt+C094S*Uc zevvK%TFK+J_r}+Nx7a=C-4QjR&a$6ryYF9a*|8lw zgUaTBg(M+V%Ggim_vu@pq2}IzQVB0(58Qn(?|km~!?tv*7r$4rY+N!f0=*^lnW@PT zU$6m4DbmvG&&uC^qMnN$6*!X}o@nj_&2b zdTWji>YUgds0NBzCyd7%+!%iX{TZ28kz_KzYHhGfNWA7X_v{eXx4w{>(&jy=@TMS_ zk%c?C-E~tS%5bfx8*}<+W#aVm_WxcQ=~+xMrO=Y5$WlMuf)7)~B8U#)09Chtk!OcP zIp`X$!5_phdcSZb5cow!X=*A&oFs(wp>b~RH+!YKskhjxmIM2TOKRORfINM_KP)_g zCp#g#PJKl`imo;PyFonfWB*xD8~496BJ#B6d5kH_ilAMzy!(fR)kh$zT-R5Wagni~-wC)rg3mMXnz0YBD5}3J(2ImFV?8mNh%k$7M4-k5jhuHgOS6InVl%b^j^(q!*_N<_;?mXy(OG)qbg4So#jyn zdis0WP4klpH;14r$+fntybbgAw^~QVMio)Y0hkB4Aob|Al%Y_gnBn2AHRP};`isXl zggbN(BOHXte=V2aas0_i5b2_EGxnCHWo+r*+*Onj)jz&YF%9#iy91oQ}z>MQ@mZTjeXR82oD>wd73WvAF>n1c|Z! zBxL%79(4@xb4gLh*IKB5;Qu+!x1>^qP5xbee{1f(t97IhExon{eUFXBACJwhiq9z020^87+y;Vvc9|mY3~@qt zzm9i(ONyjLBwzGOf4>TF_ z-Ax@X@3Fc1YEp;Q{(W{nYri78rv0$F)U7(ZrN1Ww(Vs*85LOiT>+q^m!G#``bd zLHR!Bf*+tD0}Y(`}lnJ1x8*aq8z2?7JDoU7(2+dEx-8tRIUyE7FaFoWOie96n>%G zHL5VUx_ea49(4Ahfuwo9!C;#Zz4k!l|A|H$Rr`=X1HO2y*!Lj=Sg|J))%$3mOL;4z zVIWrKY%!XcTA}^E_0Dgn=UC&$?JJiv6Qc@W=u_v$-H0nOL3HW5#};u=>t5sY-FQKa z_#!mpj~sncY`1~I7}bEzeh)QaUxBPYXcFjIUe-R6Wt>Vqo99_!Xc>eo+ z<=?SHw*wdpB!wOaIUQHK!h6`UdN;WtD1nPC^u^DV@k~KA5LCn+IqihP@1Ai7uV1CpaHC+%r;>)l{4b6GdQ-?^6)#Z|d~ls8dKi&sy_ z)FXg>=H)Q`h@-1@Lq&|5yiF-T!Zh?0cd8!r$rAVep2LJQhXwYmUdSTnJoFp3R*n0> z{Zjdxc$o2?loSWXsO$KyCb!R)MgENr7_upnb@CY`^yP_bfEm%--p7~-GU~NqUMT`0z4tzLY5(gUHzi#W8 z`CnSOpTV{M!%Oz8GE-}J?&ziu2J4~t+48;6)J86Ec<3w46c`q6_~rl#n1KnHaX%UM zvTXm{=keze+>YfDa65)+-Sz8(O7T0p9n>p_Fa~LR8tsc!hO*Z28#9xycr|I3Ae99{q`qA%n8C%PGhfMa$hLuvl;93Z6N#O-z@Tbt1Za!Z^D z-S6nO62Fx$wiNioW$ZktBU}pc7v*Ry;dJ5XLNta$U;=XORcT7Qn8RY-0@wF!Bav^w z6vKBBFK%V{uFlQ+(twRZPc~V2zA%hFnvnUW9z6csS2FtU-ucqo?~@tO`EsF+7a*hK z#H1hCfLk>xmwBu~^W6WI{|YnBKrV4Ef%4Rr1xhd!j&`Q&_zp>#sOLjeKXJ{Gij9!btI`2jV9V+FjJ({^>g}cIP zP5y$g;QmD}dBpQrzw#`w5Vf{4^KGz#Uvd3vVtoD@Knnv?t9t#osUIEZ`;#q(ZrT&W zS=#&8l`b*EapNNz8h&SsSRv?3{M1w z$frHcAq7XmG+!tDOr>UV>`m%X4H?ReedXe^6#qMv`;^;`FRQ&t(NAgPG+%%8wXpcy zGr*Eh6KvXg#6_P; z`b6zBj%_B+jgsF>r38C7Otu_9BXzoCE?8qDzDK^{3TDCJ^D#yP6JV#D_uabDmgSo6 zL$Cz7YmD>?@)1`P)h2w8BKzgLc#@H2AyIyr`6rCM;6A20!Ud7{0#QqCq6aRU+LXIT zRFalmmt6G2frZwo-<~im$Q>-juGPqoE0gY$3kq}lGTtSYpl}^I{9{pSZ#p4m zO7evOCB6x0ox+(x>H8;l*7eiey{gMG;hcTfcf2u^mp+3g#cWdDFboF3A2eg=SFMT> z*s4me-*S=X(eU}lEn?|WDD3#kw5*#kPl7c(V!I(Q$;>i@kHyY+G@!Iber!DXeGSb` z9rePOq6Y#evu1RLxRH;lqgFu{S;p(wDABV9f0p>ox5rn1PVinFx8q3wh&wre+*6Pj z_kX+q3*h_3c`q21V7@4^xBMzC@wy0{xR&$?q}TT_5s-kg>rpC$)6COsLL2)gqxN7J zXC9mdOc`gytn)SMxmw%i7^_r`I_cTZUAM+37&R`vE{J#ms1xE#5iCQ#zalZc`to3@ zH_a_@zCVXpB_L+T_gBSuGD;fI zPG+EAw`~zA{F;~3pXxbs1XCYK$C9{ur#>3Jqb&gzh1OcbD;wU698p=<1_QMHu+M?l zwizjDaduj}X;~cewQHd)L4KFs^VThTB_qdofNu(?wiF=-5d4QX19S~zfkfTCR^7P) z*R~3W1C!dTYYr1GP|bOo1Nx4G{#LPWD7#xLfiHWr1hE*MG`;ywg!RElPDwYk@}4jD zvmz<&b%IJjE!P$K=_pC3bnXv1!GqY(o?#p+Ys%K#M-Mt7b00Ai>H}wx3+{~t*^`U= zI!B+MkKjM{QvK+fiW#sT5QTi=D6-Q8$?y&kMsNh*rKJmFhbAO*CUf3S&a>cw=j!Q@I~X;K9Pn*xBLH3rF6R9p)nj#tmngZFLNS_V|Z=FC-pnzVgZAJB2-0liRO@Jn)3@^u<4!MZ7oR{{sC^mfhU$hzuaME zw@~*h6Q#}bW*B5Tic1{xI-w72z^TfDA{FS1PC!xJOG~Il5>& z8HCyyjWj8Mtv{oGwNC2-n@?L2_d?Okp|$@#dwMnC%zM@Sq;lUyx)OjlL zd3HVE*;Z~ukcRg~699iyQta=L?jE}x&G{(&K<6>G&@nXq?HUi1e6~&-S&rJ4)qMFk z(hl@w&x$g}(p!$)v%=tfh!;GJ)L%XT30`DO=H}#d(C`bKTzJdpqS;|P7NYbw5xp-C z9h+GF3f!;qeX1VI83YnJ8;oF2=(HN38LKkF-m0Bp8FBtbg~U1QpjN^dR=S z=1Vj#r3}+wbK$Tw2@_t|lXj(U?%(|LwbUBP=Ho3DEbkiVBJ;2B;>hxM&eKU=(lgfHbjcsrzxCEL$z7CduI1;Z z|a~h!3g^w?B^QWtx;_`ITdt*%2&)!@I(T>wk+yT9+A#YwBfQ&{e}7xj#B-MqE&4^f*7N-o+- zmQ=wh$W`1H{Q&$;V2+Q3XaQ$R_H}K`3f+b*IgXNEja?yL?J~F9yT3>KZ>>A9?SaEl z=yMigCurj~T?vL!pG$cWz;G?8gz1lpYfO^dZ<8Ifyy$Dh=HnHic;w-{A!9ivqLwBa zQv>L}Oq{#CU-SE(Qw84(d4pHrFOZ79uY!&^d`-4-ibbIvL8kcx0@dY7UjKnW#RYiw z8OYmp7s^ESeuZl=iXYLhdFoV}DxsP#5a&7q=`(v26^DN0Fmj+@y?MB=-z*Ij7`lJL z(E)khW=b245t^5sT_>C6J@Z7yeo6%y83h)Ol`Kpys&qm&JdVB2cfsl66o+%b#z-J-QznL=(}Rf6zq{&)?Z+ zYYDtH9g4hlMwx=q#_IsTuPh(m4jgSEr3I5cmE>g)zxZ6aCjYQYW)G8$9867`rrdI$ zo||o%f7XB2Ggdq|*uqY`e~Ea@X6**~w3hcbzdl!RN(yZp2zmjF@P-$#xm2v2Xh=EW zyzqQ@UxHsS>Qu!kpSvE1bn;S(SU0DxDxZPyU}ZiZm zXIqevCuSQ|Y9;xe&MrBq!23%Fivio^jH8fPWSOaR#=q|~TUX<@^F^(Sd#~9IDh!H? zD-c&@>Bx&F*we+2#l|O#F@B)XTfr>aWHu8JuoU>MB-{~O486C|ag*RY^9!{lC4)L1 zwmf({iwZX?hkwbYUvgPbt>*9fu;t3dDJ(|lM@N-28Ynp6o?Zf#G1Wv4sm`gK!s6AQ(eyPfNf$t%MWBD>Ljfq2K+yw9M1;P;MfRnqEK@BUvern|W4RX-zM6I@Og zUd*9F{Uw?{j4PsQ$DigJC9Q6643Ypy=G%;rY=+LBBH(9BXX`q0nk63$J*H; zU2lN0gMq}s776~d(S;f$}!5&@sqRBqC70TNH>UwAHapQw-@cdqRK$hEZfT z**?j9P3Q@Se7yAQDdVr0hG}tW4Bfs_Hhqb|{};4VW2)Pn%JyF1QgrwI=P)3SkCOyy z8m4hZJ)2May?cO+MTJU?4<{XFi{As-|FmZQA;e!>gQt8vhDcMyJ8Eh{zEyt<(Iez4=MfK^iQld z8WyI>(UUFncRQes3WqE^-m5BO);X2q@0?egz!krtmtq;*Fl#2K>ek#Nmoy;`ILygO zWD4oB7$K9@0pvfa_^2&C@IOWLP62?QvkvlBf6LU#ZSaMdMig;iQ+$hRv3|LedfEq31Q(j zEa!rFhL$fK{xrdPJZTl4K2+*=4l$FBS<1<(VYMox!rvOSeYE6-`GJ-9-X5ZjIQWL z<0HBQaDJNYOwawj`_^+(_?riM<(jYSttV!rYjndlX_9@k{HuMy-@pDs`Lw&H(LI<@ zwQPYAF8v6I7*PL1H!q20$A4U-oFf>O3~+$%{>(6djf`8p zqhoL}Z8BLW8!CWmXtW7?)WM&|KAB?i2%(SxVFz8bde_CvkHp&klG?9b#IN01PkLa3 z%5=1$HM?4`{4knvn6gBNdS|3JFQ20s}?>HwvxBP{f+3(y$Nsv>}C%*e_#9giNVA(=Yz3g zuqb(Sl>plK_4Mfe$!X_kL?C0g>_fPF?I5DSqh4ivj)AB>*76%YQ`llY?pdz?$Yr)V zxqjIS0CoMo(s*{Cl|b;@fr$eLb%Dfa-z#s1AkE+jIewu(=a-Ir{0gg{?S04E@w+bX<>s&75(%!IQfnxj@9I@!tUML$=rO zPC)YSWiR6prTLH~KnL{sKR8-_h)VbIHt<<#)!qHWI{pOfu5R6Nu%v8gVyW)K?gJ{% zmx*7E)AyZxpe?8*>Fu7)sovBNB!fv`t|GF5ebPJhBcLPmH;AL7Q_|b67Ba`uU#6sjK*Z?w z8~^BI4oov%9qFe<2r+SFLvf z?`|BH_I)_MZ94>+@wG>unCnIYK(g1!$zOVSH%2j@lU4X)IRQ{2|3RzuPoZd4_k{RC zy~0l_q#Ze@)6JQyV^5`;o5ov}O<;<vnM$M78qN@Ijcqe ztcd-qm_8>%j$}c*S(Lp&cYv1 zqytm+B5YBvj9~aTLK?V?7Xy-TSH=MYaC8tMNoeG4k@Jy!5LI$Q@@xn!ziP#77b96~9r2`pav z%+(>Up(NEPthAbAdS} z%GH)Wr=+u1H3dj7m=9E5nKbqkP7FC~$s$ehv^;$RltTiSHXAMt4+C^Q@st2`@lWN%fz(DA1Rm4IRL-)aq-4eAkfLrc8NHcH`Fx+lq@3Z@)ErLD2&dVw?oZ%7`w0EbX+f07lJl$d{HLMzcgQ^nl@ zesdhY_lfu91hF23L#Ibbhg;x8TP$iL5I1H zEJ+S=*P6lE-C!%+cygk(BMjk#;G_ijiaD+Q*3=lI)jJqfrNGso`gt^IzB$}CpnJW- z>=uQfz&@Ley@m0~FDZvLW!67N_GoE-de+pg(bYtSp)=~N&pn-{Vg?-U?92SBe%|2Y zGiAQ{?tt>rL-St$yUm$%pU&@jJURyn@Te5?-pAM8k|Jw{Ocq|jv1~<70%Nm!fg^C$ zQZw~oD;^3ro6IZ5FMw{1k!z@bzcoSb5zs)t2Pa@Ui7G=#DLBZvp62r3oi*i~j(5qruG|0+sI7 zqQTwZ+cmu{bhOQQI3HiK_o*vzdFVG-5J2YWF2>>ohF7=~(b@6>h%Pb0q0Ar96GNfu zb(m<8k3@PM{|QLaj=%J6fYU1}tsYfn?d*bPI_Qt|(_kULHah}k% zTltJBS|Mh!TRH1bcZU^8AQSoixTGCo+l_@f#*YUs%!w-e&`wASfAl14r%D1G+DMgY z>Rww}jih!wLQUQZr=FMn>t;8s4e*XE3rx&kbrO`(7qphttTmf*8W>n8Pov~&jFkdc zMo!$YHJdLfaHC(o6RB`9aD`@)Z|sAIE4RI-S$&nmUsf3)k4&Vd1|k}naFlsdrHRhs z<2wGvPFXuit?~fE;H^*2-C(2ls&aV;TyQ+4{LTZf-`ehOxz>uJF!{9%Gx^HI{(Eepyj7%_H}DpFT&>6 z+N{Eh_b}EtwiP~_BUNb`z(<7>$AqGO1?kskSxLtQJ+fo3)=XBjytYj}XM7F&=>l?{ zxwTWdyj3%}&SKb?={7ZrujC_ZO8O%x&BY{;-(<{W3^kMxU`xET{or5C{$o!ScQtz9 zguY!L<D?O}{KH(%Y95<^JB;|CfA2-J$EI?C_9`J#_K~B^B3ieig9UanA28yeWCn-E~?N)&+tt!)V zY|~KwHzjj?>3q_Sb2n2Cen6^~(#soaV$FGmpkkWCCaLM!E*_thC}Xp;li$V3kA~NM zF#*BSIcOF-=%_ymphvjZy^xBuvc$ot%x-&3R^&QCqw)&CG>zz^%3h?IPWKA$b~sX= zM)xp%nN}^5p|Zx7&;!*4zU5sjVybuQfzlQP4?zrod8E>K)vzK$59gE{vLFRDS;VzW zi5$!r0QFXBNU!3fNm!-%&IuJFyiJ-TYWJ2k$VUe=1aW5T0mCE@d| z1L{dmg?QxloY#kBPPi@ZHNTW_jzhk zK2l5LzN}+5y_~*6)B;T9Vt1Dlho}o z`M*xS*K zBN=~rMUzVBHd>xJsmj9>Ws^0BAt6d-z$1*W%AB1TfjKw|#Wx(R`1#q?ix4TU>6=1w z_eZU>b(n}_w{B?9(cU|0f}~1`eex^%!0l6*oxS`-#z&Qr?rreJX|M;=lM1^?!H+w|0)xcwj({h?Q9(;$ zqIGyqYs=iwLQ+9Uh;`MIpw{YtozrLFz18{%dU=}?UkP#)TV>3jY&-WB5(YWm)6%t^ z#TajAGGCiphsW14j@xRkgT}LKXW~kW3Gop62Y$2UI79*YYXNEuHh*s@FcCJ}!s7C5 zcx~%fJ(e`qcV1VpTv{V@kZ| zaTqPm;R|d*O!HQTK|TW-8whGB-TuTm-Lb_p0S#e~&0San#Q>qkyI1vrHw)~fQoZ@U zIizw+GtG${X@RxNpAD{g?xc3p{z^hlXBg0y8asbiQId1&4*+)4?(&G7X}`S}y#gkz zugbg6Zqul_*=!z0nO}6#9vf)rC7*?wF*b4O+R2UHjl2K;qhho9fD@eJPu9dmuPS`MlhV*r)bH3#gIU$3f#VPOFBva z3edPQys^l>;II*@oTelOeiREC+xY9e3_9GlClf+~!Ym#X`Ruvh&c=4P zmtk}9c!L=JWvtS@#N{B6(e=VBMG?VKw4!BmQeEj?I z(mb?~pE@*(=_qr*_T8AdqmxJ*r#yJ$ZX$dgRx0~@Qjy|u(0gfrn@bnRHG1Bu2=ocx zP-g`;-q66n0RzjNlit!9KgSe&%Ks~9Vt*2R7vd_x{ZI*D8VdXnX)qO4E8NC8Td!kN z#l7tbxLB$Uo(5n_c8NH&5q6^W zy%^z!y$3yIu6|5{;MVhiBmrZL%LR4k44K?y)qC3m&J6BuF|K|At}SWgA~rVzYfAq7 z#^bqt_Btpp1DxvgNu}S>@)ePVPcWMYCXP?8)@*ZMuAecll~pcQN86%je$f`5K=P2Y zpmF|#V9aaxiRoIKoNa39$C=joU7t{|K1|*^DEP0$?=3x8V?SN^79>PPCak=D^4U>( z7-INmRFq7-Wk-CAvlR!PFx5;{y|4b0=~_g?!LEl%M8EdXAU~T(+#3Ib;XOpw1psZ98 zvUVq9KSK0ft6zIb2`v>6O~VCj36cg=SBU+t7{4a;5Tii6GNCe|Dpo%~YCku%bh%{eODxhgevXv*ZqFuxY@oN>@(qrO1Y zt*#D0Sv?xLy|J=UQ_r}}%|(fcSyJ}y<1JH=KE@C79-KPAz1RO(C-51$;FkT&{EqOG z&vWav=_a%cX{RI}J@@KZqcr#kh?%gAI2En)O{i{~V^3su2w0YL0 zh<|@GUoVRq%hh(NSDyvGn`j={wA6ff{{+m0x+b;l0eq_{JZzALqd3qygYuDTP!2O@ zmsQC{+y{noO+Sq(+MOtDy`IJ|UyW^_F9TNvdIxuoU5PYMwOD;kxBsdDEb5=s)pN?8 zsPkpAOPXIYDsKY-^*FM&f2_pe@C=-Xcw}RpP#j-2z(|dEMFC^{y^T%-0&{Cqz& z&dxA#8BC1J)>-z+83m8q;jYf{2pcmpI&)dDvJQ@Xr%Ko<+muCuFL5f7wBxz3{Ziz? zf~lUx0fBdSD_)Tk5KXo3OZxyvcQ*a^P?QzQ%V*AupJWSi?>N@D_6J~uC*2m9p?`!2 zp}qsc%SSbLxE&kzH_ewa$e=HasbMf$h`ASR4ZCr*{98VJaJgOZQTuzULIS(4qq2pf zS1#l>D^$yknz-l@Z9|vmC@gRPEDfc-DQXUG`|`;w=!}lBJIY=m%LJ>-VK%9Vk81l4 zbT@C|3d8Eqj?;{~X22inT555K?O3c~#@x<23^rn@-JQnG=Hgty>)U+SoF4WS=7L0? zK?7aq7O=g&zfj3&qbQHe%BA39KL@LO%Vw*1mD;i3X8i;ow|r2d%3|Y8%;dn;>#MSa zcUQ7kvA=c`GyHd{MGm7H^F(%JfTXYF1PS{d8J?4v&BX00HewPx%Gp-yNJsAO2dCFf zI>?ns*_RXCGa0;(VXHotP3tYLbNw4JX399inuJzX0g$FWbAi82aZ)sJ@)bxTH_zc|)qm$E z*!d?CaUAO0L@jXCz((A?(0!}1K+SQM%Ce&QF{1qz}14&jj{BG~@V=QsmN3wJDvTHEybSoZ=22zjQ+AJ&ey+)Z!v-%@$E zWwRWiCUeqiNeE`_V;Fx|REn3?N(ys|m)#fWb*yVA(G}<$mo&Q)&u?d2gG3@V$TXBPZo2(uvg$uSio{jxAYerx~=G@~zfWALi(ijPg`Y7t>xV zC%(RR!c-5b{tD`Wx__T-G!DjgwwIoRcNf}R6R`1JBiFG2& zFs?__85F}9XJ{d1EYr(DxF=mXdfL12tZ8pr^lkl7Y|D2Vp#&m}@T2CF^ zcux>OIb0uPR-sQLVZWZ|e10<|gFaa42KSN6A=Ew*KYUuILVUUT^1f`dcp-Q7(gMCm zF44Q@b2-T8cJQ*Lu9dJ##A3dq)6hy`f z_ZAQzpKrJFt8MWNL(?B_nOu^3`b4VerU3TnNzcMiOPW-*%T&b$a?JtK^E;!nej;GT zp)euQI`7FJK6^!dAm7ucOY7u!WdudIGAU%d0K!np7mHy+9$wy8LeZJliAekK9!}p!6?=d!3uc;*Z`QX#T@kk_NaVlpE50gkmS&e%O4O|tXkiKs7XW+X)su^YDI&W`T|%sO>Mn|NoLljZRd(elk@l81-r$asQPBMal1kB zAi-O#a#eYH8J*A%+8rHH_dD+j(=<&@@)MhQ^YJjJGlI9Jo7N{avT)ovNiQ!zm<^b% zS=#&WVQt;=?8J4|&?}a@$pstSWnC?4*o%KKC+873qZH*zodEg9PV+M(q7p zH_X2QHx{n(ScVK|mrZ1*5oGa@LTMkO9rRU2l>k|-`V*t_4PJzZ(RODs^>uNp@%-Oj z-a46s-SNq{oq%V!)%Yh#^BdhA8g)p)k$GWVqyS#v>TFj764oHJhf?e(Nxp98F=`@i#xQtFCYUx-4~Z0}qe z!01Ea*^pBO?($b;6EnR`5IbL;e(nZ`j%G_PdPJQ*;g9~$bpO2UHx9}i-LJsqH;Hsd zkCNd2@|!HpV56qmzYF8b=tHUX@bsbmmI^ z#5%pHQ{fwF2ES?AiN(!Y*UqOKA=OhRpzPacN;PFFKRDKu(skcG6#p?=U^((LUtdqS2{qVngdS^MqOnw zS*G5>k(;%8L}-rIt&C8l9=5p&wBtX2)H#IKCg;$uqV{WDMTkc6)5 z>Y4)7)&qEZRa^}^yrL&|(kFX-k@YDCudfchJ!CVW4tLTn4)}nXNb{Bv<7(&))GjFP zSKrL-kvy2C##TLw5@gs7nB}@~#I$gEz61QCjIp^+DITqldVrKU`oMQz#~uyo5zHKY#uF|N zgtBl~3PGP!Lh2{=4rLzF0;>rrC-daY?845t0H>!9fb1=@Opmmd<2PK>Z}ahl0(9At zC3ytKn9sC4@s=AT>?s-KHA$N;vep6q05NszoN@a@xUT-6t8XeFw(s++ZzKet18fdM zH>zE)WP{!wc0i@_Hhb2s#s+M-4?mAA1n(nmZPy~0+E``Lp)ixZ%4&wd$x zz;O-nN=^0}4khAkE=dhvYq{in7+#el0;H|Fp4!hiFqk1G-H;@_FE(-^)_pRg3%$q= zwZf5H2)C;m>=9*O*rv?x_D%ZEwWFbU+#akfFZRl`Z8VZtS0N~gEwoGXAK zy+}JPh9{oe!I<62g1HDu!g#w(D!ju+Fo7Sb*t^VW!e&o#vE9r{>gNObB!u6(!4B2a z^_abpl?yJUUgA$Wl7v>UWZa5dZZC4ru4<$1YAE{kG%fU@50h+?D){#hgvod#4K9{3 zw{@^Rn9cYN0>#U|2;sZVZLzg!DYx_Z!2cK287DboKIJ*7i|GRO+DYm`oy#emf<7e6 z5BDoa7Q%HMyfYB5e|Y^G#-2p^5Xhd6?>ioq|FX4Hy58P?EnQgHprA z(N>yZFUo17?s>lM2+xq^{TG63|2EHxF0EV9(e07Xr(uK*lB2zx@p%oPl)vIS<0W6W zY336PTkP$P7DV>?3&R!SGN=x~bBJ)#hymX0q&8?uQH;M#o4J_$rri^y(u?{yQH-e| z_#LEGay4>Zh_Qi;eb9xrN$S_j0_LE4)AJA~yYJLID!qQHoMp^MUuOCQPw@GI0*jPI z9(?|!rn^c<7CT^uY^C{~7RgE-s4fP$ZbPKpL*W`>@K%V|{FFIYT@aOEzUj^AGN4dW z>!ia4AU|TsdBSXHR%o*sl8P$X51wV68B>^675Ee#$_h-tl{hM$O=NzBx0@ex%FMfA zBnf5ROEIju4!8vro4&JsWD=uvaUZAd58i@1`>i)?6DJ^26oJbVFJqh0g-SckkP`v6 zLRie)&|CR9WYL{no5`I$b24F7bYgrQ5%h6HZqs!8>c-^70O8p&o-(FUe!xjh+}Ff+ zC!V=HKGdn6c4}eIv*jc>M7}{konA%vB*2!}&MCggqmp=;N7t5l<~7@ZPmJb9X&q>9O&NIvrFm=n*Oe6^Jm{DINL-=3*6OF zyr*OnI}Z6Pj^;#<3THD18w|KPJV5T>0FC2+CZY7Y75BeHj*eU)MR!7~6RHXb-ZHkSmB#;=XhDnS8W8`JHSv7Yz^i@%U3mr5DG0s{%57mhl_D(Q%yfLXSy zd^}$u_*bRcV~gguYU=fkj?l7Zb2Cqg3+dB_EM<>DDYTV zGk}%y?xcFl+Wa65p^Ngz`lp~!gfT^g+Jh;no`LGTe#i;y{zp@LV z%$GYbd||v}(7!Oto3Mx|octj;0U7`a5hE z36ZkC#ON1~YgNJuP-jYM%ct-RZZg-+;=i+$;%Ki6FaoXsd9y)QnhrOME#zfB9LfNe zDMO-BHMAL&yHb07V5Xl2uTGTo0V0$>@Sz^$z1JPmt)%Me*JDGR)F#~xU0X5T?Do20 zFvlIe9+1C?;P|=KG|1C=)wR%0wv$G6mtA+C8G;e=9fT9%! zUR{wAQ6PDkP@g$_Dzk3Ryw%OI)!ItkINH$kO69uO*ww&gNVMuMUlR7X7+`_}@FW;Z zrzP|lc};RWraYFT9+M*QW^Bz1N^>@)ln~dYNA}@P%)Xy3-!RL2J4KJIM#yOW-YP#s zu3qA8u5kQi;zlx@ih9Pj5z7 zPEje;50DNiT#>NJ^HS96C@)B1$ABhf)2^KACA=`GM*bRp=1~Ob6qlSSUyK%As3bR91kzbtsTy~qaPHHyd=N}94 z#31KqA_pe2u4y90Y(YNL8-KMglA{pIkPol9mlkyS$gK&>b{^f9FCZkWvFPk?0tLL) zJTEoHfEWyHTXSq$07>5)Rgg=SErJL(p z132GUCbTbukd=d*wWbc1uTvE6BxL8)a-6W)@;qB_f$@}T`k2#_-IE>7BT}SE%Un)% z&ETd)>w?cZ_O-^Le=_M}-~zZ&^y{CqJ<9-%9pUmJ&Ia>pk9}jMGp3H6$ONSf#xj=%0sNyRkI9TgnFV ziq`d6@R7*#2K}%LX97sW?rUFVemBqhVg!V&Hpd<=kXr;vZd5m7G2X(=5!-Vvzd7FL z6E|qakF%Y*KyBfVv5hB*f5`dGbtck(5_{(2Kc@sRpJxoKbIjH8&{Qud%a)o1(Su>=nE8l`l$+SkuLv#2w-n`G?xM zarg<=f3gg#8{?VjxK^(Indb-uN|RKi^JO6!pT4S8+895*!GqQ`56Knf?MOb(w&4NY ztqGqMpFee9^ICE$V%sL#f}g6cHmLS&4)`IVZdFs?5hEGT zhEnsg_;d+I>~kd%^T+=@rNmQQQht%-&z{ELP6tf1;VdH86!CV$Nc_7P6>|;Ibu$ZU zH(Y7riX3CM=ShWe$1@xHlh&sxzAKRk^g43@{YIe!?P!kADw;XW=8F}<(_0XwkE z6D=iCjjD1t&L8eZx0AmSnK~O*W}GYVSKxWwpQa?`AhH%Yid*H@@em?b*Z`L;4 zAtgp(N|JIcN912e2vG@<>mTd)GL7%|m_*-qB0hb8 zE{({P+t4i@bsG78t)Lg41?75oX)v#2q?oUygl$FQJu@W;N%i{C2^7YLvPBI$-RYJo z`^NeasF=I61EX}I7O=-@pF06H=OcSoP*gT^Vqu>SK(|HrqF;pjn|dW+xBWZD9zGvP z-li8WF?$g|WwIxC?E&&NzR`kItNvdmgAFf=J+p8AHKcwyq3{M#_oe!nQBE7kfEJuVCr#TR zUV(nn$un5Pf3FHt1Py0rokiw++1jEgZu6c&*{)ZC&=a-?3z)VU2vL^5Ph%p&>IBaI zAkcb;{?1g50&=wHQqk@PX-PlXadNb1mx}5crQd13X9G>Gxes%!D#&~!s_XBwv3_?U zk2@5tpmF}CUCwEO=sU~BieD(pZjTHYjc4$Yr2={!50c*$XaG0=M-vfsZ@el*GXG70a!wIR?kBU>0&o#SY^9yyT{2$t$aWhmU0*yM*af2^M1qX?hh zO8P59Vxcq!?V(FG^Dz6~qb(!f ziG~s)rS8-ftwW#9`q)BBjGr_2(_rTEKT1UaSY;6q;dzOB>S$$IewlDi9i1vd90ntv z8nNaNs*l+`k%x#FFm2b%Ex!rQB=nzKxbACCZr0&{FlaBW64##Tdu-U%h_+yl_`2j; z^)vw$v-6fEbYd{6j6u^6&=Tk6@PH}j_%5RlQEigXQ=aNoHt+szqgp;;T&^;|PibM& z0rvXUC?G^U`w<|A0aPEv<+IeuY>oF>jPs2_9+N*ToSY^}R5c3Df5~Ng8$#H@5L%xG z``a$`w*xB2-|O&;*2aeE(rhA29{gd&{a7X6WTmuBmX6LCZz`ui)#wG?AZ!RBxItF< zD(Ac^ANx4VBN(8=$rfIo?q)m!#Kpy%K9+#$NiKZIDk<_3C-UMC+yGn?eT2ryMi{Eh)cS($p&#wn%CHTn{s^ySp|XW7=vof6$g$tfZADgbCBVuG30ad zSU}C%Vxy-~3t=cd`pF{shWfqLnZKr^4bZ=R>H-P=`;+pYkIzS-YRLDid>sa~_DS;a z81?B$E#?Xx34_H+LVaL0`tYC+i!yMw(&gT-VdKScY0!-y^S2S+v*TnGyWg!99$0G$ zUz)j}b0bNZt~j~0J*NF^py7g2U$1ChcT(yFA$xiN@jn~H)6L+tx^ewckSZ2c)xpl6 zj32(TFIw}2S^2L_G|?2-Z6JGs+QT|*0ac3(MczAhuct$-=j0E>Z@t0HGq05s)YgN2 zhx9zkN&h|3f$vW)pSTOZs_-hV!b1c`3w)2&Hv-VN5=8fN;&k9#Sz(@oR}~8wsBN#O z`|_Lxn1EL7tY@F@)|hfe>vp~~8Bac0 zVMkd`DA^F;I5wg(crq{HA-wJEN(c!|teP?|V_Yi4=-u!)YgODvaM)@+yF(i()E;X6 zBT?I*)~(tMx4ITq$LFi_h+n8h(rAuvgVAKe5Qmd^D1;3f^xX@jgIKH%0)2tm7x1** zY}An$VBJPad5>j4tDj0QbeSKXQ$Mt-)lZ>HblO1tHeW+{skSBEL4|~;S1z&hY00)7 z#0oBNpFyv610dEMlH}#sWS;l~7eD(Pd!vIi@<=c5Iceq_{ssfAQ^AScD6F!tT=H?w z`DXo|eSV4xJb-V|tryOKz+tZgC*ilsW){i5eqpiCL++}w z2m~h}{c3dr|ETWL`e0d5%G|@$q)SK`RVv3BU)Z7|vD@)!mfGa7a!POINzVgh`6II# z>@3MdUw#ny2poXXoxm9D&BG%auQ%nk!zmxU`ODeq_;JMV)5};hY74}BvSD*cTw=ff z(UWCY3|J1S0FfA*i6bmK8Qjy^yRps#cL*D1$4H((%SW{eTJ5%cX(@CsAv$sE|ljA#t2TzqhZ4nzXE@Hyz^UMotE6EPq48K_EQ(LRZHKYSB{HV2(LYodZf9r-Kp(c z9p;=PT-vO{2{&7a(fjeciH&TNMG8=gV{dwT4MDTL4d7CZ{`%(fFJ&sPE{f!(#f^^p zLcr7QPIgCwzcQhJ}fVEP&xA z)vBU0bw*k^P8RZhEEX01*v6UUKKK0RC6+=v%$U1*qEdHF+ICLyp^O0u zdZXeg{aRE>o7)Q3TrY9df(V%7!Bz5>fD*K!k!msFfm!o$G5IO<`tLve_12h;F^5i4 zjp8EnviXb-?aj!1X<>AOJUPD`&|LAwjJXL3>t^`$1Mihr>KTX+yok9Py-tAah5X(| zAnUE)P#lzn2sjI&{8vvLXS`ZGVG%SaXl24l?{w-YVJ|xF;m#L2=tVNHwaC3GO7-{W z$23C^kr;oegjs<+l}DdYRo=QUSlBMkU^~kYqP#18rOZ9)j>Pb_8qcGkG5K!^qLfI7Pt^j%=b9Ke+B6j>EoF(zFUOH zWBzk!k>`k>CaC*J(Xae(yM^id-?OFpUuWNB+}hbD0F38jMKs!Au=>I)3tX3$h-*8y zo}ONG(NI{#R#eTal^J$06itFM(X2G(;?WKm-_T2&2EZM7W2{abxJMUqy7)Y-#kown zHB*2ulm6P{VR6V1tLf|=+IFE`CouK^HpxRWB9A>3s7R!b73~n|N-t~Ed^`*{TI?o3tbV!Q7U!xVkGVF}0vi|SEbZuY$&$x88!m`+!m6f1 zXd>-|&k=ra-?xwp8nF-}vf&CL|GZsdf`7Sjw|CKvjy~7eG)#$H#+54Z55ZuNt=6Nh z)WnzT7)Q2E&3Dm$S>x1i^8odb#Rg-D(7jzb+laTb53VQkp-p^BqSrQj{XZP7oAu96 zS^w%c!J;8&+v!C;v!5dJ^&SiV0hEaF@CUpVZ89+>CMS)Pd1UO$LQ9D33^!iWU|k%>lJ3wnzHrm zTTJ^*e&bQmh(|Ynd*xp)NcenyYwHtjF1tRxMOdlc;)+Ft@~Tvaa^hvnA<~Q{rfgAy z`k)GR6F;uP%dtYL6gv|@ucgpQbt@|#$ho(@f&RPMcVVUZ%%Q`sAaK>D7qYsOP}=n? z_;Wve^X?jYI{tbsn)pCuA)-;76;c`74%8;Xz3z4J9mjFb*Wrm}8#@#31m6ao$F85@ zPo>r7sAd&Cz;E7#Fi$pVk;4sWDPL2KIf7@TN2)`6x?TgpP;f)k=+R~~L2#2)6Tfs1 zmpO8A960G$FS&+Xl$ik3dYa8ed57?ZfA#g(;!f}B=~>J?>u4K#9F1u}RxI+~vBqum zSSO$h_U566b;p`vo4%gNnWA?ww$hK|zp9xTrAB;cnt1QS8}RgJ@P0{rwa2}F@o>+& zI(;L9rRoe{^JsUb4$VVw-s1OF@rsVfNKx!Dc&g3dD?X zyZ)-5qV!;Ik6zdV7}lSoQyw-r-aCS8r?*?Hf9Qy*&$Q`VT`Om=PrrmRY!qL@8=qoW zq5UrJM-Fdvv@3n|&x>3}-x#H0UP3v;m2^$uu}PAG2UH;Tid_&D!sAzQiPjQoZi#o% z1~;k*HKSUzB!{j{yI!_)%h2B)W~>GYC_jeZn*AReoVw^!B|ypi8$>E~3LDUa2=v9` z!{}3KLN>(92LFt+xfG}^#yLLghTzg}xTG9})Sr7O!-7EbJXML|rM56dWH#xZiu9BI zJx8Z^78K4{g|E|E<77b2FHPXOWd#?__~LdD#N~I5 zXp0@8sM0x+_FnH@58>uOk2Pw^%6fr0-j_3NP(3Z2egCHfgUiz!ad#!y&(zxaJ*lb> ztFczTkwMsL>@it}PU9FPWFwG&n1k_W34T4s@6qOIl%+Gvy7$qR4NsE*_l_q+exi{4 z5cpjkfqhXB@u#);!ACjG%%Y~D>WAF`%8X6d0ekNrAa^`JLuGwM_3sI&K{!B}as@NE z>>pV6){&5akx^iE#km`PY<1y_)S5LR2cWCUZhfYE{6 zr_43QY3P()&5^1tr%iV2d<5j`Oq>5Dm*2{tw_g8=s>{%Oj_vT8jyz{cX3I0~b%1tw z9RKL8$bmqgHH0;wfK~&!8P?YxfnvMd7fE0c&^*c&$U2G{MbgYkG$R$|49Lc$7 z`tRz4+1+6~%T=4R-+ce;2aj~z9CJ!#-jL?LW5@neSXa#A>dQIEBd@HgTQSaKeerS6 zo>o;|&Sc*_^|{(JuWZdS$_nSmIX5%PKGFjz?}MVI8#-*fNU}*-?J`Bk&9Plx)E$HQ z(EF_Bv-7);^UuFd2fiXJ&s6y%;@@E1dD;{_Hi=oow3RuVmL5Tz5i>=gR5D7 zXHnxS{bDP*HaL*1k-ko4!uznz$am`nVWxYcS>Q%MBm%37%)%LExVe|zUme48-KF9m zW~8&H1DVzm=N$QJ&OfFGVC>2BVBLUA3!wk<$TDneG>w;;bO1G_}Y}& zmqkEWXA=75?#npTx^-VJB-+q=)!WU82I@9_OZzrb{LDVz`9af(YVoBFuu^DlzILK$ zq#PB$bOhGv*6a2B_oc=IiFzZNO8J99^@J3x>0Srf7Ed5hH0k&9w(f$VU=*bH8gtW+$S@*}Nl~t@4uzZR%*NZhOQ9_3*(386BV2_u^ zR;Qv||7qpKHRnjVS5|Y<&N5^fjg2XY5kYT6-}xh36Rz|mUu zYLrvu%WTgfXz3@8&@soE&q4xI+8e*>`inTI=+UX3(A;RBH~wBlje?dPzL;xfFPVl~ z{l07#-bQ{-`6vd0M~*QG`mAkyAJiB>j8tjzK4&{CZ&jNsvw6?lDRES?++p9tmv4C3SyL#kmo@HS_8qLWmLSxm@WiMDNNd_noBjo>9%%b@RmcB6ANEu^9icyh{HS|0^R$3{JX({3aTvC#4Q8-ADwG+m| zAj#PjnJuYPs&7*p`<@U%)$}5EZuJ*7v6-@OoZFZbU&&zI;5e7TE^=<^%Ca@0wFx@f ztA2%hcibY$hr{{z{%u?A()zfJ#WP-Nzf;ADbleayJ79%VPx4)n&urC+d*{#j$Lg?A zNm?Yo>(lN=2ys0;`d(}Iy~CDQ_QzXbtt&%0R?jg4CVx|lx~}}IhjReDUvk~V>5b`= z)(A9jK-Q8yq8KOlT~~3tpjqY`T^)G0zy4fHuUsg zvfMsFKjrk875*z}?M7^OvW2I%GRfP9e(z$GR$iArT()BrDEUN^TbYd!en>Td(M{f_ zsuqB~4Lf~_zxhCv=tTw#hkRs?)`GtKn1YID=1r5R!dsrdlDIy1M4)AzevW?p25FR+ z$3+Fo_Q6bjMnZ0{8pXzY<=@Ki8y}zO5v5(x^MLS1wsg>3?_fQ| zKJbX)E{?Uwchq5V)!xK^VQ$e}`(>v2L-qN`^a3->o#{$hpCB|znuPEkE_LR8G9 zf)j~VAK%->1^MdKjUj5gIvpL8ve&9#XIz+YuhYc zW;e7SpcFdiq)MZN*X+Cghg`Ow09%8Xj*0xduy$(p4+0Y8AB*~ePRTI4$7y=X*H*D7 zT@>8StkXXBKI?D8xUeV3rmr(?Y9kf`eq3HOqNs@+Zr79 zD&2jHZ1tc+JOeFp46N}OUiKaT5lUD+HXI?h5WJ)6j4zYa!26J$sGkm3Pr_~kh$Ae>c5O!O>I&-`EDTS`BGh*K9z6I#gYbD8zfOD583+mcr@ z@j3#JXVc_O&Yx-?oYkV{M1frV`%(2qAqgG!lTgyHJmu}4927L{$r^!F#2hzwJ{v2+ zSZ9@uc)A!7h7Vg~c7WD)IE#<5?z{!3H7U7!rC8&yKIUG%20u!gApIPto65I+3KOx03ptY(>7(*S+|{`0kC$QZTH30xV$iTN(E{@~6g%hy!W1o#~%uJ3-6 z310L*d&Kv)U(mSM5G(spzeTQ5NzeD^r9?iv1TK(kgi4aLPh*xBB>MK{FGMPi6mFjS zb?Kl*aw&;=5ifZV*>@d0)%F}WKLX~YHH$*r3F@{`>&f-08)aj6zOG$=#8ScroQqAr zDl$MF-|ggs8okPBOzG4A*!8&x0;vPmTAi33iJ}t*qE$}?UqGL{t-9$RW#2I~2NmXl zZYji|n3hS$s3Sx-7k|c=W_L)<|6cUR)94hUc<#};46ZtOpOibF_8CP;jOL?`bi72Mb|?$o+)c+oB0X%h@}D!_fJ*`)OB>>9rd z2MtU#*`1;6R3R)%6t`ZC5bb{YSKk^Z{Y%99rt>e1bB4QSCu%>YN7Pc zcve2hu!K05W8d(V|DkfvgNrz68_Hi9=h5x&s6Vw=Kl=VE5%jN6se}q&UpOuTPhtWO zJbIG>bUFV?A)}N^gzp@iYd!g9dsd}jIH0&zZ($6Y9DUCRE(NG#oEeKpxa#%TR-eN< z{yMd$L)XYjO-fhgF-sRrd?LRrqv8NH9Bk?PZOh?&;*n%haT{c-y(VLGEOf@f?fas94NbJI}<6kqtr!E|K3iJZ>30G8|H~dPr?mib(Tw;1p*H2LL?VC$3u9p)nL8@`9dF%k_+;xDv(fBQ)eLE$@i!SRzIkErr)84e?eiKHe~BG*4(@#s4VzXNXpPV6Y` z>^H0_H7Y!Zu9Yj^xxP~5FjjPt9lj*eXT<(kSE(OpoW;(QK!fqevoA2zyB|0Mz<0Q5Mc&c;pXX zu08qG4s3JeF`QP$9;$lS_x_)^umHB~6}S1b(TA`4K4h_8HO(oSlV}_X8x*s!fQ(D! zC@OXXN`D@PJOax@f~eT<&)}n%3{>`qd8^L`tcfW=!0~o{AtyFecwgP$3!)@Xir*g4 zyqq=8Lc5%u7_heCm_vKa`Z?g)8^2r3f?sC}bR4;V1o8TqS)vc>1HD>r58Mna7vcWF zAnjtdPr@C4jDI90%Q6%gN3bYfIB7^-4sw4~(~vfpkuFbvLzJf32xy%NoLoqEz&f09 zd?F6IDzt6wYLg{QbMn-PY&El>19@=Nvz-XYVyrA>oMjm+7KkHl}O|7du3h)do9 zf2wovW7VbUfpX7AAHu=-9ISZPitz!U-{!ikBM>BVy=H5ZmBy39sy8^*YYU@c$<#zdE)D`85numwMTu1fuj;4IQmDb zZmbDR$0yUP?)fA3IBMA4kyoouxy_ylIGY9Mn)pGYu155}VbW+8`~<1Mnr#H`Y;PP2 z9juRnjjDl@0a~lo(_1T7ch31Ew%0Ck{T7%qBr&5QCtcne_@B+XX-K(NmfFU;iZ!d@ zt=%z#%);CC_X*E5CZh80Mp6tF=IPQaql}c^WG+)5@wXjpCL*Ye_#aG6Jii}pFq4zB z_%>Wyr51FSeAWFc!g435JpKq3!tR9iVU14EkI{m6N}9J;tkjnRdTy4YM$onFoXE`e zA1xCC&!Tk#4Bc&k@b)s))wkv2zzS-8uKb@pWEVU0SOk11h^h(E>RnyrG#o>gstA+Q zrjx&lvrnov6RuoV?^0a{V!ey@plH|w%g>{=l;8m34S{ivsdqSQt$`Iru@%ZA`*v9A zBa*0dQlRH^@7a^W7^bxJiKndHP+2%dq=}*4<*YCm#+wC6cAgQLqv!q{GjeRMU>k1T z#TvUpqj67%)b%l!$T1E?p&nuUlz5d;9pil2F7KbRlGV4ZQ95s|L!zpdBkUgd^)nhR zSzZ}91nerHVXue@3JY`$C3J~VuzsgST`zv-W2tMX;!~M-=`&lb{W^lc@Be6-)Eagq zV`v_Kdpvz4gu*BWiqnU6y0~Lu=cL}Q|ACO-@u-I=hxAkWceBmIO~s!D{GL_)g}ONx zTBMy@D!DDQT5qSTbwA1uQe(Fd@;C#YoOq^9lAjAhSj0_=*(7dbRg&Qkcz8wJYY9K; zDbrM44)$0_*_uB>Vz!Sk3dZ_RpL;WXf&ROlG#hhq9JUSRhXTdTgK^}S?f3|K9V5nrQn!Zs>q)hCJ+yO=&t0p7HOQ=fRQ#Fyg2uwBYX@H+^RM+-te?Hr zjW(b6%Z%dI$JG2XSV5JF$e6^x#+&By3Cw}GXWD420i36ntfvi^NmN98Be$qykc}tr zH(^is?-w62MyG%8K`)h$jf9+V%q_We6*7s+Dwj4B(G0Z`Y`%3pS`XkE)Yveb>GS%4 ztb9H=?(L-j#|6qZ=2lH4L$=YJLMb8IW9Y(1@0;vOt2>${+aLpBU&LaM-5LFyBJ!9# zfkByibkoDv7hVi5q#=(TmL-wdOA=m$6LzkG3234qYdO9o2Yn9idNt;UF}P z3^n`yr14C+VBz3E{siBqVp+;)NJ;72zTZDab1ZA^T8>1wsSk`8C<0R8Zj2vmgSPxa zva9k$a(Uw(|2&BlXoylE)5(^%z2`+?b#u(S!0&07v!L7zX;W3*JqNWZ7)DB(U&x)&p>1Yb zW>iK3(`ltv6YodbmpGguPi4O0#u%W;%{)<_?g0S@S91mhVlV-<=`*Mctja!`cjuI^ zd*oPaJ8%9-5gOlUl^8P)-84}eIBz*liHtY*!*6vq)AspO$uuHyP-6Z#h0$@}4Jof2 z+J2r_Q<`8v^O+Id^~=1EQ2A@+U9BIJ#{K&q>&{gQ<868p@W)cA*Zn&D=0qQz2K@eh z4U+9)-oKjgt~}Hhlk$qyQhj zdh53D0Y$+BVZ3tO;yfmO(SsQ(za8eZ-{~OoPkv+nglW?crkv=i_ObdxLl7xll&;%o zq;qL{V66^9-n{1jMDpLQ>mD6Xw#zkI^=p~d0afg0_eqrT8@+!}>x1@E%Fe<38nh6| z08p`xyizq2;$Yc|%iDElXHfj4{qWV{m7(=|EQa8V98RCPzYAEQr|GzKiwWw|-g0Hj zPU0>!Ve7moIqlSPp{af*&FFyVas7JL@;y==7D9l?z$Kv3LEXt2OESV-GC^`qvf+uW}$_DV%UlgnY#- zq0Bd&7>5TEFIG`ISiNSmb%9Ynl6eo78}P@#%*?ter`ql#+m4>F-L=i>-p|}>j{(-&IG!4KSO(QXZWQbbSD5pN3ASrafm6XnYo9MXXGH;lkKk8aJRZK;bl8e z@5~y>Uo|@Of=}~{a{9Nz=?WMXg5Vwix=+o!B2;S9?8QGb8%<8@fF>L~mknGix9sym zOryG}m&$IVt}C_85DS|FAh{5+w_CDm(rT69q3%t;=OdzOMmjtpl(;fA4>a*n*DB2f zKAx6F7Cmy!#qhVhyNiK?pK&d zZI6{2$-J%@oBN>dei1HFO3aC(Fka>BJUZxcT4A(EGBw*3etrtXx>w>mlppBqKy??YU2a-QnF+~Q(60G4(UO0D*06r(EY2R|4P%kQ|3u( zO?t-q9S$+uhsqp6Eoa~pA@`Kfu&zb1Qo=MUW*I@sqMX{mmt9c(am`3{;0T=@Vk3R0prQoFhj3gko()-q# ze_Z1iv8k2p_}iAdi*+o9we>1RcAxKJByC-8I+9fi=UI=@RTTgCS&~Y+5)F0HUKAbP z>z;TEdbR9$k8m-N1%!ZN1-%-FSX5lLcx+(|KtaKFp^~P%K(=St=;)8NS9qC=e^^KQ zVvE`DBX54JAt3#a*r8SuV3qPfTJyaTvnH)4C0Hq%lyeo$@e9aO3+uq2+Xenz-{aNf z$kdD$`H`8dDkxHK-PO5;Cb~J#Z^YQ^rx$L;}}J-Pua zM>mO?P*dAeht_Wp|Kkq*G5U*JN{f!lipvZ5(?{F|ryZy4Bd6-B8W)P$SiMy?lna~o zv7NB1)w#^^3*t_ET3Cy$EN#UosdUu1z`5|?Lii&*pf2x zbHzQiz4ZQJ@BT~L%@O!sf4nIV5MO3wP)?m&`Uz@+ri97*iC5^Y^j|iv@JKJ;iU+q6 z_kvbr9Fxu`O%!S5B3w2=-D=M3Vc0q#Hzf(k3GrRNksUWNmSPo)(t5l$^3N?dlvsgoapMF1NBCKU`hQ5Gu)1O_P(f_ZKPIW2+79x+iBr ziO2x_5cx~2RvW92w~A+dlebADkIVBD8Fxj3c%GwvP<(fnylzo^wTa2#z5zZF%h3J~ zC{6V-Pj-cv*NzwMO^^4<`!ijw0n&-XzKFfCnt*W|auOsc^#FHM5=9gb?CpxdqBVa; zEWE~}5+o zTCl6rAUT98on5AjmkX=c0IjwDCyqt)wdT@jrvH>6JOlt!HXBc=CF+BB5D*{Y&$P3h zpkn12g8g}v7*3HO{`Ot>r|7kN3UmI*?-aaZs)rspzQ1ct`tb+LfYBQM1r6IZ#j5TU zm`K5=cA=I$sMr|bUmts&xqJSEOy`KZW4$~PYi^WxQUsi(nv93sJU~4fXea$T(|spI zHTgiEg1?4lx?Bif#iw?l;z2vzc+HNu+P1|kItW<=WIW|iM3X7jx`*b&aem``iktI5 zFT1E%K&gOg5!hY%kEAtGf17ERJ8%npb=)Fr(t#d~lKBLM#Dj!IRCxNZO6zl zB5nfF_4R!ORX6zJwIdktVm7srcqN8E*QaHb2Ff4wju zjvFDMGN1Ox<>6>1TLX(SYf8*K5%m^QXM8I95NY4P4=63N%389dg2HQ|0Dsu6MvmPt z|0^0eE{*gm2S0c3Y8xKgRUJ_msvdJPP@n zUHwEaim63LV;*3d)%gM_F*T#ZM!_dON*!I|dZqCJymsf#mvL70fMYV?rH}a*;y->P}V&c_&VM=EbeRt<2gel7)fX<|Dzgfi2#AXL! g(u)F^{(rwi=5Sz&aD59nfAq(_+Yhw!G_BtJKYm0x(f|Me literal 0 HcmV?d00001 diff --git a/0.6.0/assets/javascripts/bundle.af256bd8.min.js b/0.6.0/assets/javascripts/bundle.af256bd8.min.js new file mode 100644 index 0000000..27355d2 --- /dev/null +++ b/0.6.0/assets/javascripts/bundle.af256bd8.min.js @@ -0,0 +1,29 @@ +"use strict";(()=>{var ji=Object.create;var gr=Object.defineProperty;var Wi=Object.getOwnPropertyDescriptor;var Ui=Object.getOwnPropertyNames,Vt=Object.getOwnPropertySymbols,Di=Object.getPrototypeOf,xr=Object.prototype.hasOwnProperty,io=Object.prototype.propertyIsEnumerable;var no=(e,t,r)=>t in e?gr(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,$=(e,t)=>{for(var r in t||(t={}))xr.call(t,r)&&no(e,r,t[r]);if(Vt)for(var r of Vt(t))io.call(t,r)&&no(e,r,t[r]);return e};var ao=(e,t)=>{var r={};for(var o in e)xr.call(e,o)&&t.indexOf(o)<0&&(r[o]=e[o]);if(e!=null&&Vt)for(var o of Vt(e))t.indexOf(o)<0&&io.call(e,o)&&(r[o]=e[o]);return r};var yr=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports);var Vi=(e,t,r,o)=>{if(t&&typeof t=="object"||typeof t=="function")for(let n of Ui(t))!xr.call(e,n)&&n!==r&&gr(e,n,{get:()=>t[n],enumerable:!(o=Wi(t,n))||o.enumerable});return e};var Lt=(e,t,r)=>(r=e!=null?ji(Di(e)):{},Vi(t||!e||!e.__esModule?gr(r,"default",{value:e,enumerable:!0}):r,e));var so=(e,t,r)=>new Promise((o,n)=>{var i=p=>{try{s(r.next(p))}catch(c){n(c)}},a=p=>{try{s(r.throw(p))}catch(c){n(c)}},s=p=>p.done?o(p.value):Promise.resolve(p.value).then(i,a);s((r=r.apply(e,t)).next())});var po=yr((Er,co)=>{(function(e,t){typeof Er=="object"&&typeof co!="undefined"?t():typeof define=="function"&&define.amd?define(t):t()})(Er,function(){"use strict";function e(r){var o=!0,n=!1,i=null,a={text:!0,search:!0,url:!0,tel:!0,email:!0,password:!0,number:!0,date:!0,month:!0,week:!0,time:!0,datetime:!0,"datetime-local":!0};function s(H){return!!(H&&H!==document&&H.nodeName!=="HTML"&&H.nodeName!=="BODY"&&"classList"in H&&"contains"in H.classList)}function p(H){var ft=H.type,qe=H.tagName;return!!(qe==="INPUT"&&a[ft]&&!H.readOnly||qe==="TEXTAREA"&&!H.readOnly||H.isContentEditable)}function c(H){H.classList.contains("focus-visible")||(H.classList.add("focus-visible"),H.setAttribute("data-focus-visible-added",""))}function l(H){H.hasAttribute("data-focus-visible-added")&&(H.classList.remove("focus-visible"),H.removeAttribute("data-focus-visible-added"))}function f(H){H.metaKey||H.altKey||H.ctrlKey||(s(r.activeElement)&&c(r.activeElement),o=!0)}function u(H){o=!1}function h(H){s(H.target)&&(o||p(H.target))&&c(H.target)}function w(H){s(H.target)&&(H.target.classList.contains("focus-visible")||H.target.hasAttribute("data-focus-visible-added"))&&(n=!0,window.clearTimeout(i),i=window.setTimeout(function(){n=!1},100),l(H.target))}function A(H){document.visibilityState==="hidden"&&(n&&(o=!0),te())}function te(){document.addEventListener("mousemove",J),document.addEventListener("mousedown",J),document.addEventListener("mouseup",J),document.addEventListener("pointermove",J),document.addEventListener("pointerdown",J),document.addEventListener("pointerup",J),document.addEventListener("touchmove",J),document.addEventListener("touchstart",J),document.addEventListener("touchend",J)}function ie(){document.removeEventListener("mousemove",J),document.removeEventListener("mousedown",J),document.removeEventListener("mouseup",J),document.removeEventListener("pointermove",J),document.removeEventListener("pointerdown",J),document.removeEventListener("pointerup",J),document.removeEventListener("touchmove",J),document.removeEventListener("touchstart",J),document.removeEventListener("touchend",J)}function J(H){H.target.nodeName&&H.target.nodeName.toLowerCase()==="html"||(o=!1,ie())}document.addEventListener("keydown",f,!0),document.addEventListener("mousedown",u,!0),document.addEventListener("pointerdown",u,!0),document.addEventListener("touchstart",u,!0),document.addEventListener("visibilitychange",A,!0),te(),r.addEventListener("focus",h,!0),r.addEventListener("blur",w,!0),r.nodeType===Node.DOCUMENT_FRAGMENT_NODE&&r.host?r.host.setAttribute("data-js-focus-visible",""):r.nodeType===Node.DOCUMENT_NODE&&(document.documentElement.classList.add("js-focus-visible"),document.documentElement.setAttribute("data-js-focus-visible",""))}if(typeof window!="undefined"&&typeof document!="undefined"){window.applyFocusVisiblePolyfill=e;var t;try{t=new CustomEvent("focus-visible-polyfill-ready")}catch(r){t=document.createEvent("CustomEvent"),t.initCustomEvent("focus-visible-polyfill-ready",!1,!1,{})}window.dispatchEvent(t)}typeof document!="undefined"&&e(document)})});var qr=yr((lx,Sn)=>{"use strict";/*! + * escape-html + * Copyright(c) 2012-2013 TJ Holowaychuk + * Copyright(c) 2015 Andreas Lubbe + * Copyright(c) 2015 Tiancheng "Timothy" Gu + * MIT Licensed + */var Ha=/["'&<>]/;Sn.exports=ka;function ka(e){var t=""+e,r=Ha.exec(t);if(!r)return t;var o,n="",i=0,a=0;for(i=r.index;i{/*! + * clipboard.js v2.0.11 + * https://clipboardjs.com/ + * + * Licensed MIT © Zeno Rocha + */(function(t,r){typeof It=="object"&&typeof Yr=="object"?Yr.exports=r():typeof define=="function"&&define.amd?define([],r):typeof It=="object"?It.ClipboardJS=r():t.ClipboardJS=r()})(It,function(){return function(){var e={686:function(o,n,i){"use strict";i.d(n,{default:function(){return Fi}});var a=i(279),s=i.n(a),p=i(370),c=i.n(p),l=i(817),f=i.n(l);function u(V){try{return document.execCommand(V)}catch(_){return!1}}var h=function(_){var M=f()(_);return u("cut"),M},w=h;function A(V){var _=document.documentElement.getAttribute("dir")==="rtl",M=document.createElement("textarea");M.style.fontSize="12pt",M.style.border="0",M.style.padding="0",M.style.margin="0",M.style.position="absolute",M.style[_?"right":"left"]="-9999px";var j=window.pageYOffset||document.documentElement.scrollTop;return M.style.top="".concat(j,"px"),M.setAttribute("readonly",""),M.value=V,M}var te=function(_,M){var j=A(_);M.container.appendChild(j);var D=f()(j);return u("copy"),j.remove(),D},ie=function(_){var M=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{container:document.body},j="";return typeof _=="string"?j=te(_,M):_ instanceof HTMLInputElement&&!["text","search","url","tel","password"].includes(_==null?void 0:_.type)?j=te(_.value,M):(j=f()(_),u("copy")),j},J=ie;function H(V){"@babel/helpers - typeof";return typeof Symbol=="function"&&typeof Symbol.iterator=="symbol"?H=function(M){return typeof M}:H=function(M){return M&&typeof Symbol=="function"&&M.constructor===Symbol&&M!==Symbol.prototype?"symbol":typeof M},H(V)}var ft=function(){var _=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},M=_.action,j=M===void 0?"copy":M,D=_.container,Y=_.target,$e=_.text;if(j!=="copy"&&j!=="cut")throw new Error('Invalid "action" value, use either "copy" or "cut"');if(Y!==void 0)if(Y&&H(Y)==="object"&&Y.nodeType===1){if(j==="copy"&&Y.hasAttribute("disabled"))throw new Error('Invalid "target" attribute. Please use "readonly" instead of "disabled" attribute');if(j==="cut"&&(Y.hasAttribute("readonly")||Y.hasAttribute("disabled")))throw new Error(`Invalid "target" attribute. You can't cut text from elements with "readonly" or "disabled" attributes`)}else throw new Error('Invalid "target" value, use a valid Element');if($e)return J($e,{container:D});if(Y)return j==="cut"?w(Y):J(Y,{container:D})},qe=ft;function je(V){"@babel/helpers - typeof";return typeof Symbol=="function"&&typeof Symbol.iterator=="symbol"?je=function(M){return typeof M}:je=function(M){return M&&typeof Symbol=="function"&&M.constructor===Symbol&&M!==Symbol.prototype?"symbol":typeof M},je(V)}function Ai(V,_){if(!(V instanceof _))throw new TypeError("Cannot call a class as a function")}function oo(V,_){for(var M=0;M<_.length;M++){var j=_[M];j.enumerable=j.enumerable||!1,j.configurable=!0,"value"in j&&(j.writable=!0),Object.defineProperty(V,j.key,j)}}function Ci(V,_,M){return _&&oo(V.prototype,_),M&&oo(V,M),V}function Hi(V,_){if(typeof _!="function"&&_!==null)throw new TypeError("Super expression must either be null or a function");V.prototype=Object.create(_&&_.prototype,{constructor:{value:V,writable:!0,configurable:!0}}),_&&br(V,_)}function br(V,_){return br=Object.setPrototypeOf||function(j,D){return j.__proto__=D,j},br(V,_)}function ki(V){var _=Ri();return function(){var j=Ut(V),D;if(_){var Y=Ut(this).constructor;D=Reflect.construct(j,arguments,Y)}else D=j.apply(this,arguments);return $i(this,D)}}function $i(V,_){return _&&(je(_)==="object"||typeof _=="function")?_:Pi(V)}function Pi(V){if(V===void 0)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return V}function Ri(){if(typeof Reflect=="undefined"||!Reflect.construct||Reflect.construct.sham)return!1;if(typeof Proxy=="function")return!0;try{return Date.prototype.toString.call(Reflect.construct(Date,[],function(){})),!0}catch(V){return!1}}function Ut(V){return Ut=Object.setPrototypeOf?Object.getPrototypeOf:function(M){return M.__proto__||Object.getPrototypeOf(M)},Ut(V)}function vr(V,_){var M="data-clipboard-".concat(V);if(_.hasAttribute(M))return _.getAttribute(M)}var Ii=function(V){Hi(M,V);var _=ki(M);function M(j,D){var Y;return Ai(this,M),Y=_.call(this),Y.resolveOptions(D),Y.listenClick(j),Y}return Ci(M,[{key:"resolveOptions",value:function(){var D=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};this.action=typeof D.action=="function"?D.action:this.defaultAction,this.target=typeof D.target=="function"?D.target:this.defaultTarget,this.text=typeof D.text=="function"?D.text:this.defaultText,this.container=je(D.container)==="object"?D.container:document.body}},{key:"listenClick",value:function(D){var Y=this;this.listener=c()(D,"click",function($e){return Y.onClick($e)})}},{key:"onClick",value:function(D){var Y=D.delegateTarget||D.currentTarget,$e=this.action(Y)||"copy",Dt=qe({action:$e,container:this.container,target:this.target(Y),text:this.text(Y)});this.emit(Dt?"success":"error",{action:$e,text:Dt,trigger:Y,clearSelection:function(){Y&&Y.focus(),window.getSelection().removeAllRanges()}})}},{key:"defaultAction",value:function(D){return vr("action",D)}},{key:"defaultTarget",value:function(D){var Y=vr("target",D);if(Y)return document.querySelector(Y)}},{key:"defaultText",value:function(D){return vr("text",D)}},{key:"destroy",value:function(){this.listener.destroy()}}],[{key:"copy",value:function(D){var Y=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{container:document.body};return J(D,Y)}},{key:"cut",value:function(D){return w(D)}},{key:"isSupported",value:function(){var D=arguments.length>0&&arguments[0]!==void 0?arguments[0]:["copy","cut"],Y=typeof D=="string"?[D]:D,$e=!!document.queryCommandSupported;return Y.forEach(function(Dt){$e=$e&&!!document.queryCommandSupported(Dt)}),$e}}]),M}(s()),Fi=Ii},828:function(o){var n=9;if(typeof Element!="undefined"&&!Element.prototype.matches){var i=Element.prototype;i.matches=i.matchesSelector||i.mozMatchesSelector||i.msMatchesSelector||i.oMatchesSelector||i.webkitMatchesSelector}function a(s,p){for(;s&&s.nodeType!==n;){if(typeof s.matches=="function"&&s.matches(p))return s;s=s.parentNode}}o.exports=a},438:function(o,n,i){var a=i(828);function s(l,f,u,h,w){var A=c.apply(this,arguments);return l.addEventListener(u,A,w),{destroy:function(){l.removeEventListener(u,A,w)}}}function p(l,f,u,h,w){return typeof l.addEventListener=="function"?s.apply(null,arguments):typeof u=="function"?s.bind(null,document).apply(null,arguments):(typeof l=="string"&&(l=document.querySelectorAll(l)),Array.prototype.map.call(l,function(A){return s(A,f,u,h,w)}))}function c(l,f,u,h){return function(w){w.delegateTarget=a(w.target,f),w.delegateTarget&&h.call(l,w)}}o.exports=p},879:function(o,n){n.node=function(i){return i!==void 0&&i instanceof HTMLElement&&i.nodeType===1},n.nodeList=function(i){var a=Object.prototype.toString.call(i);return i!==void 0&&(a==="[object NodeList]"||a==="[object HTMLCollection]")&&"length"in i&&(i.length===0||n.node(i[0]))},n.string=function(i){return typeof i=="string"||i instanceof String},n.fn=function(i){var a=Object.prototype.toString.call(i);return a==="[object Function]"}},370:function(o,n,i){var a=i(879),s=i(438);function p(u,h,w){if(!u&&!h&&!w)throw new Error("Missing required arguments");if(!a.string(h))throw new TypeError("Second argument must be a String");if(!a.fn(w))throw new TypeError("Third argument must be a Function");if(a.node(u))return c(u,h,w);if(a.nodeList(u))return l(u,h,w);if(a.string(u))return f(u,h,w);throw new TypeError("First argument must be a String, HTMLElement, HTMLCollection, or NodeList")}function c(u,h,w){return u.addEventListener(h,w),{destroy:function(){u.removeEventListener(h,w)}}}function l(u,h,w){return Array.prototype.forEach.call(u,function(A){A.addEventListener(h,w)}),{destroy:function(){Array.prototype.forEach.call(u,function(A){A.removeEventListener(h,w)})}}}function f(u,h,w){return s(document.body,u,h,w)}o.exports=p},817:function(o){function n(i){var a;if(i.nodeName==="SELECT")i.focus(),a=i.value;else if(i.nodeName==="INPUT"||i.nodeName==="TEXTAREA"){var s=i.hasAttribute("readonly");s||i.setAttribute("readonly",""),i.select(),i.setSelectionRange(0,i.value.length),s||i.removeAttribute("readonly"),a=i.value}else{i.hasAttribute("contenteditable")&&i.focus();var p=window.getSelection(),c=document.createRange();c.selectNodeContents(i),p.removeAllRanges(),p.addRange(c),a=p.toString()}return a}o.exports=n},279:function(o){function n(){}n.prototype={on:function(i,a,s){var p=this.e||(this.e={});return(p[i]||(p[i]=[])).push({fn:a,ctx:s}),this},once:function(i,a,s){var p=this;function c(){p.off(i,c),a.apply(s,arguments)}return c._=a,this.on(i,c,s)},emit:function(i){var a=[].slice.call(arguments,1),s=((this.e||(this.e={}))[i]||[]).slice(),p=0,c=s.length;for(p;p0&&i[i.length-1])&&(c[0]===6||c[0]===2)){r=0;continue}if(c[0]===3&&(!i||c[1]>i[0]&&c[1]=e.length&&(e=void 0),{value:e&&e[o++],done:!e}}};throw new TypeError(t?"Object is not iterable.":"Symbol.iterator is not defined.")}function N(e,t){var r=typeof Symbol=="function"&&e[Symbol.iterator];if(!r)return e;var o=r.call(e),n,i=[],a;try{for(;(t===void 0||t-- >0)&&!(n=o.next()).done;)i.push(n.value)}catch(s){a={error:s}}finally{try{n&&!n.done&&(r=o.return)&&r.call(o)}finally{if(a)throw a.error}}return i}function q(e,t,r){if(r||arguments.length===2)for(var o=0,n=t.length,i;o1||s(u,h)})})}function s(u,h){try{p(o[u](h))}catch(w){f(i[0][3],w)}}function p(u){u.value instanceof nt?Promise.resolve(u.value.v).then(c,l):f(i[0][2],u)}function c(u){s("next",u)}function l(u){s("throw",u)}function f(u,h){u(h),i.shift(),i.length&&s(i[0][0],i[0][1])}}function fo(e){if(!Symbol.asyncIterator)throw new TypeError("Symbol.asyncIterator is not defined.");var t=e[Symbol.asyncIterator],r;return t?t.call(e):(e=typeof he=="function"?he(e):e[Symbol.iterator](),r={},o("next"),o("throw"),o("return"),r[Symbol.asyncIterator]=function(){return this},r);function o(i){r[i]=e[i]&&function(a){return new Promise(function(s,p){a=e[i](a),n(s,p,a.done,a.value)})}}function n(i,a,s,p){Promise.resolve(p).then(function(c){i({value:c,done:s})},a)}}function k(e){return typeof e=="function"}function ut(e){var t=function(o){Error.call(o),o.stack=new Error().stack},r=e(t);return r.prototype=Object.create(Error.prototype),r.prototype.constructor=r,r}var zt=ut(function(e){return function(r){e(this),this.message=r?r.length+` errors occurred during unsubscription: +`+r.map(function(o,n){return n+1+") "+o.toString()}).join(` + `):"",this.name="UnsubscriptionError",this.errors=r}});function Qe(e,t){if(e){var r=e.indexOf(t);0<=r&&e.splice(r,1)}}var We=function(){function e(t){this.initialTeardown=t,this.closed=!1,this._parentage=null,this._finalizers=null}return e.prototype.unsubscribe=function(){var t,r,o,n,i;if(!this.closed){this.closed=!0;var a=this._parentage;if(a)if(this._parentage=null,Array.isArray(a))try{for(var s=he(a),p=s.next();!p.done;p=s.next()){var c=p.value;c.remove(this)}}catch(A){t={error:A}}finally{try{p&&!p.done&&(r=s.return)&&r.call(s)}finally{if(t)throw t.error}}else a.remove(this);var l=this.initialTeardown;if(k(l))try{l()}catch(A){i=A instanceof zt?A.errors:[A]}var f=this._finalizers;if(f){this._finalizers=null;try{for(var u=he(f),h=u.next();!h.done;h=u.next()){var w=h.value;try{uo(w)}catch(A){i=i!=null?i:[],A instanceof zt?i=q(q([],N(i)),N(A.errors)):i.push(A)}}}catch(A){o={error:A}}finally{try{h&&!h.done&&(n=u.return)&&n.call(u)}finally{if(o)throw o.error}}}if(i)throw new zt(i)}},e.prototype.add=function(t){var r;if(t&&t!==this)if(this.closed)uo(t);else{if(t instanceof e){if(t.closed||t._hasParent(this))return;t._addParent(this)}(this._finalizers=(r=this._finalizers)!==null&&r!==void 0?r:[]).push(t)}},e.prototype._hasParent=function(t){var r=this._parentage;return r===t||Array.isArray(r)&&r.includes(t)},e.prototype._addParent=function(t){var r=this._parentage;this._parentage=Array.isArray(r)?(r.push(t),r):r?[r,t]:t},e.prototype._removeParent=function(t){var r=this._parentage;r===t?this._parentage=null:Array.isArray(r)&&Qe(r,t)},e.prototype.remove=function(t){var r=this._finalizers;r&&Qe(r,t),t instanceof e&&t._removeParent(this)},e.EMPTY=function(){var t=new e;return t.closed=!0,t}(),e}();var Tr=We.EMPTY;function qt(e){return e instanceof We||e&&"closed"in e&&k(e.remove)&&k(e.add)&&k(e.unsubscribe)}function uo(e){k(e)?e():e.unsubscribe()}var Pe={onUnhandledError:null,onStoppedNotification:null,Promise:void 0,useDeprecatedSynchronousErrorHandling:!1,useDeprecatedNextContext:!1};var dt={setTimeout:function(e,t){for(var r=[],o=2;o0},enumerable:!1,configurable:!0}),t.prototype._trySubscribe=function(r){return this._throwIfClosed(),e.prototype._trySubscribe.call(this,r)},t.prototype._subscribe=function(r){return this._throwIfClosed(),this._checkFinalizedStatuses(r),this._innerSubscribe(r)},t.prototype._innerSubscribe=function(r){var o=this,n=this,i=n.hasError,a=n.isStopped,s=n.observers;return i||a?Tr:(this.currentObservers=null,s.push(r),new We(function(){o.currentObservers=null,Qe(s,r)}))},t.prototype._checkFinalizedStatuses=function(r){var o=this,n=o.hasError,i=o.thrownError,a=o.isStopped;n?r.error(i):a&&r.complete()},t.prototype.asObservable=function(){var r=new F;return r.source=this,r},t.create=function(r,o){return new wo(r,o)},t}(F);var wo=function(e){re(t,e);function t(r,o){var n=e.call(this)||this;return n.destination=r,n.source=o,n}return t.prototype.next=function(r){var o,n;(n=(o=this.destination)===null||o===void 0?void 0:o.next)===null||n===void 0||n.call(o,r)},t.prototype.error=function(r){var o,n;(n=(o=this.destination)===null||o===void 0?void 0:o.error)===null||n===void 0||n.call(o,r)},t.prototype.complete=function(){var r,o;(o=(r=this.destination)===null||r===void 0?void 0:r.complete)===null||o===void 0||o.call(r)},t.prototype._subscribe=function(r){var o,n;return(n=(o=this.source)===null||o===void 0?void 0:o.subscribe(r))!==null&&n!==void 0?n:Tr},t}(g);var _r=function(e){re(t,e);function t(r){var o=e.call(this)||this;return o._value=r,o}return Object.defineProperty(t.prototype,"value",{get:function(){return this.getValue()},enumerable:!1,configurable:!0}),t.prototype._subscribe=function(r){var o=e.prototype._subscribe.call(this,r);return!o.closed&&r.next(this._value),o},t.prototype.getValue=function(){var r=this,o=r.hasError,n=r.thrownError,i=r._value;if(o)throw n;return this._throwIfClosed(),i},t.prototype.next=function(r){e.prototype.next.call(this,this._value=r)},t}(g);var At={now:function(){return(At.delegate||Date).now()},delegate:void 0};var Ct=function(e){re(t,e);function t(r,o,n){r===void 0&&(r=1/0),o===void 0&&(o=1/0),n===void 0&&(n=At);var i=e.call(this)||this;return i._bufferSize=r,i._windowTime=o,i._timestampProvider=n,i._buffer=[],i._infiniteTimeWindow=!0,i._infiniteTimeWindow=o===1/0,i._bufferSize=Math.max(1,r),i._windowTime=Math.max(1,o),i}return t.prototype.next=function(r){var o=this,n=o.isStopped,i=o._buffer,a=o._infiniteTimeWindow,s=o._timestampProvider,p=o._windowTime;n||(i.push(r),!a&&i.push(s.now()+p)),this._trimBuffer(),e.prototype.next.call(this,r)},t.prototype._subscribe=function(r){this._throwIfClosed(),this._trimBuffer();for(var o=this._innerSubscribe(r),n=this,i=n._infiniteTimeWindow,a=n._buffer,s=a.slice(),p=0;p0?e.prototype.schedule.call(this,r,o):(this.delay=o,this.state=r,this.scheduler.flush(this),this)},t.prototype.execute=function(r,o){return o>0||this.closed?e.prototype.execute.call(this,r,o):this._execute(r,o)},t.prototype.requestAsyncId=function(r,o,n){return n===void 0&&(n=0),n!=null&&n>0||n==null&&this.delay>0?e.prototype.requestAsyncId.call(this,r,o,n):(r.flush(this),0)},t}(gt);var Oo=function(e){re(t,e);function t(){return e!==null&&e.apply(this,arguments)||this}return t}(xt);var Hr=new Oo(So);var Mo=function(e){re(t,e);function t(r,o){var n=e.call(this,r,o)||this;return n.scheduler=r,n.work=o,n}return t.prototype.requestAsyncId=function(r,o,n){return n===void 0&&(n=0),n!==null&&n>0?e.prototype.requestAsyncId.call(this,r,o,n):(r.actions.push(this),r._scheduled||(r._scheduled=vt.requestAnimationFrame(function(){return r.flush(void 0)})))},t.prototype.recycleAsyncId=function(r,o,n){var i;if(n===void 0&&(n=0),n!=null?n>0:this.delay>0)return e.prototype.recycleAsyncId.call(this,r,o,n);var a=r.actions;o!=null&&((i=a[a.length-1])===null||i===void 0?void 0:i.id)!==o&&(vt.cancelAnimationFrame(o),r._scheduled=void 0)},t}(gt);var Lo=function(e){re(t,e);function t(){return e!==null&&e.apply(this,arguments)||this}return t.prototype.flush=function(r){this._active=!0;var o=this._scheduled;this._scheduled=void 0;var n=this.actions,i;r=r||n.shift();do if(i=r.execute(r.state,r.delay))break;while((r=n[0])&&r.id===o&&n.shift());if(this._active=!1,i){for(;(r=n[0])&&r.id===o&&n.shift();)r.unsubscribe();throw i}},t}(xt);var me=new Lo(Mo);var S=new F(function(e){return e.complete()});function Yt(e){return e&&k(e.schedule)}function kr(e){return e[e.length-1]}function Xe(e){return k(kr(e))?e.pop():void 0}function He(e){return Yt(kr(e))?e.pop():void 0}function Bt(e,t){return typeof kr(e)=="number"?e.pop():t}var yt=function(e){return e&&typeof e.length=="number"&&typeof e!="function"};function Gt(e){return k(e==null?void 0:e.then)}function Jt(e){return k(e[bt])}function Xt(e){return Symbol.asyncIterator&&k(e==null?void 0:e[Symbol.asyncIterator])}function Zt(e){return new TypeError("You provided "+(e!==null&&typeof e=="object"?"an invalid object":"'"+e+"'")+" where a stream was expected. You can provide an Observable, Promise, ReadableStream, Array, AsyncIterable, or Iterable.")}function Ji(){return typeof Symbol!="function"||!Symbol.iterator?"@@iterator":Symbol.iterator}var er=Ji();function tr(e){return k(e==null?void 0:e[er])}function rr(e){return mo(this,arguments,function(){var r,o,n,i;return Nt(this,function(a){switch(a.label){case 0:r=e.getReader(),a.label=1;case 1:a.trys.push([1,,9,10]),a.label=2;case 2:return[4,nt(r.read())];case 3:return o=a.sent(),n=o.value,i=o.done,i?[4,nt(void 0)]:[3,5];case 4:return[2,a.sent()];case 5:return[4,nt(n)];case 6:return[4,a.sent()];case 7:return a.sent(),[3,2];case 8:return[3,10];case 9:return r.releaseLock(),[7];case 10:return[2]}})})}function or(e){return k(e==null?void 0:e.getReader)}function W(e){if(e instanceof F)return e;if(e!=null){if(Jt(e))return Xi(e);if(yt(e))return Zi(e);if(Gt(e))return ea(e);if(Xt(e))return _o(e);if(tr(e))return ta(e);if(or(e))return ra(e)}throw Zt(e)}function Xi(e){return new F(function(t){var r=e[bt]();if(k(r.subscribe))return r.subscribe(t);throw new TypeError("Provided object does not correctly implement Symbol.observable")})}function Zi(e){return new F(function(t){for(var r=0;r=2;return function(o){return o.pipe(e?b(function(n,i){return e(n,i,o)}):le,Te(1),r?De(t):qo(function(){return new ir}))}}function Fr(e){return e<=0?function(){return S}:y(function(t,r){var o=[];t.subscribe(T(r,function(n){o.push(n),e=2,!0))}function pe(e){e===void 0&&(e={});var t=e.connector,r=t===void 0?function(){return new g}:t,o=e.resetOnError,n=o===void 0?!0:o,i=e.resetOnComplete,a=i===void 0?!0:i,s=e.resetOnRefCountZero,p=s===void 0?!0:s;return function(c){var l,f,u,h=0,w=!1,A=!1,te=function(){f==null||f.unsubscribe(),f=void 0},ie=function(){te(),l=u=void 0,w=A=!1},J=function(){var H=l;ie(),H==null||H.unsubscribe()};return y(function(H,ft){h++,!A&&!w&&te();var qe=u=u!=null?u:r();ft.add(function(){h--,h===0&&!A&&!w&&(f=Wr(J,p))}),qe.subscribe(ft),!l&&h>0&&(l=new at({next:function(je){return qe.next(je)},error:function(je){A=!0,te(),f=Wr(ie,n,je),qe.error(je)},complete:function(){w=!0,te(),f=Wr(ie,a),qe.complete()}}),W(H).subscribe(l))})(c)}}function Wr(e,t){for(var r=[],o=2;oe.next(document)),e}function P(e,t=document){return Array.from(t.querySelectorAll(e))}function R(e,t=document){let r=fe(e,t);if(typeof r=="undefined")throw new ReferenceError(`Missing element: expected "${e}" to be present`);return r}function fe(e,t=document){return t.querySelector(e)||void 0}function Ie(){var e,t,r,o;return(o=(r=(t=(e=document.activeElement)==null?void 0:e.shadowRoot)==null?void 0:t.activeElement)!=null?r:document.activeElement)!=null?o:void 0}var ya=O(d(document.body,"focusin"),d(document.body,"focusout")).pipe(_e(1),Q(void 0),m(()=>Ie()||document.body),G(1));function et(e){return ya.pipe(m(t=>e.contains(t)),K())}function $t(e,t){return C(()=>O(d(e,"mouseenter").pipe(m(()=>!0)),d(e,"mouseleave").pipe(m(()=>!1))).pipe(t?kt(r=>Me(+!r*t)):le,Q(e.matches(":hover"))))}function Go(e,t){if(typeof t=="string"||typeof t=="number")e.innerHTML+=t.toString();else if(t instanceof Node)e.appendChild(t);else if(Array.isArray(t))for(let r of t)Go(e,r)}function x(e,t,...r){let o=document.createElement(e);if(t)for(let n of Object.keys(t))typeof t[n]!="undefined"&&(typeof t[n]!="boolean"?o.setAttribute(n,t[n]):o.setAttribute(n,""));for(let n of r)Go(o,n);return o}function sr(e){if(e>999){let t=+((e-950)%1e3>99);return`${((e+1e-6)/1e3).toFixed(t)}k`}else return e.toString()}function Tt(e){let t=x("script",{src:e});return C(()=>(document.head.appendChild(t),O(d(t,"load"),d(t,"error").pipe(v(()=>$r(()=>new ReferenceError(`Invalid script: ${e}`))))).pipe(m(()=>{}),L(()=>document.head.removeChild(t)),Te(1))))}var Jo=new g,Ea=C(()=>typeof ResizeObserver=="undefined"?Tt("https://unpkg.com/resize-observer-polyfill"):I(void 0)).pipe(m(()=>new ResizeObserver(e=>e.forEach(t=>Jo.next(t)))),v(e=>O(Ye,I(e)).pipe(L(()=>e.disconnect()))),G(1));function ce(e){return{width:e.offsetWidth,height:e.offsetHeight}}function ge(e){let t=e;for(;t.clientWidth===0&&t.parentElement;)t=t.parentElement;return Ea.pipe(E(r=>r.observe(t)),v(r=>Jo.pipe(b(o=>o.target===t),L(()=>r.unobserve(t)))),m(()=>ce(e)),Q(ce(e)))}function St(e){return{width:e.scrollWidth,height:e.scrollHeight}}function cr(e){let t=e.parentElement;for(;t&&(e.scrollWidth<=t.scrollWidth&&e.scrollHeight<=t.scrollHeight);)t=(e=t).parentElement;return t?e:void 0}function Xo(e){let t=[],r=e.parentElement;for(;r;)(e.clientWidth>r.clientWidth||e.clientHeight>r.clientHeight)&&t.push(r),r=(e=r).parentElement;return t.length===0&&t.push(document.documentElement),t}function Ve(e){return{x:e.offsetLeft,y:e.offsetTop}}function Zo(e){let t=e.getBoundingClientRect();return{x:t.x+window.scrollX,y:t.y+window.scrollY}}function en(e){return O(d(window,"load"),d(window,"resize")).pipe(Le(0,me),m(()=>Ve(e)),Q(Ve(e)))}function pr(e){return{x:e.scrollLeft,y:e.scrollTop}}function Ne(e){return O(d(e,"scroll"),d(window,"scroll"),d(window,"resize")).pipe(Le(0,me),m(()=>pr(e)),Q(pr(e)))}var tn=new g,wa=C(()=>I(new IntersectionObserver(e=>{for(let t of e)tn.next(t)},{threshold:0}))).pipe(v(e=>O(Ye,I(e)).pipe(L(()=>e.disconnect()))),G(1));function tt(e){return wa.pipe(E(t=>t.observe(e)),v(t=>tn.pipe(b(({target:r})=>r===e),L(()=>t.unobserve(e)),m(({isIntersecting:r})=>r))))}function rn(e,t=16){return Ne(e).pipe(m(({y:r})=>{let o=ce(e),n=St(e);return r>=n.height-o.height-t}),K())}var lr={drawer:R("[data-md-toggle=drawer]"),search:R("[data-md-toggle=search]")};function on(e){return lr[e].checked}function Je(e,t){lr[e].checked!==t&&lr[e].click()}function ze(e){let t=lr[e];return d(t,"change").pipe(m(()=>t.checked),Q(t.checked))}function Ta(e,t){switch(e.constructor){case HTMLInputElement:return e.type==="radio"?/^Arrow/.test(t):!0;case HTMLSelectElement:case HTMLTextAreaElement:return!0;default:return e.isContentEditable}}function Sa(){return O(d(window,"compositionstart").pipe(m(()=>!0)),d(window,"compositionend").pipe(m(()=>!1))).pipe(Q(!1))}function nn(){let e=d(window,"keydown").pipe(b(t=>!(t.metaKey||t.ctrlKey)),m(t=>({mode:on("search")?"search":"global",type:t.key,claim(){t.preventDefault(),t.stopPropagation()}})),b(({mode:t,type:r})=>{if(t==="global"){let o=Ie();if(typeof o!="undefined")return!Ta(o,r)}return!0}),pe());return Sa().pipe(v(t=>t?S:e))}function xe(){return new URL(location.href)}function lt(e,t=!1){if(B("navigation.instant")&&!t){let r=x("a",{href:e.href});document.body.appendChild(r),r.click(),r.remove()}else location.href=e.href}function an(){return new g}function sn(){return location.hash.slice(1)}function cn(e){let t=x("a",{href:e});t.addEventListener("click",r=>r.stopPropagation()),t.click()}function Oa(e){return O(d(window,"hashchange"),e).pipe(m(sn),Q(sn()),b(t=>t.length>0),G(1))}function pn(e){return Oa(e).pipe(m(t=>fe(`[id="${t}"]`)),b(t=>typeof t!="undefined"))}function Pt(e){let t=matchMedia(e);return ar(r=>t.addListener(()=>r(t.matches))).pipe(Q(t.matches))}function ln(){let e=matchMedia("print");return O(d(window,"beforeprint").pipe(m(()=>!0)),d(window,"afterprint").pipe(m(()=>!1))).pipe(Q(e.matches))}function Nr(e,t){return e.pipe(v(r=>r?t():S))}function zr(e,t){return new F(r=>{let o=new XMLHttpRequest;return o.open("GET",`${e}`),o.responseType="blob",o.addEventListener("load",()=>{o.status>=200&&o.status<300?(r.next(o.response),r.complete()):r.error(new Error(o.statusText))}),o.addEventListener("error",()=>{r.error(new Error("Network error"))}),o.addEventListener("abort",()=>{r.complete()}),typeof(t==null?void 0:t.progress$)!="undefined"&&(o.addEventListener("progress",n=>{var i;if(n.lengthComputable)t.progress$.next(n.loaded/n.total*100);else{let a=(i=o.getResponseHeader("Content-Length"))!=null?i:0;t.progress$.next(n.loaded/+a*100)}}),t.progress$.next(5)),o.send(),()=>o.abort()})}function Fe(e,t){return zr(e,t).pipe(v(r=>r.text()),m(r=>JSON.parse(r)),G(1))}function mn(e,t){let r=new DOMParser;return zr(e,t).pipe(v(o=>o.text()),m(o=>r.parseFromString(o,"text/html")),G(1))}function fn(e,t){let r=new DOMParser;return zr(e,t).pipe(v(o=>o.text()),m(o=>r.parseFromString(o,"text/xml")),G(1))}function un(){return{x:Math.max(0,scrollX),y:Math.max(0,scrollY)}}function dn(){return O(d(window,"scroll",{passive:!0}),d(window,"resize",{passive:!0})).pipe(m(un),Q(un()))}function hn(){return{width:innerWidth,height:innerHeight}}function bn(){return d(window,"resize",{passive:!0}).pipe(m(hn),Q(hn()))}function vn(){return z([dn(),bn()]).pipe(m(([e,t])=>({offset:e,size:t})),G(1))}function mr(e,{viewport$:t,header$:r}){let o=t.pipe(Z("size")),n=z([o,r]).pipe(m(()=>Ve(e)));return z([r,t,n]).pipe(m(([{height:i},{offset:a,size:s},{x:p,y:c}])=>({offset:{x:a.x-p,y:a.y-c+i},size:s})))}function Ma(e){return d(e,"message",t=>t.data)}function La(e){let t=new g;return t.subscribe(r=>e.postMessage(r)),t}function gn(e,t=new Worker(e)){let r=Ma(t),o=La(t),n=new g;n.subscribe(o);let i=o.pipe(X(),ne(!0));return n.pipe(X(),Re(r.pipe(U(i))),pe())}var _a=R("#__config"),Ot=JSON.parse(_a.textContent);Ot.base=`${new URL(Ot.base,xe())}`;function ye(){return Ot}function B(e){return Ot.features.includes(e)}function Ee(e,t){return typeof t!="undefined"?Ot.translations[e].replace("#",t.toString()):Ot.translations[e]}function Se(e,t=document){return R(`[data-md-component=${e}]`,t)}function ae(e,t=document){return P(`[data-md-component=${e}]`,t)}function Aa(e){let t=R(".md-typeset > :first-child",e);return d(t,"click",{once:!0}).pipe(m(()=>R(".md-typeset",e)),m(r=>({hash:__md_hash(r.innerHTML)})))}function xn(e){if(!B("announce.dismiss")||!e.childElementCount)return S;if(!e.hidden){let t=R(".md-typeset",e);__md_hash(t.innerHTML)===__md_get("__announce")&&(e.hidden=!0)}return C(()=>{let t=new g;return t.subscribe(({hash:r})=>{e.hidden=!0,__md_set("__announce",r)}),Aa(e).pipe(E(r=>t.next(r)),L(()=>t.complete()),m(r=>$({ref:e},r)))})}function Ca(e,{target$:t}){return t.pipe(m(r=>({hidden:r!==e})))}function yn(e,t){let r=new g;return r.subscribe(({hidden:o})=>{e.hidden=o}),Ca(e,t).pipe(E(o=>r.next(o)),L(()=>r.complete()),m(o=>$({ref:e},o)))}function Rt(e,t){return t==="inline"?x("div",{class:"md-tooltip md-tooltip--inline",id:e,role:"tooltip"},x("div",{class:"md-tooltip__inner md-typeset"})):x("div",{class:"md-tooltip",id:e,role:"tooltip"},x("div",{class:"md-tooltip__inner md-typeset"}))}function En(...e){return x("div",{class:"md-tooltip2",role:"tooltip"},x("div",{class:"md-tooltip2__inner md-typeset"},e))}function wn(e,t){if(t=t?`${t}_annotation_${e}`:void 0,t){let r=t?`#${t}`:void 0;return x("aside",{class:"md-annotation",tabIndex:0},Rt(t),x("a",{href:r,class:"md-annotation__index",tabIndex:-1},x("span",{"data-md-annotation-id":e})))}else return x("aside",{class:"md-annotation",tabIndex:0},Rt(t),x("span",{class:"md-annotation__index",tabIndex:-1},x("span",{"data-md-annotation-id":e})))}function Tn(e){return x("button",{class:"md-clipboard md-icon",title:Ee("clipboard.copy"),"data-clipboard-target":`#${e} > code`})}var On=Lt(qr());function Qr(e,t){let r=t&2,o=t&1,n=Object.keys(e.terms).filter(p=>!e.terms[p]).reduce((p,c)=>[...p,x("del",null,(0,On.default)(c))," "],[]).slice(0,-1),i=ye(),a=new URL(e.location,i.base);B("search.highlight")&&a.searchParams.set("h",Object.entries(e.terms).filter(([,p])=>p).reduce((p,[c])=>`${p} ${c}`.trim(),""));let{tags:s}=ye();return x("a",{href:`${a}`,class:"md-search-result__link",tabIndex:-1},x("article",{class:"md-search-result__article md-typeset","data-md-score":e.score.toFixed(2)},r>0&&x("div",{class:"md-search-result__icon md-icon"}),r>0&&x("h1",null,e.title),r<=0&&x("h2",null,e.title),o>0&&e.text.length>0&&e.text,e.tags&&e.tags.map(p=>{let c=s?p in s?`md-tag-icon md-tag--${s[p]}`:"md-tag-icon":"";return x("span",{class:`md-tag ${c}`},p)}),o>0&&n.length>0&&x("p",{class:"md-search-result__terms"},Ee("search.result.term.missing"),": ",...n)))}function Mn(e){let t=e[0].score,r=[...e],o=ye(),n=r.findIndex(l=>!`${new URL(l.location,o.base)}`.includes("#")),[i]=r.splice(n,1),a=r.findIndex(l=>l.scoreQr(l,1)),...p.length?[x("details",{class:"md-search-result__more"},x("summary",{tabIndex:-1},x("div",null,p.length>0&&p.length===1?Ee("search.result.more.one"):Ee("search.result.more.other",p.length))),...p.map(l=>Qr(l,1)))]:[]];return x("li",{class:"md-search-result__item"},c)}function Ln(e){return x("ul",{class:"md-source__facts"},Object.entries(e).map(([t,r])=>x("li",{class:`md-source__fact md-source__fact--${t}`},typeof r=="number"?sr(r):r)))}function Kr(e){let t=`tabbed-control tabbed-control--${e}`;return x("div",{class:t,hidden:!0},x("button",{class:"tabbed-button",tabIndex:-1,"aria-hidden":"true"}))}function _n(e){return x("div",{class:"md-typeset__scrollwrap"},x("div",{class:"md-typeset__table"},e))}function $a(e){var o;let t=ye(),r=new URL(`../${e.version}/`,t.base);return x("li",{class:"md-version__item"},x("a",{href:`${r}`,class:"md-version__link"},e.title,((o=t.version)==null?void 0:o.alias)&&e.aliases.length>0&&x("span",{class:"md-version__alias"},e.aliases[0])))}function An(e,t){var o;let r=ye();return e=e.filter(n=>{var i;return!((i=n.properties)!=null&&i.hidden)}),x("div",{class:"md-version"},x("button",{class:"md-version__current","aria-label":Ee("select.version")},t.title,((o=r.version)==null?void 0:o.alias)&&t.aliases.length>0&&x("span",{class:"md-version__alias"},t.aliases[0])),x("ul",{class:"md-version__list"},e.map($a)))}var Pa=0;function Ra(e){let t=z([et(e),$t(e)]).pipe(m(([o,n])=>o||n),K()),r=C(()=>Xo(e)).pipe(oe(Ne),pt(1),ke(t),m(()=>Zo(e)));return t.pipe(Ae(o=>o),v(()=>z([t,r])),m(([o,n])=>({active:o,offset:n})),pe())}function Ia(e,t){let{content$:r,viewport$:o}=t,n=`__tooltip2_${Pa++}`;return C(()=>{let i=new g,a=new _r(!1);i.pipe(X(),ne(!1)).subscribe(a);let s=a.pipe(kt(c=>Me(+!c*250,Hr)),K(),v(c=>c?r:S),E(c=>c.id=n),pe());z([i.pipe(m(({active:c})=>c)),s.pipe(v(c=>$t(c,250)),Q(!1))]).pipe(m(c=>c.some(l=>l))).subscribe(a);let p=a.pipe(b(c=>c),ee(s,o),m(([c,l,{size:f}])=>{let u=e.getBoundingClientRect(),h=u.width/2;if(l.role==="tooltip")return{x:h,y:8+u.height};if(u.y>=f.height/2){let{height:w}=ce(l);return{x:h,y:-16-w}}else return{x:h,y:16+u.height}}));return z([s,i,p]).subscribe(([c,{offset:l},f])=>{c.style.setProperty("--md-tooltip-host-x",`${l.x}px`),c.style.setProperty("--md-tooltip-host-y",`${l.y}px`),c.style.setProperty("--md-tooltip-x",`${f.x}px`),c.style.setProperty("--md-tooltip-y",`${f.y}px`),c.classList.toggle("md-tooltip2--top",f.y<0),c.classList.toggle("md-tooltip2--bottom",f.y>=0)}),a.pipe(b(c=>c),ee(s,(c,l)=>l),b(c=>c.role==="tooltip")).subscribe(c=>{let l=ce(R(":scope > *",c));c.style.setProperty("--md-tooltip-width",`${l.width}px`),c.style.setProperty("--md-tooltip-tail","0px")}),a.pipe(K(),ve(me),ee(s)).subscribe(([c,l])=>{l.classList.toggle("md-tooltip2--active",c)}),z([a.pipe(b(c=>c)),s]).subscribe(([c,l])=>{l.role==="dialog"?(e.setAttribute("aria-controls",n),e.setAttribute("aria-haspopup","dialog")):e.setAttribute("aria-describedby",n)}),a.pipe(b(c=>!c)).subscribe(()=>{e.removeAttribute("aria-controls"),e.removeAttribute("aria-describedby"),e.removeAttribute("aria-haspopup")}),Ra(e).pipe(E(c=>i.next(c)),L(()=>i.complete()),m(c=>$({ref:e},c)))})}function mt(e,{viewport$:t},r=document.body){return Ia(e,{content$:new F(o=>{let n=e.title,i=En(n);return o.next(i),e.removeAttribute("title"),r.append(i),()=>{i.remove(),e.setAttribute("title",n)}}),viewport$:t})}function Fa(e,t){let r=C(()=>z([en(e),Ne(t)])).pipe(m(([{x:o,y:n},i])=>{let{width:a,height:s}=ce(e);return{x:o-i.x+a/2,y:n-i.y+s/2}}));return et(e).pipe(v(o=>r.pipe(m(n=>({active:o,offset:n})),Te(+!o||1/0))))}function Cn(e,t,{target$:r}){let[o,n]=Array.from(e.children);return C(()=>{let i=new g,a=i.pipe(X(),ne(!0));return i.subscribe({next({offset:s}){e.style.setProperty("--md-tooltip-x",`${s.x}px`),e.style.setProperty("--md-tooltip-y",`${s.y}px`)},complete(){e.style.removeProperty("--md-tooltip-x"),e.style.removeProperty("--md-tooltip-y")}}),tt(e).pipe(U(a)).subscribe(s=>{e.toggleAttribute("data-md-visible",s)}),O(i.pipe(b(({active:s})=>s)),i.pipe(_e(250),b(({active:s})=>!s))).subscribe({next({active:s}){s?e.prepend(o):o.remove()},complete(){e.prepend(o)}}),i.pipe(Le(16,me)).subscribe(({active:s})=>{o.classList.toggle("md-tooltip--active",s)}),i.pipe(pt(125,me),b(()=>!!e.offsetParent),m(()=>e.offsetParent.getBoundingClientRect()),m(({x:s})=>s)).subscribe({next(s){s?e.style.setProperty("--md-tooltip-0",`${-s}px`):e.style.removeProperty("--md-tooltip-0")},complete(){e.style.removeProperty("--md-tooltip-0")}}),d(n,"click").pipe(U(a),b(s=>!(s.metaKey||s.ctrlKey))).subscribe(s=>{s.stopPropagation(),s.preventDefault()}),d(n,"mousedown").pipe(U(a),ee(i)).subscribe(([s,{active:p}])=>{var c;if(s.button!==0||s.metaKey||s.ctrlKey)s.preventDefault();else if(p){s.preventDefault();let l=e.parentElement.closest(".md-annotation");l instanceof HTMLElement?l.focus():(c=Ie())==null||c.blur()}}),r.pipe(U(a),b(s=>s===o),Ge(125)).subscribe(()=>e.focus()),Fa(e,t).pipe(E(s=>i.next(s)),L(()=>i.complete()),m(s=>$({ref:e},s)))})}function ja(e){return e.tagName==="CODE"?P(".c, .c1, .cm",e):[e]}function Wa(e){let t=[];for(let r of ja(e)){let o=[],n=document.createNodeIterator(r,NodeFilter.SHOW_TEXT);for(let i=n.nextNode();i;i=n.nextNode())o.push(i);for(let i of o){let a;for(;a=/(\(\d+\))(!)?/.exec(i.textContent);){let[,s,p]=a;if(typeof p=="undefined"){let c=i.splitText(a.index);i=c.splitText(s.length),t.push(c)}else{i.textContent=s,t.push(i);break}}}}return t}function Hn(e,t){t.append(...Array.from(e.childNodes))}function fr(e,t,{target$:r,print$:o}){let n=t.closest("[id]"),i=n==null?void 0:n.id,a=new Map;for(let s of Wa(t)){let[,p]=s.textContent.match(/\((\d+)\)/);fe(`:scope > li:nth-child(${p})`,e)&&(a.set(p,wn(p,i)),s.replaceWith(a.get(p)))}return a.size===0?S:C(()=>{let s=new g,p=s.pipe(X(),ne(!0)),c=[];for(let[l,f]of a)c.push([R(".md-typeset",f),R(`:scope > li:nth-child(${l})`,e)]);return o.pipe(U(p)).subscribe(l=>{e.hidden=!l,e.classList.toggle("md-annotation-list",l);for(let[f,u]of c)l?Hn(f,u):Hn(u,f)}),O(...[...a].map(([,l])=>Cn(l,t,{target$:r}))).pipe(L(()=>s.complete()),pe())})}function kn(e){if(e.nextElementSibling){let t=e.nextElementSibling;if(t.tagName==="OL")return t;if(t.tagName==="P"&&!t.children.length)return kn(t)}}function $n(e,t){return C(()=>{let r=kn(e);return typeof r!="undefined"?fr(r,e,t):S})}var Pn=Lt(Br());var Ua=0;function Rn(e){if(e.nextElementSibling){let t=e.nextElementSibling;if(t.tagName==="OL")return t;if(t.tagName==="P"&&!t.children.length)return Rn(t)}}function Da(e){return ge(e).pipe(m(({width:t})=>({scrollable:St(e).width>t})),Z("scrollable"))}function In(e,t){let{matches:r}=matchMedia("(hover)"),o=C(()=>{let n=new g,i=n.pipe(Fr(1));n.subscribe(({scrollable:c})=>{c&&r?e.setAttribute("tabindex","0"):e.removeAttribute("tabindex")});let a=[];if(Pn.default.isSupported()&&(e.closest(".copy")||B("content.code.copy")&&!e.closest(".no-copy"))){let c=e.closest("pre");c.id=`__code_${Ua++}`;let l=Tn(c.id);c.insertBefore(l,e),B("content.tooltips")&&a.push(mt(l,{viewport$}))}let s=e.closest(".highlight");if(s instanceof HTMLElement){let c=Rn(s);if(typeof c!="undefined"&&(s.classList.contains("annotate")||B("content.code.annotate"))){let l=fr(c,e,t);a.push(ge(s).pipe(U(i),m(({width:f,height:u})=>f&&u),K(),v(f=>f?l:S)))}}return P(":scope > span[id]",e).length&&e.classList.add("md-code__content"),Da(e).pipe(E(c=>n.next(c)),L(()=>n.complete()),m(c=>$({ref:e},c)),Re(...a))});return B("content.lazy")?tt(e).pipe(b(n=>n),Te(1),v(()=>o)):o}function Va(e,{target$:t,print$:r}){let o=!0;return O(t.pipe(m(n=>n.closest("details:not([open])")),b(n=>e===n),m(()=>({action:"open",reveal:!0}))),r.pipe(b(n=>n||!o),E(()=>o=e.open),m(n=>({action:n?"open":"close"}))))}function Fn(e,t){return C(()=>{let r=new g;return r.subscribe(({action:o,reveal:n})=>{e.toggleAttribute("open",o==="open"),n&&e.scrollIntoView()}),Va(e,t).pipe(E(o=>r.next(o)),L(()=>r.complete()),m(o=>$({ref:e},o)))})}var jn=".node circle,.node ellipse,.node path,.node polygon,.node rect{fill:var(--md-mermaid-node-bg-color);stroke:var(--md-mermaid-node-fg-color)}marker{fill:var(--md-mermaid-edge-color)!important}.edgeLabel .label rect{fill:#0000}.label{color:var(--md-mermaid-label-fg-color);font-family:var(--md-mermaid-font-family)}.label foreignObject{line-height:normal;overflow:visible}.label div .edgeLabel{color:var(--md-mermaid-label-fg-color)}.edgeLabel,.edgeLabel rect,.label div .edgeLabel{background-color:var(--md-mermaid-label-bg-color)}.edgeLabel,.edgeLabel rect{fill:var(--md-mermaid-label-bg-color);color:var(--md-mermaid-edge-color)}.edgePath .path,.flowchart-link{stroke:var(--md-mermaid-edge-color);stroke-width:.05rem}.edgePath .arrowheadPath{fill:var(--md-mermaid-edge-color);stroke:none}.cluster rect{fill:var(--md-default-fg-color--lightest);stroke:var(--md-default-fg-color--lighter)}.cluster span{color:var(--md-mermaid-label-fg-color);font-family:var(--md-mermaid-font-family)}g #flowchart-circleEnd,g #flowchart-circleStart,g #flowchart-crossEnd,g #flowchart-crossStart,g #flowchart-pointEnd,g #flowchart-pointStart{stroke:none}g.classGroup line,g.classGroup rect{fill:var(--md-mermaid-node-bg-color);stroke:var(--md-mermaid-node-fg-color)}g.classGroup text{fill:var(--md-mermaid-label-fg-color);font-family:var(--md-mermaid-font-family)}.classLabel .box{fill:var(--md-mermaid-label-bg-color);background-color:var(--md-mermaid-label-bg-color);opacity:1}.classLabel .label{fill:var(--md-mermaid-label-fg-color);font-family:var(--md-mermaid-font-family)}.node .divider{stroke:var(--md-mermaid-node-fg-color)}.relation{stroke:var(--md-mermaid-edge-color)}.cardinality{fill:var(--md-mermaid-label-fg-color);font-family:var(--md-mermaid-font-family)}.cardinality text{fill:inherit!important}defs #classDiagram-compositionEnd,defs #classDiagram-compositionStart,defs #classDiagram-dependencyEnd,defs #classDiagram-dependencyStart,defs #classDiagram-extensionEnd,defs #classDiagram-extensionStart{fill:var(--md-mermaid-edge-color)!important;stroke:var(--md-mermaid-edge-color)!important}defs #classDiagram-aggregationEnd,defs #classDiagram-aggregationStart{fill:var(--md-mermaid-label-bg-color)!important;stroke:var(--md-mermaid-edge-color)!important}g.stateGroup rect{fill:var(--md-mermaid-node-bg-color);stroke:var(--md-mermaid-node-fg-color)}g.stateGroup .state-title{fill:var(--md-mermaid-label-fg-color)!important;font-family:var(--md-mermaid-font-family)}g.stateGroup .composit{fill:var(--md-mermaid-label-bg-color)}.nodeLabel,.nodeLabel p{color:var(--md-mermaid-label-fg-color);font-family:var(--md-mermaid-font-family)}a .nodeLabel{text-decoration:underline}.node circle.state-end,.node circle.state-start,.start-state{fill:var(--md-mermaid-edge-color);stroke:none}.end-state-inner,.end-state-outer{fill:var(--md-mermaid-edge-color)}.end-state-inner,.node circle.state-end{stroke:var(--md-mermaid-label-bg-color)}.transition{stroke:var(--md-mermaid-edge-color)}[id^=state-fork] rect,[id^=state-join] rect{fill:var(--md-mermaid-edge-color)!important;stroke:none!important}.statediagram-cluster.statediagram-cluster .inner{fill:var(--md-default-bg-color)}.statediagram-cluster rect{fill:var(--md-mermaid-node-bg-color);stroke:var(--md-mermaid-node-fg-color)}.statediagram-state rect.divider{fill:var(--md-default-fg-color--lightest);stroke:var(--md-default-fg-color--lighter)}defs #statediagram-barbEnd{stroke:var(--md-mermaid-edge-color)}.attributeBoxEven,.attributeBoxOdd{fill:var(--md-mermaid-node-bg-color);stroke:var(--md-mermaid-node-fg-color)}.entityBox{fill:var(--md-mermaid-label-bg-color);stroke:var(--md-mermaid-node-fg-color)}.entityLabel{fill:var(--md-mermaid-label-fg-color);font-family:var(--md-mermaid-font-family)}.relationshipLabelBox{fill:var(--md-mermaid-label-bg-color);fill-opacity:1;background-color:var(--md-mermaid-label-bg-color);opacity:1}.relationshipLabel{fill:var(--md-mermaid-label-fg-color)}.relationshipLine{stroke:var(--md-mermaid-edge-color)}defs #ONE_OR_MORE_END *,defs #ONE_OR_MORE_START *,defs #ONLY_ONE_END *,defs #ONLY_ONE_START *,defs #ZERO_OR_MORE_END *,defs #ZERO_OR_MORE_START *,defs #ZERO_OR_ONE_END *,defs #ZERO_OR_ONE_START *{stroke:var(--md-mermaid-edge-color)!important}defs #ZERO_OR_MORE_END circle,defs #ZERO_OR_MORE_START circle{fill:var(--md-mermaid-label-bg-color)}.actor{fill:var(--md-mermaid-sequence-actor-bg-color);stroke:var(--md-mermaid-sequence-actor-border-color)}text.actor>tspan{fill:var(--md-mermaid-sequence-actor-fg-color);font-family:var(--md-mermaid-font-family)}line{stroke:var(--md-mermaid-sequence-actor-line-color)}.actor-man circle,.actor-man line{fill:var(--md-mermaid-sequence-actorman-bg-color);stroke:var(--md-mermaid-sequence-actorman-line-color)}.messageLine0,.messageLine1{stroke:var(--md-mermaid-sequence-message-line-color)}.note{fill:var(--md-mermaid-sequence-note-bg-color);stroke:var(--md-mermaid-sequence-note-border-color)}.loopText,.loopText>tspan,.messageText,.noteText>tspan{stroke:none;font-family:var(--md-mermaid-font-family)!important}.messageText{fill:var(--md-mermaid-sequence-message-fg-color)}.loopText,.loopText>tspan{fill:var(--md-mermaid-sequence-loop-fg-color)}.noteText>tspan{fill:var(--md-mermaid-sequence-note-fg-color)}#arrowhead path{fill:var(--md-mermaid-sequence-message-line-color);stroke:none}.loopLine{fill:var(--md-mermaid-sequence-loop-bg-color);stroke:var(--md-mermaid-sequence-loop-border-color)}.labelBox{fill:var(--md-mermaid-sequence-label-bg-color);stroke:none}.labelText,.labelText>span{fill:var(--md-mermaid-sequence-label-fg-color);font-family:var(--md-mermaid-font-family)}.sequenceNumber{fill:var(--md-mermaid-sequence-number-fg-color)}rect.rect{fill:var(--md-mermaid-sequence-box-bg-color);stroke:none}rect.rect+text.text{fill:var(--md-mermaid-sequence-box-fg-color)}defs #sequencenumber{fill:var(--md-mermaid-sequence-number-bg-color)!important}";var Gr,za=0;function qa(){return typeof mermaid=="undefined"||mermaid instanceof Element?Tt("https://unpkg.com/mermaid@10/dist/mermaid.min.js"):I(void 0)}function Wn(e){return e.classList.remove("mermaid"),Gr||(Gr=qa().pipe(E(()=>mermaid.initialize({startOnLoad:!1,themeCSS:jn,sequence:{actorFontSize:"16px",messageFontSize:"16px",noteFontSize:"16px"}})),m(()=>{}),G(1))),Gr.subscribe(()=>so(this,null,function*(){e.classList.add("mermaid");let t=`__mermaid_${za++}`,r=x("div",{class:"mermaid"}),o=e.textContent,{svg:n,fn:i}=yield mermaid.render(t,o),a=r.attachShadow({mode:"closed"});a.innerHTML=n,e.replaceWith(r),i==null||i(a)})),Gr.pipe(m(()=>({ref:e})))}var Un=x("table");function Dn(e){return e.replaceWith(Un),Un.replaceWith(_n(e)),I({ref:e})}function Qa(e){let t=e.find(r=>r.checked)||e[0];return O(...e.map(r=>d(r,"change").pipe(m(()=>R(`label[for="${r.id}"]`))))).pipe(Q(R(`label[for="${t.id}"]`)),m(r=>({active:r})))}function Vn(e,{viewport$:t,target$:r}){let o=R(".tabbed-labels",e),n=P(":scope > input",e),i=Kr("prev");e.append(i);let a=Kr("next");return e.append(a),C(()=>{let s=new g,p=s.pipe(X(),ne(!0));z([s,ge(e),tt(e)]).pipe(U(p),Le(1,me)).subscribe({next([{active:c},l]){let f=Ve(c),{width:u}=ce(c);e.style.setProperty("--md-indicator-x",`${f.x}px`),e.style.setProperty("--md-indicator-width",`${u}px`);let h=pr(o);(f.xh.x+l.width)&&o.scrollTo({left:Math.max(0,f.x-16),behavior:"smooth"})},complete(){e.style.removeProperty("--md-indicator-x"),e.style.removeProperty("--md-indicator-width")}}),z([Ne(o),ge(o)]).pipe(U(p)).subscribe(([c,l])=>{let f=St(o);i.hidden=c.x<16,a.hidden=c.x>f.width-l.width-16}),O(d(i,"click").pipe(m(()=>-1)),d(a,"click").pipe(m(()=>1))).pipe(U(p)).subscribe(c=>{let{width:l}=ce(o);o.scrollBy({left:l*c,behavior:"smooth"})}),r.pipe(U(p),b(c=>n.includes(c))).subscribe(c=>c.click()),o.classList.add("tabbed-labels--linked");for(let c of n){let l=R(`label[for="${c.id}"]`);l.replaceChildren(x("a",{href:`#${l.htmlFor}`,tabIndex:-1},...Array.from(l.childNodes))),d(l.firstElementChild,"click").pipe(U(p),b(f=>!(f.metaKey||f.ctrlKey)),E(f=>{f.preventDefault(),f.stopPropagation()})).subscribe(()=>{history.replaceState({},"",`#${l.htmlFor}`),l.click()})}return B("content.tabs.link")&&s.pipe(Ce(1),ee(t)).subscribe(([{active:c},{offset:l}])=>{let f=c.innerText.trim();if(c.hasAttribute("data-md-switching"))c.removeAttribute("data-md-switching");else{let u=e.offsetTop-l.y;for(let w of P("[data-tabs]"))for(let A of P(":scope > input",w)){let te=R(`label[for="${A.id}"]`);if(te!==c&&te.innerText.trim()===f){te.setAttribute("data-md-switching",""),A.click();break}}window.scrollTo({top:e.offsetTop-u});let h=__md_get("__tabs")||[];__md_set("__tabs",[...new Set([f,...h])])}}),s.pipe(U(p)).subscribe(()=>{for(let c of P("audio, video",e))c.pause()}),Qa(n).pipe(E(c=>s.next(c)),L(()=>s.complete()),m(c=>$({ref:e},c)))}).pipe(Ke(se))}function Nn(e,{viewport$:t,target$:r,print$:o}){return O(...P(".annotate:not(.highlight)",e).map(n=>$n(n,{target$:r,print$:o})),...P("pre:not(.mermaid) > code",e).map(n=>In(n,{target$:r,print$:o})),...P("pre.mermaid",e).map(n=>Wn(n)),...P("table:not([class])",e).map(n=>Dn(n)),...P("details",e).map(n=>Fn(n,{target$:r,print$:o})),...P("[data-tabs]",e).map(n=>Vn(n,{viewport$:t,target$:r})),...P("[title]",e).filter(()=>B("content.tooltips")).map(n=>mt(n,{viewport$:t})))}function Ka(e,{alert$:t}){return t.pipe(v(r=>O(I(!0),I(!1).pipe(Ge(2e3))).pipe(m(o=>({message:r,active:o})))))}function zn(e,t){let r=R(".md-typeset",e);return C(()=>{let o=new g;return o.subscribe(({message:n,active:i})=>{e.classList.toggle("md-dialog--active",i),r.textContent=n}),Ka(e,t).pipe(E(n=>o.next(n)),L(()=>o.complete()),m(n=>$({ref:e},n)))})}var Ya=0;function Ba(e,t){document.body.append(e);let{width:r}=ce(e);e.style.setProperty("--md-tooltip-width",`${r}px`),e.remove();let o=cr(t),n=typeof o!="undefined"?Ne(o):I({x:0,y:0}),i=O(et(t),$t(t)).pipe(K());return z([i,n]).pipe(m(([a,s])=>{let{x:p,y:c}=Ve(t),l=ce(t),f=t.closest("table");return f&&t.parentElement&&(p+=f.offsetLeft+t.parentElement.offsetLeft,c+=f.offsetTop+t.parentElement.offsetTop),{active:a,offset:{x:p-s.x+l.width/2-r/2,y:c-s.y+l.height+8}}}))}function qn(e){let t=e.title;if(!t.length)return S;let r=`__tooltip_${Ya++}`,o=Rt(r,"inline"),n=R(".md-typeset",o);return n.innerHTML=t,C(()=>{let i=new g;return i.subscribe({next({offset:a}){o.style.setProperty("--md-tooltip-x",`${a.x}px`),o.style.setProperty("--md-tooltip-y",`${a.y}px`)},complete(){o.style.removeProperty("--md-tooltip-x"),o.style.removeProperty("--md-tooltip-y")}}),O(i.pipe(b(({active:a})=>a)),i.pipe(_e(250),b(({active:a})=>!a))).subscribe({next({active:a}){a?(e.insertAdjacentElement("afterend",o),e.setAttribute("aria-describedby",r),e.removeAttribute("title")):(o.remove(),e.removeAttribute("aria-describedby"),e.setAttribute("title",t))},complete(){o.remove(),e.removeAttribute("aria-describedby"),e.setAttribute("title",t)}}),i.pipe(Le(16,me)).subscribe(({active:a})=>{o.classList.toggle("md-tooltip--active",a)}),i.pipe(pt(125,me),b(()=>!!e.offsetParent),m(()=>e.offsetParent.getBoundingClientRect()),m(({x:a})=>a)).subscribe({next(a){a?o.style.setProperty("--md-tooltip-0",`${-a}px`):o.style.removeProperty("--md-tooltip-0")},complete(){o.style.removeProperty("--md-tooltip-0")}}),Ba(o,e).pipe(E(a=>i.next(a)),L(()=>i.complete()),m(a=>$({ref:e},a)))}).pipe(Ke(se))}function Ga({viewport$:e}){if(!B("header.autohide"))return I(!1);let t=e.pipe(m(({offset:{y:n}})=>n),Be(2,1),m(([n,i])=>[nMath.abs(i-n.y)>100),m(([,[n]])=>n),K()),o=ze("search");return z([e,o]).pipe(m(([{offset:n},i])=>n.y>400&&!i),K(),v(n=>n?r:I(!1)),Q(!1))}function Qn(e,t){return C(()=>z([ge(e),Ga(t)])).pipe(m(([{height:r},o])=>({height:r,hidden:o})),K((r,o)=>r.height===o.height&&r.hidden===o.hidden),G(1))}function Kn(e,{header$:t,main$:r}){return C(()=>{let o=new g,n=o.pipe(X(),ne(!0));o.pipe(Z("active"),ke(t)).subscribe(([{active:a},{hidden:s}])=>{e.classList.toggle("md-header--shadow",a&&!s),e.hidden=s});let i=ue(P("[title]",e)).pipe(b(()=>B("content.tooltips")),oe(a=>qn(a)));return r.subscribe(o),t.pipe(U(n),m(a=>$({ref:e},a)),Re(i.pipe(U(n))))})}function Ja(e,{viewport$:t,header$:r}){return mr(e,{viewport$:t,header$:r}).pipe(m(({offset:{y:o}})=>{let{height:n}=ce(e);return{active:o>=n}}),Z("active"))}function Yn(e,t){return C(()=>{let r=new g;r.subscribe({next({active:n}){e.classList.toggle("md-header__title--active",n)},complete(){e.classList.remove("md-header__title--active")}});let o=fe(".md-content h1");return typeof o=="undefined"?S:Ja(o,t).pipe(E(n=>r.next(n)),L(()=>r.complete()),m(n=>$({ref:e},n)))})}function Bn(e,{viewport$:t,header$:r}){let o=r.pipe(m(({height:i})=>i),K()),n=o.pipe(v(()=>ge(e).pipe(m(({height:i})=>({top:e.offsetTop,bottom:e.offsetTop+i})),Z("bottom"))));return z([o,n,t]).pipe(m(([i,{top:a,bottom:s},{offset:{y:p},size:{height:c}}])=>(c=Math.max(0,c-Math.max(0,a-p,i)-Math.max(0,c+p-s)),{offset:a-i,height:c,active:a-i<=p})),K((i,a)=>i.offset===a.offset&&i.height===a.height&&i.active===a.active))}function Xa(e){let t=__md_get("__palette")||{index:e.findIndex(o=>matchMedia(o.getAttribute("data-md-color-media")).matches)},r=Math.max(0,Math.min(t.index,e.length-1));return I(...e).pipe(oe(o=>d(o,"change").pipe(m(()=>o))),Q(e[r]),m(o=>({index:e.indexOf(o),color:{media:o.getAttribute("data-md-color-media"),scheme:o.getAttribute("data-md-color-scheme"),primary:o.getAttribute("data-md-color-primary"),accent:o.getAttribute("data-md-color-accent")}})),G(1))}function Gn(e){let t=P("input",e),r=x("meta",{name:"theme-color"});document.head.appendChild(r);let o=x("meta",{name:"color-scheme"});document.head.appendChild(o);let n=Pt("(prefers-color-scheme: light)");return C(()=>{let i=new g;return i.subscribe(a=>{if(document.body.setAttribute("data-md-color-switching",""),a.color.media==="(prefers-color-scheme)"){let s=matchMedia("(prefers-color-scheme: light)"),p=document.querySelector(s.matches?"[data-md-color-media='(prefers-color-scheme: light)']":"[data-md-color-media='(prefers-color-scheme: dark)']");a.color.scheme=p.getAttribute("data-md-color-scheme"),a.color.primary=p.getAttribute("data-md-color-primary"),a.color.accent=p.getAttribute("data-md-color-accent")}for(let[s,p]of Object.entries(a.color))document.body.setAttribute(`data-md-color-${s}`,p);for(let s=0;sa.key==="Enter"),ee(i,(a,s)=>s)).subscribe(({index:a})=>{a=(a+1)%t.length,t[a].click(),t[a].focus()}),i.pipe(m(()=>{let a=Se("header"),s=window.getComputedStyle(a);return o.content=s.colorScheme,s.backgroundColor.match(/\d+/g).map(p=>(+p).toString(16).padStart(2,"0")).join("")})).subscribe(a=>r.content=`#${a}`),i.pipe(ve(se)).subscribe(()=>{document.body.removeAttribute("data-md-color-switching")}),Xa(t).pipe(U(n.pipe(Ce(1))),ct(),E(a=>i.next(a)),L(()=>i.complete()),m(a=>$({ref:e},a)))})}function Jn(e,{progress$:t}){return C(()=>{let r=new g;return r.subscribe(({value:o})=>{e.style.setProperty("--md-progress-value",`${o}`)}),t.pipe(E(o=>r.next({value:o})),L(()=>r.complete()),m(o=>({ref:e,value:o})))})}var Jr=Lt(Br());function Za(e){e.setAttribute("data-md-copying","");let t=e.closest("[data-copy]"),r=t?t.getAttribute("data-copy"):e.innerText;return e.removeAttribute("data-md-copying"),r.trimEnd()}function Xn({alert$:e}){Jr.default.isSupported()&&new F(t=>{new Jr.default("[data-clipboard-target], [data-clipboard-text]",{text:r=>r.getAttribute("data-clipboard-text")||Za(R(r.getAttribute("data-clipboard-target")))}).on("success",r=>t.next(r))}).pipe(E(t=>{t.trigger.focus()}),m(()=>Ee("clipboard.copied"))).subscribe(e)}function Zn(e,t){return e.protocol=t.protocol,e.hostname=t.hostname,e}function es(e,t){let r=new Map;for(let o of P("url",e)){let n=R("loc",o),i=[Zn(new URL(n.textContent),t)];r.set(`${i[0]}`,i);for(let a of P("[rel=alternate]",o)){let s=a.getAttribute("href");s!=null&&i.push(Zn(new URL(s),t))}}return r}function ur(e){return fn(new URL("sitemap.xml",e)).pipe(m(t=>es(t,new URL(e))),de(()=>I(new Map)))}function ts(e,t){if(!(e.target instanceof Element))return S;let r=e.target.closest("a");if(r===null)return S;if(r.target||e.metaKey||e.ctrlKey)return S;let o=new URL(r.href);return o.search=o.hash="",t.has(`${o}`)?(e.preventDefault(),I(new URL(r.href))):S}function ei(e){let t=new Map;for(let r of P(":scope > *",e.head))t.set(r.outerHTML,r);return t}function ti(e){for(let t of P("[href], [src]",e))for(let r of["href","src"]){let o=t.getAttribute(r);if(o&&!/^(?:[a-z]+:)?\/\//i.test(o)){t[r]=t[r];break}}return I(e)}function rs(e){for(let o of["[data-md-component=announce]","[data-md-component=container]","[data-md-component=header-topic]","[data-md-component=outdated]","[data-md-component=logo]","[data-md-component=skip]",...B("navigation.tabs.sticky")?["[data-md-component=tabs]"]:[]]){let n=fe(o),i=fe(o,e);typeof n!="undefined"&&typeof i!="undefined"&&n.replaceWith(i)}let t=ei(document);for(let[o,n]of ei(e))t.has(o)?t.delete(o):document.head.appendChild(n);for(let o of t.values()){let n=o.getAttribute("name");n!=="theme-color"&&n!=="color-scheme"&&o.remove()}let r=Se("container");return Ue(P("script",r)).pipe(v(o=>{let n=e.createElement("script");if(o.src){for(let i of o.getAttributeNames())n.setAttribute(i,o.getAttribute(i));return o.replaceWith(n),new F(i=>{n.onload=()=>i.complete()})}else return n.textContent=o.textContent,o.replaceWith(n),S}),X(),ne(document))}function ri({location$:e,viewport$:t,progress$:r}){let o=ye();if(location.protocol==="file:")return S;let n=ur(o.base);I(document).subscribe(ti);let i=d(document.body,"click").pipe(ke(n),v(([p,c])=>ts(p,c)),pe()),a=d(window,"popstate").pipe(m(xe),pe());i.pipe(ee(t)).subscribe(([p,{offset:c}])=>{history.replaceState(c,""),history.pushState(null,"",p)}),O(i,a).subscribe(e);let s=e.pipe(Z("pathname"),v(p=>mn(p,{progress$:r}).pipe(de(()=>(lt(p,!0),S)))),v(ti),v(rs),pe());return O(s.pipe(ee(e,(p,c)=>c)),s.pipe(v(()=>e),Z("pathname"),v(()=>e),Z("hash")),e.pipe(K((p,c)=>p.pathname===c.pathname&&p.hash===c.hash),v(()=>i),E(()=>history.back()))).subscribe(p=>{var c,l;history.state!==null||!p.hash?window.scrollTo(0,(l=(c=history.state)==null?void 0:c.y)!=null?l:0):(history.scrollRestoration="auto",cn(p.hash),history.scrollRestoration="manual")}),e.subscribe(()=>{history.scrollRestoration="manual"}),d(window,"beforeunload").subscribe(()=>{history.scrollRestoration="auto"}),t.pipe(Z("offset"),_e(100)).subscribe(({offset:p})=>{history.replaceState(p,"")}),s}var oi=Lt(qr());function ni(e){let t=e.separator.split("|").map(n=>n.replace(/(\(\?[!=<][^)]+\))/g,"").length===0?"\uFFFD":n).join("|"),r=new RegExp(t,"img"),o=(n,i,a)=>`${i}${a}`;return n=>{n=n.replace(/[\s*+\-:~^]+/g," ").trim();let i=new RegExp(`(^|${e.separator}|)(${n.replace(/[|\\{}()[\]^$+*?.-]/g,"\\$&").replace(r,"|")})`,"img");return a=>(0,oi.default)(a).replace(i,o).replace(/<\/mark>(\s+)]*>/img,"$1")}}function Ft(e){return e.type===1}function dr(e){return e.type===3}function ii(e,t){let r=gn(e);return O(I(location.protocol!=="file:"),ze("search")).pipe(Ae(o=>o),v(()=>t)).subscribe(({config:o,docs:n})=>r.next({type:0,data:{config:o,docs:n,options:{suggest:B("search.suggest")}}})),r}function ai({document$:e}){let t=ye(),r=Fe(new URL("../versions.json",t.base)).pipe(de(()=>S)),o=r.pipe(m(n=>{let[,i]=t.base.match(/([^/]+)\/?$/);return n.find(({version:a,aliases:s})=>a===i||s.includes(i))||n[0]}));r.pipe(m(n=>new Map(n.map(i=>[`${new URL(`../${i.version}/`,t.base)}`,i]))),v(n=>d(document.body,"click").pipe(b(i=>!i.metaKey&&!i.ctrlKey),ee(o),v(([i,a])=>{if(i.target instanceof Element){let s=i.target.closest("a");if(s&&!s.target&&n.has(s.href)){let p=s.href;return!i.target.closest(".md-version")&&n.get(p)===a?S:(i.preventDefault(),I(p))}}return S}),v(i=>ur(new URL(i)).pipe(m(a=>{let p=xe().href.replace(t.base,i);return a.has(p.split("#")[0])?new URL(p):new URL(i)})))))).subscribe(n=>lt(n,!0)),z([r,o]).subscribe(([n,i])=>{R(".md-header__topic").appendChild(An(n,i))}),e.pipe(v(()=>o)).subscribe(n=>{var a;let i=__md_get("__outdated",sessionStorage);if(i===null){i=!0;let s=((a=t.version)==null?void 0:a.default)||"latest";Array.isArray(s)||(s=[s]);e:for(let p of s)for(let c of n.aliases.concat(n.version))if(new RegExp(p,"i").test(c)){i=!1;break e}__md_set("__outdated",i,sessionStorage)}if(i)for(let s of ae("outdated"))s.hidden=!1})}function is(e,{worker$:t}){let{searchParams:r}=xe();r.has("q")&&(Je("search",!0),e.value=r.get("q"),e.focus(),ze("search").pipe(Ae(i=>!i)).subscribe(()=>{let i=xe();i.searchParams.delete("q"),history.replaceState({},"",`${i}`)}));let o=et(e),n=O(t.pipe(Ae(Ft)),d(e,"keyup"),o).pipe(m(()=>e.value),K());return z([n,o]).pipe(m(([i,a])=>({value:i,focus:a})),G(1))}function si(e,{worker$:t}){let r=new g,o=r.pipe(X(),ne(!0));z([t.pipe(Ae(Ft)),r],(i,a)=>a).pipe(Z("value")).subscribe(({value:i})=>t.next({type:2,data:i})),r.pipe(Z("focus")).subscribe(({focus:i})=>{i&&Je("search",i)}),d(e.form,"reset").pipe(U(o)).subscribe(()=>e.focus());let n=R("header [for=__search]");return d(n,"click").subscribe(()=>e.focus()),is(e,{worker$:t}).pipe(E(i=>r.next(i)),L(()=>r.complete()),m(i=>$({ref:e},i)),G(1))}function ci(e,{worker$:t,query$:r}){let o=new g,n=rn(e.parentElement).pipe(b(Boolean)),i=e.parentElement,a=R(":scope > :first-child",e),s=R(":scope > :last-child",e);ze("search").subscribe(l=>s.setAttribute("role",l?"list":"presentation")),o.pipe(ee(r),Ur(t.pipe(Ae(Ft)))).subscribe(([{items:l},{value:f}])=>{switch(l.length){case 0:a.textContent=f.length?Ee("search.result.none"):Ee("search.result.placeholder");break;case 1:a.textContent=Ee("search.result.one");break;default:let u=sr(l.length);a.textContent=Ee("search.result.other",u)}});let p=o.pipe(E(()=>s.innerHTML=""),v(({items:l})=>O(I(...l.slice(0,10)),I(...l.slice(10)).pipe(Be(4),Vr(n),v(([f])=>f)))),m(Mn),pe());return p.subscribe(l=>s.appendChild(l)),p.pipe(oe(l=>{let f=fe("details",l);return typeof f=="undefined"?S:d(f,"toggle").pipe(U(o),m(()=>f))})).subscribe(l=>{l.open===!1&&l.offsetTop<=i.scrollTop&&i.scrollTo({top:l.offsetTop})}),t.pipe(b(dr),m(({data:l})=>l)).pipe(E(l=>o.next(l)),L(()=>o.complete()),m(l=>$({ref:e},l)))}function as(e,{query$:t}){return t.pipe(m(({value:r})=>{let o=xe();return o.hash="",r=r.replace(/\s+/g,"+").replace(/&/g,"%26").replace(/=/g,"%3D"),o.search=`q=${r}`,{url:o}}))}function pi(e,t){let r=new g,o=r.pipe(X(),ne(!0));return r.subscribe(({url:n})=>{e.setAttribute("data-clipboard-text",e.href),e.href=`${n}`}),d(e,"click").pipe(U(o)).subscribe(n=>n.preventDefault()),as(e,t).pipe(E(n=>r.next(n)),L(()=>r.complete()),m(n=>$({ref:e},n)))}function li(e,{worker$:t,keyboard$:r}){let o=new g,n=Se("search-query"),i=O(d(n,"keydown"),d(n,"focus")).pipe(ve(se),m(()=>n.value),K());return o.pipe(ke(i),m(([{suggest:s},p])=>{let c=p.split(/([\s-]+)/);if(s!=null&&s.length&&c[c.length-1]){let l=s[s.length-1];l.startsWith(c[c.length-1])&&(c[c.length-1]=l)}else c.length=0;return c})).subscribe(s=>e.innerHTML=s.join("").replace(/\s/g," ")),r.pipe(b(({mode:s})=>s==="search")).subscribe(s=>{switch(s.type){case"ArrowRight":e.innerText.length&&n.selectionStart===n.value.length&&(n.value=e.innerText);break}}),t.pipe(b(dr),m(({data:s})=>s)).pipe(E(s=>o.next(s)),L(()=>o.complete()),m(()=>({ref:e})))}function mi(e,{index$:t,keyboard$:r}){let o=ye();try{let n=ii(o.search,t),i=Se("search-query",e),a=Se("search-result",e);d(e,"click").pipe(b(({target:p})=>p instanceof Element&&!!p.closest("a"))).subscribe(()=>Je("search",!1)),r.pipe(b(({mode:p})=>p==="search")).subscribe(p=>{let c=Ie();switch(p.type){case"Enter":if(c===i){let l=new Map;for(let f of P(":first-child [href]",a)){let u=f.firstElementChild;l.set(f,parseFloat(u.getAttribute("data-md-score")))}if(l.size){let[[f]]=[...l].sort(([,u],[,h])=>h-u);f.click()}p.claim()}break;case"Escape":case"Tab":Je("search",!1),i.blur();break;case"ArrowUp":case"ArrowDown":if(typeof c=="undefined")i.focus();else{let l=[i,...P(":not(details) > [href], summary, details[open] [href]",a)],f=Math.max(0,(Math.max(0,l.indexOf(c))+l.length+(p.type==="ArrowUp"?-1:1))%l.length);l[f].focus()}p.claim();break;default:i!==Ie()&&i.focus()}}),r.pipe(b(({mode:p})=>p==="global")).subscribe(p=>{switch(p.type){case"f":case"s":case"/":i.focus(),i.select(),p.claim();break}});let s=si(i,{worker$:n});return O(s,ci(a,{worker$:n,query$:s})).pipe(Re(...ae("search-share",e).map(p=>pi(p,{query$:s})),...ae("search-suggest",e).map(p=>li(p,{worker$:n,keyboard$:r}))))}catch(n){return e.hidden=!0,Ye}}function fi(e,{index$:t,location$:r}){return z([t,r.pipe(Q(xe()),b(o=>!!o.searchParams.get("h")))]).pipe(m(([o,n])=>ni(o.config)(n.searchParams.get("h"))),m(o=>{var a;let n=new Map,i=document.createNodeIterator(e,NodeFilter.SHOW_TEXT);for(let s=i.nextNode();s;s=i.nextNode())if((a=s.parentElement)!=null&&a.offsetHeight){let p=s.textContent,c=o(p);c.length>p.length&&n.set(s,c)}for(let[s,p]of n){let{childNodes:c}=x("span",null,p);s.replaceWith(...Array.from(c))}return{ref:e,nodes:n}}))}function ss(e,{viewport$:t,main$:r}){let o=e.closest(".md-grid"),n=o.offsetTop-o.parentElement.offsetTop;return z([r,t]).pipe(m(([{offset:i,height:a},{offset:{y:s}}])=>(a=a+Math.min(n,Math.max(0,s-i))-n,{height:a,locked:s>=i+n})),K((i,a)=>i.height===a.height&&i.locked===a.locked))}function Xr(e,o){var n=o,{header$:t}=n,r=ao(n,["header$"]);let i=R(".md-sidebar__scrollwrap",e),{y:a}=Ve(i);return C(()=>{let s=new g,p=s.pipe(X(),ne(!0)),c=s.pipe(Le(0,me));return c.pipe(ee(t)).subscribe({next([{height:l},{height:f}]){i.style.height=`${l-2*a}px`,e.style.top=`${f}px`},complete(){i.style.height="",e.style.top=""}}),c.pipe(Ae()).subscribe(()=>{for(let l of P(".md-nav__link--active[href]",e)){if(!l.clientHeight)continue;let f=l.closest(".md-sidebar__scrollwrap");if(typeof f!="undefined"){let u=l.offsetTop-f.offsetTop,{height:h}=ce(f);f.scrollTo({top:u-h/2})}}}),ue(P("label[tabindex]",e)).pipe(oe(l=>d(l,"click").pipe(ve(se),m(()=>l),U(p)))).subscribe(l=>{let f=R(`[id="${l.htmlFor}"]`);R(`[aria-labelledby="${l.id}"]`).setAttribute("aria-expanded",`${f.checked}`)}),ss(e,r).pipe(E(l=>s.next(l)),L(()=>s.complete()),m(l=>$({ref:e},l)))})}function ui(e,t){if(typeof t!="undefined"){let r=`https://api.github.com/repos/${e}/${t}`;return st(Fe(`${r}/releases/latest`).pipe(de(()=>S),m(o=>({version:o.tag_name})),De({})),Fe(r).pipe(de(()=>S),m(o=>({stars:o.stargazers_count,forks:o.forks_count})),De({}))).pipe(m(([o,n])=>$($({},o),n)))}else{let r=`https://api.github.com/users/${e}`;return Fe(r).pipe(m(o=>({repositories:o.public_repos})),De({}))}}function di(e,t){let r=`https://${e}/api/v4/projects/${encodeURIComponent(t)}`;return st(Fe(`${r}/releases/permalink/latest`).pipe(de(()=>S),m(({tag_name:o})=>({version:o})),De({})),Fe(r).pipe(de(()=>S),m(({star_count:o,forks_count:n})=>({stars:o,forks:n})),De({}))).pipe(m(([o,n])=>$($({},o),n)))}function hi(e){let t=e.match(/^.+github\.com\/([^/]+)\/?([^/]+)?/i);if(t){let[,r,o]=t;return ui(r,o)}if(t=e.match(/^.+?([^/]*gitlab[^/]+)\/(.+?)\/?$/i),t){let[,r,o]=t;return di(r,o)}return S}var cs;function ps(e){return cs||(cs=C(()=>{let t=__md_get("__source",sessionStorage);if(t)return I(t);if(ae("consent").length){let o=__md_get("__consent");if(!(o&&o.github))return S}return hi(e.href).pipe(E(o=>__md_set("__source",o,sessionStorage)))}).pipe(de(()=>S),b(t=>Object.keys(t).length>0),m(t=>({facts:t})),G(1)))}function bi(e){let t=R(":scope > :last-child",e);return C(()=>{let r=new g;return r.subscribe(({facts:o})=>{t.appendChild(Ln(o)),t.classList.add("md-source__repository--active")}),ps(e).pipe(E(o=>r.next(o)),L(()=>r.complete()),m(o=>$({ref:e},o)))})}function ls(e,{viewport$:t,header$:r}){return ge(document.body).pipe(v(()=>mr(e,{header$:r,viewport$:t})),m(({offset:{y:o}})=>({hidden:o>=10})),Z("hidden"))}function vi(e,t){return C(()=>{let r=new g;return r.subscribe({next({hidden:o}){e.hidden=o},complete(){e.hidden=!1}}),(B("navigation.tabs.sticky")?I({hidden:!1}):ls(e,t)).pipe(E(o=>r.next(o)),L(()=>r.complete()),m(o=>$({ref:e},o)))})}function ms(e,{viewport$:t,header$:r}){let o=new Map,n=P(".md-nav__link",e);for(let s of n){let p=decodeURIComponent(s.hash.substring(1)),c=fe(`[id="${p}"]`);typeof c!="undefined"&&o.set(s,c)}let i=r.pipe(Z("height"),m(({height:s})=>{let p=Se("main"),c=R(":scope > :first-child",p);return s+.8*(c.offsetTop-p.offsetTop)}),pe());return ge(document.body).pipe(Z("height"),v(s=>C(()=>{let p=[];return I([...o].reduce((c,[l,f])=>{for(;p.length&&o.get(p[p.length-1]).tagName>=f.tagName;)p.pop();let u=f.offsetTop;for(;!u&&f.parentElement;)f=f.parentElement,u=f.offsetTop;let h=f.offsetParent;for(;h;h=h.offsetParent)u+=h.offsetTop;return c.set([...p=[...p,l]].reverse(),u)},new Map))}).pipe(m(p=>new Map([...p].sort(([,c],[,l])=>c-l))),ke(i),v(([p,c])=>t.pipe(jr(([l,f],{offset:{y:u},size:h})=>{let w=u+h.height>=Math.floor(s.height);for(;f.length;){let[,A]=f[0];if(A-c=u&&!w)f=[l.pop(),...f];else break}return[l,f]},[[],[...p]]),K((l,f)=>l[0]===f[0]&&l[1]===f[1])))))).pipe(m(([s,p])=>({prev:s.map(([c])=>c),next:p.map(([c])=>c)})),Q({prev:[],next:[]}),Be(2,1),m(([s,p])=>s.prev.length{let i=new g,a=i.pipe(X(),ne(!0));if(i.subscribe(({prev:s,next:p})=>{for(let[c]of p)c.classList.remove("md-nav__link--passed"),c.classList.remove("md-nav__link--active");for(let[c,[l]]of s.entries())l.classList.add("md-nav__link--passed"),l.classList.toggle("md-nav__link--active",c===s.length-1)}),B("toc.follow")){let s=O(t.pipe(_e(1),m(()=>{})),t.pipe(_e(250),m(()=>"smooth")));i.pipe(b(({prev:p})=>p.length>0),ke(o.pipe(ve(se))),ee(s)).subscribe(([[{prev:p}],c])=>{let[l]=p[p.length-1];if(l.offsetHeight){let f=cr(l);if(typeof f!="undefined"){let u=l.offsetTop-f.offsetTop,{height:h}=ce(f);f.scrollTo({top:u-h/2,behavior:c})}}})}return B("navigation.tracking")&&t.pipe(U(a),Z("offset"),_e(250),Ce(1),U(n.pipe(Ce(1))),ct({delay:250}),ee(i)).subscribe(([,{prev:s}])=>{let p=xe(),c=s[s.length-1];if(c&&c.length){let[l]=c,{hash:f}=new URL(l.href);p.hash!==f&&(p.hash=f,history.replaceState({},"",`${p}`))}else p.hash="",history.replaceState({},"",`${p}`)}),ms(e,{viewport$:t,header$:r}).pipe(E(s=>i.next(s)),L(()=>i.complete()),m(s=>$({ref:e},s)))})}function fs(e,{viewport$:t,main$:r,target$:o}){let n=t.pipe(m(({offset:{y:a}})=>a),Be(2,1),m(([a,s])=>a>s&&s>0),K()),i=r.pipe(m(({active:a})=>a));return z([i,n]).pipe(m(([a,s])=>!(a&&s)),K(),U(o.pipe(Ce(1))),ne(!0),ct({delay:250}),m(a=>({hidden:a})))}function xi(e,{viewport$:t,header$:r,main$:o,target$:n}){let i=new g,a=i.pipe(X(),ne(!0));return i.subscribe({next({hidden:s}){e.hidden=s,s?(e.setAttribute("tabindex","-1"),e.blur()):e.removeAttribute("tabindex")},complete(){e.style.top="",e.hidden=!0,e.removeAttribute("tabindex")}}),r.pipe(U(a),Z("height")).subscribe(({height:s})=>{e.style.top=`${s+16}px`}),d(e,"click").subscribe(s=>{s.preventDefault(),window.scrollTo({top:0})}),fs(e,{viewport$:t,main$:o,target$:n}).pipe(E(s=>i.next(s)),L(()=>i.complete()),m(s=>$({ref:e},s)))}function yi({document$:e,viewport$:t}){e.pipe(v(()=>P(".md-ellipsis")),oe(r=>tt(r).pipe(U(e.pipe(Ce(1))),b(o=>o),m(()=>r),Te(1))),b(r=>r.offsetWidth{let o=r.innerText,n=r.closest("a")||r;return n.title=o,B("content.tooltips")?mt(n,{viewport$:t}).pipe(U(e.pipe(Ce(1))),L(()=>n.removeAttribute("title"))):S})).subscribe(),B("content.tooltips")&&e.pipe(v(()=>P(".md-status")),oe(r=>mt(r,{viewport$:t}))).subscribe()}function Ei({document$:e,tablet$:t}){e.pipe(v(()=>P(".md-toggle--indeterminate")),E(r=>{r.indeterminate=!0,r.checked=!1}),oe(r=>d(r,"change").pipe(Dr(()=>r.classList.contains("md-toggle--indeterminate")),m(()=>r))),ee(t)).subscribe(([r,o])=>{r.classList.remove("md-toggle--indeterminate"),o&&(r.checked=!1)})}function us(){return/(iPad|iPhone|iPod)/.test(navigator.userAgent)}function wi({document$:e}){e.pipe(v(()=>P("[data-md-scrollfix]")),E(t=>t.removeAttribute("data-md-scrollfix")),b(us),oe(t=>d(t,"touchstart").pipe(m(()=>t)))).subscribe(t=>{let r=t.scrollTop;r===0?t.scrollTop=1:r+t.offsetHeight===t.scrollHeight&&(t.scrollTop=r-1)})}function Ti({viewport$:e,tablet$:t}){z([ze("search"),t]).pipe(m(([r,o])=>r&&!o),v(r=>I(r).pipe(Ge(r?400:100))),ee(e)).subscribe(([r,{offset:{y:o}}])=>{if(r)document.body.setAttribute("data-md-scrolllock",""),document.body.style.top=`-${o}px`;else{let n=-1*parseInt(document.body.style.top,10);document.body.removeAttribute("data-md-scrolllock"),document.body.style.top="",n&&window.scrollTo(0,n)}})}Object.entries||(Object.entries=function(e){let t=[];for(let r of Object.keys(e))t.push([r,e[r]]);return t});Object.values||(Object.values=function(e){let t=[];for(let r of Object.keys(e))t.push(e[r]);return t});typeof Element!="undefined"&&(Element.prototype.scrollTo||(Element.prototype.scrollTo=function(e,t){typeof e=="object"?(this.scrollLeft=e.left,this.scrollTop=e.top):(this.scrollLeft=e,this.scrollTop=t)}),Element.prototype.replaceWith||(Element.prototype.replaceWith=function(...e){let t=this.parentNode;if(t){e.length===0&&t.removeChild(this);for(let r=e.length-1;r>=0;r--){let o=e[r];typeof o=="string"?o=document.createTextNode(o):o.parentNode&&o.parentNode.removeChild(o),r?t.insertBefore(this.previousSibling,o):t.replaceChild(o,this)}}}));function ds(){return location.protocol==="file:"?Tt(`${new URL("search/search_index.js",Zr.base)}`).pipe(m(()=>__index),G(1)):Fe(new URL("search/search_index.json",Zr.base))}document.documentElement.classList.remove("no-js");document.documentElement.classList.add("js");var ot=Bo(),Wt=an(),Mt=pn(Wt),eo=nn(),Oe=vn(),hr=Pt("(min-width: 960px)"),Oi=Pt("(min-width: 1220px)"),Mi=ln(),Zr=ye(),Li=document.forms.namedItem("search")?ds():Ye,to=new g;Xn({alert$:to});var ro=new g;B("navigation.instant")&&ri({location$:Wt,viewport$:Oe,progress$:ro}).subscribe(ot);var Si;((Si=Zr.version)==null?void 0:Si.provider)==="mike"&&ai({document$:ot});O(Wt,Mt).pipe(Ge(125)).subscribe(()=>{Je("drawer",!1),Je("search",!1)});eo.pipe(b(({mode:e})=>e==="global")).subscribe(e=>{switch(e.type){case"p":case",":let t=fe("link[rel=prev]");typeof t!="undefined"&<(t);break;case"n":case".":let r=fe("link[rel=next]");typeof r!="undefined"&<(r);break;case"Enter":let o=Ie();o instanceof HTMLLabelElement&&o.click()}});yi({viewport$:Oe,document$:ot});Ei({document$:ot,tablet$:hr});wi({document$:ot});Ti({viewport$:Oe,tablet$:hr});var rt=Qn(Se("header"),{viewport$:Oe}),jt=ot.pipe(m(()=>Se("main")),v(e=>Bn(e,{viewport$:Oe,header$:rt})),G(1)),hs=O(...ae("consent").map(e=>yn(e,{target$:Mt})),...ae("dialog").map(e=>zn(e,{alert$:to})),...ae("header").map(e=>Kn(e,{viewport$:Oe,header$:rt,main$:jt})),...ae("palette").map(e=>Gn(e)),...ae("progress").map(e=>Jn(e,{progress$:ro})),...ae("search").map(e=>mi(e,{index$:Li,keyboard$:eo})),...ae("source").map(e=>bi(e))),bs=C(()=>O(...ae("announce").map(e=>xn(e)),...ae("content").map(e=>Nn(e,{viewport$:Oe,target$:Mt,print$:Mi})),...ae("content").map(e=>B("search.highlight")?fi(e,{index$:Li,location$:Wt}):S),...ae("header-title").map(e=>Yn(e,{viewport$:Oe,header$:rt})),...ae("sidebar").map(e=>e.getAttribute("data-md-type")==="navigation"?Nr(Oi,()=>Xr(e,{viewport$:Oe,header$:rt,main$:jt})):Nr(hr,()=>Xr(e,{viewport$:Oe,header$:rt,main$:jt}))),...ae("tabs").map(e=>vi(e,{viewport$:Oe,header$:rt})),...ae("toc").map(e=>gi(e,{viewport$:Oe,header$:rt,main$:jt,target$:Mt})),...ae("top").map(e=>xi(e,{viewport$:Oe,header$:rt,main$:jt,target$:Mt})))),_i=ot.pipe(v(()=>bs),Re(hs),G(1));_i.subscribe();window.document$=ot;window.location$=Wt;window.target$=Mt;window.keyboard$=eo;window.viewport$=Oe;window.tablet$=hr;window.screen$=Oi;window.print$=Mi;window.alert$=to;window.progress$=ro;window.component$=_i;})(); +//# sourceMappingURL=bundle.af256bd8.min.js.map + diff --git a/0.6.0/assets/javascripts/bundle.af256bd8.min.js.map b/0.6.0/assets/javascripts/bundle.af256bd8.min.js.map new file mode 100644 index 0000000..0501d11 --- /dev/null +++ b/0.6.0/assets/javascripts/bundle.af256bd8.min.js.map @@ -0,0 +1,7 @@ +{ + "version": 3, + "sources": ["node_modules/focus-visible/dist/focus-visible.js", "node_modules/escape-html/index.js", "node_modules/clipboard/dist/clipboard.js", "src/templates/assets/javascripts/bundle.ts", "node_modules/rxjs/node_modules/tslib/tslib.es6.js", "node_modules/rxjs/src/internal/util/isFunction.ts", "node_modules/rxjs/src/internal/util/createErrorClass.ts", "node_modules/rxjs/src/internal/util/UnsubscriptionError.ts", "node_modules/rxjs/src/internal/util/arrRemove.ts", "node_modules/rxjs/src/internal/Subscription.ts", "node_modules/rxjs/src/internal/config.ts", "node_modules/rxjs/src/internal/scheduler/timeoutProvider.ts", "node_modules/rxjs/src/internal/util/reportUnhandledError.ts", "node_modules/rxjs/src/internal/util/noop.ts", "node_modules/rxjs/src/internal/NotificationFactories.ts", "node_modules/rxjs/src/internal/util/errorContext.ts", "node_modules/rxjs/src/internal/Subscriber.ts", "node_modules/rxjs/src/internal/symbol/observable.ts", "node_modules/rxjs/src/internal/util/identity.ts", "node_modules/rxjs/src/internal/util/pipe.ts", "node_modules/rxjs/src/internal/Observable.ts", "node_modules/rxjs/src/internal/util/lift.ts", "node_modules/rxjs/src/internal/operators/OperatorSubscriber.ts", "node_modules/rxjs/src/internal/scheduler/animationFrameProvider.ts", "node_modules/rxjs/src/internal/util/ObjectUnsubscribedError.ts", "node_modules/rxjs/src/internal/Subject.ts", "node_modules/rxjs/src/internal/BehaviorSubject.ts", "node_modules/rxjs/src/internal/scheduler/dateTimestampProvider.ts", "node_modules/rxjs/src/internal/ReplaySubject.ts", "node_modules/rxjs/src/internal/scheduler/Action.ts", "node_modules/rxjs/src/internal/scheduler/intervalProvider.ts", "node_modules/rxjs/src/internal/scheduler/AsyncAction.ts", "node_modules/rxjs/src/internal/Scheduler.ts", "node_modules/rxjs/src/internal/scheduler/AsyncScheduler.ts", "node_modules/rxjs/src/internal/scheduler/async.ts", "node_modules/rxjs/src/internal/scheduler/QueueAction.ts", "node_modules/rxjs/src/internal/scheduler/QueueScheduler.ts", "node_modules/rxjs/src/internal/scheduler/queue.ts", "node_modules/rxjs/src/internal/scheduler/AnimationFrameAction.ts", "node_modules/rxjs/src/internal/scheduler/AnimationFrameScheduler.ts", "node_modules/rxjs/src/internal/scheduler/animationFrame.ts", "node_modules/rxjs/src/internal/observable/empty.ts", "node_modules/rxjs/src/internal/util/isScheduler.ts", "node_modules/rxjs/src/internal/util/args.ts", "node_modules/rxjs/src/internal/util/isArrayLike.ts", "node_modules/rxjs/src/internal/util/isPromise.ts", "node_modules/rxjs/src/internal/util/isInteropObservable.ts", "node_modules/rxjs/src/internal/util/isAsyncIterable.ts", "node_modules/rxjs/src/internal/util/throwUnobservableError.ts", "node_modules/rxjs/src/internal/symbol/iterator.ts", "node_modules/rxjs/src/internal/util/isIterable.ts", "node_modules/rxjs/src/internal/util/isReadableStreamLike.ts", "node_modules/rxjs/src/internal/observable/innerFrom.ts", "node_modules/rxjs/src/internal/util/executeSchedule.ts", "node_modules/rxjs/src/internal/operators/observeOn.ts", "node_modules/rxjs/src/internal/operators/subscribeOn.ts", "node_modules/rxjs/src/internal/scheduled/scheduleObservable.ts", "node_modules/rxjs/src/internal/scheduled/schedulePromise.ts", "node_modules/rxjs/src/internal/scheduled/scheduleArray.ts", "node_modules/rxjs/src/internal/scheduled/scheduleIterable.ts", "node_modules/rxjs/src/internal/scheduled/scheduleAsyncIterable.ts", "node_modules/rxjs/src/internal/scheduled/scheduleReadableStreamLike.ts", "node_modules/rxjs/src/internal/scheduled/scheduled.ts", "node_modules/rxjs/src/internal/observable/from.ts", "node_modules/rxjs/src/internal/observable/of.ts", "node_modules/rxjs/src/internal/observable/throwError.ts", "node_modules/rxjs/src/internal/util/EmptyError.ts", "node_modules/rxjs/src/internal/util/isDate.ts", "node_modules/rxjs/src/internal/operators/map.ts", "node_modules/rxjs/src/internal/util/mapOneOrManyArgs.ts", "node_modules/rxjs/src/internal/util/argsArgArrayOrObject.ts", "node_modules/rxjs/src/internal/util/createObject.ts", "node_modules/rxjs/src/internal/observable/combineLatest.ts", "node_modules/rxjs/src/internal/operators/mergeInternals.ts", "node_modules/rxjs/src/internal/operators/mergeMap.ts", "node_modules/rxjs/src/internal/operators/mergeAll.ts", "node_modules/rxjs/src/internal/operators/concatAll.ts", "node_modules/rxjs/src/internal/observable/concat.ts", "node_modules/rxjs/src/internal/observable/defer.ts", "node_modules/rxjs/src/internal/observable/fromEvent.ts", "node_modules/rxjs/src/internal/observable/fromEventPattern.ts", "node_modules/rxjs/src/internal/observable/timer.ts", "node_modules/rxjs/src/internal/observable/merge.ts", "node_modules/rxjs/src/internal/observable/never.ts", "node_modules/rxjs/src/internal/util/argsOrArgArray.ts", "node_modules/rxjs/src/internal/operators/filter.ts", "node_modules/rxjs/src/internal/observable/zip.ts", "node_modules/rxjs/src/internal/operators/audit.ts", "node_modules/rxjs/src/internal/operators/auditTime.ts", "node_modules/rxjs/src/internal/operators/bufferCount.ts", "node_modules/rxjs/src/internal/operators/catchError.ts", "node_modules/rxjs/src/internal/operators/scanInternals.ts", "node_modules/rxjs/src/internal/operators/combineLatest.ts", "node_modules/rxjs/src/internal/operators/combineLatestWith.ts", "node_modules/rxjs/src/internal/operators/debounce.ts", "node_modules/rxjs/src/internal/operators/debounceTime.ts", "node_modules/rxjs/src/internal/operators/defaultIfEmpty.ts", "node_modules/rxjs/src/internal/operators/take.ts", "node_modules/rxjs/src/internal/operators/ignoreElements.ts", "node_modules/rxjs/src/internal/operators/mapTo.ts", "node_modules/rxjs/src/internal/operators/delayWhen.ts", "node_modules/rxjs/src/internal/operators/delay.ts", "node_modules/rxjs/src/internal/operators/distinctUntilChanged.ts", "node_modules/rxjs/src/internal/operators/distinctUntilKeyChanged.ts", "node_modules/rxjs/src/internal/operators/throwIfEmpty.ts", "node_modules/rxjs/src/internal/operators/endWith.ts", "node_modules/rxjs/src/internal/operators/finalize.ts", "node_modules/rxjs/src/internal/operators/first.ts", "node_modules/rxjs/src/internal/operators/takeLast.ts", "node_modules/rxjs/src/internal/operators/merge.ts", "node_modules/rxjs/src/internal/operators/mergeWith.ts", "node_modules/rxjs/src/internal/operators/repeat.ts", "node_modules/rxjs/src/internal/operators/scan.ts", "node_modules/rxjs/src/internal/operators/share.ts", "node_modules/rxjs/src/internal/operators/shareReplay.ts", "node_modules/rxjs/src/internal/operators/skip.ts", "node_modules/rxjs/src/internal/operators/skipUntil.ts", "node_modules/rxjs/src/internal/operators/startWith.ts", "node_modules/rxjs/src/internal/operators/switchMap.ts", "node_modules/rxjs/src/internal/operators/takeUntil.ts", "node_modules/rxjs/src/internal/operators/takeWhile.ts", "node_modules/rxjs/src/internal/operators/tap.ts", "node_modules/rxjs/src/internal/operators/throttle.ts", "node_modules/rxjs/src/internal/operators/throttleTime.ts", "node_modules/rxjs/src/internal/operators/withLatestFrom.ts", "node_modules/rxjs/src/internal/operators/zip.ts", "node_modules/rxjs/src/internal/operators/zipWith.ts", "src/templates/assets/javascripts/browser/document/index.ts", "src/templates/assets/javascripts/browser/element/_/index.ts", "src/templates/assets/javascripts/browser/element/focus/index.ts", "src/templates/assets/javascripts/browser/element/hover/index.ts", "src/templates/assets/javascripts/utilities/h/index.ts", "src/templates/assets/javascripts/utilities/round/index.ts", "src/templates/assets/javascripts/browser/script/index.ts", "src/templates/assets/javascripts/browser/element/size/_/index.ts", "src/templates/assets/javascripts/browser/element/size/content/index.ts", "src/templates/assets/javascripts/browser/element/offset/_/index.ts", "src/templates/assets/javascripts/browser/element/offset/content/index.ts", "src/templates/assets/javascripts/browser/element/visibility/index.ts", "src/templates/assets/javascripts/browser/toggle/index.ts", "src/templates/assets/javascripts/browser/keyboard/index.ts", "src/templates/assets/javascripts/browser/location/_/index.ts", "src/templates/assets/javascripts/browser/location/hash/index.ts", "src/templates/assets/javascripts/browser/media/index.ts", "src/templates/assets/javascripts/browser/request/index.ts", "src/templates/assets/javascripts/browser/viewport/offset/index.ts", "src/templates/assets/javascripts/browser/viewport/size/index.ts", "src/templates/assets/javascripts/browser/viewport/_/index.ts", "src/templates/assets/javascripts/browser/viewport/at/index.ts", "src/templates/assets/javascripts/browser/worker/index.ts", "src/templates/assets/javascripts/_/index.ts", "src/templates/assets/javascripts/components/_/index.ts", "src/templates/assets/javascripts/components/announce/index.ts", "src/templates/assets/javascripts/components/consent/index.ts", "src/templates/assets/javascripts/templates/tooltip/index.tsx", "src/templates/assets/javascripts/templates/annotation/index.tsx", "src/templates/assets/javascripts/templates/clipboard/index.tsx", "src/templates/assets/javascripts/templates/search/index.tsx", "src/templates/assets/javascripts/templates/source/index.tsx", "src/templates/assets/javascripts/templates/tabbed/index.tsx", "src/templates/assets/javascripts/templates/table/index.tsx", "src/templates/assets/javascripts/templates/version/index.tsx", "src/templates/assets/javascripts/components/tooltip2/index.ts", "src/templates/assets/javascripts/components/content/annotation/_/index.ts", "src/templates/assets/javascripts/components/content/annotation/list/index.ts", "src/templates/assets/javascripts/components/content/annotation/block/index.ts", "src/templates/assets/javascripts/components/content/code/_/index.ts", "src/templates/assets/javascripts/components/content/details/index.ts", "src/templates/assets/javascripts/components/content/mermaid/index.css", "src/templates/assets/javascripts/components/content/mermaid/index.ts", "src/templates/assets/javascripts/components/content/table/index.ts", "src/templates/assets/javascripts/components/content/tabs/index.ts", "src/templates/assets/javascripts/components/content/_/index.ts", "src/templates/assets/javascripts/components/dialog/index.ts", "src/templates/assets/javascripts/components/tooltip/index.ts", "src/templates/assets/javascripts/components/header/_/index.ts", "src/templates/assets/javascripts/components/header/title/index.ts", "src/templates/assets/javascripts/components/main/index.ts", "src/templates/assets/javascripts/components/palette/index.ts", "src/templates/assets/javascripts/components/progress/index.ts", "src/templates/assets/javascripts/integrations/clipboard/index.ts", "src/templates/assets/javascripts/integrations/sitemap/index.ts", "src/templates/assets/javascripts/integrations/instant/index.ts", "src/templates/assets/javascripts/integrations/search/highlighter/index.ts", "src/templates/assets/javascripts/integrations/search/worker/message/index.ts", "src/templates/assets/javascripts/integrations/search/worker/_/index.ts", "src/templates/assets/javascripts/integrations/version/index.ts", "src/templates/assets/javascripts/components/search/query/index.ts", "src/templates/assets/javascripts/components/search/result/index.ts", "src/templates/assets/javascripts/components/search/share/index.ts", "src/templates/assets/javascripts/components/search/suggest/index.ts", "src/templates/assets/javascripts/components/search/_/index.ts", "src/templates/assets/javascripts/components/search/highlight/index.ts", "src/templates/assets/javascripts/components/sidebar/index.ts", "src/templates/assets/javascripts/components/source/facts/github/index.ts", "src/templates/assets/javascripts/components/source/facts/gitlab/index.ts", "src/templates/assets/javascripts/components/source/facts/_/index.ts", "src/templates/assets/javascripts/components/source/_/index.ts", "src/templates/assets/javascripts/components/tabs/index.ts", "src/templates/assets/javascripts/components/toc/index.ts", "src/templates/assets/javascripts/components/top/index.ts", "src/templates/assets/javascripts/patches/ellipsis/index.ts", "src/templates/assets/javascripts/patches/indeterminate/index.ts", "src/templates/assets/javascripts/patches/scrollfix/index.ts", "src/templates/assets/javascripts/patches/scrolllock/index.ts", "src/templates/assets/javascripts/polyfills/index.ts"], + "sourcesContent": ["(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? factory() :\n typeof define === 'function' && define.amd ? define(factory) :\n (factory());\n}(this, (function () { 'use strict';\n\n /**\n * Applies the :focus-visible polyfill at the given scope.\n * A scope in this case is either the top-level Document or a Shadow Root.\n *\n * @param {(Document|ShadowRoot)} scope\n * @see https://github.com/WICG/focus-visible\n */\n function applyFocusVisiblePolyfill(scope) {\n var hadKeyboardEvent = true;\n var hadFocusVisibleRecently = false;\n var hadFocusVisibleRecentlyTimeout = null;\n\n var inputTypesAllowlist = {\n text: true,\n search: true,\n url: true,\n tel: true,\n email: true,\n password: true,\n number: true,\n date: true,\n month: true,\n week: true,\n time: true,\n datetime: true,\n 'datetime-local': true\n };\n\n /**\n * Helper function for legacy browsers and iframes which sometimes focus\n * elements like document, body, and non-interactive SVG.\n * @param {Element} el\n */\n function isValidFocusTarget(el) {\n if (\n el &&\n el !== document &&\n el.nodeName !== 'HTML' &&\n el.nodeName !== 'BODY' &&\n 'classList' in el &&\n 'contains' in el.classList\n ) {\n return true;\n }\n return false;\n }\n\n /**\n * Computes whether the given element should automatically trigger the\n * `focus-visible` class being added, i.e. whether it should always match\n * `:focus-visible` when focused.\n * @param {Element} el\n * @return {boolean}\n */\n function focusTriggersKeyboardModality(el) {\n var type = el.type;\n var tagName = el.tagName;\n\n if (tagName === 'INPUT' && inputTypesAllowlist[type] && !el.readOnly) {\n return true;\n }\n\n if (tagName === 'TEXTAREA' && !el.readOnly) {\n return true;\n }\n\n if (el.isContentEditable) {\n return true;\n }\n\n return false;\n }\n\n /**\n * Add the `focus-visible` class to the given element if it was not added by\n * the author.\n * @param {Element} el\n */\n function addFocusVisibleClass(el) {\n if (el.classList.contains('focus-visible')) {\n return;\n }\n el.classList.add('focus-visible');\n el.setAttribute('data-focus-visible-added', '');\n }\n\n /**\n * Remove the `focus-visible` class from the given element if it was not\n * originally added by the author.\n * @param {Element} el\n */\n function removeFocusVisibleClass(el) {\n if (!el.hasAttribute('data-focus-visible-added')) {\n return;\n }\n el.classList.remove('focus-visible');\n el.removeAttribute('data-focus-visible-added');\n }\n\n /**\n * If the most recent user interaction was via the keyboard;\n * and the key press did not include a meta, alt/option, or control key;\n * then the modality is keyboard. Otherwise, the modality is not keyboard.\n * Apply `focus-visible` to any current active element and keep track\n * of our keyboard modality state with `hadKeyboardEvent`.\n * @param {KeyboardEvent} e\n */\n function onKeyDown(e) {\n if (e.metaKey || e.altKey || e.ctrlKey) {\n return;\n }\n\n if (isValidFocusTarget(scope.activeElement)) {\n addFocusVisibleClass(scope.activeElement);\n }\n\n hadKeyboardEvent = true;\n }\n\n /**\n * If at any point a user clicks with a pointing device, ensure that we change\n * the modality away from keyboard.\n * This avoids the situation where a user presses a key on an already focused\n * element, and then clicks on a different element, focusing it with a\n * pointing device, while we still think we're in keyboard modality.\n * @param {Event} e\n */\n function onPointerDown(e) {\n hadKeyboardEvent = false;\n }\n\n /**\n * On `focus`, add the `focus-visible` class to the target if:\n * - the target received focus as a result of keyboard navigation, or\n * - the event target is an element that will likely require interaction\n * via the keyboard (e.g. a text box)\n * @param {Event} e\n */\n function onFocus(e) {\n // Prevent IE from focusing the document or HTML element.\n if (!isValidFocusTarget(e.target)) {\n return;\n }\n\n if (hadKeyboardEvent || focusTriggersKeyboardModality(e.target)) {\n addFocusVisibleClass(e.target);\n }\n }\n\n /**\n * On `blur`, remove the `focus-visible` class from the target.\n * @param {Event} e\n */\n function onBlur(e) {\n if (!isValidFocusTarget(e.target)) {\n return;\n }\n\n if (\n e.target.classList.contains('focus-visible') ||\n e.target.hasAttribute('data-focus-visible-added')\n ) {\n // To detect a tab/window switch, we look for a blur event followed\n // rapidly by a visibility change.\n // If we don't see a visibility change within 100ms, it's probably a\n // regular focus change.\n hadFocusVisibleRecently = true;\n window.clearTimeout(hadFocusVisibleRecentlyTimeout);\n hadFocusVisibleRecentlyTimeout = window.setTimeout(function() {\n hadFocusVisibleRecently = false;\n }, 100);\n removeFocusVisibleClass(e.target);\n }\n }\n\n /**\n * If the user changes tabs, keep track of whether or not the previously\n * focused element had .focus-visible.\n * @param {Event} e\n */\n function onVisibilityChange(e) {\n if (document.visibilityState === 'hidden') {\n // If the tab becomes active again, the browser will handle calling focus\n // on the element (Safari actually calls it twice).\n // If this tab change caused a blur on an element with focus-visible,\n // re-apply the class when the user switches back to the tab.\n if (hadFocusVisibleRecently) {\n hadKeyboardEvent = true;\n }\n addInitialPointerMoveListeners();\n }\n }\n\n /**\n * Add a group of listeners to detect usage of any pointing devices.\n * These listeners will be added when the polyfill first loads, and anytime\n * the window is blurred, so that they are active when the window regains\n * focus.\n */\n function addInitialPointerMoveListeners() {\n document.addEventListener('mousemove', onInitialPointerMove);\n document.addEventListener('mousedown', onInitialPointerMove);\n document.addEventListener('mouseup', onInitialPointerMove);\n document.addEventListener('pointermove', onInitialPointerMove);\n document.addEventListener('pointerdown', onInitialPointerMove);\n document.addEventListener('pointerup', onInitialPointerMove);\n document.addEventListener('touchmove', onInitialPointerMove);\n document.addEventListener('touchstart', onInitialPointerMove);\n document.addEventListener('touchend', onInitialPointerMove);\n }\n\n function removeInitialPointerMoveListeners() {\n document.removeEventListener('mousemove', onInitialPointerMove);\n document.removeEventListener('mousedown', onInitialPointerMove);\n document.removeEventListener('mouseup', onInitialPointerMove);\n document.removeEventListener('pointermove', onInitialPointerMove);\n document.removeEventListener('pointerdown', onInitialPointerMove);\n document.removeEventListener('pointerup', onInitialPointerMove);\n document.removeEventListener('touchmove', onInitialPointerMove);\n document.removeEventListener('touchstart', onInitialPointerMove);\n document.removeEventListener('touchend', onInitialPointerMove);\n }\n\n /**\n * When the polfyill first loads, assume the user is in keyboard modality.\n * If any event is received from a pointing device (e.g. mouse, pointer,\n * touch), turn off keyboard modality.\n * This accounts for situations where focus enters the page from the URL bar.\n * @param {Event} e\n */\n function onInitialPointerMove(e) {\n // Work around a Safari quirk that fires a mousemove on whenever the\n // window blurs, even if you're tabbing out of the page. \u00AF\\_(\u30C4)_/\u00AF\n if (e.target.nodeName && e.target.nodeName.toLowerCase() === 'html') {\n return;\n }\n\n hadKeyboardEvent = false;\n removeInitialPointerMoveListeners();\n }\n\n // For some kinds of state, we are interested in changes at the global scope\n // only. For example, global pointer input, global key presses and global\n // visibility change should affect the state at every scope:\n document.addEventListener('keydown', onKeyDown, true);\n document.addEventListener('mousedown', onPointerDown, true);\n document.addEventListener('pointerdown', onPointerDown, true);\n document.addEventListener('touchstart', onPointerDown, true);\n document.addEventListener('visibilitychange', onVisibilityChange, true);\n\n addInitialPointerMoveListeners();\n\n // For focus and blur, we specifically care about state changes in the local\n // scope. This is because focus / blur events that originate from within a\n // shadow root are not re-dispatched from the host element if it was already\n // the active element in its own scope:\n scope.addEventListener('focus', onFocus, true);\n scope.addEventListener('blur', onBlur, true);\n\n // We detect that a node is a ShadowRoot by ensuring that it is a\n // DocumentFragment and also has a host property. This check covers native\n // implementation and polyfill implementation transparently. If we only cared\n // about the native implementation, we could just check if the scope was\n // an instance of a ShadowRoot.\n if (scope.nodeType === Node.DOCUMENT_FRAGMENT_NODE && scope.host) {\n // Since a ShadowRoot is a special kind of DocumentFragment, it does not\n // have a root element to add a class to. So, we add this attribute to the\n // host element instead:\n scope.host.setAttribute('data-js-focus-visible', '');\n } else if (scope.nodeType === Node.DOCUMENT_NODE) {\n document.documentElement.classList.add('js-focus-visible');\n document.documentElement.setAttribute('data-js-focus-visible', '');\n }\n }\n\n // It is important to wrap all references to global window and document in\n // these checks to support server-side rendering use cases\n // @see https://github.com/WICG/focus-visible/issues/199\n if (typeof window !== 'undefined' && typeof document !== 'undefined') {\n // Make the polyfill helper globally available. This can be used as a signal\n // to interested libraries that wish to coordinate with the polyfill for e.g.,\n // applying the polyfill to a shadow root:\n window.applyFocusVisiblePolyfill = applyFocusVisiblePolyfill;\n\n // Notify interested libraries of the polyfill's presence, in case the\n // polyfill was loaded lazily:\n var event;\n\n try {\n event = new CustomEvent('focus-visible-polyfill-ready');\n } catch (error) {\n // IE11 does not support using CustomEvent as a constructor directly:\n event = document.createEvent('CustomEvent');\n event.initCustomEvent('focus-visible-polyfill-ready', false, false, {});\n }\n\n window.dispatchEvent(event);\n }\n\n if (typeof document !== 'undefined') {\n // Apply the polyfill to the global document, so that no JavaScript\n // coordination is required to use the polyfill in the top-level document:\n applyFocusVisiblePolyfill(document);\n }\n\n})));\n", "/*!\n * escape-html\n * Copyright(c) 2012-2013 TJ Holowaychuk\n * Copyright(c) 2015 Andreas Lubbe\n * Copyright(c) 2015 Tiancheng \"Timothy\" Gu\n * MIT Licensed\n */\n\n'use strict';\n\n/**\n * Module variables.\n * @private\n */\n\nvar matchHtmlRegExp = /[\"'&<>]/;\n\n/**\n * Module exports.\n * @public\n */\n\nmodule.exports = escapeHtml;\n\n/**\n * Escape special characters in the given string of html.\n *\n * @param {string} string The string to escape for inserting into HTML\n * @return {string}\n * @public\n */\n\nfunction escapeHtml(string) {\n var str = '' + string;\n var match = matchHtmlRegExp.exec(str);\n\n if (!match) {\n return str;\n }\n\n var escape;\n var html = '';\n var index = 0;\n var lastIndex = 0;\n\n for (index = match.index; index < str.length; index++) {\n switch (str.charCodeAt(index)) {\n case 34: // \"\n escape = '"';\n break;\n case 38: // &\n escape = '&';\n break;\n case 39: // '\n escape = ''';\n break;\n case 60: // <\n escape = '<';\n break;\n case 62: // >\n escape = '>';\n break;\n default:\n continue;\n }\n\n if (lastIndex !== index) {\n html += str.substring(lastIndex, index);\n }\n\n lastIndex = index + 1;\n html += escape;\n }\n\n return lastIndex !== index\n ? html + str.substring(lastIndex, index)\n : html;\n}\n", "/*!\n * clipboard.js v2.0.11\n * https://clipboardjs.com/\n *\n * Licensed MIT \u00A9 Zeno Rocha\n */\n(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"ClipboardJS\"] = factory();\n\telse\n\t\troot[\"ClipboardJS\"] = factory();\n})(this, function() {\nreturn /******/ (function() { // webpackBootstrap\n/******/ \tvar __webpack_modules__ = ({\n\n/***/ 686:\n/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n\n// EXPORTS\n__webpack_require__.d(__webpack_exports__, {\n \"default\": function() { return /* binding */ clipboard; }\n});\n\n// EXTERNAL MODULE: ./node_modules/tiny-emitter/index.js\nvar tiny_emitter = __webpack_require__(279);\nvar tiny_emitter_default = /*#__PURE__*/__webpack_require__.n(tiny_emitter);\n// EXTERNAL MODULE: ./node_modules/good-listener/src/listen.js\nvar listen = __webpack_require__(370);\nvar listen_default = /*#__PURE__*/__webpack_require__.n(listen);\n// EXTERNAL MODULE: ./node_modules/select/src/select.js\nvar src_select = __webpack_require__(817);\nvar select_default = /*#__PURE__*/__webpack_require__.n(src_select);\n;// CONCATENATED MODULE: ./src/common/command.js\n/**\n * Executes a given operation type.\n * @param {String} type\n * @return {Boolean}\n */\nfunction command(type) {\n try {\n return document.execCommand(type);\n } catch (err) {\n return false;\n }\n}\n;// CONCATENATED MODULE: ./src/actions/cut.js\n\n\n/**\n * Cut action wrapper.\n * @param {String|HTMLElement} target\n * @return {String}\n */\n\nvar ClipboardActionCut = function ClipboardActionCut(target) {\n var selectedText = select_default()(target);\n command('cut');\n return selectedText;\n};\n\n/* harmony default export */ var actions_cut = (ClipboardActionCut);\n;// CONCATENATED MODULE: ./src/common/create-fake-element.js\n/**\n * Creates a fake textarea element with a value.\n * @param {String} value\n * @return {HTMLElement}\n */\nfunction createFakeElement(value) {\n var isRTL = document.documentElement.getAttribute('dir') === 'rtl';\n var fakeElement = document.createElement('textarea'); // Prevent zooming on iOS\n\n fakeElement.style.fontSize = '12pt'; // Reset box model\n\n fakeElement.style.border = '0';\n fakeElement.style.padding = '0';\n fakeElement.style.margin = '0'; // Move element out of screen horizontally\n\n fakeElement.style.position = 'absolute';\n fakeElement.style[isRTL ? 'right' : 'left'] = '-9999px'; // Move element to the same position vertically\n\n var yPosition = window.pageYOffset || document.documentElement.scrollTop;\n fakeElement.style.top = \"\".concat(yPosition, \"px\");\n fakeElement.setAttribute('readonly', '');\n fakeElement.value = value;\n return fakeElement;\n}\n;// CONCATENATED MODULE: ./src/actions/copy.js\n\n\n\n/**\n * Create fake copy action wrapper using a fake element.\n * @param {String} target\n * @param {Object} options\n * @return {String}\n */\n\nvar fakeCopyAction = function fakeCopyAction(value, options) {\n var fakeElement = createFakeElement(value);\n options.container.appendChild(fakeElement);\n var selectedText = select_default()(fakeElement);\n command('copy');\n fakeElement.remove();\n return selectedText;\n};\n/**\n * Copy action wrapper.\n * @param {String|HTMLElement} target\n * @param {Object} options\n * @return {String}\n */\n\n\nvar ClipboardActionCopy = function ClipboardActionCopy(target) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {\n container: document.body\n };\n var selectedText = '';\n\n if (typeof target === 'string') {\n selectedText = fakeCopyAction(target, options);\n } else if (target instanceof HTMLInputElement && !['text', 'search', 'url', 'tel', 'password'].includes(target === null || target === void 0 ? void 0 : target.type)) {\n // If input type doesn't support `setSelectionRange`. Simulate it. https://developer.mozilla.org/en-US/docs/Web/API/HTMLInputElement/setSelectionRange\n selectedText = fakeCopyAction(target.value, options);\n } else {\n selectedText = select_default()(target);\n command('copy');\n }\n\n return selectedText;\n};\n\n/* harmony default export */ var actions_copy = (ClipboardActionCopy);\n;// CONCATENATED MODULE: ./src/actions/default.js\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n\n\n/**\n * Inner function which performs selection from either `text` or `target`\n * properties and then executes copy or cut operations.\n * @param {Object} options\n */\n\nvar ClipboardActionDefault = function ClipboardActionDefault() {\n var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n // Defines base properties passed from constructor.\n var _options$action = options.action,\n action = _options$action === void 0 ? 'copy' : _options$action,\n container = options.container,\n target = options.target,\n text = options.text; // Sets the `action` to be performed which can be either 'copy' or 'cut'.\n\n if (action !== 'copy' && action !== 'cut') {\n throw new Error('Invalid \"action\" value, use either \"copy\" or \"cut\"');\n } // Sets the `target` property using an element that will be have its content copied.\n\n\n if (target !== undefined) {\n if (target && _typeof(target) === 'object' && target.nodeType === 1) {\n if (action === 'copy' && target.hasAttribute('disabled')) {\n throw new Error('Invalid \"target\" attribute. Please use \"readonly\" instead of \"disabled\" attribute');\n }\n\n if (action === 'cut' && (target.hasAttribute('readonly') || target.hasAttribute('disabled'))) {\n throw new Error('Invalid \"target\" attribute. You can\\'t cut text from elements with \"readonly\" or \"disabled\" attributes');\n }\n } else {\n throw new Error('Invalid \"target\" value, use a valid Element');\n }\n } // Define selection strategy based on `text` property.\n\n\n if (text) {\n return actions_copy(text, {\n container: container\n });\n } // Defines which selection strategy based on `target` property.\n\n\n if (target) {\n return action === 'cut' ? actions_cut(target) : actions_copy(target, {\n container: container\n });\n }\n};\n\n/* harmony default export */ var actions_default = (ClipboardActionDefault);\n;// CONCATENATED MODULE: ./src/clipboard.js\nfunction clipboard_typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { clipboard_typeof = function _typeof(obj) { return typeof obj; }; } else { clipboard_typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return clipboard_typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (clipboard_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\n\n\n\n\n\n/**\n * Helper function to retrieve attribute value.\n * @param {String} suffix\n * @param {Element} element\n */\n\nfunction getAttributeValue(suffix, element) {\n var attribute = \"data-clipboard-\".concat(suffix);\n\n if (!element.hasAttribute(attribute)) {\n return;\n }\n\n return element.getAttribute(attribute);\n}\n/**\n * Base class which takes one or more elements, adds event listeners to them,\n * and instantiates a new `ClipboardAction` on each click.\n */\n\n\nvar Clipboard = /*#__PURE__*/function (_Emitter) {\n _inherits(Clipboard, _Emitter);\n\n var _super = _createSuper(Clipboard);\n\n /**\n * @param {String|HTMLElement|HTMLCollection|NodeList} trigger\n * @param {Object} options\n */\n function Clipboard(trigger, options) {\n var _this;\n\n _classCallCheck(this, Clipboard);\n\n _this = _super.call(this);\n\n _this.resolveOptions(options);\n\n _this.listenClick(trigger);\n\n return _this;\n }\n /**\n * Defines if attributes would be resolved using internal setter functions\n * or custom functions that were passed in the constructor.\n * @param {Object} options\n */\n\n\n _createClass(Clipboard, [{\n key: \"resolveOptions\",\n value: function resolveOptions() {\n var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n this.action = typeof options.action === 'function' ? options.action : this.defaultAction;\n this.target = typeof options.target === 'function' ? options.target : this.defaultTarget;\n this.text = typeof options.text === 'function' ? options.text : this.defaultText;\n this.container = clipboard_typeof(options.container) === 'object' ? options.container : document.body;\n }\n /**\n * Adds a click event listener to the passed trigger.\n * @param {String|HTMLElement|HTMLCollection|NodeList} trigger\n */\n\n }, {\n key: \"listenClick\",\n value: function listenClick(trigger) {\n var _this2 = this;\n\n this.listener = listen_default()(trigger, 'click', function (e) {\n return _this2.onClick(e);\n });\n }\n /**\n * Defines a new `ClipboardAction` on each click event.\n * @param {Event} e\n */\n\n }, {\n key: \"onClick\",\n value: function onClick(e) {\n var trigger = e.delegateTarget || e.currentTarget;\n var action = this.action(trigger) || 'copy';\n var text = actions_default({\n action: action,\n container: this.container,\n target: this.target(trigger),\n text: this.text(trigger)\n }); // Fires an event based on the copy operation result.\n\n this.emit(text ? 'success' : 'error', {\n action: action,\n text: text,\n trigger: trigger,\n clearSelection: function clearSelection() {\n if (trigger) {\n trigger.focus();\n }\n\n window.getSelection().removeAllRanges();\n }\n });\n }\n /**\n * Default `action` lookup function.\n * @param {Element} trigger\n */\n\n }, {\n key: \"defaultAction\",\n value: function defaultAction(trigger) {\n return getAttributeValue('action', trigger);\n }\n /**\n * Default `target` lookup function.\n * @param {Element} trigger\n */\n\n }, {\n key: \"defaultTarget\",\n value: function defaultTarget(trigger) {\n var selector = getAttributeValue('target', trigger);\n\n if (selector) {\n return document.querySelector(selector);\n }\n }\n /**\n * Allow fire programmatically a copy action\n * @param {String|HTMLElement} target\n * @param {Object} options\n * @returns Text copied.\n */\n\n }, {\n key: \"defaultText\",\n\n /**\n * Default `text` lookup function.\n * @param {Element} trigger\n */\n value: function defaultText(trigger) {\n return getAttributeValue('text', trigger);\n }\n /**\n * Destroy lifecycle.\n */\n\n }, {\n key: \"destroy\",\n value: function destroy() {\n this.listener.destroy();\n }\n }], [{\n key: \"copy\",\n value: function copy(target) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {\n container: document.body\n };\n return actions_copy(target, options);\n }\n /**\n * Allow fire programmatically a cut action\n * @param {String|HTMLElement} target\n * @returns Text cutted.\n */\n\n }, {\n key: \"cut\",\n value: function cut(target) {\n return actions_cut(target);\n }\n /**\n * Returns the support of the given action, or all actions if no action is\n * given.\n * @param {String} [action]\n */\n\n }, {\n key: \"isSupported\",\n value: function isSupported() {\n var action = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ['copy', 'cut'];\n var actions = typeof action === 'string' ? [action] : action;\n var support = !!document.queryCommandSupported;\n actions.forEach(function (action) {\n support = support && !!document.queryCommandSupported(action);\n });\n return support;\n }\n }]);\n\n return Clipboard;\n}((tiny_emitter_default()));\n\n/* harmony default export */ var clipboard = (Clipboard);\n\n/***/ }),\n\n/***/ 828:\n/***/ (function(module) {\n\nvar DOCUMENT_NODE_TYPE = 9;\n\n/**\n * A polyfill for Element.matches()\n */\nif (typeof Element !== 'undefined' && !Element.prototype.matches) {\n var proto = Element.prototype;\n\n proto.matches = proto.matchesSelector ||\n proto.mozMatchesSelector ||\n proto.msMatchesSelector ||\n proto.oMatchesSelector ||\n proto.webkitMatchesSelector;\n}\n\n/**\n * Finds the closest parent that matches a selector.\n *\n * @param {Element} element\n * @param {String} selector\n * @return {Function}\n */\nfunction closest (element, selector) {\n while (element && element.nodeType !== DOCUMENT_NODE_TYPE) {\n if (typeof element.matches === 'function' &&\n element.matches(selector)) {\n return element;\n }\n element = element.parentNode;\n }\n}\n\nmodule.exports = closest;\n\n\n/***/ }),\n\n/***/ 438:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\nvar closest = __webpack_require__(828);\n\n/**\n * Delegates event to a selector.\n *\n * @param {Element} element\n * @param {String} selector\n * @param {String} type\n * @param {Function} callback\n * @param {Boolean} useCapture\n * @return {Object}\n */\nfunction _delegate(element, selector, type, callback, useCapture) {\n var listenerFn = listener.apply(this, arguments);\n\n element.addEventListener(type, listenerFn, useCapture);\n\n return {\n destroy: function() {\n element.removeEventListener(type, listenerFn, useCapture);\n }\n }\n}\n\n/**\n * Delegates event to a selector.\n *\n * @param {Element|String|Array} [elements]\n * @param {String} selector\n * @param {String} type\n * @param {Function} callback\n * @param {Boolean} useCapture\n * @return {Object}\n */\nfunction delegate(elements, selector, type, callback, useCapture) {\n // Handle the regular Element usage\n if (typeof elements.addEventListener === 'function') {\n return _delegate.apply(null, arguments);\n }\n\n // Handle Element-less usage, it defaults to global delegation\n if (typeof type === 'function') {\n // Use `document` as the first parameter, then apply arguments\n // This is a short way to .unshift `arguments` without running into deoptimizations\n return _delegate.bind(null, document).apply(null, arguments);\n }\n\n // Handle Selector-based usage\n if (typeof elements === 'string') {\n elements = document.querySelectorAll(elements);\n }\n\n // Handle Array-like based usage\n return Array.prototype.map.call(elements, function (element) {\n return _delegate(element, selector, type, callback, useCapture);\n });\n}\n\n/**\n * Finds closest match and invokes callback.\n *\n * @param {Element} element\n * @param {String} selector\n * @param {String} type\n * @param {Function} callback\n * @return {Function}\n */\nfunction listener(element, selector, type, callback) {\n return function(e) {\n e.delegateTarget = closest(e.target, selector);\n\n if (e.delegateTarget) {\n callback.call(element, e);\n }\n }\n}\n\nmodule.exports = delegate;\n\n\n/***/ }),\n\n/***/ 879:\n/***/ (function(__unused_webpack_module, exports) {\n\n/**\n * Check if argument is a HTML element.\n *\n * @param {Object} value\n * @return {Boolean}\n */\nexports.node = function(value) {\n return value !== undefined\n && value instanceof HTMLElement\n && value.nodeType === 1;\n};\n\n/**\n * Check if argument is a list of HTML elements.\n *\n * @param {Object} value\n * @return {Boolean}\n */\nexports.nodeList = function(value) {\n var type = Object.prototype.toString.call(value);\n\n return value !== undefined\n && (type === '[object NodeList]' || type === '[object HTMLCollection]')\n && ('length' in value)\n && (value.length === 0 || exports.node(value[0]));\n};\n\n/**\n * Check if argument is a string.\n *\n * @param {Object} value\n * @return {Boolean}\n */\nexports.string = function(value) {\n return typeof value === 'string'\n || value instanceof String;\n};\n\n/**\n * Check if argument is a function.\n *\n * @param {Object} value\n * @return {Boolean}\n */\nexports.fn = function(value) {\n var type = Object.prototype.toString.call(value);\n\n return type === '[object Function]';\n};\n\n\n/***/ }),\n\n/***/ 370:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\nvar is = __webpack_require__(879);\nvar delegate = __webpack_require__(438);\n\n/**\n * Validates all params and calls the right\n * listener function based on its target type.\n *\n * @param {String|HTMLElement|HTMLCollection|NodeList} target\n * @param {String} type\n * @param {Function} callback\n * @return {Object}\n */\nfunction listen(target, type, callback) {\n if (!target && !type && !callback) {\n throw new Error('Missing required arguments');\n }\n\n if (!is.string(type)) {\n throw new TypeError('Second argument must be a String');\n }\n\n if (!is.fn(callback)) {\n throw new TypeError('Third argument must be a Function');\n }\n\n if (is.node(target)) {\n return listenNode(target, type, callback);\n }\n else if (is.nodeList(target)) {\n return listenNodeList(target, type, callback);\n }\n else if (is.string(target)) {\n return listenSelector(target, type, callback);\n }\n else {\n throw new TypeError('First argument must be a String, HTMLElement, HTMLCollection, or NodeList');\n }\n}\n\n/**\n * Adds an event listener to a HTML element\n * and returns a remove listener function.\n *\n * @param {HTMLElement} node\n * @param {String} type\n * @param {Function} callback\n * @return {Object}\n */\nfunction listenNode(node, type, callback) {\n node.addEventListener(type, callback);\n\n return {\n destroy: function() {\n node.removeEventListener(type, callback);\n }\n }\n}\n\n/**\n * Add an event listener to a list of HTML elements\n * and returns a remove listener function.\n *\n * @param {NodeList|HTMLCollection} nodeList\n * @param {String} type\n * @param {Function} callback\n * @return {Object}\n */\nfunction listenNodeList(nodeList, type, callback) {\n Array.prototype.forEach.call(nodeList, function(node) {\n node.addEventListener(type, callback);\n });\n\n return {\n destroy: function() {\n Array.prototype.forEach.call(nodeList, function(node) {\n node.removeEventListener(type, callback);\n });\n }\n }\n}\n\n/**\n * Add an event listener to a selector\n * and returns a remove listener function.\n *\n * @param {String} selector\n * @param {String} type\n * @param {Function} callback\n * @return {Object}\n */\nfunction listenSelector(selector, type, callback) {\n return delegate(document.body, selector, type, callback);\n}\n\nmodule.exports = listen;\n\n\n/***/ }),\n\n/***/ 817:\n/***/ (function(module) {\n\nfunction select(element) {\n var selectedText;\n\n if (element.nodeName === 'SELECT') {\n element.focus();\n\n selectedText = element.value;\n }\n else if (element.nodeName === 'INPUT' || element.nodeName === 'TEXTAREA') {\n var isReadOnly = element.hasAttribute('readonly');\n\n if (!isReadOnly) {\n element.setAttribute('readonly', '');\n }\n\n element.select();\n element.setSelectionRange(0, element.value.length);\n\n if (!isReadOnly) {\n element.removeAttribute('readonly');\n }\n\n selectedText = element.value;\n }\n else {\n if (element.hasAttribute('contenteditable')) {\n element.focus();\n }\n\n var selection = window.getSelection();\n var range = document.createRange();\n\n range.selectNodeContents(element);\n selection.removeAllRanges();\n selection.addRange(range);\n\n selectedText = selection.toString();\n }\n\n return selectedText;\n}\n\nmodule.exports = select;\n\n\n/***/ }),\n\n/***/ 279:\n/***/ (function(module) {\n\nfunction E () {\n // Keep this empty so it's easier to inherit from\n // (via https://github.com/lipsmack from https://github.com/scottcorgan/tiny-emitter/issues/3)\n}\n\nE.prototype = {\n on: function (name, callback, ctx) {\n var e = this.e || (this.e = {});\n\n (e[name] || (e[name] = [])).push({\n fn: callback,\n ctx: ctx\n });\n\n return this;\n },\n\n once: function (name, callback, ctx) {\n var self = this;\n function listener () {\n self.off(name, listener);\n callback.apply(ctx, arguments);\n };\n\n listener._ = callback\n return this.on(name, listener, ctx);\n },\n\n emit: function (name) {\n var data = [].slice.call(arguments, 1);\n var evtArr = ((this.e || (this.e = {}))[name] || []).slice();\n var i = 0;\n var len = evtArr.length;\n\n for (i; i < len; i++) {\n evtArr[i].fn.apply(evtArr[i].ctx, data);\n }\n\n return this;\n },\n\n off: function (name, callback) {\n var e = this.e || (this.e = {});\n var evts = e[name];\n var liveEvents = [];\n\n if (evts && callback) {\n for (var i = 0, len = evts.length; i < len; i++) {\n if (evts[i].fn !== callback && evts[i].fn._ !== callback)\n liveEvents.push(evts[i]);\n }\n }\n\n // Remove event from queue to prevent memory leak\n // Suggested by https://github.com/lazd\n // Ref: https://github.com/scottcorgan/tiny-emitter/commit/c6ebfaa9bc973b33d110a84a307742b7cf94c953#commitcomment-5024910\n\n (liveEvents.length)\n ? e[name] = liveEvents\n : delete e[name];\n\n return this;\n }\n};\n\nmodule.exports = E;\nmodule.exports.TinyEmitter = E;\n\n\n/***/ })\n\n/******/ \t});\n/************************************************************************/\n/******/ \t// The module cache\n/******/ \tvar __webpack_module_cache__ = {};\n/******/ \t\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(__webpack_module_cache__[moduleId]) {\n/******/ \t\t\treturn __webpack_module_cache__[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = __webpack_module_cache__[moduleId] = {\n/******/ \t\t\t// no module.id needed\n/******/ \t\t\t// no module.loaded needed\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/ \t\n/******/ \t\t// Execute the module function\n/******/ \t\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n/******/ \t\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/ \t\n/************************************************************************/\n/******/ \t/* webpack/runtime/compat get default export */\n/******/ \t!function() {\n/******/ \t\t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t\t__webpack_require__.n = function(module) {\n/******/ \t\t\tvar getter = module && module.__esModule ?\n/******/ \t\t\t\tfunction() { return module['default']; } :\n/******/ \t\t\t\tfunction() { return module; };\n/******/ \t\t\t__webpack_require__.d(getter, { a: getter });\n/******/ \t\t\treturn getter;\n/******/ \t\t};\n/******/ \t}();\n/******/ \t\n/******/ \t/* webpack/runtime/define property getters */\n/******/ \t!function() {\n/******/ \t\t// define getter functions for harmony exports\n/******/ \t\t__webpack_require__.d = function(exports, definition) {\n/******/ \t\t\tfor(var key in definition) {\n/******/ \t\t\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n/******/ \t\t\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n/******/ \t\t\t\t}\n/******/ \t\t\t}\n/******/ \t\t};\n/******/ \t}();\n/******/ \t\n/******/ \t/* webpack/runtime/hasOwnProperty shorthand */\n/******/ \t!function() {\n/******/ \t\t__webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }\n/******/ \t}();\n/******/ \t\n/************************************************************************/\n/******/ \t// module exports must be returned from runtime so entry inlining is disabled\n/******/ \t// startup\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(686);\n/******/ })()\n.default;\n});", "/*\n * Copyright (c) 2016-2024 Martin Donath \n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to\n * deal in the Software without restriction, including without limitation the\n * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or\n * sell copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING\n * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS\n * IN THE SOFTWARE.\n */\n\nimport \"focus-visible\"\n\nimport {\n EMPTY,\n NEVER,\n Observable,\n Subject,\n defer,\n delay,\n filter,\n map,\n merge,\n mergeWith,\n shareReplay,\n switchMap\n} from \"rxjs\"\n\nimport { configuration, feature } from \"./_\"\nimport {\n at,\n getActiveElement,\n getOptionalElement,\n requestJSON,\n setLocation,\n setToggle,\n watchDocument,\n watchKeyboard,\n watchLocation,\n watchLocationTarget,\n watchMedia,\n watchPrint,\n watchScript,\n watchViewport\n} from \"./browser\"\nimport {\n getComponentElement,\n getComponentElements,\n mountAnnounce,\n mountBackToTop,\n mountConsent,\n mountContent,\n mountDialog,\n mountHeader,\n mountHeaderTitle,\n mountPalette,\n mountProgress,\n mountSearch,\n mountSearchHiglight,\n mountSidebar,\n mountSource,\n mountTableOfContents,\n mountTabs,\n watchHeader,\n watchMain\n} from \"./components\"\nimport {\n SearchIndex,\n setupClipboardJS,\n setupInstantNavigation,\n setupVersionSelector\n} from \"./integrations\"\nimport {\n patchEllipsis,\n patchIndeterminate,\n patchScrollfix,\n patchScrolllock\n} from \"./patches\"\nimport \"./polyfills\"\n\n/* ----------------------------------------------------------------------------\n * Functions - @todo refactor\n * ------------------------------------------------------------------------- */\n\n/**\n * Fetch search index\n *\n * @returns Search index observable\n */\nfunction fetchSearchIndex(): Observable {\n if (location.protocol === \"file:\") {\n return watchScript(\n `${new URL(\"search/search_index.js\", config.base)}`\n )\n .pipe(\n // @ts-ignore - @todo fix typings\n map(() => __index),\n shareReplay(1)\n )\n } else {\n return requestJSON(\n new URL(\"search/search_index.json\", config.base)\n )\n }\n}\n\n/* ----------------------------------------------------------------------------\n * Application\n * ------------------------------------------------------------------------- */\n\n/* Yay, JavaScript is available */\ndocument.documentElement.classList.remove(\"no-js\")\ndocument.documentElement.classList.add(\"js\")\n\n/* Set up navigation observables and subjects */\nconst document$ = watchDocument()\nconst location$ = watchLocation()\nconst target$ = watchLocationTarget(location$)\nconst keyboard$ = watchKeyboard()\n\n/* Set up media observables */\nconst viewport$ = watchViewport()\nconst tablet$ = watchMedia(\"(min-width: 960px)\")\nconst screen$ = watchMedia(\"(min-width: 1220px)\")\nconst print$ = watchPrint()\n\n/* Retrieve search index, if search is enabled */\nconst config = configuration()\nconst index$ = document.forms.namedItem(\"search\")\n ? fetchSearchIndex()\n : NEVER\n\n/* Set up Clipboard.js integration */\nconst alert$ = new Subject()\nsetupClipboardJS({ alert$ })\n\n/* Set up progress indicator */\nconst progress$ = new Subject()\n\n/* Set up instant navigation, if enabled */\nif (feature(\"navigation.instant\"))\n setupInstantNavigation({ location$, viewport$, progress$ })\n .subscribe(document$)\n\n/* Set up version selector */\nif (config.version?.provider === \"mike\")\n setupVersionSelector({ document$ })\n\n/* Always close drawer and search on navigation */\nmerge(location$, target$)\n .pipe(\n delay(125)\n )\n .subscribe(() => {\n setToggle(\"drawer\", false)\n setToggle(\"search\", false)\n })\n\n/* Set up global keyboard handlers */\nkeyboard$\n .pipe(\n filter(({ mode }) => mode === \"global\")\n )\n .subscribe(key => {\n switch (key.type) {\n\n /* Go to previous page */\n case \"p\":\n case \",\":\n const prev = getOptionalElement(\"link[rel=prev]\")\n if (typeof prev !== \"undefined\")\n setLocation(prev)\n break\n\n /* Go to next page */\n case \"n\":\n case \".\":\n const next = getOptionalElement(\"link[rel=next]\")\n if (typeof next !== \"undefined\")\n setLocation(next)\n break\n\n /* Expand navigation, see https://bit.ly/3ZjG5io */\n case \"Enter\":\n const active = getActiveElement()\n if (active instanceof HTMLLabelElement)\n active.click()\n }\n })\n\n/* Set up patches */\npatchEllipsis({ viewport$, document$ })\npatchIndeterminate({ document$, tablet$ })\npatchScrollfix({ document$ })\npatchScrolllock({ viewport$, tablet$ })\n\n/* Set up header and main area observable */\nconst header$ = watchHeader(getComponentElement(\"header\"), { viewport$ })\nconst main$ = document$\n .pipe(\n map(() => getComponentElement(\"main\")),\n switchMap(el => watchMain(el, { viewport$, header$ })),\n shareReplay(1)\n )\n\n/* Set up control component observables */\nconst control$ = merge(\n\n /* Consent */\n ...getComponentElements(\"consent\")\n .map(el => mountConsent(el, { target$ })),\n\n /* Dialog */\n ...getComponentElements(\"dialog\")\n .map(el => mountDialog(el, { alert$ })),\n\n /* Header */\n ...getComponentElements(\"header\")\n .map(el => mountHeader(el, { viewport$, header$, main$ })),\n\n /* Color palette */\n ...getComponentElements(\"palette\")\n .map(el => mountPalette(el)),\n\n /* Progress bar */\n ...getComponentElements(\"progress\")\n .map(el => mountProgress(el, { progress$ })),\n\n /* Search */\n ...getComponentElements(\"search\")\n .map(el => mountSearch(el, { index$, keyboard$ })),\n\n /* Repository information */\n ...getComponentElements(\"source\")\n .map(el => mountSource(el))\n)\n\n/* Set up content component observables */\nconst content$ = defer(() => merge(\n\n /* Announcement bar */\n ...getComponentElements(\"announce\")\n .map(el => mountAnnounce(el)),\n\n /* Content */\n ...getComponentElements(\"content\")\n .map(el => mountContent(el, { viewport$, target$, print$ })),\n\n /* Search highlighting */\n ...getComponentElements(\"content\")\n .map(el => feature(\"search.highlight\")\n ? mountSearchHiglight(el, { index$, location$ })\n : EMPTY\n ),\n\n /* Header title */\n ...getComponentElements(\"header-title\")\n .map(el => mountHeaderTitle(el, { viewport$, header$ })),\n\n /* Sidebar */\n ...getComponentElements(\"sidebar\")\n .map(el => el.getAttribute(\"data-md-type\") === \"navigation\"\n ? at(screen$, () => mountSidebar(el, { viewport$, header$, main$ }))\n : at(tablet$, () => mountSidebar(el, { viewport$, header$, main$ }))\n ),\n\n /* Navigation tabs */\n ...getComponentElements(\"tabs\")\n .map(el => mountTabs(el, { viewport$, header$ })),\n\n /* Table of contents */\n ...getComponentElements(\"toc\")\n .map(el => mountTableOfContents(el, {\n viewport$, header$, main$, target$\n })),\n\n /* Back-to-top button */\n ...getComponentElements(\"top\")\n .map(el => mountBackToTop(el, { viewport$, header$, main$, target$ }))\n))\n\n/* Set up component observables */\nconst component$ = document$\n .pipe(\n switchMap(() => content$),\n mergeWith(control$),\n shareReplay(1)\n )\n\n/* Subscribe to all components */\ncomponent$.subscribe()\n\n/* ----------------------------------------------------------------------------\n * Exports\n * ------------------------------------------------------------------------- */\n\nwindow.document$ = document$ /* Document observable */\nwindow.location$ = location$ /* Location subject */\nwindow.target$ = target$ /* Location target observable */\nwindow.keyboard$ = keyboard$ /* Keyboard observable */\nwindow.viewport$ = viewport$ /* Viewport observable */\nwindow.tablet$ = tablet$ /* Media tablet observable */\nwindow.screen$ = screen$ /* Media screen observable */\nwindow.print$ = print$ /* Media print observable */\nwindow.alert$ = alert$ /* Alert subject */\nwindow.progress$ = progress$ /* Progress indicator subject */\nwindow.component$ = component$ /* Component observable */\n", "/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n", "/**\n * Returns true if the object is a function.\n * @param value The value to check\n */\nexport function isFunction(value: any): value is (...args: any[]) => any {\n return typeof value === 'function';\n}\n", "/**\n * Used to create Error subclasses until the community moves away from ES5.\n *\n * This is because compiling from TypeScript down to ES5 has issues with subclassing Errors\n * as well as other built-in types: https://github.com/Microsoft/TypeScript/issues/12123\n *\n * @param createImpl A factory function to create the actual constructor implementation. The returned\n * function should be a named function that calls `_super` internally.\n */\nexport function createErrorClass(createImpl: (_super: any) => any): T {\n const _super = (instance: any) => {\n Error.call(instance);\n instance.stack = new Error().stack;\n };\n\n const ctorFunc = createImpl(_super);\n ctorFunc.prototype = Object.create(Error.prototype);\n ctorFunc.prototype.constructor = ctorFunc;\n return ctorFunc;\n}\n", "import { createErrorClass } from './createErrorClass';\n\nexport interface UnsubscriptionError extends Error {\n readonly errors: any[];\n}\n\nexport interface UnsubscriptionErrorCtor {\n /**\n * @deprecated Internal implementation detail. Do not construct error instances.\n * Cannot be tagged as internal: https://github.com/ReactiveX/rxjs/issues/6269\n */\n new (errors: any[]): UnsubscriptionError;\n}\n\n/**\n * An error thrown when one or more errors have occurred during the\n * `unsubscribe` of a {@link Subscription}.\n */\nexport const UnsubscriptionError: UnsubscriptionErrorCtor = createErrorClass(\n (_super) =>\n function UnsubscriptionErrorImpl(this: any, errors: (Error | string)[]) {\n _super(this);\n this.message = errors\n ? `${errors.length} errors occurred during unsubscription:\n${errors.map((err, i) => `${i + 1}) ${err.toString()}`).join('\\n ')}`\n : '';\n this.name = 'UnsubscriptionError';\n this.errors = errors;\n }\n);\n", "/**\n * Removes an item from an array, mutating it.\n * @param arr The array to remove the item from\n * @param item The item to remove\n */\nexport function arrRemove(arr: T[] | undefined | null, item: T) {\n if (arr) {\n const index = arr.indexOf(item);\n 0 <= index && arr.splice(index, 1);\n }\n}\n", "import { isFunction } from './util/isFunction';\nimport { UnsubscriptionError } from './util/UnsubscriptionError';\nimport { SubscriptionLike, TeardownLogic, Unsubscribable } from './types';\nimport { arrRemove } from './util/arrRemove';\n\n/**\n * Represents a disposable resource, such as the execution of an Observable. A\n * Subscription has one important method, `unsubscribe`, that takes no argument\n * and just disposes the resource held by the subscription.\n *\n * Additionally, subscriptions may be grouped together through the `add()`\n * method, which will attach a child Subscription to the current Subscription.\n * When a Subscription is unsubscribed, all its children (and its grandchildren)\n * will be unsubscribed as well.\n *\n * @class Subscription\n */\nexport class Subscription implements SubscriptionLike {\n /** @nocollapse */\n public static EMPTY = (() => {\n const empty = new Subscription();\n empty.closed = true;\n return empty;\n })();\n\n /**\n * A flag to indicate whether this Subscription has already been unsubscribed.\n */\n public closed = false;\n\n private _parentage: Subscription[] | Subscription | null = null;\n\n /**\n * The list of registered finalizers to execute upon unsubscription. Adding and removing from this\n * list occurs in the {@link #add} and {@link #remove} methods.\n */\n private _finalizers: Exclude[] | null = null;\n\n /**\n * @param initialTeardown A function executed first as part of the finalization\n * process that is kicked off when {@link #unsubscribe} is called.\n */\n constructor(private initialTeardown?: () => void) {}\n\n /**\n * Disposes the resources held by the subscription. May, for instance, cancel\n * an ongoing Observable execution or cancel any other type of work that\n * started when the Subscription was created.\n * @return {void}\n */\n unsubscribe(): void {\n let errors: any[] | undefined;\n\n if (!this.closed) {\n this.closed = true;\n\n // Remove this from it's parents.\n const { _parentage } = this;\n if (_parentage) {\n this._parentage = null;\n if (Array.isArray(_parentage)) {\n for (const parent of _parentage) {\n parent.remove(this);\n }\n } else {\n _parentage.remove(this);\n }\n }\n\n const { initialTeardown: initialFinalizer } = this;\n if (isFunction(initialFinalizer)) {\n try {\n initialFinalizer();\n } catch (e) {\n errors = e instanceof UnsubscriptionError ? e.errors : [e];\n }\n }\n\n const { _finalizers } = this;\n if (_finalizers) {\n this._finalizers = null;\n for (const finalizer of _finalizers) {\n try {\n execFinalizer(finalizer);\n } catch (err) {\n errors = errors ?? [];\n if (err instanceof UnsubscriptionError) {\n errors = [...errors, ...err.errors];\n } else {\n errors.push(err);\n }\n }\n }\n }\n\n if (errors) {\n throw new UnsubscriptionError(errors);\n }\n }\n }\n\n /**\n * Adds a finalizer to this subscription, so that finalization will be unsubscribed/called\n * when this subscription is unsubscribed. If this subscription is already {@link #closed},\n * because it has already been unsubscribed, then whatever finalizer is passed to it\n * will automatically be executed (unless the finalizer itself is also a closed subscription).\n *\n * Closed Subscriptions cannot be added as finalizers to any subscription. Adding a closed\n * subscription to a any subscription will result in no operation. (A noop).\n *\n * Adding a subscription to itself, or adding `null` or `undefined` will not perform any\n * operation at all. (A noop).\n *\n * `Subscription` instances that are added to this instance will automatically remove themselves\n * if they are unsubscribed. Functions and {@link Unsubscribable} objects that you wish to remove\n * will need to be removed manually with {@link #remove}\n *\n * @param teardown The finalization logic to add to this subscription.\n */\n add(teardown: TeardownLogic): void {\n // Only add the finalizer if it's not undefined\n // and don't add a subscription to itself.\n if (teardown && teardown !== this) {\n if (this.closed) {\n // If this subscription is already closed,\n // execute whatever finalizer is handed to it automatically.\n execFinalizer(teardown);\n } else {\n if (teardown instanceof Subscription) {\n // We don't add closed subscriptions, and we don't add the same subscription\n // twice. Subscription unsubscribe is idempotent.\n if (teardown.closed || teardown._hasParent(this)) {\n return;\n }\n teardown._addParent(this);\n }\n (this._finalizers = this._finalizers ?? []).push(teardown);\n }\n }\n }\n\n /**\n * Checks to see if a this subscription already has a particular parent.\n * This will signal that this subscription has already been added to the parent in question.\n * @param parent the parent to check for\n */\n private _hasParent(parent: Subscription) {\n const { _parentage } = this;\n return _parentage === parent || (Array.isArray(_parentage) && _parentage.includes(parent));\n }\n\n /**\n * Adds a parent to this subscription so it can be removed from the parent if it\n * unsubscribes on it's own.\n *\n * NOTE: THIS ASSUMES THAT {@link _hasParent} HAS ALREADY BEEN CHECKED.\n * @param parent The parent subscription to add\n */\n private _addParent(parent: Subscription) {\n const { _parentage } = this;\n this._parentage = Array.isArray(_parentage) ? (_parentage.push(parent), _parentage) : _parentage ? [_parentage, parent] : parent;\n }\n\n /**\n * Called on a child when it is removed via {@link #remove}.\n * @param parent The parent to remove\n */\n private _removeParent(parent: Subscription) {\n const { _parentage } = this;\n if (_parentage === parent) {\n this._parentage = null;\n } else if (Array.isArray(_parentage)) {\n arrRemove(_parentage, parent);\n }\n }\n\n /**\n * Removes a finalizer from this subscription that was previously added with the {@link #add} method.\n *\n * Note that `Subscription` instances, when unsubscribed, will automatically remove themselves\n * from every other `Subscription` they have been added to. This means that using the `remove` method\n * is not a common thing and should be used thoughtfully.\n *\n * If you add the same finalizer instance of a function or an unsubscribable object to a `Subscription` instance\n * more than once, you will need to call `remove` the same number of times to remove all instances.\n *\n * All finalizer instances are removed to free up memory upon unsubscription.\n *\n * @param teardown The finalizer to remove from this subscription\n */\n remove(teardown: Exclude): void {\n const { _finalizers } = this;\n _finalizers && arrRemove(_finalizers, teardown);\n\n if (teardown instanceof Subscription) {\n teardown._removeParent(this);\n }\n }\n}\n\nexport const EMPTY_SUBSCRIPTION = Subscription.EMPTY;\n\nexport function isSubscription(value: any): value is Subscription {\n return (\n value instanceof Subscription ||\n (value && 'closed' in value && isFunction(value.remove) && isFunction(value.add) && isFunction(value.unsubscribe))\n );\n}\n\nfunction execFinalizer(finalizer: Unsubscribable | (() => void)) {\n if (isFunction(finalizer)) {\n finalizer();\n } else {\n finalizer.unsubscribe();\n }\n}\n", "import { Subscriber } from './Subscriber';\nimport { ObservableNotification } from './types';\n\n/**\n * The {@link GlobalConfig} object for RxJS. It is used to configure things\n * like how to react on unhandled errors.\n */\nexport const config: GlobalConfig = {\n onUnhandledError: null,\n onStoppedNotification: null,\n Promise: undefined,\n useDeprecatedSynchronousErrorHandling: false,\n useDeprecatedNextContext: false,\n};\n\n/**\n * The global configuration object for RxJS, used to configure things\n * like how to react on unhandled errors. Accessible via {@link config}\n * object.\n */\nexport interface GlobalConfig {\n /**\n * A registration point for unhandled errors from RxJS. These are errors that\n * cannot were not handled by consuming code in the usual subscription path. For\n * example, if you have this configured, and you subscribe to an observable without\n * providing an error handler, errors from that subscription will end up here. This\n * will _always_ be called asynchronously on another job in the runtime. This is because\n * we do not want errors thrown in this user-configured handler to interfere with the\n * behavior of the library.\n */\n onUnhandledError: ((err: any) => void) | null;\n\n /**\n * A registration point for notifications that cannot be sent to subscribers because they\n * have completed, errored or have been explicitly unsubscribed. By default, next, complete\n * and error notifications sent to stopped subscribers are noops. However, sometimes callers\n * might want a different behavior. For example, with sources that attempt to report errors\n * to stopped subscribers, a caller can configure RxJS to throw an unhandled error instead.\n * This will _always_ be called asynchronously on another job in the runtime. This is because\n * we do not want errors thrown in this user-configured handler to interfere with the\n * behavior of the library.\n */\n onStoppedNotification: ((notification: ObservableNotification, subscriber: Subscriber) => void) | null;\n\n /**\n * The promise constructor used by default for {@link Observable#toPromise toPromise} and {@link Observable#forEach forEach}\n * methods.\n *\n * @deprecated As of version 8, RxJS will no longer support this sort of injection of a\n * Promise constructor. If you need a Promise implementation other than native promises,\n * please polyfill/patch Promise as you see appropriate. Will be removed in v8.\n */\n Promise?: PromiseConstructorLike;\n\n /**\n * If true, turns on synchronous error rethrowing, which is a deprecated behavior\n * in v6 and higher. This behavior enables bad patterns like wrapping a subscribe\n * call in a try/catch block. It also enables producer interference, a nasty bug\n * where a multicast can be broken for all observers by a downstream consumer with\n * an unhandled error. DO NOT USE THIS FLAG UNLESS IT'S NEEDED TO BUY TIME\n * FOR MIGRATION REASONS.\n *\n * @deprecated As of version 8, RxJS will no longer support synchronous throwing\n * of unhandled errors. All errors will be thrown on a separate call stack to prevent bad\n * behaviors described above. Will be removed in v8.\n */\n useDeprecatedSynchronousErrorHandling: boolean;\n\n /**\n * If true, enables an as-of-yet undocumented feature from v5: The ability to access\n * `unsubscribe()` via `this` context in `next` functions created in observers passed\n * to `subscribe`.\n *\n * This is being removed because the performance was severely problematic, and it could also cause\n * issues when types other than POJOs are passed to subscribe as subscribers, as they will likely have\n * their `this` context overwritten.\n *\n * @deprecated As of version 8, RxJS will no longer support altering the\n * context of next functions provided as part of an observer to Subscribe. Instead,\n * you will have access to a subscription or a signal or token that will allow you to do things like\n * unsubscribe and test closed status. Will be removed in v8.\n */\n useDeprecatedNextContext: boolean;\n}\n", "import type { TimerHandle } from './timerHandle';\ntype SetTimeoutFunction = (handler: () => void, timeout?: number, ...args: any[]) => TimerHandle;\ntype ClearTimeoutFunction = (handle: TimerHandle) => void;\n\ninterface TimeoutProvider {\n setTimeout: SetTimeoutFunction;\n clearTimeout: ClearTimeoutFunction;\n delegate:\n | {\n setTimeout: SetTimeoutFunction;\n clearTimeout: ClearTimeoutFunction;\n }\n | undefined;\n}\n\nexport const timeoutProvider: TimeoutProvider = {\n // When accessing the delegate, use the variable rather than `this` so that\n // the functions can be called without being bound to the provider.\n setTimeout(handler: () => void, timeout?: number, ...args) {\n const { delegate } = timeoutProvider;\n if (delegate?.setTimeout) {\n return delegate.setTimeout(handler, timeout, ...args);\n }\n return setTimeout(handler, timeout, ...args);\n },\n clearTimeout(handle) {\n const { delegate } = timeoutProvider;\n return (delegate?.clearTimeout || clearTimeout)(handle as any);\n },\n delegate: undefined,\n};\n", "import { config } from '../config';\nimport { timeoutProvider } from '../scheduler/timeoutProvider';\n\n/**\n * Handles an error on another job either with the user-configured {@link onUnhandledError},\n * or by throwing it on that new job so it can be picked up by `window.onerror`, `process.on('error')`, etc.\n *\n * This should be called whenever there is an error that is out-of-band with the subscription\n * or when an error hits a terminal boundary of the subscription and no error handler was provided.\n *\n * @param err the error to report\n */\nexport function reportUnhandledError(err: any) {\n timeoutProvider.setTimeout(() => {\n const { onUnhandledError } = config;\n if (onUnhandledError) {\n // Execute the user-configured error handler.\n onUnhandledError(err);\n } else {\n // Throw so it is picked up by the runtime's uncaught error mechanism.\n throw err;\n }\n });\n}\n", "/* tslint:disable:no-empty */\nexport function noop() { }\n", "import { CompleteNotification, NextNotification, ErrorNotification } from './types';\n\n/**\n * A completion object optimized for memory use and created to be the\n * same \"shape\" as other notifications in v8.\n * @internal\n */\nexport const COMPLETE_NOTIFICATION = (() => createNotification('C', undefined, undefined) as CompleteNotification)();\n\n/**\n * Internal use only. Creates an optimized error notification that is the same \"shape\"\n * as other notifications.\n * @internal\n */\nexport function errorNotification(error: any): ErrorNotification {\n return createNotification('E', undefined, error) as any;\n}\n\n/**\n * Internal use only. Creates an optimized next notification that is the same \"shape\"\n * as other notifications.\n * @internal\n */\nexport function nextNotification(value: T) {\n return createNotification('N', value, undefined) as NextNotification;\n}\n\n/**\n * Ensures that all notifications created internally have the same \"shape\" in v8.\n *\n * TODO: This is only exported to support a crazy legacy test in `groupBy`.\n * @internal\n */\nexport function createNotification(kind: 'N' | 'E' | 'C', value: any, error: any) {\n return {\n kind,\n value,\n error,\n };\n}\n", "import { config } from '../config';\n\nlet context: { errorThrown: boolean; error: any } | null = null;\n\n/**\n * Handles dealing with errors for super-gross mode. Creates a context, in which\n * any synchronously thrown errors will be passed to {@link captureError}. Which\n * will record the error such that it will be rethrown after the call back is complete.\n * TODO: Remove in v8\n * @param cb An immediately executed function.\n */\nexport function errorContext(cb: () => void) {\n if (config.useDeprecatedSynchronousErrorHandling) {\n const isRoot = !context;\n if (isRoot) {\n context = { errorThrown: false, error: null };\n }\n cb();\n if (isRoot) {\n const { errorThrown, error } = context!;\n context = null;\n if (errorThrown) {\n throw error;\n }\n }\n } else {\n // This is the general non-deprecated path for everyone that\n // isn't crazy enough to use super-gross mode (useDeprecatedSynchronousErrorHandling)\n cb();\n }\n}\n\n/**\n * Captures errors only in super-gross mode.\n * @param err the error to capture\n */\nexport function captureError(err: any) {\n if (config.useDeprecatedSynchronousErrorHandling && context) {\n context.errorThrown = true;\n context.error = err;\n }\n}\n", "import { isFunction } from './util/isFunction';\nimport { Observer, ObservableNotification } from './types';\nimport { isSubscription, Subscription } from './Subscription';\nimport { config } from './config';\nimport { reportUnhandledError } from './util/reportUnhandledError';\nimport { noop } from './util/noop';\nimport { nextNotification, errorNotification, COMPLETE_NOTIFICATION } from './NotificationFactories';\nimport { timeoutProvider } from './scheduler/timeoutProvider';\nimport { captureError } from './util/errorContext';\n\n/**\n * Implements the {@link Observer} interface and extends the\n * {@link Subscription} class. While the {@link Observer} is the public API for\n * consuming the values of an {@link Observable}, all Observers get converted to\n * a Subscriber, in order to provide Subscription-like capabilities such as\n * `unsubscribe`. Subscriber is a common type in RxJS, and crucial for\n * implementing operators, but it is rarely used as a public API.\n *\n * @class Subscriber\n */\nexport class Subscriber extends Subscription implements Observer {\n /**\n * A static factory for a Subscriber, given a (potentially partial) definition\n * of an Observer.\n * @param next The `next` callback of an Observer.\n * @param error The `error` callback of an\n * Observer.\n * @param complete The `complete` callback of an\n * Observer.\n * @return A Subscriber wrapping the (partially defined)\n * Observer represented by the given arguments.\n * @nocollapse\n * @deprecated Do not use. Will be removed in v8. There is no replacement for this\n * method, and there is no reason to be creating instances of `Subscriber` directly.\n * If you have a specific use case, please file an issue.\n */\n static create(next?: (x?: T) => void, error?: (e?: any) => void, complete?: () => void): Subscriber {\n return new SafeSubscriber(next, error, complete);\n }\n\n /** @deprecated Internal implementation detail, do not use directly. Will be made internal in v8. */\n protected isStopped: boolean = false;\n /** @deprecated Internal implementation detail, do not use directly. Will be made internal in v8. */\n protected destination: Subscriber | Observer; // this `any` is the escape hatch to erase extra type param (e.g. R)\n\n /**\n * @deprecated Internal implementation detail, do not use directly. Will be made internal in v8.\n * There is no reason to directly create an instance of Subscriber. This type is exported for typings reasons.\n */\n constructor(destination?: Subscriber | Observer) {\n super();\n if (destination) {\n this.destination = destination;\n // Automatically chain subscriptions together here.\n // if destination is a Subscription, then it is a Subscriber.\n if (isSubscription(destination)) {\n destination.add(this);\n }\n } else {\n this.destination = EMPTY_OBSERVER;\n }\n }\n\n /**\n * The {@link Observer} callback to receive notifications of type `next` from\n * the Observable, with a value. The Observable may call this method 0 or more\n * times.\n * @param {T} [value] The `next` value.\n * @return {void}\n */\n next(value?: T): void {\n if (this.isStopped) {\n handleStoppedNotification(nextNotification(value), this);\n } else {\n this._next(value!);\n }\n }\n\n /**\n * The {@link Observer} callback to receive notifications of type `error` from\n * the Observable, with an attached `Error`. Notifies the Observer that\n * the Observable has experienced an error condition.\n * @param {any} [err] The `error` exception.\n * @return {void}\n */\n error(err?: any): void {\n if (this.isStopped) {\n handleStoppedNotification(errorNotification(err), this);\n } else {\n this.isStopped = true;\n this._error(err);\n }\n }\n\n /**\n * The {@link Observer} callback to receive a valueless notification of type\n * `complete` from the Observable. Notifies the Observer that the Observable\n * has finished sending push-based notifications.\n * @return {void}\n */\n complete(): void {\n if (this.isStopped) {\n handleStoppedNotification(COMPLETE_NOTIFICATION, this);\n } else {\n this.isStopped = true;\n this._complete();\n }\n }\n\n unsubscribe(): void {\n if (!this.closed) {\n this.isStopped = true;\n super.unsubscribe();\n this.destination = null!;\n }\n }\n\n protected _next(value: T): void {\n this.destination.next(value);\n }\n\n protected _error(err: any): void {\n try {\n this.destination.error(err);\n } finally {\n this.unsubscribe();\n }\n }\n\n protected _complete(): void {\n try {\n this.destination.complete();\n } finally {\n this.unsubscribe();\n }\n }\n}\n\n/**\n * This bind is captured here because we want to be able to have\n * compatibility with monoid libraries that tend to use a method named\n * `bind`. In particular, a library called Monio requires this.\n */\nconst _bind = Function.prototype.bind;\n\nfunction bind any>(fn: Fn, thisArg: any): Fn {\n return _bind.call(fn, thisArg);\n}\n\n/**\n * Internal optimization only, DO NOT EXPOSE.\n * @internal\n */\nclass ConsumerObserver implements Observer {\n constructor(private partialObserver: Partial>) {}\n\n next(value: T): void {\n const { partialObserver } = this;\n if (partialObserver.next) {\n try {\n partialObserver.next(value);\n } catch (error) {\n handleUnhandledError(error);\n }\n }\n }\n\n error(err: any): void {\n const { partialObserver } = this;\n if (partialObserver.error) {\n try {\n partialObserver.error(err);\n } catch (error) {\n handleUnhandledError(error);\n }\n } else {\n handleUnhandledError(err);\n }\n }\n\n complete(): void {\n const { partialObserver } = this;\n if (partialObserver.complete) {\n try {\n partialObserver.complete();\n } catch (error) {\n handleUnhandledError(error);\n }\n }\n }\n}\n\nexport class SafeSubscriber extends Subscriber {\n constructor(\n observerOrNext?: Partial> | ((value: T) => void) | null,\n error?: ((e?: any) => void) | null,\n complete?: (() => void) | null\n ) {\n super();\n\n let partialObserver: Partial>;\n if (isFunction(observerOrNext) || !observerOrNext) {\n // The first argument is a function, not an observer. The next\n // two arguments *could* be observers, or they could be empty.\n partialObserver = {\n next: (observerOrNext ?? undefined) as (((value: T) => void) | undefined),\n error: error ?? undefined,\n complete: complete ?? undefined,\n };\n } else {\n // The first argument is a partial observer.\n let context: any;\n if (this && config.useDeprecatedNextContext) {\n // This is a deprecated path that made `this.unsubscribe()` available in\n // next handler functions passed to subscribe. This only exists behind a flag\n // now, as it is *very* slow.\n context = Object.create(observerOrNext);\n context.unsubscribe = () => this.unsubscribe();\n partialObserver = {\n next: observerOrNext.next && bind(observerOrNext.next, context),\n error: observerOrNext.error && bind(observerOrNext.error, context),\n complete: observerOrNext.complete && bind(observerOrNext.complete, context),\n };\n } else {\n // The \"normal\" path. Just use the partial observer directly.\n partialObserver = observerOrNext;\n }\n }\n\n // Wrap the partial observer to ensure it's a full observer, and\n // make sure proper error handling is accounted for.\n this.destination = new ConsumerObserver(partialObserver);\n }\n}\n\nfunction handleUnhandledError(error: any) {\n if (config.useDeprecatedSynchronousErrorHandling) {\n captureError(error);\n } else {\n // Ideal path, we report this as an unhandled error,\n // which is thrown on a new call stack.\n reportUnhandledError(error);\n }\n}\n\n/**\n * An error handler used when no error handler was supplied\n * to the SafeSubscriber -- meaning no error handler was supplied\n * do the `subscribe` call on our observable.\n * @param err The error to handle\n */\nfunction defaultErrorHandler(err: any) {\n throw err;\n}\n\n/**\n * A handler for notifications that cannot be sent to a stopped subscriber.\n * @param notification The notification being sent\n * @param subscriber The stopped subscriber\n */\nfunction handleStoppedNotification(notification: ObservableNotification, subscriber: Subscriber) {\n const { onStoppedNotification } = config;\n onStoppedNotification && timeoutProvider.setTimeout(() => onStoppedNotification(notification, subscriber));\n}\n\n/**\n * The observer used as a stub for subscriptions where the user did not\n * pass any arguments to `subscribe`. Comes with the default error handling\n * behavior.\n */\nexport const EMPTY_OBSERVER: Readonly> & { closed: true } = {\n closed: true,\n next: noop,\n error: defaultErrorHandler,\n complete: noop,\n};\n", "/**\n * Symbol.observable or a string \"@@observable\". Used for interop\n *\n * @deprecated We will no longer be exporting this symbol in upcoming versions of RxJS.\n * Instead polyfill and use Symbol.observable directly *or* use https://www.npmjs.com/package/symbol-observable\n */\nexport const observable: string | symbol = (() => (typeof Symbol === 'function' && Symbol.observable) || '@@observable')();\n", "/**\n * This function takes one parameter and just returns it. Simply put,\n * this is like `(x: T): T => x`.\n *\n * ## Examples\n *\n * This is useful in some cases when using things like `mergeMap`\n *\n * ```ts\n * import { interval, take, map, range, mergeMap, identity } from 'rxjs';\n *\n * const source$ = interval(1000).pipe(take(5));\n *\n * const result$ = source$.pipe(\n * map(i => range(i)),\n * mergeMap(identity) // same as mergeMap(x => x)\n * );\n *\n * result$.subscribe({\n * next: console.log\n * });\n * ```\n *\n * Or when you want to selectively apply an operator\n *\n * ```ts\n * import { interval, take, identity } from 'rxjs';\n *\n * const shouldLimit = () => Math.random() < 0.5;\n *\n * const source$ = interval(1000);\n *\n * const result$ = source$.pipe(shouldLimit() ? take(5) : identity);\n *\n * result$.subscribe({\n * next: console.log\n * });\n * ```\n *\n * @param x Any value that is returned by this function\n * @returns The value passed as the first parameter to this function\n */\nexport function identity(x: T): T {\n return x;\n}\n", "import { identity } from './identity';\nimport { UnaryFunction } from '../types';\n\nexport function pipe(): typeof identity;\nexport function pipe(fn1: UnaryFunction): UnaryFunction;\nexport function pipe(fn1: UnaryFunction, fn2: UnaryFunction): UnaryFunction;\nexport function pipe(fn1: UnaryFunction, fn2: UnaryFunction, fn3: UnaryFunction): UnaryFunction;\nexport function pipe(\n fn1: UnaryFunction,\n fn2: UnaryFunction,\n fn3: UnaryFunction,\n fn4: UnaryFunction\n): UnaryFunction;\nexport function pipe(\n fn1: UnaryFunction,\n fn2: UnaryFunction,\n fn3: UnaryFunction,\n fn4: UnaryFunction,\n fn5: UnaryFunction\n): UnaryFunction;\nexport function pipe(\n fn1: UnaryFunction,\n fn2: UnaryFunction,\n fn3: UnaryFunction,\n fn4: UnaryFunction,\n fn5: UnaryFunction,\n fn6: UnaryFunction\n): UnaryFunction;\nexport function pipe(\n fn1: UnaryFunction,\n fn2: UnaryFunction,\n fn3: UnaryFunction,\n fn4: UnaryFunction,\n fn5: UnaryFunction,\n fn6: UnaryFunction,\n fn7: UnaryFunction\n): UnaryFunction;\nexport function pipe(\n fn1: UnaryFunction,\n fn2: UnaryFunction,\n fn3: UnaryFunction,\n fn4: UnaryFunction,\n fn5: UnaryFunction,\n fn6: UnaryFunction,\n fn7: UnaryFunction,\n fn8: UnaryFunction\n): UnaryFunction;\nexport function pipe(\n fn1: UnaryFunction,\n fn2: UnaryFunction,\n fn3: UnaryFunction,\n fn4: UnaryFunction,\n fn5: UnaryFunction,\n fn6: UnaryFunction,\n fn7: UnaryFunction,\n fn8: UnaryFunction,\n fn9: UnaryFunction\n): UnaryFunction;\nexport function pipe(\n fn1: UnaryFunction,\n fn2: UnaryFunction,\n fn3: UnaryFunction,\n fn4: UnaryFunction,\n fn5: UnaryFunction,\n fn6: UnaryFunction,\n fn7: UnaryFunction,\n fn8: UnaryFunction,\n fn9: UnaryFunction,\n ...fns: UnaryFunction[]\n): UnaryFunction;\n\n/**\n * pipe() can be called on one or more functions, each of which can take one argument (\"UnaryFunction\")\n * and uses it to return a value.\n * It returns a function that takes one argument, passes it to the first UnaryFunction, and then\n * passes the result to the next one, passes that result to the next one, and so on. \n */\nexport function pipe(...fns: Array>): UnaryFunction {\n return pipeFromArray(fns);\n}\n\n/** @internal */\nexport function pipeFromArray(fns: Array>): UnaryFunction {\n if (fns.length === 0) {\n return identity as UnaryFunction;\n }\n\n if (fns.length === 1) {\n return fns[0];\n }\n\n return function piped(input: T): R {\n return fns.reduce((prev: any, fn: UnaryFunction) => fn(prev), input as any);\n };\n}\n", "import { Operator } from './Operator';\nimport { SafeSubscriber, Subscriber } from './Subscriber';\nimport { isSubscription, Subscription } from './Subscription';\nimport { TeardownLogic, OperatorFunction, Subscribable, Observer } from './types';\nimport { observable as Symbol_observable } from './symbol/observable';\nimport { pipeFromArray } from './util/pipe';\nimport { config } from './config';\nimport { isFunction } from './util/isFunction';\nimport { errorContext } from './util/errorContext';\n\n/**\n * A representation of any set of values over any amount of time. This is the most basic building block\n * of RxJS.\n *\n * @class Observable\n */\nexport class Observable implements Subscribable {\n /**\n * @deprecated Internal implementation detail, do not use directly. Will be made internal in v8.\n */\n source: Observable | undefined;\n\n /**\n * @deprecated Internal implementation detail, do not use directly. Will be made internal in v8.\n */\n operator: Operator | undefined;\n\n /**\n * @constructor\n * @param {Function} subscribe the function that is called when the Observable is\n * initially subscribed to. This function is given a Subscriber, to which new values\n * can be `next`ed, or an `error` method can be called to raise an error, or\n * `complete` can be called to notify of a successful completion.\n */\n constructor(subscribe?: (this: Observable, subscriber: Subscriber) => TeardownLogic) {\n if (subscribe) {\n this._subscribe = subscribe;\n }\n }\n\n // HACK: Since TypeScript inherits static properties too, we have to\n // fight against TypeScript here so Subject can have a different static create signature\n /**\n * Creates a new Observable by calling the Observable constructor\n * @owner Observable\n * @method create\n * @param {Function} subscribe? the subscriber function to be passed to the Observable constructor\n * @return {Observable} a new observable\n * @nocollapse\n * @deprecated Use `new Observable()` instead. Will be removed in v8.\n */\n static create: (...args: any[]) => any = (subscribe?: (subscriber: Subscriber) => TeardownLogic) => {\n return new Observable(subscribe);\n };\n\n /**\n * Creates a new Observable, with this Observable instance as the source, and the passed\n * operator defined as the new observable's operator.\n * @method lift\n * @param operator the operator defining the operation to take on the observable\n * @return a new observable with the Operator applied\n * @deprecated Internal implementation detail, do not use directly. Will be made internal in v8.\n * If you have implemented an operator using `lift`, it is recommended that you create an\n * operator by simply returning `new Observable()` directly. See \"Creating new operators from\n * scratch\" section here: https://rxjs.dev/guide/operators\n */\n lift(operator?: Operator): Observable {\n const observable = new Observable();\n observable.source = this;\n observable.operator = operator;\n return observable;\n }\n\n subscribe(observerOrNext?: Partial> | ((value: T) => void)): Subscription;\n /** @deprecated Instead of passing separate callback arguments, use an observer argument. Signatures taking separate callback arguments will be removed in v8. Details: https://rxjs.dev/deprecations/subscribe-arguments */\n subscribe(next?: ((value: T) => void) | null, error?: ((error: any) => void) | null, complete?: (() => void) | null): Subscription;\n /**\n * Invokes an execution of an Observable and registers Observer handlers for notifications it will emit.\n *\n * Use it when you have all these Observables, but still nothing is happening.\n *\n * `subscribe` is not a regular operator, but a method that calls Observable's internal `subscribe` function. It\n * might be for example a function that you passed to Observable's constructor, but most of the time it is\n * a library implementation, which defines what will be emitted by an Observable, and when it be will emitted. This means\n * that calling `subscribe` is actually the moment when Observable starts its work, not when it is created, as it is often\n * the thought.\n *\n * Apart from starting the execution of an Observable, this method allows you to listen for values\n * that an Observable emits, as well as for when it completes or errors. You can achieve this in two\n * of the following ways.\n *\n * The first way is creating an object that implements {@link Observer} interface. It should have methods\n * defined by that interface, but note that it should be just a regular JavaScript object, which you can create\n * yourself in any way you want (ES6 class, classic function constructor, object literal etc.). In particular, do\n * not attempt to use any RxJS implementation details to create Observers - you don't need them. Remember also\n * that your object does not have to implement all methods. If you find yourself creating a method that doesn't\n * do anything, you can simply omit it. Note however, if the `error` method is not provided and an error happens,\n * it will be thrown asynchronously. Errors thrown asynchronously cannot be caught using `try`/`catch`. Instead,\n * use the {@link onUnhandledError} configuration option or use a runtime handler (like `window.onerror` or\n * `process.on('error)`) to be notified of unhandled errors. Because of this, it's recommended that you provide\n * an `error` method to avoid missing thrown errors.\n *\n * The second way is to give up on Observer object altogether and simply provide callback functions in place of its methods.\n * This means you can provide three functions as arguments to `subscribe`, where the first function is equivalent\n * of a `next` method, the second of an `error` method and the third of a `complete` method. Just as in case of an Observer,\n * if you do not need to listen for something, you can omit a function by passing `undefined` or `null`,\n * since `subscribe` recognizes these functions by where they were placed in function call. When it comes\n * to the `error` function, as with an Observer, if not provided, errors emitted by an Observable will be thrown asynchronously.\n *\n * You can, however, subscribe with no parameters at all. This may be the case where you're not interested in terminal events\n * and you also handled emissions internally by using operators (e.g. using `tap`).\n *\n * Whichever style of calling `subscribe` you use, in both cases it returns a Subscription object.\n * This object allows you to call `unsubscribe` on it, which in turn will stop the work that an Observable does and will clean\n * up all resources that an Observable used. Note that cancelling a subscription will not call `complete` callback\n * provided to `subscribe` function, which is reserved for a regular completion signal that comes from an Observable.\n *\n * Remember that callbacks provided to `subscribe` are not guaranteed to be called asynchronously.\n * It is an Observable itself that decides when these functions will be called. For example {@link of}\n * by default emits all its values synchronously. Always check documentation for how given Observable\n * will behave when subscribed and if its default behavior can be modified with a `scheduler`.\n *\n * #### Examples\n *\n * Subscribe with an {@link guide/observer Observer}\n *\n * ```ts\n * import { of } from 'rxjs';\n *\n * const sumObserver = {\n * sum: 0,\n * next(value) {\n * console.log('Adding: ' + value);\n * this.sum = this.sum + value;\n * },\n * error() {\n * // We actually could just remove this method,\n * // since we do not really care about errors right now.\n * },\n * complete() {\n * console.log('Sum equals: ' + this.sum);\n * }\n * };\n *\n * of(1, 2, 3) // Synchronously emits 1, 2, 3 and then completes.\n * .subscribe(sumObserver);\n *\n * // Logs:\n * // 'Adding: 1'\n * // 'Adding: 2'\n * // 'Adding: 3'\n * // 'Sum equals: 6'\n * ```\n *\n * Subscribe with functions ({@link deprecations/subscribe-arguments deprecated})\n *\n * ```ts\n * import { of } from 'rxjs'\n *\n * let sum = 0;\n *\n * of(1, 2, 3).subscribe(\n * value => {\n * console.log('Adding: ' + value);\n * sum = sum + value;\n * },\n * undefined,\n * () => console.log('Sum equals: ' + sum)\n * );\n *\n * // Logs:\n * // 'Adding: 1'\n * // 'Adding: 2'\n * // 'Adding: 3'\n * // 'Sum equals: 6'\n * ```\n *\n * Cancel a subscription\n *\n * ```ts\n * import { interval } from 'rxjs';\n *\n * const subscription = interval(1000).subscribe({\n * next(num) {\n * console.log(num)\n * },\n * complete() {\n * // Will not be called, even when cancelling subscription.\n * console.log('completed!');\n * }\n * });\n *\n * setTimeout(() => {\n * subscription.unsubscribe();\n * console.log('unsubscribed!');\n * }, 2500);\n *\n * // Logs:\n * // 0 after 1s\n * // 1 after 2s\n * // 'unsubscribed!' after 2.5s\n * ```\n *\n * @param {Observer|Function} observerOrNext (optional) Either an observer with methods to be called,\n * or the first of three possible handlers, which is the handler for each value emitted from the subscribed\n * Observable.\n * @param {Function} error (optional) A handler for a terminal event resulting from an error. If no error handler is provided,\n * the error will be thrown asynchronously as unhandled.\n * @param {Function} complete (optional) A handler for a terminal event resulting from successful completion.\n * @return {Subscription} a subscription reference to the registered handlers\n * @method subscribe\n */\n subscribe(\n observerOrNext?: Partial> | ((value: T) => void) | null,\n error?: ((error: any) => void) | null,\n complete?: (() => void) | null\n ): Subscription {\n const subscriber = isSubscriber(observerOrNext) ? observerOrNext : new SafeSubscriber(observerOrNext, error, complete);\n\n errorContext(() => {\n const { operator, source } = this;\n subscriber.add(\n operator\n ? // We're dealing with a subscription in the\n // operator chain to one of our lifted operators.\n operator.call(subscriber, source)\n : source\n ? // If `source` has a value, but `operator` does not, something that\n // had intimate knowledge of our API, like our `Subject`, must have\n // set it. We're going to just call `_subscribe` directly.\n this._subscribe(subscriber)\n : // In all other cases, we're likely wrapping a user-provided initializer\n // function, so we need to catch errors and handle them appropriately.\n this._trySubscribe(subscriber)\n );\n });\n\n return subscriber;\n }\n\n /** @internal */\n protected _trySubscribe(sink: Subscriber): TeardownLogic {\n try {\n return this._subscribe(sink);\n } catch (err) {\n // We don't need to return anything in this case,\n // because it's just going to try to `add()` to a subscription\n // above.\n sink.error(err);\n }\n }\n\n /**\n * Used as a NON-CANCELLABLE means of subscribing to an observable, for use with\n * APIs that expect promises, like `async/await`. You cannot unsubscribe from this.\n *\n * **WARNING**: Only use this with observables you *know* will complete. If the source\n * observable does not complete, you will end up with a promise that is hung up, and\n * potentially all of the state of an async function hanging out in memory. To avoid\n * this situation, look into adding something like {@link timeout}, {@link take},\n * {@link takeWhile}, or {@link takeUntil} amongst others.\n *\n * #### Example\n *\n * ```ts\n * import { interval, take } from 'rxjs';\n *\n * const source$ = interval(1000).pipe(take(4));\n *\n * async function getTotal() {\n * let total = 0;\n *\n * await source$.forEach(value => {\n * total += value;\n * console.log('observable -> ' + value);\n * });\n *\n * return total;\n * }\n *\n * getTotal().then(\n * total => console.log('Total: ' + total)\n * );\n *\n * // Expected:\n * // 'observable -> 0'\n * // 'observable -> 1'\n * // 'observable -> 2'\n * // 'observable -> 3'\n * // 'Total: 6'\n * ```\n *\n * @param next a handler for each value emitted by the observable\n * @return a promise that either resolves on observable completion or\n * rejects with the handled error\n */\n forEach(next: (value: T) => void): Promise;\n\n /**\n * @param next a handler for each value emitted by the observable\n * @param promiseCtor a constructor function used to instantiate the Promise\n * @return a promise that either resolves on observable completion or\n * rejects with the handled error\n * @deprecated Passing a Promise constructor will no longer be available\n * in upcoming versions of RxJS. This is because it adds weight to the library, for very\n * little benefit. If you need this functionality, it is recommended that you either\n * polyfill Promise, or you create an adapter to convert the returned native promise\n * to whatever promise implementation you wanted. Will be removed in v8.\n */\n forEach(next: (value: T) => void, promiseCtor: PromiseConstructorLike): Promise;\n\n forEach(next: (value: T) => void, promiseCtor?: PromiseConstructorLike): Promise {\n promiseCtor = getPromiseCtor(promiseCtor);\n\n return new promiseCtor((resolve, reject) => {\n const subscriber = new SafeSubscriber({\n next: (value) => {\n try {\n next(value);\n } catch (err) {\n reject(err);\n subscriber.unsubscribe();\n }\n },\n error: reject,\n complete: resolve,\n });\n this.subscribe(subscriber);\n }) as Promise;\n }\n\n /** @internal */\n protected _subscribe(subscriber: Subscriber): TeardownLogic {\n return this.source?.subscribe(subscriber);\n }\n\n /**\n * An interop point defined by the es7-observable spec https://github.com/zenparsing/es-observable\n * @method Symbol.observable\n * @return {Observable} this instance of the observable\n */\n [Symbol_observable]() {\n return this;\n }\n\n /* tslint:disable:max-line-length */\n pipe(): Observable;\n pipe(op1: OperatorFunction): Observable;\n pipe(op1: OperatorFunction, op2: OperatorFunction): Observable;\n pipe(op1: OperatorFunction, op2: OperatorFunction, op3: OperatorFunction): Observable;\n pipe(\n op1: OperatorFunction,\n op2: OperatorFunction,\n op3: OperatorFunction,\n op4: OperatorFunction\n ): Observable;\n pipe(\n op1: OperatorFunction,\n op2: OperatorFunction,\n op3: OperatorFunction,\n op4: OperatorFunction,\n op5: OperatorFunction\n ): Observable;\n pipe(\n op1: OperatorFunction,\n op2: OperatorFunction,\n op3: OperatorFunction,\n op4: OperatorFunction,\n op5: OperatorFunction,\n op6: OperatorFunction\n ): Observable;\n pipe(\n op1: OperatorFunction,\n op2: OperatorFunction,\n op3: OperatorFunction,\n op4: OperatorFunction,\n op5: OperatorFunction,\n op6: OperatorFunction,\n op7: OperatorFunction\n ): Observable;\n pipe(\n op1: OperatorFunction,\n op2: OperatorFunction,\n op3: OperatorFunction,\n op4: OperatorFunction,\n op5: OperatorFunction,\n op6: OperatorFunction,\n op7: OperatorFunction,\n op8: OperatorFunction\n ): Observable;\n pipe(\n op1: OperatorFunction,\n op2: OperatorFunction,\n op3: OperatorFunction,\n op4: OperatorFunction,\n op5: OperatorFunction,\n op6: OperatorFunction,\n op7: OperatorFunction,\n op8: OperatorFunction,\n op9: OperatorFunction\n ): Observable;\n pipe(\n op1: OperatorFunction,\n op2: OperatorFunction,\n op3: OperatorFunction,\n op4: OperatorFunction,\n op5: OperatorFunction,\n op6: OperatorFunction,\n op7: OperatorFunction,\n op8: OperatorFunction,\n op9: OperatorFunction,\n ...operations: OperatorFunction[]\n ): Observable;\n /* tslint:enable:max-line-length */\n\n /**\n * Used to stitch together functional operators into a chain.\n * @method pipe\n * @return {Observable} the Observable result of all of the operators having\n * been called in the order they were passed in.\n *\n * ## Example\n *\n * ```ts\n * import { interval, filter, map, scan } from 'rxjs';\n *\n * interval(1000)\n * .pipe(\n * filter(x => x % 2 === 0),\n * map(x => x + x),\n * scan((acc, x) => acc + x)\n * )\n * .subscribe(x => console.log(x));\n * ```\n */\n pipe(...operations: OperatorFunction[]): Observable {\n return pipeFromArray(operations)(this);\n }\n\n /* tslint:disable:max-line-length */\n /** @deprecated Replaced with {@link firstValueFrom} and {@link lastValueFrom}. Will be removed in v8. Details: https://rxjs.dev/deprecations/to-promise */\n toPromise(): Promise;\n /** @deprecated Replaced with {@link firstValueFrom} and {@link lastValueFrom}. Will be removed in v8. Details: https://rxjs.dev/deprecations/to-promise */\n toPromise(PromiseCtor: typeof Promise): Promise;\n /** @deprecated Replaced with {@link firstValueFrom} and {@link lastValueFrom}. Will be removed in v8. Details: https://rxjs.dev/deprecations/to-promise */\n toPromise(PromiseCtor: PromiseConstructorLike): Promise;\n /* tslint:enable:max-line-length */\n\n /**\n * Subscribe to this Observable and get a Promise resolving on\n * `complete` with the last emission (if any).\n *\n * **WARNING**: Only use this with observables you *know* will complete. If the source\n * observable does not complete, you will end up with a promise that is hung up, and\n * potentially all of the state of an async function hanging out in memory. To avoid\n * this situation, look into adding something like {@link timeout}, {@link take},\n * {@link takeWhile}, or {@link takeUntil} amongst others.\n *\n * @method toPromise\n * @param [promiseCtor] a constructor function used to instantiate\n * the Promise\n * @return A Promise that resolves with the last value emit, or\n * rejects on an error. If there were no emissions, Promise\n * resolves with undefined.\n * @deprecated Replaced with {@link firstValueFrom} and {@link lastValueFrom}. Will be removed in v8. Details: https://rxjs.dev/deprecations/to-promise\n */\n toPromise(promiseCtor?: PromiseConstructorLike): Promise {\n promiseCtor = getPromiseCtor(promiseCtor);\n\n return new promiseCtor((resolve, reject) => {\n let value: T | undefined;\n this.subscribe(\n (x: T) => (value = x),\n (err: any) => reject(err),\n () => resolve(value)\n );\n }) as Promise;\n }\n}\n\n/**\n * Decides between a passed promise constructor from consuming code,\n * A default configured promise constructor, and the native promise\n * constructor and returns it. If nothing can be found, it will throw\n * an error.\n * @param promiseCtor The optional promise constructor to passed by consuming code\n */\nfunction getPromiseCtor(promiseCtor: PromiseConstructorLike | undefined) {\n return promiseCtor ?? config.Promise ?? Promise;\n}\n\nfunction isObserver(value: any): value is Observer {\n return value && isFunction(value.next) && isFunction(value.error) && isFunction(value.complete);\n}\n\nfunction isSubscriber(value: any): value is Subscriber {\n return (value && value instanceof Subscriber) || (isObserver(value) && isSubscription(value));\n}\n", "import { Observable } from '../Observable';\nimport { Subscriber } from '../Subscriber';\nimport { OperatorFunction } from '../types';\nimport { isFunction } from './isFunction';\n\n/**\n * Used to determine if an object is an Observable with a lift function.\n */\nexport function hasLift(source: any): source is { lift: InstanceType['lift'] } {\n return isFunction(source?.lift);\n}\n\n/**\n * Creates an `OperatorFunction`. Used to define operators throughout the library in a concise way.\n * @param init The logic to connect the liftedSource to the subscriber at the moment of subscription.\n */\nexport function operate(\n init: (liftedSource: Observable, subscriber: Subscriber) => (() => void) | void\n): OperatorFunction {\n return (source: Observable) => {\n if (hasLift(source)) {\n return source.lift(function (this: Subscriber, liftedSource: Observable) {\n try {\n return init(liftedSource, this);\n } catch (err) {\n this.error(err);\n }\n });\n }\n throw new TypeError('Unable to lift unknown Observable type');\n };\n}\n", "import { Subscriber } from '../Subscriber';\n\n/**\n * Creates an instance of an `OperatorSubscriber`.\n * @param destination The downstream subscriber.\n * @param onNext Handles next values, only called if this subscriber is not stopped or closed. Any\n * error that occurs in this function is caught and sent to the `error` method of this subscriber.\n * @param onError Handles errors from the subscription, any errors that occur in this handler are caught\n * and send to the `destination` error handler.\n * @param onComplete Handles completion notification from the subscription. Any errors that occur in\n * this handler are sent to the `destination` error handler.\n * @param onFinalize Additional teardown logic here. This will only be called on teardown if the\n * subscriber itself is not already closed. This is called after all other teardown logic is executed.\n */\nexport function createOperatorSubscriber(\n destination: Subscriber,\n onNext?: (value: T) => void,\n onComplete?: () => void,\n onError?: (err: any) => void,\n onFinalize?: () => void\n): Subscriber {\n return new OperatorSubscriber(destination, onNext, onComplete, onError, onFinalize);\n}\n\n/**\n * A generic helper for allowing operators to be created with a Subscriber and\n * use closures to capture necessary state from the operator function itself.\n */\nexport class OperatorSubscriber extends Subscriber {\n /**\n * Creates an instance of an `OperatorSubscriber`.\n * @param destination The downstream subscriber.\n * @param onNext Handles next values, only called if this subscriber is not stopped or closed. Any\n * error that occurs in this function is caught and sent to the `error` method of this subscriber.\n * @param onError Handles errors from the subscription, any errors that occur in this handler are caught\n * and send to the `destination` error handler.\n * @param onComplete Handles completion notification from the subscription. Any errors that occur in\n * this handler are sent to the `destination` error handler.\n * @param onFinalize Additional finalization logic here. This will only be called on finalization if the\n * subscriber itself is not already closed. This is called after all other finalization logic is executed.\n * @param shouldUnsubscribe An optional check to see if an unsubscribe call should truly unsubscribe.\n * NOTE: This currently **ONLY** exists to support the strange behavior of {@link groupBy}, where unsubscription\n * to the resulting observable does not actually disconnect from the source if there are active subscriptions\n * to any grouped observable. (DO NOT EXPOSE OR USE EXTERNALLY!!!)\n */\n constructor(\n destination: Subscriber,\n onNext?: (value: T) => void,\n onComplete?: () => void,\n onError?: (err: any) => void,\n private onFinalize?: () => void,\n private shouldUnsubscribe?: () => boolean\n ) {\n // It's important - for performance reasons - that all of this class's\n // members are initialized and that they are always initialized in the same\n // order. This will ensure that all OperatorSubscriber instances have the\n // same hidden class in V8. This, in turn, will help keep the number of\n // hidden classes involved in property accesses within the base class as\n // low as possible. If the number of hidden classes involved exceeds four,\n // the property accesses will become megamorphic and performance penalties\n // will be incurred - i.e. inline caches won't be used.\n //\n // The reasons for ensuring all instances have the same hidden class are\n // further discussed in this blog post from Benedikt Meurer:\n // https://benediktmeurer.de/2018/03/23/impact-of-polymorphism-on-component-based-frameworks-like-react/\n super(destination);\n this._next = onNext\n ? function (this: OperatorSubscriber, value: T) {\n try {\n onNext(value);\n } catch (err) {\n destination.error(err);\n }\n }\n : super._next;\n this._error = onError\n ? function (this: OperatorSubscriber, err: any) {\n try {\n onError(err);\n } catch (err) {\n // Send any errors that occur down stream.\n destination.error(err);\n } finally {\n // Ensure finalization.\n this.unsubscribe();\n }\n }\n : super._error;\n this._complete = onComplete\n ? function (this: OperatorSubscriber) {\n try {\n onComplete();\n } catch (err) {\n // Send any errors that occur down stream.\n destination.error(err);\n } finally {\n // Ensure finalization.\n this.unsubscribe();\n }\n }\n : super._complete;\n }\n\n unsubscribe() {\n if (!this.shouldUnsubscribe || this.shouldUnsubscribe()) {\n const { closed } = this;\n super.unsubscribe();\n // Execute additional teardown if we have any and we didn't already do so.\n !closed && this.onFinalize?.();\n }\n }\n}\n", "import { Subscription } from '../Subscription';\n\ninterface AnimationFrameProvider {\n schedule(callback: FrameRequestCallback): Subscription;\n requestAnimationFrame: typeof requestAnimationFrame;\n cancelAnimationFrame: typeof cancelAnimationFrame;\n delegate:\n | {\n requestAnimationFrame: typeof requestAnimationFrame;\n cancelAnimationFrame: typeof cancelAnimationFrame;\n }\n | undefined;\n}\n\nexport const animationFrameProvider: AnimationFrameProvider = {\n // When accessing the delegate, use the variable rather than `this` so that\n // the functions can be called without being bound to the provider.\n schedule(callback) {\n let request = requestAnimationFrame;\n let cancel: typeof cancelAnimationFrame | undefined = cancelAnimationFrame;\n const { delegate } = animationFrameProvider;\n if (delegate) {\n request = delegate.requestAnimationFrame;\n cancel = delegate.cancelAnimationFrame;\n }\n const handle = request((timestamp) => {\n // Clear the cancel function. The request has been fulfilled, so\n // attempting to cancel the request upon unsubscription would be\n // pointless.\n cancel = undefined;\n callback(timestamp);\n });\n return new Subscription(() => cancel?.(handle));\n },\n requestAnimationFrame(...args) {\n const { delegate } = animationFrameProvider;\n return (delegate?.requestAnimationFrame || requestAnimationFrame)(...args);\n },\n cancelAnimationFrame(...args) {\n const { delegate } = animationFrameProvider;\n return (delegate?.cancelAnimationFrame || cancelAnimationFrame)(...args);\n },\n delegate: undefined,\n};\n", "import { createErrorClass } from './createErrorClass';\n\nexport interface ObjectUnsubscribedError extends Error {}\n\nexport interface ObjectUnsubscribedErrorCtor {\n /**\n * @deprecated Internal implementation detail. Do not construct error instances.\n * Cannot be tagged as internal: https://github.com/ReactiveX/rxjs/issues/6269\n */\n new (): ObjectUnsubscribedError;\n}\n\n/**\n * An error thrown when an action is invalid because the object has been\n * unsubscribed.\n *\n * @see {@link Subject}\n * @see {@link BehaviorSubject}\n *\n * @class ObjectUnsubscribedError\n */\nexport const ObjectUnsubscribedError: ObjectUnsubscribedErrorCtor = createErrorClass(\n (_super) =>\n function ObjectUnsubscribedErrorImpl(this: any) {\n _super(this);\n this.name = 'ObjectUnsubscribedError';\n this.message = 'object unsubscribed';\n }\n);\n", "import { Operator } from './Operator';\nimport { Observable } from './Observable';\nimport { Subscriber } from './Subscriber';\nimport { Subscription, EMPTY_SUBSCRIPTION } from './Subscription';\nimport { Observer, SubscriptionLike, TeardownLogic } from './types';\nimport { ObjectUnsubscribedError } from './util/ObjectUnsubscribedError';\nimport { arrRemove } from './util/arrRemove';\nimport { errorContext } from './util/errorContext';\n\n/**\n * A Subject is a special type of Observable that allows values to be\n * multicasted to many Observers. Subjects are like EventEmitters.\n *\n * Every Subject is an Observable and an Observer. You can subscribe to a\n * Subject, and you can call next to feed values as well as error and complete.\n */\nexport class Subject extends Observable implements SubscriptionLike {\n closed = false;\n\n private currentObservers: Observer[] | null = null;\n\n /** @deprecated Internal implementation detail, do not use directly. Will be made internal in v8. */\n observers: Observer[] = [];\n /** @deprecated Internal implementation detail, do not use directly. Will be made internal in v8. */\n isStopped = false;\n /** @deprecated Internal implementation detail, do not use directly. Will be made internal in v8. */\n hasError = false;\n /** @deprecated Internal implementation detail, do not use directly. Will be made internal in v8. */\n thrownError: any = null;\n\n /**\n * Creates a \"subject\" by basically gluing an observer to an observable.\n *\n * @nocollapse\n * @deprecated Recommended you do not use. Will be removed at some point in the future. Plans for replacement still under discussion.\n */\n static create: (...args: any[]) => any = (destination: Observer, source: Observable): AnonymousSubject => {\n return new AnonymousSubject(destination, source);\n };\n\n constructor() {\n // NOTE: This must be here to obscure Observable's constructor.\n super();\n }\n\n /** @deprecated Internal implementation detail, do not use directly. Will be made internal in v8. */\n lift(operator: Operator): Observable {\n const subject = new AnonymousSubject(this, this);\n subject.operator = operator as any;\n return subject as any;\n }\n\n /** @internal */\n protected _throwIfClosed() {\n if (this.closed) {\n throw new ObjectUnsubscribedError();\n }\n }\n\n next(value: T) {\n errorContext(() => {\n this._throwIfClosed();\n if (!this.isStopped) {\n if (!this.currentObservers) {\n this.currentObservers = Array.from(this.observers);\n }\n for (const observer of this.currentObservers) {\n observer.next(value);\n }\n }\n });\n }\n\n error(err: any) {\n errorContext(() => {\n this._throwIfClosed();\n if (!this.isStopped) {\n this.hasError = this.isStopped = true;\n this.thrownError = err;\n const { observers } = this;\n while (observers.length) {\n observers.shift()!.error(err);\n }\n }\n });\n }\n\n complete() {\n errorContext(() => {\n this._throwIfClosed();\n if (!this.isStopped) {\n this.isStopped = true;\n const { observers } = this;\n while (observers.length) {\n observers.shift()!.complete();\n }\n }\n });\n }\n\n unsubscribe() {\n this.isStopped = this.closed = true;\n this.observers = this.currentObservers = null!;\n }\n\n get observed() {\n return this.observers?.length > 0;\n }\n\n /** @internal */\n protected _trySubscribe(subscriber: Subscriber): TeardownLogic {\n this._throwIfClosed();\n return super._trySubscribe(subscriber);\n }\n\n /** @internal */\n protected _subscribe(subscriber: Subscriber): Subscription {\n this._throwIfClosed();\n this._checkFinalizedStatuses(subscriber);\n return this._innerSubscribe(subscriber);\n }\n\n /** @internal */\n protected _innerSubscribe(subscriber: Subscriber) {\n const { hasError, isStopped, observers } = this;\n if (hasError || isStopped) {\n return EMPTY_SUBSCRIPTION;\n }\n this.currentObservers = null;\n observers.push(subscriber);\n return new Subscription(() => {\n this.currentObservers = null;\n arrRemove(observers, subscriber);\n });\n }\n\n /** @internal */\n protected _checkFinalizedStatuses(subscriber: Subscriber) {\n const { hasError, thrownError, isStopped } = this;\n if (hasError) {\n subscriber.error(thrownError);\n } else if (isStopped) {\n subscriber.complete();\n }\n }\n\n /**\n * Creates a new Observable with this Subject as the source. You can do this\n * to create custom Observer-side logic of the Subject and conceal it from\n * code that uses the Observable.\n * @return {Observable} Observable that the Subject casts to\n */\n asObservable(): Observable {\n const observable: any = new Observable();\n observable.source = this;\n return observable;\n }\n}\n\n/**\n * @class AnonymousSubject\n */\nexport class AnonymousSubject extends Subject {\n constructor(\n /** @deprecated Internal implementation detail, do not use directly. Will be made internal in v8. */\n public destination?: Observer,\n source?: Observable\n ) {\n super();\n this.source = source;\n }\n\n next(value: T) {\n this.destination?.next?.(value);\n }\n\n error(err: any) {\n this.destination?.error?.(err);\n }\n\n complete() {\n this.destination?.complete?.();\n }\n\n /** @internal */\n protected _subscribe(subscriber: Subscriber): Subscription {\n return this.source?.subscribe(subscriber) ?? EMPTY_SUBSCRIPTION;\n }\n}\n", "import { Subject } from './Subject';\nimport { Subscriber } from './Subscriber';\nimport { Subscription } from './Subscription';\n\n/**\n * A variant of Subject that requires an initial value and emits its current\n * value whenever it is subscribed to.\n *\n * @class BehaviorSubject\n */\nexport class BehaviorSubject extends Subject {\n constructor(private _value: T) {\n super();\n }\n\n get value(): T {\n return this.getValue();\n }\n\n /** @internal */\n protected _subscribe(subscriber: Subscriber): Subscription {\n const subscription = super._subscribe(subscriber);\n !subscription.closed && subscriber.next(this._value);\n return subscription;\n }\n\n getValue(): T {\n const { hasError, thrownError, _value } = this;\n if (hasError) {\n throw thrownError;\n }\n this._throwIfClosed();\n return _value;\n }\n\n next(value: T): void {\n super.next((this._value = value));\n }\n}\n", "import { TimestampProvider } from '../types';\n\ninterface DateTimestampProvider extends TimestampProvider {\n delegate: TimestampProvider | undefined;\n}\n\nexport const dateTimestampProvider: DateTimestampProvider = {\n now() {\n // Use the variable rather than `this` so that the function can be called\n // without being bound to the provider.\n return (dateTimestampProvider.delegate || Date).now();\n },\n delegate: undefined,\n};\n", "import { Subject } from './Subject';\nimport { TimestampProvider } from './types';\nimport { Subscriber } from './Subscriber';\nimport { Subscription } from './Subscription';\nimport { dateTimestampProvider } from './scheduler/dateTimestampProvider';\n\n/**\n * A variant of {@link Subject} that \"replays\" old values to new subscribers by emitting them when they first subscribe.\n *\n * `ReplaySubject` has an internal buffer that will store a specified number of values that it has observed. Like `Subject`,\n * `ReplaySubject` \"observes\" values by having them passed to its `next` method. When it observes a value, it will store that\n * value for a time determined by the configuration of the `ReplaySubject`, as passed to its constructor.\n *\n * When a new subscriber subscribes to the `ReplaySubject` instance, it will synchronously emit all values in its buffer in\n * a First-In-First-Out (FIFO) manner. The `ReplaySubject` will also complete, if it has observed completion; and it will\n * error if it has observed an error.\n *\n * There are two main configuration items to be concerned with:\n *\n * 1. `bufferSize` - This will determine how many items are stored in the buffer, defaults to infinite.\n * 2. `windowTime` - The amount of time to hold a value in the buffer before removing it from the buffer.\n *\n * Both configurations may exist simultaneously. So if you would like to buffer a maximum of 3 values, as long as the values\n * are less than 2 seconds old, you could do so with a `new ReplaySubject(3, 2000)`.\n *\n * ### Differences with BehaviorSubject\n *\n * `BehaviorSubject` is similar to `new ReplaySubject(1)`, with a couple of exceptions:\n *\n * 1. `BehaviorSubject` comes \"primed\" with a single value upon construction.\n * 2. `ReplaySubject` will replay values, even after observing an error, where `BehaviorSubject` will not.\n *\n * @see {@link Subject}\n * @see {@link BehaviorSubject}\n * @see {@link shareReplay}\n */\nexport class ReplaySubject extends Subject {\n private _buffer: (T | number)[] = [];\n private _infiniteTimeWindow = true;\n\n /**\n * @param bufferSize The size of the buffer to replay on subscription\n * @param windowTime The amount of time the buffered items will stay buffered\n * @param timestampProvider An object with a `now()` method that provides the current timestamp. This is used to\n * calculate the amount of time something has been buffered.\n */\n constructor(\n private _bufferSize = Infinity,\n private _windowTime = Infinity,\n private _timestampProvider: TimestampProvider = dateTimestampProvider\n ) {\n super();\n this._infiniteTimeWindow = _windowTime === Infinity;\n this._bufferSize = Math.max(1, _bufferSize);\n this._windowTime = Math.max(1, _windowTime);\n }\n\n next(value: T): void {\n const { isStopped, _buffer, _infiniteTimeWindow, _timestampProvider, _windowTime } = this;\n if (!isStopped) {\n _buffer.push(value);\n !_infiniteTimeWindow && _buffer.push(_timestampProvider.now() + _windowTime);\n }\n this._trimBuffer();\n super.next(value);\n }\n\n /** @internal */\n protected _subscribe(subscriber: Subscriber): Subscription {\n this._throwIfClosed();\n this._trimBuffer();\n\n const subscription = this._innerSubscribe(subscriber);\n\n const { _infiniteTimeWindow, _buffer } = this;\n // We use a copy here, so reentrant code does not mutate our array while we're\n // emitting it to a new subscriber.\n const copy = _buffer.slice();\n for (let i = 0; i < copy.length && !subscriber.closed; i += _infiniteTimeWindow ? 1 : 2) {\n subscriber.next(copy[i] as T);\n }\n\n this._checkFinalizedStatuses(subscriber);\n\n return subscription;\n }\n\n private _trimBuffer() {\n const { _bufferSize, _timestampProvider, _buffer, _infiniteTimeWindow } = this;\n // If we don't have an infinite buffer size, and we're over the length,\n // use splice to truncate the old buffer values off. Note that we have to\n // double the size for instances where we're not using an infinite time window\n // because we're storing the values and the timestamps in the same array.\n const adjustedBufferSize = (_infiniteTimeWindow ? 1 : 2) * _bufferSize;\n _bufferSize < Infinity && adjustedBufferSize < _buffer.length && _buffer.splice(0, _buffer.length - adjustedBufferSize);\n\n // Now, if we're not in an infinite time window, remove all values where the time is\n // older than what is allowed.\n if (!_infiniteTimeWindow) {\n const now = _timestampProvider.now();\n let last = 0;\n // Search the array for the first timestamp that isn't expired and\n // truncate the buffer up to that point.\n for (let i = 1; i < _buffer.length && (_buffer[i] as number) <= now; i += 2) {\n last = i;\n }\n last && _buffer.splice(0, last + 1);\n }\n }\n}\n", "import { Scheduler } from '../Scheduler';\nimport { Subscription } from '../Subscription';\nimport { SchedulerAction } from '../types';\n\n/**\n * A unit of work to be executed in a `scheduler`. An action is typically\n * created from within a {@link SchedulerLike} and an RxJS user does not need to concern\n * themselves about creating and manipulating an Action.\n *\n * ```ts\n * class Action extends Subscription {\n * new (scheduler: Scheduler, work: (state?: T) => void);\n * schedule(state?: T, delay: number = 0): Subscription;\n * }\n * ```\n *\n * @class Action\n */\nexport class Action extends Subscription {\n constructor(scheduler: Scheduler, work: (this: SchedulerAction, state?: T) => void) {\n super();\n }\n /**\n * Schedules this action on its parent {@link SchedulerLike} for execution. May be passed\n * some context object, `state`. May happen at some point in the future,\n * according to the `delay` parameter, if specified.\n * @param {T} [state] Some contextual data that the `work` function uses when\n * called by the Scheduler.\n * @param {number} [delay] Time to wait before executing the work, where the\n * time unit is implicit and defined by the Scheduler.\n * @return {void}\n */\n public schedule(state?: T, delay: number = 0): Subscription {\n return this;\n }\n}\n", "import type { TimerHandle } from './timerHandle';\ntype SetIntervalFunction = (handler: () => void, timeout?: number, ...args: any[]) => TimerHandle;\ntype ClearIntervalFunction = (handle: TimerHandle) => void;\n\ninterface IntervalProvider {\n setInterval: SetIntervalFunction;\n clearInterval: ClearIntervalFunction;\n delegate:\n | {\n setInterval: SetIntervalFunction;\n clearInterval: ClearIntervalFunction;\n }\n | undefined;\n}\n\nexport const intervalProvider: IntervalProvider = {\n // When accessing the delegate, use the variable rather than `this` so that\n // the functions can be called without being bound to the provider.\n setInterval(handler: () => void, timeout?: number, ...args) {\n const { delegate } = intervalProvider;\n if (delegate?.setInterval) {\n return delegate.setInterval(handler, timeout, ...args);\n }\n return setInterval(handler, timeout, ...args);\n },\n clearInterval(handle) {\n const { delegate } = intervalProvider;\n return (delegate?.clearInterval || clearInterval)(handle as any);\n },\n delegate: undefined,\n};\n", "import { Action } from './Action';\nimport { SchedulerAction } from '../types';\nimport { Subscription } from '../Subscription';\nimport { AsyncScheduler } from './AsyncScheduler';\nimport { intervalProvider } from './intervalProvider';\nimport { arrRemove } from '../util/arrRemove';\nimport { TimerHandle } from './timerHandle';\n\nexport class AsyncAction extends Action {\n public id: TimerHandle | undefined;\n public state?: T;\n // @ts-ignore: Property has no initializer and is not definitely assigned\n public delay: number;\n protected pending: boolean = false;\n\n constructor(protected scheduler: AsyncScheduler, protected work: (this: SchedulerAction, state?: T) => void) {\n super(scheduler, work);\n }\n\n public schedule(state?: T, delay: number = 0): Subscription {\n if (this.closed) {\n return this;\n }\n\n // Always replace the current state with the new state.\n this.state = state;\n\n const id = this.id;\n const scheduler = this.scheduler;\n\n //\n // Important implementation note:\n //\n // Actions only execute once by default, unless rescheduled from within the\n // scheduled callback. This allows us to implement single and repeat\n // actions via the same code path, without adding API surface area, as well\n // as mimic traditional recursion but across asynchronous boundaries.\n //\n // However, JS runtimes and timers distinguish between intervals achieved by\n // serial `setTimeout` calls vs. a single `setInterval` call. An interval of\n // serial `setTimeout` calls can be individually delayed, which delays\n // scheduling the next `setTimeout`, and so on. `setInterval` attempts to\n // guarantee the interval callback will be invoked more precisely to the\n // interval period, regardless of load.\n //\n // Therefore, we use `setInterval` to schedule single and repeat actions.\n // If the action reschedules itself with the same delay, the interval is not\n // canceled. If the action doesn't reschedule, or reschedules with a\n // different delay, the interval will be canceled after scheduled callback\n // execution.\n //\n if (id != null) {\n this.id = this.recycleAsyncId(scheduler, id, delay);\n }\n\n // Set the pending flag indicating that this action has been scheduled, or\n // has recursively rescheduled itself.\n this.pending = true;\n\n this.delay = delay;\n // If this action has already an async Id, don't request a new one.\n this.id = this.id ?? this.requestAsyncId(scheduler, this.id, delay);\n\n return this;\n }\n\n protected requestAsyncId(scheduler: AsyncScheduler, _id?: TimerHandle, delay: number = 0): TimerHandle {\n return intervalProvider.setInterval(scheduler.flush.bind(scheduler, this), delay);\n }\n\n protected recycleAsyncId(_scheduler: AsyncScheduler, id?: TimerHandle, delay: number | null = 0): TimerHandle | undefined {\n // If this action is rescheduled with the same delay time, don't clear the interval id.\n if (delay != null && this.delay === delay && this.pending === false) {\n return id;\n }\n // Otherwise, if the action's delay time is different from the current delay,\n // or the action has been rescheduled before it's executed, clear the interval id\n if (id != null) {\n intervalProvider.clearInterval(id);\n }\n\n return undefined;\n }\n\n /**\n * Immediately executes this action and the `work` it contains.\n * @return {any}\n */\n public execute(state: T, delay: number): any {\n if (this.closed) {\n return new Error('executing a cancelled action');\n }\n\n this.pending = false;\n const error = this._execute(state, delay);\n if (error) {\n return error;\n } else if (this.pending === false && this.id != null) {\n // Dequeue if the action didn't reschedule itself. Don't call\n // unsubscribe(), because the action could reschedule later.\n // For example:\n // ```\n // scheduler.schedule(function doWork(counter) {\n // /* ... I'm a busy worker bee ... */\n // var originalAction = this;\n // /* wait 100ms before rescheduling the action */\n // setTimeout(function () {\n // originalAction.schedule(counter + 1);\n // }, 100);\n // }, 1000);\n // ```\n this.id = this.recycleAsyncId(this.scheduler, this.id, null);\n }\n }\n\n protected _execute(state: T, _delay: number): any {\n let errored: boolean = false;\n let errorValue: any;\n try {\n this.work(state);\n } catch (e) {\n errored = true;\n // HACK: Since code elsewhere is relying on the \"truthiness\" of the\n // return here, we can't have it return \"\" or 0 or false.\n // TODO: Clean this up when we refactor schedulers mid-version-8 or so.\n errorValue = e ? e : new Error('Scheduled action threw falsy error');\n }\n if (errored) {\n this.unsubscribe();\n return errorValue;\n }\n }\n\n unsubscribe() {\n if (!this.closed) {\n const { id, scheduler } = this;\n const { actions } = scheduler;\n\n this.work = this.state = this.scheduler = null!;\n this.pending = false;\n\n arrRemove(actions, this);\n if (id != null) {\n this.id = this.recycleAsyncId(scheduler, id, null);\n }\n\n this.delay = null!;\n super.unsubscribe();\n }\n }\n}\n", "import { Action } from './scheduler/Action';\nimport { Subscription } from './Subscription';\nimport { SchedulerLike, SchedulerAction } from './types';\nimport { dateTimestampProvider } from './scheduler/dateTimestampProvider';\n\n/**\n * An execution context and a data structure to order tasks and schedule their\n * execution. Provides a notion of (potentially virtual) time, through the\n * `now()` getter method.\n *\n * Each unit of work in a Scheduler is called an `Action`.\n *\n * ```ts\n * class Scheduler {\n * now(): number;\n * schedule(work, delay?, state?): Subscription;\n * }\n * ```\n *\n * @class Scheduler\n * @deprecated Scheduler is an internal implementation detail of RxJS, and\n * should not be used directly. Rather, create your own class and implement\n * {@link SchedulerLike}. Will be made internal in v8.\n */\nexport class Scheduler implements SchedulerLike {\n public static now: () => number = dateTimestampProvider.now;\n\n constructor(private schedulerActionCtor: typeof Action, now: () => number = Scheduler.now) {\n this.now = now;\n }\n\n /**\n * A getter method that returns a number representing the current time\n * (at the time this function was called) according to the scheduler's own\n * internal clock.\n * @return {number} A number that represents the current time. May or may not\n * have a relation to wall-clock time. May or may not refer to a time unit\n * (e.g. milliseconds).\n */\n public now: () => number;\n\n /**\n * Schedules a function, `work`, for execution. May happen at some point in\n * the future, according to the `delay` parameter, if specified. May be passed\n * some context object, `state`, which will be passed to the `work` function.\n *\n * The given arguments will be processed an stored as an Action object in a\n * queue of actions.\n *\n * @param {function(state: ?T): ?Subscription} work A function representing a\n * task, or some unit of work to be executed by the Scheduler.\n * @param {number} [delay] Time to wait before executing the work, where the\n * time unit is implicit and defined by the Scheduler itself.\n * @param {T} [state] Some contextual data that the `work` function uses when\n * called by the Scheduler.\n * @return {Subscription} A subscription in order to be able to unsubscribe\n * the scheduled work.\n */\n public schedule(work: (this: SchedulerAction, state?: T) => void, delay: number = 0, state?: T): Subscription {\n return new this.schedulerActionCtor(this, work).schedule(state, delay);\n }\n}\n", "import { Scheduler } from '../Scheduler';\nimport { Action } from './Action';\nimport { AsyncAction } from './AsyncAction';\nimport { TimerHandle } from './timerHandle';\n\nexport class AsyncScheduler extends Scheduler {\n public actions: Array> = [];\n /**\n * A flag to indicate whether the Scheduler is currently executing a batch of\n * queued actions.\n * @type {boolean}\n * @internal\n */\n public _active: boolean = false;\n /**\n * An internal ID used to track the latest asynchronous task such as those\n * coming from `setTimeout`, `setInterval`, `requestAnimationFrame`, and\n * others.\n * @type {any}\n * @internal\n */\n public _scheduled: TimerHandle | undefined;\n\n constructor(SchedulerAction: typeof Action, now: () => number = Scheduler.now) {\n super(SchedulerAction, now);\n }\n\n public flush(action: AsyncAction): void {\n const { actions } = this;\n\n if (this._active) {\n actions.push(action);\n return;\n }\n\n let error: any;\n this._active = true;\n\n do {\n if ((error = action.execute(action.state, action.delay))) {\n break;\n }\n } while ((action = actions.shift()!)); // exhaust the scheduler queue\n\n this._active = false;\n\n if (error) {\n while ((action = actions.shift()!)) {\n action.unsubscribe();\n }\n throw error;\n }\n }\n}\n", "import { AsyncAction } from './AsyncAction';\nimport { AsyncScheduler } from './AsyncScheduler';\n\n/**\n *\n * Async Scheduler\n *\n * Schedule task as if you used setTimeout(task, duration)\n *\n * `async` scheduler schedules tasks asynchronously, by putting them on the JavaScript\n * event loop queue. It is best used to delay tasks in time or to schedule tasks repeating\n * in intervals.\n *\n * If you just want to \"defer\" task, that is to perform it right after currently\n * executing synchronous code ends (commonly achieved by `setTimeout(deferredTask, 0)`),\n * better choice will be the {@link asapScheduler} scheduler.\n *\n * ## Examples\n * Use async scheduler to delay task\n * ```ts\n * import { asyncScheduler } from 'rxjs';\n *\n * const task = () => console.log('it works!');\n *\n * asyncScheduler.schedule(task, 2000);\n *\n * // After 2 seconds logs:\n * // \"it works!\"\n * ```\n *\n * Use async scheduler to repeat task in intervals\n * ```ts\n * import { asyncScheduler } from 'rxjs';\n *\n * function task(state) {\n * console.log(state);\n * this.schedule(state + 1, 1000); // `this` references currently executing Action,\n * // which we reschedule with new state and delay\n * }\n *\n * asyncScheduler.schedule(task, 3000, 0);\n *\n * // Logs:\n * // 0 after 3s\n * // 1 after 4s\n * // 2 after 5s\n * // 3 after 6s\n * ```\n */\n\nexport const asyncScheduler = new AsyncScheduler(AsyncAction);\n\n/**\n * @deprecated Renamed to {@link asyncScheduler}. Will be removed in v8.\n */\nexport const async = asyncScheduler;\n", "import { AsyncAction } from './AsyncAction';\nimport { Subscription } from '../Subscription';\nimport { QueueScheduler } from './QueueScheduler';\nimport { SchedulerAction } from '../types';\nimport { TimerHandle } from './timerHandle';\n\nexport class QueueAction extends AsyncAction {\n constructor(protected scheduler: QueueScheduler, protected work: (this: SchedulerAction, state?: T) => void) {\n super(scheduler, work);\n }\n\n public schedule(state?: T, delay: number = 0): Subscription {\n if (delay > 0) {\n return super.schedule(state, delay);\n }\n this.delay = delay;\n this.state = state;\n this.scheduler.flush(this);\n return this;\n }\n\n public execute(state: T, delay: number): any {\n return delay > 0 || this.closed ? super.execute(state, delay) : this._execute(state, delay);\n }\n\n protected requestAsyncId(scheduler: QueueScheduler, id?: TimerHandle, delay: number = 0): TimerHandle {\n // If delay exists and is greater than 0, or if the delay is null (the\n // action wasn't rescheduled) but was originally scheduled as an async\n // action, then recycle as an async action.\n\n if ((delay != null && delay > 0) || (delay == null && this.delay > 0)) {\n return super.requestAsyncId(scheduler, id, delay);\n }\n\n // Otherwise flush the scheduler starting with this action.\n scheduler.flush(this);\n\n // HACK: In the past, this was returning `void`. However, `void` isn't a valid\n // `TimerHandle`, and generally the return value here isn't really used. So the\n // compromise is to return `0` which is both \"falsy\" and a valid `TimerHandle`,\n // as opposed to refactoring every other instanceo of `requestAsyncId`.\n return 0;\n }\n}\n", "import { AsyncScheduler } from './AsyncScheduler';\n\nexport class QueueScheduler extends AsyncScheduler {\n}\n", "import { QueueAction } from './QueueAction';\nimport { QueueScheduler } from './QueueScheduler';\n\n/**\n *\n * Queue Scheduler\n *\n * Put every next task on a queue, instead of executing it immediately\n *\n * `queue` scheduler, when used with delay, behaves the same as {@link asyncScheduler} scheduler.\n *\n * When used without delay, it schedules given task synchronously - executes it right when\n * it is scheduled. However when called recursively, that is when inside the scheduled task,\n * another task is scheduled with queue scheduler, instead of executing immediately as well,\n * that task will be put on a queue and wait for current one to finish.\n *\n * This means that when you execute task with `queue` scheduler, you are sure it will end\n * before any other task scheduled with that scheduler will start.\n *\n * ## Examples\n * Schedule recursively first, then do something\n * ```ts\n * import { queueScheduler } from 'rxjs';\n *\n * queueScheduler.schedule(() => {\n * queueScheduler.schedule(() => console.log('second')); // will not happen now, but will be put on a queue\n *\n * console.log('first');\n * });\n *\n * // Logs:\n * // \"first\"\n * // \"second\"\n * ```\n *\n * Reschedule itself recursively\n * ```ts\n * import { queueScheduler } from 'rxjs';\n *\n * queueScheduler.schedule(function(state) {\n * if (state !== 0) {\n * console.log('before', state);\n * this.schedule(state - 1); // `this` references currently executing Action,\n * // which we reschedule with new state\n * console.log('after', state);\n * }\n * }, 0, 3);\n *\n * // In scheduler that runs recursively, you would expect:\n * // \"before\", 3\n * // \"before\", 2\n * // \"before\", 1\n * // \"after\", 1\n * // \"after\", 2\n * // \"after\", 3\n *\n * // But with queue it logs:\n * // \"before\", 3\n * // \"after\", 3\n * // \"before\", 2\n * // \"after\", 2\n * // \"before\", 1\n * // \"after\", 1\n * ```\n */\n\nexport const queueScheduler = new QueueScheduler(QueueAction);\n\n/**\n * @deprecated Renamed to {@link queueScheduler}. Will be removed in v8.\n */\nexport const queue = queueScheduler;\n", "import { AsyncAction } from './AsyncAction';\nimport { AnimationFrameScheduler } from './AnimationFrameScheduler';\nimport { SchedulerAction } from '../types';\nimport { animationFrameProvider } from './animationFrameProvider';\nimport { TimerHandle } from './timerHandle';\n\nexport class AnimationFrameAction extends AsyncAction {\n constructor(protected scheduler: AnimationFrameScheduler, protected work: (this: SchedulerAction, state?: T) => void) {\n super(scheduler, work);\n }\n\n protected requestAsyncId(scheduler: AnimationFrameScheduler, id?: TimerHandle, delay: number = 0): TimerHandle {\n // If delay is greater than 0, request as an async action.\n if (delay !== null && delay > 0) {\n return super.requestAsyncId(scheduler, id, delay);\n }\n // Push the action to the end of the scheduler queue.\n scheduler.actions.push(this);\n // If an animation frame has already been requested, don't request another\n // one. If an animation frame hasn't been requested yet, request one. Return\n // the current animation frame request id.\n return scheduler._scheduled || (scheduler._scheduled = animationFrameProvider.requestAnimationFrame(() => scheduler.flush(undefined)));\n }\n\n protected recycleAsyncId(scheduler: AnimationFrameScheduler, id?: TimerHandle, delay: number = 0): TimerHandle | undefined {\n // If delay exists and is greater than 0, or if the delay is null (the\n // action wasn't rescheduled) but was originally scheduled as an async\n // action, then recycle as an async action.\n if (delay != null ? delay > 0 : this.delay > 0) {\n return super.recycleAsyncId(scheduler, id, delay);\n }\n // If the scheduler queue has no remaining actions with the same async id,\n // cancel the requested animation frame and set the scheduled flag to\n // undefined so the next AnimationFrameAction will request its own.\n const { actions } = scheduler;\n if (id != null && actions[actions.length - 1]?.id !== id) {\n animationFrameProvider.cancelAnimationFrame(id as number);\n scheduler._scheduled = undefined;\n }\n // Return undefined so the action knows to request a new async id if it's rescheduled.\n return undefined;\n }\n}\n", "import { AsyncAction } from './AsyncAction';\nimport { AsyncScheduler } from './AsyncScheduler';\n\nexport class AnimationFrameScheduler extends AsyncScheduler {\n public flush(action?: AsyncAction): void {\n this._active = true;\n // The async id that effects a call to flush is stored in _scheduled.\n // Before executing an action, it's necessary to check the action's async\n // id to determine whether it's supposed to be executed in the current\n // flush.\n // Previous implementations of this method used a count to determine this,\n // but that was unsound, as actions that are unsubscribed - i.e. cancelled -\n // are removed from the actions array and that can shift actions that are\n // scheduled to be executed in a subsequent flush into positions at which\n // they are executed within the current flush.\n const flushId = this._scheduled;\n this._scheduled = undefined;\n\n const { actions } = this;\n let error: any;\n action = action || actions.shift()!;\n\n do {\n if ((error = action.execute(action.state, action.delay))) {\n break;\n }\n } while ((action = actions[0]) && action.id === flushId && actions.shift());\n\n this._active = false;\n\n if (error) {\n while ((action = actions[0]) && action.id === flushId && actions.shift()) {\n action.unsubscribe();\n }\n throw error;\n }\n }\n}\n", "import { AnimationFrameAction } from './AnimationFrameAction';\nimport { AnimationFrameScheduler } from './AnimationFrameScheduler';\n\n/**\n *\n * Animation Frame Scheduler\n *\n * Perform task when `window.requestAnimationFrame` would fire\n *\n * When `animationFrame` scheduler is used with delay, it will fall back to {@link asyncScheduler} scheduler\n * behaviour.\n *\n * Without delay, `animationFrame` scheduler can be used to create smooth browser animations.\n * It makes sure scheduled task will happen just before next browser content repaint,\n * thus performing animations as efficiently as possible.\n *\n * ## Example\n * Schedule div height animation\n * ```ts\n * // html: